ngraph-gtk-6.08.00/0000755000175000017500000000000013375640235010740 500000000000000ngraph-gtk-6.08.00/COPYING0000644000175000017500000004312213070106167011706 00000000000000 GNU GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright (C) 1989, 1991 Free Software Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software. Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations. Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all. The precise terms and conditions for copying, distribution and modification follow. GNU GENERAL PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you". Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does. 1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program. You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. 2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change. b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License. c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.) These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program. In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. 3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following: a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.) The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code. 4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it. 6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License. 7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program. If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances. It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. 8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. 9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation. 10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. END OF TERMS AND CONDITIONS How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. Copyright (C) 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA Also add information on how to contact you by electronic and paper mail. If the program is interactive, make it output a short notice like this when it starts in an interactive mode: Gnomovision version 69, Copyright (C) year name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items--whatever suits your program. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here is a sample; alter the names: Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker. , 1 April 1989 Ty Coon, President of Vice This General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Library General Public License instead of this License. ngraph-gtk-6.08.00/config.rpath0000755000175000017500000004443513070106167013173 00000000000000#! /bin/sh # Output a system dependent set of variables, describing how to set the # run time search path of shared libraries in an executable. # # Copyright 1996-2013 Free Software Foundation, Inc. # Taken from GNU libtool, 2001 # Originally 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. # # The first argument passed to this file is the canonical host specification, # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld # should be set by the caller. # # The set of defined variables is at the end of this script. # Known limitations: # - On IRIX 6.5 with CC="cc", the run time search patch must not be longer # than 256 bytes, otherwise the compiler driver will dump core. The only # known workaround is to choose shorter directory names for the build # directory and/or the installation directory. # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a shrext=.so host="$1" host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` # Code taken from libtool.m4's _LT_CC_BASENAME. for cc_temp in $CC""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'` # Code taken from libtool.m4's _LT_COMPILER_PIC. wl= if test "$GCC" = yes; then wl='-Wl,' else case "$host_os" in aix*) wl='-Wl,' ;; mingw* | cygwin* | pw32* | os2* | cegcc*) ;; hpux9* | hpux10* | hpux11*) wl='-Wl,' ;; irix5* | irix6* | nonstopux*) wl='-Wl,' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) case $cc_basename in ecc*) wl='-Wl,' ;; icc* | ifort*) wl='-Wl,' ;; lf95*) wl='-Wl,' ;; nagfor*) wl='-Wl,-Wl,,' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) wl='-Wl,' ;; ccc*) wl='-Wl,' ;; xl* | bgxl* | bgf* | mpixl*) wl='-Wl,' ;; como) wl='-lopt=' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ F* | *Sun*Fortran*) wl= ;; *Sun\ C*) wl='-Wl,' ;; esac ;; esac ;; newsos6) ;; *nto* | *qnx*) ;; osf3* | osf4* | osf5*) wl='-Wl,' ;; rdos*) ;; solaris*) case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) wl='-Qoption ld ' ;; *) wl='-Wl,' ;; esac ;; sunos4*) wl='-Qoption ld ' ;; sysv4 | sysv4.2uw2* | sysv4.3*) wl='-Wl,' ;; sysv4*MP*) ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) wl='-Wl,' ;; unicos*) wl='-Wl,' ;; uts4*) ;; esac fi # Code taken from libtool.m4's _LT_LINKER_SHLIBS. hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_direct=no hardcode_minus_L=no 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 "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; esac ld_shlibs=yes if test "$with_gnu_ld" = yes; then # 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. # Unlike libtool, we use -rpath here, not --rpath, since the documented # option of GNU ld is called -rpath, not --rpath. hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' case "$host_os" in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then ld_shlibs=no fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then : else ld_shlibs=no fi ;; haiku*) ;; interix[3-9]*) hardcode_direct=no hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; netbsd*) ;; solaris*) if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then ld_shlibs=no elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : 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 ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' else ld_shlibs=no fi ;; esac ;; sunos4*) hardcode_direct=yes ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; esac if test "$ld_shlibs" = no; then hardcode_libdir_flag_spec= fi else case "$host_os" in aix3*) # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test "$GCC" = yes; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no 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 # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac fi hardcode_direct=yes hardcode_libdir_separator=':' if test "$GCC" = yes; then case $host_os in aix4.[012]|aix4.[012].*) 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 hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac fi # Begin _LT_AC_SYS_LIBPATH_AIX. echo 'int main () { return 0; }' > conftest.c ${CC} ${LDFLAGS} conftest.c -o conftest aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` fi if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib" fi rm -f conftest.c conftest # End _LT_AC_SYS_LIBPATH_AIX. if test "$aix_use_runtimelinking" = yes; then hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' else hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" fi fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) ;; 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. hardcode_libdir_flag_spec=' ' libext=lib ;; darwin* | rhapsody*) hardcode_direct=no if { case $cc_basename in ifort*) true;; *) test "$GCC" = yes;; esac; }; then : else ld_shlibs=no fi ;; dgux*) hardcode_libdir_flag_spec='-L$libdir' ;; freebsd2.2*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; freebsd2*) hardcode_direct=yes hardcode_minus_L=yes ;; freebsd* | dragonfly*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; hpux9*) 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 ;; hpux10*) if test "$with_gnu_ld" = no; then 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 fi ;; hpux11*) if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no ;; *) hardcode_direct=yes # 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*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; netbsd*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; newsos6) hardcode_direct=yes hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then hardcode_libdir_flag_spec='${wl}-rpath,$libdir' else case "$host_os" in openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) hardcode_libdir_flag_spec='-R$libdir' ;; *) hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; esac fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; osf3*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) if test "$GCC" = yes; then hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' else # Both cc and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi hardcode_libdir_separator=: ;; solaris*) hardcode_libdir_flag_spec='-R$libdir' ;; sunos4*) hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes ;; sysv4) case $host_vendor in sni) hardcode_direct=yes # is this really true??? ;; siemens) hardcode_direct=no ;; motorola) hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac ;; sysv4.3*) ;; sysv4*MP*) if test -d /usr/nec; then ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) ;; sysv5* | sco3.2v5* | sco5v6*) hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' hardcode_libdir_separator=':' ;; uts4*) hardcode_libdir_flag_spec='-L$libdir' ;; *) ld_shlibs=no ;; esac fi # Check dynamic linker characteristics # Code taken from libtool.m4's _LT_SYS_DYNAMIC_LINKER. # Unlike libtool.m4, here we don't care about _all_ names of the library, but # only about the one the linker finds when passed -lNAME. This is the last # element of library_names_spec in libtool.m4, or possibly two of them if the # linker has special search rules. library_names_spec= # the last element of library_names_spec in libtool.m4 libname_spec='lib$name' case "$host_os" in aix3*) library_names_spec='$libname.a' ;; aix[4-9]*) library_names_spec='$libname$shrext' ;; amigaos*) case "$host_cpu" in powerpc*) library_names_spec='$libname$shrext' ;; m68k) library_names_spec='$libname.a' ;; esac ;; beos*) library_names_spec='$libname$shrext' ;; bsdi[45]*) library_names_spec='$libname$shrext' ;; cygwin* | mingw* | pw32* | cegcc*) shrext=.dll library_names_spec='$libname.dll.a $libname.lib' ;; darwin* | rhapsody*) shrext=.dylib library_names_spec='$libname$shrext' ;; dgux*) library_names_spec='$libname$shrext' ;; freebsd* | dragonfly*) case "$host_os" in freebsd[123]*) library_names_spec='$libname$shrext$versuffix' ;; *) library_names_spec='$libname$shrext' ;; esac ;; gnu*) library_names_spec='$libname$shrext' ;; haiku*) library_names_spec='$libname$shrext' ;; hpux9* | hpux10* | hpux11*) case $host_cpu in ia64*) shrext=.so ;; hppa*64*) shrext=.sl ;; *) shrext=.sl ;; esac library_names_spec='$libname$shrext' ;; interix[3-9]*) library_names_spec='$libname$shrext' ;; irix5* | irix6* | nonstopux*) library_names_spec='$libname$shrext' case "$host_os" in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;; *) libsuff= shlibsuff= ;; esac ;; esac ;; linux*oldld* | linux*aout* | linux*coff*) ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) library_names_spec='$libname$shrext' ;; knetbsd*-gnu) library_names_spec='$libname$shrext' ;; netbsd*) library_names_spec='$libname$shrext' ;; newsos6) library_names_spec='$libname$shrext' ;; *nto* | *qnx*) library_names_spec='$libname$shrext' ;; openbsd*) library_names_spec='$libname$shrext$versuffix' ;; os2*) libname_spec='$name' shrext=.dll library_names_spec='$libname.a' ;; osf3* | osf4* | osf5*) library_names_spec='$libname$shrext' ;; rdos*) ;; solaris*) library_names_spec='$libname$shrext' ;; sunos4*) library_names_spec='$libname$shrext$versuffix' ;; sysv4 | sysv4.3*) library_names_spec='$libname$shrext' ;; sysv4*MP*) library_names_spec='$libname$shrext' ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) library_names_spec='$libname$shrext' ;; tpf*) library_names_spec='$libname$shrext' ;; uts4*) library_names_spec='$libname$shrext' ;; esac sed_quote_subst='s/\(["`$\\]\)/\\\1/g' escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"` shlibext=`echo "$shrext" | sed -e 's,^\.,,'` escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <. # # 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: # https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub # 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 or ALIAS Canonicalize a configuration name. Options: -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-2018 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* | cloudabi*-eabi* | \ 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/'` ;; -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 \ | ba \ | 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 | ia16 | 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 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle \ | pru \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ | score \ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[234]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 \ | wasm32 \ | 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) ;; 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]-* | arc-* | arceb-* \ | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ | avr-* | avr32-* \ | ba-* \ | 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-* | ia16-* | 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-* \ | pru-* \ | pyramid-* \ | riscv32-* | riscv64-* \ | 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-* \ | wasm32-* \ | 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-pc 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 ;; amd64) basic_machine=x86_64-pc ;; amd64-*) basic_machine=x86_64-`echo "$basic_machine" | sed 's/^[^-]*-//'` ;; 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*) basic_machine=m68k-bull os=-sysv3 ;; e500v[12]) basic_machine=powerpc-unknown os=$os"spe" ;; e500v[12]-*) basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'` os=$os"spe" ;; 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 ;; 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 ;; 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 ;; 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 ;; nsv-tandem) basic_machine=nsv-tandem ;; nsx-tandem) basic_machine=nsx-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) 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) 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 ;; sh5el) basic_machine=sh5le-unknown ;; 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 ;; x64) basic_machine=x86_64-pc ;; 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 ;; 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 ;; 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 ;; 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 ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; # es1800 is here to avoid being matched by es* (a different OS) -es1800*) os=-ose ;; # Now 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* | -sortix* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ | -hiux* | -knetbsd* | -mirbsd* | -netbsd* \ | -bitrig* | -openbsd* | -solidbsd* | -libertybsd* \ | -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* | -glidix* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -midipix* | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* \ | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ | -morphos* | -superux* | -rtmk* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* \ | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox* | -bme* \ | -midnightbsd*) # 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 | -xray | -os68k* | -v88r* \ | -windows* | -osx | -abug | -netware* | -os9* \ | -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 ;; -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 ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) os=-mint ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; -pikeos*) # Until real need of OS specific support for # particular features comes up, bare metal # configurations are quite functional. case $basic_machine in arm*) os=-eabi ;; *) os=-elf ;; esac ;; -nacl*) ;; -ios) ;; -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 ;; pru-*) os=-elf ;; *-be) os=-beos ;; *-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 ;; *-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-functions 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: ngraph-gtk-6.08.00/winrc_version.awk0000644000175000017500000000030713070106167014244 00000000000000#!/usr/bin/awk BEGIN { n = gsub(/[.]/, ",", VERSION); if (n == 2) { VERSION = sprintf("%s,00", VERSION); } gsub(/,0/, ",", VERSION); } { gsub("%VERSION%", VERSION); print } ngraph-gtk-6.08.00/misc/0000755000175000017500000000000013375640234011672 500000000000000ngraph-gtk-6.08.00/misc/ngraph.10000644000175000017500000000663613070106167013160 00000000000000.nr N -1 .nr D 5 .TH NGRAPH 1 Local .UC 4 .SH NAME Ngraph \- creating scientific 2-dimensional graphs .SH SYNOPSIS .B ngraph [options] [data file(s) or ngp file] .PP .SH DESCRIPTION .\" This defines appropriate quote strings for nroff and troff .ds lq \&" .ds rq \&" .if t .ds lq `` .if t .ds rq '' .\" Just in case these number registers aren't set yet... .if \nN==0 .nr N 10 .if \nD==0 .nr D 5 .I \fINgraph\fR is the program to create scientific 2-dimensional graphs for researchers and engineers. Graphs can be exported to PostScript, SVG, PNG or PDF format. .PP .SH OPTIONS Command line options are: .PP .TP .B -L file load ngp file .TP .B -x column data column for the x axis .TP .B -y column data column for the y axis .TP .B -X use X axis as the x axis .TP .B -Y use Y axis as the y axis .TP .B -U use U axis as the x axis .TP .B -R use R axis as the y axis .TP .B -d {mark | line | polygon | curve | diagonal | arrow | rectangle | rectangle_fill | rectangle_solid_fill | errorbar_x | errorbar_y | staircase_x | staircase_y | bar_x | bar_y | bar_fill_x | bar_fill_y | bar_solid_fill_x | bar_solid_fill_y | fit} specify plot type .TP .B -m type specify mark type (0-89) .TP .B -o size specify mark size .TP .B -l style specify line style .TP .B -w width specify line width .TP .B -CR n specify red component of the 1st plot color (0-255) .TP .B -CG n specify green component of the 1st plot color (0-255) .TP .B -CB n specify blue component of the 1st plot color (0-255) .TP .B -cr n specify red component of the 2nd plot color (0-255) .TP .B -cg n specify green component of the 2nd plot color (0-255) .TP .B -cb n specify blue component of the 2nd plot color (0-255) .TP .B -s line specify number of the head skip .TP .B -r step specify number of the read step .TP .B -f line specify number of the final line .TP .B -vx n neighbor average of the x data .TP .B -vy n neighbor average of the y data .TP .B -mx formula specify math transformation for the x data .TP .B -my formula specify math transformation for the y data .TP .B -ex {linear | log | inverse | MJD} specify scale type of the x axis .TP .B -ey {linear | log | inverse | MJD} specify scale type of the y axis .TP .B -minx value specify minimum value of x axis .TP .B -maxx value specify maximum value of x axis .TP .B -incx value specify increment value of x axis .TP .B -miny value specify minimum value of y axis .TP .B -maxy value specify maximum value of y axis .TP .B -incy value specify increment value of y axis .TP .B -g load settings from data file .TP .B -png file convert ngp file to PNG format .TP .B -pdf file convert ngp file to PDF format .TP .B -ps file convert ngp file to PostScript format .TP .B -eps file convert ngp file to Encapsulated PostScript format .TP .B -svg file convert ngp file to SVG format .TP .B -gra file convert ngp file to GRA format .TP .B -dialog show print dialog (with \-p option) .TP .B -p file print ngp file .TP .B -n output ngp-file to stdout .TP .B -h, --help show help message .TP .B -v, --version show version of \fINgraph\fR .TP .B -V, --VERSION show detail information about \fINgraph\fR .SH FILES .TP .I ${HOME}/.Ngraph/Ngraph.nsc start up script .TP .I ${HOME}/.Ngraph/Ngraph.ini configuration file .TP .I ${HOME}/.Ngraph/Ngraph.ngp default graph .SH AUTHORS \fBSatoshi ISHIZAKA\fR .PP \fBHiroyuki Ito\fR .SH "SEE ALSO" .BR ngp2 (1) .PP .SH "COPYRIGHT" .br Copyright \(co 2003 Satoshi ISHIZAKA .br Copyright \(co 2008-2011 Hiroyuki Ito ngraph-gtk-6.08.00/misc/ngraph.applications0000644000175000017500000000021313070106167015467 00000000000000ngraph command=ngraph name=ngraph can_open_multiple_files=false expects_uris=false requires_terminal=false mime_types=image/x-ngraph ngraph-gtk-6.08.00/misc/ngraph.keys0000644000175000017500000000207013070106167013757 00000000000000application/x-ngraph open=ngraph %f icon_filename=application-x-ngraph.png description=Ngraph default_action_type=application short_list_application_ids_for_novice_user_level=ngraph short_list_application_ids_for_intermediate_user_level=ngraph short_list_application_ids_for_advanced_user_level=ngraph category=Documents/Graphics application/x-ngraph-script open=gedit %f icon_filename=application-x-ngraph-script.png description=Ngraph script default_action_type=application short_list_application_ids_for_novice_user_level=ngraph short_list_application_ids_for_intermediate_user_level=ngraph short_list_application_ids_for_advanced_user_level=ngraph category=Documents application/x-ngraph-graphic open=ngraph %f icon_filename=application-x-ngraph-graphic.png description=Ngraph graphic file default_action_type=application short_list_application_ids_for_novice_user_level=ngraph short_list_application_ids_for_intermediate_user_level=ngraph short_list_application_ids_for_advanced_user_level=ngraph category=Documents/Graphics ngraph-gtk-6.08.00/misc/ngraph.xml0000644000175000017500000000135713070106167013613 00000000000000 Ngraph Ngraph graphic file Ngraph ã®ã‚°ãƒ©ãƒ•ィックデータファイル Ngraph script file Ngraph script ã®ãƒ•ァイル ngraph-gtk-6.08.00/misc/ngraph.desktop0000644000175000017500000000052713070106167014462 00000000000000[Desktop Entry] Name=Ngraph Comment=create scientific 2-dimensional graphs Comment[ja]=科学技術用 2D ã‚°ãƒ©ãƒ•ä½œæˆ Exec=ngraph %f TryExec=ngraph Icon=ngraph Terminal=false Type=Application Version=1.0 Categories=GTK;GNOME;Graphics; MimeType=application/x-ngraph;application/x-ngraph-graphic Keywords=graph;scientific;chart;calculation; ngraph-gtk-6.08.00/misc/ngp2.10000644000175000017500000000250313070106167012534 00000000000000.nr N -1 .nr D 5 .TH NGP2 1 Local .UC 4 .SH NAME ngp2 \- convert ngp files to image .SH SYNOPSIS .B ngp2 [options] ngp files .PP .SH DESCRIPTION .\" This defines appropriate quote strings for nroff and troff .ds lq \&" .ds rq \&" .if t .ds lq `` .if t .ds rq '' .\" Just in case these number registers aren't set yet... .if \nN==0 .nr N 10 .if \nD==0 .nr D 5 .I \fIngp2\fR is the program to convert ngp files created by Ngraph to image files such as PostScript, SVG, PNG, PDF or GRA. .PP .SH OPTIONS Command line options are: .PP .TP .B -I ignore path of data files .TP .B -a automatically set scale of axis when scale is not set .TP .B -A clear and automatically set scale of axis .TP .B -c change directory to location of a ngp file .TP .B -d dpi set dpi .TP .B -ps, ps3 save as PostScript level 3 .TP .B -ps2 save as PostScript level 2 .TP .B -eps, -eps3 save as Encapsulated PostScript level 3 .TP .B -eps2 save as Encapsulated PostScript level 2 .TP .B -pdf save as Portable Document Format .TP .B -svg, -svg1.1 save as Scalable Vector Graphics version 1.1 .TP .B -svg1.2 save as Scalable Vector Graphics version 1.2 .TP .B -png save as Portable Network Graphics .TP .B -h, --help show help message .SH AUTHORS \fBHiroyuki Ito\fR .SH "SEE ALSO" .BR ngraph (1) .PP .SH "COPYRIGHT" .br Copyright \(co 1999 Hiroyuki Ito ngraph-gtk-6.08.00/misc/ngraph.bash0000644000175000017500000000561013070106167013724 00000000000000# ngraph completion # put this file in /etc/bash_completion.d/ have ngraph && _ngraph() { local cur COMPREPLY=() cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]} case "$prev" in -png|-pdf|-ps|-eps|-svg|-gra|-p|-L) _filedir 'ngp' return 0 ;; -ex|-ey) COMPREPLY=( $( compgen -W 'linear log inverse MJD' -- $cur ) ) return 0 ;; -d) COMPREPLY=( $( compgen -W 'mark line polygon curve diagonal \ arrow rectangle rectangle_fill rectangle_solid_fill \ errorbar_x errorbar_y staircase_x staircase_y bar_x bar_y \ bar_fill_x bar_fill_y bar_solid_fill_x bar_solid_fill_y fit' \ -- $cur ) ) return 0 ;; -m) COMPREPLY=( $( compgen -W "`seq 0 89`" -- $cur ) ) return 0 ;; -x|-y|-o|-l|-w|-cr|-cg|-cb|-CR|-CG|-CB|-s|-r|-f|-vx|-vy|-mx|-my|-minx|-maxx|-incx|-miny|-maxy|-incy) return 0 ;; esac case "$cur" in -*) COMPREPLY=( $( compgen -W '-h --help --version --VERSION \ -L -x -y -X -Y -d -m -o -l -w -cr -cg -cb -CR -CG -CB -s -r -f \ -vx -vy -mx -my -ex -ey -minx -maxx -incx -miny -maxy -incy -g \ -png -pdf -ps -eps -svg -gra -n -p -dialog' -- $cur ) ) ;; *) _filedir ;; esac } [ "${have:-}" ] && complete -F _ngraph $filenames ngraph have ngp2 && _ngp2() { local cur COMPREPLY=() cur=${COMP_WORDS[COMP_CWORD]} case "$cur" in -*) COMPREPLY=( $( compgen -W '-h --help -I -a -A -c \ -ps -ps3 -ps2 -eps -eps3 -eps2 \ -pdf -svg -svg1.1 -svg1.2 -png' -- $cur ) ) ;; *) _filedir 'ngp' ;; esac } [ "${have:-}" ] && complete -F _ngp2 $filenames ngp2 # have gra2ps && # _gra2ps() # { # local cur # COMPREPLY=() # cur=${COMP_WORDS[COMP_CWORD]} # prev=${COMP_WORDS[COMP_CWORD-1]} # case "$prev" in # -o) # _filedir '@(ps|eps)' # return 0 # ;; # -i) # _filedir 'ps' # return 0 # ;; # -p) # COMPREPLY=( $( compgen -W 'a3 a4 b4 a5 b5 letter legal' -- $cur ) ) # return 0 # ;; # -s) # return 0 # ;; # esac # case "$cur" in # -*) # COMPREPLY=( $( compgen -W '-o -i -c -e -p -l -r' -- $cur ) ) # ;; # *) # _filedir 'gra' # ;; # esac # } # [ "${have:-}" ] && complete -F _gra2ps $filenames gra2ps # have gra2wmf && # _gra2wmf() # { # local cur # COMPREPLY=() # cur=${COMP_WORDS[COMP_CWORD]} # prev=${COMP_WORDS[COMP_CWORD-1]} # case "$prev" in # -o) # _filedir 'wmf' # return 0 # ;; # -d) # return 0 # ;; # esac # case "$cur" in # -*) # COMPREPLY=( $( compgen -W '-o -d' -- $cur ) ) # ;; # *) # _filedir 'gra' # ;; # esac # } # [ "${have:-}" ] && complete -F _gra2wmf $filenames gra2wmf ngraph-gtk-6.08.00/misc/ngraph.mime0000644000175000017500000000015613070106167013736 00000000000000application/x-ngraph ext: ngp application/x-ngraph-script ext: nsc application/x-ngraph-graphic ext: gra ngraph-gtk-6.08.00/misc/Makefile.am0000644000175000017500000000020013070106167013630 00000000000000EXTRA_DIST = ngraph.applications ngraph.mime ngraph.keys ngraph.desktop ngraph.xml ngraph.bash dist_man_MANS = ngraph.1 ngp2.1 ngraph-gtk-6.08.00/misc/Makefile.in0000644000175000017500000004074213367273152013670 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = misc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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)" NROFF = nroff MANS = $(dist_man_MANS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(dist_man_MANS) $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ EXTRA_DIST = ngraph.applications ngraph.mime ngraph.keys ngraph.desktop ngraph.xml ngraph.bash dist_man_MANS = ngraph.1 ngp2.1 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) --gnu misc/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu misc/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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: $(dist_man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(dist_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='$(dist_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) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)"; 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-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-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 .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-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 .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: ngraph-gtk-6.08.00/src/0000755000175000017500000000000013375640227011530 500000000000000ngraph-gtk-6.08.00/src/ntime.h0000644000175000017500000000217613070106167012733 00000000000000/* * $Id: ntime.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ char *ndate(time_t *timep,int style); char *ntime(time_t *timep,int style); int gettimeval(char *s,time_t *time); char *nstrftime(const gchar *fmt, double mjd); void mjd2gd(double mjd, struct tm *tm); #define MJD2GD_YEAR_MIN (-1900 - 4800) ngraph-gtk-6.08.00/src/odarray.c0000644000175000017500000003136513073663051013260 00000000000000/* * $Id: odarray.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "object.h" #include "oiarray.h" #include "math/math_equation.h" #define NAME "darray" #define PARENT "object" #define OVERSION "1.00.00" #define ERRILNAME 100 #define ERROUTBOUND 101 static char *darrayerrorlist[]={ "", "array index is out of array bounds.", }; struct darray_local { double sum, ssum, min, max; int num; int modified; }; #define ERRNUM (sizeof(darrayerrorlist) / sizeof(*darrayerrorlist)) static int darrayinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct darray_local *local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; local = g_malloc0(sizeof(*local)); if (local == NULL) { return 1; } local->modified = TRUE; _putobj(obj, "_local", inst, local); return 0; } static int darraydone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int darrayget(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; double *po; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } po=(double *)arraynget(array,num); if (po==NULL) { error(obj, ERROUTBOUND); return 1; } rval->d=*po; return 0; } static int darrayput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; num=*(int *)argv[2]; val=*(double *)argv[3]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayput(array,&val,num)==NULL) return 1; return 0; } static int darray_modified(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; return 0; } static int darrayadd(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; val=*(double *)argv[2]; array = oarray_get_array(obj, inst, sizeof(double)); if (array==NULL) { return 1; } if (arrayadd(array,&val)==NULL) return 1; return 0; } static int darraypop(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; double val; int n; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; rval->d = 0.0; _getobj(obj,"@",inst,&array); if (array == NULL) { return 1; } n = arraynum(array) - 1; if (n < 0) { return 1; } val = arraynget_double(array, n); if (arrayndel(array, n) == NULL) { return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { return 1; } } rval->d = val; return 0; } static int darrayins(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; num=*(int *)argv[2]; val=*(double *)argv[3]; array = oarray_get_array(obj, inst, sizeof(double)); if (array==NULL) { return 1; } num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayins(array,&val,num)==NULL) return 1; return 0; } static int darrayunshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; val = * (double *) argv[2]; array = oarray_get_array(obj, inst, sizeof(double)); if (array == NULL) { return 1; } if (arrayins(array, &val, 0)==NULL) { return 1; } return 0; } static int darrayshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; rval->d = 0; _getobj(obj,"@",inst,&array); if (array == NULL) { return 1; } val = arraynget_double(array, 0); if (arrayndel(array, 0) == NULL) { return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { return 1; } } rval->d = val; return 0; } static int darraydel(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); if (array==NULL) return 1; num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayndel(array,num)==NULL) { error(obj, ERROUTBOUND); return 1; } if (arraynum(array)==0) { arrayfree(array); if (_putobj(obj,"@",inst,NULL)) return 1; } return 0; } static int darraysort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arraysort_double(array); return 0; } static int darrayrsort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arrayrsort_double(array); return 0; } static int darrayuniq(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; _getobj(obj, "@", inst, &array); arrayuniq_double(array); return 0; } static int darrayjoin(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; GString *str; int i, n; char *sep, *ptr; double val; struct darray_local *local; _getobj(obj, "_local", inst, &local); local->modified = TRUE; g_free(rval->str); rval->str = NULL; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } ptr = (char *) argv[2]; if (ptr) { sep = g_strcompress(ptr); } else { sep = g_strdup(","); } if (sep == NULL) { return 1; } str = g_string_sized_new(64); if (str == NULL) { g_free(sep); return 1; } for (i = 0; i < n; i++) { val = arraynget_double(array, i); g_string_append_printf(str, "%.15e%s", val, (i == n - 1) ? "" : sep); } rval->str = g_string_free(str, FALSE); g_free(sep); return 0; } static void cache_data(struct objlist *obj, N_VALUE *inst, struct darray_local *local) { struct narray *array; double min, max, sum, ssum, *data; int i, n; _getobj(obj, "@", inst, &array); n = arraynum(array); data = arraydata(array); min = 0; max = 0; sum = 0; ssum = 0; if (n > 0) { min = max = data[0]; for (i = 0; i < n; i++) { sum += data[i]; ssum += data[i] * data[i]; if (data[i] < min) { min = data[i]; } else if (data[i] > max) { max = data[i]; } } } local->num = n; local->min = min; local->max = max; local->sum = sum; local->ssum = ssum; local->modified = FALSE; } static int darray_sum(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } rval->d = local->sum; return 0; } static int darray_average(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } if (local->num == 0) { return 0; } rval->d = local->sum / local->num; return 0; } static int darray_rms(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } if (local->num == 0) { return 0; } rval->d = sqrt(local->ssum / local->num); return 0; } static int darray_sdev(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { double sum, ssum, val; int n; struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } n = local->num; if (n == 0) { return 0; } sum = local->sum; ssum = local->ssum; sum /= n; val = ssum / n - sum * sum; rval->d = (val < 0) ? 0 : sqrt(val); return 0; } static int darray_min(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } rval->d = local->min; return 0; } static int darray_max(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct darray_local *local; rval->d = 0; _getobj(obj, "_local", inst, &local); if (local->modified) { cache_data(obj, inst, local); } rval->d = local->max; return 0; } static int darray_map(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int i, n; double *data; MathEquation *code; MathValue val; if (argv[2] == NULL) { return 0; } _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 1; } code = oarray_create_math(obj, argv[1], argv[2]); if (code == NULL) { return 1; } data = arraydata(array); for (i = 0; i < n; i++) { val.val = data[i]; val.type = MATH_VALUE_NORMAL; math_equation_set_var(code, 0, &val); val.val = i; val.type = MATH_VALUE_NORMAL; math_equation_set_var(code, 1, &val); math_equation_calculate(code, &val); data[i] = val.val; } math_equation_free(code); return 0; } static struct objtable odarray[] = { {"init",NVFUNC,NEXEC,darrayinit,NULL,0}, {"done",NVFUNC,NEXEC,darraydone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NDARRAY,NREAD|NWRITE,darray_modified,NULL,0}, {"get",NDFUNC,NREAD|NEXEC,darrayget,"i",0}, {"put",NVFUNC,NREAD|NEXEC,darrayput,"id",0}, {"add",NVFUNC,NREAD|NEXEC,darrayadd,"d",0}, {"push",NVFUNC,NREAD|NEXEC,darrayadd,"d",0}, {"pop",NDFUNC,NREAD|NEXEC,darraypop,"",0}, {"ins",NVFUNC,NREAD|NEXEC,darrayins,"id",0}, {"unshift",NVFUNC,NREAD|NEXEC,darrayunshift,"d",0}, {"shift",NDFUNC,NREAD|NEXEC,darrayshift,"",0}, {"del",NVFUNC,NREAD|NEXEC,darraydel,"i",0}, {"join",NSFUNC,NREAD|NEXEC,darrayjoin,"s",0}, {"sort",NVFUNC,NREAD|NEXEC,darraysort,"",0}, {"rsort",NVFUNC,NREAD|NEXEC,darrayrsort,"",0}, {"uniq",NVFUNC,NREAD|NEXEC,darrayuniq,"",0}, {"sum", NDFUNC, NREAD|NEXEC, darray_sum, "", 0}, {"average", NDFUNC, NREAD|NEXEC, darray_average, "", 0}, {"sdev", NDFUNC, NREAD|NEXEC, darray_sdev, "", 0}, {"RMS", NDFUNC, NREAD|NEXEC, darray_rms, "", 0}, {"min", NDFUNC, NREAD|NEXEC, darray_min, "", 0}, {"max", NDFUNC, NREAD|NEXEC, darray_max, "", 0}, {"num", NIFUNC, NREAD|NEXEC, oarray_num, "", 0}, {"seq", NSFUNC, NREAD|NEXEC, oarray_seq, "", 0}, {"rseq", NSFUNC, NREAD|NEXEC, oarray_reverse_seq, "", 0}, {"reverse", NVFUNC, NREAD|NEXEC, oarray_reverse, "", 0}, {"slice", NVFUNC, NREAD|NEXEC, oarray_slice, "ii", 0}, {"map", NVFUNC, NREAD|NEXEC, darray_map, "s", 0}, {"_local", NPOINTER, 0, NULL, NULL, 0}, }; #define TBLNUM (sizeof(odarray) / sizeof(*odarray)) void * adddarray(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,odarray,ERRNUM,darrayerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/axis.h0000644000175000017500000000361713070106167012564 00000000000000/* * $Id: axis.h,v 1.2 2009-03-24 09:14:52 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #define AXISNORMAL 0 #define AXISLOGSMALL 1 #define AXISLOGNORM 2 #define AXISLOGBIG 3 #define AXISINVERSE 4 enum AXIS_SCALE_TYPE { AXIS_TYPE_LINEAR, AXIS_TYPE_LOG, AXIS_TYPE_INVERSE, AXIS_TYPE_MJD, }; enum AXIS_NUM_DIR { AXIS_NUM_POS_HORIZONTAL, AXIS_NUM_POS_PARALLEL1, AXIS_NUM_POS_PARALLEL2, AXIS_NUM_POS_NORMAL1, AXIS_NUM_POS_NORMAL2, AXIS_NUM_POS_OBLIQUE1, AXIS_NUM_POS_OBLIQUE2, AXIS_NUM_POS_NORMAL, /* for backward compatibility */ AXIS_NUM_POS_PARALLEL, /* for backward compatibility */ }; struct axislocal { int atype; double min,max,inc; int div; int tighten; double posst,posed; double posl,posm,dposl,dposm,dposs; int counts,countm,countsend,countmend,count; int num; }; int getaxispositionini(struct axislocal *alocal, int type,double min,double max,double inc,int div,int tighten); int getaxisposition(struct axislocal *alocal,double *po); double scale(double x); double roundmin(double min,double sc); extern char *axistypechar[]; ngraph-gtk-6.08.00/src/omerge.h0000644000175000017500000000012113235044045013060 00000000000000#ifndef OMERGE_HEADER #define OMERGE_HEADER void merge_cache_clear(void); #endif ngraph-gtk-6.08.00/src/ioutil.h0000644000175000017500000000556613070106167013132 00000000000000/* * $Id: ioutil.h,v 1.9 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef IOUTIL_HEADER #define IOUTIL_HEADER #include "common.h" #include #include #include #define DIRSEP '/' #define DIRSEP_STR "/" #define CONFSEP "/" #define CONFTOP "/" #define NOHANDLE -1 #if ! WINDOWS #define PATHSEP ":" #define NFMODE (S_IRUSR | S_IWUSR) #define NFMODE_NORMAL_FILE (NFMODE | S_IRGRP | S_IROTH) #else /* WINDOWS */ #define PATHSEP ";" #define NFMODE (S_IREAD | S_IWRITE) #define NFMODE_NORMAL_FILE NFMODE #endif /* WINDOWS */ void changefilename(char *name); void path_to_win(char *name); void char_type_buf_init(void); char *getfullpath(const char *name); char *getrelativepath(const char *name); char *getbasename(const char *name); char *getdirname(const char *name); char *getextention(char *name); char *getfilename(const char *dir, const char *sep, const char *file); int findfilename(const char *dir, const char *sep, const char *file); char *ngetcwd(void); char *nsearchpath(char *path,char *name,int shellscript); int nglob(char *path,char ***namelist); int fgetline(FILE *fp,char **buf); int fgetnline(FILE *fp,char *buf,int len); int nfgetc(FILE *fp); int nisatty(int fd); FILE *nfopen(const char *filename,const char *mode); int nopen(const char *path,int access,int mode); void nclose(int fd); int nredirect(int fd,int newfd); void nredirect2(int fd,int savefd); void nlseek(int fd,long offset,int fromwhere); int nread(int fd,char *buf,unsigned len); int nwrite(int fd,char *buf,unsigned len); int stdinfd(void); int stdoutfd(void); int stderrfd(void); void set_progress_func(void (* func)(int, const char *, double)); void set_progress(int pos, char *msg, double fraction); int n_mkstemp(const char *dir, char *templ, char **name); FILE *n_tmpfile(char **name); void n_tmpfile_close(FILE *fp, char *name); int nstat(const gchar *filename, GStatBuf *buf); int naccess(const gchar *filename, int mode); int nchdir(const gchar *path); char *get_utf8_filename(const char *name); char *get_localized_filename(const char *name); #endif /* IOUTIL_HEADER */ ngraph-gtk-6.08.00/src/oaxis.c0000644000175000017500000030313313356133076012740 00000000000000/* --*-coding:utf-8-*-- */ #include #include #include #include #include #include #include #include "common.h" #include "nhash.h" #include "ntime.h" #include "ioutil.h" #include "object.h" #include "mathfn.h" #include "spline.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "olegend.h" #include "axis.h" #include "nstring.h" #include "nconfig.h" #include "math/math_equation.h" #define NAME "axis" #define PARENT "draw" #define OVERSION "1.00.00" #define AXIS_HISTORY_NUM 30 #define INST_ARRAY_NUM 4 #define ERRAXISTYPE 100 #define ERRAXISHEAD 101 #define ERRAXISGAUGE 102 #define ERRAXISSPL 103 #define ERRMINMAX 104 #define ERRFORMAT 105 #define ERRGROUPING 106 #define ERRNUMMATH 107 static char *axiserrorlist[]={ "illegal axis type.", "illegal arrow/wave type.", "illegal gauge type.", "error: spline interpolation.", "illegal value of min/max/inc.", "illegal format.", "illegal grouping type.", "error in math:", }; #define ERRNUM (sizeof(axiserrorlist) / sizeof(*axiserrorlist)) enum AXIS_TYPE { AXIS_TYPE_SINGLE, AXIS_TYPE_FRAME, AXIS_TYPE_SECTION, AXIS_TYPE_CROSS, }; char *axistypechar[]={ N_("linear"), N_("log"), N_("inverse"), N_("MJD"), NULL }; static char *axisgaugechar[]={ N_("none"), N_("both"), N_("left"), N_("right"), NULL }; enum AXIS_GAUGE { AXIS_GAUGE_NONE, AXIS_GAUGE_BOTH, AXIS_GAUGE_LEFT, AXIS_GAUGE_RIGHT, }; static char *axisnumchar[]={ N_("none"), N_("left"), N_("right"), NULL }; enum AXIS_NUM_POS { AXIS_NUM_POS_NONE, AXIS_NUM_POS_LEFT, AXIS_NUM_POS_RIGHT, }; static char *anumalignchar[]={ N_("center"), N_("left"), N_("right"), N_("point"), NULL }; enum AXIS_NUM_NO_ZERO { AXIS_NUM_NO_ZERO_REGULAR, AXIS_NUM_NO_ZERO_NO_ZERO, AXIS_NUM_NO_ZERO_NO_FLOATING_POINT, AXIS_NUM_NO_ZERO_FALSE, AXIS_NUM_NO_ZERO_TRUE, }; static char *anumnozero[]={ N_("regular"), N_("no_zero"), N_("no_floating_point"), "\0false", /* for backward compatibility */ "\0true", /* for backward compatibility */ NULL, }; enum AXIS_NUM_ALIGN { AXIS_NUM_ALIGN_CENTER, AXIS_NUM_ALIGN_LEFT, AXIS_NUM_ALIGN_RIGHT, AXIS_NUM_ALIGN_POINT, }; static char *anumdirchar[]={ N_("horizontal"), N_("parallel1"), N_("parallel2"), N_("normal1"), N_("normal2"), N_("oblique1"), N_("oblique2"), "\0normal", /* for backward compatibility */ "\0parallel", /* for backward compatibility */ NULL }; static struct obj_config AxisConfig[] = { {"R", OBJ_CONFIG_TYPE_NUMERIC}, {"G", OBJ_CONFIG_TYPE_NUMERIC}, {"B", OBJ_CONFIG_TYPE_NUMERIC}, {"A", OBJ_CONFIG_TYPE_NUMERIC}, {"type", OBJ_CONFIG_TYPE_NUMERIC}, {"direction", OBJ_CONFIG_TYPE_NUMERIC}, {"baseline", OBJ_CONFIG_TYPE_NUMERIC}, {"width", OBJ_CONFIG_TYPE_NUMERIC}, {"arrow", OBJ_CONFIG_TYPE_NUMERIC}, {"arrow_length", OBJ_CONFIG_TYPE_NUMERIC}, {"wave", OBJ_CONFIG_TYPE_NUMERIC}, {"wave_length", OBJ_CONFIG_TYPE_NUMERIC}, {"wave_width", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_length1", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_width1", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_length2", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_width2", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_length3", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_width3", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_R", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_G", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_B", OBJ_CONFIG_TYPE_NUMERIC}, {"gauge_A", OBJ_CONFIG_TYPE_NUMERIC}, {"num", OBJ_CONFIG_TYPE_NUMERIC}, {"num_auto_norm", OBJ_CONFIG_TYPE_NUMERIC}, {"num_log_pow", OBJ_CONFIG_TYPE_NUMERIC}, {"num_pt", OBJ_CONFIG_TYPE_NUMERIC}, {"num_space", OBJ_CONFIG_TYPE_NUMERIC}, {"num_script_size", OBJ_CONFIG_TYPE_NUMERIC}, {"num_align", OBJ_CONFIG_TYPE_NUMERIC}, {"num_no_zero", OBJ_CONFIG_TYPE_NUMERIC}, {"num_direction", OBJ_CONFIG_TYPE_NUMERIC}, {"num_shift_p", OBJ_CONFIG_TYPE_NUMERIC}, {"num_shift_n", OBJ_CONFIG_TYPE_NUMERIC}, {"num_R", OBJ_CONFIG_TYPE_NUMERIC}, {"num_G", OBJ_CONFIG_TYPE_NUMERIC}, {"num_B", OBJ_CONFIG_TYPE_NUMERIC}, {"num_A", OBJ_CONFIG_TYPE_NUMERIC}, {"num_head", OBJ_CONFIG_TYPE_STRING}, {"num_format", OBJ_CONFIG_TYPE_STRING}, {"num_tail", OBJ_CONFIG_TYPE_STRING}, {"num_font", OBJ_CONFIG_TYPE_STRING}, {"num_font_style", OBJ_CONFIG_TYPE_NUMERIC}, {"style", OBJ_CONFIG_TYPE_STYLE}, {"gauge_style", OBJ_CONFIG_TYPE_STYLE}, }; static NHASH AxisConfigHash = NULL; static int get_axis_group_type(struct objlist *obj, N_VALUE *inst, N_VALUE **inst_array, int check_all); static N_VALUE * check_group(struct objlist *obj, char type, N_VALUE *inst, int num) { int n; char *group, *endptr; while (inst) { _getobj(obj, "group", inst, &group); if (group && group[0] == type) { n = strtol(group + 2, &endptr, 10); if (num == n) break; } inst = inst[obj->nextp].inst; } return inst; } static int axisuniqgroup(struct objlist *obj,char type) { int num; N_VALUE *inst; num = 0; do { num++; inst = check_group(obj, type, obj->root, num); if (inst == NULL) { inst = check_group(obj, type, obj->root2, num); } } while (inst); return num; } static int axisloadconfig(struct objlist *obj,N_VALUE *inst,char *conf) { return obj_load_config(obj, inst, conf, AxisConfigHash); } static int axisinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int width; int alen,awid,wlen,wwid,alpha; int bline; int len1,wid1,len2,wid2,len3,wid3; int pt,sx,sy,logpow,scriptsize; int autonorm,num,gnum,margin; char *font,*format,*group,*name; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; width=DEFAULT_LINE_WIDTH; alen=72426; awid=60000; wlen=300; wwid=DEFAULT_LINE_WIDTH; len1=100; wid1=DEFAULT_LINE_WIDTH; len2=200; wid2=DEFAULT_LINE_WIDTH; len3=300; wid3=DEFAULT_LINE_WIDTH; bline=TRUE; pt=DEFAULT_FONT_PT; sx=0; sy=100; autonorm=5; logpow=TRUE; scriptsize=7000; num=-1; alpha=255; margin=500; if (_putobj(obj,"baseline",inst,&bline)) return 1; if (_putobj(obj,"width",inst,&width)) return 1; if (_putobj(obj,"auto_scale_margin",inst,&margin)) return 1; if (_putobj(obj,"arrow_length",inst,&alen)) return 1; if (_putobj(obj,"arrow_width",inst,&awid)) return 1; if (_putobj(obj,"wave_length",inst,&wlen)) return 1; if (_putobj(obj,"wave_width",inst,&wwid)) return 1; if (_putobj(obj,"gauge_length1",inst,&len1)) return 1; if (_putobj(obj,"gauge_width1",inst,&wid1)) return 1; if (_putobj(obj,"gauge_length2",inst,&len2)) return 1; if (_putobj(obj,"gauge_width2",inst,&wid2)) return 1; if (_putobj(obj,"gauge_length3",inst,&len3)) return 1; if (_putobj(obj,"gauge_width3",inst,&wid3)) return 1; if (_putobj(obj,"gauge_A",inst,&alpha)) return 1; if (_putobj(obj,"num_pt",inst,&pt)) return 1; if (_putobj(obj,"num_script_size",inst,&scriptsize)) return 1; if (_putobj(obj,"num_auto_norm",inst,&autonorm)) return 1; if (_putobj(obj,"num_shift_p",inst,&sx)) return 1; if (_putobj(obj,"num_shift_n",inst,&sy)) return 1; if (_putobj(obj,"num_log_pow",inst,&logpow)) return 1; if (_putobj(obj,"num_num",inst,&num)) return 1; if (_putobj(obj,"num_A",inst,&alpha)) return 1; format = font = group = name = NULL; format = g_strdup("%g"); if (format == NULL) goto errexit; if (_putobj(obj,"num_format",inst,format)) goto errexit; font = g_strdup(fontchar[0]); if (font == NULL) goto errexit; if (_putobj(obj,"num_font",inst,font)) goto errexit; gnum = axisuniqgroup(obj,'a'); group = g_strdup_printf("a_%d", gnum); if (group == NULL) goto errexit; if (_putobj(obj,"group",inst,group)) goto errexit; name = g_strdup_printf("a_%d",gnum); if (name == NULL) goto errexit; if (_putobj(obj,"name",inst,name)) goto errexit; axisloadconfig(obj,inst,"[axis]"); return 0; errexit: g_free(format); g_free(font); g_free(group); g_free(name); return 1; } static int axisdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { N_VALUE *inst_array[INST_ARRAY_NUM]; int i; get_axis_group_type(obj, inst, inst_array, TRUE); for (i = 0; i < INST_ARRAY_NUM; i++) { if (inst_array[i] && inst_array[i] != inst) { char *group, *group2; int gnum; gnum = axisuniqgroup(obj,'a'); group = g_strdup_printf("a_%d", gnum); if (group == NULL) break; _getobj(obj, "group", inst_array[i], &group2); g_free(group2); if (_putobj(obj, "group", inst_array[i], group)) break; } } if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int axisput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; char *format; int sharp,minus,plus; int i,j; field=argv[1]; if (strcmp(field,"arrow_length")==0) { if (*(int *)(argv[2])<10000) *(int *)(argv[2])=10000; else if (*(int *)(argv[2])>200000) *(int *)(argv[2])=200000; } else if (strcmp(field,"arrow_width")==0) { if (*(int *)(argv[2])<10000) *(int *)(argv[2])=10000; else if (*(int *)(argv[2])>200000) *(int *)(argv[2])=200000; } else if ((strcmp(field,"wave_length")==0) || (strcmp(field,"wave_width"))==0) { if (*(int *)(argv[2])<1) *(int *)(argv[2])=1; } else if (strcmp(field,"num_pt")==0) { if (*(int *)(argv[2])100000) *(int *)(argv[2])=100000; } else if (strcmp(field,"num_format")==0) { format=(char *)(argv[2]); if (format==NULL) { error(obj,ERRFORMAT); return 1; } if (format[0]!='%') { error(obj,ERRFORMAT); return 1; } sharp=minus=plus=FALSE; for (i=1;(format[i]!='\0') && (strchr("#-+",format[i])!=NULL);i++) { if (format[i]=='#') { if (sharp) { error(obj,ERRFORMAT); return 1; } else sharp=TRUE; } if (format[i]=='-') { if (minus) { error(obj,ERRFORMAT); return 1; } else minus=TRUE; } if (format[i]=='+') { if (plus) { error(obj,ERRFORMAT); return 1; } else plus=TRUE; } } if (format[i]=='0') i++; for (j=i;isdigit(format[i]);i++) ; if (j-i>2) { error(obj,ERRFORMAT); return 1; } if (format[i]=='.') { i++; for (j=i;isdigit(format[i]);i++) ; if ((j-i>2) || (j==i)) { error(obj,ERRFORMAT); return 1; } } if (format[i]=='\0') { error(obj,ERRFORMAT); return 1; } if (strchr("efgEG",format[i])==NULL) { error(obj,ERRFORMAT); return 1; } if (format[i+1]!='\0') { error(obj,ERRFORMAT); return 1; } } else if (strcmp(field,"num_num")==0) { if (*(int *)(argv[2])<-1) *(int *)(argv[2])=-1; } return 0; } static int axisgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { N_VALUE *inst_array[INST_ARRAY_NUM]; int i; get_axis_group_type(obj, inst, inst_array, TRUE); for (i = 0; i < INST_ARRAY_NUM; i++) { if (inst_array[i]) { if (clear_bbox(obj, inst_array[i])) { return 1; } } } return 0; } static int axisdirection(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int dir; dir = * (int *) argv[2]; dir %= 36000; if (dir < 0) dir += 36000; * (int *) argv[2] = dir; return axisgeometry(obj, inst, rval, argc, argv); } static void axis_get_box(struct objlist *obj,N_VALUE *inst, int *pos) { int minx, miny, maxx, maxy; int x0, y0, x1, y1, length, direction; double dir; _getobj(obj, "x", inst, &x0); _getobj(obj, "y", inst, &y0); _getobj(obj, "length", inst, &length); _getobj(obj, "direction", inst, &direction); dir = direction / 18000.0 * MPI; x1 = x0 + nround(length * cos(dir)); y1 = y0 - nround(length * sin(dir)); maxx = minx = x0; maxy = miny = y0; if (x1 < minx) minx = x1; if (x1 > maxx) maxx = x1; if (y1 < miny) miny = y1; if (y1 > maxy) maxy = y1; pos[0] = minx; pos[1] = miny; pos[2] = maxx; pos[3] = maxy; pos[4] = x0; pos[5] = y0; pos[6] = x1; pos[7] = y1; #define POS_ARRAY_SIZE 8 } static int axisbbox2(struct objlist *obj, N_VALUE *inst, struct narray **rval) { int i, pos[POS_ARRAY_SIZE]; struct narray *array; if (inst == NULL) return 1; array = *rval; if (arraynum(array) != 0) return 0; if (array == NULL && (array = arraynew(sizeof(int))) == NULL) return 1; axis_get_box(obj, inst, pos); for (i = 0; i < POS_ARRAY_SIZE; i++) { arrayadd(array, pos + i); } if (arraynum(array) == 0) { arrayfree(array); return 1; } *rval = array; return 0; } static int check_direction(struct objlist *obj, int type, N_VALUE **inst_array) { int i, n, direction, normal_dir[] = {0, 9000, 0, 9000}; switch (type) { case 'f': case 's': for (i = 0; i < 2; i++) { int p1, p2, len1, len2; char *field; _getobj(obj, "length", inst_array[0 + i], &len1); _getobj(obj, "length", inst_array[2 + i], &len2); if ((len1 > 0 && len2 < 0) || (len1 < 0 && len2 > 0)) return 1; field = (i == 0) ? "x" : "y"; _getobj(obj, field, inst_array[1 - i], &p1); _getobj(obj, field, inst_array[3 - i], &p2); switch (i) { case 0: if ((len1 < 0 && p2 > p1) || (len1 > 0 && p2 < p1)) return 1; break; case 1: if ((len1 < 0 && p2 < p1) || (len1 > 0 && p2 > p1)) return 1; break; } } n = 4; break; case 'c': n = 2; break; case 'a': default: return 1; } for (i = 0; i < n; i++) { _getobj(obj, "direction", inst_array[i], &direction); if (direction != normal_dir[i]) { return 1; } } return 0; } #define FIND_X 1 #define FIND_Y 2 #define FIND_U 4 #define FIND_R 8 #define FIND_FRAME (FIND_X | FIND_Y | FIND_U | FIND_R) #define FIND_CROSS (FIND_X | FIND_Y) #define CHECK_FRAME(a) ((a & FIND_FRAME) == FIND_FRAME) #define CHECK_CROSS(a) ((a & FIND_CROSS) == FIND_CROSS) static int get_axis_group_type(struct objlist *obj, N_VALUE *inst, N_VALUE **inst_array, int check_all) { char *group, *group2; N_VALUE *inst2; char type; int find_axis, len, id, i; inst_array[0] = inst; for (i = 1; i < INST_ARRAY_NUM; i++) { inst_array[i] = NULL; } _getobj(obj, "group", inst, &group); if (group == NULL || group[0] == 'a') return 'a'; len = strlen(group); if (len < 3) return 'a'; if (check_all) { id = chkobjlastinst(obj); } else { _getobj(obj, "id", inst, &id); } find_axis = 0; type = group[0]; for (i = 0; i <= id; i++) { inst2 = chkobjinst(obj, i); _getobj(obj, "group", inst2, &group2); if (group2 == NULL || group2[0] != type) continue; len = strlen(group2); if (len < 3) continue; if (strcmp(group + 2, group2 + 2)) continue; switch (group2[1]) { case 'X': find_axis |= FIND_X; inst_array[0] = inst2; break; case 'Y': find_axis |= FIND_Y; inst_array[1] = inst2; break; case 'U': find_axis |= FIND_U; inst_array[2] = inst2; break; case 'R': find_axis |= FIND_R; inst_array[3] = inst2; break; } switch (type) { case 'f': case 's': if (CHECK_FRAME(find_axis)) { return type; } break; case 'c': if (CHECK_CROSS(find_axis)) { return type; } break; default: return 'a'; } } return -1; } static int get_axis_box(struct objlist *obj, N_VALUE *inst, int *minx, int *miny, int *maxx, int *maxy) { struct narray *rval2; rval2 = NULL; if (axisbbox2(obj, inst, &rval2)) return 1; *minx = arraynget_int(rval2, 0); *miny = arraynget_int(rval2, 1); *maxx = arraynget_int(rval2, 2); *maxy = arraynget_int(rval2, 3); arrayfree(rval2); return 0; } static struct narray * set_axis_box(struct narray *array, int minx, int miny, int maxx, int maxy, int add_point) { if (array == NULL && ((array = arraynew(sizeof(int))) == NULL)) return NULL; arrayadd(array,&minx); arrayadd(array,&miny); arrayadd(array,&maxx); arrayadd(array,&maxy); if (add_point) { arrayadd(array,&minx); arrayadd(array,&miny); arrayadd(array,&maxx); arrayadd(array,&miny); arrayadd(array,&maxx); arrayadd(array,&maxy); arrayadd(array,&minx); arrayadd(array,&maxy); } if (arraynum(array)==0) { arrayfree(array); return NULL; } return array; } static int get_axis_group_box(struct objlist *obj, N_VALUE **inst_array, int type, int *minx, int *miny, int *maxx, int *maxy) { int x0, y0, x1, y1, i; switch (type) { case 'a': if (get_axis_box(obj, inst_array[0], minx, miny, maxx, maxy)) return 1; break; case 'f': case 's': if (get_axis_box(obj, inst_array[0], minx, miny, maxx, maxy)) return 1; for (i = 1; i < 4; i++) { if (get_axis_box(obj, inst_array[i], &x0, &y0, &x1, &y1)) return 1; if (x0 < *minx) *minx = x0; if (y0 < *miny) *miny = y0; if (x1 > *maxx) *maxx = x1; if (y1 > *maxy) *maxy = y1; } break; case 'c': if (get_axis_box(obj, inst_array[0], minx, miny, maxx, maxy)) return 1; if (get_axis_box(obj, inst_array[1], &x0, &y0, &x1, &y1)) return 1; if (x0 < *minx) *minx = x0; if (y0 < *miny) *miny = y0; if (x1 > *maxx) *maxx = x1; if (y1 > *maxy) *maxy = y1; break; } return 0; } static int axisbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int type, dir; N_VALUE *inst_array[INST_ARRAY_NUM]; struct narray *array; int minx,miny,maxx,maxy; array = rval->array; if (arraynum(array) != 0) return 0; type = get_axis_group_type(obj, inst, inst_array, FALSE); switch (type) { case 'a': return axisbbox2(obj, inst, &rval->array); break; case 'f': case 's': case 'c': if (get_axis_group_box(obj, inst_array, type, &minx, &miny, &maxx, &maxy)) return 1; dir = check_direction(obj, type, inst_array); array = set_axis_box(array, minx, miny, maxx, maxy, ! dir); if (array == NULL) { rval->array = NULL; return 1; } rval->array = array; break; } return 0; } static int axismatch2(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy,err; int bminx,bminy,bmaxx,bmaxy; int i,num,*data; double x1,y1,x2,y2; double r,r2,r3,ip; struct narray *array; rval->i=FALSE; array=NULL; axisbbox2(obj,inst,&array); if (array==NULL) return 0; minx=*(int *)argv[2]; miny=*(int *)argv[3]; maxx=*(int *)argv[4]; maxy=*(int *)argv[5]; err=*(int *)argv[6]; if ((minx==maxx) && (miny==maxy)) { num=arraynum(array)-4; data=arraydata(array); for (i=0;ii=TRUE; break; } if (r2!=0) { ip=((x2-x1)*(minx-x1)+(y2-y1)*(miny-y1))/r2; if ((0<=ip) && (ip<=r2)) { x2=x1+(x2-x1)*ip/r2; y2=y1+(y2-y1)*ip/r2; r=sqrt((minx-x2)*(minx-x2)+(miny-y2)*(miny-y2)); if (ri=TRUE; break; } } } } } else { if (arraynum(array)<4) { arrayfree(array); return 1; } bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } arrayfree(array); return 0; } static int axismatch(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int i, n, type; N_VALUE *inst_array[INST_ARRAY_NUM]; int rval2, match; rval->i = FALSE; type = get_axis_group_type(obj, inst, inst_array, FALSE); n = 0; switch (type) { case 'a': return axismatch2(obj, inst, rval, argc, argv); break; case 'f': case 's': n = 4; break; case 'c': n = 2; break; } if (n) { match = FALSE; for (i = 0; i < n; i++) { axismatch2(obj, inst_array[i], (void *)&rval2, argc, argv); match = match || rval2; } rval->i = match; } return 0; } static int axismove2(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); x+=*(int *)argv[2]; y+=*(int *)argv[3]; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int axismove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i; N_VALUE *inst_array[INST_ARRAY_NUM]; if (* (int *) argv[2] == 0 && * (int *) argv[3] == 0) return 0; if (get_axis_group_type(obj, inst, inst_array, FALSE) < 0) return 1; for (i = 0; i < INST_ARRAY_NUM; i++) { if (inst_array[i]) { axismove2(obj, inst_array[i], rval, argc, argv); } } return 0; } static int axisrotate2(struct objlist *obj, N_VALUE *inst, int px, int py, int angle) { int x, y, dir; if (inst == NULL) return 1; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); _getobj(obj, "direction", inst, &dir); rotate(px, py, angle, &x, &y); dir += angle; dir %= 36000; if (_putobj(obj, "x", inst, &x)) return 1; if (_putobj(obj, "y", inst, &y)) return 1; if (_putobj(obj, "direction", inst, &dir)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int axisrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i, n, type, angle, use_pivot, px, py, minx, miny, maxx, maxy; N_VALUE *inst_array[INST_ARRAY_NUM]; angle = *(int *) argv[2]; use_pivot = * (int *) argv[3]; px = *(int *) argv[4]; py = *(int *) argv[5]; angle %= 36000; if (angle < 0) angle += 36000; type = get_axis_group_type(obj, inst, inst_array, FALSE); switch (type) { case 'a': n = 1; break; case 'f': case 's': n = 4; break; case 'c': n = 2; break; default: return 0; } if (! use_pivot) { if (get_axis_group_box(obj, inst_array, type, &minx, &miny, &maxx, &maxy)) return 1; px = (minx + maxx) / 2; py = (miny + maxy) / 2; } for (i = 0; i < n; i++) { axisrotate2(obj, inst_array[i], px, py, angle); } return 0; } static int axisflip2(struct objlist *obj, N_VALUE *inst, int px, int py, enum FLIP_DIRECTION dir) { int x, y, a, p, g_dir, n_dir, n_align; if (inst == NULL) return 1; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); _getobj(obj, "direction", inst, &a); _getobj(obj, "gauge", inst, &g_dir); _getobj(obj, "num", inst, &n_dir); _getobj(obj, "num_align", inst, &n_align); switch (dir) { case FLIP_DIRECTION_HORIZONTAL: a = 18000 - a; p = px; switch (n_align) { case AXIS_NUM_ALIGN_LEFT: n_align = AXIS_NUM_ALIGN_RIGHT; break; case AXIS_NUM_ALIGN_RIGHT: n_align= AXIS_NUM_ALIGN_LEFT; break; } break; case FLIP_DIRECTION_VERTICAL: a = -a; p = py; break; default: p = 0; } switch (g_dir) { case AXIS_GAUGE_LEFT: g_dir = AXIS_GAUGE_RIGHT; break; case AXIS_GAUGE_RIGHT: g_dir = AXIS_GAUGE_LEFT; break; }; switch (n_dir) { case AXIS_NUM_POS_LEFT: n_dir = AXIS_NUM_POS_RIGHT; break; case AXIS_NUM_POS_RIGHT: n_dir = AXIS_NUM_POS_LEFT; break; } a %= 36000; a += (a < 0) ? 36000 : 0; flip(p, dir, &x, &y); if (_putobj(obj, "x", inst, &x)) return 1; if (_putobj(obj, "y", inst, &y)) return 1; if (_putobj(obj, "direction", inst, &a)) return 1; if (_putobj(obj, "gauge", inst, &g_dir)) return 1; if (_putobj(obj, "num", inst, &n_dir)) return 1; if (_putobj(obj, "num_align", inst, &n_align)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int axisflip(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i, n, type, use_pivot, px, py, minx, miny, maxx, maxy; N_VALUE *inst_array[INST_ARRAY_NUM]; enum FLIP_DIRECTION dir; dir = (* (int *) argv[2] == FLIP_DIRECTION_HORIZONTAL) ? FLIP_DIRECTION_HORIZONTAL : FLIP_DIRECTION_VERTICAL; use_pivot = * (int *) argv[3]; px = py = *(int *) argv[4]; type = get_axis_group_type(obj, inst, inst_array, FALSE); switch (type) { case 'a': n = 1; break; case 'f': case 's': n = 4; break; case 'c': n = 2; break; default: return 0; } if (! use_pivot) { if (get_axis_group_box(obj, inst_array, type, &minx, &miny, &maxx, &maxy)) return 1; px = (minx + maxx) / 2; py = (miny + maxy) / 2; } for (i = 0; i < n; i++) { axisflip2(obj, inst_array[i], px, py, dir); } return 0; } static int axischange2(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int len,dir,x,y; double x2,y2; int point,x0,y0; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"length",inst,&len); _getobj(obj,"direction",inst,&dir); x2=x+len*cos(dir*MPI/18000.0); y2=y-len*sin(dir*MPI/18000.0); point=*(int *)argv[2]; x0=*(int *)argv[3]; y0=*(int *)argv[4]; if (point==0) { x+=x0; y+=y0; } else if (point==1) { x2+=x0; y2+=y0; } len=sqrt((x2-x)*(x2-x)+(y2-y)*(y2-y)); if ((x2-x)==0) { if ((y2-y)==0) dir=0; else if ((y2-y)>0) dir=27000; else dir=9000; } else { dir=atan(-(y2-y)/(x2-x))/MPI*18000.0; if ((x2-x)<0) dir+=18000; if (dir<0) dir+=36000; } if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (_putobj(obj,"length",inst,&len)) return 1; if (_putobj(obj,"direction",inst,&dir)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static void axis_change_point0(struct objlist *obj, int type, N_VALUE **inst_array, int x0, int y0) { int len, x, y; switch (type) { case 'f': case 's': _getobj(obj, "x", inst_array[2], &x); _getobj(obj, "y", inst_array[2], &y); _getobj(obj, "length", inst_array[2], &len); x += x0; y += y0; len -= x0; _putobj(obj, "x", inst_array[2], &x); _putobj(obj, "y", inst_array[2], &y); _putobj(obj, "length", inst_array[2], &len); _getobj(obj, "length", inst_array[3], &len); len -= y0; _putobj(obj, "length", inst_array[3], &len); /* FALLTHROUGH */ case 'c': _getobj(obj, "x", inst_array[0], &x); _getobj(obj, "length", inst_array[0], &len); x += x0; len -= x0; _putobj(obj, "x", inst_array[0], &x); _putobj(obj, "length", inst_array[0], &len); _getobj(obj, "x", inst_array[1], &x); _getobj(obj, "length", inst_array[1], &len); x += x0; len -= y0; _putobj(obj, "x", inst_array[1], &x); _putobj(obj, "length", inst_array[1], &len); break; } } static void axis_change_point1(struct objlist *obj, int type, N_VALUE **inst_array, int x0, int y0) { int len, x, y; switch (type) { case 'f': case 's': _getobj(obj, "y", inst_array[2], &y); _getobj(obj, "length", inst_array[2], &len); y += y0; len += x0; _putobj(obj, "y", inst_array[2], &y); _putobj(obj, "length", inst_array[2], &len); _getobj(obj, "x", inst_array[3], &x); _getobj(obj, "length", inst_array[3], &len); x += x0; len -= y0; _putobj(obj, "x", inst_array[3], &x); _putobj(obj, "length", inst_array[3], &len); /* FALLTHROUGH */ case 'c': _getobj(obj, "length", inst_array[0], &len); len += x0; _putobj(obj, "length", inst_array[0], &len); _getobj(obj, "length", inst_array[1], &len); len -= y0; _putobj(obj, "length", inst_array[1], &len); break; } } static void axis_change_point2(struct objlist *obj, int type, N_VALUE **inst_array, int x0, int y0) { int len, x, y; switch (type) { case 'f': case 's': _getobj(obj, "length", inst_array[2], &len); len += x0; _putobj(obj, "length", inst_array[2], &len); _getobj(obj, "x", inst_array[3], &x); _getobj(obj, "y", inst_array[3], &y); _getobj(obj, "length", inst_array[3], &len); x += x0; y += y0; len += y0; _putobj(obj, "x", inst_array[3], &x); _putobj(obj, "y", inst_array[3], &y); _putobj(obj, "length", inst_array[3], &len); /* FALLTHROUGH */ case 'c': _getobj(obj, "y", inst_array[0], &y); _getobj(obj, "length", inst_array[0], &len); y += y0; len += x0; _putobj(obj, "y", inst_array[0], &y); _putobj(obj, "length", inst_array[0], &len); _getobj(obj, "y", inst_array[1], &y); _getobj(obj, "length", inst_array[1], &len); y += y0; len += y0; _putobj(obj, "y", inst_array[1], &y); _putobj(obj, "length", inst_array[1], &len); break; } } static void axis_change_point3(struct objlist *obj, int type, N_VALUE **inst_array, int x0, int y0) { int len, x, y; switch (type) { case 'f': case 's': _getobj(obj, "x", inst_array[2], &x); _getobj(obj, "length", inst_array[2], &len); x += x0; len -= x0; _putobj(obj, "x", inst_array[2], &x); _putobj(obj, "length", inst_array[2], &len); _getobj(obj, "y", inst_array[3], &y); _getobj(obj, "length", inst_array[3], &len); y += y0; len += y0; _putobj(obj, "y", inst_array[3], &y); _putobj(obj, "length", inst_array[3], &len); /* FALLTHROUGH */ case 'c': _getobj(obj, "x", inst_array[0], &x); _getobj(obj, "y", inst_array[0], &y); _getobj(obj, "length", inst_array[0], &len); x += x0; y += y0; len -= x0; _putobj(obj, "x", inst_array[0], &x); _putobj(obj, "y", inst_array[0], &y); _putobj(obj, "length", inst_array[0], &len); _getobj(obj, "x", inst_array[1], &x); _getobj(obj, "y", inst_array[1], &y); _getobj(obj, "length", inst_array[1], &len); x += x0; y += y0; len += y0; _putobj(obj, "x", inst_array[1], &x); _putobj(obj, "y", inst_array[1], &y); _putobj(obj, "length", inst_array[1], &len); break; } } static int axischange(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { N_VALUE *inst_array[INST_ARRAY_NUM]; int type, point, x0, y0, len; type = get_axis_group_type(obj, inst, inst_array, FALSE); point= * (int *) argv[2]; x0 = * (int *) argv[3]; y0 = * (int *) argv[4]; switch (type) { case 'a': return axischange2(obj, inst, rval, argc, argv); break; case 'f': case 's': case 'c': if (check_direction(obj, type, inst_array)) return 0; _getobj(obj, "length", inst_array[0], &len); if (len < 0) { switch (point) { case 0: point = 1; break; case 1: point = 0; break; case 2: point = 3; break; case 3: point = 2; break; } } _getobj(obj, "length", inst_array[1], &len); if (len < 0) { switch (point) { case 0: point = 3; break; case 1: point = 2; break; case 2: point = 1; break; case 3: point = 0; break; } } switch (point) { case 0: axis_change_point0(obj, type, inst_array, x0, y0); break; case 1: axis_change_point1(obj, type, inst_array, x0, y0); break; case 2: axis_change_point2(obj, type, inst_array, x0, y0); break; case 3: axis_change_point3(obj, type, inst_array, x0, y0); break; } if (clear_bbox(obj, inst)) return 1; break; } return 0; } static int axiszoom2(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y,len,refx,refy,preserve_width; double zoom_x, zoom_y, zoom_n, zoom_p, zoom; int pt,space,wid1,wid2,wid3,len1,len2,len3,wid,wlen,wwid,direction; struct narray *style,*gstyle; int i,snum,*sdata,gsnum,*gsdata; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; zoom_x = (*(int *) argv[2]) / 10000.0; zoom_y = (*(int *) argv[3]) / 10000.0; zoom = MIN(zoom_x, zoom_y); refx = (*(int *)argv[4]); refy = (*(int *)argv[5]); preserve_width = (*(int *)argv[6]); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"length",inst,&len); _getobj(obj,"width",inst,&wid); _getobj(obj,"num_pt",inst,&pt); _getobj(obj,"num_space",inst,&space); _getobj(obj,"wave_length",inst,&wlen); _getobj(obj,"wave_width",inst,&wwid); _getobj(obj,"gauge_length1",inst,&len1); _getobj(obj,"gauge_width1",inst,&wid1); _getobj(obj,"gauge_length2",inst,&len2); _getobj(obj,"gauge_width2",inst,&wid2); _getobj(obj,"gauge_length3",inst,&len3); _getobj(obj,"gauge_width3",inst,&wid3); _getobj(obj,"gauge_style",inst,&gstyle); _getobj(obj,"style",inst,&style); _getobj(obj,"direction",inst,&direction); snum=arraynum(style); sdata=arraydata(style); gsnum=arraynum(gstyle); gsdata=arraydata(gstyle); direction = calc_zoom_direction(direction, zoom_x, zoom_y, &zoom_p, &zoom_n); len*=zoom_p; wlen*=zoom_n; len1*=zoom_n; len2*=zoom_n; len3*=zoom_n; x=(x-refx)*zoom_x+refx; y=(y-refy)*zoom_y+refy; pt*=zoom; space*=zoom; if (! preserve_width) { wid*=zoom; wid1*=zoom; wid2*=zoom; wid3*=zoom; wwid*=zoom; for (i=0;idirection<9000) { px0=hx1; py0=hy1; } else if (aconf->direction<18000) { px0=hx1; py0=hy0; } else if (aconf->direction<27000) { px0=hx0; py0=hy0; } else { px0=hx0; py0=hy1; } } else { if (aconf->direction<9000) { px0=hx0; py0=hy0; } else if (aconf->direction<18000) { px0=hx0; py0=hy1; } else if (aconf->direction<27000) { px0=hx1; py0=hy1; } else { px0=hx1; py0=hy0; } } switch (align) { case AXIS_NUM_ALIGN_CENTER: px1=(hx0+hx1)/2; break; case AXIS_NUM_ALIGN_LEFT: px1=hx0; break; case AXIS_NUM_ALIGN_RIGHT: px1=hx1; break; case AXIS_NUM_ALIGN_POINT: px1=ilenmax+plen/2; break; default: /* never reached */ px1 = 0; } py1=(hy0+hy1)/2; fx0=px1-px0; fy0=py1-py0; t=cos(aconf->dir)*fx0-sin(aconf->dir)*fy0; *x1=fx0-t*cos(aconf->dir); *y1=fy0+t*sin(aconf->dir); if (side==AXIS_NUM_POS_LEFT) { if (aconf->direction<9000) px1=hx1; else if (aconf->direction<18000) px1=hx1; else if (aconf->direction<27000) px1=hx0; else px1=hx0; } else { if (aconf->direction<9000) px1=hx0; else if (aconf->direction<18000) px1=hx0; else if (aconf->direction<27000) px1=hx1; else px1=hx1; } py1=(hy0+hy1)/2; fx0=px1-px0; fy0=py1-py0; t=cos(aconf->dir)*fx0-sin(aconf->dir)*fy0; *x2=fx0-t*cos(aconf->dir); *y2=fy0+t*sin(aconf->dir); *len=abs(hx1-hx0); } static void get_num_ofst_parallel(const struct axis_config *aconf, int side, int hx0, int hy0, int hx1, int hy1, int *x1, int *y1, int *x2, int *y2, int *len) { int py1; py1=(hy0+hy1)/2; if (side==AXIS_NUM_POS_LEFT) py1*=-1; *x1=-py1*sin(aconf->dir); *y1=-py1*cos(aconf->dir); *x2=-py1*sin(aconf->dir); *y2=-py1*cos(aconf->dir); *len=abs(hx1-hx0); } static void get_num_ofst_normal1(const struct axis_config *aconf, int align, int side, int ilenmax, int plen, int hx0, int hy0, int hx1, int hy1, int *x1, int *y1, int *x2, int *y2, int *len) { int py1; switch (side) { case AXIS_NUM_POS_LEFT: switch (align) { case AXIS_NUM_ALIGN_CENTER: py1 = (hx1 - hx0) / 2; break; case AXIS_NUM_ALIGN_LEFT: py1 = hx1 - hx0; break; case AXIS_NUM_ALIGN_RIGHT: py1 = 0; break; case AXIS_NUM_ALIGN_POINT: py1 = plen / 2; break; default: /* never reached */ py1 = 0; } break; case AXIS_NUM_POS_RIGHT: switch (align) { case AXIS_NUM_ALIGN_CENTER: py1 = (hx0 - hx1) / 2; break; case AXIS_NUM_ALIGN_LEFT: py1 = 0; break; case AXIS_NUM_ALIGN_RIGHT: py1 = hx0 - hx1; break; case AXIS_NUM_ALIGN_POINT: py1 = hx0 - hx1 + plen / 2; break; default: /* never reached */ py1 = 0; } break; default: /* never reached */ py1 = 0; } *x1 = -py1 * sin(aconf->dir); *y1 = -py1 * cos(aconf->dir); *x2 = *y2 = 0; *len = abs(hx1 - hx0); } static void get_num_ofst_normal2(const struct axis_config *aconf, int align, int side, int ilenmax, int plen, int hx0, int hy0, int hx1, int hy1, int *x1, int *y1, int *x2, int *y2, int *len) { int py1; switch (side) { case AXIS_NUM_POS_LEFT: switch (align) { case AXIS_NUM_ALIGN_CENTER: py1 = (hx1 - hx0) / 2; break; case AXIS_NUM_ALIGN_LEFT: py1 = hx1 - hx0; break; case AXIS_NUM_ALIGN_RIGHT: py1 = 0; break; case AXIS_NUM_ALIGN_POINT: py1 = hx1 - ilenmax - plen / 2; break; default: /* never reached */ py1 = 0; } break; case AXIS_NUM_POS_RIGHT: switch (align) { case AXIS_NUM_ALIGN_CENTER: py1 = (hx0 - hx1) / 2; break; case AXIS_NUM_ALIGN_LEFT: py1 = 0; break; case AXIS_NUM_ALIGN_RIGHT: py1 = hx0 - hx1; break; case AXIS_NUM_ALIGN_POINT: py1 = hx0 - ilenmax - plen / 2; break; default: /* never reached */ py1 = 0; } break; default: /* never reached */ py1 = 0; } *x1 = -py1 * sin(aconf->dir); *y1 = -py1 * cos(aconf->dir); *x2 = *y2 = 0; *len = abs(hx1 - hx0); } static void get_num_ofst_oblique1(const struct axis_config *aconf, int align, int side, int ilenmax, int plen, int hx0, int hy0, int hx1, int hy1, int *x1, int *y1, int *x2, int *y2, int *len) { int w, h; double sin_t, cos_t; switch (side) { case AXIS_NUM_POS_LEFT: w = abs(hx1 - hx0); h = abs(hy1 - hy0); cos_t = cos(aconf->dir + MPI / 4); sin_t = sin(aconf->dir + MPI / 4); *x1 = w * cos_t - h * sin_t; *y1 = - w * sin_t - h * cos_t; break; case AXIS_NUM_POS_RIGHT: *x1 = *y1 = 0; break; default: /* never reached */ *x1 = 0; *y1 = 0; } *x2 = *y2 = 0; *len = abs(hx1 - hx0); } static void get_num_ofst_oblique2(const struct axis_config *aconf, int align, int side, int ilenmax, int plen, int hx0, int hy0, int hx1, int hy1, int *x1, int *y1, int *x2, int *y2, int *len) { int w, h; double sin_t, cos_t; switch (side) { case AXIS_NUM_POS_LEFT: w = abs(hx1 - hx0); h = abs(hy1 - hy0); cos_t = cos(aconf->dir - MPI / 4); sin_t = sin(aconf->dir - MPI / 4); *x1 = - w * cos_t - h * sin_t; *y1 = w * sin_t - h * cos_t; break; case AXIS_NUM_POS_RIGHT: *x1 = *y1 = 0; break; default: /* never reached */ *x1 = 0; *y1 = 0; } *x2 = *y2 = 0; *len = abs(hx1 - hx0); } static char * mjd_to_date_str(const struct axis_config *aconf, double mjd, const gchar *date_format) { struct tm tm; const gchar *fmt_y = "%Y", *fmt_ym = "%Y-%m", *fmt_ymd = "%Y-%m-%d", *fmt_ymdhms = "%Y-%m-%d\\&\\n%H:%M:%S\\&", *fmt_ymdhm = "%Y-%m-%d\\&\\n%H:%M\\&", *fmt_hms = "%H:%M:%S", *fmt_hm = "%H:%M", *fmt; mjd2gd(mjd, &tm); if (tm.tm_year < MJD2GD_YEAR_MIN) { return NULL; } if (date_format && date_format[0]) { fmt = date_format; } else { if (fabs(aconf->max - aconf->min) < 1) { if (tm.tm_sec == 0) { fmt = fmt_hm; } else { fmt = fmt_hms; } } else if (fabs(aconf->max - aconf->min) > 365) { if (tm.tm_sec == 0) { if (tm.tm_hour == 0 && tm.tm_min == 0) { if (tm.tm_mday == 1) { if (tm.tm_mon == 0) { fmt = fmt_y; } else { fmt = fmt_ym; } } else { fmt = fmt_ymd; } } else { fmt = fmt_ymdhm; } } else { fmt = fmt_ymdhms; } } else { if (tm.tm_sec == 0) { if (tm.tm_hour == 0 && tm.tm_min == 0) { fmt = fmt_ymd; } else { fmt = fmt_ymdhm; } } else { fmt = fmt_ymdhms; } } } return nstrftime(fmt, mjd); } static char * get_axis_gauge_num_str(const char *format, double a, int no_flt_zero) { int i, j, len; char *s; char format2[256], pm[] = "±"; GString *num; if (no_flt_zero && a == 0.0) { return g_strdup("0"); } num = g_string_sized_new(16); if (num == NULL) { return NULL; } s = strchr(format, '+'); if (a == 0 && s) { len = strlen(format); for (j = 0; j < (int) sizeof(pm) - 1; j++) { format2[j] = pm[j]; } for (i = 0; i < len && j < (int) sizeof(format2) - 1; i++) { format2[j] = format[i]; if (format[i] != '+') { j++; } } format2[j] = '\0'; g_string_printf(num, format2, a); } else { g_string_printf(num, format, a); } len = num->len; for (i = 0; i < len; i++) { if (num->str[i] == 'E' || num->str[i] == 'e') { switch (num->str[i + 1]) { case '+': j = 2; if (i + 2 < len && num->str[i + 2] == '0') { j++; } g_string_erase(num, i, j); break; case '-': if (i + 2 < len && num->str[i + 2] == '0') { g_string_erase(num, i + 2, 1); } g_string_erase(num, i, 1); break; case '0': /* never reached */ g_string_erase(num, i, 2); break; default: /* never reached */ g_string_erase(num, i, 1); break; } g_string_insert(num, i, "×10^"); g_string_append_c(num, '@'); break; } } return g_string_free(num, FALSE); } static double calc_numbering_value(const struct axis_config *aconf, double po) { MathValue val; if (aconf->code) { val.val = po; val.type = MATH_VALUE_NORMAL; math_equation_set_var(aconf->code, 0, &val); math_equation_calculate(aconf->code, &val); if (val.type == MATH_VALUE_NORMAL) { po = val.val; } else { po = 0; } } return po; } static double numformat(char **text, int *nlen, const char *format, const struct axis_config *aconf, const struct axislocal *alocal, int logpow, double po, double norm, const char *head, const char *tail, const char *date_format, int nozero) { int lpow; char *num; double a; *text = NULL; *nlen = 0; if ((! logpow && (alocal->atype == AXISLOGBIG || alocal->atype == AXISLOGNORM)) || (alocal->atype == AXISLOGSMALL)) { po = calc_numbering_value(aconf, po); a = pow(10.0, po); } else if (alocal->atype == AXISINVERSE) { a = calc_numbering_value(aconf, 1.0 / po); } else { po = calc_numbering_value(aconf, po); a = po / norm; } if (aconf->type == AXIS_TYPE_MJD) { num = mjd_to_date_str(aconf, po, date_format); if (num) { logpow = 0; } else { num = get_axis_gauge_num_str(format, a, nozero == AXIS_NUM_NO_ZERO_NO_FLOATING_POINT); } } else { num = get_axis_gauge_num_str(format, a, nozero == AXIS_NUM_NO_ZERO_NO_FLOATING_POINT); } lpow = (logpow && (alocal->atype == AXISLOGBIG || alocal->atype == AXISLOGNORM)); *text = g_strdup_printf("%s%s%s%s%s", CHK_STR(head), (lpow) ? "10^" : "", CHK_STR(num), (lpow) ? "@" : "", CHK_STR(tail)); if (num) { *nlen = strlen(num); g_free(num); } else { *nlen = 0; } return a; } static int draw_numbering_normalize(int GC, int side, const struct axis_config *aconf, const struct font_config *font, double norm, int maxlen, int sx, int sy, int dlx2, int dly2, int ndir, double nndir, int ndirection) { int fx0, fy0, fx1, fy1, px0, px1, py0, py1, gx0, gy0; char num[256]; if (norm/pow(10.0,cutdown(log10(norm)))==1) { // sprintf(num,"[%%F{Symbol}%c%%F{%s}10^%+d@]", (char )0xb4,font,(int )cutdown(log10(norm))); snprintf(num, sizeof(num), "[×10^%+d@]", (int )cutdown(log10(norm))); } else { // sprintf(num,"[%g%%F{Symbol}%c%%F{%s}10^%+d@]", norm/pow(10.0,cutdown(log10(norm))), (char )0xb4,font,(int )cutdown(log10(norm))); snprintf(num, sizeof(num), "[%g×10^%+d@]", norm/pow(10.0,cutdown(log10(norm))), (int )cutdown(log10(norm))); } GRAtextextent(num,font->font, font->style, font->pt, font->space, font->scriptsize, &fx0,&fy0,&fx1,&fy1,FALSE); if (abs(fy1-fy0)>maxlen) maxlen=abs(fy1-fy0); gx0=aconf->x0+(aconf->length+maxlen*1.2)*cos(aconf->dir); gy0=aconf->y0-(aconf->length+maxlen*1.2)*sin(aconf->dir); gx0=gx0-sy*sin(aconf->dir)+sx*cos(aconf->dir)+dlx2; gy0=gy0-sy*cos(aconf->dir)-sx*sin(aconf->dir)+dly2; switch (ndir) { case AXIS_NUM_POS_HORIZONTAL: if (side==AXIS_NUM_POS_LEFT) { if ((aconf->direction>4500) && (aconf->direction<=22500)) px1=fx1; else px1=fx0; } else { if ((aconf->direction>13500) && (aconf->direction<=31500)) px1=fx1; else px1=fx0; } py1=(fy0+fy1)/2; break; case AXIS_NUM_POS_PARALLEL1: case AXIS_NUM_POS_PARALLEL2: if (ndir==AXIS_NUM_POS_PARALLEL1) { px0=fx0; } else { px0=fx1; } py0=(fy0+fy1)/2; px1=cos(nndir)*px0+sin(nndir)*py0; py1=-sin(nndir)*px0+cos(nndir)*py0; break; case AXIS_NUM_POS_NORMAL1: case AXIS_NUM_POS_NORMAL2: if (side==AXIS_NUM_POS_LEFT) { if (ndir==AXIS_NUM_POS_NORMAL1) { px0=fx0; } else { px0=fx1; } } else { if (ndir==AXIS_NUM_POS_NORMAL1) { px0=fx1; } else { px0=fx0; } } py0=(fy0+fy1)/2; px1=cos(nndir)*px0+sin(nndir)*py0; py1=-sin(nndir)*px0+cos(nndir)*py0; break; case AXIS_NUM_POS_OBLIQUE1: case AXIS_NUM_POS_OBLIQUE2: default: px1 = py1 = 0; break; } GRAmoveto(GC,gx0-px1,gy0-py1); GRAdrawtext(GC,num,font->font,font->style,font->pt,font->space,ndirection,font->scriptsize); return 0; } static int draw_numbering(struct objlist *obj, N_VALUE *inst, struct axislocal *alocal, int GC, int side, int align, int ndir, int ilenmax, int plen, struct axis_config *aconf, const struct font_config *font, int step, int nnum, int numcount, int begin, int autonorm, int nozero, int logpow, const char *format, double norm, const char *head, int headlen, const char *tail, const char *date_format, int hx0, int hy0, int hx1, int hy1, struct narray *array) { int fx0,fy0,fx1,fy1,px0,px1,py0,py1; int dlx,dly,dlx2,dly2,maxlen; int rcode; int gx0,gy0; double nndir, po, min1, max1, value; int numlen,i; char *text, ch; int sx, sy, ndirection, cstep; _getobj(obj,"num_shift_p",inst,&sx); _getobj(obj,"num_shift_n",inst,&sy); switch (aconf->type) { case AXIS_TYPE_LOG: min1=log10(aconf->min); max1=log10(aconf->max); break; case AXIS_TYPE_INVERSE: min1=1/aconf->min; max1=1/aconf->max; break; default: min1=aconf->min; max1=aconf->max; } switch (ndir) { case AXIS_NUM_POS_HORIZONTAL: ndirection = 0; break; case AXIS_NUM_POS_NORMAL1: ndirection = aconf->direction + 9000; break; case AXIS_NUM_POS_NORMAL2: ndirection = aconf->direction + 27000; break; case AXIS_NUM_POS_OBLIQUE1: ndirection = aconf->direction + 4500; break; case AXIS_NUM_POS_OBLIQUE2: ndirection = aconf->direction + 31500; break; case AXIS_NUM_POS_PARALLEL1: ndirection = aconf->direction; break; case AXIS_NUM_POS_PARALLEL2: ndirection = aconf->direction + 18000; break; default: /* never reached */ ndirection = 0; } if (ndirection > 36000) { ndirection -= 36000; } nndir = ndirection / 18000.0 * MPI; if (side==AXIS_NUM_POS_RIGHT) sy*=-1; switch (ndir) { case AXIS_NUM_POS_HORIZONTAL: get_num_ofst_horizontal(aconf, align, side, ilenmax, plen, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; case AXIS_NUM_POS_PARALLEL1: case AXIS_NUM_POS_PARALLEL2: get_num_ofst_parallel(aconf, side, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; case AXIS_NUM_POS_NORMAL1: get_num_ofst_normal1(aconf, align, side, ilenmax, plen, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; case AXIS_NUM_POS_NORMAL2: get_num_ofst_normal2(aconf, align, side, ilenmax, plen, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; case AXIS_NUM_POS_OBLIQUE1: get_num_ofst_oblique1(aconf, align, side, ilenmax, plen, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; case AXIS_NUM_POS_OBLIQUE2: get_num_ofst_oblique2(aconf, align, side, ilenmax, plen, hx0, hy0, hx1, hy1, &dlx, &dly, &dlx2, &dly2, &maxlen); break; default: /* never reached */ dlx = 0; dly = 0; dlx2 = 0; dly2 = 0; maxlen = 0; } if (getaxispositionini(alocal,aconf->type,aconf->min,aconf->max,aconf->inc,aconf->div,FALSE)!=0) return 1; if (begin<=0) begin=1; cstep = step - begin + 1; numcount = 0; while ((rcode=getaxisposition(alocal,&po))!=-2) { if (rcode>=2) { gx0=aconf->x0+(po-min1)*aconf->length/(max1-min1)*cos(aconf->dir); gy0=aconf->y0-(po-min1)*aconf->length/(max1-min1)*sin(aconf->dir); gx0=gx0-sy*sin(aconf->dir)+sx*cos(aconf->dir)+dlx; gy0=gy0-sy*cos(aconf->dir)-sx*sin(aconf->dir)+dly; if ((cstep==step) || ((alocal->atype==AXISLOGSMALL) && (rcode==3))) { numcount++; if (((numcount<=nnum) || (nnum==-1)) && ((po!=0) || (nozero != AXIS_NUM_NO_ZERO_NO_ZERO))) { value = numformat(&text, &numlen, format, aconf, alocal, logpow, po, norm, head, tail, date_format, nozero); if (text == NULL) { return 1; } if (align == AXIS_NUM_ALIGN_POINT) { for (i = headlen; i < headlen + numlen; i++) { if (text[i]=='.') { break; } } ch=text[i]; text[i]='\0'; GRAtextextent(text,font->font, font->style, font->pt, font->space, font->scriptsize, &fx0,&fy0,&fx1,&fy1,FALSE); if (abs(fx1-fx0)>ilenmax) ilenmax=abs(fx1-fx0); text[i]=ch; GRAtextextent(text,font->font, font->style, font->pt, font->space, font->scriptsize, &px0,&py0,&px1,&py1,FALSE); if (py0fy1) fy1=py1; } else { GRAtextextent(text,font->font, font->style, font->pt, font->space, font->scriptsize, &fx0,&fy0,&fx1,&fy1,FALSE); } switch (ndir) { case AXIS_NUM_POS_HORIZONTAL: get_num_pos_horizontal(align, plen, fx0, fy0, fx1, fy1, &px1, &py1); break; case AXIS_NUM_POS_PARALLEL1: case AXIS_NUM_POS_PARALLEL2: get_num_pos(align, plen, nndir, fx0, fy0, fx1, fy1, &px1, &py1); break; case AXIS_NUM_POS_NORMAL1: get_num_pos(align, plen, nndir, fx0, fy0, fx1, fy1, &px1, &py1); break; case AXIS_NUM_POS_NORMAL2: get_num_pos(align, plen, nndir, fx1, fy0, fx0, fy1, &px1, &py1); break; case AXIS_NUM_POS_OBLIQUE1: get_num_pos_oblique(AXIS_NUM_ALIGN_LEFT, plen, nndir, fx1, fy0, fx0, fy1, &px1, &py1); break; case AXIS_NUM_POS_OBLIQUE2: get_num_pos_oblique(AXIS_NUM_ALIGN_RIGHT, plen, nndir, fx1, fy0, fx0, fy1, &px1, &py1); break; default: px1 = 0; py1 = 0; } if (array == NULL) { GRAmoveto(GC,gx0-px1,gy0-py1); GRAdrawtext(GC,text,font->font,font->style,font->pt,font->space,ndirection,font->scriptsize); } else { char *s; s = g_strdup_printf("%5d %5d %5d %.14E %.14E", gx0 - px1, gy0 - py1, ndirection, value, po); arrayadd(array, &s); } g_free(text); } if ((alocal->atype==AXISLOGSMALL) && (rcode==3)) { cstep=step-begin; } else { cstep=0; } } cstep++; } } if (norm != 1 && array == NULL) { draw_numbering_normalize(GC, side, aconf, font, norm, maxlen, sx, sy, dlx2, dly2, ndir, nndir, ndirection); } return 0; } static int get_step(struct axislocal *alocal, int step, int *begin) { int n, count, rcode; double po; count = 0; while ((rcode = getaxisposition(alocal, &po)) != -2) { if (rcode >= 2) { count++; } } switch (alocal->atype) { case AXISINVERSE: if (step == 0) { if (count == 0) { n = 1; } else { n = nround(pow(10.0, (double) (int) (log10((double) count)))); } if (n != 1) { n--; } if (count >= 18 * n) { step = 9 * n; } else if (count >= 6 * n) { step = 3 * n; } else { step = n; } } if (*begin == 0) { *begin = 1; } break; case AXISLOGSMALL: if (step == 0) { step = 1; } if (*begin == 0) { *begin = 1; } break; default: if (step == 0) { if (count == 0) { n = 1; } else { n = nround(pow(10.0,(double )(int )(log10(count * 0.5)))); } if (count >= 10 * n) { step = 5 * n; } else if (count >= 5 * n) { step = 2 * n; } else { step = n; } } if (*begin == 0) { double min1, min2; min1 = roundmin(alocal->posst, alocal->dposl); min2 = roundmin(alocal->posst, alocal->dposm); *begin = nround(fabs((min1 - min2) / alocal->dposm)) % step + 1; } } return step; } static int numbering(struct objlist *obj, N_VALUE *inst, int GC, struct axis_config *aconf, struct narray *array) { int fr,fg,fb,fa; int side, begin,step,nnum,numcount,cstep; int autonorm,align,nozero; char *format,*head,*tail,*text,*date_format; int headlen,numlen; int logpow; double po; double norm; int rcode, i; int hx0,hy0,hx1,hy1,fx0,fy0,fx1,fy1,ndir; int ilenmax,flenmax,plen; struct font_config font; struct axislocal alocal; _getobj(obj, "num", inst, &side); if (side == AXIS_NUM_POS_NONE) return 0; _getobj(obj, "num_R", inst, &fr); _getobj(obj, "num_G", inst, &fg); _getobj(obj, "num_B", inst, &fb); _getobj(obj, "num_A", inst, &fa); _getobj(obj, "num_pt", inst, &font.pt); _getobj(obj, "num_space", inst, &font.space); _getobj(obj, "num_script_size", inst, &font.scriptsize); _getobj(obj, "num_begin", inst, &begin); _getobj(obj, "num_step", inst, &step); _getobj(obj, "num_num", inst, &nnum); _getobj(obj, "num_auto_norm", inst, &autonorm); _getobj(obj, "num_head", inst, &head); _getobj(obj, "num_format", inst, &format); _getobj(obj, "num_tail", inst, &tail); _getobj(obj, "num_date_format", inst, &date_format); _getobj(obj, "num_log_pow", inst, &logpow); _getobj(obj, "num_align", inst, &align); _getobj(obj, "num_no_zero", inst, &nozero); _getobj(obj, "num_font", inst, &font.font); _getobj(obj, "num_font_style", inst, &font.style); _getobj(obj, "num_direction",inst, &ndir); GRAcolor(GC, fr, fg, fb, fa); headlen = (head) ? strlen(head) : 0; if (getaxispositionini(&alocal, aconf->type, aconf->min, aconf->max, aconf->inc, aconf->div, FALSE)!=0) { error(obj, ERRMINMAX); return 1; } step = get_step(&alocal, step, &begin); norm = 1; if (alocal.atype == AXISNORMAL && aconf->code == NULL) { double abs_pos; abs_pos = fabs(alocal.dposm); if (abs_pos >= pow(10.0, (double) autonorm) || abs_pos <= pow(10.0, (double) - autonorm)) { norm = abs_pos; } } if (aconf->type == AXIS_TYPE_MJD) { norm = 1; if (align == AXIS_NUM_ALIGN_POINT) { align = AXIS_NUM_ALIGN_CENTER; } } if (ndir == AXIS_NUM_POS_OBLIQUE1 || ndir == AXIS_NUM_POS_OBLIQUE2) { align = AXIS_NUM_ALIGN_CENTER; } if (getaxispositionini(&alocal, aconf->type, aconf->min, aconf->max, aconf->inc, aconf->div, FALSE)) { return 1; } GRAtextextent(".", font.font, font.style, font.pt, font.space, font.scriptsize, &fx0, &fy0, &fx1, &fy1, FALSE); plen = abs(fx1 - fx0); hx0 = hy0 = hx1 = hy1 = 0; flenmax = ilenmax = 0; if (begin <= 0) { begin = 1; } cstep = step - begin + 1; numcount = 0; while ((rcode = getaxisposition(&alocal, &po)) != -2) { if (rcode < 2) { continue; } if (cstep == step || (alocal.atype == AXISLOGSMALL && rcode == 3)) { numcount++; if ((numcount <= nnum || nnum == -1) && (po != 0 || (nozero != AXIS_NUM_NO_ZERO_NO_ZERO))) { numformat(&text, &numlen, format, aconf, &alocal, logpow, po, norm, head, tail, date_format, nozero); if (text == NULL) { return 1; } if (align == AXIS_NUM_ALIGN_POINT) { for (i = headlen; i < headlen + numlen; i++) { if (text[i] == '.') { break; } } if (text[i] == '.') { GRAtextextent(text + i + 1, font.font, font.style, font.pt, font.space, font.scriptsize, &fx0, &fy0, &fx1, &fy1, FALSE); hy0 = MIN(hy0, fy0); hy1 = MAX(hy1, fy1); if (abs(fx1-fx0) > flenmax) { flenmax = abs(fx1 - fx0); } } text[i] = '\0'; GRAtextextent(text, font.font, font.style, font.pt, font.space, font.scriptsize, &fx0, &fy0, &fx1, &fy1, FALSE); if (abs(fx1 - fx0) > ilenmax) { ilenmax = abs(fx1 - fx0); } hy0 = MIN(hy0, fy0); hy1 = MAX(hy1, fy1); } else { GRAtextextent(text, font.font, font.style, font.pt, font.space, font.scriptsize, &fx0, &fy0, &fx1, &fy1, FALSE); hx0 = MIN(hx0, fx0); hx1 = MAX(hx1, fx1); hy0 = MIN(hy0, fy0); hy1 = MAX(hy1, fy1); } g_free(text); } if ((alocal.atype == AXISLOGSMALL) && (rcode == 3)) { cstep = step - begin; } else { cstep = 0; } } cstep++; } if (align == AXIS_NUM_ALIGN_POINT) { hx0 = 0; hx1 = flenmax + ilenmax + plen / 2; } if (hx0 != hx1 && hy0 != hy1) { draw_numbering(obj, inst, &alocal, GC, side, align, ndir, ilenmax, plen, aconf, &font, step, nnum, numcount, begin, autonorm, nozero, logpow, format, norm, head, headlen, tail, date_format, hx0, hy0, hx1, hy1, array); } return 0; } static int draw_gauge(struct objlist *obj,N_VALUE *inst, int GC, struct axis_config *aconf) { int fr,fg,fb,fa; struct narray *style; int snum,*sdata; struct axislocal alocal; double po,gmin,gmax,min1,max1,min2,max2; int len1,wid1,len2,wid2,len3,wid3,len,wid; int limit; int rcode; int gx0,gy0,gx1,gy1; int gauge; _getobj(obj,"gauge",inst,&gauge); if (gauge == AXIS_GAUGE_NONE) return 0; _getobj(obj,"gauge_R",inst,&fr); _getobj(obj,"gauge_G",inst,&fg); _getobj(obj,"gauge_B",inst,&fb); _getobj(obj,"gauge_A",inst,&fa); _getobj(obj,"gauge_min",inst,&gmin); _getobj(obj,"gauge_max",inst,&gmax); _getobj(obj,"gauge_style",inst,&style); _getobj(obj,"gauge_length1",inst,&len1); _getobj(obj,"gauge_width1",inst,&wid1); _getobj(obj,"gauge_length2",inst,&len2); _getobj(obj,"gauge_width2",inst,&wid2); _getobj(obj,"gauge_length3",inst,&len3); _getobj(obj,"gauge_width3",inst,&wid3); snum=arraynum(style); sdata=arraydata(style); GRAcolor(GC,fr,fg,fb, fa); if (getaxispositionini(&alocal,aconf->type,aconf->min,aconf->max,aconf->inc,aconf->div,FALSE)!=0) { error(obj,ERRMINMAX); return 1; } if ((gmin!=0) || (gmax!=0)) limit=TRUE; else limit=FALSE; switch (aconf->type) { case AXIS_TYPE_LOG: min1=log10(aconf->min); max1=log10(aconf->max); if (limit && (gmin>0) && (gmax>0)) { min2=log10(gmin); max2=log10(gmax); } else limit=FALSE; break; case AXIS_TYPE_INVERSE: min1=1/aconf->min; max1=1/aconf->max; if (limit && (gmin*gmax>0)) { min2=1/gmin; max2=1/gmax; } else limit=FALSE; break; default: min1=aconf->min; max1=aconf->max; if (limit) { min2=gmin; max2=gmax; } } while ((rcode=getaxisposition(&alocal,&po))!=-2) { if ((rcode>=0) && (!limit || ((min2-po)*(max2-po)<=0))) { gx0=aconf->x0+(po-min1)*aconf->length/(max1-min1)*cos(aconf->dir); gy0=aconf->y0-(po-min1)*aconf->length/(max1-min1)*sin(aconf->dir); if (rcode==1) { len=len1; wid=wid1; } else if (rcode==2) { len=len2; wid=wid2; } else { len=len3; wid=wid3; } GRAlinestyle(GC,snum,sdata,wid,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); if ((gauge==1) || (gauge==2)) { gx1=gx0-len*sin(aconf->dir); gy1=gy0-len*cos(aconf->dir); GRAline(GC,gx0,gy0,gx1,gy1); } if ((gauge==1) || (gauge==3)) { gx1=gx0+len*sin(aconf->dir); gy1=gy0+len*cos(aconf->dir); GRAline(GC,gx0,gy0,gx1,gy1); } } } return 0; } static int get_axis_parameter(struct objlist *obj, N_VALUE *inst, struct axis_config *aconf) { _getobj(obj, "min", inst, &aconf->min); _getobj(obj, "max", inst, &aconf->max); _getobj(obj, "inc", inst, &aconf->inc); _getobj(obj, "div", inst, &aconf->div); _getobj(obj, "type", inst, &aconf->type); return 0; } static MathEquation * get_axis_math(struct objlist *obj, const char *math) { MathEquation *code; int rcode; code = math_equation_basic_new(); if (code == NULL) { return NULL; } if (math_equation_add_var(code, "X") != 0) { math_equation_free(code); return NULL; } rcode = math_equation_parse(code, math); if (rcode) { char *err_msg;; err_msg = math_err_get_error_message(code, math, rcode); error2(obj, ERRNUMMATH, err_msg); g_free(err_msg); math_equation_free(code); return NULL; } return code; } static int alloc_axis_math(struct objlist *obj, N_VALUE *inst, struct axis_config *aconf) { char *math; MathEquation *code; aconf->code = NULL; _getobj(obj, "num_math", inst, &math); if (math == NULL) { return 0; } if (math == NULL || math[0] == '\0') { code = NULL; } else { code = get_axis_math(obj, math); } aconf->code = code; return 0; } static int free_axis_math(struct axis_config *aconf) { if (aconf->code) { math_equation_free(aconf->code); } aconf->code = NULL; return 0; } static int get_reference_parameter(struct objlist *obj, N_VALUE *inst, struct axis_config *aconf) { char *axis; N_VALUE *inst1; struct objlist *aobj; int anum, id; struct narray iarray; int type; _getobj(obj,"reference",inst, &axis); if (axis == NULL) return 1; arrayinit(&iarray,sizeof(int)); if (getobjilist(axis,&aobj,&iarray,FALSE,NULL)) return 1; type = aconf->type; anum=arraynum(&iarray); if (anum>0) { id=arraylast_int(&iarray); arraydel(&iarray); if ((anum>0) && ((inst1=getobjinst(aobj,id))!=NULL)) { get_axis_parameter(aobj, inst1, aconf); } } if ((aconf->type == AXIS_TYPE_LINEAR || aconf->type == AXIS_TYPE_MJD) && (type == AXIS_TYPE_LINEAR || type == AXIS_TYPE_MJD)) { aconf->type = type; } /* AXIS_TYPE_LINEAR and AXIS_TYPE_MJD are compatible each other */ return 0; } static int draw_wave(struct objlist *obj, N_VALUE *inst, struct axis_config *aconf, int GC) { int wave, wwidth, wlength, i; double wx[5],wxc1[5],wxc2[5],wxc3[5]; double wy[5],wyc1[5],wyc2[5],wyc3[5]; double ww[5],c[6]; double dx, dy; _getobj(obj,"wave",inst,&wave); _getobj(obj,"wave_length",inst,&wlength); _getobj(obj,"wave_width",inst,&wwidth); for (i=0;i<5;i++) ww[i]=i; if ((wave==ARROW_POSITION_BEGIN) || (wave==ARROW_POSITION_BOTH)) { dx=cos(aconf->dir); dy=sin(aconf->dir); wx[0]=nround(aconf->x0-dy*wlength); wx[1]=nround(aconf->x0-dy*0.5*wlength-dx*0.25*wlength); wx[2]=aconf->x0; wx[3]=nround(aconf->x0+dy*0.5*wlength+dx*0.25*wlength); wx[4]=nround(aconf->x0+dy*wlength); if (spline(ww,wx,wxc1,wxc2,wxc3,5,SPLCND2NDDIF,SPLCND2NDDIF,0,0)) { error(obj,ERRAXISSPL); return 1; } wy[0]=nround(aconf->y0-dx*wlength); wy[1]=nround(aconf->y0-dx*0.5*wlength+dy*0.25*wlength); wy[2]=aconf->y0; wy[3]=nround(aconf->y0+dx*0.5*wlength-dy*0.25*wlength); wy[4]=nround(aconf->y0+dx*wlength); if (spline(ww,wy,wyc1,wyc2,wyc3,5,SPLCND2NDDIF,SPLCND2NDDIF,0,0)) { error(obj,ERRAXISSPL); return 1; } GRAlinestyle(GC,0,NULL,wwidth,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRAcurvefirst(GC,0,NULL,NULL,NULL,splinedif,splineint,NULL,wx[0],wy[0]); for (i=0;i<4;i++) { c[0]=wxc1[i]; c[1]=wxc2[i]; c[2]=wxc3[i]; c[3]=wyc1[i]; c[4]=wyc2[i]; c[5]=wyc3[i]; if (!GRAcurve(GC,c,wx[i],wy[i])) break; } } if ((wave==ARROW_POSITION_END) || (wave==ARROW_POSITION_BOTH)) { dx=cos(aconf->dir); dy=sin(aconf->dir); wx[0]=nround(aconf->x1-dy*wlength); wx[1]=nround(aconf->x1-dy*0.5*wlength-dx*0.25*wlength); wx[2]=aconf->x1; wx[3]=nround(aconf->x1+dy*0.5*wlength+dx*0.25*wlength); wx[4]=nround(aconf->x1+dy*wlength); if (spline(ww,wx,wxc1,wxc2,wxc3,5,SPLCND2NDDIF,SPLCND2NDDIF,0,0)) { error(obj,ERRAXISSPL); return 1; } wy[0]=nround(aconf->y1-dx*wlength); wy[1]=nround(aconf->y1-dx*0.5*wlength+dy*0.25*wlength); wy[2]=aconf->y1; wy[3]=nround(aconf->y1+dx*0.5*wlength-dy*0.25*wlength); wy[4]=nround(aconf->y1+dx*wlength); if (spline(ww,wy,wyc1,wyc2,wyc3,5,SPLCND2NDDIF,SPLCND2NDDIF,0,0)) { error(obj,ERRAXISSPL); return 1; } GRAlinestyle(GC,0,NULL,wwidth,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRAcurvefirst(GC,0,NULL,NULL,NULL,splinedif,splineint,NULL,wx[0],wy[0]); for (i=0;i<4;i++) { c[0]=wxc1[i]; c[1]=wxc2[i]; c[2]=wxc3[i]; c[3]=wyc1[i]; c[4]=wyc2[i]; c[5]=wyc3[i]; if (!GRAcurve(GC,c,wx[i],wy[i])) break; } } return 0; } static int draw_arrow(struct objlist *obj, N_VALUE *inst, struct axis_config *aconf, int GC) { int arrow,alength,awidth; double alen,awid,dx,dy; int ap[6]; _getobj(obj,"arrow",inst,&arrow); _getobj(obj,"arrow_length",inst,&alength); _getobj(obj,"arrow_width",inst,&awidth); alen=aconf->width*(double )alength/10000; awid=aconf->width*(double )awidth/20000; if ((arrow==ARROW_POSITION_BEGIN) || (arrow==ARROW_POSITION_BOTH)) { dx=-cos(aconf->dir); dy=sin(aconf->dir); ap[0]=nround(aconf->x0-dy*awid); ap[1]=nround(aconf->y0+dx*awid); ap[2]=nround(aconf->x0+dx*alen); ap[3]=nround(aconf->y0+dy*alen); ap[4]=nround(aconf->x0+dy*awid); ap[5]=nround(aconf->y0-dx*awid); GRAlinestyle(GC,0,NULL,1,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRAdrawpoly(GC,3,ap,GRA_FILL_MODE_EVEN_ODD); } if ((arrow==ARROW_POSITION_END) || (arrow==ARROW_POSITION_BOTH)) { dx=cos(aconf->dir); dy=-sin(aconf->dir); ap[0]=nround(aconf->x1-dy*awid); ap[1]=nround(aconf->y1+dx*awid); ap[2]=nround(aconf->x1+dx*alen); ap[3]=nround(aconf->y1+dy*alen); ap[4]=nround(aconf->x1+dy*awid); ap[5]=nround(aconf->y1-dx*awid); GRAlinestyle(GC,0,NULL,1,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRAdrawpoly(GC,3,ap,GRA_FILL_MODE_EVEN_ODD); } return 0; } static int axisdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; int fr, fg, fb, fa, w, h, bline; struct narray *style; int snum, *sdata; int clip, zoom; int hidden, hidden2; struct axis_config aconf; aconf.code = NULL; _getobj(obj,"hidden",inst,&hidden); hidden2=FALSE; _putobj(obj,"hidden",inst,&hidden2); if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _putobj(obj,"hidden",inst,&hidden); _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; if (hidden) goto exit; _getobj(obj,"R",inst,&fr); _getobj(obj,"G",inst,&fg); _getobj(obj,"B",inst,&fb); _getobj(obj,"A",inst,&fa); _getobj(obj,"x",inst,&aconf.x0); _getobj(obj,"y",inst,&aconf.y0); _getobj(obj,"direction",inst,&aconf.direction); _getobj(obj,"baseline",inst,&bline); _getobj(obj,"length",inst,&aconf.length); _getobj(obj,"width",inst,&aconf.width); _getobj(obj,"style",inst,&style); _getobj(obj,"clip",inst,&clip); snum=arraynum(style); sdata=arraydata(style); aconf.dir=aconf.direction/18000.0*MPI; aconf.x1=aconf.x0+nround(aconf.length*cos(aconf.dir)); aconf.y1=aconf.y0-nround(aconf.length*sin(aconf.dir)); alloc_axis_math(obj, inst, &aconf); GRAregion(GC,&w,&h,&zoom); GRAview(GC,0,0,w*10000.0/zoom,h*10000.0/zoom,clip); GRAcolor(GC,fr,fg,fb, fa); if (bline) { GRAlinestyle(GC,snum,sdata,aconf.width,GRA_LINE_CAP_PROJECTING,GRA_LINE_JOIN_MITER,1000); GRAline(GC,aconf.x0,aconf.y0,aconf.x1,aconf.y1); } draw_arrow(obj, inst, &aconf, GC); if (draw_wave(obj, inst, &aconf, GC)) goto exit; get_axis_parameter(obj, inst, &aconf); if (aconf.min == 0 && aconf.max == 0 && aconf.inc == 0) { get_reference_parameter(obj, inst, &aconf); } if (aconf.min != aconf.max && aconf.inc != 0 && draw_gauge(obj, inst, GC, &aconf)) { goto exit; } if (aconf.code == NULL) { get_axis_parameter(obj, inst, &aconf); } if (aconf.min != aconf.max && aconf.inc != 0) { numbering(obj, inst, GC, &aconf, NULL); } exit: free_axis_math(&aconf); GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int axis_get_numbering(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int GC; int hidden; struct axis_config aconf; struct narray *array; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; arrayfree2(rval->array); rval->array = NULL; _getobj(obj, "hidden", inst, &hidden); if (hidden) return 0; _getobj(obj, "GC", inst, &GC); if (GC < 0) return 0; _getobj(obj, "x", inst, &aconf.x0); _getobj(obj, "y", inst, &aconf.y0); _getobj(obj, "direction", inst, &aconf.direction); _getobj(obj, "length", inst, &aconf.length); _getobj(obj, "width", inst, &aconf.width); aconf.dir = aconf.direction / 18000.0 * MPI; aconf.x1 = aconf.x0+nround(aconf.length * cos(aconf.dir)); aconf.y1 = aconf.y0-nround(aconf.length * sin(aconf.dir)); alloc_axis_math(obj, inst, &aconf); get_axis_parameter(obj, inst, &aconf); if (aconf.min != aconf.max && aconf.inc != 0) { array = arraynew(sizeof(char *)); if (array == NULL) { free_axis_math(&aconf); return 1; } numbering(obj, inst, GC, &aconf, array); rval->array = array; } free_axis_math(&aconf); return 0; } static int axisclear(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { double min,max,inc; min=max=inc=0; if (_putobj(obj,"min",inst,&min)) return 1; if (_putobj(obj,"max",inst,&max)) return 1; if (_putobj(obj,"inc",inst,&inc)) return 1; return 0; } static int axisadjust(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *axis; int ad; struct objlist *aobj; int anum,id; struct narray iarray; N_VALUE *inst1; double min,max,inc,dir,po,dir1,x; int type,posx,posy,len,idir,posx1,posy1,div; struct axislocal alocal; int rcode; int first; int gx,gy,gx0,gy0,count; _getobj(obj,"x",inst,&posx1); _getobj(obj,"y",inst,&posy1); _getobj(obj,"direction",inst,&idir); _getobj(obj,"adjust_axis",inst,&axis); _getobj(obj,"adjust_position",inst,&ad); dir1=idir*MPI/18000; if (axis==NULL) return 0; arrayinit(&iarray,sizeof(int)); if (getobjilist(axis,&aobj,&iarray,FALSE,NULL)) return 1; anum=arraynum(&iarray); if (anum<1) { arraydel(&iarray); return 1; } id=arraylast_int(&iarray); arraydel(&iarray); if ((inst1=getobjinst(aobj,id))==NULL) return 1; if (_getobj(aobj,"min",inst1,&min)) return 1; if (_getobj(aobj,"max",inst1,&max)) return 1; if (_getobj(aobj,"inc",inst1,&inc)) return 1; if (_getobj(aobj,"div",inst1,&div)) return 1; if (_getobj(aobj,"type",inst1,&type)) return 1; if (_getobj(aobj,"x",inst1,&posx)) return 1; if (_getobj(aobj,"y",inst1,&posy)) return 1; if (_getobj(aobj,"length",inst1,&len)) return 1; if (_getobj(aobj,"direction",inst1,&idir)) return 1; dir=idir*MPI/18000; if (min==max) return 0; if (dir==dir1) return 0; if (getaxispositionini(&alocal,type,min,max,inc,div,FALSE)!=0) return 0; if (type==AXIS_TYPE_LOG) { min=log10(min); max=log10(max); } else if (type==AXIS_TYPE_INVERSE) { min=1/min; max=1/max; } gx0 = gy0 = 0; /* this initialization is added to avoid compile warnings. */ first=TRUE; count=0; while ((rcode=getaxisposition(&alocal,&po))!=-2) { if (rcode>=2) { count++; gx=posx+(po-min)*len/(max-min)*cos(dir); gy=posy-(po-min)*len/(max-min)*sin(dir); if (first) { gx0=gx; gy0=gy; first=FALSE; } if (((ad==0) && (po==0)) || (count==ad)) { gx0=gx; gy0=gy; } } } if (first) return 0; x=-sin(dir1)*(gx0-posx1)-cos(dir1)*(gy0-posy1); x=x/(-cos(dir)*sin(dir1)+sin(dir)*cos(dir1)); posx1=nround(posx1+x*cos(dir)); posy1=nround(posy1-x*sin(dir)); if (_putobj(obj,"x",inst,&posx1)) return 1; if (_putobj(obj,"y",inst,&posy1)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int axischangescale(struct objlist *obj,N_VALUE *inst, double *rmin,double *rmax,double *rinc,int room) { int type; double min,max,inc,ming,maxg,order,mmin; double a; _getobj(obj,"type",inst,&type); ming=*rmin; maxg=*rmax; if (ming>maxg) { a=ming; ming=maxg; maxg=a; } if (type==AXIS_TYPE_LOG) { if (ming<=0) return 1; if (maxg<=0) return 1; ming=log10(ming); maxg=log10(maxg); } else if (type==AXIS_TYPE_INVERSE) { if (ming*maxg<=0) return 1; } order=(fabs(ming)+fabs(maxg))*0.5; if (order==0) { maxg=1; ming=-1; } else if (fabs(maxg-ming)/order<1e-6) { maxg=maxg+order*0.5; ming=ming-order*0.5; } inc=scale(maxg-ming); if (room > 0) { max=maxg+(maxg-ming) * (room * 0.0001); max=nraise(max/inc*10)*inc/10; min=ming-(maxg-ming) * (room * 0.0001); min=cutdown(min/inc*10)*inc/10; if (type==AXIS_TYPE_LOG) { max=pow(10.0,max); min=pow(10.0,min); max=log10(nraise(max/scale(max))*scale(max)); min=log10(cutdown(min/scale(min)+1e-15)*scale(min)); } else if (type==AXIS_TYPE_INVERSE) { if (ming*min<=0) min=ming; if (maxg*max<=0) max=maxg; } } else { max=maxg; min=ming; } if (min==max) max=min+1; if (type!=AXIS_TYPE_INVERSE) { inc=scale(max-min); if (max0) inc/=10; } else { inc=scale(max-min); } if ((type!=AXIS_TYPE_LOG) && (inc==0)) inc=1; if (type==AXIS_TYPE_LOG) inc=nround(inc); inc=fabs(inc); if (type==AXIS_TYPE_LOG) { min=pow(10.0,min); max=pow(10.0,max); inc=pow(10.0,inc); } *rmin=min; *rmax=max; *rinc=inc; return 0; } static int axisscale(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int type,room; double min,max,inc; _getobj(obj,"type",inst,&type); min=*(double *)argv[2]; max=*(double *)argv[3]; room=*(int *)argv[4]; axischangescale(obj,inst,&min,&max,&inc,room); if (_putobj(obj,"min",inst,&min)) return 1; if (_putobj(obj,"max",inst,&max)) return 1; if (_putobj(obj,"inc",inst,&inc)) return 1; return 0; } static int axiscoordinate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y,dx,dy,type,dir,len; double min,max,c,t,val; _getobj(obj,"type",inst,&type); _getobj(obj,"min",inst,&min); _getobj(obj,"max",inst,&max); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"length",inst,&len); _getobj(obj,"direction",inst,&dir); if (min==max) return 1; if (len==0) return 1; dx=*(int *)argv[2]; dy=*(int *)argv[3]; c=dir/18000.0*MPI; t=-(x-dx)*cos(c)+(y-dy)*sin(c); if (type==AXIS_TYPE_LOG) { if (min<=0) return 1; if (max<=0) return 1; min=log10(min); max=log10(max); } else if (type==AXIS_TYPE_INVERSE) { if (min*max<=0) return 1; min=1.0/min; max=1.0/max; } val=min+(max-min)*t/len; if (type==AXIS_TYPE_LOG) { val=pow(10.0,val); } else if (type==AXIS_TYPE_INVERSE) { if (val==0) return 1; val=1.0/val; } rval->d=val; return 0; } static int axisautoscalefile(struct objlist *obj,N_VALUE *inst,char *fileobj,double *rmin,double *rmax) { struct objlist *fobj; int fnum; int *fdata; struct narray iarray; double min,max,min1,max1, frac; int i,id,set; char buf[20], msgbuf[64], *group; char *argv2[4]; struct narray *minmax; arrayinit(&iarray,sizeof(int)); if (getobjilist(fileobj,&fobj,&iarray,FALSE,NULL)) return 1; fnum=arraynum(&iarray); fdata=arraydata(&iarray); _getobj(obj,"id",inst,&id); snprintf(buf, sizeof(buf), "axis:%d",id); _getobj(obj,"group",inst,&group); argv2[0]=(void *)buf; argv2[1]=NULL; min = max = 0; /* this initialization is added to avoid compile warnings. */ set=FALSE; for (i=0;i=2) { min1=arraynget_double(minmax,0); max1=arraynget_double(minmax,1); if (!set) { min=min1; max=max1; set=TRUE; } else { if (min1max) max=max1; } } } arraydel(&iarray); if (!set) return 1; *rmin=min; *rmax=max; return 0; } static int axisautoscale(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *fileobj; int room; double omin,omax,oinc; double min,max,inc; fileobj=(char *)argv[2]; _getobj(obj,"auto_scale_margin",inst,&room); if (axisautoscalefile(obj,inst,fileobj,&min,&max)) return 0; axischangescale(obj,inst,&min,&max,&inc,room); _getobj(obj,"min",inst,&omin); _getobj(obj,"max",inst,&omax); _getobj(obj,"inc",inst,&oinc); if (omin==omax) { if (_putobj(obj,"min",inst,&min)) return 1; if (_putobj(obj,"max",inst,&max)) return 1; } if (oinc==0) { if (_putobj(obj,"inc",inst,&inc)) return 1; } return 0; } static int axisgetautoscale(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *fileobj; int room; double min,max,inc; struct narray *result; result=rval->array; arrayfree(result); rval->array=NULL; fileobj=(char *)argv[2]; _getobj(obj,"auto_scale_margin",inst,&room); if (axisautoscalefile(obj,inst,fileobj,&min,&max)==0) { axischangescale(obj,inst,&min,&max,&inc,room); result=arraynew(sizeof(double)); arrayadd(result,&min); arrayadd(result,&max); arrayadd(result,&inc); rval->array=result; } return 0; } static int axisautoscale_margin(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int room; room = * (int *) argv[2]; if (room < 0) { * (int *) argv[2] = 0; } else if (room > 100000) { * (int *) argv[2] = 100000; } return 0; } static int axistight(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { obj_do_tighten(obj, inst, "reference"); obj_do_tighten(obj, inst, "adjust_axis"); return 0; } static void set_group(struct objlist *obj, int gnum, int id, char axis, char type) { char *group, *group2; N_VALUE *inst2; inst2 = chkobjinst(obj, id); if (inst2 == NULL) { return; } group = g_strdup_printf("%c%c%d", type, axis, gnum); if (group) { _getobj(obj, "group", inst2, &group2); g_free(group2); _putobj(obj, "group", inst2, group); } group = g_strdup_printf("%c%c%d", type, axis, gnum); if (group) { _getobj(obj, "name", inst2, &group2); g_free(group2); _putobj(obj, "name", inst2, group); } } static int axisgrouping(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct narray *iarray; int *data; int num,gnum; char type; iarray = (struct narray *)argv[2]; num = arraynum(iarray); if (num < 1) return 1; data = arraydata(iarray); switch (data[0]) { case AXIS_TYPE_FRAME: type='f'; break; case AXIS_TYPE_SECTION: type='s'; break; case AXIS_TYPE_CROSS: type='c'; break; default: error(obj, ERRGROUPING); return 1; } gnum = axisuniqgroup(obj, type); switch (data[0]) { case AXIS_TYPE_FRAME: case AXIS_TYPE_SECTION: if (num < 5) return 1; set_group(obj, gnum, data[1], 'X', type); set_group(obj, gnum, data[2], 'Y', type); set_group(obj, gnum, data[3], 'U', type); set_group(obj, gnum, data[4], 'R', type); break; case AXIS_TYPE_CROSS: if (num<3) return 1; set_group(obj, gnum, data[1], 'X', type); set_group(obj, gnum, data[2], 'Y', type); } return 0; } static void set_group_pos(struct objlist *obj, int id, int x, int y, int len, int dir) { N_VALUE *inst2; inst2 = chkobjinst(obj, id); if (inst2 == NULL) return; _putobj(obj, "direction", inst2, &dir); _putobj(obj, "x", inst2, &x); _putobj(obj, "y", inst2, &y); _putobj(obj, "length", inst2, &len); if (clear_bbox(obj, inst2)) return; } static int axisgrouppos(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int x, y, lx, ly; struct narray *iarray; int *data; int anum; iarray = (struct narray *)argv[2]; anum = arraynum(iarray); if (anum < 1) return 1; data = arraydata(iarray); switch (data[0]) { case AXIS_TYPE_FRAME: case AXIS_TYPE_SECTION: if (anum < 9) return 1; x = data[5]; y = data[6]; lx = data[7]; ly = data[8]; set_group_pos(obj, data[1], x, y, lx, 0); set_group_pos(obj, data[2], x, y, ly, 9000); set_group_pos(obj, data[3], x, y - ly, lx, 0); set_group_pos(obj, data[4], x + lx, y, ly, 9000); break; case AXIS_TYPE_CROSS: if (anum < 7) return 1; x = data[3]; y = data[4]; lx = data[5]; ly = data[6]; set_group_pos(obj, data[1], x, y, lx, 0); set_group_pos(obj, data[2], x, y, ly, 9000); break; } return 0; } static void axis_default(struct objlist *obj, int id, int *oid, int dir, enum AXIS_GAUGE gauge, enum AXIS_NUM_POS num, enum AXIS_NUM_ALIGN align, char *conf) { N_VALUE *inst2; inst2 = chkobjinst(obj, id); if (inst2 == NULL) return; _putobj(obj, "gauge", inst2, &gauge); _putobj(obj, "num", inst2, &num); _putobj(obj, "num_align", inst2, &align); _putobj(obj, "direction", inst2, &dir); if (oid) _getobj(obj, "oid", inst2, oid); if (conf) axisloadconfig(obj, inst2, conf); } static void axis_default_set(struct objlist *obj, int id, int oid, char *field, char *conf) { N_VALUE *inst2; char *ref, *ref2; inst2 = chkobjinst(obj, id); if (inst2 == NULL) return; ref = g_strdup_printf("axis:^%d", oid); if (ref == NULL) return; _getobj(obj, field, inst2, &ref2); g_free(ref2); _putobj(obj, field, inst2, ref); axisloadconfig(obj, inst2, conf); } static void axis_default_set_ref(struct objlist *obj, int id, int oid, char *conf) { axis_default_set(obj, id, oid, "reference", conf); } static void axis_default_set_adj(struct objlist *obj, int id, int oid, char *conf) { axis_default_set(obj, id, oid, "adjust_axis", conf); } static int axisdefgrouping(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int oidx, oidy; struct narray *iarray; int *data; int anum; if (axisgrouping(obj, inst, rval, argc, argv)) return 1; iarray = (struct narray *) argv[2]; anum = arraynum(iarray); if (anum < 1) return 1; data = arraydata(iarray); switch (data[0]) { case AXIS_TYPE_FRAME: if (anum < 5) return 1; axis_default(obj, data[1], &oidx, 0, AXIS_GAUGE_LEFT, AXIS_NUM_POS_RIGHT, AXIS_NUM_ALIGN_CENTER, "[axis_fX]"); axis_default(obj, data[2], &oidy, 9000, AXIS_GAUGE_RIGHT, AXIS_NUM_POS_LEFT, AXIS_NUM_ALIGN_RIGHT, "[axis_fY]"); axis_default(obj, data[3], NULL, 0, AXIS_GAUGE_RIGHT, AXIS_NUM_POS_LEFT, AXIS_NUM_ALIGN_CENTER, NULL); axis_default(obj, data[4], NULL, 9000, AXIS_GAUGE_LEFT, AXIS_NUM_POS_RIGHT, AXIS_NUM_ALIGN_LEFT, NULL); axis_default_set_ref(obj, data[3], oidx, "[axis_fU]"); axis_default_set_ref(obj, data[4], oidy, "[axis_fR]"); if (anum < 9) return 0; break; case AXIS_TYPE_SECTION: if (anum < 5) return 1; axis_default(obj, data[1], &oidx, 0, AXIS_GAUGE_NONE, AXIS_NUM_POS_RIGHT, AXIS_NUM_ALIGN_CENTER, "[axis_sX]"); axis_default(obj, data[2], &oidy, 9000, AXIS_GAUGE_NONE, AXIS_NUM_POS_LEFT, AXIS_NUM_ALIGN_RIGHT, "[axis_sY]"); axis_default(obj, data[3], NULL, 0, AXIS_GAUGE_NONE, AXIS_NUM_POS_LEFT, AXIS_NUM_ALIGN_CENTER, NULL); axis_default(obj, data[4], NULL, 9000, AXIS_GAUGE_NONE, AXIS_NUM_POS_RIGHT, AXIS_NUM_ALIGN_LEFT, NULL); axis_default_set_ref(obj, data[3], oidx, "[axis_sU]"); axis_default_set_ref(obj, data[4], oidy, "[axis_sR]"); if (anum < 9) return 0; break; case AXIS_TYPE_CROSS: if (anum < 3) return 1; axis_default(obj, data[1], &oidx, 0, AXIS_GAUGE_BOTH, AXIS_NUM_POS_RIGHT, AXIS_NUM_ALIGN_CENTER, NULL); axis_default(obj, data[2], &oidy, 9000, AXIS_GAUGE_BOTH, AXIS_NUM_POS_LEFT, AXIS_NUM_ALIGN_RIGHT, NULL); axis_default_set_adj(obj, data[1], oidy, "[axis_cX]"); axis_default_set_adj(obj, data[2], oidx, "[axis_cY]"); if (anum < 7) return 0; break; default: return 1; } if (axisgrouppos(obj, inst, rval, argc, argv)) return 1; return 0; } static int axis_save_group(struct objlist *obj, int type, N_VALUE **inst_array, N_VALUE *rval) { char *str; int i, n, id; GString *s; switch (type) { case 'f': str = "\naxis::grouping 1 "; n = 4; break; case 's': str = "\naxis::grouping 2 "; n = 4; break; case 'c': str = "\naxis::grouping 3 "; n = 2; break; default: /* never reached */ return 1; } s = g_string_sized_new(64); if (s == NULL) return 1; if (rval->str) { g_string_append(s, rval->str); } g_string_append(s, str); for (i = 0; i < n; i++) { _getobj(obj, "id", inst_array[i], &id); g_string_append_printf(s, "%d%c", id, (i == n - 1) ? '\n' : ' '); } g_free(rval->str); rval->str = g_string_free(s, FALSE); return 0; } static int axissave(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i, r, anum, type; struct narray *array; char **adata; N_VALUE *inst_array[INST_ARRAY_NUM]; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; array = (struct narray *) argv[2]; anum = arraynum(array); adata = arraydata(array); for (i = 0; i < anum; i++) { if (strcmp("grouping", adata[i]) == 0) return 0; } type = get_axis_group_type(obj, inst, inst_array, FALSE); r = 0; switch (type) { case 'a': break; case 'f': case 's': case 'c': r = axis_save_group(obj, type, inst_array, rval); break; } return r; } static int axismanager(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i,id,lastinst; char *group,*group2; char type; N_VALUE *inst2; _getobj(obj,"id",inst,&id); _getobj(obj,"group",inst,&group); if ((group==NULL) || (group[0]=='a')) { rval->i=id; return 0; } lastinst=chkobjlastinst(obj); id=-1; type=group[0]; for (i=0;i<=lastinst;i++) { inst2=chkobjinst(obj,i); _getobj(obj,"group",inst2,&group2); if ((group2!=NULL) && (group2[0]==type) && (strcmp(group+2,group2+2)==0)) id=i; } rval->i=id; return 0; } static int axisscalepush(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; int num; double min,max,inc,*data; _getobj(obj,"min",inst,&min); _getobj(obj,"max",inst,&max); _getobj(obj,"inc",inst,&inc); if ((min==0) && (max==0) && (inc==0)) return 0; _getobj(obj,"scale_history",inst,&array); if (array==NULL) { if ((array=arraynew(sizeof(double)))==NULL) return 1; if (_putobj(obj,"scale_history",inst,array)) { arrayfree(array); return 1; } } num=arraynum(array); data=arraydata(array); if ((num>=3) && (data[0]==min) && (data[1]==max) && (data[2]==inc)) return 0; if (num > AXIS_HISTORY_NUM) { arrayndel(array, AXIS_HISTORY_NUM - 1); arrayndel(array, AXIS_HISTORY_NUM - 2); arrayndel(array, AXIS_HISTORY_NUM - 3); } arrayins(array,&inc,0); arrayins(array,&max,0); arrayins(array,&min,0); return 0; } static int axisscalepop(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; int num; double *data; _getobj(obj,"scale_history",inst,&array); if (array==NULL) return 0; num=arraynum(array); data=arraydata(array); if (num>=3) { _putobj(obj,"min",inst,&(data[0])); _putobj(obj,"max",inst,&(data[1])); _putobj(obj,"inc",inst,&(data[2])); arrayndel(array,2); arrayndel(array,1); arrayndel(array,0); } if (arraynum(array)==0) { arrayfree(array); _putobj(obj,"scale_history",inst,NULL); } return 0; } static int anumnozeroput(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int type; type = * (int *) argv[2]; switch (type) { case AXIS_NUM_NO_ZERO_REGULAR: case AXIS_NUM_NO_ZERO_NO_ZERO: case AXIS_NUM_NO_ZERO_NO_FLOATING_POINT: break; case AXIS_NUM_NO_ZERO_TRUE: * (int *) argv[2] = AXIS_NUM_NO_ZERO_NO_ZERO; break; case AXIS_NUM_NO_ZERO_FALSE: * (int *) argv[2] = AXIS_NUM_NO_ZERO_REGULAR; break; } return 0; } static int anumdirput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int type; type = * (int *) argv[2]; switch (type) { case AXIS_NUM_POS_HORIZONTAL: case AXIS_NUM_POS_PARALLEL1: case AXIS_NUM_POS_PARALLEL2: case AXIS_NUM_POS_NORMAL1: case AXIS_NUM_POS_NORMAL2: case AXIS_NUM_POS_OBLIQUE1: case AXIS_NUM_POS_OBLIQUE2: break; case AXIS_NUM_POS_NORMAL: * (int *) argv[2] = AXIS_NUM_POS_HORIZONTAL; break; case AXIS_NUM_POS_PARALLEL: * (int *) argv[2] = AXIS_NUM_POS_PARALLEL1; break; default: * (int *) argv[2] = AXIS_NUM_POS_HORIZONTAL; break; } return 0; } static int num_put_math(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { MathEquation *code; char *math; math = argv[2]; if (math == NULL) { return 0; } g_strstrip(math); if (math[0] == '\0') { g_free(argv[2]); argv[2] = NULL; return 0; } code = get_axis_math(obj, math); if (code) { math_equation_free(code); return 0; } return 1; } static int put_gauge_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "gauge_%c"); } static int put_num_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "num_%c"); } static struct objtable axis[] = { {"init",NVFUNC,NEXEC,axisinit,NULL,0}, {"done",NVFUNC,NEXEC,axisdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"group",NSTR,NREAD,NULL,NULL,0}, {"min",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"max",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"inc",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"div",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"type",NENUM,NREAD|NWRITE,NULL,axistypechar,0}, {"x",NINT,NREAD|NWRITE,axisgeometry,NULL,0}, {"y",NINT,NREAD|NWRITE,axisgeometry,NULL,0}, {"direction",NINT,NREAD|NWRITE,axisdirection,NULL,0}, {"baseline",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"length",NINT,NREAD|NWRITE,axisgeometry,NULL,0}, {"width",NINT,NREAD|NWRITE,NULL,NULL,0}, {"style",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"auto_scale_margin",NINT,NREAD|NWRITE,axisautoscale_margin,NULL,0}, {"adjust_axis",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"adjust_position",NINT,NREAD|NWRITE,NULL,NULL,0}, {"arrow",NENUM,NREAD|NWRITE,NULL,arrowchar,0}, {"arrow_length",NINT,NREAD|NWRITE,axisput,NULL,0}, {"arrow_width",NINT,NREAD|NWRITE,axisput,NULL,0}, {"wave",NENUM,NREAD|NWRITE,NULL,arrowchar,0}, {"wave_length",NINT,NREAD|NWRITE,axisput,NULL,0}, {"wave_width",NINT,NREAD|NWRITE,axisput,NULL,0}, {"reference",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"gauge",NENUM,NREAD|NWRITE,NULL,axisgaugechar,0}, {"gauge_min",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"gauge_max",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"gauge_style",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"gauge_length1",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_width1",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_length2",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_width2",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_length3",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_width3",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"gauge_R",NINT,NREAD|NWRITE,NULL,NULL,0}, {"gauge_G",NINT,NREAD|NWRITE,NULL,NULL,0}, {"gauge_B",NINT,NREAD|NWRITE,NULL,NULL,0}, {"gauge_A",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num",NENUM,NREAD|NWRITE,NULL,axisnumchar,0}, {"num_begin",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"num_step",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"num_num",NINT,NREAD|NWRITE,axisput,NULL,0}, {"num_auto_norm",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"num_head",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"num_format",NSTR,NREAD|NWRITE,axisput,NULL,0}, {"num_tail",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"num_log_pow",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"num_pt",NINT,NREAD|NWRITE,axisput,NULL,0}, {"num_space",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_font",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"num_font_style",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_script_size",NINT,NREAD|NWRITE,axisput,NULL,0}, {"num_align",NENUM,NREAD|NWRITE,NULL,anumalignchar,0}, {"num_no_zero",NENUM,NREAD|NWRITE,anumnozeroput,anumnozero,0}, {"num_direction",NENUM,NREAD|NWRITE,anumdirput,anumdirchar,0}, {"num_shift_p",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_shift_n",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_R",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_G",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_B",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_A",NINT,NREAD|NWRITE,NULL,NULL,0}, {"num_date_format",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"num_math",NSTR,NREAD|NWRITE,num_put_math,NULL,0}, {"scale_push",NVFUNC,NREAD|NEXEC,axisscalepush,"",0}, {"scale_pop",NVFUNC,NREAD|NEXEC,axisscalepop,"",0}, {"scale_history",NDARRAY,NREAD,NULL,NULL,0}, {"scale",NVFUNC,NREAD|NEXEC,axisscale,"ddi",0}, {"auto_scale",NVFUNC,NREAD|NEXEC,axisautoscale,"o",0}, {"get_auto_scale",NDAFUNC,NREAD|NEXEC,axisgetautoscale,"o",0}, {"clear",NVFUNC,NREAD|NEXEC,axisclear,"",0}, {"adjust",NVFUNC,NREAD|NEXEC,axisadjust,"",0}, {"draw",NVFUNC,NREAD|NEXEC,axisdraw,"i",0}, {"bbox",NIAFUNC,NREAD|NEXEC,axisbbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,axismove,"ii",0}, {"rotate",NVFUNC,NREAD|NEXEC,axisrotate,"iiii",0}, {"flip",NVFUNC,NREAD|NEXEC,axisflip,"iii",0}, {"change",NVFUNC,NREAD|NEXEC,axischange,"iii",0}, {"zooming",NVFUNC,NREAD|NEXEC,axiszoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,axismatch,"iiiii",0}, {"coordinate",NDFUNC,NREAD|NEXEC,axiscoordinate,"ii",0}, {"tight",NVFUNC,NREAD|NEXEC,axistight,"",0}, {"grouping",NVFUNC,NREAD|NEXEC,axisgrouping,"ia",0}, {"default_grouping",NVFUNC,NREAD|NEXEC,axisdefgrouping,"ia",0}, {"group_position",NVFUNC,NREAD|NEXEC,axisgrouppos,"ia",0}, {"group_manager",NIFUNC,NREAD|NEXEC,axismanager,"",0}, {"get_numbering",NSAFUNC,NREAD|NEXEC,axis_get_numbering,"",0}, {"save",NSFUNC,NREAD|NEXEC,axissave,"sa",0}, {"hsb", NVFUNC, NREAD|NEXEC, put_hsb,"ddd",0}, {"gauge_hsb", NVFUNC, NREAD|NEXEC, put_gauge_hsb,"ddd",0}, {"num_hsb", NVFUNC, NREAD|NEXEC, put_num_hsb,"ddd",0}, /* following fields exist for backward compatibility */ {"num_jfont",NSTR,NWRITE,NULL,NULL,0}, }; #define TBLNUM (sizeof(axis) / sizeof(*axis)) void * addaxis(void) /* addaxis() returns NULL on error */ { unsigned int i; if (AxisConfigHash == NULL) { AxisConfigHash = nhash_new(); if (AxisConfigHash == NULL) return NULL; for (i = 0; i < sizeof(AxisConfig) / sizeof(*AxisConfig); i++) { if (nhash_set_ptr(AxisConfigHash, AxisConfig[i].name, (void *) &AxisConfig[i])) { nhash_free(AxisConfigHash); return NULL; } } } return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, axis, ERRNUM, axiserrorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/math/0000755000175000017500000000000013375640227012461 500000000000000ngraph-gtk-6.08.00/src/math/math_equation.c0000644000175000017500000007021213352667211015402 00000000000000/* * $Id: math_equation.c,v 1.13 2009-11-24 06:32:37 hito Exp $ * */ #include "config.h" #include #include #include #include "math_parser.h" #include "math_equation.h" #include "object.h" #include "nstring.h" #define BUF_UNIT 64 static void init_parameter(MathEquation *eq); static void free_parameter(MathEquation *eq); static void free_func(NHASH func); static void optimize_func(NHASH func); static int optimize_const_definition(MathEquation *eq); static int math_equation_call_user_func(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); static MathValue * add_to_ary(MathValue *buf, int *num, int *size, const MathValue *val) { MathValue *ptr; if (*num % BUF_UNIT == 0) { int n; n = *num / BUF_UNIT; ptr = g_realloc(buf, sizeof(*buf) * (n + 1) * BUF_UNIT); if (ptr == NULL) { g_free(buf); *num = 0; return NULL; } buf = ptr; if (size) *size = (n + 1) * BUF_UNIT; } if (val) { buf[*num] = *val; } else { buf[*num].val = 0; buf[*num].type = MATH_VALUE_NORMAL; } (*num)++; return buf; } static int * add_to_ary_int(int *buf, int *num, int val) { int *ptr; if (*num % BUF_UNIT == 0) { int n; n = *num / BUF_UNIT; ptr = g_realloc(buf, sizeof(*buf) * (n + 1) * BUF_UNIT); if (ptr == NULL) { g_free(buf); *num = 0; return NULL; } buf = ptr; } buf[*num] = val; (*num)++; return buf; } static MathEquationArray * add_to_ary_array(MathEquationArray *buf, int *num) { MathEquationArray *ptr; if (*num % BUF_UNIT == 0) { int n; n = *num / BUF_UNIT; ptr = g_realloc(buf, sizeof(*buf) * (n + 1) * BUF_UNIT); if (ptr == NULL) { g_free(buf); *num = 0; return NULL; } buf = ptr; } buf[*num].num = 0; buf[*num].size = 0; buf[*num].data = NULL; (*num)++; return buf; } MathEquation * math_equation_basic_new(void) { MathEquation *eq; eq = math_equation_new(); if (eq == NULL) { return NULL; } if (math_add_basic_constant(eq)) goto ErrEnd; if (math_add_basic_function(eq)) goto ErrEnd; return eq; ErrEnd: math_equation_free(eq); return NULL; } MathEquation * math_equation_new(void) { MathEquation *eq; eq = g_malloc(sizeof(*eq)); if (eq == NULL) return NULL; memset(eq, 0, sizeof(*eq)); eq->constant = nhash_new(); eq->function = nhash_new(); eq->variable = nhash_new(); eq->array = nhash_new(); eq->local_array = nhash_new(); eq->local_variable = nhash_new(); if (eq->function == NULL || eq->constant == NULL || eq->variable == NULL || eq->array == NULL || eq->local_variable == NULL || eq->local_array == NULL) { math_equation_free(eq); return NULL; } return eq; } static void clear_pos_func_buf(MathEquation *eq) { int i; if (eq->pos_func_buf) { for (i = 0; i < eq->pos_func_num; i++) { eq->pos_func_buf[i].val = 0; eq->pos_func_buf[i].type = MATH_VALUE_UNDEF; } } } void math_equation_clear(MathEquation *eq) { int i; if (eq == NULL) return; clear_pos_func_buf(eq); if (eq->vnum > 0 && eq->vbuf) { memset(eq->vbuf, 0, sizeof(*eq->vbuf) * eq->vnum); } if (eq->array_num > 0 && eq->array_buf) { for (i = 0; i < eq->array_num; i++) { if (eq->array_buf[i].num > 0 && eq->array_buf[i].data) { memset(eq->array_buf[i].data, 0, sizeof(MathEquationArray) * eq->array_buf[i].num); } } } } void math_equation_set_parse_error(MathEquation *eq, const char *ptr, const struct math_string *str) { if (eq == NULL) return; eq->err_info.pos.pos = ptr; eq->err_info.pos.line = str->line + 1; eq->err_info.pos.ofst = str->ofst + 1; } void math_equation_set_const_error(MathEquation *eq, int id) { if (eq == NULL) return; eq->err_info.const_id = id; } void math_equation_set_func_arg_num_error(MathEquation *eq, struct math_function_parameter *fprm, int arg_num) { if (eq == NULL) return; eq->err_info.func.fprm = fprm; eq->err_info.func.arg_num = arg_num; } void math_equation_set_func_error(MathEquation *eq, struct math_function_parameter *fprm) { math_equation_set_func_arg_num_error(eq, fprm, 0); } int math_equation_parse(MathEquation *eq, const char *str) { int err; if (eq == NULL) return MATH_ERROR_UNKNOWN; memset(&eq->err_info, 0, sizeof(eq->err_info)); if (eq->cnum > 0 && eq->cbuf == NULL) return MATH_ERROR_UNKNOWN; if (eq->pos_func_buf) { g_free(eq->pos_func_buf); eq->pos_func_buf = NULL; } eq->pos_func_num = 0; if (eq->opt_exp) { math_expression_free(eq->opt_exp); eq->opt_exp = NULL; } if (eq->exp) { math_expression_free(eq->exp); } init_parameter(eq); if (str) { eq->exp = math_parser_parse(str, eq, &err); } else { eq->exp = NULL; } if (eq->pos_func_num > 0) { eq->pos_func_buf = g_malloc(eq->pos_func_num * sizeof(*eq->pos_func_buf)); if (eq->pos_func_buf == NULL) { math_expression_free(eq->exp); return MATH_ERROR_MEMORY; } clear_pos_func_buf(eq); } return err; } static void free_array_buf(MathEquationArray *buf, int num) { int i; if (buf == NULL) return; for (i = 0; i < num; i++) { g_free(buf[i].data); } g_free(buf); } void math_equation_free(MathEquation *eq) { if (eq == NULL) return; if (eq->constant) nhash_free(eq->constant); if (eq->variable) nhash_free(eq->variable); if (eq->function) free_func(eq->function); if (eq->array) nhash_free(eq->array); if (eq->local_array) nhash_free(eq->local_array); if (eq->local_variable) nhash_free(eq->local_variable); if (eq->const_def) { math_expression_free(eq->const_def); } free_array_buf(eq->array_buf, eq->array_num); free_parameter(eq); math_expression_free(eq->exp); math_expression_free(eq->opt_exp); g_free(eq->cbuf); g_free(eq->vbuf); g_free(eq->pos_func_buf); g_free(eq); } int math_equation_optimize(MathEquation *eq) { int err; if ((eq == NULL) || (eq->exp == NULL) || (eq->cnum > 0 && eq->cbuf == NULL) || (eq->vnum > 0 && eq->vbuf == NULL)) { return 1; } /* optimize_const_definition() must be called before any other optimization */ if (optimize_const_definition(eq)) { return 1; } /* optimize_func() must be called before optimize_expression() */ optimize_func(eq->function); if (eq->opt_exp) { math_expression_free(eq->opt_exp); } eq->opt_exp = math_expression_optimize(eq->exp, &err); return err; } int math_equation_calculate(MathEquation *eq, MathValue *val) { int r; if (val == NULL) { return 1; } val->val = 0; val->type = MATH_VALUE_ERROR; if ((eq == NULL) || (eq->exp == NULL) || (eq->cnum > 0 && eq->cbuf == NULL) || (eq->vnum > 0 && eq->vbuf == NULL)) { return 1; } if (eq->opt_exp) { r = math_expression_calculate(eq->opt_exp, val); } else { r = math_expression_calculate(eq->exp, val); } return r; } int math_equation_add_parameter(MathEquation *eq, int type, int min, int max, int use_index) { MathEquationParametar *ptr, *prm; prm = g_malloc(sizeof(*prm)); if (prm == NULL) return 1; prm->type = type; prm->min_length = min; prm->max_length = max; prm->use_index = use_index; prm->id_num = 0; prm->id_max = -1; prm->next = NULL; prm->id = NULL; if (eq->parameter == NULL) { eq->parameter = prm; } else { ptr = eq->parameter; while (ptr->next) { ptr = ptr->next; } ptr->next = prm; prm->next = NULL; } return 0; } static int add_parameter_data(MathEquationParametar *ptr, int val) { int i; if (ptr->id == NULL) { ptr->id = add_to_ary_int(ptr->id, &ptr->id_num, val); } else { for (i = 0; i < ptr->id_num; i++) { if (ptr->id[i] == val) { return i; } } ptr->id = add_to_ary_int(ptr->id, &ptr->id_num, val); } if (ptr->id == NULL) { /* error: cannot allocate enough memory */ return -1; } if (val > ptr->id_max) { ptr->id_max = val; } return ptr->id_num - 1; } int math_equation_use_parameter(MathEquation *eq, int type, int val) { MathEquationParametar *ptr; if (eq->parameter == NULL) { /* error: the parameter is not exist */ return -1; } ptr = eq->parameter; while (ptr) { if (ptr->type == type) { break; } ptr = ptr->next; } if (ptr == NULL) { /* error: the parameter is not exist */ return -1; } return add_parameter_data(ptr, val); } int math_equation_set_parameter_data(MathEquation *eq, int type, MathValue *data) { MathEquationParametar *ptr; if (eq->parameter == NULL) { /* error: the parameter is not exist */ return 1; } ptr = eq->parameter; while (ptr) { if (ptr->type == type) { ptr->data = data; return 0; } ptr = ptr->next; } return 1; } MathEquationParametar * math_equation_get_parameter(MathEquation *eq, int type, int *err) { MathEquationParametar *ptr; if (eq == NULL || eq->parameter == NULL) { if (err) { *err = MATH_ERROR_INVALID_PRM; } return NULL; } if (eq->func_def) { if (err) { *err = MATH_ERROR_PRM_IN_DEF; } return NULL; } ptr = eq->parameter; while (ptr) { if (ptr->type == type) { break; } ptr = ptr->next; } return ptr; } static void init_parameter(MathEquation *eq) { MathEquationParametar *ptr; if (eq->parameter == NULL) { return; } ptr = eq->parameter; while (ptr) { if (ptr->id) { g_free(ptr->id); ptr->id = NULL; } ptr->id_num = 0; ptr->id_max = 0; ptr = ptr->next; } } static void free_parameter(MathEquation *eq) { MathEquationParametar *ptr, *next; if (eq->parameter == NULL) { return; } ptr = eq->parameter; while (ptr) { next = ptr->next; if (ptr->id) { g_free(ptr->id); } g_free(ptr); ptr = next; } } int math_equation_add_pos_func(MathEquation *eq, struct math_function_parameter *fprm) { int n; if (! fprm->positional) return -1; if (eq->func_def) return MATH_ERROR_INVALID_FUNC; n = eq->pos_func_num; eq->pos_func_num++; return n; } static void free_func_prm_sub(struct math_function_parameter *ptr) { g_free(ptr->name); if (ptr->opt_usr) { math_expression_free(ptr->opt_usr); ptr->opt_usr = NULL; } if (ptr->base_usr) { math_expression_free(ptr->base_usr); ptr->base_usr = NULL; } g_free(ptr->arg_type); } static void free_func_prm(struct math_function_parameter *ptr) { free_func_prm_sub(ptr); g_free(ptr); } static int free_func_cb(struct nhash *hash, void *ptr) { struct math_function_parameter *fprm; fprm = (struct math_function_parameter *) hash->val.p; free_func_prm(fprm); return 0; } static void free_func(NHASH func) { nhash_each(func, free_func_cb, NULL); nhash_free(func); return; } static int optimize_func_cb(struct nhash *hash, void *ptr) { struct math_function_parameter *fprm; int err; fprm = (struct math_function_parameter *) hash->val.p; if (fprm->opt_usr) { math_expression_free(fprm->opt_usr); fprm->opt_usr = NULL; } if (fprm->base_usr) { fprm->opt_usr = math_expression_optimize(fprm->base_usr, &err); } if (fprm->opt_usr && fprm->opt_usr->u.func.exp->type == MATH_EXPRESSION_TYPE_DOUBLE) { fprm->side_effect = 0; } else { fprm->side_effect = 1; } return 0; } static void optimize_func(NHASH func) { nhash_each(func, optimize_func_cb, NULL); return; } void math_equation_remove_func(MathEquation *eq, const char *name) { int r; struct math_function_parameter *ptr; r = nhash_get_ptr(eq->function, name, (void *) &ptr); if (r == 0) { free_func_prm(ptr); nhash_del(eq->function, name); if (eq->exp) { math_expression_free(eq->exp); eq->exp = NULL; } if (eq->opt_exp) { math_expression_free(eq->opt_exp); eq->opt_exp = NULL; } } } struct math_function_parameter * math_equation_start_user_func_definition(MathEquation *eq, const char *name) { struct math_function_parameter *fprm; if (eq == NULL || eq->func_def) return NULL; fprm = g_malloc(sizeof(*fprm)); if (fprm == NULL) return NULL; fprm->argc = 0; fprm->side_effect = 1; fprm->positional = 0; fprm->func = math_equation_call_user_func; fprm->base_usr = NULL; fprm->opt_usr = NULL; fprm->arg_type = NULL; fprm->name = g_strdup(name); if (fprm->name == NULL) { g_free(fprm); return NULL; } eq->local_vnum = 0; eq->local_array_num = 0; eq->func_def = 1; return fprm; } int math_equation_register_user_func_definition(MathEquation *eq, const char *name, MathExpression *exp) { struct math_function_parameter *fprm; int r; if (eq == NULL || ! eq->func_def || name == NULL || exp == NULL) return 1; fprm = math_equation_get_func(eq, name); if (fprm == NULL) { r = nhash_set_ptr(eq->function, name, exp->u.func.fprm); return r; } #if 0 if (fprm->argc != exp->u.func.fprm->argc) { return 1; } if (fprm->argc > 0) { enum MATH_FUNCTION_ARG_TYPE *arg_type1, *arg_type2; arg_type1 = fprm->arg_type; arg_type2 = exp->u.func.fprm->arg_type; if (arg_type1 && arg_type2) { int i; for (i = 0; i < fprm->argc; i++) { if (arg_type1[i] != arg_type2[i]) { return 1; } } } else if ((arg_type1 && arg_type2 == NULL) || (arg_type1 == NULL && arg_type2)) { return 1; } } #endif free_func_prm_sub(fprm); memcpy(fprm, exp->u.func.fprm, sizeof(*fprm)); g_free(exp->u.func.fprm); exp->u.func.fprm = fprm; return 0; } int math_equation_finish_user_func_definition(MathEquation *eq, int *vnum, int *anum) { if (eq == NULL || ! eq->func_def) return 1; if (vnum) *vnum = nhash_num(eq->local_variable); nhash_clear(eq->local_variable); if (anum) *anum = nhash_num(eq->local_array); nhash_clear(eq->local_array); eq->local_vnum = 0; eq->local_array_num = 0; eq->func_def = 0; return 0; } struct math_function_parameter * math_equation_add_func(MathEquation *eq, const char *name, struct math_function_parameter *prm) { int r; struct math_function_parameter *ptr; if (eq == NULL) return NULL; r = nhash_get_ptr(eq->function, name, (void *) &ptr); if (r == 0) { free_func_prm(ptr); } ptr = g_malloc(sizeof(*ptr)); if (ptr == NULL) return NULL; memcpy(ptr, prm, sizeof(*ptr)); ptr->name = g_strdup(name); if (ptr->name == NULL) { g_free(ptr); return NULL; } if (prm->arg_type) { int argc; argc = math_function_get_arg_type_num(prm); if (argc > 0) { ptr->arg_type = g_malloc(sizeof(*prm->arg_type) * argc); if (ptr->arg_type == NULL) { g_free(ptr->name); g_free(ptr); return NULL; } memcpy(ptr->arg_type, prm->arg_type, sizeof(*prm->arg_type) * argc); } } r = nhash_set_ptr(eq->function, name, ptr); if (r) { g_free(ptr->name); g_free(ptr->arg_type); g_free(ptr); return NULL; } return ptr; } struct math_function_parameter * math_equation_get_func(MathEquation *eq, const char *name) { int r; struct math_function_parameter *ptr; r = nhash_get_ptr(eq->function, name, (void *) &ptr); if (r) { return NULL; } return (struct math_function_parameter *) ptr; } int math_equation_add_const(MathEquation *eq, const char *name, const MathValue *val) { int i, r; if (eq == NULL) return -1; r = nhash_get_int(eq->constant, name, &i); if (r) { i = eq->cnum; eq->cbuf = add_to_ary(eq->cbuf, &eq->cnum, NULL, val); if (eq->cbuf == NULL) { /* error: cannot allocate enough memory */ return -1; } nhash_set_int(eq->constant, name, i); } else if (eq->cbuf && i < eq->cnum && val) { eq->cbuf[i] = *val; } return i; } int math_equation_add_const_definition(MathEquation *eq, const char *name, MathExpression *exp, int *err) { int i, r; MathValue val; if (eq == NULL) return -1; r = nhash_get_int(eq->constant, name, &i); if (r == 0) { /* error: the constant is already exist */ *err = MATH_ERROR_CONST_EXIST; eq->err_info.const_id = i; return -1; } if (math_expression_calculate(exp->u.const_def.operand, &val)) { *err = MATH_ERROR_CALCULATION; return -1; } i = math_equation_add_const(eq, name, &val); if (i < 0) { *err = MATH_ERROR_MEMORY; return -1; } exp->u.const_def.id = i; exp->next = eq->const_def; eq->const_def = exp; return i; } static int optimize_const_definition(MathEquation *eq) { MathExpression *exp; MathValue val; if (eq->const_def == NULL) { return 0; } exp = eq->const_def; while (exp) { if (math_expression_calculate(exp->u.const_def.operand, &val)) return 1; math_equation_set_const(eq, exp->u.const_def.id, &val); exp = exp->next; } return 0; } static int expand_stack(MathEquation *eq, int size) { MathValue *ptr; int n, request_size; request_size = eq->stack_end + size; if (eq->vbuf_size <= request_size) { n = (request_size / BUF_UNIT + 1) * BUF_UNIT; ptr = g_realloc(eq->vbuf, sizeof(*ptr) * n); if (ptr == NULL) return 1; eq->vbuf = ptr; eq->vbuf_size = n; } if (eq->vbuf == NULL) return 1; memset(eq->vbuf + eq->stack_end, 0, sizeof(*eq->vbuf) * size); eq->stack_ofst = eq->stack_end; eq->stack_end = request_size; return 0; } int math_equation_add_var(MathEquation *eq, const char *name) { int i, r; if (eq == NULL) return -1; if (eq->func_def) { r = nhash_get_int(eq->local_variable, name, &i); if (r) { i = eq->local_vnum; nhash_set_int(eq->local_variable, name, i); eq->local_vnum++; } return i; } r = nhash_get_int(eq->variable, name, &i); if (r) { i = eq->vnum; if (expand_stack(eq, 1)) { /* error: cannot allocate enough memory */ return -1; } eq->stack_ofst = 0; eq->vnum++; nhash_set_int(eq->variable, name, i); } return i; } int math_equation_set_const_by_name(MathEquation *eq, const char *name, const MathValue *val) { int i, r; r = nhash_get_int(eq->constant, name, &i); if (r) { return 1; } if (eq->cbuf == NULL) { return 1; } eq->cbuf[i] = *val; return 0; } struct search_val { int val; char *name; }; int search_val_cb(struct nhash *hash, void *ptr) { struct search_val *v; v = (struct search_val *) ptr; if (hash->val.i == v->val) { v->name = hash->key; } return 0; } char * math_equation_get_var_name(MathEquation *eq, int idx) { struct search_val v; if (eq == NULL) return NULL; v.val = idx; v.name = NULL; nhash_each(eq->variable, search_val_cb, &v); return v.name; } char * math_equation_get_const_name(MathEquation *eq, int idx) { struct search_val v; if (eq == NULL) return NULL; v.val = idx; v.name = NULL; nhash_each(eq->constant, search_val_cb, &v); return v.name; } int math_equation_set_const(MathEquation *eq, int idx, const MathValue *val) { if (eq->cbuf == NULL || idx >= eq->cnum || idx < 0) { return 1; } eq->cbuf[idx] = *val; return 0; } int math_equation_set_var(MathEquation *eq, int idx, const MathValue *val) { if (eq->vbuf == NULL || idx + eq->stack_ofst >= eq->stack_end) { return 1; } eq->vbuf[idx + eq->stack_ofst] = *val; return 0; } int math_equation_get_const_by_name(MathEquation *eq, const char *name, MathValue *val) { int i, r; r = nhash_get_int(eq->constant, name, &i); if (r) { /* error: cannot find the constant */ return -1; } if (eq->cbuf == NULL) { /* error: cannot find the constant */ return -1; } if (val) { *val = eq->cbuf[i]; } return i; } int math_equation_get_const(MathEquation *eq, int idx, MathValue *val) { if (eq->cbuf == NULL || idx >= eq->cnum) { return 1; } *val = eq->cbuf[idx]; return 0; } #define USER_FUNC_NEST_MAX 8192 static int math_equation_call_user_func(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { static int nest = 0; int ofst, end, r, i, j, prev_num; MathEquationArray *prev, *local = NULL; MathExpression *func; MathFunctionArgument *argv; if (nest > USER_FUNC_NEST_MAX) return 1; if (exp->fprm->opt_usr) { func = exp->fprm->opt_usr; } else if (exp->fprm->base_usr) { func = exp->fprm->base_usr; } else { return 1; } argv = exp->buf; ofst = eq->stack_ofst; end = eq->stack_end; prev = eq->array_buf; prev_num = eq->array_num; if (func->u.func.local_array_num > 0) { local = g_malloc(sizeof(*local) * func->u.func.local_array_num); if (local == NULL) return 1; memset(local, 0, sizeof(*local) * func->u.func.local_array_num); if (func->u.func.fprm->arg_type) { j = 0; for (i = 0; i < func->u.func.argc; i++) { if (func->u.func.fprm->arg_type[i] == MATH_FUNCTION_ARG_TYPE_ARRAY) { local[j] = prev[argv[i].idx]; j++; } } } } if (expand_stack(eq, func->u.func.local_num)) { g_free(local); return 1; } eq->array_buf = local; eq->array_num = func->u.func.local_array_num; j = 0; for (i = 0; i < exp->argc; i++) { if (func->u.func.fprm->arg_type == NULL || func->u.func.fprm->arg_type[i] == MATH_FUNCTION_ARG_TYPE_DOUBLE) { eq->vbuf[eq->stack_ofst + j] = argv[i].val; j++; } } nest++; r = math_expression_calculate(func->u.func.exp, rval); nest--; eq->array_num = prev_num; eq->array_buf = prev; eq->stack_end = end; eq->stack_ofst = ofst; if (func->u.func.fprm->arg_type) { j = 0; for (i = 0; i < func->u.func.argc; i++) { if (func->u.func.fprm->arg_type[i] == MATH_FUNCTION_ARG_TYPE_ARRAY) { prev[argv[i].idx] = local[j]; local[j].num = 0; local[j].size = 0; local[j].data = NULL; j++; } } } free_array_buf(local, func->u.func.local_array_num); return r; } int math_equation_check_var(MathEquation *eq, const char *name) { int r, i; if (eq->func_def) { r = nhash_get_int(eq->local_variable, name, &i); } else { r = nhash_get_int(eq->variable, name, &i); } if (r) { return -1; } return i; } int math_equation_get_var(MathEquation *eq, int idx, MathValue *val) { if (eq->vbuf == NULL || idx + eq->stack_ofst >= eq->stack_end) { return 1; } if (val) { *val = eq->vbuf[idx + eq->stack_ofst]; } return 0; } void math_equation_clear_variable(MathEquation *eq) { if (eq->vbuf) { g_free(eq->vbuf); eq->vnum = 0; eq->vbuf = NULL; } nhash_clear(eq->variable); } char * math_equation_get_array_name(MathEquation *eq, int index) { return NULL; } int math_equation_check_array(MathEquation *eq, const char *name) { int r, i; if (eq->func_def) { r = nhash_get_int(eq->local_array, name, &i); } else { r = nhash_get_int(eq->array, name, &i); } if (r) { return -1; } return i; } int math_equation_add_array(MathEquation *eq, const char *name) { int i, r; if (eq == NULL) return -1; if (eq->func_def) { r = nhash_get_int(eq->local_array, name, &i); if (r) { i = eq->local_array_num; if (nhash_set_int(eq->local_array, name, i)) { /* error: cannot allocate enough memory */ return -1; } eq->local_array_num++; } } else { r = nhash_get_int(eq->array, name, &i); if (r) { i = eq->array_num; eq->array_buf = add_to_ary_array(eq->array_buf, &eq->array_num); if (eq->array == NULL) { /* error: cannot allocate enough memory */ return -1; } if (nhash_set_int(eq->array, name, i)) { /* error: cannot allocate enough memory */ return -1; } } } return i; } static int check_array(MathEquation *eq, int id, int index) { int i; MathEquationArray *ary; MathValue *ptr; if (eq == NULL || eq->array_buf == NULL || id < 0 || id >= eq->array_num) { /* error: the array is not exist */ return -1; } ary = eq->array_buf + id; if (index < 0) { i = ary->num + index; } else { i = index; } if (i < 0 || i > MATH_EQUATION_ARRAY_INDEX_MAX) { /* error: the index of the array is out of bound */ return -1; } if (i >= ary->size) { int n; n = (i / BUF_UNIT + 1) * BUF_UNIT; ptr = g_realloc(ary->data, sizeof(*ary->data) * n); if (ptr == NULL) { /* error: cannot allocate enough memory */ return -1; } memset(ptr + ary->num, 0, sizeof(*ptr) * (n - ary->num)); ary->data = ptr; ary->size = n; } if (i >= ary->num) { ary->num = i + 1; } return i; } int math_equation_clear_array(MathEquation *eq, int array) { int i; i = check_array(eq, array, 0); if (i < 0) return 1; eq->array_buf[array].num = 0; return 0; } int math_equation_set_array_val(MathEquation *eq, int array, int index, const MathValue *val) { int i; i = check_array(eq, array, index); if (i < 0) return 1; eq->array_buf[array].data[i] = *val; return 0; } int math_equation_push_array_val(MathEquation *eq, int array, const MathValue *val) { MathEquationArray *ary; ary = math_equation_get_array(eq, array); if (ary == NULL) { return 1; } return math_equation_set_array_val(eq, array, ary->num, val); } int math_equation_get_array_val(MathEquation *eq, int array, int index, MathValue *val) { int i; i = check_array(eq, array, index); if (i < 0) return 1; *val = eq->array_buf[array].data[i]; return 0; } MathEquationArray * math_equation_get_array(MathEquation *eq, int array) { if (array < 0 || array >= eq->array_num || eq->array_buf == NULL) { /* error: the array is not exist */ return NULL; } return &eq->array_buf[array]; } void math_equation_set_user_data(MathEquation *eq, void *user_data) { if (eq) { eq->user_data = user_data; } } void * math_equation_get_user_data(MathEquation *eq) { return (eq) ? eq->user_data : NULL; } static int check_const_sub(MathExpression *exp, int *constant, int n) { int i, r; if (exp == NULL) return 0; r = 0; switch (exp->type) { case MATH_EXPRESSION_TYPE_OR: case MATH_EXPRESSION_TYPE_AND: case MATH_EXPRESSION_TYPE_EQ: case MATH_EXPRESSION_TYPE_NE: case MATH_EXPRESSION_TYPE_ADD: case MATH_EXPRESSION_TYPE_SUB: case MATH_EXPRESSION_TYPE_MUL: case MATH_EXPRESSION_TYPE_DIV: case MATH_EXPRESSION_TYPE_MOD: case MATH_EXPRESSION_TYPE_POW: case MATH_EXPRESSION_TYPE_GT: case MATH_EXPRESSION_TYPE_GE: case MATH_EXPRESSION_TYPE_LT: case MATH_EXPRESSION_TYPE_LE: r = check_const_sub(exp->u.bin.left, constant, n); if (r) { return r; } r = check_const_sub(exp->u.bin.right, constant, n); break; case MATH_EXPRESSION_TYPE_ASSIGN: r = check_const_sub(exp->u.assign.right, constant, n); break; case MATH_EXPRESSION_TYPE_FUNC: r = check_const_sub(exp->u.func.exp, constant, n); break; case MATH_EXPRESSION_TYPE_FUNC_CALL: for (i = 0; i < exp->u.func_call.argc; i++) { r = check_const_sub(exp->u.func_call.argv[i], constant, n); if (r) { return r; } } break; case MATH_EXPRESSION_TYPE_MINUS: case MATH_EXPRESSION_TYPE_FACT: r = check_const_sub(exp->u.unary.operand, constant, n); break; case MATH_EXPRESSION_TYPE_CONST: for (i = 0; i < n; i++) { if (constant[i] == exp->u.index) { return 1; } } break; case MATH_EXPRESSION_TYPE_CONST_DEF: case MATH_EXPRESSION_TYPE_ARRAY: case MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT: case MATH_EXPRESSION_TYPE_VARIABLE: case MATH_EXPRESSION_TYPE_DOUBLE: case MATH_EXPRESSION_TYPE_PRM: case MATH_EXPRESSION_TYPE_EOEQ: break; } return r; } struct search_const { int *constant, n, r; }; static int check_counst_in_func(struct nhash *hash, void *ptr) { int r; struct math_function_parameter *fprm; struct search_const *sc; fprm = (struct math_function_parameter *) hash->val.p; sc = (struct search_const *) ptr; r = check_const_sub(fprm->base_usr, sc->constant, sc->n); sc->r = r; return r; } int math_equation_check_const(MathEquation *eq, int *constant, int n) { int r; struct search_const sc; MathExpression *exp; if (eq == NULL || constant == NULL) return 0; sc.constant = constant; sc.n = n; sc.r = 0; nhash_each(eq->function, check_counst_in_func, &sc); if (sc.r) { return sc.r; } r = 0; exp = eq->exp; while (exp) { r = check_const_sub(exp, constant, n); if (r) { break; } exp = exp->next; } return r; } ngraph-gtk-6.08.00/src/math/math_operator.h.in0000644000175000017500000000050413070106167016012 00000000000000- MINUS + PLUS * MUL / DIV \ MOD ^ POW ! FACT : ASSIGN := ASSIGN > GT < LT >: GE >= GE <: LE <= LE :: EQ == EQ !: NE != NE || OR && AND -: MINUS_ASSIGN -= MINUS_ASSIGN +: PLUS_ASSIGN += PLUS_ASSIGN *: MUL_ASSIGN *= MUL_ASSIGN /: DIV_ASSIGN /= DIV_ASSIGN \: MOD_ASSIGN \= MOD_ASSIGN ^: POW_ASSIGN ^= POW_ASSIGN = EOEQ ; EOEQ ngraph-gtk-6.08.00/src/math/math_expression.h0000644000175000017500000001206613352667211015764 00000000000000/* * $Id: math_expression.h,v 1.3 2009-11-10 04:12:20 hito Exp $ * */ #ifndef EXPRESSION_HEADER #define EXPRESSION_HEADER typedef struct _math_expression MathExpression; typedef struct _math_function_call_expression MathFunctionCallExpression; typedef union _math_function_argument MathFunctionArgument; #include "nhash.h" #include "math_equation.h" #include "math_function.h" #include "math_operator.h" enum MATH_EXPRESSION_TYPE { MATH_EXPRESSION_TYPE_OR, MATH_EXPRESSION_TYPE_AND, MATH_EXPRESSION_TYPE_EQ, MATH_EXPRESSION_TYPE_NE, MATH_EXPRESSION_TYPE_ADD, MATH_EXPRESSION_TYPE_SUB, MATH_EXPRESSION_TYPE_MUL, MATH_EXPRESSION_TYPE_DIV, MATH_EXPRESSION_TYPE_MOD, MATH_EXPRESSION_TYPE_POW, MATH_EXPRESSION_TYPE_GT, MATH_EXPRESSION_TYPE_GE, MATH_EXPRESSION_TYPE_LT, MATH_EXPRESSION_TYPE_LE, MATH_EXPRESSION_TYPE_MINUS, MATH_EXPRESSION_TYPE_FUNC, MATH_EXPRESSION_TYPE_FUNC_CALL, MATH_EXPRESSION_TYPE_FACT, MATH_EXPRESSION_TYPE_DOUBLE, MATH_EXPRESSION_TYPE_CONST, MATH_EXPRESSION_TYPE_CONST_DEF, MATH_EXPRESSION_TYPE_VARIABLE, MATH_EXPRESSION_TYPE_ARRAY, MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT, MATH_EXPRESSION_TYPE_PRM, MATH_EXPRESSION_TYPE_ASSIGN, MATH_EXPRESSION_TYPE_EOEQ, }; struct math_func_arg_list { char *name; enum MATH_FUNCTION_ARG_TYPE type; struct math_func_arg_list *next; }; typedef struct _math_function_expression { int argc, local_num, local_array_num; MathExpression *exp; struct math_function_parameter *fprm; struct math_func_arg_list *arg_list, *arg_last; } MathFunctionExpression ; typedef struct _math_binary_expression { MathExpression *left; MathExpression *right; } MathBinaryExpression; typedef struct _math_assign_expression { enum MATH_OPERATOR_TYPE op; MathExpression *left; MathExpression *right; } MathAssignExpression; typedef struct _math_unary_expression { MathExpression *operand; } MathUnaryExpression; typedef struct _math_constant_definition_expression { int id; MathExpression *operand; } MathConstantDefinitionExpression; union _math_function_argument { MathValue val; MathExpression *exp; int idx; }; struct _math_function_call_expression { MathExpression **argv; MathFunctionArgument *buf; int argc, pos_id; struct math_function_parameter *fprm; }; typedef struct _math_parameter_expression { int type, id, index; MathEquationParametar *prm; } MathParameterExpression; typedef struct _math_array_expression { int index; MathExpression *operand; } MathArrayExpression; struct _math_expression { enum MATH_EXPRESSION_TYPE type; int line_number; MathExpression *next; MathEquation *equation; union { MathValue value; char *symbol; int index; MathBinaryExpression bin; MathUnaryExpression unary; MathFunctionCallExpression func_call; MathFunctionExpression func; MathParameterExpression prm; MathArrayExpression array; MathConstantDefinitionExpression const_def; MathAssignExpression assign; } u; }; MathExpression *math_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, int *err); MathExpression *math_eoeq_expression_new(MathEquation *eq, int *err); MathExpression *math_array_expression_new(MathEquation *eq, const char *name, MathExpression *operand, int *err); MathExpression *math_array_argument_expression_new(MathEquation *eq, const char *name, int *err); MathExpression *math_unary_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *operand, int *err); MathExpression *math_binary_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *left, MathExpression *right, int *err); MathExpression *math_assign_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *left, MathExpression *right, enum MATH_OPERATOR_TYPE op, int *err); MathExpression *math_double_expression_new(MathEquation *eq, const MathValue *val, int *err); MathExpression *math_constant_expression_new(MathEquation *eq, const char *name, int *err); MathExpression *math_variable_expression_new(MathEquation *eq, const char *name, int *err); MathExpression *math_func_call_expression_new(MathEquation *eq, struct math_function_parameter *fprm, int argc, MathExpression **argv, int pos_id, int *err); MathExpression *math_parameter_expression_new(MathEquation *eq, char *name, int *err); MathExpression *math_constant_definition_expression_new(MathEquation *eq, char *name, MathExpression *exp, int *err); MathExpression *math_function_expression_new(MathEquation *eq, const char *name, int *err); int math_function_expression_add_arg(MathExpression *func, const char *arg_name, enum MATH_FUNCTION_ARG_TYPE type); int math_function_expression_set_function(MathEquation *eq, MathExpression *func, const char *name, MathExpression *exp); int math_function_expression_register_arg(MathExpression *func); MathExpression *math_expression_optimize(MathExpression *exp, int *err); void math_expression_free(MathExpression *exp); int math_expression_calculate(MathExpression *exp, MathValue *val); int math_function_get_arg_type_num(struct math_function_parameter *fprm); #endif ngraph-gtk-6.08.00/src/math/math_constant.rb0000644000175000017500000000370613070106167015566 00000000000000#! /usr/bin/ruby const_str = []; IO.foreach(ARGV[0]) { |l| l.chomp! next if (l.length < 1) const_str.push(l.split) } const_str = const_str.uniq.sort {|a, b| b[0].length - a[0].length} File.open("#{ARGV[1]}.h", "w") { |f| f.puts < #include "math_expression.h" #include "math_equation.h" #include "math_constant.h" static struct math_const_parameter MathConstParameter[] = { EOF const_str.each {|s| if (s.length == 3) f.puts(" {\"#{s[0]}\", MATH_SCANNER_VAL_TYPE_NORMAL, {#{s[1]}, #{s[2]}}},") end } f.puts("};\n\n") f.puts < #include #include #include "common.h" #include "math_equation.h" #define ERR_MSG_EOEQ N_("syntax error, unexpected end of equation.") #define ERR_MSG_FUNC_NEST N_("syntax error, function definition cannot be nested.") #define ERR_MSG_UNEXP_OP N_("syntax error, unexpected operator.") #define ERR_MSG_UNEXP_TOK N_("syntax error, unexpected token.") #define ERR_MSG_ARG_NUM N_("syntax error, wrong number of arguments.") #define ERR_MSG_MISS_RP N_("syntax error, unexpected end of equation, expecting ')'.") #define ERR_MSG_MISS_RC N_("syntax error, unexpected end of equation, expecting '}'.") #define ERR_MSG_MISS_RB N_("syntax error, unexpected end of equation, expecting ']'.") #define ERR_MSG_INVALID_F N_("syntax error, invalid function definition.") #define ERR_MSG_INVALID_C N_("syntax error, constant cannot be defined in a function definition.") #define ERR_MSG_INVALID_P N_("error, invalid parameter.") #define ERR_MSG_PRM_IN_DEF N_("error, a parameter cannot be used in a user function or a constant definition.") #define ERR_MSG_UNKNOWN_F N_("error, unknown function.") #define ERR_MSG_MEMORY N_("error, cannot allocate enough memory.") #define ERR_MSG_UNKNOWN N_("error, unknown error.") #define ERR_MSG_POS_FUNC N_("error, the function cannot be used in a user function or a constant definition.") #define ERR_MSG_CONST_EXIST N_("error, the constant is already defined.") #define ERR_MSG_CALCULATION N_("error, calculation error.") static int ErrorLine = 1, ErrorOfst = 1; static char * check_error_position(MathEquation *eq, const char *code) { int i, l, len; char *buf; if (code == NULL) return NULL; len = strlen(code); l = eq->err_info.pos.pos - code; if (l < 0) return NULL; if (l >= len) return NULL; if (eq->err_info.pos.pos[0] == ';' || eq->err_info.pos.pos[0] == '=' || eq->err_info.pos.pos[0] == '\0') return NULL; len -= l; buf = g_malloc(len + 1); if (buf == NULL) return NULL; for (i = 0; i < len; i++) { if (eq->err_info.pos.pos[i] == ';' || eq->err_info.pos.pos[i] == '=') break; buf[i] = eq->err_info.pos.pos[i]; } buf[i] = '\0'; ErrorLine = eq->err_info.pos.line; ErrorOfst = eq->err_info.pos.ofst; return buf; } char * math_err_get_error_message(MathEquation *eq, const char *code, int err) { char *code_buf = NULL, *buf = NULL, *ptr; ErrorLine = 1; switch (err) { case MATH_ERROR_NONE: break; case MATH_ERROR_EOEQ: buf = g_strdup(_(ERR_MSG_EOEQ)); break; case MATH_ERROR_FDEF_NEST: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_FUNC_NEST), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_FUNC_NEST)); } break; case MATH_ERROR_UNEXP_OPE: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_UNEXP_OP), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_UNEXP_OP)); } break; case MATH_ERROR_ARG_NUM: if (eq->err_info.func.fprm) { buf = g_strdup_printf("%s (%d for %d) '%s()' (%d:%d)", _(ERR_MSG_ARG_NUM), eq->err_info.func.arg_num, eq->err_info.func.fprm->argc, eq->err_info.func.fprm->name, eq->err_info.pos.line, eq->err_info.pos.ofst); } else { buf = g_strdup(_(ERR_MSG_ARG_NUM)); } break; case MATH_ERROR_MISS_RP: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_MISS_RP), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_MISS_RP)); } break; case MATH_ERROR_MISS_RB: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_MISS_RB), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_MISS_RB)); } break; case MATH_ERROR_MISS_RC: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_MISS_RC), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_MISS_RC)); } break; case MATH_ERROR_UNKNOWN_FUNC: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_UNKNOWN_F), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_UNKNOWN_F)); } break; case MATH_ERROR_INVALID_FDEF: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_INVALID_F), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_INVALID_F)); } break; case MATH_ERROR_INVALID_CDEF: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_INVALID_C), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_INVALID_C)); } break; case MATH_ERROR_UNEXP_TOKEN: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_UNEXP_TOK), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_UNEXP_TOK)); } break; case MATH_ERROR_INVALID_PRM: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_INVALID_P), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_INVALID_P)); } break; case MATH_ERROR_PRM_IN_DEF: code_buf = check_error_position(eq, code); if (code_buf) { buf = g_strdup_printf(_("%s (%d:%d)\n the error is found at: %s"), _(ERR_MSG_PRM_IN_DEF), eq->err_info.pos.line, eq->err_info.pos.ofst, code_buf); } else { buf = g_strdup(_(ERR_MSG_PRM_IN_DEF)); } break; case MATH_ERROR_MEMORY: buf = g_strdup(_(ERR_MSG_MEMORY)); break; case MATH_ERROR_UNKNOWN: buf = g_strdup(_(ERR_MSG_UNKNOWN)); break; case MATH_ERROR_INVALID_FUNC: if (eq->err_info.func.fprm) { buf = g_strdup_printf("%s '%s()' (%d:%d)", _(ERR_MSG_POS_FUNC), eq->err_info.func.fprm->name, eq->err_info.pos.line, eq->err_info.pos.ofst); } else { buf = g_strdup(_(ERR_MSG_POS_FUNC)); } break; case MATH_ERROR_CONST_EXIST: ptr = math_equation_get_const_name(eq, eq->err_info.const_id); if (ptr) { buf = g_strdup_printf("%s '%s' (%d:%d)", _(ERR_MSG_CONST_EXIST), ptr, eq->err_info.pos.line, eq->err_info.pos.ofst); } else { buf = g_strdup(_(ERR_MSG_CONST_EXIST)); } break; case MATH_ERROR_CALCULATION: buf = g_strdup(_(ERR_MSG_CALCULATION)); break; default: buf = g_strdup(_(ERR_MSG_UNKNOWN)); } if (code_buf) g_free(code_buf); if (buf) { gsize len; ptr = g_locale_from_utf8(buf, -1, NULL, &len, NULL); g_free(buf); buf = ptr; } return buf; } void math_err_get_recent_error_position(int *line, int *ofst) { if (line) { *line = ErrorLine; } if (ofst) { *ofst = ErrorOfst; } } ngraph-gtk-6.08.00/src/math/math_function.c0000644000175000017500000003657713243246336015422 00000000000000#include "config.h" #include #include #include #include "math_expression.h" #include "math_equation.h" #include "math_function.h" struct funcs { char *name; struct math_function_parameter prm; }; static struct funcs FuncAry[] = { {"ARRAY_AVERAGE", {1, 1, 0, math_func_array_average, NULL, NULL, NULL, NULL}}, {"ARRAY_COMPACT", {1, 1, 0, math_func_array_compact, NULL, NULL, NULL, NULL}}, {"ARRAY_STDEVP", {1, 1, 0, math_func_array_stdevp, NULL, NULL, NULL, NULL}}, {"ARRAY_CLEAR", {1, 1, 0, math_func_array_clear, NULL, NULL, NULL, NULL}}, {"ARRAY_SUMSQ", {1, 1, 0, math_func_array_sumsq, NULL, NULL, NULL, NULL}}, {"ARRAY_STDEV", {1, 1, 0, math_func_array_stdev, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ZETAM1_INT", {1, 0, 0, math_func_zetam1_int, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"MJD2MONTH", {1, 0, 0, math_func_mjd2month, NULL, NULL, NULL, NULL}}, {"ARRAY_SUM", {1, 1, 0, math_func_array_sum, NULL, NULL, NULL, NULL}}, {"ARRAY_MIN", {1, 1, 0, math_func_array_min, NULL, NULL, NULL, NULL}}, {"ARRAY_MAX", {1, 1, 0, math_func_array_max, NULL, NULL, NULL, NULL}}, {"UNIX2MJD", {1, 0, 0, math_func_unix2mjd, NULL, NULL, NULL, NULL}}, {"MJD2YEAR", {1, 0, 0, math_func_mjd2year, NULL, NULL, NULL, NULL}}, {"MJD2WDAY", {1, 0, 0, math_func_mjd2wday, NULL, NULL, NULL, NULL}}, {"MJD2YDAY", {1, 0, 0, math_func_mjd2yday, NULL, NULL, NULL, NULL}}, {"ISNORMAL", {1, 0, 0, math_func_isnormal, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ZETA_INT", {1, 0, 0, math_func_zeta_int, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"MJD2UNIX", {1, 0, 0, math_func_mjd2unix, NULL, NULL, NULL, NULL}}, {"MJD2DAY", {1, 0, 0, math_func_mjd2day, NULL, NULL, NULL, NULL}}, {"ISUNDEF", {1, 0, 0, math_func_isundef, NULL, NULL, NULL, NULL}}, {"ISBREAK", {1, 0, 0, math_func_isbreak, NULL, NULL, NULL, NULL}}, {"UNSHIFT", {2, 0, 0, math_func_unshift, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ICBETA", {3, 0, 0, math_func_icbeta, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"UNLESS", {3, 0, 0, math_func_unless, NULL, NULL, NULL, NULL}}, {"ISCONT", {1, 0, 0, math_func_iscont, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ZETAM1", {1, 0, 0, math_func_zetam1, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"CHOOSE", {2, 0, 0, math_func_choose, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"GAUSS", {1, 0, 0, math_func_gauss, NULL, NULL, NULL, NULL}}, {"ROUND", {1, 0, 0, math_func_round, NULL, NULL, NULL, NULL}}, {"ASINH", {1, 0, 0, math_func_asinh, NULL, NULL, NULL, NULL}}, {"ACOSH", {1, 0, 0, math_func_acosh, NULL, NULL, NULL, NULL}}, {"ATANH", {1, 0, 0, math_func_atanh, NULL, NULL, NULL, NULL}}, {"SRAND", {1, 0, 0, math_func_srand, NULL, NULL, NULL, NULL}}, {"THETA", {1, 0, 0, math_func_theta, NULL, NULL, NULL, NULL}}, {"DELTA", {1, 0, 0, math_func_delta, NULL, NULL, NULL, NULL}}, {"GAMMA", {1, 0, 0, math_func_gamma, NULL, NULL, NULL, NULL}}, {"ICGAM", {2, 0, 0, math_func_icgam, NULL, NULL, NULL, NULL}}, {"RSORT", {1, 1, 0, math_func_rsort, NULL, NULL, NULL, NULL}}, {"ARRAY", {-2, 1, 0, math_func_array, NULL, NULL, NULL, NULL}}, {"ISNAN", {1, 0, 0, math_func_isnan, NULL, NULL, NULL, NULL}}, {"PROGN", {-1, 0, 0, math_func_progn, NULL, NULL, NULL, NULL}}, {"PROG1", {-1, 0, 0, math_func_prog1, NULL, NULL, NULL, NULL}}, {"PROG2", {-1, 0, 0, math_func_prog2, NULL, NULL, NULL, NULL}}, {"SHIFT", {1, 0, 0, math_func_shift, NULL, NULL, NULL, NULL}}, {"SUMSQ", {-1, 0, 0, math_func_sumsq, NULL, NULL, NULL, NULL}}, {"SIGN", {1, 0, 0, math_func_sign, NULL, NULL, NULL, NULL}}, {"FRAC", {1, 0, 0, math_func_frac, NULL, NULL, NULL, NULL}}, {"SQRT", {1, 0, 0, math_func_sqrt, NULL, NULL, NULL, NULL}}, {"ASIN", {1, 0, 0, math_func_asin, NULL, NULL, NULL, NULL}}, {"ACOS", {1, 0, 0, math_func_acos, NULL, NULL, NULL, NULL}}, {"ATAN", {1, 0, 0, math_func_atan, NULL, NULL, NULL, NULL}}, {"SINH", {1, 0, 0, math_func_sinh, NULL, NULL, NULL, NULL}}, {"COSH", {1, 0, 0, math_func_cosh, NULL, NULL, NULL, NULL}}, {"TANH", {1, 0, 0, math_func_tanh, NULL, NULL, NULL, NULL}}, {"RAND", {1, 0, 0, math_func_rand, NULL, NULL, NULL, NULL}}, {"ERFC", {1, 0, 0, math_func_erfc, NULL, NULL, NULL, NULL}}, {"QINV", {1, 0, 0, math_func_qinv, NULL, NULL, NULL, NULL}}, {"BETA", {2, 0, 0, math_func_beta, NULL, NULL, NULL, NULL}}, {"SORT", {1, 1, 0, math_func_sort, NULL, NULL, NULL, NULL}}, {"SIZE", {1, 1, 0, math_func_size, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ZETA", {1, 0, 0, math_func_zeta, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"PUSH", {2, 0, 0, math_func_push, NULL, NULL, NULL, NULL}}, {"TIME", {0, 0, 0, math_func_time, NULL, NULL, NULL, NULL}}, {"FMOD", {2, 0, 0, math_func_fmod, NULL, NULL, NULL, NULL}}, {"ABS", {1, 0, 0, math_func_abs, NULL, NULL, NULL, NULL}}, {"INT", {1, 0, 0, math_func_int, NULL, NULL, NULL, NULL}}, {"MIN", {-1, 0, 0, math_func_min, NULL, NULL, NULL, NULL}}, {"MAX", {-1, 0, 0, math_func_max, NULL, NULL, NULL, NULL}}, {"SQR", {1, 0, 0, math_func_sqr, NULL, NULL, NULL, NULL}}, {"EXP", {1, 0, 0, math_func_exp, NULL, NULL, NULL, NULL}}, {"LOG", {1, 0, 0, math_func_log, NULL, NULL, NULL, NULL}}, {"SIN", {1, 0, 0, math_func_sin, NULL, NULL, NULL, NULL}}, {"COS", {1, 0, 0, math_func_cos, NULL, NULL, NULL, NULL}}, {"TAN", {1, 0, 0, math_func_tan, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"ERF", {1, 0, 0, math_func_erf, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"LGN", {3, 0, 0, math_func_lgn, NULL, NULL, NULL, NULL}}, {"MJD", {6, 0, 0, math_func_mjd, NULL, NULL, NULL, NULL}}, {"NEQ", {3, 0, 0, math_func_neq, NULL, NULL, NULL, NULL}}, {"NOT", {1, 0, 0, math_func_not, NULL, NULL, NULL, NULL}}, {"AND", {2, 0, 0, math_func_and, NULL, NULL, NULL, NULL}}, {"XOR", {2, 0, 0, math_func_xor, NULL, NULL, NULL, NULL}}, {"FOR", {5, 1, 0, math_func_for, NULL, NULL, NULL, NULL}}, {"DIF", {1, 1, 1, math_func_dif, NULL, NULL, NULL, NULL}}, {"SUM", {1, 1, 1, math_func_sum, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"JNU", {2, 0, 0, math_func_jnu, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"YNU", {2, 0, 0, math_func_ynu, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"INU", {2, 0, 0, math_func_inu, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"KNU", {2, 0, 0, math_func_knu, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"POP", {1, 0, 0, math_func_pop, NULL, NULL, NULL, NULL}}, {"LN", {1, 0, 0, math_func_ln, NULL, NULL, NULL, NULL}}, {"EI", {1, 0, 0, math_func_ei, NULL, NULL, NULL, NULL}}, {"JN", {2, 0, 0, math_func_jn, NULL, NULL, NULL, NULL}}, {"YN", {2, 0, 0, math_func_yn, NULL, NULL, NULL, NULL}}, {"PN", {2, 0, 0, math_func_pn, NULL, NULL, NULL, NULL}}, {"HN", {2, 0, 0, math_func_hn, NULL, NULL, NULL, NULL}}, {"TN", {2, 0, 0, math_func_tn, NULL, NULL, NULL, NULL}}, {"EQ", {3, 0, 0, math_func_eq, NULL, NULL, NULL, NULL}}, {"GE", {3, 0, 0, math_func_ge, NULL, NULL, NULL, NULL}}, {"GT", {3, 0, 0, math_func_gt, NULL, NULL, NULL, NULL}}, {"LE", {3, 0, 0, math_func_le, NULL, NULL, NULL, NULL}}, {"LT", {3, 0, 0, math_func_lt, NULL, NULL, NULL, NULL}}, {"OR", {2, 0, 0, math_func_or, NULL, NULL, NULL, NULL}}, {"RM", {1, 1, 0, math_func_rm, NULL, NULL, NULL, NULL}}, {"CM", {2, 1, 0, math_func_cm, NULL, NULL, NULL, NULL}}, {"AM", {1, 1, 0, math_func_am, NULL, NULL, NULL, NULL}}, {"IF", {3, 0, 0, math_func_if, NULL, NULL, NULL, NULL}}, #ifdef HAVE_LIBGSL {"IN", {2, 0, 0, math_func_in, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"KN", {2, 0, 0, math_func_kn, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"YL", {2, 0, 0, math_func_yl, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif #ifdef HAVE_LIBGSL {"JL", {2, 0, 0, math_func_jl, NULL, NULL, NULL, NULL}}, #else {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}}, #endif {"M", {2, 1, 0, math_func_m, NULL, NULL, NULL, NULL}}, }; int math_add_basic_function(MathEquation *eq) { unsigned int i; enum MATH_FUNCTION_ARG_TYPE *ptr; for (i = 0; i < sizeof(FuncAry) / sizeof(*FuncAry); i++) { if (FuncAry[i].name == NULL) { continue; } switch (i) { case 0: /* ARRAY_AVERAGE */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 1: /* ARRAY_COMPACT */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 2: /* ARRAY_STDEVP */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 3: /* ARRAY_CLEAR */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 4: /* ARRAY_SUMSQ */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 5: /* ARRAY_STDEV */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 8: /* ARRAY_SUM */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 9: /* ARRAY_MIN */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 10: /* ARRAY_MAX */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 21: /* UNSHIFT */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 2); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; ptr[1] = MATH_FUNCTION_ARG_TYPE_DOUBLE; FuncAry[i].prm.arg_type = ptr; break; case 23: /* UNLESS */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 3); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[1] = MATH_FUNCTION_ARG_TYPE_PROC; ptr[2] = MATH_FUNCTION_ARG_TYPE_PROC; FuncAry[i].prm.arg_type = ptr; break; case 37: /* RSORT */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 38: /* ARRAY */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 43: /* SHIFT */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 58: /* SORT */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 59: /* SIZE */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 61: /* PUSH */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 2); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; ptr[1] = MATH_FUNCTION_ARG_TYPE_DOUBLE; FuncAry[i].prm.arg_type = ptr; break; case 81: /* FOR */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 5); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[1] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[2] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[3] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[4] = MATH_FUNCTION_ARG_TYPE_PROC; FuncAry[i].prm.arg_type = ptr; break; case 88: /* POP */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 104: /* AM */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 1); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_ARRAY; FuncAry[i].prm.arg_type = ptr; break; case 105: /* IF */ if (FuncAry[i].prm.arg_type) { break; } ptr = g_malloc(sizeof(enum MATH_FUNCTION_ARG_TYPE) * 3); if (ptr == NULL) { return 1; } ptr[0] = MATH_FUNCTION_ARG_TYPE_DOUBLE; ptr[1] = MATH_FUNCTION_ARG_TYPE_PROC; ptr[2] = MATH_FUNCTION_ARG_TYPE_PROC; FuncAry[i].prm.arg_type = ptr; break; } if (math_equation_add_func(eq, FuncAry[i].name, &FuncAry[i].prm) == NULL) return 1; } return 0; } ngraph-gtk-6.08.00/src/math/math_function.rb0000644000175000017500000000644413070106167015564 00000000000000#! /usr/bin/ruby func_str = []; IO.foreach(ARGV[0]) { |l| next if (l[0] == ?#) l.chomp! next if (l.length < 1) func_str.push(l.split) } func_str = func_str.uniq.sort {|a, b| b[0].length - a[0].length} File.open("#{ARGV[1]}.h", "w") { |f| f.puts < #include #include #include "math_expression.h" #include "math_equation.h" #include "math_function.h" struct funcs { char *name; struct math_function_parameter prm; }; static struct funcs FuncAry[] = { EOF func = [] i = 0; func_str.each {|s| if (s.length == 5) f.puts(" {\"#{s[0].upcase}\", {#{s[1]}, #{s[2]}, #{s[3]}, math_func_#{s[0]}, NULL, NULL, NULL, NULL}},") if (s[4] != "NULL") func.push([i, s[4].split(","), s[0].upcase]) end i += 1 elsif (s.length == 6) f.puts("#ifdef HAVE_LIBGSL") f.puts(" {\"#{s[0].upcase}\", {#{s[1]}, #{s[2]}, #{s[3]}, math_func_#{s[0]}, NULL, NULL, NULL, NULL}},") if (s[4] != "NULL") func.push([i, s[4].split(","), s[0].upcase]) end f.puts("#else") f.puts(" {NULL, {0, 0, 0, NULL, NULL, NULL, NULL, NULL}},") f.puts("#endif") i += 1 end } f.puts("};\n\n") f.puts < #include "math_operator.h" struct ope_str { char *ope; int len; enum #{OPE_PREFIX} type; }; static struct ope_str OpeStr[] = { EOF ope_str.each {|s| f.puts(" {\"#{s[0].gsub('\\', '\\\\\\')}\", #{s[0].length}, #{OPE_PREFIX}_#{s[1]}},") } f.puts("};\n\n") f.puts("static char OpeChar[#{N}] = {") N.times {|i| c = sprintf("%c", i) f.puts(ope.include?(c) ? " 1, /* #{i.chr} */" : " 0,") } f.puts("};") f.puts < (int) (sizeof(OpeChar) / sizeof(*OpeChar))) return 0; return OpeChar[chr]; } enum #{OPE_PREFIX} math_scanner_check_ope_str(const char *str, int *len) { unsigned int i; for (i = 0; i < sizeof(OpeStr) / sizeof(*OpeStr); i++) { if (strncmp(str, OpeStr[i].ope, OpeStr[i].len) == 0) { *len = OpeStr[i].len; return OpeStr[i].type; } } return #{OPE_PREFIX}_UNKNOWN; } EOF } ngraph-gtk-6.08.00/src/math/math_operator.h0000644000175000017500000000157113241744617015422 00000000000000#ifndef MATH_SCANNER_OPE_HEADER #define MATH_SCANNER_OPE_HEADER enum MATH_OPERATOR_TYPE { MATH_OPERATOR_TYPE_AND, MATH_OPERATOR_TYPE_ASSIGN, MATH_OPERATOR_TYPE_DIV, MATH_OPERATOR_TYPE_DIV_ASSIGN, MATH_OPERATOR_TYPE_EOEQ, MATH_OPERATOR_TYPE_EQ, MATH_OPERATOR_TYPE_FACT, MATH_OPERATOR_TYPE_GE, MATH_OPERATOR_TYPE_GT, MATH_OPERATOR_TYPE_LE, MATH_OPERATOR_TYPE_LT, MATH_OPERATOR_TYPE_MINUS, MATH_OPERATOR_TYPE_MINUS_ASSIGN, MATH_OPERATOR_TYPE_MOD, MATH_OPERATOR_TYPE_MOD_ASSIGN, MATH_OPERATOR_TYPE_MUL, MATH_OPERATOR_TYPE_MUL_ASSIGN, MATH_OPERATOR_TYPE_NE, MATH_OPERATOR_TYPE_OR, MATH_OPERATOR_TYPE_PLUS, MATH_OPERATOR_TYPE_PLUS_ASSIGN, MATH_OPERATOR_TYPE_POW, MATH_OPERATOR_TYPE_POW_ASSIGN, MATH_OPERATOR_TYPE_UNKNOWN }; int math_scanner_is_ope(int chr); enum MATH_OPERATOR_TYPE math_scanner_check_ope_str(const char *str, int *len); #endif ngraph-gtk-6.08.00/src/math/math_constant.h0000644000175000017500000000077413241744617015424 00000000000000#ifndef MATH_SCANNER_CONST_HEADER #define MATH_SCANNER_CONST_HEADER #include "math_expression.h" #include "math_equation.h" enum MATH_SCANNER_VAL_TYPE { MATH_SCANNER_VAL_TYPE_NORMAL, MATH_SCANNER_VAL_TYPE_UNKNOWN }; struct math_const_parameter { char *str; enum MATH_SCANNER_VAL_TYPE type; MathValue val; }; int math_scanner_is_const(int chr); enum MATH_SCANNER_VAL_TYPE math_scanner_check_math_const_parameter(char *str, MathValue *val); int math_add_basic_constant(MathEquation *eq); #endif ngraph-gtk-6.08.00/src/math/math_parser.c0000644000175000017500000006465513352667211015067 00000000000000/* * $Id: math_parser.c,v 1.19 2010-03-04 08:30:17 hito Exp $ * */ #include "config.h" #include #include #include #include #include #include "object.h" #include "math_equation.h" #include "math_scanner.h" #include "math_function.h" #include "parse_bin_expression.h" #define MATH_ARG_NUM 16 #define DEBUG 1 MathValue MATH_VALUE_ZERO = {0.0, MATH_VALUE_NORMAL}; static struct math_token *st_look_ahead_token = NULL; static MathExpression * parse_expression(struct math_string *mstr, MathEquation *eq, int *err); static MathExpression * parse_expression_list(struct math_string *mstr, MathEquation *eq, int inside_block, int *err); static MathExpression * parse_unary_expression(struct math_string *mstr, MathEquation *eq, int *err); static struct math_token * my_get_token(struct math_string *str) { struct math_token *token; if (st_look_ahead_token) { token = st_look_ahead_token; st_look_ahead_token = token->next; token->next = NULL; } else { token = math_scanner_get_token(str); } return token; } static void unget_token(struct math_token *token) { token->next = st_look_ahead_token; st_look_ahead_token = token; } static MathExpression * parse_array_expression(struct math_string *str, MathEquation *eq, const char *name, int *err) { struct math_token *token; MathExpression *operand, *exp; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return NULL; } math_scanner_free_token(token); operand = parse_expression(str, eq, err); if (operand == NULL) return NULL; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(operand); return NULL; } if (token->type != MATH_TOKEN_TYPE_RB) { *err = MATH_ERROR_MISS_RB; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(operand); return NULL; } math_scanner_free_token(token); exp = math_array_expression_new(eq, name, operand, err); if (exp == NULL) { math_expression_free(operand); return NULL; } return exp; } static MathExpression * parse_primary_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token, *token2; MathExpression *exp; MathValue val; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_NUMERIC: val.val = token->data.val.dnum; val.type = MATH_VALUE_NORMAL; exp = math_double_expression_new(eq, &val, err); break; case MATH_TOKEN_TYPE_SYMBOL: token2 = my_get_token(str); unget_token(token2); if (token2->type == MATH_TOKEN_TYPE_LB) { exp = parse_array_expression(str, eq, token->data.sym, err); if (exp == NULL) { math_scanner_free_token(token); return NULL; } } else { exp = math_constant_expression_new(eq, token->data.sym, err); if (exp == NULL) { if (token->data.sym[0] == '%') { exp = math_parameter_expression_new(eq, token->data.sym, err); if (exp == NULL) { math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); return NULL; } #if 0 /* length of a variable expression is less than 3 other than start with "_". */ } else if (token->data.sym[0] == '_' || strlen(token->data.sym) < 3) { exp = math_variable_expression_new(eq, token->data.sym, err); } else { *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); return NULL; #else /* length of a variable expression is not fixed. */ } else { exp = math_variable_expression_new(eq, token->data.sym, err); #endif } } } break; case MATH_TOKEN_TYPE_LP: math_scanner_free_token(token); exp = parse_expression(str, eq, err); if (exp == NULL) return NULL; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } if (token->type != MATH_TOKEN_TYPE_RP) { *err = MATH_ERROR_MISS_RP; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(exp); return NULL; } break; case MATH_TOKEN_TYPE_EOEQ: *err = MATH_ERROR_EOEQ; math_scanner_free_token(token); return NULL; default: *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); return exp; } static void free_arg_list(MathExpression **argv) { int i; for (i = 0; argv[i]; i++) { math_expression_free(argv[i]); } } static MathExpression * get_argument(struct math_string *str, MathEquation *eq, struct math_function_parameter *fprm, int i, int *err) { struct math_token *token; MathExpression *exp; int argc; argc = math_function_get_arg_type_num(fprm); if (fprm->arg_type && i < argc && fprm->arg_type[i] == MATH_FUNCTION_ARG_TYPE_ARRAY) { token = my_get_token(str); if (token->type != MATH_TOKEN_TYPE_SYMBOL) { *err = MATH_ERROR_INVALID_FDEF; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); /* invalid argument */ return NULL; } exp = math_array_argument_expression_new(eq, token->data.sym, err); math_scanner_free_token(token); } else { exp = parse_expression(str, eq, err); } return exp; } static int parse_argument_list(struct math_string *str, MathEquation *eq, struct math_function_parameter *fprm, MathExpression ***buf, int argc, int *err) { struct math_token *token; int i, n; MathExpression *exp, **tmp, **argv; argv = *buf; token = my_get_token(str); unget_token(token); if (token->type == MATH_TOKEN_TYPE_RP) { return 0; } n = 0; exp = get_argument(str, eq, fprm, n, err); if (exp == NULL) { return -1; } argv[0] = exp; argv[1] = NULL; for (i = 1; ; i++) { token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; free_arg_list(argv); return -1; } if (token->type != MATH_TOKEN_TYPE_COMMA) { unget_token(token); break; } math_scanner_free_token(token); n++; exp = get_argument(str, eq, fprm, n, err); if (exp == NULL) { free_arg_list(argv); return -1; } if (i >= argc) { int m; m = argc * 2 + 1; tmp = g_realloc(argv, m * sizeof(*argv)); if (tmp == NULL) { math_expression_free(exp); free_arg_list(argv); return -1; } argv = tmp; *buf = tmp; memset(argv + argc, 0, m - argc); argc = m - 1; } argv[i] = exp; argv[i + 1] = NULL; } *buf = argv; return i; } static MathExpression * create_math_func(struct math_string *str, MathEquation *eq, struct math_token *name, int *err) { struct math_function_parameter *fprm; int i, arg_max, argc, pos_id; MathExpression **argv, *exp; struct math_token *token; fprm = math_equation_get_func(eq, name->data.sym); if (fprm == NULL) { *err = MATH_ERROR_UNKNOWN_FUNC; math_equation_set_parse_error(eq, name->ptr, str); return NULL; } arg_max = (fprm->argc < 0) ? MATH_ARG_NUM : fprm->argc; argv = g_malloc0((arg_max + 1) * sizeof(*argv)); if (argv == NULL) { *err = MATH_ERROR_MEMORY; return NULL; } argc = parse_argument_list(str, eq, fprm, &argv, arg_max, err); if (argc < 0) { g_free(argv); return NULL; } token = my_get_token(str); if (token->type != MATH_TOKEN_TYPE_RP) { *err = MATH_ERROR_MISS_RP; math_equation_set_parse_error(eq, token->ptr, str); free_arg_list(argv); g_free(argv); math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); if (argc < fprm->argc) { for (i = argc; i < fprm->argc; i++) { argv[i] = math_double_expression_new(eq, &MATH_VALUE_ZERO, err); if (argv[i] == NULL) { free_arg_list(argv); g_free(argv); return NULL; } } argc = fprm->argc; } else if (fprm->argc >= 0 && argc > fprm->argc) { *err = MATH_ERROR_ARG_NUM; math_equation_set_func_arg_num_error(eq, fprm, argc); free_arg_list(argv); g_free(argv); return NULL; } pos_id = math_equation_add_pos_func(eq, fprm); if (pos_id == MATH_ERROR_INVALID_FUNC) { *err = MATH_ERROR_INVALID_FUNC; math_equation_set_func_error(eq, fprm); free_arg_list(argv); g_free(argv); return NULL; } exp = math_func_call_expression_new(eq, fprm, argc, argv, pos_id, err); if (exp == NULL) { free_arg_list(argv); g_free(argv); return NULL; } return exp; } static MathExpression * parse_func_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token1, *token2; MathExpression *exp; token1 = my_get_token(str); if (token1 == NULL) { return NULL; } switch (token1->type) { case MATH_TOKEN_TYPE_SYMBOL: token2 = my_get_token(str); if (token2 == NULL) { math_scanner_free_token(token1); return NULL; } switch (token2->type) { case MATH_TOKEN_TYPE_LP: exp = create_math_func(str, eq, token1, err); math_scanner_free_token(token2); math_scanner_free_token(token1); break; default: unget_token(token2); unget_token(token1); exp = parse_primary_expression(str, eq, err); } break; default: unget_token(token1); exp = parse_primary_expression(str, eq, err); } return exp; } static MathExpression * parse_factorial_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token; MathExpression *operand, *exp; exp = parse_func_expression(str, eq, err); if (exp == NULL) { return NULL; } for (;;) { token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_OPERATOR: switch (token->data.op) { case MATH_OPERATOR_TYPE_FACT: math_scanner_free_token(token); operand = exp; exp = math_unary_expression_new(MATH_EXPRESSION_TYPE_FACT, eq, operand, err); if (exp == NULL) { return NULL; } break; default: unget_token(token); goto End; } break; default: unget_token(token); goto End; } } End: return exp; } static MathExpression * parse_power_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token; MathExpression *left, *right, *exp; exp = parse_factorial_expression(str, eq, err); if (exp == NULL) { return NULL; } token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_OPERATOR: switch (token->data.op) { case MATH_OPERATOR_TYPE_POW: right = parse_unary_expression(str, eq, err); if (right == NULL) { math_scanner_free_token(token); return NULL; } left = exp; exp = math_binary_expression_new(MATH_EXPRESSION_TYPE_POW, eq, left, right, err); if (exp == NULL) { math_expression_free(left); math_expression_free(right); math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); break; default: unget_token(token); goto End; } break; default: unget_token(token); goto End; } End: return exp; } static MathExpression * parse_unary_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token; MathExpression *exp, *operand; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_OPERATOR: switch (token->data.op) { case MATH_OPERATOR_TYPE_PLUS: exp = parse_unary_expression(str, eq, err); break; case MATH_OPERATOR_TYPE_MINUS: operand = parse_unary_expression(str, eq, err); if (operand == NULL) { math_scanner_free_token(token); return NULL; } exp = math_unary_expression_new(MATH_EXPRESSION_TYPE_MINUS, eq, operand, err); if (exp == NULL) { math_scanner_free_token(token); math_expression_free(operand); return NULL; } break; default: *err = MATH_ERROR_UNEXP_OPE; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); break; default: unget_token(token); exp = parse_power_expression(str, eq, err); } return exp; } static MathExpression * CREATE_PARSER3_FUNC(multiplicative, unary, MATH_OPERATOR_TYPE_MUL, MATH_EXPRESSION_TYPE_MUL, MATH_OPERATOR_TYPE_DIV, MATH_EXPRESSION_TYPE_DIV, MATH_OPERATOR_TYPE_MOD, MATH_EXPRESSION_TYPE_MOD); static MathExpression * CREATE_PARSER2_FUNC(additive, multiplicative, MATH_OPERATOR_TYPE_PLUS, MATH_EXPRESSION_TYPE_ADD, MATH_OPERATOR_TYPE_MINUS, MATH_EXPRESSION_TYPE_SUB); static MathExpression * CREATE_PARSER4_FUNC(relation, additive, MATH_OPERATOR_TYPE_GT, MATH_EXPRESSION_TYPE_GT, MATH_OPERATOR_TYPE_GE, MATH_EXPRESSION_TYPE_GE, MATH_OPERATOR_TYPE_LE, MATH_EXPRESSION_TYPE_LE, MATH_OPERATOR_TYPE_LT, MATH_EXPRESSION_TYPE_LT); static MathExpression * CREATE_PARSER2_FUNC(equality, relation, MATH_OPERATOR_TYPE_EQ, MATH_EXPRESSION_TYPE_EQ, MATH_OPERATOR_TYPE_NE, MATH_EXPRESSION_TYPE_NE); static MathExpression * CREATE_PARSER_FUNC(and, equality, MATH_OPERATOR_TYPE_AND, MATH_EXPRESSION_TYPE_AND); static MathExpression * CREATE_PARSER_FUNC(or, and, MATH_OPERATOR_TYPE_OR, MATH_EXPRESSION_TYPE_OR); static MathExpression * create_variable_assign_expression(MathEquation *eq, enum MATH_OPERATOR_TYPE op, MathExpression *lexp, MathExpression *rexp, int *err) { MathExpression *exp, *bin; bin = NULL; switch (op) { case MATH_OPERATOR_TYPE_ASSIGN: break; case MATH_OPERATOR_TYPE_POW_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_POW, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; case MATH_OPERATOR_TYPE_MOD_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_MOD, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; case MATH_OPERATOR_TYPE_DIV_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_DIV, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; case MATH_OPERATOR_TYPE_MUL_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_MUL, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; case MATH_OPERATOR_TYPE_PLUS_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_ADD, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; case MATH_OPERATOR_TYPE_MINUS_ASSIGN: bin = math_binary_expression_new(MATH_EXPRESSION_TYPE_SUB, eq, lexp, rexp, err); if (bin == NULL) goto ErrEnd; rexp = bin; break; default: return NULL; } exp = math_expression_new(MATH_EXPRESSION_TYPE_VARIABLE, eq, err); if (exp == NULL) { math_expression_free(bin); return NULL; } exp->u.index = lexp->u.index; lexp = math_assign_expression_new(MATH_EXPRESSION_TYPE_ASSIGN, eq, exp, rexp, op, err); if (lexp == NULL) { math_expression_free(exp); math_expression_free(bin); } return lexp; ErrEnd: math_expression_free(lexp); math_expression_free(rexp); return NULL; } static MathExpression * parse_assign_expression(struct math_string *str, MathEquation *eq, enum MATH_OPERATOR_TYPE op, MathExpression *lexp, int *err) { MathExpression *exp, *rexp; rexp = parse_expression(str, eq, err); if (rexp == NULL) { math_expression_free(lexp); return NULL; } if (lexp->type == MATH_EXPRESSION_TYPE_VARIABLE && op != MATH_OPERATOR_TYPE_ASSIGN) { exp = create_variable_assign_expression(eq, op, lexp, rexp, err); } else { exp = math_assign_expression_new(MATH_EXPRESSION_TYPE_ASSIGN, eq, lexp, rexp, op, err); if (exp == NULL) { math_expression_free(lexp); math_expression_free(rexp); } } return exp; } static int parse_parameter_list(struct math_string *str, MathEquation *eq, MathExpression *func, int *err) { struct math_token *token; enum MATH_FUNCTION_ARG_TYPE type; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return 1; } if (token->type != MATH_TOKEN_TYPE_LP) { math_scanner_free_token(token); return 1; } math_scanner_free_token(token); token = my_get_token(str); if (token->type == MATH_TOKEN_TYPE_RP) { return 0; } unget_token(token); for (;;) { token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return 1; } if (token->type == MATH_TOKEN_TYPE_ARRAY_PREFIX) { type = MATH_FUNCTION_ARG_TYPE_ARRAY; math_scanner_free_token(token); token = my_get_token(str); } else { type = MATH_FUNCTION_ARG_TYPE_DOUBLE; } if (token->type != MATH_TOKEN_TYPE_SYMBOL) { math_scanner_free_token(token); return 1; } if (math_function_expression_add_arg(func, token->data.sym, type)) { math_scanner_free_token(token); return 1; } math_scanner_free_token(token); token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return 1; } if (token->type != MATH_TOKEN_TYPE_COMMA) { unget_token(token); break; } math_scanner_free_token(token); } token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; return 1; } if (token->type != MATH_TOKEN_TYPE_RP) { math_scanner_free_token(token); return 1; } math_scanner_free_token(token); return 0; } static MathExpression * parse_block_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token; MathExpression *exp; token = my_get_token(str); if (token == NULL) { return NULL; } if (token->type != MATH_TOKEN_TYPE_LC) { math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); token = my_get_token(str); if (token->type == MATH_TOKEN_TYPE_RC) { math_scanner_free_token(token); return NULL; } unget_token(token); exp = parse_expression_list(str, eq, 1, err); if (exp == NULL) return NULL; token = my_get_token(str); if (token->type != MATH_TOKEN_TYPE_RC) { math_scanner_free_token(token); return NULL; } math_scanner_free_token(token); return exp; } static void free_func_prm(struct math_function_parameter *prm) { if (prm == NULL) return; if (prm->arg_type) { g_free(prm->arg_type); } if (prm->opt_usr) { math_expression_free(prm->opt_usr); } if (prm->name) { g_free(prm->name); } g_free(prm); } MathExpression * parse_func_def_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *fname; MathExpression *exp, *block; /* get name of the function */ fname = my_get_token(str); if (fname == NULL) { return NULL; } if (fname->type != MATH_TOKEN_TYPE_SYMBOL) { math_scanner_free_token(fname); return NULL; } exp = math_function_expression_new(eq, fname->data.sym, err); if (exp == NULL) { math_scanner_free_token(fname); return NULL; } /* get parameters */ if (parse_parameter_list(str, eq, exp, err)) { math_equation_finish_user_func_definition(eq, NULL, NULL); free_func_prm(exp->u.func.fprm); math_scanner_free_token(fname); math_expression_free(exp); return NULL; } if (math_function_expression_register_arg(exp)) { math_equation_finish_user_func_definition(eq, NULL, NULL); free_func_prm(exp->u.func.fprm); math_scanner_free_token(fname); math_expression_free(exp); } /* get block */ block = parse_block_expression(str, eq, err); if (block == NULL) { math_equation_finish_user_func_definition(eq, NULL, NULL); free_func_prm(exp->u.func.fprm); math_scanner_free_token(fname); math_expression_free(exp); return NULL; } if (math_function_expression_set_function(eq, exp, fname->data.sym, block)) { math_equation_finish_user_func_definition(eq, NULL, NULL); free_func_prm(exp->u.func.fprm); math_scanner_free_token(fname); math_expression_free(exp); return NULL; } math_scanner_free_token(fname); return exp; } MathExpression * parse_const_def_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *cname, *token; MathExpression *exp, *cdef; if (eq->func_def) { *err = MATH_ERROR_INVALID_CDEF; return NULL; } /* get name of the constant */ cname = my_get_token(str); if (cname == NULL) { return NULL; } if (cname->type != MATH_TOKEN_TYPE_SYMBOL) { *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, cname->ptr, str); math_scanner_free_token(cname); return NULL; } token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_scanner_free_token(cname); return NULL; } if (token->type != MATH_TOKEN_TYPE_OPERATOR || token->data.op != MATH_OPERATOR_TYPE_ASSIGN) { if (token->type == MATH_TOKEN_TYPE_EOEQ) { *err = MATH_ERROR_EOEQ; } else { *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); } math_scanner_free_token(token); math_scanner_free_token(cname); return NULL; } math_scanner_free_token(token); eq->func_def = TRUE; exp = parse_expression(str, eq, err); eq->func_def = FALSE; if (exp == NULL) { math_scanner_free_token(cname); return NULL; } cdef = math_constant_definition_expression_new(eq, cname->data.sym, exp, err); math_scanner_free_token(cname); if (cdef == NULL) { math_expression_free(exp); return NULL; } return cdef; } static MathExpression * parse_expression(struct math_string *str, MathEquation *eq, int *err) { struct math_token *token; MathExpression *exp; exp = parse_or_expression(str, eq, err); if (exp == NULL) return NULL; switch (exp->type) { case MATH_EXPRESSION_TYPE_VARIABLE: case MATH_EXPRESSION_TYPE_ARRAY: break; default: goto End; } token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_OPERATOR: switch (token->data.op) { case MATH_OPERATOR_TYPE_ASSIGN: case MATH_OPERATOR_TYPE_POW_ASSIGN: case MATH_OPERATOR_TYPE_MOD_ASSIGN: case MATH_OPERATOR_TYPE_DIV_ASSIGN: case MATH_OPERATOR_TYPE_MUL_ASSIGN: case MATH_OPERATOR_TYPE_PLUS_ASSIGN: case MATH_OPERATOR_TYPE_MINUS_ASSIGN: exp = parse_assign_expression(str, eq, token->data.op, exp, err); math_scanner_free_token(token); break; default: *err = MATH_ERROR_UNEXP_OPE; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(exp); return NULL; } break; case MATH_TOKEN_TYPE_RC: case MATH_TOKEN_TYPE_RP: case MATH_TOKEN_TYPE_RB: case MATH_TOKEN_TYPE_EOEQ: case MATH_TOKEN_TYPE_COMMA: unget_token(token); break; default: *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(exp); return NULL; break; } End: return exp; } static MathExpression * parse_expression_list(struct math_string *str, MathEquation *eq, int inside_block, int *err) { struct math_token *token; MathExpression *exp, *prev, *top; top = prev = NULL; for (;;) { token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(top); return NULL; } switch (token->type) { case MATH_TOKEN_TYPE_DEF: if (inside_block) { *err = MATH_ERROR_FDEF_NEST; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(top); return NULL; } math_scanner_free_token(token); exp = parse_func_def_expression(str, eq, err); if (exp == NULL) { math_expression_free(top); return NULL; } continue; case MATH_TOKEN_TYPE_CONST: if (inside_block) { *err = MATH_ERROR_INVALID_CDEF; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(top); return NULL; } math_scanner_free_token(token); exp = parse_const_def_expression(str, eq, err); if (exp == NULL) { math_expression_free(top); return NULL; } continue; case MATH_TOKEN_TYPE_EOEQ: if (str->cur[0] == '\0') { if (inside_block) { *err = MATH_ERROR_MISS_RC; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(top); return NULL; } math_scanner_free_token(token); goto End; } math_scanner_free_token(token); continue; case MATH_TOKEN_TYPE_RC: if (inside_block) { unget_token(token); goto End; } *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(top); return NULL; default: unget_token(token); exp = parse_expression(str, eq, err); } if (exp == NULL) { math_expression_free(top); return NULL; } if (prev) { prev->next = exp; } if (top == NULL) { top = exp; } prev = exp; token = my_get_token(str); if (token == NULL) { *err = MATH_ERROR_MEMORY; math_expression_free(top); return NULL; } if (token->type != MATH_TOKEN_TYPE_EOEQ) { if (token->type == MATH_TOKEN_TYPE_RC && inside_block) { unget_token(token); goto End; } *err = MATH_ERROR_UNEXP_TOKEN; math_equation_set_parse_error(eq, token->ptr, str); math_scanner_free_token(token); math_expression_free(top); return NULL; } unget_token(token); } End: return top; } MathExpression * math_parser_parse(const char *line, MathEquation *eq, int *err) { struct math_token *token, *tmp; MathExpression *exp; struct math_string str; *err = MATH_ERROR_NONE; math_scanner_init_string(&str, line); st_look_ahead_token = NULL; exp = parse_expression_list(&str, eq, 0, err); token = st_look_ahead_token; while (token) { tmp = token->next; math_scanner_free_token(token); token = tmp; } st_look_ahead_token = NULL; return exp; } ngraph-gtk-6.08.00/src/math/math_scanner.c0000644000175000017500000002473713352667211015221 00000000000000/* * $Id: math_scanner.c,v 1.5 2009-11-16 09:13:06 hito Exp $ * */ #include "config.h" #include #include #include #include #include #include #include "object.h" #include "math_scanner.h" static struct math_token *create_token(const char *str, enum MATH_TOKEN_TYPE type); static struct math_token *get_array_prefix(const char *str, const char ** rstr); static struct math_token *get_bracket(const char *str, const char ** rstr); static struct math_token *get_unknown(const char *str, const char ** rstr); static struct math_token *get_symbol(const char *str, const char ** rstr); static struct math_token *get_paren(const char *str, const char ** rstr); static struct math_token *get_curly(const char *str, const char ** rstr); static struct math_token *get_comma(const char *str, const char ** rstr); static struct math_token *get_eoeq(const char *str, const char ** rstr); static struct math_token *get_ope(const char *str, const char ** rstr); static struct math_token *get_num(const char *str, const char ** rstr); struct reserved { char *name; enum MATH_TOKEN_TYPE type; }; static struct reserved Reserved[] = { {"DEF", MATH_TOKEN_TYPE_DEF}, {"CONST", MATH_TOKEN_TYPE_CONST}, }; static enum MATH_TOKEN_TYPE check_reserved(char *str) { unsigned int i; for (i = 0; i < sizeof(Reserved) / sizeof(*Reserved); i++) { if (strcmp(Reserved[i].name, str) == 0) { return Reserved[i].type; } } return MATH_TOKEN_TYPE_UNKNOWN; } void math_scanner_free_token(struct math_token *token) { if (token == NULL) return; switch (token->type) { case MATH_TOKEN_TYPE_NUMERIC: case MATH_TOKEN_TYPE_OPERATOR: case MATH_TOKEN_TYPE_COMMA: case MATH_TOKEN_TYPE_EOEQ: case MATH_TOKEN_TYPE_LP: case MATH_TOKEN_TYPE_RP: case MATH_TOKEN_TYPE_LB: case MATH_TOKEN_TYPE_RB: case MATH_TOKEN_TYPE_LC: case MATH_TOKEN_TYPE_RC: case MATH_TOKEN_TYPE_DEF: case MATH_TOKEN_TYPE_CONST: case MATH_TOKEN_TYPE_ARRAY_PREFIX: case MATH_TOKEN_TYPE_UNKNOWN: break; case MATH_TOKEN_TYPE_SYMBOL: g_free(token->data.sym); break; } g_free(token); } struct math_token * math_scanner_get_token(struct math_string *mstr) { char c; const char *str; const char **rstr; struct math_token *token; str = mstr->cur; rstr = &(mstr->cur); if (str == NULL) { return NULL; } while (*str < 0 || *str == ' ' || *str == '\t' || *str == '\n') { mstr->ofst++; if (*str == '\n') { mstr->line++; mstr->ofst = 0; } str++; } c = str[0]; if (c == '\0') { token = get_eoeq(str, rstr); } else if (isdigit(c) || c == '.') { token = get_num(str, rstr); } else if (math_scanner_is_ope(c)) { token = get_ope(str, rstr); } else if (isalpha(c) || c == '%' || c == '_') { token = get_symbol(str, rstr); } else if (c == '(' || c == ')') { token = get_paren(str, rstr); } else if (c == '[' || c == ']') { token = get_bracket(str, rstr); } else if (c == '{' || c == '}') { token = get_curly(str, rstr); } else if (c == ',') { token = get_comma(str, rstr); } else if (c == '@') { token = get_array_prefix(str, rstr); } else if (c == '#') { /* comment */ while (*str != '\0' && *str != '\n') { mstr->ofst++; if (*str == '\n') { mstr->line++; mstr->ofst = 0; } str++; } mstr->cur = str; token = math_scanner_get_token(mstr); } else { token = get_unknown(str, rstr); } mstr->ofst += (*rstr - str); return token; } static struct math_token * get_unknown(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, MATH_TOKEN_TYPE_UNKNOWN); if (tok == NULL) return NULL; return tok; } static struct math_token * get_paren(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, (str[0] == ')') ? MATH_TOKEN_TYPE_RP : MATH_TOKEN_TYPE_LP); if (tok == NULL) return NULL; *rstr = str + 1; return tok; } static struct math_token * get_bracket(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, (str[0] == ']') ? MATH_TOKEN_TYPE_RB : MATH_TOKEN_TYPE_LB); if (tok == NULL) return NULL; *rstr = str + 1; return tok; } static struct math_token * get_curly(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, (str[0] == '}') ? MATH_TOKEN_TYPE_RC : MATH_TOKEN_TYPE_LC); if (tok == NULL) return NULL; *rstr = str + 1; return tok; } static struct math_token * get_comma(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, MATH_TOKEN_TYPE_COMMA); if (tok == NULL) return NULL; *rstr = str + 1; return tok; } static struct math_token * get_array_prefix(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, MATH_TOKEN_TYPE_ARRAY_PREFIX); if (tok == NULL) return NULL; *rstr = str + 1; return tok; } static struct math_token * get_eoeq(const char *str, const char ** rstr) { struct math_token *tok; tok = create_token(str, MATH_TOKEN_TYPE_EOEQ); if (tok == NULL) return NULL; *rstr = str + ((*str) ? 1 : 0); return tok; } static struct math_token * get_ope(const char *str, const char ** rstr) { struct math_token *tok; int len; enum MATH_OPERATOR_TYPE ope; ope = math_scanner_check_ope_str(str, &len); switch (ope) { case MATH_OPERATOR_TYPE_EOEQ: tok = create_token(str, MATH_TOKEN_TYPE_EOEQ); break; case MATH_OPERATOR_TYPE_UNKNOWN: tok = create_token(str, MATH_TOKEN_TYPE_UNKNOWN); break; default: tok = create_token(str, MATH_TOKEN_TYPE_OPERATOR); if (tok) { tok->data.op = ope; } } *rstr = str + len; return tok; } static struct math_token * get_symbol(const char *str, const char ** rstr) { struct math_token *tok; char *buf; int n, i; enum MATH_TOKEN_TYPE type; for (n = (str[0] == '%') ? 1 : 0; isalnum(str[n]) || str[n] == '_'; n++); buf = g_malloc(n + 1); if (buf == NULL) return NULL; for (i = 0; i < n; i++) { buf[i] = toupper(str[i]); } buf[i] = '\0'; type = check_reserved(buf); if (type != MATH_TOKEN_TYPE_UNKNOWN) { g_free(buf); tok = create_token(str, type); if (tok == NULL) { g_free(buf); return NULL; } } else { tok = create_token(str, MATH_TOKEN_TYPE_SYMBOL); if (tok == NULL) { g_free(buf); return NULL; } tok->data.sym = buf; } *rstr = str + n; return tok; } static const char * get_oct(const char *str, double *val) { double oct; char c; oct = 0; for (; *str; str++) { c = *str; switch (c) { case ' ': case '_': case '\t': continue; case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': oct *= 8; oct += c - '0'; break; default: goto End; } } End: *val = oct; return str; } static const char * get_hex(const char *str, double *val) { double hex; char c; hex = 0; for (; *str; str++) { c = toupper(*str); switch (c) { case ' ': case '_': case '\t': continue; case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9': hex *= 16; hex += c - '0'; break; case 'A': case 'B': case 'C': case 'D': case 'E': case 'F': hex *= 16; hex += c - 'A' + 10; break; default: goto End; } } End: *val = hex; return str; } static const char * get_bin(const char *str, double *val) { double bin; char c; bin = 0; for (; *str; str++) { c = str[0]; switch (c) { case ' ': case '_': case '\t': continue; case '0': case '1': bin *= 2; bin += c - '0'; break; default: goto End; } } End: *val = bin; return str; } static const char * get_dec(const char *str, double *val) { int in_decimal, in_pow, pow_sign, pow_val, dec_order; long double dec, flaction; pow_val = 0; pow_sign = 1; dec_order = 0; flaction = 0; dec = 0; in_decimal = 0; in_pow = 0; for (; *str; str++) { char c; c = toupper(*str); if (c < 0) { break; } else if (c == ' ' || c == '\t' || c == '_') { continue; } else if (c == '.') { if (in_decimal || in_pow) { break; } in_decimal = 1; } else if (c == 'E' || c == 'D') { if (in_pow) { break; } in_pow = 1; } else if (c == '+' || c =='-') { if (in_pow != 1) { break; } pow_sign = (c == '+') ? 1 : -1; in_pow = 2; } else if (isdigit(c)) { switch (in_pow) { case 1: in_pow = 2; /* fall through */ case 2: if (pow_val < INT_MAX / 10) { pow_val *= 10; pow_val += c - '0'; } break; default: if (in_decimal) { if (flaction < 1E30) { /* dec and flaction is not negative */ dec_order++; flaction *= 10; flaction += c - '0'; } } else { dec *= 10; dec += c - '0'; } } } else { break; } } #if HAVE_POWL *val = dec * powl(10.0, pow_sign * pow_val) + flaction * powl(10.0, pow_sign * pow_val - dec_order); #else /* HAVE_POWL */ *val = dec * pow(10.0, pow_sign * pow_val) + flaction * pow(10.0, pow_sign * pow_val - dec_order); #endif /* HAVE_POWL */ return str; } static struct math_token * get_num(const char *str, const char ** rstr) { struct math_token *tok; const char *ptr; double val; tok = create_token(str, MATH_TOKEN_TYPE_NUMERIC); if (tok == NULL) { return NULL; } if (str[0] == '0' && str[1] == 'x') { str += 2; ptr = get_hex(str, &val); } else if (str[0] == '0' && str[1] == 'b') { str += 2; ptr = get_bin(str, &val); } else if (str[0] == '0' && str[1] == 'o') { str += 2; ptr = get_oct(str, &val); } else if (str[0] == '0' && (str[1] == '.' || str[1] == 'E' || str[1] == 'D')) { ptr = get_dec(str, &val); } else { ptr = get_dec(str, &val); } if (ptr == NULL) { tok->type = MATH_TOKEN_TYPE_UNKNOWN; return tok; } tok->data.val.dnum = val; tok->data.val.type = MATH_SCANNER_VAL_TYPE_NORMAL; *rstr = ptr; return tok; } static struct math_token * create_token(const char *str, enum MATH_TOKEN_TYPE type) { struct math_token *tok; tok = g_malloc0(sizeof(*tok)); if (tok == NULL) { return NULL; } tok->type = type; tok->ptr = str; return tok; } void math_scanner_init_string(struct math_string *str, const char *line) { str->top = line; str->cur = line; str->line = 0; str->ofst = 0; } ngraph-gtk-6.08.00/src/math/math_basic_function.c0000644000175000017500000016154413320010133016530 00000000000000/* * $Id: math_basic_function.c,v 1.14 2010-03-04 08:30:17 hito Exp $ * */ #include "config.h" #include #include #include #include #include #ifdef HAVE_LIBGSL #include #include #include #endif #include "ntime.h" #include "object.h" #include "math_equation.h" #include "math_function.h" #define MPI 3.14159265358979323846 #define MEXP1 2.71828182845905 #define MEULER 0.57721566490153286 #define MATH_CHECK_ARG(rval, v) if (v.val.type != MATH_VALUE_NORMAL) { \ *rval = v.val; \ return 0; \ } #define MATH_FUNCTION_MEMORY_NUM 65536 static MathValue *Memory = NULL; static int compare_double_with_prec(long double a, long double b, int prec); int math_func_time(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { rval->val = time(NULL); return 0; } int math_func_atanh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v > 1) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = atanh(v); return 0; } int math_func_asinh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = asinh(exp->buf[0].val.val); return 0; } int math_func_acosh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v < 1) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = acosh(v); return 0; } int math_func_gauss(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int val; MATH_CHECK_ARG(rval, exp->buf[0]); if (exp->buf[0].val.val >= 0) { val = (int) (exp->buf[0].val.val); } else if (exp->buf[0].val.val - (int) exp->buf[0].val.val == 0) { val = (int) exp->buf[0].val.val; } else { val = (int) exp->buf[0].val.val - 1; } rval->val = (double) val; return 0; } int math_func_round(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double val; MATH_CHECK_ARG(rval, exp->buf[0]); if (fabs(exp->buf[0].val.val - (int) exp->buf[0].val.val) >= 0.5) { if (exp->buf[0].val.val >= 0) { val = exp->buf[0].val.val - (exp->buf[0].val.val - (int) exp->buf[0].val.val) + 1; } else { val = exp->buf[0].val.val - (exp->buf[0].val.val - (int) exp->buf[0].val.val) - 1; } } else { val = exp->buf[0].val.val - (exp->buf[0].val.val - (int) exp->buf[0].val.val); } rval->val = val; return 0; } int math_func_tanh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = tanh(exp->buf[0].val.val); return 0; } int math_func_sign(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = (exp->buf[0].val.val < 0) ? -1 : 1; return 0; } int math_func_frac(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = exp->buf[0].val.val - (int) exp->buf[0].val.val; return 0; } int math_func_cosh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = cosh(exp->buf[0].val.val); return 0; } int math_func_sqrt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v < 0) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = sqrt(v); return 0; } int math_func_sinh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = sinh(exp->buf[0].val.val); return 0; } int math_func_atan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = atan(exp->buf[0].val.val); return 0; } int math_func_acos(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v < -1 || v > 1) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = acos(v); return 0; } int math_func_asin(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v < -1 || v > 1) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = asin(v); return 0; } int math_func_log(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v <= 0) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = log10(v); return 0; } int math_func_tan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = tan(exp->buf[0].val.val); return 0; } int math_func_sin(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = sin(exp->buf[0].val.val); return 0; } int math_func_cos(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = cos(exp->buf[0].val.val); return 0; } int math_func_abs(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = fabs(exp->buf[0].val.val); return 0; } int math_func_exp(MathFunctionCallExpression *expl, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, expl->buf[0]); rval->val = exp(expl->buf[0].val.val); return 0; } int math_func_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = (int) exp->buf[0].val.val; return 0; } int math_func_max(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double max; int i; if (exp->argc < 1) { rval->val = 0; return 0; } max = exp->buf[0].val.val; for (i = 1; i < exp->argc; i++) { MATH_CHECK_ARG(rval, exp->buf[i]); if (exp->buf[i].val.val > max) { max = exp->buf[i].val.val; } } rval->val = max; return 0; } int math_func_min(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double min; int i; if (exp->argc < 1) { rval->val = 0; return 0; } min = exp->buf[0].val.val; for (i = 1; i < exp->argc; i++) { MATH_CHECK_ARG(rval, exp->buf[i]); if (exp->buf[i].val.val < min) { min = exp->buf[i].val.val; } } rval->val = min; return 0; } int math_func_sumsq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double sum, val; int i; if (exp->argc < 1) { rval->val = 0; return 0; } sum = 0; for (i = 0; i < exp->argc; i++) { MATH_CHECK_ARG(rval, exp->buf[i]); val = exp->buf[i].val.val; sum += val * val; } rval->val = sum; return 0; } int math_func_progn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { if (exp->argc < 1) { rval->val = 0; } else { *rval = exp->buf[exp->argc - 1].val; } return 0; } int math_func_prog2(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { if (exp->argc < 2) { rval->val = 0; } else { *rval = exp->buf[1].val; } return 0; } int math_func_prog1(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { if (exp->argc < 1) { rval->val = 0; } else { *rval = exp->buf[0].val; } return 0; } int math_func_sqr(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = exp->buf[0].val.val * exp->buf[0].val.val; return 0; } int math_func_ln(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double v; MATH_CHECK_ARG(rval, exp->buf[0]); v = exp->buf[0].val.val; if (v <= 0) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = log(v); return 0; } int math_func_theta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = (exp->buf[0].val.val >= 0) ? 1 : 0; return 0; } int math_func_delta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = (exp->buf[0].val.val == 0) ? 1 : 0; return 0; } #ifndef HAVE_LIBGSL static int gamma2(double x, double *val) { double m, s, x1, xx; unsigned int i; static double gammacoe[] = { -0.42278433509846714, -0.23309373642178674, 0.19109110138769151, -0.24552490005400017E-1, -0.17645244550144320E-1, 0.80232730222673465E-2, -0.80432977560424699E-3, -0.3608378162548E-3, 0.1455961421399E-3, -0.175458597517E-4, -0.25889950224E-5, 0.13385015466E-5, -0.2054743152E-6, -0.1595268E-9, 0.62756218E-8, -0.12736143E-8, 0.923397E-10, 0.120028E-10, -0.42202E-11 }; if (((x <= 0) && ((x - (int) x) == 0)) || (x > 57)) return -1; m = 1; if (1.5 < x) while (1.5 < x) { x -= 1; m *= x; } else if (x < 0.5) while (x < 0.5) { if (x <= 1E-300) return -1; m /= x; x++; } s = 1; xx = 1; x1 = x - 1; for (i = 0; i < sizeof(gammacoe) / sizeof(*gammacoe); i++) { xx *= x1; s += xx * gammacoe[i]; } s *= x; if (s == 0) return -1; *val = m / s; return 0; } static int exp1(double x, double *val) { double x2, xx, xx2, qexp1, qexp2; int i, n; static double xo[18] = { 3.3, 4.0, 4.8, 5.8, 7.1, 8.6, 10.4, 12.5, 15.2, 18.4, 22.2, 26.9, 32.5, 39.4, 47.6, 57.6, 69.7, 83.0 }; static double eipt[18] = { 44.85377247567375, 35.95520078636207, 28.55548567959244, 22.28304130069319, 17.15083762120765, 13.52650411391756, 10.81282973538746, 8.781902021178544, 7.084719123528884, 5.769115302038587, 4.728746710237675, 3.867300609441438, 3.178040354772841, 2.606037129493851, 2.146957943513479, 1.767357146269297, 1.455922099180754, 1.219698244176420 }; static double eimt[18] = { 24.23610327385172, 20.63456499010558, 17.65538999222755, 14.96789725060241, 12.50401823871386, 10.51365383249826, 8.830924437781962, 7.443527518977505, 6.194083826443568, 5.167187241655524, 4.317774043309917, 3.588549395492134, 2.987594411636582, 2.476696474779806, 2.058451487317135, 1.706965828524471, 1.414702600059552, 1.190641095161813 }; x2 = fabs(x); if (x == 0 || x2 > 174) { return -1; } if (x2 >= 90) { n = 1; xx = 1; qexp2 = 1; do { xx *= n / x; n++; qexp1 = qexp2; qexp2 = qexp1 + xx; } while (qexp1 != qexp2); qexp1 /= x; if (x < 0) { qexp1 = -qexp1 * exp(-x2); } else { qexp1 *= exp(x2); } } else if (x2 >= 3) { i = 0; while ((i < 18) && (x2 >= 0.5 * (xo[i] + xo[i + 1]))) { i++; } if (x > 0) { xx = eipt[i] / 100; } else{ xx = eimt[i] / 100; } xx2 = 1 / (-xo[i]); qexp2 = xx; n = 1; do { qexp1 = qexp2; xx = (xo[i] - x2) / n * (xx + xx2); if (x < 0) { xx = -xx; } qexp2 = qexp1 + xx; xx2 *= (x2 - xo[i]) / (-xo[i]); n++; } while (qexp2 != qexp1); if (x < 0) { qexp1 = -qexp1 * exp(-x2); } else { qexp1 *= exp(x2); } } else { n = 1; xx = 1; qexp2 = 0; do { xx *= x / n; qexp1 = qexp2; qexp2 = qexp1 + xx / n; n++; } while (qexp1 != qexp2); qexp1 += MEULER + log(x2); } *val = qexp1; return 0; } #endif int math_func_icgam(MathFunctionCallExpression *expl, MathEquation *eq, MathValue *rval) { double mu, x; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else double a, u, p0, p1, q0, q1, val; int i, i2, i3; #endif MATH_CHECK_ARG(rval, expl->buf[0]); MATH_CHECK_ARG(rval, expl->buf[1]); mu = expl->buf[0].val.val; x = expl->buf[1].val.val; if (x < 0 || mu < 0) { rval->type = MATH_VALUE_ERROR; return -1; } #ifdef HAVE_LIBGSL r = gsl_sf_gamma_inc_e(mu, x, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else if (mu == 0) { if (exp1(-x, &val)) { rval->type = MATH_VALUE_ERROR; return -1; } else { val = -val; } } else if (x == 0) { if (gamma2(mu, &val)) { rval->type = MATH_VALUE_ERROR; return -1; } } else { i2 = 0; while (mu > 1) { i = 0; do { if (i == 56) { rval->type = MATH_VALUE_ERROR; return -1; } i++; mu--; } while (mu > 1); i2 = i; } u = exp(-x + mu * log(x)); if (x <= 1) { if (gamma2(mu, &p1)) { rval->type = MATH_VALUE_ERROR; return -1; } p0 = 1; q0 = 1; i = 0; do { i++; q0 *= x / (mu + i); p0 += q0; } while ((q0 > 1E-17) && (i != 20)); val = p1 - u / mu * p0; } else { i3 = (int) (120 / x + 5); p0 = 0; if (mu != 1) { p1 = 1E-78 / (1 - mu); } else { p1 = 1E-78; } q0 = p1; q1 = x * q0; for (i = 1; i <= i3; i++) { a = i - mu; p0 = p1 + a * p0; q0 = q1 + a * q0; p1 = x * p0 + i * p1; q1 = x * q0 + i * q1; if (i >= 50) { q0 /= i; p0 /= i; q1 /= i; p1 /= i; } } val = u / q1 * p1; } for (i = 1; i < i2; i++) { val = u + mu * val; u *= x; mu++; } } rval->val = val; return 0; #endif } int math_func_gamma(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #endif MATH_CHECK_ARG(rval, exp->buf[0]); #ifdef HAVE_LIBGSL r = gsl_sf_gamma_e (exp->buf[0].val.val, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else return gamma2(exp->buf[0].val.val, &rval->val); #endif } #ifdef HAVE_LIBGSL int math_func_erf(MathFunctionCallExpression *expl, MathEquation *eq, MathValue *rval) { double x; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, expl->buf[0]); x = expl->buf[0].val.val; r = gsl_sf_erf_e(x, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } #endif int math_func_erfc(MathFunctionCallExpression *expl, MathEquation *eq, MathValue *rval) { double x; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else int i, i2, sg; double x2, x3, sum, h, h2, val; #endif MATH_CHECK_ARG(rval, expl->buf[0]); x = expl->buf[0].val.val; #ifdef HAVE_LIBGSL r = gsl_sf_erfc_e(x, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else x2 = fabs(x); if (x2 <= 0.1) { sum = 0; sg = 1; x3 = x2; for (i = 0; i <= 5; i++) { if (i == 0) { i2 = 1; } else { i2 *= i; } sum += sg * x3 / i2 / (2 * i + 1); sg *= -1; x3 *= x2 * x2; } sum *= 2 / sqrt(MPI); val = 1 - sum; } else if (x2 <= 100) { h = 0.5; h2 = h * h; sum = 0; for (i = 1; i <= 13; i++) { i2 = i * i; sum += exp(-i2 * h2) / (i2 * h2 + x2 * x2); } if (x2 < 6) { sum += 0.5 / (x2 * x2); sum *= 2 * x2 / MPI * exp(-x2 * x2) * h; sum -= 2 / (exp(2 * MPI * x2 / h) - 1); } else { sum += 0.5 / (x2 * x2); sum *= 2 * x2 / MPI * exp(-x2 * x2) * h; } val = sum; } else { sum = 1; sg = -1; x3 = 2 * x2 * x2; i2 = 1; for (i = 1; i <= 5; i++) { i2 *= (2 * i - 1); sum += sg * i2 / x3; sg *= -1; x3 *= 2 * x2 * x2; } sum *= exp(-x2 * x2) / sqrt(MPI) / x2; val = sum; } if (x < 0) { val = 2 - (val); } rval->val = val; return 0; #endif } static double qinv3(double y) { double n, sum, y2, y3, i; sum = 0; y2 = y; y3 = y * y; i = 1; n = 0; do { i *= (2 * n + 1); sum += y2 / i; n = n + 1; y2 *= y3; } while (fabs(y2 / i) > 1e-16); return sum; } static double qinv2(double y) { int n, i; double a; if (y < 7.5) { n = (int) (110 / (y - 1)); } else if (y < 12.5) { n = (int) (-1.6 * y + 30); } else { n = 10; } a = 0; for (i = n; i > 0; i--) { a = i / (y + a); } return 1 / (y + a); } int math_func_qinv(MathFunctionCallExpression *expl, MathEquation *eq, MathValue *rval) { double x, x2, m2, c0, c1, y0, y1, val; MATH_CHECK_ARG(rval, expl->buf[0]); x = expl->buf[0].val.val; if (x <= 0 || x >= 1) { rval->type = MATH_VALUE_ERROR; return -1; } if (x > 0.5) { x2 = 1 - x; } else { x2 = x; } m2 = sqrt(2 * MPI); if (x2 <= 0.01) { c0 = sqrt(-2 * log(m2 * 3 * x2)); c1 = c0 + 1 / c0; y1 = sqrt(-2 * log(m2 * c1 * x2)); do { y0 = y1; y1 = y0 + (qinv2(y0) - m2 * x2 * exp(0.5 * y0 * y0)); } while (fabs(y0 - y1) >= 1e-14); } else if (x2 <= 0.5) { y1 = m2 * (0.5 - x2) * 1.5; do { y0 = y1; y1 = y0 - (qinv3(y0) - m2 * (0.5 - x2) * exp(0.5 * y0 * y0)); } while (fabs(y0 - y1) >= 1e-14); } else { /* never reached */ y1 = 0; } if (x > 0.5) { val = -y1; } else { val = y1; } rval->val = val; return 0; } int math_func_rand(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = g_random_double() * exp->buf[0].val.val; return 0; } int math_func_srand(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); g_random_set_seed(exp->buf[0].val.val); rval->val = exp->buf[0].val.val; return 0; } #ifdef HAVE_LIBGSL int math_func_icbeta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int r; gsl_sf_result val; double a, b, x; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); a = exp->buf[0].val.val; b = exp->buf[1].val.val; x = exp->buf[2].val.val; if (x < 0 || x > 1) { rval->type = MATH_VALUE_ERROR; return -1; } r = gsl_sf_beta_inc_e(a, b, x, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_zeta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int r; gsl_sf_result val; double n; MATH_CHECK_ARG(rval, exp->buf[0]); n = exp->buf[0].val.val; if (n == 1) { rval->type = MATH_VALUE_ERROR; return -1; } r = gsl_sf_zeta_e(n, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_zetam1(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int r; gsl_sf_result val; double n; MATH_CHECK_ARG(rval, exp->buf[0]); n = exp->buf[0].val.val; if (n == 1) { rval->type = MATH_VALUE_ERROR; return -1; } r = gsl_sf_zetam1_e(n, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_zeta_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int r; gsl_sf_result val; int n; MATH_CHECK_ARG(rval, exp->buf[0]); n = exp->buf[0].val.val; if (n == 1) { rval->type = MATH_VALUE_ERROR; return -1; } r = gsl_sf_zeta_int_e(n, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_zetam1_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int r; gsl_sf_result val; int n; MATH_CHECK_ARG(rval, exp->buf[0]); n = exp->buf[0].val.val; if (n == 1) { rval->type = MATH_VALUE_ERROR; return -1; } r = gsl_sf_zetam1_int_e(n, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } #endif int math_func_beta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double p, q; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else double a, b, c; #endif MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); p = exp->buf[0].val.val; q = exp->buf[1].val.val; #ifdef HAVE_LIBGSL r = gsl_sf_beta_e(p, q, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else if (gamma2(p, &a)) { rval->type = MATH_VALUE_ERROR; return -1; } if (gamma2(q, &b)) { rval->type = MATH_VALUE_ERROR; return -1; } if (gamma2(p + q, &c)) { rval->type = MATH_VALUE_ERROR; return -1; } if (fabs(c) < 1E-300) { rval->type = MATH_VALUE_ERROR; return -1; } rval->val = a * b / c; return 0; #endif } int math_func_lgn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x, alp; int n; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else int i; double l1, l2, tmp1, tmp2, val; #endif MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); n = exp->buf[0].val.val; alp = exp->buf[1].val.val; x = exp->buf[2].val.val; if (n < 0) { rval->type = MATH_VALUE_ERROR; return -1; } #ifdef HAVE_LIBGSL if (n == 1) { r = gsl_sf_laguerre_1_e(alp, x, &val); } else if (n == 2) { r = gsl_sf_laguerre_2_e(alp, x, &val); } else if (n == 3) { r = gsl_sf_laguerre_3_e(alp, x, &val); } else { r = gsl_sf_laguerre_n_e(n, alp, x, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else l1 = 1; if (n == 0) { val = l1; } else { l2 = 1 - x + alp; if (n == 1) { val = l2; } else { tmp1 = 1 + x - alp; tmp2 = 1 - alp; for (i = 2; i <= n; i++) { val = (l2 - l1) + l2 - (tmp1 * l2 - tmp2 * l1) / i; l1 = l2; l2 = val; } } } rval->val = val; return 0; #endif } static double mjd(int y, int m, int d, int hh, int mm, int ss) { int d0, d1, d2, d3, d4; if (m < 1) { m = 1; } if (d < 1) { d = 1; } d0 = (14 - m) / 12; d1 = (y - d0) * 365.25; d2 = (m + d0 * 12 - 2) * 30.59; d3 = (y - d0) / 100; d4 = (y - d0) / 400; return d1 + d2 - d3 + d4 + d + 1721088 - 2400000 + hh / 24.0 + mm / 1440.0 + ss / 86400.0; } int math_func_mjd(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); MATH_CHECK_ARG(rval, exp->buf[3]); MATH_CHECK_ARG(rval, exp->buf[4]); MATH_CHECK_ARG(rval, exp->buf[5]); rval->val = mjd(exp->buf[0].val.val, exp->buf[1].val.val, exp->buf[2].val.val, exp->buf[3].val.val, exp->buf[4].val.val, exp->buf[5].val.val); return 0; } int math_func_unix2mjd(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm *tm; time_t t; MATH_CHECK_ARG(rval, exp->buf[0]); t = exp->buf[0].val.val; tm = gmtime(&t); if (tm == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = mjd(tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec); return 0; } int math_func_mjd2unix(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = (exp->buf[0].val.val - 40587) * 86400; return 0; } int math_func_mjd2year(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm t; MATH_CHECK_ARG(rval, exp->buf[0]); mjd2gd(exp->buf[0].val.val, &t); if (t.tm_year < MJD2GD_YEAR_MIN) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = t.tm_year + 1900; return 0; } int math_func_mjd2month(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm t; MATH_CHECK_ARG(rval, exp->buf[0]); mjd2gd(exp->buf[0].val.val, &t); if (t.tm_year < MJD2GD_YEAR_MIN) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = t.tm_mon + 1; return 0; } int math_func_mjd2day(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm t; MATH_CHECK_ARG(rval, exp->buf[0]); mjd2gd(exp->buf[0].val.val, &t); if (t.tm_year < MJD2GD_YEAR_MIN) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = t.tm_mday; return 0; } int math_func_mjd2wday(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm t; MATH_CHECK_ARG(rval, exp->buf[0]); mjd2gd(exp->buf[0].val.val, &t); if (t.tm_year < MJD2GD_YEAR_MIN) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = (t.tm_wday == 0) ? 7 : t.tm_wday; return 0; } int math_func_mjd2yday(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct tm t; MATH_CHECK_ARG(rval, exp->buf[0]); mjd2gd(exp->buf[0].val.val, &t); if (t.tm_year < MJD2GD_YEAR_MIN) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = t.tm_yday + 1; return 0; } int math_func_xor(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); rval->val = ((exp->buf[0].val.val != 0) ^ (exp->buf[1].val.val != 0)) ? 1 : 0; return 0; } int math_func_and(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); rval->val = (exp->buf[0].val.val && exp->buf[1].val.val); return 0; } int math_func_not(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); rval->val = ! exp->buf[0].val.val; return 0; } int math_func_lt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r < 0) ? 1 : 0; return 0; } int math_func_le(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r <= 0) ? 1 : 0; return 0; } int math_func_or(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); rval->val = (exp->buf[0].val.val || exp->buf[1].val.val); return 0; } int math_func_ge(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r >= 0) ? 1 : 0; return 0; } static int compare_double_with_prec(long double a, long double b, int prec) { #ifndef HAVE_LIBGSL long double scale, r, dif; int order, order_a, order_b; #endif if (a == b) { return 0; } if (prec < 1 || prec > 34) { /* long double (IEEE754-2008 binary128) */ return (a > b) ? 1 : -1; } #ifdef HAVE_LIBGSL return gsl_fcmp(a, b, pow(10, -prec)); #else if (a == 0.0 || b == 0.0) { return (a > b) ? 1 : -1; } if ((a > 0 && b < 0) || (a < 0 && b > 0)) { return (a > b) ? 1 : -1; } #if HAVE_FLOORL && HAVE_LOG10L && HAVE_FABSL order_a = floorl(log10l(fabsl(a))); order_b = floorl(log10l(fabsl(b))); #else /* HAVE_FLOORL && HAVE_LOG10L && HAVE_FABSL */ order_a = floor(log10(fabs(a))); order_b = floor(log10(fabs(b))); #endif if (order_a - order_b > 1) { return 1; } else if (order_a - order_b < -1) { return -1; } order = (order_a > order_b) ? order_a : order_b; #if HAVE_POWL scale = powl(10, - order); #else /* HAVE_POWL */ scale = pow(10, - order); #endif dif = a *scale - b * scale; #if HAVE_POWL scale = powl(10, prec - 1); #else /* HAVE_POWL */ scale = pow(10, prec - 1); #endif r = dif * scale; if (r >= 0.5) { return 1; } else if (r <= -0.5) { return -1; } return 0; #endif } int math_func_eq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r == 0) ? 1 : 0; return 0; } int math_func_neq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r != 0) ? 1 : 0; return 0; } int math_func_tn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double l1, l2, tmp1, x, val; int i, n; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; if (n < 0) { rval->type = MATH_VALUE_ERROR; return -1; } l1 = 1; if (n == 0) { val = l1; } else { l2 = x; if (n == 1) { val = l2; } else { tmp1 = x + x; for (i = 2; i <= n; i++) { val = tmp1 * l2 - l1; l1 = l2; l2 = val; } } } rval->val = val; return 0; } int math_func_hn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double l1, l2, val, x; int i, n; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; if (n < 0) { rval->type = MATH_VALUE_ERROR; return -1; } l1 = 1; if (n == 0) { val = l1; } else { l2 = 2 * x; if (n == 1) { val = l2; } else { for (i = 2; i <= n; i++) { val = x * l2 - (i - 1) * l1; val += val; l1 = l2; l2 = val; } } } rval->val = val; return 0; } int math_func_gt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int prec, r; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); MATH_CHECK_ARG(rval, exp->buf[2]); prec = exp->buf[2].val.val; r = compare_double_with_prec(exp->buf[0].val.val, exp->buf[1].val.val, prec); rval->val = (r > 0) ? 1 : 0; return 0; } int math_func_if(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; n = (exp->buf[0].val.type == MATH_VALUE_NORMAL && exp->buf[0].val.val) ? 1 : 2; return math_expression_calculate(exp->buf[n].exp, rval); } int math_func_unless(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; n = (exp->buf[0].val.type == MATH_VALUE_NORMAL && exp->buf[0].val.val) ? 2 : 1; return math_expression_calculate(exp->buf[n].exp, rval); } #define CHECK_VAL_TYPE(R,V,T) (R)->val = ((V).val.type == T); \ (R)->type = MATH_VALUE_NORMAL; int math_func_isnormal(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { CHECK_VAL_TYPE(rval, exp->buf[0], MATH_VALUE_NORMAL); return 0; } int math_func_isnan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { rval->val = (exp->buf[0].val.type == MATH_VALUE_NAN || (exp->buf[0].val.val != exp->buf[0].val.val)); rval->type = MATH_VALUE_NORMAL; return 0; } int math_func_isundef(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { CHECK_VAL_TYPE(rval, exp->buf[0], MATH_VALUE_UNDEF); return 0; } int math_func_isbreak(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { CHECK_VAL_TYPE(rval, exp->buf[0], MATH_VALUE_BREAK); return 0; } int math_func_iscont(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { CHECK_VAL_TYPE(rval, exp->buf[0], MATH_VALUE_CONT); return 0; } int math_func_pn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x; int n; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else double l1, val; int i; #endif MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; #ifdef HAVE_LIBGSL if (n < 0 || fabs(x) > 1) { rval->type = MATH_VALUE_ERROR; return -1; } switch (n) { case 1: r = gsl_sf_legendre_P1_e(x, &val); break; case 2: r = gsl_sf_legendre_P2_e(x, &val); break; case 3: r = gsl_sf_legendre_P3_e(x, &val); break; default: r = gsl_sf_legendre_Pl_e(n, x, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else if (n < 0 || fabs(x) > 1000) { rval->type = MATH_VALUE_ERROR; return -1; } l1 = 1; if (n == 0) { val = l1; } else { double l2; l2 = x; if (n == 1) { val = l2; } else { double tmp1, tmp2; for (i = 2; i <= n; i++) { tmp1 = x * l2; tmp2 = tmp1 - l1; val = tmp2 + tmp1 - tmp2 / i; l1 = l2; l2 = val; } } } rval->val = val; return 0; #endif } int math_func_yn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else int m, i, l; double t1, t2, t3, s, ss, w, j0, j1, y0, y1, y2, val; #endif MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); #ifdef HAVE_LIBGSL if (n2 == 0) { r = gsl_sf_bessel_Y0_e(x2, &val); } else if (n2 == 1) { r = gsl_sf_bessel_Y1_e(x2, &val); } else { r = gsl_sf_bessel_Yn_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else if ((n2 > 1000) || (x2 > 1000) || (x2 <= 1E-300)) { rval->type = MATH_VALUE_ERROR; return -1; } if (x2 <= 2E-5) { t1 = x2 * 0.5; j0 = 1 - t1 * t1; y0 = 2 / MPI * ((MEULER + log(t1)) * j0 + t1 * t1); if (n2 != 0) { j1 = t1 - 0.5 * t1 * t1 * t1; y1 = (j1 * y0 - 2 / MPI / x2) / j0; if (n2 >= -65 / log10(t1)) { rval->type = MATH_VALUE_ERROR; return -1; } for (i = 2; i <= n2; i++) { y2 = 2 * (i - 1) / x2 * y1 - y0; y0 = y1; y1 = y2; } } } else { if (x2 >= 100) { m = (int) (1.073 * x2 + 47); } else if (x2 >= 10) { m = (int) (1.27 * x2 + 28); } else if (x2 >= 1) { m = (int) (2.4 * x2 + 15); } else if (x2 >= 0.1) { m = 17; } else { m = 10; } t3 = 0; t2 = 1E-75; s = 0; ss = 0; for (i = m - 1; i >= 0; i--) { t1 = 2 * (i + 1) / x2 * t2 - t3; if ((i % 2 == 0) && (i != 0)) { s += t1; l = i / 2; if (l % 2 == 0) { ss -= t1 / l; } else { ss += t1 / l; } if (fabs(s) >= 1E55) { t1 *= 1E-55; t2 *= 1E-55; s *= 1E-55; ss *= 1E-55; } } t3 = t2; t2 = t1; } s = 2 * s + t1; j0 = t1 / s; j1 = t3 / s; ss /= s; y0 = 2 / MPI * ((MEULER + log(x2 * 0.5)) * j0 + 2 * ss); if (n2 != 0) { y1 = (j1 * y0 - 2 / MPI / x2) / j0; for (i = 2; i <= n2; i++) { if (y1 <= -1E65) { w = y1 * 1E-10; y2 = 2 * (i - 1) / x2 * w - y0 * 1E-10; if (fabs(y2) >= 1E65) { rval->type = MATH_VALUE_ERROR; return -1; } y2 *= 1E10; } else { y2 = 2 * (i - 1) / x2 * y1 - y0; } y0 = y1; y1 = y2; } } } if (n == 0) { val = y0; } else { if ((n < 0) && (n2 % 2 == 1)) { y1 = -y1; } if ((x < 0) && (n2 % 2 == 1)){ y1 = -y1; } val = y1; } rval->val = val; return 0; #endif } int math_func_jn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #else int m, l, i; double t1, t2, t3, s, j; #endif MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); #ifdef HAVE_LIBGSL if (n2 == 0) { r = gsl_sf_bessel_J0_e(x2, &val); } else if (n2 == 1) { r = gsl_sf_bessel_J1_e(x2, &val); } else { r = gsl_sf_bessel_Jn_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else if (n2 > 1000 || x2 > 1000) { rval->type = MATH_VALUE_ERROR; return -1; } if (x2 <= 2E-5) { t1 = x2 * 0.5; if (n2 == 0) { j = 1 - t1 * t1; } else if (x2 <= 1E-77) { j = 0; } else { t2 = 1; t3 = 1; i = 1; while ((i <= n2) && (fabs(t3) > fabs(t2 / t1) * 1E-77)) { t3 *= t1 / t2; t2++; i++; } if (i <= n2) { j = 0; } else { j = t3 * (1 - t1 * t1 / t2); } } } else { if (n2 > x2) { m = n2; } else { m = (int) x2; } if (x2 >= 100) { l = (int) (0.073 * x2 + 47); } else if (x2 >= 10) { l = (int) (0.27 * x2 + 27); } else if (x2 > 1) { l = (int) (1.4 * x2 + 14); } else { l = 14; } m += l; t3 = 0; t2 = 1E-75; s = 0; for (i = m - 1; i >= 0; i--) { t1 = 2 * (i + 1) / x2 * t2 - t3; if (i == n2) { j = t1; } if ((i % 2 == 0) && (i != 0)) { s += t1; if (fabs(s) >= 1E55) { t1 *= 1E-55; t2 *= 1E-55; s *= 1E-55; j *= 1E-55; } } t3 = t2; t2 = t1; } s = 2 * s + t1; j /= s; } if ((n < 0) && (n2 % 2 == 1)) { j = -j; } if ((x < 0) && (n2 % 2 == 1)) { j = -j; } rval->val = j; return 0; #endif } #ifdef HAVE_LIBGSL int math_func_ynu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x2, x, n2, n; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = fabs(n); r = gsl_sf_bessel_Ynu_e(n2, x2, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_jnu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x2, x, n2, n; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = fabs(n); r = gsl_sf_bessel_Jnu_e(n2, x2, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_inu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x2, x, n2, n; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = fabs(n); r = gsl_sf_bessel_Inu_e(n2, x2, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_knu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x2, x, n2, n; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = fabs(n); r = gsl_sf_bessel_Knu_e(n2, x2, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_in(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); switch (n2) { case 0: r = gsl_sf_bessel_I0_e(x2, &val); break; case 1: r = gsl_sf_bessel_I1_e(x2, &val); break; default: r = gsl_sf_bessel_In_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_kn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); switch (n2) { case 0: r = gsl_sf_bessel_K0_e(x2, &val); break; case 1: r = gsl_sf_bessel_K1_e(x2, &val); break; default: r = gsl_sf_bessel_Kn_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_yl(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); switch (n2) { case 0: r = gsl_sf_bessel_y0_e(x2, &val); break; case 1: r = gsl_sf_bessel_y1_e(x2, &val); break; default: r = gsl_sf_bessel_yl_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_jl(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n2, n; double x2, x; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); n = exp->buf[0].val.val; x = exp->buf[1].val.val; x2 = fabs(x); n2 = abs(n); switch (n2) { case 0: r = gsl_sf_bessel_j0_e(x2, &val); break; case 1: r = gsl_sf_bessel_j1_e(x2, &val); break; default: r = gsl_sf_bessel_jl_e(n2, x2, &val); } rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } int math_func_choose(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { unsigned int m, n; int r; gsl_sf_result val; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); if (exp->buf[0].val.val < 0 || exp->buf[1].val.val < 0) { printf("math_func_choose\n"); rval->type = MATH_VALUE_ERROR; return 1; } n = exp->buf[0].val.val; m = exp->buf[1].val.val; r = gsl_sf_choose_e(n, m, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; } #endif int math_func_ei(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { #ifdef HAVE_LIBGSL int r; gsl_sf_result val; #endif MATH_CHECK_ARG(rval, exp->buf[0]); #ifdef HAVE_LIBGSL r = gsl_sf_expint_Ei_e(exp->buf[0].val.val, &val); rval->val = val.val; if (r) { rval->type = MATH_VALUE_ERROR; } return r; #else return exp1(exp->buf[0].val.val, &rval->val); #endif } static int init_memory(void) { if (Memory) { return 0; } Memory = g_malloc0(sizeof(*Memory) * MATH_FUNCTION_MEMORY_NUM); if (Memory == NULL) { return 1; } return 0; } int math_func_cm(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int start, i, n; MathValue val; if (Memory == NULL && init_memory()) { return 1; } MATH_CHECK_ARG(rval, exp->buf[1]); start = 0; n = exp->buf[1].val.val; if (abs(n) >= MATH_FUNCTION_MEMORY_NUM) { rval->type = MATH_VALUE_ERROR; return 1; } if (n == 0) { n = MATH_FUNCTION_MEMORY_NUM; } else if (n < 0) { start = MATH_FUNCTION_MEMORY_NUM + n; n = MATH_FUNCTION_MEMORY_NUM; } val = exp->buf[0].val; if (val.val == 0 && val.type == MATH_VALUE_NORMAL) { memset(Memory + start, 0, sizeof(*Memory) * (n - start)); } else { for (i = start; i < n; i++) { Memory[i] = val; } } *rval = exp->buf[0].val; return 0; } int math_func_rm(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; MATH_CHECK_ARG(rval, exp->buf[0]); if (Memory == NULL && init_memory()) { return 1; } n = exp->buf[0].val.val; if (abs(n) >= MATH_FUNCTION_MEMORY_NUM) { rval->type = MATH_VALUE_ERROR; return 1; } else if (n < 0) { n += MATH_FUNCTION_MEMORY_NUM; } *rval = Memory[n]; return 0; } int math_func_m(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; MATH_CHECK_ARG(rval, exp->buf[0]); if (Memory == NULL && init_memory()) { return 1; } n = exp->buf[0].val.val; if (abs(n) >= MATH_FUNCTION_MEMORY_NUM) { rval->type = MATH_VALUE_ERROR; return 1; } else if (n < 0) { n += MATH_FUNCTION_MEMORY_NUM; } *rval = Memory[n] = exp->buf[1].val; return 0; } int math_func_am(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, n; MathEquationArray *ary; rval->val = 0; if (Memory == NULL && init_memory()) { return 1; } id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } n = (ary->num > MATH_FUNCTION_MEMORY_NUM) ? MATH_FUNCTION_MEMORY_NUM : ary->num; if (n > 0) { memcpy(Memory, ary->data, sizeof(*Memory) * n); } rval->val = n; return 0; } int math_func_for(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n, r, i; double v, start, stop, step; MathFunctionArgument *argv; if (Memory == NULL && init_memory()) { return 1; } argv = exp->buf; MATH_CHECK_ARG(rval, argv[0]); MATH_CHECK_ARG(rval, argv[1]); MATH_CHECK_ARG(rval, argv[2]); MATH_CHECK_ARG(rval, argv[3]); n = argv[0].val.val; start = argv[1].val.val; stop = argv[2].val.val; step = argv[3].val.val; if (n >= MATH_FUNCTION_MEMORY_NUM || (stop - start) * step <= 0) { rval->type = MATH_VALUE_ERROR; return 1; } if (n >= 0) { Memory[n].type = MATH_VALUE_NORMAL; } i = 0; rval->val = 0; for (v = start; (step < 0) ? (v >= stop) : (v <= stop); v += step) { if ((i & 0xff) == 0 && ninterrupt()) { rval->type = MATH_VALUE_INTERRUPT; return 1; } if (n >= 0) { Memory[n].val = v; } r = math_expression_calculate(argv[4].exp, rval); if(r) { return r; } if (rval->type == MATH_VALUE_ERROR) { return 1; } i++; } return 0; } int math_func_while(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n, r, i; MathFunctionArgument *argv; MathValue condition; if (Memory == NULL && init_memory()) { return 1; } argv = exp->buf; MATH_CHECK_ARG(rval, argv[0]); n = argv[0].val.val; if (n >= MATH_FUNCTION_MEMORY_NUM) { rval->type = MATH_VALUE_ERROR; return 1; } if (n >= 0) { Memory[n].type = MATH_VALUE_NORMAL; } rval->val = 0; rval->type = MATH_VALUE_UNDEF; condition.val = 0; condition.type = MATH_VALUE_NORMAL; for (i = 0; ; i++) { if ((i & 0xff) == 0 && ninterrupt()) { rval->type = MATH_VALUE_INTERRUPT; return 1; } if (n >= 0) { Memory[n].val = i; } r = math_expression_calculate(argv[1].exp, &condition); if(r) { return r; } if (condition.type == MATH_VALUE_ERROR) { return 1; } if (condition.val == 0.0) { break; } r = math_expression_calculate(argv[2].exp, rval); if(r) { return r; } } return 0; } static int compare_double(const void *p1, const void *p2) { MathValue *v1, *v2; v1 = (MathValue *) p1; v2 = (MathValue *) p2; if (v1->type == MATH_VALUE_NORMAL && v2->type == MATH_VALUE_NORMAL) { if (v1->val > v2->val) { return 1; } else if (v1->val < v2->val) { return -1; } } else if (v1->type != MATH_VALUE_NORMAL && v2->type == MATH_VALUE_NORMAL) { return 1; } else if (v1->type == MATH_VALUE_NORMAL && v2->type != MATH_VALUE_NORMAL) { return -1; } return 0; } static int rcompare_double(const void *p1, const void *p2) { MathValue *v1, *v2; v1 = (MathValue *) p1; v2 = (MathValue *) p2; if (v1->type == MATH_VALUE_NORMAL && v2->type == MATH_VALUE_NORMAL) { if (v1->val > v2->val) { return -1; } else if (v1->val < v2->val) { return 1; } } else if (v1->type != MATH_VALUE_NORMAL && v2->type == MATH_VALUE_NORMAL) { return -1; } else if (v1->type == MATH_VALUE_NORMAL && v2->type != MATH_VALUE_NORMAL) { return 1; } return 0; } int math_func_push(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; rval->val = 0; id = (int) exp->buf[0].idx; if (math_equation_push_array_val(eq, id, &exp->buf[1].val)) { rval->type = MATH_VALUE_ERROR; return 1; } *rval = exp->buf[1].val; return 0; } int math_func_pop(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } ary->num--; *rval = ary->data[ary->num]; ary->data[ary->num].val = 0; ary->data[ary->num].type = MATH_VALUE_NORMAL; return 0; } int math_func_shift(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } *rval = ary->data[0]; ary->num--; if (ary->num > 0) { memmove(ary->data, ary->data + 1, sizeof(*ary->data) * ary->num); } ary->data[ary->num].val = 0; ary->data[ary->num].type = MATH_VALUE_NORMAL; return 0; } int math_func_unshift(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (math_equation_set_array_val(eq, id, ary->num, &exp->buf[1].val)) { rval->type = MATH_VALUE_ERROR; return 1; } if (ary->num > 1) { memmove(ary->data + 1, ary->data, sizeof(*ary->data) * (ary->num - 1)); } *rval = ary->data[0] = exp->buf[1].val; return 0; } int math_func_sort(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = ary->num; if (ary->num < 2) { return 0; } qsort(ary->data, ary->num, sizeof(MathValue), compare_double); return 0; } int math_func_rsort(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = ary->num; if (ary->num < 2) { return 0; } qsort(ary->data, ary->num, sizeof(MathValue), rcompare_double); return 0; } int math_func_size(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = ary->num; return 0; } int math_func_array(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i, r; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } r = math_equation_clear_array(eq, id); if (r) { rval->type = MATH_VALUE_ERROR; return 1; } for (i = 1; i < exp->argc; i++) { if (math_equation_push_array_val(eq, id, &exp->buf[i].val)) { rval->type = MATH_VALUE_ERROR; return 1; } } rval->val = exp->argc - 1; return 0; } int math_func_array_sum(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i; MathEquationArray *ary; double sum; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } sum = 0; for (i = 0; i < ary->num; i++) { if (ary->data[i].type != MATH_VALUE_NORMAL) { rval->type = MATH_VALUE_ERROR; return 1; } sum += ary->data[i].val; } rval->val = sum; return 0; } int math_func_array_sumsq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i; MathEquationArray *ary; double sum, val; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } sum = 0; for (i = 0; i < ary->num; i++) { if (ary->data[i].type != MATH_VALUE_NORMAL) { rval->type = MATH_VALUE_ERROR; return 1; } val = ary->data[i].val; sum += val * val; } rval->val = sum; return 0; } int math_func_array_min(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i; MathEquationArray *ary; double min; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } min = ary->data[0].val; for (i = 0; i < ary->num; i++) { if (ary->data[i].type != MATH_VALUE_NORMAL) { rval->type = MATH_VALUE_ERROR; return 1; } if (min > ary->data[i].val) { min = ary->data[i].val; } } rval->val = min; return 0; } int math_func_array_average(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; rval->val = 0; if (math_func_size(exp, eq, rval)) { return 1; } n = rval->val; if (math_func_array_sum(exp, eq, rval)) { return 1; } rval->val /= n; return 0; } int math_func_array_stdevp(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; double sum, sumsq, stdev; rval->val = 0; if (math_func_size(exp, eq, rval)) { return 1; } n = rval->val; if (n < 1) { rval->type = MATH_VALUE_ERROR; return 1; } if (math_func_array_sum(exp, eq, rval)) { return 1; } sum = rval->val; if (math_func_array_sumsq(exp, eq, rval)) { return 1; } sumsq = rval->val; sum /= n; stdev = sumsq / n - sum * sum; if (stdev < 0) { stdev = 0; } rval->val = sqrt(stdev); return 0; } int math_func_array_stdev(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int n; double stdev; rval->val = 0; if (math_func_size(exp, eq, rval)) { return 1; } n = rval->val; if (n < 2) { rval->type = MATH_VALUE_ERROR; return 1; } if (math_func_array_stdevp(exp, eq, rval)) { return 1; } stdev = rval->val; stdev *= stdev * n; stdev /= n - 1; rval->val = sqrt(stdev); return 0; } int math_func_array_max(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i; MathEquationArray *ary; double max; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } max = ary->data[0].val; for (i = 0; i < ary->num; i++) { if (ary->data[i].type != MATH_VALUE_NORMAL) { rval->type = MATH_VALUE_ERROR; return 1; } if (max < ary->data[i].val) { max = ary->data[i].val; } } rval->val = max; return 0; } int math_func_array_compact(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, i, n; MathEquationArray *ary; rval->val = 0; id = (int) exp->buf[0].idx; ary = math_equation_get_array(eq, id); if (ary == NULL || ary->num < 1 || ary->data == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } n = 0; for (i = 0; i < ary->num; i++) { if (ary->data[i].type != MATH_VALUE_NORMAL) { ary->num--; n++; if (i < ary->num) { memmove(ary->data + i, ary->data + i + 1, sizeof(*ary->data) * (ary->num - i)); } } } for (i = 0; i < n; i++) { ary->data[i + ary->num].type = MATH_VALUE_NORMAL; ary->data[i + ary->num].val = 0; } rval->val = ary->num; return 0; } int math_func_array_clear(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int id, r; rval->val = 0; id = (int) exp->buf[0].idx; r = math_equation_clear_array(eq, id); if (r) { rval->type = MATH_VALUE_ERROR; return 1; } return 0; } int math_func_sum(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { if (exp->buf[0].val.type == MATH_VALUE_NORMAL) { MathValue *ptr = eq->pos_func_buf + exp->pos_id; ptr->val += exp->buf[0].val.val; ptr->type = MATH_VALUE_NORMAL; *rval = *ptr; } else { *rval = exp->buf[0].val; } return 0; } int math_func_dif(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { if (exp->buf[0].val.type == MATH_VALUE_NORMAL) { MathValue *ptr = eq->pos_func_buf + exp->pos_id; if (ptr->type == MATH_VALUE_NORMAL) { rval->val = exp->buf[0].val.val - ptr->val; } else { rval->val = 0; } rval->type = ptr->type; *ptr = exp->buf[0].val; } else { *rval = exp->buf[0].val; } return 0; } int math_func_fmod(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { double x, y; MATH_CHECK_ARG(rval, exp->buf[0]); MATH_CHECK_ARG(rval, exp->buf[1]); x = exp->buf[0].val.val; y = exp->buf[1].val.val; if (y == 0.0) { rval->type = MATH_VALUE_NAN; rval->val = 0.0; return 0; } rval->val = fmod(x, y); return 0; } ngraph-gtk-6.08.00/src/math/math_parser.h0000644000175000017500000000036113070106167015047 00000000000000/* * $Id: math_parser.h,v 1.3 2009-11-10 04:12:20 hito Exp $ * */ #ifndef MATH_PARSER_HEADER #define MATH_PARSER_HEADER #include "math_equation.h" MathExpression *math_parser_parse(const char *line, MathEquation *eq, int *err); #endif ngraph-gtk-6.08.00/src/math/math_operator.c0000644000175000017500000000661413241744617015420 00000000000000#include "config.h" #include #include "math_operator.h" struct ope_str { char *ope; int len; enum MATH_OPERATOR_TYPE type; }; static struct ope_str OpeStr[] = { {":=", 2, MATH_OPERATOR_TYPE_ASSIGN}, {">:", 2, MATH_OPERATOR_TYPE_GE}, {">=", 2, MATH_OPERATOR_TYPE_GE}, {"<:", 2, MATH_OPERATOR_TYPE_LE}, {"<=", 2, MATH_OPERATOR_TYPE_LE}, {"::", 2, MATH_OPERATOR_TYPE_EQ}, {"==", 2, MATH_OPERATOR_TYPE_EQ}, {"!:", 2, MATH_OPERATOR_TYPE_NE}, {"!=", 2, MATH_OPERATOR_TYPE_NE}, {"||", 2, MATH_OPERATOR_TYPE_OR}, {"&&", 2, MATH_OPERATOR_TYPE_AND}, {"-:", 2, MATH_OPERATOR_TYPE_MINUS_ASSIGN}, {"-=", 2, MATH_OPERATOR_TYPE_MINUS_ASSIGN}, {"+:", 2, MATH_OPERATOR_TYPE_PLUS_ASSIGN}, {"+=", 2, MATH_OPERATOR_TYPE_PLUS_ASSIGN}, {"*:", 2, MATH_OPERATOR_TYPE_MUL_ASSIGN}, {"*=", 2, MATH_OPERATOR_TYPE_MUL_ASSIGN}, {"/:", 2, MATH_OPERATOR_TYPE_DIV_ASSIGN}, {"/=", 2, MATH_OPERATOR_TYPE_DIV_ASSIGN}, {"\\:", 2, MATH_OPERATOR_TYPE_MOD_ASSIGN}, {"\\=", 2, MATH_OPERATOR_TYPE_MOD_ASSIGN}, {"^:", 2, MATH_OPERATOR_TYPE_POW_ASSIGN}, {"^=", 2, MATH_OPERATOR_TYPE_POW_ASSIGN}, {"-", 1, MATH_OPERATOR_TYPE_MINUS}, {"+", 1, MATH_OPERATOR_TYPE_PLUS}, {"*", 1, MATH_OPERATOR_TYPE_MUL}, {"/", 1, MATH_OPERATOR_TYPE_DIV}, {"\\", 1, MATH_OPERATOR_TYPE_MOD}, {"^", 1, MATH_OPERATOR_TYPE_POW}, {"!", 1, MATH_OPERATOR_TYPE_FACT}, {":", 1, MATH_OPERATOR_TYPE_ASSIGN}, {">", 1, MATH_OPERATOR_TYPE_GT}, {"<", 1, MATH_OPERATOR_TYPE_LT}, {"=", 1, MATH_OPERATOR_TYPE_EOEQ}, {";", 1, MATH_OPERATOR_TYPE_EOEQ}, }; static char OpeChar[256] = { 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, 0, 0, 0, 0, 1, /* ! */ 0, 0, 0, 0, 1, /* & */ 0, 0, 0, 1, /* * */ 1, /* + */ 0, 1, /* - */ 0, 1, /* / */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, /* : */ 1, /* ; */ 1, /* < */ 1, /* = */ 1, /* > */ 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, 1, /* \ */ 0, 1, /* ^ */ 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, 1, /* | */ 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, 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, 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, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; int math_scanner_is_ope(int chr) { if (chr < 0 || chr > (int) (sizeof(OpeChar) / sizeof(*OpeChar))) return 0; return OpeChar[chr]; } enum MATH_OPERATOR_TYPE math_scanner_check_ope_str(const char *str, int *len) { unsigned int i; for (i = 0; i < sizeof(OpeStr) / sizeof(*OpeStr); i++) { if (strncmp(str, OpeStr[i].ope, OpeStr[i].len) == 0) { *len = OpeStr[i].len; return OpeStr[i].type; } } return MATH_OPERATOR_TYPE_UNKNOWN; } ngraph-gtk-6.08.00/src/math/math_function.h0000644000175000017500000002507113243246336015412 00000000000000#ifndef MATH_SCANNER_FUNC_HEADER #define MATH_SCANNER_FUNC_HEADER enum MATH_FUNCTION_ARG_TYPE { MATH_FUNCTION_ARG_TYPE_DOUBLE, MATH_FUNCTION_ARG_TYPE_ARRAY, MATH_FUNCTION_ARG_TYPE_PROC, }; typedef int (* math_function) (MathFunctionCallExpression *exp, MathEquation *eq, MathValue *r); struct math_function_parameter { int argc; int side_effect, positional; math_function func; enum MATH_FUNCTION_ARG_TYPE *arg_type; MathExpression *opt_usr, *base_usr; char *name; }; int math_scanner_is_func(int chr); int math_add_basic_function(MathEquation *eq); int math_func_array_average(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_compact(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_stdevp(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_clear(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_sumsq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_stdev(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_zetam1_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_mjd2month(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_sum(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_min(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array_max(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_unix2mjd(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_mjd2year(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_mjd2wday(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_mjd2yday(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_isnormal(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_zeta_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_mjd2unix(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_mjd2day(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_isundef(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_isbreak(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_unshift(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_icbeta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_unless(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_iscont(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_zetam1(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_choose(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_gauss(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_round(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_asinh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_acosh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_atanh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_srand(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_theta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_delta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_gamma(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_icgam(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_rsort(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_array(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_isnan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_progn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_prog1(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_prog2(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_shift(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sumsq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sign(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_frac(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sqrt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_asin(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_acos(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_atan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sinh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_cosh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_tanh(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_rand(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_erfc(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_qinv(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_beta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sort(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_size(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_zeta(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_push(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_time(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_fmod(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_abs(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_int(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_min(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_max(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sqr(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_exp(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_log(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sin(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_cos(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_tan(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_erf(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_lgn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_mjd(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_neq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_not(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_and(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_xor(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_for(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_dif(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_sum(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_jnu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_ynu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_inu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_knu(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_pop(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_ln(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_ei(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_jn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_yn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_pn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_hn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_tn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_eq(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_ge(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_gt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_le(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_lt(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_or(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_rm(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_cm(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_am(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); int math_func_if(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #ifdef HAVE_LIBGSL int math_func_in(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_kn(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_yl(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif #ifdef HAVE_LIBGSL int math_func_jl(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif int math_func_m(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval); #endif ngraph-gtk-6.08.00/src/math/math_constant.c0000644000175000017500000000275313241744617015416 00000000000000#include "config.h" #include #include "math_expression.h" #include "math_equation.h" #include "math_constant.h" static struct math_const_parameter MathConstParameter[] = { {"EULER", MATH_SCANNER_VAL_TYPE_NORMAL, {0.57721566490153286061, MATH_VALUE_NORMAL}}, {"UNDEF", MATH_SCANNER_VAL_TYPE_NORMAL, {0, MATH_VALUE_UNDEF}}, {"BREAK", MATH_SCANNER_VAL_TYPE_NORMAL, {0, MATH_VALUE_BREAK}}, {"FALSE", MATH_SCANNER_VAL_TYPE_NORMAL, {0, MATH_VALUE_NORMAL}}, {"CONT", MATH_SCANNER_VAL_TYPE_NORMAL, {0, MATH_VALUE_CONT}}, {"TRUE", MATH_SCANNER_VAL_TYPE_NORMAL, {1, MATH_VALUE_NORMAL}}, {"NAN", MATH_SCANNER_VAL_TYPE_NORMAL, {0, MATH_VALUE_NAN}}, {"PI", MATH_SCANNER_VAL_TYPE_NORMAL, {3.14159265358979323846, MATH_VALUE_NORMAL}}, {"E", MATH_SCANNER_VAL_TYPE_NORMAL, {2.71828182845904523536, MATH_VALUE_NORMAL}}, }; int math_add_basic_constant(MathEquation *eq) { unsigned int i; for (i = 0; i < sizeof(MathConstParameter) / sizeof(*MathConstParameter); i++) { if (math_equation_add_const(eq, MathConstParameter[i].str, &MathConstParameter[i].val) < 0) { return 1; } } return 0; } enum MATH_SCANNER_VAL_TYPE math_scanner_check_math_const_parameter(char *str, MathValue *val) { unsigned int i; for (i = 0; i < sizeof(MathConstParameter) / sizeof(*MathConstParameter); i++) { if (strcmp(str, MathConstParameter[i].str) == 0) { *val = MathConstParameter[i].val; return MathConstParameter[i].type; } } return MATH_SCANNER_VAL_TYPE_UNKNOWN; } ngraph-gtk-6.08.00/src/math/math_constant.h.in0000644000175000017500000000043513241744506016020 00000000000000E 2.71828182845904523536 MATH_VALUE_NORMAL PI 3.14159265358979323846 MATH_VALUE_NORMAL EULER 0.57721566490153286061 MATH_VALUE_NORMAL NAN 0 MATH_VALUE_NAN UNDEF 0 MATH_VALUE_UNDEF CONT 0 MATH_VALUE_CONT BREAK 0 MATH_VALUE_BREAK TRUE 1 MATH_VALUE_NORMAL FALSE 0 MATH_VALUE_NORMAL ngraph-gtk-6.08.00/src/math/math_error.h0000644000175000017500000000270413352667211014714 00000000000000/* * $Id: math_error.h,v 1.5 2009-11-21 11:39:10 hito Exp $ * */ #ifndef MATH_ERROR_HEADER #define MATH_ERROR_HEADER #define MATH_ERROR_TYPE_SYNTAX 0x00010000 #define MATH_ERROR_TYPE_PARSE 0x00020000 #define MATH_ERROR_TYPE_RUNTIME 0x00040000 enum MATH_ERROR { MATH_ERROR_NONE = 0, MATH_ERROR_EOEQ = (MATH_ERROR_TYPE_SYNTAX | 0x0001), MATH_ERROR_FDEF_NEST = (MATH_ERROR_TYPE_SYNTAX | 0x0002), MATH_ERROR_UNEXP_OPE = (MATH_ERROR_TYPE_SYNTAX | 0x0003), MATH_ERROR_ARG_NUM = (MATH_ERROR_TYPE_SYNTAX | 0x0004), MATH_ERROR_MISS_RP = (MATH_ERROR_TYPE_SYNTAX | 0x0005), MATH_ERROR_MISS_RB = (MATH_ERROR_TYPE_SYNTAX | 0x0006), MATH_ERROR_MISS_RC = (MATH_ERROR_TYPE_SYNTAX | 0x0007), MATH_ERROR_UNKNOWN_FUNC = (MATH_ERROR_TYPE_SYNTAX | 0x0008), MATH_ERROR_INVALID_FDEF = (MATH_ERROR_TYPE_SYNTAX | 0x0009), MATH_ERROR_INVALID_CDEF = (MATH_ERROR_TYPE_PARSE | 0x000A), MATH_ERROR_UNEXP_TOKEN = (MATH_ERROR_TYPE_SYNTAX | 0x000B), MATH_ERROR_INVALID_PRM = (MATH_ERROR_TYPE_PARSE | 0x0010), MATH_ERROR_PRM_IN_DEF = (MATH_ERROR_TYPE_PARSE | 0x0020), MATH_ERROR_CONST_EXIST = (MATH_ERROR_TYPE_PARSE | 0x0040), MATH_ERROR_CALCULATION = (MATH_ERROR_TYPE_RUNTIME | 0x0010), MATH_ERROR_MEMORY = 0x0100, MATH_ERROR_UNKNOWN = 0x1000, MATH_ERROR_INVALID_FUNC = -2, }; char *math_err_get_error_message(MathEquation *eq, const char *code, int err); void math_err_get_recent_error_position(int *line, int *ofst); #endif ngraph-gtk-6.08.00/src/math/parse_bin_expression.h0000644000175000017500000001266413243246326017000 00000000000000/* * $Id: parse_bin_expression.h,v 1.3 2009-11-10 04:12:20 hito Exp $ * */ #define CREATE_PARSER_FUNC(a, b, c, d) parse_ ## a ## _expression(struct math_string *str, MathEquation *eq, int *err) \ {\ struct math_token *token;\ MathExpression *left, *right, *exp;\ \ exp = parse_ ## b ## _expression(str, eq, err); \ if (exp == NULL) {\ return NULL;\ }\ \ for (;;) {\ token = my_get_token(str);\ if (token == NULL) {\ *err = MATH_ERROR_MEMORY;\ math_expression_free(exp);\ return NULL;\ }\ \ switch (token->type) {\ case MATH_TOKEN_TYPE_OPERATOR:\ switch (token->data.op) {\ case c:\ right = parse_ ## b ## _expression(str, eq, err); \ if (right == NULL) {\ math_expression_free(exp);\ math_scanner_free_token(token);\ return NULL;\ }\ left = exp;\ math_scanner_free_token(token);\ exp = math_binary_expression_new(d, eq, left, right, err); \ if (exp == NULL) { \ math_expression_free(left); \ math_expression_free(right); \ return NULL; \ } \ break;\ default:\ unget_token(token);\ goto End;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ }\ \ End:\ return exp;\ } #define CREATE_PARSER2_FUNC(a, b, c, d, e, f) parse_ ## a ## _expression(struct math_string *str, MathEquation *eq, int *err) \ {\ struct math_token *token;\ MathExpression *left, *right, *exp;\ enum MATH_EXPRESSION_TYPE type;\ \ exp = parse_ ## b ## _expression(str, eq, err); \ if (exp == NULL) {\ return NULL;\ }\ \ for (;;) {\ token = my_get_token(str);\ if (token == NULL) {\ *err = MATH_ERROR_MEMORY;\ math_expression_free(exp);\ return NULL;\ }\ \ switch (token->type) {\ case MATH_TOKEN_TYPE_OPERATOR:\ switch (token->data.op) {\ case c:\ case e:\ right = parse_ ## b ## _expression(str, eq, err); \ if (right == NULL) {\ math_expression_free(exp);\ math_scanner_free_token(token);\ return NULL;\ }\ if (token->data.op == c) {\ type = d;\ } else if (token->data.op == e) {\ type = f;\ } else {\ type = 0; /* never reached */\ }\ left = exp;\ math_scanner_free_token(token);\ exp = math_binary_expression_new(type, eq, left, right, err); \ if (exp == NULL) {\ math_expression_free(left);\ math_expression_free(right);\ return NULL;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ }\ \ End:\ return exp;\ } #define CREATE_PARSER3_FUNC(a, b, c, d, e, f, g, h) parse_ ## a ## _expression(struct math_string *str, MathEquation *eq, int *err) \ {\ struct math_token *token;\ MathExpression *left, *right, *exp;\ enum MATH_EXPRESSION_TYPE type;\ \ exp = parse_ ## b ## _expression(str, eq, err); \ if (exp == NULL) {\ return NULL;\ }\ \ for (;;) {\ token = my_get_token(str);\ if (token == NULL) {\ *err = MATH_ERROR_MEMORY;\ math_expression_free(exp);\ return NULL;\ }\ \ switch (token->type) {\ case MATH_TOKEN_TYPE_OPERATOR:\ switch (token->data.op) {\ case c:\ case e:\ case g:\ right = parse_ ## b ## _expression(str, eq, err); \ if (right == NULL) {\ math_expression_free(exp);\ math_scanner_free_token(token);\ return NULL;\ }\ if (token->data.op == c) {\ type = d;\ } else if (token->data.op == e) {\ type = f;\ } else if (token->data.op == g) {\ type = h;\ } else {\ type = 0; /* never reached */\ }\ left = exp;\ math_scanner_free_token(token); \ exp = math_binary_expression_new(type, eq, left, right, err); \ if (exp == NULL) { \ math_expression_free(left);\ math_expression_free(right);\ return NULL;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ }\ \ End:\ return exp;\ } #define CREATE_PARSER4_FUNC(a, b, c, d, e, f, g, h, i, j) parse_ ## a ## _expression(struct math_string *str, MathEquation *eq, int *err) \ {\ struct math_token *token;\ MathExpression *left, *right, *exp;\ enum MATH_EXPRESSION_TYPE type;\ \ exp = parse_ ## b ## _expression(str, eq, err); \ if (exp == NULL) {\ return NULL;\ }\ \ for (;;) {\ token = my_get_token(str);\ if (token == NULL) {\ *err = MATH_ERROR_MEMORY;\ math_expression_free(exp);\ return NULL;\ }\ \ switch (token->type) {\ case MATH_TOKEN_TYPE_OPERATOR:\ switch (token->data.op) {\ case c:\ case e:\ case g:\ case i:\ right = parse_ ## b ## _expression(str, eq, err); \ if (right == NULL) {\ math_expression_free(exp);\ math_scanner_free_token(token);\ return NULL;\ }\ if (token->data.op == c) {\ type = d;\ } else if (token->data.op == e) {\ type = f;\ } else if (token->data.op == g) {\ type = h;\ } else if (token->data.op == i) {\ type = j;\ } else {\ type = 0; /* never reached */\ }\ left = exp;\ math_scanner_free_token(token); \ exp = math_binary_expression_new(type, eq, left, right, err); \ if (exp == NULL) {\ math_expression_free(left);\ math_expression_free(right);\ return NULL;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ break;\ default:\ unget_token(token);\ goto End;\ }\ }\ \ End:\ return exp;\ } ngraph-gtk-6.08.00/src/math/math_equation.h0000644000175000017500000001204513352667211015407 00000000000000/* * $Id: math_equation.h,v 1.8 2009-11-21 11:39:10 hito Exp $ * */ #ifndef MATH_EQUATION_HEADER #define MATH_EQUATION_HEADER typedef struct _math_equation MathEquation; typedef struct _math_parameter MathEquationParametar; typedef struct _math_array MathEquationArray; typedef struct _math_value MathValue; #include "math_error.h" #include "nhash.h" #define MATH_EQUATION_ARRAY_INDEX_MAX 65535 struct _math_value { double val; enum { MATH_VALUE_NORMAL = 0, MATH_VALUE_ERROR = 1, MATH_VALUE_NAN = 2, MATH_VALUE_UNDEF = 3, // MATH_VALUE_SYNTAX = 4, MATH_VALUE_CONT = 5, MATH_VALUE_BREAK = 6, MATH_VALUE_NONUM = 7, MATH_VALUE_MEOF = 8, MATH_VALUE_INTERRUPT = 9, } type; }; struct _math_array { int num, size; MathValue *data; }; #include "math_scanner.h" #include "math_expression.h" #include "math_function.h" #include "math_constant.h" struct _math_equation { NHASH constant, variable, array, function; int cnum, vnum, array_num, pos_func_num; NHASH local_variable, local_array; int local_vnum, local_array_num, func_def; MathValue *cbuf, *vbuf, *pos_func_buf; int stack_ofst, stack_end, vbuf_size; MathExpression *exp, *opt_exp, *const_def; MathEquationParametar *parameter; MathEquationArray *array_buf; union { struct { const char *pos; int line, ofst; } pos; struct { int arg_num; struct math_function_parameter *fprm; } func; int const_id; } err_info; void *user_data; }; struct _math_parameter { int type; int min_length, max_length; int *id, id_num, id_max; MathValue *data; int use_index; struct _math_parameter *next; }; enum { MATH_EQUATION_PARAMETAR_USE_ID, MATH_EQUATION_PARAMETAR_USE_INDEX, }; MathEquation *math_equation_new(void); MathEquation *math_equation_basic_new(void); void math_equation_free(MathEquation *eq); int math_equation_optimize(MathEquation *eq); int math_equation_parse(MathEquation *eq, const char *str); void math_equation_clear(MathEquation *eq); int math_equation_calculate(MathEquation *eq, MathValue *val); void math_equation_clear_variable(MathEquation *eq); MathEquationParametar *math_equation_get_parameter(MathEquation *eq, int type, int *err); int math_equation_use_parameter(MathEquation *eq, int type, int val); int math_equation_add_parameter(MathEquation *eq, int type, int min, int max, int use_index); int math_equation_set_parameter_data(MathEquation *eq, int type, MathValue *data); int math_equation_add_pos_func(MathEquation *eq, struct math_function_parameter *fprm); struct math_function_parameter *math_equation_start_user_func_definition(MathEquation *eq, const char *name); int math_equation_register_user_func_definition(MathEquation *eq, const char *name, MathExpression *exp); int math_equation_finish_user_func_definition(MathEquation *eq, int *vnum, int *anum); struct math_function_parameter *math_equation_add_func(MathEquation *eq, const char *name, struct math_function_parameter *prm); struct math_function_parameter *math_equation_get_func(MathEquation *eq, const char *name); void math_equation_remove_func(MathEquation *eq, const char *name); int math_equation_add_const_definition(MathEquation *eq, const char *name, MathExpression *exp, int *err); int math_equation_add_const(MathEquation *eq, const char *name, const MathValue *val); int math_equation_set_const_by_name(MathEquation *eq, const char *name, const MathValue *val); int math_equation_set_const(MathEquation *eq, int idx, const MathValue *val); int math_equation_get_const_by_name(MathEquation *eq, const char *name, MathValue *val); int math_equation_get_const(MathEquation *eq, int idx, MathValue *val); char *math_equation_get_const_name(MathEquation *eq, int idx); int math_equation_add_var(MathEquation *eq, const char *name); int math_equation_set_var(MathEquation *eq, int idx, const MathValue *val); int math_equation_check_var(MathEquation *eq, const char *name); int math_equation_get_var(MathEquation *eq, int idx, MathValue *val); int math_equation_check_array(MathEquation *eq, const char *name); int math_equation_add_array(MathEquation *eq, const char *name); int math_equation_set_array_val(MathEquation *eq, int array, int index, const MathValue *val); int math_equation_push_array_val(MathEquation *eq, int array, const MathValue *val); int math_equation_get_array_val(MathEquation *eq, int array, int index, MathValue *val); int math_equation_clear_array(MathEquation *eq, int array); MathEquationArray *math_equation_get_array(MathEquation *eq, int array); void math_equation_set_user_data(MathEquation *eq, void *user_data); void *math_equation_get_user_data(MathEquation *eq); int math_equation_check_const(MathEquation *eq, int *constant, int n); void math_equation_set_parse_error(MathEquation *eq, const char *ptr, const struct math_string *str); void math_equation_set_func_arg_num_error(MathEquation *eq, struct math_function_parameter *fprm, int arg_num); void math_equation_set_func_error(MathEquation *eq, struct math_function_parameter *fprm); void math_equation_set_const_error(MathEquation *eq, int id); #endif ngraph-gtk-6.08.00/src/math/Makefile.am0000644000175000017500000000212313070106167014423 00000000000000noinst_LTLIBRARIES = libmath.la libmath_la_SOURCES = math_function.c math_function.h math_operator.c \ math_operator.h math_constant.c math_constant.h \ math_expression.c math_parser.c math_scanner.h \ parse_bin_expression.h math_basic_function.c math_equation.c \ math_expression.h math_parser.h math_equation.h \ math_scanner.c math_error.h math_error.c EXTRA_DIST = math_operator.h.in math_operator.rb math_constant.h.in \ math_constant.rb math_function.h.in math_function.rb BUILT_SOURCES = math_operator.h math_operator.c math_constant.h \ math_constant.c math_function.h math_function.c math_operator.c: math_operator.h math_operator.h: math_operator.h.in math_operator.rb ruby math_operator.rb math_operator.h.in math_operator math_constant.c: math_constant.h math_constant.h: math_constant.h.in math_constant.rb ruby math_constant.rb math_constant.h.in math_constant math_function.c: math_function.h math_operator.h math_function.h: math_function.h.in math_function.rb ruby math_function.rb math_function.h.in math_function libmath_la_CFLAGS = $(GTK_CFLAGS) -I$(srcdir)/.. ngraph-gtk-6.08.00/src/math/math_expression.c0000644000175000017500000011534613352667211015764 00000000000000/* * $Id: math_expression.c,v 1.16 2010-02-24 00:52:44 hito Exp $ * */ #include "config.h" #include #include #include #include #include #include #include #include "nhash.h" #include "math_expression.h" #include "math_function.h" static int calc(MathExpression *exp, MathValue *val); static MathExpression *optimize(MathExpression *exp, int *err); #define CALC_EXPRESSION(e, v) \ ((e->type == MATH_EXPRESSION_TYPE_DOUBLE) ? \ ((v = e->u.value), 0) : \ calc(e, &v)) MathExpression * math_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, int *err) { MathExpression *exp; exp = g_malloc(sizeof(*exp)); if (exp == NULL) { if (err) { *err =MATH_ERROR_MEMORY; } return NULL; } exp->type = type; exp->next = NULL; exp->equation = eq; return exp; } MathExpression * math_constant_definition_expression_new(MathEquation *eq, char *name, MathExpression *exp, int *err) { MathExpression *cdef; int id; id = math_equation_get_const_by_name(eq, name, NULL); if (id >= 0) { /* already defined */ *err = MATH_ERROR_CONST_EXIST; math_equation_set_const_error(eq, id); return NULL; } cdef = math_expression_new(MATH_EXPRESSION_TYPE_CONST_DEF, eq, err); if (cdef == NULL) { return NULL; } cdef->u.const_def.operand = exp; if (math_equation_add_const_definition(eq, name, cdef, err) < 0) { g_free(cdef); return NULL; } return cdef; } MathExpression * math_function_expression_new(MathEquation *eq, const char *name, int *err) { MathExpression *func; struct math_function_parameter *prm; prm = math_equation_get_func(eq, name); if (prm && prm->base_usr == NULL) { /* embedded function */ return NULL; } func = math_expression_new(MATH_EXPRESSION_TYPE_FUNC, eq, err); if (func == NULL) return NULL; func->u.func.argc = 0; func->u.func.local_num = 0; func->u.func.exp = NULL; func->u.func.arg_list = NULL; func->u.func.fprm = math_equation_start_user_func_definition(eq, name); if (func->u.func.fprm == NULL) return NULL; return func; } static struct math_func_arg_list * create_arg(const char *name, enum MATH_FUNCTION_ARG_TYPE type) { struct math_func_arg_list *ptr; ptr = g_malloc(sizeof(*ptr)); if (ptr == NULL) { return NULL; } ptr->name = g_strdup(name); if (ptr->name == NULL) { g_free(ptr); return NULL; } ptr->next = NULL; ptr->type = type; return ptr; } static int register_arg(MathExpression *func, const char *arg_name, enum MATH_FUNCTION_ARG_TYPE type) { switch (type) { case MATH_FUNCTION_ARG_TYPE_DOUBLE: if (math_equation_check_var(func->equation, arg_name) >= 0) { /* the variable already exist */ return 1; } math_equation_add_var(func->equation, arg_name); break; case MATH_FUNCTION_ARG_TYPE_ARRAY: if (math_equation_check_array(func->equation, arg_name) >= 0) { /* the array already exist */ return 1; } math_equation_add_array(func->equation, arg_name); break; case MATH_FUNCTION_ARG_TYPE_PROC: return 1; } return 0; } int math_function_expression_add_arg(MathExpression *func, const char *arg_name, enum MATH_FUNCTION_ARG_TYPE type) { static struct math_func_arg_list *list; list = create_arg(arg_name, type); if (list == NULL) return 1; if (func->u.func.arg_list == NULL) { func->u.func.arg_list = list; } else { func->u.func.arg_last->next = list; } func->u.func.arg_last = list; return 0; } static int func_set_arg_buf(MathExpression *func) { static struct math_func_arg_list *list; int n, i, have_array; enum MATH_FUNCTION_ARG_TYPE *arg_type_buf; have_array = 0; list = func->u.func.arg_list; for (n = 0; list; n++) { switch (list->type) { case MATH_FUNCTION_ARG_TYPE_DOUBLE: break; case MATH_FUNCTION_ARG_TYPE_ARRAY: have_array = 1; break; case MATH_FUNCTION_ARG_TYPE_PROC: return 1; break; } list = list->next; } if (have_array) { arg_type_buf = g_malloc(sizeof(*arg_type_buf) * n); if (arg_type_buf == NULL) return 1; list = func->u.func.arg_list; for (i = 0; list; i++) { arg_type_buf[i] = list->type; if (register_arg(func, list->name, list->type)) { g_free(arg_type_buf); return 1; } list = list->next; } func->u.func.fprm->arg_type = arg_type_buf; } else { list = func->u.func.arg_list; for (i = 0; list; i++) { if (register_arg(func, list->name, list->type)) { return 1; } list = list->next; } } func->u.func.argc = n; func->u.func.fprm->argc = func->u.func.argc; return 0; } static void free_arg_list(struct math_func_arg_list *list) { static struct math_func_arg_list *next; while (list) { next = list->next; g_free(list->name); g_free(list); list = next; } } int math_function_expression_register_arg(MathExpression *func) { return func_set_arg_buf(func); } int math_function_expression_set_function(MathEquation *eq, MathExpression *func, const char *name, MathExpression *exp) { int anum, vnum; func->u.func.exp = exp; if (func->u.func.fprm == NULL) { return 1; } if (math_equation_register_user_func_definition(eq, name, func)) { return 1; } func->u.func.fprm->base_usr = func; func->u.func.fprm->opt_usr = NULL; math_equation_finish_user_func_definition(eq, &vnum, &anum); func->u.func.local_num = vnum; func->u.func.local_array_num = anum; return 0; } MathExpression * math_parameter_expression_new(MathEquation *eq, char *name, int *err) { int ofst, i, type, n, id, id_pre, id_post, index; MathExpression *exp; MathEquationParametar *prm; if (isalpha(name[1])) { type = name[1]; ofst = 2; } else { type = 0; ofst = 1; } prm = math_equation_get_parameter(eq, type, err); if (prm == NULL) { *err = MATH_ERROR_INVALID_PRM; return NULL; } for (i = ofst; isdigit(name[i]); i++); if (name[i] != '\0' || i == ofst) { *err = MATH_ERROR_INVALID_PRM; return NULL; } n = i - ofst; if (n < prm->min_length || n > prm->max_length) { *err = MATH_ERROR_INVALID_PRM; return NULL; } id_pre = id_post = 0; for (i = 0; i < prm->min_length - 1; i++) { id_pre *= 10; id_pre += name[ofst + i] - '0'; } for (; i < n; i++) { id_post *= 10; id_post += name[ofst + i] - '0'; } for (i = 0; i < prm->max_length - prm->min_length + 1; i++) { id_pre *= 10; } id = id_pre + id_post; index = math_equation_use_parameter(eq, type, id); if (index < 0) { *err = MATH_ERROR_MEMORY; return NULL; } exp = math_expression_new(MATH_EXPRESSION_TYPE_PRM, eq, err); if (exp == NULL) { return NULL; } exp->u.prm.type = type; exp->u.prm.prm = prm; exp->u.prm.id = id; exp->u.prm.index = (prm->use_index == MATH_EQUATION_PARAMETAR_USE_INDEX) ? index : id; return exp; } MathExpression * math_constant_expression_new(MathEquation *eq, const char *name, int *err) { MathExpression *exp; MathValue val; int i; i = math_equation_get_const_by_name(eq, name, &val); if (i < 0) { return NULL; } exp = math_expression_new(MATH_EXPRESSION_TYPE_CONST, eq, err); if (exp == NULL) { return NULL; } exp->u.index = i; return exp; } MathExpression * math_variable_expression_new(MathEquation *eq, const char *name, int *err) { MathExpression *exp; int i; exp = math_expression_new(MATH_EXPRESSION_TYPE_VARIABLE, eq, err); if (exp == NULL) { return NULL; } i = math_equation_add_var(eq, name); if (i < 0) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } exp->u.index = i; return exp; } MathExpression * math_array_expression_new(MathEquation *eq, const char *name, MathExpression *operand, int *err) { MathExpression *exp; int i; exp = math_expression_new(MATH_EXPRESSION_TYPE_ARRAY, eq, err); if (exp == NULL) { return NULL; } i = math_equation_add_array(eq, name); if (i < 0) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } exp->u.array.index = i; exp->u.array.operand = operand; return exp; } MathExpression * math_array_argument_expression_new(MathEquation *eq, const char *name, int *err) { MathExpression *exp; int i; exp = math_expression_new(MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT, eq, err); if (exp == NULL) { return NULL; } i = math_equation_add_array(eq, name); if (i < 0) { *err = MATH_ERROR_MEMORY; math_expression_free(exp); return NULL; } exp->u.array.index = i; return exp; } int math_function_get_arg_type_num(struct math_function_parameter *fprm) { if (fprm->argc < 0) { return - 1 - fprm->argc; } return fprm->argc; } static int check_argument(struct math_function_parameter *fprm, int argc, MathExpression **argv) { int i, arg_type_num; arg_type_num = math_function_get_arg_type_num(fprm); for (i = 0; i < argc; i++) { if (fprm->arg_type && i < arg_type_num && fprm->arg_type[i] == MATH_FUNCTION_ARG_TYPE_ARRAY) { if (argv[i]->type != MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT) { return 1; } } else if (argv[i]->type == MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT) { return 1; } } return 0; } MathExpression * math_func_call_expression_new(MathEquation *eq, struct math_function_parameter *fprm, int argc, MathExpression **argv, int pos_id, int *err) { MathExpression *exp; MathFunctionArgument *buf; if (check_argument(fprm, argc, argv)) { return NULL; } buf = NULL; if (argc > 0) { buf = g_malloc(sizeof(*buf) * argc); if (buf == NULL) { return NULL; } } exp = math_expression_new(MATH_EXPRESSION_TYPE_FUNC_CALL, eq, err); if (exp == NULL) { g_free(buf); return NULL; } exp->u.func_call.argv = argv; exp->u.func_call.argc = argc; exp->u.func_call.buf = buf; exp->u.func_call.pos_id = pos_id; exp->u.func_call.fprm = fprm; return exp; } MathExpression * math_binary_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *left, MathExpression *right, int *err) { MathExpression *exp; exp = math_expression_new(type, eq, err); if (exp == NULL) return NULL; exp->u.bin.left = left; exp->u.bin.right = right; return exp; } MathExpression * math_assign_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *left, MathExpression *right, enum MATH_OPERATOR_TYPE op, int *err) { MathExpression *exp; exp = math_expression_new(type, eq, err); if (exp == NULL) return NULL; exp->u.assign.op = op; exp->u.assign.left = left; exp->u.assign.right = right; return exp; } MathExpression * math_unary_expression_new(enum MATH_EXPRESSION_TYPE type, MathEquation *eq, MathExpression *operand, int *err) { MathExpression *exp; exp = math_expression_new(type, eq, err); if (exp == NULL) return NULL; exp->u.unary.operand = operand; return exp; } MathExpression * math_double_expression_new(MathEquation *eq, const MathValue *val, int *err) { MathExpression *exp; exp = math_expression_new(MATH_EXPRESSION_TYPE_DOUBLE, eq, err); if (exp == NULL) return NULL; exp->u.value = *val; return exp; } MathExpression * math_eoeq_expression_new(MathEquation *eq, int *err) { MathExpression *exp; exp = math_expression_new(MATH_EXPRESSION_TYPE_EOEQ, eq, err); return exp; } static void math_expression_free_sub(MathExpression *exp) { int i; if (exp == NULL) return; switch (exp->type) { case MATH_EXPRESSION_TYPE_OR: case MATH_EXPRESSION_TYPE_AND: case MATH_EXPRESSION_TYPE_EQ: case MATH_EXPRESSION_TYPE_NE: case MATH_EXPRESSION_TYPE_ADD: case MATH_EXPRESSION_TYPE_SUB: case MATH_EXPRESSION_TYPE_MUL: case MATH_EXPRESSION_TYPE_DIV: case MATH_EXPRESSION_TYPE_MOD: case MATH_EXPRESSION_TYPE_POW: case MATH_EXPRESSION_TYPE_GT: case MATH_EXPRESSION_TYPE_GE: case MATH_EXPRESSION_TYPE_LT: case MATH_EXPRESSION_TYPE_LE: math_expression_free(exp->u.bin.left); math_expression_free(exp->u.bin.right); break; case MATH_EXPRESSION_TYPE_ASSIGN: math_expression_free(exp->u.assign.left); math_expression_free(exp->u.assign.right); break; case MATH_EXPRESSION_TYPE_FUNC: math_expression_free(exp->u.func.exp); free_arg_list(exp->u.func.arg_list); break; case MATH_EXPRESSION_TYPE_CONST_DEF: math_expression_free(exp->u.const_def.operand); break; case MATH_EXPRESSION_TYPE_FUNC_CALL: for (i = 0; i < exp->u.func_call.argc; i++) { math_expression_free(exp->u.func_call.argv[i]); } g_free(exp->u.func_call.argv); g_free(exp->u.func_call.buf); break; case MATH_EXPRESSION_TYPE_MINUS: case MATH_EXPRESSION_TYPE_FACT: math_expression_free(exp->u.unary.operand); break; case MATH_EXPRESSION_TYPE_ARRAY: math_expression_free(exp->u.array.operand); break; case MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT: case MATH_EXPRESSION_TYPE_CONST: case MATH_EXPRESSION_TYPE_VARIABLE: break; case MATH_EXPRESSION_TYPE_DOUBLE: case MATH_EXPRESSION_TYPE_PRM: case MATH_EXPRESSION_TYPE_EOEQ: break; } g_free(exp); } void math_expression_free(MathExpression *exp) { MathExpression *next; while (exp) { next = exp->next; math_expression_free_sub(exp); exp = next; } } static double Fact_data[] = { 1.000000000000000e+00, 1.000000000000000e+00, 2.000000000000000e+00, 6.000000000000000e+00, 2.400000000000000e+01, 1.200000000000000e+02, 7.200000000000000e+02, 5.040000000000000e+03, 4.032000000000000e+04, 3.628800000000000e+05, 3.628800000000000e+06, 3.991680000000000e+07, 4.790016000000000e+08, 6.227020800000000e+09, 8.717829120000000e+10, 1.307674368000000e+12, 2.092278988800000e+13, 3.556874280960000e+14, 6.402373705728000e+15, 1.216451004088320e+17, 2.432902008176640e+18, 5.109094217170944e+19, 1.124000727777608e+21, 2.585201673888498e+22, 6.204484017332394e+23, 1.551121004333099e+25, 4.032914611266057e+26, 1.088886945041835e+28, 3.048883446117139e+29, 8.841761993739702e+30, 2.652528598121911e+32, 8.222838654177922e+33, 2.631308369336935e+35, 8.683317618811886e+36, 2.952327990396042e+38, 1.033314796638615e+40, 3.719933267899013e+41, 1.376375309122635e+43, 5.230226174666011e+44, 2.039788208119744e+46, 8.159152832478977e+47, 3.345252661316381e+49, 1.405006117752880e+51, 6.041526306337383e+52, 2.658271574788449e+54, 1.196222208654802e+56, 5.502622159812089e+57, 2.586232415111682e+59, 1.241391559253607e+61, 6.082818640342675e+62, 3.041409320171338e+64, 1.551118753287382e+66, 8.065817517094388e+67, 4.274883284060025e+69, 2.308436973392414e+71, 1.269640335365828e+73, 7.109985878048635e+74, 4.052691950487721e+76, 2.350561331282878e+78, 1.386831185456898e+80, 8.320987112741390e+81, 5.075802138772248e+83, 3.146997326038794e+85, 1.982608315404440e+87, 1.268869321858842e+89, 8.247650592082472e+90, 5.443449390774431e+92, 3.647111091818868e+94, 2.480035542436831e+96, 1.711224524281413e+98, 1.197857166996989e+100, 8.504785885678623e+101, 6.123445837688608e+103, 4.470115461512684e+105, 3.307885441519386e+107, 2.480914081139540e+109, 1.885494701666050e+111, 1.451830920282859e+113, 1.132428117820630e+115, 8.946182130782976e+116, 7.156945704626381e+118, 5.797126020747368e+120, 4.753643337012842e+122, 3.945523969720659e+124, 3.314240134565353e+126, 2.817104114380550e+128, 2.422709538367273e+130, 2.107757298379528e+132, 1.854826422573984e+134, 1.650795516090846e+136, 1.485715964481762e+138, 1.352001527678403e+140, 1.243841405464131e+142, 1.156772507081642e+144, 1.087366156656743e+146, 1.032997848823906e+148, 9.916779348709496e+149, 9.619275968248212e+151, 9.426890448883248e+153, 9.332621544394415e+155, 9.332621544394415e+157, 9.425947759838360e+159, 9.614466715035127e+161, 9.902900716486180e+163, 1.029901674514563e+166, 1.081396758240291e+168, 1.146280563734708e+170, 1.226520203196138e+172, 1.324641819451829e+174, 1.443859583202494e+176, 1.588245541522743e+178, 1.762952551090245e+180, 1.974506857221074e+182, 2.231192748659814e+184, 2.543559733472188e+186, 2.925093693493016e+188, 3.393108684451898e+190, 3.969937160808721e+192, 4.684525849754291e+194, 5.574585761207606e+196, 6.689502913449127e+198, 8.094298525273444e+200, 9.875044200833601e+202, 1.214630436702533e+205, 1.506141741511141e+207, 1.882677176888926e+209, 2.372173242880047e+211, 3.012660018457659e+213, 3.856204823625804e+215, 4.974504222477287e+217, 6.466855489220474e+219, 8.471580690878821e+221, 1.118248651196004e+224, 1.487270706090686e+226, 1.992942746161519e+228, 2.690472707318050e+230, 3.659042881952549e+232, 5.012888748274992e+234, 6.917786472619489e+236, 9.615723196941089e+238, 1.346201247571753e+241, 1.898143759076171e+243, 2.695364137888163e+245, 3.854370717180073e+247, 5.550293832739304e+249, 8.047926057471992e+251, 1.174997204390911e+254, 1.727245890454639e+256, 2.556323917872865e+258, 3.808922637630570e+260, 5.713383956445855e+262, 8.627209774233240e+264, 1.311335885683452e+267, 2.006343905095682e+269, 3.089769613847351e+271, 4.789142901463394e+273, 7.471062926282894e+275, 1.172956879426414e+278, 1.853271869493735e+280, 2.946702272495038e+282, 4.714723635992062e+284, 7.590705053947219e+286, 1.229694218739449e+289, 2.004401576545303e+291, 3.287218585534296e+293, 5.423910666131589e+295, 9.003691705778438e+297, 1.503616514864999e+300, 2.526075744973198e+302, 4.269068009004705e+304, }; #define FACT_MAX (sizeof(Fact_data) / sizeof(*Fact_data)) static double factorial(unsigned int n) { if (n < FACT_MAX) { return Fact_data[n]; } return HUGE_VAL; } static int call_func(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *val) { int i, n, arg_type_num; enum MATH_FUNCTION_ARG_TYPE *type; type = exp->fprm->arg_type; if (exp->fprm->argc > 0 && exp->argc != exp->fprm->argc) { val->type = MATH_VALUE_ERROR; return 1; } arg_type_num = math_function_get_arg_type_num(exp->fprm); n = exp->argc; for (i = 0; i < n; i++) { if (type && i < arg_type_num) { switch (type[i]) { case MATH_FUNCTION_ARG_TYPE_ARRAY: if (exp->argv[i]->type != MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT) { val->type = MATH_VALUE_ERROR; return 1; } exp->buf[i].idx = exp->argv[i]->u.array.index; break; case MATH_FUNCTION_ARG_TYPE_PROC: if (exp->argv[i]->type == MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT) { val->type = MATH_VALUE_ERROR; return 1; } exp->buf[i].exp = exp->argv[i]; break; case MATH_FUNCTION_ARG_TYPE_DOUBLE: if (exp->argv[i]->type == MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT) { val->type = MATH_VALUE_ERROR; return 1; } if (CALC_EXPRESSION(exp->argv[i], exp->buf[i].val)) return 1; break; } } else if (CALC_EXPRESSION(exp->argv[i], exp->buf[i].val)) { return 1; } } return exp->fprm->func(exp, eq, val); } static MathExpression * reduce_expression(MathExpression *exp, int *err) { #if 1 MathValue val; int r; MathExpression *rexp; r = math_expression_calculate(exp, &val); if (r) { math_expression_free(exp); *err = MATH_ERROR_CALCULATION; return NULL; } rexp = math_double_expression_new(exp->equation, &val, NULL); math_expression_free(exp); return rexp; #else return exp; #endif } static MathExpression * optimize_usr_function(MathExpression *exp,int *err) { MathExpression *new_exp; new_exp = math_expression_new(MATH_EXPRESSION_TYPE_FUNC, exp->equation, NULL); if (new_exp == NULL) return NULL; new_exp->u.func.argc = exp->u.func.argc; new_exp->u.func.local_num = exp->u.func.local_num; new_exp->u.func.local_array_num = exp->u.func.local_array_num; new_exp->u.func.exp = math_expression_optimize(exp->u.func.exp, err); new_exp->u.func.fprm = exp->u.func.fprm; new_exp->u.func.arg_list = NULL; if (new_exp->u.func.exp == NULL) { math_expression_free(new_exp); return NULL; } return new_exp; } static void free_arg_array(int argc, MathExpression **argv) { int i; for (i = 0; i < argc; i++) { math_expression_free(argv[i]); } g_free(argv); } static MathExpression * optimize_func_call(MathExpression *exp, int *err) { MathExpression **argv, *new_exp; int can_reduce, i, error; can_reduce = 1; argv = g_malloc0(exp->u.func_call.argc * sizeof(*argv)); if (argv == NULL) { return NULL; } error = 0; for (i = 0; i < exp->u.func_call.argc; i++) { argv[i] = optimize(exp->u.func_call.argv[i], err); if (argv[i] == NULL) { error = 1; } else if (argv[i]->type != MATH_EXPRESSION_TYPE_DOUBLE) { can_reduce = 0; } } if (error) { free_arg_array(exp->u.func_call.argc, argv); return NULL; } new_exp = math_func_call_expression_new(exp->equation, exp->u.func_call.fprm, exp->u.func_call.argc, argv, exp->u.func_call.pos_id, &error); if (new_exp == NULL) { free_arg_array(exp->u.func_call.argc, argv); return NULL; } if (can_reduce && ! exp->u.func_call.fprm->side_effect) { new_exp = reduce_expression(new_exp, err); } return new_exp; } static MathExpression * optimize_or_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_binary_expression_new(exp->type, exp->equation, NULL, NULL, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.bin.left, err); new_exp->u.bin.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.bin.right, err); new_exp->u.bin.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } else if (left->type == MATH_EXPRESSION_TYPE_DOUBLE) { if (left->u.value.val == 0.0) { math_expression_free(new_exp); new_exp = right; } else { new_exp->u.bin.left = NULL; math_expression_free(new_exp); new_exp = left; } } return new_exp; } static MathExpression * optimize_and_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_binary_expression_new(exp->type, exp->equation, NULL, NULL, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.bin.left, err); new_exp->u.bin.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.bin.right, err); new_exp->u.bin.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } else if (left->type == MATH_EXPRESSION_TYPE_DOUBLE) { if (left->u.value.val == 0.0) { new_exp->u.bin.left = NULL; math_expression_free(new_exp); new_exp = left; } else { new_exp->u.bin.right = NULL; math_expression_free(new_exp); new_exp = right; } } return new_exp; } static MathExpression * optimize_bin_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_binary_expression_new(exp->type, exp->equation, NULL, NULL, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.bin.left, err); new_exp->u.bin.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.bin.right, err); new_exp->u.bin.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } return new_exp; } static MathExpression * optimize_assign_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_assign_expression_new(exp->type, exp->equation, NULL, NULL, exp->u.assign.op, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.assign.left, err); new_exp->u.assign.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.assign.right, err); new_exp->u.assign.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } return new_exp; } static MathExpression * optimize_mul_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_binary_expression_new(exp->type, exp->equation, NULL, NULL, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.bin.left, err); new_exp->u.bin.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.bin.right, err); new_exp->u.bin.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } else if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && left->u.value.val == 1.0) { new_exp->u.bin.right = NULL; math_expression_free(new_exp); new_exp = right; } else if (right->type == MATH_EXPRESSION_TYPE_DOUBLE && right->u.value.val == 1.0) { new_exp->u.bin.left = NULL; math_expression_free(new_exp); new_exp = left; } return new_exp; } static MathExpression * optimize_div_expression(MathExpression *exp, int *err) { MathExpression *left, *right, *new_exp; new_exp = math_binary_expression_new(exp->type, exp->equation, NULL, NULL, err); if (new_exp == NULL) return NULL; left = optimize(exp->u.bin.left, err); new_exp->u.bin.left = left; if (left == NULL) { math_expression_free(new_exp); return NULL; } right = optimize(exp->u.bin.right, err); new_exp->u.bin.right = right; if (right == NULL) { math_expression_free(new_exp); return NULL; } if (left->type == MATH_EXPRESSION_TYPE_DOUBLE && right->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } else if (right->type == MATH_EXPRESSION_TYPE_DOUBLE) { if (right->u.value.val == 1.0) { new_exp->u.bin.left = NULL; math_expression_free(new_exp); new_exp = left; } else if (right->u.value.val == 0.0) { right->u.value.val = right->u.value.val; new_exp->type = MATH_EXPRESSION_TYPE_DIV; } else { right->u.value.val = 1.0 / right->u.value.val; new_exp->type = MATH_EXPRESSION_TYPE_MUL; } } return new_exp; } static MathExpression * optimize_una_expression(MathExpression *exp, int *err) { MathExpression *operand, *new_exp; new_exp = math_unary_expression_new(exp->type, exp->equation, NULL, err); if (new_exp == NULL) return NULL; operand = optimize(exp->u.unary.operand, err); new_exp->u.unary.operand = operand; if (operand == NULL) { math_expression_free(new_exp); return NULL; } if (operand->type == MATH_EXPRESSION_TYPE_DOUBLE) { new_exp = reduce_expression(new_exp, err); } return new_exp; } static MathExpression * optimize_array_expression(MathExpression *exp, int *err) { MathExpression *operand, *new_exp; new_exp = math_expression_new(exp->type, exp->equation, err); if (new_exp == NULL) return NULL; operand = optimize(exp->u.array.operand, err); new_exp->u.array.operand = operand; new_exp->u.array.index = exp->u.array.index; if (operand == NULL) { math_expression_free(new_exp); return NULL; } return new_exp; } static MathExpression * optimize(MathExpression *exp, int *err) { MathExpression *new_exp; switch (exp->type) { case MATH_EXPRESSION_TYPE_OR: new_exp = optimize_or_expression(exp, err); break; case MATH_EXPRESSION_TYPE_AND: new_exp = optimize_and_expression(exp, err); break; case MATH_EXPRESSION_TYPE_EQ: case MATH_EXPRESSION_TYPE_NE: case MATH_EXPRESSION_TYPE_ADD: case MATH_EXPRESSION_TYPE_SUB: case MATH_EXPRESSION_TYPE_MOD: case MATH_EXPRESSION_TYPE_POW: case MATH_EXPRESSION_TYPE_GT: case MATH_EXPRESSION_TYPE_GE: case MATH_EXPRESSION_TYPE_LT: case MATH_EXPRESSION_TYPE_LE: new_exp = optimize_bin_expression(exp, err); break; case MATH_EXPRESSION_TYPE_ASSIGN: new_exp = optimize_assign_expression(exp, err); break; case MATH_EXPRESSION_TYPE_MUL: new_exp = optimize_mul_expression(exp, err); break; case MATH_EXPRESSION_TYPE_DIV: new_exp = optimize_div_expression(exp, err); break; case MATH_EXPRESSION_TYPE_MINUS: case MATH_EXPRESSION_TYPE_FACT: new_exp = optimize_una_expression(exp, err); break; case MATH_EXPRESSION_TYPE_FUNC_CALL: new_exp = optimize_func_call(exp, err); break; case MATH_EXPRESSION_TYPE_FUNC: new_exp = optimize_usr_function(exp, err); break; case MATH_EXPRESSION_TYPE_DOUBLE: new_exp = math_double_expression_new(exp->equation, &exp->u.value, err); break; case MATH_EXPRESSION_TYPE_CONST: new_exp = math_expression_new(exp->type, exp->equation, err); if (new_exp) { new_exp->u.index = exp->u.index; new_exp = reduce_expression(new_exp, err); } break; case MATH_EXPRESSION_TYPE_VARIABLE: new_exp = math_expression_new(exp->type, exp->equation, err); if (new_exp) new_exp->u.index = exp->u.index; break; case MATH_EXPRESSION_TYPE_PRM: new_exp = math_expression_new(exp->type, exp->equation, err); if (new_exp) { new_exp->u.prm.type = exp->u.prm.type; new_exp->u.prm.index = exp->u.prm.index; new_exp->u.prm.prm = exp->u.prm.prm; new_exp->u.prm.id = exp->u.prm.id; } break; case MATH_EXPRESSION_TYPE_EOEQ: new_exp = math_eoeq_expression_new(exp->equation, err); break; case MATH_EXPRESSION_TYPE_ARRAY: new_exp = optimize_array_expression(exp, err); break; case MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT: new_exp = math_expression_new(exp->type, exp->equation, err); if (new_exp) { new_exp->u.array.index = exp->u.array.index; } break; default: new_exp = NULL; /* never reached */ } return new_exp; } MathExpression * math_expression_optimize(MathExpression *exp, int *err) { MathExpression *prev, *rexp, *top; *err = MATH_ERROR_NONE; top = prev = NULL; while (exp) { rexp = optimize(exp, err); if (rexp == NULL || *err != MATH_ERROR_NONE) { math_expression_free(top); return NULL; } if (prev) { prev->next = rexp; } if (top == NULL) { top = rexp; } prev = rexp; exp = exp->next; } return top; } static int set_val_to_array(MathExpression *exp, MathValue *val, enum MATH_OPERATOR_TYPE op) { MathValue v; int i; if (CALC_EXPRESSION(exp->u.array.operand, v)) { return 1; } i = v.val; if (op == MATH_OPERATOR_TYPE_ASSIGN) { if (math_equation_set_array_val(exp->equation, exp->u.array.index, i, val)) { return 1; } } else { if (math_equation_get_array_val(exp->equation, exp->u.array.index, i, &v)) { return 1; } switch (op) { case MATH_OPERATOR_TYPE_POW_ASSIGN: v.val = pow(v.val, val->val); break; case MATH_OPERATOR_TYPE_MOD_ASSIGN: v.val = fmod(v.val, val->val); break; case MATH_OPERATOR_TYPE_DIV_ASSIGN: v.val /= val->val; break; case MATH_OPERATOR_TYPE_MUL_ASSIGN: v.val *= val->val; break; case MATH_OPERATOR_TYPE_PLUS_ASSIGN: v.val += val->val; break; case MATH_OPERATOR_TYPE_MINUS_ASSIGN: v.val -= val->val; break; default: /* never reached */ v.val = 0; } if (math_equation_set_array_val(exp->equation, exp->u.array.index, i, &v)) { return 1; } *val = v; } return 0; } #define MATH_CHECK_VAL(rval, v) if (v.type != MATH_VALUE_NORMAL) { \ *rval = v; \ break; \ } static int calc(MathExpression *exp, MathValue *val) { MathValue left, right, operand; val->type = MATH_VALUE_NORMAL; switch (exp->type) { case MATH_EXPRESSION_TYPE_OR: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (left.type == MATH_VALUE_NORMAL && left.val) { *val = left; break; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } *val = right; break; case MATH_EXPRESSION_TYPE_AND: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (left.type != MATH_VALUE_NORMAL || ! left.val) { *val = left; break; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } *val = right; break; case MATH_EXPRESSION_TYPE_EQ: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val == right.val); break; case MATH_EXPRESSION_TYPE_NE: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val != right.val); break; case MATH_EXPRESSION_TYPE_ADD: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = left.val + right.val; break; case MATH_EXPRESSION_TYPE_SUB: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = left.val - right.val; break; case MATH_EXPRESSION_TYPE_MUL: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = left.val * right.val; break; case MATH_EXPRESSION_TYPE_DIV: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); if (right.val == 0.0) { if (left.val < 0) { val->val = - HUGE_VAL; } else if (left.val > 0) { val->val = HUGE_VAL; } else { val->val = 0; } val->type = MATH_VALUE_NAN; } else { val->val = left.val / right.val; } break; case MATH_EXPRESSION_TYPE_MOD: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); if (right.val == 0.0) { return 1; } val->val = fmod(left.val, right.val); break; case MATH_EXPRESSION_TYPE_POW: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = pow(left.val, right.val); break; case MATH_EXPRESSION_TYPE_GT: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val > right.val); break; case MATH_EXPRESSION_TYPE_GE: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val >= right.val); break; case MATH_EXPRESSION_TYPE_LT: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val < right.val); break; case MATH_EXPRESSION_TYPE_LE: if (CALC_EXPRESSION(exp->u.bin.left, left)) { return 1; } if (CALC_EXPRESSION(exp->u.bin.right, right)) { return 1; } MATH_CHECK_VAL(val, left); MATH_CHECK_VAL(val, right); val->val = (left.val <= right.val); break; case MATH_EXPRESSION_TYPE_MINUS: if (CALC_EXPRESSION(exp->u.unary.operand, operand)) { return 1; } MATH_CHECK_VAL(val, operand); val->val = - operand.val; break; case MATH_EXPRESSION_TYPE_FACT: if (CALC_EXPRESSION(exp->u.unary.operand, operand)) { return 1; } MATH_CHECK_VAL(val, operand); if (operand.val < 0 || operand.val >= FACT_MAX) { return 1; } val->val = factorial(operand.val); break; case MATH_EXPRESSION_TYPE_FUNC_CALL: if (call_func(&exp->u.func_call, exp->equation, val)) return 1; break; case MATH_EXPRESSION_TYPE_DOUBLE: *val = exp->u.value; break; case MATH_EXPRESSION_TYPE_CONST: if (math_equation_get_const(exp->equation, exp->u.index, val)) return 1; break; case MATH_EXPRESSION_TYPE_VARIABLE: if (math_equation_get_var(exp->equation, exp->u.index, val)) return 1; break; case MATH_EXPRESSION_TYPE_ASSIGN: if (CALC_EXPRESSION(exp->u.assign.right, right)) { return 1; } if (exp->u.assign.left->type == MATH_EXPRESSION_TYPE_VARIABLE) { if (math_equation_set_var(exp->equation, exp->u.assign.left->u.index, &right)) { return 1; } } else { if (set_val_to_array(exp->u.assign.left, &right, exp->u.assign.op)) { return 1; } } *val = right; break; case MATH_EXPRESSION_TYPE_ARRAY: if (CALC_EXPRESSION(exp->u.array.operand, operand)) { return 1; } if (math_equation_get_array_val(exp->equation, exp->u.array.index, operand.val, val)) { return 1; } break; case MATH_EXPRESSION_TYPE_PRM: if (exp->u.prm.prm->data == NULL) { return 1; } *val = exp->u.prm.prm->data[exp->u.prm.index]; break; case MATH_EXPRESSION_TYPE_EOEQ: val->val = 0; break; case MATH_EXPRESSION_TYPE_ARRAY_ARGUMENT: return 1; case MATH_EXPRESSION_TYPE_FUNC: case MATH_EXPRESSION_TYPE_CONST_DEF: /* never reached */ val->val = 0; break; } return 0; } int math_expression_calculate(MathExpression *exp, MathValue *val) { MathExpression *ptr; MathValue v; if (exp == NULL) { return 1; } ptr = exp; while (ptr) { v.val = 0; v.type = MATH_VALUE_NORMAL; if (calc(ptr, &v)) { *val = v; if (val->type != MATH_VALUE_INTERRUPT) { val->type = MATH_VALUE_ERROR; } return 1; } ptr = ptr->next; } *val = v; return 0; } ngraph-gtk-6.08.00/src/math/Makefile.in0000644000175000017500000010056713367273154014461 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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/math ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = LTLIBRARIES = $(noinst_LTLIBRARIES) libmath_la_LIBADD = am_libmath_la_OBJECTS = libmath_la-math_function.lo \ libmath_la-math_operator.lo libmath_la-math_constant.lo \ libmath_la-math_expression.lo libmath_la-math_parser.lo \ libmath_la-math_basic_function.lo libmath_la-math_equation.lo \ libmath_la-math_scanner.lo libmath_la-math_error.lo libmath_la_OBJECTS = $(am_libmath_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 = libmath_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(libmath_la_CFLAGS) \ $(CFLAGS) $(AM_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__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libmath_la-math_basic_function.Plo \ ./$(DEPDIR)/libmath_la-math_constant.Plo \ ./$(DEPDIR)/libmath_la-math_equation.Plo \ ./$(DEPDIR)/libmath_la-math_error.Plo \ ./$(DEPDIR)/libmath_la-math_expression.Plo \ ./$(DEPDIR)/libmath_la-math_function.Plo \ ./$(DEPDIR)/libmath_la-math_operator.Plo \ ./$(DEPDIR)/libmath_la-math_parser.Plo \ ./$(DEPDIR)/libmath_la-math_scanner.Plo 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 = $(libmath_la_SOURCES) DIST_SOURCES = $(libmath_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ noinst_LTLIBRARIES = libmath.la libmath_la_SOURCES = math_function.c math_function.h math_operator.c \ math_operator.h math_constant.c math_constant.h \ math_expression.c math_parser.c math_scanner.h \ parse_bin_expression.h math_basic_function.c math_equation.c \ math_expression.h math_parser.h math_equation.h \ math_scanner.c math_error.h math_error.c EXTRA_DIST = math_operator.h.in math_operator.rb math_constant.h.in \ math_constant.rb math_function.h.in math_function.rb BUILT_SOURCES = math_operator.h math_operator.c math_constant.h \ math_constant.c math_function.h math_function.c libmath_la_CFLAGS = $(GTK_CFLAGS) -I$(srcdir)/.. all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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) --gnu src/math/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/math/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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}; \ } libmath.la: $(libmath_la_OBJECTS) $(libmath_la_DEPENDENCIES) $(EXTRA_libmath_la_DEPENDENCIES) $(AM_V_CCLD)$(libmath_la_LINK) $(libmath_la_OBJECTS) $(libmath_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_basic_function.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_constant.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_equation.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_error.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_expression.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_function.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_operator.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_parser.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libmath_la-math_scanner.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .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 $@ $< libmath_la-math_function.lo: math_function.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_function.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_function.Tpo -c -o libmath_la-math_function.lo `test -f 'math_function.c' || echo '$(srcdir)/'`math_function.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_function.Tpo $(DEPDIR)/libmath_la-math_function.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_function.c' object='libmath_la-math_function.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_function.lo `test -f 'math_function.c' || echo '$(srcdir)/'`math_function.c libmath_la-math_operator.lo: math_operator.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_operator.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_operator.Tpo -c -o libmath_la-math_operator.lo `test -f 'math_operator.c' || echo '$(srcdir)/'`math_operator.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_operator.Tpo $(DEPDIR)/libmath_la-math_operator.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_operator.c' object='libmath_la-math_operator.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_operator.lo `test -f 'math_operator.c' || echo '$(srcdir)/'`math_operator.c libmath_la-math_constant.lo: math_constant.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_constant.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_constant.Tpo -c -o libmath_la-math_constant.lo `test -f 'math_constant.c' || echo '$(srcdir)/'`math_constant.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_constant.Tpo $(DEPDIR)/libmath_la-math_constant.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_constant.c' object='libmath_la-math_constant.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_constant.lo `test -f 'math_constant.c' || echo '$(srcdir)/'`math_constant.c libmath_la-math_expression.lo: math_expression.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_expression.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_expression.Tpo -c -o libmath_la-math_expression.lo `test -f 'math_expression.c' || echo '$(srcdir)/'`math_expression.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_expression.Tpo $(DEPDIR)/libmath_la-math_expression.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_expression.c' object='libmath_la-math_expression.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_expression.lo `test -f 'math_expression.c' || echo '$(srcdir)/'`math_expression.c libmath_la-math_parser.lo: math_parser.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_parser.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_parser.Tpo -c -o libmath_la-math_parser.lo `test -f 'math_parser.c' || echo '$(srcdir)/'`math_parser.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_parser.Tpo $(DEPDIR)/libmath_la-math_parser.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_parser.c' object='libmath_la-math_parser.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_parser.lo `test -f 'math_parser.c' || echo '$(srcdir)/'`math_parser.c libmath_la-math_basic_function.lo: math_basic_function.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_basic_function.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_basic_function.Tpo -c -o libmath_la-math_basic_function.lo `test -f 'math_basic_function.c' || echo '$(srcdir)/'`math_basic_function.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_basic_function.Tpo $(DEPDIR)/libmath_la-math_basic_function.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_basic_function.c' object='libmath_la-math_basic_function.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_basic_function.lo `test -f 'math_basic_function.c' || echo '$(srcdir)/'`math_basic_function.c libmath_la-math_equation.lo: math_equation.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_equation.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_equation.Tpo -c -o libmath_la-math_equation.lo `test -f 'math_equation.c' || echo '$(srcdir)/'`math_equation.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_equation.Tpo $(DEPDIR)/libmath_la-math_equation.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_equation.c' object='libmath_la-math_equation.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_equation.lo `test -f 'math_equation.c' || echo '$(srcdir)/'`math_equation.c libmath_la-math_scanner.lo: math_scanner.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_scanner.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_scanner.Tpo -c -o libmath_la-math_scanner.lo `test -f 'math_scanner.c' || echo '$(srcdir)/'`math_scanner.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_scanner.Tpo $(DEPDIR)/libmath_la-math_scanner.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_scanner.c' object='libmath_la-math_scanner.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_scanner.lo `test -f 'math_scanner.c' || echo '$(srcdir)/'`math_scanner.c libmath_la-math_error.lo: math_error.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -MT libmath_la-math_error.lo -MD -MP -MF $(DEPDIR)/libmath_la-math_error.Tpo -c -o libmath_la-math_error.lo `test -f 'math_error.c' || echo '$(srcdir)/'`math_error.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libmath_la-math_error.Tpo $(DEPDIR)/libmath_la-math_error.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='math_error.c' object='libmath_la-math_error.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libmath_la_CFLAGS) $(CFLAGS) -c -o libmath_la-math_error.lo `test -f 'math_error.c' || echo '$(srcdir)/'`math_error.c 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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-am all-am: Makefile $(LTLIBRARIES) installdirs: install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) clean: clean-am clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/libmath_la-math_basic_function.Plo -rm -f ./$(DEPDIR)/libmath_la-math_constant.Plo -rm -f ./$(DEPDIR)/libmath_la-math_equation.Plo -rm -f ./$(DEPDIR)/libmath_la-math_error.Plo -rm -f ./$(DEPDIR)/libmath_la-math_expression.Plo -rm -f ./$(DEPDIR)/libmath_la-math_function.Plo -rm -f ./$(DEPDIR)/libmath_la-math_operator.Plo -rm -f ./$(DEPDIR)/libmath_la-math_parser.Plo -rm -f ./$(DEPDIR)/libmath_la-math_scanner.Plo -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 -f ./$(DEPDIR)/libmath_la-math_basic_function.Plo -rm -f ./$(DEPDIR)/libmath_la-math_constant.Plo -rm -f ./$(DEPDIR)/libmath_la-math_equation.Plo -rm -f ./$(DEPDIR)/libmath_la-math_error.Plo -rm -f ./$(DEPDIR)/libmath_la-math_expression.Plo -rm -f ./$(DEPDIR)/libmath_la-math_function.Plo -rm -f ./$(DEPDIR)/libmath_la-math_operator.Plo -rm -f ./$(DEPDIR)/libmath_la-math_parser.Plo -rm -f ./$(DEPDIR)/libmath_la-math_scanner.Plo -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: all check install install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles 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 math_operator.c: math_operator.h math_operator.h: math_operator.h.in math_operator.rb ruby math_operator.rb math_operator.h.in math_operator math_constant.c: math_constant.h math_constant.h: math_constant.h.in math_constant.rb ruby math_constant.rb math_constant.h.in math_constant math_function.c: math_function.h math_operator.h math_function.h: math_function.h.in math_function.rb ruby math_function.rb math_function.h.in math_function # 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: ngraph-gtk-6.08.00/src/ogra2prn.c0000644000175000017500000001277713070106167013354 00000000000000/* * $Id: ogra2prn.c,v 1.8 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include "object.h" #include "nstring.h" #include "ioutil.h" #include "shell.h" #define NAME "gra2prn" #define PARENT "gra2" #define OVERSION "1.00.00" #define ERRFOPEN 100 static char *gra2perrorlist[]={ "I/O error: open file", }; #define ERRNUM (sizeof(gra2perrorlist) / sizeof(*gra2perrorlist)) struct gra2plocal { char *fname; FILE *fil; }; static int gra2pinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct gra2plocal *gra2plocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if ((gra2plocal=g_malloc(sizeof(struct gra2plocal)))==NULL) goto errexit; if (_putobj(obj,"_local",inst,gra2plocal)) goto errexit; gra2plocal->fname=NULL; gra2plocal->fil=NULL; return 0; errexit: g_free(gra2plocal); return 1; } static int gra2pdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct gra2plocal *gra2plocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&gra2plocal); if (gra2plocal->fname!=NULL) g_free(gra2plocal->fname); if (gra2plocal->fil!=NULL) fclose(gra2plocal->fil); return 0; } static FILE * mytempfile(char *pfx, char **name) { int fd; fd = n_mkstemp(NULL, pfx, name); if (fd < 0) { return NULL; } return fdopen(fd, "w+"); } static int gra2p_output(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct gra2plocal *gra2plocal; struct objlist *sys; char code; int *cpar; int i; char *cstr; char *graf,*sname,*sver; char *pfx; GString *s; char *driver,*option,*prn; struct nshell *nshell; gra2plocal=(struct gra2plocal *)argv[2]; code=*(char *)(argv[3]); cpar=(int *)argv[4]; cstr=argv[5]; if (code=='I') { if (gra2plocal->fil) fclose(gra2plocal->fil); gra2plocal->fil=NULL; if ((sys=getobject("system"))==NULL) return 1; if (getobj(sys,"temp_prefix",0,0,NULL,&pfx)) return 1; if (gra2plocal->fname) g_free(gra2plocal->fname); gra2plocal->fil = mytempfile(pfx, &gra2plocal->fname); if (gra2plocal->fil == NULL) { error2(obj,ERRFOPEN,gra2plocal->fname); g_free(gra2plocal->fname); gra2plocal->fname = NULL; return 1; } if (getobj(sys,"name",0,0,NULL,&sname)) return 1; if (getobj(sys,"version",0,0,NULL,&sver)) return 1; if (getobj(sys,"GRAF",0,0,NULL,&graf)) return 1; fprintf(gra2plocal->fil,"%s\n",graf); fprintf(gra2plocal->fil,"%%Creator: %s ver %s\n",sname,sver); } if (gra2plocal->fil) { fputc(code,gra2plocal->fil); if (cpar[0]==-1) { for (i=0;cstr[i]!='\0';i++) { fputc(cstr[i],gra2plocal->fil); } } else { fprintf(gra2plocal->fil,",%d",cpar[0]); for (i=1;i<=cpar[0];i++) { fprintf(gra2plocal->fil,",%d",cpar[i]); } } fputc('\n',gra2plocal->fil); if (code=='E') { fclose(gra2plocal->fil); gra2plocal->fil=NULL; _getobj(obj,"driver",inst,&driver); _getobj(obj,"option",inst,&option); _getobj(obj,"prn",inst,&prn); s = g_string_sized_new(256); if (s == NULL) { goto errexit; } if (driver) { g_string_append(s, driver); } g_string_append_c(s,' '); if (option) { g_string_append(s,option); } g_string_append(s," '"); if (gra2plocal->fname) { g_string_append(s, gra2plocal->fname); } g_string_append(s,"' "); if (prn) { g_string_append(s,prn); } nshell = newshell(); if (nshell == NULL) { g_string_free(s, TRUE); goto errexit; } ngraphenvironment(nshell); cmdexecute(nshell, s->str); delshell(nshell); g_string_free(s, TRUE); g_unlink(gra2plocal->fname); g_free(gra2plocal->fname); gra2plocal->fname=NULL; } } return 0; errexit: if (gra2plocal->fname) { g_unlink(gra2plocal->fname); g_free(gra2plocal->fname); gra2plocal->fname = NULL; } return 1; } static struct objtable gra2p[] = { {"init",NVFUNC,NEXEC,gra2pinit,NULL,0}, {"done",NVFUNC,NEXEC,gra2pdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"driver",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"option",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"prn",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"_local",NPOINTER,0,NULL,NULL,0}, {"_output",NVFUNC,0,gra2p_output,NULL,0}, }; #define TBLNUM (sizeof(gra2p) / sizeof(*gra2p)) void * addgra2prn(void) /* addgra2prn() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,gra2p,ERRNUM,gra2perrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/odraw.c0000644000175000017500000002706213337723153012735 00000000000000/* * $Id: odraw.c,v 1.14 2009-11-16 09:13:04 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include "object.h" #include "ioutil.h" #include "spline.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "nstring.h" #include "mathfn.h" #define NAME "draw" #define PARENT "object" #define OVERSION "1.00.00" #define ERRILGC 100 #define ERRGCOPEN 101 static char *drawerrorlist[]={ "illegal graphics context", "graphics context is not opened", }; #define ERRNUM (sizeof(drawerrorlist) / sizeof(*drawerrorlist)) char *pathchar[]={ N_("unchange"), N_("full"), N_("relative"), N_("base"), NULL, }; char *joinchar[]={ N_("miter"), N_("round"), N_("bevel"), NULL }; char *fontchar[]={ "Sans-serif", "Serif", "Monospace", NULL }; char *arrowchar[]={ N_("none"), N_("end"), N_("begin"), N_("both"), NULL }; char *marker_type_char[]={ N_("none"), N_("arrow"), N_("wave"), N_("mark"), N_("bar"), NULL }; char *intpchar[]={ N_("spline"), N_("spline_close"), N_("bspline"), N_("bspline_close"), NULL }; static int drawinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int clip,redrawf,alpha; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; clip=TRUE; redrawf=TRUE; alpha=255; if (_putobj(obj,"clip",inst,&clip)) return 1; if (_putobj(obj,"redraw_flag",inst,&redrawf)) return 1; if (_putobj(obj,"A",inst,&alpha)) return 1; return 0; } static int drawdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int drawdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC,hidden; GC=*(int *)(argv[2]); if (GRAopened(GC)<0) { error3(obj,ERRGCOPEN,GC); return 1; } _getobj(obj,"hidden",inst,&hidden); if (hidden) GC=-1; if (_putobj(obj,"GC",inst,&GC)) return 1; return 0; } int pathsave(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array,*array2; int anum; char **adata; int i,j; char *argv2[4]; char *file,*name,*valstr; int path; GString *s; array=(struct narray *)argv[2]; anum=arraynum(array); adata=arraydata(array); for (j=0;jstr); g_string_append_c(s, '\t'); g_string_append(s, argv[0]); g_string_append(s, "::file="); valstr = getvaluestr(obj, "file", &name, FALSE, TRUE); if (valstr == NULL) { g_free(s); goto errexit; } g_string_append(s, valstr); g_free(valstr); g_string_append_c(s, '\n'); g_free(name); g_free(rval->str); rval->str = g_string_free(s, FALSE); return 0; errexit: g_free(name); g_free(rval->str); rval->str=NULL; return 1; } int clear_bbox(struct objlist *obj, N_VALUE *inst) { struct narray *array; if (inst == NULL) return 1; if (_getobj(obj, "bbox", inst, &array)) return 1; arrayfree(array); if (_putobj(obj, "bbox", inst, NULL)) return 1; return 0; } int put_hsb_color(struct objlist *obj, N_VALUE *inst, int argc, char **argv, char *format) { double h, s, b; int rr, gg, bb; char buf[64]; h = * (double *) argv[2]; s = * (double *) argv[3]; b = * (double *) argv[4]; if (h < 0) { h = 0; } else if (h > 1) { h = 1; } if (s < 0) { s = 0; } else if (s > 1) { s = 1; } if (b < 0) { b = 0; } else if (b > 1) { b = 1; } HSB2RGB(h, s, b, &rr, &gg, &bb); snprintf(buf, sizeof(buf), format, 'R'); _putobj(obj, buf, inst, &rr); snprintf(buf, sizeof(buf), format, 'G'); _putobj(obj, buf, inst, &gg); snprintf(buf, sizeof(buf), format, 'B'); _putobj(obj, buf, inst, &bb); return 0; } int put_fill_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "fill_%c"); } int put_stroke_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "stroke_%c"); } int put_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "%c"); } int put_hsb2(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return put_hsb_color(obj, inst, argc, argv, "%c2"); } static int curve_expand(double c[], double x0, double y0, diffunc gdiff, intpfunc gintpf, struct narray *expand_points) { double d, dx, dy, ddx, ddy, dd, x, y; int gx2, gy2; d = 0; while (d < 1) { gdiff(d, c, &dx, &dy, &ddx, &ddy, NULL); if (fabs(dx) + fabs(ddx) / 3 <= 1E-100) { dx = 1; } else { dx = sqrt(fabs(2 / (fabs(dx) + fabs(ddx) / 3))); } if (fabs(dy) + fabs(ddy) / 3 <= 1E-100) { dy = 1; } else { dy = sqrt(fabs(2 / (fabs(dy) + fabs(ddy) / 3))); } dd = (dx < dy) ? dx : dy; d += dd; if (d > 1) { d = 1; } gintpf(d, c, x0, y0, &x, &y, NULL); gx2 = nround(x); gy2 = nround(y); arrayadd(expand_points, &gx2); arrayadd(expand_points, &gy2); } return TRUE; } int curve_expand_points(int *pdata, int num, int intp, struct narray *expand_points) { int i, j, bsize, spcond, x, y; double c[8]; double *buf; double bs1[7], bs2[7], bs3[4], bs4[4]; arrayclear(expand_points); switch (intp) { case INTERPOLATION_TYPE_SPLINE: case INTERPOLATION_TYPE_SPLINE_CLOSE: if (num < 2) return 0; bsize = num + 1; buf = g_malloc(sizeof(double) * 9 * bsize); if (buf == NULL) return 1; for (i = 0; i < bsize; i++) buf[i]=i; for (i = 0; i < num; i++) { buf[bsize + i] = pdata[i * 2]; buf[bsize * 2 + i] = pdata[i * 2 + 1]; } if (intp == INTERPOLATION_TYPE_SPLINE) { spcond = SPLCND2NDDIF; } else { spcond = SPLCNDPERIODIC; if (buf[num - 1 + bsize] != buf[bsize] || buf[num - 1 + 2 * bsize] != buf[2 * bsize]) { buf[num + bsize] = buf[bsize]; buf[num + 2 * bsize] = buf[2 * bsize]; num++; } } if (spline(buf, buf + bsize, buf + 3 * bsize, buf + 4 * bsize, buf + 5 * bsize, num, spcond, spcond, 0, 0)) { g_free(buf); return 1; } if (spline(buf, buf + 2 * bsize, buf + 6 * bsize, buf + 7 * bsize, buf + 8 * bsize, num, spcond, spcond, 0, 0)) { g_free(buf); return 1; } x = nround(buf[bsize]); y = nround(buf[bsize * 2]); arrayadd(expand_points, &x); arrayadd(expand_points, &y); for (i = 0; i < num - 1; i++) { for (j = 0; j < 6; j++) { c[j] = buf[i + (j + 3) * bsize]; } if (! curve_expand(c, buf[i + bsize], buf[i + 2 * bsize], splinedif, splineint, expand_points)) { break; } } g_free(buf); break; case INTERPOLATION_TYPE_BSPLINE: if (num < 7) { return 0; } for (i = 0; i < 7; i++) { bs1[i] = pdata[i * 2]; bs2[i] = pdata[i * 2 + 1]; } for (j = 0; j < 2; j++) { bspline(j + 1, bs1 + j, c); bspline(j + 1, bs2 + j, c + 4); if (j == 0) { x = nround(c[0]); y = nround(c[4]); arrayadd(expand_points, &x); arrayadd(expand_points, &y); } if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } } for (; i < num; i++) { for (j = 1; j < 7; j++) { bs1[j - 1] = bs1[j]; bs2[j - 1] = bs2[j]; } bs1[6] = pdata[i*2]; bs2[6] = pdata[i*2+1]; bspline(0, bs1 + 1, c); bspline(0, bs2 + 1, c + 4); if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } } for (j = 0; j < 2; j++) { bspline(j + 3, bs1 + j + 2, c); bspline(j + 3, bs2 + j + 2, c + 4); if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } } break; case INTERPOLATION_TYPE_BSPLINE_CLOSE: if (num < 4) { return 0; } for (i = 0; i < 4; i++) { bs1[i] = pdata[i * 2]; bs3[i] = pdata[i * 2]; bs2[i] = pdata[i * 2 + 1]; bs4[i] = pdata[i * 2 + 1]; } bspline(0, bs1, c); bspline(0, bs2, c + 4); x = nround(c[0]); y = nround(c[4]); arrayadd(expand_points, &x); arrayadd(expand_points, &y); if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } for (; i < num; i++) { for (j = 1; j < 4; j++) { bs1[j - 1] = bs1[j]; bs2[j - 1] = bs2[j]; } bs1[3] = pdata[i * 2]; bs2[3] = pdata[i * 2 + 1]; bspline(0, bs1, c); bspline(0, bs2, c + 4); if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } } for (j = 0; j < 3; j++) { bs1[4 + j] = bs3[j]; bs2[4 + j] = bs4[j]; bspline(0, bs1 + j + 1, c); bspline(0, bs2 + j + 1, c + 4); if (! curve_expand(c, c[0], c[4], bsplinedif, bsplineint, expand_points)) { return 0; } } break; } return 0; } static struct objtable draw[] = { {"init",NVFUNC,0,drawinit,NULL,0}, {"done",NVFUNC,0,drawdone,NULL,0}, {"GC",NINT,0,NULL,NULL,0}, {"hidden",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,drawdraw,"i",0}, {"redraw",NVFUNC,NREAD|NEXEC,drawdraw,"i",0}, {"R",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"G",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"B",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"A",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"clip",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"redraw_flag",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"redraw_num",NINT,0,NULL,NULL,0}, }; #define TBLNUM (sizeof(draw) / sizeof(*draw)) void * adddraw(void) /* adddraw() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,draw,ERRNUM,drawerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/orect.c0000644000175000017500000003404513356133076012734 00000000000000/* * $Id: orect.c,v 1.18 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "object.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "olegend.h" #define NAME "rectangle" #define PARENT "legend" #define OVERSION "1.00.00" static char *recterrorlist[]={ "", }; #define ERRNUM (sizeof(recterrorlist) / sizeof(*recterrorlist)) static int rectinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int width, stroke, alpha; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; width = DEFAULT_LINE_WIDTH; stroke = TRUE; alpha = 255; if (_putobj(obj, "width", inst, &width)) return 1; if (_putobj(obj, "stroke", inst, &stroke)) return 1; if (_putobj(obj, "stroke_A", inst, &alpha)) return 1; if (_putobj(obj, "fill_A", inst, &alpha)) return 1; return 0; } static int rectdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int set_position(struct objlist *obj, N_VALUE *inst, int x1, int y1, int x2, int y2) { if (_putobj(obj, "x1", inst, &x1)) return 1; if (_putobj(obj, "y1", inst, &y1)) return 1; if (_putobj(obj, "x2", inst, &x2)) return 1; if (_putobj(obj, "y2", inst, &y2)) return 1; return 0; } static void get_position(struct objlist *obj, N_VALUE *inst, int *x1, int *y1, int *x2, int *y2) { _getobj(obj, "x1", inst, x1); _getobj(obj, "y1", inst, y1); _getobj(obj, "x2", inst, x2); _getobj(obj, "y2", inst, y2); } static int rectdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; int x1,y1,x2,y2,width,ifill,stroke,fr,fg,fb,fa,br,bg,bb,ba,w,h; struct narray *style; int snum,*sdata; int clip,zoom; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; _getobj(obj,"stroke_R",inst,&fr); _getobj(obj,"stroke_G",inst,&fg); _getobj(obj,"stroke_B",inst,&fb); _getobj(obj,"stroke_A",inst,&fa); _getobj(obj,"fill_R",inst,&br); _getobj(obj,"fill_G",inst,&bg); _getobj(obj,"fill_B",inst,&bb); _getobj(obj,"fill_A", inst, &ba); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); _getobj(obj,"fill",inst,&ifill); _getobj(obj,"stroke",inst,&stroke); _getobj(obj,"clip",inst,&clip); get_position(obj, inst, &x1, &y1, &x2, &y2); snum=arraynum(style); sdata=arraydata(style); GRAregion(GC,&w,&h,&zoom); GRAview(GC,0,0,w*10000.0/zoom,h*10000.0/zoom,clip); if (ifill) { GRAcolor(GC,br,bg,bb, ba); GRArectangle(GC,x1,y1,x2,y2,1); } if (stroke) { GRAcolor(GC,fr,fg,fb, fa); GRAlinestyle(GC,snum,sdata,width,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRArectangle(GC,x1,y1,x2,y2,0); } GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int rectbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy; int x1,y1,x2,y2,width,fill,stroke; struct narray *array; array=rval->array; if (arraynum(array)!=0) return 0; get_position(obj, inst, &x1, &y1, &x2, &y2); _getobj(obj,"width",inst,&width); _getobj(obj,"fill",inst,&fill); _getobj(obj,"stroke",inst,&stroke); if (! fill && ! stroke) { return 0; } if ((array==NULL) && ((array=arraynew(sizeof(int)))==NULL)) return 1; minx=(x1x2) ? x1 : x2; maxy=(y1>y2) ? y1 : y2; if (stroke) { minx-=width/2; miny-=width/2; maxx+=width/2; maxy+=width/2; } arrayins(array,&(maxy),0); arrayins(array,&(maxx),0); arrayins(array,&(miny),0); arrayins(array,&(minx),0); minx=(x1x2) ? x1 : x2; maxy=(y1>y2) ? y1 : y2; arrayadd(array,&(minx)); arrayadd(array,&(miny)); arrayadd(array,&(maxx)); arrayadd(array,&(miny)); arrayadd(array,&(maxx)); arrayadd(array,&(maxy)); arrayadd(array,&(minx)); arrayadd(array,&(maxy)); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } rval->array=array; return 0; } static int rectrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int angle, x1, y1, x2, y2, px, py, use_pivot; get_position(obj, inst, &x1, &y1, &x2, &y2); angle = *(int *) argv[2]; angle %= 36000; if (angle < 0) angle += 36000; use_pivot = * (int *) argv[3]; if (use_pivot) { px = *(int *) argv[4]; py = *(int *) argv[5]; } else { px = (x1 + x2) / 2; py = (y1 + y2) / 2; } switch (angle) { case 9000: case 18000: case 27000: rotate(px, py, angle, &x1, &y1); rotate(px, py, angle, &x2, &y2); if (set_position(obj, inst, x1, y1, x2, y2)) return 1; break; default: return 1; } if (clear_bbox(obj, inst)) return 1; return 0; } static int rectflip(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x1, y1, x2, y2, p, use_pivot; enum FLIP_DIRECTION dir; dir = (* (int *) argv[2] == FLIP_DIRECTION_HORIZONTAL) ? FLIP_DIRECTION_HORIZONTAL : FLIP_DIRECTION_VERTICAL; use_pivot = * (int *) argv[3]; if (! use_pivot) return 0; _getobj(obj, "x1", inst, &x1); _getobj(obj, "y1", inst, &y1); _getobj(obj, "x2", inst, &x2); _getobj(obj, "y2", inst, &y2); p = *(int *) argv[4]; flip(p, dir, &x1, &y1); flip(p, dir, &x2, &y2); _putobj(obj, "x1", inst, &x1); _putobj(obj, "y1", inst, &y1); _putobj(obj, "x2", inst, &x2); _putobj(obj, "y2", inst, &y2); if (clear_bbox(obj, inst)) return 1; return 0; } static int rectmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x1,y1,x2,y2; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; get_position(obj, inst, &x1, &y1, &x2, &y2); x1+=*(int *)argv[2]; x2+=*(int *)argv[2]; y1+=*(int *)argv[3]; y2+=*(int *)argv[3]; if (set_position(obj, inst, x1, y1, x2, y2)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int rectchange(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x1,y1,x2,y2; int point,x,y; int *minx,*miny,*maxx,*maxy; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; get_position(obj, inst, &x1, &y1, &x2, &y2); point=*(int *)argv[2]; x=*(int *)argv[3]; y=*(int *)argv[4]; minx=(x1x2) ? &x1 : &x2; maxy=(y1>y2) ? &y1 : &y2; switch (point) { case 0: (*minx)+=x; (*miny)+=y; break; case 1: (*maxx)+=x; (*miny)+=y; break; case 2: (*maxx)+=x; (*maxy)+=y; break; case 3: (*minx)+=x; (*maxy)+=y; break; default: return 1; } if (set_position(obj, inst, x1, y1, x2, y2)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int rectzoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i,snum,*sdata,refx,refy,x1,y1,x2,y2,width,preserve_width; double zoom_x, zoom_y; struct narray *style; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; zoom_x = (*(int *) argv[2]) / 10000.0; zoom_y = (*(int *) argv[3]) / 10000.0; refx = (*(int *)argv[4]); refy = (*(int *)argv[5]); preserve_width = (*(int *)argv[6]); get_position(obj, inst, &x1, &y1, &x2, &y2); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); snum=arraynum(style); sdata=arraydata(style); x1=(x1-refx)*zoom_x+refx; y1=(y1-refy)*zoom_y+refy; x2=(x2-refx)*zoom_x+refx; y2=(y2-refy)*zoom_y+refy; if (! preserve_width) { double zoom; zoom = MIN(zoom_x, zoom_y); width = width * zoom; for (i=0;ii=FALSE; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); _getobj(obj,"fill",inst,&ifill); _getobj(obj,"stroke",inst,&stroke); if (! ifill && ! stroke) { return 0; } if (array==NULL) return 0; minx=*(int *)argv[2]; miny=*(int *)argv[3]; maxx=*(int *)argv[4]; maxy=*(int *)argv[5]; err=*(int *)argv[6]; if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx==maxx) && (miny==maxy)) { if (ifill) { bminx-=err; bminy-=err; bmaxx+=err; bmaxy+=err; if ((bminx<=minx) && (minx<=bmaxx) && (bminy<=miny) && (miny<=bmaxy)) rval->i=TRUE; } else { if ((((bminx-err<=minx) && (minx<=bminx+err)) || ((bmaxx-err<=minx) && (minx<=bmaxx+err))) && (bminy-err<=miny) && (miny<=bmaxy+err)) rval->i=TRUE; if ((((bminy-err<=miny) && (miny<=bminy+err)) || ((bmaxy-err<=miny) && (miny<=bmaxy+err))) && (bminx-err<=minx) && (minx<=bmaxx+err)) rval->i=TRUE; } } else { if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } static int rectgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (*(int *)(argv[2])<1) *(int *)(argv[2])=1; if (clear_bbox(obj, inst)) return 1; return 0; } static int rect_frame(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int frame, fill, stroke; frame = * (int *) argv[2]; _getobj(obj, "fill", inst, &fill); stroke = (frame || ! fill); _putobj(obj, "stroke", inst, &stroke); fill = (frame || fill); _putobj(obj, "fill", inst, &fill); return 0; } static int put_color2(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int fill, frame, col, val, val2, f; _getobj(obj, "fill", inst, &fill); _getobj(obj, "frame", inst, &frame); if (fill == 0 && frame == 0) { return 0; } col = argv[1][0]; val = * (int *) argv[2]; if (val < 0) { val = 0; } else if (val > 255) { val = 255; } if (frame) { f = TRUE; _putobj(obj, "stroke", inst, &f); _putobj(obj, "fill", inst, &f); } else { f = FALSE; _putobj(obj, "stroke", inst, &f); } switch (col) { case 'R': _getobj(obj, "stroke_R", inst, &val2); _putobj(obj, "stroke_R", inst, &val); _putobj(obj, "fill_R", inst, &val2); break; case 'G': _getobj(obj, "stroke_G", inst, &val2); _putobj(obj, "stroke_G", inst, &val); _putobj(obj, "fill_G", inst, &val2); break; case 'B': _getobj(obj, "stroke_B", inst, &val2); _putobj(obj, "stroke_B", inst, &val); _putobj(obj, "fill_B", inst, &val2); break; } return 0; } static struct objtable rect[] = { {"init",NVFUNC,NEXEC,rectinit,NULL,0}, {"done",NVFUNC,NEXEC,rectdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"x1",NINT,NREAD|NWRITE,legendgeometry,NULL,0}, {"y1",NINT,NREAD|NWRITE,legendgeometry,NULL,0}, {"x2",NINT,NREAD|NWRITE,legendgeometry,NULL,0}, {"y2",NINT,NREAD|NWRITE,legendgeometry,NULL,0}, {"stroke_R",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_G",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_B",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_A",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_R",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_G",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_B",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_A",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill",NBOOL,NREAD|NWRITE,legendgeometry,NULL,0}, {"stroke",NBOOL,NREAD|NWRITE,legendgeometry,NULL,0}, {"width",NINT,NREAD|NWRITE,rectgeometry,NULL,0}, {"style",NIARRAY,NREAD|NWRITE,oputstyle,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,rectdraw,"i",0}, {"bbox",NIAFUNC,NREAD|NEXEC,rectbbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,rectmove,"ii",0}, {"rotate",NVFUNC,NREAD|NEXEC,rectrotate,"iiii",0}, {"flip",NVFUNC,NREAD|NEXEC,rectflip,"iii",0}, {"change",NVFUNC,NREAD|NEXEC,rectchange,"iii",0}, {"zooming",NVFUNC,NREAD|NEXEC,rectzoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,rectmatch,"iiiii",0}, {"fill_hsb", NVFUNC, NREAD|NEXEC, put_fill_hsb,"ddd",0}, {"stroke_hsb", NVFUNC, NREAD|NEXEC, put_stroke_hsb,"ddd",0}, /* following fields exist for backward compatibility */ {"frame",NBOOL,NWRITE,rect_frame,NULL,0}, {"R",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"G",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"B",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"A",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"R2",NINT,NWRITE,put_color2,NULL,0}, {"G2",NINT,NWRITE,put_color2,NULL,0}, {"B2",NINT,NWRITE,put_color2,NULL,0}, }; #define TBLNUM (sizeof(rect) / sizeof(*rect)) void * addrectangle(void) /* addrectangle() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,rect,ERRNUM,recterrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/mathcode.c0000644000175000017500000000021213070106167013363 00000000000000#include char *matherrorchar[]={ "noerr", "err", "nan", "undef", "syntax", "cont", "break", "nonum", "eof", NULL }; ngraph-gtk-6.08.00/src/object.h0000644000175000017500000003003613165673031013065 00000000000000/* * $Id: object.h,v 1.20 2010-01-04 05:11:28 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef N_OBJECT_HEADER #define N_OBJECT_HEADER #define TEXT_SIZE_MIN 500 #define OBJ_MAX 128 #include "nhash.h" #include "ngraph.h" struct objlist; struct objtable; enum OBJ_LIST_SPECIFIED_TYPE { OBJ_LIST_SPECIFIED_NOT_FOUND, OBJ_LIST_SPECIFIED_BY_ID, OBJ_LIST_SPECIFIED_BY_OID, OBJ_LIST_SPECIFIED_BY_NAME, OBJ_LIST_SPECIFIED_BY_OTHER, }; union n_value { int i; double d; char *str; struct narray *array; void *ptr; union n_value *inst; }; typedef union n_value N_VALUE; typedef int (*Proc)(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv); typedef int (*DoneProc)(struct objlist *obj,void *local); typedef int (*UNDO_DUP_FUNC)(struct objlist *obj, N_VALUE *src, N_VALUE *dest); typedef int (*UNDO_FREE_FUNC)(struct objlist *obj, N_VALUE *inst); struct undo_inst { int operation; int curinst, lastinst, lastoid, lastinst2; N_VALUE *inst; struct undo_inst *next; }; struct objtable { char *name; enum ngraph_object_field_type type; int attrib; Proc proc; void *arglist; int offset; }; struct objlist { int id; int curinst; int lastinst; int lastoid; char *name; char *alias; char *ver; int tblnum, fieldnum; struct objtable *table; NHASH table_hash; int size; int errnum; char **errtable; N_VALUE *root; N_VALUE *root2; int lastinst2; struct undo_inst *undo, *redo; struct objlist *parent; struct objlist *next, *child; int idp,oidp,nextp; void *local; DoneProc doneproc; UNDO_DUP_FUNC dup_func; UNDO_FREE_FUNC free_func; }; struct narray { unsigned int size; unsigned int base; unsigned int num; void *data; }; struct loopproc; struct loopproc { struct loopproc *next; const char *objname; const char *evname; struct objlist *obj; int idn; N_VALUE *inst; void *local; }; #define ERRUNKNOWN 0 #define ERRHEAP 1 #define ERRPARENT 2 #define ERRDUP 3 #define ERROBJNUM 4 #define ERRINSTNUM 5 #define ERROBJFOUND 6 #define ERRVALFOUND 7 #define ERRNONEXT 8 #define ERRNOID 9 #define ERRIDFOUND 10 #define ERROIDFOUND 11 #define ERRNMFOUND 12 #define ERRDESTRUCT 13 #define ERRPERMISSION 14 #define ERROBJCINST 15 #define ERRNOINST 16 #define ERRILOBJ 17 #define ERRILINST 18 #define ERRFIELD 19 #define ERROEXTARG 20 #define ERROSMLARG 21 #define ERROVALUE 22 #define ERROVERWRITE 23 extern int (*getstdin)(void); extern int (*putstdout)(const char *s); extern int (*putstderr)(const char *s); extern int (*printfstdout)(const char *fmt,...); extern int (*printfstderr)(const char *fmt,...); extern int (*ninterrupt)(void); extern int (*inputyn)(const char *mes); extern void (*ndisplaydialog)(const char *str); extern void (*ndisplaystatus)(const char *str); struct savedstdio { int (*getstdin)(void); int (*putstdout)(const char *s); int (*putstderr)(const char *s); int (*printfstdout)(const char *fmt,...); int (*printfstderr)(const char *fmt,...); int (*ninterrupt)(void); int (*inputyn)(const char *mes); void (*ndisplaydialog)(const char *str); void (*ndisplaystatus)(const char *str); }; extern struct savedstdio stdiosave; int seputs(const char *s); int seprintf(const char *fmt,...); void error(struct objlist *obj,int code); void error2(struct objlist *obj,int code, const char *mes); void error22(struct objlist *obj,int code, const char *mes1, const char *mes2); void error3(struct objlist *obj,int code,int num); void ignorestdio(struct savedstdio *save); void restorestdio(struct savedstdio *save); void savestdio(struct savedstdio *save); void loadstdio(struct savedstdio *save); void arrayinit(struct narray *array,unsigned int base); struct narray *arraynew(unsigned int base); void *arraydata(struct narray *array); unsigned int arraynum(struct narray *array); void arraydel(struct narray *array); void arraydel2(struct narray *array); void arrayclear(struct narray *array); void arrayclear2(struct narray *array); void arrayfree(struct narray *array); void arrayfree2(struct narray *array); struct narray *arrayadd(struct narray *array,const void *val); struct narray *arrayadd2(struct narray *array,const char *val); struct narray *arrayins(struct narray *array,const void *val,unsigned int idx); struct narray *arrayins2(struct narray *array,const char *val,unsigned int idx); struct narray *arrayndel(struct narray *array,unsigned int idx); struct narray *arrayndel2(struct narray *array,unsigned int idx); struct narray *arrayput(struct narray *array,const void *val,unsigned int idx); struct narray *arrayput2(struct narray *array,const char *val,unsigned int idx); struct narray *array_reverse(struct narray *array); struct narray *array_slice(struct narray *array, int start, int length); struct narray *array_slice2(struct narray *array, int start, int length); void *arraynget(struct narray *array,unsigned int idx); int arraynget_int(struct narray *array, unsigned int idx); double arraynget_double(struct narray *array, unsigned int idx); char *arraynget_str(struct narray *array, unsigned int idx); void *arraylast(struct narray *array); int arraylast_int(struct narray *array); void arraysort_int(struct narray *array); void arrayrsort_int(struct narray *array); void arrayuniq_int(struct narray *array); void arraysort_double(struct narray *array); void arrayrsort_double(struct narray *array); void arrayuniq_double(struct narray *array); void arrayrsort_str(struct narray *array); void arraysort_str(struct narray *array); void arrayuniq_str(struct narray *array); void arrayuniq_all_str(struct narray *array); int arraycmp(struct narray *a, struct narray *b); int arraycpy(struct narray *a, struct narray *b); int getargc(char **arg); char **arg_add(char ***arg,void *ptr); void arg_del(char **arg); void registerevloop(const char *objname, const char *evname, struct objlist *obj,int idn,N_VALUE *inst,void *local); void unregisterevloop(struct objlist *obj,int idn,N_VALUE *inst); void eventloop(void); struct objlist *chkobjroot(void); void *addobject(char *name,char *alias,char *parentname, char *ver,int tblnum,struct objtable *table, int errnum,char **errtable,void *local,DoneProc doneproc); void hideinstance(struct objlist *obj); void recoverinstance(struct objlist *obj); struct objlist *chkobject(const char *name); int chkobjectid(struct objlist *obj); const char *chkobjectname(struct objlist *obj); const char *chkobjectalias(struct objlist *obj); struct objlist *chkobjparent(struct objlist *obj); int chkobjchild(struct objlist *parent,struct objlist *child); char *chkobjver(struct objlist *obj); int chkobjsize(struct objlist *obj); int chkobjlastinst(struct objlist *obj); int chkobjcurinst(struct objlist *obj); int chkobjoffset(struct objlist *obj, const char *name); int chkobjoffset2(struct objlist *obj,int tblpos); N_VALUE *chkobjinstoid(struct objlist *obj,int oid); N_VALUE *chkobjinst(struct objlist *obj,int id); int chkobjoid(struct objlist *obj,int oid); int chkobjfieldnum(struct objlist *obj); char *chkobjfieldname(struct objlist *obj,int num); int chkobjfield(struct objlist *obj, const char *name); int chkobjperm(struct objlist *obj, const char *name); enum ngraph_object_field_type chkobjfieldtype(struct objlist *obj, const char *name); const char *chkobjarglist(struct objlist *obj, const char *name); struct objlist *getobject(const char *name); char *getobjver(const char *name); char *getobjectname(struct objlist *obj); int getobjoffset(struct objlist *obj, const char *name); int getobjtblpos(struct objlist *obj, const char *name,struct objlist **robj); N_VALUE *getobjinstoid(struct objlist *obj,int oid); N_VALUE *getobjinst(struct objlist *obj,int id); int getobjfield(struct objlist *obj, const char *name); int _putobj(struct objlist *obj, const char *vname,N_VALUE *inst,void *val); int _getobj(struct objlist *obj, const char *vname,N_VALUE *inst,void *val); int _exeparent(struct objlist *obj,const char *vname,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int _exeobj(struct objlist *obj,const char *vname,N_VALUE *inst,int argc,char **argv); int __exeobj(struct objlist *obj,int idn,N_VALUE *inst,int argc,char **argv); int copyobj(struct objlist *obj, const char *vname,int did,int sid); int newobj(struct objlist *obj); int newobj_alias(struct objlist *obj, const char *name); int delobj(struct objlist *obj,int delid); int putobj(struct objlist *obj, const char *vname,int id,void *val); int getobj(struct objlist *obj, const char *vname,int id, int argc,char **argv,void *val); int exeobj(struct objlist *obj,const char *vname,int id,int argc,char **argv); int moveobj(struct objlist *obj,int did,int sid); int moveupobj(struct objlist *obj,int id); int movetopobj(struct objlist *obj,int id); int movedownobj(struct objlist *obj,int id); int movelastobj(struct objlist *obj,int id); int exchobj(struct objlist *obj,int id1,int id2); void set_newobj_cb(void (* newobj_cb)(struct objlist *obj)); void set_delobj_cb(void (* delobj_cb)(struct objlist *obj)); int getobjiname(char *s, char **name, char **ptr); int chkobjilist(char *s,struct objlist **obj,struct narray *iarray, int def,int *spc); int getobjilist(char *s,struct objlist **obj,struct narray *iarray, int def,int *spc); int chkobjilist2(char **s,struct objlist **obj,struct narray *iarray, int def); char *mkobjlist(struct objlist *obj, const char *objname,int id, const char *field,int oid); struct objlist *getobjlist(char *list,int *id,char **field,int *oid); char *chgobjlist(char *olist); char *getvaluestr(struct objlist *obj, const char *field,void *val,int cr,int quote); int isobject(char **s); int schkobjfield(struct objlist *obj,int id, const char *field,char *arg, char **valstr,int limittype,int cr,int quote); int sgetobjfield(struct objlist *obj,int id, const char *field,char *arg, char **valstr,int limittype,int cr,int quote); int sgetfield(struct objlist *obj,int id,char *arg,char **valstr, int limittype,int cr,int quote); struct narray *sgetobj(char *arg,int limittype,int cr,int quote); int sputobjfield(struct objlist *obj,int id, const char *field,char *arg); int sputfield(struct objlist *obj,int id,char *arg); int sputobj(char *arg); int sexefield(struct objlist *obj,int id,char *arg); int sexeobj(char *arg); int has_eventloop(void); void obj_do_tighten(struct objlist *obj, N_VALUE *inst, const char *field); void obj_do_tighten_all(struct objlist *obj, N_VALUE *inst, const char *field); int getobjilist2(char **s,struct objlist **obj,struct narray *iarray,int def); void delchildobj(struct objlist *parent); int vinterrupt(void); int vinputyn(const char *mes); int copy_obj_field(struct objlist *obj, int dist, int src, char **ignore_field); int str_calc(const char *str, double *val, int *r, char **err_msg); typedef int (*UNDO_FUNC)(struct objlist *obj); int undo_save(struct objlist *obj); int undo_undo(struct objlist *obj); int undo_redo(struct objlist *obj); int undo_clear(struct objlist *obj); int undo_delete(struct objlist *obj); void obj_set_undo_func(struct objlist *obj, UNDO_DUP_FUNC dup_func, UNDO_FREE_FUNC free_func); int obj_get_field_pos(struct objlist *obj, const char *field); int undo_check_undo(struct objlist *obj); int undo_check_redo(struct objlist *obj); #endif ngraph-gtk-6.08.00/src/ogra.h0000644000175000017500000000023113070106167012535 00000000000000#define ERROPEN 100 #define ERRBUSY 101 #define ERRALOPEN 102 #define ERRNODEVICE 103 #define ERRILGC 104 #define ERRGRABUSY 105 #define ERRGRACLOSE 106 ngraph-gtk-6.08.00/src/shellcm.c0000644000175000017500000007510013327053133013235 00000000000000/* * $Id: shellcm.c,v 1.29 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include #define USE_HASH 1 #include "object.h" #include "nstring.h" #include "ioutil.h" #include "mathfn.h" #include "shell.h" #include "shellcm.h" #include "math/math_equation.h" #define ERR 128 int cmcd(struct nshell *nshell,int argc,char **argv) { char *home; if (argv[1]!=NULL) { if (nchdir(argv[1])!=0) { sherror3(argv[0],ERRNODIR,argv[1]); return ERR; } } else { if ((home=getval(nshell,"HOME"))!=NULL) { if (nchdir(home)!=0) { sherror3(argv[0],ERRNODIR,home); return ERR; } } } return 0; } int cmecho(struct nshell *nshell,int argc,char **argv) { int i, nbr; nbr = (argc > 1 && strcmp(argv[1], "-n") == 0); for (i = (nbr) ? 2 : 1; i < argc; i++) { printfstdout("%s",argv[i]); if (i != (argc - 1)) printfstdout(" "); } if (! nbr) putstdout(""); return 0; } int cmbasename(struct nshell *nshell,int argc,char **argv) { int len, ext_len; char *bname; if (argc < 2) { return 1; } if (argv[1] == NULL) { return 1; } bname = getbasename(argv[1]); if (bname == NULL) { return 1; } if (argc == 2) { len = strlen(bname); } else { len = strlen(bname); ext_len = strlen(argv[2]); if (ext_len < len && strcmp(bname + len - ext_len, argv[2]) == 0) { bname[len - ext_len] = '\0'; } } putstdout(bname); g_free(bname); return 0; } int cmdirname(struct nshell *nshell,int argc,char **argv) { char *tmp; if (argc < 2) { return 1; } if (argv[1] == NULL) return 1; tmp = getdirname(argv[1]); putstdout(tmp); g_free(tmp); return 0; } int cmseq(struct nshell *nshell, int argc, char **argv) { int i, f, l; double x, first, last, inc; char *endptr; switch (argc) { case 0: case 1: sherror4(argv[0], ERRSMLARG); return ERR; case 2: f = 0; i = 0; l = 1; first = 1.0; inc = 1.0; break; case 3: f = 1; i = 0; l = 2; inc = 1.0; break; default: f = 1; i = 2; l = 3; break; } if (f) { errno = 0; first= strtod(argv[f], &endptr); if (errno || endptr == argv[f]) { sherror4(argv[0], ERRNUMERIC); return ERR; } } if (l) { errno = 0; last= strtod(argv[l], &endptr); if (errno || endptr == argv[l]) { sherror4(argv[0], ERRNUMERIC); return ERR; } } if (i) { errno = 0; inc= strtod(argv[i], &endptr); if (errno || endptr == argv[i]) { sherror4(argv[0], ERRNUMERIC); return ERR; } } for (x = first; (inc < 0) ? (x >= last) : (x <= last); x += inc) { printfstdout("%G\n", x); } return 0; } int cmeval(struct nshell *nshell,int argc,char **argv) { GString *s; int i,rcode; s = g_string_sized_new(128); if (s == NULL) { return ERR; } for (i = 1; i < argc; i++) { g_string_append(s, argv[i]); g_string_append_c(s, ' '); } rcode = cmdexecute(nshell, s->str); g_string_free(s, TRUE); if (rcode != 0 && rcode != 1) { return ERR; } return 0; } int cmexit(struct nshell *nshell,int argc,char **argv) { int a; char *endptr; if (argc>2) { sherror4(argv[0],ERREXTARG); return ERREXTARG; } else if (argc==2) { a=strtol(argv[1],&endptr,10); if (endptr[0]!='\0') { sherror3(argv[0],ERRNUMERIC,argv[1]); return ERRNUMERIC; } else { nshell->quit=TRUE; return a; } } else { nshell->quit=TRUE; return nshell->status; } } #if USE_HASH static int printexp(struct nhash *h, void *data) { printfstdout("%.256s\n", h->key); return 0; } #endif int cmexport(struct nshell *nshell,int argc,char **argv) { int i; #if USE_HASH if (argv[1] == NULL) { nhash_each(nshell->exproot, printexp, NULL); } else { for (i = 1; i < argc; i++) { if (addexp(nshell, argv[i]) == NULL) return ERR; } } return 0; #else struct explist *valcur; if (argv[1]==NULL) { valcur=nshell->exproot; while (valcur!=NULL) { printfstdout("%.256s\n",valcur->val); valcur=valcur->next; } return 0; } else { for (i=1;ival.p; if (!val->func) printfstdout("%.256s=%.256s\n", val->name, (char *)(val->val)); return 0; } static int print_func(struct nhash *h, void *data) { struct vallist *val; struct cmdlist *cmdcur; struct prmlist *prmcur; val = (struct vallist *) h->val.p; if (val->func) { printfstdout("%.256s=()\n", val->name); putstdout("{"); cmdcur = val->val; while (cmdcur) { prmcur = cmdcur->prm; printfstdout(" "); while (prmcur) { if (prmcur->str) printfstdout("%.256s ", prmcur->str); prmcur = prmcur->next; } printfstdout("\n"); cmdcur = cmdcur->next; } putstdout("}"); } return 0; } int cmset(struct nshell *nshell,int argc,char **argv) { #if USE_HASH char *s; int j, r, ops; if (argc < 2) { nhash_each(nshell->valroot, print_val, NULL); nhash_each(nshell->valroot, print_func, NULL); return 0; } for (j = 1; j < argc; j++) { s = argv[j]; if (s[0] == '-' && s[1] == '-' && s[2] == '\0') { j++; if (j == argc) { r = set_shell_args(nshell, j, nshell->argv[0], argc, argv); if (r) { r = ERR; } return r; } break; } else if (s[0] == '-' && s[1] == '\0') { nshell->optionv = FALSE; nshell->optionx = FALSE; j++; break; } else if (s[0] == '-' || s[0] == '+') { if (s[1] == '\0' || strchr("efvx", s[1]) == NULL) { sherror3(argv[0], ERRILOPS, s); return ERRILOPS; } } else { break; } } if (j != argc) { r = set_shell_args(nshell, j, nshell->argv[0], argc, argv); if (r) { return ERR; } } for (j = 1 ; j < argc; j++) { s = argv[j]; if (s[0] == '-') { ops=TRUE; } else if (s[0]=='+') { ops=FALSE; } else { break; } switch (s[1]) { case 'e': nshell->optione = ops; break; case 'f': nshell->optionf = ops; break; case 'v': nshell->optionv = ops; break; case 'x': nshell->optionx = ops; break; } } #else struct vallist *valcur; struct cmdlist *cmdcur; struct prmlist *prmcur; char *s; unsigned int n; int j,ops; char **argv2; int argc2; if (argc<2) { valcur=nshell->valroot; while (valcur!=NULL) { if (!valcur->func) printfstdout("%.256s=%.256s\n",valcur->name,(char *)(valcur->val)); valcur=valcur->next; } valcur=nshell->valroot; while (valcur!=NULL) { if (valcur->func) { printfstdout("%.256s=()\n",valcur->name); putstdout("{"); cmdcur=valcur->val; while (cmdcur!=NULL) { prmcur=cmdcur->prm; printfstdout(" "); while (prmcur!=NULL) { if (prmcur->str!=NULL) printfstdout("%.256s ",prmcur->str); prmcur=prmcur->next; } printfstdout("\n"); cmdcur=cmdcur->next; } putstdout("}"); } valcur=valcur->next; } } else { for (j=1;jargv)[0])+1))==NULL) return ERR; strcpy(s,(nshell->argv)[0]); if (arg_add(&argv2,s)==NULL) { g_free(s); arg_del(argv2); return ERR; } for (;jargv); nshell->argv=argv2; nshell->argc=argc2; } for (j=1;joptione=ops; break; case 'f': nshell->optionf=ops; break; case 'v': nshell->optionv=ops; break; case 'x': nshell->optionx=ops; break; } } } #endif return 0; } int cmshift(struct nshell *nshell,int argc,char **argv) { int i,a; char *arg,*endptr; if (argc>2) { sherror4(argv[0],ERREXTARG); return ERREXTARG; } else if (argc==2) { arg=argv[1]; a=strtol(arg,&endptr,10); if (endptr[0]!='\0') { sherror3(argv[0],ERRNUMERIC,arg); return ERRNUMERIC; } } else a=1; if (a<0) a=0; if ((a+1)>=nshell->argc) a=nshell->argc-1; for (i=a+1;iargc;i++) { g_free(nshell->argv[i-a]); nshell->argv[i-a]=nshell->argv[i]; nshell->argv[i]=NULL; } nshell->argc-=a; return 0; } int cmtype(struct nshell *nshell,int argc,char **argv) { struct prmlist *prm2; struct cmdlist *cmdcur; int i,j; char *cmdname; shell_proc proc; for (j=1;j= 0) { printfstdout("%.256s is a shell keyword.\n", argv[j]); } else if ((cmdcur=getfunc(nshell,argv[j]))!=NULL) { printfstdout("%.256s is a function.\n",argv[j]); printfstdout("%.256s=()\n",argv[j]); putstdout("{"); while (cmdcur!=NULL) { prm2=cmdcur->prm; printfstdout(" "); while (prm2!=NULL) { if (prm2->str!=NULL) printfstdout("%.256s ",prm2->str); prm2=prm2->next; } printfstdout("\n"); cmdcur=cmdcur->next; } putstdout("}"); } else if ((strcmp0(".",argv[j])==0) || (strcmp0("break",argv[j])==0) || (strcmp0("continue",argv[j])==0) || (strcmp0("return",argv[j])==0)) { printfstdout("%.256s is a shell built in.\n",argv[j]); } else { proc = check_cmd(argv[j]); if (proc) { printfstdout("%.256s is a shell built in.\n",argv[j]); } else { cmdname=nsearchpath(getval(nshell,"PATH"),argv[j],FALSE); if (cmdname==NULL) { sherror3(argv[0],ERRCFOUND,argv[j]); } else { printfstdout("%.256s is %.256s.\n",argv[j],cmdname); } g_free(cmdname); } } } return 0; } int cmunset(struct nshell *nshell,int argc,char **argv) { int i; for (i=1;iparent==parent) { for (i=1;i<*tab;i++) printfstdout("\t"); printfstdout("%.256s\n",objcur->name); objdisp(objcur,objcur,tab); } objcur=objcur->next; } (*tab)--; } static void dispfield(struct objlist *obj,char *name) { int j; enum ngraph_object_field_type ftype; char perm[4],type[10]; const char *alist; char **enumlist; ftype=chkobjfieldtype(obj,name); switch (ftype) { case NVOID: strcpy(type,"void"); break; case NBOOL: strcpy(type,"bool"); break; #if USE_NCHAR case NCHAR: strcpy(type,"char"); break; #endif case NINT: strcpy(type,"int"); break; case NDOUBLE: strcpy(type,"double"); break; case NSTR: strcpy(type,"char*"); break; case NPOINTER: strcpy(type,"void*"); break; case NIARRAY: strcpy(type,"int[]"); break; case NDARRAY: strcpy(type,"double[]"); break; case NSARRAY: strcpy(type,"char*[]"); break; case NENUM: strcpy(type,"enum("); break; case NOBJ: strcpy(type,"obj"); break; #if USE_NLABEL case NLABEL: strcpy(type,"label"); break; #endif case NVFUNC: strcpy(type,"void("); break; case NBFUNC: strcpy(type,"bool("); break; #if USE_NCHAR case NCFUNC: strcpy(type,"char("); break; #endif case NIFUNC: strcpy(type,"int("); break; case NDFUNC: strcpy(type,"double("); break; case NSFUNC: strcpy(type,"char*("); break; case NIAFUNC: strcpy(type,"int[]("); break; case NDAFUNC: strcpy(type,"double[]("); break; case NSAFUNC: strcpy(type,"char*[]("); break; default: strcpy(type,"unknown"); break; } if (chkobjperm(obj,name) & NREAD) perm[0]='r'; else perm[0]='-'; if (chkobjperm(obj,name) & NWRITE) perm[1]='w'; else perm[1]='-'; if (chkobjperm(obj,name) & NEXEC) perm[2]='x'; else perm[2]='-'; perm[3]='\0'; printfstdout("%3s %16.256s %.256s", (char *)perm,(char *)name,(char *)type); if (ftype>=NVFUNC) { if ((alist=chkobjarglist(obj,name))!=NULL) { if (alist[0]=='\0') printfstdout(" void"); else for (j=0;alist[j]!='\0';j++) { switch (alist[j]) { case 'b': printfstdout(" bool"); break; #if USE_NCHAR case 'c': printfstdout(" char"); break; #endif case 'i': printfstdout(" int"); break; case 'd': printfstdout(" double"); break; case 's': printfstdout(" char*"); break; case 'p': printfstdout(" void*"); break; case 'o': printfstdout(" obj"); break; } if (alist[j+1]=='a') { printfstdout("[]"); j++; } } } printfstdout(" )"); } else if (ftype==NENUM) { if ((enumlist=(char **)chkobjarglist(obj,name))!=NULL) { for (j=0;enumlist[j] && enumlist[j][0];j++) printfstdout(" %s",enumlist[j]); printfstdout(" )"); } } printfstdout("\n"); } int cmobject(struct nshell *nshell,int argc,char **argv) { struct objlist *obj; int i,j,tab; char *name; if (argc<2) { tab=0; objdisp(chkobjroot(),NULL,&tab); return 0; } else { if ((obj=getobject(argv[1]))==NULL) return ERR; } if (argc==2) { printfstdout("object: %.256s\n",chkobjectname(obj)); if (chkobjectalias(obj)!=NULL) printfstdout("alias: %.256s\n",chkobjectalias(obj)); else printfstdout("alias:\n"); printfstdout("version: %.256s\n",chkobjver(obj)); if (chkobjparent(obj)!=NULL) printfstdout("parent: %.256s\n",chkobjectname(chkobjparent(obj))); else printfstdout("parent: (null)\n"); printfstdout("object id: %d\n",chkobjectid(obj)); printfstdout("number of fields: %d\n",chkobjfieldnum(obj)); printfstdout("size of instance: %d\n",chkobjsize(obj)); printfstdout("current instance: %d\n",chkobjcurinst(obj)); printfstdout("last instance id: %d\n",chkobjlastinst(obj)); for (i=0;inext; } } int cmderive(struct nshell *nshell,int argc,char **argv) { struct objlist *obj; int i,noinst; noinst=FALSE; for (i=1;i2) { sherror4(argv[0],ERRMANYARG); return ERRMANYARG; } arrayinit(&iarray,sizeof(int)); if (getobjilist(argv[1],&obj,&iarray,TRUE,NULL)) return ERR; anum=arraynum(&iarray); if (anum==0) { sherror4(argv[0],ERRNONEINST); arraydel(&iarray); return ERRNONEINST; } adata=arraydata(&iarray); for (i=0;i3) { sherror4(argv[0],ERRMANYARG); return ERRMANYARG; } else { objname = argv[1]; } arrayinit(&iarray,sizeof(int)); if (chkobjilist(objname,&obj,&iarray,TRUE,NULL)) anum=0; else { anum=arraynum(&iarray); arraydel(&iarray); } if (! quiet) printfstdout("%d\n",anum); if (anum==0) return ERRNONEINST; return 0; } static void put_field_str(const char *valstr, int escape) { if (valstr == NULL) { return; } if (escape) { char *tmp; tmp = g_strescape(valstr, NULL); if (tmp == NULL) { return; } putstdout(tmp); g_free(tmp); } else { putstdout(valstr); } } int cmget(struct nshell*nshell,int argc,char **argv) { struct objlist *obj; struct narray iarray; char *field,*valstr; int i,j,k,l,id,anum,len,*adata; int nowrite,nofield,noid,quote,perm,multi,escape; if (argc<2) { sherror4(argv[0],ERROBJARG); return ERROBJARG; } arrayinit(&iarray,sizeof(int)); if (getobjilist(argv[1],&obj,&iarray,TRUE,NULL)) return ERR; anum=arraynum(&iarray); adata=arraydata(&iarray); if (anum==0) { sherror4(argv[0],ERRNONEINST); arraydel(&iarray); return ERRNONEINST; } nowrite=FALSE; nofield=FALSE; noid=FALSE; quote=FALSE; escape=FALSE; for (j=2;j2) { sherror4(argv[0],ERRMANYARG); return ERRMANYARG; } arrayinit(&iarray,sizeof(int)); if (getobjilist(argv[1],&obj,&iarray,TRUE,NULL)) return ERR; anum=arraynum(&iarray); adata=arraydata(&iarray); if (anum!=2) { sherror4(argv[0],ERRTWOINST); arraydel(&iarray); return ERRTWOINST; } id1=adata[0]; id2=adata[1]; arraydel(&iarray); if (strcmp0(argv[0],"move")==0) { if (moveobj(obj,id2,id1)==-1) return ERR; } else if (strcmp0(argv[0],"exch")==0) { if (exchobj(obj,id2,id1)==-1) return ERR; } return 0; } int cmmovetop(struct nshell*nshell,int argc,char **argv) { struct objlist *obj; struct narray iarray; int i,anum,top,rcode,*adata; if (argc<2) { sherror4(argv[0],ERROBJARG); return ERROBJARG; } else if (argc>2) { sherror4(argv[0],ERRMANYARG); return ERRMANYARG; } arrayinit(&iarray,sizeof(int)); if (getobjilist(argv[1],&obj,&iarray,TRUE,NULL)) return ERR; anum=arraynum(&iarray); adata=arraydata(&iarray); if (strcmp0(argv[0],"movetop")==0) top=0; else if (strcmp0(argv[0],"moveup")==0) top=1; else if (strcmp0(argv[0],"movedown")==0) top=2; else top=3; for (i=0;istr, &vd, &rcode, &err_msg); g_string_free(s, TRUE); if (ecode) { if (err_msg) { printfstderr("shell: %s\n", err_msg); g_free(err_msg); } else { sherror4(argv[0],ecode); } return ecode; } if (rcode == MATH_VALUE_NAN) { putstdout("nan"); return ERR; } else if (rcode == MATH_VALUE_UNDEF) { putstdout("undefined"); return ERR; } if (argv[0][0] == 'd') { printfstdout("%.15e\n", vd); } else { printfstdout("%.0f\n", round(vd)); } return 0; } int cmread(struct nshell *nshell,int argc,char **argv) { int c,i,len; char *po,*s2,*ifs; GString *s; s = g_string_sized_new(64); if (s == NULL) { return ERR; } while (TRUE) { c = getstdin(); if (c == '\n' || c == EOF) { break; } g_string_append_c(s, c); } if (argc == 1) { addval(nshell, "REPLY", s->str); } else { po = s->str; ifs = getval(nshell, "IFS"); for (i = 1; i < argc; i++) { s2 = getitok2(&po, &len, ifs); if (s2) { addval(nshell, argv[i], s2); g_free(s2); } else { addval(nshell, argv[i], ""); } } } g_string_free(s, TRUE); return (c == EOF) ? ERR : 0; } int cmwhich(struct nshell*nshell,int argc,char **argv) { int i, r, start, quiet; char *path; if (strcmp0(argv[1], "-q")) { start = 1; quiet = FALSE; } else { start = 2; quiet = TRUE; } if (argc < 1 + start) { sherror4(argv[0], ERRSMLARG); return ERRSMLARG; } r = 0; for (i = start; i < argc; i++) { if (check_cmd(argv[i])) { if (! quiet) { printfstdout("%s: shell built-in command\n", argv[i]); } } else { path = g_find_program_in_path(argv[i]); if (path == NULL) { r = 1; } else { if (! quiet) { putstdout(path); } g_free(path); } } } return r; } ngraph-gtk-6.08.00/src/ogra2nul.c0000644000175000017500000004466513070106167013354 00000000000000/* * $Id: ogra2nul.c,v 1.7 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include #include "common.h" #include "object.h" #include "ioutil.h" #include "gra.h" #include "nstring.h" #include "mathfn.h" #include "nconfig.h" #define NAME "gra2null" #define PARENT "gra2" #define OVERSION "1.00.00" #define ERRCONF 100 static char *g2nulerrorlist[]={ "", }; #define ERRNUM (sizeof(g2nulerrorlist) / sizeof(*g2nulerrorlist)) static int g2nulinit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } static int g2nuldone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int HelveticaSet[256]={ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 355, 556, 556, 889, 667, 222, 333, 333, 389, 584, 278, 584, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 278, 278, 584, 584, 584, 556, 1015, 667, 667, 722, 722, 667, 611, 778, 722, 278, 500, 667, 556, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, 667, 611, 278, 278, 278, 469, 556, 222, 556, 556, 500, 556, 556, 278, 556, 556, 222, 222, 500, 222, 833, 556, 556, 556, 556, 333, 500, 278, 556, 500, 722, 500, 500, 500, 334, 260, 334, 584, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 333, 333, 333, 333, 333, 333, 333, 333, 278, 333, 333, 278, 333, 333, 333, 278, 333, 556, 556, 556, 556, 260, 556, 333, 737, 370, 556, 584, 333, 737, 333, 400, 584, 333, 333, 333, 556, 537, 278, 333, 333, 365, 556, 834, 834, 834, 611, 667, 667, 667, 667, 667, 667, 1000, 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, 556, 889, 500, 556, 556, 556, 556, 278, 278, 278, 278, 556, 556, 556, 556, 556, 556, 556, 584, 611, 556, 556, 556, 556, 500, 556, 500}; static int HelveticaBoldSet[256]={ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 333, 474, 556, 556, 889, 722, 278, 333, 333, 389, 584, 278, 584, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 333, 333, 584, 584, 584, 611, 975, 722, 722, 722, 722, 667, 611, 778, 722, 278, 556, 722, 611, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, 667, 611, 333, 278, 333, 584, 556, 278, 556, 611, 556, 611, 556, 333, 611, 611, 278, 278, 556, 278, 889, 611, 611, 611, 611, 389, 556, 333, 611, 556, 778, 556, 556, 500, 389, 280, 389, 584, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 333, 333, 333, 333, 333, 333, 333, 333, 278, 333, 333, 278, 333, 333, 333, 278, 333, 556, 556, 556, 556, 280, 556, 333, 737, 370, 556, 584, 333, 737, 333, 400, 584, 333, 333, 333, 611, 556, 278, 333, 333, 365, 556, 834, 834, 834, 611, 722, 722, 722, 722, 722, 722, 1000, 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, 556, 889, 556, 556, 556, 556, 556, 278, 278, 278, 278, 611, 611, 611, 611, 611, 611, 611, 584, 611, 611, 611, 611, 611, 556, 611, 556}; static int TimesRomanSet[256]={ 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 333, 408, 500, 500, 833, 778, 333, 333, 333, 500, 564, 250, 564, 250, 278, 500, 500, 500, 500, 500, 500, 500, 500, 500, 500, 278, 278, 564, 564, 564, 444, 921, 722, 667, 667, 722, 611, 556, 722, 722, 333, 389, 722, 611, 889, 722, 722, 556, 722, 667, 556, 611, 722, 722, 944, 722, 722, 611, 333, 278, 333, 469, 500, 333, 444, 500, 444, 500, 444, 333, 500, 500, 278, 278, 500, 278, 778, 500, 500, 500, 500, 333, 389, 278, 500, 500, 722, 500, 500, 444, 480, 200, 480, 541, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 278, 333, 333, 333, 333, 333, 333, 333, 333, 250, 333, 333, 250, 333, 333, 333, 250, 333, 500, 500, 500, 500, 200, 500, 333, 760, 276, 500, 564, 333, 760, 333, 400, 564, 300, 300, 333, 500, 453, 250, 333, 300, 310, 500, 750, 750, 750, 444, 722, 722, 722, 722, 722, 722, 889, 667, 611, 611, 611, 611, 333, 333, 333, 333, 722, 722, 722, 722, 722, 722, 722, 564, 722, 722, 722, 722, 722, 722, 556, 500, 444, 444, 444, 444, 444, 444, 667, 444, 444, 444, 444, 444, 278, 278, 278, 278, 500, 500, 500, 500, 500, 500, 500, 564, 500, 500, 500, 500, 500, 500, 500, 500}; static int TimesBoldSet[256]={ 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 333, 555, 500, 500, 1000, 833, 333, 333, 333, 500, 570, 250, 570, 250, 278, 500, 500, 500, 500, 500, 500, 500, 500, 500, 500, 333, 333, 570, 570, 570, 500, 930, 722, 667, 722, 722, 667, 611, 778, 778, 389, 500, 778, 667, 944, 722, 778, 611, 778, 722, 556, 667, 722, 722, 1000, 722, 722, 667, 333, 278, 333, 581, 500, 333, 500, 556, 444, 556, 444, 333, 500, 556, 278, 333, 556, 278, 833, 556, 500, 556, 556, 444, 389, 333, 556, 500, 722, 500, 500, 444, 394, 220, 394, 520, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 278, 333, 333, 333, 333, 333, 333, 333, 333, 250, 333, 333, 250, 333, 333, 333, 250, 333, 500, 500, 500, 500, 220, 500, 333, 747, 300, 500, 570, 333, 747, 333, 400, 570, 300, 300, 333, 556, 540, 250, 333, 300, 330, 500, 750, 750, 750, 500, 722, 722, 722, 722, 722, 722, 1000, 722, 667, 667, 667, 667, 389, 389, 389, 389, 722, 722, 778, 778, 778, 778, 778, 570, 778, 722, 722, 722, 722, 722, 611, 556, 500, 500, 500, 500, 500, 500, 722, 444, 444, 444, 444, 444, 278, 278, 278, 278, 500, 556, 500, 500, 500, 500, 500, 570, 500, 556, 556, 556, 556, 500, 556, 500}; static int TimesItalicSet[256]={ 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 333, 420, 500, 500, 833, 778, 333, 333, 333, 500, 675, 250, 675, 250, 278, 500, 500, 500, 500, 500, 500, 500, 500, 500, 500, 333, 333, 675, 675, 675, 500, 920, 611, 611, 667, 722, 611, 611, 722, 722, 333, 444, 667, 556, 833, 667, 722, 611, 722, 611, 500, 556, 722, 611, 833, 611, 556, 556, 389, 278, 389, 422, 500, 333, 500, 500, 444, 500, 444, 278, 500, 500, 278, 278, 444, 278, 722, 500, 500, 500, 500, 389, 389, 278, 500, 444, 667, 444, 444, 389, 400, 275, 400, 541, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 278, 333, 333, 333, 333, 333, 333, 333, 333, 250, 333, 333, 250, 333, 333, 333, 250, 389, 500, 500, 500, 500, 275, 500, 333, 760, 276, 500, 675, 333, 760, 333, 400, 675, 300, 300, 333, 500, 523, 250, 333, 300, 310, 500, 750, 750, 750, 500, 611, 611, 611, 611, 611, 611, 889, 667, 611, 611, 611, 611, 333, 333, 333, 333, 722, 667, 722, 722, 722, 722, 722, 675, 722, 722, 722, 722, 722, 556, 611, 500, 500, 500, 500, 500, 500, 500, 667, 444, 444, 444, 444, 444, 278, 278, 278, 278, 500, 500, 500, 500, 500, 500, 500, 675, 500, 500, 500, 500, 500, 444, 500, 444}; static int TimesBoldItalicSet[256]={ 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 389, 555, 500, 500, 833, 778, 333, 333, 333, 500, 570, 250, 606, 250, 278, 500, 500, 500, 500, 500, 500, 500, 500, 500, 500, 333, 333, 570, 570, 570, 500, 832, 667, 667, 667, 722, 667, 667, 722, 778, 389, 500, 667, 611, 889, 722, 722, 611, 722, 667, 556, 611, 722, 667, 889, 667, 611, 611, 333, 278, 333, 570, 500, 333, 500, 500, 444, 500, 444, 333, 500, 556, 278, 278, 500, 278, 778, 556, 500, 500, 500, 389, 389, 278, 556, 444, 667, 500, 444, 389, 348, 220, 348, 570, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 278, 333, 333, 333, 333, 333, 333, 333, 333, 250, 333, 333, 250, 333, 333, 333, 250, 389, 500, 500, 500, 500, 220, 500, 333, 747, 266, 500, 606, 333, 747, 333, 400, 570, 300, 300, 333, 576, 500, 250, 333, 300, 300, 500, 750, 750, 750, 500, 667, 667, 667, 667, 667, 667, 944, 667, 667, 667, 667, 667, 389, 389, 389, 389, 722, 722, 722, 722, 722, 722, 722, 570, 722, 722, 722, 722, 722, 611, 611, 500, 500, 500, 500, 500, 500, 500, 722, 444, 444, 444, 444, 444, 278, 278, 278, 278, 500, 556, 500, 500, 500, 500, 500, 570, 500, 556, 556, 556, 556, 444, 500, 444}; static int SymbolSet[256]={ 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 333, 713, 500, 549, 833, 778, 439, 333, 333, 500, 549, 250, 549, 250, 278, 500, 500, 500, 500, 500, 500, 500, 500, 500, 500, 278, 278, 549, 549, 549, 444, 549, 722, 667, 722, 612, 611, 763, 603, 722, 333, 631, 722, 686, 889, 722, 722, 768, 741, 556, 592, 611, 690, 439, 768, 645, 795, 611, 333, 863, 333, 658, 500, 500, 631, 549, 549, 494, 439, 521, 411, 603, 329, 603, 549, 549, 576, 521, 549, 549, 521, 549, 603, 439, 576, 713, 686, 493, 686, 494, 480, 200, 480, 549, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 620, 247, 549, 167, 713, 500, 753, 753, 753, 753, 1042, 987, 603, 987, 603, 400, 549, 411, 549, 549, 713, 494, 460, 549, 549, 549, 549, 1000, 603, 1000, 658, 823, 686, 795, 987, 768, 768, 823, 768, 768, 713, 713, 713, 713, 713, 713, 713, 768, 713, 790, 790, 890, 823, 549, 250, 713, 603, 603, 1042, 987, 603, 987, 603, 494, 329, 790, 790, 786, 713, 384, 384, 384, 384, 384, 384, 494, 494, 494, 494, 250, 329, 274, 686, 686, 686, 384, 384, 384, 384, 384, 384, 494, 494, 494, 250}; struct font_data { char *name; int *width[4], height[4], style; }; static struct font_data FontData[] = { { "Serif", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {662, 676, 653, 669}, -1 }, { "Sans-serif", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, -1 }, { "Times", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 0 }, { "Tim", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 0 }, { "TimesBold", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 1 }, { "TimB", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 1 }, { "TimesItalic", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 2 }, { "TimI", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 2 }, { "TimesBoldItalic", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 3 }, { "TimBI", {TimesRomanSet, TimesBoldSet, TimesItalicSet, TimesBoldItalicSet}, {662, 676, 653, 669}, 3 }, { "Helvetica", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 0 }, { "Helv", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 0 }, { "HelveticaOblique", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 2 }, { "HelvO", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 2 }, { "HelveticaItalic", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 2 }, { "HelvI", {HelveticaSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 2 }, { "HelveticaBold", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 1 }, { "HelvB", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 1 }, { "HelveticaBoldOblique", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 3 }, { "HelvBO", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 2 }, { "HelveticaBoldItalic", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 3 }, { "HelvBI", {HelveticaBoldSet, HelveticaBoldSet, HelveticaSet, HelveticaBoldSet}, {718, 718, 718, 718}, 3 }, { "Symbol", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 0 }, { "Sym", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 0 }, { "SymbolBold", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 2 }, { "SymB", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 1 }, { "SymbolItalic", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 2 }, { "SymI", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 2 }, { "SymbolBoldItalic", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 3 }, { "SymBI", {SymbolSet, SymbolSet, SymbolSet, SymbolSet}, {673, 673, 673, 673}, 3 }, { "Gothic", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 0 }, { "Goth", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 0 }, { "GothicBold", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 1 }, { "GothB", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 1 }, { "GothicItalic", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 2 }, { "GothI", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 2 }, { "GothicBoldItalic", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 3 }, { "GothBI", {NULL, NULL, NULL, NULL}, {791, 791, 791, 791}, 3 }, { "Mincho", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 0 }, { "Min", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 0 }, { "MinchoBold", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 1 }, { "MinB", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 1 }, { "MinchoItalic", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 2 }, { "MinI", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 2 }, { "MinchoBoldItalic", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 3 }, { "MinBI", {NULL, NULL, NULL, NULL}, {807, 807, 807, 807}, 3 }, }; static NHASH FontDataHash = NULL; static int g2nul_strwidth(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *font, *s, *ptr; int size, width, i, style, w; gunichar ch; s = argv[3]; size = * (int *) argv[4]; font = (char *) argv[5]; style = * (int *) argv[6]; if (s == NULL) { return 0; } w = 0; for (ptr = s; ptr[0]; ptr = g_utf8_next_char(ptr)) { ch = g_utf8_get_char(ptr); width = -1; if (ch < 256 && nhash_get_int(FontDataHash, font, &i) == 0) { if (FontData[i].style >= 0) { style = FontData[i].style; } if (style >= 0 && style < 4 && FontData[i].width[style]) { width = FontData[i].width[style][ch]; } } if (width < 0) { width = 600; } if (g_unichar_iswide(ch)) { width *= 2; } w += width; } rval->i = nround(w * size * 25.4 / 72000.0); return 0; } static int g2nul_charheight(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *font; int size, height, style, i; size=*(int *)(argv[3]); font=(char *)(argv[4]); style = * (int *) argv[5]; height = -1; if (nhash_get_int(FontDataHash, font, &i) == 0) { if (FontData[i].style >= 0) { style = FontData[i].style; } if (style >= 0 && style < 4) { height = FontData[i].height[style]; } } if (height < 0) { height = 562; } rval->i = nround(25.4 / 72000.0 * size * height); return 0; } static int g2nul_chardescent(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int size; size=*(int *)(argv[3]); rval->i=nround(25.4/72000.0*size*250); return 0; } static struct objtable gra2null[] = { {"init",NVFUNC,NEXEC,g2nulinit,NULL,0}, {"done",NVFUNC,NEXEC,g2nuldone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"_strwidth",NIFUNC,0,g2nul_strwidth,NULL,0}, {"_charascent",NIFUNC,0,g2nul_charheight,NULL,0}, {"_chardescent",NIFUNC,0,g2nul_chardescent,NULL,0}, }; #define TBLNUM (sizeof(gra2null) / sizeof(*gra2null)) void * addgra2null(void) /* addgra2null() returns NULL on error */ { unsigned int i; if (FontDataHash == NULL) { FontDataHash = nhash_new(); if (FontDataHash == NULL) { return NULL; } for (i = 0; i < sizeof(FontData) / sizeof(*FontData); i++) { nhash_set_int(FontDataHash, FontData[i].name, i); } } return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,gra2null,ERRNUM,g2nulerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/ofit.h0000644000175000017500000000023213070106167012547 00000000000000#ifndef OFIT_HEADER #define OFIT_HEADER enum FIT_OBJ_TYPE { FIT_TYPE_POLY, FIT_TYPE_POW, FIT_TYPE_EXP, FIT_TYPE_LOG, FIT_TYPE_USER, }; #endif ngraph-gtk-6.08.00/src/olegend.h0000644000175000017500000000477613360310427013242 00000000000000/* * $Id: olegend.h,v 1.6 2009-05-01 09:15:58 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef OLEGEND_HEADER #define OLEGEND_HEADER #define ROTATE_MARK 0 enum FLIP_DIRECTION { FLIP_DIRECTION_HORIZONTAL, FLIP_DIRECTION_VERTICAL, }; int legendgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int legendbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int legendmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int legendrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv); int legendchange(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int legendzoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int legendmatch(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv); void rotate(int px, int py, int angle, int *x, int *y); void flip(int pivot, enum FLIP_DIRECTION dir, int *x, int *y); int legendflip(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv); int put_color_for_backward_compatibility(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); void draw_marker_mark(struct objlist *obj, N_VALUE *inst, int GC, int width, int headlen, int headwidth, int x0, int y0, double dx, double dy, int r, int g, int b, int a, int type); void draw_marker_bar(struct objlist *obj, N_VALUE *inst, int GC, int width, int headlen, int headwidth, int x0, int y0, double dx, double dy); void draw_marker_wave(struct objlist *obj, N_VALUE *inst, int GC, int width, int headlen, int headwidth, int x0, int y0, double dx, double dy, int errspl); int mark_flip(int dir, int type); int mark_rotate(int angle, int type); #endif ngraph-gtk-6.08.00/src/oiarray.h0000644000175000017500000000144213070106167013260 00000000000000#ifndef OIARRAY_HEADER #define OIARRAY_HEADER #include "math/math_equation.h" struct narray *oarray_get_array(struct objlist *obj, N_VALUE *inst, unsigned int size); MathEquation *oarray_create_math(struct objlist *obj, const char *fild, const char *eqn); int oarray_get_index(struct narray *array, int i); int oarray_seq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int oarray_reverse_seq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int oarray_reverse(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int oarray_slice(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int oarray_num(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); #endif /* OIARRAY_HEADER */ ngraph-gtk-6.08.00/src/otext.h0000644000175000017500000000011613070106167012752 00000000000000#define TEXT_OBJ_SCRIPT_SIZE_MIN 1000 #define TEXT_OBJ_SCRIPT_SIZE_MAX 100000 ngraph-gtk-6.08.00/src/oarc.c0000644000175000017500000005140713360370050012533 00000000000000/* * $id: oarc.c,v 1.21 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include "common.h" #include "object.h" #include "gra.h" #include "mathfn.h" #include "oroot.h" #include "odraw.h" #include "olegend.h" #include "oarc.h" #define NAME "arc" #define PARENT "legend" #define OVERSION "1.00.00" #define ERRSPL 100 static char *arcerrorlist[]={ "error: spline interpolation.", }; #define ERRNUM (sizeof(arcerrorlist) / sizeof(*arcerrorlist)) static int arcinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int angle2, width, pieslice, stroke, miter, join, alpha, headlen, headwidth; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; angle2 = 36000; width = DEFAULT_LINE_WIDTH; pieslice = TRUE; miter = 1000; join = JOIN_TYPE_BEVEL; stroke = TRUE; alpha = 255; headlen = 72426; headwidth = 60000; if (_putobj(obj, "pieslice", inst, &pieslice)) return 1; if (_putobj(obj, "angle2", inst, &angle2)) return 1; if (_putobj(obj, "width", inst, &width)) return 1; if (_putobj(obj, "miter_limit", inst, &miter)) return 1; if (_putobj(obj, "join", inst, &join)) return 1; if (_putobj(obj, "stroke", inst, &stroke)) return 1; if (_putobj(obj, "stroke_A", inst, &alpha)) return 1; if (_putobj(obj, "fill_A", inst, &alpha)) return 1; if (_putobj(obj, "arrow_length", inst, &headlen)) return 1; if (_putobj(obj, "arrow_width", inst, &headwidth)) return 1; return 0; } static int arcdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static void get_dx_dy(int rx, int ry, int angle, double *x, double *y, double *dx, double *dy) { double a, b; *x = rx * cos(- angle * MPI / 18000); *y = ry * sin(- angle * MPI / 18000); if (*y == 0) { *dx = 0; if (*x < 0) { *dy = 1; } else { *dy = -1; } } else { a = 1.0 * ry * ry * (*x) / rx / rx / (*y); b = 1 / sqrt(1 + a * a); if (*y < 0) { *dx = -b; } else { *dx = b; } *dy = - a * (*dx); } } static void get_position(int x, int y, int rx, int ry, int a0, int a1, double *x0, double *y0, double *x1, double *y1, double *dx0, double *dy0, double *dx1, double *dy1) { get_dx_dy(rx, ry, a0, x0, y0, dx0, dy0); *x0 += x; *y0 += y; *dx0 = -*dx0; *dy0 = -*dy0; get_dx_dy(rx, ry, a0 + a1, x1, y1, dx1, dy1); *x1 += x; *y1 += y; } static void draw_arrow(int GC, int join, int miter, int width, int headlen, int headwidth, int x, int y, double dx, double dy) { int ax0, ay0, ox, oy; double alen, alen2, awidth; int ap[6]; alen = width * (double) headlen / 10000; awidth = width * (double) headwidth / 20000; ax0 = nround(x - dx * alen); ay0 = nround(y - dy * alen); alen2 = alen * width / awidth / 2; ox = nround(dx * alen2); oy = nround(dy * alen2); ax0 += ox; ay0 += oy; ap[0] = nround(ax0 - dy * awidth); ap[1] = nround(ay0 + dx * awidth); ap[2] = x + nround(ox); ap[3] = y + nround(oy); ap[4] = nround(ax0 + dy * awidth); ap[5] = nround(ay0 - dx * awidth); GRAlinestyle(GC, 0, NULL, 1, GRA_LINE_CAP_BUTT, join, miter); GRAdrawpoly(GC, 3, ap, GRA_FILL_MODE_EVEN_ODD); } static void draw_marker(struct objlist *obj, N_VALUE *inst, int GC, int join, int miter, int width, int x, int y, int rx, int ry, int a0, int a1, int r, int g, int b, int a) { int headlen, headwidth, head_begin, head_end; double x0, y0, x1, y1, dx0, dy0, dx1, dy1; int type; _getobj(obj, "marker_begin", inst, &head_begin); _getobj(obj, "marker_end", inst, &head_end); _getobj(obj, "arrow_length", inst, &headlen); _getobj(obj, "arrow_width", inst, &headwidth); get_position(x, y, rx, ry, a0, a1, &x0, &y0, &x1, &y1, &dx0, &dy0, &dx1, &dy1); switch (head_begin) { case MARKER_TYPE_ARROW: draw_arrow(GC, join, miter, width, headlen, headwidth, x0, y0, dx0, dy0); break; case MARKER_TYPE_WAVE: draw_marker_wave(obj, inst, GC, width, headlen, headwidth, x0, y0, dx0, dy0, ERRSPL); break; case MARKER_TYPE_MARK: _getobj(obj, "mark_type_begin", inst, &type); draw_marker_mark(obj, inst, GC, width, headlen, headwidth, x0, y0, dx0, dy0, r, g, b, a, type); break; case MARKER_TYPE_BAR: draw_marker_bar(obj, inst, GC, width, headlen, headwidth, x0, y0, dx0, dy0); break; } switch (head_end) { case MARKER_TYPE_ARROW: draw_arrow(GC, join, miter, width, headlen, headwidth, x1, y1, dx1, dy1); break; case MARKER_TYPE_WAVE: draw_marker_wave(obj, inst, GC, width, headlen, headwidth, x1, y1, dx1, dy1, ERRSPL); break; case MARKER_TYPE_MARK: _getobj(obj, "mark_type_end", inst, &type); draw_marker_mark(obj, inst, GC, width, headlen, headwidth, x1, y1, dx1, dy1, r, g, b, a, type); break; case MARKER_TYPE_BAR: draw_marker_bar(obj, inst, GC, width, headlen, headwidth, x1, y1, dx1, dy1); break; } } static int arcdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; int x,y,rx,ry,angle1,angle2,width,ifill,fr,fg,fb,fa,w,h,stroke,close_path,br,bg,bb, ba, join, miter; int pieslice; struct narray *style; int snum,*sdata; int clip,zoom; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; _getobj(obj,"stroke_R",inst,&fr); _getobj(obj,"stroke_G",inst,&fg); _getobj(obj,"stroke_B",inst,&fb); _getobj(obj,"stroke_A",inst,&fa); _getobj(obj,"fill_R",inst,&br); _getobj(obj,"fill_G",inst,&bg); _getobj(obj,"fill_B",inst,&bb); _getobj(obj,"fill_A",inst,&ba); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"rx",inst,&rx); _getobj(obj,"ry",inst,&ry); _getobj(obj,"pieslice",inst,&pieslice); _getobj(obj,"angle1",inst,&angle1); _getobj(obj,"angle2",inst,&angle2); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); _getobj(obj, "join", inst, &join); _getobj(obj, "miter_limit", inst, &miter); _getobj(obj,"fill",inst,&ifill); _getobj(obj,"stroke",inst,&stroke); _getobj(obj,"close_path",inst,&close_path); _getobj(obj,"clip",inst,&clip); if (! ifill && ! stroke) { return 0; } snum=arraynum(style); sdata=arraydata(style); GRAregion(GC,&w,&h,&zoom); GRAview(GC,0,0,w*10000.0/zoom,h*10000.0/zoom,clip); if (ifill) { GRAcolor(GC,br,bg,bb, ba); GRAcircle(GC, x, y, rx, ry, angle1, angle2, (pieslice) ? 1 : 2); } if (stroke) { GRAcolor(GC,fr,fg,fb, fa); GRAlinestyle(GC, snum, sdata, width, GRA_LINE_CAP_BUTT, join, miter); GRAcircle(GC, x, y, rx, ry, angle1, angle2, (close_path) ? ((pieslice) ? 3 : 4) : 0); draw_marker(obj, inst, GC, join, miter, width, x, y, rx, ry, angle1, angle2, fr, fg, fb, fa); } GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int arcgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; int val; field = (char *) (argv[1]); val = * (int *) (argv[2]); if (strcmp(field,"width")==0) { if (val < 1) val = 1; } else if (strcmp(field, "rx") == 0 || strcmp(field, "ry") == 0) { if (val < 1) val = 1; } else if (strcmp(field, "angle1") == 0){ if (val < 0) { val %= 36000; if (val < 0) { val += 36000; } } else if (val > 36000) { val %= 36000; } } else if (strcmp(field, "angle2") == 0) { if (val < 0) { val = 0; } else if (val > 36000) { val = 36000; } } else if (strcmp(field, "arrow_length") == 0) { if (val < ARROW_SIZE_MIN) { val = ARROW_SIZE_MIN; } else if (val > ARROW_SIZE_MAX) { val = ARROW_SIZE_MAX; } } else if (strcmp(field, "arrow_width") == 0) { if (val < ARROW_SIZE_MIN) { val = ARROW_SIZE_MIN; } else if (val > ARROW_SIZE_MAX) { val = ARROW_SIZE_MAX; } } * (int *)(argv[2]) = val; if (clear_bbox(obj, inst)) return 1; return 0; } static int arcbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy; int x,y,x1,y1, head_begin, head_end; int x0,y0,angle1,angle2,rx,ry,pieslice,fill,stroke,close_path; struct narray *array; int i,width; array=rval->array; if (arraynum(array)!=0) return 0; _getobj(obj,"x",inst,&x0); _getobj(obj,"y",inst,&y0); _getobj(obj,"rx",inst,&rx); _getobj(obj,"ry",inst,&ry); _getobj(obj,"angle1",inst,&angle1); _getobj(obj,"angle2",inst,&angle2); _getobj(obj,"fill",inst,&fill); _getobj(obj,"stroke",inst,&stroke); _getobj(obj,"pieslice",inst,&pieslice); _getobj(obj,"close_path",inst,&close_path); _getobj(obj,"width",inst,&width); angle2+=angle1; if (! fill && ! stroke) { return 0; } if (angle2maxx) maxx=x; if (ymaxy) maxy=y; for (i=angle1/9000+1;i<=angle2/9000;i++) { x=x0+rx*cos(i*MPI/2); y=y0-ry*sin(i*MPI/2); if (xmaxx) maxx=x; if (ymaxy) maxy=y; } if (pieslice && (fill || close_path)) { x=x0; y=y0; if (xmaxx) maxx=x; if (ymaxy) maxy=y; } if (stroke) { minx-=width/2; miny-=width/2; maxx+=width/2; maxy+=width/2; } _getobj(obj, "marker_begin", inst, &head_begin); _getobj(obj, "marker_end", inst, &head_end); if (head_begin != MARKER_TYPE_NONE || head_end != MARKER_TYPE_NONE) { double awidth; int headwidth; _getobj(obj, "arrow_width", inst, &headwidth); awidth = width * (double) headwidth / 10000; if (((head_begin == MARKER_TYPE_MARK || head_begin == MARKER_TYPE_ARROW) && (head_end == MARKER_TYPE_MARK || head_end == MARKER_TYPE_ARROW)) || ((head_begin == MARKER_TYPE_MARK || head_begin == MARKER_TYPE_ARROW) && head_end == MARKER_TYPE_NONE) || (head_begin == MARKER_TYPE_NONE && (head_end == MARKER_TYPE_MARK || head_end == MARKER_TYPE_ARROW))) { awidth /= 2; } minx -= awidth; miny -= awidth; maxx += awidth; maxy += awidth; } arrayins(array,&maxy,0); arrayins(array,&maxx,0); arrayins(array,&miny,0); arrayins(array,&minx,0); /* ARC_POINT_TYPE_R */ x = x0 - rx; y = y0 - ry; arrayadd(array, &x); arrayadd(array, &y); /* ARC_POINT_TYPE_ANGLE1 */ arrayadd(array, &x1); arrayadd(array, &y1); /* ARC_POINT_TYPE_ANGLE2 */ if (angle2 - angle1 < 36000) { x = x0 + rx * cos(angle2 * MPI / 18000); y = y0 - ry * sin(angle2 * MPI / 18000); arrayadd(array, &x); arrayadd(array, &y); } if (arraynum(array) == 0) { arrayfree(array); rval->array = NULL; return 1; } rval->array = array; return 0; } static int arcmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); x+=*(int *)argv[2]; y+=*(int *)argv[3]; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int arcchange(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int point, a1, a2, rx, ry, ret; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; point = * (int *) argv[2]; a1 = * (int *) argv[3]; a2 = * (int *) argv[4]; ret = 1; switch (point) { case ARC_POINT_TYPE_R: _getobj(obj, "rx", inst, &rx); _getobj(obj, "ry", inst, &ry); rx -= a1; ry -= a2; if (rx > 0) ret = _putobj(obj, "rx", inst, &rx); if (ry > 0) ret = _putobj(obj, "ry", inst, &ry); break; case ARC_POINT_TYPE_ANGLE1: case ARC_POINT_TYPE_ANGLE2: ret = _putobj(obj, "angle1", inst, &a1); ret = _putobj(obj, "angle2", inst, &a2); break; default: return 1; } if (ret) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int arcrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int angle, rx, ry, a, use_pivot, type_begin, type_end; _getobj(obj, "rx", inst, &rx); _getobj(obj, "ry", inst, &ry); _getobj(obj, "angle1", inst, &a); _getobj(obj, "mark_type_begin", inst, &type_begin); _getobj(obj, "mark_type_end", inst, &type_end); angle = *(int *) argv[2]; #if ! ROTATE_MARK type_begin = mark_rotate(angle, type_begin); type_end = mark_rotate(angle, type_end); _putobj(obj, "mark_type_begin", inst, &type_begin); _putobj(obj, "mark_type_end", inst, &type_end); #endif angle %= 36000; if (angle < 0) angle += 36000; switch (angle) { case 9000: case 27000: _putobj(obj, "rx", inst, &ry); _putobj(obj, "ry", inst, &rx); /* fall through */ case 18000: a += angle; break; default: return 1; } a %= 36000; _putobj(obj, "angle1", inst, &a); use_pivot = * (int *) argv[3]; if (use_pivot) { int x, y, px, py; px = *(int *) argv[4]; py = *(int *) argv[5]; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); rotate(px, py, angle, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); } if (clear_bbox(obj, inst)) return 1; return 0; } static int arcflip(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int rx, ry, a1, a2, use_pivot, head_begin, head_end, type_begin, type_end; enum FLIP_DIRECTION dir; _getobj(obj, "rx", inst, &rx); _getobj(obj, "ry", inst, &ry); _getobj(obj, "angle1", inst, &a1); _getobj(obj, "angle2", inst, &a2); _getobj(obj, "marker_begin", inst, &head_begin); _getobj(obj, "marker_end", inst, &head_end); _getobj(obj, "mark_type_begin", inst, &type_begin); _getobj(obj, "mark_type_end", inst, &type_end); dir = (* (int *) argv[2] == FLIP_DIRECTION_HORIZONTAL) ? FLIP_DIRECTION_HORIZONTAL : FLIP_DIRECTION_VERTICAL; _putobj(obj, "marker_begin", inst, &head_end); _putobj(obj, "marker_end", inst, &head_begin); #if ROTATE_MARK type_begin = mark_flip(FLIP_DIRECTION_HORIZONTAL, type_begin); type_end = mark_flip(FLIP_DIRECTION_HORIZONTAL, type_end); #else type_begin = mark_flip(dir, type_begin); type_end = mark_flip(dir, type_end); #endif _putobj(obj, "mark_type_begin", inst, &type_end); _putobj(obj, "mark_type_end", inst, &type_begin); switch (dir) { case FLIP_DIRECTION_VERTICAL: a1 = - a1 - a2; break; case FLIP_DIRECTION_HORIZONTAL: a1 = 18000 - a1 - a2; break; } a1 %= 36000; if (a1 < 0) a1 += 36000; _putobj(obj, "angle1", inst, &a1); use_pivot = * (int *) argv[3]; if (use_pivot) { int x, y, p; p = *(int *) argv[4]; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); flip(p, dir, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); } if (clear_bbox(obj, inst)) return 1; return 0; } static int arczoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i,snum,*sdata,rx,ry,x,y,refx,refy,width,preserve_width; double zoom_x, zoom_y; struct narray *style; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; zoom_x = (*(int *) argv[2]) / 10000.0; zoom_y = (*(int *) argv[3]) / 10000.0; refx = (*(int *)argv[4]); refy = (*(int *)argv[5]); preserve_width = (*(int *)argv[6]); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"rx",inst,&rx); _getobj(obj,"ry",inst,&ry); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); snum=arraynum(style); sdata=arraydata(style); x=(x-refx)*zoom_x+refx; y=(y-refy)*zoom_y+refy; rx=rx*zoom_x; ry=ry*zoom_y; if (rx < 1) rx = 1; if (ry < 1) ry = 1; if (! preserve_width) { double zoom; zoom = MIN(zoom_x, zoom_y); width=width*zoom; for (i=0;ii=FALSE; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); if (array==NULL) return 0; minx=*(int *)(argv[2]); miny=*(int *)(argv[3]); maxx=*(int *)(argv[4]); maxy=*(int *)(argv[5]); err=*(int *)(argv[6]); if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx==maxx) && (miny==maxy)) { bminx-=err; bminy-=err; bmaxx+=err; bmaxy+=err; if ((bminx<=minx) && (minx<=bmaxx) && (bminy<=miny) && (miny<=bmaxy)) rval->i=TRUE; } else { if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } static struct objtable arc[] = { {"init",NVFUNC,NEXEC,arcinit,NULL,0}, {"done",NVFUNC,NEXEC,arcdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"x",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"y",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"rx",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"ry",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"angle1",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"angle2",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"pieslice",NBOOL,NREAD|NWRITE,arcgeometry,NULL,0}, {"fill_R",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_G",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_B",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill_A",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_R",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_G",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_B",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"stroke_A",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"fill",NBOOL,NREAD|NWRITE,arcgeometry,NULL,0}, {"stroke",NBOOL,NREAD|NWRITE,arcgeometry,NULL,0}, {"close_path",NBOOL,NREAD|NWRITE,arcgeometry,NULL,0}, {"width",NINT,NREAD|NWRITE,arcgeometry,NULL,0}, {"style",NIARRAY,NREAD|NWRITE,oputstyle,NULL,0}, {"join",NENUM,NREAD|NWRITE,NULL,joinchar,0}, {"miter_limit",NINT,NREAD|NWRITE,oputge1,NULL,0}, {"marker_begin", NENUM, NREAD|NWRITE, arcgeometry, marker_type_char, 0}, {"marker_end", NENUM, NREAD|NWRITE, arcgeometry, marker_type_char, 0}, {"arrow_length", NINT, NREAD|NWRITE, arcgeometry, NULL, 0}, {"arrow_width", NINT, NREAD|NWRITE, arcgeometry, NULL, 0}, {"mark_type_begin",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"mark_type_end",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,arcdraw,"i",0}, {"bbox",NIAFUNC,NREAD|NEXEC,arcbbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,arcmove,"ii",0}, {"rotate",NVFUNC,NREAD|NEXEC,arcrotate,"iiii",0}, {"flip",NVFUNC,NREAD|NEXEC,arcflip,"iii",0}, {"change",NVFUNC,NREAD|NEXEC,arcchange,"iii",0}, {"zooming",NVFUNC,NREAD|NEXEC,arczoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,arcmatch,"iiiii",0}, {"fill_hsb", NVFUNC, NREAD|NEXEC, put_fill_hsb,"ddd",0}, {"stroke_hsb", NVFUNC, NREAD|NEXEC, put_stroke_hsb,"ddd",0}, /* following fields exist for backward compatibility */ {"R",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"G",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"B",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, {"A",NINT,NWRITE,put_color_for_backward_compatibility,NULL,0}, }; #define TBLNUM (sizeof(arc) / sizeof(*arc)) void * addarc(void) /* addarc() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,arc,ERRNUM,arcerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/shell.h0000644000175000017500000001105013070106167012715 00000000000000#ifndef _SHELL_HEADER #define _SHELL_HEADER /* * $Id: shell.h,v 1.14 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include "ioutil.h" #define SHELLBUFSIZE 4096 #define ERRUEXPEOF 100 #define ERRBADSUB 101 #define ERRSYNTAX 102 #define ERRUEXPTOK 103 #define ERRIDENT 104 #define ERRCFOUND 105 #define ERRSYSTEM 106 #define ERREXTARG 107 #define ERRSMLARG 108 #define ERRMANYARG 109 #define ERRNOFILE 110 #define ERREOF 111 #define ERRNOFIL 112 #define ERRREAD 113 #define ERROPEN 114 #define ERROBJARG 115 #define ERRINSTARG 116 #define ERRNEWINST 117 #define ERRCMFIELD 118 #define ERRVALUE 119 #define ERRTWOINST 120 #define ERRNONEINST 121 #define ERRNOFIELD 122 #define ERRNUMERIC 123 #define ERROPTION 124 #define ERRILOPS 125 #define ERRUNSET 126 #define ERRNODIR 127 #define ERRMSYNTAX 128 #define ERRMILLEGAL 129 #define ERRMNEST 130 #define ERRMARG 131 #define ERRMFAT 132 #define ERRTESTNEST 133 #define ERRTESTSYNTAX 134 #define ERRSECURITY 135 #define ERRMEMORY 136 #define ERRUNKNOWNSH 137 struct prmlist; struct prmlist { struct prmlist *next; char *str; int prmno; int quoted; }; struct cmdlist; struct cmdlist { struct cmdlist *next; int cmdno; int cmdend; struct prmlist *prm; void *done; char *pipefile; }; struct vallist; struct vallist { struct vallist *next; char *name; void *val; int func; int arg; }; struct explist; struct explist { char *val; struct explist *next; }; struct nshell { struct objlist *obj; #if USE_HASH NHASH exproot, valroot; #else struct vallist *valroot; struct explist *exproot; #endif int argc; char **argv; int cmdexec; int status; int quit; int options; int optionf; int optione; int optionv; int optionx; int fd; char *readbuf; int readpo; int readbyte; int deleted; int (*sgetstdin)(); int (*sputstdout)(const char *s); int (*sprintfstdout)(const char *fmt,...); }; extern int CMDNUM; typedef int (* shell_proc)(struct nshell *nshell,int argc,char **argv); struct cmdtabletype { char *name; shell_proc proc; }; extern struct cmdtabletype cmdtable[]; extern int CPCMDNUM; extern char *cpcmdtable[]; shell_proc check_cmd(char *name); int check_cpcmd(char *name); int init_cmd_tbl(void); void nsleep(double a); int eval_script(const char *script, int security); char *addval(struct nshell *nshell,char *name,char *val); char *addexp(struct nshell *nshell,char *name); int delval(struct nshell *nshell,char *name); char *getval(struct nshell *nshell,char *name); struct cmdlist *getfunc(struct nshell *nshell,char *name); void setshhandle(struct nshell *shell, int fd); int getshhandle(struct nshell *nshell); int cmdexecute(struct nshell *nshell, const char *cline); struct nshell *newshell(void); void delshell(struct nshell *nshell); void sherror(int code); void sherror2(int code,char *mes); void sherror3(char *cmd,int code,char *mes); void sherror4(char *cmd,int code); void shellsavestdio(struct nshell *nshell); void shellrestorestdio(struct nshell *nshell); int setshelloption(struct nshell *nshell,char *opt); int getshelloption(struct nshell *nshell,char opt); int set_shell_args(struct nshell *nshell, int j, const char *argv0, int argc, char **argv); void setshellargument(struct nshell *nshell,int argc,char **argv); int printfconsole(const char *fmt,...); void ngraphenvironment(struct nshell *nshell); int msleep(int ms); void set_security(int state); int get_security(void); void set_environ(void); void set_childhandler(void); void unset_childhandler(void); int system_bg(char *cmd); void set_interrupt(void); int check_interrupt(void); void reset_interrupt(void); #if WINDOWS void show_system_error(void); #else int set_signal(int signal, int flags, void (*handler)(int), struct sigaction *oldact); #endif /* WINDOWS */ #endif ngraph-gtk-6.08.00/src/gra.h0000644000175000017500000001550113356133076012372 00000000000000/* * $Id: gra.h,v 1.5 2010-01-04 05:11:28 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "object.h" #ifndef GRA_HEADER #define GRA_HEADER #define EXPAND_DOTTED_LINE 0 #define CURVE_OBJ_USE_EXPAND_BUFFER 1 struct greektbltype { unsigned int jis,symbol; }; extern struct greektbltype greektable[]; struct GRAbbox { int set; int offsetx; int offsety; int minx; int miny; int maxx; int maxy; int posx; int posy; int pt; int spc; int dir; int linew; int clip; int clipsizex; int clipsizey; char *fontalias; int font_style; int loadfont; }; struct GRAdata { char code; int *cpar; char *cstr; struct GRAdata *next; }; typedef int (*clipfunc)(double *x0,double *y0,double *x1,double *y1, void *local); typedef void (*transfunc)(double x0,double y0,int *x1,int *y1,void *local); typedef void (*diffunc)(double d,double c[], double *dx,double *dy,double *ddx,double *ddy, void *local); typedef void (*intpfunc)(double d,double c[], double x0,double y0,double *x,double *y,void *local); typedef int (*directfunc)(char code,int *cpar,char *cstr,void *local); struct cmatchtype { double x0,y0; int minx,miny,maxx,maxy; int pointx,pointy; int err; clipfunc gclipf; transfunc gtransf; diffunc gdiff; intpfunc gintpf; void *gflocal; int bbox,bboxset; int match; }; enum GRA_FONT_STYLE { GRA_FONT_STYLE_NORMAL = 0, GRA_FONT_STYLE_BOLD = 1, GRA_FONT_STYLE_ITALIC = 2, }; enum GRA_LINE_CAP { GRA_LINE_CAP_BUTT = 0, GRA_LINE_CAP_ROUND = 1, GRA_LINE_CAP_PROJECTING = 2, }; enum GRA_LINE_JOIN { GRA_LINE_JOIN_MITER = 0, GRA_LINE_JOIN_ROUND = 1, GRA_LINE_JOIN_BEVEL = 2, }; enum GRA_FILL_MODE { GRA_FILL_MODE_NONE = 0, GRA_FILL_MODE_EVEN_ODD = 1, GRA_FILL_MODE_WINDING = 2, }; extern struct greektbltype greektable[48]; int _GRAopencallback(directfunc direct,struct narray **list,void *local); int _GRAopen(const char *objname,const char *outputname, struct objlist *obj,N_VALUE *inst, int output, int strwidth,int charascent,int chardescent, struct narray **list,void *local); int GRAopen(const char *objname,const char *outputname, struct objlist *obj,N_VALUE *inst, int output, int strwidth,int charascent,int chardescent, struct narray **list,void *local); int GRAreopen(int GC); int GRAopened(int GC); void _GRAclose(int GC); void GRAclose(int GC); void GRAredraw(struct objlist *obj,N_VALUE *inst,int setredrawf,int redrawf); void GRAredraw_layers(struct objlist *obj, N_VALUE *inst, int setredrawf, int redraw_num, char **objects); void GRAaddlist(int GC,struct objlist *obj,N_VALUE *inst, const char *objname, const char *field); void GRAinslist(int GC,struct objlist *obj,N_VALUE *inst, const char *objname, const char *field,int n); void GRAdellist(int GC,int n); struct objlist *GRAgetlist(int GC,int *oid,char **field,int n); int GRAdraw(int GC,char code,int *cpar,char *cstr); int GRAinit(int GC,int leftm,int topm,int width,int height,int zoom); void GRAregion(int GC,int *width,int *height,int *zoom); int GRAend(int GC); void GRAview(int GC,int x1,int y1,int x2,int y2,int clip); void GRAwindow(int GC,double minx,double miny,double maxx,double maxy); void GRAlinestyle(int GC,int num,int *type, int width,enum GRA_LINE_CAP cap,enum GRA_LINE_JOIN join,int miter); void GRAcolor(int GC, int fr, int fg, int fb, int fa); void GRAmoveto(int GC,int x,int y); void GRAline(int GC,int x0,int y0,int x1,int y1); void GRAlineto(int GC,int x,int y); void GRAcircle(int GC,int x,int y,int rx,int ry,int cs,int ce,int fil); void GRArectangle(int GC,int x0,int y0,int x1,int y1,int fil); void GRAdrawpoly(int GC,int num,int *point,enum GRA_FILL_MODE fil); void GRAlines(int GC,int num,int *point); void GRArotate(int x0, int y0, int *pos, int *rpos, int n, double dx, double dy); void GRAmark_rotate(int GC,int type,int x0,int y0, double dx, double dy, int size, int fr,int fg,int fb, int fa, int br,int bg,int bb, int ba); void GRAmark(int GC,int type,int x0,int y0,int size, int fr,int fg,int fb, int fa, int br,int bg,int bb, int ba); void GRAdrawtext(int GC,char *s,char *font, int style, int size, int space, int dir, int scriptsize); void GRAdrawtextraw(int GC,char *s,char *font, int style, int size,int space,int dir); void GRAtextextent(char *s,char *font, int style, int size,int space,int scriptsize, int *gx0,int *gy0,int *gx1,int *gy1,int raw); void GRAtextextentraw(char *s,char *font, int style, int size,int space,int *gx0,int *gy0,int *gx1,int *gy1); int GRAinput(int GC,char *s,int leftm,int topm,int rate_x,int rate_y); int GRAinputold(int GC,char *s,int leftm,int topm,int rate_x,int rate_y); void GRAcurvefirst(int GC,int num,int *dashlist, clipfunc clipf,transfunc transf,diffunc diff,intpfunc intpf,void *local, double x0,double y0); int GRAcurve(int GC,double c[],double x0,double y0); void GRAdashmovetod(int GC,double x1,double y1); void GRAdashlinetod(int GC,double x1,double y1); void GRAcmatchfirst(int pointx,int pointy,int err, clipfunc clipf,transfunc transf,diffunc diff,intpfunc intpf,void *local, struct cmatchtype *data,int bbox,double x0,double y0); int GRAcmatch(double c[],double x0,double y0,struct cmatchtype *data); void GRAinitbbox(struct GRAbbox *bbox); void GRAendbbox(struct GRAbbox *bbox); int GRAboundingbox(char code,int *cpar,char *cstr,void *local); void GRAtextstyle(int GC,char *font,int style, int size,int space,int dir); void GRAouttext(int GC,char *s); void GRAlayer(int GC,const char *s); int GRAlayer_support(int GC); void GRAcurrent_point(int GC, int *x, int *y); void GRAdata_free(struct GRAdata *data); int GRAparse(struct GRAdata *data, char *s); int GRAinputdraw(int GC,int leftm,int topm,int rate_x,int rate_y,char code,int *cpar,char *cstr); int calc_zoom_direction(int direction, double zx, double zy, double *zp, double *zn); #endif ngraph-gtk-6.08.00/src/axis.c0000644000175000017500000001724013324613425012556 00000000000000/* * $Id: axis.c,v 1.7 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include "mathfn.h" #include "object.h" #include "axis.h" #ifdef HAVE_LIBGSL #include #endif double scale(double x) { return pow(10.0,cutdown(log10(fabs(x)))); } double roundmin(double min,double sc) { return nraise(min/sc)*sc; } static void getaxispositionfirst(struct axislocal *alocal) { double min,max,inc; int numlim1,numlim2,numlim3; if (alocal->tighten) { numlim1=6; numlim2=11; numlim3=21; } else { numlim1=2; numlim2=3; numlim3=6; } if ((alocal->atype==AXISNORMAL) || (alocal->atype==AXISLOGBIG)) { if (alocal->div<=0) { if (alocal->num<=numlim1) alocal->countsend=10; else if (alocal->num<=numlim2) alocal->countsend=5; else if (alocal->num<=numlim3) alocal->countsend=2; else alocal->countsend=1; } else alocal->countsend=alocal->div; alocal->dposl=alocal->inc*10; alocal->posl=roundmin(alocal->posst,alocal->dposl)-alocal->dposl; alocal->dposm=alocal->inc; alocal->posm=roundmin(alocal->posst,alocal->dposm)-alocal->dposm; alocal->countmend=10; alocal->countm= nround((roundmin(alocal->posst,alocal->dposm)-alocal->posl)/alocal->dposm); alocal->dposs=alocal->dposm/alocal->countsend; alocal->counts=1; } else if (alocal->atype==AXISINVERSE) { if (alocal->div<=0) { if (alocal->num<=numlim1) alocal->countsend=10; else if (alocal->num<=numlim2) alocal->countsend=5; else if (alocal->num<=numlim3) alocal->countsend=2; else alocal->countsend=1; } else alocal->countsend=alocal->div; if (((alocal->max>alocal->min) && (alocal->min>0)) || ((alocal->maxmin) && (alocal->min<0))) { max=alocal->min; min=alocal->max; inc=alocal->inc*(-1); } else { min=alocal->min; max=alocal->max; inc=alocal->inc; } alocal->dposm=inc; alocal->posm=roundmin(min,alocal->dposm)-alocal->dposm; alocal->countmend=(max-alocal->posm)/alocal->dposm; alocal->countm=1; alocal->dposl=alocal->dposm*alocal->countmend; alocal->posl=alocal->posm; alocal->dposs=alocal->dposm/alocal->countsend; alocal->counts=1; } else if (alocal->atype==AXISLOGNORM) { if (alocal->div==1) { alocal->countsend=1; if (alocal->inc>0) alocal->dposs=9; else alocal->dposs=-0.9; } else if (alocal->div==2) { alocal->countsend=2; if (alocal->inc>0) alocal->dposs=4; else alocal->dposs=-0.5; } else { alocal->countsend=9; if (alocal->inc>0) alocal->dposs=1; else alocal->dposs=-0.1; } alocal->dposl=alocal->inc*10; alocal->posl=roundmin(alocal->posst,alocal->dposl)-alocal->dposl; alocal->dposm=alocal->inc; alocal->posm=roundmin(alocal->posst,alocal->dposm)-alocal->dposm; alocal->countmend=10; alocal->countm= nround((roundmin(alocal->posst,alocal->dposm)-alocal->posl)/alocal->dposm); alocal->counts=1; } else if (alocal->atype==AXISLOGSMALL) { if (alocal->div<=0) { if (alocal->num<=numlim1) alocal->countsend=10; else if (alocal->num<=numlim2) alocal->countsend=5; else if (alocal->num<=numlim3) alocal->countsend=2; else alocal->countsend=1; } else alocal->countsend=alocal->div; alocal->dposl=alocal->inc; alocal->posl=roundmin(alocal->posst,alocal->dposl)-alocal->dposl; if (alocal->dposl>0) alocal->dposm=1; else alocal->dposm=-0.1; alocal->posm=alocal->posl; alocal->countmend=9; alocal->countm=1; alocal->dposs=1.0/alocal->countsend; alocal->counts=1; } alocal->count=0; } int getaxisposition(struct axislocal *alocal, /*@out@*/ double *po) { int rcode; double dd; if (alocal->counts>=alocal->countsend) { if (alocal->atype==AXISLOGSMALL) *po=alocal->posl+log10(1.0+alocal->countm*alocal->dposm); else *po=alocal->posm+alocal->dposm; alocal->posm=*po; alocal->counts=1; rcode=2; if (alocal->countm==alocal->countmend) { *po=alocal->posl+alocal->dposl; alocal->posl=*po; alocal->countm=1; rcode=3; if (alocal->atype==AXISINVERSE) { if (((alocal->dposm>=0) && (alocal->min>=0)) || ((alocal->dposm<0) && (alocal->min<0))) dd=10; else dd=0.1; alocal->dposl*=dd; alocal->dposm*=dd; alocal->dposs*=dd; alocal->countmend=-1; } } else alocal->countm++; } else { rcode=1; if (alocal->atype==AXISLOGNORM) *po=alocal->posm+log10(1.0+alocal->counts*alocal->dposs); else if (alocal->atype==AXISLOGSMALL) *po=log10(pow(10.0, alocal->posm) + alocal->counts * alocal->dposs * pow(10.0, alocal->posl) * alocal->dposm); else *po=alocal->posm+alocal->counts*alocal->dposs; alocal->counts++; } if (fabs(*po/alocal->dposs)<1E-14) *po=0; if ((*po-alocal->posst)*(*po-alocal->posed)>0 #ifdef HAVE_LIBGSL && gsl_fcmp(*po, alocal->posst, N_EPSILON) && gsl_fcmp(*po, alocal->posed, N_EPSILON) #endif ) { if (alocal->dposm>=0) { if (((alocal->posst<=alocal->posed) && (*poposst)) || ((alocal->posst>=alocal->posed) && (*poposed))) rcode=-1; else rcode=-2; } else { if (((alocal->posst<=alocal->posed) && (*po>alocal->posed)) || ((alocal->posst>=alocal->posed) && (*po>alocal->posst))) rcode=-1; else rcode=-2; } } if ((alocal->atype==AXISINVERSE) && (rcode>=0)) *po=1 / *po; alocal->count++; if (alocal->count>=10000) rcode=-2; return rcode; } int getaxispositionini(struct axislocal *alocal, int type, double min,double max,double inc,int div,int tighten) { double po; int rcode; int num; if (compare_double(min, max)) return -1; if (compare_double(inc, 0)) return -1; if (type==AXIS_TYPE_LOG) { if ((min<=0) || (max<=0)) return -1; if (compare_double(fabs(inc), 10)) { alocal->atype=AXISLOGNORM; } else if (compare_double(fabs(inc), 1)) { alocal->atype=AXISLOGSMALL; } else { alocal->atype=AXISLOGBIG; } alocal->min=log10(min); alocal->max=log10(max); alocal->inc=log10(fabs(inc)); if (alocal->atype==AXISLOGSMALL) alocal->inc=1; } else if (type==AXIS_TYPE_INVERSE) { if (min*max<=0) return -1; alocal->atype=AXISINVERSE; alocal->min=min; alocal->max=max; alocal->inc=inc; } else { alocal->atype=AXISNORMAL; alocal->min=min; alocal->max=max; alocal->inc=inc; } if (alocal->maxmin) alocal->inc=-fabs(alocal->inc); else alocal->inc=fabs(alocal->inc); alocal->div=div; alocal->posst=alocal->min; alocal->posed=alocal->max; alocal->num=100; alocal->tighten=tighten; getaxispositionfirst(alocal); num=0; while ((rcode=getaxisposition(alocal,&po))!=-2) { if (rcode>=2) num++; } alocal->num=num; if (alocal->count>1000) return -1; getaxispositionfirst(alocal); return 0; } ngraph-gtk-6.08.00/src/strconv.c0000644000175000017500000000361413070106167013306 00000000000000/* * $Id: strconv.c,v 1.2 2010-03-04 08:30:16 hito Exp $ */ #include "common.h" #include #include #include #include "object.h" gchar * ascii2greece(const gchar *src) { int i, j, k, c, len, slen, dlen; static char *u[] = {"Α", "Î’", "Χ", "Δ", "Ε", "Φ", "Γ", "Η", "Ι", "Ï‘", "Κ", "Λ", "Μ", "Î", "Ο", "Π", "Θ", "Ρ", "Σ", "Τ", "Î¥", "Ï›", "Ω", "Ξ", "Ψ", "Ζ"}; static char *l[] = {"α", "β", "χ", "δ", "ε", "Ï•", "γ", "η", "ι", "φ", "κ", "λ", "μ", "ν", "ο", "Ï€", "θ", "Ï", "σ", "Ï„", "Ï…", "Ï–", "ω", "ξ", "ψ", "ζ"}; gchar *tmp, *ch, buf[2]; slen = strlen(src); dlen = slen * 6 + 1; tmp = g_malloc(dlen); if (tmp == NULL) return NULL; tmp[0] = '\0'; for (i = j = 0; i < slen; i++) { if (src[i] >= 'a' && src[i] <= 'z') { c = src[i] - 'a'; ch = l[c]; } else if (src[i] >= 'A' && src[i] <= 'Z') { c = src[i] - 'A'; ch = u[c]; } else { buf[0] = src[i]; buf[1] = '\0'; ch = buf; } len = strlen(ch); for (k = 0; k < len; k++) { tmp[j++] = ch[k]; } tmp[j] = '\0'; } return tmp; } static char * str2utf8(char *str, char *scode, char *dcode) { GIConv cd; size_t l, slen, dlen; char *tmp, *ptr; if (str == NULL) return NULL; cd = g_iconv_open(dcode, scode); if (cd == (GIConv)(-1)) { g_iconv_close(cd); return NULL; } slen = strlen(str); dlen = slen * 6 + 1; tmp = g_malloc(dlen); if (tmp == NULL) return NULL; ptr = tmp; l = g_iconv(cd, &str, &slen, &ptr, &dlen); if (l == (size_t)(-1)) { g_free(tmp); tmp = NULL; } else { *ptr = '\0'; } g_iconv_close(cd); return tmp; } char * sjis_to_utf8(char *src) { return str2utf8(src, "CP932", "utf-8//TRANSLIT"); } char * utf8_to_sjis(char *src) { return str2utf8(src, "utf-8", "CP932//TRANSLIT"); } ngraph-gtk-6.08.00/src/omark.c0000644000175000017500000002276313356560325012736 00000000000000/* * $Id: omark.c,v 1.16 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include "object.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "olegend.h" #define NAME "mark" #define PARENT "legend" #define OVERSION "1.00.00" #define MODIFY_MARK_TYPE 0 static char *markerrorlist[]={ "", }; #define ERRNUM (sizeof(markerrorlist) / sizeof(*markerrorlist)) static int markinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int size,width,r2,g2,b2,a2; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; size=DEFAULT_MARK_SIZE; width=DEFAULT_LINE_WIDTH; r2=255; g2=255; b2=255; a2=255; if (_putobj(obj,"size",inst,&size)) return 1; if (_putobj(obj,"width",inst,&width)) return 1; if (_putobj(obj,"R2",inst,&r2)) return 1; if (_putobj(obj,"G2",inst,&g2)) return 1; if (_putobj(obj,"B2",inst,&b2)) return 1; if (_putobj(obj,"A2",inst,&a2)) return 1; return 0; } static int markdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int markdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; int x,y,type,size,width,fr,fg,fb,fa,br,bg,bb,ba,w,h; struct narray *style; int snum,*sdata; int clip,zoom; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; _getobj(obj,"R",inst,&fr); _getobj(obj,"G",inst,&fg); _getobj(obj,"B",inst,&fb); _getobj(obj,"A",inst,&fa); _getobj(obj,"R2",inst,&br); _getobj(obj,"G2",inst,&bg); _getobj(obj,"B2",inst,&bb); _getobj(obj,"A2",inst,&ba); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"type",inst,&type); _getobj(obj,"size",inst,&size); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); _getobj(obj,"clip",inst,&clip); snum=arraynum(style); sdata=arraydata(style); GRAregion(GC,&w,&h,&zoom); GRAview(GC,0,0,w*10000.0/zoom,h*10000.0/zoom,clip); GRAlinestyle(GC,snum,sdata,width,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); GRAmark(GC,type,x,y,size,fr,fg,fb,fa,br,bg,bb,ba); GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int markbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy; int x,y,size,width; struct narray *array; array=rval->array; if (arraynum(array)!=0) return 0; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"size",inst,&size); _getobj(obj,"width",inst,&width); if ((array==NULL) && ((array=arraynew(sizeof(int)))==NULL)) return 1; size+=4*width; minx=x-size/2; miny=y-size/2; maxx=x+size/2; maxy=y+size/2; arrayins(array,&maxy,0); arrayins(array,&maxx,0); arrayins(array,&miny,0); arrayins(array,&minx,0); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } rval->array=array; return 0; } static int markmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); x+=*(int *)argv[2]; y+=*(int *)argv[3]; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int markrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int angle, use_pivot, px, py, x, y; #if MODIFY_MARK_TYPE int type; #endif angle = *(int *) argv[2]; use_pivot = * (int *) argv[3]; px = *(int *) argv[4]; py = *(int *) argv[5]; angle = *(int *) argv[2]; #if MODIFY_MARK_TYPE _getobj(obj, "type", inst, &type); type = mark_rotate(angle, type) _putobj(obj, "type", inst, &type); #endif if (! use_pivot) return 0; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); rotate(px, py, angle, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); if (clear_bbox(obj, inst)) return 1; return 0; } static int markflip(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x, y, p, use_pivot; enum FLIP_DIRECTION dir; #if MODIFY_MARK_TYPE int type; #endif dir = (* (int *) argv[2] == FLIP_DIRECTION_HORIZONTAL) ? FLIP_DIRECTION_HORIZONTAL : FLIP_DIRECTION_VERTICAL; use_pivot = * (int *) argv[3]; #if MODIFY_MARK_TYPE _getobj(obj, "type", inst, &type); type = mark_flip(dir, type); _putobj(obj, "type", inst, &type); #endif if (! use_pivot) return 0; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); p = *(int *) argv[4]; flip(p, dir, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); if (clear_bbox(obj, inst)) return 1; return 0; } static int markzoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i,x,y,size,refx,refy,width,snum,*sdata,preserve_width; double zoom, zoom_x, zoom_y; struct narray *style; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; zoom_x = (*(int *) argv[2]) / 10000.0; zoom_y = (*(int *) argv[3]) / 10000.0; zoom = MIN(zoom_x, zoom_y); refx = (*(int *)argv[4]); refy = (*(int *)argv[5]); preserve_width = (*(int *)argv[6]); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"size",inst,&size); _getobj(obj,"width",inst,&width); _getobj(obj,"style",inst,&style); snum=arraynum(style); sdata=arraydata(style); x=(x-refx)*zoom_x+refx; y=(y-refy)*zoom_y+refy; size=size*zoom; if (! preserve_width) { width=width*zoom; for (i=0;ii=FALSE; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); if (array==NULL) return 0; minx=*(int *)(argv[2]); miny=*(int *)(argv[3]); maxx=*(int *)(argv[4]); maxy=*(int *)(argv[5]); err=*(int *)(argv[6]); if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx==maxx) && (miny==maxy)) { bminx-=err; bminy-=err; bmaxx+=err; bmaxy+=err; if ((bminx<=minx) && (minx<=bmaxx) && (bminy<=miny) && (miny<=bmaxy)) rval->i=TRUE; } else { if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } static struct objtable mark[] = { {"init",NVFUNC,NEXEC,markinit,NULL,0}, {"done",NVFUNC,NEXEC,markdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"x",NINT,NREAD|NWRITE,markgeometry,NULL,0}, {"y",NINT,NREAD|NWRITE,markgeometry,NULL,0}, {"size",NINT,NREAD|NWRITE,markgeometry,NULL,0}, {"type",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"R2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"G2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"B2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"A2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"width",NINT,NREAD|NWRITE,markgeometry,NULL,0}, {"style",NIARRAY,NREAD|NWRITE,oputstyle,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,markdraw,"i",0}, {"bbox",NIAFUNC,NREAD|NEXEC,markbbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,markmove,"ii",0}, {"rotate",NVFUNC,NREAD|NEXEC,markrotate,"iiii",0}, {"flip",NVFUNC,NREAD|NEXEC,markflip,"iii",0}, {"zooming",NVFUNC,NREAD|NEXEC,markzoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,markmatch,"iiiii",0}, {"hsb",NVFUNC,NREAD|NEXEC,put_hsb,"ddd",0}, {"hsb2",NVFUNC,NREAD|NEXEC,put_hsb2,"ddd",0}, }; #define TBLNUM (sizeof(mark) / sizeof(*mark)) void * addmark(void) /* addmark() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,mark,ERRNUM,markerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/spline.c0000644000175000017500000001557013070106167013106 00000000000000/* * $Id: spline.c,v 1.4 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include "mathfn.h" #include "spline.h" static int splinecheck(double d[],double mu[],double ram[],double x[],double y[], int num) { double h1,h2; int i; h1=x[1]-x[0]; if (h1==0) return -1; for (i=1;i=0;i--) { h=2-ram[i]*ram[i+1]; if (h==0) return -1; *xx=-ram[i]*(*xx)/h; d[i]=(d[i]-ram[i]*d[i+1])/h; ram[i]=mu[i]/h; } *xx-=ram[0]; return 0; } int splineperiod(double d[],double mu[],double ram[],double x[],double y[], int num,double *df0) { double h,xx,a,b,c,e; splinesetval(d,mu,ram,x,y,num); h=x[1]-x[0]; d[0]=6/h/h*(y[1]-y[0]); ram[0]=1; mu[0]=6/h; h=x[num-1]-x[num-2]; d[num-1]=-6/h/h*(y[num-1]-y[num-2]); mu[num-1]=1; ram[num-1]=-6/h; if (splinesolv(d,mu,ram,x,y,num,&xx)!=0) return -1; a=d[num-1]; b=xx; splinesetval(d,mu,ram,x,y,num); h=x[1]-x[0]; d[0]=6/h/h*(y[1]-y[0]); ram[0]=1; mu[0]=6/h; h=x[num-1]-x[num-2]; d[num-1]=-6/h/h*(y[num-1]-y[num-2]); mu[num-1]=1; ram[num-1]=-6/h; if (splinesolv2(d,mu,ram,x,y,num,&xx)) return -1; c=d[0]; e=xx; h=e-b; if (h==0) return -1; *df0=(a*e-b*c)/h; return 0; } static int splineboundary(double d[],double mu[],double ram[],double x[],double y[], int num,int bc0,int bc1,double df0,double df1) { vector b,coe; matrix m; double h; int i,j; if (bc0==SPLCNDAUTO) { for (i=0;i<4;i++) { m[i][3]=1; b[i]=y[i]; for (j=2;j>=0;j--) m[i][j]=m[i][j+1]*x[i]; } if (matsolv(4,m,b,coe)!=0) return -1; df0=3*coe[0]*m[0][1]+2*coe[1]*m[0][2]+coe[2]; } if (bc1==SPLCNDAUTO) { for (i=0;i<4;i++) { m[i][3]=1; b[i]=y[num+i-4]; for (j=2;j>=0;j--) m[i][j]=m[i][j+1]*x[num+i-4]; } if (matsolv(4,m,b,coe)!=0) return -1; df1=3*coe[0]*m[3][1]+2*coe[1]*m[3][2]+coe[2]; } if (bc0==SPLCNDPERIODIC) { if (splineperiod(d,mu,ram,x,y,num,&df0)!=0) return -1; bc0=SPLCND2NDDIF; bc1=SPLCND2NDDIF; df1=df0; } if (bc0==SPLCND2NDDIF) { d[0]=2*df0; ram[0]=0; } else if ((bc0==SPLCNDAUTO) || (bc0==SPLCND1STDIF)) { h=x[1]-x[0]; d[0]=6/h*((y[1]-y[0])/h-df0); ram[0]=1; } else return -1; if (bc1==2) { d[num-1]=2*df1; mu[num-1]=0; } else if ((bc1==0) || (bc1==1)) { h=x[num-1]-x[num-2]; d[num-1]=6/h*(df1-(y[num-1]-y[num-2])/h); mu[num-1]=1; } else return -1; return 0; } int spline(double x[],double y[],double c1[],double c2[],double c3[], int num,int bc0,int bc1,double df0,double df1) { int i; double h,xx,m; if (splinecheck(c1,c2,c3,x,y,num)!=0) return -1; if (splineboundary(c1,c2,c3,x,y,num,bc0,bc1,df0,df1)!=0) return -1; splinesetval(c1,c2,c3,x,y,num); if (splinesolv(c1,c2,c3,x,y,num,&xx)!=0) return -1; c3[num-1]=c1[num-1]; for (i=num-2;i>=0;i--) c3[i]=c1[i]-c2[i]*c3[i+1]; for (i=0;i #include #include #include #include #include #include #include "object.h" #include "strconv.h" #include "nstring.h" #include "mathfn.h" #include "gra.h" #include "ogra.h" #include "math/math_equation.h" #define FONT_STYLE_NORMAL '\x11' #define FONT_STYLE_BOLD '\x12' #define FONT_STYLE_ITALIC '\x13' struct GRAC { int open,init; const char *objname; const char *outputname; struct objlist *obj; N_VALUE *inst; int output,strwidth,charascent,chardescent; struct narray **list; void *local; directfunc direct; int viewf; int leftm,topm,width,height; double zoom; int gminx,gminy,gmaxx,gmaxy; int cpx,cpy; int clip; int linef; int linedashn; int *linedash; int linewidth,linecap,linejoin,linemiter; int colorf; int fr,fg,fb,fa; int textf; char *textfont; int textsize; int textdir; int textspace; int font_style; int mergetop,mergeleft,mergezoom; int mergefont,mergept,mergesp,mergedir; #if EXPAND_DOTTED_LINE int gdashn; int gdashi; double gdashlen; int gdotf; int *gdashlist; #endif clipfunc gclipf; transfunc gtransf; diffunc gdiff; intpfunc gintpf; void *gflocal; double x0,y0; int oldFR,oldFG,oldFB,oldBR,oldBG,oldBB; }; #if EXPAND_DOTTED_LINE #define INIT_DASH 0, 0, 0, TRUE, NULL, #else #define INIT_DASH #endif #define GRAC_INIT_VAL {FALSE, FALSE, NULL, NULL, NULL, NULL, \ -1, -1, -1, -1, NULL, NULL, NULL, \ FALSE, 0, 0, SHRT_MAX, SHRT_MAX, 1, 0, 0, SHRT_MAX, SHRT_MAX, \ 0, 0, 1, \ FALSE, 0, NULL, 1, 0, 0, 0, \ FALSE, 0, 0, 0, 255, \ FALSE, NULL, 0, 0, 0, GRA_FONT_STYLE_NORMAL, \ 0, 0, 10000, 0, 0, 0, 0, \ INIT_DASH \ NULL, NULL, NULL, NULL, NULL, 0, 0, \ 0, 0, 0, 0, 0, 0} static struct GRAC GRAClist[]= { GRAC_INIT_VAL, /* 1 */ GRAC_INIT_VAL, /* 2 */ GRAC_INIT_VAL, /* 3 */ GRAC_INIT_VAL, /* 4 */ GRAC_INIT_VAL, /* 5 */ GRAC_INIT_VAL, /* 6 */ GRAC_INIT_VAL, /* 7 */ GRAC_INIT_VAL, /* 8 */ GRAC_INIT_VAL, /* 9 */ GRAC_INIT_VAL, /* 10 */ GRAC_INIT_VAL, /* 11 */ }; #define GRAClimit ((int) (sizeof(GRAClist) / sizeof(*GRAClist) - 1)) #if ! CURVE_OBJ_USE_EXPAND_BUFFER static void GRAcmatchtod(double x,double y,struct cmatchtype *data); #endif static int GRAinview(int GC,int x,int y); static int GRArectclip(int GC,int *x0,int *y0,int *x1,int *y1); static int GRAlineclip(int GC,int *x0,int *y0,int *x1,int *y1); int calc_zoom_direction(int direction, double zx, double zy, double *zp, double *zn) { double x, y, dir; int new_dir; dir = (direction / 100.0) / 180 * MPI; if (zn) { x = sin(dir) * zx; y = cos(dir) * zy; *zn = sqrt(x * x + y * y); } x = cos(dir) * zx; y = sin(dir) * zy; if (zp) { *zp = sqrt(x * x + y * y); } if (x == 0) { if (y > 0) { new_dir = 9000; } else { new_dir = 27000; } } else { new_dir = atan(y / x) / MPI * 18000; } return new_dir; } int _GRAopencallback(directfunc direct,struct narray **list,void *local) { int i; for (i=0;i=GRAClimit) return ERRILGC; g_free(GRAClist[GC].linedash); #if EXPAND_DOTTED_LINE g_free(GRAClist[GC].gdashlist); GRAClist[GC].gdashlist=NULL; #endif g_free(GRAClist[GC].textfont); GRAClist[GC].linedashn=0; GRAClist[GC].linedash=NULL; GRAClist[GC].textfont=NULL; GRAClist[GC].viewf=FALSE; GRAClist[GC].linef=FALSE; GRAClist[GC].colorf=FALSE; GRAClist[GC].textf=FALSE; code='I'; cpar[0]=5; cpar[1]=GRAClist[GC].leftm; cpar[2]=GRAClist[GC].topm; cpar[3]=GRAClist[GC].width; cpar[4]=GRAClist[GC].height; cpar[5]=nround(GRAClist[GC].zoom*10000); if (GRAdraw(GC,code,cpar,NULL)) return ERROPEN; return 0; } int GRAopened(int GC) { if (GC<0) return -1; if (GC>=GRAClimit) return -1; if (!(GRAClist[GC].open)) return -1; return GC; } void _GRAclose(int GC) { if (GC<0) return; if (GC>=GRAClimit) return; g_free(GRAClist[GC].linedash); #if EXPAND_DOTTED_LINE g_free(GRAClist[GC].gdashlist); #endif g_free(GRAClist[GC].textfont); GRAClist[GC]=GRAClist[GRAClimit]; } void GRAclose(int GC) { int GC2,i; if (GC<0) return; if (GC>=GRAClimit) return; GC2=-1; if (GRAClist[GC].obj!=NULL) { if (!chkobjfield(GRAClist[GC].obj,"_lock")) { _putobj(GRAClist[GC].obj,"_GC",GRAClist[GC].inst,&GC2); } i=-1; if (!chkobjfield(GRAClist[GC].obj,"_GC")) { _putobj(GRAClist[GC].obj,"_GC",GRAClist[GC].inst,&i); } } g_free(GRAClist[GC].linedash); #if EXPAND_DOTTED_LINE g_free(GRAClist[GC].gdashlist); #endif g_free(GRAClist[GC].textfont); GRAClist[GC]=GRAClist[GRAClimit]; } static void GRAaddlist2(int GC,char *draw) { struct narray **array; if (GC<0) return; if (GC>=GRAClimit) return; if (GRAClist[GC].output==-1) return; array=GRAClist[GC].list; if (array!=NULL) { if (*array==NULL) *array=arraynew(sizeof(char *)); arrayadd(*array,&draw); } } static void GRAinslist2(int GC,char *draw,int n) { struct narray **array; if (GC<0) return; if (GC>=GRAClimit) return; if (GRAClist[GC].output==-1) return; array=GRAClist[GC].list; if (array!=NULL) { if (*array==NULL) *array=arraynew(sizeof(char *)); arrayins(*array,&draw,n); } } void GRAaddlist(int GC,struct objlist *obj,N_VALUE *inst, const char *objname, const char *field) { int oid; char *draw; if (GRAClist[GC].output==-1) return; if (_getobj(obj,"oid",inst,&oid)==-1) return; if ((draw=mkobjlist(NULL,objname,oid,field,TRUE))==NULL) return; GRAaddlist2(GC,draw); } void GRAinslist(int GC,struct objlist *obj,N_VALUE *inst, const char *objname, const char *field,int n) { int oid; char *draw; if (GRAClist[GC].output==-1) return; if (_getobj(obj,"oid",inst,&oid)==-1) return; if ((draw=mkobjlist(NULL,objname,oid,field,TRUE))==NULL) return; GRAinslist2(GC,draw,n); } void GRAdellist(int GC,int n) { struct narray **array; if (GRAClist[GC].output==-1) return; if (GC<0) return; if (GC>=GRAClimit) return; if (GRAClist[GC].output==-1) return; array=GRAClist[GC].list; if (array!=NULL) { arrayndel2(*array,n); } } struct objlist * GRAgetlist(int GC,int *oid,char **field,int n) { struct narray **array; char **sdata; int snum; if (GC<0) return NULL; if (GC>=GRAClimit) return NULL; if (GRAClist[GC].output==-1) return NULL; array=GRAClist[GC].list; snum=arraynum(*array); if (n>=snum) return NULL; sdata=arraydata(*array); return getobjlist(sdata[n],oid,field,NULL); } static void _GRAredraw(int GC,int snum,char **sdata,int setredrawf,int redraw_num, int addn,struct objlist *obj,N_VALUE *inst,const char *field) { int i; char *dargv[2]; int redrawfsave; struct objlist *dobj; int did, layer; char *dfield; N_VALUE *dinst; if (ninterrupt()) return; layer = GRAlayer_support(GC); dargv[0]=(char *)&GC; if ((addn==0) && (obj!=NULL) && (inst!=NULL) && (field!=NULL)) _exeobj(obj,field,inst,1,dargv); if (addn>snum) addn=snum-1; for (i=1;iname); } _exeobj(dobj,dfield,dinst,1,dargv); if (setredrawf) { _putobj(dobj,"redraw_flag",dinst,&redrawfsave); } if ((addn==i) && (obj!=NULL) && (inst!=NULL) && (field!=NULL)) _exeobj(obj,field,inst,1,dargv); } } } } static void GRAredraw2(struct objlist *obj,N_VALUE *inst,int setredrawf,int redraw_num, int addn,struct objlist *aobj,N_VALUE *ainst,char *afield) { struct narray *sarray; char **sdata; int snum; int oid,gid,xid,GC,GCnew; char *gfield,*xfield; N_VALUE *ginst; struct objlist *gobj,*xobj; char *device; if (_getobj(obj,"_list",inst,&sarray)) return; if (_getobj(obj,"oid",inst,&oid)) return; if ((snum=arraynum(sarray))==0) return; sdata=arraydata(sarray); if ((_putobj(obj,"_list",inst,NULL)) || (_getobj(obj,"_GC",inst,&GC))) { arrayfree2(sarray); return; } if (((gobj=getobjlist(sdata[0],&gid,&gfield,NULL))==NULL) || ((ginst=getobjinstoid(gobj,gid))==NULL)) { arrayfree2(sarray); return; } if (GC!=-1) { /* gra is still opened */ GRAaddlist2(GC,sdata[0]); GCnew=GC; sdata[0]=NULL; GRAreopen(GC); } else { /* gra is already closed */ /* check consistency */ if (_getobj(gobj,"_device",ginst,&device) || (device==NULL) || ((xobj=getobjlist(device,&xid,&xfield,NULL))==NULL) || (xobj!=obj) || (xid!=oid) || (strcmp(xfield,"_output")!=0)) { arrayfree2(sarray); return; } /* open GRA */ if ((_exeobj(gobj,"open",ginst,0,NULL)) || (_getobj(gobj,"open",ginst,&GCnew)) || (GRAopened(GCnew)==-1)) { arrayfree2(sarray); return; } } _GRAredraw(GCnew,snum,sdata,setredrawf,redraw_num,addn,aobj,ainst,afield); arrayfree2(sarray); if (GC==-1) _exeobj(gobj,"close",ginst,0,NULL); } void GRAredraw(struct objlist *obj,N_VALUE *inst,int setredrawf,int redraw_num) { GRAredraw2(obj,inst,setredrawf,redraw_num,-1,NULL,NULL,NULL); } void GRAredraw_layers(struct objlist *obj, N_VALUE *inst, int setredrawf, int redraw_num, char **objects) { int i, n, snum; char *dargv[2], *device, **sdata; int redrawfsave; struct objlist *dobj, *gobj, *xobj; int xid, gid, oid, layer, GC, GCnew; char *dfield, *xfield, *gfield; N_VALUE *dinst, *ginst; struct narray *sarray; if (ninterrupt()) return; if (_getobj(obj,"_list",inst,&sarray)) return; if (_getobj(obj,"oid",inst,&oid)) return; if ((snum=arraynum(sarray))==0) return; sdata=arraydata(sarray); if (_getobj(obj,"_GC",inst,&GC)) { return; } if (((gobj=getobjlist(sdata[0],&gid,&gfield,NULL))==NULL) || ((ginst=getobjinstoid(gobj,gid))==NULL)) { return; } if (GC!=-1) { /* gra is still opened */ GCnew=GC; GRAreopen(GC); } else { /* gra is already closed */ /* check consistency */ if (_getobj(gobj,"_device",ginst,&device) || (device==NULL) || ((xobj=getobjlist(device,&xid,&xfield,NULL))==NULL) || (xobj!=obj) || (xid!=oid) || (strcmp(xfield,"_output")!=0)) { return; } /* open GRA */ if ((_exeobj(gobj,"open",ginst,0,NULL)) || (_getobj(gobj,"open",ginst,&GCnew)) || (GRAopened(GCnew)==-1)) { return; } } layer = GRAlayer_support(GC); if (! layer) { return; } dargv[0]=(char *)&GC; while (*objects) { dobj = getobject(*objects); objects++; if (dobj == NULL) { continue; } n = chkobjlastinst(dobj) + 1; if (n < 1) { continue; } GRAlayer(GC, dobj->name); for (i = 0; i < n; i++) { if (ninterrupt()) { return; } if (chkobjfield(dobj, "file")) { dfield = "draw"; } else { dfield = "redraw"; } dinst = chkobjinst(dobj, i); if (dinst == NULL) { continue; } if (setredrawf) { int t = (redraw_num != 0); _getobj(dobj, "redraw_flag", dinst, &redrawfsave); _putobj(dobj, "redraw_flag", dinst, &t); _putobj(dobj, "redraw_num", dinst, &redraw_num); } _exeobj(dobj, dfield, dinst, 1, dargv); if (setredrawf) { _putobj(dobj, "redraw_flag", dinst, &redrawfsave); } } } } int GRAdraw(int GC,char code,int *cpar,char *cstr) { char *argv[7]; double zoom; int i, zoomf, style, alpha; if (GC<0) return ERRILGC; if (GC>=GRAClimit) return ERRILGC; if (!(GRAClist[GC].open)) return ERRGRACLOSE; if ((GRAClist[GC].direct==NULL) && ((GRAClist[GC].output==-1) || (GRAClist[GC].obj==NULL))) return ERRNODEVICE; zoom=GRAClist[GC].zoom; if (zoom==1) zoomf=FALSE; else zoomf=TRUE; switch (code) { case 'I': if (GRAClist[GC].init) return 0; GRAClist[GC].init=TRUE; break; case 'V': if (GRAClist[GC].viewf && (cpar[1]==GRAClist[GC].gminx) && (cpar[3]==GRAClist[GC].gmaxx) && (cpar[2]==GRAClist[GC].gminy) && (cpar[4]==GRAClist[GC].gmaxy) && (cpar[5]==GRAClist[GC].clip)) return 0; GRAClist[GC].viewf=TRUE; GRAClist[GC].gminx=cpar[1]; GRAClist[GC].gminy=cpar[2]; GRAClist[GC].gmaxx=cpar[3]; GRAClist[GC].gmaxy=cpar[4]; GRAClist[GC].clip=cpar[5]; cpar[1]=cpar[1]*zoom+GRAClist[GC].leftm; cpar[2]=cpar[2]*zoom+GRAClist[GC].topm; cpar[3]=cpar[3]*zoom+GRAClist[GC].leftm; cpar[4]=cpar[4]*zoom+GRAClist[GC].topm; break; case 'A': if (GRAClist[GC].linef && (cpar[1]==GRAClist[GC].linedashn) && (cpar[2]==GRAClist[GC].linewidth) && (cpar[3]==GRAClist[GC].linecap) && (cpar[4]==GRAClist[GC].linejoin) && (cpar[5]==GRAClist[GC].linemiter)) { for (i=0;i 3) ? cpar[4] : 255; if (GRAClist[GC].colorf && cpar[1] == GRAClist[GC].fr && cpar[2] == GRAClist[GC].fg && cpar[3] == GRAClist[GC].fb && alpha == GRAClist[GC].fa) { return 0; } GRAClist[GC].colorf = TRUE; GRAClist[GC].fr = cpar[1]; GRAClist[GC].fg = cpar[2]; GRAClist[GC].fb = cpar[3]; GRAClist[GC].fa = alpha; break; case 'F': if ((GRAClist[GC].textfont!=NULL) && (strcmp(GRAClist[GC].textfont,cstr)==0)) return 0; g_free(GRAClist[GC].textfont); if ((GRAClist[GC].textfont=g_malloc(strlen(cstr)+1))==NULL) return 0; strcpy(GRAClist[GC].textfont,cstr); GRAClist[GC].textf=FALSE; break; case 'H': style = (cpar[0] > 3) ? cpar[4] : GRA_FONT_STYLE_NORMAL; if (GRAClist[GC].textf && cpar[1] == GRAClist[GC].textsize && cpar[2] == GRAClist[GC].textspace && cpar[3] == GRAClist[GC].textdir && style == GRAClist[GC].font_style) { return 0; } GRAClist[GC].textf=TRUE; GRAClist[GC].textsize=cpar[1]; GRAClist[GC].textspace=cpar[2]; GRAClist[GC].textdir=cpar[3]; GRAClist[GC].font_style = style; if (zoomf) { cpar[1]*=zoom; cpar[2]*=zoom; } break; case 'M': case 'N': case 'T': case 'P': if (zoomf) { cpar[1]*=zoom; cpar[2]*=zoom; } break; case 'L': case 'B': case 'C': if (zoomf) { cpar[1]*=zoom; cpar[2]*=zoom; cpar[3]*=zoom; cpar[4]*=zoom; } break; case 'R': if (zoomf) for (i=0;i= 0; i--) { if (GRAopened(i) == i && GRAClist[i].strwidth != -1) break; } if (i == -1) { return nround(25.4 / 72000.0 * size * 600); } argv[0] = (char *) GRAClist[i].objname; argv[1] = "_strwidth"; argv[2] = GRAClist[i].local; argv[3] = (char *) s; argv[4] = (char *) &size; argv[5] = font; argv[6] = (char *) &style; argv[7] = NULL; if (__exeobj(GRAClist[i].obj, GRAClist[i].strwidth, GRAClist[i].inst, 6, argv)) return nround(25.4 / 72000.0 * size * 600); idp = chkobjoffset2(GRAClist[i].obj, GRAClist[i].strwidth); return GRAClist[i].inst[idp].i; } static int GRAcharascent(char *font, int style, int size) { char *argv[7]; int i, idp; for (i = GRAClimit - 1; i >= 0; i--) { if (GRAopened(i) == i && GRAClist[i].charascent != -1) break; } if (i == -1) return nround(25.4 / 72000.0 * size * 563); argv[0] = (char *) GRAClist[i].objname; argv[1] = "_charascent"; argv[2] = GRAClist[i].local; argv[3] = (char *)&size; argv[4] = font; argv[5] = (char *) &style; argv[6] = NULL; if (__exeobj(GRAClist[i].obj, GRAClist[i].charascent, GRAClist[i].inst, 5, argv)) return nround(25.4 / 72000.0 * size * 563); idp = chkobjoffset2(GRAClist[i].obj, GRAClist[i].charascent); return GRAClist[i].inst[idp].i; } static int GRAchardescent(char *font,int style,int size) { char *argv[7]; int i, idp; for (i = GRAClimit - 1; i >= 0; i--) { if (GRAopened(i) == i && GRAClist[i].chardescent != -1) break; } if (i == -1) return nround(25.4 / 72000.0 * size * 250); argv[0] = (char *) GRAClist[i].objname; argv[1] = "_chardescent"; argv[2] = GRAClist[i].local; argv[3] = (char *)&size; argv[4] = font; argv[5] = (char *) &style; argv[6] = NULL; if (__exeobj(GRAClist[i].obj, GRAClist[i].chardescent, GRAClist[i].inst, 5, argv)) return nround(25.4 / 72000.0 * size * 250); idp = chkobjoffset2(GRAClist[i].obj, GRAClist[i].chardescent); return GRAClist[i].inst[idp].i; } int GRAinit(int GC,int leftm,int topm,int width,int height,int zoom) { char code; int cpar[6], r; code='I'; cpar[0]=5; cpar[1]=leftm; cpar[2]=topm; cpar[3]=width; cpar[4]=height; cpar[5]=zoom; r = GRAdraw(GC,code,cpar,NULL); GRAClist[GC].leftm=leftm; GRAClist[GC].topm=topm; GRAClist[GC].width=width; GRAClist[GC].height=height; GRAClist[GC].zoom=zoom/10000.0; return (r && GRAClist[GC].output != -1) ? ERROPEN: 0; } void GRAregion(int GC, int *width, int *height, int *zoom) { if (width) { if (GRAClist[GC].leftm < 0) { *width = GRAClist[GC].width; } else if (GRAClist[GC].leftm > GRAClist[GC].width) { *width = 0; } else{ *width = GRAClist[GC].width - GRAClist[GC].leftm; } } if (height) { if (GRAClist[GC].topm < 0) { *height = GRAClist[GC].height; } else if (GRAClist[GC].topm > GRAClist[GC].height) { *height = 0; } else{ *height = GRAClist[GC].height - GRAClist[GC].topm; } } if (zoom) { *zoom=GRAClist[GC].zoom*10000; } } #ifdef COMPILE_UNUSED_FUNCTIONS static void GRAdirect(int GC,int cpar[]) { char code; code='X'; GRAdraw(GC,code,cpar,NULL); } #endif /* COMPILE_UNUSED_FUNCTIONS */ int GRAend(int GC) { char code; int cpar[1]; code='E'; cpar[0]=0; return GRAdraw(GC,code,cpar,NULL); } #ifdef COMPILE_UNUSED_FUNCTIONS static void GRAremark(int GC,char *s) { char code; int cpar[1]; char *cstr; char s2[1]; code='%'; cpar[0]=-1; s2[0]='\0'; if (s==NULL) cstr=s2; else cstr=s; GRAdraw(GC,code,cpar,cstr); } #endif /* COMPILE_UNUSED_FUNCTIONS */ void GRAview(int GC,int x1,int y1,int x2,int y2,int clip) { char code; int cpar[6]; if (x1==x2) x2++; if (y1==y2) y2++; code='V'; cpar[0]=5; cpar[1]=x1; cpar[2]=y1; cpar[3]=x2; cpar[4]=y2; cpar[5]=clip; GRAdraw(GC,code,cpar,NULL); } void GRAlinestyle(int GC,int num,int *type,int width,enum GRA_LINE_CAP cap,enum GRA_LINE_JOIN join, int miter) { char code; int *cpar; int i; if ((cpar=g_malloc(sizeof(int)*(6+num)))==NULL) return; code='A'; cpar[0]=5+num; cpar[1]=num; cpar[2]=width; cpar[3]=cap; cpar[4]=join; cpar[5]=miter; for (i=0;i 255) { fr = 255; } else if (fr < 0) { fr = GRAClist[GC].fr; } if (fg > 255) { fg = 255; } else if (fg < 0) { fg = GRAClist[GC].fg; } if (fb > 255) { fb = 255; } else if (fb < 0) { fb = GRAClist[GC].fb; } if (fa > 255) { fa = 255; } else if (fa < 0) { fa = GRAClist[GC].fa; } code = 'G'; cpar[0] = 4; cpar[1] = fr; cpar[2] = fg; cpar[3] = fb; cpar[4] = fa; GRAdraw(GC, code, cpar, NULL); } void GRAtextstyle(int GC,char *font, int style, int size,int space,int dir) { char code; int cpar[5]; char *cstr; if (font==NULL) return; code='F'; cpar[0]=-1; cstr=font; GRAdraw(GC,code,cpar,cstr); code='H'; cpar[0]=4; cpar[1]=size; cpar[2]=space; cpar[3]=dir; cpar[4]=style; GRAdraw(GC,code,cpar,NULL); } void GRAmoveto(int GC,int x,int y) { char code; int cpar[3]; code='M'; cpar[0]=2; cpar[1]=x; cpar[2]=y; GRAdraw(GC,code,cpar,NULL); GRAClist[GC].cpx=x; GRAClist[GC].cpy=y; } void GRAcurrent_point(int GC, int *x, int *y) { *x = GRAClist[GC].cpx; *y = GRAClist[GC].cpy; } static void GRAmoverel(int GC,int x,int y) { char code; int cpar[3]; GRAClist[GC].cpx+=x; GRAClist[GC].cpy+=y; if ((x!=0) || (y!=0)) { /* if ((GRAClist[GC].clip==0) || (GRAinview(GC,GRAClist[GC].cpx,GRAClist[GC].cpy)==0)) { */ code='N'; cpar[0]=2; cpar[1]=x; cpar[2]=y; GRAdraw(GC,code,cpar,NULL); /* } */ } } void GRAline(int GC,int x0,int y0,int x1,int y1) { char code; int cpar[5]; if ((GRAClist[GC].clip==0) || (GRAlineclip(GC,&x0,&y0,&x1,&y1)==0)) { code='L'; cpar[0]=4; cpar[1]=x0; cpar[2]=y0; cpar[3]=x1; cpar[4]=y1; GRAdraw(GC,code,cpar,NULL); } } void GRAlineto(int GC,int x,int y) { char code; int cpar[3],x0,y0,x1,y1; x0=GRAClist[GC].cpx; y0=GRAClist[GC].cpy; x1=x; y1=y; if ((GRAClist[GC].clip==0) || (GRAlineclip(GC,&x0,&y0,&x1,&y1)==0)) { if ((x0==GRAClist[GC].cpx) && (y0==GRAClist[GC].cpy)) { code='T'; cpar[0]=2; cpar[1]=x1; cpar[2]=y1; GRAdraw(GC,code,cpar,NULL); } else { code='M'; cpar[0]=2; cpar[1]=x0; cpar[2]=y0; GRAdraw(GC,code,cpar,NULL); code='T'; cpar[0]=2; cpar[1]=x1; cpar[2]=y1; GRAdraw(GC,code,cpar,NULL); } } GRAClist[GC].cpx=x; GRAClist[GC].cpy=y; } void GRAcircle(int GC,int x,int y,int rx,int ry,int cs,int ce,int fil) { char code; int cpar[8]; code='C'; cpar[0]=7; cpar[1]=x; cpar[2]=y; cpar[3]=rx; cpar[4]=ry; cpar[5]=cs; cpar[6]=ce; cpar[7]=fil; GRAdraw(GC,code,cpar,NULL); } void GRArectangle(int GC,int x0,int y0,int x1,int y1,int fil) { char code; int cpar[6]; if ((GRAClist[GC].clip==0) || (GRArectclip(GC,&x0,&y0,&x1,&y1)==0)) { code='B'; cpar[0]=5; cpar[1]=x0; cpar[2]=y0; cpar[3]=x1; cpar[4]=y1; cpar[5]=fil; GRAdraw(GC,code,cpar,NULL); } } static void GRAputpixel(int GC,int x,int y) { char code; int cpar[3]; if ((GRAClist[GC].clip==0) || (GRAinview(GC,x,y)==0)) { code='P'; cpar[0]=2; cpar[1]=x; cpar[2]=y; GRAdraw(GC,code,cpar,NULL); } } void GRAdrawpoly(int GC,int num,int *point,enum GRA_FILL_MODE fil) { char code; int i,*cpar,num2; if (num<1) return; if ((point[0]!=point[num*2-2]) || (point[1]!=point[num*2-1])) num2=num+1; else num2=num; if ((cpar=g_malloc(sizeof(int)*(3+2*num2)))==NULL) return; code='D'; cpar[0]=2+2*num2; cpar[1]=num2; cpar[2]=fil; for (i=0;i<2*num;i++) cpar[i+3]=point[i]; if ((point[0]!=point[num*2-2]) || (point[1]!=point[num*2-1])) { cpar[2*num+3]=point[0]; cpar[2*num+4]=point[1]; } GRAdraw(GC,code,cpar,NULL); g_free(cpar); } void GRAlines(int GC,int num,int *point) { char code; int i,*cpar; if ((cpar=g_malloc(sizeof(int)*(2+2*num)))==NULL) return; code='R'; cpar[0]=1+2*num; cpar[1]=num; for (i=0;i<2*num;i++) cpar[i+2]=point[i]; GRAdraw(GC,code,cpar,NULL); g_free(cpar); } void GRArotate(int x0, int y0, int *pos, int *rpos, int n, double dx, double dy) { int i; double x, y; for (i = 0; i < n; i++) { x = pos[i * 2] - x0; y = pos[i * 2 + 1] - y0; rpos[i * 2] = nround(dx * x - dy * y) + x0; rpos[i * 2 + 1] = nround(dy * x + dx * y) + y0; } } void GRArectangle_rotate(int GC,double dx, double dy, int cx, int cy, int x0,int y0,int x1,int y1,int fil) { int po[8]; if (dy == 0) { GRArectangle(GC, x0, y0, x1, y1, fil); return; } po[0]=x0; po[1]=y0; po[2]=x0; po[3]=y1; po[4]=x1; po[5]=y1; po[6]=x1; po[7]=y0; GRArotate(cx, cy, po, po, 4, dx, dy); GRAdrawpoly(GC,4,po,fil); } void GRAmark_rotate(int GC,int type,int x0,int y0, double dx, double dy, int size, int fr,int fg,int fb, int fa, int br,int bg,int bb, int ba) { int x1,y1,x2,y2,r; int po[12],po2[12],rpo[12],rpo2[12]; int type2,sgn, ofst; double d; if ((GRAClist[GC].clip==0) || (GRAinview(GC,x0,y0)==0)) { switch (type) { case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7: case 8: case 9: type2=type-0; r=size/2; if (type2==0) { GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,1); } else if (type2==2) { GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,0); } else if (type2==5) { GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,1); r/=2; GRAcolor(GC,br,bg,bb, ba); GRAcircle(GC,x0,y0,r,r,0,36000,1); } else { GRAcolor(GC,br,bg,bb, ba); GRAcircle(GC,x0,y0,r,r,0,36000,1); GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,0); if (type2==3) { r/=2; GRAcircle(GC,x0,y0,r,r,0,36000,0); } else if (type!=1) { if (dy == 0) { if (dx >= 0) { ofst = 0; } else { ofst = 18000; } } else if (dy > 0) { ofst = acos(-dx) / MPI * 18000 + 18000; } else { ofst = acos(dx) / MPI * 18000; } if (type2==4) { r/=2; GRAcircle(GC,x0,y0,r,r,0,36000,1); } else if (type2==6) { GRAcircle(GC,x0,y0,r,r,27000 + ofst,18000,1); } else if (type2==7) { GRAcircle(GC,x0,y0,r,r,9000 + ofst, 18000,1); } else if (type2==8) { GRAcircle(GC,x0,y0,r,r,ofst,18000,1); } else if (type2==9) { GRAcircle(GC,x0,y0,r,r,18000 + ofst, 18000,1); } } } break; case 10: case 11: case 12: case 13: case 14: case 15: case 16: case 17: case 18: case 19: type2=type-10; x1=x0-size/2; y1=y0-size/2; x2=x0+size/2; y2=y0+size/2; if (type2==0) { GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else if (type2==2) { GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); } else if (type2==5) { GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); x1=x0-size/4; y1=y0-size/4; x2=x0+size/4; y2=y0+size/4; GRAcolor(GC,br,bg,bb, ba); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else { GRAcolor(GC,br,bg,bb, ba); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); if (type2==3) { x1=x0-size/4; y1=y0-size/4; x2=x0+size/4; y2=y0+size/4; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); } else if (type2!=1) { if (type2==4) { x1=x0-size/4; y1=y0-size/4; x2=x0+size/4; y2=y0+size/4; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else if (type2==6) { x1=x0; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else if (type2==7) { x2=x0; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else if (type2==8) { y2=y0; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } else if (type2==9) { y1=y0; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,1); } } } break; case 20: case 21: case 22: case 23: case 24: case 25: case 26: case 27: case 28: case 29: type2=type-20; po[0]=x0; po[1]=y0-size/2; po[2]=x0+size/2; po[3]=y0; po[4]=x0; po[5]=y0+size/2; po[6]=x0-size/2; po[7]=y0; po[8]=x0; po[9]=y0-size/2; GRArotate(x0, y0, po, rpo, 5, dx, dy); if (type2==0) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==2) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); } else if (type2==5) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); po[1]=y0-size/4; po[2]=x0+size/4; po[5]=y0+size/4; po[6]=x0-size/4; po[9]=y0-size/4; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } else { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); if (type2==3) { po[1]=y0-size/4; po[2]=x0+size/4; po[5]=y0+size/4; po[6]=x0-size/4; po[9]=y0-size/4; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); } else if (type2!=1) { if (type2==4) { po[1]=y0-size/4; po[2]=x0+size/4; po[5]=y0+size/4; po[6]=x0-size/4; po[9]=y0-size/4; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==6) { po[6]=x0; po[7]=y0; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==7) { po[2]=x0; po[3]=y0; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==8) { po[4]=x0; po[5]=y0; GRArotate(x0, y0, rpo, rpo, 5, dx, dy); GRAdrawpoly(GC,5,po,GRA_FILL_MODE_EVEN_ODD); } else if (type2==9) { po[0]=x0; po[1]=y0; po[8]=x0; po[9]=y0; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_EVEN_ODD); } } } break; case 30: case 31: case 32: case 33: case 34: case 35: case 36: case 37: case 40: case 41: case 42: case 43: case 44: case 45: case 46: case 47: if (type>=40) { type2=type-40; sgn=-1; } else { type2=type-30; sgn=1; } d=sqrt(3.0); po[0]=x0; po[1]=y0-sgn*size/2; po[2]=x0+size*d/4; po[3]=y0+sgn*size/4; po[4]=x0-size*d/4; po[5]=y0+sgn*size/4; po[6]=x0; po[7]=y0-sgn*size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); if (type2==0) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==2) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); } else if (type2==5) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); po[1]=y0-sgn*size/d/2; po[2]=x0+size/4; po[3]=y0+sgn*size/d/4; po[4]=x0-size/4; po[5]=y0+sgn*size/d/4; po[7]=y0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); if (type2==3) { po[1]=y0-sgn*size/d/2; po[2]=x0+size/4; po[3]=y0+sgn*size/d/4; po[4]=x0-size/4; po[5]=y0+sgn*size/d/4; po[7]=y0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); } else if (type2!=1) { if (type2==4) { po[1]=y0-sgn*size/d/2; po[2]=x0+size/4; po[3]=y0+sgn*size/d/4; po[4]=x0-size/4; po[5]=y0+sgn*size/d/4; po[7]=y0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==6) { po[4]=x0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==7) { po[2]=x0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } } } break; case 50: case 51: case 52: case 53: case 54: case 55: case 56: case 57: case 60: case 61: case 62: case 63: case 64: case 65: case 66: case 67: if (type>=60) { type2=type-60; sgn=-1; } else { type2=type-50; sgn=1; } d=sqrt(3.0); po[0]=x0-sgn*size/2; po[1]=y0; po[2]=x0+sgn*size/4; po[3]=y0+size*d/4; po[4]=x0+sgn*size/4; po[5]=y0-size*d/4; po[6]=x0-sgn*size/2; po[7]=y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); if (type2==0) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==2) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); } else if (type2==5) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); po[0]=x0-sgn*size/d/2; po[2]=x0+sgn*size/d/4; po[3]=y0+size/4; po[4]=x0+sgn*size/d/4; po[5]=y0-size/4; po[6]=x0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); if (type2==3) { po[0]=x0-sgn*size/d/2; po[2]=x0+sgn*size/d/4; po[3]=y0+size/4; po[4]=x0+sgn*size/d/4; po[5]=y0-size/4; po[6]=x0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); } else if (type2!=1) { if (type2==4) { po[0]=x0-sgn*size/d/2; po[2]=x0+sgn*size/d/4; po[3]=y0+size/4; po[4]=x0+sgn*size/d/4; po[5]=y0-size/4; po[6]=x0-sgn*size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==6) { po[5]=y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } else if (type2==7) { po[3]=y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); } } } break; case 38: case 39: case 48: case 49: po[0]=x0; po[1]=y0; po[2]=x0-size/2; po[3]=y0-size/2; po[4]=x0+size/2; po[5]=y0-size/2; po[6]=x0; po[7]=y0; po2[0]=x0; po2[1]=y0; po2[2]=x0-size/2; po2[3]=y0+size/2; po2[4]=x0+size/2; po2[5]=y0+size/2; po2[6]=x0; po2[7]=y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRArotate(x0, y0, po2, rpo2, 4, dx, dy); if (type==38) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); } else if (type==39) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } else if (type==48) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } else if (type==49) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } break; case 58: case 59: case 68: case 69: po[0]=x0; po[1]=y0; po[2]=x0+size/2; po[3]=y0-size/2; po[4]=x0+size/2; po[5]=y0+size/2; po[6]=x0; po[7]=y0; po2[0]=x0; po2[1]=y0; po2[2]=x0-size/2; po2[3]=y0-size/2; po2[4]=x0-size/2; po2[5]=y0+size/2; po2[6]=x0; po2[7]=y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRArotate(x0, y0, po2, rpo2, 4, dx, dy); if (type==58) { GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); } else if (type==59) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } else if (type==68) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } else if (type==69) { GRAcolor(GC,br,bg,bb, ba); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_EVEN_ODD); GRAdrawpoly(GC,4,rpo,GRA_FILL_MODE_NONE); GRAdrawpoly(GC,4,rpo2,GRA_FILL_MODE_NONE); } break; case 70: po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/2; po[3] = y0; po[4] = x0; po[5] = y0-size/2; po[6] = x0; po[7] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,rpo[0],rpo[1],rpo[2],rpo[3]); GRAline(GC,rpo[4],rpo[5],rpo[6],rpo[7]); break; case 71: d=sqrt(2.0); po[0] = x0-size/d/2; po[1] = y0-size/d/2; po[2] = x0+size/d/2; po[3] = y0+size/d/2; po[4] = x0+size/d/2; po[5] = y0-size/d/2; po[6] = x0-size/d/2; po[7] = y0+size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,rpo[0],rpo[1],rpo[2],rpo[3]); GRAline(GC,rpo[4],rpo[5],rpo[6],rpo[7]); break; case 72: d=sqrt(3.0); po[0] = x0; po[1] = y0+size/2; po[2] = x0; po[3] = y0-size/2; po[4] = x0+size*d/4; po[5] = y0-size/4; po[6] = x0-size*d/4; po[7] = y0+size/4; po[8] = x0-size*d/4; po[9] = y0-size/4; po[10] = x0+size*d/4; po[11] = y0+size/4; GRArotate(x0, y0, po, rpo, 6, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,rpo[0],rpo[1],rpo[2],rpo[3]); GRAline(GC,rpo[4],rpo[5],rpo[6],rpo[7]); GRAline(GC,rpo[8],rpo[9],rpo[10],rpo[11]); break; case 73: d=sqrt(3.0); po[0] = x0+size/2; po[1] = y0; po[2] = x0-size/2; po[3] = y0; po[4] = x0-size/4; po[5] = y0+size*d/4; po[6] = x0+size/4; po[7] = y0-size*d/4; po[8] = x0-size/4; po[9] = y0-size*d/4; po[10] = x0+size/4; po[11] = y0+size*d/4; GRArotate(x0, y0, po, rpo, 6, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,rpo[0],rpo[1],rpo[2],rpo[3]); GRAline(GC,rpo[4],rpo[5],rpo[6],rpo[7]); GRAline(GC,rpo[8],rpo[9],rpo[10],rpo[11]); break; case 74: d=sqrt(3.0); po[0] = x0; po[1] = y0-size/2; po[2] = x0-size*d/4; po[3] = y0+size/4; po[4] = x0+size*d/4; po[5] = y0+size/4; GRArotate(x0, y0, po, rpo, 3, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,x0,y0,rpo[0],rpo[1]); GRAline(GC,x0,y0,rpo[2],rpo[3]); GRAline(GC,x0,y0,rpo[4],rpo[5]); break; case 75: d=sqrt(3.0); po[0] = x0; po[1] = y0+size/2; po[2] = x0-size*d/4; po[3] = y0-size/4; po[4] = x0+size*d/4; po[5] = y0-size/4; GRArotate(x0, y0, po, rpo, 3, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,x0,y0,rpo[0],rpo[1]); GRAline(GC,x0,y0,rpo[2],rpo[3]); GRAline(GC,x0,y0,rpo[4],rpo[5]); break; case 76: d=sqrt(3.0); po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/4; po[3] = y0-size*d/4; po[4] = x0+size/4; po[5] = y0+size*d/4; GRArotate(x0, y0, po, rpo, 3, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,x0,y0,rpo[0],rpo[1]); GRAline(GC,x0,y0,rpo[2],rpo[3]); GRAline(GC,x0,y0,rpo[4],rpo[5]); break; case 77: d=sqrt(3.0); po[0] = x0+size/2; po[1] = y0; po[2] = x0-size/4; po[3] = y0-size*d/4; po[4] = x0-size/4; po[5] = y0+size*d/4; GRArotate(x0, y0, po, rpo, 3, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAline(GC,x0,y0,rpo[0],rpo[1]); GRAline(GC,x0,y0,rpo[2],rpo[3]); GRAline(GC,x0,y0,rpo[4],rpo[5]); break; case 78: GRAcolor(GC,fr,fg,fb, fa); po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/2; po[3] = y0; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC,x0-size/2,y0,x0+size/2,y0); break; case 79: GRAcolor(GC,fr,fg,fb, fa); po[0] = x0; po[1] = y0-size/2; po[2] = x0; po[3] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); break; case 80: r=size/2; GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,0); r/=2; GRAcircle(GC,x0,y0,r,r,0,36000,0); break; case 81: r=size/2; GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,0); po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/2; po[3] = y0; po[4] = x0; po[5] = y0-size/2; po[6] = x0; po[7] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; case 82: r=size/2; d=sqrt(2.0); GRAcolor(GC,fr,fg,fb, fa); GRAcircle(GC,x0,y0,r,r,0,36000,0); po[0] = x0-size/d/2; po[1] = y0-size/d/2; po[2] = x0+size/d/2; po[3] = y0+size/d/2; po[4] = x0-size/d/2; po[5] = y0+size/d/2; po[6] = x0+size/d/2; po[7] = y0-size/d/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; case 83: x1=x0-size/2; y1=y0-size/2; x2=x0+size/2; y2=y0+size/2; GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); x1=x0-size/4; y1=y0-size/4; x2=x0+size/4; y2=y0+size/4; GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); break; case 84: x1=x0-size/2; y1=y0-size/2; x2=x0+size/2; y2=y0+size/2; GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/2; po[3] = y0; po[4] = x0; po[5] = y0-size/2; po[6] = x0; po[7] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; case 85: x1=x0-size/2; y1=y0-size/2; x2=x0+size/2; y2=y0+size/2; GRAcolor(GC,fr,fg,fb, fa); GRArectangle_rotate(GC,dx,dy,x0,y0,x1,y1,x2,y2,0); po[0] = x0-size/2; po[1] = y0-size/2; po[2] = x0+size/2; po[3] = y0+size/2; po[4] = x0+size/2; po[5] = y0-size/2; po[6] = x0-size/2; po[7] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; case 86: po[0]=x0; po[1]=y0-size/2; po[2]=x0+size/2; po[3]=y0; po[4]=x0; po[5]=y0+size/2; po[6]=x0-size/2; po[7]=y0; po[8]=x0; po[9]=y0-size/2; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); po[1]=y0-size/4; po[2]=x0+size/4; po[5]=y0+size/4; po[6]=x0-size/4; po[9]=y0-size/4; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); break; case 87: po[0]=x0; po[1]=y0-size/2; po[2]=x0+size/2; po[3]=y0; po[4]=x0; po[5]=y0+size/2; po[6]=x0-size/2; po[7]=y0; po[8]=x0; po[9]=y0-size/2; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); po[0] = x0-size/2; po[1] = y0; po[2] = x0+size/2; po[3] = y0; po[4] = x0; po[5] = y0-size/2; po[6] = x0; po[7] = y0+size/2; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; case 88: po[0]=x0; po[1]=y0-size/2; po[2]=x0+size/2; po[3]=y0; po[4]=x0; po[5]=y0+size/2; po[6]=x0-size/2; po[7]=y0; po[8]=x0; po[9]=y0-size/2; GRArotate(x0, y0, po, rpo, 5, dx, dy); GRAcolor(GC,fr,fg,fb, fa); GRAdrawpoly(GC,5,rpo,GRA_FILL_MODE_NONE); po[0] = x0-size/4; po[1] = y0-size/4; po[2] = x0+size/4; po[3] = y0+size/4; po[4] = x0-size/4; po[5] = y0+size/4; po[6] = x0+size/4; po[7] = y0-size/4; GRArotate(x0, y0, po, rpo, 4, dx, dy); GRAline(GC, rpo[0], rpo[1], rpo[2], rpo[3]); GRAline(GC, rpo[4], rpo[5], rpo[6], rpo[7]); break; default: GRAcolor(GC,fr,fg,fb, fa); GRAputpixel(GC,x0,y0); break; } } } void GRAmark(int GC,int type,int x0,int y0,int size, int fr,int fg,int fb, int fa, int br,int bg,int bb, int ba) { GRAmark_rotate(GC, type, x0, y0, 1, 0, size, fr, fg, fb, fa, br, bg, bb, ba); } void GRAouttext(int GC,char *s) { char code; int cpar[1]; char *cstr; code='S'; cpar[0]=-1; cstr=s; GRAdraw(GC,code,cpar,cstr); } int GRAlayer_support(int GC) { int layer; if (GC < 0) { return FALSE; } if (GRAClist[GC].obj == NULL || GRAClist[GC].inst == NULL) { return FALSE; } if (_getobj(GRAClist[GC].obj, "_layer", GRAClist[GC].inst, &layer)) { return FALSE; } return layer; } void GRAlayer(int GC,const char *s) { char code; int cpar[1]; char *cstr; g_free(GRAClist[GC].linedash); GRAClist[GC].linedashn=0; GRAClist[GC].linedash=NULL; #if EXPAND_DOTTED_LINE g_free(GRAClist[GC].gdashlist); GRAClist[GC].gdashlist=NULL; #endif g_free(GRAClist[GC].textfont); GRAClist[GC].textfont=NULL; GRAClist[GC].viewf=FALSE; GRAClist[GC].linef=FALSE; GRAClist[GC].colorf=FALSE; GRAClist[GC].textf=FALSE; code='Z'; cpar[0]=-1; cstr=(char *) s; GRAdraw(GC,code,cpar,cstr); } static char *GRAexpandobj(char **s); static char *GRAexpandmath(char **s); static char * GRAexpandobj(char **s) { struct objlist *obj; int i,j,anum,*id; struct narray iarray; char *arg,*ret; GString *str, *garg; char *field; int len; int quote; *s=*s+2; field = arg = NULL; str = garg = NULL; arrayinit(&iarray,sizeof(int)); garg = g_string_sized_new(64); if (garg == NULL) { goto errexit; } if (chkobjilist2(s,&obj,&iarray,TRUE)) goto errexit; anum=arraynum(&iarray); if (anum<=0) goto errexit; id=arraydata(&iarray); if (((*s)==NULL) || (strchr(":= \t",(*s)[0])!=NULL) || ((field=getitok2(s,&len,":= \t}"))==NULL)) goto errexit; if (((*s)[0]!='\0') && ((*s)[0]!='}')) (*s)++; while (((*s)[0]==' ') || ((*s)[0]=='\t')) (*s)++; quote=FALSE; while (((*s)[0]!='\0') && (quote || ((*s)[0]!='}'))) { if (!quote && ((*s)[0]=='%') && ((*s)[1]=='{')) { ret=GRAexpandobj(s); if (ret) { g_string_append(garg, ret); g_free(ret); } } else if (!quote && ((*s)[0]=='%') && ((*s)[1]=='[')) { ret=GRAexpandmath(s); if (ret) { g_string_append(garg, ret); g_free(ret); } } else if (!quote && ((*s)[0]=='\\')) { quote=TRUE; (*s)++; } else { if (quote) quote=FALSE; g_string_append_c(garg, (*s)[0]); (*s)++; } } if ((*s)[0]!='}') goto errexit; (*s)++; arg = g_string_free(garg, FALSE); garg = NULL; str = g_string_sized_new(64); if (str == NULL) { goto errexit; } for (i=0;istr, &vd, &rcode, NULL); if (rcode != MATH_VALUE_NORMAL) { goto errexit; } g_string_free(str, TRUE); mod = fabs(fmod(vd, 1)); uvd = fabs(vd); if (uvd == 0) { ret = g_strdup("0"); } else if (uvd < 0.1) { ret = g_strdup_printf("%.15e", vd); } else if (uvd < 1E6 && mod < DBL_EPSILON) { ret = g_strdup_printf("%.0f", vd); } else if (uvd < 10) { ret = g_strdup_printf("%.15f", vd); } else if (uvd < 100) { ret = g_strdup_printf("%.14f", vd); } else if (uvd < 1000) { ret = g_strdup_printf("%.13f", vd); } else { ret = g_strdup_printf("%.15e", vd); } return ret; errexit: g_string_free(str, TRUE); return NULL; } static char * GRAexpandpf(char **s) { int i, len; char *format, *ret2; int quote; GString *str, *ret; *s = *s + 4; str = NULL; format = NULL; ret = g_string_sized_new(64); if (ret == NULL) { goto errexit; } str = g_string_sized_new(64); if (str == NULL) { goto errexit; } if ((*s)==NULL) goto errexit; if ((format=getitok2(s,&len," \t}"))==NULL) goto errexit; if (((*s)[0]!='\0') && ((*s)[0]!='}')) (*s)++; while (((*s)[0]==' ') || ((*s)[0]=='\t')) (*s)++; quote=FALSE; while (((*s)[0]!='\0') && (quote || ((*s)[0]!='}'))) { if (!quote && ((*s)[0]=='%') && ((*s)[1]=='{')) { ret2=GRAexpandobj(s); if (ret2) { g_string_append(str, ret2); g_free(ret2); } } else if (!quote && ((*s)[0]=='%') && ((*s)[1]=='[')) { ret2=GRAexpandmath(s); if (ret2) { g_string_append(str, ret2); g_free(ret2); } } else if (!quote && ((*s)[0]=='\\')) { quote=TRUE; (*s)++; } else { if (quote) quote=FALSE; g_string_append_c(str, (*s)[0]); (*s)++; } } if ((*s)[0]!='}') goto errexit; (*s)++; add_printf_formated_str(ret, format, str->str, &i); g_string_free(str, TRUE); g_free(format); return g_string_free(ret, FALSE); errexit: if (ret) { g_string_free(ret, TRUE); } if (str) { g_string_free(str, TRUE); } g_free(format); return NULL; } static gchar * GRAexpandtext(char *s) { int i,j,len; GString *str; char *snew,*s2; if (s == NULL) { return NULL; } str = g_string_sized_new(256); if (str == NULL) { return NULL; } len = strlen(s); j = 0; do { i = j; while (j < len && s[j] != '\\' && s[j] != '%') { j++; } g_string_append_len(str, s + i, j - i); if (s[j] == '\\') { switch (s[j + 1]) { case 'n': g_string_append_c(str, '\n'); j += 2; break; case 'b': g_string_append_c(str, '\b'); j += 2; break; case '&': g_string_append_c(str, '\r'); j += 2; break; case 'N': g_string_append_c(str, FONT_STYLE_NORMAL); j += 2; break; case 'B': g_string_append_c(str, FONT_STYLE_BOLD); j += 2; break; case 'I': g_string_append_c(str, FONT_STYLE_ITALIC); j += 2; break; case '.': g_string_append_c(str, ' '); j += 2; break; case '-': g_string_append(str, "â€"); j += 2; break; case '\\': case '%': case '@': case '^': case '_': g_string_append_c(str, '\\'); g_string_append_c(str, s[j + 1]); j += 2; break; case 'x': if (g_ascii_isxdigit(s[j + 2]) && g_ascii_isxdigit(s[j + 3])) { if (s[j + 2] != '0' || s[j + 3] != '0') { g_string_append_c(str, '\\'); g_string_append_c(str, 'x'); g_string_append_c(str, toupper(s[j + 2])); g_string_append_c(str, toupper(s[j + 3])); } j += 4; } else { j++; } break; default: j++; } } else if ((s[j]=='%') && (s[j+1]=='{')) { s2=s+j; snew=GRAexpandobj(&s2); if (snew) { g_string_append(str, snew); g_free(snew); } j=(s2-s); } else if ((s[j]=='%') && (s[j+1]=='[')) { s2=s+j; snew=GRAexpandmath(&s2); if (snew) { g_string_append(str, snew); g_free(snew); } j=(s2-s); } else if ((s[j]=='%') && (s[j+1]=='p') && (s[j+2]=='f') && (s[j+3]=='{')) { s2=s+j; snew=GRAexpandpf(&s2); if (snew) { g_string_append(str, snew); g_free(snew); } j=(s2-s); } else if (jlen != 0) { GRAtextstyle(GC, font2, style2, size2, space2, dir); GRAouttext(GC, str->str); } if (style3 != style2) { style2 = style3; continue; } switch (ptr[0]) { case '\n': x0 += (int) (si * size * 25.4 / 72.0); y0 += (int) (cs * size * 25.4 / 72.0); if (scriptf) { scriptf = 0; g_free(font2); font2 = font3; font3 = NULL; size2 = size3; space2 = space3; } x0 += scx_max; y0 += scy_max + vspace; scdist_max = 0; scx_max = 0; scy_max = 0; scmovex = 0; scmovey = 0; if (alignlen != 0) { for (k = 1; ptr[k] != '\0' && ptr[k] != '\n' && ptr[k] != '\r'; k++); ch = ptr[k]; ptr[k] = '\0'; GRAtextextent(ptr, font2, style2, size2, space2, scriptsize, &fx0, &fy0, &fx1, &fy1, TRUE); ptr[k] = ch; x1 = x0 + (int) ( cs * (alignlen - fx1)); y1 = y0 + (int) (-si * (alignlen - fx1)); } else { x1 = x0; y1 = y0; } GRAmoveto(GC, x1, y1); ptr++; break; case '\b': GRAtextextent("h", font2, style2, size2, space2, scriptsize, &fx0, &fy0, &fx1, &fy1, TRUE); x1 = (int) (cs * (fx1 - fx0)); y1 = (int) (si * (fx1 - fx0)); GRAmoverel(GC, -x1, y1); ptr++; break; case '\r': ptr++; break; case '_': case '^': if (scriptf == 0) { font3 = g_strdup(font2); if (font3 == NULL) { goto errexit; } size3 = size2; space3 = space2; } height = size2; size2 = (int) (size2 * 1e-4 * scriptsize); space2 = (int) (space2 * 1e-4 * scriptsize); if (ptr[0] == '^') { x = (int) (-si * (height * 0.8 - size2 * 5e-5 * scriptsize) * 25.4 / 72.0); y = (int) (-cs * (height * 0.8 - size2 * 5e-5 * scriptsize) * 25.4 / 72.0); GRAmoverel(GC, x, y); scmovex += x; scmovey += y; scriptf = 1; } else { x = (int) (si * size2 * 5e-5 * scriptsize * 25.4 / 72.0); y = (int) (cs * size2 * 5e-5 * scriptsize * 25.4 / 72.0); GRAmoverel(GC, x, y); scmovex += x; scmovey += y; scriptf = 2; if (scdist_max < scmovex * si + scmovey * cs) { scdist_max = scmovex * si + scmovey * cs; scx_max = scmovex; scy_max = scmovey; } } ptr++; break; case '@': if (scriptf) { scriptf = 0; GRAmoverel(GC, -scmovex, -scmovey); g_free(font2); font2 = font3; font3 = NULL; size2 = size3; space2 = space3; } scmovex = 0; scmovey = 0; ptr++; break; case '%': if ((ptr[1]!='\0') && ( strchr("FJSPNXYCA", toupper(ptr[1]))!=NULL) && (ptr[2]=='{')) { for (i = 3; ptr[i] != '\0' && ptr[i] != '}'; i++); if (ptr[i] == '}') { tok = g_strndup(ptr + 3, i - 3); if (tok == NULL) { goto errexit; } if (tok[0] != '\0') { switch (toupper(ptr[1])) { case 'F': g_free(font2); font2 = g_strdup(tok); break; case 'J': break; case 'S': val=strtol(tok, &endptr, 10); if (endptr[0]=='\0') size2=val * 100; break; case 'P': val=strtol(tok, &endptr, 10); if (endptr[0]=='\0') space2=val * 100; break; case 'N': val=strtol(tok, &endptr, 10); if (endptr[0]=='\0') vspace=val * 100; break; case 'X': val=strtol(tok, &endptr, 10); if (endptr[0]=='\0') GRAmoverel(GC, (int) (val * 100 * 25.4 / 72.0), 0); break; case 'Y': val=strtol(tok, &endptr, 10); if (endptr[0]=='\0') GRAmoverel(GC, 0, (int) (val * 100 * 25.4 / 72.0)); break; case 'C': { char *tmp_ptr; tmp_ptr = tok; while (*tmp_ptr == '#' || g_ascii_isspace(*tmp_ptr)) { tmp_ptr++; } val = strtol(tmp_ptr, &endptr, 16); if (endptr[0]=='\0') { GRAcolor(GC, (val >> 16) & 0xff, (val >> 8) & 0xff, val & 0xff, -1); } } break; case 'A': val = strtol(tok, &endptr, 10); if (endptr[0]=='\0') { GRAcolor(GC, -1, -1, -1, val); } break; } } g_free(tok); } ptr += i + 1; } else { ptr = g_utf8_next_char(ptr); } break; } } errexit: if (str) { g_string_free(str, TRUE); } g_free(c); g_free(font2); g_free(font3); } void GRAdrawtextraw(int GC, char *s, char *font, int style, int size, int space, int dir) { GString *str; int len, j; if (font == NULL || s == NULL) { return; } str = g_string_sized_new(128); if (str == NULL) { return; } len = strlen(s); for (j = 0; j < len; j++) { if (s[j] == '\\') { g_string_append_c(str, '\\'); } g_string_append_c(str, s[j]); } if (str->len > 0) { GRAtextstyle(GC, font, style, size, space, dir); GRAouttext(GC, str->str); } g_string_free(str, TRUE); } void GRAtextextent(char *s, char *font, int style, int size, int space, int scriptsize, int *gx0, int *gy0, int *gx1, int *gy1, int raw) { gchar *c, *tok; GString *str; int w, h, d, len, scmovey, scriptf, scy_max; char *endptr; char *font2; int size2, space2, style2, vspace; char *font3; int size3, space3, style3; int i, j, k, y, val, x0, y0, ofsty; int height; int alignlen, fx0, fx1, fy0, fy1; char ch; *gx0 = *gy0 = *gx1 = *gy1 = 0; if (font == NULL || s == NULL) { return; } font2 = NULL; font3 = NULL; str = NULL; x0 = 0; y0 = 0; ofsty = 0; c = GRAexpandtext(s); if (c == NULL) { goto errexit; } if (c[0] == '\0') { goto errexit; } style3 = style2 = style; font2 = g_strdup(font); size2 = size; space2 = space; size3 = size; space3 = space; scriptf = 0; scmovey = 0; scy_max = 0; vspace = 0; len = strlen(c); if (! raw) { for (k = 0; (k < len) && (c[k] != '\n') && (c[k] != '\r'); k++); if (c[k] == '\r') { ch = c[k]; c[k] = '\0'; GRAtextextent(c, font2, style2, size2, space2, scriptsize, &fx0, &fy0, &fx1, &fy1, TRUE); c[k] = ch; alignlen = fx1; } else { alignlen = 0; } } else { alignlen = 0; /* dummy code to avoid compile warnings */ } j=0; str = g_string_sized_new(256); if (str == NULL) { goto errexit; } do { g_string_set_size(str, 0); while (j < len && strchr("\n\b\r_^@%",c[j]) == NULL) { switch (c[j]) { case '\\': if (c[j + 1]=='x' && g_ascii_isxdigit(c[j + 2]) && g_ascii_isxdigit(c[j + 3])) { gunichar wc; wc = g_ascii_xdigit_value(c[j + 2]) * 16 + g_ascii_xdigit_value(c[j + 3]); g_string_append_unichar(str, wc); j += 4; } else if (isprint(c[j + 1])) { g_string_append_c(str, c[j + 1]); j += 2; } else { j++; } break; case FONT_STYLE_NORMAL: style3 = GRA_FONT_STYLE_NORMAL; j++; break; case FONT_STYLE_BOLD: style3 |= GRA_FONT_STYLE_BOLD; j++; break; case FONT_STYLE_ITALIC: style3 |= GRA_FONT_STYLE_ITALIC; j++; break; default: g_string_append_c(str, c[j]); j++; } if (style3 != style2) { break; } } if (str->len > 0) { w = GRAstrwidth(str->str, font2, style2, size2) + nround(space2 / 72.0 * 25.4) * (str->len - 1); h = GRAcharascent(font2, style2, size2); d = GRAchardescent(font2, style2, size2); if (x0 < *gx0) *gx0 = x0; if (x0 + w < *gx0) *gx0 = x0 + w; if (x0 > *gx1) *gx1 = x0; if (x0 + w > *gx1) *gx1 = x0 + w; if (y0 - h < *gy0) *gy0 = y0 - h; if (y0 + d < *gy0) *gy0 = y0 + d; if (y0 - h > *gy1) *gy1 = y0 - h; if (y0 + d > *gy1) *gy1 = y0 + d; x0 += w; } if (style3 != style2) { style2 = style3; continue; } switch (c[j]) { case '\n': y0 += (int) (size * 25.4 / 72.0); if (scriptf) { y0 -= scmovey; scriptf = 0; g_free(font2); font2 = font3; font3 = NULL; size2 = size3; space2 = space3; } y0 += scy_max + vspace; scmovey = 0; scy_max = 0; if (! raw && alignlen) { for (k = j + 1; (k < len) && (c[k] != '\n') && (c[k] != '\r'); k++); ch = c[k]; c[k] = '\0'; GRAtextextent(c + j + 1, font2, style2, size2, space2, scriptsize, &fx0, &fy0, &fx1, &fy1, TRUE); c[k] = ch; x0 = alignlen - fx1; } else { x0 = 0; } y0 -= ofsty; ofsty = 0; j++; break; case '\b': GRAtextextent("h", font2, style2, size2, space2, scriptsize, &fx0, &fy0, &fx1, &fy1, TRUE); x0 -= (fx1 - fx0); j++; break; case '\r': j++; break; case '_': case '^': if (scriptf == 0) { font3 = g_strdup(font2); if (font3 == NULL) { goto errexit; } size3 = size2; space3 = space2; } height = size2; size2 = (int) (size2 * 1e-4 * scriptsize); space2 = (int) (space2 * 1e-4 * scriptsize); if (c[j]=='^') { y = (int) (-(height * 0.8 - size2 * 5e-5 * scriptsize) * 25.4 / 72.0); y0 += y; scmovey += y; scriptf = 1; } else { y = (int) (size2 * 5e-5 * scriptsize * 25.4 / 72.0); y0 += y; scmovey += y; scriptf = 2; if (scy_max < scmovey) { scy_max = scmovey; } } j++; break; case '@': if (scriptf) { scriptf = 0; y0 -= scmovey; g_free(font2); font2 = font3; font3 = NULL; size2 = size3; space2 = space3; } scmovey = 0; j++; break; case '%': if (c[j + 1] != '\0' && strchr("FJSPNXYCA", toupper(c[j + 1])) && c[j + 2] == '{') { for (i = j + 3; c[i] != '\0' && c[i] != '}'; i++); if (c[i] == '}') { tok = g_strndup(c + j + 3, i - j - 3); if (tok == NULL) { goto errexit; } if (tok[0] != '\0') { switch (toupper(c[j + 1])) { case 'F': g_free(font2); font2 = g_strdup(tok); break; case 'J': case 'C': case 'A': break; case 'S': val = strtol(tok, &endptr, 10); if (endptr[0] == '\0') { size2 = val * 100; } break; case 'P': val = strtol(tok, &endptr, 10); if (endptr[0] == '\0') { space2 = val * 100; } break; case 'N': val = strtol(tok, &endptr, 10); if (endptr[0] == '\0') { vspace = val * 100; } break; case 'X': val = strtol(tok, &endptr, 10); if (endptr[0] == '\0') { x0 += (int) (val * 100 * 25.4 / 72.0); } break; case 'Y': val = strtol(tok, &endptr, 10); if (endptr[0] == '\0') { y = (int) (val * 100 * 25.4 / 72.0); ofsty += y; y0 += y; } break; } } g_free(tok); } j = i + 1; } else { j++; } break; } } while (j < len); errexit: if (str) { g_string_free(str, TRUE); } g_free(c); g_free(font2); g_free(font3); } void GRAtextextentraw(char *s,char *font, int style, int size,int space,int *gx0,int *gy0,int *gx1,int *gy1) { int i, n, len, ha, hd; *gx0 = *gy0 = *gx1 = *gy1 = 0; if (s == NULL || font == NULL) return; len = strlen(s); if (len < 1) { return; } *gx1 = GRAstrwidth(s, font, style, size) + nround(space / 72.0 * 25.4) * (len - 1); for (n = 0, i = 0; i < len; i++) { if (s[i] == '\n') { n++; } } ha = GRAcharascent(font, style, size); *gy0 = - ha; hd = GRAchardescent(font, style, size); *gy1 = hd + (ha + hd) * n; } static int getintpar(char *s,int num,int cpar[]) { int i,pos1,pos2; char s2[256]; char *endptr; pos1=0; for (i=0;i= (int) sizeof(s2) - 1) return FALSE; s2[pos2]=s[pos1]; pos2++; pos1++; } s2[pos2]='\0'; cpar[i]=strtol(s2,&endptr,10); if (endptr[0]!='\0') return FALSE; } return TRUE; } int GRAinputdraw(int GC,int leftm,int topm,int rate_x,int rate_y, char code,int *cpar,char *cstr) { int i; double r, rx, ry; if (GRAClist[GC].mergezoom==0) { rx = ry = 1; } else { rx = ((double )rate_x)/GRAClist[GC].mergezoom; ry = ((double )rate_y)/GRAClist[GC].mergezoom; } r = MIN(rx, ry); switch (code) { case '%': case 'O': case 'Q': case 'F': case 'S': case 'K': case 'Z': break; case 'G': if (cpar[0] != 3 && cpar[0] != 4) return FALSE; break; case 'I': if (cpar[0] != 5) return FALSE; GRAClist[GC].mergeleft=cpar[1]; GRAClist[GC].mergetop=cpar[2]; GRAClist[GC].mergezoom=cpar[5]; code='\0'; break; case 'E': GRAClist[GC].mergeleft=0; GRAClist[GC].mergetop=0; GRAClist[GC].mergezoom=10000; code='\0'; break; case 'V': if (cpar[0] != 5) return FALSE; cpar[1]=(int )(((cpar[1]-GRAClist[GC].mergeleft)*rx)+leftm); cpar[2]=(int )(((cpar[2]-GRAClist[GC].mergetop)*ry)+topm); cpar[3]=(int )(((cpar[3]-GRAClist[GC].mergeleft)*rx)+leftm); cpar[4]=(int )(((cpar[4]-GRAClist[GC].mergetop)*ry)+topm); break; case 'A': if (cpar[0] != cpar[1] + 5) return FALSE; cpar[2]=(int )(cpar[2]*r); for (i=0;icstr) { g_free(data->cstr); } if (data->cpar) { g_free(data->cpar); } } int GRAparse(struct GRAdata *data, char *s) { int pos, num, i; char code; int *cpar; char *cstr; code = '\0'; cpar =NULL; cstr = NULL; for (i = 0; s[i] != '\0'; i++) { if (strchr("\n\r", s[i]) != NULL) { s[i] = '\0'; break; } } pos = 0; while (s[pos] == ' ' || s[pos] == '\t') { pos++; } if (s[pos] == '\0') { return TRUE; } if (strchr("IE%VAGOMNLTCBPRDFHSK", s[pos]) == NULL) { return FALSE; } code = s[pos]; if (strchr("%FSK", code) == NULL) { if (! getintpar(s + pos + 1, 1, &num)) { return FALSE; } num++; cpar = g_malloc(sizeof(int) * num); if (cpar == NULL) { return FALSE; } if (! getintpar(s + pos + 1, num, cpar)) { goto errexit; } } else { cpar = g_malloc(sizeof(int)); if (cpar == NULL) { return FALSE; } cpar[0] = -1; cstr = g_strdup(s + pos + 1); if (cstr == NULL) { goto errexit; } } if (data) { data->code = code; data->cpar = cpar; data->cstr = cstr; data->next = NULL; } return TRUE; errexit: g_free(cpar); g_free(cstr); return FALSE; } int GRAinput(int GC,char *s,int leftm,int topm,int rate_x,int rate_y) { int r; struct GRAdata data; if (! GRAparse(&data, s)) { return FALSE; } r = GRAinputdraw(GC,leftm,topm,rate_x,rate_y,data.code,data.cpar,data.cstr); GRAdata_free(&data); return r; } static char *fonttbl[]={ "Times","TimesBold","TimesItalic","TimesBoldItalic", "Helvetica","HelveticaBold","HelveticaOblique","HelveticaBoldOblique", "Mincho","Mincho","Mincho","Mincho", "Gothic","Gothic","Gothic","Gothic", "Courier","CourierBold","CourierItalic","CourierBoldItalic", "Symbol"}; #define FONTTBL_NUM ((int) (sizeof(fonttbl) / sizeof(*fonttbl))) #define FONTTBL_SYMBOL (FONTTBL_NUM - 1) static char * get_gra_font(int i) { if (i < 0 || i >= FONTTBL_NUM) { i = 0; } return fonttbl[i]; } int GRAinputold(int GC,char *s,int leftm,int topm,int rate_x,int rate_y) { int pos,num,i,j; char code,code2; int cpar[50],cpar2[50]; char cstr[256],*po,*ustr; int col,B,R,G; code='\0'; for (i=0;s[i]!='\0';i++) if (strchr("\n\r",s[i])!=NULL) { s[i]='\0'; break; } pos=0; while ((s[pos]==' ') || (s[pos]=='\t')) pos++; if (s[pos]=='\0') return TRUE; if (strchr("IEX%VAOMNLTCBPDFSK",s[pos])==NULL) return FALSE; code=s[pos]; if (strchr("%SK",code)==NULL) { if (!getintpar(s+pos+1,1,&num)) return FALSE; num++; if (!getintpar(s+pos+1,num,cpar)) return FALSE; } else { cpar[0]=-1; if ((po=strchr(s+pos+1,','))==NULL) return FALSE; if ((po=strchr(po+1,','))==NULL) return FALSE; strcpy(cstr,po+1); j=0; for (i=0;cstr[i]!='\0';i++) { if (cstr[i]=='\\') { if ((cstr[i+1]!='n') && (cstr[i+1]!='r')) { cstr[j]=cstr[i+1]; j++; } i++; } else { cstr[j]=cstr[i]; j++; } } if ((j>0) && (cstr[j-1]==',')) j--; cstr[j]='\0'; } switch (code) { case 'X': break; case '%': case 'S': case 'Z': GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); break; case 'K': ustr = sjis_to_utf8(cstr); if (ustr) { GRAinputdraw(GC, leftm, topm, rate_x, rate_y, 'S', cpar, ustr); g_free(ustr); } break; case 'I': cpar[0]=5; cpar[5]=nround(cpar[3]/2.1); cpar[3]=21000; cpar[4]=29700; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); break; case 'E': case 'M': case 'N': case 'L': case 'T': case 'P': GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); break; case 'V': if (cpar[0]==4) { cpar[0]=5; cpar[5]=0; } GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); break; case 'A': col=cpar[3]; GRAClist[GC].oldFB=(col & 1)*256; GRAClist[GC].oldFG=(col & 2)*128; GRAClist[GC].oldFR=(col & 4)*64; code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldFR; cpar2[2]=GRAClist[GC].oldFG; cpar2[3]=GRAClist[GC].oldFB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); cpar[0]=5; cpar[3]=cpar[4]; cpar[4]=0; cpar[5]=1000; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); break; case 'O': col=cpar[1]; GRAClist[GC].oldBB=(col & 1)*256; GRAClist[GC].oldBG=(col & 2)*128; GRAClist[GC].oldBR=(col & 4)*64; break; case 'C': cpar2[7]=cpar[4]; if (cpar[0]>=5) cpar[4]=cpar[5]; else cpar[4]=cpar[3]; if (cpar[0]==7) { cpar[5]=cpar[6]*10; cpar[6]=cpar[7]*10-cpar[6]*10; if (cpar[6]<0) cpar[6]+=36000; } else { cpar[5]=0; cpar[6]=36000; } cpar[7]=cpar2[7]; cpar[0]=7; if (cpar[7]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldBR; cpar2[2]=GRAClist[GC].oldBG; cpar2[3]=GRAClist[GC].oldBB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); if (cpar[7]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldFR; cpar2[2]=GRAClist[GC].oldFG; cpar2[3]=GRAClist[GC].oldFB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } break; case 'B': if (cpar[5]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldBR; cpar2[2]=GRAClist[GC].oldBG; cpar2[3]=GRAClist[GC].oldBB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); if (cpar[5]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldFR; cpar2[2]=GRAClist[GC].oldFG; cpar2[3]=GRAClist[GC].oldFB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } break; case 'D': if (cpar[2]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldBR; cpar2[2]=GRAClist[GC].oldBG; cpar2[3]=GRAClist[GC].oldBB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code,cpar,cstr); if (cpar[2]==1) { code2='G'; cpar2[0]=3; cpar2[1]=GRAClist[GC].oldFR; cpar2[2]=GRAClist[GC].oldFG; cpar2[3]=GRAClist[GC].oldFB; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); } break; case 'F': code2='F'; cpar2[0]=-1; GRAClist[GC].mergefont=cpar[1]*4+cpar[2]; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,get_gra_font(cpar[1]*4+cpar[2])); if (cpar[6] == 1) { cpar[6]=9000; } else if (cpar[6]<0) { cpar[6]=abs(cpar[6]); } code2='H'; cpar2[0]=3; cpar2[1]=cpar[3]*100; cpar2[2]=cpar[4]*100; cpar2[3]=cpar[6]; GRAClist[GC].mergept=cpar2[1]; GRAClist[GC].mergesp=cpar2[2]; GRAClist[GC].mergedir=cpar2[3]; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); col=cpar[5]; B=(col & 1)*256; G=(col & 2)*128; R=(col & 4)*64; code2='G'; cpar2[0]=3; cpar2[1]=R; cpar2[2]=G; cpar2[3]=B; GRAinputdraw(GC,leftm,topm,rate_x,rate_y,code2,cpar2,cstr); break; } return TRUE; } static int GRAlineclip(int GC,int *x0,int *y0,int *x1,int *y1) { int a,xl,yl,xg,yg; int minx,miny,maxx,maxy; if (GRAClist[GC].gminx>GRAClist[GC].gmaxx) { minx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; maxx=0; } else { minx=0; maxx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; } if (GRAClist[GC].gminy>GRAClist[GC].gmaxy) { miny=GRAClist[GC].gmaxy-GRAClist[GC].gminy; maxy=0; } else { miny=0; maxy=GRAClist[GC].gmaxy-GRAClist[GC].gminy; } if (*x0<*x1) { xl=*x0; yl=*y0; xg=*x1; yg=*y1; } else { xl=*x1; yl=*y1; xg=*x0; yg=*y0; } if ((xgmaxx)) return 1; if (xg>maxx) { xg=maxx; yg=(*y1-*y0)*(maxx-*x0)/(*x1-*x0)+*y0; } if (xlyg) { a=yl; yl=yg; yg=a; a=xl; xl=xg; xg=a; } if ((ygmaxy)) return 1; if (yg>maxy) { yg=maxy; xg=(*x1-*x0)*(maxy-*y0)/(*y1-*y0)+*x0; } if (ylGRAClist[GC].gmaxx) { minx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; maxx=0; } else { minx=0; maxx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; } if (GRAClist[GC].gminy>GRAClist[GC].gmaxy) { miny=GRAClist[GC].gmaxy-GRAClist[GC].gminy; maxy=0; } else { miny=0; maxy=GRAClist[GC].gmaxy-GRAClist[GC].gminy; } if (*x0<*x1) { xl=*x0; xg=*x1; } else { xl=*x1; xg=*x0; } if (*y0<*y1) { yl=*y0; yg=*y1; } else { yl=*y1; yg=*y0; } if ((xgmaxx)) return 1; if ((ygmaxy)) return 1; if ((xg>maxx) && (xlmaxy) && (ylmaxx) xg=maxx; if (xlmaxy) yg=maxy; if (ylGRAClist[GC].gmaxx) { minx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; maxx=0; } else { minx=0; maxx=GRAClist[GC].gmaxx-GRAClist[GC].gminx; } if (GRAClist[GC].gminy>GRAClist[GC].gmaxy) { miny=GRAClist[GC].gmaxy-GRAClist[GC].gminy; maxy=0; } else { miny=0; maxy=GRAClist[GC].gmaxy-GRAClist[GC].gminy; } if ((minx<=x) && (x<=maxx) && (miny<=y) && (y<=maxy)) return 0; else return 1; } void GRAcurvefirst(int GC,int num,int *dashlist, clipfunc clipf,transfunc transf,diffunc diff,intpfunc intpf,void *local, double x0,double y0) { int gx0,gy0; #if EXPAND_DOTTED_LINE int i; g_free(GRAClist[GC].gdashlist); GRAClist[GC].gdashlist=NULL; if (num!=0) { if ((GRAClist[GC].gdashlist=g_malloc(sizeof(int)*num))==NULL) num=0; } GRAClist[GC].gdashn=num; for (i=0;i1) d=1; GRAClist[GC].gintpf(d,c,x0,y0,&x,&y,GRAClist[GC].gflocal); GRAdashlinetod(GC,x,y); } return TRUE; } void GRAdashlinetod(int GC,double x,double y) { double x1,y1,x2,y2; int gx1,gy1,gx2,gy2; #if EXPAND_DOTTED_LINE double dx,dy,dd,len,len2; int gx,gy; #endif x1=GRAClist[GC].x0; y1=GRAClist[GC].y0; x2=x; y2=y; if ((GRAClist[GC].gclipf==NULL) || (GRAClist[GC].gclipf(&x1,&y1,&x2,&y2,GRAClist[GC].gflocal)==0)) { if (GRAClist[GC].gtransf==NULL) { gx1=nround(x1); gy1=nround(y1); gx2=nround(x2); gy2=nround(y2); } else { GRAClist[GC].gtransf(x1,y1,&gx1,&gy1,GRAClist[GC].gflocal); GRAClist[GC].gtransf(x2,y2,&gx2,&gy2,GRAClist[GC].gflocal); } if ((x1!=GRAClist[GC].x0) || (y1!=GRAClist[GC].y0)) GRAmoveto(GC,gx1,gy1); #if EXPAND_DOTTED_LINE if (GRAClist[GC].gdashn==0) GRAlineto(GC,gx2,gy2); else { dx=(gx2-gx1); dy=(gy2-gy1); len2=len=sqrt(dx*dx+dy*dy); while (len2 >((GRAClist[GC].gdashlist)[GRAClist[GC].gdashi]-GRAClist[GC].gdashlen)) { dd=(len-len2+(GRAClist[GC].gdashlist)[GRAClist[GC].gdashi] -GRAClist[GC].gdashlen)/len; gx=gx1+nround(dx*dd); gy=gy1+nround(dy*dd); if (GRAClist[GC].gdotf) GRAlineto(GC,gx,gy); else GRAmoveto(GC,gx,gy); GRAClist[GC].gdotf=GRAClist[GC].gdotf ? FALSE : TRUE; len2-=((GRAClist[GC].gdashlist)[GRAClist[GC].gdashi] -GRAClist[GC].gdashlen); GRAClist[GC].gdashlen=0; GRAClist[GC].gdashi++; if (GRAClist[GC].gdashi>=GRAClist[GC].gdashn) { GRAClist[GC].gdashi=0; GRAClist[GC].gdotf=TRUE; } } if (GRAClist[GC].gdotf) GRAlineto(GC,gx2,gy2); GRAClist[GC].gdashlen+=len2; } #else GRAlineto(GC,gx2,gy2); #endif } GRAClist[GC].x0=x; GRAClist[GC].y0=y; } #if ! CURVE_OBJ_USE_EXPAND_BUFFER void GRAcmatchfirst(int pointx,int pointy,int err, clipfunc clipf,transfunc transf,diffunc diff,intpfunc intpf,void *local, struct cmatchtype *data,int bbox,double x0,double y0) { data->x0=x0; data->y0=y0; data->gclipf=clipf; data->gtransf=transf; data->gdiff=diff; data->gintpf=intpf; data->gflocal=local; data->err=err; data->pointx=pointx; data->pointy=pointy; data->bbox=bbox; data->minx=0; data->miny=0; data->maxx=0; data->maxy=0; data->bboxset=FALSE; data->match=FALSE; } static void GRAcmatchtod(double x,double y,struct cmatchtype *data) { double x1,y1,x2,y2; int gx1,gy1,gx2,gy2; double r,r2,r3,ip; x1=data->x0; y1=data->y0; x2=x; y2=y; if (data->bbox) { if (data->gtransf==NULL) { gx1=nround(x1); gy1=nround(y1); gx2=nround(x2); gy2=nround(y2); } else { data->gtransf(x1,y1,&gx1,&gy1,data->gflocal); data->gtransf(x2,y2,&gx2,&gy2,data->gflocal); } if (!data->bboxset || gx1minx) data->minx=gx1; if (!data->bboxset || gy1miny) data->miny=gy1; if (!data->bboxset || gx1>data->maxx) data->maxx=gx1; if (!data->bboxset || gy1>data->maxy) data->maxy=gy1; data->bboxset=TRUE; if (!data->bboxset || gx2minx) data->minx=gx2; if (!data->bboxset || gy2miny) data->miny=gy2; if (!data->bboxset || gx2>data->maxx) data->maxx=gx2; if (!data->bboxset || gy2>data->maxy) data->maxy=gy2; } else { if ((data->gclipf==NULL) || (data->gclipf(&x1,&y1,&x2,&y2,data->gflocal)==0)) { if (data->gtransf==NULL) { gx1=nround(x1); gy1=nround(y1); gx2=nround(x2); gy2=nround(y2); } else { data->gtransf(x1,y1,&gx1,&gy1,data->gflocal); data->gtransf(x2,y2,&gx2,&gy2,data->gflocal); } x1=gx1; y1=gy1; x2=gx2; y2=gy2; r2=sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1)); r=sqrt((data->pointx-x1)*(data->pointx-x1)+(data->pointy-y1)*(data->pointy-y1)); r3=sqrt((data->pointx-x2)*(data->pointx-x2)+(data->pointy-y2)*(data->pointy-y2)); if ((r<=data->err) || (r3err)) { data->match=TRUE; } else if (r2!=0) { ip=((x2-x1)*(data->pointx-x1)+(y2-y1)*(data->pointy-y1))/r2; if ((0<=ip) && (ip<=r2)) { x2=x1+(x2-x1)*ip/r2; y2=y1+(y2-y1)*ip/r2; r=sqrt((data->pointx-x2)*(data->pointx-x2)+(data->pointy-y2)*(data->pointy-y2)); if (rerr) data->match=TRUE; } } } } data->x0=x; data->y0=y; } int GRAcmatch(double c[],double x0,double y0,struct cmatchtype *data) { double d,dx,dy,ddx,ddy,dd,x,y; if (ninterrupt()) return FALSE; d=0; while (d<1) { data->gdiff(d,c,&dx,&dy,&ddx,&ddy,data->gflocal); if ((fabs(dx)+fabs(ddx)/3)==0) dx=1; else dx=sqrt(fabs(2/(fabs(dx)+fabs(ddx)/3))); if ((fabs(dy)+fabs(ddy)/3)==0) dy=1; else dy=sqrt(fabs(2/(fabs(dy)+fabs(ddy)/3))); dd=(dx1) d=1; data->gintpf(d,c,x0,y0,&x,&y,data->gflocal); GRAcmatchtod(x,y,data); } return TRUE; } #endif static void setbbminmax(struct GRAbbox *bbox,int x1,int y1,int x2,int y2,int lw) { int x,y; if (x1>x2) { x=x1; x1=x2; x2=x; } if (y1>y2) { y=y1; y1=y2; y2=y; } if (lw) { x1-=bbox->linew; y1-=bbox->linew; x2+=bbox->linew; y2+=bbox->linew; } if (!bbox->clip || !((x2<0) || (y2<0) || (x1>bbox->clipsizex) || (y1>bbox->clipsizey))) { if (bbox->clip) { if (x1<0) x1=0; if (y1<0) y1=0; if (x2>bbox->clipsizex) x2=bbox->clipsizex; if (y2>bbox->clipsizey) y1=bbox->clipsizey; } x1+=bbox->offsetx; x2+=bbox->offsetx; y1+=bbox->offsety; y2+=bbox->offsety; if (!bbox->set || (x1minx)) bbox->minx=x1; if (!bbox->set || (y1miny)) bbox->miny=y1; if (!bbox->set || (x2>bbox->maxx)) bbox->maxx=x2; if (!bbox->set || (y2>bbox->maxy)) bbox->maxy=y2; if (!bbox->set) bbox->set=TRUE; } } void GRAinitbbox(struct GRAbbox *bbox) { bbox->set=FALSE; bbox->minx=0; bbox->miny=0; bbox->maxx=0; bbox->maxy=0; bbox->offsetx=0; bbox->offsety=0; bbox->posx=0; bbox->posy=0; bbox->pt=0; bbox->spc=0; bbox->dir=0; bbox->linew=0; bbox->clip=TRUE; bbox->clipsizex=21000; bbox->clipsizey=29700; bbox->fontalias=NULL; bbox->loadfont=FALSE; } void GRAendbbox(struct GRAbbox *bbox) { g_free(bbox->fontalias); } static int get_str_bbox(struct GRAbbox *bbox, char *cstr) { double x, y, csin, ccos; int w, h, d, x1, y1, x2, y2, x3, y3, x4, y4; gchar *ptr; GString *str; if (! bbox->loadfont) { return 0; } str = g_string_sized_new(256); if (str == NULL) { return 1; } csin = sin(bbox->dir / 18000.0 * MPI); ccos = cos(bbox->dir / 18000.0 * MPI); for (ptr = cstr; ptr[0]; ptr++) { if (ptr[0] == '\\') { if (ptr[1] == 'x' && g_ascii_isxdigit(ptr[2]) && g_ascii_isxdigit(ptr[3])) { gunichar wc; wc = g_ascii_xdigit_value(ptr[2]) * 16 + g_ascii_xdigit_value(ptr[3]); g_string_append_unichar(str, wc); ptr += 3; } else { ptr += 1; g_string_append_c(str, ptr[0]); } } else { g_string_append_c(str, ptr[0]); } } w = GRAstrwidth(str->str, bbox->fontalias, bbox->font_style, bbox->pt); h = GRAcharascent(bbox->fontalias, bbox->font_style, bbox->pt); d = GRAchardescent(bbox->fontalias, bbox->font_style, bbox->pt); x = 0; y = d; x1 = (int )(bbox->posx + ( x * ccos + y * csin)); y1 = (int )(bbox->posy + (-x * csin + y * ccos)); x = 0; y = -h; x2 = (int )(bbox->posx + ( x * ccos + y * csin)); y2 = (int )(bbox->posy + (-x * csin + y * ccos)); x = w; y = d; x3 = (int )(bbox->posx + ( x * ccos + y * csin)); y3 = (int )(bbox->posy + (-x * csin + y * ccos)); x = w; y = -h; x4 = (int )(bbox->posx + (int )( x * ccos + y * csin)); y4 = (int )(bbox->posy + (int )(-x * csin + y * ccos)); setbbminmax(bbox, x1, y1, x4, y4, FALSE); setbbminmax(bbox, x2, y2, x3, y3, FALSE); bbox->posx += (int )((w + bbox->spc * 25.4 / 72) * ccos); bbox->posy -= (int )((w + bbox->spc * 25.4 / 72) * csin); g_string_free(str, TRUE); return 0; } int GRAboundingbox(char code, int *cpar, char *cstr, void *local) { int lw, j; struct GRAbbox *bbox; char *tmp; bbox=local; switch (code) { case 'I': case 'X': case 'E': case '%': case 'G': case 'Z': break; case 'V': bbox->offsetx=cpar[1]; bbox->offsety=cpar[2]; bbox->posx=0; bbox->posy=0; if (cpar[5]==1) bbox->clip=TRUE; else bbox->clip=FALSE; bbox->clipsizex=cpar[3]-cpar[1]; bbox->clipsizey=cpar[4]-cpar[2]; break; case 'A': bbox->linew=cpar[2]/2; break; case 'M': bbox->posx=cpar[1]; bbox->posy=cpar[2]; break; case 'N': bbox->posx+=cpar[1]; bbox->posy+=cpar[2]; break; case 'L': setbbminmax(bbox,cpar[1],cpar[2],cpar[3],cpar[4],TRUE); break; case 'T': setbbminmax(bbox,bbox->posx,bbox->posy,cpar[1],cpar[2],TRUE); bbox->posx=cpar[1]; bbox->posy=cpar[2]; break; case 'C': lw = (cpar[7] == 0); if (cpar[7]==1) setbbminmax(bbox,cpar[1],cpar[2],cpar[1],cpar[2],lw); setbbminmax(bbox,cpar[1]+(int )(cpar[3]*cos(cpar[5]/18000.0*MPI)), cpar[2]-(int )(cpar[4]*sin(cpar[5]/18000.0*MPI)), cpar[1]+(int )(cpar[3]*cos((cpar[5]+cpar[6])/18000.0*MPI)), cpar[2]-(int )(cpar[4]*sin((cpar[5]+cpar[6])/18000.0*MPI)),lw); cpar[6]+=cpar[5]; cpar[5]-=9000; cpar[6]-=9000; if ((cpar[5]<0) && (cpar[6]>0)) setbbminmax(bbox,cpar[1],cpar[2]-cpar[4],cpar[1],cpar[2]-cpar[4],lw); cpar[5]-=9000; cpar[6]-=9000; if ((cpar[5]<0) && (cpar[6]>0)) setbbminmax(bbox,cpar[1]-cpar[3],cpar[2],cpar[1]-cpar[3],cpar[2],lw); cpar[5]-=9000; cpar[6]-=9000; if ((cpar[5]<0) && (cpar[6]>0)) setbbminmax(bbox,cpar[1],cpar[2]+cpar[4],cpar[1],cpar[2]+cpar[4],lw); cpar[5]-=9000; cpar[6]-=9000; if ((cpar[5]<0) && (cpar[6]>0)) setbbminmax(bbox,cpar[1]+cpar[3],cpar[2],cpar[1]+cpar[3],cpar[2],lw); break; case 'B': setbbminmax(bbox,cpar[1],cpar[2],cpar[3],cpar[4], cpar[5] == 0); break; case 'P': setbbminmax(bbox,cpar[1],cpar[2],cpar[1],cpar[2],FALSE); break; case 'R': for (j = 0; j < cpar[1] - 1; j++) setbbminmax(bbox, cpar[j * 2 + 2], cpar[j * 2 + 3], cpar[j * 2 + 4], cpar[j * 2 + 5], TRUE); break; case 'D': lw = (cpar[2] == 0); for (j = 0; j < cpar[1] - 1; j++) setbbminmax(bbox, cpar[j * 2 + 3], cpar[j * 2 + 4], cpar[j * 2 + 5], cpar[j * 2 + 6],lw); break; case 'F': g_free(bbox->fontalias); if ((bbox->fontalias=g_malloc(strlen(cstr)+1))!=NULL) strcpy(bbox->fontalias,cstr); break; case 'H': bbox->pt=cpar[1]; bbox->spc=cpar[2]; bbox->dir=cpar[3]; if (cpar[0] > 3) { bbox->font_style = cpar[4]; } bbox->loadfont=TRUE; break; case 'S': get_str_bbox(bbox, cstr); break; case 'K': tmp = sjis_to_utf8(cstr); if (tmp) { get_str_bbox(bbox, tmp); g_free(tmp); } break; } return 0; } ngraph-gtk-6.08.00/src/object.c0000644000175000017500000032574413243770501013072 00000000000000/* * $Id: object.c,v 1.54 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include "nstring.h" #include "object.h" #include "mathfn.h" #include "nhash.h" #include "shell.h" #include #include "math/math_equation.h" #define USE_HASH 1 #define INST_MAX 32767 static struct objlist *objroot=NULL; static struct loopproc *looproot=NULL, *loopnext=NULL; static struct objlist *errobj=NULL; #define ERR_MSG_BUF_SIZE 2048 static char errormsg1[ERR_MSG_BUF_SIZE]={'\0'}; static char errormsg2[ERR_MSG_BUF_SIZE]={'\0'}; static int errcode=0; int Globallock=FALSE; int (*getstdin)(void); int (*putstdout)(const char *s); int (*putstderr)(const char *s); int (*printfstdout)(const char *fmt,...); int (*printfstderr)(const char *fmt,...); int (*ninterrupt)(void); int (*inputyn)(const char *mes); void (*ndisplaydialog)(const char *str); void (*ndisplaystatus)(const char *str); #if USE_HASH static NHASH ObjHash = NULL; #endif static char *errorlist[]={ "", "no heap space.", "parent object not found", "duplicate field identifier", "object id is too large", "instance id is too large", "object not found", "field not found", "only one instance is allowed.", "unable to make an instance.", "instance not found, id", "instance not found, oid", "named instance not found", "not allowed to destruct.", "permission denied", "not defined current instance.", "instance does not exist.", "illegal object identifier", "illegal instance identifier", "illegal field identifier", "extra object arguments", "not enough object argument", "illegal type of object argument", "instance exist. cannot overwrite object", }; #define ERRNUM (sizeof(errorlist) / sizeof(*errorlist)) static int chkobjtblpos(struct objlist *obj, const char *name, struct objlist **robj); void error(struct objlist *obj,int code) { char *objname; char **errtable; int errnum; Globallock=TRUE; errobj=obj; errcode=code; if (code < 0) { code = ERRUNKNOWN; } if (obj==NULL) { objname="kernel"; } else { objname=obj->name; } if (code==ERRUNKNOWN) { printfstderr("%.64s: %.256s%.256s\n", objname,errormsg1,errormsg2); } else if (code<100) { errtable=errorlist; errnum=ERRNUM; if ((errtable==NULL) || (code>=errnum)) { printfstderr("%.64s: %.256s(%d)%.256s\n",objname,errormsg1,code,errormsg2); } else { printfstderr("%.64s: %.256s%.256s%.256s\n", objname,errormsg1,errtable[code],errormsg2); } } else { errtable=obj->errtable; errnum=obj->errnum; code=code-100; if ((errtable==NULL) || (code>=errnum)) { printfstderr("%.64s: %.256s(%d)%.256s\n",objname,errormsg1,code,errormsg2); } else { printfstderr("%.64s: %.256s%.256s%.256s\n", objname,errormsg1,errtable[code],errormsg2); } } errormsg1[0]='\0'; errormsg2[0]='\0'; Globallock=FALSE; } static char * get_localized_str(const char *str) { char *local_str; if (g_utf8_validate(str, -1, NULL)) { local_str = g_locale_from_utf8(str, -1, NULL, NULL, NULL); } else { local_str = g_strdup(str); } return local_str; } void error2(struct objlist *obj,int code, const char *mes) { if (mes!=NULL) { char *local_msg; local_msg = get_localized_str(mes); snprintf(errormsg2, sizeof(errormsg2), " `%.256s'.", CHK_STR(local_msg)); g_free(local_msg); } else { sprintf(errormsg2,"."); } error(obj,code); } void error22(struct objlist *obj,int code, const char *mes1, const char *mes2) { char *local_msg; if (mes1!=NULL) { local_msg = get_localized_str(mes1); snprintf(errormsg1, sizeof(errormsg1), "%.256s: ", CHK_STR(local_msg)); g_free(local_msg); } else { errormsg1[0]='\0'; } if (mes2!=NULL) { local_msg = get_localized_str(mes2); snprintf(errormsg2, sizeof(errormsg2), " `%.256s'.", CHK_STR(local_msg)); g_free(local_msg); } else { sprintf(errormsg2,"."); } error(obj,code); } void error3(struct objlist *obj,int code,int num) { snprintf(errormsg2, sizeof(errormsg2), " `%d'.",num); error(obj,code); } static int vgetchar(void) { return EOF; } static int vputs(const char *s) { return 0; } static int vnprintf(const char *fmt,...) { return 0; } int seputs(const char *s) { return fputs(s,stderr); } int seprintf(const char *fmt,...) { int code; va_list ap; va_start(ap,fmt); code=vfprintf(stderr,fmt,ap); va_end(ap); return code; } int vinterrupt(void) { return FALSE; } int vinputyn(const char *mes) { return FALSE; } static void vdisplaydialog(const char *str) { } static void vdisplaystatus(const char *str) { } struct savedstdio stdiosave; void ignorestdio(struct savedstdio *save) { if (save==NULL) savestdio(&stdiosave); else savestdio(save); getstdin=vgetchar; putstdout=vputs; putstderr=vputs; printfstdout=vnprintf; printfstderr=vnprintf; ndisplaydialog=vdisplaydialog; ndisplaystatus=vdisplaystatus; } void restorestdio(struct savedstdio *save) { if (save==NULL) loadstdio(&stdiosave); else loadstdio(save); } void savestdio(struct savedstdio *save) { save->getstdin=getstdin; save->putstdout=putstdout; save->putstderr=putstderr; save->printfstdout=printfstdout; save->printfstderr=printfstderr; save->ninterrupt=ninterrupt; save->inputyn=inputyn; save->ndisplaydialog=ndisplaydialog; save->ndisplaystatus=ndisplaystatus; } void loadstdio(struct savedstdio *save) { getstdin=save->getstdin; putstdout=save->putstdout; putstderr=save->putstderr; printfstdout=save->printfstdout; printfstderr=save->printfstderr; ninterrupt=save->ninterrupt; inputyn=save->inputyn; ndisplaydialog=save->ndisplaydialog; ndisplaystatus=save->ndisplaystatus; } #define ALLOCSIZE 32 void arrayinit(struct narray *array,unsigned int base) { if (array==NULL) return; array->base=base; array->num=0; array->size=0; array->data=NULL; } struct narray * arraynew(unsigned int base) { struct narray *array; if ((array=g_malloc(sizeof(struct narray)))==NULL) return NULL; arrayinit(array,base); return array; } void * arraydata(struct narray *array) { if (array==NULL) return NULL; return array->data; } unsigned int arraynum(struct narray *array) { if (array==NULL) return 0; return array->num; } static unsigned int arraybase(struct narray *array) { if (array==NULL) return 0; return array->base; } void arraydel(struct narray *array) { if (array==NULL) return; g_free(array->data); array->data=NULL; array->size=0; array->num=0; } void arraydel2(struct narray *array) { unsigned int i; char **data; if (array==NULL) return; data=array->data; for (i=0;inum;i++) g_free(data[i]); g_free(array->data); array->data=NULL; array->size=0; array->num=0; } void arrayclear(struct narray *array) { if (array == NULL) return; array->num=0; } void arrayclear2(struct narray *array) { unsigned int i; char **data; if (array == NULL) return; data = array->data; for (i = 0; i < array->num; i++) { g_free(data[i]); } array->num=0; } int arraycmp(struct narray *a, struct narray *b) { if (a == NULL || b == NULL) { return 1; } if (a->base != b->base) { return 1; } if (a->num != b->num) { return 1; } if (a->data == NULL && b->data == NULL) { return 0; } if (a->data == NULL || b->data == NULL) { return 1; } return memcmp(a->data, b->data, a->base * a->num); } int arraycpy(struct narray *dest, struct narray *src) { void *data; if (dest == NULL || src == NULL) { return 1; } if (dest->base != src->base) { return 1; } if (src->num > dest->size) { data = g_realloc(dest->data, src->base * src->size); if (data == NULL) { return 1; } dest->data = data; dest->size = src->size; } memcpy(dest->data, src->data, src->num * src->base); dest->num = src->num; return 0; } struct narray * arraydup(struct narray *array) { struct narray *new_ary; if (array == NULL) { return NULL; } new_ary = g_malloc(sizeof(*new_ary)); if (new_ary == NULL ) { return NULL; } *new_ary = *array; if (array->data) { new_ary->data = g_memdup(array->data, array->base * array->size); if (new_ary->data == NULL) { g_free(new_ary); return NULL; } } return new_ary; } struct narray * arraydup2(struct narray *array) { struct narray *new_ary; char **data, **new_data; unsigned int i; new_ary = arraydup(array); if (new_ary == NULL ) { return NULL; } data = array->data; new_data = new_ary->data; for (i = 0; i < array->num; i++) { new_data[i] = g_strdup(data[i]); } return new_ary; } void arrayfree(struct narray *array) { if (array==NULL) return; g_free(array->data); g_free(array); } void arrayfree2(struct narray *array) { unsigned int i; char **data; if (array==NULL) return; data=array->data; for (i=0;inum;i++) g_free(data[i]); g_free(array->data); g_free(array); } struct narray * arrayadd(struct narray *array,const void *val) { int size,base; char *data; if (array==NULL || val == NULL) return NULL; if (array->num==array->size) { size=array->size+ALLOCSIZE; if ((data=g_realloc(array->data,array->base*size))==NULL) { return NULL; } array->size=size; array->data=data; } else data=array->data; base=array->base; memcpy(data+array->num*base,val,base); (array->num)++; return array; } struct narray * arrayadd2(struct narray *array,const char *val) { int size; char **data; char *s; if (array == NULL) return NULL; if (val == NULL) { return NULL; } else { s = g_strdup(val); if (s == NULL) { arraydel2(array); return NULL; } } if (array->num == array->size) { size = array->size+ALLOCSIZE; data=g_realloc(array->data,array->base*size); if (data == NULL) { return NULL; } array->size = size; array->data = data; } else { data = array->data; } data[array->num] = s; (array->num)++; return array; } struct narray * arrayins(struct narray *array,const void *val,unsigned int idx) { unsigned int i; int size,base; char *data; if (array==NULL) return NULL; if (idx>array->num) return NULL; if (array->num==array->size) { size=array->size+ALLOCSIZE; if ((data=g_realloc(array->data,array->base*size))==NULL) { return NULL; } array->size=size; array->data=data; } else data=array->data; base=array->base; for (i=array->num;i>idx;i--) memcpy(data+i*base,data+(i-1)*base,base); memcpy(data+idx*base,val,base); (array->num)++; return array; } struct narray * arrayins2(struct narray *array, const char *val, unsigned int idx) { unsigned int i; int size; char **data; char *s; if (array == NULL) { return NULL; } if (idx > array->num) { return NULL; } if (val == NULL) { return NULL; } s = g_strdup(val); if (s == NULL) { arraydel2(array); return NULL; } if (array->num == array->size) { size = array->size+ALLOCSIZE; data = g_realloc(array->data,array->base*size); if (data == NULL) { return NULL; } array->size=size; array->data=data; } else { data = array->data; } for (i = array->num; i > idx; i--) { data[i] = data[i-1]; } data[idx] = s; (array->num)++; return array; } struct narray * array_reverse(struct narray *array) { unsigned int i, base, num, n; char *data, *buf; if (array == NULL) { return NULL; } data = array->data; base = array->base; num = array->num; n = num / 2; num--; buf = g_malloc(base); if (buf == NULL) { return NULL; } for (i = 0; i < n; i++) { memcpy(buf, data + i * base, base); memcpy(data + i * base, data + (num - i) * base, base); memcpy(data + (num - i) * base, buf, base); } g_free(buf); return array; } struct narray * arrayndel(struct narray *array,unsigned int idx) { int base; char *data; if (array==NULL) return NULL; if (idx>=array->num) return NULL; data=array->data; base=array->base; #if 0 for (i=idx+1;inum;i++) memcpy(data+(i-1)*base,data+i*base,base); #else data += (idx * base); memmove(data, data + base, base * (array->num - idx - 1)); #endif (array->num)--; return array; } struct narray * array_slice(struct narray *array, int start, int length) { int base, num; char *data; if (array == NULL) { return NULL; } data = array->data; base = array->base; num = array->num; if (length < 0) { return NULL; } if (start < 0) { start = num + start; } if (start < 0) { return NULL; } if (start >= num) { return NULL; } if (start + length > num) { length = num - start; } if (length > 0) { memmove(data, data + start * base, length * base); } array->num = length; return array; } struct narray * array_slice2(struct narray *array, int start, int length) { int i, base, num; char *data, **sarray; if (array == NULL) { return NULL; } data = array->data; sarray = array->data; base = array->base; num = array->num; if (length < 0) { return NULL; } if (start < 0) { start = num + start; } if (start < 0) { return NULL; } if (start >= num) { return NULL; } if (start + length > num) { length = num - start; } for (i = 0; i < start; i++) { g_free(sarray[i]); } for (i = start + length; i < num; i++) { g_free(sarray[i]); } if (length > 0) { memmove(data, data + start * base, length * base); } array->num = length; return array; } struct narray * arrayndel2(struct narray *array,unsigned int idx) { char **data; if (array==NULL) return NULL; if (idx>=array->num) return NULL; data=(char **)array->data; g_free(data[idx]); #if 0 for (i=idx+1;inum;i++) data[i-1]=data[i]; #else data += idx; memmove(data, data + 1, sizeof(*data) * (array->num - idx - 1)); #endif (array->num)--; return array; } struct narray * arrayput(struct narray *array,const void *val,unsigned int idx) { int base; char *data; if (array==NULL) return NULL; if (idx>=array->num) return NULL; data=array->data; base=array->base; memcpy(data+idx*base,val,base); return array; } struct narray * arrayput2(struct narray *array, const char *val, unsigned int idx) { char *s; char **data; if (array == NULL) { return NULL; } if (idx >= array->num) { return NULL; } if (val == NULL){ return NULL; } s = g_strdup(val); if (s == NULL) { arraydel2(array); return NULL; } data = (char **)array->data; g_free(data[idx]); data[idx] = s; return array; } void * arraynget(struct narray *array,unsigned int idx) { int base; char *data; if (array==NULL) return NULL; if (idx>=array->num) return NULL; data=array->data; base=array->base; return data+idx*base; } int arraynget_int(struct narray *array, unsigned int idx) { void *ptr; ptr = arraynget(array, idx); return (ptr) ? * (int *) ptr : 0; } double arraynget_double(struct narray *array, unsigned int idx) { void *ptr; ptr = arraynget(array, idx); return (ptr) ? * (double *) ptr : 0; } char * arraynget_str(struct narray *array, unsigned int idx) { void *ptr; ptr = arraynget(array, idx); return (ptr) ? * (char **) ptr : NULL; } void * arraylast(struct narray *array) { int base; char *data; if (array==NULL) return NULL; if (array->num==0) return NULL; data=array->data; base=array->base; return data+(array->num-1)*base; } int arraylast_int(struct narray *array) { void *ptr; ptr = arraylast(array); return (ptr) ? * (int *) ptr : 0; } static int cmp_func_int(const void *p1, const void *p2) { return (* (int *) p1) - (* (int *) p2); } static int cmp_func_int_r(const void *p1, const void *p2) { return (* (int *) p2) - (* (int *) p1); } void arraysort_int(struct narray *array) { int num, *adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(int), cmp_func_int); } } void arrayrsort_int(struct narray *array) { int num, *adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(int), cmp_func_int_r); } } void arrayuniq_int(struct narray *array) { int i, val, num, *adata; if (array == NULL) { return; } num = arraynum(array); if (num < 2) { return; } adata = arraydata(array); val = adata[0]; for (i = 1; i < num;) { if (adata[i] == val) { arrayndel(array, i); num--; } else { val = adata[i]; i++; } } } static int cmp_func_double(const void *p1, const void *p2) { double d1, d2; d1 = * (double *) p1; d2 = * (double *) p2; if (d1 > d2) { return 1; } else if (d1 < d2) { return -1; } return 0; } static int cmp_func_double_r(const void *p1, const void *p2) { double d1, d2; d1 = * (double *) p1; d2 = * (double *) p2; if (d1 > d2) { return -1; } else if (d1 < d2) { return 1; } return 0; } void arraysort_double(struct narray *array) { int num; double *adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(double), cmp_func_double); } } void arrayrsort_double(struct narray *array) { int num; double *adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(double), cmp_func_double_r); } } void arrayuniq_double(struct narray *array) { int i, num; double *adata, val; if (array == NULL) { return; } num = arraynum(array); if (num < 2) { return; } adata = arraydata(array); val = adata[0]; for (i = 1; i < num;) { if (adata[i] == val) { arrayndel(array, i); num--; } else { val = adata[i]; i++; } } } static int cmp_func_str(const void *p1, const void *p2) { return g_strcmp0(* (char **) p1, * (char **) p2); } static int cmp_func_str_r(const void *p1, const void *p2) { return - g_strcmp0(* (char **) p1, * (char **) p2); } void arraysort_str(struct narray *array) { int num; char **adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(char *), cmp_func_str); } } void arrayrsort_str(struct narray *array) { int num; char **adata; if (array == NULL) { return; } num = arraynum(array); adata = arraydata(array); if (num > 1) { qsort(adata, num, sizeof(char *), cmp_func_str_r); } } void arrayuniq_str(struct narray *array) { int i, num; char **adata, *val; if (array == NULL) { return; } num = arraynum(array); if (num < 2) { return; } adata = arraydata(array); val = adata[0]; for (i = 1; i < num;) { if (g_strcmp0(adata[i], val) == 0) { arrayndel2(array, i); num--; } else { val = adata[i]; i++; } } } void arrayuniq_all_str(struct narray *array) { int i, j, num; char **adata, *val; if (array == NULL) { return; } num = arraynum(array); if (num < 2) { return; } adata = arraydata(array); for (j = 0; j < num - 1; j++) { val = adata[j]; for (i = j + 1; i < num;) { if (g_strcmp0(adata[i], val) == 0) { arrayndel2(array, i); num--; } else { i++; } } } } #define ARGBUFNUM 32 int getargc(char **arg) { int i; if (arg==NULL) return 0; for (i=0;arg[i]!=NULL;i++) ; return i; } char ** arg_add(char ***arg,void *ptr) { int i,num; char **arg2; if (*arg==NULL) { if ((*arg=g_malloc(ARGBUFNUM*sizeof(void *)))==NULL) return NULL; (*arg)[0]=NULL; } i=getargc(*arg); num=i/ARGBUFNUM; if (i%ARGBUFNUM==ARGBUFNUM-1) { if ((arg2=g_realloc(*arg,ARGBUFNUM*sizeof(void *)*(num+2)))==NULL) return NULL; *arg=arg2; } (*arg)[i]=ptr; (*arg)[i+1]=NULL; return *arg; } static char ** arg_add2(char ***arg,int argc,...) { va_list ap; int i; if (*arg==NULL) { if ((*arg=g_malloc(ARGBUFNUM*sizeof(void *)))==NULL) return NULL; (*arg)[0]=NULL; } va_start(ap,argc); for (i=0;inext!=NULL) lpcur=lpcur->next; lpcur->next=lpnew; } lpnew->next=NULL; lpnew->objname=objname; lpnew->evname=evname; lpnew->obj=obj; lpnew->idn=idn; lpnew->inst=inst; lpnew->local=local; } void unregisterevloop(struct objlist *obj,int idn,N_VALUE *inst) { struct loopproc *lpcur,*lpdel,*lpprev; lpcur=looproot; lpprev=NULL; while (lpcur!=NULL) { if ((lpcur->obj==obj) && (lpcur->idn==idn) && (lpcur->inst==inst)) { lpdel=lpcur; if (loopnext==lpdel) loopnext=lpdel->next; if (lpprev==NULL) looproot=lpcur->next; else lpprev->next=lpdel->next; lpcur=lpcur->next; g_free(lpdel); } else { lpprev=lpcur; lpcur=lpcur->next; } } } #ifdef COMPILE_UNUSED_FUNCTIONS static void unregisterallevloop(void) { struct loopproc *lpcur,*lpdel; lpcur=looproot; while (lpcur!=NULL) { lpdel=lpcur; lpcur=lpcur->next; g_free(lpdel); } looproot=NULL; loopnext=NULL; } #endif /* COMPILE_UNUSED_FUNCTIONS */ int has_eventloop(void) { return looproot != NULL; } void eventloop(void) { static int ineventloop = FALSE; struct loopproc *lpcur; char *argv[4]; if (looproot==NULL) return; if (ineventloop) return; ineventloop=TRUE; ignorestdio(NULL); lpcur=looproot; while (lpcur!=NULL) { argv[0]= (char *) lpcur->objname; argv[1]= (char *) lpcur->evname; argv[2]=lpcur->local; argv[3]=NULL; loopnext=lpcur->next; __exeobj(lpcur->obj,lpcur->idn,lpcur->inst,3,argv); lpcur=loopnext; } restorestdio(NULL); ineventloop=FALSE; } struct objlist * chkobjroot() { return objroot; } #if USE_HASH static int add_obj_to_hash(char *name, char *alias, void *obj) { if (ObjHash == NULL) { ObjHash = nhash_new(); if (ObjHash == NULL) return 1; } if (nhash_set_ptr(ObjHash, name, obj)) return 1; if (alias) { char *s, *aliasname; int len; s = alias; while ((aliasname = getitok2(&s, &len, ":"))) { if (nhash_set_ptr(ObjHash, aliasname, obj)) { g_free(aliasname); return 1; } g_free(aliasname); } } return 0; } #endif static int check_arglist(int type, const char *arglist) { int i; if (type == NENUM) { return (arglist) ? 0 : 1; } if (arglist == NULL || arglist[0] == '\0') { return 0; } if (arglist[1] == 'a') { if (arglist[0] != 's' && arglist[0] != 'i' && arglist[0] != 'd' && arglist[2] != '\0') { return 1; } return 0; } for (i = 0; arglist[i]; i++) { if (strchr("soidb", arglist[i]) == NULL) { return 1; } } return 0; } void * addobject(char *name,char *alias,char *parentname,char *ver, int tblnum,struct objtable *table, int errnum,char **errtable,void *local,DoneProc doneproc) /* addobject() returns NULL on error */ { struct objlist *objcur,*objprev,*objnew,*parent, *ptr; int i,offset; NHASH tbl_hash = NULL; static int id = 1; if (id >= OBJ_MAX) { error3(NULL, ERROBJNUM, id); return NULL; } objcur = chkobject(name); if (objcur) { error2(NULL,ERROVERWRITE,name); return NULL; } if (parentname==NULL) parent=NULL; else if ((parent=chkobject(parentname))==NULL) { error2(NULL,ERRPARENT,parentname); return NULL; } if ((objnew=g_malloc(sizeof(struct objlist)))==NULL) return NULL; #if USE_HASH if (add_obj_to_hash(name, alias, objnew)) { g_free(objnew); error2(NULL,ERRHEAP,name); return NULL; } tbl_hash = nhash_new(); if (tbl_hash == NULL) { g_free(objnew); error2(NULL,ERRHEAP,name); return NULL; } #endif objprev = NULL; if (parent) { if (parent->child) { ptr = parent->child; while (ptr && chkobjparent(ptr) == parent) { objprev = ptr; ptr = ptr->next; } while (objprev->child) { ptr = objprev->child; while (ptr) { objprev = ptr; ptr = objprev->next; } } } else { objprev = parent; parent->child = objnew; } } if (objprev == NULL) { objroot=objnew; objnew->next = NULL; } else if (objprev->next) { objnew->next = objprev->next; objprev->next = objnew; } else { objprev->next = objnew; objnew->next = NULL; } objnew->id=id; objnew->curinst=-1; objnew->lastinst=-1; objnew->lastinst2=-1; objnew->lastoid=INT_MAX; objnew->name=name; objnew->alias=alias; objnew->ver=ver; objnew->tblnum=tblnum; objnew->fieldnum=-1; objnew->table=table; #if USE_HASH objnew->table_hash=tbl_hash; #endif objnew->errnum=errnum; objnew->errtable=errtable; objnew->parent=parent; objnew->child=NULL; objnew->root=NULL; objnew->root2=NULL; objnew->undo = NULL; objnew->redo = NULL; objnew->local=local; objnew->doneproc=doneproc; objnew->dup_func = NULL; objnew->free_func = NULL; if (parent==NULL) offset=0; else offset=parent->size; for (i=0;isize=offset; objnew->idp=chkobjoffset(objnew,"id"); objnew->oidp=chkobjoffset(objnew,"oid"); objnew->nextp=chkobjoffset(objnew,"next"); id++; return objnew; errexit: g_free(objnew); nhash_free(tbl_hash); error2(NULL,ERRHEAP,name); return NULL; } void obj_set_undo_func(struct objlist *obj, UNDO_DUP_FUNC dup_func, UNDO_FREE_FUNC free_func) { if (obj == NULL) { return; } obj->dup_func = dup_func; obj->free_func = free_func; } void hideinstance(struct objlist *obj) { N_VALUE *instcur,*instprev; int nextp,idp; if ((idp=obj->idp)==-1) return; if ((nextp=obj->nextp)==-1) return; if (obj->lastinst==-1) return; if (obj->lastinst2==-1) { obj->root2=obj->root; obj->lastinst2=obj->lastinst; } else { instcur=obj->root; while (instcur!=NULL) { instcur[idp].i+=obj->lastinst2+1; instcur=instcur[nextp].inst; } instcur=obj->root2; instprev=NULL; while (instcur!=NULL) { instprev=instcur; instcur=instcur[nextp].inst; } instprev[nextp].inst=obj->root; obj->lastinst2+=obj->lastinst+1; } obj->root=NULL; obj->lastinst=-1; } void recoverinstance(struct objlist *obj) { N_VALUE *instcur,*instprev; int nextp,idp; if ((idp=obj->idp)==-1) return; if ((nextp=obj->nextp)==-1) return; if (obj->lastinst2==-1) return; if (obj->lastinst==-1) { obj->root=obj->root2; obj->lastinst=obj->lastinst2; } else { instcur=obj->root; while (instcur!=NULL) { instcur[idp].i+=obj->lastinst2+1; instcur=instcur[nextp].inst; } instcur=obj->root2; instprev=NULL; while (instcur!=NULL) { instprev=instcur; instcur=instcur[nextp].inst; } instprev[nextp].inst=obj->root; obj->root=obj->root2; obj->lastinst+=obj->lastinst2+1; } obj->root2=NULL; obj->lastinst2=-1; } int obj_get_field_pos(struct objlist *obj, const char *field) { int idn; struct objlist *robj; idn = getobjtblpos(obj, field, &robj); if (idn == -1) { return -1; } return chkobjoffset2(robj, idn); } static N_VALUE * dup_inst(struct objlist *obj, N_VALUE *inst) { N_VALUE *inst_new; int i, j, n, idn; const char *field; struct objlist *robj; enum ngraph_object_field_type type; inst_new = g_memdup(inst, obj->size * sizeof(N_VALUE)); if (inst_new == NULL) { return NULL; } if (obj->dup_func) { obj->dup_func(obj, inst, inst_new); } n = chkobjfieldnum(obj); for (i = 0; i < n; i++) { field = chkobjfieldname(obj, i); idn = getobjtblpos(obj, field, &robj); if (idn == -1) { return NULL; } j = chkobjoffset2(robj, idn); type = robj->table[idn].type; switch (type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NPOINTER: /* _local data is copied by obj->dup_func(). */ break; case NIARRAY: case NDARRAY: case NIAFUNC: case NDAFUNC: inst_new[j].array = arraydup(inst[j].array); break; case NSARRAY: case NSAFUNC: inst_new[j].array = arraydup2(inst[j].array); break; case NSTR: case NOBJ: case NSFUNC: inst_new[j].str = g_strdup(inst[j].str); /* If str is NULL g_strdup(str) returns NULL */ break; default: break; } } return inst_new; } static N_VALUE * dup_inst_list(struct objlist *obj) { N_VALUE *inst_new, *inst_prev, *inst, *root; int nextp; if (obj->lastinst == -1) { return NULL; } nextp = obj->nextp; inst_prev = NULL; root = NULL; for (inst = obj->root; inst; inst = inst[nextp].inst) { inst_new = dup_inst(obj, inst); if (inst_new == NULL) { return NULL; /* don't care about the memory leak. */ } if (root == NULL) { root = inst_new; } if (inst_prev) { inst_prev[nextp].inst = inst_new; } inst_prev = inst_new; } return root; } static void free_inst(struct objlist *obj, N_VALUE *inst) { int i, j, n, idn; const char *field; struct objlist *robj; enum ngraph_object_field_type type; if (inst == NULL) { return; } if (obj->free_func) { obj->free_func(obj, inst); } n = chkobjfieldnum(obj); for (i = 0; i < n; i++) { field = chkobjfieldname(obj, i); idn = getobjtblpos(obj, field, &robj); if (idn == -1) { return; } j = chkobjoffset2(robj, idn); type = robj->table[idn].type; switch (type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NPOINTER: /* _local data is freed by obj->free_func(). */ break; case NIARRAY: case NDARRAY: case NIAFUNC: case NDAFUNC: arrayfree(inst[j].array); break; case NSARRAY: case NSAFUNC: arrayfree2(inst[j].array); break; case NSTR: case NOBJ: case NSFUNC: g_free(inst[j].str); break; default: break; } } return; } static void free_inst_list(struct objlist *obj, N_VALUE *inst) { N_VALUE *next; int nextp; nextp = obj->nextp; while (inst) { next = inst[nextp].inst; free_inst(obj, inst); g_free(inst); inst = next; } } static void free_undo_inst(struct objlist *obj, struct undo_inst *cur) { struct undo_inst *next; while (cur) { free_inst_list(obj, cur->inst); next = cur->next; g_free(cur); cur = next; } } static void undo_clear_redo(struct objlist *obj) { free_undo_inst(obj, obj->redo); obj->redo = NULL; } int undo_clear(struct objlist *obj) { undo_clear_redo(obj); free_undo_inst(obj, obj->undo); obj->undo = NULL; return 0; } int undo_save(struct objlist *obj) { struct undo_inst *inst; undo_clear_redo(obj); if (obj == NULL) { return 1; } if (obj->idp == -1) { return 1; } if (obj->nextp == -1) { return 1; } if (obj->lastinst2 != -1) { return 1; } inst = g_malloc(sizeof(*inst)); inst->lastinst = obj->lastinst; inst->lastinst2 = obj->lastinst2; inst->curinst = obj->curinst; inst->lastoid = obj->lastoid; inst->inst = dup_inst_list(obj); undo_clear_redo(obj); inst->next = obj->undo; obj->undo = inst; return 0; } int undo_undo(struct objlist *obj) { int lastoid, lastinst2, curinst, lastinst; N_VALUE *inst; struct undo_inst *undo; undo = obj->undo; if (undo == NULL) { return 1; } lastinst = obj->lastinst; lastinst2 = obj->lastinst2; curinst = obj->curinst; lastoid = obj->lastoid; inst = obj->root; obj->lastinst = undo->lastinst; obj->lastinst2 = undo->lastinst2; obj->curinst = undo->curinst; obj->lastoid = undo->lastoid; obj->root = undo->inst; obj->undo = undo->next; undo->lastinst = lastinst; undo->lastinst2 = lastinst2; undo->curinst = curinst; undo->lastoid = lastoid; undo->inst = inst; undo->next = obj->redo; obj->redo = undo; return 0; } int undo_delete(struct objlist *obj) { struct undo_inst *undo; undo = obj->undo; if (undo == NULL) { return 1; } obj->undo = undo->next; undo->next = NULL; free_undo_inst(obj, undo); return 0; } int undo_check_undo(struct objlist *obj) { return (obj->undo) ? 1 : 0; } int undo_check_redo(struct objlist *obj) { return (obj->redo) ? 1 : 0; } int undo_redo(struct objlist *obj) { int lastoid, lastinst2, curinst, lastinst; N_VALUE *inst; struct undo_inst *redo; redo = obj->redo; if (redo == NULL) { return 1; } lastinst = obj->lastinst; lastinst2 = obj->lastinst2; curinst = obj->curinst; lastoid = obj->lastoid; inst = obj->root; obj->lastinst = redo->lastinst; obj->lastinst2 = redo->lastinst2; obj->curinst = redo->curinst; obj->lastoid = redo->lastoid; obj->root = redo->inst; obj->redo = redo->next; redo->lastinst = lastinst; redo->lastinst2 = lastinst2; redo->curinst = curinst; redo->lastoid = lastoid; redo->inst = inst; redo->next = obj->undo; obj->undo = redo; return 0; } struct objlist * chkobject(const char *name) /* chkobject() returns NULL when the named object is not found */ { #if USE_HASH struct objlist *obj; int r; if (ObjHash == NULL) return NULL; r = nhash_get_ptr(ObjHash, name, (void **) &obj); if (r) return NULL; return obj; #else struct objlist *obj,*objcur; char *s,*aliasname; int len; objcur=objroot; obj=NULL; while (objcur!=NULL) { if (strcmp0(objcur->name,name)==0) obj=objcur; if (objcur->alias!=NULL) { s=objcur->alias; while ((aliasname=getitok(&s,&len,":"))!=NULL) { if (strncmp(aliasname,name,len)==0) obj=objcur; } } objcur=objcur->next; } return obj; #endif } const char * chkobjectname(struct objlist *obj) { if (obj==NULL) return NULL; return obj->name; } const char * chkobjectalias(struct objlist *obj) { if (obj==NULL) return NULL; return obj->alias; } #ifdef COMPILE_UNUSED_FUNCTIONS static void * chkobjectlocal(struct objlist *obj) { if (obj==NULL) return NULL; return obj->local; } #endif /* COMPILE_UNUSED_FUNCTIONS */ int chkobjectid(struct objlist *obj) { if (obj==NULL) return -1; return obj->id; } char * chkobjver(struct objlist *obj) { if (obj==NULL) return NULL; return obj->ver; } struct objlist * chkobjparent(struct objlist *obj) { if (obj==NULL) return NULL; return obj->parent; } int chkobjchild(struct objlist *parent,struct objlist *child) { struct objlist *p; p=child; do { if (p==parent) return TRUE; p=chkobjparent(p); } while (p!=NULL); return FALSE; } int chkobjsize(struct objlist *obj) { if (obj==NULL) return 0; return obj->size * sizeof(N_VALUE); } int chkobjlastinst(struct objlist *obj) { if (obj==NULL) return -1; return obj->lastinst; } int chkobjcurinst(struct objlist *obj) { if (obj==NULL) return -1; return obj->curinst; } int chkobjoffset(struct objlist *obj, const char *name) /* chkobjoffset() returns -1 on error */ { #if USE_HASH struct objlist *objcur; int i; i = chkobjtblpos(obj, name, &objcur); if (i < 0) return -1; return objcur->table[i].offset; #else struct objlist *objcur; int i; if (obj==NULL) return -1; objcur=obj; while (objcur!=NULL) { for (i=0;itblnum;i++) if (strcmp0(objcur->table[i].name,name)==0) return objcur->table[i].offset; objcur=objcur->parent; } return -1; #endif } int chkobjoffset2(struct objlist *obj,int tblpos) { return obj->table[tblpos].offset; } N_VALUE * chkobjinstoid(struct objlist *obj,int oid) /* chkobjinstoid() returns NULL when instance is not found */ { int oidp,nextp; N_VALUE *inst; if ((oidp=obj->oidp)==-1) return NULL; inst=obj->root; if ((nextp=obj->nextp)==-1) { if (inst==NULL) return NULL; if (inst[oidp].i==oid) return inst; else return NULL; } else { while (inst!=NULL) { if (inst[oidp].i==oid) return inst; inst=inst[nextp].inst; } } return NULL; } static int chkobjtblpos(struct objlist *obj, const char *name, struct objlist **robj) /* chkobjtblpos() returns -1 on error */ { #if USE_HASH struct objlist *objcur; int i; objcur = obj; while (objcur) { if (nhash_get_int(objcur->table_hash, name, &i) == 0) { *robj = objcur; return i; } objcur = objcur->parent; } *robj = NULL; return -1; #else struct objlist *objcur; int i; objcur=obj; while (objcur!=NULL) { for (i=0;itblnum;i++) if (strcmp0(objcur->table[i].name,name)==0) { *robj=objcur; return i; } objcur=objcur->parent; } *robj=NULL; return -1; #endif } N_VALUE * chkobjinst(struct objlist *obj,int id) /* chkobjinst() returns NULL if instance is not found */ { int i,nextp; N_VALUE *instcur; instcur=obj->root; i=0; if ((nextp=obj->nextp)==-1) { if ((instcur==NULL) || (id!=0)) { return NULL; } } else { while ((instcur!=NULL) && (id!=i)) { instcur=instcur[nextp].inst; i++; } if (instcur==NULL) { return NULL; } } return instcur; } N_VALUE * chkobjlast(struct objlist *obj) /* chkobjlast() returns NULL if instance is not found */ { N_VALUE *instcur,*instprev; int nextp; instcur=obj->root; nextp=obj->nextp; if (nextp!=-1) { instprev=NULL; while (instcur!=NULL) { instprev=instcur; instcur=instcur[nextp].inst; } instcur=instprev; } return instcur; } static N_VALUE * chkobjprev(struct objlist *obj,int id,N_VALUE **inst,N_VALUE **prev) /* chkobjprev() returns NULL if instance is not found */ { N_VALUE *instcur,*instprev; int i,nextp; if (inst!=NULL) *inst=NULL; if (prev!=NULL) *prev=NULL; instcur=obj->root; instprev=NULL; i=0; if ((nextp=obj->nextp)==-1) { if ((instcur==NULL) || (id!=0)) { return NULL; } } else { while ((instcur!=NULL) && (id!=i)) { instprev=instcur; instcur=instcur[nextp].inst; i++; } if (instcur==NULL) { return NULL; } } if (inst!=NULL) *inst=instcur; if (prev!=NULL) *prev=instprev; return instcur; } static int chkobjid(struct objlist *obj,int id) /* chkobjid() returns -1 on error */ { if ((id>obj->lastinst) || (id<0)) return -1; else return id; } int chkobjoid(struct objlist *obj,int oid) /* chkobjoid() returns -1 on error */ { int oidp,idp,nextp; N_VALUE *inst; if ((oidp=obj->oidp)==-1) return -1; if ((idp=obj->idp)==-1) return -1; inst=obj->root; if ((nextp=obj->nextp)==-1) { if (inst==NULL) return -1; if (inst[oidp].i==oid) return inst[idp].i; else return -1; } else { while (inst!=NULL) { if (inst[oidp].i==oid) return inst[idp].i; inst=inst[nextp].inst; } } return -1; } static int chkobjname(struct objlist *obj,int *id,char *name) /* chkobjname() returns -1 when named object is not found*/ { int i,id2; char *iname; N_VALUE *inst; if (id == NULL) { id2 = 0; } else { id2 = *id; } if (chkobjoffset(obj, "name") == -1) { return -1; } for (i = id2; i <= obj->lastinst; i++) { inst = chkobjinst(obj, i); if (inst == NULL) { return -1; } if (_getobj(obj, "name", inst, &iname) == -1) { return -1; } if (iname && strcmp0(iname, name) == 0) { if (id) { *id = i + 1; } return i; } } if (id) { *id = obj->lastinst + 1; } return -1; } int chkobjfieldnum(struct objlist *obj) { struct objlist *objcur,*objcur2; char *name; int i,j,num; if (obj->fieldnum >= 0) return obj->fieldnum; num=0; objcur=obj; while (objcur!=NULL) { for (i=0;itblnum;i++) { name=objcur->table[i].name; objcur2=obj; while (objcur2!=objcur) { for (j=0;jtblnum;j++) if (strcmp0(name,objcur2->table[j].name)==0) goto match; objcur2=objcur2->parent; } match: if (objcur2==objcur) num++; } objcur=objcur->parent; } obj->fieldnum = num; return num; } char * chkobjfieldname(struct objlist *obj,int num) { struct objlist *objcur,*objcur2,*objcur3; char *name; int i,j,tnum; tnum=0; objcur=NULL; while (objcur!=obj) { objcur2=obj; while (objcur!=(objcur2->parent)) objcur2=objcur2->parent; for (i=0;itblnum;i++) { name=objcur2->table[i].name; objcur3=obj; while (objcur3!=objcur2) { for (j=0;jtblnum;j++) if (strcmp0(name,objcur3->table[j].name)==0) goto match; objcur3=objcur3->parent; } match: if (objcur3==objcur2) { if (tnum==num) return name; tnum++; } } objcur=objcur2; } return NULL; } int chkobjfield(struct objlist *obj,const char *name) { #if USE_HASH struct objlist *objcur; int i; i = chkobjtblpos(obj, name, &objcur); if (i < 0) return -1; return 0; #else struct objlist *objcur; int i; objcur=obj; while (objcur!=NULL) { for (i=0;itblnum;i++) if (strcmp0(objcur->table[i].name,name)==0) return 0; objcur=objcur->parent; } return -1; #endif } int chkobjperm(struct objlist *obj, const char *name) /* chkobjperm() returns 0 on error */ { struct objlist *robj; int idn; if ((idn=chkobjtblpos(obj,name,&robj))==-1) return 0; return robj->table[idn].attrib; } enum ngraph_object_field_type chkobjfieldtype(struct objlist *obj, const char *name) /* chkobjperm() returns VOID on error */ { struct objlist *robj; int idn; if ((idn=chkobjtblpos(obj,name,&robj))==-1) return NVOID; return robj->table[idn].type; } #ifdef COMPILE_UNUSED_FUNCTIONS static void * chkobjproc(struct objlist *obj,char *name) { int namen; struct objlist *robj; if ((namen=chkobjtblpos(obj,name,&robj))==-1) return NULL; return robj->table[namen].proc; } #endif /* COMPILE_UNUSED_FUNCTIONS */ const char * chkobjarglist(struct objlist *obj, const char *name) { int namen; enum ngraph_object_field_type type; struct objlist *robj; char *arglist; if ((namen=chkobjtblpos(obj,name,&robj))==-1) return NULL; type=chkobjfieldtype(obj,name); arglist=robj->table[namen].arglist; if ((arglist==NULL) && (typever; } static int getobjcurinst(struct objlist *obj) { if (obj->curinst==-1) { error(obj,ERROBJCINST); return -1; } return obj->curinst; } static int getobjlastinst(struct objlist *obj) { if (obj->lastinst==-1) { error(obj,ERRNOINST); return -1; } return obj->lastinst; } int getobjoffset(struct objlist *obj, const char *name) /* getoffset() returns -1 on error */ { int offset; if (obj==NULL) { error(NULL,ERROBJFOUND); return -1; } if ((offset=chkobjoffset(obj,name))==-1) { if (strcmp0(name,"id")==0) error(obj,ERRNOID); else error2(obj,ERRVALFOUND,name); } return offset; } int getobjtblpos(struct objlist *obj, const char *name, struct objlist **robj) /* getoffset() returns -1 on error */ { int tblnum; if (obj==NULL) { error(NULL,ERROBJFOUND); return -1; } if ((tblnum=chkobjtblpos(obj,name,robj))==-1) { if (strcmp0(name,"id")==0) error(obj,ERRNOID); else error2(obj,ERRVALFOUND,name); } return tblnum; } N_VALUE * getobjinst(struct objlist *obj,int id) /* getobjinst() returns NULL if instance is not found */ { N_VALUE *instcur; if (obj==NULL) { error(NULL,ERROBJFOUND); return NULL; } if ((instcur=chkobjinst(obj,id))==NULL) { error3(obj,ERRIDFOUND,id); return NULL; } return instcur; } N_VALUE * getobjprev(struct objlist *obj,int id,N_VALUE **inst,N_VALUE **prev) /* getobjprev() returns NULL if instance is not found */ { if (obj==NULL) { error(NULL,ERROBJFOUND); return NULL; } if (chkobjprev(obj,id,inst,prev)==NULL) { error3(obj,ERRIDFOUND,id); return NULL; } return *inst; } N_VALUE * getobjinstoid(struct objlist *obj,int oid) { N_VALUE *inst; if (obj==NULL) { error(NULL,ERROBJFOUND); return NULL; } if ((inst=chkobjinstoid(obj,oid))==NULL) { error3(obj,ERROIDFOUND,oid); return NULL; } return inst; } static int getobjname(struct objlist *obj,int *id,char *name) /* getobjname() returns -1 when named instance is not found */ { int i,id2; char *iname; N_VALUE *inst; if (id==NULL) id2=0; else id2=*id; if (getobjoffset(obj,"name")==-1) return -1; for (i=id2;i<=obj->lastinst;i++) { if ((inst=getobjinst(obj,i))==NULL) return -1; if (_getobj(obj,"name",inst,&iname)==-1) return -1; if ((iname!=NULL) && (strcmp0(iname,name)==0)) { if (id!=NULL) *id=i+1; return i; } } if (id!=NULL) *id=obj->lastinst+1; error2(obj,ERRNMFOUND,name); return -1; } static int getobjid(struct objlist *obj,int id) /* getobjid() returns -1 on error */ { if ((id>obj->lastinst) || (id<0)) { error3(obj,ERRIDFOUND,id); return -1; } else return id; } static int getobjoid(struct objlist *obj,int oid) /* getobjoid() returns -1 on error */ { int id; if ((id=chkobjoid(obj,oid))==-1) { error3(obj,ERROIDFOUND,oid); return -1; } else return id; } int getobjfield(struct objlist *obj, const char *name) { if (chkobjfield(obj,name)==-1) { error2(obj,ERRVALFOUND,name); return -1; } else { return 0; } } #ifdef COMPILE_UNUSED_FUNCTIONS static int getobjproc(struct objlist *obj,char *vname,void *val) { struct objlist *robj; int idn; Proc proc; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; proc=robj->table[idn].proc; *(Proc *)val=proc; return 0; } #endif /* COMPILE_UNUSED_FUNCTIONS */ static void (* NewObjCB)(struct objlist *obj) = NULL; static void (* DelObjCB)(struct objlist *obj) = NULL; int newobj_alias(struct objlist *obj, const char *name) { struct objlist *robj; N_VALUE *instcur,*instnew,*inst; int nextp,id,idp,oidp,rcode,initn,initp; int argc; char **argv; if (obj == NULL || name == NULL) { return -1; } idp = obj->idp; if (idp == -1) { error(obj, ERRNOID); return -1; } initn = getobjtblpos(obj, "init", &robj); if (initn == -1) return -1; initp = chkobjoffset2(robj, initn); if ((robj->table[initn].attrib & NEXEC) == 0) { error2(obj, ERRPERMISSION, "init"); return -1; } id = obj->lastinst + 1; if ((id + obj->lastinst2 + 1) == INST_MAX) { error3(obj, ERRINSTNUM, INST_MAX); return -1; } nextp = obj->nextp; instcur = chkobjinst(obj, obj->lastinst); if (instcur != NULL && nextp == -1) { error(obj, ERRNONEXT); return -1; } instnew = g_malloc0(obj->size * sizeof(N_VALUE)); if (instnew == NULL) { return -1; } instnew[idp].i = id; oidp = obj->oidp; if (oidp != -1) { if (obj->lastoid == INT_MAX) { obj->lastoid=0; } else { obj->lastoid++; } if (nextp != -1) { do { inst=obj->root; while (inst) { if (inst[oidp].i == obj->lastoid) { if (obj->lastoid == INT_MAX) { obj->lastoid=0; } else { obj->lastoid++; } break; } inst = inst[nextp].inst; } if (inst == NULL) { inst = obj->root2; while (inst) { if (inst[oidp].i == obj->lastoid) { if (obj->lastoid == INT_MAX) { obj->lastoid = 0; } else { obj->lastoid++; } break; } inst = inst[nextp].inst; } } } while (inst); } instnew[oidp].i = obj->lastoid; } if (robj->table[initn].proc) { argv = NULL; if (arg_add2(&argv, 2, name, "init") == NULL) { g_free(argv); return -1; } argc = getargc(argv); rcode = robj->table[initn].proc(robj, instnew, instnew + initp, argc, argv); g_free(argv); if (rcode != 0) { g_free(instnew); return -1; } } if (instcur == NULL) { obj->root=instnew; } else { instcur[nextp].inst = instnew; /* nextp != -1 when instcur in not NULL */ } if (nextp != -1) { instnew[nextp].inst = NULL; } obj->lastinst = id; obj->curinst = id; if (NewObjCB) { NewObjCB(obj); } return id; } void set_newobj_cb(void (* newobj_cb)(struct objlist *obj)) { NewObjCB = newobj_cb; } void set_delobj_cb(void (* delobj_cb)(struct objlist *obj)) { DelObjCB = delobj_cb; } int newobj(struct objlist *obj) /* newobj() returns id or -1 on error */ { return newobj_alias(obj, obj->name); } int delobj(struct objlist *obj,int delid) /* delobj() returns id or -1 on error */ { struct objlist *robj,*objcur; N_VALUE *instcur,*instprev,*inst; int i,nextp,idp,donen,donep,rcode,offset; int argc; char **argv; struct narray *array; if ((idp=obj->idp)==-1) { error(obj,ERRNOID); return -1; } if ((donen=chkobjtblpos(obj,"done",&robj))==-1) { error(obj,ERRDESTRUCT); return -1; } donep=chkobjoffset2(robj,donen); if ((robj->table[donen].attrib & NEXEC)==0) { error2(obj,ERRPERMISSION,"done"); return -1; } if (getobjprev(obj,delid,&instcur,&instprev)==NULL) return -1; if (robj->table[donen].proc!=NULL) { argv=NULL; if (arg_add2(&argv,2,obj->name,"done")==NULL) { g_free(argv); return -1; } argc=getargc(argv); rcode=robj->table[donen].proc(robj,instcur,instcur+donep,argc,argv); g_free(argv); if (rcode!=0) return -1; } if ((nextp=obj->nextp)==-1) obj->root=NULL; else { if (instprev==NULL) obj->root=instcur[nextp].inst; else instprev[nextp].inst=instcur[nextp].inst; inst=instcur[nextp].inst; while (inst!=NULL) { inst[idp].i--; inst=inst[nextp].inst; } instcur[nextp].inst=NULL; } objcur=obj; while (objcur!=NULL) { for (i=0;itblnum;i++) { offset=objcur->table[i].offset; switch (objcur->table[i].type) { case NSTR: case NOBJ: case NSFUNC: g_free(instcur[offset].str); break; case NPOINTER: g_free(instcur[offset].ptr); break; case NIARRAY: case NIAFUNC: case NDARRAY: case NDAFUNC: array=instcur[offset].array; arrayfree(array); break; case NSARRAY: case NSAFUNC: array=instcur[offset].array; arrayfree2(array); break; default: break; } } objcur=objcur->parent; } g_free(instcur); obj->lastinst--; obj->curinst=-1; if (DelObjCB) { DelObjCB(obj); } return 0; } void delchildobj(struct objlist *parent) { struct objlist *ocur; int i,instnum; ocur=chkobjroot(); while (ocur!=NULL) { if (chkobjparent(ocur)==parent) { if ((instnum=chkobjlastinst(ocur))!=-1) for (i=instnum;i>=0;i--) delobj(ocur,i); delchildobj(ocur); } ocur=ocur->next; } } int _putobj(struct objlist *obj, const char *vname,N_VALUE *inst,void *val) { struct objlist *robj; int idp,idn; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); switch (robj->table[idn].type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NBOOL: case NBFUNC: case NINT: case NIFUNC: #if USE_NCHAR case NCHAR: case NCFUNC: #endif case NENUM: inst[idp].i=*(int *)val; break; case NDOUBLE: case NDFUNC: inst[idp].d=*(double *)val; break; default: inst[idp].ptr=val; break; } return 0; } int putobj(struct objlist *obj, const char *vname,int id,void *val) /* putobj() returns id or -1 on error */ { struct objlist *robj; struct narray *array; N_VALUE *instcur; int idp,idn,rcode,argc; char **argv; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); if ((instcur=getobjinst(obj,id))==NULL) return -1; if ((robj->table[idn].attrib & NWRITE)==0) { error2(obj,ERRPERMISSION,vname); return -1; } if ((robj->table[idn].typetable[idn].proc!=NULL)) { argv=NULL; if (arg_add2(&argv,3,obj->name,vname,val)==NULL) { g_free(argv); return -1; } argc=getargc(argv); rcode=robj->table[idn].proc(robj,instcur,instcur+idp,argc,argv); val=argv[2]; g_free(argv); if (rcode!=0) return -1; } switch (robj->table[idn].type) { case NSTR: case NOBJ: case NSFUNC: g_free(instcur[idp].str); break; case NPOINTER: g_free(instcur[idp].ptr); break; case NIARRAY: case NIAFUNC: case NDARRAY: case NDAFUNC: array=instcur[idp].array; arrayfree(array); break; case NSARRAY: case NSAFUNC: array=instcur[idp].array; arrayfree2(array); break; default: break; } switch (robj->table[idn].type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NBOOL: case NINT: #if USE_NCHAR case NCHAR: #endif case NENUM: instcur[idp].i=*(int *)val; break; case NDOUBLE: instcur[idp].d=*(double *)val; break; default: instcur[idp].ptr=val; break; } obj->curinst=id; return id; } int _getobj(struct objlist *obj, const char *vname,N_VALUE *inst,void *val) { struct objlist *robj; int idp,idn; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); switch (robj->table[idn].type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NBOOL: case NBFUNC: case NINT: case NIFUNC: #if USE_NCHAR case NCHAR: case NCFUNC: #endif case NENUM: *(int *)val=inst[idp].i; break; case NDOUBLE: case NDFUNC: *(double *)val=inst[idp].d; break; case NSTR: case NSFUNC: case NOBJ: *(char **)val = inst[idp].str; break; case NIARRAY: case NIAFUNC: case NSARRAY: case NSAFUNC: case NDAFUNC: case NDARRAY: *(struct narray **)val = inst[idp].array; break; default: *(char **)val=inst[idp].ptr; break; } return 0; } int getobj(struct objlist *obj, const char *vname,int id, int argc,char **argv,void *val) /* getobj() returns id or -1 on error */ { struct objlist *robj; N_VALUE *instcur; int i,idp,idn; int argc2,rcode; char **argv2; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); if ((instcur=getobjinst(obj,id))==NULL) return -1; if (((robj->table[idn].attrib & NREAD)==0) || ((robj->table[idn].type>=NVFUNC) && ((robj->table[idn].attrib & NEXEC)==0))) { error2(obj,ERRPERMISSION,vname); return -1; } if ((robj->table[idn].type>=NVFUNC) && (robj->table[idn].proc!=NULL)) { argv2=NULL; if (arg_add2(&argv2,2,obj->name,vname)==NULL) { g_free(argv2); return -1; } for (i=0;itable[idn].proc(robj,instcur,instcur+idp,argc2,argv2); g_free(argv2); if (rcode!=0) return -1; } switch (robj->table[idn].type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NBOOL: case NBFUNC: case NINT: case NIFUNC: #if USE_NCHAR case NCHAR: case NCFUNC: #endif case NENUM: *(int *)val=instcur[idp].i; break; case NDOUBLE: case NDFUNC: *(double *)val=instcur[idp].d; break; case NSTR: case NSFUNC: case NOBJ: *(char **)val = instcur[idp].str; break; case NIARRAY: case NIAFUNC: case NSARRAY: case NSAFUNC: case NDAFUNC: case NDARRAY: *(struct narray **)val = instcur[idp].array; break; default: *(char **)val=instcur[idp].ptr; break; } obj->curinst=id; return id; } int _exeparent(struct objlist *obj,const char *vname,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) /* _exeparent() returns errorlevel or -1 on error */ { struct objlist *parent,*robj; int idn,idp,rcode; N_VALUE *rval2; if ((parent=obj->parent)==NULL) return 0; if ((idn=chkobjtblpos(parent,vname,&robj))==-1) return 0; idp=chkobjoffset2(robj,idn); if (chkobjfieldtype(parent,vname)table[idn].proc!=NULL) { rcode=robj->table[idn].proc(robj,inst,rval2,argc,argv); } else rcode=0; return rcode; } int __exeobj(struct objlist *obj,int idn,N_VALUE *inst,int argc,char **argv) /* __exeobj() returns errorlevel or -1 on error */ { int rcode,idp; if (obj->table[idn].typetable[idn].proc!=NULL) { idp=chkobjoffset2(obj,idn); rcode=obj->table[idn].proc(obj,inst,inst+idp,argc,argv); } else rcode=0; return rcode; } int _exeobj(struct objlist *obj,const char *vname,N_VALUE *inst,int argc,char **argv) /* _exeobj() returns errorlevel or -1 on error */ { struct objlist *robj; int i,idn,idp,rcode; int argc2; char **argv2; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); if (robj->table[idn].typetable[idn].proc!=NULL) { argv2=NULL; if (arg_add2(&argv2,2,obj->name,vname)==NULL) { g_free(argv2); return -1; } for (i=0;itable[idn].proc(robj,inst,inst+idp,argc2,argv2); g_free(argv2); } else rcode=0; return rcode; } int exeobj(struct objlist *obj, const char *vname,int id,int argc,char **argv) /* exeobj() returns errorlevel or -1 on error */ { struct objlist *robj; N_VALUE *instcur; int i,idn,idp,rcode; int argc2; char **argv2; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; idp=chkobjoffset2(robj,idn); if ((instcur=getobjinst(obj,id))==NULL) return -1; if ((robj->table[idn].typetable[idn].attrib & NREAD)==0) || ((robj->table[idn].type>=NVFUNC) && ((robj->table[idn].attrib & NEXEC)==0))) { error2(obj,ERRPERMISSION,vname); return -1; } if (robj->table[idn].proc!=NULL) { argv2=NULL; if (arg_add2(&argv2,2,obj->name,vname)==NULL) { g_free(argv2); return -1; } for (i=0;itable[idn].proc(robj,instcur,instcur+idp,argc2,argv2); g_free(argv2); } else rcode=0; obj->curinst=id; return rcode; } int copyobj(struct objlist *obj, const char *vname,int did,int sid) { struct objlist *robj; unsigned int i; int idn; char value[8]; char *po; struct narray *array; char *s; if ((idn=getobjtblpos(obj,vname,&robj))==-1) return -1; if (((robj->table[idn].attrib & NREAD)==0) || ((robj->table[idn].attrib & NWRITE)==0) || (robj->table[idn].type>=NVFUNC)) { error2(obj,ERRPERMISSION,vname); return -1; } po=value; if (getobj(obj,vname,sid,0,NULL,po)==-1) return -1; switch (robj->table[idn].type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NBOOL: case NINT: #if USE_NCHAR case NCHAR: #endif case NENUM: case NDOUBLE: if (putobj(obj,vname,did,po)==-1) return -1; break; case NSTR: case NOBJ: if (*(char **)po==NULL) { if (putobj(obj,vname,did,NULL)==-1) return -1; } else { if ((s=g_malloc(strlen(*(char **)po)+1))==NULL) return -1; strcpy(s,*(char **)po); if (putobj(obj,vname,did,s)==-1) return -1; } break; case NIARRAY: case NDARRAY: if (*(struct narray **)po==NULL) { if (putobj(obj,vname,did,NULL)==-1) return -1; } else { if ((array=arraynew(arraybase(*(struct narray **)po)))==NULL) return -1; for (i=0;iidp; if (idp == -1) { error(obj, ERRNOID); return -1; } if (getobjid(obj, sid) == -1) { return -1; } if (did == sid) { return did; } dinstcur = chkobjinst(obj, did); if (dinstcur == NULL) { return -1; } exchobj(obj,did,sid); if (delobj(obj, sid) == -1) { exchobj(obj, did, sid); return -1; } obj->curinst = dinstcur[idp].i; return dinstcur[idp].i; } int moveupobj(struct objlist *obj,int id) /* moveupobj() returns id or -1 on error */ { N_VALUE *instcur,*instprev,*instcur2,*instprev2; N_VALUE *inst; int idp,nextp; if ((idp=obj->idp)==-1) { error(obj,ERRNOID); return -1; } if (getobjprev(obj,id,&instcur,&instprev)==NULL) return -1; if (id==0) return id; if ((nextp=obj->nextp)==-1) { error2(obj,ERRVALFOUND,"next"); return -1; } if (getobjprev(obj,id-1,&instcur2,&instprev2)==NULL) return -1; inst=instcur[nextp].inst; if (instprev2==NULL) obj->root=instcur; else instprev2[nextp].inst=instcur; instcur[nextp].inst=instprev; if (instprev==NULL) obj->root=inst; else instprev[nextp].inst=inst; instcur[idp].i--; instprev[idp].i++; obj->curinst=id-1; return id-1; } int movetopobj(struct objlist *obj,int id) /* movetopobj() returns id or -1 on error */ { N_VALUE *instcur,*instprev; N_VALUE *rinst,*pinst,*inst; int idp,nextp; if ((idp=obj->idp)==-1) { error(obj,ERRNOID); return -1; } if (getobjprev(obj,id,&instcur,&instprev)==NULL) return -1; if (id==0) return id; if ((nextp=obj->nextp)==-1) { error2(obj,ERRVALFOUND,"next"); return -1; } rinst=obj->root; inst=instcur[nextp].inst; pinst=instprev[nextp].inst; obj->root=pinst; instcur[nextp].inst=rinst; instprev[nextp].inst=inst; instcur[idp].i=0; instcur=rinst; while (instcur!=inst) { instcur[idp].i++; instcur=instcur[nextp].inst; } obj->curinst=0; return 0; } int movedownobj(struct objlist *obj,int id) /* movedownobj() returns id or -1 on error */ { N_VALUE *instcur,*instprev; N_VALUE *ninst,*inst; int idp,nextp,lid; if ((idp=obj->idp)==-1) { error(obj,ERRNOID); return -1; } if (getobjprev(obj,id,&instcur,&instprev)==NULL) return -1; lid=chkobjlastinst(obj); if (id==lid) return id; if ((nextp=obj->nextp)==-1) { error2(obj,ERRVALFOUND,"next"); return -1; } inst=instcur[nextp].inst; ninst=inst[nextp].inst; if (instprev==NULL) obj->root=inst; else instprev[nextp].inst=inst; inst[nextp].inst=instcur; instcur[nextp].inst=ninst; instcur[idp].i++; inst[idp].i--; obj->curinst=id+1; return id+1; } int movelastobj(struct objlist *obj,int id) /* movelastobj() returns id or -1 on error */ { N_VALUE *instcur,*instprev,*lastinst; N_VALUE *pinst,*inst; int idp,nextp,lid; if ((idp=obj->idp)==-1) { error(obj,ERRNOID); return -1; } if (getobjprev(obj,id,&instcur,&instprev)==NULL) return -1; lid=chkobjlastinst(obj); if ((lastinst=getobjinst(obj,lid))==NULL) return -1; if (id==lid) return id; if ((nextp=obj->nextp)==-1) { error2(obj,ERRVALFOUND,"next"); return -1; } inst=instcur[nextp].inst; if (instprev==NULL) pinst=obj->root; else pinst=instprev[nextp].inst; lastinst[nextp].inst=pinst; instcur[nextp].inst=NULL; if (instprev==NULL) obj->root=inst; else instprev[nextp].inst=inst; instcur[idp].i=lid; while (inst!=instcur) { inst[idp].i--; inst=inst[nextp].inst; } obj->curinst=lid; return lid; } int exchobj(struct objlist *obj,int id1,int id2) /* exchobj() returns id or -1 on error */ { N_VALUE *instcur1,*instprev1; N_VALUE *instcur2,*instprev2; N_VALUE *inst,*inst1,*inst2; int idp,id,nextp; idp = obj->idp; if (idp == -1) { error(obj, ERRNOID); return -1; } if (getobjprev(obj, id1, &instcur1, &instprev1)==NULL || getobjprev(obj, id2, &instcur2, &instprev2)==NULL) { return -1; } if (id1 == id2) { return id1; } nextp = obj->nextp; if (nextp == -1) { error2(obj, ERRVALFOUND, "next"); return -1; } id = instcur1[idp].i; instcur1[idp].i = instcur2[idp].i; instcur2[idp].i = id; if (instprev1 == NULL) { inst1 = obj->root; } else { inst1 = instprev1[nextp].inst; } if (instprev2 == NULL) { inst2 = obj->root; } else { inst2 = instprev2[nextp].inst; } if (instprev1 == NULL) { obj->root = inst2; } else { instprev1[nextp].inst = inst2; } if (instprev2 == NULL) { obj->root = inst1; } else { instprev2[nextp].inst = inst1; } inst = instcur1[nextp].inst; instcur1[nextp].inst = instcur2[nextp].inst; instcur2[nextp].inst = inst; obj->curinst = id2; return id2; } /* char *saveobj(struct objlist *obj, int id) { N_VALUE *instcur,*instnew; if ((instcur=getobjinst(obj,id))==NULL) return NULL; if ((instnew=g_malloc(obj->size))==NULL) return NULL; memcpy(instnew,instcur,obj->size * sizeof(N_VALUE)); return instnew; } char *restoreobj(struct objlist *obj,int id,char *image) { N_VALUE *instcur; if (obj==NULL) return NULL; if ((instcur=getobjinst(obj,id))==NULL) return NULL; memcpy(instcur,image,obj->size * sizeof(N_VALUE)); g_free(image); return instcur; } */ static int chkilist(struct objlist *obj,char *ilist,struct narray *iarray,int def,int *spc) /* spc OBJ_LIST_SPECIFIED_NOT_FOUND: not found OBJ_LIST_SPECIFIED_BY_ID: specified by id OBJ_LIST_SPECIFIED_BY_OID: specified by oid OBJ_LIST_SPECIFIED_BY_NAME: specified by name OBJ_LIST_SPECIFIED_BY_OTHER: specified by other */ { int i,len,snum,dnum,num,sid,l; int oid; char *tok,*s,*iname,*endptr; *spc=OBJ_LIST_SPECIFIED_NOT_FOUND; num=0; tok=NULL; if ((ilist==NULL) || (ilist[0]=='\0')) { if (def) { if ((snum=chkobjcurinst(obj))==-1) return -1; if (arrayadd(iarray,&snum)==NULL) goto errexit; num++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } } else { while ((s=getitok2(&ilist,&len," \t,"))!=NULL) { g_free(tok); tok=s; iname=NULL; if (s[0]=='@') { if ((snum=chkobjcurinst(obj))==-1) goto errexit; s++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else if (s[0]=='!') { if ((snum=chkobjlastinst(obj))==-1) goto errexit; s++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else { if (s[0]=='^') { oid=TRUE; s++; } else oid=FALSE; l=strtol(s,&endptr,10); if (s!=endptr) { if (oid) { snum=chkobjoid(obj,l); *spc=OBJ_LIST_SPECIFIED_BY_OID; } else { snum=chkobjid(obj,l); *spc=OBJ_LIST_SPECIFIED_BY_ID; } if (snum==-1) goto errexit; } s=endptr; } if (s==tok) { snum=0; if ((dnum=chkobjlastinst(obj))==-1) goto errexit; iname=tok; } else if (s[0]=='-') { s++; if (s[0]=='@') { if ((dnum=chkobjcurinst(obj))==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else if (s[0]=='!') { if ((dnum=chkobjlastinst(obj))==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else { l=strtol(s,&endptr,10); if (endptr[0]!='\0') { goto errexit; } else { dnum=getobjid(obj,l); if (dnum==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_ID; } } } else if (s[0]=='+') { *spc=OBJ_LIST_SPECIFIED_BY_OTHER; s++; if (s[0]=='@') { if ((dnum=chkobjcurinst(obj))==-1) goto errexit; } else if (s[0]=='!') { if ((dnum=chkobjlastinst(obj))==-1) goto errexit; } else { l=strtol(s,&endptr,10); if (endptr[0]!='\0') { goto errexit; } else { dnum=l; } } snum+=dnum; dnum=snum; } else if (s[0]=='\0') { dnum=snum; } else { goto errexit; } if (iname==NULL) { for (i=snum;i<=dnum;i++) { if (chkobjid(obj,i)==-1) goto errexit; if (arrayadd(iarray,&i)==NULL) goto errexit; num++; } } else { *spc=OBJ_LIST_SPECIFIED_BY_NAME; sid=0; if (chkobjname(obj,&sid,iname)==-1) goto errexit; sid=0; while ((snum=chkobjname(obj,&sid,iname))>=0) { if (arrayadd(iarray,&snum)==NULL) goto errexit; num++; } } } } g_free(tok); return num; errexit: g_free(tok); arraydel(iarray); return -1; } static int getilist(struct objlist *obj,char *ilist,struct narray *iarray,int def,int *spc) /* spc OBJ_LIST_SPECIFIED_NOT_FOUND: not found OBJ_LIST_SPECIFIED_BY_ID: specified by id OBJ_LIST_SPECIFIED_BY_OID: specified by oid OBJ_LIST_SPECIFIED_BY_NAME: specified by name OBJ_LIST_SPECIFIED_BY_OTHER: specified by other */ { int i,len,snum,dnum,num,sid,l; int oid; char *tok,*s,*iname,*endptr; *spc=OBJ_LIST_SPECIFIED_NOT_FOUND; num=0; tok=NULL; if ((ilist==NULL) || (ilist[0]=='\0')) { if (def) { if ((snum=getobjcurinst(obj))==-1) return -1; if (arrayadd(iarray,&snum)==NULL) goto errexit; num++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } } else { while ((s=getitok2(&ilist,&len," \t,"))!=NULL) { g_free(tok); tok=s; iname=NULL; if (s[0]=='@') { if ((snum=getobjcurinst(obj))==-1) goto errexit; s++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else if (s[0]=='!') { if ((snum=getobjlastinst(obj))==-1) goto errexit; s++; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else { if (s[0]=='^') { oid=TRUE; s++; } else oid=FALSE; l=strtol(s,&endptr,10); if (s!=endptr) { if (oid) { snum=getobjoid(obj,l); *spc=OBJ_LIST_SPECIFIED_BY_OID; } else { snum=getobjid(obj,l); *spc=OBJ_LIST_SPECIFIED_BY_ID; } if (snum==-1) goto errexit; } s=endptr; } if (s==tok) { snum=0; if ((dnum=getobjlastinst(obj))==-1) goto errexit; iname=tok; } else if (s[0]=='-') { s++; if (s[0]=='@') { if ((dnum=getobjcurinst(obj))==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else if (s[0]=='!') { if ((dnum=getobjlastinst(obj))==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_OTHER; } else { l=strtol(s,&endptr,10); if (endptr[0]!='\0') { error2(obj,ERRILINST,tok); goto errexit; } else { dnum=getobjid(obj,l); if (dnum==-1) goto errexit; *spc=OBJ_LIST_SPECIFIED_BY_ID; } } } else if (s[0]=='+') { *spc=OBJ_LIST_SPECIFIED_BY_OTHER; s++; if (s[0]=='@') { if ((dnum=getobjcurinst(obj))==-1) goto errexit; } else if (s[0]=='!') { if ((dnum=getobjlastinst(obj))==-1) goto errexit; } else { l=strtol(s,&endptr,10); if (endptr[0]!='\0') { error2(obj,ERRILINST,tok); goto errexit; } else { dnum=l; } } snum+=dnum; dnum=snum; } else if (s[0]=='\0') { dnum=snum; } else { error2(obj,ERRILINST,tok); goto errexit; } if (iname==NULL) { for (i=snum;i<=dnum;i++) { if (getobjid(obj,i)==-1) goto errexit; if (arrayadd(iarray,&i)==NULL) goto errexit; num++; } } else { *spc=OBJ_LIST_SPECIFIED_BY_NAME; sid=0; if (getobjname(obj,&sid,iname)==-1) goto errexit; sid=0; while ((snum=chkobjname(obj,&sid,iname))>=0) { if (arrayadd(iarray,&snum)==NULL) goto errexit; num++; } } } } g_free(tok); return num; errexit: g_free(tok); arraydel(iarray); return -1; } int chkobjilist(char *s,struct objlist **obj,struct narray *iarray,int def,int *spc) { char *oname,*ilist; int r; int spc2; r = getobjiname(s, &oname, &s); if (r) { return r; } if ((*obj=chkobject(oname))==NULL) { g_free(oname); return -1; } g_free(oname); if (s[0]==':') s++; ilist=s; if (def && (chkobjlastinst(*obj)==-1)) return -1; if (chkilist(*obj,ilist,iarray,def,&spc2)==-1) return -1; if (spc!=NULL) *spc=spc2; return 0; } int getobjiname(char *s, char **name, char **ptr) { char *oname; int len; *name = NULL; if (s == NULL) { return -1; } len = 0; if (s[0] == ':' || (oname = getitok2(&s, &len, ":")) == NULL) { if (len == -1) { return -1; } error2(NULL, ERRILOBJ, s); return ERRILOBJ; } if (ptr) { *ptr = s; } *name = oname; return 0; } int getobjilist(char *s,struct objlist **obj,struct narray *iarray,int def,int *spc) { char *oname,*ilist; int r; int spc2; r = getobjiname(s, &oname, &s); if (r) { return r; } if ((*obj=getobject(oname))==NULL) { g_free(oname); return -1; } g_free(oname); if (s[0]==':') s++; ilist=s; if (def && (getobjlastinst(*obj)==-1)) return -1; if (getilist(*obj,ilist,iarray,def,&spc2)==-1) return -1; if (spc!=NULL) *spc=spc2; return 0; } int chkobjilist2(char **s,struct objlist **obj,struct narray *iarray,int def) { char *oname,*ilist; int len,num,spc; if ((oname=getitok2(s,&len,":"))==NULL) { if (len==-1) return -1; return ERRILOBJ; } if ((*obj=chkobject(oname))==NULL) { g_free(oname); return -1; } g_free(oname); if (def && (chkobjlastinst(*obj)==-1)) return -1; if ((*s)[0]=='\0') { return ERRILOBJ; } else if ((*s)[0]==':') (*s)++; if ((*s)[0]==':') ilist=NULL; else { if ((ilist=getitok2(s,&len,":"))==NULL) { if (len==-1) return -1; return ERRILOBJ; } } num=chkilist(*obj,ilist,iarray,def,&spc); g_free(ilist); if (num==-1) return -1; if (((*s)[0]!='\0') && ((*s)[0]==':')) (*s)++; return 0; } int getobjilist2(char **s,struct objlist **obj,struct narray *iarray,int def) { char *oname,*ilist; int len,num,spc; if ((oname=getitok2(s,&len,":"))==NULL) { if (len==-1) return -1; error2(NULL,ERRILOBJ,*s); return ERRILOBJ; } if ((*obj=getobject(oname))==NULL) { g_free(oname); return -1; } g_free(oname); if (def && (getobjlastinst(*obj)==-1)) return -1; if ((*s)[0]=='\0') { error2(NULL,ERRILOBJ,*s); return ERRILOBJ; } else if ((*s)[0]==':') (*s)++; if ((*s)[0]==':') ilist=NULL; else { if ((ilist=getitok2(s,&len,":"))==NULL) { if (len==-1) return -1; error2(NULL,ERRILOBJ,*s); return ERRILOBJ; } } num=getilist(*obj,ilist,iarray,def,&spc); g_free(ilist); if (num==-1) return -1; if (((*s)[0]!='\0') && ((*s)[0]==':')) (*s)++; return 0; } char * mkobjlist(struct objlist *obj, const char *objname,int id, const char *field,int oid) { char ids[11]; char *s; int len,flen; if (objname==NULL) objname=chkobjectname(obj); if (oid) sprintf(ids,"^%d",id); else sprintf(ids,"%d",id); if (field!=NULL) flen=strlen(field); else flen=0; if ((s=g_malloc(strlen(objname)+strlen(ids)+flen+3))==NULL) return NULL; strcpy(s,objname); len=strlen(s); s[len]=':'; strcpy(s+len+1,ids); if (field!=NULL) { len=strlen(s); s[len]=':'; strcpy(s+len+1,field); } return s; } struct objlist * getobjlist(char *list,int *id,char **field,int *oid) { char *objname; char *ids,*ids2; int len; struct objlist *obj; char *endptr; objname=getitok2(&list,&len,":"); ids=getitok2(&list,&len,":"); *field=getitok(&list,&len,":"); if ((objname==NULL) || (ids==NULL) || (*field==NULL)) { g_free(objname); g_free(ids); *field=NULL; return NULL; } obj=chkobject(objname); g_free(objname); if (ids[0]=='^') { if (oid!=NULL) *oid=TRUE; ids2=ids+1; } else { if (oid!=NULL) *oid=FALSE; ids2=ids; } *id=strtol(ids2,&endptr,0); if ((ids2[0]=='\0') || (endptr[0]!='\0') || (chkobjoffset(obj,*field)==-1)) { g_free(ids); *field=NULL; return NULL; } g_free(ids); return obj; } char * chgobjlist(char *olist) { char *list,*objname,*newlist; char *ids,*ids2; int id,len; struct objlist *obj; char *endptr; N_VALUE *inst; list=olist; objname=getitok2(&list,&len,":"); ids=getitok2(&list,&len,":"); if ((objname==NULL) || (ids==NULL)) { g_free(objname); g_free(ids); return NULL; } if (ids[0]!='^') { g_free(objname); g_free(ids); if ((newlist=g_malloc(strlen(olist)+1))==NULL) return NULL; strcpy(newlist,olist); return newlist; } ids2=ids+1; id=strtol(ids2,&endptr,0); if ((ids2[0]=='\0') || (endptr[0]!='\0')) { g_free(objname); g_free(ids); return NULL; } g_free(ids); obj=chkobject(objname); if ((inst=chkobjinstoid(obj,id))==NULL) { g_free(objname); return NULL; } _getobj(obj,"id",inst,&id); newlist=mkobjlist(obj,objname,id,NULL,FALSE); g_free(objname); return newlist; } char * getvaluestr(struct objlist *obj,const char *field,void *val,int cr,int quote) { struct narray *array; void *po; char *bval; const char *arglist; unsigned int k, n; int i; enum ngraph_object_field_type type; GString *str; str = g_string_sized_new(64); if (str == NULL) { return NULL; } arglist=chkobjarglist(obj,field); type=chkobjfieldtype(obj,field); po=val; switch (type) { case NBOOL: case NBFUNC: if (*(int *)po) bval="true"; else bval="false"; g_string_append_printf(str,"%s",bval); break; #if USE_NCHAR case NCHAR: case NCFUNC: g_string_append_printf(str,"%c",*(char *)po); break; #endif case NINT: case NIFUNC: g_string_append_printf(str,"%d",*(int *)po); break; case NDOUBLE: case NDFUNC: g_string_append_printf(str,"%.15e",*(double *)po); break; case NSTR: case NSFUNC: case NOBJ: if (*(char **)po==NULL) break; else { bval=*(char **)po; if (quote) g_string_append_printf(str,"'"); for (i=0;bval[i]!='\0';i++) { if ((bval[i]=='\'') && quote) g_string_append_printf(str,"'\\''"); else g_string_append_printf(str,"%c",bval[i]); } if (quote) g_string_append_printf(str,"'"); } break; case NIARRAY: case NIAFUNC: array=*(struct narray **)po; if (array==NULL) break; else { if (quote) g_string_append_printf(str,"'"); n = arraynum(array); for (k=0;k 0 && j >= sargc && arglist[j + 1]) { err = 1; goto errexit; } if (sargc == 0 || (j >= sargc && arglist[j + 1] == '\0')) { s = NULL; } else { s = sargv[j]; } if (add_arg_object(s, &argv)) { err = 3; goto errexit; } break; case 'i': case 'd': case 'b': if (j >= sargc) { err = 2; goto errexit; } r = add_arg_num(arglist[j], sargv[j], &argv); if (r) { err = r; goto errexit; } break; } } } if (sargv) { g_strfreev(sargv); } *argc = getargc(argv); *rargv = argv; return 0; errexit: if (sargv) { g_strfreev(sargv); } arg_del(argv); *argc = -1; *rargv = NULL; return err; } #else static int getargument(int type,char *arglist, char *val,int *argc, char ***rargv) { struct narray *array; int len,alp; char *list,*s, *s2; int vi; double vd; char **argv,*p; int rcode; int i,err; char **enumlist; char *oname,*os; int olen; struct objlist *obj2; array = NULL; argv = NULL; if (arg_add(&argv,NULL) == NULL) { err = 1; goto errexit; } s2 = NULL; alp = 0; if (val == NULL) { *argc = getargc(argv); *rargv = argv; return 0; } list = val; err = -1; if (type == NENUM) { enumlist = (char **)arglist; arglist = "s"; } else { /* initialize to avoid warning nessage */ enumlist = NULL; } while (TRUE) { if ((arglist != NULL) && ((strcmp0(arglist + alp, "s") == 0) || (strcmp0(arglist + alp, "o") == 0))) { if (list[0] == '\0') { s = NULL; len = 0; alp++; } else { s = list; len = strlen(list); list += len; } } else { s=getitok(&list,&len," \t\n\r"); for (;(list[0]!='\0') && (strchr(" \t\n\r",list[0])!=NULL);list++); } if (s==NULL) break; g_free(s2); if ((s2=g_malloc(len+1))==NULL) goto errexit; strncpy(s2,s,len); s2[len]='\0'; if ((arglist!=NULL) && (arglist[alp]=='\0')) { err=1; goto errexit; } if (arglist==NULL) { if ((p=g_malloc(strlen(s2)+1))==NULL) goto errexit; strcpy(p,s2); if (arg_add(&argv,p)==NULL) goto errexit; } else if (arglist[alp]=='o') { if (arglist[1]=='a') { err=3; goto errexit; } os=s2; if ((oname=getitok2(&os,&olen,":"))==NULL) { err=3; goto errexit; } obj2=chkobject(oname); g_free(oname); if ((obj2==NULL) || (os[0]!=':')) { err=3; goto errexit; } for (i=1; (os[i]!='\0')&&(isalnum(os[i])||(strchr("_^@!+-,",os[i])!=NULL));i++); if (os[i]!='\0') { err=3; goto errexit; } if ((p=g_malloc(strlen(s2)+1))==NULL) goto errexit; strcpy(p,s2); if (arg_add(&argv,p)==NULL) goto errexit; } else if (arglist[alp]=='s') { if (arglist[1]=='a') { if (array==NULL) { if ((array=arraynew(sizeof(char *)))==NULL) goto errexit; } if (arrayadd2(array,s2)==NULL) goto errexit; } else { if ((p=g_malloc(strlen(s2)+1))==NULL) goto errexit; strcpy(p,s2); if (arg_add(&argv,p)==NULL) goto errexit; } } else if ((arglist[alp]=='i') || (arglist[alp]=='d')) { str_calc(s2, &vd, &rcode, NULL); if (rcode!=MATH_VALUE_NORMAL) { err=3; goto errexit; } if (arglist[alp]=='i') { if (arglist[1]=='a') { vi=nround(vd); if (array==NULL) { if ((array=arraynew(sizeof(int)))==NULL) goto errexit; } if (arrayadd(array,&vi)==NULL) goto errexit; } else { if ((p=g_malloc(sizeof(int)))==NULL) goto errexit; *(int *)(p)=nround(vd); if (arg_add(&argv,p)==NULL) goto errexit; } } else { if (arglist[1]=='a') { if (array==NULL) { if ((array=arraynew(sizeof(double)))==NULL) goto errexit; } if (arrayadd(array,&vd)==NULL) goto errexit; } else { if ((p=g_malloc(sizeof(double)))==NULL) goto errexit; *(double *)(p)=vd; if (arg_add(&argv,p)==NULL) goto errexit; } } } else if (arglist[alp]=='b') { if ((strcmp0("T",s2)==0) || (strcmp0("True",s2)==0) || (strcmp0("TRUE",s2)==0) || (strcmp0("t",s2)==0) || (strcmp0("true",s2)==0)) vi=TRUE; else if ((strcmp0("F",s2)==0) || (strcmp0("False",s2)==0) || (strcmp0("FALSE",s2)==0) || (strcmp0("f",s2)==0) || (strcmp0("false",s2)==0)) vi=FALSE; else { err=3; goto errexit; } if (arglist[1]=='a') { err=3; goto errexit; } else { if ((p=g_malloc(sizeof(int)))==NULL) goto errexit; *(int *)(p)=vi; if (arg_add(&argv,p)==NULL) goto errexit; } } else if (arglist[alp]=='c') { if (strlen(s2)>1) { err=3; goto errexit; } vi=s2[0]; if (arglist[1]=='a') { err=3; goto errexit; } else { if ((p=g_malloc(sizeof(int)))==NULL) goto errexit; *(int *)(p)=vi; if (arg_add(&argv,p)==NULL) goto errexit; } } else { err=3; goto errexit; } if ((arglist!=NULL) && (arglist[1]!='a')) alp++; } if ((arglist != NULL) && (arglist[1] == 'a')) { if (arg_add(&argv,array) == NULL) { goto errexit; } } else { if ((arglist != NULL) && (arglist[alp] != '\0')) { err = 2; goto errexit; } } if (type == NENUM) { if (argv[0] == NULL) { err = 3; goto errexit; } for (i=0;enumlist[i]!=NULL;i++) { int ofst; ofst = (enumlist[i][0] == '\0') ? 1 : 0; if (strcmp0(enumlist[i] + ofst, argv[0]) == 0) { break; } } if (enumlist[i]==NULL) { err=3; goto errexit; } g_free(argv[0]); if ((p=g_malloc(sizeof(int)))==NULL) goto errexit; *(int *)(p)=i; argv[0] = p; } *argc=getargc(argv); g_free(s2); *rargv=argv; return 0; errexit: arrayfree(array); g_free(s2); arg_del(argv); *argc=-1; *rargv=NULL; return err; } #endif static void freeargument(int type,const char *arglist,int argc,char **argv,int full) { int i; if (argv!=NULL) { if (arglist==NULL) { for (i=0;i0) && (arglist[0]!='\0') && (arglist[1]=='a')) { if ((arglist[0]=='i') || (arglist[0]=='d')) arrayfree((struct narray *)(argv[0])); else if (arglist[0]=='s') arrayfree2((struct narray *)(argv[0])); } else for (i=0;iNVFUNC) && (type!=NSFUNC) && (type!=NSAFUNC)) { return -1; } } if (type>=NVFUNC) { arglist=chkobjarglist(obj,field); } else { arglist=""; type=NVOID; } po=value; err=getargument(type,arglist,val,&argc2,&argv2); if (err==1) return ERROEXTARG; else if (err==2) return ERROSMLARG; else if (err==3) return ERROVALUE; else if (err!=0) return -1; if (getobj(obj,field,id,argc2,argv2,po)==-1) err=4; freeargument(type,arglist,argc2,argv2,TRUE); if (err==0) { *valstr=getvaluestr(obj,field,po,cr,quote); if (*valstr==NULL) return -1; return 0; } else return -2; } int sgetobjfield(struct objlist *obj,int id, const char *field,char *arg, char **valstr,int limittype,int cr,int quote) { int err; char *val; int argc2; enum ngraph_object_field_type type; const char *arglist; char **argv2; char value[8]; char *po; *valstr=NULL; val=arg; if (getobjfield(obj,field)==-1) return -1; argv2=NULL; type=chkobjfieldtype(obj,field); if (limittype) { if ((type>NVFUNC) && (type!=NSFUNC) && (type!=NSAFUNC)) { return -1; } } if (type>=NVFUNC) { arglist=chkobjarglist(obj,field); } else { arglist=""; type=NVOID; } po=value; err=getargument(type,arglist,val,&argc2,&argv2); if (err==1) { error22(obj,ERROEXTARG,field,arg); return ERROEXTARG; } else if (err==2) { error22(obj,ERROSMLARG,field,arg); return ERROSMLARG; } else if (err==3) { error22(obj,ERROVALUE,field,arg); return ERROVALUE; } else if (err!=0) return -1; if (getobj(obj,field,id,argc2,argv2,po)==-1) err=4; freeargument(type,arglist,argc2,argv2,TRUE); if (err==0) { *valstr=getvaluestr(obj,field,po,cr,quote); if (*valstr==NULL) return -1; return 0; } else return -2; } static int schkfield(struct objlist *obj,int id,char *arg,char **valstr, int limittype,int cr,int quote) { int err; char *field; int len; char *s; s=arg; *valstr=NULL; if ((s==NULL) || (strchr(":= \t",s[0])!=NULL) || ((field=getitok2(&s,&len,":= \t"))==NULL)) { if (len==-1) return -1; return ERRFIELD; } if (s[0]!='\0') s++; while ((s[0]==' ') || (s[0]=='\t')) s++; err=schkobjfield(obj,id,field,s,valstr,limittype,cr,quote); g_free(field); return err; } int sgetfield(struct objlist *obj,int id,char *arg,char **valstr, int limittype,int cr,int quote) { int err; char *field; int len; char *s; s=arg; *valstr=NULL; if ((s==NULL) || (strchr(":= \t",s[0])!=NULL) || ((field=getitok2(&s,&len,":= \t"))==NULL)) { if (len==-1) return -1; error2(obj,ERRFIELD,arg); return ERRFIELD; } if (s[0]!='\0') s++; while ((s[0]==' ') || (s[0]=='\t')) s++; err=sgetobjfield(obj,id,field,s,valstr,limittype,cr,quote); g_free(field); return err; } struct narray * sgetobj(char *arg,int limittype,int cr,int quote) { struct objlist *obj; int i,anum,*id; struct narray iarray,*sarray; char *valstr; arrayinit(&iarray,sizeof(int)); if ((sarray=arraynew(sizeof(char *)))==NULL) return NULL; if (chkobjilist2(&arg,&obj,&iarray,TRUE)) { arrayfree2(sarray); return NULL; } anum=arraynum(&iarray); id=arraydata(&iarray); for (i=0;i 0) { id = arraylast_int(&iarray); if (getobj(dobj, "oid", id, 0, NULL, &oid) != -1) { dest2 = (char *) g_malloc(strlen(chkobjectname(dobj)) + 10); if (dest2) { sprintf(dest2, "%s:^%d", chkobjectname(dobj), oid); _putobj(obj, field, inst, dest2); g_free(dest); } } } } arraydel(&iarray); } void obj_do_tighten_all(struct objlist *obj, N_VALUE *inst, const char *field) { char *dest, *ptr; struct narray iarray; struct objlist *dobj; int anum, id, oid, i; GString *dest2; if (_getobj(obj, field, inst, &dest)) return; if (dest == NULL) return; dest2 = g_string_sized_new(1024); if (dest2 == NULL) { return; } arrayinit(&iarray, sizeof(int)); if (! getobjilist(dest, &dobj, &iarray, FALSE, NULL)) { anum = arraynum(&iarray); g_string_printf(dest2, "%s:", chkobjectname(dobj)); for (i = 0; i < anum; i++) { id = arraynget_int(&iarray, i); if (getobj(dobj, "oid", id, 0, NULL, &oid) != -1) { g_string_append_printf(dest2, "%s^%d", (i == 0) ? "" : ",", oid); } } ptr = g_string_free(dest2, FALSE); _putobj(obj, field, inst, ptr); } arraydel(&iarray); } int copy_obj_field(struct objlist *obj, int dist, int src, char **ignore_field) { int perm, ignore, j; enum ngraph_object_field_type type; char *field, **ptr; for (j = 0; j < chkobjfieldnum(obj); j++) { field = chkobjfieldname(obj, j); if (field == NULL) { continue; } perm = chkobjperm(obj, field); type = chkobjfieldtype(obj, field); ignore = FALSE; for (ptr = ignore_field; ptr && *ptr; ptr++) { if (strcmp2(field, *ptr) == 0) { ignore = TRUE; break; } } if (ignore) continue; if ((perm & NREAD) && (perm & NWRITE) && (type < NVFUNC)) { if (copyobj(obj, field, dist, src) == -1) { return 1; } } } return 0; } #ifdef COMPILE_UNUSED_FUNCTIONS static char * getuniqname(struct objlist *obj,char *prefix,char sep) { int i,j,len; char *iname; N_VALUE *inst; char *name; int c[10]; if (chkobjoffset(obj,"name")==-1) return NULL; if (prefix==NULL) len=0; else len=strlen(prefix); if (sep!='\0') len++; if ((name=g_malloc(len+11))==NULL) return NULL; for (i=0;i<10;i++) c[i]=0; while (TRUE) { match: i=0; while (TRUE) { c[i]++; if (c[i]==26) { c[i]=1; i++; if (i==10) return NULL; } else break; } for (i=9;i>=0;i--) if (c[i]!=0) break; if (prefix!=NULL) strcpy(name,prefix); if (sep!='\0') name[len-1]=sep; for (j=len;j<=len+i;j++) name[j]=c[i-j+len]-1+'a'; name[j]='\0'; for (i=0;i<=obj->lastinst;i++) { if ((inst=chkobjinst(obj,i))==NULL) return NULL; if (_getobj(obj,"name",inst,&iname)==-1) return NULL; if ((iname!=NULL) && (strcmp0(iname,name)==0)) goto match; } break; } return name; } #endif /* COMPILE_UNUSED_FUNCTIONS */ ngraph-gtk-6.08.00/src/ostring.c0000644000175000017500000002150113070106167013270 00000000000000/* * $Id: ostring.c,v 1.5 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include "object.h" #include "nstring.h" #define NAME "string" #define PARENT "object" #define OVERSION "1.00.00" #define ERR_INVALID_UTF8 100 #define ERR_REGEXP 101 static char *stringerrorlist[]={ "invalid UTF-8 string.", "invalid regular expression.", }; #define ERRNUM (sizeof(stringerrorlist) / sizeof(*stringerrorlist)) static int stringinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int stringdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static void set_length(struct objlist *obj, N_VALUE *inst, char *str) { int byte, len; if (str) { byte = strlen(str); len = g_utf8_strlen(str, -1); } else { byte = 0; len = 0; } _putobj(obj, "byte", inst, &byte); _putobj(obj, "length", inst, &len); } static int string_strip(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str, *tmp; if (rval->str) { g_free(rval->str); } rval->str = NULL; if (_getobj(obj, "@", inst, &str)) { return 1; } if (str == NULL || str[0] == '\0') { return 0; } tmp = g_strdup(str); if (tmp) { g_strstrip(tmp); } rval->str = tmp; return 0; } static int string_set(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; str = argv[2]; if (str == NULL) { set_length(obj, inst, str); return 0; } if (! g_utf8_validate(str, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } set_length(obj, inst, str); return 0; } static int string_upcase(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; if (_getobj(obj, "@", inst, &str)) { return 1; } if (str == NULL) { return 0; } rval->str = g_utf8_strup(str, -1); return 0; } static int string_downcase(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; if (_getobj(obj, "@", inst, &str)) { return 1; } if (str == NULL) { return 0; } rval->str = g_utf8_strdown(str, -1); return 0; } static int string_reverse(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; if (_getobj(obj, "@", inst, &str)) { return 1; } if (str == NULL) { return 0; } rval->str = g_utf8_strreverse(str, -1); return 0; } static char * utf8_string_slice(const char *str, int size, int byte_size, int start, int len) { char *data, *ptr; if (str == NULL || size < 1 || len <= 0) { return NULL; } if (start < 0) { start = size + start; } if (start < 0) { return NULL; } if (start >= size) { return NULL; } if (start + len > size) { len = size - start; } data = g_malloc(byte_size + 1); if (data == NULL) { return NULL; } ptr = g_utf8_offset_to_pointer(str, start); g_utf8_strncpy(data, ptr, len); return data; } static int string_slice(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; int start, size, byte_size, len; start = * (int *) argv[2]; len = * (int *) argv[3]; if (rval->str) { g_free(rval->str); } rval->str = NULL; if (_getobj(obj, "@", inst, &str)) { return 1; } if (_getobj(obj, "byte", inst, &byte_size)) { return 1; } if (_getobj(obj, "length", inst, &size)) { return 1; } if (str == NULL || len < 1) { return 0; } rval->str = utf8_string_slice(str, size, byte_size, start, len); return 0; } static int string_replace(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { GRegex *regexp; char *str, *pattern, *replace; g_free(rval->str); rval->str = NULL; pattern = (char *) argv[2]; replace = (char *) argv[3]; if (pattern == NULL || pattern[0] == '\0') { return 0; } if (replace == NULL) { replace = ""; } if (! g_utf8_validate(pattern, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } if (! g_utf8_validate(replace, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } if (_getobj(obj, "@", inst, &str)) { return 1; } if(str == NULL || str[0] == '\0') { return 0; } regexp = g_regex_new(pattern, 0, 0, NULL); if (regexp == NULL) { error(obj, ERR_REGEXP); return 1; } rval->str = g_regex_replace(regexp, str, -1, 0, replace, 0, NULL); g_regex_unref(regexp); return 0; } static int string_index(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int pos, size; char *str, *pattern, *ptr, *find; rval->i = -1; pattern = (char *) argv[2]; pos = * (int *) argv[3]; if (pattern == NULL || pattern[0] == '\0') { return 1; } if (_getobj(obj, "length", inst, &size)) { return 2; } if (! g_utf8_validate(pattern, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 2; } if (pos < 0) { pos += size; } if (pos < 0 || pos >= size) { return 1; } if (_getobj(obj, "@", inst, &str)) { return 1; } if(str == NULL || str[0] == '\0') { return 1; } ptr = g_utf8_offset_to_pointer(str, pos); find = g_strstr_len(ptr, -1, pattern); if (find == NULL) { return 1; } rval->i = g_utf8_pointer_to_offset(str, find); return 0; } static int string_rindex(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int pos, size, len; char *str, *pattern, *ptr, *find; rval->i = -1; pattern = (char *) argv[2]; pos = * (int *) argv[3]; if (pattern == NULL || pattern[0] == '\0') { return 1; } if (_getobj(obj, "length", inst, &size)) { return 2; } if (! g_utf8_validate(pattern, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 2; } if (pos < 0) { pos += size; } if (pos < 0 || pos >= size) { return 1; } if (_getobj(obj, "@", inst, &str)) { return 1; } if(str == NULL || str[0] == '\0') { return 1; } ptr = g_utf8_offset_to_pointer(str, pos); len = ptr - str + 1; if (len < 1) { return 1; } find = g_strrstr_len(str, len, pattern); if (find == NULL) { return 1; } rval->i = g_utf8_pointer_to_offset(str, find); return 0; } static int string_match(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { GRegex *regexp; char *str, *pattern; pattern = (char *) argv[2]; rval->i = 0; if (! g_utf8_validate(pattern, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } _getobj(obj, "@", inst, &str); if (str == NULL || str[0] == '\0') { return 0; } regexp = g_regex_new(pattern, 0, 0, NULL); if (regexp == NULL) { error(obj, ERR_REGEXP); return 1; } rval->i = g_regex_match(regexp, str, 0, NULL); g_regex_unref(regexp); return 0; } static struct objtable ostring[] = { {"init",NVFUNC,NEXEC,stringinit,NULL,0}, {"done",NVFUNC,NEXEC,stringdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NSTR,NREAD|NWRITE,string_set,NULL,0}, {"length",NINT,NREAD,NULL,NULL,0}, {"byte",NINT,NREAD,NULL,NULL,0}, {"strip",NSFUNC,NREAD|NEXEC,string_strip,"",0}, {"upcase",NSFUNC,NREAD|NEXEC,string_upcase,"",0}, {"downcase",NSFUNC,NREAD|NEXEC,string_downcase,"",0}, {"reverse",NSFUNC,NREAD|NEXEC,string_reverse,"",0}, {"slice",NSFUNC,NREAD|NEXEC,string_slice,"ii",0}, {"match",NBFUNC,NREAD|NEXEC,string_match,"s",0}, {"replace",NSFUNC,NREAD|NEXEC,string_replace,"ss",0}, {"index",NIFUNC,NREAD|NEXEC,string_index,"si",0}, {"rindex",NIFUNC,NREAD|NEXEC,string_rindex,"si",0}, }; #define TBLNUM (sizeof(ostring) / sizeof(*ostring)) void *addstring() { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,ostring,ERRNUM,stringerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/ioutil.c0000644000175000017500000004261313315417324013121 00000000000000/* * $Id: ioutil.c,v 1.25 2010-04-01 06:08:22 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include #include #include #include #include #include "object.h" #include "nstring.h" #include "ioutil.h" #ifndef O_BINARY #define O_BINARY 0 #endif static void (* ShowProgressFunc)(int, const char *, double) = NULL; #if EOF == -1 static char C_type_buf[257]; void char_type_buf_init(void) { memset(C_type_buf, 0, sizeof(C_type_buf)); C_type_buf[0] = 1; C_type_buf['\r' + 1] = 1; C_type_buf['\n' + 1] = 1; C_type_buf['\0' + 1] = 1; } #define is_line_sep(ch) (C_type_buf[ch + 1]) #endif void changefilename(char *name) { #if WINDOWS int i; if (name == NULL) { return; } for (i = 0; name[i] != '\0'; i++) { if (name[i] == '\\') { name[i] = DIRSEP; } } #endif /* WINDOWS */ } void path_to_win(char *name) { #if WINDOWS int i; if (name == NULL) { return; } for (i = 0; name[i] != '\0'; i++) { if (name[i] == DIRSEP) { name[i] = '\\'; } } #endif /* WINDOWS */ } static void pathresolv(char *name) { int j,k; if (name == NULL) { return; } changefilename(name); j=k=0; while (name[k]!='\0') { if ((name[k]==DIRSEP) && (name[k+1]=='.')) { if (name[k+2]==DIRSEP) k+=2; else if ((name[k+2]=='.') && (name[k+3]==DIRSEP)) { if (j!=0) j--; for (;(name[j]!=DIRSEP) && (j!=0);j--); k+=3; } else { name[j]=name[k]; j++; k++; } } else { name[j]=name[k]; j++; k++; } } name[j]='\0'; } char * getfullpath(const char *name) { char *s, *cwd, *utf8_name; int top; if (name == NULL) { return NULL; } utf8_name = get_utf8_filename(name); if (utf8_name == NULL) { return NULL; } changefilename(utf8_name); if (utf8_name[0] == DIRSEP && utf8_name[1] == DIRSEP) { s = utf8_name; } else { if (isalpha(utf8_name[0]) && utf8_name[1] == ':') { top = 2; } else { top = 0; } if (utf8_name[top] == DIRSEP) { s = utf8_name; } else { cwd = ngetcwd(); if (cwd == NULL) { g_free(utf8_name); return NULL; } s = g_strdup_printf("%s%c%s", cwd, DIRSEP, utf8_name + top); g_free(cwd); g_free(utf8_name); } } pathresolv(s); return s; } #if WINDOWS static int getdisk(void) { char *cwd; int drive; cwd = g_get_current_dir(); if (cwd == NULL) { return -1; } drive = toupper(cwd[0]) - 'A'; g_free(cwd); return drive; } #endif /* WINDOWS */ char * getrelativepath(const char *name) { char *utf8_name, *str; GString *s; if (name == NULL) { return NULL; } utf8_name = get_utf8_filename(name); if (utf8_name == NULL) { return NULL; } if ((utf8_name[0]==DIRSEP) && (utf8_name[1]==DIRSEP)) { str = utf8_name; pathresolv(str); } else { int i, j, top, depth; top = 0; #if WINDOWS if (isalpha(utf8_name[0]) && name[1] == ':') { top = 2; } #endif /* WINDOWS */ if ( #if WINDOWS name[top] == DIRSEP && (top != 2 || toupper(name[0]) - 'A' == getdisk()) #else /* WINDOWS */ name[0] == DIRSEP #endif /* WINDOWS */ ) { char *cwd, *cwd2; cwd = ngetcwd(); if (cwd == NULL) { g_free(utf8_name); return NULL; } #if WINDOWS for (j = 2; cwd[j] != '\0'; j++) { cwd[j - 2] = cwd[j]; } cwd[j - 2] = '\0'; #endif /* WINDOWS */ cwd2 = g_malloc(strlen(cwd) + 2); if (cwd2 == NULL) { g_free(cwd); g_free(utf8_name); return NULL; } strcpy(cwd2, cwd); g_free(cwd); i=strlen(cwd2); if ((i==0) || (cwd2[i-1]!=DIRSEP)) { cwd2[i]=DIRSEP; cwd2[i+1]='\0'; } for (i=0;(cwd2[i]!='\0') && (utf8_name[i+top]!='\0');i++) { if (cwd2[i]!=utf8_name[i+top]) { break; } } if (i > 0) { i--; } for (;cwd2[i] != DIRSEP;i--); depth=0; for (j=strlen(cwd2); j != i; j--) { if (cwd2[j] == DIRSEP) { depth++; } } g_free(cwd2); s = g_string_sized_new(64); if (s == NULL) { g_free(utf8_name); return NULL; } if (depth==0) { g_string_append(s, "./"); } else { for (j = 0; j < depth; j++) { g_string_append(s, "../"); } } g_string_append(s, utf8_name + i + top + 1); g_free(utf8_name); str = g_string_free(s, FALSE); } else { str = utf8_name; pathresolv(str); } } return str; } char * get_utf8_filename(const char *name) { char *utf8_name; if (name == NULL) { return NULL; } if (g_utf8_validate(name, -1, NULL)) { utf8_name = g_strdup(name); } else { #if WINDOWS utf8_name = g_locale_to_utf8(name, -1, NULL, NULL, NULL); #else /* WINDOWS */ utf8_name = g_filename_to_utf8(name, -1, NULL, NULL, NULL); #endif /* WINDOWS */ } changefilename(utf8_name); return utf8_name; } char * get_localized_filename(const char *name) { char *localized_name; if (name == NULL) { return NULL; } #if WINDOWS if (g_utf8_validate(name, -1, NULL)) { localized_name = g_strdup(name); } else { localized_name = g_locale_to_utf8(name, -1, NULL, NULL, NULL); } #else /* WINDOWS */ if (g_utf8_validate(name, -1, NULL)) { localized_name = g_filename_from_utf8(name, -1, NULL, NULL, NULL); } else { localized_name = g_strdup(name); } #endif /* WINDOWS */ return localized_name; } char * getbasename(const char *name) { char *basename, *tmp; if (name == NULL) return NULL; tmp = get_utf8_filename(name); if (tmp == NULL) { return NULL; } basename = g_path_get_basename(tmp); g_free(tmp); return basename; } char * getdirname(const char *name) { char *dirname, *tmp; if (name == NULL) return NULL; tmp = get_utf8_filename(name); if (tmp == NULL) { return NULL; } dirname = g_path_get_dirname(tmp); g_free(tmp); return dirname; } char * getextention(char *name) { int i; if (name==NULL) return NULL; changefilename(name); for (i=strlen(name);(name[i]!='.') && (name[i]!=':') && (i!=0);i--); if (name[i]=='.') return name+i+1; return NULL; } char * getfilename(const char *dir, const char *sep, const char *file) { char *s; unsigned int dir_len; dir_len = strlen(dir); s = g_malloc(dir_len + strlen(sep) + strlen(file) + 1); if (s == NULL) return NULL; strcpy(s, dir); if (dir_len > 0 && (s[dir_len - 1] == '/' || s[dir_len - 1] == '\\')) s[dir_len - 1]='\0'; strcat(s, sep); strcat(s, file); changefilename(s); return s; } int findfilename(const char *dir, const char *sep, const char *file) { char *s; int find; GStatBuf buf; if ((s=getfilename(dir,sep,file))==NULL) return FALSE; if ((naccess(s,R_OK)==0) && (nstat(s,&buf)==0)) { if ((buf.st_mode & S_IFMT)==S_IFREG) find=TRUE; else find=FALSE; } else find=FALSE; g_free(s); return find; } char * ngetcwd(void) { char *s; s = g_get_current_dir(); changefilename(s); return s; } char * nsearchpath(char *path,char *name,int shellscript) { char *cmdname,*tok; int len; if (name==NULL) return NULL; if (name[0]=='\0') return NULL; cmdname = g_find_program_in_path(name); if (cmdname) { return cmdname; } if (strchr(name,DIRSEP)==NULL) { while ((tok=getitok(&path,&len,PATHSEP))!=NULL) { g_free(cmdname); if ((cmdname=g_malloc(strlen(name)+len+2))==NULL) return NULL; strncpy(cmdname,tok,len); if (cmdname[len-1]!=DIRSEP) { cmdname[len]=DIRSEP; len++; } strcpy(cmdname+len,name); if ((!shellscript && (naccess(cmdname,X_OK)==0)) || (shellscript && (naccess(cmdname,R_OK)==0))) return cmdname; } if (tok==NULL) { g_free(cmdname); return NULL; } } else { if (!((!shellscript && (naccess(name,X_OK)==0)) || (shellscript && (naccess(name,R_OK)==0)))) return NULL; if ((cmdname=g_malloc(strlen(name)+1))==NULL) return NULL; strcpy(cmdname,name); return cmdname; } return NULL; } static int nscandir(char *dir,char ***namelist, int (*compar)()) { unsigned int i; GDir *dp; const char *ent; char **po,**po2; unsigned int allocn = 256, alloc = 0; dp = g_dir_open(dir, 0, NULL); if (dp == NULL) { return -1; } po = g_malloc(allocn * sizeof(char *)); if (po == NULL) { g_dir_close(dp); return -1; } while ((ent = g_dir_read_name(dp))) { if (allocn == alloc) { allocn += 256; po2 = g_realloc(po, allocn * sizeof(char *)); if (po2 == NULL) { for (i = 0; i < alloc; i++) { g_free(po[i]); } g_free(po); g_dir_close(dp); return -1; } po = po2; } po[alloc] = g_strdup(ent); if (po[alloc] == NULL) { for (i = 0; i < alloc; i++) { g_free(po[i]); } g_free(po); g_dir_close(dp); return -1; } alloc++; } g_dir_close(dp); if (compar != NULL) { qsort(po, alloc, sizeof(struct dirent *), compar); } *namelist = po; return alloc; } static int nalphasort(char **a,char **b) { return strcmp(*a,*b); } static int nglob2(char *path,int po,int *num,char ***list) { int i,j,p1,escape,scannum,len,err; char *s,*s1,*s2,*s3,*path2; char **namelist; if (path==NULL) return 0; p1=po; escape=FALSE; for (i=po;path[i]!='\0';i++) { if (escape) escape=FALSE; else if (path[i]=='\\') escape=TRUE; else if (path[i]==DIRSEP) p1=i+1; else if ((path[i]=='?') || (path[i]=='*')) break; else if (path[i]=='[') { for (j=i+1;(path[j]!='\0') && (path[j]!=']');j++) ; if (path[j]==']') { i=j; break; } } } if (path[i]=='\0') { if (naccess(path,R_OK)==0) { if ((s=g_malloc(strlen(path)+1))==NULL) return -1; strcpy(s,path); if (arg_add(list,s)==NULL) return -1; (*num)++; } } else { for (;(path[i]!='\0') && (path[i]!=DIRSEP);i++) ; s1 = g_malloc(p1 + 1); s2 = g_malloc(i - p1 + 1); s3 = g_malloc(strlen(path) - i + 1); if (s1 == NULL || s2 == NULL || s3 == NULL) { g_free(s1); g_free(s2); g_free(s3); return -1; } strncpy(s1,path,p1); s1[p1]='\0'; strncpy(s2,path+p1,i-p1); s2[i-p1]='\0'; strcpy(s3,path+i); if (strlen(s1)==0) scannum=nscandir("./",&namelist,nalphasort); else scannum=nscandir(s1,&namelist,nalphasort); for (i=0;i0) g_free(namelist); g_free(s1); g_free(s2); g_free(s3); return -1; } g_free(path2); } } g_free(namelist[i]); } if (scannum>0) g_free(namelist); g_free(s1); g_free(s2); g_free(s3); } return 0; } int nglob(char *path,char ***namelist) { int num; char *s; *namelist=NULL; num=0; if (nglob2(path,0,&num,namelist)==-1) { arg_del(*namelist); return -1; } if (num==0) { if ((s=g_malloc(strlen(path)+1))==NULL) return -1; strcpy(s,path); if (arg_add(namelist,s)==NULL) return -1; return 1; } return num; } int fgetline(FILE *fp, char **buf) { /* rcode: 0 noerror -1 fatal error 1 EOF */ char *s; int ch, i; /* modified */ *buf = NULL; ch = fgetc(fp); if (ch == EOF) { *buf = NULL; return 1; } s = nstrnew(); if (s == NULL) { *buf = NULL; return -1; } i = 0; while (TRUE) { #if EOF == -1 if (is_line_sep(ch)) { switch (ch) { case '\r': ch = fgetc(fp); if (ch != '\n') { ungetc(ch, fp); } /* FALLTHRU */ case '\0': case '\n': case EOF: s[i] = '\0'; /* nstraddchar() is not terminate string */ *buf = s; return 0; } } else { s = nstraddchar(s, i, ch); i++; if (s == NULL) { *buf = NULL; return -1; } } #else switch (ch) { case '\r': ch = fgetc(fp); if (ch != '\n') { ungetc(ch, fp); } /* FALLTHRU */ case '\0': case '\n': case EOF: s[i] = '\0'; /* nstraddchar() is not terminate string */ *buf = s; return 0; default: s = nstraddchar(s, i, ch); i++; if (s == NULL) { *buf = NULL; return -1; } } #endif ch = fgetc(fp); } } int fgetnline(FILE *fp, char *buf, int len) { /* rcode: 0 noerror -1 fatal error 1 EOF */ int rcode; char *ptr; buf[0] = '\0'; rcode = fgetline(fp, &ptr); if (rcode) return rcode; strncpy(buf, ptr, len); buf[len - 1] = '\0'; g_free(ptr); return 0; } int nfgetc(FILE *fp) { int ch; do { ch=fgetc(fp); } while (ch=='\r'); return ch; } FILE * nfopen(const char *filename, const char *mode) { FILE *fp; char *tmp; if (filename == NULL) return NULL; tmp = get_localized_filename(filename); if (tmp == NULL) { return NULL; } fp = g_fopen(tmp, mode); g_free(tmp); return fp; } int nisatty(int fd) { return isatty(fd); } int nstat(const gchar *filename, GStatBuf *buf) { int r; char *tmp; if (filename == NULL || buf == NULL) return -1; tmp = get_localized_filename(filename); if (tmp == NULL) { return -1; } r = g_stat(tmp, buf); g_free(tmp); return r; } int naccess(const gchar *filename, int mode) { int r; char *tmp; if (filename == NULL) return -1; tmp = get_localized_filename(filename); if (tmp == NULL) { return -1; } r = g_access(tmp, mode); g_free(tmp); return r; } int nchdir(const gchar *path) { int r; char *tmp; if (path == NULL) return -1; tmp = get_localized_filename(path); if (tmp == NULL) { return -1; } r = g_chdir(tmp); g_free(tmp); return r; } int nopen(const char *path,int access,int mode) { int r; char *tmp; if (path == NULL) return -1; tmp = get_localized_filename(path); if (tmp == NULL) { return -1; } r = g_open(tmp, access, mode | O_BINARY); g_free(tmp); return r; } void nclose(int fd) { close(fd); } void nlseek(int fd,long offset,int fromwhere) { lseek(fd,offset,fromwhere); } int nread(int fd,char *buf,unsigned len) { return read(fd,buf,len); } int nwrite(int fd,char *buf,unsigned len) { return write(fd,buf,len); } int nredirect(int fd,int newfd) { int savefd; savefd=dup(fd); dup2(newfd,fd); close(newfd); return savefd; } void nredirect2(int fd,int savefd) { dup2(savefd,fd); close(savefd); } int stdinfd(void) { return 0; } int stdoutfd(void) { return 1; } int stderrfd(void) { return 2; } void set_progress_func(void (* func)(int, const char *, double)) { ShowProgressFunc = func; } void set_progress(int pos, char *msg, double fraction) { if (ShowProgressFunc) ShowProgressFunc(pos, msg, fraction); } int n_mkstemp(const char *dir, char *templ, char **name) { char postfix[] = "XXXXXX", *buf, *path; int len, fd, path_last; #ifdef S_IRWXG mode_t mask_prev; #endif dir = (dir) ? dir : g_get_tmp_dir(); path = g_strdup(dir); if (path == NULL) { return -1; } len = strlen(path); if (len > 1) { path_last = path[len - 1]; } else { path_last = '\0'; } changefilename(path); buf = g_strdup_printf("%s%s%s%s", path, (path_last == '/') ? "" : "/", CHK_STR(templ), postfix); g_free(path); #ifdef S_IRWXG mask_prev = umask(S_IRWXG | S_IRWXO); #endif fd = g_mkstemp(buf); #ifdef S_IRWXG umask(mask_prev); #endif if (fd < 0) { g_free(buf); buf = NULL; } *name = buf; return fd; } FILE * n_tmpfile(char **name) { int fd; FILE *fp; fd = n_mkstemp(NULL, "ntmp", name); if (fd < 0) { return NULL; } #if ! WINDOWS if (*name) { g_unlink(*name); } #endif fp = fdopen(fd, "w+b"); if (fp == NULL) { close(fd); if (*name) { #if WINDOWS g_unlink(*name); #endif g_free(*name); *name = NULL; } } return fp; } void n_tmpfile_close(FILE *fp, char *name) { if (fp){ fclose(fp); } if (name) { #if WINDOWS g_unlink(name); #endif g_free(name); } } ngraph-gtk-6.08.00/src/nhash.h0000644000175000017500000000222313070106167012711 00000000000000/* * $Id: nhash.h,v 1.6 2009-09-19 13:21:44 hito Exp $ */ #ifndef NHASH_HEADER #define NHASH_HEADER struct nhash { char *key; union { int i; void *p; } val; struct nhash *l, *r, *p; }; typedef struct nhash **NHASH; NHASH nhash_new(void); void nhash_free(NHASH hash); void nhash_free_with_memfree_ptr(NHASH hash); void nhash_clear(NHASH hash); int nhash_set_int(NHASH hash, const char *key, int val); int nhash_set_ptr(NHASH hash, const char *key, void *val); int nhash_get_int(NHASH hash, const char *key, int *val); int nhash_get_ptr(NHASH hash, const char *key, void **val); int nhash_each(NHASH hash, int(* func)(struct nhash *, void *), void *data); void nhash_del(NHASH hash, const char *key); int nhash_set_int_with_hkey(NHASH hash, const char *key, int hkey, int val); int nhash_set_ptr_with_hkey(NHASH hash, const char *key, int hkey, void *val); int nhash_get_int_with_hkey(NHASH hash, const char *key, int hkey, int *val); int nhash_get_ptr_with_hkey(NHASH hash, const char *key, int hkey, void **val); void nhash_del_with_hkey(NHASH hash, const char *key, int hkey); int nhash_num(NHASH hash); int nhash_hkey(const char *ptr); #endif ngraph-gtk-6.08.00/src/oio.c0000644000175000017500000002510113070106167012371 00000000000000/* * $Id: oio.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include #include #include #include #include "common.h" #include "nhash.h" #include "shell.h" #include "object.h" #include "ioutil.h" #include "nstring.h" #include "oroot.h" static char *io_errorlist[]={ "file is not specified.", "invalid mode.", "I/O error: open", "I/O error: read", "I/O error: write", "I/O error: seek", "IO is closed.", "IO is opened.", "I/O error:", "the method is forbidden for the security", }; #define ERRNUM (sizeof(io_errorlist) / sizeof(*io_errorlist)) #define NAME "io" #define PARENT "object" #define OVERSION "1.00.00" #define OIO_ERRFILE 100 #define OIO_ERRMODE 101 #define OIO_ERROPEN 102 #define OIO_ERRREAD 103 #define OIO_ERRWRITE 104 #define OIO_ERRSEEK 105 #define OIO_ERRCLOSED 106 #define OIO_ERROPENED 107 #define OIO_ERRSTD 108 #define OIO_ERRSYSSECURTY 109 char *seek_whence[]={ N_("set"), N_("cur"), N_("end"), NULL }; enum IO_SEEK_WHENCE { IO_SEEK_SET, IO_SEEK_CUR, IO_SEEK_END, }; struct io_local { FILE *fp; int popen; }; static void io_error(struct objlist *obj) { const char *str; str = g_strerror(errno); error2(obj, OIO_ERRSTD, CHK_STR(str)); } static int io_init(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; char *mode; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; mode = g_strdup("r"); if (mode == NULL) { return 1; } if (_putobj(obj, "mode", inst, mode)) { g_free(mode); return 1; } io_local = g_malloc0(sizeof(struct io_local)); if (io_local == NULL) { g_free(mode); return 1; } if (_putobj(obj, "_local", inst, io_local)) { g_free(mode); g_free(io_local); return 1; } io_local->fp = NULL; io_local->popen = FALSE; return 0; } static int io_close_sub(struct io_local *io_local) { if (io_local->fp == NULL) { return 1; } if (io_local->popen) { pclose(io_local->fp); } else { fclose(io_local->fp); } io_local->fp = NULL; return 0; } static int io_done(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&io_local); if (io_local->fp) { io_close_sub(io_local); } return 0; } static int io_open(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; char *file, *mode; if (get_security()) { error(obj, OIO_ERRSYSSECURTY); return 1; } _getobj(obj, "_local", inst, &io_local); _getobj(obj, "mode", inst, &mode); if (mode == NULL || mode[0] == '\0') { mode = "r"; } if (io_local->fp) { error(obj, OIO_ERROPENED); return 1; } file = argv[2]; if (file == NULL) { return 1; } errno = 0; if (argv[1][0] == 'p') { fp = popen(file, mode); io_local->popen = TRUE; } else { fp = nfopen(file, mode); io_local->popen = FALSE; } if (fp == NULL) { io_error(obj); g_free(fp); return 1; } _putobj(obj, "file", inst, g_strdup(file)); io_local->fp = fp; return 0; } static int io_close(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; char *s; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { return 1; } _getobj(obj, "file", inst, &s); g_free(s); _putobj(obj, "file", inst, NULL); io_close_sub(io_local); return 0; } static int io_puts(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int rcode; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { return 1; } errno = 0; if (argv[2]) { rcode = fputs(argv[2], fp); } rcode = fputs("\n", fp); if (rcode == EOF) { io_error(obj); return 1; } return 0; } static int io_gets(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int rcode; char *buf; g_free(rval->str); rval->str = NULL; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } errno = 0; rcode = fgetline(fp, &buf); if (rcode < -1) { io_error(obj); return 1; } else if (rcode) { return 1; } rval->str = buf; return 0; } static int io_getc(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int rcode; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } errno = 0; rcode = fgetc(fp); if (rcode == EOF && ferror(fp)) { io_error(obj); return 1; } rval->i = rcode; return 0; } static int io_putc(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int c; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } c = *(int *) argv[2]; errno = 0; c = fputc(c, fp); if (c == EOF) { io_error(obj); return 1; } rval->i = c; return 0; } static int io_read(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int l; size_t len, rlen; char *buf; g_free(rval->str); rval->str = NULL; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } l = * (int *) argv[2]; if (l < 0) { return 1; } else if (l < 1) { return 0; } len = l; errno = 0; buf = g_malloc(len + 1); if (buf == NULL) { io_error(obj); return 1; } rlen = fread(buf, 1, len, fp); if (rlen == 0) { if (ferror(fp)) { io_error(obj); } g_free(buf); return 1; } buf[rlen] = '\0'; rval->str = buf; return 0; } static int io_write(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; size_t len, rlen; char *buf; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } buf = argv[2]; if (buf == NULL) { return 1; } len = strlen(buf); errno = 0; rlen = fwrite(buf, 1, len, fp); if (rlen < len) { io_error(obj); return 1; } rval->i = rlen; return 0; } static int io_seek(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int r, pos, w, whence; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } _getobj(obj, "whence", inst, &w); switch (w) { case IO_SEEK_SET: whence = SEEK_SET; break; case IO_SEEK_CUR: whence = SEEK_CUR; break; case IO_SEEK_END: whence = SEEK_END; break; default: return 1; } pos = *(int *) argv[2]; errno = 0; r = fseek(fp, pos, whence); if (r) { io_error(obj); return 1; } return 0; } static int io_rewind(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } rewind(fp); return 0; } static int io_tell(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; long pos; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } errno = 0; pos = ftell(fp); if (pos < 0) { error(obj, OIO_ERRSEEK); return 1; } rval->i = pos; return 0; } static int io_flush(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int r; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } errno = 0; r = fflush(fp); if (r) { io_error(obj); return 1; } return 0; } static int io_eof(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct io_local *io_local; FILE *fp; int r; _getobj(obj, "_local", inst, &io_local); fp = io_local->fp; if (fp == NULL) { error(obj, OIO_ERRCLOSED); return 1; } r = feof(fp); rval->i = (r) ? TRUE : FALSE; return r ? 0 : 1; } static struct objtable io[] = { {"init",NVFUNC,NEXEC,io_init,NULL,0}, {"done",NVFUNC,NEXEC,io_done,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"file",NSTR,NREAD,NULL,NULL,0}, {"mode",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"open",NVFUNC,NREAD|NEXEC,io_open,"s",0}, {"popen",NVFUNC,NREAD|NEXEC,io_open,"s",0}, {"close",NVFUNC,NREAD|NEXEC,io_close,"",0}, {"puts",NVFUNC,NREAD|NEXEC,io_puts,"s",0}, {"putc",NIFUNC,NREAD|NEXEC,io_putc,"i",0}, {"gets",NSFUNC,NREAD|NEXEC,io_gets,"",0}, {"getc",NIFUNC,NREAD|NEXEC,io_getc,"",0}, {"read",NSFUNC,NREAD|NEXEC,io_read,"i",0}, {"write",NIFUNC,NREAD|NEXEC,io_write,"s",0}, {"whence",NENUM,NREAD|NWRITE,NULL,seek_whence,0}, {"seek",NVFUNC,NREAD|NEXEC,io_seek,"i",0}, {"tell",NIFUNC,NREAD|NEXEC,io_tell,"",0}, {"rewind",NVFUNC,NREAD|NEXEC,io_rewind,"",0}, {"flush",NVFUNC,NREAD|NEXEC,io_flush,"",0}, {"eof",NBFUNC,NREAD|NEXEC,io_eof,"",0}, {"_local",NPOINTER,0,NULL,NULL,0}, }; #define OIO_TBLNUM (sizeof(io) / sizeof(*io)) void * addio(void) /* addio() returns NULL on error */ { return addobject(NAME, NULL, PARENT, OVERSION, OIO_TBLNUM, io, ERRNUM, io_errorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/ogra2fil.c0000644000175000017500000000756513070106167013326 00000000000000/* * $Id: ogra2fil.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include "object.h" #include "ioutil.h" #define NAME "gra2file" #define PARENT "gra2" #define OVERSION "1.00.00" #define ERRFOPEN 100 static char *gra2ferrorlist[]={ "I/O error: open file", }; #define ERRNUM (sizeof(gra2ferrorlist) / sizeof(*gra2ferrorlist)) struct gra2flocal { FILE *fil; }; static int gra2finit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct gra2flocal *gra2flocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if ((gra2flocal=g_malloc(sizeof(struct gra2flocal)))==NULL) goto errexit; if (_putobj(obj,"_local",inst,gra2flocal)) goto errexit; gra2flocal->fil=NULL; return 0; errexit: g_free(gra2flocal); return 1; } static int gra2fdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct gra2flocal *gra2flocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&gra2flocal); if (gra2flocal->fil!=NULL) fclose(gra2flocal->fil); return 0; } static int gra2f_output(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct gra2flocal *gra2flocal; struct objlist *sys; char code; int *cpar; int i; char *cstr; char *fname,*graf,*sname,*sver; gra2flocal=(struct gra2flocal *)argv[2]; code=*(char *)(argv[3]); cpar=(int *)argv[4]; cstr=argv[5]; if (code=='I') { if (gra2flocal->fil!=NULL) fclose(gra2flocal->fil); gra2flocal->fil=NULL; _getobj(obj,"file",inst,&fname); if (fname==NULL) return 1; if ((gra2flocal->fil=nfopen(fname,"wt"))==NULL) { error2(obj,ERRFOPEN,fname); return 1; } if ((sys=getobject("system"))==NULL) return 1; if (getobj(sys,"name",0,0,NULL,&sname)) return 1; if (getobj(sys,"version",0,0,NULL,&sver)) return 1; if (getobj(sys,"GRAF",0,0,NULL,&graf)) return 1; fprintf(gra2flocal->fil,"%s\n",graf); fprintf(gra2flocal->fil,"%%Creator: %s ver %s\n",sname,sver); } if (gra2flocal->fil!=NULL) { fputc(code,gra2flocal->fil); if (cpar[0]==-1) { for (i=0;cstr[i]!='\0';i++) fputc(cstr[i],gra2flocal->fil); } else { fprintf(gra2flocal->fil,",%d",cpar[0]); for (i=1;i<=cpar[0];i++) fprintf(gra2flocal->fil,",%d",cpar[i]); } fputc('\n',gra2flocal->fil); if (code=='E') { fclose(gra2flocal->fil); gra2flocal->fil=NULL; } } return 0; } static struct objtable gra2f[] = { {"init",NVFUNC,NEXEC,gra2finit,NULL,0}, {"done",NVFUNC,NEXEC,gra2fdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"file",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"_local",NPOINTER,0,NULL,NULL,0}, {"_output",NVFUNC,0,gra2f_output,NULL,0}, }; #define TBLNUM (sizeof(gra2f) / sizeof(*gra2f)) void * addgra2file(void) /* addgra2file() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,gra2f,ERRNUM,gra2ferrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/nconfig.h0000644000175000017500000000237313070106167013241 00000000000000/* * $Id: nconfig.h,v 1.2 2009-03-09 05:20:30 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef NCONFIG_HEADER #define NCONFIG_HEADER char *getscriptname(char *file); char *searchscript(char *file); FILE *openconfig(char *section); char *getconfig(FILE *fp,char **val); void closeconfig(FILE *fp); int replaceconfig(char *section,struct narray *conf); int removeconfig(char *section,struct narray *conf); int writecheckconfig(); int copyconfig(); #endif ngraph-gtk-6.08.00/src/odraw.h0000644000175000017500000000560013356245443012736 00000000000000/* * $Id: odraw.h,v 1.6 2009-08-07 02:52:40 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef ODRAW_HEADER #define ODRAW_HEADER #define ARROW_SIZE_MIN 10000 #define ARROW_SIZE_MAX 200000 enum INTERPOLATION_TYPE { INTERPOLATION_TYPE_SPLINE, INTERPOLATION_TYPE_SPLINE_CLOSE, INTERPOLATION_TYPE_BSPLINE, INTERPOLATION_TYPE_BSPLINE_CLOSE, }; enum ARROW_POSITION_TYPE { ARROW_POSITION_NONE, ARROW_POSITION_END, ARROW_POSITION_BEGIN, ARROW_POSITION_BOTH, }; #define ARROW_POSITION_TYPE_NUM (ARROW_POSITION_BOTH + 1) enum MARKER_TYPE { MARKER_TYPE_NONE, MARKER_TYPE_ARROW, MARKER_TYPE_WAVE, MARKER_TYPE_MARK, MARKER_TYPE_BAR, }; #define MARKER_TYPE_NUM (MARKER_TYPE_BAR + 1) enum SAVE_PATH_TYPE { SAVE_PATH_UNCHANGE, SAVE_PATH_FULL, SAVE_PATH_RELATIVE, SAVE_PATH_BASE, }; enum JOIN_TYPE { JOIN_TYPE_MITER, JOIN_TYPE_ROUND, JOIN_TYPE_BEVEL, }; #define JOIN_TYPE_NUM (JOIN_TYPE_BEVEL + 1) enum FONT_TYPE { FONT_TYPE_SANS_SERIF, FONT_TYPE_SERIF, FONT_TYPE_MONOSPACE, }; enum FONT_STYLE { FONT_STYLE_NORMAL = 0, FONT_STYLE_BOLD = 1, FONT_STYLE_ITALIC = 2, }; #define INTERPOLATION_TYPE_NUM (INTERPOLATION_TYPE_BSPLINE_CLOSE + 1) #define DEFAULT_LINE_WIDTH 40 #define DEFAULT_MARK_SIZE 200 #define DEFAULT_FONT_PT 2000 extern char *pathchar[]; extern char *joinchar[]; extern char *fontchar[]; extern char *intpchar[]; extern char *arrowchar[]; extern char *marker_type_char[]; int pathsave(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv); int clear_bbox(struct objlist *obj, N_VALUE *inst); int put_hsb_color(struct objlist *obj, N_VALUE *inst, int argc, char **argv, char *format); int put_fill_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int put_stroke_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int put_hsb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int put_hsb2(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int curve_expand_points(int *pdata, int num, int intp, struct narray *expand_points); #endif ngraph-gtk-6.08.00/src/osystem.c0000644000175000017500000004345613211506204013314 00000000000000/* * $Id: osystem.c,v 1.17 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include #include "nstring.h" #include "object.h" #include "shell.h" #include "ioutil.h" #include "ntime.h" #include "osystem.h" #ifdef HAVE_LIBGSL #include #endif #define NAME "system" #define PARENT "object" #define SYSNAME "Ngraph" #define TEMPN "NGP" #define COPYRIGHT "Copyright (C) 2003, Satoshi ISHIZAKA." #define EMAIL "ZXB01226@nifty.com" #define WEB "https://github.com/htrb/ngraph-gtk/" #define ERRSYSNODIR 100 #define ERRSYSTMPFILE 101 #define ERRSYSSECURTY 102 #define ERRSYSMEM 103 #define ERRSYSNOMODULE 104 #define ERRSYSLOAD 105 #define ERRSYSLOADED 106 #define ERRSYSNOLOAD 107 #define ERRSYSINIT 108 #define ERRSYSINVALID 109 #define ERRSYSNOTEXECUTABLE 110 #define ERRSYSLOCKED 111 #define ERRSYSSMALLARGS 112 void resizeconsole(int col,int row); extern int consolecol,consolerow; static char *syserrorlist[]={ "no such directory", "can't create temporary file", "the method is forbidden for the security", "cannot allocate enough memory", "no module name is specified.", "cannot load module", "the module is already loaded", "a module is not loaded", "cannot initialize the plugin", "invalid module", "not executable", "the module is locked", "too small number of arguments.", }; #define ERRNUM (sizeof(syserrorlist) / sizeof(*syserrorlist)) struct ngraph_plugin { GModule *module; ngraph_plugin_exec exec; ngraph_plugin_open open; ngraph_plugin_close close; char *file; int lock; }; static NHASH Plugins = NULL; static DRAW_NOTIFY_FUNC DrawNotify = NULL; void system_set_draw_notify_func(DRAW_NOTIFY_FUNC func) { DrawNotify = func; } void system_draw_notify(void) { if (DrawNotify) { DrawNotify(TRUE); } } static int sysinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *wd; int expand, pid; char *exdir; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; expand=TRUE; if (_putobj(obj,"expand_file",inst,&expand)) return 1; exdir = g_strdup("./"); if (exdir == NULL) return 1; if (_putobj(obj,"expand_dir",inst,exdir)) return 1; if (_putobj(obj,"name",inst,SYSNAME)) return 1; if (_putobj(obj,"version",inst,VERSION)) return 1; if (_putobj(obj,"copyright",inst,COPYRIGHT)) return 1; if (_putobj(obj,"e-mail",inst,EMAIL)) return 1; if (_putobj(obj,"web",inst,WEB)) return 1; if (_putobj(obj,"compiler",inst, COMPILER_NAME)) return 1; if (_putobj(obj,"GRAF",inst,"%Ngraph GRAF")) return 1; if (_putobj(obj,"temp_prefix",inst,TEMPN)) return 1; if ((wd=ngetcwd())==NULL) return 1; pid = getpid(); if (_putobj(obj,"pid",inst,&pid)) return 1; if (_putobj(obj,"cwd",inst,wd)) { g_free(wd); return 1; } #ifdef HAVE_LIBGSL gsl_set_error_handler_off(); #endif return 0; } static int close_module(struct nhash *hash, void *data) { struct ngraph_plugin *plugin; plugin = (struct ngraph_plugin *) hash->val.p; if (plugin->close) { plugin->close(); } if (plugin->file) { g_free(plugin->file); } if (plugin->module) { g_module_close(plugin->module); } g_free(plugin); hash->val.p = NULL; return 0; } static int sysdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct objlist *objcur; int i, n; char *s; struct narray *array; struct objlist *objectcur,*objectdel; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; nhash_each(Plugins, close_module, NULL); nhash_clear(Plugins); objcur=chkobjroot(); while (objcur!=NULL) { if (objcur!=obj) { recoverinstance(objcur); for (i=chkobjlastinst(objcur);i>=0;i--) delobj(objcur,i); } objcur=objcur->next; } _getobj(obj,"conf_dir",inst,&s); g_free(s); _getobj(obj,"data_dir",inst,&s); g_free(s); _getobj(obj,"doc_dir",inst,&s); g_free(s); _getobj(obj,"lib_dir",inst,&s); g_free(s); _getobj(obj,"plugin_dir",inst,&s); g_free(s); _getobj(obj,"home_dir",inst,&s); g_free(s); _getobj(obj,"cwd",inst,&s); g_free(s); _getobj(obj,"login_shell",inst,&s); g_free(s); _getobj(obj,"time",inst,&s); g_free(s); _getobj(obj,"date",inst,&s); g_free(s); _getobj(obj,"expand_dir",inst,&s); g_free(s); _getobj(obj,"temp_file",inst,&s); g_free(s); _getobj(obj,"temp_list",inst,&array); n = arraynum(array); if (n > 0) { char **data; data = arraydata(array); for (i = 0; i < n; i++) { g_unlink(data[i]); } } arrayfree2(array); objectcur=chkobjroot(); while (objectcur!=NULL) { objectdel=objectcur; objectcur=objectcur->next; if (objectdel->doneproc) objectdel->doneproc(objectdel,objectdel->local); if (objectdel->table_hash) nhash_free(objectdel->table_hash); g_free(objectdel); } g_free(inst); g_free(argv); nhash_free(Plugins); exit(0); return 0; } static int syscwd(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *wd; const char *home; wd=argv[2]; if (wd!=NULL) { if (nchdir(wd)!=0) { error2(obj,ERRSYSNODIR,wd); return 1; } } else { if ((home=g_getenv("HOME"))!=NULL) { if (nchdir(home)!=0) { error2(obj,ERRSYSNODIR,home); return 1; } } } if ((wd=ngetcwd())==NULL) return 1; g_free(argv[2]); argv[2]=wd; return 0; } static int systime(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { time_t t; int style; t=time(NULL); style=*(int *)(argv[2]); g_free(rval->str); rval->str=ntime(&t,style); return 0; } static int sysdate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { time_t t; int style; t=time(NULL); style=*(int *)(argv[2]); g_free(rval->str); rval->str=ndate(&t,style); return 0; } static int systemp(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *pfx, *tmpfil; struct narray *array; int fd; g_free(rval->str); rval->str=NULL; _getobj(obj,"temp_prefix",inst,&pfx); _getobj(obj,"temp_list",inst,&array); if (array==NULL) { if ((array=arraynew(sizeof(char *)))==NULL) return 1; if (_putobj(obj,"temp_list",inst,array)) { arrayfree2(array); return 1; } } fd = n_mkstemp(NULL, pfx, &tmpfil); if (fd < 0) { error(obj, ERRSYSTMPFILE); return 1; } close(fd); arrayadd2(array,tmpfil); rval->str=tmpfil; return 0; } static int sysunlink(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *tmpfil; struct narray *array; int i,num; char **data; _getobj(obj,"temp_list",inst,&array); if (array==NULL) return 0; num=arraynum(array); data=arraydata(array); if (num>0) { tmpfil=(char *)argv[2]; if (tmpfil==NULL) tmpfil=data[num-1]; for (i=num-1;i>=0;i--) if (strcmp(tmpfil,data[i])==0) break; if (i>=0) { g_unlink(data[i]); arrayndel2(array,i); } } if (arraynum(array)==0) { arrayfree2(array); _putobj(obj,"temp_list",inst,NULL); } _getobj(obj,"temp_file",inst,&tmpfil); g_free(tmpfil); _putobj(obj,"temp_file",inst,NULL); return 0; } static int syshideinstance(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; struct objlist *obj2; char **objdata; int j,anum; array=(struct narray *)argv[2]; if (array!=NULL) { anum=arraynum(array); objdata=arraydata(array); for (j=0;j= 2) { data=arraydata(iarray); resizeconsole(data[0], data[1]); } return 0; } static int get_symbol(GModule *module, const char *format, const char *name, gpointer *symbol) { char *func; int r; func = g_strdup_printf(format, name); r = g_module_symbol(module, func, symbol); g_free(func); return ! r; } static char * get_basename(const char *str) { char *basename; int i; basename = getbasename(str); if (basename == NULL) { return NULL; } for (i = 0; basename[i]; i++) { if (basename[i] == '.') { basename[i] = '\0'; break; } } return basename; } static char * get_plugin_name(const char *name) { struct objlist *sysobj; char *module_file, *plugin_path; plugin_path = NULL; sysobj = getobject("system"); getobj(sysobj, "plugin_dir", 0, 0, NULL, &plugin_path); module_file = g_module_build_path(plugin_path, name); return module_file; } static int load_plugin_sub(struct objlist *obj, N_VALUE *inst, const char *name, struct ngraph_plugin *plugin) { GModule *module; void *loaded; ngraph_plugin_open np_open; ngraph_plugin_close np_close; int r; char *module_file; module = NULL; module_file = NULL; r = nhash_get_ptr(Plugins, name, &loaded); if (r == 0 && loaded) { error2(obj, ERRSYSLOADED, name); goto ErrorExit; } module_file = get_plugin_name(name); module = g_module_open(module_file, 0); if (module == NULL) { putstderr(g_module_error()); error2(obj, ERRSYSLOAD, name); goto ErrorExit; } np_open = NULL; get_symbol(module, "ngraph_plugin_open_%s", name, (gpointer *) &np_open); np_close = NULL; get_symbol(module, "ngraph_plugin_close_%s", name, (gpointer *) &np_close); r = nhash_set_ptr(Plugins, name, plugin); if (r) { error(obj, ERRSYSMEM); goto ErrorExit; } plugin->file = module_file; plugin->module = module; plugin->exec = NULL; plugin->open = np_open; plugin->close = np_close; return 0; ErrorExit: if (module) { g_module_close(module); } g_free(module_file); return 1; } static struct ngraph_plugin * get_plugin_from_name(const char *name) { void *ptr; int r; r = nhash_get_ptr(Plugins, name, &ptr); if (r) { return NULL; } return ptr; } struct ngraph_plugin * load_plugin(struct objlist *obj, N_VALUE *inst, const char *arg, int *rval) { char *name; struct ngraph_plugin *plugin; int r; if (arg == NULL) { error(obj, ERRSYSNOMODULE); return NULL; } name = get_basename(arg); if (name == NULL) { error(obj, ERRSYSNOMODULE); return NULL; } plugin = get_plugin_from_name(name); if (plugin) { error2(obj, ERRSYSLOADED, name); g_free(name); return NULL; } plugin = g_malloc0(sizeof(struct ngraph_plugin)); if (plugin == NULL) { g_free(name); error(obj, ERRSYSMEM); return NULL; } if (load_plugin_sub(obj, inst, name, plugin)) { g_free(name); g_free(plugin); return NULL; } g_free(name); if (plugin->open) { r = plugin->open(); if (rval) { *rval = r; } if (r) { error2(obj, ERRSYSINIT, arg); return NULL; } } return plugin; } static int system_plugin_load(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct ngraph_plugin *plugin; rval->i = 0; plugin = load_plugin(obj, inst, argv[2], &rval->i); return (plugin) ? 0 : 1; } static int system_plugin_check(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *name, *module_file; name = get_basename(argv[2]); if (name == NULL) { return 1; } module_file = get_plugin_name(name); g_free(name); if (module_file == NULL) { return 1; } if (naccess(module_file, R_OK)) { g_free(module_file); return 1; } g_free(module_file); return 0; } static void free_argv(int argc, char **argv) { int i; for (i = 0; i < argc; i ++) { if (argv[i]) { g_free(argv[i]); argv[i] = NULL; } } g_free(argv); } static char ** allocate_argv(int argc, char * const *argv) { int i, new_argc; char **new_argv; new_argc = argc + 1; new_argv = g_malloc0(sizeof(*new_argv) * new_argc); if (new_argv == NULL) { return NULL; } for (i = 0; i < argc; i++) { new_argv[i] = g_strdup(argv[i]); if (new_argv[i] == NULL) { free_argv(new_argc, new_argv); return NULL; } } new_argv[i] = NULL; return new_argv; } static int system_plugin_exec(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct ngraph_plugin *plugin; char **new_argv; int r; rval->i = 0; if (argc < 4) { error2(obj, ERRSYSSMALLARGS, argv[1]); return 0; } if (get_security()) { error(obj, ERRSYSSECURTY); return 1; } plugin = get_plugin_from_name(argv[2]); if (plugin == NULL) { plugin = load_plugin(obj, inst, argv[2], NULL); if (plugin == NULL) { return 1; } } if (plugin->exec == NULL) { error2(obj, ERRSYSNOTEXECUTABLE, argv[2]); return 1; } if (plugin->lock) { error2(obj, ERRSYSLOCKED, argv[2]); return 1; } new_argv = allocate_argv(argc - 3, argv + 3); if (new_argv == NULL) { error(obj, ERRSYSMEM); return 1; } plugin->lock = TRUE; r = plugin->exec(argc - 3, new_argv); plugin->lock = FALSE; rval->i = r; free_argv(argc - 3, new_argv); return r; } static int system_plugin_get_module(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct ngraph_plugin *plugin; g_free(rval->str); rval->str = NULL; if (argv[2] == NULL) { return 1; } plugin = get_plugin_from_name(argv[2]); if (plugin == NULL) { error(obj, ERRSYSNOLOAD); return 1; } if (plugin->file) { rval->str = g_strdup(plugin->file); } else { rval->str = g_strdup("internal"); } return 0; } static int list_module(struct nhash *hash, void *data) { struct narray *array; const char *name; array = (struct narray *) data; name = hash->key; arrayadd2(array, name); return 0; } static int system_plugin_modules(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; arrayfree2(rval->array); rval->array = NULL; array = arraynew(sizeof(char *)); if (array == NULL) { error(obj, ERRSYSMEM); return 1; } rval->array = array; nhash_each(Plugins, list_module, array); return 0; } int system_set_exec_func(const char *name, ngraph_plugin_exec func) { struct ngraph_plugin *plugin; int r; if (name == NULL || func == NULL) { return 1; } plugin = get_plugin_from_name(name); if (plugin == NULL) { plugin = g_malloc0(sizeof(struct ngraph_plugin)); if (plugin == NULL) { return 1; } r = nhash_set_ptr(Plugins, name, plugin); if (r) { return 1; } } plugin->exec = func; return 0; } static struct objtable nsystem[] = { {"init",NVFUNC,NEXEC,sysinit,NULL,0}, {"done",NVFUNC,NEXEC,sysdone,NULL,0}, {"name",NSTR,NREAD,NULL,NULL,0}, {"version",NSTR,NREAD,NULL,NULL,0}, {"copyright",NSTR,NREAD,NULL,NULL,0}, {"e-mail",NSTR,NREAD,NULL,NULL,0}, {"web",NSTR,NREAD,NULL,NULL,0}, {"compiler",NSTR,NREAD,NULL,NULL,0}, {"login_shell",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"cwd",NSTR,NREAD|NWRITE,syscwd,NULL,0}, {"ignore_path",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"expand_file",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"expand_dir",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"GRAF",NSTR,NREAD,NULL,NULL,0}, {"temp_prefix",NSTR,NREAD,NULL,NULL,0}, {"conf_dir",NSTR,NREAD,NULL,NULL,0}, {"data_dir",NSTR,NREAD,NULL,NULL,0}, {"doc_dir",NSTR,NREAD,NULL,NULL,0}, {"lib_dir",NSTR,NREAD,NULL,NULL,0}, {"plugin_dir",NSTR,NREAD,NULL,NULL,0}, {"home_dir",NSTR,NREAD,NULL,NULL,0}, {"pid",NINT,NREAD,NULL,NULL,0}, {"time",NSFUNC,NREAD|NEXEC,systime,"i",0}, {"date",NSFUNC,NREAD|NEXEC,sysdate,"i",0}, {"temp_file",NSFUNC,NREAD|NEXEC,systemp,"",0}, {"temp_list",NSARRAY,NREAD,NULL,NULL,0}, {"unlink_temp_file",NVFUNC,NREAD|NEXEC,sysunlink,NULL,0}, {"hide_instance",NVFUNC,NREAD|NEXEC,syshideinstance,"sa",0}, {"recover_instance",NVFUNC,NREAD|NEXEC,sysrecoverinstance,"sa",0}, {"resize",NVFUNC,NREAD|NEXEC,systemresize,"ia",0}, {"plugin_check", NIFUNC, NREAD|NEXEC, system_plugin_check, "s", 0}, {"plugin_load", NIFUNC, NREAD|NEXEC, system_plugin_load, "s", 0}, {"plugin_exec",NIFUNC, NREAD|NEXEC, system_plugin_exec, NULL, 0}, {"plugin_module",NSFUNC, NREAD|NEXEC, system_plugin_get_module, "s", 0}, {"plugins",NSAFUNC, NREAD|NEXEC, system_plugin_modules, "", 0}, }; #define TBLNUM (sizeof(nsystem) / sizeof(*nsystem)) void * addsystem() /* addsystem() returns NULL on error */ { Plugins = nhash_new(); if (Plugins == NULL) { return NULL; } return addobject(NAME,NULL,PARENT,VERSION,TBLNUM,nsystem,ERRNUM,syserrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/odata.c0000644000175000017500000076103413340156720012707 00000000000000/* * $Id: ofile.c,v 1.113 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include #include #include #include #include #include #include #include #include #include "common.h" #include "nhash.h" #include "ngraph.h" #include "osystem.h" #include "object.h" #include "ioutil.h" #include "nstring.h" #include "mathcode.h" #include "mathfn.h" #include "spline.h" #include "gra.h" #include "ntime.h" #include "oroot.h" #include "odraw.h" #include "odata.h" #include "axis.h" #include "nconfig.h" #include "math/math_equation.h" #define UPDATE_PROGRESS_LINE_NUM 0xfff enum { MATH_CONST_NUM, MATH_CONST_MINX, MATH_CONST_MAXX, MATH_CONST_MINY, MATH_CONST_MAXY, MATH_CONST_SUMX, MATH_CONST_SUMY, MATH_CONST_SUMXX, MATH_CONST_SUMYY, MATH_CONST_SUMXY, MATH_CONST_AVX, MATH_CONST_AVY, MATH_CONST_SGX, MATH_CONST_SGY, MATH_CONST_STDEVPX, MATH_CONST_STDEVPY, MATH_CONST_STDEVX, MATH_CONST_STDEVY, TWOPASS_CONST_SIZE, }; enum { MATH_CONST_MASK = TWOPASS_CONST_SIZE, MATH_CONST_MOVE, MATH_CONST_FIRST, MATH_CONST_COLX, MATH_CONST_COLY, MATH_CONST_AXISX, MATH_CONST_AXISX_MIN, MATH_CONST_AXISX_MAX, MATH_CONST_AXISX_LEN, MATH_CONST_AXISY, MATH_CONST_AXISY_MIN, MATH_CONST_AXISY_MAX, MATH_CONST_AXISY_LEN, MATH_CONST_HSKIP, MATH_CONST_RSTEP, MATH_CONST_FLINE, MATH_CONST_DATA_OBJ, MATH_CONST_FILE_OBJ, MATH_CONST_PATH_OBJ, MATH_CONST_RECT_OBJ, MATH_CONST_ARC_OBJ, MATH_CONST_MARK_OBJ, MATH_CONST_TEXT_OBJ, MATH_CONST_D, MATH_CONST_N, MATH_CONST_SIZE, }; #define NAME "data" #define ALIAS "file" #define PARENT "draw" #define OVERSION "1.00.00" #define F2DCONF "[data]" #define COLUMN_ARRAY_NAME "COL" #define ERRFILE 100 #define ERROPEN 101 #define ERRSYNTAX 102 #define ERRILLEGAL 103 #define ERRNEST 104 #define ERRNOAXIS 105 #define ERRNOAXISINST 106 #define ERRNOSETAXIS 107 #define ERRMINMAX 108 #define ERRAXISDIR 109 #define ERRMSYNTAX 110 #define ERRMERR 111 #define ERRMNONUM 112 #define ERRSPL 113 #define ERRNOFIT 114 #define ERRNOFITINST 115 #define ERRIFS 116 #define ERRILOPTION 117 #define ERRIGNORE 118 #define ERRNEGATIVE 119 #define ERRREAD 120 #define ERRWRITE 121 #define ERR_SMALL_ARGS 122 #define ERR_INVALID_TYPE 123 #define ERR_INVALID_PARAM 124 #define ERRCONVERGE 125 #define ERR_INVALID_SOURCE 126 #define ERR_INVALID_OBJ 127 #define ERR_INVALID_RANGE 128 static char *f2derrorlist[]={ "file is not specified.", "I/O error: open file", "syntax error in math.", "not allowed function in math.", "sum() or dif(): deep nest in math.", "`axis' is not specified.", "no instance for axis", "axis parameter is not set.", "illegal axis min/max.", "illegal axis direction.", "syntax error in math:", "illegal value in math:", "unnumeric data:", "error: spline interpolation.", "`fit' is not specified.", "no instance for fit", "illegal ifs.", "illegal file option", "illegal value for axis ---> ignored", "negative value in LOG-axis ---> ABS()", "I/O error: read file", "I/O error: write file", "too small number of arguments.", "invalid type.", "invalid parameter.", "convergence error.", "invalid source.", "invalid object.", "invalid range.", }; #define ERRNUM (sizeof(f2derrorlist) / sizeof(*f2derrorlist)) static char *data_type[]={ N_("file"), N_("array"), N_("range"), NULL }; static char *averaging_type_char[]={ N_("simple"), N_("weighted"), N_("exponential"), NULL }; static char *f2dtypechar[]={ N_("mark"), N_("line"), N_("polygon"), N_("polygon_solid_fill"), N_("curve"), N_("diagonal"), N_("arrow"), N_("rectangle"), N_("rectangle_fill"), N_("rectangle_solid_fill"), N_("errorbar_x"), N_("errorbar_y"), N_("staircase_x"), N_("staircase_y"), N_("bar_x"), N_("bar_y"), N_("bar_fill_x"), N_("bar_fill_y"), N_("bar_solid_fill_x"), N_("bar_solid_fill_y"), N_("fit"), NULL }; static int set_math_config(struct objlist *obj, N_VALUE *inst, char *field, char *str); static struct obj_config FileConfig[] = { {"R", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"G", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"B", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"A", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"R2", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"G2", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"B2", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"A2", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"x", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"y", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"type", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"smooth_x", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"smooth_y", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"averaging_type", OBJ_CONFIG_TYPE_STRING, NULL, NULL}, {"mark_type", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"mark_size", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"line_width", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"line_join", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"line_miter_limit", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"head_skip", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"read_step", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"final_line", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"csv", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"data_clip", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"interpolation", OBJ_CONFIG_TYPE_NUMERIC, NULL, NULL}, {"remark", OBJ_CONFIG_TYPE_STRING, NULL, NULL}, {"ifs", OBJ_CONFIG_TYPE_STRING, NULL, NULL}, {"axis_x", OBJ_CONFIG_TYPE_STRING, NULL, NULL}, {"axis_y", OBJ_CONFIG_TYPE_STRING, NULL, NULL}, {"line_style", OBJ_CONFIG_TYPE_STYLE, NULL, NULL}, {"math_x", OBJ_CONFIG_TYPE_OTHER, set_math_config, obj_save_config_string}, {"math_y", OBJ_CONFIG_TYPE_OTHER, set_math_config, obj_save_config_string}, {"func_f", OBJ_CONFIG_TYPE_OTHER, set_math_config, obj_save_config_string}, {"func_g", OBJ_CONFIG_TYPE_OTHER, set_math_config, obj_save_config_string}, {"func_h", OBJ_CONFIG_TYPE_OTHER, set_math_config, obj_save_config_string}, }; #define MASK_SERACH_METHOD_LINER 0 #define MASK_SERACH_METHOD_BINARY 1 #define MASK_SERACH_METHOD_CONST 2 #define MASK_SERACH_METHOD MASK_SERACH_METHOD_CONST static NHASH FileConfigHash = NULL; #define DXBUFSIZE 101 #define USE_BUF_PTR 1 #define USE_RING_BUF 2 #define BUF_TYPE USE_BUF_PTR #define FIT_FIELD_PREFIX "fit_" #define USE_MEMMOVE 1 #if BUF_TYPE == USE_RING_BUF #define RING_BUF_INC(i) (((i) < DXBUFSIZE) ? ((i) + 1) : 0) #endif #if HAVE_ISFINITE #define check_infinite(v) (! isfinite(v)) #elsif HAVE_FINITE #define check_infinite(v) (! finite(v)) #else #define check_infinite(v) ((v) != (v) || (v) == HUGE_VAL || (v) == - HUGE_VAL) #endif struct rgba { int r, g, b, a; }; struct f2ddata_buf { double dx, dy, d2, d3; struct rgba col, col2; int marksize, marktype, line; int dxstat, dystat, d2stat, d3stat; }; #define EQUATION_NUM 3 struct f2dlocal; struct f2ddata { struct objlist *obj; int id,src, GC; char *file; FILE *fd; int x,y; enum {TYPE_NORMAL, TYPE_DIAGONAL, TYPE_ERR_X, TYPE_ERR_Y} type; /* fp->type: 0 normal (dx ... dy) 1 diagonal (dx dy ... d2 d3) 2 error bar x (dx d2 d3 ... dy) 3 error bar y (dx ... dy d2 d3) */ int hskip; int rstep; int final; int csv; char *remark,*ifs, ifs_buf[256]; int line,dline; double count; int eof; int dataclip; double axmin,axmax,aymin,aymax; double axmin2,axmax2,aymin2,aymax2; double axvx,axvy,ayvx,ayvy; int axisx, axisy; int axtype,aytype,axposx,axposy,ayposx,ayposy,axlen,aylen; double ratex,ratey; MathEquation *codex[EQUATION_NUM], *codey[EQUATION_NUM]; MathValue minx, maxx, miny, maxy; int *const_id; struct rgba col, col2, color, color2, fg, bg; int fnumx, fnumy; int *needx, *needy; int dxstat,dystat,d2stat,d3stat; double dx,dy,d2,d3; int maxdim, column_array_id_x, column_array_id_y, use_column_array; int need2pass; double sumx,sumy,sumxx,sumyy,sumxy; int num,datanum,prev_datanum; int marksize0,marksize; int marktype0,marktype; int ignore,negative; int msize,mtype; struct f2ddata_buf buf[DXBUFSIZE]; #if BUF_TYPE == USE_BUF_PTR struct f2ddata_buf *buf_ptr[DXBUFSIZE]; #elif BUF_TYPE == USE_RING_BUF int ringbuf_top; #endif int bufnum,bufpo; int smooth,smoothx,smoothy; int averaging_type; int masknum; int *mask; #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_CONST int mask_index; #endif int movenum; double *movex,*movey; int *move; time_t mtime; int interrupt; struct narray fileopen; struct array_prm array_data; double range_min, range_max; int range_div; struct f2dlocal *local; }; struct f2dlocal { MathEquation *codex[EQUATION_NUM], *codey[EQUATION_NUM]; MathValue minx, maxx, miny, maxy; int const_id[MATH_CONST_SIZE]; int maxdimx,maxdimy, column_array_id_x, column_array_id_y; int need2passx,need2passy,total_line; struct f2ddata *data; int coord,idx,idy,id2,id3,icx,icy,ic2,ic3,isx,isy,is2,is3,iline; FILE *storefd; int endstore; double sumx, sumy, sumxx, sumyy, sumxy; double dminx, dmaxx, dminy, dmaxy, davx, davy, dstdevpx, dstdevpy, dstdevx, dstdevy; int num, rcode, use_drawing_func; time_t mtime, mtime_stat; }; struct point_pos { double x, y, d; }; static int set_data_progress(struct f2ddata *fp); static int getminmaxdata(struct f2ddata *fp, struct f2dlocal *local); static int calc_fit_equation(struct objlist *obj, N_VALUE *inst, double x, double *y); static void f2dtransf(double x,double y,int *gx,int *gy,void *local); static int _f2dtransf(double x,double y,int *gx,int *gy,void *local); static int f2drectclipf(double *x0,double *y0,double *x1,double *y1,void *local); static int f2dlineclipf(double *x0,double *y0,double *x1,double *y1,void *local); static int getposition(struct f2ddata *fp,double x,double y,int *gx,int *gy); static int getposition2(struct f2ddata *fp,int axtype,int aytype,double *x,double *y); static void set_column_array(MathEquation **code, int id, MathValue *gdata, int maxdim); static void draw_errorbar(struct f2ddata *fp, int GC, int size, double dx0, double dy0, double dx1, double dy1); static void poly_add_point(struct narray *pos, double x, double y, struct f2ddata *fp); static void poly_add_clip_point(struct narray *pos, double minx, double miny, double maxx, double maxy, double x, double y, struct f2ddata *fp); static int poly_pos_sort_cb(const void *a, const void *b); static void poly_set_pos(struct point_pos *p, int i, double x, double y, double x0, double y0); static int poly_add_elements(struct narray *pos, double minx, double miny, double maxx, double maxy, double x0, double y0, double x1, double y1, struct f2ddata *fp); static void add_polygon_point(struct narray *pos, double x0, double y0, double x1, double y1, struct f2ddata *fp); static void uniq_points(struct narray *pos); static void draw_polygon(struct narray *pos, int GC, int fill); #if BUF_TYPE == USE_RING_BUF int ring_buf_index(struct f2ddata *fp, int i) { int n; n = fp->ringbuf_top + i; return (n < DXBUFSIZE) ? n : n % DXBUFSIZE; } #endif static void check_ifs_init(struct f2ddata *fp) { char *ifs, *remark; int i; ifs = fp->ifs; remark = fp->remark; memset(fp->ifs_buf, 0, sizeof(fp->ifs_buf)); if (ifs) { for (; *ifs; ifs++) { i = *ifs; if (i > 0) { fp->ifs_buf[i] |= 1; } } } if (remark) { for (; *remark; remark++) { i = *remark; if (i > 0) { fp->ifs_buf[i] |= 2; } } } } #define CHECK_IFS(buf, ch) (buf[(unsigned char) ch] & 1) #define CHECK_REMARK(remark, buf, ch) (remark && (buf[(unsigned char) ch] & 2)) #define FILE_OBJ_COLOR_COLOR 0 #define FILE_OBJ_COLOR_ALPHA 1 struct object_color_type { char *name; enum { COLOR_TYPE_MARK, COLOR_TYPE_PATH, COLOR_TYPE_TEXT, } color_type; }; static int line_number(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; rval->val = 0; rval->type = MATH_VALUE_NORMAL; fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = fp->line; return 0; } static int file_obj_color_alpha(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval, int type) { struct f2ddata *fp; struct objlist *obj; int id, object_id, color_type; struct object_color_type obj_names[] = { {"data", COLOR_TYPE_MARK}, {"path", COLOR_TYPE_PATH}, {"rectangle", COLOR_TYPE_PATH}, {"arc", COLOR_TYPE_PATH}, {"mark", COLOR_TYPE_MARK}, {"text", COLOR_TYPE_TEXT}, }; unsigned int i; *rval = exp->buf[0].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } id = exp->buf[0].val.val; object_id = exp->buf[1].val.val; if (object_id == 0) { object_id = chkobjectid(fp->obj); } obj = NULL; color_type = COLOR_TYPE_TEXT; for (i = 0; i < sizeof(obj_names) / sizeof(*obj_names); i++) { obj = getobject(obj_names[i].name); if (obj && object_id == chkobjectid(obj)) { color_type = obj_names[i].color_type; break; } obj = NULL; } if (obj == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (chkobjinst(obj, id) == NULL) { return 0; } switch (color_type) { case COLOR_TYPE_MARK: if (type == FILE_OBJ_COLOR_COLOR) { getobj(obj, "R2", id, 0, NULL, &fp->color2.r); getobj(obj, "G2", id, 0, NULL, &fp->color2.g); getobj(obj, "B2", id, 0, NULL, &fp->color2.b); } else { getobj(obj, "A2", id, 0, NULL, &fp->color2.a); } /* fall through */ case COLOR_TYPE_TEXT: if (type == FILE_OBJ_COLOR_COLOR) { getobj(obj, "R", id, 0, NULL, &fp->color.r); getobj(obj, "G", id, 0, NULL, &fp->color.g); getobj(obj, "B", id, 0, NULL, &fp->color.b); } else { getobj(obj, "A", id, 0, NULL, &fp->color.a); } break; case COLOR_TYPE_PATH: if (type == FILE_OBJ_COLOR_COLOR) { getobj(obj, "stroke_R", id, 0, NULL, &fp->color.r); getobj(obj, "stroke_G", id, 0, NULL, &fp->color.g); getobj(obj, "stroke_B", id, 0, NULL, &fp->color.b); getobj(obj, "fill_R", id, 0, NULL, &fp->color2.r); getobj(obj, "fill_G", id, 0, NULL, &fp->color2.g); getobj(obj, "fill_B", id, 0, NULL, &fp->color2.b); } else { getobj(obj, "stroke_A", id, 0, NULL, &fp->color.a); getobj(obj, "fill_A", id, 0, NULL, &fp->color2.a); } break; } fp->local->use_drawing_func = TRUE; return 0; } static int file_objcolor(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_obj_color_alpha(exp, eq, rval, FILE_OBJ_COLOR_COLOR); } static int file_objalpha(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_obj_color_alpha(exp, eq, rval, FILE_OBJ_COLOR_ALPHA); } static int file_color(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int color, val; *rval = exp->buf[1].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } color = exp->buf[0].val.val; val = exp->buf[1].val.val; #if 0 if (val < 0 || val > 255) { rval->type = MATH_VALUE_ERROR; return 1; } #else if (color < 8) { if (val < 0) { val = 0; } else if (val > 255) { val = 255; } } #endif switch (color) { case 0: fp->color.r = val; break; case 1: fp->color.g = val; break; case 2: fp->color.b = val; break; case 3: fp->color.r = fp->color.g = fp->color.b = val; break; case 4: fp->color2.r = val; break; case 5: fp->color2.g = val; break; case 6: fp->color2.b = val; break; case 7: fp->color2.r = fp->color2.g = fp->color2.b = val; break; case 8: fp->color.r = ((val >> 16) & 0xff); fp->color.g = ((val >> 8) & 0xff); fp->color.b = (val & 0xff); break; case 9: fp->color2.r = ((val >> 16) & 0xff); fp->color2.g = ((val >> 8) & 0xff); fp->color2.b = (val & 0xff); break; default: rval->type = MATH_VALUE_ERROR; return 1; } fp->local->use_drawing_func = TRUE; return 0; } static int file_alpha(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int alpha, color; *rval = exp->buf[0].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } alpha = exp->buf[0].val.val; #if 0 if (alpha < 0 || alpha > 255) { rval->type = MATH_VALUE_ERROR; return 1; } #else if (alpha < 0) { alpha = 0; } else if (alpha > 255) { alpha = 255; } #endif color = exp->buf[1].val.val; switch (color) { case 1: fp->color.a = alpha; break; case 2: fp->color2.a = alpha; break; default: fp->color.a = alpha; fp->color2.a = alpha; } fp->local->use_drawing_func = TRUE; return 0; } static int file_rgb_sub(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval, int color2) { struct f2ddata *fp; int r, g, b; *rval = exp->buf[2].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } r = exp->buf[0].val.val * 255; g = exp->buf[1].val.val * 255; b = exp->buf[2].val.val * 255; #if 0 if (r < 0 || r > 255 || g < 0 || g > 255 || b < 0 || b > 255) { rval->type = MATH_VALUE_ERROR; return 1; } #else if (r < 0) { r = 0; } else if (r > 255) { r = 255; } if (g < 0) { g = 0; } else if (g > 255) { g = 255; } if (b < 0) { b = 0; } else if (b > 255) { b = 255; } #endif if (color2) { fp->color2.r = r; fp->color2.g = g; fp->color2.b = b; } else { fp->color.r = r; fp->color.g = g; fp->color.b = b; } fp->local->use_drawing_func = TRUE; return 0; } static int file_rgb(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_rgb_sub(exp, eq, rval, FALSE); } static int file_rgb2(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_rgb_sub(exp, eq, rval, TRUE); } static int file_hsb_sub(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval, int color2) { struct f2ddata *fp; double h, s, b; int r, g, bb; *rval = exp->buf[2].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } h = exp->buf[0].val.val; s = exp->buf[1].val.val; b = exp->buf[2].val.val; #if 0 if (h < 0 || h > 1 || s < 0 || s > 1 || b < 0 || b > 1) { rval->type = MATH_VALUE_ERROR; return 1; } #else if (h < 0) { h = 0; } else if (h > 1) { h = 1; } if (s < 0) { s = 0; } else if (s > 1) { s = 1; } if (b < 0) { b = 0; } else if (b > 1) { b = 1; } #endif HSB2RGB(h, s, b, &r, &g, &bb); if (color2) { fp->color2.r = r; fp->color2.g = g; fp->color2.b = bb; } else { fp->color.r = r; fp->color.g = g; fp->color.b = bb; } fp->local->use_drawing_func = TRUE; return 0; } static int file_hsb(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_hsb_sub(exp, eq, rval, FALSE); } static int file_hsb2(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_hsb_sub(exp, eq, rval, TRUE); } static int file_marksize(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int size; *rval = exp->buf[0].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } size = exp->buf[0].val.val; if (size < 0 || size > 65536) { rval->type = MATH_VALUE_ERROR; return 1; } fp->marksize = size; return 0; } static int file_marktype(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int type; *rval = exp->buf[0].val; if (exp->buf[0].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } type = exp->buf[0].val.val; if (type < 0 || type >= MARK_TYPE_NUM) { rval->type = MATH_VALUE_ERROR; return 1; } fp->marktype = type; return 0; } static int file_fit_calc(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int file_id, r; double x, y; static struct objlist *file_obj = NULL; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL) { return 0; } if (file_obj == NULL) { file_obj = getobject("data"); } if (file_obj == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } file_id = exp->buf[0].val.val; x = exp->buf[1].val.val; r = ofile_calc_fit_equation(file_obj, file_id, x, &y); if (r) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = y; rval->type = MATH_VALUE_NORMAL; return 0; } static int file_fit_prm(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int file_id, prm, r; char *argv[2], *ptr; struct savedstdio save; static struct objlist *file_obj = NULL; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL) { return 0; } if (file_obj == NULL) { file_obj = getobject("data"); } if (file_obj == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } file_id = exp->buf[0].val.val; prm = exp->buf[1].val.val; argv[0] = (char *) &prm; argv[1] = NULL; ignorestdio(&save); r = getobj(file_obj, "fit_prm", file_id, 1, argv, &ptr); restorestdio(&save); if (r < 0 || ptr == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } rval->val = atof(ptr); rval->type = MATH_VALUE_NORMAL; return 0; } #define ARC_INTERPOLATION 20 #define DRAW_ARC_ARG_NUM 10 static int file_draw_arc(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int i, r, num, stroke, fill, pie, close, cx, cy, ap[ARC_INTERPOLATION * 2], *pdata, px, py; double x, y, rx, ry, angle1, angle2, angle; struct narray expand_points; rval->val = 0; for (i = 0; i < DRAW_ARC_ARG_NUM; i++) { if (exp->buf[i].val.type != MATH_VALUE_NORMAL) { return 0; } } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } x = exp->buf[0].val.val; y = exp->buf[1].val.val; rx = exp->buf[2].val.val; ry = exp->buf[3].val.val; angle1 = exp->buf[4].val.val; angle2 = exp->buf[5].val.val; pie = exp->buf[6].val.val; stroke = exp->buf[7].val.val; fill = exp->buf[8].val.val; close = exp->buf[9].val.val; if (getposition(fp, x, y, &cx, &cy)) { return 0; } angle2 = fmod(angle2, 360); if (angle2 == 0.0) { angle2 = 360; close = TRUE; } for (i = 0; i < ARC_INTERPOLATION; i++) { double ax, ay; angle = angle1 + angle2 / (ARC_INTERPOLATION - 1) * i; angle = MPI * angle / 180.0; ax = x + rx * cos(angle); ay = y + ry * sin(angle); r = getposition2(fp, fp->axtype, fp->aytype, &ax, &ay); if (r) { rval->type = MATH_VALUE_ERROR; return -1; } f2dtransf(ax, ay, ap + i * 2, ap + i * 2 + 1, fp); } arrayinit(&expand_points, sizeof(int)); if (curve_expand_points(ap, ARC_INTERPOLATION, INTERPOLATION_TYPE_SPLINE, &expand_points)) { arraydel(&expand_points); return 1; } if (pie) { arrayadd(&expand_points, &cx); arrayadd(&expand_points, &cy); } num = arraynum(&expand_points) / 2; pdata = arraydata(&expand_points); GRAcurrent_point(fp->GC, &px, &py); if (fill) { GRAcolor(fp->GC, fp->color2.r, fp->color2.g, fp->color2.b, fp->color2.a); GRAdrawpoly(fp->GC, num, pdata, GRA_FILL_MODE_EVEN_ODD); } if (stroke) { GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); if (close) { GRAdrawpoly(fp->GC, num, pdata, GRA_FILL_MODE_NONE); } else { int n; n = (pie) ? num - 1 : num; GRAmoveto(fp->GC, pdata[0], pdata[1]); for (i = 1; i < n; i++) { GRAlineto(fp->GC, pdata[i * 2], pdata[i * 2 + 1]); } } } GRAmoveto(fp->GC, px, py); arraydel(&expand_points); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_rect(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int i, r, stroke, fill, ap[8], px, py; double pos[4]; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL || exp->buf[3].val.type != MATH_VALUE_NORMAL || exp->buf[4].val.type != MATH_VALUE_NORMAL || exp->buf[5].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } for (i = 0; i < 4; i++) { pos[i] = exp->buf[i].val.val; } pos[2] += pos[0]; pos[3] += pos[1]; stroke = exp->buf[4].val.val; fill = exp->buf[5].val.val; for (i = 0; i < 2; i++) { r = getposition2(fp, fp->axtype, fp->aytype, pos + i * 2, pos + i * 2 + 1); if (r) { rval->type = MATH_VALUE_ERROR; return -1; } } if (f2drectclipf(pos, pos + 1, pos + 2, pos + 3, fp)) { return 0; } f2dtransf(pos[0], pos[1], ap + 0, ap + 1, fp); f2dtransf(pos[0], pos[3], ap + 2, ap + 3, fp); f2dtransf(pos[2], pos[3], ap + 4, ap + 5, fp); f2dtransf(pos[2], pos[1], ap + 6, ap + 7, fp); GRAcurrent_point(fp->GC, &px, &py); if (fill) { GRAcolor(fp->GC, fp->color2.r, fp->color2.g, fp->color2.b, fp->color2.a); GRAdrawpoly(fp->GC, 4, ap, GRA_FILL_MODE_EVEN_ODD); } if (stroke) { GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); GRAdrawpoly(fp->GC, 4, ap, GRA_FILL_MODE_NONE); } GRAmoveto(fp->GC, px, py); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_line(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int i, r, ap[4], px, py; double pos[4]; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL || exp->buf[3].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } for (i = 0; i < 4; i++) { pos[i] = exp->buf[i].val.val; } for (i = 0; i < 2; i++) { r = getposition2(fp, fp->axtype, fp->aytype, pos + i * 2, pos + i * 2 + 1); if (r) { rval->type = MATH_VALUE_ERROR; return -1; } } if (f2dlineclipf(pos, pos + 1, pos + 2, pos + 3, fp)) { return 0; } f2dtransf(pos[0], pos[1], ap + 0, ap + 1, fp); f2dtransf(pos[2], pos[3], ap + 2, ap + 3, fp); GRAcurrent_point(fp->GC, &px, &py); GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); GRAline(fp->GC, ap[0], ap[1], ap[2], ap[3]); GRAmoveto(fp->GC, px, py); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_errorbar(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int px, py; double x, y, erx, ery, size; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL || exp->buf[3].val.type != MATH_VALUE_NORMAL || exp->buf[4].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } x = exp->buf[0].val.val; y = exp->buf[1].val.val; erx = exp->buf[2].val.val; ery = exp->buf[3].val.val; size = exp->buf[4].val.val * 100; if (size < 1) { size = fp->marksize; } GRAcurrent_point(fp->GC, &px, &py); GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); if (erx != 0) { draw_errorbar(fp, fp->GC, size / 2, x - erx, y, x + erx, y); } if (ery != 0) { draw_errorbar(fp, fp->GC, fp->marksize / 2, x, y - ery, x, y + ery); } GRAmoveto(fp->GC, px, py); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_errorbar2(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int px, py, size; double x0, y0, x1, y1; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL || exp->buf[3].val.type != MATH_VALUE_NORMAL || exp->buf[4].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } x0 = exp->buf[0].val.val; y0 = exp->buf[1].val.val; x1 = exp->buf[2].val.val; y1 = exp->buf[3].val.val; size = exp->buf[4].val.val * 100; if (size < 1) { size = fp->marksize; } GRAcurrent_point(fp->GC, &px, &py); GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); draw_errorbar(fp, fp->GC, size / 2, x0, y0, x1, y1); GRAmoveto(fp->GC, px, py); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_mark(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { struct f2ddata *fp; int cx, cy, size; double x, y; rval->val = 0; if (exp->buf[0].val.type != MATH_VALUE_NORMAL || exp->buf[1].val.type != MATH_VALUE_NORMAL || exp->buf[2].val.type != MATH_VALUE_NORMAL) { return 0; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } x = exp->buf[0].val.val; y = exp->buf[1].val.val; size = exp->buf[2].val.val * 100; if (size <= 0) { size = fp->marksize; } if (getposition(fp, x, y, &cx, &cy)) { return 0; } if (size > 0) { int px, py; GRAcurrent_point(fp->GC, &px, &py); GRAmark(fp->GC, fp->marktype, cx, cy, size, fp->color.r, fp->color.g, fp->color.b, fp->color.a, fp->color2.r, fp->color2.g, fp->color2.b, fp->color2.a); GRAmoveto(fp->GC, px, py); fp->local->use_drawing_func = TRUE; } return 0; } static void draw_lines(struct narray *pos, int GC) { int n, *ap; uniq_points(pos); ap = (int *) arraydata(pos); n = arraynum(pos); if (n > 4) { GRAlines(GC, n / 2, ap); } } static int file_draw_path(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval, int stroke, int fill, int close) { struct f2ddata *fp; int i, id, n, first, px, py; double x0, y0, x1, y1, x2, y2; MathEquationArray *ax, *ay; struct narray pos; rval->val = 0; id = exp->buf[0].idx; ax = math_equation_get_array(eq, id); if (ax == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } n = ax->num; id = exp->buf[1].idx; ay = math_equation_get_array(eq, id); if (ay == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (ay->num < n) { n = ay->num; } fp = math_equation_get_user_data(eq); if (fp == NULL) { rval->type = MATH_VALUE_ERROR; return 1; } if (fp->GC < 0) { return 0; } arrayinit(&pos, sizeof(int)); first = TRUE; for (i = 0; i < n; i++) { if (ax->data[i].type == MATH_VALUE_NORMAL && ay->data[i].type == MATH_VALUE_NORMAL) { if (first) { first = FALSE; x0 = ax->data[i].val; y0 = ay->data[i].val; x2 = ax->data[i].val; y2 = ay->data[i].val; } else { x1 = x2; y1 = y2; x2 = ax->data[i].val; y2 = ay->data[i].val; add_polygon_point(&pos, x1, y1, x2, y2, fp); } } } if (first) { return 0; } if (close) { add_polygon_point(&pos, x2, y2, x0, y0, fp); } if (fill < 0) { fill = GRA_FILL_MODE_NONE; } else if (fill > GRA_FILL_MODE_WINDING) { fill = GRA_FILL_MODE_WINDING; } GRAcurrent_point(fp->GC, &px, &py); GRAcolor(fp->GC, fp->color2.r, fp->color2.g, fp->color2.b, fp->color2.a); if (fill) { draw_polygon(&pos, fp->GC, fill); } GRAcolor(fp->GC, fp->color.r, fp->color.g, fp->color.b, fp->color.a); if (stroke) { if (close) { draw_polygon(&pos, fp->GC, GRA_FILL_MODE_NONE); } else { draw_lines(&pos, fp->GC); } } GRAmoveto(fp->GC, px, py); arraydel(&pos); fp->local->use_drawing_func = TRUE; return 0; } static int file_draw_polyline(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { return file_draw_path(exp, eq, rval, TRUE, FALSE, FALSE); } static int file_draw_polygon(MathFunctionCallExpression *exp, MathEquation *eq, MathValue *rval) { int stroke, fill; if (exp->buf[2].val.type != MATH_VALUE_NORMAL || exp->buf[3].val.type != MATH_VALUE_NORMAL) { return 0; } stroke = exp->buf[2].val.val; fill = exp->buf[3].val.val; return file_draw_path(exp, eq, rval, stroke, fill, TRUE); } struct funcs { char *name; struct math_function_parameter prm; }; static struct funcs BasicFunc[] = { {"LINE_NUMBER", {0, 0, 0, line_number, NULL, NULL, NULL, NULL}}, }; static struct funcs FitFunc[] = { {"FIT_CALC", {2, 0, 0, file_fit_calc, NULL, NULL, NULL, NULL}}, {"FIT_PRM", {2, 0, 0, file_fit_prm, NULL, NULL, NULL, NULL}}, }; static enum MATH_FUNCTION_ARG_TYPE draw_polyline_arg_type[] = { MATH_FUNCTION_ARG_TYPE_ARRAY, MATH_FUNCTION_ARG_TYPE_ARRAY, }; static enum MATH_FUNCTION_ARG_TYPE draw_polygon_arg_type[] = { MATH_FUNCTION_ARG_TYPE_ARRAY, MATH_FUNCTION_ARG_TYPE_ARRAY, MATH_FUNCTION_ARG_TYPE_DOUBLE, MATH_FUNCTION_ARG_TYPE_DOUBLE, MATH_FUNCTION_ARG_TYPE_DOUBLE, }; static struct funcs FileFunc[] = { {"OBJ_ALPHA", {2, 0, 0, file_objalpha, NULL, NULL, NULL, NULL}}, {"OBJ_COLOR", {2, 0, 0, file_objcolor, NULL, NULL, NULL, NULL}}, {"COLOR", {2, 0, 0, file_color, NULL, NULL, NULL, NULL}}, {"ALPHA", {2, 0, 0, file_alpha, NULL, NULL, NULL, NULL}}, {"RGB", {3, 0, 0, file_rgb, NULL, NULL, NULL, NULL}}, {"RGB2", {3, 0, 0, file_rgb2, NULL, NULL, NULL, NULL}}, {"HSB", {3, 0, 0, file_hsb, NULL, NULL, NULL, NULL}}, {"HSB2", {3, 0, 0, file_hsb2, NULL, NULL, NULL, NULL}}, {"MARKSIZE", {1, 0, 0, file_marksize, NULL, NULL, NULL, NULL}}, {"MARKTYPE", {1, 0, 0, file_marktype, NULL, NULL, NULL, NULL}}, {"DRAW_RECT", {6, 0, 0, file_draw_rect, NULL, NULL, NULL, NULL}}, {"DRAW_LINE", {4, 0, 0, file_draw_line, NULL, NULL, NULL, NULL}}, {"DRAW_ARC", {DRAW_ARC_ARG_NUM, 0, 0, file_draw_arc, NULL, NULL, NULL, NULL}}, {"DRAW_MARK", {3, 0, 0, file_draw_mark, NULL, NULL, NULL, NULL}}, {"DRAW_ERRORBAR", {5, 0, 0, file_draw_errorbar, NULL, NULL, NULL, NULL}}, {"DRAW_ERRORBAR2", {5, 0, 0, file_draw_errorbar2, NULL, NULL, NULL, NULL}}, {"DRAW_POLYLINE", {2, 0, 0, file_draw_polyline, draw_polyline_arg_type, NULL, NULL, NULL}}, {"DRAW_POLYGON", {4, 0, 0, file_draw_polygon, draw_polygon_arg_type, NULL, NULL, NULL}}, }; static int add_func_sub(MathEquation *eq, struct funcs *funcs, unsigned int n) { unsigned int i; for (i = 0; i < n; i++) { if (math_equation_add_func(eq, funcs[i].name, &funcs[i].prm) == NULL) { return 1; } } return 0; } static int add_file_func(MathEquation *eq) { return add_func_sub(eq, FileFunc, sizeof(FileFunc) / sizeof(*FileFunc)); } static int add_fit_func(MathEquation *eq) { return add_func_sub(eq, FitFunc, sizeof(FitFunc) / sizeof(*FitFunc)); } static int add_basic_func(MathEquation *eq) { return add_func_sub(eq, BasicFunc, sizeof(BasicFunc) / sizeof(*BasicFunc)); } int get_axis_id(struct objlist *obj, N_VALUE *inst, struct objlist **aobj, int axis) { char *field, *axis_str; struct narray iarray; int anum, id; switch (axis) { case AXIS_X: field = "axis_x"; break; case AXIS_Y: field = "axis_y"; break; case AXIS_REFERENCE: field = "reference"; break; default: return - ERRNOAXIS; } _getobj(obj, field, inst, &axis_str); if (axis_str == NULL) { return - ERRNOAXIS; } arrayinit(&iarray, sizeof(int)); if (getobjilist(axis_str, aobj, &iarray, FALSE, NULL)) { return - ERRNOAXIS; } anum = arraynum(&iarray); if (anum < 1) { arraydel(&iarray); return - ERRNOAXISINST; } id = arraylast_int(&iarray); arraydel(&iarray); return id; } struct axis_prm { int posx, posy; int len; double min, max, min2, max2; double vx, vy, rate; int type; }; static int get_axis_prm(struct objlist *obj, N_VALUE *inst, int axis, struct axis_prm *prm) { int aid, id, dir; N_VALUE *inst1; struct objlist *aobj; double min, max, ddir; aid = get_axis_id(obj, inst, &aobj, axis); if (aid < 0) { return aid; } inst1 = getobjinst(aobj, aid); if (inst1 == NULL) { return -1; } if (_getobj(aobj, "x", inst1, &prm->posx)) { return -1; } if (_getobj(aobj, "y", inst1, &prm->posy)) { return -1; } if (_getobj(aobj, "length", inst1, &prm->len)) { return -1; } if (_getobj(aobj, "direction", inst1, &dir)) { return -1; } if (_getobj(aobj, "min", inst1, &min)) { return -1; } if (_getobj(aobj, "max", inst1, &max)) { return -1; } if (_getobj(aobj, "type", inst1, &prm->type)) { return -1; } if (min == 0 && max == 0) { id = get_axis_id(aobj, inst1, &aobj, AXIS_REFERENCE); if (id >= 0) { inst1 = getobjinst(aobj, id); if (inst1) { _getobj(aobj, "min", inst1, &min); _getobj(aobj, "max", inst1, &max); _getobj(aobj, "type", inst1, &prm->type); } } } prm->min2 = min; prm->max2 = max; ddir = dir / 18000.0 * MPI; prm->vx = cos(ddir); prm->vy = -sin(ddir); if (min == max) { return - ERRNOSETAXIS; } switch (prm->type) { case AXIS_TYPE_LOG: if (min <= 0 || max <= 0) { return - ERRMINMAX; } min = log10(min); max = log10(max); break; case AXIS_TYPE_INVERSE: if (min * max <= 0) { return - ERRMINMAX; } min = 1 / min; max = 1 / max; break; } prm->rate = prm->len / (max - min); prm->min = min; prm->max = max; return aid; } int open_array(char *objstr, struct array_prm *ary) { int i, n, dnum, id, id_max; struct narray iarray, *darray; struct objlist *dobj, *obj; dobj = getobject("darray"); ary->obj = NULL; ary->col_num = 0; ary->data_num = 0; memset(ary->id, 0, sizeof(ary->id)); memset(ary->ary, 0, sizeof(ary->ary)); if (objstr == NULL) { return 1; } arrayinit(&iarray, sizeof(int)); if (getobjilist(objstr, &obj, &iarray, FALSE, NULL)) { return 1; } if (obj != dobj) { arraydel(&iarray); return 1; } n = arraynum(&iarray); if (n < 1) { arraydel(&iarray); return 1; } if (n > FILE_OBJ_MAXCOL) { n = FILE_OBJ_MAXCOL; } id_max = chkobjlastinst(obj); for (i = 0; i < n; i++) { id = arraynget_int(&iarray, i); if (id > id_max) { continue; } darray = NULL; getobj(dobj, "@", id, 0, NULL, &darray); ary->id[i] = id; ary->ary[i] = darray; dnum = arraynum(darray); if (dnum > ary->data_num) { ary->data_num = dnum; } } arraydel(&iarray); ary->obj = obj; ary->col_num = n; return 0; } static void add_file_prm(struct f2ddata *fp, MathEquationParametar *prm) { int i, j, id, num2, *data2; N_VALUE *inst1; if (prm == NULL) { return; } for (i = 0; i < prm->id_num; i++) { id = prm->id[i] / 1000; if (id == fp->id) { if (fp->maxdim < (prm->id[i] % 1000)) { fp->maxdim = prm->id[i] % 1000; } } else if (id <= chkobjlastinst(fp->obj)) { num2 = arraynum(&(fp->fileopen)); data2 = arraydata(&(fp->fileopen)); for (j = 0; j < num2; j++) { if (id == data2[j]) { break; } } if (j == num2) { inst1 = chkobjinst(fp->obj, id); if (inst1 && _exeobj(fp->obj, "opendata_raw", inst1, 0, NULL) == 0) { arrayadd(&fp->fileopen, &id); } } } } } static struct f2ddata * opendata(struct objlist *obj,N_VALUE *inst, struct f2dlocal *f2dlocal,int axis,int raw) { int fid; char *file; struct rgba fg, bg; int x,y,type,hskip,rstep,final,csv,src; char *remark,*ifs, *array; int smoothx,smoothy,averaging_type; struct narray *mask; struct narray *move,*movex,*movey; struct f2ddata *fp; int i; int axid,ayid; int marksize,marktype; int prev_datanum; double ip1,ip2; int dataclip; struct stat stat_buf; struct axis_prm ax_prm, ay_prm; int div; double min, max; _getobj(obj, "source", inst, &src); /* for file source only */ _getobj(obj,"file",inst,&file); _getobj(obj,"remark",inst,&remark); _getobj(obj,"ifs",inst,&ifs); _getobj(obj,"csv",inst,&csv); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); /* for array source only */ _getobj(obj,"array",inst,&array); /* for range source only */ _getobj(obj,"range_min",inst,&min); _getobj(obj,"range_max",inst,&max); _getobj(obj,"range_div",inst,&div); /* common */ _getobj(obj,"id",inst,&fid); _getobj(obj,"type",inst,&type); _getobj(obj,"head_skip",inst,&hskip); _getobj(obj,"read_step",inst,&rstep); _getobj(obj,"final_line",inst,&final); _getobj(obj,"smooth_x",inst,&smoothx); _getobj(obj,"smooth_y",inst,&smoothy); _getobj(obj,"averaging_type",inst,&averaging_type); _getobj(obj,"mask",inst,&mask); _exeobj(obj,"move_data_adjust",inst,0,NULL); _getobj(obj,"move_data",inst,&move); _getobj(obj,"move_data_x",inst,&movex); _getobj(obj,"move_data_y",inst,&movey); _getobj(obj,"R",inst,&fg.r); _getobj(obj,"G",inst,&fg.g); _getobj(obj,"B",inst,&fg.b); _getobj(obj,"A",inst,&fg.a); _getobj(obj,"R2",inst,&bg.r); _getobj(obj,"G2",inst,&bg.g); _getobj(obj,"B2",inst,&bg.b); _getobj(obj,"A2",inst,&bg.a); _getobj(obj,"mark_size",inst,&marksize); _getobj(obj,"mark_type",inst,&marktype); _getobj(obj,"data_clip",inst,&dataclip); _getobj(obj,"data_num",inst,&prev_datanum); switch (src) { case DATA_SOURCE_FILE: if (file==NULL) { error(obj,ERRFILE); return NULL; } break; case DATA_SOURCE_ARRAY: break; case DATA_SOURCE_RANGE: if (min == max || div < 2) { error(obj,ERR_INVALID_RANGE); return NULL; } if (min > max) { double tmp; tmp = min; min = max; max = tmp; } break; } if (axis) { axid = get_axis_prm(obj, inst, AXIS_X, &ax_prm); if (axid < 0) { error(obj, - axid); return NULL; } ayid = get_axis_prm(obj, inst, AXIS_Y, &ay_prm); if (ayid < 0) { error(obj, - ayid); return NULL; } ip1=-ax_prm.vy*ay_prm.vx+ax_prm.vx*ay_prm.vy; ip2=-ay_prm.vy*ax_prm.vx+ay_prm.vx*ax_prm.vy; if ((fabs(ip1)<=1e-15) || (fabs(ip2)<=1e-15)) { error(obj,ERRAXISDIR); return NULL; } } else { /* these initialization exist to avoid compile warnings. */ axid =0; ayid =0; memset(&ax_prm, 0, sizeof(ax_prm)); memset(&ay_prm, 0, sizeof(ay_prm)); ax_prm.type = AXIS_TYPE_LINEAR; ay_prm.type = AXIS_TYPE_LINEAR; } if ((fp=g_malloc(sizeof(struct f2ddata)))==NULL) return NULL; fp->local = f2dlocal; fp->GC = -1; fp->src = src; switch (src) { case DATA_SOURCE_FILE: fp->file=file; if ((fp->fd=nfopen(file,"rt"))==NULL) { error2(obj,ERROPEN,file); g_free(fp); return NULL; } if (fstat(fileno(fp->fd), &stat_buf)) { error2(obj,ERROPEN,file); fclose(fp->fd); g_free(fp); return NULL; } fp->mtime = stat_buf.st_mtime; if (file==NULL) { error(obj,ERRFILE); return NULL; } break; case DATA_SOURCE_ARRAY: open_array(array, &fp->array_data); if (fp->array_data.data_num < 1) { error2(obj,ERROPEN,file); /* to be fixed */ g_free(fp); return NULL; } fp->file = NULL; fp->fd = NULL; fp->mtime = 1; break; case DATA_SOURCE_RANGE: fp->file = NULL; fp->fd = NULL; fp->range_min = min; fp->range_max = max; fp->range_div = div; fp->mtime = 1; break; } fp->obj=obj; fp->id=fid; fp->axisx = axid; fp->axisy = ayid; fp->prev_datanum = prev_datanum; #if BUF_TYPE == USE_BUF_PTR for (i = 0; i < DXBUFSIZE; i++) { fp->buf_ptr[i] = &fp->buf[i]; } #elif BUF_TYPE == USE_RING_BUF fp->ringbuf_top = 0; #endif fp->bufnum=0; fp->bufpo=0; fp->masknum=arraynum(mask); fp->mask=arraydata(mask); #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_CONST fp->mask_index = 0; #endif fp->movenum=arraynum(move); fp->move=arraydata(move); fp->movex=arraydata(movex); fp->movey=arraydata(movey); if (smoothx>smoothy) fp->smooth=smoothx; else fp->smooth=smoothy; fp->smoothx=smoothx; fp->smoothy=smoothy; fp->dataclip=dataclip; fp->averaging_type = averaging_type; fp->x=x; fp->y=y; switch (type) { case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: fp->type=TYPE_DIAGONAL; break; case PLOT_TYPE_ERRORBAR_X: fp->type=TYPE_ERR_X; break; case PLOT_TYPE_ERRORBAR_Y: fp->type=TYPE_ERR_Y; break; default: fp->type=TYPE_NORMAL; break; } fp->hskip=hskip; fp->rstep=rstep; fp->final=final; fp->remark=remark; fp->ifs=ifs; check_ifs_init(fp); fp->csv=csv; fp->line=0; fp->datanum=0; fp->num=0; fp->dline=0; fp->count=0; fp->eof=FALSE; fp->axmin=ax_prm.min; fp->axmax=ax_prm.max; fp->axmin2=ax_prm.min2; fp->axmax2=ax_prm.max2; fp->axvx=ax_prm.vx; fp->axvy=ax_prm.vy; fp->axtype=ax_prm.type; fp->axposx=ax_prm.posx; fp->axposy=ax_prm.posy; fp->axlen=ax_prm.len; fp->aymin=ay_prm.min; fp->aymax=ay_prm.max; fp->aymin2=ay_prm.min2; fp->aymax2=ay_prm.max2; fp->ayvx=ay_prm.vx; fp->ayvy=ay_prm.vy; fp->aytype=ay_prm.type; fp->ayposx=ay_prm.posx; fp->ayposy=ay_prm.posy; fp->aylen=ay_prm.len; fp->ratex=ax_prm.rate; fp->ratey=ay_prm.rate; fp->interrupt = FALSE; for (i = 0; i < (int) (sizeof(fp->codex) / sizeof(*fp->codex)); i++) { fp->codex[i] = f2dlocal->codex[i]; } for (i = 0; i < (int) (sizeof(fp->codey) / sizeof(*fp->codey)); i++) { fp->codey[i] = f2dlocal->codey[i]; } fp->const_id = f2dlocal->const_id; fp->column_array_id_x = -1; fp->column_array_id_y = -1; fp->use_column_array = FALSE; switch (fp->type) { case TYPE_NORMAL: break; case TYPE_DIAGONAL: x++; y++; break; case TYPE_ERR_X: x+=2; break; case TYPE_ERR_Y: y+=2; break; } fp->maxdim=f2dlocal->maxdimx; if (fp->maxdimmaxdim=x; if (fp->maxdimmaxdimy) fp->maxdim=f2dlocal->maxdimy; if (fp->maxdimmaxdim=y; if (f2dlocal->need2passx || f2dlocal->need2passy) fp->need2pass=TRUE; else fp->need2pass=FALSE; fp->bg=bg; fp->color2=bg; fp->fnumx = 0; fp->needx = NULL; fp->fnumy = 0; fp->needy = NULL; fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_UNDEF; fp->fg=fg; fp->color=fp->fg; fp->marksize0=marksize; fp->marksize=marksize; fp->marktype0=marktype; fp->marktype=marktype; fp->ignore=fp->negative=FALSE; arrayinit(&(fp->fileopen),sizeof(int)); if (!raw) { MathEquationParametar *prm; if (fp->codex[0] && fp->codex[0]->exp) { prm = math_equation_get_parameter(fp->codex[0], 'F', NULL); if (prm) { fp->fnumx = prm->id_num; fp->needx = prm->id; } add_file_prm(fp, prm); } if (fp->codey[0] && fp->codey[0]->exp) { prm = math_equation_get_parameter(fp->codey[0], 'F', NULL); if (prm) { fp->fnumy = prm->id_num; fp->needy = prm->id; } add_file_prm(fp, prm); } fp->column_array_id_x = f2dlocal->column_array_id_x; fp->column_array_id_y = f2dlocal->column_array_id_y; fp->use_column_array = (f2dlocal->column_array_id_x >=0 || f2dlocal->column_array_id_y >= 0); } return fp; } static void reopendata(struct f2ddata *fp) { if (fp->fd) { fseek(fp->fd,0,SEEK_SET); } fp->bufnum=0; fp->bufpo=0; fp->line=0; fp->prev_datanum = fp->datanum; fp->datanum=0; #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_CONST fp->mask_index = 0; #endif fp->dline=0; fp->count=0; fp->eof=FALSE; fp->interrupt = FALSE; fp->ignore=fp->negative=FALSE; fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_UNDEF; fp->color2=fp->bg; fp->color=fp->fg; fp->marksize=fp->marksize0; fp->marktype=fp->marktype0; } static void closedata(struct f2ddata *fp, struct f2dlocal *f2dlocal) { int j,num2,*data2; N_VALUE *inst1,*inst; if (fp==NULL) return; set_data_progress(fp); num2=arraynum(&(fp->fileopen)); data2=arraydata(&(fp->fileopen)); for (j=0;jobj,data2[j]))!=NULL) { _exeobj(fp->obj,"closedata_raw",inst1,0,NULL); } } arraydel(&(fp->fileopen)); if (fp->fd) { fclose(fp->fd); } if ((inst=chkobjinst(fp->obj,fp->id))!=NULL) _putobj(fp->obj,"data_num",inst,&(fp->datanum)); f2dlocal->num = fp->datanum; g_free(fp); } static char * create_func_def_str(const char *name, const char *code) { return g_strdup_printf("def %s(x,y,z) {%s;}", name, code); } static int set_user_fnc(MathEquation **eq, const char *str, const char *fname, char **err_msg) { int r, i; char *buf, default_func[] = "def f(x,y,z){0}"; // 01234 if (err_msg) *err_msg = NULL; for (i = 0; i < EQUATION_NUM; i++) { if (eq[i] == NULL) { return MATH_ERROR_MEMORY; } } default_func[4] = fname[0]; if (str) { buf = create_func_def_str(fname, str); if (buf == NULL) return MATH_ERROR_MEMORY; for (i = 0; i < EQUATION_NUM; i++) { r = math_equation_parse(eq[i], buf); if (r) { if (err_msg) { *err_msg = math_err_get_error_message(eq[i], buf, r); } g_free(buf); return r; } } g_free(buf); } else { for (i = 0; i < EQUATION_NUM; i++) { math_equation_parse(eq[i], default_func); } } return 0; } static int set_equation(struct f2dlocal *f2dlocal, MathEquation **eq, const char *f, const char *g, const char *h, const char *str, char **err_msg) { int i, rcode; if (err_msg) { *err_msg = NULL; } for (i = 0; i < EQUATION_NUM; i++) { if (eq[i]) { math_equation_free(eq[i]); } eq[i] = NULL; } for (i = 0; i < EQUATION_NUM; i++) { eq[i] = ofile_create_math_equation(f2dlocal->const_id, 3, TRUE, TRUE, TRUE, TRUE, TRUE); } for (i = 0; i < EQUATION_NUM; i++) { if (eq[i] == NULL) { return MATH_ERROR_MEMORY; } } if (f) { rcode = set_user_fnc(eq, f, "f", err_msg); if (rcode) return rcode; } if (g) { rcode = set_user_fnc(eq, g, "g", err_msg); if (rcode) return rcode; } if (h) { rcode = set_user_fnc(eq, h, "h", err_msg); if (rcode) return rcode; } if (str == NULL) return 0; for (i = 0; i < EQUATION_NUM; i++) { rcode = math_equation_parse(eq[i], str); if (rcode) { if (err_msg) { *err_msg = math_err_get_error_message(eq[i], str, rcode); } return rcode; } } return rcode; } static int put_func(struct objlist *obj, N_VALUE *inst, struct f2dlocal *f2dlocal, char *field, char *eq) { int rcode, type; char *x, *y, *f, *g, *h, *err_msg; type = field[5]; _getobj(obj, "math_x", inst, &x); _getobj(obj, "math_y", inst, &y); _getobj(obj, "func_f", inst, &f); _getobj(obj, "func_g", inst, &g); _getobj(obj, "func_h", inst, &h); switch (type) { case 'x': f2dlocal->need2passx = FALSE; rcode = set_equation(f2dlocal, f2dlocal->codex, f, g, h, eq, &err_msg); if (err_msg) { error22(obj, ERRUNKNOWN, field, err_msg); g_free(err_msg); set_equation(f2dlocal, f2dlocal->codex, f, g, h, x, NULL); } f2dlocal->need2passx = math_equation_check_const(f2dlocal->codex[0], f2dlocal->const_id, TWOPASS_CONST_SIZE); break; case 'y': f2dlocal->need2passy = FALSE; rcode = set_equation(f2dlocal, f2dlocal->codey, f, g, h, eq, &err_msg); if (err_msg) { error22(obj, ERRUNKNOWN, field, err_msg); g_free(err_msg); set_equation(f2dlocal, f2dlocal->codey, f, g, h, y, NULL); } f2dlocal->need2passy = math_equation_check_const(f2dlocal->codey[0], f2dlocal->const_id, TWOPASS_CONST_SIZE); break; case 'f': case 'g': case 'h': switch (type) { case 'f': rcode = set_equation(f2dlocal, f2dlocal->codex, eq, g, h, x, NULL); rcode = set_equation(f2dlocal, f2dlocal->codey, eq, g, h, y, &err_msg); break; case 'g': rcode = set_equation(f2dlocal, f2dlocal->codex, f, eq, h, x, NULL); rcode = set_equation(f2dlocal, f2dlocal->codey, f, eq, h, y, &err_msg); break; case 'h': rcode = set_equation(f2dlocal, f2dlocal->codex, f, g, eq, x, NULL); rcode = set_equation(f2dlocal, f2dlocal->codey, f, g, eq, y, &err_msg); break; default: /* never reached */ return 1; } if (err_msg) { error22(obj, ERRUNKNOWN, field, err_msg); g_free(err_msg); } if (rcode) { set_equation(f2dlocal, f2dlocal->codex, f, g, h, x, NULL); set_equation(f2dlocal, f2dlocal->codey, f, g, h, y, NULL); } f2dlocal->need2passx = math_equation_check_const(f2dlocal->codex[0], f2dlocal->const_id, TWOPASS_CONST_SIZE); f2dlocal->need2passy = math_equation_check_const(f2dlocal->codey[0], f2dlocal->const_id, TWOPASS_CONST_SIZE); break; default: /* never reached */ return 1; } return rcode; } static int f2dputmath(struct objlist *obj,N_VALUE *inst,char *field,char *math) { int rcode; struct f2dlocal *f2dlocal; _getobj(obj,"_local",inst,&f2dlocal); if (math) { g_strstrip(math); if (math[0] == '\0') { math = NULL; } } rcode = put_func(obj, inst, f2dlocal, field, math); if (rcode) { return 1; } if (strcmp(field,"math_x")==0) { f2dlocal->column_array_id_x = -1; f2dlocal->maxdimx = 0; if (f2dlocal->codex[0]) { MathEquationParametar *prm; int array_id; prm = math_equation_get_parameter(f2dlocal->codex[0], 0, NULL); if (prm == NULL) { return 1; } f2dlocal->maxdimx = prm->id_max; array_id = math_equation_check_array(f2dlocal->codex[0], COLUMN_ARRAY_NAME); f2dlocal->column_array_id_x = array_id; } } else if (strcmp(field,"math_y")==0) { f2dlocal->column_array_id_y = -1; f2dlocal->maxdimy = 0; if (f2dlocal->codey[0]) { MathEquationParametar *prm; int array_id; prm = math_equation_get_parameter(f2dlocal->codey[0], 0, NULL); if (prm == NULL) { return 1; } f2dlocal->maxdimy = prm->id_max; array_id = math_equation_check_array(f2dlocal->codey[0], COLUMN_ARRAY_NAME); f2dlocal->column_array_id_y = array_id; } } return 0; } static int set_math_config(struct objlist *obj, N_VALUE *inst, char *field, char *str) { char *f1; int len; f1 = getitok2(&str, &len, ""); if (f2dputmath(obj, inst, field, f1) == 0) { _putobj(obj, field, inst, f1); } else { g_free(f1); } return 0; } static int f2dloadconfig(struct objlist *obj,N_VALUE *inst) { return obj_load_config(obj, inst, F2DCONF, FileConfigHash); } static int f2dsaveconfig(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { return obj_save_config(obj, inst, F2DCONF, FileConfig, sizeof(FileConfig) / sizeof(*FileConfig)); } MathEquation * ofile_create_math_equation(int *id, int prm_digit, int use_fprm, int use_const, int usr_func, int use_fobj_func, int use_fit_func) { MathEquation *code; unsigned int i; int f_id; char *file_constant[MATH_CONST_SIZE] = { "NUM", "MINX", "MAXX", "MINY", "MAXY", "SUMX", "SUMY", "SUMXX", "SUMYY", "SUMXY", "AVX", "AVY", "SGX", "SGY", "STDEVPX", "STDEVPY", "STDEVX", "STDEVY", /* TWOPASS_CONST */ "MASK", "MOVE", "FIRST", "COLX", "COLY", "AXISX", "AXISX_MIN", "AXISX_MAX", "AXISX_LEN", "AXISY", "AXISY_MIN", "AXISY_MAX", "AXISY_LEN", "HSKIP", "RSTEP", "FLINE", "DATA_OBJ", "FILE_OBJ", "PATH_OBJ", "RECT_OBJ", "ARC_OBJ", "MARK_OBJ", "TEXT_OBJ", "%D", "%N", }; struct math_const_parameter static_const[] = { {"FILL_RULE_NONE", MATH_SCANNER_VAL_TYPE_NORMAL, {GRA_FILL_MODE_NONE, MATH_VALUE_NORMAL}}, {"FILL_RULE_EVEN_ODD", MATH_SCANNER_VAL_TYPE_NORMAL, {GRA_FILL_MODE_EVEN_ODD, MATH_VALUE_NORMAL}}, {"FILL_RULE_WINDING", MATH_SCANNER_VAL_TYPE_NORMAL, {GRA_FILL_MODE_WINDING, MATH_VALUE_NORMAL}}, }; code = math_equation_basic_new(); if (code == NULL) return NULL; if (prm_digit > 0) { if (math_equation_add_parameter(code, 0, 1, prm_digit, MATH_EQUATION_PARAMETAR_USE_ID)) { math_equation_free(code); return NULL; } } if (use_fprm) { if (math_equation_add_parameter(code, 'F', 3, 5, MATH_EQUATION_PARAMETAR_USE_INDEX)) { math_equation_free(code); return NULL; } } if (math_equation_add_var(code, "X") != 0) { math_equation_free(code); return NULL; } if (math_equation_add_var(code, "Y") != 1) { math_equation_free(code); return NULL; } if (use_const) { for (i = 0; i < MATH_CONST_SIZE; i++) { f_id = math_equation_add_const(code, file_constant[i], NULL); if (f_id < 0) { math_equation_free(code); return NULL; } if (id) { id[i] = f_id; } } for (i = 0; i < sizeof(static_const) / sizeof(*static_const); i++) { if (math_equation_add_const(code, static_const[i].str, &static_const[i].val) < 0) { math_equation_free(code); return NULL; } } } if (usr_func) { math_equation_parse(code, "def f(x,y,z){0}"); math_equation_parse(code, "def g(x,y,z){0}"); math_equation_parse(code, "def h(x,y,z){0}"); } if (use_fobj_func) { add_file_func(code); } if (use_fit_func) { add_fit_func(code); } add_basic_func(code); return code; } static int f2dinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y,rstep,final,msize,r2,g2,b2,a2,lwidth,miter,src,div; char *s1,*s2,*s3,*s4; struct f2dlocal *f2dlocal; int stat,minmaxstat,dataclip,num,ljoin; double min,max; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; src=DATA_SOURCE_FILE; x=1; y=2; rstep=1; final=-1; msize=DEFAULT_MARK_SIZE; lwidth=DEFAULT_LINE_WIDTH; r2=255; g2=255; b2=255; a2=255; miter=1000; num=0; stat=MATH_VALUE_MEOF; minmaxstat=MATH_VALUE_UNDEF; dataclip=TRUE; ljoin = JOIN_TYPE_BEVEL; div = 512; min = 1; max = 10; if (_putobj(obj,"source",inst,&src)) return 1; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (_putobj(obj,"read_step",inst,&rstep)) return 1; if (_putobj(obj,"final_line",inst,&final)) return 1; if (_putobj(obj,"mark_size",inst,&msize)) return 1; if (_putobj(obj,"R2",inst,&r2)) return 1; if (_putobj(obj,"G2",inst,&g2)) return 1; if (_putobj(obj,"B2",inst,&b2)) return 1; if (_putobj(obj,"A2",inst,&a2)) return 1; if (_putobj(obj,"line_width",inst,&lwidth)) return 1; if (_putobj(obj,"line_miter_limit",inst,&miter)) return 1; if (_putobj(obj,"line_join",inst,&ljoin)) return 1; if (_putobj(obj,"data_num",inst,&num)) return 1; if (_putobj(obj,"stat_x",inst,&stat)) return 1; if (_putobj(obj,"stat_y",inst,&stat)) return 1; if (_putobj(obj,"stat_2",inst,&stat)) return 1; if (_putobj(obj,"stat_3",inst,&stat)) return 1; if (_putobj(obj,"stat_minx",inst,&minmaxstat)) return 1; if (_putobj(obj,"stat_maxx",inst,&minmaxstat)) return 1; if (_putobj(obj,"stat_miny",inst,&minmaxstat)) return 1; if (_putobj(obj,"stat_maxy",inst,&minmaxstat)) return 1; if (_putobj(obj,"data_clip",inst,&dataclip)) return 1; if (_putobj(obj,"range_min",inst,&min)) return 1; if (_putobj(obj,"range_max",inst,&max)) return 1; if (_putobj(obj,"range_div",inst,&div)) return 1; s1 = s2 = s3 = s4 = NULL; f2dlocal=NULL; s1 = g_strdup("#%'"); if (s1 == NULL) goto errexit; if (_putobj(obj, "remark", inst, s1)) goto errexit; s2 = g_strdup(" ,\t()"); if (s2 == NULL) goto errexit; if (_putobj(obj, "ifs", inst, s2)) goto errexit; s3 = g_strdup("axis:0"); if (s3 == NULL) goto errexit; if (_putobj(obj, "axis_x", inst, s3)) goto errexit; s4 = g_strdup("axis:1"); if (s4 == NULL) goto errexit; if (_putobj(obj, "axis_y", inst, s4)) goto errexit; f2dlocal=g_malloc(sizeof(struct f2dlocal)); if (f2dlocal == NULL) goto errexit; memset(f2dlocal, 0, sizeof(struct f2dlocal)); if (_putobj(obj,"_local",inst,f2dlocal)) goto errexit; f2dlocal->codex[0] = NULL; f2dlocal->codex[1] = NULL; f2dlocal->codex[2] = NULL; f2dlocal->codey[0] = NULL; f2dlocal->codey[1] = NULL; f2dlocal->codey[2] = NULL; f2dlocal->column_array_id_x = -1; f2dlocal->column_array_id_y = -1; f2dlocal->maxdimx=0; f2dlocal->maxdimy=0; f2dlocal->need2passx=FALSE; f2dlocal->need2passy=FALSE; f2dlocal->data=NULL; f2dlocal->idx=chkobjoffset(obj,"data_x"); f2dlocal->idy=chkobjoffset(obj,"data_y"); f2dlocal->id2=chkobjoffset(obj,"data_2"); f2dlocal->id3=chkobjoffset(obj,"data_3"); f2dlocal->icx=chkobjoffset(obj,"coord_x"); f2dlocal->icy=chkobjoffset(obj,"coord_y"); f2dlocal->ic2=chkobjoffset(obj,"coord_2"); f2dlocal->ic3=chkobjoffset(obj,"coord_3"); f2dlocal->isx=chkobjoffset(obj,"stat_x"); f2dlocal->isy=chkobjoffset(obj,"stat_y"); f2dlocal->is2=chkobjoffset(obj,"stat_2"); f2dlocal->is3=chkobjoffset(obj,"stat_3"); f2dlocal->iline=chkobjoffset(obj,"line"); f2dlocal->storefd=NULL; f2dlocal->endstore=FALSE; f2dlocal->use_drawing_func = FALSE; f2dlocal->sumx = 0; f2dlocal->sumy = 0; f2dlocal->sumxx = 0; f2dlocal->sumyy = 0; f2dlocal->sumxy = 0; f2dlocal->dminx = HUGE_VAL; f2dlocal->dmaxx = HUGE_VAL; f2dlocal->dminy = HUGE_VAL; f2dlocal->dmaxy = HUGE_VAL; f2dlocal->davx = HUGE_VAL; f2dlocal->davy = HUGE_VAL; f2dlocal->dstdevpx = HUGE_VAL; f2dlocal->dstdevpy = HUGE_VAL; f2dlocal->dstdevx = HUGE_VAL; f2dlocal->dstdevy = HUGE_VAL; f2dlocal->num = 0; f2dlocal->rcode = 0; f2dlocal->minx.val = 0; f2dlocal->maxx.val = 0; f2dlocal->miny.val = 0; f2dlocal->maxy.val = 0; f2dlocal->minx.type = MATH_VALUE_UNDEF; f2dlocal->maxx.type = MATH_VALUE_UNDEF; f2dlocal->miny.type = MATH_VALUE_UNDEF; f2dlocal->maxy.type = MATH_VALUE_UNDEF; f2dlocal->mtime = 0; f2dlocal->mtime_stat = 0; f2dlocal->total_line = 0; f2dloadconfig(obj,inst); return 0; errexit: g_free(s1); g_free(s2); g_free(s3); g_free(s4); g_free(f2dlocal); return 1; } static int f2ddone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&f2dlocal); closedata(f2dlocal->data, f2dlocal); math_equation_free(f2dlocal->codex[0]); math_equation_free(f2dlocal->codex[1]); math_equation_free(f2dlocal->codex[2]); math_equation_free(f2dlocal->codey[0]); math_equation_free(f2dlocal->codey[1]); math_equation_free(f2dlocal->codey[2]); return 0; } static int f2dfile(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct objlist *sys; int ignorepath; char *file, *file2; int num2; struct f2dlocal *f2dlocal; _getobj(obj, "_local", inst, &f2dlocal); f2dlocal->mtime = 0; f2dlocal->mtime_stat = 0; sys=getobject("system"); getobj(sys, "ignore_path", 0, 0, NULL, &ignorepath); num2 = 0; _putobj(obj, "data_num", inst, &num2); if (argv[2] == NULL) { return 0; } file = get_utf8_filename(argv[2]); g_free(argv[2]); if (file == NULL) { argv[2] = NULL; return 1; } if (ignorepath) { file2 = getbasename(file); g_free(file); argv[2] = file2; } else { argv[2] = file; } return 0; } static int f2dbasename(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *file,*file2; g_free(rval->str); rval->str=NULL; _getobj(obj,"file",inst,&file); if (file==NULL) return 0; file2=getbasename(file); rval->str=file2; return 0; } static int f2dput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; char *math; struct f2dlocal *f2dlocal; _getobj(obj,"_local",inst,&f2dlocal); f2dlocal->mtime = 0; f2dlocal->mtime_stat = 0; field=argv[1]; if (strcmp(field,"final_line")==0) { #if 0 if (*(int *)(argv[2])<-1) *(int *)(argv[2])=-1; #endif } else if ((strcmp(field,"x")==0) || (strcmp(field,"y")==0)) { if (*(int *)(argv[2])<0) *(int *)(argv[2])=0; else if (*(int *)(argv[2])>FILE_OBJ_MAXCOL) *(int *)(argv[2])=FILE_OBJ_MAXCOL; } else if ((strcmp(field,"math_x")==0) || (strcmp(field,"math_y")==0) || (strcmp(field,"func_f")==0) || (strcmp(field,"func_g")==0) || (strcmp(field,"func_h")==0)) { math=(char *)(argv[2]); return f2dputmath(obj,inst,field,math); } else if (strcmp(field,"ifs")==0) { if (strlen((char *)argv[2])==0) { error(obj,ERRIFS); return 1; } } else if ((strcmp(field,"smooth_x")==0) || (strcmp(field,"smooth_y")==0)) { if (*(int *)(argv[2])<0) *(int *)(argv[2])=0; else if (*(int *)(argv[2])>FILE_OBJ_SMOOTH_MAX) *(int *)(argv[2])=FILE_OBJ_SMOOTH_MAX; } return 0; } #define ACCEPT_PARTIAL_VAL 0 static double get_value_from_str(char *po, char *po2, int *type) { char *endptr; int st, ch; double val; if (po == po2) { *type = MATH_VALUE_NONUM; return 0; } ch = *po2; *po2 = '\0'; val = strtod(po, &endptr); *po2 = ch; if (endptr >= po2) { if (check_infinite(val)) { st = MATH_VALUE_NAN; } else { st = MATH_VALUE_NORMAL; } } else if (endptr != po) { if (g_ascii_isspace(*endptr)) { if (check_infinite(val)) { st = MATH_VALUE_NAN; } else { st = MATH_VALUE_NORMAL; } } else { st = MATH_VALUE_NONUM; } } else { char *top, *bottom; top = po; bottom = po2; for (; top < bottom; top++) { if (! g_ascii_isspace(*top)) { break; } } for (; top < bottom; bottom--) { if (! g_ascii_isspace(*(bottom - 1))) { break; } } switch (bottom - top) { case 1: switch (*top) { case '|': st = MATH_VALUE_CONT; break; case '=': st = MATH_VALUE_BREAK; break; default: st = MATH_VALUE_NONUM; } break; case 3: if (strncmp(top, "NAN", 3) == 0) { st = MATH_VALUE_NAN; } else { st = MATH_VALUE_NONUM; } break; case 4: if (strncmp(top, "CONT", 4) == 0) { st = MATH_VALUE_CONT; } else { st = MATH_VALUE_NONUM; } break; case 5: if (strncmp(top, "UNDEF", 5) == 0) { st = MATH_VALUE_UNDEF; } else if (strncmp(top, "BREAK", 5) == 0) { st = MATH_VALUE_BREAK; } else { st = MATH_VALUE_NONUM; } break; default: st = MATH_VALUE_NONUM; } } *type = st; return val; } static void column_array_clear(MathEquation **code, int id) { int j; if (id < 0) { return; } for (j = 0; j < EQUATION_NUM; j++) { math_equation_clear_array(code[j], id); } } static void column_array_push(MathEquation **code, int id, MathValue *val) { int j; if (id < 0) { return; } for (j = 0; j < EQUATION_NUM; j++) { math_equation_push_array_val(code[j], id, val); } } static int getdataarray(struct f2ddata *fp, char *buf, int maxdim, MathValue *data) { /* return: 0 no error -1 fatal error 1 too small column */ char *po, *po2; int st; double val; int i, r; int dim, hex; char *ifs, csv; MathValue v; ifs = fp->ifs_buf; csv = fp->csv; fp->count++; r = 1; dim=0; data[dim].val = fp->count; data[dim].type = MATH_VALUE_NORMAL; po=buf; if (fp->use_column_array) { column_array_clear(fp->codex, fp->column_array_id_x); column_array_clear(fp->codey, fp->column_array_id_y); column_array_push(fp->codex, fp->column_array_id_x, data); column_array_push(fp->codey, fp->column_array_id_y, data); } while (*po!='\0') { hex = FALSE; if (! fp->use_column_array && dim >= maxdim) { r = 0; break; } if (csv) { for (;*po==' ';po++); if (*po=='\0') break; if (CHECK_IFS(ifs, *po)) { po2=po; po2++; val=0; st=MATH_VALUE_NONUM; } else { #if 0 for (po2=po;(*po2!='\0') && ! CHECK_IFS(ifs, *po2) && (*po2!=' ');po2++) *po2=toupper(*po2); for (i=0;iuse_column_array) { column_array_push(fp->codex, fp->column_array_id_x, &v); column_array_push(fp->codey, fp->column_array_id_y, &v); } } for (i=dim+1;i<=maxdim;i++) { data[i].val = 0; data[i].type = MATH_VALUE_NONUM; } return r; } static int hskipdata(struct f2ddata *fp) { int skip,rcode; char *buf; switch (fp->src) { case DATA_SOURCE_FILE: skip=0; while (skiphskip) { if ((fp->line & UPDATE_PROGRESS_LINE_NUM) == 0 && set_data_progress(fp)) { return 0; } rcode=fgetline(fp->fd,&buf); if (rcode==-1) return -1; if (rcode==1) { fp->eof=TRUE; return 0; } g_free(buf); fp->line++; skip++; } break; case DATA_SOURCE_ARRAY: if (fp->hskip > fp->array_data.data_num) { fp->eof=TRUE; return 0; } fp->line = fp->hskip; break; case DATA_SOURCE_RANGE: if (fp->hskip > fp->range_div) { fp->eof = TRUE; return 0; } fp->line = fp->hskip; break; } return 0; } static int set_data_progress(struct f2ddata *fp) { char msgbuf[32]; double frac; if (fp->final > 0) { frac = 1.0 * fp->line / fp->final; } else if (fp->prev_datanum > 0) { if (fp->datanum <= fp->prev_datanum) { if (fp->line < fp->hskip) { frac = 1.0 * fp->line / (fp->prev_datanum + fp->hskip); } else { frac = 1.0 * (fp->datanum + fp->bufnum + fp->hskip) / (fp->prev_datanum + fp->hskip); } } else { frac = -1; } } else { frac = -1; } if (frac > 1) { frac = 1.0; } snprintf(msgbuf, sizeof(msgbuf), "id:%d (%d)", fp->id, fp->line); set_progress(0, msgbuf, frac); if (ninterrupt() || fp->interrupt) { fp->eof=TRUE; fp->interrupt = TRUE; return TRUE; } return FALSE; } static void getdata_get_other_files(struct f2ddata *fp, int fnumx, int fnumy, int *needx, int *needy, MathValue *datax, MathValue *datay, int filenum, int *openfile) { int *idata,inum,argc; char *argv[2]; int i,j,k; double *ddata; int colnum; N_VALUE *inst1; struct narray iarray; int id,col; struct narray *coldata; for (i = 0; i < filenum; i++) { id = openfile[i]; arrayinit(&iarray,sizeof(int)); for (j = 0; j < fnumx; j++) { if (needx[j] / 1000 == id) { col = needx[j] % 1000; arrayadd(&iarray, &col); } } for (j = 0; j < fnumy; j++) { if (needy[j] / 1000 == id) { col = needy[j] % 1000; arrayadd(&iarray, &col); } } inum = arraynum(&iarray); idata = arraydata(&iarray); argv[0] = (char *)&iarray; argv[1] = NULL; argc=1; if ((inst1 = chkobjinst(fp->obj, id)) && _exeobj(fp->obj, "getdata_raw", inst1, argc, argv) == 0) { _getobj(fp->obj,"getdata_raw", inst1, &coldata); colnum = arraynum(coldata); ddata = arraydata(coldata); if (colnum == inum * 2) { int n; for (j = 0; j < fnumx; j++) { if (needx[j] / 1000 == id) { n = needx[j] % 1000; for (k = 0; k < inum; k++) { if (idata[k] == n) { datax[j].val = ddata[k]; datax[j].type = nround(ddata[k + inum]); } } } } for (j = 0; j < fnumy; j++) { if (needy[j] / 1000 == id) { n = needy[j] % 1000; for (k = 0; k < inum; k++){ if (idata[k] == n) { datay[j].val = ddata[k]; datay[j].type = nround(ddata[k + inum]); } } } } } } arraydel(&iarray); } } static int getdata_skip_step(struct f2ddata *fp, int progress) { char *buf; int i, step, rcode; rcode = 0; switch (fp->src) { case DATA_SOURCE_FILE: step = 1; while (step < fp->rstep) { if (progress && (fp->line & UPDATE_PROGRESS_LINE_NUM) == 0 && set_data_progress(fp)) { return 1; } rcode = fgetline(fp->fd, &buf); if (rcode == 1) { fp->eof = TRUE; g_free(buf); break; } else if (rcode == -1) { g_free(buf); return -1; } fp->line++; for (i = 0; buf[i] != '\0' && CHECK_IFS(fp->ifs_buf, buf[i]); i++); if (buf[i] != '\0' && (! CHECK_REMARK(fp->remark, fp->ifs_buf, buf[i]))) { step++; } g_free(buf); } break; case DATA_SOURCE_ARRAY: if (fp->line + fp->rstep - 1 > fp->array_data.data_num) { fp->eof = TRUE; } else { fp->line += fp->rstep - 1; } break; case DATA_SOURCE_RANGE: if (fp->line + fp->rstep - 1 > fp->range_div) { fp->eof = TRUE; } else { fp->line += fp->rstep - 1; } break; } return 0; } #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_CONST static int search_mask(int *mask, int n, int *index, int line) { int i; i = *index; if (mask == NULL || i >= n) return FALSE; if (mask[i] < line) { for (; i < n; i++) { if (mask[i] >= line) break; } } if (i == n) { *index = n; return FALSE; } if (mask[i] > line) { *index = i; return FALSE; } else if (mask[i] < line) { *index = n; return FALSE; } *index = i + 1; return TRUE; } #endif static void set_var(MathEquation *eq, const MathValue *x, const MathValue *y) { math_equation_set_var(eq, 0, x); math_equation_set_var(eq, 1, y); } struct obj_name_const { char *obj_name; int const_id; }; static int set_const(MathEquation *eq, int *const_id, int need2pass, struct f2ddata *fp, int first) { struct obj_name_const obj_names[] = { {"data", MATH_CONST_DATA_OBJ}, {"file", MATH_CONST_FILE_OBJ}, {"path", MATH_CONST_PATH_OBJ}, {"rectangle", MATH_CONST_RECT_OBJ}, {"arc", MATH_CONST_ARC_OBJ}, {"mark", MATH_CONST_MARK_OBJ}, {"text", MATH_CONST_TEXT_OBJ}, }; MathValue val; int i; double tmp; if (eq == NULL || eq->exp == NULL) return 0; math_equation_clear(eq); if (need2pass) { math_equation_set_const(eq, const_id[MATH_CONST_MINX], &fp->minx); math_equation_set_const(eq, const_id[MATH_CONST_MINY], &fp->miny); math_equation_set_const(eq, const_id[MATH_CONST_MAXX], &fp->maxx); math_equation_set_const(eq, const_id[MATH_CONST_MAXY], &fp->maxy); val.val = fp->num; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_NUM], &val); val.val = fp->sumx; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SUMX], &val); val.val = fp->sumy; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SUMY], &val); val.val = fp->sumxx; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SUMXX], &val); val.val = fp->sumyy; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SUMYY], &val); val.val = fp->sumxy; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SUMXY], &val); if (fp->num > 0) { val.val = fp->sumx / fp->num; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AVX], &val); val.val = fp->sumy / fp->num; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AVY], &val); tmp = fp->sumxx / fp->num - (fp->sumx / fp->num) * (fp->sumx / fp->num); val.val = (tmp < 0) ? 0 : sqrt(tmp); val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SGX], &val); math_equation_set_const(eq, const_id[MATH_CONST_STDEVPX], &val); tmp = fp->sumyy / fp->num - (fp->sumy / fp->num) * (fp->sumy / fp->num); val.val = (tmp < 0) ? 0 : sqrt(tmp); val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_SGY], &val); math_equation_set_const(eq, const_id[MATH_CONST_STDEVPY], &val); } if (fp->num > 1) { double n; n = fp->num; tmp = fp->sumxx / (n - 1) - (fp->sumx / (n - 1)) * (fp->sumx / n); val.val = (tmp < 0) ? 0 : sqrt(tmp); val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_STDEVX], &val); tmp = fp->sumyy / (n - 1) - (fp->sumy / (n - 1)) * (fp->sumy / n); val.val = (tmp < 0) ? 0 : sqrt(tmp); val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_STDEVY], &val); } } val.val = chkobjlastinst(fp->obj) + 1; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_N], &val); val.val = fp->id; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_D], &val); val.val = first; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_FIRST], &val); val.val = fp->x; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_COLX], &val); val.val = fp->y; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_COLY], &val); val.val = fp->axisx; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISX], &val); val.val = fp->axmin2; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISX_MIN], &val); val.val = fp->axmax2; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISX_MAX], &val); val.val = fp->axlen; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISX_LEN], &val); val.val = fp->axisy; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISY], &val); val.val = fp->aymin2; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISY_MIN], &val); val.val = fp->aymax2; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISY_MAX], &val); val.val = fp->aylen; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_AXISY_LEN], &val); val.val = fp->masknum; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_MASK], &val); val.val = fp->movenum; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_MOVE], &val); val.val = fp->hskip; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_HSKIP], &val); val.val = fp->rstep; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_RSTEP], &val); getobj(fp->obj, "final_line", fp->id, 0, NULL, &i); val.val = i; val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[MATH_CONST_FLINE], &val); for (i = 0; i < (int) (sizeof(obj_names) / sizeof(*obj_names)); i++) { struct objlist *obj; obj = chkobject(obj_names[i].obj_name); if (obj == NULL) { continue; } val.val = chkobjectid(obj); val.type = MATH_VALUE_NORMAL; math_equation_set_const(eq, const_id[obj_names[i].const_id], &val); } return math_equation_optimize(eq); } static int set_const_all(struct f2ddata *fp) { int first_x1, first_y1; if (set_const(fp->codex[0], fp->const_id, fp->need2pass, fp, TRUE)) return 1; if (set_const(fp->codey[0], fp->const_id, fp->need2pass, fp, TRUE)) return 1; switch (fp->type) { case TYPE_NORMAL: first_x1 = FALSE; first_y1 = FALSE; break; case TYPE_DIAGONAL: first_x1 = FALSE; first_y1 = FALSE; break; case TYPE_ERR_X: first_x1 = TRUE; first_y1 = FALSE; break; case TYPE_ERR_Y: first_x1 = FALSE; first_y1 = TRUE; break; default: first_x1 = FALSE; first_y1 = FALSE; } if (set_const(fp->codex[1], fp->const_id, fp->need2pass, fp, first_x1)) return 1; if (set_const(fp->codex[2], fp->const_id, fp->need2pass, fp, FALSE)) return 1; if (set_const(fp->codey[1], fp->const_id, fp->need2pass, fp, first_y1)) return 1; if (set_const(fp->codey[2], fp->const_id, fp->need2pass, fp, FALSE)) return 1; return 0; } static int file_calculate(struct f2ddata *fp, MathEquation *eq, const MathValue *x, const MathValue *y, MathValue *prm, MathValue *fprm, MathValue *val) { int r; if (eq == NULL || eq->exp == NULL) return 0; math_equation_set_parameter_data(eq, 0, prm); math_equation_set_parameter_data(eq, 'F', fprm); set_var(eq, x, y); math_equation_set_user_data(eq, fp); r = math_equation_calculate(eq, val); if (val->type == MATH_VALUE_INTERRUPT) { fp->interrupt = TRUE; } return r; } static int getdata_sub2(struct f2ddata *fp, int fnumx, int fnumy, int *needx, int *needy, MathValue *datax, MathValue *datay, MathValue *gdata, int filenum, int *openfile) { int i,j; int masked,moved,moven; struct f2ddata_buf *buf; MathValue dx, dy, dx2, dy2, dx3, dy3, d2, d3; #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_LINER masked = FALSE; for (j = 0; j < fp->masknum; j++) { if (fp->mask[j] == fp->line) { masked = TRUE; break; } } #elif MASK_SERACH_METHOD == MASK_SERACH_METHOD_BINARY masked = bsearch_int(fp->mask, fp->masknum, fp->line, NULL); #else masked = search_mask(fp->mask, fp->masknum, &(fp->mask_index), fp->line); #endif moved = FALSE; if (! masked) { for (j = 0; j < fp->movenum; j++) { if (fp->move[j] == fp->line) { moved = TRUE; moven = j; break; } } for (i = 0; i < fnumx; i++) { if (needx[i] / 1000 == fp->id) { j = needx[i] % 1000; datax[i] = gdata[j]; } else { datax[i].val = 0; datax[i].type = MATH_VALUE_NONUM; } } for (i = 0; i < fnumy; i++) { if (needy[i] / 1000 == fp->id) { j = needy[i] % 1000; datay[i] = gdata[j]; } else { datay[i].val = 0; datay[i].type = MATH_VALUE_NONUM; } } if (filenum) { getdata_get_other_files(fp, fnumx, fnumy, needx, needy, datax, datay, filenum, openfile); } } d2.val = d3.val = 0; d2.type = d3.type = MATH_VALUE_UNDEF; dx = gdata[fp->x]; switch (fp->type) { case TYPE_DIAGONAL: dy = gdata[fp->x + 1]; break; default: dy = gdata[fp->y]; } dx2 = dx; dy2 = dy; if (fp->codex[0]) { file_calculate(fp, fp->codex[0], &dx2, &dy2, gdata, datax, &dx); } if (fp->codey[0]) { file_calculate(fp, fp->codey[0], &dx2, &dy2, gdata, datay, &dy); } switch (fp->type) { case TYPE_NORMAL: break; case TYPE_DIAGONAL: d2 = gdata[fp->y]; d3 = gdata[fp->y + 1]; dx2 = d2; dy2 = d3; dx3 = d2; dy3 = d3; if (fp->codex[1]) { file_calculate(fp, fp->codex[1], &dx2, &dy2, gdata, datax, &d2); } if (fp->codey[2]) { file_calculate(fp, fp->codey[2], &dx3, &dy3, gdata, datay, &d3); } break; case TYPE_ERR_X: d2.val = gdata[fp->x].val + gdata[fp->x + 1].val; if (gdata[fp->x].type < gdata[fp->x + 1].type) { d2.type = gdata[fp->x].type; } else { d2.type = gdata[fp->x + 1].type; } d3.val = gdata[fp->x].val + gdata[fp->x + 2].val; if (gdata[fp->x].type < gdata[fp->x + 2].type) { d3.type = gdata[fp->x].type; } else { d3.type = gdata[fp->x + 2].type; } dx2 = d2; dy2 = gdata[fp->y]; dx3 = d3; dy3 = gdata[fp->y]; if (fp->codex[1]) { file_calculate(fp, fp->codex[1], &dx2, &dy2, gdata, datax, &d2); } if (fp->codex[2]) { file_calculate(fp, fp->codex[2], &dx3, &dy3, gdata, datax, &d3); } break; case TYPE_ERR_Y: d2.val = gdata[fp->y].val + gdata[fp->y + 1].val; if (gdata[fp->y].type < gdata[fp->y + 1].type) { d2.type = gdata[fp->y].type; } else { d2.type = gdata[fp->y + 1].type; } d3.val = gdata[fp->y].val + gdata[fp->y + 2].val; if (gdata[fp->y].type < gdata[fp->y + 2].type) { d3.type = gdata[fp->y].type; } else { d3.type = gdata[fp->y + 2].type; } dx2 = gdata[fp->x]; dy2 = d2; dx3 = gdata[fp->x]; dy3 = d3; if (fp->codey[1]) { file_calculate(fp, fp->codey[1], &dx2, &dy2, gdata, datax, &d2); } if (fp->codey[2]) { file_calculate(fp, fp->codey[2], &dx3, &dy3, gdata, datax, &d3); } break; } if (masked) { dx.type = dy.type = d2.type = d3.type = MATH_VALUE_CONT; } if (moved) { dx.type = dy.type = d2.type = d3.type = MATH_VALUE_NORMAL; dx.val = fp->movex[moven]; dy.val = fp->movey[moven]; switch (fp->type) { case TYPE_ERR_X: d2 = dx; d3 = dx; break; case TYPE_ERR_Y: d2 = dy; d3 = dy; break; default: d2 = dx; d3 = dy; break; } } #if BUF_TYPE == USE_BUF_PTR buf = fp->buf_ptr[fp->bufnum]; #elif BUF_TYPE == USE_RING_BUF buf = &fp->buf[ring_buf_index(fp, fp->bufnum)]; #else buf = &fp->buf[fp->bufnum]; #endif buf->col = fp->color; buf->marksize = fp->marksize; buf->marktype = fp->marktype; buf->line = fp->line; buf->col2 = fp->color2; buf->dx = dx.val; buf->dy = dy.val; buf->d2 = d2.val; buf->d3 = d3.val; buf->dxstat = dx.type; buf->dystat = dy.type; buf->d2stat = d2.type; buf->d3stat = d3.type; fp->bufnum++; if (fp->rstep > 1) { return getdata_skip_step(fp, TRUE); } return 0; } static void array_data(MathValue *gdata, struct narray *array, int i) { if (array == NULL) { gdata->val = 0; gdata->type = MATH_VALUE_NONUM; return; } gdata->val = arraynget_double(array, i); gdata->type = MATH_VALUE_NORMAL; } static void set_column_array(MathEquation **code, int id, MathValue *gdata, int maxdim) { int i, j; if (id < 0) { return; } for (j = 0; j < EQUATION_NUM; j++) { math_equation_clear_array(code[j], id); for (i = 0; i <= maxdim; i++) { math_equation_set_array_val(code[j], id, i, gdata + i); } } } static int get_data_from_source(struct f2ddata *fp, int maxdim, MathValue *gdata) { char *buf; int i, rcode, n; double x; MathValue nonum; nonum.val = 0; nonum.type = MATH_VALUE_NONUM; rcode = 0; switch (fp->src) { case DATA_SOURCE_FILE: rcode = fgetline(fp->fd, &buf); if (rcode == 1 || rcode == -1) { fp->eof = TRUE; return rcode; } fp->line++; for (i = 0; buf[i] && CHECK_IFS(fp->ifs_buf, buf[i]); i++); rcode = 2; if (buf[i] != '\0' && (! CHECK_REMARK(fp->remark, fp->ifs_buf, buf[i]))) { rcode = getdataarray(fp, buf, maxdim, gdata); if (rcode != -1) { rcode = 0; } } g_free(buf); break; case DATA_SOURCE_ARRAY: if (fp->line >= fp->array_data.data_num) { fp->eof = TRUE; return 1; } n = (fp->array_data.col_num > fp->maxdim) ? fp->maxdim : fp->array_data.col_num; fp->count++; gdata[0].val = fp->count; gdata[0].type = MATH_VALUE_NORMAL; for (i = 0; i < n; i++) { array_data(gdata + i + 1, fp->array_data.ary[i], fp->line); } for (i = n + 1; i <= fp->maxdim; i++) { gdata[i] = nonum; } set_column_array(fp->codex, fp->column_array_id_x, gdata, n); set_column_array(fp->codey, fp->column_array_id_y, gdata, n); fp->line++; break; case DATA_SOURCE_RANGE: if (fp->line > fp->range_div) { fp->eof = TRUE; return 1; } fp->count++; gdata[0].val = fp->count; gdata[0].type = MATH_VALUE_NORMAL; x = fp->range_min + (fp->range_max - fp->range_min) / fp->range_div * fp->line; gdata[1].val = x; gdata[1].type = MATH_VALUE_NORMAL; gdata[2].val = x; gdata[2].type = MATH_VALUE_NORMAL; for (i = 3; i <= fp->maxdim; i++) { gdata[i] = nonum; } fp->line++; set_column_array(fp->codex, fp->column_array_id_x, gdata, 2); set_column_array(fp->codey, fp->column_array_id_y, gdata, 2); break; } return rcode; } static int getdata_sub1(struct f2ddata *fp, int fnumx, int fnumy, int *needx, int *needy, MathValue *datax, MathValue *datay, MathValue *gdata, int filenum, int *openfile) { int rcode; while (! fp->eof && fp->bufnum < DXBUFSIZE) { if (fp->final >= 0 && fp->line >= fp->final) { fp->eof=TRUE; break; } if ((fp->line & UPDATE_PROGRESS_LINE_NUM) == 0 && set_data_progress(fp)) { break; } rcode = get_data_from_source(fp, fp->maxdim, gdata); if (rcode == 0) { if (getdata_sub2(fp, fnumx, fnumy, needx, needy, datax, datay, gdata, filenum, openfile)) { break; } } else if (rcode == 1) { fp->eof=TRUE; break; } else if (rcode==-1) { return -1; } if (fp->interrupt) { return -1; } if ((fp->final>=0) && (fp->line>=fp->final)) fp->eof=TRUE; } return 0; } static void calculate_average_simple(struct f2ddata *fp, int smx, int smy, int sm2, int sm3, int num) { int i; struct f2ddata_buf *buf; int numx, numy, num2, num3; double sumx, sumy, sum2, sum3; sumx=sumy=sum2=sum3=0; numx=numy=num2=num3=0; #if BUF_TYPE == USE_BUF_PTR for (i = 0; i <= num; i++) { buf = fp->buf_ptr[i]; if (buf->dxstat == MATH_VALUE_NORMAL && i >= fp->bufpo - smx && i <= fp->bufpo + smx) { sumx += buf->dx; numx++; } if (buf->dystat == MATH_VALUE_NORMAL && i >= fp->bufpo - smy && i <= fp->bufpo + smy) { sumy += buf->dy; numy++; } if (buf->d2stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm2 && i <= fp->bufpo + sm2) { sum2 += buf->d2; num2++; } if (buf->d3stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm3 && i <= fp->bufpo + sm3) { sum3 += buf->d3; num3++; } } buf = fp->buf_ptr[fp->bufpo]; if (numx != 0) fp->dx = sumx / numx; fp->dxstat = buf->dxstat; if (numy != 0) fp->dy=sumy/numy; fp->dystat = buf->dystat; if (num2 != 0) fp->d2 = sum2/num2; fp->d2stat = buf->d2stat; if (num3 != 0) fp->d3 = sum3 / num3; fp->d3stat = buf->d3stat; fp->dline = buf->line; fp->col = buf->col; fp->col2 = buf->col2; fp->msize = buf->marksize; fp->mtype = buf->marktype; #elif BUF_TYPE == USE_RING_BUF for (i=0;i<=num;i++) { n = ring_buf_index(fp, i); if ((fp->buf[n].dxstat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-smx) && (i<=fp->bufpo+smx)) { sumx+=fp->buf[n].dx; numx++; } if ((fp->buf[n].dystat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-smy) && (i<=fp->bufpo+smy)) { sumy+=fp->buf[n].dy; numy++; } if ((fp->buf[n].d2stat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-sm2) && (i<=fp->bufpo+sm2)) { sum2+=fp->buf[n].d2; num2++; } if ((fp->buf[n].d3stat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-sm3) && (i<=fp->bufpo+sm3)) { sum3+=fp->buf[n].d3; num3++; } } n = ring_buf_index(fp, fp->bufpo); if (numx!=0) fp->dx=sumx/numx; fp->dxstat=fp->buf[n].dxstat; if (numy!=0) fp->dy=sumy/numy; fp->dystat=fp->buf[n].dystat; if (num2!=0) fp->d2=sum2/num2; fp->d2stat=fp->buf[n].d2stat; if (num3!=0) fp->d3=sum3/num3; fp->d3stat=fp->buf[n].d3stat; fp->dline=fp->buf[n].line; fp->col=fp->buf[n].col; fp->col2=fp->buf[n].col2; fp->msize=fp->buf[n].marksize; fp->mtype=fp->buf[n].marktype; #else /* BUF_TYPE */ for (i=0;i<=num;i++) { if ((fp->buf[i].dxstat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-smx) && (i<=fp->bufpo+smx)) { sumx+=fp->buf[i].dx; numx++; } if ((fp->buf[i].dystat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-smy) && (i<=fp->bufpo+smy)) { sumy+=fp->buf[i].dy; numy++; } if ((fp->buf[i].d2stat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-sm2) && (i<=fp->bufpo+sm2)) { sum2+=fp->buf[i].d2; num2++; } if ((fp->buf[i].d3stat==MATH_VALUE_NORMAL) && (i>=fp->bufpo-sm3) && (i<=fp->bufpo+sm3)) { sum3+=fp->buf[i].d3; num3++; } } if (numx!=0) fp->dx=sumx/numx; fp->dxstat=fp->buf[fp->bufpo].dxstat; if (numy!=0) fp->dy=sumy/numy; fp->dystat=fp->buf[fp->bufpo].dystat; if (num2!=0) fp->d2=sum2/num2; fp->d2stat=fp->buf[fp->bufpo].d2stat; if (num3!=0) fp->d3=sum3/num3; fp->d3stat=fp->buf[fp->bufpo].d3stat; fp->dline=fp->buf[fp->bufpo].line; fp->col=fp->buf[fp->bufpo].col; fp->col2=fp->buf[fp->bufpo].col2; fp->msize=fp->buf[fp->bufpo].marksize; fp->mtype=fp->buf[fp->bufpo].marktype; #endif /* BUF_TYPE */ } static void calculate_average_weughted(struct f2ddata *fp, int smx, int smy, int sm2, int sm3, int num) { int i, weight; struct f2ddata_buf *buf; int numx, numy, num2, num3; double sumx, sumy, sum2, sum3, wx, wy, w2, w3; sumx = sumy = sum2 = sum3 = 0; numx = numy = num2 = num3 = 0; wx = wy = w2 = w3 = 0; /* o i: 0 1 2 3 4 5 6 7 8 9 10 b-i: 3 2 1 0 1 2 3 smx: 5 bufpo: 3 bufpo - smx: -2 bufpo + smx: 8 if (smx > bufpo) smx = bufpo o i: 0 1 2 3 4 5 6 7 8 9 10 11 b-i: 6 5 4 3 2 1 0 1 2 3 4 5 smx: 5 bufpo: 6 bufpo - smx: 1 bufpo + smx: 11 if (smx > bufpo) smx = bufpo */ #if 0 if (smx > fp->bufpo) smx = fp->bufpo; if (smy > fp->bufpo) smy = fp->bufpo; if (sm2 > fp->bufpo) sm2 = fp->bufpo; if (sm3 > fp->bufpo) sm3 = fp->bufpo; if (smx > num - fp->bufpo) smx = num - fp->bufpo; if (smy > num - fp->bufpo) smy = num - fp->bufpo; if (sm2 > num - fp->bufpo) sm2 = num - fp->bufpo; if (sm3 > num - fp->bufpo) sm3 = num - fp->bufpo; #endif for (i = 0; i <= num; i++) { buf = fp->buf_ptr[i]; if (buf->dxstat == MATH_VALUE_NORMAL && i >= fp->bufpo - smx && i <= fp->bufpo + smx) { weight = smx + 1 - abs(fp->bufpo - i); wx += weight; sumx += buf->dx * weight; numx++; } if (buf->dystat == MATH_VALUE_NORMAL && i >= fp->bufpo - smy && i <= fp->bufpo + smy) { weight = smy + 1 - abs(fp->bufpo - i); wy += weight; sumy += buf->dy * weight; numy++; } if (buf->d2stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm2 && i <= fp->bufpo + sm2) { weight = sm2 + 1 - abs(fp->bufpo - i); w2 += weight; sum2 += buf->d2 * weight; num2++; } if (buf->d3stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm3 && i <= fp->bufpo + sm3) { weight = sm3 + 1 - abs(fp->bufpo - i); w3 += weight; sum3 += buf->d3 * weight; num3++; } } buf = fp->buf_ptr[fp->bufpo]; if (numx != 0) { fp->dx = sumx / wx; } fp->dxstat = buf->dxstat; if (numy != 0) { fp->dy = sumy / wy; } fp->dystat = buf->dystat; if (num2 != 0) { fp->d2 = sum2 / w2; } fp->d2stat = buf->d2stat; if (num3 != 0) { fp->d3 = sum3 / w3; } fp->d3stat = buf->d3stat; fp->dline = buf->line; fp->col = buf->col; fp->col2 = buf->col2; fp->msize = buf->marksize; fp->mtype = buf->marktype; } #define HALFLIFE 2.8854 static void calculate_average_exponential(struct f2ddata *fp, int smx, int smy, int sm2, int sm3, int num) { int i; struct f2ddata_buf *buf; int numx, numy, num2, num3; double sumx, sumy, sum2, sum3, ax, ay, a2, a3, wx, wy, w2, w3, weight; sumx = sumy = sum2 = sum3 = 0; numx = numy = num2 = num3 = 0; wx = wy = w2 = w3 = 0; #if 0 if (smx > fp->bufpo) smx = fp->bufpo; if (smy > fp->bufpo) smy = fp->bufpo; if (sm2 > fp->bufpo) sm2 = fp->bufpo; if (smx > num - fp->bufpo) smx = num - fp->bufpo; if (smy > num - fp->bufpo) smy = num - fp->bufpo; if (sm2 > num - fp->bufpo) sm2 = num - fp->bufpo; if (sm3 > num - fp->bufpo) sm3 = num - fp->bufpo; #endif ax = (1 - 2.0 / (smx / HALFLIFE + 2)); ay = (1 - 2.0 / (smy / HALFLIFE + 2)); a2 = (1 - 2.0 / (sm2 / HALFLIFE + 2)); a3 = (1 - 2.0 / (sm3 / HALFLIFE + 2)); for (i = 0; i <= num; i++) { buf = fp->buf_ptr[i]; if (buf->dxstat == MATH_VALUE_NORMAL && i >= fp->bufpo - smx && i <= fp->bufpo + smx) { weight = pow(ax, abs(fp->bufpo - i)); wx += weight; sumx += buf->dx * weight; numx++; } if (buf->dystat == MATH_VALUE_NORMAL && i >= fp->bufpo - smy && i <= fp->bufpo + smy) { weight = pow(ay, abs(fp->bufpo - i)); wy += weight; sumy += buf->dy * weight; numy++; } if (buf->d2stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm2 && i <= fp->bufpo + sm2) { weight = pow(a2, abs(fp->bufpo - i)); w2 += weight; sum2 += buf->d2 * weight; num2++; } if (buf->d3stat == MATH_VALUE_NORMAL && i >= fp->bufpo - sm3 && i <= fp->bufpo + sm3) { weight = pow(a3, abs(fp->bufpo - i)); w3 += weight; sum3 += buf->d3 * weight; num3++; } } buf = fp->buf_ptr[fp->bufpo]; if (numx != 0) { fp->dx = sumx / wx; } fp->dxstat = buf->dxstat; if (numy != 0) { fp->dy = sumy / wy; } fp->dystat = buf->dystat; if (num2 != 0) { fp->d2 = sum2 / w2; } fp->d2stat = buf->d2stat; if (num3 != 0) { fp->d3 = sum3 / w3; } fp->d3stat = buf->d3stat; fp->dline = buf->line; fp->col = buf->col; fp->col2 = buf->col2; fp->msize = buf->marksize; fp->mtype = buf->marktype; } static void calculate_average(struct f2ddata *fp, int smx, int smy, int sm2, int sm3) { int num; if (fp->bufpo + fp->smooth >= fp->bufnum) { num = fp->bufnum - 1; } else { num = fp->bufpo + fp->smooth; } switch (fp->averaging_type) { case MOVING_AVERAGE_SIMPLE: calculate_average_simple(fp, smx, smy, sm2, sm3, num); break; case MOVING_AVERAGE_WEIGHTED: calculate_average_weughted(fp, smx, smy, sm2, sm3, num); break; case MOVING_AVERAGE_EXPONENTIAL: calculate_average_exponential(fp, smx, smy, sm2, sm3, num); break; } } static int getdata(struct f2ddata *fp) /* return -1: fatal error 0: no error 1: EOF */ { int rcode; int smx,smy,sm2,sm3; int filenum,*openfile,*needx,*needy; struct narray filedatax,filedatay; unsigned int fnumx,fnumy,j; #if BUF_TYPE == USE_RING_BUF int n; #endif MathValue *datax,*datay; static MathValue gdata[FILE_OBJ_MAXCOL + 3]; static MathValue math_value_zero = {0, 0}; fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_UNDEF; filenum=arraynum(&(fp->fileopen)); openfile=arraydata(&(fp->fileopen)); fnumx = fp->fnumx; needx = fp->needx; arrayinit(&filedatax, sizeof(MathValue)); for (j = 0; j < fnumx; j++) { arrayadd(&filedatax, &math_value_zero); } if (arraynum(&filedatax) < fnumx) { fnumx = arraynum(&filedatax); } datax = arraydata(&filedatax); fnumy = fp->fnumy; needy = fp->needy; arrayinit(&filedatay, sizeof(MathValue)); for (j = 0; j < fnumy; j++) { arrayadd(&filedatay, &math_value_zero); } if (arraynum(&filedatay) < fnumy) { fnumy = arraynum(&filedatay); } datay = arraydata(&filedatay); rcode = getdata_sub1(fp, fnumx, fnumy, needx, needy, datax, datay, gdata, filenum, openfile); if (rcode) { return rcode; } arraydel(&filedatax); arraydel(&filedatay); if ((fp->bufnum==0) || (fp->bufpo>=fp->bufnum)) { fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_MEOF; return 1; } switch (fp->type) { case TYPE_NORMAL: smx=fp->smoothx; smy=fp->smoothy; sm2=0; sm3=0; break; case TYPE_DIAGONAL: smx=fp->smoothx; smy=fp->smoothy; sm2=fp->smoothx; sm3=fp->smoothy; break; case TYPE_ERR_X: smx=fp->smoothx; smy=fp->smoothy; sm2=fp->smoothx; sm3=fp->smoothx; break; case TYPE_ERR_Y: smx=fp->smoothx; smy=fp->smoothy; sm2=fp->smoothy; sm3=fp->smoothy; break; default: /* never reached */ smx = 0; smy = 0; sm2 = 0; sm3 = 0; break; } calculate_average(fp, smx, smy, sm2, sm3); switch (fp->type) { case TYPE_NORMAL: if (fp->dxstat==MATH_VALUE_NORMAL && fp->dystat==MATH_VALUE_NORMAL) fp->datanum++; break; case TYPE_DIAGONAL: if (fp->dxstat==MATH_VALUE_NORMAL && fp->dystat==MATH_VALUE_NORMAL && fp->d2stat==MATH_VALUE_NORMAL && fp->d3stat==MATH_VALUE_NORMAL) fp->datanum++; break; case TYPE_ERR_X: if (fp->dystat==MATH_VALUE_NORMAL && fp->d2stat==MATH_VALUE_NORMAL && fp->d3stat==MATH_VALUE_NORMAL) fp->datanum++; break; case TYPE_ERR_Y: if (fp->dxstat==MATH_VALUE_NORMAL && fp->d2stat==MATH_VALUE_NORMAL && fp->d3stat==MATH_VALUE_NORMAL) fp->datanum++; break; } if (fp->bufposmooth) { fp->bufpo++; } else { #if BUF_TYPE == USE_BUF_PTR if (fp->bufnum > 0) { struct f2ddata_buf *tmp; fp->bufnum--; tmp = fp->buf_ptr[0]; #if USE_MEMMOVE memmove(fp->buf_ptr, fp->buf_ptr + 1, sizeof(*fp->buf_ptr) * fp->bufnum); #else for (i = 0; i < fp->bufnum; i++) { fp->buf_ptr[i] = fp->buf_ptr[i + 1]; } #endif fp->buf_ptr[fp->bufnum] = tmp; } #elif BUF_TYPE == USE_RING_BUF if (fp->bufnum > 0) { fp->bufnum--; fp->ringbuf_top = RING_BUF_INC(fp->ringbuf_top); } #else /* BUF_TYPE */ if (fp->bufnum > 0) { fp->bufnum--; #if USE_MEMMOVE memmove(fp->buf, fp->buf + 1, sizeof(*fp->buf) * fp->bufnum); #else for (i = 0; i < fp->bufnum; i++) { fp->buf[i] = fp->buf[i + 1]; } #endif } #endif /* BUF_TYPE */ } return 0; } static int getdata2(struct f2ddata *fp, MathEquation *code, int maxdim, double *dd, int *ddstat) /* return -1: fatal error 0: no error 1: EOF */ { int rcode; MathValue val, gdata[FILE_OBJ_MAXCOL + 3], dx2, dy2; int masked; int find; *dd=0; *ddstat=MATH_VALUE_UNDEF; find=FALSE; while (!fp->eof && (!find)) { if ((fp->final>=0) && (fp->line>=fp->final)) { fp->eof=TRUE; break; } rcode = get_data_from_source(fp, maxdim, gdata); if (rcode == 1) { fp->eof=TRUE; break; } else if (rcode==-1) { return -1; } else if (rcode != 0) { continue; } #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_LINER for (j=0;jmasknum;j++) if ((fp->mask)[j]==fp->line) break; if (j!=fp->masknum) masked=TRUE; else masked=FALSE; #elif MASK_SERACH_METHOD == MASK_SERACH_METHOD_BINARY masked = bsearch_int(fp->mask, fp->masknum, fp->line, NULL); #else masked = search_mask(fp->mask, fp->masknum, &(fp->mask_index), fp->line); #endif *dd=0; *ddstat=MATH_VALUE_UNDEF; dx2 = gdata[fp->x]; dy2 = gdata[fp->y]; if (code && code->exp) { file_calculate(fp, code, &dx2, &dy2, gdata, NULL, &val); *dd = val.val; *ddstat = val.type; } if (masked) *ddstat=MATH_VALUE_CONT; find=TRUE; fp->dline=fp->line; rcode = getdata_skip_step(fp, FALSE); if (rcode == -1) { return -1; } if ((fp->final>=0) && (fp->line>=fp->final)) fp->eof=TRUE; } if (!find) { *dd=0; *ddstat=MATH_VALUE_MEOF; return 1; } return 0; } static int getdataraw(struct f2ddata *fp, int maxdim, MathValue *data) /* return -1: fatal error 0: no error 1: EOF */ { int i,rcode; int masked; double dx,dy,d2,d3; char dxstat,dystat,d2stat,d3stat; int datanum; fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_UNDEF; datanum=0; while (!fp->eof && (datanum==0)) { if ((fp->final>=0) && (fp->line>=fp->final)) { fp->eof=TRUE; break; } if ((fp->line & UPDATE_PROGRESS_LINE_NUM) == 0 && set_data_progress(fp)) { break; } rcode = get_data_from_source(fp, maxdim, data); if (rcode == 1) { fp->eof=TRUE; break; } else if (rcode==-1) { return -1; } else if (rcode != 0) { continue; } #if MASK_SERACH_METHOD == MASK_SERACH_METHOD_LINER for (j=0;jmasknum;j++) if ((fp->mask)[j]==fp->line) break; if (j!=fp->masknum) masked=TRUE; else masked=FALSE; #elif MASK_SERACH_METHOD == MASK_SERACH_METHOD_BINARY masked = bsearch_int(fp->mask, fp->masknum, fp->line, NULL); #else masked = search_mask(fp->mask, fp->masknum, &(fp->mask_index), fp->line); #endif dx=dy=d2=d3=0; dxstat=dystat=d2stat=d3stat=MATH_VALUE_UNDEF; dx = data[fp->x].val; dxstat = data[fp->x].type; switch (fp->type) { case TYPE_DIAGONAL: dy = data[fp->x + 1].val; dystat = data[fp->x + 1].type; break; default: dy = data[fp->y].val; dystat = data[fp->y].type; } switch (fp->type) { case TYPE_NORMAL: break; case TYPE_DIAGONAL: d2 = data[fp->y].val; d2stat = data[fp->y].type; d3 = data[fp->y + 1].val; d3stat = data[fp->y + 1].type; break; case TYPE_ERR_X: d2 = data[fp->x].val + data[fp->x + 1].val; if (data[fp->x].type < data[fp->x + 1].type) d2stat = data[fp->x].type; else d2stat = data[fp->x + 1].type; d3 = data[fp->x].val + data[fp->x + 2].val; if (data[fp->x].type < data[fp->x + 2].type) d3stat = data[fp->x].type; else d3stat = data[fp->x + 2].type; break; case TYPE_ERR_Y: d2 = data[fp->y].val + data[fp->y + 1].val; if (data[fp->y].type < data[fp->y + 1].type) d2stat = data[fp->y].type; else d2stat = data[fp->y + 1].type; d3 = data[fp->y].val + data[fp->y + 2].val; if (data[fp->y].type < data[fp->y + 2].type) d3stat = data[fp->y].type; else d3stat = data[fp->y + 2].type; break; } if (masked) { dxstat=dystat=d2stat=d3stat=MATH_VALUE_CONT; for (i=0;i<=maxdim;i++) data[i].type = MATH_VALUE_CONT; } fp->dx=dx; fp->dy=dy; fp->d2=d2; fp->d3=d3; fp->dxstat=dxstat; fp->dystat=dystat; fp->d2stat=d2stat; fp->d3stat=d3stat; fp->col=fp->color; fp->col2=fp->color2; datanum++; if (fp->rstep > 1 && getdata_skip_step(fp, TRUE)) return -1; fp->datanum++; if ((fp->final>=0) && (fp->line>=fp->final)) fp->eof=TRUE; } if (datanum==0) { fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_MEOF; return 1; } return 0; } static void set_final_line(struct f2ddata *fp, struct f2dlocal *local) { if (fp->final < -1) { fp->final += local->total_line + 1; if (fp->final < 0) { fp->final = 0; } } } static int check_mtime(struct f2ddata *fp, struct f2dlocal *local) { if (local->mtime != fp->mtime) { return 1; } fp->datanum = local->num; fp->dx = fp->dy = fp->d2 = fp->d3=0; fp->dxstat = fp->dystat = fp->d2stat = fp->d3stat = MATH_VALUE_UNDEF; fp->dline = 0; fp->minx = local->minx; fp->maxx = local->maxx; fp->miny = local->miny; fp->maxy = local->maxy; fp->sumx = local->sumx; fp->sumy = local->sumy; fp->sumxx = local->sumxx; fp->sumyy = local->sumyy; fp->sumxy = local->sumxy; fp->num = local->num; if (local->rcode == -1) return -1; set_final_line(fp, local); return 0; } static int getminmaxdata(struct f2ddata *fp, struct f2dlocal *local) /* return -1: fatal error 0: no error */ { int rcode; MathValue gdata[FILE_OBJ_MAXCOL + 3]; if (check_mtime(fp, local) == 0) { return 0; } if (hskipdata(fp)!=0) { closedata(fp, local); return 1; } fp->minx.type = MATH_VALUE_UNDEF; fp->maxx.type = MATH_VALUE_UNDEF; fp->miny.type = MATH_VALUE_UNDEF; fp->maxy.type = MATH_VALUE_UNDEF; fp->sumx=0; fp->sumy=0; fp->sumxx=0; fp->sumyy=0; fp->sumxy=0; fp->num=0; while ((rcode = getdataraw(fp, fp->maxdim, gdata)) == 0) { switch (fp->type) { case TYPE_NORMAL: case TYPE_DIAGONAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if ((fp->minx.type == MATH_VALUE_UNDEF) || (fp->minx.val > fp->dx)) { fp->minx.val = fp->dx; } if ((fp->maxx.type == MATH_VALUE_UNDEF) || (fp->maxx.val < fp->dx)) { fp->maxx.val = fp->dx; } fp->minx.type = MATH_VALUE_NORMAL; fp->maxx.type = MATH_VALUE_NORMAL; if ((fp->miny.type == MATH_VALUE_UNDEF) || (fp->miny.val > fp->dy)) { fp->miny.val = fp->dy; } if ((fp->maxy.type == MATH_VALUE_UNDEF) || (fp->maxy.val < fp->dy)) { fp->maxy.val = fp->dy; } fp->miny.type = MATH_VALUE_NORMAL; fp->maxy.type = MATH_VALUE_NORMAL; fp->sumx += fp->dx; fp->sumxx += (fp->dx) * (fp->dx); fp->sumy += fp->dy; fp->sumyy += (fp->dy) * (fp->dy); fp->sumxy += (fp->dx) * (fp->dy); fp->num++; } if (fp->type == TYPE_NORMAL) break; if ((fp->d2stat == MATH_VALUE_NORMAL) && (fp->d3stat == MATH_VALUE_NORMAL)) { if ((fp->minx.type == MATH_VALUE_UNDEF) || (fp->minx.val > fp->d2)) { fp->minx.val = fp->d2; } if ((fp->maxx.type == MATH_VALUE_UNDEF) || (fp->maxx.val < fp->d2)) { fp->maxx.val = fp->d2; } fp->minx.type = MATH_VALUE_NORMAL; fp->maxx.type = MATH_VALUE_NORMAL; if ((fp->miny.type == MATH_VALUE_UNDEF) || (fp->miny.val > fp->d3)) { fp->miny.val = fp->d3; } if ((fp->maxy.type == MATH_VALUE_UNDEF) || (fp->maxy.val < fp->d3)) { fp->maxy.val = fp->d3; } fp->miny.type = MATH_VALUE_NORMAL; fp->maxy.type = MATH_VALUE_NORMAL; fp->sumx += fp->d2; fp->sumxx += (fp->d2) * (fp->d2); fp->sumy += fp->d3; fp->sumyy += (fp->d3) * (fp->d3); fp->sumxy += (fp->d2) * (fp->d3); fp->num++; } break; case TYPE_ERR_X: if ((fp->d2stat == MATH_VALUE_NORMAL) && (fp->d3stat == MATH_VALUE_NORMAL) && (fp->dystat == MATH_VALUE_NORMAL)) { if ((fp->minx.type == MATH_VALUE_UNDEF) || (fp->minx.val > fp->d2)) { fp->minx.val = fp->d2; } if ((fp->maxx.type == MATH_VALUE_UNDEF) || (fp->maxx.val < fp->d2)) { fp->maxx.val = fp->d2; } fp->minx.type = MATH_VALUE_NORMAL; fp->maxx.type = MATH_VALUE_NORMAL; if ((fp->minx.type == MATH_VALUE_UNDEF) || (fp->minx.val > fp->d3)) { fp->minx.val = fp->d3; } if ((fp->maxx.type == MATH_VALUE_UNDEF) || (fp->maxx.val < fp->d3)) { fp->maxx.val = fp->d3; } fp->minx.type=MATH_VALUE_NORMAL; fp->maxx.type=MATH_VALUE_NORMAL; if ((fp->miny.type == MATH_VALUE_UNDEF) || (fp->miny.val > fp->dy)) { fp->miny.val = fp->dy; } if ((fp->maxy.type == MATH_VALUE_UNDEF) || (fp->maxy.val < fp->dy)) { fp->maxy.val = fp->dy; } fp->miny.type = MATH_VALUE_NORMAL; fp->maxy.type = MATH_VALUE_NORMAL; fp->sumx += fp->d2; fp->sumxx += (fp->d2) * (fp->d2); fp->sumy += fp->dy; fp->sumyy += (fp->dy) * (fp->dy); fp->sumxy += (fp->d2) * (fp->dy); fp->num++; fp->sumx += fp->d3; fp->sumxx += (fp->d3) * (fp->d3); fp->sumy += fp->dy; fp->sumyy += (fp->dy) * (fp->dy); fp->sumxy += (fp->d3) * (fp->dy); fp->num++; } break; case TYPE_ERR_Y: if ((fp->d2stat == MATH_VALUE_NORMAL) && (fp->d3stat == MATH_VALUE_NORMAL) && (fp->dxstat == MATH_VALUE_NORMAL)) { if ((fp->miny.type == MATH_VALUE_UNDEF) || (fp->miny.val > fp->d2)) { fp->miny.val = fp->d2; } if ((fp->maxy.type == MATH_VALUE_UNDEF) || (fp->maxy.val < fp->d2)) { fp->maxy.val = fp->d2; } fp->miny.type = MATH_VALUE_NORMAL; fp->maxy.type = MATH_VALUE_NORMAL; if ((fp->miny.type == MATH_VALUE_UNDEF) || (fp->miny.val > fp->d3)) { fp->miny.val = fp->d3; } if ((fp->maxy.type == MATH_VALUE_UNDEF) || (fp->maxy.val < fp->d3)) { fp->maxy.val = fp->d3; } fp->miny.type = MATH_VALUE_NORMAL; fp->maxy.type = MATH_VALUE_NORMAL; if ((fp->minx.type == MATH_VALUE_UNDEF) || (fp->minx.val > fp->dx)) { fp->minx.val = fp->dx; } if ((fp->maxx.type == MATH_VALUE_UNDEF) || (fp->maxx.val < fp->dx)) { fp->maxx.val = fp->dx; } fp->minx.type = MATH_VALUE_NORMAL; fp->maxx.type = MATH_VALUE_NORMAL; fp->sumx += fp->dx; fp->sumxx += (fp->dx) * (fp->dx); fp->sumy += fp->d2; fp->sumyy += (fp->d2) * (fp->d2); fp->sumxy += (fp->dx) * (fp->d2); fp->num++; fp->sumx += fp->dx; fp->sumxx += (fp->dx) * (fp->dx); fp->sumy += fp->d3; fp->sumyy += (fp->d3) * (fp->d3); fp->sumxy += (fp->dx) * (fp->d3); fp->num++; } break; } } fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_UNDEF; fp->dline=0; local->minx = fp->minx; local->maxx = fp->maxx; local->miny = fp->miny; local->maxy = fp->maxy; local->sumx = fp->sumx; local->sumy = fp->sumy; local->sumxx = fp->sumxx; local->sumyy = fp->sumyy; local->sumxy = fp->sumxy; local->num = fp->num; local->rcode = rcode; local->total_line = fp->line; if (rcode==-1) return -1; if (fp->interrupt == FALSE) local->mtime = fp->mtime; set_final_line(fp, local); return 0; } static int getposition(struct f2ddata *fp, double x, double y, int *gx, int *gy) /* return -1: unable to transform 0: normal 1: outside region */ { *gx = *gy = 0; if (getposition2(fp, fp->axtype, fp->aytype, &x, &y)) { return -1; } if (fp->dataclip && (((fp->axmin > x || x > fp->axmax) && (fp->axmax > x || x > fp->axmin)) || ((fp->aymin > y || y > fp->aymax) && (fp->aymax > y || y > fp->aymin)))) { /* fix-me: this condition will be simplified as (fp->dataclip && (fp->axmin>x || x>fp->axmax || fp->aymin>y || y>fp->aymax)) */ return 1; } if (_f2dtransf(x, y, gx, gy, fp)) { fp->ignore = TRUE; return -1; } return 0; } static int get_pos_sub(struct f2ddata *fp, double *val, int atype) { switch (atype) { case AXIS_TYPE_LOG: if (*val == 0) { fp->ignore = TRUE; return -1; } else if (*val < 0) { fp->negative = TRUE; *val = fabs(*val); } *val = log10(*val); break; case AXIS_TYPE_INVERSE: if (*val == 0) { fp->ignore = TRUE; return -1; } *val = 1 / *val; break; } return 0; } static int getposition2(struct f2ddata *fp,int axtype,int aytype,double *x,double *y) /* return -1: unable to transform 0: normal */ { int r; r = get_pos_sub(fp, x, axtype); if (r) { return -1; } r = get_pos_sub(fp, y, aytype); if (r) { return -1; } return 0; } static int _f2dtransf(double x,double y,int *gx,int *gy,void *local) { struct f2ddata *fp; double minx,miny; double v1x,v1y,v2x,v2y,vx,vy; double a,b,c,d; fp=local; minx=fp->axmin; miny=fp->aymin; v1x=fp->ratex*(x-minx)*fp->axvx; v1y=fp->ratex*(x-minx)*fp->axvy; v2x=fp->ratey*(y-miny)*fp->ayvx; v2y=fp->ratey*(y-miny)*fp->ayvy; vx=fp->ayposx-fp->axposx+v2x-v1x; vy=fp->ayposy-fp->axposy+v2y-v1y; a=fp->ayvy*fp->axvx-fp->ayvx*fp->axvy; c=-fp->ayvy*vx+fp->ayvx*vy; b=fp->axvy*fp->ayvx-fp->axvx*fp->ayvy; d=fp->axvy*vx-fp->axvx*vy; if ((fabs(a)<=1e-16) && (fabs(b)<=1e-16)) { return 1; } else if (fabs(b)<=1e-16) { a=c/a; *gx=fp->ayposx+nround(v2x+a*fp->axvx); *gy=fp->ayposy+nround(v2y+a*fp->axvy); } else { b=d/b; *gx=fp->axposx+nround(v1x+b*fp->ayvx); *gy=fp->axposy+nround(v1y+b*fp->ayvy); } return 0; } static void f2dtransf(double x,double y,int *gx,int *gy,void *local) { _f2dtransf(x, y, gx, gy, local); } static int f2dlineclipf(double *x0,double *y0,double *x1,double *y1,void *local) { double a,xl,yl,xg,yg; double minx,miny,maxx,maxy; struct f2ddata *fp; fp=local; if (!fp->dataclip) return 0; if (fp->axmin>fp->axmax) { minx=fp->axmax; maxx=fp->axmin; } else { minx=fp->axmin; maxx=fp->axmax; } if (fp->aymax>fp->aymin) { miny=fp->aymin; maxy=fp->aymax; } else { miny=fp->aymax; maxy=fp->aymin; } if (*x0<*x1) { xl=*x0; yl=*y0; xg=*x1; yg=*y1; } else { xl=*x1; yl=*y1; xg=*x0; yg=*y0; } if ((xgmaxx)) return 1; if (xg>maxx) { xg=maxx; yg=(*y1-*y0)*(maxx-*x0)/(*x1-*x0)+*y0; } if (xlyg) { a=yl; yl=yg; yg=a; a=xl; xl=xg; xg=a; } if ((ygmaxy)) return 1; if (yg>maxy) { yg=maxy; xg=(*x1-*x0)*(maxy-*y0)/(*y1-*y0)+*x0; } if (yldataclip) return 0; if (fp->axmin>fp->axmax) { minx=fp->axmax; maxx=fp->axmin; } else { minx=fp->axmin; maxx=fp->axmax; } if (fp->aymax>fp->aymin) { miny=fp->aymin; maxy=fp->aymax; } else { miny=fp->aymax; maxy=fp->aymin; } if (*x0<*x1) { xl=*x0; xg=*x1; } else { xl=*x1; xg=*x0; } if (*y0<*y1) { yl=*y0; yg=*y1; } else { yl=*y1; yg=*y0; } if ((xgmaxx)) return 1; if ((ygmaxy)) return 1; if ((xg>maxx) && (xlmaxy) && (ylmaxx) xg=maxx; if (xlmaxy) yg=maxy; if (ylratex; (*dy)*=fp->ratey; (*ddx)*=fp->ratex; (*ddy)*=fp->ratey; } static void f2dbsplinedif(double d,double c[], double *dx,double *dy,double *ddx,double *ddy,void *local) { struct f2ddata *fp; fp=local; bsplinedif(d,c,dx,dy,ddx,ddy,NULL); (*dx)*=fp->ratex; (*dy)*=fp->ratey; (*ddx)*=fp->ratex; (*ddy)*=fp->ratey; } static void f2derror(struct objlist *obj,struct f2ddata *fp,int code,char *s) { char buf[256]; switch (fp->src) { case DATA_SOURCE_FILE: snprintf(buf, sizeof(buf), "#%d: %s (%d:%s)",fp->id,fp->file,fp->dline,s); break; case DATA_SOURCE_ARRAY: snprintf(buf, sizeof(buf), "#%d: Array (%s)",fp->id, s); break; case DATA_SOURCE_RANGE: snprintf(buf, sizeof(buf), "#%d: Range (%s)",fp->id, s); break; } error2(obj,code,buf); } static void errordisp(struct objlist *obj, struct f2ddata *fp, int *emerr,int *emnonum,int *emig,int *emng) { int x,y; char *s; if (!*emerr) { x=FALSE; y=FALSE; if ((fp->dxstat==MATH_VALUE_ERROR) || (fp->dxstat==MATH_VALUE_NAN)) x=TRUE; if ((fp->dystat==MATH_VALUE_ERROR) || (fp->dystat==MATH_VALUE_NAN)) y=TRUE; switch (fp->type) { case TYPE_NORMAL: break; case TYPE_DIAGONAL: if ((fp->d2stat==MATH_VALUE_ERROR) || (fp->d2stat==MATH_VALUE_NAN)) x=TRUE; if ((fp->d3stat==MATH_VALUE_ERROR) || (fp->d3stat==MATH_VALUE_NAN)) y=TRUE; break; case TYPE_ERR_X: if ((fp->d2stat==MATH_VALUE_ERROR) || (fp->d2stat==MATH_VALUE_NAN)) x=TRUE; if ((fp->d3stat==MATH_VALUE_ERROR) || (fp->d3stat==MATH_VALUE_NAN)) x=TRUE; break; case TYPE_ERR_Y: if ((fp->d2stat==MATH_VALUE_ERROR) || (fp->d2stat==MATH_VALUE_NAN)) y=TRUE; if ((fp->d3stat==MATH_VALUE_ERROR) || (fp->d3stat==MATH_VALUE_NAN)) y=TRUE; break; } if (x || y) { if (x && (!y)) s="x"; else if ((!x) && y) s="y"; else s="xy"; f2derror(obj,fp,ERRMERR,s); *emerr=TRUE; } } if (!*emnonum) { x=FALSE; y=FALSE; if (fp->dxstat==MATH_VALUE_NONUM) x=TRUE; if (fp->dystat==MATH_VALUE_NONUM) y=TRUE; switch (fp->type) { case TYPE_NORMAL: break; case TYPE_DIAGONAL: if (fp->d2stat==MATH_VALUE_NONUM) x=TRUE; if (fp->d3stat==MATH_VALUE_NONUM) y=TRUE; break; case TYPE_ERR_X: if (fp->d2stat==MATH_VALUE_NONUM) x=TRUE; if (fp->d3stat==MATH_VALUE_NONUM) x=TRUE; break; case TYPE_ERR_Y: if (fp->d2stat==MATH_VALUE_NONUM) y=TRUE; if (fp->d3stat==MATH_VALUE_NONUM) y=TRUE; break; } if (x || y) { if (x && (!y)) s="x"; else if ((!x) && y) s="y"; else s="xy"; f2derror(obj,fp,ERRMNONUM,s); *emnonum=TRUE; } } if (!*emig && fp->ignore) { error(obj,ERRIGNORE); *emig=TRUE; } if (!*emng && fp->negative) { error(obj,ERRNEGATIVE); *emng=TRUE; } } static void errordisp2(struct objlist *obj, struct f2ddata *fp, int *emerr,int *emnonum,int *emig,int *emng, char ddstat,char *s) { if (!*emerr && (ddstat==MATH_VALUE_ERROR)) { f2derror(obj,fp,ERRMERR,s); *emerr=TRUE; } if (!*emerr && (ddstat==MATH_VALUE_NAN)) { f2derror(obj,fp,ERRMERR,s); *emerr=TRUE; } if (!*emnonum && (ddstat==MATH_VALUE_NONUM)) { f2derror(obj,fp,ERRMNONUM,s); *emnonum=TRUE; } if (!*emig && fp->ignore) { error(obj,ERRIGNORE); *emig=TRUE; } if (!*emng && fp->negative) { error(obj,ERRNEGATIVE); *emng=TRUE; } } #define SPBUFFERSZ 1024 static double * dataadd(double dx,double dy,double dz, int fr,int fg,int fb,int fa, int *size, double **x,double **y,double **z, int **r,int **g,int **b, int **a, double **c1,double **c2,double **c3, double **c4,double **c5,double **c6) { double *xb,*yb,*zb,*c1b,*c2b,*c3b,*c4b,*c5b,*c6b; int *rb,*gb,*bb,*ab; int bz; if (*size==0) { if (((*x=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*y=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*z=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*r=g_malloc(sizeof(int)*SPBUFFERSZ))==NULL) || ((*g=g_malloc(sizeof(int)*SPBUFFERSZ))==NULL) || ((*b=g_malloc(sizeof(int)*SPBUFFERSZ))==NULL) || ((*a=g_malloc(sizeof(int)*SPBUFFERSZ))==NULL) || ((*c1=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*c2=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*c3=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*c4=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*c5=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL) || ((*c6=g_malloc(sizeof(double)*SPBUFFERSZ))==NULL)) { g_free(*x); g_free(*y); g_free(*z); g_free(*r); g_free(*g); g_free(*b); g_free(*a); g_free(*c1); g_free(*c2); g_free(*c3); g_free(*c4); g_free(*c5); g_free(*c6); return NULL; } } else if ((*size%SPBUFFERSZ)==0) { bz=*size/SPBUFFERSZ+1; if (((xb=g_realloc(*x,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((yb=g_realloc(*y,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((zb=g_realloc(*z,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((rb=g_realloc(*r,sizeof(int)*SPBUFFERSZ*bz))==NULL) || ((gb=g_realloc(*g,sizeof(int)*SPBUFFERSZ*bz))==NULL) || ((bb=g_realloc(*b,sizeof(int)*SPBUFFERSZ*bz))==NULL) || ((ab=g_realloc(*b,sizeof(int)*SPBUFFERSZ*bz))==NULL) || ((c1b=g_realloc(*c1,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((c2b=g_realloc(*c2,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((c3b=g_realloc(*c3,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((c4b=g_realloc(*c4,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((c5b=g_realloc(*c5,sizeof(double)*SPBUFFERSZ*bz))==NULL) || ((c6b=g_realloc(*c6,sizeof(double)*SPBUFFERSZ*bz))==NULL)) { g_free(*x); g_free(*y); g_free(*z); g_free(*r); g_free(*g); g_free(*b); g_free(*a); g_free(*c1); g_free(*c2); g_free(*c3); g_free(*c4); g_free(*c5); g_free(*c6); return NULL; } else { *x=xb; *y=yb; *z=zb; *r=rb; *g=gb; *b=bb; *a=ab; *c1=c1b; *c2=c2b; *c3=c3b; *c4=c4b; *c5=c5b; *c6=c6b; } } (*x)[*size]=dx; (*y)[*size]=dy; (*z)[*size]=dz; (*r)[*size]=fr; (*g)[*size]=fg; (*b)[*size]=fb; (*a)[*size]=fa; (*size)++; return *x; } static int markout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style) { int emerr,emnonum,emig,emng; int gx,gy; emerr=emnonum=emig=emng=FALSE; GRAlinestyle(GC,snum,style,width,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); while (getdata(fp)==0) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition(fp,fp->dx,fp->dy,&gx,&gy)==0)) { if (fp->msize>0) GRAmark(GC,fp->mtype, gx, gy, fp->msize, fp->col.r, fp->col.g, fp->col.b, fp->col.a, fp->col2.r, fp->col2.g, fp->col2.b, fp->col2.a); } else errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static int lineout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style, int join,int miter,int close) { int emerr,emnonum,emig,emng; int first; double x0,y0; emerr=emnonum=emig=emng=FALSE; #if EXPAND_DOTTED_LINE GRAlinestyle(GC,0,NULL,width,GRA_LINE_CAP_BUTT,join,miter); #else GRAlinestyle(GC, snum, style, width, GRA_LINE_CAP_BUTT, join, miter); #endif first=TRUE; while (getdata(fp)==0) { GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (first) { GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf,NULL,NULL,fp, fp->dx,fp->dy); first=FALSE; x0=fp->dx; y0=fp->dy; } else { GRAdashlinetod(GC,fp->dx,fp->dy); } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (! first && close) { GRAdashlinetod(GC,x0,y0); } first=TRUE; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (!first && close) GRAdashlinetod(GC,x0,y0); errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static void poly_add_point(struct narray *pos, double x, double y, struct f2ddata *fp) { int gx, gy; f2dtransf(x, y, &gx, &gy, fp); arrayadd(pos, &gx); arrayadd(pos, &gy); } static void poly_add_clip_point(struct narray *pos, double minx, double miny, double maxx, double maxy, double x, double y, struct f2ddata *fp) { if (x < minx) { x = minx; } else if (x > maxx) { x = maxx; } if (y < miny) { y = miny; } else if (y > maxy) { y = maxy; } poly_add_point(pos, x, y, fp); } static int poly_pos_sort_cb(const void *a, const void *b) { const struct point_pos *p1, *p2; double d; int r; p1 = a; p2 = b; d = p1->d - p2->d; if (d < 0) { r = -1; } else if (d > 0) { r = 1; } else { r = 0; } return r; } static void poly_set_pos(struct point_pos *p, int i, double x, double y, double x0, double y0) { p[i].x = x; p[i].y = y; x -= x0; y -= y0; p[i].d = x * x + y * y; } static int poly_add_elements(struct narray *pos, double minx, double miny, double maxx, double maxy, double x0, double y0, double x1, double y1, struct f2ddata *fp) { double x, y, v0, v1, a, b, ba; struct point_pos cpos[4]; int i; if (x0 == x1 && y0 == y1) { return 1; } if (x0 >= minx && x0 <= maxx && y0 >= miny && y0 <= maxy) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x0, y0, fp); } if (x0 == x1) { if ((y0 < miny && y1 < miny) || (y0 > maxy && y1 > maxy)) { return 1; } if (y0 > y1) { if (y0 > maxy) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x0, maxy, fp); } if (y1 < miny) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x0, miny, fp); } } else { if (y0 < miny) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x0, miny, fp); } if (y1 > maxy) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x0, maxy, fp); } } goto End; } else if (y0 == y1) { if ((x0 < minx && x1 < minx) || (x0 > maxx && x1 > maxx)){ return 1; } if (x0 > x1) { if (x0 > maxx) { poly_add_clip_point(pos, minx, miny, maxx, maxy, maxx, y0, fp); } if (x1 < minx) { poly_add_clip_point(pos, minx, miny, maxx, maxy, minx, y0, fp); } } else { if (x0 < minx) { poly_add_clip_point(pos, minx, miny, maxx, maxy, minx, y0, fp); } if (x1 > maxx) { poly_add_clip_point(pos, minx, miny, maxx, maxy, maxx, y0, fp); } } goto End; } a = (y1 - y0) / (x1 - x0); b = (x1 * y0 - x0 * y1) / (x1 - x0); ba = (x1 * y0 - x0 * y1) / (y1 - y0); cpos[0].d = -1; cpos[1].d = -1; cpos[2].d = -1; cpos[3].d = -1; v0 = a * x0 + b; v1 = a * x1 + b; x = maxx; y = a * maxx + b; if (((x >= x0 && x <= x1) || (x >= x1 && x <= x0)) && ((y >= v0 && y <= v1) || (y >= v1 && y <= v0))) { poly_set_pos(cpos, 0, x, y, x0, y0); } x = minx; y = a * minx + b; if (((x >= x0 && x <= x1) || (x >= x1 && x <= x0)) && ((y >= v0 && y <= v1) || (y >= v1 && y <= v0))) { poly_set_pos(cpos, 1, x, y, x0, y0); } v0 = y0 / a - ba; v1 = y1 / a - ba; x = maxy / a - ba; y = maxy; if (((x >= v0 && x <= v1) || (x >= v1 && x <= v0)) && ((y >= y0 && y <= y1) || (y >= y1 && y <= y0))) { poly_set_pos(cpos, 2, x, y, x0, y0); } x = miny / a - ba; y = miny; if (((x >= v0 && x <= v1) || (x >= v1 && x <= v0)) && ((y >= y0 && y <= y1) || (y >= y1 && y <= y0))) { poly_set_pos(cpos, 3, x, y, x0, y0); } qsort(cpos, 4, sizeof(*cpos), poly_pos_sort_cb); for (i = 0; i < 4; i++) { if (cpos[i].d >= 0) { poly_add_clip_point(pos, minx, miny, maxx, maxy, cpos[i].x, cpos[i].y, fp); } } End: if (x1 >= minx && x1 <= maxx && y1 >= miny && y1 <= maxy) { poly_add_clip_point(pos, minx, miny, maxx, maxy, x1, y1, fp); } return 0; } static void add_polygon_point(struct narray *pos, double x0, double y0, double x1, double y1, struct f2ddata *fp) { double minx, miny, maxx, maxy; if (! fp->dataclip) { poly_add_point(pos, x0, y0, fp); poly_add_point(pos, x1, y1, fp); return; } if (fp->axmin > fp->axmax) { minx = fp->axmax; maxx = fp->axmin; } else { minx = fp->axmin; maxx = fp->axmax; } if (fp->aymax > fp->aymin) { miny = fp->aymin; maxy = fp->aymax; } else { miny = fp->aymax; maxy = fp->aymin; } poly_add_elements(pos, minx, miny, maxx, maxy, x0, y0, x1, y1, fp); } static void uniq_points(struct narray *pos) { int n, i, x0, y0, x1, y1; n = arraynum(pos) / 2 - 1; if (n < 2) { return; } for (i = n; i > 0; i--) { x0 = arraynget_int(pos, i * 2 - 2); y0 = arraynget_int(pos, i * 2 - 1); x1 = arraynget_int(pos, i * 2); y1 = arraynget_int(pos, i * 2 + 1); if (x0 == x1 && y0 == y1) { arrayndel(pos, i * 2 + 1); arrayndel(pos, i * 2); } } n = arraynum(pos) / 2 - 1; if (n < 2) { return; } x0 = arraynget_int(pos, 0); y0 = arraynget_int(pos, 1); x1 = arraynget_int(pos, n * 2); y1 = arraynget_int(pos, n * 2 + 1); if (x0 == x1 && y0 == y1) { arrayndel(pos, n * 2 + 1); arrayndel(pos, n * 2); } } static void draw_polygon(struct narray *pos, int GC, int fill) { int n, *ap; uniq_points(pos); ap = (int *) arraydata(pos); n = arraynum(pos); if (n > 4) { GRAdrawpoly(GC, n / 2, ap, fill); } #if 0 /* for debug */ int i; for (i = 0; i < n / 2; i++) { char buf[256]; GRAmark(GC, 0, ap[i * 2], ap[i * 2 + 1], 200, 0, 0, 0, 255, 0, 0, 0, 255); GRAcolor(GC, 0, 0, 0, 255); sprintf(buf, "%d/%d", i + 1, n / 2); GRAmoveto(GC, ap[i * 2], ap[i * 2 + 1] - i * 500); GRAdrawtext(GC, buf, "Serif", 0, 2000, 0, 0, 7000); } #endif } static int polyout(struct objlist *obj, struct f2ddata *fp, int GC) { int emerr, emnonum, emig, emng; int first; struct narray pos; double x0, y0, x1, y1, x2, y2; arrayinit(&pos, sizeof(int)); emerr = emnonum = emig = emng = FALSE; first = TRUE; while (getdata(fp) == 0) { GRAcolor(GC, fp->col.r, fp->col.g, fp->col.b, fp->col.a); if (fp->dxstat == MATH_VALUE_NORMAL && fp->dystat == MATH_VALUE_NORMAL) { if (first) { first = FALSE; x0 = fp->dx; y0 = fp->dy; x2 = fp->dx; y2 = fp->dy; } else { x1 = x2; y1 = y2; x2 = fp->dx; y2 = fp->dy; add_polygon_point(&pos, x1, y1, x2, y2, fp); } } else { if (fp->dxstat != MATH_VALUE_CONT && fp->dystat != MATH_VALUE_CONT) { if (! first) { add_polygon_point(&pos, x2, y2, x0, y0, fp); } draw_polygon(&pos, GC, GRA_FILL_MODE_WINDING); arraydel(&pos); first = TRUE; } errordisp(obj, fp, &emerr, &emnonum, &emig, &emng); } } if (! first) { add_polygon_point(&pos, x2, y2, x0, y0, fp); } draw_polygon(&pos, GC, GRA_FILL_MODE_WINDING); arraydel(&pos); errordisp(obj, fp, &emerr, &emnonum, &emig, &emng); return 0; } #define FREE_INTP_BUF() \ g_free(x); g_free(y); g_free(z); \ g_free(r); g_free(g); g_free(b); g_free(a); \ g_free(c1); g_free(c2); g_free(c3); \ g_free(c4); g_free(c5); g_free(c6); static int curveout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style, int join,int miter,int intp) { int emerr,emnonum,emig,emng; int j,num; int first; double *x,*y,*z,*c1,*c2,*c3,*c4,*c5,*c6,count; int *r,*g,*b,*a; double c[8]; double bs1[7],bs2[7],bs3[4],bs4[4]; int bsr[7],bsg[7],bsb[7],bsa[7],bsr2[4],bsg2[4],bsb2[4],bsa2[4]; int spcond; emerr=emnonum=emig=emng=FALSE; #if EXPAND_DOTTED_LINE GRAlinestyle(GC,0,NULL,width,GRA_LINE_CAP_BUTT,join,miter); #else GRAlinestyle(GC, snum, style, width, GRA_LINE_CAP_BUTT, join, miter); #endif switch (intp) { case INTERPOLATION_TYPE_SPLINE: case INTERPOLATION_TYPE_SPLINE_CLOSE: num=0; count=0; x=y=z=c1=c2=c3=c4=c5=c6=NULL; r=g=b=a=NULL; while (getdata(fp)==0) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (dataadd(fp->dx,fp->dy,count,fp->col.r,fp->col.g,fp->col.b,fp->col.a,&num, &x,&y,&z,&r,&g,&b,&a,&c1,&c2,&c3,&c4,&c5,&c6)==NULL) return -1; count++; } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (num>=2) { if (intp==INTERPOLATION_TYPE_SPLINE) { spcond=SPLCND2NDDIF; } else { spcond=SPLCNDPERIODIC; if ((x[num-1]!=x[0]) || (y[num-1]!=y[0])) { if (dataadd(x[0],y[0],count,r[0],g[0],b[0],a[0],&num, &x,&y,&z,&r,&g,&b,&a,&c1,&c2,&c3,&c4,&c5,&c6)==NULL) return -1; } } if (spline(z,x,c1,c2,c3,num,spcond,spcond,0,0) || spline(z,y,c4,c5,c6,num,spcond,spcond,0,0)) { FREE_INTP_BUF(); error(obj,ERRSPL); return -1; } GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf, f2dsplinedif,splineint,fp,x[0],y[0]); for (j=0;jdxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (first) { bs1[num]=fp->dx; bs2[num]=fp->dy; bsr[num]=fp->col.r; bsg[num]=fp->col.g; bsb[num]=fp->col.b; bsa[num]=fp->col.a; num++; if (num>=7) { for (j=0;j<2;j++) { bspline(j+1,bs1+j,c); bspline(j+1,bs2+j,c+4); if (j==0) { GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf, f2dbsplinedif,bsplineint,fp,c[0],c[4]); } GRAcolor(GC,bsr[j],bsg[j],bsb[j],bsa[j]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } first=FALSE; } } else { for (j=1;j<7;j++) { bs1[j-1]=bs1[j]; bs2[j-1]=bs2[j]; bsr[j-1]=bsr[j]; bsg[j-1]=bsg[j]; bsb[j-1]=bsb[j]; bsa[j-1]=bsa[j]; } bs1[6]=fp->dx; bs2[6]=fp->dy; bsr[6]=fp->col.r; bsg[6]=fp->col.g; bsb[6]=fp->col.b; bsa[6]=fp->col.a; num++; bspline(0,bs1+1,c); bspline(0,bs2+1,c+4); GRAcolor(GC,bsr[1],bsg[1],bsb[1],bsa[1]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (!first) { for (j=0;j<2;j++) { bspline(j+3,bs1+j+2,c); bspline(j+3,bs2+j+2,c+4); GRAcolor(GC,bsr[j+2],bsg[j+2],bsb[j+2],bsa[j+2]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } first=TRUE; num=0; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (!first) { for (j=0;j<2;j++) { bspline(j+3,bs1+j+2,c); bspline(j+3,bs2+j+2,c+4); GRAcolor(GC,bsr[j+2],bsg[j+2],bsb[j+2],bsa[j+2]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } break; case INTERPOLATION_TYPE_BSPLINE_CLOSE: first=TRUE; num=0; while (getdata(fp)==0) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (first) { bs1[num]=fp->dx; bs3[num]=fp->dx; bs2[num]=fp->dy; bs4[num]=fp->dy; bsr[num]=fp->col.r; bsg[num]=fp->col.g; bsb[num]=fp->col.b; bsa[num]=fp->col.a; bsr2[num]=fp->col.r; bsg2[num]=fp->col.g; bsb2[num]=fp->col.b; bsa2[num]=fp->col.a; num++; if (num>=4) { bspline(0,bs1,c); bspline(0,bs2,c+4); GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf, f2dbsplinedif,bsplineint,fp,c[0],c[4]); GRAcolor(GC,bsr[0],bsg[0],bsb[0],bsa[0]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; first=FALSE; } } else { for (j=1;j<4;j++) { bs1[j-1]=bs1[j]; bs2[j-1]=bs2[j]; bsr[j-1]=bsr[j]; bsg[j-1]=bsg[j]; bsb[j-1]=bsb[j]; bsa[j-1]=bsa[j]; } bs1[3]=fp->dx; bs2[3]=fp->dy; bsr[3]=fp->col.r; bsg[3]=fp->col.g; bsb[3]=fp->col.b; bsa[3]=fp->col.a; num++; bspline(0,bs1,c); bspline(0,bs2,c+4); GRAcolor(GC,bsr[0],bsg[0],bsb[0],bsa[0]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (!first) { for (j=0;j<3;j++) { bs1[4+j]=bs3[j]; bs2[4+j]=bs4[j]; bsr[4+j]=bsr2[j]; bsg[4+j]=bsg2[j]; bsb[4+j]=bsb2[j]; bsa[4+j]=bsa2[j]; bspline(0,bs1+j+1,c); bspline(0,bs2+j+1,c+4); GRAcolor(GC,bsr[j+1],bsg[j+1],bsb[j+1],bsa[j+1]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } first=TRUE; num=0; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (!first) { for (j=0;j<3;j++) { bs1[4+j]=bs3[j]; bs2[4+j]=bs4[j]; bsr[4+j]=bsr2[j]; bsg[4+j]=bsg2[j]; bsb[4+j]=bsb2[j]; bsa[4+j]=bsa2[j]; bspline(0,bs1+j+1,c); bspline(0,bs2+j+1,c+4); GRAcolor(GC,bsr[j+1],bsg[j+1],bsb[j+1],bsa[j+1]); if (!GRAcurve(GC,c,c[0],c[4])) return -1; } } break; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static int rectout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style,int type) { int emerr,emnonum,emig,emng; double x0,y0,x1,y1; int gx0,gy0,gx1,gy1,ax0,ay0; double dx,dy,len,alen,awidth; int ap[8],headlen,headwidth; emerr=emnonum=emig=emng=FALSE; headlen=72426; headwidth=60000; if (type == PLOT_TYPE_DIAGONAL) GRAlinestyle(GC,snum,style,width,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); else GRAlinestyle(GC,snum,style,width,GRA_LINE_CAP_PROJECTING,GRA_LINE_JOIN_MITER,1000); while (getdata(fp)==0) { GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->d2),&(fp->d3))==0)) { if (type == PLOT_TYPE_DIAGONAL) { x0=fp->dx; y0=fp->dy; x1=fp->d2; y1=fp->d3; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); GRAline(GC,gx0,gy0,gx1,gy1); } } if (type == PLOT_TYPE_ARROW) { x0=fp->dx; y0=fp->dy; x1=fp->d2; y1=fp->d3; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); if ((x1==fp->d2) && (y1==fp->d3) && (fp->msize>0)) { alen=fp->msize; awidth=fp->msize*(double )headwidth/(double )headlen/2; dx=gx1-gx0; dy=gy1-gy0; len=sqrt(dx*dx+dy*dy); if (len>0) { ax0=nround(gx1-dx*alen/len); ay0=nround(gy1-dy*alen/len); ap[0]=nround(ax0-dy/len*awidth); ap[1]=nround(ay0+dx/len*awidth); ap[2]=gx1; ap[3]=gy1; ap[4]=nround(ax0+dy/len*awidth); ap[5]=nround(ay0-dx/len*awidth); GRAline(GC,gx0,gy0,ax0,ay0); GRAdrawpoly(GC,3,ap,GRA_FILL_MODE_EVEN_ODD); } } else GRAline(GC,gx0,gy0,gx1,gy1); } } if (type == PLOT_TYPE_RECTANGLE_FILL || type == PLOT_TYPE_RECTANGLE_SOLID_FILL) { if (type == PLOT_TYPE_RECTANGLE_FILL) { GRAcolor(GC, fp->col2.r, fp->col2.g, fp->col2.b, fp->col2.a); } x0=fp->dx; y0=fp->dy; x1=fp->d2; y1=fp->d3; if (f2drectclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0, y0, ap + 0, ap + 1, fp); f2dtransf(x0, y1, ap + 2, ap + 3, fp); f2dtransf(x1, y1, ap + 4, ap + 5, fp); f2dtransf(x1, y0, ap + 6, ap + 7, fp); GRAdrawpoly(GC, 4, ap, GRA_FILL_MODE_EVEN_ODD); } if (type == PLOT_TYPE_RECTANGLE_FILL) { GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); } } if (type == PLOT_TYPE_RECTANGLE || type == PLOT_TYPE_RECTANGLE_FILL) { x0=fp->dx; y0=fp->dy; x1=fp->dx; y1=fp->d3; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); GRAline(GC,gx0,gy0,gx1,gy1); } x0=fp->dx; y0=fp->d3; x1=fp->d2; y1=fp->d3; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); GRAline(GC,gx0,gy0,gx1,gy1); } x0=fp->d2; y0=fp->d3; x1=fp->d2; y1=fp->dy; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); GRAline(GC,gx0,gy0,gx1,gy1); } x0=fp->d2; y0=fp->dy; x1=fp->dx; y1=fp->dy; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)==0) { f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); GRAline(GC,gx0,gy0,gx1,gy1); } } } else errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static void draw_errorbar(struct f2ddata *fp, int GC, int size, double dx0, double dy0, double dx1, double dy1) { double x0, y0, x1, y1, x, y, r, dirx, diry; int gx0, gy0, gx1, gy1; x0 = dx0; y0 = dy0; x1 = dx1; y1 = dy1; if (f2dlineclipf(&x0, &y0, &x1, &y1, fp)) { return; } f2dtransf(x0, y0, &gx0, &gy0, fp); f2dtransf(x1, y1, &gx1, &gy1, fp); x = gx1 - gx0; y = gy1 - gy0; r = sqrt(x * x + y * y); if (r == 0) { return; } dirx = x / r; diry = y / r; GRAline(GC, gx0, gy0, gx1, gy1); if (dx0 == x0 && dy0 == y0) { GRAline(GC, gx0 + nround(size * diry), gy0 - nround(size * dirx), gx0 - nround(size * diry), gy0 + nround(size * dirx)); } if (dx1 == x1 && dy1 == y1) { GRAline(GC, gx1 + nround(size * diry), gy1 - nround(size * dirx), gx1 - nround(size * diry), gy1 + nround(size * dirx)); } } static int errorbarout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style,int type) { int emerr,emnonum,emig,emng; int size; emerr=emnonum=emig=emng=FALSE; GRAlinestyle(GC,snum,style,width,GRA_LINE_CAP_BUTT,GRA_LINE_JOIN_MITER,1000); while (getdata(fp)==0) { size=fp->marksize0/2; GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); if (type == PLOT_TYPE_ERRORBAR_X) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0) && (getposition2(fp,fp->axtype,fp->axtype,&(fp->d2),&(fp->d3))==0)) { draw_errorbar(fp, GC, size, fp->d2, fp->dy, fp->d3, fp->dy); } else errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } else if (type == PLOT_TYPE_ERRORBAR_Y) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0) && (getposition2(fp,fp->aytype,fp->aytype,&(fp->d2),&(fp->d3))==0)) { draw_errorbar(fp, GC, size, fp->dx, fp->d2, fp->dx, fp->d3); } else errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static int stairout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style, int join,int miter,int type) { int emerr,emnonum,emig,emng; int num; double x0,y0,x1,y1,x,y,dx,dy; emerr=emnonum=emig=emng=FALSE; #if EXPAND_DOTTED_LINE GRAlinestyle(GC,0,NULL,width,GRA_LINE_CAP_BUTT,join,miter); #else GRAlinestyle(GC, snum, style, width, GRA_LINE_CAP_BUTT, join, miter); #endif num=0; while (getdata(fp)==0) { GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (num==0) { x0=fp->dx; y0=fp->dy; num++; } else if (num==1) { x1=fp->dx; y1=fp->dy; if (type == PLOT_TYPE_STAIRCASE_X) { dx=(x1-x0)*0.5; y=y0; x=x0-dx; GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf,NULL,NULL,fp,x,y); x=x0+dx; GRAdashlinetod(GC,x,y); y=y1; GRAdashlinetod(GC,x,y); } else { dy=(y1-y0)*0.5; x=x0; y=y0-dy; GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf,NULL,NULL,fp,x,y); y=y0+dy; GRAdashlinetod(GC,x,y); x=x1; GRAdashlinetod(GC,x,y); } x0=x1; y0=y1; num++; } else { x1=fp->dx; y1=fp->dy; if (type == PLOT_TYPE_STAIRCASE_X) { dx=(x1-x0)*0.5; y=y0; x=x0+dx; GRAdashlinetod(GC,x,y); y=y1; GRAdashlinetod(GC,x,y); } else { dy=(y1-y0)*0.5; x=x0; y=y0+dy; GRAdashlinetod(GC,x,y); x=x1; GRAdashlinetod(GC,x,y); } x0=x1; y0=y1; } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (num!=0) { if (type == PLOT_TYPE_STAIRCASE_X) { dx=x0-x; x=x0+dx; GRAdashlinetod(GC,x,y); } else { dy=y0-y; y=y0+dy; GRAdashlinetod(GC,x,y); } } num=0; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (num!=0) { if (type == PLOT_TYPE_STAIRCASE_X) { dx=x0-x; x=x0+dx; GRAdashlinetod(GC,x,y); } else { dy=y0-y; y=y0+dy; GRAdashlinetod(GC,x,y); } } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static void draw_rect(int GC, int *ap, double v0, double v1, double v2, double v3) { GRAline(GC, ap[0], ap[1], ap[2] ,ap[3]); if (v0 == v1) { GRAline(GC, ap[2], ap[3], ap[4] ,ap[5]); } GRAline(GC, ap[4], ap[5], ap[6] ,ap[7]); if (v2 == v3) { GRAline(GC, ap[6], ap[7], ap[0] ,ap[1]); } } static int barout(struct objlist *obj,struct f2ddata *fp,int GC, int width,int snum,int *style,int type) { int emerr,emnonum,emig,emng; double x0,y0,x1,y1; int gx0,gy0,gx1,gy1; int size; int ap[8]; emerr=emnonum=emig=emng=FALSE; if (type <= PLOT_TYPE_BAR_FILL_Y) GRAlinestyle(GC,snum,style,width,GRA_LINE_CAP_PROJECTING,GRA_LINE_JOIN_MITER,1000); while (getdata(fp)==0) { size=fp->marksize0/2; if (fp->dxstat != MATH_VALUE_NORMAL || fp->dystat != MATH_VALUE_NORMAL || getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))) { errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); continue; } switch (type) { case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_SOLID_FILL_X: case PLOT_TYPE_BAR_X: x0=0; y0=fp->dy; x1=fp->dx; y1=fp->dy; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)) { break; } f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); ap[0]=gx0+nround(size*fp->ayvx); ap[1]=gy0+nround(size*fp->ayvy); ap[2]=gx1+nround(size*fp->ayvx); ap[3]=gy1+nround(size*fp->ayvy); ap[4]=gx1-nround(size*fp->ayvx); ap[5]=gy1-nround(size*fp->ayvy); ap[6]=gx0-nround(size*fp->ayvx); ap[7]=gy0-nround(size*fp->ayvy); switch (type) { case PLOT_TYPE_BAR_X: GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); draw_rect(GC, ap, x1, fp->dx, x0, 0); break; case PLOT_TYPE_BAR_SOLID_FILL_X: GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); GRAdrawpoly(GC,4,ap,GRA_FILL_MODE_EVEN_ODD); break; case PLOT_TYPE_BAR_FILL_X: GRAcolor(GC, fp->col2.r, fp->col2.g, fp->col2.b, fp->col2.a); GRAdrawpoly(GC,4,ap,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); draw_rect(GC, ap, x1, fp->dx, x0, 0); break; } break; case PLOT_TYPE_BAR_FILL_Y: case PLOT_TYPE_BAR_SOLID_FILL_Y: case PLOT_TYPE_BAR_Y: x0=fp->dx; y0=0; x1=fp->dx; y1=fp->dy; if (f2dlineclipf(&x0,&y0,&x1,&y1,fp)) { break; } f2dtransf(x0,y0,&gx0,&gy0,fp); f2dtransf(x1,y1,&gx1,&gy1,fp); ap[0]=gx0+nround(size*fp->axvx); ap[1]=gy0+nround(size*fp->axvy); ap[2]=gx1+nround(size*fp->axvx); ap[3]=gy1+nround(size*fp->axvy); ap[4]=gx1-nround(size*fp->axvx); ap[5]=gy1-nround(size*fp->axvy); ap[6]=gx0-nround(size*fp->axvx); ap[7]=gy0-nround(size*fp->axvy); switch (type) { case PLOT_TYPE_BAR_Y: GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); draw_rect(GC, ap, y1, fp->dy, y0, 0); break; case PLOT_TYPE_BAR_SOLID_FILL_Y: GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); GRAdrawpoly(GC,4,ap,GRA_FILL_MODE_EVEN_ODD); break; case PLOT_TYPE_BAR_FILL_Y: GRAcolor(GC, fp->col2.r, fp->col2.g, fp->col2.b, fp->col2.a); GRAdrawpoly(GC,4,ap,GRA_FILL_MODE_EVEN_ODD); GRAcolor(GC,fp->col.r,fp->col.g,fp->col.b, fp->col.a); draw_rect(GC, ap, y1, fp->dy, y0, 0); break; } break; } } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); return 0; } static int calc_weight(struct objlist *obj, struct f2dlocal *f2dlocal, struct f2ddata *fp, const char *weight, struct narray *data, struct narray *index) { MathEquation *code; MathEquationParametar *prm; double dd; int emerr, emserr, emnonum, emig, emng, two_pass, maxdim, ddstat, rcode, datanum2, i, j; int const_id[MATH_CONST_SIZE]; code = ofile_create_math_equation(const_id, 3, FALSE, TRUE, FALSE, FALSE, TRUE); if (code == NULL) { return 1; } rcode = math_equation_parse(code, weight); if (rcode) { math_equation_free(code); return 1; } prm = math_equation_get_parameter(code, 0, NULL); maxdim = (prm) ? prm->id_max : 0; two_pass = math_equation_check_const(code, const_id, TWOPASS_CONST_SIZE); if (two_pass) { reopendata(fp); if (getminmaxdata(fp, f2dlocal) == -1) { math_equation_free(code); return 1; } } if (maxdim < fp->x) maxdim = fp->x; if (maxdim < fp->y) maxdim = fp->y; datanum2 = fp->datanum; reopendata(fp); if (hskipdata(fp) != 0) { math_equation_free(code); return 1; } fp->datanum = datanum2; if (set_const(code, const_id, two_pass, fp, TRUE)) { math_equation_free(code); return 1; } emerr = emserr = emnonum = emig = emng = FALSE; for (i = j = 0; getdata2(fp, code, maxdim, &dd, &ddstat) == 0; i++) { int *line; line = (int *) arraynget(index, j); if (line == NULL) { break; } else if (*line != i) { continue; } j++; if (ddstat == MATH_VALUE_NORMAL) { if (arrayadd(data, &dd) == NULL) { return -1; } } else { errordisp2(obj, fp, &emerr, &emnonum, &emig, &emng, ddstat, "weight"); } } math_equation_free(code); if (arraynum(data) == 0) { return -1; } return 0; } static int calc_fit(struct objlist *obj, struct f2dlocal *f2dlocal, struct f2ddata *fp, struct objlist *fitobj, int fit_id) { int emerr, emserr, emnonum, emig, emng, i, rcode; struct narray data, index; char *weight, *argv[2]; double dnum; arrayinit(&data,sizeof(double)); arrayinit(&index,sizeof(int)); emerr = emserr = emnonum = emig = emng = FALSE; for (i = 0; getdata(fp)==0; i++) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if (arrayadd(&data, &fp->dx) == NULL || arrayadd(&data, &fp->dy) == NULL || arrayadd(&index, &i) == NULL) { arraydel(&index); arraydel(&data); return -1; } } else { errordisp(obj, fp, &emerr, &emnonum, &emig, &emng); } } errordisp(obj, fp, &emerr, &emnonum, &emig, &emng); if ((dnum=(double )arraynum(&data))==0) { arraydel(&index); arraydel(&data); return -1; } dnum /= 2; if (arrayins(&data, &dnum, 0) == NULL) { arraydel(&index); arraydel(&data); return -1; } if (getobj(fitobj, "weight_func", fit_id, 0, NULL, &weight) == -1) { arraydel(&index); arraydel(&data); return -1; } if (weight) { rcode = calc_weight(obj, f2dlocal, fp, weight, &data, &index); if (rcode) { arraydel(&index); arraydel(&data); return rcode; } } arraydel(&index); argv[0] = (void *) (&data); argv[1] = NULL; if (exeobj(fitobj, "fit", fit_id, 1, argv)) { arraydel(&data); return -1; } arraydel(&data); return 0; } #define MATH_EQUATION_FREE(eq) math_equation_free(eq) static int draw_interpolation(struct f2ddata *fp, int GC, int num, int snum, int *style, double *c, double *x, double *y, double *z, double *c1, double *c2, double *c3, double *c4, double *c5, double *c6) { int j, spcond; spcond = SPLCND2NDDIF; if (spline(z, x, c1, c2, c3, num, spcond, spcond, 0, 0) || spline(z, y, c4, c5, c6, num, spcond, spcond, 0, 0)) { return -1; } GRAcurvefirst(GC, snum, style, f2dlineclipf, f2dtransf, f2dsplinedif, splineint, fp, x[0], y[0]); for (j = 0; j < num - 1; j++) { c[0] = c1[j]; c[1] = c2[j]; c[2] = c3[j]; c[3] = c4[j]; c[4] = c5[j]; c[5] = c6[j]; if (GRAcurve(GC, c, x[j], y[j]) == 0) { break; } } return 0; } static int draw_fit(struct objlist *obj, struct f2ddata *fp, int GC, struct objlist *fitobj, N_VALUE *fit_inst, int width, int snum, int *style, int join, int miter) { char *equation; double min, max, dx, dy; int i, div, interpolation, first, rcode, num, emerr; int *r, *g, *b, *a; double c[8], *x, *y, *z, *c1, *c2, *c3, *c4, *c5, *c6, count; MathEquation *code; MathValue val; if (_getobj(fitobj, "equation", fit_inst, &equation)) return -1; if (_getobj(fitobj, "min", fit_inst, &min)) return -1; if (_getobj(fitobj, "max", fit_inst, &max)) return -1; if (_getobj(fitobj, "div", fit_inst, &div)) return -1; if (_getobj(fitobj, "interpolation", fit_inst, &interpolation)) return -1; if (equation==NULL) return -1; if ((min==0) && (max==0)) { min=fp->axmin2; max=fp->axmax2; } else if (min==max) return 0; code = ofile_create_math_equation(NULL, 0, FALSE, FALSE, FALSE, FALSE, TRUE); if (code == NULL) { return 1; } rcode = math_equation_parse(code, equation); if (rcode) { math_equation_free(code); return 1; } rcode = math_equation_optimize(code); if (rcode) { math_equation_free(code); return 1; } if (code->exp == NULL) { math_equation_free(code); return 1; } GRAcolor(GC,fp->color.r,fp->color.g,fp->color.b, fp->color.a); #if EXPAND_DOTTED_LINE GRAlinestyle(GC,0,NULL,width,GRA_LINE_CAP_BUTT,join,miter); #else GRAlinestyle(GC, snum, style, width, GRA_LINE_CAP_BUTT, join, miter); #endif num=0; count=0; emerr=FALSE; x=y=z=c1=c2=c3=c4=c5=c6=NULL; r=g=b=a=NULL; first=TRUE; for (i=0;i<=div;i++) { dx=min+(max-min)/div*i; val.val = dx; val.type = MATH_VALUE_NORMAL; math_equation_set_var(code, 0, &val); math_equation_calculate(code, &val); dy = val.val; if (interpolation) { if ((val.type==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0)) { if (dataadd(dx,dy,count,0,0,0,255,&num, &x,&y,&z,&r,&g,&b,&a,&c1,&c2,&c3,&c4,&c5,&c6)==NULL) { MATH_EQUATION_FREE(code); return -1; } count++; } else { if (num >= 2 && draw_interpolation(fp, GC, num, snum, style, c, x, y, z, c1, c2, c3, c4, c5, c6)) { FREE_INTP_BUF(); MATH_EQUATION_FREE(code); error(obj,ERRSPL); return -1; } FREE_INTP_BUF(); num=0; count=0; x=y=z=c1=c2=c3=c4=c5=c6=NULL; r=g=b=a=NULL; } } else { if ((val.type==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0)) { if (first) { GRAcurvefirst(GC,snum,style,f2dlineclipf,f2dtransf,NULL,NULL,fp,dx,dy); first=FALSE; } else { GRAdashlinetod(GC,dx,dy); } } else { first=TRUE; } } if ((!emerr) && (val.type!=MATH_VALUE_NORMAL) && (val.type!=MATH_VALUE_UNDEF)) { error(obj,ERRMERR); emerr=TRUE; } } MATH_EQUATION_FREE(code); if (interpolation) { if (num > 0 && draw_interpolation(fp, GC, num, snum, style, c, x, y, z, c1, c2, c3, c4, c5, c6)) { FREE_INTP_BUF(); error(obj,ERRSPL); return -1; } FREE_INTP_BUF(); } return 0; } static int get_fit_obj_id(char *fit, struct objlist **fitobj, N_VALUE **inst) { struct narray iarray; int anum, id; if (fit == NULL) { return -1; } arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, fitobj, &iarray, FALSE, NULL)) { return -1 ; } anum = arraynum(&iarray); if (anum < 1) { arraydel(&iarray); return -1 ; } id = arraylast_int(&iarray); arraydel(&iarray); *inst = getobjinst(*fitobj, id); if (*inst == NULL) { return -1 ; } return id; } static void dummyout(struct objlist *obj, struct f2ddata *fp, int GC, int width, int snum, int *style, int join, int miter) { GRAlinestyle(GC, snum, style, width, GRA_LINE_CAP_BUTT, join, miter); while (! getdata(fp)); } static int fitout(struct objlist *obj,struct f2dlocal *f2dlocal, struct f2ddata *fp,int GC, int width,int snum,int *style, int join,int miter,char *fit,int redraw) { struct objlist *fitobj; int id; N_VALUE *inst; char *equation; int rcode; if (fit == NULL) { error(obj, ERRNOFIT); return -1; } id = get_fit_obj_id(fit, &fitobj, &inst); if (id < 0) { error2(obj, ERRNOFITINST, fit); return -1; } if (_getobj(fitobj, "equation", inst, &equation)) { return -1; } if (equation == NULL && redraw == 0) { f2dlocal->use_drawing_func = FALSE; rcode = calc_fit(obj, f2dlocal, fp, fitobj, id); if (rcode) { return rcode; } } else if (f2dlocal->use_drawing_func) { dummyout(obj, fp, GC, width, snum, style, join, miter); } return draw_fit(obj, fp, GC, fitobj, inst, width, snum, style, join, miter); } static int f2ddraw(struct objlist *obj, N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; int GC; int type, src; int mtype; int lwidth, ljoin, lmiter, intp; struct narray *lstyle; int snum, *style; struct f2ddata *fp; int rcode; int w, h, clip, zoom; char *fit, *field, *array; char *file; struct array_prm ary; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; _getobj(obj, "_local", inst, &f2dlocal); _getobj(obj, "source", inst, &src); _getobj(obj, "GC", inst, &GC); if (GC<0) return 0; switch (src) { case DATA_SOURCE_FILE: _getobj(obj, "file", inst, &file); if (file == NULL){ return 0; } break; case DATA_SOURCE_ARRAY: _getobj(obj,"array", inst, &array); open_array(array, &ary); if (ary.data_num < 1) { return 0; } break; } _getobj(obj, "type", inst, &type); _getobj(obj, "mark_type", inst, &mtype); _getobj(obj, "line_width", inst, &lwidth); _getobj(obj, "line_style", inst, &lstyle); _getobj(obj, "line_join", inst, &ljoin); _getobj(obj, "line_miter_limit", inst, &lmiter); _getobj(obj, "interpolation", inst, &intp); _getobj(obj, "fit", inst, &fit); _getobj(obj, "clip", inst, &clip); snum = arraynum(lstyle); style = arraydata(lstyle); fp = opendata(obj, inst, f2dlocal, TRUE, FALSE); if (fp == NULL) { return 1; } fp->GC = GC; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal) == -1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)) { closedata(fp, f2dlocal); return 1; } if (set_const_all(fp)) return 1; GRAregion(GC, &w, &h, &zoom); GRAview(GC, 0, 0, w*10000.0/zoom, h*10000.0/zoom, clip); switch (type) { case PLOT_TYPE_MARK: rcode = markout(obj, fp, GC, lwidth, snum, style); break; case PLOT_TYPE_LINE: rcode = lineout(obj, fp, GC, lwidth, snum, style, ljoin, lmiter, FALSE); break; case PLOT_TYPE_POLYGON: rcode = lineout(obj, fp, GC, lwidth, snum, style, ljoin, lmiter, TRUE); break; case PLOT_TYPE_POLYGON_SOLID_FILL: rcode = polyout(obj, fp, GC); break; case PLOT_TYPE_CURVE: rcode = curveout(obj, fp, GC, lwidth, snum, style, ljoin, lmiter, intp); break; case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: rcode = rectout(obj, fp, GC, lwidth, snum, style, type); break; case PLOT_TYPE_ERRORBAR_X: rcode = errorbarout(obj, fp, GC, lwidth, snum, style, type); break; case PLOT_TYPE_ERRORBAR_Y: rcode = errorbarout(obj, fp, GC, lwidth, snum, style, type); break; case PLOT_TYPE_STAIRCASE_X: case PLOT_TYPE_STAIRCASE_Y: rcode = stairout(obj, fp, GC, lwidth, snum, style, ljoin, lmiter, type); break; case PLOT_TYPE_BAR_X: case PLOT_TYPE_BAR_Y: case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_FILL_Y: case PLOT_TYPE_BAR_SOLID_FILL_X: case PLOT_TYPE_BAR_SOLID_FILL_Y: rcode = barout(obj, fp, GC, lwidth, snum, style, type); break; case PLOT_TYPE_FIT: field = (char *)argv[1]; rcode = fitout(obj, f2dlocal, fp, GC, lwidth, snum, style, ljoin, lmiter, fit, field[0] == 'r'); if (fp->datanum == 0) fp->datanum = f2dlocal->num; break; default: /* not reachable */ rcode = -1; } closedata(fp, f2dlocal); if (rcode == -1) return 1; GRAaddlist(GC, obj, inst, (char *) argv[0], "redraw"); return 0; } static int f2dgetcoord(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { double x,y; int gx,gy; int id; double ip1,ip2; int dataclip; double minx,maxx,miny,maxy; double v1x,v1y,v2x,v2y,vx,vy; double a,b,c,d; struct narray *array; struct axis_prm ax_prm, ay_prm; x=*(double *)argv[2]; y=*(double *)argv[3]; _getobj(obj,"data_clip",inst,&dataclip); id = get_axis_prm(obj, inst, AXIS_X, &ax_prm); if (id < 0) { return 1; } id = get_axis_prm(obj, inst, AXIS_Y, &ay_prm); if (id < 0) { return 1; } ip1=-ax_prm.vy*ay_prm.vx+ax_prm.vx*ay_prm.vy; ip2=-ay_prm.vy*ax_prm.vx+ay_prm.vx*ax_prm.vy; if ((fabs(ip1)<=1e-15) || (fabs(ip2)<=1e-15)) return 1; gx=gy=0; minx=ax_prm.min; maxx=ax_prm.max; miny=ay_prm.min; maxy=ay_prm.max; if (ax_prm.type == AXIS_TYPE_LOG) { if (x == 0) { return -1; } else if (x < 0) { x = fabs(x); } x = log10(x); } else if (ax_prm.type == AXIS_TYPE_INVERSE) { if (x == 0) { return -1; } x = 1 / x; } if (ay_prm.type == AXIS_TYPE_LOG) { if (y == 0) { return -1; } else if (y < 0) { y = fabs(y); } y = log10(y); } else if (ay_prm.type == AXIS_TYPE_INVERSE) { if (y == 0) { return -1; } y = 1 / y; } if (dataclip && ((((minx>x) || (x>maxx)) && ((maxx>x) || (x>minx))) || (((miny>y) || (y>maxy)) && ((maxy>y) || (y>miny))))) return 1; v1x=ax_prm.rate*(x-minx)*ax_prm.vx; v1y=ax_prm.rate*(x-minx)*ax_prm.vy; v2x=ay_prm.rate*(y-miny)*ay_prm.vx; v2y=ay_prm.rate*(y-miny)*ay_prm.vy; vx=ay_prm.posx-ax_prm.posx+v2x-v1x; vy=ay_prm.posy-ax_prm.posy+v2y-v1y; a=ay_prm.vy*ax_prm.vx-ay_prm.vx*ax_prm.vy; c=-ay_prm.vy*vx+ay_prm.vx*vy; b=ax_prm.vy*ay_prm.vx-ax_prm.vx*ay_prm.vy; d=ax_prm.vy*vx-ax_prm.vx*vy; if ((fabs(a)<=1e-16) && (fabs(b)<=1e-16)) { return -1; } else if (fabs(b)<=1e-16) { a=c/a; gx=ay_prm.posx+nround(v2x+a*ax_prm.vx); gy=ay_prm.posy+nround(v2y+a*ax_prm.vy); } else { b=d/b; gx=ax_prm.posx+nround(v1x+b*ay_prm.vx); gy=ax_prm.posy+nround(v1y+b*ay_prm.vy); } array=rval->array; if (arraynum(array) > 0) { arraydel(array); } if ((array==NULL) && ((array=arraynew(sizeof(double)))==NULL)) return 1; arrayins(array,&gy,0); arrayins(array,&gx,0); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } rval->array=array; return 0; } static int f2devaluate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; char *str; struct narray *array; int gx0,gy0,gx1,gy1,num,limit; int minx,miny,maxx,maxy,err; double line,dx,dy,d2,d3; int src; array=rval->array; arrayfree(array); array=NULL; rval->array=array; _getobj(obj,"source", inst, &src); switch (src) { case DATA_SOURCE_FILE: _getobj(obj, "file", inst, &str); if (str == NULL) { return 0; } break; case DATA_SOURCE_ARRAY: _getobj(obj, "array", inst, &str); if (str == NULL) { return 0; } break; case DATA_SOURCE_RANGE: break; } _getobj(obj,"_local",inst,&f2dlocal); if ((fp=opendata(obj,inst,f2dlocal,TRUE,FALSE))==NULL) return 1; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); return 1; } array=arraynew(sizeof(double)); minx=*(int *)argv[2]; miny=*(int *)argv[3]; maxx=*(int *)argv[4]; maxy=*(int *)argv[5]; err=*(int *)argv[6]; limit=*(int *)argv[7]; if ((minx==maxx) && (miny==maxy)) { minx-=err; maxx+=err; miny-=err; maxy+=err; } if (set_const_all(fp)) return 1; while (getdata(fp)==0) { switch (fp->type) { case TYPE_NORMAL: dx=fp->dx; dy=fp->dy; if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0)) { f2dtransf(dx,dy,&gx0,&gy0,fp); line=fp->dline; if ((minx<=gx0) && (gx0dx)); arrayadd(array,&(fp->dy)); } } break; case TYPE_DIAGONAL: dx=fp->dx; dy=fp->dy; d2=fp->d2; d3=fp->d3; if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0) && (getposition2(fp,fp->axtype,fp->aytype,&d2,&d3)==0)) { f2dtransf(dx,dy,&gx0,&gy0,fp); f2dtransf(d2,d3,&gx1,&gy1,fp); line=fp->dline; if ((minx<=gx0) && (gx0dx)); arrayadd(array,&(fp->dy)); } if ((minx<=gx1) && (gx1d2)); arrayadd(array,&(fp->d3)); } } break; case TYPE_ERR_X: dx=fp->dx; dy=fp->dy; d2=fp->d2; d3=fp->d3; if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0) && (getposition2(fp,fp->axtype,fp->axtype,&d2,&d3)==0)) { f2dtransf(d2,dy,&gx0,&gy0,fp); f2dtransf(d3,dy,&gx1,&gy1,fp); line=fp->dline; if ((minx<=gx0) && (gx0d2)); arrayadd(array,&(fp->dy)); } if ((minx<=gx1) && (gx1d3)); arrayadd(array,&(fp->dy)); } } break; case TYPE_ERR_Y: dx=fp->dx; dy=fp->dy; d2=fp->d2; d3=fp->d3; if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&dx,&dy)==0) && (getposition2(fp,fp->aytype,fp->aytype,&d2,&d3)==0)) { f2dtransf(dx,d2,&gx0,&gy0,fp); f2dtransf(dx,d3,&gx1,&gy1,fp); line=fp->dline; if ((minx<=gx0) && (gx0dx)); arrayadd(array,&(fp->d2)); } if ((minx<=gx1) && (gx1dx)); arrayadd(array,&(fp->d3)); } } break; } if ((int) arraynum(array) >= (limit * 3)) break; } closedata(fp, f2dlocal); num=arraynum(array); if (num/3>0) rval->array=array; else arrayfree(array); return 0; } static int f2dredraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int redrawf, num, dmax, type, source, hidden, r; int GC; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"hidden",inst,&hidden); _getobj(obj,"source",inst,&source); _getobj(obj,"redraw_flag",inst,&redrawf); _getobj(obj,"data_num",inst,&num); _getobj(obj,"redraw_num",inst,&dmax); _getobj(obj, "type", inst, &type); r = 0; if (num > 0 && (dmax == 0 || num <= dmax) && redrawf) { r = f2ddraw(obj,inst,rval,argc,argv); } else if (source == DATA_SOURCE_RANGE && redrawf) { r = f2ddraw(obj,inst,rval,argc,argv); } else { if (! hidden) { system_draw_notify(); } _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); } if (r) { system_draw_notify(); } return 0; } static int f2dcolumn_file(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file,*ifs; int csv; int cline,ccol; int line,col; FILE *fd; int rcode; char *buf,*buf2; char *po,*po2; g_free(rval->str); rval->str=NULL; _getobj(obj,"file",inst,&file); _getobj(obj,"ifs",inst,&ifs); _getobj(obj,"csv",inst,&csv); line=*(int *)argv[2]; col=*(int *)argv[3]; if (line<=0) return 0; if (col<=0) col=0; if (file==NULL) return 0; if ((fd=nfopen(file,"rt"))==NULL) return 0; cline=0; while (TRUE) { if ((rcode=fgetline(fd,&buf))!=0) { fclose(fd); return 1; } cline++; if (cline==line) { if (col==0) rval->str=buf; else { ccol=0; po=buf; while (TRUE) { ccol++; if (*po=='\0') break; if (csv) { for (;*po==' ';po++); if (*po=='\0') break; if (strchr(ifs,*po)!=NULL) { if (ccol==col) break; else po++; } else { for (po2=po;(*po2!='\0') && (strchr(ifs,*po2)==NULL) && (*po2!=' ');po2++); if (ccol==col) { if ((buf2=g_malloc(po2-po+1))==NULL) { fclose(fd); g_free(buf); return 1; } strncpy(buf2,po,po2-po); buf2[po2-po]='\0'; rval->str=buf2; break; } else { for (;*po2==' ';po2++); if (strchr(ifs,*po2)!=NULL) po2++; po=po2; } } } else { for (;(*po!='\0') && (strchr(ifs,*po)!=NULL);po++); if (*po=='\0') break; for (po2=po;(*po2!='\0') && (strchr(ifs,*po2)==NULL);po2++); if (ccol==col) { if ((buf2=g_malloc(po2-po+1))==NULL) { fclose(fd); g_free(buf); return 1; } strncpy(buf2,po,po2-po); buf2[po2-po]='\0'; rval->str=buf2; break; } else po=po2; } } g_free(buf); } break; } else g_free(buf); } fclose(fd); return 0; } static int f2dcolumn_array(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct array_prm ary; int line, col, n; char *array; double val; g_free(rval->str); rval->str = NULL; line=*(int *)argv[2]; col=*(int *)argv[3]; _getobj(obj,"array", inst, &array); open_array(array, &ary); if (col >= ary.col_num) { return 0; } n = arraynum(ary.ary[col - 1]); if (line < 1 || line >= n) { return 0; } val = arraynget_double(ary.ary[col - 1], line - 1); rval->str = g_strdup_printf("%.15e", val); return 0; } static int f2dcolumn_range(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int line, col, div; double val, min, max; g_free(rval->str); rval->str = NULL; line=*(int *)argv[2]; col=*(int *)argv[3]; _getobj(obj, "range_min", inst, &min); _getobj(obj, "range_max", inst, &max); _getobj(obj, "range_div", inst, &div); if (col >= 2) { return 0; } if (line < 1 || line >= div) { return 0; } val = min + (max - min) / div * line; rval->str = g_strdup_printf("%.15e", val); return 0; } static int f2dcolumn(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r, src; _getobj(obj,"source", inst, &src); r = 1; switch (src) { case DATA_SOURCE_FILE: r = f2dcolumn_file(obj, inst, rval, argc, argv); break; case DATA_SOURCE_ARRAY: r = f2dcolumn_array(obj, inst, rval, argc, argv); break; case DATA_SOURCE_RANGE: r = f2dcolumn_range(obj, inst, rval, argc, argv); break; } return r; } static int f2dhead_file(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int cline, line; char *file, *ptr; GString *s; FILE *fd; g_free(rval->str); rval->str = NULL; _getobj(obj, "file", inst, &file); line = *(int *) argv[2]; if (line <= 0) return 0; if (file == NULL) return 0; fd = nfopen(file, "rt"); if (fd == NULL) return 0; s = g_string_sized_new(256); if (s == NULL) { fclose(fd); return 0; } for (cline = 0; cline < line; cline++) { if (fgetline(fd, &ptr)) { break; } if (cline) { s = g_string_append_c(s, '\n'); } g_string_append_printf(s, "%s", ptr); g_free(ptr); } fclose(fd); rval->str = g_string_free(s, FALSE); return 0; } static int f2dhead(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r, src; _getobj(obj,"source", inst, &src); r = 1; switch (src) { case DATA_SOURCE_FILE: r = f2dhead_file(obj, inst, rval, argc, argv); break; case DATA_SOURCE_ARRAY: case DATA_SOURCE_RANGE: break; } return r; } static int f2dsettings_file(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; FILE *fd; int err; char *buf, *rem; char *po,*endptr; int d1,d2,d3; double f1,f2,f3; int i,j,id; char *s; struct narray *iarray; struct objlist *aobj; int aid,x; _getobj(obj,"file",inst,&file); if (file==NULL) return 0; if ((fd=nfopen(file,"rt"))==NULL) return 0; if (fgetline(fd,&buf)!=0) { fclose(fd); return 1; } _getobj(obj,"id",inst,&id); fclose(fd); po=buf; err=FALSE; sgetobjfield(obj, id, "remark", NULL, &rem, FALSE, FALSE, FALSE); if (rem && strchr(rem, po[0])) po++; g_free(rem); while (po[0]!='\0') { for (;(po[0]!='\0') && (strchr(" \t",po[0])!=NULL);po++); if (po[0]=='-') { switch (po[1]) { case 'x': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"x",id,&d1); } break; case 'y': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"y",id,&d1); } break; case 'd': for (i = PLOT_TYPE_FIT; i >= 0; i--) { if (strncmp(f2dtypechar[i], po + 2, strlen(f2dtypechar[i])) == 0) { break; } } if ((i==-1) || ((i == PLOT_TYPE_MARK) && (po[2+4]!=',')) || ((i == PLOT_TYPE_CURVE) && (po[2+5]!=','))) { err=TRUE; } else { if (i == PLOT_TYPE_MARK) { d1=strtol(po+2+5,&endptr,10); if (endptr==(po+2+5)) err=TRUE; else { putobj(obj,"type",id,&i); putobj(obj,"mark_type",id,&d1); po=endptr; } } else if (i == PLOT_TYPE_CURVE) { for (j = INTERPOLATION_TYPE_BSPLINE_CLOSE; j >= 0; j--) { if (strncmp(intpchar[j], po + 2 + 6, strlen(intpchar[j])) == 0) break; } if (j == -1) { err = TRUE; } else { putobj(obj,"type",id,&i); putobj(obj,"interpolation",id,&j); po=po+2+6+strlen(intpchar[j]); } } else { putobj(obj,"type",id,&i); po=po+2+strlen(f2dtypechar[i]); } } break; case 'o': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"mark_size",id,&d1); } break; case 'l': iarray=arraynew(sizeof(int)); po+=1; do { po++; d1=strtol(po,&endptr,10); if (endptr==po) err=TRUE; else { po=endptr; arrayadd(iarray,&d1); } } while ((!err) && (po[0]==',')); if (err) arrayfree(iarray); else putobj(obj,"line_style",id,iarray); break; case 'w': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"line_width",id,&d1); } break; case 'c': po+=2; d1=strtol(po,&endptr,10); if ((endptr==po) || (endptr[0]!=',')) err=TRUE; else { po=endptr+1; d2=strtol(po,&endptr,10); if ((endptr==po) || (endptr[0]!=',')) err=TRUE; else { po=endptr+1; d3=strtol(po,&endptr,10); if (endptr==po) err=TRUE; else po=endptr; } } if (!err) { putobj(obj,"R",id,&d1); putobj(obj,"G",id,&d2); putobj(obj,"B",id,&d3); } break; case 'C': po+=2; d1=strtol(po,&endptr,10); if ((endptr==po) || (endptr[0]!=',')) err=TRUE; else { po=endptr+1; d2=strtol(po,&endptr,10); if ((endptr==po) || (endptr[0]!=',')) err=TRUE; else { po=endptr+1; d3=strtol(po,&endptr,10); if (endptr==po) err=TRUE; else po=endptr; } } if (!err) { putobj(obj,"R2",id,&d1); putobj(obj,"G2",id,&d2); putobj(obj,"B2",id,&d3); } break; case 'v': if (po[2]=='x') { d1=strtol(po+3,&endptr,10); if (endptr==(po+3)) err=TRUE; else { po=endptr; putobj(obj,"smooth_x",id,&d1); } break; } else if (po[2]=='y') { d1=strtol(po+3,&endptr,10); if (endptr==(po+3)) err=TRUE; else { po=endptr; putobj(obj,"smooth_y",id,&d1); } break; } else err=TRUE; break; case 's': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"head_skip",id,&d1); } break; case 'r': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"read_step",id,&d1); } break; case 'f': d1=strtol(po+2,&endptr,10); if (endptr==(po+2)) err=TRUE; else { po=endptr; putobj(obj,"final_line",id,&d1); } break; case 'z': if ((po[2]=='x') || (po[2]=='y')) { x = (po[2] == 'x'); po+=3; f1=strtod(po,&endptr); if (check_infinite(f1) || endptr == po || endptr[0] != ',') { err=TRUE; } else { po=endptr+1; f2=strtod(po,&endptr); if (check_infinite(f2) || endptr == po || endptr[0] != ',') { err=TRUE; } else { po=endptr+1; f3=strtod(po,&endptr); if (check_infinite(f3) || endptr == po) { err=TRUE; } else { po=endptr; } } } if (!err) { aid = get_axis_id(obj, inst, &aobj, (x) ? AXIS_X : AXIS_Y); if (aid >= 0) { putobj(aobj,"min",aid,&f1); putobj(aobj,"max",aid,&f2); putobj(aobj,"inc",aid,&f3); } } } else err=TRUE; break; case 'e': if ((po[2]=='x') || (po[2]=='y')) { for (i=0;i<3;i++) if (strncmp(axistypechar[i],po+3,strlen(axistypechar[i]))==0) break; if (i!=3) { aid = get_axis_id(obj, inst, &aobj, (po[2]=='x') ? AXIS_X : AXIS_Y); if (aid >= 0) { putobj(aobj,"type",aid,&i); } po=po+3+strlen(axistypechar[i]); } else err=TRUE; } else err=TRUE; break; case 'm': if (po[2] != 'x' && po[2] != 'y') { err = TRUE; break; } for (i=3;(po[i]!='\0') && (strchr(" \t",po[i])==NULL);i++); if (i>3) { if ((s=g_malloc(i-2))!=NULL) { strncpy(s,po+3,i-3); s[i-3]='\0'; } else { err=TRUE; break; } } else s=NULL; putobj(obj, (po[2] == 'x') ? "math_x" : "math_y", id, s); po+=i; break; default: err=TRUE; break; } } else { err=TRUE; } if (err) { error2(obj,ERRILOPTION,buf); g_free(buf); return 1; } } g_free(buf); return 0; } static int f2dsettings(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r, src; _getobj(obj,"source", inst, &src); r = 1; switch (src) { case DATA_SOURCE_FILE: r = f2dsettings_file(obj, inst, rval, argc, argv); break; case DATA_SOURCE_ARRAY: case DATA_SOURCE_RANGE: break; } return r; } static int f2dtime(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; GStatBuf buf; int style, src; g_free(rval->str); rval->str=NULL; _getobj(obj,"source", inst, &src); if (src != DATA_SOURCE_FILE) { error(obj, ERR_INVALID_SOURCE); return -1; } _getobj(obj,"file",inst,&file); if (file==NULL) return 0; if (nstat(file,&buf)!=0) return 1; style=*(int *)(argv[2]); rval->str=ntime((time_t *)&(buf.st_mtime),style); return 0; } static int f2ddate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; GStatBuf buf; int style, src; g_free(rval->str); rval->str=NULL; _getobj(obj,"source", inst, &src); if (src != DATA_SOURCE_FILE) { error(obj, ERR_INVALID_SOURCE); return -1; } _getobj(obj,"file",inst,&file); if (file==NULL) return 0; if (nstat(file,&buf)!=0) return 1; style=*(int *)(argv[2]); rval->str=ndate((time_t *)&(buf.st_mtime),style); return 0; } static void f2dsettbl(N_VALUE *inst,struct f2dlocal *f2dlocal,struct f2ddata *fp) { int gx,gy,g2,g3; switch (fp->type) { case TYPE_NORMAL: inst[f2dlocal->idx].d=fp->dx; inst[f2dlocal->idy].d=fp->dy; if (f2dlocal->coord) { getposition(fp,fp->dx,fp->dy,&gx,&gy); inst[f2dlocal->icx].i=gx; inst[f2dlocal->icy].i=gy; } break; case TYPE_DIAGONAL: inst[f2dlocal->idx].d=fp->dx; inst[f2dlocal->idy].d=fp->dy; inst[f2dlocal->id2].d=fp->d2; inst[f2dlocal->id3].d=fp->d3; if (f2dlocal->coord) { getposition(fp,fp->dx,fp->dy,&gx,&gy); getposition(fp,fp->d2,fp->d3,&g2,&g3); inst[f2dlocal->icx].i=gx; inst[f2dlocal->icy].i=gy; inst[f2dlocal->ic2].i=g2; inst[f2dlocal->ic3].i=g3; } break; case TYPE_ERR_X: inst[f2dlocal->idx].d=fp->dx; inst[f2dlocal->idy].d=fp->dy; inst[f2dlocal->id2].d=fp->d2; inst[f2dlocal->id3].d=fp->d3; if (f2dlocal->coord) { getposition(fp,fp->dx,fp->dy,&gx,&gy); getposition(fp,fp->d2,fp->dy,&g2,&gy); getposition(fp,fp->d3,fp->dy,&g3,&gy); inst[f2dlocal->icx].i=gx; inst[f2dlocal->icy].i=gy; inst[f2dlocal->ic2].i=g2; inst[f2dlocal->ic3].i=g3; } break; case TYPE_ERR_Y: inst[f2dlocal->idx].d=fp->dx; inst[f2dlocal->idy].d=fp->dy; inst[f2dlocal->id2].d=fp->d2; inst[f2dlocal->id3].d=fp->d3; if (f2dlocal->coord) { getposition(fp,fp->dx,fp->dy,&gx,&gy); getposition(fp,fp->dx,fp->d2,&gx,&g2); getposition(fp,fp->dx,fp->d3,&gx,&g3); inst[f2dlocal->icx].i=gx; inst[f2dlocal->icy].i=gy; inst[f2dlocal->ic2].i=g2; inst[f2dlocal->ic3].i=g3; } break; } inst[f2dlocal->isx].i=fp->dxstat; inst[f2dlocal->isy].i=fp->dystat; inst[f2dlocal->is2].i=fp->d2stat; inst[f2dlocal->is3].i=fp->d3stat; inst[f2dlocal->iline].i=fp->dline; } static int f2dopendata(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; int num2; _getobj(obj,"_local",inst,&f2dlocal); if (strcmp0((char *)argv[1],"opendatac")==0) f2dlocal->coord=TRUE; else f2dlocal->coord=FALSE; fp=f2dlocal->data; if (fp!=NULL) closedata(fp, f2dlocal); f2dlocal->data=NULL; if ((fp=opendata(obj,inst,f2dlocal,f2dlocal->coord,FALSE))==NULL) return 1; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); f2dlocal->data=NULL; return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); f2dlocal->data=NULL; return 1; } f2dsettbl(inst,f2dlocal,fp); num2=0; _putobj(obj,"data_num",inst,&num2); f2dlocal->data=fp; return 0; } static int f2dgetdata(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; int rcode; _getobj(obj,"_local",inst,&f2dlocal); fp=f2dlocal->data; if (fp==NULL) return 1; rcode=getdata(fp); f2dsettbl(inst,f2dlocal,fp); if (rcode!=0) { closedata(fp, f2dlocal); f2dlocal->data=NULL; return 1; } return 0; } static int f2dclosedata(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; _getobj(obj,"_local",inst,&f2dlocal); fp=f2dlocal->data; if (fp==NULL) return 0; fp->dx=fp->dy=fp->d2=fp->d3=0; fp->dxstat=fp->dystat=fp->d2stat=fp->d3stat=MATH_VALUE_MEOF; f2dsettbl(inst,f2dlocal,fp); closedata(fp, f2dlocal); f2dlocal->data=NULL; return 0; } static int f2dopendataraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; _getobj(obj,"_local",inst,&f2dlocal); fp=f2dlocal->data; if (fp!=NULL) closedata(fp, f2dlocal); f2dlocal->data=NULL; if ((fp=opendata(obj,inst,f2dlocal,FALSE,TRUE))==NULL) return 1; if (fp->final < -1) { if (getminmaxdata(fp, f2dlocal) == -1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); f2dlocal->data=NULL; return 1; } f2dlocal->data=fp; return 0; } static int f2dgetdataraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; int rcode; struct narray *iarray; struct narray *darray; int i,num,*data,maxdim; double d; MathValue gdata[FILE_OBJ_MAXCOL + 3]; _getobj(obj,"_local",inst,&f2dlocal); fp=f2dlocal->data; if (fp==NULL) { return 0; } darray=rval->array; arrayfree(darray); rval->array=NULL; iarray=(struct narray *)argv[2]; num=arraynum(iarray); data=arraydata(iarray); maxdim=-1; for (i=0;imaxdim) { maxdim=data[i]; } } if (maxdim==-1) { return 0; } if (maxdim>FILE_OBJ_MAXCOL) maxdim=FILE_OBJ_MAXCOL; rcode = getdataraw(fp, maxdim, gdata); if (rcode!=0) { closedata(fp, f2dlocal); f2dlocal->data=NULL; return 1; } darray=arraynew(sizeof(double)); for (i=0;iFILE_OBJ_MAXCOL) { d=0; } else { d = gdata[data[i]].val; } arrayadd(darray,&d); } for (i=0;iFILE_OBJ_MAXCOL) { d=MATH_VALUE_NONUM; } else { d = gdata[data[i]].type; } arrayadd(darray,&d); } rval->array=darray; return 0; } static int f2dclosedataraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; _getobj(obj,"_local",inst,&f2dlocal); fp=f2dlocal->data; if (fp==NULL) return 0; closedata(fp, f2dlocal); f2dlocal->data=NULL; return 0; } static time_t get_mtime(struct objlist *obj, N_VALUE *inst, time_t *mtime) { GStatBuf buf; int r, src; char *file; _getobj(obj, "source", inst, &src); switch (src) { case DATA_SOURCE_FILE: break; case DATA_SOURCE_ARRAY: case DATA_SOURCE_RANGE: *mtime = 1; return 0; } _getobj(obj, "file", inst, &file); if (file == NULL) return 1; r = nstat(file, &buf); if (r) return 1; *mtime = buf.st_mtime; return 0; } struct data_stat { double min, max, ave, stdevp, stdev; }; static int f2dstat_sub(struct objlist *obj,N_VALUE *inst, const char *field, struct f2dlocal *f2dlocal, struct data_stat *stat_x, struct data_stat *stat_y, int *num) { int rcode, interrupt; int dnum,minxstat,maxxstat,minystat,maxystat; double minx,maxx,miny,maxy; double sumx,sumxx,sumy,sumyy, tmp; time_t mtime; struct f2ddata *fp; if (get_mtime(obj, inst, &mtime)) return 1; /* evaluation of mtime must be done before call opendata(). */ if (f2dlocal->mtime_stat == mtime) { stat_x->min = f2dlocal->dminx; stat_x->max = f2dlocal->dmaxx; stat_y->min = f2dlocal->dminy; stat_y->max = f2dlocal->dmaxy; stat_x->ave = f2dlocal->davx; stat_y->ave = f2dlocal->davy; stat_x->stdevp = f2dlocal->dstdevpx; stat_y->stdevp = f2dlocal->dstdevpy; stat_x->stdev = f2dlocal->dstdevx; stat_y->stdev = f2dlocal->dstdevy; *num = f2dlocal->num; if (f2dlocal->dminx != HUGE_VAL || strcmp(field, "dnum") == 0) { return 0; } } fp = opendata(obj, inst, f2dlocal, FALSE, FALSE); if (fp == NULL) return 1; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); return 1; } minxstat=MATH_VALUE_UNDEF; maxxstat=MATH_VALUE_UNDEF; minystat=MATH_VALUE_UNDEF; maxystat=MATH_VALUE_UNDEF; dnum=0; minx=maxx=miny=maxy=0; sumx=sumxx=sumy=sumyy=0; if (set_const_all(fp)) return 1; while ((rcode=getdata(fp))==0) { switch (fp->type) { case TYPE_NORMAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; sumx=sumx+fp->dx; sumxx=sumxx+(fp->dx)*(fp->dx); sumy=sumy+fp->dy; sumyy=sumyy+(fp->dy)*(fp->dy); dnum++; } break; case TYPE_DIAGONAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d2)) minx=fp->d2; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd2)) maxx=fp->d2; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d3)) miny=fp->d3; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd3)) maxy=fp->d3; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; sumx=sumx+fp->dx; sumxx=sumxx+(fp->dx)*(fp->dx); sumy=sumy+fp->dy; sumyy=sumyy+(fp->dy)*(fp->dy); dnum++; sumx=sumx+fp->d2; sumxx=sumxx+(fp->d2)*(fp->d2); sumy=sumy+fp->d3; sumyy=sumyy+(fp->d3)*(fp->d3); dnum++; } break; case TYPE_ERR_X: if ((fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d2)) minx=fp->d2; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd2)) maxx=fp->d2; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d3)) minx=fp->d3; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd3)) maxx=fp->d3; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; sumx=sumx+fp->d2; sumxx=sumxx+(fp->d2)*(fp->d2); sumy=sumy+fp->dy; sumyy=sumyy+(fp->dy)*(fp->dy); dnum++; sumx=sumx+fp->d3; sumxx=sumxx+(fp->d3)*(fp->d3); sumy=sumy+fp->dy; sumyy=sumyy+(fp->dy)*(fp->dy); dnum++; } break; case TYPE_ERR_Y: if ((fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (fp->dxstat==MATH_VALUE_NORMAL)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d2)) miny=fp->d2; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd2)) maxy=fp->d2; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d3)) miny=fp->d3; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd3)) maxy=fp->d3; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; sumx=sumx+fp->dx; sumxx=sumxx+(fp->dx)*(fp->dx); sumy=sumy+fp->d2; sumyy=sumyy+(fp->d2)*(fp->d2); dnum++; sumx=sumx+fp->dx; sumxx=sumxx+(fp->dx)*(fp->dx); sumy=sumy+fp->d3; sumyy=sumyy+(fp->d3)*(fp->d3); dnum++; } break; } } interrupt = fp->interrupt; mtime = fp->mtime; closedata(fp, f2dlocal); if (rcode==-1) return -1; if (dnum!=0) { sumx=sumx/(double )dnum; sumy=sumy/(double )dnum; tmp = sumxx / dnum - sumx * sumx; sumxx = (tmp < 0) ? 0 : sqrt(tmp); tmp = sumyy / dnum - sumy * sumy; sumyy = (tmp < 0) ? 0 : sqrt(tmp); } else { sumx=sumy=sumxx=sumyy=0; } if (minxstat!=MATH_VALUE_NORMAL) minx=0; if (minystat!=MATH_VALUE_NORMAL) miny=0; if (maxxstat!=MATH_VALUE_NORMAL) maxx=0; if (maxystat!=MATH_VALUE_NORMAL) maxy=0; if (interrupt == FALSE) f2dlocal->mtime_stat = mtime; stat_x->min = minx; stat_x->max = maxx; stat_y->min = miny; stat_y->max = maxy; stat_x->ave = sumx; stat_y->ave = sumy; stat_x->stdevp = sumxx; stat_y->stdevp = sumyy; if (dnum > 1) { tmp = sqrt(dnum / (dnum - 1.0)); stat_x->stdev = sumxx * tmp; stat_y->stdev = sumyy * tmp; } else { stat_x->stdev = HUGE_VAL; stat_y->stdev = HUGE_VAL; } *num = dnum; return 0; } static int f2dstat(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; int dnum; char *field; char *ptr; int src, r; struct data_stat stat_x, stat_y; g_free(rval->str); rval->str=NULL; field=argv[1]; _getobj(obj,"_local",inst,&f2dlocal); _getobj(obj,"source", inst, &src); memset(&stat_x, 0, sizeof(stat_x)); memset(&stat_y, 0, sizeof(stat_y)); r = f2dstat_sub(obj, inst, field, f2dlocal, &stat_x, &stat_y, &dnum); if (r) { return r; } f2dlocal->dminx = stat_x.min; f2dlocal->dmaxx = stat_x.max; f2dlocal->dminy = stat_y.min; f2dlocal->dmaxy = stat_y.max; f2dlocal->davx = stat_x.ave; f2dlocal->davy = stat_y.ave; f2dlocal->dstdevpx = stat_x.stdevp; f2dlocal->dstdevpy = stat_y.stdevp; f2dlocal->dstdevx = stat_x.stdev; f2dlocal->dstdevy = stat_y.stdev; ptr = NULL; if (strcmp(field, "dnum") == 0) { ptr = g_strdup_printf("%d", dnum); } else if (strcmp(field,"dminx")==0) { ptr = g_strdup_printf("%.15e", stat_x.min); } else if (strcmp(field,"dmaxx")==0) { ptr = g_strdup_printf("%.15e", stat_x.max); } else if (strcmp(field,"dminy")==0) { ptr = g_strdup_printf("%.15e", stat_y.min); } else if (strcmp(field,"dmaxy")==0) { ptr = g_strdup_printf("%.15e", stat_y.max); } else if (strcmp(field,"davx")==0) { ptr = g_strdup_printf("%.15e", stat_x.ave); } else if (strcmp(field,"davy")==0) { ptr = g_strdup_printf("%.15e", stat_y.ave); } else if (strcmp(field,"dsigx")==0) { ptr = g_strdup_printf("%.15e", stat_x.stdevp); } else if (strcmp(field,"dsigy")==0) { ptr = g_strdup_printf("%.15e", stat_y.stdevp); } else if (strcmp(field,"dstdevpx")==0) { ptr = g_strdup_printf("%.15e", stat_x.stdevp); } else if (strcmp(field,"dstdevpy")==0) { ptr = g_strdup_printf("%.15e", stat_y.stdevp); } else if (strcmp(field,"dstdevx")==0) { ptr = g_strdup_printf("%.15e", stat_x.stdev); } else if (strcmp(field,"dstdevy")==0) { ptr = g_strdup_printf("%.15e", stat_y.stdev); } if (ptr == NULL) return -1; rval->str = ptr; return 0; } static int f2dstat2(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; int rcode; int line; double dx,dy,d2,d3; int find; char *field; char *ptr; g_free(rval->str); rval->str=NULL; field=argv[1]; line=*(int *)(argv[2]); _getobj(obj,"_local",inst,&f2dlocal); if ((fp=opendata(obj,inst,f2dlocal,FALSE,FALSE))==NULL) return 1; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); return 1; } dx=dy=d2=d3=0; find=FALSE; if (set_const_all(fp)) return 1; while ((rcode=getdata(fp))==0) { if (fp->dline==line) { switch (fp->type) { case TYPE_NORMAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { dx=fp->dx; dy=fp->dy; find=TRUE; } break; default: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) { dx=fp->dx; dy=fp->dy; d2=fp->d2; d3=fp->d3; find=TRUE; } break; } } } closedata(fp, f2dlocal); if (!find) return -1; ptr = NULL; if (strcmp(field,"dx")==0) { ptr = g_strdup_printf("%.15e", dx); } else if (strcmp(field,"dy")==0) { ptr = g_strdup_printf("%.15e", dy); } else if (strcmp(field,"d2")==0) { ptr = g_strdup_printf("%.15e", d2); } else if (strcmp(field,"d3")==0) { ptr = g_strdup_printf("%.15e", d3); } if (ptr == NULL) { return -1; } rval->str = ptr; return 0; } static int set_bounding_info(struct objlist *obj, N_VALUE *inst, double minx, double maxx, double miny, double maxy, int minxstat, int maxxstat, int minystat, int maxystat) { if (_putobj(obj,"minx",inst,&minx)) return 1; if (_putobj(obj,"maxx",inst,&maxx)) return 1; if (_putobj(obj,"miny",inst,&miny)) return 1; if (_putobj(obj,"maxy",inst,&maxy)) return 1; if (_putobj(obj,"stat_minx",inst,&minxstat)) return 1; if (_putobj(obj,"stat_maxx",inst,&maxxstat)) return 1; if (_putobj(obj,"stat_miny",inst,&minystat)) return 1; if (_putobj(obj,"stat_maxy",inst,&maxystat)) return 1; return 0; } static int f2dboundings_file(struct f2dlocal *f2dlocal, struct f2ddata *fp, struct objlist *obj, N_VALUE *inst, int abs) { int rcode; int minxstat,maxxstat,minystat,maxystat,type; double minx,maxx,miny,maxy; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); return 1; } minxstat=MATH_VALUE_UNDEF; maxxstat=MATH_VALUE_UNDEF; minystat=MATH_VALUE_UNDEF; maxystat=MATH_VALUE_UNDEF; minx=maxx=miny=maxy=0; if (set_const_all(fp)) return 1; while ((rcode=getdata(fp))==0) { switch (fp->type) { case TYPE_NORMAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if ((!abs) || (fp->dx>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->dy>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } if (_getobj(obj, "type", inst, &type)) return 1; switch (type) { case PLOT_TYPE_BAR_X: case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_SOLID_FILL_X: if (minxstat != MATH_VALUE_NORMAL) { break; } if (minx > 0 && maxx > 0) { minx = 0; } else if (minx < 0 && maxx < 0) { maxx = 0; } break; case PLOT_TYPE_BAR_Y: case PLOT_TYPE_BAR_FILL_Y: case PLOT_TYPE_BAR_SOLID_FILL_Y: if (minystat != MATH_VALUE_NORMAL) { break; } if (miny > 0 && maxy > 0) { miny = 0; } else if (miny < 0 && maxy < 0) { maxy = 0; } break; } } break; case TYPE_DIAGONAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) { if ((!abs) || (fp->dx>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->dy>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d2>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d2)) minx=fp->d2; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd2)) maxx=fp->d2; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d3>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d3)) miny=fp->d3; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd3)) maxy=fp->d3; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } } break; case TYPE_ERR_X: if ((fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) { if ((!abs) || (fp->dy>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->dy)) miny=fp->dy; if ((maxystat==MATH_VALUE_UNDEF) || (maxydy)) maxy=fp->dy; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d2>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d2)) minx=fp->d2; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd2)) maxx=fp->d2; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d3>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->d3)) minx=fp->d3; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxd3)) maxx=fp->d3; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } } break; case TYPE_ERR_Y: if ((fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL) && (fp->dxstat==MATH_VALUE_NORMAL)) { if ((!abs) || (fp->dx>0)) { if ((minxstat==MATH_VALUE_UNDEF) || (minx>fp->dx)) minx=fp->dx; if ((maxxstat==MATH_VALUE_UNDEF) || (maxxdx)) maxx=fp->dx; minxstat=MATH_VALUE_NORMAL; maxxstat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d2>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d2)) miny=fp->d2; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd2)) maxy=fp->d2; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } if ((!abs) || (fp->d3>0)) { if ((minystat==MATH_VALUE_UNDEF) || (miny>fp->d3)) miny=fp->d3; if ((maxystat==MATH_VALUE_UNDEF) || (maxyd3)) maxy=fp->d3; minystat=MATH_VALUE_NORMAL; maxystat=MATH_VALUE_NORMAL; } } break; } } if (rcode != -1) { set_bounding_info(obj, inst, minx, maxx, miny, maxy, minxstat, maxxstat, minystat, maxystat); } return rcode; } static int f2dboundings(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; int rcode; int abs; abs=*(int *)argv[2]; rcode = set_bounding_info(obj, inst, 0, 0, 0, 0, MATH_VALUE_UNDEF, MATH_VALUE_UNDEF, MATH_VALUE_UNDEF, MATH_VALUE_UNDEF); if (rcode) { return 1; } _getobj(obj,"_local",inst,&f2dlocal); fp = opendata(obj,inst,f2dlocal,FALSE,FALSE); if (fp == NULL) return 1; rcode = f2dboundings_file(f2dlocal, fp, obj, inst, abs); closedata(fp, f2dlocal); if (rcode==-1) { return -1; } return 0; } static int f2dbounding(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct narray *minmax; char *axiss; struct narray iarray; struct objlist *aobj; int i,anum,id,r = 1; int *adata; double min,max; int minstat,maxstat; int hidden; int type,abs; char *argv2[2]; minmax=rval->array; if (minmax!=NULL) arrayfree(minmax); rval->array=NULL; axiss=(char *)argv[2]; if (axiss==NULL) return 0; _getobj(obj,"hidden",inst,&hidden); if (hidden) return 0; arrayinit(&iarray,sizeof(int)); if (getobjilist(axiss,&aobj,&iarray,FALSE,NULL)) return 0; anum=arraynum(&iarray); if (anum<1) { arraydel(&iarray); return 0; } adata=arraydata(&iarray); id = get_axis_id(obj, inst, &aobj, AXIS_X); if (id >= 0) { for (i=0;iarray=minmax; } r = 0; goto exit; } } id = get_axis_id(obj, inst, &aobj, AXIS_Y); if (id >= 0) { for (i=0;iarray=minmax; } } } r = 0; exit: arraydel(&iarray); return r; } static int save_fit(GString *s, char *fit, struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray iarray; struct objlist *fitobj; char *fitsave; int id, idnum; arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &fitobj, &iarray, FALSE, NULL)) { return 1; } idnum = arraynum(&iarray); if (idnum < 1) { arraydel(&iarray); return 1; } id = arraylast_int(&iarray); arraydel(&iarray); if (getobj(fitobj, "save", id, 0, NULL, &fitsave) == -1) { return 1; } g_string_append(s, fitsave); return 0; } static int f2dsave(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array, *array2; int anum; char **adata; int i, j, r; char *argv2[4]; char *s2, *fit; GString *s; array = (struct narray *) argv[2]; anum = arraynum(array); adata = arraydata(array); for (j = 0; j < anum; j++) { if (strcmp("fit", adata[j]) == 0) { return pathsave(obj, inst, rval, argc, argv); } } _getobj(obj, "fit", inst, &fit); if (fit == NULL) { return pathsave(obj, inst, rval, argc, argv); } array2 = arraynew(sizeof(char *)); for (i = 0; i < anum; i++) { arrayadd(array2, &(adata[i])); } s2 = "fit"; arrayadd(array2, &s2); argv2[0] = argv[0]; argv2[1] = argv[1]; argv2[2] = (char *) array2; argv2[3] = NULL; if (pathsave(obj, inst, rval, 3, argv2)) { arrayfree(array2); return 1; } s = g_string_sized_new(1024); if (s == NULL) { return 1; } r = save_fit(s, fit, obj, inst, rval, argc, argv); if (r) { g_string_free(s, TRUE); return pathsave(obj, inst, rval, argc, argv); } arrayfree(array2); g_string_append(s, rval->str); g_string_append(s, "\tfile::fit='fit:^'${fit::oid}\n"); g_free(rval->str); rval->str = g_string_free(s, FALSE); return 0; } static int f2dstore_file(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; char *file,*base,*date,*time; int style, r; char *buf; char *argv2[2]; g_free(rval->str); rval->str=NULL; _getobj(obj,"_local",inst,&f2dlocal); if (f2dlocal->endstore) { f2dlocal->endstore=FALSE; return 1; } if (f2dlocal->storefd == NULL) { _getobj(obj,"file",inst,&file); if (file==NULL) return 1; style=3; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"date",inst,1,argv2)) return 1; style=0; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"time",inst,1,argv2)) return 1; _getobj(obj,"date",inst,&date); if(date == NULL) { date = "1-1-1970"; } _getobj(obj,"time",inst,&time); if(time == NULL) { time = "00:00:00"; } if ((base=getbasename(file))==NULL) return 1; if ((f2dlocal->storefd=nfopen(file,"rt"))==NULL) { g_free(base); return 1; } buf = g_strdup_printf("file::load_data '%s' '%s %s' <<'[EOF]'", base, date, time); g_free(base); if (buf == NULL) { fclose(f2dlocal->storefd); f2dlocal->storefd=NULL; return 1; } rval->str=buf; } else { r = fgetline(f2dlocal->storefd, &buf); if (r) { fclose(f2dlocal->storefd); f2dlocal->storefd=NULL; buf = g_strdup("[EOF]\n"); if (buf == NULL) return 1; f2dlocal->endstore=TRUE; rval->str=buf; } else { rval->str=buf; } } return 0; } static int f2dstore(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r, src; _getobj(obj,"source", inst, &src); r = 1; switch (src) { case DATA_SOURCE_FILE: r = f2dstore_file(obj, inst, rval, argc, argv); break; case DATA_SOURCE_ARRAY: case DATA_SOURCE_RANGE: break; } return r; } static int nstrrchr(const char *str, int chr, int index) { int i; for (i = index; i >= 0; i--) { if (str[i] == chr) { break; } } return i; } static int get_filename_last_index(const char *s) { int i; i = strlen(s); i = nstrrchr(s, ' ', i); if (i < 0) { return i; } while (s[i] == ' ') { i--; } i = nstrrchr(s, ' ', i); if (i < 0) { return i; } return i; } static int f2dload_sub(struct objlist *obj, N_VALUE *inst, char **s, int *expand, char **fullname) { struct objlist *sys; char *exdir, *file2, *file, *oldfile, *fname; int len; if (s == NULL) return 1; sys = getobject("system"); if (expand) { getobj(sys, "expand_file", 0, 0, NULL, expand); } len = get_filename_last_index(*s); if (len < 0) { return 1; } file = g_strndup(*s, len); if (file == NULL) { return 1; } *s = *s + len; getobj(sys, "expand_dir", 0, 0, NULL, &exdir); file2 = getfilename(CHK_STR(exdir), "/", file); g_free(file); fname = getfullpath(file2); if (fname == NULL) { g_free(file2); return 1; } if (fullname) *fullname = fname; g_free(file2); _getobj(obj, "file", inst, &oldfile); g_free(oldfile); _putobj(obj, "file", inst, fname); return 0; } static int f2dload_file(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int expand; char *s, *fullname, *mes; int mkdata; time_t ftime; s = argv[2]; if (f2dload_sub(obj, inst, &s, &expand, &fullname)) return 1; if (! expand) return 0; if (gettimeval(s, &ftime)) return 1; if (naccess(fullname, R_OK) != 0) { mkdata = TRUE; } else { int len; len = strlen(fullname) + 256; mes = g_malloc(len); if (mes == NULL) return 1; snprintf(mes, len, "`%s' Overwrite existing file?", fullname); mkdata = inputyn(mes); g_free(mes); } if (mkdata) { int len; struct utimbuf tm; FILE *fp; int fd; char buf[257]; fp = nfopen(fullname, "wt"); if (fp == NULL) { error2(obj, ERROPEN, fullname); return 1; } fd = stdinfd(); while ((len = nread(fd, buf, sizeof(buf) - 1)) > 0) { buf[len] = '\0'; fputs(buf, fp); } fclose(fp); tm.actime = ftime; tm.modtime = ftime; utime(fullname, &tm); } return 0; } static int f2dload(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r, src; _getobj(obj,"source", inst, &src); r = 1; switch (src) { case DATA_SOURCE_FILE: r = f2dload_file(obj, inst, rval, argc, argv); break; case DATA_SOURCE_ARRAY: case DATA_SOURCE_RANGE: break; } return r; } static int f2dstoredum(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct f2dlocal *f2dlocal; char *file,*base,*date,*time; int style; char *buf; char *argv2[2]; g_free(rval->str); rval->str=NULL; _getobj(obj,"_local",inst,&f2dlocal); if (f2dlocal->endstore) { f2dlocal->endstore=FALSE; return 1; } else { _getobj(obj,"file",inst,&file); if (file==NULL) return 1; style=3; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"date",inst,1,argv2)) return 1; style=0; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"time",inst,1,argv2)) return 1; _getobj(obj,"date",inst,&date); if(date == NULL) { date = "1-1-1970"; } _getobj(obj,"time",inst,&time); if(time == NULL) { time = "00:00:00"; } if ((base=getbasename(file))==NULL) return 1; buf = g_strdup_printf("file::load_dummy '%s' '%s %s'\n", base, date, time); g_free(base); if (buf == NULL) { return 1; } rval->str=buf; f2dlocal->endstore=TRUE; return 0; } } static int f2dloaddum(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *s = argv[2]; return f2dload_sub(obj, inst, &s, NULL, NULL); } static int f2dtight(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { obj_do_tighten(obj, inst, "axis_x"); obj_do_tighten(obj, inst, "axis_y"); obj_do_tighten(obj, inst, "fit"); obj_do_tighten_all(obj, inst, "array"); return 0; } static int curveoutfile(struct objlist *obj,struct f2ddata *fp,FILE *fp2, int intp,int div) { int emerr,emnonum,emig,emng; int j,k,num; int first; double *x,*y,*z,*c1,*c2,*c3,*c4,*c5,*c6,count,dd,dx,dy; int *r,*g,*b,*a; double c[8]; double bs1[7],bs2[7],bs3[4],bs4[4]; int spcond; emerr=emnonum=emig=emng=FALSE; switch (intp) { case INTERPOLATION_TYPE_SPLINE: case INTERPOLATION_TYPE_SPLINE_CLOSE: num=0; count=0; x=y=z=c1=c2=c3=c4=c5=c6=NULL; r=g=b=a=NULL; while (getdata(fp)==0) { if (fp->dxstat==MATH_VALUE_NORMAL && fp->dystat==MATH_VALUE_NORMAL) { if (dataadd(fp->dx,fp->dy,count,fp->col.r,fp->col.g,fp->col.b,fp->col.a,&num, &x,&y,&z,&r,&g,&b,&a,&c1,&c2,&c3,&c4,&c5,&c6)==NULL) return -1; count++; } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (num>=2) { if (intp==INTERPOLATION_TYPE_SPLINE) { spcond=SPLCND2NDDIF; } else { spcond=SPLCNDPERIODIC; if ((x[num-1]!=x[0]) || (y[num-1]!=y[0])) { if (dataadd(x[0],y[0],count,r[0],g[0],b[0],a[0],&num, &x,&y,&z,&r,&g,&b,&a,&c1,&c2,&c3,&c4,&c5,&c6)==NULL) return -1; } } if (spline(z,x,c1,c2,c3,num,spcond,spcond,0,0) || spline(z,y,c4,c5,c6,num,spcond,spcond,0,0)) { FREE_INTP_BUF(); error(obj,ERRSPL); return -1; } fprintf(fp2,"%.15e %.15e\n",x[0],y[0]); for (j=0;jdxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (first) { bs1[num]=fp->dx; bs2[num]=fp->dy; num++; if (num>=7) { for (j=0;j<2;j++) { bspline(j+1,bs1+j,c); bspline(j+1,bs2+j,c+4); if (j==0) { fprintf(fp2,"%.15e %.15e\n",c[0],c[4]); } for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } first=FALSE; } } else { for (j=1;j<7;j++) { bs1[j-1]=bs1[j]; bs2[j-1]=bs2[j]; } bs1[6]=fp->dx; bs2[6]=fp->dy; num++; bspline(0,bs1+1,c); bspline(0,bs2+1,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (!first) { for (j=0;j<2;j++) { bspline(j+3,bs1+j+2,c); bspline(j+3,bs2+j+2,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } first=TRUE; num=0; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (!first) { for (j=0;j<2;j++) { bspline(j+3,bs1+j+2,c); bspline(j+3,bs2+j+2,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } break; case INTERPOLATION_TYPE_BSPLINE_CLOSE: first=TRUE; num=0; while (getdata(fp)==0) { if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (getposition2(fp,fp->axtype,fp->aytype,&(fp->dx),&(fp->dy))==0)) { if (first) { bs1[num]=fp->dx; bs3[num]=fp->dx; bs2[num]=fp->dy; bs4[num]=fp->dy; num++; if (num>=4) { bspline(0,bs1,c); bspline(0,bs2,c+4); fprintf(fp2,"%.15e %.15e\n",c[0],c[4]); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } first=FALSE; } } else { for (j=1;j<4;j++) { bs1[j-1]=bs1[j]; bs2[j-1]=bs2[j]; } bs1[3]=fp->dx; bs2[3]=fp->dy; num++; bspline(0,bs1,c); bspline(0,bs2,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } else { if ((fp->dxstat!=MATH_VALUE_CONT) && (fp->dystat!=MATH_VALUE_CONT)) { if (!first) { for (j=0;j<3;j++) { bs1[4+j]=bs3[j]; bs2[4+j]=bs4[j]; bspline(0,bs1+j+1,c); bspline(0,bs2+j+1,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } first=TRUE; num=0; } errordisp(obj,fp,&emerr,&emnonum,&emig,&emng); } } if (!first) { for (j=0;j<3;j++) { bs1[4+j]=bs3[j]; bs2[4+j]=bs4[j]; bspline(0,bs1+j+1,c); bspline(0,bs2+j+1,c+4); for (k=1;k<=div;k++) { dd=1.0/div*k; bsplineint(dd,c,c[0],c[4],&dx,&dy,NULL); fprintf(fp2,"%.15e %.15e\n",dx,dy); } } } break; } return 0; } static int save_data_file(struct objlist *obj, N_VALUE *inst, struct f2dlocal *f2dlocal, struct f2ddata *fp, const char *data_file, const char *file, int div, int append) { int rcode, type, intp, r; FILE *fp2; if (fp->need2pass || fp->final < -1) { if (getminmaxdata(fp, f2dlocal)==-1) { closedata(fp, f2dlocal); error2(obj, ERRREAD, data_file); return 1; } reopendata(fp); } if (hskipdata(fp)!=0) { closedata(fp, f2dlocal); error2(obj, ERRREAD, data_file); return 1; } fp2 = nfopen(file, (append) ? "at" : "wt"); if (fp2 == NULL) { // error2(obj, ERROPEN, file); error22(obj, ERRUNKNOWN, g_strerror(errno), file); closedata(fp, f2dlocal); return 1; } if (set_const_all(fp)) return 1; _getobj(obj,"type",inst,&type); if (type==3) { _getobj(obj,"interpolation",inst,&intp); if (curveoutfile(obj,fp,fp2,intp,div)!=0) { closedata(fp, f2dlocal); fclose(fp2); error2(obj, ERRWRITE, file); return 1; } } else { while ((rcode=getdata(fp))==0) { switch (fp->type) { case TYPE_NORMAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL)) fprintf(fp2,"%.15e %.15e\n",fp->dx,fp->dy); break; case TYPE_DIAGONAL: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) fprintf(fp2,"%.15e %.15e %.15e %.15e\n",fp->dx,fp->dy,fp->d2,fp->d3); break; case TYPE_ERR_X: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) fprintf(fp2,"%.15e %.15e %.15e %.15e\n", fp->dx,fp->d2-fp->dx,fp->d3-fp->dx,fp->dy); break; case TYPE_ERR_Y: if ((fp->dxstat==MATH_VALUE_NORMAL) && (fp->dystat==MATH_VALUE_NORMAL) && (fp->d2stat==MATH_VALUE_NORMAL) && (fp->d3stat==MATH_VALUE_NORMAL)) fprintf(fp2,"%.15e %.15e %.15e %.15e\n", fp->dx,fp->dy,fp->d2-fp->dy,fp->d3-fp->dy); break; } } } r = 0; if (ferror(fp2)) { error2(obj, ERRWRITE, file); r = 1; } fclose(fp2); return r; } static int f2doutputfile(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct f2dlocal *f2dlocal; struct f2ddata *fp; char *file, *data_file; int div,append,r; _getobj(obj,"_local",inst,&f2dlocal); _getobj(obj,"file", inst, &data_file); file=(char *)argv[2]; div=*(int *)argv[3]; append = *(int *) argv[4]; if (div<1) div=1; fp = opendata(obj,inst,f2dlocal,FALSE,FALSE); if (fp == NULL) { return 1; } r = save_data_file(obj, inst, f2dlocal, fp, data_file, file, div, append); closedata(fp, f2dlocal); return r; } static int update_field(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct f2dlocal *f2dlocal; _getobj(obj, "_local", inst, &f2dlocal); f2dlocal->mtime = 0; f2dlocal->mtime_stat = 0; return 0; } static int accept_ascii_only(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *str; int i, j, n; update_field(obj, inst, rval, argc, argv); if (argv[2] == NULL) { return 0; } str = argv[2]; n = strlen(str); for (i = j = 0; i < n; i++) { if (str[i] > 0 && (g_ascii_isprint(str[i]) || g_ascii_isspace(str[i]))) { str[j] = str[i]; j++; } } str[j] = '\0'; return 0; } static int update_mask(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; update_field(obj, inst, rval, argc, argv); array = (struct narray *) argv[2]; arraysort_int(array); arrayuniq_int(array); return 0; } static int foputabs(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { update_field(obj, inst, rval, argc, argv); return oputabs(obj, inst, rval, argc, argv); } static int foputge1(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { update_field(obj, inst, rval, argc, argv); return oputge1(obj, inst, rval, argc, argv); } static int adjust_move_num(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *move, *move_x, *move_y; int i, n, nx, ny; _getobj(obj, "move_data", inst, &move); _getobj(obj, "move_data_x", inst, &move_x); _getobj(obj, "move_data_y", inst, &move_y); if (move == NULL || move_x == NULL || move_y == NULL) { arrayfree(move); arrayfree(move_x); arrayfree(move_y); move = NULL; _putobj(obj, "move_data", inst, move); _putobj(obj, "move_data_x", inst, move); _putobj(obj, "move_data_y", inst, move); return 0; } n = arraynum(move); nx = arraynum(move_x); ny = arraynum(move_y); if (n == nx && n == ny) return 0; if (nx < n) { for (i = n - 1; i >= nx; i--) { arrayndel(move, i); } n = nx; } else if (nx > n) { for (i = nx - 1; i >= n; i--) { arrayndel(move_x, i); } } if (ny < n) { for (i = n - 1; i >= ny; i--) { arrayndel(move, i); arrayndel(move_x, i); } n = ny; } else if (ny > n) { for (i = ny - 1; i >= n; i--) { arrayndel(move_y, i); } } return 0; } #define MAX_ITERATION 10000 static int bisection(MathEquation *eq, double a, double b, double y, double tolerance, double *x) { int r, i; double c, fa, fb, fc; MathValue val, rval; if (tolerance < 0) { tolerance = 0; } if (b < a) { c = a; a = b; a = c; } val.type = MATH_VALUE_NORMAL; val.val = a; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } fa = rval.val - y; val.val = b; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } fb = rval.val - y; if (compare_double(fa, 0)) { *x = a; return 0; } if (compare_double(fb, 0)) { *x = b; return 0; } if (fa * fb > 0) { return 1; } i = 0; while (1) { c = (a + b) / 2; if (c - a <= tolerance || b - c <= tolerance) { break; } val.val = c; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } fc = rval.val - y; if (compare_double(fc, 0)) { break; } if (fc * fa > 0) { a = c; fa = fc; } else { b = c; fb = fc; } if (tolerance == 0 && i > MAX_ITERATION) { break; } i++; } *x = c; return i >= MAX_ITERATION; } static int newton(MathEquation *eq, double *xx, double y) { int r, i, n; double h, x, fx, df, x_prev, fx_prev; MathValue val, rval; val.type = MATH_VALUE_NORMAL; x = *xx; val.val = x; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } fx = rval.val - y; n = 0; while (! compare_double(fx, 0)) { double dx; dx = (x == 0) ? 1E-6 : x * 1E-6; val.val = x + dx; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } df = (rval.val - y - fx) / dx; h = fx / df; x_prev = x; fx_prev = fx; i = 0; do { x = x_prev - h; val.val = x; math_equation_set_var(eq, 0, &val); r = math_equation_calculate(eq, &rval); if (r || rval.type != MATH_VALUE_NORMAL) { return 1; } fx = rval.val - y; h /= 2; i++; if (i > MAX_ITERATION) { return 1; } } while (fabs(fx) > fabs(fx_prev)); n++; if (n > MAX_ITERATION || (x == x_prev)) { break; } } *xx = x; return n >= MAX_ITERATION; } static int solve_equation(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { MathEquation *eq = NULL; int r, n, type, fit_id; char *equation, *fit, prefix[] = FIT_FIELD_PREFIX; N_VALUE *fit_inst; double a, b, x, y, tolerance, *data; struct narray *darray; struct objlist *fit_obj; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; g_free(rval->str); rval->str = NULL; _getobj(obj, "type", inst, &type); _getobj(obj, "fit", inst, &fit); if (type != PLOT_TYPE_FIT) { error(obj, ERR_INVALID_TYPE); return 1; } fit_id = get_fit_obj_id(fit, &fit_obj, &fit_inst); if (fit_id < 0) { error2(obj, ERRNOFITINST, fit); return -1; } if (_getobj(fit_obj, "equation", fit_inst, &equation)) { return -1; } darray = (struct narray *) (argv[2]); n = arraynum(darray); data = arraydata(darray); eq = ofile_create_math_equation(NULL, 0, FALSE, FALSE, FALSE, FALSE, TRUE); if (eq == NULL) { return 1; } r = math_equation_parse(eq, equation); if (r) { math_equation_free(eq); return 1; } r = math_equation_optimize(eq); if (r) { math_equation_free(eq); return 1; } if (eq->exp == NULL) { math_equation_free(eq); return 1; } if (argv[1][sizeof(prefix) - 1] == 'b') { if (n < 2) { error(obj, ERR_SMALL_ARGS); math_equation_free(eq); return 1; } a = data[0]; b = data[1]; y = (n > 2) ? data[2] : 0; x = 0; tolerance = (n > 3) ? data[3] : 0; r = bisection(eq, a, b, y, tolerance, &x); } else { x = (n > 0) ? data[0] : 0; y = (n > 1) ? data[1] : 0; r = newton(eq, &x, y); } math_equation_free(eq); if (r) { error(obj, ERRCONVERGE); return 1; } rval->str = g_strdup_printf("%.15e", x); return 0; } int ofile_calc_fit_equation(struct objlist *obj, int id, double x, double *y) { N_VALUE *inst; inst = chkobjinst(obj, id); if (inst == NULL) { return ERRNOFITINST; } return calc_fit_equation(obj, inst, x, y); } static int calc_fit_equation(struct objlist *obj, N_VALUE *inst, double x, double *y) { int type, fit_id; char *fit; N_VALUE *fit_inst; struct objlist *fit_obj; char *fit_argv[2]; *y = 0; _getobj(obj, "type", inst, &type); _getobj(obj, "fit", inst, &fit); if (type != PLOT_TYPE_FIT) { return ERR_INVALID_TYPE; } fit_id = get_fit_obj_id(fit, &fit_obj, &fit_inst); if (fit_id < 0) { return ERRNOFITINST; } fit_argv[0] = (char *) &x; fit_argv[1] = NULL; getobj(fit_obj, "calc", fit_id, 1, fit_argv, y); return 0; } static int calc_equation(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int r; double x, y; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; g_free(rval->str); rval->str = NULL; x = * (double *) argv[2]; r = calc_fit_equation(obj, inst, x, &y); switch (r) { case 0: break; case ERR_INVALID_TYPE: case ERRNOFITINST: error(obj, ERR_INVALID_TYPE); return 1; case ERR_INVALID_SOURCE: error(obj, ERR_INVALID_SOURCE); return 1; default: break; } rval->str = g_strdup_printf("%.15e", y); return 0; } static int get_fit_parameter(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int type, fit_id, i; char *fit; N_VALUE *fit_inst; struct objlist *fit_obj; char prm_str[] = "%00"; double val; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; g_free(rval->str); rval->str = NULL; _getobj(obj, "type", inst, &type); _getobj(obj, "fit", inst, &fit); if (type != PLOT_TYPE_FIT) { error(obj, ERR_INVALID_TYPE); return 1; } fit_id = get_fit_obj_id(fit, &fit_obj, &fit_inst); if (fit_id < 0) { error2(obj, ERRNOFITINST, fit); return -1; } i = * (int *) argv[2]; if (i < 0 || i > 9) { error(obj, ERR_INVALID_PARAM); return 1; } prm_str[2] += i; if (_getobj(fit_obj, prm_str, fit_inst, &val)) { return -1; } rval->str = g_strdup_printf("%.15e", val); return 0; } static int add_keyword(struct nhash *hash, void *data) { GString *str; str = data; g_string_append(str, hash->key); g_string_append_c(str, '\n'); return 0; } static gchar * create_keyword_list(NHASH hash) { GString *str; gchar *text; str = g_string_new(""); nhash_each(hash, add_keyword, str); text = g_string_free(str, FALSE); return g_strstrip(text); } char * odata_get_functions(void) { MathEquation *eq; gchar *text; eq = ofile_create_math_equation(NULL, 3, TRUE, TRUE, TRUE, TRUE, TRUE); if (eq == NULL) { return NULL; } text = create_keyword_list(eq->function); math_equation_free(eq); return text; } char * odata_get_constants(void) { MathEquation *eq; gchar *text; eq = ofile_create_math_equation(NULL, 3, TRUE, TRUE, TRUE, TRUE, TRUE); if (eq == NULL) { return NULL; } text = create_keyword_list(eq->constant); math_equation_free(eq); return text; } static int get_functions(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; g_free(rval->str); rval->str = NULL; rval->str = odata_get_functions(); return 0; } static int get_constants(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; g_free(rval->str); rval->str = NULL; rval->str = odata_get_constants(); return 0; } static int set_array(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct array_prm ary; if (argv[2] && open_array(argv[2], &ary)) { error2(obj, ERR_INVALID_OBJ, argv[2]); return 1; } return 0; } static int data_inst_dup(struct objlist *obj, N_VALUE *src, N_VALUE *dest) { int i, pos; struct f2dlocal *local_new, *local_src; char *math; pos = obj_get_field_pos(obj, "_local"); if (pos < 0) { return 1; } local_src = src[pos].ptr; local_new = g_memdup(local_src, sizeof(struct f2dlocal)); if (local_new == NULL) { return 1; } dest[pos].ptr = local_new; if (local_src->data) { closedata(local_src->data, local_src); local_src->data = NULL; local_new->data = NULL; } if (local_src->codex[0]) { _getobj(obj, "math_x", src, &math); for (i = 0; i < EQUATION_NUM; i++) { local_new->codex[i] = NULL; } put_func(obj, dest, local_new, "math_x", math); } if (local_src->codey[0]) { _getobj(obj, "math_y", src, &math); for (i = 0; i < EQUATION_NUM; i++) { local_new->codey[i] = NULL; } put_func(obj, dest, local_new, "math_y", math); } return 0; } static int data_inst_free(struct objlist *obj, N_VALUE *inst) { int i, pos; struct f2dlocal *local; pos = obj_get_field_pos(obj, "_local"); if (pos < 0) { return 1; } local = inst[pos].ptr; if (local->data) { closedata(local->data, local); } for (i = 0; i < EQUATION_NUM; i++) { if (local->codex[i]) { math_equation_free(local->codex[i]); } if (local->codey[i]) { math_equation_free(local->codey[i]); } } g_free(local); return 0; } static struct objtable file2d[] = { {"init",NVFUNC,NEXEC,f2dinit,NULL,0}, {"done",NVFUNC,NEXEC,f2ddone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"source",NENUM,NREAD|NWRITE,NULL,data_type,0}, /* for file */ {"file",NSTR,NREAD|NWRITE,f2dfile,NULL,0}, {"save_path",NENUM,NREAD|NWRITE,NULL,pathchar,0}, {"x",NINT,NREAD|NWRITE,f2dput,NULL,0}, {"y",NINT,NREAD|NWRITE,f2dput,NULL,0}, {"type",NENUM,NREAD|NWRITE,NULL,f2dtypechar,0}, {"interpolation",NENUM,NREAD|NWRITE,NULL,intpchar,0}, {"fit",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"math_x",NSTR,NREAD|NWRITE,f2dput,NULL,0}, {"math_y",NSTR,NREAD|NWRITE,f2dput,NULL,0}, {"func_f",NSTR,NREAD|NWRITE,f2dput,NULL,0}, {"func_g",NSTR,NREAD|NWRITE,f2dput,NULL,0}, {"func_h",NSTR,NREAD|NWRITE,f2dput,NULL,0}, {"smooth_x",NINT,NREAD|NWRITE,f2dput,NULL,0}, {"smooth_y",NINT,NREAD|NWRITE,f2dput,NULL,0}, {"averaging_type",NENUM,NREAD|NWRITE,NULL,averaging_type_char,0}, {"mark_type",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"mark_size",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"line_width",NINT,NREAD|NWRITE,oputge1,NULL,0}, {"line_style",NIARRAY,NREAD|NWRITE,oputstyle,NULL,0}, {"line_join",NENUM,NREAD|NWRITE,NULL,joinchar,0}, {"line_miter_limit",NINT,NREAD|NWRITE,oputge1,NULL,0}, {"R2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"G2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"B2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"A2",NINT,NREAD|NWRITE,oputcolor,NULL,0}, {"remark",NSTR,NREAD|NWRITE,accept_ascii_only,NULL,0}, {"ifs",NSTR,NREAD|NWRITE,accept_ascii_only,NULL,0}, {"csv",NBOOL,NREAD|NWRITE,update_field,NULL,0}, {"head_skip",NINT,NREAD|NWRITE,foputabs,NULL,0}, {"read_step",NINT,NREAD|NWRITE,foputge1,NULL,0}, {"final_line",NINT,NREAD|NWRITE,f2dput,NULL,0}, {"mask",NIARRAY,NREAD|NWRITE,update_mask,NULL,0}, {"move_data",NIARRAY,NREAD|NWRITE,update_field,NULL,0}, {"move_data_x",NDARRAY,NREAD|NWRITE,update_field,NULL,0}, {"move_data_y",NDARRAY,NREAD|NWRITE,update_field,NULL,0}, {"move_data_adjust",NVFUNC,NREAD|NEXEC,adjust_move_num,"",0}, {"axis_x",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"axis_y",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"data_clip",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"dnum",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dminx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dmaxx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"davx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dsigx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dstdevpx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dstdevx",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dminy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dmaxy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"davy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dsigy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dstdevpy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dstdevy",NSFUNC,NREAD|NEXEC,f2dstat,"",0}, {"dx",NSFUNC,NREAD|NEXEC,f2dstat2,"i",0}, {"dy",NSFUNC,NREAD|NEXEC,f2dstat2,"i",0}, {"d2",NSFUNC,NREAD|NEXEC,f2dstat2,"i",0}, {"d3",NSFUNC,NREAD|NEXEC,f2dstat2,"i",0}, {"data_num",NINT,NREAD,NULL,NULL,0}, {"data_x",NDOUBLE,NREAD,NULL,NULL,0}, {"data_y",NDOUBLE,NREAD,NULL,NULL,0}, {"data_2",NDOUBLE,NREAD,NULL,NULL,0}, {"data_3",NDOUBLE,NREAD,NULL,NULL,0}, {"coord_x",NINT,NREAD,NULL,NULL,0}, {"coord_y",NINT,NREAD,NULL,NULL,0}, {"coord_2",NINT,NREAD,NULL,NULL,0}, {"coord_3",NINT,NREAD,NULL,NULL,0}, {"stat_x",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_y",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_2",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_3",NENUM,NREAD,NULL,matherrorchar,0}, {"minx",NDOUBLE,NREAD,NULL,NULL,0}, {"maxx",NDOUBLE,NREAD,NULL,NULL,0}, {"miny",NDOUBLE,NREAD,NULL,NULL,0}, {"maxy",NDOUBLE,NREAD,NULL,NULL,0}, {"stat_minx",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_maxx",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_miny",NENUM,NREAD,NULL,matherrorchar,0}, {"stat_maxy",NENUM,NREAD,NULL,matherrorchar,0}, {"line",NINT,NREAD,NULL,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,f2ddraw,"i",0}, {"getcoord",NIAFUNC,NREAD|NEXEC,f2dgetcoord,"dd",0}, {"redraw",NVFUNC,NREAD|NEXEC,f2dredraw,"i",0}, {"opendata",NVFUNC,NREAD|NEXEC,f2dopendata,"",0}, {"opendatac",NVFUNC,NREAD|NEXEC,f2dopendata,"",0}, {"getdata",NVFUNC,NREAD|NEXEC,f2dgetdata,"",0}, {"closedata",NVFUNC,NREAD|NEXEC,f2dclosedata,"",0}, {"opendata_raw",NVFUNC,NEXEC,f2dopendataraw,"",0}, {"getdata_raw",NDAFUNC,NEXEC,f2dgetdataraw,"ia",0}, {"closedata_raw",NVFUNC,NEXEC,f2dclosedataraw,"",0}, {"column",NSFUNC,NREAD|NEXEC,f2dcolumn,"ii",0}, {"basename",NSFUNC,NREAD|NEXEC,f2dbasename,"",0}, {"head_lines",NSFUNC,NREAD|NEXEC,f2dhead,"i",0}, {"boundings",NVFUNC,NREAD|NEXEC,f2dboundings,"b",0}, {"bounding",NDAFUNC,NREAD|NEXEC,f2dbounding,"o",0}, {"load_settings",NVFUNC,NREAD|NEXEC,f2dsettings,"",0}, {"time",NSFUNC,NREAD|NEXEC,f2dtime,"i",0}, {"date",NSFUNC,NREAD|NEXEC,f2ddate,"i",0}, {"save",NSFUNC,NREAD|NEXEC,f2dsave,"sa",0}, {"evaluate",NDAFUNC,NREAD|NEXEC,f2devaluate,"iiiiii",0}, {"store_data",NSFUNC,NREAD|NEXEC,f2dstore,"",0}, {"load_data",NVFUNC,NREAD|NEXEC,f2dload,"s",0}, {"store_dummy",NSFUNC,NREAD|NEXEC,f2dstoredum,"",0}, {"load_dummy",NVFUNC,NREAD|NEXEC,f2dloaddum,"s",0}, {"tight",NVFUNC,NREAD|NEXEC,f2dtight,"",0}, {"save_config",NVFUNC,NREAD|NEXEC,f2dsaveconfig,"",0}, {"output_file",NVFUNC,NREAD|NEXEC,f2doutputfile,"sib",0}, {"modified",NVFUNC,NEXEC,update_field,"",0}, {"hsb",NVFUNC,NREAD|NEXEC,put_hsb,"ddd",0}, {"hsb2",NVFUNC,NREAD|NEXEC,put_hsb2,"ddd",0}, {FIT_FIELD_PREFIX "newton",NSFUNC,NREAD|NEXEC,solve_equation,"da",0}, {FIT_FIELD_PREFIX "bisection",NSFUNC,NREAD|NEXEC,solve_equation,"da",0}, {FIT_FIELD_PREFIX "calc",NSFUNC,NREAD|NEXEC,calc_equation,"d",0}, {FIT_FIELD_PREFIX "prm",NSFUNC,NREAD|NEXEC,get_fit_parameter,"i",0}, {"math_functions",NSFUNC,NREAD|NEXEC,get_functions,"",0}, {"math_constants",NSFUNC,NREAD|NEXEC,get_constants,"",0}, {"_local",NPOINTER,0,NULL,NULL,0}, /* for range */ {"range_min", NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"range_max", NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"range_div", NINT,NREAD|NWRITE,oputge1,NULL,0}, /* for array */ {"array",NOBJ,NREAD|NWRITE,set_array,NULL,0}, }; #define TBLNUM (sizeof(file2d) / sizeof(*file2d)) void * addfile(void) /* addfile() returns NULL on error */ { struct objlist *data_obj; unsigned int i; if (FileConfigHash == NULL) { FileConfigHash = nhash_new(); if (FileConfigHash == NULL) return NULL; for (i = 0; i < sizeof(FileConfig) / sizeof(*FileConfig); i++) { if (nhash_set_ptr(FileConfigHash, FileConfig[i].name, (void *) &FileConfig[i])) { nhash_free(FileConfigHash); return NULL; } } } data_obj = addobject(NAME,ALIAS,PARENT,OVERSION,TBLNUM,file2d,ERRNUM,f2derrorlist,NULL,NULL); obj_set_undo_func(data_obj, data_inst_dup, data_inst_free); return data_obj; } ngraph-gtk-6.08.00/src/common.h0000644000175000017500000000204513351432266013106 00000000000000#ifndef COMMON_HEADER #define COMMON_HEADER #ifdef HAVE_CONFIG_H #include "config.h" #endif #ifdef HAVE_GETTEXT #define DEFAULT_TEXT_DOMAIN PACKAGE #include "gettext.h" #define _(String) gettext(String) #define N_(String) gettext_noop(String) #else /* HAVE_GETTEXT */ #define _(String) (String) #define N_(String) (String) #endif /* HAVE_GETTEXT */ #include #include #ifdef G_OS_WIN32 #define WINDOWS 1 #ifndef _WIN32_WINNT #define _WIN32_WINNT 0x0500 #endif #include #else #define WINDOWS 0 #endif #ifdef __APPLE__ #define OSX 1 #else #define OSX 0 #endif #ifdef __WIN64__ #define WINDOWS 1 #include #endif #ifndef CCNAME #define CCNAME "unknown"; #endif #ifndef __VERSION__ #define __VERSION__ "" #endif #define COMPILER_NAME (CCNAME " " __VERSION__) #define MARK_TYPE_NUM 90 int printfconsole(const char *fmt,...); int putconsole(const char *s); int printfconsole(const char *fmt,...); void displaydialog(const char *str); void displaystatus(const char *str); #endif /* COMMON_HEADER */ ngraph-gtk-6.08.00/src/nstring.h0000644000175000017500000000300213070106167013270 00000000000000/* * $Id: nstring.h,v 1.4 2009-11-16 09:13:04 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef NSTRING_HEADER #define NSTRING_HEADER #define STRLEN 256 #define CHK_STR(s) (((s) == NULL) ? "" : (s)) char *nstrnew(void); char *nstrccat(char *po,char ch); char *nstrcat(char *po,char *s); char *nstraddchar(char *po, int len, char ch); int strcmp0(const char *s1,const char *s2); int strcmp2(char *s1,char *s2); #define WILD_PATHNAME 2 #define WILD_PERIOD 4 int wildmatch(const char *pat, const char *s,int flags); char *getitok(char **s, int *len, const char *ifs); char *getitok2(char **s, int *len, const char *ifs); int add_printf_formated_str(GString *str, const char *format, const char *arg, int *len); #endif ngraph-gtk-6.08.00/src/olegend.c0000644000175000017500000003560413360311000013213 00000000000000/* * $Id: olegend.c,v 1.18 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include "spline.h" #include "gra.h" #include "mathfn.h" #include "object.h" #include "odraw.h" #include "olegend.h" #define NAME "legend" #define PARENT "draw" #define OVERSION "1.00.00" static char *legenderrorlist[]={ "", }; #define ERRNUM (sizeof(legenderrorlist) / sizeof(*legenderrorlist)) static int legendinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int legenddone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } int legendgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { if (clear_bbox(obj, inst)) return 1; return 0; } int legendmatch(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy,err; int bminx,bminy,bmaxx,bmaxy; int i,num,*data; double x1,y1,x2,y2; double r,r2,r3,ip; struct narray *array; rval->i=FALSE; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); if (array==NULL) return 0; minx=*(int *)argv[2]; miny=*(int *)argv[3]; maxx=*(int *)argv[4]; maxy=*(int *)argv[5]; err=*(int *)argv[6]; if ((minx==maxx) && (miny==maxy)) { num=arraynum(array)-4; data=arraydata(array); for (i=0;ii=TRUE; break; } if (r2!=0) { ip=((x2-x1)*(minx-x1)+(y2-y1)*(miny-y1))/r2; if ((0<=ip) && (ip<=r2)) { x2=x1+(x2-x1)*ip/r2; y2=y1+(y2-y1)*ip/r2; r=sqrt((minx-x2)*(minx-x2)+(miny-y2)*(miny-y2)); if (ri=TRUE; break; } } } } } else { if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } int legendbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy; int x,y,num; struct narray *points; int pnum; int *pdata; struct narray *array; int i,width; array=rval->array; if (arraynum(array)!=0) return 0; _getobj(obj,"points",inst,&points); _getobj(obj,"width",inst,&width); pnum=arraynum(points); pdata=arraydata(points); num=pnum/2; if (num<2) return 0; if ((array==NULL) && ((array=arraynew(sizeof(int)))==NULL)) return 1; maxx=minx=pdata[0]; maxy=miny=pdata[1]; arrayadd(array,&(pdata[0])); arrayadd(array,&(pdata[1])); for (i=1;imaxx) maxx=x; if (ymaxy) maxy=y; } minx-=width/2; miny-=width/2; maxx+=width/2; maxy+=width/2; arrayins(array,&(maxy),0); arrayins(array,&(maxx),0); arrayins(array,&(miny),0); arrayins(array,&(minx),0); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } rval->array=array; return 0; } int legendmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *points; int i,num,*pdata; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"points",inst,&points); num=arraynum(points); pdata=arraydata(points); for (i=0;i 255) { val = 255; } switch (col) { case 'R': _putobj(obj, "stroke_R", inst, &val); _putobj(obj, "fill_R", inst, &val); break; case 'G': _putobj(obj, "stroke_G", inst, &val); _putobj(obj, "fill_G", inst, &val); break; case 'B': _putobj(obj, "stroke_B", inst, &val); _putobj(obj, "fill_B", inst, &val); break; case 'A': _putobj(obj, "stroke_A", inst, &val); _putobj(obj, "fill_A", inst, &val); break; } return 0; } static struct objtable legend[] = { {"init",NVFUNC,0,legendinit,NULL,0}, {"done",NVFUNC,0,legenddone,NULL,0}, {"bbox",NIAFUNC,NREAD|NEXEC,NULL,"",0}, {"move",NVFUNC,NREAD|NEXEC,NULL,"ii",0}, {"zooming",NVFUNC,NREAD|NEXEC,NULL,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,NULL,"iiiii",0}, }; #define TBLNUM (sizeof(legend) / sizeof(*legend)) void * addlegend(void) /* addlegend() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,legend,ERRNUM,legenderrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/spline.h0000644000175000017500000000346313070106167013111 00000000000000/* * $Id: spline.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #define SPLCNDAUTO 0 #define SPLCND1STDIF 1 #define SPLCND2NDDIF 2 #define SPLCNDPERIODIC 3 int spline(double x[],double y[],double c1[],double c2[],double c3[], int num,int bc0,int bc1,double df0,double df1); void bspline(int edge,double x[],double c[]); void splinedif(double d,double c[], double *dx,double *dy,double *ddx,double *ddy,void *local); void splinedifxy(double d,double c[], double *dx,double *dy,double *ddx,double *ddy,void *local); void bsplinedif(double d,double c[], double *dx,double *dy,double *ddx,double *ddy,void *local); void splineint(double d,double c[],double x0,double y0,double *x,double *y, void *local); void splineintxy(double d,double c[],double x0,double y0,double *x,double *y, void *local); void bsplineint(double d,double c[],double x0,double y0,double *x,double *y, void *local); ngraph-gtk-6.08.00/src/ofit.c0000644000175000017500000010022613142564544012555 00000000000000/* * $Id: ofit.c,v 1.37 2010-02-24 00:52:44 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include "nstring.h" #include "ioutil.h" #include "object.h" #include "mathfn.h" #include "oroot.h" #include "ofit.h" #include "odata.h" #include "math/math_equation.h" #define NAME "fit" #define PARENT "object" #define OVERSION "1.00.01" #define ERRSYNTAX 100 #define ERRILLEGAL 101 #define ERRNEST 102 #define ERRMANYPARAM 103 #define ERRLN 104 #define ERRSMLDATA 105 #define ERRPOINT 106 #define ERRMATH 107 #define ERRSINGULAR 108 #define ERRNOEQS 109 #define ERRTHROUGH 110 #define ERRRANGE 111 #define ERRNEGATIVEWEIGHT 112 #define ERRCONVERGE 113 #define ERR_INCONSISTENT_DATA_NUM 114 #define ERRINTERRUPT 115 static char *fiterrorlist[]={ "syntax error.", "not allowed function.", "sum() or dif(): deep nest.", "too many parameters.", "illegal data -> ignored.", "too small number of data.", "illegal point", "math error -> ignored.", "singular matrix.", "no fitting equation.", "`through_point' for type `user' is not supported.", "math range check.", "negative or zero weight -> ignored.", "convergence error.", "number of the data is not consistent.", }; #define ERRNUM (sizeof(fiterrorlist) / sizeof(*fiterrorlist)) static char *fittypechar[]={ N_("poly"), N_("pow"), N_("exp"), N_("log"), N_("user"), NULL }; struct fitlocal { int id, oid; MathEquation *codedf[10]; MathEquation *codef, *result_code; int dim; double coe[11]; int num; double derror,correlation; char *equation; }; static int fitinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int div,dimension; double converge; struct fitlocal *fitlocal; int i,disp, oid; if (_getobj(obj, "oid", inst, &oid) == -1) return 1; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; div=500; dimension=1; converge=1; disp=TRUE; if (_putobj(obj,"div",inst,&div)) return 1; if (_putobj(obj,"poly_dimension",inst,&dimension)) return 1; if (_putobj(obj,"converge",inst,&converge)) return 1; if (_putobj(obj,"display",inst,&disp)) return 1; if ((fitlocal=g_malloc(sizeof(struct fitlocal)))==NULL) return 1; fitlocal->codef=NULL; fitlocal->result_code = NULL; for (i=0;i<10;i++) fitlocal->codedf[i]=NULL; fitlocal->equation=NULL; fitlocal->oid = oid; if (_putobj(obj,"_local",inst,fitlocal)) { g_free(fitlocal); return 1; } return 0; } static int fitdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct fitlocal *fitlocal; int i; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&fitlocal); g_free(fitlocal->equation); math_equation_free(fitlocal->codef); math_equation_free(fitlocal->result_code); for (i = 0; i < 10; i++) math_equation_free(fitlocal->codedf[i]); return 0; } static int set_equation(struct objlist *obj, N_VALUE *inst, struct fitlocal *fitlocal, char *equation) { int r; char *old_equation; _getobj(obj, "equation", inst, &old_equation); r = _putobj(obj, "equation", inst, equation); if (r) { return 1; } if (old_equation) { g_free(old_equation); } if (fitlocal && fitlocal->result_code) { math_equation_free(fitlocal->result_code); fitlocal->result_code = NULL; } return 0; } static void show_eqn_error(struct objlist *obj, MathEquation *code, const char *math, const char *field, int rcode) { char *err_msg; err_msg = math_err_get_error_message(code, math, rcode); if (err_msg) { error22(obj, ERRUNKNOWN, field, err_msg); g_free(err_msg); } else { error(obj, ERRSYNTAX); } } static int fitequation(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { struct fitlocal *fitlocal; _getobj(obj,"_local",inst,&fitlocal); if (fitlocal->result_code) { math_equation_free(fitlocal->result_code); fitlocal->result_code = NULL; } return 0; } static MathEquation * create_math_equation(struct objlist *obj, const char *math, const char *field) { MathEquation *code; int rcode; code = ofile_create_math_equation(NULL, 2, FALSE, FALSE, FALSE, FALSE, TRUE); if (code == NULL) { return NULL; } rcode = math_equation_parse(code, math); if (rcode) { show_eqn_error(obj, code, math, field, rcode); math_equation_free(code); return NULL; } if (math_equation_optimize(code)) { math_equation_free(code); return NULL; } return code; } static int fitput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; char *math; struct fitlocal *fitlocal; MathEquation *code; _getobj(obj,"_local",inst,&fitlocal); field=argv[1]; if (strcmp(field,"poly_dimension")==0) { if (*(int *)(argv[2])<1) *(int *)(argv[2])=1; else if (*(int *)(argv[2])>9) *(int *)(argv[2])=9; } else if ((strcmp(field,"user_func")==0) || ((strncmp(field,"derivative",10)==0) && (field[10]!='\0'))) { math=(char *)(argv[2]); if (math!=NULL) { MathEquationParametar *prm; code = create_math_equation(obj, math, field); if (code == NULL) { return 1; } prm = math_equation_get_parameter(code, 0, NULL); if (prm == NULL) { math_equation_free(code); return 1; } if (prm->id_max > 9) { error(obj,ERRMANYPARAM); math_equation_free(code); return 1; } } else { code=NULL; } if (field[0]=='u') { math_equation_free(fitlocal->codef); fitlocal->codef = code; } else { math_equation_free(fitlocal->codedf[field[10] - '0']); fitlocal->codedf[field[10] - '0'] = code; } } if (set_equation(obj, inst, fitlocal, NULL)) return 1; return 0; } static int fit_put_weight_func(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *math; MathEquation *code; int rcode; math = argv[2]; if (math == NULL) { return 0; } g_strstrip(math); if (math[0] == '\0') { g_free(argv[2]); argv[2] = NULL; return 0; } code = ofile_create_math_equation(NULL, 3, FALSE, TRUE, FALSE, FALSE, TRUE); if (code == NULL) return 1; rcode = math_equation_parse(code, math); if (rcode) { show_eqn_error(obj, code, math, argv[1], rcode); } math_equation_free(code); return rcode; } enum FitError { FitError_Interrupt = -7, /* FitError_Convergence = -6, */ FitError_Range = -5, /* range check */ FitError_Syntax = -4, /* syntax error */ FitError_Equation = -3, /* equation is not specified */ FitError_Matrix = -2, /* singular matrix */ FitError_Small = -1, /* too small data */ FitError_Success = 0, /* no error */ FitError_Fatal = 1, /* fatal error */ }; static void display_equation(const char *equation) { if (equation == NULL) return; ndisplaydialog("\nEquation:\n"); ndisplaydialog(equation); ndisplaydialog("\n"); } static int show_poly_equation(struct fitlocal *fitlocal, enum FIT_OBJ_TYPE type, vector coe) { GString *equation; int i; equation = g_string_new(""); if (equation == NULL) { return 1; } switch (type) { case FIT_TYPE_POLY: for (i = fitlocal->dim - 1; i > 0; i--) { g_string_append_printf(equation, (i == fitlocal->dim - 1) ? "%.7e*X" : "%+.7e*X", coe[i]); if (i > 1) { g_string_append_printf(equation, "^%d", i); } } g_string_append_printf(equation, "%+.7e", coe[0]); break; case FIT_TYPE_POW: g_string_printf(equation, "exp(%.7e)*X^%.7e", coe[0], coe[1]); break; case FIT_TYPE_EXP: g_string_printf(equation, "exp(%.7e*X%+.7e)", coe[1], coe[0]); break; case FIT_TYPE_LOG: g_string_printf(equation, "%.7e*Ln(X)%+.7e", coe[1], coe[0]); break; case FIT_TYPE_USER: /* never reached */ break; } fitlocal->equation = g_string_free(equation, FALSE); return 0; } static int show_poly_result(struct fitlocal *fitlocal, enum FIT_OBJ_TYPE type, vector coe, int num) { int j; GString *info; info = g_string_new(""); if (info == NULL) { return 1; } g_string_append_printf(info, "--------\nfit:%d (^%d)\n", fitlocal->id, fitlocal->oid); switch (type) { case FIT_TYPE_POLY: g_string_append_printf(info,"Eq: %%0i*X^i (i=0-%d)\n\n", fitlocal->dim - 1); break; case FIT_TYPE_POW: g_string_append(info,"Eq: exp(%00)*X^%01\n\n"); break; case FIT_TYPE_EXP: g_string_append(info,"Eq: exp(%01*X+%00)\n\n"); break; case FIT_TYPE_LOG: g_string_append(info,"Eq: %01*Ln(X)+%00\n\n"); break; case FIT_TYPE_USER: /* never reached */ break; } for (j = 0; j < fitlocal->dim; j++) { g_string_append_printf(info, " %%0%d = %+.7e\n", j, coe[j]); } g_string_append_c(info, '\n'); g_string_append_printf(info, " points = %d\n", fitlocal->num); g_string_append_printf(info, " = %+.7e\n", fitlocal->derror); if (fitlocal->correlation >= 0) { g_string_append_printf(info, "|r| or |R| = %+.7e\n", fitlocal->correlation); } else { g_string_append(info, "|r| or |R| = -------------\n"); } ndisplaydialog(info->str); g_string_free(info, TRUE); display_equation(fitlocal->equation); return 0; } static enum FitError fitpoly(struct fitlocal *fitlocal, enum FIT_OBJ_TYPE type,int dimension,int through,double x0,double y0, double *data,int num,int disp,int weight,double *wdata) /* return FitError_Range FitError_Matrix FitError_Small FitError_Success FitError_Fatal */ { int i,j,k,dim; double yy,y1,y2,derror,sy,correlation,wt,sum; vector b,x1,x2,coe; matrix m; if (type == FIT_TYPE_POLY) dim=dimension+1; else dim=2; if (!through && (num1e100) || (fabs(data[k*2])>1e100)) return FitError_Range; x1[i]=x1[i-1]*data[k*2]; if (fabs(x1[i])>1e100) return FitError_Range; } yy+=wt*y1*y1; if (fabs(yy)>1e100) return FitError_Range; for (i=0;i1e100) return FitError_Range; b[i]+=wt*y1*x1[i]; if (fabs(b[i])>1e100) return FitError_Range; } for (i=0;i1e100) return FitError_Range; } } if (through) { y2=y0; x2[0]=1; for (i=1;icoe[i]=coe[i]; for (;i<10;i++) fitlocal->coe[i]=0; fitlocal->dim=dim; fitlocal->derror=derror; fitlocal->correlation=correlation; fitlocal->num=num; if (show_poly_equation(fitlocal, type, coe)) { return FitError_Fatal; } if (disp && show_poly_result(fitlocal, type, coe, derror)) { return FitError_Fatal; } return FitError_Success; } static int show_user_result(struct fitlocal *fitlocal, const char *func, int dim, int *tbl, MathValue *par, int n, double dxxc, double derror, double correlation) { GString *info; int j; info = g_string_sized_new(1024); if (info == NULL) { return 1; } g_string_append_printf(info, "--------\nfit:%d (^%d)\n", fitlocal->id, fitlocal->oid); g_string_append(info, "Eq: User defined\n"); g_string_append_printf(info, " %s\n\n", func); for (j = 0; j < dim; j++) { g_string_append_printf(info, " %%0%d = %+.7e\n", tbl[j], par[tbl[j]].val); } g_string_append_c(info, '\n'); g_string_append_printf(info, " points = %d\n", n); g_string_append_printf(info, " delta = %+.7e\n", dxxc); g_string_append_printf(info, " = %+.7e\n", derror); if (correlation >= 0) { g_string_append_printf(info, "|r| or |R| = %+.7e\n", correlation); } else { g_string_append(info, "|r| or |R| = -------------\n"); } ndisplaydialog(info->str); g_string_free(info, TRUE); return 0; } static int show_user_equation(struct fitlocal *fitlocal, const char *func, MathValue *par, int disp) { int i, prev_char; GString *equation; equation = g_string_sized_new(256); if (equation == NULL) { return 1; } prev_char = '\0'; for (i = 0; func[i] != '\0'; i++) { double val; char *format; int prm_index; switch (func[i]) { case '%': if (isdigit(func[i + 1]) && isdigit(func[i + 2]) && isdigit(func[i + 3])) { prm_index = (func[i + 1] - '0') * 100 + (func[i + 2] - '0') * 10 + (func[i + 3] - '0'); i += 3; } else if (isdigit(func[i + 1]) && isdigit(func[i + 2])) { prm_index = (func[i + 1] - '0') * 10 + (func[i + 2] - '0'); i += 2; } else { prm_index = (func[i + 1] - '0'); i += 1; } val = par[prm_index].val; switch (prev_char) { case '-': val = - val; /* fall-through */ case '+': g_string_truncate(equation, equation->len - 1); format = "%+.7e"; break; default: format = "%.7e"; } prev_char = '\0'; g_string_append_printf(equation, format, val); break; case ' ': break; default: prev_char = func[i]; g_string_append_c(equation, toupper(prev_char)); } } fitlocal->equation = g_string_free(equation, FALSE); if (disp) { display_equation(fitlocal->equation); } return 0; } static enum FitError fituser(struct objlist *obj,struct fitlocal *fitlocal, const char *func, int deriv,double converge,double *data,int num,int disp, int weight,double *wdata) /* return FitError_Interrupt FitError_Convergence FitError_Range FitError_syntax FitError_Equation FitError_Matrix FitError_Small FitError_Success FitError_Fatal */ { int ecode; int *needdata; int tbl[10],dim,n,count,err,err2,err3; double yy,y,y1,y2,y3,sy,spx,spy,dxx,dxxc,xx,derror,correlation; double b[10],x2[10],parerr[10]; MathValue par[10], par2[10], var; MathEquationParametar *prm; matrix m; int i,j,k; char buf[1024]; double wt,sum; /* matrix m2; int count2; double sum2; double lambda,s0; */ if (num<1) return FitError_Small; if (fitlocal->codef==NULL) return FitError_Equation; prm = math_equation_get_parameter(fitlocal->codef, 0, NULL); dim = prm->id_num; needdata = prm->id; if (deriv) { for (i = 0; i < dim; i++) { if (fitlocal->codedf[needdata[i]] == NULL) return FitError_Equation; } } for (i = 0; i < dim; i++) tbl[i] = needdata[i]; for (i = 0; i < 10; i++) { par[i].type = MATH_VALUE_NORMAL; par[i].val = fitlocal->coe[i]; } ecode=FitError_Success; /* err2=FALSE; n=0; sum=0; yy=0; lambda=0.001; for (k=0;kcodef,1,spx,MATH_VALUE_NORMAL,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0, par,parstat,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL, NULL,NULL,NULL,0,NULL,NULL,NULL,0,&y1); if (rcode!=MATH_VALUE_NORMAL) err=TRUE; if (!err) { if (fabs(yy)>1e100) return FitError_Range; y2=spy-y1; if ((fabs(y2)>1e50) || (fabs(spy)>1e50)) err=TRUE; } if (!err) { n++; yy+=wt*y2*y2; } else err2=TRUE; } if (err2) error(obj,ERRMATH); if (n<1) { ecode=FitError_Small; goto errexit; } s0=yy/sum; */ count=0; err3=FALSE; do { yy=0; y=0; y3=0; for (i=0;icodef, 0, par); math_equation_set_var(fitlocal->codef, 0, &var); math_equation_calculate(fitlocal->codef, &var); y1 = var.val; if (var.type!=MATH_VALUE_NORMAL) err=TRUE; if (deriv) { for (j=0;jcodedf[tbl[j]], 0, par); math_equation_set_var(fitlocal->codedf[tbl[j]], 0, &var); math_equation_calculate(fitlocal->codedf[tbl[j]], &var); x2[j] = var.val; if (var.type!=MATH_VALUE_NORMAL) err=TRUE; } } else { for (j=0;jcodef, 0, par2); math_equation_set_var(fitlocal->codef, 0, &var); math_equation_calculate(fitlocal->codef, &var); x2[j] = var.val; if (var.type!=MATH_VALUE_NORMAL) err=TRUE; x2[j]=(x2[j]-y1)/dxx; } } if (!err) { if ((fabs(yy)>1e100) || (fabs(y3)>1e100)) return FitError_Range; y2=spy-y1; if ((fabs(y2)>1e50) || (fabs(spy)>1e50)) err=TRUE; } if (!err) { n++; yy+=wt*y2*y2; y+=wt*spy; y3+=wt*spy*spy; for (j=0;j1) correlation=-1; derror=sqrt(derror); /* if (disp) { i=0; i += sprintf(buf + i, "fit:^%d\n", fitlocal->oid); i+=sprintf(buf+i,"Eq: User defined\n\n"); for (j=0;j = %+.7e\n",derror); if (correlation>=0) i+=sprintf(buf+i,"|r| or |R| = %+.7e\n",correlation); else i+=sprintf(buf+i,"|r| or |R| = -------------\n"); i+=sprintf(buf+i," Iteration = %d\n",count); ndisplaydialog(buf); } */ if (count & 0x100) { sprintf(buf,"fit:^%d Iteration = %d delta = %g", fitlocal->oid, count, dxxc); set_progress(0, buf, -1); } if (ninterrupt()) { ecode=FitError_Interrupt; goto errexit; } /* count2=0; sum2=sum; while (TRUE) { count2++; sprintf(buf,"Iteration = %d:%d",count,count2); ndisplaystatus(buf); for (j=0;jcodef,1,spx,MATH_VALUE_NORMAL,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0, par2,parstat,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL, NULL,NULL,NULL,0,NULL,NULL,NULL,0,&y1); if (rcode!=MATH_VALUE_NORMAL) err=TRUE; if (!err) { if (fabs(yy)>1e100) goto repeat; y2=spy-y1; if ((fabs(y2)>1e50) || (fabs(spy)>1e50)) err=TRUE; } if (!err) { n++; yy+=wt*y2*y2; } } if (n<1) goto repeat; if (yy/sum<=s0) { s0=yy/sum; break; } repeat: lambda*=10; if (lambda>1e100) return FitError_Convergence; } lambda/=10; */ if (matsolv(dim,m,b,parerr)) return FitError_Matrix; dxxc=0; xx=0; for (i=0;ixx*converge/100) && ((xx>1e-6) || (dxxc>1e-6*converge/100))); if (disp && show_user_result(fitlocal, func, dim, tbl, par, n, dxxc, derror, correlation)) {; return FitError_Fatal; } errexit: if ((ecode==FitError_Success) || (ecode==FitError_Range)) { for (i = 0; i < 10; i++) { fitlocal->coe[i] = par[i].val; } fitlocal->dim=dim; fitlocal->derror=derror; fitlocal->correlation=correlation; fitlocal->num=n; if (show_user_equation(fitlocal, func, par, disp)) { ecode = FitError_Fatal; } } return ecode; } static int fitfit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct fitlocal *fitlocal; int i,through,dimension,deriv,disp; enum FIT_OBJ_TYPE type; double x,y,x0,y0,converge,wt; struct narray *darray; double *data,*wdata; char *equation,*func,prm[32]; int dnum,num,err,err2,err3; enum FitError rcode; double derror,correlation,pp; int ecode; int weight,anum; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&fitlocal); if (set_equation(obj, inst, fitlocal, NULL)) return 1; equation = g_strdup("undef"); if (equation == NULL) return 1; if (set_equation(obj, inst, fitlocal, equation)) { g_free(equation); return 1; } num=0; derror=0; correlation=0; pp=0; if (_putobj(obj,"number",inst,&num)) return 1; if (_putobj(obj,"error",inst,&derror)) return 1; if (_putobj(obj,"correlation",inst,&correlation)) return 1; for (i = 0; i < 10; i++) { snprintf(prm, sizeof(prm), "%%%02d", i); if (_putobj(obj, prm, inst, &pp)) return 1; } _getobj(obj,"type",inst,&type); _getobj(obj,"through_point",inst,&through); _getobj(obj,"point_x",inst,&x0); _getobj(obj,"point_y",inst,&y0); _getobj(obj,"poly_dimension",inst,&dimension); _getobj(obj,"user_func",inst,&func); _getobj(obj,"derivative",inst,&deriv); _getobj(obj,"converge",inst,&converge); _getobj(obj, "id", inst, &(fitlocal->id)); for (i = 0; i < 10; i++) { snprintf(prm, sizeof(prm), "parameter%d", i); _getobj(obj, prm, inst, &(fitlocal->coe[i])); } _getobj(obj,"display",inst,&disp); if (through && (type == FIT_TYPE_USER)) { error(obj,ERRTHROUGH); return 1; } darray = (struct narray *) (argv[2]); if (arraynum(darray) < 1) return FitError_Small; data=arraydata(darray); anum=arraynum(darray)-1; dnum=nround(data[0]); data += 1; if (dnum == (anum / 2)) { weight = FALSE; wt = 0; /* dummy code to avoid compile warnings */ wdata = NULL; /* dummy code to avoid compile warnings */ } else if (dnum == (anum / 3)) { weight = TRUE; wdata = data + 2 * dnum; } else { error(obj, ERR_INCONSISTENT_DATA_NUM); return 1; } num=0; err2=err3=FALSE; for (i=0;inum))) return 1; if (_putobj(obj,"error",inst,&(fitlocal->derror))) return 1; if (_putobj(obj,"correlation",inst,&(fitlocal->correlation))) return 1; for (i = 0; i < 10; i++) { snprintf(prm, sizeof(prm), "%%%02d", i); if (_putobj(obj, prm, inst, &(fitlocal->coe[i]))) return 1; } if (set_equation(obj, inst, fitlocal, fitlocal->equation)) return 1; fitlocal->equation = NULL; return 0; } static int fitcalc(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { MathValue val; int r; char *equation; double x; struct fitlocal *fitlocal; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; rval->d = 0; x = * (double *) argv[2]; _getobj(obj,"_local",inst,&fitlocal); if (fitlocal->result_code == NULL) { MathEquation *eq; _getobj(obj, "equation", inst, &equation); if (equation == NULL) { return 0; } eq = ofile_create_math_equation(NULL, 0, FALSE, FALSE, FALSE, FALSE, TRUE); if (eq == NULL) { return 1; } if (math_equation_parse(eq, equation)) { math_equation_free(eq); return 1; } math_equation_optimize(eq); fitlocal->result_code = eq; } val.val = x; val.type = MATH_VALUE_NORMAL; math_equation_set_var(fitlocal->result_code, 0, &val); r = math_equation_calculate(fitlocal->result_code, &val); if (r) { return 1; } rval->d = val.val; return 0; } static int fit_inst_dup(struct objlist *obj, N_VALUE *src, N_VALUE *dest) { int i, pos, len; struct fitlocal *local_new, *local_src; char deriv[] = "derivative0", *math; pos = obj_get_field_pos(obj, "_local"); if (pos < 0) { return 1; } local_src = src[pos].ptr; local_new = g_memdup(local_src, sizeof(struct fitlocal)); if (local_new == NULL) { return 1; } dest[pos].ptr = local_new; local_new->equation = g_strdup(local_src->equation); local_new->result_code = NULL; if (local_src->codef) { _getobj(obj, "user_func", src, &math); local_new->codef = create_math_equation(obj, math, "user_func"); if (local_new->codef == NULL) { return 1; } } len = sizeof(deriv); for (i = 0; i < 10; i++) { deriv[len - 2] = '0' + i; if (local_src->codedf[i]) { _getobj(obj, deriv, src, &math); local_new->codedf[i] = create_math_equation(obj, math, deriv); if (local_new->codedf[i] == NULL) { return 1; } } } return 0; } static int fit_inst_free(struct objlist *obj, N_VALUE *inst) { int i, pos; struct fitlocal *local; pos = obj_get_field_pos(obj, "_local"); if (pos < 0) { return 1; } local = inst[pos].ptr; if (local->equation) { g_free(local->equation); } if (local->result_code) { math_equation_free(local->result_code); } if (local->codef) { math_equation_free(local->codef); } for (i = 0; i < 10; i++) { if (local->codedf[i]) { math_equation_free(local->codedf[i]); } } g_free(local); return 0; } static struct objtable fit[] = { {"init",NVFUNC,NEXEC,fitinit,NULL,0}, {"done",NVFUNC,NEXEC,fitdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"profile",NSTR,NREAD|NWRITE,NULL,NULL,0}, {"type",NENUM,NREAD|NWRITE,fitput,fittypechar,0}, {"min",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"max",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, {"div",NINT,NREAD|NWRITE,oputge1,NULL,0}, {"interpolation",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"through_point",NBOOL,NREAD|NWRITE,fitput,NULL,0}, {"point_x",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"point_y",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"equation",NSTR,NREAD|NWRITE,fitequation,NULL,0}, {"poly_dimension",NINT,NREAD|NWRITE,fitput,NULL,0}, {"weight_func",NSTR,NREAD|NWRITE,fit_put_weight_func,NULL,0}, {"user_func",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative",NBOOL,NREAD|NWRITE,fitput,NULL,0}, {"derivative0",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative1",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative2",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative3",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative4",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative5",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative6",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative7",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative8",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"derivative9",NSTR,NREAD|NWRITE,fitput,NULL,0}, {"converge",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter0",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter1",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter2",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter3",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter4",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter5",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter6",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter7",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter8",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"parameter9",NDOUBLE,NREAD|NWRITE,fitput,NULL,0}, {"%00",NDOUBLE,NREAD,NULL,NULL,0}, {"%01",NDOUBLE,NREAD,NULL,NULL,0}, {"%02",NDOUBLE,NREAD,NULL,NULL,0}, {"%03",NDOUBLE,NREAD,NULL,NULL,0}, {"%04",NDOUBLE,NREAD,NULL,NULL,0}, {"%05",NDOUBLE,NREAD,NULL,NULL,0}, {"%06",NDOUBLE,NREAD,NULL,NULL,0}, {"%07",NDOUBLE,NREAD,NULL,NULL,0}, {"%08",NDOUBLE,NREAD,NULL,NULL,0}, {"%09",NDOUBLE,NREAD,NULL,NULL,0}, {"number",NINT,NREAD,NULL,NULL,0}, {"error",NDOUBLE,NREAD,NULL,NULL,0}, {"correlation",NDOUBLE,NREAD,NULL,NULL,0}, {"display",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"fit",NVFUNC,NREAD|NEXEC,fitfit,"da",0}, {"calc",NDFUNC,NREAD|NEXEC,fitcalc,"d",0}, {"_local",NPOINTER,0,NULL,NULL,0}, }; #define TBLNUM (sizeof(fit) / sizeof(*fit)) void * addfit(void) /* addfit() returns NULL on error */ { struct objlist *fit_obj; fit_obj = addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,fit,ERRNUM,fiterrorlist,NULL,NULL); obj_set_undo_func(fit_obj, fit_inst_dup, fit_inst_free); return fit_obj; } ngraph-gtk-6.08.00/src/shell.c0000644000175000017500000032367413070106167012732 00000000000000/* * $Id: shell.c,v 1.41 2010-04-01 06:08:23 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ /* * SYNTAX: * * name1=val1 name2=val2 ... command arg1 arg2 arg3 ... * * # comment * * keyword * for name [in word] do list done * case word in [patterm [|pattern] ...list;;] ... esac * if list then list [elif list then list]...[else list] fi * while list do list done * until list do list done * name() { list; } * { } is needed * * command replacement * `command` * * parameter replacement * name=value [ name=value ] ... * $# $? $num $* $@ * ${parameter} * ${parameter:-word} * ${parameter:=word} * ${parameter:?word} * ${parameter:+word} * ${parameter#word} * ${parameter##word} * ${parameter%word} * ${parameter%%word} * * object replacement * object:namelist:field=value * ${object:namelist:field=argument} * * input & output * < file * << word * > file * >> file * * special command * : * .file * break [n] * continue [n] * cd * echo * eval [arg] * exit [n] * export [name] * pwd * quit * read name ... * return [n] * set * shift [n] * test * unset * [ * new object [field:val, ...] * del object namelist * exist object namelist * get object namelist field:argument ... * put object namelist field:val ... * exe object namelist field:argument ... * cpy object sname dnamelist field * move object sname dname * movetop object name * moveup object name * movedown object name * movelast object name * exch object name1 name2 * dexpr * iexpr * */ #include "common.h" #include #include #include #include #include #include #include #include #include #include #include #ifdef HAVE_READLINE_READLINE_H #include #include static char *Prompt; static int MultiLine = FALSE; #endif /* HAVE_READLINE_READLINE_H */ #if ! WINDOWS #include #include #endif /* WINDOWS */ #include #define USE_HASH 1 #include "object.h" #include "nstring.h" #include "ioutil.h" #include "shell.h" #include "shellcm.h" #include "shellux.h" #include "math/math_equation.h" #define TEMPPFX "NGS" static char *cmderrorlist[] = { "unexpected EOF.", "bad substitution.", "syntax error near unexpected token", "unexpected token", "invalid identifier", "command not found", "system call", "extra arguments.", "not enough argument.", "too many arguments.", "cannot open file", "Use \"exit\" to leave the shell.", "no such file", "I/O error: read file", "I/O error: open file", "missing object argument.", "missing instance argument.", "new instance is specified", "illegal field identifier", "illegal type of argument", "illegal number of specified instance.", "no instance specified", "no field identifier.", "non-numeric argument", "unknown option", "illegal option", "cannot unset", "no such directory", "syntax error for math.", "not allowed function for math.", "sum() or dif(): deep nest for math.", "illegal argument for math.", "fatal error for math.", "deep nest.", "syntax error.", "security check.", "cannot allocate enough memory.", "unknown error.", }; #define ERRNUM (sizeof(cmderrorlist) / sizeof(*cmderrorlist)) static char **MainEnviron; static int Security=FALSE; #define WRITEBUFSIZE 4096 static char writebuf[WRITEBUFSIZE]; static int writepo; static int Interrupted = FALSE; static int storeshhandle(struct nshell *nshell,int fd, char **readbuf,int *readbyte,int *readpo); static void restoreshhandle(struct nshell *nshell,int fd, char *readbuf,int readbyte,int readpo); typedef struct { int sleep; int msec; } ThreadParam; gpointer sleep_thread(gpointer data) { ThreadParam *th; th = (ThreadParam *) data; msleep(th->msec); th->sleep = FALSE; return 0; } void nsleep(double a) { ThreadParam th; GThread *thread; if (a < 0 || a > 100000) { return; } th.sleep = TRUE; th.msec = a * 1000; if (th.msec < 1) { return; } #if GLIB_CHECK_VERSION(2, 32, 0) thread= g_thread_new("sleep", sleep_thread, &th); #else thread = g_thread_create(sleep_thread, &th, TRUE, NULL); #endif while (th.sleep) { eventloop(); msleep(1); } g_thread_join(thread); return; } void set_environ(void) { int i, n; char *name, **list, **env; const char *val; MainEnviron = NULL; env = g_listenv(); if (env == NULL) { MainEnviron = NULL; return; } for (n = 0; env[n]; n++) ; list = g_malloc0(sizeof(*list) * (n + 1)); if (list == NULL) { g_strfreev(env); return; } for (i = 0; i < n; i++) { name = env[i]; val = g_getenv(name); list[i] = g_strdup_printf("%s=%s", name, val); if (list[i] == NULL) { g_strfreev(env); g_strfreev(list); return; } } MainEnviron = list; g_strfreev(env); } void set_security(int state) { Security = state; } int get_security(void) { return Security; } static void unlinkfile(char **file) { if (*file!=NULL) { g_unlink(*file); g_free(*file); *file=NULL; } } #if ! WINDOWS int set_signal(int signal_id, int flags, void (*handler)(int), struct sigaction *oldact) { static struct sigaction act; memset(&act, 0, sizeof(act)); act.sa_handler = handler; act.sa_flags = (flags | SA_RESTART); sigemptyset(&act.sa_mask); return sigaction(signal_id, &act, oldact); } static void childhandler(int sig) { pid_t child_pid; do { child_pid = waitpid(-1, NULL, WNOHANG); } while (child_pid > 0); } void set_childhandler(void) { set_signal(SIGCHLD, SA_NOCLDSTOP, childhandler, NULL); } void unset_childhandler(void) { set_signal(SIGCHLD, 0, SIG_DFL, NULL); } #endif /* WINDOWS */ static int EvLoopActive = FALSE; static GThread *EvLoopThread = NULL; static void * shellevloop(void *ptr) { EvLoopActive = TRUE; while (EvLoopActive) { eventloop(); msleep(10); } return NULL; } static void set_shellevloop(int sig) { if (! has_eventloop()) return; if (EvLoopActive) return; #if GLIB_CHECK_VERSION(2, 32, 0) EvLoopThread = g_thread_new("evloop", shellevloop, NULL); #else EvLoopThread = g_thread_create(shellevloop, NULL, TRUE, NULL); #endif if (EvLoopThread == NULL) return; while (! EvLoopActive) { msleep(10); } } static void reset_shellevloop(void) { if (EvLoopActive) { EvLoopActive = FALSE; g_thread_join(EvLoopThread); } } static int shgetstdin(void) { char buf[2]; int byte; if (nisatty(stdinfd())) { set_shellevloop(0); do { byte=read(stdinfd(),buf,1); } while (byte<0); reset_shellevloop(); } else { do { byte=read(stdinfd(),buf,1); if (byte<=0) return EOF; } while (buf[0]=='\r'); } if (byte<=0) return EOF; return buf[0]; } #if HAVE_READLINE_READLINE_H static int ReadlineLock = FALSE; static void * readline_thread(void *prompt) { char *str; str = readline(prompt); ReadlineLock = FALSE; return str; } static char * nreadline(char *prompt) { GThread *thread; if (ReadlineLock) { return NULL; } ReadlineLock = TRUE; #if GLIB_CHECK_VERSION(2, 32, 0) thread= g_thread_new("readline", readline_thread, prompt); #else thread = g_thread_create(readline_thread, prompt, TRUE, NULL); #endif if (thread == NULL) { ReadlineLock = FALSE; return NULL; } while (ReadlineLock) { eventloop(); msleep(10); } return (char *) g_thread_join(thread); } static void remove_duplicate_history(char *str) { HIST_ENTRY *entry; int pos; for(pos = history_length; pos >= 0; pos--) { pos = history_search_pos(str, -1, pos); if(pos >= 0 && strcmp(history_get(pos + history_base)->line, str) == 0) { entry = remove_history(pos); if (entry) { free_history_entry(entry); } break; } } } #endif static int shget(struct nshell *nshell) { char buf[2]; int byte; #ifdef HAVE_READLINE_READLINE_H static char *str_ptr = NULL, *line_str = NULL; #endif if (nisatty(nshell->fd)) { #ifdef HAVE_READLINE_READLINE_H if(str_ptr == NULL){ str_ptr = line_str = nreadline(Prompt); if(str_ptr == NULL){ byte = 0; } else if(strlen(str_ptr) > 0) { if (MultiLine && history_length > 0) { HIST_ENTRY *entry; char *tmp; entry = remove_history(history_length - 1); remove_duplicate_history(str_ptr); if (entry) { tmp = g_strdup_printf("%s\n%s", entry->line, str_ptr); free_history_entry(entry); if (tmp) { remove_duplicate_history(tmp); add_history(tmp); g_free(tmp); } } } else { remove_duplicate_history(str_ptr); add_history(str_ptr); } } } if(str_ptr != NULL){ if(*line_str == '\0'){ free(str_ptr); /* str_ptr is allocated by readline library */ str_ptr = line_str = NULL; buf[0] = '\0'; byte = 1; }else{ buf[0] = *line_str++; byte = 1; } } #else /* HAVE_READLINE_READLINE_H */ set_shellevloop(0); do { byte=read(nshell->fd,buf,1); } while (byte<0); reset_shellevloop(); #endif /* HAVE_READLINE_READLINE_H */ } else { do { byte=read(nshell->fd,buf,1); if (byte<=0) return EOF; } while (buf[0]=='\r'); } if (byte<=0) return EOF; return buf[0]; } static int puts_localized(int fd, const char *str) { int len, r; char *localized; localized = g_locale_from_utf8(str, -1, NULL, NULL, NULL); if (localized == NULL) { return 0; } len = strlen(localized); r = write(fd, localized, len); g_free(localized); return r; } static int shputstdout(const char *s) { int len, r; len = puts_localized(stdoutfd(), s); r = write(stdoutfd(), "\n", 1); if (r >= 0) len += r; return len; } #if WINDOWS static int shputstderr(const char *s) { int len, r; len=strlen(s); r = write(stderrfd(),s,len); if (r < 0){ return r; } r = write(stderrfd(),"\n",1); if (r < 0){ return r; } return len + 1; } #endif /* WINDOWS */ static int shprintfstdout(const char *fmt,...) { int len; char *buf; va_list ap; va_start(ap,fmt); buf = g_strdup_vprintf(fmt, ap); va_end(ap); if (buf == NULL) { return 0; } len = puts_localized(stdoutfd(), buf); g_free(buf); return len; } #ifdef COMPILE_UNUSED_FUNCTIONS static int shprintfstderr(const char *fmt,...) { int len; char buf[1024]; va_list ap; va_start(ap,fmt); len=vsprintf(buf,fmt,ap); va_end(ap); write(stderrfd(),buf,len); return len; } #endif /* COMPILE_UNUSED_FUNCTIONS */ struct cmdtabletype cmdtable[] = { {"cd", cmcd}, {"echo", cmecho}, {"basename", cmbasename}, {"dirname", cmdirname}, {"seq", cmseq}, {"eval", cmeval}, {"exit", cmexit}, {"export", cmexport}, {"pwd", cmpwd}, {"read", cmread}, {"set", cmset}, {"shift", cmshift}, {"type", cmtype}, {"unset", cmunset}, {":", cmtrue}, {"object", cmobject}, {"derive", cmderive}, {"new", cmnew}, {"exist", cmexist}, {"del", cmdel}, {"get", cmget}, {"put", cmput}, {"cpy", cmcpy}, {"dup", cmdup}, {"move", cmmove}, {"movetop", cmmovetop}, {"moveup", cmmovetop}, {"movedown", cmmovetop}, {"movelast", cmmovetop}, {"exch", cmmove}, {"exe", cmexe}, {"dexpr", cmdexpr}, {"iexpr", cmdexpr}, {"true", cmtrue}, {"false", cmfalse}, {"[", cmtest}, {"sleep", cmsleep}, {"test", cmtest}, {"which", cmwhich}, }; int CMDNUM = sizeof(cmdtable) / sizeof(*cmdtable); char *cpcmdtable[] = { ";&|", "if", "then", "else", "elif", "fi", "case", "esac", "for", "while", "until", "do", "done", "{", "}", }; int CPCMDNUM = sizeof(cpcmdtable) / sizeof(*cpcmdtable); enum {CPNULL=1,CPIF,CPTHEN,CPELSE,CPELIF,CPFI,CPCASE,CPESAC, CPFOR,CPWHILE,CPUNTIL,CPDO,CPDONE,CPBI,CPBO, CPPATI,CPPATO,CPFN,CPNO}; enum {PPNULL=0,PPNO,PPSETV,PPSETO,PPSO1,PPSO2,PPSI1,PPSI2,PPPATOR,PPPIPE, PPAND,PPEND}; struct cmdstack { int cmdno; char *val; int ival,iftrue,casetrue; char *pat; struct prmlist *prm; struct cmdlist *cmd; void *next; }; static NHASH CmdTblHash, CpCmdTblHash; int eval_script(const char *script, int security) { struct nshell *nshell; nshell = newshell(); if (nshell == NULL) return 1; set_security(security); ngraphenvironment(nshell); cmdexecute(nshell, script); set_security(FALSE); delshell(nshell); return 0; } int init_cmd_tbl(void) { int i, r; CmdTblHash = nhash_new(); if (CmdTblHash == NULL) return 1; CpCmdTblHash = nhash_new(); if (CpCmdTblHash == NULL) return 1; for (i = 0; i < CMDNUM; i++) { r = nhash_set_ptr(CmdTblHash, cmdtable[i].name, cmdtable[i].proc); if (r) { goto Err; } } for (i = 1; i < CPCMDNUM; i++) { r = nhash_set_int(CpCmdTblHash, cpcmdtable[i], i); if (r) { goto Err; } } return 0; Err: nhash_free(CmdTblHash); nhash_free(CpCmdTblHash); return 1; } shell_proc check_cmd(char *name) { shell_proc proc; int r; r = nhash_get_ptr(CmdTblHash, name, (void **) &proc); if (r) return NULL; return proc; } int check_cpcmd(char *name) { int r, i; r = nhash_get_int(CpCmdTblHash, name, &i); if (r) i = -1; return i; } static void prmfree(struct prmlist *prmroot) { struct prmlist *prmcur,*prmdel; if (prmroot==NULL) return; prmcur=prmroot; while (prmcur!=NULL) { prmdel=prmcur; prmcur=prmcur->next; g_free(prmdel->str); g_free(prmdel); } } static void cmdfree(struct cmdlist *cmdroot) { struct cmdlist *cmdcur,*cmddel; cmdcur=cmdroot; while (cmdcur!=NULL) { prmfree(cmdcur->prm); cmddel=cmdcur; cmdcur=cmdcur->next; g_free(cmddel); } } static void cmdstackfree(struct cmdstack *stroot) { struct cmdstack *stcur,*stdel; stcur=stroot; while (stcur!=NULL) { stdel=stcur; stcur=stcur->next; prmfree(stdel->prm); g_free(stdel->pat); /* hito (mem leak of pat) */ g_free(stdel); } } static void * cmdstackcat(struct cmdstack **stroot,int cmdno) { struct cmdstack *stcur,*stnew; if ((stnew=g_malloc(sizeof(struct cmdstack)))==NULL) return NULL; stcur=*stroot; if (stcur==NULL) *stroot=stnew; else { while (stcur->next!=NULL) stcur=stcur->next; stcur->next=stnew; } stnew->next=NULL; stnew->prm=NULL; stnew->cmd=NULL; stnew->pat=NULL; /* hito (mem leak of pat) */ stnew->cmdno=cmdno; return stnew; } static struct cmdstack * cmdstackgetpo(struct cmdstack **stroot) { struct cmdstack *stcur,*stprev; stcur=*stroot; stprev=NULL; while (stcur!=NULL) { stprev=stcur; stcur=stcur->next; } return stprev; } static int cmdstackgetlast(struct cmdstack **stroot) { struct cmdstack *stcur,*stprev; stcur=*stroot; stprev=NULL; while (stcur!=NULL) { stprev=stcur; stcur=stcur->next; } if (stprev==NULL) return 0; else return stprev->cmdno; } static void cmdstackrmlast(struct cmdstack **stroot) { struct cmdstack *stcur,*stprev; stcur=*stroot; stprev=NULL; if (stcur==NULL) return; while (stcur->next!=NULL) { stprev=stcur; stcur=stcur->next; } if (stprev==NULL) *stroot=NULL; else stprev->next=NULL; prmfree(stcur->prm); g_free(stcur->pat); /* hito (mem leak of pat) */ g_free(stcur); } static struct vallist * create_vallist(char *name, char *val) { struct vallist *valnew; valnew = g_malloc(sizeof(* valnew)); if (valnew == NULL) return NULL; valnew->name = g_strdup(name); if (valnew->name == NULL) { g_free(valnew); return NULL; } if (val) { valnew->val = g_strdup(val); if (valnew->val == NULL) { g_free(valnew->name); g_free(valnew); return NULL; } } else { valnew->val = NULL; } return valnew; } static void free_vallist(struct vallist *val) { if (val == NULL) return; g_free(val->name); if (val->func) cmdfree(val->val); else g_free(val->val); g_free(val); } char * addval(struct nshell *nshell,char *name,char *val) /* addval() returns NULL on error */ { #if USE_HASH struct vallist *valnew, *valcur; int hkey; valnew = create_vallist(name, val); if (valnew == NULL) return NULL; valnew->func = FALSE; valnew->arg = FALSE; hkey = nhash_hkey(name); nhash_get_ptr_with_hkey(nshell->valroot, name, hkey, (void **) &valcur); if (valcur) { free_vallist(valcur); } nhash_set_ptr_with_hkey(nshell->valroot, valnew->name, hkey, valnew); return valnew->name; #else struct vallist *valcur,*valprev,*valnew; if ((valnew=g_malloc(sizeof(struct vallist)))==NULL) return NULL; if ((valnew->name=g_malloc(strlen(name)+1))==NULL) { g_free(valnew); return NULL; } if ((valnew->val=g_malloc(strlen(val)+1))==NULL) { g_free(valnew->name); g_free(valnew); return NULL; } valnew->func=FALSE; valnew->arg=FALSE; strcpy(valnew->name,name); strcpy(valnew->val,val); valcur=nshell->valroot; valprev=NULL; while (valcur!=NULL) { if (strcmp2(name,valcur->name)<=0) break; valprev=valcur; valcur=valcur->next; } if (valprev==NULL) nshell->valroot=valnew; else valprev->next=valnew; if (valcur==NULL) { valnew->next=NULL; } else if (strcmp0(name,valcur->name)==0) { valnew->next=valcur->next; g_free(valcur->name); if (valcur->func) cmdfree(valcur->val); else g_free(valcur->val); g_free(valcur); } else { valnew->next=valcur; } return valnew->name; #endif } static char * saveval(struct nshell *nshell,char *name,char *val, struct vallist **newvalroot) /* saveval() returns NULL on error */ { #if USE_HASH struct vallist *valnew, *valcur; int hkey; valnew = create_vallist(name, val); if (valnew == NULL) return NULL; valnew->func = FALSE; valnew->arg = TRUE; hkey = nhash_hkey(name); nhash_get_ptr_with_hkey(nshell->valroot, name, hkey, (void **) &valcur); if (valcur) { valcur->next = NULL; if (*newvalroot == NULL) { *newvalroot = valcur; } else { (*newvalroot)->next=valcur; } } nhash_set_ptr_with_hkey(nshell->valroot, name, hkey, valnew); return valnew->name; #else struct vallist *valcur,*valprev,*valnew; if ((valnew=g_malloc(sizeof(struct vallist)))==NULL) return NULL; if ((valnew->name=g_malloc(strlen(name)+1))==NULL) { g_free(valnew); return NULL; } if ((valnew->val=g_malloc(strlen(val)+1))==NULL) { g_free(valnew->name); g_free(valnew); return NULL; } valnew->func=FALSE; valnew->arg=TRUE; strcpy(valnew->name,name); strcpy(valnew->val,val); valcur=nshell->valroot; valprev=NULL; while (valcur!=NULL) { if (strcmp2(name,valcur->name)<=0) break; valprev=valcur; valcur=valcur->next; } if (valprev==NULL) nshell->valroot=valnew; else valprev->next=valnew; if (valcur==NULL) { valnew->next=NULL; } else if (strcmp0(name,valcur->name)==0) { valnew->next=valcur->next; // valcur->next = *newvalroot; /* this code may be wrong. */ valcur->next=NULL; if (*newvalroot==NULL) *newvalroot=valcur; else (*newvalroot)->next=valcur; } else { valnew->next=valcur; } return valnew->name; #endif } static int delete_save_val(struct nhash *hash, void *data) { struct vallist *val; struct nshell *nshell; val = (struct vallist *) hash->val.p; nshell = (struct nshell *) data; if (val->arg) { nhash_del(nshell->valroot, val->name); free_vallist(val); } return 0; } static void restoreval(struct nshell *nshell,struct vallist *newvalroot) /* restoreval() returns NULL on error */ { #if USE_HASH struct vallist *valcur,*valnext, *valcur2; int hk; nhash_each(nshell->valroot, delete_save_val, nshell); valcur = newvalroot; while (valcur) { valnext = valcur->next; hk = nhash_hkey(valcur->name); nhash_get_ptr_with_hkey(nshell->valroot, valcur->name, hk, (void **) &valcur2); if (valcur2) { free_vallist(valcur); } else { nhash_set_ptr_with_hkey(nshell->valroot, valcur->name, hk, (void *) valcur); } valcur = valnext; } #else struct vallist *valcur,*valprev,*valnext; struct vallist *valcur2,*valprev2; valcur=nshell->valroot; valprev=NULL; while (valcur!=NULL) { valnext=valcur->next; if (valcur->arg==1) { if (valprev==NULL) nshell->valroot=valcur->next; else valprev->next=valcur->next; g_free(valcur->name); g_free(valcur->val); g_free(valcur); } else valprev=valcur; valcur=valnext; } valcur=newvalroot; while (valcur!=NULL) { valnext=valcur->next; valcur2=nshell->valroot; valprev2=NULL; while (valcur2!=NULL) { if (strcmp2(valcur->name,valcur2->name)<=0) break; valprev2=valcur2; valcur2=valcur2->next; } if (valcur2==NULL) { if (valprev2==NULL) nshell->valroot=valcur; else valprev2->next=valcur; valcur->next=NULL; } else if (strcmp0(valcur->name,valcur2->name)==0) { g_free(valcur->name); if (valcur->func) cmdfree(valcur->val); else g_free(valcur->val); g_free(valcur); } else { if (valprev2==NULL) nshell->valroot=valcur; else valprev2->next=valcur; valcur->next=valcur2; } valcur=valnext; } #endif } char * addexp(struct nshell *nshell,char *name) /* addexp() returns NULL on error */ { #if USE_HASH if (nhash_set_int(nshell->exproot, name, TRUE)) return NULL; return name; #else struct explist *valcur,*valprev,*valnew; int cmp; valcur=nshell->exproot; valprev=NULL; while (valcur!=NULL) { cmp=strcmp2(name,valcur->val); if (cmp==0) return valcur->val; else if (cmp<0) break; valprev=valcur; valcur=valcur->next; } if ((valnew=g_malloc(sizeof(struct vallist)))==NULL) return NULL; if ((valnew->val=g_malloc(strlen(name)+1))==NULL) { g_free(valnew); return NULL; } if (valprev==NULL) nshell->exproot=valnew; else valprev->next=valnew; strcpy(valnew->val,name); valnew->next=valcur; return valnew->val; #endif } int delval(struct nshell *nshell,char *name) { #if USE_HASH struct vallist *val; int r, hkey; hkey = nhash_hkey(name); r = nhash_get_ptr_with_hkey(nshell->valroot, name, hkey, (void **) &val); if (r == 0) { free_vallist(val); nhash_del_with_hkey(nshell->valroot, name, hkey); return TRUE; } return FALSE; #else struct vallist *valcur,*valprev; valcur=nshell->valroot; valprev=NULL; while (valcur!=NULL) { if (strcmp0(valcur->name,name)==0) { if (valprev==NULL) nshell->valroot=valcur->next; else valprev->next=valcur->next; g_free(valcur->name); if (valcur->func) cmdfree(valcur->val); else g_free(valcur->val); g_free(valcur); return TRUE; } valprev=valcur; valcur=valcur->next; } return FALSE; #endif } char * getval(struct nshell *nshell,char *name) { #if USE_HASH struct vallist *val; nhash_get_ptr(nshell->valroot, name, (void **) &val); if (val && ! val->func) { return val->val; } return FALSE; #else struct vallist *valcur; valcur=nshell->valroot; while (valcur!=NULL) { if ((strcmp0(valcur->name,name)==0) && (!valcur->func)) return valcur->val; valcur=valcur->next; } return NULL; #endif } static int getexp(struct nshell *nshell,char *name) { #if USE_HASH int i, r; r = nhash_get_int(nshell->exproot, name, &i); return ! r; #else struct explist *valcur; valcur=nshell->exproot; while (valcur!=NULL) { if (strcmp0(valcur->val,name)==0) return TRUE; valcur=valcur->next; } return FALSE; #endif } static char * newfunc(struct nshell *nshell,char *name) /* newfunc() returns NULL on error */ { #if USE_HASH struct vallist *valnew, *valcur; int hkey; valnew = create_vallist(name, NULL); if (valnew == NULL) return NULL; valnew->func = TRUE; valnew->arg = FALSE; hkey = nhash_hkey(name); nhash_get_ptr_with_hkey(nshell->valroot, name, hkey, (void **) &valcur); if (valcur) { free_vallist(valcur); } nhash_set_ptr_with_hkey(nshell->valroot, valnew->name, hkey, valnew); return valnew->name; #else struct vallist *valcur,*valprev,*valnew; if ((valnew=g_malloc(sizeof(struct vallist)))==NULL) return NULL; if ((valnew->name=g_malloc(strlen(name)+1))==NULL) { g_free(valnew); return NULL; } valnew->func=TRUE; valnew->arg=FALSE; strcpy(valnew->name,name); valnew->val=NULL; valcur=nshell->valroot; valprev=NULL; while (valcur!=NULL) { if (strcmp2(name,valcur->name)<=0) break; valprev=valcur; valcur=valcur->next; } if (valprev==NULL) nshell->valroot=valnew; else valprev->next=valnew; if (valcur==NULL) { valnew->next=NULL; } else if (strcmp0(name,valcur->name)==0) { valnew->next=valcur->next; g_free(valcur->name); if (valcur->func) cmdfree(valcur->val); else g_free(valcur->val); g_free(valcur); } else { valnew->next=valcur; } return valnew->name; #endif } static char * addfunc(struct nshell *nshell,char *name,struct cmdlist *val) /* addfunc() returns NULL on error */ { #if USE_HASH struct vallist *valcur; struct cmdlist *cmdcur,*cmdprev,*cmdnew; struct prmlist *prmcur,*prmprev,*prmnew; char *snew; nhash_get_ptr(nshell->valroot, name, (void **) &valcur); if (valcur == NULL) { return NULL; } if (! valcur->func) { return NULL; } cmdcur = valcur->val; cmdprev = NULL; while (cmdcur) { cmdprev = cmdcur; cmdcur = cmdcur->next; } cmdnew = g_malloc(sizeof(* cmdnew)); if (cmdnew == NULL) { delval(nshell, name); return NULL; } if (cmdprev == NULL) { valcur->val = cmdnew; } else { cmdprev->next = cmdnew; } *cmdnew = *val; cmdnew->prm = NULL; cmdnew->next = NULL; prmcur = val->prm; prmprev = NULL; while (prmcur) { prmnew = g_malloc(sizeof(* prmnew)); if (prmnew == NULL) { delval(nshell, name); return NULL; } if (prmprev == NULL) { cmdnew->prm=prmnew; } else { prmprev->next=prmnew; } *prmnew = *prmcur; prmnew->next = NULL; if (prmcur->str) { snew = g_strdup(prmcur->str); if (snew == NULL) { delval(nshell, name); return NULL; } prmnew->str = snew; } prmprev = prmnew; prmcur = prmcur->next; } return valcur->name; #else struct vallist *valcur; struct cmdlist *cmdcur,*cmdprev,*cmdnew; struct prmlist *prmcur,*prmprev,*prmnew; char *snew; valcur=nshell->valroot; while (valcur!=NULL) { if ((strcmp0(valcur->name,name)==0) && (valcur->func)) { cmdcur=valcur->val; cmdprev=NULL; while (cmdcur!=NULL) { cmdprev=cmdcur; cmdcur=cmdcur->next; } if ((cmdnew=g_malloc(sizeof(struct cmdlist)))==NULL) { delval(nshell,name); return NULL; } if (cmdprev==NULL) valcur->val=cmdnew; else cmdprev->next=cmdnew; *cmdnew=*val; cmdnew->prm=NULL; cmdnew->next=NULL; prmcur=val->prm; prmprev=NULL; while (prmcur!=NULL) { if ((prmnew=g_malloc(sizeof(struct prmlist)))==NULL) { delval(nshell,name); return NULL; } if (prmprev==NULL) cmdnew->prm=prmnew; else prmprev->next=prmnew; *prmnew=*prmcur; prmnew->next=NULL; if (prmcur->str!=NULL) { if ((snew=g_malloc(strlen(prmcur->str)+1))==NULL) { delval(nshell,name); return NULL; } strcpy(snew,prmcur->str); prmnew->str=snew; } prmprev=prmnew; prmcur=prmcur->next; } break; } valcur=valcur->next; } return valcur->name; #endif } struct cmdlist * getfunc(struct nshell *nshell,char *name) { #if USE_HASH struct vallist *val; nhash_get_ptr(nshell->valroot, name, (void **) &val); if (val && val->func) { return val->val; } return FALSE; #else struct vallist *valcur; valcur=nshell->valroot; while (valcur!=NULL) { if ((strcmp0(valcur->name,name)==0) && (valcur->func)) return valcur->val; valcur=valcur->next; } return NULL; #endif } static char * gettok(char **s,int *len,int *quote,int *bquote,int *cend,int *escape) { int i; char *po,*spo; *len = 0; if (*s==NULL) return NULL; *cend='\0'; *escape=FALSE; po=*s; /* remove branck */ for (i=0;(po[i]!='\0') && !*quote && (strchr(" \t",po[i])!=NULL);i++); /* token ends */ if ((po[i]=='\0') || (!*quote && (po[i]=='#'))) { *len=0; return NULL; } spo=po+i; if (!*quote && !*bquote) { /* check speecial character */ if (strchr(";&|^<>()",po[i])!=NULL) { if (strchr(";&)",po[i])!=NULL) *cend=po[i]; if ((strchr("<>",po[i])!=NULL) && (po[i]==po[i+1])) { i++; if (po[i] == '<' && po[i + 1] == '-') { i++; } } if ((po[i]==';') && (po[i]==po[i+1])) i++; *s+=(i+1); *len=*s-spo; return spo; } } for (;(po[i]!='\0') && (*quote || *bquote || *escape || (strchr(";&|^<> \t()",po[i])==NULL)); i++) { /* check escapse */ if (*escape) *escape=FALSE; else if (po[i]=='\\') { if (!*quote || ((*quote=='"') && (strchr("\"\\'$",po[i+1])!=NULL)) || *bquote ) *escape=TRUE; /* check back quote */ } else if (*bquote) { if (po[i]=='`') *bquote='\0'; } else if ((po[i]=='`') && (*quote!='\'')) *bquote='`'; /* check quotation */ else if ((*quote=='"') || (*quote=='\'')) { if (po[i]==*quote) *quote='\0'; } else if (po[i]=='\'' || po[i]=='"') *quote=po[i]; } if (*escape) i--; *s+=i; *len=*s-spo; return spo; } static int getcmdline(struct nshell *nshell, struct cmdlist **rcmdroot,struct cmdlist *cmd, const char *str,int *istr) /* getcmdline() returns -2: unexpected eof detected -1: fatal error 0: noerror 1: eof detected */ { struct cmdlist *cmdroot,*cmdcur; struct prmlist *prmcur,*prmnew; int quote,quote2,bquote,bquote2,escape,escape2; int cend,l; char *spo,*po,*prompt,*tok,*tok2; char *ignoreeof,*endptr; int ch; int i,eofnum; int err,eofcount; err=-1; escape=escape2=FALSE; quote=quote2=bquote=bquote2='\0'; cend='\0'; cmdroot=NULL; cmdcur=NULL; prmcur=NULL; tok=NULL; eofcount=0; do { g_free(tok); tok=NULL; if (str==NULL) { if ((tok=nstrnew())==NULL) goto errexit; if (nisatty(nshell->fd)) { if (cmd == NULL && cmdroot == NULL) { prompt = getval(nshell, "PS1"); #ifdef HAVE_READLINE_READLINE_H MultiLine = FALSE; #endif } else { prompt = getval(nshell, "PS2"); #ifdef HAVE_READLINE_READLINE_H MultiLine = TRUE; #endif } #ifdef HAVE_READLINE_READLINE_H Prompt = prompt; #else if (prompt!=NULL) printfconsole("%.256s",prompt); #endif } do { ch=shget(nshell); if (ch==EOF) { if (strlen(tok)!=0) { if (!nisatty(nshell->fd)) break; else printfconsole("%c",(char )0x07); } else { if (!nisatty(nshell->fd)) { if ((cmd!=NULL) || (cmdroot!=NULL)) { sherror(ERRUEXPEOF); err=-2; } else err=1; goto errexit; } else { if ((cmd!=NULL) || (cmdroot!=NULL)) { sherror(ERRUEXPEOF); err=-2; goto errexit; } eofcount++; ignoreeof = getval(nshell,"IGNOREEOF"); if (ignoreeof == NULL) { eofnum=0; } else { if (ignoreeof[0] == '\0') { eofnum = 10; } else { eofnum = strtol(ignoreeof,&endptr,10); if (endptr[0] != '\0') eofnum = 10; } } if (eofcount > eofnum) { err=1; putconsole("exit"); nshell->quit=TRUE; goto errexit; } else { sherror(ERREOF); ch='\0'; } } } } else { eofcount=0; if (ch=='\n') ch='\0'; if ((tok=nstrccat(tok,ch))==NULL) goto errexit; } } while (ch!='\0'); } else { if (str[*istr]=='\0') { if ((cmd!=NULL) || (cmdroot!=NULL)) { sherror(ERRUEXPEOF); err=-2; } else { err=1; } goto errexit; } for (i=*istr;(str[i]!='\0') && (str[i]!='\n');i++); if ((tok=g_malloc(i-*istr+1))==NULL) { goto errexit; } strncpy(tok,str+*istr,i-*istr); tok[i-*istr]='\0'; if (str[i]=='\n') { *istr=i+1; } else { *istr=i; } } if (! g_utf8_validate(tok, -1, NULL)) { char *tmp; tmp = g_locale_to_utf8(tok, -1, NULL, NULL, NULL); if (tmp) { g_free(tok); tok = tmp; } } tok2=tok; do { int len; spo=gettok(&tok2,&len,"e,&bquote,&cend,&escape); if (quote2 || bquote2 || escape2) { l=strlen(prmcur->str); if (quote2 || bquote2) l++; if ((po=g_malloc(len+l+1))==NULL) goto errexit; strcpy(po,prmcur->str); if (quote2 || bquote2) *(po+l-1)='\n'; if (spo!=NULL) strncpy(po+l,spo,len); *(po+len+l)='\0'; g_free(prmcur->str); prmcur->str=po; } else if (spo!=NULL) { if (cmdroot==NULL) { if ((cmdcur=g_malloc(sizeof(struct cmdlist)))==NULL) goto errexit; cmdroot=cmdcur; cmdcur->next=NULL; cmdcur->prm=NULL; } if ((prmnew=g_malloc(sizeof(struct prmlist)))==NULL) goto errexit; if (cmdcur->prm==NULL) cmdcur->prm=prmnew; else prmcur->next=prmnew; prmcur=prmnew; prmcur->next=NULL; if ((prmcur->str=g_malloc(len+1))==NULL) goto errexit; strncpy(prmcur->str,spo,len); prmcur->str[len]='\0'; } if (cend) { if ((cmdcur->next=g_malloc(sizeof(struct cmdlist)))==NULL) goto errexit; cmdcur=cmdcur->next; cmdcur->next=NULL; cmdcur->prm=NULL; } quote2=quote; bquote2=bquote; escape2=escape; } while ((spo!=NULL) && (!escape) && (!quote) && (!bquote)); } while (quote || bquote || escape || (cmdroot==NULL)); *rcmdroot=cmdroot; g_free(tok); return 0; errexit: cmdfree(cmdroot); g_free(tok); *rcmdroot=NULL; return err; } static char * quotation(struct nshell *nshell,char *s,int quote) { int i,j,num; char *snew,*ifs; ifs=getval(nshell,"IFS"); num=0; for (i=0;s[i]!='\0';i++) if (strchr("\"\\'$",s[i])!=NULL) num++; if ((snew=g_malloc(strlen(s)+num+1))==NULL) return NULL; j=0; for (i=0;s[i]!='\0';i++) { if ((quote!='"') && (ifs!=NULL) && (ifs[0]!='\0') && (strchr(ifs,s[i])!=NULL)) snew[j++]=(char )0x01; else { if (strchr("\"\\'$",s[i])!=NULL) snew[j++]=(char )0x02; snew[j++]=s[i]; } } snew[j]='\0'; return snew; } static char * unquotation(char *s,int *quoted) { int escape,quote,i,j; char *snew,*po; if ((snew=g_malloc(strlen(s)+1))==NULL) return NULL; *quoted=FALSE; po=s; escape=FALSE; quote='\0'; j=0; for (i=0;po[i]!='\0';i++) { if (escape) { escape=FALSE; snew[j++]=po[i]; } else if (po[i]=='\\') { if (!quote || ((quote=='"') && (strchr("\"\\'$",po[i+1])!=NULL))) escape=TRUE; else snew[j++]=po[i]; } else if (po[i]==(char )0x02) escape=TRUE; else if (po[i]==(char )0x01) snew[j++]=' '; else if ((quote=='"') || (quote=='\'')) { if (po[i]==quote) quote='\0'; else snew[j++]=po[i]; } else if (po[i]=='\'' || po[i]=='"') { quote=po[i]; *quoted=TRUE; } else snew[j++]=po[i]; } snew[j]='\0'; return snew; } static char * fnexpand(struct nshell *nshell,char *str) { int escape,expand,noexpand,quote,i,j,len,num; char *po; char *s,*s2; char **namelist; po=str; escape=expand=noexpand=FALSE; quote='\0'; if ((s=nstrnew())==NULL) return NULL; if ((s2=nstrnew())==NULL) return NULL; len=strlen(po); for (i=0;i<=len;i++) { if (escape && (po[i]!='\0')) { escape=FALSE; if ((s=nstrccat(s,po[i]))==NULL) goto errexit; if (strchr("*?[",po[i])!=NULL) noexpand=TRUE; } else if (po[i]=='\\') { if (!quote || ((quote=='"') && (strchr("\"\\'$",po[i+1])!=NULL))) escape=TRUE; else if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } else if (po[i]==(char )0x02) escape=TRUE; else if ((po[i]==(char )0x01) || (po[i]=='\0')) { if (strlen(s)!=0) { if (!nshell->optionf && expand && !noexpand) { if ((num=nglob(s,&namelist))==-1) goto errexit; for (j=0;jstr; if (po==NULL) return 1; if ((s=nstrnew())==NULL) return -1; for (i=0;po[i]!='\0';i++) { if (po[i]==(char )0x02) { i++; if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } else if (po[i]==(char )0x01) { prmcur->str=s; if ((s=nstrnew())==NULL) goto errexit; if ((prmnew=g_malloc(sizeof(struct prmlist)))==NULL) goto errexit; prmnew->str=NULL; prmnew->next=prmcur->next; prmnew->prmno=prmcur->prmno; prmcur->next=prmnew; prmcur=prmnew; num++; } else if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } prmcur->str=s; num++; g_free(po); return num; errexit: g_free(s); g_free(po); return -1; } static char * wordunsplit(char *str) { int i,j; char *po; po=str; j=0; for (i=0;po[i]!='\0';i++) if (po[i]==(char )0x01) po[j++]=' '; else if (po[i]!=(char )0x02) po[j++]=po[i]; po[j]='\0'; return po; } static char * expand(struct nshell *nshell,char *str,int *quote,int *bquote, int ifsexp) { char *po; int quote2,bquote2,escape; int i,j,k,num; unsigned int u, n; char *c1,*c2,*name,*val,ch,valf,valf2,*ifs; char *s,*sb,*se; int sout,sout2; int rcode,dummy; int byte; char *tmpfil; struct objlist *sys; struct narray *sarray; char **sdata; int snum; char *tmp; if ((po=str)==NULL) return NULL; if ((s=nstrnew())==NULL) return NULL; name=NULL; sb=se=NULL; escape=FALSE; ifs=getval(nshell,"IFS"); for (i=0;po[i]!='\0';i++) { /* check escapse */ if (escape) { if (se==NULL) { if (sb!=NULL) { if ((sb=nstrccat(sb,po[i]))==NULL) goto errexit; } else { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } escape=FALSE; } else if (po[i]=='\\') { if (!*quote || ((*quote=='"') && (strchr("\"\\'$",po[i+1])!=NULL)) || *bquote ) { escape=TRUE; if ((se==NULL) && (sb==NULL)) { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } else if (se==NULL) { if (sb!=NULL) { if ((sb=nstrccat(sb,po[i]))==NULL) goto errexit; } else { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } } else if (po[i]==(char )0x02) { escape=TRUE; if ((se==NULL) && (sb==NULL)) { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } /* check back quote */ } else if (*bquote) { if (po[i]=='`') { *bquote='\0'; if (se==NULL) { /* command substitution */ if ((sys=getobject("system"))==NULL) goto errexit; sout = n_mkstemp(getval(nshell,"TMPDIR"), TEMPPFX, &tmpfil); if (sout < 0) goto errexit; sout2=nredirect(1,sout); rcode=cmdexecute(nshell,sb); if ((rcode!=0) && (rcode!=1)) { nredirect2(1,sout2); g_unlink(tmpfil); g_free(tmpfil); goto errexit; } g_free(sb); if ((sb=nstrnew())==NULL) { nredirect2(1,sout2); g_unlink(tmpfil); g_free(tmpfil); goto errexit; } nlseek(stdoutfd(),0L,SEEK_SET); while ((byte=nread(stdoutfd(),writebuf,WRITEBUFSIZE-1))>0) { writebuf[byte]='\0'; if ((sb=nstrcat(sb,writebuf))==NULL) { nredirect2(1,sout2); g_unlink(tmpfil); g_free(tmpfil); goto errexit; } } nredirect2(1,sout2); g_unlink(tmpfil); if (byte==-1) { sherror2(ERRREAD,tmpfil); g_free(tmpfil); goto errexit; } g_free(tmpfil); n = strlen(sb); for (u = 0; u < n; u++) { if (sb[u] == '\n') { sb[u] = ' '; } } for (j=strlen(sb)-1;(j>=0) && (sb[j]==' ');j--); sb[j+1]='\0'; if ((c1=quotation(nshell,sb,*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; g_free(sb); sb=NULL; } } else if (se==NULL) { if (sb!=NULL) { if ((sb=nstrccat(sb,po[i]))==NULL) goto errexit; } else { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } } else if ((po[i]=='`') && (*quote!='\'')) { *bquote='`'; if (se==NULL) { if ((sb=nstrnew())==NULL) goto errexit; } /* check constant variable */ } else if ((po[i]=='$') && (po[i+1]!='\0') && (*quote!='\'') && (se==NULL)) { if (isdigit(po[i+1])) { for (j=i+1;(po[j]!='\0') && isdigit(po[j]);j++); g_free(name); if ((name=g_malloc(j-i))==NULL) goto errexit; strncpy(name,po+i+1,j-i-1); name[j-i-1]='\0'; num=atoi(name); if (numargc) { if ((c1=quotation(nshell,(nshell->argv)[num],*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; } i=j-1; } else if (strchr("#?",po[i+1])!=NULL) { switch (po[i+1]) { case '#': g_free(name); if ((name=g_malloc(12))==NULL) goto errexit; sprintf(name,"%d",nshell->argc-1); break; case '?': g_free(name); if ((name=g_malloc(12))==NULL) goto errexit; sprintf(name,"%d",nshell->status); break; } if ((c1=quotation(nshell,name,*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; i++; } else if (strchr("*@",po[i+1])!=NULL) { val=getval(nshell,"IFS"); if (val==NULL) ch='\0'; else ch=val[0]; for (j=1;jargc;j++) { if ((c1=quotation(nshell,(nshell->argv)[j],*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; if (j!=(nshell->argc-1)) { if ((*quote=='"') && (po[i+1]=='*')) { if (ch!='\0') { if (strchr("\"\\'$",ch)!=NULL) { if ((s=nstrccat(s,'\\'))==NULL) goto errexit; } if ((s=nstrccat(s,ch))==NULL) goto errexit; } } else { if ((s=nstrccat(s,(char )0x01))==NULL) goto errexit; } } } i++; /* check variable */ } else if (po[i+1]=='{') { for (j=i+2;(po[j]!='\0') && (isalnum(po[j]) || (po[j]=='_'));j++); if ((po[j]=='\0') || (strchr(":-=?+#%}",po[j])==NULL) || (po[j-1]=='{')) { sherror(ERRBADSUB); goto errexit; } if (po[j]=='}') { g_free(name); if ((name=g_malloc(j-i-1))==NULL) goto errexit; strncpy(name,po+i+2,j-i-2); name[j-i-2]='\0'; val=getval(nshell,name); if (val!=NULL) { if ((c1=quotation(nshell,val,*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; } i=j; } else { if ((po[j]==':') && (po[j+1]!='\0') && (strchr("-=?+",po[j+1])==NULL)) { valf='o'; if ((se=nstrnew())==NULL) goto errexit; i+=2; } else { g_free(name); if ((name=g_malloc(j-i-1))==NULL) goto errexit; strncpy(name,po+i+2,j-i-2); name[j-i-2]='\0'; val=getval(nshell,name); quote2=*quote; bquote2=*bquote; valf2=' '; if (po[j]==':') { valf2=':'; j++; } if (strchr("-=?+",po[j])!=NULL) { valf=po[j]; j++; } else if (strchr("#%",po[j])!=NULL) { if (po[j]==po[j+1]) { valf2=po[j]; j++; } valf=po[j]; j++; } else { sherror(ERRBADSUB); goto errexit; } if ((se=nstrnew())==NULL) goto errexit; i=j; } } } else { /* simple variable substitution */ for (j=i+1;(po[j]!='\0') && (isalnum(po[j]) || (po[j]=='_'));j++); g_free(name); if ((name=g_malloc(j-i))==NULL) goto errexit; strncpy(name,po+i+1,j-i-1); name[j-i-1]='\0'; if (name[0]=='\0') val="$"; else val=getval(nshell,name); if (val!=NULL) { if ((c1=quotation(nshell,val,*quote))==NULL) goto errexit; s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; } i=j-1; } /* check variable end */ } else if ((po[i]=='}') && (*quote!='\'') && (se!=NULL)) { if (valf=='o') { /* object replacement */ if ((tmp=unquotation(se,&dummy))==NULL) goto errexit; g_free(se); se=NULL; sarray=sgetobj(tmp,FALSE,FALSE,FALSE); g_free(tmp); sdata=arraydata(sarray); snum=arraynum(sarray); for (j=0;j=0;k--) { ch=c2[k]; c2[k]='\0'; if (wildmatch(c1,c2,WILD_PATHNAME)) { c2[k]=ch; break; } c2[k]=ch; } } else { for (k = 0; k <= (int) strlen(c2); k++) { ch=c2[k]; c2[k]='\0'; if (wildmatch(c1,c2,WILD_PATHNAME)) { c2[k]=ch; break; } c2[k]=ch; } } if (k > (int) strlen(c2)) { k=0; } g_free(c1); c1=quotation(nshell,c2+k,quote2); g_free(c2); if (c1==NULL) goto errexit; } break; case '%': if ((val!=NULL) && (val[0]!='\0')) { if ((c2=nstrnew())==NULL) goto errexit; if ((c2=nstrcat(c2,val))==NULL) goto errexit; if ((c1=expand(nshell,se,"e2,&bquote2,TRUE))==NULL) { g_free(c2); goto errexit; } if (valf2=='%') { int len; len = strlen(c2) - 1; for (k = 0; k <= len; k++) { if (wildmatch(c1,c2+k,WILD_PATHNAME)) break; } } else { for (k=strlen(c2);k>=0;k--) { if (wildmatch(c1,c2+k,WILD_PATHNAME)) break; } } if (k<0) k=strlen(c2); c2[k]='\0'; g_free(c1); c1=quotation(nshell,c2,quote2); g_free(c2); if (c1==NULL) goto errexit; } break; } if (c1!=NULL) { s=nstrcat(s,c1); g_free(c1); if (s==NULL) goto errexit; } *quote=quote2; *bquote=bquote2; g_free(se); se=NULL; } /* check quotation */ } else if ((*quote=='"') || (*quote=='\'')) { if (po[i]==*quote) *quote='\0'; if (se==NULL) { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } else if (po[i]=='\'' || po[i]=='"') { *quote=po[i]; if (se==NULL) { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } else { if (se==NULL) { if (ifsexp && (ifs!=NULL) && (ifs[0]!='\0') && (strchr(ifs,po[i])!=NULL)) { if ((s=nstrccat(s,(char )0x01))==NULL) goto errexit; } else { if ((s=nstrccat(s,po[i]))==NULL) goto errexit; } } } if (se!=NULL) { if ((se=nstrccat(se,po[i]))==NULL) goto errexit; } } if ((se!=NULL) || (sb!=NULL)) { sherror(ERRBADSUB); goto errexit; } g_free(name); g_free(sb); g_free(se); return s; errexit: g_free(name); g_free(sb); g_free(se); g_free(s); return NULL; } static int checkcmd(struct nshell *nshell,struct cmdlist **cmdroot) /* checkcmd() returns -1: fatal error 0: noerror 2: error */ { struct cmdlist *cmdcur,*cmdprev,*cmddel,*cmdnew; struct prmlist *prmcur,*prmprev; int cmd,i; char *po; char *s,*eof, *prompt; int quoted,ch; int eoflen,match,len; struct objlist *sys; char *tmpfil; int sout; int ignore_indent, remove_tab; cmdcur=*cmdroot; cmdprev=NULL; while (cmdcur!=NULL) { if (cmdcur->prm==NULL) { if (cmdprev==NULL) *cmdroot=cmdcur->next; else cmdprev->next=cmdcur->next; cmddel=cmdcur; cmdcur=cmdcur->next; g_free(cmddel); } else { /* remove zero length parameter */ prmcur=cmdcur->prm; cmd=CPNO; while (prmcur->next!=NULL) prmcur=prmcur->next; if (prmcur->str[0]==')') cmd=CPPATI; prmcur=cmdcur->prm; if ((prmcur->str[0]!='\0') && (strchr(cpcmdtable[0],prmcur->str[0])!=NULL)) cmd=CPNULL; i = check_cpcmd(prmcur->str); if (i >= 0) { cmd = i + 1; } else { prmcur=prmcur->next; if ((prmcur!=NULL) && (prmcur->str[0]=='(')) { prmcur=prmcur->next; if ((prmcur!=NULL) && (prmcur->str[0]==')')) cmd=CPFN; } } cmdcur->cmdno=cmd; if ((cmd!=CPNO) && (cmd!=CPCASE) && (cmd!=CPPATI) && (cmd!=CPPATO) && (cmd!=CPFOR) && (cmd!=CPFN) && ((cmdcur->prm)->next!=NULL)) { if ((cmdnew=g_malloc(sizeof(struct cmdlist)))==NULL) return -1; cmdnew->next=cmdcur->next; cmdcur->next=cmdnew; cmdnew->prm=(cmdcur->prm)->next; (cmdcur->prm)->next=NULL; cmdnew->cmdno=CPNO; } /* check pattern */ if (cmdcur->cmdno==CPCASE) { prmcur=cmdcur->prm; /* case */ if (prmcur->next!=NULL) { prmcur=prmcur->next; /* word */ if (prmcur->next!=NULL) { prmprev=prmcur->next; /* in */ if (prmprev->next!=NULL) { prmcur=prmprev->next; prmprev->next=NULL; if ((cmdnew=g_malloc(sizeof(struct cmdlist)))==NULL) return -1; cmdnew->next=cmdcur->next; cmdcur->next=cmdnew; cmdnew->prm=prmcur; } } } } /* check redirect and pipe */ cmdcur->cmdend=PPEND; cmdcur->pipefile=NULL; prmcur=cmdcur->prm; prmprev=NULL; while (prmcur!=NULL) { if (prmcur->str!=NULL) { if ((prmcur->str[0]=='>') || (prmcur->str[0]=='<')) { if ((prmcur->next==NULL) || ((prmcur->next)->str==NULL) || (strchr(";&|",(prmcur->next)->str[0])!=NULL)) { sherror2(ERRUEXPTOK,prmprev->str); return 2; } if (prmcur->str[0]==prmcur->str[1]) { if (prmcur->str[0]=='>') prmcur->prmno=PPSO2; else { prmcur->prmno=PPSI2; if ((eof=unquotation((prmcur->next)->str,"ed))==NULL) return -1; g_free((prmcur->next)->str); (prmcur->next)->str=eof; (prmcur->next)->quoted=quoted; if (prmcur->str[2] == '-') { ignore_indent = TRUE; remove_tab = TRUE; } else { ignore_indent = FALSE; remove_tab = FALSE; } /* get << contents */ if ((sys=getobject("system"))==NULL) return -1; sout = n_mkstemp(getval(nshell,"TMPDIR"), TEMPPFX, &tmpfil); if (sout < 0) return -1; if ((quoted) && !nisatty(nshell->fd)) { eoflen=strlen(eof); match=0; writepo=0; while (TRUE) { ch=shget(nshell); if ((ch==EOF) || (ch=='\0')) break; if (remove_tab && ch == '\t') continue; remove_tab = FALSE; if (ch=='\n') { if (match==eoflen) break; writebuf[writepo]=ch; writepo++; if (writepo==WRITEBUFSIZE) { nwrite(sout,writebuf,WRITEBUFSIZE); writepo=0; } match=0; remove_tab = ignore_indent; } else if (match==-1) { writebuf[writepo]=ch; writepo++; if (writepo==WRITEBUFSIZE) { nwrite(sout,writebuf,WRITEBUFSIZE); writepo=0; } } else if ((match==eoflen) || (ch!=eof[match])) { for (i=0;ifd)) { prompt = getval(nshell,"PS2"); #ifdef HAVE_READLINE_READLINE_H Prompt = prompt; MultiLine = TRUE; #else if (prompt) printfconsole("%.256s", prompt); #endif } do { ch=shget(nshell); if (ch==EOF) { if (strlen(s)!=0) { if (!nisatty(nshell->fd)) break; else printfconsole("%c",(char )0x07); } else break; } else { if (ch=='\n') ch='\0'; if (remove_tab && ch == '\t') continue; remove_tab = FALSE; if ((s=nstrccat(s,ch))==NULL) { nclose(sout); unlinkfile(&tmpfil); return -1; } } } while (ch!='\0'); if (strcmp0(eof,s)!=0) { len=strlen(s); s[len]='\n'; nwrite(sout,s,len+1); g_free(s); } else { g_free(s); break; } } while (ch!=EOF); } nclose(sout); g_free((prmcur->next)->str); (prmcur->next)->str=tmpfil; } } else { if (prmcur->str[0]=='>') prmcur->prmno=PPSO1; else prmcur->prmno=PPSI1; } (prmcur->next)->prmno=prmcur->prmno; prmcur=prmcur->next; } else if (prmcur->str[0]=='|') { if (cmdcur->cmdno==CPPATI) { prmcur->prmno=PPPATOR; } else { cmdcur->cmdend=PPPIPE; prmcur->prmno=PPPIPE; if ((prmcur->next==NULL) || ((prmcur->next)->str==NULL) || (strchr(";&|",(prmcur->next)->str[0])!=NULL)) { sherror2(ERRUEXPTOK,prmcur->str); return 2; } if ((cmdnew=g_malloc(sizeof(struct cmdlist)))==NULL) return -1; cmdnew->next=cmdcur->next; cmdcur->next=cmdnew; cmdnew->prm=prmcur->next; prmcur->next=NULL; cmdnew->cmdno=CPNO; } } else if (prmcur->str[0]=='&') { prmcur->prmno=PPAND; cmdcur->cmdend=PPAND; } else if (prmcur->str[0]==';') { if (prmcur->str[1]==';') { cmdcur->cmdno=CPPATO; /* how is prmcur->prmno ? */ prmcur->prmno=PPNULL; /* is it right? */ } else { prmcur->prmno=PPEND; } } else { prmcur->prmno=PPNO; } } else { prmcur->prmno=PPNULL; } prmprev=prmcur; prmcur=prmcur->next; } /* check variable setting command */ prmcur=cmdcur->prm; while (prmcur!=NULL) { if (prmcur->prmno == PPNO) { po=prmcur->str; if (isobject(&po) && (po[0]=='=')) { prmcur->prmno=PPSETO; } else { po=prmcur->str; for (i=0;(po[i]!='\0') && (isalnum(po[i]) || (po[i]=='_'));i++); if ((i!=0) && (po[i]=='=')) prmcur->prmno=PPSETV; } if (prmcur->prmno==PPNO) break; } prmcur=prmcur->next; } cmdprev=cmdcur; cmdcur=cmdcur->next; } } return 0; } static int syntax(struct nshell *nshell, struct cmdlist *cmdroot,int *needcmd,struct cmdstack **sx) /* syntax() returns -1: fatal error 0: noerror 2: syntax error */ { struct cmdlist *cmdcur; struct prmlist *prmcur; int i,cmd,c; char *s; struct cmdstack *st; cmdcur=cmdroot; while (cmdcur!=NULL) { cmd=cmdcur->cmdno; c=cmdstackgetlast(sx); if ((c==CPFOR) && (cmd!=CPDO)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((c==CPCASE) && (cmd!=CPPATI) && (cmd!=CPESAC)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((c==CPFN) && (cmd!=CPBI)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((*needcmd) && !((cmd==CPIF) || (cmd==CPCASE) || (cmd==CPFOR) || (cmd==CPWHILE) || (cmd==CPUNTIL) || (cmd==CPFN) || (cmd==CPNO))) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((cmd==CPIF) || (cmd==CPTHEN) || (cmd==CPELSE) || (cmd==CPELIF) || (cmd==CPWHILE) || (cmd==CPUNTIL) || (cmd==CPDO) || (cmd==CPBI)) *needcmd=TRUE; else if (cmdcur->cmdend==PPPIPE) *needcmd=TRUE; else *needcmd=FALSE; switch (cmd) { case CPNULL: sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; case CPIF: if ((st=cmdstackcat(sx,CPIF))==NULL) return -1; st->cmd=cmdcur; break; case CPTHEN: if (cmdstackgetlast(sx)!=CPIF) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPTHEN))==NULL) return -1; st->cmd=cmdcur; break; case CPELIF: if (cmdstackgetlast(sx)!=CPTHEN) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPIF))==NULL) return -1; st->cmd=cmdcur; break; case CPELSE: if (cmdstackgetlast(sx)!=CPTHEN) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPELSE))==NULL) return -1; st->cmd=cmdcur; break; case CPFI: c=cmdstackgetlast(sx); if ((c!=CPTHEN) && (c!=CPELSE)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); break; case CPCASE: if ((st=cmdstackcat(sx,CPCASE))==NULL) return -1; st->cmd=cmdcur; prmcur=(cmdcur->prm)->next; if ((prmcur==NULL) || (prmcur->next==NULL)) { sherror2(ERRSYNTAX,(cmdcur->prm)->str); return 2; } prmcur=prmcur->next; if ((prmcur->str==NULL) || (strcmp0("in",prmcur->str)!=0)) { sherror2(ERRSYNTAX,prmcur->str); return 2; } if (prmcur->next!=NULL) { sherror2(ERRUEXPTOK,(prmcur->next)->str); return 2; } break; case CPPATI: c=cmdstackgetlast(sx); if ((c!=CPCASE) && (c!=CPPATO)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } prmcur=cmdcur->prm; if (prmcur->str[0]==')') { sherror2(ERRUEXPTOK,prmcur->str); return 2; } prmcur=prmcur->next; while (TRUE) { if (prmcur->str[0]==')') break; if (prmcur->prmno!=PPPATOR) { sherror2(ERRUEXPTOK,prmcur->str); return 2; } if ((prmcur->next==NULL) || ((prmcur->next)->next==NULL)) { sherror2(ERRUEXPTOK,prmcur->str); return 2; } prmcur=(prmcur->next)->next; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPPATI))==NULL) return -1; st->cmd=cmdcur; break; case CPPATO: if (cmdstackgetlast(sx)!=CPPATI) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPPATO))==NULL) return -1; st->cmd=cmdcur; break; case CPESAC: c=cmdstackgetlast(sx); if ((c!=CPCASE) && (c!=CPPATI) && (c!=CPPATO)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); break; case CPFOR: if (cmdstackcat(sx,CPFOR)==NULL) return -1; prmcur=(cmdcur->prm)->next; if (prmcur==NULL) { sherror2(ERRSYNTAX,(cmdcur->prm)->str); return 2; } prmcur=prmcur->next; if (prmcur!=NULL) { if (strcmp0("in",prmcur->str)!=0) { sherror2(ERRSYNTAX,prmcur->str); return 2; } prmcur=prmcur->next; while (prmcur!=NULL) { if ((prmcur->prmno!=PPNO) && (prmcur->prmno!=PPEND)) { sherror2(ERRUEXPTOK,prmcur->str); return 2; } prmcur=prmcur->next; } } break; case CPWHILE: if (cmdstackcat(sx,CPWHILE)==NULL) return -1; break; case CPUNTIL: if (cmdstackcat(sx,CPUNTIL)==NULL) return -1; break; case CPDO: c=cmdstackgetlast(sx); if ((c!=CPFOR) && (c!=CPWHILE) && (c!=CPUNTIL)) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } cmdstackrmlast(sx); if ((st=cmdstackcat(sx,CPDO))==NULL) return -1; st->cmd=cmdcur; break; case CPDONE: if (cmdstackgetlast(sx)!=CPDO) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); break; case CPFN: s=(cmdcur->prm)->str; for (i=0;s[i]!='\0';i++) if (!isalnum(s[i]) && (s[i]!='_')) { sherror2(ERRIDENT,s); return 2; } if ((st=cmdstackcat(sx,CPFN))==NULL) return -1; st->cmd=cmdcur; break; case CPBI: if (cmdstackgetlast(sx)!=CPFN) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackcat(sx,CPBI))==NULL) return -1; st->cmd=cmdcur; break; case CPBO: if (cmdstackgetlast(sx)!=CPBI) { sherror2(ERRUEXPTOK,(cmdcur->prm)->str); return 2; } if ((st=cmdstackgetpo(sx))==NULL) return -1; (st->cmd)->done=cmdcur; cmdstackrmlast(sx); cmdstackrmlast(sx); break; default: break; } cmdcur=cmdcur->next; } return 0; } struct set_env_arg { struct nshell *nshell; char ***newenviron; }; static int set_env_val(struct nhash *h, void *data) { struct vallist *valcur; struct set_env_arg *arg; const char *val, *env; char *s; int r; valcur = (struct vallist *) h->val.p; arg = (struct set_env_arg *) data; if (valcur->func) return 0; r = getexp(arg->nshell, valcur->name); if (r || valcur->arg) { val = valcur->val; } else if ((env = g_getenv(valcur->name))) { val = env; } else { return 0; } s = g_strdup_printf("%s=%s", valcur->name, val); if (s == NULL) return 1; if (arg_add(arg->newenviron, s) == NULL) { g_free(s); return 1; } return 0; } int msleep(int ms) { #ifdef HAVE_NANOSLEEP struct timespec ts; ts.tv_sec = ms / 1000; ts.tv_nsec = (ms % 1000) * 1000000; return nanosleep(&ts, NULL); #else return usleep(ms * 1000); #endif } #if WINDOWS static int WaitProc; static void * proc_in_thread(void *ptr) { char *cmd; PROCESS_INFORMATION pi; STARTUPINFO si; DWORD exit_code; int r; if (ptr == NULL) { return NULL; } while (! WaitProc) { msleep(1); } cmd = (char *) ptr; ZeroMemory(&si, sizeof(si)); si.cb = sizeof(si); r = CreateProcess(NULL, cmd, NULL, NULL, TRUE, NORMAL_PRIORITY_CLASS, NULL, NULL, &si, &pi); if (r == 0) { show_system_error(); WaitProc = 0; return NULL; } CloseHandle(pi.hThread); WaitForSingleObject(pi.hProcess, INFINITE); GetExitCodeProcess(pi.hProcess, &exit_code); CloseHandle(pi.hProcess); WaitProc = 0; return GINT_TO_POINTER(exit_code); } static char * quote_args(char **args) { int len, i; char *cmd, *ptr; if (args == NULL) { return NULL; } for (len = i = 0; args[i]; i++) { len += strlen(args[i]) * 2 + 3; } cmd = g_malloc(len + 1); if (cmd == NULL) { return NULL; } ptr = cmd; for (i = 0; args[i]; i++) { char *arg, ch; *ptr = '"'; ptr++; arg = args[i]; while (*arg) { ch = *arg; if (ch == '"') { *ptr = '\\'; ptr++; } *ptr = ch; ptr++; arg++; } *ptr = '"'; ptr++; *ptr = ' '; ptr++; } *ptr = '\0'; return cmd; } #endif /* WINDOWS */ void set_interrupt(void) { Interrupted = TRUE; } void reset_interrupt(void) { Interrupted = FALSE; } int check_interrupt(void) { int state; state = Interrupted; Interrupted = FALSE; return state; } int cmdexec(struct nshell *nshell,struct cmdlist *cmdroot,int namedfunc) { struct cmdlist *cmdcur,*cmdnew,*cmd; struct prmlist *prmcur,*prmprev,*prm,*prmnewroot; struct vallist *newvalroot; int err,quote,bquote,rcode,needcmd; char *str,*name,*val,*po,*cmdname; int i,j,num,pnum,errlevel,a,looplevel,len; char *arg,*endptr,**env; struct cmdstack *stroot,*stcur,*st; char *fstdout,*fstdin; int istdout,istdin; int sout,sout2,sin,sin2,sin3,fd; int lastc; int pipef; struct objlist *sys; char *tmpfil,*tmpfil2; char *cmds; char *s; char **argv,**newenviron; char **argvsave,**argvnew; int quoted; int argcsave,argcnew; int iftrue,casetrue; char *pat; char *readbuf; int readpo; int readbyte; int ch; char buf[2]; shell_proc proc; #if ! WINDOWS pid_t pid; #endif /* WINDOWS */ reset_interrupt(); nshell->cmdexec++; err=-1; stroot=NULL; prmnewroot=NULL; fstdout=fstdin=NULL; env=NULL; newenviron=NULL; newvalroot=NULL; cmdname=NULL; sout=sout2=sin=sin2=NOHANDLE; tmpfil2=NULL; if (nshell->optionv) { cmd=cmdroot; while (cmd!=NULL) { prm=cmd->prm; while (prm!=NULL) { printfconsole("%.256s ",prm->str); prm=prm->next; } printfconsole("\n"); cmd=cmd->next; } } cmdcur=cmdroot; while ((cmdcur!=NULL) && (!(nshell->quit))) { if (ninterrupt()) goto errexit; stcur=cmdstackgetpo(&stroot); if ((stcur!=NULL) && (stcur->cmdno==CPBI) && (stcur->cmd!=cmdcur)) { if (addfunc(nshell,stcur->val,cmdcur)==NULL) goto errexit; cmdcur=cmdcur->next; } else { switch (cmdcur->cmdno) { case CPNULL: cmdcur=cmdcur->next; break; case CPIF: if ((st=cmdstackcat(&stroot,CPIF))==NULL) goto errexit; st->iftrue=FALSE; cmdcur=cmdcur->next; break; case CPTHEN: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; iftrue=st->iftrue; if (iftrue || nshell->status) cmdcur=cmdcur->done; else { iftrue=TRUE; cmdcur=cmdcur->next; } cmdstackrmlast(&stroot); if ((st=cmdstackcat(&stroot,CPTHEN))==NULL) goto errexit; st->iftrue=iftrue; break; case CPELIF: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; iftrue=st->iftrue; if (iftrue) cmdcur=cmdcur->done; else cmdcur=cmdcur->next; cmdstackrmlast(&stroot); if ((st=cmdstackcat(&stroot,CPIF))==NULL) goto errexit; st->iftrue=iftrue; break; case CPELSE: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; iftrue=st->iftrue; if (iftrue) cmdcur=cmdcur->done; else cmdcur=cmdcur->next; cmdstackrmlast(&stroot); if ((st=cmdstackcat(&stroot,CPELSE))==NULL) goto errexit; st->iftrue=iftrue; break; case CPFI: cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; case CPCASE: if ((st=cmdstackcat(&stroot,CPCASE))==NULL) return -1; st->casetrue=FALSE; prmcur=(cmdcur->prm)->next; quote='\0'; bquote='\0'; if ((str=expand(nshell,prmcur->str,"e,&bquote,FALSE))==NULL) goto errexit; if (quote || bquote) { sherror(ERRUEXPEOF); goto errexit; } if ((str=fnexpand(nshell,str))==NULL) goto errexit; wordunsplit(str); st->pat=str; cmdcur=cmdcur->next; break; case CPPATI: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; casetrue=st->casetrue; pat=st->pat; st->pat = NULL; /* hito (mem leak of pat) */ if (casetrue) cmdcur=cmdcur->done; else { prm=cmdcur->prm; while (prm!=NULL) { if (wildmatch(prm->str,pat,0)) break; prm=prm->next; prm=prm->next; } if (prm!=NULL) { casetrue=TRUE; cmdcur=cmdcur->next; } else cmdcur=cmdcur->done; } cmdstackrmlast(&stroot); if ((st=cmdstackcat(&stroot,CPPATI))==NULL) goto errexit; st->casetrue=casetrue; st->pat=pat; break; case CPPATO: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; casetrue=st->casetrue; pat=st->pat; st->pat = NULL; /* hito (mem leak of pat) */ cmdstackrmlast(&stroot); if ((st=cmdstackcat(&stroot,CPPATO))==NULL) goto errexit; st->casetrue=casetrue; st->pat=pat; cmdcur=cmdcur->done; break; case CPESAC: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; casetrue=st->casetrue; pat=st->pat; st->pat = NULL; /* hito (mem leak of pat) */ g_free(pat); cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; case CPFOR: if ((stcur=cmdstackcat(&stroot,CPFOR))==NULL) goto errexit; stcur->cmd=cmdcur; prmcur=(cmdcur->prm)->next; stcur->val=prmcur->str; prmcur=prmcur->next; if (prmcur==NULL) stcur->ival=0; else { stcur->ival=-1; prmnewroot=NULL; prmprev=NULL; prmcur=prmcur->next; while (prmcur!=NULL) { if ((prm=g_malloc(sizeof(struct prmlist)))==NULL) goto errexit; if (prmprev==NULL) prmnewroot=prm; else prmprev->next=prm; prm->next=NULL; prm->str=NULL; prm->prmno=prmcur->prmno; quote='\0'; bquote='\0'; if ((str=expand(nshell,prmcur->str,"e,&bquote,FALSE))==NULL) goto errexit; if (quote || bquote) { sherror(ERRUEXPEOF); goto errexit; } if (str[0]!='\0') { if ((prm->str=fnexpand(nshell,str))==NULL) goto errexit; } else { g_free(str); prm->str=NULL; } if ((num=wordsplit(prm))==-1) goto errexit; for (j=0;jnext; } prmcur=prmcur->next; } /* remove null parameter and command end */ prmcur=prmnewroot; prmprev=NULL; while (prmcur!=NULL) { if ((prmcur->str==NULL) || (prmcur->prmno==PPEND)) { if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm->str); g_free(prm); } else { prmprev=prmcur; prmcur=prmcur->next; } } prmfree(stcur->prm); stcur->prm=prmnewroot; prmnewroot=NULL; } cmdcur=cmdcur->next; break; case CPWHILE: if ((stcur=cmdstackcat(&stroot,CPWHILE))==NULL) goto errexit; stcur->cmd=cmdcur; cmdcur=cmdcur->next; break; case CPUNTIL: if ((stcur=cmdstackcat(&stroot,CPUNTIL))==NULL) goto errexit; stcur->cmd=cmdcur; cmdcur=cmdcur->next; break; case CPDO: if ((stcur=cmdstackgetpo(&stroot))==NULL) goto errexit; if (stcur->cmdno==CPFOR) { if (stcur->ival==-1) { prmcur=stcur->prm; if (prmcur==NULL) { cmdcur=cmdcur->done; cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; } if (addval(nshell,stcur->val,prmcur->str)==NULL) goto errexit; stcur->prm=prmcur->next; g_free(prmcur->str); g_free(prmcur); } else { stcur->ival++; if (stcur->ivalargc) { if (addval(nshell,stcur->val,nshell->argv[stcur->ival])==NULL) goto errexit; } else { cmdcur=cmdcur->done; cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; } } } else if (stcur->cmdno==CPWHILE) { if (nshell->status) { cmdcur=cmdcur->done; cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; } } else if (stcur->cmdno==CPUNTIL) { if (!nshell->status) { cmdcur=cmdcur->done; cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; } } cmdcur=cmdcur->next; break; case CPDONE: if ((stcur=cmdstackgetpo(&stroot))==NULL) goto errexit; cmdcur=stcur->cmd; cmdcur=cmdcur->next; break; case CPFN: if ((stcur=cmdstackcat(&stroot,CPFN))==NULL) goto errexit; prmcur=cmdcur->prm; stcur->val=prmcur->str; if (newfunc(nshell,prmcur->str)==NULL) goto errexit; cmdcur=cmdcur->next; break; case CPBI: if ((st=cmdstackgetpo(&stroot))==NULL) goto errexit; if ((stcur=cmdstackcat(&stroot,CPBI))==NULL) goto errexit; stcur->val=st->val; stcur->cmd=cmdcur->done; cmdcur=cmdcur->next; break; case CPBO: cmdstackrmlast(&stroot); cmdstackrmlast(&stroot); cmdcur=cmdcur->next; break; case CPNO: prmnewroot=NULL; prmprev=NULL; prmcur=cmdcur->prm; while (prmcur!=NULL) { if (prmcur->prmno!=PPSI2) { quote='\0'; bquote='\0'; if ((str=expand(nshell,prmcur->str,"e,&bquote,FALSE))==NULL) goto errexit; if (quote || bquote) { g_free(str); sherror(ERRUEXPEOF); goto errexit; } prmcur->quoted=FALSE; } else { if ((str=g_malloc(strlen(prmcur->str)+1))==NULL) goto errexit; strcpy(str,prmcur->str); } if ((prmcur->prmno!=PPNO) || (str[0]!='\0')) { if ((prm=g_malloc(sizeof(struct prmlist)))==NULL) goto errexit; if (prmprev==NULL) prmnewroot=prm; else prmprev->next=prm; prm->next=NULL; prm->prmno=prmcur->prmno; prm->quoted=prmcur->quoted; if (prmcur->prmno!=PPSI2) { if ((prm->str=fnexpand(nshell,str))==NULL) goto errexit; if (prm->prmno==PPNO) { if ((num=wordsplit(prm))==-1) goto errexit; for (j=0;jprmno=PPNO; prm=prm->next; } } else { wordunsplit(prm->str); prmprev=prm; } } else { prm->str=str; prmprev=prm; } } else g_free(str); prmcur=prmcur->next; } /* remove null parameter & check redirect and pipe */ istdout=istdin=PPNO; pipef=FALSE; prmcur=prmnewroot; prmprev=NULL; pnum=0; while (prmcur!=NULL) { if (prmcur->str==NULL) { if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm->str); g_free(prm); } else if ((prmcur->prmno==PPSI1) || (prmcur->prmno==PPSI2) || (prmcur->prmno==PPSO1) || (prmcur->prmno==PPSO2)) { if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm->str); g_free(prm); switch (prmcur->prmno) { case PPSI1: g_free(fstdin); fstdin=prmcur->str; istdin=PPSI1; break; case PPSI2: g_free(fstdin); fstdin=prmcur->str; istdin=PPSI2; quoted=prmcur->quoted; break; case PPSO1: g_free(fstdout); fstdout=prmcur->str; istdout=PPSO1; break; case PPSO2: g_free(fstdout); fstdout=prmcur->str; istdout=PPSO2; break; } if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm); } else if (prmcur->prmno==PPPIPE) { pipef=TRUE; if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm->str); g_free(prm); } else if (prmcur->prmno==PPEND) { if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm->str); g_free(prm); } else if ((prmcur->prmno!=PPSETV) && (prmcur->prmno!=PPSETO)) { pnum++; prmprev=prmcur; prmcur=prmcur->next; } else { prmprev=prmcur; prmcur=prmcur->next; } } /* set variable */ prmcur=prmnewroot; prmprev=NULL; while (prmcur!=NULL) { if (prmcur->prmno==PPSETV) { po=strchr(prmcur->str,'='); if ((name=g_malloc(po-prmcur->str+1))==NULL) goto errexit; strncpy(name,prmcur->str,po-prmcur->str); name[po-prmcur->str]='\0'; if ((val=g_malloc(strlen(prmcur->str)-(po-prmcur->str)))==NULL) { g_free(name); goto errexit; } strcpy(val,po+1); if (pnum==0) po=addval(nshell,name,val); else po=saveval(nshell,name,val,&newvalroot); g_free(name); g_free(val); if (po==NULL) goto errexit; g_free(prmcur->str); if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm); } else if (prmcur->prmno==PPSETO) { /* set object */ if (sputobj(prmcur->str)==-1) goto errexit; g_free(prmcur->str); if (prmprev==NULL) prmnewroot=prmcur->next; else prmprev->next=prmcur->next; prm=prmcur; prmcur=prmcur->next; g_free(prm); } else { prmprev=prmcur; prmcur=prmcur->next; } } prmcur=prmnewroot; if ((prmcur!=NULL) && (prmcur->prmno==PPNO)) { /* set environment variable */ #if USE_HASH { struct set_env_arg se_arg; se_arg.nshell = nshell; se_arg.newenviron = &newenviron; if (nhash_each(nshell->valroot, set_env_val, &se_arg)) goto errexit; } #else struct vallist *valcur = nshell->valroot; while (valcur!=NULL) { if (!valcur->func && (getexp(nshell,valcur->name) || valcur->arg || (g_getenv(valcur->name)!=NULL))) { len=strlen(valcur->name); if (getexp(nshell,valcur->name) || valcur->arg) val=valcur->val; else val=g_getenv(valcur->name); if ((s=g_malloc(len+strlen(val)+2))==NULL) goto errexit; strcpy(s,valcur->name); s[len]='='; strcpy(s+len+1,val); if (arg_add(&newenviron,s)==NULL) { g_free(s); goto errexit; } } valcur=valcur->next; } #endif env=MainEnviron; MainEnviron=newenviron; newenviron=NULL; sout=sin=NOHANDLE; if (istdin!=PPNO) { if (istdin==PPSI1) sin=nopen(fstdin,O_RDONLY,NFMODE); else if (istdin==PPSI2) { sin=nopen(fstdin,O_RDONLY,NFMODE); if (!quoted) { fd = n_mkstemp(getval(nshell,"TMPDIR"), TEMPPFX, &tmpfil2); if (fd < 0) { nclose(sin); goto errexit; } do { if ((s=nstrnew())==NULL) { nclose(sin); nclose(fd); goto errexit; } do { if (nread(sin,buf,1)>0) ch=buf[0]; else ch=EOF; if (ch==EOF) break; else { if (ch=='\n') ch='\0'; if ((s=nstrccat(s,ch))==NULL) { nclose(sin); nclose(fd); goto errexit; } } } while (ch!='\0'); quote=bquote='\0'; str=s; s=expand(nshell,str,"e,&bquote,FALSE); g_free(str); if (s==NULL) { nclose(sin); nclose(fd); goto errexit; } wordunsplit(s); len=strlen(s); if (ch!=EOF) { s[len]='\n'; len++; } nwrite(fd,s,len); g_free(s); } while (ch!=EOF); nclose(sin); nclose(fd); sin=nopen(tmpfil2,O_RDONLY,NFMODE); } } } else if (cmdcur->pipefile!=NULL) { sin=nopen(cmdcur->pipefile,O_RDONLY,NFMODE); } if (sin!=NOHANDLE) sin2=nredirect(0,sin); /* redirect : stdout */ if (istdout!=PPNO) { if (Security) { sherror(ERRSECURITY); goto errexit; } if (istdout==PPSO2) sout=nopen(fstdout,O_APPEND|O_CREAT|O_WRONLY,NFMODE); else sout=nopen(fstdout,O_CREAT|O_WRONLY|O_TRUNC,NFMODE); /* pipe */ } else if (pipef) { if ((sys=getobject("system"))==NULL) goto errexit; sout = n_mkstemp(getval(nshell,"TMPDIR"), TEMPPFX, &tmpfil); if (sout < 0) goto errexit; unlinkfile(&((cmdcur->next)->pipefile)); (cmdcur->next)->pipefile=tmpfil; } if (sout!=NOHANDLE) sout2=nredirect(1,sout); if (nshell->optionx) { for (i=0;icmdexec;i++) printfconsole("+"); printfconsole(" "); prm=prmcur; while (prm!=NULL) { printfconsole("%.256s ",prm->str); prm=prm->next; } printfconsole("\n"); } cmds=prmcur->str; /* exec named function */ if ((cmdnew=getfunc(nshell,cmds))!=NULL) { needcmd=FALSE; st=NULL; rcode=syntax(nshell,cmdnew,&needcmd,&st); cmdstackfree(st); if ((rcode!=0) || (st!=NULL) || (needcmd)) goto errexit; argvnew=NULL; if ((s=g_malloc(strlen((nshell->argv)[0])+1))==NULL) goto errexit; strcpy(s,(nshell->argv)[0]); if (arg_add(&argvnew,s)==NULL) { g_free(s); arg_del(argvnew); goto errexit; } prmcur=prmcur->next; while (prmcur!=NULL) { if ((s=g_malloc(strlen(prmcur->str)+1))==NULL) { g_free(s); arg_del(argvnew); goto errexit; } strcpy(s,prmcur->str); if (arg_add(&argvnew,s)==NULL) { g_free(s); arg_del(argvnew); goto errexit; } prmcur=prmcur->next; } argcnew=getargc(argvnew); argcsave=nshell->argc; argvsave=nshell->argv; nshell->argc=argcnew; nshell->argv=argvnew; rcode=cmdexec(nshell,cmdnew,TRUE); arg_del(nshell->argv); nshell->argc=argcsave; nshell->argv=argvsave; if ((rcode==-1) || (rcode==1)) goto errexit; /* exec special command */ /* . */ } else if (strcmp0(".",cmds)==0) { prmcur=prmcur->next; if (prmcur!=NULL) { cmdname=nsearchpath(getval(nshell,"PATH"),prmcur->str,TRUE); if (cmdname!=NULL) { argvnew=NULL; if ((s=g_malloc(strlen((nshell->argv)[0])+1))==NULL) goto errexit; strcpy(s,(nshell->argv)[0]); if (arg_add(&argvnew,s)==NULL) { g_free(s); arg_del(argvnew); goto errexit; } prmcur=prmcur->next; while (prmcur!=NULL) { if ((s=g_malloc(strlen(prmcur->str)+1))==NULL) { g_free(s); arg_del(argvnew); goto errexit; } strcpy(s,prmcur->str); if (arg_add(&argvnew,s)==NULL) { g_free(s); arg_del(argvnew); goto errexit; } prmcur=prmcur->next; } argcnew=getargc(argvnew); sin=nopen(cmdname,O_RDONLY,NFMODE); g_free(cmdname); cmdname=NULL; if (sin==NOHANDLE) { sherror2(ERROPEN,cmdname); arg_del(argvnew); goto errexit; } argcsave=nshell->argc; argvsave=nshell->argv; nshell->argc=argcnew; nshell->argv=argvnew; sin3=storeshhandle(nshell,sin,&readbuf,&readbyte,&readpo); rcode=cmdexecute(nshell,NULL); restoreshhandle(nshell,sin3,readbuf,readbyte,readpo); nclose(sin); arg_del(nshell->argv); nshell->argc=argcsave; nshell->argv=argvsave; if ((rcode!=0) && (rcode!=1)) goto errexit; } else { sherror2(ERRNOFIL,prmcur->str); goto errexit; } } /* break */ } else if (strcmp0("break",cmds)==0) { if (pnum>2) { sherror(ERREXTARG); goto errexit; } else if (pnum==2) { arg=(prmcur->next)->str; a=strtol(arg,&endptr,10); if (endptr[0]!='\0') { sherror2(ERRNUMERIC,arg); goto errexit; } } else a=1; looplevel=0; stcur=stroot; while (stcur!=NULL) { if ((stcur->cmdno==CPFOR) || (stcur->cmdno==CPWHILE) || (stcur->cmdno==CPUNTIL)) looplevel++; stcur=stcur->next; } if (looplevel!=0) { while (a>0) { if ((stcur=cmdstackgetpo(&stroot))==NULL) break; if ((stcur->cmdno==CPFOR) && (stcur->ival==-1)) { prmfree(stcur->prm); stcur->prm=NULL; } if ((stcur->cmdno==CPFOR) || (stcur->cmdno==CPWHILE) || (stcur->cmdno==CPUNTIL)) { cmdcur=stcur->cmd; while (cmdcur->cmdno!=CPDO) cmdcur=cmdcur->next; cmdcur=cmdcur->done; cmdstackrmlast(&stroot); a--; } else cmdstackrmlast(&stroot); } } /* continue */ } else if (strcmp0("continue",cmds)==0) { if (pnum>2) { sherror(ERREXTARG); goto errexit; } else if (pnum==2) { arg=(prmcur->next)->str; a=strtol(arg,&endptr,10); if (endptr[0]!='\0') { sherror2(ERRNUMERIC,arg); goto errexit; } } else a=1; looplevel=0; stcur=stroot; while (stcur!=NULL) { if ((stcur->cmdno==CPFOR) || (stcur->cmdno==CPWHILE) || (stcur->cmdno==CPUNTIL)) looplevel++; stcur=stcur->next; } if (looplevel!=0) { while (a>0) { if ((stcur=cmdstackgetpo(&stroot))==NULL) break; if ((stcur->cmdno==CPFOR) || (stcur->cmdno==CPWHILE) || (stcur->cmdno==CPUNTIL)) { cmdcur=stcur->cmd; a--; if (a>0) { if ((stcur->cmdno==CPFOR) && (stcur->ival==-1)) { prmfree(stcur->prm); stcur->prm=NULL; } cmdstackrmlast(&stroot); } } else cmdstackrmlast(&stroot); } } /* return */ } else if (strcmp0("return",cmds)==0) { if (pnum>2) { sherror(ERREXTARG); goto errexit; } else if (pnum==2) { arg=(prmcur->next)->str; a=strtol(arg,&endptr,10); if (endptr[0]!='\0') { sherror2(ERRNUMERIC,arg); goto errexit; } nshell->status=a; } if (namedfunc) { err=0; goto errexit; } /* execute object */ } else if (isobject(&cmds)) { len=0; prm=prmcur; while (prm!=NULL) { len+=strlen(prm->str)+1; prm=prm->next; } if ((str=g_malloc(len))==NULL) goto errexit; str[0]='\0'; prm=prmcur; while (prm!=NULL) { strcat(str,prm->str); if (prm->next!=NULL) strcat(str," "); prm=prm->next; } errlevel=sexeobj(str); g_free(str); if (errlevel==-1) goto errexit; nshell->status=errlevel; nshell->status=errlevel; lastc=cmdstackgetlast(&stroot); if ((lastc!=CPIF) && (lastc!=CPELIF) && (lastc!=CPWHILE) && (lastc!=CPUNTIL) && (nshell->optione) && (errlevel!=0)) { err=3; goto errexit; } nshell->status=errlevel; lastc=cmdstackgetlast(&stroot); if ((lastc!=CPIF) && (lastc!=CPELIF) && (lastc!=CPWHILE) && (lastc!=CPUNTIL) && (nshell->optione) && (errlevel!=0)) { err=3; goto errexit; } if (nshell->quit) break; if (nshell->quit) break; /* exec inner command */ } else { proc = check_cmd(prmcur->str); if (proc) { argv = NULL; if (arg_add(&argv, NULL) == NULL) goto errexit; prm = prmnewroot; while (prm) { if (arg_add(&argv, prm->str) == NULL) { g_free(argv); goto errexit; } prm = prm->next; } errlevel = proc(nshell, pnum, (char **)argv); g_free(argv); } else { cmdname=nsearchpath(getval(nshell,"PATH"),prmcur->str,FALSE); if (cmdname==NULL) { sherror2(ERRCFOUND,prmcur->str); goto errexit; } else { if (Security) { sherror(ERRSECURITY); goto errexit; } argv=NULL; if (arg_add(&argv,NULL)==NULL) goto errexit; prm=prmnewroot; while (prm!=NULL) { if (arg_add(&argv,prm->str)==NULL) { g_free(argv); goto errexit; } prm=prm->next; } #if WINDOWS { GThread *thread; char *ptr, *cmd; ptr = quote_args(argv); if (ptr == NULL) { sherror(ERRMEMORY); goto errexit; } cmd = g_locale_from_utf8(ptr, -1, NULL, NULL, NULL); g_free(ptr); if (cmd == NULL) { sherror(ERRMEMORY); goto errexit; } errlevel = 0; #if GLIB_CHECK_VERSION(2, 32, 0) thread= g_thread_new("process", proc_in_thread, cmd); #else thread = g_thread_create(proc_in_thread, cmd, TRUE, NULL); #endif if (thread) { WaitProc = 1; while (WaitProc) { msleep(1); eventloop(); } errlevel = GPOINTER_TO_INT(g_thread_join(thread)); } g_free(cmd); } #else /* WINDOWS */ unset_childhandler(); pid = fork(); if (pid < 0) { sherror2(ERRSYSTEM,"fork"); set_childhandler(); goto errexit; } else if (pid == 0) { errlevel=execve(cmdname,(char **)argv,MainEnviron); printfstderr("shell: %.64s: %.64s", argv[0],g_strerror(errno)); exit(errlevel); } else { if (has_eventloop()) { while (waitpid(pid,&errlevel,WNOHANG)==0) { eventloop(); msleep(10); } } else { waitpid(pid, &errlevel, 0); } errlevel = WIFEXITED(errlevel) ? WEXITSTATUS(errlevel) : 1; } set_childhandler(); #endif /* WINDOWS */ g_free(argv); g_free(cmdname); cmdname=NULL; } } nshell->status = errlevel; lastc=cmdstackgetlast(&stroot); if ((lastc!=CPIF) && (lastc!=CPELIF) && (lastc!=CPWHILE) && (lastc!=CPUNTIL) && (nshell->optione) && (errlevel!=0)) { err=3; goto errexit; } if (nshell->quit) break; } if (sout2!=NOHANDLE) { nredirect2(1,sout2); sout2=NOHANDLE; } if (sin2!=NOHANDLE) { nredirect2(0,sin2); sin2=NOHANDLE; } unlinkfile(&tmpfil2); arg_del(MainEnviron); MainEnviron=env; env=NULL; } restoreval(nshell,newvalroot); newvalroot=NULL; prmfree(prmnewroot); prmnewroot=NULL; g_free(fstdout); g_free(fstdin); fstdout=fstdin=NULL; unlinkfile(&(cmdcur->pipefile)); cmdcur=cmdcur->next; break; default: unlinkfile(&(cmdcur->pipefile)); cmdcur=cmdcur->next; break; } } } err=0; errexit: cmdstackfree(stroot); prmfree(prmnewroot); g_free(fstdout); g_free(fstdin); g_free(cmdname); arg_del(newenviron); if (env!=NULL) { arg_del(MainEnviron); MainEnviron=env; } if (newvalroot!=NULL) restoreval(nshell,newvalroot); if (sout2!=NOHANDLE) nredirect2(1,sout2); if (sin2!=NOHANDLE) nredirect2(0,sin2); unlinkfile(&tmpfil2); cmdcur=cmdroot; while (cmdcur!=NULL) { prmcur=cmdcur->prm; while (prmcur!=NULL) { if (prmcur->prmno == PPSI2 && prmcur->next!=NULL && prmcur->next->str != NULL) { g_unlink((prmcur->next)->str); prmcur=prmcur->next; } prmcur=prmcur->next; } unlinkfile(&(cmdcur->pipefile)); cmdcur=cmdcur->next; } nshell->cmdexec--; return err; } int cmdexecute(struct nshell *nshell, const char *cline) /* return -2: unexpected eof detected -1: fatal error 0: no error 1: eof detected 2: syntax error 3: runtime error */ { struct cmdlist *cmdroot,*cmdcur,*cmdnew; struct cmdstack *stroot; int needcmd,rcode; int istr; istr=0; nshell->quit=FALSE; while (TRUE) { needcmd=FALSE; cmdroot=NULL; cmdcur=cmdroot; cmdnew=NULL; stroot=NULL; if (nshell->deleted) { rcode = -1; break; } do { if ((rcode=getcmdline(nshell,&cmdnew,cmdroot,cline,&istr))!=0) break; if ((rcode=checkcmd(nshell,&cmdnew))!=0) break; if ((rcode=syntax(nshell,cmdnew,&needcmd,&stroot))!=0) break; if (cmdnew!=NULL) { if (cmdcur==NULL) cmdroot=cmdnew; else cmdcur->next=cmdnew; cmdcur=cmdnew; while (cmdcur->next!=NULL) cmdcur=cmdcur->next; cmdnew=NULL; } } while ((stroot!=NULL) || (needcmd)); if (rcode!=0) { cmdfree(cmdnew); cmdfree(cmdroot); cmdstackfree(stroot); if (nshell->quit) rcode=0; break; } else if (cmdroot!=NULL) { rcode=cmdexec(nshell,cmdroot,FALSE); cmdfree(cmdroot); if (nshell->quit) { rcode=0; break; } if (rcode!=0) break; } } nshell->quit=FALSE; return rcode; } void setshhandle(struct nshell *nshell,int fd) { nshell->fd=fd; nshell->readbyte=0; nshell->readpo=0; } static int storeshhandle(struct nshell *nshell,int fd, char **readbuf,int *readbyte,int *readpo) { int sfd; sfd=nshell->fd; *readbuf=nshell->readbuf; *readbyte=nshell->readbyte; *readpo=nshell->readpo; nshell->readbuf=g_malloc(SHELLBUFSIZE); nshell->readbyte=0; nshell->readpo=0; nshell->fd=fd; return sfd; } static void restoreshhandle(struct nshell *nshell,int fd, char *readbuf,int readbyte,int readpo) { g_free(nshell->readbuf); nshell->fd=fd; nshell->readbuf=readbuf; nshell->readbyte=readbyte; nshell->readpo=readpo; } int getshhandle(struct nshell *nshell) { return nshell->fd; } struct nshell * newshell(void) { struct nshell *nshell; char *name,**env,*tok; int i,len; nshell = g_malloc(sizeof(struct nshell)); if (nshell == NULL) return NULL; #if USE_HASH nshell->valroot = nhash_new(); nshell->exproot = nhash_new(); #else nshell->valroot = NULL; nshell->exproot = NULL; #endif env = MainEnviron; i=0; while (env && env[i]) { tok=env[i]; name=getitok2(&tok,&len,"="); if (tok[0]=='=') tok++; if (addval(nshell,name,tok)==NULL) { g_free(name); delshell(nshell); return NULL; } g_free(name); i++; } if ((getval(nshell,"PATH")==NULL) && (g_getenv("Path")!=NULL)) { const char *path; char *tmp; path = g_getenv("Path"); tmp = g_strdup(path); if (tmp) { addval(nshell,"PATH", tmp); g_free(tmp); } } nshell->argc=0; nshell->argv=NULL; nshell->cmdexec=0; nshell->status=0; nshell->quit=0; nshell->fd=stdinfd(); nshell->options=TRUE; nshell->optionf=FALSE; nshell->optione=TRUE; nshell->optionv=FALSE; nshell->optionx=FALSE; nshell->readbuf=g_malloc(SHELLBUFSIZE); nshell->readbyte=0; nshell->readpo=0; nshell->deleted = 0; return nshell; } static int del_vallist(struct nhash *h, void *data) { struct vallist *val; val = (struct vallist *) h->val.p; free_vallist(val); return 0; } void delshell(struct nshell *nshell) { #if ! USE_HASH struct vallist *valcur, *valdel; struct explist *expcur,*expdel; #endif if (nshell==NULL) return; #if USE_HASH nhash_each(nshell->valroot, del_vallist, NULL); nhash_free(nshell->valroot); #else valcur=nshell->valroot; while (valcur!=NULL) { g_free(valcur->name); if (valcur->func) cmdfree(valcur->val); else g_free(valcur->val); valdel=valcur; valcur=valcur->next; g_free(valdel); } #endif #if USE_HASH nhash_free(nshell->exproot); #else expcur=nshell->exproot; while (expcur!=NULL) { g_free(expcur->val); expdel=expcur; expcur=expcur->next; g_free(expdel); } #endif arg_del(nshell->argv); g_free(nshell->readbuf); g_free(nshell); return; } void sherror(int code) { printfstderr("shell: %.64s\n",cmderrorlist[code-100]); } void sherror2(int code,char *mes) { if (mes!=NULL) { printfstderr("shell: %.64s `%.64s'.\n",cmderrorlist[code-100],mes); } else { printfstderr("shell: %.64s.\n",cmderrorlist[code-100]); } } void sherror3(char *cmd,int code,char *mes) { cmd = CHK_STR(cmd); if (mes!=NULL) { printfstderr("shell: %.64s: %.64s `%.64s'.\n", cmd,cmderrorlist[code-100],mes); } else { printfstderr("shell: %.64s: %.64s.\n",cmd,cmderrorlist[code-100]); } } void sherror4(char *cmd,int code) { cmd = CHK_STR(cmd); printfstderr("shell: %.64s: %.64s\n",cmd,cmderrorlist[code-100]); } void shellsavestdio(struct nshell *nshell) { nshell->sgetstdin=getstdin; nshell->sputstdout=putstdout; nshell->sprintfstdout=printfstdout; getstdin=shgetstdin; putstdout=shputstdout; printfstdout=shprintfstdout; } void shellrestorestdio(struct nshell *nshell) { getstdin=nshell->sgetstdin; putstdout=nshell->sputstdout; printfstdout=nshell->sprintfstdout; } int setshelloption(struct nshell *nshell,char *opt) { int flag; if ((opt[0]!='-') && (opt[0]!='+')) return 1; if (opt[0]=='-') flag=TRUE; else flag=FALSE; switch (opt[1]) { case 's': nshell->options=flag; break; case 'e': nshell->optione=flag; break; case 'v': nshell->optionv=flag; break; case 'x': nshell->optionx=flag; break; case 'f': nshell->optionf=flag; break; default: sherror2(ERRILOPS,opt); return -1; } return 0; } int getshelloption(struct nshell *nshell,char opt) { switch (opt) { case 's': return nshell->options; case 'e': return nshell->optione; case 'v': return nshell->optionv; case 'x': return nshell->optionx; case 'f': return nshell->optionf; default: break; } return 0; } int set_shell_args(struct nshell *nshell, int j, const char *argv0, int argc, char **argv) { char *s, **argv2; int argc2; argv2 = NULL; s = g_strdup(argv0); if (s == NULL) { return ERRMEMORY; } if (arg_add(&argv2, s) == NULL) { g_free(s); arg_del(argv2); return ERRMEMORY; } for (; j < argc; j++) { if (argv[j]) { s = g_strdup(argv[j]); if (s == NULL) { return ERRMEMORY; } if (arg_add(&argv2, s) == NULL) { g_free(s); arg_del(argv2); return ERRMEMORY; } } } argc2 = getargc(argv2); arg_del(nshell->argv); nshell->argv = argv2; nshell->argc = argc2; return 0; } void setshellargument(struct nshell *nshell,int argc,char **argv) { arg_del(nshell->argv); nshell->argc=argc; nshell->argv=argv; } void ngraphenvironment(struct nshell *nshell) { char *sver,*lib,*home,*conf,*data,*addin; struct objlist *sobj; char *systemname; char *pathset; sobj=chkobject("system"); getobj(sobj,"name",0,0,NULL,&systemname); getobj(sobj,"conf_dir",0,0,NULL,&conf); getobj(sobj,"data_dir",0,0,NULL,&data); getobj(sobj,"lib_dir",0,0,NULL,&lib); getobj(sobj,"home_dir",0,0,NULL,&home); sver=getobjver("system"); addval(nshell,"NGRAPH",systemname); addval(nshell,"VERSION",sver); addval(nshell,"NGRAPHCONF",conf); addval(nshell,"NGRAPHLIB",lib); addval(nshell,"NGRAPHHOME",home); if (getval(nshell,"PS1")==NULL) addval(nshell,"PS1","Ngraph$ "); if (getval(nshell,"PS2")==NULL) addval(nshell,"PS2",">"); if (getval(nshell,"IFS")==NULL) addval(nshell,"IFS"," \t\n"); if (getval(nshell,"IGNOREEOF")==NULL) addval(nshell,"IGNOREEOF","10"); addin = g_strdup_printf("%s/addin", data); if (addin) { pathset = g_strdup_printf("PATH='%s%s%s%s%s%s%s%s'$PATH", home, PATHSEP, addin, PATHSEP, lib, PATHSEP, ".", PATHSEP); if (pathset) { #if WINDOWS path_to_win(pathset); #endif /* WINDOWS */ cmdexecute(nshell,pathset); g_free(pathset); } g_free(addin); } } int str_calc(const char *str, double *val, int *r, char **err_msg) { int ecode, rcode; static MathEquation *eq = NULL; MathValue value = {0, 0}; if (r) { *r = MATH_VALUE_ERROR; } if (err_msg) { *err_msg = NULL; } if (str == NULL || val == NULL) { return ERRMILLEGAL; } *val = 0; if (eq == NULL) { eq = math_equation_basic_new(); if (eq == NULL) { return ERRMEMORY; } } ecode = math_equation_parse(eq, str); if (ecode) { if (err_msg) { *err_msg = math_err_get_error_message(eq, str, ecode); } return ERRMSYNTAX; } rcode = math_equation_calculate(eq, &value); ecode = (rcode) ? ERRMFAT : 0; *val = value.val; if (value.type == MATH_VALUE_NAN || value.type == MATH_VALUE_UNDEF) { rcode = value.type; } if (ecode) { return ecode; } if (r) { *r = rcode; } return 0; } #if WINDOWS void show_system_error(void) { LPVOID *msg; FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (LPSTR) &msg, 0, NULL); shputstderr((char *)msg); LocalFree(msg); } static void * system_in_thread(void *ptr) { char *cmd; PROCESS_INFORMATION pi; STARTUPINFO si; int r; if (ptr == NULL) { return NULL; } cmd = (char *) ptr; ZeroMemory(&si, sizeof(si)); si.cb = sizeof(si); r = CreateProcess(NULL, cmd, NULL, NULL, TRUE, NORMAL_PRIORITY_CLASS, NULL, NULL, &si, &pi); if (r == 0) { show_system_error(); return NULL; } CloseHandle(pi.hThread); WaitForSingleObject(pi.hProcess, INFINITE); CloseHandle(pi.hProcess); g_free(cmd); return NULL; } #endif /* WINDOWS */ int system_bg(char *cmd) { #if WINDOWS GThread *thread; char *ptr; if (cmd == NULL) return 1; ptr = g_locale_from_utf8(cmd, -1, NULL, NULL, NULL); #if GLIB_CHECK_VERSION(2, 32, 0) thread= g_thread_new("process", system_in_thread, ptr); #else thread = g_thread_create(proc_in_thread, cmd, TRUE, NULL); thread = g_thread_create(system_in_thread, ptr, FALSE, NULL); #endif if (thread == NULL) { return 1; } #if GLIB_CHECK_VERSION(2, 32, 0) g_thread_unref(thread); #endif return 0; #else /* WINDOWS */ if (cmd == NULL) return 1; return ! g_spawn_command_line_async(cmd, NULL); #endif /* WINDOWS */ } ngraph-gtk-6.08.00/src/oprm.c0000644000175000017500000014210713337723153012574 00000000000000/* * $Id: oprm.c,v 1.14 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include "strconv.h" #include "mathfn.h" #include "ntime.h" #include "object.h" #include "gra.h" #include "ioutil.h" #include "odraw.h" #include "odata.h" #include "opath.h" #define NAME "prm" #define PARENT "object" #define OVERSION "1.00.00" #define ERROPEN 100 #define ERRREAD 101 #define ERRPRM 102 #define ERREXIST 103 static char *prmerrorlist[]={ "I/O error: open file", "I/O error: read file", "unsupported PRM file", "skip existing file", }; #define ERRNUM (sizeof(prmerrorlist) / sizeof(*prmerrorlist)) static int prminit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int prmdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static char * pathconv(char *str,int ignorepath) { int i; char *file, *s; if (str==NULL) return NULL; if (str[0]=='\0') return NULL; s = sjis_to_utf8(str); if (s == NULL) { return NULL; } g_free(str); if (ignorepath) { file=getbasename(s); g_free(s); } else { file=s; } changefilename(file); for (i=0;file[i]!='\0';i++) { file[i]=tolower(file[i]); } return file; } static struct narray *linestyleconv(int attr,int dottedsize) { int i,dt[4],num; struct narray *array; if (attr==1) { dt[0]=dottedsize*10; dt[1]=dottedsize*10; num=2; } else if (attr==2) { dt[0]=dottedsize*30; dt[1]=dottedsize*10; num=2; } else if (attr==3) { dt[0]=dottedsize*30; dt[1]=dottedsize*10; dt[2]=dottedsize*10; dt[3]=dottedsize*10; num=4; } else { return NULL; } array=arraynew(sizeof(int)); for (i=0;i %F{} %d ---> %{system:0:date:1} %01C0101 ---> %{file:01:column:01 01} */ { int i,j,fchange[2],jchange[2],script,fff[2],ffj[2],ffb[2]; char *s2, *s; int file,line,col; s = sjis_to_utf8(str); if (s == NULL) { return NULL; } s2 = g_malloc(strlen(s) + 200); if (s2 == NULL) { return NULL; } j=0; script=0; for (i=0;i<2;i++) { fff[i]=ff; ffj[i]=fj; ffb[i]=fb; fchange[i]=FALSE; jchange[i]=FALSE; } for (i=0;s[i]!='\0';i++) { if ((s[i]=='\\') && (s[i+1]!='\0')) { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); s2[j]=s[i]; s2[j+1]=s[i+1]; i++; j+=2; } else if (s[i]=='%') { if ((toupper(s[i+1])=='S') && isdigit(s[i+2]) && isdigit(s[i+3])) { s2[j]=s[i]; s2[j+1]=s[i+1]; s2[j+2]='{'; s2[j+3]=s[i+2]; s2[j+4]=s[i+3]; s2[j+5]='}'; i+=3; j+=6; } else if ((strchr("PXYpxy",s[i+1])!=NULL) && ((s[i+2]=='+') || (s[i+2]=='-')) && isdigit(s[i+3]) && isdigit(s[i+4])) { s2[j]=s[i]; s2[j+1]=s[i+1]; s2[j+2]='{'; s2[j+3]=s[i+2]; s2[j+4]=s[i+3]; s2[j+5]=s[i+4]; s2[j+6]='}'; i+=4; j+=7; } else if ((toupper(s[i+1])=='F') && (strchr("THCthc",s[i+2])!=NULL)) { fchange[script]=TRUE; if (toupper(s[i+2]=='T')) fff[script]=FONT_TYPE_SERIF; else if (toupper(s[i+2]=='H')) fff[script]=FONT_TYPE_SANS_SERIF; else if (toupper(s[i+2]=='C')) fff[script]=FONT_TYPE_MONOSPACE; i+=2; } else if ((toupper(s[i+1])=='J') && (strchr("GMgm",s[i+2])!=NULL)) { jchange[script]=TRUE; if (toupper(s[i+2]=='M')) ffj[script]=0; else if (toupper(s[i+2]=='G')) ffj[script]=1; i+=2; } else if (toupper(s[i+1])=='R') { fchange[script]=TRUE; ffb[script]=FONT_STYLE_NORMAL; i++; } else if (toupper(s[i+1])=='B') { fchange[script]=TRUE; ffb[script]=FONT_STYLE_BOLD; i++; } else if (toupper(s[i+1])=='I') { fchange[script]=TRUE; ffb[script]=FONT_STYLE_ITALIC; i++; } else if (toupper(s[i+1])=='O') { fchange[script]=TRUE; ffb[script]=(FONT_STYLE_BOLD | FONT_STYLE_ITALIC); i++; } else if (s[i+1]=='d') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{system:0:date:1}"); i++; } else if (s[i+1]=='D') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{system:0:date:0}"); i++; } else if (s[i+1]=='t') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{system:0:time:2}"); i++; } else if (s[i+1]=='t') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{system:0:time:3}"); i++; } else if (toupper(s[i+1])=='M') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%s",prmfile); i++; } else if ((toupper(s[i+1])=='C') && isdigit(s[i+2])) { i+=2; } else if (isdigit(s[i+1]) && isdigit(s[i+2])) { file=(s[i+1]-'0')*10+(s[i+2]-'0')-1; if (file==-1) file=0; if (toupper(s[i+3])=='N') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); if (file<20) { if (s[i+3]=='N') j+=sprintf(s2+j,"%%{file:%d:file}",fnameid[file]); else j+=sprintf(s2+j,"%%{file:%d:basename}",fnameid[file]); } i+=3; } else if (s[i+3]=='d') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{file:%d:date:1}",fnameid[file]); i+=3; } else if (s[i+3]=='D') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{file:%d:date:0}",fnameid[file]); i+=3; } else if (s[i+3]=='t') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{file:%d:time:4}",fnameid[file]); i+=3; } else if (s[i+3]=='t') { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); j+=sprintf(s2+j,"%%{system:%d:time:3}",fnameid[file]); i+=3; } else if ((toupper(s[i+3])=='C') && isdigit(s[i+4]) && isdigit(s[i+5]) && isdigit(s[i+6]) && isdigit(s[i+7])) { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); line=(s[i+4]-'0')*10+(s[i+5]-'0'); col=(s[i+6]-'0')*10+(s[i+7]-'0'); if (file<20) j+=sprintf(s2+j,"%%{file:%d:column:%d %d}", fnameid[file],line,col); i+=7; } } } else { addfontcontrol(s2,&j,fchange,jchange,fff,ffb,ffj,script); if ((s[i]=='^') || (s[i]=='_')) { script=1; } else if (s[i]=='@') { script=0; } s2[j]=s[i]; j++; } } s2[j]='\0'; g_free(s); return s2; } static char * mathconv(char *math) /* INTEG ---> SUM F(,) ---> F(,,) NAN ---> CONT UNDEF ---> BREAK */ { int i,j; int f,g,fb[50],gb[50]; char *m; if ((m=g_malloc(strlen(math)+100))==NULL) return NULL; j=0; f=g=0; for (i=0;math[i]!='\0';i++) { if (strncmp(math+i,"NAN",3)==0) { strcpy(m+j,"CONT"); i+=2; j+=4; } else if (strncmp(math+i,"NONE",3)==0) { strcpy(m+j,"BREAK"); i+=3; j+=5; } else if (strncmp(math+i,"INTEG",5)==0) { strcpy(m+j,"SUM"); i+=4; j+=3; } else if (strncmp(math+i,"DIF(",4)==0) { strcpy(m+j,"DIF"); i+=2; j+=3; } else if (strncmp(math+i,"IF(",3)==0) { strcpy(m+j,"IF"); i++; j+=2; } else if (strncmp(math+i,"LOG(",4)==0) { strcpy(m+j,"LOG"); i+=2; j+=3; } else if (strncmp(math+i,"F(",2)==0) { f++; fb[f]=0; } else if (strncmp(math+i,"G(",2)==0) { g++; gb[g]=0; } else if (math[i]=='(') { if (f) fb[f]++; if (g) gb[f]++; m[j]=math[i]; j++; } else if (math[i]==')') { if (f) { fb[f]--; if (fb[f]==0) { m[j]=','; m[j+1]='0'; f--; j+=2; } } if (g) { gb[g]--; if (gb[g]==0) { m[j]=','; m[j+1]='0'; g--; j+=2; } } m[j]=math[i]; j++; } else if ((math[i]!=' ') && (math[i]!='\t')) { m[j]=math[i]; j++; } } m[j]='\0'; if (m[0]=='\0') { g_free(m); m=NULL; } return m; } #define BUFSIZE 512 static int prmloadline(struct objlist *obj,char *file,FILE *fp,char *buf,int err) { if (fgetnline(fp,buf,BUFSIZE)) { if (err) error2(obj,ERRREAD,file); return -1; } return 0; } static int sscanf2(char *buffer,char *format,...) { va_list ap; int i,num; int *d; double *e; char *s; char *endptr; va_start(ap,format); s=buffer; num=0; i=0; while (format[i]!='\0') { if (format[i]=='d') { d=va_arg(ap,int *); *d=strtol(s,&endptr,10); num++; if (endptr[0]=='\0') break; s=endptr; } else if (format[i]=='e') { e=va_arg(ap,double *); *e=strtod(s,&endptr); num++; if (endptr[0]=='\0') break; s=endptr; } i++; } va_end(ap); return num; } static int gettimeval2(char *s,time_t *time) { char *endptr; struct tm tm; tm.tm_year=strtol(s,&endptr,10)-1900; if (endptr[0]!='-') return -1; s=endptr+1; tm.tm_mon=strtol(s,&endptr,10)-1; if (endptr[0]!='-') return -1; s=endptr+1; tm.tm_mday=strtol(s,&endptr,10); if (endptr[0]!=' ') return -1; s=endptr+1; tm.tm_hour=strtol(s,&endptr,10); if (endptr[0]!=':') return -1; s=endptr+1; tm.tm_min=strtol(s,&endptr,10); if (endptr[0]!=':') return -1; s=endptr+1; tm.tm_sec=strtol(s,&endptr,10); tm.tm_isdst=0; *time=mktime(&tm); return 0; } char buf[BUFSIZE]; char buf2[BUFSIZE]; static int prmload(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; FILE *fp,*fp2; int i,j,k,filetype,num,ignorepath; struct objlist *fobj,*fitobj,*aobj,*agdobj; struct objlist *pobj,*mobj,*tobj,*robj; struct objlist *mgobj,*gobj,*cmobj; int fid,fidroot,fitid,aid,agdid,lid,pid,mid,tid,rid,cid; int mgid,gid,cmid; char *s,*s2; int d1,d2,d3,d4,d5,d6,d7,d8,d9,d10,R,G,B,gx[11],gy[11]; double f1,f2,f3,f4; int type,intp,mark,fittype; struct narray *iarray; int graphtype,vx,vy,szx,szy,dmode[3]; int fff[7],ffj[7],ffb[7],ffs[7],ffp[7],ffR[7],ffG[7],ffB[7]; char *argv2[5]; int anameid[4],anameoid[4]; int fitnameid[20],nameid; int fnameid[20]; int masknum,movenum; struct narray *mask,*move,*movex,*movey; double datax,datay,data2,data3; int statx,staty,stat2,stat3,line,plottype; char str4[5],*endptr; int hiddenaxis[4]; int setaxis[4],sccros[4]; int scnum,scstart,scstep,sczero,scplus,scposs,scpose; int scdir,sclr,sclog,scposx,scposy,scfull; char scfig[5]; int la0,la1,la2,la3,la4,lw0,lw1,lw2,lw3,lw4,lc0,lc1,lc4; int ll1,ll2,ll3; double amax,amin,ainc; int atype,aid2[4],posx,posy; char format[10],*EOD; char *filename; time_t ftime; struct utimbuf tm; int mkdata; struct narray group; int gtype; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"file",inst,&file); _getobj(obj,"ignore_path",inst,&ignorepath); str4[4]='\0'; if ((fobj=getobject("data"))==NULL) return 1; if ((fitobj=getobject("fit"))==NULL) return 1; if ((aobj=getobject("axis"))==NULL) return 1; if ((agdobj=getobject("axisgrid"))==NULL) return 1; if ((pobj=getobject("path"))==NULL) return 1; if ((mobj=getobject("mark"))==NULL) return 1; if ((robj=getobject("rectangle"))==NULL) return 1; if ((tobj=getobject("text"))==NULL) return 1; if ((mgobj=getobject("merge"))==NULL) return 1; if ((gobj=getobject("gra"))==NULL) return 1; if (file==NULL) return 0; if ((fp=nfopen(file,"rt"))==NULL) { error2(obj,ERROPEN,file); return 1; } if (prmloadline(obj,file,fp,buf,TRUE)!=0) goto errexit; if (strcmp(buf," Ngraph ver 5.2 PRM file")==0) filetype=2; else if (strcmp(buf," Ngraph ver. 5.3 PRM file")==0) filetype=3; else if (strcmp(buf," Ngraph ver 5.2 DPM file")==0) filetype=12; else if (strcmp(buf," Ngraph ver. 5.3 DPM file")==0) filetype=13; else { error2(obj,ERRPRM,file); goto errexit; } if (prmloadline(obj,file,fp,buf,TRUE)!=0) goto errexit; if (sscanf2(buf,"%d",(int *)&num)!=1) { error2(obj,ERRPRM,file); goto errexit; } anameid[0]=anameid[1]=anameid[2]=anameid[3]=-1; anameoid[0]=anameoid[1]=anameoid[2]=anameoid[3]=-1; /* FilePar */ for (i=0;i=26) { if ((rid=newobj(robj))==-1) goto errexit; putobj(robj,"x1",rid,&(gx[0])); putobj(robj,"y1",rid,&(gy[0])); putobj(robj,"x2",rid,&(gx[1])); putobj(robj,"y2",rid,&(gy[1])); if ((d3==26) || (d3==27)) d10=TRUE; else d10=FALSE; putobj(robj,"fill",rid,&d10); cmid=rid; cmobj=robj; if (d3==26) { d10 = FALSE; putobj(robj,"stroke",rid,&d10); } } else { if ((mid=newobj(mobj))==-1) goto errexit; putobj(mobj,"x",mid,&(gx[0])); putobj(mobj,"y",mid,&(gy[0])); if ((d3==5) || (d3==6)) type=0; else if (d3==7) type=1; else if (d3==8) type=2; else if (d3==9) type=3; else if (d3==10) type=80; else if (d3==11) type=10; else if (d3==12) type=11; else if (d3==13) type=12; else if (d3==14) type=20; else if (d3==15) type=21; else if (d3==16) type=22; else if (d3==17) type=30; else if (d3==18) type=31; else if (d3==19) type=32; else if (d3==20) type=40; else if (d3==21) type=41; else if (d3==22) type=42; else if (d3==23) type=70; else if (d3==24) type=71; putobj(mobj,"type",mid,&type); d6*=10; if (d3==5) d6/=2; putobj(mobj,"size",mid,&d6); cmobj=mobj; cmid=mid; } if ((d3<=3) || (d3==25)) { if ((iarray=arraynew(sizeof(int)))==NULL) goto errexit; for (j=0;j1)) { if ((s=g_malloc(30))==NULL) goto errexit; if (i==2) sprintf(s,"axis:^%d",anameoid[0]); else sprintf(s,"axis:^%d",anameoid[1]); putobj(aobj,"reference",aid,s); } putobj(aobj,"type",aid,&atype); putobj(aobj,"x",aid,&d1); putobj(aobj,"y",aid,&d2); putobj(aobj,"direction",aid,&d3); putobj(aobj,"length",aid,&d4); iarray=linestyleconv(la0,15); putobj(aobj,"style",aid,iarray); R=(lc0 & 4)?255:0; G=(lc0 & 2)?255:0; B=(lc0 & 1)?255:0; putobj(aobj,"R",aid,&R); putobj(aobj,"G",aid,&G); putobj(aobj,"B",aid,&B); putobj(aobj,"width",aid,&lw0); if ((graphtype==1) || ((i<=1) && (graphtype==2))) { d1=0; if ((i==0) || (i==3)) { if (scdir==0) d1=2; else if (scdir==1) d1=3; else if (scdir==2) d1=1; } else { if (scdir==0) d1=3; else if (scdir==1) d1=2; else if (scdir==2) d1=1; } putobj(aobj,"gauge",aid,&d1); iarray=linestyleconv(la4,15); putobj(aobj,"gauge_style",aid,iarray); R=(lc4 & 4)?255:0; G=(lc4 & 2)?255:0; B=(lc4 & 1)?255:0; putobj(aobj,"gauge_R",aid,&R); putobj(aobj,"gauge_G",aid,&G); putobj(aobj,"gauge_B",aid,&B); putobj(aobj,"gauge_width1",aid,&lw4); putobj(aobj,"gauge_width2",aid,&lw4); putobj(aobj,"gauge_width3",aid,&lw4); ll1*=10; ll2*=10; ll3*=10; putobj(aobj,"gauge_length1",aid,&ll1); putobj(aobj,"gauge_length2",aid,&ll2); putobj(aobj,"gauge_length3",aid,&ll3); } if ((i<=1) || ((i>=2) && (graphtype==1))) { putobj(aobj,"num_num",aid,&scnum); putobj(aobj,"num_begin",aid,&scstart); putobj(aobj,"num_step",aid,&scstep); if (sclog==0) sclog=FALSE; else sclog=TRUE; putobj(aobj,"num_log_pow",aid,&sclog); if (sclr==0) sclr=3; else if (sclr==1) sclr=2; else if (sclr==2) sclr=0; else if (sclr==3) sclr=1; putobj(aobj,"num_align",aid,&sclr); if (i==0){ d1=2; posx=scposx*10; posy=scposy*10; } else if (i==1) { d1=1; posy=-scposx*10; posx=-scposy*10; } else if (i==2) { d1=1; posx=scposx*10; posy=-scposy*10; } else if (i==3) { d1=2; posy=scposx*10; posx=-scposy*10; } putobj(aobj,"num",aid,&d1); putobj(aobj,"num_shift_p",aid,&posx); putobj(aobj,"num_shift_n",aid,&posy); j=0; format[j++]='%'; if (scplus) format[j++]='+'; if (sczero) { format[j++]=scfig[0]; format[j++]=scfig[1]; format[j++]=scfig[2]; format[j++]='f'; } else format[j++]='g'; format[j]='\0'; if ((s=g_malloc(strlen(format)+1))==NULL) goto errexit; strcpy(s,format); putobj(aobj,"num_format",aid,s); if ((s=g_malloc(strlen(fontchar[fff[3+i]])+1))==NULL) goto errexit; strcpy(s,fontchar[fff[3+i]]); putobj(aobj,"num_font",aid,s); putobj(aobj,"num_font_style",aid,&(ffb[3+i])); putobj(aobj,"num_pt",aid,&(ffs[3+i])); putobj(aobj,"num_space",aid,&(ffp[3+i])); putobj(aobj,"num_R",aid,&(ffR[3+i])); putobj(aobj,"num_G",aid,&(ffG[3+i])); putobj(aobj,"num_B",aid,&(ffB[3+i])); } if (hiddenaxis[i]) { d1=0; putobj(aobj,"baseline",aid,&d1); putobj(aobj,"gauge",aid,&d1); putobj(aobj,"num",aid,&d1); } } if (graphtype==0) { if ((agdid=newobj(agdobj))==-1) goto errexit; if ((s=g_malloc(30))==NULL) goto errexit; sprintf(s,"axis:^%d",anameoid[0]); putobj(agdobj,"axis_x",agdid,s); if ((s=g_malloc(30))==NULL) goto errexit; sprintf(s,"axis:^%d",anameoid[1]); putobj(agdobj,"axis_y",agdid,s); iarray=linestyleconv(la1,15); putobj(agdobj,"style1",agdid,iarray); iarray=linestyleconv(la2,15); putobj(agdobj,"style2",agdid,iarray); iarray=linestyleconv(la3,15); putobj(agdobj,"style3",agdid,iarray); R=(lc1 & 4)?255:0; G=(lc1 & 2)?255:0; B=(lc1 & 1)?255:0; putobj(agdobj,"R",agdid,&R); putobj(agdobj,"G",agdid,&G); putobj(agdobj,"B",agdid,&B); putobj(agdobj,"width1",agdid,&lw1); putobj(agdobj,"width2",agdid,&lw2); putobj(agdobj,"width3",agdid,&lw3); gtype=2; arrayinit(&group,sizeof(int)); arrayadd(&group,>ype); arrayadd(&group,&aid2[0]); arrayadd(&group,&aid2[1]); arrayadd(&group,&aid2[2]); arrayadd(&group,&aid2[3]); argv2[0]=(void *)&group; argv2[1]=NULL; exeobj(aobj,"grouping",aid2[3],1,argv2); arraydel(&group); } else if (graphtype==1) { gtype=1; arrayinit(&group,sizeof(int)); arrayadd(&group,>ype); arrayadd(&group,&aid2[0]); arrayadd(&group,&aid2[1]); arrayadd(&group,&aid2[2]); arrayadd(&group,&aid2[3]); argv2[0]=(void *)&group; argv2[1]=NULL; exeobj(aobj,"grouping",aid2[3],1,argv2); arraydel(&group); } else if (graphtype==2) { if ((s=g_malloc(30))==NULL) goto errexit; sprintf(s,"axis:^%d",anameoid[1]); putobj(aobj,"adjust_axis",aid2[0],s); putobj(aobj,"adjust_position",aid2[0],&sccros[1]); exeobj(aobj,"adjust",aid2[0],0,NULL); if ((s=g_malloc(30))==NULL) goto errexit; sprintf(s,"axis:^%d",anameoid[0]); putobj(aobj,"adjust_axis",aid2[1],s); putobj(aobj,"adjust_position",aid2[1],&sccros[0]); exeobj(aobj,"adjust",aid2[1],0,NULL); if (aid2[2]>aid2[3]) { delobj(aobj,aid2[2]); delobj(aobj,aid2[3]); } else { delobj(aobj,aid2[3]); delobj(aobj,aid2[2]); } gtype=3; arrayinit(&group,sizeof(int)); arrayadd(&group,>ype); arrayadd(&group,&aid2[0]); arrayadd(&group,&aid2[1]); argv2[0]=(void *)&group; argv2[1]=NULL; exeobj(aobj,"grouping",aid2[1],1,argv2); arraydel(&group); } /* Merge */ for (i=0;i<10;i++) { if (prmloadline(obj,file,fp,buf,TRUE)!=0) goto errexit; if (strlen(buf)!=0) { if ((mgid=newobj(mgobj))==-1) goto errexit; if ((s=g_malloc(strlen(buf)+1))==NULL) goto errexit; strcpy(s,buf); s=pathconv(s,ignorepath); putobj(mgobj,"file",mgid,s); if (prmloadline(obj,file,fp,buf,TRUE)!=0) goto errexit; if (sscanf2(buf,"%d%d%d",(int *)&d1,(int *)&d2,(int *)&d3)!=3) { error2(obj,ERRPRM,file); goto errexit; } d1*=10; d2*=10; d3=nround(d3/0.21); putobj(mgobj,"left_margin",mgid,&d1); putobj(mgobj,"top_margin",mgid,&d2); putobj(mgobj,"zoom",mgid,&d3); putobj(mgobj,"hidden",mgid,&(dmode[2])); } else { if (prmloadline(obj,file,fp,buf,TRUE)!=0) goto errexit; } } EOD="\n[EOF]\n"; if ((filetype==12) || (filetype==13)) { while (prmloadline(obj,file,fp,buf,FALSE)==0) { if (buf[0]=='[') { if ((s2=strchr(buf,']'))!=NULL) { int ch; if ((filename=g_malloc(s2-buf))==NULL) goto errexit; strncpy(filename,buf+1,s2-buf-1); filename[s2-buf-1]='\0'; filename=pathconv(filename,ignorepath); if (naccess(filename,R_OK)!=0) mkdata=TRUE; else { sprintf(buf2,"`%s' Overwrite existing file?",filename); mkdata=inputyn(buf2); } if (mkdata) { if ((fp2=nfopen(filename,"wt"))==NULL) { error2(obj,ERROPEN,filename); goto errexit; } } i=0; do { ch=nfgetc(fp); if (ch==EOD[i]) i++; else { if (mkdata) for (j=0;j #include #include #include #include #include "object.h" #include "nstring.h" #include "ntime.h" #include "mathfn.h" char *weekstr[7]={"Sun","Mon","Tue","Wed","Thu","Fri","Sat"}; char *monthstr[12]={"Jan","Feb","Mar","Apr","May","Jun", "Jul","Aug","Sep","Oct","Nov","Dec"}; char * ndate(time_t *timep,int style) { struct tm *ltime; char *c; ltime=localtime(timep); if (ltime == NULL) { return NULL; } switch (style) { case 1: c = g_strdup_printf("%d-%d-%d", ltime->tm_mon + 1, ltime->tm_mday, 1900 + ltime->tm_year); break; case 2: c = g_strdup_printf("%s %d %d", monthstr[ltime->tm_mon], ltime->tm_mday, 1900 + ltime->tm_year); break; case 3: c = g_strdup_printf("%d-%d-%d", ltime->tm_mday, ltime->tm_mon + 1, 1900 + ltime->tm_year); break; case 4: c = g_strdup_printf("%d/%d/%d", ltime->tm_mon + 1, ltime->tm_mday, 1900 + ltime->tm_year); break; default: c = g_strdup_printf("%s %s %d %d", weekstr[ltime->tm_wday], monthstr[ltime->tm_mon], ltime->tm_mday, 1900 + ltime->tm_year); break; } return c; } char * ntime(time_t *timep,int style) { struct tm *ltime; char *c; ltime=localtime(timep); if (ltime == NULL) { return NULL; } switch (style) { case 1: if (ltime->tm_hour<12) c = g_strdup_printf("%02d:%02d:%02d am", ltime->tm_hour, ltime->tm_min, ltime->tm_sec); else c = g_strdup_printf("%02d:%02d:%02d pm", ltime->tm_hour - 12, ltime->tm_min, ltime->tm_sec); break; case 2: c = g_strdup_printf("%02d:%02d", ltime->tm_hour, ltime->tm_min); break; case 3: if (ltime->tm_hour<12) { c = g_strdup_printf("%02d:%02d am", ltime->tm_hour, ltime->tm_min); } else { c = g_strdup_printf("%02d:%02d pm", ltime->tm_hour - 12, ltime->tm_min); } break; default: c = g_strdup_printf("%02d:%02d:%02d", ltime->tm_hour, ltime->tm_min, ltime->tm_sec); break; } return c; } int gettimeval(char *s,time_t *time) { char *endptr; struct tm tm; int year; tm.tm_mday=strtol(s,&endptr,10); if (endptr[0]!='-') return -1; s=endptr+1; tm.tm_mon=strtol(s,&endptr,10)-1; if (endptr[0]!='-') return -1; s=endptr+1; year=strtol(s,&endptr,10)-1900; if (year<0) year+=1900; tm.tm_year=year; if (endptr[0]!=' ') return -1; s=endptr+1; tm.tm_hour=strtol(s,&endptr,10); if (endptr[0]!=':') return -1; s=endptr+1; tm.tm_min=strtol(s,&endptr,10); if (endptr[0]!=':') return -1; s=endptr+1; tm.tm_sec=strtol(s,&endptr,10); tm.tm_isdst=0; *time=mktime(&tm); return 0; } void mjd2gd(double mjd, struct tm *tm) { double t; int wd, sec; /* Date */ #if 1 /* http://en.wikipedia.org/wiki/Julian_day */ int j, g, dg, c, dc, b, db, a, da, y, m, d, Y, M, D; j = floor(mjd + 2400001 + 32044); g = j / 146097; dg = j % 146097; c = (dg / 36524 + 1) * 3 / 4; dc = dg - c * 36524; b = dc / 1461; db = dc % 1461; a = (db / 365 + 1) * 3 / 4; da = db - a * 365; y = g * 400 + c * 100 + b * 4 + a; m = (da * 5 + 308) / 153 - 2; d = da - (m + 4) * 153 / 5 + 122; Y = y - 4800 + (m + 2) / 12; M = (m + 2) % 12 + 1; D = d + 1; #else /* http://www.astro.uu.nl/~strous/AA/en/reken/juliaansedag.html */ double x0, x1, x2, c1, c2; int Y, M, D, da; x2 = floor(mjd) + (2400000.5 - 1721119.5); c2 = floor((4 * x2 + 3) / 146097.0); x1 = x2 - floor(146097 * c2 / 4.0); c1 = floor((100 * x1 + 99) / 36525.0); x0 = x1 - floor(36525 * c1 / 100.0); Y = 100 * c2 + c1; M = floor((5 * x0 + 461) / 153.0); D = x0 - floor((153 * M - 457) / 5.0) + 1; if (M > 12) { M -= 12; Y += 1; } da = floor(x0); #endif wd = floor(mjd) + 2400000 + 2; wd %= 7; tm->tm_year = Y - 1900; tm->tm_mon = M - 1; tm->tm_mday = D; tm->tm_wday = wd; if (Y % 400 == 0) { da += 60; da %= 366; } else if (Y % 100 == 0) { da += 59; da %= 365; } else if (Y % 4 == 0) { da += 60; da %= 366; } else { da += 59; da %= 365; } tm->tm_yday = da; /* Time */ t = fmod(mjd, 1); t = (t < 0) ? 1 + t : t; sec = nround(t * 86400); tm->tm_hour = sec / 3600; sec %= 3600; tm->tm_min = sec / 60; sec %= 60; tm->tm_sec = sec; tm->tm_isdst = -1; } static int get_iso_8601_week(struct tm *t) { int y, w, a, b, c, x; w = t->tm_wday; a = t->tm_yday % 7; b = (w > a) ? w - a : 7 + w - a; c = (b == 0) ? 6 : b -1; x = (t->tm_yday + c) / 7; y = (b + 3) % 7; if (y > 4 || y == 0) { x += 1; } if ((t->tm_yday == 0 && (w == 5 || w == 6 || w == 0)) || (t->tm_yday == 1 && (w == 6 || w == 0)) || (t->tm_yday == 2 && w == 0)) { x = 53; } else if (t->tm_mon == 11) { if ((t->tm_mday == 31 && (w == 1 || w == 2 || w == 3)) || (t->tm_mday == 30 && (w == 1 || w == 2)) || (t->tm_mday == 29 && w == 1)) { x = 1; } } return x; } static int append_date_str(GString *str, const gchar *fmt, struct tm *t) { const char *wfname[]={"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}; const char *mfname[]={"January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"}; int y, m, d, w, h24, h12, mm, s, a, b, c, x; if (fmt == NULL || *fmt == '\0') { return 0; } if (t == NULL || t->tm_mon < 0 || t->tm_mon > 11 || t->tm_wday < 0 || t->tm_wday > 6) { return 1; } y = t->tm_year + 1900; m = t->tm_mon + 1; d = t->tm_mday; w = t->tm_wday; h24 = t->tm_hour; if (h24 == 0) { h12 = 12; } else if (h24 > 12) { h12 = h24 - 12; } else { h12 = h24; } mm = t->tm_min; s = t->tm_sec; switch (*fmt) { case 'a': g_string_append_printf(str, "%s", weekstr[w]); break; case 'A': g_string_append_printf(str, "%s", wfname[w]); break; case 'b': case 'h': g_string_append_printf(str, "%s", monthstr[m - 1]); break; case 'B': g_string_append_printf(str, "%s", mfname[m - 1]); break; case 'c': g_string_append_printf(str, "%s %s % 2d %02d:%02d:%02d %d", weekstr[w], monthstr[m - 1], d, h24, mm, s, y); break; case 'C': g_string_append_printf(str, "%d", y / 100); break; case 'd': g_string_append_printf(str, "%02d", d); break; case 'D': case 'x': g_string_append_printf(str, "%02d/%02d/%02d", m, d, y % 100); break; case 'e': g_string_append_printf(str, "% 2d", d); break; case 'F': g_string_append_printf(str, "% 4d-%02d-%02d", y, m, d); break; case 'G': x = get_iso_8601_week(t); if (m == 1 && x == 53) { y -= 1; } else if (m == 12 && x == 1) { y += 1; } g_string_append_printf(str, "% 4d", y); break; case 'g': x = get_iso_8601_week(t); if (m == 1 && x == 53) { y -= 1; } else if (m == 12 && x == 1) { y += 1; } g_string_append_printf(str, "%02d", y % 100); break; case 'H': g_string_append_printf(str, "%02d", h24); break; case 'I': g_string_append_printf(str, "%02d", h12); break; case 'j': g_string_append_printf(str, "%03d", t->tm_yday + 1); break; case 'k': g_string_append_printf(str, "% 2d", h24); break; case 'l': g_string_append_printf(str, "% 2d", h12); break; case 'm': g_string_append_printf(str, "%02d", m); break; case 'M': g_string_append_printf(str, "%02d", mm); break; case 'n': g_string_append_c(str, '\n'); break; case 'p': g_string_append(str, (h24 > 11) ? "PM" : "AM"); break; case 'P': g_string_append(str, (h24 > 11) ? "pm" : "am"); break; case 'r': g_string_append_printf(str, "%02d:%02d:%02d %s", h12, mm, s, (h24 > 11) ? "PM" : "AM"); break; case 'R': g_string_append_printf(str, "%02d:%02d", h24, mm); break; case 's': break; case 'S': g_string_append_printf(str, "%02d", s); break; case 't': g_string_append_c(str, '\t'); break; case 'T': case 'X': g_string_append_printf(str, "%02d:%02d:%02d", h24, mm, s); break; case 'u': g_string_append_printf(str, "%d", (w == 0) ? 7 : w); break; case 'U': a = t->tm_yday % 7; b = (w > a) ? w - a : 7 + w - a; c = (b == 0) ? 7 : b; g_string_append_printf(str, "%02d", (t->tm_yday + c)/ 7); break; case 'V': x = get_iso_8601_week(t); g_string_append_printf(str, "%02d", x); break; case 'w': g_string_append_printf(str, "%d", w); break; case 'W': a = t->tm_yday % 7; b = (w > a) ? w - a : 7 + w - a; c = (b == 0) ? 6 : b -1; g_string_append_printf(str, "%02d", (t->tm_yday + c) / 7); break; case 'y': g_string_append_printf(str, "%02d", y % 100); break; case 'Y': g_string_append_printf(str, "%d", y); break; case 'z': g_string_append(str, "+0000"); break; case 'Z': g_string_append(str, "GMT"); break; case '+': g_string_append_printf(str, "%s %s % 2d %02d:%02d:%02d GMT %d", weekstr[w], monthstr[m - 1], d, h24, mm, s, y); break; case '%': default: g_string_append_c(str, *fmt); } return 1; } char * nstrftime(const gchar *fmt, double mjd) { GString *str; struct tm t; int n; if (fmt == NULL || fmt[0] == '\0') { return NULL; } mjd2gd(mjd, &t); str = g_string_sized_new(64); while (*fmt) { switch (*fmt) { case '%': fmt++; while (*fmt == 'O' || *fmt == 'E') { fmt++; } n = append_date_str(str, fmt, &t); fmt += n; break; default: g_string_append_c(str, *fmt); fmt++; } } return g_string_free(str, FALSE); } ngraph-gtk-6.08.00/src/opath.h0000644000175000017500000000015413226510226012722 00000000000000#ifndef OPATH_HEADER #define OPATH_HEADER enum PATH_TYPE { PATH_TYPE_LINE, PATH_TYPE_CURVE, }; #endif ngraph-gtk-6.08.00/src/oshell.c0000644000175000017500000001223113070106167013071 00000000000000/* * $Id: oshell.c,v 1.9 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include "object.h" #include "ioutil.h" #include "shell.h" #define NAME "shell" #define PARENT "object" #define OVERSION "1.00.00" #define MAXCLINE 256 #define ERRRUN 100 #define ERRNOCL 101 #define ERRFILEFIND 102 static char *sherrorlist[]={ "already running.", "no command string is specified.", "no such file", }; #define ERRNUM (sizeof(sherrorlist) / sizeof(*sherrorlist)) struct shlocal { int lock; struct nshell *nshell; }; static int cmdinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct shlocal *shlocal; struct nshell *nshell; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if ((shlocal=g_malloc(sizeof(struct shlocal)))==NULL) return 1; if (_putobj(obj,"_local",inst,shlocal)) { g_free(shlocal); return 1; } if ((nshell=newshell())==NULL) return 1; ngraphenvironment(nshell); shlocal->lock=0; shlocal->nshell=nshell; return 0; } static int cmddone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct shlocal *shlocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&shlocal); if (shlocal->lock) { shlocal->nshell->deleted = 1; } else { delshell(shlocal->nshell); } return 0; } #if ! WINDOWS static void int_handler(int sig) { set_interrupt(); } #endif static int cmdshell(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct shlocal *shlocal; struct nshell *nshell; struct narray *sarray; char **sdata; int i,snum; int err; char *filename,*filename2; int fd; int rcode; char *s; #if ! WINDOWS struct sigaction oldact; int (*save_interrupt)(void); #endif _getobj(obj,"_local",inst,&shlocal); if (shlocal->lock) { error(obj,ERRRUN); return 1; } shlocal->lock=1; nshell=shlocal->nshell; shellsavestdio(nshell); #if ! WINDOWS save_interrupt = ninterrupt; set_signal(SIGINT, 0, int_handler, &oldact); ninterrupt = check_interrupt; #endif err=1; filename=NULL; sarray=(struct narray *)argv[2]; snum=arraynum(sarray); sdata=arraydata(sarray); for (i=0;ideleted) break; } while (nisatty(getshhandle(nshell)) && (rcode!=0)); if (fd!=NOHANDLE) { nclose(fd); setshhandle(nshell,stdinfd()); if (!getshelloption(nshell,'s')) { do { rcode=cmdexecute(nshell,NULL); } while (nisatty(getshhandle(nshell)) && (rcode!=0)); } } err=0; errexit: #if ! WINDOWS ninterrupt = save_interrupt; sigaction(SIGINT, &oldact, NULL); #endif shellrestorestdio(nshell); if (nshell->deleted) { delshell(nshell); } else { shlocal->lock = 0; } return err; } static int cmdsecurity(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { set_security(*(int *)argv[2]); return 0; } static struct objtable shell[] = { {"init",NVFUNC,NEXEC,cmdinit,NULL,0}, {"done",NVFUNC,NEXEC,cmddone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"shell",NVFUNC,NREAD|NEXEC,cmdshell,"sa",0}, {"security",NVFUNC,0,cmdsecurity,"b",0}, {"_local",NPOINTER,0,NULL,NULL,0}}; #define TBLNUM (sizeof(shell) / sizeof(*shell)) void * addshell(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,shell,ERRNUM,sherrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/ngraph_export.map0000644000175000017500000000007513070106167015021 00000000000000{ global: ngraph_*; _IO_stdin_used; local: *; }; ngraph-gtk-6.08.00/src/omath.c0000644000175000017500000002141213070106167012714 00000000000000/* * $Id: omath.c,v 1.22 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include "object.h" #include "mathcode.h" #include "mathfn.h" #include "math/math_equation.h" #define NAME "math" #define PARENT "object" #define OVERSION "1.00.00" #define ERRSYNTAX 100 #define ERRILLEGAL 101 #define ERRNEST 102 #define ERRARG 103 #define ERRSMLARG 104 static char *matherrorlist[]={ "syntax error.", "not allowed function.", "sum() or dif(): deep nest.", "illegal argument", "not enough argument." }; #define ERRNUM (sizeof(matherrorlist) / sizeof(*matherrorlist)) struct mlocal { double x; double y; double z; double val; int maxdim; MathEquation *code; int rcode; int idpx; int idpy; int idpz; int idpr; }; static void msettbl(N_VALUE *inst,struct mlocal *mlocal) { inst[mlocal->idpx].d=mlocal->x; inst[mlocal->idpy].d=mlocal->y; inst[mlocal->idpz].d=mlocal->z; inst[mlocal->idpr].i=mlocal->rcode; } static void mlocalclear(struct mlocal *mlocal,int memory) { math_equation_clear(mlocal->code); } static int minit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mlocal *mlocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; if ((mlocal=g_malloc(sizeof(struct mlocal)))==NULL) goto errexit; if (_putobj(obj,"_local",inst,mlocal)) goto errexit; mlocal->x=0; mlocal->y=0; mlocal->z=0; mlocal->val=0; mlocal->code = math_equation_basic_new(); if (mlocal->code == NULL) goto errexit; if (math_equation_add_parameter(mlocal->code, 0, 1, 2, MATH_EQUATION_PARAMETAR_USE_ID)) { math_equation_free(mlocal->code); goto errexit; } if (math_equation_add_var(mlocal->code, "X") != 0) { math_equation_free(mlocal->code); goto errexit; } if (math_equation_add_var(mlocal->code, "Y") != 1) { math_equation_free(mlocal->code); goto errexit; } if (math_equation_add_var(mlocal->code, "Z") != 2) { math_equation_free(mlocal->code); goto errexit; } math_equation_parse(mlocal->code, "def f(x,y,z){0}"); math_equation_parse(mlocal->code, "def g(x,y,z){0}"); math_equation_parse(mlocal->code, "def h(x,y,z){0}"); mlocal->rcode=MATH_VALUE_NORMAL; mlocalclear(mlocal,TRUE); if (_putobj(obj,"formula",inst,NULL)) goto errexit; if (_putobj(obj,"f",inst,NULL)) goto errexit; if (_putobj(obj,"g",inst,NULL)) goto errexit; if (_putobj(obj,"h",inst,NULL)) goto errexit; mlocal->idpx=chkobjoffset(obj,"x"); mlocal->idpy=chkobjoffset(obj,"y"); mlocal->idpz=chkobjoffset(obj,"z"); mlocal->idpr=chkobjoffset(obj,"status"); msettbl(inst,mlocal); return 0; errexit: g_free(mlocal); return 1; } static int mdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mlocal *mlocal; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_local",inst,&mlocal); math_equation_free(mlocal->code); return 0; } static char * create_func_def_str(char *name, char *code) { return g_strdup_printf("def %s(x,y,z) {%s;}", name, code); } static void parse_original_formula(struct objlist *obj,N_VALUE *inst, struct mlocal *mlocal) { char *ptr; MathEquationParametar *prm; _getobj(obj, "formula", inst, &ptr); math_equation_parse(mlocal->code, ptr); math_equation_optimize(mlocal->code); prm = math_equation_get_parameter(mlocal->code, 0, NULL); if (prm == NULL) { mlocal->maxdim = 0; } else { mlocal->maxdim = prm->id_max; } } /* # following procedure causes error. new math math::formula="const A:1;A" get math: calc # calc:1.000000000000000e+00 math::formula="const A=1;A" get math: formula # formula:const A:1;A get math: calc # calc:0.000000000000000e+00 */ static int mformula(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *math; struct mlocal *mlocal; int rcode; char *ptr, *err_msg; MathEquationParametar *prm; math=argv[2]; _getobj(obj,"_local",inst,&mlocal); if (strcmp("formula",argv[1])==0) { if (math) { rcode = math_equation_parse(mlocal->code, math); if (rcode) { err_msg = math_err_get_error_message(mlocal->code, math, rcode); error22(obj, ERRUNKNOWN, argv[1], err_msg); g_free(err_msg); parse_original_formula(obj, inst, mlocal); return 1; } if (math_equation_optimize(mlocal->code)) { parse_original_formula(obj, inst, mlocal); return 1; } prm = math_equation_get_parameter(mlocal->code, 0, NULL); if (prm == NULL) { mlocal->maxdim = 0; } else { mlocal->maxdim = prm->id_max; } } } else { if (math) { ptr = create_func_def_str(argv[1], math); } else { ptr = create_func_def_str(argv[1], "0"); } if (ptr == NULL) { return 1; } rcode = math_equation_parse(mlocal->code, ptr); if (rcode) { err_msg = math_err_get_error_message(mlocal->code, math, rcode); error22(obj, ERRUNKNOWN, argv[1], err_msg); g_free(err_msg); parse_original_formula(obj, inst, mlocal); return 1; } if (math_equation_optimize(mlocal->code)) { parse_original_formula(obj, inst, mlocal); return 1; } g_free(ptr); parse_original_formula(obj, inst, mlocal); } msettbl(inst,mlocal); return 0; } static int mparam(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *arg; struct mlocal *mlocal; _getobj(obj, "_local", inst, &mlocal); arg = argv[1]; switch (arg[0]) { case 'x': mlocal->x = * (double *) argv[2]; break; case 'y': mlocal->y = * (double *) argv[2]; break; case 'z': mlocal->z = * (double *) argv[2]; break; } msettbl(inst, mlocal); return 0; } static int mcalc(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mlocal *mlocal; int i,num; double *adata; struct narray *darray; int maxdim; MathValue val, *data; _getobj(obj,"_local",inst,&mlocal); maxdim=mlocal->maxdim; darray=(struct narray *)argv[2]; num=arraynum(darray); adata=arraydata(darray); if (numx; math_equation_set_var(mlocal->code, 0, &val); val.val = mlocal->y; math_equation_set_var(mlocal->code, 1, &val); val.val = mlocal->z; math_equation_set_var(mlocal->code, 2, &val); math_equation_set_parameter_data(mlocal->code, 0, data); math_equation_calculate(mlocal->code, &val); mlocal->val = val.val; mlocal->rcode = val.type; g_free(data); msettbl(inst,mlocal); rval->d=mlocal->val; return 0; } static int mclear(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mlocal *mlocal; _getobj(obj,"_local",inst,&mlocal); mlocalclear(mlocal,TRUE); msettbl(inst,mlocal); return 0; } static struct objtable math[] = { {"init",NVFUNC,NEXEC,minit,NULL,0}, {"done",NVFUNC,NEXEC,mdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"formula",NSTR,NREAD|NWRITE,mformula,NULL,0}, {"f",NSTR,NREAD|NWRITE,mformula,NULL,0}, {"g",NSTR,NREAD|NWRITE,mformula,NULL,0}, {"h",NSTR,NREAD|NWRITE,mformula,NULL,0}, {"x",NDOUBLE,NREAD|NWRITE,mparam,NULL,0}, {"y",NDOUBLE,NREAD|NWRITE,mparam,NULL,0}, {"z",NDOUBLE,NREAD|NWRITE,mparam,NULL,0}, {"status",NENUM,NREAD,NULL,matherrorchar,0}, {"calc",NDFUNC,NREAD|NEXEC,mcalc,"da",0}, {"clear",NVFUNC,NREAD|NEXEC,mclear,"",0}, {"_local",NPOINTER,0,NULL,NULL,0}, }; #define TBLNUM (sizeof(math) / sizeof(*math)) void * addmath(void) /* addmath() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,math,ERRNUM,matherrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/oint.c0000644000175000017500000000523013070106167012555 00000000000000/* * $Id: oint.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include "object.h" #define NAME "int" #define PARENT "object" #define OVERSION "1.00.00" #define ERRILNAME 100 static char *interrorlist[]={ "", }; #define ERRNUM (sizeof(interrorlist) / sizeof(*interrorlist)) static int intinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int intdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int int_times(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int count; _getobj(obj, "@", inst, &count); rval->i = count; if (count <= 0) { return 1; } count--; _putobj(obj,"@",inst,&count); return 0; } static int int_inc(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int count; _getobj(obj, "@", inst, &count); count++; rval->i = count; _putobj(obj,"@",inst,&count); return 0; } static int int_dec(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int count; _getobj(obj, "@", inst, &count); count--; rval->i = count; _putobj(obj,"@",inst,&count); return 0; } static struct objtable oint[] = { {"init",NVFUNC,NEXEC,intinit,NULL,0}, {"done",NVFUNC,NEXEC,intdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NINT,NREAD|NWRITE,NULL,NULL,0}, {"times",NIFUNC,NREAD|NEXEC,int_times,"",0}, {"inc",NIFUNC,NREAD|NEXEC,int_inc,"",0}, {"dec",NIFUNC,NREAD|NEXEC,int_dec,"",0}, }; #define TBLNUM (sizeof(oint) / sizeof(*oint)) void * addint(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,oint,ERRNUM,interrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/odata.h0000644000175000017500000000274713340156720012713 00000000000000#ifndef OFILE_HEADER #define OFILE_HEADER #define FILE_OBJ_MAXCOL 999 #define FILE_OBJ_SMOOTH_MAX 50 enum DATA_OBJ_SOURCE { DATA_SOURCE_FILE, DATA_SOURCE_ARRAY, DATA_SOURCE_RANGE, }; enum MOVING_AVERAGE_TYPE { MOVING_AVERAGE_SIMPLE, MOVING_AVERAGE_WEIGHTED, MOVING_AVERAGE_EXPONENTIAL, }; enum FILE_OBJ_PLOT_TYPE { PLOT_TYPE_MARK, PLOT_TYPE_LINE, PLOT_TYPE_POLYGON, PLOT_TYPE_POLYGON_SOLID_FILL, PLOT_TYPE_CURVE, PLOT_TYPE_DIAGONAL, PLOT_TYPE_ARROW, PLOT_TYPE_RECTANGLE, PLOT_TYPE_RECTANGLE_FILL, PLOT_TYPE_RECTANGLE_SOLID_FILL, PLOT_TYPE_ERRORBAR_X, PLOT_TYPE_ERRORBAR_Y, PLOT_TYPE_STAIRCASE_X, PLOT_TYPE_STAIRCASE_Y, PLOT_TYPE_BAR_X, PLOT_TYPE_BAR_Y, PLOT_TYPE_BAR_FILL_X, PLOT_TYPE_BAR_FILL_Y, PLOT_TYPE_BAR_SOLID_FILL_X, PLOT_TYPE_BAR_SOLID_FILL_Y, PLOT_TYPE_FIT, }; enum axis_instance_field_type{ AXIS_X, AXIS_Y, AXIS_REFERENCE, }; #include "math/math_equation.h" struct array_prm { struct objlist *obj; int data_num, col_num; int id[FILE_OBJ_MAXCOL]; struct narray *ary[FILE_OBJ_MAXCOL]; }; MathEquation *ofile_create_math_equation(int *id, int prm_digit, int use_fprm, int use_const, int usr_func, int use_fobj_func, int use_fit_func); int get_axis_id(struct objlist *obj, N_VALUE *inst, struct objlist **aobj, int axis); int ofile_calc_fit_equation(struct objlist *obj, int id, double x, double *y); int open_array(char *objstr, struct array_prm *ary); char *odata_get_functions(void); char *odata_get_constants(void); #endif ngraph-gtk-6.08.00/src/ogra2.c0000644000175000017500000001004213154220370012607 00000000000000/* * $Id: ogra2.c,v 1.7 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "object.h" #define NAME "gra2" #define PARENT "object" #define OVERSION "1.00.00" #define ERRLOCK 100 static char *gra2errorlist[]={ "device is locked", }; #define ERRNUM (sizeof(gra2errorlist) / sizeof(*gra2errorlist)) static int gra2init(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC, layer; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; GC=-1; if (_putobj(obj,"_GC",inst,&GC)) return 1; layer = FALSE; if (_putobj(obj,"_layer",inst,&layer)) return 1; return 0; } static int gra2done(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; struct narray *sarray; struct objlist *gobj; int gid,deletegra,id,n; char *gfield; N_VALUE *ginst; char *device; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"_GC",inst,&GC); _getobj(obj,"delete_gra",inst,&deletegra); _getobj(obj,"_list",inst,&sarray); n = arraynum(sarray); if (GC != -1 && (! deletegra || n == 0)) { error2(obj,ERRLOCK,argv[0]); return 1; } if (n) { gobj=getobjlist(arraynget_str(sarray,0),&gid,&gfield,NULL); if (gobj==NULL) return 0; if ((ginst=getobjinstoid(gobj,gid))==NULL) return 0; if (GC!=-1) _exeobj(gobj,"close",ginst,0,NULL); if (!_getobj(gobj,"_device",ginst,&device)) { g_free(device); _putobj(gobj,"_device",ginst,NULL); } if (deletegra) { if (_getobj(gobj,"id",ginst,&id)) return 0; delobj(gobj,id); } } return 0; } static int gra2clear(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int i,num; struct narray *sarray; _getobj(obj,"_list",inst,&sarray); num=arraynum(sarray); for (i=num-1;i>0;i--) arrayndel2(sarray,i); return 0; } #ifdef COMPILE_UNUSED_FUNCTIONS static int gra2disconnect(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; struct narray *sarray; struct objlist *gobj; int gid; char *gfield; char *ginst,*device; _getobj(obj,"_GC",inst,&GC); _getobj(obj,"_list",inst,&sarray); _putobj(obj,"_list",inst,NULL); if (arraynum(sarray)!=0) { gobj=getobjlist(arraynget_str(sarray,0),&gid,&gfield,NULL); if (gobj!=NULL) { if ((ginst=getobjinstoid(gobj,gid))==NULL) return 0; if (GC!=-1) _exeobj(gobj,"close",ginst,0,NULL); if (!_getobj(gobj,"_device",ginst,&device)) { g_free(device); _putobj(gobj,"_device",ginst,NULL); } } } arrayfree2(sarray); return 0; } #endif /* COMPILE_UNUSED_FUNCTIONS */ static struct objtable gra2[] = { {"init",NVFUNC,NEXEC,gra2init,NULL,0}, {"done",NVFUNC,NEXEC,gra2done,NULL,0}, {"clear",NVFUNC,NREAD|NEXEC,gra2clear,"",0}, {"_list",NSARRAY,NREAD,NULL,NULL,0}, {"_GC",NINT,NREAD,NULL,NULL,0}, {"_layer",NBOOL,NREAD,NULL,NULL,0}, {"delete_gra",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"disconnect",NVFUNC,NREAD|NEXEC,NULL,"",0}, }; #define TBLNUM (sizeof(gra2) / sizeof(*gra2)) void * addgra2(void) /* addgra2() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,gra2,ERRNUM,gra2errorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/oiarray.c0000644000175000017500000003452213073663051013263 00000000000000/* * $Id: oiarray.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "mathfn.h" #include "object.h" #include "oiarray.h" #include "math/math_equation.h" #define NAME "iarray" #define PARENT "object" #define OVERSION "1.00.00" #define ERRILNAME 100 #define ERROUTBOUND 101 static char *iarrayerrorlist[]={ "", "array index is out of array bounds.", }; #define ERRNUM (sizeof(iarrayerrorlist) / sizeof(*iarrayerrorlist)) static int iarrayinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int iarraydone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } int oarray_get_index(struct narray *array, int i) { if (i < 0) { i += arraynum(array); } return i; } static int iarrayget(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num,*po; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } po=(int *)arraynget(array,num); if (po==NULL) { error(obj, ERROUTBOUND); return 1; } rval->i=*po; return 0; } static int iarrayput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; int val; num=*(int *)argv[2]; val=*(int *)argv[3]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayput(array,&val,num)==NULL) return 1; return 0; } struct narray * oarray_get_array(struct objlist *obj, N_VALUE *inst, unsigned int size) { struct narray *array; _getobj(obj, "@", inst, &array); if (array == NULL) { array = arraynew(size); if (array == NULL) { return NULL; } if (_putobj(obj, "@", inst, array)) { arrayfree(array); return NULL; } } return array; } static int iarrayadd(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int val; val=*(int *)argv[2]; array = oarray_get_array(obj, inst, sizeof(int)); if (array==NULL) { return 1; } if (arrayadd(array,&val)==NULL) return 1; return 0; } static int iarraypop(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int val, n; rval->i = 0; _getobj(obj,"@",inst,&array); if (array == NULL) { return 1; } n = arraynum(array) - 1; if (n < 0) { return 1; } val = arraynget_int(array, n); if (arrayndel(array, n) == NULL) { return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { return 1; } } rval->i = val; return 0; } static int iarrayins(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; int val; num=*(int *)argv[2]; val=*(int *)argv[3]; array = oarray_get_array(obj, inst, sizeof(int)); if (array == NULL) { return 1; } num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayins(array, &val, num)==NULL) { return 1; } return 0; } static int iarrayunshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int val; val = * (int *) argv[2]; array = oarray_get_array(obj, inst, sizeof(int)); if (array == NULL) { return 1; } if (arrayins(array, &val, 0)==NULL) { return 1; } return 0; } static int iarrayshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int val; rval->i = 0; _getobj(obj,"@",inst,&array); if (array == NULL) { return 1; } val = arraynget_int(array, 0); if (arrayndel(array, 0) == NULL) { return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { return 1; } } rval->i = val; return 0; } static int iarraydel(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); if (array==NULL) return 1; num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayndel(array,num)==NULL) { error(obj, ERROUTBOUND); return 1; } if (arraynum(array)==0) { arrayfree(array); if (_putobj(obj,"@",inst,NULL)) return 1; } return 0; } int oarray_num(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); rval->i = arraynum(array); return 0; } int oarray_seq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; GString *str; int i, n; g_free(rval->str); rval->str = NULL; if (_getobj(obj, "@", inst, &array)) { return 1; } n = arraynum(array); if (n == 0) { return 0; } str = g_string_sized_new(64); if (str == NULL) { return 0; } for (i = 0; i < n; i++) { g_string_append_printf(str, "%d%s", i, (i == n - 1) ? "" : " "); } rval->str = g_string_free(str, FALSE); return 0; } int oarray_reverse_seq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; GString *str; int i, n; g_free(rval->str); rval->str = NULL; if (_getobj(obj, "@", inst, &array)) { return 1; } n = arraynum(array); if (n == 0) { return 0; } str = g_string_sized_new(64); if (str == NULL) { return 0; } for (i = 0; i < n; i++) { g_string_append_printf(str, "%d%s", n - i - 1, (i == n - 1) ? "" : " "); } rval->str = g_string_free(str, FALSE); return 0; } static int iarraysort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arraysort_int(array); return 0; } static int iarrayrsort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arrayrsort_int(array); return 0; } static int iarrayuniq(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arrayuniq_int(array); return 0; } static int iarrayjoin(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; GString *str; int i, n; char *sep, *ptr; int val; g_free(rval->str); rval->str = NULL; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } ptr = (char *) argv[2]; if (ptr) { sep = g_strcompress(ptr); } else { sep = g_strdup(","); } if (sep == NULL) { return 1; } str = g_string_sized_new(64); if (str == NULL) { g_free(sep); return 1; } for (i = 0; i < n; i++) { val = arraynget_int(array, i); g_string_append_printf(str, "%d%s", val, (i == n - 1) ? "" : sep); } rval->str = g_string_free(str, FALSE); g_free(sep); return 0; } int oarray_reverse(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; if (_getobj(obj, "@", inst, &array)) { return 1; } array_reverse(array); return 0; } int oarray_slice(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int start, len; start = * (int *) argv[2]; len = * (int *) argv[3]; if (_getobj(obj, "@", inst, &array)) { return 1; } if (array_slice(array, start, len) == NULL) { return 1; } return 0; } static double calc_sum(const int *d, int n) { double sum; int i; sum = 0; for (i = 0; i < n; i++) { sum += d[i]; } return sum; } static double calc_square_sum(const int *d, int n) { double sum; int i; sum = 0; for (i = 0; i < n; i++) { sum += d[i] * d[i]; } return sum; } static int iarray_sum(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int n, *data; double val; rval->i = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } data = arraydata(array); val = calc_sum(data, n); if (val <= G_MININT || val >= G_MAXINT) { return 1; } rval->i = nround(val); return 0; } static int iarray_average(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int n, *data; double val; rval->d = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } data = arraydata(array); val = calc_sum(data, n); rval->d = val / n; return 0; } static int iarray_rms(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int n, *data; double val; rval->d = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } data = arraydata(array); val = calc_square_sum(data, n); rval->d = sqrt(val / n); return 0; } static int iarray_sdev(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int n, *data; double sum, ssum, val; rval->d = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } data = arraydata(array); sum = calc_sum(data, n); ssum = calc_square_sum(data, n); sum /= n; val = ssum / n - sum * sum; rval->d = (val < 0) ? 0 : sqrt(val); return 0; } static int iarray_min(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int i, n, *data, val; rval->i = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 1; } data = arraydata(array); val = data[0]; for (i = 1; i < n; i++) { if (data[i] < val) { val = data[i]; } } rval->i = val; return 0; } static int iarray_max(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int i, n, *data, val; rval->i = 0; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 1; } data = arraydata(array); val = data[0]; for (i = 1; i < n; i++) { if (data[i] > val) { val = data[i]; } } rval->i = val; return 0; } MathEquation * oarray_create_math(struct objlist *obj, const char *fild, const char *eqn) { MathEquation *code; int rcode; code = math_equation_basic_new(); if (code == NULL) { return NULL; } if (math_equation_add_var(code, "X") != 0) { math_equation_free(code); return NULL; } if (math_equation_add_var(code, "I") != 1) { math_equation_free(code); return NULL; } rcode = math_equation_parse(code, eqn); if (rcode) { char *err_msg; err_msg = math_err_get_error_message(code, eqn, rcode); error22(obj, ERRUNKNOWN, fild, err_msg); g_free(err_msg); math_equation_free(code); return NULL; } math_equation_optimize(code); return code; } static int iarray_map(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int i, n, *data; MathEquation *code; MathValue val; if (argv[2] == NULL) { return 0; } _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 1; } code = oarray_create_math(obj, argv[1], argv[2]); if (code == NULL) { return 1; } data = arraydata(array); for (i = 0; i < n; i++) { val.val = data[i]; val.type = MATH_VALUE_NORMAL; math_equation_set_var(code, 0, &val); val.val = i; val.type = MATH_VALUE_NORMAL; math_equation_set_var(code, 1, &val); math_equation_calculate(code, &val); data[i] = val.val; } math_equation_free(code); return 0; } static struct objtable oiarray[] = { {"init",NVFUNC,NEXEC,iarrayinit,NULL,0}, {"done",NVFUNC,NEXEC,iarraydone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"get",NIFUNC,NREAD|NEXEC,iarrayget,"i",0}, {"put",NVFUNC,NREAD|NEXEC,iarrayput,"ii",0}, {"add",NVFUNC,NREAD|NEXEC,iarrayadd,"i",0}, {"push",NVFUNC,NREAD|NEXEC,iarrayadd,"i",0}, {"pop",NIFUNC,NREAD|NEXEC,iarraypop,"",0}, {"ins",NVFUNC,NREAD|NEXEC,iarrayins,"ii",0}, {"unshift",NVFUNC,NREAD|NEXEC,iarrayunshift,"i",0}, {"shift",NIFUNC,NREAD|NEXEC,iarrayshift,"",0}, {"del",NVFUNC,NREAD|NEXEC,iarraydel,"i",0}, {"join",NSFUNC,NREAD|NEXEC,iarrayjoin,"s",0}, {"sort",NVFUNC,NREAD|NEXEC,iarraysort,"",0}, {"rsort",NVFUNC,NREAD|NEXEC,iarrayrsort,"",0}, {"uniq",NVFUNC,NREAD|NEXEC,iarrayuniq,"",0}, {"sum", NIFUNC, NREAD|NEXEC, iarray_sum, "", 0}, {"average", NDFUNC, NREAD|NEXEC, iarray_average, "", 0}, {"sdev", NDFUNC, NREAD|NEXEC, iarray_sdev, "", 0}, {"RMS", NDFUNC, NREAD|NEXEC, iarray_rms, "", 0}, {"min", NIFUNC, NREAD|NEXEC, iarray_min, "", 0}, {"max", NIFUNC, NREAD|NEXEC, iarray_max, "", 0}, {"num", NIFUNC, NREAD|NEXEC, oarray_num, "", 0}, {"seq", NSFUNC, NREAD|NEXEC, oarray_seq, "", 0}, {"rseq", NSFUNC, NREAD|NEXEC, oarray_reverse_seq, "", 0}, {"reverse", NVFUNC, NREAD|NEXEC, oarray_reverse, "", 0}, {"slice", NVFUNC, NREAD|NEXEC, oarray_slice, "ii", 0}, {"map", NVFUNC, NREAD|NEXEC, iarray_map, "s", 0}, }; #define TBLNUM (sizeof(oiarray) / sizeof(*oiarray)) void * addiarray(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,oiarray,ERRNUM,iarrayerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/oagrid.c0000644000175000017500000002604513070106167013060 00000000000000/* * $Id: oagrid.c,v 1.20 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "common.h" #include "object.h" #include "mathfn.h" #include "gra.h" #include "axis.h" #include "oroot.h" #include "odraw.h" #define NAME "axisgrid" #define PARENT "draw" #define OVERSION "1.00.00" #define ERRNOAXISINST 100 #define ERRMINMAX 101 #define ERRAXISDIR 102 static char *agriderrorlist[]={ "no instance for axis", "illegal axis min/max.", "illegal axis direction.", }; #define ERRNUM (sizeof(agriderrorlist) / sizeof(*agriderrorlist)) static int agridinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int wid1,wid2,wid3,dot,grid; int r,g,b,br,bg,bb,ba; struct narray *style1; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; wid1=5; wid2=10; wid3=20; r=0; g=255; b=255; br=255; bg=255; bb=255; ba=255; style1=arraynew(sizeof(int)); dot=150; grid=TRUE; arrayadd(style1,&dot); arrayadd(style1,&dot); if (_putobj(obj,"width1",inst,&wid1)) return 1; if (_putobj(obj,"width2",inst,&wid2)) return 1; if (_putobj(obj,"width3",inst,&wid3)) return 1; if (_putobj(obj,"style1",inst,style1)) return 1; if (_putobj(obj,"R",inst,&r)) return 1; if (_putobj(obj,"G",inst,&g)) return 1; if (_putobj(obj,"B",inst,&b)) return 1; if (_putobj(obj,"BR",inst,&br)) return 1; if (_putobj(obj,"BG",inst,&bg)) return 1; if (_putobj(obj,"BB",inst,&bb)) return 1; if (_putobj(obj,"BA",inst,&ba)) return 1; if (_putobj(obj,"grid_x",inst,&grid)) return 1; if (_putobj(obj,"grid_y",inst,&grid)) return 1; return 0; } static int agriddone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } struct axis_prm { int type, div; double amin, amax, inc; double min, max; }; struct axis_pos { int dir, len, x, y; double len_x, len_y; }; #define GRID_PRM_NUM 3 struct grid_prm { int wid[GRID_PRM_NUM]; int snum[GRID_PRM_NUM]; int *sdata[GRID_PRM_NUM]; }; static int calc_intersection(int x1, int y1, int dir1, int x2, int y2, int dir2, int *ix, int *iy) { double x, y, a, b; if (dir1 == dir2 || dir1 - dir2 == 18000 || dir1 - dir2 == -18000) return 1; if (x1 == x2 && y1 == y2) { *ix = x1; *iy = y1; return 0; } dir1 = -dir1; dir2 = -dir2; if (dir1 == -9000 || dir1 == -27000) { x = x1; b = tan(dir2 / 18000.0 * MPI); y = y2 + b * (x1 - x2); } else if (dir2 == -9000 || dir2 == -27000) { x = x2; a = tan(dir1 / 18000.0 * MPI); y = y1 + a * (x2 - x1); } else { a = tan(dir1 / 18000.0 * MPI); b = tan(dir2 / 18000.0 * MPI); x = (y2 - y1 + a * x1 - b * x2) / (a - b); y = y1 + a * (x - x1); } if (dir1 == 0 || dir1 == -18000) { y = y1; } else if (dir2 == 0 || dir2 == -18000) { y = y2; } *ix = nround(x); *iy = nround(y); return 0; } static int get_grid_prm(struct objlist *obj, char *axisy, struct axis_prm *prm, struct axis_pos *pos) { struct narray iarray; int anum, id; N_VALUE *inst1; char *raxis; struct objlist *aobj; if (axisy == NULL) { return -1; } arrayinit(&iarray, sizeof(int)); if (getobjilist(axisy, &aobj, &iarray, FALSE, NULL)) return 1; anum = arraynum(&iarray); if (anum < 1) { arraydel(&iarray); error2(obj, ERRNOAXISINST, axisy); return 1; } id = arraylast_int(&iarray); arraydel(&iarray); if ((inst1 = getobjinst(aobj, id)) == NULL) return 1; if (_getobj(aobj, "x", inst1, &pos->x)) return 1; if (_getobj(aobj, "y", inst1, &pos->y)) return 1; if (_getobj(aobj, "length", inst1, &pos->len)) return 1; if (_getobj(aobj, "direction", inst1, &pos->dir)) return 1; if (_getobj(aobj, "min", inst1, &prm->amin)) return 1; if (_getobj(aobj, "max", inst1, &prm->amax)) return 1; if (_getobj(aobj, "inc", inst1, &prm->inc)) return 1; if (_getobj(aobj, "div", inst1, &prm->div)) return 1; if (_getobj(aobj, "type", inst1, &prm->type)) return 1; if ((prm->amin == 0) && (prm->amax == 0) && (prm->inc == 0)) { if (_getobj(aobj, "reference", inst1, &raxis)) return 1; if (raxis) { arrayinit(&iarray, sizeof(int)); if (!getobjilist(raxis, &aobj, &iarray, FALSE, NULL)) { anum = arraynum(&iarray); if (anum > 0) { id = arraylast_int(&iarray); arraydel(&iarray); if (anum > 0 && (inst1 = getobjinst(aobj, id))) { _getobj(aobj, "min", inst1, &prm->amin); _getobj(aobj, "max", inst1, &prm->amax); _getobj(aobj, "inc", inst1, &prm->inc); _getobj(aobj, "div", inst1, &prm->div); _getobj(aobj, "type", inst1, &prm->type); } } } } } pos->dir %= 36000; if (pos->dir < 0) pos->dir += 36000; pos->len_x = pos->len * cos(pos->dir / 18000.0 * MPI); pos->len_y = pos->len * sin(pos->dir / 18000.0 * MPI); if (prm->amin == prm->amax) return 0; switch (prm->type) { case 1: prm->min = log10(prm->amin); prm->max = log10(prm->amax); break; case 2: prm->min = 1 / prm->amin; prm->max = 1 / prm->amax; break; default: prm->min = prm->amin; prm->max = prm->amax; } return 0; } static int draw_grid_line(struct objlist *obj, int GC, struct axis_prm *a1_prm, struct axis_pos *a1_pos, struct axis_pos *a2_pos, struct grid_prm *gprm) { int r, rcode, snum, wid, *sdata; double po; int x0, y0, x, y; struct axislocal alocal; if (getaxispositionini(&alocal, a1_prm->type, a1_prm->amin, a1_prm->amax, a1_prm->inc, a1_prm->div, TRUE)) { error(obj, ERRMINMAX); return 1; } r = calc_intersection(a1_pos->x, a1_pos->y, a2_pos->dir, a2_pos->x, a2_pos->y, a1_pos->dir, &x, &y); if (r) { error(obj, ERRAXISDIR); return 1; } while ((rcode = getaxisposition(&alocal, &po)) != -2) { switch (rcode) { case 1: case 2: case 3: snum = gprm->snum[rcode - 1]; sdata = gprm->sdata[rcode - 1]; wid = gprm->wid[rcode - 1]; break; default: wid = 0; } if (wid == 0) continue; GRAlinestyle(GC, snum, sdata, wid, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); x0 = x + (po - a1_prm->min) * a1_pos->len_x / (a1_prm->max - a1_prm->min); y0 = y - (po - a1_prm->min) * a1_pos->len_y / (a1_prm->max - a1_prm->min); GRAline(GC, x0, y0, x0 + a2_pos->len_x, y0 - a2_pos->len_y); } return 0; } static int draw_background(struct objlist *obj, N_VALUE *inst, int GC, struct axis_pos *ax, struct axis_pos *ay) { int r, br, bg, bb, ba, pos[8]; _getobj(obj, "BR", inst, &br); _getobj(obj, "BG", inst, &bg); _getobj(obj, "BB", inst, &bb); _getobj(obj, "BA", inst, &ba); GRAcolor(GC, br, bg, bb, ba); r = calc_intersection(ax->x, ax->y, ay->dir, ay->x, ay->y, ax->dir, pos + 0, pos + 1); if (r) return 1; pos[2] = pos[0] + ax->len_x; pos[3] = pos[1] - ax->len_y; pos[4] = pos[2] + ay->len_x; pos[5] = pos[3] - ay->len_y; pos[6] = pos[0] + ay->len_x; pos[7] = pos[1] - ay->len_y; GRAdrawpoly(GC, 4, pos, GRA_FILL_MODE_EVEN_ODD); return 0; } static int agriddraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int GC, clip, zoom, back; int i, fr, fg, fb, fa, w, h, r, grid_x, grid_y; char *axisx, *axisy; struct axis_prm ax_prm, ay_prm; struct axis_pos ax_pos, ay_pos; struct grid_prm gprm; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; _getobj(obj, "GC", inst, &GC); if (GC < 0) return 0; _getobj(obj, "R", inst, &fr); _getobj(obj, "G", inst, &fg); _getobj(obj, "B", inst, &fb); _getobj(obj, "A", inst, &fa); _getobj(obj, "axis_x", inst, &axisx); _getobj(obj, "axis_y", inst, &axisy); _getobj(obj, "clip", inst, &clip); _getobj(obj, "background", inst, &back); _getobj(obj, "grid_x", inst, &grid_x); _getobj(obj, "grid_y", inst, &grid_y); for (i = 0; i < GRID_PRM_NUM; i++) { char buf[32]; struct narray *st; snprintf(buf, sizeof(buf), "width%d", i + 1); _getobj(obj, buf, inst, &gprm.wid[i]); snprintf(buf, sizeof(buf), "style%d", i + 1); _getobj(obj, buf, inst, &st); gprm.snum[i] = arraynum(st); gprm.sdata[i] = arraydata(st); } r = get_grid_prm(obj, axisx, &ax_prm, &ax_pos); if (r) { return (r > 0) ? 1 : 0; } r = get_grid_prm(obj, axisy, &ay_prm, &ay_pos); if (r) { return (r > 0) ? 1 : 0; } GRAregion(GC, &w, &h, &zoom); GRAview(GC, 0, 0, w * 10000.0 / zoom, h * 10000.0 / zoom, clip); if (back && draw_background(obj, inst, GC, &ax_pos, &ay_pos)) { error(obj, ERRAXISDIR); return 1; } if (ax_prm.amin != ax_prm.amax && ay_prm.amin != ay_prm.amax) { GRAcolor(GC, fr, fg, fb, fa); if (grid_x && draw_grid_line(obj, GC, &ax_prm, &ax_pos, &ay_pos, &gprm)) { goto error_exit; } if (grid_y && draw_grid_line(obj, GC, &ay_prm, &ay_pos, &ax_pos, &gprm)) { goto error_exit; } } GRAaddlist(GC, obj, inst, (char *) argv[0], (char *) argv[1]); error_exit: return 0; } static int agridtight(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { obj_do_tighten(obj, inst, "axis_x"); obj_do_tighten(obj, inst, "axis_y"); return 0; } static struct objtable agrid[] = { {"init",NVFUNC,NEXEC,agridinit,NULL,0}, {"done",NVFUNC,NEXEC,agriddone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"axis_x",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"axis_y",NOBJ,NREAD|NWRITE,NULL,NULL,0}, {"grid_x",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"grid_y",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"width1",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"style1",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"width2",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"style2",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"width3",NINT,NREAD|NWRITE,oputabs,NULL,0}, {"style3",NIARRAY,NREAD|NWRITE,NULL,NULL,0}, {"background",NBOOL,NREAD|NWRITE,NULL,NULL,0}, {"BR",NINT,NREAD|NWRITE,NULL,NULL,0}, {"BG",NINT,NREAD|NWRITE,NULL,NULL,0}, {"BB",NINT,NREAD|NWRITE,NULL,NULL,0}, {"BA",NINT,NREAD|NWRITE,NULL,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,agriddraw,"i",0}, {"tight",NVFUNC,NREAD|NEXEC,agridtight,"",0}, {"hsb", NVFUNC, NREAD|NEXEC, put_hsb,"ddd",0}, }; #define TBLNUM (sizeof(agrid) / sizeof(*agrid)) void * addagrid(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,agrid,ERRNUM,agriderrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/nconfig.c0000644000175000017500000003354613070106167013242 00000000000000/* * $Id: nconfig.c,v 1.17 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include #include #include #include #include "common.h" #include "object.h" #include "nstring.h" #include "ioutil.h" #include "shell.h" #include "nconfig.h" #include #define CONF "Ngraph.ini" #define CONFBAK "Ngraph.ini~" #define LOCK "Ngraph.lock" #ifndef TRUE #define TRUE 1 #endif #ifndef FALSE #define FALSE 0 #endif char * getscriptname(char *file) { struct objlist *sys; char *homedir,*s; if ((sys=getobject("system"))==NULL) return NULL; if (getobj(sys,"home_dir",0,0,NULL,&homedir)==-1) return NULL; s=getfilename(homedir,CONFTOP,file); return s; } char * searchscript(char *file) { struct objlist *sys; char *libdir,*homedir,*s; if ((sys=getobject("system"))==NULL) return NULL; if (getobj(sys,"home_dir",0,0,NULL,&homedir)==-1) return NULL; if (getobj(sys,"conf_dir",0,0,NULL,&libdir)==-1) return NULL; if (!findfilename(homedir,CONFTOP,file)) { if (!findfilename(libdir,CONFTOP,file)) return NULL; if ((s=getfilename(libdir,CONFTOP,file))==NULL) return NULL; } else { if ((s=getfilename(homedir,CONFTOP,file))==NULL) return NULL; } return s; } static int configlocked(char *dir) { if (findfilename(dir,CONFSEP,LOCK)) return TRUE; else return FALSE; } static void lockconfig(char *dir) { char *file; FILE *fp; while (configlocked(dir)) { msleep(100); } if ((file=getfilename(dir,CONFSEP,LOCK))==NULL) return; if ((fp=nfopen(file,"wt"))==NULL) { g_free(file); return; } fputs("Ngraph.ini is locked",fp); fclose(fp); g_free(file); } static void unlockconfig(char *dir) { char *file; if (!findfilename(dir,CONFSEP,LOCK)) return; if ((file=getfilename(dir,CONFSEP,LOCK))==NULL) return; g_unlink(file); g_free(file); } FILE * openconfig(char *section) { struct objlist *sys; char *libdir,*s,*homedir,*homeconf,*libconf,*buf; FILE *fp; GStatBuf homestat,libstat; if ((sys=getobject("system"))==NULL) return NULL; if (getobj(sys,"home_dir",0,0,NULL,&homedir)==-1) return NULL; if (getobj(sys,"conf_dir",0,0,NULL,&libdir)==-1) return NULL; homeconf=libconf=NULL; if (findfilename(homedir,CONFSEP,CONF)) { if ((homeconf=getfilename(homedir,CONFSEP,CONF))!=NULL) { if (nstat(homeconf,&homestat)!=0) { g_free(homeconf); homeconf=NULL; } } } if (findfilename(libdir,CONFSEP,CONF)) { if ((libconf=getfilename(libdir,CONFSEP,CONF))!=NULL) { if (nstat(libconf,&libstat)!=0) { g_free(libconf); libconf=NULL; } } } if (homeconf) { #if 0 if (libconf==NULL) { s=homeconf; } else if (homestat.st_mtime>=libstat.st_mtime) { s=homeconf; g_free(libconf); } else { s=libconf; g_free(homeconf); } #else s=homeconf; g_free(libconf); #endif } else if (libconf) { s=libconf; } else { return NULL; } if ((fp=nfopen(s,"rt"))==NULL) { g_free(s); return NULL; } g_free(s); while (fgetline(fp,&buf)==0) { if (strcmp0(buf,section)==0) { g_free(buf); return fp; } g_free(buf); } fclose(fp); return NULL; } char * getconfig(FILE *fp,char **val) { char *s,*tok,*buf; int len; while (fgetline(fp, &buf) == 0) { switch (buf[0]) { case '[': g_free(buf); return NULL; case ';': case '#': g_free(buf); continue; } s = buf; tok = getitok2(&s, &len, "="); if (tok) { s += (s[0] == '=') ? 1 : 0; *val = g_strdup(s); if (*val == NULL) { g_free(tok); tok = NULL; } g_free(buf); return tok; } g_free(buf); } return NULL; } void closeconfig(FILE *fp) { fclose(fp); } static int make_backup(char *homedir, char *libdir, char *fil, FILE *fptmp) { FILE *fp; char *buf, *bak; if (! findfilename(homedir, CONFSEP, CONF)) { bak = getfilename(libdir, CONFSEP, CONFBAK); if (bak && findfilename(libdir, CONFSEP, CONFBAK)) { g_unlink(bak); } } else { bak = getfilename(homedir, CONFSEP, CONFBAK); if (bak && findfilename(homedir, CONFSEP, CONFBAK)) { g_unlink(bak); } } if (bak) { rename(fil, bak); g_free(bak); } fp = nfopen(fil, "wt"); if (fp == NULL) { return FALSE; } rewind(fptmp); while (fgetline(fptmp, &buf) == 0) { fputs(buf, fp); fputs("\n", fp); g_free(buf); } fclose(fp); return TRUE; } static char * replaceconfig_match(FILE *fp, FILE *fptmp, struct narray *iconf, struct narray *conf) { char *s, *s2, *buf, *tok, *tok2, **data; int out, len, len2, i, j, num, num2; num = arraynum(conf); data = arraydata(conf); while (fgetline(fp, &buf) == 0) { if (buf[0]=='[') { return buf; } s = buf; out = FALSE; tok = getitok(&s, &len, " \t=,"); if (tok) { for (i = 0; i < num; i++) { s2 = data[i]; tok2 = getitok(&s2, &len2, " \t=,"); if (tok2 && (len == len2 && strncmp(tok, tok2, len) == 0)) { out = TRUE; num2 = arraynum(iconf); for (j = 0; j < num2; j++) { if (i == arraynget_int(iconf, j)) break; } if (j == num2) { fputs(data[i], fptmp); fputs("\n", fptmp); arrayadd(iconf, &i); } } } } if (! out && buf && buf[0] != '\0') { fputs(buf, fptmp); fputs("\n", fptmp); } g_free(buf); } return NULL; } int replaceconfig(char *section,struct narray *conf) { int i,j,num,num2, r; char **data; struct objlist *sys; char *libdir,*homedir,*dir,*fil,*buf,*pfx, *tmp_name; FILE *fp,*fptmp; struct narray iconf; if (arraynum(conf) == 0) return TRUE; if ((sys=getobject("system"))==NULL) return FALSE; if (getobj(sys,"temp_prefix",0,0,NULL,&pfx)) return FALSE; if ((sys=getobject("system"))==NULL) return FALSE; if (getobj(sys,"home_dir",0,0,NULL,&homedir)==-1) return FALSE; if (getobj(sys,"conf_dir",0,0,NULL,&libdir)==-1) return FALSE; if (!findfilename(homedir,CONFSEP,CONF)) { if (!findfilename(libdir,CONFSEP,CONF)) return FALSE; if ((fil=getfilename(libdir,CONFSEP,CONF))==NULL) return FALSE; dir=libdir; } else { if ((fil=getfilename(homedir,CONFSEP,CONF))==NULL) return FALSE; dir=homedir; } lockconfig(dir); fptmp = n_tmpfile(&tmp_name); if (fptmp == NULL) { g_free(fil); unlockconfig(dir); return FALSE; } fp = nfopen(fil,"rt"); if (fp == NULL) { n_tmpfile_close(fptmp, tmp_name); g_free(fil); unlockconfig(dir); return FALSE; } arrayinit(&iconf,sizeof(int)); while (fgetline(fp,&buf)==0) { if (strcmp0(buf,section)==0) { fputs(buf,fptmp); fputs("\n",fptmp); g_free(buf); buf = replaceconfig_match(fp, fptmp, &iconf, conf); goto flush; } else { fputs(buf,fptmp); fputs("\n",fptmp); } g_free(buf); } /* section not found */ fputs("\n",fptmp); fputs(section,fptmp); fputs("\n",fptmp); flush: data = arraydata(conf); num = arraynum(conf); for (i=0;i=libstat.st_mtime) { dir=1; s=homeconf; g_free(libconf); } else { dir=3; s=homeconf; g_free(libconf); } } else if (libconf!=NULL) { dir=2; s=libconf; } else return 0; ret=naccess(s,W_OK); g_free(s); if (ret==0) return dir; return -dir; } int copyconfig(void) /* copy configuration file from libdir to home dir */ { struct objlist *sys; char *libdir,*homedir,*buf; char *libname,*homename,*bak; FILE *libfp,*homefp; int r; GStatBuf sbuf; if ((sys=getobject("system"))==NULL) return FALSE; if (getobj(sys,"home_dir",0,0,NULL,&homedir)==-1) return FALSE; if (getobj(sys,"conf_dir",0,0,NULL,&libdir)==-1) return FALSE; r = nstat(homedir, &sbuf); if (r && errno == ENOENT) { r = g_mkdir(homedir, 0755); if (r) return FALSE; } else if (! S_ISDIR(sbuf.st_mode)) { return FALSE; } if (findfilename(homedir,CONFSEP,CONF)) { if ((bak=getfilename(homedir,CONFSEP,CONFBAK))!=NULL) { if (findfilename(homedir,CONFSEP,CONFBAK)) g_unlink(bak); if ((homename=getfilename(homedir,CONFSEP,CONF))!=NULL) { rename(homename,bak); g_free(homename); } g_free(bak); } } if (!findfilename(libdir,CONFSEP,CONF)) return FALSE; homename = getfilename(homedir,CONFSEP,CONF); libname = getfilename(libdir,CONFSEP,CONF); if (homename == NULL || libname == NULL) { g_free(homename); g_free(libname); return FALSE; } if (strcmp0(homename,libname)==0) { g_free(homename); g_free(libname); return FALSE; } if ((homefp=nfopen(homename,"wt"))==NULL) { return FALSE; } if ((libfp=nfopen(libname,"rt"))==NULL) { g_free(homename); fclose(homefp); g_free(libname); fclose(libfp); return FALSE; } g_free(homename); g_free(libname); while (fgetline(libfp,&buf)==0) { fputs(buf,homefp); fputs("\n",homefp); g_free(buf); } fclose(libfp); fclose(homefp); return TRUE; } ngraph-gtk-6.08.00/src/ngraph.ico0000644000175000017500000004107613070106167013423 00000000000000@@ (B(@€ @  üüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿììÿììÿììÿììÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿ€€ÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿììÿììÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿ€€ÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿììÿììÿüüÿÿüüÿüüÿüüÿüüÿüüÿüüÿÿüüÿÿÿÿüüÿ€€ÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿììÿììÿüüÿüüÿÿÿüüÿüüÿüüÿÿüüÿÿÿÿüüÿ€€ÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿììÿììÿììÿ€€ÿÿüüÿ€€€ÿüüÿÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿÿüüÿÿÿÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿÿüüÿÿÿÿ€€ÿ€€ÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿÿÿÿÿÿ€€ÿ€€ÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿÿÿÿÿ€€ÿ€€ÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿÿÿ€€ÿ€€ÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿÿÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿÿÿÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿ€€€ÿÿ€€ÿ€€ÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿüüÿÿÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿ€€ÿ€€ÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿüÿüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿüÿüÿüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿüüÿüÿüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿ€€ÿüüÿ€€ÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿÿÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿüüüÿÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿ€€ÿüüüÿüüüÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿüüüÿÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿüüüÿÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿÿÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÿüüüÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿüüüÿÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿÿÿÿÀÀÀÿÀÀÀÿÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿüüüÿÿ€€€ÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿüüüÿÿ€€€ÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÀÀÀÿÿÿÿÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿüüüÿüüüÿüüüÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿÿÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿÿÿüüüÿÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿÿÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿÀÀÀÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüüÿüüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüÿüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿüüüÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿüüüÿüüüÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿ€€€ÿðÇÿðàºá}ÀÀÂÝ À€ºÝuÀºapºp À0øðpðpðàðÀð€ððÿüÿøÿðÿàÿÀÿ€ÿþüøðàÀ€?ÿÿÿ€ÿ€ÿÀÿð?ÿüÿÿÿÿÿÀÿÿÿðÿÿÿüÿÿÿÿÿÿÿÿÀÿÿÿÿð?ÿÿÿÿüÿÿÿÿÿÿÿÿÿÿÿÀÿÿÿÿÿÿðÿÿÿÿÿÿüÿÿÿÿÿÿÿÿÿÿngraph-gtk-6.08.00/src/nstring.c0000644000175000017500000002245613070106167013301 00000000000000/* * $Id: nstring.c,v 1.10 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include "object.h" #include "nstring.h" #define NSTRLEN 0x400 char * nstrnew(void) { char *po; if ((po=g_malloc(NSTRLEN))==NULL) return NULL; po[0]='\0'; return po; } char * nstrccat(char *po,char ch) { size_t len,num; char *po2; if (po==NULL) return NULL; len=strlen(po); num=len/NSTRLEN; if (len%NSTRLEN==NSTRLEN-1) { if ((po2=g_realloc(po,NSTRLEN*(num+2)))==NULL) { g_free(po); return NULL; } po=po2; } po[len]=ch; po[len+1]='\0'; return po; } char * nstraddchar(char *po, int len, char ch) { // if (po == NULL) return NULL; if (len >= NSTRLEN - 1 && ! ((len + 1) & (NSTRLEN - 1))) { char *po2; po2 = g_realloc(po, NSTRLEN * (len / NSTRLEN + 2)); if (po2 == NULL) { g_free(po); return NULL; } po = po2; } po[len] = ch; // po[len + 1] = '\0'; return po; } char * nstrcat(char *po,char *s) { size_t i, len; /* modified */ if (po == NULL) return NULL; if (s == NULL) return po; len = strlen(po); for (i = 0; s[i] != '\0'; i++) { po = nstraddchar(po, len + i, s[i]); if (po == NULL) { return NULL; } } po[len + i] = '\0'; /* nstraddchar() is not terminate string */ return po; } #ifdef COMPILE_UNUSED_FUNCTIONS char * nstrncat(char *po,char *s,size_t n) { size_t i; if (po==NULL) return NULL; if (s==NULL) return po; for (i=0;(s[i]!='\0') && (ilen2) return 1; else return 0; } else return c; } static int wildmatch2(const char *pat, const char *s,int flags) { const char *spo,*patpo,*po; if ((s==NULL) || (pat==NULL)) return 0; spo=s; patpo=pat; while (1) { if ((*spo=='\0') && (*patpo=='\0')) return 1; else if (*patpo=='\0') return 0; else if ((flags & WILD_PATHNAME) && (*spo=='/')) { if (*patpo!='/') return 0; patpo++; spo++; } else if (*patpo=='?') { if (*spo=='\0') return 0; patpo++; spo++; } else if (*patpo=='*') { patpo++; while (1) { if (wildmatch2(patpo,spo,flags)) return 1; if (*spo=='\0') return 0; spo++; } } else if (*patpo=='[') { for(po=patpo+1;(*po!='\0') && (*po!=']');po++); if (*po=='\0') { if (*patpo==*spo) { patpo++; spo++; } else return 0; } else { patpo++; while (patpo!=po) { if ((*(patpo+1)=='-') && (*(patpo+2)!=']')) { if ((*patpo<=*spo) && (*spo<=*(patpo+2))) { patpo=po+1; spo++; break; } else patpo+=3; } else { if (*patpo==*spo) { patpo=po+1; spo++; break; } else patpo++; } } } } else if (*patpo==*spo) { patpo++; spo++; } else return 0; } } int wildmatch(const char *pat, const char *s,int flags) { if ((s==NULL) || (pat==NULL)) return 0; if (flags & WILD_PERIOD) { /* "." and ".." should not match "*" */ if (s[0]=='.') { if (pat[0]=='.') return wildmatch2(pat+1,s+1,flags); else return 0; } else return wildmatch2(pat,s,flags); } else return wildmatch2(pat,s,flags); } char * getitok(char **s, int *len, const char *ifs) { char *po,*spo; int i; if (*s == NULL) return NULL; po = *s; for (i = 0; (po[i]!='\0') && (strchr(ifs, po[i]) != NULL); i++); if (po[i]=='\0') { *len=0; return NULL; } spo=po+i; for (;(po[i]!='\0') && (strchr(ifs,po[i])==NULL);i++); *s+=i; *len=*s-spo; return spo; } char * getitok2(char **s, int *len, const char *ifs) { char *po,*s2; if ((s2 = getitok(s, len, ifs))==NULL) return NULL; if ((po=g_malloc(*len+1))==NULL) { *len=-1; return NULL; } strncpy(po,s2,*len); po[*len]='\0'; return po; } static char * get_printf_format_str(const char *str, int *len, int *pow) { int n; GString *format; if (pow) { *pow = FALSE; } if (len) { *len = 0; } n = 0; if (str[n] != '%') { return NULL; } format = g_string_new(""); if (format == NULL) { return NULL; } g_string_append_c(format, str[n]); n++; while (strchr("#0- +^", str[n])) { if (str[n] != '^') { g_string_append_c(format, str[n]); } else if (pow) { *pow = TRUE; } n++; } for (; isdigit(str[n]); n++) { g_string_append_c(format, str[n]); } if (str[n] == '.') { g_string_append_c(format, str[n]); n++; for (; isdigit(str[n]); n++) { g_string_append_c(format, str[n]); } } if (str[n] == 'l') { g_string_append_c(format, str[n]); n++; } if (str[n] == 'l') { g_string_append_c(format, str[n]); n++; } if (strchr("diouxXeEfFgGcs", str[n]) == NULL) { g_string_free(format, TRUE); return NULL; } g_string_append_c(format, str[n]); if (len) { *len = n; } return g_string_free(format, FALSE); } static char * str_to_pow(const char *str) { int n, i, len, pow; GString *pow_str; if (str == NULL) { return NULL; } n = -1; len = strlen(str); for (i = 0; i < len; i++) { if (str[i] == 'E' || str[i] == 'e') { n = i; break; } } if (n < 0) { return NULL; } pow_str = g_string_new(""); if (pow_str == NULL) { return NULL; } pow = atoi(str + n + 1); g_string_append_len(pow_str, str, n); if (pow) { g_string_append_printf(pow_str, "×10^%d@", pow); } return g_string_free(pow_str, FALSE); } int add_printf_formated_str(GString *str, const char *format, const char *arg, int *len) { int i, formated, pow; char *format2, *buf, *endptr; int vi; long long int vll; double vd; formated = FALSE; format2 = get_printf_format_str(format, &i, &pow); if (len) { *len = i; } if (format2 == NULL) { return formated; } buf = NULL; switch (format[i]) { case 'd': case 'i': case 'o': case 'u': case 'x': case 'X': if (i > 2 && strncmp(format2 + i - 2, "ll", 2) == 0) { vll = 0; if (arg) { vll = strtod(arg, &endptr); } buf = g_strdup_printf(format2, vll); }else { vi = 0; if (arg) { vi = strtod(arg, &endptr); } buf = g_strdup_printf(format2, vi); } formated = TRUE; break; case 'e': case 'E': case 'f': case 'F': case 'g': case 'G': if (i > 2 && strncmp(format2 + i - 2, "ll", 2) == 0) { break; } vd = 0.0; if (arg) { vd = strtod(arg,&endptr); } buf = g_strdup_printf(format2, vd); if (pow) { char *new_buf; new_buf = str_to_pow(buf); if (new_buf) { g_free(buf); buf = new_buf; } } formated = TRUE; break; case 's': if (i > 1 && format2[i - 1] == 'l') { break; } if (arg) { buf = g_strdup_printf(format2, arg); } formated = TRUE; break; case 'c': if (i > 1 && format2[i - 1] == 'l') { break; } if (arg) { buf = g_strdup_printf(format2, arg[0]); } formated = TRUE; break; } if (buf) { g_string_append(str, buf); g_free(buf); } g_free(format2); return formated; } #ifdef COMPILE_UNUSED_FUNCTIONS char * getitok3(char **s,int *len,char *ifs) { char *po,*spo; int i,quote; if (*s==NULL) return NULL; quote=FALSE; po=*s; for (i=0;(po[i]!='\0') && (po[i]!='"') && (strchr(ifs,po[i])!=NULL);i++); if (po[i]=='\0') { *len=0; return NULL; } if (po[i]=='"') { quote=TRUE; i++; } spo=po+i; if (quote) { for (;(po[i]!='\0') && (po[i]!='"');i++); *s+=i; *len=*s-spo; if (po[i]=='"') (*s)++; } else { for (;(po[i]!='\0') && (strchr(ifs,po[i])==NULL);i++); *s+=i; *len=*s-spo; } return spo; } char * getitok4(char **s,int *len,char *ifs) { char *po,*s2; if ((s2=getitok3(s,len,ifs))==NULL) return NULL; if ((po=g_malloc(*len+1))==NULL) { *len=-1; return NULL; } strncpy(po,s2,*len); po[*len]='\0'; return po; } #endif /* COMPILE_UNUSED_FUNCTIONS */ ngraph-gtk-6.08.00/src/oroot.c0000644000175000017500000002365013070106167012754 00000000000000/* * $Id: oroot.c,v 1.11 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include "object.h" #include "nstring.h" #include "oroot.h" #include "nconfig.h" #define NAME "object" #define PARENT NULL #define OVERSION "1.00.00" #define ERRILNAME 100 static char *rooterrorlist[]={ "illegal instance name", }; #define ERRNUM (sizeof(rooterrorlist) / sizeof(*rooterrorlist)) int obj_load_config(struct objlist *obj, N_VALUE *inst, char *title, NHASH hash) { FILE *fp; char *tok,*str,*s2; char *f1,*f2; int val; char *endptr; int len; struct obj_config *cfg; struct narray *iarray; fp = openconfig(title); if (fp == NULL) return 0; while ((tok = getconfig(fp, &str))) { s2 = str; if (nhash_get_ptr(hash, tok, (void *) &cfg) == 0) { switch (cfg->type) { case OBJ_CONFIG_TYPE_NUMERIC: f1 = getitok2(&s2, &len, " \t,"); val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') _putobj(obj, cfg->name, inst, &val); g_free(f1); break; case OBJ_CONFIG_TYPE_STRING: f1 = getitok2(&s2, &len, ""); _getobj(obj, cfg->name, inst, &f2); g_free(f2); _putobj(obj, cfg->name, inst, f1); break; case OBJ_CONFIG_TYPE_STYLE: iarray = arraynew(sizeof(int)); if (iarray) { while ((f1 = getitok2(&s2, &len, " \t,")) != NULL) { val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') arrayadd(iarray, &val); g_free(f1); } _putobj(obj, tok, inst, iarray); } break; case OBJ_CONFIG_TYPE_OTHER: if (cfg->load_proc) { cfg->load_proc(obj, inst, cfg->name, s2); } break; } } else { fprintf(stderr, "configuration '%s' in section %s is not used.\n", tok, title); } g_free(tok); g_free(str); } closeconfig(fp); return 0; } static void obj_save_config_numeric(struct objlist *obj, N_VALUE *inst, char *field, struct narray *conf) { char *str; int val; _getobj(obj, field, inst, &val); str = g_strdup_printf("%s=%d", field, val); if (str) { arrayadd(conf, &str); } } void obj_save_config_string(struct objlist *obj, N_VALUE *inst, char *field, struct narray *conf) { char *buf, *val; _getobj(obj, field, inst, &val); buf = g_strdup_printf("%s=%s", field, CHK_STR(val)); if (buf) { arrayadd(conf, &buf); } } static void obj_save_config_line_style(struct objlist *obj, N_VALUE *inst, char *field, struct narray *conf) { char *buf; int i, j, num; struct narray *iarray; _getobj(obj, field, inst, &iarray); num = arraynum(iarray); buf = g_malloc(strlen(field) + 2 + 20 * num); if (buf == NULL) return; j = 0; j += sprintf(buf, "%s=", field); for (i = 0; i < num; i++) { j += sprintf(buf + j, "%d%s", arraynget_int(iarray, i), (i == num - 1) ? "" : " "); } arrayadd(conf, &buf); } int obj_save_config(struct objlist *obj, N_VALUE *inst, char *title, struct obj_config *config, unsigned int n) { struct narray conf; unsigned int i; arrayinit(&conf, sizeof(char *)); for (i = 0; i < n; i++) { switch (config[i].type) { case OBJ_CONFIG_TYPE_NUMERIC: obj_save_config_numeric(obj, inst, config[i].name, &conf); break; case OBJ_CONFIG_TYPE_STRING: obj_save_config_string(obj, inst, config[i].name, &conf); break; case OBJ_CONFIG_TYPE_STYLE: obj_save_config_line_style(obj, inst, config[i].name, &conf); break; case OBJ_CONFIG_TYPE_OTHER: if (config[i].save_proc) { config[i].save_proc(obj, inst, config[i].name, &conf); } break; } } replaceconfig(title, &conf); arraydel2(&conf); return 0; } static int oinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int odone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int oputname(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *arg; int i; if (argc<3) return 0; arg=argv[2]; if (arg==NULL) return 0; if (!isalpha(arg[0]) && (arg[0]!='_')) { error2(obj,ERRILNAME,arg); return 1; } for (i=1;arg[i]!='\0';i++) if (!isalnum(arg[i]) && (strchr("_",arg[i])==NULL)) { error2(obj,ERRILNAME,arg); return 1; } return 0; } int oputabs(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (*(int *)(argv[2])<0) *(int *)argv[2]=0; return 0; } int oputge1(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (*(int *)(argv[2])<1) *(int *)(argv[2])=1; return 0; } int oputangle(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (*(int *)(argv[2])<0) *(int *)(argv[2])=0; else if (*(int *)(argv[2])>36000) *(int *)(argv[2])=36000; return 0; } int oputcolor(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (*(int *) (argv[2]) < 0) *(int *)(argv[2]) = 0; else if (*(int *)(argv[2]) > 255) *(int *)(argv[2]) = 255; return 0; } int oputmarktype(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int type; type = * (int *) (argv[2]); if (type < 0 || type >= MARK_TYPE_NUM) { * (int *) (argv[2]) = 0; } return 0; } int oputstyle(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int i, num, *adata; array = (struct narray *) argv[2]; num = arraynum(array); adata = arraydata(array); if (num == 1) { array = arrayadd(array, adata); if (array == NULL) { return 1; } num++; } for (i = 0; i < num; i++) { adata[i] = abs(adata[i]); } return 0; } #ifdef COMPILE_UNUSED_FUNCTIONS static void ochgobjlist(char **olist) { char *list,*objname,*field; char *ids,*ids2; int id,len; struct objlist *obj; char *endptr; N_VALUE *inst; list=*olist; objname=getitok2(&list,&len,":"); ids=getitok2(&list,&len,":"); field=list; if ((objname==NULL) || (ids==NULL)) { g_free(objname); g_free(ids); g_free(*olist); *olist=NULL; return; } obj=chkobject(objname); g_free(objname); if (ids[0]!='^') { g_free(ids); return; } ids2=ids+1; id=strtol(ids2,&endptr,0); if ((ids2[0]=='\0') || (endptr[0]!='\0')) { g_free(ids); g_free(*olist); *olist=NULL; return; } g_free(ids); if ((inst=getobjinstoid(obj,id))==NULL) { g_free(*olist); *olist=NULL; return; } _getobj(obj,"id",inst,&id); g_free(*olist); *olist=mkobjlist(obj,NULL,id,field,FALSE); return; } #endif /* COMPILE_UNUSED_FUNCTIONS */ static int osave(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct objlist *obj2; char *field, *name, *valstr; char buf[8], *list; int i, j, perm; struct narray *array; int anum; char **adata; GString *s; g_free(rval->str); rval->str = NULL; array = (struct narray *) argv[2]; anum = arraynum(array); adata = arraydata(array); obj2 = getobject(argv[0]); if (obj2 == NULL) { return 1; } if (_getobj(obj2, "name", inst, &name)) { return 1; } s = g_string_sized_new(256); if (s == NULL) { return 1; } g_string_append(s, "new "); g_string_append(s, argv[0]); if (name) { g_string_append(s, " name:"); g_string_append(s, name); } g_string_append_c(s, '\n'); for (i = 0; i < chkobjfieldnum(obj2); i++) { field = chkobjfieldname(obj2, i); for (j = 0; j < anum; j++) { if (strcmp0(field, adata[j]) == 0) { break; } } if (j == anum) { perm = chkobjperm(obj2, field); if ((perm & NREAD) && (perm & NWRITE) && strcmp0(field, "name") != 0) { valstr = NULL; g_string_append_c(s, '\t'); g_string_append(s, argv[0]); g_string_append(s, "::"); g_string_append(s, field); g_string_append_c(s, '='); if (chkobjfieldtype(obj2, field) == NOBJ) { if (_getobj(obj2, field, inst, &list)) { goto errexit; } list = chgobjlist(list); valstr = getvaluestr(obj2, field, &list, FALSE, TRUE); if (valstr == NULL) { goto errexit; } g_free(list); } else { if (_getobj(obj2, field, inst, (void *)buf)) { goto errexit; } valstr = getvaluestr(obj2, field, buf, FALSE, TRUE); if (valstr == NULL) { goto errexit; } } g_string_append(s, valstr); g_string_append_c(s, '\n'); g_free(valstr); } } } rval->str = g_string_free(s, FALSE); return 0; errexit: g_string_free(s, TRUE); g_free(valstr); return 1; } static struct objtable objectroot[] = { {"init",NVFUNC,NEXEC,oinit,NULL,0}, {"done",NVFUNC,NEXEC,odone,NULL,0}, {"id",NINT,NREAD,NULL,NULL,0}, {"oid",NINT,NREAD,NULL,NULL,0}, {"name",NSTR,NREAD|NWRITE,oputname,NULL,0}, {"save",NSFUNC,NREAD|NEXEC,osave,"sa",0}, }; #define TBLNUM (sizeof(objectroot) / sizeof(*objectroot)) void * addobjectroot(void) /* addobjectroot() returns NULL on error */ { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,objectroot,ERRNUM,rooterrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/odouble.c0000644000175000017500000000361613070106167013243 00000000000000/* * $Id: odouble.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include "object.h" #define NAME "double" #define PARENT "object" #define OVERSION "1.00.00" #define ERRILNAME 100 static char *doubleerrorlist[]={ "", }; #define ERRNUM (sizeof(doubleerrorlist) / sizeof(*doubleerrorlist)) static int doubleinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int doubledone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static struct objtable odouble[] = { {"init",NVFUNC,NEXEC,doubleinit,NULL,0}, {"done",NVFUNC,NEXEC,doubledone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NDOUBLE,NREAD|NWRITE,NULL,NULL,0}, }; #define TBLNUM (sizeof(odouble) / sizeof(*odouble)) void * adddouble(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,odouble,ERRNUM,doubleerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/gtk/0000755000175000017500000000000013375640231012310 500000000000000ngraph-gtk-6.08.00/src/gtk/init.h0000644000175000017500000000103313070106167013336 00000000000000#ifndef _INIT_HEADER #define _INIT_HEADER extern char *AppName, *AppClass, *Auther[], *Translator, *Documenter[]; #define NGRAPH_GRAPH_MIME "application/x-ngraph" #define NGRAPH_DATA_MIME "text/plain" #define NGRAPH_TEXT_MIME "text/" int OpenApplication(void); int nallocconsole(void); void nfreeconsole(void); void nforegroundconsole(void); void hide_console(void); void resotre_console(void); const char *n_getlocale(void); int n_initialize(int *argc, char ***argv); void n_save_shell_history(void); void n_finalize(void); #endif ngraph-gtk-6.08.00/src/gtk/ogra2gdk.c0000644000175000017500000000436113070106167014075 00000000000000/* * $Id: ogra2gdk.c,v 1.5 2009-11-16 09:13:05 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #include "mathfn.h" #include "object.h" #include "ioutil.h" #include "x11gui.h" #include "ogra2cairo.h" #define NAME "gra2gdk" #define PARENT "gra2cairo" #define OVERSION "1.00.00" #ifndef M_PI #define M_PI 3.141592 #endif static int g2g_init(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; int dpi; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; dpi = DPI_MAX; if (_putobj(obj, "dpi", inst, &dpi) < 0) goto Err; if (_putobj(obj, "dpix", inst, &dpi) < 0) goto Err; if (_putobj(obj, "dpiy", inst, &dpi) < 0) goto Err; _getobj(obj, "_local", inst, &local); local->pixel_dot_x = local->pixel_dot_y = dpi / (DPI_MAX * 1.0); return 0; Err: local = gra2cairo_free(obj, inst); g_free(local); return 1; } static int g2g_done(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } cairo_surface_t * gra2gdk_create_pixmap(struct gra2cairo_local *local, int w, int h, double r, double g, double b) { cairo_t *cairo; cairo_surface_t *pix; pix = cairo_image_surface_create(CAIRO_FORMAT_RGB24, w, h); cairo = cairo_create(pix); if (cairo_status(cairo) != CAIRO_STATUS_SUCCESS) { cairo_destroy(cairo); cairo_surface_destroy(pix); return NULL; } cairo_set_source_rgb(cairo, r, g, b); cairo_paint(cairo); if (local->cairo) { cairo_destroy(local->cairo); } local->cairo = cairo; return pix; } static struct objtable gra2gdk[] = { {"init", NVFUNC, NEXEC, g2g_init, NULL, 0}, {"done", NVFUNC, NEXEC, g2g_done, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, }; #define TBLNUM (sizeof(gra2gdk) / sizeof(*gra2gdk)) void * addgra2gdk() /* addgra2gdk() returns NULL on error */ { return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, gra2gdk, Gra2CairoErrMsgNum, Gra2CairoErrMsgs, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/x11dialg.h0000644000175000017500000004335613362614046014027 00000000000000/* * $Id: x11dialg.h,v 1.57 2010-02-03 01:18:12 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef GTK_DIALOG_HEADER #define GTK_DIALOG_HEADER #include "common.h" #include #include #include "object.h" #include "ogra2cairo.h" #include "x11menu.h" #define MATH_FNC_NUM 5 struct line_style { char *name, *list; int num; }; extern struct line_style FwLineStyle[]; extern char *FwNumStyle[]; extern int FwNumStyleNum; #define N_RESPONSE_ALL 1 void initdialog(void); int CopyClick(GtkWidget *parent, struct objlist *obj, int Id, char *(*callback) (struct objlist *, int)); int SetObjFieldFromWidget(GtkWidget *w, struct objlist *Obj, int Id, char *field); void SetWidgetFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); int SetObjPointsFromText(GtkWidget *w, struct objlist *Obj, int Id, char *field); void SetTextFromObjPoints(GtkWidget *w, struct objlist *Obj, int Id, char *field); int SetObjFieldFromStyle(GtkWidget *w, struct objlist *Obj, int Id, char *field); void SetStyleFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); int SetObjAxisFieldFromWidget(GtkWidget *w, struct objlist *obj, int id, char *field); struct compatible_font_info *SetFontListFromObj(GtkWidget *w, struct objlist *obj, int id, const char *name); void SetObjFieldFromFontList(GtkWidget *w, struct objlist *obj, int id, char *name); void set_color(GtkWidget *w, struct objlist *obj, int id, char *prefix); void set_color2(GtkWidget *w, struct objlist *obj, int id); void set_fill_color(GtkWidget *w, struct objlist *obj, int id); void set_stroke_color(GtkWidget *w, struct objlist *obj, int id); int putobj_color(GtkWidget *w, struct objlist *obj, int id, char *prefix); int putobj_color2(GtkWidget *w, struct objlist *obj, int id); int putobj_fill_color(GtkWidget *w, struct objlist *obj, int id); int putobj_stroke_color(GtkWidget *w, struct objlist *obj, int id); int chk_sputobjfield(struct objlist *obj, int id, char *field, char *str); const char *get_style_string(struct objlist *obj, int id, char *field); #define DIALOG_PROTOTYPE GtkWidget *parent, *widget, *focus; \ GtkBox *vbox;\ int ret, show_cancel;\ char *resource, *ok_button;\ void (*SetupWindow) (GtkWidget *w, void *data, int makewidget);\ void (*CloseWindow) (GtkWidget *w, void *data);\ struct DialogType { DIALOG_PROTOTYPE; }; struct MarkDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *parnet, *toggle[MARK_TYPE_NUM]; int Type, cb_respond; }; void MarkDialog(struct MarkDialog *data, GtkWidget *parent, int type); struct FileMath { GtkWidget *xsmooth, *x, *ysmooth, *averaging_type, *y, *f, *g, *h, *text_x, *text_y, *text_f, *text_g, *text_h; int tab_id; }; struct FileLoad { GtkWidget *headskip, *readstep, *finalline, *remark, *ifs, *csv; int tab_id; }; struct FileMask { GtkWidget *line, *list; int changed, tab_id; }; struct FileMove { GtkWidget *line, *x, *y, *list; int changed, tab_id; }; struct FileDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *file, *load_settings, *fit, *xcol, *xaxis, *ycol, *yaxis, *type, *mark_btn, *curve, *col1, *col2, *math_input_tab, *clip, *style, *size, *miter, *join, *min, *max, *div, *comment_box, *file_box, *fit_table, *width, *apply_all, *comment_view, *comment_table; GtkNotebook *tab, *math_tab; struct objlist *Obj; int Id, source, math_page; struct MarkDialog mark; int R, G, B, R2, G2, B2, alpha, multi_open, fit_row, initialized; struct FileMath math; struct FileLoad load; struct FileMask mask; struct FileMove move; char *head_lines; }; void FileDialog(struct obj_list_data *data, int id, int multi); struct EvalDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list; struct narray *sel; struct objlist *Obj; int Num; }; void EvalDialog(struct EvalDialog *data, struct objlist *obj, int num, struct narray *iarray); struct MathDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *func[MATH_FNC_NUM]; struct objlist *Obj; int Mode, modified; }; void MathDialog(struct MathDialog *data, struct objlist *obj); struct MathTextDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *text, *tree, *input_tab; GList *id_list; struct objlist *Obj; char *Text; int Mode, modified, page; }; void MathTextDialog(struct MathTextDialog *data, char *text, int mode, struct objlist *obj, GList *list, GtkWidget *tree); #define FIT_PARM_NUM 10 struct FitDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *type, *through_point, *x, *y, *dim, *weight, *min, *max, *div, *interpolation, *formula, *converge, *derivatives, *p[FIT_PARM_NUM], *d[FIT_PARM_NUM], *through_box, *usr_def_frame, *usr_def_prm_tbl, *func_label; struct objlist *Obj; int Id; int Lastid; }; void FitDialog(struct FitDialog *data, struct objlist *obj, int id); struct FitLoadDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list; struct objlist *Obj; int Sid; int sel; }; void FitLoadDialog(struct FitLoadDialog *data, struct objlist *obj, int sid); struct FitSaveDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *profile; struct objlist *Obj; int Sid; char *Profile; }; void FitSaveDialog(struct FitSaveDialog *data, struct objlist *obj, int sid); struct SectionDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *x, *y, *w, *h, *xid, *yid, *rid, *uid, *gid, *width, *height, *xaxis, *yaxis, *uaxis, *raxis, *grid; int Section; int X, Y, LenX, LenY, X0, Y0, LenX0, LenY0; int IDX, IDY, IDU, IDR, *IDG; struct objlist *Obj, *Obj2; int MaxX, MaxY; }; void SectionDialog(struct SectionDialog *data, int x, int y, int lenx, int leny, struct objlist *obj, int idx, int idy, int idu, int idr, struct objlist *obj2, int *idg, int section); struct CrossDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *x, *y, *w, *h, *xid, *yid, *width, *height, *xaxis, *yaxis; int X, Y, LenX, LenY, X0, Y0, LenX0, LenY0; int IDX, IDY; struct objlist *Obj; int MaxX, MaxY; }; void CrossDialog(struct CrossDialog *data, int x, int y, int lenx, int leny, struct objlist *obj, int idx, int idy); struct AxisBase { GtkWidget *style, *width, *color, *arrow, *arrowlen, *arrowwid, *wave, *wavelen, *wavewid, *baseline; int R, G, B, alpha, tab_id; }; struct AxisPos { GtkWidget *x, *y, *len, *direction, *adjust, *adjustpos; int tab_id; }; struct AxisFont { GtkWidget *space, *pt, *script, *font, *color, *font_bold, *font_italic; int R, G, B, alpha, tab_id; }; struct AxisNumbering { GtkWidget *num, *begin, *ster, *numnum, *head, *fraction, *add_plus, *tail, *date_format, *align, *direction, *shiftp, *shiftn, *log_power, *no_zero, *norm, *step, *math; int tab_id; }; #define GAUGE_STYLE_NUM 3 struct AxisGauge { GtkWidget *length[GAUGE_STYLE_NUM], *width[GAUGE_STYLE_NUM], *gauge, *min, *max, *style, *color; int R, G, B, alpha, tab_id; }; struct AxisDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *min, *max, *inc, *div, *scale, *ref, *clear, *margin; GtkNotebook *tab; struct objlist *Obj; int Id; struct AxisBase base; struct AxisFont font; struct AxisPos position; struct AxisGauge gauge; struct AxisNumbering numbering; }; void AxisDialog(struct obj_list_data *data, int id, int sub_id); #define GRID_DIALOG_STYLE_NUM 3 struct GridDialog { DIALOG_PROTOTYPE; /****** local member *******/ struct objlist *Obj; GtkWidget *style[GRID_DIALOG_STYLE_NUM], *width[GRID_DIALOG_STYLE_NUM], *axisx, *axisy, *background, *color, *bcolor, *draw_x, *draw_y; int Id; int R, G, B, R2, G2, B2, A; }; void GridDialog(struct GridDialog *data, struct objlist *obj, int id); struct ZoomDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *zoom_entry; int zoom; }; void ZoomDialog(struct ZoomDialog *data); struct MergeDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *file, *topmargin, *leftmargin, *zoom_x, *zoom_y; struct objlist *Obj; int Id; }; void MergeDialog(struct obj_list_data *data, int id, int Sub_id); struct LegendDialog { DIALOG_PROTOTYPE; /****** local member *******/ char *(* prop_cb) (struct objlist *obj, int id); GtkWidget *path_type, *style, *points, *interpolation, *width, *miter, *join, *color, *color2, *stroke_color, *fill_color, *x, *y, *x1, *y1, *x2, *y2, *rx, *ry, *angle1, *angle2, *pieslice, *close_path, *stroke, *fill, *fill_rule, *marker_begin, *marker_end, *arrow_length, *arrow_width, *size, *type, *view, *text, *pt, *mark_type_begin, *mark_type_end, *space, *script_size, *direction, *raw, *font, *font_bold, *font_italic; struct objlist *Obj; int Id; int R, G, B, R2, G2, B2, fill_R, fill_G, fill_B, alpha, wid, ang; struct MarkDialog mark, mark_begin, mark_end; cairo_surface_t *arrow_pixmap; }; void LegendArrowDialog(struct LegendDialog *data, struct objlist *obj, int id); void LegendRectDialog(struct LegendDialog *data, struct objlist *obj, int id); void LegendArcDialog(struct LegendDialog *data, struct objlist *obj, int id); void LegendMarkDialog(struct LegendDialog *data, struct objlist *obj, int id); void LegendTextDialog(struct LegendDialog *data, struct objlist *obj, int id); struct LegendGaussDialog { DIALOG_PROTOTYPE; /****** local member *******/ GSList *func_list, *dir_list; GtkWidget *style, *div, *color, *width, *miter, *join, *sch, *scv, *view; int R, G, B, A; struct objlist *Obj; int Id; int Minx, Miny, Wdx, Wdy; int Div, Dir; int Mode; double Position, Param; int alloc; }; void LegendGaussDialog(struct LegendGaussDialog *data, struct objlist *obj, int id, int minx, int miny, int wdx, int wdy); struct PageDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *leftmargin, *topmargin, *paperwidth, *paperheight, *paperzoom, *paper; }; void PageDialog(struct PageDialog *data); struct SwitchDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *drawlist, *objlist, *top, *up, *down, *bottom, *del, *ins, *add; int btn_lock; struct narray drawrable; struct narray idrawrable; }; void SwitchDialog(struct SwitchDialog *data); struct DirectoryDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *dir, *dir_label; }; void DirectoryDialog(struct DirectoryDialog *data); struct LoadDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *expand_file, *load_path, *dir; int expand; char *exdir; int loadpath; int Id; }; void LoadDialog(struct LoadDialog *data); struct SaveDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *path, *include_data, *include_merge; int Path; int *SaveData, *SaveMerge; }; void SaveDialog(struct SaveDialog *data, int *sdata, int *smerge); struct DriverDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *driver, *file, *option; char *ext; struct objlist *Obj; int Id; }; void DriverDialog(struct DriverDialog *data, struct objlist *obj, int id); struct PrintDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *driver, *print, *option; struct objlist *Obj; int Id; }; void PrintDialog(struct PrintDialog *data, struct objlist *obj, int id); struct OutputDataDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *div_entry; int div; }; void OutputDataDialog(struct OutputDataDialog *data, int div); struct DefaultDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *viewer, *external_driver, *addin_script, *misc, *external_viewer, *fonts; }; void DefaultDialog(struct DefaultDialog *data); struct SetScriptDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *addins, *name, *script, *option, *description; struct script *Script; }; void SetScriptDialog(struct SetScriptDialog *data, struct script *sc); struct PrefScriptDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *update_b, *del_b, *up_b, *down_b; }; void PrefScriptDialog(struct PrefScriptDialog *data); struct SetDriverDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *name, *driver, *option, *ext; struct extprinter *Driver; }; void SetDriverDialog(struct SetDriverDialog *data, struct extprinter *prn); struct PrefDriverDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *update_b, *del_b, *up_b, *down_b; }; void PrefDriverDialog(struct PrefDriverDialog *data); struct PrefFontDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *update_b, *del_b, *up_b, *down_b; }; void PrefFontDialog(struct PrefFontDialog *data); struct FontSettingDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *list, *alias, *font_b, *add_b, *del_b, *up_b, *down_b; const gchar *alias_str, *font_str, *alternative_str; int is_update; }; void FontSettingDialog(struct FontSettingDialog *d, const char *alias, const char *font, const char *alternative); struct MiscDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *editor, *directory, *path, *datafile, *expand, *expanddir, *loadpath, *mergefile, *coordwin_font, *infowin_font, *file_preview_font, *hist_size, *info_size, *data_head_lines, *help_browser, *browser, *use_opacity, *select_data, *use_custom_palette, *source_style; struct objlist *Obj; struct narray tmp_palette; int Id; }; void MiscDialog(struct MiscDialog *data, struct objlist *obj, int id); struct ExViewerDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *dpi, *width, *height, *use_external; struct objlist *Obj; int Id; }; void ExViewerDialog(struct ExViewerDialog *data); struct ViewerDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *dpi, *loadfile, *grid, *data_num, *antialias, *fftype, *bgcol, *preserve_width; struct objlist *Obj; int Id; int Clear; int dpis; }; void ViewerDialog(struct ViewerDialog *data, struct objlist *obj, int id); struct SelectDialog { DIALOG_PROTOTYPE; /****** local member *******/ struct narray *sel, *isel; struct objlist *Obj; char *Field; GtkWidget *list; const char *title; char *(*cb) (struct objlist * obj, int id); }; void SelectDialog(struct SelectDialog *data, struct objlist *obj, const char *title, char *(*callback) (struct objlist * obj, int id), struct narray *array, struct narray *iarray); struct CopyDialog { DIALOG_PROTOTYPE; /****** local member *******/ struct objlist *Obj; int Id; int sel; GtkWidget *list; const char *title; char *(*cb) (struct objlist * obj, int id); }; void CopyDialog(struct CopyDialog *data, struct objlist *obj, int id, const char *title, char *(*callback) (struct objlist * obj, int id)); struct OutputImageDialog { DIALOG_PROTOTYPE; /****** local member *******/ GtkWidget *version, *t2p, *dpi, *use_opacity; int Version, text2path, Dpi, DlgType, UseOpacity; }; void OutputImageDialog(struct OutputImageDialog *data, int type); extern struct FileDialog DlgFile; extern struct FileDialog DlgRange; extern struct FileDialog DlgArray; extern struct FileDialog DlgFileDef; extern struct EvalDialog DlgEval; extern struct MathDialog DlgMath; extern struct MathTextDialog DlgMathText; extern struct FitDialog DlgFit; extern struct FitLoadDialog DlgFitLoad; extern struct FitSaveDialog DlgFitSave; extern struct FileMoveDialog DlgFileMove; extern struct FileMaskDialog DlgFileMask; extern struct SectionDialog DlgSection; extern struct CrossDialog DlgCross; extern struct AxisDialog DlgAxis; extern struct GridDialog DlgGrid; extern struct ZoomDialog DlgZoom; extern struct AxisBaseDialog DlgAxisBase; extern struct AxisPosDialog DlgAxisPos; extern struct NumDialog DlgNum; extern struct AxisFontDialog DlgAxisFont; extern struct GaugeDialog DlgGauge; extern struct MergeDialog DlgMerge; extern struct LegendDialog DlgLegendArrow; extern struct LegendDialog DlgLegendRect; extern struct LegendDialog DlgLegendArc; extern struct LegendDialog DlgLegendMark; extern struct LegendDialog DlgLegendText; extern struct LegendDialog DlgLegendTextDef; extern struct LegendGaussDialog DlgLegendGauss; extern struct PageDialog DlgPage; extern struct SwitchDialog DlgSwitch; extern struct DirectoryDialog DlgDirectory; extern struct LoadDialog DlgLoad; extern struct SaveDialog DlgSave; extern struct DriverDialog DlgDriver; extern struct PrintDialog DlgPrinter; extern struct OutputDataDialog DlgOutputData; extern struct DefaultDialog DlgDefault; extern struct SetScriptDialog DlgSetScript; extern struct PrefScriptDialog DlgPrefScript; extern struct SetDriverDialog DlgSetDriver; extern struct PrefDriverDialog DlgPrefDriver; extern struct PrefFontDialog DlgPrefFont; extern struct FontSettingDialog DlgFontSetting; extern struct MiscDialog DlgMisc; extern struct ExViewerDialog DlgExViewer; extern struct ViewerDialog DlgViewer; extern struct SelectDialog DlgSelect; extern struct CopyDialog DlgCopy; extern struct OutputImageDialog DlgImageOut; #endif ngraph-gtk-6.08.00/src/gtk/gtk_subwin.c0000644000175000017500000010055713351432267014562 00000000000000/* * $Id: gtk_subwin.c,v 1.68 2010-04-01 06:08:23 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include "dir_defs.h" #include "object.h" #include "nstring.h" #include "mathfn.h" #include "init.h" #include "ox11menu.h" #include "x11menu.h" #include "x11view.h" #include "x11gui.h" #include "x11dialg.h" #include "gtk_liststore.h" #include "gtk_widget.h" #include "gtk_combo.h" #include "gtk_subwin.h" #define DOUBLE_CLICK_PERIOD 250 static void hidden(struct obj_list_data *d); static void modify_numeric(struct obj_list_data *d, char *field, int val); static void modify_string(struct obj_list_data *d, char *field, char *str); static void toggle_boolean(struct obj_list_data *d, char *field, int sel); void set_cell_attribute_source(struct SubWin *d, const char *attr, int target_column, int source_column) { GList *list; GtkTreeViewColumn *col; GtkCellRenderer *renderer; col = gtk_tree_view_get_column(GTK_TREE_VIEW(d->data.data->text), target_column); list = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col)); if (list == NULL) { return; } if (list->data == NULL) { return; } renderer = list->data; gtk_tree_view_column_add_attribute(col, renderer, attr, source_column); g_list_free(list); } static void file_select(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { struct obj_list_data *d; int sel, num; char *file, *ext; GtkWidget *parent; d = user_data; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } ext = NULL; if (chkobjfield(d->obj, "ext") == 0) { getobj(d->obj, "ext", sel, 0, NULL, &ext); } parent = TopLevel; if (nGetOpenFileName(parent, _("Open"), ext, NULL, gtk_entry_get_text(w), &file, TRUE, Menulocal.changedirectory) == IDOK && file) { if (file) { gtk_entry_set_text(w, file); modify_string(d, "file", file); g_free(file); } } } static void select_enum(GtkComboBox *w, gpointer user_data) { int j, val, sel; struct obj_list_data *d; n_list_store *list; d = (struct obj_list_data *) user_data; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); if (sel < 0) { return; } list = g_object_get_data(G_OBJECT(w), "user-data"); getobj(d->obj, list->name, sel, 0, NULL, &val); j = combo_box_get_active(GTK_WIDGET(w)); if (j < 0 || j == val) return; menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); if (putobj(d->obj, list->name, sel, &j) >= 0) { d->select = sel; } } static void start_editing_enum(GtkCellEditable *editable, struct obj_list_data *d, n_list_store *list) { GtkComboBox *cbox; int sel, type; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); cbox = GTK_COMBO_BOX(editable); g_object_set_data(G_OBJECT(cbox), "user-data", list); SetWidgetFromObjField(GTK_WIDGET(cbox), d->obj, sel, list->name); getobj(d->obj, list->name, sel, 0, NULL, &type); combo_box_set_active(GTK_WIDGET(cbox), type); d->select = -1; g_signal_connect(cbox, "changed", G_CALLBACK(select_enum), d); } #if GTK_CHECK_VERSION(3, 8, 0) && ! GTK_CHECK_VERSION(3, 18, 0) static void spin_button_size_allocated(GtkWidget *widget, GdkRectangle *allocation, gpointer user_data) { GtkRequisition requisition; GdkRectangle new_allocation; gtk_widget_get_preferred_size(widget, &requisition, NULL); if (requisition.width <= allocation->width) { return; } new_allocation = *allocation; new_allocation.x -= (requisition.width - allocation->width) / 2; new_allocation.width = requisition.width; gtk_widget_size_allocate(widget, &new_allocation); } #endif static void start_editing(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data) { GtkTreeView *view; GtkTreeModel *model; GtkTreeIter iter; n_list_store *list; struct obj_list_data *d; menu_lock(TRUE); UnFocus(); d = user_data; view = GTK_TREE_VIEW(d->text); model = gtk_tree_view_get_model(view); list = (n_list_store *) g_object_get_data(G_OBJECT(renderer), "user-data"); if (list == NULL) return; if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) return; list_store_select_iter(GTK_WIDGET(view), &iter); switch (list->type) { case G_TYPE_ENUM: start_editing_enum(editable, d, list); break; case G_TYPE_STRING: if (GTK_IS_ENTRY(editable)) { int sel; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); if (chkobjfieldtype(d->obj, list->name) == NDOUBLE) { char buf[64]; double val; getobj(d->obj, list->name, sel, 0, NULL, &val); snprintf(buf, sizeof(buf), "%.15g", val); gtk_entry_set_text(GTK_ENTRY(editable), buf); } else { char *valstr; if (strcmp(list->name, "file") == 0) { gtk_entry_set_icon_from_icon_name(GTK_ENTRY(editable), GTK_ENTRY_ICON_SECONDARY, "document-open-symbolic"); g_signal_connect(editable, "icon-release", G_CALLBACK(file_select), d); } sgetobjfield(d->obj, sel, list->name, NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { gtk_entry_set_text(GTK_ENTRY(editable), CHK_STR(valstr)); g_free(valstr); } } } break; case G_TYPE_DOUBLE: case G_TYPE_INT: if (GTK_IS_SPIN_BUTTON(editable)) { #if GTK_CHECK_VERSION(3, 8, 0) && ! GTK_CHECK_VERSION(3, 18, 0) g_signal_connect(editable, "size-allocate", G_CALLBACK(spin_button_size_allocated), NULL); #endif gtk_entry_set_alignment(GTK_ENTRY(editable), 1.0); gtk_spin_button_set_numeric(GTK_SPIN_BUTTON(editable), FALSE); if (list->max == 36000) { gtk_spin_button_set_wrap(GTK_SPIN_BUTTON(editable), TRUE); } } break; } } static void cancel_editing(GtkCellRenderer *renderer, gpointer user_data) { menu_lock(FALSE); if (user_data) { struct obj_list_data *d; d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); } } static void toggle_cb(GtkCellRendererToggle *cell_renderer, gchar *path, gpointer user_data) { struct obj_list_data *d; n_list_store *list; long int sel; GtkTreeModel *model; GtkTreeIter iter; d = user_data; list = (n_list_store *) g_object_get_data(G_OBJECT(cell_renderer), "user-data"); if (list == NULL) { return; } model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->text)); if (model == NULL) { return; } if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, COL_ID, &sel, -1); toggle_boolean(d, list->name, sel); } static void enum_cb(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { struct obj_list_data *d; menu_lock(FALSE); d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); if (str == NULL || d->select < 0) return; d->update(d, FALSE, TRUE); set_graph_modified(); } static void numeric_cb(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { GtkTreeView *view; GtkTreeModel *model; struct obj_list_data *d; n_list_store *list; double val; int ecode; menu_lock(FALSE); d = user_data; if (str == NULL) return; view = GTK_TREE_VIEW(d->text); model = gtk_tree_view_get_model(view); list = (n_list_store *) g_object_get_data(G_OBJECT(cell_renderer), "user-data"); if (list == NULL) return; ecode = str_calc(str, &val, NULL, NULL); if (ecode || val != val || val == HUGE_VAL || val == - HUGE_VAL) { return; } if (list->type == G_TYPE_DOUBLE || list->type == G_TYPE_FLOAT) val *= 100; if (G_TYPE_CHECK_INSTANCE_TYPE(model, GTK_TYPE_LIST_STORE)) { modify_numeric(d, list->name, nround(val)); } } static void string_cb(GtkCellRenderer *renderer, gchar *path, gchar *str, gpointer user_data) { GtkTreeView *view; GtkTreeModel *model; GtkTreeIter iter; struct obj_list_data *d; n_list_store *list; menu_lock(FALSE); d = user_data; view = GTK_TREE_VIEW(d->text); model = gtk_tree_view_get_model(view); list = (n_list_store *) g_object_get_data(G_OBJECT(renderer), "user-data"); if (list == NULL) return; if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) return; list_store_select_iter(GTK_WIDGET(view), &iter); if (G_TYPE_CHECK_INSTANCE_TYPE(model, GTK_TYPE_LIST_STORE)) { modify_string(d, list->name, str); } } static void set_cell_renderer_cb(struct obj_list_data *d, int n, n_list_store *list, GtkWidget *w) { int i; GtkTreeViewColumn *col; GtkCellRenderer *rend; GtkTreeView *view; GList *glist; view = GTK_TREE_VIEW(w); for (i = 0; i < n; i++) { if (! list[i].editable) continue; col = gtk_tree_view_get_column(view, i); glist = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col)); rend = GTK_CELL_RENDERER(glist->data); g_list_free(glist); switch (list[i].type) { case G_TYPE_BOOLEAN: g_signal_connect(rend, "toggled", G_CALLBACK(toggle_cb), d); break; case G_TYPE_DOUBLE: case G_TYPE_INT: list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(numeric_cb), d); g_signal_connect(rend, "editing-started", G_CALLBACK(start_editing), d); g_signal_connect(rend, "editing-canceled", G_CALLBACK(cancel_editing), NULL); break; case G_TYPE_ENUM: list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(enum_cb), d); g_signal_connect(rend, "editing-started", G_CALLBACK(start_editing), d); g_signal_connect(rend, "editing-canceled", G_CALLBACK(cancel_editing), d); break; case G_TYPE_STRING: list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(string_cb), d); g_signal_connect(rend, "editing-started", G_CALLBACK(start_editing), d); g_signal_connect(rend, "editing-canceled", G_CALLBACK(cancel_editing), NULL); break; } } } static GtkCellRenderer * get_cell_renderer_from_tree_view(GtkWidget *view, int i) { GtkTreeViewColumn *col; GtkCellRenderer *rend; GList *glist; col = gtk_tree_view_get_column(GTK_TREE_VIEW(view), i); glist = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col)); rend = GTK_CELL_RENDERER(glist->data); g_list_free(glist); return rend; } void set_editable_cell_renderer_cb(struct obj_list_data *d, int i, n_list_store *list, GCallback end) { GtkCellRenderer *rend; if (list == NULL || end == NULL || i < 0) return; if (! list[i].editable) return; rend = get_cell_renderer_from_tree_view(d->text, i); if (list[i].edited_id) { g_signal_handler_disconnect(rend, list[i].edited_id); } list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(end), d); } static void combo_edited_cb(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { struct obj_list_data *d; menu_lock(FALSE); d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); } void set_combo_cell_renderer_cb(struct obj_list_data *d, int i, n_list_store *list, GCallback start, GCallback end) { GtkCellRenderer *rend; if (list == NULL || i < 0) return; if (! list[i].editable || (list[i].type != G_TYPE_ENUM && list[i].type != G_TYPE_PARAM)) return; rend = get_cell_renderer_from_tree_view(d->text, i); if (list[i].edited_id) { g_signal_handler_disconnect(rend, list[i].edited_id); } if (end) { list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(end), d); } else { list[i].edited_id = g_signal_connect(rend, "edited", G_CALLBACK(combo_edited_cb), d); } if (start) g_signal_connect(rend, "editing-started", G_CALLBACK(start), d); g_signal_connect(rend, "editing-canceled", G_CALLBACK(cancel_editing), d); } void set_obj_cell_renderer_cb(struct obj_list_data *d, int i, n_list_store *list, GCallback start) { GtkCellRenderer *rend; if (list == NULL || i < 0) return; if (! list[i].editable || list[i].type != G_TYPE_OBJECT) return; rend = get_cell_renderer_from_tree_view(d->text, i); if (start) g_signal_connect(rend, "editing-started", G_CALLBACK(start), d); g_signal_connect(rend, "editing-canceled", G_CALLBACK(cancel_editing), d); } void update_viewer(struct obj_list_data *d) { char *objects[2]; objects[0] = d->obj->name; objects[1] = NULL; ViewerWinUpdate(objects); } static void obj_copy(struct objlist *obj, int dest, int src) { char *field[] = {"name", NULL}; copy_obj_field(obj, dest, src, field); } static void copy(struct obj_list_data *d) { int sel, id, num, undo; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel >= 0 && sel <= num) { undo = menu_save_undo_single(UNDO_TYPE_COPY, d->obj->name); id = newobj(d->obj); if (id < 0) { menu_delete_undo(undo); return; } obj_copy(d->obj, id, sel); set_graph_modified(); d->select = id; d->update(d, FALSE, TRUE); } } static void delete(struct obj_list_data *d) { int sel, num; int update; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } UnFocus(); menu_save_undo_single(UNDO_TYPE_DELETE, d->obj->name); if (d->delete) { d->delete(d, sel); } else { delobj(d->obj, sel); } num = chkobjlastinst(d->obj); if (num < 0) { d->select = -1; update = TRUE; } else if (sel > num) { d->select = num; update = FALSE; } else { d->select = sel; update = FALSE; } d->update(d, update, TRUE); set_graph_modified(); } static void move_top(struct obj_list_data *d) { int sel, num; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } UnFocus(); menu_save_undo_single(UNDO_TYPE_ORDER, d->obj->name); movetopobj(d->obj, sel); d->select = 0; d->update(d, FALSE, TRUE); set_graph_modified(); } static void move_last(struct obj_list_data *d) { int sel, num; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } menu_save_undo_single(UNDO_TYPE_ORDER, d->obj->name); movelastobj(d->obj, sel); d->select = num; d->update(d, FALSE, TRUE); set_graph_modified(); } static void move_up(struct obj_list_data *d) { int sel, num; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 1) && (sel <= num)) { menu_save_undo_single(UNDO_TYPE_ORDER, d->obj->name); moveupobj(d->obj, sel); d->select = sel - 1; d->update(d, FALSE, TRUE); set_graph_modified(); } } static void move_down(struct obj_list_data *d) { int sel, num; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel < num)) { menu_save_undo_single(UNDO_TYPE_ORDER, d->obj->name); movedownobj(d->obj, sel); d->select = sel + 1; d->update(d, FALSE, TRUE); set_graph_modified(); } } static void update(struct obj_list_data *d) { int sel, ret, num, undo; GtkWidget *parent; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } parent = TopLevel; d->setup_dialog(d, sel, -1); d->select = sel; if (d->undo_save) { undo = d->undo_save(UNDO_TYPE_EDIT); } else { undo = menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); } ret = DialogExecute(parent, d->dialog); set_graph_modified(); switch (ret) { case IDCANCEL: menu_undo_internal(undo); break; case IDDELETE: if (d->delete) { d->delete(d, sel); } else { delobj(d->obj, sel); } d->select = -1; d->update(d, FALSE, DRAW_REDRAW); break; default: d->update(d, FALSE, DRAW_NOTIFY); } } static void focus(struct obj_list_data *d, int add) { int sel, num; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) Focus(d->obj, sel, add); } static void toggle_boolean(struct obj_list_data *d, char *field, int sel) { int v1, num; if (Menulock || Globallock) return; num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); getobj(d->obj, field, sel, 0, NULL, &v1); v1 = ! v1; if (putobj(d->obj, field, sel, &v1) < 0) { return; } d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } static void modify_numeric(struct obj_list_data *d, char *field, int val) { int sel, v1, v2, num, undo; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } undo = menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); getobj(d->obj, field, sel, 0, NULL, &v1); if (putobj(d->obj, field, sel, &val) < 0) { return; } getobj(d->obj, field, sel, 0, NULL, &v2); if (v1 != v2) { d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } else { menu_delete_undo(undo); } } static void modify_string(struct obj_list_data *d, char *field, char *str) { int sel, num, undo; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } undo = menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); if (chk_sputobjfield(d->obj, sel, field, str)) { menu_delete_undo(undo); return; } d->select = sel; d->update(d, FALSE, TRUE); } static void hidden(struct obj_list_data *d) { int sel, num; int hidden; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } UnFocus(); menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); getobj(d->obj, "hidden", sel, 0, NULL, &hidden); hidden = hidden ? FALSE : TRUE; putobj(d->obj, "hidden", sel, &hidden); d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } static void set_hidden_state(struct obj_list_data *d, int hide) { int sel, num; int hidden; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } getobj(d->obj, "hidden", sel, 0, NULL, &hidden); if (hidden != hide) { putobj(d->obj, "hidden", sel, &hide); d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } } #if ! GTK_CHECK_VERSION(3, 22, 0) static void popup_menu_position(GtkMenu *menu, gint *x, gint *y, gboolean *push_in, gpointer user_data) { GtkWidget *w; GdkWindow *gdk_win; w = user_data; gdk_win = gtk_widget_get_window(w); gdk_window_get_origin(gdk_win, x, y); } #endif static void do_popup(GdkEventButton *event, struct obj_list_data *d) { #if GTK_CHECK_VERSION(3, 22, 0) if (d->parent->type == TypeFileWin || d->parent->type == TypeAxisWin || d->parent->type == TypeMergeWin || d->parent->type == TypePathWin || d->parent->type == TypeRectWin || d->parent->type == TypeArcWin || d->parent->type == TypeMarkWin || d->parent->type == TypeTextWin) { d->select = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); } gtk_menu_popup_at_pointer(GTK_MENU(d->popup), ((GdkEvent *)event)); #else int button, event_time; GtkMenuPositionFunc func; if (event) { event_time = event->time; func = NULL; } else { event_time = gtk_get_current_event_time(); func = popup_menu_position; } if (d->parent->type == TypeFileWin || d->parent->type == TypeAxisWin || d->parent->type == TypeMergeWin || d->parent->type == TypeLegendWin) { d->select = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); } /* If the menu popup was initiated by something other than a mouse button press, such as a mouse button release or a keypress, button should be 0. */ button = 0; gtk_menu_popup(GTK_MENU(d->popup), NULL, NULL, func, d->text, button, event_time); #endif } static gboolean ev_button_down(GtkWidget *w, GdkEventButton *event, gpointer user_data) { struct obj_list_data *d; static guint32 time = 0; int tdif; if (Menulock || Globallock) return FALSE; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); tdif = event->time - time; time = event->time; /* following check is necessary for editable column. */ if (tdif > 0 && tdif < DOUBLE_CLICK_PERIOD) return TRUE; d = user_data; switch (event->button) { case 1: if (event->type == GDK_2BUTTON_PRESS) { update(d); return TRUE; } break; } return FALSE; } static gboolean ev_button_up(GtkWidget *w, GdkEventButton *event, gpointer user_data) { struct obj_list_data *d; if (Menulock || Globallock) return FALSE; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); d = user_data; switch (event->button) { case 3: if (d->popup) { do_popup(event, d); return TRUE; } break; } return FALSE; } static gboolean ev_key_down(GtkWidget *w, GdkEvent *event, gpointer user_data) { struct obj_list_data *d; GdkEventKey *e; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); if (Menulock || Globallock) return TRUE; d = user_data; e = (GdkEventKey *)event; if (d->ev_key && d->ev_key(w, event, user_data)) return TRUE; switch (e->keyval) { case GDK_KEY_Delete: delete(d); break; case GDK_KEY_Insert: copy(d); break; case GDK_KEY_Home: if (e->state & GDK_SHIFT_MASK) move_top(d); else return FALSE; break; case GDK_KEY_End: if (e->state & GDK_SHIFT_MASK) move_last(d); else return FALSE; break; case GDK_KEY_Up: if (e->state & GDK_SHIFT_MASK) move_up(d); else return FALSE; break; case GDK_KEY_Down: if (e->state & GDK_SHIFT_MASK) move_down(d); else return FALSE; break; case GDK_KEY_Return: if (e->state & GDK_SHIFT_MASK) { e->state &= ~ GDK_SHIFT_MASK; return FALSE; } update(d); break; case GDK_KEY_BackSpace: hidden(d); break; case GDK_KEY_space: if (e->state & GDK_CONTROL_MASK) return FALSE; if (! d->can_focus) return FALSE; if (e->state & GDK_SHIFT_MASK) { list_sub_window_add_focus(NULL, d); } else { list_sub_window_focus(NULL, d); } break; default: return FALSE; } return TRUE; } #if WINDOWS #include static void hide_minimize_menu_item(GtkWidget *widget, gpointer user_data) { HWND handle; HMENU menu; handle = GDK_WINDOW_HWND(gtk_widget_get_window(widget)); menu = GetSystemMenu(handle, FALSE); RemoveMenu(menu, SC_MINIMIZE, MF_BYCOMMAND); } #endif gboolean focus_in(GtkWidget *widget, GdkEvent *event, gpointer user_data) { gtk_grab_add(GTK_WIDGET(widget)); return FALSE; } gboolean focus_out(GtkWidget *widget, GdkEvent *event, gpointer user_data) { gtk_grab_remove(GTK_WIDGET(widget)); return FALSE; } static void swin_realized(GtkWidget *widget, gpointer user_data) { struct obj_list_data *ptr; ptr = (struct obj_list_data *) user_data; ptr->update(ptr, TRUE, TRUE); } GtkWidget * text_sub_window_create(struct SubWin *d) { GtkWidget *view, *swin; GtkTextBuffer *buf; buf = gtk_text_buffer_new(NULL); view = gtk_text_view_new_with_buffer(buf); gtk_text_view_set_editable(GTK_TEXT_VIEW(view), FALSE); gtk_text_view_set_cursor_visible(GTK_TEXT_VIEW(view), FALSE); d->data.text = view; swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), view); d->Win = swin; return swin; } GtkWidget * label_sub_window_create(struct SubWin *d) { GtkWidget *label, *swin; label = gtk_label_new(NULL); gtk_widget_set_halign(label, GTK_ALIGN_START); gtk_widget_set_valign(label, GTK_ALIGN_START); gtk_label_set_selectable(GTK_LABEL(label), TRUE); gtk_label_set_line_wrap(GTK_LABEL(label), FALSE); gtk_label_set_single_line_mode(GTK_LABEL(label), FALSE); d->data.text = label; swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); #if GTK_CHECK_VERSION(3, 8, 0) gtk_container_add(GTK_CONTAINER(swin), label); #else gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(swin), label); #endif d->Win = swin; return swin; } static gboolean list_focused(GtkWidget *widget, GdkEvent *ev, gpointer user_data) { set_focus_insensitive(&NgraphApp.Viewer); return FALSE; } static struct obj_list_data * list_widget_create(struct SubWin *d, int lisu_num, n_list_store *list, int can_focus, GtkWidget **w) { struct obj_list_data *data; GtkWidget *lstor, *swin; GList *rend_list, *col_list, *col; data = g_malloc0(sizeof(*data)); data->select = -1; data->parent = d; data->undo_save = NULL; data->can_focus = can_focus; data->list = list; data->list_col_num = lisu_num; lstor = list_store_create(lisu_num, list); data->text = lstor; set_cell_renderer_cb(data, lisu_num, list, lstor); g_signal_connect(lstor, "button-press-event", G_CALLBACK(ev_button_down), data); g_signal_connect(lstor, "button-release-event", G_CALLBACK(ev_button_up), data); g_signal_connect(lstor, "key-press-event", G_CALLBACK(ev_key_down), data); /* to handle key-press-event correctly in single window mode */ g_signal_connect(lstor, "focus-in-event", G_CALLBACK(list_focused), NULL); gtk_tree_view_set_enable_search(GTK_TREE_VIEW(lstor), TRUE); gtk_tree_view_set_search_column(GTK_TREE_VIEW(lstor), COL_ID); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), lstor); col_list = gtk_tree_view_get_columns(GTK_TREE_VIEW(lstor)); for (col = g_list_next(col_list); col; col = g_list_next(col)) { rend_list = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col->data)); gtk_tree_view_column_add_attribute(GTK_TREE_VIEW_COLUMN(col->data), GTK_CELL_RENDERER(rend_list->data), "sensitive", 0); g_list_free(rend_list); } g_list_free(col_list); g_signal_connect(swin, "realize", G_CALLBACK(swin_realized), data); *w = swin; return data; } GtkWidget * list_sub_window_create(struct SubWin *d, int lisu_num, n_list_store *list) { GtkWidget *swin; struct obj_list_data *data; data = list_widget_create(d, lisu_num, list, d->type != TypeFileWin, &swin); d->data.data = data; d->Win = swin; return swin; } gboolean list_sub_window_must_rebuild(struct obj_list_data *d) { int n, num; num = chkobjlastinst(d->obj); n = list_store_get_num(GTK_WIDGET(d->text)); return (n != num + 1); } void list_sub_window_build(struct obj_list_data *d, list_sub_window_set_val_func func) { GtkTreeIter iter; int i, num; num = chkobjlastinst(d->obj); list_store_clear(d->text); for (i = 0; i <= num; i++) { list_store_append(GTK_WIDGET(d->text), &iter); func(d, &iter, i); } } void list_sub_window_set(struct obj_list_data *d, list_sub_window_set_val_func func) { GtkTreeIter iter; int i, num; gboolean state; state = list_store_get_iter_first(GTK_WIDGET(d->text), &iter); if (! state) return; num = chkobjlastinst(d->obj); for (i = 0; i <= num; i++) { func(d, &iter, i); if (! list_store_iter_next(GTK_WIDGET(d->text), &iter)) { break; } } } void list_sub_window_delete(GtkMenuItem *item, gpointer user_data) { delete((struct obj_list_data *) user_data); } void list_sub_window_copy(GtkMenuItem *item, gpointer user_data) { copy((struct obj_list_data *) user_data); } void list_sub_window_move_top(GtkMenuItem *item, gpointer user_data) { move_top((struct obj_list_data *) user_data); } void list_sub_window_move_last(GtkMenuItem *item, gpointer user_data) { move_last((struct obj_list_data *) user_data); } void list_sub_window_move_up(GtkMenuItem *item, gpointer user_data) { move_up((struct obj_list_data *) user_data); } void list_sub_window_move_down(GtkMenuItem *item, gpointer user_data) { move_down((struct obj_list_data *) user_data); } void list_sub_window_update(GtkMenuItem *item, gpointer user_data) { update((struct obj_list_data *) user_data); } void list_sub_window_hide(GtkMenuItem *item, gpointer user_data) { int hide; hide = gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(item)); set_hidden_state((struct obj_list_data *)user_data, ! hide); } void list_sub_window_focus(GtkMenuItem *item, gpointer user_data) { focus((struct obj_list_data *) user_data, FALSE); } void list_sub_window_add_focus(GtkMenuItem *item, gpointer user_data) { focus((struct obj_list_data *) user_data, TRUE); } static gboolean ev_popup_menu(GtkWidget *w, gpointer client_data) { struct obj_list_data *d; if (Menulock || Globallock) return TRUE; d = (struct obj_list_data *) client_data; do_popup(NULL, d); return TRUE; } static int set_object_name(struct objlist *obj, int id) { char *name, *new_name, buf[256]; int r; getobj(obj, "name", id, 0, NULL, &name); new_name = NULL; snprintf(buf, sizeof(buf), "%s:%d:name", chkobjectname(obj), id); r = DialogInput(TopLevel, _("Instance name"), buf, name, NULL, NULL, &new_name, NULL, NULL); if (r != IDOK) { return 0; } if (g_strcmp0(name, new_name) == 0) { return 0; } if (new_name == NULL) { putobj(obj, "name", id, new_name); return 1; } g_strstrip(new_name); if (new_name[0] == '\0') { g_free(new_name); new_name = NULL; } if (putobj(obj, "name", id, new_name) < 0) { g_free(new_name); return 0; } return 1; } void list_sub_window_object_name(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data*) client_data; int sel, update, num; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { return; } update = set_object_name(d->obj, sel); if (update) { set_graph_modified(); } } static GtkWidget * create_popup_menu_sub(struct obj_list_data *d, int top, struct subwin_popup_list *list) { GtkWidget *menu, *item, *submenu; int i; menu = gtk_menu_new(); for (i = 0; list[i].type != POP_UP_MENU_ITEM_TYPE_END; i++) { switch (list[i].type) { case POP_UP_MENU_ITEM_TYPE_NORMAL: item = gtk_menu_item_new_with_mnemonic(_(list[i].title)); g_signal_connect(item, "activate", list[i].func, d); break; case POP_UP_MENU_ITEM_TYPE_CHECK: item = gtk_check_menu_item_new_with_mnemonic(_(list[i].title)); g_signal_connect(item, "toggled", list[i].func, d); break; case POP_UP_MENU_ITEM_TYPE_MENU: item = gtk_menu_item_new_with_mnemonic(_(list[i].title)); submenu = create_popup_menu_sub(d, FALSE, list[i].submenu); gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu); break; case POP_UP_MENU_ITEM_TYPE_RECENT_DATA: item = gtk_menu_item_new_with_mnemonic(_(list[i].title)); submenu = create_recent_menu(RECENT_TYPE_DATA); gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu); break; case POP_UP_MENU_ITEM_TYPE_SEPARATOR: default: item = gtk_separator_menu_item_new(); break; } if (top) { d->popup_item[i] = item; } gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); } return menu; } GtkWidget * sub_win_create_popup_menu(struct obj_list_data *d, int n, struct subwin_popup_list *list, GCallback cb) { GtkWidget *menu; if (d->popup_item) g_free(d->popup_item); d->popup_item = g_malloc(sizeof(GtkWidget *) * n); menu = create_popup_menu_sub(d, TRUE, list); d->popup = menu; gtk_widget_show_all(menu); gtk_menu_attach_to_widget(GTK_MENU(menu), GTK_WIDGET(d->text), NULL); g_signal_connect(d->text, "popup-menu", G_CALLBACK(ev_popup_menu), d); if (cb) g_signal_connect(menu, "show", cb, d); return menu; } ngraph-gtk-6.08.00/src/gtk/x11menu.h0000644000175000017500000001773013356133076013712 00000000000000/* * $Id: x11menu.h,v 1.48 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for GTK". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for GTK" 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. * * "Ngraph for GTK" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef GTK_MENU_HEADER #define GTK_MENU_HEADER #include "common.h" #include "gtk_liststore.h" #include "ogra2cairo.h" #define N2GTK_RULER_METRIC(v) ((v) / 100.0 * 72.0 / 25.4 * 10) #define MARK_PIX_SIZE 24 enum MenuID { MenuIdGraphNewFrame, MenuIdGraphNewSection, MenuIdGraphNewCross, MenuIdGraphAllClear, MenuIdEditRedo, MenuIdEditUndo, MenuIdEditCut, MenuIdEditCopy, MenuIdEditPaste, MenuIdEditDelete, MenuIdEditDuplicate, MenuIdAlignLeft, MenuIdAlignVCenter, MenuIdAlignRight, MenuIdAlignTop, MenuIdAlignHCenter, MenuIdAlignBottom, MenuIdEditRotateCW, MenuIdEditRotateCCW, MenuIdEditFlipHorizontally, MenuIdEditFlipVertically, MenuIdOutputGRAFile, MenuIdOutputPSFile, MenuIdOutputEPSFile, MenuIdOutputPNGFile, MenuIdOutputCairoEMFFile, MenuIdOutputEMFFile, MenuIdOutputEMFClipboard, MenuIdOutputPDFFile, MenuIdOutputSVGFile, MenuIdToggleSidebar, MenuIdToggleStatusbar, MenuIdToggleRuler, MenuIdToggleScrollbar, MenuIdToggleCToolbar, MenuIdTogglePToolbar, MenuIdToggleCrossGauge, MenuIdToggleGridLine, MenuIdEditOrderTop, MenuIdEditOrderUp, MenuIdEditOrderDown, MenuIdEditOrderBottom, }; enum { RECENT_TYPE_GRAPH, RECENT_TYPE_DATA, }; enum DrawLockVal {DrawLockNone, DrawLockDraw, DrawLockExpose}; enum PointerType { PointB = 0x000001, LegendB = 0x000002, PathB = 0x000004, RectB = 0x000008, ArcB = 0x000010, MarkB = 0x000020, TextB = 0x000040, GaussB = 0x000080, AxisB = 0x000100, TrimB = 0x000200, FrameB = 0x000400, SectionB = 0x000800, CrossB = 0x001000, SingleB = 0x002000, DataB = 0x004000, EvalB = 0x008000, ZoomB = 0x010000, }; #define POINT_TYPE_POINT (PointB | LegendB | AxisB) #define POINT_TYPE_DRAW1 (ArcB | RectB | GaussB | FrameB | SectionB | CrossB) #define POINT_TYPE_DRAW2 (PathB | SingleB) #define POINT_TYPE_DRAW3 (TextB | MarkB) #define POINT_TYPE_DRAW_ALL (POINT_TYPE_DRAW1 | POINT_TYPE_DRAW2 | POINT_TYPE_DRAW3) #define POINT_TYPE_TRIM (TrimB | DataB | EvalB) enum _n_line_type { N_LINE_TYPE_SOLID, N_LINE_TYPE_DOT, }; enum MouseMode { MOUSENONE, MOUSEPOINT, MOUSEDRAG, MOUSEZOOM1, MOUSEZOOM2, MOUSEZOOM3, MOUSEZOOM4, MOUSECHANGE, MOUSESCROLLE, }; enum pop_up_menu_item_type { POP_UP_MENU_ITEM_TYPE_NORMAL, POP_UP_MENU_ITEM_TYPE_CHECK, POP_UP_MENU_ITEM_TYPE_MENU, POP_UP_MENU_ITEM_TYPE_SEPARATOR, POP_UP_MENU_ITEM_TYPE_RECENT_GRAPH, POP_UP_MENU_ITEM_TYPE_RECENT_DATA, POP_UP_MENU_ITEM_TYPE_END, }; #define VIEWER_POPUP_ITEM_NUM 14 struct Viewer { GtkWidget *Win; GtkWidget *menu, *VScroll, *HScroll, *popup, *VRuler, *HRuler, *side_pane1, *side_pane2, *side_pane3, *main_pane; int ShowFrame, ShowLine, ShowRect; int Capture, MoveData, KeyMask; enum MouseMode MouseMode; enum PointerType Mode; struct narray *focusobj, *points; int FrameOfsX, FrameOfsY; int MouseX1, MouseY1, MouseX2, MouseY2, MouseDX, MouseDY; int RefX1, RefY1, RefX2, RefY2, ChangePoint; int LineX, LineY, CrossX, CrossY, Angle; int allclear; int cx, cy; int ignoreredraw; double vscroll, hscroll, ZoomX, ZoomY; }; enum SubWinType { TypeFileWin, TypeAxisWin, TypePathWin, TypeRectWin, TypeArcWin, TypeMarkWin, TypeTextWin, TypeMergeWin, TypeCoordWin, TypeInfoWin, }; struct SubWin; struct obj_list_data { GtkWidget *popup, **popup_item; GtkWidget *text; int select, can_focus; void (* update)(struct obj_list_data *data, int, int); void (* delete)(struct obj_list_data *data, int); void (* setup_dialog)(struct obj_list_data *data, int id, int user_data); int (* undo_save)(int type); void *dialog; gboolean (* ev_key) (GtkWidget *, GdkEvent *, gpointer); struct objlist *obj; struct SubWin *parent; n_list_store *list; int list_col_num; }; typedef void (* sub_window_state_func) (struct SubWin *d, int state); struct SubWin { enum SubWinType type; GtkWidget *Win; union { struct obj_list_data *data; GtkWidget *text; } data; }; #define MENU_HISTORY_NUM 10 struct NgraphApp { char *FileName; GtkWidget *Message, *Message_pos, *Message_extra; gint Message1; GtkRecentManager *recent_manager; GtkEntryCompletion *legend_text_list, *x_math_list, *y_math_list, *func_list, *fit_list; cairo_surface_t *markpix[MARK_TYPE_NUM]; GdkCursor **cursor; struct Viewer Viewer; struct SubWin FileWin; struct SubWin AxisWin; struct SubWin PathWin; struct SubWin RectWin; struct SubWin ArcWin; struct SubWin MarkWin; struct SubWin TextWin; struct SubWin MergeWin; struct SubWin CoordWin; struct SubWin InfoWin; }; extern int Menulock, DnDLock; extern struct NgraphApp NgraphApp; extern GtkWidget *TopLevel; extern GdkColor white, gray; extern GtkAccelGroup *AccelGroup; #if USE_GTK_BUILDER extern GtkApplication *GtkApp; #endif enum MENU_UNDO_TYPE { UNDO_TYPE_EDIT, UNDO_TYPE_MOVE, UNDO_TYPE_ROTATE, UNDO_TYPE_FLIP, UNDO_TYPE_DELETE, UNDO_TYPE_CREATE, UNDO_TYPE_ALIGN, UNDO_TYPE_ORDER, UNDO_TYPE_COPY, UNDO_TYPE_SHLL, UNDO_TYPE_ADDIN, UNDO_TYPE_CLEAR_SCALE, UNDO_TYPE_UNDO_SCALE, UNDO_TYPE_OPEN_FILE, UNDO_TYPE_ADD_RANGE, UNDO_TYPE_PASTE, UNDO_TYPE_ZOOM, UNDO_TYPE_AUTOSCALE, UNDO_TYPE_TRIMMING, UNDO_TYPE_DUMMY, UNDO_TYPE_NUM, }; struct EventLoopInfo { int type; guint32 time; }; enum RerawFlag { DRAW_NONE = 0, DRAW_REDRAW = 1, DRAW_NOTIFY = 2, DRAW_AXIS_ONLY = 4, }; int application(char *file); void set_current_window(GtkWidget *w); GtkWidget *get_current_window(void); GtkWidget *create_recent_menu(int type); void UpdateAll(char **objects); void UpdateAll2(char **objects, int redraw); void ChangePage(void); void NSetCursor(unsigned int type); unsigned int NGetCursor(void); void reset_event(void); void SetStatusBar(const char *mes); void ResetStatusBar(void); int PutStderr(const char *s); int PutStdout(const char *s); void DisplayDialog(const char *str); int ChkInterrupt(void); int InputYN(const char *mes); void QuitGUI(void); void menu_lock(int lock); void set_draw_lock(int lock); int find_gra2gdk_inst(struct objlist **o, N_VALUE **i, struct objlist **ro, int *routput, struct gra2cairo_local **rlocal); void set_axis_undo_button_sensitivity(int state); void set_modified_state(int state); void set_focus_insensitive(const struct Viewer *d); void set_focus_sensitivity(const struct Viewer *d); void create_addin_menu(void); void create_recent_data_menu(void); void set_pointer_mode(int id); void set_toggle_action_widget_state(int id, int state); void script_exec(GtkWidget *w, gpointer client_data); int toggle_view(int type, int state); void CmToggleSingleWindowMode(GtkCheckMenuItem *action, gpointer client_data); void CmReloadWindowConfig(void *w, gpointer user_data); void show_recent_dialog(int type); int menu_save_undo(enum MENU_UNDO_TYPE type, char **obj); int menu_save_undo_single(enum MENU_UNDO_TYPE type, char *obj); void menu_delete_undo(int id); void menu_clear_undo(void); void menu_undo_internal(int id); void menu_undo(void); void menu_redo(void); int get_graph_modified(void); void set_graph_modified(void); void set_graph_modified_gra(void); void reset_graph_modified(void); void draw_notify(int notify); #endif ngraph-gtk-6.08.00/src/gtk/sourcecompletionwords.h0000644000175000017500000000472313242772500017056 00000000000000/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8; coding: utf-8 -*- * modified from gtksourcecompletionproviderwords.h * This file is part of GtkSourceView * * Copyright (C) 2009 - Jesse van den Kieboom * * gtksourceview 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.1 of the License, or (at your option) any later version. * * gtksourceview 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef SOURCE_COMPLETION_WORDS_H #define SOURCE_COMPLETION_WORDS_H #define GTK_SOURCE_H_INSIDE #include #include G_BEGIN_DECLS #define SOURCE_TYPE_COMPLETION_WORDS (source_completion_words_get_type ()) #define SOURCE_COMPLETION_WORDS(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), SOURCE_TYPE_COMPLETION_WORDS, SourceCompletionWords)) #define SOURCE_COMPLETION_WORDS_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), SOURCE_TYPE_COMPLETION_WORDS, SourceCompletionWordsClass)) #define SOURCE_IS_COMPLETION_WORDS(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SOURCE_TYPE_COMPLETION_WORDS)) #define SOURCE_IS_COMPLETION_WORDS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), SOURCE_TYPE_COMPLETION_WORDS)) #define SOURCE_COMPLETION_WORDS_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), SOURCE_TYPE_COMPLETION_WORDS, SourceCompletionWordsClass)) typedef struct _SourceCompletionWords SourceCompletionWords; typedef struct _SourceCompletionWordsClass SourceCompletionWordsClass; typedef struct _SourceCompletionWordsPrivate SourceCompletionWordsPrivate; struct _SourceCompletionWords { GObject parent; SourceCompletionWordsPrivate *priv; }; struct _SourceCompletionWordsClass { GObjectClass parent_class; }; GType source_completion_words_get_type (void) G_GNUC_CONST; typedef GList * (* populate_func)(const char *, int, GtkTextIter *); SourceCompletionWords *source_completion_words_new(const gchar *name, populate_func func); G_END_DECLS #endif /* SOURCE_COMPLETION_WORDS_H */ ngraph-gtk-6.08.00/src/gtk/gtk_common.h0000644000175000017500000000135613345130036014535 00000000000000#ifndef GTK_COMMON_HEADER #define GTK_COMMON_HEADER #include #include #include #include #include #include #include "common.h" #ifndef GTK_WIDGET_VISIBLE #define GTK_WIDGET_VISIBLE(w) gtk_widget_get_visible(w) #endif #define USE_APP_MENU GTK_CHECK_VERSION(3, 12, 0) #if OSX #define USE_GTK_BUILDER 1 #else #define USE_GTK_BUILDER 0 #endif #if WINDOWS || OSX #define USE_HEADER_BAR 0 #else #define USE_HEADER_BAR 1 #endif #define RECENT_CHOOSER_LIMIT 25 #define APPLICATION_ID "com.github.htrb.ngraph-gtk" #define RESOURCE_PATH "/com/github/htrb/ngraph-gtk" #define CAIRO_COORDINATE_OFFSET 1 #define LINE_NUMBER_WIDGET_NAME "line_number" #endif ngraph-gtk-6.08.00/src/gtk/completion_info.c0000644000175000017500000000404513243526636015571 00000000000000#include "completion_info.h" #if GTK_SOURCE_CHECK_VERSION(3, 24, 0) static int check_paren(GtkTextIter *iter) { GtkTextIter cur; gunichar ch, paren; paren = g_utf8_get_char("("); cur = *iter; while (1) { ch = gtk_text_iter_get_char(&cur); if (! g_unichar_isspace(ch)) { break; } gtk_text_iter_forward_char(&cur); } return (ch == paren); } #endif static GList * completion_info_populate(struct completion_info *info, const char *word, int len, GtkTextIter *iter) { GList *ret = NULL; int i, r; #if GTK_SOURCE_CHECK_VERSION(3, 24, 0) const char *text; #endif for (i = 0; info[i].lower_text; i++) { r = strncmp(info[i].lower_text, word, len); if (r < 0) { continue; } else if (r > 0) { break; } if (info[i].proposal == NULL) { GtkSourceCompletionItem *proposal; #if GTK_SOURCE_CHECK_VERSION(3, 24, 0) proposal = gtk_source_completion_item_new2(); gtk_source_completion_item_set_label(proposal, info[i].text); gtk_source_completion_item_set_text(proposal, info[i].text); gtk_source_completion_item_set_info(proposal, _(info[i].info)); #else proposal = gtk_source_completion_item_new(info[i].text, info[i].text, NULL, _(info[i].info)); #endif info[i].proposal = proposal; } #if GTK_SOURCE_CHECK_VERSION(3, 24, 0) if (info[i].text_wo_paren && check_paren(iter)) { text = info[i].text_wo_paren; } else { text = info[i].text; } gtk_source_completion_item_set_text(info[i].proposal, text); #endif ret = g_list_prepend (ret, info[i].proposal); } return ret; } GList * completion_info_func_populate(const char *word, int len, GtkTextIter *iter) { return completion_info_populate(completion_info_func, word, len, iter); } GList * completion_info_const_populate(const char *word, int len, GtkTextIter *iter) { return completion_info_populate(completion_info_const, word, len, iter); } ngraph-gtk-6.08.00/src/gtk/gtk_entry_completion.c0000644000175000017500000000654613237171026016644 00000000000000/* * $Id: gtk_entry_completion.c,v 1.8 2010-03-04 08:30:16 hito Exp $ */ #include #include #include #include #include "gtk_common.h" #include "ioutil.h" #include "object.h" static int HistSize; GtkEntryCompletion * entry_completion_create(void) { GtkListStore *list; GtkEntryCompletion *comp; list = gtk_list_store_new(1, G_TYPE_STRING); comp = gtk_entry_completion_new(); gtk_entry_completion_set_model(comp, GTK_TREE_MODEL(list)); gtk_entry_completion_set_inline_completion(comp, FALSE); gtk_entry_completion_set_popup_completion(comp, TRUE); gtk_entry_completion_set_popup_set_width(comp, TRUE); gtk_entry_completion_set_text_column(comp, 0); return comp; } void entry_completion_set_entry(GtkEntryCompletion *comp, GtkWidget *entry) { GtkWidget *old_entry; if (comp == NULL || entry == NULL) { return; } old_entry = gtk_entry_completion_get_entry(comp); if (old_entry) { gtk_entry_set_completion(GTK_ENTRY(old_entry), NULL); } gtk_entry_set_completion(GTK_ENTRY(entry), comp); } static gboolean save_history_cb(GtkTreeModel *model, GtkTreePath *path, GtkTreeIter *iter, gpointer data) { FILE *fp; int *a; char *v; fp = (FILE *) data; a = gtk_tree_path_get_indices(path); if (a == NULL || a[0] >= HistSize) return TRUE; gtk_tree_model_get(model, iter, 0, &v, -1); if (v) { fprintf(fp, "%s\n", v); g_free(v); } return FALSE; } static gboolean add_completion(GtkListStore *list, FILE *fp) { char *buf; GtkTreeIter iter; int r; r = fgetline(fp, &buf); if (r || buf == NULL) return TRUE; g_strchomp(buf); if (g_utf8_validate(buf, -1, NULL)) { gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, 0, buf, -1); } g_free(buf); return FALSE; } int entry_completion_save(GtkEntryCompletion *comp, char *file, int size) { FILE *fp; GtkTreeModel *model; model = gtk_entry_completion_get_model(comp); if (model == NULL) return 1; fp = nfopen(file, "w"); if (fp == NULL) return 1; HistSize = size; gtk_tree_model_foreach(model, save_history_cb, fp); fclose(fp); return 0; } int entry_completion_load(GtkEntryCompletion *comp, char *file, int size) { FILE *fp; int i; GtkTreeModel *model; model = gtk_entry_completion_get_model(comp); if (model == NULL) return 1; gtk_list_store_clear(GTK_LIST_STORE(model)); fp = nfopen(file, "r"); if (fp == NULL) return 1; for (i = 0; i < size; i++) { if (add_completion(GTK_LIST_STORE(model), fp)) break; } fclose(fp); return 0; } void entry_completion_append(GtkEntryCompletion *comp, const char *str) { gboolean found; GtkTreeModel *model; GtkTreeIter iter; char *v = NULL; if (comp == NULL || str == NULL || strlen(str) == 0) return; if (strchr(str, '\n')) { return; } model = gtk_entry_completion_get_model(comp); if (model == NULL) return; found = gtk_tree_model_get_iter_first(model, &iter); while (found) { gtk_tree_model_get(model, &iter, 0, &v, -1); if (v) { if (strcmp(str, v) == 0) { gtk_list_store_remove(GTK_LIST_STORE(model), &iter); g_free(v); break; } g_free(v); } found = gtk_tree_model_iter_next(model, &iter); } gtk_list_store_prepend(GTK_LIST_STORE(model), &iter); gtk_list_store_set(GTK_LIST_STORE(model), &iter, 0, str, -1); } ngraph-gtk-6.08.00/src/gtk/gtk_liststore.c0000644000175000017500000006712013070106167015274 00000000000000/* * $Id: gtk_liststore.c,v 1.27 2010-02-03 01:18:12 hito Exp $ */ #include #include "gra.h" #include "gtk_common.h" #include "gtk_liststore.h" #include "x11dialg.h" static gboolean tree_view_set_tooltip_query_cb(GtkWidget *widget, gint x, gint y, gboolean keyboard_tip, GtkTooltip *tooltip, gpointer data) { char *str; GtkTreeIter iter; GtkTreePath *path; GtkTreeModel *model; GtkTreeView *tree_view = GTK_TREE_VIEW(widget); int column; if (!gtk_tree_view_get_tooltip_context(GTK_TREE_VIEW(widget), &x, &y, keyboard_tip, &model, &path, &iter)) { return FALSE; } column = GPOINTER_TO_INT(data); if (column < 0) { return FALSE; } str = NULL; gtk_tree_model_get(model, &iter, column, &str, -1); if (str == NULL) { return FALSE; } gtk_tooltip_set_text(tooltip, str); gtk_tree_view_set_tooltip_row(tree_view, tooltip, path); g_free(str); gtk_tree_path_free(path); return TRUE; } void tree_view_set_tooltip_column(GtkTreeView *tree_view, gint column) { g_signal_connect(tree_view, "query-tooltip", G_CALLBACK(tree_view_set_tooltip_query_cb), GINT_TO_POINTER(column)); gtk_widget_set_has_tooltip(GTK_WIDGET(tree_view), TRUE); } static gboolean combo_box_separator_func(GtkTreeModel *model, GtkTreeIter *iter, gpointer data) { char *str; int r; gtk_tree_model_get(model, iter, OBJECT_COLUMN_TYPE_STRING, &str, -1); r = ! str; if (str) { g_free(str); } return r; } void init_object_combo_box(GtkWidget *cbox) { GtkCellRenderer *rend; GtkTreeViewRowSeparatorFunc func; func = gtk_combo_box_get_row_separator_func(GTK_COMBO_BOX(cbox)); if (func == NULL) { gtk_combo_box_set_row_separator_func(GTK_COMBO_BOX(cbox), combo_box_separator_func, NULL, NULL); } gtk_cell_layout_clear(GTK_CELL_LAYOUT(cbox)); rend = gtk_cell_renderer_toggle_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(cbox), rend, "active", OBJECT_COLUMN_TYPE_TOGGLE, "visible", OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, "radio", OBJECT_COLUMN_TYPE_TOGGLE_IS_RADIO, NULL); rend = gtk_cell_renderer_text_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "text", OBJECT_COLUMN_TYPE_STRING); rend = gtk_cell_renderer_pixbuf_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "pixbuf", OBJECT_COLUMN_TYPE_PIXBUF); } static GtkTreeModel * create_object_tree_model(void) { return GTK_TREE_MODEL(gtk_tree_store_new(OBJECT_COLUMN_TYPE_NUM, G_TYPE_BOOLEAN, G_TYPE_STRING, G_TYPE_OBJECT, G_TYPE_INT, G_TYPE_INT, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN)); } static GtkWidget * create_object_cbox(void) { GtkTreeModel *model; GtkWidget *cbox; model = create_object_tree_model(); cbox = gtk_combo_box_new_with_model(model); init_object_combo_box(cbox); g_object_set(cbox, "has-frame", FALSE, NULL); return cbox; } void add_separator_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent) { add_text_combo_item_to_cbox(list, iter, parent, -1, -1, NULL, TOGGLE_NONE, FALSE); } void add_font_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id) { struct fontmap *fcur; char *font; int match; getobj(obj, field, id, 0, NULL, &font); fcur = Gra2cairoConf->fontmap_list_root; while (fcur) { match = ! g_strcmp0(font, fcur->fontalias); add_text_combo_item_to_cbox(list, iter, parent, column_id, -1, fcur->fontalias, TOGGLE_RADIO, match); fcur = fcur->next; } } void add_font_style_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id_bold, int column_id_italic, struct objlist *obj, const char *field, int id) { int style; getobj(obj, field, id, 0, NULL, &style); add_text_combo_item_to_cbox(list, iter, parent, column_id_bold, -1, _("Bold"), TOGGLE_CHECK, style & GRA_FONT_STYLE_BOLD); add_text_combo_item_to_cbox(list, iter, parent, column_id_italic, -1, _("Italic"), TOGGLE_CHECK, style & GRA_FONT_STYLE_ITALIC); } void add_text_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, int enum_id, const char *title, enum TOGGLE_TYPE type, int active) { GtkTreeIter locl_iter; if (iter == NULL) { iter = &locl_iter; } gtk_tree_store_append(list, iter, parent); gtk_tree_store_set(list, iter, OBJECT_COLUMN_TYPE_STRING, title, OBJECT_COLUMN_TYPE_PIXBUF, NULL, OBJECT_COLUMN_TYPE_INT, column_id, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, type != TOGGLE_NONE, OBJECT_COLUMN_TYPE_TOGGLE_IS_RADIO, type == TOGGLE_RADIO, OBJECT_COLUMN_TYPE_TOGGLE, active, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, FALSE, OBJECT_COLUMN_TYPE_ENUM, enum_id, -1); } void add_mark_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id) { int j, type; GtkTreeIter locl_iter; if (iter == NULL) { iter = &locl_iter; } type = -1; getobj(obj, field, id, 0, NULL, &type); for (j = 0; j < MARK_TYPE_NUM; j++) { GdkPixbuf *pixbuf; pixbuf = gdk_pixbuf_get_from_surface(NgraphApp.markpix[j], 0, 0, MARK_PIX_SIZE, MARK_PIX_SIZE); if (pixbuf) { char buf[64]; gtk_tree_store_append(list, iter, parent); snprintf(buf, sizeof(buf), "%02d ", j); gtk_tree_store_set(list, iter, OBJECT_COLUMN_TYPE_STRING, buf, OBJECT_COLUMN_TYPE_PIXBUF, pixbuf, OBJECT_COLUMN_TYPE_INT, column_id, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, TRUE, OBJECT_COLUMN_TYPE_TOGGLE_IS_RADIO, TRUE, OBJECT_COLUMN_TYPE_TOGGLE, j == type, OBJECT_COLUMN_TYPE_ENUM, j, -1); g_object_unref(pixbuf); } } } void add_enum_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id) { char **enum_array; int state, i; getobj(obj, field, id, 0, NULL, &state); enum_array = (char **) chkobjarglist(obj, field); if (enum_array == NULL) { return; } for (i = 0; enum_array[i] && enum_array[i][0]; i++) { add_text_combo_item_to_cbox(list, iter, parent, column_id, i, _(enum_array[i]), TOGGLE_RADIO, i == state); } } void add_bool_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id, const char *title) { GtkTreeIter locl_iter; int state; if (iter == NULL) { iter = &locl_iter; } getobj(obj, field, id, 0, NULL, &state); add_text_combo_item_to_cbox(list, iter, parent, column_id, -1, title, TOGGLE_CHECK, state); } void add_line_style_item_to_cbox(GtkTreeStore *list, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id) { GtkTreeIter iter; int i, active; char *str; sgetobjfield(obj, id, field, NULL, &str, FALSE, FALSE, FALSE); if (str == NULL) { return; } add_text_combo_item_to_cbox(list, &iter, parent, -1, -1, _("Line style"), TOGGLE_NONE, FALSE); for (i = 0; FwLineStyle[i].name; i++) { active = ! g_strcmp0(str, FwLineStyle[i].list); add_text_combo_item_to_cbox(list, NULL, &iter, column_id, i, _(FwLineStyle[i].name), TOGGLE_RADIO, active); } g_free(str); } GtkCellEditable * start_editing_obj(GtkCellRenderer *cell, GdkEvent *event, GtkWidget *widget, const gchar *path, const GdkRectangle *background_area, const GdkRectangle *cell_area, GtkCellRendererState flags) { return GTK_CELL_EDITABLE(create_object_cbox()); } static GtkTreeViewColumn * create_column(n_list_store *list, int i) { GtkCellRenderer *renderer; GtkTreeViewColumn *col; GtkTreeModel *model; switch (list[i].type) { case G_TYPE_BOOLEAN: renderer = gtk_cell_renderer_toggle_new(); col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "active", i, NULL); if (list[i].editable) { g_object_set(renderer, "mode", GTK_CELL_RENDERER_MODE_ACTIVATABLE, NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); } break; case G_TYPE_INT: case G_TYPE_UINT: case G_TYPE_LONG: case G_TYPE_ULONG: case G_TYPE_INT64: case G_TYPE_UINT64: case G_TYPE_FLOAT: case G_TYPE_DOUBLE: #if GTK_CHECK_VERSION(3, 8, 0) renderer = gtk_cell_renderer_spin_new(); #else renderer = gtk_cell_renderer_text_new(); #endif col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "text", i, NULL); gtk_tree_view_column_set_resizable(col, TRUE); g_object_set((GObject *) renderer, "xalign", (gfloat) 1.0, NULL); if (list[i].editable) { if (list[i].type == G_TYPE_DOUBLE || list[i].type == G_TYPE_FLOAT) { g_object_set((GObject *) renderer, "editable", list[i].editable, #if GTK_CHECK_VERSION(3, 8, 0) "adjustment", gtk_adjustment_new(0, list[i].min / 100.0, list[i].max / 100.0, list[i].inc / 100.0, list[i].page / 100.0, 0), "digits", 2, #endif NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); } else { g_object_set((GObject *) renderer, "editable", list[i].editable, #if GTK_CHECK_VERSION(3, 8, 0) "adjustment", gtk_adjustment_new(0, list[i].min, list[i].max, list[i].inc, list[i].page, 0), "digits", 0, #endif NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); } } if (list[i].editable) { gtk_tree_view_column_set_expand(col, TRUE); } break; case G_TYPE_OBJECT: renderer = gtk_cell_renderer_pixbuf_new(); g_object_set((GObject *) renderer, "mode", (list[i].editable) ? GTK_CELL_RENDERER_MODE_EDITABLE : GTK_CELL_RENDERER_MODE_INERT, "sensitive", list[i].editable, NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); GTK_CELL_RENDERER_GET_CLASS(renderer)->start_editing = start_editing_obj; col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "pixbuf", i, NULL); break; case G_TYPE_PARAM: renderer = gtk_cell_renderer_combo_new(); model = create_object_tree_model(); g_object_set((GObject *) renderer, "has-entry", FALSE, "model", model, "text-column", OBJECT_COLUMN_TYPE_STRING, "editable", list[i].editable, NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "text", i, NULL); break; case G_TYPE_ENUM: renderer = gtk_cell_renderer_combo_new(); model = GTK_TREE_MODEL(gtk_list_store_new(1, G_TYPE_STRING)); g_object_set((GObject *) renderer, "has-entry", FALSE, "model", model, "text-column", 0, "editable", list[i].editable, NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "text", i, NULL); break; case G_TYPE_STRING: default: renderer = gtk_cell_renderer_text_new(); g_object_set((GObject *) renderer, "editable", list[i].editable, "ellipsize", list[i].ellipsize, NULL); g_object_set_data(G_OBJECT(renderer), "user-data", &list[i]); col = gtk_tree_view_column_new_with_attributes(_(list[i].title), renderer, "text", i, NULL); gtk_tree_view_column_set_resizable(col, TRUE); if (list[i].ellipsize != PANGO_ELLIPSIZE_NONE || list[i].editable) { gtk_tree_view_column_set_expand(col, TRUE); } } return col; } void tree_view_set_no_expand_column(GtkWidget *tview, const int *columns, int n) { GtkTreeViewColumn *col; int i; for (i = 0; i < n; i++) { col = gtk_tree_view_get_column(GTK_TREE_VIEW(tview), columns[i]); gtk_tree_view_column_set_expand(col, FALSE); } } void list_store_set_align(GtkWidget *tview, int n, double align) { GtkTreeViewColumn *col; GList *list; col = gtk_tree_view_get_column(GTK_TREE_VIEW(tview), n); if (col == NULL) { return; } list = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col)); if (list == NULL || list->data == NULL) { return; } g_object_set((GObject *) list->data, "xalign", (gfloat) align, NULL); g_list_free(list); } static GtkWidget * create_tree_view(int n, n_list_store *list, int tree) { GType *tarray; GtkTreeModel *lstore; GtkWidget *tview; GtkTreeViewColumn *col; GtkTreeSelection *sel; int i; if (n < 1 || list == NULL) return NULL; tarray = g_malloc(sizeof(*tarray) * n); if (tarray == NULL) return NULL; for (i = 0; i < n; i++) { if (list[i].type == G_TYPE_DOUBLE || list[i].type == G_TYPE_ENUM || list[i].type == G_TYPE_PARAM) { tarray[i] = G_TYPE_STRING; } else { tarray[i] = list[i].type; } list[i].edited_id = 0; } if (tree) { lstore = GTK_TREE_MODEL(gtk_tree_store_newv(n, tarray)); } else { lstore = GTK_TREE_MODEL(gtk_list_store_newv(n, tarray)); } g_free(tarray); tview = gtk_tree_view_new_with_model(lstore); #if ! GTK_CHECK_VERSION(3, 14, 0) gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(tview), TRUE); #endif gtk_tree_view_set_rubber_banding(GTK_TREE_VIEW(tview), TRUE); gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(tview), GTK_TREE_VIEW_GRID_LINES_VERTICAL); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(tview)); gtk_tree_selection_set_mode(sel, GTK_SELECTION_SINGLE); for (i = 0; i < n; i++) { if (list[i].visible) { col = create_column(list, i); gtk_tree_view_column_set_visible(col, list[i].visible); gtk_tree_view_append_column(GTK_TREE_VIEW(tview), col); } } gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(tview), n > 1); return tview; } void list_store_set_sort_all(GtkWidget *tview) { GList *list, *ptr; int i; GtkTreeViewColumn *column; list = gtk_tree_view_get_columns(GTK_TREE_VIEW(tview)); if (list == NULL) return; for (ptr = list, i = 0; ptr; ptr = ptr->next, i++) { column = GTK_TREE_VIEW_COLUMN(ptr->data); gtk_tree_view_column_set_sort_column_id(column, i); gtk_tree_view_column_set_clickable(column, TRUE); } gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(tview), TRUE); g_list_free(list); } void list_store_set_sort_column(GtkWidget *tview, int col) { GList *list, *ptr; list = gtk_tree_view_get_columns(GTK_TREE_VIEW(tview)); if (list == NULL) return; ptr = g_list_nth(list, col); if (ptr) { GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(ptr->data); gtk_tree_view_column_set_sort_column_id(column, col); gtk_tree_view_column_set_clickable(column, TRUE); } gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(tview), TRUE); g_list_free(list); } GtkWidget * list_store_create(int n, n_list_store *list) { return create_tree_view(n, list, FALSE); } GtkWidget * tree_store_create(int n, n_list_store *list) { return create_tree_view(n, list, TRUE); } int list_store_get_int(GtkWidget *w, GtkTreeIter *iter, int col) { GtkTreeModel *model; int v = 0; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_model_get(model, iter, col, &v, -1); return v; } void list_store_set_int(GtkWidget *w, GtkTreeIter *iter, int col, int v) { GtkListStore *list; list = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); gtk_list_store_set(list, iter, col, v, -1); } void tree_store_set_int(GtkWidget *w, GtkTreeIter *iter, int col, int v) { GtkTreeStore *list; list = GTK_TREE_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); gtk_tree_store_set(list, iter, col, v, -1); } int list_store_path_get_int(GtkWidget *w, GtkTreePath *path, int col, int *val) { GtkTreeModel *model; gboolean found; GtkTreeIter iter; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); found = gtk_tree_model_get_iter(model, &iter, path); if (! found) return 1; gtk_tree_model_get(model, &iter, col, val, -1); return 0; } void list_store_set_double(GtkWidget *w, GtkTreeIter *iter, int col, double v) { char buf[128]; snprintf(buf, sizeof(buf), "%.2f", v); list_store_set_string(w, iter, col, buf); } void tree_store_set_double(GtkWidget *w, GtkTreeIter *iter, int col, double v) { char buf[128]; snprintf(buf, sizeof(buf), "%.2f", v); tree_store_set_string(w, iter, col, buf); } gboolean list_store_get_boolean(GtkWidget *w, GtkTreeIter *iter, int col) { GtkTreeModel *model; gboolean v; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_model_get(model, iter, col, &v, -1); return v; } void list_store_set_boolean(GtkWidget *w, GtkTreeIter *iter, int col, gboolean v) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_list_store_set(GTK_LIST_STORE(model), iter, col, v, -1); } void tree_store_set_boolean(GtkWidget *w, GtkTreeIter *iter, int col, gboolean v) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_store_set(GTK_TREE_STORE(model), iter, col, v, -1); } char * list_store_get_string(GtkWidget *w, GtkTreeIter *iter, int col) { GtkTreeModel *model; char *v; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_model_get(model, iter, col, &v, -1); return v; } char * list_store_path_get_string(GtkWidget *w, GtkTreePath *path, int col) { GtkTreeModel *model; gboolean found; GtkTreeIter iter; char *v; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); found = gtk_tree_model_get_iter(model, &iter, path); if (! found) return NULL; gtk_tree_model_get(model, &iter, col, &v, -1); return v; } void list_store_set_string(GtkWidget *w, GtkTreeIter *iter, int col, const char *v) { GtkListStore *list; list = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); gtk_list_store_set(list, iter, col, v, -1); } void list_store_path_set_string(GtkWidget *w, GtkTreePath *path, int col, const char *v) { GtkListStore *list; gboolean found; GtkTreeIter iter; list = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); found = gtk_tree_model_get_iter(GTK_TREE_MODEL(list), &iter, path); if (! found) return; gtk_list_store_set(list, &iter, col, v, -1); } void tree_store_set_string(GtkWidget *w, GtkTreeIter *iter, int col, const char *v) { GtkTreeStore *list; list = GTK_TREE_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); gtk_tree_store_set(list, iter, col, v, -1); } void list_store_set_pixbuf(GtkWidget *w, GtkTreeIter *iter, int col, GdkPixbuf *v) { GtkListStore *list; list = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(w))); gtk_list_store_set(list, iter, col, v, -1); } GdkPixbuf * list_store_get_pixbuf(GtkWidget *w, GtkTreeIter *iter, int col) { GtkTreeModel *model; GObject *v; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_model_get(model, iter, col, &v, -1); return GDK_PIXBUF(v); } void list_store_set_val(GtkWidget *w, GtkTreeIter *iter, int col, GType type, void *ptr) { int v; gboolean b; char *s; switch (type) { case G_TYPE_BOOLEAN: b = *((int *)ptr); list_store_set_boolean(w, iter, col, b); break; case G_TYPE_INT: v = *((int *)ptr); list_store_set_int(w, iter, col, v); break; case G_TYPE_STRING: s = (char *)ptr; list_store_set_string(w, iter, col, s); break; } } void tree_store_set_val(GtkWidget *w, GtkTreeIter *iter, int col, GType type, void *ptr) { int v; gboolean b; char *s; switch (type) { case G_TYPE_BOOLEAN: b = *((int *)ptr); tree_store_set_boolean(w, iter, col, b); break; case G_TYPE_INT: v = *((int *)ptr); tree_store_set_int(w, iter, col, v); break; case G_TYPE_STRING: s = (char *)ptr; tree_store_set_string(w, iter, col, s); break; } } void list_store_clear(GtkWidget *w) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_list_store_clear(GTK_LIST_STORE(model)); } void tree_store_clear(GtkWidget *w) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_store_clear(GTK_TREE_STORE(model)); } void list_store_append(GtkWidget *w, GtkTreeIter *iter) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_list_store_append(GTK_LIST_STORE(model), iter); } void tree_store_append(GtkWidget *w, GtkTreeIter *iter, GtkTreeIter *parent) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_store_append(GTK_TREE_STORE(model), iter, parent); } void tree_store_prepend(GtkWidget *w, GtkTreeIter *iter, GtkTreeIter *parent) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); gtk_tree_store_prepend(GTK_TREE_STORE(model), iter, parent); } gboolean list_store_get_iter_first(GtkWidget *w, GtkTreeIter *iter) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); return gtk_tree_model_get_iter_first(model, iter); } gboolean list_store_iter_next(GtkWidget *w, GtkTreeIter *iter) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); return gtk_tree_model_iter_next(GTK_TREE_MODEL(model), iter); } gboolean tree_store_get_iter_children(GtkWidget *w, GtkTreeIter *child, GtkTreeIter *iter) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); return gtk_tree_model_iter_children(model, child, iter); } gboolean list_store_get_selected_iter(GtkWidget *w, GtkTreeIter *iter) { GtkTreeSelection *sel; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); return gtk_tree_selection_get_selected(sel, NULL, iter); } int list_store_get_selected_int(GtkWidget *w, int col) { GtkTreeIter iter; if (! list_store_get_selected_iter(w, &iter)) return -1; return list_store_get_int(w, &iter, col); } char * list_store_get_selected_string(GtkWidget *w, int col) { GtkTreeIter iter; if (! list_store_get_selected_iter(w, &iter)) return NULL; return list_store_get_string(w, &iter, col); } gboolean tree_store_get_selected_nth(GtkWidget *w, int *n, int *m) { GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; GtkTreePath* path; int depth, *ary; gboolean state; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); state = gtk_tree_selection_get_selected(sel, &model, &iter); if (! state) return FALSE; path = gtk_tree_model_get_path(model, &iter); depth = gtk_tree_path_get_depth(path); ary = gtk_tree_path_get_indices(path); *n = ary[0]; if (depth < 2) { *m = -1; } else { *m = ary[1]; } gtk_tree_path_free(path); return TRUE; } int list_store_get_selected_index(GtkWidget *w) { int m, n; gboolean state; state = tree_store_get_selected_nth(w, &n, &m); if (state) return n; return -1; } gboolean list_store_get_selected_nth(GtkWidget *w, int *n) { int m; return tree_store_get_selected_nth(w, n, &m); } void list_store_select_all(GtkWidget *w) { GtkTreeSelection *sel; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); gtk_tree_selection_select_all(sel); } void list_store_select_iter(GtkWidget *w, GtkTreeIter *iter) { GtkTreeModel *model; GtkTreeSelection *sel; GtkTreePath *path; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); gtk_tree_selection_select_iter(sel, iter); path = gtk_tree_model_get_path(model, iter); gtk_tree_view_set_cursor(GTK_TREE_VIEW(w), path, NULL, FALSE); gtk_tree_path_free(path); } void list_store_select_int(GtkWidget *w, int col, int id) { GtkTreeIter iter; GtkTreeModel *model; gboolean state; int val; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); state = gtk_tree_model_get_iter_first(model, &iter); while (state) { val = list_store_get_int(w, &iter, col); if (val == id) { list_store_select_iter(w, &iter); break; } state = gtk_tree_model_iter_next(model, &iter); } } static void select_path_str(GtkWidget *w, char *str) { GtkTreePath *path; GtkTreeSelection *sel; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); path = gtk_tree_path_new_from_string(str); if (! path) return; gtk_tree_selection_select_path(sel, path); gtk_tree_view_set_cursor(GTK_TREE_VIEW(w), path, NULL, FALSE); /* this line is commented out before (I forgot the reason). */ gtk_tree_path_free(path); } static void select_range_path_str(GtkWidget *w, char *from, char *to) { GtkTreePath *path1, *path2; GtkTreeSelection *sel; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); path1 = gtk_tree_path_new_from_string(from); if (! path1) return; path2 = gtk_tree_path_new_from_string(to); if (! path2) { gtk_tree_path_free(path1); return; } gtk_tree_selection_select_range(sel, path1, path2); gtk_tree_path_free(path2); gtk_tree_path_free(path1); } void list_store_select_nth(GtkWidget *w, int n) { char buf[1024]; snprintf(buf, sizeof(buf), "%d", n); select_path_str(w, buf); } void tree_store_select_nth(GtkWidget *w, int n, int m) { char buf[1024]; snprintf(buf, sizeof(buf), "%d:%d", n, m); select_path_str(w, buf); } void list_store_multi_select_nth(GtkWidget *w, int n, int m) { char buf1[1024], buf2[1024]; snprintf(buf1, sizeof(buf1), "%d", n); snprintf(buf2, sizeof(buf2), "%d", m); select_range_path_str(w, buf1, buf2); } int list_store_get_num(GtkWidget *w) { return tree_store_get_child_num(w, NULL); } int tree_store_get_child_num(GtkWidget *w, GtkTreeIter *iter) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); return gtk_tree_model_iter_n_children(model, iter); } void list_store_set_selection_mode(GtkWidget *w, GtkSelectionMode mode) { GtkTreeSelection *gsel; gsel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); gtk_tree_selection_set_mode(gsel, mode); } void list_store_select_all_cb(GtkButton *w, gpointer client_data) { list_store_select_all(GTK_WIDGET(client_data)); } void list_store_remove_selected_cb(GtkWidget *w, gpointer client_data) { GtkTreeSelection *sel; GList *selected, *data; GtkTreeModel *model; gboolean found; GtkTreeIter iter; GtkTreePath *first_path = NULL; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(client_data)); selected = gtk_tree_selection_get_selected_rows(sel, &model); if (selected == NULL) return; for (data = g_list_last(selected); data; data = data->prev) { found = gtk_tree_model_get_iter(model, &iter, data->data); if (found) { gtk_list_store_remove(GTK_LIST_STORE(model), &iter); } first_path = data->data; } if (first_path) { if (! gtk_tree_model_get_iter(model, &iter, first_path)) { gtk_tree_path_prev(first_path); } gtk_tree_view_set_cursor(GTK_TREE_VIEW(client_data), first_path, NULL, FALSE); } g_list_foreach(selected, free_tree_path_cb, NULL); g_list_free(selected); } void free_tree_path_cb(gpointer data, gpointer user_data) { gtk_tree_path_free(data); } void tree_store_selected_toggle_expand(GtkWidget *w) { GtkTreeIter iter; GtkTreePath *path; GtkTreeModel *model; if (! list_store_get_selected_iter(w, &iter)) return; model = gtk_tree_view_get_model(GTK_TREE_VIEW(w)); path = gtk_tree_model_get_path(model, &iter); if (gtk_tree_view_row_expanded(GTK_TREE_VIEW(w), path)) { gtk_tree_view_collapse_row(GTK_TREE_VIEW(w), path); } else { gtk_tree_view_expand_row(GTK_TREE_VIEW(w), path, FALSE); } } int tree_view_get_selected_row_int_from_path(GtkWidget *view, gchar *path, GtkTreeIter *iter, int col) { GtkTreeModel *model; int sel; model = gtk_tree_view_get_model(GTK_TREE_VIEW(view)); if (! gtk_tree_model_get_iter_from_string(model, iter, path)) { return -1; } list_store_select_iter(GTK_WIDGET(view), iter); gtk_tree_model_get(model, iter, col, &sel, -1); return sel; } ngraph-gtk-6.08.00/src/gtk/data/0000755000175000017500000000000013375640231013221 500000000000000ngraph-gtk-6.08.00/src/gtk/data/pixmaps/0000755000175000017500000000000013375640231014702 500000000000000ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_gauss-symbolic.svg0000644000175000017500000001676713344733021021660 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/mark_begin-symbolic.svg0000644000175000017500000000643613342667613021300 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/arrow_end-symbolic.svg0000644000175000017500000000604413342672033021145 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_t.png0000644000175000017500000000070413070106167020302 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“lIDATXÃí—ÁJQ†ÿsgj‹’Rk@¬FŒ _"r…›ž!Bz¡h×#ÔF"Ÿ hÑ*Q,C ¬eãhÞÓ¢‚ ™f*ÅÍýWwñqø.œË=‡ …‚ˆOe<Ã`MC«çðtÂf%Áe04Öà¶z¬k šó¬Ç Áè÷Û,e_ê–e `€Ÿc!ö~pÀ¥ÏCG§ÓŽ4Si^ÙÝñEïJX}¸§Ìm–·³[¾\¥VE=[#;Sç|ÞöåÊåP£‘h¦Ò†ÅE# —L>n0#dÕ1F (% ”ÀÈø—¼š<<PE¥V ø¶ñ:–ŒÜÍfâyñiÆï¢¦cŠËõÚÐ¶Ç @‚p¾ÖÐUM¨Fýëà9R~BÊ5Óub ’^ƒü bˆÀ)û¯G§ÇÐTM¨&þ GýÏ7®kÌð[Éÿ—bñ$í8‘e¢ï¿&3 ëCÍ4_®s¹«ÞÅäpÔA+OIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/arrow_begin-symbolic.svg0000644000175000017500000000615713342667224021476 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/mark_end-symbolic.svg0000644000175000017500000000640713342671560020754 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_008-symbolic.svg0000644000175000017500000000363113342674012021541 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_mark-symbolic.svg0000644000175000017500000000510113342362656021456 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/bar_end-symbolic.svg0000644000175000017500000001030013342672075020553 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_filewin-symbolic.svg0000644000175000017500000002004313342520045022147 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_032-symbolic.svg0000644000175000017500000000363413342674077021554 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_eval-symbolic.svg0000644000175000017500000000752313342475263021464 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_6-symbolic.svg0000644000175000017500000000456513351432267021740 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_004-symbolic.svg0000644000175000017500000000363313342673744021552 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_single-symbolic.svg0000644000175000017500000000624213342473512022006 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_b.png0000644000175000017500000000072713070106167020265 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœtIMEÛ 5¨¿FÿWIDATXÃ핽JAF¿;3ºY4¢6ìÒÙØŠ)B}‹bï³_ÀN‘±¶0¤0 ˆ¿‘,Dm²ÙˆsmEvÉ.‹0·ÃÌ™áÞùTµº¿äº‰"ðï5f@©/iÛýV>9 (²Ù[Å$“ïkÍæê…BDU(d×;X–÷1—ˆ]@ímï@h±=7" Ÿ¹ùLX Vù°ö÷¥Æ1Ü—KE*Gñ?„ONMèÆ0,Èš±y´•~›}à6¶k‹z±þ‰ ÂU¾ý22  ¹P;vsØXYDÎnÎáj1Î 3FÀ#ðï2ÏO!ÿxŠë^®×›¿&¨R©p\·wœnJ9Ž#ÓcMpP1XJt.ÏYÀ”&¿Ìc0$Kx+9¢ißý˜!Ãa—™¡¿SEf©wæSIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_l.png0000644000175000017500000000073113070106167020272 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“IDATXÃí—ÏKQÇ¿³=]×CA©d¥btí(žB) ÿ‰@ü›4èÐß`ˆˆÑ±kEÑèPö‹j]ÛÝé Ç\é¡ë¡x§á1Ÿ7oæûæQ>Ÿ'",W*oÌpÕÊåEñ+¡Ðz?oQ*õ¸çVpÃPWÒéë[á÷G÷z®f@׃)aÛÈfã®o4Ú0Í%K!ÂÂŒP°`óþ73H0¿3 ¢Ñh» iƒaZ¯Âh·Ô?@0ÛK T„ †@¢™”~ k±X=WïÈìà3É©à—Í+èšnK!¼6ô 0“9Lº’>†oÔN²¶ú²ö) 0|2€ÐÚmËÜH±¶T,þê>3€Âùéd€h@#@gs‹»2G¨Öœý™£}7È)áöqnæÖ­Öàö”"œ³N:=ðæÀìC|Ø7n™¹üÿT­ï˜çoƒ`çþŽÆš>Óe+Šã¨ö¨Íuƒ!ZIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_icon64.png0000644000175000017500000000152013070106167017764 00000000000000‰PNG  IHDR@@XGlígAMA± üa cHRMz&€„ú€èu0ê`:˜pœºQ<!PLTE€€€ÿÿÿÿÿÿÿÀÀÀ€€ÿÿ€€S‡étRNS@æØfbKGDf |dtIMEà &/ù#ZIDATHÇ…’1oÛ0…¯€¹Šìaý€jê¦0‚ŒœÙbƒ 2z ÷NÞ ðÞ)¿2¼ãEвKІ­÷ðñ½£V˸ºL÷õºn­ùn¯ X¿‚ý"BõKˆEßFú&¢Ò7¢—¢w?¶ÊgþE,çÇ#îŸDoߤ¨õkÄ—%ÿÈMj*=¥O¨A³) ûb‚˜ýr„T¨f1ÓV(s8æ@sfð-À+"Ž= `@ADƒ"ª¨6x,‡H|ôƒ¤à#ìà}1ÄÈ÷¹…$b9D«:!RÍaðyˆÊ„ ŸõÙ;¾]öNGmŸ}οèÁZ¹,{ÏE˜ÿú^z"áü!Ô†| (ù׆^†8Ð8)ÿÊ€&ߦþñù)/ 7„Ø—ó« ¿é1!Ã9/H™Ÿ÷†”"ñ1>d‘!!Hç"bxüÇ› ŒÒýЫÕ4ä·’‚£â¡Bl´¨vÛP Äðç§lhlø5ʆßâÓGÙÐ"‚¹=ÿ¾ÉçHwnA˜[,C:7±!#¢¾286h Ò±lá] Á:–-#â‡Q?°aiáA¦ˆ p‡u‹.ªd¸™YO†2$¡ïéåÛ ýAçV†ŽŽé ëv˜&Øíð¡j †CçÔP¶F&"ÄýPµà9Ñálˆ¿È°º‹N|ªŒ¾Ri-†OØ´­Q"g%tEXtdate:create2016-12-22T17:38:47+09:00k3y%tEXtdate:modify2016-12-22T17:38:47+09:00m6‹ÅIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/join_miter-symbolic.svg0000644000175000017500000000572213342664163021333 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/wave_begin-symbolic.svg0000644000175000017500000001511313342667351021277 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_4-symbolic.svg0000644000175000017500000000352713351432267021733 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_064-symbolic.svg0000644000175000017500000000362513342674126021554 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_axispoint-symbolic.svg0000644000175000017500000000707713342473263022555 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_point-symbolic.svg0000644000175000017500000000374313342456602021662 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/wave_end-symbolic.svg0000644000175000017500000001466113342672154020765 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_016-symbolic.svg0000644000175000017500000000363413342674050021545 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_vc.png0000644000175000017500000000111513070106167020444 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“õIDATXÃí—ÁJ[A†ÿ3wLlbJ"DJoªØU! ‘º+ ­A7.ºð!ú>‹PádòHRˆ„?J¸°Û–p±Xí]<žlªÍM‘m^¦"nhÑy"áêõ\f}}ƒÔÏéiKRðÇiˆ.-×aGÔÒôô21]½x> ¶h]:ž*k¿Ûv¾ÿˆuôu0U®Ö‘¡L7£Q/rÚÀÉîÞ­ §”cDÀìÁ‹FÎ|þ~Ù/McÃBáö¿N(Ô²Œ H$jz|üY¢[¾X¬q.⦑_†K2¿IEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_axiswin-symbolic.svg0000644000175000017500000001115313342517050022200 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_trimming-symbolic.svg0000644000175000017500000001511713342661721022355 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_rect-symbolic.svg0000644000175000017500000000410713342521030021445 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_7-symbolic.svg0000644000175000017500000000567613351432267021745 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/none_end-symbolic.svg0000644000175000017500000000560113342672242020752 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_undo.png0000644000175000017500000000201013070106167017622 00000000000000‰PNG  IHDRàw=øsBIT|dˆ pHYs × ×B(›xtEXtSoftwarewww.inkscape.org›î<tEXtTitleOptical Drive>gº fIDATH‰Õ•h”uÇ_ßçyînÏ.7g?¶±öÏÖô²¦ábè 7+)ˆ,A%ƒÈ¬ÿªá?FZ`mؼ­I KœnkM9ŒÆŽZN—ìæÚmóvçþpÝnνáó×÷ÃûýùýU"Âí„v[Ùÿ c®‡®FU*Š÷µä%¼·¦V¢ V‘YÖõ%®F}0>Ü-Žhä3élä“L¾óÙ¬ýÒ hzÛÊ Ýþ%÷#nŒ¼¢'@xvÁÑ3£DWȵ¶Ï+ÈZTŒ}9ŒÒø¡[PWÇô*yùÓ­Ù¹÷a'»ÑŒ{:M¤sˆ{#ž> [ß"M³ÚT™¦´ã=ÕRhæ–bM´b˜«Ð½ËæPœô“ñ>úºß&ëÙ›m±=¸U,˜*‘ãp 0°¡0kQ>©ñpS¤­³7YšQD–)åëZè××?Ó ¼<ÁOŸ«2MSÇ—W¾R˜WPŠ=ù+†ù†¹'™'‘$núJÏÛû'›×ºñKÁµ¯Jxº­ûT—¶Ý\—/ödóηHƇ8ñ}-2Gt‡%ù%*w"Ö) óaã NþøÚšm²ezL«·JoÚ¦êLÇ·Ñ‘Áº§˜ÄИþ;®ÛíòuÍ6Q3-³r¢ç#õ~Ã0W‘Ž7c..ÅqxfœŠõuÒëU᎖è߃ýž¥\þ€œ»+qÖdÊ`ã‰[)ö ü~ÝÀMž@“1l—(5kÑÖ×Io:MU¸óh4z!†æ{’èَáL{ö(Ÿ£¨.*©I¸Ö(Ý$kÁu‘Œ·è¹7¥7ô±z,ÜÕ¾iß„"$.»®õ9ø¡*C£¢Ä¼+¸¬²¶¢xùfìÑz image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_frame-symbolic.svg0000644000175000017500000001620213342520666021617 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_arc-symbolic.svg0000644000175000017500000000434213342521054021264 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_legendpoint-symbolic.svg0000644000175000017500000001124713342461515023036 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_draw-symbolic.svg0000644000175000017500000000731013351432267021461 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/join_round-symbolic.svg0000644000175000017500000000611013342664140021325 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_5-symbolic.svg0000644000175000017500000000464013351432267021731 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_zoom-symbolic.svg0000644000175000017500000001074313342476724021522 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_hc.png0000644000175000017500000000101513070106167020425 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“µIDATXÃí–O/QÅÏy˜¶Zÿ£ B¨†­ a×hB+±k>¾€•`!éNbeÓR±#ÂÎÂøŸbaAš‘ig̵n4ÓRÌfÎòeÞ»¿ûfΙ T¡éé©ú……y®æ ³³¯¯ DlUº‘Y1óùãÁ÷÷Äãé‘.*ßKðxt™ˆ(9•³Ù&H×=Š0 Á‹õükñtú##-ÃIIpX.€óÌä(%»¤ª!ˉ⭭/¢lû˩ɆgÝÓÎ@ѳ²Ììñj›Ê”25%b¶°6³ug{åz/ûª Šëð¥B ¼í¿ œÆû¢?*¾uàÚÐp*É~ÃN62¿D+KK²0 ŸdYH S€¢@ úfêöl´ÆïÝ›hëõ?io_šab*ÔšD 0Y’¤-®®ê¶éht8tusüWWÞýxO¶¯ ®P° +1ùëÅ3Û;å?B&rmè8 @ÿ<$~±a¶¹ù¹3óPÒ22”–Z<’ý¹œ­%Tõc.{ƒÁ‹õd’ÎûûeÛ<¹@À;<,JÔOŽg ©ãlIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_3-symbolic.svg0000644000175000017500000000552613351432267021733 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_0-symbolic.svg0000644000175000017500000000352713351432267021727 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_mergewin-symbolic.svg0000644000175000017500000001771513342522211022340 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/bar_begin-symbolic.svg0000644000175000017500000001040613342667276021107 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_icon.png0000644000175000017500000000130013070106167017606 00000000000000‰PNG  IHDR00¥,ä´gAMA± üa cHRMz&€„ú€èu0ê`:˜pœºQ<!PLTE€€€ÿÿÿÿÿÿÿÀÀÀ€€ÿÿ€€ø0²tRNS@æØfbKGDf |dtIMEà &-!O¹IDAT8Ëu”±nÂ0†ÄH2T]kÄÀ¡Î•*/JZ9¬Læ:ÒvJ÷. XHSúþ+¢sÕ|•Q—Ë÷Ö¬Ÿ£2*¥½&(P¥9ô€¤U§4¡ÔV2R²~Vž¶Ædë7!ÜÕµ,-‡ßò¢0(=„®¿©½*0lÍ‚N„÷5…3øÁêҧ֙ʾW:ªôQ{Äg? FM‰¯ôȃ¡OàH;ÝÁ«B•åÁàK]ÚË<áø¡ÇÐd§K[É ÇVω#ŸE:!…ÁÏYΉTÁëÞ ø=¿ð  Š%} ÖÏZ¥Ê. WÒ©Näçð½ÁðÄÊîÛ· .(=(ö­—K+(ü>É€¢ ð bçJÔ_ÄŒ1+ÎíP'Ÿf`0ç<ê”eÐí&¨M“ ҤΠf(ÝïkšfE@Ù·‚rùWñ°ðqš¹–ã%tEXtdate:create2016-12-22T17:38:03+09:00ln%tEXtdate:modify2016-12-22T17:38:03+09:003¡,IEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_1-symbolic.svg0000644000175000017500000000447013351432267021726 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/join_bevel-symbolic.svg0000644000175000017500000000576113342664120021304 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_text-symbolic.svg0000644000175000017500000000615413344733442021516 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_line-symbolic.svg0000644000175000017500000000622413344750361021456 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_cross-symbolic.svg0000644000175000017500000001004213342471657021657 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_datapoint-symbolic.svg0000644000175000017500000000454113342463501022505 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_math.png0000644000175000017500000000031313070106167017612 00000000000000‰PNG  IHDR'€Õ†bKGDª#2 pHYs  šœtIMEÞ  £ ¼·\IDAT(Ïå“Á À0C_ŠÿÿËÙaƒnuµÝyŠ$9¨Àf ¶Ê5Rôf¢†0}0S;ўÑ¼-Öh÷4™‘Ó,u©ŒõsÆÁ:×[Gu;)£7¬{Ïp¡?\¤DIEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_128-symbolic.svg0000644000175000017500000000362213342674167021557 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph.svg0000644000175000017500000004313013342643670016627 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/linewidth_002-symbolic.svg0000644000175000017500000000363413342673665021553 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/stroke_fill_2-symbolic.svg0000644000175000017500000000456513351432267021734 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_scale-symbolic.svg0000644000175000017500000001051713342453266021620 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_align_r.png0000644000175000017500000000070313070106167020277 00000000000000‰PNG  IHDR szzôsRGB®ÎébKGDÿÿÿ ½§“kIDATXÃí–ÏJQ‡¿;NŽÓ¦¨E(J"´Nì D}†ˆ`ÚôAo ásˆÑ²e”¡h”£¤sÛ´mÄñÏlæwwï=ß¹p>.åòR²ÑP*wŠÅ¢P“P*uy¬i“!J"qð_L³¯ª–µwð Á`D¨Ói`Í&6`ÛE<‹ àq|ï¤Dx  êúب×_6Z8›)?åRÝ'$¨‹^2‚‰qaH󽧪n‹çj¹øs³ÕŠ,Ñ€ ×–nÙ™£´k€™˜y;á{ÀX `•¸ýýïnØä®yïê|†4|)Î&¬œœkÿ°Û¡¸©¸x:Ã0d¯;ׄ2Ù©Þ>:n‰FhW@,¤;›pk<± ùõˆh6Ï„kÿ0ú&ôæH¹v@Ç1´4}ЩÖV_¹g$pîÐV”öŸóWºâo¯ ÿ3‘¿·â þp±IEND®B`‚ngraph-gtk-6.08.00/src/gtk/data/pixmaps/ngraph_section-symbolic.svg0000644000175000017500000001127013342520773022170 00000000000000 image/svg+xml ngraph-gtk-6.08.00/src/gtk/data/ngraphui.resources.xml0000644000175000017500000000656313351432267017525 00000000000000 gtk/menus-common.ui gtk/menus-appmenu.ui gtk/help-overlay.ui gtk/menus-tool.ui pixmaps/ngraph_align_b.png pixmaps/ngraph_align_hc.png pixmaps/ngraph_align_l.png pixmaps/ngraph_align_r.png pixmaps/ngraph_align_t.png pixmaps/ngraph_align_vc.png pixmaps/ngraph_arc-symbolic.svg pixmaps/ngraph_axispoint-symbolic.svg pixmaps/ngraph_axiswin-symbolic.svg pixmaps/ngraph_cross-symbolic.svg pixmaps/ngraph_datapoint-symbolic.svg pixmaps/ngraph_draw-symbolic.svg pixmaps/ngraph_eval-symbolic.svg pixmaps/ngraph_filewin-symbolic.svg pixmaps/ngraph_frame-symbolic.svg pixmaps/ngraph_gauss-symbolic.svg pixmaps/ngraph.svg pixmaps/ngraph_icon.png pixmaps/ngraph_icon64.png pixmaps/ngraph_legendpoint-symbolic.svg pixmaps/ngraph_line-symbolic.svg pixmaps/ngraph_mark-symbolic.svg pixmaps/ngraph_math.png pixmaps/ngraph_mergewin-symbolic.svg pixmaps/ngraph_point-symbolic.svg pixmaps/ngraph_rect-symbolic.svg pixmaps/ngraph_scale-symbolic.svg pixmaps/ngraph_section-symbolic.svg pixmaps/ngraph_single-symbolic.svg pixmaps/ngraph_text-symbolic.svg pixmaps/ngraph_trimming-symbolic.svg pixmaps/ngraph_undo.png pixmaps/ngraph_zoom-symbolic.svg pixmaps/none_begin-symbolic.svg pixmaps/none_end-symbolic.svg pixmaps/arrow_begin-symbolic.svg pixmaps/arrow_end-symbolic.svg pixmaps/wave_begin-symbolic.svg pixmaps/wave_end-symbolic.svg pixmaps/mark_begin-symbolic.svg pixmaps/mark_end-symbolic.svg pixmaps/bar_begin-symbolic.svg pixmaps/bar_end-symbolic.svg pixmaps/join_bevel-symbolic.svg pixmaps/join_miter-symbolic.svg pixmaps/join_round-symbolic.svg pixmaps/stroke_fill_0-symbolic.svg pixmaps/stroke_fill_1-symbolic.svg pixmaps/stroke_fill_2-symbolic.svg pixmaps/stroke_fill_3-symbolic.svg pixmaps/stroke_fill_4-symbolic.svg pixmaps/stroke_fill_5-symbolic.svg pixmaps/stroke_fill_6-symbolic.svg pixmaps/stroke_fill_7-symbolic.svg pixmaps/linewidth_002-symbolic.svg pixmaps/linewidth_004-symbolic.svg pixmaps/linewidth_008-symbolic.svg pixmaps/linewidth_016-symbolic.svg pixmaps/linewidth_032-symbolic.svg pixmaps/linewidth_064-symbolic.svg pixmaps/linewidth_128-symbolic.svg css/ngraph.css ngraph-gtk-6.08.00/src/gtk/data/css/0000755000175000017500000000000013375640231014011 500000000000000ngraph-gtk-6.08.00/src/gtk/data/css/ngraph.css0000644000175000017500000000106513337723153015727 00000000000000@binding-set CloseWindow1 { bind "w" { "close" () }; } dialog { -gtk-key-bindings: CloseWindow1; } @keyframes flush-bg { 0% { background-color: @theme_bg_color; } 100% { background-color: @theme_fg_color; } } toolbutton.draw_notify > button { animation: flush-bg infinite alternate ease-in-out 1.5s; } button#StrokeColorButton > colorswatch > overlay { background-color: @theme_bg_color; margin: 3px; border-color: rgba(0,0,0,0); } combobox#MarkerType > box > button > box > arrow { opacity: 0; min-width: 0; } ngraph-gtk-6.08.00/src/gtk/data/gtk/0000755000175000017500000000000013375640231014006 500000000000000ngraph-gtk-6.08.00/src/gtk/data/gtk/menus-common.ui.osx0000644000175000017500000005716013356636640017533 00000000000000 _Graph
_New graph
_Frame graph app.GraphNewFrameAction _Section graph app.GraphNewSectionAction _Cross graph app.GraphNewCrossAction
_All clear app.GraphNewClearAction
_Load graph app.GraphLoadAction _Recent graphs app.GraphRecentAction
_Save app.GraphSaveAction Save _As app.GraphSaveAsAction
_Export image _GRA file app.GraphExportGRAAction _PS file app.GraphExportPSAction _EPS file app.GraphExportEPSAction P_DF file app.GraphExportPDFAction _SVG file app.GraphExportSVGAction P_NG file app.GraphExportPNGAction
_Draw order app.GraphDrawOrderAction
Page Set_up app.GraphPageSetupAction Pre_view app.GraphPrintPreviewAction _Print app.GraphPrintAction
_Current directory app.GraphCurrentDirectoryAction
_Ngraph shell app.GraphShellAction
_Edit
_Redo app.EditRedoAction _Undo app.EditUndoAction
Cu_t app.EditCutAction _Copy app.EditCopyAction _Paste app.EditPasteAction _Delete app.EditDeleteAction _Duplicate app.EditDuplicateAction
draw _Order
_Top app.EditOrderTopAction _Up app.EditOrderUpAction _Down app.EditOrderDownAction _Bottom app.EditOrderBottomAction
_Align
Align _Left app.EditAlignLeftAction Align _Horizontal Center app.EditAlignHCenterAction Align _Right app.EditAlignRightAction
Align _Top app.EditAlignTopAction Align _Vertical Center app.EditAlignVCenterAction Align _Bottom app.EditAlignBottomAction
rotate _90 degree clockwise app.EditRotateCWAction rotate 9_0 degree counter-clockwise app.EditRotateCCWAction flip _Horizontally app.EditFlipHAction flip _Vertically app.EditFlipVActiopn
_View
_Draw app.ViewDrawAction
Data window app.ViewToggleDataWindowAction action-disabled Axis window app.ViewToggleAxisWindowAction action-disabled Legend window app.ViewToggleLegendWindowAction action-disabled Merge window app.ViewToggleMergeWindowAction action-disabled Coordinate window app.ViewToggleCoordinateWindowAction action-disabled Information window app.ViewToggleInformationWindowAction action-disabled Single window mode app.ViewToggleSingleWindowModeAction action-disabled
default _Window config app.ViewDefaultWindowConfigAction action-disabled
_Clear information view app.ViewClearInformationWindowAction
_Sidebar app.ViewSidebarAction _Statusbar app.ViewStatusbarAction _Ruler app.ViewRulerAction _Scrollbar app.ViewScrollbarAction _Command toolbar app.ViewCommandToolbarAction _Toolbox app.ViewToolboxAction cross _Gauge app.ViewCrossGaugeAction _Grid app.ViewGridLineAction
_Object
_Data
_Add
_File app.DataAddFileAction _Range app.DataAddRangeAction
_Recent files app.DataAddRecentFileAction
_Properties app.DataPropertyAction _Close app.DataCloseAction _Edit app.DataEditAction
_Save data app.DataSaveAction _Math Transformation app.DataMathAction
_Axis
_Add
_Frame graph app.AxisAddFrameAction _Section graph app.AxisAddSectionAction _Cross graph app.AxisAddCrossAction Single _Axis app.AxisAddSingleAction
_Properties app.AxisPropertyAction _Delete app.AxisDeleteAction Scale _Zoom app.AxisScaleZoomAction Scale _Clear app.AxisScaleClearAction Scale _Undo app.AxisScaleUndoAction _Grid
_Add app.AxisGridNewAction _Properties app.AxisGridPropertyAction _Delete app.AxisGridDeleteAction
_Path
_Properties app.LegendPathPropertyAction _Delete app.LegendPathDeleteAction
_Rectangle
_Properties app.LegendRectanglePropertyAction _Delete app.LegendRectangleDeleteAction
_Arc
_Properties app.LegendArcPropertyAction _Delete app.LegendArcDeleteAction
_Mark
_Properties app.LegendMarkPropertyAction _Delete app.LegendMarkDeleteAction
_Text
_Properties app.LegendTextPropertyAction _Delete app.LegendTextDeleteAction
_Merge
_Add app.MergeAddAction _Properties app.MergePropertyAction _Close app.MergeCloseAction
_Preference
Viewer app.PreferenceViewerAction _External viewer app.PreferenceExternalViewerAction _Font aliases app.PreferenceFontAction _Add-in script app.PreferenceAddinAction _Miscellaneous app.PreferenceMiscAction
save as default (_Settings) app.PreferenceSaveSettingAction save as default (_Graph) app.PreferenceSaveGraphAction
_Data file default app.PreferenceDataDefaultAction _Legend text default app.PreferenceTextDefaultAction
_Help
Shortcuts... win.show-help-overlay _Help app.help
Cu_t app.EditCutAction _Copy app.EditCopyAction _Paste app.EditPasteAction _Delete app.EditDeleteAction _Duplicate app.EditDuplicateAction
_Properties app.PopupUpdateAction
_Align
Align _Left app.EditAlignLeftAction Align _Horizontal Center app.EditAlignHCenterAction Align _Right app.EditAlignRightAction
Align _Top app.EditAlignTopAction Align _Vertical Center app.EditAlignVCenterAction Align _Bottom app.EditAlignBottomAction
_Rotate
rotate _90 degree clockwise app.EditRotateCWAction rotate 9_0 degree counter-clockwise app.EditRotateCCWAction
_Flip
flip _Horizontally app.EditFlipHAction flip _Vertically app.EditFlipVActiopn
_Top app.EditOrderTopAction _Up app.EditOrderUpAction _Down app.EditOrderDownAction _Bottom app.EditOrderBottomAction
cross _Gauge app.ViewCrossGaugeAction
ngraph-gtk-6.08.00/src/gtk/data/gtk/help-overlay.ui0000644000175000017500000002013413144305140016663 00000000000000 1 1 shortcuts 12 1 General 1 app.GraphLoadAction Load a graph (NGP file) 1 app.GraphSaveAction Save the graph 1 app.GraphSaveAsAction Save the graph with a new filename 1 app.GraphPrintAction Print the graph 1 app.DataAddFileAction Add data file 1 app.AxisScaleClearAction Clear Scale 1 app.ViewDrawAction Draw on Viewer Window 1 app.ViewCrossGaugeAction Show cross gauge 1 app.quit Quit the application 1 Editing 1 app.EditUndoAction Undo previous command 1 app.EditUndoAction Redo previous command 1 app.EditCutAction Cut selected object to clipboard 1 app.EditCopyAction Copy selected object to clipboard 1 app.EditPasteAction Paste object from clipboard 1 app.EditDeleteAction Delete the selected object 1 app.EditDuplicateAction Duplicate the selected object 1 app.EditOrderTopAction Rise selection to top 1 app.EditOrderBottomAction Lower selection to bottom 1 Window (multi window mode only) 1 app.ViewToggleDataWindowAction Activate Data Window 1 app.ViewToggleAxisWindowAction Activate Axis Window 1 app.ViewToggleLegendWindowAction Activate Legend Window 1 app.ViewToggleMergeWindowAction Activate Merge Window 1 app.ViewToggleCoordinateWindowAction Activate Coordinate Window 1 app.ViewToggleInformationWindowAction Activate Information Window 1 Help 1 app.help Show the help document 1 win.show-help-overlay Show shortcut keys ngraph-gtk-6.08.00/src/gtk/data/gtk/menus-tool.ui0000644000175000017500000000645713337723153016406 00000000000000
_Stroke app.StrokeFillStrokeAction _Fill app.StrokeFillFillAction _Close path app.StrokeFillClosePathAction action-disabled
miter app.JoinTypeAction miter round app.JoinTypeAction round bevel app.JoinTypeAction bevel
none app.MarkerTypeBeginAction none arrow app.MarkerTypeBeginAction arrow wave app.MarkerTypeBeginAction wave mark app.MarkerTypeBeginAction mark bar app.MarkerTypeBeginAction bar
none app.MarkerTypeEndAction none arrow app.MarkerTypeEndAction arrow wave app.MarkerTypeEndAction wave mark app.MarkerTypeEndAction mark bar app.MarkerTypeEndAction bar
ngraph-gtk-6.08.00/src/gtk/data/gtk/menus-appmenu.ui.osx0000644000175000017500000000435513070106167017673 00000000000000
About %s app.about replace-appname
Services services-submenu
Hide %s hide-this gtkinternal.hide Hide Others hide-others gtkinternal.hide-others Show All show-all gtkinternal.show-all
Quit %s app.quit replace-appname
ngraph-gtk-6.08.00/src/gtk/data/gtk/menus-appmenu.ui.in0000644000175000017500000000136613070106167017467 00000000000000
_Help app.help _About app.about _Quit app.quit
ngraph-gtk-6.08.00/src/gtk/data/gtk/menus-common.ui.in0000644000175000017500000005315113356636626017330 00000000000000 _Graph
_New graph
_Frame graph app.GraphNewFrameAction _Section graph app.GraphNewSectionAction _Cross graph app.GraphNewCrossAction
_All clear app.GraphNewClearAction
_Load graph app.GraphLoadAction _Recent graphs app.GraphRecentAction
_Save app.GraphSaveAction Save _As app.GraphSaveAsAction
_Export image _GRA file app.GraphExportGRAAction _PS file app.GraphExportPSAction _EPS file app.GraphExportEPSAction P_DF file app.GraphExportPDFAction _SVG file app.GraphExportSVGAction P_NG file app.GraphExportPNGAction
_Draw order app.GraphDrawOrderAction
Page Set_up app.GraphPageSetupAction Pre_view app.GraphPrintPreviewAction _Print app.GraphPrintAction
_Current directory app.GraphCurrentDirectoryAction
_Ngraph shell app.GraphShellAction
_Edit
_Redo app.EditRedoAction _Undo app.EditUndoAction
Cu_t app.EditCutAction _Copy app.EditCopyAction _Paste app.EditPasteAction _Delete app.EditDeleteAction _Duplicate app.EditDuplicateAction
draw _Order
_Top app.EditOrderTopAction _Up app.EditOrderUpAction _Down app.EditOrderDownAction _Bottom app.EditOrderBottomAction
_Align
Align _Left app.EditAlignLeftAction Align _Horizontal Center app.EditAlignHCenterAction Align _Right app.EditAlignRightAction
Align _Top app.EditAlignTopAction Align _Vertical Center app.EditAlignVCenterAction Align _Bottom app.EditAlignBottomAction
rotate _90 degree clockwise app.EditRotateCWAction rotate 9_0 degree counter-clockwise app.EditRotateCCWAction flip _Horizontally app.EditFlipHAction flip _Vertically app.EditFlipVActiopn
_View
_Draw app.ViewDrawAction
_Clear information view app.ViewClearInformationWindowAction
_Sidebar app.ViewSidebarAction _Statusbar app.ViewStatusbarAction _Ruler app.ViewRulerAction _Scrollbar app.ViewScrollbarAction _Command toolbar app.ViewCommandToolbarAction _Toolbox app.ViewToolboxAction cross _Gauge app.ViewCrossGaugeAction _Grid app.ViewGridLineAction
_Object
_Data
_Add
_File app.DataAddFileAction _Range app.DataAddRangeAction
_Recent files app.DataAddRecentFileAction
_Properties app.DataPropertyAction _Close app.DataCloseAction _Edit app.DataEditAction
_Save data app.DataSaveAction _Math Transformation app.DataMathAction
_Axis
_Add
_Frame graph app.AxisAddFrameAction _Section graph app.AxisAddSectionAction _Cross graph app.AxisAddCrossAction Single _Axis app.AxisAddSingleAction
_Properties app.AxisPropertyAction _Delete app.AxisDeleteAction Scale _Zoom app.AxisScaleZoomAction Scale _Clear app.AxisScaleClearAction Scale _Undo app.AxisScaleUndoAction _Grid
_Add app.AxisGridNewAction _Properties app.AxisGridPropertyAction _Delete app.AxisGridDeleteAction
_Path
_Properties app.LegendPathPropertyAction _Delete app.LegendPathDeleteAction
_Rectangle
_Properties app.LegendRectanglePropertyAction _Delete app.LegendRectangleDeleteAction
_Arc
_Properties app.LegendArcPropertyAction _Delete app.LegendArcDeleteAction
_Mark
_Properties app.LegendMarkPropertyAction _Delete app.LegendMarkDeleteAction
_Text
_Properties app.LegendTextPropertyAction _Delete app.LegendTextDeleteAction
_Merge
_Add app.MergeAddAction _Properties app.MergePropertyAction _Close app.MergeCloseAction
_Preference
Viewer app.PreferenceViewerAction _External viewer app.PreferenceExternalViewerAction _Font aliases app.PreferenceFontAction _Add-in script app.PreferenceAddinAction _Miscellaneous app.PreferenceMiscAction
save as default (_Settings) app.PreferenceSaveSettingAction save as default (_Graph) app.PreferenceSaveGraphAction
_Data file default app.PreferenceDataDefaultAction _Legend text default app.PreferenceTextDefaultAction
_Help
_Help app.help
Cu_t app.EditCutAction _Copy app.EditCopyAction _Paste app.EditPasteAction _Delete app.EditDeleteAction _Duplicate app.EditDuplicateAction
_Properties app.PopupUpdateAction
_Align
Align _Left app.EditAlignLeftAction Align _Horizontal Center app.EditAlignHCenterAction Align _Right app.EditAlignRightAction
Align _Top app.EditAlignTopAction Align _Vertical Center app.EditAlignVCenterAction Align _Bottom app.EditAlignBottomAction
_Rotate
rotate _90 degree clockwise app.EditRotateCWAction rotate 9_0 degree counter-clockwise app.EditRotateCCWAction
_Flip
flip _Horizontally app.EditFlipHAction flip _Vertically app.EditFlipVActiopn
_Top app.EditOrderTopAction _Up app.EditOrderUpAction _Down app.EditOrderDownAction _Bottom app.EditOrderBottomAction
cross _Gauge app.ViewCrossGaugeAction
ngraph-gtk-6.08.00/src/gtk/x11print.c0000644000175000017500000006455013351432267014076 00000000000000/* * $Id: x11print.c,v 1.52 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include "nstring.h" #include "object.h" #include "ioutil.h" #include "gtk_liststore.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "x11gui.h" #include "x11dialg.h" #include "ox11menu.h" #include "ogra2cairofile.h" #include "x11menu.h" #include "x11print.h" #include "x11file.h" #include "x11commn.h" #include "x11view.h" #define DEVICE_BUF_SIZE 20 #define MESSAGE_BUF_SIZE 1024 static char *PsVersion[] = { "PostScript Level 3", "PostScript Level 2", NULL, }; static char *SvgVersion[] = { "SVG version 1.1", "SVG version 1.2", NULL, }; struct print_obj { struct objlist *graobj, *g2wobj; int id; N_VALUE *g2winst; }; static GtkPrintSettings *PrintSettings = NULL; static void DriverDialogSelectCB(GtkWidget *wi, gpointer client_data) { int a, i, l, n; struct extprinter *pcur; struct DriverDialog *d; char *ptr, ngp_ext[] = ".ngp"; d = (struct DriverDialog *) client_data; a = combo_box_get_active(d->driver); if (a < 0) return; pcur = Menulocal.extprinterroot; i = 0; while (pcur) { if (i != a) { pcur = pcur->next; i++; continue; } if (pcur->ext && pcur->ext[0] != '\0') { if (NgraphApp.FileName) { l = strlen(NgraphApp.FileName); n = sizeof(ngp_ext) - 1; if (l > n && strcasecmp(NgraphApp.FileName + l - n, ngp_ext) == 0) { l -= n; } ptr = g_strdup_printf("%.*s.%s", l, NgraphApp.FileName, CHK_STR(pcur->ext)); gtk_entry_set_text(GTK_ENTRY(d->file), CHK_STR(ptr)); g_free(ptr); } d->ext = pcur->ext; } else { gtk_entry_set_text(GTK_ENTRY(d->file), ""); d->ext = NULL; } gtk_entry_set_text(GTK_ENTRY(d->option), CHK_STR(pcur->option)); break; } } static void DriverDialogBrowseCB(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { char *file; const char *str; struct DriverDialog *d; d = (struct DriverDialog *) user_data; str = gtk_entry_get_text(w); if (nGetSaveFileName(d->widget, _("External Driver Output"), d->ext, NULL, str, &file, TRUE, Menulocal.changedirectory) == IDOK) { gtk_entry_set_text(w, file); } g_free(file); } static void DriverDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct DriverDialog *d; struct extprinter *pcur; int i, j; d = (struct DriverDialog *) data; if (makewidget) { table = gtk_grid_new(); i = 0; w = combo_box_create(); d->driver = w; add_widget_to_table(table, w, _("_Driver:"), FALSE, i++); g_signal_connect(d->driver, "changed", G_CALLBACK(DriverDialogSelectCB), d); w = create_text_entry(FALSE, TRUE); d->option = w; add_widget_to_table(table, w, _("_Option:"), TRUE, i++); w = create_file_entry_with_cb(G_CALLBACK(DriverDialogBrowseCB), d); d->file = w; add_widget_to_table(table, w, _("_File:"), TRUE, i++); gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } combo_box_clear(d->driver); pcur = Menulocal.extprinterroot; while (pcur != NULL) { combo_box_append_text(d->driver, pcur->name); pcur = pcur->next; j++; } combo_box_set_active(d->driver, 0); } static void DriverDialogClose(GtkWidget *w, void *data) { int a, i; struct extprinter *pcur; struct DriverDialog *d; const char *s, *file; char *driver, *option; d = (struct DriverDialog *) data; if (d->ret == IDCANCEL) return; a = combo_box_get_active(d->driver); pcur = Menulocal.extprinterroot; i = 0; while (pcur != NULL) { if (i == a && pcur->driver) { driver = g_strdup(pcur->driver); if (driver) { putobj(d->Obj, "driver", d->Id, driver); } break; } pcur = pcur->next; i++; } s = gtk_entry_get_text(GTK_ENTRY(d->option)); file = gtk_entry_get_text(GTK_ENTRY(d->file)); option = NULL; if (s || file) { option = g_strdup_printf("%s%s%s%s", (file) ? "-o '" : "", CHK_STR(file), (file) ? "' " : "", CHK_STR(s)); } putobj(d->Obj, "option", d->Id, option); } void DriverDialog(struct DriverDialog *data, struct objlist *obj, int id) { data->SetupWindow = DriverDialogSetup; data->CloseWindow = DriverDialogClose; data->Obj = obj; data->Id = id; data->ext = NULL; } static void OutputDataDialogSetupItem(GtkWidget *w, struct OutputDataDialog *d) { spin_entry_set_val(d->div_entry, d->div); } static void OutputDataDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox; struct OutputDataDialog *d; d = (struct OutputDataDialog *) data; if (makewidget) { w = create_spin_entry(0, 200, 1, FALSE, TRUE); d->div_entry = w; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); item_setup(hbox, w, _("_Div:"), TRUE); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } OutputDataDialogSetupItem(wi, d); } static void OutputDataDialogClose(GtkWidget *w, void *data) { struct OutputDataDialog *d; d = (struct OutputDataDialog *) data; if (d->ret != IDOK) return; d->div = spin_entry_get_val(d->div_entry); } void OutputDataDialog(struct OutputDataDialog *data, int div) { data->SetupWindow = OutputDataDialogSetup; data->CloseWindow = OutputDataDialogClose; data->div = div; } static void OutputImageDialogSetupItem(GtkWidget *w, struct OutputImageDialog *d) { int i; GtkWidget *vlabel; GtkWidget *window; GtkRequisition minimum_size; vlabel = get_mnemonic_label(d->version); gtk_label_set_text(GTK_LABEL(vlabel), ""); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_opacity), FALSE); combo_box_clear(d->version); switch (d->DlgType) { case MenuIdOutputPSFile: case MenuIdOutputEPSFile: for (i = 0; PsVersion[i]; i++) { combo_box_append_text(d->version, PsVersion[i]); } set_widget_visibility_with_label(d->dpi, FALSE); set_widget_visibility_with_label(d->version, TRUE); gtk_widget_set_visible(d->t2p, TRUE); gtk_label_set_markup_with_mnemonic(GTK_LABEL(vlabel), _("_PostScript Version:")); gtk_spin_button_set_value(GTK_SPIN_BUTTON(d->dpi), 72); combo_box_set_active(d->version, Menulocal.ps_version); break; case MenuIdOutputPNGFile: set_widget_visibility_with_label(d->dpi, TRUE); set_widget_visibility_with_label(d->version, FALSE); gtk_widget_set_visible(d->t2p, FALSE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(d->dpi), Menulocal.png_dpi); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_opacity), Menulocal.use_opacity); break; case MenuIdOutputPDFFile: set_widget_visibility_with_label(d->dpi, FALSE); set_widget_visibility_with_label(d->version, FALSE); gtk_widget_set_visible(d->t2p, TRUE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(d->dpi), 72); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_opacity), Menulocal.use_opacity); break; case MenuIdOutputSVGFile: for (i = 0; PsVersion[i]; i++) { combo_box_append_text(d->version, SvgVersion[i]); } set_widget_visibility_with_label(d->dpi, FALSE); set_widget_visibility_with_label(d->version, TRUE); gtk_widget_set_visible(d->t2p, TRUE); gtk_label_set_markup_with_mnemonic(GTK_LABEL(vlabel), _("_SVG Version:")); gtk_spin_button_set_value(GTK_SPIN_BUTTON(d->dpi), 72); combo_box_set_active(d->version, Menulocal.svg_version); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_opacity), Menulocal.use_opacity); break; #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: set_widget_visibility_with_label(d->dpi, TRUE); set_widget_visibility_with_label(d->version, FALSE); gtk_widget_set_visible(d->t2p, FALSE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(d->dpi), Menulocal.emf_dpi); break; #endif /* CAIRO_HAS_WIN32_SURFACE */ } window = gtk_widget_get_parent(GTK_WIDGET(d->vbox)); if (GTK_IS_WINDOW(window)) { gtk_widget_get_preferred_size(GTK_WIDGET(d->vbox), &minimum_size, NULL); gtk_window_resize(GTK_WINDOW(window), minimum_size.width, minimum_size.height); } } static void OutputImageDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w; struct OutputImageDialog *d; char *title; d = (struct OutputImageDialog *) data; if (makewidget) { w = gtk_check_button_new_with_mnemonic(_("_Convert texts to paths")); d->t2p = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_Use opacity")); d->use_opacity = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_spin_button_new_with_range(1, DPI_MAX, 1); gtk_spin_button_set_numeric(GTK_SPIN_BUTTON(w), TRUE); gtk_entry_set_activates_default(GTK_ENTRY(w), TRUE); d->dpi = w; item_setup(GTK_WIDGET(d->vbox), w, "_DPI:", FALSE); w = combo_box_create(); d->version = w; item_setup(GTK_WIDGET(d->vbox), w, "", FALSE); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } switch (d->DlgType) { case MenuIdOutputPSFile: title = N_("Cairo PS Output"); break; case MenuIdOutputEPSFile: title = N_("Cairo EPS Output"); break; case MenuIdOutputPNGFile: title = N_("Cairo PNG Output"); break; case MenuIdOutputPDFFile: title = N_("Cairo PDF Output"); break; case MenuIdOutputSVGFile: title = N_("Cairo SVG Output"); break; #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: title = N_("Cairo EMF Output"); break; #endif /* CAIRO_HAS_WIN32_SURFACE */ default: title = NULL; /* not reachable */ } gtk_window_set_title(GTK_WINDOW(wi), _(title)); OutputImageDialogSetupItem(w, d); } static void OutputImageDialogClose(GtkWidget *w, void *data) { struct OutputImageDialog *d; int a; d = (struct OutputImageDialog *) data; if (d->ret != IDOK) return; d->Dpi = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(d->dpi)); d->UseOpacity = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->use_opacity)); switch (d->DlgType) { case MenuIdOutputPSFile: d->text2path = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->t2p)); a = combo_box_get_active(d->version); switch (a) { case 0: d->Version = TYPE_PS3; break; case 1: default: d->Version = TYPE_PS2; break; } Menulocal.ps_version = a; break; case MenuIdOutputEPSFile: d->text2path = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->t2p)); a = combo_box_get_active(d->version); switch (a) { case 0: d->Version = TYPE_EPS3; break; case 1: default: d->Version = TYPE_EPS2; break; } Menulocal.ps_version = a; break; case MenuIdOutputPNGFile: d->Version = TYPE_PNG; Menulocal.png_dpi = d->Dpi; break; #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: d->Version = TYPE_EMF; Menulocal.emf_dpi = d->Dpi; break; #endif /* CAIRO_HAS_WIN32_SURFACE */ case MenuIdOutputPDFFile: d->text2path = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->t2p)); d->Version = TYPE_PDF; break; case MenuIdOutputSVGFile: d->text2path = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->t2p)); a = combo_box_get_active(d->version); switch (a) { case 0: d->Version = TYPE_SVG1_1; break; case 1: default: d->Version = TYPE_SVG1_2; break; } Menulocal.svg_version = a; break; } } void OutputImageDialog(struct OutputImageDialog *data, int type) { data->SetupWindow = OutputImageDialogSetup; data->CloseWindow = OutputImageDialogClose; data->DlgType = type; } static void draw_gra(struct objlist *graobj, int id, char *msg, int close) { ProgressDialogCreate(msg); SetStatusBar(msg); if (exeobj(graobj, "open", id, 0, NULL) == 0) { exeobj(graobj, "draw", id, 0, NULL); exeobj(graobj, "flush", id, 0, NULL); if (close) { exeobj(graobj, "close", id, 0, NULL); } } ProgressDialogFinalize(); ResetStatusBar(); main_window_redraw(); } static void draw_page(GtkPrintOperation *operation, GtkPrintContext *context, int page_nr, gpointer user_data) { struct objlist *graobj, *g2wobj; char *argv[2]; struct print_obj *pobj; int id, r; N_VALUE *g2winst; pobj = (struct print_obj *) user_data; graobj = pobj->graobj; g2wobj = pobj->g2wobj; id = pobj->id; g2winst = pobj->g2winst; argv[0] = (char *) context; argv[1] = NULL; r = _exeobj(g2wobj, "_context", g2winst, 1, argv); if (r == 0) { draw_gra(graobj, id, _("Printing."), TRUE); } } static void init_graobj(struct objlist *graobj, int id, char *dev_name, int dev_oid) { struct narray *drawrable; unsigned int i, n; char *device; putobj(graobj, "paper_width", id, &(Menulocal.PaperWidth)); putobj(graobj, "paper_height", id, &(Menulocal.PaperHeight)); putobj(graobj, "left_margin", id, &(Menulocal.LeftMargin)); putobj(graobj, "top_margin", id, &(Menulocal.TopMargin)); putobj(graobj, "zoom", id, &(Menulocal.PaperZoom)); if (arraynum(&(Menulocal.drawrable)) > 0) { drawrable = arraynew(sizeof(char *)); n = arraynum(&(Menulocal.drawrable)); for (i = 0; i < n; i++) { arrayadd2(drawrable, *(char **) arraynget(&(Menulocal.drawrable), i)); } } else { drawrable = NULL; } putobj(graobj, "draw_obj", id, drawrable); device = (char *) g_malloc(DEVICE_BUF_SIZE); snprintf(device, DEVICE_BUF_SIZE, "%s:^%d", dev_name, dev_oid); putobj(graobj, "device", id, device); } void CmOutputPrinter(int select_file, int show_dialog) { GtkPrintOperation *print; GtkPrintOperationResult res; char buf[MESSAGE_BUF_SIZE]; struct objlist *graobj, *g2wobj; int id, g2wid, g2woid, opt; N_VALUE *g2winst; GError *error; struct print_obj pobj; GtkPaperSize *paper_size; GtkPageSetup *page_setup; if (Menulock || Globallock) return; if (select_file && ! SetFileHidden()) return; FileAutoScale(); AdjustAxis(); graobj = chkobject("gra"); if (graobj == NULL) return; g2wobj = chkobject("gra2gtkprint"); if (g2wobj == NULL) return; g2wid = newobj(g2wobj); if (g2wid < 0) return; putobj(g2wobj, "use_opacity", g2wid, &Menulocal.use_opacity); g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); id = newobj(graobj); init_graobj(graobj, id, "gra2gtkprint", g2woid); print = gtk_print_operation_new(); gtk_print_operation_set_n_pages(print, 1); gtk_print_operation_set_has_selection(print, FALSE); gtk_print_operation_set_support_selection(print, FALSE); gtk_print_operation_set_embed_page_setup(print, FALSE); gtk_print_operation_set_use_full_page(print, TRUE); if (PrintSettings == NULL) PrintSettings = gtk_print_settings_new(); if (Menulocal.PaperId == PAPER_ID_CUSTOM) { paper_size = gtk_paper_size_new_custom(Menulocal.PaperName, Menulocal.PaperName, Menulocal.PaperWidth / 100.0, Menulocal.PaperHeight / 100.0, GTK_UNIT_MM); } else { paper_size = gtk_paper_size_new(Menulocal.PaperName); } page_setup = gtk_page_setup_new(); gtk_page_setup_set_paper_size(page_setup, paper_size); gtk_paper_size_free(paper_size); if (Menulocal.PaperLandscape) { gtk_page_setup_set_orientation(page_setup, GTK_PAGE_ORIENTATION_LANDSCAPE); } else { gtk_page_setup_set_orientation(page_setup, GTK_PAGE_ORIENTATION_PORTRAIT); } gtk_print_operation_set_default_page_setup(print, page_setup); g_object_unref(page_setup); gtk_print_operation_set_print_settings(print, PrintSettings); pobj.graobj = graobj; pobj.id = id; pobj.g2wobj = g2wobj; pobj.g2winst = g2winst; g_signal_connect(print, "draw_page", G_CALLBACK(draw_page), &pobj); switch (show_dialog) { case PRINT_SHOW_DIALOG_NONE: opt = GTK_PRINT_OPERATION_ACTION_PRINT; break; case PRINT_SHOW_DIALOG_PREVIEW: opt = GTK_PRINT_OPERATION_ACTION_PREVIEW; break; case PRINT_SHOW_DIALOG_DIALOG: opt = GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG; break; default: opt = GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG; } #ifdef __WIN64__ gtk_widget_set_visible(NgraphApp.Viewer.side_pane1, FALSE); #endif res = gtk_print_operation_run(print, opt, GTK_WINDOW(TopLevel), &error); #ifdef __WIN64__ gtk_widget_set_visible(NgraphApp.Viewer.side_pane1, Menulocal.sidebar); #endif if (res == GTK_PRINT_OPERATION_RESULT_ERROR) { snprintf(buf, sizeof(buf), _("Printing error: %s"), error->message); message_box(NULL, buf, _("Print"), RESPONS_ERROR); g_error_free(error); } else if (res == GTK_PRINT_OPERATION_RESULT_APPLY) { if (PrintSettings) g_object_unref(PrintSettings); PrintSettings = g_object_ref(gtk_print_operation_get_print_settings(print)); } g_object_unref(print); delobj(graobj, id); delobj(g2wobj, g2wid); if (select_file && NgraphApp.FileWin.data.data) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, TRUE); } } void CmOutputDriver(void) { struct objlist *graobj, *g2wobj; int id, g2wid, g2woid; N_VALUE *g2winst; int ret; struct savedstdio stdio; if (Menulock || Globallock) return; if (Menulocal.select_data && ! SetFileHidden()) return; FileAutoScale(); AdjustAxis(); graobj = chkobject("gra"); if (graobj == NULL) return; g2wobj = chkobject("gra2prn"); if (g2wobj == NULL) return; g2wid = newobj(g2wobj); if (g2wid < 0) return; DriverDialog(&DlgDriver, g2wobj, g2wid); ret = DialogExecute(TopLevel, &DlgDriver); if (ret == IDOK) { SetStatusBar(_("Spawning external driver.")); g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); id = newobj(graobj); init_graobj(graobj, id, "gra2prn", g2woid); ignorestdio(&stdio); draw_gra(graobj, id, _("Drawing."), TRUE); restorestdio(&stdio); delobj(graobj, id); ResetStatusBar(); } delobj(g2wobj, g2wid); if (Menulocal.select_data) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, TRUE); } } void CmOutputViewerB(void *wi, gpointer client_data) { if (Menulock || Globallock) return; FileAutoScale(); AdjustAxis(); if (Menulocal.exwin_use_external) { struct objlist *menuobj; int show_dialog, s; char *argv[3]; menuobj = chkobject("menu"); if (menuobj == NULL) return; s = FALSE; show_dialog = PRINT_SHOW_DIALOG_PREVIEW; argv[0] = (char *) &s; argv[1] = (char *) &show_dialog; argv[2] = NULL; exeobj(menuobj, "print", 0, 2, argv); } else { struct objlist *graobj, *g2wobj; int id, g2wid, g2woid, c; N_VALUE *g2winst; int delgra; if ((graobj = chkobject("gra")) == NULL) return; if ((g2wobj = chkobject("gra2gtk")) == NULL) return; g2wid = newobj(g2wobj); if (g2wid < 0) return; g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); putobj(g2wobj, "dpi", g2wid, &(Menulocal.exwindpi)); putobj(g2wobj, "width", g2wid, &Menulocal.exwinwidth); putobj(g2wobj, "height", g2wid, &Menulocal.exwinheight); c = Menulocal.bg_r * 255.0; putobj(g2wobj, "BR", g2wid, &c); c = Menulocal.bg_g * 255.0; putobj(g2wobj, "BG", g2wid, &c); c = Menulocal.bg_b * 255.0; putobj(g2wobj, "BB", g2wid, &c); putobj(g2wobj, "use_opacity", g2wid, &Menulocal.use_opacity); id = newobj(graobj); init_graobj(graobj, id, "gra2gtk", g2woid); draw_gra(graobj, id, _("Spawning external viewer."), FALSE); delgra = TRUE; _putobj(g2wobj, "delete_gra", g2winst, &delgra); exeobj(g2wobj, "present", g2wid, 0, NULL); } } static char * get_base_ngp_name(void) { char *ptr, *tmp; if (NgraphApp.FileName == NULL) return NULL; tmp = g_strdup(NgraphApp.FileName); if (tmp == NULL) return NULL; ptr = strrchr(tmp, '.'); if (ptr && strcmp(ptr, ".ngp") == 0) { *ptr = '\0'; } return tmp; } static void CmPrintGRAFile(void) { struct objlist *graobj, *g2wobj; int id, g2wid, g2woid, ret; N_VALUE *g2winst; char *tmp, *file; if (Menulock || Globallock) return; tmp = get_base_ngp_name(); ret = nGetSaveFileName(TopLevel, _("GRA file"), "gra", NULL, tmp, &file, FALSE, Menulocal.changedirectory); if (tmp) g_free(tmp); if (ret != IDOK) return; if (file == NULL) { return; } if (Menulocal.select_data && ! SetFileHidden()) return; FileAutoScale(); AdjustAxis(); if ((graobj = chkobject("gra")) == NULL) { g_free(file); return; } if ((g2wobj = chkobject("gra2file")) == NULL) { g_free(file); return; } g2wid = newobj(g2wobj); if (g2wid < 0) { g_free(file); return; } g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); putobj(g2wobj, "file", g2wid, file); id = newobj(graobj); init_graobj(graobj, id, "gra2file", g2woid); draw_gra(graobj, id, _("Making GRA file."), TRUE); delobj(graobj, id); delobj(g2wobj, g2wid); if (Menulocal.select_data) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, TRUE); } } static void CmOutputImage(int type) { struct objlist *graobj, *g2wobj; int id, g2wid, g2woid; N_VALUE *g2winst; int ret; char *title, *ext_str; char *file, *tmp; if (Menulock || Globallock) return; switch (type) { case MenuIdOutputPSFile: title = "Save as PostScript"; ext_str = "ps"; break; case MenuIdOutputEPSFile: title = "Save as Encapsulated PostScript"; ext_str = "eps"; break; case MenuIdOutputPDFFile: title = "Save as Portable Document Format (PDF)"; ext_str = "pdf"; break; case MenuIdOutputPNGFile: title = "Save as Portable Network Graphics (PNG)"; ext_str = "png"; break; case MenuIdOutputSVGFile: title = "Save as Scalable Vector Graphics (SVG)"; ext_str = "svg"; break; #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: title = "Save as Windows Enhanced Metafile (EMF)"; ext_str = "emf"; break; #endif /* CAIRO_HAS_WIN32_SURFACE */ default: /* not reachable */ title = NULL; ext_str = NULL; } tmp = get_base_ngp_name(); ret = nGetSaveFileName(TopLevel, title, ext_str, NULL, tmp, &file, FALSE, Menulocal.changedirectory); if (tmp) { g_free(tmp); } if (ret != IDOK) { return; } if (file == NULL) { return; } OutputImageDialog(&DlgImageOut, type); ret = DialogExecute(TopLevel, &DlgImageOut); if (ret != IDOK) { g_free(file); return; } if (Menulocal.select_data && ! SetFileHidden()) return; FileAutoScale(); AdjustAxis(); graobj = chkobject("gra"); if (graobj == NULL) { g_free(file); return; } g2wobj = chkobject("gra2cairofile"); if (g2wobj == NULL) { g_free(file); return; } g2wid = newobj(g2wobj); if (g2wid < 0) { g_free(file); return; } g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); id = newobj(graobj); putobj(g2wobj, "file", g2wid, file); switch (type) { case MenuIdOutputPSFile: case MenuIdOutputEPSFile: case MenuIdOutputSVGFile: case MenuIdOutputPDFFile: #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: #endif /* CAIRO_HAS_WIN32_SURFACE */ putobj(g2wobj, "text2path", g2wid, &DlgImageOut.text2path); break; case MenuIdOutputPNGFile: break; } putobj(g2wobj, "use_opacity", g2wid, &DlgImageOut.UseOpacity); putobj(g2wobj, "dpi", g2wid, &DlgImageOut.Dpi); putobj(g2wobj, "format", g2wid, &DlgImageOut.Version); init_graobj(graobj, id, "gra2cairofile", g2woid); draw_gra(graobj, id, _("Drawing."), TRUE); delobj(graobj, id); delobj(g2wobj, g2wid); if (Menulocal.select_data) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, TRUE); } } #if WINDOWS static void CmOutputEMF(int type) { struct objlist *graobj, *g2wobj; int id, g2wid, g2woid; N_VALUE *g2winst; int ret; char *title, *ext_str; char *file, *tmp; if (Menulock || Globallock) return; title = "Save as Windows Enhanced Metafile (EMF)"; file = NULL; if (type == MenuIdOutputEMFFile) { ext_str = "emf"; tmp = get_base_ngp_name(); ret = nGetSaveFileName(TopLevel, title, ext_str, NULL, tmp, &file, FALSE, Menulocal.changedirectory); if (tmp) { g_free(tmp); } if (ret != IDOK) { return; } if (file == NULL) { return; } } if (Menulocal.select_data && ! SetFileHidden()) return; FileAutoScale(); AdjustAxis(); graobj = chkobject("gra"); if (graobj == NULL) { g_free(file); return; } g2wobj = chkobject("gra2emf"); if (g2wobj == NULL) { g_free(file); return; } g2wid = newobj(g2wobj); if (g2wid < 0) { g_free(file); return; } g2winst = chkobjinst(g2wobj, g2wid); _getobj(g2wobj, "oid", g2winst, &g2woid); id = newobj(graobj); putobj(g2wobj, "file", g2wid, file); init_graobj(graobj, id, "gra2emf", g2woid); draw_gra(graobj, id, _("Drawing."), TRUE); delobj(graobj, id); delobj(g2wobj, g2wid); if (Menulocal.select_data) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, TRUE); } } #endif void CmOutputPrinterB(void *wi, gpointer client_data) { CmOutputPrinter(FALSE, PRINT_SHOW_DIALOG_DIALOG); } void CmOutputMenu(void *wi, gpointer client_data) { switch (GPOINTER_TO_INT(client_data)) { case MenuIdOutputGRAFile: CmPrintGRAFile(); break; case MenuIdOutputPSFile: case MenuIdOutputEPSFile: case MenuIdOutputPDFFile: case MenuIdOutputPNGFile: case MenuIdOutputSVGFile: #ifdef CAIRO_HAS_WIN32_SURFACE case MenuIdOutputCairoEMFFile: #endif /* CAIRO_HAS_WIN32_SURFACE */ CmOutputImage(GPOINTER_TO_INT(client_data)); break; #if WINDOWS case MenuIdOutputEMFFile: case MenuIdOutputEMFClipboard: CmOutputEMF(GPOINTER_TO_INT(client_data)); break; #endif } } ngraph-gtk-6.08.00/src/gtk/gtk_action.c0000644000175000017500000006014613356636720014534 00000000000000#include "gtk_common.h" #include "dir_defs.h" #include "x11menu.h" #include "x11info.h" #include "x11cood.h" #include "x11merge.h" #include "x11lgnd.h" #include "x11axis.h" #include "x11file.h" #include "x11graph.h" #include "x11print.h" #include "x11opt.h" #include "x11view.h" #include "ox11menu.h" #if USE_APP_MENU static void help_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmHelpHelp(NULL, NULL); } static void about_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmHelpAbout(NULL, NULL); } static void quit_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphQuit(NULL, NULL); } static void GraphNewFrameAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphNewMenu(NULL, GINT_TO_POINTER(MenuIdGraphNewFrame)); } static void GraphNewSectionAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphNewMenu(NULL, GINT_TO_POINTER(MenuIdGraphNewSection)); } static void GraphNewCrossAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphNewMenu(NULL, GINT_TO_POINTER(MenuIdGraphNewCross)); } static void GraphNewClearAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphNewMenu(NULL, GINT_TO_POINTER(MenuIdGraphAllClear)); } static void GraphLoadAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphLoad(NULL, NULL); } static void GraphRecentAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { show_recent_dialog(RECENT_TYPE_GRAPH); } static void GraphSaveAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphOverWrite(NULL, NULL); } static void GraphSaveAsAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphSave(NULL, NULL); } static void GraphExportGRAAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputGRAFile)); } static void GraphExportPSAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputPSFile)); } static void GraphExportEPSAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputEPSFile)); } static void GraphExportPDFAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputPDFFile)); } static void GraphExportSVGAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputSVGFile)); } static void GraphExportPNGAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputMenu(NULL, GINT_TO_POINTER(MenuIdOutputPNGFile)); } static void GraphDrawOrderAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphSwitch(NULL, NULL); } static void GraphPageSetupAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphPage(NULL, NULL); } static void GraphPrintPreviewAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputViewerB(NULL, NULL); } static void GraphPrintAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOutputPrinterB(NULL, NULL); } static void GraphCurrentDirectoryAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphDirectory(NULL, NULL); } static void GraphShellAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmGraphShell(NULL, NULL); } static void GraphAddinAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int i, n; struct script *fcur; n = g_variant_get_int32(parameter); if (n < 0) { return; } fcur = Menulocal.scriptroot; for (i = 0; i < n; i++) { if (fcur == NULL) { return; } fcur = fcur->next; } script_exec(NULL, fcur); } static void EditRedoAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditRedo)); } static void EditUndoAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditUndo)); } static void EditCutAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditCut)); } static void EditCopyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditCut)); } static void EditPasteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditPaste)); } static void EditDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditDelete)); } static void EditDuplicateAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditDuplicate)); } static void EditOrderTopAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditOrderTop)); } static void EditOrderUpAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditOrderUp)); } static void EditOrderDownAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditOrderDown)); } static void EditOrderBottomAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditOrderBottom));} static void EditAlignLeftAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignLeft)); } static void EditAlignVCenterAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignVCenter)); } static void EditAlignRightAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignRight)); } static void EditAlignTopAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignTop)); } static void EditAlignHCenterAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignHCenter)); } static void EditAlignBottomAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdAlignBottom)); } static void EditRotateCWAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditRotateCW)); } static void EditRotateCCWAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditRotateCCW)); } static void EditFlipHAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditFlipHorizontally)); } static void EditFlipVActiopn_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmEditMenuCB(NULL, GINT_TO_POINTER(MenuIdEditFlipVertically)); } static void ViewDrawDirectAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); } static void ViewDrawAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmViewerDraw(NULL, GINT_TO_POINTER(TRUE)); } static void ViewClearInformationWindowAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { InfoWinClear(); } static void ViewSidebarAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleSidebar, state)) { g_simple_action_set_state(action, parameter); } } static void ViewStatusbarAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleStatusbar, state)){ g_simple_action_set_state(action, parameter); } } static void ViewRulerAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleRuler, state)) { g_simple_action_set_state(action, parameter); } } static void ViewScrollbarAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleScrollbar, state)) { g_simple_action_set_state(action, parameter); } } static void ViewCommandToolbarAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleCToolbar, state)) { g_simple_action_set_state(action, parameter); } } static void ViewToolboxAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdTogglePToolbar, state)) { g_simple_action_set_state(action, parameter); } } static void ViewCrossGaugeAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleCrossGauge, state)) { g_simple_action_set_state(action, parameter); } } static void ViewGridLineAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); if (toggle_view(MenuIdToggleGridLine, state)) { g_simple_action_set_state(action, parameter); } } static void DataAddFileAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileOpen(NULL, NULL); } static void DataAddRangeAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmRangeAdd(NULL, NULL); } static void DataAddRecentFileAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { show_recent_dialog(RECENT_TYPE_DATA); } static void DataPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileUpdate(NULL, NULL); } static void DataCloseAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileClose(NULL, NULL); } static void DataEditAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileEdit(NULL, NULL); } static void DataSaveAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileSaveData(NULL, NULL); } static void DataMathAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmFileMath(NULL, NULL); } static void AxisAddFrameAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisNewFrame(NULL, NULL); } static void AxisAddSectionAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisNewSection(NULL, NULL); } static void AxisAddCrossAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisNewCross(NULL, NULL); } static void AxisAddSingleAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisNewSingle(NULL, NULL); } static void AxisPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisUpdate(NULL, NULL); } static void AxisDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisDel(NULL, NULL); } static void AxisScaleZoomAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisZoom(NULL, NULL); } static void AxisScaleClearAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisClear(NULL, NULL); } static void AxisScaleUndoAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisScaleUndo(NULL, NULL); } static void AxisGridNewAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisGridNew(NULL, NULL); } static void AxisGridPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisGridUpdate(NULL, NULL); } static void AxisGridDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmAxisGridDel(NULL, NULL); } static void LegendPathPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmLineUpdate(NULL, NULL); } static void LegendPathDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmLineDel(NULL, NULL); } static void LegendRectanglePropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmRectUpdate(NULL, NULL); } static void LegendRectangleDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmRectDel(NULL, NULL); } static void LegendArcPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmArcUpdate(NULL, NULL); } static void LegendArcDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmArcDel(NULL, NULL); } static void LegendMarkPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmMarkUpdate(NULL, NULL); } static void LegendMarkDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmMarkDel(NULL, NULL); } static void LegendTextPropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmTextUpdate(NULL, NULL); } static void LegendTextDeleteAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmTextDel(NULL, NULL); } static void MergeAddAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmMergeOpen(NULL, NULL); } static void MergePropertyAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmMergeUpdate(NULL, NULL); } static void MergeCloseAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmMergeClose(NULL, NULL); } static void PreferenceViewerAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionViewer(NULL, NULL); } static void PreferenceExternalViewerAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionExtViewer(NULL, NULL); } static void PreferenceFontAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionPrefFont(NULL, NULL); } static void PreferenceAddinAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionScript(NULL, NULL); } static void PreferenceMiscAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionMisc(NULL, NULL); } static void PreferenceSaveSettingAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionSaveDefault(NULL, NULL); } static void PreferenceSaveGraphAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionSaveNgp(NULL, NULL); } static void PreferenceDataDefaultAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionFileDef(NULL, NULL); } static void PreferenceTextDefaultAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { CmOptionTextDef(NULL, NULL); } static void PopupUpdateAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { ViewerUpdateCB(NULL, NULL); } static GActionEntry AppEntries[] = { { "help", help_activated, NULL, NULL, NULL }, { "about", about_activated, NULL, NULL, NULL }, { "quit", quit_activated, NULL, NULL, NULL }, { "preferences", PreferenceMiscAction_activated, NULL, NULL, NULL }, { "GraphNewFrameAction", GraphNewFrameAction_activated, NULL, NULL, NULL }, { "GraphNewSectionAction", GraphNewSectionAction_activated, NULL, NULL, NULL }, { "GraphNewCrossAction", GraphNewCrossAction_activated, NULL, NULL, NULL }, { "GraphNewClearAction", GraphNewClearAction_activated, NULL, NULL, NULL }, { "GraphRecentAction", GraphRecentAction_activated, NULL, NULL, NULL }, { "GraphLoadAction", GraphLoadAction_activated, NULL, NULL, NULL }, { "GraphSaveAction", GraphSaveAction_activated, NULL, NULL, NULL }, { "GraphSaveAsAction", GraphSaveAsAction_activated, NULL, NULL, NULL }, { "GraphExportGRAAction", GraphExportGRAAction_activated, NULL, NULL, NULL }, { "GraphExportPSAction", GraphExportPSAction_activated, NULL, NULL, NULL }, { "GraphExportEPSAction", GraphExportEPSAction_activated, NULL, NULL, NULL }, { "GraphExportPDFAction", GraphExportPDFAction_activated, NULL, NULL, NULL }, { "GraphExportSVGAction", GraphExportSVGAction_activated, NULL, NULL, NULL }, { "GraphExportPNGAction", GraphExportPNGAction_activated, NULL, NULL, NULL }, { "GraphDrawOrderAction", GraphDrawOrderAction_activated, NULL, NULL, NULL }, { "GraphPageSetupAction", GraphPageSetupAction_activated, NULL, NULL, NULL }, { "GraphPrintPreviewAction", GraphPrintPreviewAction_activated, NULL, NULL, NULL }, { "GraphPrintAction", GraphPrintAction_activated, NULL, NULL, NULL }, { "GraphCurrentDirectoryAction", GraphCurrentDirectoryAction_activated, NULL, NULL, NULL }, { "GraphAddinAction", GraphAddinAction_activated, "i", NULL, NULL }, { "GraphShellAction", GraphShellAction_activated, NULL, NULL, NULL }, { "EditRedoAction", EditRedoAction_activated, NULL, NULL, NULL }, { "EditUndoAction", EditUndoAction_activated, NULL, NULL, NULL }, { "EditCutAction", EditCutAction_activated, NULL, NULL, NULL }, { "EditCopyAction", EditCopyAction_activated, NULL, NULL, NULL }, { "EditPasteAction", EditPasteAction_activated, NULL, NULL, NULL }, { "EditDeleteAction", EditDeleteAction_activated, NULL, NULL, NULL }, { "EditDuplicateAction", EditDuplicateAction_activated, NULL, NULL, NULL }, { "EditOrderTopAction", EditOrderTopAction_activated, NULL, NULL, NULL }, { "EditOrderUpAction", EditOrderUpAction_activated, NULL, NULL, NULL }, { "EditOrderDownAction", EditOrderDownAction_activated, NULL, NULL, NULL }, { "EditOrderBottomAction", EditOrderBottomAction_activated, NULL, NULL, NULL }, { "EditAlignLeftAction", EditAlignLeftAction_activated, NULL, NULL, NULL }, { "EditAlignHCenterAction", EditAlignHCenterAction_activated, NULL, NULL, NULL }, { "EditAlignRightAction", EditAlignRightAction_activated, NULL, NULL, NULL }, { "EditAlignTopAction", EditAlignTopAction_activated, NULL, NULL, NULL }, { "EditAlignVCenterAction", EditAlignVCenterAction_activated, NULL, NULL, NULL }, { "EditAlignBottomAction", EditAlignBottomAction_activated, NULL, NULL, NULL }, { "EditRotateCWAction", EditRotateCWAction_activated, NULL, NULL, NULL }, { "EditRotateCCWAction", EditRotateCCWAction_activated, NULL, NULL, NULL }, { "EditFlipHAction", EditFlipHAction_activated, NULL, NULL, NULL }, { "EditFlipVActiopn", EditFlipVActiopn_activated, NULL, NULL, NULL }, { "ViewDrawDirectAction", ViewDrawDirectAction_activated, NULL, NULL, NULL }, { "ViewDrawAction", ViewDrawAction_activated, NULL, NULL, NULL }, { "ViewClearInformationWindowAction", ViewClearInformationWindowAction_activated, NULL, NULL, NULL }, { "ViewSidebarAction", NULL, NULL, "true", ViewSidebarAction_activated }, { "ViewStatusbarAction", NULL, NULL, "true", ViewStatusbarAction_activated }, { "ViewRulerAction", NULL, NULL, "true", ViewRulerAction_activated }, { "ViewScrollbarAction", NULL, NULL, "true", ViewScrollbarAction_activated }, { "ViewCommandToolbarAction", NULL, NULL, "true", ViewCommandToolbarAction_activated }, { "ViewToolboxAction", NULL, NULL, "true", ViewToolboxAction_activated }, { "ViewCrossGaugeAction", NULL, NULL, "true", ViewCrossGaugeAction_activated }, { "ViewGridLineAction", NULL, NULL, "true", ViewGridLineAction_activated }, { "DataAddFileAction", DataAddFileAction_activated, NULL, NULL, NULL }, { "DataAddRangeAction", DataAddRangeAction_activated, NULL, NULL, NULL }, { "DataAddRecentFileAction", DataAddRecentFileAction_activated, NULL, NULL, NULL }, { "DataPropertyAction", DataPropertyAction_activated, NULL, NULL, NULL }, { "DataCloseAction", DataCloseAction_activated, NULL, NULL, NULL }, { "DataEditAction", DataEditAction_activated, NULL, NULL, NULL }, { "DataSaveAction", DataSaveAction_activated, NULL, NULL, NULL }, { "DataMathAction", DataMathAction_activated, NULL, NULL, NULL }, { "AxisAddFrameAction", AxisAddFrameAction_activated, NULL, NULL, NULL }, { "AxisAddSectionAction", AxisAddSectionAction_activated, NULL, NULL, NULL }, { "AxisAddCrossAction", AxisAddCrossAction_activated, NULL, NULL, NULL }, { "AxisAddSingleAction", AxisAddSingleAction_activated, NULL, NULL, NULL }, { "AxisPropertyAction", AxisPropertyAction_activated, NULL, NULL, NULL }, { "AxisDeleteAction", AxisDeleteAction_activated, NULL, NULL, NULL }, { "AxisScaleZoomAction", AxisScaleZoomAction_activated, NULL, NULL, NULL }, { "AxisScaleClearAction", AxisScaleClearAction_activated, NULL, NULL, NULL }, { "AxisScaleUndoAction", AxisScaleUndoAction_activated, NULL, NULL, NULL }, { "AxisGridNewAction", AxisGridNewAction_activated, NULL, NULL, NULL }, { "AxisGridPropertyAction", AxisGridPropertyAction_activated, NULL, NULL, NULL }, { "AxisGridDeleteAction", AxisGridDeleteAction_activated, NULL, NULL, NULL }, { "LegendPathPropertyAction", LegendPathPropertyAction_activated, NULL, NULL, NULL }, { "LegendPathDeleteAction", LegendPathDeleteAction_activated, NULL, NULL, NULL }, { "LegendRectanglePropertyAction", LegendRectanglePropertyAction_activated, NULL, NULL, NULL }, { "LegendRectangleDeleteAction", LegendRectangleDeleteAction_activated, NULL, NULL, NULL }, { "LegendArcPropertyAction", LegendArcPropertyAction_activated, NULL, NULL, NULL }, { "LegendArcDeleteAction", LegendArcDeleteAction_activated, NULL, NULL, NULL }, { "LegendMarkPropertyAction", LegendMarkPropertyAction_activated, NULL, NULL, NULL }, { "LegendMarkDeleteAction", LegendMarkDeleteAction_activated, NULL, NULL, NULL }, { "LegendTextPropertyAction", LegendTextPropertyAction_activated, NULL, NULL, NULL }, { "LegendTextDeleteAction", LegendTextDeleteAction_activated, NULL, NULL, NULL }, { "MergeAddAction", MergeAddAction_activated, NULL, NULL, NULL }, { "MergePropertyAction", MergePropertyAction_activated, NULL, NULL, NULL }, { "MergeCloseAction", MergeCloseAction_activated, NULL, NULL, NULL }, { "PreferenceViewerAction", PreferenceViewerAction_activated, NULL, NULL, NULL }, { "PreferenceExternalViewerAction", PreferenceExternalViewerAction_activated, NULL, NULL, NULL }, { "PreferenceFontAction", PreferenceFontAction_activated, NULL, NULL, NULL }, { "PreferenceAddinAction", PreferenceAddinAction_activated, NULL, NULL, NULL }, { "PreferenceMiscAction", PreferenceMiscAction_activated, NULL, NULL, NULL }, { "PreferenceSaveSettingAction", PreferenceSaveSettingAction_activated, NULL, NULL, NULL }, { "PreferenceSaveGraphAction", PreferenceSaveGraphAction_activated, NULL, NULL, NULL }, { "PreferenceDataDefaultAction", PreferenceDataDefaultAction_activated, NULL, NULL, NULL }, { "PreferenceTextDefaultAction", PreferenceTextDefaultAction_activated, NULL, NULL, NULL }, { "PopupUpdateAction", PopupUpdateAction_activated, NULL, NULL, NULL }, }; GtkApplication * create_application_window(GtkWidget **popup) { GtkApplication *app; app = gtk_application_new(APPLICATION_ID, G_APPLICATION_NON_UNIQUE); g_application_register(G_APPLICATION(app), NULL, NULL); g_action_map_add_action_entries(G_ACTION_MAP(app), AppEntries, G_N_ELEMENTS(AppEntries), app); #if OSX { /* only for remove "Settings" menu item */ GtkBuilder *builder; GObject *menu; builder = gtk_builder_new_from_resource(RESOURCE_PATH "/gtk/menus-appmenu.ui"); menu = gtk_builder_get_object(builder, "app-menu"); gtk_application_set_app_menu(app, G_MENU_MODEL(menu)); g_object_unref(builder); } #endif #if USE_GTK_BUILDER /* menu = gtk_application_get_menu_by_id(app, "menubar"); gtk_application_set_menubar(app, G_MENU_MODEL(menu)); */ { GMenu *menu; menu = gtk_application_get_menu_by_id(app, "popup-menu"); *popup = gtk_menu_new_from_model(G_MENU_MODEL(menu)); } #endif return app; } #endif /* USE_APP_MENU */ ngraph-gtk-6.08.00/src/gtk/x11gui.h0000644000175000017500000000701413213743342013517 00000000000000/* * $Id: x11gui.h,v 1.15 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef GTK_GUI_HEADER #define GTK_GUI_HEADER #define RESPONS_OK 1 #define RESPONS_YESNOCANCEL 2 #define RESPONS_YESNO 3 #define RESPONS_OKCANCEL 4 #define RESPONS_ERROR 5 #ifdef IDOK #undef IDOK #undef IDCANCEL #undef IDYES #undef IDNO #undef IDCLOSE #endif /* IDOK */ #define IDLOOP 0 #define IDOK 1 #define IDCANCEL 2 #define IDYES 3 #define IDNO 4 #define IDDELETE 101 #define IDFAPPLY 102 #define IDCOPY 103 #define IDLOAD 104 #define IDSAVE 105 #define IDCLOSE 106 #define IDSALL 201 #define IDCOPYALL 202 #define DPI_MAX 2540 #define DEFAULT_DPI 70 typedef struct _tpoint { int x, y; } TPoint; int DialogExecute(GtkWidget *parent, void *dialog); void message_beep(GtkWidget *parent); int markup_message_box(GtkWidget * parent, const char *message, const char *title, int mode, int markup); int message_box(GtkWidget *parent, const char *message, const char *title, int yesno); int DialogInput(GtkWidget *parent, const char *title, const char *mes, const char *init_str, struct narray *buttons, int *res_btn, char **s, int *x, int *y); int DialogRadio(GtkWidget *parent, const char *title, const char *caption, struct narray *ary, struct narray *buttons, int *res_btn, int *r, int *x, int *y); int DialogButton(GtkWidget *parent, const char *title, const char *caption, struct narray *array, int *x, int *y); int DialogCheck(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int *r, int *x, int *y); int DialogCombo(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int sel, char **r, int *x, int *y); int DialogComboEntry(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int sel, char **r, int *x, int *y); int DialogSpinEntry(GtkWidget *parent, const char *title, const char *caption, double min, double max, double inc, struct narray *buttons, int *res_btn, double *r, int *x, int *y); int nGetOpenFileNameMulti(GtkWidget * parent, char *title, char *defext, char **initdir, const char *initfil, char ***file, int chd); int nGetOpenFileName(GtkWidget * parent, char *title, char *defext, char **initdir, const char *initfil, char **file, int exist, int chd); int nGetSaveFileName(GtkWidget * parent, char *title, char *defext, char **initdir, const char *initfil, char **file, int overwrite, int chdir); void get_window_geometry(GtkWidget *win, gint *x, gint *y, gint *w, gint *h); void set_sensitivity_by_check_instance(GtkWidget *widget, gpointer user_data); int ndialog_run(GtkWidget *dlg); #endif ngraph-gtk-6.08.00/src/gtk/x11file.c0000644000175000017500000050521613351432267013660 00000000000000// -*- coding: utf-8 -*- /* * $Id: x11file.c,v 1.136 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include #include "gtk_entry_completion.h" #include "gtk_liststore.h" #include "gtk_subwin.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "shell.h" #include "object.h" #include "ioutil.h" #include "nstring.h" #include "mathfn.h" #include "gra.h" #include "spline.h" #include "nconfig.h" #include "odata.h" #include "ofit.h" #include "math_equation.h" #include "x11bitmp.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "ogra2cairo.h" #include "ogra2gdk.h" #include "ox11menu.h" #include "x11graph.h" #include "x11view.h" #include "x11file.h" #include "x11commn.h" #include "sourcecompletionwords.h" #include "completion_info.h" static n_list_store Flist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {N_("file/range"), G_TYPE_STRING, TRUE, TRUE, "file", 0, 0, 0, 0, PANGO_ELLIPSIZE_END}, {"x ", G_TYPE_INT, TRUE, TRUE, "x", 0, 999, 1, 10}, {"y ", G_TYPE_INT, TRUE, TRUE, "y", 0, 999, 1, 10}, {N_("ax"), G_TYPE_PARAM, TRUE, TRUE, "axis_x"}, {N_("ay"), G_TYPE_PARAM, TRUE, TRUE, "axis_y"}, {N_("type"), G_TYPE_OBJECT, TRUE, TRUE, "type"}, {N_("size"), G_TYPE_DOUBLE, TRUE, TRUE, "mark_size", 0, SPIN_ENTRY_MAX, 100, 1000}, {N_("width"), G_TYPE_DOUBLE, TRUE, TRUE, "line_width", 0, SPIN_ENTRY_MAX, 10, 100}, {N_("skip"), G_TYPE_INT, TRUE, TRUE, "head_skip", 0, INT_MAX, 1, 10}, {N_("step"), G_TYPE_INT, TRUE, TRUE, "read_step", 1, INT_MAX, 1, 10}, {N_("final"), G_TYPE_INT, TRUE, TRUE, "final_line", INT_MIN, INT_MAX, 1, 10}, {N_("num"), G_TYPE_INT, TRUE, FALSE, "data_num"}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, {"masked", G_TYPE_INT, FALSE, FALSE, "masked"}, {"tip", G_TYPE_STRING, FALSE, FALSE, "file"}, {"not_func", G_TYPE_INT, FALSE, FALSE, "source"}, {"is_file", G_TYPE_INT, FALSE, FALSE, "source"}, }; enum { FILE_WIN_COL_HIDDEN, FILE_WIN_COL_ID, FILE_WIN_COL_FILE, FILE_WIN_COL_X, FILE_WIN_COL_Y, FILE_WIN_COL_X_AXIS, FILE_WIN_COL_Y_AXIS, FILE_WIN_COL_TYPE, FILE_WIN_COL_SIZE, FILE_WIN_COL_WIDTH, FILE_WIN_COL_SKIP, FILE_WIN_COL_STEP, FILE_WIN_COL_FINAL, FILE_WIN_COL_DNUM, FILE_WIN_COL_OID, FILE_WIN_COL_MASKED, FILE_WIN_COL_TIP, FILE_WIN_COL_NOT_RANGE, FILE_WIN_COL_IS_FILE, FILE_WIN_COL_NUM, }; static void file_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static void file_delete_popup_func(GtkMenuItem *w, gpointer client_data); static void file_copy2_popup_func(GtkMenuItem *w, gpointer client_data); static void file_copy_popup_func(GtkMenuItem *w, gpointer client_data); static void file_edit_popup_func(GtkMenuItem *w, gpointer client_data); static void file_draw_popup_func(GtkMenuItem *w, gpointer client_data); static void FileDialogType(GtkWidget *w, gpointer client_data); static void create_type_combo_item(GtkTreeStore *list, struct objlist *obj, int id); static gboolean func_entry_focused(GtkWidget *w, GdkEventFocus *event, gpointer user_data); static struct subwin_popup_list add_menu_list[] = { {N_("_File"), G_CALLBACK(CmFileOpen), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Range"), G_CALLBACK(CmRangeAdd), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Recent file"), NULL, NULL, POP_UP_MENU_ITEM_TYPE_RECENT_DATA}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; static struct subwin_popup_list Popup_list[] = { {N_("_Add"), NULL, add_menu_list, POP_UP_MENU_ITEM_TYPE_MENU}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Duplicate"), G_CALLBACK(file_copy_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("duplicate _Behind"), G_CALLBACK(file_copy2_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Delete"), G_CALLBACK(file_delete_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Draw"), G_CALLBACK(file_draw_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Properties"), G_CALLBACK(list_sub_window_update), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Instance name"), G_CALLBACK(list_sub_window_object_name), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Edit"), G_CALLBACK(file_edit_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Top"), G_CALLBACK(list_sub_window_move_top), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Up"), G_CALLBACK(list_sub_window_move_up), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Down"), G_CALLBACK(list_sub_window_move_down), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Bottom"), G_CALLBACK(list_sub_window_move_last), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; #define POPUP_ITEM_NUM (sizeof(Popup_list) / sizeof(*Popup_list) - 1) #define POPUP_ITEM_EDIT 9 #define POPUP_ITEM_TOP 11 #define POPUP_ITEM_UP 12 #define POPUP_ITEM_DOWN 13 #define POPUP_ITEM_BOTTOM 14 #define RANGE_ENTRY_WIDTH 26 #define FITSAVE "fit.ngp" enum MATH_FNC_TYPE { TYPE_MATH_X = 0, TYPE_MATH_Y, TYPE_FUNC_F, TYPE_FUNC_G, TYPE_FUNC_H, }; static char *FieldStr[] = {"math_x", "math_y", "func_f", "func_g", "func_h"}; static void add_completion_provider(GtkSourceView *source_view, GtkSourceCompletionProvider *provider) { GtkSourceCompletion *comp; comp = gtk_source_view_get_completion(source_view); gtk_source_completion_add_provider(comp, provider, NULL); g_object_unref(G_OBJECT(provider)); } static void add_completion_provider_math(GtkSourceView *source_view) { SourceCompletionWords *words; words = source_completion_words_new(_("functions"), completion_info_func_populate); add_completion_provider(source_view, GTK_SOURCE_COMPLETION_PROVIDER(words)); words = source_completion_words_new(_("constants"), completion_info_const_populate); add_completion_provider(source_view, GTK_SOURCE_COMPLETION_PROVIDER(words)); } static GtkWidget * create_source_view(void) { GtkSourceView *source_view; GtkSourceLanguageManager *lm; GtkSourceBuffer *buffer; GtkSourceLanguage *lang; GtkSourceCompletionWords *words; GValue value = G_VALUE_INIT; GtkSourceCompletion *comp; source_view = GTK_SOURCE_VIEW(gtk_source_view_new()); buffer = gtk_source_buffer_new(NULL); gtk_text_view_set_buffer(GTK_TEXT_VIEW(source_view), GTK_TEXT_BUFFER(buffer)); #if GTK_CHECK_VERSION(3, 16, 0) gtk_text_view_set_monospace(GTK_TEXT_VIEW(source_view), TRUE); #endif gtk_source_view_set_tab_width(source_view, 2); gtk_source_view_set_insert_spaces_instead_of_tabs(source_view, TRUE); gtk_source_view_set_smart_home_end(source_view, GTK_SOURCE_SMART_HOME_END_BEFORE); #if GTK_SOURCE_CHECK_VERSION(3, 18, 0) gtk_source_view_set_smart_backspace(source_view, TRUE); #endif gtk_source_view_set_indent_width(source_view, -1); gtk_source_view_set_indent_on_tab(source_view, TRUE); gtk_source_view_set_auto_indent(source_view, TRUE); gtk_source_view_set_show_line_numbers(source_view, TRUE); comp = gtk_source_view_get_completion(source_view); g_value_init(&value, G_TYPE_BOOLEAN); g_value_set_boolean(&value, FALSE); /* fix-me: proposals are not * shown 2nd time in linux if * TRUE */ g_object_set_property(G_OBJECT(comp), "remember-info-visibility", &value); lm = gtk_source_language_manager_get_default(); lang = gtk_source_language_manager_get_language(lm, "ngraph-math"); gtk_source_buffer_set_language(GTK_SOURCE_BUFFER(buffer), lang); gtk_source_buffer_set_highlight_syntax(GTK_SOURCE_BUFFER(buffer), TRUE); add_completion_provider_math(source_view); words = gtk_source_completion_words_new(_("current equations"), NULL); gtk_source_completion_words_register(words, GTK_TEXT_BUFFER(buffer)); add_completion_provider(source_view, GTK_SOURCE_COMPLETION_PROVIDER(words)); return GTK_WIDGET(source_view); } static void set_source_style(GtkWidget *view) { GtkSourceBuffer *buffer; GtkSourceStyleScheme *style; GtkSourceStyleSchemeManager *sman; const char *style_id; if (Menulocal.source_style_id == NULL) { return; } buffer = GTK_SOURCE_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(view))); style = gtk_source_buffer_get_style_scheme(buffer); style_id = gtk_source_style_scheme_get_id(style); if (g_strcmp0(Menulocal.source_style_id, style_id) == 0) { return; } sman = gtk_source_style_scheme_manager_get_default(); style = gtk_source_style_scheme_manager_get_scheme(sman, Menulocal.source_style_id); if (style == NULL) { return; } gtk_source_buffer_set_style_scheme(buffer, style); } static gchar * get_text_from_buffer(GtkTextBuffer *buffer) { GtkTextIter start, end; gtk_text_buffer_get_start_iter(buffer, &start); gtk_text_buffer_get_end_iter(buffer, &end); return gtk_text_buffer_get_text(buffer, &start, &end, FALSE); } static void set_text_to_source_buffer(GtkWidget *view, const char *text) { GtkTextBuffer *buffer; buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(view)); gtk_source_buffer_begin_not_undoable_action(GTK_SOURCE_BUFFER(buffer)); gtk_text_buffer_set_text(buffer, text, -1); gtk_source_buffer_end_not_undoable_action(GTK_SOURCE_BUFFER(buffer)); } static void MathTextDialogChangeInputType(GtkNotebook *notebook, GtkWidget *page, guint page_num, gpointer user_data) { struct MathTextDialog *d; gchar *text; GtkTextBuffer *buffer; d = user_data; d->page = page_num; buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(d->text)); switch (page_num) { case 0: text = get_text_from_buffer(buffer); gtk_entry_set_text(GTK_ENTRY(d->list), text); g_free(text); break; case 1: set_text_to_source_buffer(d->text, gtk_entry_get_text(GTK_ENTRY(d->list))); break; } } static void MathTextDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *title, *vbox, *tab, *swin; struct MathTextDialog *d; static char *label[] = {N_("Math X"), N_("Math Y"), "F(X,Y,Z)", "G(X,Y,Z)", "H(X,Y,Z)"}; d = (struct MathTextDialog *) data; if (makewidget) { tab = gtk_notebook_new(); gtk_notebook_set_tab_pos(GTK_NOTEBOOK(tab), GTK_POS_BOTTOM); d->input_tab = tab; title = gtk_label_new(_("single line")); w = create_text_entry(TRUE, TRUE); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); gtk_notebook_append_page(GTK_NOTEBOOK(tab), vbox, title); d->list = w; title = gtk_label_new(_("multi line")); w = create_source_view(); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), w); gtk_notebook_append_page(GTK_NOTEBOOK(tab), swin, title); d->text = w; g_signal_connect(tab, "switch-page", G_CALLBACK(MathTextDialogChangeInputType), d); gtk_box_pack_start(GTK_BOX(d->vbox), tab, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); gtk_window_set_default_size(GTK_WINDOW(wi), 800, 500); } switch (d->Mode) { case TYPE_MATH_X: entry_completion_set_entry(NgraphApp.x_math_list, d->list); break; case TYPE_MATH_Y: entry_completion_set_entry(NgraphApp.y_math_list, d->list); break; case TYPE_FUNC_F: case TYPE_FUNC_G: case TYPE_FUNC_H: entry_completion_set_entry(NgraphApp.func_list, d->list); break; } set_source_style(d->text); gtk_window_set_title(GTK_WINDOW(wi), _(label[d->Mode])); gtk_entry_set_text(GTK_ENTRY(d->list), d->Text); set_text_to_source_buffer(d->text, d->Text); gtk_notebook_set_current_page(GTK_NOTEBOOK(d->input_tab), Menulocal.math_input_mode); if (Menulocal.math_input_mode) { gtk_widget_grab_focus(d->text); } else { gtk_widget_grab_focus(d->list); } } static void move_cursor_to_error_line(GtkWidget *view) { GtkTextIter iter; GtkTextBuffer *buffer; int ln, ofst; math_err_get_recent_error_position(&ln, &ofst); buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(view)); gtk_text_buffer_get_iter_at_line_offset(buffer, &iter, ln - 1, ofst - 1); gtk_text_buffer_place_cursor(buffer, &iter); } static void MathTextDialogClose(GtkWidget *w, void *data) { struct MathTextDialog *d; const char *p; char *obuf, *ptr; int r, id; GList *id_ptr; d = (struct MathTextDialog *) data; switch (d->ret) { case IDOK: break; case IDCANCEL: return; default: d->ret = IDLOOP; return; } switch (d->page) { case 0: p = gtk_entry_get_text(GTK_ENTRY(d->list)); ptr = g_strdup(p); break; case 1: ptr = get_text_from_buffer(gtk_text_view_get_buffer(GTK_TEXT_VIEW(d->text))); break; default: /* not reached */ return; } if (ptr == NULL) { return; } for (id_ptr = d->id_list; id_ptr; id_ptr = id_ptr->next) { r = list_store_path_get_int(d->tree, id_ptr->data, 0, &id); if (r) { continue; } sgetobjfield(d->Obj, id, FieldStr[d->Mode], NULL, &obuf, FALSE, FALSE, FALSE); if (obuf == NULL || strcmp(obuf, ptr)) { if (sputobjfield(d->Obj, id, FieldStr[d->Mode], ptr)) { g_free(ptr); d->ret = IDLOOP; switch (d->page) { case 0: gtk_widget_grab_focus(d->list); break; case 1: gtk_widget_grab_focus(d->text); move_cursor_to_error_line(d->text); break; } return; } set_graph_modified(); d->modified = TRUE; } g_free(obuf); } switch (d->Mode) { case TYPE_MATH_X: entry_completion_append(NgraphApp.x_math_list, ptr); break; case TYPE_MATH_Y: entry_completion_append(NgraphApp.y_math_list, ptr); break; case TYPE_FUNC_F: case TYPE_FUNC_G: case TYPE_FUNC_H: entry_completion_append(NgraphApp.func_list, ptr); break; } g_free(ptr); Menulocal.math_input_mode = gtk_notebook_get_current_page(GTK_NOTEBOOK(d->input_tab)); } void MathTextDialog(struct MathTextDialog *data, char *text, int mode, struct objlist *obj, GList *list, GtkWidget *tree) { if (mode < 0 || mode >= MATH_FNC_NUM) mode = 0; data->SetupWindow = MathTextDialogSetup; data->CloseWindow = MathTextDialogClose; data->tree = tree; data->Text = text; data->Mode = mode; data->modified = FALSE; data->Obj = obj; data->id_list = list; } static void set_escaped_str(GtkWidget *list, GtkTreeIter *iter, int col, const char *math) { const char *str; char *tmpstr; str = CHK_STR(math); tmpstr = NULL; if (strchr(str, '\n')) { tmpstr = g_strescape(str, "\\"); str = tmpstr; } list_store_set_string(list, iter, col, str); if (tmpstr) { g_free(tmpstr); } } static void MathDialogSetupItem(GtkWidget *w, struct MathDialog *d) { int i; char *math, *field = NULL; GtkTreeIter iter; list_store_clear(d->list); if (d->Mode < 0 || d->Mode >= MATH_FNC_NUM) d->Mode = 0; field = FieldStr[d->Mode]; for (i = 0; i <= chkobjlastinst(d->Obj); i++) { math = NULL; getobj(d->Obj, field, i, 0, NULL, &math); list_store_append(d->list, &iter); list_store_set_int(d->list, &iter, 0, i); set_escaped_str(d->list, &iter, 1, math); } if (d->Mode >= 0 && d->Mode < MATH_FNC_NUM) gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->func[d->Mode]), TRUE); } static void MathDialogMode(GtkWidget *w, gpointer client_data) { struct MathDialog *d; int i; if (! gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w))) return; d = (struct MathDialog *) client_data; for (i = 0; i < MATH_FNC_NUM; i++) { if (w == d->func[i]) d->Mode = i; } MathDialogSetupItem(d->widget, d); } static void MathDialogList(GtkButton *w, gpointer client_data) { struct MathDialog *d; int a, *ary, r; char *field = NULL, *buf; GtkTreeSelection *gsel; GtkTreePath *path; GList *list, *data; d = (struct MathDialog *) client_data; gsel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); list = gtk_tree_selection_get_selected_rows(gsel, NULL); if (list == NULL) return; gtk_tree_view_get_cursor(GTK_TREE_VIEW(d->list), &path, NULL); if (path) { r = list_store_path_get_int(d->list, path, 0, &a); gtk_tree_path_free(path); } else { data = g_list_last(list); r = list_store_path_get_int(d->list, data->data, 0, &a); } if (r) goto END; if (d->Mode < 0 || d->Mode >= MATH_FNC_NUM) d->Mode = 0; field = FieldStr[d->Mode]; sgetobjfield(d->Obj, a, field, NULL, &buf, FALSE, FALSE, FALSE); if (buf == NULL) goto END; MathTextDialog(&DlgMathText, buf, d->Mode, d->Obj, list, d->list); DialogExecute(d->widget, &DlgMathText); d->modified = DlgMathText.modified; g_free(buf); MathDialogSetupItem(d->widget, d); for (data = list; data; data = data->next) { ary = gtk_tree_path_get_indices(data->data); if (ary == NULL) continue; gtk_tree_selection_select_path(gsel, data->data); } END: g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } static gboolean math_dialog_key_pressed_cb(GtkWidget *w, GdkEventKey *e, gpointer user_data) { struct MathDialog *d; GtkTreeSelection *gsel; int n; d = (struct MathDialog *) user_data; if (e->keyval != GDK_KEY_Return) return FALSE; gsel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); n = gtk_tree_selection_count_selected_rows(gsel); if (n < 1) return FALSE; MathDialogList(NULL, d); return TRUE; } static gboolean math_dialog_butten_pressed_cb(GtkWidget *w, GdkEventButton *e, gpointer user_data) { struct MathDialog *d; d = (struct MathDialog *) user_data; if (e->type != GDK_2BUTTON_PRESS) return FALSE; MathDialogList(NULL, d); return TRUE; } static void set_btn_sensitivity_delete_cb(GtkTreeModel *tree_model, GtkTreePath *path, gpointer user_data) { int n; GtkWidget *w; w = GTK_WIDGET(user_data); n = gtk_tree_model_iter_n_children(tree_model, NULL); gtk_widget_set_sensitive(w, n > 0); } static void set_btn_sensitivity_insert_cb(GtkTreeModel *tree_model, GtkTreePath *path, GtkTreeIter *iter, gpointer user_data) { set_btn_sensitivity_delete_cb(tree_model, path, user_data); } static void set_sensitivity_by_row_num(GtkWidget *tree, GtkWidget *btn) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(tree)); g_signal_connect(model, "row-deleted", G_CALLBACK(set_btn_sensitivity_delete_cb), btn); g_signal_connect(model, "row-inserted", G_CALLBACK(set_btn_sensitivity_insert_cb), btn); gtk_widget_set_sensitive(btn, FALSE); } static gboolean set_btn_sensitivity_selection_cb(GtkTreeSelection *sel, gpointer user_data) { int n; GtkWidget *w; w = GTK_WIDGET(user_data); n = gtk_tree_selection_count_selected_rows(sel); gtk_widget_set_sensitive(w, n > 0); return FALSE; } static void set_sensitivity_by_selection(GtkWidget *tree, GtkWidget *btn) { GtkTreeSelection *sel; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(tree)); g_signal_connect(sel, "changed", G_CALLBACK(set_btn_sensitivity_selection_cb), btn); gtk_widget_set_sensitive(btn, FALSE); } static void MathDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *swin, *vbox, *hbox; struct MathDialog *d; static n_list_store list[] = { {"id", G_TYPE_INT, TRUE, FALSE, NULL}, {N_("math"), G_TYPE_STRING, TRUE, FALSE, NULL, 0, 0, 0, 0, PANGO_ELLIPSIZE_END}, }; int i; d = (struct MathDialog *) data; if (makewidget) { char *button_str[] = { N_("_X math"), N_("_Y math"), "_F(X, Y, Z)", "_G(X, Y, Z)", "_H(X, Y, Z)", }; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); w = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_sort_all(w); list_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); g_signal_connect(w, "key-press-event", G_CALLBACK(math_dialog_key_pressed_cb), d); g_signal_connect(w, "button-press-event", G_CALLBACK(math_dialog_butten_pressed_cb), d); d->list = w; swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), w); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), swin); gtk_box_pack_start(GTK_BOX(vbox), w, TRUE, TRUE, 4); w = NULL; for (i = 0; i < MATH_FNC_NUM; i++) { w = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(w), _(button_str[i])); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); d->func[i] = w; g_signal_connect(w, "toggled", G_CALLBACK(MathDialogMode), d); } hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_button_new_with_mnemonic(_("Select _All")); set_button_icon(w, "edit-select-all"); g_signal_connect(w, "clicked", G_CALLBACK(list_store_select_all_cb), d->list); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); set_sensitivity_by_row_num(d->list, w); w = gtk_button_new_with_mnemonic(_("_Edit")); g_signal_connect(w, "clicked", G_CALLBACK(MathDialogList), d); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); set_sensitivity_by_selection(d->list, w); gtk_box_pack_start(GTK_BOX(d->vbox), vbox, TRUE, TRUE, 4); d->show_cancel = FALSE; d->ok_button = _("_Close"); gtk_window_set_default_size(GTK_WINDOW(wi), -1, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); d->Mode = 0; } MathDialogSetupItem(wi, d); } static void MathDialogClose(GtkWidget *w, void *data) { } void MathDialog(struct MathDialog *data, struct objlist *obj) { data->SetupWindow = MathDialogSetup; data->CloseWindow = MathDialogClose; data->Obj = obj; data->modified = FALSE; } static void FitLoadDialogSetup(GtkWidget *wi, void *data, int makewidget) { char *s; struct FitLoadDialog *d; int i; GtkWidget *w; d = (struct FitLoadDialog *) data; if (makewidget) { w = combo_box_create(); d->list = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } combo_box_clear(d->list); for (i = d->Sid; i <= chkobjlastinst(d->Obj); i++) { getobj(d->Obj, "profile", i, 0, NULL, &s); combo_box_append_text(d->list, CHK_STR(s)); } combo_box_set_active(d->list, 0); /* if (makewidget) { XtManageChild(d->widget); d->widget = NULL; XtVaSetValues(d->list, XmNwidth, 200, NULL); } */ } static void FitLoadDialogClose(GtkWidget *w, void *data) { struct FitLoadDialog *d; d = (struct FitLoadDialog *) data; if (d->ret == IDCANCEL) return; d->sel = combo_box_get_active(d->list); } void FitLoadDialog(struct FitLoadDialog *data, struct objlist *obj, int sid) { data->SetupWindow = FitLoadDialogSetup; data->CloseWindow = FitLoadDialogClose; data->Obj = obj; data->Sid = sid; data->sel = -1; } static void FitSaveDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox; struct FitSaveDialog *d; int i; char *s; d = (struct FitSaveDialog *) data; if (makewidget) { gtk_dialog_add_buttons(GTK_DIALOG(wi), _("_Delete"), IDDELETE, NULL); w = combo_box_entry_create(); combo_box_entry_set_width(w, 20); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); item_setup(hbox, w, _("_Profile:"), TRUE); d->profile = w; gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } combo_box_clear(d->profile); for (i = d->Sid; i <= chkobjlastinst(d->Obj); i++) { getobj(d->Obj, "profile", i, 0, NULL, &s); combo_box_append_text(d->profile, CHK_STR(s)); } combo_box_entry_set_text(d->profile, ""); } static void FitSaveDialogClose(GtkWidget *w, void *data) { struct FitSaveDialog *d; const char *s; d = (struct FitSaveDialog *) data; if (d->ret != IDOK && d->ret != IDDELETE) return; s = combo_box_entry_get_text(d->profile); if (s) { char *ptr; ptr = g_strdup(s); g_strstrip(ptr); if (ptr[0] != '\0') { d->Profile = ptr; return; } g_free(ptr); } message_box(d->widget, _("Please specify the profile."), NULL, RESPONS_OK); d->ret = IDLOOP; return; } void FitSaveDialog(struct FitSaveDialog *data, struct objlist *obj, int sid) { data->SetupWindow = FitSaveDialogSetup; data->CloseWindow = FitSaveDialogClose; data->Obj = obj; data->Sid = sid; data->Profile = NULL; } static void FitDialogSetupItem(GtkWidget *w, struct FitDialog *d, int id) { int a, i; SetWidgetFromObjField(d->type, d->Obj, id, "type"); getobj(d->Obj, "poly_dimension", id, 0, NULL, &a); combo_box_set_active(d->dim, a - 1); SetWidgetFromObjField(d->weight, d->Obj, id, "weight_func"); SetWidgetFromObjField(d->through_point, d->Obj, id, "through_point"); SetWidgetFromObjField(d->x, d->Obj, id, "point_x"); SetWidgetFromObjField(d->y, d->Obj, id, "point_y"); SetWidgetFromObjField(d->min, d->Obj, id, "min"); SetWidgetFromObjField(d->max, d->Obj, id, "max"); SetWidgetFromObjField(d->div, d->Obj, id, "div"); SetWidgetFromObjField(d->interpolation, d->Obj, id, "interpolation"); SetWidgetFromObjField(d->converge, d->Obj, id, "converge"); SetWidgetFromObjField(d->derivatives, d->Obj, id, "derivative"); SetWidgetFromObjField(d->formula, d->Obj, id, "user_func"); for (i = 0; i < FIT_PARM_NUM; i++) { char p[] = "parameter0", dd[] = "derivative0"; p[sizeof(p) - 2] += i; dd[sizeof(dd) - 2] += i; SetWidgetFromObjField(d->p[i], d->Obj, id, p); SetWidgetFromObjField(d->d[i], d->Obj, id, dd); } } static char * FitCB(struct objlist *obj, int id) { char *valstr, *profile; getobj(obj, "profile", id, 0, NULL, &profile); valstr = NULL; if (profile == NULL) { char *tmp; sgetobjfield(obj, id, "type", NULL, &tmp, FALSE, FALSE, FALSE); if (tmp) { valstr = g_strdup(_(tmp)); g_free(tmp); } } return valstr; } static void FitDialogCopy(GtkButton *btn, gpointer user_data) { struct FitDialog *d; int sel; d = (struct FitDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FitCB); if (sel != -1) FitDialogSetupItem(d->widget, d, sel); } static int FitDialogLoadConfig(struct FitDialog *d, int errmes) { int lastid; int newid; struct objlist *shell; struct narray sarray; char *argv[2]; char *file; lastid = chkobjlastinst(d->Obj); if (lastid == d->Lastid) { if ((file = searchscript(FITSAVE)) == NULL) { if (errmes) message_box(d->widget, _("Setting file not found."), FITSAVE, RESPONS_OK); return FALSE; } if ((shell = chkobject("shell")) == NULL) return FALSE; newid = newobj(shell); if (newid < 0) { g_free(file); return FALSE; } arrayinit(&sarray, sizeof(char *)); changefilename(file); if (arrayadd(&sarray, &file) == NULL) { g_free(file); arraydel2(&sarray); return FALSE; } argv[0] = (char *) &sarray; argv[1] = NULL; exeobj(shell, "shell", newid, 1, argv); arraydel2(&sarray); delobj(shell, newid); } return TRUE; } static void FitDialogLoad(GtkButton *btn, gpointer user_data) { struct FitDialog *d; int lastid, id; d = (struct FitDialog *) user_data; if (!FitDialogLoadConfig(d, TRUE)) return; lastid = chkobjlastinst(d->Obj); if ((d->Lastid < 0) || (lastid == d->Lastid)) { message_box(d->widget, _("No settings."), FITSAVE, RESPONS_OK); return; } FitLoadDialog(&DlgFitLoad, d->Obj, d->Lastid + 1); if ((DialogExecute(d->widget, &DlgFitLoad) == IDOK) && (DlgFitLoad.sel >= 0)) { id = DlgFitLoad.sel + d->Lastid + 1; FitDialogSetupItem(d->widget, d, id); } } static int copy_settings_to_fitobj(struct FitDialog *d, char *profile) { int i, id, num; char *s; for (i = d->Lastid + 1; i <= chkobjlastinst(d->Obj); i++) { getobj(d->Obj, "profile", i, 0, NULL, &s); if (s && strcmp(s, profile) == 0) { if (message_box(d->widget, _("Overwrite existing profile?"), "Confirm", RESPONS_YESNO) != IDYES) { return 1; } break; } } if (i > chkobjlastinst(d->Obj)) { id = newobj(d->Obj); } else { id = i; } if (putobj(d->Obj, "profile", id, profile) == -1) return 1; if (SetObjFieldFromWidget(d->type, d->Obj, id, "type")) return 1; num = combo_box_get_active(d->dim); num++; if (num > 0 && putobj(d->Obj, "poly_dimension", id, &num) == -1) return 1; if (SetObjFieldFromWidget(d->weight, d->Obj, id, "weight_func")) return 1; if (SetObjFieldFromWidget (d->through_point, d->Obj, id, "through_point")) return 1; if (SetObjFieldFromWidget(d->x, d->Obj, id, "point_x")) return 1; if (SetObjFieldFromWidget(d->y, d->Obj, id, "point_y")) return 1; if (SetObjFieldFromWidget(d->min, d->Obj, id, "min")) return 1; if (SetObjFieldFromWidget(d->max, d->Obj, id, "max")) return 1; if (SetObjFieldFromWidget(d->div, d->Obj, id, "div")) return 1; if (SetObjFieldFromWidget(d->interpolation, d->Obj, id, "interpolation")) return 1; if (SetObjFieldFromWidget(d->formula, d->Obj, id, "user_func")) return 1; if (SetObjFieldFromWidget(d->derivatives, d->Obj, id, "derivative")) return 1; if (SetObjFieldFromWidget(d->converge, d->Obj, id, "converge")) return 1; for (i = 0; i < FIT_PARM_NUM; i++) { char p[] = "parameter0", dd[] = "derivative0"; p[sizeof(p) - 2] += i; dd[sizeof(dd) - 2] += i; if (SetObjFieldFromWidget(d->p[i], d->Obj, id, p)) return 1; if (SetObjFieldFromWidget(d->d[i], d->Obj, id, dd)) return 1; } return 0; } static int delete_fitobj(struct FitDialog *d, char *profile) { int i, r; char *s, *ptr; if (profile == NULL) return 1; for (i = d->Lastid + 1; i <= chkobjlastinst(d->Obj); i++) { getobj(d->Obj, "profile", i, 0, NULL, &s); if (s && strcmp(s, profile) == 0) { ptr = g_strdup_printf(_("Delete the profile '%s'?"), profile); r = message_box(d->widget, ptr, "Confirm", RESPONS_YESNO); g_free(ptr); if (r != IDYES) { return 1; } break; } } if (i > chkobjlastinst(d->Obj)) { ptr = g_strdup_printf(_("The profile '%s' is not exist."), profile); message_box(d->widget, ptr, "Confirm", RESPONS_OK); g_free(ptr); return 1; } delobj(d->Obj, i); return 0; } static void FitDialogSave(GtkWidget *w, gpointer client_data) { int i, r, len; char *s, *ngpfile, *ptr; int error; int hFile; struct FitDialog *d; d = (struct FitDialog *) client_data; if (!FitDialogLoadConfig(d, FALSE)) return; FitSaveDialog(&DlgFitSave, d->Obj, d->Lastid + 1); r = DialogExecute(d->widget, &DlgFitSave); if (r != IDOK && r != IDDELETE) return; if (DlgFitSave.Profile == NULL) return; if (DlgFitSave.Profile[0] == '\0') { g_free(DlgFitSave.Profile); return; } switch (r) { case IDOK: if (copy_settings_to_fitobj(d, DlgFitSave.Profile)) { g_free(DlgFitSave.Profile); return; } break; case IDDELETE: if (delete_fitobj(d, DlgFitSave.Profile)) { g_free(DlgFitSave.Profile); return; } break; } ngpfile = getscriptname(FITSAVE); if (ngpfile == NULL) { return; } error = FALSE; hFile = nopen(ngpfile, O_CREAT | O_TRUNC | O_RDWR, NFMODE_NORMAL_FILE); if (hFile < 0) { error = TRUE; } else { for (i = d->Lastid + 1; i <= chkobjlastinst(d->Obj); i++) { getobj(d->Obj, "save", i, 0, NULL, &s); len = strlen(s); if (len != nwrite(hFile, s, len)) error = TRUE; if (nwrite(hFile, "\n", 1) != 1) error = TRUE; } nclose(hFile); } if (error) { ErrorMessage(); } else { switch (r) { case IDOK: ptr = g_strdup_printf(_("The profile '%s' is saved."), DlgFitSave.Profile); message_box(d->widget, ptr, "Confirm", RESPONS_OK); g_free(ptr); break; case IDDELETE: ptr = g_strdup_printf(_("The profile '%s' is deleted."), DlgFitSave.Profile); message_box(d->widget, ptr, "Confirm", RESPONS_OK); g_free(ptr); g_free(DlgFitSave.Profile); break; } } g_free(ngpfile); } static int check_fit_func(GtkEditable *w, gpointer client_data) { struct FitDialog *d; MathEquation *code; MathEquationParametar *prm; const char *math; int dim, i, n, deriv; d = (struct FitDialog *) client_data; code = math_equation_basic_new(); if (code == NULL) return FALSE; if (math_equation_add_parameter(code, 0, 1, 2, MATH_EQUATION_PARAMETAR_USE_ID)) { math_equation_free(code); return FALSE; } math = gtk_entry_get_text(GTK_ENTRY(d->formula)); if (math_equation_parse(code, math)) { math_equation_free(code); return FALSE; } prm = math_equation_get_parameter(code, 0, NULL); dim = prm->id_num; deriv = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->derivatives)); for (i = 0; i < FIT_PARM_NUM; i++) { set_widget_sensitivity_with_label(d->p[i], FALSE); set_widget_sensitivity_with_label(d->d[i], FALSE); } for (i = 0; i < dim; i++) { n = prm->id[i]; if (n < FIT_PARM_NUM) { set_widget_sensitivity_with_label(d->p[n], TRUE); if (deriv) { set_widget_sensitivity_with_label(d->d[n], TRUE); } } } math_equation_free(code); return TRUE; } static void FitDialogResult(GtkWidget *w, gpointer client_data) { struct FitDialog *d; double derror, correlation, coe[FIT_PARM_NUM]; char *equation, *math; N_VALUE *inst; int i, j, dim, dimension, type, num; GString *buf; d = (struct FitDialog *) client_data; if ((inst = chkobjinst(d->Obj, d->Id)) == NULL) return; if (_getobj(d->Obj, "type", inst, &type)) return; if (_getobj(d->Obj, "poly_dimension", inst, &dimension)) return; if (_getobj(d->Obj, "number", inst, &num)) return; if (_getobj(d->Obj, "error", inst, &derror)) return; if (_getobj(d->Obj, "correlation", inst, &correlation)) return; for (i = 0; i < FIT_PARM_NUM; i++) { char p[] = "%00"; p[sizeof(p) - 2] += i; if (_getobj(d->Obj, p, inst, coe + i)) { return; } } if (_getobj(d->Obj, "equation", inst, &equation)) return; if (_getobj(d->Obj, "user_func", inst, &math)) return; buf = g_string_new(""); if (buf == NULL) { return; } if (equation == NULL) { g_string_append_printf(buf, "Undefined"); } else if (type != FIT_TYPE_USER) { if (type == FIT_TYPE_POLY) { dim = dimension + 1; } else { dim = 2; } switch (type) { case FIT_TYPE_POLY: g_string_append_printf(buf, "Eq: %%0i*Xi (i=0-%d)\n\n", dim - 1); break; case FIT_TYPE_POW: g_string_append_printf(buf, "Eq: exp(%%00)*X%%01\n\n"); break; case FIT_TYPE_EXP: g_string_append_printf(buf, "Eq: exp(%%01*X+%%00)\n\n"); break; case FIT_TYPE_LOG: g_string_append_printf(buf, "Eq: %%01*Ln(X)+%%00\n\n"); break; } for (j = 0; j < dim; j++) { g_string_append_printf(buf, " %%0%d = %+.7e\n", j, coe[j]); } g_string_append_printf(buf, "\n"); g_string_append_printf(buf, " points = %d\n", num); g_string_append_printf(buf, " <DY^2> = %.7e\n", derror); if (correlation >= 0) { g_string_append_printf(buf, "|r| or |R| = %.7e\n", correlation); } else { g_string_append_printf(buf, "|r| or |R| = -------------"); } } else { int tbl[FIT_PARM_NUM]; MathEquation *code; MathEquationParametar *prm; code = math_equation_basic_new(); if (code == NULL) return; if (math_equation_add_parameter(code, 0, 1, 2, MATH_EQUATION_PARAMETAR_USE_ID)) { math_equation_free(code); return; } if (math_equation_parse(code, math)) { math_equation_free(code); return; } prm = math_equation_get_parameter(code, 0, NULL); dim = prm->id_num; for (i = 0; i < dim; i++) { tbl[i] = prm->id[i]; } math_equation_free(code); g_string_append_printf(buf, "Eq: User defined\n\n"); for (j = 0; j < dim; j++) { g_string_append_printf(buf, " %%0%d = %+.7e\n", tbl[j], coe[tbl[j]]); } g_string_append_printf(buf, "\n"); g_string_append_printf(buf, " points = %d\n", num); g_string_append_printf(buf, " <DY^2> = %.7e\n", derror); if (correlation >= 0) { g_string_append_printf(buf, "|r| or |R| = %.7e\n", correlation); } else { g_string_append_printf(buf, "|r| or |R| = -------------"); } } g_string_append(buf, ""); markup_message_box(d->widget, buf->str, _("Fitting Results"), RESPONS_OK, TRUE); g_string_free(buf, TRUE); } static int FitDialogApply(GtkWidget *w, struct FitDialog *d) { int i, num, dim; const gchar *s; if (SetObjFieldFromWidget(d->type, d->Obj, d->Id, "type")) return FALSE; if (getobj(d->Obj, "poly_dimension", d->Id, 0, NULL, &dim) == -1) return FALSE; num = combo_box_get_active(d->dim); num++; if (num > 0 && putobj(d->Obj, "poly_dimension", d->Id, &num) == -1) return FALSE; if (num != dim) set_graph_modified(); if (SetObjFieldFromWidget(d->weight, d->Obj, d->Id, "weight_func")) return FALSE; if (SetObjFieldFromWidget(d->through_point, d->Obj, d->Id, "through_point")) return FALSE; if (SetObjFieldFromWidget(d->x, d->Obj, d->Id, "point_x")) return FALSE; if (SetObjFieldFromWidget(d->y, d->Obj, d->Id, "point_y")) return FALSE; if (SetObjFieldFromWidget(d->min, d->Obj, d->Id, "min")) return FALSE; if (SetObjFieldFromWidget(d->max, d->Obj, d->Id, "max")) return FALSE; if (SetObjFieldFromWidget(d->div, d->Obj, d->Id, "div")) return FALSE; if (SetObjFieldFromWidget(d->interpolation, d->Obj, d->Id, "interpolation")) return FALSE; if (SetObjFieldFromWidget(d->derivatives, d->Obj, d->Id, "derivative")) return FALSE; if (SetObjFieldFromWidget(d->converge, d->Obj, d->Id, "converge")) return FALSE; if (SetObjFieldFromWidget(d->formula, d->Obj, d->Id, "user_func")) return FALSE; s = gtk_entry_get_text(GTK_ENTRY(d->formula)); entry_completion_append(NgraphApp.fit_list, s); for (i = 0; i < FIT_PARM_NUM; i++) { char p[] = "parameter0", dd[] = "derivative0"; p[sizeof(p) - 2] += i; dd[sizeof(dd) - 2] += i; if (SetObjFieldFromWidget(d->p[i], d->Obj, d->Id, p)) return FALSE; if (SetObjFieldFromWidget(d->d[i], d->Obj, d->Id, dd)) return FALSE; s = gtk_entry_get_text(GTK_ENTRY(d->d[i])); entry_completion_append(NgraphApp.fit_list, s); } return TRUE; } static void FitDialogDraw(GtkWidget *w, gpointer client_data) { struct FitDialog *d; d = (struct FitDialog *) client_data; if (!FitDialogApply(d->widget, d)) return; FitDialogSetupItem(d->widget, d, d->Id); Draw(FALSE); } static void set_user_fit_sensitivity(struct FitDialog *d, int active) { int i; for (i = 0; i < FIT_PARM_NUM; i++) { set_widget_sensitivity_with_label(d->d[i], active); } } static void set_fitdialog_sensitivity(struct FitDialog *d, int type, int through) { int i; set_user_fit_sensitivity(d, FALSE); for (i = 0; i < FIT_PARM_NUM; i++) { set_widget_sensitivity_with_label(d->p[i], FALSE); } set_widget_sensitivity_with_label(d->dim, type == FIT_TYPE_POLY); gtk_widget_set_sensitive(d->usr_def_frame, FALSE); gtk_widget_set_sensitive(d->usr_def_prm_tbl, FALSE); gtk_widget_set_sensitive(d->through_box, through); gtk_widget_set_sensitive(d->through_point, TRUE); } static void FitDialogSetSensitivity(GtkWidget *widget, gpointer user_data) { struct FitDialog *d; int type, through, deriv, dim; char buf[1024]; d = (struct FitDialog *) user_data; type = combo_box_get_active(d->type); through = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->through_point)); switch (type) { case FIT_TYPE_POLY: dim = combo_box_get_active(d->dim); if (dim == 0) { gtk_label_set_markup(GTK_LABEL(d->func_label), "Equation: Y=a·X+b"); } else { snprintf(buf, sizeof(buf), "Equation: Y=∑ ai·Xi (i=0-%d)", dim + 1); gtk_label_set_markup(GTK_LABEL(d->func_label), buf); } set_fitdialog_sensitivity(d, type, through); break; case FIT_TYPE_POW: gtk_label_set_markup(GTK_LABEL(d->func_label), "Equation: Y=a·Xb"); set_fitdialog_sensitivity(d, type, through); break; case FIT_TYPE_EXP: gtk_label_set_markup(GTK_LABEL(d->func_label), "Equation: Y=e(a·X+b)"); set_fitdialog_sensitivity(d, type, through); break; case FIT_TYPE_LOG: gtk_label_set_markup(GTK_LABEL(d->func_label), "Equation: Y=a·Ln(X)+b"); set_fitdialog_sensitivity(d, type, through); break; case FIT_TYPE_USER: gtk_label_set_text(GTK_LABEL(d->func_label), ""); deriv = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->derivatives)); set_widget_sensitivity_with_label(d->dim, FALSE); gtk_widget_set_sensitive(d->through_point, FALSE); gtk_widget_set_sensitive(d->through_box, FALSE); gtk_widget_set_sensitive(d->usr_def_frame, TRUE); gtk_widget_set_sensitive(d->usr_def_prm_tbl, TRUE); set_user_fit_sensitivity(d, deriv); check_fit_func(NULL, d); break; } } static GtkWidget * create_user_fit_frame(struct FitDialog *d) { GtkWidget *table, *w, *vbox; int i, j; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); table = gtk_grid_new(); j = 0; w = create_text_entry(FALSE, TRUE); add_widget_to_table_sub(table, w, _("_Formula:"), TRUE, 0, 2, 3, j++); g_signal_connect(w, "focus-in-event", G_CALLBACK(func_entry_focused), NgraphApp.fit_list); g_signal_connect(w, "changed", G_CALLBACK(check_fit_func), d); d->formula = w; w = create_text_entry(TRUE, TRUE); add_widget_to_table_sub(table, w, _("_Converge (%):"), TRUE, 0, 1, 3, j); d->converge = w; w = gtk_check_button_new_with_mnemonic(_("_Derivatives")); add_widget_to_table_sub(table, w, NULL, FALSE, 2, 1, 3, j++); d->derivatives = w; gtk_box_pack_start(GTK_BOX(vbox), table, FALSE, FALSE, 0); table = gtk_grid_new(); for (i = 0; i < FIT_PARM_NUM; i++) { char p[] = "%0_0:", dd[] = "dF/d(%0_0):"; p[sizeof(p) - 3] += i; dd[sizeof(dd) - 4] += i; w = create_text_entry(TRUE, TRUE); add_widget_to_table_sub(table, w, p, TRUE, 0, 1, 4, j); d->p[i] = w; w = create_text_entry(TRUE, TRUE); g_signal_connect(w, "focus-in-event", G_CALLBACK(func_entry_focused), NgraphApp.fit_list); add_widget_to_table_sub(table, w, dd, TRUE, 2, 1, 4, j++); d->d[i] = w; } w = gtk_scrolled_window_new(NULL, NULL); #if GTK_CHECK_VERSION(3, 8, 0) gtk_container_add(GTK_CONTAINER(w), table); #else gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(w), table); #endif gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(w), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(w), GTK_SHADOW_NONE); gtk_widget_set_size_request(GTK_WIDGET(w), -1, 200); gtk_container_set_border_width(GTK_CONTAINER(w), 2); gtk_box_pack_start(GTK_BOX(vbox), w, TRUE, TRUE, 0); d->usr_def_prm_tbl = table; w = gtk_frame_new(_("User definition")); gtk_container_add(GTK_CONTAINER(w), vbox); return w; } static void FitDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *hbox2, *vbox, *frame, *table; struct FitDialog *d; char title[20], **enumlist, mes[10]; int i; d = (struct FitDialog *) data; snprintf(title, sizeof(title), _("Fit %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); table = gtk_grid_new(); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = combo_box_create(); add_widget_to_table_sub(table, w, _("_Type:"), FALSE, 0, 1, 5, 0); d->type = w; enumlist = (char **) chkobjarglist(d->Obj, "type"); for (i = 0; enumlist[i] && enumlist[i][0]; i++) { combo_box_append_text(d->type, _(enumlist[i])); } hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = combo_box_create(); add_widget_to_table_sub(table, w, _("_Dim:"), FALSE, 2, 1, 5, 0); d->dim = w; for (i = 0; i < FIT_PARM_NUM - 1; i++) { snprintf(mes, sizeof(mes), "%d", i + 1); combo_box_append_text(d->dim, mes); } w = gtk_label_new(""); add_widget_to_table_sub(table, w, NULL, TRUE, 4, 1, 5, 0); gtk_widget_set_halign(w, GTK_ALIGN_START); gtk_widget_set_valign(w, GTK_ALIGN_END); d->func_label = w; hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_text_entry(TRUE, TRUE); add_widget_to_table_sub(table, w, _("_Weight:"), TRUE, 0, 4, 5, 1); d->weight = w; gtk_box_pack_start(GTK_BOX(vbox), table, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_check_button_new_with_mnemonic(_("_Through")); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); d->through_point = w; hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_text_entry(TRUE, TRUE); item_setup(hbox2, w, "_X:", TRUE); d->x = w; w = create_text_entry(TRUE, TRUE); item_setup(hbox2, w, "_Y:", TRUE); d->y = w; d->through_box = hbox2; gtk_box_pack_start(GTK_BOX(hbox), hbox2, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); frame = gtk_frame_new(_("Action")); gtk_container_add(GTK_CONTAINER(frame), vbox); gtk_box_pack_start(GTK_BOX(d->vbox), frame, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_text_entry(TRUE, TRUE); item_setup(hbox, w, _("_Min:"), TRUE); d->min = w; w = create_text_entry(TRUE, TRUE); item_setup(hbox, w, _("_Max:"), TRUE); d->max = w; w = create_spin_entry(1, 65535, 1, TRUE, TRUE); item_setup(hbox, w, _("_Div:"), FALSE); d->div = w; w = gtk_check_button_new_with_mnemonic(_("_Interpolation")); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); d->interpolation = w; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); frame = gtk_frame_new(_("Draw X range")); gtk_container_add(GTK_CONTAINER(frame), vbox); gtk_box_pack_start(GTK_BOX(d->vbox), frame, FALSE, FALSE, 4); frame = create_user_fit_frame(d); d->usr_def_frame = frame; gtk_box_pack_start(GTK_BOX(d->vbox), frame, TRUE, TRUE, 4); hbox = add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(FitDialogCopy), d, "fit"); w = gtk_button_new_with_mnemonic(_("_Load")); g_signal_connect(w, "clicked", G_CALLBACK(FitDialogLoad), d); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Save")); set_button_icon(w, "document-save"); g_signal_connect(w, "clicked", G_CALLBACK(FitDialogSave), d); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Draw")); gtk_box_pack_end(GTK_BOX(hbox), w, FALSE, FALSE, 4); g_signal_connect(w, "clicked", G_CALLBACK(FitDialogDraw), d); w = gtk_button_new_with_mnemonic(_("_Result")); gtk_box_pack_end(GTK_BOX(hbox), w, FALSE, FALSE, 4); g_signal_connect(w, "clicked", G_CALLBACK(FitDialogResult), d); g_signal_connect(d->dim, "changed", G_CALLBACK(FitDialogSetSensitivity), d); g_signal_connect(d->type, "changed", G_CALLBACK(FitDialogSetSensitivity), d); g_signal_connect(d->through_point, "toggled", G_CALLBACK(FitDialogSetSensitivity), d); g_signal_connect(d->derivatives, "toggled", G_CALLBACK(FitDialogSetSensitivity), d); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } FitDialogSetupItem(wi, d, d->Id); } static void FitDialogClose(GtkWidget *w, void *data) { struct FitDialog *d; int ret; int i, lastid; d = (struct FitDialog *) data; switch (d->ret) { case IDOK: break; case IDDELETE: break; case IDCANCEL: break; default: d->ret = IDLOOP; return; } ret = d->ret; d->ret = IDLOOP; if (ret == IDOK && ! FitDialogApply(w, d)) { return; } d->ret = ret; lastid = chkobjlastinst(d->Obj); for (i = lastid; i > d->Lastid; i--) { delobj(d->Obj, i); } } void FitDialog(struct FitDialog *data, struct objlist *obj, int id) { data->SetupWindow = FitDialogSetup; data->CloseWindow = FitDialogClose; data->Obj = obj; data->Id = id; data->Lastid = chkobjlastinst(obj); } static void move_tab_setup_item(struct FileDialog *d, int id) { unsigned int j, movenum; int line; double x, y; struct narray *move, *movex, *movey; GtkTreeIter iter; char buf[64]; list_store_clear(d->move.list); exeobj(d->Obj, "move_data_adjust", id, 0, NULL); getobj(d->Obj, "move_data", id, 0, NULL, &move); getobj(d->Obj, "move_data_x", id, 0, NULL, &movex); getobj(d->Obj, "move_data_y", id, 0, NULL, &movey); movenum = arraynum(move); if (arraynum(movex) < movenum) { movenum = arraynum(movex); } if (arraynum(movey) < movenum) { movenum = arraynum(movey); } if (movenum > 0) { for (j = 0; j < movenum; j++) { line = arraynget_int(move, j); x = arraynget_double(movex, j); y = arraynget_double(movey, j); list_store_append(d->move.list, &iter); list_store_set_int(d->move.list, &iter, 0, line); snprintf(buf, sizeof(buf), "%+.15e", x); list_store_set_string(d->move.list, &iter, 1, buf); snprintf(buf, sizeof(buf), "%+.15e", y); list_store_set_string(d->move.list, &iter, 2, buf); } } } static void FileMoveDialogAdd(GtkWidget *w, gpointer client_data) { struct FileDialog *d; int a; double x, y; const char *buf; char *endptr, buf2[64]; GtkTreeIter iter; d = (struct FileDialog *) client_data; a = spin_entry_get_val(d->move.line); buf = gtk_entry_get_text(GTK_ENTRY(d->move.x)); if (buf[0] == '\0') return; x = strtod(buf, &endptr); if (x != x || x == HUGE_VAL || x == - HUGE_VAL || endptr[0] != '\0') return; buf = gtk_entry_get_text(GTK_ENTRY(d->move.y)); if (buf[0] == '\0') return; y = strtod(buf, &endptr); if (y != y || y == HUGE_VAL || y == - HUGE_VAL || endptr[0] != '\0') return; list_store_append(d->move.list, &iter); list_store_set_int(d->move.list, &iter, 0, a); snprintf(buf2, sizeof(buf2), "%+.15e", x); list_store_set_string(d->move.list, &iter, 1, buf2); snprintf(buf2, sizeof(buf2), "%+.15e", y); list_store_set_string(d->move.list, &iter, 2, buf2); gtk_entry_set_text(GTK_ENTRY(d->move.x), ""); gtk_entry_set_text(GTK_ENTRY(d->move.y), ""); d->move.changed = TRUE; } static gboolean move_dialog_key_pressed(GtkWidget *w, GdkEventKey *e, gpointer user_data) { struct FileDialog *d; d = (struct FileDialog *) user_data; if (e->keyval != GDK_KEY_Return) return FALSE; FileMoveDialogAdd(NULL, d); return TRUE; } static void FileMoveDialogRemove(GtkWidget *w, gpointer client_data) { struct FileDialog *d; d = (struct FileDialog *) client_data; list_store_remove_selected_cb(w, d->move.list); d->move.changed = TRUE; } static void move_tab_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { move_tab_setup_item(d, sel); d->move.changed = TRUE; } } static GtkWidget * move_tab_create(struct FileDialog *d) { GtkWidget *w, *hbox, *swin, *table, *vbox; n_list_store list[] = { {N_("Line No."), G_TYPE_INT, TRUE, FALSE, NULL}, {"X", G_TYPE_STRING, TRUE, FALSE, NULL}, {"Y", G_TYPE_STRING, TRUE, FALSE, NULL}, }; int i; swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(swin), GTK_SHADOW_ETCHED_IN); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); w = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_sort_column(w, 0); list_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); d->move.list = w; gtk_container_add(GTK_CONTAINER(swin), w); set_widget_margin(swin, WIDGET_MARGIN_TOP | WIDGET_MARGIN_BOTTOM); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_NATURAL, TRUE, FALSE); g_signal_connect(w, "key-press-event", G_CALLBACK(move_dialog_key_pressed), d); add_widget_to_table(table, w, _("_Line:"), FALSE, i++); d->move.line = w; w = create_text_entry(TRUE, FALSE); g_signal_connect(w, "key-press-event", G_CALLBACK(move_dialog_key_pressed), d); add_widget_to_table(table, w, "_X:", FALSE, i++); d->move.x = w; w = create_text_entry(TRUE, FALSE); g_signal_connect(w, "key-press-event", G_CALLBACK(move_dialog_key_pressed), d); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->move.y = w; w = gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(w, "list-add"); add_widget_to_table(table, w, "", FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(FileMoveDialogAdd), d); w = gtk_button_new_with_mnemonic(_("_Remove")); set_button_icon(w, "list-remove"); add_widget_to_table(table, w, NULL, FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(FileMoveDialogRemove), d); set_sensitivity_by_selection(d->move.list, w); w = gtk_button_new_with_mnemonic(_("Select _All")); set_button_icon(w, "edit-select-all"); add_widget_to_table(table, w, NULL, FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(list_store_select_all_cb), d->move.list); set_sensitivity_by_row_num(d->move.list, w); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(hbox), table, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), swin, TRUE, TRUE, 4); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), hbox); set_widget_margin(w, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), w, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(move_tab_copy), d, "data"); return vbox; } static int move_tab_set_value(struct FileDialog *d) { unsigned int j, movenum; int line, a; double x, y; struct narray *move, *movex, *movey; GtkTreeIter iter; gboolean state; char *ptr, *endptr; if (d->move.changed == FALSE) { return 0; } set_graph_modified(); exeobj(d->Obj, "move_data_adjust", d->Id, 0, NULL); getobj(d->Obj, "move_data", d->Id, 0, NULL, &move); getobj(d->Obj, "move_data_x", d->Id, 0, NULL, &movex); getobj(d->Obj, "move_data_y", d->Id, 0, NULL, &movey); if (move) { putobj(d->Obj, "move_data", d->Id, NULL); move = NULL; } if (movex) { putobj(d->Obj, "move_data_x", d->Id, NULL); movex = NULL; } if (movey) { putobj(d->Obj, "move_data_y", d->Id, NULL); movey = NULL; } state = list_store_get_iter_first(d->move.list, &iter); while (state) { a = list_store_get_int(d->move.list, &iter, 0); ptr = list_store_get_string(d->move.list, &iter, 1); x = strtod(ptr, &endptr); g_free(ptr); ptr = list_store_get_string(d->move.list, &iter, 2); y = strtod(ptr, &endptr); g_free(ptr); if (move == NULL) move = arraynew(sizeof(int)); if (movex == NULL) movex = arraynew(sizeof(double)); if (movey == NULL) movey = arraynew(sizeof(double)); movenum = arraynum(move); if (arraynum(movex) < movenum) movenum = arraynum(movex); if (arraynum(movey) < movenum) movenum = arraynum(movey); for (j = 0; j < movenum; j++) { line = arraynget_int(move, j); if (line == a) break; } if (j == movenum) { arrayadd(move, &a); arrayadd(movex, &x); arrayadd(movey, &y); } state = list_store_iter_next(d->move.list, &iter); } putobj(d->Obj, "move_data", d->Id, move); putobj(d->Obj, "move_data_x", d->Id, movex); putobj(d->Obj, "move_data_y", d->Id, movey); return 0; } static void mask_tab_setup_item(struct FileDialog *d, int id) { int line, j, masknum; struct narray *mask; GtkTreeIter iter; list_store_clear(d->mask.list); getobj(d->Obj, "mask", id, 0, NULL, &mask); if ((masknum = arraynum(mask)) > 0) { for (j = 0; j < masknum; j++) { line = arraynget_int(mask, j); list_store_append(d->mask.list, &iter); list_store_set_int(d->mask.list, &iter, 0, line); } } } static void FileMaskDialogAdd(GtkWidget *w, gpointer client_data) { struct FileDialog *d; int a; GtkTreeIter iter; d = (struct FileDialog *) client_data; a = spin_entry_get_val(d->mask.line); list_store_append(d->mask.list, &iter); list_store_set_int(d->mask.list, &iter, 0, a); d->mask.changed = TRUE; } static gboolean mask_dialog_key_pressed(GtkWidget *w, GdkEventKey *e, gpointer user_data) { struct FileDialog *d; d = (struct FileDialog *) user_data; if (e->keyval != GDK_KEY_Return) return FALSE; FileMaskDialogAdd(NULL, d); return TRUE; } static void mask_tab_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { mask_tab_setup_item(d, sel); d->mask.changed = TRUE; } } static void FileMaskDialogRemove(GtkWidget *w, gpointer client_data) { struct FileDialog *d; d = (struct FileDialog *) client_data; list_store_remove_selected_cb(w, d->mask.list); d->mask.changed = TRUE; } static GtkWidget * mask_tab_create(struct FileDialog *d) { GtkWidget *w, *swin, *hbox, *table, *vbox, *frame; n_list_store list[] = { {_("Line No."), G_TYPE_INT, TRUE, FALSE, NULL}, }; int i; table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_NATURAL, TRUE, FALSE); g_signal_connect(w, "key-press-event", G_CALLBACK(mask_dialog_key_pressed), d); add_widget_to_table(table, w, _("_Line:"), FALSE, i++); d->mask.line = w; swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(swin), GTK_SHADOW_ETCHED_IN); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); w = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_sort_column(w, 0); list_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); d->mask.list = w; gtk_container_add(GTK_CONTAINER(swin), w); set_widget_margin(swin, WIDGET_MARGIN_TOP | WIDGET_MARGIN_BOTTOM); w = gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(w, "list-add"); add_widget_to_table(table, w, "", FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(FileMaskDialogAdd), d); w = gtk_button_new_with_mnemonic(_("_Remove")); set_button_icon(w, "list-remove"); add_widget_to_table(table, w, NULL, FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(FileMaskDialogRemove), d); set_sensitivity_by_selection(d->mask.list, w); w = gtk_button_new_with_mnemonic(_("Select _All")); set_button_icon(w, "edit-select-all"); add_widget_to_table(table, w, NULL, FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(list_store_select_all_cb), d->mask.list); set_sensitivity_by_row_num(d->mask.list, w); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(hbox), table, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), swin, TRUE, TRUE, 4); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), hbox); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(mask_tab_copy), d, "data"); return vbox; } static int mask_tab_set_value(struct FileDialog *d) { int a; struct narray *mask; GtkTreeIter iter; gboolean state; if (d->mask.changed == FALSE) { return 0; } getobj(d->Obj, "mask", d->Id, 0, NULL, &mask); if (mask) { putobj(d->Obj, "mask", d->Id, NULL); mask = NULL; } state = list_store_get_iter_first(d->mask.list, &iter); while (state) { a = list_store_get_int(d->mask.list, &iter, 0); if (mask == NULL) mask = arraynew(sizeof(int)); arrayadd(mask, &a); state = list_store_iter_next(d->mask.list, &iter); } putobj(d->Obj, "mask", d->Id, mask); set_graph_modified(); return 0; } static void load_tab_setup_item(struct FileDialog *d, int id) { char *ifs, *s; unsigned int i, j, l; SetWidgetFromObjField(d->load.headskip, d->Obj, id, "head_skip"); SetWidgetFromObjField(d->load.readstep, d->Obj, id, "read_step"); SetWidgetFromObjField(d->load.finalline, d->Obj, id, "final_line"); if (d->source != DATA_SOURCE_FILE) { return; } SetWidgetFromObjField(d->load.remark, d->Obj, id, "remark"); SetWidgetFromObjField(d->load.csv, d->Obj, id, "csv"); sgetobjfield(d->Obj, id, "ifs", NULL, &ifs, FALSE, FALSE, FALSE); if (ifs == NULL) { return; } l = strlen(ifs); s = g_malloc(l * 2 + 1); if (s == NULL) { g_free(ifs); return; } j = 0; for (i = 0; i < l; i++) { if (ifs[i] == '\t') { s[j++] = '\\'; s[j++] = 't'; } else if (ifs[i] == '\\') { s[j++] = '\\'; s[j++] = '\\'; } else { s[j++] = ifs[i]; } } s[j] = '\0'; gtk_entry_set_text(GTK_ENTRY(d->load.ifs), s); g_free(s); g_free(ifs); } static void load_tab_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { load_tab_setup_item(d, sel); } } static GtkWidget * load_tab_create(struct FileDialog *d) { GtkWidget *w, *table, *frame, *vbox; int i; table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Head skip:"), FALSE, i++); d->load.headskip = w; w = create_spin_entry(1, INT_MAX, 1, TRUE, TRUE); add_widget_to_table(table, w, _("_Read step:"), FALSE, i++); d->load.readstep = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_INT, TRUE, TRUE); add_widget_to_table(table, w, _("_Final line:"), FALSE, i++); d->load.finalline = w; if (d->source == DATA_SOURCE_FILE) { w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_Remark:"), TRUE, i++); d->load.remark = w; w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_IFS:"), TRUE, i++); d->load.ifs = w; w = gtk_check_button_new_with_mnemonic(_("_CSV")); add_widget_to_table(table, w, NULL, TRUE, i++); d->load.csv = w; } frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(load_tab_copy), d, "data"); return vbox; } static void decode_ifs_text(GString *s, const char *ifs) { int i, l; l = strlen(ifs); for (i = 0; i < l; i++) { if ((ifs[i] == '\\') && (ifs[i + 1] == 't')) { g_string_append_c(s, 0x09); i++; } else if (ifs[i] == '\\') { g_string_append_c(s, '\\'); i++; } else if (isascii(ifs[i])) { g_string_append_c(s, ifs[i]); } } } static int load_tab_set_value(struct FileDialog *d) { const char *ifs; char *obuf; GString *s; if (SetObjFieldFromWidget(d->load.headskip, d->Obj, d->Id, "head_skip")) return 1; if (SetObjFieldFromWidget(d->load.readstep, d->Obj, d->Id, "read_step")) return 1; if (SetObjFieldFromWidget(d->load.finalline, d->Obj, d->Id, "final_line")) return 1; if (d->source != DATA_SOURCE_FILE) { return 0; } if (SetObjFieldFromWidget(d->load.remark, d->Obj, d->Id, "remark")) return 1; ifs = gtk_entry_get_text(GTK_ENTRY(d->load.ifs)); s = g_string_new(""); decode_ifs_text(s, ifs); sgetobjfield(d->Obj, d->Id, "ifs", NULL, &obuf, FALSE, FALSE, FALSE); if (obuf == NULL || strcmp(s->str, obuf)) { if (sputobjfield(d->Obj, d->Id, "ifs", s->str) != 0) { g_free(obuf); g_string_free(s, TRUE); return 1; } set_graph_modified(); } g_free(obuf); g_string_free(s, TRUE); if (SetObjFieldFromWidget(d->load.csv, d->Obj, d->Id, "csv")) return 1; return 0; } static void copy_text_to_entry(GtkWidget *text, GtkWidget *entry) { GtkTextBuffer *buffer; gchar *str; buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(text)); str = get_text_from_buffer(buffer); gtk_entry_set_text(GTK_ENTRY(entry), str); g_free(str); } static void copy_entry_to_text(GtkWidget *text, GtkWidget *entry) { const gchar *str; str = gtk_entry_get_text(GTK_ENTRY(entry)); set_text_to_source_buffer(text, str); } static void copy_text_to_entry_all(struct FileDialog *d) { copy_text_to_entry(d->math.text_x, d->math.x); copy_text_to_entry(d->math.text_y, d->math.y); copy_text_to_entry(d->math.text_f, d->math.f); copy_text_to_entry(d->math.text_g, d->math.g); copy_text_to_entry(d->math.text_h, d->math.h); } static void copy_entry_to_text_all(struct FileDialog *d) { copy_entry_to_text(d->math.text_x, d->math.x); copy_entry_to_text(d->math.text_y, d->math.y); copy_entry_to_text(d->math.text_f, d->math.f); copy_entry_to_text(d->math.text_g, d->math.g); copy_entry_to_text(d->math.text_h, d->math.h); } static void math_tab_setup_item(struct FileDialog *d, int id) { SetWidgetFromObjField(d->math.xsmooth, d->Obj, id, "smooth_x"); SetWidgetFromObjField(d->math.ysmooth, d->Obj, id, "smooth_y"); SetWidgetFromObjField(d->math.averaging_type, d->Obj, id, "averaging_type"); SetWidgetFromObjField(d->math.x, d->Obj, id, "math_x"); SetWidgetFromObjField(d->math.y, d->Obj, id, "math_y"); SetWidgetFromObjField(d->math.f, d->Obj, id, "func_f"); SetWidgetFromObjField(d->math.g, d->Obj, id, "func_g"); SetWidgetFromObjField(d->math.h, d->Obj, id, "func_h"); copy_entry_to_text_all(d); entry_completion_set_entry(NgraphApp.x_math_list, d->math.x); entry_completion_set_entry(NgraphApp.y_math_list, d->math.y); set_source_style(d->math.text_x); set_source_style(d->math.text_y); set_source_style(d->math.text_f); set_source_style(d->math.text_g); set_source_style(d->math.text_h); } static void math_tab_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { math_tab_setup_item(d, sel); } } static gboolean func_entry_focused(GtkWidget *w, GdkEventFocus *event, gpointer user_data) { GtkEntryCompletion *compl; compl = GTK_ENTRY_COMPLETION(user_data); entry_completion_set_entry(compl, w); return FALSE; } static GtkWidget * create_math_text_tab(GtkWidget *tab, const gchar *label) { GtkWidget *w, *title, *swin; w = create_source_view(); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), w); title = gtk_label_new_with_mnemonic(label); gtk_notebook_append_page(GTK_NOTEBOOK(tab), swin, title); return w; } static void MathDialogChangeInputType(GtkNotebook *notebook, GtkWidget *page, guint page_num, gpointer user_data) { struct FileDialog *d; d = user_data; d->math_page = page_num; switch (page_num) { case 0: copy_text_to_entry_all(d); break; case 1: copy_entry_to_text_all(d); break; } } static GtkWidget * math_text_widgets_create(struct FileDialog *d) { GtkWidget *tab; tab = gtk_notebook_new(); d->math_tab = GTK_NOTEBOOK(tab); gtk_notebook_set_tab_pos(GTK_NOTEBOOK(tab), GTK_POS_LEFT); d->math.text_x = create_math_text_tab(tab, _("_X math:")); d->math.text_y = create_math_text_tab(tab, _("_Y math:")); d->math.text_f = create_math_text_tab(tab, "_F(X,Y,Z):"); d->math.text_g = create_math_text_tab(tab, "_G(X,Y,Z):"); d->math.text_h = create_math_text_tab(tab, "_H(X,Y,Z):"); return tab; } static int math_common_widgets_create(struct FileDialog *d, GtkWidget *grid, int pos) { GtkWidget *w, *tab, *title, *table; int i; tab = gtk_notebook_new(); gtk_notebook_set_tab_pos(GTK_NOTEBOOK(tab), GTK_POS_BOTTOM); gtk_widget_set_vexpand(tab, TRUE); d->math_input_tab = tab; table = gtk_grid_new(); i = 0; w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_X math:"), TRUE, i++); d->math.x = w; w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_Y math:"), TRUE, i++); d->math.y = w; w = create_text_entry(TRUE, TRUE); g_signal_connect(w, "focus-in-event", G_CALLBACK(func_entry_focused), NgraphApp.func_list); add_widget_to_table(table, w, "_F(X,Y,Z):", TRUE, i++); d->math.f = w; w = create_text_entry(TRUE, TRUE); g_signal_connect(w, "focus-in-event", G_CALLBACK(func_entry_focused), NgraphApp.func_list); add_widget_to_table(table, w, "_G(X,Y,Z):", TRUE, i++); d->math.g = w; w = create_text_entry(TRUE, TRUE); g_signal_connect(w, "focus-in-event", G_CALLBACK(func_entry_focused), NgraphApp.func_list); add_widget_to_table(table, w, "_H(X,Y,Z):", TRUE, i++); d->math.h = w; title = gtk_label_new(_("single line")); gtk_notebook_append_page(GTK_NOTEBOOK(tab), table, title); title = gtk_label_new(_("multi line")); w = math_text_widgets_create(d); gtk_notebook_append_page(GTK_NOTEBOOK(tab), w, title); g_signal_connect(tab, "switch-page", G_CALLBACK(MathDialogChangeInputType), d); add_widget_to_table_sub(grid, tab, NULL, TRUE, 0, 4, 2, pos++); return pos; } static GtkWidget * math_tab_create(struct FileDialog *d) { GtkWidget *table, *w, *vbox, *frame; int i; table = gtk_grid_new(); i = 0; w = create_spin_entry(0, FILE_OBJ_SMOOTH_MAX, 1, FALSE, TRUE); gtk_widget_set_halign (w, GTK_ALIGN_START); add_widget_to_table(table, w, _("_X smooth:"), FALSE, i); d->math.xsmooth = w; w = combo_box_create(); gtk_widget_set_hexpand(w, TRUE); add_widget_to_table_sub(table, w, _("_Averaging type:"), FALSE, 2, 1, 2, i++); d->math.averaging_type = w; w = create_spin_entry(0, FILE_OBJ_SMOOTH_MAX, 1, FALSE, TRUE); gtk_widget_set_halign (w, GTK_ALIGN_START); add_widget_to_table(table, w, _("_Y smooth:"), FALSE, i++); d->math.ysmooth = w; math_common_widgets_create(d, table, i); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(math_tab_copy), d, "data"); return vbox; } enum MATH_ERROR_FIELD { MATH_ERROR_FIELD_NONE, MATH_ERROR_FIELD_X, MATH_ERROR_FIELD_Y, MATH_ERROR_FIELD_F, MATH_ERROR_FIELD_G, MATH_ERROR_FIELD_H, MATH_ERROR_FIELD_SX, MATH_ERROR_FIELD_SY, }; static int math_set_value_common(struct FileDialog *d) { const char *s; if (d->math_page == 1) { copy_text_to_entry_all(d); } if (SetObjFieldFromWidget(d->math.x, d->Obj, d->Id, "math_x")) return MATH_ERROR_FIELD_X; if (SetObjFieldFromWidget(d->math.y, d->Obj, d->Id, "math_y")) return MATH_ERROR_FIELD_Y; if (SetObjFieldFromWidget(d->math.f, d->Obj, d->Id, "func_f")) return MATH_ERROR_FIELD_F; if (SetObjFieldFromWidget(d->math.g, d->Obj, d->Id, "func_g")) return MATH_ERROR_FIELD_G; if (SetObjFieldFromWidget(d->math.h, d->Obj, d->Id, "func_h")) return MATH_ERROR_FIELD_H; s = gtk_entry_get_text(GTK_ENTRY(d->math.y)); entry_completion_append(NgraphApp.y_math_list, s); s = gtk_entry_get_text(GTK_ENTRY(d->math.x)); entry_completion_append(NgraphApp.x_math_list, s); s = gtk_entry_get_text(GTK_ENTRY(d->math.f)); entry_completion_append(NgraphApp.func_list, s); s = gtk_entry_get_text(GTK_ENTRY(d->math.g)); entry_completion_append(NgraphApp.func_list, s); s = gtk_entry_get_text(GTK_ENTRY(d->math.h)); entry_completion_append(NgraphApp.func_list, s); return MATH_ERROR_FIELD_NONE; } static int math_tab_set_value(void *data) { struct FileDialog *d; d = (struct FileDialog *) data; if (SetObjFieldFromWidget(d->math.xsmooth, d->Obj, d->Id, "smooth_x")) return MATH_ERROR_FIELD_SX; if (SetObjFieldFromWidget(d->math.ysmooth, d->Obj, d->Id, "smooth_y")) return MATH_ERROR_FIELD_SY; if (SetObjFieldFromWidget(d->math.averaging_type, d->Obj, d->Id, "averaging_type")) return MATH_ERROR_FIELD_SX; return math_set_value_common(d); } static void MarkDialogCB(GtkWidget *w, gpointer client_data) { int i; struct MarkDialog *d; d = (struct MarkDialog *) client_data; if (! d->cb_respond) return; for (i = 0; i < MARK_TYPE_NUM; i++) { if (w == d->toggle[i]) break; } d->Type = i; d->ret = IDOK; gtk_dialog_response(GTK_DIALOG(d->widget), GTK_RESPONSE_OK); } void button_set_mark_image(GtkWidget *w, int type) { GtkWidget *img; char buf[64]; if (type < 0 || type >= MARK_TYPE_NUM) { type = 0; } if (NgraphApp.markpix[type]) { GdkPixbuf *pixbuf; pixbuf = gdk_pixbuf_get_from_surface(NgraphApp.markpix[type], 0, 0, MARK_PIX_SIZE, MARK_PIX_SIZE); img = gtk_image_new_from_pixbuf(pixbuf); if (img) { gtk_button_set_image(GTK_BUTTON(w), img); } snprintf(buf, sizeof(buf), "%02d", type); gtk_widget_set_tooltip_text(w, buf); } } static void MarkDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *grid; struct MarkDialog *d; int type; #define COL 10 d = (struct MarkDialog *) data; if (makewidget) { grid = gtk_grid_new(); gtk_grid_set_column_spacing(GTK_GRID(grid), 8); gtk_grid_set_row_spacing(GTK_GRID(grid), 8); #if GTK_CHECK_VERSION(3, 12, 0) gtk_widget_set_margin_end(grid, 4); gtk_widget_set_margin_start(grid, 4); #else gtk_widget_set_margin_right(grid, 4); gtk_widget_set_margin_left(grid, 4); #endif for (type = 0; type < MARK_TYPE_NUM; type++) { w = gtk_toggle_button_new(); button_set_mark_image(w, type); g_signal_connect(w, "clicked", G_CALLBACK(MarkDialogCB), d); d->toggle[type] = w; gtk_grid_attach(GTK_GRID(grid), w, type % COL, type / COL, 1, 1); } gtk_box_pack_start(GTK_BOX(d->vbox), grid, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } d->cb_respond = FALSE; for (type = 0; type < MARK_TYPE_NUM; type++) { gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->toggle[type]), FALSE); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->toggle[d->Type]), TRUE); d->focus = d->toggle[d->Type]; d->cb_respond = TRUE; } static void MarkDialogClose(GtkWidget *w, void *data) { } void MarkDialog(struct MarkDialog *data, GtkWidget *parent, int type) { if (type < 0 || type >= MARK_TYPE_NUM) { type = 0; } data->SetupWindow = MarkDialogSetup; data->CloseWindow = MarkDialogClose; data->Type = type; data->parent = parent; } static void set_axis_combo_box(struct objlist *obj, int id, const char *field, GtkWidget *combo) { char *valstr; int i; sgetobjfield(obj, id, field, NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') i++; combo_box_entry_set_text(combo, valstr + i); g_free(valstr); } } static void plot_axis_setup_item(struct FileDialog *d, int id) { struct objlist *aobj; char *name; int j, lastinst; combo_box_clear(d->xaxis); combo_box_clear(d->yaxis); aobj = getobject("axis"); lastinst = chkobjlastinst(aobj); for (j = 0; j <= lastinst; j++) { getobj(aobj, "group", j, 0, NULL, &name); name = CHK_STR(name); combo_box_append_text(d->xaxis, name); combo_box_append_text(d->yaxis, name); } set_axis_combo_box(d->Obj, id, "axis_x", d->xaxis); set_axis_combo_box(d->Obj, id, "axis_y", d->yaxis); } static void file_setup_item(struct FileDialog *d, int id) { if (d->source != DATA_SOURCE_RANGE) { SetWidgetFromObjField(d->xcol, d->Obj, id, "x"); SetWidgetFromObjField(d->ycol, d->Obj, id, "y"); } plot_axis_setup_item(d, id); } static void set_fit_button_label(GtkWidget *btn, const char *str) { char buf[128]; if (str && str[0] != '\0') { snprintf(buf, sizeof(buf), "Fit:%s", str); } else { snprintf(buf, sizeof(buf), _("Create")); } gtk_button_set_label(GTK_BUTTON(btn), buf); } static void plot_tab_setup_item(struct FileDialog *d, int id) { int a; SetWidgetFromObjField(d->type, d->Obj, id, "type"); SetWidgetFromObjField(d->curve, d->Obj, id, "interpolation"); getobj(d->Obj, "mark_type", id, 0, NULL, &a); button_set_mark_image(d->mark_btn, a); MarkDialog(&(d->mark), d->widget, a); SetWidgetFromObjField(d->size, d->Obj, id, "mark_size"); SetWidgetFromObjField(d->width, d->Obj, id, "line_width"); SetStyleFromObjField(d->style, d->Obj, id, "line_style"); SetWidgetFromObjField(d->join, d->Obj, id, "line_join"); SetWidgetFromObjField(d->miter, d->Obj, id, "line_miter_limit"); SetWidgetFromObjField(d->clip, d->Obj, id, "data_clip"); set_color(d->col1, d->Obj, id, NULL); set_color2(d->col2, d->Obj, id); FileDialogType(d->type, d); } static void FileDialogSetupItem(GtkWidget *w, struct FileDialog *d) { char *valstr; int i; plot_tab_setup_item(d, d->Id); math_tab_setup_item(d, d->Id); load_tab_setup_item(d, d->Id); mask_tab_setup_item(d, d->Id); move_tab_setup_item(d, d->Id); file_setup_item(d, d->Id); switch (d->source) { case DATA_SOURCE_FILE: SetWidgetFromObjField(d->file, d->Obj, d->Id, "file"); gtk_editable_set_position(GTK_EDITABLE(d->file), -1); break; case DATA_SOURCE_ARRAY: SetWidgetFromObjField(d->file, d->Obj, d->Id, "array"); break; case DATA_SOURCE_RANGE: SetWidgetFromObjField(d->min, d->Obj, d->Id, "range_min"); SetWidgetFromObjField(d->max, d->Obj, d->Id, "range_max"); SetWidgetFromObjField(d->div, d->Obj, d->Id, "range_div"); break; } sgetobjfield(d->Obj, d->Id, "fit", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') { i++; } set_fit_button_label(d->fit, valstr + i); g_free(valstr); } gtk_widget_set_sensitive(d->apply_all, d->multi_open); gtk_notebook_set_current_page(GTK_NOTEBOOK(d->math_input_tab), Menulocal.math_input_mode); } static void FileDialogAxis(GtkWidget *w, gpointer client_data) { char buf[16]; int a; a = combo_box_get_active(w); if (a < 0) return; snprintf(buf, sizeof(buf), "%d", a); combo_box_entry_set_text(w, buf); } static void FileDialogMark(GtkWidget *w, gpointer client_data) { struct FileDialog *d; d = (struct FileDialog *) client_data; DialogExecute(d->widget, &(d->mark)); button_set_mark_image(w, d->mark.Type); } static int execute_fit_dialog(GtkWidget *w, struct objlist *fileobj, int fileid, struct objlist *fitobj, int fitid) { int save_type, type, ret; type = PLOT_TYPE_FIT; getobj(fileobj, "type", fileid, 0, NULL, &save_type); putobj(fileobj, "type", fileid, &type); FitDialog(&DlgFit, fitobj, fitid); ret = DialogExecute(w, &DlgFit); putobj(fileobj, "type", fileid, &save_type); return ret; } static int show_fit_dialog(struct objlist *obj, int id, GtkWidget *parent) { struct objlist *fitobj, *robj; char *fit; N_VALUE *inst; int idnum, fitid = 0, fitoid, ret, create = FALSE; struct narray iarray; if ((fitobj = chkobject("fit")) == NULL) return -1; if (getobj(obj, "fit", id, 0, NULL, &fit) == -1) return -1; if (fit) { arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &robj, &iarray, FALSE, NULL)) return -1; idnum = arraynum(&iarray); if ((robj != fitobj) || (idnum < 1)) { if (putobj(obj, "fit", id, NULL) == -1) { arraydel(&iarray); return -1; } } else { fitid = arraylast_int(&iarray); } arraydel(&iarray); } if (fit == NULL) { fitid = newobj(fitobj); inst = getobjinst(fitobj, fitid); _getobj(fitobj, "oid", inst, &fitoid); if ((fit = mkobjlist(fitobj, NULL, fitoid, NULL, TRUE)) == NULL) return -1; if (putobj(obj, "fit", id, fit) == -1) { g_free(fit); return -1; } create = TRUE; } ret = execute_fit_dialog(parent, obj, id, fitobj, fitid); switch (ret) { case IDCANCEL: if (! create) break; /* fall through */ case IDDELETE: delobj(fitobj, fitid); putobj(obj, "fit", id, NULL); if (! create) set_graph_modified(); break; case IDOK: if (create) set_graph_modified(); break; } return ret; } static void FileDialogFit(GtkWidget *w, gpointer client_data) { struct FileDialog *d; int i; char *valstr; d = (struct FileDialog *) client_data; show_fit_dialog(d->Obj, d->Id, d->widget); sgetobjfield(d->Obj, d->Id, "fit", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') i++; set_fit_button_label(d->fit, valstr + i); g_free(valstr); } } static void plot_tab_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { plot_tab_setup_item(d, sel); } } void copy_file_obj_field(struct objlist *obj, int id, int sel, int copy_filename) { char *field[] = {"name", "fit", "file", "array", NULL}; if (copy_filename) { field[2] = NULL; } copy_obj_field(obj, id, sel, field); FitCopy(obj, id, sel); set_graph_modified(); } static void FileDialogOption(GtkWidget *w, gpointer client_data) { struct FileDialog *d; d = (struct FileDialog *) client_data; exeobj(d->Obj, "load_settings", d->Id, 0, NULL); FileDialogSetupItem(d->widget, d); } static void edit_file(const char *file) { char *cmd, *localize_name; if (file == NULL) return; localize_name = get_localized_filename(file); if (localize_name == NULL) return; #if OSX cmd = g_strdup_printf("%s \"%s\"", Menulocal.editor, localize_name); #else cmd = g_strdup_printf("\"%s\" \"%s\"", Menulocal.editor, localize_name); #endif g_free(localize_name); system_bg(cmd); g_free(cmd); } static void FileDialogEdit(GtkWidget *w, gpointer client_data) { struct FileDialog *d; const char *file; d = (struct FileDialog *) client_data; if (Menulocal.editor == NULL) return; file = gtk_entry_get_text(GTK_ENTRY(d->file)); if (file == NULL) return; edit_file(file); } #if 1 static void FileDialogType(GtkWidget *w, gpointer client_data) { struct FileDialog *d; int type; d = (struct FileDialog *) client_data; type = combo_box_get_active(w); set_widget_sensitivity_with_label(d->curve, TRUE); set_widget_sensitivity_with_label(d->fit, TRUE); switch (type) { case PLOT_TYPE_MARK: case PLOT_TYPE_LINE: case PLOT_TYPE_POLYGON: case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_POLYGON_SOLID_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_ERRORBAR_X: case PLOT_TYPE_ERRORBAR_Y: case PLOT_TYPE_STAIRCASE_X: case PLOT_TYPE_STAIRCASE_Y: case PLOT_TYPE_BAR_X: case PLOT_TYPE_BAR_Y: case PLOT_TYPE_BAR_SOLID_FILL_X: case PLOT_TYPE_BAR_SOLID_FILL_Y: case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_FILL_Y: set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_CURVE: set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_FIT: set_widget_sensitivity_with_label(d->curve, FALSE); break; } } #else static void FileDialogType(GtkWidget *w, gpointer client_data) { struct FileDialog *d; int type; d = (struct FileDialog *) client_data; type = combo_box_get_active(w); set_widget_sensitivity_with_label(d->mark_btn, TRUE); set_widget_sensitivity_with_label(d->curve, TRUE); set_widget_sensitivity_with_label(d->col2, TRUE); set_widget_sensitivity_with_label(d->size, TRUE); set_widget_sensitivity_with_label(d->miter, TRUE); set_widget_sensitivity_with_label(d->join, TRUE); set_widget_sensitivity_with_label(d->fit, TRUE); set_widget_sensitivity_with_label(d->style, TRUE); set_widget_sensitivity_with_label(d->width, TRUE); switch (type) { case PLOT_TYPE_MARK: set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_LINE: case PLOT_TYPE_POLYGON: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_CURVE: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_RECTANGLE: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_POLYGON_SOLID_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); set_widget_sensitivity_with_label(d->style, FALSE); set_widget_sensitivity_with_label(d->width, FALSE); break; case PLOT_TYPE_ARROW: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_RECTANGLE_FILL: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_ERRORBAR_X: case PLOT_TYPE_ERRORBAR_Y: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_STAIRCASE_X: case PLOT_TYPE_STAIRCASE_Y: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_BAR_X: case PLOT_TYPE_BAR_Y: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_BAR_SOLID_FILL_X: case PLOT_TYPE_BAR_SOLID_FILL_Y: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); set_widget_sensitivity_with_label(d->style, FALSE); set_widget_sensitivity_with_label(d->width, FALSE); break; case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_FILL_Y: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->miter, FALSE); set_widget_sensitivity_with_label(d->join, FALSE); set_widget_sensitivity_with_label(d->fit, FALSE); break; case PLOT_TYPE_FIT: set_widget_sensitivity_with_label(d->mark_btn, FALSE); set_widget_sensitivity_with_label(d->curve, FALSE); set_widget_sensitivity_with_label(d->col2, FALSE); set_widget_sensitivity_with_label(d->size, FALSE); break; } } #endif static void file_settings_copy(GtkButton *btn, gpointer user_data) { struct FileDialog *d; int sel; d = (struct FileDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { file_setup_item(d, sel); } } static GtkWidget * plot_tab_create(GtkWidget *parent, struct FileDialog *d) { GtkWidget *table, *hbox, *w, *vbox; int i; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Type:"), FALSE, i++); d->type = w; g_signal_connect(w, "changed", G_CALLBACK(FileDialogType), d); w = gtk_button_new(); add_widget_to_table(table, w, _("_Mark:"), FALSE, i++); d->mark_btn = w; g_signal_connect(w, "clicked", G_CALLBACK(FileDialogMark), d); w = combo_box_create(); add_widget_to_table(table, w, _("_Curve:"), FALSE, i++); d->curve = w; d->fit_table = table; d->fit_row = i; i++; w = create_color_button(parent); add_widget_to_table(table, w, _("_Color 1:"), FALSE, i++); d->col1 = w; w = create_color_button(parent); add_widget_to_table(table, w, _("_Color 2:"), FALSE, i++); d->col2 = w; gtk_box_pack_start(GTK_BOX(hbox), table, FALSE, FALSE, 4); table = gtk_grid_new(); i = 0; w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); add_widget_to_table(table, w, _("Line _Style:"), TRUE, i++); d->style = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Line Width:"), FALSE, i++); d->width = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Size:"), FALSE, i++); d->size = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Miter:"), FALSE, i++); d->miter = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Join:"), FALSE, i++); d->join = w; w = gtk_check_button_new_with_mnemonic(_("_Clip")); add_widget_to_table(table, w, NULL, FALSE, i++); d->clip = w; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), hbox); set_widget_margin(w, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), w, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(plot_tab_copy), d, "data"); return vbox; } static void FileDialogSetupCommon(GtkWidget *wi, struct FileDialog *d) { GtkWidget *w, *hbox, *vbox2, *frame, *notebook, *label; vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); if (d->source != DATA_SOURCE_RANGE) { w = create_spin_entry(0, FILE_OBJ_MAXCOL, 1, FALSE, TRUE); item_setup(hbox, w, _("_X column:"), TRUE); d->xcol = w; } w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); item_setup(hbox, w, _("_X axis:"), TRUE); d->xaxis = w; g_signal_connect(w, "changed", G_CALLBACK(FileDialogAxis), d); gtk_box_pack_start(GTK_BOX(vbox2), hbox, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); if (d->source != DATA_SOURCE_RANGE) { w = create_spin_entry(0, FILE_OBJ_MAXCOL, 1, FALSE, TRUE); item_setup(hbox, w, _("_Y column:"), TRUE); d->ycol = w; } w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); item_setup(hbox, w, _("_Y axis:"), TRUE); d->yaxis = w; g_signal_connect(w, "changed", G_CALLBACK(FileDialogAxis), d); gtk_box_pack_start(GTK_BOX(vbox2), hbox, FALSE, FALSE, 4); add_copy_button_to_box(vbox2, G_CALLBACK(file_settings_copy), d, "data"); hbox = gtk_grid_new(); gtk_grid_set_column_spacing(GTK_GRID(hbox), 4); d->comment_box = hbox; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), vbox2); gtk_widget_set_hexpand(frame, FALSE); gtk_grid_attach(GTK_GRID(hbox), frame, 0, 0, 1, 1); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); notebook = gtk_notebook_new(); d->tab = GTK_NOTEBOOK(notebook); gtk_notebook_set_scrollable(d->tab, FALSE); gtk_notebook_set_tab_pos(d->tab, GTK_POS_TOP); w = plot_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Plot")); gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = math_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Math")); d->math.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = load_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Load")); d->load.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); gtk_box_pack_start(GTK_BOX(d->vbox), notebook, TRUE, TRUE, 4); } static void set_headlines(struct FileDialog *d, const char *s) { gboolean valid; const gchar *ptr; if (s == NULL) { return; } if (Menulocal.file_preview_font) { text_view_with_line_number_set_font(d->comment_view, Menulocal.file_preview_font); } valid = g_utf8_validate(s, -1, &ptr); if (valid) { text_view_with_line_number_set_text(d->comment_view, s); } else { char *ptr; ptr = g_locale_to_utf8(s, -1, NULL, NULL, NULL); if (ptr) { text_view_with_line_number_set_text(d->comment_view, ptr); g_free(ptr); } else { text_view_with_line_number_set_text(d->comment_view, _("This file contain invalid UTF-8 strings.")); } } } #define CHECK_TERMINATE(ch) ((ch) == '\0' || (ch) == '\n') #define CHECK_CHR(ifs, ch) (ch && strchr(ifs, ch)) #define CHECK_VISIBILITY(i, skip, step, remark, c) (! CHECK_CHR(remark, c) && (i >= skip && ! ((i - skip) % step))) #define CHECK_VISIBILITY_ARRAY(i, skip, step) ((i >= skip && ! ((i - skip) % step))) static void check_add_str(struct narray *array, const char *str, int len) { int valid; char *ptr; valid = g_utf8_validate(str, len, NULL); if (valid) { ptr = g_strndup(str, len); arrayadd(array, &ptr); } else { ptr = g_locale_to_utf8(str, len, NULL, NULL, NULL); if (ptr == NULL) { GString *s; int i; s = g_string_new(""); if (s == NULL) { return; } for (i = 0; i < len; i++) { if (g_ascii_isprint(str[i]) || g_ascii_isspace(str[i])) { g_string_append_c(s, str[i]); } else { g_string_append(s, "〓"); } } ptr = g_string_free(s, FALSE); } if (ptr) { arrayadd(array, &ptr); } } } static const char * parse_data_line(struct narray *array, const char *str, const char *ifs, const char *comment, int csv) { const char *po; int len; if (str == NULL) { return NULL; } po = str; while (! CHECK_TERMINATE(*po)) { if (csv) { for (; *po == ' '; po++); if (CHECK_TERMINATE(*po)) break; if (CHECK_CHR(ifs, *po)) { po++; check_add_str(array, "", 0); } else { len = 0; for (; (! CHECK_TERMINATE(po[len])) && ! CHECK_CHR(ifs, po[len]) && (po[len] != ' '); len++) ; check_add_str(array, po, len); po += len; for (; (*po == ' '); po++); if (CHECK_CHR(ifs, *po)) po++; } } else { for (; (! CHECK_TERMINATE(*po)) && CHECK_CHR(ifs, *po); po++); len = 0; for (; (! CHECK_TERMINATE(po[len])) && ! CHECK_CHR(ifs, po[len]); len++) ; check_add_str(array, po, len); po += len; if (CHECK_TERMINATE(*po)) break; } } if (*po == '\n') { po++; } return (*po) ? po : NULL; } #define MAX_COLS 100 #define HEADLINE_FIRST_CHAR_COLUMN (MAX_COLS + 0) #define HEADLINE_LINE_NUM_COLUMN (MAX_COLS + 1) #define HEADLINE_VISIBILITY_COLUMN (MAX_COLS + 2) #define HEADLINE_ELLIPSIZE_COLUMN (MAX_COLS + 3) #define HEADLINE_FONT_COLUMN (MAX_COLS + 4) #define HEADLINE_COLUMN_NUM (MAX_COLS + 5) static void set_headline_table_header(struct FileDialog *d) { int x, y, type, i; GString *str; type = combo_box_get_active(d->type); x = spin_entry_get_val(d->xcol); y = spin_entry_get_val(d->ycol); str = g_string_new(""); if (str == NULL) { return; } for (i = 0; i < MAX_COLS; i++) { GtkTreeViewColumn *col; g_string_set_size(str, 0); col = gtk_tree_view_get_column(GTK_TREE_VIEW(d->comment_table), i); if (i == x) { switch (type) { case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: g_string_append(str, "X1"); break; default: g_string_append(str, "X"); } } else if (i == x + 1) { switch (type) { case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: g_string_append(str, "Y1"); break; case PLOT_TYPE_ERRORBAR_X: g_string_append(str, "Ex1"); break; } } else if (i == x + 2) { switch (type) { case PLOT_TYPE_ERRORBAR_X: g_string_append(str, "Ex2"); break; } } if (str->len) { g_string_append_c(str, ' '); } if (i == y) { switch (type) { case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: g_string_append(str, "X2"); break; default: g_string_append(str, "Y"); } } else if (i == y + 1) { switch (type) { case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_RECTANGLE_SOLID_FILL: g_string_append(str, "Y2"); break; case PLOT_TYPE_ERRORBAR_Y: g_string_append(str, "Ey1"); break; } } else if (i == y + 2) { switch (type) { case PLOT_TYPE_ERRORBAR_Y: g_string_append(str, "Ey2"); break; } } if (str->len) { if (str->str[str->len - 1] != ' ') { g_string_append_c(str, ' '); } g_string_append_printf(str, "(%%%d)", i); } else { g_string_append_printf(str, "%%%d", i); } gtk_tree_view_column_set_title(col, str->str); // gtk_tree_view_column_set_visible(col, i < max_col); } g_string_free(str, TRUE); } static void set_headline_table_array(struct FileDialog *d, int max_lines) { struct array_prm ary; int i, j, l, m, n, skip, step; char *array, buf[64]; GtkListStore *model; getobj(d->Obj, "array", d->Id, 0, NULL, &array); open_array(array, &ary); skip = spin_entry_get_val(d->load.headskip); if (skip < 0) { skip = 0; } step = spin_entry_get_val(d->load.readstep); if (step < 1) { step = 1; } model = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(d->comment_table))); gtk_list_store_clear(model); gtk_tree_view_set_model(GTK_TREE_VIEW(d->comment_table), NULL); n = (ary.data_num > max_lines) ? max_lines : ary.data_num; m = (ary.col_num < MAX_COLS) ? ary.col_num : MAX_COLS; l = 1; for (i = 0; i < n; i++) { GtkTreeIter iter; double val; void *ptr; int v; gtk_list_store_append(model, &iter); for (j = 0; j < m; j++) { ptr = arraynget(ary.ary[j], i); if (ptr) { val = * (double *) ptr; snprintf(buf, sizeof(buf), "%G", val); gtk_list_store_set(model, &iter, j + 1, buf, -1); } } v = CHECK_VISIBILITY_ARRAY(i, skip, step); gtk_list_store_set(model, &iter, 0, l, HEADLINE_LINE_NUM_COLUMN, i, HEADLINE_VISIBILITY_COLUMN, v, HEADLINE_ELLIPSIZE_COLUMN, (v) ? PANGO_ELLIPSIZE_NONE : PANGO_ELLIPSIZE_END, HEADLINE_FONT_COLUMN, Menulocal.file_preview_font, -1); if (v) { l++; } } gtk_tree_view_set_model(GTK_TREE_VIEW(d->comment_table), GTK_TREE_MODEL(model)); } static void set_headline_table(struct FileDialog *d, char *s, int max_lines) { struct narray *lines; int i, j, l, n, skip, step, csv; const char *tmp, *remark, *po; GString *ifs; GtkListStore *model; if (! d->initialized || s == NULL || max_lines < 1) { return; } lines = g_malloc0(sizeof(*lines) * max_lines); if (lines == NULL) { return; } skip = spin_entry_get_val(d->load.headskip); if (skip < 0) { skip = 0; } step = spin_entry_get_val(d->load.readstep); if (step < 1) { step = 1; } csv = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->load.csv)); remark = gtk_entry_get_text(GTK_ENTRY(d->load.remark)); if (remark == NULL) { remark = ""; } tmp = gtk_entry_get_text(GTK_ENTRY(d->load.ifs)); if (tmp == NULL) { tmp = ""; } ifs = g_string_new(""); decode_ifs_text(ifs, tmp); po = s; for (n = 0; n < max_lines; n++) { arrayinit(lines + n, sizeof(char *)); po = parse_data_line(lines + n, po, ifs->str, remark, csv); if (po == NULL) { n++; break; } } g_string_free(ifs, TRUE); if (n == 0) { goto exit; } model = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(d->comment_table))); gtk_list_store_clear(model); gtk_tree_view_set_model(GTK_TREE_VIEW(d->comment_table), NULL); l = 1; for (i = 0; i < n; i++) { GtkTreeIter iter; int m, c, v; const char *str; gtk_list_store_append(model, &iter); m = arraynum(lines + i); m = (m < MAX_COLS) ? m : MAX_COLS; for (j = 0; j < m; j++) { gtk_list_store_set(model, &iter, j + 1, arraynget_str(lines + i, j), -1); } str = arraynget_str(lines + i, 0); if (str) { c = (g_ascii_isprint(str[0]) || g_ascii_isspace(str[0])) ? str[0] : 0; } else { c = 0; } v = CHECK_VISIBILITY(i, skip, step, remark, c); gtk_list_store_set(model, &iter, 0, l, HEADLINE_LINE_NUM_COLUMN, i, HEADLINE_FIRST_CHAR_COLUMN, c, HEADLINE_VISIBILITY_COLUMN, v, HEADLINE_ELLIPSIZE_COLUMN, (v) ? PANGO_ELLIPSIZE_NONE : PANGO_ELLIPSIZE_END, HEADLINE_FONT_COLUMN, Menulocal.file_preview_font, -1); if (v) { l++; } } gtk_tree_view_set_model(GTK_TREE_VIEW(d->comment_table), GTK_TREE_MODEL(model)); exit: for (i = 0; i < n; i++) { arraydel2(lines + i); } g_free(lines); } static GtkWidget * create_preview_table(struct FileDialog *d) { GtkWidget *view; GtkListStore *model; GType *types; int i; view = gtk_tree_view_new(); gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(view), GTK_TREE_VIEW_GRID_LINES_BOTH); types = g_malloc(sizeof(*types) * HEADLINE_COLUMN_NUM); if (types == NULL) { return NULL; } for (i = 1; i < MAX_COLS; i++) { types[i] = G_TYPE_STRING; } types[0] = G_TYPE_INT; types[HEADLINE_LINE_NUM_COLUMN] = G_TYPE_INT; types[HEADLINE_FIRST_CHAR_COLUMN] = G_TYPE_INT; types[HEADLINE_VISIBILITY_COLUMN] = G_TYPE_BOOLEAN; types[HEADLINE_ELLIPSIZE_COLUMN] = G_TYPE_INT; types[HEADLINE_FONT_COLUMN] = G_TYPE_STRING; model = gtk_list_store_newv(HEADLINE_COLUMN_NUM, types); g_free(types); gtk_tree_view_set_model(GTK_TREE_VIEW(view), GTK_TREE_MODEL(model)); for (i = 0; i < MAX_COLS; i++) { char buf[32]; GtkCellRenderer *cell; GtkTreeViewColumn *column; snprintf(buf, sizeof(buf), "%%%d", i); cell = gtk_cell_renderer_text_new(); column = gtk_tree_view_column_new_with_attributes(buf, cell, "text", i, "sensitive", HEADLINE_VISIBILITY_COLUMN, "ellipsize", HEADLINE_ELLIPSIZE_COLUMN, "font", HEADLINE_FONT_COLUMN, NULL); if (i == 0) { gtk_tree_view_column_add_attribute(column, cell, "visible", HEADLINE_VISIBILITY_COLUMN); } g_object_set((GObject *) cell, "xalign", (gfloat) 1.0, NULL); gtk_tree_view_column_set_alignment(column, 0.5); gtk_tree_view_column_set_sizing(column, GTK_TREE_VIEW_COLUMN_AUTOSIZE); gtk_tree_view_append_column(GTK_TREE_VIEW(view), column); } return view; } static void update_table(GtkEditable *editable, gpointer user_data) { struct FileDialog *d; d = (struct FileDialog *) user_data; set_headline_table(d, d->head_lines, Menulocal.data_head_lines); } static void update_table_visibility(GtkEditable *editable, gpointer user_data) { struct FileDialog *d; GtkTreeModel *model; GtkTreeIter iter; const char *remark; int skip, step, ln, fc, v, i; d = (struct FileDialog *) user_data; skip = spin_entry_get_val(d->load.headskip); if (skip < 0) { skip = 0; } step = spin_entry_get_val(d->load.readstep); if (step < 1) { step = 1; } remark = NULL; if (d->source == DATA_SOURCE_FILE) { remark = gtk_entry_get_text(GTK_ENTRY(d->load.remark)); } if (remark == NULL) { remark = ""; } model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->comment_table)); if (! gtk_tree_model_get_iter_first(model, &iter)) { return; } i = 1; do { gtk_tree_model_get(model, &iter, HEADLINE_LINE_NUM_COLUMN, &ln, HEADLINE_FIRST_CHAR_COLUMN, &fc, -1); if (d->source == DATA_SOURCE_FILE) { v = CHECK_VISIBILITY(ln, skip, step, remark, fc); } else { v = CHECK_VISIBILITY_ARRAY(ln, skip, step); } gtk_list_store_set(GTK_LIST_STORE(model), &iter, 0, i, HEADLINE_VISIBILITY_COLUMN, v, HEADLINE_ELLIPSIZE_COLUMN, (v) ? PANGO_ELLIPSIZE_NONE : PANGO_ELLIPSIZE_END, HEADLINE_FONT_COLUMN, Menulocal.file_preview_font, -1); if (v) { i++; } } while (gtk_tree_model_iter_next(model, &iter)); } static void update_table_header(GtkEditable *editable, gpointer user_data) { struct FileDialog *d; d = (struct FileDialog *) user_data; set_headline_table_header(d); } static void FileDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *view, *label, *swin; struct FileDialog *d; int line; char title[32], *argv[2], *s; d = (struct FileDialog *) data; snprintf(title, sizeof(title), _("Data %d (File)"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { d->apply_all = gtk_dialog_add_button(GTK_DIALOG(wi), _("_Apply all"), IDFAPPLY); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_file_entry(d->Obj); item_setup(GTK_WIDGET(hbox), w, _("_File:"), TRUE); d->file = w; w = gtk_button_new_with_mnemonic(_("_Load settings")); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); d->load_settings = w; g_signal_connect(w, "clicked", G_CALLBACK(FileDialogOption), d); w = gtk_button_new_with_mnemonic(_("_Edit")); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); g_signal_connect(w, "clicked", G_CALLBACK(FileDialogEdit), d); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); FileDialogSetupCommon(wi, d); w = mask_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Mask")); d->mask.tab_id = gtk_notebook_append_page(d->tab, w, label); w = move_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Move")); d->move.tab_id = gtk_notebook_append_page(d->tab, w, label); w = gtk_notebook_new(); view = create_preview_table(d); if (view) { label = gtk_label_new_with_mnemonic(_("_Table")); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), view); gtk_notebook_append_page(GTK_NOTEBOOK(w), swin, label); } d->comment_table = view; view = create_text_view_with_line_number(&d->comment_view); label = gtk_label_new_with_mnemonic(_("_Plain")); gtk_notebook_append_page(GTK_NOTEBOOK(w), view, label); g_signal_connect(d->load.ifs, "changed", G_CALLBACK(update_table), d); g_signal_connect(d->load.csv, "toggled", G_CALLBACK(update_table), d); g_signal_connect(d->load.remark, "changed", G_CALLBACK(update_table_visibility), d); g_signal_connect(d->load.readstep, "changed", G_CALLBACK(update_table_visibility), d); g_signal_connect(d->load.headskip, "changed", G_CALLBACK(update_table_visibility), d); g_signal_connect(d->xcol, "changed", G_CALLBACK(update_table_header), d); g_signal_connect(d->ycol, "changed", G_CALLBACK(update_table_header), d); g_signal_connect(d->type, "changed", G_CALLBACK(update_table_header), d); gtk_grid_attach(GTK_GRID(d->comment_box), w, 1, 0, 1, 1); w = gtk_button_new_with_label(_("Create")); add_widget_to_table(d->fit_table, w, _("_Fit:"), FALSE, d->fit_row); d->fit = w; g_signal_connect(w, "clicked", G_CALLBACK(FileDialogFit), d); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } line = Menulocal.data_head_lines; argv[0] = (char *) &line; argv[1] = NULL; getobj(d->Obj, "head_lines", d->Id, 1, argv, &s); FileDialogSetupItem(wi, d); d->initialized = TRUE; set_headlines(d, s); set_headline_table_header(d); set_headline_table(d, s, line); d->head_lines = g_strdup(s); } static void ArrayDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *view, *label, *swin; struct FileDialog *d; char title[32]; d = (struct FileDialog *) data; snprintf(title, sizeof(title), _("Data %d (Array)"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { d->apply_all = gtk_dialog_add_button(GTK_DIALOG(wi), _("_Apply all"), IDFAPPLY); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_text_entry(TRUE, TRUE); item_setup(GTK_WIDGET(hbox), w, _("_Array:"), TRUE); d->file = w; gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); FileDialogSetupCommon(wi, d); w = mask_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Mask")); d->mask.tab_id = gtk_notebook_append_page(d->tab, w, label); w = move_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Move")); d->move.tab_id = gtk_notebook_append_page(d->tab, w, label); view = create_preview_table(d); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), view); d->comment_table = view; g_signal_connect(d->load.readstep, "changed", G_CALLBACK(update_table_visibility), d); g_signal_connect(d->load.headskip, "changed", G_CALLBACK(update_table_visibility), d); g_signal_connect(d->xcol, "changed", G_CALLBACK(update_table_header), d); g_signal_connect(d->ycol, "changed", G_CALLBACK(update_table_header), d); g_signal_connect(d->type, "changed", G_CALLBACK(update_table_header), d); gtk_widget_set_hexpand(swin, TRUE); gtk_widget_set_vexpand(swin, TRUE); gtk_grid_attach(GTK_GRID(d->comment_box), swin, 1, 0, 1, 1); w = gtk_button_new_with_label(_("Create")); add_widget_to_table(d->fit_table, w, _("_Fit:"), FALSE, d->fit_row); d->fit = w; g_signal_connect(w, "clicked", G_CALLBACK(FileDialogFit), d); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } FileDialogSetupItem(wi, d); d->initialized = TRUE; set_headline_table_header(d); set_headline_table_array(d, Menulocal.data_head_lines); } static void RangeDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table, *label; struct FileDialog *d; char title[32]; int i; d = (struct FileDialog *) data; snprintf(title, sizeof(title), _("Data %d (Range)"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { d->apply_all = gtk_dialog_add_button(GTK_DIALOG(wi), _("_Apply all"), IDFAPPLY); table = gtk_grid_new(); i = 0; w = create_text_entry(FALSE, TRUE); gtk_entry_set_width_chars(GTK_ENTRY(w), RANGE_ENTRY_WIDTH); add_widget_to_table(table, w, _("_Minimum:"), FALSE, i++); d->min = w; w = create_text_entry(FALSE, TRUE); gtk_entry_set_width_chars(GTK_ENTRY(w), RANGE_ENTRY_WIDTH); add_widget_to_table(table, w, _("_Maximum:"), FALSE, i++); d->max = w; w = create_spin_entry(2, 65536, 1, FALSE, TRUE); add_widget_to_table(table, w, _("di_ViSion:"), FALSE, i++); d->div = w; FileDialogSetupCommon(wi, d); gtk_grid_insert_column(GTK_GRID(d->comment_box), 0); gtk_grid_attach(GTK_GRID(d->comment_box), table, 0, 0, 1, 1); w = mask_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Mask")); d->mask.tab_id = gtk_notebook_append_page(d->tab, w, label); w = move_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Move")); d->move.tab_id = gtk_notebook_append_page(d->tab, w, label); w = gtk_button_new_with_label(_("Create")); add_widget_to_table(d->fit_table, w, _("_Fit:"), FALSE, d->fit_row); d->fit = w; g_signal_connect(w, "clicked", G_CALLBACK(FileDialogFit), d); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } FileDialogSetupItem(wi, d); } static int plot_tab_set_value(struct FileDialog *d) { if (SetObjFieldFromWidget(d->type, d->Obj, d->Id, "type")) return TRUE; if (SetObjFieldFromWidget(d->curve, d->Obj, d->Id, "interpolation")) return TRUE; if (putobj(d->Obj, "mark_type", d->Id, &(d->mark.Type)) == -1) return TRUE; if (SetObjFieldFromWidget(d->size, d->Obj, d->Id, "mark_size")) return TRUE; if (SetObjFieldFromWidget(d->width, d->Obj, d->Id, "line_width")) return TRUE; if (SetObjFieldFromStyle(d->style, d->Obj, d->Id, "line_style")) return TRUE; if (SetObjFieldFromWidget(d->join, d->Obj, d->Id, "line_join")) return TRUE; if (SetObjFieldFromWidget(d->miter, d->Obj, d->Id, "line_miter_limit")) return TRUE; if (SetObjFieldFromWidget(d->clip, d->Obj, d->Id, "data_clip")) return TRUE; if (putobj_color(d->col1, d->Obj, d->Id, NULL)) return TRUE; if (putobj_color2(d->col2, d->Obj, d->Id)) return TRUE; return 0; } static void focus_math_widget(struct FileDialog *d, int math_tab_id, GtkWidget *text, GtkWidget *entry) { if (d->math_page == 0) { gtk_widget_grab_focus(entry); } else { gtk_notebook_set_current_page(d->math_tab, math_tab_id); gtk_widget_grab_focus(text); move_cursor_to_error_line(text); } } static int FileDialogCloseCommon(GtkWidget *w, struct FileDialog *d) { int r; if (SetObjFieldFromWidget(d->xcol, d->Obj, d->Id, "x")) return TRUE; if (SetObjAxisFieldFromWidget(d->xaxis, d->Obj, d->Id, "axis_x")) return TRUE; if (SetObjFieldFromWidget(d->ycol, d->Obj, d->Id, "y")) return TRUE; if (SetObjAxisFieldFromWidget(d->yaxis, d->Obj, d->Id, "axis_y")) return TRUE; if (plot_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, 0); return TRUE; } r = math_tab_set_value(d); if (r != MATH_ERROR_FIELD_NONE) { gtk_notebook_set_current_page(d->tab, d->math.tab_id); switch (r) { case MATH_ERROR_FIELD_X: focus_math_widget(d, r -1, d->math.text_x, d->math.x); break; case MATH_ERROR_FIELD_Y: focus_math_widget(d, r -1, d->math.text_y, d->math.y); break; case MATH_ERROR_FIELD_F: focus_math_widget(d, r -1, d->math.text_f, d->math.f); break; case MATH_ERROR_FIELD_G: focus_math_widget(d, r -1, d->math.text_g, d->math.g); break; case MATH_ERROR_FIELD_H: focus_math_widget(d, r -1, d->math.text_h, d->math.h); break; case MATH_ERROR_FIELD_SX: gtk_widget_grab_focus(d->math.xsmooth); break; case MATH_ERROR_FIELD_SY: gtk_widget_grab_focus(d->math.ysmooth); break; } return TRUE; } if (load_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, d->load.tab_id); return TRUE; } Menulocal.math_input_mode = gtk_notebook_get_current_page(GTK_NOTEBOOK(d->math_input_tab)); return FALSE; } static void FileDialogClose(GtkWidget *w, void *data) { struct FileDialog *d; int ret; d = (struct FileDialog *) data; switch (d->ret) { case IDOK: case IDFAPPLY: break; default: goto End; } ret = d->ret; d->ret = IDLOOP; switch (d->source) { case DATA_SOURCE_FILE: if (SetObjFieldFromWidget(d->file, d->Obj, d->Id, "file")) { return; } break; case DATA_SOURCE_ARRAY: if (SetObjFieldFromWidget(d->file, d->Obj, d->Id, "array")) { return; } break; case DATA_SOURCE_RANGE: if (SetObjFieldFromWidget(d->min, d->Obj, d->Id, "range_min")) { return; } if (SetObjFieldFromWidget(d->max, d->Obj, d->Id, "range_max")) { return; } if (SetObjFieldFromWidget(d->div, d->Obj, d->Id, "range_div")) { return; } break; } if (FileDialogCloseCommon(w, d)) return; if (mask_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, d->mask.tab_id); return; } if (move_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, d->move.tab_id); return; } d->initialized = FALSE; d->ret = ret; End: g_free(d->head_lines); d->head_lines = NULL; } void FileDialog(struct obj_list_data *data, int id, int multi) { struct FileDialog *d; int source; getobj(data->obj, "source", id, 0, NULL, &source); switch (source) { case DATA_SOURCE_FILE: d = &DlgFile; data->dialog = d; d->SetupWindow = FileDialogSetup; break; case DATA_SOURCE_ARRAY: d = &DlgArray; data->dialog = d; d->SetupWindow = ArrayDialogSetup; break; case DATA_SOURCE_RANGE: d = &DlgRange; data->dialog = d; d->SetupWindow = RangeDialogSetup; break; default: return; /* never reached */ } d->CloseWindow = FileDialogClose; d->Obj = data->obj; d->Id = id; d->source = source; d->multi_open = multi > 0; d->initialized = FALSE; d->head_lines = NULL; } static void FileDialogDefSetupItem(GtkWidget *w, struct FileDialog *d, int id) { plot_tab_setup_item(d, d->Id); math_tab_setup_item(d, d->Id); load_tab_setup_item(d, d->Id); file_setup_item(d, d->Id); } static void FileDefDialogSetup(GtkWidget *wi, void *data, int makewidget) { struct FileDialog *d; d = (struct FileDialog *) data; if (makewidget) { FileDialogSetupCommon(wi, d); gtk_notebook_set_tab_pos(d->tab, GTK_POS_TOP); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } FileDialogDefSetupItem(wi, d, d->Id); } static void FileDefDialogClose(GtkWidget *w, void *data) { struct FileDialog *d; int ret; d = (struct FileDialog *) data; switch (d->ret) { case IDOK: break; default: return; } ret = d->ret; d->ret = IDLOOP; if (FileDialogCloseCommon(w, d)) return; d->ret = ret; } void FileDefDialog(struct FileDialog *data, struct objlist *obj, int id) { data->SetupWindow = FileDefDialogSetup; data->CloseWindow = FileDefDialogClose; data->Obj = obj; data->Id = id; data->source = DATA_SOURCE_FILE; } static void delete_file_obj(struct obj_list_data *data, int id) { FitDel(data->obj, id); delobj(data->obj, id); /* don't delete darray object */ } static int data_save_undo(int type) { char *arg[3]; arg[0] = "data"; arg[1] = "fit"; arg[2] = NULL; return menu_save_undo(type, arg); } void CmFileHistory(GtkRecentChooser *w, gpointer client_data) { int ret; char *name, *fname; int id, undo; struct objlist *obj; char *uri; struct obj_list_data *data; if (Menulock || Globallock) { return; } uri = gtk_recent_chooser_get_current_uri(w); if (uri == NULL) { return; } name = g_filename_from_uri(uri, NULL, NULL); g_free(uri); if (name == NULL) { return; } obj = chkobject("data"); if (obj == NULL) { return; } undo = data_save_undo(UNDO_TYPE_OPEN_FILE); id = newobj(obj); if (id < 0) { menu_delete_undo(undo); return; } fname = g_strdup(name); if (fname == NULL) { menu_delete_undo(undo); return; } putobj(obj, "file", id, name); data = NgraphApp.FileWin.data.data; FileDialog(data, id, FALSE); ret = DialogExecute(TopLevel, data->dialog); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); AddDataFileList(fname); } g_free(fname); FileWinUpdate(data, TRUE, DRAW_NOTIFY); } void CmRangeAdd(void *w, gpointer client_data) { int id, ret, val, undo; struct objlist *obj; struct obj_list_data *data; if (Menulock || Globallock) return; obj = chkobject("data"); if (obj == NULL) { return; } undo = data_save_undo(UNDO_TYPE_ADD_RANGE); id = newobj(obj); if (id < 0) { menu_delete_undo(undo); return; } data = NgraphApp.FileWin.data.data; val = DATA_SOURCE_RANGE; putobj(obj, "source", id, &val); val = PLOT_TYPE_LINE; putobj(obj, "type", id, &val); FileDialog(data, id, FALSE); ret = DialogExecute(TopLevel, data->dialog); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); FileWinUpdate(data, TRUE, DRAW_REDRAW); } } void CmFileOpen(void *w, gpointer client_data) { int id, ret, n, undo = -1; char *name; char **file = NULL, **ptr; struct objlist *obj; struct narray farray; if (Menulock || Globallock) return; obj = chkobject("data"); if (obj == NULL) return; ret = nGetOpenFileNameMulti(TopLevel, _("Add Data file"), NULL, &(Menulocal.fileopendir), NULL, &file, Menulocal.changedirectory); n = chkobjlastinst(obj); arrayinit(&farray, sizeof(int)); if (ret == IDOK && file) { undo = data_save_undo(UNDO_TYPE_OPEN_FILE); for (ptr = file; *ptr; ptr++) { name = *ptr; id = newobj(obj); if (id >= 0) { arrayadd(&farray, &id); changefilename(name); putobj(obj, "file", id, name); } } g_free(file); } if (update_file_obj_multi(obj, &farray, TRUE)) { menu_delete_undo(undo); } if (n == chkobjlastinst(obj)) { menu_delete_undo(undo); } else { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, DRAW_NOTIFY); set_graph_modified(); } arraydel(&farray); } void CmFileClose(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i; int *array, num; struct obj_list_data *data; if (Menulock || Globallock) return; if ((obj = chkobject("data")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("close data (multi select)"), FileCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { data = NgraphApp.FileWin.data.data; num = arraynum(&farray); if (num > 0) { data_save_undo(UNDO_TYPE_DELETE); } array = arraydata(&farray); for (i = num - 1; i >= 0; i--) { delete_file_obj(data, array[i]); set_graph_modified(); } FileWinUpdate(data, TRUE, DRAW_REDRAW); } arraydel(&farray); } int update_file_obj_multi(struct objlist *obj, struct narray *farray, int new_file) { int i, j, num, *array, id0, modified, ret, undo; char *name; struct obj_list_data *data; num = arraynum(farray); if (num < 1) { return 0; } array = arraydata(farray); id0 = -1; ret = IDCANCEL; modified = FALSE; data_save_undo(UNDO_TYPE_EDIT); for (i = 0; i < num; i++) { name = NULL; if (id0 != -1) { copy_file_obj_field(obj, array[i], array[id0], FALSE); if (new_file) { getobj(obj, "file", array[i], 0, NULL, &name); AddDataFileList(name); } } else { undo = data_save_undo(UNDO_TYPE_DUMMY); data = NgraphApp.FileWin.data.data; FileDialog(data, array[i], i < num - 1); ret = DialogExecute(TopLevel, data->dialog); if (ret == IDCANCEL && new_file) { ret = IDDELETE; } switch (ret) { case IDDELETE: delete_file_obj(data, array[i]); modified = TRUE; if (! new_file) { set_graph_modified(); } for (j = i + 1; j < num; j++) { array[j]--; } menu_delete_undo(undo); break; case IDFAPPLY: id0 = i; /* fall-through */ case IDOK: if (new_file) { getobj(obj, "file", array[i], 0, NULL, &name); AddDataFileList(name); } menu_delete_undo(undo); modified = TRUE; break; case IDCANCEL: menu_undo_internal(undo); break; } } } if (! modified) { menu_undo_internal(undo); } return modified; } void CmFileUpdate(void *w, gpointer client_data) { struct objlist *obj; int ret; struct narray farray; int last; if (Menulock || Globallock) return; if ((obj = chkobject("data")) == NULL) return; last = chkobjlastinst(obj); if (last == -1) { return; } else if (last == 0) { arrayinit(&farray, sizeof(int)); arrayadd(&farray, &last); ret = IDOK; } else { SelectDialog(&DlgSelect, obj, _("data property (multi select)"), FileCB, (struct narray *) &farray, NULL); ret = DialogExecute(TopLevel, &DlgSelect); } if (ret == IDOK && update_file_obj_multi(obj, &farray, FALSE)) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, DRAW_REDRAW); } arraydel(&farray); } static int check_plot_obj_file(struct objlist *obj) { int last, i, source; last = chkobjlastinst(obj); for (i = 0; i < last; i++) { getobj(obj, "source", i, 0, NULL, &source); if (source == DATA_SOURCE_FILE) { return i; } } return -1; } void CmFileEdit(void *w, gpointer client_data) { struct objlist *obj; int i; char *name; int last; if (Menulock || Globallock) return; if (Menulocal.editor == NULL) return; if ((obj = chkobject("data")) == NULL) return; last = check_plot_obj_file(obj); if (last == -1) { return; } else { CopyDialog(&DlgCopy, obj, -1, _("edit data file (single select)"), PlotFileCB); if (DialogExecute(TopLevel, &DlgCopy) == IDOK) { i = DlgCopy.sel; } else { return; } } if (i < 0) return; if (getobj(obj, "file", i, 0, NULL, &name) == -1) return; edit_file(name); } void CmOptionFileDef(void *w, gpointer client_data) { struct objlist *obj; int id; char *objs[2]; if (Menulock || Globallock) return; if ((obj = chkobject("data")) == NULL) return; id = newobj(obj); if (id >= 0) { int modified; modified = get_graph_modified(); FileDefDialog(&DlgFileDef, obj, id); if (DialogExecute(TopLevel, &DlgFileDef) == IDOK) { if (CheckIniFile()) { exeobj(obj, "save_config", id, 0, NULL); } } delobj(obj, id); objs[0] = obj->name; objs[1] = NULL; UpdateAll2(objs, TRUE); if (! modified) { reset_graph_modified(); } } } static void FileWinFileEdit(struct obj_list_data *d) { int sel, num; char *name; if (Menulock || Globallock) return; if (Menulocal.editor == NULL) return; sel = d->select; num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) return; if (getobj(d->obj, "file", sel, 0, NULL, &name) == -1) return; edit_file(name); } static void file_edit_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data *) client_data; FileWinFileEdit(d); } static void FileWinFileDelete(struct obj_list_data *d) { int sel, update, num; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { data_save_undo(UNDO_TYPE_DELETE); delete_file_obj(d, sel); num = chkobjlastinst(d->obj); update = FALSE; if (num < 0) { d->select = -1; update = TRUE; } else if (sel > num) { d->select = num; } else { d->select = sel; } FileWinUpdate(d, update, DRAW_REDRAW); set_graph_modified(); } } static void file_delete_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data*) client_data; FileWinFileDelete(d); } static int file_obj_copy(struct obj_list_data *d) { int sel, id, num; if (Menulock || Globallock) return -1; sel = list_store_get_selected_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel < 0) || (sel > num)) return -1; id = newobj(d->obj); if (id < 0) return -1; copy_file_obj_field(d->obj, id, sel, TRUE); return id; } static void FileWinFileCopy(struct obj_list_data *d) { data_save_undo(UNDO_TYPE_COPY); d->select = file_obj_copy(d); FileWinUpdate(d, FALSE, DRAW_NOTIFY); } static void file_copy_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data *) client_data; FileWinFileCopy(d); } static void FileWinFileCopy2(struct obj_list_data *d) { int id, sel, j, num; if (Menulock || Globallock) return; data_save_undo(UNDO_TYPE_COPY); sel = list_store_get_selected_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID); id = file_obj_copy(d); num = chkobjlastinst(d->obj); if (id < 0) { d->select = sel; FileWinUpdate(d, TRUE, DRAW_NOTIFY); return; } for (j = num; j > sel + 1; j--) { moveupobj(d->obj, j); } d->select = sel + 1; FileWinUpdate(d, FALSE, DRAW_NOTIFY); } static void file_copy2_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data *) client_data; FileWinFileCopy2(d); } static void FileWinFileUpdate(struct obj_list_data *d) { int sel, ret, num, undo; GtkWidget *parent; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { undo = data_save_undo(UNDO_TYPE_EDIT); d->setup_dialog(d, sel, FALSE); d->select = sel; parent = TopLevel; ret = DialogExecute(parent, d->dialog); set_graph_modified(); switch (ret) { case IDCANCEL: menu_undo_internal(undo); break; default: d->update(d, FALSE, DRAW_NOTIFY); } } } static void FileWinFileDraw(struct obj_list_data *d) { int i, sel, hidden, h, num, modified, undo; if (Menulock || Globallock) return; sel = list_store_get_selected_index(GTK_WIDGET(d->text)); num = chkobjlastinst(d->obj); modified = FALSE; undo = data_save_undo(UNDO_TYPE_EDIT); if ((sel >= 0) && (sel <= num)) { for (i = 0; i <= num; i++) { hidden = (i != sel); getobj(d->obj, "hidden", i, 0, NULL, &h); putobj(d->obj, "hidden", i, &hidden); if (h != hidden) { modified = TRUE; } } d->select = sel; } else { hidden = FALSE; for (i = 0; i <= num; i++) { getobj(d->obj, "hidden", i, 0, NULL, &h); putobj(d->obj, "hidden", i, &hidden); if (h != hidden) { modified = TRUE; } } d->select = -1; } if (modified) { set_graph_modified(); } else { menu_delete_undo(undo); } CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); FileWinUpdate(d, FALSE, DRAW_NONE); } static void file_draw_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data *) client_data; FileWinFileDraw(d); } void FileWinUpdate(struct obj_list_data *d, int clear, int draw) { int redraw; if (Menulock || Globallock) return; if (d == NULL) return; if (list_sub_window_must_rebuild(d)) { list_sub_window_build(d, file_list_set_val); } else { list_sub_window_set(d, file_list_set_val); } if (! clear && d->select >= 0) { list_store_select_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID, d->select); } switch (draw) { case DRAW_REDRAW: getobj(Menulocal.obj, "redraw_flag", 0, 0, NULL, &redraw); if (redraw) { NgraphApp.Viewer.allclear = TRUE; update_viewer(d); } else { draw_notify(TRUE); } break; case DRAW_NOTIFY: draw_notify(TRUE); break; } } static void FileWinFit(struct obj_list_data *d) { struct objlist *fitobj, *obj2; char *fit; int sel, idnum, fitid = 0, ret, num, undo; struct narray iarray; GtkWidget *parent; if (Menulock || Globallock) return; sel = list_store_get_selected_int(GTK_WIDGET(d->text), FILE_WIN_COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) return; if ((fitobj = chkobject("fit")) == NULL) return; if (getobj(d->obj, "fit", sel, 0, NULL, &fit) == -1) return; if (fit) { arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &obj2, &iarray, FALSE, NULL)) { arraydel(&iarray); return; } idnum = arraynum(&iarray); if ((obj2 != fitobj) || (idnum < 1)) { if (putobj(d->obj, "fit", sel, NULL) == -1) { arraydel(&iarray); return; } } else { fitid = arraylast_int(&iarray); } arraydel(&iarray); } if (fit == NULL) return; undo = data_save_undo(UNDO_TYPE_EDIT); parent = TopLevel; ret = execute_fit_dialog(parent, d->obj, sel, fitobj, fitid); switch (ret) { case IDCANCEL: menu_delete_undo(undo); break; case IDDELETE: delobj(fitobj, fitid); putobj(d->obj, "fit", sel, NULL); break; } } #define MARK_PIX_LINE_WIDTH 1 static void set_line_style(struct objlist *obj, int id, int ggc) { struct narray *line_style; int n; getobj(obj, "line_style", id, 0, NULL, &line_style); n = arraynum(line_style); if (n > 0) { int i, *style, *ptr; style = g_malloc(sizeof(*style) * n); if (style == NULL) { GRAlinestyle(ggc, 0, NULL, MARK_PIX_LINE_WIDTH, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); return; } ptr = arraydata(line_style); for (i = 0; i < n; i++) { style[i] = ptr[i] / 40; } GRAlinestyle(ggc, n, style, MARK_PIX_LINE_WIDTH, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); g_free(style); } else { GRAlinestyle(ggc, 0, NULL, MARK_PIX_LINE_WIDTH, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); } } #define CURVE_POINTS_MAX 7 static void draw_curve(int ggc, double *spx, double *spy, int spnum, int spcond) { double spz[CURVE_POINTS_MAX], spc[6][CURVE_POINTS_MAX], spc2[6]; int j, k; for (j = 0; j < CURVE_POINTS_MAX; j++) { spz[j] = j; } spline(spz, spx, spc[0], spc[1], spc[2], spnum, spcond, spcond, 0, 0); spline(spz, spy, spc[3], spc[4], spc[5], spnum, spcond, spcond, 0, 0); GRAcurvefirst(ggc, 0, NULL, NULL, NULL, splinedif, splineint, NULL, spx[0], spy[0]); for (j = 0; j < spnum - 1; j++) { for (k = 0; k < 6; k++) { spc2[k] = spc[k][j]; } if (!GRAcurve(ggc, spc2, spx[j], spy[j])) break; } } static GdkPixbuf * draw_type_pixbuf(struct objlist *obj, int i) { int ggc, fr, fg, fb, fr2, fg2, fb2, type, w, width = 40, height = 20, poly[14], marktype, intp, spcond, spnum, lockstate, found, output; double spx[CURVE_POINTS_MAX], spy[CURVE_POINTS_MAX]; cairo_surface_t *pix; GdkPixbuf *pixbuf; struct objlist *gobj, *robj; N_VALUE *inst; struct gra2cairo_local *local; lockstate = Globallock; Globallock = TRUE; found = find_gra2gdk_inst(&gobj, &inst, &robj, &output, &local); if (! found) { return NULL; } pix = gra2gdk_create_pixmap(local, width, height, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); if (pix == NULL) { return NULL; } getobj(obj, "type", i, 0, NULL, &type); getobj(obj, "R", i, 0, NULL, &fr); getobj(obj, "G", i, 0, NULL, &fg); getobj(obj, "B", i, 0, NULL, &fb); getobj(obj, "R2", i, 0, NULL, &fr2); getobj(obj, "G2", i, 0, NULL, &fg2); getobj(obj, "B2", i, 0, NULL, &fb2); ggc = _GRAopen("gra2gdk", "_output", robj, inst, output, -1, -1, -1, NULL, local); if (ggc < 0) { _GRAclose(ggc); g_object_unref(G_OBJECT(pix)); return NULL; } GRAview(ggc, 0, 0, width, height, 0); GRAcolor(ggc, fr, fg, fb, 255); set_line_style(obj, i, ggc); switch (type) { case PLOT_TYPE_MARK: getobj(obj, "mark_type", i, 0, NULL, &marktype); GRAmark(ggc, marktype, width / 2, height / 2, height - 2, fr, fg, fb, 255, fr2, fg2, fb2, 255); break; case PLOT_TYPE_LINE: GRAline(ggc, 1, height / 2, width - 1, height / 2); break; case PLOT_TYPE_POLYGON: case PLOT_TYPE_POLYGON_SOLID_FILL: poly[0] = 1; poly[1] = height / 2; poly[2] = width / 4; poly[3] = 1; poly[4] = width * 3 / 4; poly[5] = height - 1; poly[6] = width - 1; poly[7] = height / 2; poly[8] = width * 3 / 4; poly[9] = 1; poly[10] = width / 4; poly[11] = height - 1; poly[12] = 1; poly[13] = height / 2; GRAdrawpoly(ggc, 7, poly, (type == PLOT_TYPE_POLYGON) ? GRA_FILL_MODE_NONE : GRA_FILL_MODE_WINDING); break; case PLOT_TYPE_CURVE: getobj(obj, "interpolation", i, 0, NULL, &intp); w = (intp >= 2) ? height : width; spx[0] = 1; spx[1] = w / 3 + 1; spx[2] = w * 2 / 3; spx[3] = w - 1; spx[4] = w * 2 / 3; spx[5] = w / 3 + 1; spx[6] = 1; spy[0] = height / 2; spy[1] = 1; spy[2] = height - 1; spy[3] = height / 2; spy[4] = 1; spy[5] = height - 1; spy[6] = height / 2; if ((intp == 0) || (intp == 2)) { spcond = SPLCND2NDDIF; spnum = 4; } else { spcond = SPLCNDPERIODIC; spnum = 7; } draw_curve(ggc, spx, spy, spnum, spcond); if (intp >= 2) { GRAmoveto(ggc, height, height * 3 / 4); GRAtextstyle(ggc, "Serif", GRA_FONT_STYLE_NORMAL, 52, 0, 0); GRAouttext(ggc, "B"); } break; case PLOT_TYPE_DIAGONAL: GRAline(ggc, 1, height - 1, width - 1, 1); break; case PLOT_TYPE_ARROW: spx[0] = 1; spy[0] = height - 1; spx[1] = width - 1; spy[1] = 1; GRAline(ggc, 1, height - 1, width - 1, 1); poly[0] = width - 8; poly[1] = 1; poly[2] = width - 1; poly[3] = 1; poly[4] = width - 5; poly[5] = 6; GRAdrawpoly(ggc, 3, poly, GRA_FILL_MODE_EVEN_ODD); break; case PLOT_TYPE_RECTANGLE: GRArectangle(ggc, 1, height - 1, width - 1, 1, 0); break; case PLOT_TYPE_RECTANGLE_FILL: GRAcolor(ggc, fr2, fg2, fb2, 255); GRArectangle(ggc, 1, height - 1, width - 1, 1, 1); GRAcolor(ggc, fr, fg, fb, 255); GRArectangle(ggc, 1, height - 1, width - 1, 1, 0); break; case PLOT_TYPE_RECTANGLE_SOLID_FILL: GRArectangle(ggc, 1, height - 1, width - 1, 1, 1); break; case PLOT_TYPE_ERRORBAR_X: GRAline(ggc, 1, height / 2, width - 1, height / 2); GRAline(ggc, 1, height / 4, 1, height * 3 / 4); GRAline(ggc, width - 1, height / 4, width - 1, height * 3 / 4); break; case PLOT_TYPE_ERRORBAR_Y: GRAline(ggc, width / 2, 1, width / 2, height - 1); GRAline(ggc, width * 3 / 8, 1, width * 5 / 8, 1); GRAline(ggc, width * 3 / 8, height -1, width * 5 / 8, height - 1); break; case PLOT_TYPE_STAIRCASE_X: GRAmoveto(ggc, 1, height - 1); GRAlineto(ggc, width / 4, height - 1); GRAlineto(ggc, width / 4, height / 2); GRAlineto(ggc, width * 3 / 4, height / 2); GRAlineto(ggc, width * 3 / 4, 1); GRAlineto(ggc, width - 1, 1); break; case PLOT_TYPE_STAIRCASE_Y: GRAmoveto(ggc, 1, height - 1); GRAlineto(ggc, 1, height / 2 + 1); GRAlineto(ggc, width / 2, height / 2 + 1); GRAlineto(ggc, width / 2, height / 4); GRAlineto(ggc, width - 1, height / 4); GRAlineto(ggc, width - 1, 1); break; case PLOT_TYPE_BAR_X: GRArectangle(ggc, 1, height / 4, width - 1, height * 3 / 4, 0); break; case PLOT_TYPE_BAR_Y: GRArectangle(ggc, width * 3 / 8, 1, width * 5 / 8, height - 1, 0); break; case PLOT_TYPE_BAR_FILL_X: GRAcolor(ggc, fr2, fg2, fb2, 255); GRArectangle(ggc, 1, height / 4, width - 1, height * 3 / 4, 1); GRAcolor(ggc, fr, fg, fb, 255); GRArectangle(ggc, 1, height / 4, width - 1, height * 3 / 4, 0); break; case PLOT_TYPE_BAR_FILL_Y: GRAcolor(ggc, fr2, fg2, fb2, 255); GRArectangle(ggc, width * 3 / 8, 1, width * 5 / 8, height - 1, 1); GRAcolor(ggc, fr, fg, fb, 255); GRArectangle(ggc, width * 3 / 8, 1, width * 5 / 8, height - 1, 0); break; case PLOT_TYPE_BAR_SOLID_FILL_X: GRArectangle(ggc, 1, height / 4, width - 1, height * 3 / 4, 1); break; case PLOT_TYPE_BAR_SOLID_FILL_Y: GRArectangle(ggc, width * 3 / 8, 1, width * 5 / 8, height - 1, 1); break; case PLOT_TYPE_FIT: spx[0] = width * 3 / 6 - 1; spx[1] = width * 4 / 6 - 1; spx[2] = width * 5 / 6 - 1; spx[3] = width - 1; spy[0] = height - 1; spy[1] = height / 3; spy[2] = height * 2 / 3; spy[3] = 1; draw_curve(ggc, spx, spy, 4, SPLCND2NDDIF); GRAmoveto(ggc, 1, height * 3 / 4); GRAtextstyle(ggc, "Serif", GRA_FONT_STYLE_NORMAL, 52, 0, 0); GRAouttext(ggc, "fit"); break; } _GRAclose(ggc); gra2cairo_draw_path(local); pixbuf = gdk_pixbuf_get_from_surface(pix, 0, 0, width, height); cairo_surface_destroy(pix); Globallock = lockstate; return pixbuf; } static char * get_axis_obj_str(struct objlist *obj, int id, char *field) { char *tmp, *valstr; int j; sgetobjfield(obj, id, field, NULL, &valstr, FALSE, FALSE, FALSE); if (valstr == NULL) { return NULL; } for (j = 0; (valstr[j] != '\0') && (valstr[j] != ':'); j++); if (valstr[j] == ':') j++; tmp = g_strdup(valstr + j); g_free(valstr); return tmp; } const char * get_plot_info_str(struct objlist *obj, int id, int src) { char *str; str = NULL; switch (src) { case DATA_SOURCE_FILE: getobj(obj, "file", id, 0, NULL, &str); break; case DATA_SOURCE_RANGE: getobj(obj, "math_y", id, 0, NULL, &str); if (str == NULL) { getobj(obj, "math_x", id, 0, NULL, &str); if (str == NULL) { str = "X"; } } break; case DATA_SOURCE_ARRAY: getobj(obj, "array", id, 0, NULL, &str); break; } return str; } static void file_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx, style; unsigned int i; char buf[256]; struct narray *mask, *move; char *bfile, *axis; GdkPixbuf *pixbuf = NULL; int src; const char *str; getobj(d->obj, "source", row, 0, NULL, &src); list_store_set_int(GTK_WIDGET(d->text), iter, FILE_WIN_COL_NOT_RANGE, src != DATA_SOURCE_RANGE); list_store_set_int(GTK_WIDGET(d->text), iter, FILE_WIN_COL_IS_FILE, src == DATA_SOURCE_FILE); getobj(d->obj, "mask", row, 0, NULL, &mask); getobj(d->obj, "move_data", row, 0, NULL, &move); if ((arraynum(mask) != 0) || (arraynum(move) != 0)) { style = PANGO_STYLE_ITALIC; } else { style = PANGO_STYLE_NORMAL; } list_store_set_int(GTK_WIDGET(d->text), iter, FILE_WIN_COL_MASKED, style); for (i = 0; i < FILE_WIN_COL_NUM; i++) { switch (i) { case FILE_WIN_COL_TIP: str = NULL; str = get_plot_info_str(d->obj, row, src); list_store_set_string(GTK_WIDGET(d->text), iter, i, (str) ? str : ""); break; case FILE_WIN_COL_FILE: str = get_plot_info_str(d->obj, row, src); if (str == NULL) { list_store_set_string(GTK_WIDGET(d->text), iter, i, "...................."); } else { if (src == DATA_SOURCE_FILE) { bfile = getbasename(str); if (bfile) { list_store_set_string(GTK_WIDGET(d->text), iter, i, bfile); g_free(bfile); } else { list_store_set_string(GTK_WIDGET(d->text), iter, i, "...................."); } } else { set_escaped_str(GTK_WIDGET(d->text), iter, i, str); } } break; case FILE_WIN_COL_TYPE: pixbuf = draw_type_pixbuf(d->obj, row); if (pixbuf) { list_store_set_pixbuf(GTK_WIDGET(d->text), iter, i, pixbuf); g_object_unref(pixbuf); } break; case FILE_WIN_COL_X_AXIS: case FILE_WIN_COL_Y_AXIS: axis = get_axis_obj_str(d->obj, row, Flist[i].name); if (axis) { snprintf(buf, sizeof(buf), "%3s", axis); list_store_set_string(GTK_WIDGET(d->text), iter, i, buf); g_free(axis); } break; case FILE_WIN_COL_HIDDEN: getobj(d->obj, Flist[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_val(GTK_WIDGET(d->text), iter, i, Flist[i].type, &cx); break; case FILE_WIN_COL_MASKED: case FILE_WIN_COL_NOT_RANGE: case FILE_WIN_COL_IS_FILE: break; default: if (Flist[i].type == G_TYPE_DOUBLE) { getobj(d->obj, Flist[i].name, row, 0, NULL, &cx); list_store_set_double(GTK_WIDGET(d->text), iter, i, cx / 100.0); } else { getobj(d->obj, Flist[i].name, row, 0, NULL, &cx); list_store_set_val(GTK_WIDGET(d->text), iter, i, Flist[i].type, &cx); } } } } void CmFileMath(void *w, gpointer client_data) { struct objlist *obj; int undo; if (Menulock || Globallock) return; obj = chkobject("data"); if (chkobjlastinst(obj) < 0) return; undo = menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); MathDialog(&DlgMath, obj); DialogExecute(TopLevel, &DlgMath); if (DlgMath.modified) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, DRAW_REDRAW); } else { menu_delete_undo(undo); } } static int GetDrawFiles(struct narray *farray) { struct objlist *fobj; int lastinst; struct narray ifarray; int i, a; if (farray == NULL) return 1; fobj = chkobject("data"); if (fobj == NULL) return 1; lastinst = chkobjlastinst(fobj); if (lastinst < 0) return 1; arrayinit(&ifarray, sizeof(int)); for (i = 0; i <= lastinst; i++) { getobj(fobj, "hidden", i, 0, NULL, &a); if (!a) arrayadd(&ifarray, &i); } SelectDialog(&DlgSelect, fobj, NULL, FileCB, farray, &ifarray); if (DialogExecute(TopLevel, &DlgSelect) != IDOK) { arraydel(&ifarray); arraydel(farray); return 1; } arraydel(&ifarray); return 0; } void CmFileSaveData(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i, num, onum, type, div, curve = FALSE, *array, append; char *file, buf[1024]; char *argv[4]; if (Menulock || Globallock) return; if (GetDrawFiles(&farray)) return; obj = chkobject("data"); if (obj == NULL) return; onum = chkobjlastinst(obj); num = arraynum(&farray); if (num == 0) { arraydel(&farray); return; } array = arraydata(&farray); for (i = 0; i < num; i++) { if (array[i] < 0 || array[i] > onum) continue; getobj(obj, "type", array[i], 0, NULL, &type); if (type == 3) { curve = TRUE; } } div = 10; if (curve) { OutputDataDialog(&DlgOutputData, div); if (DialogExecute(TopLevel, &DlgOutputData) != IDOK) { arraydel(&farray); return; } div = DlgOutputData.div; } if (nGetSaveFileName(TopLevel, _("Data file"), NULL, NULL, NULL, &file, FALSE, Menulocal.changedirectory) != IDOK) { arraydel(&farray); return; } ProgressDialogCreate(_("Making data file")); SetStatusBar(_("Making data file.")); argv[0] = (char *) file; argv[1] = (char *) ÷ argv[3] = NULL; for (i = 0; i < num; i++) { if (array[i] < 0 || array[i] > onum) continue; snprintf(buf, sizeof(buf), "%d/%d", i, num); set_progress(1, buf, 1.0 * (i + 1) / num); append = (i == 0) ? FALSE : TRUE; argv[2] = (char *) &append; if (exeobj(obj, "output_file", array[i], 3, argv)) break; } ProgressDialogFinalize(); ResetStatusBar(); main_window_redraw(); arraydel(&farray); g_free(file); } static gboolean filewin_ev_key_down(GtkWidget *w, GdkEvent *event, gpointer user_data) { struct obj_list_data *d; GdkEventKey *e; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); if (Menulock || Globallock) return TRUE; d = (struct obj_list_data *) user_data; e = (GdkEventKey *)event; switch (e->keyval) { case GDK_KEY_Delete: FileWinFileDelete(d); UnFocus(); break; case GDK_KEY_Return: if (e->state & GDK_SHIFT_MASK) { return FALSE; } FileWinFileUpdate(d); UnFocus(); break; case GDK_KEY_Insert: if (e->state & GDK_SHIFT_MASK) { FileWinFileCopy2(d); } else { FileWinFileCopy(d); } UnFocus(); break; case GDK_KEY_space: if (e->state & GDK_CONTROL_MASK) return FALSE; FileWinFileDraw(d); UnFocus(); break; case GDK_KEY_f: if (e->state & GDK_CONTROL_MASK) { FileWinFit(d); UnFocus(); } break; default: return FALSE; } return TRUE; } static void popup_show_cb(GtkWidget *widget, gpointer user_data) { int sel, num, source; unsigned int i; struct obj_list_data *d; d = (struct obj_list_data *) user_data; sel = d->select; num = chkobjlastinst(d->obj); for (i = 1; i < POPUP_ITEM_NUM; i++) { switch (i) { case POPUP_ITEM_TOP: case POPUP_ITEM_UP: gtk_widget_set_sensitive(d->popup_item[i], sel > 0 && sel <= num); break; case POPUP_ITEM_DOWN: case POPUP_ITEM_BOTTOM: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel < num); break; case POPUP_ITEM_EDIT: if (sel >= 0 && sel <= num) { getobj(d->obj, "source", sel, 0, NULL, &source); gtk_widget_set_sensitive(d->popup_item[i], source == DATA_SOURCE_FILE); } else { gtk_widget_set_sensitive(d->popup_item[i], FALSE); } break; default: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel <= num); } } } enum FILE_COMBO_ITEM { FILE_COMBO_ITEM_COLOR_1, FILE_COMBO_ITEM_COLOR_2, FILE_COMBO_ITEM_TYPE, FILE_COMBO_ITEM_MARK, FILE_COMBO_ITEM_INTP, FILE_COMBO_ITEM_LINESTYLE, FILE_COMBO_ITEM_JOIN, FILE_COMBO_ITEM_FIT, FILE_COMBO_ITEM_CLIP, }; static void add_fit_combo_item_to_cbox(GtkTreeStore *list, struct objlist *obj, int id) { char *valstr, buf[1024]; int i; sgetobjfield(obj, id, "fit", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr == NULL) { return; } for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') { i++; } if (valstr[i]) { snprintf(buf, sizeof(buf), "Fit:%s", valstr + i); } else { snprintf(buf, sizeof(buf), "Fit:%s", _("Create")); } g_free(valstr); add_text_combo_item_to_cbox(list, NULL, NULL, FILE_COMBO_ITEM_FIT, -1, buf, TOGGLE_NONE, FALSE); } static void create_type_color_combo_box(GtkWidget *cbox, struct objlist *obj, int type, int id) { int count; GtkTreeStore *list; GtkTreeIter parent; count = combo_box_get_num(cbox); if (count > 0) { return; } list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); create_type_combo_item(list, obj, id); switch (type) { case PLOT_TYPE_MARK: case PLOT_TYPE_LINE: case PLOT_TYPE_POLYGON: case PLOT_TYPE_CURVE: case PLOT_TYPE_DIAGONAL: case PLOT_TYPE_ARROW: case PLOT_TYPE_RECTANGLE: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_ERRORBAR_X: case PLOT_TYPE_ERRORBAR_Y: case PLOT_TYPE_STAIRCASE_X: case PLOT_TYPE_STAIRCASE_Y: case PLOT_TYPE_BAR_X: case PLOT_TYPE_BAR_Y: case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_FILL_Y: case PLOT_TYPE_FIT: add_line_style_item_to_cbox(list, NULL, FILE_COMBO_ITEM_LINESTYLE, obj, "line_style", id); break; } switch (type) { case PLOT_TYPE_LINE: case PLOT_TYPE_POLYGON: case PLOT_TYPE_CURVE: case PLOT_TYPE_STAIRCASE_X: case PLOT_TYPE_STAIRCASE_Y: case PLOT_TYPE_FIT: add_text_combo_item_to_cbox(list, &parent, NULL, -1, -1, _("Join"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &parent, FILE_COMBO_ITEM_JOIN, obj, "line_join", id); break; } add_text_combo_item_to_cbox(list, NULL, NULL, FILE_COMBO_ITEM_COLOR_1, -1, _("Color 1"), TOGGLE_NONE, FALSE); switch (type) { case PLOT_TYPE_MARK: case PLOT_TYPE_RECTANGLE_FILL: case PLOT_TYPE_BAR_FILL_X: case PLOT_TYPE_BAR_FILL_Y: add_text_combo_item_to_cbox(list, NULL, NULL, FILE_COMBO_ITEM_COLOR_2, -1, _("Color 2"), TOGGLE_NONE, FALSE); break; } if (type == PLOT_TYPE_FIT) { add_fit_combo_item_to_cbox(list, obj, id); } add_bool_combo_item_to_cbox(list, NULL, NULL, FILE_COMBO_ITEM_CLIP, obj, "data_clip", id, _("Clip")); } static void create_type_combo_item(GtkTreeStore *list, struct objlist *obj, int id) { char **enumlist; int i, type; GtkTreeIter parent, iter; gtk_tree_store_append(list, &parent, NULL); gtk_tree_store_set(list, &parent, OBJECT_COLUMN_TYPE_STRING, _("Type"), OBJECT_COLUMN_TYPE_PIXBUF, NULL, OBJECT_COLUMN_TYPE_INT, FILE_COMBO_ITEM_TYPE, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, FALSE, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, FALSE, -1); enumlist = (char **) chkobjarglist(obj, "type"); type = -1; getobj(obj, "type", id, 0, NULL, &type); for (i = 0; enumlist[i] && enumlist[i][0]; i++) { add_text_combo_item_to_cbox(list, &iter, &parent, FILE_COMBO_ITEM_TYPE, i, _(enumlist[i]), TOGGLE_RADIO, type == i); if (strcmp(enumlist[i], "mark") == 0) { add_mark_combo_item_to_cbox(list, NULL, &iter, FILE_COMBO_ITEM_MARK, obj, "mark_type", id); } else if (strcmp(enumlist[i], "curve") == 0) { add_enum_combo_item_to_cbox(list, NULL, &iter, FILE_COMBO_ITEM_INTP, obj, "interpolation", id); } } } static void select_type(GtkComboBox *w, gpointer user_data) { int sel, col_type, type, mark_type, curve_type, enum_id, found, active, join, ret, undo; struct objlist *obj; struct obj_list_data *d; GtkTreeStore *list; GtkTreeIter iter; menu_lock(FALSE); d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) return; obj = getobject("data"); getobj(obj, "type", sel, 0, NULL, &type); list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(w))); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) return; gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &col_type, OBJECT_COLUMN_TYPE_ENUM, &enum_id, -1); switch (col_type) { case FILE_COMBO_ITEM_COLOR_1: if (select_obj_color(obj, sel, OBJ_FIELD_COLOR_TYPE_1)) { return; } break; case FILE_COMBO_ITEM_COLOR_2: if (select_obj_color(obj, sel, OBJ_FIELD_COLOR_TYPE_2)) { return; } break; case FILE_COMBO_ITEM_TYPE: if (enum_id == type) { return; } undo = menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(obj, "type", sel, &enum_id); if (enum_id == PLOT_TYPE_FIT) { char *fit; int ret; getobj(obj, "fit", sel, 0, NULL, &fit); if (fit == NULL) { ret = show_fit_dialog(obj, sel, TopLevel); if (ret != IDOK) { menu_delete_undo(undo); putobj(obj, "type", sel, &type); return; } } } break; case FILE_COMBO_ITEM_MARK: getobj(obj, "mark_type", sel, 0, NULL, &mark_type); if (type == PLOT_TYPE_MARK && enum_id == mark_type) return; menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(obj, "mark_type", sel, &enum_id); type = PLOT_TYPE_MARK; putobj(obj, "type", sel, &type); break; case FILE_COMBO_ITEM_INTP: getobj(obj, "interpolation", sel, 0, NULL, &curve_type); if (type == PLOT_TYPE_CURVE && enum_id == curve_type) return; menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(obj, "interpolation", sel, &enum_id); type = PLOT_TYPE_CURVE; putobj(obj, "type", sel, &type); break; case FILE_COMBO_ITEM_LINESTYLE: if (enum_id < 0 || enum_id >= FwNumStyleNum) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); if (chk_sputobjfield(d->obj, sel, "line_style", FwLineStyle[enum_id].list) != 0) { return; } if (! get_graph_modified()) { return; } break; case FILE_COMBO_ITEM_FIT: undo = data_save_undo(UNDO_TYPE_EDIT); ret = show_fit_dialog(obj, sel, TopLevel); if (ret != IDOK) { menu_delete_undo(undo); return; } break; case FILE_COMBO_ITEM_JOIN: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_ENUM, &enum_id, -1); getobj(d->obj, "line_join", sel, 0, NULL, &join); if (join == enum_id) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(d->obj, "line_join", sel, &enum_id); break; case FILE_COMBO_ITEM_CLIP: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); active = ! active; menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(d->obj, "data_clip", sel, &active); break; default: return; } d->select = sel; d->update(d, FALSE, DRAW_REDRAW); set_graph_modified(); } static void start_editing_type(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { GtkTreeIter iter; struct obj_list_data *d; GtkComboBox *cbox; int sel, type; struct objlist *obj; menu_lock(TRUE); d = (struct obj_list_data *) user_data; sel = tree_view_get_selected_row_int_from_path(d->text, path_str, &iter, FILE_WIN_COL_ID); if (sel < 0) { return; } cbox = GTK_COMBO_BOX(editable); g_object_set_data(G_OBJECT(cbox), "user-data", GINT_TO_POINTER(sel)); obj = getobject("data"); if (obj == NULL) return; getobj(obj, "type", sel, 0, NULL, &type); create_type_color_combo_box(GTK_WIDGET(cbox), obj, type, sel); g_signal_connect(cbox, "editing-done", G_CALLBACK(select_type), d); gtk_widget_show(GTK_WIDGET(cbox)); return; } static void select_axis(GtkComboBox *w, gpointer user_data, char *axis) { GtkTreeStore *list; GtkTreeIter iter; char buf[64]; int j, sel, found; struct obj_list_data *d; sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) return; d = (struct obj_list_data *) user_data; list = GTK_TREE_STORE(gtk_combo_box_get_model(w)); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) return; gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &j, -1); if (j < 0) return; data_save_undo(UNDO_TYPE_EDIT); snprintf(buf, sizeof(buf), "axis:%d", j); if (sputobjfield(d->obj, sel, axis, buf) == 0) { d->select = sel; } } static void select_axis_x(GtkComboBox *w, gpointer user_data) { select_axis(w, user_data, "axis_x"); } static void select_axis_y(GtkComboBox *w, gpointer user_data) { select_axis(w, user_data, "axis_y"); } static void start_editing(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data, int axis) { GtkTreeIter iter; GtkTreeStore *list; struct obj_list_data *d; GtkComboBox *cbox; int lastinst, j, sel, id = 0, is_oid; struct objlist *aobj; char *name, *ptr; menu_lock(TRUE); d = (struct obj_list_data *) user_data; sel = tree_view_get_selected_row_int_from_path(d->text, path, &iter, FILE_WIN_COL_ID); if (sel < 0) { return; } cbox = GTK_COMBO_BOX(editable); g_object_set_data(G_OBJECT(cbox), "user-data", GINT_TO_POINTER(sel)); init_object_combo_box(GTK_WIDGET(editable)); list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(editable))); gtk_tree_store_clear(list); aobj = getobject("axis"); name = get_axis_obj_str(d->obj, sel, (axis == AXIS_X) ? "axis_x" : "axis_y"); if (name) { is_oid = (name[0] == '^'); id = strtol(name + is_oid, &ptr, 10); if (*ptr == '\0') { if (is_oid) { id = chkobjoid(aobj, id); } } g_free(name); } lastinst = chkobjlastinst(aobj); for (j = 0; j <= lastinst; j++) { getobj(aobj, "group", j, 0, NULL, &name); name = CHK_STR(name); add_text_combo_item_to_cbox(list, &iter, NULL, j, -1, name, TOGGLE_NONE, FALSE); if (j == id) { gtk_combo_box_set_active_iter(cbox, &iter); } } d->select = -1; g_signal_connect(cbox, "changed", G_CALLBACK((axis == AXIS_X) ? select_axis_x : select_axis_y), d); } static void start_editing_x(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data) { start_editing(renderer, editable, path, user_data, AXIS_X); } static void start_editing_y(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data) { start_editing(renderer, editable, path, user_data, AXIS_Y); } static void edited_axis(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data, char *axis) { struct obj_list_data *d; menu_lock(FALSE); d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); if (str == NULL || d->select < 0) return; d->update(d, FALSE, DRAW_REDRAW); set_graph_modified(); } static void drag_drop_cb(GtkWidget *w, GdkDragContext *context, gint x, gint y, GtkSelectionData *data, guint info, guint time, gpointer user_data) { gchar **filenames; int num; switch (info) { case DROP_TYPE_FILE: filenames = gtk_selection_data_get_uris(data); num = g_strv_length(filenames); data_dropped(filenames, num, FILE_TYPE_DATA); g_strfreev(filenames); gtk_drag_finish(context, TRUE, FALSE, time); break; } } static void init_dnd(struct SubWin *d) { GtkWidget *widget; GtkTargetEntry target[] = { {"text/uri-list", 0, DROP_TYPE_FILE}, }; widget = d->data.data->text; gtk_drag_dest_set(widget, GTK_DEST_DEFAULT_ALL, target, sizeof(target) / sizeof(*target), GDK_ACTION_COPY); g_signal_connect(widget, "drag-data-received", G_CALLBACK(drag_drop_cb), NULL); } GtkWidget * dreate_data_list(struct SubWin *d) { int n; int noexpand_colmns[] = {FILE_WIN_COL_X, FILE_WIN_COL_Y, FILE_WIN_COL_X_AXIS, FILE_WIN_COL_Y_AXIS, FILE_WIN_COL_TYPE, FILE_WIN_COL_SIZE, FILE_WIN_COL_WIDTH, FILE_WIN_COL_SKIP, FILE_WIN_COL_STEP, FILE_WIN_COL_FINAL, FILE_WIN_COL_DNUM}; if (d->Win) { return d->Win; } list_sub_window_create(d, FILE_WIN_COL_NUM, Flist); d->data.data->update = FileWinUpdate; d->data.data->setup_dialog = FileDialog; d->data.data->dialog = &DlgFile; d->data.data->ev_key = filewin_ev_key_down; d->data.data->delete = delete_file_obj; d->data.data->undo_save = data_save_undo; d->data.data->obj = chkobject("data"); sub_win_create_popup_menu(d->data.data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_combo_cell_renderer_cb(d->data.data, FILE_WIN_COL_X_AXIS, Flist, G_CALLBACK(start_editing_x), G_CALLBACK(edited_axis)); set_combo_cell_renderer_cb(d->data.data, FILE_WIN_COL_Y_AXIS, Flist, G_CALLBACK(start_editing_y), G_CALLBACK(edited_axis)); set_obj_cell_renderer_cb(d->data.data, FILE_WIN_COL_TYPE, Flist, G_CALLBACK(start_editing_type)); init_dnd(d); gtk_tree_view_set_enable_search(GTK_TREE_VIEW(d->data.data->text), TRUE); gtk_tree_view_set_search_column(GTK_TREE_VIEW(d->data.data->text), FILE_WIN_COL_FILE); tree_view_set_tooltip_column(GTK_TREE_VIEW(d->data.data->text), FILE_WIN_COL_TIP); n = sizeof(noexpand_colmns) / sizeof(*noexpand_colmns); tree_view_set_no_expand_column(d->data.data->text, noexpand_colmns, n); set_cell_attribute_source(d, "style", FILE_WIN_COL_FILE, FILE_WIN_COL_MASKED); set_cell_attribute_source(d, "visible", FILE_WIN_COL_X, FILE_WIN_COL_NOT_RANGE); set_cell_attribute_source(d, "visible", FILE_WIN_COL_Y, FILE_WIN_COL_NOT_RANGE); set_cell_attribute_source(d, "editable", FILE_WIN_COL_FILE, FILE_WIN_COL_IS_FILE); return d->Win; } ngraph-gtk-6.08.00/src/gtk/ogra2cairofile.h0000644000175000017500000000063613070106167015273 00000000000000#ifndef _O_GRA2CAIROFILE_HEADER #define _O_GRA2CAIROFILE_HEADER #include #include #include #include enum surface_type_id { TYPE_PS2, TYPE_PS3, TYPE_EPS2, TYPE_EPS3, TYPE_PDF, TYPE_SVG1_1, TYPE_SVG1_2, TYPE_PNG, #ifdef CAIRO_HAS_WIN32_SURFACE TYPE_EMF, TYPE_CLIPBOARD, #endif /* CAIRO_HAS_WIN32_SURFACE */ }; #endif ngraph-gtk-6.08.00/src/gtk/x11bitmp.h0000644000175000017500000000525713351432267014061 00000000000000/* * $Id: x11bitmp.h,v 1.5 2009-01-07 02:39:34 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include "ioutil.h" #include "dir_defs.h" #define NGRAPH_ICON_PATH RESOURCE_PATH "/pixmaps" #define NGRAPH_ALIGN_B_ICON "ngraph_align_b" #define NGRAPH_ALIGN_HC_ICON "ngraph_align_hc" #define NGRAPH_ALIGN_L_ICON "ngraph_align_l" #define NGRAPH_ALIGN_R_ICON "ngraph_align_r" #define NGRAPH_ALIGN_T_ICON "ngraph_align_t" #define NGRAPH_ALIGN_VC_ICON "ngraph_align_vc" #define NGRAPH_MATH_ICON "ngraph_math" #define NGRAPH_UNDO_ICON "ngraph_undo" #define NGRAPH_SVG_ICON_FILE RESOURCE_PATH "/pixmaps/ngraph.svg" #define NGRAPH_ICON_FILE RESOURCE_PATH "/pixmaps/ngraph_icon.png" #define NGRAPH_ICON64_FILE RESOURCE_PATH "/pixmaps/ngraph_icon64.png" #define NGRAPH_DRAW_ICON "ngraph_draw-symbolic" #define NGRAPH_POINT_ICON "ngraph_point-symbolic" #define NGRAPH_LEGENDPOINT_ICON "ngraph_legendpoint-symbolic" #define NGRAPH_AXISPOINT_ICON "ngraph_axispoint-symbolic" #define NGRAPH_DATAPOINT_ICON "ngraph_datapoint-symbolic" #define NGRAPH_TEXT_ICON "ngraph_text-symbolic" #define NGRAPH_ARC_ICON "ngraph_arc-symbolic" #define NGRAPH_GAUSS_ICON "ngraph_gauss-symbolic" #define NGRAPH_LINE_ICON "ngraph_line-symbolic" #define NGRAPH_MARK_ICON "ngraph_mark-symbolic" #define NGRAPH_RECT_ICON "ngraph_rect-symbolic" #define NGRAPH_CROSS_ICON "ngraph_cross-symbolic" #define NGRAPH_FRAME_ICON "ngraph_frame-symbolic" #define NGRAPH_SECTION_ICON "ngraph_section-symbolic" #define NGRAPH_SINGLE_ICON "ngraph_single-symbolic" #define NGRAPH_SCALE_ICON "ngraph_scale-symbolic" #define NGRAPH_TRIMMING_ICON "ngraph_trimming-symbolic" #define NGRAPH_EVAL_ICON "ngraph_eval-symbolic" #define NGRAPH_ZOOM_ICON "ngraph_zoom-symbolic" #define NGRAPH_AXISWIN_ICON "ngraph_axiswin-symbolic" #define NGRAPH_FILEWIN_ICON "ngraph_filewin-symbolic" #define NGRAPH_MERGEWIN_ICON "ngraph_mergewin-symbolic" ngraph-gtk-6.08.00/src/gtk/x11print.h0000644000175000017500000000231713070106167014067 00000000000000/* * $Id: x11print.h,v 1.7 2008-09-12 09:12:08 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #define PRINT_SHOW_DIALOG_NONE 0 #define PRINT_SHOW_DIALOG_PREVIEW 1 #define PRINT_SHOW_DIALOG_DIALOG 2 void CmOutputPrinter(int select_file, int show_dialog); void CmOutputMenu(void *w, gpointer client_data); void CmOutputViewerB(void *w, gpointer client_data); void CmOutputPrinterB(void *wi, gpointer client_data); ngraph-gtk-6.08.00/src/gtk/x11view.c0000644000175000017500000043076713356643434013730 00000000000000/* -*- coding: utf-8 -*- */ /* * $Id: x11view.c,v 1.186 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include "object.h" #include "gra.h" #include "odata.h" #include "olegend.h" #include "oarc.h" #include "opath.h" #include "mathfn.h" #include "ioutil.h" #include "nstring.h" #include "shell.h" #include "gtk_liststore.h" #include "gtk_widget.h" #include "gtk_ruler.h" #include "gtk_presettings.h" #include "strconv.h" #include "x11gui.h" #include "x11dialg.h" #include "ogra2cairo.h" #include "ox11menu.h" #include "x11menu.h" #include "x11graph.h" #include "x11file.h" #include "x11axis.h" #include "x11info.h" #include "x11cood.h" #include "x11lgnd.h" #include "x11view.h" #include "x11commn.h" #include "x11merge.h" #define SCROLL_INC 20 #define POINT_ERROR 4 #define ZOOM_SPEED_NORMAL 1.4 #define ZOOM_SPEED_LITTLE 1.1 enum object_move_type { OBJECT_MOVE_TYPE_TOP, OBJECT_MOVE_TYPE_UP, OBJECT_MOVE_TYPE_DOWN, OBJECT_MOVE_TYPE_LAST, }; #define Button1 1 #define Button2 2 #define Button3 3 #define Button4 4 #define Button5 5 enum EvalDialogColType { EVAL_DIALOG_COL_TYPE_ID, EVAL_DIALOG_COL_TYPE_LN, EVAL_DIALOG_COL_TYPE_X, EVAL_DIALOG_COL_TYPE_Y, EVAL_DIALOG_COL_TYPE_N, }; enum ViewerAlignType { VIEW_ALIGN_LEFT, VIEW_ALIGN_RIGHT, VIEW_ALIGN_HCENTER, VIEW_ALIGN_TOP, VIEW_ALIGN_VCENTER, VIEW_ALIGN_BOTTOM, }; #define POINT_LENGTH 5 #define FOCUS_FRAME_OFST 5 #define FOCUS_RECT_SIZE 6 static cairo_region_t *region = NULL; static int PaintLock = FALSE, ZoomLock = FALSE, KeepMouseMode = FALSE; #define EVAL_NUM_MAX 5000 static struct evaltype EvalList[EVAL_NUM_MAX]; static struct narray SelList; #define IDEVMASK 101 #define IDEVMOVE 102 static void ViewerEvSize(GtkWidget *w, GtkAllocation *allocation, gpointer client_data); static void ViewerEvHScroll(GtkRange *range, gpointer user_data); static void ViewerEvVScroll(GtkRange *range, gpointer user_data); static gboolean ViewerEvPaint(GtkWidget *w, cairo_t *cr, gpointer client_data); static gboolean ViewerEvLButtonDown(unsigned int state, TPoint *point, struct Viewer *d); static gboolean ViewerEvLButtonUp(unsigned int state, TPoint *point, struct Viewer *d); static gboolean ViewerEvLButtonDblClk(unsigned int state, TPoint *point, struct Viewer *d); static gboolean ViewerEvMouseMove(unsigned int state, TPoint *point, struct Viewer *d); static gboolean ViewerEvButtonDown(GtkWidget *w, GdkEventButton *e, gpointer client_data); static gboolean ViewerEvButtonUp(GtkWidget *w, GdkEventButton *e, gpointer client_data); static gboolean ViewerEvMouseMotion(GtkWidget *w, GdkEventMotion *e, gpointer client_data); static gboolean ViewerEvScroll(GtkWidget *w, GdkEventScroll *e, gpointer client_data); static gboolean ViewerEvKeyDown(GtkWidget *w, GdkEventKey *e, gpointer client_data); static gboolean ViewerEvKeyUp(GtkWidget *w, GdkEventKey *e, gpointer client_data); static void DelList(struct objlist *obj, N_VALUE *inst, const struct Viewer *d); static void ViewUpdate(void); static void ViewCopy(void); static void do_popup(GdkEventButton *event, struct Viewer *d); static int check_focused_obj(struct narray *focusobj, struct objlist *fobj, int oid); static int get_mouse_cursor_type(struct Viewer *d, int x, int y); static void reorder_object(enum object_move_type type); static void SetHRuler(const struct Viewer *d); static void SetVRuler(const struct Viewer *d); static void clear_focus_obj(const struct Viewer *d); static void ViewDelete(void); static int text_dropped(const char *str, gint x, gint y, struct Viewer *d); static int add_focus_obj(struct narray *focusobj, struct objlist *obj, int oid); static void ShowFocusFrame(cairo_t *cr, const struct Viewer *d); static void AddInvalidateRect(struct objlist *obj, N_VALUE *inst); static void AddList(struct objlist *obj, N_VALUE *inst); static void RotateFocusedObj(int direction); static void set_mouse_cursor_hover(struct Viewer *d, int x, int y); static void CheckGrid(int ofs, unsigned int state, int *x, int *y, double *zoom_x, double *zoom_y); static int check_drawrable(struct objlist *obj); #define GRAY 0.5 #define DOT_LENGTH 4.0 int check_paint_lock(void) { return PaintLock; } static int mxd2p(int r) { return nround(r * Menulocal.local->pixel_dot_x); } #if 0 static int mxd2px(int x) { return nround(x * Menulocal.local->pixel_dot_x + Menulocal.local->offsetx); } static int mxd2py(int y) { return nround(y * Menulocal.local->pixel_dot_y + Menulocal.local->offsety); } #endif static int mxp2d(int r) { return ceil(r / Menulocal.local->pixel_dot_x); } static int calc_mouse_x(int x, double zoom, const struct Viewer *d) { return nround((mxp2d(x + d->hscroll - d->cx) - Menulocal.LeftMargin) / zoom); } static int calc_mouse_y(int y, double zoom, const struct Viewer *d) { return nround((mxp2d(y + d->vscroll - d->cy) - Menulocal.TopMargin) / zoom); } static double range_increment(GtkWidget *w, double inc) { double val; val = gtk_range_get_value(GTK_RANGE(w)); gtk_range_set_value(GTK_RANGE(w), val + inc); return val; } static char SCRIPT_IDN[] = "#! ngraph\n# clipboard\n\n"; #define SCRIPT_IDN_LEN (sizeof(SCRIPT_IDN) - 1) static int CopyFocusedObjects(void) { struct narray *focus_array; struct FocusObj **focus; struct objlist *axis; char *s; int i, r, n, id, num; GtkClipboard* clipboard; GString *str; focus_array = NgraphApp.Viewer.focusobj; n = arraynum(focus_array); if (n < 1) return 1; focus = arraydata(focus_array); str = g_string_sized_new(256); if (str == NULL) return 1; axis = chkobject("axis"); g_string_append(str, SCRIPT_IDN); num = 0; for (i = 0; i < n; i++) { if (focus[i]->obj == axis) { g_string_free(str, TRUE); return 1; } id = chkobjoid(focus[i]->obj, focus[i]->oid); if (id < 0) continue; r = getobj(focus[i]->obj, "save", id, 0, NULL, &s); if (r < 0 || s == NULL) { g_string_free(str, TRUE); return 1; } g_string_append(str, s); num++; } if (num > 0) { clipboard = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); gtk_clipboard_set_text(clipboard, str->str, -1); } g_string_free(str, TRUE); return 0; } static int CutFocusedObjects(void) { if (CopyFocusedObjects()) return 1; ViewDelete(); return 0; } static void check_last_insts(struct objlist *parent, struct narray *array) { struct objlist *ocur; int instnum; ocur = parent->child; while (chkobjparent(ocur) == parent) { instnum = chkobjlastinst(ocur); arrayadd(array, &instnum); if (ocur->child) { check_last_insts(ocur, array); } ocur = ocur->next; } return; } static void focus_new_insts(struct objlist *parent, struct narray *array, char **objects) { struct objlist *ocur; int i, instnum, prev_instnum, oid; N_VALUE *inst; ocur = parent->child; while (chkobjparent(ocur) == parent) { instnum = chkobjlastinst(ocur); prev_instnum = arraynget_int(array, 0); arrayndel(array, 0); if (chkobjfield(ocur, "bbox") == 0) { if (instnum != prev_instnum) { *objects = ocur->name; objects++; *objects = NULL; } for (i = prev_instnum + 1; i <= instnum; i++) { getobj(ocur, "oid", i, 0, NULL, &oid); add_focus_obj(NgraphApp.Viewer.focusobj, ocur, oid); inst = chkobjinst(ocur, i); AddList(ocur, inst); AddInvalidateRect(ocur, inst); } } if (ocur->child) { focus_new_insts(ocur, array, objects); } ocur = ocur->next; } return; } static void paste_cb(GtkClipboard *clipboard, const gchar *text, gpointer data) { struct narray idarray; struct objlist *draw_obj; GdkWindow *window; char *objects[OBJ_MAX] = {NULL}; if (text == NULL) return; window = gtk_widget_get_window(NgraphApp.Viewer.Win); if (window == NULL) return; if (strncmp(text, SCRIPT_IDN, SCRIPT_IDN_LEN)) { gint w, h; w = gdk_window_get_width(window); h = gdk_window_get_height(window); text_dropped(text, w / 2, h / 2, &NgraphApp.Viewer); return; } draw_obj = chkobject("draw"); if (draw_obj == NULL) return; arrayinit(&idarray, sizeof(int)); check_last_insts(draw_obj, &idarray); UnFocus(); menu_save_undo(UNDO_TYPE_PASTE, NULL); eval_script(text, TRUE); focus_new_insts(draw_obj, &idarray, objects); arraydel(&idarray); if (arraynum(NgraphApp.Viewer.focusobj) > 0) { set_graph_modified(); NgraphApp.Viewer.allclear = FALSE; NgraphApp.Viewer.ShowFrame = TRUE; gtk_widget_grab_focus(NgraphApp.Viewer.Win); UpdateAll(objects); } } static void PasteObjectsFromClipboard(void) { GtkClipboard *clip; struct Viewer *d; GdkDevice *device; GdkWindow *win; d = &NgraphApp.Viewer; if (d->Win == NULL || (d->Mode != PointB && d->Mode != LegendB)) { return; } clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); if (gtk_clipboard_wait_is_text_available(clip)) { gint x, y; gtk_clipboard_request_text(clip, paste_cb, NULL); device = gtk_get_current_event_device(); /* fix-me: is there any other appropriate way to get the device? */ if (device && gdk_device_get_source(device) != GDK_SOURCE_KEYBOARD) { win = gtk_widget_get_window(d->Win); if (win) { gdk_window_get_device_position(win, device, &x, &y, NULL); set_mouse_cursor_hover(d, x, y); } } } } static int graph_dropped(char *fname) { char *ext; if (fname == NULL) { return 1; } ext = getextention(fname); if (ext == NULL) return 1; if (strcmp0(ext, "ngp")) { return 1; } if (!CheckSave()) { return 0; } LoadNgpFile(fname, FALSE, "-f"); return 0; } static int new_merge_obj(char *name, struct objlist *obj) { int id, ret; id = newobj(obj); if (id < 0) return 1; changefilename(name); putobj(obj, "file", id, name); MergeDialog(NgraphApp.MergeWin.data.data, id, -1); ret = DialogExecute(TopLevel, &DlgMerge); if (ret == IDCANCEL) { delobj(obj, id); } else { set_graph_modified(); } return 0; } static int arc_get_angle(struct objlist *obj, N_VALUE *inst, unsigned int round, int point, int px, int py, int *angle1, int *angle2) { int x, y, rx, ry, a1, a2; double dx, dy, r, angle; if (inst == NULL) return 1; if (point != ARC_POINT_TYPE_ANGLE1 && point != ARC_POINT_TYPE_ANGLE2) return 1; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); _getobj(obj, "rx", inst, &rx); _getobj(obj, "ry", inst, &ry); _getobj(obj, "angle1", inst, &a1); _getobj(obj, "angle2", inst, &a2); if (rx < 1 || ry < 1) return 1; dx = 1.0 * (px - x) / rx; dy = 1.0 * (y - py) / ry; r = sqrt(dx * dx + dy * dy); if (dx == 0 && dy == 0) return 1; if (dx >= 0 && dy >= 0) { if (dx > dy) { angle = acos(dx / r) / MPI * 180; } else { angle = asin(dy / r) / MPI * 180; } } else if (dx < 0 && dy >= 0) { if (-dx > dy) { angle = acos(-dx / r) / MPI * 180; } else { angle = asin(dy / r) / MPI * 180; } angle = 180 - angle; } else if (dx < 0 && dy < 0) { if (-dx > -dy) { angle = acos(-dx / r) / MPI * 180; } else { angle = asin(-dy / r) / MPI * 180; } angle += 180; } else { if (dx > -dy) { angle = acos(dx / r) / MPI * 180; } else { angle = asin(-dy / r) / MPI * 180; } angle = 360 - angle; } if (round & GDK_CONTROL_MASK) { int tmp; angle = nround(angle); tmp = angle / 15; angle = tmp * 15; } else if (! (round & GDK_SHIFT_MASK)) { angle = nround(angle); } angle *= 100; switch (point) { case ARC_POINT_TYPE_ANGLE1: a2 += a1; a1 = angle; a2 -= a1; break; case ARC_POINT_TYPE_ANGLE2: a2 = angle - a1; break; } a1 %= 36000; if (a1 < 0) a1 += 36000; a2 %= 36000; if (a2 < 0) { a2 += 36000; } if (a2 < 500) a2 = 36000; if (angle1) *angle1 = a1; if (angle2) *angle2 = a2; return 0; } static int new_file_obj(char *name, struct objlist *obj, int *id0, int multi) { int id, ret; id = newobj(obj); if (id < 0) { return 1; } putobj(obj, "file", id, name); if (*id0 != -1) { copy_file_obj_field(obj, id, *id0, FALSE); AddDataFileList(name); return 0; } FileDialog(NgraphApp.FileWin.data.data, id, multi); ret = DialogExecute(TopLevel, &DlgFile); if (ret == IDCANCEL) { FitDel(obj, id); delobj(obj, id); } else { if (ret == IDFAPPLY) { *id0 = id; } set_graph_modified(); AddDataFileList(name); } return 0; } int data_dropped(char **filenames, int num, int file_type) { char *name, *ext, *arg[4]; int i, id0, type, ret; struct objlist *obj, *mobj; obj = chkobject("data"); if (obj == NULL) { return 1; } mobj = chkobject("merge"); if (mobj == NULL) { return 1; } id0 = -1; arg[0] = obj->name; arg[1] = mobj->name; arg[2] = "fit"; arg[3] = NULL; menu_save_undo(UNDO_TYPE_PASTE, arg); for (i = 0; i < num; i++) { name = g_filename_from_uri(filenames[i], NULL, NULL); if (name == NULL) { continue; } type = file_type; if (type == FILE_TYPE_AUTO) { ext = getextention(name); if (ext && strcmp0(ext, "gra") == 0) { type = FILE_TYPE_MERGE; } else { type = FILE_TYPE_DATA; } } ret = 1; if (type == FILE_TYPE_MERGE) { ret = new_merge_obj(name, mobj); } else { ret = new_file_obj(name, obj, &id0, i < num - 1); } if (ret) { g_free(name); continue; } } MergeWinUpdate(NgraphApp.MergeWin.data.data, TRUE, FALSE); FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); return 0; } static int text_dropped(const char *str, gint x, gint y, struct Viewer *d) { N_VALUE *inst; char *ptr; double zoom = Menulocal.PaperZoom / 10000.0; struct objlist *obj; int id, x1, y1, r, i, j, l, undo; obj = chkobject("text"); if (obj == NULL) return 1; l = strlen(str); ptr = g_malloc(l * 2 + 1); if (ptr == NULL) return 1; for (i = j = 0; i < l; i++, j++) { switch (str[i]) { case '\n': ptr[j] = '\\'; j++; ptr[j] = 'n'; break; case '%': case '^': case '_': case '\\': ptr[j] = '\\'; j++; ptr[j] = str[i]; break; default: ptr[j] = str[i]; break; } } ptr[j] = '\0'; undo = menu_save_undo_single(UNDO_TYPE_PASTE, obj->name); id = newobj(obj); if (id < 0) { g_free(ptr); return 1; } inst = chkobjinst(obj, id); x1 = calc_mouse_x(x, zoom, d); y1 = calc_mouse_y(y, zoom, d); CheckGrid(FALSE, 0, &x1, &y1, NULL, NULL); _putobj(obj, "x", inst, &x1); _putobj(obj, "y", inst, &y1); _putobj(obj, "text", inst, ptr); PaintLock= TRUE; LegendTextDialog(&DlgLegendText, obj, id); r = DialogExecute(TopLevel, &DlgLegendText); if ((r == IDDELETE) || (r == IDCANCEL)) { menu_delete_undo(undo); delobj(obj, id); } else { int oid; char *objects[] = {"text", NULL}; UnFocus(); getobj(obj, "oid", id, 0, NULL, &oid); add_focus_obj(NgraphApp.Viewer.focusobj, obj, oid); d->allclear = FALSE; AddList(obj, inst); AddInvalidateRect(obj, inst); set_graph_modified(); d->ShowFrame = TRUE; gtk_widget_grab_focus(d->Win); UpdateAll(objects); } PaintLock = FALSE; return 0; } static void drag_drop_cb(GtkWidget *w, GdkDragContext *context, gint x, gint y, GtkSelectionData *data, guint info, guint time, gpointer user_data) { gchar **filenames, *str; int num, r, success; struct Viewer *d; success = FALSE; if (Globallock || Menulock || DnDLock) goto End; d = (struct Viewer *) user_data; switch (info) { case DROP_TYPE_TEXT: str = (gchar *) gtk_selection_data_get_text(data); if (str) { r = text_dropped(str, x, y, d); g_free(str); success = (! r); } break; case DROP_TYPE_FILE: filenames = gtk_selection_data_get_uris(data); num = g_strv_length(filenames); r = 1; if (num == 1) { char *fname; fname = g_filename_from_uri(filenames[0], NULL, NULL); if (fname == NULL) { g_strfreev(filenames); break; } r = graph_dropped(fname); g_free(fname); } if (r && data_dropped(filenames, num, FILE_TYPE_AUTO) == 0) { success = TRUE; } else { success = TRUE; } g_strfreev(filenames); break; } End: gtk_drag_finish(context, success, FALSE, time); } static void init_dnd(struct Viewer *d) { GtkWidget *widget; GtkTargetEntry target[] = { {"text/uri-list", 0, DROP_TYPE_FILE}, }; GtkTargetList *list; widget = d->Win; gtk_drag_dest_set(widget, GTK_DEST_DEFAULT_ALL, target, sizeof(target) / sizeof(*target), GDK_ACTION_COPY); list = gtk_drag_dest_get_target_list(widget); gtk_target_list_add_text_targets(list, DROP_TYPE_TEXT); g_signal_connect(widget, "drag-data-received", G_CALLBACK(drag_drop_cb), d); } static void eval_dialog_set_parent_cal(GtkWidget *w, GtkTreeIter *iter, int id, int n) { tree_store_set_int(w, iter, EVAL_DIALOG_COL_TYPE_ID, id); tree_store_set_int(w, iter, EVAL_DIALOG_COL_TYPE_LN, n); tree_store_set_int(w, iter, EVAL_DIALOG_COL_TYPE_N, -1); } static void EvalDialogSetupItem(GtkWidget *w, struct EvalDialog *d) { int i, id, n; GtkTreeIter iter, parent; char buf[64]; tree_store_clear(d->list); id = -1; n = 0; for (i = d->Num - 1; i >= 0; i--) { if (id != EvalList[i].id) { if (id >= 0) { eval_dialog_set_parent_cal(d->list, &parent, id, n); } tree_store_prepend(d->list, &parent, NULL); id = EvalList[i].id; n = 0; } tree_store_prepend(d->list, &iter, &parent); tree_store_set_int(d->list, &iter, EVAL_DIALOG_COL_TYPE_ID, EvalList[i].id); tree_store_set_int(d->list, &iter, EVAL_DIALOG_COL_TYPE_LN, EvalList[i].line); snprintf(buf, sizeof(buf), "%+.15e", EvalList[i].x); tree_store_set_string(d->list, &iter, EVAL_DIALOG_COL_TYPE_X, buf); snprintf(buf, sizeof(buf), "%+.15e", EvalList[i].y); tree_store_set_string(d->list, &iter, EVAL_DIALOG_COL_TYPE_Y, buf); tree_store_set_int(d->list, &iter, EVAL_DIALOG_COL_TYPE_N, i); n++; } eval_dialog_set_parent_cal(d->list, &parent, id, n); gtk_tree_view_expand_all(GTK_TREE_VIEW(d->list)); } static void eval_dialog_copy_selected(GtkWidget *w, gpointer *user_data) { GtkTreeView *tv; GtkClipboard *clip; GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; GList *list, *ptr; GString *str; tv = GTK_TREE_VIEW(user_data); sel = gtk_tree_view_get_selection(tv); list = gtk_tree_selection_get_selected_rows(sel, &model); str = g_string_sized_new(256); if (str == NULL) return; for (ptr = g_list_first(list); ptr; ptr = g_list_next(ptr)) { gboolean found; int id, ln; char *x, *y; found = gtk_tree_model_get_iter(model, &iter, ptr->data); if (! found) continue; if (gtk_tree_path_get_depth(ptr->data) < 2) { gtk_tree_model_get(model, &iter, EVAL_DIALOG_COL_TYPE_ID, &id, EVAL_DIALOG_COL_TYPE_LN, &ln, -1); g_string_append_printf(str, "%d %d\n", id, ln); } else { gtk_tree_model_get(model, &iter, EVAL_DIALOG_COL_TYPE_ID, &id, EVAL_DIALOG_COL_TYPE_LN, &ln, EVAL_DIALOG_COL_TYPE_X, &x, EVAL_DIALOG_COL_TYPE_Y, &y, -1); if (x && y) { g_string_append_printf(str, "%d %d %s %s\n", id, ln, x, y); } g_free(x); g_free(y); } } if (str->len > 0) { clip = gtk_clipboard_get(GDK_SELECTION_PRIMARY); gtk_clipboard_set_text(clip, str->str, -1); clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); gtk_clipboard_set_text(clip, str->str, -1); } g_string_free(str, TRUE); g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } static gboolean eval_data_sel_cb(GtkTreeSelection *sel, gpointer user_data) { int n; GtkWidget *w; w = GTK_WIDGET(user_data); n = gtk_tree_selection_count_selected_rows(sel); gtk_widget_set_sensitive(w, n); return FALSE; } static void EvalDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *swin, *hbox; GtkTreeSelection *sel; struct EvalDialog *d; n_list_store list[] = { {"#", G_TYPE_INT, TRUE, FALSE, NULL}, {_("Line No."), G_TYPE_INT, TRUE, FALSE, NULL}, {"X", G_TYPE_STRING, TRUE, FALSE, NULL}, {"Y", G_TYPE_STRING, TRUE, FALSE, NULL}, {"N", G_TYPE_INT, FALSE, FALSE, NULL}, }; d = (struct EvalDialog *) data; if (makewidget) { gtk_dialog_add_buttons(GTK_DIALOG(wi), _("_Mask"), IDEVMASK, _("_Move"), IDEVMOVE, NULL); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); w = tree_store_create(sizeof(list) / sizeof(*list), list); tree_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); d->list = w; gtk_container_add(GTK_CONTAINER(swin), w); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), swin); gtk_box_pack_start(GTK_BOX(d->vbox), w, TRUE, TRUE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_button_new_with_mnemonic(_("Select _All")); set_button_icon(w, "edit-select-all"); g_signal_connect(w, "clicked", G_CALLBACK(tree_store_select_all_cb), d->list); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Copy")); g_signal_connect(w, "clicked", G_CALLBACK(eval_dialog_copy_selected), d->list); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); g_signal_connect(sel, "changed", G_CALLBACK(eval_data_sel_cb), w); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); d->show_cancel = FALSE; d->ok_button = _("_Close"); gtk_window_set_default_size(GTK_WINDOW(wi), 540, 400); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } EvalDialogSetupItem(wi, d); } static void select_data_cb(GtkTreeModel *model, GtkTreePath *path, GtkTreeIter *iter, gpointer data) { struct EvalDialog *d; int a; a = gtk_tree_path_get_depth(path); if (a < 2) return; d = (struct EvalDialog *) data; gtk_tree_model_get(model, iter, EVAL_DIALOG_COL_TYPE_N, &a, -1); if (a >= 0) { arrayadd(d->sel, &a); } } static void EvalDialogClose(GtkWidget *w, void *data) { struct EvalDialog *d; GtkTreeSelection *selected; d = (struct EvalDialog *) data; if ((d->ret == IDEVMASK) || (d->ret == IDEVMOVE)) { selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); gtk_tree_selection_selected_foreach(selected, select_data_cb, d); } } void EvalDialog(struct EvalDialog *data, struct objlist *obj, int num, struct narray *iarray) { data->SetupWindow = EvalDialogSetup; data->CloseWindow = EvalDialogClose; data->Obj = obj; data->Num = num; arrayinit(iarray, sizeof(int)); data->sel = iarray; } static gboolean scrollbar_scroll_cb(GtkWidget *w, GdkEventScroll *e, gpointer client_data) { gdouble x, y; switch (e->direction) { case GDK_SCROLL_UP: case GDK_SCROLL_LEFT: range_increment(w, -SCROLL_INC); break; case GDK_SCROLL_DOWN: case GDK_SCROLL_RIGHT: range_increment(w, SCROLL_INC); break; case GDK_SCROLL_SMOOTH: if (gdk_event_get_scroll_deltas((GdkEvent *) e, &x, &y)) { range_increment(w, y * SCROLL_INC); } return TRUE; default: return FALSE; } return TRUE; } static void menu_activate(GtkMenuShell *menushell, gpointer user_data) { struct Viewer *d; d = (struct Viewer *) user_data; if (d->MoveData) { move_data_cancel(d, FALSE); } } static gboolean ev_popup_menu(GtkWidget *w, gpointer client_data) { struct Viewer *d; if (Menulock || Globallock) return TRUE; d = (struct Viewer *) client_data; do_popup(NULL, d); return TRUE; } void ViewerWinSetup(void) { struct Viewer *d; int x, y, width, height; GdkWindow *win; d = &NgraphApp.Viewer; Menulocal.GRAoid = -1; d->Mode = PointB; d->Capture = FALSE; d->MoveData = FALSE; d->MouseMode = MOUSENONE; d->focusobj = arraynew(sizeof(struct FocusObj *)); d->points = arraynew(sizeof(struct Point *)); d->FrameOfsX = 0; d->FrameOfsY = 0; d->LineX = 0; d->LineY = 0; d->Angle = -1; d->CrossX = 0; d->CrossY = 0; d->ShowFrame = FALSE; d->ShowLine = FALSE; d->ShowRect = FALSE; d->allclear = TRUE; d->ignoreredraw = FALSE; d->KeyMask = 0; region = NULL; OpenGC(); OpenGRA(); SetScroller(); win = gtk_widget_get_window(NgraphApp.Viewer.Win); gdk_window_get_position(win, &x, &y); width = gdk_window_get_width(win); height = gdk_window_get_height(win); d->cx = width / 2; d->cy = height / 2; d->hscroll = gtk_range_get_value(GTK_RANGE(d->HScroll)); d->vscroll = gtk_range_get_value(GTK_RANGE(d->VScroll)); ChangeDPI(); g_signal_connect(d->Win, "draw", G_CALLBACK(ViewerEvPaint), d); g_signal_connect(d->Win, "size-allocate", G_CALLBACK(ViewerEvSize), d); g_signal_connect(d->HScroll, "value-changed", G_CALLBACK(ViewerEvHScroll), d); g_signal_connect(d->VScroll, "value-changed", G_CALLBACK(ViewerEvVScroll), d); g_signal_connect(d->HScroll, "scroll-event", G_CALLBACK(scrollbar_scroll_cb), d); g_signal_connect(d->VScroll, "scroll-event", G_CALLBACK(scrollbar_scroll_cb), d); init_dnd(d); gtk_widget_add_events(d->Win, GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_PRESS_MASK | GDK_KEY_PRESS_MASK | GDK_SCROLL_MASK | GDK_SMOOTH_SCROLL_MASK | GDK_KEY_RELEASE_MASK); gtk_widget_set_can_focus(d->Win, TRUE); if (d->popup) { gtk_menu_attach_to_widget(GTK_MENU(d->popup), GTK_WIDGET(d->Win), NULL); } g_signal_connect(d->Win, "button-press-event", G_CALLBACK(ViewerEvButtonDown), d); g_signal_connect(d->Win, "button-release-event", G_CALLBACK(ViewerEvButtonUp), d); g_signal_connect(d->Win, "motion-notify-event", G_CALLBACK(ViewerEvMouseMotion), d); g_signal_connect(d->Win, "scroll-event", G_CALLBACK(ViewerEvScroll), d); g_signal_connect(d->Win, "key-press-event", G_CALLBACK(ViewerEvKeyDown), d); g_signal_connect(d->Win, "key-release-event", G_CALLBACK(ViewerEvKeyUp), d); g_signal_connect(d->Win, "popup-menu", G_CALLBACK(ev_popup_menu), d); g_signal_connect(d->menu, "selection-done", G_CALLBACK(menu_activate), d); } void ViewerWinClose(void) { struct Viewer *d; d = &NgraphApp.Viewer; arrayfree2(d->focusobj); arrayfree2(d->points); d->focusobj = NULL; d->points = NULL; if (region) { cairo_region_destroy(region); region = NULL; } } static int ViewerWinFileUpdate(int x1, int y1, int x2, int y2, int err) { struct objlist *fileobj; char *argv[7]; int snum, hidden; int did, limit; N_VALUE *dinst; int i; struct narray *eval; int evalnum; int minx, miny, maxx, maxy; struct savedstdio save; char mes[256]; struct narray dfile; int ret; ret = FALSE; ignorestdio(&save); minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; maxx = (x1 > x2) ? x1 : x2; maxy = (y1 > y2) ? y1 : y2; limit = 1; argv[0] = (char *) &minx; argv[1] = (char *) &miny; argv[2] = (char *) &maxx; argv[3] = (char *) &maxy; argv[4] = (char *) &err; argv[5] = (char *) &limit; argv[6] = NULL; fileobj = chkobject("data"); if (! fileobj) goto End; arrayinit(&dfile, sizeof(int)); if (check_drawrable(fileobj)) { goto End; } snum = chkobjlastinst(fileobj) + 1; if (snum == 0) { goto End; } snprintf(mes, sizeof(mes), _("Searching for data.")); SetStatusBar(mes); ProgressDialogCreate(_("Searching for data.")); for (i = 0; i < snum; i++) { dinst = chkobjinst(fileobj, i); if (dinst == NULL) { continue; } _getobj(fileobj, "hidden", dinst, &hidden); if (hidden) { continue; } _getobj(fileobj, "oid", dinst, &did); _exeobj(fileobj, "evaluate", dinst, 6, argv); _getobj(fileobj, "evaluate", dinst, &eval); evalnum = arraynum(eval) / 3; if (evalnum != 0) { arrayadd(&dfile, &i); } } ProgressDialogFinalize(); ResetStatusBar(); ret = update_file_obj_multi(fileobj, &dfile, FALSE); arraydel(&dfile); End: restorestdio(&save); return ret; } static void mask_selected_data(struct objlist *fileobj, int selnum, struct narray *sel_list) { int masknum, i, j, sel; struct narray *mask; for (i = 0; i < selnum; i++) { sel = arraynget_int(sel_list, i); getobj(fileobj, "mask", EvalList[sel].id, 0, NULL, &mask); if (mask == NULL) { mask = arraynew(sizeof(int)); putobj(fileobj, "mask", EvalList[sel].id, mask); } masknum = arraynum(mask); if (masknum == 0 || (arraynget_int(mask, masknum - 1)) < EvalList[sel].line) { arrayadd(mask, &(EvalList[sel].line)); exeobj(fileobj, "modified", EvalList[sel].id, 0, NULL); set_graph_modified(); } else if ((arraynget_int(mask, 0)) > EvalList[sel].line) { arrayins(mask, &(EvalList[sel].line), 0); exeobj(fileobj, "modified", EvalList[sel].id, 0, NULL); set_graph_modified(); } else { if (bsearch_int(arraydata(mask), masknum, EvalList[sel].line, &j) == 0) { arrayins(mask, &(EvalList[sel].line), j); exeobj(fileobj, "modified", EvalList[sel].id, 0, NULL); set_graph_modified(); } } } } static void Evaluate(int x1, int y1, int x2, int y2, int err, struct Viewer *d) { struct objlist *fileobj; char *argv[7]; int snum, hidden; int limit; N_VALUE *dinst; int i, j; struct narray *eval; int evalnum, tot; int minx, miny, maxx, maxy; struct savedstdio save; double line, dx, dy; char mes[256]; int ret; int selnum; minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; maxx = (x1 > x2) ? x1 : x2; maxy = (y1 > y2) ? y1 : y2; limit = EVAL_NUM_MAX; argv[0] = (char *) &minx; argv[1] = (char *) &miny; argv[2] = (char *) &maxx; argv[3] = (char *) &maxy; argv[4] = (char *) &err; argv[5] = (char *) &limit; argv[6] = NULL; if ((fileobj = chkobject("data")) == NULL) return; if (check_drawrable(fileobj)) { return; } snum = chkobjlastinst(fileobj) + 1; if (snum == 0) { return; } ignorestdio(&save); snprintf(mes, sizeof(mes), _("Evaluating.")); SetStatusBar(mes); ProgressDialogCreate(_("Evaluating")); tot = 0; for (i = 0; i < snum; i++) { dinst = chkobjinst(fileobj, i); if (dinst == NULL) { continue; } _getobj(fileobj, "hidden", dinst, &hidden); if (hidden) { continue; } _exeobj(fileobj, "evaluate", dinst, 6, argv); _getobj(fileobj, "evaluate", dinst, &eval); evalnum = arraynum(eval) / 3; for (j = 0; j < evalnum; j++) { if (tot >= limit) break; tot++; line = arraynget_double(eval, j * 3 + 0); dx = arraynget_double(eval, j * 3 + 1); dy = arraynget_double(eval, j * 3 + 2); EvalList[tot - 1].id = i; EvalList[tot - 1].line = nround(line); EvalList[tot - 1].x = dx; EvalList[tot - 1].y = dy; } if (tot >= limit) break; } ProgressDialogFinalize(); ResetStatusBar(); if (tot > 0) { EvalDialog(&DlgEval, fileobj, tot, &SelList); ret = DialogExecute(TopLevel, &DlgEval); selnum = arraynum(&SelList); if (selnum > 0) { switch (ret) { case IDEVMASK: menu_save_undo_single(UNDO_TYPE_EDIT, fileobj->name); mask_selected_data(fileobj, selnum, &SelList); arraydel(&SelList); argv[0] = "data"; argv[1] = NULL; UpdateAll(argv); break; case IDEVMOVE: NSetCursor(GDK_TCROSS); d->Capture = TRUE; d->MoveData = TRUE; break; } } } restorestdio(&save); } static void Trimming(int x1, int y1, int x2, int y2, struct Viewer *d) { struct narray farray; struct objlist *obj; int i, id; int *array, num; int vx1, vy1, vx2, vy2; int maxx, maxy, minx, miny; int dir, rcode1, rcode2, room; double ax, ay, ip1, ip2, min, max; char *argv[4]; if ((x1 == x2) && (y1 == y2)) return; if ((obj = chkobject("axis")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("trimming (multi select)"), AxisCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { vx1 = x1 - x2; vy1 = y1 - y2; vx2 = x2 - x1; vy2 = y1 - y2; num = arraynum(&farray); array = arraydata(&farray); if (num > 0) { menu_save_undo_single(UNDO_TYPE_TRIMMING, obj->name); } for (i = 0; i < num; i++) { id = array[i]; getobj(obj, "direction", id, 0, NULL, &dir); ax = cos(dir / 18000.0 * MPI); ay = -sin(dir / 18000.0 * MPI); ip1 = ax * vx1 + ay * vy1; ip2 = ax * vx2 + ay * vy2; if (fabs(ip1) > fabs(ip2)) { if (ip1 > 0) { maxx = x1; maxy = y1; minx = x2; miny = y2; } else if (ip1 < 0) { maxx = x2; maxy = y2; minx = x1; miny = y1; } else { maxx = minx = 0; maxy = miny = 0; } } else { if (ip2 > 0) { maxx = x2; maxy = y1; minx = x1; miny = y2; } else if (ip2 < 0) { maxx = x1; maxy = y2; minx = x2; miny = y1; } else { maxx = minx = 0; maxy = miny = 0; } } if ((minx != maxx) && (miny != maxy)) { argv[0] = (char *) &minx; argv[1] = (char *) &miny; argv[2] = NULL; rcode1 = getobj(obj, "coordinate", id, 2, argv, &min); argv[0] = (char *) &maxx; argv[1] = (char *) &maxy; argv[2] = NULL; rcode2 = getobj(obj, "coordinate", id, 2, argv, &max); if ((rcode1 != -1) && (rcode2 != -1)) { axis_scale_push(obj, id); room = 0; argv[0] = (char *) &min; argv[1] = (char *) &max; argv[2] = (char *) &room; argv[3] = NULL; exeobj(obj, "scale", id, 3, argv); set_graph_modified(); } } } AdjustAxis(); d->allclear = TRUE; argv[0] = "data"; argv[1] = "axis"; argv[2] = "axisgrid"; argv[3] = NULL; UpdateAll(argv); } arraydel(&farray); } static int Match(char *objname, int x1, int y1, int x2, int y2, int err, const struct Viewer *d) { struct objlist *fobj, *aobj; char *argv[6]; struct narray *sarray; char **sdata; int snum, dnum; struct objlist *dobj; int did, oid; N_VALUE *dinst; int i, match, hidden, r; int minx, miny, maxx, maxy; struct savedstdio save; minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; maxx = (x1 > x2) ? x1 : x2; maxy = (y1 > y2) ? y1 : y2; argv[0] = (char *) &minx; argv[1] = (char *) &miny; argv[2] = (char *) &maxx; argv[3] = (char *) &maxy; argv[4] = (char *) &err; argv[5] = NULL; fobj = chkobject(objname); if (! fobj) { return 0; } sarray = &Menulocal.drawrable; snum = arraynum(sarray); if (snum < 1) { return 0; } ignorestdio(&save); aobj = getobject("axis"); sdata = arraydata(sarray); r = 0; for (i = 0; i < snum; i++) { dobj = getobject(sdata[i]); if (dobj == NULL) { continue; } if (! chkobjchild(fobj, dobj)) { continue; } dnum = chkobjlastinst(dobj) + 1; if (dnum < 1) { continue; } for (did = 0; did < dnum; did++) { dinst = chkobjinst(dobj, did); if (dinst == NULL) { continue; } _getobj(dobj, "hidden", dinst, &hidden); if (hidden) { continue; } if (dobj == aobj) { getobj(fobj, "group_manager", did, 0, NULL, &did); dinst = chkobjinst(dobj, did); } _getobj(dobj, "oid", dinst, &oid); _exeobj(dobj, "match", dinst, 5, argv); _getobj(dobj, "match", dinst, &match); if (! match) { continue; } if (add_focus_obj(d->focusobj, dobj, oid)) { r++; } } } restorestdio(&save); return r; } static void AddList(struct objlist *obj, N_VALUE *inst) { int addi; struct objlist *aobj; char *afield; int i, j, po, num, oid, id, id2; struct objlist **objlist; struct objlist *obj2; N_VALUE *inst2, *ainst; char *field, **objname; struct narray *draw, drawrable; aobj = obj; ainst = inst; afield = "draw"; addi = -1; _getobj(obj, "id", inst, &id); draw = &(Menulocal.drawrable); num = arraynum(draw); if (num == 0) { arrayinit(&drawrable, sizeof(char *)); menuadddrawrable(chkobject("draw"), &drawrable); draw = &drawrable; num = arraynum(draw); } objlist = (struct objlist **) g_malloc(sizeof(struct objlist *) * num); if (objlist == NULL) return; po = 0; for (i = 0; i < num; i++) { objname = (char **) arraynget(draw, i); objlist[i] = chkobject(*objname); if (objlist[i] == obj) po = i; } i = 1; j = 0; while ((obj2 = GRAgetlist(Menulocal.GC, &oid, &field, i)) != NULL) { for (; j < num; j++) { if (objlist[j] == obj2) break; } if (j == po) { inst2 = chkobjinstoid(obj2, oid); if (inst2 == NULL) { GRAdellist(Menulocal.GC, i); continue; } _getobj(obj2, "id", inst2, &id2); if (id2 > id) { addi = i; g_free(objlist); mx_inslist(Menulocal.obj, Menulocal.inst, aobj, ainst, afield, addi); if (draw != &(Menulocal.drawrable)) { arraydel2(draw); } return; } } else if (j > po) { addi = i; g_free(objlist); mx_inslist(Menulocal.obj, Menulocal.inst, aobj, ainst, afield, addi); if (draw != &(Menulocal.drawrable)) { arraydel2(draw); } return; } i++; } addi = i; g_free(objlist); mx_inslist(Menulocal.obj, Menulocal.inst, aobj, ainst, afield, addi); if (draw != &(Menulocal.drawrable)) arraydel2(draw); } static void DelList(struct objlist *obj, N_VALUE *inst, const struct Viewer *d) { int i, oid, oid2; struct objlist *obj2; char *field; _getobj(obj, "oid", inst, &oid); i = 0; while ((obj2 = GRAgetlist(Menulocal.GC, &oid2, &field, i)) != NULL) { if ((obj2 == obj) && (oid == oid2)) mx_dellist(Menulocal.obj, Menulocal.inst, i); i++; } } static void AddInvalidateRect(struct objlist *obj, N_VALUE *inst) { struct narray *abbox; int bboxnum, *bbox; double zoom; cairo_rectangle_int_t rect; if (chkobjfield(obj, "bbox")) { return; } _exeobj(obj, "bbox", inst, 0, NULL); _getobj(obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (bboxnum < 4) { return; } zoom = Menulocal.PaperZoom / 10000.0; rect.x = mxd2p(bbox[0] * zoom + Menulocal.LeftMargin) - 7; rect.y = mxd2p(bbox[1] * zoom + Menulocal.TopMargin) - 7; rect.width = mxd2p(bbox[2] * zoom + Menulocal.LeftMargin) - rect.x + 7; rect.height = mxd2p(bbox[3] * zoom + Menulocal.TopMargin) - rect.y + 7; if (region == NULL) { region = cairo_region_create_rectangle(&rect); } else { cairo_region_union_rectangle(region, &rect); } } static void GetLargeFrame(int *minx, int *miny, int *maxx, int *maxy, const struct Viewer *d) { int i, num; struct FocusObj **focus; struct narray *abbox; int bboxnum, *bbox; N_VALUE *inst; struct savedstdio save; ignorestdio(&save); *minx = *miny = *maxx = *maxy = 0; num = arraynum(d->focusobj); focus = arraydata(d->focusobj); inst = chkobjinstoid(focus[0]->obj, focus[0]->oid); if (inst) { _exeobj(focus[0]->obj, "bbox", inst, 0, NULL); _getobj(focus[0]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (bboxnum >= 4) { *minx = bbox[0]; *miny = bbox[1]; *maxx = bbox[2]; *maxy = bbox[3]; } } for (i = 1; i < num; i++) { inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst == NULL) { continue; } _exeobj(focus[i]->obj, "bbox", inst, 0, NULL); _getobj(focus[i]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (bboxnum < 4) { continue; } if (bbox[0] < *minx) { *minx = bbox[0]; } if (bbox[1] < *miny) { *miny = bbox[1]; } if (bbox[2] > *maxx) { *maxx = bbox[2]; } if (bbox[3] > *maxy) { *maxy = bbox[3]; } } restorestdio(&save); } static int coord_conv_x(int x, double zoom, const struct Viewer *d) { return mxd2p(x * zoom + Menulocal.LeftMargin) - d->hscroll + d->cx + CAIRO_COORDINATE_OFFSET; } static int coord_conv_y(int y, double zoom, const struct Viewer *d) { return mxd2p(y * zoom + Menulocal.TopMargin) - d->vscroll + d->cy + CAIRO_COORDINATE_OFFSET; } static void GetFocusFrame(int *minx, int *miny, int *maxx, int *maxy, int ofsx, int ofsy, const struct Viewer *d) { int x1, y1, x2, y2; double zoom; GetLargeFrame(&x1, &y1, &x2, &y2, d); zoom = Menulocal.PaperZoom / 10000.0; *minx = coord_conv_x((x1 + ofsx), zoom, d); *miny = coord_conv_y((y1 + ofsy), zoom, d); *maxx = coord_conv_x((x2 + ofsx), zoom, d); *maxy = coord_conv_y((y2 + ofsy), zoom, d); } static void ShowFocusFrame(cairo_t *cr, const struct Viewer *d) { int i, j, num; struct FocusObj **focus; struct narray *abbox; int bboxnum; int *bbox; int x1, y1, x2, y2; N_VALUE *inst; struct savedstdio save; double zoom; int minx, miny, height, width; ignorestdio(&save); cairo_set_source_rgb(cr, GRAY, GRAY, GRAY); if (Menulocal.focus_frame_type == N_LINE_TYPE_SOLID) { cairo_set_dash(cr, NULL, 0, 0); } else { double dash[] = {DOT_LENGTH}; cairo_set_dash(cr, dash, sizeof(dash) / sizeof(*dash), 0); } // cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); num = arraynum(d->focusobj); focus = arraydata(d->focusobj); if (num > 0) { GetFocusFrame(&x1, &y1, &x2, &y2, d->FrameOfsX, d->FrameOfsY, d); x1 -= FOCUS_FRAME_OFST; y1 -= FOCUS_FRAME_OFST; x2 += FOCUS_FRAME_OFST - 1; y2 += FOCUS_FRAME_OFST - 1; minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; width = abs(x2 - x1); height = abs(y2 - y1); cairo_rectangle(cr, minx, miny, width, height); cairo_stroke(cr); cairo_rectangle(cr, x1 - FOCUS_RECT_SIZE, y1 - FOCUS_RECT_SIZE, FOCUS_RECT_SIZE, FOCUS_RECT_SIZE); cairo_rectangle(cr, x1 - FOCUS_RECT_SIZE, y2, FOCUS_RECT_SIZE, FOCUS_RECT_SIZE); cairo_rectangle(cr, x2, y1 - FOCUS_RECT_SIZE, FOCUS_RECT_SIZE, FOCUS_RECT_SIZE); cairo_rectangle(cr, x2, y2, FOCUS_RECT_SIZE, FOCUS_RECT_SIZE); cairo_fill(cr); } zoom = Menulocal.PaperZoom / 10000.0; if (num > 1) { for (i = 0; i < num; i++) { inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst == NULL) { continue; } _exeobj(focus[i]->obj, "bbox", inst, 0, NULL); _getobj(focus[i]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (bboxnum < 4) { continue; } x1 = coord_conv_x((bbox[0] + d->FrameOfsX), zoom, d); y1 = coord_conv_y((bbox[1] + d->FrameOfsY), zoom, d); x2 = coord_conv_x((bbox[2] + d->FrameOfsX), zoom, d); y2 = coord_conv_y((bbox[3] + d->FrameOfsY), zoom, d); minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; width = abs(x2 - x1); height = abs(y2 - y1); cairo_rectangle(cr, minx, miny, width, height); cairo_stroke(cr); } } else if (num == 1) { i = 0; inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst) { _exeobj(focus[i]->obj, "bbox", inst, 0, NULL); _getobj(focus[i]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); for (j = 4; j < bboxnum; j += 2) { x1 = coord_conv_x((bbox[j] + d->FrameOfsX), zoom, d); y1 = coord_conv_y((bbox[j + 1] + d->FrameOfsY), zoom, d); cairo_rectangle(cr, x1 - FOCUS_RECT_SIZE / 2 - CAIRO_COORDINATE_OFFSET, y1 - FOCUS_RECT_SIZE / 2 - CAIRO_COORDINATE_OFFSET, FOCUS_RECT_SIZE, FOCUS_RECT_SIZE); } cairo_fill(cr); } } restorestdio(&save); } static int get_focused_obj_array(struct narray *focusobj, char **objs) { int i, j, obj_n, n, axis; struct objlist *obj, *obj_array[OBJ_MAX] = {NULL}; struct FocusObj **focus; n = arraynum(focusobj); focus = arraydata(focusobj); axis = FALSE; obj_n = 0; for (i = 0; i < n; i++) { obj = focus[i]->obj; if (! axis && strcmp(obj->name, "axis") == 0) { axis = TRUE; } for (j = 0; j < obj_n; j++) { if (obj_array[j] == obj) { break; } } if (j == obj_n) { obj_array[obj_n] = obj; obj_n++; } } for (i = 0; i < obj_n; i++) { objs[i] = obj_array[i]->name; } if (axis) { objs[i] = "axisgrid"; i++; objs[i] = "data"; i++; } objs[i] = NULL; return i; } static void AlignFocusedObj(int align) { int i, num, bboxnum, *bbox, minx, miny, maxx, maxy, dx, dy; struct FocusObj **focus; struct narray *abbox; char *argv[4], *objs[OBJ_MAX]; N_VALUE *inst; struct Viewer *d; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; num = arraynum(d->focusobj); if (num < 1) { return; } focus = arraydata(d->focusobj); if (num == 1) { maxx = Menulocal.PaperWidth; maxy = Menulocal.PaperHeight; minx = 0; miny = 0; } else { GetLargeFrame(&minx, &miny, &maxx, &maxy, d); } if (maxx < minx || maxy < miny) return; d->allclear = FALSE; PaintLock = TRUE; get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_ALIGN, objs); for (i = 0; i < num; i++) { inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst == NULL) { continue; } _getobj(focus[i]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (bboxnum < 4) { continue; } dx = dy = 0; switch (align) { case VIEW_ALIGN_LEFT: dx = minx - bbox[0]; break; case VIEW_ALIGN_HCENTER: dx = (maxx + minx - bbox[2] - bbox[0]) / 2; break; case VIEW_ALIGN_RIGHT: dx = maxx - bbox[2]; break; case VIEW_ALIGN_TOP: dy = miny - bbox[1]; break; case VIEW_ALIGN_VCENTER: dy = (maxy + miny - bbox[3] - bbox[1]) / 2; break; case VIEW_ALIGN_BOTTOM: dy = maxy - bbox[3]; break; } if (dx == 0 && dy == 0) continue; argv[0] = (char *) &dx; argv[1] = (char *) &dy; argv[2] = NULL; if (focus[i]->obj == chkobject("axis")) { d->allclear = TRUE; } AddInvalidateRect(focus[i]->obj, inst); _exeobj(focus[i]->obj, "move", inst, 2, argv); set_graph_modified(); AddInvalidateRect(focus[i]->obj, inst); } PaintLock = FALSE; UpdateAll(objs); } static void execute_selected_instances(struct FocusObj **focus, int num, int argc, char **argv, char *field) { N_VALUE *inst; int i; for (i = 0; i < num; i++) { inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst == NULL) { continue; } if (chkobjfield(focus[i]->obj, field) == 0) { AddInvalidateRect(focus[i]->obj, inst); _exeobj(focus[i]->obj, field, inst, argc, argv); set_graph_modified(); AddInvalidateRect(focus[i]->obj, inst); } } } static void RotateFocusedObj(int direction) { int num, minx, miny, maxx, maxy, angle, type; int use_pivot, px, py; struct FocusObj **focus; char *argv[5], *objs[OBJ_MAX]; struct Viewer *d; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; num = check_focused_obj_type(d, &type); if (num < 1 || (type & FOCUS_OBJ_TYPE_MERGE)) { return; } angle = (direction == ROTATE_CLOCKWISE) ? 27000 : 9000; focus = arraydata(d->focusobj); PaintLock = TRUE; argv[0] = (char *) ∠ argv[1] = (char *) &use_pivot; argv[2] = (char *) &px; argv[3] = (char *) &py; argv[4] = NULL; if (num == 1) { use_pivot = 0; px = 0; py = 0; } else { GetLargeFrame(&minx, &miny, &maxx, &maxy, d); use_pivot = 1; px = (minx + maxx) / 2; py = (miny + maxy) / 2; } get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_ROTATE, objs); execute_selected_instances(focus, num, 4, argv, "rotate"); PaintLock = FALSE; UpdateAll(objs); } static void FlipFocusedObj(enum FLIP_DIRECTION dir) { int num, minx, miny, maxx, maxy, type; int use_pivot, p; struct FocusObj **focus; char *argv[4], *objs[OBJ_MAX]; struct Viewer *d; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; num = check_focused_obj_type(d, &type); if (num < 1 || (type & FOCUS_OBJ_TYPE_MERGE)) { return; } focus = arraydata(d->focusobj); PaintLock = TRUE; argv[0] = (char *) &dir; argv[1] = (char *) &use_pivot; argv[2] = (char *) &p; argv[3] = NULL; if (num == 1) { use_pivot = 0; p = 0; } else { GetLargeFrame(&minx, &miny, &maxx, &maxy, d); use_pivot = 1; p = (dir == FLIP_DIRECTION_HORIZONTAL) ? (minx + maxx) / 2 : (miny + maxy) / 2; } get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_FLIP, objs); execute_selected_instances(focus, num, 3, argv, "flip"); PaintLock = FALSE; UpdateAll(objs); } static int check_angle(int a) { if (a < 0) { a %= 36000; if (a < 0) { a += 36000; } } else if (a > 36000) { a %= 36000; } return a; } static void draw_cairo_arc(cairo_t *cr, int x, int y, int rx, int ry, int a1, int a2) { double da1, da2; if (rx < 1 || ry < 1) { return; } cairo_save(cr); cairo_translate(cr, x, y); cairo_scale(cr, rx, ry); da1 = check_angle(a1) * (M_PI / 18000.0); da2 = check_angle(a1 + a2) * (M_PI / 18000.0); cairo_arc_negative(cr, 0.0, 0.0, 1.0, -da1, -da2); cairo_restore(cr); } static void show_focus_line_arc(cairo_t *cr, int change, double zoom, struct objlist *obj, N_VALUE *inst, struct Viewer *d) { int x, y, rx, ry, pie_slice, fill, a1, a2, close_path; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); _getobj(obj, "rx", inst, &rx); _getobj(obj, "ry", inst, &ry); _getobj(obj, "angle1", inst, &a1); _getobj(obj, "angle2", inst, &a2); _getobj(obj, "close_path", inst, &close_path); _getobj(obj, "fill", inst, &fill); _getobj(obj, "pieslice", inst, &pie_slice); close_path = (close_path || fill); switch (change) { case ARC_POINT_TYPE_R: ry -= d->LineY; rx -= d->LineX; break; case ARC_POINT_TYPE_ANGLE1: case ARC_POINT_TYPE_ANGLE2: if (arc_get_angle(obj, inst, d->KeyMask, change, d->MouseX2, d->MouseY2, &a1, &a2)) { return; } d->Angle = (change == ARC_POINT_TYPE_ANGLE1) ? a1 : (a1 + a2) % 36000; break; } if (rx > 0 && ry > 0) { rx = mxd2p(rx * zoom); ry = mxd2p(ry * zoom); x = coord_conv_x(x, zoom, d); y = coord_conv_y(y, zoom, d); draw_cairo_arc(cr, x, y, rx, ry, a1, a2); if (close_path) { if (pie_slice) { cairo_line_to(cr, x, y); } cairo_close_path(cr); } cairo_stroke(cr); } } static void draw_frame_rect(cairo_t *gc, int change, double zoom, int *bbox, const struct Viewer *d) { int x1 = 0, y1 = 0, x2 = 0, y2 = 0; int minx, miny, height, width; switch (change) { case 0: x1 = coord_conv_x(bbox[4] + d->LineX, zoom, d); y1 = coord_conv_y(bbox[5] + d->LineY, zoom, d); x2 = coord_conv_x(bbox[8], zoom, d); y2 = coord_conv_y(bbox[9], zoom, d); break; case 1: x1 = coord_conv_x(bbox[4], zoom, d); y1 = coord_conv_y(bbox[5] + d->LineY, zoom, d); x2 = coord_conv_x(bbox[8] + d->LineX, zoom, d); y2 = coord_conv_y(bbox[9], zoom, d); break; case 2: x1 = coord_conv_x(bbox[4], zoom, d); y1 = coord_conv_y(bbox[5], zoom, d); x2 = coord_conv_x(bbox[8] + d->LineX, zoom, d); y2 = coord_conv_y(bbox[9] + d->LineY, zoom, d); break; case 3: x1 = coord_conv_x(bbox[4] + d->LineX, zoom, d); y1 = coord_conv_y(bbox[5], zoom, d); x2 = coord_conv_x(bbox[8], zoom, d); y2 = coord_conv_y(bbox[9] + d->LineY, zoom, d); break; } minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; width = abs(x2 - x1); height = abs(y2 - y1); cairo_rectangle(gc, minx, miny, width, height); cairo_stroke(gc); } static void draw_focus_line(cairo_t *gc, int change, double zoom, int bboxnum, int *bbox, int close_path, const struct Viewer *d) { int j, ofsx, ofsy, x1, y1; for (j = 4; j < bboxnum; j += 2) { if (change == (j - 4) / 2) { ofsx = d->LineX; ofsy = d->LineY; } else { ofsx = 0; ofsy = 0; } x1 = coord_conv_x(bbox[j] + ofsx, zoom, d); y1 = coord_conv_y(bbox[j + 1] + ofsy, zoom, d); if (j == 4) { cairo_move_to(gc, x1, y1); } else { cairo_line_to(gc, x1, y1); } } if (close_path) { cairo_close_path(gc); } cairo_stroke(gc); } static void ShowFocusLine(cairo_t *cr, struct Viewer *d) { int num; struct FocusObj **focus; struct narray *abbox; int bboxnum; int *bbox; N_VALUE *inst; struct savedstdio save; double zoom; char *group; double dash[] = {DOT_LENGTH}; ignorestdio(&save); cairo_set_source_rgb(cr, GRAY, GRAY, GRAY); cairo_set_dash(cr, dash, sizeof(dash) / sizeof(*dash), 0); // cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); num = arraynum(d->focusobj); focus = arraydata(d->focusobj); zoom = Menulocal.PaperZoom / 10000.0; if (num != 1) { goto End; } inst = chkobjinstoid(focus[0]->obj, focus[0]->oid); if (inst == NULL) { goto End; } _exeobj(focus[0]->obj, "bbox", inst, 0, NULL); _getobj(focus[0]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); if (focus[0]->obj == chkobject("rectangle")) { draw_frame_rect(cr, d->ChangePoint, zoom, bbox, d); } else if (focus[0]->obj == chkobject("arc")) { show_focus_line_arc(cr, d->ChangePoint, zoom, focus[0]->obj, inst, d); } else if (focus[0]->obj == chkobject("path")) { int close_path, fill; _getobj(focus[0]->obj, "close_path", inst, &close_path); _getobj(focus[0]->obj, "fill", inst, &fill); close_path = (close_path || fill); draw_focus_line(cr, d->ChangePoint, zoom, bboxnum, bbox, close_path, d); } else if (focus[0]->obj == chkobject("axis")) { _getobj(focus[0]->obj, "group", inst, &group); if (group && group[0] != 'a') { draw_frame_rect(cr, d->ChangePoint, zoom, bbox, d); } else { draw_focus_line(cr, d->ChangePoint, zoom, bboxnum, bbox, FALSE, d); } } End: // cairo_set_operator(cr, CAIRO_OPERATOR_OVER); restorestdio(&save); } static void ShowPoints(cairo_t *cr, const struct Viewer *d) { int i, num, x1, y1, x2, y2; struct Point **po; double zoom; int minx, miny, height, width; double dash[] = {DOT_LENGTH}; cairo_set_source_rgb(cr, GRAY, GRAY, GRAY); // cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); num = arraynum(d->points); po = arraydata(d->points); zoom = Menulocal.PaperZoom / 10000.0; if (d->Mode & POINT_TYPE_DRAW1) { if (num >= 2) { cairo_set_dash(cr, dash, sizeof(dash) / sizeof(*dash), 0); x1 = coord_conv_x(po[0]->x, zoom, d); y1 = coord_conv_y(po[0]->y, zoom, d); x2 = coord_conv_x(po[1]->x, zoom, d); y2 = coord_conv_y(po[1]->y, zoom, d); minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; width = abs(x2 - x1); height = abs(y2 - y1); if (d->Mode == ArcB) { draw_cairo_arc(cr, minx + width / 2, miny + height / 2, width / 2, height / 2, 0, 36000); } else { cairo_rectangle(cr, minx, miny, width, height); } cairo_stroke(cr); } } else { cairo_set_dash(cr, NULL, 0, 0); for (i = 0; i < num; i++) { x1 = coord_conv_x(po[i]->x, zoom, d); y1 = coord_conv_y(po[i]->y, zoom, d); cairo_move_to(cr, x1 - (POINT_LENGTH - 1), y1); cairo_line_to(cr, x1 + POINT_LENGTH, y1); cairo_move_to(cr, x1, y1 - (POINT_LENGTH - 1)); cairo_line_to(cr, x1, y1 + POINT_LENGTH); } cairo_stroke(cr); if (num >= 1) { cairo_set_dash(cr, dash, sizeof(dash) / sizeof(*dash), 0); x1 = coord_conv_x(po[0]->x, zoom, d); y1 = coord_conv_y(po[0]->y, zoom, d); cairo_move_to(cr, x1, y1); for (i = 1; i < num; i++) { x1 = coord_conv_x(po[i]->x, zoom, d); y1 = coord_conv_y(po[i]->y, zoom, d); cairo_line_to(cr, x1, y1); } cairo_stroke(cr); } } // cairo_set_operator(cr, CAIRO_OPERATOR_OVER); } static void ShowFrameRect(cairo_t *cr, const struct Viewer *d) { int x1, y1, x2, y2; double zoom; int minx, miny, width, height; double dash[] = {DOT_LENGTH}; if (d->MouseX1 == d->MouseX2 && d->MouseY1 == d->MouseY2) { return; } zoom = Menulocal.PaperZoom / 10000.0; cairo_set_source_rgb(cr, GRAY, GRAY, GRAY); cairo_set_dash(cr, dash, sizeof(dash) / sizeof(*dash), 0); // cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); x1 = coord_conv_x(d->MouseX1, zoom, d); y1 = coord_conv_y(d->MouseY1, zoom, d); x2 = coord_conv_x(d->MouseX2, zoom, d); y2 = coord_conv_y(d->MouseY2, zoom, d); minx = (x1 < x2) ? x1 : x2; miny = (y1 < y2) ? y1 : y2; width = abs(x2 - x1); height = abs(y2 - y1); cairo_rectangle(cr, minx, miny, width, height); cairo_stroke(cr); // cairo_set_operator(cr, CAIRO_OPERATOR_OVER); } static void ShowCrossGauge(cairo_t *cr, const struct Viewer *d) { int x, y, width, height; double zoom; GdkWindow *win; cairo_set_source_rgb(cr, GRAY, GRAY, GRAY); cairo_set_dash(cr, NULL, 0, 0); // cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } width = gdk_window_get_width(win); height = gdk_window_get_height(win); zoom = Menulocal.PaperZoom / 10000.0; x = coord_conv_x(d->CrossX, zoom, d); y = coord_conv_y(d->CrossY, zoom, d); cairo_move_to(cr, x, 0); cairo_line_to(cr, x, height); cairo_move_to(cr, 0, y); cairo_line_to(cr, width, y); cairo_stroke(cr); // cairo_set_operator(cr, CAIRO_OPERATOR_OVER); } static void CheckGrid(int ofs, unsigned int state, int *x, int *y, double *zoom_x, double *zoom_y) { int offset; int grid; if ((state & GDK_CONTROL_MASK) && ! ofs && x != NULL && y != NULL) { if (abs(*x) > abs(*y)) { *y = 0; } else { *x = 0; } } grid = Menulocal.grid; if (state & GDK_SHIFT_MASK) { return; } if (ofs) { offset = grid / 2; } else { offset = 0; } if (x != NULL) { *x = ((*x + offset) / grid) * grid; } if (y != NULL) { *y = ((*y + offset) / grid) * grid; } if (zoom_x != NULL) { *zoom_x = nround(*zoom_x * grid) / ((double) grid); } if (zoom_y != NULL) { *zoom_y = nround(*zoom_y * grid) / ((double) grid); } } static void mouse_down_point(unsigned int state, TPoint *point, struct Viewer *d) { d->Capture = TRUE; if (arraynum(d->focusobj) && ! (state & GDK_SHIFT_MASK)) { d->ShowFrame = FALSE; clear_focus_obj(d); } d->MouseMode = MOUSEPOINT; d->ShowRect = TRUE; } #define ZOOM_RATIO_LIMIT 0.5 static void calc_zoom(struct Viewer *d, int vx1, int vy1, int *x2, int *y2, double *zoom_x, double *zoom_y, int preserve_ratio) { int vx2, vy2; double cc, nn, zoom2, zmx, zmy, zmr; vx1 -= d->RefX1 - d->MouseDX; vy1 -= d->RefY1 - d->MouseDY; vx2 = (d->RefX2 - d->RefX1); vy2 = (d->RefY2 - d->RefY1); cc = 1.0 * vx1 * vx2 + 1.0 * vy1 * vy2; nn = 1.0 * vx2 * vx2 + 1.0 * vy2 * vy2; if (x2) { *x2 = vx2; } if (y2) { *y2 = vy2; } if ((nn == 0) || (cc < 0)) { zoom2 = 0; } else { zoom2 = cc / nn; } if (vx2 * vx1 <= 0) { zmx = 0; } else { zmx = 1.0 * vx1 / vx2; } if (vy2 * vy1 <= 0) { zmy = 0; } else { zmy = 1.0 * vy1 / vy2; } if (zmx > 0) { zmr = zmy / zmx; } else { zmr = 2; } if (zoom_x && zoom_y) { if (preserve_ratio) { if (zmr > 1 + ZOOM_RATIO_LIMIT) { *zoom_x = 1; *zoom_y = zmy; } else if (zmr < ZOOM_RATIO_LIMIT) { *zoom_x = zmx; *zoom_y = 1; } else { *zoom_x = zoom2; *zoom_y = zoom2; } } else { *zoom_x = zmx; *zoom_y = zmy; } } } static void set_zoom_prm(struct Viewer *d, int vx2, int vy2, double zoom_x, double zoom_y) { int vx1, vy1; vx1 = d->RefX1 + vx2 * zoom_x; vy1 = d->RefY1 + vy2 * zoom_y; d->MouseX1 = d->RefX1; d->MouseY1 = d->RefY1; d->MouseX2 = vx1; d->MouseY2 = vy1; } static void init_zoom(unsigned int state, struct Viewer *d) { int vx1, vy1, vx2, vy2, preserve_ratio; double zoom_x, zoom_y; d->ShowFrame = FALSE; d->MouseDX = d->RefX2 - d->MouseX1; d->MouseDY = d->RefY2 - d->MouseY1; vx1 = d->MouseX1; vy1 = d->MouseY1; preserve_ratio = (state & GDK_CONTROL_MASK); calc_zoom(d, vx1, vy1, &vx2, &vy2, &zoom_x, &zoom_y, preserve_ratio); CheckGrid(FALSE, state, NULL, NULL, &zoom_x, &zoom_y); set_zoom_prm(d, vx2, vy2, zoom_x, zoom_y); d->ShowRect = TRUE; } static void mouse_down_move(unsigned int state, TPoint *point, struct Viewer *d) { int cursor; cursor = get_mouse_cursor_type(d, point->x, point->y); if (cursor == GDK_LEFT_PTR) { NSetCursor(cursor); return; } d->Capture = TRUE; switch (cursor) { case GDK_TOP_LEFT_CORNER: GetLargeFrame(&(d->RefX2), &(d->RefY2), &(d->RefX1), &(d->RefY1), d); d->MouseMode = MOUSEZOOM1; NSetCursor(cursor); init_zoom(state, d); break; case GDK_TOP_RIGHT_CORNER: GetLargeFrame(&(d->RefX1), &(d->RefY2), &(d->RefX2), &(d->RefY1), d); d->MouseMode = MOUSEZOOM2; NSetCursor(cursor); init_zoom(state, d); break; case GDK_BOTTOM_RIGHT_CORNER: GetLargeFrame(&(d->RefX1), &(d->RefY1), &(d->RefX2), &(d->RefY2), d); d->MouseMode = MOUSEZOOM3; NSetCursor(cursor); init_zoom(state, d); break; case GDK_BOTTOM_LEFT_CORNER: GetLargeFrame(&(d->RefX2), &(d->RefY1), &(d->RefX1), &(d->RefY2), d); d->MouseMode = MOUSEZOOM4; NSetCursor(cursor); init_zoom(state, d); break; case GDK_CROSSHAIR: d->MouseMode = MOUSECHANGE; d->Angle = -1; d->ShowFrame = FALSE; d->ShowLine = TRUE; d->LineX = d->LineY = 0; NSetCursor(cursor); break; case GDK_FLEUR: d->MouseMode = MOUSEDRAG; break; } } static void mouse_down_move_data(struct Viewer *d) { struct objlist *fileobj, *aobjx, *aobjy; struct narray iarray, *move, *movex, *movey; int selnum, sel, i, ax, ay, anum, iline, j, movenum; double dx, dy; char *axis, *argv[3]; int *ptr; fileobj = chkobject("data"); if (fileobj == NULL) goto ErrEnd; selnum = arraynum(&SelList); for (i = 0; i < selnum; i++) { sel = arraynget_int(&SelList, i); if (getobj(fileobj, "axis_x", EvalList[sel].id, 0, NULL, &axis) == -1) goto ErrEnd; arrayinit(&iarray, sizeof(int)); if (getobjilist(axis, &aobjx, &iarray, FALSE, NULL)) { ax = -1; } else { anum = arraynum(&iarray); ax = (anum < 1) ? -1 : (arraylast_int(&iarray)); arraydel(&iarray); } if (getobj(fileobj, "axis_y", EvalList[sel].id, 0, NULL, &axis) == -1) goto ErrEnd; arrayinit(&iarray, sizeof(int)); if (getobjilist(axis, &aobjy, &iarray, FALSE, NULL)) { ay = -1; } else { anum = arraynum(&iarray); ay = (anum < 1) ? -1 : (arraylast_int(&iarray)); arraydel(&iarray); } if (ax == -1 || ax == -1) goto ErrEnd; argv[0] = (char *) &(d->MouseX1); argv[1] = (char *) &(d->MouseY1); argv[2] = NULL; if (getobj(aobjx, "coordinate", ax, 2, argv, &dx) == -1 || getobj(aobjy, "coordinate", ay, 2, argv, &dy) == -1) goto ErrEnd; if (exeobj(fileobj, "move_data_adjust", EvalList[sel].id, 0, NULL) == -1) goto ErrEnd; if (getobj(fileobj, "move_data", EvalList[sel].id, 0, NULL, &move) == -1) goto ErrEnd; if (getobj(fileobj, "move_data_x", EvalList[sel].id, 0, NULL, &movex) == -1) goto ErrEnd; if (getobj(fileobj, "move_data_y", EvalList[sel].id, 0, NULL, &movey) == - 1) goto ErrEnd; if (move == NULL) { move = arraynew(sizeof(int)); putobj(fileobj, "move_data", EvalList[sel].id, move); } if (movex == NULL) { movex = arraynew(sizeof(double)); putobj(fileobj, "move_data_x", EvalList[sel].id, movex); } if (movey == NULL) { movey = arraynew(sizeof(double)); putobj(fileobj, "move_data_y", EvalList[sel].id, movey); } movenum = arraynum(move); for (j = 0; j < movenum; j++) { ptr = (int *) arraynget(move, j); if (ptr) { iline = * ptr; if (iline == EvalList[sel].line) break; } } if (j == movenum) { arrayadd(move, &(EvalList[sel].line)); arrayadd(movex, &dx); arrayadd(movey, &dy); set_graph_modified(); } else { arrayput(move, &(EvalList[sel].line), j); arrayput(movex, &dx, j); arrayput(movey, &dy, j); set_graph_modified(); } } if (selnum > 0) { message_box(NULL, _("Data points are moved."), "Confirm", RESPONS_OK); } argv[0] = "data"; argv[1] = NULL; UpdateAll(argv); ErrEnd: move_data_cancel(d, FALSE); } #define VIEWER_DPI_MAX 620 #define VIEWER_DPI_MIN 20 #if ! GTK_CHECK_VERSION(3, 22, 0) #define ANIM_DIV 1 static void show_zoom_animation(struct Viewer *d, TPoint *point, double zoom) { cairo_pattern_t *pattern; cairo_matrix_t matrix; cairo_t *cr; int i; double inc, z; GdkWindow *win; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } cr = gdk_cairo_create(win); inc = (zoom - 1) / ANIM_DIV; pattern = cairo_pattern_create_for_surface(Menulocal.pix); cairo_set_source(cr, pattern); for (i = 1; i <= ANIM_DIV; i++) { z = 1 + inc * i; cairo_matrix_init(&matrix, z, 0, 0, z, (point->x + d->hscroll - d->cx) - point->x * z, (point->y + d->vscroll - d->cy) - point->y * z); cairo_pattern_set_matrix(pattern, &matrix); cairo_paint(cr); } cairo_pattern_destroy(pattern); cairo_destroy(cr); } #endif #ifdef SHOW_MOVE_ANIMATION static void show_move_animation(struct Viewer *d, int x, int y) { cairo_pattern_t *pattern; cairo_matrix_t matrix; cairo_t *cr; int i, n; double incx, incy; GdkWindow *win; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } if (abs(x) < 1 && abs(y) < 1) { return; } cr = gdk_cairo_create(win); n = abs(x) / 4; if (abs(y) / 4 > n) { n = abs(y) / 4; } if (n > ANIM_DIV) { n = ANIM_DIV; } incx = 1.0 * x / n; incy = 1.0 * y / n; pattern = cairo_pattern_create_for_surface(Menulocal.pix); cairo_set_source(cr, pattern); for (i = 1; i <= n; i++) { cairo_matrix_init(&matrix, 1, 0, 0, 1, (d->hscroll - d->cx) + incx * i, (d->vscroll - d->cy) + incy * i); cairo_pattern_set_matrix(pattern, &matrix); cairo_paint(cr); } cairo_pattern_destroy(pattern); cairo_destroy(cr); } #endif /* SHOW_MOVE_ANIMATION */ static void mouse_down_zoom2(unsigned int state, TPoint *point, struct Viewer *d, int zoom_out, double factor) { static double saved_dpi_d = -1; static double saved_dpi_i = -1; double dpi, ratio; int vdpi; if (ZoomLock) { return; } ZoomLock = TRUE; if (state & GDK_SHIFT_MASK) { #ifdef SHOW_MOVE_ANIMATION show_move_animation(d, point->x - d->cx , point->y - d->cy); #endif /* SHOW_MOVE_ANIMATION */ d->hscroll -= (d->cx - point->x); d->vscroll -= (d->cy - point->y); ChangeDPI(); goto End; } if (getobj(Menulocal.obj, "dpi", 0, 0, NULL, &vdpi) == -1) { goto End; } if (saved_dpi_i < 0 || saved_dpi_i != vdpi) { saved_dpi_i = vdpi; saved_dpi_d = vdpi; } dpi = (zoom_out) ? saved_dpi_d / factor : saved_dpi_d * factor; if (dpi < VIEWER_DPI_MIN) { saved_dpi_i = VIEWER_DPI_MIN; message_beep(TopLevel); } else if (dpi > VIEWER_DPI_MAX) { saved_dpi_i = VIEWER_DPI_MAX; message_beep(TopLevel); } else { saved_dpi_d = dpi; saved_dpi_i = nround(dpi); } ratio = vdpi / saved_dpi_i; #if ! GTK_CHECK_VERSION(3, 22, 0) if (vdpi != nround(saved_dpi_i)) { show_zoom_animation(d, point, ratio); } #endif vdpi = saved_dpi_i; if (putobj(Menulocal.obj, "dpi", 0, &vdpi) != -1) { d->hscroll -= (d->cx - point->x) * (1 - ratio); d->vscroll -= (d->cy - point->y) * (1 - ratio); ChangeDPI(); } End: ZoomLock = FALSE; } static void mouse_down_zoom(unsigned int state, TPoint *point, struct Viewer *d, int zoom_out) { mouse_down_zoom2(state, point, d, zoom_out, ZOOM_SPEED_NORMAL); } static void mouse_down_zoom_little(unsigned int state, TPoint *point, struct Viewer *d, int zoom_out) { mouse_down_zoom2(state, point, d, zoom_out, ZOOM_SPEED_LITTLE); } static void mouse_down_set_points(unsigned int state, struct Viewer *d, int n) { int x1, y1, i; struct Point *po; if (d->Capture) return; x1 = d->MouseX1; y1 = d->MouseY1; CheckGrid(TRUE, state, &x1, &y1, NULL, NULL); for (i = 0; i < n; i++) { po = (struct Point *) g_malloc(sizeof(struct Point)); if (po) { po->x = x1; po->y = y1; arrayadd(d->points, &po); } } d->Capture = TRUE; } static gboolean ViewerEvLButtonDown(unsigned int state, TPoint *point, struct Viewer *d) { double zoom; int pos; if (Menulock || Globallock) return FALSE; if (region) { return FALSE; } zoom = Menulocal.PaperZoom / 10000.0; d->MouseX1 = d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY1 = d->MouseY2 = calc_mouse_y(point->y, zoom, d); d->MouseMode = MOUSENONE; if (d->MoveData) { menu_save_undo_single(UNDO_TYPE_ORDER, "data"); mouse_down_move_data(d); return TRUE; } switch (d->Mode) { case PointB: case LegendB: case AxisB: pos = NGetCursor(); if (pos == GDK_LEFT_PTR) { if (state & GDK_CONTROL_MASK) { NSetCursor(GDK_FLEUR); d->MouseMode = MOUSESCROLLE; return TRUE; } else { mouse_down_point(state, point, d); } } else { mouse_down_move(state, point, d); } break; case TrimB: case DataB: case EvalB: if (state & GDK_CONTROL_MASK) { NSetCursor(GDK_FLEUR); d->MouseMode = MOUSESCROLLE; return TRUE; } else { d->Capture = TRUE; d->MouseMode = MOUSEPOINT; d->ShowRect = TRUE; } break; case MarkB: case TextB: mouse_down_set_points(state, d, 1); break; case ZoomB: mouse_down_zoom(state, point, d, state & GDK_CONTROL_MASK); break; default: mouse_down_set_points(state, d, 2); break; } gtk_widget_queue_draw(d->Win); return TRUE; } static void mouse_up_point(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int x1, x2, y1, y2, err; d->Capture = FALSE; d->ShowRect = FALSE; d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); x1 = d->MouseX1; y1 = d->MouseY1; x2 = d->MouseX2; y2 = d->MouseY2; err = mxp2d(POINT_ERROR) / zoom; switch (d->Mode) { case PointB: case AxisB: Match("axis", x1, y1, x2, y2, err, d); /* fall-through */ case LegendB: if (d->Mode != AxisB) { Match("legend", x1, y1, x2, y2, err, d); Match("merge", x1, y1, x2, y2, err, d); } d->FrameOfsX = d->FrameOfsY = 0; d->ShowFrame = TRUE; break; case TrimB: Trimming(x1, y1, x2, y2, d); break; case DataB: if (ViewerWinFileUpdate(x1, y1, x2, y2, err)) { char *objects[] = {"data", NULL}; UpdateAll(objects); } break; case EvalB: Evaluate(x1, y1, x2, y2, err, d); break; default: /* never reached */ break; } } static int move_objects(int dx, int dy, struct Viewer *d, char **objs) { int i, num, axis; char *argv[5]; N_VALUE *inst; struct FocusObj *focus; struct objlist *obj; d->ShowFrame = FALSE; num = arraynum(d->focusobj); axis = FALSE; PaintLock = TRUE; if (dx != 0 || dy != 0) { menu_save_undo(UNDO_TYPE_MOVE, objs); argv[0] = (char *) &dx; argv[1] = (char *) &dy; argv[2] = NULL; for (i = num - 1; i >= 0; i--) { focus = *(struct FocusObj **) arraynget(d->focusobj, i); obj = focus->obj; if (obj == chkobject("axis")) axis = TRUE; inst = chkobjinstoid(focus->obj, focus->oid); if (inst) { AddInvalidateRect(obj, inst); _exeobj(obj, "move", inst, 2, argv); set_graph_modified(); AddInvalidateRect(obj, inst); } } } PaintLock = FALSE; d->FrameOfsX = d->FrameOfsY = 0; d->ShowFrame = TRUE; return axis; } static void add_data_grid_to_objs(char **objs) { int i, axis, data, axisgrid; if (objs == NULL) { return; } i = 0; axis = FALSE; data = FALSE; axisgrid = FALSE; while (objs[i]) { if (strcmp(objs[i], "axis") == 0) { axis = TRUE; } else if (strcmp(objs[i], "data") == 0) { data = TRUE; } else if (strcmp(objs[i], "axisgrid") == 0) { axisgrid = TRUE; } i++; } if (axis) { if (! data) { objs[i] = "data"; i++; } if (! axisgrid) { objs[i] = "axisgrid"; i++; } objs[i] = NULL; } } static void mouse_up_drag(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int dx, dy, axis; char *objs[OBJ_MAX]; if (d->MouseX1 == d->MouseX2 && d->MouseY1 == d->MouseY2) { return; } d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); dx = d->MouseX2 - d->MouseX1; dy = d->MouseY2 - d->MouseY1; CheckGrid(FALSE, state, &dx, &dy, NULL, NULL); get_focused_obj_array(d->focusobj, objs); axis = move_objects(dx, dy, d, objs); if (d->Mode == LegendB || (d->Mode == PointB && !axis)) { d->allclear=FALSE; } if (axis) { add_data_grid_to_objs(objs); } UpdateAll(objs); } static int check_zoom(double zoom) { int zm; if (zoom * 10000 > G_MAXINT) { return -1; } zm = nround(zoom * 10000); if (zm < 1000) { zm = 1000; } return zm; } static void mouse_up_zoom(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int vx1, vy1, zmx, zmy, i, num, axis, preserve_ratio; double zoom_x, zoom_y; char *argv[6], *objs[OBJ_MAX]; N_VALUE *inst; struct FocusObj *focus; struct objlist *obj; axis = FALSE; d->ShowRect = FALSE; vx1 = calc_mouse_x(point->x, zoom, d); vy1 = calc_mouse_y(point->y, zoom, d); d->MouseX2 = vx1; d->MouseY2 = vy1; preserve_ratio = (state & GDK_CONTROL_MASK); calc_zoom(d, vx1, vy1, NULL, NULL, &zoom_x, &zoom_y, preserve_ratio); if ((d->Mode != DataB) && (d->Mode != EvalB)) { CheckGrid(FALSE, state, NULL, NULL, &zoom_x, &zoom_y); } zmx = check_zoom(zoom_x); zmy = check_zoom(zoom_y); if (zmx < 0 || zmy < 0) { return; } objs[0] = NULL; if (zmx != 10000 || zmy != 10000) { argv[0] = (char *) &zmx; argv[1] = (char *) &zmy; argv[2] = (char *) &(d->RefX1); argv[3] = (char *) &(d->RefY1); argv[4] = (char *) &Menulocal.preserve_width; argv[5] = NULL; num = arraynum(d->focusobj); PaintLock = TRUE; if (num > 0) { get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_ZOOM, objs); } for (i = num - 1; i >= 0; i--) { focus = *(struct FocusObj **) arraynget(d->focusobj, i); obj = focus->obj; if (obj == chkobject("axis")) { axis = TRUE; } inst = chkobjinstoid(focus->obj, focus->oid); if (inst) { AddInvalidateRect(obj, inst); _exeobj(obj, "zooming", inst, 5, argv); set_graph_modified(); AddInvalidateRect(obj, inst); } } } PaintLock = FALSE; d->FrameOfsX = d->FrameOfsY = 0; d->ShowFrame = TRUE; if (d->Mode == LegendB || (d->Mode == PointB && !axis)) { d->allclear = FALSE; } UpdateAll(objs); } static void mouse_up_change(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int dx, dy, axis; char *argv[5]; N_VALUE *inst; struct FocusObj *focus; struct objlist *obj; axis = FALSE; d->ShowLine = FALSE; obj = NULL; if ((d->MouseX1 != d->MouseX2) || (d->MouseY1 != d->MouseY2)) { d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); dx = d->MouseX2 - d->MouseX1; dy = d->MouseY2 - d->MouseY1; if ((d->Mode != DataB) && (d->Mode != EvalB)) { CheckGrid(FALSE, state, &dx, &dy, NULL, NULL); } if (dx != 0 || dy != 0) { argv[0] = (char *) &(d->ChangePoint); argv[1] = (char *) &dx; argv[2] = (char *) &dy; argv[3] = NULL; PaintLock = TRUE; focus = *(struct FocusObj **) arraynget(d->focusobj, 0); obj = focus->obj; inst = chkobjinstoid(focus->obj, focus->oid); if (obj == chkobject("arc") && (d->ChangePoint == ARC_POINT_TYPE_ANGLE1 || d->ChangePoint == ARC_POINT_TYPE_ANGLE2)) { if (arc_get_angle(obj, inst, state, d->ChangePoint, d->MouseX2, d->MouseY2, &dx, &dy)) inst = NULL; } else if (obj == chkobject("axis")) { axis = TRUE; } if (inst) { menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); AddInvalidateRect(obj, inst); _exeobj(obj, "change", inst, 3, argv); set_graph_modified(); AddInvalidateRect(obj, inst); } PaintLock = FALSE; } d->FrameOfsX = d->FrameOfsY = 0; d->ShowFrame = TRUE; if (d->Mode == LegendB || (d->Mode == PointB && !axis)) { d->allclear = FALSE; } argv[0] = (obj) ? obj->name : NULL; argv[1] = NULL; if (axis) { argv[1] = "data"; argv[2] = "axisgrid"; argv[3] = NULL; } UpdateAll(argv); } else { d->FrameOfsX = d->FrameOfsY = 0; d->ShowFrame = TRUE; } } static void mouse_up_lgend1(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int x1, y1, num; struct Point *po; d->Capture = FALSE; d->MouseX1 = calc_mouse_x(point->x, zoom, d); d->MouseY1 = calc_mouse_y(point->y, zoom, d); x1 = d->MouseX1; y1 = d->MouseY1; CheckGrid(TRUE, state, &x1, &y1, NULL, NULL); num = arraynum(d->points); if (num >= 1) { po = *(struct Point **) arraynget(d->points, 0); po->x = x1; po->y = y1; } if (arraynum(d->points) == 1) { ViewerEvLButtonDblClk(state, point, d); } } static void mouse_up_lgend2(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int num, x1, y1; struct Point *po; d->MouseX1 = calc_mouse_x(point->x, zoom, d); d->MouseY1 = calc_mouse_y(point->y, zoom, d); x1 = d->MouseX1; y1 = d->MouseY1; CheckGrid(TRUE, state, &x1, &y1, NULL, NULL); num = arraynum(d->points); if (num >= 2) { po = *(struct Point **) arraynget(d->points, num - 2); } if ((num < 2) || (po->x != x1) || (po->y != y1)) { po = (struct Point *) g_malloc(sizeof(struct Point)); if (po) { po->x = x1; po->y = y1; arrayadd(d->points, &po); } } if ((d->Mode & POINT_TYPE_DRAW1) || d->Mode == SingleB) { if (arraynum(d->points) == 3) { d->Capture = FALSE; ViewerEvLButtonDblClk(state, point, d); } } } static void set_drag_info(struct Viewer *d) { char buf[32]; snprintf(buf, sizeof(buf), "(% .2f, % .2f)", d->FrameOfsX / 100.0, d->FrameOfsY / 100.0); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), buf); } #define CLEAR_DRAG_INFO 0 #if CLEAR_DRAG_INFO static void reset_drag_info(struct Viewer *d) { gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), NULL); } #endif static void SetPoint(struct Viewer *d, int x, int y) { char buf[128]; struct Point *po; unsigned int num; // x += Menulocal.LeftMargin; // y += Menulocal.TopMargin; if (NgraphApp.Message && GTK_WIDGET_VISIBLE(NgraphApp.Message)) { snprintf(buf, sizeof(buf), "% 6.2f, % 6.2f", x / 100.0, y / 100.0); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_pos), buf); switch (d->MouseMode) { case MOUSECHANGE: if (d->Angle >= 0) { snprintf(buf, sizeof(buf), "%6.2f°", d->Angle / 100.0); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), buf); } else { snprintf(buf, sizeof(buf), "(% .2f, % .2f)", d->LineX / 100.0, d->LineY / 100.0); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), buf); } break; case MOUSEZOOM1: case MOUSEZOOM2: case MOUSEZOOM3: case MOUSEZOOM4: snprintf(buf, sizeof(buf), "% .2f%%, % .2f%%", d->ZoomX * 100, d->ZoomY * 100); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), buf); break; case MOUSEDRAG: set_drag_info(d); break; default: num = arraynum(d->points); po = (num > 1) ? (* (struct Point **) arraynget(d->points, num - 2)) : NULL; if (d->Capture && po) { snprintf(buf, sizeof(buf), "(% .2f, % .2f)", (x - po->x) / 100.0, (y - po->y) / 100.0); gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), buf); } else { gtk_label_set_text(GTK_LABEL(NgraphApp.Message_extra), NULL); } } } nruler_set_position(NgraphApp.Viewer.HRuler, N2GTK_RULER_METRIC(x)); nruler_set_position(NgraphApp.Viewer.VRuler, N2GTK_RULER_METRIC(y)); CoordWinSetCoord(x, y); } static gboolean ViewerEvLButtonUp(unsigned int state, TPoint *point, struct Viewer *d) { double zoom; if (Menulock || Globallock) return FALSE; zoom = Menulocal.PaperZoom / 10000.0; if (d->MouseMode == MOUSESCROLLE) { NSetCursor(GDK_LEFT_PTR); d->MouseMode = MOUSENONE; return FALSE; } if (! d->Capture) return TRUE; switch (d->Mode) { case PointB: case LegendB: case AxisB: case TrimB: case DataB: case EvalB: d->Capture = FALSE; switch (d->MouseMode) { case MOUSEDRAG: mouse_up_drag(state, point, zoom, d); break; case MOUSEZOOM1: case MOUSEZOOM2: case MOUSEZOOM3: case MOUSEZOOM4: mouse_up_zoom(state, point, zoom, d); break; case MOUSECHANGE: mouse_up_change(state, point, zoom, d); break; case MOUSEPOINT: mouse_up_point(state, point, zoom, d); #if 0 if (d->Mode & POINT_TYPE_POINT) { d->allclear = FALSE; UpdateAll(NULL); } else { gtk_widget_queue_draw(d->Win); } #else gtk_widget_queue_draw(d->Win); #endif break; case MOUSENONE: case MOUSESCROLLE: break; } NSetCursor(get_mouse_cursor_type(d, point->x, point->y)); d->MouseMode = MOUSENONE; SetPoint(d, d->MouseX2, d->MouseY2); break; case MarkB: case TextB: mouse_up_lgend1(state, point, zoom, d); break; default: mouse_up_lgend2(state, point, zoom, d); } set_focus_sensitivity(d); return TRUE; } static void swapint(int *a, int *b) { int tmp; tmp = *a; *a = *b; *b = tmp; } static void create_legend1(struct Viewer *d) { int id, num, x1, y1, ret, undo; N_VALUE *inst; struct objlist *obj = NULL; struct Point *po; char *objects[2]; d->Capture = FALSE; num = arraynum(d->points); if (d->Mode == MarkB) { obj = chkobject("mark"); } else { obj = chkobject("text"); } if (obj) { undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); id = newobj(obj); if (id >= 0) { presetting_set_obj_field(obj, id); if (num >= 1) { po = *(struct Point **) arraynget(d->points, 0); x1 = po->x; y1 = po->y; } inst = chkobjinst(obj, id); _putobj(obj, "x", inst, &x1); _putobj(obj, "y", inst, &y1); PaintLock = TRUE; if (d->Mode == MarkB) { LegendMarkDialog(&DlgLegendMark, obj, id); ret = DialogExecute(TopLevel, &DlgLegendMark); } else { LegendTextDialog(&DlgLegendText, obj, id); ret = DialogExecute(TopLevel, &DlgLegendText); } if ((ret == IDDELETE) || (ret == IDCANCEL)) { delobj(obj, id); menu_delete_undo(undo); } else { AddList(obj, inst); AddInvalidateRect(obj, inst); set_graph_modified(); } PaintLock = FALSE; } } arraydel2(d->points); d->allclear = FALSE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void create_path(struct Viewer *d) { struct objlist *obj = NULL; struct narray *parray; struct Point *po; N_VALUE *inst; int i, num, id, ret = IDCANCEL, undo; char *objects[2]; d->Capture = FALSE; num = arraynum(d->points); obj = chkobject("path"); if (num < 3 || obj == NULL) { goto ExitCreatePath; } undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); id = newobj(obj); if (id < 0) { menu_delete_undo(undo); goto ExitCreatePath; } presetting_set_obj_field(obj, id); inst = chkobjinst(obj, id); parray = arraynew(sizeof(int)); for (i = 0; i < num - 1; i++) { po = *(struct Point **) arraynget(d->points, i); arrayadd(parray, &po->x); arrayadd(parray, &po->y); } _putobj(obj, "points", inst, parray); PaintLock = TRUE; LegendArrowDialog(&DlgLegendArrow, obj, id); ret = DialogExecute(TopLevel, &DlgLegendArrow); if (ret == IDDELETE || ret == IDCANCEL) { menu_delete_undo(undo); delobj(obj, id); } else { AddList(obj, inst); AddInvalidateRect(obj, inst); set_graph_modified(); } PaintLock = FALSE; ExitCreatePath: arraydel2(d->points); d->allclear = FALSE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void create_legend3(struct Viewer *d) { int id, num, x1, y1, x2, y2, ret = IDCANCEL, undo; N_VALUE *inst; struct objlist *obj = NULL; struct Point **pdata; char *objects[2]; d->Capture = FALSE; num = arraynum(d->points); pdata = arraydata(d->points); if (num >= 3) { if (d->Mode == RectB) { obj = chkobject("rectangle"); } else if (d->Mode == ArcB) { obj = chkobject("arc"); } if (obj) { undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); id = newobj(obj); if (id >= 0) { presetting_set_obj_field(obj, id); inst = chkobjinst(obj, id); x1 = pdata[0]->x; y1 = pdata[0]->y; x2 = pdata[1]->x; y2 = pdata[1]->y; if (x1 > x2) swapint(&x1, &x2); if (y1 > y2) swapint(&y1, &y2); PaintLock = TRUE; if (d->Mode == RectB) { _putobj(obj, "x1", inst, &x1); _putobj(obj, "y1", inst, &y1); _putobj(obj, "x2", inst, &x2); _putobj(obj, "y2", inst, &y2); LegendRectDialog(&DlgLegendRect, obj, id); ret = DialogExecute(TopLevel, &DlgLegendRect); } else if (d->Mode == ArcB) { int x, y, rx, ry; x = (x1 + x2) / 2; y = (y1 + y2) / 2; rx = abs(x1 - x); ry = abs(y1 - y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "rx", inst, &rx); _putobj(obj, "ry", inst, &ry); LegendArcDialog(&DlgLegendArc, obj, id); ret = DialogExecute(TopLevel, &DlgLegendArc); } if ((ret == IDDELETE) || (ret == IDCANCEL)) { delobj(obj, id); menu_delete_undo(undo); } else { AddList(obj, inst); AddInvalidateRect(obj, inst); set_graph_modified(); } PaintLock = FALSE; } } } arraydel2(d->points); d->allclear = FALSE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void create_legendx(struct Viewer *d) { int id, num, x1, y1, x2, y2, ret = IDCANCEL, type, fill, undo; N_VALUE *inst; struct objlist *obj = NULL; struct Point **pdata; char *objects[2]; d->Capture = FALSE; num = arraynum(d->points); pdata = arraydata(d->points); if (num >= 3) { obj = chkobject("path"); if (obj) { undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); id = newobj(obj); if (id >= 0) { presetting_set_obj_field(obj, id); type = PATH_TYPE_CURVE; putobj(obj, "type", id, &type); fill = FALSE; putobj(obj, "fill", id, &fill); inst = chkobjinst(obj, id); x1 = pdata[0]->x; y1 = pdata[0]->y; x2 = pdata[1]->x; y2 = pdata[1]->y; if (x1 > x2) swapint(&x1, &x2); if (y1 > y2) swapint(&y1, &y2); PaintLock = TRUE; if ((x1 != x2) && (y1 != y2)) { LegendGaussDialog(&DlgLegendGauss, obj, id, x1, y1, x2 - x1, y2 - y1); ret = DialogExecute(TopLevel, &DlgLegendGauss); if (ret != IDOK) { delobj(obj, id); menu_delete_undo(undo); } else { AddList(obj, inst); AddInvalidateRect(obj, inst); set_graph_modified(); } } PaintLock = FALSE; } } } arraydel2(d->points); d->allclear = FALSE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void create_single_axis(struct Viewer *d) { int id, num, x1, y1, x2, y2, lenx, dir, ret = IDCANCEL, undo; double fx1, fy1; N_VALUE *inst; struct objlist *obj = NULL; struct Point **pdata; char *objects[2]; d->Capture = FALSE; num = arraynum(d->points); pdata = arraydata(d->points); if (num >= 3) { obj = chkobject("axis"); if (obj != NULL) { undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); if ((id = newobj(obj)) >= 0) { inst = chkobjinst(obj, id); x1 = pdata[0]->x; y1 = pdata[0]->y; x2 = pdata[1]->x; y2 = pdata[1]->y; fx1 = x2 - x1; fy1 = y2 - y1; lenx = nround(sqrt(fx1 * fx1 + fy1 * fy1)); if (fx1 == 0) { if (fy1 >= 0) { dir = 27000; } else { dir = 9000; } } else { dir = nround(atan(-fy1 / fx1) / MPI * 18000); if (fx1 < 0) dir += 18000; if (dir < 0) dir += 36000; if (dir >= 36000) dir -= 36000; } inst = chkobjinst(obj, id); _putobj(obj, "x", inst, &x1); _putobj(obj, "y", inst, &y1); _putobj(obj, "length", inst, &lenx); _putobj(obj, "direction", inst, &dir); presetting_set_obj_field(obj, id); AxisDialog(NgraphApp.AxisWin.data.data, id, TRUE); ret = DialogExecute(TopLevel, &DlgAxis); if (ret == IDCANCEL) { menu_delete_undo(undo); delobj(obj, id); } else { AddList(obj, inst); set_graph_modified(); } } } } arraydel2(d->points); d->allclear = TRUE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void create_axis(struct Viewer *d) { int idx, idy, idu, idr, idg, oidx, oidy, type, num, x1, y1, x2, y2, lenx, leny, ret = IDCANCEL, undo; N_VALUE *inst; char *argv[3], *ref; struct objlist *obj = NULL, *obj2; struct Point **pdata; struct narray group; d->Capture = FALSE; num = arraynum(d->points); pdata = arraydata(d->points); if (num >= 3) { obj = chkobject("axis"); obj2 = chkobject("axisgrid"); argv[0] = obj->name; argv[1] = obj2->name; argv[2] = NULL; if (obj != NULL) { undo = menu_save_undo(UNDO_TYPE_CREATE, argv); x1 = pdata[0]->x; y1 = pdata[0]->y; x2 = pdata[1]->x; y2 = pdata[1]->y; lenx = abs(x1 - x2); leny = abs(y1 - y2); x1 = (x1 < x2) ? x1 : x2; y1 = (y1 > y2) ? y1 : y2; idx = newobj(obj); idy = newobj(obj); if (d->Mode != CrossB) { idu = newobj(obj); idr = newobj(obj); arrayinit(&group, sizeof(int)); if (d->Mode == FrameB) { type = 1; } else { type = 2; } arrayadd(&group, &type); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &idu); arrayadd(&group, &idr); arrayadd(&group, &x1); arrayadd(&group, &y1); arrayadd(&group, &lenx); arrayadd(&group, &leny); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "default_grouping", idr, 1, argv); arraydel(&group); } else { arrayinit(&group, sizeof(int)); type = 3; arrayadd(&group, &type); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &x1); arrayadd(&group, &y1); arrayadd(&group, &lenx); arrayadd(&group, &leny); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "default_grouping", idx, 1, argv); arraydel(&group); } if ((d->Mode == SectionB) && (obj2 != NULL)) { idg = newobj(obj2); if (idg >= 0) { getobj(obj, "oid", idx, 0, NULL, &oidx); ref = g_strdup_printf("axis:^%d", oidx); if (ref) { putobj(obj2, "axis_x", idg, ref); } getobj(obj, "oid", idy, 0, NULL, &oidy); ref = g_strdup_printf("axis:^%d", oidy); if (ref) { putobj(obj2, "axis_y", idg, ref); } } } else { idg = -1; } if (d->Mode == FrameB) { presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); presetting_set_obj_field(obj, idu); presetting_set_obj_field(obj, idr); SectionDialog(&DlgSection, x1, y1, lenx, leny, obj, idx, idy, idu, idr, obj2, &idg, FALSE); ret = DialogExecute(TopLevel, &DlgSection); } else if (d->Mode == SectionB) { presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); presetting_set_obj_field(obj, idu); presetting_set_obj_field(obj, idr); presetting_set_obj_field(obj2, idg); SectionDialog(&DlgSection, x1, y1, lenx, leny, obj, idx, idy, idu, idr, obj2, &idg, TRUE); ret = DialogExecute(TopLevel, &DlgSection); } else if (d->Mode == CrossB) { presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); CrossDialog(&DlgCross, x1, y1, lenx, leny, obj, idx, idy); ret = DialogExecute(TopLevel, &DlgCross); } if (ret == IDCANCEL) { menu_undo_internal(undo); } else { inst = chkobjinst(obj, idx); if (inst) AddList(obj, inst); inst = chkobjinst(obj, idy); if (inst) AddList(obj, inst); if (d->Mode != CrossB) { inst = chkobjinst(obj, idu); if (inst) AddList(obj, inst); inst = chkobjinst(obj, idr); if (inst) AddList(obj, inst); } if ((idg != -1) && (obj2 != NULL)) { inst = chkobjinst(obj2, idg); if (inst) AddList(obj2, inst); } set_graph_modified(); } } d->allclear = TRUE; argv[0] = obj->name; argv[1] = obj2->name; argv[2] = NULL; UpdateAll(argv); } arraydel2(d->points); } static gboolean ViewerEvLButtonDblClk(unsigned int state, TPoint *point, struct Viewer *d) { if (Menulock || Globallock) return FALSE; switch (d->Mode) { case PointB: case LegendB: case AxisB: d->Capture = FALSE; ViewUpdate(); break; case TrimB: case DataB: case EvalB: break; case MarkB: case TextB: create_legend1(d); break; case PathB: create_path(d); break; case RectB: case ArcB: create_legend3(d); break; case GaussB: create_legendx(d); break; case SingleB: create_single_axis(d); break; case FrameB: case SectionB: case CrossB: create_axis(d); break; case ZoomB: break; } if ((d->Mode & POINT_TYPE_DRAW_ALL) && ! KeepMouseMode) { set_pointer_mode(-1); } return TRUE; } void move_data_cancel(struct Viewer *d, gboolean show_message) { arraydel(&SelList); d->MoveData = FALSE; d->Capture = FALSE; NSetCursor(GDK_LEFT_PTR); if (show_message) message_box(NULL, _("Moving data points is canceled."), "Confirm", RESPONS_OK); } static gboolean ViewerEvRButtonDown(unsigned int state, TPoint *point, struct Viewer *d, GdkEventButton *e) { int num; struct Point *po; double zoom; if (Menulock || Globallock) return FALSE; if (d->MoveData) { move_data_cancel(d, TRUE); } else if (d->Capture) { zoom = Menulocal.PaperZoom / 10000.0; switch (d->Mode) { case PathB: num = arraynum(d->points); if (num > 0) { arrayndel2(d->points, num - 1); if (num <= 2) { arraydel2(d->points); d->Capture = FALSE; } else { po = *(struct Point **) arraylast(d->points); if (po != NULL) { d->MouseX1 = (mxp2d(d->hscroll + point->x - d->cx) - Menulocal.LeftMargin) / zoom; d->MouseY1 = (mxp2d(d->vscroll + point->y - d->cy) - Menulocal.TopMargin) / zoom; po->x = d->MouseX1; po->y = d->MouseY1; CheckGrid(TRUE, state, &(po->x), &(po->y), NULL, NULL); } } break; case RectB: case ArcB: case GaussB: case SingleB: case FrameB: case SectionB: case CrossB: arraydel2(d->points); d->Capture = FALSE; break; default: break; } } } else if (d->Mode == ZoomB) { mouse_down_zoom(state, point, d, ! (state & GDK_CONTROL_MASK)); } else if (d->MouseMode == MOUSENONE) { do_popup(e, d); } gtk_widget_queue_draw(d->Win); return TRUE; } static gboolean ViewerEvMButtonDown(unsigned int state, TPoint *point, struct Viewer *d) { if (Menulock || Globallock) return FALSE; if (d->Mode == ZoomB) { #ifdef SHOW_MOVE_ANIMATION show_move_animation(d, point->x - d->cx , point->y - d->cy); #endif /* SHOW_MOVE_ANIMATION */ d->hscroll -= (d->cx - point->x); d->vscroll -= (d->cy - point->y); ChangeDPI(); } else { ViewerEvLButtonDown(state, point, d); ViewerEvLButtonUp(state, point, d); ViewerEvLButtonDblClk(state, point, d); } return FALSE; } static int get_mouse_cursor_type(struct Viewer *d, int x, int y) { int j, x1, y1, x2, y2, num, cursor, bboxnum, *bbox; N_VALUE *inst; struct narray *abbox; struct FocusObj **focus; double zoom; if (d->MoveData) return GDK_TCROSS; num = arraynum(d->focusobj); if (num == 0) return GDK_LEFT_PTR; GetFocusFrame(&x1, &y1, &x2, &y2, d->FrameOfsX, d->FrameOfsY, d); if (x >= x1 && x <= x2 && y >= y1 && y <= y2) { cursor = GDK_FLEUR; } else if (x > x1 - FOCUS_RECT_SIZE - FOCUS_FRAME_OFST && x < x1 - FOCUS_FRAME_OFST && y > y1 - FOCUS_RECT_SIZE - FOCUS_FRAME_OFST && y < y1 - FOCUS_FRAME_OFST) { cursor = GDK_TOP_LEFT_CORNER; } else if (x > x1 - FOCUS_RECT_SIZE - FOCUS_FRAME_OFST && x < x1 - FOCUS_FRAME_OFST && y < y2 + FOCUS_RECT_SIZE + FOCUS_FRAME_OFST - 1 && y > y2 + FOCUS_FRAME_OFST - 1) { cursor = GDK_BOTTOM_LEFT_CORNER; } else if (x < x2 + FOCUS_RECT_SIZE + FOCUS_FRAME_OFST - 1 && x > x2 + FOCUS_FRAME_OFST - 1 && y > y1 - FOCUS_RECT_SIZE - FOCUS_FRAME_OFST && y < y1 - FOCUS_FRAME_OFST) { cursor = GDK_TOP_RIGHT_CORNER; } else if (x < x2 + FOCUS_RECT_SIZE + FOCUS_FRAME_OFST - 1 && x > x2 + FOCUS_FRAME_OFST - 1 && y < y2 + FOCUS_RECT_SIZE + FOCUS_FRAME_OFST - 1 && y > y2 + FOCUS_FRAME_OFST - 1) { cursor = GDK_BOTTOM_RIGHT_CORNER; } else { cursor = GDK_LEFT_PTR; } if (num > 1) return cursor; focus = arraydata(d->focusobj); inst = chkobjinstoid(focus[0]->obj, focus[0]->oid); if (inst == NULL) return cursor; zoom = Menulocal.PaperZoom / 10000.0; _exeobj(focus[0]->obj, "bbox", inst, 0, NULL); _getobj(focus[0]->obj, "bbox", inst, &abbox); bboxnum = arraynum(abbox); bbox = arraydata(abbox); for (j = 4; j < bboxnum; j += 2) { x1 = coord_conv_x((bbox[j] + d->FrameOfsX), zoom, d); y1 = coord_conv_y((bbox[j + 1] + d->FrameOfsY), zoom, d); if (x > x1 - FOCUS_RECT_SIZE / 2 && x < x1 + FOCUS_RECT_SIZE / 2 && y > y1 - FOCUS_RECT_SIZE / 2 && y < y1 + FOCUS_RECT_SIZE / 2) { cursor = GDK_CROSSHAIR; d->ChangePoint = (j - 4) / 2; break; } } return cursor; } static void set_mouse_cursor_hover(struct Viewer *d, int x, int y) { if (d->Mode != PointB && d->Mode != LegendB && d->Mode != AxisB) return; NSetCursor(get_mouse_cursor_type(d, x, y)); } static void update_frame_rect(TPoint *point, struct Viewer *d, double zoom) { d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); } #define SQRT3 1.73205080756888 static void calc_snap_angle(struct narray *points, int *dx, int *dy) { struct Point *po2; int x, y, w, h, n; double angle, l; x = *dx; y = *dy; n = arraynum(points); if (n < 2) return; po2 = *(struct Point **) arraynget(points, n - 2); w = x - po2->x; h = y - po2->y; if (h == 0 || w == 0) return; l = sqrt(w * w + h * h); if (w / h) { angle = acos(w / l); if (h < 0) angle = -angle; } else { angle = asin(h / l); if (w < 0) angle = -angle; } if (angle < 0) angle += 2 * MPI; angle *= 180 / MPI; if (angle < 15) { y = po2->y; } else if (angle < 37) { /* 30 */ y = po2->y + w / SQRT3; } else if (angle < 52) { /* 45 */ y = po2->y + w; } else if (angle < 75) { /* 60 */ x = po2->x + h / SQRT3; } else if (angle < 105) { /* 90 */ x = po2->x; } else if (angle < 127) { /* 120 */ x = po2->x - h / SQRT3; } else if (angle < 142) { /* 135 */ y = po2->y - w; } else if (angle < 165) { /* 150 */ y = po2->y - w / SQRT3; } else if (angle < 195) { /* 180 */ y = po2->y; } else if (angle < 217) { /* 210 */ y = po2->y + w / SQRT3; } else if (angle < 232) { /* 225 */ y = po2->y + w; } else if (angle < 255) { /* 240 */ x = po2->x + h / SQRT3; } else if (angle < 285) { /* 270 */ x = po2->x; } else if (angle < 307) { /* 300 */ x = po2->x - h / SQRT3; } else if (angle < 322) { /* 315 */ y = po2->y - w; } else if (angle < 345) { /* 330 */ y = po2->y - w / SQRT3; } else { /* 360 */ y = po2->y; } *dx = x; *dy = y; } static void calc_integer_ratio(struct narray *points, int *dx, int *dy) { struct Point *po2; int x, y, w, h; x = *dx; y = *dy; po2 = *(struct Point **) arraynget(points, 0); if (po2 == NULL) { return; } w = abs(x - po2->x); h = abs(y - po2->y); if (w < h) { w *= (w) ? h / w: 0; if (y > po2->y) { y = po2->y + w; } else { y = po2->y - w; } } else { h *= (h) ? w / h: 0; if (x > po2->x) { x = po2->x + h; } else { x = po2->x - h; } } *dx = x; *dy = y; } static void mouse_move_drag(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int x, y; d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); x = d->MouseX2 - d->MouseX1; y = d->MouseY2 - d->MouseY1; CheckGrid(FALSE, state, &x, &y, NULL, NULL); d->FrameOfsX = x; d->FrameOfsY = y; } static void mouse_move_zoom(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { double zoom_x, zoom_y, preserve_ratio; int vx1, vx2, vy1, vy2; vx1 = calc_mouse_x(point->x, zoom, d); vy1 = calc_mouse_y(point->y, zoom, d); preserve_ratio = (state & GDK_CONTROL_MASK); calc_zoom(d, vx1, vy1, &vx2, &vy2, &zoom_x, &zoom_y, preserve_ratio); if ((d->Mode != DataB) && (d->Mode != EvalB)) CheckGrid(FALSE, state, NULL, NULL, &zoom_x, &zoom_y); d->ZoomX = zoom_x; d->ZoomY = zoom_y; set_zoom_prm(d, vx2, vy2, zoom_x, zoom_y); } static void mouse_move_change(unsigned int state, TPoint *point, double zoom, struct Viewer *d) { int x, y; d->MouseX2 = calc_mouse_x(point->x, zoom, d); d->MouseY2 = calc_mouse_y(point->y, zoom, d); x = d->MouseX2 - d->MouseX1; y = d->MouseY2 - d->MouseY1; if ((d->Mode != DataB) && (d->Mode != EvalB)) { CheckGrid(FALSE, state, &x, &y, NULL, NULL); } d->LineX = x; d->LineY = y; } static void mouse_move_scroll(TPoint *point, const struct Viewer *d) { int h, w; GdkWindow *win; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } w = gdk_window_get_width(win); h = gdk_window_get_height(win); if (point->y > h) { range_increment(d->VScroll, SCROLL_INC); } else if (point->y < 0) { range_increment(d->VScroll, -SCROLL_INC); } if (point->x > w) { range_increment(d->HScroll, SCROLL_INC); } else if (point->x < 0) { range_increment(d->HScroll, -SCROLL_INC); } } static void mouse_move_draw(unsigned int state, int *dx, int *dy, const struct Viewer *d) { struct Point *po; if (arraynum(d->points) == 0) { return; } po = *(struct Point **) arraylast(d->points); if (state & GDK_CONTROL_MASK) { if (d->Mode & POINT_TYPE_DRAW1) { calc_integer_ratio(d->points, dx, dy); } else if (d->Mode & POINT_TYPE_DRAW2) { calc_snap_angle(d->points, dx, dy); if (! (state & GDK_SHIFT_MASK)) { CheckGrid(FALSE, 0, dx, dy, NULL, NULL); } } } if (po != NULL) { po->x = *dx; po->y = *dy; } } static gboolean ViewerEvMouseMove(unsigned int state, TPoint *point, struct Viewer *d) { int dx, dy; double zoom; if (Menulock || Globallock) { return FALSE; } if (gtk_widget_get_window(d->Win) == NULL) { return FALSE; } d->KeyMask = state; zoom = Menulocal.PaperZoom / 10000.0; dx = calc_mouse_x(point->x, zoom, d); dy = calc_mouse_y(point->y, zoom, d); if (d->MouseMode == MOUSESCROLLE) { range_increment(d->HScroll, mxd2p(d->MouseX1 - dx)); range_increment(d->VScroll, mxd2p(d->MouseY1 - dy)); return FALSE; } if ((d->Mode != DataB) && (d->Mode != EvalB) && (d->Mode != ZoomB) && (d->MouseMode != MOUSEPOINT) && (((d->Mode != PointB) && (d->Mode != LegendB) && (d->Mode != AxisB)) || (d->MouseMode != MOUSENONE))) { CheckGrid(TRUE, state, &dx, &dy, NULL, NULL); } d->CrossX = dx; d->CrossY = dy; mouse_move_scroll(point, d); if (! d->Capture) { set_mouse_cursor_hover(d, point->x, point->y); } else { int pos; pos = NGetCursor(); if (pos == GDK_FLEUR || pos == GDK_TOP_LEFT_CORNER || pos == GDK_BOTTOM_LEFT_CORNER || pos == GDK_TOP_RIGHT_CORNER || pos == GDK_BOTTOM_RIGHT_CORNER || pos == GDK_CROSSHAIR || (d->Mode & POINT_TYPE_TRIM)) { switch (d->MouseMode) { case MOUSEDRAG: mouse_move_drag(state, point, zoom, d); break; case MOUSEZOOM1: case MOUSEZOOM2: case MOUSEZOOM3: case MOUSEZOOM4: mouse_move_zoom(state, point, zoom, d); break; case MOUSECHANGE: mouse_move_change(state, point, zoom, d); break; case MOUSEPOINT: update_frame_rect(point, d, zoom); break; case MOUSENONE: case MOUSESCROLLE: break; } } else if (d->Mode & POINT_TYPE_POINT) { if (d->MouseMode == MOUSEPOINT) { update_frame_rect(point, d, zoom); } } else { mouse_move_draw(state, &dx, &dy, d); } } SetPoint(d, dx, dy); if ((region == NULL && Menulocal.show_cross && gtk_widget_is_drawable(d->Win)) || (d->Mode & POINT_TYPE_DRAW_ALL) || d->MouseMode != MOUSENONE) { gtk_widget_queue_draw(d->Win); } return FALSE; } static gboolean ViewerEvMouseMotion(GtkWidget *w, GdkEventMotion *e, gpointer client_data) { TPoint point; #if 0 static guint32 etime = 0; if (e->time - etime < 100) return FALSE; etime = e->time; #endif point.x = e->x; point.y = e->y; ViewerEvMouseMove(e->state, &point, (struct Viewer *) client_data); gdk_event_request_motions(e); /* handles is_hint events */ return FALSE; } #if ! GTK_CHECK_VERSION(3, 22, 0) static void popup_menu_position(GtkMenu *menu, gint *x, gint *y, gboolean *push_in, gpointer user_data) { struct Viewer *d; GdkWindow *win; d = (struct Viewer *) user_data; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } gdk_window_get_origin(win, x, y); } #endif int check_focused_obj_type(const struct Viewer *d, int *type) { int num, i, t; static struct objlist *axis, *merge, *legend, *text; struct FocusObj *focus; num = arraynum(d->focusobj); if (axis == NULL) axis = chkobject("axis"); if (merge == NULL) merge = chkobject("merge"); if (legend == NULL) legend = chkobject("legend"); if (text == NULL) text = chkobject("text"); if (axis == NULL || merge == NULL || legend == NULL || text == NULL) { return 0; } t = 0; for (i = 0; i < num; i++) { focus = *(struct FocusObj **) arraynget(d->focusobj, i); if (chkobjchild(legend, focus->obj)) { t |= FOCUS_OBJ_TYPE_LEGEND; if (chkobjchild(text, focus->obj)) { t |= FOCUS_OBJ_TYPE_TEXT; } } else if (chkobjchild(axis, focus->obj)) { t |= FOCUS_OBJ_TYPE_AXIS; } else if (chkobjchild(merge, focus->obj)) { t |= FOCUS_OBJ_TYPE_MERGE; } } if (type) *type = t; return num; } static void do_popup(GdkEventButton *event, struct Viewer *d) { #if GTK_CHECK_VERSION(3, 22, 0) if (! gtk_widget_get_realized(d->popup)) { gtk_widget_realize(d->popup); } gtk_menu_popup_at_pointer(GTK_MENU(d->popup), ((GdkEvent *)event)); #else int button, event_time; GtkMenuPositionFunc func = NULL; if (d->popup == NULL) { return; } if (event) { button = event->button; event_time = event->time; } else { button = 0; event_time = gtk_get_current_event_time(); func = popup_menu_position; } gtk_menu_popup(GTK_MENU(d->popup), NULL, NULL, func, d, button, event_time); #endif } static gboolean ViewerEvScroll(GtkWidget *w, GdkEventScroll *e, gpointer client_data) { struct Viewer *d; TPoint point; gdouble x, y; point.x = e->x; point.y = e->y; d = (struct Viewer *) client_data; switch (e->direction) { case GDK_SCROLL_UP: if (e->state & GDK_CONTROL_MASK) { mouse_down_zoom_little(0, &point, d, FALSE); } else { range_increment(d->VScroll, -SCROLL_INC); } return TRUE; case GDK_SCROLL_DOWN: if (e->state & GDK_CONTROL_MASK) { mouse_down_zoom_little(0, &point, d, TRUE); } else { range_increment(d->VScroll, SCROLL_INC); } return TRUE; case GDK_SCROLL_LEFT: range_increment(d->HScroll, -SCROLL_INC); return TRUE; case GDK_SCROLL_RIGHT: range_increment(d->HScroll, SCROLL_INC); return TRUE; case GDK_SCROLL_SMOOTH: if (gdk_event_get_scroll_deltas((GdkEvent *) e, &x, &y)) { if ((e->state & GDK_CONTROL_MASK) && y != 0) { mouse_down_zoom_little(0, &point, d, y > 0); } else { range_increment(d->HScroll, x * SCROLL_INC); range_increment(d->VScroll, y * SCROLL_INC); } } return TRUE; } return FALSE; } static gboolean ViewerEvButtonDown(GtkWidget *w, GdkEventButton *e, gpointer client_data) { struct Viewer *d; TPoint point; d = (struct Viewer *) client_data; d->KeyMask = e->state; point.x = e->x; point.y = e->y; gtk_widget_grab_focus(w); switch (e->button) { case Button1: if (e->type == GDK_BUTTON_PRESS) { return ViewerEvLButtonDown(e->state, &point, d); } else { return ViewerEvLButtonDblClk(e->state, &point, d); } break; case Button2: return ViewerEvMButtonDown(e->state, &point, d); case Button3: return ViewerEvRButtonDown(e->state, &point, d, e); } return FALSE; } static gboolean ViewerEvButtonUp(GtkWidget *w, GdkEventButton *e, gpointer client_data) { struct Viewer *d; TPoint point; d = (struct Viewer *) client_data; d->KeyMask = e->state; point.x = e->x; point.y = e->y; switch (e->button) { case Button1: return ViewerEvLButtonUp(e->state, &point, d); } return FALSE; } static void move_focus_frame(GdkEventKey *e, struct Viewer *d) { int dx = 0, dy = 0, mv; double zoom; zoom = Menulocal.PaperZoom / 10000.0; mv = (e->state & GDK_SHIFT_MASK) ? Menulocal.grid / 10 : Menulocal.grid; switch (e->keyval) { case GDK_KEY_Down: dy = mv; break; case GDK_KEY_Up: dy = -mv; break; case GDK_KEY_Right: dx = mv; break; case GDK_KEY_Left: dx = -mv; break; default: return; } if (dx != 0 || dy != 0) { d->FrameOfsX += dx / zoom; d->FrameOfsY += dy / zoom; d->MouseMode = MOUSEDRAG; set_drag_info(d); main_window_redraw(); } } static int viewer_key_scroll(GdkEventKey *e, struct Viewer *d) { switch (e->keyval) { case GDK_KEY_Up: range_increment(d->VScroll, -SCROLL_INC); return TRUE; case GDK_KEY_Down: range_increment(d->VScroll, SCROLL_INC); return TRUE; case GDK_KEY_Left: range_increment(d->HScroll, -SCROLL_INC); return TRUE; case GDK_KEY_Right: range_increment(d->HScroll, SCROLL_INC); return TRUE; } return FALSE; } static gboolean ViewerEvKeyDown(GtkWidget *w, GdkEventKey *e, gpointer client_data) { struct Viewer *d; d = (struct Viewer *) client_data; if (Menulock || Globallock) goto EXIT_PRAPAGATE; switch (e->keyval) { case GDK_KEY_Escape: if (d->MoveData) { move_data_cancel(d, TRUE); } else { UnFocus(); } set_pointer_mode(-1); goto EXIT_PRAPAGATE; case GDK_KEY_space: CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); return TRUE; case GDK_KEY_Page_Up: range_increment(d->VScroll, -SCROLL_INC * 4); return TRUE; case GDK_KEY_Page_Down: range_increment(d->VScroll, SCROLL_INC * 4); return TRUE; case GDK_KEY_Down: case GDK_KEY_Up: case GDK_KEY_Left: case GDK_KEY_Right: if (arraynum(d->focusobj) == 0) { return viewer_key_scroll(e, d); } if (((d->MouseMode == MOUSENONE) || (d->MouseMode == MOUSEDRAG)) && (d->Mode & POINT_TYPE_POINT)) { move_focus_frame(e, d); return TRUE; } break; case GDK_KEY_Shift_L: case GDK_KEY_Shift_R: if (d->Mode == ZoomB) { NSetCursor(GDK_PLUS); return TRUE; } break; case GDK_KEY_Control_L: case GDK_KEY_Control_R: if (d->Mode == ZoomB) { NSetCursor(GDK_TARGET); return TRUE; } break; case GDK_KEY_Return: ViewUpdate(); break; default: break; } EXIT_PRAPAGATE: set_focus_sensitivity(d); return FALSE; } static gboolean ViewerEvKeyUp(GtkWidget *w, GdkEventKey *e, gpointer client_data) { struct Viewer *d; char *objs[OBJ_MAX]; int dx, dy; int axis; if (Menulock || Globallock) return FALSE; d = (struct Viewer *) client_data; switch (e->keyval) { case GDK_KEY_Shift_L: case GDK_KEY_Shift_R: case GDK_KEY_Control_L: case GDK_KEY_Control_R: if (d->Mode == ZoomB) { NSetCursor(GDK_TARGET); return TRUE; } break; case GDK_KEY_Down: case GDK_KEY_Up: case GDK_KEY_Left: case GDK_KEY_Right: if (d->MouseMode != MOUSEDRAG) break; dx = d->FrameOfsX; dy = d->FrameOfsY; get_focused_obj_array(d->focusobj, objs); axis = move_objects(dx, dy, d, objs); if (! axis) { d->allclear = FALSE; } else { add_data_grid_to_objs(objs); } UpdateAll(objs); d->MouseMode = MOUSENONE; #if CLEAR_DRAG_INFO reset_drag_info(d); #endif return TRUE; default: break; } return FALSE; } static void ViewerEvSize(GtkWidget *w, GtkAllocation *allocation, gpointer client_data) { struct Viewer *d; d = (struct Viewer *) client_data; d->cx = allocation->width / 2; d->cy = allocation->height / 2; ChangeDPI(); } static gboolean ViewerEvPaint(GtkWidget *w, cairo_t *cr, gpointer client_data) { struct Viewer *d; d = (struct Viewer *) client_data; if (ZoomLock) { return TRUE; } if (Menulocal.pix && Menulocal.bg) { cairo_set_source_surface(cr, Menulocal.bg, nround(- d->hscroll + d->cx), nround(- d->vscroll + d->cy)); cairo_paint(cr); cairo_set_source_surface(cr, Menulocal.pix, nround(- d->hscroll + d->cx), nround(- d->vscroll + d->cy)); cairo_paint(cr); } if (! Globallock) { cairo_set_antialias(cr, CAIRO_ANTIALIAS_NONE); cairo_set_line_width(cr, 1); /* I think it is not necessary to check chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid). */ if (d->ShowFrame) { ShowFocusFrame(cr, d); } ShowPoints(cr, d); if (d->ShowLine) { ShowFocusLine(cr, d); } if (d->ShowRect) { ShowFrameRect(cr, d); } if (Menulocal.show_cross) { ShowCrossGauge(cr, d); } } if (! PaintLock && region) { cairo_region_destroy(region); region = NULL; } return FALSE; } static void ViewerEvVScroll(GtkRange *range, gpointer user_data) { struct Viewer *d; d = (struct Viewer *) user_data; d->vscroll = gtk_range_get_value(range); SetVRuler(d); main_window_redraw(); } static void ViewerEvHScroll(GtkRange *range, gpointer user_data) { struct Viewer *d; d = (struct Viewer *) user_data; d->hscroll = gtk_range_get_value(range); SetHRuler(d); main_window_redraw(); } void ViewerWinUpdate(char **objects) { int i, num, lock_state; struct FocusObj **focus; struct Viewer *d; lock_state = PaintLock; PaintLock = TRUE; d = &NgraphApp.Viewer; if (chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid) == NULL) { CloseGC(); CloseGRA(); OpenGRA(); OpenGC(); SetScroller(); ChangeDPI(); } CheckPage(); num = arraynum(d->focusobj); focus = arraydata(d->focusobj); for (i = num - 1; i >= 0; i--) { if (chkobjoid(focus[i]->obj, focus[i]->oid) == -1) { arrayndel2(d->focusobj, i); } } if (arraynum(d->focusobj) == 0) { clear_focus_obj(d); } if (d->allclear) { mx_clear(NULL, objects); mx_redraw(Menulocal.obj, Menulocal.inst, objects); } else if (region) { Menulocal.region = region; gra2cairo_clip_region(Menulocal.local, region); mx_redraw(Menulocal.obj, Menulocal.inst, objects); gra2cairo_clip_region(Menulocal.local, NULL); Menulocal.region = NULL; } PaintLock = lock_state; main_window_redraw(); d->allclear = TRUE; } static void SetHRuler(const struct Viewer *d) { gdouble x1, x2, zoom; int width; GdkWindow *win; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } width = gdk_window_get_width(win); zoom = Menulocal.PaperZoom / 10000.0; x1 = N2GTK_RULER_METRIC(calc_mouse_x(0, zoom, d)); x2 = x1 + N2GTK_RULER_METRIC(mxp2d(width)) / zoom; nruler_set_range(d->HRuler, x1, x2); } static void SetVRuler(const struct Viewer *d) { gdouble y1, y2, zoom; int height; GdkWindow *win; win = gtk_widget_get_window(d->Win); if (win == NULL) { return; } height = gdk_window_get_height(win); zoom = Menulocal.PaperZoom / 10000.0; y1 = N2GTK_RULER_METRIC(calc_mouse_y(0, zoom, d)); y2 = y1 + N2GTK_RULER_METRIC(mxp2d(height)) / zoom; nruler_set_range(d->VRuler, y1, y2); } #define CHECK_FOCUSED_OBJ_ERROR -1 #define CHECK_FOCUSED_OBJ_NOT_FOUND -2 static int check_focused_obj(struct narray *focusobj, struct objlist *fobj, int oid) { int i, num; struct FocusObj *focus; if (fobj == NULL) return CHECK_FOCUSED_OBJ_ERROR; num = arraynum(focusobj); for (i = 0; i < num; i++) { focus = *(struct FocusObj **) arraynget(focusobj, i); if (focus == NULL) continue; if (fobj == focus->obj && oid == focus->oid) { return i; } } return CHECK_FOCUSED_OBJ_NOT_FOUND; } static int add_focus_obj(struct narray *focusobj, struct objlist *obj, int oid) { struct FocusObj *focus; int r; if (chkobjfield(obj, "bbox")) return FALSE; r = check_focused_obj(focusobj, obj, oid); if (r != CHECK_FOCUSED_OBJ_NOT_FOUND) return FALSE; focus = (struct FocusObj *) g_malloc(sizeof(struct FocusObj)); if (! focus) return FALSE; focus->obj = obj; focus->oid = oid; arrayadd(focusobj, &focus); return TRUE; } static void clear_focus_obj(const struct Viewer *d) { arraydel2(d->focusobj); } static int check_drawrable(struct objlist *obj) { struct narray *array; int i, n; char *name; array = &Menulocal.drawrable; n = arraynum(array); for (i = 0; i < n; i++) { name = arraynget_str(array, i); if (g_strcmp0(name, obj->name) == 0) { return 0; } } return 1; } void Focus(struct objlist *fobj, int id, int add) { int oid, focus; N_VALUE *inst; int man, hidden, legend, axis, merge; struct Viewer *d; struct savedstdio save; if (fobj == NULL) { return; } d = &NgraphApp.Viewer; legend = chkobjchild(chkobject("legend"), fobj); axis = chkobjchild(chkobject("axis"), fobj); merge = chkobjchild(chkobject("merge"), fobj); if (! legend && ! axis && ! merge) { return; } if (check_drawrable(fobj)) { return; } if (! add) { UnFocus(); } inst = chkobjinst(fobj, id); _getobj(fobj, "oid", inst, &oid); _getobj(fobj, "hidden", inst, &hidden); if (hidden) { return; } ignorestdio(&save); if (axis) { getobj(fobj, "group_manager", id, 0, NULL, &man); if (man >= 0) { getobj(fobj, "oid", man, 0, NULL, &oid); } } focus = check_focused_obj(d->focusobj, fobj, oid); if (focus >= 0) { arrayndel2(d->focusobj, focus); } add_focus_obj(d->focusobj, fobj, oid); d->MouseMode = MOUSENONE; if (arraynum(d->focusobj) == 0) { UnFocus(); } d->allclear = FALSE; // UpdateAll(); d->ShowFrame = TRUE; /* this is inconvenient when one use single window mode. */ /* gtk_widget_grab_focus(d->Win); */ restorestdio(&save); } void UnFocus(void) { struct Viewer *d; d = &NgraphApp.Viewer; if (arraynum(d->focusobj) != 0) { clear_focus_obj(d); } d->ShowFrame = FALSE; if (arraynum(d->points) != 0) { arraydel2(d->points); } gtk_widget_queue_draw(d->Win); } #define GRID_MIN 16.0 #define GRIG_COLOR 0.7 static void draw_grid(cairo_t *cr, int w, int h) { int grid, x, y; double dx, dy, dw, dashes[] = {1.0, 1.0}; grid = Menulocal.grid; dw = mxd2p(grid); if (dw < GRID_MIN) { grid *= ceil(GRID_MIN / dw); } cairo_set_source_rgba(cr, GRIG_COLOR, GRIG_COLOR, GRIG_COLOR, 1); cairo_set_dash(cr, dashes, 2, 0); for (x = grid; x < Menulocal.PaperWidth; x += grid) { dx = mxd2p(x) + 1; cairo_move_to(cr, dx, 0); cairo_line_to(cr, dx, h); cairo_stroke(cr); } for (y = grid; y < Menulocal.PaperHeight; y += grid) { dy = mxd2p(y) + 1; cairo_move_to(cr, 0, dy); cairo_line_to(cr, w, dy); cairo_stroke(cr); } } void update_bg(void) { int w, h; cairo_t *cr; if (Menulocal.bg == NULL) { return; } cr = cairo_create(Menulocal.bg); cairo_set_source_rgb(cr, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); cairo_paint(cr); w = cairo_image_surface_get_width(Menulocal.bg) - CAIRO_COORDINATE_OFFSET; h = cairo_image_surface_get_height(Menulocal.bg) - CAIRO_COORDINATE_OFFSET; cairo_set_antialias(cr, CAIRO_ANTIALIAS_NONE); cairo_set_source_rgb(cr, 0, 0, 0); cairo_set_line_width(cr, 1); cairo_set_dash(cr, NULL, 0, 0); cairo_rectangle(cr, CAIRO_COORDINATE_OFFSET, CAIRO_COORDINATE_OFFSET, w, h); cairo_stroke(cr); if (Menulocal.show_grid) { draw_grid(cr, w, h); } cairo_destroy(cr); } static void create_layers(void) { int i, n; struct narray *array; char *obj; array = &Menulocal.drawrable; n = arraynum(array); for (i = 0; i < n; i++) { obj = arraynget_str(array, i); init_layer(obj); } } static void create_pix(int w, int h) { GdkWindow *window; window = gtk_widget_get_window(NgraphApp.Viewer.Win); if (window == NULL) { return; } if (w == 0) { w = 1; } if (h == 0) { h = 1; } if (Menulocal.pix) { cairo_surface_destroy(Menulocal.pix); } Menulocal.pix = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, w + 1, h + 1); if (Menulocal.bg) { cairo_surface_destroy(Menulocal.bg); } Menulocal.bg = cairo_image_surface_create(CAIRO_FORMAT_RGB24, w + 1, h + 1); create_layers(); /* draw background */ update_bg(); gra2cairo_set_antialias(Menulocal.local, Menulocal.antialias); #if 0 cairo_set_tolerance(Menulocal.local->cairo, 0.1); #endif Menulocal.local->offsetx = 0; Menulocal.local->offsety = 0; } void OpenGC(void) { int width, height; Menulocal.local->pixel_dot_x = Menulocal.local->pixel_dot_y = Menulocal.windpi / 25.4 / 100; Menulocal.local->offsetx = 0; Menulocal.local->offsety = 0; width = mxd2p(Menulocal.PaperWidth); height = mxd2p(Menulocal.PaperHeight); if (width == 0) width = 1; if (height == 0) height = 1; create_pix(width, height); Menulocal.region = NULL; } void SetScroller(void) { int width, height, x, y; struct Viewer *d; d = &NgraphApp.Viewer; width = mxd2p(Menulocal.PaperWidth); height = mxd2p(Menulocal.PaperHeight); x = width / 2; y = height / 2; gtk_range_set_range(GTK_RANGE(d->HScroll), 0, width); gtk_range_set_value(GTK_RANGE(d->HScroll), x); gtk_range_set_increments(GTK_RANGE(d->HScroll), 10, 40); gtk_range_set_range(GTK_RANGE(d->VScroll), 0, height); gtk_range_set_value(GTK_RANGE(d->VScroll), y); gtk_range_set_increments(GTK_RANGE(d->VScroll), 10, 40); d->hscroll = x; d->vscroll = y; } static double get_range_max(GtkWidget *w) { GtkAdjustment *adj; double val; adj = gtk_range_get_adjustment(GTK_RANGE(w)); val = (adj) ? gtk_adjustment_get_upper(adj) : 0; return val; } void ChangeDPI(void) { int width, height, i, num, XPos, YPos, XRange = 0, YRange = 0; gint w, h; N_VALUE *inst; double ratex, ratey; struct objlist *obj; struct narray *array; struct Viewer *d; d = &NgraphApp.Viewer; XRange = get_range_max(d->HScroll); YRange = get_range_max(d->VScroll); XPos = nround(d->hscroll); YPos = nround(d->vscroll); if (XPos < 0) { XPos = 0; } if (XPos > XRange) { XPos = XRange; } if (YPos < 0) { YPos = 0; } if (YPos > YRange) { YPos = YRange; } ratex = (XRange == 0) ? 0 : XPos / (double) XRange; ratey = (YRange == 0) ? 0 : YPos / (double) YRange; width = mxd2p(Menulocal.PaperWidth); height = mxd2p(Menulocal.PaperHeight); if (Menulocal.pix) { w = cairo_image_surface_get_width(Menulocal.pix) - 1; h = cairo_image_surface_get_height(Menulocal.pix) - 1; } else { h = w = 0; } if (w != width || h != height) { create_pix(width, height); mx_redraw(Menulocal.obj, Menulocal.inst, NULL); } XPos = nround(width * ratex); YPos = nround(height * ratey); gtk_range_set_range(GTK_RANGE(d->HScroll), 0, width); gtk_range_set_value(GTK_RANGE(d->HScroll), XPos); d->hscroll = XPos; gtk_range_set_range(GTK_RANGE(d->VScroll), 0, height); gtk_range_set_value(GTK_RANGE(d->VScroll), YPos); d->vscroll = YPos; if ((obj = chkobject("text")) != NULL) { num = chkobjlastinst(obj); for (i = 0; i <= num; i++) { inst = chkobjinst(obj, i); _getobj(obj, "bbox", inst, &array); arrayfree(array); _putobj(obj, "bbox", inst, NULL); } } main_window_redraw(); SetHRuler(d); SetVRuler(d); } void CloseGC(void) { if (Menulocal.region != NULL) { cairo_region_destroy(Menulocal.region); } Menulocal.region = NULL; UnFocus(); } void ReopenGC(void) { Menulocal.local->pixel_dot_x = Menulocal.local->pixel_dot_y = Menulocal.windpi / 25.4 / 100; if (Menulocal.region != NULL) { cairo_region_destroy(Menulocal.region); } Menulocal.region = NULL; } void Draw(int SelectFile) { struct Viewer *d; N_VALUE *gra_inst; draw_notify(FALSE); d = &NgraphApp.Viewer; if (SelectFile && !SetFileHidden()) return; ProgressDialogCreate(_("Scaling")); FileAutoScale(); AdjustAxis(); FitClear(); SetStatusBar(_("Drawing.")); ProgressDialogSetTitle(_("Drawing")); ReopenGC(); if (region) { cairo_region_destroy(region); } region = NULL; gra_inst = chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid); if (gra_inst != NULL) { d->ignoreredraw = TRUE; _exeobj(Menulocal.GRAobj, "clear", gra_inst, 0, NULL); // reset_event(); /* XmUpdateDisplay(d->Win); */ _exeobj(Menulocal.GRAobj, "draw", gra_inst, 0, NULL); _exeobj(Menulocal.GRAobj, "flush", gra_inst, 0, NULL); d->ignoreredraw = FALSE; } ResetStatusBar(); ProgressDialogFinalize(); main_window_redraw(); if (SelectFile) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); } } void CmViewerDraw(void *w, gpointer client_data) { int select_file; if (Menulock || Globallock) return; select_file = GPOINTER_TO_INT(client_data); Draw(select_file); FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, DRAW_NONE); } static int search_axis_group(struct objlist *obj, int id, const char *group, int *findX, int *findY, int *findU, int *findR, int *findG, int *idx, int *idy, int *idu, int *idr, int *idg) { int j, id2, type; struct objlist *aobj, *gobj; N_VALUE *inst2, *dinst; char *group2; int snum; *findX = *findY = *findU = *findR = *findG = FALSE; type = group[0]; for (j = 0; j <= id; j++) { inst2 = chkobjinst(obj, j); _getobj(obj, "group", inst2, &group2); _getobj(obj, "id", inst2, &id2); if (group2 == NULL || group2[0] != type) continue; if (strcmp(group + 2, group2 + 2) != 0) continue; if (group2[1] == 'X') { *findX = TRUE; *idx = id2; } else if (group2[1] == 'Y') { *findY = TRUE; *idy = id2; } else if (group2[1] == 'U') { *findU = TRUE; *idu = id2; } else if (group2[1] == 'R') { *findR = TRUE; *idr = id2; } } gobj = chkobject("axisgrid"); if ((type == 's' || type == 'f') && *findX && *findY && ! check_drawrable(gobj)) { snum = chkobjlastinst(gobj) + 1; for (j = 0; j < snum; j++) { int aid1, aid2; dinst = chkobjinst(gobj, j); if (dinst == NULL) { continue; } aid1 = get_axis_id(gobj, dinst, &aobj, AXIS_X); aid2 = get_axis_id(gobj, dinst, &aobj, AXIS_Y); if (aid1 >= 0 && aid2 >= 0 && obj == aobj && aid1 == *idx && aid2 == *idy) { *findG = TRUE; _getobj(gobj, "id", dinst, idg); break; } } } return type; } static void ViewUpdate(void) { int i, id, num, modified, undo; struct FocusObj *focus; struct objlist *obj, *dobj = NULL; N_VALUE *inst, *dinst; int ret; int x1, y1; int idx = 0, idy = 0, idu = 0, idr = 0, idg, lenx, leny; int findX, findY, findU, findR, findG; char type; char *group, *objs[OBJ_MAX]; int axis; struct Viewer *d; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; num = arraynum(d->focusobj); if (num < 1) { return; } d->ShowFrame = FALSE; d->ShowRect = FALSE; get_focused_obj_array(d->focusobj, objs); undo = menu_save_undo(UNDO_TYPE_EDIT, objs); axis = FALSE; PaintLock = TRUE; modified = FALSE; for (i = num - 1; i >= 0; i--) { focus = *(struct FocusObj **) arraynget(d->focusobj, i); if (focus == NULL) continue; inst = chkobjinstoid(focus->obj, focus->oid); if (inst == NULL) continue; obj = focus->obj; _getobj(obj, "id", inst, &id); ret = IDCANCEL; if (obj == chkobject("axis")) { axis = TRUE; _getobj(obj, "group", inst, &group); if (group && group[0] != 'a') { type = search_axis_group(obj, id, group, &findX, &findY, &findU, &findR, &findG, &idx, &idy, &idu, &idr, &idg); if (((type == 's') || (type == 'f')) && findX && findY && findU && findR) { dobj = chkobject("axisgrid"); if (! findG) { idg = -1; } getobj(obj, "y", idx, 0, NULL, &y1); getobj(obj, "x", idy, 0, NULL, &x1); getobj(obj, "y", idu, 0, NULL, &leny); getobj(obj, "x", idr, 0, NULL, &lenx); leny = y1 - leny; lenx = lenx - x1; SectionDialog(&DlgSection, x1, y1, lenx, leny, obj, idx, idy, idu, idr, dobj, &idg, type == 's'); ret = DialogExecute(TopLevel, &DlgSection); if (! findG && idg != -1) { dinst = chkobjinst(dobj, idg); if (dinst) { AddList(dobj, dinst); } } } else if ((type == 'c') && findX && findY) { getobj(obj, "x", idx, 0, NULL, &x1); getobj(obj, "y", idy, 0, NULL, &y1); getobj(obj, "length", idx, 0, NULL, &lenx); getobj(obj, "length", idy, 0, NULL, &leny); CrossDialog(&DlgCross, x1, y1, lenx, leny, obj, idx, idy); ret = DialogExecute(TopLevel, &DlgCross); } } else { AxisDialog(NgraphApp.AxisWin.data.data, id, TRUE); ret = DialogExecute(TopLevel, &DlgAxis); } } else { AddInvalidateRect(obj, inst); if (obj == chkobject("path")) { LegendArrowDialog(&DlgLegendArrow, obj, id); ret = DialogExecute(TopLevel, &DlgLegendArrow); } else if (obj == chkobject("rectangle")) { LegendRectDialog(&DlgLegendRect, obj, id); ret = DialogExecute(TopLevel, &DlgLegendRect); } else if (obj == chkobject("arc")) { LegendArcDialog(&DlgLegendArc, obj, id); ret = DialogExecute(TopLevel, &DlgLegendArc); } else if (obj == chkobject("mark")) { LegendMarkDialog(&DlgLegendMark, obj, id); ret = DialogExecute(TopLevel, &DlgLegendMark); } else if (obj == chkobject("text")) { LegendTextDialog(&DlgLegendText, obj, id); ret = DialogExecute(TopLevel, &DlgLegendText); } else if (obj == chkobject("merge")) { MergeDialog(NgraphApp.MergeWin.data.data, id, 0); ret = DialogExecute(TopLevel, &DlgMerge); } if (ret == IDDELETE) { set_graph_modified(); delobj(obj, id); } if (ret == IDOK) AddInvalidateRect(obj, inst); } if (ret != IDCANCEL) { modified = TRUE; } } PaintLock = FALSE; if (arraynum(d->focusobj) == 0) clear_focus_obj(d); if (modified) { if (! axis) { d->allclear = FALSE; } UpdateAll(objs); } else { menu_undo_internal(undo); } d->ShowFrame = TRUE; } static void ViewDelete(void) { int i, id, num; struct FocusObj *focus; struct objlist *obj; N_VALUE *inst; int axis; struct Viewer *d; char *objs[OBJ_MAX]; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; if ((d->MouseMode != MOUSENONE) || (d->Mode != PointB && d->Mode != LegendB && d->Mode != AxisB)) { return; } num = arraynum(d->focusobj); if (num <1) { return; } d->ShowFrame = FALSE; axis = FALSE; PaintLock = TRUE; get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_DELETE, objs); for (i = num - 1; i >= 0; i--) { focus = *(struct FocusObj **) arraynget(d->focusobj, i); obj = focus->obj; inst = chkobjinstoid(obj, focus->oid); if (inst == NULL) continue; AddInvalidateRect(obj, inst); DelList(obj, inst, d); _getobj(obj, "id", inst, &id); if (obj == chkobject("axis")) { AxisDel(id); axis = TRUE; } else { delobj(obj, id); } set_graph_modified(); } PaintLock = FALSE; if (! axis) d->allclear = FALSE; if (num != 0) UpdateAll(objs); NSetCursor(GDK_LEFT_PTR); } static void reorder_object(enum object_move_type type) { int id, num; struct FocusObj *focus; struct objlist *obj; N_VALUE *inst; struct Viewer *d; char *objects[2]; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; if (d->MouseMode != MOUSENONE || (d->Mode != PointB && d->Mode != LegendB && d->Mode != AxisB)) return; num = arraynum(d->focusobj); if (num != 1) return; focus = *(struct FocusObj **) arraynget(d->focusobj, 0); obj = focus->obj; if (! chkobjchild(chkobject("legend"), obj) && ! chkobjchild(chkobject("merge"), obj)) return; inst = chkobjinstoid(obj, focus->oid); if (inst == NULL) return; menu_save_undo_single(UNDO_TYPE_ORDER, obj->name); DelList(obj, inst, d); _getobj(obj, "id", inst, &id); switch (type) { case OBJECT_MOVE_TYPE_TOP: movetopobj(obj, id); break; case OBJECT_MOVE_TYPE_LAST: movelastobj(obj, id); break; case OBJECT_MOVE_TYPE_UP: moveupobj(obj, id); break; case OBJECT_MOVE_TYPE_DOWN: movedownobj(obj, id); break; } AddList(obj, inst); set_graph_modified(); d->allclear = TRUE; objects[0] = obj->name; objects[1] = NULL; UpdateAll(objects); } static void ncopyobj(struct objlist *obj, int id1, int id2) { char *field[] = {"name", NULL}; copy_obj_field(obj, id1, id2, field); } static void ViewCopyAxis(struct objlist *obj, int id, struct FocusObj *focus, N_VALUE *inst) { int id2; struct objlist *dobj; N_VALUE *inst2; int findX, findY, findU, findR, findG; char *axisx, *axisy; int oidx, oidy; int idx = 0, idy = 0, idu = 0, idr = 0, idg; int idx2, idy2, idu2, idr2, idg2; char type; char *group; int tp; struct narray agroup; char *argv[2]; _getobj(obj, "group", inst, &group); if (group && group[0] != 'a') { type = search_axis_group(obj, id, group, &findX, &findY, &findU, &findR, &findG, &idx, &idy, &idu, &idr, &idg); if (((type == 's') || (type == 'f')) && findX && findY && findU && findR) { if ((idx2 = newobj(obj)) >= 0) { ncopyobj(obj, idx2, idx); inst2 = chkobjinst(obj, idx2); _getobj(obj, "oid", inst2, &oidx); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if ((idy2 = newobj(obj)) >= 0) { ncopyobj(obj, idy2, idy); inst2 = chkobjinst(obj, idy2); _getobj(obj, "oid", inst2, &oidy); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if ((idu2 = newobj(obj)) >= 0) { ncopyobj(obj, idu2, idu); inst2 = chkobjinst(obj, idu2); if (idx2 >= 0) { axisx = g_strdup_printf("axis:^%d", oidx); if (axisx) { putobj(obj, "reference", idu2, axisx); } } AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if ((idr2 = newobj(obj)) >= 0) { ncopyobj(obj, idr2, idr); inst2 = chkobjinst(obj, idr2); if (idy2 >= 0) { axisy = g_strdup_printf("axis:^%d", oidy); if(axisy) { putobj(obj, "reference", idr2, axisy); } } arrayinit(&agroup, sizeof(int)); if (type == 'f') tp = 1; else tp = 2; arrayadd(&agroup, &tp); arrayadd(&agroup, &idx2); arrayadd(&agroup, &idy2); arrayadd(&agroup, &idu2); arrayadd(&agroup, &idr2); argv[0] = (char *) &agroup; argv[1] = NULL; exeobj(obj, "grouping", idr2, 1, argv); arraydel(&agroup); _getobj(obj, "oid", inst2, &(focus->oid)); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if (findG) { dobj = chkobject("axisgrid"); if ((idg2 = newobj(dobj)) >= 0) { ncopyobj(dobj, idg2, idg); inst2 = chkobjinst(dobj, idg2); if (idx2 >= 0 && idu2 >= 0) { axisx = g_strdup_printf("axis:^%d", oidx); if (axisx) { putobj(dobj, "axis_x", idg2, axisx); } } if (idy2 >= 0 && idr2 >= 0) { axisy = g_strdup_printf("axis:^%d", oidy); if (axisy) { putobj(dobj, "axis_y", idg2, axisy); } } AddList(dobj, inst2); set_graph_modified(); } } } else if ((type == 'c') && findX && findY) { if ((idx2 = newobj(obj)) >= 0) { ncopyobj(obj, idx2, idx); inst2 = chkobjinst(obj, idx2); _getobj(obj, "oid", inst2, &oidx); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if ((idy2 = newobj(obj)) >= 0) { ncopyobj(obj, idy2, idy); inst2 = chkobjinst(obj, idy2); _getobj(obj, "oid", inst2, &oidy); arrayinit(&agroup, sizeof(int)); tp = 3; arrayadd(&agroup, &tp); arrayadd(&agroup, &idx2); arrayadd(&agroup, &idy2); argv[0] = (char *) &agroup; argv[1] = NULL; exeobj(obj, "grouping", idy2, 1, argv); arraydel(&agroup); focus->oid = oidy; AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } if (idx2 >= 0 && idy2 >= 0) { axisy = g_strdup_printf("axis:^%d", oidy); if (axisy) { putobj(obj, "adjust_axis", idx2, axisy); } axisx = g_strdup_printf("axis:^%d", oidx); if (axisx) { putobj(obj, "adjust_axis", idy2, axisx); } } } } else { if ((id2 = newobj(obj)) >= 0) { ncopyobj(obj, id2, id); inst2 = chkobjinst(obj, id2); _getobj(obj, "oid", inst2, &(focus->oid)); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } } } static void ViewCopy(void) { int i, id, id2, num; struct FocusObj *focus; struct objlist *obj; N_VALUE *inst, *inst2; int axis = FALSE; struct Viewer *d; char *objs[OBJ_MAX]; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; if (d->MouseMode != MOUSENONE || ! (d->Mode & POINT_TYPE_POINT)) { return; } num = arraynum(d->focusobj); if (num < 1) { return; } d->ShowFrame = FALSE; axis = FALSE; PaintLock = TRUE; get_focused_obj_array(d->focusobj, objs); menu_save_undo(UNDO_TYPE_COPY, objs); for (i = 0; i < num; i++) { focus = * (struct FocusObj **) arraynget(d->focusobj, i); if (focus == NULL) continue; inst = chkobjinstoid(focus->obj, focus->oid); if (inst == NULL) continue; obj = focus->obj; _getobj(obj, "id", inst, &id); if (obj == chkobject("axis")) { axis = TRUE; ViewCopyAxis(obj, id, focus, inst); } else { if ((id2 = newobj(obj)) >= 0) { ncopyobj(obj, id2, id); inst2 = chkobjinst(obj, id2); _getobj(obj, "oid", inst2, &(focus->oid)); AddList(obj, inst2); AddInvalidateRect(obj, inst2); set_graph_modified(); } else { AddInvalidateRect(obj, inst); } } } PaintLock = FALSE; if (! axis) d->allclear = FALSE; UpdateAll(objs); d->ShowFrame = TRUE; } void ViewCross(int state) { struct Viewer *d; if (Menulock || Globallock) return; d = &NgraphApp.Viewer; Menulocal.show_cross = state; if (gtk_widget_is_drawable(d->Win)) { gtk_widget_queue_draw(d->Win); } } void ViewerUpdateCB(void *w, gpointer client_data) { ViewUpdate(); } gboolean CmViewerButtonPressed(GtkWidget *widget, GdkEventButton *event, gpointer user_data) { KeepMouseMode = (event->state & GDK_SHIFT_MASK); return FALSE; } void CmEditMenuCB(void *w, gpointer client_data) { if (Menulock || Globallock) return; switch (GPOINTER_TO_INT(client_data)) { case MenuIdEditRedo: menu_redo(); break; case MenuIdEditUndo: menu_undo(); break; case MenuIdEditCut: CutFocusedObjects(); break; case MenuIdEditCopy: CopyFocusedObjects(); break; case MenuIdEditPaste: PasteObjectsFromClipboard(); break; case MenuIdEditDelete: ViewDelete(); break; case MenuIdEditDuplicate: ViewCopy(); break; case MenuIdAlignLeft: AlignFocusedObj(VIEW_ALIGN_LEFT); break; case MenuIdAlignVCenter: AlignFocusedObj(VIEW_ALIGN_VCENTER); break; case MenuIdAlignRight: AlignFocusedObj(VIEW_ALIGN_RIGHT); break; case MenuIdAlignTop: AlignFocusedObj(VIEW_ALIGN_TOP); break; case MenuIdAlignHCenter: AlignFocusedObj(VIEW_ALIGN_HCENTER); break; case MenuIdAlignBottom: AlignFocusedObj(VIEW_ALIGN_BOTTOM); break; case MenuIdEditRotateCW: RotateFocusedObj(ROTATE_CLOCKWISE); break; case MenuIdEditRotateCCW: RotateFocusedObj(ROTATE_COUNTERCLOCKWISE); break; case MenuIdEditFlipHorizontally: FlipFocusedObj(FLIP_DIRECTION_HORIZONTAL); break; case MenuIdEditFlipVertically: FlipFocusedObj(FLIP_DIRECTION_VERTICAL); break; case MenuIdEditOrderTop: reorder_object(OBJECT_MOVE_TYPE_TOP); break; case MenuIdEditOrderUp: reorder_object(OBJECT_MOVE_TYPE_UP); break; case MenuIdEditOrderDown: reorder_object(OBJECT_MOVE_TYPE_DOWN); break; case MenuIdEditOrderBottom: reorder_object(OBJECT_MOVE_TYPE_LAST); break; } set_focus_sensitivity(&(NgraphApp.Viewer)); } ngraph-gtk-6.08.00/src/gtk/ox11menu.h0000644000175000017500000001164713362614566014077 00000000000000/* * $Id: ox11menu.h,v 1.37 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for GTK". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for GTK" 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. * * "Ngraph for GTK" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "nhash.h" #ifndef _O_X11_MENU_HEADER #define _O_X11_MENU_HEADER #define LINETOLIMIT 500 #define DEFAULT_GEOMETRY -100000 #define ERRRUN 100 #define ERRCMAP 101 #define ERRFONT 102 #define HIST_SIZE_MAX 10000 #define INFOWIN_SIZE_MAX 10000 extern int Globallock; extern struct savedstdio GtkIOSave; enum paper_id { PAPER_ID_A3, PAPER_ID_A4, PAPER_ID_A5, PAPER_ID_B4, PAPER_ID_B5, PAPER_ID_LETTER, PAPER_ID_LEGAL, PAPER_ID_NORMAL, PAPER_ID_WIDE, PAPER_ID_CUSTOM, }; struct extprinter { char *name; char *driver; char *ext; char *option; struct extprinter *next; }; struct script { char *name; char *script; char *description; char *option; struct script *next; }; struct prnprinter { char *name; char *driver; char *option; char *prn; struct prnprinter *next; }; struct character_map_list { char *title, *data; struct character_map_list *next; }; struct layer { cairo_surface_t *pix; cairo_t *cairo; }; struct menulocal { cairo_surface_t *pix, *bg; NHASH layers; int redrawf, redrawf_num; int windpi, data_head_lines; int grid, show_grid; int modified; cairo_region_t *region; int lock; struct gra2cairo_local *local; int antialias; char *editor, *browser, *help_browser; struct objlist *obj; N_VALUE *inst; struct objlist *GRAobj; int GRAoid; int GC; int PaperWidth, PaperHeight, PaperLandscape; char *PaperName, *Palette; enum paper_id PaperId; int LeftMargin, TopMargin; int PaperZoom; struct narray drawrable; struct extprinter *extprinterroot; struct script *scriptroot, *addin_list; int menuheight, menuwidth, menux, menuy; int exwindpi, exwinwidth, exwinheight, exwin_use_external; char *fileopendir, *graphloaddir, *expanddir, *coordwin_font, *infowin_font, *file_preview_font; int expand, loadpath, expandtofullpath, changedirectory, savehistory; int savepath, savewithdata, savewithmerge; int scriptconsole, addinconsole; int statusbar, sidebar, ruler, scrollbar, ctoolbar, ptoolbar, show_cross, showtip, preserve_width; int hist_size, info_size; double bg_r, bg_g, bg_b; int focus_frame_type, use_opacity, select_data; int side_pane1_pos, side_pane2_pos, side_pane3_pos, main_pane_pos; int file_tab, axis_tab, merge_tab, path_tab, rectangle_tab, arc_tab, mark_tab, text_tab; #ifdef WINDOWS int emf_dpi; #endif int png_dpi, ps_version, svg_version; struct character_map_list *char_map; int use_custom_palette; struct narray custom_palette; char *source_style_id; int math_input_mode; }; extern struct menulocal Menulocal; enum SAVE_CONFIG_TYPE { SAVE_CONFIG_TYPE_GEOMETRY = 0x0001, SAVE_CONFIG_TYPE_VIEWER = 0x0002, SAVE_CONFIG_TYPE_EXTERNAL_DRIVER = 0x0004, SAVE_CONFIG_TYPE_ADDIN_SCRIPT = 0x0008, SAVE_CONFIG_TYPE_MISC = 0x0010, SAVE_CONFIG_TYPE_EXTERNAL_VIEWER = 0x0020, SAVE_CONFIG_TYPE_FONTS = 0x0040, SAVE_CONFIG_TYPE_TOGGLE_VIEW = 0x0080, SAVE_CONFIG_TYPE_OTHERS = 0x0100, }; #define SAVE_CONFIG_TYPE_X11MENU (SAVE_CONFIG_TYPE_GEOMETRY \ | SAVE_CONFIG_TYPE_VIEWER \ | SAVE_CONFIG_TYPE_EXTERNAL_VIEWER \ | SAVE_CONFIG_TYPE_EXTERNAL_DRIVER \ | SAVE_CONFIG_TYPE_ADDIN_SCRIPT \ | SAVE_CONFIG_TYPE_MISC) void mx_redraw(struct objlist *obj, N_VALUE *inst, char **objects); void mx_clear(cairo_region_t *region, char **objects); void mx_inslist(struct objlist *obj, N_VALUE *inst, struct objlist *aobj, N_VALUE *ainst, char *afield, int addn); void mx_dellist(struct objlist *obj, N_VALUE *inst, int deln); void mgtkdisplaydialog(const char *str); void mgtkdisplaystatus(const char *str); int mgtkputstderr(const char *s); int mgtkprintfstderr(const char *fmt, ...); int mgtkinterrupt(void); int mgtkinputyn(const char *mes); int mgtkputstdout(const char *s); int mgtkprintfstdout(const char *fmt, ...); void initwindowconfig(void); int mgtkwindowconfig(void); void menuadddrawrable(struct objlist *parent, struct narray *drawrable); int menu_save_config(int type); void main_window_redraw(void); void init_layer(const char *obj); #endif ngraph-gtk-6.08.00/src/gtk/x11lgnd.h0000644000175000017500000000343013351432267013661 00000000000000/* * $Id: x11lgnd.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ typedef void (* legend_cb_func)(GtkMenuItem *w, gpointer client_data); void LegendWinUpdate(char **objects, int clear, int draw); void CmLineUpdate(void *w, gpointer client_data); void CmLineDel(void *w, gpointer client_data); void CmRectUpdate(void *w, gpointer client_data); void CmRectDel(void *w, gpointer client_data); void CmArcUpdate(void *w, gpointer client_data); void CmArcDel(void *w, gpointer client_data); void CmMarkUpdate(void *w, gpointer client_data); void CmMarkDel(void *w, gpointer client_data); void CmTextUpdate(void *w, gpointer client_data); void CmTextDel(void *w, gpointer client_data); GtkWidget *create_path_list(struct SubWin *d); GtkWidget *create_rect_list(struct SubWin *d); GtkWidget *create_arc_list(struct SubWin *d); GtkWidget *create_mark_list(struct SubWin *d); GtkWidget *create_text_list(struct SubWin *d); void CmOptionTextDef(void *w, gpointer client_data); ngraph-gtk-6.08.00/src/gtk/x11info.c0000644000175000017500000000567413351432267013677 00000000000000/* * $Id: x11info.c,v 1.9 2009-07-22 14:53:31 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include "object.h" #include "gtk_widget.h" #include "gtk_subwin.h" #include "x11bitmp.h" #include "x11gui.h" #include "ox11menu.h" #include "x11menu.h" #include "x11info.h" void InfoWinSetFont(char *font) { if (NgraphApp.InfoWin.data.text && font) { #if GTK_CHECK_VERSION(3, 16, 0) set_widget_font(NgraphApp.InfoWin.data.text, font); #else /* GTK_CHECK_VERSION(3, 16, 0) */ PangoFontDescription *desc; desc = pango_font_description_from_string(font); gtk_widget_override_font(GTK_WIDGET(NgraphApp.InfoWin.data.text), NULL); gtk_widget_override_font(GTK_WIDGET(NgraphApp.InfoWin.data.text), desc); pango_font_description_free(desc); #endif } } void InfoWinDrawInfoText(const char *str) { GtkTextBuffer *buf; GtkTextIter iter; gint len; GtkTextMark *mark; if (str == NULL) return; if (NgraphApp.InfoWin.Win == NULL) { return; } if (NgraphApp.InfoWin.data.text == NULL) { return; } buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(NgraphApp.InfoWin.data.text)); gtk_text_buffer_get_end_iter(buf, &iter); gtk_text_buffer_insert(buf, &iter, str, -1); len = gtk_text_buffer_get_line_count(buf); if (len > Menulocal.info_size) { GtkTextIter start, end; gtk_text_buffer_get_start_iter(buf, &start); gtk_text_buffer_get_iter_at_line(buf, &end, len - Menulocal.info_size); gtk_text_buffer_delete(buf, &start, &end); } gtk_text_buffer_get_end_iter(buf, &iter); gtk_text_buffer_place_cursor(buf, &iter); mark = gtk_text_buffer_get_selection_bound(buf); gtk_text_view_scroll_mark_onscreen(GTK_TEXT_VIEW(NgraphApp.InfoWin.data.text), mark); } void InfoWinClear(void) { GtkTextBuffer *buf; if (NgraphApp.InfoWin.data.text == NULL) return; buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(NgraphApp.InfoWin.data.text)); gtk_text_buffer_set_text(buf, "", 0); } void InfoWinUpdate(int clear) { } GtkWidget * InfoWinCreate(struct SubWin *d) { if (d->Win) { return d->Win; } text_sub_window_create(d); InfoWinSetFont(Menulocal.infowin_font); return d->Win; } ngraph-gtk-6.08.00/src/gtk/x11opt.h0000644000175000017500000000240713070106167013535 00000000000000/* * $Id: x11opt.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void CmOptionViewer(void *w, gpointer client_data); void CmOptionExtViewer(void *w, gpointer client_data); void CmOptionPrefFont(void *w, gpointer client_data); void CmOptionScript(void *w, gpointer client_datavoid); void CmOptionMisc(void *w, gpointer client_data); void CmOptionSaveDefault(void *w, gpointer client_data); void CmOptionSaveNgp(void *w, gpointer client_data); ngraph-gtk-6.08.00/src/gtk/gtk_liststore.h0000644000175000017500000001431413070106167015276 00000000000000/* * $Id: gtk_liststore.h,v 1.11 2009-08-19 06:44:16 hito Exp $ */ #ifndef _GTK_LISTSTORE_HEADER #define _GTK_LISTSTORE_HEADER #include "object.h" enum TOGGLE_TYPE { TOGGLE_NONE, TOGGLE_CHECK, TOGGLE_RADIO, }; enum OBJECT_COLUMN_TYPE { OBJECT_COLUMN_TYPE_TOGGLE, OBJECT_COLUMN_TYPE_STRING, OBJECT_COLUMN_TYPE_PIXBUF, OBJECT_COLUMN_TYPE_INT, OBJECT_COLUMN_TYPE_ENUM, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, OBJECT_COLUMN_TYPE_TOGGLE_IS_RADIO, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, OBJECT_COLUMN_TYPE_NUM, }; typedef struct _list_store { char *title; GType type; gboolean visible, editable; char *name; int min, max, inc, page; PangoEllipsizeMode ellipsize; gulong edited_id; } n_list_store; void tree_view_set_tooltip_column(GtkTreeView *tree_view, gint column); void tree_view_set_no_expand_column(GtkWidget *tview, const int *columns, int n); void init_object_combo_box(GtkWidget *cbox); void add_separator_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent); void add_line_style_item_to_cbox(GtkTreeStore *list, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id); void add_bool_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id, const char *title); void add_mark_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id); void add_enum_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id); void add_font_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, struct objlist *obj, const char *field, int id); void add_text_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id, int enum_id, const char *title, enum TOGGLE_TYPE type, int active); void add_font_style_combo_item_to_cbox(GtkTreeStore *list, GtkTreeIter *iter, GtkTreeIter *parent, int column_id_bold, int column_id_italic, struct objlist *obj, const char *field, int id); GtkWidget *list_store_create(int n, n_list_store *list); void list_store_set_val(GtkWidget *w, GtkTreeIter *iter, int col, GType type, void *ptr); void list_store_set_sort_all(GtkWidget *tview); void list_store_set_sort_column(GtkWidget *tview, int col); void list_store_set_align(GtkWidget *tview, int col, double align); int list_store_get_int(GtkWidget *w, GtkTreeIter *iter, int col); void list_store_set_int(GtkWidget *w, GtkTreeIter *iter, int col, int v); int list_store_path_get_int(GtkWidget *w, GtkTreePath *path, int col, int *val); void list_store_set_double(GtkWidget *w, GtkTreeIter *iter, int col, double v); void tree_store_set_double(GtkWidget *w, GtkTreeIter *iter, int col, double v); char *list_store_get_string(GtkWidget *w, GtkTreeIter *iter, int col); void list_store_set_string(GtkWidget *w, GtkTreeIter *iter, int col, const char *v); gboolean list_store_get_boolean(GtkWidget *w, GtkTreeIter *iter, int col); void list_store_set_boolean(GtkWidget *w, GtkTreeIter *iter, int col, int v); void list_store_path_set_string(GtkWidget *w, GtkTreePath *path, int col, const char *v); char *list_store_path_get_string(GtkWidget *w, GtkTreePath *path, int col); gboolean list_store_get_iter_first(GtkWidget *w, GtkTreeIter *iter); gboolean list_store_iter_next(GtkWidget *w, GtkTreeIter *iter); void list_store_append(GtkWidget *w, GtkTreeIter *iter); void list_store_clear(GtkWidget *w); gboolean list_store_get_selected_iter(GtkWidget *w, GtkTreeIter *iter); int list_store_get_selected_int(GtkWidget *w, int col); void list_store_select_int(GtkWidget *w, int col, int id); char *list_store_get_selected_string(GtkWidget *w, int col); int list_store_get_num(GtkWidget *w); void list_store_set_selection_mode(GtkWidget *w, GtkSelectionMode mode); void list_store_select_nth(GtkWidget *w, int n); void list_store_select_iter(GtkWidget *w, GtkTreeIter *iter); void list_store_multi_select_nth(GtkWidget *w, int n, int m); gboolean list_store_get_selected_nth(GtkWidget *w, int *n); int list_store_get_selected_index(GtkWidget *w); void list_store_set_pixbuf(GtkWidget *w, GtkTreeIter *iter, int col, GdkPixbuf *v); GdkPixbuf *list_store_get_pixbuf(GtkWidget *w, GtkTreeIter *iter, int col); void list_store_select_all(GtkWidget *w); GtkWidget *tree_store_create(int n, n_list_store *list); void tree_store_append(GtkWidget *w, GtkTreeIter *iter, GtkTreeIter *parent); void tree_store_prepend(GtkWidget *w, GtkTreeIter *iter, GtkTreeIter *parent); gboolean tree_store_get_iter_children(GtkWidget *w, GtkTreeIter *child, GtkTreeIter *iter); gboolean tree_store_get_selected_nth(GtkWidget *w, int *n, int *m); void tree_store_select_nth(GtkWidget *w, int n, int m); void tree_store_clear(GtkWidget *w); int tree_store_get_child_num(GtkWidget *w, GtkTreeIter *iter); void tree_store_set_int(GtkWidget *w, GtkTreeIter *iter, int col, int v); void tree_store_set_string(GtkWidget *w, GtkTreeIter *iter, int col, const char *v); void tree_store_set_boolean(GtkWidget *w, GtkTreeIter *iter, int col, int v); void tree_store_set_val(GtkWidget *w, GtkTreeIter *iter, int col, GType type, void *ptr); void list_store_select_all_cb(GtkButton *w, gpointer client_data); void list_store_remove_selected_cb(GtkWidget *w, gpointer client_data); void free_tree_path_cb(gpointer data, gpointer user_data); void tree_store_selected_toggle_expand(GtkWidget *w); int tree_view_get_selected_row_int_from_path(GtkWidget *view, gchar *path, GtkTreeIter *iter, int col); #define tree_store_get_int list_store_get_int #define tree_store_get_boolean list_store_get_boolean #define tree_store_get_string list_store_get_string #define tree_store_get_iter_first list_store_get_iter_first #define tree_store_iter_next list_store_iter_next #define tree_store_get_selected_iter list_store_get_selected_iter #define tree_store_set_selection_mode list_store_set_selection_mode #define tree_store_path_get_string list_store_path_get_string #define tree_store_set_sort_all list_store_set_sort_all #define tree_store_set_sort_column list_store_set_sort_column #define tree_store_select_all_cb list_store_select_all_cb #define tree_store_set_align list_store_set_align #endif ngraph-gtk-6.08.00/src/gtk/gtk_entry_completion.h0000644000175000017500000000066213070106167016641 00000000000000/* * $Id: gtk_entry_completion.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ */ GtkEntryCompletion *entry_completion_create(void); void entry_completion_set_entry(GtkEntryCompletion *comp, GtkWidget *entry); int entry_completion_save(GtkEntryCompletion *comp, char *file, int size); int entry_completion_load(GtkEntryCompletion *comp, char *file, int size); void entry_completion_append(GtkEntryCompletion *comp, const char *str); ngraph-gtk-6.08.00/src/gtk/x11merge.c0000644000175000017500000003162513356133076014037 00000000000000/* * $Id: x11merge.c,v 1.33 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include "object.h" #include "nstring.h" #include "ioutil.h" #include "gtk_liststore.h" #include "gtk_subwin.h" #include "gtk_widget.h" #include "x11bitmp.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "ox11menu.h" #include "x11file.h" #include "x11merge.h" #include "x11commn.h" #include "x11view.h" static n_list_store Mlist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {N_("file"), G_TYPE_STRING, TRUE, TRUE, "file"}, {N_("top"), G_TYPE_DOUBLE, TRUE, TRUE, "top_margin", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("left"), G_TYPE_DOUBLE, TRUE, TRUE, "left_margin", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("zoom_x"), G_TYPE_DOUBLE, TRUE, TRUE, "zoom_x", 0, SPIN_ENTRY_MAX, 100, 1000}, {N_("zoom_y"), G_TYPE_DOUBLE, TRUE, TRUE, "zoom_y", 0, SPIN_ENTRY_MAX, 100, 1000}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, }; #define MERG_WIN_COL_NUM (sizeof(Mlist)/sizeof(*Mlist)) #define MERG_WIN_COL_OID (MERG_WIN_COL_NUM - 1) #define MERG_WIN_COL_HIDDEN 0 #define MERG_WIN_COL_ID 1 #define MERG_WIN_COL_FILE 2 static void merge_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static struct subwin_popup_list Popup_list[] = { {N_("_Add"), G_CALLBACK(CmMergeOpen), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Duplicate"), G_CALLBACK(list_sub_window_copy), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Delete"), G_CALLBACK(list_sub_window_delete), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {"_Focus", G_CALLBACK(list_sub_window_focus), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Preferences"), G_CALLBACK(list_sub_window_update), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Instance name"), G_CALLBACK(list_sub_window_object_name), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Top"), G_CALLBACK(list_sub_window_move_top), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Up"), G_CALLBACK(list_sub_window_move_up), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Down"), G_CALLBACK(list_sub_window_move_down), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Bottom"), G_CALLBACK(list_sub_window_move_last), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; #define POPUP_ITEM_NUM (sizeof(Popup_list) / sizeof(*Popup_list) - 1) #define POPUP_ITEM_TOP 8 #define POPUP_ITEM_UP 9 #define POPUP_ITEM_DOWN 10 #define POPUP_ITEM_BOTTOM 11 static void MergeDialogSetupItem(struct MergeDialog *d, int file, int id) { if (file) { SetWidgetFromObjField(d->file, d->Obj, id, "file"); gtk_editable_set_position(GTK_EDITABLE(d->file), -1); } SetWidgetFromObjField(d->topmargin, d->Obj, id, "top_margin"); SetWidgetFromObjField(d->leftmargin, d->Obj, id, "left_margin"); SetWidgetFromObjField(d->zoom_x, d->Obj, id, "zoom_x"); SetWidgetFromObjField(d->zoom_y, d->Obj, id, "zoom_y"); } static void MergeDialogCopy(GtkWidget *w, gpointer data) { struct MergeDialog *d; int sel; d = (struct MergeDialog *) data; sel = CopyClick(d->widget, d->Obj, d->Id, FileCB); if (sel != -1) { MergeDialogSetupItem(d, FALSE, sel); } } static void MergeDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *frame, *table; struct MergeDialog *d; char title[64]; int i; d = (struct MergeDialog *) data; snprintf(title, sizeof(title), _("Merge %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { table = gtk_grid_new(); i = 0; w = create_file_entry(d->Obj); add_widget_to_table(table, w, _("_File:"), TRUE, i++); d->file = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("_Top Margin:"), FALSE, i++); d->topmargin = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("_Left Margin:"), FALSE, i++); d->leftmargin = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); add_widget_to_table(table, w, _("zoom _X:"), FALSE, i++); d->zoom_x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); add_widget_to_table(table, w, _("zoom _Y:"), FALSE, i++); d->zoom_y = w; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(d->vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(MergeDialogCopy), d, "merge"); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } MergeDialogSetupItem(d, TRUE, d->Id); } static void MergeDialogClose(GtkWidget *w, void *data) { struct MergeDialog *d; int ret; d = (struct MergeDialog *) data; switch(d->ret) { case IDOK: break; default: return; } ret = d->ret; d->ret = IDLOOP; if (SetObjFieldFromWidget(d->file, d->Obj, d->Id, "file")) return; if (SetObjFieldFromWidget(d->topmargin, d->Obj, d->Id, "top_margin")) return; if (SetObjFieldFromWidget(d->leftmargin, d->Obj, d->Id, "left_margin")) return; if (SetObjFieldFromWidget(d->zoom_x, d->Obj, d->Id, "zoom_x")) return; if (SetObjFieldFromWidget(d->zoom_y, d->Obj, d->Id, "zoom_y")) return; d->ret = ret; } void MergeDialog(struct obj_list_data *data, int id, int user_data) { struct MergeDialog *d; d = (struct MergeDialog *) data->dialog; d->SetupWindow = MergeDialogSetup; d->CloseWindow = MergeDialogClose; d->Obj = data->obj; d->Id = id; } void CmMergeOpen(void *w, gpointer client_data) { struct objlist *obj; char *name = NULL; int id, ret, undo; if (Menulock || Globallock) return; if ((obj = chkobject("merge")) == NULL) return; if (nGetOpenFileName(TopLevel, _("Add Merge file"), "gra", NULL, NULL, &name, TRUE, Menulocal.changedirectory) != IDOK || ! name) return; undo = menu_save_undo_single(UNDO_TYPE_CREATE, obj->name); id = newobj(obj); if (id >= 0) { changefilename(name); putobj(obj, "file", id, name); MergeDialog(NgraphApp.MergeWin.data.data, id, -1); ret = DialogExecute(TopLevel, &DlgMerge); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } } else { g_free(name); } MergeWinUpdate(NgraphApp.MergeWin.data.data, TRUE, DRAW_NOTIFY); } void CmMergeClose(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i; int num, *array; if (Menulock || Globallock) return; if ((obj = chkobject("merge")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("close merge file (multi select)"), FileCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); if (num > 0) { menu_save_undo_single(UNDO_TYPE_DELETE, obj->name); } array = arraydata(&farray); for (i = num - 1; i >= 0; i--) { delobj(obj, array[i]); set_graph_modified(); } MergeWinUpdate(NgraphApp.MergeWin.data.data, TRUE, TRUE); } arraydel(&farray); } void CmMergeUpdate(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i, ret, modified; int *array, num; if (Menulock || Globallock) return; if ((obj = chkobject("merge")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("merge file property (multi select)"), FileCB, (struct narray *) &farray, NULL); modified = FALSE; if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); if (num > 0) { menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); } array = arraydata(&farray); for (i = 0; i < num; i++) { MergeDialog(NgraphApp.MergeWin.data.data, array[i], -1); ret = DialogExecute(TopLevel, &DlgMerge); if (ret != IDCANCEL) { modified = TRUE; } } if (modified) { MergeWinUpdate(NgraphApp.MergeWin.data.data, TRUE, TRUE); } } arraydel(&farray); } void MergeWinUpdate(struct obj_list_data *d, int clear, int draw) { int redraw; if (Menulock || Globallock) return; if (d == NULL) return; if (list_sub_window_must_rebuild(d)) { list_sub_window_build(d, merge_list_set_val); } else { list_sub_window_set(d, merge_list_set_val); } if (! clear && d->select >= 0) { list_store_select_int(GTK_WIDGET(d->text), MERG_WIN_COL_ID, d->select); } switch (draw) { case DRAW_REDRAW: getobj(Menulocal.obj, "redraw_flag", 0, 0, NULL, &redraw); if (redraw) { NgraphApp.Viewer.allclear = TRUE; update_viewer(d); } else { draw_notify(TRUE); } break; case DRAW_NOTIFY: draw_notify(TRUE); break; } } static void merge_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx; unsigned int i = 0; char *file, *bfile; for (i = 0; i < MERG_WIN_COL_NUM; i++) { switch (i) { case MERG_WIN_COL_FILE: getobj(d->obj, "file", row, 0, NULL, &file); bfile = getbasename(file); if (bfile) { list_store_set_string(GTK_WIDGET(d->text), iter, i, CHK_STR(bfile)); g_free(bfile); } else { list_store_set_string(GTK_WIDGET(d->text), iter, i, "...................."); } break; case MERG_WIN_COL_HIDDEN: getobj(d->obj, Mlist[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_val(GTK_WIDGET(d->text), iter, i, Mlist[i].type, &cx); break; default: if (Mlist[i].type == G_TYPE_DOUBLE) { getobj(d->obj, Mlist[i].name, row, 0, NULL, &cx); list_store_set_double(GTK_WIDGET(d->text), iter, i, cx / 100.0); } else { getobj(d->obj, Mlist[i].name, row, 0, NULL, &cx); list_store_set_val(GTK_WIDGET(d->text), iter, i, Mlist[i].type, &cx); } } } } static void popup_show_cb(GtkWidget *widget, gpointer user_data) { unsigned int i; int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) user_data; sel = d->select; num = chkobjlastinst(d->obj); for (i = 1; i < POPUP_ITEM_NUM; i++) { switch (i) { case POPUP_ITEM_TOP: case POPUP_ITEM_UP: gtk_widget_set_sensitive(d->popup_item[i], sel > 0 && sel <= num); break; case POPUP_ITEM_DOWN: case POPUP_ITEM_BOTTOM: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel < num); break; default: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel <= num); } } } static void drag_drop_cb(GtkWidget *w, GdkDragContext *context, gint x, gint y, GtkSelectionData *data, guint info, guint time, gpointer user_data) { gchar **filenames; int num; switch (info) { case DROP_TYPE_FILE: filenames = gtk_selection_data_get_uris(data); num = g_strv_length(filenames); data_dropped(filenames, num, FILE_TYPE_MERGE); g_strfreev(filenames); gtk_drag_finish(context, TRUE, FALSE, time); break; } } static void init_dnd(struct SubWin *d) { GtkWidget *widget; GtkTargetEntry target[] = { {"text/uri-list", 0, DROP_TYPE_FILE}, }; widget = d->data.data->text; gtk_drag_dest_set(widget, GTK_DEST_DEFAULT_ALL, target, sizeof(target) / sizeof(*target), GDK_ACTION_COPY); g_signal_connect(widget, "drag-data-received", G_CALLBACK(drag_drop_cb), NULL); } GtkWidget * dreate_merge_list(struct SubWin *d) { if (d->Win) { return d->Win; } list_sub_window_create(d, MERG_WIN_COL_NUM, Mlist); d->data.data->update = MergeWinUpdate; d->data.data->setup_dialog = MergeDialog; d->data.data->dialog = &DlgMerge; d->data.data->obj = chkobject("merge"); sub_win_create_popup_menu(d->data.data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); init_dnd(d); gtk_tree_view_set_enable_search(GTK_TREE_VIEW(d->data.data->text), TRUE); gtk_tree_view_set_search_column(GTK_TREE_VIEW(d->data.data->text), MERG_WIN_COL_FILE); tree_view_set_tooltip_column(GTK_TREE_VIEW(d->data.data->text), MERG_WIN_COL_FILE); return d->Win; } ngraph-gtk-6.08.00/src/gtk/ogra2gdk.h0000644000175000017500000000036013070106167014075 00000000000000/* * $Id: ogra2gdk.h,v 1.2 2008-09-11 07:07:22 hito Exp $ */ #ifndef _O_GRA2GDK_HEADER #define _O_GRA2GDK_HEADER cairo_surface_t *gra2gdk_create_pixmap(struct gra2cairo_local *local, int w, int h, double r, double g, double b); #endif ngraph-gtk-6.08.00/src/gtk/ogra2cairo.h0000644000175000017500000000411013150526674014432 00000000000000#ifndef _O_GRA2CAIRO_HEADER #define _O_GRA2CAIRO_HEADER #include "object.h" #include "nhash.h" extern struct gra2cairo_config *Gra2cairoConf; extern char *gra2cairo_antialias_type[], **Gra2CairoErrMsgs; extern int Gra2CairoErrMsgNum; enum antialias_type_id { ANTIALIAS_TYPE_NONE, ANTIALIAS_TYPE_DEFAULT, ANTIALIAS_TYPE_GRAY, ANTIALIAS_TYPE_SUBPIXEL, }; struct fontmap { char *fontalias, *fontname, *alternative; PangoFontDescription *font; struct fontmap *next; }; struct compatible_font_info { char *old_name; int style; int symbol; char *name; }; struct gra2cairo_config { NHASH fontmap; struct fontmap *fontmap_list_root; int font_num; }; struct gra2cairo_local { cairo_t *cairo; PangoLayout *layout; int linetonum, text2path, antialias, use_opacity; struct fontmap *loadfont; char *fontalias; int font_style, symbol; double pixel_dot_x, pixel_dot_y, offsetx, offsety, fontdir, fontcos, fontsin, fontspace, fontsize; cairo_region_t *region; }; int gra2cairo_clip_region(struct gra2cairo_local *local, cairo_region_t *region); int gra2cairo_strwidth(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); int gra2cairo_charheight(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); void gra2cairo_set_antialias(struct gra2cairo_local *local, int antialias); void set_cairo_antialias(cairo_t *cairo, int antialias); struct gra2cairo_local *gra2cairo_free(struct objlist *obj, N_VALUE *inst); void gra2cairo_update_fontmap(const char *fontalias, const char *fontname); struct fontmap *gra2cairo_get_fontmap(const char *font_alias); void gra2cairo_remove_fontmap(const char *fontalias); void gra2cairo_add_fontmap(const char *fontalias, const char *fontname); int gra2cairo_get_fontmap_num(void); void gra2cairo_save_config(void); void gra2cairo_draw_path(struct gra2cairo_local *local); struct compatible_font_info *gra2cairo_get_compatible_font_info(const char *name); void gra2cairo_set_alternative_font(const char *fontalias, const char *fontname); char *gra2cairo_get_utf8_str(const char *cstr, int symbol); #endif ngraph-gtk-6.08.00/src/gtk/ogra2x11.h0000644000175000017500000000164413070106167013747 00000000000000/* * $Id: ogra2x11.h,v 1.2 2008-12-31 12:30:49 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void *addgra2gtk(void); ngraph-gtk-6.08.00/src/gtk/x11axis.h0000644000175000017500000000334613351432267013707 00000000000000/* * $Id: x11axis.h,v 1.3 2009-05-14 10:25:27 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ char *AxisCB(struct objlist *obj, int id); void CmAxisNewFrame(void *w, gpointer client_data); void CmAxisNewSection(void *w, gpointer client_data); void CmAxisNewCross(void *w, gpointer client_data); void CmAxisNewSingle(void *w, gpointer client_data); void CmAxisUpdate(void *w, gpointer client_data); void CmAxisDel(void *w, gpointer client_data); void CmAxisZoom(void *w, gpointer client_data); void CmAxisClear(void *w, gpointer client_data); void CmAxisScaleUndo(void *w, gpointer client_data); void CmAxisGridNew(void *w, gpointer client_data); void CmAxisGridDel(void *w, gpointer client_data); void CmAxisGridUpdate(void *w, gpointer client_data); GtkWidget *dreate_axis_list(struct SubWin *d); void axis_scale_push(struct objlist *obj, int id); void AxisWinUpdate(struct obj_list_data *data, int clear, int draw); int axis_check_history(void); ngraph-gtk-6.08.00/src/gtk/gtk_ruler.c0000644000175000017500000003270313070106167014374 00000000000000/* GTK - The GIMP Toolkit * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald * * This library 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. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ /* * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS * file for a list of people on the GTK+ Team. See the ChangeLog * files for a list of changes. These files are distributed with * GTK+ at ftp://ftp.gtk.org/pub/gtk/. */ #include "gtk_common.h" #include "gtk_ruler.h" #include "mathfn.h" #include "x11menu.h" #include #include #define RULER_FONT_SIZE 7000 #define RULER_WIDTH 14 #define MINIMUM_INCR 5 #define MAXIMUM_SUBDIVIDE 5 #define MAXIMUM_SCALES 10 typedef struct _Nruler { int orientation, ofst, length, size; cairo_surface_t *backing_store; double lower, upper, position; double save_l, save_u; GtkWidget *widget, *parent; GtkStyleContext *saved_style; GdkRGBA saved_fg; } Nruler; struct _NrulerMetric { gchar *metric_name; gchar *abbrev; /* This should be points_per_unit. This is the size of the unit * in 1/72nd's of an inch and has nothing to do with screen pixels */ gdouble pixels_per_unit; gdouble ruler_scale[MAXIMUM_SCALES]; gint subdivide[MAXIMUM_SUBDIVIDE]; /* five possible modes of subdivision */ }; static const struct _NrulerMetric Metric = { "Centimeters", "Cn", 28.35, { 1, 2, 5, 10, 20, 50, 100, 200, 500, 1000 }, { 1, 5, 10, 50, 100 } }; #define RULER_DATA_KEY "nruler" static void nruler_make_pixmap(Nruler *ruler, GtkWidget *widget, GtkWidget *parent); static void nruler_draw_ticks(Nruler *ruler, GtkWidget *widget); static void nruler_realize(GtkWidget *widget, gpointer user_data); static void nruler_size_allocate(GtkWidget *widget, GtkAllocation *allocation, gpointer user_data); static gboolean nruler_destroy(GtkWidget *widget, gpointer user_data); static void nruler_draw_pos(Nruler *ruler, GtkWidget *widget, cairo_t *cr); static gboolean nruler_expose(GtkWidget *widget, cairo_t *cr, gpointer user_data); static GtkStyleContext *nruler_get_color(Nruler *ruler, GdkRGBA *fg); GtkWidget * nruler_new(GtkOrientation orientation) { Nruler *ruler; GtkWidget *w, *frame; ruler = g_malloc0(sizeof(*ruler)); if (ruler == NULL) { return NULL; } w = gtk_drawing_area_new(); if (orientation == GTK_ORIENTATION_VERTICAL) { gtk_widget_set_size_request(w, RULER_WIDTH, -1); } else { gtk_widget_set_size_request(w, -1, RULER_WIDTH); } frame = gtk_frame_new(NULL); gtk_frame_set_shadow_type(GTK_FRAME(frame), GTK_SHADOW_OUT); gtk_container_add(GTK_CONTAINER(frame), w); ruler->orientation = orientation; ruler->widget = w; ruler->parent = frame; ruler->saved_style = NULL; g_object_set_data(G_OBJECT(frame), RULER_DATA_KEY, ruler); g_signal_connect(w, "draw", G_CALLBACK(nruler_expose), ruler); g_signal_connect(w, "realize", G_CALLBACK(nruler_realize), ruler); g_signal_connect(w, "size-allocate", G_CALLBACK(nruler_size_allocate), ruler); g_signal_connect(frame, "unrealize", G_CALLBACK(nruler_destroy), ruler); return frame; } void nruler_set_range(GtkWidget *frame, double lower, double upper) { Nruler *ruler; if (frame == NULL) { return; } ruler = g_object_get_data(G_OBJECT(frame), RULER_DATA_KEY); if (ruler == NULL) { return; } ruler->lower = lower; ruler->upper = upper; if (gtk_widget_is_drawable(ruler->widget)) { gtk_widget_queue_draw(ruler->widget); } } void nruler_set_position(GtkWidget *frame, double position) { Nruler *ruler; if (frame == NULL) { return; } ruler = g_object_get_data(G_OBJECT(frame), RULER_DATA_KEY); if (ruler == NULL) { return; } ruler->position = position; if (gtk_widget_is_drawable(ruler->widget)) { gtk_widget_queue_draw(ruler->widget); } } static gboolean nruler_destroy(GtkWidget *widget, gpointer user_data) { Nruler *ruler; g_object_set_data(G_OBJECT(widget), RULER_DATA_KEY, NULL); ruler = (Nruler *) user_data; if (ruler) { if (ruler->backing_store) { cairo_surface_destroy(ruler->backing_store); } g_free(ruler); } return FALSE; } static void nruler_size_allocate(GtkWidget *widget, GtkAllocation *allocation, gpointer user_data) { Nruler *ruler; ruler = (Nruler *) user_data; nruler_make_pixmap(ruler, widget, ruler->parent); } static void nruler_realize(GtkWidget *widget, gpointer user_data) { Nruler *ruler; ruler = (Nruler *) user_data; nruler_make_pixmap(ruler, widget, ruler->parent); } static gboolean nruler_expose(GtkWidget *widget, cairo_t *cr, gpointer user_data) { if (gtk_widget_is_drawable(widget)) { Nruler *ruler = (Nruler *) user_data; nruler_draw_ticks(ruler, widget); nruler_draw_pos(ruler, widget, cr); } return FALSE; } static void nruler_make_pixmap(Nruler *ruler, GtkWidget *widget, GtkWidget *parent) { gint width; gint height; GtkAllocation allocation, parent_allocation; if (! gtk_widget_is_drawable(widget)) { return; } gtk_widget_get_allocation(widget, &allocation); gtk_widget_get_allocation(parent, &parent_allocation); if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { ruler->length = parent_allocation.width; ruler->size = allocation.height; ruler->ofst = (parent_allocation.width - allocation.width) / 2; } else { ruler->length = parent_allocation.height; ruler->size = allocation.width; ruler->ofst = (parent_allocation.height - allocation.height) / 2; } if (ruler->backing_store) { width = cairo_image_surface_get_width(ruler->backing_store); height = cairo_image_surface_get_height(ruler->backing_store); if ((width == allocation.width) && (height == allocation.height)) { return; } cairo_surface_destroy(ruler->backing_store); } ruler->backing_store = cairo_image_surface_create(CAIRO_FORMAT_RGB24, allocation.width, allocation.height); ruler->save_l = 0; ruler->save_u = 0; } static void nruler_draw_ticks(Nruler *ruler, GtkWidget *widget) { cairo_t *cr; gint i, j, len; gint length, ideal_length; gdouble lower, upper; /* Upper and lower limits, in ruler units */ gdouble increment; /* Number of pixels per unit */ gint scale; /* Number of units per major unit */ gdouble subd_incr; gdouble start, end, cur; gchar unit_str[32]; gint digit_height; gint text_width; gint text_height; gint pos; PangoLayout *layout; PangoRectangle logical_rect, ink_rect; PangoFontDescription *fs; GtkAllocation allocation; GdkRGBA fg; GtkStyleContext *context; if (! gtk_widget_is_drawable(widget)) { return; } if (ruler->save_l == ruler->lower && ruler->save_u == ruler->upper) { return; } gtk_widget_get_allocation(widget, &allocation); layout = gtk_widget_create_pango_layout(widget, "012456789"); fs = pango_font_description_new(); pango_font_description_set_size(fs, RULER_FONT_SIZE); pango_layout_set_font_description(layout, fs); pango_font_description_free(fs); pango_layout_get_extents(layout, &ink_rect, &logical_rect); digit_height = PANGO_PIXELS(ink_rect.height) + 2; context = nruler_get_color(ruler, &fg); cr = cairo_create(ruler->backing_store); gtk_render_background(context, cr, 0, 0, allocation.width, allocation.height); gdk_cairo_set_source_rgba(cr, &fg); if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { cairo_rectangle(cr, 0, allocation.height - 1, allocation.width, 1); } else { cairo_rectangle(cr, allocation.width - 1, 0, 1, allocation.height); } upper = ruler->upper / Metric.pixels_per_unit; lower = ruler->lower / Metric.pixels_per_unit; if (upper - lower == 0) { goto out; } increment = (gdouble) ruler->length / (upper - lower); /* determine the scale H * We calculate the text size as for the vruler instead of using * text_width = gdk_string_width(font, unit_str), so that the result * for the scale looks consistent with an accompanying vruler */ /* determine the scale V * use the maximum extents of the ruler to determine the largest * possible number to be displayed. Calculate the height in pixels * of this displayed text. Use this height to find a scale which * leaves sufficient room for drawing the ruler. */ scale = ceil(ruler->upper / Metric.pixels_per_unit); len = g_snprintf(unit_str, sizeof(unit_str), "%d", scale); if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { text_width = len * digit_height + 1; for (scale = 0; scale < MAXIMUM_SCALES; scale++) { if (Metric.ruler_scale[scale] * fabs(increment) > 2 * text_width) { break; } } } else { text_height = len * digit_height + 1; for (scale = 0; scale < MAXIMUM_SCALES; scale++) { if (Metric.ruler_scale[scale] * fabs(increment) > 2 * text_height){ break; } } } if (scale == MAXIMUM_SCALES) { scale = MAXIMUM_SCALES - 1; } /* drawing starts here */ length = 0; for (i = MAXIMUM_SUBDIVIDE - 1; i >= 0; i--) { subd_incr = Metric.ruler_scale[scale] / Metric.subdivide[i]; if (subd_incr * fabs(increment) <= MINIMUM_INCR) { continue; } /* Calculate the length of the tickmarks. Make sure that * this length increases for each set of ticks */ ideal_length = ruler->size / (i + 1) - 1; if (ideal_length > ++length) { length = ideal_length; } if (lower < upper) { start = floor(lower / subd_incr) * subd_incr; end = ceil(upper / subd_incr) * subd_incr; } else { start = floor(upper / subd_incr) * subd_incr; end = ceil(lower / subd_incr) * subd_incr; } for (cur = start; cur <= end; cur += subd_incr) { pos = nround((cur - lower) * increment) - ruler->ofst; if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { cairo_rectangle(cr, pos, ruler->size - length, 1, length); } else { cairo_rectangle(cr, ruler->size - length, pos, length, 1); } /* draw label */ if (i == 0) { int ofst; len = g_snprintf(unit_str, sizeof(unit_str), "%d", (int) cur); ofst = PANGO_PIXELS(logical_rect.y - ink_rect.y); if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { pango_layout_set_text(layout, unit_str, -1); cairo_move_to(cr, pos + 2, ofst + 1); pango_cairo_show_layout(cr, layout); } else { for (j = 0; j < len; j++) { pango_layout_set_text(layout, unit_str + j, 1); cairo_move_to(cr, 1, pos + digit_height * j + 2 + ofst); pango_cairo_show_layout(cr, layout); } } } } } cairo_fill(cr); ruler->save_l = ruler->lower; ruler->save_u = ruler->upper; out: cairo_destroy(cr); g_object_unref(layout); } static GtkStyleContext * nruler_get_color(Nruler *ruler, GdkRGBA *fg) { if (ruler->saved_style == NULL) { ruler->saved_style = gtk_widget_get_style_context(TopLevel); gtk_style_context_get_color(ruler->saved_style, GTK_STATE_FLAG_NORMAL, &ruler->saved_fg); } if (fg == NULL) { return ruler->saved_style; } *fg = ruler->saved_fg; return ruler->saved_style; } static void nruler_draw_pos(Nruler *ruler, GtkWidget *widget, cairo_t *cr) { gint x, y; gint width, height; gint bs_width, bs_height; gdouble increment; GtkAllocation allocation; GdkRGBA fg; gtk_widget_get_allocation(widget, &allocation); if (! gtk_widget_is_drawable(widget)) { return; } if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { width = ruler->length; height = ruler->size; bs_width = height / 2 + 2; bs_width |= 1; /* make sure it's odd */ bs_height = bs_width / 2 + 1; } else { width = ruler->size; height = ruler->length; bs_height = width / 2 + 2; bs_height |= 1; /* make sure it's odd */ bs_width = bs_height / 2 + 1; } if (bs_width <= 0 || bs_height <= 0) { return; } /* If a backing store exists, restore the ruler */ if (ruler->backing_store) { cairo_set_source_surface(cr, ruler->backing_store, 0, 0); cairo_rectangle(cr, 0, 0, allocation.width, allocation.height); cairo_fill(cr); } if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { increment = (gdouble) width / (ruler->upper - ruler->lower); x = nround((ruler->position - ruler->lower) * increment) - bs_width / 2 - ruler->ofst; y = (height + bs_height) / 2 - 1; } else { increment = (gdouble) height / (ruler->upper - ruler->lower); x = (width + bs_width) / 2 - 1; y = nround((ruler->position - ruler->lower) * increment) - bs_height / 2 - ruler->ofst; } nruler_get_color(ruler, &fg); gdk_cairo_set_source_rgba(cr, &fg); cairo_set_antialias(cr, CAIRO_ANTIALIAS_NONE); cairo_move_to(cr, x, y); if (ruler->orientation == GTK_ORIENTATION_HORIZONTAL) { cairo_line_to(cr, x + bs_width / 2.0, y + bs_height); cairo_line_to(cr, x + bs_width, y); } else { cairo_line_to(cr, x + bs_width, y + bs_height / 2.0); cairo_line_to(cr, x, y + bs_height); } cairo_fill(cr); } ngraph-gtk-6.08.00/src/gtk/x11graph.c0000644000175000017500000007671213305743374014051 00000000000000/* * $Id: x11graph.c,v 1.57 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include "dir_defs.h" #include "object.h" #include "ioutil.h" #include "shell.h" #include "nstring.h" #include "odraw.h" #include "init.h" #include "x11dialg.h" #include "ox11menu.h" #include "x11menu.h" #include "x11gui.h" #include "x11graph.h" #include "x11view.h" #include "x11axis.h" #include "x11print.h" #include "x11commn.h" #include "x11info.h" #include "gtk_liststore.h" #include "gtk_combo.h" #include "gtk_widget.h" #define PAPER_SIZE_MIN 1000 char *LoadPathStr[] = { N_("unchange"), N_("full"), N_("base"), NULL, }; struct pagelisttype { char *paper, *name; enum paper_id id; int langscape, width, height; }; static struct pagelisttype pagelist[] = { {N_("Custom"), "custom", PAPER_ID_CUSTOM, TRUE, 0, 0}, {N_("normal display (4:3)"), "normal display", PAPER_ID_NORMAL, TRUE, 28000, 21000}, {N_("wide display (16:9)"), "wide display", PAPER_ID_WIDE, TRUE, 38400, 21600}, {"A3 P (297.00x420.00)", GTK_PAPER_NAME_A3, PAPER_ID_A3, FALSE, 29700, 42000}, {"A4 P (210.00x297.00)", GTK_PAPER_NAME_A4, PAPER_ID_A4, FALSE, 21000, 29700}, {"A4 L (297.00x210.00)", GTK_PAPER_NAME_A4, PAPER_ID_A4, TRUE, 29700, 21000}, {"A5 P (148.00x210.00)", GTK_PAPER_NAME_A5, PAPER_ID_A5, FALSE, 14800, 21000}, {"A5 L (210.00x148.00)", GTK_PAPER_NAME_A5, PAPER_ID_A5, TRUE, 21000, 14800}, {"B4 P (257.00x364.00)", "iso_b4", PAPER_ID_B4, FALSE, 25700, 36400}, {"B5 P (182.00x257.00)", GTK_PAPER_NAME_B5, PAPER_ID_B5, FALSE, 18200, 25700}, {"B5 L (257.00x182.00)", GTK_PAPER_NAME_B5, PAPER_ID_B5, TRUE, 25700, 18200}, {N_("Letter P (215.90x279.40)"), GTK_PAPER_NAME_LETTER, PAPER_ID_LETTER, FALSE, 21590, 27940}, {N_("Letter L (279.40x215.90)"), GTK_PAPER_NAME_LETTER, PAPER_ID_LETTER, TRUE, 27940, 21590}, {N_("Legal P (215.90x355.60)"), GTK_PAPER_NAME_LEGAL, PAPER_ID_LEGAL, FALSE, 21590, 35560}, {N_("Legal L (355.60x215.90)"), GTK_PAPER_NAME_LEGAL, PAPER_ID_LEGAL, TRUE, 35560, 21590}, }; #define PAGELISTNUM (sizeof(pagelist) / sizeof(*pagelist)) #define DEFAULT_PAPER_SIZE 0 int set_paper_type(int w, int h) { unsigned int j; if (w < 1 || h < 1) return 0; Menulocal.PaperWidth = w; Menulocal.PaperHeight = h; for (j = 0; j < PAGELISTNUM; j++) { if (w == pagelist[j].width && h == pagelist[j].height) { break; } } if (j == PAGELISTNUM) { j = DEFAULT_PAPER_SIZE; } Menulocal.PaperName = pagelist[j].name; Menulocal.PaperId = pagelist[j].id; Menulocal.PaperLandscape = pagelist[j].langscape; return j; } static void PageDialogSetupItem(GtkWidget *w, struct PageDialog *d) { int j; spin_entry_set_val(d->leftmargin, Menulocal.LeftMargin); spin_entry_set_val(d->topmargin, Menulocal.TopMargin); spin_entry_set_val(d->paperwidth, Menulocal.PaperWidth); spin_entry_set_val(d->paperheight, Menulocal.PaperHeight); spin_entry_set_val(d->paperzoom, Menulocal.PaperZoom); j = set_paper_type(Menulocal.PaperWidth, Menulocal.PaperHeight); combo_box_set_active(d->paper, j); } static void PageDialogPage(GtkWidget *w, gpointer client_data) { struct PageDialog *d; int a; d = (struct PageDialog *) client_data; a = combo_box_get_active(d->paper); if (a < 0) return; set_widget_sensitivity_with_label(d->paperwidth, a == 0); set_widget_sensitivity_with_label(d->paperheight, a == 0); if (a > 0) { spin_entry_set_val(d->paperwidth, pagelist[a].width); spin_entry_set_val(d->paperheight, pagelist[a].height); } } static void PageDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; unsigned int j; struct PageDialog *d; int i; d = (struct PageDialog *) data; if (makewidget) { table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, FALSE, TRUE); spin_entry_set_range(w, PAPER_SIZE_MIN, G_MAXUSHORT); add_widget_to_table(table, w, _("paper _Width:"), FALSE, i++); d->paperwidth = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, FALSE, TRUE); spin_entry_set_range(w, PAPER_SIZE_MIN, G_MAXUSHORT); add_widget_to_table(table, w, _("paper _Height:"), FALSE, i++); d->paperheight = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Paper:"), FALSE, i++); d->paper = w; g_signal_connect(w, "changed", G_CALLBACK(PageDialogPage), d); for (j = 0; j < PAGELISTNUM; j++) { combo_box_append_text(d->paper, _(pagelist[j].paper)); } w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, FALSE, TRUE); add_widget_to_table(table, w, _("_Left margin:"), FALSE, i++); d->leftmargin = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, FALSE, TRUE); add_widget_to_table(table, w, _("_Top margin:"), FALSE, i++); d->topmargin = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, FALSE, TRUE); add_widget_to_table(table, w, _("paper _Zoom:"), FALSE, i++); d->paperzoom = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } PageDialogSetupItem(wi, d); } static void PageDialogClose(GtkWidget *wi, void *data) { struct PageDialog *d; int w, h; d = (struct PageDialog *) data; if (d->ret != IDOK) return; w = spin_entry_get_val(d->paperwidth); h = spin_entry_get_val(d->paperheight); if (w < PAPER_SIZE_MIN || h < PAPER_SIZE_MIN) { d->ret = IDLOOP; return; } set_paper_type(w, h); Menulocal.LeftMargin = spin_entry_get_val(d->leftmargin); Menulocal.TopMargin = spin_entry_get_val(d->topmargin); Menulocal.PaperZoom = spin_entry_get_val(d->paperzoom); } void PageDialog(struct PageDialog *data) { data->SetupWindow = PageDialogSetup; data->CloseWindow = PageDialogClose; } static void set_objlist_btn_state(struct SwitchDialog *d, gboolean b) { gtk_widget_set_sensitive(d->add, b); gtk_widget_set_sensitive(d->ins, b); } static void set_drawlist_btn_state(struct SwitchDialog *d, gboolean b) { gtk_widget_set_sensitive(d->top, b); gtk_widget_set_sensitive(d->bottom, b); gtk_widget_set_sensitive(d->up, b); gtk_widget_set_sensitive(d->down, b); gtk_widget_set_sensitive(d->del, b); } static void SwitchDialogSetupItem(GtkWidget *w, struct SwitchDialog *d) { int j, num; char **buf; GtkTreeIter iter; d->btn_lock = TRUE; list_store_clear(d->drawlist); num = arraynum(&(d->idrawrable)); for (j = 0; j < num; j++) { buf = (char **) arraynget(&(d->drawrable), arraynget_int(&(d->idrawrable), j)); list_store_append(d->drawlist, &iter); list_store_set_string(d->drawlist, &iter, 0, _(*buf)); } d->btn_lock = FALSE; } static void SwitchDialogAdd(GtkWidget *w, gpointer client_data) { struct SwitchDialog *d; GtkTreeSelection *selected; GList *list, *ptr; int duplicate, num, *data, i; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->objlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); data = arraydata(&(d->idrawrable)); num = arraynum(&(d->idrawrable)); for (ptr = list; ptr; ptr = ptr->next) { int *ary, a; duplicate = FALSE; ary = gtk_tree_path_get_indices((GtkTreePath *)(ptr->data)); a = ary[0]; for (i = 0; i < num; i++) { if (data[i] == a) { duplicate = TRUE; break; } } if ( !duplicate) { arrayadd(&(d->idrawrable), &a); } } if (list) { g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } SwitchDialogSetupItem(d->widget, d); set_drawlist_btn_state(d, FALSE); } static void SwitchDialogInsert(GtkWidget *w, gpointer client_data) { struct SwitchDialog *d; int i, a, pos, num2; int *data; GtkTreeSelection *selected; GList *list, *last; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); pos = 0; if (list) { last = g_list_last(list); if (last) { int *ptr; ptr = gtk_tree_path_get_indices((GtkTreePath *)(last->data)); pos = ptr[0]; } g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } data = arraydata(&(d->idrawrable)); num2 = arraynum(&(d->idrawrable)); selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->objlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); for (last = list; last; last = last->next) { int *ptr; ptr = gtk_tree_path_get_indices((GtkTreePath *)(last->data)); a = ptr[0]; for (i = 0; i < num2; i++) { if (data[i] == a) { break; } } if (i == num2) { arrayins(&(d->idrawrable), &a, pos); } } if (list) { g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } SwitchDialogSetupItem(d->widget, d); set_drawlist_btn_state(d, FALSE); } static void switch_dialog_top_cb(gpointer data, gpointer user_data) { GtkTreePath *path; int *ary, i, k; struct SwitchDialog *d; path = (GtkTreePath *) data; d = (struct SwitchDialog *) user_data; ary = gtk_tree_path_get_indices(path); if (! ary) return; i = ary[0]; k = arraynget_int(&(d->idrawrable), i); arrayndel(&(d->idrawrable), i); arrayins(&(d->idrawrable), &k, 0); } static void switch_dialog_last_cb(gpointer data, gpointer user_data) { GtkTreePath *path; int *ary, i, k; struct SwitchDialog *d; path = (GtkTreePath *) data; d = (struct SwitchDialog *) user_data; ary = gtk_tree_path_get_indices(path); if (! ary) return; i = ary[0]; k = arraynget_int(&(d->idrawrable), i); arrayndel(&(d->idrawrable), i); arrayadd(&(d->idrawrable), &k); } static void SwitchDialogUp(GtkWidget *w, gpointer client_data) { GtkTreeSelection *selected; GList *list, *ptr; struct SwitchDialog *d; int i, k, modified, *ary; GtkTreePath *path; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); if (list == NULL) { return; } modified = FALSE; for (ptr = list; ptr; ptr = g_list_next(ptr)) { path = (GtkTreePath *) ptr->data; ary = gtk_tree_path_get_indices(path); if (ary == NULL) { break; } i = ary[0]; if (i <= 0) { break; } k = arraynget_int(&(d->idrawrable), i); arrayndel(&(d->idrawrable), i); i--; arrayins(&(d->idrawrable), &k, i); modified = TRUE; } if (modified) { SwitchDialogSetupItem(d->widget, d); for (ptr = list; ptr; ptr = g_list_next(ptr)) { path = (GtkTreePath *) ptr->data; ary = gtk_tree_path_get_indices(path); if (ary == NULL) break; list_store_select_nth(d->drawlist, ary[0] - 1); } } g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } static void SwitchDialogDown(GtkWidget *w, gpointer client_data) { GtkTreeSelection *selected; GList *list, *ptr; struct SwitchDialog *d; int i, k, num, modified, *ary; GtkTreePath *path; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); if (list == NULL) { return; } num = list_store_get_num(d->drawlist); modified = FALSE; for (ptr = g_list_last(list); ptr; ptr = g_list_previous(ptr)) { path = (GtkTreePath *) ptr->data; ary = gtk_tree_path_get_indices(path); if (ary == NULL) break; i = ary[0]; if (i >= num - 1) { break; } k = arraynget_int(&(d->idrawrable), i); arrayndel(&(d->idrawrable), i); i++; arrayins(&(d->idrawrable), &k, i); modified = TRUE; } if (modified) { SwitchDialogSetupItem(d->widget, d); for (ptr = g_list_last(list); ptr; ptr = g_list_previous(ptr)) { path = (GtkTreePath *) ptr->data; ary = gtk_tree_path_get_indices(path); if (ary == NULL) break; list_store_select_nth(d->drawlist, ary[0] + 1); } } g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } static void SwitchDialogTop(GtkWidget *w, gpointer client_data) { GtkTreeSelection *selected; GList *list; struct SwitchDialog *d; int i, num = 0; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); if (list) { num = g_list_length(list); g_list_foreach(list, switch_dialog_top_cb, d); g_list_foreach(list, free_tree_path_cb, NULL); g_list_free(list); } SwitchDialogSetupItem(d->widget, d); for (i = 0; i < num; i++) { list_store_select_nth(d->drawlist, i); } } static void SwitchDialogLast(GtkWidget *w, gpointer client_data) { struct SwitchDialog *d; GtkTreeSelection *selected; GList *list; int n, i, num = 0; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); if (list) { num = g_list_length(list); list = g_list_reverse(list); g_list_foreach(list, switch_dialog_last_cb, d); g_list_foreach(list, free_tree_path_cb, NULL); g_list_free (list); } SwitchDialogSetupItem(d->widget, d); n = list_store_get_num(d->drawlist); for (i = 0; i < num; i++) { list_store_select_nth(d->drawlist, n - i - 1); } } static void switch_dialog_remove_cb(gpointer data, gpointer user_data) { GtkTreePath *path; int *ary; struct SwitchDialog *d; path = (GtkTreePath *) data; d = (struct SwitchDialog *) user_data; ary = gtk_tree_path_get_indices(path); if (! ary) return; arrayndel(&(d->idrawrable), ary[0]); } static void SwitchDialogRemove(GtkWidget *w, gpointer client_data) { struct SwitchDialog *d; GtkTreeSelection *selected; GList *list; d = (struct SwitchDialog *) client_data; selected = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->drawlist)); list = gtk_tree_selection_get_selected_rows(selected, NULL); if (list) { list = g_list_reverse(list); g_list_foreach(list, switch_dialog_remove_cb, d); g_list_foreach(list, free_tree_path_cb, NULL); g_list_free (list); } SwitchDialogSetupItem(d->widget, d); set_drawlist_btn_state(d, FALSE); } static gboolean drawlist_sel_cb(GtkTreeSelection *sel, gpointer user_data) { int n; struct SwitchDialog *d; d = (struct SwitchDialog *) user_data; if (! d->btn_lock) { n = gtk_tree_selection_count_selected_rows(sel); set_drawlist_btn_state(d, n); } return FALSE; } static gboolean objlist_sel_cb(GtkTreeSelection *sel, gpointer user_data) { int n; struct SwitchDialog *d; d = (struct SwitchDialog *) user_data; if (! d->btn_lock) { n = gtk_tree_selection_count_selected_rows(sel); set_objlist_btn_state(d, n); } return FALSE; } static void SwitchDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *vbox, *vbox2, *label, *frame; GtkTreeIter iter; struct SwitchDialog *d; int num2, num1, j, k, *obj_check; char **buf; GtkTreeSelection *sel; static n_list_store list[] = { {N_("Object"), G_TYPE_STRING, TRUE, FALSE, NULL}, }; d = (struct SwitchDialog *) data; if (makewidget) { hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); label = gtk_label_new_with_mnemonic(_("_Draw order")); gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 4); w = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); d->drawlist = w; gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); g_signal_connect(sel, "changed", G_CALLBACK(drawlist_sel_cb), d); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), w); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(w, "list-add"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogAdd), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->add = w; w = gtk_button_new_with_mnemonic(_("_Insert")); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogInsert), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->ins = w; w = gtk_separator_new(GTK_ORIENTATION_HORIZONTAL); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Top")); set_button_icon(w, "go-top"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogTop), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->top =w; w = gtk_button_new_with_mnemonic(_("_Up")); set_button_icon(w, "go-up"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogUp), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->up = w; w = gtk_button_new_with_mnemonic(_("_Down")); set_button_icon(w, "go-down"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogDown), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->down = w; w = gtk_button_new_with_mnemonic(_("_Bottom")); set_button_icon(w, "go-bottom"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogLast), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->bottom = w; w = gtk_button_new_with_mnemonic(("_Remove")); set_button_icon(w, "list-remove"); g_signal_connect(w, "clicked", G_CALLBACK(SwitchDialogRemove), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->del = w; vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_end(GTK_BOX(vbox2), vbox, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox2, FALSE, FALSE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); label = gtk_label_new_with_mnemonic(_("_Objects")); gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 4); w = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_selection_mode(w, GTK_SELECTION_MULTIPLE); d->objlist = w; gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); g_signal_connect(sel, "changed", G_CALLBACK(objlist_sel_cb), d); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), w); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); d->btn_lock = FALSE; } menuadddrawrable(chkobject("draw"), &(d->drawrable)); list_store_clear(d->objlist); num2 = arraynum(&(d->drawrable)); for (j = 0; j < num2; j++) { buf = (char **) arraynget(&(d->drawrable), j); list_store_append(d->objlist, &iter); list_store_set_string(d->objlist, &iter, 0, _(*buf)); } num1 = arraynum(&(Menulocal.drawrable)); obj_check = g_malloc0(sizeof(*obj_check) * num2); if (obj_check == NULL) { return; } for (j = 0; j < num1; j++) { struct objlist *obj; buf = (char **) arraynget(&(Menulocal.drawrable), j); obj = chkobject(*buf); if (obj == NULL) { continue; } for (k = 0; k < num2; k++) { if (strcmp0(arraynget_str(&(d->drawrable), k), obj->name) == 0) { break; } } if (k != num2 && obj_check[k] == 0) { obj_check[k] = 1; arrayadd(&(d->idrawrable), &k); } } g_free(obj_check); SwitchDialogSetupItem(wi, d); set_objlist_btn_state(d, FALSE); set_drawlist_btn_state(d, FALSE); } static void SwitchDialogClose(GtkWidget *w, void *data) { struct SwitchDialog *d; int j, num; char **buf; d = (struct SwitchDialog *) data; if (d->ret == IDOK) { arraydel2(&(Menulocal.drawrable)); num = arraynum(&(d->idrawrable)); if (num == 0) { menuadddrawrable(chkobject("draw"), &(Menulocal.drawrable)); } else { for (j = 0; j < num; j++) { buf = (char **) arraynget(&(d->drawrable), arraynget_int(&(d->idrawrable), j)); if ((*buf) != NULL) arrayadd2(&(Menulocal.drawrable), *buf); } } } arraydel2(&(d->drawrable)); arraydel(&(d->idrawrable)); } void SwitchDialog(struct SwitchDialog *data) { data->SetupWindow = SwitchDialogSetup; data->CloseWindow = SwitchDialogClose; arrayinit(&(data->drawrable), sizeof(char *)); arrayinit(&(data->idrawrable), sizeof(int)); } static void DirectoryDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct DirectoryDialog *d; char *cwd; d = (struct DirectoryDialog *) data; if (makewidget) { table = gtk_grid_new(); w = gtk_file_chooser_button_new(_("directory"), GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER); gtk_file_chooser_set_local_only(GTK_FILE_CHOOSER(w), TRUE); d->dir = w; add_widget_to_table(table, w, _("_Select Dir:"), TRUE, 0); w = gtk_label_new(_("Current Dir:")); gtk_widget_set_halign(w, GTK_ALIGN_START); g_object_set(w, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), w, 0, 1, 1, 1); w = gtk_label_new(""); gtk_label_set_ellipsize(GTK_LABEL(w), PANGO_ELLIPSIZE_START); d->dir_label = w; gtk_widget_set_hexpand(w, TRUE); gtk_widget_set_halign(w, GTK_ALIGN_START); g_object_set(w, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), w, 1, 2, 1, 1); gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } cwd = ngetcwd(); if (cwd) { gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(d->dir), cwd); gtk_label_set_text(GTK_LABEL(d->dir_label), cwd); g_free(cwd); } } static void DirectoryDialogClose(GtkWidget *w, void *data) { struct DirectoryDialog *d; char *s; d = (struct DirectoryDialog *) data; if (d->ret == IDCANCEL) return; s = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(d->dir)); if (s && strlen(s) > 0) { if (nchdir(s)) { ErrorMessage(); } } if (s) g_free(s); } void DirectoryDialog(struct DirectoryDialog *data) { data->SetupWindow = DirectoryDialogSetup; data->CloseWindow = DirectoryDialogClose; } static void LoadDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *vbox; struct LoadDialog *d; int j; d = (struct LoadDialog *) data; if (makewidget) { vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_check_button_new_with_mnemonic(_("_Expand included file")); d->expand_file = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = create_text_entry(FALSE, TRUE); item_setup(vbox, w, _("_Dir:"), FALSE); d->dir = w; w = combo_box_create(); item_setup(vbox, w, _("_Path:"), FALSE); for (j = 0; LoadPathStr[j]; j++) { combo_box_append_text(w, _(LoadPathStr[j])); } d->load_path = w; gtk_box_pack_start(GTK_BOX(d->vbox), vbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->expand_file), d->expand); combo_box_set_active(d->load_path, d->loadpath); gtk_entry_set_text(GTK_ENTRY(d->dir), d->exdir); } static void LoadDialogClose(GtkWidget *w, void *data) { struct LoadDialog *d; const char *s; d = (struct LoadDialog *) data; if (d->ret == IDCANCEL) return; d->expand = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->expand_file)); s = gtk_entry_get_text(GTK_ENTRY(d->dir)); g_free(d->exdir); d->exdir = g_strdup(s); d->loadpath = combo_box_get_active(d->load_path); } void LoadDialog(struct LoadDialog *data) { data->SetupWindow = LoadDialogSetup; data->CloseWindow = LoadDialogClose; data->expand = Menulocal.expand; if (data->exdir) { g_free(data->exdir); } data->exdir = g_strdup(Menulocal.expanddir); data->loadpath = Menulocal.loadpath; } static void SaveDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *vbox; int j; struct SaveDialog *d; d = (struct SaveDialog *) data; if (makewidget) { vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = combo_box_create(); item_setup(vbox, w, _("_Path:"), FALSE); for (j = 0; pathchar[j] != NULL; j++) { combo_box_append_text(w, _(pathchar[j])); } d->path = w; w = gtk_check_button_new_with_mnemonic(_("_Include data file")); d->include_data = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_Include merge file")); d->include_merge = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), vbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } combo_box_set_active(d->path, Menulocal.savepath); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->include_data), Menulocal.savewithdata); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->include_merge), Menulocal.savewithmerge); d->focus = d->include_data; } static void SaveDialogClose(GtkWidget *w, void *data) { int num; struct SaveDialog *d; d = (struct SaveDialog *) data; if (d->ret == IDCANCEL) return; num = combo_box_get_active(d->path); if (num >= 0) { d->Path = num; } *(d->SaveData) = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->include_data)); *(d->SaveMerge) = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->include_merge)); } void SaveDialog(struct SaveDialog *data, int *sdata, int *smerge) { data->SetupWindow = SaveDialogSetup; data->CloseWindow = SaveDialogClose; data->SaveData = sdata; data->SaveMerge = smerge; } void CmGraphNewMenu(void *w, gpointer client_data) { int sel; if (Menulock || Globallock) return; if (!CheckSave()) return; DeleteDrawable(); sel = GPOINTER_TO_INT(client_data); switch (sel) { case MenuIdGraphNewFrame: CmAxisNewFrame(NULL, client_data); break; case MenuIdGraphNewSection: CmAxisNewSection(NULL, client_data); break; case MenuIdGraphNewCross: CmAxisNewCross(NULL, client_data); break; case MenuIdGraphAllClear: default: break; } SetFileName(NULL); set_axis_undo_button_sensitivity(FALSE); reset_graph_modified(); CmViewerDraw(NULL, GINT_TO_POINTER(TRUE)); UpdateAll2(NULL, FALSE); InfoWinClear(); menu_clear_undo(); } void CmGraphLoad(void *w, gpointer client_data) { char *file; if (Menulock || Globallock) return; if (!CheckSave()) return; if (nGetOpenFileName(TopLevel, _("Load NGP file"), "ngp", &(Menulocal.graphloaddir), NULL, &file, TRUE, Menulocal.changedirectory) != IDOK) { return; } LoadNgpFile(file, Menulocal.scriptconsole, "-f"); g_free(file); } void CmGraphSave(void *w, gpointer client_data) { if (Menulock || Globallock) return; GraphSave(FALSE); } void CmGraphOverWrite(void *w, gpointer client_data) { if (Menulock || Globallock) return; GraphSave(TRUE); } void CmGraphSwitch(void *w, gpointer client_data) { if (Menulock || Globallock) return; SwitchDialog(&DlgSwitch); if (DialogExecute(TopLevel, &DlgSwitch) == IDOK) { set_graph_modified_gra(); ChangePage(); } } void CmGraphPage(void *w, gpointer client_data) { if (Menulock || Globallock) return; PageDialog(&DlgPage); if (DialogExecute(TopLevel, &DlgPage) == IDOK) { SetPageSettingsToGRA(); ChangePage(); GetPageSettingsFromGRA(); set_graph_modified_gra(); } } void CmGraphDirectory(void *w, gpointer client_data) { if (Menulock || Globallock) return; DirectoryDialog(&DlgDirectory); DialogExecute(TopLevel, &DlgDirectory); } void CmGraphShell(void *w, gpointer client_data) { struct objlist *obj, *robj, *shell; N_VALUE *inst; int idn, allocnow, n; if (Menulock || Globallock) return; menu_lock(TRUE); menu_save_undo(UNDO_TYPE_SHLL, NULL); obj = Menulocal.obj; inst = Menulocal.inst; idn = getobjtblpos(obj, "_evloop", &robj); registerevloop(chkobjectname(obj), "_evloop", robj, idn, inst, NULL); if ((shell = chkobject("shell")) != NULL) { n = chkobjlastinst(shell); if (n < 0) { newobj(shell); } allocnow = allocate_console(); exeobj(shell, "shell", 0, 0, NULL); free_console(allocnow); } unregisterevloop(robj, idn, inst); menu_lock(FALSE); set_graph_modified(); UpdateAll(NULL); } void CmGraphQuit(void *w, gpointer client_data) { if (Menulock || Globallock) return; QuitGUI(); } void CmGraphHistory(GtkRecentChooser *w, gpointer client_data) { char *uri, *fname, *path; if (Menulock || Globallock) return; uri = gtk_recent_chooser_get_current_uri(w); if (uri == NULL) { return; } fname = g_filename_from_uri(uri, NULL, NULL); g_free(uri); if (fname == NULL) { return; } if (!CheckSave()) { g_free(fname); return; } path = g_path_get_dirname(fname); if (nchdir(path)) { ErrorMessage(); g_free(path); g_free(fname); return; } g_free(path); LoadNgpFile(fname, Menulocal.scriptconsole, "-f"); g_free(fname); } void CmHelpAbout(void *w, gpointer client_data) { struct objlist *obj; char *web, *copyright; if (Menulock || Globallock) return; if ((obj = chkobject("system")) == NULL) return; getobj(obj, "copyright", 0, 0, NULL, ©right); getobj(obj, "web", 0, 0, NULL, &web); gtk_show_about_dialog(GTK_WINDOW(TopLevel), "program-name", PACKAGE, "copyright", copyright, "version", VERSION, "website", web, "license-type", GTK_LICENSE_GPL_2_0, "wrap-license", TRUE, "authors", Auther, "translator-credits", Translator, "documenters", Documenter, "comments", _("Ngraph is the program to create scientific 2-dimensional graphs for researchers and engineers."), NULL); } static char * check_help_file(void) { char *file, *ptr, *tmp; const char *locale; locale = n_getlocale(); if (locale == NULL) { goto End; } tmp = g_strdup(locale); if (tmp == NULL){ goto End; } ptr = strchr(tmp, '_'); if (ptr == NULL) { g_free(tmp); goto End; } *ptr = '\0'; file = g_strdup_printf("%s/html/%s/%s", DOCDIR, tmp, HELP_FILE); g_free(tmp); if (naccess(file, R_OK) == 0) { return file; } g_free(file); End: return g_strdup_printf("%s/html/ja/%s", DOCDIR, HELP_FILE); /* default language of the help file is Japanese. */ } void CmHelpHelp(void *w, gpointer client_data) { char *cmd, *file; if (Menulock || Globallock) return; if (Menulocal.help_browser == NULL) return; file = check_help_file(); cmd = g_strdup_printf("%s \"%s\"", Menulocal.help_browser, file); g_free(file); system_bg(cmd); g_free(cmd); } ngraph-gtk-6.08.00/src/gtk/ox11dlg.c0000644000175000017500000004035113145543711013656 00000000000000/* * $Id: ox11dlg.c,v 1.29 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include "object.h" #include "mathfn.h" #include "nstring.h" #include "ioutil.h" #include "x11menu.h" #include "ox11menu.h" #include "init.h" #include "x11gui.h" #define NAME "dialog" #define PARENT "object" #define NVERSION "1.00.00" #define ERRDISPLAY 100 #define ERRNODLGINST 101 static char *dlgerrorlist[] = { "cannot open display.", "no instance for dialog", }; #define ERRNUM (sizeof(dlgerrorlist) / sizeof(*dlgerrorlist)) static GtkWidget *DLGTopLevel = NULL; static GtkWidget * get_toplevel_window(void) { if (TopLevel) { return TopLevel; } if (DLGTopLevel == NULL) { DLGTopLevel = gtk_window_new(GTK_WINDOW_TOPLEVEL); } return DLGTopLevel; } static int dlginit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int pos = -1; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) { return 1; } if (!OpenApplication()) { error(obj, ERRDISPLAY); return 1; } _putobj(obj, "x", inst, &pos); _putobj(obj, "y", inst, &pos); return 0; } static int dlgdone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } static int dlgconfirm(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *mes, *title; int rcode, locksave; if (_getobj(obj, "title", inst, &title)) { title = NULL; } mes = (char *)argv[2]; locksave = Globallock; Globallock = TRUE; mes = CHK_STR(mes); rcode = message_box(get_toplevel_window(), mes, (title) ? title : _("Confirm"), RESPONS_YESNO); Globallock = locksave; if (rcode == IDYES) { rval->i = 1; } else { rval->i = 0; } return (rcode == IDYES)? 0 : 1; } static int dlgmessage(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *mes, *title; int locksave; if (_getobj(obj, "title", inst, &title)) { title = NULL; } mes = (char *)argv[2]; locksave = Globallock; Globallock = TRUE; message_box(get_toplevel_window(), CHK_STR(mes), (title) ? title : _("Message"), RESPONS_OK); Globallock = locksave; return 0; } static struct narray * dlg_get_buttons(struct objlist *obj, N_VALUE *inst) { struct narray *sarray; int num; if (_getobj(obj, "buttons", inst, &sarray)) { return NULL; } if (sarray == NULL) { return NULL; } num = arraynum(sarray); if (num < 1) { return NULL; } return sarray; } static int dlginput(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *mes, *title, *init_str; int locksave, x, y, r; char *inputbuf; struct narray *buttons; int btn = -1; locksave = Globallock; Globallock = TRUE; init_str = (char *)argv[2]; g_free(rval->str); rval->str = NULL; inputbuf = NULL; if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &mes)) { mes = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } buttons = dlg_get_buttons(obj, inst); r = DialogInput(get_toplevel_window(), (title) ? title : _("Input"), mes, init_str, buttons, &btn, &inputbuf, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "response_button", inst, &btn); if (r == IDOK && inputbuf != NULL) { rval->str = inputbuf; } else { g_free(inputbuf); Globallock = locksave; return 1; } Globallock = locksave; return 0; } struct narray * get_sarray_argument(struct narray *sarray) { int m, n, i, j, id; char *ptr, sa[] = "sarray:", *argv[2]; struct narray iarray; struct objlist *saobj; n = arraynum(sarray); if (n != 1) return sarray; ptr = * (char **) arraydata(sarray); if (ptr == NULL) return sarray; if (strncmp(ptr, sa, sizeof(sa) / sizeof(*sa) - 1)) return sarray; arrayinit(&iarray, sizeof(int)); if (getobjilist(ptr, &saobj, &iarray, FALSE, NULL)) return sarray; n = arraynum(&iarray); for (j = 0; j < n; j++) { id = arraynget_int(&iarray, j); if (getobj(saobj, "num", id, 0, NULL, &m) == -1) continue; if (m < 1) continue; for (i = 0; i < m; i++) { argv[0] = (char *) & i; argv[1] = NULL; getobj(saobj, "get", id, 1, argv, &ptr); if (arrayadd2(sarray, ptr) == NULL) goto End; } } End: if (arraynum(sarray) > 1) { arrayndel2(sarray, 0); } arraydel(&iarray); return sarray; } static int dlgbutton(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *title, *caption; int rcode, x, y; struct narray *sarray; sarray = get_sarray_argument((struct narray *) argv[2]); if (arraynum(sarray) == 0) { return -1; } if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &caption)) { caption = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } g_free(rval->str); rval->str = NULL; rcode = DialogButton(get_toplevel_window(), (title) ? title : _("Select"), caption, sarray, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); if (rcode >= 0) { const char *str; str = arraynget_str(sarray, rcode); if (str) { rval->str = g_strdup(str); } } return 0; } static int dlgradio(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *title, *caption; int locksave, r, x, y, ret; struct narray *iarray, *sarray; struct narray *buttons; int btn = -1; sarray = get_sarray_argument((struct narray *) argv[2]); if (arraynum(sarray) == 0) return 1; locksave = Globallock; Globallock = TRUE; if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &caption)) { caption = NULL; } if (_getobj(obj, "select", inst, &iarray)) { iarray = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } r = arraylast_int(iarray); buttons = dlg_get_buttons(obj, inst); ret = DialogRadio(get_toplevel_window(), (title) ? title : _("Select"), caption, sarray, buttons, &btn, &r, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "response_button", inst, &btn); if (ret != IDOK) { Globallock = locksave; return 1; } rval->i = r; Globallock = locksave; return 0; } static int dlgcombo(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int locksave, sel, ret, x, y; char *r, *title, *caption; struct narray *iarray, *sarray; struct narray *buttons; int btn = -1; sarray = get_sarray_argument((struct narray *) argv[2]); if (arraynum(sarray) == 0) return 1; locksave = Globallock; Globallock = TRUE; g_free(rval->str); rval->str = NULL; if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &caption)) { caption = NULL; } if (_getobj(obj, "select", inst, &iarray)) { iarray = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } sel = arraylast_int(iarray); buttons = dlg_get_buttons(obj, inst); if (strcmp(argv[1], "combo") == 0) { ret = DialogCombo(get_toplevel_window(), (title) ? title : _("Select"), caption, sarray, buttons, &btn, sel, &r, &x, &y); } else { ret = DialogComboEntry(get_toplevel_window(), (title) ? title : _("Input"), caption, sarray, buttons, &btn, sel, &r, &x, &y); } _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "response_button", inst, &btn); if (ret != IDOK) { Globallock = locksave; return 1; } rval->str = r; Globallock = locksave; return 0; } static int dlgspin(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int locksave, ret, type, x, y; char *title, *caption; double min, max, inc, r; struct narray *buttons; int btn = -1; locksave = Globallock; Globallock = TRUE; if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &caption)) { caption = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } type = argv[1][0]; switch (type) { case 'd': min = * (double *) argv[2]; max = * (double *) argv[3]; inc = * (double *) argv[4]; r = * (double *) argv[5]; break; case 'i': min = * (int *) argv[2]; max = * (int *) argv[3]; inc = * (int *) argv[4]; r = * (int *) argv[5]; break; default: Globallock = locksave; return 1; } buttons = dlg_get_buttons(obj, inst); ret = DialogSpinEntry(get_toplevel_window(), (title) ? title : _("Input"), caption, min, max, inc, buttons, &btn, &r, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "response_button", inst, &btn); if (ret != IDOK) { Globallock = locksave; return 1; } switch (type) { case 'd': rval->d = r; break; case 'i': rval->i = nround(r); break; default: Globallock = locksave; return 1; } Globallock = locksave; return 0; } static int dlgcheck(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int locksave, *r, i, n, inum, *ptr, x, y, ret; struct narray *array, *sarray, *iarray; char *title, *caption; struct narray *buttons; int btn = -1; sarray = get_sarray_argument((struct narray *) argv[2]); n = arraynum(sarray); if (n == 0) return 1; arrayfree(rval->array); rval->array = NULL; array = arraynew(sizeof(int)); if (array == NULL) { return 1; } if (_getobj(obj, "title", inst, &title)) { title = NULL; } if (_getobj(obj, "caption", inst, &caption)) { caption = NULL; } if (_getobj(obj, "select", inst, &iarray)) { iarray = NULL; } if (_getobj(obj, "x", inst, &x)) { x = -1; } if (_getobj(obj, "y", inst, &y)) { y = -1; } r = g_malloc(n * sizeof(int)); if (r == NULL) { arrayfree(array); return 1; } memset(r, 0, n * sizeof(int)); locksave = Globallock; Globallock = TRUE; inum = arraynum(iarray); for (i = 0; i < inum; i++) { ptr = (int *) arraynget(iarray, i); if (ptr && *ptr >= 0 && *ptr < n) r[*ptr] = 1; } buttons = dlg_get_buttons(obj, inst); ret = DialogCheck(get_toplevel_window(), (title) ? title : _("Select"), caption, sarray, buttons, &btn, r, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); _putobj(obj, "response_button", inst, &btn); if (ret != IDOK) { arrayfree(array); g_free(r); Globallock = locksave; return 1; } for (i = 0; i < n; i++) { if (r[i]) arrayadd(array, &i); } g_free(r); rval->array = array; Globallock = locksave; return 0; } static int dlgbeep(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int locksave; locksave = Globallock; Globallock = TRUE; message_beep(get_toplevel_window()); Globallock = locksave; return 0; } static int dlggetopenfile(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; char **d; int anum; char *filter = NULL, *initfile = NULL; int locksave; int ret; char *file; locksave = Globallock; Globallock = TRUE; g_free(rval->str); rval->str = NULL; array = (struct narray *)argv[2]; d = arraydata(array); anum = arraynum(array); switch (anum) { case 0: break; case 2: initfile = d[1]; /* fall through */ case 1: filter = d[0]; break; default: filter = d[0]; initfile = d[1]; } ret = nGetOpenFileName(get_toplevel_window(), _("Open file"), filter, NULL, initfile, &file, TRUE, TRUE); if (ret == IDOK) { if (file) { changefilename(file); rval->str = file; } } Globallock = locksave; return (ret == IDOK)? 0 : 1; } static int dlggetopenfiles(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; char **d; int anum, i; char *filter = NULL, *initfile = NULL; int locksave; int ret; char **file = NULL, *name; struct narray *farray; locksave = Globallock; Globallock = TRUE; arrayfree2(rval->array); rval->array = NULL; array = (struct narray *)argv[2]; d = arraydata(array); anum = arraynum(array); switch (anum) { case 0: break; case 2: initfile = d[1]; /* fall through */ case 1: filter = d[0]; break; default: filter = d[0]; initfile = d[1]; } ret = nGetOpenFileNameMulti(get_toplevel_window(), _("Open files"), filter, NULL, initfile, &file, TRUE); if (ret == IDOK) { farray = arraynew(sizeof(char *)); for (i = 0; file[i]; i++) { changefilename(file[i]); arrayadd(farray, &name); } rval->array = farray; } g_free(file); Globallock = locksave; return (ret == IDOK)? 0 : 1; } static int dlggetsavefile(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; char **d; int anum; char *filter = NULL, *initfile = NULL; int locksave; int ret; char *file; locksave = Globallock; Globallock = TRUE; g_free(rval->str); rval->str = NULL; array = (struct narray *)argv[2]; d = arraydata(array); anum = arraynum(array); switch (anum) { case 0: break; case 2: initfile = d[1]; /* fall through */ case 1: filter = d[0]; break; default: filter = d[0]; initfile = d[1]; } ret = nGetSaveFileName(get_toplevel_window(), _("Save file"), filter, NULL, initfile, &file, FALSE, TRUE); if (ret == IDOK) { if (file) { changefilename(file); rval->str = file; } } Globallock = locksave; return (ret == IDOK) ? 0 : 1; } static struct objtable dialog[] = { {"init", NVFUNC, NEXEC, dlginit, NULL, 0}, {"done", NVFUNC, NEXEC, dlgdone, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, {"x", NINT, NREAD | NWRITE, NULL, NULL, 0}, {"y", NINT, NREAD | NWRITE, NULL, NULL, 0}, {"title", NSTR, NREAD | NWRITE, NULL, NULL, 0}, {"caption", NSTR, NREAD | NWRITE, NULL, NULL, 0}, {"select", NIARRAY, NREAD | NWRITE, NULL, NULL, 0}, {"buttons", NSARRAY, NREAD | NWRITE, NULL, NULL, 0}, {"response_button", NINT, NREAD, NULL, NULL, 0}, {"yesno", NIFUNC, NREAD | NEXEC, dlgconfirm, "s", 0}, {"message", NVFUNC, NREAD | NEXEC, dlgmessage, "s", 0}, {"input", NSFUNC, NREAD | NEXEC, dlginput, "s", 0}, {"radio", NIFUNC, NREAD | NEXEC, dlgradio, "sa", 0}, {"check", NIAFUNC, NREAD | NEXEC, dlgcheck, "sa", 0}, {"button", NSFUNC, NREAD | NEXEC, dlgbutton, "sa", 0}, {"combo", NSFUNC, NREAD | NEXEC, dlgcombo, "sa", 0}, {"combo_entry", NSFUNC, NREAD | NEXEC, dlgcombo, "sa", 0}, {"double_entry", NDFUNC, NREAD | NEXEC, dlgspin, "dddd", 0}, {"integer_entry", NIFUNC, NREAD | NEXEC, dlgspin, "iiii", 0}, {"beep", NVFUNC, NREAD | NEXEC, dlgbeep, "", 0}, {"get_open_file", NSFUNC, NREAD | NEXEC, dlggetopenfile, "sa", 0}, {"get_open_files", NSAFUNC, NREAD | NEXEC, dlggetopenfiles, "sa", 0}, {"get_save_file", NSFUNC, NREAD | NEXEC, dlggetsavefile, "sa", 0}, }; #define TBLNUM (sizeof(dialog) / sizeof(*dialog)) void * adddialog() { return addobject(NAME, NULL, PARENT, NVERSION, TBLNUM, dialog, ERRNUM, dlgerrorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/x11lgnd.c0000644000175000017500000031457713360277171013676 00000000000000/* * $Id: x11lgnd.c,v 1.68 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include "dir_defs.h" #include "strconv.h" #include "ioutil.h" #include "object.h" #include "gra.h" #include "ogra2cairo.h" #include "ogra2gdk.h" #include "odraw.h" #include "otext.h" #include "opath.h" #include "nstring.h" #include "mathfn.h" #include "gtk_liststore.h" #include "gtk_entry_completion.h" #include "gtk_subwin.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "x11bitmp.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "ox11menu.h" #include "x11file.h" #include "x11view.h" #include "x11lgnd.h" #include "x11commn.h" #define ARROW_VIEW_SIZE 160 static n_list_store Plist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {"type", G_TYPE_PARAM, TRUE, TRUE, "type"}, {N_("marker begin"), G_TYPE_ENUM, TRUE, TRUE, "marker_begin"}, {N_("marker end"), G_TYPE_ENUM, TRUE, TRUE, "marker_end"}, {N_("color"), G_TYPE_OBJECT, TRUE, TRUE, "color"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("width"), G_TYPE_DOUBLE, TRUE, TRUE, "width", 0, SPIN_ENTRY_MAX, 20, 100}, {N_("points"), G_TYPE_INT, TRUE, FALSE, "points"}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, }; enum PATH_LIST_COL { PATH_LIST_COL_HIDDEN = 0, PATH_LIST_COL_ID, PATH_LIST_COL_TYPE, PATH_LIST_COL_MARKER_BEGIN, PATH_LIST_COL_MARKER_END, PATH_LIST_COL_COLOR, PATH_LIST_COL_X, PATH_LIST_COL_Y, PATH_LIST_COL_WIDTH, PATH_LIST_COL_POINTS, PATH_LIST_COL_OID, PATH_LIST_COL_NUM, }; static n_list_store Rlist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {N_("color"), G_TYPE_OBJECT, TRUE, TRUE, "color"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x1", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y1", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"width", G_TYPE_DOUBLE, TRUE, TRUE, "width", 0, SPIN_ENTRY_MAX, 20, 100}, {N_("height"), G_TYPE_DOUBLE, TRUE, TRUE, "height", 0, SPIN_ENTRY_MAX, 20, 100}, {N_("line width"), G_TYPE_DOUBLE, TRUE, TRUE, "width", 0, SPIN_ENTRY_MAX, 20, 100}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, }; enum RECT_LIST_COL { RECT_LIST_COL_HIDDEN = 0, RECT_LIST_COL_ID, RECT_LIST_COL_COLOR, RECT_LIST_COL_X, RECT_LIST_COL_Y, RECT_LIST_COL_WIDTH, RECT_LIST_COL_HEIGHT, RECT_LIST_COL_LWIDTH, RECT_LIST_COL_OID, RECT_LIST_COL_NUM, }; static n_list_store Alist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {"color", G_TYPE_OBJECT, TRUE, TRUE, "color"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"rx", G_TYPE_DOUBLE, TRUE, TRUE, "rx", 0, SPIN_ENTRY_MAX, 100, 1000}, {"ry", G_TYPE_DOUBLE, TRUE, TRUE, "ry", 0, SPIN_ENTRY_MAX, 100, 1000}, {N_("angle1"), G_TYPE_DOUBLE, TRUE, TRUE, "angle1", 0, 36000, 100, 1500}, {N_("angle2"), G_TYPE_DOUBLE, TRUE, TRUE, "angle2", 0, 36000, 100, 1500}, {N_("pieslice"), G_TYPE_BOOLEAN, TRUE, TRUE, "pieslice"}, {N_("width"), G_TYPE_DOUBLE, TRUE, TRUE, "width", 0, SPIN_ENTRY_MAX, 20, 100}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, }; enum ARC_LIST_COL { ARC_LIST_COL_HIDDEN = 0, ARC_LIST_COL_ID, ARC_LIST_COL_COLOR, ARC_LIST_COL_X, ARC_LIST_COL_Y, ARC_LIST_COL_RX, ARC_LIST_COL_RY, ARC_LIST_COL_ANGLE1, ARC_LIST_COL_ANGLE2, ARC_LIST_COL_PIESLICE, ARC_LIST_COL_WIDTH, ARC_LIST_COL_OID, ARC_LIST_COL_NUM, }; static n_list_store Mlist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {"mark", G_TYPE_OBJECT, TRUE, TRUE, "type"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("size"), G_TYPE_DOUBLE, TRUE, TRUE, "size", 0, SPIN_ENTRY_MAX, 100, 200}, {"width", G_TYPE_DOUBLE, TRUE, TRUE, "width", 0, SPIN_ENTRY_MAX, 20, 100}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, }; enum MARK_LIST_COL { MARK_LIST_COL_HIDDEN = 0, MARK_LIST_COL_ID, MARK_LIST_COL_MARK, MARK_LIST_COL_X, MARK_LIST_COL_Y, MARK_LIST_COL_SIZE, MARK_LIST_COL_WIDTH, MARK_LIST_COL_OID, MARK_LIST_COL_NUM, }; static n_list_store Tlist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {"text", G_TYPE_STRING, TRUE, TRUE, "text", 0, 0, 0, 0, PANGO_ELLIPSIZE_END}, {N_("font"), G_TYPE_PARAM, TRUE, TRUE, "font"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("pt"), G_TYPE_DOUBLE, TRUE, TRUE, "pt", 0, SPIN_ENTRY_MAX, 100, 1000}, {N_("direction"), G_TYPE_DOUBLE, TRUE, TRUE, "direction", 0, 36000, 100, 1500}, {"raw", G_TYPE_BOOLEAN, TRUE, TRUE, "raw"}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, {"style", G_TYPE_INT, FALSE, FALSE, "style"}, {"weight", G_TYPE_INT, FALSE, FALSE, "weight"}, {"color", G_TYPE_STRING, FALSE, FALSE, "color"}, {"bgcolor", G_TYPE_STRING, FALSE, FALSE, "bgcolor"}, #ifdef TEXT_LIST_USE_FONT_FAMILY {"font_family", G_TYPE_STRING, FALSE, FALSE, "font_family"}, #endif }; enum TEXT_LIST_COL { TEXT_LIST_COL_HIDDEN = 0, TEXT_LIST_COL_ID, TEXT_LIST_COL_TEXT, TEXT_LIST_COL_FONT, TEXT_LIST_COL_X, TEXT_LIST_COL_Y, TEXT_LIST_COL_PT, TEXT_LIST_COL_DIR, TEXT_LIST_COL_RAW, TEXT_LIST_COL_OID, TEXT_LIST_COL_STYLE, TEXT_LIST_COL_WEIGHT, TEXT_LIST_COL_COLOR, TEXT_LIST_COL_BGCOLOR, #ifdef TEXT_LIST_USE_FONT_FAMILY TEXT_LIST_COL_FONT_FAMILY, #endif TEXT_LIST_COL_NUM, }; static struct subwin_popup_list Popup_list[] = { {N_("_Duplicate"), G_CALLBACK(list_sub_window_copy), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, // {N_("duplicate _Behind"), G_CALLBACK(list_sub_window_copy), FALSE, NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Delete"), G_CALLBACK(list_sub_window_delete), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Focus"), G_CALLBACK(list_sub_window_focus), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Properties"), G_CALLBACK(list_sub_window_update), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Instance name"), G_CALLBACK(list_sub_window_object_name), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Top"), G_CALLBACK(list_sub_window_move_top), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Up"), G_CALLBACK(list_sub_window_move_up), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Down"), G_CALLBACK(list_sub_window_move_down), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Bottom"), G_CALLBACK(list_sub_window_move_last), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; #define POPUP_ITEM_NUM (sizeof(Popup_list) / sizeof(*Popup_list) - 1) #define POPUP_ITEM_TOP 7 #define POPUP_ITEM_UP 8 #define POPUP_ITEM_DOWN 9 #define POPUP_ITEM_BOTTOM 10 typedef void (* LEGEND_DIALOG_SETUP)(struct LegendDialog *data, struct objlist *obj, int id); static void LegendMarkDialogMark(GtkWidget *w, gpointer client_data); static void LegendDialogCopy(struct LegendDialog *d); static void path_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static void rect_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static void arc_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static void mark_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static void text_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); enum LegendType { LegendTypePath = 0, LegendTypeRect, LegendTypeArc, LegendTypeMark, LegendTypeText, }; static char *MarkChar[] = { "â—", "â—‹", "â—‹", "â—Ž", "⦿", "", "â—‘", "â—", "â—“", "â—’", "â– ", "⬜", "⬜", "⧈", "â–£", "", "â—¨", "â—§", "⬒", "⬓", "â—†", "â—‡", "â—‡", "", "â—ˆ", "", "⬗", "⬖", "⬘", "⬙", "â–²", "â–³", "â–³", "", "", "", "â—®", "â—­", "â§—", "â§–", "â–¼", "â–½", "â–½", "", "", "", "â§©", "⧨", "", "", "â—€", "â—", "â—", "", "", "", "", "", "â§“", "⋈", "â–¶", "â–·", "â–·", "", "", "", "", "", "â§’", "â§‘", "+", "×", "∗", "âš¹", "", "", "", "", "―", "|", "â—Ž", "â¨", "⨂", "⧈", "⊞", "⊠", "", "", "", "·", }; #define MarkCharNum ((int) (sizeof(MarkChar) / sizeof(*MarkChar))) struct lwidget { GtkWidget *w; char *f; }; static void legend_menu_update_object(const char *name, char *(*callback) (struct objlist * obj, int id), void *dialog, LEGEND_DIALOG_SETUP setup) { struct narray array; struct objlist *obj; int i, j; int *data, num; char title[256], *objs[2]; if (Menulock || Globallock) return; if ((obj = chkobject(name)) == NULL) return; if (chkobjlastinst(obj) == -1) return; snprintf(title, sizeof(title), _("%s property (multi select)"), _(obj->name)); SelectDialog(&DlgSelect, obj, title, callback, &array, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&array); if (num > 0) { menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); data = arraydata(&array); for (i = 0; i < num; i++) { setup(dialog, obj, data[i]); if (DialogExecute(TopLevel, dialog) == IDDELETE) { delobj(obj, data[i]); set_graph_modified(); for (j = i + 1; j < num; j++) { data[j]--; } } } objs[0] = obj->name; objs[1] = NULL; LegendWinUpdate(objs, TRUE, TRUE); } } arraydel(&array); } static void legend_menu_delete_object(const char *name, char *(*callback) (struct objlist * obj, int id)) { struct narray array; struct objlist *obj; int i; int num, *data; char title[256], *objs[2]; if (Menulock || Globallock) return; if ((obj = chkobject(name)) == NULL) return; if (chkobjlastinst(obj) == -1) return; snprintf(title, sizeof(title), _("delete %s (multi select)"), _(obj->name)); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&array); if (num > 0) { menu_save_undo_single(UNDO_TYPE_DELETE, obj->name); data = arraydata(&array); for (i = num - 1; i >= 0; i--) { delobj(obj, data[i]); set_graph_modified(); } objs[0] = obj->name; objs[1] = NULL; LegendWinUpdate(objs, TRUE, TRUE); } } arraydel(&array); } static char * LegendLineCB(struct objlist *obj, int id) { struct narray *array; int num, *data, path_type; char *s, **enum_path_type; getobj(obj, "type", id, 0, NULL, &path_type); enum_path_type = (char **) chkobjarglist(obj, "type"); getobj(obj, "points", id, 0, NULL, &array); num = arraynum(array); data = arraydata(array); if (num < 2) { s = g_strdup("------"); } else { s = g_strdup_printf("%s (X:%.2f Y:%.2f)-", _(enum_path_type[path_type]), data[0] / 100.0, data[1] / 100.0); } return s; } static char * LegendRectCB(struct objlist *obj, int id) { int x1, y1; char *s; getobj(obj, "x1", id, 0, NULL, &x1); getobj(obj, "y1", id, 0, NULL, &y1); s = g_strdup_printf("X1:%.2f Y1:%.2f", x1 / 100.0, y1 / 100.0); return s; } static char * LegendArcCB(struct objlist *obj, int id) { int x1, y1; char *s; getobj(obj, "x", id, 0, NULL, &x1); getobj(obj, "y", id, 0, NULL, &y1); s = g_strdup_printf("X:%.2f Y:%.2f", x1 / 100.0, y1 / 100.0); return s; } static char * LegendMarkCB(struct objlist *obj, int id) { int x, y, type; char *s; getobj(obj, "x", id, 0, NULL, &x); getobj(obj, "y", id, 0, NULL, &y); getobj(obj, "type", id, 0, NULL, &type); if (type >= 0 && type < MarkCharNum) { char *mc = MarkChar[type]; s = g_strdup_printf(_("X:%.2f Y:%.2f %s%stype:%-2d"), x / 100.0, y / 100.0, mc, (mc[0]) ? " " : "", type); } else { s = g_strdup_printf("X:%.2f Y:%.2f", x / 100.0, y / 100.0); } return s; } static char * LegendTextCB(struct objlist *obj, int id) { char *text, *s; getobj(obj, "text", id, 0, NULL, &text); if (text) { s = g_strdup(text); } else { s = g_strdup(""); } return s; } static void init_legend_dialog_widget_member(struct LegendDialog *d) { d->path_type = NULL; d->stroke = NULL; d->close_path = NULL; d->style = NULL; d->points = NULL; d->interpolation = NULL; d->width = NULL; d->miter = NULL; d->join = NULL; d->color = NULL; d->color2 = NULL; d->stroke_color = NULL; d->fill_color = NULL; d->x = NULL; d->y = NULL; d->x1 = NULL; d->y1 = NULL; d->x2 = NULL; d->y2 = NULL; d->rx = NULL; d->ry = NULL; d->pieslice = NULL; d->size = NULL; d->type = NULL; d->mark_type_begin = NULL; d->mark_type_end = NULL; d->angle1 = NULL; d->angle2 = NULL; d->fill = NULL; d->fill_rule = NULL; d->marker_begin = NULL; d->marker_end = NULL; d->arrow_length = NULL; d->arrow_width = NULL; d->view = NULL; d->text = NULL; d->pt = NULL; d->space = NULL; d->script_size = NULL; d->direction = NULL; d->raw = NULL; d->font = NULL; d->font_bold = NULL; d->font_italic = NULL; } static void get_font(struct LegendDialog *d) { int style, bold, italic, old_style; SetObjFieldFromFontList(d->font, d->Obj, d->Id, "font"); style = 0; bold = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->font_bold)); if (bold) { style |= GRA_FONT_STYLE_BOLD; } italic = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->font_italic)); if (italic) { style |= GRA_FONT_STYLE_ITALIC; } getobj(d->Obj, "style", d->Id, 0, NULL, &old_style); if (old_style != style) { putobj(d->Obj, "style", d->Id, &style); set_graph_modified(); } } static void set_font(struct LegendDialog *d, int id) { int style; struct compatible_font_info *compatible; compatible = SetFontListFromObj(d->font, d->Obj, d->Id, "font"); if (compatible) { /* for backward compatibility */ style = compatible->style; if (d->text && compatible->symbol) { char buf[] = "%F{Sym}", *tmp; const char *str; str = gtk_entry_get_text(GTK_ENTRY(d->text)); if (str && strncmp(str, buf, sizeof(buf) - 1)) { tmp = g_strdup_printf("%s%s", buf, str); gtk_entry_set_text(GTK_ENTRY(d->text), tmp); g_free(tmp); } } } else { getobj(d->Obj, "style", d->Id, 0, NULL, &style); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->font_bold), style & GRA_FONT_STYLE_BOLD); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->font_italic), style & GRA_FONT_STYLE_ITALIC); } static void legend_dialog_set_sensitive(GtkWidget *w, gpointer client_data) { struct LegendDialog *d; int path_type, marker_type; d = (struct LegendDialog *) client_data; path_type = PATH_TYPE_LINE; if (d->path_type && d->interpolation) { path_type = combo_box_get_active(d->path_type); set_widget_sensitivity_with_label(d->interpolation, path_type == PATH_TYPE_CURVE); } if (d->stroke && d->stroke_color && d->style && d->width) { int stroke; stroke = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->stroke)); set_widget_sensitivity_with_label(d->stroke_color, stroke); set_widget_sensitivity_with_label(d->style, stroke); set_widget_sensitivity_with_label(d->width, stroke); } if (d->stroke && d->miter && d->join && d->close_path) { int stroke; stroke = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->stroke)); set_widget_sensitivity_with_label(d->miter, stroke); set_widget_sensitivity_with_label(d->join, stroke); set_widget_sensitivity_with_label(d->close_path, stroke); } if (d->stroke && d->close_path && d->marker_begin && d->marker_end && d->arrow_length && d->arrow_width) { int stroke; stroke = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->stroke)); set_widget_sensitivity_with_label(d->miter, stroke); set_widget_sensitivity_with_label(d->join, stroke); set_widget_sensitivity_with_label(d->marker_begin, stroke); gtk_widget_set_sensitive(d->marker_end, stroke); set_widget_sensitivity_with_label(d->arrow_length, stroke); set_widget_sensitivity_with_label(d->arrow_width, stroke); marker_type = combo_box_get_active(d->marker_begin); gtk_widget_set_sensitive(d->mark_type_begin, marker_type == MARKER_TYPE_MARK && stroke); marker_type = combo_box_get_active(d->marker_end); gtk_widget_set_sensitive(d->mark_type_end, marker_type == MARKER_TYPE_MARK && stroke); if (d->interpolation) { int intp; intp = combo_box_get_active(d->interpolation); if (path_type == PATH_TYPE_CURVE) { set_widget_sensitivity_with_label(d->close_path, stroke && (intp != INTERPOLATION_TYPE_SPLINE_CLOSE && intp != INTERPOLATION_TYPE_BSPLINE_CLOSE)); } } if (path_type != PATH_TYPE_CURVE) { set_widget_sensitivity_with_label(d->close_path, stroke); } } if (d->fill && d->fill_color) { int fill; fill = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->fill)); if (d->marker_begin && d->marker_end) { int marker_begin, marker_end, stroke; stroke = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->stroke)); marker_begin = combo_box_get_active(d->marker_begin); marker_end = combo_box_get_active(d->marker_end); set_widget_sensitivity_with_label(d->fill_color, (stroke && (marker_begin == MARKER_TYPE_MARK || marker_end == MARKER_TYPE_MARK)) || fill); } else { set_widget_sensitivity_with_label(d->fill_color, fill); } if (d->fill_rule) { set_widget_sensitivity_with_label(d->fill_rule, fill); } } } static void setup_mark_type(struct LegendDialog *d, int id, GtkWidget *type, const char *field, struct MarkDialog *mark) { int a; getobj(d->Obj, field, id, 0, NULL, &a); button_set_mark_image(type, a); MarkDialog(mark, d->widget, a); } static void legend_dialog_setup_item(GtkWidget *w, struct LegendDialog *d, int id) { unsigned int i; int x1, y1, x2, y2; struct lwidget lw[] = { {d->stroke, "stroke"}, {d->path_type, "type"}, {d->close_path, "close_path"}, {d->width, "width"}, {d->join, "join"}, {d->miter, "miter_limit"}, {d->interpolation, "interpolation"}, {d->x, "x"}, {d->y, "y"}, {d->x1, "x1"}, {d->y1, "y1"}, {d->rx, "rx"}, {d->ry, "ry"}, {d->angle1, "angle1"}, {d->angle2, "angle2"}, {d->fill, "fill"}, {d->fill_rule, "fill_rule"}, {d->raw, "raw"}, {d->pieslice, "pieslice"}, {d->size, "size"}, {d->pt, "pt"}, {d->direction, "direction"}, {d->space, "space"}, {d->script_size, "script_size"}, }; SetTextFromObjPoints(d->points, d->Obj, id, "points"); SetStyleFromObjField(d->style, d->Obj, id, "style"); for (i = 0; i < sizeof(lw) / sizeof(*lw); i++) { SetWidgetFromObjField(lw[i].w, d->Obj, id, lw[i].f); } if (d->arrow_length) { int len, wid; getobj(d->Obj, "arrow_length", id, 0, NULL, &len); getobj(d->Obj, "arrow_width", id, 0, NULL, &wid); d->wid = (wid / 100) * 100; d->ang = atan(0.5 * d->wid / len) * 2 * 180 / MPI; if (d->ang < 10) { d->ang = 10; } else if (d->ang > 170) { d->ang = 170; } gtk_range_set_value(GTK_RANGE(d->arrow_width), d->wid / 100); gtk_range_set_value(GTK_RANGE(d->arrow_length), d->ang); } if (d->type) { setup_mark_type(d, id, d->type, "type", &(d->mark)); } if (d->marker_begin) { getobj(d->Obj, "marker_begin", id, 0, NULL, &i); combo_box_set_active(d->marker_begin, i); } if (d->marker_end) { getobj(d->Obj, "marker_end", id, 0, NULL, &i); combo_box_set_active(d->marker_end, i); } if (d->mark_type_begin) { setup_mark_type(d, id, d->mark_type_begin, "mark_type_begin", &(d->mark_begin)); } if (d->mark_type_end) { setup_mark_type(d, id, d->mark_type_end, "mark_type_end", &(d->mark_end)); } if (d->x1 && d->y1 && d->x2 && d->y2) { getobj(d->Obj, "x1", id, 0, NULL, &x1); getobj(d->Obj, "y1", id, 0, NULL, &y1); getobj(d->Obj, "x2", id, 0, NULL, &x2); getobj(d->Obj, "y2", id, 0, NULL, &y2); spin_entry_set_val(d->x2, x2 - x1); spin_entry_set_val(d->y2, y2 - y1); } if (d->text) { char *buf; sgetobjfield(d->Obj,id,"text",NULL,&buf,FALSE,FALSE,FALSE); if (buf) { gtk_entry_set_text(GTK_ENTRY(d->text), buf); g_free(buf); } } if (d->font && d->font_bold && d->font_italic) set_font(d, id); if (d->color) set_color(d->color, d->Obj, id, NULL); if (d->color2) set_color2(d->color2, d->Obj, id); if (d->stroke_color) set_stroke_color(d->stroke_color, d->Obj, id); if (d->fill_color) set_fill_color(d->fill_color, d->Obj, id); legend_dialog_set_sensitive(NULL, d); } static int set_mark_type(struct LegendDialog *d, const char *field, struct MarkDialog *mark) { int oval; getobj(d->Obj, field, d->Id, 0, NULL, &oval); if (oval != mark->Type) { if (putobj(d->Obj, field, d->Id, &(mark->Type)) == -1) { return 1; } set_graph_modified(); } return 0; } static void legend_dialog_close(GtkWidget *w, void *data) { struct LegendDialog *d = (struct LegendDialog *) data; unsigned int i; int ret, x1, y1, x2, y2, oval; struct lwidget lw[] = { {d->stroke, "stroke"}, {d->path_type, "type"}, {d->close_path, "close_path"}, {d->width, "width"}, {d->join, "join"}, {d->miter, "miter_limit"}, {d->interpolation, "interpolation"}, {d->x, "x"}, {d->y, "y"}, {d->x1, "x1"}, {d->y1, "y1"}, {d->rx, "rx"}, {d->ry, "ry"}, {d->angle1, "angle1"}, {d->angle2, "angle2"}, {d->fill, "fill"}, {d->fill_rule, "fill_rule"}, {d->raw, "raw"}, {d->marker_begin, "marker_begin"}, {d->marker_end, "marker_end"}, {d->pieslice, "pieslice"}, {d->size, "size"}, {d->pt, "pt"}, {d->direction, "direction"}, {d->space, "space"}, {d->script_size, "script_size"}, }; switch(d->ret) { case IDOK: break; case IDCOPY: LegendDialogCopy(d); d->ret = IDLOOP; return; default: return; } ret = d->ret; d->ret = IDLOOP; for (i = 0; i < sizeof(lw) / sizeof(*lw); i++) { if (SetObjFieldFromWidget(lw[i].w, d->Obj, d->Id, lw[i].f)) return; } if (SetObjPointsFromText(d->points, d->Obj, d->Id, "points")) return; if (SetObjFieldFromStyle(d->style, d->Obj, d->Id, "style")) return; if (d->x1 && d->y1 && d->x2 && d->y2) { x1 = spin_entry_get_val(d->x1); x2 = spin_entry_get_val(d->x2); y1 = spin_entry_get_val(d->y1); y2 = spin_entry_get_val(d->y2); x2 += x1; y2 += y1; getobj(d->Obj, "x2", d->Id, 0, NULL, &oval); if (oval != x2 && putobj(d->Obj, "x2", d->Id, &x2) == -1) return; getobj(d->Obj, "y2", d->Id, 0, NULL, &oval); if (oval != y2 && putobj(d->Obj, "y2", d->Id, &y2) == -1) return; } if (d->arrow_length) { int wid, ang, len; wid = gtk_range_get_value(GTK_RANGE(d->arrow_width)); ang = gtk_range_get_value(GTK_RANGE(d->arrow_length)); d->wid = wid * 100; d->ang = ang; len = d->wid * 0.5 / tan(d->ang * 0.5 * MPI / 180); getobj(d->Obj, "arrow_length", d->Id, 0, NULL, &oval); if (oval != len) { if (putobj(d->Obj, "arrow_length", d->Id, &len) == -1) { return; } set_graph_modified(); } getobj(d->Obj, "arrow_width", d->Id, 0, NULL, &oval); if (oval != d->wid) { if(putobj(d->Obj, "arrow_width", d->Id, &(d->wid)) == -1) { return; } set_graph_modified(); } } if (d->type) { set_mark_type(d, "type", &(d->mark)); } if (d->mark_type_begin) { set_mark_type(d, "mark_type_begin", &(d->mark_begin)); } if (d->mark_type_end) { set_mark_type(d, "mark_type_end", &(d->mark_end)); } if (d->font && d->font_bold && d->font_italic) { get_font(d); } if (d->text) { const char *str; char *ptr; str = gtk_entry_get_text(GTK_ENTRY(d->text)); if (str == NULL) return; entry_completion_append(NgraphApp.legend_text_list, str); ptr = g_strdup(str); if (ptr) { char *org_str; sgetobjfield(d->Obj, d->Id, "text", NULL, &org_str, FALSE, FALSE, FALSE); if (org_str == NULL || strcmp(ptr, org_str)) { if (sputobjfield(d->Obj, d->Id, "text", ptr) != 0) { g_free(org_str); g_free(ptr); return; } set_graph_modified(); } g_free(org_str); g_free(ptr); } } if (d->stroke_color && putobj_stroke_color(d->stroke_color, d->Obj, d->Id)) return; if (d->fill_color && putobj_fill_color(d->fill_color, d->Obj, d->Id)) return; if (d->color && putobj_color(d->color, d->Obj, d->Id, NULL)) return; if (d->color2 && putobj_color2(d->color2, d->Obj, d->Id)) return; d->ret = ret; } static void legend_copy_clicked(GtkButton *btn, gpointer user_data) { int sel; struct LegendDialog *d; d = (struct LegendDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, d->prop_cb); if (sel != -1) { legend_dialog_setup_item(d->widget, d, sel); } } static void LegendDialogCopy(struct LegendDialog *d) { int sel; if ((sel = CopyClick(d->widget, d->Obj, d->Id, d->prop_cb)) != -1) legend_dialog_setup_item(d->widget, d, sel); } static void width_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); d->width = w; add_widget_to_table(table, w, _("_Line width:"), FALSE, i++); } #define POINTS_DIMENSION 2 static void renderer_func(GtkTreeViewColumn *col, GtkCellRenderer *renderer, GtkTreeModel *model, GtkTreeIter *iter, gpointer data) { int n; double v; char buf[1024]; n = GPOINTER_TO_INT(data); gtk_tree_model_get(model, iter, n, &v, -1); snprintf(buf, sizeof(buf), "%.2f", v); g_object_set((GObject *) renderer, "text", buf, NULL); } static void column_edited(GtkCellRenderer *cell_renderer, gchar *path_str, gchar *str, int column, gpointer user_data) { double d; char *eptr; GtkTreeModel *list; GtkTreeIter iter; GtkTreePath *path; int r; path = gtk_tree_path_new_from_string(path_str); if (path == NULL) return; list = GTK_TREE_MODEL(user_data); r = gtk_tree_model_get_iter(list, &iter, path); if (! r) return; d = strtod(str, &eptr); if (d != d || d == HUGE_VAL || d == - HUGE_VAL || eptr == str) return; gtk_list_store_set(GTK_LIST_STORE(list), &iter, column, d, -1); } static void column_0_edited(GtkCellRenderer *cell_renderer, gchar *path_str, gchar *str, gpointer user_data) { column_edited(cell_renderer, path_str, str, 0, user_data); } static void column_1_edited(GtkCellRenderer *cell_renderer, gchar *path_str, gchar *str, gpointer user_data) { column_edited(cell_renderer, path_str, str, 1, user_data); } static void insert_column(GtkWidget *w, gpointer user_data) { GtkTreeView *tree_view; GtkTreeModel *list; GtkTreeIter iter, tmp; GtkTreePath *path; int r; tree_view = GTK_TREE_VIEW(user_data); list = gtk_tree_view_get_model(tree_view); if (list == NULL) { return; } gtk_tree_view_get_cursor(tree_view, &path, NULL); if (path) { r = gtk_tree_model_get_iter(list, &iter, path); if (! r) goto End; gtk_list_store_insert_after(GTK_LIST_STORE(list), &tmp, &iter); } else { gtk_list_store_append(GTK_LIST_STORE(list), &tmp); } if (path) { gtk_tree_path_free(path); } path = gtk_tree_model_get_path(list, &tmp); if (path) { gtk_tree_view_set_cursor(tree_view, path, NULL, FALSE); } End: if (path) gtk_tree_path_free(path); } static void set_delete_button_sensitivity(GtkTreeSelection *sel, gpointer user_data) { GtkWidget *btn; int n; btn = GTK_WIDGET(user_data); n = gtk_tree_selection_count_selected_rows(sel); gtk_widget_set_sensitive(btn, n > 0); } static GtkWidget * points_setup(struct LegendDialog *d) { GtkWidget *label, *swin, *vbox, *hbox, *tree_view, *btn; GtkTreeModel *list; GtkCellRenderer *renderer; GtkTreeViewColumn *col; GtkTreeSelection *sel; char *title[] = {"x", "y"}; int i; GCallback edited_func[] = {G_CALLBACK(column_0_edited), G_CALLBACK(column_1_edited)}; list = GTK_TREE_MODEL(gtk_list_store_new(POINTS_DIMENSION, G_TYPE_DOUBLE, G_TYPE_DOUBLE)); tree_view = gtk_tree_view_new_with_model(list); #if ! GTK_CHECK_VERSION(3, 14, 0) gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(tree_view), TRUE); #endif gtk_tree_view_set_rubber_banding(GTK_TREE_VIEW(tree_view), FALSE); gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(tree_view), GTK_TREE_VIEW_GRID_LINES_VERTICAL); gtk_tree_view_set_reorderable(GTK_TREE_VIEW(tree_view), TRUE); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(tree_view)); gtk_tree_selection_set_mode(sel, GTK_SELECTION_MULTIPLE); for (i = 0; i < POINTS_DIMENSION; i++) { #if GTK_CHECK_VERSION(3, 8, 0) renderer = gtk_cell_renderer_spin_new(); #else renderer = gtk_cell_renderer_text_new(); #endif g_object_set((GObject *) renderer, "xalign", 1.0, "editable", TRUE, #if GTK_CHECK_VERSION(3, 8, 0) "adjustment", gtk_adjustment_new(0, -SPIN_ENTRY_MAX / 100.0, SPIN_ENTRY_MAX / 100.0, 1, 10, 0), "digits", 2, #endif NULL); g_signal_connect(renderer, "edited", G_CALLBACK(edited_func[i]), list); col = gtk_tree_view_column_new_with_attributes(title[i], renderer, "text", i, NULL); gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), col); gtk_tree_view_column_set_cell_data_func(col, renderer, renderer_func, GINT_TO_POINTER(i), NULL); gtk_tree_view_column_set_expand(col, TRUE); } vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); label = gtk_label_new_with_mnemonic(_("_Points:")); set_widget_margin(label, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_TOP | WIDGET_MARGIN_BOTTOM); gtk_widget_set_halign(label, GTK_ALIGN_START); gtk_label_set_mnemonic_widget(GTK_LABEL(label), tree_view); gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(swin), GTK_SHADOW_ETCHED_IN); gtk_container_set_border_width(GTK_CONTAINER(swin), 2); set_widget_margin(swin, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_container_add(GTK_CONTAINER(swin), tree_view); gtk_box_pack_start(GTK_BOX(vbox), swin, TRUE, TRUE, 0); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); btn = gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(btn, "list-add"); g_signal_connect(btn, "clicked", G_CALLBACK(insert_column), tree_view); gtk_box_pack_start(GTK_BOX(hbox), btn, FALSE, FALSE, 4); btn = gtk_button_new_with_mnemonic(_("_Delete")); g_signal_connect(btn, "clicked", G_CALLBACK(list_store_remove_selected_cb), tree_view); g_signal_connect(sel, "changed", G_CALLBACK(set_delete_button_sensitivity), btn); gtk_widget_set_sensitive(btn, FALSE); gtk_box_pack_start(GTK_BOX(hbox), btn, FALSE, FALSE, 4); set_widget_margin(hbox, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); d->points = tree_view; return vbox; } static void style_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); d->style = w; add_widget_to_table(table, w, _("Line _Style:"), TRUE, i); } static void miter_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); d->miter = w; add_widget_to_table(table, w, _("_Miter:"), FALSE, i++); } static void join_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = combo_box_create(); d->join = w; add_widget_to_table(table, w, _("_Join:"), FALSE, i++); } static void color_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_color_button(d->widget); d->color = w; add_widget_to_table(table, w, _("_Color:"), FALSE, i); } static void color2_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_color_button(d->widget); d->color2 = w; add_widget_to_table(table, w, _("_Color2:"), FALSE, i); } static void fill_color_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_color_button(d->widget); d->fill_color = w; add_widget_to_table(table, w, _("_Color:"), FALSE, i); } static void stroke_color_setup(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w; w = create_color_button(d->widget); d->stroke_color = w; add_widget_to_table(table, w, _("_Color:"), FALSE, i); } static void draw_arrow_pixmap(GtkWidget *win, struct LegendDialog *d) { int lw, len, x, w; cairo_t *cr; GdkWindow *window; window = gtk_widget_get_window(win); if (window == NULL) { return; } if (d->arrow_pixmap == NULL) { d->arrow_pixmap = cairo_image_surface_create(CAIRO_FORMAT_RGB24, ARROW_VIEW_SIZE, ARROW_VIEW_SIZE); } cr = cairo_create(d->arrow_pixmap); cairo_set_source_rgb(cr, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); cairo_paint(cr); cairo_set_source_rgb(cr, 0, 0, 0); lw = ARROW_VIEW_SIZE / 20; len = d->wid * 0.5 / tan(d->ang * 0.5 * MPI / 180); x = nround(lw * (len / 10000.0)); w = nround(lw * (d->wid / 20000.0)); cairo_rectangle(cr, x, (ARROW_VIEW_SIZE - lw) / 2, ARROW_VIEW_SIZE - x, lw); cairo_move_to(cr, 0, ARROW_VIEW_SIZE / 2); cairo_line_to(cr, x, ARROW_VIEW_SIZE / 2 - w); cairo_line_to(cr, x, ARROW_VIEW_SIZE / 2 + w); cairo_fill(cr); } static void LegendArrowDialogPaint(GtkWidget *w, cairo_t *cr, gpointer client_data) { struct LegendDialog *d; d = (struct LegendDialog *) client_data; if (d->arrow_pixmap == NULL) { draw_arrow_pixmap(w, d); } if (d->arrow_pixmap == NULL) { return; } cairo_set_source_surface(cr, d->arrow_pixmap, 0, 0); cairo_paint(cr); } static void LegendArrowDialogScale(GtkWidget *w, struct LegendDialog *d) { GdkWindow *win; #if ! GTK_CHECK_VERSION(3, 22, 0) cairo_t *cr; #endif draw_arrow_pixmap(w, d); #if GTK_CHECK_VERSION(3, 22, 0) win = gtk_widget_get_window(d->view); if (win) { gdk_window_invalidate_rect(win, NULL, FALSE); } #else /* GTK_CHECK_VERSION(3, 22, 0) */ win = gtk_widget_get_window(d->view); if (win == NULL) { return; } cr = gdk_cairo_create(win); LegendArrowDialogPaint(d->view, cr, d); cairo_destroy(cr); #endif /* GTK_CHECK_VERSION(3, 22, 0) */ } static void LegendArrowDialogScaleW(GtkWidget *w, gpointer client_data) { struct LegendDialog *d; d = (struct LegendDialog *) client_data; d->wid = gtk_range_get_value(GTK_RANGE(w)) * 100; LegendArrowDialogScale(w, d); } static void LegendArrowDialogScaleL(GtkWidget *w, gpointer client_data) { struct LegendDialog *d; d = (struct LegendDialog *) client_data; d->ang = gtk_range_get_value(GTK_RANGE(w)); LegendArrowDialogScale(w, d); } static gchar* format_value_percent(GtkScale *scale, gdouble value, gpointer user_data) { return g_strdup_printf ("%.0f%%", value); } static gchar* format_value_degree(GtkScale *scale, gdouble value, gpointer user_data) { return g_strdup_printf ("%.0f°", value); } static GtkWidget * create_marker_type_combo_box(const char *postfix, const char *tooltip) { GtkWidget *cbox; GtkListStore *list; GtkTreeIter iter; int j; GtkCellRenderer *rend; list = gtk_list_store_new(2, G_TYPE_STRING, G_TYPE_INT); cbox = gtk_combo_box_new_with_model(GTK_TREE_MODEL(list)); rend = gtk_cell_renderer_pixbuf_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "icon-name", 0); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "stock-size", 1); for (j = 0; j < MARKER_TYPE_NUM; j++) { char img_file[256]; snprintf(img_file, sizeof(img_file), "%s_%s-symbolic", marker_type_char[j], postfix); gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, 0, img_file, 1, GTK_ICON_SIZE_LARGE_TOOLBAR, -1); } gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), 1); gtk_widget_set_name(cbox, "MarkerType"); gtk_widget_set_tooltip_text(cbox, tooltip); return cbox; } static void create_maker_setting_widgets(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w, *hbox3, *label; hbox3 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); w = gtk_button_new(); g_signal_connect(w, "clicked", G_CALLBACK(LegendMarkDialogMark), &(d->mark_begin)); gtk_box_pack_start(GTK_BOX(hbox3), w, FALSE, FALSE, 0); d->mark_type_begin = w; w = create_marker_type_combo_box("begin", _("Marker begin")); gtk_box_pack_start(GTK_BOX(hbox3), w, FALSE, FALSE, 0); d->marker_begin = w; w = create_marker_type_combo_box("end", _("Marker end")); gtk_box_pack_start(GTK_BOX(hbox3), w, FALSE, FALSE, 0); d->marker_end = w; w = gtk_button_new(); gtk_box_pack_start(GTK_BOX(hbox3), w, FALSE, FALSE, 0); g_signal_connect(w, "clicked", G_CALLBACK(LegendMarkDialogMark), &(d->mark_end)); d->mark_type_end = w; g_signal_connect(d->marker_begin, "changed", G_CALLBACK(legend_dialog_set_sensitive), d); g_signal_connect(d->marker_end, "changed", G_CALLBACK(legend_dialog_set_sensitive), d); label = gtk_label_new_with_mnemonic(_("_Marker:")); gtk_widget_set_halign(label, GTK_ALIGN_START); gtk_label_set_mnemonic_widget(GTK_LABEL(label), d->marker_begin); gtk_grid_attach(GTK_GRID(table), label, 0, i, 1, 1); gtk_grid_attach(GTK_GRID(table), hbox3, 1, i, 1, 1); } static void create_arrow_setting_widgets(struct LegendDialog *d, GtkWidget *hbox) { GtkWidget *w, *vbox; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 10, 170, 1); set_scale_mark(w, GTK_POS_BOTTOM, 15, 15); g_signal_connect(w, "value-changed", G_CALLBACK(LegendArrowDialogScaleL), d); g_signal_connect(w, "format-value", G_CALLBACK(format_value_degree), NULL); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->arrow_length = w; w = gtk_drawing_area_new(); gtk_widget_set_size_request(w, ARROW_VIEW_SIZE, ARROW_VIEW_SIZE); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); g_signal_connect(w, "draw", G_CALLBACK(LegendArrowDialogPaint), d); d->view = w; w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 100, 2000, 1); set_scale_mark(w, GTK_POS_TOP, 200, 200); g_signal_connect(w, "value-changed", G_CALLBACK(LegendArrowDialogScaleW), d); g_signal_connect(w, "format-value", G_CALLBACK(format_value_percent), NULL); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); d->arrow_width = w; set_widget_margin(vbox, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 0); } static void LegendArrowDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *hbox2, *vbox2, *frame, *table; struct LegendDialog *d; char title[64]; int i; d = (struct LegendDialog *) data; snprintf(title, sizeof(title), _("Legend line %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { init_legend_dialog_widget_member(d); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = points_setup(d); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), w); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Type:"), FALSE, i++); g_signal_connect(w, "changed", G_CALLBACK(legend_dialog_set_sensitive), d); d->path_type = w; w = combo_box_create(); d->interpolation = w; add_widget_to_table(table, w, _("_Interpolation:"), FALSE, i++); g_signal_connect(w, "changed", G_CALLBACK(legend_dialog_set_sensitive), d); gtk_box_pack_start(GTK_BOX(vbox2), table, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = gtk_check_button_new_with_mnemonic(_("_Close path")); add_widget_to_table(table, w, NULL, FALSE, i++); d->close_path = w; create_maker_setting_widgets(d, table, i++); style_setup(d, table, i++); width_setup(d, table, i++); miter_setup(d, table, i++); join_setup(d, table, i++); stroke_color_setup(d, table, i++); gtk_box_pack_start(GTK_BOX(hbox2), table, TRUE, TRUE, 0); create_arrow_setting_widgets(d, hbox2); w = gtk_check_button_new_with_mnemonic(_("_Stroke")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->stroke = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), hbox2); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox2), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = combo_box_create(); d->fill_rule = w; add_widget_to_table(table, w, _("fill _Rule:"), FALSE, i++); fill_color_setup(d, table, i++); w = gtk_check_button_new_with_mnemonic(_("_Fill")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->fill = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox2), frame, TRUE, TRUE, 0); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), vbox2); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "path"); d->prop_cb = LegendLineCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(wi, d, d->Id); } void LegendArrowDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendArrowDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } static void LegendRectDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *vbox, *frame, *table; struct LegendDialog *d; char title[64]; int i; d = (struct LegendDialog *) data; snprintf(title, sizeof(title), _("Legend rectangle %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { init_legend_dialog_widget_member(d); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x1 = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y1 = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("_Width:"), FALSE, i++); d->x2 = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("_Height:"), FALSE, i++); d->y2 = w; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, FALSE, FALSE, 0); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); table = gtk_grid_new(); i = 0; style_setup(d, table, i++); width_setup(d, table, i++); stroke_color_setup(d, table, i++); w = gtk_check_button_new_with_mnemonic(_("_Stroke")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->stroke = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; fill_color_setup(d, table, i++); w = gtk_check_button_new_with_mnemonic(_("_Fill")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->fill = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), vbox); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "rectangle"); d->prop_cb = LegendRectCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(wi, d, d->Id); } void LegendRectDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendRectDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } static void LegendArcDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *hbox2, *vbox, *table, *frame; struct LegendDialog *d; char title[64]; int i; d = (struct LegendDialog *) data; snprintf(title, sizeof(title), _("Legend arc %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { init_legend_dialog_widget_member(d); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, "_RX:", FALSE, i++); d->rx = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, "_RY:", FALSE, i++); d->ry = w; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = create_direction_entry(); add_widget_to_table(table, w, _("_Angle1:"), FALSE, i++); d->angle1 = w; w = create_direction_entry(); add_widget_to_table(table, w, _("_Angle2:"), FALSE, i++); d->angle2 = w; w = gtk_check_button_new_with_mnemonic(_("_Pieslice")); add_widget_to_table(table, w, NULL, FALSE, i++); d->pieslice = w; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); gtk_box_pack_start(GTK_BOX(vbox), table, FALSE, FALSE, 0); hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = gtk_check_button_new_with_mnemonic(_("_Close path")); add_widget_to_table(table, w, NULL, FALSE, i++); d->close_path = w; create_maker_setting_widgets(d, table, i++); style_setup(d, table, i++); width_setup(d, table, i++); miter_setup(d, table, i++); join_setup(d, table, i++); stroke_color_setup(d, table, i++); gtk_box_pack_start(GTK_BOX(hbox2), table, TRUE, TRUE, 0); create_arrow_setting_widgets(d, hbox2); w = gtk_check_button_new_with_mnemonic(_("_Stroke")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->stroke = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), hbox2); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; fill_color_setup(d, table, i++); w = gtk_check_button_new_with_mnemonic(_("_Fill")); g_signal_connect(w, "toggled", G_CALLBACK(legend_dialog_set_sensitive), d); d->fill = w; frame = gtk_frame_new(NULL); gtk_frame_set_label_widget(GTK_FRAME(frame), w); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT | WIDGET_MARGIN_BOTTOM); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), vbox); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "arc"); d->prop_cb = LegendArcCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(wi, d, d->Id); } void LegendArcDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendArcDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } static void LegendMarkDialogMark(GtkWidget *w, gpointer client_data) { struct MarkDialog *d; d = (struct MarkDialog *) client_data; DialogExecute(d->parent, d); button_set_mark_image(w, d->Type); } static void LegendMarkDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *frame, *table; struct LegendDialog *d; char title[64]; int i; d = (struct LegendDialog *) data; snprintf(title, sizeof(title), _("Legend mark %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { init_legend_dialog_widget_member(d); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; style_setup(d, table, i++); width_setup(d, table, i++); w = gtk_button_new(); add_widget_to_table(table, w, _("_Mark:"), FALSE, i++); g_signal_connect(w, "clicked", G_CALLBACK(LegendMarkDialogMark), &(d->mark)); d->type = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Size:"), FALSE, i++); d->size = w; color_setup(d, table, i++); color2_setup(d, table, i++); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "mark"); d->prop_cb = LegendArcCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(wi, d, d->Id); if (makewidget) d->widget = NULL; } void LegendMarkDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendMarkDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } static void legend_dialog_setup_sub(struct LegendDialog *d, GtkWidget *table, int i) { GtkWidget *w, *btn_box; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Pt:"), FALSE, i++); d->pt = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_SPACE_POINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Space:"), FALSE, i++); d->space = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); spin_entry_set_range(w, TEXT_OBJ_SCRIPT_SIZE_MIN, TEXT_OBJ_SCRIPT_SIZE_MAX); add_widget_to_table(table, w, _("_Script:"), FALSE, i++); d->script_size = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Font:"), FALSE, i++); d->font = w; btn_box = gtk_button_box_new(GTK_ORIENTATION_HORIZONTAL); gtk_box_set_spacing(GTK_BOX(btn_box), 10); w = gtk_check_button_new_with_mnemonic(_("_Bold")); set_button_icon(w, "format-text-bold"); d->font_bold = w; gtk_box_pack_start(GTK_BOX(btn_box), w, FALSE, FALSE, 0); w = gtk_check_button_new_with_mnemonic(_("_Italic")); set_button_icon(w, "format-text-italic"); d->font_italic = w; gtk_box_pack_start(GTK_BOX(btn_box), w, FALSE, FALSE, 0); add_widget_to_table(table, btn_box, "", FALSE, i++); color_setup(d, table, i++); w = create_direction_entry(); add_widget_to_table(table, w, _("_Direction:"), FALSE, i++); d->direction = w; w = gtk_check_button_new_with_mnemonic(_("_Raw")); add_widget_to_table(table, w, NULL, FALSE, i++); d->raw = w; } static void insert_selcted_char(GtkIconView *icon_view, GtkTreePath *path, gpointer user_data) { GtkTreeModel *model; GtkTreeIter iter; char *ptr; GtkEditable *entry; int pos; model = gtk_icon_view_get_model(icon_view); if (! gtk_tree_model_get_iter(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, 0, &ptr, -1); entry = GTK_EDITABLE(user_data); pos = gtk_editable_get_position(entry); gtk_editable_insert_text(entry, ptr, -1, &pos); gtk_editable_set_position(entry, pos + 1); gtk_widget_grab_focus(GTK_WIDGET(user_data)); gtk_editable_select_region(entry, pos, pos); g_free(ptr); } static GtkWidget * create_character_view(GtkWidget *entry, gchar *data) { GtkWidget *icon_view, *swin; GtkListStore *model; GtkTreeIter iter; gchar *ptr; #if ! GTK_CHECK_VERSION(3, 8, 0) PangoLayout *layout; PangoRectangle ink_rect; int width = 0, w; #endif model = gtk_list_store_new(1, G_TYPE_STRING); icon_view = gtk_icon_view_new_with_model(GTK_TREE_MODEL(model)); gtk_icon_view_set_text_column(GTK_ICON_VIEW(icon_view), 0); gtk_icon_view_set_spacing(GTK_ICON_VIEW(icon_view), 0); gtk_icon_view_set_row_spacing(GTK_ICON_VIEW(icon_view), 0); gtk_icon_view_set_column_spacing(GTK_ICON_VIEW(icon_view), 0); gtk_icon_view_set_margin(GTK_ICON_VIEW(icon_view), 0); gtk_icon_view_set_item_padding(GTK_ICON_VIEW(icon_view), 0); #if ! GTK_CHECK_VERSION(3, 8, 0) gtk_icon_view_set_columns(GTK_ICON_VIEW(icon_view), 24); #endif g_signal_connect(icon_view, "item-activated", G_CALLBACK(insert_selcted_char), entry); for (ptr = data; *ptr; ptr = g_utf8_next_char(ptr)) { gunichar ch; gchar str[8]; int l; gtk_list_store_append(model, &iter); ch = g_utf8_get_char(ptr); l = g_unichar_to_utf8(ch, str); str[l] = '\0'; gtk_list_store_set(model, &iter, 0, str, -1); #if ! GTK_CHECK_VERSION(3, 8, 0) /* fix-me: there exist extra spaces both side of strings when use GTK+3.0 */ layout = gtk_widget_create_pango_layout(icon_view, str); pango_layout_get_pixel_extents(layout, &ink_rect, NULL); w = ink_rect.x + ink_rect.width; if (w > width) { width = w; } g_object_unref(layout); #endif } #if ! GTK_CHECK_VERSION(3, 8, 0) gtk_icon_view_set_item_width(GTK_ICON_VIEW(icon_view), width * 1.5); #endif swin = gtk_scrolled_window_new(NULL, NULL); #if GTK_CHECK_VERSION(3, 8, 0) gtk_icon_view_set_activate_on_single_click(GTK_ICON_VIEW(icon_view),TRUE); gtk_widget_set_size_request(GTK_WIDGET(swin), -1, 100); #endif gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), icon_view); return swin; } static GtkWidget * create_character_panel(GtkWidget *entry) { GtkWidget *tab, *label, *child; struct character_map_list *list; tab = gtk_notebook_new(); for (list = Menulocal.char_map; list; list = list->next) { char *data, *title; data = list->data; title = list->title; if (data && data[0]) { label = gtk_label_new_with_mnemonic(_(title)); child = create_character_view(entry, data); gtk_notebook_append_page(GTK_NOTEBOOK(tab), child, label); } } return tab; } static void LegendTextDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *frame, *table; struct LegendDialog *d; char title[64]; int i; d = (struct LegendDialog *) data; snprintf(title, sizeof(title), _("Legend text %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { init_legend_dialog_widget_member(d); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Text:"), TRUE, i++); d->text = w; legend_dialog_setup_sub(d, table, i++); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); w = create_character_panel(d->text); gtk_box_pack_start(GTK_BOX(d->vbox), w, TRUE, TRUE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "text"); d->prop_cb = LegendTextCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(wi, d, d->Id); entry_completion_set_entry(NgraphApp.legend_text_list, d->text); d->focus = d->text; } void LegendTextDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendTextDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } static void LegendTextDefDialogSetup(GtkWidget *w, void *data, int makewidget) { struct LegendDialog *d; GtkWidget *table, *frame; d = (struct LegendDialog *) data; if (makewidget) { init_legend_dialog_widget_member(d); table = gtk_grid_new(); legend_dialog_setup_sub(d, table, 0); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(d->vbox), frame, TRUE, TRUE, 0); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(legend_copy_clicked), d, "text"); d->prop_cb = LegendTextCB; gtk_widget_show_all(GTK_WIDGET(d->vbox)); } legend_dialog_setup_item(w, d, d->Id); } void LegendTextDefDialog(struct LegendDialog *data, struct objlist *obj, int id) { data->SetupWindow = LegendTextDefDialogSetup; data->CloseWindow = legend_dialog_close; data->Obj = obj; data->Id = id; } void CmLineDel(void *w, gpointer client_data) { legend_menu_delete_object("path", LegendLineCB); } void CmLineUpdate(void *w, gpointer client_data) { legend_menu_update_object("path", LegendLineCB, &DlgLegendArrow, LegendArrowDialog); } void CmRectDel(void *w, gpointer client_data) { legend_menu_delete_object("rectangle", LegendRectCB); } void CmRectUpdate(void *w, gpointer client_data) { legend_menu_update_object("rectangle", LegendRectCB, &DlgLegendRect, LegendRectDialog); } void CmArcDel(void *w, gpointer client_data) { legend_menu_delete_object("arc", LegendArcCB); } void CmArcUpdate(void *w, gpointer client_data) { legend_menu_update_object("arc", LegendArcCB, &DlgLegendArc, LegendArcDialog); } void CmMarkDel(void *w, gpointer client_data) { legend_menu_delete_object("mark", LegendMarkCB); } void CmMarkUpdate(void *w, gpointer client_data) { legend_menu_update_object("mark", LegendMarkCB, &DlgLegendMark, LegendMarkDialog); } void CmTextDel(void *w, gpointer client_data) { legend_menu_delete_object("text", LegendTextCB); } void CmTextUpdate(void *w, gpointer client_data) { legend_menu_update_object("text", LegendTextCB, &DlgLegendText, LegendTextDialog); } void CmOptionTextDef(void *w, gpointer client_data) { struct objlist *obj; int id; char *objs[2]; if (Menulock || Globallock) return; if ((obj = chkobject("text")) == NULL) return; id = newobj(obj); if (id >= 0) { int modified; modified = get_graph_modified(); LegendTextDefDialog(&DlgLegendTextDef, obj, id); if (DialogExecute(TopLevel, &DlgLegendTextDef) == IDOK) { if (CheckIniFile()) { exeobj(obj, "save_config", id, 0, NULL); } } delobj(obj, id); objs[0] = obj->name; objs[1] = NULL; UpdateAll2(objs, TRUE); if (! modified) { reset_graph_modified(); } } } static void LegendWinPathUpdate(struct obj_list_data *data, int id, int user_data) { LegendArrowDialog(&DlgLegendArrow, data->obj, id); } static void LegendWinRectUpdate(struct obj_list_data *data, int id, int user_data) { LegendRectDialog(&DlgLegendRect, data->obj, id); } static void LegendWinArcUpdate(struct obj_list_data *data, int id, int user_data) { LegendArcDialog(&DlgLegendArc, data->obj, id); } static void LegendWinMarkUpdate(struct obj_list_data *data, int id, int user_data) { LegendMarkDialog(&DlgLegendMark, data->obj, id); } static void LegendWinTextUpdate(struct obj_list_data *data, int id, int user_data) { LegendTextDialog(&DlgLegendText, data->obj, id); } static void ObjListUpdate(struct obj_list_data *d, int clear, int draw, list_sub_window_set_val_func func) { if (Menulock || Globallock) return; if (d->text == NULL) { return; } if (list_sub_window_must_rebuild(d)) { list_sub_window_build(d, func); } else { list_sub_window_set(d, func); } if (! clear && d->select >= 0) { list_store_select_int(GTK_WIDGET(d->text), COL_ID, d->select); } if (draw) { NgraphApp.Viewer.allclear = TRUE; update_viewer(d); } } static void PathListUpdate(struct obj_list_data *d, int clear, int draw) { ObjListUpdate(d, clear, draw, path_list_set_val); } static void ArcListUpdate(struct obj_list_data *d, int clear, int draw) { ObjListUpdate(d, clear, draw, arc_list_set_val); } static void RectListUpdate(struct obj_list_data *d ,int clear, int draw) { ObjListUpdate(d, clear, draw, rect_list_set_val); } static void MarkListUpdate(struct obj_list_data *d, int clear, int draw) { ObjListUpdate(d, clear, draw, mark_list_set_val); } static void TextListUpdate(struct obj_list_data *d, int clear, int draw) { ObjListUpdate(d, clear, draw, text_list_set_val); } void LegendWinUpdate(char **objects, int clear, int draw) { struct obj_list_data *d; struct objlist *obj; char **ptr; struct SubWin win[] = { NgraphApp.PathWin, NgraphApp.RectWin, NgraphApp.ArcWin, NgraphApp.MarkWin, NgraphApp.TextWin, }; int i, n; if (Menulock || Globallock) return; n = G_N_ELEMENTS(win); for (i = 0; i < n; i++) { d = win[i].data.data; if (objects) { for (ptr = objects; *ptr; ptr++) { obj = getobject(*ptr); if (obj == d->obj) { d->update(d, clear, draw); break; } } } else { d->update(d, clear, draw); } } } static void get_points(struct objlist *obj, int id, int *x, int *y, int *n) { int *points, i; struct narray *array; getobj(obj, "points", id, 0, NULL, &array); points = arraydata(array); i = arraynum(array); *n = i / 2; if (i < 2) { *x = 0; *y = 0; } else { *x = points[0]; *y = points[1]; } } static GdkPixbuf * draw_color_pixbuf(struct objlist *obj, int id, enum OBJ_FIELD_COLOR_TYPE type, int width) { int ggc, fr, fg, fb, stroke, fill, close_path, pos[8], height = 20, lockstate, found, output, n; cairo_surface_t *pix; GdkPixbuf *pixbuf; struct objlist *gobj, *robj; N_VALUE *inst; struct gra2cairo_local *local; struct narray *line_style; lockstate = Globallock; Globallock = TRUE; found = find_gra2gdk_inst(&gobj, &inst, &robj, &output, &local); if (! found) { return NULL; } pix = gra2gdk_create_pixmap(local, width, height, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); if (pix == NULL) { return NULL; } ggc = _GRAopen("gra2gdk", "_output", robj, inst, output, -1, -1, -1, NULL, local); if (ggc < 0) { _GRAclose(ggc); g_object_unref(G_OBJECT(pix)); return NULL; } GRAview(ggc, 0, 0, width, height, 0); if (chkobjfieldtype(obj, "style") == NINT) { line_style = NULL; } else { getobj(obj, "style", id, 0, NULL, &line_style); } n = arraynum(line_style); if (n > 0) { int i, *style, *ptr; style = g_malloc(sizeof(*style) * n); if (style == NULL) { _GRAclose(ggc); g_object_unref(G_OBJECT(pix)); return NULL; } ptr = arraydata(line_style); for (i = 0; i < n; i++) { style[i] = ptr[i] / 30; } GRAlinestyle(ggc, n, style, 4, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); g_free(style); } else { GRAlinestyle(ggc, 0, NULL, 4, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); } if (type == OBJ_FIELD_COLOR_TYPE_STROKE) { getobj(obj, "fill", id, 0, NULL, &fill); if (fill) { getobj(obj, "fill_R", id, 0, NULL, &fr); getobj(obj, "fill_G", id, 0, NULL, &fg); getobj(obj, "fill_B", id, 0, NULL, &fb); GRAcolor(ggc, fr, fg, fb, 255); GRArectangle(ggc, 2, 2, width - 2, height - 2, 1); } getobj(obj, "stroke", id, 0, NULL, &stroke); if (stroke) { if (chkobjfield(obj, "close_path") == 0) { getobj(obj, "close_path", id, 0, NULL, &close_path); } else { close_path = TRUE; } getobj(obj, "stroke_R", id, 0, NULL, &fr); getobj(obj, "stroke_G", id, 0, NULL, &fg); getobj(obj, "stroke_B", id, 0, NULL, &fb); GRAcolor(ggc, fr, fg, fb, 255); pos[0] = 2; pos[1] = height - 2; pos[2] = 2; pos[3] = 2; pos[4] = width - 2; pos[5] = 2; pos[6] = width - 2; pos[7] = height - 2; if (close_path) { GRAdrawpoly(ggc, 4, pos, GRA_FILL_MODE_NONE); } else { GRAlines(ggc, 4, pos); } } } else { getobj(obj, "R", id, 0, NULL, &fr); getobj(obj, "G", id, 0, NULL, &fg); getobj(obj, "B", id, 0, NULL, &fb); GRAcolor(ggc, fr, fg, fb, 255); GRArectangle(ggc, 0, 0, width, height, 1); } _GRAclose(ggc); gra2cairo_draw_path(local); pixbuf = gdk_pixbuf_get_from_surface(pix, 0, 0, width, height); cairo_surface_destroy(pix); Globallock = lockstate; return pixbuf; } static void path_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx, n, x0, y0, w, i, interpolation, type; char *valstr; GdkPixbuf *pixbuf; for (i = 0; i < d->list_col_num; i++) { switch (i) { case PATH_LIST_COL_HIDDEN: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_boolean(d->text, iter, i, cx); break; case PATH_LIST_COL_TYPE: getobj(d->obj, "type", row, 0, NULL, &type); getobj(d->obj, "interpolation", row, 0, NULL, &interpolation); if (type == 0) { char **enumlist; enumlist = (char **) chkobjarglist(d->obj, "type"); list_store_set_string(GTK_WIDGET(d->text), iter, i, _(enumlist[0])); } else { char **enumlist; enumlist = (char **) chkobjarglist(d->obj, "interpolation"); list_store_set_string(GTK_WIDGET(d->text), iter, i, _(enumlist[interpolation])); } break; case PATH_LIST_COL_MARKER_BEGIN: case PATH_LIST_COL_MARKER_END: sgetobjfield(d->obj, row, d->list[i].name, NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { list_store_set_string(GTK_WIDGET(d->text), iter, i, _(valstr)); g_free(valstr); } break; case PATH_LIST_COL_COLOR: pixbuf = draw_color_pixbuf(d->obj, row, OBJ_FIELD_COLOR_TYPE_STROKE, 40); if (pixbuf) { list_store_set_pixbuf(GTK_WIDGET(d->text), iter, i, pixbuf); g_object_unref(pixbuf); } break; case PATH_LIST_COL_X: get_points(d->obj, row, &x0, &y0, &n); list_store_set_double(d->text, iter, PATH_LIST_COL_X, x0 / 100.0); list_store_set_double(d->text, iter, PATH_LIST_COL_Y, y0 / 100.0); list_store_set_int(d->text, iter, PATH_LIST_COL_POINTS, n); break; case PATH_LIST_COL_Y: case PATH_LIST_COL_POINTS: break; case PATH_LIST_COL_WIDTH: getobj(d->obj, d->list[i].name, row, 0, NULL, &w); list_store_set_double(d->text, iter, i, w / 100.0); break; default: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_val(d->text, iter, i, d->list[i].type, &cx); } } } static void rect_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int x1, x2, y1, y2, v, i; GdkPixbuf *pixbuf; for (i = 0; i < d->list_col_num; i++) { switch (i) { case RECT_LIST_COL_HIDDEN: getobj(d->obj, d->list[i].name, row, 0, NULL, &v); v = ! v; list_store_set_boolean(d->text, iter, i, v); break; case RECT_LIST_COL_COLOR: pixbuf = draw_color_pixbuf(d->obj, row, OBJ_FIELD_COLOR_TYPE_STROKE, 40); if (pixbuf) { list_store_set_pixbuf(GTK_WIDGET(d->text), iter, i, pixbuf); g_object_unref(pixbuf); } break; case RECT_LIST_COL_X: getobj(d->obj, "x1", row, 0, NULL, &x1); getobj(d->obj, "x2", row, 0, NULL, &x2); v = (x1 < x2) ? x1 : x2; list_store_set_double(d->text, iter, i, v / 100.0); break; case RECT_LIST_COL_Y: getobj(d->obj, "y1", row, 0, NULL, &y1); getobj(d->obj, "y2", row, 0, NULL, &y2); v = (y1 < y2) ? y1 : y2; list_store_set_double(d->text, iter, i, v / 100.0); break; case RECT_LIST_COL_WIDTH: v = abs(x1 - x2); list_store_set_double(d->text, iter, i, v / 100.0); break; case RECT_LIST_COL_HEIGHT: v = abs(y1 - y2); list_store_set_double(d->text, iter, i, v / 100.0); break; case RECT_LIST_COL_LWIDTH: getobj(d->obj, d->list[i].name, row, 0, NULL, &v); list_store_set_double(d->text, iter, i, v / 100.0); break; default: getobj(d->obj, d->list[i].name, row, 0, NULL, &v); list_store_set_val(d->text, iter, i, d->list[i].type, &v); } } } static void arc_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx, w, i; GdkPixbuf *pixbuf; for (i = 0; i < d->list_col_num; i++) { switch (i) { case ARC_LIST_COL_HIDDEN: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_boolean(d->text, iter, i, cx); break; case ARC_LIST_COL_PIESLICE: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_boolean(d->text, iter, i, cx); break; case ARC_LIST_COL_COLOR: pixbuf = draw_color_pixbuf(d->obj, row, OBJ_FIELD_COLOR_TYPE_STROKE, 40); if (pixbuf) { list_store_set_pixbuf(GTK_WIDGET(d->text), iter, i, pixbuf); g_object_unref(pixbuf); } break; case ARC_LIST_COL_Y: case ARC_LIST_COL_X: case ARC_LIST_COL_RY: case ARC_LIST_COL_RX: case ARC_LIST_COL_ANGLE1: case ARC_LIST_COL_ANGLE2: case ARC_LIST_COL_WIDTH: getobj(d->obj, d->list[i].name, row, 0, NULL, &w); list_store_set_double(d->text, iter, i, w / 100.0); break; default: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_val(d->text, iter, i, d->list[i].type, &cx); } } } static GdkPixbuf * draw_mark_pixbuf(struct objlist *obj, int i) { int ggc, fr, fg, fb, fr2, fg2, fb2, width = 20, height = 20, marktype, lockstate, found, output; cairo_surface_t *pix; GdkPixbuf *pixbuf; struct objlist *gobj, *robj; N_VALUE *inst; struct gra2cairo_local *local; lockstate = Globallock; Globallock = TRUE; found = find_gra2gdk_inst(&gobj, &inst, &robj, &output, &local); if (! found) { return NULL; } pix = gra2gdk_create_pixmap(local, width, height, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); if (pix == NULL) { return NULL; } getobj(obj, "R", i, 0, NULL, &fr); getobj(obj, "G", i, 0, NULL, &fg); getobj(obj, "B", i, 0, NULL, &fb); getobj(obj, "R2", i, 0, NULL, &fr2); getobj(obj, "G2", i, 0, NULL, &fg2); getobj(obj, "B2", i, 0, NULL, &fb2); ggc = _GRAopen("gra2gdk", "_output", robj, inst, output, -1, -1, -1, NULL, local); if (ggc < 0) { _GRAclose(ggc); g_object_unref(G_OBJECT(pix)); return NULL; } GRAview(ggc, 0, 0, width, height, 0); GRAcolor(ggc, fr, fg, fb, 255); GRAlinestyle(ggc, 0, NULL, 1, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); getobj(obj, "type", i, 0, NULL, &marktype); GRAmark(ggc, marktype, height / 2, height / 2, height - 2, fr, fg, fb, 255, fr2, fg2, fb2, 255); _GRAclose(ggc); gra2cairo_draw_path(local); pixbuf = gdk_pixbuf_get_from_surface(pix, 0, 0, width, height); cairo_surface_destroy(pix); Globallock = lockstate; return pixbuf; } static void mark_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx, w, i; GdkPixbuf *pixbuf = NULL; for (i = 0; i < d->list_col_num; i++) { switch (i) { case MARK_LIST_COL_HIDDEN: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_boolean(d->text, iter, i, cx); break; case MARK_LIST_COL_MARK: pixbuf = draw_mark_pixbuf(d->obj, row); if (pixbuf) { list_store_set_pixbuf(GTK_WIDGET(d->text), iter, i, pixbuf); g_object_unref(pixbuf); } break; case MARK_LIST_COL_X: case MARK_LIST_COL_Y: case MARK_LIST_COL_WIDTH: case MARK_LIST_COL_SIZE: getobj(d->obj, d->list[i].name, row, 0, NULL, &w); list_store_set_double(d->text, iter, i, w / 100.0); break; default: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_val(d->text, iter, i, d->list[i].type, &cx); } } } static void text_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx, w, i, style, r, g ,b; char *str, buf[64]; #ifdef TEXT_LIST_USE_FONT_FAMILY struct fontmap *fmap; #endif for (i = 0; i < d->list_col_num; i++) { switch (i) { case TEXT_LIST_COL_HIDDEN: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_boolean(d->text, iter, i, cx); break; case TEXT_LIST_COL_RAW: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_boolean(d->text, iter, i, cx); break; case TEXT_LIST_COL_TEXT: getobj(d->obj, d->list[i].name, row, 0, NULL, &str); list_store_set_string(d->text, iter, i, str); break; case TEXT_LIST_COL_FONT: getobj(d->obj, d->list[i].name, row, 0, NULL, &str); list_store_set_string(d->text, iter, i, str); #ifdef TEXT_LIST_USE_FONT_FAMILY if (str == NULL) { break; } fmap = gra2cairo_get_fontmap(str); if (fmap == NULL || fmap->fontname == NULL) { break; } list_store_set_string(d->text, iter, TEXT_LIST_COL_FONT_FAMILY, fmap->fontname); #endif break; case TEXT_LIST_COL_STYLE: getobj(d->obj, "style", row, 0, NULL, &style); list_store_set_int(d->text, iter, i, (style & GRA_FONT_STYLE_ITALIC) ? PANGO_STYLE_ITALIC : 0); list_store_set_int(d->text, iter, TEXT_LIST_COL_WEIGHT, (style & GRA_FONT_STYLE_BOLD) ? PANGO_WEIGHT_BOLD : PANGO_WEIGHT_NORMAL); break; case TEXT_LIST_COL_COLOR: getobj(d->obj, "R", row, 0, NULL, &r); getobj(d->obj, "G", row, 0, NULL, &g); getobj(d->obj, "B", row, 0, NULL, &b); snprintf(buf, sizeof(buf), "#%02x%02x%02x", r & 0xff, g & 0xff, b & 0xff); list_store_set_string(d->text, iter, i, buf); break; case TEXT_LIST_COL_BGCOLOR: snprintf(buf, sizeof(buf), "#%02x%02x%02x", ((int) (Menulocal.bg_r * 255)) & 0xff, ((int) (Menulocal.bg_g * 255)) & 0xff, ((int) (Menulocal.bg_b * 255)) & 0xff); list_store_set_string(d->text, iter, i, buf); break; case TEXT_LIST_COL_X: case TEXT_LIST_COL_Y: case TEXT_LIST_COL_DIR: case TEXT_LIST_COL_PT: getobj(d->obj, d->list[i].name, row, 0, NULL, &w); list_store_set_double(d->text, iter, i, w / 100.0); break; case TEXT_LIST_COL_WEIGHT: #ifdef TEXT_LIST_USE_FONT_FAMILY case TEXT_LIST_COL_FONT_FAMILY: #endif break; default: getobj(d->obj, d->list[i].name, row, 0, NULL, &cx); list_store_set_val(d->text, iter, i, d->list[i].type, &cx); } } } static void popup_show_cb(GtkWidget *widget, gpointer user_data) { unsigned int i; int m, last_id; struct obj_list_data *d; d = (struct obj_list_data *) user_data; if (d->text == NULL) { return; } m = list_store_get_selected_int(d->text, COL_ID); for (i = 0; i < POPUP_ITEM_NUM; i++) { switch (i) { case POPUP_ITEM_TOP: case POPUP_ITEM_UP: gtk_widget_set_sensitive(d->popup_item[i], m > 0); break; case POPUP_ITEM_DOWN: case POPUP_ITEM_BOTTOM: last_id = -1; if (m >= 0) { last_id = chkobjlastinst(d->obj); } gtk_widget_set_sensitive(d->popup_item[i], m >= 0 && m < last_id); break; default: gtk_widget_set_sensitive(d->popup_item[i], m >= 0); } } } enum CHANGE_DIR { CHANGE_DIR_X, CHANGE_DIR_Y, }; static void pos_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data, enum CHANGE_DIR dir) { struct obj_list_data *d; int col, inc, ecode, m; double prev, val; GtkTreeModel *model; GtkTreeIter iter; int x, y, i; char *argv[3], *tmp, *ptr; menu_lock(FALSE); if (str == NULL || path == NULL) return; ecode = str_calc(str, &val, NULL, NULL); if (ecode || val != val || val == HUGE_VAL || val == - HUGE_VAL) { return; } d = (struct obj_list_data *) user_data; if (d->text == NULL) { return; } col = -1; for (i = 0; i < d->list_col_num; i++) { if (dir == CHANGE_DIR_X && strcmp(d->list[i].title, "x") == 0) { col = i; break; } else if (dir == CHANGE_DIR_Y && strcmp(d->list[i].title, "y") == 0) { col = i; break; } } if (col < 0) { return; } model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->text)); if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, col, &tmp, COL_ID, &m, -1); if (tmp == NULL) { return; } prev = strtod(tmp, &ptr); if (prev != prev || prev == HUGE_VAL || prev == - HUGE_VAL || ptr[0] != '\0') { g_free(tmp); return; } g_free(tmp); inc = nround((val - prev) * 100); switch (dir) { case CHANGE_DIR_X: x = inc; y = 0; break; case CHANGE_DIR_Y: x = 0; y = inc; break; } argv[0] = (char *) &x; argv[1] = (char *) &y; argv[2] = NULL; if (inc != 0 ) { menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); exeobj(d->obj, "move", m, 2, argv); set_graph_modified(); d->update(d, TRUE, TRUE); } return; } static void rect_size_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data, char *pos1, char *pos2) { struct obj_list_data *d; GtkTreeIter iter; int id, ecode; double val; int x1, x2, v, num; menu_lock(FALSE); if (str == NULL || path == NULL) return; ecode = str_calc(str, &val, NULL, NULL); if (ecode || val != val || val == HUGE_VAL || val == - HUGE_VAL) { return; } d = (struct obj_list_data *) user_data; id = tree_view_get_selected_row_int_from_path(d->text, path, &iter, COL_ID); num = chkobjlastinst(d->obj); if (id < 0 || id > num) { return; } getobj(d->obj, pos1, id, 0, NULL, &x1); getobj(d->obj, pos2, id, 0, NULL, &x2); if (x1 > x2) { v = x1; x1 = x2; x2 = v; } v = nround(val * 100); if (v != x2 - x1) { menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); x2 = x1 + v; putobj(d->obj, pos1, id, &x1); putobj(d->obj, pos2, id, &x2); set_graph_modified(); d->update(d, TRUE, TRUE); } return; } static void rect_width_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { rect_size_edited(cell_renderer, path, str, user_data, "x1", "x2"); } static void rect_height_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { rect_size_edited(cell_renderer, path, str, user_data, "y1", "y2"); } static void pos_x_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { pos_edited(cell_renderer, path, str, user_data, CHANGE_DIR_X); } static void pos_y_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { pos_edited(cell_renderer, path, str, user_data, CHANGE_DIR_Y); } enum LEGEND_COMBO_ITEM { LEGEND_COMBO_ITEM_COLOR_0, LEGEND_COMBO_ITEM_COLOR_1, LEGEND_COMBO_ITEM_COLOR_2, LEGEND_COMBO_ITEM_COLOR_STROKE, LEGEND_COMBO_ITEM_COLOR_FILL, LEGEND_COMBO_ITEM_MARK, LEGEND_COMBO_ITEM_TOGGLE_STROKE, LEGEND_COMBO_ITEM_TOGGLE_FILL, LEGEND_COMBO_ITEM_CLOSE_PATH, LEGEND_COMBO_ITEM_STYLE, LEGEND_COMBO_ITEM_FONT, LEGEND_COMBO_ITEM_STYLE_BOLD, LEGEND_COMBO_ITEM_STYLE_ITALIC, LEGEND_COMBO_ITEM_FILL_RULE, LEGEND_COMBO_ITEM_JOIN, LEGEND_COMBO_ITEM_NONE, }; static void create_mark_color_combo_box(GtkWidget *cbox, struct objlist *obj, int id) { int count; GtkTreeStore *list; GtkTreeIter iter; count = combo_box_get_num(cbox); if (count > 0) return; list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); add_text_combo_item_to_cbox(list, &iter, NULL, -1, -1, _("Mark"), TOGGLE_NONE, FALSE); add_mark_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_MARK, obj, "type", id); add_line_style_item_to_cbox(list, NULL, LEGEND_COMBO_ITEM_STYLE, obj, "style", id); add_text_combo_item_to_cbox(list, NULL, NULL, LEGEND_COMBO_ITEM_COLOR_1, -1, _("Color 1"), TOGGLE_NONE, FALSE); add_text_combo_item_to_cbox(list, NULL, NULL, LEGEND_COMBO_ITEM_COLOR_2, -1, _("Color 2"), TOGGLE_NONE, FALSE); } static void create_color_combo_box(GtkWidget *cbox, struct objlist *obj, int id) { int count; GtkTreeStore *list; GtkTreeIter iter, parent; count = combo_box_get_num(cbox); if (count > 0) return; list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); add_text_combo_item_to_cbox(list, &iter, NULL, -1, -1, _("Stroke"), TOGGLE_NONE, FALSE); add_bool_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_TOGGLE_STROKE, obj, "stroke", id, _("Stroke")); add_line_style_item_to_cbox(list, &iter, LEGEND_COMBO_ITEM_STYLE, obj, "style", id); if (chkobjfield(obj, "join") == 0) { add_text_combo_item_to_cbox(list, &parent, &iter, -1, -1, _("Join"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &parent, LEGEND_COMBO_ITEM_JOIN, obj, "join", id); } add_text_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_COLOR_STROKE, -1, _("Color"), TOGGLE_NONE, FALSE); if (chkobjfield(obj, "close_path") == 0) { add_bool_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_CLOSE_PATH, obj, "close_path", id, _("Close path")); } add_text_combo_item_to_cbox(list, &iter, NULL, -1, -1, _("Fill"), TOGGLE_NONE, FALSE); add_bool_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_TOGGLE_FILL, obj, "fill", id, _("Fill")); if (chkobjfield(obj, "fill_rule") == 0) { add_text_combo_item_to_cbox(list, &parent, &iter, -1, -1, _("Fill rule"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &parent, LEGEND_COMBO_ITEM_FILL_RULE, obj, "fill_rule", id); } add_text_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_COLOR_FILL, -1, _("Color"), TOGGLE_NONE, FALSE); } static int set_bool_field(struct objlist *obj, char *field, int id, int state) { int active; if (chkobjfield(obj, field)) { return 0; } getobj(obj, field, id, 0, NULL, &active); if (active == state) { return 0; } menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); putobj(obj, field, id, &state); return 1; } static int set_stroke(struct objlist *obj, int id, int stroke) { return set_bool_field(obj, "stroke", id, stroke); } static int set_fill(struct objlist *obj, int id, int fill) { return set_bool_field(obj, "fill", id, fill); } static void select_type(GtkComboBox *w, gpointer user_data) { int sel, col_type, mark_type, enum_id, found, active, style, modified, fill_rule, join, r; struct obj_list_data *d; GtkTreeStore *list; GtkTreeIter iter; menu_lock(FALSE); d = (struct obj_list_data *) user_data; gtk_widget_grab_focus(d->text); sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) { return; } list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(w))); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) { return; } gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &col_type, OBJECT_COLUMN_TYPE_ENUM, &enum_id, -1); switch (col_type) { case LEGEND_COMBO_ITEM_COLOR_1: if (select_obj_color(d->obj, sel, OBJ_FIELD_COLOR_TYPE_1)) { return; } break; case LEGEND_COMBO_ITEM_COLOR_2: if (select_obj_color(d->obj, sel, OBJ_FIELD_COLOR_TYPE_2)) { return; } break; case LEGEND_COMBO_ITEM_MARK: getobj(d->obj, "type", sel, 0, NULL, &mark_type); if (enum_id == mark_type) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "type", sel, &enum_id); break; case LEGEND_COMBO_ITEM_STYLE: modified = set_stroke(d->obj, sel, TRUE); if (enum_id < 0 || enum_id >= FwNumStyleNum) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); if (chk_sputobjfield(d->obj, sel, "style", FwLineStyle[enum_id].list) != 0 && ! modified) { return; } if (! modified && ! get_graph_modified()) { return; } break; case LEGEND_COMBO_ITEM_COLOR_STROKE: r = select_obj_color(d->obj, sel, OBJ_FIELD_COLOR_TYPE_STROKE); switch (r) { case SELECT_OBJ_COLOR_DIFFERENT: set_stroke(d->obj, sel, TRUE); break; case SELECT_OBJ_COLOR_SAME: if (! set_stroke(d->obj, sel, TRUE)) { return; } break; case SELECT_OBJ_COLOR_ERROR: case SELECT_OBJ_COLOR_CANCEL: return; } break; case LEGEND_COMBO_ITEM_COLOR_FILL: r = select_obj_color(d->obj, sel, OBJ_FIELD_COLOR_TYPE_FILL); switch (r) { case SELECT_OBJ_COLOR_DIFFERENT: set_fill(d->obj, sel, TRUE); break; case SELECT_OBJ_COLOR_SAME: if (! set_fill(d->obj, sel, TRUE)) { return; } break; case SELECT_OBJ_COLOR_ERROR: case SELECT_OBJ_COLOR_CANCEL: return; } break; case LEGEND_COMBO_ITEM_TOGGLE_STROKE: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); set_stroke(d->obj, sel, ! active); break; case LEGEND_COMBO_ITEM_TOGGLE_FILL: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); set_fill(d->obj, sel, ! active); break; case LEGEND_COMBO_ITEM_FILL_RULE: modified = set_fill(d->obj, sel, TRUE); getobj(d->obj, "fill_rule", sel, 0, NULL, &fill_rule); if (fill_rule == enum_id && ! modified) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); fill_rule = enum_id; putobj(d->obj, "fill_rule", sel, &fill_rule); break; case LEGEND_COMBO_ITEM_JOIN: getobj(d->obj, "join", sel, 0, NULL, &join); if (join == enum_id) { return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "join", sel, &enum_id); break; case LEGEND_COMBO_ITEM_CLOSE_PATH: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); active = ! active; putobj(d->obj, "close_path", sel, &active); set_stroke(d->obj, sel, TRUE); break; case LEGEND_COMBO_ITEM_STYLE_BOLD: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "style", sel, 0, NULL, &style); style = (style & GRA_FONT_STYLE_ITALIC) | (active ? 0 : GRA_FONT_STYLE_BOLD); menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "style", sel, &style); break; case LEGEND_COMBO_ITEM_STYLE_ITALIC: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "style", sel, 0, NULL, &style); style = (style & GRA_FONT_STYLE_BOLD) | (active ? 0 : GRA_FONT_STYLE_ITALIC); menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "style", sel, &style); break; default: return; } d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } static int start_editing_common(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { GtkTreeIter iter; struct obj_list_data *d; int sel; menu_lock(TRUE); d = (struct obj_list_data *) user_data; sel = tree_view_get_selected_row_int_from_path(d->text, path_str, &iter, MARK_LIST_COL_ID); if (sel < 0) { menu_lock(FALSE); return -1; } g_object_set_data(G_OBJECT(editable), "user-data", GINT_TO_POINTER(sel)); return sel; } static void start_editing_mark(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { struct obj_list_data *d; int sel; d = (struct obj_list_data *) user_data; sel = start_editing_common(renderer, editable, path_str, user_data); if (sel < 0) { return; } create_mark_color_combo_box(GTK_WIDGET(editable), d->obj, sel); gtk_widget_show(GTK_WIDGET(editable)); g_signal_connect(editable, "editing-done", G_CALLBACK(select_type), user_data); return; } static void start_editing_color(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { struct obj_list_data *d; int sel; d = (struct obj_list_data *) user_data; sel = start_editing_common(renderer, editable, path_str, user_data); if (sel < 0) { return; } create_color_combo_box(GTK_WIDGET(editable), d->obj, sel); gtk_widget_show(GTK_WIDGET(editable)); g_signal_connect(editable, "editing-done", G_CALLBACK(select_type), user_data); return; } enum LEGEND_PATH_LINE_TYPE { LEGEND_PATH_LINE_TYPE_LINE, LEGEND_PATH_LINE_TYPE_CURVE, }; static void select_line_type(GtkComboBox *w, gpointer user_data) { struct obj_list_data *d; int sel, type, interpolation, enum_id, col_type, found; GtkTreeIter iter; GtkTreeStore *list; d = (struct obj_list_data *) user_data; sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) { return; } list = GTK_TREE_STORE(gtk_combo_box_get_model(w)); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) { return; } gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &col_type, OBJECT_COLUMN_TYPE_ENUM, &enum_id, -1); getobj(d->obj, "type", sel, 0, NULL, &type); getobj(d->obj, "interpolation", sel, 0, NULL, &interpolation); switch (col_type) { case LEGEND_PATH_LINE_TYPE_LINE: if (type == PATH_TYPE_LINE) { return; } break; case LEGEND_PATH_LINE_TYPE_CURVE: if (type == PATH_TYPE_CURVE && enum_id == interpolation) { return; } break; default: return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "type", sel, &col_type); if (enum_id >= 0) { putobj(d->obj, "interpolation", sel, &enum_id); } d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } static void start_editing_line_type(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { struct obj_list_data *d; int sel, type; char **enumlist; GtkTreeStore *list; GtkTreeIter iter; d = (struct obj_list_data *) user_data; sel = start_editing_common(renderer, editable, path_str, user_data); if (sel < 0) { return; } g_object_set_data(G_OBJECT(editable), "user-data", GINT_TO_POINTER(sel)); init_object_combo_box(GTK_WIDGET(editable)); list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(editable))); gtk_tree_store_clear(list); getobj(d->obj, "type", sel, 0, NULL, &type); enumlist = (char **) chkobjarglist(d->obj, "type"); add_text_combo_item_to_cbox(list, &iter, NULL, LEGEND_PATH_LINE_TYPE_LINE, -1, _(enumlist[0]), TOGGLE_RADIO, type == PATH_TYPE_LINE); if (type == PATH_TYPE_LINE) { gtk_combo_box_set_active_iter(GTK_COMBO_BOX(editable), &iter); } add_text_combo_item_to_cbox(list, &iter, NULL, LEGEND_PATH_LINE_TYPE_CURVE, -1, _(enumlist[1]), TOGGLE_RADIO, type == PATH_TYPE_CURVE); if (type == PATH_TYPE_CURVE) { gtk_combo_box_set_active_iter(GTK_COMBO_BOX(editable), &iter); } add_enum_combo_item_to_cbox(list, NULL, &iter, LEGEND_PATH_LINE_TYPE_CURVE, d->obj, "interpolation", sel); gtk_widget_show(GTK_WIDGET(editable)); g_signal_connect(editable, "editing-done", G_CALLBACK(select_line_type), user_data); return; } static void select_font(GtkComboBox *w, gpointer user_data) { int sel, col_type, found, active, style; struct obj_list_data *d; GtkTreeStore *list; GtkTreeIter iter; char *font, *ptr; menu_lock(FALSE); d = (struct obj_list_data *) user_data; sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) { return; } list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(w))); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) { return; } gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &col_type, -1); switch (col_type) { case LEGEND_COMBO_ITEM_FONT: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_STRING, &font, -1); getobj(d->obj, "font", sel, 0, NULL, &ptr); if (g_strcmp0(font, ptr) == 0) { g_free(font); return; } menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); putobj(d->obj, "font", sel, font); break; case LEGEND_COMBO_ITEM_COLOR_0: if (select_obj_color(d->obj, sel, OBJ_FIELD_COLOR_TYPE_0)) { return; } break; case LEGEND_COMBO_ITEM_STYLE_BOLD: menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "style", sel, 0, NULL, &style); style = (style & GRA_FONT_STYLE_ITALIC) | (active ? 0 : GRA_FONT_STYLE_BOLD); putobj(d->obj, "style", sel, &style); break; case LEGEND_COMBO_ITEM_STYLE_ITALIC: menu_save_undo_single(UNDO_TYPE_EDIT, d->obj->name); gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "style", sel, 0, NULL, &style); style = (style & GRA_FONT_STYLE_BOLD) | (active ? 0 : GRA_FONT_STYLE_ITALIC); putobj(d->obj, "style", sel, &style); break; default: return; } d->select = sel; d->update(d, FALSE, TRUE); set_graph_modified(); } static void start_editing_font(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data) { GtkTreeIter iter; GtkTreeStore *list; struct obj_list_data *d; int sel; menu_lock(TRUE); d = (struct obj_list_data *) user_data; sel = start_editing_common(renderer, editable, path, user_data); if (sel < 0) { return; } g_object_set_data(G_OBJECT(editable), "user-data", GINT_TO_POINTER(sel)); init_object_combo_box(GTK_WIDGET(editable)); list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(editable))); gtk_tree_store_clear(list); add_text_combo_item_to_cbox(list, &iter, NULL, -1, -1, _("Font"), TOGGLE_NONE, FALSE); add_font_combo_item_to_cbox(list, NULL, &iter, LEGEND_COMBO_ITEM_FONT, d->obj, "font", sel); add_text_combo_item_to_cbox(list, NULL, NULL, LEGEND_COMBO_ITEM_COLOR_0, -1, _("Color"), TOGGLE_NONE, FALSE); add_font_style_combo_item_to_cbox(list, NULL, NULL, LEGEND_COMBO_ITEM_STYLE_BOLD, LEGEND_COMBO_ITEM_STYLE_ITALIC, d->obj, "style", sel); g_signal_connect(editable, "editing-done", G_CALLBACK(select_font), user_data); } static void select_text(GtkWidget *w, gpointer user_data) { gboolean canceled; g_object_get(w, "editing-canceled", &canceled, NULL); if (! canceled) { entry_completion_append(NgraphApp.legend_text_list, gtk_entry_get_text(GTK_ENTRY(w))); } gtk_entry_set_completion(GTK_ENTRY(w), NULL); } static void start_editing_text(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path_str, gpointer user_data) { if (GTK_IS_ENTRY(editable)) { entry_completion_set_entry(NgraphApp.legend_text_list, GTK_WIDGET(editable)); g_object_set_data(G_OBJECT(editable), "user-data", renderer); g_signal_connect(editable, "editing-done", G_CALLBACK(select_text), user_data); } return; } struct legend_data { char *icon_file; void (* update_func) (struct obj_list_data *, int, int); void (* update_dialog_func) (struct obj_list_data *, int, int); char *name; struct LegendDialog *dialog; }; GtkWidget * create_path_list(struct SubWin *d) { struct obj_list_data *data; list_sub_window_create(d, PATH_LIST_COL_NUM, Plist); data = d->data.data; data->update = PathListUpdate; data->dialog = &DlgLegendArrow; data->setup_dialog = LegendWinPathUpdate; data->ev_key = NULL; data->obj = chkobject("path"); sub_win_create_popup_menu(data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_combo_cell_renderer_cb(data, PATH_LIST_COL_TYPE, Plist, G_CALLBACK(start_editing_line_type), NULL); set_editable_cell_renderer_cb(data, PATH_LIST_COL_X, Plist, G_CALLBACK(pos_x_edited)); set_editable_cell_renderer_cb(data, PATH_LIST_COL_Y, Plist, G_CALLBACK(pos_y_edited)); set_obj_cell_renderer_cb(data, PATH_LIST_COL_COLOR, Plist, G_CALLBACK(start_editing_color)); return d->Win; } GtkWidget * create_rect_list(struct SubWin *d) { struct obj_list_data *data; list_sub_window_create(d, RECT_LIST_COL_NUM, Rlist); data = d->data.data; data->update = RectListUpdate; data->dialog = &DlgLegendRect; data->setup_dialog = LegendWinRectUpdate; data->ev_key = NULL; data->obj = chkobject("rectangle"); sub_win_create_popup_menu(data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_editable_cell_renderer_cb(data, RECT_LIST_COL_X, Rlist, G_CALLBACK(pos_x_edited)); set_editable_cell_renderer_cb(data, RECT_LIST_COL_Y, Rlist, G_CALLBACK(pos_y_edited)); set_editable_cell_renderer_cb(data, RECT_LIST_COL_WIDTH, Rlist, G_CALLBACK(rect_width_edited)); set_editable_cell_renderer_cb(data, RECT_LIST_COL_HEIGHT, Rlist, G_CALLBACK(rect_height_edited)); set_obj_cell_renderer_cb(data, RECT_LIST_COL_COLOR, Rlist, G_CALLBACK(start_editing_color)); return d->Win; } GtkWidget * create_arc_list(struct SubWin *d) { struct obj_list_data *data; list_sub_window_create(d, ARC_LIST_COL_NUM, Alist); data = d->data.data; data->update = ArcListUpdate; data->dialog = &DlgLegendArc; data->setup_dialog = LegendWinArcUpdate; data->ev_key = NULL; data->obj = chkobject("arc"); sub_win_create_popup_menu(data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_obj_cell_renderer_cb(data, ARC_LIST_COL_COLOR, Alist, G_CALLBACK(start_editing_color)); return d->Win; } GtkWidget * create_mark_list(struct SubWin *d) { struct obj_list_data *data; list_sub_window_create(d, MARK_LIST_COL_NUM, Mlist); data = d->data.data; data->update = MarkListUpdate; data->dialog = &DlgLegendMark; data->setup_dialog = LegendWinMarkUpdate; data->ev_key = NULL; data->obj = chkobject("mark"); sub_win_create_popup_menu(data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_obj_cell_renderer_cb(data, MARK_LIST_COL_MARK, Mlist, G_CALLBACK(start_editing_mark)); return d->Win; } GtkWidget * create_text_list(struct SubWin *d) { struct obj_list_data *data; int n; GList *list; GtkTreeViewColumn *col; int noexpand_text_colmns[] = {TEXT_LIST_COL_X, TEXT_LIST_COL_Y, TEXT_LIST_COL_PT, TEXT_LIST_COL_DIR}; list_sub_window_create(d, TEXT_LIST_COL_NUM, Tlist); data = d->data.data; data->update = TextListUpdate; data->dialog = &DlgLegendText; data->setup_dialog = LegendWinTextUpdate; data->ev_key = NULL; data->obj = chkobject("text"); sub_win_create_popup_menu(data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_combo_cell_renderer_cb(data, TEXT_LIST_COL_FONT, Tlist, G_CALLBACK(start_editing_font), NULL); col = gtk_tree_view_get_column(GTK_TREE_VIEW(data->text), TEXT_LIST_COL_TEXT); list = gtk_cell_layout_get_cells(GTK_CELL_LAYOUT(col)); if (list == NULL) { return NULL; } if (list->data) { GtkCellRenderer *renderer; renderer = list->data; gtk_tree_view_column_add_attribute(col, renderer, "style", TEXT_LIST_COL_STYLE); gtk_tree_view_column_add_attribute(col, renderer, "weight", TEXT_LIST_COL_WEIGHT); #ifdef TEXT_LIST_USE_FONT_FAMILY gtk_tree_view_column_add_attribute(col, renderer, "family", TEXT_LIST_COL_FONT_FAMILY); #endif gtk_tree_view_column_add_attribute(col, renderer, "foreground", TEXT_LIST_COL_COLOR); gtk_tree_view_column_add_attribute(col, renderer, "background", TEXT_LIST_COL_BGCOLOR); g_signal_connect_after(renderer, "editing-started", G_CALLBACK(start_editing_text), data); } g_list_free(list); n = sizeof(noexpand_text_colmns) / sizeof(*noexpand_text_colmns); tree_view_set_no_expand_column(data->text, noexpand_text_colmns, n); tree_view_set_tooltip_column(GTK_TREE_VIEW(data->text), TEXT_LIST_COL_TEXT); return d->Win; } ngraph-gtk-6.08.00/src/gtk/ox11menu.c0000644000175000017500000014447513362614576014101 00000000000000/* * $Id: ox11menu.c,v 1.90 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for GTK". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for GTK" 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. * * "Ngraph for GTK" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #include #include #include #include "object.h" #include "odraw.h" #include "ioutil.h" #include "shell.h" #include "nstring.h" #include "nconfig.h" #include "mathfn.h" #include "gra.h" #include "spline.h" #include "strconv.h" #include "gtk_widget.h" #include "gtk_subwin.h" #include "init.h" #include "ogra2cairo.h" #include "ogra2x11.h" #include "ox11menu.h" #include "x11menu.h" #include "x11gui.h" #include "x11view.h" #include "x11graph.h" #include "x11print.h" #include "x11merge.h" #include "x11lgnd.h" #include "x11axis.h" #include "x11file.h" #include "x11cood.h" #include "x11info.h" #define NAME "menu" #define ALIAS "winmenu:gtkmenu" #define PARENT "gra2cairo" #define NVERSION "1.00.00" #define MGTKCONF "[x11menu]" #define G2WINCONF "[gra2gtk]" static char *menuerrorlist[] = { "running.", "cannot open the display.", "cannot open the file", "the GUI is not active", }; #define ERRNUM (sizeof(menuerrorlist) / sizeof(*menuerrorlist)) enum { ERR_MENU_RUN = 100, ERR_MENU_DISPLAY, ERR_MENU_OPEN_FILE, ERR_MENU_GUI, }; struct menulocal Menulocal; struct savedstdio GtkIOSave; static int mxflush(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); enum menu_config_type { MENU_CONFIG_TYPE_NUMERIC, MENU_CONFIG_TYPE_BOOL, MENU_CONFIG_TYPE_STRING, MENU_CONFIG_TYPE_WINDOW, MENU_CONFIG_TYPE_COLOR, MENU_CONFIG_TYPE_COLOR_ARY, MENU_CONFIG_TYPE_SCRIPT, MENU_CONFIG_TYPE_DRIVER, MENU_CONFIG_TYPE_CHARMAP, }; static int menu_config_set_custom_palette(char *s2, void *data); static int menu_config_set_four_elements(char *s2, void *data); static int menu_config_set_bgcolor(char *s2, void *data); static int menu_config_set_ext_driver(char *s2, void *data); static int menu_config_set_script(char *s2, void *data); static int menu_config_set_char_map(char *s2, void *data); static int *menu_config_menu_geometry[] = { &Menulocal.menux, &Menulocal.menuy, &Menulocal.menuwidth, &Menulocal.menuheight, }; struct menu_config { char *name; enum menu_config_type type; int (* proc)(char *, void *); void *data; }; static struct menu_config MenuConfig[] = { {"script_console", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.scriptconsole}, {"addin_console", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.addinconsole}, {"show_tip", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.showtip}, {"character_map", MENU_CONFIG_TYPE_CHARMAP, menu_config_set_char_map, &Menulocal.char_map}, {NULL}, }; static struct menu_config MenuConfigDriver[] = { {"ext_driver", MENU_CONFIG_TYPE_DRIVER, menu_config_set_ext_driver, NULL}, {NULL}, }; static struct menu_config MenuConfigScript[] = { {"script", MENU_CONFIG_TYPE_SCRIPT, menu_config_set_script, NULL}, {NULL}, }; static struct menu_config MenuConfigMisc[] = { {"editor", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.editor}, {"browser", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.browser}, {"help_browser", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.help_browser}, {"coordwin_font", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.coordwin_font}, {"infowin_font", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.infowin_font}, {"file_preview_font", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.file_preview_font}, {"change_directory", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.changedirectory}, {"save_path", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.savepath}, {"save_with_data", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.savewithdata}, {"save_with_merge", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.savewithmerge}, {"expand_dir", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.expanddir}, {"expand", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.expand}, {"load_path", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.loadpath}, {"history_size", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.hist_size}, {"infowin_size", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.info_size}, {"data_head_lines", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.data_head_lines}, {"use_opacity", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.use_opacity}, {"select_data_on_export", MENU_CONFIG_TYPE_BOOL, NULL, &Menulocal.select_data}, {"use_custom_palette", MENU_CONFIG_TYPE_BOOL, NULL, &Menulocal.use_custom_palette}, {"custom_palette", MENU_CONFIG_TYPE_COLOR_ARY, menu_config_set_custom_palette, NULL}, {"sourece_style_id", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.source_style_id}, {NULL}, }; static struct menu_config MenuConfigViewer[] = { {"viewer_dpi", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.windpi}, {"antialias", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.antialias}, {"viewer_load_file_on_redraw", MENU_CONFIG_TYPE_BOOL, NULL, &Menulocal.redrawf}, {"viewer_load_file_data_number", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.redrawf_num}, {"viewer_grid", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.grid}, {"focus_frame_type", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.focus_frame_type}, {"preserve_width", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.preserve_width}, {"background_color", MENU_CONFIG_TYPE_COLOR, menu_config_set_bgcolor, NULL}, {NULL}, }; static struct menu_config MenuConfigToggleView[] = { {"viewer_show_ruler", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.ruler}, {"sidebar", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.sidebar}, {"status_bar", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.statusbar}, {"scrollbar", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.scrollbar}, {"command_toolbar", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.ctoolbar}, {"pointer_toolbar", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.ptoolbar}, {"cross_gauge", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.show_cross}, {"show_grid", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.show_grid}, {NULL}, }; static struct menu_config MenuConfigOthers[] = { {"png_dpi", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.png_dpi}, #if WINDOWS {"emf_dpi", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.emf_dpi}, #endif {"ps_version", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.ps_version}, {"svg_version", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.svg_version}, {"palette", MENU_CONFIG_TYPE_STRING, NULL, &Menulocal.Palette}, {"main_pane", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.main_pane_pos}, {"side_pane1", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.side_pane1_pos}, {"side_pane2", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.side_pane2_pos}, {"side_pane3", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.side_pane3_pos}, {"file_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.file_tab}, {"axis_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.axis_tab}, {"merge_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.merge_tab}, {"path_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.path_tab}, {"rectangle_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.rectangle_tab}, {"arc_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.arc_tab}, {"mark_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.mark_tab}, {"text_tab", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.text_tab}, {"math_input_mode", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.math_input_mode}, {NULL}, }; static struct menu_config MenuConfigGeometry[] = { {"menu_win", MENU_CONFIG_TYPE_WINDOW, menu_config_set_four_elements, menu_config_menu_geometry}, {NULL}, }; static struct menu_config MenuConfigExtView[] = { {"extwin_dpi", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.exwindpi}, {"extwin_width", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.exwinwidth}, {"extwin_height", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.exwinheight}, {"use_external_viewer", MENU_CONFIG_TYPE_NUMERIC, NULL, &Menulocal.exwin_use_external}, {NULL}, }; static struct menu_config *MenuConfigArrray[] = { MenuConfig, MenuConfigDriver, MenuConfigScript, MenuConfigMisc, MenuConfigViewer, MenuConfigToggleView, MenuConfigOthers, MenuConfigGeometry, MenuConfigExtView, NULL, }; static NHASH MenuConfigHash = NULL; static void add_str_with_int_to_array(struct menu_config *cfg, struct narray *conf) { char *buf; buf = g_strdup_printf("%s=%d", cfg->name, * (int *) cfg->data); if (buf) { arrayadd(conf, &buf); } } static void add_geometry_to_array(struct menu_config *cfg, struct narray *conf) { char *buf; gint x, y, w, h; get_window_geometry(TopLevel, &x, &y, &w, &h); Menulocal.menux = x; Menulocal.menuy = y; Menulocal.menuwidth = w; Menulocal.menuheight = h; buf = g_strdup_printf("%s=%d,%d,%d,%d", cfg->name, Menulocal.menux, Menulocal.menuy, Menulocal.menuwidth, Menulocal.menuheight); if (buf) { arrayadd(conf, &buf); } } static void add_color_to_array(struct menu_config *cfg, struct narray *conf) { char *buf; buf = g_strdup_printf("%s=%02x%02x%02x", cfg->name, (int) (Menulocal.bg_r * 255), (int) (Menulocal.bg_g * 255), (int) (Menulocal.bg_b * 255)); if (buf) { arrayadd(conf, &buf); } } static void add_color_ary_to_array(struct menu_config *cfg, struct narray *conf) { GString *str; char *buf; struct narray *palette; int i, n; GdkRGBA *color; unsigned int r, g, b, a; palette = &(Menulocal.custom_palette); n = arraynum(palette); if (n < 1) { return; } str = g_string_new(cfg->name); g_string_append_c(str, '='); for (i = 0; i < n; i++) { color = arraynget(palette, i); r = color->red * 0xff; g = color->green * 0xff; b = color->blue * 0xff; a = color->alpha * 0xff; g_string_append_printf(str, "%02x%02x%02x%02x%s", r, g, b, a, (i == n -1) ? "\n" : ","); } buf = g_string_free(str, FALSE); if (buf) { arrayadd(conf, &buf); } } static void add_prm_str_to_array(struct menu_config *cfg, struct narray *conf) { char *buf, *prm; prm = CHK_STR(* (char **) cfg->data); buf = g_strdup_printf("%s=%s", cfg->name, prm); if (buf) { arrayadd(conf, &buf); } } static void save_char_map_config(struct narray *conf) { char *title, *data, *buf; struct character_map_list *pcur; pcur = Menulocal.char_map; while (pcur) { title = CHK_STR(pcur->title); data = CHK_STR(pcur->data); buf = g_strdup_printf("character_map=%s,%s", title, data); if (buf) { arrayadd(conf, &buf); } pcur = pcur->next; } } static void save_ext_driver_config(struct narray *conf) { char *buf, *driver, *ext, *option; struct extprinter *pcur; pcur = Menulocal.extprinterroot; while (pcur) { driver = CHK_STR(pcur->driver); ext = CHK_STR(pcur->ext); option= CHK_STR(pcur->option); buf = g_strdup_printf("ext_driver=%s,%s,%s,%s", pcur->name, driver, ext, option); if (buf) { arrayadd(conf, &buf); } pcur = pcur->next; } } static void save_script_config(struct narray *conf) { char *buf, *script, *option, *description; struct script *scur; scur = Menulocal.scriptroot; while (scur) { script = CHK_STR(scur->script); option = CHK_STR(scur->option); description = CHK_STR(scur->description); buf = g_strdup_printf("script=%s,%s,%s,%s", scur->name, script, description, option); if (buf) { arrayadd(conf, &buf); } scur = scur->next; } } static void add_str_to_array(struct narray *conf, char *str) { char *buf; buf = g_strdup(str); if (buf) { arrayadd(conf, &buf); } } static void menu_save_config_sub(struct menu_config *cfg, struct narray *conf) { int i; for (i = 0; cfg[i].name; i++) { switch (cfg[i].type) { case MENU_CONFIG_TYPE_NUMERIC: case MENU_CONFIG_TYPE_BOOL: add_str_with_int_to_array(cfg + i, conf); break; case MENU_CONFIG_TYPE_COLOR: add_color_to_array(cfg + i, conf); break; case MENU_CONFIG_TYPE_COLOR_ARY: add_color_ary_to_array(cfg + i, conf); break; case MENU_CONFIG_TYPE_STRING: add_prm_str_to_array(cfg + i, conf); break; case MENU_CONFIG_TYPE_WINDOW: add_geometry_to_array(cfg + i, conf); break; case MENU_CONFIG_TYPE_SCRIPT: save_script_config(conf); break; case MENU_CONFIG_TYPE_DRIVER: save_ext_driver_config(conf); break; case MENU_CONFIG_TYPE_CHARMAP: save_char_map_config(conf); break; } } } int menu_save_config(int type) { struct narray conf; arrayinit(&conf, sizeof(char *)); if (type & SAVE_CONFIG_TYPE_GEOMETRY) { menu_save_config_sub(MenuConfigGeometry, &conf); } if (type & SAVE_CONFIG_TYPE_VIEWER) { menu_save_config_sub(MenuConfigViewer, &conf); } if (type & SAVE_CONFIG_TYPE_EXTERNAL_VIEWER) { menu_save_config_sub(MenuConfigExtView, &conf); } if (type & SAVE_CONFIG_TYPE_TOGGLE_VIEW) { menu_save_config_sub(MenuConfigToggleView, &conf); } if (type & SAVE_CONFIG_TYPE_OTHERS) { menu_save_config_sub(MenuConfigOthers, &conf); } if (type & SAVE_CONFIG_TYPE_EXTERNAL_DRIVER) { menu_save_config_sub(MenuConfigDriver, &conf); } if (type & SAVE_CONFIG_TYPE_ADDIN_SCRIPT) { menu_save_config_sub(MenuConfigScript, &conf); } if (type & SAVE_CONFIG_TYPE_MISC) { menu_save_config_sub(MenuConfigMisc, &conf); } replaceconfig(MGTKCONF, &conf); arraydel2(&conf); arrayinit(&conf, sizeof(char *)); if (type & SAVE_CONFIG_TYPE_EXTERNAL_DRIVER) { if (Menulocal.extprinterroot == NULL) { add_str_to_array(&conf, "ext_driver"); } } if (type & SAVE_CONFIG_TYPE_ADDIN_SCRIPT) { if (Menulocal.scriptroot == NULL) { add_str_to_array(&conf, "script"); } } removeconfig(MGTKCONF, &conf); arraydel2(&conf); return 0; } static int menu_config_set_four_elements(char *s2, void *data) { int len, i, val, **ary; char *endptr, *f[] = {NULL, NULL, NULL, NULL}; if (data == NULL) return 0; ary = (int **) data; for (i = 0; i < 4; i++) { f[i] = getitok2(&s2, &len, " \t,"); if (f[i] == NULL) goto End; } for (i = 0; i < 4; i++) { val = strtol(f[i], &endptr, 10); if (endptr[0] == '\0' && val != 0) { *(ary[i]) = val; } } End: for (i = 0; i < 4; i++) { g_free(f[i]); } return 0; } static int menu_config_set_bgcolor(char *s2, void *data) { char *f1, *endptr; int len, val; f1 = getitok2(&s2, &len, " \t,"); val = strtol(f1, &endptr, 16); if (endptr[0] == '\0') { Menulocal.bg_r = ((val >> 16) & 0xffU) / 255.0; Menulocal.bg_g = ((val >> 8) & 0xffU) / 255.0; Menulocal.bg_b = (val & 0xffU) / 255.0; } g_free(f1); return 0; } static int menu_config_set_custom_palette(char *s2, void *data) { gchar **colors, **ptr; unsigned int r, g, b, a; struct narray *palette; GdkRGBA color; colors = g_strsplit(s2, ",", 0); if (colors == NULL) { return 0; } palette = &(Menulocal.custom_palette); arrayclear(palette); ptr = colors; while (*ptr) { r = g = b = a = 0xff; sscanf(*ptr, "%02x%02x%02x%02x", &r, &g, &b, &a); color.red = r / 255.0; color.green = g / 255.0; color.blue = b / 255.0; color.alpha = a / 255.0; arrayadd(palette, &color); ptr++; } g_strfreev(colors); return 0; } static int menu_config_set_char_map(char *s2, void *data) { char *title; int len; struct character_map_list *pcur, **pptr; pptr = (struct character_map_list **) data; if (! g_utf8_validate(s2, -1, NULL)) { return 0; } title = getitok2(&s2, &len, ","); g_strstrip(title); for (; (s2[0] != '\0') && (strchr(" \t,", s2[0])); s2++); g_strstrip(s2); pcur = g_malloc(sizeof(*pcur)); if (pcur == NULL) { g_free(title); return 1; } pcur->title = title; pcur->data = g_strdup(s2); pcur->next = *pptr; *pptr = pcur; return 0; } static int menu_config_set_ext_driver(char *s2, void *data) { char *f[4] = {NULL, NULL, NULL, NULL}; int len, i; struct extprinter *pnew, *pcur, **pptr; pptr = (struct extprinter **) data; pcur = *pptr; f[0] = getitok2(&s2, &len, ","); f[1] = getitok2(&s2, &len, ","); if (s2[1] == ',') { f[2] = NULL; } else { f[2] = getitok2(&s2, &len, ","); } for (; (s2[0] != '\0') && (strchr(" \t,", s2[0])); s2++); f[3] = getitok2(&s2, &len, ""); if (f[0] && f[1]) { pnew = (struct extprinter *) g_malloc(sizeof(struct extprinter)); if (pnew == NULL) { for (i = 0; i < 4; i++) { g_free(f[i]); } return 1; } if (pcur == NULL) { Menulocal.extprinterroot = pnew; } else { pcur->next = pnew; } *pptr = pnew; pcur = pnew; pcur->next = NULL; pcur->name = f[0]; pcur->driver = f[1]; pcur->ext = f[2]; pcur->option = f[3]; } else { for (i = 0; i < 4; i++) { g_free(f[i]); } } return 0; } static int menu_config_set_script(char *s2, void *data) { char *f[] = {NULL, NULL, NULL, NULL}; int len; unsigned int i; struct script *snew, *scur, **sptr; sptr = (struct script **) data; scur = *sptr; f[0] = getitok2(&s2, &len, ","); f[1] = getitok2(&s2, &len, ","); f[2] = getitok2(&s2, &len, ","); for (; (s2[0] != '\0') && (strchr(" \t,", s2[0])); s2++); f[3] = getitok2(&s2, &len, ","); if (f[0] && f[1]) { snew = (struct script *) g_malloc(sizeof(struct script)); if (snew == NULL) { for (i = 0; i < sizeof(f) / sizeof(*f); i++) { g_free(f[i]); } return 1; } if (scur == NULL) { Menulocal.scriptroot = snew; } else { scur->next = snew; } *sptr = snew; scur = snew; scur->next = NULL; scur->name = f[0]; scur->script = f[1]; scur->description = f[2]; scur->option = f[3]; } else { for (i = 0; i < sizeof(f) / sizeof(*f); i++) { g_free(f[i]); } } return 0; } static int mgtkloadconfig(void) { FILE *fp; char *tok, *str, *s2; char *f1; int val; char *endptr; int len; struct extprinter *pcur; struct script *scur; struct menu_config *cfg; fp = openconfig(MGTKCONF); if (fp == NULL) return 0; pcur = Menulocal.extprinterroot; scur = Menulocal.scriptroot; if (nhash_get_ptr(MenuConfigHash, "ext_driver", (void *) &cfg) == 0) { if (cfg) { cfg->data = &pcur; } } if (nhash_get_ptr(MenuConfigHash, "script", (void *) &cfg) == 0) { if (cfg) { cfg->data = &scur; } } while ((tok = getconfig(fp, &str))) { s2 = str; if (nhash_get_ptr(MenuConfigHash, tok, (void *) &cfg) == 0 && cfg) { switch (cfg->type) { case MENU_CONFIG_TYPE_NUMERIC: f1 = getitok2(&s2, &len, " \t,"); if (f1) { val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') { * (int *) (cfg->data) = val; } } g_free(f1); break; case MENU_CONFIG_TYPE_BOOL: f1 = getitok2(&s2, &len, " \t,"); if (f1) { val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') { * (int *) (cfg->data) = (val ? 1 : 0); } } g_free(f1); break; case MENU_CONFIG_TYPE_STRING: f1 = getitok2(&s2, &len, ""); if (f1) { g_free(* (char **) (cfg->data)); * (char **) (cfg->data) = f1; } break; case MENU_CONFIG_TYPE_CHARMAP: case MENU_CONFIG_TYPE_COLOR: case MENU_CONFIG_TYPE_COLOR_ARY: case MENU_CONFIG_TYPE_SCRIPT: case MENU_CONFIG_TYPE_DRIVER: case MENU_CONFIG_TYPE_WINDOW: if (cfg->proc && cfg->proc(s2, cfg->data)) { g_free(tok); g_free(str); closeconfig(fp); return 1; } break; } } else { fprintf(stderr, "(%s): configuration '%s' in section %s is not used.\n", AppName, tok, MGTKCONF); } g_free(tok); g_free(str); } closeconfig(fp); return 0; } void menuadddrawrable(struct objlist *parent, struct narray *drawrable) { struct objlist *ocur; const char *name; ocur = chkobjroot(); while (ocur) { if (chkobjparent(ocur) == parent) { name = chkobjectname(ocur); arrayadd2(drawrable, name); menuadddrawrable(ocur, drawrable); } ocur = ocur->next; } } static void free_script_list(struct script *script) { struct script *scur, *sdel; scur = script; while (scur) { sdel = scur; scur = scur->next; g_free(sdel->name); g_free(sdel->script); g_free(sdel->description); g_free(sdel->option); g_free(sdel); } } static int free_layers(struct nhash *layers, void *ptr) { struct layer *layer; layer = layers->val.p; if (layer == NULL) { return 0; } cairo_surface_destroy(layer->pix); cairo_destroy(layer->cairo); g_free(layer); return 0; } int select_layer(const char *id) { struct layer *layer; void *ptr; int r; r = nhash_get_ptr(Menulocal.layers, id, &ptr); if (r) { return 1; } layer = ptr; Menulocal.local->cairo = layer->cairo; set_cairo_antialias(layer->cairo, Menulocal.antialias); return 0; } static void create_layer(struct layer *layer, int w, int h) { layer->pix = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, w, h); layer->cairo = cairo_create(layer->pix); } void init_layer(const char *obj) { struct layer *layer; void *ptr; int r, w, h, lw, lh; if (Menulocal.pix == NULL) { return; } if (obj == NULL) { return; } w = cairo_image_surface_get_width(Menulocal.pix); h = cairo_image_surface_get_height(Menulocal.pix); r = nhash_get_ptr(Menulocal.layers, obj, &ptr); if (r) { layer = g_malloc(sizeof(*layer)); if (layer == NULL) { return; } create_layer(layer, w, h); nhash_set_ptr(Menulocal.layers, obj, layer); } else { layer = ptr; lw = cairo_image_surface_get_width(layer->pix); lh = cairo_image_surface_get_height(layer->pix); if (lw != w || lh != h) { cairo_destroy(layer->cairo); cairo_surface_destroy(layer->pix); create_layer(layer, w, h); } } set_cairo_antialias(layer->cairo, Menulocal.antialias); } static void menulocal_finalize(void) { struct extprinter *pcur, *pdel; struct character_map_list *cmap, *cmap_tmp; int i, j; struct menu_config *cfg; for (i = 0; (cfg = MenuConfigArrray[i]); i++) { for (j = 0; cfg[j].name; j++) { if (cfg[i].type == MENU_CONFIG_TYPE_STRING) { g_free(* (char **) cfg[i].data); * (char **) cfg[i].data = NULL; } } } cmap = Menulocal.char_map; while (cmap) { cmap_tmp = cmap; cmap = cmap_tmp->next; g_free(cmap_tmp->title); g_free(cmap_tmp->data); g_free(cmap_tmp); } Menulocal.char_map = NULL; pcur = Menulocal.extprinterroot; while (pcur) { pdel = pcur; pcur = pcur->next; g_free(pdel->name); g_free(pdel->driver); g_free(pdel->ext); g_free(pdel->option); g_free(pdel); } Menulocal.extprinterroot = NULL; free_script_list(Menulocal.scriptroot); Menulocal.scriptroot = NULL; free_script_list(Menulocal.addin_list); Menulocal.addin_list = NULL; if (Menulocal.pix) { cairo_surface_destroy(Menulocal.pix); Menulocal.pix = NULL; } if (Menulocal.bg) { cairo_surface_destroy(Menulocal.bg); Menulocal.bg = NULL; } if (Menulocal.layers) { nhash_each(Menulocal.layers, free_layers, NULL); nhash_free(Menulocal.layers); Menulocal.layers = NULL; } arraydel2(&Menulocal.drawrable); arraydel(&Menulocal.custom_palette); g_free(Menulocal.fileopendir); Menulocal.fileopendir = NULL; g_free(Menulocal.graphloaddir); Menulocal.graphloaddir = NULL; Menulocal.obj = NULL; Menulocal.local = NULL; } static void init_custom_palette(void) { struct narray *palette; int i, j, k; unsigned int c[] = {0xff, 0xcc, 0x99}; GdkRGBA color; palette = &(Menulocal.custom_palette); arrayclear(palette); add_default_color(palette); for (i = 0; i < 3; i++) { for (j = 0; j < 3; j++) { for (k = 0; k < 3; k++) { color.red = c[j] / 255.0; color.green = c[i] / 255.0; color.blue = c[k] / 255.0; color.alpha = 1.0; arrayadd(palette, &color); } } } add_default_gray(palette); } static int menuinit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; int layer; if (!OpenApplication()) { error(obj, ERR_MENU_DISPLAY); goto errexit; } if (_exeparent(obj, (char *) argv[1], inst, rval, argc, argv)) { return 1; } layer = TRUE; if (_putobj(obj, "_layer", inst, &layer)) return 1; if (_getobj(obj, "_local", inst, &local)) { local = gra2cairo_free(obj, inst); g_free(local); return 1; } memset(&Menulocal, 0, sizeof(Menulocal)); Menulocal.menux = Menulocal.menuy = Menulocal.menuheight = Menulocal.menuwidth = DEFAULT_GEOMETRY; Menulocal.showtip = TRUE; Menulocal.sidebar = TRUE; Menulocal.statusbar = TRUE; Menulocal.ruler = TRUE; Menulocal.scrollbar = TRUE; Menulocal.ptoolbar = TRUE; Menulocal.ctoolbar = TRUE; Menulocal.show_cross = FALSE; Menulocal.scriptconsole = FALSE; Menulocal.addinconsole = TRUE; Menulocal.changedirectory = 1; set_paper_type(21000, 29700); Menulocal.PaperZoom = 10000; Menulocal.exwindpi = DEFAULT_DPI / 2; Menulocal.exwinwidth = 400; Menulocal.exwinheight = 600; Menulocal.exwin_use_external = TRUE; Menulocal.expand = 1; Menulocal.expanddir = g_strdup("./"); Menulocal.source_style_id = NULL; Menulocal.loadpath = SAVE_PATH_FULL; Menulocal.GRAobj = chkobject("gra"); Menulocal.hist_size = 1000; Menulocal.info_size = 1000; Menulocal.bg_r = 1.0; Menulocal.bg_g = 1.0; Menulocal.bg_b = 1.0; Menulocal.focus_frame_type = N_LINE_TYPE_DOT; Menulocal.main_pane_pos = 600; Menulocal.side_pane1_pos = 500; Menulocal.side_pane2_pos = 300; Menulocal.side_pane3_pos = 200; Menulocal.file_tab = 0; Menulocal.axis_tab = 100; Menulocal.merge_tab = 101; Menulocal.path_tab = 1; Menulocal.rectangle_tab = 2; Menulocal.arc_tab = 3; Menulocal.mark_tab = 4; Menulocal.text_tab = 5; Menulocal.math_input_mode = 1; arrayinit(&(Menulocal.drawrable), sizeof(char *)); menuadddrawrable(chkobject("draw"), &(Menulocal.drawrable)); arrayinit(&(Menulocal.custom_palette), sizeof(GdkRGBA)); init_custom_palette(); Menulocal.use_custom_palette = TRUE; Menulocal.windpi = DEFAULT_DPI; Menulocal.redrawf = TRUE; Menulocal.redrawf_num = 0xffU; Menulocal.grid = 200; Menulocal.show_grid = TRUE; Menulocal.data_head_lines = 100; Menulocal.use_opacity = FALSE; Menulocal.select_data = TRUE; Menulocal.local = local; Menulocal.png_dpi = 72; #if WINDOWS Menulocal.emf_dpi = 576; #endif Menulocal.ps_version = 0; Menulocal.svg_version = 0; if (mgtkloadconfig()) goto errexit; gra2cairo_set_antialias(Menulocal.local, Menulocal.antialias); if (_putobj(obj, "antialias", inst, &(Menulocal.antialias))) goto errexit; if (Menulocal.exwindpi < 1) Menulocal.exwindpi = DEFAULT_DPI / 2; if (Menulocal.exwindpi > DPI_MAX) Menulocal.exwindpi = DPI_MAX; if (Menulocal.windpi < 1) Menulocal.windpi = DEFAULT_DPI; if (Menulocal.windpi > DPI_MAX) Menulocal.windpi = DPI_MAX; if (_putobj(obj, "dpi", inst, &(Menulocal.windpi))) goto errexit; if (_putobj(obj, "data_head_lines", inst, &(Menulocal.data_head_lines))) goto errexit; if (_putobj(obj, "redraw_flag", inst, &(Menulocal.redrawf))) goto errexit; if (_putobj(obj, "redraw_num", inst, &(Menulocal.redrawf_num))) goto errexit; Menulocal.local->use_opacity = Menulocal.use_opacity; if (_putobj(obj, "use_opacity", inst, &Menulocal.use_opacity)) goto errexit; Menulocal.modified = 0; if (_putobj(obj, "modified", inst, &Menulocal.modified)) goto errexit; Menulocal.obj = obj; Menulocal.inst = inst; Menulocal.pix = NULL; Menulocal.bg = NULL; Menulocal.layers = nhash_new(); Menulocal.lock = 0; return 0; errexit: menulocal_finalize(); local = gra2cairo_free(obj, inst); g_free(local); return 1; } static int menudone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (Menulocal.lock) { error(obj, ERR_MENU_RUN); return 1; } Menulocal.local->cairo = NULL; if (_exeparent(obj, (char *) argv[1], inst, rval, argc, argv)) return 1; menulocal_finalize(); return 0; } void mgtkdisplaydialog(const char *str) { DisplayDialog(str); } void mgtkdisplaystatus(const char *str) { DisplayDialog(str); } int mgtkputstderr(const char *s) { return PutStderr(s); } int mgtkputstdout(const char *s) { return PutStdout(s); } int mgtkprintfstderr(const char *fmt, ...) { int len; char buf[1024]; va_list ap; va_start(ap, fmt); len = vsnprintf(buf, sizeof(buf), fmt, ap); va_end(ap); PutStderr(buf); return len; } int mgtkprintfstdout(const char *fmt, ...) { int len; char buf[1024]; va_list ap; va_start(ap, fmt); len = vsnprintf(buf, sizeof(buf), fmt, ap); va_end(ap); PutStdout(buf); return len; } int mgtkinterrupt(void) { return ChkInterrupt(); } int mgtkinputyn(const char *mes) { char *ptr; int r; ptr = g_locale_to_utf8(CHK_STR(mes), -1, NULL, NULL, NULL); r = InputYN(ptr); g_free(ptr); return r; } static int menumenu(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *file; int r; if (_exeparent(obj, (char *) argv[1], inst, rval, argc, argv)) return 1; if (Menulocal.lock) { error(obj, ERR_MENU_RUN); return 1; } Menulocal.lock = 1; savestdio(&GtkIOSave); file = get_utf8_filename(argv[2]); hide_console(); r = application(file); resotre_console(); if (file) { g_free(file); } loadstdio(&GtkIOSave); Menulocal.lock = 0; return r; } static int mx_evloop(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { reset_event(); return 0; } static int mxredrawflag(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { Menulocal.redrawf = *(int *) argv[2]; return 0; } static int mxredraw_num(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int n; n = *(int *) argv[2]; n = (n < 0) ? 0: n; Menulocal.redrawf_num = n; *(int *) argv[2] = n; return 0; } static int mxuse_opacity(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int n; n = *(int *) argv[2]; Menulocal.local->use_opacity = Menulocal.use_opacity = n; return 0; } static int mx_data_head_lines(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int n; n = *(int *) argv[2]; n = (n < 0) ? 0: n; Menulocal.data_head_lines = n; *(int *) argv[2] = n; return 0; } void main_window_redraw(void) { GdkWindow *win; if (NgraphApp.Viewer.Win == NULL) { return; } win = gtk_widget_get_window(NgraphApp.Viewer.Win); if(win == NULL) { return; } gdk_window_invalidate_rect(win, NULL, FALSE); } void mx_redraw(struct objlist *obj, N_VALUE *inst, char **objects) { int n; char *objs[OBJ_MAX]; struct savedstdio save; if (Menulocal.region) { mx_clear(Menulocal.region, objects); } if (Menulocal.redrawf) { n = Menulocal.redrawf_num; } else { n = 0; } if (objects == NULL) { int i, num; struct narray *array; array = &Menulocal.drawrable; num = arraynum(array); for (i = 0; i < num; i++) { objs[i] = arraynget_str(array, i); } objs[i] = NULL; objects = objs; } ignorestdio(&save); GRAredraw_layers(obj, inst, TRUE, n, objects); restorestdio(&save); mxflush(obj, inst, NULL, 0, NULL); main_window_redraw(); } void mx_inslist(struct objlist *obj, N_VALUE *inst, struct objlist *aobj, N_VALUE *ainst, char *afield, int addn) { int gc; _getobj(obj, "_GC", inst, &gc); GRAinslist(gc, aobj, ainst, chkobjectname(aobj), afield, addn); } void mx_dellist(struct objlist *obj, N_VALUE *inst, int deln) { int gc; _getobj(obj, "_GC", inst, &gc); GRAdellist(gc, deln); } static int mxredraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } mx_redraw(obj, inst, NULL); return 0; } static int mxdpi(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int dpi; if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } dpi = abs(*(int *) argv[2]); if (dpi < 1) dpi = 1; if (dpi > DPI_MAX) dpi = DPI_MAX; Menulocal.windpi = dpi; Menulocal.local->pixel_dot_x = Menulocal.local->pixel_dot_y = dpi / (DPI_MAX * 1.0); *(int *) argv[2] = dpi; main_window_redraw(); return 0; } static void flush_layers(cairo_t *cr) { int r, i, n; struct narray *array; struct layer *layer; char *obj; void *ptr; array = &Menulocal.drawrable; n = arraynum(array); for (i = 0; i < n; i++) { obj = arraynget_str(array, i); r = nhash_get_ptr(Menulocal.layers, obj, &ptr); if (r) { continue; } layer = ptr; if (layer->pix) { cairo_surface_flush(layer->pix); } cairo_set_source_surface(cr, layer->pix, 0, 0); cairo_paint(cr); } } static void clear_region(cairo_t *cr, cairo_region_t *region) { cairo_save(cr); cairo_set_source_rgba(cr, 0, 0, 0, 0); cairo_set_operator(cr, CAIRO_OPERATOR_SOURCE); if (region) { gdk_cairo_region(cr, region); cairo_fill(cr); } else { cairo_reset_clip(cr); cairo_paint(cr); } cairo_restore(cr); } static int mxflush(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { cairo_surface_t *surface; cairo_t *cr; if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } if (Menulocal.local->cairo) { gra2cairo_draw_path(Menulocal.local); surface = cairo_get_target(Menulocal.local->cairo); if (surface) { cairo_surface_flush(surface); } } if (Menulocal.pix) { cr = cairo_create(Menulocal.pix); clear_region(cr, NULL); flush_layers(cr); cairo_destroy(cr); } return 0; } static int clear_layer(const char *obj, cairo_region_t *region) { struct layer *layer; void *ptr; int r; r = nhash_get_ptr(Menulocal.layers, obj, &ptr); if (r) { return 1; } layer = ptr; clear_region(layer->cairo, region); return 0; } void mx_clear(cairo_region_t *region, char **objects) { int i, n; struct narray *array; char *obj; if (objects) { while(*objects) { clear_layer(*objects, region); objects++; } } else { array = &Menulocal.drawrable; n = arraynum(array); for (i = 0; i < n; i++) { obj = arraynget_str(array, i); clear_layer(obj, region); } } } static int mxclear(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } if (_exeparent(obj, (char *) argv[1], inst, rval, argc, argv)) return 1; mx_clear(NULL, NULL); main_window_redraw(); return 0; } static int mxfullpathngp(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *name, *ngp2; name = (char *) argv[2]; if (name == NULL) ngp2 = NULL; else ngp2 = getbasename(name); putobj(Menulocal.obj, "ngp", 0, ngp2); return 0; } static int check_object_name(struct objlist *obj, struct narray *array) { int i, n; char **adata; if (array == NULL) return 0; adata = arraydata(array); if (adata == NULL) return 0; n = arraynum(array); if (n == 0) return 0; for (i = 0; i < n; i ++) { if (obj == chkobject(adata[i])) return 0; } return 1; } static int mx_get_focused(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int num, i, id; const char *name; char *ptr; struct narray *oarray, *sarray; struct Viewer *d; struct FocusObj **focus; if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } arrayfree2(rval->array); rval->array = NULL; d = &(NgraphApp.Viewer); num = arraynum(d->focusobj); if (num < 1) return 0; oarray = arraynew(sizeof(char *)); if (oarray == NULL) return 1; sarray = (argc > 2) ? (struct narray *) argv[2] : NULL; focus = arraydata(d->focusobj); for (i = 0; i < num; i++) { if (check_object_name(focus[i]->obj, sarray)) continue; inst = chkobjinstoid(focus[i]->obj, focus[i]->oid); if (inst) { _getobj(focus[i]->obj, "id", inst, &id); name = chkobjectname(focus[i]->obj); ptr = g_strdup_printf("%s:%d", name, id); if (ptr) { arrayadd(oarray, &ptr); } } } rval->array = oarray; return 0; } static int mx_print(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int show_dialog, select_file, create_window = FALSE, lock; GtkWidget *label; select_file = * (int *) argv[2]; show_dialog = * (int *) argv[3]; if (TopLevel == NULL) { create_window = TRUE; TopLevel = gtk_window_new(GTK_WINDOW_TOPLEVEL); gtk_window_set_type_hint(GTK_WINDOW(TopLevel), GDK_WINDOW_TYPE_HINT_DIALOG); g_signal_connect(TopLevel, "delete-event", G_CALLBACK(gtk_true), NULL); label = gtk_label_new(" Ngraph "); gtk_container_add(GTK_CONTAINER(TopLevel), label); gtk_widget_show_all(TopLevel); reset_event(); } lock = Menulock; menu_lock(FALSE); CmOutputPrinter(select_file, show_dialog); menu_lock(lock); if (create_window) { gtk_widget_destroy(TopLevel); TopLevel = NULL; reset_event(); } return 0; } static int mx_echo(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } if (argv[2]) PutStdout((char *) argv[2]); PutStdout("\n"); return 0; } static int mx_cat(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char buf[1024]; int len, use_stdin = TRUE; int fd; if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } if (argv[2]) { fd = nopen(argv[2], O_RDONLY, 0); if (fd == -1) { error(obj, ERR_MENU_OPEN_FILE); return 1; } use_stdin = FALSE; } else { fd = stdinfd(); } while ((len = nread(fd, buf, sizeof(buf) - 1)) > 0) { buf[len] = '\0'; PutStdout(buf); } if (! use_stdin) { nclose(fd); } return 0; } static int mx_clear_info(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } InfoWinClear(); return 0; } static int mx_get_accel_map(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { #if USE_GTK_BUILDER char **actions, **accels; int i, j; GString *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; str = g_string_new(""); actions = gtk_application_list_action_descriptions(GtkApp); for (i = 0; actions[i]; i++) { accels = gtk_application_get_accels_for_action(GtkApp, actions[i]); for (j = 0; accels[j]; j++) { g_string_append_printf(str, "%s %s\n", actions[i], accels[j]); } g_strfreev(accels); } g_strfreev(actions); #else FILE *fp; int fd; char buf[1024], *ptr; GString *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; fp = tmpfile(); if (fp == NULL) { putstderr(g_strerror(errno)); return 1; } fd = fileno(fp); gtk_accel_map_save_fd(fd); rewind(fp); str = g_string_new(""); while ((ptr = fgets(buf, sizeof(buf), fp))) { buf[sizeof(buf) - 1] = '\0'; g_string_append(str, buf); } fclose(fp); #endif rval->str = g_string_free(str, FALSE); return 0; } #ifdef HAVE_READLINE_READLINE_H #include #endif #ifdef HAVE_LIBGSL #include #endif static int mx_show_lib_version(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *s, h[256]; int i, n; GString *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; n = 0; s = argv[2]; if (s) { n = s[0] - '0'; n = (n < (int) sizeof(h) - 1) ? n : (int) sizeof(h) - 1; } for (i = 0; i < n; i++) { h[i] = ' '; } h[i] = '\0'; str = g_string_new(""); g_string_append_printf(str, "%sGTK+\n" "%s compile: %d.%d.%d\n" "%s linked: %d.%d.%d\n" "\n", h, h, GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION, h, gtk_major_version, gtk_minor_version, gtk_micro_version); g_string_append_printf(str, "%sGLib\n" "%s compile: %d.%d.%d\n" "%s linked: %d.%d.%d\n" "\n", h, h, GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION, h, glib_major_version, glib_minor_version, glib_micro_version); g_string_append_printf(str, "%sCairo\n" "%s compile: %s\n" "%s linked: %s\n" "\n", h, h, CAIRO_VERSION_STRING, h, cairo_version_string()); g_string_append_printf(str, "%sPango\n" "%s compile: %s\n" "%s linked: %s\n" "\n", h, h, PANGO_VERSION_STRING, h, pango_version_string()); g_string_append_printf(str, "%sGtkSourceView\n" "%s compile: %d.%d.%d\n" "%s linked: %d.%d.%d\n", h, h, GTK_SOURCE_MAJOR_VERSION, GTK_SOURCE_MINOR_VERSION, GTK_SOURCE_MICRO_VERSION, h, gtk_source_get_major_version(), gtk_source_get_minor_version(), gtk_source_get_micro_version()); #ifdef RL_VERSION_MAJOR g_string_append(str, "\n"); g_string_append_printf(str, "%sreadline\n" "%s compile: %d.%d\n" "%s linked: %s\n", h, h, RL_VERSION_MAJOR, RL_VERSION_MINOR, h, rl_library_version); #endif #ifdef HAVE_LIBGSL g_string_append(str, "\n"); g_string_append_printf(str, "%sGSL\n" #ifdef GSL_VERSION "%s compile: %s\n" #else /* GSL_VERSION */ "%s compile: %d.%d\n" #endif /* GSL_VERSION */ "%s linked: %s\n", h, h, #ifdef GSL_VERSION GSL_VERSION, #else /* GSL_VERSION */ GSL_MAJOR_VERSION, GSL_MINOR_VERSION, #endif /* GSL_VERSION */ h, gsl_version); #endif /* HAVE_LIBGSL */ rval->str = g_string_free(str, FALSE); return 0; } static int mx_show_source_view_search_path(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { const gchar * const *dirs; int i; GtkSourceLanguageManager *lm; GString *str; if (rval->str) { g_free(rval->str); } rval->str = NULL; str = g_string_new(""); lm = gtk_source_language_manager_get_default(); dirs = gtk_source_language_manager_get_search_path(lm); for (i = 0; dirs[i]; i++) { g_string_append_printf(str, "%s\n", dirs[i]); } rval->str = g_string_free(str, FALSE); return 0; } static int mxdraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } Draw(FALSE); return 0; } static void SetCaption(int modified) { char buf[1024], *file; getobj(Menulocal.obj, "ngp", 0, 0, NULL, &file); snprintf(buf, sizeof(buf), "%s%s - Ngraph", (modified) ? "*" : "", (file) ? file : _("Unsaved Graph")); gtk_window_set_title(GTK_WINDOW(TopLevel), buf); } static int mxmodified(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int modified; if (TopLevel == NULL) { error(obj, ERR_MENU_GUI); return 1; } modified = * (int *) argv[2]; if (modified) { Menulocal.modified |= modified; } else { Menulocal.modified = modified; } SetCaption(modified); set_modified_state(modified); return 0; } static int mx_focus_obj(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int n, i, *id_array; char *legend; struct objlist *lobj; struct narray iarray; legend = (char *) argv[2]; if (legend == NULL) { return 0; } arrayinit(&iarray, sizeof(int)); if (getobjilist(legend, &lobj, &iarray, FALSE, NULL)) { return 0; } n = arraynum(&iarray); if (n < 1) { arraydel(&iarray); return 0; } id_array = arraydata(&iarray); for (i = 0; i < n; i++) { Focus(lobj, id_array[i], TRUE); } arraydel(&iarray); return 0; } static int mx_unfocus_obj(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { UnFocus(); return 0; } static int mx_get_locale(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { const char *locale; if (rval->str) { g_free(rval->str); } rval->str = NULL; locale = n_getlocale(); if (locale) { rval->str = g_strdup(locale); } return 0; } static int mx_get_active(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (TopLevel) { rval->i = TRUE; } else { rval->i = FALSE; } return 0; } static int mx_addin_list_append(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int n, id, i; char *sarray, *name, *script, *description, *option, *argv2[2]; struct objlist *sa_obj; struct narray iarray; struct script *addin, *list; sarray = (char *) argv[2]; if (sarray == NULL) { return 0; } arrayinit(&iarray, sizeof(int)); if (getobjilist(sarray, &sa_obj, &iarray, FALSE, NULL)) { return 0; } if (g_strcmp0(chkobjectname(sa_obj), "sarray") != 0) { return 1; } n = arraynum(&iarray); if (n < 1) { arraydel(&iarray); return 0; } id = arraynget_int(&iarray, 0); if (getobj(sa_obj, "num", id, 0, NULL, &n) < 0) { return 0; } if (n < 4) { arraydel(&iarray); return 0; } addin = g_malloc0(sizeof(*addin)); if (addin == NULL) { return 1; } argv2[0] = (char *) &i; argv2[1] = NULL; i = 0; getobj(sa_obj, "get", id, 1, argv2, &script); if (! g_utf8_validate(script, -1, NULL)) { goto Err; } addin->script = g_strdup(script); i = 1; getobj(sa_obj, "get", id, 1, argv2, &name); if (! g_utf8_validate(name, -1, NULL)) { goto Err; } addin->name = g_strdup(name); i = 2; getobj(sa_obj, "get", id, 1, argv2, &description); if (! g_utf8_validate(description, -1, NULL)) { goto Err; } addin->description = g_strdup(description); i = 3; getobj(sa_obj, "get", id, 1, argv2, &option); if (! g_utf8_validate(option, -1, NULL)) { goto Err; } addin->option = g_strdup(option); addin->next = NULL; if (Menulocal.addin_list == NULL) { Menulocal.addin_list = addin; } else { for (list = Menulocal.addin_list; list != addin; list = list->next) { if (list->next == NULL) { list->next = addin; } } } arraydel(&iarray); return 0; Err: if (addin->script) { g_free(addin->script); } if (addin->name) { g_free(addin->name); } if (addin->description) { g_free(addin->description); } if (addin->option) { g_free(addin->option); } g_free(addin); return 0; } static int mx_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char code, *cstr, *layer; struct gra2cairo_local *local; local = (struct gra2cairo_local *)argv[2]; code = *(char *) (argv[3]); cstr = argv[5]; switch (code) { case 'I': layer = arraynget_str(&Menulocal.drawrable, 0); if (layer){ select_layer(layer); } break; case 'Z': gra2cairo_draw_path(local); select_layer(cstr); break; } if (_exeparent(obj, argv[1], inst, rval, argc, argv)) { return 1; } return 0; } static int mx_exeparent(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { return _exeparent(obj, argv[1], inst, rval, argc, argv); } static struct objtable gtkmenu[] = { {"init", NVFUNC, NEXEC, menuinit, NULL, 0}, {"done", NVFUNC, NEXEC, menudone, NULL, 0}, {"menu", NVFUNC, NREAD | NEXEC, menumenu, "s", 0}, {"ngp", NSTR, NREAD | NWRITE, NULL, NULL, 0}, {"fullpath_ngp", NSTR, NREAD | NWRITE, mxfullpathngp, NULL, 0}, {"data_head_lines", NINT, NREAD | NWRITE, mx_data_head_lines, NULL, 0}, {"modified", NBOOL, NREAD | NWRITE, mxmodified, NULL, 0}, {"dpi", NINT, NREAD | NWRITE, mxdpi, NULL, 0}, {"redraw_flag", NBOOL, NREAD | NWRITE, mxredrawflag, NULL, 0}, {"redraw_num", NINT, NREAD | NWRITE, mxredraw_num, NULL, 0}, {"use_opacity", NBOOL, NREAD | NWRITE, mxuse_opacity, NULL,0}, {"redraw", NVFUNC, NREAD | NEXEC, mxredraw, "", 0}, {"draw", NVFUNC, NREAD | NEXEC, mxdraw, "", 0}, {"flush", NVFUNC, NREAD | NEXEC, mxflush, "", 0}, {"clear", NVFUNC, NREAD | NEXEC, mxclear, "", 0}, {"focused", NSAFUNC, NREAD | NEXEC, mx_get_focused, "sa", 0}, {"print", NVFUNC, NREAD | NEXEC, mx_print, "bi", 0}, {"echo", NVFUNC, NREAD | NEXEC, mx_echo, "s", 0}, {"cat", NVFUNC, NREAD | NEXEC, mx_cat, "s", 0}, {"clear_info", NVFUNC, NREAD | NEXEC, mx_clear_info, "", 0}, {"get_accel_map", NSFUNC, NREAD | NEXEC, mx_get_accel_map, "", 0}, {"lib_version", NSFUNC, NREAD | NEXEC, mx_show_lib_version, NULL, 0}, {"source_view_search_path", NSFUNC, NREAD | NEXEC, mx_show_source_view_search_path, NULL, 0}, {"focus", NVFUNC, NREAD | NEXEC, mx_focus_obj, "o", 0}, {"unfocus", NVFUNC, NREAD | NEXEC, mx_unfocus_obj, "", 0}, {"locale", NSFUNC, NREAD | NEXEC, mx_get_locale, "", 0}, {"active", NBFUNC, NREAD | NEXEC, mx_get_active, "", 0}, {"addin_list_append", NVFUNC, NREAD | NEXEC, mx_addin_list_append, "o", 0}, {"_evloop", NVFUNC, 0, mx_evloop, NULL, 0}, {"_output", NVFUNC, 0, mx_output, NULL, 0}, {"_strwidth", NIFUNC, 0, mx_exeparent, NULL, 0}, {"_charascent", NIFUNC, 0, mx_exeparent, NULL, 0}, {"_chardescent", NIFUNC, 0, mx_exeparent, NULL, 0}, }; #define TBLNUM (sizeof(gtkmenu) / sizeof(*gtkmenu)) void * addmenu(void) { unsigned int i, j; struct menu_config *cfg; if (MenuConfigHash == NULL) { MenuConfigHash = nhash_new(); if (MenuConfigHash ==NULL) return NULL; for (i = 0; (cfg = MenuConfigArrray[i]); i++) { for (j = 0; cfg[j].name; j++) { if (nhash_set_ptr(MenuConfigHash, cfg[j].name, (void *) (cfg + j))) { nhash_free(MenuConfigHash); return NULL; } } } } return addobject(NAME, ALIAS, PARENT, NVERSION, TBLNUM, gtkmenu, ERRNUM, menuerrorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/ogra2cairofile.c0000644000175000017500000002042213070106167015261 00000000000000/* * $Id: ogra2cairofile.c,v 1.16 2009-11-16 09:13:05 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #ifdef CAIRO_HAS_WIN32_SURFACE #include #endif /* CAIRO_HAS_WIN32_SURFACE */ #include "mathfn.h" #include "object.h" #include "ioutil.h" #include "init.h" #include "x11gui.h" #include "ogra2cairo.h" #include "ogra2cairofile.h" #define NAME "gra2cairofile" #define PARENT "gra2cairo" #define OVERSION "1.00.00" #ifndef M_PI #define M_PI 3.141592 #endif char *surface_type[] = { "ps2", "ps3", "eps2", "eps3", "pdf", "svg1.1", "svg1.2", "png", #ifdef CAIRO_HAS_WIN32_SURFACE "emf", #endif /* CAIRO_HAS_WIN32_SURFACE */ NULL, }; static int gra2cairofile_init(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int dpi; struct gra2cairo_local *local; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; dpi = 72; if (_putobj(obj, "dpi", inst, &dpi) < 0) goto Err; if (_putobj(obj, "dpix", inst, &dpi) < 0) goto Err; if (_putobj(obj, "dpiy", inst, &dpi) < 0) goto Err; _getobj(obj, "_local", inst, &local); local->pixel_dot_x = local->pixel_dot_y = dpi / (DPI_MAX * 1.0); return 0; Err: local = gra2cairo_free(obj, inst); g_free(local); return 1; } static int gra2cairofile_done(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } #ifdef CAIRO_HAS_WIN32_SURFACE static cairo_surface_t * open_emf(int dpi, const char *fname) { HDC hdc; cairo_surface_t *surface; XFORM xform = {1, 0, 0, 1, 0, 0}; int disp_dpi; hdc = CreateEnhMetaFile(NULL, fname, NULL, NULL); if (hdc == NULL) { return NULL; } SetGraphicsMode(hdc, GM_ADVANCED); disp_dpi = GetDeviceCaps(hdc, LOGPIXELSX); xform.eM11 = xform.eM22 = 1.0 * disp_dpi / dpi; SetWorldTransform(hdc, &xform); surface = cairo_win32_printing_surface_create(hdc); StartPage(hdc); return surface; } static int close_emf(cairo_surface_t *surface) { HDC hdc; HENHMETAFILE emf; int r; hdc = cairo_win32_surface_get_dc(surface); cairo_surface_flush(surface); cairo_surface_copy_page(surface); cairo_surface_finish(surface); r = 1; EndPage(hdc); emf = CloseEnhMetaFile(hdc); if (emf == NULL) { return 1; } DeleteEnhMetaFile(emf); /* DeleteDC() is called in the cairo library */ return r; } #endif /* CAIRO_HAS_WIN32_SURFACE */ static cairo_t * create_cairo(struct objlist *obj, N_VALUE *inst, char *fname, int iw, int ih, int *err) { cairo_surface_t *ps; cairo_t *cairo; double w, h; int format, dpi, r; struct gra2cairo_local *local; #if WINDOWS fname = g_locale_from_utf8(fname, -1, NULL, NULL, NULL); #else /* WINDOWS */ fname = g_filename_from_utf8(fname, -1, NULL, NULL, NULL); #endif /* WINDOWS */ if (fname == NULL) { *err = CAIRO_STATUS_NO_MEMORY; return NULL; } *err = 0; _getobj(obj, "format", inst, &format); _getobj(obj, "dpi", inst, &dpi); _getobj(obj, "_local", inst, &local); w = iw * dpi / 25.4 / 100; h = ih * dpi / 25.4 / 100; switch (format) { case TYPE_PS2: ps = cairo_ps_surface_create(fname, w, h); cairo_ps_surface_restrict_to_level(ps, CAIRO_PS_LEVEL_2); cairo_ps_surface_set_eps(ps, FALSE); break; case TYPE_PS3: ps = cairo_ps_surface_create(fname, w, h); cairo_ps_surface_restrict_to_level(ps, CAIRO_PS_LEVEL_3); cairo_ps_surface_set_eps(ps, FALSE); break; case TYPE_EPS2: ps = cairo_ps_surface_create(fname, w, h); cairo_ps_surface_restrict_to_level(ps, CAIRO_PS_LEVEL_2); cairo_ps_surface_set_eps(ps, TRUE); break; case TYPE_EPS3: ps = cairo_ps_surface_create(fname, w, h); cairo_ps_surface_restrict_to_level(ps, CAIRO_PS_LEVEL_3); cairo_ps_surface_set_eps(ps, TRUE); break; case TYPE_PDF: ps = cairo_pdf_surface_create(fname, w, h); break; case TYPE_SVG1_1: ps = cairo_svg_surface_create(fname, w, h); cairo_svg_surface_restrict_to_version(ps, CAIRO_SVG_VERSION_1_1); break; case TYPE_SVG1_2: ps = cairo_svg_surface_create(fname, w, h); cairo_svg_surface_restrict_to_version(ps, CAIRO_SVG_VERSION_1_2); break; case TYPE_PNG: ps = cairo_image_surface_create(CAIRO_FORMAT_RGB24, w, h); break; #ifdef CAIRO_HAS_WIN32_SURFACE case TYPE_EMF: ps = open_emf(dpi, fname); if (ps == NULL) { g_free(fname); return NULL; } break; #endif /* CAIRO_HAS_WIN32_SURFACE */ default: ps = cairo_ps_surface_create(fname, w, h); } g_free(fname); r = cairo_surface_status(ps); if (r != CAIRO_STATUS_SUCCESS) { *err = r; cairo_surface_destroy(ps); return NULL; } cairo = cairo_create(ps); /* cairo_create() references target, so you can immediately call cairo_surface_destroy() on it */ cairo_surface_destroy(ps); r = cairo_status(cairo); if (r != CAIRO_STATUS_SUCCESS) { *err = r; cairo_destroy(cairo); return NULL; } switch (format) { case TYPE_PNG: cairo_set_source_rgb(cairo, 1, 1, 1); cairo_paint(cairo); cairo_new_path(cairo); break; } return cairo; } static int init_cairo(struct objlist *obj, N_VALUE *inst, struct gra2cairo_local *local, int w, int h) { char *fname; cairo_t *cairo; int t2p, r; _getobj(obj, "file", inst, &fname); if (fname == NULL) return CAIRO_STATUS_NULL_POINTER; cairo = create_cairo(obj, inst, fname, w, h, &r); if (cairo == NULL) { return r; } if (local->cairo) cairo_destroy(local->cairo); local->cairo = cairo; _getobj(obj, "text2path", inst, &t2p); local->text2path = t2p; return 0; } static int gra2cairofile_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char code, *fname; int *cpar, format, r; struct gra2cairo_local *local; cairo_surface_t *surface; local = (struct gra2cairo_local *)argv[2]; code = *(char *)(argv[3]); cpar = (int *)argv[4]; switch (code) { case 'I': r = init_cairo(obj, inst, local, cpar[3], cpar[4]); if (r) { _getobj(obj, "file", inst, &fname); error2(obj, r + 100, fname); return 1; } break; case 'E': _getobj(obj, "format", inst, &format); if (local->cairo) { switch (format) { case TYPE_PNG: gra2cairo_draw_path(local); _getobj(obj, "file", inst, &fname); if (fname == NULL) return 1; #if WINDOWS fname = g_locale_from_utf8(fname, -1, NULL, NULL, NULL); #else /* WINDOWS */ fname = g_filename_from_utf8(fname, -1, NULL, NULL, NULL); #endif /* WINDOWS */ if (fname == NULL) { error(obj, CAIRO_STATUS_NO_MEMORY + 100); return 1; } surface = cairo_get_target(local->cairo); r = cairo_surface_write_to_png(surface, fname); g_free(fname); if (r) { _getobj(obj, "file", inst, &fname); error2(obj, r + 100, fname); return 1; } break; #ifdef CAIRO_HAS_WIN32_SURFACE case TYPE_EMF: gra2cairo_draw_path(local); surface = cairo_get_target(local->cairo); r = close_emf(surface); if (r) { _getobj(obj, "file", inst, &fname); error2(obj, CAIRO_STATUS_WRITE_ERROR + 100, fname); return 1; } break; #endif /* CAIRO_HAS_WIN32_SURFACE */ } } break; } if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } static struct objtable gra2cairofile[] = { {"init", NVFUNC, NEXEC, gra2cairofile_init, NULL, 0}, {"done", NVFUNC, NEXEC, gra2cairofile_done, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, {"file", NSTR, NREAD | NWRITE, NULL, NULL,0}, {"text2path", NBOOL, NREAD | NWRITE, NULL, NULL,0}, {"format", NENUM, NREAD | NWRITE, NULL, surface_type, 0}, {"_output", NVFUNC, 0, gra2cairofile_output, NULL, 0}, {"_strwidth", NIFUNC, 0, gra2cairo_strwidth, NULL, 0}, {"_charascent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, {"_chardescent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, }; #define TBLNUM (sizeof(gra2cairofile) / sizeof(*gra2cairofile)) void * addgra2cairofile() /* addgra2cairofile() returns NULL on error */ { return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, gra2cairofile, Gra2CairoErrMsgNum, Gra2CairoErrMsgs, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/x11gui.c0000644000175000017500000007032013242772500013512 00000000000000/* * $Id: x11gui.c,v 1.41 2010-04-01 06:08:23 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include #include "object.h" #include "nstring.h" #include "ioutil.h" #include "gtk_widget.h" #include "gtk_combo.h" #include "ox11menu.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "x11commn.h" struct nGetOpenFileData { GtkWidget *widget, *chdir_cb; int ret; char *title; char **init_dir; const char *init_file; int chdir; char *ext; char **file; const char *button; int type; int mustexist; int overwrite; int multi; int changedir; }; static int add_buttons(GtkWidget *dlg, struct narray *array); void set_sensitivity_by_check_instance(GtkWidget *widget, gpointer user_data) { char *name; struct objlist *obj; int n; name = (char *) user_data; obj = chkobject(name); n = chkobjlastinst(obj); gtk_widget_set_sensitive(widget, n > 0); } static void dialog_destroyed_cb(GtkWidget *w, gpointer user_data) { ((struct DialogType *) user_data)->widget = NULL; } int ndialog_run(GtkWidget *dlg) { int lock_state, r; if (dlg == NULL) { return GTK_RESPONSE_CANCEL; } lock_state = DnDLock; r = gtk_dialog_run(GTK_DIALOG(dlg)); DnDLock = lock_state; return r; } int DialogExecute(GtkWidget *parent, void *dialog) { GtkWidget *dlg, *win_ptr, *btn; struct DialogType *data; gint res_id, lockstate; lockstate = DnDLock; DnDLock = TRUE; data = (struct DialogType *) dialog; if (data->widget && (data->parent != parent)) { #if 1 gtk_window_set_transient_for(GTK_WINDOW(data->widget), GTK_WINDOW(parent)); data->parent = parent; #else gtk_widget_destroy(data->widget); reset_event(); data->widget = NULL; #endif } if (data->widget == NULL) { dlg = gtk_dialog_new_with_buttons(_(data->resource), GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, _("_Cancel"), GTK_RESPONSE_CANCEL, NULL); gtk_window_set_resizable(GTK_WINDOW(dlg), TRUE); g_signal_connect(dlg, "delete-event", G_CALLBACK(gtk_true), data); g_signal_connect(dlg, "destroy", G_CALLBACK(dialog_destroyed_cb), data); data->parent = parent; data->widget = dlg; data->vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); data->show_cancel = TRUE; data->ok_button = _("_OK"); data->SetupWindow(dlg, data, TRUE); gtk_dialog_add_button(GTK_DIALOG(dlg), data->ok_button, GTK_RESPONSE_OK); if (! data->show_cancel) { btn = gtk_dialog_get_widget_for_response(GTK_DIALOG(dlg), GTK_RESPONSE_CANCEL); gtk_widget_hide(btn); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); } else { dlg = data->widget; data->SetupWindow(dlg, data, FALSE); } gtk_widget_hide(dlg); gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); data->widget = dlg; data->ret = IDLOOP; gtk_widget_show(dlg); win_ptr = get_current_window(); set_current_window(dlg); if (data->focus) gtk_widget_grab_focus(data->focus); while (data->ret == IDLOOP) { res_id = ndialog_run(dlg); if (res_id < 0) { switch (res_id) { case GTK_RESPONSE_OK: data->ret = IDOK; break; default: data->ret = IDCANCEL; break; } } else { data->ret = res_id; } if (data->CloseWindow) { data->CloseWindow(dlg, data); } } // gtk_widget_destroy(dlg); // data->widget = NULL; set_current_window(win_ptr); gtk_widget_hide(dlg); reset_event(); DnDLock = lockstate; return data->ret; } void message_beep(GtkWidget * parent) { if (parent) { GdkWindow *window; window = gtk_widget_get_window(parent); gdk_window_beep(window); } else { GdkDisplay *disp; disp = gdk_display_get_default(); if (disp) { gdk_display_beep(disp); } } // reset_event(); } static void set_dialog_position(GtkWidget *w, const int *x, const int *y) { if (x == NULL || y == NULL || *x < 0 || *y < 0) return; gtk_window_move(GTK_WINDOW(w), *x, *y); } static void get_dialog_position(GtkWidget *w, int *x, int *y) { if (x == NULL || y == NULL) return; gtk_window_get_position(GTK_WINDOW(w), x, y); if (*x < 0) *x = 0; if (*y < 0) *y = 0; } int message_box(GtkWidget * parent, const char *message, const char *title, int mode) { return markup_message_box(parent, message, title, mode, FALSE); } int markup_message_box(GtkWidget * parent, const char *message, const char *title, int mode, int markup) { GtkWidget *dlg; int data; GtkMessageType dlg_type; GtkButtonsType dlg_button; gint res_id; if (title == NULL) { title = _("Error"); } switch (mode) { case RESPONS_YESNOCANCEL: dlg_button = GTK_BUTTONS_CANCEL; dlg_type = GTK_MESSAGE_QUESTION; break; case RESPONS_YESNO: dlg_button = GTK_BUTTONS_YES_NO; dlg_type = GTK_MESSAGE_QUESTION; break; case RESPONS_ERROR: dlg_button = GTK_BUTTONS_OK; dlg_type = GTK_MESSAGE_ERROR; break; default: dlg_button = GTK_BUTTONS_OK; dlg_type = GTK_MESSAGE_INFO; } if (parent == NULL) parent = get_current_window(); dlg = gtk_message_dialog_new(GTK_WINDOW(parent), GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, dlg_type, dlg_button, "%.512s", message); if (markup) { gtk_message_dialog_set_markup(GTK_MESSAGE_DIALOG(dlg), message); } switch (mode) { case RESPONS_YESNOCANCEL: gtk_dialog_add_button(GTK_DIALOG(dlg), _("_No"), GTK_RESPONSE_NO); gtk_dialog_add_button(GTK_DIALOG(dlg), _("_Yes"), GTK_RESPONSE_YES); /* fall through */ case RESPONS_YESNO: gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_YES); break; } gtk_window_set_title(GTK_WINDOW(dlg), title); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); switch (res_id) { case GTK_RESPONSE_OK: data = IDYES; break; case GTK_RESPONSE_YES: data = IDYES; break; case GTK_RESPONSE_NO: data = IDNO; break; case GTK_RESPONSE_CANCEL: data = IDCANCEL; break; default: if ((mode == RESPONS_OK) || (mode == RESPONS_ERROR)) { data = IDOK; } else if (mode == RESPONS_YESNO) { data = IDNO; } else { data = IDCANCEL; } } gtk_widget_destroy(dlg); reset_event(); return data; } int DialogInput(GtkWidget * parent, const char *title, const char *mes, const char *init_str, struct narray *buttons, int *res_btn, char **s, int *x, int *y) { GtkWidget *dlg, *text; GtkBox *vbox; int data; gint res_id; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); } gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (mes) { GtkWidget *label; label = gtk_label_new(mes); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } text = create_text_entry(FALSE, TRUE); if (init_str) { gtk_entry_set_text(GTK_ENTRY(text), init_str); } gtk_box_pack_start(vbox, text, FALSE, FALSE, 5); set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { *s = g_strdup(gtk_entry_get_text(GTK_ENTRY(text))); data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } int DialogRadio(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int *r, int *x, int *y) { GtkWidget *dlg, *btn, **btn_ary; GtkBox *vbox; int data; gint res_id; char **d; int i, anum; d = arraydata(array); anum = arraynum(array); btn_ary = g_malloc(anum * sizeof(*btn_ary)); if (btn_ary == NULL) return IDCANCEL; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (caption) { GtkWidget *label; label = gtk_label_new(caption); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } btn = NULL; for (i = 0; i < anum; i++) { btn = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(btn), d[i]); gtk_box_pack_start(vbox, btn, FALSE, FALSE, 2); btn_ary[i] = btn; gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(btn), i == *r); } set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { *r = -1; for (i = 0; i < anum; i++) { if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(btn_ary[i]))) { *r = i; break; } } data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } g_free(btn_ary); get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } static int add_buttons(GtkWidget *dlg, struct narray *array) { char **d; int i, anum; if (array == NULL) { return 1; } d = arraydata(array); anum = arraynum(array); if (anum < 1) { return 1; } for (i = 0; i < anum; i++) { if (d[i] && g_utf8_validate(d[i], -1, NULL)) { gtk_dialog_add_button(GTK_DIALOG(dlg), d[i], i + 1); } } return 0; } int DialogButton(GtkWidget *parent, const char *title, const char *caption, struct narray *buttons, int *x, int *y) { GtkWidget *dlg; gint res_id; dlg = gtk_dialog_new(); if (add_buttons(dlg, buttons)) { return 1; } if (title && g_utf8_validate(title, -1, NULL)) { gtk_window_set_title(GTK_WINDOW(dlg), title); } if (caption && g_utf8_validate(caption, -1, NULL)) { GtkWidget *box, *label; box = gtk_dialog_get_content_area(GTK_DIALOG(dlg)); label = gtk_label_new(caption); gtk_box_pack_start(GTK_BOX(box), label, TRUE, TRUE, 4); } gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return res_id; } int DialogCombo(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int sel, char **r, int *x, int *y) { GtkWidget *dlg, *combo; GtkBox *vbox; int data; gint res_id; char **d; int i, anum; d = arraydata(array); anum = arraynum(array); *r = NULL; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (caption) { GtkWidget *label; label = gtk_label_new(caption); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } combo = combo_box_create(); for (i = 0; i < anum; i++) { combo_box_append_text(combo, d[i]); } if (sel < 0 || sel >= anum) { sel = 0; } combo_box_set_active(combo, sel); gtk_box_pack_start(vbox, combo, FALSE, FALSE, 2); set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { i = combo_box_get_active(combo); if (i >= 0) { *r = g_strdup(d[i]); } data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } int DialogComboEntry(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int sel, char **r, int *x, int *y) { GtkWidget *dlg, *combo; GtkBox *vbox; int data; gint res_id; char **d; const char *s; int i, anum; d = arraydata(array); anum = arraynum(array); *r = NULL; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (caption) { GtkWidget *label; label = gtk_label_new(caption); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } combo = combo_box_entry_create(); for (i = 0; i < anum; i++) { combo_box_append_text(combo, d[i]); } if (sel >= 0 && sel < anum) { combo_box_set_active(combo, sel); } gtk_box_pack_start(vbox, combo, FALSE, FALSE, 2); set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { s = combo_box_entry_get_text(combo); if (s) { *r = g_strdup(s); } else { *r = NULL; } data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } int DialogSpinEntry(GtkWidget *parent, const char *title, const char *caption, double min, double max, double inc, struct narray *buttons, int *res_btn, double *r, int *x, int *y) { GtkWidget *dlg, *spin; GtkBox *vbox; int data, n; gint res_id; double prec; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (caption) { GtkWidget *label; label = gtk_label_new(caption); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } if (inc == 0) inc = 1; spin = gtk_spin_button_new_with_range(min, max, inc); gtk_spin_button_set_numeric(GTK_SPIN_BUTTON(spin), TRUE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(spin), *r); gtk_box_pack_start(vbox, spin, FALSE, FALSE, 2); gtk_entry_set_activates_default(GTK_ENTRY(spin), TRUE); prec = log10(fabs(inc)); if (prec < 0) { n = ceil(- prec); } else { n = 0; } gtk_spin_button_set_digits(GTK_SPIN_BUTTON(spin), n); set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { *r = gtk_spin_button_get_value(GTK_SPIN_BUTTON(spin)); data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } int DialogCheck(GtkWidget *parent, const char *title, const char *caption, struct narray *array, struct narray *buttons, int *res_btn, int *r, int *x, int *y) { GtkWidget *dlg, *btn, **btn_ary; GtkBox *vbox; int data; gint res_id; char **d; int i, anum; d = arraydata(array); anum = arraynum(array); btn_ary = g_malloc(anum * sizeof(*btn_ary)); if (btn_ary == NULL) return IDCANCEL; dlg = gtk_dialog_new_with_buttons(title, GTK_WINDOW(parent), #if GTK_CHECK_VERSION(3, 12, 0) && USE_HEADER_BAR GTK_DIALOG_USE_HEADER_BAR | #endif GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, NULL, NULL); if (add_buttons(dlg, buttons)) { gtk_dialog_add_buttons(GTK_DIALOG(dlg), _("_Cancel"), GTK_RESPONSE_CANCEL, _("_OK"), GTK_RESPONSE_OK, NULL); } gtk_dialog_set_default_response(GTK_DIALOG(dlg), GTK_RESPONSE_OK); gtk_window_set_resizable(GTK_WINDOW(dlg), FALSE); vbox = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dlg))); if (caption) { GtkWidget *label; label = gtk_label_new(caption); gtk_box_pack_start(vbox, label, FALSE, FALSE, 5); } btn = NULL; for (i = 0; i < anum; i++) { btn = gtk_check_button_new_with_mnemonic(d[i]); gtk_box_pack_start(vbox, btn, FALSE, FALSE, 2); btn_ary[i] = btn; } for (i = 0; i < anum; i++) { gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(btn_ary[i]), r[i]); } set_dialog_position(dlg, x, y); gtk_widget_show_all(dlg); res_id = ndialog_run(dlg); if (res_id > 0 || res_id == GTK_RESPONSE_OK) { for (i = 0; i < anum; i++) { r[i] = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(btn_ary[i])); } data = IDOK; } else { data = IDCANCEL; } if (buttons && res_btn) { *res_btn = res_id; } g_free(btn_ary); get_dialog_position(dlg, x, y); gtk_widget_destroy(dlg); reset_event(); return data; } static void free_str_list(GSList *top) { int i, n; GSList *list; n = g_slist_length(top); for (i = 0, list = top; i < n; i++, list = list->next) { g_free(list->data); } g_slist_free(top); } static void fsok(GtkWidget *dlg, struct nGetOpenFileData *data) { char *file, *file2, **farray; const char *filter_name; int i, k, len, n; GStatBuf buf; GSList *top, *list; GtkFileFilter *filter; top = gtk_file_chooser_get_filenames(GTK_FILE_CHOOSER(dlg)); filter = gtk_file_chooser_get_filter(GTK_FILE_CHOOSER(dlg)); if (filter) { filter_name = gtk_file_filter_get_name(filter); } else { filter_name = NULL; } if (filter_name == NULL || strcmp(filter_name, _("All")) == 0) { data->ext = NULL; } n = g_slist_length(top); farray = g_malloc(sizeof(*farray) * (n + 1)); if (farray == NULL) { free_str_list(top); return; } data->file = farray; k = 0; for (list = top; list; list = list->next) { char *tmp; tmp = (char *) list->data; if (tmp == NULL || strlen(tmp) < 1) { message_beep(TopLevel); continue; } file = get_utf8_filename(tmp); for (i = strlen(file) - 1; (i > 0) && (file[i] != '/') && (file[i] != '.'); i--); if ((file[i] != '.') && data->ext) { len = strlen(data->ext) + 1; } else { len = 0; } if (len) { file2 = g_strdup_printf("%s.%s", file, data->ext); g_free(file); } else { file2 = file; } if (file2) { if (data->mustexist) { if ((nstat(file2, &buf) != 0) || ((buf.st_mode & S_IFMT) != S_IFREG) || (naccess(file2, R_OK) != 0)) { message_beep(TopLevel); error22(NULL, 0, "I/O error", file2); g_free(file2); continue; } } else { if ((nstat(file2, &buf) == 0) && ((buf.st_mode & S_IFMT) != S_IFREG)) { message_beep(TopLevel); error22(NULL, 0, "I/O error", file2); g_free(file2); continue; } } farray[k] = file2; k++; } } if (k == 0) return; if (data->changedir && k > 0) { data->chdir = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(data->chdir_cb)); if (data->chdir && data->init_dir) { char *dir; g_free(*(data->init_dir)); dir = g_path_get_dirname(farray[0]); *(data->init_dir) = dir; } } farray[k] = NULL; free_str_list(top); data->ret = IDOK; } static void file_dialog_set_current_neme(GtkWidget *dlg, const char *full_name) { char *name; if (dlg == NULL || full_name == NULL) return; name = getbasename(full_name); if (name) { gtk_file_chooser_set_current_name(GTK_FILE_CHOOSER(dlg), name); g_free(name); } } static int check_overwrite(GtkWidget *parent, const char *filename) { int r; char *buf; if (filename == NULL || naccess(filename, W_OK)) return 0; buf = g_strdup_printf(_("`%s'\n\nOverwrite existing file?"), CHK_STR(filename)); r = message_box(parent, buf, "Driver", RESPONS_YESNO); g_free(buf); return r != IDYES; } static char * get_filename_with_ext(const char *basename, const char *ext) { char *filename; int len, ext_len, i; if (basename == NULL) { return NULL; } if (ext == NULL || ext[0] == '\0') { return g_strdup(basename); } ext_len = strlen(ext); len = strlen(basename); i = len - ext_len; if (i > 0 && g_strcmp0(basename + i, ext) == 0 && basename[i - 1] == '.') { return g_strdup(basename); } filename = g_strdup_printf("%s%s%s", basename, (basename[len -1] == '.') ? "" : ".", ext); return filename; } static int FileSelectionDialog(GtkWidget *parent, struct nGetOpenFileData *data) { GtkWidget *dlg, *rc; GtkFileFilter *filter; char *fname; dlg = gtk_file_chooser_dialog_new(data->title, GTK_WINDOW((parent) ? parent : TopLevel), data->type, _("_Cancel"), GTK_RESPONSE_CANCEL, data->button, GTK_RESPONSE_ACCEPT, NULL); gtk_file_chooser_set_local_only(GTK_FILE_CHOOSER(dlg), TRUE); rc = gtk_check_button_new_with_mnemonic(_("_Change current directory")); gtk_file_chooser_set_extra_widget(GTK_FILE_CHOOSER(dlg), rc); data->chdir_cb = rc; gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dlg), data->multi); data->widget = dlg; if (data->ext) { char *filter_str, *filter_name, *ext_name; filter_str = g_strdup_printf("*.%s", data->ext); ext_name = g_ascii_strup(data->ext, -1); filter_name = g_strdup_printf(_("%s file (*.%s)"), ext_name, data->ext); g_free(ext_name); filter = gtk_file_filter_new(); gtk_file_filter_add_pattern(filter, filter_str); gtk_file_filter_set_name(filter, filter_name); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dlg), filter); g_free(filter_str); g_free(filter_name); filter = gtk_file_filter_new(); gtk_file_filter_add_pattern(filter, "*"); gtk_file_filter_set_name(filter, _("All")); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dlg), filter); } else { filter = gtk_file_filter_new(); gtk_file_filter_add_pattern(filter, "*"); gtk_file_filter_set_name(filter, _("All")); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dlg), filter); filter = gtk_file_filter_new(); gtk_file_filter_add_pattern(filter, "*.txt"); gtk_file_filter_set_name(filter, "Text file (*.txt)"); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dlg), filter); filter = gtk_file_filter_new(); gtk_file_filter_add_pattern(filter, "*.dat"); gtk_file_filter_set_name(filter, "Data file (*.dat)"); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dlg), filter); } if (data->init_dir && *(data->init_dir)) { gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dlg), *(data->init_dir)); } gtk_widget_show_all(dlg); if (data->changedir && data->init_dir) { gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(data->chdir_cb), data->chdir); } else { gtk_widget_hide(data->chdir_cb); } fname = get_filename_with_ext(data->init_file, data->ext); if (fname) { if (data->type == GTK_FILE_CHOOSER_ACTION_SAVE) { #if WINDOWS char *tmp; tmp = g_locale_from_utf8(fname, -1, NULL, NULL, NULL); if (tmp) { file_dialog_set_current_neme(dlg, tmp); g_free(tmp); } #else /* WINDOWS */ file_dialog_set_current_neme(dlg, fname); #endif /* WINDOWS */ } else { gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dlg), fname); } g_free(fname); } data->ret = IDCANCEL; while (1) { if (ndialog_run(dlg) != GTK_RESPONSE_ACCEPT) break; fsok(dlg, data); if (data->ret == IDOK && data->type == GTK_FILE_CHOOSER_ACTION_SAVE) { file_dialog_set_current_neme(dlg, data->file[0]); if (! data->overwrite && check_overwrite(dlg, data->file[0])) { data->ret = IDCANCEL; continue; } } break; } gtk_widget_destroy(dlg); reset_event(); data->widget = NULL; return data->ret; } int nGetOpenFileNameMulti(GtkWidget * parent, char *title, char *defext, char **init_dir, const char *init_file, char ***file, int chd) { int ret; struct nGetOpenFileData data; data.title = title; data.init_dir = init_dir; data.init_file = init_file; data.file = NULL; data.chdir = chd; data.ext = defext; data.mustexist = TRUE; data.overwrite = FALSE; data.multi = TRUE; data.changedir = TRUE; data.type = GTK_FILE_CHOOSER_ACTION_OPEN; data.button = _("_Open"); ret = FileSelectionDialog(parent, &data); if (ret == IDOK) { *file = data.file; if (data.chdir && init_dir && nchdir(*init_dir)) { ErrorMessage(); } } else { *file = NULL; } return ret; } int nGetOpenFileName(GtkWidget *parent, char *title, char *defext, char **init_dir, const char *init_file, char **file, int exist, int chd) { struct nGetOpenFileData data; int ret; data.title = title; data.init_dir = init_dir; data.init_file = init_file; data.file = NULL; data.chdir = chd; data.ext = defext; data.mustexist = exist; data.overwrite = FALSE; data.multi = FALSE; data.changedir = TRUE; data.type = (exist) ? GTK_FILE_CHOOSER_ACTION_OPEN : GTK_FILE_CHOOSER_ACTION_SAVE; data.button = _("_Open"); ret = FileSelectionDialog(parent, &data); if (ret == IDOK) { *file = data.file[0]; g_free(data.file); if (data.chdir && init_dir && nchdir(*init_dir)) { ErrorMessage(); } } else { *file = NULL; } return ret; } int nGetSaveFileName(GtkWidget * parent, char *title, char *defext, char **init_dir, const char *init_file, char **file, int overwrite, int chd) { struct nGetOpenFileData data; int ret; data.title = title; data.init_dir = init_dir; data.init_file = init_file; data.file = NULL; data.chdir = chd; data.ext = defext; data.mustexist = FALSE; data.overwrite = overwrite; data.multi = FALSE; data.changedir = TRUE; data.type = GTK_FILE_CHOOSER_ACTION_SAVE, data.button = _("_Save"); ret = FileSelectionDialog(parent, &data); if (ret == IDOK) { *file = data.file[0]; g_free(data.file); if (data.chdir && init_dir && nchdir(*init_dir)) { ErrorMessage(); } } else { *file = NULL; } return ret; } void get_window_geometry(GtkWidget *win, gint *x, gint *y, gint *w, gint *h) { gtk_window_get_size(GTK_WINDOW(win), w, h); gtk_window_get_position(GTK_WINDOW(win), x, y); } ngraph-gtk-6.08.00/src/gtk/gtk_action.h0000644000175000017500000000030213070106167014513 00000000000000#ifndef GTK_ACTION_HEADER #define GTK_ACTION_HEADER #if USE_APP_MENU GtkApplication *create_application_window(GtkWidget **popup); #endif /* USE_GTK_BUILDER */ #endif /* GTK_ACTION_HEADER */ ngraph-gtk-6.08.00/src/gtk/create_completion_info.rb0000644000175000017500000000344413242772500017267 00000000000000# -*- coding: utf-8 -*- class CompletionInfo DataTypeFunc = 0 DataTypeConst = 1 def initialize(func_file, const_file) @func_data = [] @const_data = [] load_data(DataTypeFunc, func_file, @func_data) load_data(DataTypeConst, const_file, @const_data) end def func_struct(info) function = info[0].sub(/\(.+\)/, '()') args = ($&) ? $&.gsub(/[()]/, '') : "" func_name = function.split("(")[0] lfunc = func_name.downcase title = "#{func_name}(#{args})" info_text = info[1].gsub('"', '\\"') %Q!{"#{lfunc}", "#{function}", "#{func_name}", N_("#{title}\\n#{info_text}"), NULL},! end def const_struct(info) info_text = info[1].gsub('"', '\\"') %Q!{"#{info[0].downcase}", "#{info[0]}", NULL, N_("#{info[0]}\\n#{info_text}"), NULL},! end def load_data(type, file, ary) File.open(file, "r:utf-8") { |info_file| info_file.each { |l| info = l.chomp.split(/\t+/) data = if (type == DataTypeFunc) func_struct(info) else const_struct(info) end ary.push(data) } } ary.sort! end def save_sruct(type, data, c_file) c_file.puts("struct completion_info completion_info_#{type}[] = {") data.each {|info| c_file.puts(info) } c_file.puts("{NULL, NULL, NULL, NULL}") c_file.puts("};") end def save_data(filename) File.open(filename, "w:utf-8") { |c_file| c_file.puts('/* -*- Mode: C; coding: utf-8 -*- */') c_file.puts('#include "gtk_common.h"') c_file.puts('#include "completion_info.h"') save_sruct("func", @func_data, c_file) save_sruct("const", @const_data, c_file) } end end completion_info = CompletionInfo.new(ARGV[0], ARGV[1]) completion_info.save_data(ARGV[2]) ngraph-gtk-6.08.00/src/gtk/x11graph.h0000644000175000017500000000330113070106167014026 00000000000000/* * $Id: x11graph.h,v 1.3 2009-06-09 06:38:53 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef X11GRAPH_HEADER void CmGraphQuit(void *w, gpointer client_data); void CmGraphNewMenu(void *w, gpointer client_data); void CmGraphHistory(GtkRecentChooser *w, gpointer client_data); void CmGraphLoad(void *w, gpointer client_data); void CmGraphSave(void *w, gpointer client_data); void CmGraphOverWrite(void *w, gpointer client_data); void CmGraphShell(void *w, gpointer client_data); void CmGraphDirectory(void *w, gpointer client_data); void CmHelpHelp(void *w, gpointer client_data); void CmHelpAbout(void *w, gpointer client_data); void CmGraphSwitch(void *w, gpointer client_data); void CmGraphPage(void *w, gpointer client_data); int set_paper_type(int w, int h); enum LOAD_PATH_TYPE { LOAD_PATH_UNCHANGE, LOAD_PATH_FULL, LOAD_PATH_BASE, }; extern char *LoadPathStr[]; #endif /* X11GRAPH_HEADER */ ngraph-gtk-6.08.00/src/gtk/x11opt.c0000644000175000017500000014511213362760221013532 00000000000000/* * $Id: x11opt.c,v 1.81 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include "object.h" #include "ioutil.h" #include "nstring.h" #include "nconfig.h" #include "odraw.h" #include "gtk_liststore.h" #include "gtk_subwin.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "x11gui.h" #include "x11dialg.h" #include "ox11menu.h" #include "x11menu.h" #include "x11file.h" #include "x11graph.h" #include "x11view.h" #include "x11lgnd.h" #include "x11opt.h" #include "x11commn.h" #include "x11cood.h" #include "x11info.h" #define MESSAGE_BUF_SIZE 4096 #define WIN_SIZE_MIN 100 #define WIN_SIZE_MAX 2048 #define GRID_MAX 1000 static void DefaultDialogSetup(GtkWidget *wi, void *data, int makewidget) { struct DefaultDialog *d; GtkWidget *w; d = (struct DefaultDialog *) data; if (makewidget) { w = gtk_check_button_new_with_mnemonic(_("_Viewer")); d->viewer = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_External Viewer")); d->external_viewer = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_Font aliases")); d->fonts = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_External Driver")); d->external_driver = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_Add-in Script")); d->addin_script = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); w = gtk_check_button_new_with_mnemonic(_("_Miscellaneous")); d->misc = w; gtk_box_pack_start(GTK_BOX(d->vbox), w, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->viewer), FALSE); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->external_viewer), FALSE); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->external_driver), FALSE); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->addin_script), FALSE); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->misc), FALSE); } static int save_config(int type) { if (!CheckIniFile()) { return 1; } if (type & SAVE_CONFIG_TYPE_X11MENU) { menu_save_config(type); } if (type & SAVE_CONFIG_TYPE_FONTS) { gra2cairo_save_config(); } return 0; } static void DefaultDialogClose(GtkWidget *win, void *data) { struct DefaultDialog *d; unsigned int i; int ret, type; struct { GtkWidget *btn; enum SAVE_CONFIG_TYPE type; } btns[] = { {NULL, SAVE_CONFIG_TYPE_VIEWER}, {NULL, SAVE_CONFIG_TYPE_EXTERNAL_DRIVER}, {NULL, SAVE_CONFIG_TYPE_ADDIN_SCRIPT}, {NULL, SAVE_CONFIG_TYPE_MISC}, {NULL, SAVE_CONFIG_TYPE_EXTERNAL_VIEWER}, {NULL, SAVE_CONFIG_TYPE_FONTS}, }; d = (struct DefaultDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; btns[0].btn = d->viewer; btns[1].btn = d->external_driver; btns[2].btn = d->addin_script; btns[3].btn = d->misc; btns[4].btn = d->external_viewer; btns[5].btn = d->fonts; type = 0; for (i = 0; i < sizeof(btns) / sizeof(*btns); i++) { if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(btns[i].btn))) { type |= btns[i].type; } } if (save_config(type)) { d->ret = ret; return; } d->ret = ret; } void DefaultDialog(struct DefaultDialog *data) { data->SetupWindow = DefaultDialogSetup; data->CloseWindow = DefaultDialogClose; } static void active_script_changed(GtkComboBox *widget, gpointer user_data) { struct SetScriptDialog *d; struct script *addin; int i, n; d = (struct SetScriptDialog *) user_data; n = gtk_combo_box_get_active(widget); if (n < 1) { gtk_entry_set_text(GTK_ENTRY(d->name), ""); gtk_entry_set_text(GTK_ENTRY(d->script), ""); gtk_entry_set_text(GTK_ENTRY(d->option), ""); gtk_entry_set_text(GTK_ENTRY(d->description), ""); return; } addin = Menulocal.addin_list; for (i = 0; i < n - 1; i++) { if (addin == NULL) { return; } addin = addin->next; } gtk_entry_set_text(GTK_ENTRY(d->name), CHK_STR(addin->name)); gtk_entry_set_text(GTK_ENTRY(d->script), CHK_STR(addin->script)); gtk_entry_set_text(GTK_ENTRY(d->option), CHK_STR(addin->option)); gtk_entry_set_text(GTK_ENTRY(d->description), CHK_STR(addin->description)); return; } static void remove_char(char *str, int c) { int i, j, n; if (str == NULL) { return; } n = strlen(str); for (i = 0; i < n; i++) { if (str[i] == c) { for (j = i; j < n; j++) { str[j] = str[j + 1]; } n--; } } } static void SetScriptDialogSetupItem(GtkWidget *w, struct SetScriptDialog *d) { struct script *addin; char *title; combo_box_clear(d->addins); combo_box_append_text(d->addins, "Custom"); if (Menulocal.addin_list == NULL) { set_widget_sensitivity_with_label(d->addins, FALSE); } else { set_widget_sensitivity_with_label(d->addins, TRUE); for (addin = Menulocal.addin_list; addin; addin = addin->next) { title = g_strdup(addin->name); if (title) { remove_char(title, '_'); combo_box_append_text(d->addins, title); g_free(title); } } active_script_changed(GTK_COMBO_BOX(d->addins), d); } if (d->Script->name) { combo_box_set_active(d->addins, 0); gtk_entry_set_text(GTK_ENTRY(d->name), CHK_STR(d->Script->name)); gtk_entry_set_text(GTK_ENTRY(d->script), CHK_STR(d->Script->script)); gtk_entry_set_text(GTK_ENTRY(d->option), CHK_STR(d->Script->option)); gtk_entry_set_text(GTK_ENTRY(d->description), CHK_STR(d->Script->description)); } else { combo_box_set_active(d->addins, 1); } } static void SetScriptDialogBrowse(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { char *file; if (nGetOpenFileName(TopLevel, _("Add-in Script"), "nsc", NULL, NULL, &file, TRUE, FALSE) == IDOK) { entry_set_filename(GTK_WIDGET(w), file); } g_free(file); } static void SetScriptDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct SetScriptDialog *d; int i; d = (struct SetScriptDialog *) data; if (makewidget) { table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Add-in:"), TRUE, i++); g_signal_connect(w, "changed", G_CALLBACK(active_script_changed), d); d->addins = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Name:"), TRUE, i++); d->name = w; w = create_file_entry_with_cb(G_CALLBACK(SetScriptDialogBrowse), NULL); add_widget_to_table(table, w, _("_Script file:"), TRUE, i++); d->script = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Option:"), TRUE, i++); d->option = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Description:"), TRUE, i++); d->description = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } SetScriptDialogSetupItem(wi, d); } static int set_scrpt_option(GtkWidget *entry, char **opt, char *msg) { const char *buf; char *buf2; buf = gtk_entry_get_text(GTK_ENTRY(entry)); if (msg && strlen(buf) == 0) { message_box(NULL, msg, NULL, RESPONS_OK); return 1; } buf2 = g_strdup(buf); if (buf2) { g_free(*opt); *opt = buf2; } return 0; } static int set_scrpt_file(GtkWidget *entry, char **opt, char *msg) { char *buf; buf = entry_get_filename(entry); if (buf == NULL) { return 1; } if (msg && strlen(buf) == 0) { message_box(NULL, msg, NULL, RESPONS_OK); g_free(buf); return 1; } g_free(*opt); *opt = buf; return 0; } static void SetScriptDialogClose(GtkWidget *w, void *data) { int ret; struct SetScriptDialog *d; d = (struct SetScriptDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; if (set_scrpt_option(d->name, &(d->Script->name), _("Please specify script name."))) { return; } if (set_scrpt_file(d->script, &(d->Script->script), _("Please specify script file name."))) { return; } if (set_scrpt_option(d->option, &(d->Script->option), NULL)) { return; } if (set_scrpt_option(d->description, &(d->Script->description), _("Please specify script description."))) { return; } d->ret = ret; } void SetScriptDialog(struct SetScriptDialog *data, struct script *sc) { data->SetupWindow = SetScriptDialogSetup; data->CloseWindow = SetScriptDialogClose; data->Script = sc; } static void PrefScriptDialogSetupItem(struct PrefScriptDialog *d) { struct script *fcur; GtkTreeIter iter; list_store_clear(d->list); fcur = Menulocal.scriptroot; while (fcur) { list_store_append(d->list, &iter); list_store_set_string(d->list, &iter, 0, fcur->name); list_store_set_string(d->list, &iter, 1, fcur->script); list_store_set_string(d->list, &iter, 2, fcur->description); fcur = fcur->next; } } static void script_free(struct script *fdel) { g_free(fdel->name); g_free(fdel->script); g_free(fdel->description); g_free(fdel->option); g_free(fdel); } static void script_init(struct script *fnew) { fnew->next = NULL; fnew->name = NULL; fnew->script = NULL; fnew->option = NULL; fnew->description = NULL; } #define LIST_TYPE script #define LIST_ROOT Menulocal.scriptroot #define SET_DIALOG DlgSetScript #define LIST_FREE script_free #define LIST_INIT script_init #define CREATE_NAME(a, c) a ## Script ## c #include "x11opt_proto.h" static void PrefScriptDialogSetup(GtkWidget *wi, void *data, int makewidget) { struct PrefScriptDialog *d; n_list_store list[] = { {N_("name"), G_TYPE_STRING, TRUE, FALSE, NULL}, {N_("file"), G_TYPE_STRING, TRUE, FALSE, NULL}, {N_("description"), G_TYPE_STRING, TRUE, FALSE, NULL}, }; d = (struct PrefScriptDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); PrefScriptDialogCreateWidgets(d, NULL, sizeof(list) / sizeof(*list), list); gtk_window_set_default_size(GTK_WINDOW(wi), 400, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } PrefScriptDialogSetupItem(d); } static void PrefScriptDialogClose(GtkWidget *w, void *data) { struct PrefScriptDialog *d; d = (struct PrefScriptDialog *) data; switch (d->ret) { case IDSAVE: save_config(SAVE_CONFIG_TYPE_ADDIN_SCRIPT); /* fall through */ case IDOK: create_addin_menu(); break; } } void PrefScriptDialog(struct PrefScriptDialog *data) { data->SetupWindow = PrefScriptDialogSetup; data->CloseWindow = PrefScriptDialogClose; } static void SetDriverDialogSetupItem(GtkWidget *w, struct SetDriverDialog *d) { gtk_entry_set_text(GTK_ENTRY(d->name), CHK_STR(d->Driver->name)); gtk_entry_set_text(GTK_ENTRY(d->driver), CHK_STR(d->Driver->driver)); gtk_entry_set_text(GTK_ENTRY(d->option), CHK_STR(d->Driver->option)); gtk_entry_set_text(GTK_ENTRY(d->ext), CHK_STR(d->Driver->ext)); } static void SetDriverDialogBrowse(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { char *file; struct SetDriverDialog *d; d = (struct SetDriverDialog *) user_data; if (nGetOpenFileName(d->widget, _("External Driver"), NULL, NULL, NULL, &file, TRUE, FALSE) == IDOK) { entry_set_filename(GTK_WIDGET(w), file); } g_free(file); } static void SetDriverDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct SetDriverDialog *d; int i; d = (struct SetDriverDialog *) data; if (makewidget) { table = gtk_grid_new(); i = 0; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Name:"), TRUE, i++); d->name = w; w = create_file_entry_with_cb(G_CALLBACK(SetDriverDialogBrowse), d); add_widget_to_table(table, w, _("_Driver:"), TRUE, i++); d->driver = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Option:"), TRUE, i++); d->option = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Extension:"), TRUE, i++); d->ext = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } SetDriverDialogSetupItem(wi, d); } static void SetDriverDialogClose(GtkWidget *w, void *data) { const char *buf; char *buf2; int ret; struct SetDriverDialog *d; d = (struct SetDriverDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; buf = gtk_entry_get_text(GTK_ENTRY(d->name)); if (strlen(buf) == 0) { message_box(d->widget, _("Please specify driver name."), NULL, RESPONS_OK); return; } buf2 = g_strdup(buf); if (buf2) { g_free(d->Driver->name); d->Driver->name = buf2; } buf2 = entry_get_filename(d->driver); if (buf2) { g_free(d->Driver->driver); d->Driver->driver = buf2; } buf = gtk_entry_get_text(GTK_ENTRY(d->ext)); buf2 = g_strdup(buf); if (buf2) { g_free(d->Driver->ext); d->Driver->ext = buf2; } buf = gtk_entry_get_text(GTK_ENTRY(d->option)); buf2 = g_strdup(buf); if (buf2) { g_free(d->Driver->option); d->Driver->option = buf2; } d->ret = ret; } void SetDriverDialog(struct SetDriverDialog *data, struct extprinter *prn) { data->SetupWindow = SetDriverDialogSetup; data->CloseWindow = SetDriverDialogClose; data->Driver = prn; } static void PrefDriverDialogSetupItem(struct PrefDriverDialog *d) { struct extprinter *fcur; GtkTreeIter iter; list_store_clear(d->list); fcur = Menulocal.extprinterroot; while (fcur) { list_store_append(d->list, &iter); list_store_set_string(d->list, &iter, 0, fcur->name); fcur = fcur->next; } } static void extprinter_free(struct extprinter *fdel) { g_free(fdel->name); g_free(fdel->driver); g_free(fdel->option); g_free(fdel->ext); g_free(fdel); } static void extprinter_init(struct extprinter *fnew) { fnew->next = NULL; fnew->name = NULL; fnew->driver = NULL; fnew->option = NULL; fnew->ext = NULL; } #define LIST_TYPE extprinter #define LIST_ROOT Menulocal.extprinterroot #define SET_DIALOG DlgSetDriver #define LIST_FREE extprinter_free #define LIST_INIT extprinter_init #define CREATE_NAME(a, c) a ## Driver ## c #include "x11opt_proto.h" static void PrefDriverDialogSetup(GtkWidget *wi, void *data, int makewidget) { struct PrefDriverDialog *d; n_list_store list[] = { {N_("Driver"), G_TYPE_STRING, TRUE, FALSE, NULL}, }; d = (struct PrefDriverDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); PrefDriverDialogCreateWidgets(d, NULL, sizeof(list) / sizeof(*list), list); gtk_window_set_default_size(GTK_WINDOW(wi), 400, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } PrefDriverDialogSetupItem(d); } static void PrefDriverDialogClose(GtkWidget *w, void *data) { struct PrefDriverDialog *d; d = (struct PrefDriverDialog *) data; if (d->ret == IDSAVE) { save_config(SAVE_CONFIG_TYPE_EXTERNAL_DRIVER); } } void PrefDriverDialog(struct PrefDriverDialog *data) { data->SetupWindow = PrefDriverDialogSetup; data->CloseWindow = PrefDriverDialogClose; } static void FontSettingDialogSetupItem(GtkWidget *w, struct FontSettingDialog *d) { gtk_entry_set_text(GTK_ENTRY(d->alias), CHK_STR(d->alias_str)); gtk_editable_set_editable(GTK_EDITABLE(d->alias), ! d->is_update); if (d->font_str) { char *tmp; tmp = g_strdup_printf("%s, 16", d->font_str); gtk_font_chooser_set_font(GTK_FONT_CHOOSER(d->font_b), tmp); g_free(tmp); } list_store_clear(d->list); if (d->alternative_str) { GtkTreeIter iter; gchar **ary; int i; ary = g_strsplit(d->alternative_str, ",", 0); for (i = 0; ary[i]; i++) { list_store_append(d->list, &iter); list_store_set_string(d->list, &iter, 0, ary[i]); } g_strfreev(ary); } d->alias_str = NULL; d->font_str = NULL; d->alternative_str = NULL; } static gboolean AlternativeFontListSelCb(GtkTreeSelection *sel, gpointer user_data) { int a, n; struct FontSettingDialog *d; d = (struct FontSettingDialog *) user_data; a = list_store_get_selected_index(d->list); n = list_store_get_num(d->list); gtk_widget_set_sensitive(d->del_b, a >= 0); gtk_widget_set_sensitive(d->up_b, a > 0); gtk_widget_set_sensitive(d->down_b, a >= 0 && a < n - 1); return FALSE; } static gchar * get_font_family(const gchar *font_name) { gchar *ptr; const gchar *family; PangoFontDescription *pdesc; pdesc = pango_font_description_from_string(font_name); family = pango_font_description_get_family(pdesc); if (family == NULL) { return NULL; } ptr = g_strdup(family); pango_font_description_free(pdesc); return ptr; } static void FontSettingDialogAddAlternative(GtkWidget *w, gpointer client_data) { struct FontSettingDialog *d; GtkWidget *dialog; d = (struct FontSettingDialog *) client_data; dialog = gtk_font_chooser_dialog_new(_("Alternative font"), NULL); if (ndialog_run(dialog) != GTK_RESPONSE_CANCEL) { const gchar *font_name; PangoFontFamily *family; GtkTreeIter iter; family = gtk_font_chooser_get_font_family(GTK_FONT_CHOOSER(dialog)); if (family) { font_name = pango_font_family_get_name(family); list_store_append(d->list, &iter); list_store_set_string(d->list, &iter, 0, font_name); } } gtk_widget_destroy (dialog); } static void FontSettingDialogRemoveAlternative(GtkWidget *w, gpointer client_data) { struct FontSettingDialog *d; GtkTreeIter iter; d = (struct FontSettingDialog *) client_data; if (list_store_get_selected_iter(d->list, &iter)) { GtkTreeModel *model; model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->list)); gtk_list_store_remove(GTK_LIST_STORE(model), &iter); } } static void FontSettingDialogDownAlternative(GtkWidget *wi, gpointer data) { struct FontSettingDialog *d; GtkTreeIter iter, next_iter; GtkTreeModel *model; GtkTreeSelection *sel; d = (struct FontSettingDialog *) data; if (! list_store_get_selected_iter(d->list, &iter)) { return; } model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->list)); next_iter = iter; if (! gtk_tree_model_iter_next(GTK_TREE_MODEL(model), &next_iter)) { return; } gtk_list_store_move_after(GTK_LIST_STORE(model), &iter, &next_iter); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); AlternativeFontListSelCb(sel, data); } static void FontSettingDialogUpAlternative(GtkWidget *wi, gpointer data) { struct FontSettingDialog *d; GtkTreeIter iter, prev_iter; GtkTreeModel *model; GtkTreePath *path; GtkTreeSelection *sel; d = (struct FontSettingDialog *) data; if (! list_store_get_selected_iter(d->list, &iter)) { return; } model = gtk_tree_view_get_model(GTK_TREE_VIEW(d->list)); path = gtk_tree_model_get_path(GTK_TREE_MODEL(model), &iter); if (gtk_tree_path_prev(path)) { gtk_tree_model_get_iter(GTK_TREE_MODEL(model), &prev_iter, path); gtk_list_store_move_before(GTK_LIST_STORE(model), &iter, &prev_iter); } gtk_tree_path_free(path); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); AlternativeFontListSelCb(sel, data); } static void FontSettingDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *vbox, *table, *frame, *swin; struct FontSettingDialog *d; GtkTreeSelection *sel; d = (struct FontSettingDialog *) data; if (makewidget) { n_list_store list[] = { {N_("Font name"), G_TYPE_STRING, TRUE, FALSE, NULL}, }; int j; table = gtk_grid_new(); j = 0; w = gtk_entry_new(); add_widget_to_table(table, w, _("_Alias:"), TRUE, j++); d->alias = w; w = gtk_font_button_new(); gtk_font_button_set_show_size(GTK_FONT_BUTTON(w), FALSE); gtk_font_button_set_show_style(GTK_FONT_BUTTON(w), FALSE); add_widget_to_table(table, w, _("_Font:"), TRUE, j++); d->font_b = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); w = list_store_create(sizeof(list) / sizeof(*list), list); gtk_tree_view_set_reorderable(GTK_TREE_VIEW(w), TRUE); d->list = w; gtk_container_add(GTK_CONTAINER(swin), w); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); g_signal_connect(sel, "changed", G_CALLBACK(AlternativeFontListSelCb), d); gtk_box_pack_start(GTK_BOX(hbox), swin, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w= gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(w, "list-add"); g_signal_connect(w, "clicked", G_CALLBACK(FontSettingDialogAddAlternative), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Remove")); set_button_icon(w, "list-remove"); g_signal_connect(w, "clicked", G_CALLBACK(FontSettingDialogRemoveAlternative), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->del_b = w; w = gtk_button_new_with_mnemonic(_("_Down")); set_button_icon(w, "go-down"); g_signal_connect(w, "clicked", G_CALLBACK(FontSettingDialogDownAlternative), d); gtk_box_pack_end(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->down_b = w; w = gtk_button_new_with_mnemonic(_("_Up")); set_button_icon(w, "go-up"); g_signal_connect(w, "clicked", G_CALLBACK(FontSettingDialogUpAlternative), d); gtk_box_pack_end(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->up_b = w; gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 4); frame = gtk_frame_new(_("Alternative fonts")); gtk_container_add(GTK_CONTAINER(frame), hbox); gtk_box_pack_start(GTK_BOX(d->vbox), frame, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } FontSettingDialogSetupItem(wi, d); } static char * get_font_alias(struct FontSettingDialog *d) { const char *alias; char *tmp, *ptr; alias = gtk_entry_get_text(GTK_ENTRY(d->alias)); tmp = g_strdup(alias); if (tmp == NULL) return NULL; g_strstrip(tmp); for (ptr = tmp; *ptr != '\0'; ptr++) { if (*ptr == '\t') *ptr = ' '; } if (tmp[0] == '\0') { g_free(tmp); tmp = NULL; } return tmp; } static void FontSettingDialogClose(GtkWidget *wi, void *data) { struct FontSettingDialog *d; gchar *alias, *family, *font; const gchar *font_name; struct fontmap *fmap; GString *alt; GtkTreeIter iter; d = (struct FontSettingDialog *) data; if (d->ret == IDCANCEL) { return; } alias = get_font_alias(d); if (alias == NULL) { if (! d->is_update) { message_box(d->widget, _("Please specify a new alias name."), NULL, RESPONS_OK); } d->ret = IDLOOP; return; } fmap = gra2cairo_get_fontmap(alias); if (fmap && ! d->is_update) { message_box(d->widget, _("Alias name already exists."), NULL, RESPONS_OK); d->ret = IDLOOP; g_free(alias); return; } font_name = gtk_font_chooser_get_font(GTK_FONT_CHOOSER(d->font_b)); family = get_font_family(font_name); if (family == NULL) { g_free(alias); return; } if (d->is_update) { gra2cairo_update_fontmap(alias, family); } else { gra2cairo_add_fontmap(alias, family); } g_free(family); if (! list_store_get_iter_first(d->list, &iter)) { gra2cairo_set_alternative_font(alias, NULL); g_free(alias); return; } font = list_store_get_string(d->list, &iter, 0); alt = g_string_new(font); g_free(font); while (list_store_iter_next(d->list, &iter)) { font = list_store_get_string(d->list, &iter, 0); g_string_append_printf(alt, ",%s", font); g_free(font); } gra2cairo_set_alternative_font(alias, alt->str); g_string_free(alt, TRUE); g_free(alias); } void FontSettingDialog(struct FontSettingDialog *d, const char *alias, const char *font, const char *alternative) { d->SetupWindow = FontSettingDialogSetup; d->CloseWindow = FontSettingDialogClose; d->alias_str = alias; d->font_str = font; d->alternative_str = alternative; d->is_update = (alias != NULL); } static void PrefFontDialogSetupItem(struct PrefFontDialog *d) { struct fontmap *fcur; GtkTreeIter iter; list_store_clear(d->list); fcur = Gra2cairoConf->fontmap_list_root; while (fcur) { list_store_append(d->list, &iter); list_store_set_string(d->list, &iter, 0, fcur->fontalias); list_store_set_string(d->list, &iter, 1, fcur->fontname); list_store_set_string(d->list, &iter, 2, fcur->alternative); fcur = fcur->next; } } static void PrefFontDialogUpdate(GtkWidget *w, gpointer client_data) { struct PrefFontDialog *d; struct fontmap *fcur; char *fontalias; int ret; d = (struct PrefFontDialog *) client_data; fontalias = list_store_get_selected_string(d->list, 0); if (fontalias == NULL) return; fcur = gra2cairo_get_fontmap(fontalias); g_free(fontalias); if (fcur == NULL) return; FontSettingDialog(&DlgFontSetting, fcur->fontalias, fcur->fontname, fcur->alternative); ret = DialogExecute(d->widget, &DlgFontSetting); if (ret == IDOK) { PrefFontDialogSetupItem(d); } } static void PrefFontDialogRemove(GtkWidget *w, gpointer client_data) { struct PrefFontDialog *d; char *fontalias; d = (struct PrefFontDialog *) client_data; fontalias = list_store_get_selected_string(d->list, 0); gra2cairo_remove_fontmap(fontalias); g_free(fontalias); PrefFontDialogSetupItem(d); } static void PrefFontDialogAdd(GtkWidget *w, gpointer client_data) { struct PrefFontDialog *d; int ret; d = (struct PrefFontDialog *) client_data; FontSettingDialog(&DlgFontSetting, NULL, NULL, NULL); ret = DialogExecute(d->widget, &DlgFontSetting); if (ret == IDOK) { PrefFontDialogSetupItem(d); } } #define HAVE_UPDATE_FUNC #define LIST_TYPE fontmap #define LIST_ROOT Gra2cairoConf->fontmap_list_root #define CREATE_NAME(a, c) a ## Font ## c #include "x11opt_proto.h" static void PrefFontDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *vbox; struct PrefFontDialog *d; n_list_store list[] = { {N_("alias"), G_TYPE_STRING, TRUE, FALSE, NULL}, {N_("name"), G_TYPE_STRING, TRUE, FALSE, NULL}, {N_("alternative fonts"), G_TYPE_STRING, TRUE, FALSE, NULL}, }; d = (struct PrefFontDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); PrefFontDialogCreateWidgets(d, vbox, sizeof(list) / sizeof(*list), list); gtk_window_set_default_size(GTK_WINDOW(wi), 550, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } PrefFontDialogSetupItem(d); } static void PrefFontDialogClose(GtkWidget *w, void *data) { struct PrefFontDialog *d; d = (struct PrefFontDialog *) data; if (d->ret == IDSAVE) { save_config(SAVE_CONFIG_TYPE_FONTS); } } void PrefFontDialog(struct PrefFontDialog *data) { data->SetupWindow = PrefFontDialogSetup; data->CloseWindow = PrefFontDialogClose; } static void MiscDialogSetupItem(GtkWidget *w, struct MiscDialog *d) { if (Menulocal.editor) gtk_entry_set_text(GTK_ENTRY(d->editor), Menulocal.editor); if (Menulocal.help_browser) gtk_entry_set_text(GTK_ENTRY(d->help_browser), Menulocal.help_browser); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->directory), Menulocal.changedirectory); combo_box_set_active(d->path, Menulocal.savepath); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->datafile), Menulocal.savewithdata); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->mergefile), Menulocal.savewithmerge); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->expand), Menulocal.expand); if (Menulocal.expanddir) gtk_entry_set_text(GTK_ENTRY(d->expanddir), Menulocal.expanddir); combo_box_set_active(d->loadpath, Menulocal.loadpath); spin_entry_set_val(d->hist_size, Menulocal.hist_size); spin_entry_set_val(d->info_size, Menulocal.info_size); spin_entry_set_val(d->data_head_lines, Menulocal.data_head_lines); if (Menulocal.coordwin_font) { gtk_font_chooser_set_font(GTK_FONT_CHOOSER(d->coordwin_font), Menulocal.coordwin_font); } if (Menulocal.infowin_font) { gtk_font_chooser_set_font(GTK_FONT_CHOOSER(d->infowin_font), Menulocal.infowin_font); } if (Menulocal.file_preview_font) { gtk_font_chooser_set_font(GTK_FONT_CHOOSER(d->file_preview_font), Menulocal.file_preview_font); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_opacity), Menulocal.use_opacity); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->select_data), Menulocal.select_data); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_custom_palette), Menulocal.use_custom_palette); arraycpy(&(d->tmp_palette), &(Menulocal.custom_palette)); if (Menulocal.source_style_id) { GtkSourceStyleSchemeManager *sman; GtkSourceStyleScheme *style; sman = gtk_source_style_scheme_manager_get_default(); style = gtk_source_style_scheme_manager_get_scheme(sman, Menulocal.source_style_id); gtk_source_style_scheme_chooser_set_style_scheme(GTK_SOURCE_STYLE_SCHEME_CHOOSER(d->source_style), style); } } static void set_file_in_entry(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { char *file; struct SetDriverDialog *d; d = (struct SetDriverDialog *) user_data; if (nGetOpenFileName(d->widget, _("Select program"), NULL, NULL, NULL, &file, TRUE, FALSE) == IDOK) { entry_set_filename(GTK_WIDGET(w), file); } g_free(file); } #define PALETTE_COLUMN 9 static GtkWidget ** create_custom_palette_buttons(struct MiscDialog *d, GtkWidget *box) { struct narray *palette; GdkRGBA *colors; GtkWidget *btn, *bbox, **btns; int i, n; GValue value = G_VALUE_INIT; g_value_init(&value, G_TYPE_BOOLEAN); g_value_set_boolean(&value, TRUE); palette = &(d->tmp_palette); n = arraynum(palette); if (n < 1) { return NULL; } btns = g_malloc(sizeof(*btns) * (n + 1)); if (btns == NULL) { return NULL; } colors = arraydata(palette); bbox = NULL; for (i = 0; i < n; i++) { if (i % PALETTE_COLUMN == 0) { if (bbox) { gtk_box_pack_start(GTK_BOX(box), bbox, FALSE, FALSE, 0); } bbox = gtk_button_box_new(GTK_ORIENTATION_HORIZONTAL); gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_START); } btn = gtk_color_button_new_with_rgba(colors + i); g_object_set_property(G_OBJECT(btn), "show-editor", &value); gtk_box_pack_start(GTK_BOX(bbox), btn, FALSE, FALSE, 4); btns[i] = btn; } btns[i] = NULL; if (bbox) { gtk_box_pack_start(GTK_BOX(box), bbox, FALSE, FALSE, 0); } return btns; } static void save_custom_palette(struct MiscDialog *d, GtkWidget **btns) { struct narray *palette; GdkRGBA rgba; palette = &(d->tmp_palette); arrayclear(palette); while (*btns) { gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(*btns), &rgba); arrayadd(palette, &rgba); btns++; } } static void edit_custom_palette(GtkWidget *w, gpointer data) { GtkWidget *dialog, *box, **btns; struct MiscDialog *d; gint r; d = data; dialog = gtk_dialog_new_with_buttons(_("custom palette"), GTK_WINDOW(d->widget), GTK_DIALOG_MODAL, _("_OK"), GTK_RESPONSE_ACCEPT, _("_Cancel"), GTK_RESPONSE_REJECT, NULL); box = gtk_dialog_get_content_area(GTK_DIALOG(dialog)); btns = create_custom_palette_buttons(d, box); if (btns == NULL) { gtk_widget_destroy(dialog); return; } gtk_widget_show_all(dialog); r = gtk_dialog_run(GTK_DIALOG(dialog)); if (r == GTK_RESPONSE_ACCEPT) { save_custom_palette(d, btns); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_custom_palette), TRUE); } g_free(btns); gtk_widget_destroy(dialog); } static void MiscDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox2, *vbox2, *frame, *table; struct MiscDialog *d; int i, j; d = (struct MiscDialog *) data; if (makewidget) { arrayinit(&(d->tmp_palette), sizeof(GdkRGBA)); gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); frame = gtk_frame_new(_("External programs")); table = gtk_grid_new(); i = 0; w = create_file_entry_with_cb(G_CALLBACK(set_file_in_entry), d); add_widget_to_table(table, w, _("_Editor:"), TRUE, i++); d->editor = w; w = create_file_entry_with_cb(G_CALLBACK(set_file_in_entry), d); add_widget_to_table(table, w, _("_Help browser:"), TRUE, i++); d->help_browser = w; gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, FALSE, FALSE, 4); frame = gtk_frame_new(NULL); gtk_frame_set_label(GTK_FRAME(frame), _("Save graph")); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Path:"), FALSE, i++); for (j = 0; pathchar[j]; j++) { combo_box_append_text(w, _(pathchar[j])); } d->path = w; w = gtk_check_button_new_with_mnemonic(_("include _Data file")); d->datafile = w; add_widget_to_table(table, w, NULL, FALSE, i++); w = gtk_check_button_new_with_mnemonic(_("include _Merge file")); d->mergefile = w; add_widget_to_table(table, w, NULL, FALSE, i++); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, FALSE, FALSE, 4); frame = gtk_frame_new(NULL); gtk_frame_set_label(GTK_FRAME(frame), _("Load graph")); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Path:"), FALSE, i++); for (j = 0; LoadPathStr[j]; j++) { combo_box_append_text(w, _(LoadPathStr[j])); } d->loadpath = w; w = gtk_check_button_new_with_mnemonic(_("_Expand include file")); add_widget_to_table(table, w, NULL, FALSE, i++); d->expand = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("_Expand directory:"), TRUE, i++); d->expanddir = w; gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox2), vbox2, TRUE, TRUE, 4); vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); frame = gtk_frame_new(_("Size")); table = gtk_grid_new(); i = 0; w = create_spin_entry(1, HIST_SIZE_MAX, 1, FALSE, TRUE); add_widget_to_table(table, w, _("_Size of completion history:"), FALSE, i++); d->hist_size = w; w = create_spin_entry(1, INFOWIN_SIZE_MAX, 1, FALSE, TRUE); add_widget_to_table(table, w, _("_Length of information view:"), FALSE, i++); d->info_size = w; w = create_spin_entry(0, HIST_SIZE_MAX, 1, FALSE, TRUE); add_widget_to_table(table, w, _("_Length of data preview:"), FALSE, i++); d->data_head_lines = w; gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, FALSE, FALSE, 4); frame = gtk_frame_new(_("Font")); table = gtk_grid_new(); i = 0; w = gtk_font_button_new(); add_widget_to_table(table, w, _("_Coordinate view:"), FALSE, i++); d->coordwin_font = w; w = gtk_font_button_new(); add_widget_to_table(table, w, _("_Information view:"), FALSE, i++); d->infowin_font = w; w = gtk_font_button_new(); add_widget_to_table(table, w, _("data _Preview:"), FALSE, i++); d->file_preview_font = w; gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, FALSE, FALSE, 4); frame = gtk_frame_new(_("Miscellaneous")); table = gtk_grid_new(); i = 0; w = gtk_check_button_new_with_mnemonic(_("_Check \"change current directory\"")); add_widget_to_table(table, w, NULL, FALSE, i++); d->directory = w; w = gtk_check_button_new_with_mnemonic(_("_Use opacity")); add_widget_to_table(table, w, NULL, FALSE, i++); d->use_opacity = w; w = gtk_check_button_new_with_mnemonic(_("_Show select data dialog on exporting")); add_widget_to_table(table, w, NULL, FALSE, i++); d->select_data = w; w = gtk_check_button_new_with_mnemonic(_("use custom _Palette")); add_widget_to_table(table, w, NULL, FALSE, i++); d->use_custom_palette = w; w = gtk_button_new_with_mnemonic(_("_Edit custom palette")); g_signal_connect(w, "clicked", G_CALLBACK(edit_custom_palette), d); add_widget_to_table(table, w, NULL, FALSE, i++); w = gtk_source_style_scheme_chooser_button_new(); add_widget_to_table(table, w, _("_Source style:"), FALSE, i++); d->source_style = w; gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(vbox2), frame, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox2), vbox2, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox2, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } MiscDialogSetupItem(wi, d); } static int set_font(char **cfg, GtkWidget *btn) { const char *buf; buf = gtk_font_chooser_get_font(GTK_FONT_CHOOSER(btn)); if (buf && *cfg) { if (strcmp(*cfg, buf)) { g_free(*cfg); } else { buf = NULL; } } if (buf) { *cfg = g_strdup(buf); return 1; } return 0; } static void set_program_name(GtkWidget *entry, char **prm) { const char *buf; char *buf2; buf = gtk_entry_get_text(GTK_ENTRY(entry)); if (buf) { buf2 = g_strdup(buf); if (buf2) { changefilename(buf2); g_free(*prm); } *prm = buf2; } else { g_free(*prm); *prm = NULL; } } static void MiscDialogClose(GtkWidget *w, void *data) { struct MiscDialog *d; int a, ret; const char *buf, *source_style_id; char *buf2; GtkSourceStyleScheme *source_style; d = (struct MiscDialog *) data; if (d->ret != IDOK && d->ret != IDSAVE) return; ret = d->ret; d->ret = IDLOOP; set_program_name(d->editor, &Menulocal.editor); set_program_name(d->help_browser, &Menulocal.help_browser); Menulocal.changedirectory = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->directory)); a = combo_box_get_active(d->path); if (a >= 0) { Menulocal.savepath = a; } Menulocal.savewithdata = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->datafile)); Menulocal.savewithmerge = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->mergefile)); Menulocal.expand = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->expand)); buf = gtk_entry_get_text(GTK_ENTRY(d->expanddir)); if (buf) { buf2 = g_strdup(buf); if (buf2) { g_free(Menulocal.expanddir); Menulocal.expanddir = buf2; } } Menulocal.loadpath = combo_box_get_active(d->loadpath); a = spin_entry_get_val(d->hist_size); if (a <= HIST_SIZE_MAX && a > 0) Menulocal.hist_size = a; a = spin_entry_get_val(d->info_size); if (a <= INFOWIN_SIZE_MAX && a > 0) Menulocal.info_size = a; a = spin_entry_get_val(d->data_head_lines); putobj(d->Obj, "data_head_lines", d->Id, &a); if (set_font(&Menulocal.coordwin_font, d->coordwin_font)) { CoordWinSetFont(Menulocal.coordwin_font); } if (set_font(&Menulocal.infowin_font, d->infowin_font)) { InfoWinSetFont(Menulocal.infowin_font); } set_font(&Menulocal.file_preview_font, d->file_preview_font); Menulocal.use_opacity = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->use_opacity)); putobj(d->Obj, "use_opacity", d->Id, &Menulocal.use_opacity); Menulocal.select_data = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->select_data)); Menulocal.use_custom_palette = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->use_custom_palette)); if (arraycmp(&(Menulocal.custom_palette), &(d->tmp_palette))) { arraycpy(&(Menulocal.custom_palette), &(d->tmp_palette)); } arraydel(&(d->tmp_palette)); d->ret = ret; source_style = gtk_source_style_scheme_chooser_get_style_scheme(GTK_SOURCE_STYLE_SCHEME_CHOOSER(d->source_style)); source_style_id = gtk_source_style_scheme_get_id(source_style); if (g_strcmp0(Menulocal.source_style_id, source_style_id)) { if (Menulocal.source_style_id) { g_free(Menulocal.source_style_id); } Menulocal.source_style_id = g_strdup(source_style_id); } if (d->ret == IDSAVE) { save_config(SAVE_CONFIG_TYPE_MISC); } } void MiscDialog(struct MiscDialog *data, struct objlist *obj, int id) { data->SetupWindow = MiscDialogSetup; data->CloseWindow = MiscDialogClose; data->Obj = obj; data->Id = id; } static void ExViewerDialogSetupItem(GtkWidget *w, struct ExViewerDialog *d) { gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->use_external), Menulocal.exwin_use_external); gtk_range_set_value(GTK_RANGE(d->dpi), Menulocal.exwindpi); spin_entry_set_val(d->width, Menulocal.exwinwidth); spin_entry_set_val(d->height, Menulocal.exwinheight); } static void use_external_toggled(GtkToggleButton *togglebutton, gpointer user_data) { gboolean state; struct ExViewerDialog *d; d = (struct ExViewerDialog *) user_data; state = ! gtk_toggle_button_get_active(togglebutton); set_widget_sensitivity_with_label(d->dpi, state); set_widget_sensitivity_with_label(d->width, state); set_widget_sensitivity_with_label(d->height, state); } static void ExViewerDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct ExViewerDialog *d; int i; d = (struct ExViewerDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); table = gtk_grid_new(); i = 0; w = gtk_check_button_new_with_mnemonic(_("use _External previewer")); add_widget_to_table(table, w, NULL, FALSE, i++); g_signal_connect(w, "toggled", G_CALLBACK(use_external_toggled), d); d->use_external = w; w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 20, 620, 1); d->dpi = w; add_widget_to_table(table, w, "_DPI:", TRUE, i++); w = create_spin_entry(WIN_SIZE_MIN, WIN_SIZE_MAX, 1, FALSE, TRUE); add_widget_to_table(table, w, _("Window _Width:"), FALSE, i++); d->width = w; w = create_spin_entry(WIN_SIZE_MIN, WIN_SIZE_MAX, 1, FALSE, TRUE); add_widget_to_table(table, w, _("Window _Height:"), FALSE, i++); d->height = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } ExViewerDialogSetupItem(wi, d); } static void ExViewerDialogClose(GtkWidget *w, void *data) { struct ExViewerDialog *d; d = (struct ExViewerDialog *) data; if (d->ret != IDOK && d->ret != IDSAVE) return; Menulocal.exwindpi = gtk_range_get_value(GTK_RANGE(d->dpi)); Menulocal.exwinwidth = spin_entry_get_val(d->width); Menulocal.exwinheight = spin_entry_get_val(d->height); Menulocal.exwin_use_external = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->use_external)); if (d->ret == IDSAVE) { save_config(SAVE_CONFIG_TYPE_EXTERNAL_VIEWER); } } void ExViewerDialog(struct ExViewerDialog *data) { data->SetupWindow = ExViewerDialogSetup; data->CloseWindow = ExViewerDialogClose; } static void ViewerDialogSetupItem(GtkWidget *w, struct ViewerDialog *d) { int a; GdkRGBA color; getobj(d->Obj, "dpi", d->Id, 0, NULL, &(d->dpis)); gtk_range_set_value(GTK_RANGE(d->dpi), d->dpis); getobj(d->Obj, "antialias", d->Id, 0, NULL, &a); combo_box_set_active(d->antialias, a); getobj(d->Obj, "redraw_flag", d->Id, 0, NULL, &a); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->loadfile), a); spin_entry_set_val(d->data_num, Menulocal.redrawf_num); spin_entry_set_val(d->grid, Menulocal.grid); combo_box_set_active(d->fftype, (Menulocal.focus_frame_type == N_LINE_TYPE_SOLID) ? 0 : 1); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->preserve_width), Menulocal.preserve_width); color.red = Menulocal.bg_r; color.green = Menulocal.bg_g; color.blue = Menulocal.bg_b; color.alpha = 1; gtk_color_chooser_set_use_alpha(GTK_COLOR_CHOOSER(d->bgcol), FALSE); gtk_color_chooser_set_rgba(GTK_COLOR_CHOOSER(d->bgcol), &color); } static void load_file_toggled(GtkToggleButton *togglebutton, gpointer user_data) { gboolean state; struct ViewerDialog *d; d = (struct ViewerDialog *) user_data; state = gtk_toggle_button_get_active(togglebutton); set_widget_sensitivity_with_label(d->data_num, state); } static void ViewerDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *table; struct ViewerDialog *d; int i, j; d = (struct ViewerDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Save"), IDSAVE); table = gtk_grid_new(); i = 0; w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 20, 620, 1); d->dpi = w; add_widget_to_table(table, w, "_DPI:", TRUE, i++); w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, FALSE, TRUE); spin_entry_set_range(w, 1, GRID_MAX); add_widget_to_table(table, w, _("_Grid:"), FALSE, i++); d->grid = w; w = create_color_button(wi); add_widget_to_table(table, w, _("_Background Color:"), FALSE, i++); d->bgcol = w; w = combo_box_create(); combo_box_append_text(w, _("solid")); combo_box_append_text(w, _("dot")); add_widget_to_table(table, w, _("_Line attribute of focus frame:"), FALSE, i++); d->fftype = w; w = combo_box_create(); for (j = 0; gra2cairo_antialias_type[j]; j++) { combo_box_append_text(w, _(gra2cairo_antialias_type[j])); } d->antialias = w; add_widget_to_table(table, w, _("_Antialias:"), FALSE, i++); w = gtk_check_button_new_with_mnemonic(_("_Preserve line width and style")); d->preserve_width = w; add_widget_to_table(table, w, NULL, FALSE, i++); w = gtk_check_button_new_with_mnemonic(_("_Load files on redraw")); g_signal_connect(w, "toggled", G_CALLBACK(load_file_toggled), d); d->loadfile = w; add_widget_to_table(table, w, NULL, FALSE, i++); w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Maximum number of data on redraw:"), FALSE, i++); d->data_num = w; gtk_box_pack_start(GTK_BOX(d->vbox), table, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } ViewerDialogSetupItem(wi, d); } static void ViewerDialogClose(GtkWidget *w, void *data) { struct ViewerDialog *d; int ret, dpi, a, bg; GdkRGBA color; d = (struct ViewerDialog *) data; if (d->ret != IDOK && d->ret != IDSAVE) return; ret = d->ret; d->ret = IDLOOP; dpi = gtk_range_get_value(GTK_RANGE(d->dpi)); if (d->dpis != dpi) { if (putobj(d->Obj, "dpi", d->Id, &dpi) == -1) return; d->Clear = TRUE; } a = combo_box_get_active(d->antialias); if (putobj(d->Obj, "antialias", d->Id, &a) == -1) return; Menulocal.antialias = a; a = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->loadfile)); a = a ? TRUE : FALSE; if (putobj(d->Obj, "redraw_flag", d->Id, &a) == -1) return; a = spin_entry_get_val(d->data_num); if (putobj(d->Obj, "redraw_num", d->Id, &a) == -1) return; Menulocal.preserve_width = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->preserve_width)); gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(d->bgcol), &color); bg = (Menulocal.bg_r != color.red || Menulocal.bg_g != color.green || Menulocal.bg_b != color.blue); Menulocal.bg_r = color.red; Menulocal.bg_g = color.green; Menulocal.bg_b = color.blue; Menulocal.grid = spin_entry_get_val(d->grid); a = combo_box_get_active(d->fftype); Menulocal.focus_frame_type = ((a == 0) ? N_LINE_TYPE_SOLID : N_LINE_TYPE_DOT); d->ret = ret; if (d->ret == IDSAVE) { save_config(SAVE_CONFIG_TYPE_VIEWER); } if (bg) { update_bg(); UpdateAll2(NULL, TRUE); } } void ViewerDialog(struct ViewerDialog *data, struct objlist *obj, int id) { data->SetupWindow = ViewerDialogSetup; data->CloseWindow = ViewerDialogClose; data->Obj = obj; data->Id = id; data->Clear = FALSE; } void CmOptionSaveNgp(void *w, gpointer client_data) { char *ngpfile; char mes[MESSAGE_BUF_SIZE]; int i, path; struct objlist *obj; if (Menulock || Globallock) return; ngpfile = getscriptname("Ngraph.ngp"); if (ngpfile == NULL) return; path = 1; obj = chkobject("data"); if (obj) { for (i = 0; i <= chkobjlastinst(obj); i++) { putobj(obj, "save_path", i, &path); } } obj = chkobject("merge"); if (obj) { for (i = 0; i <= chkobjlastinst(obj); i++) { putobj(obj, "save_path", i, &path); } } if (naccess(ngpfile, 04) == 0) { snprintf(mes, sizeof(mes), _("`%s'\n\nOverwrite existing file?"), ngpfile); if (message_box(NULL, mes, _("Save as Ngraph.ngp"), RESPONS_YESNO) != IDYES) { g_free(ngpfile); return; } } snprintf(mes, sizeof(mes), _("Saving `%.128s'."), ngpfile); SetStatusBar(mes); SaveDrawrable(ngpfile, FALSE, FALSE); ResetStatusBar(); g_free(ngpfile); return; } void CmOptionViewer(void *w, gpointer client_data) { int r; if (Menulock || Globallock) return; ViewerDialog(&DlgViewer, Menulocal.obj, 0); r = DialogExecute(TopLevel, &DlgViewer); if (r == IDOK && DlgViewer.Clear) { ChangeDPI(); } } void CmOptionExtViewer(void *w, gpointer client_data) { if (Menulock || Globallock) return; ExViewerDialog(&DlgExViewer); DialogExecute(TopLevel, &DlgExViewer); } void CmOptionPrefFont(void *w, gpointer client_data) { if (Menulock || Globallock) return; PrefFontDialog(&DlgPrefFont); DialogExecute(TopLevel, &DlgPrefFont); } #if 0 static void CmOptionPrefDriver(void) { if (Menulock || Globallock) return; PrefDriverDialog(&DlgPrefDriver); DialogExecute(TopLevel, &DlgPrefDriver); } #endif void CmOptionScript(void *w, gpointer client_datavoid) { if (Menulock || Globallock) return; PrefScriptDialog(&DlgPrefScript); DialogExecute(TopLevel, &DlgPrefScript); } void CmOptionMisc(void *w, gpointer client_data) { if (Menulock || Globallock) return; MiscDialog(&DlgMisc, Menulocal.obj, 0); DialogExecute(TopLevel, &DlgMisc); } void CmOptionSaveDefault(void *w, gpointer client_data) { if (Menulock || Globallock) return; DefaultDialog(&DlgDefault); DialogExecute(TopLevel, &DlgDefault); } ngraph-gtk-6.08.00/src/gtk/x11menu.c0000644000175000017500000035443213365064363013712 00000000000000/* --*-coding:utf-8-*-- */ /* * $Id: x11menu.c,v 1.116 2010-04-01 06:08:23 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #include #include "dir_defs.h" #include "object.h" #include "ioutil.h" #include "shell.h" #include "nstring.h" #include "nconfig.h" #include "mathfn.h" #include "gra.h" #include "spline.h" #include "gtk_entry_completion.h" #include "gtk_subwin.h" #include "gtk_widget.h" #include "gtk_ruler.h" #include "gtk_action.h" #include "gtk_presettings.h" #include "init.h" #include "osystem.h" #include "omerge.h" #include "x11bitmp.h" #include "x11dialg.h" #include "ogra2cairo.h" #include "ogra2gdk.h" #include "ox11menu.h" #include "x11menu.h" #include "x11info.h" #include "x11cood.h" #include "x11gui.h" #include "x11merge.h" #include "x11commn.h" #include "x11lgnd.h" #include "x11axis.h" #include "x11file.h" #include "x11graph.h" #include "x11print.h" #include "x11opt.h" #include "x11view.h" #define DUMMY_AXISGRID N_("axisgrid") /* only for translation */ #define DUMMY_SHORTCUT N_("Show shortcut keys") /* only for translation */ #define TEXT_HISTORY "text_history" #define MATH_X_HISTORY "math_x_history" #define MATH_Y_HISTORY "math_y_history" #define FUNCTION_HISTORY "function_history" #define FIT_HISTORY "fit_history" #define KEYMAP_FILE "accel_map" #define FUNC_MATH_HISTORY "func_math_history" #define FUNC_FUNC_HISTORY "func_func_history" #define USE_EXT_DRIVER 0 #define SIDE_PANE_TAB_ID "side_pane" int Menulock = FALSE, DnDLock = FALSE; struct NgraphApp NgraphApp = {0}; GtkWidget *TopLevel = NULL, *DrawButton = NULL; GtkAccelGroup *AccelGroup = NULL; #define DRAW_NOTIFY_CLASS_NAME "draw_notify" static GtkWidget *CurrentWindow = NULL, *CToolbar = NULL, *PToolbar = NULL, *SettingPanel = NULL, *ToolBox = NULL; static enum {APP_CONTINUE, APP_QUIT, APP_QUIT_FORCE} Hide_window = APP_CONTINUE; static int DrawLock = FALSE; static unsigned int CursorType; #if USE_APP_MENU GtkApplication *GtkApp; #endif #if USE_EXT_DRIVER static GtkWidget *ExtDrvOutMenu = NULL #endif struct MenuItem; struct ToolItem; static void create_menu(GtkWidget *w, struct MenuItem *item); static void create_menu_sub(GtkWidget *parent, struct MenuItem *item, int popup); static void create_popup(GtkWidget *parent, struct MenuItem *item); static GtkWidget *create_toolbar(struct ToolItem *item, int n, GCallback btn_press_cb); static void CmViewerButtonArm(GtkToggleToolButton *action, gpointer client_data); static GdkCursorType Cursor[] = { GDK_LEFT_PTR, GDK_XTERM, GDK_CROSSHAIR, GDK_TOP_LEFT_CORNER, GDK_TOP_RIGHT_CORNER, GDK_BOTTOM_RIGHT_CORNER, GDK_BOTTOM_LEFT_CORNER, GDK_TARGET, GDK_SIZING, GDK_SIZING, GDK_WATCH, GDK_FLEUR, GDK_PENCIL, GDK_TCROSS, }; #define CURSOR_TYPE_NUM (sizeof(Cursor) / sizeof(*Cursor)) static void clear_information(void *w, gpointer user_data); static void toggle_view_cb(GtkCheckMenuItem *action, gpointer data); enum FOCUS_TYPE { FOCUS_TYPE_1 = 0, FOCUS_TYPE_2, FOCUS_TYPE_3, FOCUS_TYPE_4, FOCUS_TYPE_5, FOCUS_TYPE_6, FOCUS_TYPE_NUM, }; enum ACTION_TYPE { ACTION_TYPE_FILE, ACTION_TYPE_AXIS, ACTION_TYPE_GRID, ACTION_TYPE_PATH, ACTION_TYPE_ARC, ACTION_TYPE_RECTANGLE, ACTION_TYPE_MARK, ACTION_TYPE_TEXT, ACTION_TYPE_MERGE, ACTION_TYPE_FOCUS_EDIT1, ACTION_TYPE_FOCUS_EDIT2, ACTION_TYPE_FOCUS_EDIT_PASTE, ACTION_TYPE_FOCUS_ROTATE, ACTION_TYPE_FOCUS_FLIP, ACTION_TYPE_FOCUS_UP, ACTION_TYPE_FOCUS_DOWN, ACTION_TYPE_AXIS_UNDO, ACTION_TYPE_MODIFIED, ACTION_TYPE_NONE, }; struct ActionWidget { GtkWidget *menu, *popup; GtkToolItem *tool; #if USE_GTK_BUILDER GAction *action; #endif enum ACTION_TYPE type; }; enum ActionWidgetIndex { GraphSaveAction, EditMenuAction, EditRedoAction, EditUndoAction, EditCutAction, EditCopyAction, EditRotateCCWAction, EditRotateCWAction, EditFlipVAction, EditFlipHAction, EditDeleteAction, EditDuplicateAction, EditAlignLeftAction, EditAlignRightAction, EditAlignHCenterAction, EditAlignTopAction, EditAlignBottomAction, EditAlignVCenterAction, EditOrderTopAction, EditOrderUpAction, EditOrderDownAction, EditOrderBottomAction, PopupUpdateAction, EditPasteAction, ViewSidebarAction, ViewStatusbarAction, ViewRulerAction, ViewScrollbarAction, ViewCommandToolbarAction, ViewToolboxAction, ViewCrossGaugeAction, ViewGridLineAction, DataPropertyAction, DataCloseAction, DataEditAction, DataSaveAction, DataMathAction, AxisPropertyAction, AxisDeleteAction, AxisScaleZoomAction, AxisScaleClearAction, AxisGridPropertyAction, AxisGridDeleteAction, AxisScaleUndoAction, LegendPathPropertyAction, LegendPathDeleteAction, LegendRectanglePropertyAction, LegendRectangleDeleteAction, LegendArcPropertyAction, LegendArcDeleteAction, LegendMarkPropertyAction, LegendMarkDeleteAction, LegendTextPropertyAction, LegendTextDeleteAction, MergePropertyAction, MergeCloseAction, AddinAction, PointerModeBoth, PointerModeLegend, PointerModeAxis, PointerModeData, ActionWidgetNum, }; struct ActionWidget ActionWidget[ActionWidgetNum]; static int DefaultMode = PointerModeBoth; struct ToolItem { enum { TOOL_TYPE_NORMAL, TOOL_TYPE_DRAW, TOOL_TYPE_SAVE, TOOL_TYPE_TOGGLE, TOOL_TYPE_TOGGLE2, TOOL_TYPE_RADIO, TOOL_TYPE_RECENT_GRAPH, TOOL_TYPE_RECENT_DATA, TOOL_TYPE_SEPARATOR, } type; const char *label; const char *tip; const char *caption; const char *icon; const char *accel_path; guint accel_key; GdkModifierType accel_mods; struct MenuItem *child; GCallback callback; int user_data; struct ActionWidget *action; const char *action_name; }; static struct ToolItem PointerToolbar[] = { { TOOL_TYPE_RADIO, N_("Point"), N_("Pointer"), N_("Legend and Axis Pointer (+SHIFT: Multi select / +CONTROL: Horizontal/Vertical +SHIFT: Fine)"), NGRAPH_POINT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), PointB, ActionWidget + PointerModeBoth, }, { TOOL_TYPE_RADIO, N_("Legend"), N_("Legend Pointer"), N_("Legend Pointer (+SHIFT: Multi select / +CONTROL: Horizontal/Vertical +SHIFT: Fine)"), NGRAPH_LEGENDPOINT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), LegendB, ActionWidget + PointerModeLegend, }, { TOOL_TYPE_RADIO, N_("Axis"), N_("Axis Pointer"), N_("Axis Pointer (+SHIFT: Multi select / +CONTROL: Horizontal/Vertical +SHIFT: Fine)"), NGRAPH_AXISPOINT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), AxisB, ActionWidget + PointerModeAxis, }, { TOOL_TYPE_RADIO, N_("Data"), N_("Data Pointer"), N_("Data Pointer"), NGRAPH_DATAPOINT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), DataB, ActionWidget + PointerModeData, }, { TOOL_TYPE_SEPARATOR, }, { TOOL_TYPE_RADIO, N_("Path"), N_("Path"), N_("New Legend Path (+SHIFT: Fine +CONTROL: snap angle)"), NGRAPH_LINE_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), PathB, }, { TOOL_TYPE_RADIO, N_("Rectangle"), N_("Rectangle"), N_("New Legend Rectangle (+SHIFT: Fine +CONTROL: square integer ratio rectangle)"), NGRAPH_RECT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), RectB, }, { TOOL_TYPE_RADIO, N_("Arc"), N_("Arc"), N_("New Legend Arc (+SHIFT: Fine +CONTROL: circle or integer ratio ellipse)"), NGRAPH_ARC_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), ArcB, }, { TOOL_TYPE_RADIO, N_("Mark"), N_("Mark"), N_("New Legend Mark (+SHIFT: Fine)"), NGRAPH_MARK_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), MarkB, }, { TOOL_TYPE_RADIO, N_("Text"), N_("Text"), N_("New Legend Text (+SHIFT: Fine)"), NGRAPH_TEXT_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), TextB, }, { TOOL_TYPE_RADIO, N_("Gauss"), N_("Gaussian"), N_("New Legend Gaussian (+SHIFT: Fine +CONTROL: integer ratio)"), NGRAPH_GAUSS_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), GaussB, }, { TOOL_TYPE_SEPARATOR, }, { TOOL_TYPE_RADIO, N_("Frame axis"), N_("Frame Graph"), N_("New Frame Graph (+SHIFT: Fine +CONTROL: integer ratio)"), NGRAPH_FRAME_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), FrameB, }, { TOOL_TYPE_RADIO, N_("Section axis"), N_("Section Graph"), N_("New Section Graph (+SHIFT: Fine +CONTROL: integer ratio)"), NGRAPH_SECTION_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), SectionB, }, { TOOL_TYPE_RADIO, N_("Cross axis"), N_("Cross Graph"), N_("New Cross Graph (+SHIFT: Fine +CONTROL: integer ratio)"), NGRAPH_CROSS_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), CrossB, }, { TOOL_TYPE_RADIO, N_("Single axis"), N_("Single Axis"), N_("New Single Axis (+SHIFT: Fine +CONTROL: snap angle)"), NGRAPH_SINGLE_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), SingleB, }, { TOOL_TYPE_SEPARATOR, }, { TOOL_TYPE_RADIO, N_("Trimming"), N_("Axis Trimming"), N_("Axis Trimming (+SHIFT: Fine)"), NGRAPH_TRIMMING_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), TrimB, }, { TOOL_TYPE_RADIO, N_("Evaluate"), N_("Evaluate Data"), N_("Evaluate Data Point"), NGRAPH_EVAL_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), EvalB, }, { TOOL_TYPE_RADIO, N_("Zoom"), N_("Viewer Zoom"), N_("Viewer Zoom-In (+CONTROL: Zoom-Out +SHIFT: Centering)"), NGRAPH_ZOOM_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmViewerButtonArm), ZoomB, }, }; static struct ToolItem CommandToolbar[] = { { TOOL_TYPE_RECENT_DATA, N_("_Add"), N_("Add Data"), N_("Add Data file"), "text-x-generic-symbolic", "/Data/Add", GDK_KEY_o, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmFileOpen), 0, NULL, "app.DataAddFileAction", }, { TOOL_TYPE_SEPARATOR, NULL, }, { TOOL_TYPE_RECENT_GRAPH, N_("_Load graph"), N_("Load NGP"), N_("Load NGP file"), "document-open-symbolic", "/Graph/Load graph", GDK_KEY_r, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmGraphLoad), 0, NULL, "app.GraphLoadAction", }, { TOOL_TYPE_SAVE, N_("_Save"), N_("Save NGP"), N_("Save NGP file"), "document-save-symbolic", "/Graph/Save", GDK_KEY_s, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmGraphOverWrite), 0, NULL, "app.GraphSaveAction", }, { TOOL_TYPE_SEPARATOR, NULL, }, { TOOL_TYPE_NORMAL, N_("Scale _Clear"), N_("Clear Scale"), N_("Clear Scale"), NGRAPH_SCALE_ICON, "/Edit/Copy", GDK_KEY_c, GDK_SHIFT_MASK | GDK_CONTROL_MASK, NULL, G_CALLBACK(CmAxisClear), 0, ActionWidget + AxisScaleClearAction, "app.AxisScaleClearAction", }, { TOOL_TYPE_DRAW, N_("_Draw"), N_("Draw"), N_("Draw on Viewer Window"), "ngraph_draw-symbolic", "/View/Draw", GDK_KEY_d, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmViewerDraw), FALSE, NULL, "app.ViewDrawDirectAction", }, { TOOL_TYPE_NORMAL, N_("_Print"), N_("Print"), N_("Print"), "document-print-symbolic", "/Graph/Print", GDK_KEY_p, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmOutputPrinterB), 0, NULL, "app.GraphPrintAction", }, { TOOL_TYPE_SEPARATOR, NULL, }, { TOOL_TYPE_NORMAL, N_("_Math Transformation"), N_("Math Transformation"), N_("Set Math Transformation"), "accessories-calculator-symbolic", NULL, 0, 0, NULL, G_CALLBACK(CmFileMath), 0, ActionWidget + DataMathAction, "app.DataMathAction", }, { TOOL_TYPE_NORMAL, N_("Scale _Undo"), N_("Scale Undo"), N_("Undo Scale Settings"), #if GTK_CHECK_VERSION(3, 10, 0) "edit-undo-symbolic", #else NGRAPH_UNDO_ICON, #endif NULL, 0, 0, NULL, G_CALLBACK(CmAxisScaleUndo), 0, ActionWidget + AxisScaleUndoAction, "app.AxisScaleUndoAction", }, }; struct MenuItem { enum { MENU_TYPE_NORMAL, MENU_TYPE_TOGGLE, MENU_TYPE_TOGGLE2, MENU_TYPE_RADIO, MENU_TYPE_RECENT_GRAPH, MENU_TYPE_RECENT_DATA, MENU_TYPE_SEPARATOR, MENU_TYPE_END, } type; const char *label; const char *tip; const char *caption; const char *icon; const char *accel_path; guint accel_key; GdkModifierType accel_mods; struct MenuItem *child; GCallback callback; int user_data; struct ActionWidget *action; const char *action_name; }; static struct MenuItem HelpMenu[] = { { MENU_TYPE_NORMAL, N_("_Help"), NULL, N_("Show the help document"), #if GTK_CHECK_VERSION(3, 10, 0) "help-browser", #else NULL, #endif "/Help/Help", GDK_KEY_F1, 0, NULL, G_CALLBACK(CmHelpHelp), 0, NULL, "help", }, { MENU_TYPE_NORMAL, N_("_About"), NULL, NULL, "help-about", "/Help/About", 0, 0, NULL, G_CALLBACK(CmHelpAbout), 0, NULL, "about", }, { MENU_TYPE_END, }, }; static struct MenuItem PreferenceMenu[] = { { MENU_TYPE_NORMAL, N_("_Viewer"), NULL, NULL, NULL, "/Preference/Viewer", 0, 0, NULL, G_CALLBACK(CmOptionViewer), 0, NULL, "PreferenceViewerAction", }, { MENU_TYPE_NORMAL, N_("_External viewer"), NULL, NULL, NULL, "/Preference/External Viewer", 0, 0, NULL, G_CALLBACK(CmOptionExtViewer), 0, NULL, "PreferenceExternalViewerAction", }, { MENU_TYPE_NORMAL, N_("_Font aliases"), NULL, NULL, NULL, "/Preference/Font aliases", 0, 0, NULL, G_CALLBACK(CmOptionPrefFont), 0, NULL, "PreferenceFontAction", }, { MENU_TYPE_NORMAL, N_("_Add-in script"), NULL, NULL, NULL, "/Preference/Addin Script", 0, 0, NULL, G_CALLBACK(CmOptionScript), 0, NULL, "PreferenceAddinAction", }, { MENU_TYPE_NORMAL, N_("_Miscellaneous"), NULL, NULL, NULL, "/Preference/Miscellaneous", 0, 0, NULL, G_CALLBACK(CmOptionMisc), 0, NULL, "PreferenceMiscAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("save as default (_Settings)"), NULL, NULL, NULL, "/Preference/save as default (Settings)", 0, 0, NULL, G_CALLBACK(CmOptionSaveDefault), 0, NULL, "PreferenceSaveSettingAction", }, { MENU_TYPE_NORMAL, N_("save as default (_Graph)"), NULL, NULL, NULL, "/Preference/save as default (Graph)", 0, 0, NULL, G_CALLBACK(CmOptionSaveNgp), 0, NULL, "PreferenceSaveGraphAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Data file default"), NULL, NULL, NULL, "/Preference/Data file default", 0, 0, NULL, G_CALLBACK(CmOptionFileDef), 0, NULL, "PreferenceDataDefaultAction", }, { MENU_TYPE_NORMAL, N_("_Legend text default"), NULL, NULL, NULL, "/Preference/Legend text default", 0, 0, NULL, G_CALLBACK(CmOptionTextDef), 0, NULL, "PreferenceTextDefaultAction", }, { MENU_TYPE_END, }, }; static struct MenuItem MergeMenu[] = { { MENU_TYPE_NORMAL, N_("_Add"), NULL, NULL, "list-add", "/Merge/Add", 0, 0, NULL, G_CALLBACK(CmMergeOpen), 0, NULL, "MergeAddAction", }, { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Merge/Property", 0, 0, NULL, G_CALLBACK(CmMergeUpdate), 0, ActionWidget + MergePropertyAction, "MergePropertyAction", }, { MENU_TYPE_NORMAL, N_("_Close"), NULL, NULL, "window-close", "/Merge/Close", 0, 0, NULL, G_CALLBACK(CmMergeClose), 0, ActionWidget + MergeCloseAction, "MergeCloseAction", }, { MENU_TYPE_END, }, }; static struct MenuItem LegendTextleMenu[] = { { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Legend/Text/Property", 0, 0, NULL, G_CALLBACK(CmTextUpdate), 0, ActionWidget + LegendTextPropertyAction, "LegendTextPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Legend/Text/Delete", 0, 0, NULL, G_CALLBACK(CmTextDel), 0, ActionWidget + LegendTextDeleteAction, "LegendTextDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem LegendMarkleMenu[] = { { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Legend/Mark/Property", 0, 0, NULL, G_CALLBACK(CmMarkUpdate), 0, ActionWidget + LegendMarkPropertyAction, "LegendMarkPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Legend/Mark/Delete", 0, 0, NULL, G_CALLBACK(CmMarkDel), 0, ActionWidget + LegendMarkDeleteAction, "LegendMarkDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem LegendArcMenu[] = { { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Legend/Arc/Property", 0, 0, NULL, G_CALLBACK(CmArcUpdate), 0, ActionWidget + LegendArcPropertyAction, "LegendArcPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Legend/Arc/Delete", 0, 0, NULL, G_CALLBACK(CmArcDel), 0, ActionWidget + LegendArcDeleteAction, "LegendArcDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem LegendRectangleMenu[] = { { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Legend/Rectangle/Property", 0, 0, NULL, G_CALLBACK(CmRectUpdate), 0, ActionWidget + LegendRectanglePropertyAction, "LegendRectanglePropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Legend/Rectangle/Delete", 0, 0, NULL, G_CALLBACK(CmRectDel), 0, ActionWidget + LegendRectangleDeleteAction, "LegendRectangleDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem LegendPathMenu[] = { { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Legend/Path/Property", 0, 0, NULL, G_CALLBACK(CmLineUpdate), 0, ActionWidget + LegendPathPropertyAction, "LegendPathPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Legend/Path/Delete", 0, 0, NULL, G_CALLBACK(CmLineDel), 0, ActionWidget + LegendPathDeleteAction, "LegendPathDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem AxisGridMenu[] = { { MENU_TYPE_NORMAL, N_("_Add"), NULL, NULL, "list-add", "/Axis/Grid/Add", 0, 0, NULL, G_CALLBACK(CmAxisGridNew), 0, NULL, "AxisGridNewAction", }, { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Axis/Grid/Property", 0, 0, NULL, G_CALLBACK(CmAxisGridUpdate), 0, ActionWidget + AxisGridPropertyAction, "AxisGridPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Axis/Grid/Delete", 0, 0, NULL, G_CALLBACK(CmAxisGridDel), 0, ActionWidget + AxisGridDeleteAction, "AxisGridDeleteAction", }, { MENU_TYPE_END, }, }; static struct MenuItem AxisAddMenu[] = { { MENU_TYPE_NORMAL, N_("_Frame graph"), NULL, NULL, NGRAPH_FRAME_ICON, "/Axis/Add/Frame graph", 0, 0, NULL, G_CALLBACK(CmAxisNewFrame), 0, NULL, "AxisAddFrameAction", }, { MENU_TYPE_NORMAL, N_("_Section graph"), NULL, NULL, NGRAPH_SECTION_ICON, "/Axis/Add/Section graph", 0, 0, NULL, G_CALLBACK(CmAxisNewSection), 0, NULL, "AxisAddSectionAction", }, { MENU_TYPE_NORMAL, N_("_Cross graph"), NULL, NULL, NGRAPH_CROSS_ICON, "/Axis/Add/Cross graph", 0, 0, NULL, G_CALLBACK(CmAxisNewCross), 0, NULL, "AxisAddCrossAction", }, { MENU_TYPE_NORMAL, N_("Single _Axis"), NULL, NULL, NGRAPH_SINGLE_ICON, "/Axis/Add/Single axis", 0, 0, NULL, G_CALLBACK(CmAxisNewSingle), 0, NULL, "AxisAddSingleAction", }, { MENU_TYPE_END, }, }; static struct MenuItem AxisMenu[] = { { MENU_TYPE_NORMAL, N_("_Add"), NULL, NULL, "list-add", NULL, 0, 0, AxisAddMenu, }, { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Axis/Property", 0, 0, NULL, G_CALLBACK(CmAxisUpdate), 0, ActionWidget + AxisPropertyAction, "AxisPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Axis/Delete", 0, 0, NULL, G_CALLBACK(CmAxisDel), 0, ActionWidget + AxisDeleteAction, "AxisDeleteAction", }, { MENU_TYPE_NORMAL, N_("Scale _Zoom"), NULL, NULL, NULL, "/Axis/Scale Zoom", 0, 0, NULL, G_CALLBACK(CmAxisZoom), 0, ActionWidget + AxisScaleZoomAction, "AxisScaleZoomAction", }, { MENU_TYPE_NORMAL, N_("Scale _Clear"), N_("Clear Scale"), N_("Clear Scale"), NGRAPH_SCALE_ICON, "/Axis/Scale Clear", GDK_KEY_c, GDK_SHIFT_MASK | GDK_CONTROL_MASK, NULL, G_CALLBACK(CmAxisClear), 0, ActionWidget + AxisScaleClearAction, "AxisScaleClearAction", }, { MENU_TYPE_NORMAL, N_("Scale _Undo"), N_("Scale Undo"), N_("Undo Scale Settings"), #if GTK_CHECK_VERSION(3, 10, 0) "edit-undo", #else NGRAPH_UNDO_ICON, #endif "/Axis/Scale Undo", 0, 0, NULL, G_CALLBACK(CmAxisScaleUndo), 0, ActionWidget + AxisScaleUndoAction, "AxisScaleUndoAction", }, { MENU_TYPE_NORMAL, N_("_Grid"), NULL, NULL, NULL, NULL, 0, 0, AxisGridMenu, }, { MENU_TYPE_END, }, }; static struct MenuItem PlotAddMenu[] = { { MENU_TYPE_NORMAL, N_("_File"), N_("Add data file"), N_("Add data file"), "text-x-generic", "/Data/Add/Data", GDK_KEY_o, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmFileOpen), 0, NULL, "DataAddFileAction", }, { MENU_TYPE_NORMAL, N_("_Range"), N_("Add range plot"), NULL, NULL, "/Data/Add/Range", 0, 0, NULL, G_CALLBACK(CmRangeAdd), 0, NULL, "DataAddRangeAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_RECENT_DATA, N_("_Recent files"), NULL, }, { MENU_TYPE_END, }, }; static struct MenuItem DataMenu[] = { { MENU_TYPE_NORMAL, N_("_Add"), NULL, NULL, NULL, NULL, 0, 0, PlotAddMenu, }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, "document-properties", "/Data/Property", 0, 0, NULL, G_CALLBACK(CmFileUpdate), 0, ActionWidget + DataPropertyAction, "DataPropertyAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, "/Data/Close", 0, 0, NULL, G_CALLBACK(CmFileClose), 0, ActionWidget + DataCloseAction, "DataCloseAction", }, { MENU_TYPE_NORMAL, N_("_Edit"), NULL, NULL, NULL, "/Data/Edit", 0, 0, NULL, G_CALLBACK(CmFileEdit), 0, ActionWidget + DataEditAction, "DataEditAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Save data"), NULL, NULL, NULL, "/Data/Save data", 0, 0, NULL, G_CALLBACK(CmFileSaveData), 0, ActionWidget + DataSaveAction, "DataSaveAction", }, { MENU_TYPE_NORMAL, N_("_Math Transformation"), N_("Math Transformation"), N_("Set Math Transformation"), NGRAPH_MATH_ICON, "/Data/Math", 0, 0, NULL, G_CALLBACK(CmFileMath), 0, ActionWidget + DataMathAction, "DataMathAction", }, { MENU_TYPE_END, }, }; static struct MenuItem ObjectMenu[] = { { MENU_TYPE_NORMAL, N_("_Data"), NULL, NULL, NULL, NULL, 0, 0, DataMenu, }, { MENU_TYPE_NORMAL, N_("_Axis"), NULL, NULL, NULL, NULL, 0, 0, AxisMenu, }, { MENU_TYPE_NORMAL, N_("_Path"), NULL, NULL, NGRAPH_LINE_ICON, NULL, 0, 0, LegendPathMenu, }, { MENU_TYPE_NORMAL, N_("_Rectangle"), NULL, NULL, NGRAPH_RECT_ICON, NULL, 0, 0, LegendRectangleMenu, }, { MENU_TYPE_NORMAL, N_("_Arc"), NULL, NULL, NGRAPH_ARC_ICON, NULL, 0, 0, LegendArcMenu, }, { MENU_TYPE_NORMAL, N_("_Mark"), NULL, NULL, NGRAPH_MARK_ICON, NULL, 0, 0, LegendMarkleMenu, }, { MENU_TYPE_NORMAL, N_("_Text"), NULL, NULL, NGRAPH_TEXT_ICON, NULL, 0, 0, LegendTextleMenu, }, { MENU_TYPE_NORMAL, N_("_Merge"), NULL, NULL, NULL, NULL, 0, 0, MergeMenu, }, { MENU_TYPE_END, }, }; static struct MenuItem ViewMenu[] = { { MENU_TYPE_NORMAL, N_("_Draw"), N_("Draw"), N_("Draw on Viewer Window"), NGRAPH_DRAW_ICON, "/View/Draw", GDK_KEY_d, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmViewerDraw), TRUE, NULL, "ViewDrawAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Clear information view"), NULL, NULL, NULL, "/View/Clear information window", 0, 0, NULL, G_CALLBACK(clear_information), 0, NULL, "ViewClearInformationWindowAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_TOGGLE, N_("_Sidebar"), NULL, NULL, NULL, "/View/Sidebar", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleSidebar, ActionWidget + ViewSidebarAction, "ViewSidebarAction", }, { MENU_TYPE_TOGGLE, N_("_Statusbar"), NULL, NULL, NULL, "/View/Statusbar", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleStatusbar, ActionWidget + ViewStatusbarAction, "ViewStatusbarAction", }, { MENU_TYPE_TOGGLE, N_("_Ruler"), NULL, NULL, NULL, "/View/Ruler", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleRuler, ActionWidget + ViewRulerAction, "ViewRulerAction", }, { MENU_TYPE_TOGGLE, N_("_Scrollbar"), NULL, NULL, NULL, "/View/Scrollbar", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleScrollbar, ActionWidget + ViewScrollbarAction, "ViewScrollbarAction", }, { MENU_TYPE_TOGGLE, N_("_Command toolbar"), NULL, NULL, NULL, "/View/Command toolbar", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleCToolbar, ActionWidget + ViewCommandToolbarAction, "ViewCommandToolbarAction", }, { MENU_TYPE_TOGGLE, N_("_Toolbox"), NULL, NULL, NULL, "/View/Toolbox", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdTogglePToolbar, ActionWidget + ViewToolboxAction, "ViewToolboxAction", }, { MENU_TYPE_TOGGLE, N_("cross _Gauge"), NULL, N_("Show cross gauge"), NULL, "/View/cross Gauge", GDK_KEY_g, GDK_CONTROL_MASK, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleCrossGauge, ActionWidget + ViewCrossGaugeAction, "ViewCrossGaugeAction", }, { MENU_TYPE_TOGGLE, N_("_Grid"), NULL, N_("Show grid"), NULL, "/View/grid Line", 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleGridLine, ActionWidget + ViewGridLineAction, "ViewGridLineAction", }, { MENU_TYPE_END, }, }; static struct MenuItem EditOrderMenu[] = { { MENU_TYPE_NORMAL, N_("_Top"), NULL, N_("Rise selection to top"), "go-top", "/Edit/draw Order/Top", GDK_KEY_Home, GDK_SHIFT_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderTop, ActionWidget + EditOrderTopAction, "EditOrderTopAction", }, { MENU_TYPE_NORMAL, N_("_Up"), NULL, N_("Rise selection one step"), "go-up", "/Edit/draw Order/Up", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderUp, ActionWidget + EditOrderUpAction, "EditOrderUpAction", }, { MENU_TYPE_NORMAL, N_("_Down"), NULL, N_("Lower selection one step"), "go-down", "/Edit/draw Order/Down", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderDown, ActionWidget + EditOrderDownAction, "EditOrderDownAction", }, { MENU_TYPE_NORMAL, N_("_Bottom"), NULL, N_("Lower selection to bottom"), "go-bottom", "/Edit/draw Order/Bottom", GDK_KEY_End, GDK_SHIFT_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderBottom, ActionWidget + EditOrderBottomAction, "EditOrderBottomAction", }, { MENU_TYPE_END, }, }; static struct MenuItem EditAlignMenu[] = { { MENU_TYPE_NORMAL, N_("Align _Left"), NULL, NULL, NGRAPH_ALIGN_L_ICON, "/Edit/Align/Left", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignLeft, ActionWidget + EditAlignLeftAction, "EditAlignLeftAction", }, { MENU_TYPE_NORMAL, N_("Align _Horizontal Center"), NULL, NULL, NGRAPH_ALIGN_HC_ICON, "/Edit/Align/Horizontal center", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignHCenter, ActionWidget + EditAlignHCenterAction, "EditAlignHCenterAction", }, { MENU_TYPE_NORMAL, N_("Align _Right"), NULL, NULL, NGRAPH_ALIGN_R_ICON, "/Edit/Align/Right", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignRight, ActionWidget + EditAlignRightAction, "EditAlignRightAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("Align _Top"), NULL, NULL, NGRAPH_ALIGN_T_ICON, "/Edit/Align/Top", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignTop, ActionWidget + EditAlignTopAction, "EditAlignTopAction", }, { MENU_TYPE_NORMAL, N_("Align _Vertical Center"), NULL, NULL, NGRAPH_ALIGN_VC_ICON, "/Edit/Align/Vertical center", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignVCenter, ActionWidget + EditAlignVCenterAction, "EditAlignVCenterAction", }, { MENU_TYPE_NORMAL, N_("Align _Bottom"), NULL, NULL, NGRAPH_ALIGN_B_ICON, "/Edit/Align/Bottom", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignBottom, ActionWidget + EditAlignBottomAction, "EditAlignBottomAction", }, { MENU_TYPE_END, }, }; static struct MenuItem EditMenu[] = { { MENU_TYPE_NORMAL, N_("_Redo"), NULL, N_("Redo previous command"), NULL, "/Edit/Redo", GDK_KEY_y, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditRedo, ActionWidget + EditRedoAction, "EditRedoAction", }, { MENU_TYPE_NORMAL, N_("_Undo"), NULL, N_("Undo previous command"), NULL, "/Edit/Undo", GDK_KEY_z, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditUndo, ActionWidget + EditUndoAction, "EditUndoAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("Cu_t"), NULL, N_("Cut selected object to clipboard"), NULL, "/Edit/Cut", GDK_KEY_x, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditCut, ActionWidget + EditCutAction, "EditCutAction", }, { MENU_TYPE_NORMAL, N_("_Copy"), NULL, N_("Copy selected object to clipboard"), NULL, "/Edit/Copy", GDK_KEY_c, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditCopy, ActionWidget + EditCopyAction, "EditCopyAction", }, { MENU_TYPE_NORMAL, N_("_Paste"), NULL, N_("Paste object from clipboard"), NULL, "/Edit/Paste", GDK_KEY_v, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditPaste, ActionWidget + EditPasteAction, "EditPasteAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, N_("Delete the selected object"), NULL, "/Edit/Delete", GDK_KEY_Delete, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditDelete, ActionWidget + EditDeleteAction, "EditDeleteAction", }, { MENU_TYPE_NORMAL, N_("_Duplicate"), NULL, N_("Duplicate the selected object"), NULL, "/Edit/Duplicate", GDK_KEY_Insert, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditDuplicate, ActionWidget + EditDuplicateAction, "EditDuplicateAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("draw _Order"), NULL, NULL, NULL, NULL, 0, 0, EditOrderMenu, }, { MENU_TYPE_NORMAL, N_("_Align"), NULL, NULL, NULL, NULL, 0, 0, EditAlignMenu, }, { MENU_TYPE_NORMAL, N_("rotate _90 degree clockwise"), NULL, NULL, NULL, "/Edit/RotateCW", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditRotateCW, ActionWidget + EditRotateCWAction, "EditRotateCWAction", }, { MENU_TYPE_NORMAL, N_("rotate 9_0 degree counter-clockwise"), NULL, NULL, NULL, "/Edit/RotateCCW", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditRotateCCW, ActionWidget + EditRotateCCWAction, "EditRotateCCWAction", }, { MENU_TYPE_NORMAL, N_("flip _Horizontally"), NULL, NULL, NULL, "/Edit/FlipHorizontally", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditFlipHorizontally, ActionWidget + EditFlipHAction, "EditFlipHAction", }, { MENU_TYPE_NORMAL, N_("flip _Vertically"), NULL, NULL, NULL, "/Edit/FlipVertically", 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditFlipVertically, ActionWidget + EditFlipVAction, "EditFlipVActiopn", }, { MENU_TYPE_END, }, }; static struct MenuItem GraphNewMenu[] = { { MENU_TYPE_NORMAL, N_("_Frame graph"), N_("Create frame graph"), NULL, NGRAPH_FRAME_ICON, "/Graph/New graph/Frame graph", 0, 0, NULL, G_CALLBACK(CmGraphNewMenu), MenuIdGraphNewFrame, NULL, "GraphNewFrameAction", }, { MENU_TYPE_NORMAL, N_("_Section graph"), N_("Create section graph"), NULL, NGRAPH_SECTION_ICON, "/Graph/New graph/Section graph", 0, 0, NULL, G_CALLBACK(CmGraphNewMenu), MenuIdGraphNewSection, NULL, "GraphNewSectionAction", }, { MENU_TYPE_NORMAL, N_("_Cross graph"), N_("Create cross graph"), NULL, NGRAPH_CROSS_ICON, "/Graph/New graph/Cross graph", 0, 0, NULL, G_CALLBACK(CmGraphNewMenu), MenuIdGraphNewCross, NULL, "GraphNewCrossAction", }, { MENU_TYPE_NORMAL, N_("_All clear"), N_("Clear graph"), NULL, NULL, "/Graph/New graph/All clear", 0, 0, NULL, G_CALLBACK(CmGraphNewMenu), MenuIdGraphAllClear, NULL, "GraphNewClearAction", }, { MENU_TYPE_END, }, }; static struct MenuItem GraphExportMenu[] = { { MENU_TYPE_NORMAL, N_("_GRA file"), N_("Export as GRA file"), NULL, NULL, "/Graph/Export image/GRA File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputGRAFile, NULL, "GraphExportGRAAction", }, { MENU_TYPE_NORMAL, N_("_PS file"), N_("Export as PostScript file"), NULL, NULL, "/Graph/Export image/PS File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputPSFile, NULL, "GraphExportPSAction", }, { MENU_TYPE_NORMAL, N_("_EPS file"), N_("Export as Encapsulate PostScript file"), NULL, NULL, "/Graph/Export image/EPS File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputEPSFile, NULL, "GraphExportEPSAction", }, { MENU_TYPE_NORMAL, N_("P_DF file"), N_("Export as Portable Document Format"), NULL, NULL, "/Graph/Export image/PDF File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputPDFFile, NULL, "GraphExportPDFAction", }, { MENU_TYPE_NORMAL, N_("_SVG file"), N_("Export as Scalable Vector Graphics file"), NULL, NULL, "/Graph/Export image/SVG File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputSVGFile, NULL, "GraphExportSVGAction", }, { MENU_TYPE_NORMAL, N_("P_NG file"), N_("Export as Portable Network Graphics file"), NULL, NULL, "/Graph/Export image/PNG File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputPNGFile, NULL, "GraphExportPNGAction", }, #if WINDOWS { MENU_TYPE_NORMAL, N_("_EMF file"), N_("Export as Windows Enhanced Metafile"), NULL, NULL, "/Graph/Export image/EMF File", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputEMFFile, NULL, "GraphExportEMFAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Clipboard (EMF)"), N_("Copy to the clipboard as Windows Enhanced Metafile "), NULL, NULL, "/Graph/Export image/Clipboard", 0, 0, NULL, G_CALLBACK(CmOutputMenu), MenuIdOutputEMFClipboard, NULL, "GraphExportEMFClipboardAction", }, #endif /* WINDOWS */ { MENU_TYPE_END, }, }; static struct MenuItem GraphMenu[] = { { MENU_TYPE_NORMAL, N_("_New graph"), NULL, NULL, NULL, NULL, 0, 0, GraphNewMenu, }, { MENU_TYPE_NORMAL, N_("_Load graph"), N_("Load NGP"), N_("Load a graph (NGP file)"), "document-open", "/Graph/Load graph", GDK_KEY_r, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmGraphLoad), 0, NULL, "GraphLoadAction", }, { MENU_TYPE_RECENT_GRAPH, N_("_Recent graphs"), NULL, NULL, NULL, }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Save"), N_("Save NGP"), N_("Save the graph"), "document-save", "/Graph/Save", GDK_KEY_s, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmGraphOverWrite), 0, ActionWidget + GraphSaveAction, "GraphSaveAction", }, { MENU_TYPE_NORMAL, N_("Save _As"), N_("Save NGP"), N_("Save the graph with a new filename"), "document-save-as", "/Graph/SaveAs", GDK_KEY_s, GDK_CONTROL_MASK | GDK_SHIFT_MASK, NULL, G_CALLBACK(CmGraphSave), 0, NULL, "GraphSaveAsAction", }, { MENU_TYPE_NORMAL, N_("_Export image"), NULL, NULL, NULL, NULL, 0, 0, GraphExportMenu, }, { MENU_TYPE_SEPARATOR, }, { MENU_TYPE_NORMAL, N_("_Draw order"), NULL, NULL, NULL, "/Graph/Draw order", 0, 0, NULL, G_CALLBACK(CmGraphSwitch), 0, NULL, "GraphDrawOrderAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("Page Set_up"), NULL, NULL, #if GTK_CHECK_VERSION(3, 10, 0) "document-page-setup", #else NULL, #endif "/Graph/Page", 0, 0, NULL, G_CALLBACK(CmGraphPage), 0, NULL, "GraphPageSetupAction", }, { MENU_TYPE_NORMAL, N_("Pre_view"), N_("Print preview"), N_("Print preview"), NULL, "/Graph/Print preview", 0, 0, NULL, G_CALLBACK(CmOutputViewerB), 0, NULL, "GraphPrintPreviewAction", }, { MENU_TYPE_NORMAL, N_("_Print"), N_("Print"), N_("Print the graph"), "document-print", "/Graph/Print", GDK_KEY_p, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmOutputPrinterB), 0, NULL, "GraphPrintAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Current directory"), NULL, NULL, NULL, "/Graph/Current directory", 0, 0, NULL, G_CALLBACK(CmGraphDirectory), 0, NULL, "GraphCurrentDirectoryAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Ngraph shell"), NULL, NULL, NULL, "/Graph/Ngraph shell", 0, 0, NULL, G_CALLBACK(CmGraphShell), 0, NULL, "GraphShellAction", }, { MENU_TYPE_NORMAL, N_("_Add-in"), NULL, NULL, NULL, NULL, 0, 0, NULL, NULL, 0, ActionWidget + AddinAction, }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Quit"), NULL, N_("Quit the application"), "application-exit", "/Graph/Quit", GDK_KEY_q, GDK_CONTROL_MASK, NULL, G_CALLBACK(CmGraphQuit), 0, NULL, "quit", }, { MENU_TYPE_END, }, }; static struct MenuItem MainMenu[] = { { MENU_TYPE_NORMAL, N_("_Graph"), NULL, NULL, NULL, NULL, 0, 0, GraphMenu, }, { MENU_TYPE_NORMAL, N_("_Edit"), NULL, NULL, NULL, NULL, 0, 0, EditMenu, NULL, 0, ActionWidget + EditMenuAction, }, { MENU_TYPE_NORMAL, N_("_View"), NULL, NULL, NULL, NULL, 0, 0, ViewMenu, }, { MENU_TYPE_NORMAL, N_("_Object"), NULL, NULL, NULL, NULL, 0, 0, ObjectMenu, }, { MENU_TYPE_NORMAL, N_("_Preference"), NULL, NULL, NULL, NULL, 0, 0, PreferenceMenu, }, { MENU_TYPE_NORMAL, N_("_Help"), NULL, NULL, NULL, NULL, 0, 0, HelpMenu, }, { MENU_TYPE_END, }, }; static struct MenuItem SaveMenu[] = { { MENU_TYPE_NORMAL, N_("_Save"), N_("Save NGP"), N_("Save the graph"), "document-save", "/Graph/Save", GDK_KEY_s, GDK_CONTROL_MASK, NULL, #if USE_GTK_BUILDER NULL, #else G_CALLBACK(CmGraphOverWrite), #endif 0, ActionWidget + GraphSaveAction, "GraphSaveAction", }, { MENU_TYPE_NORMAL, N_("Save _As"), N_("Save NGP"), NULL, "document-save-as", "/Graph/SaveAs", GDK_KEY_s, GDK_CONTROL_MASK | GDK_SHIFT_MASK, NULL, G_CALLBACK(CmGraphSave), 0, NULL, "GraphSaveAsAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Export image"), NULL, NULL, NULL, NULL, 0, 0, GraphExportMenu, }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("_Save data"), NULL, NULL, NULL, "/Data/Save data", 0, 0, NULL, #if USE_GTK_BUILDER NULL, #else G_CALLBACK(CmFileSaveData), #endif 0, ActionWidget + DataSaveAction, "DataSaveAction", }, { MENU_TYPE_END, }, }; static struct MenuItem PopupRotateMenu[] = { { MENU_TYPE_NORMAL, N_("rotate _90 degree clockwise"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditRotateCW, ActionWidget + EditRotateCWAction, "EditRotateCWAction", }, { MENU_TYPE_NORMAL, N_("rotate 9_0 degree counter-clockwise"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditRotateCCW, ActionWidget + EditRotateCCWAction, "EditRotateCCWAction", }, { MENU_TYPE_END, }, }; static struct MenuItem PopupFlipMenu[] = { { MENU_TYPE_NORMAL, N_("flip _Horizontally"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditFlipHorizontally, ActionWidget + EditFlipHAction, "EditFlipHAction", }, { MENU_TYPE_NORMAL, N_("flip _Vertically"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditFlipVertically, ActionWidget + EditFlipVAction, "EditFlipVActiopn", }, { MENU_TYPE_END, }, }; static struct MenuItem PopupAlignMenu[] = { { MENU_TYPE_NORMAL, N_("Align _Left"), NULL, NULL, NGRAPH_ALIGN_L_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignLeft, ActionWidget + EditAlignLeftAction, "EditAlignLeftAction", }, { MENU_TYPE_NORMAL, N_("Align _Horizontal Center"), NULL, NULL, NGRAPH_ALIGN_HC_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignHCenter, ActionWidget + EditAlignHCenterAction, "EditAlignHCenterAction", }, { MENU_TYPE_NORMAL, N_("Align _Right"), NULL, NULL, NGRAPH_ALIGN_R_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignRight, ActionWidget + EditAlignRightAction, "EditAlignRightAction", }, { MENU_TYPE_SEPARATOR, NULL, }, { MENU_TYPE_NORMAL, N_("Align _Top"), NULL, NULL, NGRAPH_ALIGN_T_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignTop, ActionWidget + EditAlignTopAction, "EditAlignTopAction", }, { MENU_TYPE_NORMAL, N_("Align _Vertical Center"), NULL, NULL, NGRAPH_ALIGN_VC_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignVCenter, ActionWidget + EditAlignVCenterAction, "EditAlignVCenterAction", }, { MENU_TYPE_NORMAL, N_("Align _Bottom"), NULL, NULL, NGRAPH_ALIGN_B_ICON, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdAlignBottom, ActionWidget + EditAlignBottomAction, "EditAlignBottomAction", }, { MENU_TYPE_END, }, }; static struct MenuItem PopupMenu[] = { { MENU_TYPE_NORMAL, "Cu_t", NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditCut, ActionWidget + EditCutAction, "EditCutAction", }, { MENU_TYPE_NORMAL, N_("_Copy"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditCopy, ActionWidget + EditCopyAction, "EditCopyAction", }, { MENU_TYPE_NORMAL, N_("_Paste"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditPaste, ActionWidget + EditPasteAction, "EditPasteAction", }, { MENU_TYPE_NORMAL, N_("_Delete"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditDelete, ActionWidget + EditDeleteAction, "EditDeleteAction", }, { MENU_TYPE_NORMAL, N_("_Duplicate"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditDuplicate, ActionWidget + EditDuplicateAction, "EditDuplicateAction", }, { MENU_TYPE_SEPARATOR, }, { MENU_TYPE_NORMAL, N_("_Properties"), NULL, NULL, NULL, "/Popup/Update", 0, 0, NULL, G_CALLBACK(ViewerUpdateCB), 0, ActionWidget + PopupUpdateAction, "PopupUpdateAction", }, { MENU_TYPE_SEPARATOR, }, { MENU_TYPE_NORMAL, N_("_Align"), NULL, NULL, NULL, NULL, 0, 0, PopupAlignMenu, }, { MENU_TYPE_NORMAL, N_("_Rotate"), NULL, NULL, NULL, NULL, 0, 0, PopupRotateMenu, }, { MENU_TYPE_NORMAL, N_("_Flip"), NULL, NULL, NULL, NULL, 0, 0, PopupFlipMenu, }, { MENU_TYPE_SEPARATOR, }, { MENU_TYPE_NORMAL, N_("_Top"), NULL, NULL, "go-top", NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderTop, ActionWidget + EditOrderTopAction, "EditOrderTopAction", }, { MENU_TYPE_NORMAL, N_("_Up"), NULL, NULL, "go-up", NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderUp, ActionWidget + EditOrderUpAction, "EditOrderUpAction", }, { MENU_TYPE_NORMAL, N_("_Down"), NULL, NULL, "go-down", NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderDown, ActionWidget + EditOrderDownAction, "EditOrderDownAction", }, { MENU_TYPE_NORMAL, N_("_Bottom"), NULL, NULL, "go-bottom", NULL, 0, 0, NULL, G_CALLBACK(CmEditMenuCB), MenuIdEditOrderBottom, ActionWidget + EditOrderBottomAction, "EditOrderBottomAction", }, { MENU_TYPE_SEPARATOR, }, { MENU_TYPE_TOGGLE, N_("cross _Gauge"), NULL, NULL, NULL, NULL, 0, 0, NULL, G_CALLBACK(toggle_view_cb), MenuIdToggleCrossGauge, ActionWidget + ViewCrossGaugeAction, "ViewCrossGaugeAction", }, { MENU_TYPE_END, }, }; void set_pointer_mode(int id) { if (id < 0) { id = DefaultMode; } switch (id) { case PointerModeBoth: case PointerModeLegend: case PointerModeAxis: case PointerModeData: gtk_toggle_tool_button_set_active(GTK_TOGGLE_TOOL_BUTTON(ActionWidget[id].tool), TRUE); break; } } static void init_action_widget_list(void) { int i; for (i = 0; i < ActionWidgetNum; i++) { ActionWidget[i].menu = NULL; ActionWidget[i].tool = NULL; ActionWidget[i].popup = NULL; switch (i) { case GraphSaveAction: ActionWidget[i].type = ACTION_TYPE_MODIFIED; break; case EditCutAction: case EditCopyAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_EDIT1; break; case EditRotateCCWAction: case EditRotateCWAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_ROTATE; break; case EditFlipVAction: case EditFlipHAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_FLIP; break; case EditDeleteAction: case EditDuplicateAction: case EditAlignLeftAction: case EditAlignRightAction: case EditAlignHCenterAction: case EditAlignTopAction: case EditAlignBottomAction: case EditAlignVCenterAction: case PopupUpdateAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_EDIT2; break; case EditOrderTopAction: case EditOrderUpAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_UP; break; case EditOrderDownAction: case EditOrderBottomAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_DOWN; break; case EditPasteAction: ActionWidget[i].type = ACTION_TYPE_FOCUS_EDIT_PASTE; break; case DataPropertyAction: case DataCloseAction: case DataEditAction: case DataSaveAction: case DataMathAction: ActionWidget[i].type = ACTION_TYPE_FILE; break; case AxisPropertyAction: case AxisDeleteAction: case AxisScaleZoomAction: case AxisScaleClearAction: ActionWidget[i].type = ACTION_TYPE_AXIS; break; case AxisGridPropertyAction: case AxisGridDeleteAction: ActionWidget[i].type = ACTION_TYPE_GRID; break; case AxisScaleUndoAction: ActionWidget[i].type = ACTION_TYPE_AXIS_UNDO; break; case LegendPathPropertyAction: case LegendPathDeleteAction: ActionWidget[i].type = ACTION_TYPE_PATH; break; case LegendRectanglePropertyAction: case LegendRectangleDeleteAction: ActionWidget[i].type = ACTION_TYPE_RECTANGLE; break; case LegendArcPropertyAction: case LegendArcDeleteAction: ActionWidget[i].type = ACTION_TYPE_ARC; break; case LegendMarkPropertyAction: case LegendMarkDeleteAction: ActionWidget[i].type = ACTION_TYPE_MARK; break; case LegendTextPropertyAction: case LegendTextDeleteAction: ActionWidget[i].type = ACTION_TYPE_TEXT; break; case MergePropertyAction: case MergeCloseAction: ActionWidget[i].type = ACTION_TYPE_MERGE; break; default: ActionWidget[i].type = ACTION_TYPE_NONE; } } } void set_current_window(GtkWidget *w) { CurrentWindow = w; } GtkWidget * get_current_window(void) { return (CurrentWindow) ? CurrentWindow : TopLevel; } void menu_lock(int lock) { GtkWidget *w; static int count = 0; if (lock) { count++; } else { count--; } if (count > 0) { Menulock = TRUE; } else { Menulock = FALSE; count = 0; } if (NgraphApp.Viewer.menu == NULL) { return; } gtk_widget_set_sensitive(NgraphApp.Viewer.menu, ! Menulock); w = gtk_paned_get_child1(GTK_PANED(NgraphApp.Viewer.main_pane)); if (w) { gtk_widget_set_sensitive(w, ! Menulock); } } static void set_action_widget_sensitivity(int id, int state) { #if USE_GTK_BUILDER if (ActionWidget[id].action) { g_simple_action_set_enabled(G_SIMPLE_ACTION(ActionWidget[id].action), state); } #else if (ActionWidget[id].menu) { gtk_widget_set_sensitive(ActionWidget[id].menu, state); } if (ActionWidget[id].tool) { gtk_widget_set_sensitive(GTK_WIDGET(ActionWidget[id].tool), state); } if (ActionWidget[id].popup) { gtk_widget_set_sensitive(ActionWidget[id].popup, state); } #endif } void set_axis_undo_button_sensitivity(int state) { set_action_widget_sensitivity(AxisScaleUndoAction, state); } void set_draw_lock(int lock) { DrawLock = lock; } #if ! WINDOWS static void kill_signal_handler(int sig) { if (Menulock || check_paint_lock()) { set_interrupt(); /* accept SIGINT */ } else { Hide_window = APP_QUIT; } } static void term_signal_handler(int sig) { Hide_window = APP_QUIT_FORCE; } #endif /* WINDOWS */ static int AppMainLoop(void) { Hide_window = APP_CONTINUE; while (TRUE) { gtk_main_iteration(); if (Hide_window != APP_CONTINUE && ! gtk_events_pending()) { int state = Hide_window; Hide_window = APP_CONTINUE; switch (state) { case APP_QUIT: if (CheckSave()) { menu_clear_undo(); return 0; } break; case APP_QUIT_FORCE: menu_clear_undo(); return 1; } } } return 0; } void reset_event(void) { while (gtk_events_pending()) { gtk_main_iteration(); } } struct WmStateHint { unsigned long state; GtkWindow icon; }; static gboolean CloseCallback(GtkWidget *w, GdkEvent *event, gpointer user_data) { CmGraphQuit(NULL, user_data); return TRUE; } void QuitGUI(void) { if (TopLevel) { Hide_window = TRUE; } } int find_gra2gdk_inst(struct objlist **o, N_VALUE **i, struct objlist **ro, int *routput, struct gra2cairo_local **rlocal) { static struct objlist *obj = NULL, *robj = NULL; static int pos; N_VALUE *inst = NULL; int id; if (obj == NULL) { obj = chkobject("gra2gdk"); pos = getobjtblpos(obj, "_output", &robj); } if (obj == NULL) return FALSE; inst = chkobjinst(obj, 0); if (inst == NULL) { id = newobj(obj); if (id < 0) return FALSE; inst = chkobjinst(obj, 0); } if (inst == NULL) { return FALSE; } _getobj(obj, "_local", inst, rlocal); *routput = pos; *i = inst; *o = obj; *ro = robj; return TRUE; } #if USE_GTK_BUILDER #define ADDIN_MENU_SECTION_INDEX 6 static void add_addin_menu(void) { GMenuModel *menu; GMenu *addin_menu; struct script *fcur; GMenuItem *item; int i, n; char buf[1024]; menu = gtk_application_get_menubar(GtkApp); if (menu == NULL) { return; } menu = g_menu_model_get_item_link(G_MENU_MODEL(menu), 0, G_MENU_LINK_SUBMENU); if (menu == NULL) { return; } n = g_menu_model_get_n_items(menu); if (n < ADDIN_MENU_SECTION_INDEX) { return; } menu = g_menu_model_get_item_link(menu, ADDIN_MENU_SECTION_INDEX, G_MENU_LINK_SECTION); if (menu == NULL) { return; } n = g_menu_model_get_n_items(menu); if (n > 1) { g_menu_remove(G_MENU(menu), 0); } addin_menu = g_menu_new(); i = 0; fcur = Menulocal.scriptroot; while (fcur) { if (fcur->name && fcur->script) { snprintf(buf, sizeof(buf), "app.GraphAddinAction(%d)", i); item = g_menu_item_new(fcur->name, buf); g_menu_append_item(addin_menu, item); } fcur = fcur->next; i++; } g_menu_prepend_submenu(G_MENU(menu), _("_Add-in"), G_MENU_MODEL(addin_menu)); } #endif void create_addin_menu(void) { GtkWidget *menu, *item, *parent; struct script *fcur; parent = ActionWidget[AddinAction].menu; if (parent == NULL) { return; } gtk_widget_set_sensitive(parent, Menulocal.scriptroot != NULL); if (Menulocal.scriptroot == NULL) { return; } menu = gtk_menu_item_get_submenu(GTK_MENU_ITEM(parent)); if (menu) { gtk_widget_destroy(menu); } menu = gtk_menu_new(); gtk_menu_item_set_submenu(GTK_MENU_ITEM(parent), menu); fcur = Menulocal.scriptroot; while (fcur) { if (fcur->name && fcur->script) { item = gtk_menu_item_new_with_mnemonic(fcur->name); g_signal_connect(item, "activate", G_CALLBACK(script_exec), fcur); gtk_menu_shell_append(GTK_MENU_SHELL(menu), GTK_WIDGET(item)); if (Menulocal.showtip && fcur->description) { gtk_widget_set_tooltip_text(item, fcur->description); } } fcur = fcur->next; } gtk_widget_show_all(menu); #if USE_GTK_BUILDER add_addin_menu(); #endif } static void set_focus_sensitivity_sub(const struct Viewer *d, int insensitive) { int i, num, type, state, up_state, down_state; GtkClipboard *clip; num = check_focused_obj_type(d, &type); up_state = down_state = FALSE; if (num == 1 && (type & (FOCUS_OBJ_TYPE_LEGEND | FOCUS_OBJ_TYPE_MERGE))) { int id, last_id; struct FocusObj *focus; focus= * (struct FocusObj **) arraynget(d->focusobj, 0); id = chkobjoid(focus->obj, focus->oid); last_id = chkobjlastinst(focus->obj); up_state = (id > 0); down_state = (id < last_id); } for (i = 0; i < ActionWidgetNum; i++) { switch (ActionWidget[i].type) { case ACTION_TYPE_FOCUS_EDIT1: if (insensitive) { state = FALSE; } else { state = (! (type & FOCUS_OBJ_TYPE_AXIS) && (type & (FOCUS_OBJ_TYPE_MERGE | FOCUS_OBJ_TYPE_LEGEND))); } set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_EDIT2: if (insensitive) { state = FALSE; } else { state = (type & (FOCUS_OBJ_TYPE_AXIS | FOCUS_OBJ_TYPE_LEGEND | FOCUS_OBJ_TYPE_MERGE)); } set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_EDIT_PASTE: if (insensitive) { state = FALSE; } else { switch (d->Mode) { case PointB: case LegendB: clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); state = gtk_clipboard_wait_is_text_available(clip); break; default: state = FALSE; } } set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_ROTATE: if (insensitive) { state = FALSE; } else { state = (! (type & FOCUS_OBJ_TYPE_MERGE) && (type & (FOCUS_OBJ_TYPE_AXIS | FOCUS_OBJ_TYPE_LEGEND))); } set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_FLIP: if (insensitive) { state = FALSE; } else { state = (! (type & (FOCUS_OBJ_TYPE_MERGE | FOCUS_OBJ_TYPE_TEXT)) && (type & (FOCUS_OBJ_TYPE_AXIS | FOCUS_OBJ_TYPE_LEGEND))); } set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_UP: state = up_state; set_action_widget_sensitivity(i, state); break; case ACTION_TYPE_FOCUS_DOWN: state = down_state; set_action_widget_sensitivity(i, state); break; default: continue; } } } void set_focus_insensitive(const struct Viewer *d) { set_focus_sensitivity_sub(d, TRUE); } void set_focus_sensitivity(const struct Viewer *d) { set_focus_sensitivity_sub(d, FALSE); } static void clear_information(void *w, gpointer user_data) { InfoWinClear(); } static char * get_home(void) { struct objlist *sysobj; N_VALUE *inst; char *home; sysobj = chkobject("system"); inst = chkobjinst(sysobj, 0); _getobj(sysobj, "home_dir", inst, &home); return home; } #if ! USE_GTK_BUILDER static void read_keymap_file(void) { char *home, *filename; home = get_home(); if (home == NULL) { filename = g_strdup_printf("%s/%s", home, KEYMAP_FILE); if (naccess(filename, R_OK) == 0) { gtk_accel_map_load(filename); g_free(filename); return; } g_free(filename); } filename = g_strdup_printf("%s/%s", CONFDIR, KEYMAP_FILE); if (naccess(filename, R_OK) == 0) { gtk_accel_map_load(filename); } g_free(filename); } #endif static void create_markpixmap(GtkWidget *win) { cairo_surface_t *pix; int gra, i, R, G, B, R2, G2, B2, found, output; struct objlist *obj, *robj; N_VALUE *inst; struct gra2cairo_local *local; GdkWindow *window; R = G = B = 0; R2 = 0; G2 = B2 = 255; window = gtk_widget_get_window(win); found = find_gra2gdk_inst(&obj, &inst, &robj, &output, &local); for (i = 0; i < MARK_TYPE_NUM; i++) { pix = NULL; if (window && found) { pix = gra2gdk_create_pixmap(local, MARK_PIX_SIZE, MARK_PIX_SIZE, 1.0, 1.0, 1.0); if (pix) { gra = _GRAopen("gra2gdk", "_output", robj, inst, output, -1, -1, -1, NULL, local); if (gra >= 0) { GRAview(gra, 0, 0, MARK_PIX_SIZE, MARK_PIX_SIZE, 0); GRAlinestyle(gra, 0, NULL, 1, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); GRAmark(gra, i, MARK_PIX_SIZE / 2, MARK_PIX_SIZE / 2, MARK_PIX_SIZE - 4, R, G, B, 255, R2, G2, B2, 255); } _GRAclose(gra); } } NgraphApp.markpix[i] = pix; } } static void free_markpixmap(void) { int i; for (i = 0; i < MARK_TYPE_NUM; i++) { if (NgraphApp.markpix[i]) { cairo_surface_destroy(NgraphApp.markpix[i]); } NgraphApp.markpix[i] = NULL; } } static void create_icon(void) { GList *tmp, *list = NULL; GdkPixbuf *pixbuf; pixbuf = gdk_pixbuf_new_from_resource(NGRAPH_SVG_ICON_FILE, NULL); if (pixbuf) { list = g_list_append(list, pixbuf); } pixbuf = gdk_pixbuf_new_from_resource(NGRAPH_ICON_FILE, NULL); if (pixbuf) { list = g_list_append(list, pixbuf); } pixbuf = gdk_pixbuf_new_from_resource(NGRAPH_ICON64_FILE, NULL); if (pixbuf) { list = g_list_append(list, pixbuf); } if (list) { gtk_window_set_default_icon_list(list); gtk_window_set_icon_list(GTK_WINDOW(TopLevel), list); tmp = list; while (tmp) { g_object_unref(tmp->data); tmp = tmp->next; } g_list_free(list); } } static int create_cursor(void) { unsigned int i; NgraphApp.cursor = g_malloc(sizeof(GdkCursor *) * CURSOR_TYPE_NUM); if (NgraphApp.cursor == NULL) return 1; for (i = 0; i < CURSOR_TYPE_NUM; i++) { NgraphApp.cursor[i] = gdk_cursor_new_for_display(gdk_display_get_default(), Cursor[i]); } return 0; } static void free_cursor(void) { unsigned int i; for (i = 0; i < CURSOR_TYPE_NUM; i++) { g_object_unref(NgraphApp.cursor[i]); NgraphApp.cursor[i] = NULL; } g_free(NgraphApp.cursor); NgraphApp.cursor = NULL; } static gboolean tool_button_enter_leave_cb(GtkWidget *w, GdkEventCrossing *e, gpointer data) { char *str; str = (char *) data; if (e->type == GDK_ENTER_NOTIFY) { SetStatusBar(str); } else { ResetStatusBar(); } return FALSE; } static GtkWidget * create_message_box(GtkWidget **label1, GtkWidget **label2) { GtkWidget *frame, *w, *hbox; frame = gtk_frame_new(NULL); gtk_frame_set_shadow_type(GTK_FRAME(frame), GTK_SHADOW_IN); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_label_new(NULL); gtk_widget_set_halign(w, GTK_ALIGN_END); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); *label1 = w; w = gtk_label_new(NULL); gtk_widget_set_halign(w, GTK_ALIGN_START); gtk_label_set_width_chars(GTK_LABEL(w), 16); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); *label2 = w; gtk_container_add(GTK_CONTAINER(frame), hbox); return frame; } #define OBJ_ID_KEY "ngraph_object_id" static void setup_object_tab(struct SubWin *win, GtkWidget *tab, const char *icon_name, const char *tip) { GtkWidget *icon; int obj_id; obj_id = chkobjectid(win->data.data->obj); g_object_set_data(G_OBJECT(win->Win), OBJ_ID_KEY, GINT_TO_POINTER(obj_id)); icon = gtk_image_new_from_icon_name(icon_name, GTK_ICON_SIZE_LARGE_TOOLBAR); gtk_widget_set_tooltip_text(icon, tip); gtk_notebook_append_page(GTK_NOTEBOOK(tab), win->Win, icon); gtk_notebook_set_tab_detachable(GTK_NOTEBOOK(tab), win->Win, TRUE); gtk_notebook_set_tab_reorderable(GTK_NOTEBOOK(tab), win->Win, TRUE); gtk_notebook_set_menu_label_text(GTK_NOTEBOOK(tab), win->Win, tip); } static void get_pane_position(void) { Menulocal.main_pane_pos = gtk_paned_get_position(GTK_PANED(NgraphApp.Viewer.main_pane)); Menulocal.side_pane1_pos = gtk_paned_get_position(GTK_PANED(NgraphApp.Viewer.side_pane1)); Menulocal.side_pane2_pos = gtk_paned_get_position(GTK_PANED(NgraphApp.Viewer.side_pane2)); Menulocal.side_pane3_pos = gtk_paned_get_position(GTK_PANED(NgraphApp.Viewer.side_pane3)); } static void set_pane_position(void) { gtk_paned_set_position(GTK_PANED(NgraphApp.Viewer.main_pane), Menulocal.main_pane_pos); gtk_paned_set_position(GTK_PANED(NgraphApp.Viewer.side_pane3), Menulocal.side_pane3_pos); gtk_paned_set_position(GTK_PANED(NgraphApp.Viewer.side_pane1), Menulocal.side_pane1_pos); gtk_paned_set_position(GTK_PANED(NgraphApp.Viewer.side_pane2), Menulocal.side_pane2_pos); } struct obj_tab_info { int tab, order; int *conf; int obj_id; const char *obj_name; GtkWidget * (* init_func)(struct SubWin *); struct SubWin *d; const char *icon; }; static int tab_info_compare(const void * a, const void * b) { const struct obj_tab_info *info_a, *info_b; info_a = (const struct obj_tab_info *) a; info_b = (const struct obj_tab_info *) b; return info_a->order + info_a->tab * 100 - info_b->order - info_b->tab * 100; } static void init_tab_info(struct obj_tab_info *info, int n) { int i, position; struct objlist *obj; for (i = 0; i < n; i++) { position = *info[i].conf; if (position > 99) { info[i].tab = 1; } else { info[i].tab = 0; } obj = chkobject(info[i].obj_name); info[i].obj_id = chkobjectid(obj); info[i].order = position % 100; } qsort(info, n, sizeof(*info), tab_info_compare); } static void save_tab_position_sub(GtkWidget *tab, struct obj_tab_info *tab_info, int offset) { int i, n, obj_id; GtkWidget *w; n = gtk_notebook_get_n_pages(GTK_NOTEBOOK(tab)); for (i = 0; i < n; i++){ w = gtk_notebook_get_nth_page(GTK_NOTEBOOK(tab), i); obj_id = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), OBJ_ID_KEY)); if (obj_id == tab_info->obj_id) { *tab_info->conf = offset + i; break; } } } static void save_tab_position(void) { int i, n; GtkWidget *tab; struct obj_tab_info tab_info[] = { {0, 0, &Menulocal.file_tab, 0, "data"}, {0, 0, &Menulocal.axis_tab, 0, "axis"}, {0, 0, &Menulocal.merge_tab, 0, "merge"}, {0, 0, &Menulocal.path_tab, 0, "path"}, {0, 0, &Menulocal.rectangle_tab, 0, "rectangle"}, {0, 0, &Menulocal.arc_tab, 0, "arc"}, {0, 0, &Menulocal.mark_tab, 0, "mark"}, {0, 0, &Menulocal.text_tab, 0, "text"}, }; n = sizeof(tab_info) / sizeof(*tab_info); init_tab_info(tab_info, n); for (i = 0; i < n; i++) { tab = gtk_paned_get_child1(GTK_PANED(NgraphApp.Viewer.side_pane2)); save_tab_position_sub(tab, tab_info + i, 0); tab = gtk_paned_get_child2(GTK_PANED(NgraphApp.Viewer.side_pane2)); save_tab_position_sub(tab, tab_info + i, 100); } } static void create_object_tabs(void) { int j, tab_n; GtkWidget *tab; struct obj_tab_info tab_info[] = { {0, 0, &Menulocal.file_tab, 0, "data", dreate_data_list, &NgraphApp.FileWin, NGRAPH_FILEWIN_ICON}, {0, 0, &Menulocal.axis_tab, 0, "axis", dreate_axis_list, &NgraphApp.AxisWin, NGRAPH_AXISWIN_ICON}, {0, 0, &Menulocal.merge_tab, 0, "merge", dreate_merge_list, &NgraphApp.MergeWin, NGRAPH_MERGEWIN_ICON}, {0, 0, &Menulocal.path_tab, 0, "path", create_path_list, &NgraphApp.PathWin, NGRAPH_LINE_ICON}, {0, 0, &Menulocal.rectangle_tab, 0, "rectangle", create_rect_list, &NgraphApp.RectWin, NGRAPH_RECT_ICON}, {0, 0, &Menulocal.arc_tab, 0, "arc", create_arc_list, &NgraphApp.ArcWin, NGRAPH_ARC_ICON}, {0, 0, &Menulocal.mark_tab, 0, "mark", create_mark_list, &NgraphApp.MarkWin, NGRAPH_MARK_ICON}, {0, 0, &Menulocal.text_tab, 0, "text", create_text_list, &NgraphApp.TextWin, NGRAPH_TEXT_ICON}, }; tab_n = sizeof(tab_info) / sizeof(*tab_info); init_tab_info(tab_info, tab_n); for (j = 0; j < tab_n; j++) { if (tab_info[j].tab > 0) { tab = gtk_paned_get_child2(GTK_PANED(NgraphApp.Viewer.side_pane2)); } else { tab = gtk_paned_get_child1(GTK_PANED(NgraphApp.Viewer.side_pane2)); } tab_info[j].init_func(tab_info[j].d); setup_object_tab(tab_info[j].d, tab, tab_info[j].icon, _(tab_info[j].obj_name)); } CoordWinCreate(&NgraphApp.CoordWin); gtk_paned_pack1(GTK_PANED(NgraphApp.Viewer.side_pane3), NgraphApp.CoordWin.Win, FALSE, TRUE); InfoWinCreate(&NgraphApp.InfoWin); gtk_paned_pack2(GTK_PANED(NgraphApp.Viewer.side_pane3), NgraphApp.InfoWin.Win, TRUE, TRUE); set_pane_position(); if (Menulocal.sidebar) { gtk_widget_show(NgraphApp.Viewer.side_pane1); } } static void edit_menu_shown(GtkWidget *w, gpointer user_data) { struct Viewer *d; d = (struct Viewer *) user_data; set_focus_sensitivity(d); } #if USE_GTK_BUILDER static void clipboard_changed(GtkWidget *w, GdkEvent *e, gpointer user_data) { struct Viewer *d; d = (struct Viewer *) user_data; set_focus_sensitivity(d); } #endif #define USE_APP_HEADER_BAR 0 static void setup_toolbar(GtkWidget *window) { GtkWidget *w; #if USE_APP_HEADER_BAR GtkWidget *hbar; #endif w = create_toolbar(CommandToolbar, sizeof(CommandToolbar) / sizeof(*CommandToolbar), NULL); CToolbar = w; gtk_toolbar_set_style(GTK_TOOLBAR(w), GTK_TOOLBAR_ICONS); #if USE_APP_HEADER_BAR hbar = gtk_header_bar_new(); gtk_header_bar_set_title(GTK_HEADER_BAR(hbar), AppName); gtk_header_bar_set_show_close_button(GTK_HEADER_BAR(hbar), TRUE); gtk_window_set_titlebar(GTK_WINDOW(window), hbar); #endif w = create_toolbar(PointerToolbar, sizeof(PointerToolbar) / sizeof(*PointerToolbar), G_CALLBACK(CmViewerButtonPressed)); PToolbar = w; gtk_orientable_set_orientation(GTK_ORIENTABLE(w), GTK_ORIENTATION_VERTICAL); gtk_toolbar_set_style(GTK_TOOLBAR(w), GTK_TOOLBAR_ICONS); } static void setupwindow(GtkApplication *app) { GtkWidget *w, *hbox, *hbox2, *vbox2, *table, *hpane1, *hpane2, *vpane1, *vpane2; #if ! USE_APP_HEADER_BAR GtkWidget *vbox; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); #endif vbox2 = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); w = gtk_menu_bar_new(); create_menu(w, MainMenu); #if ! USE_GTK_BUILDER gtk_box_pack_start(GTK_BOX(vbox2), w, FALSE, FALSE, 0); read_keymap_file(); #endif NgraphApp.Viewer.menu = w; ToolBox = gtk_stack_new(); SettingPanel = presetting_create_panel(app); gtk_stack_add_named(GTK_STACK(ToolBox), CToolbar, "CommandToolbar"); gtk_stack_add_named(GTK_STACK(ToolBox), SettingPanel, "SettingPanel"); gtk_box_pack_start(GTK_BOX(vbox2), ToolBox, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(hbox), PToolbar, FALSE, FALSE, 0); w = gtk_menu_new(); create_popup(w, PopupMenu); #if ! USE_GTK_BUILDER gtk_menu_set_accel_group(GTK_MENU(w), AccelGroup); NgraphApp.Viewer.popup = w; gtk_widget_show_all(w); g_signal_connect(ActionWidget[EditMenuAction].menu, "show", G_CALLBACK(edit_menu_shown), &NgraphApp.Viewer); #endif if (NgraphApp.Viewer.popup) { g_signal_connect(NgraphApp.Viewer.popup, "show", G_CALLBACK(edit_menu_shown), &NgraphApp.Viewer); } NgraphApp.Viewer.HScroll = gtk_scrollbar_new(GTK_ORIENTATION_HORIZONTAL, NULL); NgraphApp.Viewer.VScroll = gtk_scrollbar_new(GTK_ORIENTATION_VERTICAL, NULL); NgraphApp.Viewer.HRuler = nruler_new(GTK_ORIENTATION_HORIZONTAL); NgraphApp.Viewer.VRuler = nruler_new(GTK_ORIENTATION_VERTICAL); NgraphApp.Viewer.Win = gtk_drawing_area_new(); table = gtk_grid_new(); gtk_widget_set_hexpand(NgraphApp.Viewer.HRuler, TRUE); gtk_grid_attach(GTK_GRID(table), NgraphApp.Viewer.HRuler, 1, 0, 1, 1); gtk_widget_set_vexpand(NgraphApp.Viewer.VRuler, TRUE); gtk_grid_attach(GTK_GRID(table), NgraphApp.Viewer.VRuler, 0, 1, 1, 1); gtk_widget_set_hexpand(NgraphApp.Viewer.HScroll, TRUE); gtk_grid_attach(GTK_GRID(table), NgraphApp.Viewer.HScroll, 1, 2, 1, 1); gtk_widget_set_vexpand(NgraphApp.Viewer.VScroll, TRUE); gtk_grid_attach(GTK_GRID(table), NgraphApp.Viewer.VScroll, 2, 1, 1, 1); gtk_widget_set_hexpand(NgraphApp.Viewer.Win, TRUE); gtk_widget_set_vexpand(NgraphApp.Viewer.Win, TRUE); gtk_grid_attach(GTK_GRID(table), NgraphApp.Viewer.Win, 1, 1, 1, 1); vpane2 = gtk_paned_new(GTK_ORIENTATION_VERTICAL); NgraphApp.Viewer.side_pane2 = vpane2; w = gtk_notebook_new(); gtk_notebook_popup_enable(GTK_NOTEBOOK(w)); gtk_notebook_set_tab_pos(GTK_NOTEBOOK(w), GTK_POS_LEFT); gtk_notebook_set_group_name(GTK_NOTEBOOK(w), SIDE_PANE_TAB_ID); gtk_notebook_set_scrollable(GTK_NOTEBOOK(w), TRUE); gtk_paned_add1(GTK_PANED(vpane2), w); w = gtk_notebook_new(); gtk_notebook_popup_enable(GTK_NOTEBOOK(w)); gtk_notebook_set_tab_pos(GTK_NOTEBOOK(w), GTK_POS_LEFT); gtk_notebook_set_group_name(GTK_NOTEBOOK(w), SIDE_PANE_TAB_ID); gtk_notebook_set_scrollable(GTK_NOTEBOOK(w), TRUE); gtk_paned_add2(GTK_PANED(vpane2), w); hpane2 = gtk_paned_new(GTK_ORIENTATION_HORIZONTAL); NgraphApp.Viewer.side_pane3 = hpane2; vpane1 = gtk_paned_new(GTK_ORIENTATION_VERTICAL); gtk_paned_pack1(GTK_PANED(vpane1), vpane2, TRUE, TRUE); gtk_paned_pack2(GTK_PANED(vpane1), hpane2, FALSE, TRUE); NgraphApp.Viewer.side_pane1 = vpane1; hpane1 = gtk_paned_new(GTK_ORIENTATION_HORIZONTAL); #if USE_APP_HEADER_BAR gtk_paned_add1(GTK_PANED(hpane1), hbox); #else gtk_paned_add1(GTK_PANED(hpane1), vbox); #endif gtk_paned_add2(GTK_PANED(hpane1), vpane1); NgraphApp.Viewer.main_pane = hpane1; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 0); #if ! USE_APP_HEADER_BAR gtk_box_pack_start(GTK_BOX(vbox), hbox, TRUE, TRUE, 0); #endif gtk_box_pack_start(GTK_BOX(hbox2), hpane1, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(vbox2), hbox2, TRUE, TRUE, 0); NgraphApp.Message = gtk_statusbar_new(); gtk_box_pack_end(GTK_BOX(NgraphApp.Message), create_message_box(&NgraphApp.Message_extra, &NgraphApp.Message_pos), FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(vbox2), NgraphApp.Message, FALSE, FALSE, 0); NgraphApp.Message1 = gtk_statusbar_get_context_id(GTK_STATUSBAR(NgraphApp.Message), "Message1"); set_axis_undo_button_sensitivity(FALSE); gtk_container_add(GTK_CONTAINER(TopLevel), vbox2); create_object_tabs(); } static void load_hist_file(GtkEntryCompletion *list, char *home, char *name) { char *filename; filename = g_strdup_printf("%s/%s", home, name); entry_completion_load(list, filename, Menulocal.hist_size); g_free(filename); } static void save_hist_file(GtkEntryCompletion *list, char *home, char *name) { char *filename; filename = g_strdup_printf("%s/%s", home, name); entry_completion_save(list, filename, Menulocal.hist_size); g_free(filename); } static void load_hist(void) { char *home; NgraphApp.legend_text_list = entry_completion_create(); NgraphApp.x_math_list = entry_completion_create(); NgraphApp.y_math_list = entry_completion_create(); NgraphApp.func_list = entry_completion_create(); NgraphApp.fit_list = entry_completion_create(); home = get_home(); if (home == NULL) return; load_hist_file(NgraphApp.legend_text_list, home, TEXT_HISTORY); load_hist_file(NgraphApp.x_math_list, home, MATH_X_HISTORY); load_hist_file(NgraphApp.y_math_list, home, MATH_Y_HISTORY); load_hist_file(NgraphApp.func_list, home, FUNCTION_HISTORY); load_hist_file(NgraphApp.fit_list, home, FIT_HISTORY); } static void unref_entry_history(void) { g_object_unref(NgraphApp.legend_text_list); g_object_unref(NgraphApp.x_math_list); g_object_unref(NgraphApp.y_math_list); g_object_unref(NgraphApp.func_list); g_object_unref(NgraphApp.fit_list); NgraphApp.legend_text_list = NULL; NgraphApp.x_math_list = NULL; NgraphApp.y_math_list = NULL; NgraphApp.func_list = NULL; NgraphApp.fit_list = NULL; } static void save_entry_history(void) { char *home; home = get_home(); if (home == NULL) return; save_hist_file(NgraphApp.legend_text_list, home, TEXT_HISTORY); save_hist_file(NgraphApp.x_math_list, home, MATH_X_HISTORY); save_hist_file(NgraphApp.y_math_list, home, MATH_Y_HISTORY); save_hist_file(NgraphApp.func_list, home, FUNCTION_HISTORY); save_hist_file(NgraphApp.fit_list, home, FIT_HISTORY); } static void init_ngraph_app_struct(void) { NgraphApp.Viewer.Win = NULL; NgraphApp.Viewer.popup = NULL; memset(&NgraphApp.FileWin, 0, sizeof(NgraphApp.FileWin)); NgraphApp.FileWin.type = TypeFileWin; memset(&NgraphApp.AxisWin, 0, sizeof(NgraphApp.AxisWin)); NgraphApp.AxisWin.type = TypeAxisWin; memset(&NgraphApp.PathWin, 0, sizeof(NgraphApp.PathWin)); NgraphApp.PathWin.type = TypePathWin; memset(&NgraphApp.RectWin, 0, sizeof(NgraphApp.RectWin)); NgraphApp.RectWin.type = TypeRectWin; memset(&NgraphApp.ArcWin, 0, sizeof(NgraphApp.ArcWin)); NgraphApp.ArcWin.type = TypeArcWin; memset(&NgraphApp.MarkWin, 0, sizeof(NgraphApp.MarkWin)); NgraphApp.MarkWin.type = TypeMarkWin; memset(&NgraphApp.TextWin, 0, sizeof(NgraphApp.TextWin)); NgraphApp.TextWin.type = TypeTextWin; memset(&NgraphApp.MergeWin, 0, sizeof(NgraphApp.MergeWin)); NgraphApp.MergeWin.type = TypeMergeWin; memset(&NgraphApp.InfoWin, 0, sizeof(NgraphApp.InfoWin)); NgraphApp.InfoWin.type = TypeInfoWin; memset(&NgraphApp.CoordWin, 0, sizeof(NgraphApp.CoordWin)); NgraphApp.CoordWin.type = TypeCoordWin; NgraphApp.legend_text_list = NULL; NgraphApp.x_math_list = NULL; NgraphApp.y_math_list = NULL; NgraphApp.func_list = NULL; NgraphApp.fit_list = NULL; } void set_modified_state(int state) { set_action_widget_sensitivity(GraphSaveAction, state); } int toggle_view(int type, int state) { static int lock = FALSE; GtkWidget *w1 = NULL, *w2 = NULL; if (Menulock || Globallock) { return FALSE; } if (lock) { return FALSE; } lock = TRUE; switch (type) { case MenuIdToggleSidebar: Menulocal.sidebar = state; w1 = NgraphApp.Viewer.side_pane1; break; case MenuIdToggleStatusbar: Menulocal.statusbar = state; w1 = NgraphApp.Message; break; case MenuIdToggleRuler: Menulocal.ruler = state; w1 = NgraphApp.Viewer.HRuler; w2 = NgraphApp.Viewer.VRuler; break; case MenuIdToggleScrollbar: Menulocal.scrollbar = state; w1 = NgraphApp.Viewer.HScroll; w2 = NgraphApp.Viewer.VScroll; break; case MenuIdToggleCToolbar: Menulocal.ctoolbar = state; w1 = ToolBox; break; case MenuIdTogglePToolbar: Menulocal.ptoolbar = state; w1 = PToolbar; break; case MenuIdToggleCrossGauge: ViewCross(state); set_toggle_action_widget_state(ViewCrossGaugeAction, state); lock = FALSE; return TRUE; break; case MenuIdToggleGridLine: Menulocal.show_grid = state; set_toggle_action_widget_state(ViewGridLineAction, state); update_bg(); gtk_widget_queue_draw(NgraphApp.Viewer.Win); lock = FALSE; return TRUE; break; } if (w1) { gtk_widget_set_visible(w1, state); } if (w2) { gtk_widget_set_visible(w2, state); } lock = FALSE; return TRUE; } static void toggle_view_cb(GtkCheckMenuItem *action, gpointer data) { int type, state; if (action == NULL) { return; } type = GPOINTER_TO_INT(data); state = gtk_check_menu_item_get_active(action); toggle_view(type, state); } void set_toggle_action_widget_state(int id, int state) { #if USE_GTK_BUILDER if (ActionWidget[id].action) { GVariant *value; value = g_variant_new_boolean(state); g_action_change_state(ActionWidget[id].action, value); } #else if (ActionWidget[id].menu) { gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(ActionWidget[id].menu), state); } if (ActionWidget[id].popup) { gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(ActionWidget[id].popup), state); } if (ActionWidget[id].tool) { gtk_toggle_tool_button_set_active(GTK_TOGGLE_TOOL_BUTTON(ActionWidget[id].tool), state); } #endif } static void set_widget_visibility(void) { int i, state; for (i = 0; i < ActionWidgetNum; i++) { switch (i) { case ViewSidebarAction: state = Menulocal.sidebar; break; case ViewStatusbarAction: state = Menulocal.statusbar; break; case ViewRulerAction: state = Menulocal.ruler; break; case ViewScrollbarAction: state = Menulocal.scrollbar; break; case ViewCommandToolbarAction: state = Menulocal.ctoolbar; break; case ViewToolboxAction: state = Menulocal.ptoolbar; break; case ViewCrossGaugeAction: state = Menulocal.show_cross; break; case ViewGridLineAction: state = Menulocal.show_grid; break; default: continue; } #if ! USE_GTK_BUILDER set_toggle_action_widget_state(i, ! state); #endif set_toggle_action_widget_state(i, state); } } static void check_instance(struct objlist *obj) { int i; struct objlist *dobj; for (i = 0; i < ActionWidgetNum; i++) { dobj = NULL; switch (i) { case DataPropertyAction: case DataCloseAction: case DataEditAction: case DataSaveAction: case DataMathAction: dobj = chkobject("data"); break; case AxisPropertyAction: case AxisDeleteAction: case AxisScaleZoomAction: case AxisScaleClearAction: dobj = chkobject("axis"); if (obj == dobj && obj->lastinst < 0) { set_axis_undo_button_sensitivity(FALSE); } break; case AxisGridPropertyAction: case AxisGridDeleteAction: dobj = chkobject("axisgrid"); break; case LegendPathPropertyAction: case LegendPathDeleteAction: dobj = chkobject("path"); break; case LegendRectanglePropertyAction: case LegendRectangleDeleteAction: dobj = chkobject("rectangle"); break; case LegendArcPropertyAction: case LegendArcDeleteAction: dobj = chkobject("arc"); break; case LegendMarkPropertyAction: case LegendMarkDeleteAction: dobj = chkobject("mark"); break; case LegendTextPropertyAction: case LegendTextDeleteAction: dobj = chkobject("text"); break; case MergePropertyAction: case MergeCloseAction: dobj = chkobject("merge"); break; default: continue; } if (obj == dobj) { set_action_widget_sensitivity(i, obj->lastinst >= 0); } } } static void check_exist_instances(struct objlist *parent) { struct objlist *ocur; ocur = chkobjroot(); while (ocur) { if (chkobjparent(ocur) == parent) { check_instance(ocur); check_exist_instances(ocur); } ocur = ocur->next; } } static gboolean recent_filter(const GtkRecentFilterInfo *filter_info, gpointer user_data) { int i; if (filter_info->mime_type == NULL) { return FALSE; } switch (GPOINTER_TO_INT(user_data)) { case RECENT_TYPE_GRAPH: if (g_ascii_strcasecmp(filter_info->mime_type, NGRAPH_GRAPH_MIME)) { return FALSE; } break; case RECENT_TYPE_DATA: if (g_ascii_strncasecmp(filter_info->mime_type, NGRAPH_TEXT_MIME, strlen(NGRAPH_TEXT_MIME))) { return FALSE; } break; default: return FALSE; } for (i = 0; filter_info->applications[i]; i++) { if (g_strcmp0(AppName, filter_info->applications[i]) == 0) { return TRUE; } } return FALSE; } static void create_recent_filter(GtkWidget *w, int type) { GtkRecentFilter *filter; GtkRecentChooser *recent; recent = GTK_RECENT_CHOOSER(w); filter = gtk_recent_filter_new(); gtk_recent_filter_set_name(filter, (type == RECENT_TYPE_GRAPH) ? "NGP file" : "Data file"); gtk_recent_filter_add_custom(filter, GTK_RECENT_FILTER_URI | GTK_RECENT_FILTER_MIME_TYPE | GTK_RECENT_FILTER_APPLICATION, recent_filter, GINT_TO_POINTER(type), NULL); gtk_recent_chooser_set_filter(recent, filter); gtk_recent_chooser_set_show_tips(recent, TRUE); gtk_recent_chooser_set_show_icons(recent, FALSE); gtk_recent_chooser_set_local_only(recent, TRUE); #if ! WINDOWS gtk_recent_chooser_set_show_not_found(recent, FALSE); #endif gtk_recent_chooser_set_sort_type(recent, GTK_RECENT_SORT_MRU); } void show_recent_dialog(int type) { #if USE_GTK_BUILDER GtkWidget *dialog; int res; char *title; if (Menulock || Globallock) { return; } title = (type == RECENT_TYPE_GRAPH) ? _("Recent Graphs") : _("Recent Data Files"); dialog = gtk_recent_chooser_dialog_new_for_manager(title, GTK_WINDOW(TopLevel), NgraphApp.recent_manager, _("_Cancel"), GTK_RESPONSE_CANCEL, _("_Open"), GTK_RESPONSE_ACCEPT, NULL); create_recent_filter(dialog, type); res = gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_hide(dialog); if (res == GTK_RESPONSE_ACCEPT) { switch (type) { case RECENT_TYPE_GRAPH: CmGraphHistory(GTK_RECENT_CHOOSER(dialog), NULL); break; case RECENT_TYPE_DATA: CmFileHistory(GTK_RECENT_CHOOSER(dialog), NULL); break; } } gtk_widget_destroy(dialog); #endif } GtkWidget * create_recent_menu(int type) { GtkWidget *submenu; submenu = gtk_recent_chooser_menu_new_for_manager(NgraphApp.recent_manager); create_recent_filter(submenu, type); gtk_recent_chooser_menu_set_show_numbers(GTK_RECENT_CHOOSER_MENU(submenu), TRUE); gtk_recent_chooser_set_limit(GTK_RECENT_CHOOSER(submenu), RECENT_CHOOSER_LIMIT); switch (type) { case RECENT_TYPE_GRAPH: g_signal_connect(GTK_RECENT_CHOOSER(submenu), "item-activated", G_CALLBACK(CmGraphHistory), NULL); break; case RECENT_TYPE_DATA: g_signal_connect(GTK_RECENT_CHOOSER(submenu), "item-activated", G_CALLBACK(CmFileHistory), NULL); break; } return submenu; } static GtkWidget* create_save_menu(void) { GtkWidget *menu; #if USE_GTK_BUILDER int i; char *action; #endif menu = gtk_menu_new(); create_menu_sub(menu, SaveMenu, TRUE); #if USE_GTK_BUILDER for (i = 0; SaveMenu[i].type != MENU_TYPE_END; i++) { if (SaveMenu[i].action_name && SaveMenu[i].action) { action = g_strdup_printf("app.%s", SaveMenu[i].action_name); if (action) { gtk_actionable_set_action_name(GTK_ACTIONABLE(SaveMenu[i].action->popup), action); g_free(action); } } } #endif gtk_widget_show_all(menu); return menu; } void draw_notify(int notify) { static int state = FALSE; GtkStyleContext *style; if (state == notify) { return; } state = notify; if (DrawButton == NULL) { return; } style = gtk_widget_get_style_context(DrawButton); if (state) { gtk_style_context_add_class(style, DRAW_NOTIFY_CLASS_NAME); } else { gtk_style_context_remove_class(style, DRAW_NOTIFY_CLASS_NAME); } } static GtkWidget * create_toolbar(struct ToolItem *item, int n, GCallback btn_press_cb) { int i; GSList *list; GtkToolItem *widget; GtkWidget *toolbar, *icon, *menu; toolbar = gtk_toolbar_new(); list = NULL; icon = NULL; for (i = 0; i < n; i++) { if (item[i].icon) { icon = gtk_image_new_from_icon_name(item[i].icon, GTK_ICON_SIZE_SMALL_TOOLBAR); } switch (item[i].type) { case TOOL_TYPE_SEPARATOR: widget = gtk_separator_tool_item_new(); gtk_separator_tool_item_set_draw(GTK_SEPARATOR_TOOL_ITEM(widget), TRUE); break; case TOOL_TYPE_NORMAL: widget = gtk_tool_button_new(icon, _(item[i].label)); break; case TOOL_TYPE_DRAW: widget = gtk_tool_button_new(icon, _(item[i].label)); DrawButton = GTK_WIDGET(widget); break; case TOOL_TYPE_SAVE: widget = gtk_menu_tool_button_new(icon, _(item[i].label)); menu = create_save_menu(); gtk_menu_tool_button_set_menu(GTK_MENU_TOOL_BUTTON(widget), menu); gtk_menu_tool_button_set_arrow_tooltip_text(GTK_MENU_TOOL_BUTTON(widget), _("Save menu")); break; case TOOL_TYPE_RECENT_GRAPH: widget = gtk_menu_tool_button_new(icon, _(item[i].label)); menu = create_recent_menu(RECENT_TYPE_GRAPH); gtk_menu_tool_button_set_menu(GTK_MENU_TOOL_BUTTON(widget), menu); gtk_menu_tool_button_set_arrow_tooltip_text(GTK_MENU_TOOL_BUTTON(widget), _("Recent Graphs")); break; case TOOL_TYPE_RECENT_DATA: widget = gtk_menu_tool_button_new(icon, _(item[i].label)); menu = create_recent_menu(RECENT_TYPE_DATA); gtk_menu_tool_button_set_menu(GTK_MENU_TOOL_BUTTON(widget), menu); gtk_menu_tool_button_set_arrow_tooltip_text(GTK_MENU_TOOL_BUTTON(widget), _("Recent Data Files")); break; case TOOL_TYPE_TOGGLE: case TOOL_TYPE_TOGGLE2: widget = gtk_toggle_tool_button_new(); if (icon) { gtk_tool_button_set_icon_widget(GTK_TOOL_BUTTON(widget), icon); } break; case TOOL_TYPE_RADIO: widget = gtk_radio_tool_button_new(list); list = gtk_radio_tool_button_get_group(GTK_RADIO_TOOL_BUTTON(widget)); gtk_tool_button_set_label(GTK_TOOL_BUTTON(widget), _(item[i].label)); if (icon) { gtk_tool_button_set_icon_widget(GTK_TOOL_BUTTON(widget), icon); } if (btn_press_cb) { g_signal_connect(gtk_bin_get_child(GTK_BIN(widget)), "button-press-event", btn_press_cb, NULL); } break; default: widget = NULL; } if (widget == NULL) { continue; } #if USE_GTK_BUILDER if (item[i].action_name) { gtk_actionable_set_action_name(GTK_ACTIONABLE(widget), item[i].action_name); } else #endif if (item[i].callback) { switch (item[i].type) { case TOOL_TYPE_TOGGLE: g_signal_connect(widget, "toggled", G_CALLBACK(item[i].callback), GINT_TO_POINTER(item[i].user_data)); break; default: g_signal_connect(widget, "clicked", G_CALLBACK(item[i].callback), GINT_TO_POINTER(item[i].user_data)); } } if (item[i].tip) { gtk_tool_item_set_tooltip_text(GTK_TOOL_ITEM(widget), _(item[i].tip)); } if (item[i].caption) { g_signal_connect(gtk_bin_get_child(GTK_BIN(widget)), "enter-notify-event", G_CALLBACK(tool_button_enter_leave_cb), _(item[i].caption)); g_signal_connect(gtk_bin_get_child(GTK_BIN(widget)), "leave-notify-event", G_CALLBACK(tool_button_enter_leave_cb), NULL); } if (item[i].action) { item[i].action->tool = widget; } gtk_toolbar_insert(GTK_TOOLBAR(toolbar), GTK_TOOL_ITEM(widget), -1); } return toolbar; } static void create_menu_sub(GtkWidget *parent, struct MenuItem *item, int popup) { int i; GtkWidget *menu, *widget, *submenu; for (i = 0; item[i].type != MENU_TYPE_END; i++) { switch (item[i].type) { case MENU_TYPE_SEPARATOR: widget = gtk_separator_menu_item_new(); break; case MENU_TYPE_NORMAL: #if GTK_CHECK_VERSION(3, 10, 0) widget = gtk_menu_item_new_with_mnemonic(_(item[i].label)); #else widget = gtk_image_menu_item_new_with_mnemonic(_(item[i].label)); if (item[i].icon) { GtkWidget *icon; icon = gtk_image_new_from_icon_name(item[i].icon, GTK_ICON_SIZE_MENU); gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(widget), icon); } #endif break; case MENU_TYPE_TOGGLE: case MENU_TYPE_TOGGLE2: widget = gtk_check_menu_item_new_with_mnemonic(_(item[i].label)); break; case MENU_TYPE_RECENT_GRAPH: widget = gtk_menu_item_new_with_mnemonic(_(item[i].label)); submenu = create_recent_menu(RECENT_TYPE_GRAPH); gtk_menu_item_set_submenu(GTK_MENU_ITEM(widget), submenu); break; case MENU_TYPE_RECENT_DATA: widget = gtk_menu_item_new_with_mnemonic(_(item[i].label)); submenu = create_recent_menu(RECENT_TYPE_DATA); gtk_menu_item_set_submenu(GTK_MENU_ITEM(widget), submenu); break; default: widget = NULL; } if (widget == NULL) { continue; } if (item[i].callback) { switch (item[i].type) { case MENU_TYPE_TOGGLE: g_signal_connect(widget, "toggled", G_CALLBACK(item[i].callback), GINT_TO_POINTER(item[i].user_data)); break; default: g_signal_connect(widget, "activate", G_CALLBACK(item[i].callback), GINT_TO_POINTER(item[i].user_data)); } } #if ! USE_GTK_BUILDER if (item[i].accel_path) { gtk_accel_map_add_entry(item[i].accel_path, item[i].accel_key, item[i].accel_mods); gtk_menu_item_set_accel_path(GTK_MENU_ITEM(widget), item[i].accel_path); } #endif if (item[i].child) { menu = gtk_menu_new(); gtk_menu_set_accel_group(GTK_MENU(menu), AccelGroup); gtk_menu_shell_set_take_focus(GTK_MENU_SHELL(menu), TRUE); create_menu_sub(menu, item[i].child, popup); gtk_menu_item_set_submenu(GTK_MENU_ITEM(widget), menu); } if (item[i].action) { if (popup) { item[i].action->popup = widget; } else { item[i].action->menu = widget; } } #if USE_GTK_BUILDER if (item[i].action_name) { if (item[i].action) { item[i].action->action = g_action_map_lookup_action(G_ACTION_MAP(GtkApp), item[i].action_name); } if (item[i].accel_key) { char *key, accel[128], action[128]; const char *accels[2]; key = gdk_keyval_name(item[i].accel_key); if (key) { snprintf(accel, sizeof(accel), "%s%s%s", (item[i].accel_mods & GDK_CONTROL_MASK) ? "" : "", (item[i].accel_mods & GDK_SHIFT_MASK) ? "" : "", key); snprintf(action, sizeof(action), "app.%s", item[i].action_name); accels[0] = accel; accels[1] = NULL; gtk_application_set_accels_for_action(GtkApp, action, accels); } } } #endif gtk_menu_shell_append(GTK_MENU_SHELL(parent), widget); } } static void create_menu(GtkWidget *parent, struct MenuItem *item) { create_menu_sub(parent, item, FALSE); } static void create_popup(GtkWidget *parent, struct MenuItem *item) { create_menu_sub(parent, item, TRUE); } static int create_toplevel_window(void) { int i; struct objlist *aobj; int x, y, width, height, w, h; #if GTK_CHECK_VERSION(3, 22, 0) GdkDisplay *disp; #else GdkScreen *screen; #endif #if USE_APP_MENU GtkWidget *popup; #if USE_GTK_BUILDER GtkClipboard *clip; #endif /* USE_GTK_BUILDER */ #endif /* USE_APP_MENU */ NgraphApp.recent_manager = gtk_recent_manager_get_default(); init_action_widget_list(); init_ngraph_app_struct(); #if GTK_CHECK_VERSION(3, 22, 0) w = 800; h = 600; disp = gdk_display_get_default(); if (disp) { GdkMonitor *monitor; monitor = gdk_display_get_primary_monitor(disp); if (monitor) { GdkRectangle rect; gdk_monitor_get_geometry(monitor, &rect); w = rect.width; h = rect.height; } } #else screen = gdk_screen_get_default(); w = gdk_screen_get_width(screen); h = gdk_screen_get_height(screen); #endif if (Menulocal.menux == DEFAULT_GEOMETRY) Menulocal.menux = w * 3 / 8; if (Menulocal.menuy == DEFAULT_GEOMETRY) Menulocal.menuy = h / 8; if (Menulocal.menuwidth == DEFAULT_GEOMETRY) Menulocal.menuwidth = w / 2; if (Menulocal.menuheight == DEFAULT_GEOMETRY) Menulocal.menuheight = h / 1.2; x = Menulocal.menux; y = Menulocal.menuy; width = Menulocal.menuwidth; height = Menulocal.menuheight; load_hist(); #if USE_APP_MENU GtkApp = create_application_window(&popup); CurrentWindow = TopLevel = gtk_application_window_new(GtkApp); gtk_window_set_modal(GTK_WINDOW(TopLevel), TRUE); /* for the GtkColorButton (modal GtkColorChooserDialog) */ #if USE_GTK_BUILDER gtk_application_window_set_show_menubar(GTK_APPLICATION_WINDOW(TopLevel), TRUE); if (popup) { NgraphApp.Viewer.popup = popup; } clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); g_signal_connect(clip, "owner-change", G_CALLBACK(clipboard_changed), &NgraphApp.Viewer); #else /* USE_GTK_BUILDER */ gtk_application_window_set_show_menubar(GTK_APPLICATION_WINDOW(TopLevel),FALSE); #endif /* USE_GTK_BUILDER */ #else /* USE_APP_MENU */ CurrentWindow = TopLevel = gtk_window_new(GTK_WINDOW_TOPLEVEL); #endif /* USE_APP_MENU */ gtk_window_set_title(GTK_WINDOW(TopLevel), AppName); gtk_window_set_default_size(GTK_WINDOW(TopLevel), width, height); gtk_window_move(GTK_WINDOW(TopLevel), x, y); if (AccelGroup == NULL) { AccelGroup = gtk_accel_group_new(); } gtk_window_add_accel_group(GTK_WINDOW(TopLevel), AccelGroup); g_signal_connect(TopLevel, "delete-event", G_CALLBACK(CloseCallback), NULL); g_signal_connect(TopLevel, "destroy-event", G_CALLBACK(CloseCallback), NULL); create_icon(); initdialog(); setup_toolbar(TopLevel); gtk_widget_show_all(GTK_WIDGET(TopLevel)); reset_event(); create_markpixmap(TopLevel); setupwindow(GtkApp); create_addin_menu(); NgraphApp.FileName = NULL; gtk_widget_show_all(GTK_WIDGET(TopLevel)); ViewerWinSetup(); if (create_cursor()) return 1; reset_graph_modified(); NSetCursor(GDK_LEFT_PTR); putstderr = mgtkputstderr; printfstderr = mgtkprintfstderr; putstdout = mgtkputstdout; printfstdout = mgtkprintfstdout; ndisplaydialog = mgtkdisplaydialog; ndisplaystatus = mgtkdisplaystatus; ninterrupt = mgtkinterrupt; inputyn = mgtkinputyn; aobj = getobject("axis"); if (aobj) { for (i = 0; i <= chkobjlastinst(aobj); i++) { exeobj(aobj, "tight", i, 0, NULL); } } aobj = getobject("axisgrid"); if (aobj) { for (i = 0; i <= chkobjlastinst(aobj); i++) { exeobj(aobj, "tight", i, 0, NULL); } } gtk_widget_show_all(GTK_WIDGET(TopLevel)); set_widget_visibility(); set_focus_sensitivity(&NgraphApp.Viewer); check_exist_instances(chkobject("draw")); set_newobj_cb(check_instance); set_delobj_cb(check_instance); return 0; } static void souce_view_set_search_path(void) { const gchar * const *dirs; gchar **new_dirs; gchar *dir; int n; GtkSourceLanguageManager *lm; lm = gtk_source_language_manager_get_default(); dirs = gtk_source_language_manager_get_search_path(lm); dir = g_strdup_printf("%s/%s", NDATADIR, "gtksourceview"); if (dir == NULL) { return; } if (g_strv_contains(dirs, dir)) { g_free(dir); return; } for (n = 0; dirs[n]; n++); new_dirs = g_malloc((n + 2) * sizeof(*new_dirs)); if (new_dirs == NULL) { g_free(dir); return; } memcpy(new_dirs, dirs, n * sizeof(*new_dirs)); new_dirs[n] = dir; new_dirs[n + 1] = NULL; gtk_source_language_manager_set_search_path(lm, new_dirs); g_free(dir); g_free(new_dirs); } int application(char *file) { int terminated; if (TopLevel) { #if GTK_CHECK_VERSION(3, 8, 0) if (gtk_widget_is_visible(TopLevel)) { return 1; } #else if (GTK_WIDGET_VISIBLE(TopLevel)) { return 1; } #endif gtk_widget_show(TopLevel); OpenGC(); OpenGRA(); } else { GtkIconTheme *theme; theme = gtk_icon_theme_get_default(); gtk_icon_theme_add_resource_path(theme, NGRAPH_ICON_PATH); if (create_toplevel_window()) { return 1; } } souce_view_set_search_path(); #if ! WINDOWS set_signal(SIGINT, 0, kill_signal_handler, NULL); set_signal(SIGTERM, 0, term_signal_handler, NULL); #endif /* WINDOWS */ if (file != NULL) { char *ext; ext = getextention(file); if (ext && ((strcmp0(ext, "NGP") == 0) || (strcmp0(ext, "ngp") == 0))) { LoadNgpFile(file, FALSE, NULL); } else { CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); } } else { CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); } system_set_draw_notify_func(draw_notify); terminated = AppMainLoop(); system_set_draw_notify_func(NULL); if (CheckIniFile()) { save_tab_position(); get_pane_position(); menu_save_config(SAVE_CONFIG_TYPE_GEOMETRY); save_entry_history(); menu_save_config(SAVE_CONFIG_TYPE_TOGGLE_VIEW | SAVE_CONFIG_TYPE_OTHERS); } set_newobj_cb(NULL); set_delobj_cb(NULL); #if ! WINDOWS set_signal(SIGTERM, 0, SIG_DFL, NULL); set_signal(SIGINT, 0, SIG_DFL, NULL); #endif /* WINDOWS */ gtk_widget_hide(TopLevel); reset_event(); CloseGC(); CloseGRA(); if (terminated) { unref_entry_history(); ViewerWinClose(); g_free(NgraphApp.FileName); NgraphApp.FileName = NULL; gtk_widget_destroy(TopLevel); NgraphApp.Viewer.Win = NULL; CurrentWindow = TopLevel = PToolbar = CToolbar = ToolBox = NULL; free_markpixmap(); free_cursor(); reset_event(); delobj(getobject("system"), 0); } return 0; } void UpdateAll(char **objects) { UpdateAll2(objects, TRUE); } static void check_update_obj(char **objects, struct obj_list_data *file, int *update_file, struct obj_list_data *axis, int *update_axis, struct obj_list_data *merge, int *update_merge) { struct objlist *obj; char **ptr; if (objects == NULL) { *update_file = TRUE; *update_axis = TRUE; *update_merge = TRUE; return; } *update_file = FALSE; *update_axis = FALSE; *update_merge = FALSE; for (ptr = objects; *ptr; ptr++) { obj = getobject(*ptr); if (obj == file->obj) { *update_file = TRUE; } else if (obj == axis->obj) { *update_axis = TRUE; } else if (obj == merge->obj) { *update_merge = TRUE; } } } void UpdateAll2(char **objs, int redraw) { int update_axis, update_file, update_merge; check_update_obj(objs, NgraphApp.FileWin.data.data, &update_file, NgraphApp.AxisWin.data.data, &update_axis, NgraphApp.MergeWin.data.data, &update_merge); if (update_file) { FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, redraw && ! update_axis); } if (update_axis) { AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, redraw); } if (update_merge) { MergeWinUpdate(NgraphApp.MergeWin.data.data, TRUE, redraw); } LegendWinUpdate(objs, TRUE, redraw); InfoWinUpdate(TRUE); CoordWinUpdate(TRUE); } void ChangePage(void) { CloseGRA(); OpenGRA(); CloseGC(); CloseGRA(); OpenGRA(); OpenGC(); SetScroller(); ChangeDPI(); draw_notify(TRUE); } static void SetStatusBarSub(const char *mes, guint id) { if (NgraphApp.Message) { gtk_statusbar_push(GTK_STATUSBAR(NgraphApp.Message), id, mes); } } static void ResetStatusBarSub(guint id) { if (NgraphApp.Message) { gtk_statusbar_pop(GTK_STATUSBAR(NgraphApp.Message), id); } } void SetStatusBar(const char *mes) { SetStatusBarSub(mes, NgraphApp.Message1); } void ResetStatusBar(void) { ResetStatusBarSub(NgraphApp.Message1); } unsigned int NGetCursor(void) { return CursorType; } void NSetCursor(unsigned int type) { GdkWindow *win; if (NgraphApp.Viewer.Win == NULL || NgraphApp.cursor == NULL || CursorType == type) return; win = gtk_widget_get_window(NgraphApp.Viewer.Win); if (win == NULL) { return; } CursorType = type; switch (type) { case GDK_LEFT_PTR: gdk_window_set_cursor(win, NgraphApp.cursor[0]); break; case GDK_XTERM: gdk_window_set_cursor(win, NgraphApp.cursor[1]); break; case GDK_CROSSHAIR: gdk_window_set_cursor(win, NgraphApp.cursor[2]); break; case GDK_TOP_LEFT_CORNER: gdk_window_set_cursor(win, NgraphApp.cursor[3]); break; case GDK_TOP_RIGHT_CORNER: gdk_window_set_cursor(win, NgraphApp.cursor[4]); break; case GDK_BOTTOM_RIGHT_CORNER: gdk_window_set_cursor(win, NgraphApp.cursor[5]); break; case GDK_BOTTOM_LEFT_CORNER: gdk_window_set_cursor(win, NgraphApp.cursor[6]); break; case GDK_TARGET: gdk_window_set_cursor(win, NgraphApp.cursor[7]); break; case GDK_PLUS: gdk_window_set_cursor(win, NgraphApp.cursor[8]); break; case GDK_SIZING: gdk_window_set_cursor(win, NgraphApp.cursor[9]); break; case GDK_WATCH: gdk_window_set_cursor(win, NgraphApp.cursor[10]); break; case GDK_FLEUR: gdk_window_set_cursor(win, NgraphApp.cursor[11]); break; case GDK_PENCIL: gdk_window_set_cursor(win, NgraphApp.cursor[12]); break; case GDK_TCROSS: gdk_window_set_cursor(win, NgraphApp.cursor[13]); break; } } void DisplayDialog(const char *str) { char *ustr; if (str == NULL) return; ustr = g_locale_to_utf8(CHK_STR(str), -1, NULL, NULL, NULL); InfoWinDrawInfoText(ustr); g_free(ustr); } int PutStdout(const char *s) { gssize len; if (s == NULL) return 0; len = strlen(s); DisplayDialog(s); return len + 1; } int PutStderr(const char *s) { gssize len; gsize rlen, wlen; char *ustr, *arg[] = {NULL}; if (s == NULL) return 0; len = strlen(s); ustr = g_locale_to_utf8(s, len, &rlen, &wlen, NULL); message_box(NULL, ustr, _("Error:"), RESPONS_ERROR); g_free(ustr); UpdateAll2(arg, FALSE); return len + 1; } int ChkInterrupt(void) { #if 0 GdkEvent *e; GtkWidget *w; e = gtk_get_current_event(); if(e == NULL) return FALSE; w = gtk_get_event_widget(e); if (w && (e->type == GDK_BUTTON_PRESS || e->type == GDK_BUTTON_RELEASE)) { // if (w && e->type != GDK_EXPOSE) { gtk_propagate_event(w, e); } gdk_event_free(e); if (check_interrupt()) { return TRUE; } #else if (DrawLock != DrawLockDraw) { return check_interrupt(); } while (gtk_events_pending()) { gtk_main_iteration_do(FALSE); if (check_interrupt()) { return TRUE; } } #endif return FALSE; } int InputYN(const char *mes) { int ret; char *arg[] = {NULL}; ret = message_box(get_current_window(), mes, _("Question"), RESPONS_YESNO); UpdateAll2(arg, FALSE); return (ret == IDYES) ? TRUE : FALSE; } void script_exec(GtkWidget *w, gpointer client_data) { char *name, *option, *s, *argv[2], mes[256]; int newid, allocnow = FALSE, len, idn; struct narray sarray; struct objlist *robj, *shell; struct script *fcur; if (Menulock || Globallock || client_data == NULL) { return; } shell = chkobject("shell"); if (shell == NULL) return; fcur = (struct script *) client_data; if (fcur->script == NULL) return; name = g_strdup(fcur->script); if (name == NULL) return; newid = newobj(shell); if (newid < 0) { g_free(name); return; } arrayinit(&sarray, sizeof(char *)); if (arrayadd(&sarray, &name) == NULL) { delobj(shell, newid); g_free(name); arraydel2(&sarray); return; } option = fcur->option; while ((s = getitok2(&option, &len, " \t")) != NULL) { if (arrayadd(&sarray, &s) == NULL) { delobj(shell, newid); g_free(s); arraydel2(&sarray); return; } } if (Menulocal.addinconsole) { allocnow = allocate_console(); } snprintf(mes, sizeof(mes), _("Executing `%.128s'."), name); SetStatusBar(mes); menu_lock(TRUE); menu_save_undo(UNDO_TYPE_ADDIN, NULL); idn = getobjtblpos(Menulocal.obj, "_evloop", &robj); registerevloop(chkobjectname(Menulocal.obj), "_evloop", robj, idn, Menulocal.inst, NULL); argv[0] = (char *) &sarray; argv[1] = NULL; exeobj(shell, "shell", newid, 1, argv); unregisterevloop(robj, idn, Menulocal.inst); menu_lock(FALSE); ResetStatusBar(); arraydel2(&sarray); if (Menulocal.addinconsole) { free_console(allocnow); } GetPageSettingsFromGRA(); UpdateAll(NULL); delobj(shell, newid); main_window_redraw(); } static void CmViewerButtonArm(GtkToggleToolButton *action, gpointer client_data) { int mode = PointB; struct Viewer *d; d = &NgraphApp.Viewer; if (! gtk_toggle_tool_button_get_active(action)) { return; } mode = GPOINTER_TO_INT(client_data); UnFocus(); switch (mode) { case PointB: DefaultMode = PointerModeBoth; NSetCursor(GDK_LEFT_PTR); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; case LegendB: DefaultMode = PointerModeLegend; NSetCursor(GDK_LEFT_PTR); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; case AxisB: DefaultMode = PointerModeAxis; NSetCursor(GDK_LEFT_PTR); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; case DataB: DefaultMode = PointerModeData; NSetCursor(GDK_LEFT_PTR); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; case TrimB: case EvalB: NSetCursor(GDK_LEFT_PTR); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; case TextB: NSetCursor(GDK_XTERM); gtk_stack_set_visible_child(GTK_STACK(ToolBox), SettingPanel); break; case ZoomB: NSetCursor(GDK_TARGET); gtk_stack_set_visible_child(GTK_STACK(ToolBox), CToolbar); break; default: NSetCursor(GDK_PENCIL); gtk_stack_set_visible_child(GTK_STACK(ToolBox), SettingPanel); } NgraphApp.Viewer.Mode = mode; NgraphApp.Viewer.Capture = FALSE; NgraphApp.Viewer.MouseMode = MOUSENONE; presetting_set_visibility(mode); if (d->MoveData) { move_data_cancel(d, TRUE); } gtk_widget_queue_draw(d->Win); } #define MODIFIED_TYPE_UNMODIFIED 0 #define MODIFIED_TYPE_DRAWOBJ 1 #define MODIFIED_TYPE_GRAOBJ 2 struct undo_info { enum MENU_UNDO_TYPE type; char **obj; time_t time; struct undo_info *next; int modified, id; }; static struct undo_info *UndoInfo = NULL, *RedoInfo = NULL; static void iterate_undo_func(struct objlist *parent, UNDO_FUNC func) { struct objlist *obj; obj = parent->child; while (obj) { if (obj->parent != parent) { break; } func(obj); if (obj->child) { iterate_undo_func(obj, func); } obj = obj->next; } } static int menu_undo_iteration(UNDO_FUNC func, char **objs) { struct objlist *obj; int r; r = 0; if (objs) { while (*objs) { obj = getobject(*objs); if (obj) { func(obj); } objs++; } } else { obj = getobject("draw"); if (obj == NULL) { return 1; } iterate_undo_func(obj, func); obj = getobject("fit"); if (obj == NULL) { return 1; } r = func(obj);; } return r; } static int menu_check_undo(void) { return UndoInfo ? 1 : 0; } static int menu_check_redo(void) { return RedoInfo ? 1 : 0; } static struct undo_info * undo_info_push(enum MENU_UNDO_TYPE type, char **obj) { static int id = 0; struct undo_info *info; time_t t; t = time(NULL); if (UndoInfo && (type == UndoInfo->type) && (t - UndoInfo->time < 2)) { UndoInfo->time = t; return NULL; } info = g_malloc(sizeof(*info)); if (info == NULL) { return NULL; } info->type = type; info->obj = g_strdupv(obj); info->next = UndoInfo; info->time = t; info->modified = get_graph_modified(); info->id = id++; UndoInfo = info; return info; } static struct undo_info * undo_info_pop(struct undo_info *undo_info) { struct undo_info *info, *next; if (undo_info == NULL) { return NULL; } info = undo_info; next = info->next; g_strfreev(info->obj); g_free(info); return next; } static char *UndoTypeStr[UNDO_TYPE_NUM] = { N_("edit"), N_("move"), N_("rotate"), N_("flip"), N_("delete object"), N_("create object"), N_("align"), N_("order"), N_("duplicate"), N_("execute shell"), N_("execute add-in"), N_("scale clear"), N_("scale undo"), N_("open file"), N_("add range"), N_("paste"), N_("scale"), N_("auto scale"), N_("scale trimming"), N_("edit"), /* dummy message */ }; #if USE_GTK_BUILDER #define EDIT_MENU_INDEX 1 #define UNDO_MENU_SECTION_INDEX 0 static void set_undo_menu_label(void) { GMenuModel *menu; GMenuItem *item; int i, n; char buf[1024], *label; menu = gtk_application_get_menubar(GtkApp); if (menu == NULL) { return; } menu = g_menu_model_get_item_link(G_MENU_MODEL(menu), EDIT_MENU_INDEX, G_MENU_LINK_SUBMENU); if (menu == NULL) { return; } n = g_menu_model_get_n_items(menu); if (n < UNDO_MENU_SECTION_INDEX) { return; } menu = g_menu_model_get_item_link(menu, UNDO_MENU_SECTION_INDEX, G_MENU_LINK_SECTION); if (menu == NULL) { return; } n = g_menu_model_get_n_items(menu); for (i = 0; i < n; i++) { g_menu_remove(G_MENU(menu), 0); } if (RedoInfo) { snprintf(buf, sizeof(buf), _("_Redo: %s"), _(UndoTypeStr[RedoInfo->type])); label = buf; } else { label = _("_Redo"); } item = g_menu_item_new(label, "app.EditRedoAction"); g_menu_insert_item(G_MENU(menu), 0, item); if (UndoInfo) { snprintf(buf, sizeof(buf), _("_Undo: %s"), _(UndoTypeStr[UndoInfo->type])); label = buf; } else { label = _("_Undo"); } item = g_menu_item_new(label, "app.EditUndoAction"); g_menu_insert_item(G_MENU(menu), 0, item); } #else static void set_undo_menu_label(void) { char buf[512], *label; if (ActionWidget[EditUndoAction].menu) { if (UndoInfo) { snprintf(buf, sizeof(buf), _("_Undo: %s"), _(UndoTypeStr[UndoInfo->type])); label = buf; } else { label = _("_Undo"); } gtk_menu_item_set_label(GTK_MENU_ITEM(ActionWidget[EditUndoAction].menu), label); } if (ActionWidget[EditRedoAction].menu) { if (RedoInfo) { snprintf(buf, sizeof(buf), _("_Redo: %s"), _(UndoTypeStr[RedoInfo->type])); label = buf; } else { label = _("_Redo"); } gtk_menu_item_set_label(GTK_MENU_ITEM(ActionWidget[EditRedoAction].menu), label); } } #endif int menu_save_undo(enum MENU_UNDO_TYPE type, char **obj) { struct undo_info *info; info = undo_info_push(type, obj); if (info == NULL) { return -1; } menu_undo_iteration(undo_save, obj); while (RedoInfo) { RedoInfo = undo_info_pop(RedoInfo); } set_undo_menu_label(); set_action_widget_sensitivity(EditUndoAction, menu_check_undo()); set_action_widget_sensitivity(EditRedoAction, menu_check_redo()); return info->id; } int menu_save_undo_single(enum MENU_UNDO_TYPE type, char *obj) { char *objs[2]; objs[0] = obj; objs[1] = NULL; return menu_save_undo(type, objs); } void menu_delete_undo(int id) { if (UndoInfo == NULL) { return; } if (UndoInfo->id != id) { return; } menu_undo_iteration(undo_delete, UndoInfo->obj); UndoInfo = undo_info_pop(UndoInfo); set_undo_menu_label(); if (! menu_check_undo()) { set_action_widget_sensitivity(EditUndoAction, FALSE); } } void menu_clear_undo(void) { while (UndoInfo) { UndoInfo = undo_info_pop(UndoInfo); } while (RedoInfo) { RedoInfo = undo_info_pop(RedoInfo); } menu_undo_iteration(undo_clear, NULL); set_undo_menu_label(); set_action_widget_sensitivity(EditUndoAction, menu_check_undo()); set_action_widget_sensitivity(EditRedoAction, menu_check_redo()); merge_cache_clear(); } static void undo_update_widgets(struct undo_info *info) { set_action_widget_sensitivity(EditUndoAction, menu_check_undo()); set_action_widget_sensitivity(EditRedoAction, menu_check_redo()); check_exist_instances(chkobject("draw")); set_axis_undo_button_sensitivity(axis_check_history()); if (info->obj == NULL) { UpdateAll(NULL); } else { char **ptr, *objs[OBJ_MAX]; int i, axis, data, axisgrid; axis = FALSE; data = FALSE; axisgrid = FALSE; ptr = info->obj; i = 0; while (ptr[i]) { objs[i] = ptr[i]; if (strcmp(ptr[i], "axis") == 0) { axis = TRUE; } else if (strcmp(ptr[i], "data") == 0) { data = TRUE; } else if (strcmp(ptr[i], "axisgrid") == 0) { axisgrid = TRUE; } i++; } if (axis) { if (! data) { objs[i] = "data"; i++; } if (! axisgrid) { objs[i] = "axisgrid"; i++; } } objs[i] = NULL; UpdateAll(objs); } } static void graph_modified_sub(int a) { if (Menulocal.obj == NULL) return; putobj(Menulocal.obj, "modified", 0, &a); } static int undo_check_modified(struct undo_info *info) { int modified_saved, modified_current; modified_saved = info->modified; modified_current = get_graph_modified(); if (modified_current) { if (! (modified_current & (modified_saved | MODIFIED_TYPE_GRAOBJ))) { graph_modified_sub(MODIFIED_TYPE_UNMODIFIED); } } else { if (modified_saved) { set_graph_modified(); } } return modified_current; } static struct undo_info * menu_undo_common(int *is_modify) { int r, modified; struct undo_info *info; r = menu_undo_iteration(undo_undo, UndoInfo->obj); if (r) { return NULL; } modified = undo_check_modified(UndoInfo); info = UndoInfo; UndoInfo = info->next; if (is_modify) { *is_modify = modified; } return info; } void menu_undo_internal(int id) { struct undo_info *info; if (UndoInfo == NULL) { return; } if (UndoInfo->id != id) { return; } info = menu_undo_common(NULL); if (info == NULL) { return; } undo_info_pop(info); set_action_widget_sensitivity(EditUndoAction, menu_check_undo()); set_action_widget_sensitivity(EditRedoAction, menu_check_redo()); set_undo_menu_label(); } void menu_undo(void) { int modified; struct undo_info *info; if (UndoInfo == NULL) { return; } info = menu_undo_common(&modified); if (info == NULL) { return; } info->next = RedoInfo; info->modified = modified; RedoInfo = info; undo_update_widgets(info); set_undo_menu_label(); } void menu_redo(void) { int r, modified; struct undo_info *info; if (RedoInfo == NULL) { return; } r = menu_undo_iteration(undo_redo, RedoInfo->obj); if (r) { return; } modified = undo_check_modified(RedoInfo); info = RedoInfo; RedoInfo = info->next; info->next = UndoInfo; info->modified = modified; UndoInfo = info; undo_update_widgets(info); set_undo_menu_label(); } int get_graph_modified(void) { return Menulocal.modified; } void set_graph_modified(void) { graph_modified_sub(MODIFIED_TYPE_DRAWOBJ); } void set_graph_modified_gra(void) { graph_modified_sub(MODIFIED_TYPE_GRAOBJ); } static void reset_modified_info(struct undo_info *info) { for (; info; info = info->next) { info->modified = 1; } } void reset_graph_modified(void) { graph_modified_sub(MODIFIED_TYPE_UNMODIFIED); reset_modified_info(UndoInfo); reset_modified_info(RedoInfo); } ngraph-gtk-6.08.00/src/gtk/gtk_presettings.c0000644000175000017500000006757613356564133015642 00000000000000#include "gtk_common.h" #include "gtk_presettings.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "object.h" #include "gra.h" #include "ogra2cairo.h" #include "odraw.h" #include "x11menu.h" #include "x11dialg.h" #include "x11gui.h" #include "x11file.h" #define SETTING_PANEL_MARGIN 4 #define LINE_WIDTH_ICON_NUM 7 #define LINE_STYLE_ICON_NUM 7 #define DEFAULT_JOIN_TYPE JOIN_TYPE_MITER #define DEFAULT_JOIN_STR "'miter'" #define DEFAULT_MARKER_TYPE MARKER_TYPE_NONE #define DEFAULT_MARKER_STR "'none'" #define DEFAULT_STROKE_FILL_TYPE 1 #define STROKE_FILL_ICON_NUM 8 struct presetting_widgets { GtkWidget *line_width, *line_style; GtkWidget *color1, *color2; GtkWidget *path_type; GtkWidget *join_type, *join_icon[JOIN_TYPE_NUM]; GtkWidget *marker_type_begin, *marker_begin_icon[MARKER_TYPE_NUM]; GtkWidget *marker_type_end, *marker_end_icon[MARKER_TYPE_NUM]; GtkWidget *mark_type_begin, *mark_type_end; GtkWidget *stroke_fill, *stroke_fill_icon[STROKE_FILL_ICON_NUM]; GtkWidget *font, *bold, *italic, *pt; GtkWidget *mark_type, *mark_size; enum JOIN_TYPE join; enum MARKER_TYPE marker_begin, marker_end; struct MarkDialog mark, mark_begin, mark_end; int lw, fill, stroke, close_path; }; static struct presetting_widgets Widgets = {NULL}; static int check_selected_item(GSimpleAction *action, GVariant *parameter, char **item, GtkWidget *button, GtkWidget **icon) { const char *state; int i, selected; selected = 0; state = g_variant_get_string(parameter, NULL); for (i = 0; item[i]; i++) { if (g_strcmp0(state, item[i]) == 0) { gtk_button_set_image(GTK_BUTTON(button), icon[i]); selected = i; break; } } g_simple_action_set_state(action, parameter); return selected; } static void JoinTypeAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { Widgets.join = check_selected_item(action, parameter, joinchar, Widgets.join_type, Widgets.join_icon); } static void MarkerTypeBeginAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { Widgets.marker_begin = check_selected_item(action, parameter, marker_type_char, Widgets.marker_type_begin, Widgets.marker_begin_icon); gtk_widget_set_sensitive(Widgets.mark_type_begin, Widgets.marker_begin == MARKER_TYPE_MARK); } static void MarkerTypeEndAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { Widgets.marker_end = check_selected_item(action, parameter, marker_type_char, Widgets.marker_type_end, Widgets.marker_end_icon); gtk_widget_set_sensitive(Widgets.mark_type_end, Widgets.marker_end == MARKER_TYPE_MARK); } static void set_stroke_fill_icon(void) { int i; i = 0; if (Widgets.stroke) { i |= 1; } if (Widgets.fill) { i |= 2; } if (Widgets.close_path) { i |= 4; } gtk_button_set_image(GTK_BUTTON(Widgets.stroke_fill), Widgets.stroke_fill_icon[i]); } static void StrokeFillClosePathAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); Widgets.close_path = state; set_stroke_fill_icon(); g_simple_action_set_state(action, parameter); } static void StrokeFillFillAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); Widgets.fill = state; set_stroke_fill_icon(); g_simple_action_set_state(action, parameter); } static void StrokeFillStrokeAction_activated(GSimpleAction *action, GVariant *parameter, gpointer app) { int state; state = g_variant_get_boolean(parameter); Widgets.stroke = state; set_stroke_fill_icon(); g_simple_action_set_state(action, parameter); } static GActionEntry ToolMenuEntries[] = { {"JoinTypeAction", NULL, "s", DEFAULT_JOIN_STR, JoinTypeAction_activated}, {"MarkerTypeBeginAction", NULL, "s", DEFAULT_MARKER_STR, MarkerTypeBeginAction_activated}, {"MarkerTypeEndAction", NULL, "s", DEFAULT_MARKER_STR, MarkerTypeEndAction_activated}, {"StrokeFillStrokeAction", NULL, NULL, "true", StrokeFillStrokeAction_activated}, {"StrokeFillFillAction", NULL, NULL, "false", StrokeFillFillAction_activated}, {"StrokeFillClosePathAction", NULL, NULL, "false", StrokeFillClosePathAction_activated}, }; static void create_images_sub(const char *prefix, char **item, GtkWidget **icon) { int i; GtkWidget *img; char img_file[256]; for (i = 0; item[i]; i++) { snprintf(img_file, sizeof(img_file), "%s_%s-symbolic", prefix, item[i]); img = gtk_image_new_from_icon_name(img_file, GTK_ICON_SIZE_LARGE_TOOLBAR); icon[i] = img; g_object_ref(img); } } static void create_marker_images_sub(const char *postfix, char **item, GtkWidget **icon) { int i; GtkWidget *img; char img_file[256]; for (i = 0; item[i]; i++) { snprintf(img_file, sizeof(img_file), "%s_%s-symbolic", item[i], postfix); img = gtk_image_new_from_icon_name(img_file, GTK_ICON_SIZE_LARGE_TOOLBAR); icon[i] = img; g_object_ref(img); } } static void create_images(struct presetting_widgets *widgets) { int i; create_marker_images_sub("begin", marker_type_char, widgets->marker_begin_icon); create_marker_images_sub("end", marker_type_char, widgets->marker_end_icon); create_images_sub("join", joinchar, widgets->join_icon); for (i = 0; i < STROKE_FILL_ICON_NUM; i++) { GtkWidget *img; char img_file[256]; snprintf(img_file, sizeof(img_file), "stroke_fill_%d-symbolic", i); img = gtk_image_new_from_icon_name(img_file, GTK_ICON_SIZE_LARGE_TOOLBAR); widgets->stroke_fill_icon[i] = img; g_object_ref(img); } } static void set_rgba(GtkWidget *cbutton, int *r, int *g, int *b, int *a) { GdkRGBA color; gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(cbutton), &color); *r = color.red * 255; *g = color.green * 255; *b = color.blue * 255; *a = color.alpha * 255; } static void get_rgba(struct objlist *obj, int id, int r1, int g1, int b1, int a1, int r2, int g2, int b2, int a2) { putobj(obj, "stroke_R", id, &r1); putobj(obj, "stroke_G", id, &g1); putobj(obj, "stroke_B", id, &b1); putobj(obj, "stroke_A", id, &a1); putobj(obj, "fill_R", id, &r2); putobj(obj, "fill_G", id, &g2); putobj(obj, "fill_B", id, &b2); putobj(obj, "fill_A", id, &a2); } static void set_font_style(struct objlist *obj, int id, const char *field) { int style, bold, italic; bold = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(Widgets.bold)); italic = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(Widgets.italic)); style = 0; if (bold) { style |= GRA_FONT_STYLE_BOLD; } if (italic) { style |= GRA_FONT_STYLE_ITALIC; } putobj(obj, field, id, &style); } static void set_font(struct objlist *obj, int id, const char *field) { char *fontalias; fontalias = combo_box_get_active_text(Widgets.font); if (fontalias) { putobj(obj, field, id, fontalias); } } static void set_text_obj(struct objlist *obj, int id) { int r, g, b, a, pt; set_font_style(obj, id, "style"); set_font(obj, id, "font"); set_rgba(Widgets.color1, &r, &g, &b, &a); putobj(obj, "R", id, &r); putobj(obj, "G", id, &g); putobj(obj, "B", id, &b); putobj(obj, "A", id, &a); pt = gtk_spin_button_get_value(GTK_SPIN_BUTTON(Widgets.pt)) * 100; putobj(obj, "pt", id, &pt); } static void set_path_type(struct objlist *obj, int id) { int type, interpolation; type = combo_box_get_active(Widgets.path_type); if (type == 0) { putobj(obj, "type", id, &type); } else { interpolation = type - 1; type = 1; putobj(obj, "type", id, &type); putobj(obj, "interpolation", id, &interpolation); } } void presetting_set_obj_field(struct objlist *obj, int id) { const char *name; int ival, r1, g1, b1, a1, r2, g2, b2, a2, width; if (obj == NULL) { return; } name = chkobjectname(obj); if (name == NULL) { return; } set_rgba(Widgets.color1, &r1, &g1, &b1, &a1); set_rgba(Widgets.color2, &r2, &g2, &b2, &a2); width = (2 << combo_box_get_active(Widgets.line_width)) * 10; if (strcmp(name, "axis") == 0) { putobj(obj, "width", id, &width); putobj(obj, "gauge_width1", id, &width); putobj(obj, "gauge_width2", id, &width); putobj(obj, "gauge_width3", id, &width); putobj(obj, "R", id, &r1); putobj(obj, "G", id, &g1); putobj(obj, "B", id, &b1); putobj(obj, "A", id, &a1); putobj(obj, "gauge_R", id, &r1); putobj(obj, "gauge_G", id, &g1); putobj(obj, "gauge_B", id, &b1); putobj(obj, "gauge_A", id, &a1); putobj(obj, "num_R", id, &r1); putobj(obj, "num_G", id, &g1); putobj(obj, "num_B", id, &b1); putobj(obj, "num_A", id, &a1); set_font_style(obj, id, "num_font_style"); set_font(obj, id, "num_font"); ival = gtk_spin_button_get_value(GTK_SPIN_BUTTON(Widgets.pt)) * 100; putobj(obj, "num_pt", id, &ival); ival = combo_box_get_active(Widgets.line_style); sputobjfield(obj, id, "style", FwLineStyle[ival].list); sputobjfield(obj, id, "gauge_style", FwLineStyle[ival].list); } else if (strcmp(name, "axisgrid") == 0) { ival = width / 2; putobj(obj, "width3", id, &ival); ival = width / 4; putobj(obj, "width2", id, &ival); ival = width / 8; putobj(obj, "width1", id, &ival); } else if (strcmp(name, "path") == 0) { putobj(obj, "stroke", id, &(Widgets.stroke)); putobj(obj, "fill", id, &(Widgets.fill)); putobj(obj, "close_path", id, &(Widgets.close_path)); ival = Widgets.join; putobj(obj, "join", id, &ival); ival = Widgets.marker_begin; putobj(obj, "marker_begin", id, &ival); ival = Widgets.marker_end; putobj(obj, "marker_end", id, &ival); putobj(obj, "mark_type_begin", id, &(Widgets.mark_begin.Type)); putobj(obj, "mark_type_end", id, &(Widgets.mark_end.Type)); putobj(obj, "width", id, &width); get_rgba(obj, id, r1, g1, b1, a1, r2, g2, b2, a2); ival = combo_box_get_active(Widgets.line_style); sputobjfield(obj, id, "style", FwLineStyle[ival].list); set_path_type(obj, id); } else if (strcmp(name, "rectangle") == 0) { putobj(obj, "stroke", id, &(Widgets.stroke)); putobj(obj, "fill", id, &(Widgets.fill)); putobj(obj, "width", id, &width); get_rgba(obj, id, r1, g1, b1, a1, r2, g2, b2, a2); ival = combo_box_get_active(Widgets.line_style); sputobjfield(obj, id, "style", FwLineStyle[ival].list); } else if (strcmp(name, "arc") == 0) { putobj(obj, "stroke", id, &(Widgets.stroke)); putobj(obj, "fill", id, &(Widgets.fill)); putobj(obj, "close_path", id, &(Widgets.close_path)); ival = Widgets.join; putobj(obj, "join", id, &ival); putobj(obj, "width", id, &width); get_rgba(obj, id, r1, g1, b1, a1, r2, g2, b2, a2); ival = combo_box_get_active(Widgets.line_style); sputobjfield(obj, id, "style", FwLineStyle[ival].list); ival = Widgets.marker_begin; putobj(obj, "marker_begin", id, &ival); ival = Widgets.marker_end; putobj(obj, "marker_end", id, &ival); putobj(obj, "mark_type_begin", id, &(Widgets.mark_begin.Type)); putobj(obj, "mark_type_end", id, &(Widgets.mark_end.Type)); } else if (strcmp(name, "mark") == 0) { putobj(obj, "width", id, &width); putobj(obj, "R", id, &r1); putobj(obj, "G", id, &g1); putobj(obj, "B", id, &b1); putobj(obj, "A", id, &a1); putobj(obj, "R2", id, &r2); putobj(obj, "G2", id, &g2); putobj(obj, "B2", id, &b2); putobj(obj, "A2", id, &a2); ival = gtk_spin_button_get_value(GTK_SPIN_BUTTON(Widgets.mark_size)) * 100; putobj(obj, "size", id, &ival); putobj(obj, "type", id, &(Widgets.mark.Type)); ival = combo_box_get_active(Widgets.line_style); sputobjfield(obj, id, "style", FwLineStyle[ival].list); } else if (strcmp(name, "text") == 0) { set_text_obj(obj, id); } } static void set_font_family(GtkWidget *cbox) { struct fontmap *fcur; combo_box_clear(cbox); fcur = Gra2cairoConf->fontmap_list_root; while (fcur) { combo_box_append_text(cbox, fcur->fontalias); fcur = fcur->next; } combo_box_set_active(cbox, 0); } static GtkWidget * create_toggle_button(GtkWidget *box, GtkWidget *img, const char *tooltip, int state) { GtkWidget *w; w = gtk_toggle_button_new(); gtk_container_add(GTK_CONTAINER(w), img); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), state); gtk_widget_set_tooltip_text(w, tooltip); return w; } void presetting_set_visibility(enum PointerType type) { switch (type) { case PointB: case AxisB: case LegendB: case DataB: case EvalB: case TrimB: case ZoomB: break; case PathB: gtk_widget_set_visible(Widgets.stroke_fill, TRUE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, TRUE); gtk_widget_set_visible(Widgets.path_type, TRUE); gtk_widget_set_visible(Widgets.join_type, TRUE); gtk_widget_set_visible(Widgets.marker_type_begin, TRUE); gtk_widget_set_visible(Widgets.marker_type_end, TRUE); gtk_widget_set_visible(Widgets.font, FALSE); gtk_widget_set_visible(Widgets.bold, FALSE); gtk_widget_set_visible(Widgets.italic, FALSE); gtk_widget_set_visible(Widgets.pt, FALSE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,TRUE); gtk_widget_set_visible(Widgets.mark_type_end, TRUE); break; case RectB: gtk_widget_set_visible(Widgets.stroke_fill, TRUE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, TRUE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, FALSE); gtk_widget_set_visible(Widgets.marker_type_begin, FALSE); gtk_widget_set_visible(Widgets.marker_type_end, FALSE); gtk_widget_set_visible(Widgets.font, FALSE); gtk_widget_set_visible(Widgets.bold, FALSE); gtk_widget_set_visible(Widgets.italic, FALSE); gtk_widget_set_visible(Widgets.pt, FALSE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,FALSE); gtk_widget_set_visible(Widgets.mark_type_end, FALSE); break; case ArcB: gtk_widget_set_visible(Widgets.stroke_fill, TRUE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, TRUE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, TRUE); gtk_widget_set_visible(Widgets.marker_type_begin, TRUE); gtk_widget_set_visible(Widgets.marker_type_end, TRUE); gtk_widget_set_visible(Widgets.font, FALSE); gtk_widget_set_visible(Widgets.bold, FALSE); gtk_widget_set_visible(Widgets.italic, FALSE); gtk_widget_set_visible(Widgets.pt, FALSE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,TRUE); gtk_widget_set_visible(Widgets.mark_type_end, TRUE); break; case MarkB: gtk_widget_set_visible(Widgets.stroke_fill, FALSE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, TRUE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, FALSE); gtk_widget_set_visible(Widgets.marker_type_begin, FALSE); gtk_widget_set_visible(Widgets.marker_type_end, FALSE); gtk_widget_set_visible(Widgets.font, FALSE); gtk_widget_set_visible(Widgets.bold, FALSE); gtk_widget_set_visible(Widgets.italic, FALSE); gtk_widget_set_visible(Widgets.pt, FALSE); gtk_widget_set_visible(Widgets.mark_size, TRUE); gtk_widget_set_visible(Widgets.mark_type, TRUE); gtk_widget_set_visible(Widgets.mark_type_begin,FALSE); gtk_widget_set_visible(Widgets.mark_type_end, FALSE); break; case TextB: set_font_family(Widgets.font); gtk_widget_set_visible(Widgets.stroke_fill, FALSE); gtk_widget_set_visible(Widgets.line_width, FALSE); gtk_widget_set_visible(Widgets.line_style, FALSE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, FALSE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, FALSE); gtk_widget_set_visible(Widgets.marker_type_begin, FALSE); gtk_widget_set_visible(Widgets.marker_type_end, FALSE); gtk_widget_set_visible(Widgets.font, TRUE); gtk_widget_set_visible(Widgets.bold, TRUE); gtk_widget_set_visible(Widgets.italic, TRUE); gtk_widget_set_visible(Widgets.pt, TRUE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,FALSE); gtk_widget_set_visible(Widgets.mark_type_end, FALSE); break; case GaussB: gtk_widget_set_visible(Widgets.stroke_fill, FALSE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, FALSE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, TRUE); gtk_widget_set_visible(Widgets.marker_type_begin, FALSE); gtk_widget_set_visible(Widgets.marker_type_end, FALSE); gtk_widget_set_visible(Widgets.font, FALSE); gtk_widget_set_visible(Widgets.bold, FALSE); gtk_widget_set_visible(Widgets.italic, FALSE); gtk_widget_set_visible(Widgets.pt, FALSE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,FALSE); gtk_widget_set_visible(Widgets.mark_type_end, FALSE); break; case FrameB: case SectionB: case CrossB: case SingleB: gtk_widget_set_visible(Widgets.stroke_fill, FALSE); gtk_widget_set_visible(Widgets.line_width, TRUE); gtk_widget_set_visible(Widgets.line_style, TRUE); gtk_widget_set_visible(Widgets.color1, TRUE); gtk_widget_set_visible(Widgets.color2, FALSE); gtk_widget_set_visible(Widgets.path_type, FALSE); gtk_widget_set_visible(Widgets.join_type, FALSE); gtk_widget_set_visible(Widgets.marker_type_begin, FALSE); gtk_widget_set_visible(Widgets.marker_type_end, FALSE); gtk_widget_set_visible(Widgets.font, TRUE); gtk_widget_set_visible(Widgets.bold, TRUE); gtk_widget_set_visible(Widgets.italic, TRUE); gtk_widget_set_visible(Widgets.pt, TRUE); gtk_widget_set_visible(Widgets.mark_size, FALSE); gtk_widget_set_visible(Widgets.mark_type, FALSE); gtk_widget_set_visible(Widgets.mark_type_begin,FALSE); gtk_widget_set_visible(Widgets.mark_type_end, FALSE); break; } } #if 0 static GtkWidget * create_mark_combo_box(const char *tooltop) { GtkWidget *cbox; GtkListStore *list; GtkTreeIter iter; int j; GtkCellRenderer *rend; list = gtk_list_store_new(2, G_TYPE_STRING, G_TYPE_OBJECT); cbox = gtk_combo_box_new_with_model(GTK_TREE_MODEL(list)); gtk_widget_set_tooltip_text(cbox, tooltop); rend = gtk_cell_renderer_text_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "text", 0); rend = gtk_cell_renderer_pixbuf_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "pixbuf", 1); for (j = 0; j < MARK_TYPE_NUM; j++) { GdkPixbuf *pixbuf; pixbuf = gdk_pixbuf_get_from_surface(NgraphApp.markpix[j], 0, 0, MARK_PIX_SIZE, MARK_PIX_SIZE); if (pixbuf) { char buf[64]; gtk_list_store_append(list, &iter); snprintf(buf, sizeof(buf), "%02d", j); gtk_list_store_set(list, &iter, 0, buf, 1, pixbuf, -1); g_object_unref(pixbuf); } } gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), 0); return cbox; } #endif static GtkWidget * create_line_width_combo_box(void) { GtkWidget *cbox; GtkListStore *list; GtkTreeIter iter; int j; GtkCellRenderer *rend; list = gtk_list_store_new(3, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_INT); cbox = gtk_combo_box_new_with_model(GTK_TREE_MODEL(list)); rend = gtk_cell_renderer_text_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "text", 0); rend = gtk_cell_renderer_pixbuf_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "icon-name", 1); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend, "stock-size", 2); for (j = 0; j < LINE_WIDTH_ICON_NUM; j++) { char buf[64], img_file[256]; snprintf(img_file, sizeof(img_file), "linewidth_%03d-symbolic", 2 << j); gtk_list_store_append(list, &iter); snprintf(buf, sizeof(buf), "%4.1f", (2 << j) / 10.0); gtk_list_store_set(list, &iter, 0, buf, 1, img_file, 2, GTK_ICON_SIZE_LARGE_TOOLBAR, -1); } gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), 1); return cbox; } static GtkWidget * create_line_style_combo_box(void) { GtkWidget *cbox; int j; cbox = gtk_combo_box_text_new(); for (j = 0; j < LINE_STYLE_ICON_NUM; j++) { gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(cbox), NULL, _(FwLineStyle[j].name)); } gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), 0); return cbox; } static GtkWidget * create_path_type_combo_box(void) { GtkWidget *cbox; int j; cbox = gtk_combo_box_text_new(); gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(cbox), NULL, _("line")); for (j = 0; intpchar[j]; j++) { gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(cbox), NULL, _(intpchar[j])); } gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), 0); return cbox; } GtkWidget * create_menu_button(GtkBuilder *builder, const char *menu_name, const char *tooltip) { GtkWidget *w; GMenuModel *menu; w = gtk_menu_button_new(); menu = G_MENU_MODEL(gtk_builder_get_object(builder, menu_name)); gtk_menu_button_set_menu_model(GTK_MENU_BUTTON(w), menu); gtk_widget_set_tooltip_text(w, tooltip); return w; } static void select_mark(GtkWidget *w, gpointer client_data) { struct MarkDialog *d; d = (struct MarkDialog *) client_data; DialogExecute(d->parent, d); button_set_mark_image(w, d->Type); } static void setup_mark_type(GtkWidget *type, struct MarkDialog *mark) { button_set_mark_image(type, 0); MarkDialog(mark, TopLevel, 0); } GtkWidget * presetting_create_panel(GtkApplication *app) { GtkWidget *w, *box, *img; GtkBuilder *builder; GdkRGBA color; g_action_map_add_action_entries(G_ACTION_MAP(app), ToolMenuEntries, G_N_ELEMENTS(ToolMenuEntries), app); create_images(&Widgets); builder = gtk_builder_new_from_resource(RESOURCE_PATH "/gtk/menus-tool.ui"); box = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_widget_set_margin_start(box, SETTING_PANEL_MARGIN); gtk_widget_set_margin_end(box, SETTING_PANEL_MARGIN); gtk_widget_set_margin_top(box, SETTING_PANEL_MARGIN); gtk_widget_set_margin_bottom(box, SETTING_PANEL_MARGIN); w = combo_box_create(); set_font_family(w); gtk_widget_set_tooltip_text(w, _("Font name")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.font = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POINT, FALSE, FALSE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(w), DEFAULT_FONT_PT / 100.0); gtk_entry_set_width_chars(GTK_ENTRY(w), 5); gtk_widget_set_tooltip_text(w, _("Font size")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.pt = w; img = gtk_image_new_from_icon_name("format-text-bold-symbolic", GTK_ICON_SIZE_BUTTON); Widgets.bold = create_toggle_button(box, img, _("Bold"), FALSE); img = gtk_image_new_from_icon_name("format-text-italic-symbolic", GTK_ICON_SIZE_BUTTON); Widgets.italic = create_toggle_button(box, img, _("Italic"), FALSE); w = create_path_type_combo_box(); gtk_widget_set_margin_end(w, SETTING_PANEL_MARGIN * 4); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.path_type = w; w = create_menu_button(builder, "stroke-fill-menu", _("stroke/fill")); Widgets.stroke_fill = w; Widgets.stroke = TRUE; gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); set_stroke_fill_icon(); w = gtk_button_new(); g_signal_connect(w, "clicked", G_CALLBACK(select_mark), &(Widgets.mark)); setup_mark_type(w, &(Widgets.mark)); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.mark_type = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, FALSE, FALSE); gtk_spin_button_set_value(GTK_SPIN_BUTTON(w), DEFAULT_MARK_SIZE / 100.0); gtk_entry_set_width_chars(GTK_ENTRY(w), 5); gtk_widget_set_tooltip_text(w, _("Mark size")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.mark_size = w; w = create_line_width_combo_box(); gtk_widget_set_tooltip_text(w, _("Line Width")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.line_width = w; w = create_line_style_combo_box(); gtk_widget_set_tooltip_text(w, _("Line Style")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.line_style = w; w = create_color_button(NULL); color.red = color.green = color.blue = 0; color.alpha = 1; gtk_color_chooser_set_rgba(GTK_COLOR_CHOOSER(w), &color); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.color1 = w; gtk_widget_set_name(Widgets.color1, "StrokeColorButton"); w = create_color_button(NULL); color.red = color.green = color.blue = 1; color.alpha = 1; gtk_color_chooser_set_rgba(GTK_COLOR_CHOOSER(w), &color); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.color2 = w; w = create_menu_button(builder, "join-type-menu", _("Join")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.join_type = w; gtk_button_set_image(GTK_BUTTON(Widgets.join_type), Widgets.join_icon[DEFAULT_JOIN_TYPE]); w = gtk_button_new(); g_signal_connect(w, "clicked", G_CALLBACK(select_mark), &(Widgets.mark_begin)); setup_mark_type(w, &(Widgets.mark_begin)); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.mark_type_begin = w; w = create_menu_button(builder, "marker-type-begin-menu", _("Marker begin")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.marker_type_begin = w; Widgets.marker_begin = DEFAULT_MARKER_TYPE; gtk_button_set_image(GTK_BUTTON(Widgets.marker_type_begin), Widgets.marker_begin_icon[DEFAULT_MARKER_TYPE]); w = create_menu_button(builder, "marker-type-end-menu", _("Marker end")); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.marker_type_end = w; Widgets.marker_end = DEFAULT_MARKER_TYPE; gtk_button_set_image(GTK_BUTTON(Widgets.marker_type_end), Widgets.marker_end_icon[DEFAULT_MARKER_TYPE]); w = gtk_button_new(); g_signal_connect(w, "clicked", G_CALLBACK(select_mark), &(Widgets.mark_end)); setup_mark_type(w, &(Widgets.mark_end)); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 0); Widgets.mark_type_end = w; gtk_widget_set_sensitive(Widgets.mark_type_begin, Widgets.marker_begin == MARKER_TYPE_MARK); gtk_widget_set_sensitive(Widgets.mark_type_end, Widgets.marker_end == MARKER_TYPE_MARK); g_object_unref(builder); return box; } ngraph-gtk-6.08.00/src/gtk/x11view.h0000644000175000017500000000423513165673030013711 00000000000000/* * $Id: x11view.h,v 1.12 2009-05-01 09:15:59 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #define DROP_TYPE_FILE 0 #define DROP_TYPE_TEXT 1 #define FILE_TYPE_AUTO 0 #define FILE_TYPE_MERGE 1 #define FILE_TYPE_DATA 2 #define ROTATE_CLOCKWISE 0 #define ROTATE_COUNTERCLOCKWISE 1 struct Point { int x, y; }; struct FocusObj { struct objlist *obj; int oid; }; enum FOCU_OBJ_TYPE { FOCUS_OBJ_TYPE_AXIS = 0x01, FOCUS_OBJ_TYPE_MERGE = 0x02, FOCUS_OBJ_TYPE_LEGEND = 0x04, FOCUS_OBJ_TYPE_TEXT = 0x08, }; void ViewerWinSetup(void); void ViewerWinClose(void); void ViewerWinUpdate(char **objects); void OpenGC(void); void CloseGC(void); void SetScroller(void); void Focus(struct objlist *fobj, int id, int add); void UnFocus(void); void ChangeDPI(void); void Draw(int SelectFile); void CmViewerClear(void *w, gpointer client_data); void CmViewerDraw(void *w, gpointer client_data); gboolean CmViewerButtonPressed(GtkWidget *widget, GdkEventButton *event, gpointer user_data); int data_dropped(char **filenames, int num, int file_type); void draw_paper_frame(void); void CmEditMenuCB(void *w, gpointer client_data); void ViewCross(int state); void ViewerUpdateCB(void *w, gpointer client_data); int check_focused_obj_type(const struct Viewer *d, int *type); void move_data_cancel(struct Viewer *d, gboolean show_message); int check_paint_lock(void); void update_bg(void); ngraph-gtk-6.08.00/src/gtk/gtk_ruler.h0000644000175000017500000000043513070106167014376 00000000000000#ifndef GTK_RULER_HEADER #define GTK_RULER_HEADER #include GtkWidget *nruler_new(GtkOrientation orientation); void nruler_set_range(GtkWidget *ruler, double lower, double upper); void nruler_set_position(GtkWidget *ruler, double position); #endif /* GTK_RULER_HEADER */ ngraph-gtk-6.08.00/src/gtk/gtk_combo.c0000644000175000017500000000553713070106167014347 00000000000000/* * $Id: gtk_combo.c,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ */ #include "gtk_common.h" #include #include "gtk_widget.h" #include "gtk_combo.h" static void set_model(GtkComboBox *cbox, int renderer) { GtkListStore *list; GtkCellRenderer *rend_s; list = gtk_list_store_new(1, G_TYPE_STRING); gtk_combo_box_set_model(cbox, GTK_TREE_MODEL(list)); if (renderer) { rend_s = gtk_cell_renderer_text_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend_s, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend_s, "text", 0); } /* rend_n = gtk_cell_renderer_text_new(); g_object_set_data((GObject *) rend_n, "visible", FALSE); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(cbox), rend_n, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(cbox), rend_s, "text", 1); */ } GtkWidget * combo_box_create(void) { GtkComboBox *cbox; cbox = GTK_COMBO_BOX(gtk_combo_box_new()); set_model(cbox, TRUE); return GTK_WIDGET(cbox); } GtkWidget * combo_box_entry_create(void) { GtkComboBox *cbox; cbox = GTK_COMBO_BOX(gtk_combo_box_new_with_entry()); set_model(cbox, FALSE); gtk_combo_box_set_entry_text_column(GTK_COMBO_BOX(cbox), 0); gtk_entry_set_activates_default(GTK_ENTRY(gtk_bin_get_child(GTK_BIN(cbox))), TRUE); return GTK_WIDGET(cbox); } void combo_box_entry_set_text(GtkWidget *cbox, char *str) { gtk_entry_set_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN(cbox))), str); } const char * combo_box_entry_get_text(GtkWidget *cbox) { return gtk_entry_get_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN(cbox)))); } void combo_box_entry_set_width(GtkWidget *cbox, int width) { return gtk_entry_set_width_chars(GTK_ENTRY(gtk_bin_get_child(GTK_BIN(cbox))), width); } void combo_box_append_text(GtkWidget *cbox, char *str) { GtkListStore *list; GtkTreeIter iter; list = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, 0, str, -1); } int combo_box_get_active(GtkWidget *cbox) { return gtk_combo_box_get_active(GTK_COMBO_BOX(cbox)); } char * combo_box_get_active_text(GtkWidget *cbox) { GtkTreeIter iter; gboolean ret; GtkTreeModel *model; char *str; ret = gtk_combo_box_get_active_iter(GTK_COMBO_BOX(cbox), &iter); if (! ret) return NULL; model = gtk_combo_box_get_model(GTK_COMBO_BOX(cbox)); gtk_tree_model_get(model, &iter, 0, &str, -1); return str; } void combo_box_set_active(GtkWidget *cbox, int i) { gtk_combo_box_set_active(GTK_COMBO_BOX(cbox), i); } void combo_box_clear(GtkWidget *cbox) { GtkListStore *list; list = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); gtk_list_store_clear(list); } int combo_box_get_num(GtkWidget *cbox) { GtkTreeModel *model; model = gtk_combo_box_get_model(GTK_COMBO_BOX(cbox)); return gtk_tree_model_iter_n_children(model, NULL); } ngraph-gtk-6.08.00/src/gtk/x11cood.c0000644000175000017500000000647213351432267013665 00000000000000/* * $Id: x11cood.c,v 1.15 2009-11-16 09:13:05 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include "ntime.h" #include "object.h" #include "axis.h" #include "gtk_subwin.h" #include "gtk_widget.h" #include "x11bitmp.h" #include "x11gui.h" #include "ox11menu.h" #include "x11menu.h" #include "x11cood.h" void CoordWinSetFont(const char *font) { #if GTK_CHECK_VERSION(3, 16, 0) if (NgraphApp.CoordWin.data.text && font) { set_widget_font(NgraphApp.CoordWin.data.text, font); } #else /* GTK_CHECK_VERSION(3, 16, 0) */ const char *ptr; PangoAttrList *pattr; PangoFontDescription *desc; GtkLabel *label; label = GTK_LABEL(NgraphApp.CoordWin.data.text); if (label == NULL) return; pattr = gtk_label_get_attributes(label); if (pattr == NULL) { pattr = pango_attr_list_new(); gtk_label_set_attributes(GTK_LABEL(label), pattr); } ptr = (font) ? font : "Monospace"; desc = pango_font_description_from_string(ptr); pango_attr_list_change(pattr, pango_attr_font_desc_new(desc)); pango_font_description_free(desc); #endif } void CoordWinSetCoord(int x, int y) { struct objlist *obj; int i, num, type; char *argv[3]; double a; char *name; struct SubWin *d; static GString *str = NULL; static int lock = FALSE; d = &(NgraphApp.CoordWin); obj = chkobject("axis"); if (d->Win == NULL || obj == NULL || d->data.text == NULL) { return; } num = chkobjlastinst(obj) + 1; if (lock) { return; } lock = TRUE; if (str == NULL) { str = g_string_new(""); gtk_label_set_text(GTK_LABEL(d->data.text), ""); if (str == NULL) { lock = FALSE; return; } } g_string_printf(str, "(X:%6.2f Y:%6.2f)", x / 100.0, y / 100.0); argv[0] = (char *) &x; argv[1] = (char *) &y; argv[2] = NULL; for (i = 0; i < num; i++) { if (getobj(obj, "coordinate", i, 2, argv, &a) == -1) { continue; } getobj(obj, "group", i, 0, NULL, &name); getobj(obj, "type", i, 0, NULL, &type); g_string_append_printf(str, "\n%2d %5s %+.7e", i, name, a); if (type == AXIS_TYPE_MJD) { char *s; s = nstrftime("\n %F %T", a); if (s) { g_string_append(str, s); g_free(s); } } } gtk_label_set_text(GTK_LABEL(d->data.text), str->str); lock = FALSE; } void CoordWinUpdate(int clear) { } GtkWidget * CoordWinCreate(struct SubWin *d) { if (d->Win) { return d->Win; } label_sub_window_create(d); CoordWinSetFont(Menulocal.coordwin_font); return d->Win; } ngraph-gtk-6.08.00/src/gtk/gtk_widget.h0000644000175000017500000000631213244151203014522 00000000000000#ifndef GTK_WIDGET_HEADER #define GTK_WIDGET_HEADER #include "object.h" #define SPIN_ENTRY_MAX 1000000 #define NUM_ENTRY_WIDTH 12 enum SPIN_BUTTON_TYPE { SPIN_BUTTON_TYPE_WIDTH, SPIN_BUTTON_TYPE_LENGTH, SPIN_BUTTON_TYPE_POSITION, SPIN_BUTTON_TYPE_ANGLE, SPIN_BUTTON_TYPE_POINT, SPIN_BUTTON_TYPE_SPACE_POINT, SPIN_BUTTON_TYPE_PERCENT, SPIN_BUTTON_TYPE_INT, SPIN_BUTTON_TYPE_UINT, SPIN_BUTTON_TYPE_NUM, SPIN_BUTTON_TYPE_NATURAL, SPIN_BUTTON_TYPE_CUSTOM, }; enum OBJ_FIELD_COLOR_TYPE { OBJ_FIELD_COLOR_TYPE_0, OBJ_FIELD_COLOR_TYPE_1, OBJ_FIELD_COLOR_TYPE_2, OBJ_FIELD_COLOR_TYPE_FILL, OBJ_FIELD_COLOR_TYPE_STROKE, OBJ_FIELD_COLOR_TYPE_AXIS_BASE, OBJ_FIELD_COLOR_TYPE_AXIS_GAUGE, OBJ_FIELD_COLOR_TYPE_AXIS_NUM, }; enum SELECT_OBJ_COLOR_RESULT { SELECT_OBJ_COLOR_DIFFERENT, SELECT_OBJ_COLOR_SAME, SELECT_OBJ_COLOR_ERROR, SELECT_OBJ_COLOR_CANCEL, }; enum WIDGET_MARGIN { WIDGET_MARGIN_LEFT = 1, WIDGET_MARGIN_RIGHT = 2, WIDGET_MARGIN_TOP = 4, WIDGET_MARGIN_BOTTOM = 8, }; GtkWidget *create_spin_entry_type(enum SPIN_BUTTON_TYPE type, int set_default_size, int set_default_action); GtkWidget *create_spin_entry(int min, int max, int inc, int set_default_size, int set_default_action); void set_button_icon(GtkWidget *w, const char *icon_name); void spin_entry_set_val(GtkWidget *entry, int val); int spin_entry_get_val(GtkWidget *entry); void spin_entry_set_range(GtkWidget *w, int min, int max); void spin_entry_set_inc(GtkWidget *w, int inc, int page); char *entry_get_filename(GtkWidget *w); int entry_set_filename(GtkWidget *w, char *filename); GtkWidget *create_color_button(GtkWidget *win); GtkWidget *create_text_entry(int set_default_size, int set_default_action); GtkWidget *create_file_entry(struct objlist *obj); GtkWidget *create_file_entry_with_cb(GCallback cb, gpointer data); GtkWidget *create_direction_entry(void); GtkWidget *item_setup(GtkWidget *box, GtkWidget *w, char *title, gboolean expand); GtkWidget *get_parent_window(GtkWidget *w); GtkWidget *add_widget_to_table_sub(GtkWidget *table, GtkWidget *w, char *title, int expand, int col, int width, int col_max, int n); GtkWidget *add_widget_to_table(GtkWidget *table, GtkWidget *w, char *title, int expand, int n); GtkWidget *add_copy_button_to_box(GtkWidget *parent_box, GCallback cb, gpointer d, char *obj_name); GtkWidget *get_mnemonic_label(GtkWidget *w); GtkWidget *create_text_view_with_line_number(GtkWidget **v); void text_view_with_line_number_set_text(GtkWidget *view, const gchar *str); void text_view_with_line_number_set_font(GtkWidget *view, const gchar *font); void set_widget_sensitivity_with_label(GtkWidget *w, gboolean state); void set_widget_visibility_with_label(GtkWidget *w, gboolean state); void combo_box_create_mark(GtkWidget *cbox, GtkTreeIter *parent, int col_id, int type); enum SELECT_OBJ_COLOR_RESULT select_obj_color(struct objlist *obj, int id, enum OBJ_FIELD_COLOR_TYPE type); void set_widget_margin(GtkWidget *w, int margin_pos); void set_scale_mark(GtkWidget *scale, GtkPositionType pos, int start, int inc); #if GTK_CHECK_VERSION(3, 16, 0) void set_widget_font(GtkWidget *w, const char *font); #endif void add_default_color(struct narray *palette); void add_default_gray(struct narray *palette); #endif ngraph-gtk-6.08.00/src/gtk/dir_defs.h.in0000644000175000017500000000110013070106167014552 00000000000000/* * $Id: dir_defs.h.in,v 1.3 2009-06-18 11:32:11 hito Exp $ */ #ifndef _DIR_DEFS_HEADER #define _DIR_DEFS_HEADER #if WINDOWS || OSX extern char *DOCDIR, *NDATADIR, *ADDINDIR, *LIBDIR, *PLUGINDIR, *CONFDIR; #else /* WINDOWS */ #define DOCDIR "DOCDIRDEF" #define LIBDIR "LIBEXECDIRDEF" #define PLUGINDIR "LIBDIRDEF/plugins" #define NDATADIR "DATADIRDEF" #define ADDINDIR "DATADIRDEF/addin" #define CONFDIR "CONFDIRDEF" #endif /* WINDOWS */ #if WINDOWS #define HOME_DIR "Ngraph" #else #define HOME_DIR ".Ngraph" #endif #define HELP_FILE "ngraph.html" #endif ngraph-gtk-6.08.00/src/gtk/x11opt_proto.h0000644000175000017500000001706413070106167014765 00000000000000#ifndef HAVE_UPDATE_FUNC static void CREATE_NAME(Pref, DialogUpdate)(GtkWidget *w, gpointer client_data) { struct CREATE_NAME(Pref, Dialog) *d; int a, j; struct LIST_TYPE *fcur; d = (struct CREATE_NAME(Pref, Dialog) *) client_data; a = list_store_get_selected_index(d->list); j = 0; fcur = LIST_ROOT; while (fcur) { if (j == a) break; fcur = fcur->next; j++; } #ifdef SET_DIALOG if (fcur) { CREATE_NAME(Set, Dialog)(&SET_DIALOG, fcur); DialogExecute(d->widget, &SET_DIALOG); CREATE_NAME(Pref, DialogSetupItem)(d); } #endif } #endif #ifdef LIST_INIT static void CREATE_NAME(Pref, DialogAdd)(GtkWidget *w, gpointer client_data) { struct LIST_TYPE *fcur, *fprev, *fnew; struct CREATE_NAME(Pref, Dialog) *d; d = (struct CREATE_NAME(Pref, Dialog) *) client_data; fprev = NULL; fcur = LIST_ROOT; while (fcur) { fprev = fcur; fcur = fcur->next; } fnew = (struct LIST_TYPE *) g_malloc(sizeof(struct LIST_TYPE)); if (fnew == NULL) { return; } LIST_INIT(fnew); if (fprev == NULL) { LIST_ROOT = fnew; } else { fprev->next = fnew; } CREATE_NAME(Set, Dialog)(&SET_DIALOG, fnew); if (DialogExecute(d->widget, &SET_DIALOG) != IDOK) { if (fprev == NULL) { LIST_ROOT = NULL; } else { fprev->next = NULL; } g_free(fnew); } CREATE_NAME(Pref, DialogSetupItem)(d); } #endif #ifdef LIST_FREE static void CREATE_NAME(Pref, DialogRemove)(GtkWidget *w, gpointer client_data) { int a, j; struct LIST_TYPE *fcur, *fprev, *fdel; struct CREATE_NAME(Pref, Dialog) *d; d = (struct CREATE_NAME(Pref, Dialog) *) client_data; a = list_store_get_selected_index(d->list); j = 0; fprev = NULL; fcur = LIST_ROOT; while (fcur) { if (j == a) { fdel = fcur; if (fprev == NULL) LIST_ROOT = fcur->next; else fprev->next = fcur->next; fcur = fcur->next; LIST_FREE(fdel); CREATE_NAME(Pref, DialogSetupItem)(d); break; } else { fprev = fcur; fcur = fcur->next; } j++; } } #endif static int CREATE_NAME(Pref, DialogMoveSub)(struct CREATE_NAME(Pref, Dialog) *d, int a) { int j, n; struct LIST_TYPE *fcur, *fprev, *next; n = list_store_get_num(d->list); if (a < 0 || a >= n - 1) return -1; j = 0; fprev = NULL; fcur = LIST_ROOT; while (fcur) { if (j == a) { next = fcur->next; if (next == NULL) { break; } else if (fprev == NULL) { LIST_ROOT = next; } else { fprev->next = next; } fcur->next = next->next; next->next = fcur; break; } fprev = fcur; fcur = fcur->next; j++; } CREATE_NAME(Pref, DialogSetupItem)(d); return a; } static void CREATE_NAME(Pref, DialogUp)(GtkWidget *w, gpointer client_data) { struct CREATE_NAME(Pref, Dialog) *d; int a; d = (struct CREATE_NAME(Pref, Dialog) *) client_data; a = list_store_get_selected_index(d->list); a = CREATE_NAME(Pref, DialogMoveSub)(d, a - 1); if (a >= 0) { list_store_select_nth(d->list, a); } } static void CREATE_NAME(Pref, DialogDown)(GtkWidget *w, gpointer client_data) { struct CREATE_NAME(Pref, Dialog) *d; int a; d = (struct CREATE_NAME(Pref, Dialog) *) client_data; a = list_store_get_selected_index(d->list); a = CREATE_NAME(Pref, DialogMoveSub)(d, a); if (a >= 0) { list_store_select_nth(d->list, a + 1); } } static gboolean CREATE_NAME(Pref, ListDefailtCb)(GtkWidget *w, GdkEventAny *e, gpointer user_data) { struct CREATE_NAME(Pref, Dialog) *d; int i; d = (struct CREATE_NAME(Pref, Dialog) *) user_data; i = list_store_get_selected_index(d->list); if (i < 0) return FALSE; if (e->type == GDK_2BUTTON_PRESS) { CREATE_NAME(Pref, DialogUpdate)(NULL, d); return TRUE; } else if (e->type == GDK_KEY_PRESS) { GdkEventKey *ke; ke = (GdkEventKey *) e; switch (ke->keyval) { case GDK_KEY_Return: CREATE_NAME(Pref, DialogUpdate)(NULL, d); return TRUE; break; case GDK_KEY_Up: if (ke->state & GDK_SHIFT_MASK) { CREATE_NAME(Pref, DialogUp)(NULL, d); return TRUE; } break; case GDK_KEY_Down: if (ke->state & GDK_SHIFT_MASK) { CREATE_NAME(Pref, DialogDown)(NULL, d); return TRUE; } break; case GDK_KEY_Delete: CREATE_NAME(Pref, DialogRemove)(NULL, d); return TRUE; break; } } return FALSE; } static gboolean CREATE_NAME(Pref, ListSelCb)(GtkTreeSelection *sel, gpointer user_data) { int a, n; struct CREATE_NAME(Pref, Dialog) *d; d = (struct CREATE_NAME(Pref, Dialog) *) user_data; a = list_store_get_selected_index(d->list); n = list_store_get_num(d->list); gtk_widget_set_sensitive(d->update_b, a >= 0); gtk_widget_set_sensitive(d->del_b, a >= 0); gtk_widget_set_sensitive(d->up_b, a > 0); gtk_widget_set_sensitive(d->down_b, a >= 0 && a < n - 1); return FALSE; } static void CREATE_NAME(Pref, DialogCreateWidgets)(struct CREATE_NAME(Pref, Dialog) *d, GtkWidget *win_box, int n, n_list_store * list) { GtkWidget *w, *hbox, *vbox, *swin; GtkTreeSelection *sel; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); w = list_store_create(n, list); d->list = w; g_signal_connect(d->list, "button-press-event", G_CALLBACK(CREATE_NAME(Pref, ListDefailtCb)), d); g_signal_connect(d->list, "key-press-event", G_CALLBACK(CREATE_NAME(Pref, ListDefailtCb)), d); gtk_container_add(GTK_CONTAINER(swin), w); sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(w)); g_signal_connect(sel, "changed", G_CALLBACK(CREATE_NAME(Pref, ListSelCb)), d); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), swin); if (win_box) { gtk_box_pack_start(GTK_BOX(win_box), w, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox), win_box, TRUE, TRUE, 4); } else { gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); } vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w= gtk_button_new_with_mnemonic(_("_Add")); set_button_icon(w, "list-add"); g_signal_connect(w, "clicked", G_CALLBACK(CREATE_NAME(Pref, DialogAdd)), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_button_new_with_mnemonic(_("_Preferences")); set_button_icon(w, "preferences-system"); g_signal_connect(w, "clicked", G_CALLBACK(CREATE_NAME(Pref, DialogUpdate)), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->update_b = w; w = gtk_button_new_with_mnemonic(_("_Remove")); set_button_icon(w, "list-remove"); g_signal_connect(w, "clicked", G_CALLBACK(CREATE_NAME(Pref, DialogRemove)), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->del_b = w; w = gtk_button_new_with_mnemonic(_("_Down")); set_button_icon(w, "go-down"); g_signal_connect(w, "clicked", G_CALLBACK(CREATE_NAME(Pref, DialogDown)), d); gtk_box_pack_end(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->down_b = w; w = gtk_button_new_with_mnemonic(_("_Up")); set_button_icon(w, "go-up"); g_signal_connect(w, "clicked", G_CALLBACK(CREATE_NAME(Pref, DialogUp)), d); gtk_box_pack_end(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_widget_set_sensitive(w, FALSE); d->up_b = w; gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 4); d->show_cancel = FALSE; d->ok_button = _("_Close"); } #undef LIST_TYPE #undef LIST_ROOT #undef LIST_FREE #undef LIST_INIT #undef SET_DIALOG #undef CREATE_NAME #undef HAVE_UPDATE_FUNC ngraph-gtk-6.08.00/src/gtk/completion_info.h0000644000175000017500000000075313242772500015570 00000000000000#ifndef COMPLETION_INFO_HEADER #define COMPLETION_INFO_HEADER #include "gtk_common.h" struct completion_info { char *lower_text, *text, *text_wo_paren, *info; GtkSourceCompletionItem *proposal; }; extern struct completion_info completion_info_const[]; extern struct completion_info completion_info_func[]; GList *completion_info_func_populate(const char *word, int len, GtkTextIter *iter); GList *completion_info_const_populate(const char *word, int len, GtkTextIter *iter); #endif ngraph-gtk-6.08.00/src/gtk/x11dialg.c0000644000175000017500000010125713165673043014020 00000000000000/* * $Id: x11dialg.c,v 1.53 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include "object.h" #include "mathfn.h" #include "nstring.h" #include "ogra2cairo.h" #include "ox11menu.h" #include "x11menu.h" #include "x11gui.h" #include "x11dialg.h" #include "gtk_liststore.h" #include "gtk_combo.h" #include "gtk_widget.h" struct line_style FwLineStyle[] = { {N_("solid"), "", 0}, {N_("dot"), "100 100", 2}, {N_("short dash"), "150 150", 2}, {N_("dash"), "450 150", 2}, {N_("dot dash"), "450 150 150 150", 4}, {N_("2-dot dash"), "450 150 150 150 150 150", 6}, {N_("dot 2-dash"), "450 150 450 150 150 150", 6}, {NULL, NULL, -1}, }; #define CLINESTYLE ((sizeof(FwLineStyle) / sizeof(*FwLineStyle)) - 1) char *FwNumStyle[] = {N_("auto"), "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" }; int FwNumStyleNum = sizeof(FwNumStyle) / sizeof(*FwNumStyle); struct FileDialog DlgFile; struct FileDialog DlgRange; struct FileDialog DlgArray; struct FileDialog DlgFileDef; struct EvalDialog DlgEval; struct MathDialog DlgMath; struct MathTextDialog DlgMathText; struct FitDialog DlgFit; struct FitLoadDialog DlgFitLoad; struct FitSaveDialog DlgFitSave; struct SectionDialog DlgSection; struct CrossDialog DlgCross; struct AxisDialog DlgAxis; struct GridDialog DlgGrid; struct ZoomDialog DlgZoom; struct MergeDialog DlgMerge; struct LegendDialog DlgLegendArrow; struct LegendDialog DlgLegendRect; struct LegendDialog DlgLegendArc; struct LegendDialog DlgLegendMark; struct LegendDialog DlgLegendText; struct LegendDialog DlgLegendTextDef; struct LegendGaussDialog DlgLegendGauss; struct PageDialog DlgPage; struct SwitchDialog DlgSwitch; struct DirectoryDialog DlgDirectory; struct LoadDialog DlgLoad; struct SaveDialog DlgSave; struct DriverDialog DlgDriver; struct PrintDialog DlgPrinter; struct OutputDataDialog DlgOutputData; struct DefaultDialog DlgDefault; struct SetScriptDialog DlgSetScript; struct PrefScriptDialog DlgPrefScript; struct SetDriverDialog DlgSetDriver; struct PrefDriverDialog DlgPrefDriver; struct PrefFontDialog DlgPrefFont; struct FontSettingDialog DlgFontSetting; struct MiscDialog DlgMisc; struct ExViewerDialog DlgExViewer; struct ViewerDialog DlgViewer; struct SelectDialog DlgSelect; struct CopyDialog DlgCopy; struct OutputImageDialog DlgImageOut; static void SetTextFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); static int SetObjFieldFromSpin(GtkWidget *w, struct objlist *Obj, int Id, char *field); static void SetSpinFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); static int SetObjFieldFromToggle(GtkWidget *w, struct objlist *Obj, int Id, char *field); static void SetToggleFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); static int SetObjFieldFromList(GtkWidget *w, struct objlist *Obj, int Id, char *field); static void SetListFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field); static int SetObjFieldFromText(GtkWidget *w, struct objlist *Obj, int Id, char *field); void initdialog(void) { DlgFile.widget = NULL; DlgFile.focus = NULL; DlgFile.resource = N_("file"); DlgFile.mark.widget = NULL; DlgFile.mark.focus = NULL; DlgFile.mark.resource = N_("mark selection"); DlgRange.widget = NULL; DlgRange.focus = NULL; DlgRange.resource = N_("function"); DlgRange.mark.widget = NULL; DlgRange.mark.focus = NULL; DlgRange.mark.resource = NULL; DlgArray.widget = NULL; DlgArray.focus = NULL; DlgArray.resource = N_("array"); DlgArray.mark.widget = NULL; DlgArray.mark.focus = NULL; DlgArray.mark.resource = NULL; DlgFileDef.widget = NULL; DlgFileDef.focus = NULL; DlgFileDef.resource = N_("data default"); DlgFileDef.mark.widget = NULL; DlgFileDef.mark.focus = NULL; DlgFileDef.mark.resource = N_("mark selection"); DlgEval.widget = NULL; DlgEval.focus = NULL; DlgEval.resource = N_("evaluation"); DlgMath.widget = NULL; DlgMath.focus = NULL; DlgMath.resource = N_("math"); DlgMathText.widget = NULL; DlgMathText.focus = NULL; DlgMathText.resource = N_("math text"); DlgFit.widget = NULL; DlgFit.focus = NULL; DlgFit.resource = N_("fit"); DlgFitLoad.widget = NULL; DlgFitLoad.focus = NULL; DlgFitLoad.resource = N_("fit load"); DlgFitSave.widget = NULL; DlgFitSave.focus = NULL; DlgFitSave.Profile = NULL; DlgFitSave.resource = N_("fit save"); DlgSection.widget = NULL; DlgSection.focus = NULL; DlgSection.resource = N_("Frame/Section Graph"); DlgCross.widget = NULL; DlgCross.focus = NULL; DlgCross.resource = N_("Cross Graph"); DlgAxis.widget = NULL; DlgAxis.focus = NULL; DlgAxis.resource = N_("axis"); DlgGrid.widget = NULL; DlgGrid.focus = NULL; DlgGrid.resource = N_("grid"); DlgZoom.widget = NULL; DlgZoom.focus = NULL; DlgZoom.resource = N_("Scale Zoom"); DlgZoom.zoom = 20000; DlgMerge.widget = NULL; DlgMerge.focus = NULL; DlgMerge.resource = N_("merge"); DlgLegendArrow.widget = NULL; DlgLegendArrow.focus = NULL; DlgLegendArrow.arrow_pixmap = NULL; DlgLegendArrow.resource = N_("legend line"); DlgLegendRect.widget = NULL; DlgLegendRect.focus = NULL; DlgLegendRect.resource = N_("legend rectangle"); DlgLegendArc.widget = NULL; DlgLegendArc.focus = NULL; DlgLegendArc.resource = N_("legend arc"); DlgLegendMark.widget = NULL; DlgLegendMark.focus = NULL; DlgLegendMark.resource = N_("legend mark"); DlgLegendMark.mark.widget = NULL; DlgLegendMark.mark.focus = NULL; DlgLegendMark.mark.resource = N_("mark selection"); DlgLegendText.widget = NULL; DlgLegendText.focus = NULL; DlgLegendText.resource = N_("legend text"); DlgLegendTextDef.widget = NULL; DlgLegendTextDef.focus = NULL; DlgLegendTextDef.resource = N_("textdefault"); DlgLegendGauss.widget = NULL; DlgLegendGauss.focus = NULL; DlgLegendGauss.resource = N_("legend gauss"); DlgPage.widget = NULL; DlgPage.focus = NULL; DlgPage.resource = N_("page"); DlgSwitch.widget = NULL; DlgSwitch.focus = NULL; DlgSwitch.resource = N_("drawobj"); DlgDirectory.widget = NULL; DlgDirectory.focus = NULL; DlgDirectory.resource = N_("directory"); DlgLoad.widget = NULL; DlgLoad.focus = NULL; DlgLoad.exdir = NULL; DlgLoad.resource = N_("load"); DlgSave.widget = NULL; DlgSave.focus = NULL; DlgSave.resource = N_("save"); DlgDriver.widget = NULL; DlgDriver.focus = NULL; DlgDriver.resource = N_("driver"); DlgPrinter.widget = NULL; DlgPrinter.focus = NULL; DlgPrinter.resource = N_("print"); DlgOutputData.widget = NULL; DlgOutputData.focus = NULL; DlgOutputData.resource = N_("output data"); DlgDefault.widget = NULL; DlgDefault.focus = NULL; DlgDefault.resource = N_("save default"); DlgSetScript.widget = NULL; DlgSetScript.focus = NULL; DlgSetScript.resource = N_("Add-in script"); DlgPrefScript.widget = NULL; DlgPrefScript.focus = NULL; DlgPrefScript.resource = N_("Add-in script setup"); DlgSetDriver.widget = NULL; DlgSetDriver.focus = NULL; DlgSetDriver.resource = N_("External driver"); DlgPrefDriver.widget = NULL; DlgPrefDriver.focus = NULL; DlgPrefDriver.resource = N_("External driver setup"); DlgPrefFont.widget = NULL; DlgPrefFont.focus = NULL; DlgPrefFont.resource = N_("Font"); DlgMisc.widget = NULL; DlgMisc.focus = NULL; DlgMisc.resource = N_("Miscellaneous"); DlgExViewer.widget = NULL; DlgExViewer.focus = NULL; DlgExViewer.resource = N_("External viewer"); DlgViewer.widget = NULL; DlgViewer.focus = NULL; DlgViewer.resource = N_("Viewer"); DlgSelect.widget = NULL; DlgSelect.focus = NULL; DlgSelect.resource = N_("multi select"); DlgCopy.widget = NULL; DlgCopy.focus = NULL; DlgCopy.resource = N_("single select"); DlgImageOut.widget = NULL; DlgImageOut.focus = NULL; DlgImageOut.resource = N_("output image"); } static gboolean multi_list_default_cb(GtkWidget *w, GdkEventAny *e, gpointer user_data) { GtkTreeSelection *sel; struct SelectDialog *d; int n; d = (struct SelectDialog *) user_data; if (e->type == GDK_2BUTTON_PRESS || (e->type == GDK_KEY_PRESS && ((GdkEventKey *)e)->keyval == GDK_KEY_Return)){ sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); n = gtk_tree_selection_count_selected_rows(sel); if (n < 1) return FALSE; gtk_dialog_response(GTK_DIALOG(d->widget), GTK_RESPONSE_OK); return TRUE; } return FALSE; } static int search_id(GtkWidget *list, int id) { GtkTreeModel *model; GtkTreeIter iter; int r, a, i; model = gtk_tree_view_get_model(GTK_TREE_VIEW(list)); r = gtk_tree_model_get_iter_first(model, &iter); i = 0; while (r) { gtk_tree_model_get(model, &iter, 0, &a, -1); if (a == id) return i; r = gtk_tree_model_iter_next(model, &iter); i++; } return -1; } static void SelectDialogSetup(GtkWidget *wi, void *data, int makewidget) { char *s; struct SelectDialog *d; int i, *seldata, selnum, a; GtkWidget *swin, *w, *hbox; GtkTreeIter iter; n_list_store list[] = { {"id", G_TYPE_INT, TRUE, FALSE, NULL, 0, 0, 0, 0, PANGO_ELLIPSIZE_NONE, 0}, {"property", G_TYPE_STRING, TRUE, FALSE, NULL, 0, 0, 0, 0, PANGO_ELLIPSIZE_END, 0}, }; d = (struct SelectDialog *) data; if (makewidget) { d->list = list_store_create(sizeof(list) / sizeof(*list), list); list_store_set_sort_all(d->list); list_store_set_selection_mode(d->list, GTK_SELECTION_MULTIPLE); g_signal_connect(d->list, "button-press-event", G_CALLBACK(multi_list_default_cb), d); g_signal_connect(d->list, "key-press-event", G_CALLBACK(multi_list_default_cb), d); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), d->list); gtk_dialog_add_button(GTK_DIALOG(wi), _("_All"), IDSALL); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), swin); gtk_box_pack_start(GTK_BOX(d->vbox), w, TRUE, TRUE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_button_new_with_mnemonic(_("Select _All")); set_button_icon(w, "edit-select-all"); g_signal_connect(w, "clicked", G_CALLBACK(list_store_select_all_cb), d->list); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); gtk_window_set_default_size(GTK_WINDOW(wi), -1, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } gtk_window_set_title(GTK_WINDOW(d->widget), (d->title) ? d->title : d->resource); list_store_clear(d->list); for (i = 0; i <= chkobjlastinst(d->Obj); i++) { s = d->cb(d->Obj, i); if (s) { list_store_append(d->list, &iter); list_store_set_int(d->list, &iter, 0, i); list_store_set_string(d->list, &iter, 1, CHK_STR(s)); g_free(s); } } /* if (makewidget) { XtManageChild(d->widget); d->widget = NULL; XtVaSetValues(XtNameToWidget(w, "*list"), XmNwidth, 200, NULL); } */ if (chkobjlastinst(d->Obj) == 0) { list_store_select_nth(d->list, 0); } else if (d->isel) { seldata = arraydata(d->isel); selnum = arraynum(d->isel); for (i = 0; i < selnum; i++) { a = search_id(d->list, seldata[i]); if (a >= 0) { list_store_multi_select_nth(d->list, a, a); } } } } static void select_tree_selection_foreach_cb(GtkTreeModel *model, GtkTreePath *path, GtkTreeIter *iter, gpointer data) { int a; struct SelectDialog *d; d = (struct SelectDialog *) data; a = list_store_get_int(d->list, iter, 0); arrayadd(d->sel, &a); } static void SelectDialogClose(GtkWidget *w, void *data) { struct SelectDialog *d; d = (struct SelectDialog *) data; if (d->ret == IDOK) { GtkTreeSelection *gsel; gsel = gtk_tree_view_get_selection(GTK_TREE_VIEW(d->list)); gtk_tree_selection_selected_foreach(gsel, select_tree_selection_foreach_cb, data); } else if (d->ret == IDSALL) { int r, id; GtkTreeIter iter; r = list_store_get_iter_first(d->list, &iter); while (r) { id = list_store_get_int(d->list, &iter, 0); arrayadd(d->sel, &id); r = list_store_iter_next(d->list, &iter); } d->ret = IDOK; } } void SelectDialog(struct SelectDialog *data, struct objlist *obj, const char *title, char *(*callback) (struct objlist * obj, int id), struct narray *array, struct narray *iarray) { data->SetupWindow = SelectDialogSetup; data->CloseWindow = SelectDialogClose; data->Obj = obj; data->cb = callback; arrayinit(array, sizeof(int)); data->sel = array; data->isel = iarray; data->title = title; } static gboolean single_list_default_cb(GtkWidget *w, GdkEventAny *e, gpointer user_data) { struct CopyDialog *d; int i; d = (struct CopyDialog *) user_data; if (e->type == GDK_2BUTTON_PRESS || (e->type == GDK_KEY_PRESS && ((GdkEventKey *)e)->keyval == GDK_KEY_Return)){ i = list_store_get_selected_index(d->list); if (i < 0) { return FALSE; } gtk_dialog_response(GTK_DIALOG(d->widget), GTK_RESPONSE_OK); return TRUE; } return FALSE; } static void CopyDialogSetup(GtkWidget *wi, void *data, int makewidget) { char *s; struct CopyDialog *d; int i, a; GtkWidget *swin, *w; GtkTreeIter iter; n_list_store copy_list[] = { {"id", G_TYPE_INT, TRUE, FALSE, NULL, 0, 0, 0, 0, PANGO_ELLIPSIZE_NONE, 0}, {"property", G_TYPE_STRING, TRUE, FALSE, NULL, 0, 0, 0, 0, PANGO_ELLIPSIZE_END, 0}, }; d = (struct CopyDialog *) data; if (makewidget) { d->list = list_store_create(sizeof(copy_list) / sizeof(*copy_list), copy_list); list_store_set_sort_all(d->list); list_store_set_selection_mode(d->list, GTK_SELECTION_SINGLE); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), d->list); g_signal_connect(d->list, "button-press-event", G_CALLBACK(single_list_default_cb), d); g_signal_connect(d->list, "key-press-event", G_CALLBACK(single_list_default_cb), d); w = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(w), swin); gtk_box_pack_start(GTK_BOX(d->vbox), w, TRUE, TRUE, 0); gtk_window_set_default_size(GTK_WINDOW(wi), -1, 300); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } gtk_window_set_title(GTK_WINDOW(d->widget), (d->title) ? d->title : d->resource); list_store_clear(d->list); for (i = 0; i <= chkobjlastinst(d->Obj); i++) { s = d->cb(d->Obj, i); if (s) { list_store_append(d->list, &iter); list_store_set_int(d->list, &iter, 0, i); list_store_set_string(d->list, &iter, 1, CHK_STR(s)); g_free(s); } } if (chkobjlastinst(d->Obj) == 0) { list_store_select_nth(d->list, 0); } else if (d->Id >= 0) { a = search_id(d->list, d->Id); if (a >= 0) { list_store_select_nth(d->list, a); } } /* if (makewidget) { XtManageChild(d->widget); d->widget = NULL; XtVaSetValues(XtNameToWidget(w, "*list"), XmNwidth, 200, NULL); } */ } static void CopyDialogClose(GtkWidget *w, void *data) { struct CopyDialog *d; d = (struct CopyDialog *) data; if (d->ret == IDCANCEL) { return; } d->sel = list_store_get_selected_int(d->list, 0); } void CopyDialog(struct CopyDialog *data, struct objlist *obj, int id, const char *title, char *(*callback) (struct objlist * obj, int id)) { data->SetupWindow = CopyDialogSetup; data->CloseWindow = CopyDialogClose; data->Obj = obj; data->Id = id; data->cb = callback; data->sel = id; data->title = title; } int CopyClick(GtkWidget *parent, struct objlist *obj, int Id, char *(*callback) (struct objlist * obj, int id)) { int sel; CopyDialog(&DlgCopy, obj, Id, "copy property (single select)", callback); if (DialogExecute(parent, &DlgCopy) == IDOK) { sel = DlgCopy.sel; } else { sel = -1; } return sel; } int SetObjPointsFromText(GtkWidget *w, struct objlist *Obj, int Id, char *field) { GtkTreeModel *list; GtkTreeIter iter; GtkTreeView *tree_view; struct narray *array, *atmp; unsigned int i; int r, ip; double point[2]; if (w == NULL) { return 0; } tree_view = GTK_TREE_VIEW(w); list = gtk_tree_view_get_model(tree_view); r = gtk_tree_model_get_iter_first(list, &iter); if (! r) { return -1; } array = arraynew(sizeof(int)); if (array == NULL) { return -1; } while (r) { gtk_tree_model_get(list, &iter, 0, point, 1, point + 1, -1); for (i = 0; i < sizeof(point) / sizeof(*point); i++) { ip = nround(point[i] * 100); atmp = arrayadd(array, &ip); if (atmp == NULL){ goto ErrEnd; } array = atmp; } r = gtk_tree_model_iter_next(list, &iter); } if (get_graph_modified()) { if (putobj(Obj, field, Id, array) < 0) { goto ErrEnd; } } else { char *str1, *str2; sgetobjfield(Obj, Id, field, NULL, &str1, FALSE, FALSE, FALSE); if (putobj(Obj, field, Id, array) < 0) { g_free(str1); goto ErrEnd; } sgetobjfield(Obj, Id, field, NULL, &str2, FALSE, FALSE, FALSE); if (str1 && str2 && strcmp(str1, str2)) { set_graph_modified(); } g_free(str2); g_free(str1); } return 0; ErrEnd: if (array) { arrayfree(array); } gtk_widget_grab_focus(w); return -1; } void SetTextFromObjPoints(GtkWidget *w, struct objlist *Obj, int Id, char *field) { GtkListStore *list; GtkTreeIter iter; GtkTreeView *tree_view; struct narray *array; int i, n, *points; if (w == NULL) { return; } tree_view = GTK_TREE_VIEW(w); list = GTK_LIST_STORE(gtk_tree_view_get_model(tree_view)); gtk_list_store_clear(list); getobj(Obj, field, Id, 0, NULL, &array); n = arraynum(array); points = arraydata(array); for (i = 0; i < n / 2; i++) { gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, 0, points[i * 2] / 100.0, 1, points[i * 2 + 1] / 100.0, -1); } } int chk_sputobjfield(struct objlist *obj, int id, char *field, char *str) { if (get_graph_modified()) { if (sputobjfield(obj, id, field, str)) { return 1; } } else { char *ptr, *org; sgetobjfield(obj, id, field, NULL, &org, FALSE, FALSE, FALSE); if (sputobjfield(obj, id, field, str)) { g_free(org); return 1; } sgetobjfield(obj, id, field, NULL, &ptr, FALSE, FALSE, FALSE); if ((ptr == NULL && org) || (ptr && org == NULL) || (ptr && org && strcmp(ptr, org))) { set_graph_modified(); } g_free(ptr); g_free(org); } return 0; } int SetObjFieldFromWidget(GtkWidget *w, struct objlist *Obj, int Id, char *field) { int r = 0; if (w == NULL) { return 0; } if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_SPIN_BUTTON)) { r = SetObjFieldFromSpin(w, Obj, Id, field); } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_ENTRY)) { r = SetObjFieldFromText(w, Obj, Id, field); } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_COMBO_BOX)) { if (gtk_combo_box_get_has_entry(GTK_COMBO_BOX(w))) { r = SetObjFieldFromText(gtk_bin_get_child(GTK_BIN(w)), Obj, Id, field); } else { r = SetObjFieldFromList(w, Obj, Id, field); } } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_TOGGLE_BUTTON)) { r = SetObjFieldFromToggle(w, Obj, Id, field); } if (r) { gtk_widget_grab_focus(w); } return r; } void SetWidgetFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { if (w == NULL) { return; } if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_SPIN_BUTTON)) { SetSpinFromObjField(w, Obj, Id, field); } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_ENTRY)) { SetTextFromObjField(w, Obj, Id, field); } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_COMBO_BOX)) { if (gtk_combo_box_get_has_entry(GTK_COMBO_BOX(w))) { SetTextFromObjField(gtk_bin_get_child(GTK_BIN(w)), Obj, Id, field); } else { SetListFromObjField(w, Obj, Id, field); } } else if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_TOGGLE_BUTTON)) { SetToggleFromObjField(w, Obj, Id, field); } } static int SetObjFieldFromText(GtkWidget *w, struct objlist *Obj, int Id, char *field) { const char *tmp; char *buf; if (w == NULL) { return 0; } tmp = gtk_entry_get_text(GTK_ENTRY(w)); if (tmp == NULL) { return -1; } buf = g_strdup(tmp); if (buf == NULL) { return -1; } if (chk_sputobjfield(Obj, Id, field, buf)) { g_free(buf); return -1; } g_free(buf); return 0; } static void SetTextFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { GtkEntry *entry; char *buf; if (w == NULL) { return; } entry = GTK_ENTRY(w); sgetobjfield(Obj, Id, field, NULL, &buf, FALSE, FALSE, FALSE); if (buf == NULL) { gtk_entry_set_text(entry, ""); return; } gtk_entry_set_text(entry, CHK_STR(buf)); g_free(buf); } static int SetObjFieldFromSpin(GtkWidget *w, struct objlist *Obj, int Id, char *field) { int val, oval; if (w == NULL) { return 0; } val = spin_entry_get_val(w); if (get_graph_modified()) { if (putobj(Obj, field, Id, &val) < 0) { return -1; } } else { getobj(Obj, field, Id, 0, NULL, &oval); if (putobj(Obj, field, Id, &val) < 0) { return -1; } getobj(Obj, field, Id, 0, NULL, &val); if (val != oval) { set_graph_modified(); } } return 0; } static void SetSpinFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { int val; if (w == NULL){ return; } getobj(Obj, field, Id, 0, NULL, &val); spin_entry_set_val(w, val); } static int SetObjFieldFromToggle(GtkWidget *w, struct objlist *Obj, int Id, char *field) { gboolean state; int a, oa; if (w == NULL) { return 0; } state = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w)); a = state ? TRUE : FALSE; getobj(Obj, field, Id, 0, NULL, &oa); oa = oa ? TRUE : FALSE; if (a != oa) { if (putobj(Obj, field, Id, &a) == -1){ return -1; } set_graph_modified(); } return 0; } static void SetToggleFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { int a; if (w == NULL) { return; } getobj(Obj, field, Id, 0, NULL, &a); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), a); } static int set_obj_points_from_text(GtkWidget *w, struct objlist *Obj, int Id, char *field) { double d; int ip; char *buf, *ptr, *tmp, *eptr; const char *ctmp; struct narray *array = NULL, *atmp; if (w == NULL) { return 0; } ctmp = gtk_entry_get_text(GTK_ENTRY(w)); if (ctmp == NULL) { return -1; } buf = g_strdup(ctmp); if (buf == NULL) { return -1; } array = arraynew(sizeof(int)); ptr = buf; while (1) { while (ptr && isspace(*ptr)) ptr++; if (*ptr == '\0') { break; } tmp = strchr(ptr, ' '); if (tmp) { *tmp = '\0'; } d = strtod(ptr, &eptr); if (d != d || d == HUGE_VAL || d == - HUGE_VAL || eptr[0] != '\0') goto ErrEnd; ip = nround(d * 100); atmp = arrayadd(array, &ip); if (atmp == NULL) { goto ErrEnd; } array = atmp; if (tmp == NULL) { break; } ptr = tmp + 1; } if (get_graph_modified()) { if (putobj(Obj, field, Id, array) < 0) { goto ErrEnd; } } else { char *str1, *str2; sgetobjfield(Obj, Id, field, NULL, &str1, FALSE, FALSE, FALSE); if (putobj(Obj, field, Id, array) < 0) { g_free(str1); goto ErrEnd; } sgetobjfield(Obj, Id, field, NULL, &str2, FALSE, FALSE, FALSE); if (str1 && str2 && strcmp(str1, str2)) { set_graph_modified(); } g_free(str2); g_free(str1); } g_free(buf); return 0; ErrEnd: if (buf) { g_free(buf); } if (array) { arrayfree(array); } return -1; } int SetObjFieldFromStyle(GtkWidget *w, struct objlist *Obj, int Id, char *field) { unsigned int j; const char *ptr; if (w == NULL) { return 0; } ptr = gtk_entry_get_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN(w)))); if (ptr == NULL) { return -1; } for (j = 0; j < CLINESTYLE; j++) { if (strcmp(ptr, FwLineStyle[j].name) == 0 || strcmp(ptr, _(FwLineStyle[j].name)) == 0) { if (chk_sputobjfield(Obj, Id, field, FwLineStyle[j].list) != 0) { gtk_widget_grab_focus(w); return -1; } break; } } if (j == CLINESTYLE) { if (set_obj_points_from_text(gtk_bin_get_child(GTK_BIN(w)), Obj, Id, field)) { gtk_widget_grab_focus(w); return -1; } } return 0; } const char * get_style_string(struct objlist *obj, int id, char *field) { unsigned int j; int i; struct narray *array; int stylenum; int *style, a; char *s; getobj(obj, field, id, 0, NULL, &array); stylenum = arraynum(array); style = arraydata(array); for (j = 0; j < CLINESTYLE; j++) { if (stylenum == FwLineStyle[j].num) { s = FwLineStyle[j].list; for (i = 0; i < FwLineStyle[j].num; i++) { a = strtol(s, &s, 10); if (style[i] != a) { break; } } if (i == FwLineStyle[j].num) { return FwLineStyle[j].name; } } } return NULL; } static void set_entry_from_obj_point(GtkEntry *entry, struct objlist *Obj, int Id, char *field) { struct narray *array; char buf[128]; int i, n, *points, l, pos; GtkEntryBuffer *t_buf; t_buf = gtk_entry_get_buffer(entry); gtk_entry_buffer_set_text(t_buf, "", 0); getobj(Obj, field, Id, 0, NULL, &array); n = arraynum(array); points = arraydata(array); pos = 0; for (i = 0; i < n / 2; i++) { l = snprintf(buf, sizeof(buf), "%.2f %.2f ", points[i * 2] / 100.0, points[i * 2 + 1] / 100.0); gtk_entry_buffer_insert_text(t_buf, pos, buf, l); pos += l; } } void SetStyleFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { unsigned int j; GtkEntry *entry; int count; const char *s; if (w == NULL) { return; } entry = GTK_ENTRY(gtk_bin_get_child(GTK_BIN(w))); count = combo_box_get_num(w); if (count == 0) { for (j = 0; j < CLINESTYLE; j++) { combo_box_append_text(w, _(FwLineStyle[j].name)); } } s = get_style_string(Obj, Id, field); if (s) { gtk_entry_set_text(entry, _(s)); } else { set_entry_from_obj_point(entry, Obj, Id, field); } } static int SetObjFieldFromList(GtkWidget *w, struct objlist *Obj, int Id, char *field) { int pos, opos; if (w == NULL) { return 0; } pos = combo_box_get_active(w); if (pos < 0) { return -1; } getobj(Obj, field, Id, 0, NULL, &opos); if (pos != opos) { if (putobj(Obj, field, Id, &pos) == -1) { return -1; } set_graph_modified(); } return 0; } static void SetListFromObjField(GtkWidget *w, struct objlist *Obj, int Id, char *field) { char **enumlist; int j, a, count; if (w == NULL) { return; } count = combo_box_get_num(w); if (count == 0) { enumlist = (char **) chkobjarglist(Obj, field); for (j = 0; enumlist[j] && enumlist[j][0]; j++) { combo_box_append_text(w, _(enumlist[j])); } } getobj(Obj, field, Id, 0, NULL, &a); combo_box_set_active(w, a); } struct compatible_font_info * SetFontListFromObj(GtkWidget *w, struct objlist *obj, int id, const char *name) { int j, selfont; struct fontmap *fcur; char *font; struct compatible_font_info *compatible; if (w == NULL) { return NULL; } compatible = NULL; getobj(obj, name, id, 0, NULL, &font); combo_box_clear(w); fcur = Gra2cairoConf->fontmap_list_root; j = 0; selfont = -1; while (fcur) { combo_box_append_text(w, fcur->fontalias); if (font && strcmp(font, fcur->fontalias) == 0) { selfont = j; } j++; fcur = fcur->next; } if (selfont < 0) { selfont = 0; compatible = gra2cairo_get_compatible_font_info(font); if (compatible) { fcur = Gra2cairoConf->fontmap_list_root; j = 0; while (fcur) { if (strcmp(compatible->name, fcur->fontalias) == 0) { selfont = j; break; } j++; fcur = fcur->next; } } } combo_box_set_active(w, selfont); return compatible; } void SetObjFieldFromFontList(GtkWidget *w, struct objlist *obj, int id, char *name) { struct fontmap *fcur; char *fontalias; if (w == NULL) { return; } fontalias = combo_box_get_active_text(w); if (fontalias == NULL) { return; } if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fcur)) { g_free(fontalias); return; } g_free(fontalias); chk_sputobjfield(obj, id, name, fcur->fontalias); } int SetObjAxisFieldFromWidget(GtkWidget *w, struct objlist *obj, int id, char *field) { const char *s; char *buf; int r; s = combo_box_entry_get_text(w); if (s == NULL) { return 0; } if (s[0] == '\0') { buf = NULL; } else { buf = g_strdup_printf("axis:%s", CHK_STR(s)); } r = chk_sputobjfield(obj, id, field, buf); if (buf) { g_free(buf); } return r; } static void _set_color(GtkWidget *w, struct objlist *obj, int id, char *prefix, char *postfix) { GdkRGBA color; int r, g, b, a; char buf[64]; snprintf(buf, sizeof(buf), "%sR%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &r); snprintf(buf, sizeof(buf), "%sG%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &g); snprintf(buf, sizeof(buf), "%sB%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &b); snprintf(buf, sizeof(buf), "%sA%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &a); if (! Menulocal.use_opacity) { a = 255; } color.red = r / 255.0; color.green = g / 255.0; color.blue = b / 255.0; color.alpha = a / 255.0; gtk_color_chooser_set_use_alpha(GTK_COLOR_CHOOSER(w), Menulocal.use_opacity); gtk_color_chooser_set_rgba(GTK_COLOR_CHOOSER(w), &color); snprintf(buf, sizeof(buf), "#%02X%02X%02X", r, g, b); gtk_widget_set_tooltip_text(w, buf); } void set_color(GtkWidget *w, struct objlist *obj, int id, char *prefix) { _set_color(w, obj, id, prefix, NULL); } void set_color2(GtkWidget *w, struct objlist *obj, int id) { _set_color(w, obj, id, NULL, "2"); } void set_fill_color(GtkWidget *w, struct objlist *obj, int id) { _set_color(w, obj, id, "fill_", NULL); } void set_stroke_color(GtkWidget *w, struct objlist *obj, int id) { _set_color(w, obj, id, "stroke_", NULL); } static int _putobj_color(GtkWidget *w, struct objlist *obj, int id, char *prefix, char *postfix) { GdkRGBA color; int r, g, b, a, o; char buf[64]; gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(w), &color); a = (Menulocal.use_opacity) ? (color.alpha * 255) : 0xff; r = color.red * 255; g = color.green * 255; b = color.blue * 255; snprintf(buf, sizeof(buf), "%sR%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &o); if (o != r) { if (putobj(obj, buf, id, &r) == -1) { return TRUE; } set_graph_modified(); } snprintf(buf, sizeof(buf), "%sG%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &o); if (o != g) { if (putobj(obj, buf, id, &g) == -1) { return TRUE; } set_graph_modified(); } snprintf(buf, sizeof(buf), "%sB%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &o); if (o != b) { if (putobj(obj, buf, id, &b) == -1) { return TRUE; } set_graph_modified(); } snprintf(buf, sizeof(buf), "%sA%s", CHK_STR(prefix), CHK_STR(postfix)); getobj(obj, buf, id, 0, NULL, &o); if (o != a) { if (putobj(obj, buf, id, &a) == -1) { return TRUE; } set_graph_modified(); } return FALSE; } int putobj_color(GtkWidget *w, struct objlist *obj, int id, char *prefix) { return _putobj_color(w, obj, id, prefix, NULL); } int putobj_color2(GtkWidget *w, struct objlist *obj, int id) { return _putobj_color(w, obj, id, NULL, "2"); } int putobj_fill_color(GtkWidget *w, struct objlist *obj, int id) { return _putobj_color(w, obj, id, "fill_", NULL); } int putobj_stroke_color(GtkWidget *w, struct objlist *obj, int id) { return _putobj_color(w, obj, id, "stroke_", NULL); } ngraph-gtk-6.08.00/src/gtk/init.c0000644000175000017500000007630713327053133013350 00000000000000/* * $id: main.c,v 1.47 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #ifdef HAVE_SYS_WAIT_H #include #endif /* HAVE_SYS_WAIT_H */ #include #include #include #include #include #include #include #include #if WINDOWS || OSX #ifdef LOCALEDIR #undef LOCALEDIR #endif /* LOCALEDIR */ char *DOCDIR, *NDATADIR, *ADDINDIR, *LIBDIR, *PLUGINDIR, *CONFDIR, *LOCALEDIR, *BINDIR; #endif /* WINDOWS */ #include "dir_defs.h" #include "object.h" #include "ioutil.h" #include "nstring.h" #include "nconfig.h" #include "shell.h" #include "init.h" #ifdef HAVE_READLINE_READLINE_H #include #include #include "ox11menu.h" #include "x11menu.h" #include "ogra2x11.h" #include "ogra2cairo.h" #include static char **attempt_shell_completion(char *text, int start, int end); char *HistoryFile = NULL; #define HIST_SIZE 100 #define HIST_FILE "shell_history" #endif /* HAVE_READLINE_READLINE_H */ #define CSS_PATH RESOURCE_PATH "/css/ngraph.css" #define SYSCONF "[Ngraph]" static char *systemname, *locale; static int consolefdout, consolefdin, ConsoleAc = FALSE; static int consolecol = 80, consolerow = 25; static int Initialized = FALSE; void *addobjectroot(void); void *addint(void); void *adddouble(void); void *addio(void); void *addstring(void); void *addregexp(void); void *addiarray(void); void *adddarray(void); void *addsarray(void); void *addsystem(void); void *addshell(void); void *adddraw(void); void *addfile(void); void *addmath(void); void *addfit(void); void *addgra(void); void *addgra2(void); void *addgra2null(void); void *addgra2file(void); void *addgra2prn(void); void *addgra2cairo(void); void *addgra2cairofile(void); void *addgra2gtkprint(void); void *addgra2gdk(void); void *addmerge(void); void *addlegend(void); void *addrectangle(void); void *addarc(void); void *addmark(void); void *addtext(void); void *addaxis(void); void *addagrid(void); void *addprm(void); void *addpath(void); void *addgra2gtk(void); void *addmenu(void); void *adddialog(void); #if WINDOWS void *addgra2emf(void); #endif /* WINDOWS */ void resizeconsole(int col, int row); // XtAppContext Application=NULL; char *AppName = "Ngraph", *AppClass = "Ngraph", *Home; char *Auther[] = { "Satoshi ISHIZAKA", "Ito Hiroyuki", NULL }; char *Translator = "Satoshi ISHIZAKA\n" \ "Ito Hiroyuki" \ ; char *Documenter[] = { "Satoshi ISHIZAKA", "Ito Hiroyuki", NULL }; static int OpenDisplay = FALSE; static void * ( * obj_add_func_ary[]) (void) = { addshell, addgra, addgra2, addgra2null, addgra2file, addgra2prn, addgra2cairo, addgra2cairofile, addgra2gtkprint, addgra2gtk, addgra2gdk, addio, addint, adddouble, addstring, addregexp, addiarray, adddarray, addsarray, addmath, addfit, addprm, adddraw, addagrid, addaxis, addfile, addmerge, addlegend, addrectangle, addarc, addpath, addmark, addtext, addmenu, adddialog, #if WINDOWS addgra2emf, #endif }; int OpenApplication(void) { return OpenDisplay; } int putconsole(const char *s) { int len; len = strlen(s); if (write(consolefdout, s, len) < 0) return 0; if (write(consolefdout, "\n", 1) < 0) return 0; return len + 1; } int printfconsole(const char *fmt, ...) { int len; char buf[1024]; va_list ap; va_start(ap, fmt); len = vsnprintf(buf, sizeof(buf), fmt, ap); va_end(ap); if (write(consolefdout, buf, len) < 0) return 0; return len; } static int inputynconsole(const char *mes) { int len, r; char buf[10], yn[] = " [yn] "; len = strlen(mes); if (write(consolefdout, mes, len)) return FALSE; if (write(consolefdout, yn, sizeof(yn) - 1)) return FALSE; do { r = read(consolefdin, buf, 1); } while (strchr("yYnN", buf[0]) == NULL && r >= 0); if (r < 0) return FALSE; do { r = read(consolefdin, buf, 1); } while(buf[0] != '\n' && r >= 0); if ((buf[0] == 'y') || (buf[0] == 'Y')) return TRUE; return FALSE; } static void displaydialogconsole(const char *str) { putconsole(str); } static void displaystatusconsole(const char *str) { } void resizeconsole(int col, int row) { } static char *Terminal = NULL; #if WINDOWS static HWND ConsoleHandle = NULL; static int check_console(int allocconsole) { DWORD console_pid; pid_t pid; if (allocconsole) { return TRUE; } ConsoleHandle = GetConsoleWindow(); if (ConsoleHandle == NULL) { return TRUE; } GetWindowThreadProcessId(ConsoleHandle, &console_pid); pid = getpid(); return (pid != console_pid); } int nallocconsole(void) { if (ConsoleAc) { return TRUE; } if (ConsoleHandle) { ShowWindow(ConsoleHandle, SW_RESTORE); return TRUE; } return FALSE; } void nfreeconsole(void) { if (ConsoleAc) { return; } if (ConsoleHandle) { ShowWindow(ConsoleHandle, SW_HIDE); } } void hide_console(void) { HMENU menu; if (ConsoleHandle == NULL || ConsoleAc) { return; } menu = GetSystemMenu(ConsoleHandle, FALSE); RemoveMenu(menu, SC_CLOSE, MF_BYCOMMAND); nfreeconsole(); } void resotre_console(void) { if (ConsoleHandle == NULL || ConsoleAc) { return; } GetSystemMenu(ConsoleHandle, TRUE); nallocconsole(); } #else /* WINDOWS */ static pid_t consolepid = -1; static struct savedstdio consolesave; static int consolefd[3]; static int interruptconsole(void) { return FALSE; } static void reset_fifo(char *fifo_in, char *fifo_out) { int fdi, fdo; fdi = nopen(fifo_in, O_WRONLY, 0); fdo = nopen(fifo_out, O_RDONLY, 0); if (fdi >= 0) nclose(fdi); if (fdo >= 0) nclose(fdo); } void hide_console(void) { /* do nothing */ } void resotre_console(void) { /* do nothing */ } static int exec_console(char *fifo_in, char *fifo_out) { char **argv; pid_t pid; pid = fork(); if (pid == -1) { g_unlink(fifo_in); g_unlink(fifo_out); return 1; } else if (pid == 0) { pid = fork(); if (pid == 0) { char buf[2049], *s2, *s; int len; #if OSX snprintf(buf, sizeof(buf), "%s -e %s/terminal %s %s", Terminal, LIBDIR, fifo_in, fifo_out); system(buf); exit(0); #else snprintf(buf, sizeof(buf), "%s %s %s", Terminal, fifo_in, fifo_out); argv = NULL; s = buf; while ((s2 = getitok2(&s, &len, " \t")) != NULL) { arg_add(&argv, s2); } execvp(argv[0], argv); #endif } else if (pid != -1) { int status; waitpid(pid, &status, 0); } reset_fifo(fifo_in, fifo_out); exit(0); } return 0; } int nallocconsole(void) { int fd[3] = {-1, -1, -1}, fdi, fdo; unsigned int i; char buf[256], ttyname[256], fifo_in[1024], fifo_out[1024]; struct objlist *sys; char *sysname; char *version; if (ConsoleAc) return FALSE; if (Terminal == NULL) return FALSE; #if OSX { char *path; path = g_find_program_in_path(Terminal); if (path == NULL) { PutStderr("To use this function, please install XQuartz."); return FALSE; } g_free(path); } #endif snprintf(fifo_in, sizeof(fifo_in) - 1, "/tmp/nterm1_%d", getpid()); snprintf(fifo_out, sizeof(fifo_out) - 1, "/tmp/nterm2_%d", getpid()); if (mkfifo(fifo_in, 0600)) { return FALSE; } if (mkfifo(fifo_out, 0600)) { g_unlink(fifo_in); return FALSE; } if (exec_console(fifo_in, fifo_out)) return FALSE; fdi = nopen(fifo_in, O_RDONLY, 0); fdo = nopen(fifo_out, O_WRONLY, 0); g_unlink(fifo_in); g_unlink(fifo_out); sys = chkobject("system"); getobj(sys, "name", 0, 0, NULL, &sysname); getobj(sys, "version", 0, 0, NULL, &version); snprintf(buf, sizeof(buf), "%c]2;Ngraph shell%c%s version %s. Script interpreter.\n", 0x1b, 0x07, sysname, version); if (write(fdo, buf, strlen(buf) + 1) < 0) { nclose(fdi); nclose(fdo); return FALSE; } nclose(fdo); for (i = 0; i < sizeof(ttyname) - 1; i++) { if (read(fdi, ttyname + i, 1) != 1) break; if (ttyname[i] == '\0') break; } ttyname[i] = '\0'; if (i == 0) { nclose(fdi); return FALSE; } for (i = 0; i < sizeof(buf) - 1; i++) { if (read(fdi, buf + i, 1) != 1) break; if (buf[0] == '\0') break; } nclose(fdi); if (i == 0) return FALSE; buf[i] = '\0'; fd[0] = nopen(ttyname, O_RDONLY, 0); if (fd[0] < 0) { goto ErrEnd; } fd[1] = nopen(ttyname, O_WRONLY, 0); if (fd[1] < 0) { goto ErrEnd; } fd[2] = nopen(ttyname, O_WRONLY, 0); if (fd[2] < 0) { goto ErrEnd; } consolepid = atoi(buf); consolefd[0] = dup(0); nclose(0); dup2(fd[0], 0); consolefd[1] = dup(1); nclose(1); dup2(fd[1], 1); consolefd[2] = dup(2); nclose(2); dup2(fd[2], 2); nclose(fd[0]); nclose(fd[1]); nclose(fd[2]); consolefdin = dup(0); consolefdout = dup(2); ConsoleAc = TRUE; savestdio(&consolesave); putstderr = putconsole; printfstderr = printfconsole; ninterrupt = interruptconsole; inputyn = inputynconsole; ndisplaydialog = displaydialogconsole; ndisplaystatus = displaystatusconsole; return TRUE; ErrEnd: if (fd[0] < 0) { nclose(fd[0]); } if (fd[1] < 0) { nclose(fd[1]); } if (fd[2] < 0) { nclose(fd[2]); } return FALSE; } void nfreeconsole(void) { if (ConsoleAc) { nclose(0); if (consolefd[0] != -1) { dup2(consolefd[0], 0); nclose(consolefd[0]); } nclose(1); if (consolefd[1] != -1) { dup2(consolefd[1], 1); nclose(consolefd[1]); } nclose(2); if (consolefd[2] != -1) { dup2(consolefd[2], 2); nclose(consolefd[2]); } kill(consolepid, SIGTERM); consolepid = -1; nclose(consolefdin); nclose(consolefdout); consolefdin = 0; consolefdout = 2; ConsoleAc = FALSE; loadstdio(&consolesave); } } #endif /* WINDOWS */ void nforegroundconsole() { } static void #ifdef HAVE_READLINE_READLINE_H load_config(struct objlist *sys, N_VALUE *inst, int *allocconsole, int *history_size) #else load_config(struct objlist *sys, N_VALUE *inst, int *allocconsole) #endif { FILE *fp; char *tok, *str, *f1, *endptr, *s2; int len; long val; if ((fp = openconfig(SYSCONF)) != NULL) { while ((tok = getconfig(fp, &str)) != NULL) { s2 = str; if (strcmp(tok, "login_shell") == 0) { f1 = getitok2(&s2, &len, " \t,"); if (_putobj(sys, "login_shell", inst, f1)) exit(1); } else if (strcmp(tok, "create_object") == 0) { while ((f1 = getitok2(&s2, &len, " \t,")) != NULL) { struct objlist *obj; obj = getobject(f1); if (obj) { newobj(obj); } g_free(f1); } } else if (strcmp(tok, "alloc_console") == 0) { f1 = getitok2(&s2, &len, " \t,"); val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') { if (val == 0) *allocconsole = FALSE; else *allocconsole = TRUE; } g_free(f1); } else if (strcmp(tok, "console_size") == 0) { f1 = getitok2(&s2, &len, " \x09,"); val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') consolecol = val; g_free(f1); f1 = getitok2(&s2, &len, " \x09,"); val = strtol(f1, &endptr, 10); if (endptr[0] == '\0') consolerow = val; g_free(f1); #ifdef HAVE_READLINE_READLINE_H } else if (strcmp(tok, "history_size") == 0) { f1 = getitok2(&s2, &len, " \t,"); val = strtol(f1, &endptr, 10); if (endptr[0] == '\0' && val > 0) { *history_size = val; } g_free(f1); #endif } else if (strcmp(tok, "terminal") == 0) { Terminal = getitok2(&s2, &len, ""); } else { fprintf(stderr, "(%s): configuration '%s' in section %s is not used.\n", AppName, tok, SYSCONF); } g_free(tok); g_free(str); } closeconfig(fp); } } #if WINDOWS static int set_dir_defs(char *app) { char *utf8_name, *app_path, *tmp; utf8_name = g_locale_to_utf8(app, -1, NULL, NULL, NULL); if (utf8_name == NULL) { return 1; } changefilename(utf8_name); tmp = g_path_get_dirname(utf8_name); g_free(utf8_name); if (tmp == NULL) { return 1; } app_path = g_path_get_dirname(tmp); g_free(tmp); if (app_path == NULL) { return 1; } BINDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "bin"); DOCDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/doc/ngraph-gtk"); LIBDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "lib/ngraph-gtk"); PLUGINDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "lib/ngraph-gtk/plugins"); NDATADIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/ngraph-gtk"); ADDINDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/ngraph-gtk/addin"); CONFDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "etc/ngraph-gtk"); LOCALEDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/locale"); g_free(app_path); return 0; } #endif /* WINDOWS */ #if OSX static int set_dir_defs(char *app) { const char *app_contents; char *app_path; app_contents = g_getenv("NGRAPH_APP_CONTENTS"); if (app_contents) { app_path = g_strdup_printf("%s%c%s", app_contents, DIRSEP, "Resources"); LIBDIR = g_strdup_printf("%s%c%s", app_contents, DIRSEP, "MacOS"); } else { char *bin_path; bin_path = g_path_get_dirname(app); app_path = g_path_get_dirname(bin_path); g_free(bin_path); LIBDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "libexec/ngraph-gtk"); } if (app_path == NULL) { return 1; } BINDIR = NULL; DOCDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/doc/ngraph-gtk"); PLUGINDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "lib/ngraph-gtk/plugins"); NDATADIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/ngraph-gtk"); ADDINDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/ngraph-gtk/addin"); CONFDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "etc/ngraph-gtk"); LOCALEDIR = g_strdup_printf("%s%c%s", app_path, DIRSEP, "share/locale"); g_free(app_path); return 0; } #endif #if WINDOWS static void set_path_env(char *homedir) { const char *path; char *pathset; path = g_getenv("PATH"); pathset = g_strdup_printf("%s%s%s%s%s%s%s%s%s%s%s", homedir, PATHSEP, ADDINDIR, PATHSEP, LIBDIR, PATHSEP, BINDIR, PATHSEP, ".", PATHSEP, CHK_STR(path)); path_to_win(pathset); g_setenv("PATH", pathset, TRUE); g_setenv("NGRAPHLIB", LIBDIR, TRUE); g_setenv("NGRAPHCONF", CONFDIR, TRUE); g_free(pathset); } #endif const char * n_getlocale(void) { return locale; } #if GTK_CHECK_VERSION(3, 16, 0) static void load_css(void) { GtkCssProvider *css_provider; css_provider = gtk_css_provider_new(); gtk_css_provider_load_from_resource(css_provider, CSS_PATH); gtk_style_context_add_provider_for_screen(gdk_screen_get_default(), GTK_STYLE_PROVIDER(css_provider), GTK_STYLE_PROVIDER_PRIORITY_USER); } #endif int n_initialize(int *argc, char ***argv) { char *homedir, *datadir, *docdir, *libdir, *plugindir, *confdir; const char *home; N_VALUE *inst; struct objlist *sys; unsigned int j; int allocconsole = FALSE; #ifdef HAVE_READLINE_READLINE_H int history_size = HIST_SIZE; #endif if (Initialized) { return 0; } #if ! GLIB_CHECK_VERSION(2, 32, 0) g_thread_init(NULL); #endif #if EOF == -1 char_type_buf_init(); #endif #if ! WINDOWS set_childhandler(); #endif /* WINDOWS */ OpenDisplay = gtk_init_check(argc, argv); g_set_application_name(AppName); #if WINDOWS || OSX set_dir_defs((*argv)[0]); #endif /* WINDOWS */ if (init_cmd_tbl()) { exit(1); } ignorestdio(NULL); inputyn = vinputyn; ninterrupt = vinterrupt; printfstderr = seprintf; putstderr = seputs; consolefdin = 0; consolefdout = 2; #if GTK_CHECK_VERSION(3, 16, 0) if (OpenDisplay) { load_css(); } #endif /* GTK_CHECK_VERSION(3, 16, 0) */ #ifdef HAVE_GETTEXT setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, LOCALEDIR); bind_textdomain_codeset(PACKAGE, "UTF-8"); textdomain(PACKAGE); #endif /* HAVE_GETTEXT */ #if WINDOWS locale = g_win32_getlocale(); #else /* WINDOWS */ locale = setlocale(LC_ALL, NULL); locale = g_strdup(CHK_STR(locale)); #endif /* WINDOWS */ libdir = g_strdup(LIBDIR); if (libdir == NULL) exit(1); plugindir = g_strdup(PLUGINDIR); if (plugindir == NULL) exit(1); docdir = g_strdup(DOCDIR); if (docdir == NULL) exit(1); datadir = g_strdup(NDATADIR); if (datadir == NULL) exit(1); confdir = g_strdup(CONFDIR); if (confdir == NULL) { exit(1); } if ((home = g_getenv("HOME")) != NULL) { homedir = g_strdup_printf("%s/%s", home, HOME_DIR); if (homedir == NULL) { exit(1); } changefilename(homedir); } else { if ((home = g_get_user_config_dir()) != NULL) { homedir = g_strdup_printf("%s/%s", home, HOME_DIR); if (homedir == NULL) { exit(1); } changefilename(homedir); } else { homedir = g_strdup(confdir); if (homedir == NULL) { exit(1); } } } #if WINDOWS set_path_env(homedir); #endif set_environ(); if (addobjectroot() == NULL) exit(1); if (addsystem() == NULL) exit(1); sys = getobject("system"); if (sys == NULL) exit(1); if (newobj(sys) < 0) exit(1); inst = chkobjinst(sys, 0); if (inst == NULL) exit(1); if (_putobj(sys, "conf_dir", inst, confdir)) exit(1); if (_putobj(sys, "data_dir", inst, datadir)) exit(1); if (_putobj(sys, "doc_dir", inst, docdir)) exit(1); if (_putobj(sys, "lib_dir", inst, libdir)) exit(1); if (_putobj(sys, "plugin_dir", inst, plugindir)) exit(1); if (_putobj(sys, "home_dir", inst, homedir)) exit(1); if (_getobj(sys, "conf_dir", inst, &confdir) == -1) exit(1); if (_getobj(sys, "data_dir", inst, &datadir) == -1) exit(1); if (_getobj(sys, "doc_dir", inst, &docdir) == -1) exit(1); if (_getobj(sys, "lib_dir", inst, &libdir) == -1) exit(1); if (_getobj(sys, "plugin_dir", inst, &plugindir) == -1) exit(1); if (_getobj(sys, "home_dir", inst, &homedir) == -1) exit(1); if (_getobj(sys, "name", inst, &systemname) == -1) exit(1); for (j = 0; j < sizeof(obj_add_func_ary) / sizeof(*obj_add_func_ary); j++) { if (obj_add_func_ary[j]() == NULL) exit(1); } #ifdef HAVE_READLINE_READLINE_H load_config(sys, inst, &allocconsole, &history_size); rl_readline_name = "ngraph"; rl_completer_word_break_characters = " \t\n\"'@><;|&({}`"; rl_attempted_completion_function = (rl_completion_func_t *) attempt_shell_completion; rl_completion_entry_function = NULL; HistoryFile = g_strdup_printf("%s/%s", homedir, HIST_FILE); if (HistoryFile) { read_history(HistoryFile); } using_history(); stifle_history(history_size); #else load_config(sys, inst, &allocconsole); #endif putstderr = putconsole; printfstderr = printfconsole; inputyn = inputynconsole; ndisplaydialog = displaydialogconsole; ndisplaystatus = displaystatusconsole; if (allocconsole) { nallocconsole(); } #if WINDOWS ConsoleAc = check_console(allocconsole); if (isatty(0) && isatty(1) && isatty(2)) { if (! allocconsole) { consolefdin = dup(0); consolefdout = dup(2); } } #else if (isatty(0) && isatty(1) && isatty(2)) { ConsoleAc = TRUE; if (! allocconsole) { consolefdin = dup(0); consolefdout = dup(2); } } else { ConsoleAc = FALSE; } #endif Initialized = TRUE; return 0; } void n_save_shell_history(void) { #ifdef HAVE_READLINE_READLINE_H if (HistoryFile) { write_history(HistoryFile); } #endif } void n_finalize(void) { #ifdef HAVE_READLINE_READLINE_H if (HistoryFile != NULL) { n_save_shell_history(); g_free(HistoryFile); HistoryFile = NULL; } #endif #if ! WINDOWS if (ConsoleAc && (consolepid != -1)) { nfreeconsole(); } #endif if (Terminal) { g_free(Terminal); Terminal = NULL; } } #ifdef HAVE_READLINE_READLINE_H struct mylist { struct mylist *next; int len; char str[1]; }; static char **obj_name_matching(const char *text); static char *obj_member_completion_function(const char *text, int state); static char *obj_name_completion_function(const char *text, int state); static char *my_completion_function(const char *text, int state, char **func(const char *)); static char *command_word_completion_function(const char *hint_text, int state); static char **cmd_name_matching(const char *text); static char **get_obj_member_list(struct objlist *objcur, char *member); static char **get_obj_enum_list(struct objlist *objcur, char *member, char *val); static char **get_obj_bool_list(struct objlist *objcur, char *member, char *val); static char **get_obj_font_list(struct objlist *objcur, char *member, char *val); static int get_obj_num(void); static struct mylist *mylist_add(struct mylist *parent, const char *text); static struct mylist *mylist_cat(struct mylist *list_top, struct mylist *list); static void mylist_free(struct mylist *list); static int mylist_num(const struct mylist *list); static struct mylist *get_file_list(const char *path, int type, int mode); static struct mylist *get_exec_file_list(void); static char ** attempt_shell_completion(char *text, int start, int end) { char **matches = NULL; int in_command_position, ti; char *command_separator_chars = ";|(`"; ti = start - 1; while ((ti > -1) && (whitespace(rl_line_buffer[ti]))) ti--; in_command_position = 0; if (ti < 0) { in_command_position++; } else if (strchr(command_separator_chars, rl_line_buffer[ti])) { in_command_position++; } if (!matches && in_command_position) matches = rl_completion_matches(text, command_word_completion_function); if (!matches) matches = rl_completion_matches(text, obj_name_completion_function); if (!matches) matches = rl_completion_matches(text, obj_member_completion_function); return matches; } static char * obj_member_completion_function(const char *text, int state) { static char **list = (char **) NULL; static int list_index = 0, first_char_loc; struct objlist *objcur; /* If we don't have any state, make some. */ if (!state) { static char *obj, *instances, *member, *val; if (list) g_free(list); list = (char **) NULL; first_char_loc = 0; obj = g_strdup(text); if (obj == NULL) return NULL; if ((instances = strchr(obj, ':')) && (member = strchr(instances + 1, ':'))) { *instances = *member = '\0'; instances++; member++; } else { g_free(obj); return NULL; } objcur = getobject(obj); if (objcur == NULL) { g_free(obj); return NULL; } if ((val = strchr(member, '=')) != NULL) { *val = '\0'; val++; first_char_loc = val - obj; list = get_obj_enum_list(objcur, member, val); if (list == NULL) list = get_obj_bool_list(objcur, member, val); if (list == NULL) list = get_obj_font_list(objcur, member, val); } else { first_char_loc = member - obj; list = get_obj_member_list(objcur, member); } list_index = 0; g_free(obj); } if (list && list[list_index]) { char *t, *tt; t = g_strdup_printf("%.*s%s", first_char_loc, text, list[list_index]); tt = strdup(t); g_free(t); list_index++; return tt; } return NULL; } static char ** get_obj_member_list(struct objlist *objcur, char *member) { char **list = (char **) NULL, *field; int i, j, len, n; n = chkobjfieldnum(objcur); list = g_malloc(sizeof(*list) * (n + 1)); if (list == NULL) { return NULL; } len = strlen(member); j = 0; for (i = 0; i < n; i++) { field = chkobjfieldname(objcur, i); if (field == NULL) { continue; } if (strncmp(field, member, len) == 0) { list[j++] = field; } } list[j] = NULL; return list; } static char ** get_obj_enum_list(struct objlist *objcur, char *member, char *val) { char **list = (char **) NULL, **enumlist; int i, j, len; if (chkobjfieldtype(objcur, member) != NENUM) return NULL; enumlist = (char **) chkobjarglist(objcur, member); for (i = 0; enumlist[i] != NULL; i++); list = g_malloc((sizeof(*list)) * (i + 1)); if (list == NULL) return NULL; len = strlen(val); j = 0; for (i = 0; enumlist[i] && enumlist[i][0]; i++) { if (strncmp(enumlist[i], val, len) == 0) { list[j++] = enumlist[i]; } } list[j] = NULL; return list; } static char ** get_obj_bool_list(struct objlist *objcur, char *member, char *val) { char **list = (char **) NULL; static char *boollist[] = { "true", "false", NULL }; int i, j, len; if (chkobjfieldtype(objcur, member) != NBOOL) return NULL; list = g_malloc(sizeof(boollist)); if (list == NULL) return NULL; len = strlen(val); j = 0; for (i = 0; boollist[i] != NULL; i++) { if (strncmp(boollist[i], val, len) == 0) { list[j++] = boollist[i]; } } list[j] = NULL; return list; } static char ** get_obj_font_list(struct objlist *objcur, char *member, char *val) { char **list = (char **) NULL; struct fontmap *fontmap, *fontmaproot; int j, len; if (Gra2cairoConf == NULL) return NULL; fontmaproot = Gra2cairoConf->fontmap_list_root; if (fontmaproot == NULL) return NULL; if (chkobjfieldtype(objcur, member) != NSTR) return NULL; if (strstr(member, "font") == NULL) return NULL; list = g_malloc((sizeof(*list)) * (Gra2cairoConf->font_num + 1)); if (list == NULL) return NULL; len = strlen(val); j = 0; for (fontmap = fontmaproot; fontmap != NULL; fontmap = fontmap->next) { if (strncmp(fontmap->fontalias, val, len) == 0) { list[j++] = fontmap->fontalias; } } list[j] = NULL; return list; } static char * command_word_completion_function(const char *text, int state) { return my_completion_function(text, state, cmd_name_matching); } static char * obj_name_completion_function(const char *text, int state) { return my_completion_function(text, state, obj_name_matching); } static char * my_completion_function(const char *text, int state, char **func(const char *)) { static char **list = (char **) NULL; static int list_index = 0; static int first_char_loc; /* If we don't have any state, make some. */ if (!state) { if (list) g_free(list); list = (char **) NULL; first_char_loc = 0; list = func(&text[first_char_loc]); list_index = 0; } if (list && list[list_index]) { char *t = strdup(list[list_index]); if (t == NULL) return NULL; list_index++; return t; } return NULL; } static int get_obj_num(void) { static int num = 0; if (num == 0) { struct objlist *objcur; for (objcur = chkobjroot(); objcur != NULL; objcur = objcur->next) num++; } return num; } static char ** obj_name_matching(const char *text) { int j, text_len; struct objlist *objcur; char **list; list = g_malloc((get_obj_num() + 1) * sizeof(*list)); if (list == NULL) return NULL; text_len = strlen(text); j = 0; for (objcur = chkobjroot(); objcur != NULL; objcur = objcur->next) { if (strncmp(objcur->name, text, text_len) == 0) list[j++] = objcur->name; } if (j == 0) { g_free(list); list = NULL; } else { list[j] = NULL; } assert(j < get_obj_num() + 1); return list; } static char ** cmd_name_matching(const char *text) { int i, j, text_len, file_len; struct objlist *objcur; char **list; struct mylist *file_list = NULL, *file_list_cur = NULL; file_list = get_exec_file_list(); file_len = mylist_num(file_list); list = g_malloc((CMDNUM + CPCMDNUM + get_obj_num() + file_len + 1) * sizeof(*list)); if (list == NULL) return NULL; text_len = strlen(text); j = 0; for (file_list_cur = file_list; file_list_cur != NULL; file_list_cur = file_list_cur->next) { if (strncmp(file_list_cur->str, text, text_len) == 0) { list[j++] = file_list_cur->str; } } for (i = 0; i < CMDNUM; i++) { if (strncmp(cmdtable[i].name, text, text_len) == 0) { list[j++] = cmdtable[i].name; } } for (i = 0; i < CPCMDNUM; i++) { if (strncmp(cpcmdtable[i], text, text_len) == 0) { list[j++] = cpcmdtable[i]; } } for (objcur = chkobjroot(); objcur != NULL; objcur = objcur->next) { if (strncmp(objcur->name, text, text_len) == 0) list[j++] = objcur->name; } if (j == 0) { g_free(list); list = NULL; } else { list[j] = NULL; } assert(j < CMDNUM + CPCMDNUM + get_obj_num() + file_len + 1); return list; } struct mylist * get_exec_file_list(void) { char *path, *next_ptr, *path_ptr; const char *path_env; static struct mylist *list = NULL, *list_next = NULL; if (list != NULL) { return list; /* mylist_free(list); list = NULL; */ } if ((path_env = g_getenv("PATH")) == NULL) return NULL; if ((path = path_ptr = g_strdup(path_env)) == NULL) return NULL; while ((next_ptr = strchr(path_ptr, ':')) != NULL) { *next_ptr = '\0'; next_ptr++; list_next = get_file_list(path_ptr, S_IFREG, S_IXUSR); list = mylist_cat(list, list_next); path_ptr = next_ptr; } g_free(path); return list; } static struct mylist * get_file_list(const char *path, int type, int mode) { GDir *dir; const char *ent; GStatBuf statbuf; struct mylist *list = NULL, *list_next = list; char *full_path_name; if ((dir = g_dir_open(path, 0, NULL)) == NULL) { return NULL; } while ((ent = g_dir_read_name(dir)) != NULL) { full_path_name = g_strdup_printf("%s/%s", path, ent); if (full_path_name == NULL) { if (list != NULL) { mylist_free(list); } list = NULL; break; } nstat(full_path_name, &statbuf); if ((statbuf.st_mode & type) && (statbuf.st_mode & mode)) { list_next = mylist_add(list_next, ent); if (list == NULL) { list = list_next; } } } g_dir_close(dir); return list; } static struct mylist * mylist_add(struct mylist *parent, const char *text) { struct mylist *list; int len; len = strlen(text) + 1; if ((list = g_malloc(sizeof(struct mylist) + len)) == NULL) return NULL; memcpy(list->str, text, len); list->next = NULL; list->len = len; if (parent != NULL) parent->next = list; return list; } static void mylist_free(struct mylist *list) { struct mylist *tmp; while (list != NULL) { tmp = list->next; g_free(list); list = tmp; } } static int mylist_num(const struct mylist *list) { int num = 0; while (list != NULL) { num++; list = list->next; } return num; } static struct mylist * mylist_cat(struct mylist *list_top, struct mylist *list) { struct mylist *list_ptr; if (list_top == NULL) return list; list_ptr = list_top; while (list_ptr->next != NULL) list_ptr = list_ptr->next; list_ptr->next = list; return list_top; } #endif ngraph-gtk-6.08.00/src/gtk/sourcecompletionwords.c0000644000175000017500000001642013242772500017046 00000000000000/* -*- Mode: C; coding: utf-8 -*- * modified from gtksourcecompletionproviderwords.c * This file is part of GtkSourceView * * Copyright (C) 2009 - Jesse van den Kieboom * Copyright (C) 2013 - Sébastien Wilmet * * gtksourceview 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.1 of the License, or (at your option) any later version. * * gtksourceview 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #ifdef HAVE_CONFIG_H #include #endif #include "gtk_common.h" #include "sourcecompletionwords.h" #include #define MINIMUM_WORD_SIZE 2 #define INTERACTIVE_DELAY 50 #define PRIORITY 10 #define ACTIVATION (GTK_SOURCE_COMPLETION_ACTIVATION_INTERACTIVE | GTK_SOURCE_COMPLETION_ACTIVATION_USER_REQUESTED) #define PROPOSALS_BATCH_SIZE 300 struct _SourceCompletionWordsPrivate { gchar *name; populate_func populate_func; }; static void source_completion_words_iface_init (GtkSourceCompletionProviderIface *iface); G_DEFINE_TYPE_WITH_CODE (SourceCompletionWords, source_completion_words, G_TYPE_OBJECT, G_ADD_PRIVATE (SourceCompletionWords) G_IMPLEMENT_INTERFACE (GTK_SOURCE_TYPE_COMPLETION_PROVIDER, source_completion_words_iface_init)) static gchar * source_completion_words_get_name (GtkSourceCompletionProvider *self) { return g_strdup (SOURCE_COMPLETION_WORDS (self)->priv->name); } static gboolean valid_start_char (gunichar ch) { return !g_unichar_isdigit (ch); } static gboolean valid_word_char (gunichar ch) { return g_unichar_isprint (ch) && (ch == '_' || ch == '%' || g_unichar_isalnum (ch)); } static gchar * get_end_word(gchar *text) { gchar *cur_char = text + strlen (text); gboolean word_found = FALSE; gunichar ch; while (TRUE) { gchar *prev_char = g_utf8_find_prev_char(text, cur_char); if (prev_char == NULL) { break; } ch = g_utf8_get_char (prev_char); if (!valid_word_char (ch)) { break; } word_found = TRUE; cur_char = prev_char; } if (! word_found) { return NULL; } ch = g_utf8_get_char (cur_char); if (! valid_start_char(ch)) { return NULL; } return g_ascii_strdown(cur_char, -1); } static gchar * get_word_at_iter (GtkTextIter *iter) { GtkTextBuffer *buffer; GtkTextIter start_line; gchar *line_text; gchar *word; buffer = gtk_text_iter_get_buffer (iter); start_line = *iter; gtk_text_iter_set_line_offset (&start_line, 0); line_text = gtk_text_buffer_get_text (buffer, &start_line, iter, FALSE); word = get_end_word (line_text); g_free (line_text); return word; } static gboolean text_char_predicate(gunichar ch, gpointer user_data) { return ch == '#'; } static int in_comment(GtkTextIter *iter) { GtkTextIter cur; cur = *iter; gtk_text_iter_set_line_offset(iter, 0); return gtk_text_iter_forward_find_char(iter, text_char_predicate, NULL, &cur); } static void source_completion_words_populate (GtkSourceCompletionProvider *provider, GtkSourceCompletionContext *context) { SourceCompletionWords *words = SOURCE_COMPLETION_WORDS (provider); GtkSourceCompletionActivation activation; GtkTextIter iter; gchar *word; GList *ret = NULL; if (!gtk_source_completion_context_get_iter (context, &iter)) { gtk_source_completion_context_add_proposals (context, provider, NULL, TRUE); return; } if (in_comment(&iter)) { gtk_source_completion_context_add_proposals (context, provider, NULL, TRUE); return; } word = get_word_at_iter (&iter); activation = gtk_source_completion_context_get_activation (context); if (word == NULL || (activation == GTK_SOURCE_COMPLETION_ACTIVATION_INTERACTIVE && g_utf8_strlen (word, -1) < MINIMUM_WORD_SIZE)) { g_free(word); gtk_source_completion_context_add_proposals(context, provider, NULL, TRUE); return; } ret = words->priv->populate_func(word, strlen(word), &iter); g_free(word); ret = g_list_reverse(ret); gtk_source_completion_context_add_proposals(context, GTK_SOURCE_COMPLETION_PROVIDER(words), ret, TRUE); g_list_free (ret); } static void source_completion_words_dispose (GObject *object) { SourceCompletionWords *provider = SOURCE_COMPLETION_WORDS (object); g_free (provider->priv->name); provider->priv->name = NULL; G_OBJECT_CLASS (source_completion_words_parent_class)->dispose (object); } static void source_completion_words_class_init (SourceCompletionWordsClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); object_class->dispose = source_completion_words_dispose; } static gboolean source_completion_words_get_start_iter (GtkSourceCompletionProvider *provider, GtkSourceCompletionContext *context, GtkSourceCompletionProposal *proposal, GtkTextIter *iter) { gchar *word; glong nb_chars; if (!gtk_source_completion_context_get_iter (context, iter)) { return FALSE; } word = get_word_at_iter (iter); g_return_val_if_fail (word != NULL, FALSE); nb_chars = g_utf8_strlen (word, -1); gtk_text_iter_backward_chars (iter, nb_chars); g_free (word); return TRUE; } static gint source_completion_words_get_interactive_delay (GtkSourceCompletionProvider *provider) { return INTERACTIVE_DELAY; } static gint source_completion_words_get_priority (GtkSourceCompletionProvider *provider) { return PRIORITY; } static GtkSourceCompletionActivation source_completion_words_get_activation (GtkSourceCompletionProvider *provider) { return ACTIVATION; } static void source_completion_words_iface_init (GtkSourceCompletionProviderIface *iface) { iface->get_name = source_completion_words_get_name; iface->populate = source_completion_words_populate; iface->get_start_iter = source_completion_words_get_start_iter; iface->get_interactive_delay = source_completion_words_get_interactive_delay; iface->get_priority = source_completion_words_get_priority; iface->get_activation = source_completion_words_get_activation; } static void source_completion_words_init (SourceCompletionWords *self) { self->priv = source_completion_words_get_instance_private(self); } /** * gtk_source_completion_words_new: * @name: (nullable): The name for the provider, or %NULL. * @populate_func: : The function to populate completion. * * Returns: a new #GtkSourceCompletionWords provider */ SourceCompletionWords * source_completion_words_new (const gchar *name, populate_func populate_func) { SourceCompletionWords *self; self = g_object_new(SOURCE_TYPE_COMPLETION_WORDS, NULL); self->priv->name = g_strdup(name); self->priv->populate_func = populate_func; return self; } ngraph-gtk-6.08.00/src/gtk/x11info.h0000644000175000017500000000207313351432267013672 00000000000000/* * $Id: x11info.h,v 1.2 2009-07-08 10:13:03 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void InfoWinClear(void); void InfoWinUpdate(int clear); void InfoWinDrawInfoText(const char *str); void InfoWinSetFont(char *font); GtkWidget *InfoWinCreate(struct SubWin *d); ngraph-gtk-6.08.00/src/gtk/completion_info_constants.txt0000644000175000017500000000437113313701025020245 00000000000000PI Pi E The base of natural logarithm (Napier's constant) EULER Euler's constant NAN Missing data with error indication UNDEF Missing data without error indication CONT Missing data (data lines are combined) BREAK Missing data (data lines are not combined) NUM The number of the data MINX The minimum value of X MAXX The maximum value of X MINY The minimum value of Y MAXY The maximum value of Y SUMX Sum of X SUMY Sum of Y SUMXX Square sum of X SUMYY Square sum of Y SUMXY Product sum of X and Y AVX The average of X AVY The average of X STDEVPX The standard deviation of X STDEVPY The standard deviation of Y STDEVX The corrected sample standard deviation of X STDEVY The corrected sample standard deviation of Y FIRST When conversion is performed twice with one line of data such as diagonal or errorbar plot,\ntrue (1) in the first call, false (0) in the second call. MASK Number of lines set for mask MOVE Number of lines set for move COLX The column number specified for X COLY The column number specified for Y AXISX The ID of the axis instance specified as X axis AXISX_MIN The minimum value of the X axis AXISX_MAX The maximum value of the X axis AXISX_LEN Length of the X axis AXISY The ID of the axis instance specified as Y axis AXISY_MIN The minimum value of the Y axis AXISY_MAX The maximum value of the Y axis AXISY_LEN Length of the Y axis HSKIP Number of lines specified as "Head skip" RSTEP Number of lines specified as "Read step" FLINE Number of lines specified as "Final line" DATA_OBJ The identification number of the data object PATH_OBJ The identification number of the path object RECT_OBJ The identification number of the rectangle object ARC_OBJ The identification number of the arc object MARK_OBJ The identification number of the mark object TEXT_OBJ The identification number of the text object %D The ID of the instance of the data object %N The number of instances of data object TRUE the TRUE value (1) FALSE the FALSE value (0) FILL_RULE_NONE Defined for the function draw_polygon().\ndon't fill the polygon. FILL_RULE_EVEN_ODD Defined for the function draw_polygon().\nfill the polygon with evin-odd rule. FILL_RULE_WINDING Defined for the function draw_polygon().\nfill the polygon with winding rule. ngraph-gtk-6.08.00/src/gtk/gtk_presettings.h0000644000175000017500000000047213331306431015611 00000000000000#ifndef GTK_PRESETTINGS_HEADER #define GTK_PRESETTINGS_HEADER #include "object.h" #include "x11menu.h" GtkWidget *presetting_create_panel(GtkApplication *app); void presetting_set_obj_field(struct objlist *obj, int id); void presetting_set_visibility(enum PointerType type); #endif /* GTK_PRESETTINGS_HEADER */ ngraph-gtk-6.08.00/src/gtk/ogra2gtkprint.c0000644000175000017500000000466713070106167015203 00000000000000/* * $Id: ogra2gtkprint.c,v 1.6 2008-09-18 08:13:43 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #include "mathfn.h" #include "object.h" #include "ioutil.h" #include "x11gui.h" #include "ogra2cairo.h" #define NAME "gra2gtkprint" #define PARENT "gra2cairo" #define OVERSION "1.00.00" #ifndef M_PI #define M_PI 3.141592 #endif static int gra2gtkprint_init(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) { return 1; } return 0; } static int gra2gtkprint_done(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; _getobj(obj, "_local", inst, &local); if (local && local->cairo) { gra2cairo_draw_path(local); local->cairo = NULL; /* the instance of cairo is created by GtkPrintContext */ } if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } static int create_cairo(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { cairo_t *cairo; int dpi, id, r; struct gra2cairo_local *local; GtkPrintContext *gpc; gpc = GTK_PRINT_CONTEXT(argv[2]); if (gpc == NULL) { error(obj, CAIRO_STATUS_NULL_POINTER + 100); return 1; } cairo = gtk_print_context_get_cairo_context(gpc); r = cairo_status(cairo); if (r != CAIRO_STATUS_SUCCESS) { error(obj, r + 100); return 1; } _getobj(obj, "id", inst, &id); dpi = gtk_print_context_get_dpi_x(gpc); if (putobj(obj, "dpix", id, &dpi) < 0) { error(obj, ERRFIELD); return 1; } dpi = gtk_print_context_get_dpi_y(gpc); if (putobj(obj, "dpiy", id, &dpi) < 0) { error(obj, ERRFIELD); return 1; } _getobj(obj, "_local", inst, &local); local->cairo = cairo; return 0; } static struct objtable gra2gtkprint[] = { {"init", NVFUNC, NEXEC, gra2gtkprint_init, NULL, 0}, {"done", NVFUNC, NEXEC, gra2gtkprint_done, NULL, 0}, {"_context", NVFUNC, 0, create_cairo, NULL,0}, }; #define TBLNUM (sizeof(gra2gtkprint) / sizeof(*gra2gtkprint)) void * addgra2gtkprint() /* addgra2gtkprint() returns NULL on error */ { return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, gra2gtkprint, Gra2CairoErrMsgNum, Gra2CairoErrMsgs, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/x11merge.h0000644000175000017500000000223113351432267014032 00000000000000/* * $Id: x11merge.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void MergeWinUpdate(struct obj_list_data *d, int clear, int draw); void CmMergeOpen(void *w, gpointer client_data); void CmMergeClose(void *w, gpointer client_data); void CmMergeUpdate(void *w, gpointer client_data); GtkWidget *dreate_merge_list(struct SubWin *d); ngraph-gtk-6.08.00/src/gtk/gtk_combo.h0000644000175000017500000000135113070106167014342 00000000000000/* * $Id: gtk_combo.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ */ #ifndef GTKCOMBO_HEADER #define GTKCOMBO_HEADER GtkWidget *combo_box_create(void); GtkWidget *combo_box_entry_create(void); void combo_box_entry_set_width(GtkWidget *cbox, int width); void combo_box_entry_set_text(GtkWidget *cbox, char *str); const char *combo_box_entry_get_text(GtkWidget *cbox); int combo_box_get_active(GtkWidget *cbox); char *combo_box_get_active_text(GtkWidget *cbox); void combo_box_set_active(GtkWidget *cbox, int i); void combo_box_clear(GtkWidget *cbox); int combo_box_get_num(GtkWidget *cbox); void combo_box_append_text(GtkWidget *cbox, char *str); int combo_box_get_selected_row(GtkWidget *view, gchar *path, GtkTreeIter *iter, int col); #endif ngraph-gtk-6.08.00/src/gtk/ogra2emf.c0000644000175000017500000012015013150462202014064 00000000000000#include "common.h" #if WINDOWS #include #include #include #include #include #include #include #include #include #include "gtk_common.h" #include "object.h" #include "nstring.h" #include "ioutil.h" #include "shell.h" #include "strconv.h" #include "gra.h" #include "ogra2cairo.h" #define NAME "gra2emf" #define PARENT "gra2" #define OVERSION "1.00.00" #define DEFAULT_FONT "Sans-serif" #define USE_LINE_TO 1 #ifndef MPI #define MPI 3.14159265358979323846 #endif #define ERRFOPEN 100 #define ERREMF 101 #define USE_EnumFontFamiliesExW 0 /* FixMe: the program will be crashed when use EnumLogFontExW */ static char *gra2emf_errorlist[]={ "I/O error: open file", "EMF error", }; #define ERRNUM (sizeof(gra2emf_errorlist) / sizeof(*gra2emf_errorlist)) #define CHAR_SET_NUM 32 struct gra2emf_fontmap { char *name; int char_set[CHAR_SET_NUM + 1]; struct gra2emf_fontmap *next; }; struct gra2emf_local { HDC hdc, hdc_dummy; int r, g, b, x, y, offsetx, offsety; char *fontalias, *fontname; int font_style, line_join, line_cap, line_width, line_style_num, symbol; int update_pen_attribute, update_brush_attribute; double fontdir, fontcos, fontsin, fontspace, fontsize; DWORD *line_style; #if USE_LINE_TO int line; #else struct narray line; #endif NHASH fontmap; HPEN null_pen, the_pen; HBRUSH the_brush; }; static void draw_lines(struct gra2emf_local *local); static int close_emf(struct gra2emf_local *local, const char *fname); static int #if USE_EnumFontFamiliesExW enum_font_cb(ENUMLOGFONTEXW *lpelfe, NEWTEXTMETRICEXW *lpntme, DWORD FontType, LPARAM lParam) #else enum_font_cb(ENUMLOGFONTEX *lpelfe, NEWTEXTMETRICEX *lpntme, DWORD FontType, LPARAM lParam) #endif { int char_set, i; struct gra2emf_fontmap *fontmap; if (lpelfe == NULL || lpntme == NULL || lParam == 0) { return 0; } if (FontType == 0) { return 0; /* this check may necessary to avoid crash on Windows8 */ } if (FontType & ~(TRUETYPE_FONTTYPE | RASTER_FONTTYPE | DEVICE_FONTTYPE)) { return 0; /* this check may necessary to avoid crash on Windows8 */ } if (lpntme->ntmTm.tmWeight != FW_NORMAL || lpntme->ntmTm.tmItalic) { return 1; } fontmap = (struct gra2emf_fontmap *) lParam; char_set = lpntme->ntmTm.tmCharSet; for (i = 0; i < CHAR_SET_NUM; i++) { if (fontmap->char_set[i] < 0) { fontmap->char_set[i] = char_set; fontmap->char_set[i + 1] = -1; break; } } return 1; } static int get_char_set(gunichar ch) { GUnicodeScript script; int char_set; script = g_unichar_get_script(ch); switch (script) { case G_UNICODE_SCRIPT_COMMON: char_set = ANSI_CHARSET; break; case G_UNICODE_SCRIPT_INHERITED: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_ARABIC: char_set = ARABIC_CHARSET; break; case G_UNICODE_SCRIPT_ARMENIAN: char_set = EASTEUROPE_CHARSET; break; case G_UNICODE_SCRIPT_BENGALI: case G_UNICODE_SCRIPT_BOPOMOFO: case G_UNICODE_SCRIPT_CHEROKEE: case G_UNICODE_SCRIPT_COPTIC: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_CYRILLIC: char_set = RUSSIAN_CHARSET; break; case G_UNICODE_SCRIPT_DESERET: case G_UNICODE_SCRIPT_DEVANAGARI: case G_UNICODE_SCRIPT_ETHIOPIC: case G_UNICODE_SCRIPT_GEORGIAN: case G_UNICODE_SCRIPT_GOTHIC: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_GREEK: char_set = GREEK_CHARSET; break; case G_UNICODE_SCRIPT_GUJARATI: case G_UNICODE_SCRIPT_GURMUKHI: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_HAN: char_set = CHINESEBIG5_CHARSET; char_set = GB2312_CHARSET; char_set = SHIFTJIS_CHARSET; break; case G_UNICODE_SCRIPT_HANGUL: char_set = HANGEUL_CHARSET; break; case G_UNICODE_SCRIPT_HEBREW: char_set = HEBREW_CHARSET; break; case G_UNICODE_SCRIPT_HIRAGANA: char_set = SHIFTJIS_CHARSET; break; case G_UNICODE_SCRIPT_KANNADA: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_KATAKANA: char_set = SHIFTJIS_CHARSET; break; case G_UNICODE_SCRIPT_KHMER: case G_UNICODE_SCRIPT_LAO: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_LATIN: char_set = ANSI_CHARSET; break; case G_UNICODE_SCRIPT_MALAYALAM: case G_UNICODE_SCRIPT_MONGOLIAN: case G_UNICODE_SCRIPT_MYANMAR: case G_UNICODE_SCRIPT_OGHAM: case G_UNICODE_SCRIPT_OLD_ITALIC: case G_UNICODE_SCRIPT_ORIYA: case G_UNICODE_SCRIPT_RUNIC: case G_UNICODE_SCRIPT_SINHALA: case G_UNICODE_SCRIPT_SYRIAC: case G_UNICODE_SCRIPT_TAMIL: case G_UNICODE_SCRIPT_TELUGU: case G_UNICODE_SCRIPT_THAANA: char_set = DEFAULT_CHARSET; break; case G_UNICODE_SCRIPT_THAI: char_set = THAI_CHARSET; break; case G_UNICODE_SCRIPT_TIBETAN: case G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL: case G_UNICODE_SCRIPT_YI: case G_UNICODE_SCRIPT_TAGALOG: case G_UNICODE_SCRIPT_HANUNOO: case G_UNICODE_SCRIPT_BUHID: case G_UNICODE_SCRIPT_TAGBANWA: case G_UNICODE_SCRIPT_BRAILLE: case G_UNICODE_SCRIPT_CYPRIOT: case G_UNICODE_SCRIPT_LIMBU: case G_UNICODE_SCRIPT_OSMANYA: case G_UNICODE_SCRIPT_SHAVIAN: case G_UNICODE_SCRIPT_LINEAR_B: case G_UNICODE_SCRIPT_TAI_LE: case G_UNICODE_SCRIPT_UGARITIC: case G_UNICODE_SCRIPT_NEW_TAI_LUE: case G_UNICODE_SCRIPT_BUGINESE: case G_UNICODE_SCRIPT_GLAGOLITIC: case G_UNICODE_SCRIPT_TIFINAGH: case G_UNICODE_SCRIPT_SYLOTI_NAGRI: case G_UNICODE_SCRIPT_OLD_PERSIAN: case G_UNICODE_SCRIPT_KHAROSHTHI: case G_UNICODE_SCRIPT_UNKNOWN: case G_UNICODE_SCRIPT_BALINESE: case G_UNICODE_SCRIPT_CUNEIFORM: case G_UNICODE_SCRIPT_PHOENICIAN: case G_UNICODE_SCRIPT_PHAGS_PA: case G_UNICODE_SCRIPT_NKO: case G_UNICODE_SCRIPT_KAYAH_LI: case G_UNICODE_SCRIPT_LEPCHA: case G_UNICODE_SCRIPT_REJANG: case G_UNICODE_SCRIPT_SUNDANESE: case G_UNICODE_SCRIPT_SAURASHTRA: case G_UNICODE_SCRIPT_CHAM: case G_UNICODE_SCRIPT_OL_CHIKI: case G_UNICODE_SCRIPT_VAI: case G_UNICODE_SCRIPT_CARIAN: case G_UNICODE_SCRIPT_LYCIAN: case G_UNICODE_SCRIPT_LYDIAN: case G_UNICODE_SCRIPT_AVESTAN: case G_UNICODE_SCRIPT_BAMUM: case G_UNICODE_SCRIPT_EGYPTIAN_HIEROGLYPHS: case G_UNICODE_SCRIPT_IMPERIAL_ARAMAIC: case G_UNICODE_SCRIPT_INSCRIPTIONAL_PAHLAVI: case G_UNICODE_SCRIPT_INSCRIPTIONAL_PARTHIAN: case G_UNICODE_SCRIPT_JAVANESE: case G_UNICODE_SCRIPT_KAITHI: case G_UNICODE_SCRIPT_LISU: case G_UNICODE_SCRIPT_MEETEI_MAYEK: case G_UNICODE_SCRIPT_OLD_SOUTH_ARABIAN: char_set = DEFAULT_CHARSET; break; default: char_set = DEFAULT_CHARSET; } /* 0: 'ANSI_CHARSET'; 1: 'DEFAULT_CHARSET'; 2: 'SYMBOL_CHARSET'; 77: 'MAC_CHARSET'; 128: 'SHIFTJIS_CHARSET'; 129: 'HANGEUL_CHARSET'; 130: 'JOHAB_CHARSET'; 134: 'GB2312_CHARSET'; 136: 'CHINESEBIG5_CHARSET'; 161: 'GREEK_CHARSET'; 162: 'TURKISH_CHARSET'; 163: 'VIETNAMESE_CHARSET'; 177: 'HEBREW_CHARSET'; 178: 'ARABIC_CHARSET'; 186: 'BALTIC_CHARSET'; 204: 'RUSSIAN_CHARSET'; 222: 'THAI_CHARSET'; 238: 'EASTEUROPE_CHARSET'; 255: 'OEM_CHARSET '; */ #if 0 { char *script_name; char str[16], *sstr; int l; switch (script) { case G_UNICODE_SCRIPT_COMMON: script_name = "G_UNICODE_SCRIPT_COMMON"; break; case G_UNICODE_SCRIPT_INHERITED: script_name = "G_UNICODE_SCRIPT_INHERITED"; break; case G_UNICODE_SCRIPT_ARABIC: script_name = "G_UNICODE_SCRIPT_ARABIC"; break; case G_UNICODE_SCRIPT_ARMENIAN: script_name = "G_UNICODE_SCRIPT_ARMENIAN"; break; case G_UNICODE_SCRIPT_BENGALI: script_name = "G_UNICODE_SCRIPT_BENGALI"; break; case G_UNICODE_SCRIPT_BOPOMOFO: script_name = "G_UNICODE_SCRIPT_BOPOMOFO"; break; case G_UNICODE_SCRIPT_CHEROKEE: script_name = "G_UNICODE_SCRIPT_CHEROKEE"; break; case G_UNICODE_SCRIPT_COPTIC: script_name = "G_UNICODE_SCRIPT_COPTIC"; break; case G_UNICODE_SCRIPT_CYRILLIC: script_name = "G_UNICODE_SCRIPT_CYRILLIC"; break; case G_UNICODE_SCRIPT_DESERET: script_name = "G_UNICODE_SCRIPT_DESERET"; break; case G_UNICODE_SCRIPT_DEVANAGARI: script_name = "G_UNICODE_SCRIPT_DEVANAGARI"; break; case G_UNICODE_SCRIPT_ETHIOPIC: script_name = "G_UNICODE_SCRIPT_ETHIOPIC"; break; case G_UNICODE_SCRIPT_GEORGIAN: script_name = "G_UNICODE_SCRIPT_GEORGIAN"; break; case G_UNICODE_SCRIPT_GOTHIC: script_name = "G_UNICODE_SCRIPT_GOTHIC"; break; case G_UNICODE_SCRIPT_GREEK: script_name = "G_UNICODE_SCRIPT_GREEK"; break; case G_UNICODE_SCRIPT_GUJARATI: script_name = "G_UNICODE_SCRIPT_GUJARATI"; break; case G_UNICODE_SCRIPT_GURMUKHI: script_name = "G_UNICODE_SCRIPT_GURMUKHI"; break; case G_UNICODE_SCRIPT_HAN: script_name = "G_UNICODE_SCRIPT_HAN"; break; case G_UNICODE_SCRIPT_HANGUL: script_name = "G_UNICODE_SCRIPT_HANGUL"; break; case G_UNICODE_SCRIPT_HEBREW: script_name = "G_UNICODE_SCRIPT_HEBREW"; break; case G_UNICODE_SCRIPT_HIRAGANA: script_name = "G_UNICODE_SCRIPT_HIRAGANA"; break; case G_UNICODE_SCRIPT_KANNADA: script_name = "G_UNICODE_SCRIPT_KANNADA"; break; case G_UNICODE_SCRIPT_KATAKANA: script_name = "G_UNICODE_SCRIPT_KATAKANA"; break; case G_UNICODE_SCRIPT_KHMER: script_name = "G_UNICODE_SCRIPT_KHMER"; break; case G_UNICODE_SCRIPT_LAO: script_name = "G_UNICODE_SCRIPT_LAO"; break; case G_UNICODE_SCRIPT_LATIN: script_name = "G_UNICODE_SCRIPT_LATIN"; break; case G_UNICODE_SCRIPT_MALAYALAM: script_name = "G_UNICODE_SCRIPT_MALAYALAM"; break; case G_UNICODE_SCRIPT_MONGOLIAN: script_name = "G_UNICODE_SCRIPT_MONGOLIAN"; break; case G_UNICODE_SCRIPT_MYANMAR: script_name = "G_UNICODE_SCRIPT_MYANMAR"; break; case G_UNICODE_SCRIPT_OGHAM: script_name = "G_UNICODE_SCRIPT_OGHAM"; break; case G_UNICODE_SCRIPT_OLD_ITALIC: script_name = "G_UNICODE_SCRIPT_OLD_ITALIC"; break; case G_UNICODE_SCRIPT_ORIYA: script_name = "G_UNICODE_SCRIPT_ORIYA"; break; case G_UNICODE_SCRIPT_RUNIC: script_name = "G_UNICODE_SCRIPT_RUNIC"; break; case G_UNICODE_SCRIPT_SINHALA: script_name = "G_UNICODE_SCRIPT_SINHALA"; break; case G_UNICODE_SCRIPT_SYRIAC: script_name = "G_UNICODE_SCRIPT_SYRIAC"; break; case G_UNICODE_SCRIPT_TAMIL: script_name = "G_UNICODE_SCRIPT_TAMIL"; break; case G_UNICODE_SCRIPT_TELUGU: script_name = "G_UNICODE_SCRIPT_TELUGU"; break; case G_UNICODE_SCRIPT_THAANA: script_name = "G_UNICODE_SCRIPT_THAANA"; break; case G_UNICODE_SCRIPT_THAI: script_name = "G_UNICODE_SCRIPT_THAI"; break; case G_UNICODE_SCRIPT_TIBETAN: script_name = "G_UNICODE_SCRIPT_TIBETAN"; break; case G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL: script_name = "G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL"; break; case G_UNICODE_SCRIPT_YI: script_name = "G_UNICODE_SCRIPT_YI"; break; case G_UNICODE_SCRIPT_TAGALOG: script_name = "G_UNICODE_SCRIPT_TAGALOG"; break; case G_UNICODE_SCRIPT_HANUNOO: script_name = "G_UNICODE_SCRIPT_HANUNOO"; break; case G_UNICODE_SCRIPT_BUHID: script_name = "G_UNICODE_SCRIPT_BUHID"; break; case G_UNICODE_SCRIPT_TAGBANWA: script_name = "G_UNICODE_SCRIPT_TAGBANWA"; break; case G_UNICODE_SCRIPT_BRAILLE: script_name = "G_UNICODE_SCRIPT_BRAILLE"; break; case G_UNICODE_SCRIPT_CYPRIOT: script_name = "G_UNICODE_SCRIPT_CYPRIOT"; break; case G_UNICODE_SCRIPT_LIMBU: script_name = "G_UNICODE_SCRIPT_LIMBU"; break; case G_UNICODE_SCRIPT_OSMANYA: script_name = "G_UNICODE_SCRIPT_OSMANYA"; break; case G_UNICODE_SCRIPT_SHAVIAN: script_name = "G_UNICODE_SCRIPT_SHAVIAN"; break; case G_UNICODE_SCRIPT_LINEAR_B: script_name = "G_UNICODE_SCRIPT_LINEAR_B"; break; case G_UNICODE_SCRIPT_TAI_LE: script_name = "G_UNICODE_SCRIPT_TAI_LE"; break; case G_UNICODE_SCRIPT_UGARITIC: script_name = "G_UNICODE_SCRIPT_UGARITIC"; break; case G_UNICODE_SCRIPT_NEW_TAI_LUE: script_name = "G_UNICODE_SCRIPT_NEW_TAI_LUE"; break; case G_UNICODE_SCRIPT_BUGINESE: script_name = "G_UNICODE_SCRIPT_BUGINESE"; break; case G_UNICODE_SCRIPT_GLAGOLITIC: script_name = "G_UNICODE_SCRIPT_GLAGOLITIC"; break; case G_UNICODE_SCRIPT_TIFINAGH: script_name = "G_UNICODE_SCRIPT_TIFINAGH"; break; case G_UNICODE_SCRIPT_SYLOTI_NAGRI: script_name = "G_UNICODE_SCRIPT_SYLOTI_NAGRI"; break; case G_UNICODE_SCRIPT_OLD_PERSIAN: script_name = "G_UNICODE_SCRIPT_OLD_PERSIAN"; break; case G_UNICODE_SCRIPT_KHAROSHTHI: script_name = "G_UNICODE_SCRIPT_KHAROSHTHI"; break; case G_UNICODE_SCRIPT_UNKNOWN: script_name = "G_UNICODE_SCRIPT_UNKNOWN"; break; case G_UNICODE_SCRIPT_BALINESE: script_name = "G_UNICODE_SCRIPT_BALINESE"; break; case G_UNICODE_SCRIPT_CUNEIFORM: script_name = "G_UNICODE_SCRIPT_CUNEIFORM"; break; case G_UNICODE_SCRIPT_PHOENICIAN: script_name = "G_UNICODE_SCRIPT_PHOENICIAN"; break; case G_UNICODE_SCRIPT_PHAGS_PA: script_name = "G_UNICODE_SCRIPT_PHAGS_PA"; break; case G_UNICODE_SCRIPT_NKO: script_name = "G_UNICODE_SCRIPT_NKO"; break; case G_UNICODE_SCRIPT_KAYAH_LI: script_name = "G_UNICODE_SCRIPT_KAYAH_LI"; break; case G_UNICODE_SCRIPT_LEPCHA: script_name = "G_UNICODE_SCRIPT_LEPCHA"; break; case G_UNICODE_SCRIPT_REJANG: script_name = "G_UNICODE_SCRIPT_REJANG"; break; case G_UNICODE_SCRIPT_SUNDANESE: script_name = "G_UNICODE_SCRIPT_SUNDANESE"; break; case G_UNICODE_SCRIPT_SAURASHTRA: script_name = "G_UNICODE_SCRIPT_SAURASHTRA"; break; case G_UNICODE_SCRIPT_CHAM: script_name = "G_UNICODE_SCRIPT_CHAM"; break; case G_UNICODE_SCRIPT_OL_CHIKI: script_name = "G_UNICODE_SCRIPT_OL_CHIKI"; break; case G_UNICODE_SCRIPT_VAI: script_name = "G_UNICODE_SCRIPT_VAI"; break; case G_UNICODE_SCRIPT_CARIAN: script_name = "G_UNICODE_SCRIPT_CARIAN"; break; case G_UNICODE_SCRIPT_LYCIAN: script_name = "G_UNICODE_SCRIPT_LYCIAN"; break; case G_UNICODE_SCRIPT_LYDIAN: script_name = "G_UNICODE_SCRIPT_LYDIAN"; break; case G_UNICODE_SCRIPT_AVESTAN: script_name = "G_UNICODE_SCRIPT_AVESTAN"; break; case G_UNICODE_SCRIPT_BAMUM: script_name = "G_UNICODE_SCRIPT_BAMUM"; break; case G_UNICODE_SCRIPT_EGYPTIAN_HIEROGLYPHS: script_name = "G_UNICODE_SCRIPT_EGYPTIAN_HIEROGLYPHS"; break; case G_UNICODE_SCRIPT_IMPERIAL_ARAMAIC: script_name = "G_UNICODE_SCRIPT_IMPERIAL_ARAMAIC"; break; case G_UNICODE_SCRIPT_INSCRIPTIONAL_PAHLAVI: script_name = "G_UNICODE_SCRIPT_INSCRIPTIONAL_PAHLAVI"; break; case G_UNICODE_SCRIPT_INSCRIPTIONAL_PARTHIAN: script_name = "G_UNICODE_SCRIPT_INSCRIPTIONAL_PARTHIAN"; break; case G_UNICODE_SCRIPT_JAVANESE: script_name = "G_UNICODE_SCRIPT_JAVANESE"; break; case G_UNICODE_SCRIPT_KAITHI: script_name = "G_UNICODE_SCRIPT_KAITHI"; break; case G_UNICODE_SCRIPT_LISU: script_name = "G_UNICODE_SCRIPT_LISU"; break; case G_UNICODE_SCRIPT_MEETEI_MAYEK: script_name = "G_UNICODE_SCRIPT_MEETEI_MAYEK"; break; case G_UNICODE_SCRIPT_OLD_SOUTH_ARABIAN: script_name = "G_UNICODE_SCRIPT_OLD_SOUTH_ARABIAN"; break; default: script_name = "UNKNOWN"; } l = g_unichar_to_utf8(ch, str); str[l] = '\0'; sstr = utf8_to_sjis(str); printf("%s (%d): %s\n", script_name, script, sstr); g_free(sstr); } #endif return char_set; } static void fontmap_append(struct gra2emf_local *local, const char *font_name, struct gra2emf_fontmap *fontmap) { struct gra2emf_fontmap *cur; if (nhash_get_ptr(local->fontmap, font_name, (void *) &cur)) { nhash_set_ptr(local->fontmap, font_name, fontmap); return; } while (cur) { if (cur->next == NULL) { cur->next = fontmap; fontmap->next = NULL; break; } cur = cur->next; } } static void check_fonts(struct gra2emf_local *local, HDC hdc, const char *alias, const char *font_name) { #if USE_EnumFontFamiliesExW LOGFONTW logfont; #else LOGFONT logfont; #endif glong len, size; gunichar2 *ustr; struct gra2emf_fontmap *fontmap; ustr = g_utf8_to_utf16(font_name, -1, NULL, &len, NULL); len *= 2; logfont.lfCharSet = DEFAULT_CHARSET; logfont.lfPitchAndFamily = 0; size = (len > LF_FACESIZE - 2) ? LF_FACESIZE - 2: len; memcpy(logfont.lfFaceName, ustr, size); memset(((char *) logfont.lfFaceName) + size, 0, 2); g_free(ustr); fontmap = g_malloc0(sizeof(*fontmap)); if (fontmap == NULL) { return; } fontmap->char_set[0] = -1; fontmap->next = NULL; fontmap->name = g_strdup(font_name); if (fontmap->name == NULL) { g_free(fontmap); return; } fontmap_append(local, alias, fontmap); /* fontmap_append() should be called before EnumFontFamiliesExW() when compiled with -O2 option */ #if USE_EnumFontFamiliesExW EnumFontFamiliesExW(hdc, &logfont, (FONTENUMPROCW) enum_font_cb, (LPARAM) fontmap, 0); #else EnumFontFamiliesEx(hdc, &logfont, (FONTENUMPROC) enum_font_cb, (LPARAM) fontmap, 0); #endif } static int gra2emf_init(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2emf_local *local = NULL; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) { return 1; } local = g_malloc0(sizeof(struct gra2emf_local)); if (local == NULL){ goto errexit; } local->fontmap = nhash_new(); local->hdc_dummy = CreateDC("DISPLAY", NULL, NULL, NULL); if (local->hdc_dummy == NULL) { g_free(local); goto errexit; } if (_putobj(obj, "_local", inst, local)) { goto errexit; } local->null_pen = CreatePen(PS_NULL, 0, RGB(0, 0, 0)); #if USE_LINE_TO local->line = 0; #else arrayinit(&local->line, sizeof(int)); #endif return 0; errexit: g_free(local); return 1; } static void free_fontmap_sub(NHASH fontmap, const char *name) { struct gra2emf_fontmap *cur, *next; if (nhash_get_ptr(fontmap, name, (void *) &cur)) { return; } while (cur) { if (cur->name) { g_free(cur->name); } next = cur->next; g_free(cur); cur = next; } nhash_del(fontmap, name); } static void free_fontmap(NHASH fontmap) { free_fontmap_sub(fontmap, "Serif"); free_fontmap_sub(fontmap, "Sans-serif"); free_fontmap_sub(fontmap, "Monospace"); } static int gra2emf_done(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2emf_local *local; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) { return 1; } _getobj(obj, "_local", inst, &local); if (local == NULL) { return 0; } if (local->hdc) { close_emf(local, NULL); } if (local->null_pen) { DeleteObject(local->null_pen); } DeleteDC(local->hdc_dummy); #if USE_LINE_TO draw_lines(local); #else arraydel(&local->line); #endif free_fontmap(local->fontmap); nhash_free(local->fontmap); return 0; } static void add_fontmap(struct gra2emf_local *local, HDC hdc, const char *alias) { struct fontmap *font_map; font_map = gra2cairo_get_fontmap(alias); if (font_map == NULL) { return; } if (font_map->fontname) { check_fonts(local, hdc, alias, font_map->fontname); } if (font_map->alternative) { gchar **alternative; int i; alternative = g_strsplit(font_map->alternative, ",", 0); for (i = 0; alternative[i]; i++) { check_fonts(local, hdc, alias, alternative[i]); } g_strfreev(alternative); } } static int open_emf(struct gra2emf_local *local) { HDC hdc; XFORM xform = {1, 0, 0, -1, 0, 0}; hdc = CreateEnhMetaFile(NULL, NULL, NULL, NULL); if (hdc == NULL) { return 1; } add_fontmap(local, hdc, "Serif"); add_fontmap(local, hdc, "Sans-serif"); add_fontmap(local, hdc, "Monospace"); StartPage(hdc); SaveDC(hdc); SetGraphicsMode(hdc, GM_ADVANCED); SetMapMode(hdc, MM_HIMETRIC); SetWorldTransform(hdc, &xform); SetBkMode(hdc, TRANSPARENT); SetArcDirection(hdc, AD_COUNTERCLOCKWISE); local->update_pen_attribute = TRUE; local->update_brush_attribute = TRUE; local->the_brush = NULL; local->the_pen = NULL; local->hdc = hdc; return 0; } static int close_emf(struct gra2emf_local *local, const char *fname) { HENHMETAFILE emf; int r; HPEN pen; HBRUSH brush; if (local->hdc == NULL) { return 1; } r = 1; if (local->the_pen) { pen = SelectObject(local->hdc, local->the_pen); DeleteObject(pen); local->the_pen = NULL; } if (local->the_brush) { brush = SelectObject(local->hdc, local->the_brush); DeleteObject(brush); local->the_brush = NULL; } RestoreDC(local->hdc, -1); EndPage(local->hdc); emf = CloseEnhMetaFile(local->hdc); if (emf == NULL) { return 1; } if (fname) { HENHMETAFILE emf2; emf2 = CopyEnhMetaFile(emf, fname); if (emf2) { DeleteEnhMetaFile(emf2); r = 0; } } else { if (OpenClipboard(NULL)) { EmptyClipboard(); SetClipboardData(CF_ENHMETAFILE, emf); CloseClipboard(); r = 0; } } DeleteEnhMetaFile(emf); DeleteDC(local->hdc); local->hdc = NULL; if (local->fontalias) { g_free(local->fontalias); local->fontalias = NULL; } if (local->fontname) { g_free(local->fontname); local->fontname = NULL; } free_fontmap(local->fontmap); return r; } static HFONT select_font(struct gra2emf_local *local, const char *fontname, int charset) { LOGFONTW id_font; gunichar2 *ustr; id_font.lfHeight = - local->fontsize; id_font.lfWidth = 0; id_font.lfEscapement = local->fontdir * 10; id_font.lfOrientation = local->fontdir * 10; id_font.lfUnderline = 0; id_font.lfStrikeOut = 0; id_font.lfWeight = (local->font_style & GRA_FONT_STYLE_BOLD) ? FW_BOLD : FW_NORMAL; id_font.lfItalic = (local->font_style & GRA_FONT_STYLE_ITALIC) ? TRUE : FALSE; if (local->fontalias == NULL) { id_font.lfPitchAndFamily = (VARIABLE_PITCH | FF_SWISS); } else if (g_ascii_strncasecmp(local->fontalias, "Sans-serif", 5) == 0) { id_font.lfPitchAndFamily = (VARIABLE_PITCH | FF_SWISS); } else if (g_ascii_strncasecmp(local->fontalias, "Serif", 5) == 0) { id_font.lfPitchAndFamily = (VARIABLE_PITCH | FF_ROMAN); } else if (g_ascii_strncasecmp(local->fontalias, "Monospace", 7) == 0) { id_font.lfPitchAndFamily = (FIXED_PITCH | FF_MODERN); } else { id_font.lfPitchAndFamily = (VARIABLE_PITCH | FF_SWISS); } id_font.lfCharSet = charset; id_font.lfOutPrecision = OUT_DEFAULT_PRECIS; id_font.lfOutPrecision = OUT_TT_ONLY_PRECIS; id_font.lfClipPrecision = CLIP_STROKE_PRECIS; id_font.lfQuality = PROOF_QUALITY; ustr = g_utf8_to_utf16(fontname, -1, NULL, NULL, NULL); wcsncpy(id_font.lfFaceName, ustr, LF_FACESIZE - 1); g_free(ustr); id_font.lfFaceName[LF_FACESIZE - 1] = L'\0'; return CreateFontIndirectW(&id_font); } void draw_text_rect(struct gra2emf_local *local, int w, int h) { POINT pos[4]; HGDIOBJ brush, old_brush; pos[0].x = local->x - h * local->fontsin; pos[0].y = local->y - h * local->fontcos; pos[1].x = local->x; pos[1].y = local->y; pos[2].x = local->x + w * local->fontcos; pos[2].y = local->y - w * local->fontsin; pos[3].x = local->x + w * local->fontcos - h * local->fontsin; pos[3].y = local->y - w * local->fontsin - h * local->fontcos; brush = GetStockObject(NULL_BRUSH); old_brush = SelectObject(local->hdc, brush); BeginPath(local->hdc); Polygon(local->hdc, pos, 4); EndPath(local->hdc); FillPath(local->hdc); SelectObject(local->hdc, old_brush); } static void draw_str_sub(struct gra2emf_local *local, const char *str, const char *fontname, int charset) { gunichar2 *ustr; glong len; HDC hdc; char *utf8_str; HFONT font, old_font; SIZE str_size; UINT align; if (str == NULL || str[0] == '\0') { return; } hdc = local->hdc; align = TA_BASELINE; if (charset == HEBREW_CHARSET || charset == ARABIC_CHARSET) { align |= TA_RTLREADING; } SetTextCharacterExtra(hdc, local->fontspace); SetTextColor(hdc, RGB(local->r, local->g, local->b)); font = select_font(local, fontname, charset); old_font = SelectObject(hdc, font); SetTextAlign(hdc, align); utf8_str = gra2cairo_get_utf8_str(str, local->symbol); ustr = g_utf8_to_utf16(utf8_str, -1, NULL, &len, NULL); g_free(utf8_str); ExtTextOutW(hdc, local->x, local->y, 0, NULL, ustr, len, NULL); GetTextExtentPoint32W(hdc, ustr, len, &str_size); SelectObject(hdc, old_font); DeleteObject(font); draw_text_rect(local, str_size.cx, str_size.cy); local->x += str_size.cx * local->fontcos; local->y -= str_size.cx * local->fontsin; g_free(ustr); } static const char * check_font_indices(struct gra2emf_local *local, gunichar ch) { WORD indices[2]; HFONT font, old_font; gunichar str[2]; gunichar2 *ustr; struct gra2emf_fontmap *cur; DWORD r; str[0] = ch; str[1] = 0; if (local->fontalias == NULL) { return NULL; } if (nhash_get_ptr(local->fontmap, local->fontalias, (void *) &cur)) { return NULL; } ustr = g_ucs4_to_utf16(str, 1, NULL, NULL, NULL); if (ustr == NULL) { return NULL; } while (cur) { font = select_font(local, cur->name, ANSI_CHARSET); old_font = SelectObject(local->hdc_dummy, font); r = GetGlyphIndicesW(local->hdc_dummy, ustr, 1, indices, GGI_MARK_NONEXISTING_GLYPHS); SelectObject(local->hdc_dummy, old_font); DeleteObject(font); if (r != GDI_ERROR && indices[0] != 0xffff) { g_free(ustr); return cur->name; } cur = cur->next; } g_free(ustr); return NULL; } static void draw_str(struct gra2emf_local *local, const char *str) { gunichar ch; const char *ptr; GString *sub_str; const char *font, *prev_font; int charset, prev_charset; sub_str = g_string_new(""); prev_font = NULL; prev_charset = DEFAULT_CHARSET; for (ptr = str; *ptr; ptr = g_utf8_next_char(ptr)) { ch = g_utf8_get_char(ptr); charset = get_char_set(ch); font = check_font_indices(local, ch); if (font == NULL) { font = "Arial"; } if (prev_font == NULL) { prev_charset = charset; prev_font = font; } else if (prev_font != font) { draw_str_sub(local, sub_str->str, prev_font, prev_charset); g_string_truncate(sub_str, 0); prev_font = font; prev_charset = charset; } if (prev_charset < charset) { prev_charset = charset; } g_string_append_unichar(sub_str, ch); } draw_str_sub(local, sub_str->str, prev_font, prev_charset); g_string_free(sub_str, TRUE); } static int gra2emf_flush(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2emf_local *local; _getobj(obj, "_local", inst, &local); if (local->hdc == NULL) { return -1; } return 0; } static void create_pen(struct gra2emf_local *local) { HPEN old; DWORD line_attr; LOGBRUSH log_brush; HPEN pen; if (! local->update_pen_attribute) { return; } line_attr = PS_GEOMETRIC; switch (local->line_cap) { case 2: line_attr |= PS_ENDCAP_SQUARE; break; case 1: line_attr |= PS_ENDCAP_ROUND; break; default: line_attr |= PS_ENDCAP_FLAT; } switch (local->line_join) { case 2: line_attr |= PS_JOIN_BEVEL; break; case 1: line_attr |= PS_JOIN_ROUND; break; default: line_attr |= PS_JOIN_MITER; } if (local->line_style) { line_attr |= PS_USERSTYLE; } else { line_attr |= PS_SOLID; } log_brush.lbStyle = BS_SOLID; log_brush.lbColor = RGB(local->r, local->g, local->b); pen = ExtCreatePen(line_attr, local->line_width, &log_brush, local->line_style_num, local->line_style); old = SelectObject(local->hdc, pen); if (local->the_pen) { DeleteObject(old); } else { local->the_pen = old; } local->update_pen_attribute = FALSE; } static void create_brush(struct gra2emf_local *local) { HBRUSH brush, old_brush; if (! local->update_brush_attribute) { return; } brush = CreateSolidBrush(RGB(local->r, local->g, local->b)); old_brush = SelectObject(local->hdc, brush); if (local->the_brush) { DeleteObject(old_brush); } else { local->the_brush = old_brush; } local->update_brush_attribute = FALSE; } static void draw_arc(struct gra2emf_local *local, int x, int y, int w, int h, int start, int angle, int style) { double a1, a2; HPEN old_pen; if (angle == 0) { return; } if (angle % 36000 == 0 && (style == 1 || style == 2)) { create_brush(local); old_pen = SelectObject(local->hdc, local->null_pen); Ellipse(local->hdc, x - w, y - h, x + w, y + h); SelectObject(local->hdc, old_pen); return; } a1 = start * (MPI / 18000.0); a2 = angle * (MPI / 18000.0) + a1; switch (style) { case 1: create_brush(local); old_pen = SelectObject(local->hdc, local->null_pen); Pie(local->hdc, x - w, y - h, x + w, y + h, x + w * cos(a1), y - h * sin(a1), x + w * cos(a2), y - h * sin(a2) ); SelectObject(local->hdc, old_pen); break; case 2: create_brush(local); old_pen = SelectObject(local->hdc, local->null_pen); Chord(local->hdc, x - w, y - h, x + w, y + h, x + w * cos(a1), y - h * sin(a1), x + w * cos(a2), y - h * sin(a2)); SelectObject(local->hdc, old_pen); break; case 3: create_pen(local); MoveToEx(local->hdc, x, y, NULL); BeginPath(local->hdc); ArcTo(local->hdc, x - w, y - h, x + w, y + h, x + w * cos(a1), y - h * sin(a1), x + w * cos(a2), y - h * sin(a2) ); CloseFigure(local->hdc); EndPath(local->hdc); StrokePath(local->hdc); break; case 4: create_pen(local); BeginPath(local->hdc); Arc(local->hdc, x - w, y - h, x + w, y + h, x + w * cos(a1), y - h * sin(a1), x + w * cos(a2), y - h * sin(a2) ); CloseFigure(local->hdc); EndPath(local->hdc); StrokePath(local->hdc); break; default: create_pen(local); Arc(local->hdc, x - w, y - h, x + w, y + h, x + w * cos(a1), y - h * sin(a1), x + w * cos(a2), y - h * sin(a2) ); break; } } static void set_alternative_font(struct gra2emf_local *local) { struct compatible_font_info *info; if (local->fontalias) { g_free(local->fontalias); } local->fontalias = NULL; if (local->fontname == NULL || local->fontname[0] == '\0') { return; } info = gra2cairo_get_compatible_font_info(local->fontname); if (info == NULL) { local->fontalias = g_strdup(local->fontname); local->symbol = FALSE; return; } local->fontalias = g_strdup(info->name); local->font_style = info->style; local->symbol = info->symbol; } static void draw_rectangle(struct gra2emf_local *local, int x1, int y1, int x2, int y2, int fill) { x1 += local->offsetx; y1 += local->offsety; x2 += local->offsetx; y2 += local->offsety; #if USE_LINE_TO if (fill) { create_brush(local); } else { create_pen(local); } BeginPath(local->hdc); MoveToEx(local->hdc, x1, y1, NULL); LineTo(local->hdc, x1, y2); LineTo(local->hdc, x2, y2); LineTo(local->hdc, x2, y1); CloseFigure(local->hdc); EndPath(local->hdc); if (fill) { FillPath(local->hdc); } else { StrokePath(local->hdc); } #else /* USE_LINE_TO */ if (fill) { HPEN old_pen; create_brush(local); old_pen = SelectObject(local->hdc, local->null_pen); Rectangle(local->hdc, x1, y1, x2, y2); SelectObject(local->hdc, old_pen); } else { HBRUSH old_brush; create_pen(local); old_brush = SelectObject(local->hdc, GetStockObject(NULL_BRUSH)); Rectangle(local->hdc, x1, y1, x2, y2); SelectObject(local->hdc, old_brush); } #endif /* USE_LINE_TO */ } static void draw_polygon(struct gra2emf_local *local, int n, int *points, int fill) { int i; #if USE_LINE_TO if (n < 2) { return; } switch (fill) { case 0: create_pen(local); break; case 1: create_brush(local); SetPolyFillMode(local->hdc, ALTERNATE); break; case 2: create_brush(local); SetPolyFillMode(local->hdc, WINDING); break; } BeginPath(local->hdc); MoveToEx(local->hdc, points[0] + local->offsetx, points[1] + local->offsety, NULL); for (i = 1; i < n; i++) { LineTo(local->hdc, points[i * 2 + 0] + local->offsetx, points[i * 2 + 1] + local->offsety); } CloseFigure(local->hdc); EndPath(local->hdc); switch (fill) { case 0: StrokePath(local->hdc); break; case 1: case 2: FillPath(local->hdc); break; } #else /* USE_LINE_TO */ HPEN old_pen; HBRUSH old_brush; POINT *pos; if (n < 2) { return; } pos = g_malloc(sizeof(*pos) * n); if (pos == NULL) { return; } for (i = 0; i < n; i++) { pos[i].x = points[i * 2] + local->offsetx; pos[i].y = points[i * 2 + 1] + local->offsety; } switch (fill) { case 0: create_pen(local); old_brush = SelectObject(local->hdc, GetStockObject(NULL_BRUSH)); Polygon(local->hdc, pos, n); SelectObject(local->hdc, old_brush); break; case 1: create_brush(local); SetPolyFillMode(local->hdc, ALTERNATE); old_pen = SelectObject(local->hdc, local->null_pen); Polygon(local->hdc, pos, n); SelectObject(local->hdc, old_pen); break; case 2: create_brush(local); SetPolyFillMode(local->hdc, WINDING); old_pen = SelectObject(local->hdc, local->null_pen); Polygon(local->hdc, pos, n); SelectObject(local->hdc, old_pen); break; } #endif /* USE_LINE_TO */ } static void draw_polyline(struct gra2emf_local *local, int n, int *points) { int i; #if USE_LINE_TO if (n < 2) { return; } create_pen(local); BeginPath(local->hdc); MoveToEx(local->hdc, points[0] + local->offsetx, points[1] + local->offsety, NULL); for (i = 1; i < n; i++) { LineTo(local->hdc, points[i * 2 + 0] + local->offsetx, points[i * 2 + 1] + local->offsety); } EndPath(local->hdc); StrokePath(local->hdc); #else /* USE_LINE_TO */ POINT *pos; if (n < 2) { return; } pos = g_malloc(sizeof(*pos) * n); if (pos == NULL) { return; } for (i = 0; i < n; i++) { pos[i].x = points[i * 2 + 0] + local->offsetx; pos[i].y = points[i * 2 + 1] + local->offsety; } create_pen(local); Polyline(local->hdc, pos, n); #endif /* USE_LINE_TO */ } static void draw_lines(struct gra2emf_local *local) { #if USE_LINE_TO if (local->line > 0) { EndPath(local->hdc); StrokePath(local->hdc); } local->line = 0; #else POINT *pos; int i, n, *data; n = arraynum(&local->line) / 2; if (n < 2) { arrayclear(&local->line); return; } data = arraydata(&local->line); pos = g_malloc(sizeof(*pos) * n); if (pos == NULL) { return; } for (i = 0; i < n; i++) { pos[i].x = data[i * 2]; pos[i].y = data[i * 2 + 1]; } create_pen(local); Polyline(local->hdc, pos, n); arrayclear(&local->line); #endif } static int gra2emf_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char code, *cstr, *tmp, *fname; int *cpar, i, r; double x, y, w, h, fontdir; struct gra2emf_local *local; DWORD *line_style; POINT lpoint[2]; local = (struct gra2emf_local *)argv[2]; code = *(char *)(argv[3]); cpar = (int *)argv[4]; cstr = argv[5]; if (code != 'I' && local->hdc == NULL) { return 1; } if (code != 'T') { draw_lines(local); } switch (code) { case 'I': if (open_emf(local)) { error(obj, ERREMF); return 1; } break; case '%': case 'X': case 'Z': break; case 'E': r = 0; _getobj(obj, "file", inst, &fname); if (fname) { fname = g_locale_from_utf8(fname, -1, NULL, NULL, NULL); } r = close_emf(local, fname); if (fname) { g_free(fname); } if (r) { error(obj, ERREMF); return 1; } break; case 'V': local->offsetx = cpar[1]; local->offsety = cpar[2]; if (cpar[5]) { BeginPath(local->hdc); Rectangle(local->hdc,cpar[1], cpar[2], cpar[3], cpar[4]); EndPath(local->hdc); SelectClipPath(local->hdc, RGN_COPY); } else { SelectClipRgn(local->hdc, NULL); } break; case 'A': if (local->line_style) { g_free(local->line_style); } local->line_style = NULL; local->line_style_num = 0; if (cpar[1]) { local->line_style = g_malloc(sizeof(* line_style) * cpar[1]); if (local->line_style == NULL) { break; } for (i = 0; i < cpar[1]; i++) { local->line_style[i] = cpar[6 + i]; } local->line_style_num = cpar[1]; } local->line_width = cpar[2]; local->line_cap = cpar[3]; local->line_join = cpar[4]; SetMiterLimit(local->hdc, cpar[5] / 100.0, NULL); local->update_pen_attribute = TRUE; break; case 'G': local->r = cpar[1]; local->g = cpar[2]; local->b = cpar[3]; local->update_pen_attribute = TRUE; local->update_brush_attribute = TRUE; break; case 'M': local->x = cpar[1] + local->offsetx; local->y = cpar[2] + local->offsety; break; case 'N': local->x += cpar[1]; local->y += cpar[2]; break; case 'L': lpoint[0].x = cpar[1] + local->offsetx; lpoint[0].y = cpar[2] + local->offsety; lpoint[1].x = cpar[3] + local->offsetx; lpoint[1].y = cpar[4] + local->offsety; create_pen(local); Polyline(local->hdc, lpoint, 2); break; case 'T': #if USE_LINE_TO if (local->line == 0) { create_pen(local); BeginPath(local->hdc); MoveToEx(local->hdc, local->x, local->y, NULL); } local->x = cpar[1] + local->offsetx; local->y = cpar[2] + local->offsety; LineTo(local->hdc, local->x, local->y); local->line++; #else /* USE_LINE_TO */ /* it seems that the function LineTo() cannot handle dotted line correctly when the points exist very closely. */ if (arraynum(&local->line) < 1) { arrayclear(&local->line); arrayadd(&local->line, &local->x); arrayadd(&local->line, &local->y); } local->x = cpar[1] + local->offsetx; local->y = cpar[2] + local->offsety; arrayadd(&local->line, &local->x); arrayadd(&local->line, &local->y); #endif /* USE_LINE_TO */ break; case 'C': x = cpar[1] + local->offsetx; y = cpar[2] + local->offsety; w = cpar[3]; h = cpar[4]; draw_arc(local, x, y, w, h, cpar[5], cpar[6], cpar[7]); break; case 'B': draw_rectangle(local, cpar[1], cpar[2], cpar[3], cpar[4], cpar[5]); break; case 'P': SetPixel(local->hdc, cpar[1] + local->offsetx, cpar[2] + local->offsety, RGB(local->r, local->g, local->b)); break; case 'R': draw_polyline(local, cpar[1], cpar + 2); break; case 'D': draw_polygon(local, cpar[1], cpar + 3, cpar[2]); break; case 'F': if (local->fontname) { g_free(local->fontname); } local->fontname = g_strdup(cstr); break; case 'H': local->fontspace = cpar[2] / 72.0 * 25.4; local->fontsize = cpar[1] / 72.0 * 25.4; fontdir = cpar[3] * (MPI / 18000.0); local->fontdir = (cpar[3] % 36000) / 100.0; if (local->fontdir < 0) { local->fontdir += 360; } local->fontsin = sin(fontdir); local->fontcos = cos(fontdir); local->font_style = (cpar[0] > 3) ? cpar[4] : 0; set_alternative_font(local); break; case 'S': draw_str(local, argv[5]); break; case 'K': tmp = sjis_to_utf8(cstr); if (tmp) { draw_str(local, tmp); g_free(tmp); } break; default: break; } return 0; } static struct objtable gra2emf[] = { {"init", NVFUNC, NEXEC, gra2emf_init, NULL, 0}, {"done", NVFUNC, NEXEC, gra2emf_done, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, {"file", NSTR, NREAD | NWRITE, NULL, NULL,0}, {"flush", NVFUNC,NREAD|NEXEC, gra2emf_flush,"",0}, {"_output", NVFUNC, 0, gra2emf_output, NULL, 0}, {"_local", NPOINTER, 0, NULL, NULL, 0}, }; #define TBLNUM (sizeof(gra2emf) / sizeof(*gra2emf)) void * addgra2emf(void) /* addgra2emfile() returns NULL on error */ { return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, gra2emf, ERRNUM, gra2emf_errorlist, NULL, NULL); } #endif /* WINDOWS */ ngraph-gtk-6.08.00/src/gtk/completion_info_functions.txt0000644000175000017500000003076113246234367020262 00000000000000abs(x) compute the absolute value of x sign(x) positive / negative sign (-1 with x < 0, 1 with x >= 0) int(x) round to integer, toward zero gauss(x) largest integral value not greater than x frac(x) remainder round(x) round to nearest integer, away from zero min(a, b, c, ...) The smallest value of arguments max(a, b, c, ...) The largest value of arguments sumsq(a, b, c, ...) square sum of arguments sqr(x) squaring sqrt(x) square root exp(x) base-e exponential function (x <= 690) ln(x) natural logarithmic function log(x) base-10 logarithmic function sin(x) sine function cos(x) cosine function tan(x) tangent function asin(x) arc sine function acos(x) arc cosine function atan(x) arc tangent function sinh(x) hyperbolic sine function cosh(x) hyperbolic cosine function tanh(x) hyperbolic tangent function asinh(x) inverse hyperbolic sine function acosh(x) inverse hyperbolic cosine function atanh(x) inverse hyperbolic tangent function fmod(x, y) compute the floating-point remainder of dividing x by y rand(x) returns a random gdouble equally distributed over the range [0..x) srand(x) Sets the seed for the random number generator which is used by the rand() function theta(x) staircase function (1 if x >= 0, 0 otherwise) delta(x) Kronecker delta (1 when x = 0, 0 otherwise) gamma(x) gamma function icgam(m, x) incomplete gamma function erf(x) error function erf(x) erfc(x) complementary error function erfc(x) qinv(x) inverse complementary error function ei(x) compute the exponential integral Ei(x) beta(x, y) beta function icbeta(a, b, x) incomplete beta function jn(n, x) compute the regular cylindrical Bessel function of order n, Jn(|x|) yn(n, x) compute the irregular cylindrical Bessel function of order n, Yn(|x|) in(n, x) compute the regular modified cylindrical Bessel function of order |n|, In(|x|) kn(n, x) compute the irregular modified cylindrical Bessel function of order |n|, Kn(|x|) jl(l, x) compute the regular spherical Bessel function of order |l|, jl(|x|) yl(l, x) compute the irregular spherical Bessel function of order |l|, yl(|x|) jnu(nu, x) compute the regular cylindrical Bessel function of fractional order |nu|, Jnu(|x|) ynu(nu, x) compute the irregular cylindrical Bessel function of fractional order |nu|, Ynu(|x|) inu(nu, x) compute the regular modified Bessel function of fractional order |nu|, Inu(|x|) knu(nu, x) compute the irregular modified Bessel function of fractional order |nu|, Knu(|x|) pn(l, x) evaluate the Legendre polynomial Pl(x) for a specific value of l, x subject to l >= 0, |x| <= 1 lgn(n, a, x) evaluate the generalized Laguerre polynomials Lan(x) for a > -1, n >= 0 hn(n, x) Hermite polynomials tn(n, x) Chebyshev polynomials zeta(s) compute the Riemann zeta function zeta(s) for arbitrary s, s != 1 zeta_int(n) compute the Riemann zeta function zeta(n) for integer n, n != 1 zetam1(s) compute zeta(s) - 1 for arbitrary s, s != 1 zetam1_int(n) compute zeta(n) - 1 for integer n, n != 1 choose(n, m) the combinatorial factor n choose m: n!/(m!(n-m)!) mjd(year, month, day, hour, min, sec) Modified Julian Date (date and time are given in UTC) unix2mjd(time) Modified Julian Date\ntime represents the number of seconds elapsed since the Epoch,\n1970-01-01 00:00:00 +0000 (UTC)) mjd2unix(mjd) time represents the number of seconds elapsed since the Epoch at mjd mjd2year(mjd) year of Gregorian calendar corresponding to Modified Julian Day mjd mjd2month(mjd) month of Gregorian calendar corresponding to Modified Julian Day mjd mjd2day(mjd) Gregorian calendar day corresponding to Modified Julian Day mjd mjd2wday(mjd) The day of the week as a decimal range 1 to 7, Monday being 1 corresponding to mjd mjd2yday(mjd) The day of the year as a decimal number (range 001 to 366) corresponding to mjd time() returns the time as the number of seconds since the Epoch,\n1970-01-01 00:00:00 +0000 (UTC) eq(x, y, prec) True (= 1) when x == y.\nThe number of digits of comparison can be specified with prec\n(prec == 0 is exact match). neq(x, y, prec) True (= 1) when x != y.\nThe number of digits of comparison can be specified with prec\n(prec == 0 is exact match). ge(x, y, prec) True (= 1) when x >= y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits). gt(x, y, prec) True (= 1) when x > y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits). le(x, y, prec) True (= 1) when x <= y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits). lt(x, y, prec) True (= 1) when x < y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits). not(x) True (= 1) when x == 0 or(x, y) True (= 1) when (x != 0) or (y != 0) and(x, y) True (= 1) when (x != 0) and (y != 0) xor(x, y) True (= 1) when (x != 0) xor (y != 0) size(a) number of elements of array a sort(a) sort elements of array a rsort(a) reverse sort elements of array a pop(a) remove the last element of array a, and returns that element push(a, x) adds new element x to the end of an array a, and returns x shift(a) remove the first element of array a, and returns that element unshift(a, x) adds new element x to the beginning of an array a, returns x array(a, v1, v2, ...) initialize an array a with the rest arguments\nreturn the number of elements of the array array_sum(a) returns the sum of the elements of array a array_sumsq(a) returns the square sum of the elements of array a array_average(a) return the average of the elements of array a array_stdevp(a) return the standard deviation of the elements of array a array_stdev(a) return the corrected sample standard deviation of the elements of array a array_max(a) returns the maximum value contained in array a array_min(a) returns the minimum value contained in array a array_clear(a) set the number of elements of the array a to 0 array_compact(a) Remove non-numeric values from the elements of the array of array a\nand return the number of elements after removal m(i, x) assigns x to the i-th memory (i = 0 to 65535)\nthe index from the tail when i is negative\n(return x) rm(i) the value of the current i-th memory (i = 0 to 65535),\nthe index from the tail when i is negative cm(x, n) initialize n memories from the beginning with x\ninitialize whole memory when n is 0\nand n memories from the end when x is negative\n(return x) am(a) copy the contents of array a to the memory\n(return the number of copied elements) draw_rect(x, y, w, h, stroke, fill) draw a rectangle with (x, y) and (x + w, y + h) as diagonal vertices.\nWhen stroke and fill are 0, do not draw contours and fills respectively. draw_arc(x, y, rx, ry, start, arc, pieslice, stroke, fill, close) draw an arc with the X direction radius rx and the Y direction radius ry centered on (x, y).\nstart and arc specify start angle and arc angle respectively.\nWhen stroke and fill are 0, do not draw contours and fills respectively.\nIf pieslice is not 0, draw a sector.\nIf close is not 0, close the outline. draw_mark(x, y, size) draw a mark on (x, y). The size of a mark can be specified with size.\nWhen size is 0, specification of the file object is used. draw_line(x1, y1, x2, y2) draw a line form (x1, y1) to (x2, y2). draw_polyline(ax, ay) connect coordinates (ax[0], ay[0]), (ax[1], ay[1]), ... by polyline. draw_polygon(ax, ay, stroke, fill) drow polygon defined by coordinates (ax[0], ay[0]), (ax[1], ay[1]), ....\nwhen stroke is 0, do not draw contours.\nfill can be specified with one of\nFILL_RULE_NONE, FILL_RULE_EVEN_ODD or FILL_RULE_WINDING. draw_errorbar(x, y, erx, ery, size) draw errorbars from (x - erx, y) to (x + erx, y) and\nfrom (x, y - ery) to (x, y + ery).\nThe length of ticks can be specified with size.\nWhen size is 0, specification of the file object is used. draw_errorbar2(x1, y1, x2, y2, size) draw an errorbar from (x1, y1) to (x2, y2).\nThe length of ticks can be specified with size.\nWhen size is 0, specification of the file object is used. fit_prm(id, x) When the plot type of the data object whose ID is id is fit,\nthe value of the field "%0x" of the corresponding fit object. fit_calc(id, x) When the plot type of the data object whose ID is id is fit,\nthe corresponding fit result f(x) is calculated. line_number() File line number being processed (1st line is 1) isnormal(x) True if x is a normal number isbreak(x) True if x is BREAK iscont(x) True if x is CONT isnan(x) True if x is NAN isundef(x) True if x is UNDEF sum(x) Integration dif(x) Difference color(i, x) i = 0: Set the R value to x (0 <= x < 256)\ni = 1: Set the G value to x (0 <= x < 256)\ni = 2: Set the B value to x (0 <= x < 256)\ni = 3: Set the R, G and B values to x (0 <= x < 256)\ni = 4: Set the R2 value to x (0 <= x < 256)\ni = 5: Set the G2 value to x (0 <= x < 256)\ni = 6: Set the B2 value to x (0 <= x < 256)\ni = 7: Set the R2, G2 and B2 values to x (0 <= x < 256)\ni = 8: Set the R, G and B values to be hexadecimal color of x\ni = 9: Set the R2, G2 and B2 values to be hexadecimal color of x obj_color(id, obj) Set the R, G, B, R2, G2 and B2 values to the same value as the instance of obj whose ID is id.\nobj is one of DATA_OBJ, PATH_OBJ, ARC_OBJ, MARK_OBJ or TEXT_OBJ. alpha(x, i) Set A (i == 1) or A2 (i == 2) values to x (0 <= x < 256)\nwhen i == 0, set A and A2 values to x obj_alpha(id, obj) Set the A and A2 value to the same value as the instance of obj whose ID is id.\nobj is one of DATA_OBJ, PATH_OBJ, ARC_OBJ, MARK_OBJ or TEXT_OBJ. rgb(r, g, b) Set the R, G and B values of the color to r, g, b (0 <= r, g, b <= 1) rgb2(r, g, b) Set the R2, G2 and B2 values of the color to r, g, b (0 <= r, g, b <= 1) hsb(h, s, b) Set the R, G and B values of the color to h, s, b (0 <= h, s, b <=1) from the HSB value hsb2(h, s, b) Set the R2, G2 and B2 values of the color to h, s, b (0 <= h, s, b <=1) from the HSB value marksize(x) Set mark size to x marktype(x) Set mark type to x if(x, ex1, ex2) evaluate ex1 when x != 0, evaluate ex2 otherwise unless(x, ex1, ex2) evaluate ex2 when x != 0, evaluate ex1 otherwise for(m, begin, end, step, ex) Set the value in step from begin to end to the m-th memory and repeat ex.\nWhen m is negative, no setting to memory is done.\nReturns the value of ex evaluated last. prog1(arg1, arg2, ...) Evaluate the arguments and return the evaluated value of the first argument prog2(arg1, arg2, ...) Evaluate the arguments and return the evaluated value of the second argument progn(arg1, arg2, ...) Evaluate the arguments and return the evaluated value of the last argument ngraph-gtk-6.08.00/src/gtk/gtk_widget.c0000644000175000017500000006325713351432267014543 00000000000000#include #include #include "mathfn.h" #include "object.h" #include "otext.h" #include "gtk_common.h" #include "gtk_widget.h" #include "ox11menu.h" #include "x11menu.h" #include "x11gui.h" #include "dir_defs.h" void set_button_icon(GtkWidget *w, const char *icon_name) { #if ! GTK_CHECK_VERSION(3, 12, 0) GtkWidget *icon; icon = gtk_image_new_from_icon_name(icon_name, GTK_ICON_SIZE_BUTTON); gtk_button_set_image(GTK_BUTTON(w), icon); #endif } void set_widget_margin(GtkWidget *w, int margin_pos) { #if GTK_CHECK_VERSION(3, 12, 0) if (margin_pos & WIDGET_MARGIN_LEFT) { gtk_widget_set_margin_start(w, 4); } if (margin_pos & WIDGET_MARGIN_RIGHT) { gtk_widget_set_margin_end(w, 4); } #else if (margin_pos & WIDGET_MARGIN_LEFT) { gtk_widget_set_margin_left(w, 4); } if (margin_pos & WIDGET_MARGIN_RIGHT) { gtk_widget_set_margin_right(w, 4); } #endif if (margin_pos & WIDGET_MARGIN_BOTTOM) { gtk_widget_set_margin_bottom(w, 4); } if (margin_pos & WIDGET_MARGIN_TOP) { gtk_widget_set_margin_top(w, 4); } } void set_scale_mark(GtkWidget *scale, GtkPositionType pos, int start, int inc) { int max, val; GtkAdjustment *adj; adj = gtk_range_get_adjustment(GTK_RANGE(scale)); max = gtk_adjustment_get_upper(adj); for (val = start; val <=max; val += inc) { gtk_scale_add_mark(GTK_SCALE(scale), val, pos, NULL); } switch (pos) { case GTK_POS_BOTTOM: gtk_scale_set_value_pos(GTK_SCALE(scale), GTK_POS_TOP); break; case GTK_POS_TOP: gtk_scale_set_value_pos(GTK_SCALE(scale), GTK_POS_BOTTOM); break; case GTK_POS_LEFT: gtk_scale_set_value_pos(GTK_SCALE(scale), GTK_POS_RIGHT); break; case GTK_POS_RIGHT: gtk_scale_set_value_pos(GTK_SCALE(scale), GTK_POS_LEFT); break; } } GtkWidget * get_mnemonic_label(GtkWidget *w) { GList *list; GtkWidget *label; if (w == NULL) { return NULL; } list = gtk_widget_list_mnemonic_labels(w); if (list == NULL) { return NULL; } label = GTK_WIDGET(list->data); g_list_free(list); return label; } void set_widget_sensitivity_with_label(GtkWidget *w, gboolean state) { GtkWidget *label; if(w == NULL) { return; } if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_LABEL)) { label = w; w = gtk_label_get_mnemonic_widget(GTK_LABEL(w)); } else { label = get_mnemonic_label(w); } if (w) { gtk_widget_set_sensitive(w, state); } if (label) { gtk_widget_set_sensitive(label, state); } } void set_widget_visibility_with_label(GtkWidget *w, gboolean state) { GtkWidget *label; if(w == NULL) { return; } if (G_TYPE_CHECK_INSTANCE_TYPE(w, GTK_TYPE_LABEL)) { label = w; w = gtk_label_get_mnemonic_widget(GTK_LABEL(w)); } else { label = get_mnemonic_label(w); } if (w) { gtk_widget_set_visible(w, state); } if (label) { gtk_widget_set_visible(label, state); } } GtkWidget * add_widget_to_table_sub(GtkWidget *table, GtkWidget *w, char *title, int expand, int col, int width, int col_max, int n) { GtkWidget *label; label = NULL; if (title) { label = gtk_label_new_with_mnemonic(title); gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); gtk_widget_set_halign(label, GTK_ALIGN_START); g_object_set(label, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), label, col, n, 1, 1); col++; } if (w) { if (expand) { gtk_widget_set_hexpand(w, TRUE); gtk_widget_set_halign(w, GTK_ALIGN_FILL); } else { gtk_widget_set_halign(w, GTK_ALIGN_START); } g_object_set(w, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), w, col, n, width, 1); } return label; } GtkWidget * add_widget_to_table(GtkWidget *table, GtkWidget *w, char *title, int expand, int n) { return add_widget_to_table_sub(table, w, title, expand, 0, (title) ? 1 : 2, 2, n); } GtkWidget * add_copy_button_to_box(GtkWidget *parent_box, GCallback cb, gpointer d, char *obj_name) { GtkWidget *hbox, *w; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = gtk_button_new_with_mnemonic(_("_Copy Settings")); g_signal_connect(w, "map", G_CALLBACK(set_sensitivity_by_check_instance), obj_name); g_signal_connect(w, "clicked", cb, d); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(parent_box), hbox, FALSE, FALSE, 4); return hbox; } GtkWidget * item_setup(GtkWidget *box, GtkWidget *w, char *title, gboolean expand) { GtkWidget *hbox, *label; hbox = gtk_grid_new(); label = gtk_label_new_with_mnemonic(title); gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); g_object_set(label, "margin", GINT_TO_POINTER(2), NULL); g_object_set(w, "margin", GINT_TO_POINTER(2), NULL); if (expand) { gtk_widget_set_hexpand(w, TRUE); gtk_widget_set_halign(w, GTK_ALIGN_FILL); } else { gtk_widget_set_halign(w, GTK_ALIGN_START); } gtk_grid_attach(GTK_GRID(hbox), label, 0, 0, 1, 1); gtk_grid_attach(GTK_GRID(hbox), w, 1, 0, 1, 1); gtk_box_pack_start(GTK_BOX(box), hbox, expand, expand, 4); return label; } int entry_set_filename(GtkWidget *w, char *filename) { gtk_entry_set_text(GTK_ENTRY(w), filename); return 0; } char * entry_get_filename(GtkWidget *w) { const char *utf8filename; utf8filename = gtk_entry_get_text(GTK_ENTRY(w)); if (utf8filename == NULL) { return NULL; } return g_strdup(utf8filename); } GtkWidget * get_parent_window(GtkWidget *w) { GtkWidget *ptr; ptr = w; while (ptr && ! G_TYPE_CHECK_INSTANCE_TYPE(ptr, GTK_TYPE_WINDOW)) { ptr = gtk_widget_get_parent(ptr); } return (ptr) ? ptr : TopLevel; } static void entry_icon_file_select(GtkEntry *w, GtkEntryIconPosition icon_pos, GdkEvent *event, gpointer user_data) { struct objlist *obj; char *file, *ext; obj = (struct objlist *) user_data; if (obj == NULL) return; ext = NULL; if (chkobjfield(obj, "ext") == 0 && chkobjlastinst(obj) >= 0) { getobj(obj, "ext", 0, 0, NULL, &ext); } if (nGetOpenFileName(get_parent_window(GTK_WIDGET(w)), obj->name, ext, NULL, gtk_entry_get_text(w), &file, TRUE, Menulocal.changedirectory) == IDOK && file) { entry_set_filename(GTK_WIDGET(w), file); g_free(file); } } GtkWidget * create_file_entry_with_cb(GCallback cb, gpointer data) { GtkWidget *w; w = create_text_entry(TRUE, TRUE); gtk_entry_set_icon_from_icon_name(GTK_ENTRY(w), GTK_ENTRY_ICON_SECONDARY, "document-open-symbolic"); g_signal_connect(w, "icon-release", cb, data); return w; } GtkWidget * create_file_entry(struct objlist *obj) { return create_file_entry_with_cb(G_CALLBACK(entry_icon_file_select), obj); } static void direction_icon_released(GtkEntry *entry, GtkEntryIconPosition pos, GdkEvent *event, gpointer user_data) { int angle, val, rest; angle = gtk_spin_button_get_value(GTK_SPIN_BUTTON(entry)); val = angle % 360; val += (val < 0) ? 360 : 0; switch (pos) { case GTK_ENTRY_ICON_SECONDARY: if (angle == 360) { val = 0; } else { val -= val % 90; val += 90; } break; case GTK_ENTRY_ICON_PRIMARY: if (angle == 0) { val = 360; } else { rest = val % 90; if (rest == 0) { val -= 90; } else { val -= rest; } } break; } val += (val < 0) ? 360 : 0; gtk_spin_button_set_value(GTK_SPIN_BUTTON(entry), val); } GtkWidget * create_direction_entry(void) { GtkWidget *w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_ANGLE, FALSE, TRUE); gtk_entry_set_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH); #if GTK_CHECK_VERSION(3, 12, 0) gtk_entry_set_max_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH); #endif gtk_entry_set_icon_from_icon_name(GTK_ENTRY(w), GTK_ENTRY_ICON_SECONDARY, "go-up-symbolic"); gtk_entry_set_icon_from_icon_name(GTK_ENTRY(w), GTK_ENTRY_ICON_PRIMARY, "go-down-symbolic"); g_signal_connect(w, "icon-release", G_CALLBACK(direction_icon_released), NULL); return w; } GtkWidget * create_text_entry(int set_default_size, int set_default_action) { GtkWidget *w; w = gtk_entry_new(); if (set_default_size) { gtk_entry_set_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH); } if (set_default_action) { gtk_entry_set_activates_default(GTK_ENTRY(w), TRUE); } return w; } static double int2val(enum SPIN_BUTTON_TYPE type, int ival) { gdouble val; switch (type) { case SPIN_BUTTON_TYPE_WIDTH: case SPIN_BUTTON_TYPE_LENGTH: case SPIN_BUTTON_TYPE_POSITION: case SPIN_BUTTON_TYPE_ANGLE: case SPIN_BUTTON_TYPE_SPACE_POINT: case SPIN_BUTTON_TYPE_POINT: case SPIN_BUTTON_TYPE_PERCENT: val = ival * 0.01; break; case SPIN_BUTTON_TYPE_INT: case SPIN_BUTTON_TYPE_UINT: case SPIN_BUTTON_TYPE_NUM: case SPIN_BUTTON_TYPE_CUSTOM: default: val = ival; } return val; } static int val2int(enum SPIN_BUTTON_TYPE type, double val) { int ival; switch (type) { case SPIN_BUTTON_TYPE_WIDTH: case SPIN_BUTTON_TYPE_LENGTH: case SPIN_BUTTON_TYPE_POSITION: case SPIN_BUTTON_TYPE_ANGLE: case SPIN_BUTTON_TYPE_SPACE_POINT: case SPIN_BUTTON_TYPE_POINT: case SPIN_BUTTON_TYPE_PERCENT: ival = nround(val * 100); break; case SPIN_BUTTON_TYPE_INT: case SPIN_BUTTON_TYPE_UINT: case SPIN_BUTTON_TYPE_NUM: case SPIN_BUTTON_TYPE_CUSTOM: default: ival = val; } return ival; } void spin_entry_set_range(GtkWidget *w, int min, int max) { enum SPIN_BUTTON_TYPE type; type = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); gtk_spin_button_set_range(GTK_SPIN_BUTTON(w), int2val(type, min), int2val(type, max)); } void spin_entry_set_inc(GtkWidget *w, int inc, int page) { enum SPIN_BUTTON_TYPE type; type = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); gtk_spin_button_set_increments(GTK_SPIN_BUTTON(w), int2val(type, inc), int2val(type, page)); } void spin_entry_set_val(GtkWidget *entry, int ival) { gdouble min, max, val; enum SPIN_BUTTON_TYPE type; type = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(entry), "user-data")); val = int2val(type, ival); gtk_spin_button_get_range(GTK_SPIN_BUTTON(entry), &min, &max); if (val < min) { val = min; } else if (val > max) { val = max; } gtk_spin_button_set_value(GTK_SPIN_BUTTON(entry), val); } int spin_entry_get_val(GtkWidget *entry) { gdouble val; enum SPIN_BUTTON_TYPE type; type = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(entry), "user-data")); val = gtk_spin_button_get_value(GTK_SPIN_BUTTON(entry)); return val2int(type, val); } static int spin_change_value_cb(GtkSpinButton *spinbutton, GtkScrollType arg1, gpointer user_data) { const char *str; double oval, val; int ecode; str = gtk_entry_get_text(GTK_ENTRY(spinbutton)); if (str == NULL) return 0; oval = gtk_spin_button_get_value(GTK_SPIN_BUTTON(spinbutton)); ecode = str_calc(str, &val, NULL, NULL); if (ecode || val != val || val == HUGE_VAL || val == - HUGE_VAL) { gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinbutton), oval); return 0; } gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinbutton), val); return 0; } static GtkWidget * _create_spin_entry(enum SPIN_BUTTON_TYPE type, double min, double max, double inc, double page, gboolean numeric, gboolean wrap, int set_default_size, int set_default_action) { GtkWidget *w; w = gtk_spin_button_new_with_range(min, max, inc); gtk_entry_set_alignment(GTK_ENTRY(w), 1.0); gtk_spin_button_set_increments(GTK_SPIN_BUTTON(w), inc, page); gtk_spin_button_set_wrap(GTK_SPIN_BUTTON(w), wrap); gtk_spin_button_set_numeric(GTK_SPIN_BUTTON(w), FALSE); gtk_spin_button_set_digits(GTK_SPIN_BUTTON(w), (numeric) ? 0 : 2); if (set_default_size) { gtk_entry_set_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH); #if GTK_CHECK_VERSION(3, 12, 0) gtk_entry_set_max_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH); #endif } if (set_default_action) { gtk_entry_set_activates_default(GTK_ENTRY(w), TRUE); } g_object_set_data(G_OBJECT(w), "user-data", GINT_TO_POINTER(type)); g_signal_connect(w, "input", G_CALLBACK(spin_change_value_cb), NULL); return w; } GtkWidget * create_spin_entry_type(enum SPIN_BUTTON_TYPE type, int set_default_size, int set_default_action) { double min, max, inc, page = 10; gboolean wrap = FALSE, numeric = FALSE; switch (type) { case SPIN_BUTTON_TYPE_WIDTH: min = 0; max = int2val(type, SPIN_ENTRY_MAX); inc = 0.1; page = 1; break; case SPIN_BUTTON_TYPE_LENGTH: min = 0; max = int2val(type, SPIN_ENTRY_MAX); inc = 1; break; case SPIN_BUTTON_TYPE_POSITION: min = int2val(type, - SPIN_ENTRY_MAX); max = int2val(type, SPIN_ENTRY_MAX); inc = 1; break; case SPIN_BUTTON_TYPE_ANGLE: min = 0; max = 360; inc = 1; page = 15; wrap = TRUE; break; case SPIN_BUTTON_TYPE_SPACE_POINT: min = 0; max = int2val(type, SPIN_ENTRY_MAX); inc = 1; break; case SPIN_BUTTON_TYPE_POINT: min = int2val(type, TEXT_SIZE_MIN); max = int2val(type, SPIN_ENTRY_MAX); inc = 1; break; case SPIN_BUTTON_TYPE_PERCENT: min = 0; max = int2val(type, SPIN_ENTRY_MAX); inc = 1; break; case SPIN_BUTTON_TYPE_INT: min = INT_MIN; max = INT_MAX; inc = 1; numeric = TRUE; break; case SPIN_BUTTON_TYPE_UINT: min = 0; max = INT_MAX; inc = 1; numeric = TRUE; break; case SPIN_BUTTON_TYPE_NUM: min = -1; max = INT_MAX; inc = 1; numeric = TRUE; break; case SPIN_BUTTON_TYPE_NATURAL: min = 1; max = INT_MAX; inc = 1; numeric = TRUE; break; case SPIN_BUTTON_TYPE_CUSTOM: min = INT_MIN; max = INT_MAX; inc = 1; numeric = TRUE; break; default: type = SPIN_BUTTON_TYPE_CUSTOM; min = INT_MIN; max = INT_MAX; inc = 1; numeric = TRUE; } return _create_spin_entry(type, min, max, inc, page, numeric, wrap, set_default_size, set_default_action); } GtkWidget * create_spin_entry(int min, int max, int inc, int set_default_size, int set_default_action) { return _create_spin_entry(SPIN_BUTTON_TYPE_CUSTOM, min, max, inc, inc * 10, TRUE, FALSE, set_default_size, set_default_action); } static void set_custom_palette(GtkWidget *dlg) { int n; struct narray *palette; GdkRGBA *colors; palette = &(Menulocal.custom_palette); n = arraynum(palette); if (n < 1) { return; } colors = arraydata(palette); if (n >= 18) { gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(dlg), GTK_ORIENTATION_HORIZONTAL, 9, n - 9, colors); gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(dlg), GTK_ORIENTATION_HORIZONTAL, 9, 9, colors + (n - 9)); } else { gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(dlg), GTK_ORIENTATION_HORIZONTAL, 9, n - 9, colors); } } static void show_color_sel(GtkWidget *w, gpointer user_data) { GdkRGBA col; char buf[64]; gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(w), &col); snprintf(buf, sizeof(buf), "#%02X%02X%02X", nround(col.red * 255), nround(col.green * 255), nround(col.blue * 255)); gtk_widget_set_tooltip_text(w, buf); } void add_default_color(struct narray *palette) { const gchar *default_colors[9][3] = { { "#ef2929", "#cc0000", "#a40000" }, /* Scarlet Red */ { "#fcaf3e", "#f57900", "#ce5c00" }, /* Orange */ { "#fce94f", "#edd400", "#c4a000" }, /* Butter */ { "#8ae234", "#73d216", "#4e9a06" }, /* Chameleon */ { "#729fcf", "#3465a4", "#204a87" }, /* Sky Blue */ { "#ad7fa8", "#75507b", "#5c3566" }, /* Plum */ { "#e9b96e", "#c17d11", "#8f5902" }, /* Chocolate */ { "#888a85", "#555753", "#2e3436" }, /* Aluminum 1 */ { "#eeeeec", "#d3d7cf", "#babdb6" } /* Aluminum 2 */ }; GdkRGBA color; int i, j; for (j = 0; j < 3; j++) { for (i = 0; i < 9; i++) { gdk_rgba_parse(&color, default_colors[i][j]); arrayadd(palette, &color); } } } void add_default_gray(struct narray *palette) { const gchar *default_grays[9] = { "#000000", /* black */ "#2e3436", /* very dark gray */ "#555753", /* darker gray */ "#888a85", /* dark gray */ "#babdb6", /* medium gray */ "#d3d7cf", /* light gray */ "#eeeeec", /* lighter gray */ "#f3f3f3", /* very light gray */ "#ffffff" /* white */ }; GdkRGBA color; int i; for (i = 0; i < 9; i++) { gdk_rgba_parse(&color, default_grays[i]); arrayadd(palette, &color); } } static void set_default_palette(GtkWidget *cc) { struct narray palette; gint n; arrayinit(&palette, sizeof(GdkRGBA)); add_default_color(&palette); n = arraynum(&palette); gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(cc), GTK_ORIENTATION_HORIZONTAL, 9, n, arraydata(&palette)); arrayclear(&palette); add_default_gray(&palette); n = arraynum(&palette); gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(cc), GTK_ORIENTATION_HORIZONTAL, n, n, arraydata(&palette)); arraydel(&palette); } #define CUSTOM_PALETTE_KEY "custom_palette" static gboolean show_color_dialog(GtkButton *btn, GdkEvent *event, gpointer user_data) { gtk_color_chooser_add_palette(GTK_COLOR_CHOOSER(btn), GTK_ORIENTATION_HORIZONTAL, 0, 0, NULL); if (Menulocal.use_custom_palette) { set_custom_palette(GTK_WIDGET(btn)); } else { set_default_palette(GTK_WIDGET(btn)); } return FALSE; } GtkWidget * create_color_button(GtkWidget *win) { GtkWidget *w; w = gtk_color_button_new(); g_object_set_data(G_OBJECT(w), CUSTOM_PALETTE_KEY, GINT_TO_POINTER(0)); g_signal_connect(w, "color-set", G_CALLBACK(show_color_sel), win); g_signal_connect(w, "button-press-event", G_CALLBACK(show_color_dialog), win); return w; } #if GTK_CHECK_VERSION(3, 16, 0) void set_widget_font(GtkWidget *w, const char *font) { GtkCssProvider *css_provider; GError *error; char *css_str; PangoFontDescription *desc; const char *family, *style_str, *unit; PangoStyle style; PangoWeight weight; int weight_val, size; desc = pango_font_description_from_string(font); if (desc == NULL) { return; } family = pango_font_description_get_family(desc); style = pango_font_description_get_style(desc); size = pango_font_description_get_size(desc); weight = pango_font_description_get_weight(desc); switch (style) { case PANGO_STYLE_NORMAL: style_str = "normal"; break; case PANGO_STYLE_OBLIQUE: style_str = "oblique"; break; case PANGO_STYLE_ITALIC: style_str = "italic"; break; default: style_str = "normal"; break; } switch (weight) { case PANGO_WEIGHT_THIN: weight_val = 100; break; case PANGO_WEIGHT_ULTRALIGHT: weight_val = 200; break; case PANGO_WEIGHT_LIGHT: weight_val = 300; break; case PANGO_WEIGHT_SEMILIGHT: weight_val = 350; break; case PANGO_WEIGHT_BOOK: weight_val = 380; break; case PANGO_WEIGHT_NORMAL: weight_val = 400; break; case PANGO_WEIGHT_MEDIUM: weight_val = 500; break; case PANGO_WEIGHT_SEMIBOLD: weight_val = 600; break; case PANGO_WEIGHT_BOLD: weight_val = 700; break; case PANGO_WEIGHT_ULTRABOLD: weight_val = 800; break; case PANGO_WEIGHT_HEAVY: weight_val = 900; break; case PANGO_WEIGHT_ULTRAHEAVY: weight_val = 1000; break; default: weight_val = 400; break; } if (pango_font_description_get_size_is_absolute(desc)) { unit = "px"; } else { unit = "pt"; } css_str = g_strdup_printf("* {\n" " font-style: %s;\n" " font-weight: %d;\n" " font-size: %d%s;\n" " font-family: \"%s\";\n" "}", style_str, weight_val, size / PANGO_SCALE, unit, family ? family : ""); pango_font_description_free(desc); if (css_str == NULL) { return; } css_provider = gtk_css_provider_new(); if (css_provider == NULL) { return; } error = NULL; gtk_css_provider_load_from_data(css_provider, css_str, -1, &error); g_free(css_str); if (error == NULL) { gtk_style_context_add_provider(gtk_widget_get_style_context(w), GTK_STYLE_PROVIDER(css_provider), GTK_STYLE_PROVIDER_PRIORITY_USER); } } #endif /* ! GTK_CHECK_VERSION(3, 16, 0) */ GtkWidget * create_text_view_with_line_number(GtkWidget **v) { GtkWidget *source_view, *swin; GtkSourceBuffer *buffer; source_view = gtk_source_view_new(); gtk_widget_set_hexpand(source_view, TRUE); gtk_widget_set_vexpand(source_view, TRUE); buffer = gtk_source_buffer_new(NULL); gtk_text_view_set_buffer(GTK_TEXT_VIEW(source_view), GTK_TEXT_BUFFER(buffer)); gtk_text_view_set_editable(GTK_TEXT_VIEW(source_view), FALSE); gtk_source_buffer_set_highlight_syntax(GTK_SOURCE_BUFFER(buffer), FALSE); gtk_source_view_set_show_line_numbers(GTK_SOURCE_VIEW(source_view), TRUE); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), source_view); *v = source_view; return swin; } void text_view_with_line_number_set_text(GtkWidget *view, const gchar *str) { GtkTextBuffer *buf; buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(view)); gtk_text_buffer_set_text(buf, str, -1); } void text_view_with_line_number_set_font(GtkWidget *view, const gchar *font) { #if ! GTK_CHECK_VERSION(3, 16, 0) PangoFontDescription *desc; #endif #if GTK_CHECK_VERSION(3, 16, 0) set_widget_font(view, font); #else /* GTK_CHECK_VERSION(3, 16, 0) */ desc = pango_font_description_from_string(font); gtk_widget_override_font(view, NULL); gtk_widget_override_font(view, desc); #endif /* GTK_CHECK_VERSION(3, 16, 0) */ } enum SELECT_OBJ_COLOR_RESULT select_obj_color(struct objlist *obj, int id, enum OBJ_FIELD_COLOR_TYPE type) { GtkWidget *dlg; int r, g, b, a, rr ,gg, bb, aa, response, modified, undo; GdkRGBA color; char *title; switch (type) { case OBJ_FIELD_COLOR_TYPE_STROKE: title = _("Stroke Color"); getobj(obj, "stroke_R", id, 0, NULL, &r); getobj(obj, "stroke_G", id, 0, NULL, &g); getobj(obj, "stroke_B", id, 0, NULL, &b); getobj(obj, "stroke_A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_FILL: title = _("Fill Color"); getobj(obj, "fill_R", id, 0, NULL, &r); getobj(obj, "fill_G", id, 0, NULL, &g); getobj(obj, "fill_B", id, 0, NULL, &b); getobj(obj, "fill_A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_0: title = _("Color"); getobj(obj, "R", id, 0, NULL, &r); getobj(obj, "G", id, 0, NULL, &g); getobj(obj, "B", id, 0, NULL, &b); getobj(obj, "A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_1: title = _("Color 1"); getobj(obj, "R", id, 0, NULL, &r); getobj(obj, "G", id, 0, NULL, &g); getobj(obj, "B", id, 0, NULL, &b); getobj(obj, "A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_2: title = _("Color 2"); getobj(obj, "R2", id, 0, NULL, &r); getobj(obj, "G2", id, 0, NULL, &g); getobj(obj, "B2", id, 0, NULL, &b); getobj(obj, "A2", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_AXIS_BASE: title = _("Axis baseline color"); getobj(obj, "R", id, 0, NULL, &r); getobj(obj, "G", id, 0, NULL, &g); getobj(obj, "B", id, 0, NULL, &b); getobj(obj, "A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_AXIS_GAUGE: title = _("Axis gauge color"); getobj(obj, "gauge_R", id, 0, NULL, &r); getobj(obj, "gauge_G", id, 0, NULL, &g); getobj(obj, "gauge_B", id, 0, NULL, &b); getobj(obj, "gauge_A", id, 0, NULL, &a); break; case OBJ_FIELD_COLOR_TYPE_AXIS_NUM: title = _("Axis numbering color"); getobj(obj, "num_R", id, 0, NULL, &r); getobj(obj, "num_G", id, 0, NULL, &g); getobj(obj, "num_B", id, 0, NULL, &b); getobj(obj, "num_A", id, 0, NULL, &a); break; default: return SELECT_OBJ_COLOR_ERROR; } if (! Menulocal.use_opacity) { a = 255; } color.red = r / 255.0; color.green = g / 255.0; color.blue = b / 255.0; color.alpha = a / 255.0; dlg = gtk_color_chooser_dialog_new(title, GTK_WINDOW(TopLevel)); if (Menulocal.use_custom_palette) { set_custom_palette(dlg); } gtk_color_chooser_set_rgba(GTK_COLOR_CHOOSER(dlg), &color); gtk_color_chooser_set_use_alpha(GTK_COLOR_CHOOSER(dlg), Menulocal.use_opacity); response = ndialog_run(dlg); gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(dlg), &color); gtk_widget_destroy(dlg); if (response != GTK_RESPONSE_OK) { return SELECT_OBJ_COLOR_CANCEL; } rr = nround(color.red * 255); gg = nround(color.green * 255); bb = nround(color.blue * 255); aa = nround(color.alpha * 255); undo = menu_save_undo_single(UNDO_TYPE_EDIT, obj->name); switch (type) { case OBJ_FIELD_COLOR_TYPE_STROKE: putobj(obj, "stroke_R", id, &rr); putobj(obj, "stroke_G", id, &gg); putobj(obj, "stroke_B", id, &bb); putobj(obj, "stroke_A", id, &aa); break; case OBJ_FIELD_COLOR_TYPE_FILL: putobj(obj, "fill_R", id, &rr); putobj(obj, "fill_G", id, &gg); putobj(obj, "fill_B", id, &bb); putobj(obj, "fill_A", id, &aa); break; case OBJ_FIELD_COLOR_TYPE_0: case OBJ_FIELD_COLOR_TYPE_1: case OBJ_FIELD_COLOR_TYPE_AXIS_BASE: putobj(obj, "R", id, &rr); putobj(obj, "G", id, &gg); putobj(obj, "B", id, &bb); putobj(obj, "A", id, &aa); break; case OBJ_FIELD_COLOR_TYPE_2: putobj(obj, "R2", id, &rr); putobj(obj, "G2", id, &gg); putobj(obj, "B2", id, &bb); putobj(obj, "A2", id, &aa); break; case OBJ_FIELD_COLOR_TYPE_AXIS_GAUGE: putobj(obj, "gauge_R", id, &rr); putobj(obj, "gauge_G", id, &gg); putobj(obj, "gauge_B", id, &bb); putobj(obj, "gauge_A", id, &aa); break; case OBJ_FIELD_COLOR_TYPE_AXIS_NUM: putobj(obj, "num_R", id, &rr); putobj(obj, "num_G", id, &gg); putobj(obj, "num_B", id, &bb); putobj(obj, "num_A", id, &aa); break; default: return SELECT_OBJ_COLOR_ERROR; } if (rr == r && gg == g && bb == b && aa == a) { modified = SELECT_OBJ_COLOR_SAME; menu_delete_undo(undo); } else { modified = SELECT_OBJ_COLOR_DIFFERENT; } return modified; } ngraph-gtk-6.08.00/src/gtk/gtk_subwin.h0000644000175000017500000000651713351432267014570 00000000000000/* * $Id: gtk_subwin.h,v 1.14 2009-07-22 14:53:31 hito Exp $ */ #ifndef _GTK_SUBWIN_HEADER #define _GTK_SUBWIN_HEADER #include "common.h" #include "gtk_liststore.h" #include "object.h" #include "ogra2cairo.h" #include "x11menu.h" #include "ox11menu.h" #define COL_ID 1 typedef void (* list_sub_window_set_val_func) (struct obj_list_data *d, GtkTreeIter *iter, int i); struct subwin_popup_list { char *title; GCallback func; struct subwin_popup_list *submenu; enum pop_up_menu_item_type type; }; GtkWidget *label_sub_window_create(struct SubWin *d); GtkWidget *text_sub_window_create(struct SubWin *d); GtkWidget *list_sub_window_create(struct SubWin *d, int lisu_num, n_list_store *list); GtkWidget *tree_sub_window_create(struct SubWin *d, int page_num, int *lisu_num, n_list_store **list, GtkWidget **icons); void sub_window_set_geometry(struct SubWin *d, int resize); void sub_window_save_geometry(struct SubWin *d); void sub_window_set_visibility(struct SubWin *d, int state); void sub_window_save_visibility(struct SubWin *d); //GtkWidget *sub_window_get_nth_content(struct LegendWin *d, int n); void set_editable_cell_renderer_cb(struct obj_list_data *d, int i, n_list_store *list, GCallback end); void set_combo_cell_renderer_cb(struct obj_list_data *d, int col, n_list_store *list, GCallback start, GCallback end); void set_obj_cell_renderer_cb(struct obj_list_data *d, int col, n_list_store *list, GCallback start); void set_cell_attribute_source(struct SubWin *d, const char *attr, int target_column, int source_column); gboolean list_sub_window_must_rebuild(struct obj_list_data *d); void list_sub_window_build(struct obj_list_data *d, list_sub_window_set_val_func func); void list_sub_window_set(struct obj_list_data *d, list_sub_window_set_val_func func); void list_sub_window_object_name(GtkMenuItem *w, gpointer client_data); void list_sub_window_delete(GtkMenuItem *item, gpointer user_data); void list_sub_window_copy(GtkMenuItem *item, gpointer user_data); void list_sub_window_move_top(GtkMenuItem *item, gpointer user_data); void list_sub_window_move_last(GtkMenuItem *item, gpointer user_data); void list_sub_window_move_up(GtkMenuItem *item, gpointer user_data); void list_sub_window_move_down(GtkMenuItem *item, gpointer user_data); void list_sub_window_update(GtkMenuItem *item, gpointer user_data); void list_sub_window_hide(GtkMenuItem *item, gpointer user_data); void list_sub_window_focus(GtkMenuItem *item, gpointer user_data); void list_sub_window_add_focus(GtkMenuItem *item, gpointer user_data); void tree_sub_window_delete(GtkMenuItem *item, gpointer user_data); void tree_sub_window_copy(GtkMenuItem *item, gpointer user_data); void tree_sub_window_move_top(GtkMenuItem *item, gpointer user_data); void tree_sub_window_move_last(GtkMenuItem *item, gpointer user_data); void tree_sub_window_move_up(GtkMenuItem *item, gpointer user_data); void tree_sub_window_move_down(GtkMenuItem *item, gpointer user_data); void tree_sub_window_update(GtkMenuItem *item, gpointer user_data); void tree_sub_window_hide(GtkMenuItem *item, gpointer user_data); void tree_sub_window_focus(GtkMenuItem *item, gpointer user_data); void tree_sub_window_add_focus(GtkMenuItem *item, gpointer user_data); void update_viewer(struct obj_list_data *d); GtkWidget *sub_win_create_popup_menu(struct obj_list_data *d, int n, struct subwin_popup_list *list, GCallback cb); #endif ngraph-gtk-6.08.00/src/gtk/x11axis.c0000644000175000017500000030244713351432267013706 00000000000000/* * $Id: x11axis.c,v 1.81 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include "object.h" #include "nstring.h" #include "mathfn.h" #include "gra.h" #include "axis.h" #include "gtk_liststore.h" #include "gtk_subwin.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "gtk_presettings.h" #include "x11bitmp.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "ox11menu.h" #include "x11graph.h" #include "x11file.h" #include "x11view.h" #include "x11axis.h" #include "x11commn.h" static n_list_store Alist[] = { {" ", G_TYPE_BOOLEAN, TRUE, TRUE, "hidden"}, {"#", G_TYPE_INT, TRUE, FALSE, "id"}, {N_("name"), G_TYPE_STRING, TRUE, FALSE, "group"}, {N_("min"), G_TYPE_STRING, TRUE, TRUE, "min"}, {N_("max"), G_TYPE_STRING, TRUE, TRUE, "max"}, {N_("inc"), G_TYPE_STRING, TRUE, TRUE, "inc"}, {N_("type"), G_TYPE_PARAM, TRUE, TRUE, "type"}, {"x", G_TYPE_DOUBLE, TRUE, TRUE, "x", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"y", G_TYPE_DOUBLE, TRUE, TRUE, "y", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {N_("dir"), G_TYPE_DOUBLE, TRUE, TRUE, "direction", 0, 36000, 100, 1500}, {N_("len"), G_TYPE_DOUBLE, TRUE, TRUE, "length", - SPIN_ENTRY_MAX, SPIN_ENTRY_MAX, 100, 1000}, {"^#", G_TYPE_INT, TRUE, FALSE, "oid"}, {"num_math", G_TYPE_INT, FALSE, FALSE, "num_math"}, }; enum { AXIS_WIN_COL_HIDDEN, AXIS_WIN_COL_ID, AXIS_WIN_COL_NAME, AXIS_WIN_COL_MIN, AXIS_WIN_COL_MAX, AXIS_WIN_COL_INC, AXIS_WIN_COL_TYPE, AXIS_WIN_COL_X, AXIS_WIN_COL_Y, AXIS_WIN_COL_DIR, AXIS_WIN_COL_LEN, AXIS_WIN_COL_OID, AXIS_WIN_COL_MATH, AXIS_WIN_COL_NUM, }; static void axiswin_scale_clear(GtkMenuItem *item, gpointer user_data); static void axis_delete_popup_func(GtkMenuItem *w, gpointer client_data); static void AxisWinAxisTop(GtkWidget *w, gpointer client_data); static void AxisWinAxisUp(GtkWidget *w, gpointer client_data); static void AxisWinAxisDown(GtkWidget *w, gpointer client_data); static void AxisWinAxisLast(GtkWidget *w, gpointer client_data); static struct subwin_popup_list add_menu_list[] = { {N_("_Frame graph"), G_CALLBACK(CmAxisNewFrame), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Section graph"), G_CALLBACK(CmAxisNewSection), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Cross graph"), G_CALLBACK(CmAxisNewCross), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("Single _Axis"), G_CALLBACK(CmAxisNewSingle), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; static struct subwin_popup_list Popup_list[] = { {N_("_Add"), NULL, add_menu_list, POP_UP_MENU_ITEM_TYPE_MENU}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Duplicate"), G_CALLBACK(list_sub_window_copy), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Delete"), G_CALLBACK(axis_delete_popup_func), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Focus"), G_CALLBACK(list_sub_window_focus), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Clear"), G_CALLBACK(axiswin_scale_clear), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Properties"), G_CALLBACK(list_sub_window_update), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Instance name"), G_CALLBACK(list_sub_window_object_name), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_SEPARATOR}, {N_("_Top"), G_CALLBACK(AxisWinAxisTop), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Up"), G_CALLBACK(AxisWinAxisUp), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Down"), G_CALLBACK(AxisWinAxisDown), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {N_("_Bottom"), G_CALLBACK(AxisWinAxisLast), NULL, POP_UP_MENU_ITEM_TYPE_NORMAL}, {NULL, NULL, NULL, POP_UP_MENU_ITEM_TYPE_END}, }; #define POPUP_ITEM_NUM (sizeof(Popup_list) / sizeof(*Popup_list) - 1) #define POPUP_ITEM_TOP 10 #define POPUP_ITEM_UP 11 #define POPUP_ITEM_DOWN 12 #define POPUP_ITEM_BOTTOM 13 #define TITLE_BUF_SIZE 128 static void axis_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row); static int check_axis_history(struct objlist *obj); #define TIME_FORMAT_STR N_( \ "%a The abbreviated weekday name.\n" \ "%A The full weekday name.\n" \ "%b The abbreviated month name.\n" \ "%B The full month name.\n" \ "%c Equivalent to %a %b %e %T %Y.\n" \ "%C The century number (year/100).\n" \ "%d The day of the month (01 to 31).\n" \ "%e The day of the month (1 to 31).\n" \ "%F Equivalent to %Y-%m-%d.\n" \ "%H The hour (00 to 23).\n" \ "%I The hour (01 to 12).\n" \ "%j The day of the year (001 to 366).\n" \ "%k The hour (0 to 23).\n" \ "%l The hour (1 to 12).\n" \ "%m The month (01 to 12).\n" \ "%M The minute (00 to 59).\n" \ "%n A newline character.\n" \ "%p Either \"AM\" or \"PM\".\n" \ "%P Either \"am\" or \"pm\".\n" \ "%r Equivalent to %I:%M:%S %p.\n" \ "%R Equivalent to %H:%M.\n" \ "%S The second (00 to 60).\n" \ "%T Equivalent to %H:%M:%S.\n" \ "%u The day of the week, Monday being 1 (1 to 7).\n" \ "%w The day of the week, Sunday being 0 (0 to 6).\n" \ "%y The year without a century (00 to 99).\n" \ "%Y The year including the century.\n" \ "%+ Equivalent to %a %b %e %T GMT %Y.\n" \ "%% A literal '%' character.") void axis_scale_push(struct objlist *obj, int id) { int n; exeobj(obj, "scale_push", id, 0, NULL); n = check_axis_history(obj); set_axis_undo_button_sensitivity(n > 0); } char * AxisCB(struct objlist *obj, int id) { char *s, *valstr, *name; int dir; getobj(obj, "direction", id, 0, NULL, &dir); getobj(obj, "group", id, 0, NULL, &name); s = NULL; name = CHK_STR(name); sgetobjfield(obj, id, "type", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { s = g_strdup_printf("%-10s %.6s %s:%.2f", name, _(valstr), _("dir"), dir / 100.0); g_free(valstr); } return s; } char * AxisHistoryCB(struct objlist *obj, int id) { int num; struct narray *array; getobj(obj, "scale_history", id, 0, NULL, &array); num = arraynum(array) / 3; if (num == 0) return NULL; return AxisCB(obj, id); } static char * GridCB(struct objlist *obj, int id) { char *s, *s1, *s2; getobj(obj, "axis_x", id, 0, NULL, &s1); getobj(obj, "axis_y", id, 0, NULL, &s2); s = g_strdup_printf("%.8s %.8s", (s1)? s1: "-----", (s2)? s2: "-----"); return s; } static void bg_button_toggled(GtkToggleButton *button, gpointer user_data) { struct GridDialog *d; gboolean state; d = (struct GridDialog *) user_data; state = gtk_toggle_button_get_active(button); set_widget_sensitivity_with_label(d->bcolor, state); } static void GridDialogSetupItem(GtkWidget *w, struct GridDialog *d, int id) { char *valstr; int i, j; int lastinst; struct objlist *aobj; char *name; aobj = getobject("axis"); lastinst = chkobjlastinst(aobj); combo_box_clear(d->axisx); combo_box_clear(d->axisy); for (j = 0; j <= lastinst; j++) { getobj(aobj, "group", j, 0, NULL, &name); name = CHK_STR(name); combo_box_append_text(d->axisx, name); combo_box_append_text(d->axisy, name); } sgetobjfield(d->Obj, id, "axis_x", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') { i++; } combo_box_entry_set_text(d->axisx, valstr + i); g_free(valstr); } sgetobjfield(d->Obj, id, "axis_y", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') { i++; } combo_box_entry_set_text(d->axisy, valstr + i); g_free(valstr); } SetWidgetFromObjField(d->draw_x, d->Obj, id, "grid_x"); SetWidgetFromObjField(d->draw_y, d->Obj, id, "grid_y"); for (i = 0; i < GRID_DIALOG_STYLE_NUM; i++) { char width[] = "width1", style[] = "style1"; style[sizeof(style) - 2] += i; SetStyleFromObjField(d->style[i], d->Obj, id, style); width[sizeof(width) - 2] += i; SetWidgetFromObjField(d->width[i], d->Obj, id, width); } SetWidgetFromObjField(d->background, d->Obj, id, "background"); bg_button_toggled(GTK_TOGGLE_BUTTON(d->background), d); set_color(d->color, d->Obj, id, NULL); set_color(d->bcolor, d->Obj, id, "B"); } static void grid_copy_clicked(GtkButton *btn, gpointer user_data) { int sel; struct GridDialog *d; d = (struct GridDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, GridCB); if (sel != -1) { GridDialogSetupItem(d->widget, d, sel); } } static void GridDialogAxis(GtkWidget *w, gpointer client_data) { char buf[10]; int a, oid; struct objlist *aobj; aobj = getobject("axis"); a = combo_box_get_active(w); if (a < 0) return; getobj(aobj, "oid", a, 0, NULL, &oid); snprintf(buf, sizeof(buf), "^%d", oid); combo_box_entry_set_text(w, buf); } static void gauge_syle_setup(struct GridDialog *d, GtkWidget *table, int n, int j) { GtkWidget *w; char buf[TITLE_BUF_SIZE]; if (n < 0 || n >= GRID_DIALOG_STYLE_NUM) return; snprintf(buf, sizeof(buf), _("_Style %d:"), n + 1); w = combo_box_entry_create(); add_widget_to_table_sub(table, w, buf, TRUE, 0, 1, 4, j); d->style[n] = w; snprintf(buf, sizeof(buf), _("_Width %d:"), n + 1); w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table_sub(table, w, buf, FALSE, 2, 1, 4, j); d->width[n] = w; } static void GridDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *frame, *w, *hbox, *table; struct GridDialog *d; char title[TITLE_BUF_SIZE]; int i, j; d = (struct GridDialog *) data; snprintf(title, sizeof(title), _("Grid %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); d = (struct GridDialog *) data; if (makewidget) { gtk_dialog_add_button(GTK_DIALOG(wi), _("_Delete"), IDDELETE); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); j = 0; w = combo_box_entry_create(); add_widget_to_table(table, w, _("Axis (_X):"), FALSE, j++); g_signal_connect(w, "changed", G_CALLBACK(GridDialogAxis), NULL); d->axisx = w; w = gtk_check_button_new_with_mnemonic(_("draw _X grid")); add_widget_to_table(table, w, NULL, FALSE, j++); d->draw_x = w; w = combo_box_entry_create(); add_widget_to_table(table, w, _("Axis (_Y):"), FALSE, j++); g_signal_connect(w, "changed", G_CALLBACK(GridDialogAxis), NULL); d->axisy = w; w = gtk_check_button_new_with_mnemonic(_("draw _Y grid")); add_widget_to_table(table, w, NULL, FALSE, j++); d->draw_y = w; frame = gtk_frame_new(_("Axis")); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); j = 0; w = create_color_button(wi); add_widget_to_table(table, w, _("_Color:"), FALSE, j++); d->color = w; w = gtk_check_button_new_with_mnemonic(_("_Background")); add_widget_to_table(table, w, NULL, FALSE, j++); g_signal_connect(w, "toggled", G_CALLBACK(bg_button_toggled), d); d->background = w; w = create_color_button(wi); add_widget_to_table(table, w, _("_Background Color:"), FALSE, j++); d->bcolor = w; frame = gtk_frame_new(_("Color")); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); table = gtk_grid_new(); j = 0; for (i = 0; i < GRID_DIALOG_STYLE_NUM; i++) { gauge_syle_setup(d, table, i, j++); } frame = gtk_frame_new(_("Style")); gtk_container_add(GTK_CONTAINER(frame), table); gtk_box_pack_start(GTK_BOX(d->vbox), frame, FALSE, FALSE, 4); add_copy_button_to_box(GTK_WIDGET(d->vbox), G_CALLBACK(grid_copy_clicked), d, "axisgrid"); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } GridDialogSetupItem(wi, d, d->Id); } static void GridDialogClose(GtkWidget *w, void *data) { struct GridDialog *d; int ret; int i; d = (struct GridDialog *) data; switch (d->ret) { case IDOK: break; default: return; } ret = d->ret; d->ret = IDLOOP; if (SetObjAxisFieldFromWidget(d->axisx, d->Obj, d->Id, "axis_x")) return; if (SetObjAxisFieldFromWidget(d->axisy, d->Obj, d->Id, "axis_y")) return; for (i = 0; i < GRID_DIALOG_STYLE_NUM; i++) { char width[] = "width1", style[] = "style1"; style[sizeof(style) - 2] += i; if (SetObjFieldFromStyle(d->style[i], d->Obj, d->Id, style)) return; width[sizeof(width) - 2] += i; if (SetObjFieldFromWidget(d->width[i], d->Obj, d->Id, width)) return; } if (SetObjFieldFromWidget(d->draw_x, d->Obj, d->Id, "grid_x")) return; if (SetObjFieldFromWidget(d->draw_y, d->Obj, d->Id, "grid_y")) return; if (SetObjFieldFromWidget(d->background, d->Obj, d->Id, "background")) return; if (putobj_color(d->color, d->Obj, d->Id, NULL)) return; if (putobj_color(d->bcolor, d->Obj, d->Id, "B")) return; d->ret = ret; } void GridDialog(struct GridDialog *data, struct objlist *obj, int id) { data->SetupWindow = GridDialogSetup; data->CloseWindow = GridDialogClose; data->Obj = obj; data->Id = id; } static void set_axis_id(GtkWidget *w, int id) { char buf[256]; if (id != -1) { snprintf(buf, sizeof(buf), "id:%d", id); } else { buf[0] = '\0'; } gtk_label_set_text(GTK_LABEL(w), buf); } static void SectionDialogSetupItem(GtkWidget *w, struct SectionDialog *d) { spin_entry_set_val(d->x, d->X); spin_entry_set_val(d->y, d->Y); set_axis_id(d->xid, d->IDX); set_axis_id(d->yid, d->IDY); set_axis_id(d->uid, d->IDU); set_axis_id(d->rid, d->IDR); set_axis_id(d->gid, *(d->IDG)); spin_entry_set_val(d->width, d->LenX); spin_entry_set_val(d->height, d->LenY); } static void SectionDialogAxisX(GtkWidget *w, gpointer client_data) { struct SectionDialog *d; d = (struct SectionDialog *) client_data; if (d->IDX >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDX, -1); DialogExecute(d->widget, &DlgAxis); } } static void SectionDialogAxisY(GtkWidget *w, gpointer client_data) { struct SectionDialog *d; d = (struct SectionDialog *) client_data; if (d->IDY >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDY, -1); DialogExecute(d->widget, &DlgAxis); } } static void SectionDialogAxisU(GtkWidget *w, gpointer client_data) { struct SectionDialog *d; d = (struct SectionDialog *) client_data; if (d->IDU >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDU, -1); DialogExecute(d->widget, &DlgAxis); } } static void SectionDialogAxisR(GtkWidget *w, gpointer client_data) { struct SectionDialog *d; d = (struct SectionDialog *) client_data; if (d->IDR >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDR, -1); DialogExecute(d->widget, &DlgAxis); } } static int axis_save_undo(int type) { char *arg[4]; arg[0] = "axis"; arg[1] = "axisgrid"; arg[2] = "data"; arg[3] = NULL; return menu_save_undo(type, arg); } static void SectionDialogGrid(GtkWidget *w, gpointer client_data) { struct SectionDialog *d; char *ref; int ret, oidx, oidy, create = FALSE, undo = -1; d = (struct SectionDialog *) client_data; if (*(d->IDG) == -1) { undo = axis_save_undo(UNDO_TYPE_DUMMY); if ((*(d->IDG) = newobj(d->Obj2)) >= 0) { getobj(d->Obj, "oid", d->IDX, 0, NULL, &oidx); ref = g_strdup_printf("axis:^%d", oidx); if (ref) { putobj(d->Obj2, "axis_x", *(d->IDG), ref); } getobj(d->Obj, "oid", d->IDY, 0, NULL, &oidy); ref = g_strdup_printf("axis:^%d", oidy); if (ref) { putobj(d->Obj2, "axis_y", *(d->IDG), ref); } create = TRUE; presetting_set_obj_field(d->Obj2, *(d->IDG)); } } if (*(d->IDG) >= 0) { GridDialog(&DlgGrid, d->Obj2, *(d->IDG)); ret = DialogExecute(d->widget, &DlgGrid); switch (ret) { case IDCANCEL: menu_undo_internal(undo); if (create) { *(d->IDG) = -1; } break; case IDDELETE: if (create) { menu_undo_internal(undo); } else { delobj(d->Obj2, *(d->IDG)); set_graph_modified(); } *(d->IDG) = -1; break; default: menu_delete_undo(undo); set_graph_modified(); } } SectionDialogSetupItem(d->widget, d); } static void SectionDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *vbox, *table; struct SectionDialog *d; int i; d = (struct SectionDialog *) data; if (makewidget) { hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("Graph _Width:"), FALSE, i++); d->width = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("Graph _Height:"), FALSE, i++); d->height = w; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_X axis")); g_signal_connect(w, "clicked", G_CALLBACK(SectionDialogAxisX), d); d->xaxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->xid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_Y axis")); g_signal_connect(w, "clicked", G_CALLBACK(SectionDialogAxisY), d); d->yaxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->yid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_U axis")); g_signal_connect(w, "clicked", G_CALLBACK(SectionDialogAxisU), d); d->uaxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->uid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_R axis")); g_signal_connect(w, "clicked", G_CALLBACK(SectionDialogAxisR), d); d->raxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->rid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_Grid")); g_signal_connect(w, "clicked", G_CALLBACK(SectionDialogGrid), d); d->grid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->gid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } SectionDialogSetupItem(wi, d); } static void SectionDialogClose(GtkWidget *w, void *data) { struct SectionDialog *d; int ret; int type; struct narray group; char *argv[2]; d = (struct SectionDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; d->X = spin_entry_get_val(d->x); d->Y = spin_entry_get_val(d->y); d->LenX = spin_entry_get_val(d->width); d->LenY = spin_entry_get_val(d->height); if ((d->X != d->X0) || (d->Y != d->Y0) || (d->LenX0 != d->LenX) || (d->LenY0 != d->LenY)) { arrayinit(&group, sizeof(int)); if (d->Section) type = 2; else type = 1; arrayadd(&group, &type); arrayadd(&group, &(d->IDX)); arrayadd(&group, &(d->IDY)); arrayadd(&group, &(d->IDU)); arrayadd(&group, &(d->IDR)); arrayadd(&group, &(d->X)); arrayadd(&group, &(d->Y)); arrayadd(&group, &(d->LenX)); arrayadd(&group, &(d->LenY)); argv[0] = (char *) &group; argv[1] = NULL; exeobj(d->Obj, "group_position", d->IDX, 1, argv); arraydel(&group); } d->ret = ret; } void SectionDialog(struct SectionDialog *data, int x, int y, int lenx, int leny, struct objlist *obj, int idx, int idy, int idu, int idr, struct objlist *obj2, int *idg, int section) { data->SetupWindow = SectionDialogSetup; data->CloseWindow = SectionDialogClose; data->X0 = data->X = x; data->Y0 = data->Y = y; data->LenX0 = data->LenX = lenx; data->LenY0 = data->LenY = leny; data->Obj = obj; data->Obj2 = obj2; data->IDX = idx; data->IDY = idy; data->IDU = idu; data->IDR = idr; data->IDG = idg; data->Section = section; data->MaxX = Menulocal.PaperWidth * (10000.0 / Menulocal.PaperZoom); data->MaxY = Menulocal.PaperHeight * (10000.0 / Menulocal.PaperZoom); } static void CrossDialogSetupItem(GtkWidget *w, struct CrossDialog *d) { spin_entry_set_val(d->x, d->X); spin_entry_set_val(d->y, d->Y); set_axis_id(d->xid, d->IDX); set_axis_id(d->yid, d->IDY); spin_entry_set_val(d->width, d->LenX); spin_entry_set_val(d->height, d->LenY); } static void CrossDialogAxisX(GtkWidget *w, gpointer client_data) { struct CrossDialog *d; d = (struct CrossDialog *) client_data; if (d->IDX >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDX, -1); DialogExecute(d->widget, &DlgAxis); } } static void CrossDialogAxisY(GtkWidget *w, gpointer client_data) { struct CrossDialog *d; d = (struct CrossDialog *) client_data; if (d->IDY >= 0) { AxisDialog(NgraphApp.AxisWin.data.data, d->IDY, -1); DialogExecute(d->widget, &DlgAxis); } } static void CrossDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *hbox, *vbox, *table; struct CrossDialog *d; int i; d = (struct CrossDialog *) data; if (makewidget) { hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("Graph _Width:"), FALSE, i++); d->width = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("Graph _Height:"), FALSE, i++); d->height = w; gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_X axis")); g_signal_connect(w, "clicked", G_CALLBACK(CrossDialogAxisX), d); d->xaxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->xid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_button_new_with_mnemonic(_("_Y axis")); g_signal_connect(w, "clicked", G_CALLBACK(CrossDialogAxisY), d); d->yaxis = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); w = gtk_label_new(NULL); d->yid = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } CrossDialogSetupItem(wi, d); } static void CrossDialogClose(GtkWidget *w, void *data) { struct CrossDialog *d; int ret; int type; struct narray group; char *argv[2]; d = (struct CrossDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; d->X = spin_entry_get_val(d->x); d->Y = spin_entry_get_val(d->y); d->LenX = spin_entry_get_val(d->width); d->LenY = spin_entry_get_val(d->height); if ((d->X != d->X0) || (d->Y != d->Y0) || (d->LenX != d->LenX0) || (d->LenY != d->LenY0)) { arrayinit(&group, sizeof(int)); type = 3; arrayadd(&group, &type); arrayadd(&group, &(d->IDX)); arrayadd(&group, &(d->IDY)); arrayadd(&group, &(d->X)); arrayadd(&group, &(d->Y)); arrayadd(&group, &(d->LenX)); arrayadd(&group, &(d->LenY)); argv[0] = (char *) &group; argv[1] = NULL; exeobj(d->Obj, "group_position", d->IDX, 1, argv); arraydel(&group); } if ((d->IDX != -1) && (d->IDY != -1)) { exeobj(d->Obj, "adjust", d->IDX, 0, NULL); exeobj(d->Obj, "adjust", d->IDY, 0, NULL); } d->ret = ret; } void CrossDialog(struct CrossDialog *data, int x, int y, int lenx, int leny, struct objlist *obj, int idx, int idy) { data->SetupWindow = CrossDialogSetup; data->CloseWindow = CrossDialogClose; data->X0 = data->X = x; data->Y0 = data->Y = y; data->LenX0 = data->LenX = lenx; data->LenY0 = data->LenY = leny; data->Obj = obj; data->IDX = idx; data->IDY = idy; data->MaxX = Menulocal.PaperWidth * (10000.0 / Menulocal.PaperZoom); data->MaxY = Menulocal.PaperHeight * (10000.0 / Menulocal.PaperZoom); } static void ZoomDialogSetupItem(GtkWidget *w, struct ZoomDialog *d) { spin_entry_set_val(d->zoom_entry, d->zoom); } static void ZoomDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *vbox; struct ZoomDialog *d; d = (struct ZoomDialog *) data; if (makewidget) { vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); item_setup(vbox, w, _("_Zoom:"), TRUE); d->zoom_entry = w; gtk_box_pack_start(GTK_BOX(d->vbox), vbox, FALSE, FALSE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } ZoomDialogSetupItem(wi, d); } static void ZoomDialogClose(GtkWidget *w, void *data) { struct ZoomDialog *d; d = (struct ZoomDialog *) data; if (d->ret != IDOK) return; d->zoom = spin_entry_get_val(d->zoom_entry); } void ZoomDialog(struct ZoomDialog *data) { data->SetupWindow = ZoomDialogSetup; data->CloseWindow = ZoomDialogClose; } static void scale_tab_setup_item(struct AxisDialog *d, int id) { char *valstr; int i, j; double min, max, inc, pmin, pmax, pinc; int lastinst; char *name; struct narray *array; int num; double *data; char buf[30]; combo_box_clear(d->min); combo_box_clear(d->max); combo_box_clear(d->inc); getobj(d->Obj, "min", id, 0, NULL, &min); getobj(d->Obj, "max", id, 0, NULL, &max); getobj(d->Obj, "inc", id, 0, NULL, &inc); getobj(d->Obj, "scale_history", d->Id, 0, NULL, &array); if (array) { pmin = min; pmax = max; pinc = inc; num = arraynum(array) / 3; data = arraydata(array); for (j = 0; j < num; j++) { if (data[0 + j * 3] != pmin) { snprintf(buf, sizeof(buf), "%.15g", data[0 + j * 3]); combo_box_append_text(d->min, buf); } pmin = data[0 + j * 3]; if (data[1 + j * 3] != pmax) { snprintf(buf, sizeof(buf), "%.15g", data[1 + j * 3]); combo_box_append_text(d->max, buf); } pmax = data[1 + j * 3]; if (data[2 + j * 3] != pinc) { snprintf(buf, sizeof(buf), "%.15g", data[2 + j * 3]); combo_box_append_text(d->inc, buf); } pinc = data[2 + j * 3]; } } if ((min == 0) && (max == 0) && (inc == 0)) { combo_box_entry_set_text(d->min, "0"); combo_box_entry_set_text(d->max, "0"); combo_box_entry_set_text(d->inc, "0"); } else { snprintf(buf, sizeof(buf), "%.15g", min); combo_box_entry_set_text(d->min, buf); snprintf(buf, sizeof(buf), "%.15g", max); combo_box_entry_set_text(d->max, buf); snprintf(buf, sizeof(buf), "%.15g", inc); combo_box_entry_set_text(d->inc, buf); } SetWidgetFromObjField(d->div, d->Obj, id, "div"); SetWidgetFromObjField(d->scale, d->Obj, id, "type"); combo_box_clear(d->ref); lastinst = chkobjlastinst(d->Obj); combo_box_append_text(d->ref, _("none")); for (j = 0; j <= lastinst; j++) { getobj(d->Obj, "group", j, 0, NULL, &name); name =CHK_STR(name); combo_box_append_text(d->ref, name); } sgetobjfield(d->Obj, id, "reference", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') { i++; } combo_box_entry_set_text(d->ref, valstr + i); g_free(valstr); } SetWidgetFromObjField(d->margin, d->Obj, id, "auto_scale_margin"); } static void AxisDialogClear(GtkWidget *w, gpointer client_data) { struct AxisDialog *d; d = (struct AxisDialog *) client_data; combo_box_entry_set_text(d->min, "0"); combo_box_entry_set_text(d->max, "0"); combo_box_entry_set_text(d->inc, "0"); } static void AxisDialogFile(GtkWidget *w, gpointer client_data) { struct AxisDialog *d; struct objlist *fobj; struct narray farray; d = (struct AxisDialog *) client_data; fobj = chkobject("data"); if (fobj == NULL) return; if (chkobjlastinst(fobj) == -1) return; SelectDialog(&DlgSelect, fobj, _("autoscale (multi select)"), FileCB, (struct narray *) &farray, NULL); if (DialogExecute(d->widget, &DlgSelect) == IDOK) { int a, i, anum, num, *array; num = arraynum(&farray); array = arraydata(&farray); anum = chkobjlastinst(d->Obj); if (num > 0 && anum != 0) { char *buf, *argv2[2]; GString *str; int type; struct narray *result; str = g_string_sized_new(32); if (str) { g_string_append(str, "file:"); for (i = 0; i < num; i++) { if (i == num - 1) { g_string_append_printf(str, "%d", array[i]); } else { g_string_append_printf(str, "%d,", array[i]); } } buf = g_string_free(str, FALSE); argv2[0] = (char *) buf; argv2[1] = NULL; if (getobj(d->Obj, "type", d->Id, 0, NULL, &type) == -1) { arraydel(&farray); g_free(buf); return; } a = combo_box_get_active(d->scale); if (a >= 0 && (putobj(d->Obj, "type", d->Id, &a) == -1)) { arraydel(&farray); g_free(buf); return; } getobj(d->Obj, "get_auto_scale", d->Id, 1, argv2, &result); g_free(buf); if (arraynum(result) == 3) { char s[30]; snprintf(s, sizeof(s), "%.15g", arraynget_double(result, 0)); combo_box_entry_set_text(d->min, s); snprintf(s, sizeof(s), "%.15g", arraynget_double(result, 1)); combo_box_entry_set_text(d->max, s); snprintf(s, sizeof(s), "%.15g", arraynget_double(result, 2)); combo_box_entry_set_text(d->inc, s); } putobj(d->Obj, "type", d->Id, &type); } } } arraydel(&farray); } static void AxisDialogRef(GtkWidget *w, gpointer client_data) { struct AxisDialog *d; char buf[10]; int a, oid; d = (struct AxisDialog *) client_data; a = combo_box_get_active(w); if (a < 0) { return; } if (a == 0) { combo_box_entry_set_text(w, ""); return; } getobj(d->Obj, "oid", a - 1, 0, NULL, &oid); snprintf(buf, sizeof(buf), "^%d", oid); combo_box_entry_set_text(w, buf); } static void file_button_show(GtkWidget *widget, gpointer user_data) { static struct objlist *file = NULL; int n; if (file == NULL) { file = chkobject("data"); } if (file == NULL) return; n = chkobjlastinst(file); gtk_widget_set_sensitive(widget, n >= 0); } static void scale_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { scale_tab_setup_item(d, sel); } } static GtkWidget * scale_tab_create(struct AxisDialog *d) { GtkWidget *parent_box, *w, *frame, *table, *hbox; int i; table = gtk_grid_new(); i = 0; w = combo_box_entry_create(); add_widget_to_table(table, w, _("_Min:"), TRUE, i++); d->min = w; w = combo_box_entry_create(); add_widget_to_table(table, w, _("_Max:"), TRUE, i++); d->max = w; w = combo_box_entry_create(); add_widget_to_table(table, w, _("_Inc:"), TRUE, i++); d->inc = w; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 12); w = gtk_button_new_with_mnemonic(_("_Clear")); g_signal_connect(w, "clicked", G_CALLBACK(AxisDialogClear), d); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 0); w = gtk_button_new_with_mnemonic(_("_Data")); g_signal_connect(w, "clicked", G_CALLBACK(AxisDialogFile), d); g_signal_connect(w, "map", G_CALLBACK(file_button_show), NULL); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 4); add_widget_to_table(table, hbox, "", FALSE, i++); w = combo_box_create(); add_widget_to_table(table, w, _("_Scale:"), FALSE, i++); d->scale = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Div:"), FALSE, i++); d->div = w; w = combo_box_entry_create(); add_widget_to_table(table, w, _("_Ref:"), FALSE, i++); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); g_signal_connect(w, "changed", G_CALLBACK(AxisDialogRef), d); d->ref = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); add_widget_to_table(table, w, _("_Auto scale margin:"), FALSE, i++); d->margin = w; frame = gtk_frame_new(_("Scale")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); parent_box = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(parent_box), frame, TRUE, TRUE, 4); add_copy_button_to_box(parent_box, G_CALLBACK(scale_tab_copy_clicked), d, "axis"); return parent_box; } static int baseline_tab_set_value(struct AxisDialog *axis) { struct AxisBase *d; d = &axis->base; if (SetObjFieldFromStyle(d->style, axis->Obj, axis->Id, "style")) return 1; if (SetObjFieldFromWidget(d->width, axis->Obj, axis->Id, "width")) return 1; if (SetObjFieldFromWidget(d->baseline, axis->Obj, axis->Id, "baseline")) return 1; if (SetObjFieldFromWidget(d->arrow, axis->Obj, axis->Id, "arrow")) return 1; if (SetObjFieldFromWidget(d->arrowlen, axis->Obj, axis->Id, "arrow_length")) return 1; if (SetObjFieldFromWidget(d->arrowwid, axis->Obj, axis->Id, "arrow_width")) return 1; if (SetObjFieldFromWidget(d->wave, axis->Obj, axis->Id, "wave")) return 1; if (SetObjFieldFromWidget(d->wavelen, axis->Obj, axis->Id, "wave_length")) return 1; if (SetObjFieldFromWidget(d->wavewid, axis->Obj, axis->Id, "wave_width")) return 1; if (putobj_color(d->color, axis->Obj, axis->Id, NULL)) return 1; return 0; } static void baseline_tab_setup_item(struct AxisDialog *axis, int id) { struct AxisBase *d; d = &axis->base; SetStyleFromObjField(d->style, axis->Obj, id, "style"); SetWidgetFromObjField(d->width, axis->Obj, id, "width"); SetWidgetFromObjField(d->baseline, axis->Obj, id, "baseline"); SetWidgetFromObjField(d->arrow, axis->Obj, id, "arrow"); SetWidgetFromObjField(d->arrowlen, axis->Obj, id, "arrow_length"); SetWidgetFromObjField(d->arrowwid, axis->Obj, id, "arrow_width"); SetWidgetFromObjField(d->wave, axis->Obj, id, "wave"); SetWidgetFromObjField(d->wavelen, axis->Obj, id, "wave_length"); SetWidgetFromObjField(d->wavewid, axis->Obj, id, "wave_width"); set_color(d->color, axis->Obj, id, NULL); } static void baseline_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { baseline_tab_setup_item(d, sel); } } static GtkWidget * baseline_tab_create(GtkWidget *wi, struct AxisDialog *dd) { GtkWidget *w, *hbox, *vbox, *frame, *table; struct AxisBase *d; int i; d = &dd->base; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); table = gtk_grid_new(); i = 0; w = gtk_check_button_new_with_mnemonic(_("Draw _Baseline")); add_widget_to_table(table, w, NULL, FALSE , i++); d->baseline = w; w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); add_widget_to_table(table, w, _("Line _Style:"), TRUE, i++); d->style = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Line Width:"), FALSE, i++); d->width = w; w = create_color_button(wi); add_widget_to_table(table, w, _("_Color:"), FALSE, i++); d->color = w; frame = gtk_frame_new(_("Baseline")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); table = gtk_grid_new(); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Position:"), FALSE, i++); d->arrow = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); spin_entry_set_inc(w, 1000, 10000); add_widget_to_table(table, w, _("_Arrow length:"), FALSE, i++); d->arrowlen = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); spin_entry_set_inc(w, 1000, 10000); add_widget_to_table(table, w, _("_Arrow width:"), FALSE, i++); d->arrowwid = w; frame = gtk_frame_new(_("Arrow")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Position:"), FALSE, i++); d->wave = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Wave length:"), FALSE, i++); d->wavelen = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Wave width:"), FALSE, i++); d->wavewid = w; frame = gtk_frame_new(_("Wave")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 0); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(baseline_tab_copy_clicked), dd, "axis"); return vbox; } static int gauge_tab_set_value(struct AxisDialog *axis) { int i; struct AxisGauge *d; d = &axis->gauge; if (SetObjFieldFromWidget(d->gauge, axis->Obj, axis->Id, "gauge")) return 1; if (SetObjFieldFromWidget(d->min, axis->Obj, axis->Id, "gauge_min")) return 1; if (SetObjFieldFromWidget(d->max, axis->Obj, axis->Id, "gauge_max")) return 1; if (SetObjFieldFromStyle(d->style, axis->Obj, axis->Id, "gauge_style")) return 1; for (i = 0; i < GAUGE_STYLE_NUM; i++) { char width[] = "gauge_width1", length[] = "gauge_length1"; width[sizeof(width) - 2] += i; if (SetObjFieldFromWidget(d->width[i], axis->Obj, axis->Id, width)) return 1; length[sizeof(length) - 2] += i; if (SetObjFieldFromWidget(d->length[i], axis->Obj, axis->Id, length)) return 1; } if (putobj_color(d->color, axis->Obj, axis->Id, "gauge_")) return 1; return 0; } static void gauge_tab_setup_item(struct AxisDialog *axis, int id) { int i; struct AxisGauge *d; d = &axis->gauge; SetWidgetFromObjField(d->gauge, axis->Obj, id, "gauge"); SetWidgetFromObjField(d->min, axis->Obj, id, "gauge_min"); SetWidgetFromObjField(d->max, axis->Obj, id, "gauge_max"); SetStyleFromObjField(d->style, axis->Obj, id, "gauge_style"); for (i = 0; i < GAUGE_STYLE_NUM; i++) { char width[] = "gauge_width1", length[] = "gauge_length1"; width[sizeof(width) - 2] += i; SetWidgetFromObjField(d->width[i], axis->Obj, id, width); length[sizeof(length) - 2] += i; SetWidgetFromObjField(d->length[i], axis->Obj, id, length); } set_color(d->color, axis->Obj, id, "gauge_"); } static void gauge_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { gauge_tab_setup_item(d, sel); } } static GtkWidget * gauge_tab_create(GtkWidget *wi, struct AxisDialog *dd) { GtkWidget *parent_box, *w, *vbox, *frame, *table; struct AxisGauge *d; int i, j; char buf[TITLE_BUF_SIZE]; d = &dd->gauge; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); table = gtk_grid_new(); j = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Gauge:"), FALSE, j++); d->gauge = w; w = create_text_entry(FALSE, TRUE); gtk_entry_set_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH * 2); add_widget_to_table(table, w, _("_Min:"), TRUE, j++); d->min = w; w = create_text_entry(FALSE, TRUE); gtk_entry_set_width_chars(GTK_ENTRY(w), NUM_ENTRY_WIDTH * 2); add_widget_to_table(table, w, _("_Max:"), TRUE, j++); d->max = w; frame = gtk_frame_new(_("Range")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); j = 0; w = combo_box_entry_create(); add_widget_to_table_sub(table, w, _("_Style:"), TRUE, 0, 3, 4, j++); d->style = w; w = create_color_button(wi); add_widget_to_table_sub(table, w, _("_Color:"), FALSE, 0, 1, 4, j++); d->color = w; for (i = 0; i < GAUGE_STYLE_NUM; i++) { snprintf(buf, sizeof(buf), _("_Width %d:"), i + 1); w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table_sub(table, w, buf, TRUE, 0, 1, 4, j); d->width[i] = w; snprintf(buf, sizeof(buf), _("_Length %d:"), i + 1); w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table_sub(table, w, buf, TRUE, 2, 1, 4, j++); d->length[i] = w; } frame = gtk_frame_new(_("Style")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); parent_box = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(parent_box), vbox, TRUE, TRUE, 4); add_copy_button_to_box(parent_box, G_CALLBACK(gauge_tab_copy_clicked), dd, "axis"); return parent_box; } static int set_num_format(struct AxisDialog *axis, struct AxisNumbering *d) { GString *format; int a; char *new, *old; format = g_string_new("%"); if (format == NULL) { return 1; } if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->add_plus))) { g_string_append_c(format, '+'); } a = combo_box_get_active(d->fraction); if (a == 0) { g_string_append_c(format, 'g'); } else if (a > 0) { g_string_append_printf(format, ".%df", a - 1); } if (getobj(axis->Obj, "num_format", axis->Id, 0, NULL, &old) == -1) { return 1; } new = g_string_free(format, FALSE); if (g_strcmp0(old, new)) { set_graph_modified(); } if (putobj(axis->Obj, "num_format", axis->Id, new) == -1) { return 1; } if (getobj(axis->Obj, "num_format", axis->Id, 0, NULL, &new) == -1){ return 1; } return 0; } static int numbering_tab_set_value(struct AxisDialog *axis) { struct AxisNumbering *d; d = &axis->numbering; if (SetObjFieldFromWidget(d->num, axis->Obj, axis->Id, "num")) return 1; if (SetObjFieldFromWidget(d->begin, axis->Obj, axis->Id, "num_begin")) return 1; if (SetObjFieldFromWidget(d->step, axis->Obj, axis->Id, "num_step")) return 1; if (SetObjFieldFromWidget(d->numnum, axis->Obj, axis->Id, "num_num")) return 1; if (SetObjFieldFromWidget(d->head, axis->Obj, axis->Id, "num_head")) return 1; if (set_num_format(axis, d)) return 1; if (SetObjFieldFromWidget(d->tail, axis->Obj, axis->Id, "num_tail")) return 1; if (SetObjFieldFromWidget(d->date_format, axis->Obj, axis->Id, "num_date_format")) return 1; if (SetObjFieldFromWidget(d->align, axis->Obj, axis->Id, "num_align")) return 1; if (SetObjFieldFromWidget(d->direction, axis->Obj, axis->Id, "num_direction")) return 1; if (SetObjFieldFromWidget(d->shiftp, axis->Obj, axis->Id, "num_shift_p")) return 1; if (SetObjFieldFromWidget(d->shiftn, axis->Obj, axis->Id, "num_shift_n")) return 1; if (SetObjFieldFromWidget(d->log_power, axis->Obj, axis->Id, "num_log_pow")) return 1; if (SetObjFieldFromWidget(d->no_zero, axis->Obj, axis->Id, "num_no_zero")) return 1; if (SetObjFieldFromWidget(d->norm, axis->Obj, axis->Id, "num_auto_norm")) return 1; if (SetObjFieldFromWidget(d->math, axis->Obj, axis->Id, "num_math")) return 1; return 0; } static void numbering_tab_setup_item(struct AxisDialog *axis, int id) { char *format, *endptr; int j, a; struct AxisNumbering *d; d = &axis->numbering; SetWidgetFromObjField(d->num, axis->Obj, id, "num"); SetWidgetFromObjField(d->begin, axis->Obj, id, "num_begin"); SetWidgetFromObjField(d->step, axis->Obj, id, "num_step"); SetWidgetFromObjField(d->numnum, axis->Obj, id, "num_num"); SetWidgetFromObjField(d->head, axis->Obj, id, "num_head"); combo_box_clear(d->fraction); for (j = 0; j < FwNumStyleNum; j++) { combo_box_append_text(d->fraction, _(FwNumStyle[j])); } getobj(axis->Obj, "num_format", id, 0, NULL, &format); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->add_plus), strchr(format, '+') != NULL); if ((strchr(format, 'f') == NULL) || (strchr(format, '.') == NULL)) { a = 0; } else { a = strtol(strchr(format, '.') + 1, &endptr, 10) + 1; } if (a < 0) { a = 0; } else if (a > 10) { a = 10; } combo_box_set_active(d->fraction, a); SetWidgetFromObjField(d->date_format, axis->Obj, id, "num_date_format"); SetWidgetFromObjField(d->tail, axis->Obj, id, "num_tail"); SetWidgetFromObjField(d->align, axis->Obj, id, "num_align"); SetWidgetFromObjField(d->direction, axis->Obj, id, "num_direction"); SetWidgetFromObjField(d->shiftp, axis->Obj, id, "num_shift_p"); SetWidgetFromObjField(d->shiftn, axis->Obj, id, "num_shift_n"); SetWidgetFromObjField(d->log_power, axis->Obj, id, "num_log_pow"); SetWidgetFromObjField(d->no_zero, axis->Obj, id, "num_no_zero"); SetWidgetFromObjField(d->norm, axis->Obj, id, "num_auto_norm"); SetWidgetFromObjField(d->math, axis->Obj, id, "num_math"); } static void numbering_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { numbering_tab_setup_item(d, sel); } } static void num_direction_changed(GtkWidget *w, gpointer client_data) { int dir, state; struct AxisDialog *d; d = (struct AxisDialog *) client_data; dir = combo_box_get_active(w); state = (dir != AXIS_NUM_POS_OBLIQUE1 && dir != AXIS_NUM_POS_OBLIQUE2); set_widget_sensitivity_with_label(d->numbering.align, state); } static GtkWidget * numbering_tab_create(GtkWidget *wi, struct AxisDialog *dd) { GtkWidget *w, *hbox, *vbox, *frame, *table; struct AxisNumbering *d; int i; d = &dd->numbering; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Numbering:"), FALSE, i++); d->num = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Begin:"), FALSE, i++); d->begin = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Step:"), FALSE, i++); d->step = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_NUM, TRUE, TRUE); add_widget_to_table(table, w, _("_Num:"), FALSE, i++); d->numnum = w; frame = gtk_frame_new(_("Range")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Align:"), FALSE, i++); d->align = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Direction:"), FALSE, i++); g_signal_connect(w, "changed", G_CALLBACK(num_direction_changed), dd); d->direction = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("shift (_P):"), FALSE, i++); d->shiftp = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("shift (_N):"), FALSE, i++); d->shiftn = w; frame = gtk_frame_new(_("Position")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 0); table = gtk_grid_new(); i = 0; w = combo_box_create(); add_widget_to_table(table, w, _("_Fraction:"), FALSE, i++); d->fraction = w; w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_Head:"), TRUE, i++); d->head = w; w = create_text_entry(TRUE, TRUE); add_widget_to_table(table, w, _("_Tail:"), TRUE, i++); d->tail = w; w = create_text_entry(TRUE, TRUE); gtk_widget_set_tooltip_text(w, _(TIME_FORMAT_STR)); add_widget_to_table(table, w, _("_Date/time format:"), TRUE, i++); d->date_format = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Auto normalization:"), FALSE, i++); d->norm = w; w = gtk_check_button_new_with_mnemonic(_("_Log power")); add_widget_to_table(table, w, NULL, FALSE, i++); d->log_power = w; w = gtk_check_button_new_with_mnemonic(_("_Add plus")); d->add_plus = w; add_widget_to_table(table, w, NULL, FALSE, i++); w = combo_box_create(); add_widget_to_table(table, w, _("_Zero:"), FALSE, i++); d->no_zero = w; w = create_text_entry(FALSE, TRUE); add_widget_to_table(table, w, _("numbering _Math:"), TRUE, i++); d->math = w; frame = gtk_frame_new(_("Format")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_RIGHT); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 0); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(numbering_tab_copy_clicked), dd, "axis"); return vbox; } static int font_tab_set_value(struct AxisDialog *axis) { struct AxisFont *d; int style, bold, italic, old_style; d = &axis->font; if (SetObjFieldFromWidget(d->space, axis->Obj, axis->Id, "num_space")) return 1; if (SetObjFieldFromWidget(d->pt, axis->Obj, axis->Id, "num_pt")) return 1; if (SetObjFieldFromWidget(d->script, axis->Obj, axis->Id, "num_script_size")) return 1; SetObjFieldFromFontList(d->font, axis->Obj, axis->Id, "num_font"); if (putobj_color(d->color, axis->Obj, axis->Id, "num_")) return 1; style = 0; bold = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->font_bold)); if (bold) { style |= GRA_FONT_STYLE_BOLD; } italic = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->font_italic)); if (italic) { style |= GRA_FONT_STYLE_ITALIC; } getobj(axis->Obj, "num_font_style", axis->Id, 0, NULL, &old_style); if (old_style != style) { putobj(axis->Obj, "num_font_style", axis->Id, &style); set_graph_modified(); } return 0; } static void font_tab_setup_item(struct AxisDialog *axis, int id) { struct compatible_font_info *compatible; struct AxisFont *d; int style; d = &axis->font; SetWidgetFromObjField(d->space, axis->Obj, id, "num_space"); SetWidgetFromObjField(d->pt, axis->Obj, id, "num_pt"); SetWidgetFromObjField(d->script, axis->Obj, id, "num_script_size"); set_color(d->color, axis->Obj, id, "num_"); compatible = SetFontListFromObj(d->font, axis->Obj, id, "num_font"); if (compatible) { style = compatible->style; } else { getobj(axis->Obj, "num_font_style", axis->Id, 0, NULL, &style); } gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->font_bold), style & GRA_FONT_STYLE_BOLD); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(d->font_italic), style & GRA_FONT_STYLE_ITALIC); } static void font_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { font_tab_setup_item(d, sel); } } static GtkWidget * font_tab_create(GtkWidget *wi, struct AxisDialog *dd) { GtkWidget *w, *vbox, *table, *frame, *btn_box; struct AxisFont *d; int i; d = &dd->font; table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Point:"), FALSE, i++); d->pt = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_SPACE_POINT, TRUE, TRUE); add_widget_to_table(table, w, _("_Space:"), FALSE, i++); d->space = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_PERCENT, TRUE, TRUE); add_widget_to_table(table, w, _("_Script size:"), FALSE, i++); d->script = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Font:"), FALSE, i++); d->font = w; btn_box = gtk_button_box_new(GTK_ORIENTATION_HORIZONTAL); gtk_box_set_spacing(GTK_BOX(btn_box), 10); w = gtk_check_button_new_with_mnemonic(_("_Bold")); set_button_icon(w, "format-text-bold"); d->font_bold = w; gtk_box_pack_start(GTK_BOX(btn_box), w, FALSE, FALSE, 0); w = gtk_check_button_new_with_mnemonic(_("_Italic")); set_button_icon(w, "format-text-italic"); d->font_italic = w; gtk_box_pack_start(GTK_BOX(btn_box), w, FALSE, FALSE, 0); add_widget_to_table(table, btn_box, "", FALSE, i++); w = create_color_button(wi); add_widget_to_table(table, w, _("_Color:"), FALSE, i++); d->color = w; frame = gtk_frame_new(_("Font")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(font_tab_copy_clicked), dd, "axis"); return vbox; } static int position_tab_set_value(struct AxisDialog *axis) { struct AxisPos *d; d = &axis->position; if (SetObjFieldFromWidget(d->x, axis->Obj, axis->Id, "x")) return 1; if (SetObjFieldFromWidget(d->y, axis->Obj, axis->Id, "y")) return 1; if (SetObjFieldFromWidget(d->len, axis->Obj, axis->Id, "length")) return 1; if (SetObjFieldFromWidget(d->direction, axis->Obj, axis->Id, "direction")) return 1; if (SetObjAxisFieldFromWidget(d->adjust, axis->Obj, axis->Id, "adjust_axis")) return 1; if (SetObjFieldFromWidget(d->adjustpos, axis->Obj, axis->Id, "adjust_position")) return 1; return 0; } static void position_tab_setup_item(struct AxisDialog *axis, int id) { char *valstr; int i, j; int lastinst; char *name; struct AxisPos *d; d = &axis->position; SetWidgetFromObjField(d->x, axis->Obj, id, "x"); SetWidgetFromObjField(d->y, axis->Obj, id, "y"); SetWidgetFromObjField(d->len, axis->Obj, id, "length"); SetWidgetFromObjField(d->direction, axis->Obj, id, "direction"); lastinst = chkobjlastinst(axis->Obj); combo_box_clear(d->adjust); combo_box_append_text(d->adjust, _("none")); for (j = 0; j <= lastinst; j++) { getobj(axis->Obj, "group", j, 0, NULL, &name); name = CHK_STR(name); combo_box_append_text(d->adjust, name); } sgetobjfield(axis->Obj, id, "adjust_axis", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { for (i = 0; (valstr[i] != '\0') && (valstr[i] != ':'); i++); if (valstr[i] == ':') i++; combo_box_entry_set_text(d->adjust, valstr + i); g_free(valstr); } SetWidgetFromObjField(d->adjustpos, axis->Obj, id, "adjust_position"); } static void position_tab_copy_clicked(GtkButton *btn, gpointer user_data) { struct AxisDialog *d; int sel; d = (struct AxisDialog *) user_data; sel = CopyClick(d->widget, d->Obj, d->Id, AxisCB); if (sel != -1) { position_tab_setup_item(d, sel); } } static GtkWidget * position_tab_create(GtkWidget *wi, struct AxisDialog *dd) { GtkWidget *w, *vbox, *frame, *table; struct AxisPos *d; int i; d = &dd->position; table = gtk_grid_new(); i = 0; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_X:", FALSE, i++); d->x = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, "_Y:", FALSE, i++); d->y = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_POSITION, TRUE, TRUE); add_widget_to_table(table, w, _("_Length:"), FALSE, i++); d->len = w; w = create_direction_entry(); add_widget_to_table(table, w, _("_Direction:"), FALSE, i++); d->direction = w; w = combo_box_entry_create(); combo_box_entry_set_width(w, NUM_ENTRY_WIDTH); g_signal_connect(w, "changed", G_CALLBACK(AxisDialogRef), dd); add_widget_to_table(table, w, _("_Adjust:"), FALSE, i++); d->adjust = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_UINT, TRUE, TRUE); add_widget_to_table(table, w, _("Adjust _Position:"), FALSE, i++); d->adjustpos = w; frame = gtk_frame_new(_("Position")); gtk_container_add(GTK_CONTAINER(frame), table); set_widget_margin(frame, WIDGET_MARGIN_LEFT | WIDGET_MARGIN_RIGHT); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, 4); add_copy_button_to_box(vbox, G_CALLBACK(position_tab_copy_clicked), dd, "axis"); return vbox; } static void AxisDialogSetup(GtkWidget *wi, void *data, int makewidget) { struct AxisDialog *d; char *group; char title[25]; d = (struct AxisDialog *) data; getobj(d->Obj, "group", d->Id, 0, NULL, &group); group = CHK_STR(group); snprintf(title, sizeof(title), _("Axis %d %s"), d->Id, group); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { GtkWidget *notebook, *w, *label; notebook = gtk_notebook_new(); gtk_notebook_set_scrollable(GTK_NOTEBOOK(notebook), FALSE); w = scale_tab_create(d); label = gtk_label_new_with_mnemonic(_("_Scale")); gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = baseline_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Baseline")); d->base.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = gauge_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Gauge")); d->gauge.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = numbering_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Numbering")); d->numbering.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = font_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Font")); d->font.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); w = position_tab_create(wi, d); label = gtk_label_new_with_mnemonic(_("_Position")); d->position.tab_id = gtk_notebook_append_page(GTK_NOTEBOOK(notebook), w, label); gtk_box_pack_start(GTK_BOX(d->vbox), notebook, TRUE, TRUE, 4); gtk_widget_show_all(GTK_WIDGET(d->vbox)); d->tab = GTK_NOTEBOOK(notebook); } position_tab_setup_item(d, d->Id); font_tab_setup_item(d, d->Id); gauge_tab_setup_item(d, d->Id); numbering_tab_setup_item(d, d->Id); baseline_tab_setup_item(d, d->Id); scale_tab_setup_item(d, d->Id); } static int scale_tab_set_value(struct AxisDialog *d) { axis_scale_push(d->Obj, d->Id); if (SetObjFieldFromWidget(d->min, d->Obj, d->Id, "min")) { return 1; } if (SetObjFieldFromWidget(d->max, d->Obj, d->Id, "max")) { return 1; } if (SetObjFieldFromWidget(d->inc, d->Obj, d->Id, "inc")) { return 1; } if (SetObjFieldFromWidget(d->div, d->Obj, d->Id, "div")) { return 1; } if (SetObjFieldFromWidget(d->scale, d->Obj, d->Id, "type")) { return 1; } if (SetObjAxisFieldFromWidget(d->ref, d->Obj, d->Id, "reference")) { return 1; } if (SetObjFieldFromWidget(d->margin, d->Obj, d->Id, "auto_scale_margin")) { return 1; } return 0; } static void AxisDialogClose(GtkWidget *w, void *data) { struct AxisDialog *d; int ret; d = (struct AxisDialog *) data; switch (d->ret) { case IDOK: break; default: return; } ret = d->ret; d->ret = IDLOOP; if (scale_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, 0); return; } if (font_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, d->font.tab_id); return; } if (numbering_tab_set_value(d)) { gtk_notebook_set_current_page(d->tab, d->numbering.tab_id); return; } if (baseline_tab_set_value(d)){ gtk_notebook_set_current_page(d->tab, d->base.tab_id); return; } if (gauge_tab_set_value(d)){ gtk_notebook_set_current_page(d->tab, d->gauge.tab_id); return; } if (position_tab_set_value(d)){ gtk_notebook_set_current_page(d->tab, d->position.tab_id); return; } d->ret = ret; } void AxisDialog(struct obj_list_data *data, int id, int user_data) { struct AxisDialog *d; d = (struct AxisDialog *) data->dialog; d->SetupWindow = AxisDialogSetup; d->CloseWindow = AxisDialogClose; d->Obj = data->obj; d->Id = id; } void CmAxisNewFrame(void *w, gpointer client_data) { struct objlist *obj, *obj2; int idx, idy, idu, idr, idg, ret; int type, x, y, lenx, leny, undo; struct narray group; char *argv[2]; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if ((obj2 = getobject("axisgrid")) == NULL) return; undo = axis_save_undo(UNDO_TYPE_CREATE); idx = newobj(obj); idy = newobj(obj); idu = newobj(obj); idr = newobj(obj); idg = -1; arrayinit(&group, sizeof(int)); type = 1; x = 3500; y = 22000; lenx = 14000; leny = 14000; arrayadd(&group, &type); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &idu); arrayadd(&group, &idr); arrayadd(&group, &x); arrayadd(&group, &y); arrayadd(&group, &lenx); arrayadd(&group, &leny); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "default_grouping", idr, 1, argv); arraydel(&group); presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); presetting_set_obj_field(obj, idu); presetting_set_obj_field(obj, idr); SectionDialog(&DlgSection, x, y, lenx, leny, obj, idx, idy, idu, idr, obj2, &idg, FALSE); ret = DialogExecute(TopLevel, &DlgSection); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } void CmAxisNewSection(void *w, gpointer client_data) { struct objlist *obj, *obj2; int idx, idy, idu, idr, idg, ret, oidx, oidy, undo; int type, x, y, lenx, leny; struct narray group; char *argv[2]; char *ref; if (Menulock || Globallock) return; if ((obj = getobject("axis")) == NULL) return; if ((obj2 = getobject("axisgrid")) == NULL) return; undo = axis_save_undo(UNDO_TYPE_CREATE); idx = newobj(obj); idy = newobj(obj); idu = newobj(obj); idr = newobj(obj); idg = newobj(obj2); arrayinit(&group, sizeof(int)); type = 2; x = 3500; y = 22000; lenx = 14000; leny = 14000; arrayadd(&group, &type); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &idu); arrayadd(&group, &idr); arrayadd(&group, &x); arrayadd(&group, &y); arrayadd(&group, &lenx); arrayadd(&group, &leny); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "default_grouping", idr, 1, argv); arraydel(&group); if (idg >= 0) { getobj(obj, "oid", idx, 0, NULL, &oidx); ref = g_strdup_printf("axis:^%d", oidx); if (ref) { putobj(obj2, "axis_x", idg, ref); } getobj(obj, "oid", idy, 0, NULL, &oidy); ref = g_strdup_printf("axis:^%d", oidy); if (ref) { putobj(obj2, "axis_y", idg, ref); } } presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); presetting_set_obj_field(obj, idu); presetting_set_obj_field(obj, idr); presetting_set_obj_field(obj2, idg); SectionDialog(&DlgSection, x, y, lenx, leny, obj, idx, idy, idu, idr, obj2, &idg, TRUE); ret = DialogExecute(TopLevel, &DlgSection); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } void CmAxisNewCross(void *w, gpointer client_data) { struct objlist *obj; int idx, idy, ret; int type, x, y, lenx, leny, undo; struct narray group; char *argv[2]; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; undo = axis_save_undo(UNDO_TYPE_CREATE); idx = newobj(obj); idy = newobj(obj); arrayinit(&group, sizeof(int)); type = 3; x = 3500; y = 22000; lenx = 14000; leny = 14000; arrayadd(&group, &type); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &x); arrayadd(&group, &y); arrayadd(&group, &lenx); arrayadd(&group, &leny); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "default_grouping", idy, 1, argv); arraydel(&group); presetting_set_obj_field(obj, idx); presetting_set_obj_field(obj, idy); CrossDialog(&DlgCross, x, y, lenx, leny, obj, idx, idy); ret = DialogExecute(TopLevel, &DlgCross); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } void CmAxisNewSingle(void *w, gpointer client_data) { struct objlist *obj; int id, ret, undo; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; undo = axis_save_undo(UNDO_TYPE_CREATE); if ((id = newobj(obj)) >= 0) { presetting_set_obj_field(obj, id); AxisDialog(NgraphApp.AxisWin.data.data, id, -1); ret = DialogExecute(TopLevel, &DlgAxis); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } } void CmAxisDel(void *w, gpointer client_data) { struct objlist *obj; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if (chkobjlastinst(obj) == -1) return; CopyDialog(&DlgCopy, obj, -1, _("delete axis (single select)"), AxisCB); if (DialogExecute(TopLevel, &DlgCopy) == IDOK && DlgCopy.sel >= 0) { axis_save_undo(UNDO_TYPE_DELETE); AxisDel(DlgCopy.sel); set_graph_modified(); AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); } } void CmAxisUpdate(void *w, gpointer client_data) { struct objlist *obj; int i, ret, undo; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if (chkobjlastinst(obj) == -1) return; CopyDialog(&DlgCopy, obj, -1, _("axis property (single select)"), AxisCB); if (DialogExecute(TopLevel, &DlgCopy) == IDOK) { i = DlgCopy.sel; if (i < 0) return; } else { return; } undo = axis_save_undo(UNDO_TYPE_EDIT); AxisDialog(NgraphApp.AxisWin.data.data, i, -1); ret = DialogExecute(TopLevel, &DlgAxis); if (ret == IDCANCEL) { menu_delete_undo(undo); } else { AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); } } void CmAxisZoom(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i; int *array, num, room; double zoom, min, max, mid, wd; char *argv[4]; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if (chkobjlastinst(obj) == -1) return; ZoomDialog(&DlgZoom); if ((DialogExecute(TopLevel, &DlgZoom) == IDOK) && (DlgZoom.zoom > 0)) { zoom = DlgZoom.zoom / 10000.0; SelectDialog(&DlgSelect, obj, _("scale zoom (multi select)"), AxisCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); array = arraydata(&farray); if (num > 0) { axis_save_undo(UNDO_TYPE_EDIT); } for (i = 0; i < num; i++) { getobj(obj, "min", array[i], 0, NULL, &min); getobj(obj, "max", array[i], 0, NULL, &max); wd = (max - min) / 2; if (wd != 0) { mid = (min + max) / 2; min = mid - wd * zoom; max = mid + wd * zoom; room = 0; argv[0] = (char *) &min; argv[1] = (char *) &max; argv[2] = (char *) &room; argv[3] = NULL; exeobj(obj, "scale", array[i], 3, argv); set_graph_modified(); } } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } arraydel(&farray); } } static void axiswin_scale_clear(GtkMenuItem *item, gpointer user_data) { struct obj_list_data *d; struct objlist *obj; int sel, num; if (Menulock || Globallock) return; obj = chkobject("axis"); if (obj == NULL) return; d = (struct obj_list_data *) user_data; sel = list_store_get_selected_int(d->text, AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { axis_save_undo(UNDO_TYPE_CLEAR_SCALE); d->setup_dialog(d, sel, -1); d->select = sel; axis_scale_push(obj, sel); exeobj(obj, "clear", sel, 0, NULL); set_graph_modified(); d->update(d, FALSE, TRUE); } } void CmAxisClear(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i; int *array, num; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("scale clear (multi select)"), AxisCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); array = arraydata(&farray); if (num > 0) { axis_save_undo(UNDO_TYPE_CLEAR_SCALE); } for (i = 0; i < num; i++) { axis_scale_push(obj, array[i]); exeobj(obj, "clear", array[i], 0, NULL); set_graph_modified(); } AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } arraydel(&farray); } void CmAxisGridNew(void *w, gpointer client_data) { struct objlist *obj; int id, ret, undo; if (Menulock || Globallock) return; if ((obj = chkobject("axisgrid")) == NULL) return; undo = axis_save_undo(UNDO_TYPE_CREATE); id = newobj(obj); if (id < 0) { menu_delete_undo(undo); return; } GridDialog(&DlgGrid, obj, id); ret = DialogExecute(TopLevel, &DlgGrid); if (ret == IDCANCEL) { menu_undo_internal(undo); } else { set_graph_modified(); } } void CmAxisGridDel(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i; int num, *array; if (Menulock || Globallock) return; if ((obj = chkobject("axisgrid")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("delete grid (multi select)"), GridCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); if (num > 0) { axis_save_undo(UNDO_TYPE_DELETE); } array = arraydata(&farray); for (i = num - 1; i >= 0; i--) { delobj(obj, array[i]); set_graph_modified(); } } arraydel(&farray); } void CmAxisGridUpdate(void *w, gpointer client_data) { struct narray farray; struct objlist *obj; int i, j, ret; int *array, num; if (Menulock || Globallock) return; if ((obj = chkobject("axisgrid")) == NULL) return; if (chkobjlastinst(obj) == -1) return; SelectDialog(&DlgSelect, obj, _("grid property (multi select)"), GridCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); if (num > 0) { axis_save_undo(UNDO_TYPE_EDIT); } array = arraydata(&farray); for (i = 0; i < num; i++) { GridDialog(&DlgGrid, obj, array[i]); if ((ret = DialogExecute(TopLevel, &DlgGrid)) == IDDELETE) { delobj(obj, array[i]); set_graph_modified(); for (j = i + 1; j < num; j++) array[j]--; } } } arraydel(&farray); } void AxisWinUpdate(struct obj_list_data *d, int clear, int draw) { char *objects[4]; if (Menulock || Globallock) return; if (d == NULL) return; if (list_sub_window_must_rebuild(d)) { list_sub_window_build(d, axis_list_set_val); } else { list_sub_window_set(d, axis_list_set_val); } if (! clear && d->select >= 0) { list_store_select_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID, d->select); } if (draw) { NgraphApp.Viewer.allclear = TRUE; objects[0] = d->obj->name; objects[1] = "axisgrid"; objects[2] = (draw == DRAW_AXIS_ONLY) ? NULL : NgraphApp.FileWin.data.data->obj->name; objects[3] = NULL; ViewerWinUpdate(objects); } } static void AxisDelCB(struct obj_list_data *data, int id) { AxisDel(id); } static void axis_list_set_val(struct obj_list_data *d, GtkTreeIter *iter, int row) { int cx; unsigned int i; double min, max, inc; char buf[256], *valstr; int style; for (i = 0; i < AXIS_WIN_COL_NUM; i++) { switch (i) { case AXIS_WIN_COL_NAME: getobj(d->obj, "group", row, 0, NULL, &valstr); if (valstr) { list_store_set_string(GTK_WIDGET(d->text), iter, i, valstr); } else { list_store_set_string(GTK_WIDGET(d->text), iter, i, "....."); } break; case AXIS_WIN_COL_MIN: getobj(d->obj, "min", row, 0, NULL, &min); break; case AXIS_WIN_COL_MAX: getobj(d->obj, "max", row, 0, NULL, &max); if ((min == 0) && (max == 0)) { list_store_set_string(GTK_WIDGET(d->text), iter, i - 1, "---------"); list_store_set_string(GTK_WIDGET(d->text), iter, i, "---------"); } else { snprintf(buf, sizeof(buf), "%g", min); list_store_set_string(GTK_WIDGET(d->text), iter, i - 1, buf); snprintf(buf, sizeof(buf), "%g", max); list_store_set_string(GTK_WIDGET(d->text), iter, i, buf); } break; case AXIS_WIN_COL_TYPE: sgetobjfield(d->obj, row, "type", NULL, &valstr, FALSE, FALSE, FALSE); if (valstr) { list_store_set_string(GTK_WIDGET(d->text), iter, i, _(valstr)); g_free(valstr); } break; case AXIS_WIN_COL_INC: getobj(d->obj, "inc", row, 0, NULL, &inc); if (inc == 0) { list_store_set_string(GTK_WIDGET(d->text), iter, i, "---------"); } else { snprintf(buf, sizeof(buf), "%g", inc); list_store_set_string(GTK_WIDGET(d->text), iter, i, buf); } break; case AXIS_WIN_COL_HIDDEN: getobj(d->obj, Alist[i].name, row, 0, NULL, &cx); cx = ! cx; list_store_set_val(GTK_WIDGET(d->text), iter, i, Alist[i].type, &cx); break; case AXIS_WIN_COL_MATH: getobj(d->obj, Alist[i].name, row, 0, NULL, &valstr); if (valstr) { style = PANGO_STYLE_ITALIC; } else { style = PANGO_STYLE_NORMAL; } list_store_set_int(GTK_WIDGET(d->text), iter, i, style); break; default: if (Alist[i].type == G_TYPE_DOUBLE) { getobj(d->obj, Alist[i].name, row, 0, NULL, &cx); list_store_set_double(GTK_WIDGET(d->text), iter, i, cx / 100.0); } else { getobj(d->obj, Alist[i].name, row, 0, NULL, &cx); list_store_set_val(GTK_WIDGET(d->text), iter, i, Alist[i].type, &cx); } } } } static int check_axis_history(struct objlist *obj) { struct narray *array; int num, n, i; n = chkobjlastinst(obj); if (n < 0) return 0; num = 0; for (i = 0; i <= n; i++) { getobj(obj, "scale_history", i, 0, NULL, &array); num += arraynum(array) / 3; } return num; } int axis_check_history(void) { struct objlist *obj; obj = chkobject("axis"); if (obj == NULL) { return FALSE; } return check_axis_history(obj); } void CmAxisScaleUndo(void *w, gpointer client_data) { char *argv[1]; struct objlist *obj; struct narray farray; int i, n, num, *array; if (Menulock || Globallock) return; if ((obj = chkobject("axis")) == NULL) return; if (check_axis_history(obj) == 0) return; SelectDialog(&DlgSelect, obj, _("scale undo (multi select)"), AxisHistoryCB, (struct narray *) &farray, NULL); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { num = arraynum(&farray); if (num > 0) { axis_save_undo(UNDO_TYPE_UNDO_SCALE); } array = arraydata(&farray); for (i = num - 1; i >= 0; i--) { argv[0] = NULL; exeobj(obj, "scale_pop", array[i], 0, argv); set_graph_modified(); } n = check_axis_history(obj); set_axis_undo_button_sensitivity(n > 0); AxisWinUpdate(NgraphApp.AxisWin.data.data, TRUE, TRUE); } arraydel(&farray); } static void popup_show_cb(GtkWidget *widget, gpointer user_data) { unsigned int i; int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) user_data; sel = d->select; num = chkobjlastinst(d->obj); for (i = 1; i < POPUP_ITEM_NUM; i++) { switch (i) { case POPUP_ITEM_TOP: case POPUP_ITEM_UP: gtk_widget_set_sensitive(d->popup_item[i], sel > 0 && sel <= num); break; case POPUP_ITEM_DOWN: case POPUP_ITEM_BOTTOM: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel < num); break; default: gtk_widget_set_sensitive(d->popup_item[i], sel >= 0 && sel <= num); } } } enum CHANGE_DIR { CHANGE_DIR_X, CHANGE_DIR_Y, }; static void pos_edited_common(struct obj_list_data *d, int id, char *str, enum CHANGE_DIR dir) { int x, y, pos1, pos2, man, ecode; double val; char *argv[3]; if (str == NULL || id < 0) { menu_lock(FALSE); return; } switch (dir) { case CHANGE_DIR_X: getobj(d->obj, "x", id, 0, NULL, &pos1); break; case CHANGE_DIR_Y: getobj(d->obj, "y", id, 0, NULL, &pos1); break; } ecode = str_calc(str, &val, NULL, NULL); menu_lock(FALSE); if (ecode || val != val || val == HUGE_VAL || val == - HUGE_VAL) { return; } pos2 = nround(val * 100); if (pos1 == pos2) { return; } switch (dir) { case CHANGE_DIR_X: x = (pos2 - pos1); y = 0; break; case CHANGE_DIR_Y: x = 0; y = (pos2 - pos1); break; } argv[0] = (char *) &x; argv[1] = (char *) &y; argv[2] = NULL; getobj(d->obj, "group_manager", id, 0, NULL, &man); if (man >= 0) { axis_save_undo(UNDO_TYPE_EDIT); exeobj(d->obj, "move", man, 2, argv); set_graph_modified(); AxisWinUpdate(d, TRUE, DRAW_REDRAW); } } static void pos_x_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { struct obj_list_data *d; int sel; d = (struct obj_list_data *) user_data; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); pos_edited_common(d, sel, str, CHANGE_DIR_X); } static void pos_y_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { struct obj_list_data *d; int sel; d = (struct obj_list_data *) user_data; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); pos_edited_common(d, sel, str, CHANGE_DIR_Y); } static void axis_prm_edited_common(struct obj_list_data *d, char *field, gchar *str) { int sel, num; sel = list_store_get_selected_int(GTK_WIDGET(d->text), COL_ID); num = chkobjlastinst(d->obj); if (sel < 0 || sel > num) { menu_lock(FALSE); return; } axis_save_undo(UNDO_TYPE_EDIT); axis_scale_push(d->obj, sel); if (chk_sputobjfield(d->obj, sel, field, str)) { menu_lock(FALSE); return; } menu_lock(FALSE); d->select = sel; d->update(d, FALSE, TRUE); } static void min_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { axis_prm_edited_common((struct obj_list_data *) user_data, "min", str); } static void max_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { axis_prm_edited_common((struct obj_list_data *) user_data, "max", str); } static void inc_edited(GtkCellRenderer *cell_renderer, gchar *path, gchar *str, gpointer user_data) { axis_prm_edited_common((struct obj_list_data *) user_data, "inc", str); } enum AXIS_COMBO_ITEM { AXIS_COMBO_ITEM_SCALE, AXIS_COMBO_ITEM_BASE_DRAW, AXIS_COMBO_ITEM_BASE_COLOR, AXIS_COMBO_ITEM_BASE_STYLE, AXIS_COMBO_ITEM_BASE_ARROW, AXIS_COMBO_ITEM_BASE_WAVE, AXIS_COMBO_ITEM_GAUGE_POS, AXIS_COMBO_ITEM_GAUGE_COLOR, AXIS_COMBO_ITEM_GAUGE_STYLE, AXIS_COMBO_ITEM_NUM_POS, AXIS_COMBO_ITEM_NUM_ALIGN, AXIS_COMBO_ITEM_NUM_DIR, AXIS_COMBO_ITEM_NUM_LOG, AXIS_COMBO_ITEM_NUM_NO_ZERO, AXIS_COMBO_ITEM_NUM_COLOR, AXIS_COMBO_ITEM_NUM_FONT, AXIS_COMBO_ITEM_NUM_BOLD, AXIS_COMBO_ITEM_NUM_ITALIC, }; static void create_base_combo_item(GtkTreeStore *list, GtkTreeIter *parent, struct objlist *obj, int id) { GtkTreeIter iter, child; gtk_tree_store_append(list, &iter, parent); gtk_tree_store_set(list, &iter, OBJECT_COLUMN_TYPE_STRING, _("Baseline"), OBJECT_COLUMN_TYPE_PIXBUF, NULL, OBJECT_COLUMN_TYPE_INT, -1, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, FALSE, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, FALSE, -1); add_bool_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_BASE_DRAW, obj, "baseline", id, _("Draw")); add_line_style_item_to_cbox(list, &iter, AXIS_COMBO_ITEM_BASE_STYLE, obj, "style", id); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Arrow"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_BASE_ARROW, obj, "arrow", id); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Wave"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_BASE_WAVE, obj, "wave", id); add_text_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_BASE_COLOR, -1, _("Color"), TOGGLE_NONE, FALSE); } static void create_gauge_combo_item(GtkTreeStore *list, GtkTreeIter *parent, struct objlist *obj, int id) { GtkTreeIter iter, child; gtk_tree_store_append(list, &iter, parent); gtk_tree_store_set(list, &iter, OBJECT_COLUMN_TYPE_STRING, _("Gauge"), OBJECT_COLUMN_TYPE_PIXBUF, NULL, OBJECT_COLUMN_TYPE_INT, -1, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, FALSE, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, FALSE, -1); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Position"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_GAUGE_POS, obj, "gauge", id); add_line_style_item_to_cbox(list, &iter, AXIS_COMBO_ITEM_GAUGE_STYLE, obj, "gauge_style", id); add_text_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_GAUGE_COLOR, -1, _("Color"), TOGGLE_NONE, FALSE); } static void create_num_combo_item(GtkTreeStore *list, GtkTreeIter *parent, struct objlist *obj, int id) { GtkTreeIter iter, child; gtk_tree_store_append(list, &iter, parent); gtk_tree_store_set(list, &iter, OBJECT_COLUMN_TYPE_STRING, _("Numbering"), OBJECT_COLUMN_TYPE_PIXBUF, NULL, OBJECT_COLUMN_TYPE_INT, -1, OBJECT_COLUMN_TYPE_TOGGLE_VISIBLE, FALSE, OBJECT_COLUMN_TYPE_PIXBUF_VISIBLE, FALSE, -1); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Position"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_POS, obj, "num", id); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Align"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_ALIGN, obj, "num_align", id); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Direction"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_DIR, obj, "num_direction", id); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Font"), TOGGLE_NONE, FALSE); add_font_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_FONT, obj, "num_font", id); add_separator_combo_item_to_cbox(list, NULL, &child); add_font_style_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_BOLD, AXIS_COMBO_ITEM_NUM_ITALIC, obj, "num_font_style", id); add_text_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_NUM_COLOR, -1, _("Color"), TOGGLE_NONE, FALSE); add_bool_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_NUM_LOG, obj, "num_log_pow", id, _("Log power")); add_text_combo_item_to_cbox(list, &child, &iter, -1, -1, _("Zero"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &child, AXIS_COMBO_ITEM_NUM_NO_ZERO, obj, "num_no_zero", id); } static void create_type_combo_box(GtkWidget *cbox, struct objlist *obj, int id) { GtkTreeStore *list; GtkTreeIter iter; list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(cbox))); gtk_tree_store_clear(list); add_text_combo_item_to_cbox(list, &iter, NULL, -1, -1, _("Scale"), TOGGLE_NONE, FALSE); add_enum_combo_item_to_cbox(list, NULL, &iter, AXIS_COMBO_ITEM_SCALE, obj, "type", id); create_base_combo_item(list, NULL, obj, id); create_gauge_combo_item(list, NULL, obj, id); create_num_combo_item(list, NULL, obj, id); } static void select_type(GtkComboBox *w, gpointer user_data) { int sel, col_type, type, enum_id, found, active, style, draw; struct objlist *obj; struct obj_list_data *d; GtkTreeStore *list; GtkTreeIter iter; char *font, *ptr; menu_lock(FALSE); d = (struct obj_list_data *) user_data; sel = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(w), "user-data")); if (sel < 0) return; obj = getobject("axis"); list = GTK_TREE_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(w))); found = gtk_combo_box_get_active_iter(w, &iter); if (! found) return; gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_INT, &col_type, OBJECT_COLUMN_TYPE_ENUM, &enum_id, -1); draw = DRAW_AXIS_ONLY; switch (col_type) { case AXIS_COMBO_ITEM_SCALE: getobj(d->obj, "type", sel, 0, NULL, &type); if (type == enum_id) { return; } draw = DRAW_REDRAW; axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "type", sel, &enum_id); break; case AXIS_COMBO_ITEM_BASE_DRAW: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); axis_save_undo(UNDO_TYPE_EDIT); active = ! active; putobj(d->obj, "baseline", sel, &active); break; case AXIS_COMBO_ITEM_BASE_COLOR: if (select_obj_color(obj, sel, OBJ_FIELD_COLOR_TYPE_AXIS_BASE)) { return; } break; case AXIS_COMBO_ITEM_BASE_STYLE: if (enum_id < 0 || enum_id >= FwNumStyleNum) { return; } axis_save_undo(UNDO_TYPE_EDIT); if (chk_sputobjfield(d->obj, sel, "style", FwLineStyle[enum_id].list) != 0) { return; } if (! get_graph_modified()) { return; } break; case AXIS_COMBO_ITEM_BASE_ARROW: getobj(d->obj, "arrow", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "arrow", sel, &enum_id); break; case AXIS_COMBO_ITEM_BASE_WAVE: getobj(d->obj, "wave", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "wave", sel, &enum_id); break; case AXIS_COMBO_ITEM_GAUGE_POS: getobj(d->obj, "gauge", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "gauge", sel, &enum_id); break; case AXIS_COMBO_ITEM_GAUGE_COLOR: if (select_obj_color(obj, sel, OBJ_FIELD_COLOR_TYPE_AXIS_GAUGE)) { return; } break; case AXIS_COMBO_ITEM_GAUGE_STYLE: if (enum_id < 0 || enum_id >= FwNumStyleNum) { return; } axis_save_undo(UNDO_TYPE_EDIT); if (chk_sputobjfield(d->obj, sel, "gauge_style", FwLineStyle[enum_id].list) != 0) { return; } if (! get_graph_modified()) { return; } break; case AXIS_COMBO_ITEM_NUM_POS: getobj(d->obj, "num", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "num", sel, &enum_id); break; case AXIS_COMBO_ITEM_NUM_ALIGN: getobj(d->obj, "num_align", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "num_align", sel, &enum_id); break; case AXIS_COMBO_ITEM_NUM_DIR: getobj(d->obj, "num_direction", sel, 0, NULL, &type); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "num_direction", sel, &enum_id); break; case AXIS_COMBO_ITEM_NUM_LOG: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); axis_save_undo(UNDO_TYPE_EDIT); active = ! active; putobj(d->obj, "num_log_pow", sel, &active); break; case AXIS_COMBO_ITEM_NUM_NO_ZERO: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); if (type == enum_id) { return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "num_no_zero", sel, &enum_id); break; case AXIS_COMBO_ITEM_NUM_COLOR: if (select_obj_color(obj, sel, OBJ_FIELD_COLOR_TYPE_AXIS_NUM)) { return; } break; case AXIS_COMBO_ITEM_NUM_FONT: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_STRING, &font, -1); getobj(d->obj, "num_font", sel, 0, NULL, &ptr); if (g_strcmp0(font, ptr) == 0) { g_free(font); return; } axis_save_undo(UNDO_TYPE_EDIT); putobj(d->obj, "num_font", sel, font); break; case AXIS_COMBO_ITEM_NUM_BOLD: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "num_font_style", sel, 0, NULL, &type); axis_save_undo(UNDO_TYPE_EDIT); style = (type & GRA_FONT_STYLE_ITALIC) | (active ? 0 : GRA_FONT_STYLE_BOLD); putobj(d->obj, "num_font_style", sel, &style); break; case AXIS_COMBO_ITEM_NUM_ITALIC: gtk_tree_model_get(GTK_TREE_MODEL(list), &iter, OBJECT_COLUMN_TYPE_TOGGLE, &active, -1); getobj(d->obj, "num_font_style", sel, 0, NULL, &type); axis_save_undo(UNDO_TYPE_EDIT); style = (type & GRA_FONT_STYLE_BOLD) | (active ? 0 : GRA_FONT_STYLE_ITALIC); putobj(d->obj, "num_font_style", sel, &style); break; default: return; } d->select = sel; d->update(d, FALSE, draw); set_graph_modified(); } static void start_editing_type(GtkCellRenderer *renderer, GtkCellEditable *editable, gchar *path, gpointer user_data) { GtkTreeIter iter; struct obj_list_data *d; GtkWidget *cbox; int sel; struct objlist *obj; menu_lock(TRUE); d = (struct obj_list_data *) user_data; sel = tree_view_get_selected_row_int_from_path(d->text, path, &iter, AXIS_WIN_COL_ID); if (sel < 0) { return; } cbox = GTK_WIDGET(editable); g_object_set_data(G_OBJECT(cbox), "user-data", GINT_TO_POINTER(sel)); init_object_combo_box(cbox); obj = getobject("axis"); if (obj == NULL) { return; } create_type_combo_box(cbox, obj, sel); g_signal_connect(cbox, "editing-done", G_CALLBACK(select_type), d); gtk_widget_show(cbox); return; } static void axiswin_delete_axis(struct obj_list_data *d) { int sel, num; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { axis_save_undo(UNDO_TYPE_DELETE); AxisDel(sel); AxisWinUpdate(d, TRUE, DRAW_REDRAW); FileWinUpdate(NgraphApp.FileWin.data.data, TRUE, FALSE); set_graph_modified(); d->select = -1; } } static void axis_delete_popup_func(GtkMenuItem *w, gpointer client_data) { struct obj_list_data *d; d = (struct obj_list_data *) client_data; axiswin_delete_axis(d); } static void AxisWinAxisTop(GtkWidget *w, gpointer client_data) { int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) client_data; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { axis_save_undo(UNDO_TYPE_ORDER); movetopobj(d->obj, sel); d->select = 0; AxisMove(sel,0); AxisWinUpdate(d, FALSE, FALSE); FileWinUpdate(NgraphApp.FileWin.data.data, FALSE, FALSE); set_graph_modified(); } } static void AxisWinAxisLast(GtkWidget *w, gpointer client_data) { int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) client_data; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 0) && (sel <= num)) { axis_save_undo(UNDO_TYPE_ORDER); movelastobj(d->obj, sel); d->select = num; AxisMove(sel, num); AxisWinUpdate(d, FALSE, FALSE); FileWinUpdate(NgraphApp.FileWin.data.data, FALSE, FALSE); set_graph_modified(); } } static void AxisWinAxisUp(GtkWidget *w, gpointer client_data) { int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) client_data; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if ((sel >= 1) && (sel <= num)) { axis_save_undo(UNDO_TYPE_ORDER); moveupobj(d->obj, sel); d->select = sel - 1; AxisMove(sel, sel - 1); AxisWinUpdate(d, FALSE, FALSE); FileWinUpdate(NgraphApp.FileWin.data.data, FALSE, FALSE); set_graph_modified(); } } static void AxisWinAxisDown(GtkWidget *w, gpointer client_data) { int sel, num; struct obj_list_data *d; d = (struct obj_list_data *) client_data; if (Menulock || Globallock) return; UnFocus(); sel = list_store_get_selected_int(GTK_WIDGET(d->text), AXIS_WIN_COL_ID); num = chkobjlastinst(d->obj); if (sel >= 0 && sel <= num-1) { axis_save_undo(UNDO_TYPE_ORDER); movedownobj(d->obj, sel); d->select = sel + 1; AxisMove(sel, sel + 1); AxisWinUpdate(d, FALSE, FALSE); FileWinUpdate(NgraphApp.FileWin.data.data, FALSE, FALSE); set_graph_modified(); } } static gboolean axiswin_ev_key_down(GtkWidget *w, GdkEvent *event, gpointer user_data) { struct obj_list_data *d; GdkEventKey *e; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); if (Menulock || Globallock) return TRUE; d = (struct obj_list_data *) user_data; e = (GdkEventKey *)event; switch (e->keyval) { case GDK_KEY_Delete: axiswin_delete_axis(d); break; case GDK_KEY_Home: if (e->state & GDK_SHIFT_MASK) { AxisWinAxisTop(w, d); } else { return FALSE; } break; case GDK_KEY_End: if (e->state & GDK_SHIFT_MASK) { AxisWinAxisLast(w, d); } else { return FALSE; } break; case GDK_KEY_Up: if (e->state & GDK_SHIFT_MASK) { AxisWinAxisUp(w, d); } else { return FALSE; } break; case GDK_KEY_Down: if (e->state & GDK_SHIFT_MASK) { AxisWinAxisDown(w, d); } else { return FALSE; } break; default: return FALSE; } return TRUE; } GtkWidget * dreate_axis_list(struct SubWin *d) { if (d->Win) { return d->Win; } list_sub_window_create(d, AXIS_WIN_COL_NUM, Alist); d->data.data->update = AxisWinUpdate; d->data.data->setup_dialog = AxisDialog; d->data.data->dialog = &DlgAxis; d->data.data->ev_key = axiswin_ev_key_down; d->data.data->delete = AxisDelCB; d->data.data->obj = chkobject("axis"); sub_win_create_popup_menu(d->data.data, POPUP_ITEM_NUM, Popup_list, G_CALLBACK(popup_show_cb)); set_editable_cell_renderer_cb(d->data.data, AXIS_WIN_COL_X, Alist, G_CALLBACK(pos_x_edited)); set_editable_cell_renderer_cb(d->data.data, AXIS_WIN_COL_Y, Alist, G_CALLBACK(pos_y_edited)); set_editable_cell_renderer_cb(d->data.data, AXIS_WIN_COL_MIN, Alist, G_CALLBACK(min_edited)); set_editable_cell_renderer_cb(d->data.data, AXIS_WIN_COL_MAX, Alist, G_CALLBACK(max_edited)); set_editable_cell_renderer_cb(d->data.data, AXIS_WIN_COL_INC, Alist, G_CALLBACK(inc_edited)); set_cell_attribute_source(d, "style", AXIS_WIN_COL_NAME, AXIS_WIN_COL_MATH); set_cell_attribute_source(d, "style", AXIS_WIN_COL_MIN, AXIS_WIN_COL_MATH); set_cell_attribute_source(d, "style", AXIS_WIN_COL_MAX, AXIS_WIN_COL_MATH); set_cell_attribute_source(d, "style", AXIS_WIN_COL_INC, AXIS_WIN_COL_MATH); set_combo_cell_renderer_cb(d->data.data, AXIS_WIN_COL_TYPE, Alist, G_CALLBACK(start_editing_type), NULL); list_store_set_align(GTK_WIDGET(d->data.data->text), AXIS_WIN_COL_MIN, 1.0); list_store_set_align(GTK_WIDGET(d->data.data->text), AXIS_WIN_COL_MAX, 1.0); list_store_set_align(GTK_WIDGET(d->data.data->text), AXIS_WIN_COL_INC, 1.0); gtk_tree_view_set_enable_search(GTK_TREE_VIEW(d->data.data->text), TRUE); gtk_tree_view_set_search_column(GTK_TREE_VIEW(d->data.data->text), AXIS_WIN_COL_NAME); tree_view_set_tooltip_column(GTK_TREE_VIEW(d->data.data->text), AXIS_WIN_COL_NAME); return d->Win; } ngraph-gtk-6.08.00/src/gtk/ogra2cairo.c0000644000175000017500000010616713150526720014434 00000000000000/* * $Id: ogra2cairo.c,v 1.58 2010-03-04 08:30:17 hito Exp $ */ #include "gtk_common.h" #include #include #include #include #include #include #include #include "mathfn.h" #include "object.h" #include "gra.h" #include "init.h" #include "nstring.h" #include "object.h" #include "ioutil.h" #include "nconfig.h" #include "strconv.h" #include "x11gui.h" #include "ogra2cairo.h" #define NAME "gra2cairo" #define PARENT "gra2" #define OVERSION "1.00.00" #define CAIROCONF "[gra2cairo]" #define DEFAULT_FONT "Sans-serif" #ifndef M_PI #define M_PI 3.141592 #endif char **Gra2CairoErrMsgs = NULL; int Gra2CairoErrMsgNum = 0; int OldConfigExist = FALSE; /* for backward compatibility */ char *gra2cairo_antialias_type[] = { N_("none"), N_("default"), N_("gray"), // N_("subpixel"), NULL, }; struct gra2cairo_config *Gra2cairoConf = NULL; static int Instance = 0; static NHASH CompatibleFontHash = NULL; static struct compatible_font_info CompatibleFont[] = { {"Times", GRA_FONT_STYLE_NORMAL, FALSE, "Serif"}, {"TimesBold", GRA_FONT_STYLE_BOLD, FALSE, "Serif"}, {"TimesItalic", GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"TimesBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"Helvetica", GRA_FONT_STYLE_NORMAL, FALSE, "Sans-serif"}, {"HelveticaBold", GRA_FONT_STYLE_BOLD, FALSE, "Sans-serif"}, {"HelveticaOblique", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelveticaItalic", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelveticaBoldOblique", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelveticaBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"Courier", GRA_FONT_STYLE_NORMAL, FALSE, "Monospace"}, {"CourierBold", GRA_FONT_STYLE_BOLD, FALSE, "Monospace"}, {"CourierOblique", GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourierItalic", GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourierBoldOblique", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourierBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"Symbol", GRA_FONT_STYLE_NORMAL, TRUE, "Serif"}, {"SymbolBold", GRA_FONT_STYLE_BOLD, TRUE, "Serif"}, {"SymbolItalic", GRA_FONT_STYLE_ITALIC, TRUE, "Serif"}, {"SymbolBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, TRUE, "Serif"}, {"Mincho", GRA_FONT_STYLE_NORMAL, FALSE, "Serif"}, {"MinchoBold", GRA_FONT_STYLE_BOLD, FALSE, "Serif"}, {"MinchoItalic", GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"MinchoBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"Gothic", GRA_FONT_STYLE_NORMAL, FALSE, "Sans-serif"}, {"GothicBold", GRA_FONT_STYLE_BOLD, FALSE, "Sans-serif"}, {"GothicItalic", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"GothicBoldItalic", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"Tim", GRA_FONT_STYLE_NORMAL, FALSE, "Serif"}, {"TimB", GRA_FONT_STYLE_BOLD, FALSE, "Serif"}, {"TimI", GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"TimBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"Helv", GRA_FONT_STYLE_NORMAL, FALSE, "Sans-serif"}, {"HelvB", GRA_FONT_STYLE_BOLD, FALSE, "Sans-serif"}, {"HelvO", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelvI", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelvBO", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"HelvBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"Cour", GRA_FONT_STYLE_NORMAL, FALSE, "Monospace"}, {"CourB", GRA_FONT_STYLE_BOLD, FALSE, "Monospace"}, {"CourO", GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourI", GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourBO", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"CourBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Monospace"}, {"Sym", GRA_FONT_STYLE_NORMAL, TRUE, "Serif"}, {"SymB", GRA_FONT_STYLE_BOLD, TRUE, "Serif"}, {"SymI", GRA_FONT_STYLE_ITALIC, TRUE, "Serif"}, {"SymBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, TRUE, "Serif"}, {"Min", GRA_FONT_STYLE_NORMAL, FALSE, "Serif"}, {"MinB", GRA_FONT_STYLE_BOLD, FALSE, "Serif"}, {"MinI", GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"MinBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Serif"}, {"Goth", GRA_FONT_STYLE_NORMAL, FALSE, "Sans-serif"}, {"GothB", GRA_FONT_STYLE_BOLD, FALSE, "Sans-serif"}, {"GothI", GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, {"GothBI", GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC, FALSE, "Sans-serif"}, }; #define FONT_FACE_NUM ((int) (sizeof(FontFaceStr) / sizeof(*FontFaceStr))) static int mxp2dw(struct gra2cairo_local *local, int r) { return ceil(r / local->pixel_dot_x); } static double mxd2pw(struct gra2cairo_local *local, int r) { return r * local->pixel_dot_x; } static int mxp2dh(struct gra2cairo_local *local, int r) { return ceil(r / local->pixel_dot_y); } static double mxd2ph(struct gra2cairo_local *local, int r) { return r * local->pixel_dot_y; } static double mxd2px(struct gra2cairo_local *local, int x) { return x * local->pixel_dot_x + local->offsetx; } static double mxd2py(struct gra2cairo_local *local, int y) { return y * local->pixel_dot_y + local->offsety; } static void free_font_map(struct fontmap *fcur) { struct fontmap *cur, *prev; if (fcur == NULL) return; if (fcur->font) { pango_font_description_free(fcur->font); } g_free(fcur->fontalias); g_free(fcur->fontname); g_free(fcur->alternative); prev = NULL; cur = Gra2cairoConf->fontmap_list_root; while (cur) { if (cur == fcur) { if (prev == NULL) { Gra2cairoConf->fontmap_list_root = cur->next; } else { prev->next = cur->next; } break; } prev = cur; cur = cur->next; } g_free(fcur); } static void add_font_map(struct fontmap *fmap) { struct fontmap *cur; if (Gra2cairoConf->fontmap_list_root == NULL) { Gra2cairoConf->fontmap_list_root = fmap; return; } cur = Gra2cairoConf->fontmap_list_root; while (cur->next) { cur = cur->next; } cur->next = fmap; } static struct fontmap * create_font_map(const char *fontalias, const char *fontname, const char *alternative) { struct fontmap *fnew; if (Gra2cairoConf->fontmap == NULL) return NULL; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fnew) == 0) { free_font_map(fnew); } fnew = g_malloc(sizeof(struct fontmap)); if (fnew == NULL) { return NULL; } if (nhash_set_ptr(Gra2cairoConf->fontmap, fontalias, fnew)) { g_free(fnew); return NULL; } fnew->fontalias = g_strdup(fontalias); fnew->fontname = g_strdup(fontname); fnew->alternative = g_strdup(alternative); fnew->font = NULL; fnew->next = NULL; add_font_map(fnew); Gra2cairoConf->font_num++; return fnew; } void gra2cairo_save_config(void) { char *buf; struct fontmap *fcur; struct narray conf; arrayinit(&conf, sizeof(char *)); if (gra2cairo_get_fontmap_num() == 0) { buf = g_strdup("font"); if (buf) { arrayadd(&conf, &buf); removeconfig(CAIROCONF, &conf); } } else { fcur = Gra2cairoConf->fontmap_list_root; while (fcur) { buf = g_strdup_printf("font=%s,%s%s%s", fcur->fontalias, fcur->fontname, (fcur->alternative) ? "," : "", CHK_STR(fcur->alternative)); if (buf) { arrayadd(&conf, &buf); } fcur = fcur->next; } replaceconfig(CAIROCONF, &conf); } /* for backward compatibility */ if (OldConfigExist) { buf = g_strdup("font_map"); if (buf) { arrayadd(&conf, &buf); removeconfig(CAIROCONF, &conf); } OldConfigExist = FALSE; } arraydel2(&conf); } static int loadconfig(void) { FILE *fp; char *tok, *str, *s2; char *f1, *f2, *f3; int len; struct fontmap *fnew; fp = openconfig(CAIROCONF); if (fp == NULL) return 0; while ((tok = getconfig(fp, &str))) { s2 = str; if (strcmp(tok, "font") == 0) { f1 = getitok2(&s2, &len, ","); f2 = getitok2(&s2, &len, ","); for (; (s2[0] != '\0') && (strchr(" \x09,", s2[0])); s2++); f3 = getitok2(&s2, &len, ""); if (f1 && f2) { fnew = create_font_map(f1, f2, f3); g_free(f1); g_free(f2); if (fnew == NULL) { g_free(tok); closeconfig(fp); return 1; } } else { g_free(f1); g_free(f2); } g_free(f3); } else if (strcmp(tok, "font_map") == 0) { /* for backward compatibility */ char *f4, *endptr; int two_byte; OldConfigExist = TRUE; f1 = getitok2(&s2, &len, " \t,"); f3 = getitok2(&s2, &len, " \t,"); f4 = getitok2(&s2, &len, " \t,"); two_byte = strtol(f4, &endptr, 10); g_free(f3); g_free(f4); for (; (s2[0] != '\0') && (strchr(" \x09,", s2[0])); s2++); f2 = getitok2(&s2, &len, ""); fnew = NULL; if (f1 && f2) { struct compatible_font_info *info; struct fontmap *tmp; info = gra2cairo_get_compatible_font_info(f1); if (info) { if (nhash_get_ptr(Gra2cairoConf->fontmap, info->name, (void *) &tmp)) { g_free(f1); f1 = g_strdup(info->name); if (f1) { fnew = create_font_map(f1, f2, NULL); } if (fnew == NULL) { g_free(tok); g_free(f1); g_free(f2); closeconfig(fp); return 1; } } else { if (two_byte) { gra2cairo_set_alternative_font(info->name, f2); } } } } g_free(f1); g_free(f2); } else { fprintf(stderr, "(%s): configuration '%s' in section %s is not used.\n", AppName,tok, CAIROCONF); } g_free(tok); g_free(str); } closeconfig(fp); return 0; } static int free_fonts_sub(struct nhash *h, void *d) { struct fontmap *fcur; fcur = (struct fontmap *) h->val.p; free_font_map(fcur); return 0; } static void free_fonts(struct gra2cairo_config *conf) { nhash_each(conf->fontmap, free_fonts_sub, NULL); conf->font_num = 0; } static int init_conf(void) { Gra2cairoConf = g_malloc(sizeof(*Gra2cairoConf)); if (Gra2cairoConf == NULL) return 1; Gra2cairoConf->fontmap = nhash_new(); if (Gra2cairoConf->fontmap == NULL) { g_free(Gra2cairoConf); Gra2cairoConf = NULL; return 1; } Gra2cairoConf->fontmap_list_root = NULL; Gra2cairoConf->font_num = 0; if (loadconfig()) { free_fonts(Gra2cairoConf); nhash_free(Gra2cairoConf->fontmap); g_free(Gra2cairoConf); Gra2cairoConf = NULL; return 1; } return 0; } static void free_conf(void) { if (Gra2cairoConf == NULL) return; free_fonts(Gra2cairoConf); nhash_free(Gra2cairoConf->fontmap); g_free(Gra2cairoConf); Gra2cairoConf = NULL; } struct fontmap * gra2cairo_get_fontmap(const char *fontalias) { struct fontmap *fnew; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fnew)) { return NULL; } return fnew; } int gra2cairo_get_fontmap_num(void) { int n = 0; if (Gra2cairoConf->fontmap) { n = nhash_num(Gra2cairoConf->fontmap); } return n; } void gra2cairo_remove_fontmap(const char *fontalias) { struct fontmap *fnew; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fnew) == 0) { free_font_map(fnew); nhash_del(Gra2cairoConf->fontmap, fontalias); } } void gra2cairo_update_fontmap(const char *fontalias, const char *fontname) { struct fontmap *fcur; if (fontname == NULL || fontalias == NULL) return; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fcur)) return; if (strcmp(fontname, fcur->fontname)) { g_free(fcur->fontname); fcur->fontname = g_strdup(fontname); } if (fcur->font) { pango_font_description_free(fcur->font); fcur->font = NULL; } } void gra2cairo_add_fontmap(const char *fontalias, const char *fontname) { struct fontmap *fnew; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fnew) == 0) { free_font_map(fnew); } create_font_map(fontalias, fontname, NULL); } void gra2cairo_set_alternative_font(const char *fontalias, const char *fontname) { struct fontmap *fnew; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fnew)) { return; } g_free(fnew->alternative); if (fontname) { gchar *ptr; ptr = g_strdup(fontname); if (ptr) { g_strstrip(ptr); if (ptr[0]) { fnew->alternative = ptr; } else { fnew->alternative = NULL; g_free(ptr); } } } else { fnew->alternative = NULL; } if (fnew->font) { pango_font_description_free(fnew->font); fnew->font = NULL; } } static int gra2cairo_init(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local = NULL; int antialias = ANTIALIAS_TYPE_DEFAULT; if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; if (Gra2cairoConf == NULL && init_conf()) { goto errexit; } local = g_malloc(sizeof(struct gra2cairo_local)); if (local == NULL) goto errexit; if (_putobj(obj, "_local", inst, local)) goto errexit; if (_putobj(obj, "antialias", inst, &antialias)) goto errexit; local->cairo = NULL; local->fontalias = NULL; local->layout = NULL; local->pixel_dot_x = 1; local->pixel_dot_y = 1; local->linetonum = 0; local->text2path = FALSE; local->antialias = antialias; local->region = NULL; local->font_style = GRA_FONT_STYLE_NORMAL; local->symbol = FALSE; local->use_opacity = FALSE; Instance++; return 0; errexit: if (Instance == 0) free_conf(); g_free(local); return 1; } void gra2cairo_draw_path(struct gra2cairo_local *local) { if (local->cairo && local->linetonum) { double x, y; cairo_get_current_point(local->cairo, &x, &y); cairo_stroke(local->cairo); cairo_move_to(local->cairo, x, y); local->linetonum = 0; } } struct gra2cairo_local * gra2cairo_free(struct objlist *obj, N_VALUE *inst) { struct gra2cairo_local *local; _getobj(obj, "_local", inst, &local); if (local == NULL) return NULL; if (local->cairo) { gra2cairo_draw_path(local); cairo_destroy(local->cairo); } if (local->layout) { g_object_unref(local->layout); } if (local->fontalias) { g_free(local->fontalias); } Instance--; if (Instance == 0) { free_conf(); } return local; } static int gra2cairo_done(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; if (OldConfigExist) { /* for backward compatibility */ gra2cairo_save_config(); } gra2cairo_free(obj, inst); return 0; } int gra2cairo_clip_region(struct gra2cairo_local *local, cairo_region_t *region) { if (local == NULL || local->cairo == NULL) return 1; cairo_new_path(local->cairo); if (region) { gdk_cairo_region(local->cairo, region); cairo_clip(local->cairo); local->region = region; } else { cairo_reset_clip(local->cairo); local->region = NULL; } return 0; } static double gra2cairo_get_pixel_dot(struct objlist *obj, N_VALUE *inst, char **argv) { int dpi; dpi = *(int *) argv[2]; if (dpi < 1) dpi = 1; if (dpi > DPI_MAX) dpi = DPI_MAX; *(int *)argv[2] = dpi; return dpi / (DPI_MAX * 1.0); } static int gra2cairo_set_dpi(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int dpi; struct gra2cairo_local *local; dpi = *(int *) argv[2]; _getobj(obj, "_local", inst, &local); _putobj(obj, "dpix", inst, &dpi); _putobj(obj, "dpiy", inst, &dpi); local->pixel_dot_x = local->pixel_dot_y = gra2cairo_get_pixel_dot(obj, inst, argv); return 0; } static int gra2cairo_set_dpi_x(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; _getobj(obj, "_local", inst, &local); local->pixel_dot_x = gra2cairo_get_pixel_dot(obj, inst, argv); return 0; } static int gra2cairo_set_dpi_y(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; _getobj(obj, "_local", inst, &local); local->pixel_dot_y = gra2cairo_get_pixel_dot(obj, inst, argv); return 0; } void set_cairo_antialias(cairo_t *cairo, int antialias) { if (cairo == NULL) { return; } switch (antialias) { case ANTIALIAS_TYPE_NONE: antialias = CAIRO_ANTIALIAS_NONE; break; case ANTIALIAS_TYPE_DEFAULT: antialias = CAIRO_ANTIALIAS_DEFAULT; break; case ANTIALIAS_TYPE_GRAY: antialias = CAIRO_ANTIALIAS_GRAY; break; case ANTIALIAS_TYPE_SUBPIXEL: antialias = CAIRO_ANTIALIAS_SUBPIXEL; break; } cairo_set_antialias(cairo, antialias); } void gra2cairo_set_antialias(struct gra2cairo_local *local, int antialias) { if (local->cairo == NULL) return; local->antialias = antialias; set_cairo_antialias(local->cairo, antialias); } static int set_antialias(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int antialias; struct gra2cairo_local *local; antialias = *(int *) argv[2]; _getobj(obj, "_local", inst, &local); gra2cairo_set_antialias(local, antialias); return 0; } struct compatible_font_info * gra2cairo_get_compatible_font_info(const char *name) { int i; if (name == NULL) { return NULL; } if (CompatibleFontHash == NULL) { return NULL; } if (nhash_get_int(CompatibleFontHash, name, &i)) { return NULL; } return &CompatibleFont[i]; } static struct fontmap * loadfont(char *fontalias, int font_style, int *symbol) { struct fontmap *fcur; PangoFontDescription *pfont; PangoStyle style; PangoWeight weight; *symbol = FALSE; if (nhash_get_ptr(Gra2cairoConf->fontmap, fontalias, (void *) &fcur)) { int i; if (nhash_get_int(CompatibleFontHash, fontalias, &i) == 0) { if (nhash_get_ptr(Gra2cairoConf->fontmap, CompatibleFont[i].name, (void *) &fcur) == 0) { font_style = CompatibleFont[i].style; *symbol = CompatibleFont[i].symbol; } } if (fcur == NULL && nhash_get_ptr(Gra2cairoConf->fontmap, DEFAULT_FONT, (void *) &fcur)) { return NULL; } } if (fcur->font) { pfont = fcur->font; } else { gchar *ptr; pfont = pango_font_description_new(); ptr = g_strdup_printf("%s%s%s", fcur->fontname, (fcur->alternative) ? "," : "", CHK_STR(fcur->alternative)); if (ptr) { pango_font_description_set_family(pfont, ptr); g_free(ptr); } else { return NULL; } } if (font_style > 0 && (font_style & GRA_FONT_STYLE_ITALIC)) { style = PANGO_STYLE_ITALIC; } else { style = PANGO_STYLE_NORMAL; } pango_font_description_set_style(pfont, style); if (font_style > 0 && (font_style & GRA_FONT_STYLE_BOLD)) { weight = PANGO_WEIGHT_BOLD; } else { weight = PANGO_WEIGHT_NORMAL; } pango_font_description_set_weight(pfont, weight); fcur->font = pfont; return fcur; } static void relative_move(cairo_t *cr, double x, double y) { if (cairo_has_current_point(cr)) { cairo_rel_move_to(cr, x, y); } else { cairo_move_to(cr, x, y); } } static void draw_str(struct gra2cairo_local *local, int draw, char *str, struct fontmap *font, int size, int space, int *fw, int *ah, int *dh) { PangoAttribute *attr; PangoAttrList *alist; PangoLayoutIter *piter; int w, h, baseline; if (size == 0 || str == NULL) { if (fw) *fw = 0; if (ah) *ah = 0; if (dh) *dh = 0; return; } if (local->layout == NULL) { local->layout = pango_cairo_create_layout(local->cairo); } alist = pango_attr_list_new(); attr = pango_attr_size_new_absolute(mxd2ph(local, size) * PANGO_SCALE); pango_attr_list_insert(alist, attr); attr = pango_attr_letter_spacing_new(mxd2ph(local, space) * PANGO_SCALE); pango_attr_list_insert(alist, attr); pango_layout_set_font_description(local->layout, font->font); pango_layout_set_attributes(local->layout, alist); pango_attr_list_unref(alist); pango_layout_set_text(local->layout, str, -1); pango_layout_get_pixel_size(local->layout, &w, &h); piter = pango_layout_get_iter(local->layout); baseline = pango_layout_iter_get_baseline(piter) / PANGO_SCALE; if (fw) *fw = w; if (ah) *ah = baseline; if (dh) *dh = h - baseline; if (draw && str) { double x, y; double cx, cy; x = - local->fontsin * baseline; y = - local->fontcos * baseline; cairo_get_current_point(local->cairo, &cx, &cy); relative_move(local->cairo, x, y); cairo_save(local->cairo); cairo_rotate(local->cairo, -local->fontdir * G_PI / 180.); pango_cairo_update_layout(local->cairo, local->layout); if (local->text2path) { pango_cairo_layout_path(local->cairo, local->layout); cairo_fill(local->cairo); cairo_restore(local->cairo); cairo_move_to(local->cairo, cx + w * local->fontcos, cy - w * local->fontsin); } else { pango_cairo_show_layout(local->cairo, local->layout); cairo_restore(local->cairo); relative_move(local->cairo, w * local->fontcos - x, - w * local->fontsin - y); } } pango_layout_iter_free(piter); } static int check_cairo_status(cairo_t *cairo) { int r; r = cairo_status(cairo); if (r != CAIRO_STATUS_SUCCESS) { return r + 100; } r = cairo_surface_status(cairo_get_target(cairo)); if (r != CAIRO_STATUS_SUCCESS) { return r + 100; } return 0; } static int gra2cairo_flush(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; cairo_surface_t *surface; _getobj(obj, "_local", inst, &local); if (local->cairo == NULL) return -1; gra2cairo_draw_path(local); surface = cairo_get_target(local->cairo); if (surface) { cairo_surface_flush(surface); } return check_cairo_status(local->cairo); } char * gra2cairo_get_utf8_str(const char *cstr, int symbol) { char *tmp; size_t l, i, j; l = strlen(cstr); tmp = g_malloc(l * 6 + 1); if (tmp == NULL) { return NULL; } for (j = i = 0; i <= l; i++) { if (cstr[i] == '\\') { if (cstr[i + 1] == 'x' && g_ascii_isxdigit(cstr[i + 2]) && g_ascii_isxdigit(cstr[i + 3])) { char buf[8]; int len, k; gunichar wc; wc = g_ascii_xdigit_value(cstr[i + 2]) * 16 + g_ascii_xdigit_value(cstr[i + 3]); len = g_unichar_to_utf8(wc, buf); for (k = 0; k < len; k++) { tmp[j++] = buf[k]; } i += 3; } else { i += 1; tmp[j++] = cstr[i]; } } else { tmp[j++] = cstr[i]; } tmp[j] = '\0'; } if (symbol) { char *ptr; ptr = ascii2greece(tmp); if (ptr) { g_free(tmp); tmp = ptr; } } return tmp; } static int gra2cairo_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char code, *cstr, *tmp; int *cpar, i, r, font_style; double x, y, w, h, fontsize, fontspace, fontdir, fontsin, fontcos, a1, a2; cairo_line_join_t join; cairo_line_cap_t cap; double *dashlist = NULL; struct gra2cairo_local *local; local = (struct gra2cairo_local *)argv[2]; code = *(char *)(argv[3]); cpar = (int *)argv[4]; cstr = argv[5]; if (local->cairo == NULL) return -1; if (code != 'T') { gra2cairo_draw_path(local); } switch (code) { case 'I': gra2cairo_set_antialias(local, local->antialias); local->linetonum = 0; r = check_cairo_status(local->cairo); if (r) { error(obj, r); return 1; } case '%': case 'X': case 'Z': break; case 'E': r = check_cairo_status(local->cairo); if (r) { error(obj, r); return 1; } break; case 'V': local->offsetx = mxd2pw(local, cpar[1]); local->offsety = mxd2ph(local, cpar[2]); cairo_new_path(local->cairo); if (cpar[5]) { x = mxd2pw(local, cpar[1]); y = mxd2ph(local, cpar[2]); w = mxd2pw(local, cpar[3]) - x; h = mxd2ph(local, cpar[4]) - y; cairo_reset_clip(local->cairo); cairo_rectangle(local->cairo, x, y, w, h); cairo_clip(local->cairo); } else { cairo_reset_clip(local->cairo); } if (local->region) { gra2cairo_clip_region(local, local->region); } break; case 'A': if (cpar[1] == 0) { cairo_set_dash(local->cairo, NULL, 0, 0); } else { dashlist = g_malloc(sizeof(* dashlist) * cpar[1]); if (dashlist == NULL) break; for (i = 0; i < cpar[1]; i++) { dashlist[i] = mxd2pw(local, cpar[6 + i]); if (dashlist[i] <= 0) { dashlist[i] = 1; } } cairo_set_dash(local->cairo, dashlist, cpar[1], 0); g_free(dashlist); } cairo_set_line_width(local->cairo, mxd2pw(local, cpar[2])); if (cpar[3] == 2) { cap = CAIRO_LINE_CAP_SQUARE; } else if (cpar[3] == 1) { cap = CAIRO_LINE_CAP_ROUND; } else { cap = CAIRO_LINE_CAP_BUTT; } cairo_set_line_cap(local->cairo, cap); if (cpar[4] == 2) { join = CAIRO_LINE_JOIN_BEVEL; } else if (cpar[4] == 1) { join = CAIRO_LINE_JOIN_ROUND; } else { join = CAIRO_LINE_JOIN_MITER; } cairo_set_line_join(local->cairo, join); break; case 'G': if (local->use_opacity && cpar[0] > 3 && cpar[4] < 255) { cairo_set_source_rgba(local->cairo, cpar[1] / 255.0, cpar[2] / 255.0, cpar[3] / 255.0, cpar[4] / 255.0); } else { cairo_set_source_rgb(local->cairo, cpar[1] / 255.0, cpar[2] / 255.0, cpar[3] / 255.0); } break; case 'M': cairo_move_to(local->cairo, mxd2px(local, cpar[1]), mxd2py(local, cpar[2])); break; case 'N': relative_move(local->cairo, mxd2pw(local, cpar[1]), mxd2ph(local, cpar[2])); break; case 'L': cairo_new_path(local->cairo); cairo_move_to(local->cairo, mxd2px(local, cpar[1]), mxd2py(local, cpar[2])); cairo_line_to(local->cairo, mxd2px(local, cpar[3]), mxd2py(local, cpar[4])); cairo_stroke(local->cairo); break; case 'T': cairo_line_to(local->cairo, mxd2px(local, cpar[1]), mxd2py(local, cpar[2])); local->linetonum++; break; case 'C': x = mxd2px(local, cpar[1] - cpar[3]); y = mxd2py(local, cpar[2] - cpar[4]); w = mxd2pw(local, cpar[3]); h = mxd2ph(local, cpar[4]); a1 = cpar[5] * (M_PI / 18000.0); a2 = cpar[6] * (M_PI / 18000.0) + a1; if (w == 0 || h == 0 || a1 == a2) break; cairo_new_path(local->cairo); cairo_save(local->cairo); cairo_translate(local->cairo, x + w, y + h); cairo_scale(local->cairo, w, h); cairo_arc_negative(local->cairo, 0., 0., 1., -a1, -a2); cairo_restore (local->cairo); switch (cpar[7]) { case 1: cairo_line_to(local->cairo, x + w, y + h); /* fall through */ case 2: cairo_close_path(local->cairo); cairo_fill(local->cairo); break; case 3: cairo_line_to(local->cairo, x + w, y + h); /* fall through */ case 4: cairo_close_path(local->cairo); cairo_stroke(local->cairo); break; default: cairo_stroke(local->cairo); } break; case 'B': cairo_new_path(local->cairo); if (cpar[1] <= cpar[3]) { x = mxd2px(local, cpar[1]); w = mxd2pw(local, cpar[3] - cpar[1]); } else { x = mxd2px(local, cpar[3]); w = mxd2pw(local, cpar[1] - cpar[3]); } if (cpar[2] <= cpar[4]) { y = mxd2py(local, cpar[2]); h = mxd2ph(local, cpar[4] - cpar[2]); } else { y = mxd2py(local, cpar[4]); h = mxd2ph(local, cpar[2] - cpar[4]); } cairo_rectangle(local->cairo, x, y, w, h); if (cpar[5] == 0) { cairo_stroke(local->cairo); } else { cairo_fill(local->cairo); } break; case 'P': cairo_new_path(local->cairo); cairo_arc(local->cairo, mxd2px(local, cpar[1]), mxd2py(local, cpar[2]), mxd2pw(local, 1), 0, 2 * M_PI); cairo_fill(local->cairo); break; case 'R': cairo_new_path(local->cairo); if (cpar[1] == 0) break; for (i = 0; i < cpar[1]; i++) { cairo_line_to(local->cairo, mxd2px(local, cpar[i * 2 + 2]), mxd2py(local, cpar[i * 2 + 3])); } cairo_stroke(local->cairo); break; case 'D': cairo_new_path(local->cairo); if (cpar[1] == 0) break; for (i = 0; i < cpar[1]; i++) { cairo_line_to(local->cairo, mxd2px(local, cpar[i * 2 + 3]), mxd2py(local, cpar[i * 2 + 4])); } cairo_close_path(local->cairo); switch (cpar[2]) { case 0: cairo_stroke(local->cairo); break; case 1: cairo_set_fill_rule(local->cairo, CAIRO_FILL_RULE_EVEN_ODD); cairo_fill(local->cairo); break; case 2: cairo_set_fill_rule(local->cairo, CAIRO_FILL_RULE_WINDING); cairo_fill(local->cairo); break; } break; case 'F': g_free(local->fontalias); local->fontalias = g_strdup(cstr); break; case 'H': fontspace = cpar[2] / 72.0 * 25.4; local->fontspace = fontspace; fontsize = cpar[1] / 72.0 * 25.4; local->fontsize = fontsize; fontdir = cpar[3] * MPI / 18000.0; fontsin = sin(fontdir); fontcos = cos(fontdir); local->fontdir = (cpar[3] % 36000) / 100.0; if (local->fontdir < 0) { local->fontdir += 360; } local->fontsin = fontsin; local->fontcos = fontcos; font_style = (cpar[0] > 3) ? cpar[4] : -1; local->loadfont = loadfont(local->fontalias, font_style, &local->symbol); break; case 'S': if (local->loadfont == NULL) break; tmp = gra2cairo_get_utf8_str(cstr, local->symbol); if (tmp) { draw_str(local, TRUE, tmp, local->loadfont, local->fontsize, local->fontspace, NULL, NULL, NULL); g_free(tmp); } break; case 'K': if (local->loadfont == NULL) break; tmp = sjis_to_utf8(cstr); if (tmp) { draw_str(local, TRUE, tmp, local->loadfont, local->fontsize, local->fontspace, NULL, NULL, NULL); g_free(tmp); } break; default: break; } return 0; } int gra2cairo_strwidth(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; gchar *font, *str; double size, dir, s,c ; int width, style, symbol; struct fontmap *fcur; str = argv[3]; size = ( * (int *) argv[4]) / 72.0 * 25.4; font = argv[5]; style = * (int *) (argv[6]); if (size == 0) { rval->i = 0; return 0; } if (_getobj(obj, "_local", inst, &local)) return 1; if (local->cairo == NULL) return 0; fcur = loadfont(font, style, &symbol); if (fcur == NULL) { rval->i = nround(size * 0.600); return 0; } dir = local->fontdir; s = local->fontsin; c = local->fontcos; local->fontdir = 0; local->fontsin = 0; local->fontcos = 1; if (symbol) { char *ptr; ptr = ascii2greece(str); if (ptr == NULL) { return 1; } str = ptr; } draw_str(local, FALSE, str, fcur, size, 0, &width, NULL, NULL); if (symbol) { g_free(str); } rval->i = mxp2dw(local, width); local->fontsin = s; local->fontcos = c; local->fontdir = dir; return 0; } int gra2cairo_charheight(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; char *font; double size, dir, s, c; char *func; int height, descent, ascent, style, symbol; struct fontmap *fcur; func = (char *)argv[1]; size = (*(int *)(argv[3])) / 72.0 * 25.4; font = (char *)(argv[4]); style = *(int *) (argv[5]); if (size == 0) { rval->i = 0; return 0; } if (_getobj(obj, "_local", inst, &local)) return 1; if (local->cairo == NULL) return 1; if (strcmp0(func, "_charascent") == 0) { height = TRUE; } else { height = FALSE; } fcur = loadfont(font, style, &symbol); if (fcur == NULL) { if (height) { rval->i = nround(size * 0.562); } else { rval->i = nround(size * 0.250); } return 0; } dir = local->fontdir; s = local->fontsin; c = local->fontcos; local->fontdir = 0; local->fontsin = 0; local->fontcos = 1; draw_str(local, FALSE, "A", fcur, size, 0, NULL, &ascent, &descent); if (height) { rval->i = mxp2dh(local, ascent); } else { rval->i = mxp2dh(local, descent); } local->fontsin = s; local->fontcos = c; local->fontdir = dir; return 0; } static int use_opacity(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gra2cairo_local *local; if (_getobj(obj, "_local", inst, &local)) return 1; local->use_opacity = * (int *) argv[2]; return 0; } static struct objtable gra2cairo[] = { {"init", NVFUNC, 0, gra2cairo_init, NULL, 0}, {"done", NVFUNC, 0, gra2cairo_done, NULL, 0}, {"dpi", NINT, NREAD | NWRITE, gra2cairo_set_dpi, NULL, 0}, {"dpix", NINT, NREAD | NWRITE, gra2cairo_set_dpi_x, NULL, 0}, {"dpiy", NINT, NREAD | NWRITE, gra2cairo_set_dpi_y, NULL, 0}, {"flush",NVFUNC,NREAD|NEXEC,gra2cairo_flush,"",0}, {"antialias", NENUM, NREAD | NWRITE, set_antialias, gra2cairo_antialias_type, 0}, {"use_opacity", NBOOL, NREAD | NWRITE, use_opacity, NULL,0}, {"_output", NVFUNC, 0, gra2cairo_output, NULL, 0}, {"_strwidth", NIFUNC, 0, gra2cairo_strwidth, NULL, 0}, {"_charascent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, {"_chardescent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, {"_local", NPOINTER, 0, NULL, NULL, 0}, }; #define TBLNUM (sizeof(gra2cairo) / sizeof(*gra2cairo)) void * addgra2cairo() /* addgra2cairoile() returns NULL on error */ { int i; if (CompatibleFontHash == NULL) { CompatibleFontHash = nhash_new(); if (CompatibleFontHash == NULL) { return NULL; } for (i = 0; i < (int) (sizeof(CompatibleFont) / sizeof(*CompatibleFont)); i++) { nhash_set_int(CompatibleFontHash, CompatibleFont[i].old_name, i); } } if (Gra2CairoErrMsgs == NULL) { Gra2CairoErrMsgs = g_malloc(sizeof(*Gra2CairoErrMsgs) * CAIRO_STATUS_LAST_STATUS); Gra2CairoErrMsgNum = CAIRO_STATUS_LAST_STATUS; for (i = 0; i < CAIRO_STATUS_LAST_STATUS; i++) { Gra2CairoErrMsgs[i] = g_strdup(cairo_status_to_string(i)); } } return addobject(NAME, NULL, PARENT, OVERSION, TBLNUM, gra2cairo, Gra2CairoErrMsgNum, Gra2CairoErrMsgs, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/completion_info_data.c0000644000175000017500000006210613313701035016546 00000000000000/* -*- Mode: C; coding: utf-8 -*- */ #include "gtk_common.h" #include "completion_info.h" struct completion_info completion_info_func[] = { {"abs", "abs()", "abs", N_("abs(x)\ncompute the absolute value of x"), NULL}, {"acos", "acos()", "acos", N_("acos(x)\narc cosine function"), NULL}, {"acosh", "acosh()", "acosh", N_("acosh(x)\ninverse hyperbolic cosine function"), NULL}, {"alpha", "alpha()", "alpha", N_("alpha(x, i)\nSet A (i == 1) or A2 (i == 2) values to x (0 <= x < 256)\nwhen i == 0, set A and A2 values to x"), NULL}, {"am", "am()", "am", N_("am(a)\ncopy the contents of array a to the memory\n(return the number of copied elements)"), NULL}, {"and", "and()", "and", N_("and(x, y)\nTrue (= 1) when (x != 0) and (y != 0)"), NULL}, {"array", "array()", "array", N_("array(a, v1, v2, ...)\ninitialize an array a with the rest arguments\nreturn the number of elements of the array"), NULL}, {"array_average", "array_average()", "array_average", N_("array_average(a)\nreturn the average of the elements of array a"), NULL}, {"array_clear", "array_clear()", "array_clear", N_("array_clear(a)\nset the number of elements of the array a to 0"), NULL}, {"array_compact", "array_compact()", "array_compact", N_("array_compact(a)\nRemove non-numeric values from the elements of the array of array a\nand return the number of elements after removal"), NULL}, {"array_max", "array_max()", "array_max", N_("array_max(a)\nreturns the maximum value contained in array a"), NULL}, {"array_min", "array_min()", "array_min", N_("array_min(a)\nreturns the minimum value contained in array a"), NULL}, {"array_stdev", "array_stdev()", "array_stdev", N_("array_stdev(a)\nreturn the corrected sample standard deviation of the elements of array a"), NULL}, {"array_stdevp", "array_stdevp()", "array_stdevp", N_("array_stdevp(a)\nreturn the standard deviation of the elements of array a"), NULL}, {"array_sum", "array_sum()", "array_sum", N_("array_sum(a)\nreturns the sum of the elements of array a"), NULL}, {"array_sumsq", "array_sumsq()", "array_sumsq", N_("array_sumsq(a)\nreturns the square sum of the elements of array a"), NULL}, {"asin", "asin()", "asin", N_("asin(x)\narc sine function"), NULL}, {"asinh", "asinh()", "asinh", N_("asinh(x)\ninverse hyperbolic sine function"), NULL}, {"atan", "atan()", "atan", N_("atan(x)\narc tangent function"), NULL}, {"atanh", "atanh()", "atanh", N_("atanh(x)\ninverse hyperbolic tangent function"), NULL}, {"beta", "beta()", "beta", N_("beta(x, y)\nbeta function"), NULL}, {"choose", "choose()", "choose", N_("choose(n, m)\nthe combinatorial factor n choose m: n!/(m!(n-m)!)"), NULL}, {"cm", "cm()", "cm", N_("cm(x, n)\ninitialize n memories from the beginning with x\ninitialize whole memory when n is 0\nand n memories from the end when x is negative\n(return x)"), NULL}, {"color", "color()", "color", N_("color(i, x)\ni = 0: Set the R value to x (0 <= x < 256)\ni = 1: Set the G value to x (0 <= x < 256)\ni = 2: Set the B value to x (0 <= x < 256)\ni = 3: Set the R, G and B values to x (0 <= x < 256)\ni = 4: Set the R2 value to x (0 <= x < 256)\ni = 5: Set the G2 value to x (0 <= x < 256)\ni = 6: Set the B2 value to x (0 <= x < 256)\ni = 7: Set the R2, G2 and B2 values to x (0 <= x < 256)\ni = 8: Set the R, G and B values to be hexadecimal color of x\ni = 9: Set the R2, G2 and B2 values to be hexadecimal color of x"), NULL}, {"cos", "cos()", "cos", N_("cos(x)\ncosine function"), NULL}, {"cosh", "cosh()", "cosh", N_("cosh(x)\nhyperbolic cosine function"), NULL}, {"delta", "delta()", "delta", N_("delta(x)\nKronecker delta (1 when x = 0, 0 otherwise)"), NULL}, {"dif", "dif()", "dif", N_("dif(x)\nDifference"), NULL}, {"draw_arc", "draw_arc()", "draw_arc", N_("draw_arc(x, y, rx, ry, start, arc, pieslice, stroke, fill, close)\ndraw an arc with the X direction radius rx and the Y direction radius ry centered on (x, y).\nstart and arc specify start angle and arc angle respectively.\nWhen stroke and fill are 0, do not draw contours and fills respectively.\nIf pieslice is not 0, draw a sector.\nIf close is not 0, close the outline."), NULL}, {"draw_errorbar", "draw_errorbar()", "draw_errorbar", N_("draw_errorbar(x, y, erx, ery, size)\ndraw errorbars from (x - erx, y) to (x + erx, y) and\nfrom (x, y - ery) to (x, y + ery).\nThe length of ticks can be specified with size.\nWhen size is 0, specification of the file object is used."), NULL}, {"draw_errorbar2", "draw_errorbar2()", "draw_errorbar2", N_("draw_errorbar2(x1, y1, x2, y2, size)\ndraw an errorbar from (x1, y1) to (x2, y2).\nThe length of ticks can be specified with size.\nWhen size is 0, specification of the file object is used."), NULL}, {"draw_line", "draw_line()", "draw_line", N_("draw_line(x1, y1, x2, y2)\ndraw a line form (x1, y1) to (x2, y2)."), NULL}, {"draw_mark", "draw_mark()", "draw_mark", N_("draw_mark(x, y, size)\ndraw a mark on (x, y). The size of a mark can be specified with size.\nWhen size is 0, specification of the file object is used."), NULL}, {"draw_polygon", "draw_polygon()", "draw_polygon", N_("draw_polygon(ax, ay, stroke, fill)\ndrow polygon defined by coordinates (ax[0], ay[0]), (ax[1], ay[1]), ....\nwhen stroke is 0, do not draw contours.\nfill can be specified with one of\nFILL_RULE_NONE, FILL_RULE_EVEN_ODD or FILL_RULE_WINDING."), NULL}, {"draw_polyline", "draw_polyline()", "draw_polyline", N_("draw_polyline(ax, ay)\nconnect coordinates (ax[0], ay[0]), (ax[1], ay[1]), ... by polyline."), NULL}, {"draw_rect", "draw_rect()", "draw_rect", N_("draw_rect(x, y, w, h, stroke, fill)\ndraw a rectangle with (x, y) and (x + w, y + h) as diagonal vertices.\nWhen stroke and fill are 0, do not draw contours and fills respectively."), NULL}, {"ei", "ei()", "ei", N_("ei(x)\ncompute the exponential integral Ei(x)"), NULL}, {"eq", "eq()", "eq", N_("eq(x, y, prec)\nTrue (= 1) when x == y.\nThe number of digits of comparison can be specified with prec\n(prec == 0 is exact match)."), NULL}, {"erf", "erf()", "erf", N_("erf(x)\nerror function erf(x)"), NULL}, {"erfc", "erfc()", "erfc", N_("erfc(x)\ncomplementary error function erfc(x)"), NULL}, {"exp", "exp()", "exp", N_("exp(x)\nbase-e exponential function (x <= 690)"), NULL}, {"fit_calc", "fit_calc()", "fit_calc", N_("fit_calc(id, x)\nWhen the plot type of the data object whose ID is id is fit,\nthe corresponding fit result f(x) is calculated."), NULL}, {"fit_prm", "fit_prm()", "fit_prm", N_("fit_prm(id, x)\nWhen the plot type of the data object whose ID is id is fit,\nthe value of the field \"%0x\" of the corresponding fit object."), NULL}, {"fmod", "fmod()", "fmod", N_("fmod(x, y)\ncompute the floating-point remainder of dividing x by y"), NULL}, {"for", "for()", "for", N_("for(m, begin, end, step, ex)\nSet the value in step from begin to end to the m-th memory and repeat ex.\nWhen m is negative, no setting to memory is done.\nReturns the value of ex evaluated last."), NULL}, {"frac", "frac()", "frac", N_("frac(x)\nremainder"), NULL}, {"gamma", "gamma()", "gamma", N_("gamma(x)\ngamma function"), NULL}, {"gauss", "gauss()", "gauss", N_("gauss(x)\nlargest integral value not greater than x"), NULL}, {"ge", "ge()", "ge", N_("ge(x, y, prec)\nTrue (= 1) when x >= y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits)."), NULL}, {"gt", "gt()", "gt", N_("gt(x, y, prec)\nTrue (= 1) when x > y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits)."), NULL}, {"hn", "hn()", "hn", N_("hn(n, x)\nHermite polynomials"), NULL}, {"hsb", "hsb()", "hsb", N_("hsb(h, s, b)\nSet the R, G and B values of the color to h, s, b (0 <= h, s, b <=1) from the HSB value"), NULL}, {"hsb2", "hsb2()", "hsb2", N_("hsb2(h, s, b)\nSet the R2, G2 and B2 values of the color to h, s, b (0 <= h, s, b <=1) from the HSB value"), NULL}, {"icbeta", "icbeta()", "icbeta", N_("icbeta(a, b, x)\nincomplete beta function"), NULL}, {"icgam", "icgam()", "icgam", N_("icgam(m, x)\nincomplete gamma function"), NULL}, {"if", "if()", "if", N_("if(x, ex1, ex2)\nevaluate ex1 when x != 0, evaluate ex2 otherwise"), NULL}, {"in", "in()", "in", N_("in(n, x)\ncompute the regular modified cylindrical Bessel function of order |n|, In(|x|)"), NULL}, {"int", "int()", "int", N_("int(x)\nround to integer, toward zero"), NULL}, {"inu", "inu()", "inu", N_("inu(nu, x)\ncompute the regular modified Bessel function of fractional order |nu|, Inu(|x|)"), NULL}, {"isbreak", "isbreak()", "isbreak", N_("isbreak(x)\nTrue if x is BREAK"), NULL}, {"iscont", "iscont()", "iscont", N_("iscont(x)\nTrue if x is CONT"), NULL}, {"isnan", "isnan()", "isnan", N_("isnan(x)\nTrue if x is NAN"), NULL}, {"isnormal", "isnormal()", "isnormal", N_("isnormal(x)\nTrue if x is a normal number"), NULL}, {"isundef", "isundef()", "isundef", N_("isundef(x)\nTrue if x is UNDEF"), NULL}, {"jl", "jl()", "jl", N_("jl(l, x)\ncompute the regular spherical Bessel function of order |l|, jl(|x|)"), NULL}, {"jn", "jn()", "jn", N_("jn(n, x)\ncompute the regular cylindrical Bessel function of order n, Jn(|x|)"), NULL}, {"jnu", "jnu()", "jnu", N_("jnu(nu, x)\ncompute the regular cylindrical Bessel function of fractional order |nu|, Jnu(|x|)"), NULL}, {"kn", "kn()", "kn", N_("kn(n, x)\ncompute the irregular modified cylindrical Bessel function of order |n|, Kn(|x|)"), NULL}, {"knu", "knu()", "knu", N_("knu(nu, x)\ncompute the irregular modified Bessel function of fractional order |nu|, Knu(|x|)"), NULL}, {"le", "le()", "le", N_("le(x, y, prec)\nTrue (= 1) when x <= y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits)."), NULL}, {"lgn", "lgn()", "lgn", N_("lgn(n, a, x)\nevaluate the generalized Laguerre polynomials Lan(x) for a > -1, n >= 0"), NULL}, {"line_number", "line_number()", "line_number", N_("line_number()\nFile line number being processed (1st line is 1)"), NULL}, {"ln", "ln()", "ln", N_("ln(x)\nnatural logarithmic function"), NULL}, {"log", "log()", "log", N_("log(x)\nbase-10 logarithmic function"), NULL}, {"lt", "lt()", "lt", N_("lt(x, y, prec)\nTrue (= 1) when x < y.\nThe precision allows you to specify the number of digits for comparison\n(prec == 0 does not specify the number of digits)."), NULL}, {"m", "m()", "m", N_("m(i, x)\nassigns x to the i-th memory (i = 0 to 65535)\nthe index from the tail when i is negative\n(return x)"), NULL}, {"marksize", "marksize()", "marksize", N_("marksize(x)\nSet mark size to x"), NULL}, {"marktype", "marktype()", "marktype", N_("marktype(x)\nSet mark type to x"), NULL}, {"max", "max()", "max", N_("max(a, b, c, ...)\nThe largest value of arguments"), NULL}, {"min", "min()", "min", N_("min(a, b, c, ...)\nThe smallest value of arguments"), NULL}, {"mjd", "mjd()", "mjd", N_("mjd(year, month, day, hour, min, sec)\nModified Julian Date (date and time are given in UTC)"), NULL}, {"mjd2day", "mjd2day()", "mjd2day", N_("mjd2day(mjd)\nGregorian calendar day corresponding to Modified Julian Day mjd"), NULL}, {"mjd2month", "mjd2month()", "mjd2month", N_("mjd2month(mjd)\nmonth of Gregorian calendar corresponding to Modified Julian Day mjd"), NULL}, {"mjd2unix", "mjd2unix()", "mjd2unix", N_("mjd2unix(mjd)\ntime represents the number of seconds elapsed since the Epoch at mjd"), NULL}, {"mjd2wday", "mjd2wday()", "mjd2wday", N_("mjd2wday(mjd)\nThe day of the week as a decimal range 1 to 7, Monday being 1 corresponding to mjd"), NULL}, {"mjd2yday", "mjd2yday()", "mjd2yday", N_("mjd2yday(mjd)\nThe day of the year as a decimal number (range 001 to 366) corresponding to mjd"), NULL}, {"mjd2year", "mjd2year()", "mjd2year", N_("mjd2year(mjd)\nyear of Gregorian calendar corresponding to Modified Julian Day mjd"), NULL}, {"neq", "neq()", "neq", N_("neq(x, y, prec)\nTrue (= 1) when x != y.\nThe number of digits of comparison can be specified with prec\n(prec == 0 is exact match)."), NULL}, {"not", "not()", "not", N_("not(x)\nTrue (= 1) when x == 0"), NULL}, {"obj_alpha", "obj_alpha()", "obj_alpha", N_("obj_alpha(id, obj)\nSet the A and A2 value to the same value as the instance of obj whose ID is id.\nobj is one of DATA_OBJ, PATH_OBJ, ARC_OBJ, MARK_OBJ or TEXT_OBJ."), NULL}, {"obj_color", "obj_color()", "obj_color", N_("obj_color(id, obj)\nSet the R, G, B, R2, G2 and B2 values to the same value as the instance of obj whose ID is id.\nobj is one of DATA_OBJ, PATH_OBJ, ARC_OBJ, MARK_OBJ or TEXT_OBJ."), NULL}, {"or", "or()", "or", N_("or(x, y)\nTrue (= 1) when (x != 0) or (y != 0)"), NULL}, {"pn", "pn()", "pn", N_("pn(l, x)\nevaluate the Legendre polynomial Pl(x) for a specific value of l, x subject to l >= 0, |x| <= 1"), NULL}, {"pop", "pop()", "pop", N_("pop(a)\nremove the last element of array a, and returns that element"), NULL}, {"prog1", "prog1()", "prog1", N_("prog1(arg1, arg2, ...)\nEvaluate the arguments and return the evaluated value of the first argument"), NULL}, {"prog2", "prog2()", "prog2", N_("prog2(arg1, arg2, ...)\nEvaluate the arguments and return the evaluated value of the second argument"), NULL}, {"progn", "progn()", "progn", N_("progn(arg1, arg2, ...)\nEvaluate the arguments and return the evaluated value of the last argument"), NULL}, {"push", "push()", "push", N_("push(a, x)\nadds new element x to the end of an array a, and returns x"), NULL}, {"qinv", "qinv()", "qinv", N_("qinv(x)\ninverse complementary error function"), NULL}, {"rand", "rand()", "rand", N_("rand(x)\nreturns a random gdouble equally distributed over the range [0..x)"), NULL}, {"rgb", "rgb()", "rgb", N_("rgb(r, g, b)\nSet the R, G and B values of the color to r, g, b (0 <= r, g, b <= 1)"), NULL}, {"rgb2", "rgb2()", "rgb2", N_("rgb2(r, g, b)\nSet the R2, G2 and B2 values of the color to r, g, b (0 <= r, g, b <= 1)"), NULL}, {"rm", "rm()", "rm", N_("rm(i)\nthe value of the current i-th memory (i = 0 to 65535),\nthe index from the tail when i is negative"), NULL}, {"round", "round()", "round", N_("round(x)\nround to nearest integer, away from zero"), NULL}, {"rsort", "rsort()", "rsort", N_("rsort(a)\nreverse sort elements of array a"), NULL}, {"shift", "shift()", "shift", N_("shift(a)\nremove the first element of array a, and returns that element"), NULL}, {"sign", "sign()", "sign", N_("sign(x)\npositive / negative sign (-1 with x < 0, 1 with x >= 0)"), NULL}, {"sin", "sin()", "sin", N_("sin(x)\nsine function"), NULL}, {"sinh", "sinh()", "sinh", N_("sinh(x)\nhyperbolic sine function"), NULL}, {"size", "size()", "size", N_("size(a)\nnumber of elements of array a"), NULL}, {"sort", "sort()", "sort", N_("sort(a)\nsort elements of array a"), NULL}, {"sqr", "sqr()", "sqr", N_("sqr(x)\nsquaring"), NULL}, {"sqrt", "sqrt()", "sqrt", N_("sqrt(x)\nsquare root"), NULL}, {"srand", "srand()", "srand", N_("srand(x)\nSets the seed for the random number generator which is used by the rand() function"), NULL}, {"sum", "sum()", "sum", N_("sum(x)\nIntegration"), NULL}, {"sumsq", "sumsq()", "sumsq", N_("sumsq(a, b, c, ...)\nsquare sum of arguments"), NULL}, {"tan", "tan()", "tan", N_("tan(x)\ntangent function"), NULL}, {"tanh", "tanh()", "tanh", N_("tanh(x)\nhyperbolic tangent function"), NULL}, {"theta", "theta()", "theta", N_("theta(x)\nstaircase function (1 if x >= 0, 0 otherwise)"), NULL}, {"time", "time()", "time", N_("time()\nreturns the time as the number of seconds since the Epoch,\n1970-01-01 00:00:00 +0000 (UTC)"), NULL}, {"tn", "tn()", "tn", N_("tn(n, x)\nChebyshev polynomials"), NULL}, {"unix2mjd", "unix2mjd()", "unix2mjd", N_("unix2mjd(time)\nModified Julian Date\ntime represents the number of seconds elapsed since the Epoch,\n1970-01-01 00:00:00 +0000 (UTC))"), NULL}, {"unless", "unless()", "unless", N_("unless(x, ex1, ex2)\nevaluate ex2 when x != 0, evaluate ex1 otherwise"), NULL}, {"unshift", "unshift()", "unshift", N_("unshift(a, x)\nadds new element x to the beginning of an array a, returns x"), NULL}, {"xor", "xor()", "xor", N_("xor(x, y)\nTrue (= 1) when (x != 0) xor (y != 0)"), NULL}, {"yl", "yl()", "yl", N_("yl(l, x)\ncompute the irregular spherical Bessel function of order |l|, yl(|x|)"), NULL}, {"yn", "yn()", "yn", N_("yn(n, x)\ncompute the irregular cylindrical Bessel function of order n, Yn(|x|)"), NULL}, {"ynu", "ynu()", "ynu", N_("ynu(nu, x)\ncompute the irregular cylindrical Bessel function of fractional order |nu|, Ynu(|x|)"), NULL}, {"zeta", "zeta()", "zeta", N_("zeta(s)\ncompute the Riemann zeta function zeta(s) for arbitrary s, s != 1"), NULL}, {"zeta_int", "zeta_int()", "zeta_int", N_("zeta_int(n)\ncompute the Riemann zeta function zeta(n) for integer n, n != 1"), NULL}, {"zetam1", "zetam1()", "zetam1", N_("zetam1(s)\ncompute zeta(s) - 1 for arbitrary s, s != 1"), NULL}, {"zetam1_int", "zetam1_int()", "zetam1_int", N_("zetam1_int(n)\ncompute zeta(n) - 1 for integer n, n != 1"), NULL}, {NULL, NULL, NULL, NULL} }; struct completion_info completion_info_const[] = { {"%d", "%D", NULL, N_("%D\nThe ID of the instance of the data object"), NULL}, {"%n", "%N", NULL, N_("%N\nThe number of instances of data object"), NULL}, {"arc_obj", "ARC_OBJ", NULL, N_("ARC_OBJ\nThe identification number of the arc object"), NULL}, {"avx", "AVX", NULL, N_("AVX\nThe average of X"), NULL}, {"avy", "AVY", NULL, N_("AVY\nThe average of X"), NULL}, {"axisx", "AXISX", NULL, N_("AXISX\nThe ID of the axis instance specified as X axis"), NULL}, {"axisx_len", "AXISX_LEN", NULL, N_("AXISX_LEN\nLength of the X axis"), NULL}, {"axisx_max", "AXISX_MAX", NULL, N_("AXISX_MAX\nThe maximum value of the X axis"), NULL}, {"axisx_min", "AXISX_MIN", NULL, N_("AXISX_MIN\nThe minimum value of the X axis"), NULL}, {"axisy", "AXISY", NULL, N_("AXISY\nThe ID of the axis instance specified as Y axis"), NULL}, {"axisy_len", "AXISY_LEN", NULL, N_("AXISY_LEN\nLength of the Y axis"), NULL}, {"axisy_max", "AXISY_MAX", NULL, N_("AXISY_MAX\nThe maximum value of the Y axis"), NULL}, {"axisy_min", "AXISY_MIN", NULL, N_("AXISY_MIN\nThe minimum value of the Y axis"), NULL}, {"break", "BREAK", NULL, N_("BREAK\nMissing data (data lines are not combined)"), NULL}, {"colx", "COLX", NULL, N_("COLX\nThe column number specified for X"), NULL}, {"coly", "COLY", NULL, N_("COLY\nThe column number specified for Y"), NULL}, {"cont", "CONT", NULL, N_("CONT\nMissing data (data lines are combined)"), NULL}, {"data_obj", "DATA_OBJ", NULL, N_("DATA_OBJ\nThe identification number of the data object"), NULL}, {"e", "E", NULL, N_("E\nThe base of natural logarithm (Napier's constant)"), NULL}, {"euler", "EULER", NULL, N_("EULER\nEuler's constant"), NULL}, {"false", "FALSE", NULL, N_("FALSE\nthe FALSE value (0)"), NULL}, {"fill_rule_even_odd", "FILL_RULE_EVEN_ODD", NULL, N_("FILL_RULE_EVEN_ODD\nDefined for the function draw_polygon().\nfill the polygon with evin-odd rule."), NULL}, {"fill_rule_none", "FILL_RULE_NONE", NULL, N_("FILL_RULE_NONE\nDefined for the function draw_polygon().\ndon't fill the polygon."), NULL}, {"fill_rule_winding", "FILL_RULE_WINDING", NULL, N_("FILL_RULE_WINDING\nDefined for the function draw_polygon().\nfill the polygon with winding rule."), NULL}, {"first", "FIRST", NULL, N_("FIRST\nWhen conversion is performed twice with one line of data such as diagonal or errorbar plot,\ntrue (1) in the first call, false (0) in the second call."), NULL}, {"fline", "FLINE", NULL, N_("FLINE\nNumber of lines specified as \"Final line\""), NULL}, {"hskip", "HSKIP", NULL, N_("HSKIP\nNumber of lines specified as \"Head skip\""), NULL}, {"mark_obj", "MARK_OBJ", NULL, N_("MARK_OBJ\nThe identification number of the mark object"), NULL}, {"mask", "MASK", NULL, N_("MASK\nNumber of lines set for mask"), NULL}, {"maxx", "MAXX", NULL, N_("MAXX\nThe maximum value of X"), NULL}, {"maxy", "MAXY", NULL, N_("MAXY\nThe maximum value of Y"), NULL}, {"minx", "MINX", NULL, N_("MINX\nThe minimum value of X"), NULL}, {"miny", "MINY", NULL, N_("MINY\nThe minimum value of Y"), NULL}, {"move", "MOVE", NULL, N_("MOVE\nNumber of lines set for move"), NULL}, {"nan", "NAN", NULL, N_("NAN\nMissing data with error indication"), NULL}, {"num", "NUM", NULL, N_("NUM\nThe number of the data"), NULL}, {"path_obj", "PATH_OBJ", NULL, N_("PATH_OBJ\nThe identification number of the path object"), NULL}, {"pi", "PI", NULL, N_("PI\nPi"), NULL}, {"rect_obj", "RECT_OBJ", NULL, N_("RECT_OBJ\nThe identification number of the rectangle object"), NULL}, {"rstep", "RSTEP", NULL, N_("RSTEP\nNumber of lines specified as \"Read step\""), NULL}, {"stdevpx", "STDEVPX", NULL, N_("STDEVPX\nThe standard deviation of X"), NULL}, {"stdevpy", "STDEVPY", NULL, N_("STDEVPY\nThe standard deviation of Y"), NULL}, {"stdevx", "STDEVX", NULL, N_("STDEVX\nThe corrected sample standard deviation of X"), NULL}, {"stdevy", "STDEVY", NULL, N_("STDEVY\nThe corrected sample standard deviation of Y"), NULL}, {"sumx", "SUMX", NULL, N_("SUMX\nSum of X"), NULL}, {"sumxx", "SUMXX", NULL, N_("SUMXX\nSquare sum of X"), NULL}, {"sumxy", "SUMXY", NULL, N_("SUMXY\nProduct sum of X and Y"), NULL}, {"sumy", "SUMY", NULL, N_("SUMY\nSum of Y"), NULL}, {"sumyy", "SUMYY", NULL, N_("SUMYY\nSquare sum of Y"), NULL}, {"text_obj", "TEXT_OBJ", NULL, N_("TEXT_OBJ\nThe identification number of the text object"), NULL}, {"true", "TRUE", NULL, N_("TRUE\nthe TRUE value (1)"), NULL}, {"undef", "UNDEF", NULL, N_("UNDEF\nMissing data without error indication"), NULL}, {NULL, NULL, NULL, NULL} }; ngraph-gtk-6.08.00/src/gtk/x11commn.h0000644000175000017500000000361613070106167014047 00000000000000/* * $Id: x11commn.h,v 1.11 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void OpenGRA(void); void CloseGRA(void); void ChangeGRA(void); void CheckPage(void); void SetPageSettingsToGRA(void); void GetPageSettingsFromGRA(void); void AxisDel(int id); void AxisMove(int id1, int id2); void AdjustAxis(void); void FitCopy(struct objlist *obj, int did, int sid); void FitDel(struct objlist *obj, int id); void ArrayDel(struct objlist *obj, int id); void FitClear(void); int LoadNgpFile(char *File, int console, char *option); int SaveDrawrable(char *name, int storedata, int storemerge); int GraphSave(int overwrite); void DeleteDrawable(void); void FileAutoScale(void); int CheckSave(void); void AddDataFileList(const char *file); void SetFileName(char *name); int CheckIniFile(void); int allocate_console(void); void free_console(int allocnow); char *FileCB(struct objlist *obj, int id); char *PlotFileCB(struct objlist *obj, int id); int SetFileHidden(void); void ProgressDialogCreate(char *title); void ProgressDialogSetTitle(char *title); void ProgressDialogFinalize(void); void ErrorMessage(void); ngraph-gtk-6.08.00/src/gtk/ogra2x11.c0000644000175000017500000005241113070106167013740 00000000000000/* * $Id: ogra2x11.c,v 1.34 2010-01-04 05:11:28 hito Exp $ * * This file is part of "Ngraph for GTK". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for GTK" 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. * * "Ngraph for GTK" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include #include "strconv.h" #include "object.h" #include "ioutil.h" #include "gra.h" #include "nstring.h" #include "mathfn.h" #include "nconfig.h" #include "shell.h" #include "init.h" #include "x11menu.h" #include "x11gui.h" #include "ogra2x11.h" #include "ogra2cairo.h" #define NAME "gra2gtk" #define ALIAS "gra2win:gra2x11" #define PARENT "gra2cairo" #define NVERSION "1.00.00" #define GRA2GTKCONF "[gra2gtk]" #define ERRDISPLAY 100 #define ERRCMAP 101 #define WINWIDTH 578 #define WINHEIGHT 819 #define WINSIZE_MAX 10000 static char *gtkerrorlist[] = { "cannot open display.", "not enough color cell.", }; #define ERRNUM (sizeof(gtkerrorlist)/sizeof(*gtkerrorlist)) struct action_type { enum { ACTION_TYPE_NONE, ACTION_TYPE_KEY, ACTION_TYPE_BUTTON, ACTION_TYPE_SCROLL, } type; int val; }; struct gtklocal { struct objlist *obj; GdkCursor *blank_cursor; N_VALUE *inst; GtkWidget *mainwin, *View; cairo_surface_t *surface; GdkWindow *window; char *title; int redraw, fit, frame; unsigned int windpi; int PaperWidth, PaperHeight; struct action_type action; double bg_r, bg_g, bg_b; struct gra2cairo_local *local; }; static void gtkMakeRuler(cairo_t *cr, struct gtklocal *gtklocal); static int gtk_evloop(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static int gtkclose(GtkWidget *widget, GdkEvent *event, gpointer user_data); static void gtkchangedpi(struct gtklocal *gtklocal); static gboolean gtkevpaint(GtkWidget * w, cairo_t * e, gpointer user_data); static int gtkinit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static int gtkdone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static int gtkclear(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static int gtkredraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static int dot2pixel(struct gtklocal *gtklocal, int r); static int gtk_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv); static gboolean gtkevpaint(GtkWidget *w, cairo_t *cr, gpointer user_data) { struct gtklocal *gtklocal; gtklocal = (struct gtklocal *) user_data; if (gtklocal->surface == NULL) { return FALSE; } if (gtklocal->redraw) { GRAredraw(gtklocal->obj, gtklocal->inst, FALSE, FALSE); gtklocal->redraw = FALSE; } cairo_set_source_surface(cr, gtklocal->surface, 0, 0); cairo_paint(cr); gtkMakeRuler(cr, gtklocal); return FALSE; } static int gtkclose(GtkWidget *widget, GdkEvent *event, gpointer user_data) { N_VALUE *inst; struct gtklocal *local; int i, id; struct objlist *obj; obj = chkobject("gra2gtk"); for (i = 0; i <= chkobjlastinst(obj); i++) { inst = chkobjinst(obj, i); _getobj(obj, "_gtklocal", inst, &local); if (local->mainwin == widget) { _getobj(obj, "id", inst, &id); delobj(obj, id); break; } } return TRUE; } static gboolean ev_key_down(GtkWidget *w, GdkEvent *event, gpointer user_data) { GdkEventKey *e; struct gtklocal *gtklocal; gtklocal = (struct gtklocal *) user_data; g_return_val_if_fail(w != NULL, FALSE); g_return_val_if_fail(event != NULL, FALSE); e = (GdkEventKey *)event; gtklocal->action.type = ACTION_TYPE_KEY; gtklocal->action.val = e->keyval; switch (e->keyval) { case GDK_KEY_w: if (e->state & GDK_CONTROL_MASK) { gtkclose(w, NULL, NULL); return TRUE; } return FALSE; } return FALSE; } void size_allocate(GtkWidget *widget, GdkRectangle *allocation, gpointer user_data) { struct gtklocal *local; double w, h, rh, rw, ratio; int pw, ph, dpi; local = (struct gtklocal *) user_data; if (local == NULL) { return; } if (! local->fit) { return; } w = allocation->width; h = allocation->height; pw = local->PaperWidth; ph = local->PaperHeight; if (pw < 1 || ph < 1) { return; } rw = w / pw; rh = h / ph; ratio = (rh > rw) ? rw : rh; dpi = ratio * DPI_MAX; local->windpi = dpi; local->local->pixel_dot_x = local->local->pixel_dot_y = ratio; _putobj(local->obj, "dpi", local->inst, &dpi); gtkchangedpi(local); } static gboolean cursor_moved(GtkWidget *widget, GdkEvent *event, gpointer user_data) { struct gtklocal *gtklocal; gtklocal = (struct gtklocal *) user_data; if (gtklocal->blank_cursor) { gdk_window_set_cursor(gtk_widget_get_window(gtklocal->mainwin), NULL); g_object_unref(gtklocal->blank_cursor); gtklocal->blank_cursor = NULL; } return FALSE; } static gboolean button_released(GtkWidget *widget, GdkEventButton *event, gpointer user_data) { struct gtklocal *gtklocal; gtklocal = (struct gtklocal *) user_data; gtklocal->action.type = ACTION_TYPE_BUTTON; gtklocal->action.val = event->button; return FALSE; } static gboolean scrolled(GtkWidget *widget, GdkEventScroll *event, gpointer user_data) { struct gtklocal *gtklocal; gtklocal = (struct gtklocal *) user_data; switch (event->direction) { case GDK_SCROLL_UP: case GDK_SCROLL_DOWN: case GDK_SCROLL_LEFT: case GDK_SCROLL_RIGHT: gtklocal->action.type = ACTION_TYPE_SCROLL; gtklocal->action.val = event->direction; break; case GDK_SCROLL_SMOOTH: break; } return FALSE; } static int gtkinit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; struct gra2cairo_local *local; struct objlist *robj; int idn, oid, width, height; GtkWidget *scrolled_window = NULL; if (_exeparent(obj, (char *) argv[1], inst, rval, argc, argv)) return 1; gtklocal = g_malloc(sizeof(*gtklocal)); if (gtklocal == NULL) goto errexit; gtklocal->obj = obj; gtklocal->inst = inst; gtklocal->title = NULL; gtklocal->mainwin = NULL; gtklocal->fit = FALSE; gtklocal->frame = TRUE; gtklocal->blank_cursor = NULL; gtklocal->action.type = ACTION_TYPE_NONE; gtklocal->action.val = 0; if (_putobj(obj, "_gtklocal", inst, gtklocal)) goto errexit; if (_getobj(obj, "oid", inst, &oid)) goto errexit; if (_getobj(obj, "_local", inst, &local)) goto errexit; if (_getobj(obj, "fit", inst, >klocal->fit)) goto errexit; if (_getobj(obj, "frame", inst, >klocal->frame)) goto errexit; gtklocal->PaperWidth = 0; gtklocal->PaperHeight = 0; gtklocal->windpi = DEFAULT_DPI / 2; gtklocal->bg_r = 1.0; gtklocal->bg_g = 1.0; gtklocal->bg_b = 1.0; gtklocal->local = local; if (gtklocal->windpi < 1) gtklocal->windpi = 1; if (gtklocal->windpi > DPI_MAX) gtklocal->windpi = DPI_MAX; if (_putobj(obj, "dpi", inst, &(gtklocal->windpi))) goto errexit; if (_putobj(obj, "dpix", inst, &(gtklocal->windpi))) goto errexit; if (_putobj(obj, "dpiy", inst, &(gtklocal->windpi))) goto errexit; local->pixel_dot_x = local->pixel_dot_y = gtklocal->windpi / (DPI_MAX * 1.0); width = WINWIDTH; height = WINHEIGHT; if (_putobj(obj, "width", inst, &width)) goto errexit; if (_putobj(obj, "height", inst, &height)) goto errexit; if (! OpenApplication()) { error(obj, ERRDISPLAY); goto errexit; } gtklocal->title = mkobjlist(obj, NULL, oid, NULL, TRUE); gtklocal->mainwin = gtk_window_new(GTK_WINDOW_TOPLEVEL); gtk_window_set_default_size(GTK_WINDOW(gtklocal->mainwin), width, height); g_signal_connect_swapped(gtklocal->mainwin, "delete-event", G_CALLBACK(gtkclose), gtklocal->mainwin); g_signal_connect(gtklocal->mainwin, "key-press-event", G_CALLBACK(ev_key_down), gtklocal); gtk_window_set_title((GtkWindow *) gtklocal->mainwin, gtklocal->title); scrolled_window = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled_window), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(gtklocal->mainwin), scrolled_window); gtklocal->View = gtk_drawing_area_new(); gtk_widget_set_halign(gtklocal->View, GTK_ALIGN_CENTER); gtk_widget_set_valign(gtklocal->View, GTK_ALIGN_CENTER); g_signal_connect(gtklocal->View, "draw", G_CALLBACK(gtkevpaint), gtklocal); g_signal_connect(gtklocal->mainwin, "size-allocate", G_CALLBACK(size_allocate), gtklocal); #if GTK_CHECK_VERSION(3, 8, 0) gtk_container_add(GTK_CONTAINER(scrolled_window), gtklocal->View); #else gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW (scrolled_window), gtklocal->View); #endif gtk_widget_show_all(gtklocal->mainwin); gtklocal->surface= NULL; gtklocal->redraw = TRUE; gtk_widget_add_events(gtklocal->mainwin, GDK_POINTER_MOTION_MASK | GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_PRESS_MASK); g_signal_connect(gtklocal->mainwin, "motion-notify-event", G_CALLBACK(cursor_moved), gtklocal); g_signal_connect(gtklocal->mainwin, "button-release-event", G_CALLBACK(button_released), gtklocal); g_signal_connect(gtklocal->mainwin, "scroll-event", G_CALLBACK(scrolled), gtklocal); if (chkobjfield(obj, "_evloop")) { goto errexit; } idn = getobjtblpos(obj, "_evloop", &robj); if (idn == -1) { goto errexit; } registerevloop(chkobjectname(obj), "_evloop", robj, idn, inst, gtklocal); gtkchangedpi(gtklocal); gtk_evloop(obj, inst, NULL, argc, argv); return 0; errexit: if (gtklocal) { if (gtklocal->mainwin) { gtk_widget_destroy(gtklocal->mainwin); } if (gtklocal->mainwin) { g_free(gtklocal->title); } g_free(gtklocal); } local = gra2cairo_free(obj, inst); g_free(local); return 1; } static int gtkdone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; int idn; struct objlist *robj; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; if (gtklocal->blank_cursor) { g_object_unref(gtklocal->blank_cursor); } if (gtklocal->mainwin != NULL) { gtk_widget_destroy(gtklocal->mainwin); gtklocal->mainwin = NULL; while (gtk_events_pending()) { gtk_main_iteration(); } } if (gtklocal->surface) { cairo_surface_destroy(gtklocal->surface); } idn = getobjtblpos(obj, "_evloop", &robj); if (idn != -1) unregisterevloop(robj, idn, inst); g_free(gtklocal->title); return 0; } static void clear_pixmap(struct gtklocal *local) { cairo_t *cr; cr = cairo_create(local->surface); cairo_set_source_rgb(cr, local->bg_r, local->bg_g, local->bg_b); cairo_paint(cr); cairo_destroy(cr); } static void redraw_window(struct gtklocal *local) { GdkWindow *win; if (local->View == NULL) { return; } win = gtk_widget_get_window(local->View); if (win == NULL) { return; } gdk_window_invalidate_rect(win, NULL, TRUE); } static int gtkclear(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; if (_getobj(obj, "_gtklocal", inst, &local)) return 1; clear_pixmap(local); redraw_window(local); return 0; } static int gtkpresent(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; if (_getobj(obj, "_gtklocal", inst, &local)) return 1; reset_event(); msleep(100); gtk_window_present(GTK_WINDOW(local->mainwin)); return 0; } static int gtkfullscreen(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; int state; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; if (_getobj(obj, "_gtklocal", inst, &local)) return 1; state = *(int *) argv[2]; if (state) { gtk_window_fullscreen(GTK_WINDOW(local->mainwin)); } else { gtk_window_unfullscreen(GTK_WINDOW(local->mainwin)); } return 0; } static int gtkflush(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; if (_getobj(obj, "_gtklocal", inst, &local)) return 1; redraw_window(local); return 0; } static double get_color(struct gtklocal *gtklocal, int argc, char **argv) { int c; c = abs(*(int *) argv[2]); if (c < 0) { c = 0; } else if (c > 255) { c = 255; } return c / 255.0; } static int gtkbr(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; gtklocal->bg_r = get_color(gtklocal, argc, argv); return 0; } static int gtkbb(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; gtklocal->bg_b = get_color(gtklocal, argc, argv); return 0; } static int gtkbg(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; gtklocal->bg_g = get_color(gtklocal, argc, argv); return 0; } static int gtkredraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *gtklocal; if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; redraw_window(gtklocal); return 0; } static int gtk_evloop(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { while (gtk_events_pending()) { gtk_main_iteration(); } return 0; } static int dot2pixel(struct gtklocal *gtklocal, int r) { return nround(r * gtklocal->local->pixel_dot_x); } static void gtkchangedpi(struct gtklocal *gtklocal) { int width, height; cairo_surface_t *pixmap; if ((gtklocal->PaperWidth == 0) || (gtklocal->PaperHeight == 0)) { return; } width = dot2pixel(gtklocal, gtklocal->PaperWidth); height = dot2pixel(gtklocal, gtklocal->PaperHeight); pixmap = gtklocal->surface; if (pixmap) { int pw, ph; ph = cairo_image_surface_get_height(pixmap); pw = cairo_image_surface_get_width(pixmap); if (pw != width || ph != height) { cairo_surface_destroy(pixmap); pixmap = NULL; } } if (pixmap == NULL) { pixmap = cairo_image_surface_create(CAIRO_FORMAT_RGB24, width, height); gtklocal->surface = pixmap; clear_pixmap(gtklocal); gtklocal->redraw = TRUE; if (gtklocal->local->cairo) { cairo_destroy(gtklocal->local->cairo); } gtklocal->local->cairo = cairo_create(pixmap); } gtk_widget_set_size_request(gtklocal->View, width, height); } static void gtkMakeRuler(cairo_t *cr, struct gtklocal *gtklocal) { int width, height; width = gtklocal->PaperWidth; height = gtklocal->PaperHeight; if (width == 0 || height == 0 || gtklocal->surface == NULL || ! gtklocal->frame) return; cairo_save(cr); cairo_set_antialias(cr, CAIRO_ANTIALIAS_NONE); cairo_set_line_width(cr, 1); cairo_set_source_rgb(cr, 0, 0, 0); cairo_rectangle(cr, CAIRO_COORDINATE_OFFSET, CAIRO_COORDINATE_OFFSET, dot2pixel(gtklocal, width) - 1, dot2pixel(gtklocal, height) - 1); cairo_stroke(cr); cairo_restore(cr); } static int gtk_output(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char code; int *cpar; struct gtklocal *gtklocal; code = *(char *) (argv[3]); cpar = (int *) argv[4]; switch (code) { case 'I': if (_getobj(obj, "_gtklocal", inst, >klocal)) return 1; gtklocal->PaperWidth = cpar[3]; gtklocal->PaperHeight = cpar[4]; gtkchangedpi(gtklocal); break; case 'E': break; } if (_exeparent(obj, (char *)argv[1], inst, rval, argc, argv)) return 1; return 0; } static int gtk_set_dpi(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int dpi, fit; struct gtklocal *local; dpi = abs(*(int *) argv[2]); _getobj(obj, "_gtklocal", inst, &local); fit = FALSE; local->fit = FALSE; _putobj(obj, "fit", inst, &fit); if (dpi < 1) dpi = 1; if (dpi > DPI_MAX) dpi = DPI_MAX; local->windpi = dpi; local->local->pixel_dot_x = local->local->pixel_dot_y = dpi / (DPI_MAX * 1.0); *(int *) argv[2] = dpi; gtkchangedpi(local); return 0; } static int gtk_set_fit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int fit; struct gtklocal *local; _getobj(obj, "_gtklocal", inst, &local); fit = *(int *) argv[2]; local->fit = fit; if (fit) { GtkAllocation allocation; gtk_widget_get_allocation(local->mainwin, &allocation); size_allocate(local->mainwin, &allocation, local); } return 0; } static int gtk_set_frame(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; _getobj(obj, "_gtklocal", inst, &local); local->frame = *(int *) argv[2]; return 0; } static int gtk_set_size(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int width, height, size; struct gtklocal *local; _getobj(obj, "_gtklocal", inst, &local); size = *(int *) argv[2]; if (size < 1 || size > WINSIZE_MAX) { return 1; } switch (argv[1][0]) { case 'h': height = size; _getobj(obj, "width", inst, &width); gtk_window_resize(GTK_WINDOW(local->mainwin), width, height); break; case 'w': width = size; _getobj(obj, "height", inst, &height); gtk_window_resize(GTK_WINDOW(local->mainwin), width, height); break; } return 0; } static int gtkwait_action(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct gtklocal *local; char *name; _getobj(obj, "_gtklocal", inst, &local); g_free(rval->str); rval->str = NULL; if (local->mainwin == NULL) { return 1; } if (local->blank_cursor == NULL) { local->blank_cursor = gdk_cursor_new_for_display(gdk_display_get_default(), GDK_BLANK_CURSOR); gdk_window_set_cursor(gtk_widget_get_window(local->mainwin), local->blank_cursor); } local->action.type = ACTION_TYPE_NONE; local->action.val = 0; while (local->action.type == ACTION_TYPE_NONE) { gtk_evloop(NULL, NULL, NULL, 0, NULL); msleep(100); } switch (local->action.type) { case ACTION_TYPE_NONE: break; case ACTION_TYPE_KEY: name = gdk_keyval_name(local->action.val); if (name) { rval->str = g_strdup(name); } break; case ACTION_TYPE_BUTTON: rval->str = g_strdup_printf("button%d", local->action.val); break; case ACTION_TYPE_SCROLL: switch (local->action.val) { case GDK_SCROLL_UP: rval->str = g_strdup("scroll_up"); break; case GDK_SCROLL_DOWN: rval->str = g_strdup("scroll_down"); break; case GDK_SCROLL_LEFT: rval->str = g_strdup("scroll_left"); break; case GDK_SCROLL_RIGHT: rval->str = g_strdup("scroll_right"); break; } break; } return 0; } static struct objtable gra2gtk[] = { {"init", NVFUNC, NEXEC, gtkinit, NULL, 0}, {"done", NVFUNC, NEXEC, gtkdone, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, {"dpi", NINT, NREAD | NWRITE, gtk_set_dpi, NULL, 0}, {"dpix", NINT, NREAD | NWRITE, gtk_set_dpi, NULL, 0}, {"dpiy", NINT, NREAD | NWRITE, gtk_set_dpi, NULL, 0}, {"width", NINT, NREAD | NWRITE, gtk_set_size, NULL, 0}, {"height", NINT, NREAD | NWRITE, gtk_set_size, NULL, 0}, {"fit", NBOOL, NREAD | NWRITE, gtk_set_fit, NULL, 0}, {"frame", NBOOL, NREAD | NWRITE, gtk_set_frame, NULL, 0}, {"expose", NVFUNC, NREAD | NEXEC, gtkredraw, "", 0}, {"flush", NVFUNC, NREAD | NEXEC, gtkflush, "", 0}, {"clear", NVFUNC, NREAD | NEXEC, gtkclear, "", 0}, {"present", NVFUNC, NREAD | NEXEC, gtkpresent, "", 0}, {"fullscreen", NVFUNC, NREAD | NEXEC, gtkfullscreen, "b", 0}, {"BR", NINT, NREAD | NWRITE, gtkbr, NULL, 0}, {"BG", NINT, NREAD | NWRITE, gtkbg, NULL, 0}, {"BB", NINT, NREAD | NWRITE, gtkbb, NULL, 0}, {"wait_action",NSFUNC, NREAD | NEXEC, gtkwait_action, "", 0}, {"_gtklocal", NPOINTER, 0, NULL, NULL, 0}, {"_output", NVFUNC, 0, gtk_output, NULL, 0}, {"_strwidth", NIFUNC, 0, gra2cairo_strwidth, NULL, 0}, {"_charascent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, {"_chardescent", NIFUNC, 0, gra2cairo_charheight, NULL, 0}, {"_evloop", NVFUNC, 0, gtk_evloop, NULL, 0}, }; #define TBLNUM (sizeof(gra2gtk) / sizeof(*gra2gtk)) void * addgra2gtk(void) /* addgra2gtk() returns NULL on error */ { return addobject(NAME, ALIAS, PARENT, NVERSION, TBLNUM, gra2gtk, ERRNUM, gtkerrorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/gtk/x11cood.h0000644000175000017500000000204513351432267013662 00000000000000/* * $Id: x11cood.h,v 1.2 2009-02-06 08:25:14 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ void CoordWinSetFont(const char *font); void CoordWinUpdate(int clear); void CoordWinSetCoord(int x, int y); GtkWidget *CoordWinCreate(struct SubWin *d); ngraph-gtk-6.08.00/src/gtk/Makefile.am0000644000175000017500000001337013351432267014272 00000000000000NGRAPH_ICONS = data/pixmaps/ngraph_align_b.png \ data/pixmaps/ngraph_align_hc.png \ data/pixmaps/ngraph_align_l.png \ data/pixmaps/ngraph_align_r.png \ data/pixmaps/ngraph_align_t.png \ data/pixmaps/ngraph_align_vc.png data/pixmaps/ngraph_icon.png \ data/pixmaps/ngraph_icon64.png data/pixmaps/ngraph_math.png \ data/pixmaps/ngraph_undo.png data/ngraphui.resources.xml \ data/pixmaps/none_begin-symbolic.svg \ data/pixmaps/none_end-symbolic.svg \ data/pixmaps/arrow_begin-symbolic.svg \ data/pixmaps/arrow_end-symbolic.svg \ data/pixmaps/wave_begin-symbolic.svg \ data/pixmaps/wave_end-symbolic.svg \ data/pixmaps/mark_begin-symbolic.svg \ data/pixmaps/mark_end-symbolic.svg \ data/pixmaps/bar_begin-symbolic.svg \ data/pixmaps/bar_end-symbolic.svg \ data/pixmaps/stroke_fill_0-symbolic.svg \ data/pixmaps/stroke_fill_1-symbolic.svg \ data/pixmaps/stroke_fill_2-symbolic.svg \ data/pixmaps/stroke_fill_3-symbolic.svg \ data/pixmaps/stroke_fill_4-symbolic.svg \ data/pixmaps/stroke_fill_5-symbolic.svg \ data/pixmaps/stroke_fill_6-symbolic.svg \ data/pixmaps/stroke_fill_7-symbolic.svg \ data/pixmaps/join_bevel-symbolic.svg \ data/pixmaps/join_miter-symbolic.svg \ data/pixmaps/join_round-symbolic.svg data/pixmaps/ngraph.svg \ data/pixmaps/ngraph_draw-symbolic.svg \ data/pixmaps/ngraph_eval-symbolic.svg \ data/pixmaps/ngraph_line-symbolic.svg \ data/pixmaps/ngraph_single-symbolic.svg \ data/pixmaps/ngraph_arc-symbolic.svg \ data/pixmaps/ngraph_filewin-symbolic.svg \ data/pixmaps/ngraph_mark-symbolic.svg \ data/pixmaps/ngraph_text-symbolic.svg \ data/pixmaps/ngraph_axispoint-symbolic.svg \ data/pixmaps/ngraph_frame-symbolic.svg \ data/pixmaps/ngraph_mergewin-symbolic.svg \ data/pixmaps/ngraph_trimming-symbolic.svg \ data/pixmaps/ngraph_axiswin-symbolic.svg \ data/pixmaps/ngraph_gauss-symbolic.svg \ data/pixmaps/ngraph_point-symbolic.svg \ data/pixmaps/ngraph_zoom-symbolic.svg \ data/pixmaps/ngraph_rect-symbolic.svg \ data/pixmaps/ngraph_cross-symbolic.svg \ data/pixmaps/ngraph_legendpoint-symbolic.svg \ data/pixmaps/ngraph_scale-symbolic.svg \ data/pixmaps/ngraph_datapoint-symbolic.svg \ data/pixmaps/ngraph_section-symbolic.svg \ data/pixmaps/linewidth_002-symbolic.svg \ data/pixmaps/linewidth_004-symbolic.svg \ data/pixmaps/linewidth_008-symbolic.svg \ data/pixmaps/linewidth_016-symbolic.svg \ data/pixmaps/linewidth_032-symbolic.svg \ data/pixmaps/linewidth_064-symbolic.svg \ data/pixmaps/linewidth_128-symbolic.svg EXTRA_DIST = dir_defs.h.in data/css/ngraph.css \ data/gtk/menus-common.ui.in data/gtk/menus-common.ui.osx \ data/gtk/menus-appmenu.ui.in data/gtk/help-overlay.ui \ data/gtk/menus-appmenu.ui.osx data/gtk/menus-tool.ui \ create_completion_info.rb completion_info_functions.txt \ completion_info_constants.txt $(NGRAPH_ICONS) AM_CPPFLAGS = -DLOCALEDIR=\""@localedir@"\" noinst_LTLIBRARIES = libngraphui.la nodist_libngraphui_la_SOURCES = dir_defs.h ngraphui.resources.c libngraphui_la_SOURCES = gtk_common.h gtk_combo.c gtk_combo.h \ gtk_entry_completion.c gtk_entry_completion.h gtk_liststore.c \ gtk_liststore.h gtk_subwin.c gtk_subwin.h ogra2x11.c \ ogra2cairo.c ogra2emf.c ogra2cairo.h ogra2cairofile.c \ ogra2gtkprint.c ogra2cairofile.h ogra2x11.h ogra2gdk.c \ ogra2gdk.h ox11dlg.c ox11menu.c ox11menu.h x11axis.c \ x11axis.h x11bitmp.h x11commn.c x11commn.h x11cood.c \ x11cood.h x11dialg.c x11dialg.h x11file.c x11file.h \ x11graph.c x11graph.h x11gui.c x11gui.h x11info.c x11info.h \ x11lgnd.c x11lgnd.h x11lgndx.c x11menu.c x11menu.h x11merge.c \ x11merge.h x11opt.c x11opt.h x11opt_proto.h x11print.c \ x11print.h x11view.c x11view.h gtk_widget.c gtk_widget.h \ gtk_ruler.c gtk_ruler.h init.c init.h gtk_action.c \ gtk_action.h sourcecompletionwords.c sourcecompletionwords.h \ completion_info.c completion_info.h completion_info_data.c \ gtk_presettings.c gtk_presettings.h if OS_WIN32 APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.in MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.in else if OS_OSX APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.osx MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.osx else APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.in MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.in endif endif uidir = data/gtk $(uidir)/menus-appmenu.ui: $(APPMENU_UI_SOURCE) $(MKDIR_P) $(uidir) cp $< $@ $(uidir)/menus-common.ui: $(MENU_UI_SOURCE) $(MKDIR_P) $(uidir) cp $< $@ ngraphui.resources.c: $(srcdir)/data/ngraphui.resources.xml $(uidir)/menus-common.ui $(srcdir)/data/gtk/menus-tool.ui $(srcdir)/data/css/ngraph.css $(srcdir)/data/gtk/help-overlay.ui $(uidir)/menus-appmenu.ui $(NGRAPH_ICONS) $(GLIB_COMPILE_RESOURCES) --target=$@ --generate-source --sourcedir $(srcdir)/data --sourcedir $(builddir)/data $< BUILT_SOURCES = ${nodist_libngraphui_la_SOURCES} ngraphconfdir = $(sysconfdir)/$(PACKAGE) pixmapdir = $(datadir)/pixmaps/$(PACKAGE) dir_defs.h: dir_defs.h.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/dir_defs.h.in completion_info_data.c: $(srcdir)/completion_info_functions.txt $(srcdir)/completion_info_constants.txt $(srcdir)/create_completion_info.rb ruby $(srcdir)/create_completion_info.rb $(srcdir)/completion_info_functions.txt $(srcdir)/completion_info_constants.txt completion_info_data.c libngraphui_la_CFLAGS = $(GTK_CFLAGS) -I$(top_builddir) -I$(builddir) -I$(srcdir)/.. -I$(srcdir)/../math $(GTKSOURCEVIEW_CFLAGS) libngraphui_la_LDFLAGS = $(GTKSOURCEVIEW_LIBS) CLEANFILES = dir_defs.h $(builddir)/data/gtk/menus-appmenu.ui $(builddir)/data/gtk/menus-common.ui $(BUILT_SOURCES) ngraph-gtk-6.08.00/src/gtk/x11lgndx.c0000644000175000017500000004110213070106167014035 00000000000000/* * $Id: x11lgndx.c,v 1.20 2009-12-17 10:55:44 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include "object.h" #include "gra.h" #include "mathfn.h" #include "spline.h" #include "gtk_combo.h" #include "gtk_widget.h" #include "x11gui.h" #include "x11dialg.h" #include "x11menu.h" #include "ogra2cairo.h" #include "ogra2gdk.h" #include "ox11menu.h" #include "x11commn.h" #define VIEW_SIZE 128 enum LEGEND_DIRECTION { LEGEND_DIRECTION_RIGHT, LEGEND_DIRECTION_LEFT, LEGEND_DIRECTION_BOTTOM, LEGEND_DIRECTION_TOP, }; #define LEGEND_DIRECTION_NUM (LEGEND_DIRECTION_TOP + 1) static double *spx, *spy, *spz; static double *spc[6]; static void LegendGaussDialogScaleH(GtkWidget *w, gpointer client_data); static void LegendGaussDialogDiv(GtkWidget *w, gpointer client_data); #define DIV_MAX 200 #define SCALE_V_MAX 1000.0 #define SCALE_H_MAX 100.0 static void clear_view(struct LegendGaussDialog *d) { GdkWindow *win; win = gtk_widget_get_window(d->view); if (win) { gdk_window_invalidate_rect(win, NULL, TRUE); } } static void LegendGaussDialogSetupItem(GtkWidget *w, struct LegendGaussDialog *d, int id) { int n; SetStyleFromObjField(d->style, d->Obj, id, "style"); SetWidgetFromObjField(d->width, d->Obj, id, "width"); SetWidgetFromObjField(d->join, d->Obj, id, "join"); SetWidgetFromObjField(d->miter, d->Obj, id, "miter_limit"); set_stroke_color(d->color, d->Obj, id); n = d->Dir; if (n >= 0 && n < LEGEND_DIRECTION_NUM) { GtkToggleButton *btn; btn = GTK_TOGGLE_BUTTON(g_slist_nth_data(d->dir_list, n)); gtk_toggle_button_set_active(btn, TRUE); } n = d->Mode; if (n >=0 && n < 4) { GtkToggleButton *btn; btn = GTK_TOGGLE_BUTTON(g_slist_nth_data(d->func_list, n)); gtk_toggle_button_set_active(btn, TRUE); } gtk_range_set_value(GTK_RANGE(d->div), d->Div); gtk_range_set_value(GTK_RANGE(d->sch), d->Position * SCALE_H_MAX); gtk_range_set_value(GTK_RANGE(d->scv), d->Param * SCALE_V_MAX); } static gboolean LegendGaussDialogPaint(GtkWidget *w, cairo_t *cr, gpointer client_data) { struct LegendGaussDialog *d; int i, j, k, pw, dw, minx, miny, maxx, maxy, amp, wd, GC, spnum, output, found; double ppd, x, y = 0, tmp, spc2[6], dashes[] = {4.0}; GdkWindow *win; struct objlist *gobj, *robj; N_VALUE *inst; struct gra2cairo_local *local; cairo_surface_t *pix; d = (struct LegendGaussDialog *) client_data; win = gtk_widget_get_window(w); if (win == NULL) { return FALSE; } found = find_gra2gdk_inst(&gobj, &inst, &robj, &output, &local); if (! found) { return FALSE; } pix = gra2gdk_create_pixmap(local, VIEW_SIZE, VIEW_SIZE, Menulocal.bg_r, Menulocal.bg_g, Menulocal.bg_b); if (pix == NULL) { return FALSE; } pw = VIEW_SIZE - 1; dw = (d->Wdx < d->Wdy) ? d->Wdy : d->Wdx; ppd = pw / ((double) dw); minx = VIEW_SIZE / 2 - d->Wdx * ppd / 2; miny = VIEW_SIZE / 2 - d->Wdy * ppd / 2; maxx = VIEW_SIZE / 2 + d->Wdx * ppd / 2; maxy = VIEW_SIZE / 2 + d->Wdy * ppd / 2; switch (d->Dir) { case LEGEND_DIRECTION_TOP: case LEGEND_DIRECTION_BOTTOM: amp = d->Wdy; wd = d->Wdx; break; default: amp = d->Wdx; wd = d->Wdy; } if (d->alloc) { GC = _GRAopen("gra2gdk", "_output", robj, inst, output, -1, -1, -1, NULL, local); GRAlinestyle(GC, 0, NULL, 1, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); if (GC >= 0) { GRAview(GC, minx, miny, maxx, maxy, 1); if (d->Div > DIV_MAX) { d->Div = DIV_MAX; } for (i = 0; i <= (d->Div); i++) { x = wd / ((double) (d->Div)) * i; if (d->Mode == 0) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd / (1 + 10 * d->Param) / 2); y = amp * exp(-tmp * tmp); } else if (d->Mode == 1) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd / (1 + 10 * d->Param) / 2); y = amp / (tmp * tmp + 1); } else if (d->Mode == 2) { if (d->Position >= 0) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (-wd * 0.5 - wd * d->Position * 0.5); } else { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd * 0.5 - wd * d->Position * 0.5); } y = amp * tmp * tmp; } else if (d->Mode == 3) { tmp = x / (wd / (0.25 + 10 * d->Param)); y = amp * 0.5 * (sin(2.0 * MPI * (tmp - d->Position * 0.5)) + 1); } switch (d->Dir) { case LEGEND_DIRECTION_TOP: spx[i] = nround(x); spy[i] = d->Wdy - nround(y); break; case LEGEND_DIRECTION_BOTTOM: spx[i] = nround(x); spy[i] = nround(y); break; case LEGEND_DIRECTION_LEFT: spx[i] = d->Wdx - nround(y); spy[i] = d->Wdy - nround(x); break; case LEGEND_DIRECTION_RIGHT: spx[i] = nround(y); spy[i] = d->Wdy - nround(x); break; default: /* never reached*/ spx[i] = 0; spy[i] = 0; } spz[i] = i; spx[i] *= ppd; spy[i] *= ppd; } spnum = d->Div + 1; spline(spz, spx, spc[0], spc[1], spc[2], spnum, SPLCND2NDDIF, SPLCND2NDDIF, 0, 0); spline(spz, spy, spc[3], spc[4], spc[5], spnum, SPLCND2NDDIF, SPLCND2NDDIF, 0, 0); GRAcolor(GC, 0, 0, 0, 255); GRAcurvefirst(GC, 0, NULL, NULL, NULL, splinedif, splineint, NULL, spx[0], spy[0]); for (j = 0; j < spnum - 1; j++) { for (k = 0; k < 6; k++) { spc2[k] = spc[k][j]; } if (! GRAcurve(GC, spc2, spx[j], spy[j])) { break; } } } _GRAclose(GC); gra2cairo_draw_path(local); } cairo_set_source_surface(cr, pix, 0, 0); cairo_paint(cr); cairo_set_source_rgb(cr, 0, 0, 0); cairo_set_antialias(cr, CAIRO_ANTIALIAS_NONE); cairo_set_line_width(cr, 1); cairo_set_dash(cr, dashes, sizeof(dashes) / sizeof(*dashes), 0); cairo_rectangle(cr, minx + CAIRO_COORDINATE_OFFSET, miny + CAIRO_COORDINATE_OFFSET, maxx - minx, maxy - miny); cairo_stroke(cr); cairo_surface_destroy(pix); return FALSE; } static void LegendGaussDialogScaleV(GtkWidget *w, gpointer client_data) { struct LegendGaussDialog *d; d = (struct LegendGaussDialog *) client_data; d->Param = gtk_range_get_value(GTK_RANGE(w)) / SCALE_V_MAX; clear_view(d); } static void LegendGaussDialogScaleH(GtkWidget *w, gpointer client_data) { struct LegendGaussDialog *d; d = (struct LegendGaussDialog *) client_data; d->Position = gtk_range_get_value(GTK_RANGE(w)) / SCALE_H_MAX; clear_view(d); } static int get_radio_index(GSList *top) { int i, n; GtkToggleButton *btn; GSList *list; n = g_slist_length(top); for (i = 0, list = top; i < n; i++, list = list->next) { btn = GTK_TOGGLE_BUTTON(list->data); if (gtk_toggle_button_get_active(btn)) { return i; } } return -1; } static void LegendGaussDialogMode(GtkWidget *w, gpointer client_data) { struct LegendGaussDialog *d; int i; gboolean active; active = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w)); if (! active) return; d = (struct LegendGaussDialog *) client_data; i = get_radio_index(d->func_list); if (i < 0) return; d->Mode = i; clear_view(d); } static void LegendGaussDialogDir(GtkWidget *w, gpointer client_data) { int i; struct LegendGaussDialog *d; gboolean active; active = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w)); if (! active) return; d = (struct LegendGaussDialog *) client_data; i= get_radio_index(d->dir_list); if (i < 0 || i >= LEGEND_DIRECTION_NUM) return; d->Dir = i; clear_view(d); } static void LegendGaussDialogDiv(GtkWidget *w, gpointer client_data) { struct LegendGaussDialog *d; d = (struct LegendGaussDialog *) client_data; d->Div = gtk_range_get_value(GTK_RANGE(w)); clear_view(d); } static void LegendGaussDialogSetup(GtkWidget *wi, void *data, int makewidget) { GtkWidget *w, *button, *hbox, *hbox2, *vbox, *table; GSList *func_list, *dir_list; struct LegendGaussDialog *d; char title[256]; int i; d = (struct LegendGaussDialog *) data; snprintf(title, sizeof(title), _("Legend Gaussian/Lorentzian/Parabola/Sin %d"), d->Id); gtk_window_set_title(GTK_WINDOW(wi), title); if (makewidget) { hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); button = NULL; button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), _("_Sin")); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogMode), d); gtk_box_pack_end(GTK_BOX(hbox), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), _("_Parabola")); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogMode), d); gtk_box_pack_end(GTK_BOX(hbox), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), _("_Lorentz")); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogMode), d); gtk_box_pack_end(GTK_BOX(hbox), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), _("_Gauss")); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogMode), d); gtk_box_pack_end(GTK_BOX(hbox), button, FALSE, FALSE, 0); func_list = gtk_radio_button_get_group(GTK_RADIO_BUTTON(button)); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, FALSE, FALSE, 0); d->func_list = func_list; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); table = gtk_grid_new(); i = 0; w = combo_box_entry_create(); add_widget_to_table(table, w, _("Line _Style:"), TRUE, i++); d->style = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_WIDTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Line Width:"), FALSE, i++); d->width = w; w = create_spin_entry_type(SPIN_BUTTON_TYPE_LENGTH, TRUE, TRUE); add_widget_to_table(table, w, _("_Miter:"), FALSE, i++); d->miter = w; w = combo_box_create(); add_widget_to_table(table, w, _("_Join:"), FALSE, i++); d->join = w; w = create_color_button(wi); add_widget_to_table(table, w, _("_Color:"), FALSE, i++); d->color = w; w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 10, DIV_MAX, 1); set_scale_mark(w, GTK_POS_BOTTOM, 20, 20); add_widget_to_table(table, w, _("_Division:"), TRUE, i++); g_signal_connect(w, "value-changed", G_CALLBACK(LegendGaussDialogDiv), d); d->div = w; hbox2 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); button = NULL; button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), "_T"); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogDir), d); gtk_box_pack_start(GTK_BOX(hbox2), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), "_B"); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogDir), d); gtk_box_pack_start(GTK_BOX(hbox2), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), "_L"); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogDir), d); gtk_box_pack_start(GTK_BOX(hbox2), button, FALSE, FALSE, 0); button = gtk_radio_button_new_with_mnemonic_from_widget(GTK_RADIO_BUTTON(button), "_R"); g_signal_connect(button, "toggled", G_CALLBACK(LegendGaussDialogDir), d); gtk_box_pack_start(GTK_BOX(hbox2), button, FALSE, FALSE, 0); dir_list = gtk_radio_button_get_group(GTK_RADIO_BUTTON(button)); d->dir_list = dir_list; add_widget_to_table(table, hbox2, _("Direction:"), TRUE, i++); gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 0); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, SCALE_V_MAX, 1); set_scale_mark(w, GTK_POS_BOTTOM, 100, 200); g_signal_connect(w, "value-changed", G_CALLBACK(LegendGaussDialogScaleV), d); d->scv = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); w = gtk_drawing_area_new(); d->view = w; gtk_widget_set_size_request(w, VIEW_SIZE, VIEW_SIZE); g_signal_connect(w, "draw", G_CALLBACK(LegendGaussDialogPaint), d); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); w = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, - SCALE_H_MAX, SCALE_H_MAX, 1); set_scale_mark(w, GTK_POS_TOP, -100, 25); g_signal_connect(w, "value-changed", G_CALLBACK(LegendGaussDialogScaleH), d); d->sch = w; gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(d->vbox), hbox, TRUE, TRUE, 0); gtk_widget_show_all(GTK_WIDGET(d->vbox)); } LegendGaussDialogSetupItem(wi, d, d->Id); } static void LegendGaussDialogClose(GtkWidget *w, void *data) { struct LegendGaussDialog *d; int ret, a, i, amp, wd, gx, gy; double x, y = 0, tmp; struct narray *parray; d = (struct LegendGaussDialog *) data; if (d->ret != IDOK) return; ret = d->ret; d->ret = IDLOOP; if (SetObjFieldFromStyle(d->style, d->Obj, d->Id, "style")) return; if (SetObjFieldFromWidget(d->width, d->Obj, d->Id, "width")) return; if (SetObjFieldFromWidget(d->join, d->Obj, d->Id, "join")) return; if (SetObjFieldFromWidget(d->miter, d->Obj, d->Id, "miter_limit")) return; if (putobj_stroke_color(d->color, d->Obj, d->Id)) return; switch (d->Dir) { case LEGEND_DIRECTION_TOP: case LEGEND_DIRECTION_BOTTOM: amp = d->Wdy; wd = d->Wdx; break; default: amp = d->Wdx; wd = d->Wdy; } parray = arraynew(sizeof(int)); for (i = 0; i <= d->Div; i++) { x = wd / ((double) (d->Div)) * i; if (d->Mode == 0) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd / (1 + 10 * d->Param) / 2); y = amp * exp(-tmp * tmp); } else if (d->Mode == 1) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd / (1 + 10 * d->Param) / 2); y = amp / (tmp * tmp + 1); } else if (d->Mode == 2) { if (d->Position >= 0) { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (-wd * 0.5 - wd * d->Position * 0.5); } else { tmp = (x - wd * 0.5 - wd * d->Position * 0.5) / (wd * 0.5 - wd * d->Position * 0.5); } y = amp * tmp * tmp; } else if (d->Mode == 3) { tmp = x / (wd / (0.25 + 10 * d->Param)); y = amp * 0.5 * (sin(2.0 * MPI * (tmp - d->Position * 0.5)) + 1); } switch (d->Dir) { case LEGEND_DIRECTION_TOP: gx = nround(x); gy = d->Wdy - nround(y); break; case LEGEND_DIRECTION_BOTTOM: gx = nround(x); gy = nround(y); break; case LEGEND_DIRECTION_LEFT: gx = d->Wdx - nround(y); gy = d->Wdy - nround(x); break; case LEGEND_DIRECTION_RIGHT: gx = nround(y); gy = d->Wdy - nround(x); break; default: /* never reached */ gx = 0; gy = 0; } gx += d->Minx; gy += d->Miny; arrayadd(parray, &gx); arrayadd(parray, &gy); } putobj(d->Obj, "points", d->Id, parray); a = 0; putobj(d->Obj, "interpolation", d->Id, &a); d->ret = ret; for (i = 0; i < 6; i++) g_free(spc[i]); g_free(spz); g_free(spy); g_free(spx); } void LegendGaussDialog(struct LegendGaussDialog *data, struct objlist *obj, int id, int minx, int miny, int wdx, int wdy) { int i; data->SetupWindow = LegendGaussDialogSetup; data->CloseWindow = LegendGaussDialogClose; data->Obj = obj; data->Id = id; data->Minx = minx; data->Miny = miny; data->Wdx = wdx; data->Wdy = wdy; data->Div = 20; data->Position = 0; data->Param = 0.175; data->Dir = LEGEND_DIRECTION_TOP; data->Mode = 0; data->alloc = TRUE; spx = (double *) g_malloc(sizeof(double) * (DIV_MAX + 1)); if (spx == NULL) data->alloc = FALSE; spy = (double *) g_malloc(sizeof(double) * (DIV_MAX + 1)); if (spy == NULL) data->alloc = FALSE; spz = (double *) g_malloc(sizeof(double) * (DIV_MAX + 1)); if (spz == NULL) data->alloc = FALSE; for (i = 0; i < 6; i++) { spc[i] = (double *) g_malloc(sizeof(double) * (DIV_MAX + 1)); if (spc[i] == NULL) { data->alloc = FALSE; } } } ngraph-gtk-6.08.00/src/gtk/x11file.h0000644000175000017500000000352713351432267013663 00000000000000/* * $Id: x11file.h,v 1.4 2009-07-26 13:01:40 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ struct evaltype { int id; int line; double x, y; }; const char *get_plot_info_str(struct objlist *obj, int id, int src); void FileWinUpdate(struct obj_list_data *data, int clear, int draw); void CmFileHistory(GtkRecentChooser *w, gpointer client_data); void CmRangeAdd(void *w, gpointer client_data); void CmFileNew(void *w, gpointer client_data); void CmFileOpen(void *w, gpointer client_data); void CmFileClose(void *w, gpointer client_data); void CmFileUpdate(void *w, gpointer client_data); void CmFileEdit(void *w, gpointer client_data); void CmFileMath(void *w, gpointer client_data); void CmFileSaveData(void *w, gpointer client_data); GtkWidget *dreate_data_list(struct SubWin *d); void CmOptionFileDef(void *w, gpointer client_data); int update_file_obj_multi(struct objlist *obj, struct narray *farray, int newfile); void copy_file_obj_field(struct objlist *obj, int id, int sel, int copy_filename); void button_set_mark_image(GtkWidget *w, int type); ngraph-gtk-6.08.00/src/gtk/x11commn.c0000644000175000017500000012366313234053141014042 00000000000000/* * $Id: x11commn.c,v 1.60 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "gtk_common.h" #include #include #include #include #include #include #include #include #include #include "dir_defs.h" #include "object.h" #include "ioutil.h" #include "shell.h" #include "nstring.h" #include "odata.h" #include "odraw.h" #include "nconfig.h" #include "init.h" #include "gtk_widget.h" #include "x11gui.h" #include "x11graph.h" #include "x11dialg.h" #include "ox11menu.h" #include "x11menu.h" #include "x11commn.h" #include "x11info.h" #include "x11file.h" #include "x11view.h" #define COMMENT_BUF_SIZE 1024 static GtkWidget *ProgressDialog = NULL; static GtkProgressBar *ProgressBar, *ProgressBar2; static unsigned int SaveCursor; static void AddNgpFileList(const char *file); static void ToFullPath(void); static void ToBasename(void); static void ToRalativePath(void); void OpenGRA(void) { unsigned int j; int i, id, otherGC; char *device, *name, *name_str = "viewer"; struct narray *drawrable; N_VALUE *gra_inst; gra_inst = chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid); if (gra_inst) { return; } CloseGRA(); for (i = chkobjlastinst(Menulocal.GRAobj); i >= 0; i--) { getobj(Menulocal.GRAobj, "GC", i, 0, NULL, &otherGC); if (otherGC < 0) break; } if (i == -1) { /* closed gra object is not found. generate new gra object */ id = newobj(Menulocal.GRAobj); gra_inst = chkobjinst(Menulocal.GRAobj, id); _getobj(Menulocal.GRAobj, "oid", gra_inst, &(Menulocal.GRAoid)); /* set page settings */ putobj(Menulocal.GRAobj, "paper_width", id, &(Menulocal.PaperWidth)); putobj(Menulocal.GRAobj, "paper_height", id, &(Menulocal.PaperHeight)); putobj(Menulocal.GRAobj, "left_margin", id, &(Menulocal.LeftMargin)); putobj(Menulocal.GRAobj, "top_margin", id, &(Menulocal.TopMargin)); putobj(Menulocal.GRAobj, "zoom", id, &(Menulocal.PaperZoom)); CheckPage(); } else { /* find closed gra object */ id = i; gra_inst = chkobjinst(Menulocal.GRAobj, id); _getobj(Menulocal.GRAobj, "oid", gra_inst, &(Menulocal.GRAoid)); /* get page settings */ CheckPage(); } if (arraynum(&(Menulocal.drawrable)) > 0) { drawrable = arraynew(sizeof(char *)); for (j = 0; j < arraynum(&(Menulocal.drawrable)); j++) { arrayadd2(drawrable, *(char **)arraynget(&(Menulocal.drawrable), j)); } } else { drawrable = NULL; } putobj(Menulocal.GRAobj, "draw_obj", id, drawrable); device = g_strdup("menu:0"); putobj(Menulocal.GRAobj, "device", id, device); name = g_strdup(name_str); putobj(Menulocal.GRAobj, "name", id, name); getobj(Menulocal.GRAobj, "open", id, 0, NULL, &(Menulocal.GC)); } void CheckPage(void) { N_VALUE *gra_inst; gra_inst = chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid); if (gra_inst == NULL) { return; } _getobj(Menulocal.GRAobj, "paper_width", gra_inst, &(Menulocal.PaperWidth)); _getobj(Menulocal.GRAobj, "paper_height", gra_inst, &(Menulocal.PaperHeight)); _getobj(Menulocal.GRAobj, "left_margin", gra_inst, &(Menulocal.LeftMargin)); _getobj(Menulocal.GRAobj, "top_margin", gra_inst, &(Menulocal.TopMargin)); _getobj(Menulocal.GRAobj, "zoom", gra_inst, &(Menulocal.PaperZoom)); set_paper_type(Menulocal.PaperWidth, Menulocal.PaperHeight); } static int ValidGRA(void) { int id; struct objlist *graobj; N_VALUE *inst; if ((graobj = chkobject("gra")) == NULL) return -1; id = -1; if ((inst = chkobjinstoid(graobj, Menulocal.GRAoid)) != NULL) _getobj(graobj, "id", inst, &id); if (id == -1) id = chkobjlastinst(graobj); return id; } void CloseGRA(void) { int id; N_VALUE *gra_inst; gra_inst = chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid); if (gra_inst == NULL) { return; } _getobj(Menulocal.GRAobj, "id", gra_inst, &id); exeobj(Menulocal.GRAobj, "close", id, 0, NULL); delobj(Menulocal.GRAobj, id); Menulocal.GRAoid = -1; } void ChangeGRA(void) { int i, otherGC; /* search for closed gra object */ for (i = chkobjlastinst(Menulocal.GRAobj); i >= 0; i--) { getobj(Menulocal.GRAobj, "GC", i, 0, NULL, &otherGC); if (otherGC < 0) break; } if (i == -1) { /* closed gra is not find. maintain present gra object */ if (chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid) == NULL) { ChangePage(); } } else { /* use closed gra object */ ChangePage(); } CheckPage(); } void SetPageSettingsToGRA(void) { int i, j, num, otherGC, id; struct objlist *obj; N_VALUE *inst; struct narray *drawrable; if ((obj = chkobject("gra")) == NULL) return; for (i = chkobjlastinst(obj); i >= 0; i--) { getobj(obj, "GC", i, 0, NULL, &otherGC); if (otherGC < 0) break; } if (i >= 0) { id = i; inst = chkobjinst(obj, id); putobj(obj, "paper_width", id, &(Menulocal.PaperWidth)); putobj(obj, "paper_height", id, &(Menulocal.PaperHeight)); putobj(obj, "left_margin", id, &(Menulocal.LeftMargin)); putobj(obj, "top_margin", id, &(Menulocal.TopMargin)); putobj(obj, "zoom", id, &(Menulocal.PaperZoom)); _getobj(obj, "draw_obj", inst, &drawrable); arrayfree2(drawrable); drawrable = arraynew(sizeof(char *)); num = arraynum(&(Menulocal.drawrable)); for (j = 0; j < num; j++) { arrayadd2(drawrable, *(char **) arraynget(&(Menulocal.drawrable), j)); } _putobj(obj, "draw_obj", inst, drawrable); } } void GetPageSettingsFromGRA(void) { int i, j, num, otherGC, id; struct objlist *obj, *dobj; N_VALUE *inst; struct narray *drawrable; if ((obj = chkobject("gra")) == NULL) return; for (i = chkobjlastinst(obj); i >= 0; i--) { getobj(obj, "GC", i, 0, NULL, &otherGC); if (otherGC < 0) break; } if (i >= 0) { id = i; inst = chkobjinst(obj, id); CheckPage(); _getobj(obj, "draw_obj", inst, &drawrable); arraydel2(&(Menulocal.drawrable)); num = arraynum(drawrable); if (num == 0) { menuadddrawrable(chkobject("draw"), &(Menulocal.drawrable)); } else { char *name; for (j = 0; j < num; j++) { name = arraynget_str(drawrable, j); if (name == NULL) { continue; } dobj = chkobject(name); if (dobj == NULL) { continue; } arrayadd2(&(Menulocal.drawrable), chkobjectname(dobj)); } arrayuniq_all_str(&(Menulocal.drawrable)); } } ChangeGRA(); } static int get_new_axis_id(struct objlist *obj, struct objlist **aobj, int fid, int id, int a) { int spc, aid = 0; char *axis; struct narray iarray; int anum; if (getobj(obj, (a == AXIS_X) ? "axis_x" : "axis_y", fid, 0, NULL, &axis) < 0) { return -1; } if (axis == NULL) { return -1; } arrayinit(&iarray, sizeof(int)); if (getobjilist(axis, aobj, &iarray, FALSE, &spc)) { return -1; } anum = arraynum(&iarray); if (anum > 0 && spc == OBJ_LIST_SPECIFIED_BY_ID) { aid = arraylast_int(&iarray); if (aid > id) { aid--; } } else { aid = -1; } arraydel(&iarray); return aid; } static void AxisDel2(int id) { struct objlist *obj, *aobj; int i, aid1, aid2; char *axis2; N_VALUE *inst; obj = getobject("axisgrid"); if (obj) { for (i = chkobjlastinst(obj); i >= 0; i--) { inst = chkobjinst(obj, i); if (inst == NULL) { continue; } aid1 = get_axis_id(obj, inst, &aobj, AXIS_X); if (aid1 == id) { delobj(obj, i); continue; } aid1 = get_axis_id(obj, inst, &aobj, AXIS_Y); if (aid1 == id) { delobj(obj, i); } } } obj = getobject("data"); if (obj == NULL) { return; } for (i = 0; i <= chkobjlastinst(obj); i++) { aid1 = get_new_axis_id(obj, &aobj, i, id, AXIS_X); aid2 = get_new_axis_id(obj, &aobj, i, id, AXIS_Y); if ((aid1 >= 0) && (aid2 >= 0)) { if (aid1 == aid2) { aid2 = aid1 + 1; } axis2 = g_strdup_printf("%s:%d", chkobjectname(aobj), aid1); if (axis2) { putobj(obj, "axis_x", i, axis2); } axis2 = g_strdup_printf("%s:%d", chkobjectname(aobj), aid2); if (axis2) { putobj(obj, "axis_y", i, axis2); } } } } void AxisDel(int id) { struct objlist *obj; int i, lastinst, *id_array, n; char *group, *group2; char type; N_VALUE *inst, *inst2; char group3[20]; obj = chkobject("axis"); if (obj == NULL) return; inst = chkobjinst(obj, id); if (inst == NULL) return; _getobj(obj, "group", inst, &group); if (group == NULL || group[0] == 'a') { AxisDel2(id); delobj(obj, id); return; } lastinst = chkobjlastinst(obj); type = group[0]; strncpy(group3, group, sizeof(group3) - 1); group3[sizeof(group3) - 1] = '\0'; id_array = g_malloc(sizeof(*id_array) * (lastinst + 1)); if (id_array == NULL) return; n = 0; for (i = lastinst; i >= 0; i--) { inst2 = chkobjinst(obj, i); _getobj(obj, "group", inst2, &group2); if (group2 && group2[0] == type) { if (strcmp(group3 + 2, group2 + 2) == 0) { AxisDel2(i); id_array[n] = i; n++; } } } for (i = 0; i < n; i++) { delobj(obj, id_array[i]); } g_free(id_array); } static void axis_move_each_obj(char *axis_str, int i, struct objlist *obj, int id1, int id2) { struct objlist *aobj; int spc, aid; char *axis, *axis2; struct narray iarray; int anum; if (getobj(obj, axis_str, i, 0, NULL, &axis) < 0 || axis == NULL) return; arrayinit(&iarray, sizeof(int)); if (getobjilist(axis, &aobj, &iarray, FALSE, &spc)) return; anum = arraynum(&iarray); if (anum > 0 && spc == OBJ_LIST_SPECIFIED_BY_ID) { aid = arraylast_int(&iarray); if (aid == id1) { aid = id2; } else { if (aid > id1) aid--; if (aid >= id2) aid++; } axis2 = g_strdup_printf("%s:%d", chkobjectname(aobj), aid); if (axis2) { putobj(obj, axis_str, i, axis2); } } arraydel(&iarray); } void AxisMove(int id1, int id2) { struct objlist *obj; int i; if ((obj = getobject("data")) == NULL) return; for (i = 0; i <= chkobjlastinst(obj); i++) { axis_move_each_obj("axis_x", i, obj, id1, id2); axis_move_each_obj("axis_y", i, obj, id1, id2); } } static void AxisNameToGroup(void) /* this function may exist for compatibility with older version. */ { int idx, idy, idu, idr; int findX, findY, findU, findR, graphtype; int id, id2, num; struct objlist *obj; char *name, *name2, *gp; struct narray group, iarray; int a, j, anum; char *argv[2]; int *data; N_VALUE *inst; if ((obj = (struct objlist *) chkobject("axis")) == NULL) return; num = chkobjlastinst(obj); arrayinit(&iarray, sizeof(int)); for (id = 0; id <= num; id++) { anum = arraynum(&iarray); data = arraydata(&iarray); for (j = 0; j < anum; j++) if (data[j] == id) break; inst = chkobjinst(obj, id); _getobj(obj, "name", inst, &name); _getobj(obj, "group", inst, &gp); if ((j == anum) && (gp[0] == 'a')) { findX = findY = findU = findR = FALSE; graphtype = -1; if (name != NULL) { if (strncmp(name, "sectionX", 8) == 0) { graphtype = 0; findX = TRUE; idx = id; } else if (strncmp(name, "sectionY", 8) == 0) { graphtype = 0; findY = TRUE; idy = id; } else if (strncmp(name, "sectionU", 8) == 0) { graphtype = 0; findU = TRUE; idu = id; } else if (strncmp(name, "sectionR", 8) == 0) { graphtype = 0; findR = TRUE; idr = id; } else if (strncmp(name, "frameX", 6) == 0) { graphtype = 1; findX = TRUE; idx = id; } else if (strncmp(name, "frameY", 6) == 0) { graphtype = 1; findY = TRUE; idy = id; } else if (strncmp(name, "frameU", 6) == 0) { graphtype = 1; findU = TRUE; idu = id; } else if (strncmp(name, "frameR", 6) == 0) { graphtype = 1; findR = TRUE; idr = id; } else if (strncmp(name, "crossX", 6) == 0) { graphtype = 2; findX = TRUE; idx = id; } else if (strncmp(name, "crossY", 6) == 0) { graphtype = 2; findY = TRUE; idy = id; } } for (id2 = id + 1; id2 <= num; id2++) { for (j = 0; j < anum; j++) if (data[j] == id2) break; inst = chkobjinst(obj, id2); _getobj(obj, "name", inst, &name2); _getobj(obj, "group", inst, &gp); if ((j == anum) && (gp[0] == 'a')) { if (graphtype == 0) { if (name2 != NULL) { if ((strncmp(name2, "sectionX", 8) == 0) && (strcmp(name + 8, name2 + 8) == 0)) { findX = TRUE; idx = id2; } else if ((strncmp(name2, "sectionY", 8) == 0) && (strcmp(name + 8, name2 + 8) == 0)) { findY = TRUE; idy = id2; } else if ((strncmp(name2, "sectionU", 8) == 0) && (strcmp(name + 8, name2 + 8) == 0)) { findU = TRUE; idu = id2; } else if ((strncmp(name2, "sectionR", 8) == 0) && (strcmp(name + 8, name2 + 8) == 0)) { findR = TRUE; idr = id2; } } } else if (graphtype == 1) { if (name2 != NULL) { if ((strncmp(name2, "frameX", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findX = TRUE; idx = id2; } else if ((strncmp(name2, "frameY", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findY = TRUE; idy = id2; } else if ((strncmp(name2, "frameU", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findU = TRUE; idu = id2; } else if ((strncmp(name2, "frameR", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findR = TRUE; idr = id2; } } } else if (graphtype == 2) { if (name2 != NULL) { if ((strncmp(name2, "crossX", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findX = TRUE; idx = id2; } else if ((strncmp(name2, "crossY", 6) == 0) && (strcmp(name + 6, name2 + 6) == 0)) { findY = TRUE; idy = id2; } } } } } if ((graphtype == 0) && findX && findY && findU && findR) { arrayinit(&group, sizeof(int)); a = 2; arrayadd(&group, &a); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &idu); arrayadd(&group, &idr); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "grouping", id, 1, argv); arraydel(&group); arrayadd(&iarray, &idx); arrayadd(&iarray, &idy); arrayadd(&iarray, &idu); arrayadd(&iarray, &idr); } else if ((graphtype == 1) && findX && findY && findU && findR) { arrayinit(&group, sizeof(int)); a = 1; arrayadd(&group, &a); arrayadd(&group, &idx); arrayadd(&group, &idy); arrayadd(&group, &idu); arrayadd(&group, &idr); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "grouping", id, 1, argv); arraydel(&group); arrayadd(&iarray, &idx); arrayadd(&iarray, &idy); arrayadd(&iarray, &idu); arrayadd(&iarray, &idr); } else if ((graphtype == 2) && findX && findY) { arrayinit(&group, sizeof(int)); a = 3; arrayadd(&group, &a); arrayadd(&group, &idx); arrayadd(&group, &idy); argv[0] = (char *) &group; argv[1] = NULL; exeobj(obj, "grouping", id, 1, argv); arraydel(&group); arrayadd(&iarray, &idx); arrayadd(&iarray, &idy); } } } arraydel(&iarray); } static void field_obj_del(struct objlist *obj, int id, const char *field) { char *fit; struct objlist *fitobj; int fitid, idnum, i; struct narray iarray; if ((getobj(obj, field, id, 0, NULL, &fit) >= 0) && (fit != NULL)) { arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &fitobj, &iarray, FALSE, NULL) == 0) { idnum = arraynum(&iarray); arraysort_int(&iarray); for (i = idnum - 1; i >= 0; i--) { fitid = arraynget_int(&iarray, i); delobj(fitobj, fitid); } } arraydel(&iarray); } } void FitDel(struct objlist *obj, int id) { field_obj_del(obj, id, "fit"); } void ArrayDel(struct objlist *obj, int id) { field_obj_del(obj, id, "array"); } void FitCopy(struct objlist *obj, int did, int sid) { char *fit; struct objlist *fitobj; int fitid; struct narray iarray; struct narray iarray2; int id2, idnum, idnum2; char *field[] = {"name", "equation", NULL}; int fitoid; N_VALUE *inst; if ((getobj(obj, "fit", sid, 0, NULL, &fit) >= 0) && (fit != NULL)) { arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &fitobj, &iarray, FALSE, NULL) == 0) { idnum = arraynum(&iarray); if (idnum >= 1) { fitid = arraylast_int(&iarray); if ((getobj(obj, "fit", did, 0, NULL, &fit) >= 0) && (fit != NULL)) { arrayinit(&iarray2, sizeof(int)); if (getobjilist(fit, &fitobj, &iarray2, FALSE, NULL) == 0) { idnum2 = arraynum(&iarray2); if (idnum2 >= 1) { id2 = arraylast_int(&iarray2); } else id2 = newobj(fitobj); } else id2 = newobj(fitobj); arraydel(&iarray2); } else id2 = newobj(fitobj); if (id2 >= 0) { copy_obj_field(fitobj, id2, fitid, field); inst = getobjinst(fitobj, id2); _getobj(fitobj, "oid", inst, &fitoid); if ((fit = mkobjlist(fitobj, NULL, fitoid, NULL, TRUE)) != NULL) { if (putobj(obj, "fit", did, fit) == -1) g_free(fit); } } } } arraydel(&iarray); } } void FitClear(void) { struct objlist *obj, *fitobj; int i, anum, id, hidden; char *fit; struct narray iarray; if (Menulock || Globallock) return; if ((obj = chkobject("data")) == NULL) return; if ((fitobj = chkobject("fit")) == NULL) return; for (i = 0; i <= chkobjlastinst(obj); i++) { getobj(obj, "fit", i, 0, NULL, &fit); if (fit == NULL) { continue; } arrayinit(&iarray, sizeof(int)); if (getobjilist(fit, &fitobj, &iarray, FALSE, NULL) == 0) { anum = arraynum(&iarray); if (anum >= 1) { id = arraylast_int(&iarray); getobj(obj, "hidden", i, 0, NULL, &hidden); if (! hidden) { putobj(fitobj, "equation", id, NULL); } } arraydel(&iarray); } } } static void del_darray(struct objlist *data_obj) { char *array; int i, j, n, id, last; struct array_prm ary; struct narray *id_array; struct objlist *darray_obj; darray_obj = chkobject("darray"); if (darray_obj == NULL) { return; } last = chkobjlastinst(data_obj); if (last < 0) { return; } id_array = arraynew(sizeof(int)); if (id_array == NULL) { return; } for (i = 0; i <= last; i++) { getobj(data_obj, "array", i, 0, NULL, &array); if (array == NULL) { continue; } open_array(array, &ary); for (j = 0; j < ary.col_num; j++) { arrayadd(id_array, &ary.id[j]); } } arraysort_int(id_array); arrayuniq_int(id_array); n = arraynum(id_array); for (i = 0; i < n; i++) { id = arraynget_int(id_array, n - 1 - i); delobj(darray_obj, id); } arrayfree(id_array); } void DeleteDrawable(void) { struct objlist *fileobj, *drawobj; int i; fileobj = chkobject("data"); if (fileobj) { for (i = 0; i <= chkobjlastinst(fileobj); i++) { FitDel(fileobj, i); } del_darray(fileobj); } drawobj = chkobject("draw"); if (drawobj) { delchildobj(drawobj); } } static void store_file(struct objlist *ocur, int hFile, int i) { char *s, *fname, *fname2; int j; N_VALUE *inst; getobj(ocur, "file", i, 0, NULL, &fname); if (fname == NULL) { return; } for (j = i - 1; j >= 0; j--) { getobj(ocur, "file", j, 0, NULL, &fname2); if ((fname2 != NULL) && (strcmp0(fname, fname2) == 0)) { break; } } inst = chkobjinst(ocur, i); if (j == -1) { while (_exeobj(ocur, "store_data", inst, 0, NULL) == 0) { _getobj(ocur, "store_data", inst, &s); nwrite(hFile, s, strlen(s)); nwrite(hFile, "\n", 1); } } else { while (_exeobj(ocur, "store_dummy", inst, 0, NULL) == 0) { _getobj(ocur, "store_dummy", inst, &s); nwrite(hFile, s, strlen(s)); nwrite(hFile, "\n", 1); } } } static void save_array(struct objlist *ocur, int hFile, int i, GString *str) { char *s, *array, *array2, iarray_str[] = "iarray:!:push ${darray:!:oid}\n\n"; int j, k, l, n, id; struct array_prm ary, ary2; struct narray *id_array; getobj(ocur, "array", i, 0, NULL, &array); if (array == NULL) { return; } id_array = arraynew(sizeof(int)); for (j = 0; j < i; j++) { getobj(ocur, "array", j, 0, NULL, &array2); if (array2 == NULL) { continue; } open_array(array2, &ary2); for (k = 0; k < ary2.col_num; k++) { n = arraynum(id_array); for (l = 0; l < n; l++) { id = arraynget_int(id_array, l); if (id == ary2.id[k]) { break; } } if (l == n) { arrayadd(id_array, &ary2.id[k]); } } } open_array(array, &ary); for (k = 0; k < ary.col_num; k++) { n = arraynum(id_array); for (l = 0; l < n; l++) { id = arraynget_int(id_array, l); if (id == ary2.id[k]) { break; } } if (l == n) { arrayadd(id_array, &ary.id[k]); if (getobj(ary.obj, "save", ary.id[k], 0, NULL, &s) != -1) { nwrite(hFile, s, strlen(s)); nwrite(hFile, "\n", 1); nwrite(hFile, iarray_str, sizeof(iarray_str) - 1); } } g_string_append_printf(str, "%s^${iarray:!:get:%d}", (k == 0) ? "darray:\"" : ",", l); } arrayfree(id_array); } static void save_merge(struct objlist *ocur, int hFile, int storemerge, int i) { char *s; getobj(ocur, "save", i, 0, NULL, &s); nwrite(hFile, s, strlen(s)); nwrite(hFile, "\n", 1); if (storemerge) { store_file(ocur, hFile, i); } } static void save_data(struct objlist *ocur, int hFile, int storedata, int i, int *array_data) { char *s; int source, argc; char *argv2[3], **argv; struct narray *array; GString *str; str = NULL; argc = 0; argv = NULL; array = NULL; getobj(ocur, "source", i, 0, NULL, &source); switch (source) { case DATA_SOURCE_FILE: break; case DATA_SOURCE_ARRAY: array = arraynew(sizeof(char *)); if (array == NULL) { error(NULL, ERRHEAP); return; } s = "array"; arrayadd(array, &s); argv2[0] = (char *) array; argv2[1] = NULL; argv = argv2; argc = 1; str = g_string_new("\tdata::array="); if (str == NULL) { error(NULL, ERRHEAP); return; } if (! *array_data) { char iarray_str[] = "new iarray\n\n"; *array_data = TRUE; nwrite(hFile, iarray_str, sizeof(iarray_str) - 1); } save_array(ocur, hFile, i, str); break; case DATA_SOURCE_RANGE: break; } getobj(ocur, "save", i, argc, argv, &s); nwrite(hFile, s, strlen(s)); if (storedata) { store_file(ocur, hFile, i); } if (array) { arrayfree(array); } if (str) { nwrite(hFile, str->str, str->len); nwrite(hFile, "\"\n", 2); g_string_free(str, TRUE); } nwrite(hFile, "\n", 1); } static void SaveParent(int hFile, struct objlist *parent, int storedata, int storemerge) { struct objlist *ocur, *odata, *omerge; int i, instnum, array_data; char *s; ocur = chkobjroot(); odata = chkobject("data"); omerge = chkobject("merge"); array_data = FALSE; while (ocur) { if (chkobjparent(ocur) == parent) { if ((instnum = chkobjlastinst(ocur)) != -1) { for (i = 0; i <= instnum; i++) { if (ocur == odata) { save_data(ocur, hFile, storedata, i, &array_data); } else if (ocur == omerge) { save_merge(ocur, hFile, storemerge, i); } else { getobj(ocur, "save", i, 0, NULL, &s); nwrite(hFile, s, strlen(s)); nwrite(hFile, "\n", 1); } } if (ocur == odata && array_data) { char iarray_str[] = "del iarray:!\n\n"; nwrite(hFile, iarray_str, sizeof(iarray_str) -1); } } SaveParent(hFile, ocur, storedata, storemerge); } ocur = ocur->next; } } int SaveDrawrable(char *name, int storedata, int storemerge) { int hFile; struct objlist *sysobj, *drawobj, *graobj; int id, len, error; char *arg[2]; struct narray sarray; N_VALUE *inst; char *ver, *sysname, *s, *opt, comment[COMMENT_BUF_SIZE]; error = FALSE; hFile = nopen(name, O_CREAT | O_TRUNC | O_RDWR, NFMODE_NORMAL_FILE); if (hFile < 0) { error = TRUE; } else { sysobj = chkobject("system"); inst = chkobjinst(sysobj, 0); _getobj(sysobj, "name", inst, &sysname); _getobj(sysobj, "version", inst, &ver); len = snprintf(comment, sizeof(comment), "#!ngraph\n#%%creator: %s \n#%%version: %s\n", sysname, ver); if (nwrite(hFile, comment, len) != len) error = TRUE; if ((drawobj = chkobject("draw")) != NULL) { SaveParent(hFile, drawobj, storedata, storemerge); if ((graobj = chkobject("gra")) != NULL) { id = ValidGRA(); if (id != -1) { arrayinit(&sarray, sizeof(char *)); opt = "device"; arrayadd(&sarray, &opt); arg[0] = (char *) &sarray; arg[1] = NULL; getobj(graobj, "save", id, 1, arg, &s); arraydel(&sarray); len = strlen(s); if (nwrite(hFile, s, len) != len) error = TRUE; } else { error = TRUE; } } } nclose(hFile); } if (error) ErrorMessage(); return error; } static int get_save_opt(int *sdata, int *smerge, int *path) { int ret, fnum, mnum, i, src; struct objlist *fobj, *mobj; *path = SAVE_PATH_UNCHANGE; *sdata = FALSE; *smerge = FALSE; fobj = chkobject("data"); mobj = chkobject("merge"); fnum = chkobjlastinst(fobj) + 1; mnum = chkobjlastinst(mobj) + 1; /* there are no instances of data and merge objects */ if (fnum < 1 && mnum < 1) { return IDOK; } /* check source field of data objects */ for (i = 0; i < fnum; i++) { getobj(fobj, "source", i, 0, NULL, &src); if (src == DATA_SOURCE_FILE) { break; } } if (fnum > 0 && mnum < 1 && i == fnum) { return IDOK; } SaveDialog(&DlgSave, sdata, smerge); ret = DialogExecute(TopLevel, &DlgSave); if (ret != IDOK) return IDCANCEL; *path = DlgSave.Path; for (i = 0; i < fnum; i++) { putobj(fobj, "save_path", i, path); } for (i = 0; i < mnum; i++) { putobj(mobj, "save_path", i, path); } return IDOK; } int GraphSave(int overwrite) { char mes[256]; int path; int sdata, smerge; int ret; char *initfil; char *file, *prev_wd, *current_wd; if (NgraphApp.FileName != NULL) { initfil = NgraphApp.FileName; } else { initfil = NULL; overwrite = FALSE; } prev_wd = current_wd = NULL; if ((initfil == NULL) || (! overwrite || (naccess(initfil, 04) == -1))) { prev_wd = ngetcwd(); ret = nGetSaveFileName(TopLevel, _("Save NGP file"), "ngp", &(Menulocal.graphloaddir), initfil, &file, overwrite, Menulocal.changedirectory); current_wd = ngetcwd(); if (prev_wd && current_wd && strcmp(prev_wd, current_wd) == 0) { g_free(prev_wd); g_free(current_wd); prev_wd = NULL; current_wd = NULL; } } else { file = g_strdup(initfil); if (file == NULL) return IDCANCEL; ret = IDOK; } if (ret == IDOK) { if (prev_wd && nchdir(prev_wd)) { ErrorMessage(); } ret = get_save_opt(&sdata, &smerge, &path); if (ret == IDOK) { snprintf(mes, sizeof(mes), _("Saving `%.128s'."), file); SetStatusBar(mes); if(SaveDrawrable(file, sdata, smerge)) { ret = IDCANCEL; } else { switch (path) { case SAVE_PATH_BASE: ToBasename(); break; case SAVE_PATH_RELATIVE: ToRalativePath(); break; case SAVE_PATH_FULL: ToFullPath(); break; } changefilename(file); AddNgpFileList(file); SetFileName(file); reset_graph_modified(); } ResetStatusBar(); } g_free(file); if (current_wd && nchdir(current_wd)) { ErrorMessage(); } } g_free(prev_wd); g_free(current_wd); return ret; } static void change_filename(char * (*func)(const char *)) { struct objlist *obj; int i; unsigned int j; char *file, *file2, *objname[] = {"data", "merge"}; for (j = 0; j < sizeof(objname) / sizeof(*objname); j++) { obj = chkobject(objname[j]); if (obj == NULL) continue; for (i = 0; i <= chkobjlastinst(obj); i++) { getobj(obj, "file", i, 0, NULL, &file); if (file == NULL) continue; file2 = func(file); if (file2 == NULL) return; if (strcmp(file, file2) == 0) { g_free(file2); continue; } set_graph_modified(); putobj(obj, "file", i, file2); } } } static void ToFullPath(void) { change_filename(getfullpath); } static void ToRalativePath(void) { change_filename(getrelativepath); } static char * get_basename(const char *file) { char *ptr; ptr = getbasename(file); if (ptr == NULL) return NULL; return ptr; } static void ToBasename(void) { change_filename(get_basename); } int LoadNgpFile(char *file, int console, char *option) { struct objlist *sys; char *expanddir; struct objlist *obj, *aobj; char *name; int i, r, newid, allocnow = FALSE, tmp; char *s; int len; char *argv[2]; struct narray sarray; char mes[256]; int sec; N_VALUE *inst; struct objlist *robj; int idn; int loadpath, expand; LoadDialog(&DlgLoad); if (DialogExecute(TopLevel, &DlgLoad) != IDOK) { return 1; } changefilename(file); if (naccess(file, R_OK)) { ErrorMessage(); return 1; } sys = chkobject("system"); if (sys == NULL) { return 1; } loadpath = DlgLoad.loadpath; expand = DlgLoad.expand; expanddir = g_strdup(DlgLoad.exdir); if (expanddir == NULL) return 1; putobj(sys, "expand_dir", 0, expanddir); putobj(sys, "expand_file", 0, &expand); tmp = FALSE; putobj(sys, "ignore_path", 0, &tmp); obj = chkobject("shell"); if (obj == NULL) return 1; newid = newobj(obj); if (newid < 0) return 1; inst = chkobjinst(obj, newid); arrayinit(&sarray, sizeof(char *)); while ((s = getitok2(&option, &len, " \t")) != NULL) { if (arrayadd(&sarray, &s) == NULL) { g_free(s); arraydel2(&sarray); return 1; } } name = g_strdup(file); if (name == NULL) { arraydel2(&sarray); return 1; } if (arrayadd(&sarray, &name) == NULL) { g_free(name); arraydel2(&sarray); return 1; } DeleteDrawable(); if (console) { allocnow = allocate_console(); } sec = TRUE; argv[0] = (char *) &sec; argv[1] = NULL; _exeobj(obj, "security", inst, 1, argv); argv[0] = (char *) &sarray; argv[1] = NULL; snprintf(mes, sizeof(mes), _("Loading `%.128s'."), name); SetStatusBar(mes); menu_lock(TRUE); idn = getobjtblpos(Menulocal.obj, "_evloop", &robj); registerevloop(chkobjectname(Menulocal.obj), "_evloop", robj, idn, Menulocal.inst, NULL); r = _exeobj(obj, "shell", inst, 1, argv); unregisterevloop(robj, idn, Menulocal.inst); menu_lock(FALSE); sec = FALSE; argv[0] = (char *) &sec; argv[1] = NULL; _exeobj(obj, "security", inst, 1, argv); if (r == 0) { if ((aobj = getobject("axis")) != NULL) { for (i = 0; i <= chkobjlastinst(aobj); i++) exeobj(aobj, "tight", i, 0, NULL); } if ((aobj = getobject("axisgrid")) != NULL) { for (i = 0; i <= chkobjlastinst(aobj); i++) exeobj(aobj, "tight", i, 0, NULL); } SetFileName(file); AddNgpFileList(name); reset_graph_modified(); switch (loadpath) { case LOAD_PATH_BASE: ToBasename(); break; case LOAD_PATH_FULL: ToFullPath(); break; } InfoWinClear(); } AxisNameToGroup(); ResetStatusBar(); arraydel2(&sarray); if (console) { free_console(allocnow); } set_axis_undo_button_sensitivity(FALSE); GetPageSettingsFromGRA(); CmViewerDraw(NULL, GINT_TO_POINTER(FALSE)); UpdateAll2(NULL, FALSE); delobj(obj, newid); menu_clear_undo(); return 0; } static int check_ref_axis(char *ref, const char *group) { int anum, aid; char *refgroup; struct narray iarray; struct objlist *aobj; N_VALUE *inst; if (ref == NULL) { return FALSE; } arrayinit(&iarray, sizeof(int)); if (getobjilist(ref, &aobj, &iarray, FALSE, NULL)) { arraydel(&iarray); return TRUE; } anum = arraynum(&iarray); if (anum < 1) { arraydel(&iarray); return TRUE; } aid = arraylast_int(&iarray); arraydel(&iarray); inst = getobjinst(aobj, aid); if (inst == NULL) { return TRUE; } _getobj(aobj, "group", inst, &refgroup); if (refgroup && group && refgroup[0] == group[0] && strcmp(refgroup + 2, group + 2) == 0) { return FALSE; } return TRUE; } static int file_auto_scale(char *file_obj, struct objlist *aobj, int anum) { int i, refother; double min, max, inc; char *group, *ref, *argv[2]; argv[0] = (char *) file_obj; argv[1] = NULL; for (i = 0; i <= anum; i++) { getobj(aobj, "min", i, 0, NULL, &min); getobj(aobj, "max", i, 0, NULL, &max); getobj(aobj, "inc", i, 0, NULL, &inc); getobj(aobj, "group", i, 0, NULL, &group); getobj(aobj, "reference", i, 0, NULL, &ref); refother = check_ref_axis(ref, group); if (! refother && (min == max || inc == 0)) { exeobj(aobj, "auto_scale", i, 1, argv); } } return 0; } void FileAutoScale(void) { int anum; struct objlist *aobj; char *buf; struct objlist *fobj; int lastinst; int i, hidden; GString *str; if ((fobj = chkobject("data")) == NULL) return; lastinst = chkobjlastinst(fobj); aobj = chkobject("axis"); anum = chkobjlastinst(aobj); if (lastinst < 0 || aobj == NULL || anum == 0) return; str = g_string_new("file:"); if (str == NULL) { error(NULL, ERRHEAP); return; } for (i = 0; i <= lastinst; i++) { getobj(fobj, "hidden", i, 0, NULL, &hidden); if (! hidden) { g_string_append_printf(str, "%d,", i); } } i = str->len - 1; buf = g_string_free(str, FALSE); if (buf[i] != ',') { g_free(buf); return; } buf[i] = '\0'; file_auto_scale(buf, aobj, anum); g_free(buf); } void AdjustAxis(void) { struct objlist *aobj; int i, anum; if ((aobj = chkobject("axis")) == NULL) return; anum = chkobjlastinst(aobj); for (i = 0; i <= anum; i++) exeobj(aobj, "adjust", i, 0, NULL); } int CheckSave(void) { int ret; if (get_graph_modified()) { ret = message_box(TopLevel, _("This graph is modified.\nSave this graph?"), _("Confirm"), RESPONS_YESNOCANCEL); if (ret == IDYES) { if (GraphSave(TRUE) == IDCANCEL) return FALSE; } else if (ret != IDNO) return FALSE; } return TRUE; } static void add_hist(const char *file, char *mime) { char *full_name, *uri; GtkRecentData recent_data = { NULL, AppName, NULL, AppName, "ngraph %f", NULL, FALSE, }; if (! g_utf8_validate(file, -1, NULL)) { return; } full_name = getfullpath(file); if (full_name == NULL) { return; } recent_data.mime_type = mime; uri = g_filename_to_uri(full_name, NULL, NULL); g_free(full_name); gtk_recent_manager_add_full(NgraphApp.recent_manager, uri, &recent_data); g_free(uri); } static void AddNgpFileList(const char *file) { add_hist(file, NGRAPH_GRAPH_MIME); } void AddDataFileList(const char *file) { add_hist(file, NGRAPH_DATA_MIME); } void SetFileName(char *str) { char *ngp, *name; name = g_strdup(str); g_free(NgraphApp.FileName); if (name == NULL) { NgraphApp.FileName = NULL; ngp = NULL; } else { NgraphApp.FileName = getfullpath(name); ngp = getfullpath(name); g_free(name); } putobj(Menulocal.obj, "fullpath_ngp", 0, ngp); } int allocate_console(void) { int allocnow; loadstdio(&GtkIOSave); allocnow = nallocconsole(); nforegroundconsole(); return allocnow; } void free_console(int allocnow) { if (allocnow) nfreeconsole(); putstderr = mgtkputstderr; printfstderr = mgtkprintfstderr; putstdout = mgtkputstdout; printfstdout = mgtkprintfstdout; inputyn = mgtkinputyn; ndisplaydialog = mgtkdisplaydialog; ndisplaystatus = mgtkdisplaystatus; ninterrupt = mgtkinterrupt; } static char * get_plot_cb_str(struct objlist *obj, int id, int source) { char *valstr, *s; const char *str; str = get_plot_info_str(obj, id, source); if (str == NULL) { return g_strdup("...................."); } if (source == DATA_SOURCE_FILE) { valstr = getbasename(str); s = g_strdup_printf("%s", (valstr) ? valstr : "...................."); if (valstr != NULL) { g_free(valstr); } } else { s = g_strdup(str); } return s; } char * FileCB(struct objlist *obj, int id) { int source; getobj(obj, "source", id, 0, NULL, &source); return get_plot_cb_str(obj, id, source); } char * PlotFileCB(struct objlist *obj, int id) { int source; getobj(obj, "source", id, 0, NULL, &source); if (source != DATA_SOURCE_FILE) { return NULL; } return get_plot_cb_str(obj, id, source); } int SetFileHidden(void) { struct objlist *fobj; int lastinst; struct narray farray, ifarray; int i, a, r, num, inum, *array; fobj = chkobject("data"); if (fobj == NULL) { return 1; } lastinst = chkobjlastinst(fobj); if (lastinst < 0) { return 1; } arrayinit(&ifarray, sizeof(int)); for (i = 0; i <= lastinst; i++) { getobj(fobj, "hidden", i, 0, NULL, &a); if (!a) { arrayadd(&ifarray, &i); } } r = 0; SelectDialog(&DlgSelect, fobj, NULL, FileCB, &farray, &ifarray); if (DialogExecute(TopLevel, &DlgSelect) == IDOK) { a = TRUE; for (i = 0; i <= lastinst; i++) { putobj(fobj, "hidden", i, &a); } num = arraynum(&farray); array = arraydata(&farray); a = FALSE; for (i = 0; i < num; i++) { putobj(fobj, "hidden", array[i], &a); } inum = arraynum(&ifarray); if (inum != num) { set_graph_modified(); } else { for (i = 0; i < num; i++) { if (arraynget_int(&ifarray, i) != array[i]) { set_graph_modified(); break; } } } r = 1; } arraydel(&ifarray); arraydel(&farray); return r; } int CheckIniFile(void) { int ret; ret = writecheckconfig(); if (ret == 0) { message_box(TopLevel, _("Ngraph.ini is not found."), "Ngraph.ini", RESPONS_ERROR); return FALSE; } else if ((ret == -1) || (ret == -3)) { message_box(TopLevel, _("Ngraph.ini is write protected."), "Ngraph.ini", RESPONS_ERROR); return FALSE; } else if ((ret == -2) || (ret == 2)) { struct objlist *sys; char *homedir, *buf; sys = getobject("system"); if (sys == NULL) { return FALSE; } if (getobj(sys, "home_dir", 0, 0, NULL, &homedir) == -1) { return FALSE; } buf = g_strdup_printf(_("Install `Ngraph.ini' to %s ?"), homedir); if (message_box(TopLevel, buf, "Ngraph.ini", RESPONS_YESNO) == IDYES) { g_free(buf); if (!copyconfig()) { message_box(TopLevel, _("Ngraph.ini could not be copied."), "Ngraph.ini", RESPONS_ERROR); return FALSE; } } else { g_free(buf); return FALSE; } } return TRUE; } void ProgressDialogSetTitle(char *title) { if (ProgressDialog) gtk_window_set_title(GTK_WINDOW(ProgressDialog), title); } static void show_progress(int pos, const char *msg, double fraction) { GtkProgressBar *bar; if (! ProgressDialog) return; if (pos) { bar = ProgressBar2; } else { bar = ProgressBar; } if (fraction < 0) { gtk_progress_bar_pulse(bar); } else { gtk_progress_bar_set_fraction(bar, fraction); } gtk_progress_bar_set_text(bar, msg); } static void stop_btn_clicked(GtkButton *button, gpointer user_data) { set_interrupt(); } void ProgressDialogCreate(char *title) { GtkWidget *btn, *vbox, *hbox; if (TopLevel == NULL) return; reset_interrupt(); SaveCursor = NGetCursor(); NSetCursor(GDK_WATCH); set_draw_lock(DrawLockDraw); if (ProgressDialog) { ProgressDialogSetTitle(title); show_progress(0, "", 0); show_progress(1, "", 0); set_progress_func(show_progress); gtk_widget_show_all(ProgressDialog); return; } ProgressDialog = gtk_window_new(GTK_WINDOW_TOPLEVEL); g_signal_connect(ProgressDialog, "delete-event", G_CALLBACK(gtk_true), NULL); gtk_window_set_title(GTK_WINDOW(ProgressDialog), title); gtk_window_set_transient_for(GTK_WINDOW(ProgressDialog), GTK_WINDOW(TopLevel)); gtk_window_set_modal(GTK_WINDOW(ProgressDialog), TRUE); gtk_window_set_position(GTK_WINDOW(ProgressDialog), GTK_WIN_POS_CENTER); gtk_window_set_type_hint(GTK_WINDOW(ProgressDialog), GDK_WINDOW_TYPE_HINT_DIALOG); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); ProgressBar = GTK_PROGRESS_BAR(gtk_progress_bar_new()); gtk_progress_bar_set_ellipsize(ProgressBar, PANGO_ELLIPSIZE_MIDDLE); gtk_progress_bar_set_show_text(ProgressBar, TRUE); gtk_box_pack_start(GTK_BOX(vbox), GTK_WIDGET(ProgressBar), FALSE, FALSE, 4); ProgressBar2 = GTK_PROGRESS_BAR(gtk_progress_bar_new()); gtk_progress_bar_set_ellipsize(ProgressBar2, PANGO_ELLIPSIZE_MIDDLE); gtk_progress_bar_set_show_text(ProgressBar2, TRUE); gtk_box_pack_start(GTK_BOX(vbox), GTK_WIDGET(ProgressBar2), FALSE, FALSE, 4); btn = gtk_button_new_with_mnemonic(_("_Stop")); set_button_icon(btn, "process-stop"); g_signal_connect(btn, "clicked", G_CALLBACK(stop_btn_clicked), NULL); #if USE_HEADER_BAR hbox = gtk_header_bar_new(); gtk_header_bar_set_title(GTK_HEADER_BAR(hbox), title); gtk_header_bar_pack_end(GTK_HEADER_BAR(hbox), btn); gtk_window_set_titlebar(GTK_WINDOW(ProgressDialog), hbox); #else hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_end(GTK_BOX(hbox), btn, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 4); #endif gtk_container_add(GTK_CONTAINER(ProgressDialog), vbox); gtk_window_set_default_size(GTK_WINDOW(ProgressDialog), 400, -1); gtk_widget_show_all(ProgressDialog); set_progress_func(show_progress); } void ProgressDialogFinalize(void) { if (TopLevel == NULL) return; gtk_widget_hide(ProgressDialog); NSetCursor(SaveCursor); set_progress_func(NULL); set_draw_lock(DrawLockNone); } void ErrorMessage(void) { const char *s; char *ptr; s = g_strerror(errno); ptr = g_strdup(s); message_box(NULL, CHK_STR(ptr), _("error"), RESPONS_ERROR); g_free(ptr); } ngraph-gtk-6.08.00/src/gtk/Makefile.in0000644000175000017500000022433713367273153014316 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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/gtk ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = LTLIBRARIES = $(noinst_LTLIBRARIES) libngraphui_la_LIBADD = am_libngraphui_la_OBJECTS = libngraphui_la-gtk_combo.lo \ libngraphui_la-gtk_entry_completion.lo \ libngraphui_la-gtk_liststore.lo libngraphui_la-gtk_subwin.lo \ libngraphui_la-ogra2x11.lo libngraphui_la-ogra2cairo.lo \ libngraphui_la-ogra2emf.lo libngraphui_la-ogra2cairofile.lo \ libngraphui_la-ogra2gtkprint.lo libngraphui_la-ogra2gdk.lo \ libngraphui_la-ox11dlg.lo libngraphui_la-ox11menu.lo \ libngraphui_la-x11axis.lo libngraphui_la-x11commn.lo \ libngraphui_la-x11cood.lo libngraphui_la-x11dialg.lo \ libngraphui_la-x11file.lo libngraphui_la-x11graph.lo \ libngraphui_la-x11gui.lo libngraphui_la-x11info.lo \ libngraphui_la-x11lgnd.lo libngraphui_la-x11lgndx.lo \ libngraphui_la-x11menu.lo libngraphui_la-x11merge.lo \ libngraphui_la-x11opt.lo libngraphui_la-x11print.lo \ libngraphui_la-x11view.lo libngraphui_la-gtk_widget.lo \ libngraphui_la-gtk_ruler.lo libngraphui_la-init.lo \ libngraphui_la-gtk_action.lo \ libngraphui_la-sourcecompletionwords.lo \ libngraphui_la-completion_info.lo \ libngraphui_la-completion_info_data.lo \ libngraphui_la-gtk_presettings.lo nodist_libngraphui_la_OBJECTS = libngraphui_la-ngraphui.resources.lo libngraphui_la_OBJECTS = $(am_libngraphui_la_OBJECTS) \ $(nodist_libngraphui_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 = libngraphui_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(libngraphui_la_CFLAGS) $(CFLAGS) $(libngraphui_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__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libngraphui_la-completion_info.Plo \ ./$(DEPDIR)/libngraphui_la-completion_info_data.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_action.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_combo.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_entry_completion.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_liststore.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_presettings.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_ruler.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_subwin.Plo \ ./$(DEPDIR)/libngraphui_la-gtk_widget.Plo \ ./$(DEPDIR)/libngraphui_la-init.Plo \ ./$(DEPDIR)/libngraphui_la-ngraphui.resources.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2cairo.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2cairofile.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2emf.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2gdk.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2gtkprint.Plo \ ./$(DEPDIR)/libngraphui_la-ogra2x11.Plo \ ./$(DEPDIR)/libngraphui_la-ox11dlg.Plo \ ./$(DEPDIR)/libngraphui_la-ox11menu.Plo \ ./$(DEPDIR)/libngraphui_la-sourcecompletionwords.Plo \ ./$(DEPDIR)/libngraphui_la-x11axis.Plo \ ./$(DEPDIR)/libngraphui_la-x11commn.Plo \ ./$(DEPDIR)/libngraphui_la-x11cood.Plo \ ./$(DEPDIR)/libngraphui_la-x11dialg.Plo \ ./$(DEPDIR)/libngraphui_la-x11file.Plo \ ./$(DEPDIR)/libngraphui_la-x11graph.Plo \ ./$(DEPDIR)/libngraphui_la-x11gui.Plo \ ./$(DEPDIR)/libngraphui_la-x11info.Plo \ ./$(DEPDIR)/libngraphui_la-x11lgnd.Plo \ ./$(DEPDIR)/libngraphui_la-x11lgndx.Plo \ ./$(DEPDIR)/libngraphui_la-x11menu.Plo \ ./$(DEPDIR)/libngraphui_la-x11merge.Plo \ ./$(DEPDIR)/libngraphui_la-x11opt.Plo \ ./$(DEPDIR)/libngraphui_la-x11print.Plo \ ./$(DEPDIR)/libngraphui_la-x11view.Plo 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 = $(libngraphui_la_SOURCES) $(nodist_libngraphui_la_SOURCES) DIST_SOURCES = $(libngraphui_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ NGRAPH_ICONS = data/pixmaps/ngraph_align_b.png \ data/pixmaps/ngraph_align_hc.png \ data/pixmaps/ngraph_align_l.png \ data/pixmaps/ngraph_align_r.png \ data/pixmaps/ngraph_align_t.png \ data/pixmaps/ngraph_align_vc.png data/pixmaps/ngraph_icon.png \ data/pixmaps/ngraph_icon64.png data/pixmaps/ngraph_math.png \ data/pixmaps/ngraph_undo.png data/ngraphui.resources.xml \ data/pixmaps/none_begin-symbolic.svg \ data/pixmaps/none_end-symbolic.svg \ data/pixmaps/arrow_begin-symbolic.svg \ data/pixmaps/arrow_end-symbolic.svg \ data/pixmaps/wave_begin-symbolic.svg \ data/pixmaps/wave_end-symbolic.svg \ data/pixmaps/mark_begin-symbolic.svg \ data/pixmaps/mark_end-symbolic.svg \ data/pixmaps/bar_begin-symbolic.svg \ data/pixmaps/bar_end-symbolic.svg \ data/pixmaps/stroke_fill_0-symbolic.svg \ data/pixmaps/stroke_fill_1-symbolic.svg \ data/pixmaps/stroke_fill_2-symbolic.svg \ data/pixmaps/stroke_fill_3-symbolic.svg \ data/pixmaps/stroke_fill_4-symbolic.svg \ data/pixmaps/stroke_fill_5-symbolic.svg \ data/pixmaps/stroke_fill_6-symbolic.svg \ data/pixmaps/stroke_fill_7-symbolic.svg \ data/pixmaps/join_bevel-symbolic.svg \ data/pixmaps/join_miter-symbolic.svg \ data/pixmaps/join_round-symbolic.svg data/pixmaps/ngraph.svg \ data/pixmaps/ngraph_draw-symbolic.svg \ data/pixmaps/ngraph_eval-symbolic.svg \ data/pixmaps/ngraph_line-symbolic.svg \ data/pixmaps/ngraph_single-symbolic.svg \ data/pixmaps/ngraph_arc-symbolic.svg \ data/pixmaps/ngraph_filewin-symbolic.svg \ data/pixmaps/ngraph_mark-symbolic.svg \ data/pixmaps/ngraph_text-symbolic.svg \ data/pixmaps/ngraph_axispoint-symbolic.svg \ data/pixmaps/ngraph_frame-symbolic.svg \ data/pixmaps/ngraph_mergewin-symbolic.svg \ data/pixmaps/ngraph_trimming-symbolic.svg \ data/pixmaps/ngraph_axiswin-symbolic.svg \ data/pixmaps/ngraph_gauss-symbolic.svg \ data/pixmaps/ngraph_point-symbolic.svg \ data/pixmaps/ngraph_zoom-symbolic.svg \ data/pixmaps/ngraph_rect-symbolic.svg \ data/pixmaps/ngraph_cross-symbolic.svg \ data/pixmaps/ngraph_legendpoint-symbolic.svg \ data/pixmaps/ngraph_scale-symbolic.svg \ data/pixmaps/ngraph_datapoint-symbolic.svg \ data/pixmaps/ngraph_section-symbolic.svg \ data/pixmaps/linewidth_002-symbolic.svg \ data/pixmaps/linewidth_004-symbolic.svg \ data/pixmaps/linewidth_008-symbolic.svg \ data/pixmaps/linewidth_016-symbolic.svg \ data/pixmaps/linewidth_032-symbolic.svg \ data/pixmaps/linewidth_064-symbolic.svg \ data/pixmaps/linewidth_128-symbolic.svg EXTRA_DIST = dir_defs.h.in data/css/ngraph.css \ data/gtk/menus-common.ui.in data/gtk/menus-common.ui.osx \ data/gtk/menus-appmenu.ui.in data/gtk/help-overlay.ui \ data/gtk/menus-appmenu.ui.osx data/gtk/menus-tool.ui \ create_completion_info.rb completion_info_functions.txt \ completion_info_constants.txt $(NGRAPH_ICONS) AM_CPPFLAGS = -DLOCALEDIR=\""@localedir@"\" noinst_LTLIBRARIES = libngraphui.la nodist_libngraphui_la_SOURCES = dir_defs.h ngraphui.resources.c libngraphui_la_SOURCES = gtk_common.h gtk_combo.c gtk_combo.h \ gtk_entry_completion.c gtk_entry_completion.h gtk_liststore.c \ gtk_liststore.h gtk_subwin.c gtk_subwin.h ogra2x11.c \ ogra2cairo.c ogra2emf.c ogra2cairo.h ogra2cairofile.c \ ogra2gtkprint.c ogra2cairofile.h ogra2x11.h ogra2gdk.c \ ogra2gdk.h ox11dlg.c ox11menu.c ox11menu.h x11axis.c \ x11axis.h x11bitmp.h x11commn.c x11commn.h x11cood.c \ x11cood.h x11dialg.c x11dialg.h x11file.c x11file.h \ x11graph.c x11graph.h x11gui.c x11gui.h x11info.c x11info.h \ x11lgnd.c x11lgnd.h x11lgndx.c x11menu.c x11menu.h x11merge.c \ x11merge.h x11opt.c x11opt.h x11opt_proto.h x11print.c \ x11print.h x11view.c x11view.h gtk_widget.c gtk_widget.h \ gtk_ruler.c gtk_ruler.h init.c init.h gtk_action.c \ gtk_action.h sourcecompletionwords.c sourcecompletionwords.h \ completion_info.c completion_info.h completion_info_data.c \ gtk_presettings.c gtk_presettings.h @OS_OSX_FALSE@@OS_WIN32_FALSE@APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.in @OS_OSX_TRUE@@OS_WIN32_FALSE@APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.osx @OS_WIN32_TRUE@APPMENU_UI_SOURCE = $(srcdir)/data/gtk/menus-appmenu.ui.in @OS_OSX_FALSE@@OS_WIN32_FALSE@MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.in @OS_OSX_TRUE@@OS_WIN32_FALSE@MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.osx @OS_WIN32_TRUE@MENU_UI_SOURCE = $(srcdir)/data/gtk/menus-common.ui.in uidir = data/gtk BUILT_SOURCES = ${nodist_libngraphui_la_SOURCES} ngraphconfdir = $(sysconfdir)/$(PACKAGE) pixmapdir = $(datadir)/pixmaps/$(PACKAGE) libngraphui_la_CFLAGS = $(GTK_CFLAGS) -I$(top_builddir) -I$(builddir) -I$(srcdir)/.. -I$(srcdir)/../math $(GTKSOURCEVIEW_CFLAGS) libngraphui_la_LDFLAGS = $(GTKSOURCEVIEW_LIBS) CLEANFILES = dir_defs.h $(builddir)/data/gtk/menus-appmenu.ui $(builddir)/data/gtk/menus-common.ui $(BUILT_SOURCES) all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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) --gnu src/gtk/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu src/gtk/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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}; \ } libngraphui.la: $(libngraphui_la_OBJECTS) $(libngraphui_la_DEPENDENCIES) $(EXTRA_libngraphui_la_DEPENDENCIES) $(AM_V_CCLD)$(libngraphui_la_LINK) $(libngraphui_la_OBJECTS) $(libngraphui_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-completion_info.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-completion_info_data.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_action.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_combo.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_entry_completion.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_liststore.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_presettings.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_ruler.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_subwin.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-gtk_widget.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-init.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ngraphui.resources.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2cairo.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2cairofile.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2emf.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2gdk.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2gtkprint.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ogra2x11.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ox11dlg.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-ox11menu.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-sourcecompletionwords.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11axis.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11commn.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11cood.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11dialg.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11file.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11graph.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11gui.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11info.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11lgnd.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11lgndx.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11menu.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11merge.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11opt.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11print.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraphui_la-x11view.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .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 $@ $< libngraphui_la-gtk_combo.lo: gtk_combo.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_combo.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_combo.Tpo -c -o libngraphui_la-gtk_combo.lo `test -f 'gtk_combo.c' || echo '$(srcdir)/'`gtk_combo.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_combo.Tpo $(DEPDIR)/libngraphui_la-gtk_combo.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_combo.c' object='libngraphui_la-gtk_combo.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_combo.lo `test -f 'gtk_combo.c' || echo '$(srcdir)/'`gtk_combo.c libngraphui_la-gtk_entry_completion.lo: gtk_entry_completion.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_entry_completion.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_entry_completion.Tpo -c -o libngraphui_la-gtk_entry_completion.lo `test -f 'gtk_entry_completion.c' || echo '$(srcdir)/'`gtk_entry_completion.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_entry_completion.Tpo $(DEPDIR)/libngraphui_la-gtk_entry_completion.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_entry_completion.c' object='libngraphui_la-gtk_entry_completion.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_entry_completion.lo `test -f 'gtk_entry_completion.c' || echo '$(srcdir)/'`gtk_entry_completion.c libngraphui_la-gtk_liststore.lo: gtk_liststore.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_liststore.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_liststore.Tpo -c -o libngraphui_la-gtk_liststore.lo `test -f 'gtk_liststore.c' || echo '$(srcdir)/'`gtk_liststore.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_liststore.Tpo $(DEPDIR)/libngraphui_la-gtk_liststore.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_liststore.c' object='libngraphui_la-gtk_liststore.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_liststore.lo `test -f 'gtk_liststore.c' || echo '$(srcdir)/'`gtk_liststore.c libngraphui_la-gtk_subwin.lo: gtk_subwin.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_subwin.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_subwin.Tpo -c -o libngraphui_la-gtk_subwin.lo `test -f 'gtk_subwin.c' || echo '$(srcdir)/'`gtk_subwin.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_subwin.Tpo $(DEPDIR)/libngraphui_la-gtk_subwin.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_subwin.c' object='libngraphui_la-gtk_subwin.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_subwin.lo `test -f 'gtk_subwin.c' || echo '$(srcdir)/'`gtk_subwin.c libngraphui_la-ogra2x11.lo: ogra2x11.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2x11.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2x11.Tpo -c -o libngraphui_la-ogra2x11.lo `test -f 'ogra2x11.c' || echo '$(srcdir)/'`ogra2x11.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2x11.Tpo $(DEPDIR)/libngraphui_la-ogra2x11.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2x11.c' object='libngraphui_la-ogra2x11.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2x11.lo `test -f 'ogra2x11.c' || echo '$(srcdir)/'`ogra2x11.c libngraphui_la-ogra2cairo.lo: ogra2cairo.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2cairo.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2cairo.Tpo -c -o libngraphui_la-ogra2cairo.lo `test -f 'ogra2cairo.c' || echo '$(srcdir)/'`ogra2cairo.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2cairo.Tpo $(DEPDIR)/libngraphui_la-ogra2cairo.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2cairo.c' object='libngraphui_la-ogra2cairo.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2cairo.lo `test -f 'ogra2cairo.c' || echo '$(srcdir)/'`ogra2cairo.c libngraphui_la-ogra2emf.lo: ogra2emf.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2emf.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2emf.Tpo -c -o libngraphui_la-ogra2emf.lo `test -f 'ogra2emf.c' || echo '$(srcdir)/'`ogra2emf.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2emf.Tpo $(DEPDIR)/libngraphui_la-ogra2emf.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2emf.c' object='libngraphui_la-ogra2emf.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2emf.lo `test -f 'ogra2emf.c' || echo '$(srcdir)/'`ogra2emf.c libngraphui_la-ogra2cairofile.lo: ogra2cairofile.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2cairofile.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2cairofile.Tpo -c -o libngraphui_la-ogra2cairofile.lo `test -f 'ogra2cairofile.c' || echo '$(srcdir)/'`ogra2cairofile.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2cairofile.Tpo $(DEPDIR)/libngraphui_la-ogra2cairofile.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2cairofile.c' object='libngraphui_la-ogra2cairofile.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2cairofile.lo `test -f 'ogra2cairofile.c' || echo '$(srcdir)/'`ogra2cairofile.c libngraphui_la-ogra2gtkprint.lo: ogra2gtkprint.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2gtkprint.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2gtkprint.Tpo -c -o libngraphui_la-ogra2gtkprint.lo `test -f 'ogra2gtkprint.c' || echo '$(srcdir)/'`ogra2gtkprint.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2gtkprint.Tpo $(DEPDIR)/libngraphui_la-ogra2gtkprint.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2gtkprint.c' object='libngraphui_la-ogra2gtkprint.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2gtkprint.lo `test -f 'ogra2gtkprint.c' || echo '$(srcdir)/'`ogra2gtkprint.c libngraphui_la-ogra2gdk.lo: ogra2gdk.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ogra2gdk.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ogra2gdk.Tpo -c -o libngraphui_la-ogra2gdk.lo `test -f 'ogra2gdk.c' || echo '$(srcdir)/'`ogra2gdk.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ogra2gdk.Tpo $(DEPDIR)/libngraphui_la-ogra2gdk.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2gdk.c' object='libngraphui_la-ogra2gdk.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ogra2gdk.lo `test -f 'ogra2gdk.c' || echo '$(srcdir)/'`ogra2gdk.c libngraphui_la-ox11dlg.lo: ox11dlg.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ox11dlg.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ox11dlg.Tpo -c -o libngraphui_la-ox11dlg.lo `test -f 'ox11dlg.c' || echo '$(srcdir)/'`ox11dlg.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ox11dlg.Tpo $(DEPDIR)/libngraphui_la-ox11dlg.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ox11dlg.c' object='libngraphui_la-ox11dlg.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ox11dlg.lo `test -f 'ox11dlg.c' || echo '$(srcdir)/'`ox11dlg.c libngraphui_la-ox11menu.lo: ox11menu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ox11menu.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ox11menu.Tpo -c -o libngraphui_la-ox11menu.lo `test -f 'ox11menu.c' || echo '$(srcdir)/'`ox11menu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ox11menu.Tpo $(DEPDIR)/libngraphui_la-ox11menu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ox11menu.c' object='libngraphui_la-ox11menu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ox11menu.lo `test -f 'ox11menu.c' || echo '$(srcdir)/'`ox11menu.c libngraphui_la-x11axis.lo: x11axis.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11axis.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11axis.Tpo -c -o libngraphui_la-x11axis.lo `test -f 'x11axis.c' || echo '$(srcdir)/'`x11axis.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11axis.Tpo $(DEPDIR)/libngraphui_la-x11axis.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11axis.c' object='libngraphui_la-x11axis.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11axis.lo `test -f 'x11axis.c' || echo '$(srcdir)/'`x11axis.c libngraphui_la-x11commn.lo: x11commn.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11commn.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11commn.Tpo -c -o libngraphui_la-x11commn.lo `test -f 'x11commn.c' || echo '$(srcdir)/'`x11commn.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11commn.Tpo $(DEPDIR)/libngraphui_la-x11commn.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11commn.c' object='libngraphui_la-x11commn.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11commn.lo `test -f 'x11commn.c' || echo '$(srcdir)/'`x11commn.c libngraphui_la-x11cood.lo: x11cood.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11cood.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11cood.Tpo -c -o libngraphui_la-x11cood.lo `test -f 'x11cood.c' || echo '$(srcdir)/'`x11cood.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11cood.Tpo $(DEPDIR)/libngraphui_la-x11cood.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11cood.c' object='libngraphui_la-x11cood.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11cood.lo `test -f 'x11cood.c' || echo '$(srcdir)/'`x11cood.c libngraphui_la-x11dialg.lo: x11dialg.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11dialg.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11dialg.Tpo -c -o libngraphui_la-x11dialg.lo `test -f 'x11dialg.c' || echo '$(srcdir)/'`x11dialg.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11dialg.Tpo $(DEPDIR)/libngraphui_la-x11dialg.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11dialg.c' object='libngraphui_la-x11dialg.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11dialg.lo `test -f 'x11dialg.c' || echo '$(srcdir)/'`x11dialg.c libngraphui_la-x11file.lo: x11file.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11file.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11file.Tpo -c -o libngraphui_la-x11file.lo `test -f 'x11file.c' || echo '$(srcdir)/'`x11file.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11file.Tpo $(DEPDIR)/libngraphui_la-x11file.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11file.c' object='libngraphui_la-x11file.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11file.lo `test -f 'x11file.c' || echo '$(srcdir)/'`x11file.c libngraphui_la-x11graph.lo: x11graph.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11graph.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11graph.Tpo -c -o libngraphui_la-x11graph.lo `test -f 'x11graph.c' || echo '$(srcdir)/'`x11graph.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11graph.Tpo $(DEPDIR)/libngraphui_la-x11graph.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11graph.c' object='libngraphui_la-x11graph.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11graph.lo `test -f 'x11graph.c' || echo '$(srcdir)/'`x11graph.c libngraphui_la-x11gui.lo: x11gui.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11gui.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11gui.Tpo -c -o libngraphui_la-x11gui.lo `test -f 'x11gui.c' || echo '$(srcdir)/'`x11gui.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11gui.Tpo $(DEPDIR)/libngraphui_la-x11gui.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11gui.c' object='libngraphui_la-x11gui.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11gui.lo `test -f 'x11gui.c' || echo '$(srcdir)/'`x11gui.c libngraphui_la-x11info.lo: x11info.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11info.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11info.Tpo -c -o libngraphui_la-x11info.lo `test -f 'x11info.c' || echo '$(srcdir)/'`x11info.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11info.Tpo $(DEPDIR)/libngraphui_la-x11info.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11info.c' object='libngraphui_la-x11info.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11info.lo `test -f 'x11info.c' || echo '$(srcdir)/'`x11info.c libngraphui_la-x11lgnd.lo: x11lgnd.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11lgnd.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11lgnd.Tpo -c -o libngraphui_la-x11lgnd.lo `test -f 'x11lgnd.c' || echo '$(srcdir)/'`x11lgnd.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11lgnd.Tpo $(DEPDIR)/libngraphui_la-x11lgnd.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11lgnd.c' object='libngraphui_la-x11lgnd.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11lgnd.lo `test -f 'x11lgnd.c' || echo '$(srcdir)/'`x11lgnd.c libngraphui_la-x11lgndx.lo: x11lgndx.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11lgndx.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11lgndx.Tpo -c -o libngraphui_la-x11lgndx.lo `test -f 'x11lgndx.c' || echo '$(srcdir)/'`x11lgndx.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11lgndx.Tpo $(DEPDIR)/libngraphui_la-x11lgndx.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11lgndx.c' object='libngraphui_la-x11lgndx.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11lgndx.lo `test -f 'x11lgndx.c' || echo '$(srcdir)/'`x11lgndx.c libngraphui_la-x11menu.lo: x11menu.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11menu.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11menu.Tpo -c -o libngraphui_la-x11menu.lo `test -f 'x11menu.c' || echo '$(srcdir)/'`x11menu.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11menu.Tpo $(DEPDIR)/libngraphui_la-x11menu.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11menu.c' object='libngraphui_la-x11menu.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11menu.lo `test -f 'x11menu.c' || echo '$(srcdir)/'`x11menu.c libngraphui_la-x11merge.lo: x11merge.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11merge.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11merge.Tpo -c -o libngraphui_la-x11merge.lo `test -f 'x11merge.c' || echo '$(srcdir)/'`x11merge.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11merge.Tpo $(DEPDIR)/libngraphui_la-x11merge.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11merge.c' object='libngraphui_la-x11merge.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11merge.lo `test -f 'x11merge.c' || echo '$(srcdir)/'`x11merge.c libngraphui_la-x11opt.lo: x11opt.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11opt.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11opt.Tpo -c -o libngraphui_la-x11opt.lo `test -f 'x11opt.c' || echo '$(srcdir)/'`x11opt.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11opt.Tpo $(DEPDIR)/libngraphui_la-x11opt.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11opt.c' object='libngraphui_la-x11opt.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11opt.lo `test -f 'x11opt.c' || echo '$(srcdir)/'`x11opt.c libngraphui_la-x11print.lo: x11print.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11print.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11print.Tpo -c -o libngraphui_la-x11print.lo `test -f 'x11print.c' || echo '$(srcdir)/'`x11print.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11print.Tpo $(DEPDIR)/libngraphui_la-x11print.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11print.c' object='libngraphui_la-x11print.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11print.lo `test -f 'x11print.c' || echo '$(srcdir)/'`x11print.c libngraphui_la-x11view.lo: x11view.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-x11view.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-x11view.Tpo -c -o libngraphui_la-x11view.lo `test -f 'x11view.c' || echo '$(srcdir)/'`x11view.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-x11view.Tpo $(DEPDIR)/libngraphui_la-x11view.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='x11view.c' object='libngraphui_la-x11view.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-x11view.lo `test -f 'x11view.c' || echo '$(srcdir)/'`x11view.c libngraphui_la-gtk_widget.lo: gtk_widget.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_widget.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_widget.Tpo -c -o libngraphui_la-gtk_widget.lo `test -f 'gtk_widget.c' || echo '$(srcdir)/'`gtk_widget.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_widget.Tpo $(DEPDIR)/libngraphui_la-gtk_widget.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_widget.c' object='libngraphui_la-gtk_widget.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_widget.lo `test -f 'gtk_widget.c' || echo '$(srcdir)/'`gtk_widget.c libngraphui_la-gtk_ruler.lo: gtk_ruler.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_ruler.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_ruler.Tpo -c -o libngraphui_la-gtk_ruler.lo `test -f 'gtk_ruler.c' || echo '$(srcdir)/'`gtk_ruler.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_ruler.Tpo $(DEPDIR)/libngraphui_la-gtk_ruler.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_ruler.c' object='libngraphui_la-gtk_ruler.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_ruler.lo `test -f 'gtk_ruler.c' || echo '$(srcdir)/'`gtk_ruler.c libngraphui_la-init.lo: init.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-init.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-init.Tpo -c -o libngraphui_la-init.lo `test -f 'init.c' || echo '$(srcdir)/'`init.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-init.Tpo $(DEPDIR)/libngraphui_la-init.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='init.c' object='libngraphui_la-init.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-init.lo `test -f 'init.c' || echo '$(srcdir)/'`init.c libngraphui_la-gtk_action.lo: gtk_action.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_action.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_action.Tpo -c -o libngraphui_la-gtk_action.lo `test -f 'gtk_action.c' || echo '$(srcdir)/'`gtk_action.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_action.Tpo $(DEPDIR)/libngraphui_la-gtk_action.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_action.c' object='libngraphui_la-gtk_action.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_action.lo `test -f 'gtk_action.c' || echo '$(srcdir)/'`gtk_action.c libngraphui_la-sourcecompletionwords.lo: sourcecompletionwords.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-sourcecompletionwords.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-sourcecompletionwords.Tpo -c -o libngraphui_la-sourcecompletionwords.lo `test -f 'sourcecompletionwords.c' || echo '$(srcdir)/'`sourcecompletionwords.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-sourcecompletionwords.Tpo $(DEPDIR)/libngraphui_la-sourcecompletionwords.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='sourcecompletionwords.c' object='libngraphui_la-sourcecompletionwords.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-sourcecompletionwords.lo `test -f 'sourcecompletionwords.c' || echo '$(srcdir)/'`sourcecompletionwords.c libngraphui_la-completion_info.lo: completion_info.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-completion_info.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-completion_info.Tpo -c -o libngraphui_la-completion_info.lo `test -f 'completion_info.c' || echo '$(srcdir)/'`completion_info.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-completion_info.Tpo $(DEPDIR)/libngraphui_la-completion_info.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='completion_info.c' object='libngraphui_la-completion_info.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-completion_info.lo `test -f 'completion_info.c' || echo '$(srcdir)/'`completion_info.c libngraphui_la-completion_info_data.lo: completion_info_data.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-completion_info_data.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-completion_info_data.Tpo -c -o libngraphui_la-completion_info_data.lo `test -f 'completion_info_data.c' || echo '$(srcdir)/'`completion_info_data.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-completion_info_data.Tpo $(DEPDIR)/libngraphui_la-completion_info_data.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='completion_info_data.c' object='libngraphui_la-completion_info_data.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-completion_info_data.lo `test -f 'completion_info_data.c' || echo '$(srcdir)/'`completion_info_data.c libngraphui_la-gtk_presettings.lo: gtk_presettings.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-gtk_presettings.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-gtk_presettings.Tpo -c -o libngraphui_la-gtk_presettings.lo `test -f 'gtk_presettings.c' || echo '$(srcdir)/'`gtk_presettings.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-gtk_presettings.Tpo $(DEPDIR)/libngraphui_la-gtk_presettings.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gtk_presettings.c' object='libngraphui_la-gtk_presettings.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-gtk_presettings.lo `test -f 'gtk_presettings.c' || echo '$(srcdir)/'`gtk_presettings.c libngraphui_la-ngraphui.resources.lo: ngraphui.resources.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -MT libngraphui_la-ngraphui.resources.lo -MD -MP -MF $(DEPDIR)/libngraphui_la-ngraphui.resources.Tpo -c -o libngraphui_la-ngraphui.resources.lo `test -f 'ngraphui.resources.c' || echo '$(srcdir)/'`ngraphui.resources.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraphui_la-ngraphui.resources.Tpo $(DEPDIR)/libngraphui_la-ngraphui.resources.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ngraphui.resources.c' object='libngraphui_la-ngraphui.resources.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraphui_la_CFLAGS) $(CFLAGS) -c -o libngraphui_la-ngraphui.resources.lo `test -f 'ngraphui.resources.c' || echo '$(srcdir)/'`ngraphui.resources.c 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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-am all-am: Makefile $(LTLIBRARIES) installdirs: install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) clean: clean-am clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/libngraphui_la-completion_info.Plo -rm -f ./$(DEPDIR)/libngraphui_la-completion_info_data.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_action.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_combo.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_entry_completion.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_liststore.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_presettings.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_ruler.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_subwin.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_widget.Plo -rm -f ./$(DEPDIR)/libngraphui_la-init.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ngraphui.resources.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2cairo.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2cairofile.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2emf.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2gdk.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2gtkprint.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2x11.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ox11dlg.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ox11menu.Plo -rm -f ./$(DEPDIR)/libngraphui_la-sourcecompletionwords.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11axis.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11commn.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11cood.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11dialg.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11file.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11graph.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11gui.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11info.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11lgnd.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11lgndx.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11menu.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11merge.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11opt.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11print.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11view.Plo -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 -f ./$(DEPDIR)/libngraphui_la-completion_info.Plo -rm -f ./$(DEPDIR)/libngraphui_la-completion_info_data.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_action.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_combo.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_entry_completion.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_liststore.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_presettings.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_ruler.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_subwin.Plo -rm -f ./$(DEPDIR)/libngraphui_la-gtk_widget.Plo -rm -f ./$(DEPDIR)/libngraphui_la-init.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ngraphui.resources.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2cairo.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2cairofile.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2emf.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2gdk.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2gtkprint.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ogra2x11.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ox11dlg.Plo -rm -f ./$(DEPDIR)/libngraphui_la-ox11menu.Plo -rm -f ./$(DEPDIR)/libngraphui_la-sourcecompletionwords.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11axis.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11commn.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11cood.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11dialg.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11file.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11graph.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11gui.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11info.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11lgnd.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11lgndx.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11menu.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11merge.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11opt.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11print.Plo -rm -f ./$(DEPDIR)/libngraphui_la-x11view.Plo -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: all check install install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles 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 $(uidir)/menus-appmenu.ui: $(APPMENU_UI_SOURCE) $(MKDIR_P) $(uidir) cp $< $@ $(uidir)/menus-common.ui: $(MENU_UI_SOURCE) $(MKDIR_P) $(uidir) cp $< $@ ngraphui.resources.c: $(srcdir)/data/ngraphui.resources.xml $(uidir)/menus-common.ui $(srcdir)/data/gtk/menus-tool.ui $(srcdir)/data/css/ngraph.css $(srcdir)/data/gtk/help-overlay.ui $(uidir)/menus-appmenu.ui $(NGRAPH_ICONS) $(GLIB_COMPILE_RESOURCES) --target=$@ --generate-source --sourcedir $(srcdir)/data --sourcedir $(builddir)/data $< dir_defs.h: dir_defs.h.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/dir_defs.h.in completion_info_data.c: $(srcdir)/completion_info_functions.txt $(srcdir)/completion_info_constants.txt $(srcdir)/create_completion_info.rb ruby $(srcdir)/create_completion_info.rb $(srcdir)/completion_info_functions.txt $(srcdir)/completion_info_constants.txt completion_info_data.c # 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: ngraph-gtk-6.08.00/src/nhash.c0000644000175000017500000001661713310717145012721 00000000000000/* * $Id: nhash.c,v 1.16 2009-11-16 12:59:18 hito Exp $ */ #include #include #include #include #include "object.h" #include "nhash.h" #define HASH_SIZE 251 NHASH nhash_new(void) { struct nhash **hash; hash = g_malloc0(HASH_SIZE * sizeof(struct nhash *)); return hash; } static void free_hash_list(struct nhash *hash, int free_ptr) { struct nhash *l, *r; if (hash == NULL) return; l = hash->l; r = hash->r; g_free(hash->key); if (free_ptr) { g_free(hash->val.p); } g_free(hash); free_hash_list(l, free_ptr); free_hash_list(r, free_ptr); } void nhash_free(NHASH hash) { int i; for (i = 0; i < HASH_SIZE; i++) { free_hash_list(hash[i], FALSE); } g_free(hash); } void nhash_free_with_memfree_ptr(NHASH hash) { int i; for (i = 0; i < HASH_SIZE; i++) { free_hash_list(hash[i], TRUE); } g_free(hash); } void nhash_clear(NHASH hash) { int i; for (i = 0; i < HASH_SIZE; i++) { free_hash_list(hash[i], FALSE); } memset(hash, 0, HASH_SIZE * sizeof(struct nhash *)); } int nhash_hkey(const char *ptr) { unsigned int i, v; for (v = i = 0; ptr[i]; i++) { v += ptr[i]; } return v % HASH_SIZE; } static struct nhash * create_hash_with_hkey(NHASH hash, const char *key, int hkey) { int lr = 0; char *k; struct nhash *h, *ptr, *prev = NULL; if (key == NULL) return NULL; ptr = hash[hkey]; if (ptr == NULL) { h = g_malloc(sizeof(struct nhash)); if (h == NULL) return NULL; hash[hkey] = h; } else { while (ptr) { lr = strcmp(key, ptr->key); if (lr == 0) { return ptr; } else if (lr < 0) { prev = ptr; ptr = ptr->l; } else { prev = ptr; ptr = ptr->r; } } h = g_malloc(sizeof(struct nhash)); if (h == NULL) { return NULL; } } k = g_strdup(key); if (k == NULL) { g_free(h); return NULL; } if (prev) { if (lr < 0) { prev->l = h; } else { prev->r = h; } } h->key = k; h->l = NULL; h->r = NULL; h->p = prev; return h; } struct nhash * create_hash(NHASH hash, const char *key) { int hkey; if (key == NULL) return NULL; hkey = nhash_hkey(key); return create_hash_with_hkey(hash, key, hkey); } int nhash_set_int(NHASH hash, const char *key, int val) { struct nhash *h; h = create_hash(hash, key); if (h == NULL) return 1; h->val.i = val; return 0; } int nhash_set_ptr(NHASH hash, const char *key, void *val) { struct nhash *h; h = create_hash(hash, key); if (h == NULL) return 1; h->val.p = val; return 0; } int nhash_set_int_with_hkey(NHASH hash, const char *key, int hkey, int val) { struct nhash *h; h = create_hash_with_hkey(hash, key, hkey); if (h == NULL) return 1; h->val.i = val; return 0; } int nhash_set_ptr_with_hkey(NHASH hash, const char *key, int hkey, void *val) { struct nhash *h; h = create_hash_with_hkey(hash, key, hkey); if (h == NULL) return 1; h->val.p = val; return 0; } static struct nhash * nhash_get(NHASH hash, const char *key) { struct nhash *ptr; int hk, r; if (key == NULL) return NULL; hk = nhash_hkey(key); ptr = hash[hk]; while (ptr) { r = strcmp(key, ptr->key); if (r < 0) { ptr = ptr->l; } else if (r > 0) { ptr = ptr->r; } else { return ptr; } } return NULL; } static struct nhash * nhash_get_with_hkey(NHASH hash, const char *key, int hk) { struct nhash *ptr; int r; if (key == NULL) return NULL; ptr = hash[hk]; while (ptr) { r = strcmp(key, ptr->key); if (r < 0) { ptr = ptr->l; } else if (r > 0) { ptr = ptr->r; } else { return ptr; } } return NULL; } int nhash_get_int(NHASH hash, const char *key, int *val) { struct nhash *h; h = nhash_get(hash, key); if (h == NULL) return 1; *val = h->val.i; return 0; } int nhash_get_int_with_hkey(NHASH hash, const char *key, int hkey, int *val) { struct nhash *h; h = nhash_get_with_hkey(hash, key, hkey); if (h == NULL) return 1; *val = h->val.i; return 0; } static void btree_cat(struct nhash *dest, struct nhash *src) { struct nhash *h; int r; h = dest; while (1) { r = strcmp(h->key, src->key); if (r < 0) { if (h->l == NULL) { h->l = src; break; } h = h->l; } else if (r > 0) { if (h->r == NULL) { h->r = src; break; } h = h->r; } else { /* never reached */ break; } } src->p = h; } static void nhash_del_sub(NHASH hash, struct nhash *h, int hkey) { struct nhash *p; p = h->p; if (p == NULL) { if (h->l && h->r) { btree_cat(h->r, h->l); hash[hkey] = h->r; h->r->p = NULL; } else if (h->l) { hash[hkey] = h->l; h->l->p = NULL; } else if (h->r) { hash[hkey] = h->r; h->r->p = NULL; } else { hash[hkey] = NULL; } } else { if (h->l && h->r) { btree_cat(h->r, h->l); if (p->l == h) { p->l = h->r; } else { p->r = h->r; } h->r->p = p; } else if (h->l) { if (p->l == h) { p->l = h->l; } else { p->r = h->l; } h->l->p = p; } else if (h->r) { if (p->l == h) { p->l = h->r; } else { p->r = h->r; } h->r->p = p; } else { if (p->l == h) { p->l = NULL; } else { p->r = NULL; } } } g_free(h->key); g_free(h); } void nhash_del_with_hkey(NHASH hash, const char *key, int hkey) { struct nhash *h; h = nhash_get_with_hkey(hash, key, hkey); if (h) nhash_del_sub(hash, h, hkey); } void nhash_del(NHASH hash, const char *key) { struct nhash *h; int hkey; hkey = nhash_hkey(key); h = nhash_get_with_hkey(hash, key, hkey); if (h) nhash_del_sub(hash, h, hkey); } static int hash_each_sub(struct nhash *h, int(* func)(struct nhash *, void *), void *data) { int r; if (h == NULL) return 0; if (h->l) { r = hash_each_sub(h->l, func, data); if (r) { return r; } } if (h->r) { r = hash_each_sub(h->r, func, data); if (r) { return r; } } return func(h, data); } int nhash_each(NHASH hash, int(* func)(struct nhash *, void *), void *data) { int i, r; if (func == NULL || hash == NULL) return 0; for (i = 0; i < HASH_SIZE; i++) { if (hash[i]) { r = hash_each_sub(hash[i], func, data); if (r) return r; } } return 0; } int nhash_get_ptr(NHASH hash, const char *key, void **ptr) { struct nhash *h; h = nhash_get(hash, key); if (h == NULL) { *ptr = NULL; return 1; } *ptr = h->val.p; return 0; } int nhash_get_ptr_with_hkey(NHASH hash, const char *key, int hkey, void **ptr) { struct nhash *h; h = nhash_get_with_hkey(hash, key, hkey); if (h == NULL) { *ptr = NULL; return 1; } *ptr = h->val.p; return 0; } static void print_hash(struct nhash *h) { if (h == NULL) return; printf("%s ", h->key); print_hash(h->l); print_hash(h->r); } void nhash_show(NHASH hash) { int i; for (i = 0; i < HASH_SIZE; i++) { printf("%2d: ", i); print_hash(hash[i]); printf("\n"); } } static void count_hash(struct nhash *h, int *n) { if (h == NULL) return; if (h->l) count_hash(h->l, n); if (h->r) count_hash(h->r, n); (*n)++; } int nhash_num(NHASH hash) { int i, n = 0; for (i = 0; i < HASH_SIZE; i++) { if (hash[i]) { count_hash(hash[i], &n); } } return n; } ngraph-gtk-6.08.00/src/oregexp.c0000644000175000017500000001461413070106167013263 00000000000000#include "common.h" #include #include #include #include "object.h" #define NAME "regexp" #define PARENT "object" #define OVERSION "1.00.00" #define ERR_REGEXP 100 #define ERR_INVALID_UTF8 101 static char *regexperrorlist[]={ "invalid regular expression.", "invalid UTF-8 string.", }; struct oregexp_local { GRegex *regexp; struct narray *array; }; #define ERRNUM (sizeof(regexperrorlist) / sizeof(*regexperrorlist)) static void del_array_element(struct narray *array) { int i, n; char ***data; n = arraynum(array); data = arraydata(array); for (i = 0; i < n; i++) { g_strfreev(data[i]); } arraydel(array); } static int regexpinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; local = g_malloc0(sizeof(*local)); if (local == NULL) { return 1; } local->array = arraynew(sizeof(char **)); if (local->array == NULL) { g_free(local); return 1; } if (_putobj(obj, "_local", inst, local)) { g_free(local); return 1; } return 0; } static int regexpdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj, "_local", inst, &local); if (local->regexp) { g_regex_unref(local->regexp); } if (local->array) { del_array_element(local->array); arrayfree(local->array); } return 0; } static int regexp_set(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct oregexp_local *local; GRegex *regexp; char *str; _getobj(obj, "_local", inst, &local); str = (char *) argv[2]; if (str == NULL || str[0] == '\0') { if (local->regexp) { g_regex_unref(local->regexp); } local->regexp = NULL; del_array_element(local->array); return 0; } if (! g_utf8_validate(str, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } regexp = g_regex_new(str, 0, 0, NULL); if (regexp == NULL) { error(obj, ERR_REGEXP); return 1; } if (local->regexp) { g_regex_unref(local->regexp); } local->regexp = regexp; del_array_element(local->array); return 0; } static int regexp_get(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; int i, j, n; char ***strvp, **strv; i = * (int *) argv[2]; j = * (int *) argv[3]; g_free(rval->str); rval->str = NULL; if (i < 0) { return 1; } _getobj(obj, "_local", inst, &local); strvp = arraynget(local->array, i); if (strvp == NULL) { return 1; } strv = *strvp; for (n = 0; strv[n]; n++) { if (n == j) { rval->str = g_strdup(strv[n]); return 0; } } return 1; } static int regexp_num(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; rval->i = 0; _getobj(obj, "_local", inst, &local); rval->i = arraynum(local->array); return 0; } static int regexp_match(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; GMatchInfo *info; int r; char *str, **match; str = (char *) argv[2]; rval->i = 0; _getobj(obj, "_local", inst, &local); if (local->regexp == NULL) { return 1; } del_array_element(local->array); if (str == NULL || str[0] == '\0') { return 1; } info = NULL; r = g_regex_match(local->regexp, str, 0, &info); if (! r) { g_match_info_free(info); return 1; } while (g_match_info_matches(info)) { match = g_match_info_fetch_all(info); arrayadd(local->array, &match); g_match_info_next(info, NULL); } g_match_info_free(info); rval->i = arraynum(local->array); return 0; } static int regexp_replace(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct oregexp_local *local; char *str, *replace; g_free(rval->str); rval->str = NULL; str = (char *) argv[2]; replace = (char *) argv[3]; if (str == NULL || str[0] == '\0') { return 0; } if (replace == NULL) { replace = ""; } if (! g_utf8_validate(str, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } if (! g_utf8_validate(replace, -1, NULL)) { error(obj, ERR_INVALID_UTF8); return 1; } _getobj(obj, "_local", inst, &local); if (local->regexp == NULL) { return 1; } rval->str = g_regex_replace(local->regexp, str, -1, 0, replace, 0, NULL); return 0; } int regexp_seq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct oregexp_local *local; GString *str; int i, n; g_free(rval->str); rval->str = NULL; _getobj(obj, "_local", inst, &local); n = arraynum(local->array); if (n == 0) { return 0; } str = g_string_sized_new(64); if (str == NULL) { return 0; } for (i = 0; i < n; i++) { g_string_append_printf(str, "%d%s", i, (i == n - 1) ? "" : " "); } rval->str = g_string_free(str, FALSE); return 0; } int regexp_rseq(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct oregexp_local *local; GString *str; int i, n; g_free(rval->str); rval->str = NULL; _getobj(obj, "_local", inst, &local); n = arraynum(local->array); if (n == 0) { return 0; } str = g_string_sized_new(64); if (str == NULL) { return 0; } for (i = 0; i < n; i++) { g_string_append_printf(str, "%d%s", n - i - 1, (i == n - 1) ? "" : " "); } rval->str = g_string_free(str, FALSE); return 0; } static struct objtable oregexp[] = { {"init", NVFUNC, NEXEC, regexpinit, NULL, 0}, {"done", NVFUNC, NEXEC, regexpdone, NULL, 0}, {"next", NPOINTER,0, NULL, NULL, 0}, {"@", NSTR, NREAD|NWRITE,regexp_set, NULL, 0}, {"match", NIFUNC, NREAD|NEXEC, regexp_match,"s", 0}, {"replace", NSFUNC,NREAD|NEXEC, regexp_replace,"ss",0}, {"get", NSFUNC, NREAD|NEXEC, regexp_get, "ii", 0}, {"num", NIFUNC, NREAD|NEXEC, regexp_num, "", 0}, {"seq", NSFUNC, NREAD|NEXEC, regexp_seq, "", 0}, {"rseq", NSFUNC, NREAD|NEXEC, regexp_rseq, "", 0}, {"_local",NPOINTER,0, NULL, NULL, 0}, }; #define TBLNUM (sizeof(oregexp) / sizeof(*oregexp)) void * addregexp(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,oregexp,ERRNUM,regexperrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/opath.c0000644000175000017500000006315413360377524012741 00000000000000/* * $Id: oline.c,v 1.13 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include "object.h" #include "gra.h" #include "spline.h" #include "mathfn.h" #include "oroot.h" #include "odraw.h" #include "olegend.h" #include "opath.h" #define NAME "path" #define ALIAS "line:curve:polygon" #define PARENT "legend" #define OVERSION "1.00.01" #define ERRSPL 100 static char *patherrorlist[]={ "error: spline interpolation.", }; #define ERRNUM (sizeof(patherrorlist) / sizeof(*patherrorlist)) static char *path_fill_mode[]={ "false", "true", "\0empty", /* for backward compatibility */ "\0even_odd_rule", /* for backward compatibility */ "\0winding_rule", /* for backward compatibility */ NULL, }; enum PATH_FUILL_MODE { PATH_FILL_MODE_TRUE, PATH_FILL_MODE_FALSE, PATH_FILL_MODE_EMPTY, PATH_FILL_MODE_EVEN_ODD, PATH_FILL_MODE_WINDING, }; static char *path_fill_rule[]={ N_("even_odd_rule"), N_("winding_rule"), NULL, }; enum PATH_FUILL_RULE { PATH_FILL_RULE_EVEN_ODD, PATH_FILL_RULE_WINDING, }; static char *path_type[]={ N_("line"), N_("curve"), NULL, }; static int arrowinit(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int width, headlen, headwidth, miter, stroke, join, prm, type, alpha; struct narray *expand_points; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) { return 1; } switch (argv[0][0]) { case 'l': /* line */ type = PATH_TYPE_LINE; break; case 'c': /* curve */ type = PATH_TYPE_CURVE; break; case 'p': /* polygon or path */ type = PATH_TYPE_LINE; prm = 1; if (strcmp(argv[0], "polygon") == 0) { _putobj(obj, "close_path", inst, &prm); } break; default: type = PATH_TYPE_LINE; } width = DEFAULT_LINE_WIDTH; headlen = 72426; headwidth = 60000; miter = 1000; join = JOIN_TYPE_BEVEL; stroke = 1; alpha = 255; if (_putobj(obj, "type", inst, &type)) return 1; if (_putobj(obj, "stroke", inst, &stroke)) return 1; if (_putobj(obj, "width", inst, &width)) return 1; if (_putobj(obj, "miter_limit", inst, &miter)) return 1; if (_putobj(obj, "arrow_length", inst, &headlen)) return 1; if (_putobj(obj, "arrow_width", inst, &headwidth)) return 1; if (_putobj(obj, "join", inst, &join)) return 1; if (_putobj(obj, "stroke_A", inst, &alpha)) return 1; if (_putobj(obj, "fill_A", inst, &alpha)) return 1; expand_points = arraynew(sizeof(int)); if (expand_points == NULL) { return 1; } if (_putobj(obj, "_points", inst, expand_points)) { arrayfree(expand_points); return 1; } return 0; } static int arrowdone(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { if (_exeparent(obj, argv[1], inst, rval, argc, argv)) return 1; return 0; } static int arrowput(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { char *field; int *val_ptr; field = argv[1]; val_ptr = (int *) argv[2]; if (strcmp(field, "width") == 0) { if (*val_ptr < 1) { *val_ptr = 1; } } else if (strcmp(field, "arrow_length") == 0) { if (*val_ptr < ARROW_SIZE_MIN) { *val_ptr = ARROW_SIZE_MIN; } else if (*val_ptr > ARROW_SIZE_MAX) { *val_ptr = ARROW_SIZE_MAX; } } else if (strcmp(field, "arrow_width") == 0) { if (*val_ptr < ARROW_SIZE_MIN) { *val_ptr = ARROW_SIZE_MIN; } else if (*val_ptr > ARROW_SIZE_MAX) { *val_ptr = ARROW_SIZE_MAX; } } if (clear_bbox(obj, inst)) { return 1; } return 0; } static int opath_curve_expand_points(struct objlist *obj, N_VALUE *inst, int intp, struct narray *expand_points) { int num, r; struct narray *points; int *pdata; _getobj(obj, "points", inst, &points); num = arraynum(points) / 2; pdata = arraydata(points); r = curve_expand_points(pdata, num, intp, expand_points); if (r) { error(obj, ERRSPL); } return r; } static void curve_clear(struct objlist *obj,N_VALUE *inst) { struct narray *expand_points; _getobj(obj, "_points", inst, &expand_points); arrayclear(expand_points); } static double get_dx_dy(int x0, int y0, int x1, int y1, double *dx, double *dy) { double len, x, y; x = x0 - x1; y = y0 - y1; len = distance(x, y); *dx = x / len; *dy = y / len; return len; } static void get_arrow_pos(int *points2, int n, int width, int headlen, int headwidth, int x0, int y0, int x1, int y1, int *ap) { int ax0, ay0, ox, oy; double alen, alen2, awidth, len, dx, dy; alen = width * (double) headlen / 10000; awidth = width * (double) headwidth / 20000; len = get_dx_dy(x0, y0, x1, y1, &dx, &dy); ax0 = nround(x0 - dx * alen); ay0 = nround(y0 - dy * alen); alen2 = alen * width / awidth / 2; if (len >= alen2) { ox = oy = 0; if (points2) { points2[n] = nround(x0 - dx * alen2); points2[n + 1] = nround(y0 - dy * alen2); } } else { ox = nround(dx * alen2); oy = nround(dy * alen2); } ax0 += ox; ay0 += oy; ap[0] = nround(ax0 - dy * awidth); ap[1] = nround(ay0 + dx * awidth); ap[2] = x0 + nround(ox); ap[3] = y0 + nround(oy); ap[4] = nround(ax0 + dy * awidth); ap[5] = nround(ay0 - dx * awidth); } static void draw_marker(struct objlist *obj, N_VALUE *inst, int GC, int type, int mark_type, int *ap, int join, int miter, int x0, int y0, int x1, int y1, int width, int fr, int fg, int fb, int fa, int headlen, int headwidth) { double dx, dy; switch (type) { case MARKER_TYPE_ARROW: GRAlinestyle(GC, 0, NULL, 1, GRA_LINE_CAP_BUTT, join, miter); GRAdrawpoly(GC, 3, ap, GRA_FILL_MODE_EVEN_ODD); break; case MARKER_TYPE_WAVE: get_dx_dy(x0, y0, x1, y1, &dx, &dy); draw_marker_wave(obj, inst, GC, width, headlen, headwidth, x0, y0, dx, dy, ERRSPL); break; case MARKER_TYPE_MARK: get_dx_dy(x0, y0, x1, y1, &dx, &dy); draw_marker_mark(obj, inst, GC, width, headlen, headwidth, x0, y0, dx, dy, fr, fg, fb, fa, mark_type); break; case MARKER_TYPE_BAR: get_dx_dy(x0, y0, x1, y1, &dx, &dy); draw_marker_bar(obj, inst, GC, width, headlen, headwidth, x0, y0, dx, dy); break; } } static void draw_stroke(struct objlist *obj, N_VALUE *inst, int GC, int *points2, int *pdata, int num, int close_path) { int width, fr, fg, fb, fa, headlen, headwidth; int join, miter, head_begin, head_end; int x, y, x0, y0, x1, y1, x2, y2, x3, y3, type; struct narray *style; int snum, *sdata; int i; int ap[6], ap2[6]; _getobj(obj, "stroke_R", inst, &fr); _getobj(obj, "stroke_G", inst, &fg); _getobj(obj, "stroke_B", inst, &fb); _getobj(obj, "stroke_A", inst, &fa); _getobj(obj, "width", inst, &width); _getobj(obj, "style", inst, &style); _getobj(obj, "join", inst, &join); _getobj(obj, "miter_limit", inst, &miter); _getobj(obj, "marker_begin", inst, &head_begin); _getobj(obj, "marker_end", inst, &head_end); _getobj(obj, "arrow_length", inst, &headlen); _getobj(obj, "arrow_width", inst, &headwidth); snum = arraynum(style); sdata = arraydata(style); GRAcolor(GC, fr, fg, fb, fa); GRAlinestyle(GC, snum, sdata, width, GRA_LINE_CAP_BUTT, join, miter); x0 = points2[0]; y0 = points2[1]; x1 = points2[2]; y1 = points2[3]; x2 = points2[2 * num - 4]; y2 = points2[2 * num - 3]; x3 = points2[2 * num - 2]; y3 = points2[2 * num - 1]; if (head_begin == MARKER_TYPE_ARROW) { get_arrow_pos(points2, 0, width, headlen, headwidth, x0, y0, x1, y1, ap); } if (head_end == MARKER_TYPE_ARROW) { get_arrow_pos(points2, num * 2 - 2, width, headlen, headwidth, x3, y3, x2, y2, ap2); } if (num > 2 && close_path) { GRAdrawpoly(GC, num, pdata, GRA_FILL_MODE_NONE); } else { x = points2[0]; y = points2[1]; GRAmoveto(GC, x, y); for (i = 1; i < num; i++) { x = points2[i * 2]; y = points2[i * 2 + 1]; GRAlineto(GC, x, y); } } _getobj(obj, "mark_type_begin", inst, &type); draw_marker(obj, inst, GC, head_begin, type, ap, join, miter, x0, y0, x1, y1, width, fr, fg, fb, fa, headlen, headwidth); _getobj(obj, "mark_type_end", inst, &type); draw_marker(obj, inst, GC, head_end, type, ap2, join, miter, x3, y3, x2, y2, width, fr, fg, fb, fa, headlen, headwidth); } static void draw_fill(struct objlist *obj, N_VALUE *inst, int GC, int *points2, int num) { int br, bg, bb, ba, fill_rule; _getobj(obj, "fill_rule", inst, &fill_rule); _getobj(obj, "fill_R", inst, &br); _getobj(obj, "fill_G", inst, &bg); _getobj(obj, "fill_B", inst, &bb); _getobj(obj, "fill_A", inst, &ba); GRAcolor(GC, br, bg, bb, ba); GRAdrawpoly(GC, num, points2, fill_rule + 1); } static int arrowdraw(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int GC, w, h, intp, i, j, num, close_path; struct narray *points; int *points2, *pdata; int x0, y0, x1, y1, type, stroke, fill, clip, zoom; if (_exeparent(obj, argv[1], inst, rval, argc, argv)) { return 1; } _getobj(obj, "GC", inst, &GC); if (GC < 0) { return 0; } _getobj(obj, "stroke", inst, &stroke); _getobj(obj, "fill", inst, &fill); if (fill == 0 && stroke == 0) { return 0; } _getobj(obj, "type", inst, &type); _getobj(obj, "clip", inst, &clip); _getobj(obj, "close_path", inst, &close_path); if (type == PATH_TYPE_CURVE) { _getobj(obj, "interpolation", inst, &intp); _getobj(obj, "_points", inst, &points); if (arraynum(points) == 0) { opath_curve_expand_points(obj, inst, intp, points); } if (intp == INTERPOLATION_TYPE_SPLINE_CLOSE || intp == INTERPOLATION_TYPE_BSPLINE_CLOSE) { close_path = TRUE; } } else { _getobj(obj, "points", inst, &points); } num = arraynum(points) / 2; pdata = arraydata(points); points2 = g_malloc(sizeof(int) * num * 2); if (points2 == NULL) { return 1; } j = 0; x1 = y1 = 0; for (i = 0; i < num; i++) { x0 = pdata[2 * i]; y0 = pdata[2 * i + 1]; if (i == 0 || x0 != x1 || y0 != y1) { points2[2 * j] = x0; points2[2 * j + 1] = y0; j++; x1 = x0; y1 = y0; } } num = j; if (num < 2) { g_free(points2); return 0; } GRAregion(GC, &w, &h, &zoom); GRAview(GC, 0, 0, w * 10000.0 / zoom, h * 10000.0 / zoom, clip); if (fill) { draw_fill(obj, inst, GC, points2, num); } if (stroke) { draw_stroke(obj, inst, GC, points2, pdata, num, close_path); } g_free(points2); GRAaddlist(GC, obj, inst, argv[0], argv[1]); return 0; } static int arrowbbox(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int minx, miny, maxx, maxy; int x, y, num, num2, type, intp, stroke, fill; struct narray *points; int *pdata; struct narray *array; int i, j, width; int headlen, headwidth; int head_begin, head_end; int *points2; int x0, y0, x1, y1, x2, y2, x3, y3; int ap[6], ap2[6]; double dx, dy, awidth, w; array = rval->array; if (arraynum(array) != 0) { return 0; } _getobj(obj, "type", inst, &type); _getobj(obj, "fill", inst, &fill); _getobj(obj, "stroke", inst, &stroke); if (fill == 0 && stroke == 0) { return 0; } if (type == PATH_TYPE_CURVE) { _getobj(obj, "interpolation", inst, &intp); _getobj(obj, "_points", inst, &points); if (arraynum(points) == 0) { opath_curve_expand_points(obj, inst, intp, points); } } else { _getobj(obj, "points", inst, &points); } _getobj(obj, "width", inst, &width); _getobj(obj, "marker_begin", inst, &head_begin); _getobj(obj, "marker_end", inst, &head_end); _getobj(obj, "arrow_length", inst, &headlen); _getobj(obj, "arrow_width", inst, &headwidth); awidth = width * (double) headwidth / 10000; num = arraynum(points) / 2; pdata = arraydata(points); points2 = g_malloc(sizeof(int) * num * 2); if (points2 == NULL) { return 1; } j = 0; x1 = y1 = 0; for (i = 0; i < num; i++) { x0 = pdata[2 * i]; y0 = pdata[2 * i + 1]; if (i == 0 || x0 != x1 || y0 != y1) { points2[2 * j] = x0; points2[2 * j + 1] = y0; j++; x1 = x0; y1 = y0; } } num2 = j; if (num2 < 2) { g_free(points2); return 0; } x0 = points2[0]; y0 = points2[1]; x1 = points2[2]; y1 = points2[3]; x2 = points2[2 * num2 - 4]; y2 = points2[2 * num2 - 3]; x3 = points2[2 * num2 - 2]; y3 = points2[2 * num2 - 1]; g_free(points2); switch (head_begin) { case MARKER_TYPE_ARROW: get_arrow_pos(NULL, 0, width, headlen, headwidth, x0, y0, x1, y1, ap); break; case MARKER_TYPE_WAVE: case MARKER_TYPE_BAR: ap[0] = x0; ap[1] = y0 - awidth; ap[2] = x0 + 0.25 * awidth; ap[3] = y0 + 0.5 * awidth; ap[4] = x0; ap[5] = y0 + awidth; get_dx_dy(x0, y0, x1, y1, &dx, &dy); GRArotate(x0, y0, ap, ap, 3, dx, dy); break; case MARKER_TYPE_MARK: w = awidth / 2; ap[0] = x0 + w; ap[1] = y0 + w; ap[2] = x0 + w; ap[3] = y0 - w; ap[4] = x0; ap[5] = y0; get_dx_dy(x0, y0, x1, y1, &dx, &dy); GRArotate(x0, y0, ap, ap, 2, dx, dy); break; } switch (head_end) { case MARKER_TYPE_ARROW: get_arrow_pos(NULL, 0, width, headlen, headwidth, x3, y3, x2, y2, ap2); break; case MARKER_TYPE_WAVE: case MARKER_TYPE_BAR: ap2[0] = x3; ap2[1] = y3 - awidth; ap2[2] = x3 + 0.25 * awidth; ap2[3] = y3 + 0.5 * awidth; ap2[4] = x3; ap2[5] = y3 + awidth; get_dx_dy(x3, y3, x2, y2, &dx, &dy); GRArotate(x3, y3, ap2, ap2, 3, dx, dy); break; case MARKER_TYPE_MARK: w = awidth / 2; ap2[0] = x3 + w; ap2[1] = y3 + w; ap2[2] = x3 + w; ap2[3] = y3 - w; ap2[4] = x3; ap2[5] = y3; get_dx_dy(x3, y3, x2, y2, &dx, &dy); GRArotate(x3, y3, ap2, ap2, 2, dx, dy); break; } if (array == NULL && (array = arraynew(sizeof(int))) == NULL) { return 1; } maxx = minx = pdata[0]; maxy = miny = pdata[1]; arrayadd(array, &(pdata[0])); arrayadd(array, &(pdata[1])); for (i = 1; i < num; i++) { x = pdata[i * 2]; y = pdata[i * 2 + 1]; if (x < minx) minx = x; if (x > maxx) maxx = x; if (y < miny) miny = y; if (y > maxy) maxy = y; } if (type == PATH_TYPE_CURVE) { _getobj(obj, "points", inst, &points); num = arraynum(points) / 2; pdata = arraydata(points); } for (i = 1; i < num; i++) { x = pdata[i * 2]; y = pdata[i * 2 + 1]; arrayadd(array, &x); arrayadd(array, &y); } if (stroke) { if (head_begin != MARKER_TYPE_NONE) { for (i = 0; i < 3; i++) { if (ap[i * 2] < minx) minx = ap[i * 2]; if (ap[i * 2] > maxx) maxx = ap[i * 2]; if (ap[i * 2 + 1] < miny) miny = ap[i * 2 + 1]; if (ap[i * 2 + 1] > maxy) maxy = ap[i * 2 + 1]; } } if (head_end != MARKER_TYPE_NONE) { for (i = 0; i < 3 ; i++) { if (ap2[i * 2] < minx) minx = ap2[i * 2]; if (ap2[i * 2] > maxx) maxx = ap2[i * 2]; if (ap2[i * 2 + 1] < miny) miny = ap2[i * 2+ 1]; if (ap2[i * 2 + 1] > maxy) maxy = ap2[i * 2 + 1]; } } minx -= width / 2; miny -= width / 2; maxx += width / 2; maxy += width / 2; } arrayins(array, &(maxy), 0); arrayins(array, &(maxx), 0); arrayins(array, &(miny), 0); arrayins(array, &(minx), 0); if (arraynum(array) == 0) { arrayfree(array); rval->array = NULL; return 1; } rval->array = array; return 0; } static int set_points(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { curve_clear(obj, inst); return legendgeometry(obj, inst, rval, argc, argv); } static int check_point_match(int i, int j, int *pdata, int err, int x, int y) { double x1, y1, x2, y2, r, ip; x1 = pdata[i * 2]; y1 = pdata[i * 2 + 1]; x2 = pdata[j * 2]; y2 = pdata[j * 2 + 1]; r = distance(x - x1, y - y1); if (r <= err) { return TRUE; } r = distance(x - x2, y - y2); if (r <= err) { return TRUE; } r = distance(x1 - x2, y1 - y2); if (r == 0) { return FALSE; } ip = ((x2 - x1) * (x - x1) + (y2 - y1) * (y - y1)) / r; if (ip < 0 || ip > r) { return FALSE; } x2 = x1 + (x2 - x1) * ip / r; y2 = y1 + (y2 - y1) * ip / r; r = distance(x - x2, y - y2); if (r <= err) { return TRUE; } return FALSE; } static int point_match(struct objlist *obj, N_VALUE *inst, int type, int fill, int err, int x, int y) { struct narray *points; int *pdata, num, r, i; if (type == PATH_TYPE_CURVE) { int intp; _getobj(obj, "interpolation", inst, &intp); _getobj(obj, "_points", inst, &points); if (arraynum(points) == 0) { opath_curve_expand_points(obj, inst, intp, points); } } else { _getobj(obj, "points", inst, &points); } num = arraynum(points) / 2; pdata = arraydata(points); if (num == 0 || pdata == NULL) { return FALSE; } r = FALSE; for (i = 0; i < num - 1; i++) { r = check_point_match(i, i + 1, pdata, err, x, y); if (r) { break; } } if (r == FALSE) { int close_path; _getobj(obj, "close_path", inst, &close_path); if (fill || close_path) { r = check_point_match(0, num - 1, pdata, err, x, y); } } return r; } static int curvematch(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int minx, miny, maxx, maxy, err; int bminx, bminy, bmaxx, bmaxy; int fill, stroke, type; struct narray *array; rval->i = FALSE; if (_exeparent(obj,argv[1],inst,rval,argc,argv)) { return 1; } _getobj(obj, "type", inst, &type); _getobj(obj, "fill", inst, &fill); _getobj(obj, "stroke", inst, &stroke); if (fill == 0 && stroke == 0) { return 0; } minx = * (int *) argv[2]; miny = * (int *) argv[3]; maxx = * (int *) argv[4]; maxy = * (int *) argv[5]; err = * (int *) argv[6]; if (minx == maxx && miny == maxy) { rval->i = point_match(obj, inst, type, fill, err, minx, miny); } else { if (_exeobj(obj, "bbox", inst, 0, NULL)) { return 1; } _getobj(obj, "bbox", inst, &array); if (array == NULL) { return 0; } if (arraynum(array) < 4) { return 1; } bminx = arraynget_int(array, 0); bminy = arraynget_int(array, 1); bmaxx = arraynget_int(array, 2); bmaxy = arraynget_int(array, 3); if (minx <= bminx && bminx <= maxx && minx <= bmaxx && bmaxx <= maxx && miny <= bminy && bminy <= maxy && miny <= bmaxy && bmaxy <= maxy) { rval->i = TRUE; } } return 0; } static int curve_flip(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { #if ! ROTATE_MARK int type_begin, type_end; enum FLIP_DIRECTION dir; dir = (* (int *) argv[2] == FLIP_DIRECTION_HORIZONTAL) ? FLIP_DIRECTION_HORIZONTAL : FLIP_DIRECTION_VERTICAL; _getobj(obj, "mark_type_begin", inst, &type_begin); _getobj(obj, "mark_type_end", inst, &type_end); type_begin = mark_flip(dir, type_begin); type_end = mark_flip(dir, type_end); _putobj(obj, "mark_type_begin", inst, &type_begin); _putobj(obj, "mark_type_end", inst, &type_end); #endif curve_clear(obj, inst); return legendflip(obj, inst, rval, argc, argv); } static int curve_move(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *points; int i, num, *pdata, type; _getobj(obj, "type", inst, &type); if (type == PATH_TYPE_CURVE) { _getobj(obj, "_points", inst, &points); num = arraynum(points); pdata = arraydata(points); for (i = 0; i < num; i++) { if (i % 2 == 0) { pdata[i] += * (int *) argv[2]; } else { pdata[i] += * (int *) argv[3]; } } } return legendmove(obj, inst, rval, argc, argv); } static int curve_rotate(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { #if ! ROTATE_MARK int type_begin, type_end, angle; angle = *(int *) argv[2]; _getobj(obj, "mark_type_begin", inst, &type_begin); _getobj(obj, "mark_type_end", inst, &type_end); type_begin = mark_rotate(angle, type_begin); type_end = mark_rotate(angle, type_end); _putobj(obj, "mark_type_begin", inst, &type_begin); _putobj(obj, "mark_type_end", inst, &type_end); #endif curve_clear(obj, inst); return legendrotate(obj, inst, rval, argc, argv); } static int curve_zoom(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { curve_clear(obj, inst); return legendzoom(obj, inst, rval, argc, argv); } static int curve_change(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { curve_clear(obj, inst); return legendchange(obj, inst, rval, argc, argv); } static int put_fill_mode(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int mode, rule; mode = * (int *) argv[2]; switch (mode) { case PATH_FILL_MODE_TRUE: break; case PATH_FILL_MODE_FALSE: break; case PATH_FILL_MODE_EMPTY: * (int *) argv[2] = FALSE; break; case PATH_FILL_MODE_EVEN_ODD: * (int *) argv[2] = TRUE; rule = PATH_FILL_RULE_EVEN_ODD; _putobj(obj, "fill_rule", inst, &rule); break; case PATH_FILL_MODE_WINDING: * (int *) argv[2] = TRUE; rule = PATH_FILL_RULE_WINDING; _putobj(obj, "fill_rule", inst, &rule); break; default: * (int *) argv[2] = FALSE; } return legendgeometry(obj, inst, rval, argc, argv); } static int arrowput_arrow(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { int arrow, type; arrow = * (int *) argv[2]; switch (arrow) { case ARROW_POSITION_NONE: type = MARKER_TYPE_NONE; _putobj(obj, "marker_begin", inst, &type); _putobj(obj, "marker_end", inst, &type); break; case ARROW_POSITION_END: type = MARKER_TYPE_NONE; _putobj(obj, "marker_begin", inst, &type); type = MARKER_TYPE_ARROW; _putobj(obj, "marker_end", inst, &type); break; case ARROW_POSITION_BEGIN: type = MARKER_TYPE_ARROW; _putobj(obj, "marker_begin", inst, &type); type = MARKER_TYPE_NONE; _putobj(obj, "marker_end", inst, &type); break; case ARROW_POSITION_BOTH: type = MARKER_TYPE_ARROW; _putobj(obj, "marker_begin", inst, &type); _putobj(obj, "marker_end", inst, &type); break; } if (clear_bbox(obj, inst)) { return 1; } return 0; } static struct objtable arrow[] = { {"init", NVFUNC, NEXEC, arrowinit, NULL, 0}, {"done", NVFUNC, NEXEC, arrowdone, NULL, 0}, {"next", NPOINTER, 0, NULL, NULL, 0}, {"type", NENUM, NREAD|NWRITE, set_points, path_type, 0}, {"points", NIARRAY, NREAD|NWRITE, set_points, NULL, 0}, {"_points", NIARRAY, NREAD, NULL, NULL, 0}, {"interpolation", NENUM, NREAD|NWRITE, set_points, intpchar, 0}, {"fill_R", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"fill_G", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"fill_B", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"fill_A", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"stroke_R", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"stroke_G", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"stroke_B", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"stroke_A", NINT, NREAD|NWRITE, oputcolor, NULL, 0}, {"fill", NENUM, NREAD|NWRITE, put_fill_mode, path_fill_mode, 0}, {"fill_rule", NENUM, NREAD|NWRITE, NULL, path_fill_rule, 0}, {"stroke", NBOOL, NREAD|NWRITE, NULL, NULL, 0}, {"close_path", NBOOL, NREAD|NWRITE, NULL, NULL, 0}, {"width", NINT, NREAD|NWRITE, arrowput, NULL, 0}, {"style", NIARRAY, NREAD|NWRITE, oputstyle, NULL, 0}, {"join", NENUM, NREAD|NWRITE, NULL, joinchar, 0}, {"miter_limit", NINT, NREAD|NWRITE, oputge1, NULL, 0}, {"marker_begin", NENUM, NREAD|NWRITE, arrowput, marker_type_char, 0}, {"marker_end", NENUM, NREAD|NWRITE, arrowput, marker_type_char, 0}, {"arrow_length", NINT, NREAD|NWRITE, arrowput, NULL, 0}, {"arrow_width", NINT, NREAD|NWRITE, arrowput, NULL, 0}, {"mark_type_begin",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"mark_type_end",NINT,NREAD|NWRITE,oputmarktype,NULL,0}, {"draw", NVFUNC, NREAD|NEXEC, arrowdraw, "i", 0}, {"bbox", NIAFUNC, NREAD|NEXEC, arrowbbox, "", 0}, {"move", NVFUNC, NREAD|NEXEC, curve_move, "ii", 0}, {"rotate", NVFUNC, NREAD|NEXEC, curve_rotate, "iiii", 0}, {"flip", NVFUNC, NREAD|NEXEC, curve_flip, "iii", 0}, {"change", NVFUNC, NREAD|NEXEC, curve_change, "iii", 0}, {"zooming", NVFUNC, NREAD|NEXEC, curve_zoom, "iiii", 0}, {"match", NBFUNC, NREAD|NEXEC, curvematch, "iiiii", 0}, {"fill_hsb", NVFUNC, NREAD|NEXEC, put_fill_hsb,"ddd",0}, {"stroke_hsb", NVFUNC, NREAD|NEXEC, put_stroke_hsb,"ddd",0}, /* following fields exist for backward compatibility */ {"R", NINT, NWRITE, put_color_for_backward_compatibility, NULL, 0}, {"G", NINT, NWRITE, put_color_for_backward_compatibility, NULL, 0}, {"B", NINT, NWRITE, put_color_for_backward_compatibility, NULL, 0}, {"A", NINT, NWRITE, put_color_for_backward_compatibility, NULL, 0}, {"arrow", NENUM, NWRITE, arrowput_arrow, arrowchar, 0}, }; #define TBLNUM (sizeof(arrow) / sizeof(*arrow)) void * addpath(void) /* addarrow() returns NULL on error */ { return addobject(NAME, ALIAS, PARENT, OVERSION, TBLNUM, arrow, ERRNUM, patherrorlist, NULL, NULL); } ngraph-gtk-6.08.00/src/ogra.c0000644000175000017500000002753013154220370012537 00000000000000/* * $Id: ogra.c,v 1.11 2009-11-16 09:13:04 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include "object.h" #include "ioutil.h" #include "ogra.h" #include "gra.h" #define NAME "gra" #define PARENT "object" #define OVERSION "1.00.00" static char *GRAerrorlist[]={ "unable to open device", "device is busy", "device is already opened", "no instance for output device", "illegal graphics context", "gra is now opened.", "gra is closed.", }; #define ERRNUM (sizeof(GRAerrorlist) / sizeof(*GRAerrorlist)) static void set_progress_val(int i, int n, const char *name); static int oGRAclose(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv); static int oGRAinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC,width,height,zoom; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; GC=-1; width=21000; height=29700; zoom=10000; if (_putobj(obj,"open",inst,&GC)) return 1; if (_putobj(obj,"GC",inst,&GC)) return 1; if (_putobj(obj,"zoom",inst,&zoom)) return 1; if (_putobj(obj,"paper_width",inst,&width)) return 1; if (_putobj(obj,"paper_height",inst,&height)) return 1; return 0; } static int oGRAdisconnect(struct objlist *obj,void *inst,int clear) { struct objlist *dobj,*gobj; struct narray *sarray; char *list; N_VALUE *dinst; char *device,*dfield,*gfield; int oid,did,gid; _getobj(obj,"oid",inst,&oid); _getobj(obj,"_device",inst,&device); _putobj(obj,"_device",inst,NULL); if (device!=NULL) { if (((dobj=getobjlist(device,&did,&dfield,NULL))!=NULL) && ((dinst=chkobjinstoid(dobj,did))!=NULL)) { if ((!chkobjfield(dobj,"_list")) && (!_getobj(dobj,"_list",dinst,&sarray)) && (sarray!=NULL)) { list=arraynget_str(sarray,0); if (((gobj=getobjlist(list,&gid,&gfield,NULL))!=NULL) && (gobj==obj) && (gid==oid) && (strcmp(gfield,"open")==0)) { arrayfree2(sarray); _putobj(dobj,"_list",dinst,NULL); _exeobj(dobj,"disconnect",dinst,0,NULL); if (clear) _exeobj(dobj,"disconnect",dinst,0,NULL); } } } } g_free(device); return 0; } static int oGRAdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; _getobj(obj,"GC",inst,&GC); GRAclose(GC); if (oGRAdisconnect(obj,inst,FALSE)) return 1; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int oGRAputdevice(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { int GC; _getobj(obj,"GC",inst,&GC); if (GC!=-1) { error(obj,ERRGRABUSY); return 1; } if (oGRAdisconnect(obj,inst,FALSE)) return 1; return 0; } static int close_gc(struct objlist *obj, N_VALUE *inst, int GC) { GRAclose(GC); GC = -1; if (_putobj(obj, "GC", inst, &GC)) { return 1; } return 0; } static int oGRAopen(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int anum,id; struct narray iarray; int GC, r; char *device,*dev,*gfield; struct objlist *dobj,*gobj,*robj; N_VALUE *dinst,*ginst; void *local; struct narray **list; int oid,gid; int topm,leftm,width,height,zoom; int output,charheight,chardescent,strwidth; _getobj(obj,"device",inst,&device); _getobj(obj,"GC",inst,&GC); if (GC!=-1) { error2(obj,ERRALOPEN,device); return 1; } _getobj(obj,"left_margin",inst,&leftm); _getobj(obj,"top_margin",inst,&topm); _getobj(obj,"zoom",inst,&zoom); _getobj(obj,"paper_width",inst,&width); _getobj(obj,"paper_height",inst,&height); if (device==NULL) { GC=GRAopen(NULL,NULL,NULL,NULL,-1,-1,-1,-1,NULL,NULL); if (GC<0) { error2(obj,ERROPEN,device); return 1; } } else { arrayinit(&iarray,sizeof(int)); if (getobjilist(device,&dobj,&iarray,FALSE,NULL)) return 1; anum=arraynum(&iarray); if (anum<1) { arraydel(&iarray); error2(obj,ERRNODEVICE,device); return 1; } id=arraylast_int(&iarray); arraydel(&iarray); /* check target device */ dinst = getobjinst(dobj, id); if (dinst == NULL) { return 1; } robj = NULL; if (!chkobjfield(dobj,"_output")) { if ((output=getobjtblpos(dobj,"_output",&robj))==-1) return 1; } else output=-1; if (!chkobjfield(dobj,"_strwidth")) { if ((strwidth=getobjtblpos(dobj,"_strwidth",&robj))==-1) return 1; } else strwidth=-1; if (!chkobjfield(dobj,"_charascent")) { if ((charheight=getobjtblpos(dobj,"_charascent",&robj))==-1) return 1; } else charheight=-1; if (!chkobjfield(dobj,"_chardescent")) { if ((chardescent=getobjtblpos(dobj,"_chardescent",&robj))==-1) return 1; } else chardescent=-1; if (robj == NULL) { error2(obj, ERROPEN, device); return -1; } if (!chkobjfield(dobj,"_list")) { int offset; offset = getobjoffset(dobj, "_list"); if (offset == -1) { return 1; } list = &dinst[offset].array; } else { list = NULL; } if (!chkobjfield(dobj,"_local")) { if (_getobj(dobj,"_local",dinst,&local)) return 1; } else local=NULL; GC=GRAopen(chkobjectname(dobj),"_output", robj,dinst,output,strwidth,charheight,chardescent,list,local); if (GC==-2) { error2(obj,ERRBUSY,device); return 1; } else if (GC<0) { error2(obj,ERROPEN,device); return 1; } /* clear gra connected to target device */ if ((list!=NULL) && (*list!=NULL) && (arraynum(*list)!=0)) { if (((gobj=getobjlist(arraynget_str(*list,0),&gid,&gfield,NULL))!=NULL) && ((ginst=chkobjinstoid(gobj,gid))!=NULL) && (!_getobj(gobj,"_device",ginst,&dev))) { if (oGRAdisconnect(gobj,ginst,TRUE)) return 1; } } if (oGRAdisconnect(obj,inst,FALSE)) return 1; if (!_getobj(dobj,"oid",dinst,&oid)) { if ((dev=mkobjlist(dobj,NULL,oid,"_output",TRUE))!=NULL) if (_putobj(obj,"_device",inst,dev)) { g_free(dev); return 1; } } } rval->i=GC; if (_putobj(obj,"GC",inst,&GC)) return 1; r = GRAinit(GC,leftm,topm,width,height,zoom); if (r) { error2(obj,ERROPEN,device); close_gc(obj, inst, GC); return r; } GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int oGRAclose(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; _getobj(obj,"GC",inst,&GC); GRAend(GC); return close_gc(obj, inst, GC); } static int oGRAredraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct objlist *dobj; N_VALUE *dinst; char *device,*dfield,*field; int oid,did; field=(char *)(argv[1]); _getobj(obj,"oid",inst,&oid); _getobj(obj,"_device",inst,&device); if (device!=NULL) { if (((dobj=getobjlist(device,&did,&dfield,NULL))!=NULL) && ((dinst=chkobjinstoid(dobj,did))!=NULL)) { if (chkobjfield(dobj,field)==0) _exeobj(dobj,field,dinst,0,NULL); } } return 0; } static int oGRAclear(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; struct objlist *dobj; N_VALUE *dinst; char *device,*dfield,*field; int oid,did; field=(char *)(argv[1]); _getobj(obj,"GC",inst,&GC); if (GC!=-1) GRAreopen(GC); _getobj(obj,"oid",inst,&oid); _getobj(obj,"_device",inst,&device); if (device!=NULL) { if (((dobj=getobjlist(device,&did,&dfield,NULL))!=NULL) && ((dinst=chkobjinstoid(dobj,did))!=NULL)) { if (chkobjfield(dobj,field)==0) _exeobj(dobj,field,dinst,0,NULL); } } return 0; } static int oGRAputtopm(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; char *arg; _getobj(obj,"GC",inst,&GC); if (GC!=-1) { error(obj,ERRGRABUSY); return 1; } arg=argv[1]; if (arg[0]=='p') { if ((*(int *)(argv[2]))<=0) *(int *)(argv[2])=1; } else if (arg[0]=='z') { if ((*(int *)(argv[2]))<=0) *(int *)(argv[2])=1; } if (oGRAdisconnect(obj,inst,FALSE)) return 1; return 0; } static int oGRAdrawparent(struct objlist *parent, char **oGRAargv, int layer) { struct objlist *ocur; int i,instnum; const char *objname; ocur=chkobjroot(); while (ocur!=NULL) { if (chkobjparent(ocur)==parent) { instnum = chkobjlastinst(ocur); if (instnum != -1) { objname = chkobjectname(ocur); if (layer) { GRAlayer(*((int *) oGRAargv[0]), objname); } for (i=0;i<=instnum;i++) { set_progress_val(i, instnum, objname); if (ninterrupt()) return FALSE; exeobj(ocur,"draw",i,1,oGRAargv); } } if (!oGRAdrawparent(ocur, oGRAargv, layer)) return FALSE; } ocur=ocur->next; } return TRUE; } static int oGRAdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC, layer; struct objlist *draw; struct narray *array; char **drawrable; const char *objname; char *oGRAargv[2]; int j,i,anum,instnum; _getobj(obj,"GC",inst,&GC); if (GC==-1) { error(obj,ERRGRACLOSE); return 1; } layer = GRAlayer_support(GC); _getobj(obj,"draw_obj",inst,&array); oGRAargv[0]=(char *)&GC; oGRAargv[1]=NULL; if (array==NULL) { if ((draw=getobject("draw"))==NULL) return 1; oGRAdrawparent(draw, oGRAargv, layer); } else { anum=arraynum(array); drawrable=arraydata(array); for (j=0;j #include #include #include #include #include #include #include #include #include "object.h" #include "nstring.h" #include "ntime.h" #include "ioutil.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "osystem.h" #define NAME "merge" #define PARENT "draw" #define OVERSION "1.00.00" #define OLD_GRA_HEADER " Ngraph GRA file" #define ERRFILE 100 #define ERROPEN 101 #define ERRGRA 102 #define ERRGRAFM 103 static char *mergeerrorlist[]={ "GRA file is not specified.", "I/O error: open file", "not GRA file", "illegal GRA format", }; #define ERRNUM (sizeof(mergeerrorlist) / sizeof(*mergeerrorlist)) struct mergelocal { FILE *storefd; int endstore; time_t mtime; int bbox[4]; }; struct gra_info { int GC, lm, tm, zmx, zmy; GStatBuf gstat; struct objlist *obj; }; #define USE_MERGE_CACHE 1 #if USE_MERGE_CACHE struct gra_cache { struct GRAdata *data; GStatBuf gstat; }; static NHASH GraCache = NULL; #endif static void set_bbox(struct objlist *obj,N_VALUE *inst, struct narray *array, int l, int t, int zx, int zy) { int *bbox; double zoom_x, zoom_y; struct mergelocal *mergelocal; _getobj(obj,"_local",inst,&mergelocal); if (arraynum(array) != 4) { return; } bbox = arraydata(array); zoom_x = zx / 10000.0; zoom_y = zy / 10000.0; bbox[0] = (mergelocal->bbox[0]) * zoom_x + l; bbox[1] = (mergelocal->bbox[1]) * zoom_y + t; bbox[2] = (mergelocal->bbox[2]) * zoom_x + l; bbox[3] = (mergelocal->bbox[3]) * zoom_y + t; } #if USE_MERGE_CACHE static struct GRAdata * gra_data_new(void) { struct GRAdata *data; data = g_malloc(sizeof(*data)); if (data == NULL) { return NULL; } data->code = '\0'; data->cpar = NULL; data->cstr = NULL; data->next = NULL; return data; } static void gra_data_free(struct GRAdata *data) { struct GRAdata *next; while (data) { next = data->next; g_free(data->cpar); g_free(data->cstr); g_free(data); data = next; } } static struct gra_cache * gra_cache_new(const char *file) { struct gra_cache *cache; if (GraCache == NULL) { GraCache = nhash_new(); } if (GraCache == NULL) { return NULL; } cache = g_malloc(sizeof(*cache)); if (cache == NULL) { return NULL; } cache->data = NULL; cache->gstat.st_mtime = 0; cache->gstat.st_size = 0; nhash_set_ptr(GraCache, file, cache); return cache; } static struct gra_cache * gra_cache_get(const char *file) { void *ptr; if (GraCache == NULL) { return NULL; } nhash_get_ptr(GraCache, file, &ptr); return ptr; } static void gra_cache_free(const char *file) { struct gra_cache *cache; cache = gra_cache_get(file); if (cache == NULL) { return; } gra_data_free(cache->data); g_free(cache); nhash_del(GraCache, file); } #endif /* USE_MERGE_CACHE */ static int mergeinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int zm, n; struct mergelocal *mergelocal; char *ext; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; zm=10000; n = 0; ext = g_strdup("gra"); if (_putobj(obj,"zoom_x",inst,&zm)) return 1; if (_putobj(obj,"zoom_y",inst,&zm)) return 1; if (_putobj(obj,"line_num",inst,&n)) return 1; if (_putobj(obj,"ext",inst,ext)) return 1; if ((mergelocal=g_malloc(sizeof(struct mergelocal)))==NULL) goto errexit; if (_putobj(obj,"_local",inst,mergelocal)) goto errexit; mergelocal->storefd=NULL; mergelocal->endstore=FALSE; mergelocal->mtime = 0; mergelocal->bbox[0] = 0; mergelocal->bbox[1] = 0; mergelocal->bbox[2] = 0; mergelocal->bbox[3] = 0; return 0; errexit: g_free(mergelocal); return 1; } static int mergedone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } #if USE_MERGE_CACHE static void gra_cache_init(struct gra_cache *cache, struct gra_info *info) { if (cache->data) { gra_data_free(cache->data); cache->data = NULL; } if (info) { cache->gstat = info->gstat; } else { cache->gstat.st_mtime = 0; cache->gstat.st_size = 0; } } static int * dup_cpar(const int *cpar) { int n; n = cpar[0] + 1; if (n < 1) { n = 1; } return g_memdup(cpar, n * sizeof(*cpar)); } static int draw_gra_data(struct gra_info *info, struct GRAdata *data) { int rcode, *cpar; cpar = dup_cpar(data->cpar); if (cpar == NULL) { return FALSE; } rcode = GRAinputdraw(info->GC, info->lm, info->tm, info->zmx, info->zmy, data->code, cpar, data->cstr); g_free(cpar); return rcode; } static int read_new_gra_file(struct gra_cache *cache, struct gra_info *info, FILE *fd) { int r; char *buf; int rcode; struct GRAdata *prev, *data; gra_cache_init(cache, info); r = 0; prev = NULL; while ((rcode = fgetline(fd, &buf)) != 1) { if (rcode == -1) { return 1; } data = gra_data_new(); if (data == NULL) { goto errexit; } rcode = GRAparse(data, buf); if (! rcode) { GRAdata_free(data); error2(info->obj, ERRGRAFM, buf); goto errexit; } rcode = draw_gra_data(info, data); if (! rcode) { GRAdata_free(data); error2(info->obj, ERRGRAFM, buf); goto errexit; } g_free(buf); if (prev) { prev->next = data; } else { cache->data = data; } prev = data; } return r; errexit: g_free(buf); gra_cache_init(cache, NULL); return 1; } static int read_old_gra_file(struct gra_cache *cache, struct gra_info *info, FILE *fd, const char *file) { int r; char *buf; int rcode; gra_cache_init(cache, NULL); rcode = fgetline(fd, &buf); if (rcode == 1) { error2(info->obj, ERRGRA, file); } g_free(buf); if (rcode != 0) { return 1; } r = 0; while ((rcode = fgetline(fd, &buf)) != 1) { if (rcode == -1) { return 1; } rcode = GRAinputold(info->GC, buf, info->lm, info->tm, info->zmx, info->zmy); if (!rcode) { error2(info->obj, ERRGRAFM, buf); g_free(buf); return 1; } g_free(buf); } return r; } static int read_gra_file(struct gra_cache *cache, struct gra_info *info, const char *graf, const char *file) { FILE *fd; char *buf; int newgra, rcode; fd = nfopen(file, "rt"); if (fd == NULL) { error2(info->obj, ERROPEN, file); return 1; } rcode = fgetline(fd, &buf); if (rcode == 1) { error2(info->obj,ERRGRA,file); } if (rcode != 0) { error2(info->obj, ERROPEN, file); fclose(fd); return 1; } if (strcmp(graf, buf) == 0) { newgra = TRUE; } else if (strcmp(OLD_GRA_HEADER, buf) == 0) { newgra = FALSE; } else { error2(info->obj, ERRGRA, file); g_free(buf); fclose(fd); return 1; } g_free(buf); if (newgra) { rcode = read_new_gra_file(cache, info, fd); } else { rcode = read_old_gra_file(cache, info, fd, file); } fclose(fd); return rcode; } static int draw_gra(struct gra_cache *cache, struct gra_info *info) { struct GRAdata *data; int rcode; if (cache == NULL) { return 0; } data = cache->data; if (data == NULL) { return 0; } while (data) { rcode = draw_gra_data(info, data); if (! rcode) { return 1; } data = data->next; } return 0; } static int free_cache(struct nhash *hash, void *data) { struct gra_cache *cache; cache = hash->val.p; if (cache == NULL) { return 0; } gra_data_free(cache->data); g_free(cache); hash->val.p = NULL; return 0; } static int read_gra(struct gra_info *info, const char *graf, const char *file) { struct gra_cache *cache; cache = gra_cache_get(file); if (cache == NULL) { cache = gra_cache_new(file); if (cache == NULL) { return 1; } } if (info->gstat.st_mtime != cache->gstat.st_mtime || info->gstat.st_size != cache->gstat.st_size) { if (read_gra_file(cache, info, graf, file)) { gra_cache_free(file); return 1; } } else { if (draw_gra(cache, info)) { error2(info->obj, ERRGRAFM, file); return 1; } } return 0; } #endif /* USE_MERGE_CACHE */ void merge_cache_clear(void) { #if USE_MERGE_CACHE if (GraCache == NULL) { return; } nhash_each(GraCache, free_cache, NULL); nhash_clear(GraCache); #endif } static int mergedraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct gra_info info; char *file,*graf; struct objlist *sys; struct mergelocal *mergelocal; #if ! USE_MERGE_CACHE FILE *fd; int newgra,rcode; char *buf; #endif if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"GC",inst,&info.GC); if (info.GC<0) return 0; _getobj(obj,"file",inst,&file); _getobj(obj,"left_margin",inst,&info.lm); _getobj(obj,"top_margin",inst,&info.tm); _getobj(obj,"zoom_x",inst,&info.zmx); _getobj(obj,"zoom_y",inst,&info.zmy); _getobj(obj,"_local",inst,&mergelocal); info.obj = obj; if (file==NULL) { error(obj,ERRFILE); return 1; } if (nstat(file, &info.gstat)) { clear_bbox(obj, inst); error2(obj, ERROPEN, file); return 1; } if (info.gstat.st_mtime != mergelocal->mtime) { clear_bbox(obj, inst); } mergelocal->mtime = info.gstat.st_mtime; if ((sys=getobject("system"))==NULL) return 1; if (getobj(sys,"GRAF",0,0,NULL,&graf)) return 1; #if USE_MERGE_CACHE read_gra(&info, graf, file); #else /* USE_MERGE_CACHE */ if ((fd=nfopen(file,"rt"))==NULL) { error2(obj,ERROPEN,file); return 1; } if ((rcode=fgetline(fd,&buf))==1) error2(obj,ERRGRA,file); if (rcode!=0) { fclose(fd); return 1; } if (strcmp(graf,buf)==0) newgra=TRUE; else if (strcmp(OLD_GRA_HEADER,buf)==0) newgra=FALSE; else { error2(obj,ERRGRA,file); g_free(buf); fclose(fd); return 1; } g_free(buf); if (!newgra) { if ((rcode=fgetline(fd,&buf))==1) error2(obj,ERRGRA,file); g_free(buf); if (rcode!=0) { fclose(fd); return 1; } } while ((rcode=fgetline(fd,&buf))!=1) { if (rcode==-1) { fclose(fd); return 1; } if (newgra) { rcode=GRAinput(info.GC, buf, info.lm, info.tm, info.zm); } else { rcode=GRAinputold(info.GC, buf, info.lm, info.tm, info.zm); } if (!rcode) { error2(obj,ERRGRAFM,buf); g_free(buf); fclose(fd); return 1; } g_free(buf); } fclose(fd); #endif /* USE_MERGE_CACHE */ GRAaddlist(info.GC,obj,inst,(char *)argv[0],"redraw"); return 0; } static int mergeredraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int hidden; #if ! USE_MERGE_CACHE int redrawf; #endif if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"hidden",inst,&hidden); #if USE_MERGE_CACHE if (! hidden) { mergedraw(obj,inst,rval,argc,argv); } #else /* USE_MERGE_CACHE */ _getobj(obj,"redraw_flag",inst,&redrawf); if (redrawf) { mergedraw(obj,inst,rval,argc,argv); } else { int GC; struct narray *array; int x1, x2, y1, y2, zoom, w, h; if (! hidden) { system_draw_notify(); } _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; if (_exeobj(obj, "bbox", inst, 0, NULL)) { return 1; } _getobj(obj, "bbox", inst, &array); if (array) { x1 = arraynget_int(array,0); y1 = arraynget_int(array,1); x2 = arraynget_int(array,2); y2 = arraynget_int(array,3); GRAregion(GC, &w, &h, &zoom); GRAview(GC, 0, 0, w * 10000.0 / zoom, h * 10000.0 / zoom, 1); GRAcolor(GC, 0, 0, 0, 255); GRAlinestyle(GC, 0, NULL, 10, GRA_LINE_CAP_BUTT, GRA_LINE_JOIN_MITER, 1000); GRArectangle(GC, x1, y1, x2, y2, 0); } GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); } #endif /* USE_MERGE_CACHE */ return 0; } static int mergefile(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct objlist *sys; int ignorepath; char *file, *file2; sys=getobject("system"); getobj(sys, "ignore_path", 0, 0, NULL, &ignorepath); if (argv[2] == NULL) { return 0; } file = get_utf8_filename(argv[2]); g_free(argv[2]); if (file == NULL) { argv[2] = NULL; return 1; } if (ignorepath) { file2 = getbasename(file); g_free(file); argv[2] = file2; } else { argv[2] = file; } if (clear_bbox(obj, inst)) { return 1; } return 0; } static int mergetime(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; GStatBuf buf; int style; g_free(rval->str); rval->str=NULL; _getobj(obj,"file",inst,&file); if (file==NULL) return 0; if (nstat(file,&buf)!=0) return 1; style=*(int *)(argv[2]); rval->str=ntime((time_t *)&(buf.st_mtime),style); return 0; } static int mergedate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *file; GStatBuf buf; int style; g_free(rval->str); rval->str=NULL; _getobj(obj,"file",inst,&file); if (file==NULL) return 0; if (nstat(file,&buf)!=0) return 1; style=*(int *)(argv[2]); rval->str=ndate((time_t *)&(buf.st_mtime),style); return 0; } static int mergestore(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mergelocal *mergelocal; char *file,*base,*date,*time; int style; char *buf; char *argv2[2]; g_free(rval->str); rval->str=NULL; _getobj(obj,"_local",inst,&mergelocal); if (mergelocal->endstore) { mergelocal->endstore=FALSE; return 1; } else if (mergelocal->storefd==NULL) { _getobj(obj,"file",inst,&file); if (file==NULL) return 1; style=3; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"date",inst,1,argv2)) return 1; style=0; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"time",inst,1,argv2)) return 1; _getobj(obj,"date",inst,&date); if(date == NULL) { date = "1-1-1970"; } _getobj(obj,"time",inst,&time); if(time == NULL) { time = "00:00:00"; } if ((base=getbasename(file))==NULL) return 1; if ((mergelocal->storefd=nfopen(file,"rt"))==NULL) { g_free(base); return 1; } buf = g_strdup_printf("merge::load_data '%s' '%s %s' <<'[EOF]'", base, date, time); g_free(base); if (buf == NULL) { fclose(mergelocal->storefd); mergelocal->storefd=NULL; return 1; } rval->str=buf; return 0; } else { if (fgetline(mergelocal->storefd,&buf)!=0) { fclose(mergelocal->storefd); mergelocal->storefd=NULL; buf = g_strdup("[EOF]\n"); if (buf == NULL) return 1; mergelocal->endstore=TRUE; rval->str=buf; return 0; } else { rval->str=buf; return 0; } } } static int mergeload(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *s; int len; char *file,*fullname,*oldfile,*mes; time_t ftime; int mkdata; char buf[2]; FILE *fp; struct utimbuf tm; s=(char *)argv[2]; if ((file=getitok2(&s,&len," \t"))==NULL) return 1; if ((fullname=getfullpath(file))==NULL) { g_free(file); return 1; } _getobj(obj,"file",inst,&oldfile); g_free(oldfile); _putobj(obj,"file",inst,fullname); if (gettimeval(s,&ftime)) { g_free(file); return 1; } if (naccess(file,R_OK)!=0) mkdata=TRUE; else { if ((mes=g_malloc(strlen(file)+256))==NULL) { g_free(file); return 1; } sprintf(mes,"`%s' Overwrite existing file?",file); mkdata=inputyn(mes); g_free(mes); } if (mkdata) { if ((fp=nfopen(file,"wt"))==NULL) { error2(obj,ERROPEN,file); g_free(file); return 1; } while (nread(stdinfd(),buf,1)==1) fputc(buf[0],fp); fclose(fp); tm.actime=ftime; tm.modtime=ftime; utime(file,&tm); } g_free(file); return 0; } static int mergestoredum(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct mergelocal *mergelocal; char *file,*base,*date,*time; int style; char *buf; char *argv2[2]; g_free(rval->str); rval->str=NULL; _getobj(obj,"_local",inst,&mergelocal); if (mergelocal->endstore) { mergelocal->endstore=FALSE; return 1; } else { _getobj(obj,"file",inst,&file); if (file==NULL) return 1; style=3; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"date",inst,1,argv2)) return 1; style=0; argv2[0]=(char *)&style; argv2[1]=NULL; if (_exeobj(obj,"time",inst,1,argv2)) return 1; _getobj(obj,"date",inst,&date); if(date == NULL) { date = "1-1-1970"; } _getobj(obj,"time",inst,&time); if(time == NULL) { time = "00:00:00"; } if ((base=getbasename(file))==NULL) return 1; buf = g_strdup_printf("merge::load_dummy '%s' '%s %s'\n", base, date, time); g_free(base); if (buf == NULL) { return 1; } rval->str=buf; mergelocal->endstore=TRUE; return 0; } } static int mergeloaddum(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *s; int len; char *file,*fullname,*oldfile; s=(char *)argv[2]; if ((file=getitok2(&s,&len," \t"))==NULL) return 1; if ((fullname=getfullpath(file))==NULL) { g_free(file); return 1; } _getobj(obj,"file",inst,&oldfile); g_free(oldfile); _putobj(obj,"file",inst,fullname); return 0; } static int mergebbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char *file,*graf; int lm,tm,zmx,zmy; int newgra,rcode; struct objlist *sys; FILE *fd; char *buf; struct GRAbbox bbox; int GC; struct mergelocal *mergelocal; array=rval->array; if (arraynum(array)!=0) return 0; _getobj(obj,"file",inst,&file); _getobj(obj,"left_margin",inst,&lm); _getobj(obj,"top_margin",inst,&tm); _getobj(obj,"zoom_x",inst,&zmx); _getobj(obj,"zoom_y",inst,&zmy); if (file==NULL) return 1; if ((sys=getobject("system"))==NULL) return 1; if (getobj(sys,"GRAF",0,0,NULL,&graf)) return 1; if ((fd=nfopen(file,"rt"))==NULL) return 1; if ((rcode=fgetline(fd,&buf))!=0) { fclose(fd); return 1; } if (strcmp(graf,buf)==0) newgra=TRUE; else if (strcmp(OLD_GRA_HEADER,buf)==0) newgra=FALSE; else { g_free(buf); fclose(fd); return 1; } g_free(buf); if (!newgra) { if ((rcode=fgetline(fd,&buf))!=0) { fclose(fd); return 1; } g_free(buf); } GRAinitbbox(&bbox); if ((GC=_GRAopencallback(GRAboundingbox,NULL,&bbox))==-1) { GRAendbbox(&bbox); fclose(fd); return 1; } GRAinit(GC,0,0,21000,29300,10000); while ((rcode=fgetline(fd,&buf))!=1) { if (rcode==-1) { fclose(fd); return 1; } if (newgra) rcode=GRAinput(GC,buf,0,0,10000,10000); else rcode=GRAinputold(GC,buf,0,0,10000,10000); if (!rcode) { g_free(buf); fclose(fd); return 1; } g_free(buf); } fclose(fd); _GRAclose(GC); GRAendbbox(&bbox); if ((array==NULL) && ((array=arraynew(sizeof(int)))==NULL)) return 1; arrayins(array,&bbox.maxy,0); arrayins(array,&bbox.maxx,0); arrayins(array,&bbox.miny,0); arrayins(array,&bbox.minx,0); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } _getobj(obj,"_local",inst,&mergelocal); mergelocal->bbox[0] = bbox.minx; mergelocal->bbox[1] = bbox.miny; mergelocal->bbox[2] = bbox.maxx; mergelocal->bbox[3] = bbox.maxy; set_bbox(obj, inst, array, lm, tm, zmx, zmy); rval->array=array; return 0; } static int mergemove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int lm, tm, zmx, zmy, x, y; struct narray *array; _getobj(obj,"left_margin",inst,&lm); _getobj(obj,"top_margin",inst,&tm); x = *(int *)argv[2]; y = *(int *)argv[3]; lm += x; tm += y; if (_putobj(obj,"left_margin",inst,&lm)) return 1; if (_putobj(obj,"top_margin",inst,&tm)) return 1; #if 0 if (clear_bbox(obj, inst)) return 1; #else _getobj(obj, "bbox", inst, &array); if (arraynum(array) == 4) { _getobj(obj, "zoom_x", inst, &zmx); _getobj(obj, "zoom_y", inst, &zmy); set_bbox(obj, inst, array, lm, tm, zmx, zmy); } #endif return 0; } #define ZOOM_MAX 1000000 static int mergezoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int lm,tm,zmx,zmy; double zoom_x, zoom_y; int refx,refy; struct narray *array; zoom_x=(*(int *)argv[2])/10000.0; zoom_y=(*(int *)argv[3])/10000.0; refx=(*(int *)argv[4]); refy=(*(int *)argv[5]); _getobj(obj,"left_margin",inst,&lm); _getobj(obj,"top_margin",inst,&tm); _getobj(obj,"zoom_x",inst,&zmx); _getobj(obj,"zoom_y",inst,&zmy); lm=(lm-refx)*zoom_x+refx; tm=(tm-refy)*zoom_y+refy; if (zmx * zoom_x > ZOOM_MAX) { return 0; } if (zmy * zoom_y > ZOOM_MAX) { return 0; } zmx*=zoom_x; zmy*=zoom_y; if (_putobj(obj,"left_margin",inst,&lm)) return 1; if (_putobj(obj,"top_margin",inst,&tm)) return 1; if (_putobj(obj,"zoom_x",inst,&zmx)) return 1; if (_putobj(obj,"zoom_y",inst,&zmy)) return 1; #if 0 if (clear_bbox(obj, inst)) return 1; #else _getobj(obj, "bbox", inst, &array); if (arraynum(array) == 4) { set_bbox(obj, inst, array, lm, tm, zmx, zmy); } #endif return 0; } static int mergematch(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy,err; int bminx,bminy,bmaxx,bmaxy; struct narray *array; rval->i=FALSE; if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); if (array==NULL) return 0; minx=*(int *)argv[2]; miny=*(int *)argv[3]; maxx=*(int *)argv[4]; maxy=*(int *)argv[5]; err=*(int *)argv[6]; if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx==maxx) && (miny==maxy)) { bminx-=err; bminy-=err; bmaxx+=err; bmaxy+=err; if ((bminx<=minx) && (minx<=bmaxx) && (bminy<=miny) && (miny<=bmaxy)) rval->i=TRUE; } else { if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } static int mergegeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; int zoom, val; struct narray *array; field=(char *)(argv[1]); if (field[0] == 'z') { zoom = * (int *) (argv[2]); if (zoom > ZOOM_MAX) { zoom = ZOOM_MAX; } else if (zoom < 1) { zoom = 1; } if (strcmp(field, "zoom") == 0) { _putobj(obj, "zoom_x", inst, &zoom); _putobj(obj, "zoom_y", inst, &zoom); } else { * (int *) (argv[2]) = zoom; } } #if 0 if (clear_bbox(obj, inst)){ return 1; } #else val = * (int *) (argv[2]); _getobj(obj, "bbox", inst, &array); if (arraynum(array) == 4) { int t, l, zx, zy; _getobj(obj, "top_margin", inst, &t); _getobj(obj, "left_margin", inst, &l); _getobj(obj, "zoom_x", inst, &zx); _getobj(obj, "zoom_y", inst, &zy); switch (field[0]) { case 't': t = val; break; case 'l': l = val; break; case 'z': if (strcmp(field, "zoom") == 0) { zx = zoom; zy = zoom; } else if (strcmp(field, "zoom_x") == 0) { zx = zoom; } else { zy = zoom; } break; } set_bbox(obj, inst, array, l, t, zx, zy); } #endif return 0; } static int merge_inst_dup(struct objlist *obj, N_VALUE *src, N_VALUE *dest) { int i; i = obj_get_field_pos(obj, "_local"); if (i < 0) { return 1; } dest[i].ptr = g_memdup(src[i].ptr, sizeof(struct mergelocal)); /* mergelocal->storefd may be NULL */ if (dest[i].ptr == NULL) { return 1; } return 0; } static int merge_inst_free(struct objlist *obj, N_VALUE *inst) { int i; i = obj_get_field_pos(obj, "_local"); if (i == -1) { return 1; } g_free(inst[i].ptr); /* mergelocal->storefd may be NULL */ return 0; } static struct objtable merge[] = { {"init",NVFUNC,NEXEC,mergeinit,NULL,0}, {"done",NVFUNC,NEXEC,mergedone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"file",NSTR,NREAD|NWRITE,mergefile,NULL,0}, {"save_path",NENUM,NREAD|NWRITE,NULL,pathchar,0}, {"top_margin",NINT,NREAD|NWRITE,mergegeometry,NULL,0}, {"left_margin",NINT,NREAD|NWRITE,mergegeometry,NULL,0}, {"zoom_x",NINT,NREAD|NWRITE,mergegeometry,NULL,0}, {"zoom_y",NINT,NREAD|NWRITE,mergegeometry,NULL,0}, {"zoom",NINT,NWRITE,mergegeometry,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,mergedraw,"i",0}, {"redraw",NVFUNC,NREAD|NEXEC,mergeredraw,"i",0}, {"save",NSFUNC,NREAD|NEXEC,pathsave,"sa",0}, {"store_data",NSFUNC,NREAD|NEXEC,mergestore,"",0}, {"load_data",NVFUNC,NREAD|NEXEC,mergeload,"s",0}, {"store_dummy",NSFUNC,NREAD|NEXEC,mergestoredum,"",0}, {"load_dummy",NVFUNC,NREAD|NEXEC,mergeloaddum,"s",0}, {"time",NSFUNC,NREAD|NEXEC,mergetime,"i",0}, {"date",NSFUNC,NREAD|NEXEC,mergedate,"i",0}, {"line_num",NINT,NREAD,NULL,NULL,0}, {"bbox",NIAFUNC,NREAD|NEXEC,mergebbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,mergemove,"ii",0}, {"zooming",NVFUNC,NREAD|NEXEC,mergezoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,mergematch,"iiiii",0}, {"ext",NSTR,NREAD,NULL,NULL,0}, {"_local",NPOINTER,0,NULL,NULL,0}, {"symbol_greek",NBOOL,NWRITE,NULL,NULL,0}, }; #define TBLNUM (sizeof(merge) / sizeof(*merge)) void * addmerge(void) /* addmerge() returns NULL on error */ { struct objlist *merge_obj; merge_obj = addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,merge,ERRNUM,mergeerrorlist,NULL,NULL); obj_set_undo_func(merge_obj, merge_inst_dup, merge_inst_free); return merge_obj; } ngraph-gtk-6.08.00/src/mathcode.h0000644000175000017500000000037013070106167013375 00000000000000extern char *matherrorchar[]; /* #define MNOERR 0 */ /* #define MERR 1 */ /* #define MNAN 2 */ /* #define MUNDEF 3 */ /* #define MSERR 4 */ /* #define MSCONT 5 */ /* #define MSBREAK 6 */ /* #define MNONUM 7 */ /* #define MEOF 8 */ ngraph-gtk-6.08.00/src/gettext.h0000644000175000017500000002311713070106167013301 00000000000000/* Convenience header for conditional use of GNU . Copyright (C) 1995-1998, 2000-2002, 2004-2006, 2009 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 3, 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 Library 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef _LIBGETTEXT_H #define _LIBGETTEXT_H 1 /* NLS can be disabled through the configure --disable-nls option. */ #if ENABLE_NLS /* Get declarations of GNU message catalog functions. */ # include /* You can set the DEFAULT_TEXT_DOMAIN macro to specify the domain used by the gettext() and ngettext() macros. This is an alternative to calling textdomain(), and is useful for libraries. */ # ifdef DEFAULT_TEXT_DOMAIN # undef gettext # define gettext(Msgid) \ dgettext (DEFAULT_TEXT_DOMAIN, Msgid) # undef ngettext # define ngettext(Msgid1, Msgid2, N) \ dngettext (DEFAULT_TEXT_DOMAIN, Msgid1, Msgid2, N) # endif #else /* Solaris /usr/include/locale.h includes /usr/include/libintl.h, which chokes if dcgettext is defined as a macro. So include it now, to make later inclusions of a NOP. We don't include as well because people using "gettext.h" will not include , and also including would fail on SunOS 4, whereas is OK. */ #if defined(__sun) # include #endif /* Many header files from the libstdc++ coming with g++ 3.3 or newer include , which chokes if dcgettext is defined as a macro. So include it now, to make later inclusions of a NOP. */ #if defined(__cplusplus) && defined(__GNUG__) && (__GNUC__ >= 3) # include # if (__GLIBC__ >= 2) || _GLIBCXX_HAVE_LIBINTL_H # include # endif #endif /* Disabled NLS. The casts to 'const char *' serve the purpose of producing warnings for invalid uses of the value returned from these functions. On pre-ANSI systems without 'const', the config.h file is supposed to contain "#define const". */ # undef gettext # define gettext(Msgid) ((const char *) (Msgid)) # undef dgettext # define dgettext(Domainname, Msgid) ((void) (Domainname), gettext (Msgid)) # undef dcgettext # define dcgettext(Domainname, Msgid, Category) \ ((void) (Category), dgettext (Domainname, Msgid)) # undef ngettext # define ngettext(Msgid1, Msgid2, N) \ ((N) == 1 \ ? ((void) (Msgid2), (const char *) (Msgid1)) \ : ((void) (Msgid1), (const char *) (Msgid2))) # undef dngettext # define dngettext(Domainname, Msgid1, Msgid2, N) \ ((void) (Domainname), ngettext (Msgid1, Msgid2, N)) # undef dcngettext # define dcngettext(Domainname, Msgid1, Msgid2, N, Category) \ ((void) (Category), dngettext(Domainname, Msgid1, Msgid2, N)) # undef textdomain # define textdomain(Domainname) ((const char *) (Domainname)) # undef bindtextdomain # define bindtextdomain(Domainname, Dirname) \ ((void) (Domainname), (const char *) (Dirname)) # undef bind_textdomain_codeset # define bind_textdomain_codeset(Domainname, Codeset) \ ((void) (Domainname), (const char *) (Codeset)) #endif /* A pseudo function call that serves as a marker for the automated extraction of messages, but does not call gettext(). The run-time translation is done at a different place in the code. The argument, String, should be a literal string. Concatenated strings and other string expressions won't work. The macro's expansion is not parenthesized, so that it is suitable as initializer for static 'char[]' or 'const char[]' variables. */ #define gettext_noop(String) String /* The separator between msgctxt and msgid in a .mo file. */ #define GETTEXT_CONTEXT_GLUE "\004" /* Pseudo function calls, taking a MSGCTXT and a MSGID instead of just a MSGID. MSGCTXT and MSGID must be string literals. MSGCTXT should be short and rarely need to change. The letter 'p' stands for 'particular' or 'special'. */ #ifdef DEFAULT_TEXT_DOMAIN # define pgettext(Msgctxt, Msgid) \ pgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) #else # define pgettext(Msgctxt, Msgid) \ pgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) #endif #define dpgettext(Domainname, Msgctxt, Msgid) \ pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) #define dcpgettext(Domainname, Msgctxt, Msgid, Category) \ pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, Category) #ifdef DEFAULT_TEXT_DOMAIN # define npgettext(Msgctxt, Msgid, MsgidPlural, N) \ npgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) #else # define npgettext(Msgctxt, Msgid, MsgidPlural, N) \ npgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) #endif #define dnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N) \ npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) #define dcnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N, Category) \ npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, Category) #ifdef __GNUC__ __inline #else #ifdef __cplusplus inline #endif #endif static const char * pgettext_aux (const char *domain, const char *msg_ctxt_id, const char *msgid, int category) { const char *translation = dcgettext (domain, msg_ctxt_id, category); if (translation == msg_ctxt_id) return msgid; else return translation; } #ifdef __GNUC__ __inline #else #ifdef __cplusplus inline #endif #endif static const char * npgettext_aux (const char *domain, const char *msg_ctxt_id, const char *msgid, const char *msgid_plural, unsigned long int n, int category) { const char *translation = dcngettext (domain, msg_ctxt_id, msgid_plural, n, category); if (translation == msg_ctxt_id || translation == msgid_plural) return (n == 1 ? msgid : msgid_plural); else return translation; } /* The same thing extended for non-constant arguments. Here MSGCTXT and MSGID can be arbitrary expressions. But for string literals these macros are less efficient than those above. */ #include #define _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS \ (((__GNUC__ >= 3 || __GNUG__ >= 2) && !__STRICT_ANSI__) \ /* || __STDC_VERSION__ >= 199901L */ ) #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS #include #endif #define pgettext_expr(Msgctxt, Msgid) \ dcpgettext_expr (NULL, Msgctxt, Msgid, LC_MESSAGES) #define dpgettext_expr(Domainname, Msgctxt, Msgid) \ dcpgettext_expr (Domainname, Msgctxt, Msgid, LC_MESSAGES) #ifdef __GNUC__ __inline #else #ifdef __cplusplus inline #endif #endif static const char * dcpgettext_expr (const char *domain, const char *msgctxt, const char *msgid, int category) { size_t msgctxt_len = strlen (msgctxt) + 1; size_t msgid_len = strlen (msgid) + 1; const char *translation; #if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS char msg_ctxt_id[msgctxt_len + msgid_len]; #else char buf[1024]; char *msg_ctxt_id = (msgctxt_len + msgid_len <= sizeof (buf) ? buf : (char *) malloc (msgctxt_len + msgid_len)); if (msg_ctxt_id != NULL) #endif { memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1); msg_ctxt_id[msgctxt_len - 1] = '\004'; memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len); translation = dcgettext (domain, msg_ctxt_id, category); #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS if (msg_ctxt_id != buf) free (msg_ctxt_id); #endif if (translation != msg_ctxt_id) return translation; } return msgid; } #define npgettext_expr(Msgctxt, Msgid, MsgidPlural, N) \ dcnpgettext_expr (NULL, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES) #define dnpgettext_expr(Domainname, Msgctxt, Msgid, MsgidPlural, N) \ dcnpgettext_expr (Domainname, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES) #ifdef __GNUC__ __inline #else #ifdef __cplusplus inline #endif #endif static const char * dcnpgettext_expr (const char *domain, const char *msgctxt, const char *msgid, const char *msgid_plural, unsigned long int n, int category) { size_t msgctxt_len = strlen (msgctxt) + 1; size_t msgid_len = strlen (msgid) + 1; const char *translation; #if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS char msg_ctxt_id[msgctxt_len + msgid_len]; #else char buf[1024]; char *msg_ctxt_id = (msgctxt_len + msgid_len <= sizeof (buf) ? buf : (char *) malloc (msgctxt_len + msgid_len)); if (msg_ctxt_id != NULL) #endif { memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1); msg_ctxt_id[msgctxt_len - 1] = '\004'; memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len); translation = dcngettext (domain, msg_ctxt_id, msgid_plural, n, category); #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS if (msg_ctxt_id != buf) free (msg_ctxt_id); #endif if (!(translation == msg_ctxt_id || translation == msgid_plural)) return translation; } return (n == 1 ? msgid : msgid_plural); } #endif /* _LIBGETTEXT_H */ ngraph-gtk-6.08.00/src/mathfn.c0000644000175000017500000001101513356255253013067 00000000000000/* * $Id: mathfn.c,v 1.9 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include "mathfn.h" double distance(double x1, double y1) { return sqrt(x1 * x1 + y1 * y1); } int compare_double(double x, double y) { if (x) { return fabs(x - y) <= fabs(DBL_EPSILON * x); } else { return fabs(x - y) <= fabs(DBL_EPSILON * y); } } double cutdown(double x) { if (x>=0) return (int )x; else if ((x-(int )x)==0.0) return (int )x; else return (int )(x-1); } double nraise(double x) { if (x<0) return (int ) (x - N_EPSILON); else if ((x-(int )x)==0.0) return (int )x; else return (int )(x+1); } int nround(double x) { int ix; double dx; if (x>G_MAXINT) return G_MAXINT; else if (x=0.5) return ix+1; else if (dx<=-0.5) return ix-1; else return ix; } } static int matinv(int dim,matrix m,matrix mi) { int i,j,k; double max; int pivot; vector vec; for (i=0;imax) { pivot=j; max=fabs(m[j][i]); } } if (max<=1E-300) return -1; for (k=0;k=0;j--) mi[i][j]=mi[i][j]/m[i][i]; for (j=dim-1;j>=i;j--) m[i][j]=m[i][j]/m[i][i]; for (j=0;j=0;k--) mi[j][k]=mi[j][k]-m[j][i]*mi[i][k]; for (j=0;j=0;k--) m[j][k]=m[j][k]-m[j][i]*m[i][k]; } return 0; } int matsolv(int dim,matrix a,vector b,vector x) { matrix ai; int i,j; double d; if (matinv(dim,a,ai)) return -1; for (i=0;i= h) { th = tan(2 * MPI * h); *R = b * 255; *B = b * s * 255; *G = b * (2 * th - s * (th - s3)) / (th + s3) * 255; } else if (2.0 / 6.0 >= h) { th = tan(2 * MPI * (h - 1.0 / 3.0)); *G = b * 255; *B = b * s * 255; *R = b * (2 * th - s * (th + s3)) / (th - s3) * 255; } else if (3.0 / 6.0 >= h) { th = tan(2 * MPI * (h - 1.0 / 3.0)); *G = b * 255; *R = b * s * 255; *B = b * (2 * th - s * (th - s3)) / (th + s3) * 255; } else if (4.0 / 6.0 >= h) { th = tan(2 * MPI * (h - 2.0 / 3.0)); *B = b * 255; *R = b * s * 255; *G = b * (2 * th - s * (th + s3)) / (th - s3) * 255; } else if (5.0 / 6.0 >= h) { th = tan(2 * MPI * (h - 2.0 / 3.0)); *B = b * 255; *G = b * s * 255; *R = b * (2 * th - s * (th - s3)) / (th + s3) * 255; } else { th = tan(2 * MPI * h); *R = b * 255; *G = b * s * 255; *B = b * (2 * th - s * (th + s3)) / (th - s3) * 255; } } int bsearch_int(int *ary, int n, int val, int *idx) { int min, max, i; if (n == 0 || ary == NULL) { if (idx) { *idx = 0; } return FALSE; } min = 0; max = n - 1; while (1) { i = (min + max) / 2; if (ary[i] == val) { if (idx) { *idx = i; } return TRUE; } if (min >= max) { if (idx) { if (ary[i] < val) { i++; } *idx = i; } return FALSE; } if (ary[i] < val) { min = i + 1; } else { max = i - 1; } } return FALSE; } ngraph-gtk-6.08.00/src/ngraph.h0000644000175000017500000000731013070106167013071 00000000000000#ifndef NGRAPH_HEADER #define NGRAPH_HEADER enum ngraph_object_field_type { NVOID = 0, NBOOL = 1, #if USE_NCHAR NCHAR = 2, #endif NINT = 3, NDOUBLE = 4, NSTR = 5, NPOINTER = 6, NIARRAY = 7, NDARRAY = 8, NSARRAY = 9, NENUM = 10, NOBJ = 11, #if USE_LABEL NLABEL = 12, #endif NVFUNC = 20, NBFUNC = 21, #if USE_NCHAR NCFUNC = 22, #endif NIFUNC = 23, NDFUNC = 24, NSFUNC = 25, NIAFUNC = 26, NDAFUNC = 27, NSAFUNC = 28, }; #define NREAD 1 #define NWRITE 2 #define NEXEC 4 struct ngraph_plugin; struct objlist; union _ngraph_value; struct ngraph_obj { struct objlist *obj; int id; }; struct ngraph_array; typedef struct ngraph_array ngraph_arg; typedef union _ngraph_value { int i; double d; const char *str; struct ngraph_array *ary; } ngraph_value; struct ngraph_array { int num; union _ngraph_value ary[1]; }; typedef union _ngraph_returned_value { int i; double d; const char *str; struct { int num; union { const int *ia; const double *da; const char * const *sa; } data; } ary; } ngraph_returned_value; typedef int (* ngraph_plugin_exec) (int argc, char *argv[]); typedef int (* ngraph_plugin_open) (void); typedef int (* ngraph_plugin_close) (void); int ngraph_initialize(int *argc, char ***argv); void ngraph_save_shell_history(void); void ngraph_finalize(void); char *ngraph_get_init_file(const char *init_file); int ngraph_exec_loginshell(char *loginshell, struct objlist *obj, int id); int ngraph_object_put(struct objlist *obj, const char *vname, int id, ngraph_value *val); int ngraph_object_get(struct objlist *obj, const char *vname, int id, ngraph_arg *arg, ngraph_returned_value *val); int ngraph_object_exe(struct objlist *obj, const char *vname, int id, ngraph_arg *arg); int ngraph_object_get_id_by_oid(struct objlist *obj, int oid); int ngraph_object_move_top(struct objlist *obj, int id); int ngraph_object_move_last(struct objlist *obj, int id); int ngraph_object_move_up(struct objlist *obj, int id); int ngraph_object_move_down(struct objlist *obj, int id); int ngraph_object_exchange(struct objlist *obj, int id1, int id2); int ngraph_object_copy(struct objlist *obj, int id_dest, int id_src); int ngraph_object_new(struct objlist *obj); int ngraph_object_del(struct objlist *obj, int id); int ngraph_object_exist(struct objlist *obj, int id); const char *ngraph_get_object_name(struct objlist *obj); const char *ngraph_get_object_alias(struct objlist *obj); const char *ngraph_get_object_field_args(struct objlist *obj, const char *field); const char *ngraph_get_object_field(struct objlist *obj, int i); const char *ngraph_get_object_version(struct objlist *obj); struct objlist *ngraph_get_object(const char *name); struct objlist *ngraph_get_parent_object(struct objlist *obj); struct objlist *ngraph_get_root_object(void); struct objlist *ngraph_get_next_object(struct objlist *obj); struct objlist *ngraph_get_child_object(struct objlist *obj); struct objlist *ngraph_get_object_instances_by_str(const char *str, int *n, int **ids); int ngraph_get_object_id(struct objlist *obj); int ngraph_get_object_size(struct objlist *obj); int ngraph_get_object_current_id(struct objlist *obj); int ngraph_get_object_last_id(struct objlist *obj); int ngraph_get_object_field_num(struct objlist *obj); int ngraph_get_object_field_permission(struct objlist *obj, const char *field); enum ngraph_object_field_type ngraph_get_object_field_type(struct objlist *obj, const char *field); int ngraph_puts(const char *s); int ngraph_err_puts(const char *s); void ngraph_sleep(double t); void *ngraph_malloc(size_t size); void ngraph_free(void *ptr); char *ngraph_strdup(const char *str); int ngraph_set_exec_func(const char *name, ngraph_plugin_exec func); #endif ngraph-gtk-6.08.00/src/main.c0000644000175000017500000000652513070106167012540 00000000000000/* * $Id: main.c,v 1.47 2010-03-04 08:30:17 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include "ngraph.h" #define INIT_SCRIPT "Ngraph.nsc" static void exec_init_script(int argc, char **argv, struct objlist *obj, int id) { char *inifile; ngraph_arg *sarray, sarg; int i, j, n, r; i = 1; if (argc > 1 && strcmp(argv[1], "-i") == 0) { i++; if (argc > 2) { inifile = ngraph_strdup(argv[2]); if (inifile == NULL) { exit(1); } #if WINDOWS for (j = 0; inifile[i] != '\0'; i++) { if (inifile[i] == '\\') { name[i] = '/'; } } #endif /* WINDOWS */ i++; } else { inifile = NULL; } } else { inifile = ngraph_get_init_file(INIT_SCRIPT); } if (inifile) { n = argc - i + 1; sarray = ngraph_malloc(sizeof(*sarray) + sizeof(ngraph_value) * n); if (sarray == NULL) { exit(1); } sarray->num = n; sarray->ary[0].str = inifile; for (j = 1; j < n; j++) { sarray->ary[j].str = argv[j - 1 + i]; } } else { sarray = ngraph_malloc(sizeof(*sarray)); sarray->num = 0; } sarg.num = 1; sarg.ary[0].ary = sarray; r = ngraph_object_exe(obj, "shell", id, &sarg); ngraph_free(sarray); ngraph_free(inifile); if (r) { exit(1); } } static char* get_login_shell(struct objlist *sys) { char *loginshell; ngraph_arg arg; ngraph_returned_value rval; arg.num = 0; arg.ary[0].str = NULL; if (ngraph_object_get(sys, "login_shell", 0, &arg, &rval) < 0) { exit(1); } if (rval.str) { loginshell = ngraph_strdup(rval.str); } else { loginshell = NULL; } return loginshell; } int main(int argc, char **argv) { char *loginshell; struct objlist *sys, *obj; int id; if (ngraph_initialize(&argc, &argv)) { exit(1); } sys = ngraph_get_object("system"); obj = ngraph_get_object("shell"); if (obj == NULL || sys == NULL) { exit(1); } id = ngraph_object_new(obj); if (id < 0) { exit(1); } exec_init_script(argc, argv, obj, id); loginshell = get_login_shell(sys); #if 1 if (loginshell) { ngraph_exec_loginshell(loginshell, obj, id); ngraph_free(loginshell); } #else do { ngraph_value val; val.str = NULL; if (ngraph_object_put(sys, "login_shell", 0, &val) < 0) { exit(1); } ngraph_exec_loginshell(loginshell, obj, id); if (loginshell) { ngraph_free(loginshell); } loginshell = get_login_shell(sys); } while (loginshell); #endif ngraph_finalize(); ngraph_object_del(sys, 0); return 0; } ngraph-gtk-6.08.00/src/oarc.h0000644000175000017500000000022013070106167012527 00000000000000#ifndef OARC_HEADER #define OARC_HEADER enum arc_point_type { ARC_POINT_TYPE_R, ARC_POINT_TYPE_ANGLE1, ARC_POINT_TYPE_ANGLE2, }; #endif ngraph-gtk-6.08.00/src/otext.c0000644000175000017500000003327613356133076012770 00000000000000/* * $Id: otext.c,v 1.19 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include #include #include #include #include #include #include "common.h" #include "object.h" #include "gra.h" #include "oroot.h" #include "odraw.h" #include "otext.h" #include "olegend.h" #include "mathfn.h" #include "nstring.h" #include "nconfig.h" #include "strconv.h" #define NAME "text" #define PARENT "legend" #define OVERSION "1.00.00" #define TEXTCONF "[text]" #define ERR_INVALID_STR 100 static char *texterrorlist[]={ "invalid string.", }; #define ERRNUM (sizeof(texterrorlist) / sizeof(*texterrorlist)) static struct obj_config TextConfig[] = { {"R", OBJ_CONFIG_TYPE_NUMERIC}, {"G", OBJ_CONFIG_TYPE_NUMERIC}, {"B", OBJ_CONFIG_TYPE_NUMERIC}, {"A", OBJ_CONFIG_TYPE_NUMERIC}, {"pt", OBJ_CONFIG_TYPE_NUMERIC}, {"space", OBJ_CONFIG_TYPE_NUMERIC}, {"direction", OBJ_CONFIG_TYPE_NUMERIC}, {"script_size", OBJ_CONFIG_TYPE_NUMERIC}, {"raw", OBJ_CONFIG_TYPE_NUMERIC}, {"font", OBJ_CONFIG_TYPE_STRING}, {"style", OBJ_CONFIG_TYPE_NUMERIC}, }; static NHASH TextConfigHash = NULL; static int textloadconfig(struct objlist *obj,N_VALUE *inst) { return obj_load_config(obj, inst, TEXTCONF, TextConfigHash); } static int textsaveconfig(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { return obj_save_config(obj, inst, TEXTCONF, TextConfig, sizeof(TextConfig) / sizeof(*TextConfig)); } static int textinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int pt,scriptsize; char *font; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; pt=DEFAULT_FONT_PT; scriptsize=7000; if (_putobj(obj,"pt",inst,&pt)) return 1; if (_putobj(obj,"script_size",inst,&scriptsize)) return 1; font = g_strdup(fontchar[0]); if (font == NULL) { return 1; } if (_putobj(obj,"font",inst,font)) { g_free(font); return 1; } textloadconfig(obj,inst); return 0; } static int textdone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; return 0; } static int textgeometry(struct objlist *obj,N_VALUE *inst,N_VALUE *rval, int argc,char **argv) { char *field; field=(char *)(argv[1]); if (strcmp(field,"pt") == 0) { if (*(int *)(argv[2])TEXT_OBJ_SCRIPT_SIZE_MAX) { *(int *)(argv[2])=TEXT_OBJ_SCRIPT_SIZE_MAX; } } else if (strcmp(field,"style") == 0) { * (int *) (argv[2]) &= (GRA_FONT_STYLE_BOLD | GRA_FONT_STYLE_ITALIC); } if (clear_bbox(obj, inst)) return 1; return 0; } static int textdraw(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int GC; int x,y,pt,space,dir,fr,fg,fb,fa,w,h,scriptsize,raw; char *font; char *text; int clip,zoom,style; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"GC",inst,&GC); if (GC<0) return 0; _getobj(obj,"R",inst,&fr); _getobj(obj,"G",inst,&fg); _getobj(obj,"B",inst,&fb); _getobj(obj,"A",inst,&fa); _getobj(obj,"text",inst,&text); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"pt",inst,&pt); _getobj(obj,"space",inst,&space); _getobj(obj,"direction",inst,&dir); _getobj(obj,"script_size",inst,&scriptsize); _getobj(obj,"raw",inst,&raw); _getobj(obj,"font",inst,&font); _getobj(obj,"clip",inst,&clip); _getobj(obj,"style",inst,&style); GRAregion(GC,&w,&h,&zoom); GRAview(GC,0,0,w*10000.0/zoom,h*10000.0/zoom,clip); GRAcolor(GC,fr,fg,fb, fa); GRAmoveto(GC,x,y); if (raw) { GRAdrawtextraw(GC,text,font,style,pt,space,dir); } else { GRAdrawtext(GC,text,font,style,pt,space,dir,scriptsize); } GRAaddlist(GC,obj,inst,(char *)argv[0],(char *)argv[1]); return 0; } static int textprintf(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char **argv2; int argc2; char *format; int po, arg, i, quote, r; GString *ret; char *arg_str; g_free(rval->str); rval->str=NULL; array=(struct narray *)argv[2]; argv2=arraydata(array); argc2=arraynum(array); if (argc2<1) return 0; format=argv2[0]; ret = g_string_sized_new(64); if (ret == NULL) { return 1; } po=0; arg=1; while (format[po]!='\0') { quote=FALSE; for (i=po;(quote || (format[i]!='%')) && (format[i]!='\0');i++) { if (quote) { quote=FALSE; } else if (format[i]=='\\') { quote=TRUE; } } if (i > po) { g_string_append_len(ret, format + po, i - po); } po = i; if (format[po] != '%') { continue; } arg_str = (arg < argc2 && argv2[arg]) ? argv2[arg] : NULL; r = add_printf_formated_str(ret, format + po, arg_str, &i); if (r) { arg++; } po += i + 1; } rval->str = g_string_free(ret, FALSE); return 0; } static int textbbox(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy; struct narray *array; int x,y,pt,space,dir,scriptsize,raw,style; char *font; char *text; int gx0,gy0,gx1,gy1; int i,ggx[4],ggy[4]; double si,co; array=rval->array; if (arraynum(array)!=0) return 0; _getobj(obj,"text",inst,&text); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"pt",inst,&pt); _getobj(obj,"space",inst,&space); _getobj(obj,"direction",inst,&dir); _getobj(obj,"script_size",inst,&scriptsize); _getobj(obj,"raw",inst,&raw); _getobj(obj,"font",inst,&font); _getobj(obj,"style",inst,&style); if (raw) { GRAtextextentraw(text,font,style,pt,space,&gx0,&gy0,&gx1,&gy1); } else { GRAtextextent(text,font,style,pt,space,scriptsize,&gx0,&gy0,&gx1,&gy1,FALSE); } si=-sin(dir/18000.0*MPI); co=cos(dir/18000.0*MPI); ggx[0]=x+gx0*co-gy0*si; ggy[0]=y+gx0*si+gy0*co; ggx[1]=x+gx1*co-gy0*si; ggy[1]=y+gx1*si+gy0*co; ggx[2]=x+gx0*co-gy1*si; ggy[2]=y+gx0*si+gy1*co; ggx[3]=x+gx1*co-gy1*si; ggy[3]=y+gx1*si+gy1*co; minx=ggx[0]; maxx=ggx[0]; miny=ggy[0]; maxy=ggy[0]; for (i=1;i<4;i++) { if (ggx[i]maxx) maxx=ggx[i]; if (ggy[i]maxy) maxy=ggy[i]; } if ((array==NULL) && ((array=arraynew(sizeof(int)))==NULL)) return 1; arrayins(array,&(maxy),0); arrayins(array,&(maxx),0); arrayins(array,&(miny),0); arrayins(array,&(minx),0); if (arraynum(array)==0) { arrayfree(array); rval->array = NULL; return 1; } rval->array=array; return 0; } static int textmove(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); x+=*(int *)argv[2]; y+=*(int *)argv[3]; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int textrotate(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int dir, angle, use_pivot; _getobj(obj, "direction", inst, &dir); angle = *(int *) argv[2]; use_pivot = * (int *) argv[3]; dir += angle; dir %= 36000; if (dir < 0) dir += 36000; if (use_pivot) { int px, py, x, y; px = *(int *) argv[4]; py = *(int *) argv[5]; _getobj(obj, "x", inst, &x); _getobj(obj, "y", inst, &y); rotate(px, py, angle, &x, &y); _putobj(obj, "x", inst, &x); _putobj(obj, "y", inst, &y); } _putobj(obj, "direction", inst, &dir); if (clear_bbox(obj, inst)) return 1; return 0; } static int textzoom(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int x,y,pt,space,refx,refy,dir; double zoom, zoom_x, zoom_y, zoom_p, zoom_n; zoom_x = (*(int *) argv[2]) / 10000.0; zoom_y = (*(int *) argv[3]) / 10000.0; refx = (*(int *)argv[4]); refy = (*(int *)argv[5]); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"pt",inst,&pt); _getobj(obj,"space",inst,&space); _getobj(obj,"direction",inst,&dir); dir = calc_zoom_direction(dir, zoom_x, zoom_y, &zoom_p, &zoom_n); zoom = MIN(zoom_n, zoom_p); x=(x-refx)*zoom_x+refx; y=(y-refy)*zoom_y+refy; pt *= zoom; space *= zoom_p; if (pt < 1) pt = 1; if (_putobj(obj,"x",inst,&x)) return 1; if (_putobj(obj,"y",inst,&y)) return 1; if (_putobj(obj,"pt",inst,&pt)) return 1; if (_putobj(obj,"space",inst,&space)) return 1; if (_putobj(obj,"direction",inst,&dir)) return 1; if (clear_bbox(obj, inst)) return 1; return 0; } static int textmatch(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { int minx,miny,maxx,maxy,err; int bminx,bminy,bmaxx,bmaxy; struct narray *array; int gx0,gy0,gx1,gy1; int px,py,px2,py2; double si,co; int x,y,pt,space,dir,scriptsize,raw, style; char *font; char *text; rval->i=FALSE; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj,"text",inst,&text); _getobj(obj,"x",inst,&x); _getobj(obj,"y",inst,&y); _getobj(obj,"pt",inst,&pt); _getobj(obj,"space",inst,&space); _getobj(obj,"direction",inst,&dir); _getobj(obj,"script_size",inst,&scriptsize); _getobj(obj,"raw",inst,&raw); _getobj(obj,"font",inst,&font); _getobj(obj,"style",inst,&style); minx=*(int *)(argv[2]); miny=*(int *)(argv[3]); maxx=*(int *)(argv[4]); maxy=*(int *)(argv[5]); err=*(int *)(argv[6]); if ((minx==maxx) && (miny==maxy)) { if (raw) { GRAtextextentraw(text,font,style,pt,space,&gx0,&gy0,&gx1,&gy1); } else { GRAtextextent(text,font,style,pt,space,scriptsize,&gx0,&gy0,&gx1,&gy1,FALSE); } si=sin(dir/18000.0*MPI); co=cos(dir/18000.0*MPI); px=minx-x; py=miny-y; px2=px*co-py*si; py2=px*si+py*co; if ((px2 >= gx0 - err) && (px2 <= gx1 + err) && (py2 >= gy0 - err) && (py2 <= gy1 + err)) { rval->i=TRUE; } } else { if (_exeobj(obj,"bbox",inst,0,NULL)) return 1; _getobj(obj,"bbox",inst,&array); if (arraynum(array)<4) return 1; bminx=arraynget_int(array,0); bminy=arraynget_int(array,1); bmaxx=arraynget_int(array,2); bmaxy=arraynget_int(array,3); if ((minx<=bminx) && (bminx<=maxx) && (minx<=bmaxx) && (bmaxx<=maxx) && (miny<=bminy) && (bminy<=maxy) && (miny<=bmaxy) && (bmaxy<=maxy)) rval->i=TRUE; } return 0; } static int text_set_text(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { char *str, *ptr; gsize len; str = argv[2]; if (str == NULL) return 0; if (g_utf8_validate(str, -1, NULL)) return textgeometry(obj, inst, rval, argc, argv); ptr = sjis_to_utf8(str); if (ptr) { g_free(str); argv[2] = ptr; return textgeometry(obj, inst, rval, argc, argv); } ptr = g_locale_to_utf8(str, -1, NULL, &len, NULL); if (ptr) { char *tmp; g_free(str); tmp = g_strdup(ptr); g_free(ptr); if (tmp == NULL) return 1; argv[2] = tmp; return textgeometry(obj, inst, rval, argc, argv); } error(obj, ERR_INVALID_STR); return 1; } static struct objtable text[] = { {"init",NVFUNC,NEXEC,textinit,NULL,0}, {"done",NVFUNC,NEXEC,textdone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"text",NSTR,NREAD|NWRITE,text_set_text,NULL,0}, {"x",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"y",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"pt",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"font",NSTR,NREAD|NWRITE,textgeometry,NULL,0}, {"style",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"space",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"direction",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"script_size",NINT,NREAD|NWRITE,textgeometry,NULL,0}, {"raw",NBOOL,NREAD|NWRITE,textgeometry,NULL,0}, {"draw",NVFUNC,NREAD|NEXEC,textdraw,"i",0}, {"printf",NSFUNC,NREAD|NEXEC,textprintf,"sa",0}, {"bbox",NIAFUNC,NREAD|NEXEC,textbbox,"",0}, {"move",NVFUNC,NREAD|NEXEC,textmove,"ii",0}, {"rotate",NVFUNC,NREAD|NEXEC,textrotate,"iiii",0}, {"zooming",NVFUNC,NREAD|NEXEC,textzoom,"iiiii",0}, {"match",NBFUNC,NREAD|NEXEC,textmatch,"iiiii",0}, {"save_config",NVFUNC,NREAD|NEXEC,textsaveconfig,"",0}, {"hsb", NVFUNC, NREAD|NEXEC, put_hsb,"ddd",0}, /* following fields exist for backward compatibility */ {"jfont",NSTR,NWRITE,textgeometry,NULL,0}, }; #define TBLNUM (sizeof(text) / sizeof(*text)) void * addtext() /* addtext() returns NULL on error */ { unsigned int i; if (TextConfigHash == NULL) { TextConfigHash = nhash_new(); if (TextConfigHash == NULL) return NULL; for (i = 0; i < sizeof(TextConfig) / sizeof(*TextConfig); i++) { if (nhash_set_ptr(TextConfigHash, TextConfig[i].name, (void *) &TextConfig[i])) { nhash_free(TextConfigHash); return NULL; } } } return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,text,ERRNUM,texterrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/osystem.h0000644000175000017500000000037213211506204013307 00000000000000#ifndef OSYSTEM_HEADER #define OSYSTEM_HEADER typedef void (* DRAW_NOTIFY_FUNC)(int); int system_set_exec_func(const char *name, ngraph_plugin_exec func); void system_set_draw_notify_func(DRAW_NOTIFY_FUNC func); void system_draw_notify(void); #endif ngraph-gtk-6.08.00/src/osarray.c0000644000175000017500000002437613070106167013300 00000000000000/* * $Id: osarray.c,v 1.6 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include "object.h" #include "oiarray.h" #define NAME "sarray" #define PARENT "object" #define OVERSION "1.00.00" #define ERRREGEXP 100 #define ERROUTBOUND 101 static char *sarrayerrorlist[]={ "invalid regular expression.", "array index is out of array bounds.", }; #define DEFAULT_DELIMITER "\\s+" struct osarray_local { GRegex *regexp; }; #define ERRNUM (sizeof(sarrayerrorlist) / sizeof(*sarrayerrorlist)) static int sarrayinit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct osarray_local *local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; local = g_malloc0(sizeof(*local)); if (local == NULL) { return 1; } if (_putobj(obj, "_local", inst, local)) { g_free(local); return 1; } local->regexp = g_regex_new(DEFAULT_DELIMITER, 0, 0, NULL); return 0; } static int sarraydone(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct osarray_local *local; if (_exeparent(obj,(char *)argv[1],inst,rval,argc,argv)) return 1; _getobj(obj, "_local", inst, &local); if (local->regexp) { g_regex_unref(local->regexp); } return 0; } static int sarrayget(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; char **po; char *buf; g_free(rval->str); rval->str=NULL; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } po=(char **)arraynget(array,num); if (po==NULL) { error(obj, ERROUTBOUND); return 1; } if ((buf=g_malloc(strlen(*po)+1))==NULL) return 1; strcpy(buf,*po); rval->str=buf; return 0; } static int sarrayput(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; char *val; num=*(int *)argv[2]; val=(char *)argv[3]; _getobj(obj,"@",inst,&array); num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayput2(array,val,num)==NULL) return 1; return 0; } static int sarrayadd(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char *val; val=(char *)argv[2]; array = oarray_get_array(obj, inst, sizeof(char *)); if (array == NULL) { return 1; } if (arrayadd2(array,val)==NULL) return 1; return 0; } static int sarraypop(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char *val; int n; g_free(rval->str); rval->str = NULL; _getobj(obj, "@", inst, &array); if (array == NULL) { return 1; } n = arraynum(array) - 1; if (n < 0) { return 1; } val = arraynget_str(array, n); if (arrayndel(array, n) == NULL) { g_free(val); return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { g_free(val); return 1; } } rval->str = val; return 0; } static int sarrayins(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; char *val; num=*(int *)argv[2]; val=(char *)argv[3]; array = oarray_get_array(obj, inst, sizeof(char *)); if (array == NULL) { return 1; } num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayins2(array,val,num)==NULL) return 1; return 0; } static int sarrayunshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char *val; val = (char *) argv[2]; array = oarray_get_array(obj, inst, sizeof(char *)); if (array == NULL) { return 1; } if (arrayins2(array, val, 0)==NULL) { return 1; } return 0; } static int sarrayshift(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; char *val; g_free(rval->str); rval->str = NULL; _getobj(obj, "@", inst, &array); if (array == NULL) { return 1; } val = arraynget_str(array, 0); if (arrayndel(array, 0) == NULL) { g_free(val); return 1; } if (arraynum(array) == 0) { arrayfree(array); if (_putobj(obj, "@", inst, NULL)) { g_free(val); return 1; } } rval->str = val; return 0; } static int sarraydel(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc,char **argv) { struct narray *array; int num; num=*(int *)argv[2]; _getobj(obj,"@",inst,&array); if (array==NULL) return 1; num = oarray_get_index(array, num); if (num < 0) { error(obj, ERROUTBOUND); return 1; } if (arrayndel2(array,num)==NULL) { error(obj, ERROUTBOUND); return 1; } if (arraynum(array)==0) { arrayfree2(array); if (_putobj(obj,"@",inst,NULL)) return 1; } return 0; } static int set_delimiter(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct osarray_local *local; GRegex *regexp; char *str; str = (char *) argv[2]; if (str == NULL || str[0] == '\0') { str = DEFAULT_DELIMITER; } regexp = g_regex_new(str, 0, 0, NULL); if (regexp == NULL) { error(obj, ERRREGEXP); return 1; } _getobj(obj, "_local", inst, &local); if (local->regexp) { g_regex_unref(local->regexp); } local->regexp = regexp; return 0; } static int sarraysplit(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct osarray_local *local; struct narray *array, *array2; int i; char *str, *delimiter, **sary; str = (char *) argv[2]; if (str == NULL) { return 0; } _getobj(obj, "_local", inst, &local); _getobj(obj, "delimiter", inst, &delimiter); if (delimiter == NULL) { delimiter = " "; } sary = g_regex_split(local->regexp, str, 0); if (sary == NULL) { return 1; } array = arraynew(sizeof(char *)); if (array == NULL) { g_strfreev(sary); return 1; } for (i = 0; sary[i]; i++) { if (arrayadd(array, sary + i) == NULL) { arrayfree(array); g_strfreev(sary); return 1; } } g_free(sary); /* don't free each element i.e. don't use g_strfreev() */ _getobj(obj, "@", inst, &array2); if (array2) { arrayfree2(array2); } if (_putobj(obj, "@", inst, array) == -1) { arrayfree2(array); return 1; } return 0; } static int sarrayjoin(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; GString *str; int i, n; char *sep, *val, *ptr; g_free(rval->str); rval->str = NULL; _getobj(obj, "@", inst, &array); n = arraynum(array); if (n == 0) { return 0; } ptr = (char *) argv[2]; if (ptr) { sep = g_strcompress(ptr); } else { sep = g_strdup(","); } if (sep == NULL) { return 1; } str = g_string_sized_new(64); if (str == NULL) { g_free(sep); return 1; } for (i = 0; i < n; i++) { val = arraynget_str(array, i); g_string_append_printf(str, "%s%s", val, (i == n - 1) ? "" : sep); } rval->str = g_string_free(str, FALSE); g_free(sep); return 0; } static int sarraysort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arraysort_str(array); return 0; } static int sarrayrsort(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arrayrsort_str(array); return 0; } static int sarrayuniq(struct objlist *obj,N_VALUE *inst,N_VALUE *rval,int argc, char **argv) { struct narray *array; _getobj(obj, "@", inst, &array); arrayuniq_str(array); return 0; } static int sarray_slice(struct objlist *obj, N_VALUE *inst, N_VALUE *rval, int argc, char **argv) { struct narray *array; int start, len; start = * (int *) argv[2]; len = * (int *) argv[3]; if (_getobj(obj, "@", inst, &array)) { return 1; } if (array_slice2(array, start, len) == NULL) { return 1; } return 0; } static struct objtable osarray[] = { {"init",NVFUNC,NEXEC,sarrayinit,NULL,0}, {"done",NVFUNC,NEXEC,sarraydone,NULL,0}, {"next",NPOINTER,0,NULL,NULL,0}, {"@",NSARRAY,NREAD|NWRITE,NULL,NULL,0}, {"delimiter",NSTR,NREAD|NWRITE,set_delimiter,NULL,0}, {"get",NSFUNC,NREAD|NEXEC,sarrayget,"i",0}, {"put",NVFUNC,NREAD|NEXEC,sarrayput,"is",0}, {"add",NVFUNC,NREAD|NEXEC,sarrayadd,"s",0}, {"push",NVFUNC,NREAD|NEXEC,sarrayadd,"s",0}, {"pop",NSFUNC,NREAD|NEXEC,sarraypop,"",0}, {"ins",NVFUNC,NREAD|NEXEC,sarrayins,"is",0}, {"unshift",NVFUNC,NREAD|NEXEC,sarrayunshift,"s",0}, {"shift",NSFUNC,NREAD|NEXEC,sarrayshift,"",0}, {"del",NVFUNC,NREAD|NEXEC,sarraydel,"i",0}, {"split",NVFUNC,NREAD|NEXEC,sarraysplit,"s",0}, {"join",NSFUNC,NREAD|NEXEC,sarrayjoin,"s",0}, {"sort",NVFUNC,NREAD|NEXEC,sarraysort,"s",0}, {"rsort",NVFUNC,NREAD|NEXEC,sarrayrsort,"s",0}, {"uniq", NSFUNC, NREAD|NEXEC, sarrayuniq, "", 0}, {"num", NIFUNC, NREAD|NEXEC, oarray_num, "", 0}, {"seq", NSFUNC, NREAD|NEXEC, oarray_seq, "", 0}, {"rseq", NSFUNC, NREAD|NEXEC, oarray_reverse_seq, "", 0}, {"reverse", NVFUNC, NREAD|NEXEC, oarray_reverse, "", 0}, {"slice", NVFUNC, NREAD|NEXEC, sarray_slice, "ii", 0}, {"_local",NPOINTER,0,NULL,NULL,0}, }; #define TBLNUM (sizeof(osarray) / sizeof(*osarray)) void * addsarray(void) { return addobject(NAME,NULL,PARENT,OVERSION,TBLNUM,osarray,ERRNUM,sarrayerrorlist,NULL,NULL); } ngraph-gtk-6.08.00/src/mathfn.h0000644000175000017500000000262313356255311013074 00000000000000/* * $Id: mathfn.h,v 1.6 2009-12-04 16:11:20 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #define MPI 3.1415926535897932385 #define MEXP1 2.71828182845905 #define MEULER 0.57721566490153286 #define N_EPSILON 1E-12 typedef double vector[11]; typedef vector matrix[11]; double cutdown(double x); double nraise(double x); double frand(double a); int nround(double x); int matsolv(int dim,matrix a,vector b,vector x); void HSB2RGB(double h,double s,double b,int *R,int *G,int *B); int bsearch_int(int *ary, int n, int val, int *idx); int compare_double(double x, double y); double distance(double x1, double y1); ngraph-gtk-6.08.00/src/Makefile.am0000644000175000017500000000417513241745046013510 00000000000000SUBDIRS = math gtk EXTRA_DIST = ngraph_export.map ngraph_resource.rc.in libngraph_resource.rc.in ngraph.ico libngraph_ldflags = -version-info $(LIBNGRAPH_VERSION) $(READLINE_LIBS) $(GTK_LIBS) $(GLIB_LIBS) $(GSL_LIBS) ngraph_ldflags = -lngraph ngraph_lib = libngraph.la if OS_WIN32 libngraph_ldflags += -no-undefined -export-symbols ngraph.def -Wl,libngraph_resource.o ngraph_ldflags += -Wl,ngraph_resource.o BUILT_SOURCES = ngraph.def libngraph_resource.o ngraph_resource.o CLEANFILES = $(BUILT_SOURCES) libngraph_resource.rc ngraph_resource.rc ngraph_resource.rc: ngraph_resource.rc.in $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ libngraph_resource.rc: libngraph_resource.rc.in $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ .rc.o: $(WINDRES) -I $(top_srcdir)/src -o $@ $< ngraph.def: ngraph_api.c echo "EXPORTS" > $@ cat $^ | grep '^ngraph_' | sed 's/[^a-z0-9_].*//' >> $@ else libngraph_ldflags += @vsymldflags@ pkglibexec_PROGRAMS = terminal terminal_SOURCES = terminal.c terminal_CFLAGS = $(GTK_CFLAGS) endif lib_LTLIBRARIES = $(ngraph_lib) libngraph_la_SOURCES = axis.c axis.h nconfig.c nconfig.h gra.c gra.h \ ioutil.c ioutil.h mathcode.c mathcode.h mathfn.c mathfn.h \ nstring.c nstring.h ntime.c ntime.h oagrid.c oarc.c oarc.h \ oaxis.c object.c object.h odarray.c odouble.c odraw.c odraw.h \ odata.c odata.h ofit.c ofit.h ogra.c ogra.h ogra2.c \ ogra2fil.c ogra2nul.c ogra2prn.c oiarray.c oiarray.h oint.c \ olegend.c olegend.h omark.c omath.c omerge.c omerge.h oprm.c \ orect.c oroot.c oroot.h osarray.c oshell.c oregexp.c \ ostring.c osystem.c osystem.h otext.c otext.h opath.c opath.h \ shell.c shell.h shellcm.c shellcm.h shellux.c shellux.h \ spline.c spline.h common.h nhash.h nhash.c strconv.c \ strconv.h oio.c gettext.h ngraph_api.c libngraph_la_CFLAGS = $(GTK_CFLAGS) $(GSL_CFLAGS) -I$(top_builddir) -DCCNAME='"'$(CC)'"' libngraph_la_LIBADD = gtk/libngraphui.la math/libmath.la libngraph_la_LDFLAGS = $(libngraph_ldflags) bin_PROGRAMS = ngraph ngraph_SOURCES = main.c ngraph_DEPENDENCIES = $(ngraph_lib) ngraph_LDFLAGS = $(ngraph_ldflags) include_HEADERS = ngraph.h ngraph-gtk-6.08.00/src/terminal.c0000644000175000017500000000326213070106167013422 00000000000000#include "common.h" #include #include #ifdef HAVE_SYS_WAIT_H #include #endif #include #include #include #include #include #include #ifndef __MINGW32__ static void sig_handler(int sig) { } static void my_signal(int signum, void (* sighandler)) { struct sigaction act; act.sa_handler = sighandler; act.sa_flags = SA_RESTART; sigemptyset(&act.sa_mask); sigaction(signum, &act, NULL); } #endif int main(int argc,char **argv) { #ifndef __MINGW32__ int fdi, fdo, len; char *ptr, buf[256] = {0}; #ifdef HAVE_SIGSUSPEND sigset_t sig_mask; #endif if (argc < 3) { return 1; } if (! isatty(0) || ! isatty(1)) { return 1; } ptr = ttyname(0); if (ptr == NULL) { return 1; } fdo = open(argv[1], O_WRONLY); fdi = open(argv[2], O_RDONLY); while (1) { int n; n = read(fdi,buf,1); if (n != 1) { perror(""); break; } if (buf[0] == '\0') break; putchar(buf[0]); } close(fdi); len = strlen(ptr) + 1; if (write(fdo, ptr, len) < 0) { close(fdo); return 1; } len = snprintf(buf, sizeof(buf) - 1, "%d", getpid()) + 1; if (write(fdo, buf, len) < 0) { close(fdo); return 1; } close(fdo); close(fdi); my_signal(SIGTERM, sig_handler); #ifdef HAVE_SIGSUSPEND sigemptyset(&sig_mask); sigaddset(&sig_mask, SIGINT); #ifdef SIGWINCH sigaddset(&sig_mask, SIGWINCH); #endif sigsuspend(&sig_mask); #else /* HAVE_SIGSUSPEND */ my_signal(SIGINT, SIG_IGN); #ifdef SIGWINCH my_signal(SIGWINCH, SIG_IGN); #endif pause(); #endif /* HAVE_SIGSUSPEND */ #endif /* __MINGW32__ */ return 0; } ngraph-gtk-6.08.00/src/ngraph_api.c0000644000175000017500000002777513070106167013736 00000000000000#include "common.h" #include #include "gtk/init.h" #include "ngraph.h" #include "object.h" #include "mathfn.h" #include "shell.h" #include "osystem.h" union ngraph_val { int i; double d; char *str; struct narray *ary; }; static struct narray * allocate_iarray(ngraph_arg *arg) { struct narray *array, *ptr; int i; if (arg == NULL) { return NULL; } if (arg->num < 1) { return NULL; } array = arraynew(sizeof(int)); if (array == NULL) { return NULL; } for (i = 0; i < arg->num; i++) { ptr = arrayadd(array, &arg->ary[i].i); if (ptr == NULL) { arrayfree(array); return NULL; } } return array; } static struct narray * allocate_darray(ngraph_arg *arg) { struct narray *array, *ptr; int i; if (arg == NULL) { return NULL; } if (arg->num < 1) { return NULL; } array = arraynew(sizeof(double)); if (array == NULL) { return NULL; } for (i = 0; i < arg->num; i++) { ptr = arrayadd(array, &arg->ary[i].d); if (ptr == NULL) { arrayfree(array); return NULL; } } return array; } static struct narray * allocate_sarray(ngraph_arg *arg) { struct narray *array, *ptr; int i; if (arg == NULL) { return NULL; } if (arg->num < 1) { return NULL; } array = arraynew(sizeof(char *)); if (array == NULL) { return NULL; } for (i = 0; i < arg->num; i++) { ptr = arrayadd2(array, arg->ary[i].str); if (ptr == NULL) { arrayfree(array); return NULL; } } return array; } int ngraph_object_put(struct objlist *obj, const char *vname, int id, ngraph_value *val) { enum ngraph_object_field_type type; int r; void *valp; struct narray *array; r = -1; type = chkobjfieldtype(obj, vname); switch (type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: valp = NULL; r = putobj(obj, vname, id, valp); break; case NSTR: case NOBJ: if (val->str) { valp = g_strdup(val->str); } else { valp = NULL; } r = putobj(obj, vname, id, valp); if (r < 0 && valp) { g_free(valp); } break; case NPOINTER: /* these fields may not be writable */ case NBFUNC: case NIFUNC: case NDFUNC: case NSFUNC: case NIAFUNC: case NDAFUNC: case NSAFUNC: valp = NULL; r = putobj(obj, vname, id, valp); break; case NBOOL: case NINT: case NENUM: valp = &val->i; r = putobj(obj, vname, id, valp); break; case NDOUBLE: valp = &val->d; r = putobj(obj, vname, id, valp); break; case NIARRAY: array = allocate_iarray(val->ary); r = putobj(obj, vname, id, array); if (r < 0) { arrayfree(array); } break; case NDARRAY: array = allocate_darray(val->ary); r = putobj(obj, vname, id, array); if (r < 0) { arrayfree(array); } break; case NSARRAY: array = allocate_sarray(val->ary); r = putobj(obj, vname, id, array); if (r < 0) { arrayfree2(array); } break; } return r; } static const char ** allocate_obj_arg(struct objlist *obj, const char *vname, ngraph_arg *arg) { int i, n, num, is_a; const char *arglist; const char **ary; num = arg->num; if (num < 1) { /* If the type of the field is NENUM the number of the argument is 0. */ return NULL; } arglist = chkobjarglist(obj, vname); if (arglist && arglist[0] == '\0') { return NULL; } ary = g_malloc0(sizeof(*ary) * (num + 1)); if (ary == NULL) { return NULL; } if (arglist == NULL) { for (i = 0; i < num; i++) { ary[i] = arg->ary[i].str; } } else { n = 0; for (i = 0; arglist[i]; i++) { if (n >= num) { break; } is_a = (arglist[i + 1]== 'a'); switch (arglist[i]) { case 'b': case 'c': ary[n] = (char *) &arg->ary[n].i; break; case 'i': if (is_a) { ary[n] = (char *) allocate_iarray(arg->ary[n].ary); } else { ary[n] = (char *) &arg->ary[n].i; } break; case 'd': if (is_a) { ary[n] = (char *) allocate_darray(arg->ary[n].ary); } else { ary[n] = (char *) &arg->ary[n].d; } break; case 's': if (is_a) { ary[n] = (char *) allocate_sarray(arg->ary[n].ary); } else { ary[n] = arg->ary[n].str; } break; case 'p': ary[n] = NULL; break; case 'o': ary[n] = arg->ary[n].str; break; } if (is_a) { i++; } n++; } } return ary; } static void free_obj_arg(const char **ary, struct objlist *obj, const char *vname, ngraph_arg *arg) { int i, n, num, is_a; const char *arglist; num = arg->num; if (num < 1) { return; } arglist = chkobjarglist(obj, vname); if (arglist == NULL) { return; } n = 0; for (i = 0; arglist[i]; i++) { if (n >= num) { break; } is_a = (arglist[i + 1]== 'a'); switch (arglist[i]) { case 'b': case 'c': break; case 'i': case 'd': if (is_a) { arrayfree((struct narray *) ary[n]); } break; case 's': if (is_a) { arrayfree2((struct narray *) ary[n]); } break; case 'p': break; case 'o': break; } if (is_a) { i++; } n++; } g_free(ary); return; } int ngraph_object_get(struct objlist *obj, const char *vname, int id, ngraph_arg *arg, ngraph_returned_value *val) { int r, argc; enum ngraph_object_field_type type; const char **argv; union ngraph_val nval; type = chkobjfieldtype(obj, vname); argc = arg->num; argv = allocate_obj_arg(obj, vname, arg); r = getobj(obj, vname, id, argc, (char **) argv, &nval); free_obj_arg(argv, obj, vname, arg); if (r < 0) { return r; } switch (type) { case NVOID: #if USE_LABEL case NLABEL: #endif case NVFUNC: break; case NSFUNC: case NSTR: case NOBJ: val->str = nval.str; break; case NPOINTER: /* these fields may not be writable */ break; case NBFUNC: case NIFUNC: case NBOOL: case NINT: case NENUM: val->i = nval.i; break; case NDFUNC: case NDOUBLE: val->d = nval.d; break; case NIAFUNC: case NIARRAY: val->ary.num = arraynum(nval.ary); val->ary.data.ia = arraydata(nval.ary); break; case NDAFUNC: case NDARRAY: val->ary.num = arraynum(nval.ary); val->ary.data.da = arraydata(nval.ary); break; case NSAFUNC: case NSARRAY: val->ary.num = arraynum(nval.ary); val->ary.data.sa = arraydata(nval.ary); break; } return r; } int ngraph_object_exe(struct objlist *obj, const char *vname, int id, ngraph_arg *arg) { int r, argc; enum ngraph_object_field_type type; const char **argv; type = chkobjfieldtype(obj, vname); if (type < NVFUNC) { return -1; } argc = arg->num; argv = allocate_obj_arg(obj, vname, arg); r = exeobj(obj, vname, id, argc, (char **) argv); free_obj_arg(argv, obj, vname, arg); return r; } struct objlist * ngraph_get_object(const char *name) { return getobject(name); } struct objlist * ngraph_get_object_instances_by_str(const char *str, int *n, int **ids) { struct narray iarray; int *id_ary, *adata, anum, i, r; struct objlist *obj; if (n) { *n = 0; } if (ids == NULL) { return NULL; } *ids = NULL; if (str == NULL) { return NULL; } arrayinit(&iarray,sizeof(int)); r = chkobjilist((char *) str, &obj, &iarray, TRUE, NULL); if (r) { arraydel(&iarray); return NULL; } anum = arraynum(&iarray); adata = arraydata(&iarray); id_ary = g_malloc(sizeof(*id_ary) * (anum + 1)); if (id_ary == NULL) { arraydel(&iarray); return NULL; } for (i = 0; i < anum; i++) { id_ary[i] = adata[i]; } id_ary[i] = -1; arraydel(&iarray); if (n) { *n = anum; } *ids = id_ary; return obj; } int ngraph_object_get_id_by_oid(struct objlist *obj, int oid) { return chkobjoid(obj, oid); } int ngraph_object_move_top(struct objlist *obj, int id) { return movetopobj(obj, id); } int ngraph_object_move_last(struct objlist *obj, int id) { return movelastobj(obj, id); } int ngraph_object_move_up(struct objlist *obj, int id) { return moveupobj(obj, id); } int ngraph_object_move_down(struct objlist *obj, int id) { return movedownobj(obj, id); } int ngraph_object_exchange(struct objlist *obj, int id1, int id2) { return exchobj(obj, id1, id2); } int ngraph_object_copy(struct objlist *obj, int dist, int src) { return copy_obj_field(obj, dist, src, NULL); } int ngraph_object_new(struct objlist *obj) { return newobj(obj); } int ngraph_object_del(struct objlist *obj, int id) { return delobj(obj, id); } int ngraph_object_exist(struct objlist *obj, int id) { int last; if (obj == NULL) { return -1; } last = chkobjlastinst(obj); if (id < 0 || id > last) { return -1; } return id; } const char * ngraph_get_object_name(struct objlist *obj) { return chkobjectname(obj); } const char * ngraph_get_object_alias(struct objlist *obj) { return chkobjectalias(obj); } int ngraph_get_object_field_num(struct objlist *obj) { return chkobjfieldnum(obj); } const char * ngraph_get_object_field(struct objlist *obj, int i) { return chkobjfieldname(obj, i); } int ngraph_get_object_field_permission(struct objlist *obj, const char *field) { return chkobjperm(obj, field); } enum ngraph_object_field_type ngraph_get_object_field_type(struct objlist *obj, const char *field) { return chkobjfieldtype(obj, field); } const char * ngraph_get_object_field_args(struct objlist *obj, const char *field) { return chkobjarglist(obj, field); } struct objlist * ngraph_get_parent_object(struct objlist *obj) { return chkobjparent(obj); } struct objlist * ngraph_get_root_object(void) { return chkobjroot(); } const char * ngraph_get_object_version(struct objlist *obj) { return chkobjver(obj); } int ngraph_get_object_id(struct objlist *obj) { return chkobjectid(obj); } int ngraph_get_object_size(struct objlist *obj) { return chkobjsize(obj); } int ngraph_get_object_current_id(struct objlist *obj) { return chkobjcurinst(obj); } int ngraph_get_object_last_id(struct objlist *obj) { return chkobjlastinst(obj); } struct objlist * ngraph_get_next_object(struct objlist *obj) { return obj->next; } struct objlist * ngraph_get_child_object(struct objlist *obj) { return obj->child; } int ngraph_puts(const char *s) { return putstdout(s); } int ngraph_err_puts(const char *s) { return putstderr(s); } void ngraph_sleep(double t) { nsleep(t); } char * ngraph_get_init_file(const char *init_file) { char *homedir, *confdir, *inifile;; struct objlist *sys; if (init_file == NULL) { return NULL; } sys = chkobject("system"); getobj(sys, "home_dir", 0, 0, NULL, &homedir); getobj(sys, "conf_dir", 0, 0, NULL, &confdir); inifile = NULL; if (findfilename(homedir, CONFTOP, init_file)) { inifile = getfilename(homedir, CONFTOP, init_file); } else if (findfilename(confdir, CONFTOP, init_file)) { inifile = getfilename(confdir, CONFTOP, init_file); } return inifile; } int ngraph_exec_loginshell(char *loginshell, struct objlist *obj, int id) { int r, allocnow; struct objlist *lobj; struct narray iarray; char *arg; if (loginshell == NULL) { allocnow = nallocconsole(); r = exeobj(obj, "shell", id, 0, NULL); if (allocnow) { nfreeconsole(); } } else { arrayinit(&iarray, sizeof(int)); arg = loginshell; if (getobjilist2(&arg, &lobj, &iarray, TRUE)) { return -1; } arraydel(&iarray); if (lobj == obj) { allocnow = nallocconsole(); } else { allocnow = FALSE; } r = sexeobj(loginshell); if (allocnow) { nallocconsole(); } } return r; } int ngraph_initialize(int *argc, char ***argv) { return n_initialize(argc, argv); } void ngraph_save_shell_history(void) { n_save_shell_history(); } void ngraph_finalize(void) { n_finalize(); } void * ngraph_malloc(size_t size) { return g_malloc(size); } void ngraph_free(void *ptr) { return g_free(ptr); } char * ngraph_strdup(const char *str) { return g_strdup(str); } int ngraph_set_exec_func(const char *name, ngraph_plugin_exec func) { return system_set_exec_func(name, func); } ngraph-gtk-6.08.00/src/shellux.c0000644000175000017500000002241413070106167013273 00000000000000/* * $Id: shellux.c,v 1.9 2010-03-04 08:30:16 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #include "common.h" #include #include #include #include #include #include #include "nstring.h" #include "object.h" #include "ioutil.h" #include "shell.h" #include "shellux.h" int cmtrue(struct nshell *nshell,int argc,char **argv) { return 0; } int cmfalse(struct nshell *nshell,int argc,char **argv) { return 1; } int cmsleep(struct nshell *nshell,int argc,char **argv) { double a; char *arg,*endptr; if (argc<2) { sherror4(argv[0],ERRSMLARG); return ERRSMLARG; } arg=argv[1]; a=strtod(arg, &endptr); if (endptr[0]!='\0') { sherror3(argv[0],ERRNUMERIC,arg); return ERRNUMERIC; } nsleep(a); return 0; } static int testexpand(int pre,int *oppo,int *numpo, int numbuf[],char *numbufc[],char opbuf[],int prebuf[]) { int argnum; int d1,d2; char *endptr1,*endptr2; GStatBuf buf; while ((*oppo>=0) && (pre<=prebuf[*oppo])) { if (strchr("!nzdefrswx",opbuf[*oppo])!=NULL) argnum=1; else argnum=2; switch (opbuf[*oppo]) { case 'n': if (numbufc[*numpo]==NULL) return FALSE; numbuf[*numpo]=(numbufc[*numpo][0]=='\0')?FALSE:TRUE; numbufc[*numpo]=NULL; break; case 'z': if (numbufc[*numpo]==NULL) return FALSE; numbuf[*numpo]=(numbufc[*numpo][0]=='\0')?TRUE:FALSE; numbufc[*numpo]=NULL; break; case 'd': case 'f': case 'e': case 'r': case 'w': case 'x': case 's': if (numbufc[*numpo]==NULL) return FALSE; if (nstat(numbufc[*numpo],&buf)!=0) { numbuf[*numpo]=FALSE; numbufc[*numpo]=NULL; break; } switch (opbuf[*oppo]) { case 'd': numbuf[*numpo]=((buf.st_mode & S_IFMT)==S_IFDIR)?TRUE:FALSE; break; case 'f': numbuf[*numpo]=((buf.st_mode & S_IFMT)==S_IFREG)?TRUE:FALSE; break; case 'e': numbuf[*numpo]=TRUE; break; case 'r': numbuf[*numpo]=((buf.st_mode & S_IREAD)!=0)?TRUE:FALSE; break; case 'w': numbuf[*numpo]=((buf.st_mode & S_IWRITE)!=0)?TRUE:FALSE; break; case 'x': numbuf[*numpo]=((buf.st_mode & S_IEXEC)!=0)?TRUE:FALSE; break; case 's': numbuf[*numpo]=(buf.st_size>0)?TRUE:FALSE; break; } numbufc[*numpo]=NULL; break; case '!': numbuf[*numpo]=(numbuf[*numpo])?FALSE:TRUE; numbufc[*numpo]=NULL; break; case 'o': numbuf[*numpo-1]=numbuf[*numpo-1] || numbuf[*numpo]; numbufc[*numpo]=NULL; break; case 'a': numbuf[*numpo-1]=numbuf[*numpo-1] && numbuf[*numpo]; numbufc[*numpo]=NULL; break; case '?': case '*': case '>': case '}': case '<': case '{': if ((numbufc[*numpo-1]==NULL) || (numbufc[*numpo]==NULL)) return FALSE; d1=strtol(numbufc[*numpo-1],&endptr1,10); d2=strtol(numbufc[*numpo],&endptr2,10); if ((endptr1[0]!='\0') || (endptr2[0]!='\0')) return FALSE; switch (opbuf[*oppo]) { case '?': numbuf[*numpo-1]=(d1==d2)?TRUE:FALSE; break; case '*': numbuf[*numpo-1]=(d1!=d2)?TRUE:FALSE; break; case '>': numbuf[*numpo-1]=(d1>d2)?TRUE:FALSE; break; case '}': numbuf[*numpo-1]=(d1>=d2)?TRUE:FALSE; break; case '<': numbuf[*numpo-1]=(d1=20) { sherror4(argv[0],ERRTESTNEST); return 1; } opbuf[oppo]='!'; prebuf[oppo]=4; i++; } else if (((strcmp2(argv[i],"-d")==0) || (strcmp2(argv[i],"-e")==0) || (strcmp2(argv[i],"-f")==0) || (strcmp2(argv[i],"-r")==0) || (strcmp2(argv[i],"-s")==0) || (strcmp2(argv[i],"-w")==0) || (strcmp2(argv[i],"-x")==0) || (strcmp2(argv[i],"-z")==0) || (strcmp2(argv[i],"-n")==0)) && ((i+1)=20) { sherror4(argv[0],ERRTESTNEST); return 1; } opbuf[oppo]='('; prebuf[oppo]=0; i++; } else { numpo++; if (numpo>=20) { sherror4(argv[0],ERRTESTNEST); return 1; } numbuf[numpo]=strlen(argv[i]); numbufc[numpo]=argv[i]; numeric=TRUE; i++; } } else { if (((strcmp2(argv[i],"-eq")==0) || (strcmp2(argv[i],"-ne")==0) || (strcmp2(argv[i],"-gt")==0) || (strcmp2(argv[i],"-ge")==0) || (strcmp2(argv[i],"-lt")==0) || (strcmp2(argv[i],"-le")==0) || (strcmp2(argv[i],"=")==0) || (strcmp2(argv[i],"!=")==0)) && ((i+1)=20) { sherror4(argv[0],ERRTESTNEST); return 1; } if (strcmp2(argv[i],"-eq")==0) opbuf[oppo]='?'; else if (strcmp2(argv[i],"-ne")==0) opbuf[oppo]='*'; else if (strcmp2(argv[i],"-gt")==0) opbuf[oppo]='>'; else if (strcmp2(argv[i],"-ge")==0) opbuf[oppo]='}'; else if (strcmp2(argv[i],"-lt")==0) opbuf[oppo]='<'; else if (strcmp2(argv[i],"-le")==0) opbuf[oppo]='{'; else if (strcmp2(argv[i],"=")==0) opbuf[oppo]='='; else if (strcmp2(argv[i],"!=")==0) opbuf[oppo]='+'; prebuf[oppo]=5; numeric=FALSE; i++; } else if (strcmp2(argv[i],")")==0) { if (!testexpand(1,&oppo,&numpo,numbuf,numbufc,opbuf,prebuf)) { sherror4(argv[0],ERRTESTSYNTAX); return 1; } if ((oppo!=-1) && (opbuf[oppo]=='(')) oppo--; numeric=TRUE; i++; } else if ((strcmp2(argv[i],"-a")==0) && ((i+1)=20) { sherror4(argv[0],ERRTESTNEST); return 1; } opbuf[oppo]=argv[i][1]; prebuf[oppo]=3; numeric=FALSE; i++; } else if ((strcmp2(argv[i],"-o")==0) && ((i+1)=20) { sherror4(argv[0],ERRTESTNEST); return 1; } opbuf[oppo]=argv[i][1]; prebuf[oppo]=2; numeric=FALSE; i++; } else if (strcmp2(argv[i],"]")==0) { i++; } else { sherror4(argv[0],ERRTESTSYNTAX); return 1; } } } if (!numeric || !testexpand(1,&oppo,&numpo,numbuf,numbufc,opbuf,prebuf)) { sherror4(argv[0],ERRTESTSYNTAX); return 1; } if ((oppo>-1) || (numpo!=0)) { sherror4(argv[0],ERRTESTSYNTAX); return 1; } if (numbuf[0]) return 0; else return 1; } ngraph-gtk-6.08.00/src/shellcm.h0000644000175000017500000000515713070106167013250 00000000000000/* * $Id: shellcm.h,v 1.8 2009-11-12 01:36:45 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ #ifndef SHELLCM_HEADER #define SHELLCM_HEADER #include "shell.h" int cmcd(struct nshell *nshell,int argc,char **argv); int cmecho(struct nshell *nshell,int argc,char **argv); int cmbasename(struct nshell *nshell,int argc,char **argv); int cmdirname(struct nshell *nshell,int argc,char **argv); int cmeval(struct nshell *nshell,int argc,char **argv); int cmexit(struct nshell *nshell,int argc,char **argv); int cmexport(struct nshell *nshell,int argc,char **argv); int cmpwd(struct nshell *nshell,int argc,char **argv); int cmset(struct nshell *nshell,int argc,char **argv); int cmshift(struct nshell *nshell,int argc,char **argv); int cmtype(struct nshell *nshell,int argc,char **argv); int cmunset(struct nshell *nshell,int argc,char **argv); int cmobject(struct nshell *nshell,int argc,char **argv); int cmderive(struct nshell *nshell,int argc,char **argv); int cmnew(struct nshell *nshell,int argc,char **argv); int cmdel(struct nshell *nshell,int argc,char **argv); int cmexist(struct nshell *nshell,int argc,char **argv); int cmget(struct nshell *nshell,int argc,char **argv); int cmput(struct nshell *nshell,int argc,char **argv); int cmdup(struct nshell *nshell,int argc,char **argv); int cmcpy(struct nshell *nshell,int argc,char **argv); int cmmove(struct nshell *nshell,int argc,char **argv); int cmmovetop(struct nshell *nshell,int argc,char **argv); int cmcopy(struct nshell *nshell,int argc,char **argv); int cmexch(struct nshell *nshell,int argc,char **argv); int cmexe(struct nshell *nshell,int argc,char **argv); int cmdexpr(struct nshell *nshell,int argc,char **argv); int cmread(struct nshell *nshell,int argc,char **argv); int cmseq(struct nshell *nshell, int argc, char **argv); int cmwhich(struct nshell*nshell,int argc,char **argv); #endif ngraph-gtk-6.08.00/src/strconv.h0000644000175000017500000000024413070106167013307 00000000000000/* * $Id: strconv.h,v 1.1 2009-11-16 09:13:04 hito Exp $ */ char *sjis_to_utf8(char *src); char *utf8_to_sjis(char *src); gchar *ascii2greece(const gchar *src); ngraph-gtk-6.08.00/src/Makefile.in0000644000175000017500000027532113367273153013530 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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@ @OS_WIN32_TRUE@am__append_1 = -no-undefined -export-symbols ngraph.def -Wl,libngraph_resource.o @OS_WIN32_TRUE@am__append_2 = -Wl,ngraph_resource.o @OS_WIN32_FALSE@am__append_3 = @vsymldflags@ @OS_WIN32_FALSE@pkglibexec_PROGRAMS = terminal$(EXEEXT) bin_PROGRAMS = ngraph$(EXEEXT) subdir = src ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" "$(DESTDIR)$(pkglibexecdir)" \ "$(DESTDIR)$(libdir)" "$(DESTDIR)$(includedir)" PROGRAMS = $(bin_PROGRAMS) $(pkglibexec_PROGRAMS) 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; }; \ } LTLIBRARIES = $(lib_LTLIBRARIES) libngraph_la_DEPENDENCIES = gtk/libngraphui.la math/libmath.la am_libngraph_la_OBJECTS = libngraph_la-axis.lo libngraph_la-nconfig.lo \ libngraph_la-gra.lo libngraph_la-ioutil.lo \ libngraph_la-mathcode.lo libngraph_la-mathfn.lo \ libngraph_la-nstring.lo libngraph_la-ntime.lo \ libngraph_la-oagrid.lo libngraph_la-oarc.lo \ libngraph_la-oaxis.lo libngraph_la-object.lo \ libngraph_la-odarray.lo libngraph_la-odouble.lo \ libngraph_la-odraw.lo libngraph_la-odata.lo \ libngraph_la-ofit.lo libngraph_la-ogra.lo \ libngraph_la-ogra2.lo libngraph_la-ogra2fil.lo \ libngraph_la-ogra2nul.lo libngraph_la-ogra2prn.lo \ libngraph_la-oiarray.lo libngraph_la-oint.lo \ libngraph_la-olegend.lo libngraph_la-omark.lo \ libngraph_la-omath.lo libngraph_la-omerge.lo \ libngraph_la-oprm.lo libngraph_la-orect.lo \ libngraph_la-oroot.lo libngraph_la-osarray.lo \ libngraph_la-oshell.lo libngraph_la-oregexp.lo \ libngraph_la-ostring.lo libngraph_la-osystem.lo \ libngraph_la-otext.lo libngraph_la-opath.lo \ libngraph_la-shell.lo libngraph_la-shellcm.lo \ libngraph_la-shellux.lo libngraph_la-spline.lo \ libngraph_la-nhash.lo libngraph_la-strconv.lo \ libngraph_la-oio.lo libngraph_la-ngraph_api.lo libngraph_la_OBJECTS = $(am_libngraph_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 = libngraph_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(libngraph_la_CFLAGS) \ $(CFLAGS) $(libngraph_la_LDFLAGS) $(LDFLAGS) -o $@ am_ngraph_OBJECTS = main.$(OBJEXT) ngraph_OBJECTS = $(am_ngraph_OBJECTS) ngraph_LDADD = $(LDADD) ngraph_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(ngraph_LDFLAGS) $(LDFLAGS) -o $@ am__terminal_SOURCES_DIST = terminal.c @OS_WIN32_FALSE@am_terminal_OBJECTS = terminal-terminal.$(OBJEXT) terminal_OBJECTS = $(am_terminal_OBJECTS) terminal_LDADD = $(LDADD) terminal_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(terminal_CFLAGS) \ $(CFLAGS) $(AM_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__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libngraph_la-axis.Plo \ ./$(DEPDIR)/libngraph_la-gra.Plo \ ./$(DEPDIR)/libngraph_la-ioutil.Plo \ ./$(DEPDIR)/libngraph_la-mathcode.Plo \ ./$(DEPDIR)/libngraph_la-mathfn.Plo \ ./$(DEPDIR)/libngraph_la-nconfig.Plo \ ./$(DEPDIR)/libngraph_la-ngraph_api.Plo \ ./$(DEPDIR)/libngraph_la-nhash.Plo \ ./$(DEPDIR)/libngraph_la-nstring.Plo \ ./$(DEPDIR)/libngraph_la-ntime.Plo \ ./$(DEPDIR)/libngraph_la-oagrid.Plo \ ./$(DEPDIR)/libngraph_la-oarc.Plo \ ./$(DEPDIR)/libngraph_la-oaxis.Plo \ ./$(DEPDIR)/libngraph_la-object.Plo \ ./$(DEPDIR)/libngraph_la-odarray.Plo \ ./$(DEPDIR)/libngraph_la-odata.Plo \ ./$(DEPDIR)/libngraph_la-odouble.Plo \ ./$(DEPDIR)/libngraph_la-odraw.Plo \ ./$(DEPDIR)/libngraph_la-ofit.Plo \ ./$(DEPDIR)/libngraph_la-ogra.Plo \ ./$(DEPDIR)/libngraph_la-ogra2.Plo \ ./$(DEPDIR)/libngraph_la-ogra2fil.Plo \ ./$(DEPDIR)/libngraph_la-ogra2nul.Plo \ ./$(DEPDIR)/libngraph_la-ogra2prn.Plo \ ./$(DEPDIR)/libngraph_la-oiarray.Plo \ ./$(DEPDIR)/libngraph_la-oint.Plo \ ./$(DEPDIR)/libngraph_la-oio.Plo \ ./$(DEPDIR)/libngraph_la-olegend.Plo \ ./$(DEPDIR)/libngraph_la-omark.Plo \ ./$(DEPDIR)/libngraph_la-omath.Plo \ ./$(DEPDIR)/libngraph_la-omerge.Plo \ ./$(DEPDIR)/libngraph_la-opath.Plo \ ./$(DEPDIR)/libngraph_la-oprm.Plo \ ./$(DEPDIR)/libngraph_la-orect.Plo \ ./$(DEPDIR)/libngraph_la-oregexp.Plo \ ./$(DEPDIR)/libngraph_la-oroot.Plo \ ./$(DEPDIR)/libngraph_la-osarray.Plo \ ./$(DEPDIR)/libngraph_la-oshell.Plo \ ./$(DEPDIR)/libngraph_la-ostring.Plo \ ./$(DEPDIR)/libngraph_la-osystem.Plo \ ./$(DEPDIR)/libngraph_la-otext.Plo \ ./$(DEPDIR)/libngraph_la-shell.Plo \ ./$(DEPDIR)/libngraph_la-shellcm.Plo \ ./$(DEPDIR)/libngraph_la-shellux.Plo \ ./$(DEPDIR)/libngraph_la-spline.Plo \ ./$(DEPDIR)/libngraph_la-strconv.Plo ./$(DEPDIR)/main.Po \ ./$(DEPDIR)/terminal-terminal.Po 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 = $(libngraph_la_SOURCES) $(ngraph_SOURCES) \ $(terminal_SOURCES) DIST_SOURCES = $(libngraph_la_SOURCES) $(ngraph_SOURCES) \ $(am__terminal_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 HEADERS = $(include_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 distdir-am 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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ SUBDIRS = math gtk EXTRA_DIST = ngraph_export.map ngraph_resource.rc.in libngraph_resource.rc.in ngraph.ico libngraph_ldflags = -version-info $(LIBNGRAPH_VERSION) \ $(READLINE_LIBS) $(GTK_LIBS) $(GLIB_LIBS) $(GSL_LIBS) \ $(am__append_1) $(am__append_3) ngraph_ldflags = -lngraph $(am__append_2) ngraph_lib = libngraph.la @OS_WIN32_TRUE@BUILT_SOURCES = ngraph.def libngraph_resource.o ngraph_resource.o @OS_WIN32_TRUE@CLEANFILES = $(BUILT_SOURCES) libngraph_resource.rc ngraph_resource.rc @OS_WIN32_FALSE@terminal_SOURCES = terminal.c @OS_WIN32_FALSE@terminal_CFLAGS = $(GTK_CFLAGS) lib_LTLIBRARIES = $(ngraph_lib) libngraph_la_SOURCES = axis.c axis.h nconfig.c nconfig.h gra.c gra.h \ ioutil.c ioutil.h mathcode.c mathcode.h mathfn.c mathfn.h \ nstring.c nstring.h ntime.c ntime.h oagrid.c oarc.c oarc.h \ oaxis.c object.c object.h odarray.c odouble.c odraw.c odraw.h \ odata.c odata.h ofit.c ofit.h ogra.c ogra.h ogra2.c \ ogra2fil.c ogra2nul.c ogra2prn.c oiarray.c oiarray.h oint.c \ olegend.c olegend.h omark.c omath.c omerge.c omerge.h oprm.c \ orect.c oroot.c oroot.h osarray.c oshell.c oregexp.c \ ostring.c osystem.c osystem.h otext.c otext.h opath.c opath.h \ shell.c shell.h shellcm.c shellcm.h shellux.c shellux.h \ spline.c spline.h common.h nhash.h nhash.c strconv.c \ strconv.h oio.c gettext.h ngraph_api.c libngraph_la_CFLAGS = $(GTK_CFLAGS) $(GSL_CFLAGS) -I$(top_builddir) -DCCNAME='"'$(CC)'"' libngraph_la_LIBADD = gtk/libngraphui.la math/libmath.la libngraph_la_LDFLAGS = $(libngraph_ldflags) ngraph_SOURCES = main.c ngraph_DEPENDENCIES = $(ngraph_lib) ngraph_LDFLAGS = $(ngraph_ldflags) include_HEADERS = ngraph.h all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) all-recursive .SUFFIXES: .SUFFIXES: .c .lo .o .obj .rc $(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) --gnu src/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu 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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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 install-pkglibexecPROGRAMS: $(pkglibexec_PROGRAMS) @$(NORMAL_INSTALL) @list='$(pkglibexec_PROGRAMS)'; test -n "$(pkglibexecdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkglibexecdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkglibexecdir)" || 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)$(pkglibexecdir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(pkglibexecdir)$$dir" || exit $$?; \ } \ ; done uninstall-pkglibexecPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(pkglibexec_PROGRAMS)'; test -n "$(pkglibexecdir)" || 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)$(pkglibexecdir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(pkglibexecdir)" && rm -f $$files clean-pkglibexecPROGRAMS: @list='$(pkglibexec_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 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}; \ } libngraph.la: $(libngraph_la_OBJECTS) $(libngraph_la_DEPENDENCIES) $(EXTRA_libngraph_la_DEPENDENCIES) $(AM_V_CCLD)$(libngraph_la_LINK) -rpath $(libdir) $(libngraph_la_OBJECTS) $(libngraph_la_LIBADD) $(LIBS) ngraph$(EXEEXT): $(ngraph_OBJECTS) $(ngraph_DEPENDENCIES) $(EXTRA_ngraph_DEPENDENCIES) @rm -f ngraph$(EXEEXT) $(AM_V_CCLD)$(ngraph_LINK) $(ngraph_OBJECTS) $(ngraph_LDADD) $(LIBS) terminal$(EXEEXT): $(terminal_OBJECTS) $(terminal_DEPENDENCIES) $(EXTRA_terminal_DEPENDENCIES) @rm -f terminal$(EXEEXT) $(AM_V_CCLD)$(terminal_LINK) $(terminal_OBJECTS) $(terminal_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-axis.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-gra.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ioutil.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-mathcode.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-mathfn.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-nconfig.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ngraph_api.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-nhash.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-nstring.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ntime.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oagrid.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oarc.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oaxis.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-object.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-odarray.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-odata.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-odouble.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-odraw.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ofit.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ogra.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ogra2.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ogra2fil.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ogra2nul.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ogra2prn.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oiarray.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oint.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oio.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-olegend.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-omark.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-omath.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-omerge.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-opath.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oprm.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-orect.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oregexp.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oroot.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-osarray.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-oshell.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-ostring.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-osystem.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-otext.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-shell.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-shellcm.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-shellux.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-spline.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libngraph_la-strconv.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/main.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/terminal-terminal.Po@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .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 $@ $< libngraph_la-axis.lo: axis.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-axis.lo -MD -MP -MF $(DEPDIR)/libngraph_la-axis.Tpo -c -o libngraph_la-axis.lo `test -f 'axis.c' || echo '$(srcdir)/'`axis.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-axis.Tpo $(DEPDIR)/libngraph_la-axis.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='axis.c' object='libngraph_la-axis.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-axis.lo `test -f 'axis.c' || echo '$(srcdir)/'`axis.c libngraph_la-nconfig.lo: nconfig.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-nconfig.lo -MD -MP -MF $(DEPDIR)/libngraph_la-nconfig.Tpo -c -o libngraph_la-nconfig.lo `test -f 'nconfig.c' || echo '$(srcdir)/'`nconfig.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-nconfig.Tpo $(DEPDIR)/libngraph_la-nconfig.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nconfig.c' object='libngraph_la-nconfig.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-nconfig.lo `test -f 'nconfig.c' || echo '$(srcdir)/'`nconfig.c libngraph_la-gra.lo: gra.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-gra.lo -MD -MP -MF $(DEPDIR)/libngraph_la-gra.Tpo -c -o libngraph_la-gra.lo `test -f 'gra.c' || echo '$(srcdir)/'`gra.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-gra.Tpo $(DEPDIR)/libngraph_la-gra.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gra.c' object='libngraph_la-gra.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-gra.lo `test -f 'gra.c' || echo '$(srcdir)/'`gra.c libngraph_la-ioutil.lo: ioutil.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ioutil.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ioutil.Tpo -c -o libngraph_la-ioutil.lo `test -f 'ioutil.c' || echo '$(srcdir)/'`ioutil.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ioutil.Tpo $(DEPDIR)/libngraph_la-ioutil.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ioutil.c' object='libngraph_la-ioutil.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ioutil.lo `test -f 'ioutil.c' || echo '$(srcdir)/'`ioutil.c libngraph_la-mathcode.lo: mathcode.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-mathcode.lo -MD -MP -MF $(DEPDIR)/libngraph_la-mathcode.Tpo -c -o libngraph_la-mathcode.lo `test -f 'mathcode.c' || echo '$(srcdir)/'`mathcode.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-mathcode.Tpo $(DEPDIR)/libngraph_la-mathcode.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mathcode.c' object='libngraph_la-mathcode.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-mathcode.lo `test -f 'mathcode.c' || echo '$(srcdir)/'`mathcode.c libngraph_la-mathfn.lo: mathfn.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-mathfn.lo -MD -MP -MF $(DEPDIR)/libngraph_la-mathfn.Tpo -c -o libngraph_la-mathfn.lo `test -f 'mathfn.c' || echo '$(srcdir)/'`mathfn.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-mathfn.Tpo $(DEPDIR)/libngraph_la-mathfn.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='mathfn.c' object='libngraph_la-mathfn.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-mathfn.lo `test -f 'mathfn.c' || echo '$(srcdir)/'`mathfn.c libngraph_la-nstring.lo: nstring.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-nstring.lo -MD -MP -MF $(DEPDIR)/libngraph_la-nstring.Tpo -c -o libngraph_la-nstring.lo `test -f 'nstring.c' || echo '$(srcdir)/'`nstring.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-nstring.Tpo $(DEPDIR)/libngraph_la-nstring.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nstring.c' object='libngraph_la-nstring.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-nstring.lo `test -f 'nstring.c' || echo '$(srcdir)/'`nstring.c libngraph_la-ntime.lo: ntime.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ntime.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ntime.Tpo -c -o libngraph_la-ntime.lo `test -f 'ntime.c' || echo '$(srcdir)/'`ntime.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ntime.Tpo $(DEPDIR)/libngraph_la-ntime.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ntime.c' object='libngraph_la-ntime.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ntime.lo `test -f 'ntime.c' || echo '$(srcdir)/'`ntime.c libngraph_la-oagrid.lo: oagrid.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oagrid.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oagrid.Tpo -c -o libngraph_la-oagrid.lo `test -f 'oagrid.c' || echo '$(srcdir)/'`oagrid.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oagrid.Tpo $(DEPDIR)/libngraph_la-oagrid.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oagrid.c' object='libngraph_la-oagrid.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oagrid.lo `test -f 'oagrid.c' || echo '$(srcdir)/'`oagrid.c libngraph_la-oarc.lo: oarc.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oarc.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oarc.Tpo -c -o libngraph_la-oarc.lo `test -f 'oarc.c' || echo '$(srcdir)/'`oarc.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oarc.Tpo $(DEPDIR)/libngraph_la-oarc.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oarc.c' object='libngraph_la-oarc.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oarc.lo `test -f 'oarc.c' || echo '$(srcdir)/'`oarc.c libngraph_la-oaxis.lo: oaxis.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oaxis.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oaxis.Tpo -c -o libngraph_la-oaxis.lo `test -f 'oaxis.c' || echo '$(srcdir)/'`oaxis.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oaxis.Tpo $(DEPDIR)/libngraph_la-oaxis.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oaxis.c' object='libngraph_la-oaxis.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oaxis.lo `test -f 'oaxis.c' || echo '$(srcdir)/'`oaxis.c libngraph_la-object.lo: object.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-object.lo -MD -MP -MF $(DEPDIR)/libngraph_la-object.Tpo -c -o libngraph_la-object.lo `test -f 'object.c' || echo '$(srcdir)/'`object.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-object.Tpo $(DEPDIR)/libngraph_la-object.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='object.c' object='libngraph_la-object.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-object.lo `test -f 'object.c' || echo '$(srcdir)/'`object.c libngraph_la-odarray.lo: odarray.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-odarray.lo -MD -MP -MF $(DEPDIR)/libngraph_la-odarray.Tpo -c -o libngraph_la-odarray.lo `test -f 'odarray.c' || echo '$(srcdir)/'`odarray.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-odarray.Tpo $(DEPDIR)/libngraph_la-odarray.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='odarray.c' object='libngraph_la-odarray.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-odarray.lo `test -f 'odarray.c' || echo '$(srcdir)/'`odarray.c libngraph_la-odouble.lo: odouble.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-odouble.lo -MD -MP -MF $(DEPDIR)/libngraph_la-odouble.Tpo -c -o libngraph_la-odouble.lo `test -f 'odouble.c' || echo '$(srcdir)/'`odouble.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-odouble.Tpo $(DEPDIR)/libngraph_la-odouble.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='odouble.c' object='libngraph_la-odouble.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-odouble.lo `test -f 'odouble.c' || echo '$(srcdir)/'`odouble.c libngraph_la-odraw.lo: odraw.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-odraw.lo -MD -MP -MF $(DEPDIR)/libngraph_la-odraw.Tpo -c -o libngraph_la-odraw.lo `test -f 'odraw.c' || echo '$(srcdir)/'`odraw.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-odraw.Tpo $(DEPDIR)/libngraph_la-odraw.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='odraw.c' object='libngraph_la-odraw.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-odraw.lo `test -f 'odraw.c' || echo '$(srcdir)/'`odraw.c libngraph_la-odata.lo: odata.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-odata.lo -MD -MP -MF $(DEPDIR)/libngraph_la-odata.Tpo -c -o libngraph_la-odata.lo `test -f 'odata.c' || echo '$(srcdir)/'`odata.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-odata.Tpo $(DEPDIR)/libngraph_la-odata.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='odata.c' object='libngraph_la-odata.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-odata.lo `test -f 'odata.c' || echo '$(srcdir)/'`odata.c libngraph_la-ofit.lo: ofit.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ofit.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ofit.Tpo -c -o libngraph_la-ofit.lo `test -f 'ofit.c' || echo '$(srcdir)/'`ofit.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ofit.Tpo $(DEPDIR)/libngraph_la-ofit.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ofit.c' object='libngraph_la-ofit.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ofit.lo `test -f 'ofit.c' || echo '$(srcdir)/'`ofit.c libngraph_la-ogra.lo: ogra.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ogra.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ogra.Tpo -c -o libngraph_la-ogra.lo `test -f 'ogra.c' || echo '$(srcdir)/'`ogra.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ogra.Tpo $(DEPDIR)/libngraph_la-ogra.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra.c' object='libngraph_la-ogra.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ogra.lo `test -f 'ogra.c' || echo '$(srcdir)/'`ogra.c libngraph_la-ogra2.lo: ogra2.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ogra2.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ogra2.Tpo -c -o libngraph_la-ogra2.lo `test -f 'ogra2.c' || echo '$(srcdir)/'`ogra2.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ogra2.Tpo $(DEPDIR)/libngraph_la-ogra2.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2.c' object='libngraph_la-ogra2.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ogra2.lo `test -f 'ogra2.c' || echo '$(srcdir)/'`ogra2.c libngraph_la-ogra2fil.lo: ogra2fil.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ogra2fil.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ogra2fil.Tpo -c -o libngraph_la-ogra2fil.lo `test -f 'ogra2fil.c' || echo '$(srcdir)/'`ogra2fil.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ogra2fil.Tpo $(DEPDIR)/libngraph_la-ogra2fil.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2fil.c' object='libngraph_la-ogra2fil.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ogra2fil.lo `test -f 'ogra2fil.c' || echo '$(srcdir)/'`ogra2fil.c libngraph_la-ogra2nul.lo: ogra2nul.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ogra2nul.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ogra2nul.Tpo -c -o libngraph_la-ogra2nul.lo `test -f 'ogra2nul.c' || echo '$(srcdir)/'`ogra2nul.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ogra2nul.Tpo $(DEPDIR)/libngraph_la-ogra2nul.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2nul.c' object='libngraph_la-ogra2nul.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ogra2nul.lo `test -f 'ogra2nul.c' || echo '$(srcdir)/'`ogra2nul.c libngraph_la-ogra2prn.lo: ogra2prn.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ogra2prn.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ogra2prn.Tpo -c -o libngraph_la-ogra2prn.lo `test -f 'ogra2prn.c' || echo '$(srcdir)/'`ogra2prn.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ogra2prn.Tpo $(DEPDIR)/libngraph_la-ogra2prn.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ogra2prn.c' object='libngraph_la-ogra2prn.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ogra2prn.lo `test -f 'ogra2prn.c' || echo '$(srcdir)/'`ogra2prn.c libngraph_la-oiarray.lo: oiarray.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oiarray.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oiarray.Tpo -c -o libngraph_la-oiarray.lo `test -f 'oiarray.c' || echo '$(srcdir)/'`oiarray.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oiarray.Tpo $(DEPDIR)/libngraph_la-oiarray.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oiarray.c' object='libngraph_la-oiarray.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oiarray.lo `test -f 'oiarray.c' || echo '$(srcdir)/'`oiarray.c libngraph_la-oint.lo: oint.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oint.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oint.Tpo -c -o libngraph_la-oint.lo `test -f 'oint.c' || echo '$(srcdir)/'`oint.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oint.Tpo $(DEPDIR)/libngraph_la-oint.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oint.c' object='libngraph_la-oint.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oint.lo `test -f 'oint.c' || echo '$(srcdir)/'`oint.c libngraph_la-olegend.lo: olegend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-olegend.lo -MD -MP -MF $(DEPDIR)/libngraph_la-olegend.Tpo -c -o libngraph_la-olegend.lo `test -f 'olegend.c' || echo '$(srcdir)/'`olegend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-olegend.Tpo $(DEPDIR)/libngraph_la-olegend.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='olegend.c' object='libngraph_la-olegend.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-olegend.lo `test -f 'olegend.c' || echo '$(srcdir)/'`olegend.c libngraph_la-omark.lo: omark.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-omark.lo -MD -MP -MF $(DEPDIR)/libngraph_la-omark.Tpo -c -o libngraph_la-omark.lo `test -f 'omark.c' || echo '$(srcdir)/'`omark.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-omark.Tpo $(DEPDIR)/libngraph_la-omark.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='omark.c' object='libngraph_la-omark.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-omark.lo `test -f 'omark.c' || echo '$(srcdir)/'`omark.c libngraph_la-omath.lo: omath.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-omath.lo -MD -MP -MF $(DEPDIR)/libngraph_la-omath.Tpo -c -o libngraph_la-omath.lo `test -f 'omath.c' || echo '$(srcdir)/'`omath.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-omath.Tpo $(DEPDIR)/libngraph_la-omath.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='omath.c' object='libngraph_la-omath.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-omath.lo `test -f 'omath.c' || echo '$(srcdir)/'`omath.c libngraph_la-omerge.lo: omerge.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-omerge.lo -MD -MP -MF $(DEPDIR)/libngraph_la-omerge.Tpo -c -o libngraph_la-omerge.lo `test -f 'omerge.c' || echo '$(srcdir)/'`omerge.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-omerge.Tpo $(DEPDIR)/libngraph_la-omerge.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='omerge.c' object='libngraph_la-omerge.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-omerge.lo `test -f 'omerge.c' || echo '$(srcdir)/'`omerge.c libngraph_la-oprm.lo: oprm.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oprm.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oprm.Tpo -c -o libngraph_la-oprm.lo `test -f 'oprm.c' || echo '$(srcdir)/'`oprm.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oprm.Tpo $(DEPDIR)/libngraph_la-oprm.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oprm.c' object='libngraph_la-oprm.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oprm.lo `test -f 'oprm.c' || echo '$(srcdir)/'`oprm.c libngraph_la-orect.lo: orect.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-orect.lo -MD -MP -MF $(DEPDIR)/libngraph_la-orect.Tpo -c -o libngraph_la-orect.lo `test -f 'orect.c' || echo '$(srcdir)/'`orect.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-orect.Tpo $(DEPDIR)/libngraph_la-orect.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='orect.c' object='libngraph_la-orect.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-orect.lo `test -f 'orect.c' || echo '$(srcdir)/'`orect.c libngraph_la-oroot.lo: oroot.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oroot.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oroot.Tpo -c -o libngraph_la-oroot.lo `test -f 'oroot.c' || echo '$(srcdir)/'`oroot.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oroot.Tpo $(DEPDIR)/libngraph_la-oroot.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oroot.c' object='libngraph_la-oroot.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oroot.lo `test -f 'oroot.c' || echo '$(srcdir)/'`oroot.c libngraph_la-osarray.lo: osarray.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-osarray.lo -MD -MP -MF $(DEPDIR)/libngraph_la-osarray.Tpo -c -o libngraph_la-osarray.lo `test -f 'osarray.c' || echo '$(srcdir)/'`osarray.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-osarray.Tpo $(DEPDIR)/libngraph_la-osarray.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='osarray.c' object='libngraph_la-osarray.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-osarray.lo `test -f 'osarray.c' || echo '$(srcdir)/'`osarray.c libngraph_la-oshell.lo: oshell.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oshell.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oshell.Tpo -c -o libngraph_la-oshell.lo `test -f 'oshell.c' || echo '$(srcdir)/'`oshell.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oshell.Tpo $(DEPDIR)/libngraph_la-oshell.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oshell.c' object='libngraph_la-oshell.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oshell.lo `test -f 'oshell.c' || echo '$(srcdir)/'`oshell.c libngraph_la-oregexp.lo: oregexp.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oregexp.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oregexp.Tpo -c -o libngraph_la-oregexp.lo `test -f 'oregexp.c' || echo '$(srcdir)/'`oregexp.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oregexp.Tpo $(DEPDIR)/libngraph_la-oregexp.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oregexp.c' object='libngraph_la-oregexp.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oregexp.lo `test -f 'oregexp.c' || echo '$(srcdir)/'`oregexp.c libngraph_la-ostring.lo: ostring.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ostring.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ostring.Tpo -c -o libngraph_la-ostring.lo `test -f 'ostring.c' || echo '$(srcdir)/'`ostring.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ostring.Tpo $(DEPDIR)/libngraph_la-ostring.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ostring.c' object='libngraph_la-ostring.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ostring.lo `test -f 'ostring.c' || echo '$(srcdir)/'`ostring.c libngraph_la-osystem.lo: osystem.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-osystem.lo -MD -MP -MF $(DEPDIR)/libngraph_la-osystem.Tpo -c -o libngraph_la-osystem.lo `test -f 'osystem.c' || echo '$(srcdir)/'`osystem.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-osystem.Tpo $(DEPDIR)/libngraph_la-osystem.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='osystem.c' object='libngraph_la-osystem.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-osystem.lo `test -f 'osystem.c' || echo '$(srcdir)/'`osystem.c libngraph_la-otext.lo: otext.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-otext.lo -MD -MP -MF $(DEPDIR)/libngraph_la-otext.Tpo -c -o libngraph_la-otext.lo `test -f 'otext.c' || echo '$(srcdir)/'`otext.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-otext.Tpo $(DEPDIR)/libngraph_la-otext.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='otext.c' object='libngraph_la-otext.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-otext.lo `test -f 'otext.c' || echo '$(srcdir)/'`otext.c libngraph_la-opath.lo: opath.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-opath.lo -MD -MP -MF $(DEPDIR)/libngraph_la-opath.Tpo -c -o libngraph_la-opath.lo `test -f 'opath.c' || echo '$(srcdir)/'`opath.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-opath.Tpo $(DEPDIR)/libngraph_la-opath.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='opath.c' object='libngraph_la-opath.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-opath.lo `test -f 'opath.c' || echo '$(srcdir)/'`opath.c libngraph_la-shell.lo: shell.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-shell.lo -MD -MP -MF $(DEPDIR)/libngraph_la-shell.Tpo -c -o libngraph_la-shell.lo `test -f 'shell.c' || echo '$(srcdir)/'`shell.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-shell.Tpo $(DEPDIR)/libngraph_la-shell.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='shell.c' object='libngraph_la-shell.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-shell.lo `test -f 'shell.c' || echo '$(srcdir)/'`shell.c libngraph_la-shellcm.lo: shellcm.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-shellcm.lo -MD -MP -MF $(DEPDIR)/libngraph_la-shellcm.Tpo -c -o libngraph_la-shellcm.lo `test -f 'shellcm.c' || echo '$(srcdir)/'`shellcm.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-shellcm.Tpo $(DEPDIR)/libngraph_la-shellcm.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='shellcm.c' object='libngraph_la-shellcm.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-shellcm.lo `test -f 'shellcm.c' || echo '$(srcdir)/'`shellcm.c libngraph_la-shellux.lo: shellux.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-shellux.lo -MD -MP -MF $(DEPDIR)/libngraph_la-shellux.Tpo -c -o libngraph_la-shellux.lo `test -f 'shellux.c' || echo '$(srcdir)/'`shellux.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-shellux.Tpo $(DEPDIR)/libngraph_la-shellux.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='shellux.c' object='libngraph_la-shellux.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-shellux.lo `test -f 'shellux.c' || echo '$(srcdir)/'`shellux.c libngraph_la-spline.lo: spline.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-spline.lo -MD -MP -MF $(DEPDIR)/libngraph_la-spline.Tpo -c -o libngraph_la-spline.lo `test -f 'spline.c' || echo '$(srcdir)/'`spline.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-spline.Tpo $(DEPDIR)/libngraph_la-spline.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='spline.c' object='libngraph_la-spline.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-spline.lo `test -f 'spline.c' || echo '$(srcdir)/'`spline.c libngraph_la-nhash.lo: nhash.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-nhash.lo -MD -MP -MF $(DEPDIR)/libngraph_la-nhash.Tpo -c -o libngraph_la-nhash.lo `test -f 'nhash.c' || echo '$(srcdir)/'`nhash.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-nhash.Tpo $(DEPDIR)/libngraph_la-nhash.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nhash.c' object='libngraph_la-nhash.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-nhash.lo `test -f 'nhash.c' || echo '$(srcdir)/'`nhash.c libngraph_la-strconv.lo: strconv.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-strconv.lo -MD -MP -MF $(DEPDIR)/libngraph_la-strconv.Tpo -c -o libngraph_la-strconv.lo `test -f 'strconv.c' || echo '$(srcdir)/'`strconv.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-strconv.Tpo $(DEPDIR)/libngraph_la-strconv.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='strconv.c' object='libngraph_la-strconv.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-strconv.lo `test -f 'strconv.c' || echo '$(srcdir)/'`strconv.c libngraph_la-oio.lo: oio.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-oio.lo -MD -MP -MF $(DEPDIR)/libngraph_la-oio.Tpo -c -o libngraph_la-oio.lo `test -f 'oio.c' || echo '$(srcdir)/'`oio.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-oio.Tpo $(DEPDIR)/libngraph_la-oio.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='oio.c' object='libngraph_la-oio.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-oio.lo `test -f 'oio.c' || echo '$(srcdir)/'`oio.c libngraph_la-ngraph_api.lo: ngraph_api.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -MT libngraph_la-ngraph_api.lo -MD -MP -MF $(DEPDIR)/libngraph_la-ngraph_api.Tpo -c -o libngraph_la-ngraph_api.lo `test -f 'ngraph_api.c' || echo '$(srcdir)/'`ngraph_api.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libngraph_la-ngraph_api.Tpo $(DEPDIR)/libngraph_la-ngraph_api.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ngraph_api.c' object='libngraph_la-ngraph_api.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libngraph_la_CFLAGS) $(CFLAGS) -c -o libngraph_la-ngraph_api.lo `test -f 'ngraph_api.c' || echo '$(srcdir)/'`ngraph_api.c terminal-terminal.o: terminal.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(terminal_CFLAGS) $(CFLAGS) -MT terminal-terminal.o -MD -MP -MF $(DEPDIR)/terminal-terminal.Tpo -c -o terminal-terminal.o `test -f 'terminal.c' || echo '$(srcdir)/'`terminal.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/terminal-terminal.Tpo $(DEPDIR)/terminal-terminal.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='terminal.c' object='terminal-terminal.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(terminal_CFLAGS) $(CFLAGS) -c -o terminal-terminal.o `test -f 'terminal.c' || echo '$(srcdir)/'`terminal.c terminal-terminal.obj: terminal.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(terminal_CFLAGS) $(CFLAGS) -MT terminal-terminal.obj -MD -MP -MF $(DEPDIR)/terminal-terminal.Tpo -c -o terminal-terminal.obj `if test -f 'terminal.c'; then $(CYGPATH_W) 'terminal.c'; else $(CYGPATH_W) '$(srcdir)/terminal.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/terminal-terminal.Tpo $(DEPDIR)/terminal-terminal.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='terminal.c' object='terminal-terminal.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(terminal_CFLAGS) $(CFLAGS) -c -o terminal-terminal.obj `if test -f 'terminal.c'; then $(CYGPATH_W) 'terminal.c'; else $(CYGPATH_W) '$(srcdir)/terminal.c'; fi` 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) # 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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-recursive all-am: Makefile $(PROGRAMS) $(LTLIBRARIES) $(HEADERS) install-binPROGRAMS: install-libLTLIBRARIES installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(pkglibexecdir)" "$(DESTDIR)$(libdir)" "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) clean: clean-recursive clean-am: clean-binPROGRAMS clean-generic clean-libLTLIBRARIES \ clean-libtool clean-pkglibexecPROGRAMS mostlyclean-am distclean: distclean-recursive -rm -f ./$(DEPDIR)/libngraph_la-axis.Plo -rm -f ./$(DEPDIR)/libngraph_la-gra.Plo -rm -f ./$(DEPDIR)/libngraph_la-ioutil.Plo -rm -f ./$(DEPDIR)/libngraph_la-mathcode.Plo -rm -f ./$(DEPDIR)/libngraph_la-mathfn.Plo -rm -f ./$(DEPDIR)/libngraph_la-nconfig.Plo -rm -f ./$(DEPDIR)/libngraph_la-ngraph_api.Plo -rm -f ./$(DEPDIR)/libngraph_la-nhash.Plo -rm -f ./$(DEPDIR)/libngraph_la-nstring.Plo -rm -f ./$(DEPDIR)/libngraph_la-ntime.Plo -rm -f ./$(DEPDIR)/libngraph_la-oagrid.Plo -rm -f ./$(DEPDIR)/libngraph_la-oarc.Plo -rm -f ./$(DEPDIR)/libngraph_la-oaxis.Plo -rm -f ./$(DEPDIR)/libngraph_la-object.Plo -rm -f ./$(DEPDIR)/libngraph_la-odarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-odata.Plo -rm -f ./$(DEPDIR)/libngraph_la-odouble.Plo -rm -f ./$(DEPDIR)/libngraph_la-odraw.Plo -rm -f ./$(DEPDIR)/libngraph_la-ofit.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2fil.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2nul.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2prn.Plo -rm -f ./$(DEPDIR)/libngraph_la-oiarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-oint.Plo -rm -f ./$(DEPDIR)/libngraph_la-oio.Plo -rm -f ./$(DEPDIR)/libngraph_la-olegend.Plo -rm -f ./$(DEPDIR)/libngraph_la-omark.Plo -rm -f ./$(DEPDIR)/libngraph_la-omath.Plo -rm -f ./$(DEPDIR)/libngraph_la-omerge.Plo -rm -f ./$(DEPDIR)/libngraph_la-opath.Plo -rm -f ./$(DEPDIR)/libngraph_la-oprm.Plo -rm -f ./$(DEPDIR)/libngraph_la-orect.Plo -rm -f ./$(DEPDIR)/libngraph_la-oregexp.Plo -rm -f ./$(DEPDIR)/libngraph_la-oroot.Plo -rm -f ./$(DEPDIR)/libngraph_la-osarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-oshell.Plo -rm -f ./$(DEPDIR)/libngraph_la-ostring.Plo -rm -f ./$(DEPDIR)/libngraph_la-osystem.Plo -rm -f ./$(DEPDIR)/libngraph_la-otext.Plo -rm -f ./$(DEPDIR)/libngraph_la-shell.Plo -rm -f ./$(DEPDIR)/libngraph_la-shellcm.Plo -rm -f ./$(DEPDIR)/libngraph_la-shellux.Plo -rm -f ./$(DEPDIR)/libngraph_la-spline.Plo -rm -f ./$(DEPDIR)/libngraph_la-strconv.Plo -rm -f ./$(DEPDIR)/main.Po -rm -f ./$(DEPDIR)/terminal-terminal.Po -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-includeHEADERS install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-binPROGRAMS install-libLTLIBRARIES \ install-pkglibexecPROGRAMS 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 ./$(DEPDIR)/libngraph_la-axis.Plo -rm -f ./$(DEPDIR)/libngraph_la-gra.Plo -rm -f ./$(DEPDIR)/libngraph_la-ioutil.Plo -rm -f ./$(DEPDIR)/libngraph_la-mathcode.Plo -rm -f ./$(DEPDIR)/libngraph_la-mathfn.Plo -rm -f ./$(DEPDIR)/libngraph_la-nconfig.Plo -rm -f ./$(DEPDIR)/libngraph_la-ngraph_api.Plo -rm -f ./$(DEPDIR)/libngraph_la-nhash.Plo -rm -f ./$(DEPDIR)/libngraph_la-nstring.Plo -rm -f ./$(DEPDIR)/libngraph_la-ntime.Plo -rm -f ./$(DEPDIR)/libngraph_la-oagrid.Plo -rm -f ./$(DEPDIR)/libngraph_la-oarc.Plo -rm -f ./$(DEPDIR)/libngraph_la-oaxis.Plo -rm -f ./$(DEPDIR)/libngraph_la-object.Plo -rm -f ./$(DEPDIR)/libngraph_la-odarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-odata.Plo -rm -f ./$(DEPDIR)/libngraph_la-odouble.Plo -rm -f ./$(DEPDIR)/libngraph_la-odraw.Plo -rm -f ./$(DEPDIR)/libngraph_la-ofit.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2fil.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2nul.Plo -rm -f ./$(DEPDIR)/libngraph_la-ogra2prn.Plo -rm -f ./$(DEPDIR)/libngraph_la-oiarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-oint.Plo -rm -f ./$(DEPDIR)/libngraph_la-oio.Plo -rm -f ./$(DEPDIR)/libngraph_la-olegend.Plo -rm -f ./$(DEPDIR)/libngraph_la-omark.Plo -rm -f ./$(DEPDIR)/libngraph_la-omath.Plo -rm -f ./$(DEPDIR)/libngraph_la-omerge.Plo -rm -f ./$(DEPDIR)/libngraph_la-opath.Plo -rm -f ./$(DEPDIR)/libngraph_la-oprm.Plo -rm -f ./$(DEPDIR)/libngraph_la-orect.Plo -rm -f ./$(DEPDIR)/libngraph_la-oregexp.Plo -rm -f ./$(DEPDIR)/libngraph_la-oroot.Plo -rm -f ./$(DEPDIR)/libngraph_la-osarray.Plo -rm -f ./$(DEPDIR)/libngraph_la-oshell.Plo -rm -f ./$(DEPDIR)/libngraph_la-ostring.Plo -rm -f ./$(DEPDIR)/libngraph_la-osystem.Plo -rm -f ./$(DEPDIR)/libngraph_la-otext.Plo -rm -f ./$(DEPDIR)/libngraph_la-shell.Plo -rm -f ./$(DEPDIR)/libngraph_la-shellcm.Plo -rm -f ./$(DEPDIR)/libngraph_la-shellux.Plo -rm -f ./$(DEPDIR)/libngraph_la-spline.Plo -rm -f ./$(DEPDIR)/libngraph_la-strconv.Plo -rm -f ./$(DEPDIR)/main.Po -rm -f ./$(DEPDIR)/terminal-terminal.Po -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-binPROGRAMS uninstall-includeHEADERS \ uninstall-libLTLIBRARIES uninstall-pkglibexecPROGRAMS .MAKE: $(am__recursive_targets) all check install install-am \ install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--depfiles check check-am clean clean-binPROGRAMS \ clean-generic clean-libLTLIBRARIES clean-libtool \ clean-pkglibexecPROGRAMS 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-includeHEADERS install-info install-info-am \ install-libLTLIBRARIES install-man install-pdf install-pdf-am \ install-pkglibexecPROGRAMS 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-binPROGRAMS uninstall-includeHEADERS \ uninstall-libLTLIBRARIES uninstall-pkglibexecPROGRAMS .PRECIOUS: Makefile @OS_WIN32_TRUE@ngraph_resource.rc: ngraph_resource.rc.in @OS_WIN32_TRUE@ $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ @OS_WIN32_TRUE@libngraph_resource.rc: libngraph_resource.rc.in @OS_WIN32_TRUE@ $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ @OS_WIN32_TRUE@.rc.o: @OS_WIN32_TRUE@ $(WINDRES) -I $(top_srcdir)/src -o $@ $< @OS_WIN32_TRUE@ngraph.def: ngraph_api.c @OS_WIN32_TRUE@ echo "EXPORTS" > $@ @OS_WIN32_TRUE@ cat $^ | grep '^ngraph_' | sed 's/[^a-z0-9_].*//' >> $@ # 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: ngraph-gtk-6.08.00/src/shellux.h0000644000175000017500000000216113070106167013275 00000000000000/* * $Id: shellux.h,v 1.1.1.1 2008-05-29 09:37:33 hito Exp $ * * This file is part of "Ngraph for X11". * * Copyright (C) 2002, Satoshi ISHIZAKA. isizaka@msa.biglobe.ne.jp * * "Ngraph for X11" 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. * * "Ngraph for X11" 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * */ int cmtrue(struct nshell *nshell,int argc,char **argv); int cmfalse(struct nshell *nshell,int argc,char **argv); int cmtest(struct nshell *nshell,int argc,char **argv); int cmsleep(struct nshell *nshell,int argc,char **argv); ngraph-gtk-6.08.00/driver/0000755000175000017500000000000013375640232012230 500000000000000ngraph-gtk-6.08.00/driver/dir_defs.h.in0000644000175000017500000000016313070106167014501 00000000000000#define DOCDIR "DOCDIRDEF" #define DATADIR "LIBDIRDEF" #define CONFDIR "CONFDIRDEF" #define HOME_DIR ".Ngraph" ngraph-gtk-6.08.00/driver/Makefile.am0000644000175000017500000000150713070106167014203 00000000000000ngraphconfdir = $(sysconfdir)/$(PACKAGE) ngraphconf_DATA = # gra2ps.ini Ngraph.ps gra2wmf.ini EXTRA_DIST = dir_defs.h.in ngp2.in ${ngraphconf_DATA} #bin_PROGRAMS = gra2ps gra2wmf bin_SCRIPTS = ngp2 # dir_defs.h: dir_defs.h.in Makefile # $(SHELL) ../pathconv.sh "$(docdir)" "$(pkgdatadir)" "$(ngraphconfdir)" dir_defs.h.in ngp2: ngp2.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/ngp2.in # gra2ps_SOURCES = gra2ps.c # nodist_gra2ps_SOURCES = dir_defs.h # gra2ps_LDADD = $(GLIB_LIBS) # gra2ps_CFLAGS = $(GLIB_CFLAGS) # gra2wmf_SOURCES = gra2wmf.c wmfapi.c wmfapi.h # nodist_gra2wmf_SOURCES = dir_defs.h # gra2wmf_LDADD = $(GLIB_LIBS) # gra2wmf_CFLAGS = $(GLIB_CFLAGS) #BUILT_SOURCES = dir_defs.h CLEANFILES = ngp2 dir_defs.h ngraph-gtk-6.08.00/driver/ngp2.in0000644000175000017500000001061313070106167013343 00000000000000#! BINDIRDEF/ngraph -i # $Id: ngp2.in,v 1.15 2010-02-18 06:38:49 hito Exp $ IGN_PATH=0 AUTO_SCALE=0 OPTION="-gra" CHDIR=0 PWD=`pwd` NULL_DEVICE=/dev/null DPI=86 clear_viewer() { for i in `derive -instance draw fit` do del ${i}:0-! done if exist -q gra:viewer then del gra:viewer fi } save_image() { new gra2cairofile name=OUTPUT new gra name=OUTPUT gra2cairofile:OUTPUT:format=$1 gra2cairofile:OUTPUT:file=$2 gra2cairofile:OUTPUT:dpi=$DPI gra:OUTPUT:device=gra2cairofile:OUTPUT if exist -q gra:viewer then cpy gra:viewer,OUTPUT draw_obj left_margin top_margin zoom paper_width paper_height fi if exist -q fit:0 then fit:0-!:display=false fi gra:OUTPUT:open gra:OUTPUT:draw gra:OUTPUT:close del gra:OUTPUT del gra2cairofile:OUTPUT } save_gra() { if [ -n "$1" ] then new gra2cairofile file=$NULL_DEVICE new gra name=DUMMY gra:DUMMY:device=gra2cairofile:0 gra:DUMMY:open new gra2file name=OUTPUT file="$1" new gra name=OUTPUT if exist -q gra:viewer then cpy gra:viewer,OUTPUT draw_obj left_margin top_margin zoom paper_width paper_height fi if exist -q fit:0 then fit:0-!:display=false fi gra:OUTPUT:device=gra2file:OUTPUT gra:OUTPUT:open gra:OUTPUT:draw gra:OUTPUT:close del gra:OUTPUT del gra2file:OUTPUT gra:DUMMY:close del gra:DUMMY del gra2cairofile fi } show_usage() { echo "ngp2 version 1.10" echo "usage: ngp2 [option] ngpfile ..." echo echo " -I ignore path" echo " -a auto scale" echo " -A clear scale and auto scale" echo " -c change directory" echo " -d dpi set dot per inch" echo echo " -ps, -ps3 output PostScript level 3" echo " -ps2 output PostScript level 2" echo " -eps, -eps3 output Encapsulated PostScript level 3" echo " -eps2 output Encapsulated PostScript level 2" echo " -pdf output Portable Document Format" echo " -svg, -svg1.1 output Scalable Vector Graphics version 1.1" echo " -svg1.2 output Scalable Vector Graphics version 1.2" echo " -png output Portable Network Graphics" echo " -h, --help show this usage" echo del system } set +e new menu while true do case "$1" in -I) IGN_PATH=1 shift ;; -a) AUTO_SCALE=1 shift ;; -A) AUTO_SCALE=2 shift ;; -c) CHDIR=1 shift ;; -d) shift DPI=$1 shift ;; -h|--help) show_usage ;; -*) OPTION="$1" shift ;; *) break ;; esac done NGP_FILES=$@ if [ -z "$NGP_FILES" ] then show_usage fi for NGP_FILE in $NGP_FILES do clear_viewer if [ -f "$NGP_FILE" ] then NGP_NAME=`basename "$NGP_FILE" .ngp` PATH_NAME=`dirname $NGP_FILE` if exist -q menu:0 then menu::fullpath_ngp="$NGP_FILE" fi case "$OPTION" in -) ;; *) echo "Drawing ${NGP_FILE}." ;; esac new shell shell::shell "$NGP_FILE" del shell if [ $IGN_PATH -ne 0 ] then for i in `object file -instances` do put file:$i file=`get file:$i -field basename` done fi if [ $CHDIR -ne 0 ] then cd $PATH_NAME fi if exist -q axis:0 then if exist -q file:0 then case "$AUTO_SCALE" in 2) axis:0-!:clear axis:0-!:auto_scale:'file:0-!' ;; 1) axis:0-!:auto_scale:'file:0-!' ;; esac fi fi TMPFILE=${system:0:temp_file} case "$OPTION" in #====================================================================== # options # # $TMPFILE : temporary file (automatically deleted). # $NGP_NAME : base name of ngp file. -ps|-ps3) save_image "ps3" $NGP_NAME.ps ;; -ps2) save_image "ps2" $NGP_NAME.ps ;; -eps|-eps3) save_image "eps3" $NGP_NAME.eps ;; -eps2) save_image "eps2" $NGP_NAME.eps ;; -pdf) save_image "pdf" $NGP_NAME.pdf ;; -svg|svg1.1) save_image "svg1.1" $NGP_NAME.svg ;; -svg1.2) save_image "svg1.2" $NGP_NAME.svg ;; -png) save_image "png" $NGP_NAME.png ;; -) save_gra $TMPFILE cat $TMPFILE ;; *) save_gra "$NGP_NAME.gra" ;; #====================================================================== esac system:0:unlink_temp_file if [ $CHDIR -ne 0 ] then cd $PWD fi fi done echo if exist -q menu:0 then del menu:0 fi del system:0 exit ngraph-gtk-6.08.00/driver/Makefile.in0000644000175000017500000004367613367273152014241 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = driver ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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)$(bindir)" "$(DESTDIR)$(ngraphconfdir)" SCRIPTS = $(bin_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 DATA = $(ngraphconf_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ ngraphconfdir = $(sysconfdir)/$(PACKAGE) ngraphconf_DATA = # gra2ps.ini Ngraph.ps gra2wmf.ini EXTRA_DIST = dir_defs.h.in ngp2.in ${ngraphconf_DATA} #bin_PROGRAMS = gra2ps gra2wmf bin_SCRIPTS = ngp2 # gra2ps_SOURCES = gra2ps.c # nodist_gra2ps_SOURCES = dir_defs.h # gra2ps_LDADD = $(GLIB_LIBS) # gra2ps_CFLAGS = $(GLIB_CFLAGS) # gra2wmf_SOURCES = gra2wmf.c wmfapi.c wmfapi.h # nodist_gra2wmf_SOURCES = dir_defs.h # gra2wmf_LDADD = $(GLIB_LIBS) # gra2wmf_CFLAGS = $(GLIB_CFLAGS) #BUILT_SOURCES = dir_defs.h CLEANFILES = ngp2 dir_defs.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) --gnu driver/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu driver/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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-binSCRIPTS: $(bin_SCRIPTS) @$(NORMAL_INSTALL) @list='$(bin_SCRIPTS)'; 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 \ 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)$(bindir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(bin_SCRIPTS)'; test -n "$(bindir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(bindir)'; $(am__uninstall_files_from_dir) mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-ngraphconfDATA: $(ngraphconf_DATA) @$(NORMAL_INSTALL) @list='$(ngraphconf_DATA)'; test -n "$(ngraphconfdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(ngraphconfdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(ngraphconfdir)" || 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)$(ngraphconfdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(ngraphconfdir)" || exit $$?; \ done uninstall-ngraphconfDATA: @$(NORMAL_UNINSTALL) @list='$(ngraphconf_DATA)'; test -n "$(ngraphconfdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(ngraphconfdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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) $(DATA) installdirs: for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(ngraphconfdir)"; 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-ngraphconfDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binSCRIPTS 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-binSCRIPTS uninstall-ngraphconfDATA .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-binSCRIPTS 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-ngraphconfDATA 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-binSCRIPTS uninstall-ngraphconfDATA .PRECIOUS: Makefile # dir_defs.h: dir_defs.h.in Makefile # $(SHELL) ../pathconv.sh "$(docdir)" "$(pkgdatadir)" "$(ngraphconfdir)" dir_defs.h.in ngp2: ngp2.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/ngp2.in # 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: ngraph-gtk-6.08.00/ABOUT-NLS0000644000175000017500000026713313070106167012114 000000000000001 Notes on the Free Translation Project *************************************** Free software is going international! The Free Translation Project is a way to get maintainers of free software, translators, and users all together, so that free software will gradually become able to speak many languages. A few packages already provide translations for their messages. If you found this `ABOUT-NLS' file inside a distribution, you may assume that the distributed package does use GNU `gettext' internally, itself available at your nearest GNU archive site. But you do _not_ need to install GNU `gettext' prior to configuring, installing or using this package with messages translated. Installers will find here some useful hints. These notes also explain how users should proceed for getting the programs to use the available translations. They tell how people wanting to contribute and work on translations can contact the appropriate team. 1.1 INSTALL Matters =================== Some packages are "localizable" when properly installed; the programs they contain can be made to speak your own native language. Most such packages use GNU `gettext'. Other packages have their own ways to internationalization, predating GNU `gettext'. By default, this package will be installed to allow translation of messages. It will automatically detect whether the system already provides the GNU `gettext' functions. Installers may use special options at configuration time for changing the default behaviour. The command: ./configure --disable-nls will _totally_ disable translation of messages. When you already have GNU `gettext' installed on your system and run configure without an option for your new package, `configure' will probably detect the previously built and installed `libintl' library and will decide to use it. If not, you may have to to use the `--with-libintl-prefix' option to tell `configure' where to look for it. Internationalized packages usually have many `po/LL.po' files, where LL gives an ISO 639 two-letter code identifying the language. Unless translations have been forbidden at `configure' time by using the `--disable-nls' switch, all available translations are installed together with the package. However, the environment variable `LINGUAS' may be set, prior to configuration, to limit the installed set. `LINGUAS' should then contain a space separated list of two-letter codes, stating which languages are allowed. 1.2 Using This Package ====================== As a user, if your language has been installed for this package, you only have to set the `LANG' environment variable to the appropriate `LL_CC' combination. If you happen to have the `LC_ALL' or some other `LC_xxx' environment variables set, you should unset them before setting `LANG', otherwise the setting of `LANG' will not have the desired effect. Here `LL' is an ISO 639 two-letter language code, and `CC' is an ISO 3166 two-letter country code. For example, let's suppose that you speak German and live in Germany. At the shell prompt, merely execute `setenv LANG de_DE' (in `csh'), `export LANG; LANG=de_DE' (in `sh') or `export LANG=de_DE' (in `bash'). This can be done from your `.login' or `.profile' file, once and for all. You might think that the country code specification is redundant. But in fact, some languages have dialects in different countries. For example, `de_AT' is used for Austria, and `pt_BR' for Brazil. The country code serves to distinguish the dialects. The locale naming convention of `LL_CC', with `LL' denoting the language and `CC' denoting the country, is the one use on systems based on GNU libc. On other systems, some variations of this scheme are used, such as `LL' or `LL_CC.ENCODING'. You can get the list of locales supported by your system for your language by running the command `locale -a | grep '^LL''. Not all programs have translations for all languages. By default, an English message is shown in place of a nonexistent translation. If you understand other languages, you can set up a priority list of languages. This is done through a different environment variable, called `LANGUAGE'. GNU `gettext' gives preference to `LANGUAGE' over `LANG' for the purpose of message handling, but you still need to have `LANG' set to the primary language; this is required by other parts of the system libraries. For example, some Swedish users who would rather read translations in German than English for when Swedish is not available, set `LANGUAGE' to `sv:de' while leaving `LANG' to `sv_SE'. Special advice for Norwegian users: The language code for Norwegian bokma*l changed from `no' to `nb' recently (in 2003). During the transition period, while some message catalogs for this language are installed under `nb' and some older ones under `no', it's recommended for Norwegian users to set `LANGUAGE' to `nb:no' so that both newer and older translations are used. In the `LANGUAGE' environment variable, but not in the `LANG' environment variable, `LL_CC' combinations can be abbreviated as `LL' to denote the language's main dialect. For example, `de' is equivalent to `de_DE' (German as spoken in Germany), and `pt' to `pt_PT' (Portuguese as spoken in Portugal) in this context. 1.3 Translating Teams ===================== For the Free Translation Project to be a success, we need interested people who like their own language and write it well, and who are also able to synergize with other translators speaking the same language. Each translation team has its own mailing list. The up-to-date list of teams can be found at the Free Translation Project's homepage, `http://translationproject.org/', in the "Teams" area. If you'd like to volunteer to _work_ at translating messages, you should become a member of the translating team for your own language. The subscribing address is _not_ the same as the list itself, it has `-request' appended. For example, speakers of Swedish can send a message to `sv-request@li.org', having this message body: subscribe Keep in mind that team members are expected to participate _actively_ in translations, or at solving translational difficulties, rather than merely lurking around. If your team does not exist yet and you want to start one, or if you are unsure about what to do or how to get started, please write to `coordinator@translationproject.org' to reach the coordinator for all translator teams. The English team is special. It works at improving and uniformizing the terminology in use. Proven linguistic skills are praised more than programming skills, here. 1.4 Available Packages ====================== Languages are not equally supported in all packages. The following matrix shows the current state of internationalization, as of June 2010. The matrix shows, in regard of each package, for which languages PO files have been submitted to translation coordination, with a translation percentage of at least 50%. Ready PO files af am an ar as ast az be be@latin bg bn_IN bs ca +--------------------------------------------------+ a2ps | [] [] | aegis | | ant-phone | | anubis | | aspell | [] [] | bash | | bfd | | bibshelf | [] | binutils | | bison | | bison-runtime | [] | bluez-pin | [] [] | bombono-dvd | | buzztard | | cflow | | clisp | | coreutils | [] [] | cpio | | cppi | | cpplib | [] | cryptsetup | | dfarc | | dialog | [] [] | dico | | diffutils | [] | dink | | doodle | | e2fsprogs | [] | enscript | [] | exif | | fetchmail | [] | findutils | [] | flex | [] | freedink | | gas | | gawk | [] [] | gcal | [] | gcc | | gettext-examples | [] [] [] [] | gettext-runtime | [] [] | gettext-tools | [] [] | gip | [] | gjay | | gliv | [] | glunarclock | [] [] | gnubiff | | gnucash | [] | gnuedu | | gnulib | | gnunet | | gnunet-gtk | | gnutls | | gold | | gpe-aerial | | gpe-beam | | gpe-bluetooth | | gpe-calendar | | gpe-clock | [] | gpe-conf | | gpe-contacts | | gpe-edit | | gpe-filemanager | | gpe-go | | gpe-login | | gpe-ownerinfo | [] | gpe-package | | gpe-sketchbook | | gpe-su | [] | gpe-taskmanager | [] | gpe-timesheet | [] | gpe-today | [] | gpe-todo | | gphoto2 | | gprof | [] | gpsdrive | | gramadoir | | grep | | grub | [] [] | gsasl | | gss | | gst-plugins-bad | [] | gst-plugins-base | [] | gst-plugins-good | [] | gst-plugins-ugly | [] | gstreamer | [] [] [] | gtick | | gtkam | [] | gtkorphan | [] | gtkspell | [] [] [] | gutenprint | | hello | [] | help2man | | hylafax | | idutils | | indent | [] [] | iso_15924 | | iso_3166 | [] [] [] [] [] [] [] | iso_3166_2 | | iso_4217 | | iso_639 | [] [] [] [] | iso_639_3 | | jwhois | | kbd | | keytouch | [] | keytouch-editor | | keytouch-keyboa... | [] | klavaro | [] | latrine | | ld | [] | leafpad | [] [] | libc | [] [] | libexif | () | libextractor | | libgnutls | | libgpewidget | | libgpg-error | | libgphoto2 | | libgphoto2_port | | libgsasl | | libiconv | [] | libidn | | lifelines | | liferea | [] [] | lilypond | | linkdr | [] | lordsawar | | lprng | | lynx | [] | m4 | | mailfromd | | mailutils | | make | | man-db | | man-db-manpages | | minicom | | mkisofs | | myserver | | nano | [] [] | opcodes | | parted | | pies | | popt | | psmisc | | pspp | [] | pwdutils | | radius | [] | recode | [] [] | rosegarden | | rpm | | rush | | sarg | | screem | | scrollkeeper | [] [] [] | sed | [] [] | sharutils | [] [] | shishi | | skencil | | solfege | | solfege-manual | | soundtracker | | sp | | sysstat | | tar | [] | texinfo | | tin | | unicode-han-tra... | | unicode-transla... | | util-linux-ng | [] | vice | | vmm | | vorbis-tools | | wastesedge | | wdiff | | wget | [] [] | wyslij-po | | xchat | [] [] [] [] | xdg-user-dirs | [] [] [] [] [] [] [] [] [] | xkeyboard-config | [] [] | +--------------------------------------------------+ af am an ar as ast az be be@latin bg bn_IN bs ca 6 0 1 2 3 19 1 10 3 28 3 1 38 crh cs da de el en en_GB en_ZA eo es et eu fa +-------------------------------------------------+ a2ps | [] [] [] [] [] [] [] | aegis | [] [] [] | ant-phone | [] () | anubis | [] [] | aspell | [] [] [] [] [] | bash | [] [] [] | bfd | [] | bibshelf | [] [] [] | binutils | [] | bison | [] [] | bison-runtime | [] [] [] [] | bluez-pin | [] [] [] [] [] [] | bombono-dvd | [] | buzztard | [] [] [] | cflow | [] [] | clisp | [] [] [] [] | coreutils | [] [] [] [] | cpio | | cppi | | cpplib | [] [] [] | cryptsetup | [] | dfarc | [] [] [] | dialog | [] [] [] [] [] | dico | | diffutils | [] [] [] [] [] [] | dink | [] [] [] | doodle | [] | e2fsprogs | [] [] [] | enscript | [] [] [] | exif | () [] [] | fetchmail | [] [] () [] [] [] | findutils | [] [] [] | flex | [] [] | freedink | [] [] [] | gas | [] | gawk | [] [] [] | gcal | [] | gcc | [] [] | gettext-examples | [] [] [] [] | gettext-runtime | [] [] [] [] | gettext-tools | [] [] [] | gip | [] [] [] [] | gjay | [] | gliv | [] [] [] | glunarclock | [] [] | gnubiff | () | gnucash | [] () () () () | gnuedu | [] [] | gnulib | [] [] | gnunet | | gnunet-gtk | [] | gnutls | [] [] | gold | [] | gpe-aerial | [] [] [] [] | gpe-beam | [] [] [] [] | gpe-bluetooth | [] [] | gpe-calendar | [] | gpe-clock | [] [] [] [] | gpe-conf | [] [] [] | gpe-contacts | [] [] [] | gpe-edit | [] [] | gpe-filemanager | [] [] [] | gpe-go | [] [] [] [] | gpe-login | [] [] | gpe-ownerinfo | [] [] [] [] | gpe-package | [] [] [] | gpe-sketchbook | [] [] [] [] | gpe-su | [] [] [] [] | gpe-taskmanager | [] [] [] [] | gpe-timesheet | [] [] [] [] | gpe-today | [] [] [] [] | gpe-todo | [] [] [] | gphoto2 | [] [] () [] [] [] | gprof | [] [] [] | gpsdrive | [] [] [] | gramadoir | [] [] [] | grep | [] | grub | [] [] | gsasl | [] | gss | | gst-plugins-bad | [] [] [] [] [] | gst-plugins-base | [] [] [] [] [] | gst-plugins-good | [] [] [] [] [] [] | gst-plugins-ugly | [] [] [] [] [] [] | gstreamer | [] [] [] [] [] | gtick | [] () [] | gtkam | [] [] () [] [] | gtkorphan | [] [] [] [] | gtkspell | [] [] [] [] [] [] [] | gutenprint | [] [] [] | hello | [] [] [] [] | help2man | [] | hylafax | [] [] | idutils | [] [] | indent | [] [] [] [] [] [] [] | iso_15924 | [] () [] [] | iso_3166 | [] [] [] [] () [] [] [] () | iso_3166_2 | () | iso_4217 | [] [] [] () [] [] | iso_639 | [] [] [] [] () [] [] | iso_639_3 | [] | jwhois | [] | kbd | [] [] [] [] [] | keytouch | [] [] | keytouch-editor | [] [] | keytouch-keyboa... | [] | klavaro | [] [] [] [] | latrine | [] () | ld | [] [] | leafpad | [] [] [] [] [] [] | libc | [] [] [] [] | libexif | [] [] () | libextractor | | libgnutls | [] | libgpewidget | [] [] | libgpg-error | [] [] | libgphoto2 | [] () | libgphoto2_port | [] () [] | libgsasl | | libiconv | [] [] [] [] [] | libidn | [] [] [] | lifelines | [] () | liferea | [] [] [] [] [] | lilypond | [] [] [] | linkdr | [] [] [] | lordsawar | [] | lprng | | lynx | [] [] [] [] | m4 | [] [] [] [] | mailfromd | | mailutils | [] | make | [] [] [] | man-db | | man-db-manpages | | minicom | [] [] [] [] | mkisofs | | myserver | | nano | [] [] [] | opcodes | [] [] | parted | [] [] | pies | | popt | [] [] [] [] [] | psmisc | [] [] [] | pspp | [] | pwdutils | [] | radius | [] | recode | [] [] [] [] [] [] | rosegarden | () () () | rpm | [] [] [] | rush | | sarg | | screem | | scrollkeeper | [] [] [] [] [] | sed | [] [] [] [] [] [] | sharutils | [] [] [] [] | shishi | | skencil | [] () [] | solfege | [] [] [] | solfege-manual | [] [] | soundtracker | [] [] [] | sp | [] | sysstat | [] [] [] | tar | [] [] [] [] | texinfo | [] [] [] | tin | [] [] | unicode-han-tra... | | unicode-transla... | | util-linux-ng | [] [] [] [] | vice | () () | vmm | [] | vorbis-tools | [] [] | wastesedge | [] | wdiff | [] [] | wget | [] [] [] | wyslij-po | | xchat | [] [] [] [] [] | xdg-user-dirs | [] [] [] [] [] [] [] [] [] | xkeyboard-config | [] [] [] [] [] [] | +-------------------------------------------------+ crh cs da de el en en_GB en_ZA eo es et eu fa 5 64 105 117 18 1 8 0 28 89 18 19 0 fi fr ga gl gu he hi hr hu hy id is it ja ka kn +----------------------------------------------------+ a2ps | [] [] [] [] | aegis | [] [] | ant-phone | [] [] | anubis | [] [] [] [] | aspell | [] [] [] [] | bash | [] [] [] [] | bfd | [] [] [] | bibshelf | [] [] [] [] [] | binutils | [] [] [] | bison | [] [] [] [] | bison-runtime | [] [] [] [] [] [] | bluez-pin | [] [] [] [] [] [] [] [] | bombono-dvd | [] | buzztard | [] | cflow | [] [] [] | clisp | [] | coreutils | [] [] [] [] [] | cpio | [] [] [] [] | cppi | [] [] | cpplib | [] [] [] | cryptsetup | [] [] [] | dfarc | [] [] [] | dialog | [] [] [] [] [] [] [] | dico | | diffutils | [] [] [] [] [] [] [] [] [] | dink | [] | doodle | [] [] | e2fsprogs | [] [] | enscript | [] [] [] [] | exif | [] [] [] [] [] [] | fetchmail | [] [] [] [] | findutils | [] [] [] [] [] [] | flex | [] [] [] | freedink | [] [] [] | gas | [] [] | gawk | [] [] [] [] () [] | gcal | [] | gcc | [] | gettext-examples | [] [] [] [] [] [] [] | gettext-runtime | [] [] [] [] [] [] | gettext-tools | [] [] [] [] | gip | [] [] [] [] [] [] | gjay | [] | gliv | [] () | glunarclock | [] [] [] [] | gnubiff | () [] () | gnucash | () () () () () [] | gnuedu | [] [] | gnulib | [] [] [] [] [] [] | gnunet | | gnunet-gtk | [] | gnutls | [] [] | gold | [] [] | gpe-aerial | [] [] [] | gpe-beam | [] [] [] [] | gpe-bluetooth | [] [] [] [] | gpe-calendar | [] [] | gpe-clock | [] [] [] [] [] | gpe-conf | [] [] [] [] | gpe-contacts | [] [] [] [] | gpe-edit | [] [] [] | gpe-filemanager | [] [] [] [] | gpe-go | [] [] [] [] [] | gpe-login | [] [] [] | gpe-ownerinfo | [] [] [] [] [] | gpe-package | [] [] [] | gpe-sketchbook | [] [] [] [] | gpe-su | [] [] [] [] [] [] | gpe-taskmanager | [] [] [] [] [] | gpe-timesheet | [] [] [] [] [] | gpe-today | [] [] [] [] [] [] [] | gpe-todo | [] [] [] | gphoto2 | [] [] [] [] [] [] | gprof | [] [] [] [] | gpsdrive | [] [] [] | gramadoir | [] [] [] | grep | [] [] | grub | [] [] [] [] | gsasl | [] [] [] [] [] | gss | [] [] [] [] [] | gst-plugins-bad | [] [] [] [] [] [] | gst-plugins-base | [] [] [] [] [] [] | gst-plugins-good | [] [] [] [] [] [] | gst-plugins-ugly | [] [] [] [] [] [] | gstreamer | [] [] [] [] [] | gtick | [] [] [] [] [] | gtkam | [] [] [] [] [] | gtkorphan | [] [] [] | gtkspell | [] [] [] [] [] [] [] [] [] | gutenprint | [] [] [] [] | hello | [] [] [] | help2man | [] [] | hylafax | [] | idutils | [] [] [] [] [] [] | indent | [] [] [] [] [] [] [] [] | iso_15924 | [] () [] [] | iso_3166 | [] () [] [] [] [] [] [] [] [] [] [] | iso_3166_2 | () [] [] [] | iso_4217 | [] () [] [] [] [] | iso_639 | [] () [] [] [] [] [] [] [] | iso_639_3 | () [] [] | jwhois | [] [] [] [] [] | kbd | [] [] | keytouch | [] [] [] [] [] [] | keytouch-editor | [] [] [] [] [] | keytouch-keyboa... | [] [] [] [] [] | klavaro | [] [] | latrine | [] [] [] | ld | [] [] [] [] | leafpad | [] [] [] [] [] [] [] () | libc | [] [] [] [] [] | libexif | [] | libextractor | | libgnutls | [] [] | libgpewidget | [] [] [] [] | libgpg-error | [] [] | libgphoto2 | [] [] [] | libgphoto2_port | [] [] [] | libgsasl | [] [] [] [] [] | libiconv | [] [] [] [] [] [] | libidn | [] [] [] [] | lifelines | () | liferea | [] [] [] [] | lilypond | [] [] | linkdr | [] [] [] [] [] | lordsawar | | lprng | [] | lynx | [] [] [] [] [] | m4 | [] [] [] [] [] [] | mailfromd | | mailutils | [] [] | make | [] [] [] [] [] [] [] [] [] | man-db | [] [] | man-db-manpages | [] | minicom | [] [] [] [] [] | mkisofs | [] [] [] [] | myserver | | nano | [] [] [] [] [] [] | opcodes | [] [] [] [] | parted | [] [] [] [] | pies | | popt | [] [] [] [] [] [] [] [] [] | psmisc | [] [] [] | pspp | | pwdutils | [] [] | radius | [] [] | recode | [] [] [] [] [] [] [] [] | rosegarden | () () () () () | rpm | [] [] | rush | | sarg | [] | screem | [] [] | scrollkeeper | [] [] [] [] | sed | [] [] [] [] [] [] [] [] | sharutils | [] [] [] [] [] [] [] | shishi | [] | skencil | [] | solfege | [] [] [] [] | solfege-manual | [] [] | soundtracker | [] [] | sp | [] () | sysstat | [] [] [] [] [] | tar | [] [] [] [] [] [] [] | texinfo | [] [] [] [] | tin | [] | unicode-han-tra... | | unicode-transla... | [] [] | util-linux-ng | [] [] [] [] [] [] | vice | () () () | vmm | [] | vorbis-tools | [] | wastesedge | () () | wdiff | [] | wget | [] [] [] [] [] [] [] [] | wyslij-po | [] [] [] | xchat | [] [] [] [] [] [] [] [] [] | xdg-user-dirs | [] [] [] [] [] [] [] [] [] [] [] [] [] | xkeyboard-config | [] [] [] [] [] | +----------------------------------------------------+ fi fr ga gl gu he hi hr hu hy id is it ja ka kn 105 121 53 20 4 8 3 5 53 2 120 5 84 67 0 4 ko ku ky lg lt lv mk ml mn mr ms mt nb nds ne +-----------------------------------------------+ a2ps | [] | aegis | | ant-phone | | anubis | [] [] | aspell | [] | bash | | bfd | | bibshelf | [] [] | binutils | | bison | [] | bison-runtime | [] [] [] [] [] | bluez-pin | [] [] [] [] [] | bombono-dvd | | buzztard | | cflow | | clisp | | coreutils | [] | cpio | | cppi | | cpplib | | cryptsetup | | dfarc | [] | dialog | [] [] [] [] [] | dico | | diffutils | [] [] | dink | | doodle | | e2fsprogs | | enscript | | exif | [] | fetchmail | | findutils | | flex | | freedink | [] | gas | | gawk | | gcal | | gcc | | gettext-examples | [] [] [] [] | gettext-runtime | [] | gettext-tools | [] | gip | [] [] | gjay | | gliv | | glunarclock | [] | gnubiff | | gnucash | () () () () | gnuedu | | gnulib | | gnunet | | gnunet-gtk | | gnutls | [] | gold | | gpe-aerial | [] | gpe-beam | [] | gpe-bluetooth | [] [] | gpe-calendar | [] | gpe-clock | [] [] [] [] [] | gpe-conf | [] [] | gpe-contacts | [] [] | gpe-edit | [] | gpe-filemanager | [] [] | gpe-go | [] [] [] | gpe-login | [] | gpe-ownerinfo | [] [] | gpe-package | [] [] | gpe-sketchbook | [] [] | gpe-su | [] [] [] [] [] [] | gpe-taskmanager | [] [] [] [] [] [] | gpe-timesheet | [] [] | gpe-today | [] [] [] [] | gpe-todo | [] [] | gphoto2 | | gprof | [] | gpsdrive | | gramadoir | | grep | | grub | | gsasl | | gss | | gst-plugins-bad | [] [] [] [] | gst-plugins-base | [] [] | gst-plugins-good | [] [] | gst-plugins-ugly | [] [] [] [] [] | gstreamer | | gtick | | gtkam | [] | gtkorphan | [] [] | gtkspell | [] [] [] [] [] [] [] | gutenprint | | hello | [] [] [] | help2man | | hylafax | | idutils | | indent | | iso_15924 | [] [] | iso_3166 | [] [] () [] [] [] [] [] | iso_3166_2 | | iso_4217 | [] [] | iso_639 | [] [] | iso_639_3 | [] | jwhois | [] | kbd | | keytouch | [] | keytouch-editor | [] | keytouch-keyboa... | [] | klavaro | [] | latrine | [] | ld | | leafpad | [] [] [] | libc | [] | libexif | | libextractor | | libgnutls | [] | libgpewidget | [] [] | libgpg-error | | libgphoto2 | | libgphoto2_port | | libgsasl | | libiconv | | libidn | | lifelines | | liferea | | lilypond | | linkdr | | lordsawar | | lprng | | lynx | | m4 | | mailfromd | | mailutils | | make | [] | man-db | | man-db-manpages | | minicom | [] | mkisofs | | myserver | | nano | [] [] | opcodes | | parted | | pies | | popt | [] [] [] | psmisc | | pspp | | pwdutils | | radius | | recode | | rosegarden | | rpm | | rush | | sarg | | screem | | scrollkeeper | [] [] | sed | | sharutils | | shishi | | skencil | | solfege | [] | solfege-manual | | soundtracker | | sp | | sysstat | [] | tar | [] | texinfo | [] | tin | | unicode-han-tra... | | unicode-transla... | | util-linux-ng | | vice | | vmm | | vorbis-tools | | wastesedge | | wdiff | | wget | [] | wyslij-po | | xchat | [] [] [] | xdg-user-dirs | [] [] [] [] [] [] [] [] | xkeyboard-config | [] [] [] | +-----------------------------------------------+ ko ku ky lg lt lv mk ml mn mr ms mt nb nds ne 20 5 10 1 13 48 4 2 2 4 24 10 20 3 1 nl nn or pa pl ps pt pt_BR ro ru rw sk sl sq sr +---------------------------------------------------+ a2ps | [] [] [] [] [] [] [] [] | aegis | [] [] [] | ant-phone | [] [] | anubis | [] [] [] | aspell | [] [] [] [] [] | bash | [] [] | bfd | [] | bibshelf | [] [] | binutils | [] [] | bison | [] [] [] | bison-runtime | [] [] [] [] [] [] [] | bluez-pin | [] [] [] [] [] [] [] [] | bombono-dvd | [] () | buzztard | [] [] | cflow | [] | clisp | [] [] | coreutils | [] [] [] [] [] [] | cpio | [] [] [] | cppi | [] | cpplib | [] | cryptsetup | [] | dfarc | [] | dialog | [] [] [] [] | dico | [] | diffutils | [] [] [] [] [] [] | dink | () | doodle | [] [] | e2fsprogs | [] [] | enscript | [] [] [] [] [] | exif | [] [] [] () [] | fetchmail | [] [] [] [] | findutils | [] [] [] [] [] | flex | [] [] [] [] [] | freedink | [] [] | gas | | gawk | [] [] [] [] | gcal | | gcc | [] | gettext-examples | [] [] [] [] [] [] [] [] | gettext-runtime | [] [] [] [] [] [] [] [] [] | gettext-tools | [] [] [] [] [] [] | gip | [] [] [] [] [] | gjay | | gliv | [] [] [] [] [] [] | glunarclock | [] [] [] [] [] | gnubiff | [] () | gnucash | [] () () () | gnuedu | [] | gnulib | [] [] [] [] | gnunet | | gnunet-gtk | | gnutls | [] [] | gold | | gpe-aerial | [] [] [] [] [] [] [] | gpe-beam | [] [] [] [] [] [] [] | gpe-bluetooth | [] [] | gpe-calendar | [] [] [] [] | gpe-clock | [] [] [] [] [] [] [] [] | gpe-conf | [] [] [] [] [] [] [] | gpe-contacts | [] [] [] [] [] | gpe-edit | [] [] [] | gpe-filemanager | [] [] [] | gpe-go | [] [] [] [] [] [] [] [] | gpe-login | [] [] | gpe-ownerinfo | [] [] [] [] [] [] [] [] | gpe-package | [] [] | gpe-sketchbook | [] [] [] [] [] [] [] | gpe-su | [] [] [] [] [] [] [] [] | gpe-taskmanager | [] [] [] [] [] [] [] [] | gpe-timesheet | [] [] [] [] [] [] [] [] | gpe-today | [] [] [] [] [] [] [] [] | gpe-todo | [] [] [] [] [] | gphoto2 | [] [] [] [] [] [] [] [] | gprof | [] [] [] | gpsdrive | [] [] | gramadoir | [] [] | grep | [] [] [] [] | grub | [] [] [] | gsasl | [] [] [] [] | gss | [] [] [] | gst-plugins-bad | [] [] [] [] [] [] | gst-plugins-base | [] [] [] [] [] | gst-plugins-good | [] [] [] [] [] | gst-plugins-ugly | [] [] [] [] [] [] | gstreamer | [] [] [] [] [] | gtick | [] [] [] | gtkam | [] [] [] [] [] [] | gtkorphan | [] | gtkspell | [] [] [] [] [] [] [] [] [] [] | gutenprint | [] [] | hello | [] [] [] [] | help2man | [] [] | hylafax | [] | idutils | [] [] [] [] [] | indent | [] [] [] [] [] [] [] | iso_15924 | [] [] [] [] | iso_3166 | [] [] [] [] [] () [] [] [] [] [] [] [] [] | iso_3166_2 | [] [] [] | iso_4217 | [] [] [] [] [] [] [] [] | iso_639 | [] [] [] [] [] [] [] [] [] | iso_639_3 | [] [] | jwhois | [] [] [] [] | kbd | [] [] [] | keytouch | [] [] [] | keytouch-editor | [] [] [] | keytouch-keyboa... | [] [] [] | klavaro | [] [] | latrine | [] [] | ld | | leafpad | [] [] [] [] [] [] [] [] [] | libc | [] [] [] [] | libexif | [] [] () [] | libextractor | | libgnutls | [] [] | libgpewidget | [] [] [] | libgpg-error | [] [] | libgphoto2 | [] [] | libgphoto2_port | [] [] [] [] [] | libgsasl | [] [] [] [] [] | libiconv | [] [] [] [] [] | libidn | [] [] | lifelines | [] [] | liferea | [] [] [] [] [] () () [] | lilypond | [] | linkdr | [] [] [] | lordsawar | | lprng | [] | lynx | [] [] [] | m4 | [] [] [] [] [] | mailfromd | [] | mailutils | [] | make | [] [] [] [] | man-db | [] [] [] | man-db-manpages | [] [] [] | minicom | [] [] [] [] | mkisofs | [] [] [] | myserver | | nano | [] [] [] [] | opcodes | [] [] | parted | [] [] [] [] | pies | [] | popt | [] [] [] [] | psmisc | [] [] [] | pspp | [] [] | pwdutils | [] | radius | [] [] [] | recode | [] [] [] [] [] [] [] [] | rosegarden | () () | rpm | [] [] [] | rush | [] [] | sarg | | screem | | scrollkeeper | [] [] [] [] [] [] [] [] | sed | [] [] [] [] [] [] [] [] [] | sharutils | [] [] [] [] | shishi | [] | skencil | [] [] | solfege | [] [] [] [] | solfege-manual | [] [] [] | soundtracker | [] | sp | | sysstat | [] [] [] [] | tar | [] [] [] [] | texinfo | [] [] [] [] | tin | [] | unicode-han-tra... | | unicode-transla... | | util-linux-ng | [] [] [] [] [] | vice | [] | vmm | [] | vorbis-tools | [] [] | wastesedge | [] | wdiff | [] [] | wget | [] [] [] [] [] [] [] | wyslij-po | [] [] [] | xchat | [] [] [] [] [] [] [] [] [] | xdg-user-dirs | [] [] [] [] [] [] [] [] [] [] [] [] [] [] | xkeyboard-config | [] [] [] | +---------------------------------------------------+ nl nn or pa pl ps pt pt_BR ro ru rw sk sl sq sr 135 10 4 7 105 1 29 62 47 91 3 54 46 9 37 sv sw ta te tg th tr uk vi wa zh_CN zh_HK zh_TW +---------------------------------------------------+ a2ps | [] [] [] [] [] | 27 aegis | [] | 9 ant-phone | [] [] [] [] | 9 anubis | [] [] [] [] | 15 aspell | [] [] [] | 20 bash | [] [] [] | 12 bfd | [] | 6 bibshelf | [] [] [] | 16 binutils | [] [] | 8 bison | [] [] | 12 bison-runtime | [] [] [] [] [] [] | 29 bluez-pin | [] [] [] [] [] [] [] [] | 37 bombono-dvd | [] | 4 buzztard | [] | 7 cflow | [] [] [] | 9 clisp | | 10 coreutils | [] [] [] [] | 22 cpio | [] [] [] [] [] [] | 13 cppi | [] [] | 5 cpplib | [] [] [] [] [] [] | 14 cryptsetup | [] [] | 7 dfarc | [] | 9 dialog | [] [] [] [] [] [] [] | 30 dico | [] | 2 diffutils | [] [] [] [] [] [] | 30 dink | | 4 doodle | [] [] | 7 e2fsprogs | [] [] [] | 11 enscript | [] [] [] [] | 17 exif | [] [] [] | 16 fetchmail | [] [] [] | 17 findutils | [] [] [] [] [] | 20 flex | [] [] [] [] | 15 freedink | [] | 10 gas | [] | 4 gawk | [] [] [] [] | 18 gcal | [] [] | 5 gcc | [] [] [] | 7 gettext-examples | [] [] [] [] [] [] [] | 34 gettext-runtime | [] [] [] [] [] [] [] | 29 gettext-tools | [] [] [] [] [] [] | 22 gip | [] [] [] [] | 22 gjay | [] | 3 gliv | [] [] [] | 14 glunarclock | [] [] [] [] [] | 19 gnubiff | [] [] | 4 gnucash | () [] () [] () | 10 gnuedu | [] [] | 7 gnulib | [] [] [] [] | 16 gnunet | [] | 1 gnunet-gtk | [] [] [] | 5 gnutls | [] [] [] | 10 gold | [] | 4 gpe-aerial | [] [] [] | 18 gpe-beam | [] [] [] | 19 gpe-bluetooth | [] [] [] | 13 gpe-calendar | [] [] [] [] | 12 gpe-clock | [] [] [] [] [] | 28 gpe-conf | [] [] [] [] | 20 gpe-contacts | [] [] [] | 17 gpe-edit | [] [] [] | 12 gpe-filemanager | [] [] [] [] | 16 gpe-go | [] [] [] [] [] | 25 gpe-login | [] [] [] | 11 gpe-ownerinfo | [] [] [] [] [] | 25 gpe-package | [] [] [] | 13 gpe-sketchbook | [] [] [] | 20 gpe-su | [] [] [] [] [] | 30 gpe-taskmanager | [] [] [] [] [] | 29 gpe-timesheet | [] [] [] [] [] | 25 gpe-today | [] [] [] [] [] [] | 30 gpe-todo | [] [] [] [] | 17 gphoto2 | [] [] [] [] [] | 24 gprof | [] [] [] | 15 gpsdrive | [] [] [] | 11 gramadoir | [] [] [] | 11 grep | [] [] [] | 10 grub | [] [] [] | 14 gsasl | [] [] [] [] | 14 gss | [] [] [] | 11 gst-plugins-bad | [] [] [] [] | 26 gst-plugins-base | [] [] [] [] [] | 24 gst-plugins-good | [] [] [] [] | 24 gst-plugins-ugly | [] [] [] [] [] | 29 gstreamer | [] [] [] [] | 22 gtick | [] [] [] | 13 gtkam | [] [] [] | 20 gtkorphan | [] [] [] | 14 gtkspell | [] [] [] [] [] [] [] [] [] | 45 gutenprint | [] | 10 hello | [] [] [] [] [] [] | 21 help2man | [] [] | 7 hylafax | [] | 5 idutils | [] [] [] [] | 17 indent | [] [] [] [] [] [] | 30 iso_15924 | () [] () [] [] | 16 iso_3166 | [] [] () [] [] () [] [] [] () | 53 iso_3166_2 | () [] () [] | 9 iso_4217 | [] () [] [] () [] [] | 26 iso_639 | [] [] [] () [] () [] [] [] [] | 38 iso_639_3 | [] () | 8 jwhois | [] [] [] [] [] | 16 kbd | [] [] [] [] [] | 15 keytouch | [] [] [] | 16 keytouch-editor | [] [] [] | 14 keytouch-keyboa... | [] [] [] | 14 klavaro | [] | 11 latrine | [] [] [] | 10 ld | [] [] [] [] | 11 leafpad | [] [] [] [] [] [] | 33 libc | [] [] [] [] [] | 21 libexif | [] () | 7 libextractor | [] | 1 libgnutls | [] [] [] | 9 libgpewidget | [] [] [] | 14 libgpg-error | [] [] [] | 9 libgphoto2 | [] [] | 8 libgphoto2_port | [] [] [] [] | 14 libgsasl | [] [] [] | 13 libiconv | [] [] [] [] | 21 libidn | () [] [] | 11 lifelines | [] | 4 liferea | [] [] [] | 21 lilypond | [] | 7 linkdr | [] [] [] [] [] | 17 lordsawar | | 1 lprng | [] | 3 lynx | [] [] [] [] | 17 m4 | [] [] [] [] | 19 mailfromd | [] [] | 3 mailutils | [] | 5 make | [] [] [] [] | 21 man-db | [] [] [] | 8 man-db-manpages | | 4 minicom | [] [] | 16 mkisofs | [] [] | 9 myserver | | 0 nano | [] [] [] [] | 21 opcodes | [] [] [] | 11 parted | [] [] [] [] [] | 15 pies | [] [] | 3 popt | [] [] [] [] [] [] | 27 psmisc | [] [] | 11 pspp | | 4 pwdutils | [] [] | 6 radius | [] [] | 9 recode | [] [] [] [] | 28 rosegarden | () | 0 rpm | [] [] [] | 11 rush | [] [] | 4 sarg | | 1 screem | [] | 3 scrollkeeper | [] [] [] [] [] | 27 sed | [] [] [] [] [] | 30 sharutils | [] [] [] [] [] | 22 shishi | [] | 3 skencil | [] [] | 7 solfege | [] [] [] [] | 16 solfege-manual | [] | 8 soundtracker | [] [] [] | 9 sp | [] | 3 sysstat | [] [] | 15 tar | [] [] [] [] [] [] | 23 texinfo | [] [] [] [] [] | 17 tin | | 4 unicode-han-tra... | | 0 unicode-transla... | | 2 util-linux-ng | [] [] [] [] | 20 vice | () () | 1 vmm | [] | 4 vorbis-tools | [] | 6 wastesedge | | 2 wdiff | [] [] | 7 wget | [] [] [] [] [] | 26 wyslij-po | [] [] | 8 xchat | [] [] [] [] [] [] | 36 xdg-user-dirs | [] [] [] [] [] [] [] [] [] [] | 63 xkeyboard-config | [] [] [] | 22 +---------------------------------------------------+ 85 teams sv sw ta te tg th tr uk vi wa zh_CN zh_HK zh_TW 178 domains 119 1 3 3 0 10 65 51 155 17 98 7 41 2618 Some counters in the preceding matrix are higher than the number of visible blocks let us expect. This is because a few extra PO files are used for implementing regional variants of languages, or language dialects. For a PO file in the matrix above to be effective, the package to which it applies should also have been internationalized and distributed as such by its maintainer. There might be an observable lag between the mere existence a PO file and its wide availability in a distribution. If June 2010 seems to be old, you may fetch a more recent copy of this `ABOUT-NLS' file on most GNU archive sites. The most up-to-date matrix with full percentage details can be found at `http://translationproject.org/extra/matrix.html'. 1.5 Using `gettext' in new packages =================================== If you are writing a freely available program and want to internationalize it you are welcome to use GNU `gettext' in your package. Of course you have to respect the GNU Library General Public License which covers the use of the GNU `gettext' library. This means in particular that even non-free programs can use `libintl' as a shared library, whereas only free software can use `libintl' as a static library or use modified versions of `libintl'. Once the sources are changed appropriately and the setup can handle the use of `gettext' the only thing missing are the translations. The Free Translation Project is also available for packages which are not developed inside the GNU project. Therefore the information given above applies also for every other Free Software Project. Contact `coordinator@translationproject.org' to make the `.pot' files available to the translation teams. ngraph-gtk-6.08.00/addin/0000755000175000017500000000000013375640232012014 500000000000000ngraph-gtk-6.08.00/addin/legend.nsc0000644000175000017500000000201213323350555013671 00000000000000# legend.nsc written by S. ISHIZAKA. 1997/12 # # This script generates a legend box. # # Please edit the following X, Y, and WIDTH variables as you like. # # Description: _Legend...,automatic legend generator, X=5000 # top-left of the legend to be inserted. Y=5000 # top-left of the legend to be inserted. WIDTH=2000 # width of "type" field. if [ `object data -instance` != 0 ] then DATALIST=${system:0:temp_file} object data -instance > "$DATALIST" get data:0-! -id -field -escape source file array id hidden x y type mark_type mark_size line_width line_style R G B R2 G2 B2 math_x math_y >> "$DATALIST" SCRIPT=${system:0:temp_file} "${NGRAPHLIB}/legend" -x ${X} -y ${Y} -w ${WIDTH} "$DATALIST" "$SCRIPT" if [ -s "$SCRIPT" ]; then new shell shell::shell "$SCRIPT" del shell gra::clear gra::draw gra::flush fi system:0:unlink_temp_file "$DATALIST" system:0:unlink_temp_file "$SCRIPT" else new dialog dialog::beep dialog::message "No data file." del dialog fi ngraph-gtk-6.08.00/addin/legend.c0000644000175000017500000005502413340172070013334 00000000000000#include #include #include #include #include #include #include #include #include #include "addin_common.h" #define NAME "Legend" #define VERSION "1.01.01" #define POS_X 50.00 #define POS_Y 50.00 #define POS_INC 1.00 #define POS_MIN -1000 #define POS_MAX 1000 #define MIX TRUE #define CAPTION TRUE #define TYPE TRUE #define FRAME TRUE #define COLUMN_CHECK 0 #define COLUMN_ID 1 #define COLUMN_CAPTION 5 enum { PLOT_SOURCE_FILE, PLOT_SOURCE_ARRAY, PLOT_SOURCE_FUNC, }; struct file_data { char *file, *array, *math_x, *math_y, *type, *caption, *style; int id, source, x, y, mark, size, width, r, g, b, r2, g2, b2, show, mix; }; struct caption_widget { GtkWidget *check, *caption, *val, *label; }; struct file_prm { GtkWidget *window, *x,*y, *width, *mix, *type, *caption, *frame, *shadow, *files; struct font_prm font; const char *script; struct file_data *data; int posx, posy, w, file_num; }; static char * escape_char(const char *src, const char *escape, const char *str) { GString *s; const char *ptr; if (src == NULL) { return g_strdup(""); } if (escape == NULL) { return g_strdup(src); } s = g_string_new(""); for (ptr = src; *ptr; ptr++) { if (strchr(escape, *ptr)) { g_string_append(s, str); } g_string_append_c(s, *ptr); } return g_string_free(s, FALSE); } static int loaddatalist(struct file_prm *prm, const char *datalist) { FILE *f; int i, j, filenum; char *hidden, *str, *file; if (datalist == NULL) { return 1; } f = g_fopen(datalist, "r"); if (f == NULL) { return 1; } filenum = fgets_int(f); if (filenum < 1) { fclose(f); return 1; } prm->data = g_malloc(sizeof(*prm->data) * filenum); prm->file_num = filenum; for (i = 0; i < filenum; i++) { str = fgets_str(f); if (g_strcmp0(str, "array") == 0) { prm->data[i].source = PLOT_SOURCE_ARRAY; } else if (g_strcmp0(str, "function") == 0) { prm->data[i].source = PLOT_SOURCE_FUNC; } else { prm->data[i].source = PLOT_SOURCE_FILE; } prm->data[i].file = fgets_str(f); prm->data[i].array = fgets_str(f); prm->data[i].id = fgets_int(f); hidden = fgets_str(f); prm->data[i].show = (g_strcmp0(hidden, "true") == 0) ? FALSE : TRUE; g_free(hidden); prm->data[i].x = fgets_int(f); prm->data[i].y = fgets_int(f); prm->data[i].type = fgets_str(f); prm->data[i].mark = fgets_int(f); prm->data[i].size = fgets_int(f); prm->data[i].width = fgets_int(f); prm->data[i].style = fgets_str(f); prm->data[i].r = fgets_int(f); prm->data[i].g = fgets_int(f); prm->data[i].b = fgets_int(f); prm->data[i].r2 = fgets_int(f); prm->data[i].g2 = fgets_int(f); prm->data[i].b2 = fgets_int(f); prm->data[i].math_x = fgets_str(f); prm->data[i].math_y = fgets_str(f); prm->data[i].mix = -1; str = NULL; file = NULL; if (prm->data[i].source == PLOT_SOURCE_ARRAY) { if (prm->data[i].array) { file = g_strdup(prm->data[i].array); str = escape_char(file, "_^@%\\", "\\"); } } else if (prm->data[i].source == PLOT_SOURCE_FUNC) { file = g_strdup_printf("X=%s; Y=%s", (prm->data[i].math_x[0]) ? prm->data[i].math_x : "X", (prm->data[i].math_y[0]) ? prm->data[i].math_y : "Y"); str = escape_char(file, "_^@%\\", "\\"); prm->data[i].type = "line"; } else { if (prm->data[i].file) { file = g_path_get_basename(prm->data[i].file); str = escape_char(file, "_^@%\\", "\\"); } } prm->data[i].caption = str; if (file) { g_free(file); } for (j = 0; j < i; j++) { if ((prm->data[i].source == prm->data[j].source) && (g_strcmp0(prm->data[i].file, prm->data[j].file) == 0) && (g_strcmp0(prm->data[i].array, prm->data[j].array) == 0) && (prm->data[i].show == prm->data[j].show) && (prm->data[i].x == prm->data[j].x) && (prm->data[i].y == prm->data[j].y) && (g_strcmp0(prm->data[i].math_x, prm->data[j].math_x) == 0) && (g_strcmp0(prm->data[i].math_y, prm->data[j].math_y) == 0)) { prm->data[i].mix = j; break; } } } fclose(f); return 0; } static void makescript(FILE *f, struct file_data *data, int gx, int gy, int width, int height) { int h; h = ceil(height * 2.0 / 3.0 / 100.0) * 100; if ((g_strcmp0(data->type, "line") == 0) || (g_strcmp0(data->type, "polygon") == 0) || (g_strcmp0(data->type, "curve") == 0) || (g_strcmp0(data->type, "diagonal") == 0) || (g_strcmp0(data->type, "staircase_x") == 0) || (g_strcmp0(data->type, "staircase_y") == 0) || (g_strcmp0(data->type, "fit") == 0)) { fprintf(f, "new path type=line\n"); fprintf(f, "path::points='%d %d %d %d'\n", gx, gy + h, gx + width, gy + h); fprintf(f, "path::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "path::style='%s'\n", data->style); } fprintf(f, "path::stroke_R=%d\n", data->r); fprintf(f, "path::stroke_G=%d\n", data->g); fprintf(f, "path::stroke_B=%d\n", data->b); } else if (g_strcmp0(data->type, "errorbar_x") == 0) { fprintf(f, "new path type=line\n"); fprintf(f, "path::points='%d %d %d %d'\n", gx + width / 4, gy + h, gx + width * 3 / 4, gy + h); fprintf(f, "path::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "path::style='%s'\n", data->style); } fprintf(f, "path::stroke_R=%d\n", data->r); fprintf(f, "path::stroke_G=%d\n", data->g); fprintf(f, "path::stroke_B=%d\n", data->b); fprintf(f, "path::marker_begin=bar\n"); fprintf(f, "path::marker_end=bar\n"); fprintf(f, "path::arrow_width=%d\n", data->size * 5000 / data->width); } else if (g_strcmp0(data->type, "errorbar_y") == 0) { fprintf(f, "new path type=line\n"); fprintf(f, "path::points='%d %d %d %d'\n", gx + width / 2, gy + h + h / 2, gx + width / 2, gy + h / 2); fprintf(f, "path::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "path::style='%s'\n", data->style); } fprintf(f, "path::stroke_R=%d\n", data->r); fprintf(f, "path::stroke_G=%d\n", data->g); fprintf(f, "path::stroke_B=%d\n", data->b); fprintf(f, "path::marker_begin=bar\n"); fprintf(f, "path::marker_end=bar\n"); fprintf(f, "path::arrow_width=%d\n", data->size * 5000 / data->width); } else if (g_strcmp0(data->type, "arrow") == 0) { fprintf(f, "new path type=line\n"); fprintf(f, "path::points='%d %d %d %d'\n", gx, gy + h, gx + width, gy + h ); fprintf(f, "path::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "path::style='%s'\n", data->style); } fprintf(f, "path::stroke_R=%d\n", data->r); fprintf(f, "path::stroke_G=%d\n", data->g); fprintf(f, "path::stroke_B=%d\n", data->b); fprintf(f, "path::marker_end=arrow\n"); } else if ((g_strcmp0(data->type, "polygon_solid_fill") == 0) || (g_strcmp0(data->type, "rectangle") == 0) || (g_strcmp0(data->type, "rectangle_fill") == 0) || (g_strcmp0(data->type, "rectangle_solid_fill") == 0) || (g_strcmp0(data->type, "bar_x") == 0) || (g_strcmp0(data->type, "bar_y") == 0) || (g_strcmp0(data->type, "bar_fill_x") == 0) || (g_strcmp0(data->type, "bar_fill_y") == 0) || (g_strcmp0(data->type, "bar_solid_fill_x") == 0) || (g_strcmp0(data->type, "bar_solid_fill_y") == 0)) { fprintf(f, "new rectangle\n"); fprintf(f, "rectangle::x1=%d\n", gx); fprintf(f, "rectangle::y1=%d\n", gy + h - height / 2); fprintf(f, "rectangle::x2=%d\n", gx + width); fprintf(f, "rectangle::y2=%d\n", gy + h + height / 2); if ((g_strcmp0(data->type, "rectangle") == 0) || (g_strcmp0(data->type, "bar_x") == 0) || (g_strcmp0(data->type, "bar_y") == 0)) { fprintf(f, "rectangle::fill=false\n"); fprintf(f, "rectangle::stroke=true\n"); fprintf(f, "rectangle::stroke_R=%d\n", data->r); fprintf(f, "rectangle::stroke_G=%d\n", data->g); fprintf(f, "rectangle::stroke_B=%d\n", data->b); } else if ((g_strcmp0(data->type, "rectangle_fill") == 0) || (g_strcmp0(data->type, "bar_fill_x") == 0) || (g_strcmp0(data->type, "bar_fill_y") == 0)) { fprintf(f, "rectangle::fill=true\n"); fprintf(f, "rectangle::stroke=true\n"); fprintf(f, "rectangle::fill_R=%d\n", data->r2); fprintf(f, "rectangle::fill_G=%d\n", data->g2); fprintf(f, "rectangle::fill_B=%d\n", data->b2); fprintf(f, "rectangle::stroke_R=%d\n", data->r); fprintf(f, "rectangle::stroke_G=%d\n", data->g); fprintf(f, "rectangle::stroke_B=%d\n", data->b); } else if ((g_strcmp0(data->type, "polygon_solid_fill") == 0) || (g_strcmp0(data->type, "rectangle_solid_fill") == 0) || (g_strcmp0(data->type, "bar_solid_fill_x") == 0) || (g_strcmp0(data->type, "bar_solid_fill_y") == 0)) {; fprintf(f, "rectangle::fill=true\n"); fprintf(f, "rectangle::stroke=false\n"); fprintf(f, "rectangle::fill_R=%d\n", data->r); fprintf(f, "rectangle::fill_G=%d\n", data->g); fprintf(f, "rectangle::fill_B=%d\n", data->b); } fprintf(f, "rectangle::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "rectangle::style='%s'\n", data->style); } } else if (g_strcmp0(data->type, "mark") == 0) { fprintf(f, "new mark\n"); fprintf(f, "mark::x=%d\n", gx + width / 2); fprintf(f, "mark::y=%d\n", gy + h); fprintf(f, "mark::size=%d\n", data->size); fprintf(f, "mark::type=%d\n", data->mark); fprintf(f, "mark::width=%d\n", data->width); if (data->style && data->style[0] != '\0') { fprintf(f, "mark::style='%s'\n", data->style); } fprintf(f, "mark::R=%d\n", data->r); fprintf(f, "mark::G=%d\n", data->g); fprintf(f, "mark::B=%d\n", data->b); fprintf(f, "mark::R2=%d\n", data->r2); fprintf(f, "mark::G2=%d\n", data->g2); fprintf(f, "mark::B2=%d\n", data->b2); } } static int savescript(struct file_prm *prm) { FILE *f; int i, j, height, len, gx, gy, posx, posy, pt, spc, script, r, g, b, style, width; gboolean type, mix, frame, shadow, caption; char *str; const char *font; if (prm->script == NULL) { return 1; } f = g_fopen(prm->script, "w"); if (f == NULL) { return 1; } type = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->type)); mix = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->mix)); frame = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->frame)); shadow = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->shadow)); caption = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->caption)); font = get_selected_font(&prm->font); get_font_parameter(&prm->font, &pt, &spc, &script, &style, &r, &g, &b); width = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->width)) * 100; height = ceil(pt * 25.4 / 72.0 / 100.0) * 100; posx = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->x)) * 100; posy = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->y)) * 100; if (frame) { fprintf(f, "new iarray name:textlen\n"); fprintf(f, "new iarray name:textbbox\n"); } len = 0; gy = posy; for (i = 0; i < prm->file_num; i++) { if (((prm->data[i].mix == -1) || (! mix )) && prm->data[i].show) { gx = posx; if (type) { makescript(f, &prm->data[i], gx, gy, width, height); if (mix) { for (j = i + 1; j < prm->file_num; j++) { if (prm->data[j].mix == i && prm->data[j].show) { makescript(f, &prm->data[j], gx, gy, width, height); } } } len = width + height / 2; } if (caption) { fprintf(f, "new text\n"); str = escape_char(prm->data[i].caption, "'", "'\"'\""); fprintf(f, "text::text='%s'\n", str); g_free(str); fprintf(f, "text::x=%d\n", gx + len); fprintf(f, "text::y=%d\n", gy + height); fprintf(f, "text::pt=%d\n", pt); fprintf(f, "text::font=%s\n", font); fprintf(f, "text::style=%d\n", style); fprintf(f, "text::space=%d\n", spc); fprintf(f, "text::script_size=%d\n", script); fprintf(f, "text::R=%d\n", r); fprintf(f, "text::G=%d\n", g); fprintf(f, "text::B=%d\n", b); if (frame) { fprintf(f, "iarray:textbbox:@=${text::bbox}\n"); fprintf(f, "iarray:textlen:push \"${iarray:textbbox:get:2}-${iarray:textbbox:get:0}\"\n"); } } gy = gy + ceil(height * 1.2 / 100.0) * 100; } } if (frame) { fprintf(f, "iarray:textlen:map 'int(X/100+0.5)*100'\n"); fprintf(f, "new rectangle\n"); fprintf(f, "rectangle::x1=%d\n", posx - height / 2); fprintf(f, "rectangle::y1=%d\n", posy - height / 4); fprintf(f, "rectangle::x2=%d+${iarray:textlen:max}\n", posx + len + height / 2); fprintf(f, "rectangle::y2=%d\n", gy + height / 4); fprintf(f, "rectangle::fill_R=255\n"); fprintf(f, "rectangle::fill_G=255\n"); fprintf(f, "rectangle::fill_B=255\n"); fprintf(f, "rectangle::stroke_R=0\n"); fprintf(f, "rectangle::stroke_G=0\n"); fprintf(f, "rectangle::stroke_B=0\n"); fprintf(f, "rectangle::fill=true\n"); fprintf(f, "rectangle::stroke=true\n"); fprintf(f, "movetop rectangle:!\n"); if (shadow) { fprintf(f, "new rectangle\n"); fprintf(f, "rectangle::x1=%d\n", posx - height / 4); fprintf(f, "rectangle::y1=%d\n", posy); fprintf(f, "rectangle::x2=%d+${iarray:textlen:max}\n", posx + len + 3 * height / 4); fprintf(f, "rectangle::y2=%d\n", gy + height / 2); fprintf(f, "rectangle::fill_R=0\n"); fprintf(f, "rectangle::fill_G=0\n"); fprintf(f, "rectangle::fill_B=0\n"); fprintf(f, "rectangle::fill=true\n"); fprintf(f, "rectangle::stroke=false\n"); fprintf(f, "movetop rectangle:!\n"); } fprintf(f, "del iarray:textlen\n"); fprintf(f, "del iarray:textbbox\n"); } fprintf(f, "menu::modified=true\n"); fclose(f); return 0; } static void frame_toggled(GtkToggleButton *togglebutton, gpointer user_data) { int state; struct file_prm *prm; prm = (struct file_prm *) user_data; state = gtk_toggle_button_get_active(togglebutton); gtk_widget_set_sensitive(GTK_WIDGET(prm->shadow), state); } static GtkWidget * create_option_frame(struct file_prm *prm) { GtkWidget *frame, *vbox, *w; frame = gtk_frame_new("option"); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_check_button_new_with_mnemonic("_Mix"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), MIX); prm->mix = w; w = gtk_check_button_new_with_mnemonic("_Type"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), TYPE); prm->type = w; w = gtk_check_button_new_with_mnemonic("_Caption"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), CAPTION); prm->caption = w; w = gtk_check_button_new_with_mnemonic("_Frame"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), FRAME); prm->frame = w; w = gtk_check_button_new_with_mnemonic("_Shadow"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), FRAME); prm->shadow = w; g_signal_connect(prm->frame, "toggled", G_CALLBACK(frame_toggled), prm); gtk_container_add(GTK_CONTAINER(frame), vbox); return frame; } static GtkWidget * create_geometry_frame(struct file_prm *prm) { GtkWidget *frame, *w, *table; int j; frame = gtk_frame_new("geometry"); table = gtk_grid_new(); j = 0; w = create_spin_button(POS_MIN, POS_MAX, POS_INC, prm->posx / 100.0, 2); add_widget_to_table_sub(table, w, "_X:", TRUE, 0, 1, j++); prm->x = w; w = create_spin_button(POS_MIN, POS_MAX, POS_INC, prm->posy / 100.0, 2); add_widget_to_table_sub(table, w, "_Y:", TRUE, 0, 1, j++); prm->y = w; w = create_spin_button(1, 100, 10, prm->w / 100.0, 2); add_widget_to_table_sub(table, w, "_Width:", TRUE, 0, 1, j++); prm->width = w; gtk_container_add(GTK_CONTAINER(frame), table); return frame; } static void set_parameter(struct file_prm *prm) { int i, mix; char *caption; GtkTreeIter iter; GtkListStore *list; list = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(prm->files))); gtk_list_store_clear(list); mix = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->mix)); for (i = 0; i < prm->file_num; i++) { if (mix && prm->data[i].mix >= 0) { continue; } gtk_list_store_append(list, &iter); if (prm->data[i].source == PLOT_SOURCE_ARRAY) { caption = g_strdup(prm->data[i].array); } else if (prm->data[i].source == PLOT_SOURCE_FUNC) { caption = g_strdup("function"); } else { caption = g_path_get_basename(prm->data[i].file); } gtk_list_store_set(list, &iter, 0, prm->data[i].show, 1, prm->data[i].id, 2, caption, 3, prm->data[i].x, 4, prm->data[i].y, 5, prm->data[i].caption, -1); g_free(caption); } } static void set_files(GtkWidget *widget, gpointer user_data) { struct file_prm *prm; prm = (struct file_prm *) user_data; set_parameter(prm); } static void caption_toggled(GtkCellRendererToggle *cell_renderer, gchar *path, gpointer user_data) { struct file_prm *prm; GtkTreeView *view; GtkTreeModel *model; GtkTreeIter iter; gboolean v; gint i; prm = (struct file_prm *) user_data; view = GTK_TREE_VIEW(prm->files); model = gtk_tree_view_get_model(view); if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, COLUMN_CHECK, &v, -1); gtk_tree_model_get(model, &iter, COLUMN_ID, &i, -1); v = !v; prm->data[i].show = v; gtk_list_store_set(GTK_LIST_STORE(model), &iter, COLUMN_CHECK, v, -1); } static void caption_edited(GtkCellRenderer *renderer, gchar *path, gchar *new_text, gpointer user_data) { struct file_prm *prm; GtkTreeModel *model; GtkTreeIter iter; GtkTreeView *view; gint i; prm = (struct file_prm *) user_data; view = GTK_TREE_VIEW(prm->files); model = gtk_tree_view_get_model(view); if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, COLUMN_ID, &i, -1); g_free(prm->data[i].caption); prm->data[i].caption = g_strdup(new_text); gtk_list_store_set(GTK_LIST_STORE(model), &iter, COLUMN_CAPTION, new_text, -1); } static GtkWidget * create_file_frame(struct file_prm *prm) { GtkListStore *list; GtkCellRenderer *renderer; GtkTreeViewColumn *col; GtkWidget *tview, *hbox, *swin, *frame; int i, n; char *title[] = {"#", "Source", "x", "y", "Caption"}; n = sizeof(title) / sizeof(*title); list = gtk_list_store_new(n + 1, G_TYPE_BOOLEAN, G_TYPE_INT, G_TYPE_STRING, G_TYPE_INT, G_TYPE_INT, G_TYPE_STRING); tview = gtk_tree_view_new_with_model(GTK_TREE_MODEL(list)); #if ! GTK_CHECK_VERSION(3, 14, 0) gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(tview), TRUE); #endif gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(tview), GTK_TREE_VIEW_GRID_LINES_VERTICAL); renderer = gtk_cell_renderer_toggle_new(); col = gtk_tree_view_column_new_with_attributes("", renderer, "active", 0, NULL); g_object_set(renderer, "mode", GTK_CELL_RENDERER_MODE_ACTIVATABLE, NULL); g_signal_connect(renderer, "toggled", G_CALLBACK(caption_toggled), prm); gtk_tree_view_append_column(GTK_TREE_VIEW(tview), col); for (i = 0; i < n; i++) { renderer = gtk_cell_renderer_text_new(); col = gtk_tree_view_column_new_with_attributes(title[i], renderer, "text", i + 1, "sensitive", 0, NULL); gtk_tree_view_append_column(GTK_TREE_VIEW(tview), col); } g_object_set(renderer, "editable", TRUE, NULL); g_signal_connect(renderer, "edited", G_CALLBACK(caption_edited), prm); swin = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); gtk_container_add(GTK_CONTAINER(swin), tview); gtk_widget_set_size_request(GTK_WIDGET(swin), -1, 300); frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), swin); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 4); prm->files = tview; return hbox; } static GtkWidget * create_control(GtkWidget *box, struct file_prm *prm) { GtkWidget *w, *hbox; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_option_frame(prm); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); w = create_geometry_frame(prm); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); w = create_font_frame(&prm->font); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(box), hbox, FALSE, FALSE, 4); w = create_file_frame(prm); gtk_box_pack_start(GTK_BOX(box), w, TRUE, TRUE, 4); return NULL; } static void create_widgets(GtkWidget *vbox, struct file_prm *prm) { GtkWidget *w; w = create_title(NAME " version " VERSION, "automatic legend generator"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); w = create_control(vbox, prm); } static const char * get_opt(int argc, char **argv, struct file_prm *prm) { int i; char *data_file = NULL; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-x") == 0) { i++; if (argv[i]) { prm->posx = atoi(argv[i]); } } else if (strcmp(argv[i], "-y") == 0) { i++; if (argv[i]) { prm->posy = atoi(argv[i]); } } else if (strcmp(argv[i], "-w") == 0) { i++; if (argv[i]) { prm->w = atoi(argv[i]); } } else if (data_file == NULL) { data_file = argv[i]; } else { prm->script = argv[i]; } } return data_file; } int main(int argc, char **argv) { GtkWidget *mainwin; gint r; struct file_prm prm; const char *data_file; setlocale(LC_ALL, ""); gtk_init(&argc, &argv); prm.posx = POS_X; prm.posy = POS_Y; data_file = get_opt(argc, argv, &prm); if (data_file == NULL) { return 0; } if (loaddatalist(&prm, data_file)) { return 0; } mainwin = gtk_dialog_new_with_buttons(NAME, NULL, 0, "_Cancel", GTK_RESPONSE_REJECT, "_Ok", GTK_RESPONSE_ACCEPT, NULL); gtk_dialog_set_default_response(GTK_DIALOG(mainwin), GTK_RESPONSE_ACCEPT); prm.window = mainwin; create_widgets(gtk_dialog_get_content_area(GTK_DIALOG(mainwin)), &prm); g_signal_connect(prm.mix, "toggled", G_CALLBACK(set_files), &prm); set_parameter(&prm); gtk_widget_show_all(mainwin); r = gtk_dialog_run(GTK_DIALOG(mainwin)); if (r == GTK_RESPONSE_ACCEPT) { savescript(&prm); } return 0; } ngraph-gtk-6.08.00/addin/addin_common.h0000644000175000017500000000160613070106167014533 00000000000000#ifndef ADDIN_COMMON_HEADER #define ADDIN_COMMON_HEADER struct font_prm { GtkWidget *font, *pt, *space, *script, *color, *bold, *italic; }; GtkWidget *create_text_entry(int set_default_action); GtkWidget *create_spin_button(double min, double max, double inc, double init, int digit); GtkWidget *add_widget_to_table_sub(GtkWidget *table, GtkWidget *w, char *title, int expand, int col, int width, int n); int warning_dialog(GtkWidget *parent, const char *msg, const char *str); char *get_text_from_entry(GtkWidget *entry); int fgets_int(FILE *fp); double fgets_double(FILE *fp); char *fgets_str(FILE *fp); GtkWidget *create_title(const char *name, const char *comment); const char *get_selected_font(struct font_prm *prm); GtkWidget *create_font_frame(struct font_prm *prm); void get_font_parameter(struct font_prm *prm, int *pt, int *spc, int *script, int *style, int *r, int *g, int *b); #endif ngraph-gtk-6.08.00/addin/fig2gra.nsc0000644000175000017500000001305613070106167013763 00000000000000set +e fig2gra_delete_obj() { del io:fig2gra del regexp:fig2gra del sarray:fig2gra del iarray:fig2gra del sarray:palette del iarray:points } fig2gra_set_color() { c=`get sarray:palette -field get:$1` if [ -n "$c" ] then io:fig2gra:puts "G,4,$c,255" fi } fig2gra_set_line_attribute () { style=${iarray:fig2gra:get:2} width=`iexpr "${iarray:fig2gra:get:3} * $COORD_CONV * 100 / 80"` len=`iexpr "${iarray:fig2gra:get:9} * $COORD_CONV * 100 / 80"` join=${iarray:fig2gra:get:10} cap=${iarray:fig2gra:get:11} case $style in 1) io:fig2gra:puts "A,7,2,$width,$cap,$join,1000,$len,$len" ;; 2) io:fig2gra:puts "A,7,2,$width,$cap,$join,1000,50,$len" ;; 3) io:fig2gra:puts "A,9,4,$width,$cap,$join,1000,$len,100,50,100" ;; 4) io:fig2gra:puts "A,11,6,$width,$cap,$join,1000,$len,100,50,100,50,100" ;; 5) io:fig2gra:puts "A,13,8,$width,$cap,$join,1000,$len,100,50,100,50,100,50,100" ;; *) io:fig2gra:puts "A,5,0,$width,$cap,$join,1000" ;; esac } fig2gra_draw_poly_line() { n=${iarray:points:num} if [ $n -lt 4 ] then return fi fill=0 if [ "${iarray:fig2gra:get:8}" != -1 ] then fill=1 fi close_path=0 if [ ${iarray:points:get:0} -eq ${iarray:points:get:-2} -a ${iarray:points:get:1} -eq ${iarray:points:get:-1} ] then iarray:points:pop iarray:points:pop n=${iarray:points:num} close_path=1 fi m=`iexpr $n/2` if [ ${iarray:fig2gra:get:1} -ne 1 -o $fill -ne 0 ] then n2=`iexpr $n+2` if [ $fill -ne 0 ] then fig2gra_set_color ${iarray:fig2gra:get:5} io:fig2gra:puts "D,$n2,$m,1,${iarray:points:join:','}" fi if [ ${iarray:fig2gra:get:3} -gt 0 ] then fig2gra_set_color ${iarray:fig2gra:get:4} fig2gra_set_line_attribute io:fig2gra:puts "D,$n2,$m,0,${iarray:points:join:','}" fi else fig2gra_set_color ${iarray:fig2gra:get:4} fig2gra_set_line_attribute if [ $close_path -ne 0 ] then io:fig2gra:puts "D,`iexpr $n+2`,$m,0,${iarray:points:join:','}" else io:fig2gra:puts "R,`iexpr $n+1`,$m,${iarray:points:join:','}" fi fi } fig2gra_init_palette() { sarray:palette:@="" sarray:palette:push "0,0,0" sarray:palette:push "0,0,255" sarray:palette:push "0,255,0" sarray:palette:push "0,255,255" sarray:palette:push "255,0,0" sarray:palette:push "255,0,255" sarray:palette:push "255,255,0" sarray:palette:push "255,255,255" sarray:palette:push "0,0,144" sarray:palette:push "0,0,176" sarray:palette:push "0,0,208" sarray:palette:push "135,206,255" sarray:palette:push "0,144,0" sarray:palette:push "0,176,0" sarray:palette:push "0,208,0" sarray:palette:push "0,144,144" sarray:palette:push "0,176,176" sarray:palette:push "0,208,208" sarray:palette:push "144,0,144" sarray:palette:push "176,0,176" sarray:palette:push "208,0,208" sarray:palette:push "128,48,0" sarray:palette:push "160,64,0" sarray:palette:push "192,96,0" sarray:palette:push "255,128,128" sarray:palette:push "255,160,160" sarray:palette:push "255,192,192" sarray:palette:push "255,224,224" sarray:palette:push "255,215,224" new int int::@=512 while int::times do sarray:palette:push "0,0,0" done del int } fig2gra_add_palette() { new string string::@=$3 r=`iexpr 0x${string::slice:"1 2"}` g=`iexpr 0x${string::slice:"3 2"}` b=`iexpr 0x${string::slice:"5 2"}` sarray:palette:put $2 "$r,$g,$b" del string } fig2gra() { new io name=fig2gra new sarray name=fig2gra new iarray name=fig2gra new regexp name=fig2gra new iarray name=points new sarray name=palette fig2gra_init_palette if [ "$1" = "-dummy" ] then shift fi io:fig2gra:mode="r" regexp:fig2gra:@='^#' io:fig2gra:open $1 while true do l=${io:fig2gra:gets} if io:fig2gra:eof then break fi if regexp:fig2gra:match:"$l" then continue fi sarray:fig2gra:push "$l" done io:fig2gra:close if [ ${sarray:fig2gra:num} -lt 9 ] then fig2gra_delete_obj return 1 fi head=${sarray:fig2gra:shift} # 0 head=${sarray:fig2gra:shift} # 1 head=${sarray:fig2gra:shift} # 2 if [ $head = "Metric" ] then COORD_CONV=1 else COORD_CONV=25.4 fi head=${sarray:fig2gra:shift} # 3 head=${sarray:fig2gra:shift} # 4 head=${sarray:fig2gra:shift} # 5 head=${sarray:fig2gra:shift} # 6 iarray:fig2gra:@=${sarray:fig2gra:shift} # 7 RESOLUTION=${iarray:fig2gra:get:0} regexp:fig2gra:@='^a\W' io:fig2gra:mode="w" io:fig2gra:open "$2" io:fig2gra:puts ${system::GRAF} io:fig2gra:puts '%Creator: fig2gra.nsc' io:fig2gra:puts "I,5,0,0,21600,27900,10000" io:fig2gra:puts "V,5,0,0,21600,27900,0" while true do a=${sarray:fig2gra:shift} if [ -z "$a" ] then break fi b="" while true do l=${sarray:fig2gra:shift} if regexp:fig2gra:match "a$l" then b="$b $l" else sarray:fig2gra:unshift "$l" break fi done iarray:fig2gra:@="$a" case ${iarray:fig2gra:get:0} in 0) # Color Pseudo-objects fig2gra_add_palette $a ;; 1) # ELLIPSE ;; 2) # POLYLINE if [ ${iarray:fig2gra:get:1} -ne 5 ] then iarray:points:@="$b" iarray:points:map "x * $COORD_CONV * 100 / $RESOLUTION" fig2gra_draw_poly_line fi ;; 3) # SPLINE ;; 4) # TEXT ;; 5) # ARC ;; 6) # COMPOUND ;; esac done io:fig2gra:puts 'E,0' io:fig2gra:close fig2gra_delete_obj return 0 } ngraph-gtk-6.08.00/addin/fitrslt.nsc0000644000175000017500000000245113070106167014126 00000000000000# fitrslt.nsc written by S. ISHIZAKA. 1999/04 # # This script generates a legend box. # # Please edit the following X, Y, and WIDTH variables as you like. # # Description: _Fit result...,insert fitting results as legend-text, X=5000 # top-left of the legend to be inserted. Y=5000 # top-left of the legend to be inserted. new iarray name=ID for i in `object data -instances` do if [ `get data:$i -field type` = "fit" ] then if [ "x${data::fit}" != "x" ] then iarray:ID:push $i fi fi done if [ ${iarray:ID:num} != 0 ] then DATALIST=${system:0:temp_file} echo ${iarray:ID:num} > "$DATALIST" for i in ${iarray:ID:@} do if [ "x`get data:$i -field fit`" != "x" ] then get data: -field id source file array >> "$DATALIST" get ${data::fit} -field id type poly_dimension user_func %00 %01 %02 %03 %04 %05 %06 %07 %08 %09 >> "$DATALIST" fi done SCRIPT=${system:0:temp_file} "${NGRAPHLIB}/fitrslt" -x ${X} -y ${Y} "$DATALIST" "$SCRIPT" if [ -s "$SCRIPT" ]; then new shell shell::shell "$SCRIPT" del shell gra::clear gra::draw gra::flush fi system:0:unlink_temp_file "$SCRIPT" system:0:unlink_temp_file "$DATALIST" else new dialog dialog::beep dialog::message "No fitting data." del dialog fi del iarray:ID ngraph-gtk-6.08.00/addin/addin_common.c0000644000175000017500000001333313070106167014526 00000000000000#include #include #include #include #include #include "addin_common.h" #define LINE_BUF_SIZE 1024 #define FONT_PT 20.00 #define FONT_SCRIPT 70.00 #define FONT_SPACE 0.00 static char *FontList[] = {"Serif", "Sans-serif", "Monospace"}; GtkWidget * create_text_entry(int set_default_action) { GtkWidget *w; w = gtk_entry_new(); if (set_default_action) { gtk_entry_set_activates_default(GTK_ENTRY(w), TRUE); } return w; } GtkWidget * create_spin_button(double min, double max, double inc, double init, int digit) { GtkWidget *w; w = gtk_spin_button_new_with_range(min, max, inc); gtk_entry_set_alignment(GTK_ENTRY(w), 1.0); gtk_spin_button_set_value(GTK_SPIN_BUTTON(w), init); if (digit > 0) { gtk_spin_button_set_digits(GTK_SPIN_BUTTON(w), digit); } return w; } GtkWidget * add_widget_to_table_sub(GtkWidget *table, GtkWidget *w, char *title, int expand, int col, int width, int n) { GtkWidget *label; label = NULL; if (title) { label = gtk_label_new_with_mnemonic(title); gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); gtk_widget_set_halign(label, GTK_ALIGN_START); g_object_set(label, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), label, col, n, 1, 1); col++; } if (w) { if (expand) { gtk_widget_set_hexpand(w, TRUE); gtk_widget_set_halign(w, GTK_ALIGN_FILL); } else { gtk_widget_set_halign(w, GTK_ALIGN_START); } g_object_set(w, "margin", GINT_TO_POINTER(4), NULL); gtk_grid_attach(GTK_GRID(table), w, col, n, width, 1); } return label; } int warning_dialog(GtkWidget *parent, const char *msg, const char *str) { GtkWidget *dlg; int r; dlg = gtk_message_dialog_new(GTK_WINDOW(parent), GTK_DIALOG_MODAL, GTK_MESSAGE_WARNING,GTK_BUTTONS_YES_NO, msg, str); r = gtk_dialog_run(GTK_DIALOG(dlg)); gtk_widget_destroy(dlg); return r; } char * get_text_from_entry(GtkWidget *entry) { const char *tmp; tmp = gtk_entry_get_text(GTK_ENTRY(entry)); if (tmp == NULL) { tmp = ""; } return g_strdup(tmp); } GtkWidget * create_title(const char *name, const char *comment) { GtkWidget *frame, *label; frame = gtk_frame_new(name); gtk_frame_set_shadow_type(GTK_FRAME(frame), GTK_SHADOW_IN); g_object_set(frame, "margin", GINT_TO_POINTER(4), NULL); g_object_set(frame, "border-width", GINT_TO_POINTER(4), NULL); gtk_frame_set_label_align(GTK_FRAME(frame), 0.5, 0.5); label = gtk_label_new(comment); g_object_set(label, "margin", GINT_TO_POINTER(4), NULL); gtk_widget_set_halign(label, GTK_ALIGN_CENTER); gtk_widget_set_valign(label, GTK_ALIGN_CENTER); gtk_container_add(GTK_CONTAINER(frame), label); return frame; } const char * get_selected_font(struct font_prm *prm) { int font, i; i = gtk_combo_box_get_active(GTK_COMBO_BOX(prm->font)); font = (i >= 1 && i < (int) (sizeof(FontList) / sizeof(*FontList))) ? i : 0; return FontList[font]; } void get_font_parameter(struct font_prm *prm, int *pt, int *spc, int *script, int *style, int *r, int *g, int *b) { int bold, italic; GdkRGBA color; *pt = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->pt)) * 100; *script = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->script)) * 100; *spc = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->space)) * 100; bold = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->bold)); italic = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->italic)); *style = (bold ? 1 : 0) + (italic ? 2 : 0); gtk_color_chooser_get_rgba(GTK_COLOR_CHOOSER(prm->color), &color); *r = color.red * 255; *g = color.green * 255; *b = color.blue * 255; } GtkWidget * create_font_frame(struct font_prm *prm) { GtkWidget *frame, *w, *table, *hbox, *vbox; unsigned int j, i; frame = gtk_frame_new("font"); table = gtk_grid_new(); j = 0; w = gtk_combo_box_text_new(); for (i = 0; i < sizeof(FontList) / sizeof(*FontList); i++) { gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(w), FontList[i]); } gtk_combo_box_set_active(GTK_COMBO_BOX(w), 1); add_widget_to_table_sub(table, w, "_Font:", TRUE, 0, 1, j++); prm->font = w; w = create_spin_button(6, 100, 1, FONT_PT, 2); add_widget_to_table_sub(table, w, "_Pt:", TRUE, 0, 1, j++); prm->pt = w; w = create_spin_button(0, 100, 1, FONT_SPACE, 2); add_widget_to_table_sub(table, w, "_Space:", TRUE, 0, 1, j++); prm->space = w; w = create_spin_button(10, 100, 10, FONT_SCRIPT, 2); add_widget_to_table_sub(table, w, "_Script:", TRUE, 0, 1, j++); prm->script = w; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(hbox), table, TRUE, TRUE, 4); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_check_button_new_with_mnemonic("_Bold"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); prm->bold = w; w = gtk_check_button_new_with_mnemonic("_Italic"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); prm->italic = w; w = gtk_color_button_new(); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 4); prm->color = w; gtk_box_pack_start(GTK_BOX(hbox), vbox, FALSE, FALSE, 4); gtk_container_add(GTK_CONTAINER(frame), hbox); return frame; } int fgets_int(FILE *fp) { char buf[LINE_BUF_SIZE], *r; int val; r = fgets(buf, sizeof(buf), fp); if (r == NULL) { return 0; } val = atoi(buf); return val; } double fgets_double(FILE *fp) { char buf[LINE_BUF_SIZE], *r; double val; r = fgets(buf, sizeof(buf), fp); if (r == NULL) { return 0; } val = atof(buf); return val; } char * fgets_str(FILE *fp) { char buf[LINE_BUF_SIZE], *r; char *str; r = fgets(buf, sizeof(buf), fp); if (r == NULL) { return NULL; } g_strchomp(buf); str = g_strdup(buf); return str; } ngraph-gtk-6.08.00/addin/gimg2gra.c0000644000175000017500000002502113223663676013610 00000000000000/************************************************************************** gimg2gra Version 0.00 Copyright (C) H.Ito 2002 **************************************************************************/ #include #include #include #include #include #include #include #define PRGNAME "gimg2gra" #define VERSION "0.0.0" #define WIDTH 0 #define HEIGHT 1 #define DPI_MAX 2540 struct AppData { GdkPixbuf *im; gchar *gra; GtkWidget *entry; gint dpi; }; struct Color { int r, g, b, a; }; static struct Color BGCOLOR = {255, 255, 255, 255}; static int DotSize = 36; struct rectangle{ unsigned char r, g, b, a; int x1, y1, x2, y2; }; static GtkWidget *App = NULL; static GtkWidget *create_widgets(struct AppData *app_data, const gchar *img_file); static void print_error_exit(const gchar *error); static void set_bgcolor(int r, int g, int b, int a, struct AppData *data); static void create_entry(GdkPixbuf *im, GtkWidget *hbox, struct AppData *data); static void create_buttons(struct AppData *data, GtkWidget *hbox); static gboolean delete_event(GtkWidget *widget, GdkEvent *event, gpointer data); static gboolean button_press_event(GtkWidget *widget, GdkEventButton *event, gpointer data); static void save_button_clicked(GtkButton *widget, gpointer data); static void cancel_button_clicked(GtkButton *widget, gpointer data); static int rectcmp(const void *tmpa, const void *tmpb); static void fputcolor(FILE *fp, struct Color *color); static int colorcmp(struct Color *a, struct Color *b); static int gra_set_dpi(int dpi); static void gra_set_bgcolor(gint r, gint g, gint b, gint a); static int gra_save(GdkPixbuf *im, char *gra_file); int main(int argc, char *argv[]) { static gchar *img_file = NULL, *gra_file = NULL; static char *usage = "Usage: %s resolution image_file gra_file\n"; struct AppData app_data; gtk_init(&argc, &argv); if (argc != 4) { gchar *error; error = g_strdup_printf(usage, g_path_get_basename(argv[0])); print_error_exit(error); } gra_file = argv[3]; img_file = argv[2]; app_data.dpi = atoi(argv[1]); if(gra_file == NULL) { gra_file = g_strconcat(g_path_get_basename(img_file), ".gra", NULL); } app_data.gra = gra_file; App = create_widgets(&app_data, img_file); gtk_main(); return 0; } static GtkWidget * create_widgets(struct AppData *app_data, const gchar *img_file) { GtkWidget *w, *vbox, *hbox, *event_box, *scrolled_window, *app; GdkPixbuf *pixbuf; GError *error; app_data->entry = NULL; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); error = NULL; pixbuf = gdk_pixbuf_new_from_file(img_file, &error); if (pixbuf == NULL) { print_error_exit(error->message); } w = gtk_image_new_from_pixbuf(pixbuf); app_data->im = gtk_image_get_pixbuf(GTK_IMAGE(w)); event_box = gtk_event_box_new(); gtk_container_add(GTK_CONTAINER(event_box), w); g_signal_connect(event_box, "button-press-event", G_CALLBACK(button_press_event), app_data); scrolled_window = gtk_scrolled_window_new(NULL, NULL); gtk_widget_set_size_request(scrolled_window, 800, 600); gtk_container_add(GTK_CONTAINER(scrolled_window), event_box); gtk_box_pack_start(GTK_BOX(vbox), scrolled_window, TRUE, TRUE, 0); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 5); create_buttons(app_data, hbox); app = gtk_window_new(GTK_WINDOW_TOPLEVEL); g_signal_connect(app, "delete-event", G_CALLBACK(delete_event), NULL); gtk_container_add(GTK_CONTAINER(app), vbox); gtk_widget_show_all(app); return app; } static void print_error_exit(const gchar *error) { GtkWidget *dialog; dialog = gtk_message_dialog_new(GTK_WINDOW(App), GTK_DIALOG_DESTROY_WITH_PARENT, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, "Error loading file %s", error); gtk_dialog_run(GTK_DIALOG(dialog)); gtk_widget_destroy(dialog); exit(1); } static void create_buttons(struct AppData *data, GtkWidget *box) { GtkWidget *w, *vbox, *hbox; GdkPixbuf *im; vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 0); im = data->im; create_entry(im, vbox, data); gtk_box_pack_start(GTK_BOX(box), vbox, FALSE, FALSE, 10); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); w = gtk_button_new_with_label(" OK "); g_signal_connect(w, "clicked", G_CALLBACK(save_button_clicked), data); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 5); w = gtk_button_new_with_label(" Cancel "); g_signal_connect(w, "clicked", G_CALLBACK(cancel_button_clicked), NULL); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 5); gtk_box_pack_start(GTK_BOX(box), hbox, FALSE, FALSE, 5); } static void create_entry(GdkPixbuf *im, GtkWidget *box, struct AppData *data) { GtkWidget *w, *hbox, *entry = NULL; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 0); w = gtk_label_new("BGCOLOR:"); gtk_box_pack_start(GTK_BOX(hbox), w, FALSE, FALSE, 0); entry = gtk_entry_new(); gtk_entry_set_max_length(GTK_ENTRY(entry), 10); gtk_editable_set_editable(GTK_EDITABLE(entry), FALSE); gtk_box_pack_start(GTK_BOX(hbox), entry, FALSE, FALSE, 0); data->entry = entry; set_bgcolor(255, 255, 255, 255, data); gtk_box_pack_start(GTK_BOX(box), hbox, FALSE, FALSE, 0); } static void set_bgcolor(int r, int g, int b, int a, struct AppData *data) { static char bgcolor[64]; gra_set_bgcolor(r, g, b, a); sprintf(bgcolor, "#%02x%02x%02x%02x", r, g, b, a); if(data->entry != NULL) { gtk_entry_set_text(GTK_ENTRY(data->entry), bgcolor); } } /************* Event Handler **************/ static gboolean delete_event(GtkWidget *widget, GdkEvent *event, gpointer data) { gtk_main_quit(); return TRUE; } static gboolean button_press_event(GtkWidget *widget, GdkEventButton *event, gpointer data) { struct AppData *app_data = (struct AppData *) data; GdkPixbuf *im; int i, x = event->x, y = event->y, w, h, r, g, b, a, rowstride, alpha, bpp; guchar *pixels; im = app_data->im; w = gdk_pixbuf_get_width(im); h = gdk_pixbuf_get_height(im); rowstride = gdk_pixbuf_get_rowstride(im); pixels = gdk_pixbuf_get_pixels(im); alpha = gdk_pixbuf_get_has_alpha(im); bpp = rowstride / w; if(x >= w || y >= h) return TRUE; i = y * rowstride + x * bpp; switch(event->button){ case 1: r = pixels[i]; g = pixels[i + 1]; b = pixels[i + 2]; a = (alpha) ? pixels[i + 3] : 255; set_bgcolor(r, g, b, a, app_data); break; } return TRUE; } static void save_button_clicked(GtkButton *widget, gpointer data) { struct AppData *app_data = (struct AppData *) data; GdkPixbuf *im; gchar *grafile; int dotsize, w, h; im = app_data->im; grafile = app_data->gra; w = gdk_pixbuf_get_width(im); h = gdk_pixbuf_get_height(im); dotsize = gra_set_dpi(app_data->dpi); gra_save(im, grafile); printf("%d %d\n", w * dotsize, h * dotsize); gtk_main_quit(); } static void cancel_button_clicked(GtkButton *widget, gpointer data) { gtk_main_quit(); } static void gra_set_bgcolor(gint r, gint g, gint b, gint a) { if(r >= 0 && r < 256 && g >= 0 && g < 256 && b >= 0 && b < 256 && a >= 0 && a < 256){ BGCOLOR.r = r; BGCOLOR.g = g; BGCOLOR.b = b; BGCOLOR.a = a; } } static int gra_set_dpi(int dpi) { if(dpi > 0 && dpi<= DPI_MAX) { DotSize = DPI_MAX / dpi; } return DotSize; } static int gra_save(GdkPixbuf *im, char *gra_file) { gint w, h, x, x1, y, i, j, rowstride, alpha, bpp, offset; struct Color shape_color, color, color2; struct rectangle *rect; FILE *fp; guchar *pixels; if(im == NULL) return 1; w = gdk_pixbuf_get_width(im); h = gdk_pixbuf_get_height(im); if(INT_MAX / sizeof(*rect) / w / h < 1 || INT_MAX / w / DotSize < 1 || INT_MAX / h / DotSize < 1){ gchar *error; error = g_strdup_printf("Too large image.\n"); print_error_exit(error); } rect = g_malloc(sizeof(*rect) * w * h); if(gra_file == NULL){ fp = stdout; }else if((fp = fopen(gra_file, "wt")) == NULL){ print_error_exit(g_strerror(errno)); } fprintf(fp, "%%Ngraph GRAF\n" "%%Creator: %s\n" "I,5,0,0,%d,%d,10000\n" "V,5,0,0,%d,%d,1\n" "A,5,0,1,0,0,1000\n", (PRGNAME) ? PRGNAME : "", w * DotSize, h * DotSize, w * DotSize, h * DotSize); rowstride = gdk_pixbuf_get_rowstride(im); pixels = gdk_pixbuf_get_pixels(im); alpha = gdk_pixbuf_get_has_alpha(im); bpp = rowstride / w; shape_color = BGCOLOR; color = BGCOLOR; fputcolor(fp, &BGCOLOR); fprintf(fp, "B,5,0,0,%d,%d,1\n", w * DotSize, h * DotSize); j = 0; for(y = 0; y < h; y++){ offset = y * rowstride; for(x = x1 = 0; x < w; x++, offset += bpp){ color2.r = pixels[offset]; color2.g = pixels[offset + 1]; color2.b = pixels[offset + 2]; color2.a = (alpha) ? pixels[offset + 3] : 255; if(colorcmp(&color2, &color)){ if(x != 0 && colorcmp(&shape_color, &color)){ rect[j].r = color.r; rect[j].g = color.g; rect[j].b = color.b; rect[j].a = color.a; rect[j].x1 = x1 * DotSize; rect[j].y1 = y * DotSize; rect[j].x2 = x * DotSize; rect[j].y2 = (y + 1) * DotSize; j++; } color = color2; x1 = x; } if(x == w - 1 && colorcmp(&shape_color, &color)){ rect[j].r = color.r; rect[j].g = color.g; rect[j].b = color.b; rect[j].a = color.a; rect[j].x1 = x1 * DotSize; rect[j].y1 = y * DotSize; rect[j].x2 = (x + 1) * DotSize; rect[j].y2 = (y + 1) * DotSize; j++; } } } qsort(rect, j, sizeof(*rect), rectcmp); color.r = rect[0].r; color.g = rect[0].g; color.b = rect[0].b; color.a = rect[0].a; fputcolor(fp, &color); for(i = 0; i < j; i++){ color2.r = rect[i].r; color2.g = rect[i].g; color2.b = rect[i].b; color2.a = rect[i].a; if(colorcmp(&color2, &color)){ fputcolor(fp, &color2); color = color2; } if (color2.a > 0) { fprintf(fp, "B,5,%d,%d,%d,%d,1\n", rect[i].x1, rect[i].y1, rect[i].x2, rect[i].y2); } } fprintf(fp, "E,0\n"); if(ferror(fp)){ print_error_exit(g_strerror(errno)); } if(fp != stdout) { fclose(fp); } g_free(rect); return 0; } static int colorcmp(struct Color *a, struct Color *b) { return ! (a->r == b->r && a->g == b->g && a->b == b->b && a->a == b->a); } static int rectcmp(const void *tmpa, const void *tmpb) { struct rectangle *a = (struct rectangle *)tmpa, *b = (struct rectangle *)tmpb; int c, d; c = (((int)a->r)<<16) + (((int)a->g)<<8) + a->b; d = (((int)b->r)<<16) + (((int)b->g)<<8) + b->b; return d - c; } static void fputcolor(FILE *fp, struct Color *color) { if (color->a > 0) { fprintf(fp, "G,4,%d,%d,%d,%d\n", color->r, color->g, color->b, color->a); } } ngraph-gtk-6.08.00/addin/cal.nsc0000644000175000017500000000077513351432266013211 00000000000000# Description: _Calendar,show calendar in the information window, new regexp regexp::@="(?i)UTF-?8" if regexp::match "$LANG" then LOCALE=$LANG else LOCALE=C fi del regexp DATE=`date +%m` set +e new dialog dialog::title="Calendar" dialog::caption="select MONTH" DATE=`get dialog: -field integer_entry:"1 12 1 $DATE"` RVAL=$? del dialog set -e if [ $RVAL != 0 ] then exit fi YEAR=`date +%Y` MONTH=`iexpr $DATE` menu::echo LANG=$LOCALE /usr/bin/ncal -3Mbh $MONTH $YEAR | menu::cat menu::echo ngraph-gtk-6.08.00/addin/text-in.nsc0000644000175000017500000000430313070106167014025 00000000000000# text-in.nsc written by S. ISHIZAKA. 1997/12 # # This script inserts a column as legend-text. # # Description: _Text in...,inserts a column as legend-text, SHIFTX=0 # ammount of the shift from plotted data-points. SHIFTY=0 # ammount of the shift from plotted data-points. PT=2000 # Size FONT=Sans-serif # Font DIR=0 # Direction if [ `object data -instance` = 0 ] then new dialog dialog::beep dialog::message "No data file." del dialog exit fi new dialog new sarray name=FILES for i in `object data -instances` do if [ `get data:$i -field source` != "function"] then sarray:FILES:push `get data:$i -field id file` fi done dialog::title="select data" dialog::caption="select data object" FILE_OBJ=${dialog::combo:"sarray:FILES"} del sarray:FILES if [ -z "$FILE_OBJ" ] then del dialog exit fi set $FILE_OBJ ID=$1 dialog::title="$FILE_OBJ" dialog::caption='Input legend-text column' COLUMN=${dialog::integer_entry:'0 1000 1 1'} if [ -z "$COLUMN" ] then del dialog exit fi dialog::caption='select horizontal position of the text' ALIGN=${dialog::radio:'_Left _Center _Right'} if [ -z "$ALIGN" ] then del dialog exit fi dialog::title="$FILE_OBJ" dialog::caption='Input vertical offset (mm)' OFFSET=${dialog::integer_entry:'-50 50 1 0'} if [ -z "$OFFSET" ] then del dialog exit fi del dialog new iarray name=BBOX new int name=NAME @=0 exe data:$ID opendatac while data::getdata do int:NAME:inc TEXT_NAME=in_${ID}_${int:NAME:@} if exist -q text:$TEXT_NAME then put text:$TEXT_NAME name:$TEXT_NAME # to set text:$TEXT_NAME as a current instance else new text name=$TEXT_NAME text::pt=$PT text::R=${data::R} text::G=${data::G} text::B=${data::B} text::font=$FONT text::direction=$DIR fi text::x=0 text::y=0 text::text=`get data:$ID -field column:"${data::line} ${COLUMN}"` iarray:BBOX:@="${text::bbox}" text::x="${data::coord_x}+$SHIFTX-ABS(${iarray:BBOX:get:2}-${iarray:BBOX:get:0})/2*(2-$ALIGN)" text::y="${data::coord_y}+$SHIFTY+ABS(${iarray:BBOX:get:3}-${iarray:BBOX:get:1})/2-${iarray:BBOX:get:3}+$OFFSET*100" done menu::modified=true data::closedata del int:NAME del iarray:BBOX ngraph-gtk-6.08.00/addin/ruby.nsc0000644000175000017500000000003513070106167013414 00000000000000system:0:plugin_exec ruby $* ngraph-gtk-6.08.00/addin/fitrslt.c0000644000175000017500000004310513327053133013565 00000000000000#include #include #include #include #include #include #include #include #include #include "addin_common.h" #define NAME "Fitrslt" #define VERSION "1.00.03" #define POS_X 50.00 #define POS_Y 50.00 #define POS_INC 1.00 #define POS_MIN -1000 #define POS_MAX 1000 #define ACCURACY 7 #define DIVISION 100 #define ADD_PLUS FALSE #define EXPAND TRUE #define FRAME TRUE #define LINE_BUF_SIZE 8 #define PRM_NUM 10 enum { COLUMN_CHECK, COLUMN_PRM, COLUMN_CAPTION, COLUMN_VAL, }; struct fit_data { int file_id; char *file; int id; char *type; int poly; char *userfunc; double prm[PRM_NUM]; }; struct caption_widget { GtkWidget *check, *caption, *val, *label; }; struct fit_prm { GtkWidget *window, *x,*y, *add_plus, *accuracy, *expand, *frame, *shadow, *combo; struct font_prm font; GtkWidget *caption; const char *script; struct fit_data *data; int posx, posy, fit_num; }; static int loaddatalist(struct fit_prm *prm, const char *datalist) { FILE *f; int i, j, fitnum; char *source, *file, *array; if (datalist == NULL) { return 1; } f = g_fopen(datalist, "r"); if (f == NULL) { return 1; } fitnum = fgets_int(f); if (fitnum < 1) { fclose(f); return 1; } prm->data = g_malloc(sizeof(*prm->data) * fitnum); prm->fit_num = fitnum; for (i = 0; i < fitnum; i++) { prm->data[i].file_id = fgets_int(f); source = fgets_str(f); file = fgets_str(f); array = fgets_str(f); prm->data[i].id = fgets_int(f); prm->data[i].type = fgets_str(f); prm->data[i].poly = fgets_int(f); prm->data[i].userfunc = fgets_str(f); for (j = 0; j < PRM_NUM; j++) { prm->data[i].prm[j] = fgets_double(f); } if (g_strcmp0(source, "array") == 0) { prm->data[i].file = array; } else { prm->data[i].file = file; } } fclose(f); return 0; } static void makescript(FILE *f, struct fit_prm *prm, int gx, int gy, int height, const char *cap, const char *val) { int style, textpt, textspc, textsc, textred, textblue, textgreen, frame; const char *font; get_font_parameter(&prm->font, &textpt, &textspc, &textsc, &style, &textred, &textblue, &textgreen); font = get_selected_font(&prm->font); frame = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->frame)); fprintf(f, "new text\n"); fprintf(f, "text::text='%s %s'\n", cap, val); fprintf(f, "text::x=%d\n", gx); fprintf(f, "text::y=%d\n", gy + height); fprintf(f, "text::pt=%d\n", textpt); fprintf(f, "text::font=%s\n", font); fprintf(f, "text::style=%d\n", style); fprintf(f, "text::space=%d\n", textspc); fprintf(f, "text::script_size=%d\n", textsc); fprintf(f, "text::R=%d\n", textred); fprintf(f, "text::G=%d\n", textgreen); fprintf(f, "text::B=%d\n", textblue); if (frame) { fprintf(f, "iarray:textbbox:@=${text::bbox}\n"); fprintf(f, "iarray:textlen:push \"${iarray:textbbox:get:2}-${iarray:textbbox:get:0}\"\n"); } fprintf(f, "menu::modified=true\n"); } static int savescript(struct fit_prm *prm) { char *cap, *val; FILE *f; int frame, shadow, height, textpt, gx, gy, posx, posy, h_inc, i, draw; GtkTreeModel *model; GtkTreeIter iter; if (prm->script == NULL) { return 0; } f = g_fopen(prm->script, "w"); posx = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->x)) * 100; posy = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->y)) * 100; frame = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->frame)); if (frame) { fprintf(f, "new iarray name:textlen\n"); fprintf(f, "new iarray name:textbbox\n"); } shadow = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->shadow)); textpt = gtk_spin_button_get_value(GTK_SPIN_BUTTON(prm->font.pt)) * 100; height = ceil(textpt * 25.4 / 72.0 / 100) * 100; gy = posy; h_inc = ceil(height * 1.2 / 100) * 100; model = gtk_tree_view_get_model(GTK_TREE_VIEW(prm->caption)); if (! gtk_tree_model_get_iter_first(model, &iter)) { return 1; } for (i = 0; i < PRM_NUM; i++) { gtk_tree_model_get(model, &iter, COLUMN_CHECK, &draw, COLUMN_CAPTION, &cap, COLUMN_VAL, &val, -1); if (draw) { gx = posx; makescript(f, prm, gx, gy, height, cap, val); gy += h_inc; } g_free(cap); g_free(val); if (! gtk_tree_model_iter_next(model, &iter)) { break; } } if (frame) { fprintf(f, "iarray:textlen:map 'int(X/100+0.5)*100'\n"); if (shadow) { fprintf(f, "new rectangle\n"); fprintf(f, "rectangle::x1=%d\n", posx - height / 4); fprintf(f, "rectangle::y1=%d\n", posy); fprintf(f, "rectangle::x2=%d+${iarray:textlen:max}\n", posx + 3 * height / 4); fprintf(f, "rectangle::y2=%d\n", gy + height / 2); fprintf(f, "rectangle::fill_R=0\n"); fprintf(f, "rectangle::fill_G=0\n"); fprintf(f, "rectangle::fill_B=0\n"); fprintf(f, "rectangle::fill=true\n"); } fprintf(f, "new rectangle\n"); fprintf(f, "rectangle::x1=%d\n", posx - height / 2); fprintf(f, "rectangle::y1=%d\n", posy - height / 4); fprintf(f, "rectangle::x2=%d+${iarray:textlen:max}\n", posx + height / 2); fprintf(f, "rectangle::y2=%d\n", gy + height / 4); fprintf(f, "rectangle::fill_R=255\n"); fprintf(f, "rectangle::fill_G=255\n"); fprintf(f, "rectangle::fill_B=255\n"); fprintf(f, "rectangle::stroke_R=0\n"); fprintf(f, "rectangle::stroke_G=0\n"); fprintf(f, "rectangle::stroke_B=0\n"); fprintf(f, "rectangle::fill=true\n"); fprintf(f, "rectangle::stroke=true\n"); fprintf(f, "del iarray:textlen\n"); fprintf(f, "del iarray:textbbox\n"); } fclose(f); return 0; } static GtkWidget * my_create_spin_button(const char *title, double min, double max, double inc, double init, GtkWidget **hbox) { GtkWidget *w, *label; *hbox = gtk_grid_new(); gtk_widget_set_hexpand(*hbox, FALSE); label = gtk_label_new_with_mnemonic(title); g_object_set(label, "margin", GINT_TO_POINTER(4), NULL); w = create_spin_button(min, max, inc, init, 0); #if GTK_CHECK_VERSION(3, 12, 0) gtk_widget_set_margin_end(w, 4); #else gtk_widget_set_margin_right(w, 4); #endif gtk_label_set_mnemonic_widget(GTK_LABEL(label), w); gtk_widget_set_hexpand(w, TRUE); gtk_widget_set_halign(w, GTK_ALIGN_FILL); gtk_grid_attach(GTK_GRID(*hbox), label, 0, 0, 1, 1); gtk_grid_attach(GTK_GRID(*hbox), w, 1, 0, 1, 1); return w; } static void frame_toggled(GtkToggleButton *togglebutton, gpointer user_data) { int state; struct fit_prm *prm; prm = (struct fit_prm *) user_data; state = gtk_toggle_button_get_active(togglebutton); gtk_widget_set_sensitive(GTK_WIDGET(prm->shadow), state); } static GtkWidget * create_format_frame(struct fit_prm *prm) { GtkWidget *frame, *vbox, *w, *hbox; frame = gtk_frame_new("format"); vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 4); w = gtk_check_button_new_with_mnemonic("add _+"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), ADD_PLUS); prm->add_plus = w; w = gtk_check_button_new_with_mnemonic("_Expand"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), EXPAND); prm->expand = w; w = gtk_check_button_new_with_mnemonic("_Frame"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), FRAME); prm->frame = w; w = gtk_check_button_new_with_mnemonic("_Shadow"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 2); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(w), FRAME); prm->shadow = w; g_signal_connect(prm->frame, "toggled", G_CALLBACK(frame_toggled), prm); w = my_create_spin_button("_Accuracy:", 1, 15, 1, ACCURACY, &hbox); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 2); prm->accuracy = w; gtk_container_add(GTK_CONTAINER(frame), vbox); return frame; } static GtkWidget * create_position_frame(struct fit_prm *prm) { GtkWidget *frame, *w, *table; int j; frame = gtk_frame_new("position"); table = gtk_grid_new(); j = 0; w = create_spin_button(POS_MIN, POS_MAX, POS_INC, prm->posx / 100.0, 2); add_widget_to_table_sub(table, w, "_X:", TRUE, 0, 1, j++); prm->x = w; w = create_spin_button(POS_MIN, POS_MAX, POS_INC, prm->posy / 100.0, 2); add_widget_to_table_sub(table, w, "_Y:", TRUE, 0, 1, j++); prm->y = w; gtk_container_add(GTK_CONTAINER(frame), table); return frame; } static void set_parameter(struct fit_prm *prm) { int i, j, accuracy, expand, add_plus, dim[PRM_NUM]; char buf[LINE_BUF_SIZE], fmt[LINE_BUF_SIZE], *prm_str; GtkTreeModel *model; GtkTreeIter iter; i = gtk_combo_box_get_active(GTK_COMBO_BOX(prm->combo)); if (i < 0) { return; } accuracy = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(prm->accuracy)); expand = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->expand)); add_plus = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prm->add_plus)); if (strcmp(prm->data[i].type, "poly") == 0) { for (j = 0; j < PRM_NUM; j++) { dim[j] = (j <= prm->data[i].poly); } } else if (strcmp(prm->data[i].type, "exp") == 0|| strcmp(prm->data[i].type, "log") == 0|| strcmp(prm->data[i].type, "pow") == 0) { for (j = 0; j < PRM_NUM; j++) { dim[j] = (j < 2); } } else if (prm->data[i].userfunc) { for (j = 0; j < PRM_NUM; j++) { snprintf(buf, sizeof(buf), "%%%02d", j); if (strstr(prm->data[i].userfunc, buf)) { dim[j] = TRUE; } else { dim[j] = FALSE; } } } model = gtk_tree_view_get_model(GTK_TREE_VIEW(prm->caption)); if (! gtk_tree_model_get_iter_first(model, &iter)) { return; } for (j = 0; j < PRM_NUM; j++) { snprintf(fmt, sizeof(fmt), "%%#%s.%dg", add_plus ? "+" : "", accuracy); if (expand) { prm_str = g_strdup_printf(fmt, prm->data[i].prm[j]); } else { prm_str = g_strdup_printf("%%pf{%s %%{data:%d:fit_prm:%d}}", fmt, prm->data[i].file_id, j); } gtk_list_store_set(GTK_LIST_STORE(model), &iter, COLUMN_CHECK, dim[j], COLUMN_VAL, prm_str, -1); g_free(prm_str); if (! gtk_tree_model_iter_next(model, &iter)) { break; } } } static void file_changed(GtkWidget *widget, gpointer user_data) { struct fit_prm *prm; prm = (struct fit_prm *) user_data; set_parameter(prm); } static void text_edited(GtkCellRenderer *renderer, gchar *path, gchar *new_text, struct fit_prm *prm, int column) { GtkTreeModel *model; GtkTreeIter iter; GtkTreeView *view; view = GTK_TREE_VIEW(prm->caption); model = gtk_tree_view_get_model(view); if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_list_store_set(GTK_LIST_STORE(model), &iter, column, new_text, -1); } static void caption_edited(GtkCellRenderer *renderer, gchar *path, gchar *new_text, gpointer user_data) { text_edited(renderer, path, new_text, (struct fit_prm *) user_data, COLUMN_CAPTION); } static void value_edited(GtkCellRenderer *renderer, gchar *path, gchar *new_text, gpointer user_data) { text_edited(renderer, path, new_text, (struct fit_prm *) user_data, COLUMN_VAL); } static void caption_toggled(GtkCellRendererToggle *cell_renderer, gchar *path, gpointer user_data) { struct fit_prm *prm; GtkTreeView *view; GtkTreeModel *model; GtkTreeIter iter; gboolean v; prm = (struct fit_prm *) user_data; view = GTK_TREE_VIEW(prm->caption); model = gtk_tree_view_get_model(view); if (! gtk_tree_model_get_iter_from_string(model, &iter, path)) { return; } gtk_tree_model_get(model, &iter, COLUMN_CHECK, &v, -1); v = !v; gtk_list_store_set(GTK_LIST_STORE(model), &iter, COLUMN_CHECK, v, -1); } struct text_column { char *title; int editable; void (* func)(GtkCellRenderer *, gchar *, gchar *, gpointer); }; static GtkWidget * create_caption_frame(struct fit_prm *prm) { GtkListStore *list; GtkCellRenderer *renderer; GtkTreeViewColumn *col; GtkTreeIter iter; GtkWidget *tview, *hbox, *frame; int i, n; struct text_column text_column[] = { {"prm", FALSE, NULL}, {"caption", TRUE, caption_edited}, {"result", TRUE, value_edited}, }; char buf1[64], buf2[64]; n = sizeof(text_column) / sizeof(*text_column); list = gtk_list_store_new(n + 1, G_TYPE_BOOLEAN, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING); tview = gtk_tree_view_new_with_model(GTK_TREE_MODEL(list)); #if ! GTK_CHECK_VERSION(3, 14, 0) gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(tview), TRUE); #endif gtk_tree_view_set_grid_lines(GTK_TREE_VIEW(tview), GTK_TREE_VIEW_GRID_LINES_VERTICAL); renderer = gtk_cell_renderer_toggle_new(); col = gtk_tree_view_column_new_with_attributes("", renderer, "active", 0, NULL); g_object_set(renderer, "mode", GTK_CELL_RENDERER_MODE_ACTIVATABLE, NULL); g_signal_connect(renderer, "toggled", G_CALLBACK(caption_toggled), prm); gtk_tree_view_append_column(GTK_TREE_VIEW(tview), col); for (i = 0; i < n; i++) { renderer = gtk_cell_renderer_text_new(); col = gtk_tree_view_column_new_with_attributes(text_column[i].title, renderer, "text", i + 1, "sensitive", 0, NULL); if (text_column[i].editable) { g_object_set(renderer, "editable", TRUE, NULL); g_signal_connect(renderer, "edited", G_CALLBACK(text_column[i].func), prm); } gtk_tree_view_append_column(GTK_TREE_VIEW(tview), col); } for (i = 0; i < PRM_NUM; i++) { snprintf(buf1, sizeof(buf1), "%%%02d", i); snprintf(buf2, sizeof(buf2), "\\%%%02d: ", i); gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, COLUMN_PRM, buf1, COLUMN_CAPTION, buf2, -1); } frame = gtk_frame_new(NULL); gtk_container_add(GTK_CONTAINER(frame), tview); hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); gtk_box_pack_start(GTK_BOX(hbox), frame, TRUE, TRUE, 4); prm->caption = tview; return hbox; } static GtkWidget * create_file_frame(struct fit_prm *prm) { GtkListStore *list; GtkTreeIter iter; GtkCellRenderer *rend_s; GtkWidget *combo, *hbox, *label; char *str, *filename; int i; combo = gtk_combo_box_new(); list = gtk_list_store_new(1, G_TYPE_STRING); gtk_combo_box_set_model(GTK_COMBO_BOX(combo), GTK_TREE_MODEL(list)); rend_s = gtk_cell_renderer_text_new(); gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(combo), rend_s, FALSE); gtk_cell_layout_add_attribute(GTK_CELL_LAYOUT(combo), rend_s, "text", 0); for (i = 0; i < prm->fit_num; i++) { if (prm->data[i].file == NULL) { continue; } filename = g_path_get_basename(prm->data[i].file); str = g_strdup_printf("#%d %s", prm->data[i].file_id, filename); gtk_list_store_append(list, &iter); gtk_list_store_set(list, &iter, 0, str, -1); g_free(str); g_free(filename); } prm->combo = combo; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); label = gtk_label_new_with_mnemonic("_Data:"); gtk_label_set_mnemonic_widget(GTK_LABEL(label), combo); gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, FALSE, 4); gtk_box_pack_start(GTK_BOX(hbox), combo, TRUE, TRUE, 4); return hbox; } static GtkWidget * create_control(GtkWidget *box, struct fit_prm *prm) { GtkWidget *w, *hbox; hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 4); w = create_format_frame(prm); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); w = create_position_frame(prm); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); w = create_font_frame(&prm->font); gtk_box_pack_start(GTK_BOX(hbox), w, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(box), hbox, FALSE, FALSE, 4); w = create_file_frame(prm); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 4); w = create_caption_frame(prm); gtk_box_pack_start(GTK_BOX(box), w, FALSE, FALSE, 4); return NULL; } static void create_widgets(GtkWidget *vbox, struct fit_prm *prm) { GtkWidget *w; w = create_title(NAME " version " VERSION, "fitting results -> legend text"); gtk_box_pack_start(GTK_BOX(vbox), w, FALSE, FALSE, 0); w = create_control(vbox, prm); } static const char * get_opt(int argc, char **argv, struct fit_prm *prm) { int i; char *data_file = NULL; for (i = 1; i < argc; i++) { if (strcmp(argv[i], "-x") == 0) { i++; if (argv[i]) { prm->posx = atoi(argv[i]); } } else if (strcmp(argv[i], "-y") == 0) { i++; if (argv[i]) { prm->posy = atoi(argv[i]); } } else if (data_file == NULL) { data_file = argv[i]; } else { prm->script = argv[i]; } } return data_file; } int main(int argc, char **argv) { GtkWidget *mainwin; gint r; struct fit_prm prm; const char *data_file; setlocale(LC_ALL, ""); gtk_init(&argc, &argv); prm.posx = POS_X; prm.posy = POS_Y; data_file = get_opt(argc, argv, &prm); if (data_file == NULL) { return 0; } if (loaddatalist(&prm, data_file)) { return 0; } mainwin = gtk_dialog_new_with_buttons(NAME, NULL, 0, "_Cancel", GTK_RESPONSE_REJECT, "_OK", GTK_RESPONSE_ACCEPT, NULL); gtk_dialog_set_default_response(GTK_DIALOG(mainwin), GTK_RESPONSE_ACCEPT); prm.window = mainwin; create_widgets(gtk_dialog_get_content_area(GTK_DIALOG(mainwin)), &prm); g_signal_connect(prm.combo, "changed", G_CALLBACK(file_changed), &prm); g_signal_connect(prm.add_plus, "toggled", G_CALLBACK(file_changed), &prm); g_signal_connect(prm.expand, "toggled", G_CALLBACK(file_changed), &prm); g_signal_connect(prm.accuracy, "value-changed", G_CALLBACK(file_changed), &prm); gtk_combo_box_set_active(GTK_COMBO_BOX(prm.combo), 0); gtk_widget_show_all(mainwin); r = gtk_dialog_run(GTK_DIALOG(mainwin)); if (r == GTK_RESPONSE_ACCEPT) { savescript(&prm); } return 0; } ngraph-gtk-6.08.00/addin/tex_equation.nsc0000644000175000017500000000562313351432266015154 00000000000000# Description: Te_X equation,import TeX equation as GRA, TEX_COMMAND="pdflatex" TEX_OPTION="-halt-on-error" PSTOEDIT_COMMAND="pstoedit" PSTOEDIT_OPTION="-q -flat 0.1 -nc -ssp -dt" RUBY_COMMAND="ruby" TEX_FILE="_tex_eqn_${system::pid}" tex_eqn_error_dialog() { new dialog dialog::message "$1" del dialog } tex_eqn_check_command() { if which -q $1 then true else tex_eqn_error_dialog "Cannot execute '$1'." exit fi } tex_eqn_delete_object() { del iarray:text del iarray:graf del iarray:merge } set +e text_obj="${menu::focused:'text'}" if [ -z "$text_obj" ] then tex_eqn_error_dialog "focus text object to convert." exit fi tex_eqn_check_command $TEX_COMMAND tex_eqn_check_command $PSTOEDIT_COMMAND if which -q $RUBY_COMMAND then FIG2GRA_COMMAND="$RUBY_COMMAND" FIG2GRA_OPTION="${system::data_dir}/addin/fig2gra.rb" else . "${system::data_dir}/addin/fig2gra.nsc" FIG2GRA_COMMAND=fig2gra FIG2GRA_OPTION="-dummy" fi new iarray name=text new iarray name=graf new iarray name=merge for text in $text_obj do merge_name=`get $text -field name` if [ -z "$merge_name" ] then new text t=`iexpr 'time()'` t=`get text -field printf:"%X $t"` del text merge_name="tex_eqn_`get $text -field oid`_$t" fi str=`get $text -field text` cat <<-EOF > $TEX_FILE.tex \documentclass[12pt]{article} \usepackage{amsmath,txfonts} \begin{document} \pagestyle{empty} \[ $str \] \end{document} EOF $TEX_COMMAND $TEX_OPTION "$TEX_FILE".tex | menu::cat menu::echo "---------------" menu::echo if [ ! -r "$TEX_FILE".pdf ] then tex_eqn_error_dialog "Faital error occurred while executing $TEX_COMMAND." rm "$TEX_FILE".* tex_eqn_delete_object exit fi $PSTOEDIT_COMMAND $PSTOEDIT_OPTION -f fig "$TEX_FILE".pdf "$TEX_FILE".fig if [ ! -r "$TEX_FILE".fig ] then tex_eqn_error_dialog "Faital error occurred while executing $PSTOEDIT_COMMAND." rm "$TEX_FILE".* tex_eqn_delete_object exit fi gra_file="`pwd`/$merge_name".gra $FIG2GRA_COMMAND "$FIG2GRA_OPTION" "$TEX_FILE".fig "$gra_file" if [ ! -r "$gra_file" ] then tex_eqn_error_dialog "Faital error occurred while executing fig2gra." rm "$TEX_FILE".* tex_eqn_delete_object exit fi if exist -q merge:$merge_name then true else new merge name=$merge_name merge::file="$gra_file" fi put merge:$merge_name left_margin=0 top_margin=0 iarray:text:@=`get $text -field bbox` iarray:graf:@=`get merge:$merge_name -field bbox` dx=`iexpr ${iarray:text:get:0} - ${iarray:graf:get:0}` dy=`iexpr ${iarray:text:get:1} - ${iarray:graf:get:1}` put merge:$merge_name left_margin=$dx top_margin=$dy put $text hidden=true raw=true name=$merge_name iarray:merge:push ${merge::id} rm "$TEX_FILE".* done menu::unfocus menu::draw menu::focus merge:${iarray:merge:join:","} menu::modified=true tex_eqn_delete_object ngraph-gtk-6.08.00/addin/timer.nsc0000644000175000017500000000275413207502317013564 00000000000000# Description: _Timer,Countdown timer, BAR_X=1000 BAR_Y=19000 BAR_W=19000 BAR_H=3000 new dialog dialog::title="Countdown timer" dialog::caption="Countdown (minutes):" T=${dialog::integer_entry:"1 120 1 30"} del dialog if [ -z "$T" ] then exit fi for inst in text:timer int:timer do if exist -q $inst then del $inst fi done T=`iexpr $T*60` OBJ=`derive -instance draw` system:0:hide_instance $OBJ new int int::name="timer" int::@="$T+1" new text text::name="timer" text::hidden=false text::text='%{system::time:0}' text::x=600 text::y=13000 text::pt=14200 text::font='Sans-serif' new rectangle rectangle::name="timer_bar" rectangle::x1="$BAR_X" rectangle::y1="$BAR_Y" rectangle::x2="$BAR_X+$BAR_W" rectangle::y2="$BAR_Y+$BAR_H" rectangle::fill_G=255 rectangle::fill=true rectangle::stroke=false dup rectangle rectangle::name="timer" rectangle::fill=false rectangle::stroke=true rectangle::width=120 while int:timer:times do m=`iexpr "int(${int:timer:@}/60)"` s=`iexpr "${int:timer:@}\\\\60"` s=`get text:timer -field printf:"%02d $s"` text:timer:text="%{system::time:0}\&\n$m:$s\&" rectangle:timer_bar:x2="$BAR_W*${int:timer:@}/$T+${rectangle:timer:x1}" rectangle:timer_bar:fill_G="255*${int:timer:@}/$T" rectangle:timer_bar:fill_R="255*(1-${int:timer:@}/$T)" gra::clear gra::draw gra::flush sleep 1 done del int:timer del text:timer del rectangle:timer del rectangle:timer_bar system:0:recover_instance $OBJ gra::clear gra::draw gra::flush ngraph-gtk-6.08.00/addin/img2gra.nsc0000644000175000017500000000073613207502317013772 00000000000000# legend.nsc written by hito # # This script import image as merge object. # # Description: _Import image...,import image as merge object, new dialog IMG_FILE=${dialog::get_open_file} del dialog if [ ! -r "$IMG_FILE" ] then exit fi GRA_FILE=`basename "$IMG_FILE"`.gra "${NGRAPHLIB}/gimg2gra" ${menu::dpi} "$IMG_FILE" "$GRA_FILE" if [ -f "$GRA_FILE" ] then new merge merge::file="$GRA_FILE" gra::clear gra::draw gra::flush menu::modified=true fi ngraph-gtk-6.08.00/addin/fft.nsc0000644000175000017500000000142413070106167013215 00000000000000# # fft.nsc written by S. ISHIZAKA. 1999/07 # # Description: _FFT...,Fast Fourier Transform, new dialog SOURCE_FILE=${dialog::get_open_file} if [ ! -r "$SOURCE_FILE" ] then del dialog exit fi DEST_FILE=${dialog::get_save_file:"dat _fft_.dat"} if [ -z "$DEST_FILE" ] then del dialog exit fi if "$NGRAPHLIB/fft" "$SOURCE_FILE" "$DEST_FILE" then true else dialog::message "some errors are occurred while calculation." del dialog exit fi new data data::x=1 data::y=2 data::file="$DEST_FILE" data::type=line data::B=255 new data data::file="$DEST_FILE" data::x=1 data::y=3 data::type=line data::R=255 new data data::file="$DEST_FILE" data::x=1 data::y=2 data::type=staircase_x data::math_y='SQRT(%02^2+%03^2)' menu::modified=true del dialog menu:0:clear ngraph-gtk-6.08.00/addin/fig2gra.rb0000644000175000017500000002603213070106167013601 00000000000000class Spline def initialize(pos) @n = 0 @x = [] @y = [] @t = [] (pos.size/ 2).times { |i| next if (i > 0 && @x[-1] == pos[i * 2] && @y[-1] == pos[i * 2 + 1]) @x.push(pos[i * 2]) @y.push(pos[i * 2 + 1]) if (i == 0) @t[i] = 0 elsif (@x.size > 1) t1 = @x[-1] - @x[-2] t2 = @y[-1] - @y[-2] @t.push(@t.last + Math.sqrt(t1 ** 2 + t2 ** 2)) end } @n = @x.size (1 .. @n - 1).each { |i| @t[i] /= @t[@n - 1] } @xz = [] @yz = [] maketable(@t, @x, @xz) maketable(@t, @y, @yz) end def maketable(x, y, z) h = [] d = [] z[0] = 0 z[@n - 1] = 0 (@n - 1).times { |i| h[i ] = x[i + 1] - x[i] d[i + 1] = (y[i + 1] - y[i]) / h[i].to_f } z[1] = d[2] - d[1] - h[0] * z[0] d[1] = 2 * (x[2] - x[0]) (1 .. @n - 3).each { |i| t = h[i] / d[i].to_f z[i + 1] = d[i + 2] - d[i + 1] - z[i] * t d[i + 1] = 2 * (x[i + 2] - x[i]) - h[i] * t } z[@n - 2] -= h[@n - 2] * z[@n - 1] (@n - 2).downto(1) { |i| z[i] = (z[i] - h[i] * z[i + 1]) / d[i].to_f } end def spline_sub(x, y, z, t) i = 0 j = @n - 1 while (i < j) k = (i + j) / 2 if (x[k] < t) i = k + 1 else j = k end end i -= 1 if (i > 0) h = x[i + 1] - x[i] d = t - x[i] return (((z[i + 1] - z[i]) * d / h.to_f + z[i] * 3) * d + ((y[i + 1] - y[i]) / h.to_f - (z[i] * 2 + z[i + 1]) * h)) * d + y[i] end def spline(t) x = spline_sub(@t, @x, @xz, t) y = spline_sub(@t, @y, @yz, t) return [x, y] end end class Fig2Gra SPLINE_DIV = 10 PS_FONT = [ ["Serif", 0], # 0 Times Roman ["Serif", 2], # 1 Times Italic ["Serif", 1], # 2 Times Bold ["Serif", 3], # 3 Times Bold Italic ["Sans-serif", 0], # 4 AvantGarde Book ["Sans-serif", 2], # 5 AvantGarde Book Oblique ["Sans-serif", 1], # 6 AvantGarde Demi ["Sans-serif", 3], # 7 AvantGarde Demi Oblique ["Serif", 0], # 8 Bookman Light ["Serif", 2], # 9 Bookman Light Italic ["Serif", 1], # 10 Bookman Demi ["Serif", 3], # 11 Bookman Demi Italic ["Monospace", 0], # 12 Courier ["Monospace", 2], # 13 Courier Oblique ["Monospace", 1], # 14 Courier Bold ["Monospace", 3], # 15 Courier Bold Oblique ["Sans-serif", 0], # 16 Helvetica ["Sans-serif", 2], # 17 Helvetica Oblique ["Sans-serif", 1], # 18 Helvetica Bold ["Sans-serif", 3], # 19 Helvetica Bold Oblique ["Sans-serif", 0], # 20 Helvetica Narrow ["Sans-serif", 2], # 21 Helvetica Narrow Oblique ["Sans-serif", 1], # 22 Helvetica Narrow Bold ["Sans-serif", 3], # 23 Helvetica Narrow Bold Oblique ["Serif", 0], # 24 New Century Schoolbook Roman ["Serif", 2], # 25 New Century Schoolbook Italic ["Serif", 1], # 26 New Century Schoolbook Bold ["Serif", 3], # 27 New Century Schoolbook Bold Italic ["Serif", 0], # 28 Palatino Roman ["Serif", 2], # 29 Palatino Italic ["Serif", 1], # 30 Palatino Bold ["Serif", 3], # 31 Palatino Bold Italic ["Serif", 0], # 32 Symbol ["Serif", 2], # 33 Zapf Chancery Medium Italic ["Serif", 0], # 34 Zapf Dingbats nil ] LATEX_FONT = [ nil, # 0 Default font ["Serif", 0], # 1 Roman ["Serif", 1], # 2 Bold ["Serif", 2], # 3 Italic ["Sans-serif", 0], # 4 Sans Serif ["Monospace", 3], # 5 Typewriter ] PAPER_SIZE = { "Letter" => [21600, 27900], "Legal" => [21600, 35600], "Ledger" => [43200, 27900], "Tabloid" => [27900, 43200], "A" => [22900, 30500], "B" => [30500, 45700], "C" => [45700, 61000], "D" => [61000, 91400], "E" => [91400, 121900], "A4" => [21000, 29700], "A3" => [29700, 42000], "A2" => [42000, 59400], "A1" => [59400, 84100], "A0" => [84100, 118900], "B5" => [17600, 25000], } COLOR = [ [0, 0, 0], [0, 0, 0xff], [0, 0xff, 0], [0, 0xff, 0xff], [0xff, 0, 0], [0xff, 0, 0xff], [0xff, 0xff, 0], [0xff, 0xff, 0xff], [0, 0, 0x90], [0, 0, 0xB0], [0, 0, 0xD0], [0x87, 0xCE, 0xFF], [0, 0x90, 0], [0, 0xB0, 0], [0, 0xD0, 0], [0, 0x90, 0x90], [0, 0xB0, 0xB0], [0, 0xD0, 0xD0], [0x90, 0, 0x90], [0xB0, 0, 0xB0], [0xD0, 0, 0xD0], [0x80, 0x30, 0], [0xA0, 0x40, 0], [0xC0, 0x60, 0], [0xFF, 0x80, 0x80], [0xFF, 0xA0, 0xA0], [0xFF, 0xC0, 0xC0], [0xFF, 0xE0, 0xE0], [0xFF, 0xD7, 0xE00], ] def initialize @coord_conv = 1 @resolution = 1 end def coord_conv(v) (v * @coord_conv * 100).to_i end def unit_conv(v) (v * @coord_conv * 100 / @resolution).to_i end def set_line_attribute(f, type, width, cap, join, len) len = coord_conv(len) style = [ [], [len, len], [50, len], [len, 100, 50, 100], [len, 100, 50, 100, 50, 100], [len, 100, 50, 100, 50, 100, 50, 100], ] n = style[type].size f.print("A,#{n + 5},#{n},#{coord_conv(width) + 1},#{cap},#{join},1000") if (n > 0) f.print(",#{style[type].join(',')}") end f.print("\n") end def set_color(f, col) return unless (col) f.puts("G,4,#{col.join(',')},255") end def draw_ellipse(f, a) return if (a.size != 16) end def draw_poly_line(f, a, b) return if (a.size != 16) prm = a.map{|i| i.to_i} return if (prm[1] == 5) n = prm[15] * 2 fill = (prm[8] != -1) close_path = false if (b[0] == b[-2] && b[1] == b[-1]) n -= 2 close_path = true end if (prm[1] != 1 || fill) if (fill) set_color(f, COLOR[prm[5]]) f.puts("D,#{n + 2},#{n / 2},1,#{b[0, n].join(',')}") end if (prm[3] > 0) set_color(f, COLOR[prm[4]]) set_line_attribute(f, prm[2], prm[3] / 80.0, prm[11], prm[10], prm[9]) if (fill) f.puts("D,#{n + 2},#{n / 2},0,#{b[0, n].join(',')}") end else set_color(f, COLOR[prm[4]]) set_line_attribute(f, prm[2], prm[3] / 80.0, prm[11], prm[10], prm[9]) if (close_path) f.puts("D,#{n + 2},#{n / 2},0,#{b[0, n].join(',')}") else f.puts("R,#{n + 1},#{n / 2},#{b[0, n].join(',')}") end end end def uniq_pos(pos) n = pos.size / 2 a = [] n.times {|i| x = pos[i * 2] y = pos[i * 2 + 1] if (i == 0) a.push(x) a.push(y) else if (a[-2] != x || a[-1] != y) a.push(x) a.push(y) end end } return a end def draw_spline(f, a, b) return if (a.size != 14) prm = a.map{|i| i.to_i} n = prm[13] * 2 fill = (prm[8] != -1) pos = [] subpath = [] state = b[n, n / 2] state.each_with_index {|v, i| if (v == 0) m = subpath.size / 2 if (m > 2) s = Spline.new(subpath) (1 .. m * SPLINE_DIV - 1).each { |j| x, y = s.spline(j * 1.0 / m / SPLINE_DIV) pos.push(x.to_i) pos.push(y.to_i) } elsif (m == 2) pos.push(subpath[2]) pos.push(subpath[3]) end pos.push(b[i * 2]) pos.push(b[i * 2 + 1]) subpath.clear subpath.push(b[i * 2]) subpath.push(b[i * 2 + 1]) else if (subpath[-1] != b[i * 2 + 1] || subpath[-2] != b[i * 2]) subpath.push(b[i * 2]) subpath.push(b[i * 2 + 1]) end end } pos = uniq_pos(pos) n = pos.size close_path = false if (pos[0] == pos[-2] && pos[1] == pos[-1]) n -= 2 close_path = true end return if (n < 4) if (prm[1] % 2 != 0 || fill) if (fill) set_color(f, COLOR[prm[5]]) f.puts("D,#{n + 2},#{n / 2},1,#{pos.join(',')}") end if (prm[3] > 0) set_color(f, COLOR[prm[4]]) set_line_attribute(f, prm[2], prm[3] / 80.0, prm[10], 2, prm[9]) if (fill) f.puts("D,#{n + 2},#{n / 2},0,#{pos.join(',')}") end else set_color(f, COLOR[prm[4]]) set_line_attribute(f, prm[2], prm[3] / 80.0, prm[10], 2, prm[9]) if (close_path) f.puts("D,#{n + 2},#{n / 2},0,#{pos.join(',')}") else f.puts("R,#{n + 1},#{n / 2},#{pos.join(',')}") end end end def draw_text(f, a) return if (a.size != 14) prm = a.map{|i| i.to_i} flag = prm[8] f = prm[5] if (flag & 4 == 0) font = LATEX_FONT[f] else font = PS_FONT[f] end set_color(f, COLOR[prm[2]]) if (font) style = font[1] f.puts("F#{font[0]}") else style = 0 end s = a[13] f.puts("H,4,#{prm[6] * 100},0,#{(a[7].to_f / Math::PI * 180 * 100).to_i},#{style}") f.puts("M,2,#{unit_conv(prm[11])},#{unit_conv(prm[12])}") f.puts("S#{s[0, s.size - 4]}") end def draw_arc(f, a) end def convert(fig, gra) f = IO.readlines(fig) l = f.select {|s| s[0] != ?# } return false if (l.size < 9) head = l[0, 8].map {|s| s.chomp} @resolution = head[7].split[0].to_i @coord_conv = (head[2] == "Metric") ? 1 : 25.4 psize = PAPER_SIZE[head[3]] psize = [21000, 29700] unless (psize) File.open(gra, "w") {|f| f.puts('%Ngraph GRAF') f.puts('%Creator: fig2gra.rb') f.puts("I,5,0,0,#{psize.join(',')},10000") f.puts("V,5,0,0,#{psize.join(',')},0") i = 8 while (l[i]) a = l[i].split cmd = a[0].to_i b = [] i += 1 while (l[i] && l[i][0, 1] == "\t") b += l[i].split.map {|v| unit_conv(v.to_i)} i += 1 end case cmd when 0 s = a[2][1, 6] c = [s[0, 2].hex, s[2, 2].hex, s[4, 2].hex] COLOR[a[1].to_i] = c when 1 draw_ellipse(f, a) when 2 draw_poly_line(f, a, b) when 3 draw_spline(f, a, b) when 4 draw_text(f, a) when 5 draw_arc(f, a) when 6 end end f.puts('E,0') } end end if (__FILE__ == $0) exit(1) if (ARGV.size != 2) fig2gra = Fig2Gra.new fig2gra.convert(ARGV[0], ARGV[1]) end ngraph-gtk-6.08.00/addin/fft.c0000644000175000017500000000601713070106167012657 00000000000000/* * * fft.c written by S. ISHIZAKA 1999/07 * */ #include #include #include #define PI 3.141592653589793 #define MAXP 24 #define MAXDATA (1 << MAXP) double fr[MAXDATA], fi[MAXDATA], gr[MAXDATA], gi[MAXDATA]; double workr[MAXDATA / 2], worki[MAXDATA / 2]; static void fft(int p,int num); static int read_data(const char *fname1, int *n, int *p, double *min, double *max); static int save_data(const char *fname2, int n, int p, double minx, double maxx); int main(int argc,char **argv) { char *fname1,*fname2; int n, p, num; double minx, maxx; if (argc < 3) { fprintf(stderr, "usage: fft input output"); exit(1); } fname1 = argv[1]; fname2 = argv[2]; num = read_data(fname1, &p, &n, &minx, &maxx); if (num < 0) { fprintf(stderr, "error: open (%s)", fname1); exit(1); } else if (num < 2) { fprintf(stderr, "error: too small number of data"); exit(1); } if (save_data(fname2, p, n, minx, maxx)) { fprintf(stderr, "error: open (%s)", fname2); exit(1); } return 0; } static int save_data(const char *fname2, int p, int n, double minx, double maxx) { FILE *fp2; double dx; int i; fp2 = fopen(fname2, "wt"); if (fp2 == NULL) { return 1; } fft(p, n); dx = (n - 1) / (maxx - minx) / n; for (i = n / 2; i < n; i++) { fprintf(fp2, "%+E %+.15E %+.15E\n", dx * (i - n), gr[i], gi[i]); } for (i = 0; i < n / 2; i++) { fprintf(fp2, "%+E %+.15E %+.15E\n", dx * i, gr[i], gi[i]); } fclose(fp2); return 0; } static int read_data(const char *fname1, int *fft_p, int *fft_n, double *min, double *max) { FILE *fp1; int num, n, p; double x, y, minx, maxx; char line[1024]; fp1 = fopen(fname1, "rt"); if (fp1 == NULL) { return -1; } num = 0; n = 1; p = 0; maxx = 0; minx = 0; while (fgets(line, sizeof(line), fp1)) { if (sscanf(line, "%lf%*[ \t,]%lf", &x, &y) != 2) { continue; } if (num == 0) { minx = x; } fr[num] = y; fi[num] = 0; num++; if (num == (n*2)) { n *= 2; p++; if (p == MAXP) { break; } maxx=x; } } fclose(fp1); *fft_n = n; *fft_p = p; *min = minx; *max = maxx; return num; } static void fft(int p,int n) { int i,j,k,l,l1,l2,m,n2; double ar,ai,br,bi; n2=n/2; for (i=0;i 1) if (str) modified_string << str else modified_string << word end word.clear str end def check(text) original_string = text.text modified_string = "" word = "" len = original_string.size i = 0 r = true while (i < len) c = original_string[i] case (c) when '\\' r = check_word(original_string, text.id, modified_string, word) modified_string << c i += 1 c = original_string[i] if (c) modified_string << c i += 1 end when '%' r = check_word(original_string, text.id, modified_string, word) modified_string << c i = skip_prm(original_string, i, modified_string) when @alphabet word << c i += 1 r = check_word(original_string, text.id, modified_string, word) if (i >= len) else r = check_word(original_string, text.id, modified_string, word) modified_string << c i += 1 end unless (r) lest = original_string[i, len - i] modified_string << lest if (lest) break end end if (original_string != modified_string) text.text = modified_string @modified = true end r end def check_inst(inst) inst.each {|text| break unless (check(text)) } end def check_all Ngraph::Text.each {|text| break unless (check(text)) } end def run inst = focused if (inst) check_inst(inst) else check_all end finalize end def finalize Ngraph::Dialog.new {|dialog| dialog.title = "spell check" str = dialog.message("Spell check completed.") } if (@menu && @modified) @menu.modified = true @menu.draw end end end checker = NgraphSpellchecker.new checker.run ngraph-gtk-6.08.00/addin/ps2gra.nsc0000644000175000017500000000345113070106167013636 00000000000000# Description: import _PS...,Import PostScript image,ps # Description: import _EPS...,Import Encapsulated PostScript image,eps # Description: import _PDF...,Import Portable Document Format image,pdf PSTOEDIT_COMMAND="pstoedit" PSTOEDIT_OPTION="-q -flat 0.1 -nc -ssp -dt" RUBY_COMMAND="ruby" ps2gra_error_dialog() { new dialog dialog::message "$1" del dialog } set +e if which -q $PSTOEDIT_COMMAND then true else ps2gra_error_dialog "Cannot execute '$PSTOEDIT_COMMAND'." exit fi new dialog ps_file=`get dialog -field get_open_file:$1` del dialog if [ -z "$ps_file" ] then exit fi if [ ! -r "$ps_file" ] then ps2gra_error_dialog "cannot open $ps_file" exit fi gra_file="`pwd`/`basename $ps_file .$1`.gra" if [ -e "$gra_file" ] then new dialog response=`get dialog -field yesno:"The file '$gra_file' already exists. Do you want to replace it?"` del dialog if [ x"$response" != "x1" ] then exit fi fi fig_file="${system::temp_file}" $PSTOEDIT_COMMAND $PSTOEDIT_OPTION -f fig "$ps_file" "$fig_file" if [ ! -r "$fig_file" ] then ps2gra_error_dialog "Faital error occurred while execute pstoedit." system::unlink_temp_file "$fig_file" exit fi if which -q $RUBY_COMMAND then $RUBY_COMMAND "${system::data_dir}/addin/fig2gra.rb" "$fig_file" "$gra_file" else . "${system::data_dir}/addin/fig2gra.nsc" fig2gra "$fig_file" "$gra_file" fi system::unlink_temp_file "$fig_file" rm -f "$fig_file"* if [ ! -r "$gra_file" ] then ps2gra_error_dialog "Fatal error occurred while executing fig2gra." exit fi for i in `object merge -instances` do merge_file=`get merge:$i -field file` if [ "$merge_file" = "$gra_file"] then exit fi done new merge merge::file="$gra_file" menu::draw menu::unfocus menu::focus merge:! menu::modified=true ngraph-gtk-6.08.00/addin/append.nsc0000644000175000017500000000155213070106167013707 00000000000000# append.nsc written by S. ISHIZAKA. 1997/12 # # This script reads and appends a NGP-file without clearing the present graph. # # This script uses rather special techniques. # We don't recommend to edit this script. # # Description: _Append...,append NGP file, if [ "$*" ] then FILE=$* else new dialog FILE=${dialog::get_open_file:'ngp'} del dialog fi if [ "$FILE" ] then # hide exsisting 'axis', 'axisgrid' and 'data' instances system:0:hide_instance axis axisgrid data # execute file new shell shell::shell "$FILE" del shell # tighten connection between new instances for i in `derive -instance data axis axisgrid` do exe ${i}:0-! tight done # recover hidden instances system:0:recover_instance axis axisgrid data # delete closed GRA instance if [ ${gra::GC} = -1 ] then del gra fi menu:0:clear menu:0:modified=true fi ngraph-gtk-6.08.00/addin/Makefile.in0000644000175000017500000010716413367273151014015 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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@ @HAVE_RUBY_DEV_TRUE@am__append_1 = $(ruby_addins) pkglibexec_PROGRAMS = fft$(EXEEXT) fitrslt$(EXEEXT) legend$(EXEEXT) \ gimg2gra$(EXEEXT) subdir = addin ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__dist_addin_DATA_DIST) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(pkglibexecdir)" "$(DESTDIR)$(addindir)" PROGRAMS = $(pkglibexec_PROGRAMS) am_fft_OBJECTS = fft.$(OBJEXT) fft_OBJECTS = $(am_fft_OBJECTS) fft_DEPENDENCIES = 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_fitrslt_OBJECTS = fitrslt-fitrslt.$(OBJEXT) \ fitrslt-addin_common.$(OBJEXT) fitrslt_OBJECTS = $(am_fitrslt_OBJECTS) am__DEPENDENCIES_1 = fitrslt_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) fitrslt_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(fitrslt_CFLAGS) \ $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ am_gimg2gra_OBJECTS = gimg2gra-gimg2gra.$(OBJEXT) gimg2gra_OBJECTS = $(am_gimg2gra_OBJECTS) gimg2gra_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) gimg2gra_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(gimg2gra_CFLAGS) \ $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ am_legend_OBJECTS = legend-legend.$(OBJEXT) \ legend-addin_common.$(OBJEXT) legend_OBJECTS = $(am_legend_OBJECTS) legend_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) legend_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(legend_CFLAGS) $(CFLAGS) \ $(AM_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__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/fft.Po \ ./$(DEPDIR)/fitrslt-addin_common.Po \ ./$(DEPDIR)/fitrslt-fitrslt.Po \ ./$(DEPDIR)/gimg2gra-gimg2gra.Po \ ./$(DEPDIR)/legend-addin_common.Po \ ./$(DEPDIR)/legend-legend.Po 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 = $(fft_SOURCES) $(fitrslt_SOURCES) $(gimg2gra_SOURCES) \ $(legend_SOURCES) DIST_SOURCES = $(fft_SOURCES) $(fitrslt_SOURCES) $(gimg2gra_SOURCES) \ $(legend_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__dist_addin_DATA_DIST = append.nsc fft.nsc fitrslt.nsc legend.nsc \ math.nsc text-in.nsc cal.nsc tex_equation.nsc ps2gra.nsc \ fig2gra.nsc timer.nsc fig2gra.rb load_prm.nsc img2gra.nsc \ ruby.nsc spellchecker.rb 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_addin_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ addindir = $(pkgdatadir)/addin addins = append.nsc fft.nsc fitrslt.nsc legend.nsc math.nsc \ text-in.nsc cal.nsc tex_equation.nsc ps2gra.nsc fig2gra.nsc \ timer.nsc fig2gra.rb load_prm.nsc img2gra.nsc $(am__append_1) ruby_addins = ruby.nsc spellchecker.rb @HAVE_RUBY_DEV_FALSE@EXTRA_DIST = $(ruby_addins) dist_addin_DATA = $(addins) APP_CFLAGS = fitrslt_SOURCES = fitrslt.c addin_common.c addin_common.h fitrslt_CFLAGS = $(GTK_CFLAGS) $(APP_CFLAGS) fitrslt_LDADD = $(GTK_LIBS) $(GLIB_LIBS) legend_SOURCES = legend.c addin_common.c addin_common.h legend_CFLAGS = $(GTK_CFLAGS) $(APP_CFLAGS) legend_LDADD = $(GTK_LIBS) $(GLIB_LIBS) gimg2gra_SOURCES = gimg2gra.c gimg2gra_CFLAGS = $(GTK_CFLAGS) $(APP_CFLAGS) gimg2gra_LDADD = $(GTK_LIBS) $(GLIB_LIBS) fft_SOURCES = fft.c fft_LDADD = 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) --gnu addin/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu addin/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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-pkglibexecPROGRAMS: $(pkglibexec_PROGRAMS) @$(NORMAL_INSTALL) @list='$(pkglibexec_PROGRAMS)'; test -n "$(pkglibexecdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkglibexecdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkglibexecdir)" || 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)$(pkglibexecdir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(pkglibexecdir)$$dir" || exit $$?; \ } \ ; done uninstall-pkglibexecPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(pkglibexec_PROGRAMS)'; test -n "$(pkglibexecdir)" || 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)$(pkglibexecdir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(pkglibexecdir)" && rm -f $$files clean-pkglibexecPROGRAMS: @list='$(pkglibexec_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 fft$(EXEEXT): $(fft_OBJECTS) $(fft_DEPENDENCIES) $(EXTRA_fft_DEPENDENCIES) @rm -f fft$(EXEEXT) $(AM_V_CCLD)$(LINK) $(fft_OBJECTS) $(fft_LDADD) $(LIBS) fitrslt$(EXEEXT): $(fitrslt_OBJECTS) $(fitrslt_DEPENDENCIES) $(EXTRA_fitrslt_DEPENDENCIES) @rm -f fitrslt$(EXEEXT) $(AM_V_CCLD)$(fitrslt_LINK) $(fitrslt_OBJECTS) $(fitrslt_LDADD) $(LIBS) gimg2gra$(EXEEXT): $(gimg2gra_OBJECTS) $(gimg2gra_DEPENDENCIES) $(EXTRA_gimg2gra_DEPENDENCIES) @rm -f gimg2gra$(EXEEXT) $(AM_V_CCLD)$(gimg2gra_LINK) $(gimg2gra_OBJECTS) $(gimg2gra_LDADD) $(LIBS) legend$(EXEEXT): $(legend_OBJECTS) $(legend_DEPENDENCIES) $(EXTRA_legend_DEPENDENCIES) @rm -f legend$(EXEEXT) $(AM_V_CCLD)$(legend_LINK) $(legend_OBJECTS) $(legend_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fft.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fitrslt-addin_common.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fitrslt-fitrslt.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gimg2gra-gimg2gra.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/legend-addin_common.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/legend-legend.Po@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .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 $@ $< fitrslt-fitrslt.o: fitrslt.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -MT fitrslt-fitrslt.o -MD -MP -MF $(DEPDIR)/fitrslt-fitrslt.Tpo -c -o fitrslt-fitrslt.o `test -f 'fitrslt.c' || echo '$(srcdir)/'`fitrslt.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/fitrslt-fitrslt.Tpo $(DEPDIR)/fitrslt-fitrslt.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='fitrslt.c' object='fitrslt-fitrslt.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -c -o fitrslt-fitrslt.o `test -f 'fitrslt.c' || echo '$(srcdir)/'`fitrslt.c fitrslt-fitrslt.obj: fitrslt.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -MT fitrslt-fitrslt.obj -MD -MP -MF $(DEPDIR)/fitrslt-fitrslt.Tpo -c -o fitrslt-fitrslt.obj `if test -f 'fitrslt.c'; then $(CYGPATH_W) 'fitrslt.c'; else $(CYGPATH_W) '$(srcdir)/fitrslt.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/fitrslt-fitrslt.Tpo $(DEPDIR)/fitrslt-fitrslt.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='fitrslt.c' object='fitrslt-fitrslt.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -c -o fitrslt-fitrslt.obj `if test -f 'fitrslt.c'; then $(CYGPATH_W) 'fitrslt.c'; else $(CYGPATH_W) '$(srcdir)/fitrslt.c'; fi` fitrslt-addin_common.o: addin_common.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -MT fitrslt-addin_common.o -MD -MP -MF $(DEPDIR)/fitrslt-addin_common.Tpo -c -o fitrslt-addin_common.o `test -f 'addin_common.c' || echo '$(srcdir)/'`addin_common.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/fitrslt-addin_common.Tpo $(DEPDIR)/fitrslt-addin_common.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='addin_common.c' object='fitrslt-addin_common.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -c -o fitrslt-addin_common.o `test -f 'addin_common.c' || echo '$(srcdir)/'`addin_common.c fitrslt-addin_common.obj: addin_common.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -MT fitrslt-addin_common.obj -MD -MP -MF $(DEPDIR)/fitrslt-addin_common.Tpo -c -o fitrslt-addin_common.obj `if test -f 'addin_common.c'; then $(CYGPATH_W) 'addin_common.c'; else $(CYGPATH_W) '$(srcdir)/addin_common.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/fitrslt-addin_common.Tpo $(DEPDIR)/fitrslt-addin_common.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='addin_common.c' object='fitrslt-addin_common.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(fitrslt_CFLAGS) $(CFLAGS) -c -o fitrslt-addin_common.obj `if test -f 'addin_common.c'; then $(CYGPATH_W) 'addin_common.c'; else $(CYGPATH_W) '$(srcdir)/addin_common.c'; fi` gimg2gra-gimg2gra.o: gimg2gra.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(gimg2gra_CFLAGS) $(CFLAGS) -MT gimg2gra-gimg2gra.o -MD -MP -MF $(DEPDIR)/gimg2gra-gimg2gra.Tpo -c -o gimg2gra-gimg2gra.o `test -f 'gimg2gra.c' || echo '$(srcdir)/'`gimg2gra.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/gimg2gra-gimg2gra.Tpo $(DEPDIR)/gimg2gra-gimg2gra.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gimg2gra.c' object='gimg2gra-gimg2gra.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(gimg2gra_CFLAGS) $(CFLAGS) -c -o gimg2gra-gimg2gra.o `test -f 'gimg2gra.c' || echo '$(srcdir)/'`gimg2gra.c gimg2gra-gimg2gra.obj: gimg2gra.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(gimg2gra_CFLAGS) $(CFLAGS) -MT gimg2gra-gimg2gra.obj -MD -MP -MF $(DEPDIR)/gimg2gra-gimg2gra.Tpo -c -o gimg2gra-gimg2gra.obj `if test -f 'gimg2gra.c'; then $(CYGPATH_W) 'gimg2gra.c'; else $(CYGPATH_W) '$(srcdir)/gimg2gra.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/gimg2gra-gimg2gra.Tpo $(DEPDIR)/gimg2gra-gimg2gra.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='gimg2gra.c' object='gimg2gra-gimg2gra.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(gimg2gra_CFLAGS) $(CFLAGS) -c -o gimg2gra-gimg2gra.obj `if test -f 'gimg2gra.c'; then $(CYGPATH_W) 'gimg2gra.c'; else $(CYGPATH_W) '$(srcdir)/gimg2gra.c'; fi` legend-legend.o: legend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -MT legend-legend.o -MD -MP -MF $(DEPDIR)/legend-legend.Tpo -c -o legend-legend.o `test -f 'legend.c' || echo '$(srcdir)/'`legend.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/legend-legend.Tpo $(DEPDIR)/legend-legend.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='legend.c' object='legend-legend.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -c -o legend-legend.o `test -f 'legend.c' || echo '$(srcdir)/'`legend.c legend-legend.obj: legend.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -MT legend-legend.obj -MD -MP -MF $(DEPDIR)/legend-legend.Tpo -c -o legend-legend.obj `if test -f 'legend.c'; then $(CYGPATH_W) 'legend.c'; else $(CYGPATH_W) '$(srcdir)/legend.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/legend-legend.Tpo $(DEPDIR)/legend-legend.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='legend.c' object='legend-legend.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -c -o legend-legend.obj `if test -f 'legend.c'; then $(CYGPATH_W) 'legend.c'; else $(CYGPATH_W) '$(srcdir)/legend.c'; fi` legend-addin_common.o: addin_common.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -MT legend-addin_common.o -MD -MP -MF $(DEPDIR)/legend-addin_common.Tpo -c -o legend-addin_common.o `test -f 'addin_common.c' || echo '$(srcdir)/'`addin_common.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/legend-addin_common.Tpo $(DEPDIR)/legend-addin_common.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='addin_common.c' object='legend-addin_common.o' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -c -o legend-addin_common.o `test -f 'addin_common.c' || echo '$(srcdir)/'`addin_common.c legend-addin_common.obj: addin_common.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -MT legend-addin_common.obj -MD -MP -MF $(DEPDIR)/legend-addin_common.Tpo -c -o legend-addin_common.obj `if test -f 'addin_common.c'; then $(CYGPATH_W) 'addin_common.c'; else $(CYGPATH_W) '$(srcdir)/addin_common.c'; fi` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/legend-addin_common.Tpo $(DEPDIR)/legend-addin_common.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='addin_common.c' object='legend-addin_common.obj' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(legend_CFLAGS) $(CFLAGS) -c -o legend-addin_common.obj `if test -f 'addin_common.c'; then $(CYGPATH_W) 'addin_common.c'; else $(CYGPATH_W) '$(srcdir)/addin_common.c'; fi` mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_addinDATA: $(dist_addin_DATA) @$(NORMAL_INSTALL) @list='$(dist_addin_DATA)'; test -n "$(addindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(addindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(addindir)" || 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)$(addindir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(addindir)" || exit $$?; \ done uninstall-dist_addinDATA: @$(NORMAL_UNINSTALL) @list='$(dist_addin_DATA)'; test -n "$(addindir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(addindir)'; $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)$(pkglibexecdir)" "$(DESTDIR)$(addindir)"; 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-pkglibexecPROGRAMS \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/fft.Po -rm -f ./$(DEPDIR)/fitrslt-addin_common.Po -rm -f ./$(DEPDIR)/fitrslt-fitrslt.Po -rm -f ./$(DEPDIR)/gimg2gra-gimg2gra.Po -rm -f ./$(DEPDIR)/legend-addin_common.Po -rm -f ./$(DEPDIR)/legend-legend.Po -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_addinDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-pkglibexecPROGRAMS 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 ./$(DEPDIR)/fft.Po -rm -f ./$(DEPDIR)/fitrslt-addin_common.Po -rm -f ./$(DEPDIR)/fitrslt-fitrslt.Po -rm -f ./$(DEPDIR)/gimg2gra-gimg2gra.Po -rm -f ./$(DEPDIR)/legend-addin_common.Po -rm -f ./$(DEPDIR)/legend-legend.Po -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_addinDATA uninstall-pkglibexecPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ clean-generic clean-libtool clean-pkglibexecPROGRAMS \ 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_addinDATA \ 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-pkglibexecPROGRAMS 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-dist_addinDATA uninstall-pkglibexecPROGRAMS .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: ngraph-gtk-6.08.00/osx/0000755000175000017500000000000013375640234011550 500000000000000ngraph-gtk-6.08.00/osx/Info-ngraph-gtk.plist.in0000644000175000017500000000236513071153662016110 00000000000000 CFBundleDevelopmentRegion Japanese CFBundleExecutable ngraph-gtk CFBundleName ngraph-gtk CFBundleGetInfoString %VERSION%, (C) 2003, Satoshi ISHIZAKA, 2017 Hiroyuki Ito CFBundleIconFile ngraph.icns CFBundleIdentifier com.github.htrb.ngraph-gtk CFBundleInfoDictionaryVersion 6.0 CFBundlePackageType APPL CFBundleShortVersionString %VERSION% CFBundleSignature ngrp CFBundleVersion %VERSION% NSHumanReadableCopyright Copyright 2003, Satoshi ISHIZAKA, 2017 Hiroyuki Ito, GNU General Public License. LSMinimumSystemVersion 10.4 GtkOSXLaunchScriptFile ngraph-launcher.sh ngraph-gtk-6.08.00/osx/ngraph.iconset/0000755000175000017500000000000013375640234014472 500000000000000ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_512x512@2x.png0000644000175000017500000027643313070106167017442 00000000000000‰PNG  IHDR+ƒsBIT|dˆ pHYsì8ì8q+Ê8tEXtSoftwarewww.inkscape.org›î< IDATxœìÝw˜UÕÝöñûÌ "͆؃F ÖÄ7V¢tÄ–h+Á5–ÇXbæ¬`4F ÆKLa†^¤W¥Z¤#½(M¤ e†™óþ±%A˜™³ÖY{Ÿóý\—Wòæžås„Y÷oï½vL–uéÒåì²²²Î’ÚHŠ9ú63%µ0Ælr”@Zqõd ÿ½ÍªZµj‹§Ÿ~zc ¾‘Æ$ÍCñßÛlwlHñ÷ R€Jó\ü÷6GRs†ìPa!*þ{[(©©1¦À÷B£°üÀÒâ¿·EUªTiÚ±cǵ¾@Ø„ñ7™ÿ½1à„ý8ðÈó3IqI×(Zûà{¢ôƒ¤HÄ®øïÏ’œœœ¦:uúÒ÷Bƒ¨þ@DøŠÿþ0à[éðƒ$)M®øïÏ IMŒ1+<¯¯Òí<¨€°]ñ¯U«– ]D/ÏÉÉiÒ©S§Õ.ˆï?è@ê…튃 Ô¬Y3Õ«WOýúõÓ’%K\|›•ÙÙÙM:wîü…‹pÂÎû|:a-þÇ{ìÿ^ii©Ë!À*|î"€0óþƒ¸…â¿·ÒÒRõïß_‹/vñíWegg7íܹórá„•÷ p'jÅoއ«%55Æ,s@yßû¢\ü÷VZZªhÑ¢E.–µFÁã Áû†Ø“.Åoeee0`€.\hqeÿU ©™1f‹pÂÄûÆ$/‹ÿÞ‰„ ¤Ï>ûÌJÞ÷¬ËÊÊj–››;ßE8aá}ƒ*/Ý‹ÿÞïPq™Tü÷–H$4xð`Í;×Eü× ˜ç"ß¼o@ùejñß›ë!@VVVóÜÜ\'·à“÷88Šÿw% 2DsæÌq¿^RscŒ“ ¾xß@€ý£øï_"‘ÐСC5{ölñ›%µ4ÆLw€Þ7`_ÿòI$9r¤¦OwÒÓ·deeµÌÍÍæ"€Tó¾¡ÿCñ¯¸D"¡Q£FiÚ4'=}‹¤VƘO]„JÞ7€âŸ,×C€¬¬¬+rss§º U¼o0Èd{‰„F­O?ur±~«¤+Œ1S\„ Þ7d"Š¿‰DBcÆŒÑÔ©N.ÖoÍÊÊj››û‰‹p\ó¾á “PüÝs<(ÊÊʺ*77w’‹p\ò¾ñ PüSoܸqúè£\DIºÚ3ÑE8®x߀Î(þ~?^~ø¡‹è¢X,vM<Ÿà"¼oDHGÿðp8Ø.écÌxáØæ}C@:¡ø‡Ó„ ôÁ¸ˆÞ.é—Æ˜±.°ÉûÆ€t@ñ¿‰'jÒ$'g÷ít-C@Øyß eÿhq8Ø%©1f¸‹plð¾Q Š(þÑõñÇkìX'ëwÅb±¶ñx|˜‹p’å}Ã@”PüÓƒÃ!@±¤¶Æ˜¡.ÂH†÷ Q@ñO?“'OÖûï¿ï"º8‹µ‹ÇãC\„PYÞ70„Å?½¹HºÁ3ØE8•á}#@Qü3Ç'Ÿ|¢÷Þ{ÏEtI,»!r@EyßÐ&ÿÌ4eÊ3ÆEti,kÇ{» "¼olŠ?¦OŸ®#F¸ˆ.ÅbâñxOá”—÷ >Qü±·3fhøðá.¢K%ÝfŒéá"€òð¾ÑÀŠ?ögæÌ™>|¸‰„íèÒX,v{<ïn;€òð¾á •(þ(—CIwcòmp0Þ7>¤Å5kÖ, 6ÌÕwÆãñ<ÛÁˆ÷ .Qü‘ ‡C€²X,öÛx<þÛÁì÷.Püa˼yó4pà@C€D,»?¿i;€â}C€M¸0oÞ< 4Heee¶£’0Ƽa;€ïó¾1ÀŠ?\›?¾èjð 1æuÛÁìÍû €dPü‘J.‡±Xì÷ñxü5ÛÁìá}£@ePüáË‚ ôî»ïº<Ç_± €‚ AñG,\¸P põ8À#Ƙ¿ÙÀûÆ €ò ø#l–,Y¢~ýú©´´Ôzv,{:ÿÙz0 £yß@p „ÙÒ¥KÕ·o_WC€NñxüYëÁ€Œå}#À¡ø#*–-[¦¾}ûj÷îÝ.â;cþä"y¼o¨ØÅQäx7Ætq È,Þ7VHDßòåËÕ§O'C€X,fâñø­2Š÷  ³Qü‘N\$ýÅó¤‹`@fð¾Ñd&Š?ÒÕÊ•+Õ³gO•””¸ˆg¨4ï.@f¡ø#¬\¹R½zõRqq±‹ø1»¤7ï/@f ø#Ó¬ZµJ={öt5xÉó˜‹`@úò¾¤7Š?2™ã!@WcÌ£.‚éÉûF ž(þ@`õêÕêÑ£‡«!ÀËÆ˜G\Ò÷  ½Pü}­^½Z={öÔ®]»\Ä¿eŒ¹ORÂE8 }xߘÒÅ8°5kÖ¨G®†ocîCÀxß ¢â”ßÚµkÕ½{wíØ±ÃEü;’~gŒ)sˆ>ï5@4QüÊaðÅû† - yÊÏÏw5ø—¤»¾ÏûÆ  À.ÇC€Kº‹!`oÞ7p€p£øî¨{÷îÚ¾}»‹øÞ 6lß®]»Rá€èñ¾‘„ÅHuëÖ)??ßÕ ¤öƘÝ.ÂÑâ}CŠ?z6lP^^ž¶mÛæ"¾¯¤[¼oìá@ñür<è'é†Ù¼oð~Qüðظq£òòòôÍ7߸ˆï_¿~ý[î¹çžá€ðó¾ÑøAñÂÉñ`@ýúõof™Éû†Z ü†~øám|ðÁ].Âáå}ãH Š?-›6mR^^ž ]Ä8üðÃÍ2‹÷ À-Š?][¶lQ^^ž¶lÙâ"~¤¤_cvº„÷ À Š?¶nݪnݺ¹Œ’t=CÈ Þ7„»(þ@úÙºu«òòò´yófñ£%]ÇÒŸ÷!ÀŠ?ÞÞ«U«Ö¯yä‘.Âáà}ƒHÅÈ………êÖ­C@¥xß(*‡âd¦ÂÂBåååiÓ¦M.â?t•1f›‹p€_Þ7Œ€Š¡øضm›òóóµ~ýzñJº’!¤ïG@ùPüì­¨¨Hyyy®†U¯^ýÊ'žxâá?¼o Fñ°?އW¯^½5CHÞ7’€FñPEEEÊÏÏ××_í"þcº¤–÷ %à»(þ*Êñ`²¤Ö  ú¼o,Š?€dlß¾]ùùùZ·n‹ø’Zcœ¼zÞ7˜é(þlÙ¹s§òóóµvíZñ3%µ`Ñå}£ ™ŠâÀ…;wª{÷îúꫯ\ÄϪZµj‹§Ÿ~z£‹p€[Þ7œi(þ\cø!Þ7ž)(þRiçÎêÑ£‡¾üòKñ³<°ÁE8À ïPHw¾ìÚµKÝ»ww5˜#©9CˆïQHWa°k×.õèÑCkÖ¬q¿PRScL‹p€]Þ7¤n(þ¦¸¸X½zõÒÊ•+]Ä/ªR¥JÓŽ;:yõÀïSHaVRR¢^½ziÅŠ.âIjfŒqrê ÀïTˆ:Š?€¨p<X¬àq†RÞ7ªUQTRR¢Þ½{ë‹/¾p¿$''§i§Nœœ:HŽ÷ +D Å@Ô9,ÍÉÉiÂÂÇûÆ¢‚â ”””¨OŸ>úüóÏ]įÔijÂE8 r¼o` ì(þÒÕîݻջwoWC€•ÙÙÙM:wîìä6@ÅyßÈ@XQüd‚ÒÒRõë×OK–,q¿RÁÁ€N& €Šñ¾¡€°¡øÈ4¥¥¥êß¿¿/^ì"~UvvvÓÎ;/w(?ï[ Š?€Læx°úÛÇ€GÞ7¸àÅ¥¥¥0`€-Zä"~µ‚Ç–¹œ÷.øBñ€}9|û8ÀBá€ó¾á€T£øÀ•••iÀ€Z¸ÐIO/Ô̳ÀE8`ÿ¼o| U(þP~‰DBƒ ÒgŸ}æ"~]VVV³ÜÜÜù.Â?Ìû\£ø@å8|­àN€y.Âûò¾W(þ¼D"¡Áƒkîܹ.â¿ÎÊÊjž››ëdÂø.ïb°âv% 2DsæÌq¿þÛÇ€cÞ7Æ` ÅÜq=ÔÜãä6@Àû’Eñ€ÔH$:t¨fÏží"~³¤–Ƙé.Â!Ø(@eQü õ‰„FŽ©éÓôô-YYY-sss§¹€Lç}à Eñ¿‰„F¥iÓœôô-’Zc>u™ÌûÆÊ‹âááx°5++«UnnîT᩼o à`(þN‰DB£GÖ§Ÿ:¹X¿UÒƘ). yßHÀþPü ü‰„ÆŒ£©S\¬/ÌÊʺ"77÷ái¼o¨àû(þ-އE’®6ÆLt™ÄûÆö ø@´7N}ô‘‹è¢X,vM<Ÿà"2…÷ 6Pü }Œ?^~ø¡‹èí’®1ÆŒw™ÀûF@æ¢ø@zš0a‚>øàÑÛc±Øµñx|œ‹pHwÞ7Ü2ÅÒŸË!€¤_cƺ€tæ}ã sPü ³Lœ8Q“&Mr½#‹ý2¿ï"Ò•÷ 8€ôGñ€ÌõñÇkìX'ëwIjcŒî"Ò‘÷8€ôEñHN‡Å±X¬M<æ"Ò÷ 9€ôCñ|ŸË!€¤¶Æ˜¡. xߘHÀLž]#FŒp]*é7Ƙ^. ʼoÜDÅ`ÓŒ34|¸“·ø•Æb±ñx¼§‹pˆ*ïxáGñ¸âr é6cLáEÞ7ò‹âH…™3gjøðáJ$¶£Kc±Øíñx¼»í`ˆ"ïzáCñ¤šã!Àñx<Ïv0D÷=€ð ø|š5k–† æbP&éNcL7ÛÁ%Þ7øü£øÂböìÙ:t¨‹!@"‹ÝÇß´ Qá}£ÀŠ? ŒæÍ›§Aƒ©¬¬ÌvtBÒƘ7l@xßðH=Š? ì\b±ØÿÅãñ¿Û€°ó¾ñ:@”ÌŸ?_tu'ÀƒÆ˜×m@˜y/Ü£ø¢jÁ‚z÷Ýw] 2Ƽj;ÂÊ{àÅ\b±ØÃñxüÛÁFÞ û(þ€t³páB 0ÀÅ@’ž2Æ<ï"ÂÄ{1`ÅΖ.]ª¾}ûª´´ÔE|GcÌs.‚ ,¼É£ø2…Ë!@,ëÇŸµ !á½(¨<Š? -[¶L}ûöÕîÝ»­gÇb±Üx<þŒõ`ï…@ÅQü‘ÉÊʤÏ?—V­’Ö¬‘ ¤ÂBi÷n©¨HªQCª^]ªUK:öXéøã¥SO•êÕó½r6¹HŠcº¸Ÿ¼åGñG&*,”Æ—Æ“¦O—>û,(úU¯žtÞyÒEI-ZH^(åäØ_/€ÔY¾|¹úôéãêNÇÿh=<ò^ Å™fófiÀ©woéëû¶Õª%]stóÍRË– €¨r9ôcÌ“.‚ÀïEÀþQü‘iæÌ‘þúW©o_©¸8uß÷裥ûî þ:ê¨Ô}_v¬\¹R½zõR±›?8^0Æ<á"RÍ{¡°/Š?2ͬYÒSOIcÆø]GõêÒ]wI;KGéw-*ÆñàEcÌã.‚ •¼ ÿCñG¦)(ž|RêÞ=8Ü/,êÔ‘ž~Zzøa ¢dÕªUêÙ³§«!À_1p ©â½` ø#3  Ý{¯´aƒï•ìß9çHùùÒ¹çú^ €òr<èjŒyÔE0¤‚÷¢d2Š?2ÑÎAñïÖÍ÷JÊçC¤W^‘î¾Û÷J”×êÕ«Õ£GWC€—¿$\„€KÞ ‰(þÈTk×J×]'Mê{%÷ÿ'uíÊ#@T¬^½Z={öÔ®]»\Ä¿eŒ¹O DŒ÷âdŠ?2ÙŠRãÆÒÊ•¾WRy¿ú•Ô¯ŸT¥Šï•(µk×*??_;wîtÿcÌïÄ@„x/ @& ø#Ó­^”ÿÏ?÷½’ä]½Ô§C *Ö®]«îÝ»kÇŽ.âß‘ô;cLˆŽ1€ýó^D€tFñ¤­[¥ /”/ö½{îºKúÇ?|¯@y9üSÒ= D÷B¤#Š?H$¤6m¤}¯Ä¾·ßæ`@ J ”ŸŸïjð/Iw3vÞ‹ N(þÀw½ø¢ôøã¾WáFµjÁa†¼"ˆŽ‚‚uïÞ]Û·owÿoIw1fÞ (þÀ¾V®”θËE8”—÷b„ ÅHNa¡T·®T–ì[°ï’ô¶Ró»pƒ¤&’’¼…¿qci ëàͦM›”——§ÂÂBñ xç½àa@ñì˜4)(ÂI¹\ÒXI9ɯ§Ü¾ôSo¨¤Úµ¥Í›¥˜÷?A$cË–-ÊËËÓ–-[\Ä’t½1f§‹p8¶)ÈhÀ®W^‘z(‰€lWâϰ´ ŠxYÒ#ÉE,_.5h`e5<Úºu«ºuëæj0ZÒu øà½ð>Pü7:v”ž{.‰€k% ±µš *’TïÛÿ¬¤É“¥‹mXˆƒÛ¾]:ôPß«@šÙºu«òòò´yófñcjÕªuÝ#<²ÃE8ìO–ï©Ô¥K—³1ýÊÊÊæHj+Ïå¿Aƒºë®»Ô¾}{Ê?ÒBÒËšXYFåÔtar›6YY *båJ鬳¤7ßô½¤™Úµk«C‡ª[·®‹øV………ƒ»víêò˜SØG*Ÿ°¼ÙsÅ¿¬¬Œ+þ€CEI\=—$ne•wdr_žô??*fÕ*©Ié‹/¤ûï— é¾û|¯ i¤víÚºí¶Û”——§Mö'|- G½øâ‹W=öØcüé % ­QüÔªY3É€µV–Qy_&÷åµjÙYÊaÕªàÄÉ/¾þïDBzàà?ï¿ßëÒ^jÕª¥:¸\^TT4Òs•1f›ípø>ï…pgü?:u’ž}6‰€Ë%M´´˜ŠÚ é8IÅ•˜2Eº0ÉÇP«WåÿóÏ÷ýßb1éÕWƒa`ѶmÛ”ŸŸ¯õë×»ˆÿPÒ• ¸æ½6Qü¿Þ|ÓÂØ“%ù8HïiIN.bõjéøã­¬û³fMPþ—/ßÿ¯‰Å¤¿ýMzðÁ”- ™¡¨¨Hyyy®†U¯^ýÊ'žxâá …  6Püp˜:Uºè¢$CJš*é0 *¯i’)©«ÿG%}ýµ­á­Y<ó¿lÙÁm,&½ü²ôûß»_2Šã!ÀÇÕ«WoÍ€+Þ‹ Š?.;vÏÁïÞdPK¯<Ä¢f‰¤ÆJúü+®F²°ü°uë‚ò¿pažîÏ–ž|ÒÍš±ŠŠŠ”ŸŸ¯¯ÝLý&KjmŒ)t ³y/L@ePüðjÜXš4ÉBÐ%’Hªo!k>P𧈅 y/½$=úhò9øëÖIM›J TîëŸ{Nzê)»kBÆs<˜^­Zµ–O=õÔfá2W¶ïÑ¥K—³/¿üò׉Äk’Δçòß AµiÓF5Rͤ?ÒCQ‘4r¤… Õ’ºIª'éÙýÝ^¨à™ÿû$Y8r+“þñ©Nä³ð=_\ù—¤qã¤*U¤Ë.³·.d¼ªU«êÌ3ÏÔòåËUdÿ Ç–––6oܸñ€‰'î° sy¿r ”WüèX»V:ñD ìíÅUù—¤»ï–Þ~Û~.2ÞÎ;Õ£G}ùå—.âgW­Zµ9CÉò^¬€½QüôqûíR·n¾WáWÿ-Û¼YjÞ\š9Ó~öwHï¼Ã´θ(x`ƒ‹p™Á{Á$Š?Ž6n”~ò“àbnºjÝÚÒ‡lÙ”ÿ3ìgß~»ôÏRþáÜ®]»Ô£G­Y³ÆEüœoHã?Y¸ä½h!³QüôÖ«—tË-¾WáFݺҜ9Ò 'ø^IšØ²EjÑBš>Ý~v‡Ò¿ÿMùGÊ8,”ÔÔSà"@zó^¸™(þ@æxàéï÷½ »²²¤aä+¯ô½’4±e‹Ô²¥4mšýìnzö”²yó1R«¤¤D={öÔÊ•+]Ä/ªR¥JÓŽ;®u }y/^È, ó””wuðï•Øóì³ÒÓOû^EšØº5(ÿŸ~j?»]» üçäØÏÊ¡¤¤D½zõÒŠ+\Ä/Vp'€“WHOÞ 2ÅÈl……AÇ›:Õ÷J’÷ðÃR×®¾W‘&¶n•Zµró/FÛ¶Á3(”xÆ@˜x/bHo{lÙt=zSåÑG¥—^ò½Š4ár*Ô¦Ô»7å¡QRR¢Þ½{ë‹/¾p¿$''§i§Nœ¼z@zñ^Èž(þ~ÈöíÁaìýúù^IÅääHû›tÿý¾W’&ŠŠ‚\<òë_K}úPþ:އKÜ àäÔAéÃ{1Cz¡ø8˜DBzî9Éi÷nß«9¸zõ¤î݃êaAQ‘tÕUÒ¤Iö³¯¿>(ÿUªØÏ,())QŸ>}ôù矻ˆ_!©‰1f…‹péÁ{ACz ø¨¨¹sƒ·³Íží{%û×¶­ôÆÒ‘Gú^IšØ¾=(ÿ'ÚϾî:©o_Ê?B¯´´TýúõÓ’%K\įÌÎÎnÒ¹sg'·ˆ>ïE ÑFñŒ;¥—_–ž>x$<,N?]záéÚk}¯$lß.]}µ4a‚ýìÖ­¥Aƒ¤jÕìg8¬Rp'€“Û D›÷†h¢ø°iýzéO’þõ¯àq_N:Izüqé®»¸lÕöíÒ5×HãÇÛϾâ ið`Ê?"§´´Týû÷×âÅ‹]įÊÎÎnÚ¹sçå.ÂD—÷â†h¡øpiÓ&éí·¥·Þ’V­JÝ÷½äéÁƒóã8;β;‚ò?nœýì+®®ürˆýl Vû8CÿE+• IDATå½À!(þR)‘>ü0xûˆÒËçZÇbÒ¹çgÆÝ|³tÊ)vóñ­;‚ç(ÆŽµŸÝ²¥4då‘WZZªhÑ¢E.âW+x;À2á¢Ç{‘C¸Qü„ÁÂ…ÁäéÓƒC,JJÊÿõµjIçüuÑER³fÒÑG»[/$íÚÜR1b„ýì-¤¡C)ÿHeeeêß¿¿«!@¤fƘ.ÂD‹÷B‡p¢ø³Ý»¥‚‚à1‚‚àÜ€;‚¿Ÿ“þ5¤ãþ:ê(ß+Î0ÅÅAù>Ü~v‹Á•ÿêÕíg% 8PóæÍs¿NÁ € ç½Ø!\(þ€¤KmÚHÆÙÏþÅ/¤Q£‚醉„ ¤Ï>ûÌEüº¬¬¬f¹¹¹ó]„ˆïá@ñ$­¸XjÛ6¸=ß¶_üB9R:ì0ûÙ@ˆ$ ï¼àÊÿGØÏÒP"‘И1c4uª“‹õEYYYWåææNrÀ/ï…•Cñ¤L"!Ý{¯ôöÛö³Ï=7¸òOù*$‘Hè½÷ÞÓ”)N.ÖIºÚ3ÑE8¼GT ÅR‰„tß}Ò[oÙÏ>眠üy¤ýl CŒ7N}ô‘‹è¢X,vM<Ÿà"€Þ $ʇâH¹DBzàé7ìgŸq†4a‚tÌ1ö³ 3~üx}øá‡.¢·KºÆ3ÞE8€Ôó^$q`€” R&L˜ >øÀEôöX,vm<ç"@jy/”øa€7‰„ôàƒÒë¯ÛÏ>ýô üׯo?Èp.‡’~iŒë"@êx/–ø.Š?À«DBúýï¥×^³Ÿ}ÚiÒĉ”À¡‰'jÒ$'øïˆÅb¿ŒÇãï»Þ &@(<ñ„ô ösO;-¸òÏÏÀ¹?þXcÇ:¹X¿+‹µÇãÃ\„pÏ{ÑÌt@h<ù¤ô—¿ØÏýñƒ+ÿülRÆá XR[cÌPáÜò^83Å*O?-ýùÏösO=5(ÿÇg?ÀMžÈE8û¼ÑtGñ„Vn®ôÌ3ösO<1¸òÿ£ÙÏP)S¦Lј1c\D—HºÑ3ÐE8»¼ÒtEñ„Z<.uéb?÷„‚òß ýlI™>}ºFŒá"ºTÒoŒ1½\„°Ç{1M7@è#ýñösO8!xÕß)§ØÏ`ÅŒ34|øpÑ¥’n3ÆôpÀï5]Pü‘ðâ‹ÒãÛÏ=þøàÊ?å½3fhĈJ$¶£!罨FÅ/½$=ö˜ýÜcŽ ®üŸq†ýlNÌœ9SÇw5¸Ã“o;@ò¼Ö¨¢ø"寕þðû¹õêåÿ'?±Ÿ À©Y³fiذaN†±XìÎx<žg;@r¼ר¡ø"çå—¥G±Ÿ[¯ž4~¼Ô°¡ýl)ápP&éNcL7ÛÁ*Ï{ Š? ’þö7éá‡íç}tPþÏ<Ó~v„”–JË—K+WJ_~)­['mÞüýmÛ¤Úµ¥*U¤ºu¥úõƒs4øñ0™7ožèbˆÅb÷Çãñ7m¨ïE6ì(þ€Èzå顇ìçfpùß²%xâaìXiútiÞÛnnHÍš%uí*õë'§îû}t0»¹ÿþà¿©äxðûx<þší`åç½à†ÅþùOéî»í—ÿºu¥÷ß—Î?ßnnÍœ)=ùdðëÓ!‡HwÝ%åæJGéw-È, ,лï¾ëêq€‡Œ1¯ÚP>Þ‹®o@Úø×¿‚òo{Ó^§NІÿßÿ³›2ÒOH=zØÿa2j×–ž~:8Ë‘G*.‡±Xìáx<þŠí`ç½ðúBñ¤•ÿ;¸\Lù¯”þý¥ûî“6lð½’ý;ç)//8<H…… jÀ€.†ŠÅbOÇãñ?[p@Þ‹oªQüiç?ÿ‘~û[ûå¿ví üÿüçvsCdçÎউîÝ}¯¤|9$x³ã=÷ø^ 2ÅÒ¥KÕ·o_•º8ýRêhŒyÎE0€æ½§ Å–òò¤;îpSþß{Oºà»¹!òÕWÒu×IŸ~ê{%÷ÀÒË/K99¾W‚L°téRõë×O»wïvßÙó'Áöå½»Fñ¤­¾}¥[n±ÿ^ºÚµ¥1c¤ /´›"+VH—_.­Zå{%•÷Ë_.p.RaÙ²eêÛ·¯“!@,ËÇãÏX°ï…ØŠ? ­õë”Û›ñZµ‚òÑEvsCdõj©qcéóÏ}¯$y×]Ì \$Å1]\øïÅØ6Š? íõï/Ý|³ýò_£†4r¤tÙevsCdëÖàÆ†Å‹}¯ÄžßþVzçß«@¦X¾|¹úôéãjðcÌ“.‚¼d[(þ€Œ0`€tÓMnÊÿðáÁ¥ñ4UVÜ6?|¸ï•Ø÷æ›Òï~ç{È €èò^”“EñdŒwß•n¼Ñ~ù?ôPiĈ´.ÿ’ô ÒOø^…U«JS§òŠ@¤ÎÊ•+Õ«W/»ˆÁ“¦¿[¿¼æÊ¢ø2ÊÀAù/)±›{è¡Á%ñ&Mìæ†ÌʕҙgJEE¾WâÎÏ.}ò‰”í{%È«V­RÏž=] ^2Æ<æ"Èd‘ûÑ¥K—³/¿üò׉Äk’Δçòß AµiÓF5RÍš5}.®FŽ”Úµ“lo²=T6LjÚÔnnÝt“´p¡ïU¸õÕWÒQG¥õ›2µk×ÖI'¤ ¨ÔöÛH¤K7n\sâĉïÙ2™÷+çåÅ`_eeÁ«¬V­ Nµ.(®níܼ,;[ªY3x´÷øã¥ãŽ“N=5Ø "ºøÜ3̨QÁQï»vÙÍ­^=(ÿÍšÙÍ ¡?–5rüMŽ’tž¤’Ž“T]Òa’¶JÚ&i•¤Å’>“´ÝÝ2ê×ÞnpÈ!î¾ð}ŽïèjŒyÔE0‰¼郡øÿóÍ7ÒÄ‰ÒØ±ÒŒÒܹÁß«¨úõƒçD/ºHjÑ"¸ZÄ-£áÅçžÁF–~õ+ûå¿Zµà‘‚+¯´›RW_q`Ý’n”ÔZÒåüšIS$ “ÔGÒjûËâ@@ø°zõjõìÙS»lÿyxËsŸ¤„‹p “x/ÔûCñ[¶ûô^½¤>°ÿø¯$Õ®-]{mðV±æÍ¥œûßÃç”ÿ;íæV­üËuÕUvsCjÙ2é´Ó¤„­Ú“ÔVÒ“’~šdV©¤Á’ž•4+ɬ½4l(ÍŸo/(/ÇC€·1÷Š!ïÅúû(þ@à³Ï¤®]¥Þ½í_ü;cŽ‘î»Oº÷^éÈ#S÷}às‡$é½÷‚÷Õ¹(ÿH×\c77Äž^zê)Ka?‘ôIZÊÛ£LÒ¿$ýAR¡Èyó‚CT[»v­ºwï®;v¸ˆÿ‡¤{1e.ÂLà½`ïAñsæ›ÕÑ£-^±ª„êÕ¥{î‘:u’Ž8Âß:2Ÿ;þëý÷ƒ[3(ÿVœ¾4s¦… ›”ôê²ög™¤k%Y8¬07Wúã“Ï*ÃñàI¿cTŽ÷¢Mñ_ÀnÝ‚CÞ¢n]©cGé÷¿çqøÜñï¿\ù·½i®ZUêß?,dÂÂàßå¤oÝ-é-¥f—²ARS‡&áò˃³C_þ)é†@Åy+ÜàFŒîºKZ»Ö÷Jöï‚ ¤¼<éŒòt…ƒâsÇw|ø¡ÔºµýÕW©”ÿ_þÒnnLš$5nœdÈå’ÆJJå l…‚7 l­|D­ZÒæÍRV–¥5•PPP üü|WC€Kº‹!P1)/Þàví’î¿_ú׿|¯¤|ªW—^{MºóNß+‰6>wìãÃù·m³›[¥ŠÔ¯_p˜`zå顇’È–4_Òé–T¯HJfí @<å+«*­  @Ý»w×öíNÞùI¿e”_Ê 8Åø®uë¤ë¯—&Oö½’Š{è!饗x…\eð¹c}\ù·]þ³³¥=¤o´›!;JÏ=—DÀ5’†ÚZMm—TORÿZ|ü±tÉ%¶TÞºu딟ŸïjÐGR{cÌná@ºq^Ä)þÀ¾V­ nKýâ ß+©¼ë¯—úô .0¢|øÜ±?Êÿ7ߨÍÍΖºw—nºÉnnÄÜ¿ôÆI¼¬¤¯Â'¥¹¤q•ÿòáÃ3æmˆ€ 6(//OÛl;}%ÝÊ88gO†uéÒålcL¿²²²9 Þ˜ëµü7hÐ@wÝu—Ú·oOù‡WkÖHM›F»JÁkÄoºIÚÍÚrásÇ>&OvWþóò2¾üKŽS8ÜÊ2*/ÉWrÚ>NHÆ‘G©:è°Ãsƒ¤žÆŽ­Âúœ]ºt9ûòË/=‘H¼&éL… ø·iÓF5RÍš5}.Ð7ßW€—,ñ½;. N±¿újß+ 7>wìã“O¤+®pSþ»u“n½ÕnnD'}úiIjdk5•ðФU•ÿò;ï”N=ÕÚj€¤zè¡:í´Ó´hÑ"ÛŽ?SÒO7n]»J>ê{nT«\e;çß+ >w|ÇÌ™RóæÁûÙlÊÊ Êÿo~c77âÞ|Sºï¾$C&KºØÆj*¨“¤g“‹XµJ:á+«¬Û¸q£òòòôíahàÝúõëßtÏ=÷”¸¢,éÂþík7¼ÿÓO?]—_~¹êׯï{)À>V­’Î<Óþ!ßarÁÁ#Íœÿ?|îøŽY³‚ò¿i“ÝÜXLzë-éî»í榩S¥‹.J2¤¡¤©’œ<¶¼ÓáÇçne%ѱlYPþ¿üÒ~ö3ÏH;ÚÏÍp/¿,]v™ïUØÕ¥‹tÕU¾W¸S£F ýæ7¿q5¸tÇŽ£1I>DCh’4uêT†ˆ¬¢¢$œÜíVG&÷åIÿóGŸ»eDÂÊ•R‹nÊ—.R§Nös¡*U¤aä “v…ÅC1'Bfp<¸DCd„P$iÊ”)š8q¢ïeV3Ù›ÉêÔ ^[Ù¦ï•T\NŽôÚkÁ› €Ls衇ê¶ÛnsõÊðó%½Ïé,I7nœ>þøcßËÊí¸ã’ øP’¯å»J*N."éþˆâs·²’ðZ½:xæßÅë{LúË_ìçb¿=Tê×/xâ"'Ç÷jÊç裥#¤ð½ÀŸC9DíÛ·w5ø™¤±Ï=÷œï‡ò'"3¤±cÇjÚ´$/O)ò³ŸYù­¤o,äTħ’’¼ªtÔQÒñÇ[YMäð¹[YM8í)ÿŸn?ûÑG¥^°Ÿ‹ƒŠÅ‚'.¦O—Î=×÷j¬MiÞ<©eKß+üÛ38ÎÍäù§ÅÅÅc1IžŒ„O¤’4räH͘1Ã÷2€ƒ:çœà°©¤,’t½¤TÞï÷K%}øüóm,&šøÜÓÔš5Aù_¾Ü~ö#H/½d?rî¹Ò”)Á›“>ËòÓN“ ’ú÷mއçIb€´“ÌàDI¯ØZHEŒ1BsçÎõñ­r;äéÒK-•ÔD’ƒWŒÇDI¿dá=îÍ›'ŸU|îi¨  8íßEùøaä‘C NÔ_ºTºÿþàŸN8!xÖÞ<éW¿ò» ¬ªU«¦öíÛëx7· +écÌ1.Â*38YAñ_"éA««)§D"¡ÁƒkÞ¼y>¾=PnmÛZ š*élIÿ‘Tf)s­’–ÔLÁ!pIŠÅ¢y¨–M|îidÝ:©iSiÑ"ûÙ=$uíj?I«WOzýõàMÏ<ñTºè"©gÏ`æôÀî*Ò\µjÕtë­·ºüDÒ„gŸ}¶¾‹p Õbøµ?’ô¤¤;$ý÷¨cŒå%•_VV–Úµk§ÓO?ÝÛ€Y·.Ø8–”X =GÒc’ÚIªšDÎ×’Þ’ôš¬À=.¾Xš<Ù^^ñ¹§‰=åÁûÙ¿ÿ½ô·¿ÙÏ…eeÒH½zð}eùΜXL:ûléºë¤[n‘~üc»ù@¦())Q¯^½´ÂÅ[Z¤EUªTiÚ±cGß/ì’Rž@CÅÿ&íUü÷ð9¤ììlÝpà ú1?-R·ß.uëæ øpω_!©‘¤ƒ½7¡à¾ ’FH#ÉfAýVÿþiz%¸‚øÜ#î믃ò?¾ýì»ï–Þz+h}ˆ¤ùó¥qゃgÏ–.”vï.ÿ×׬œ9pÞyÁÕþfͤc¸Á°Âñ`±¤¦Æ×èÎh÷q–¤Ç%Ý,){¿È÷@ †7Þx£N=õTßKö±x±Ô°apÉ©c%5t¼¤Zßþ½2Ië÷ˆY¿>¸ÛEù¿ãÊ?¤P•*UtÓM7©Aƒ.â¼{÷îŒ1'»\Ê’t‰¤a’fIj«Š *{†_Ù>HÒá‡K¯¾ê{î~xðH3¾‹Ï=B6o–Z·–>ûÌ~öí·Kï¼Cù€s<8YÒ„gžyæG.ÂW²%­’tZe7nœÔªT©¢2‹É–––jÁ‚:å”ST³fMk¹@²Î:+èS§ú^‰]YYÒ€Òùçû^I8ñ¹GÀ–-RË–ÒŒö³o»Mú׿(ÿàIVV–Î:ë,hãÆ¶ãë$‰_5kÖlÈ„ ¶Ø\ð¾#¹òÊ+UÅò nwîÜ©=zhýúõVsd½ô’Ô¤‰ïUØõì³Á…SìŸ{ˆmÙ"µhçnÛ7Jÿü'å<ËÎÎV»vítÚi•¾æy '•––N4Æ8¹Í°Íû®¤^½zjÙ²¥²³÷û¢JÙ¾}»òòò´aƒÅ]IªRE6Lºì2ß+±ã‘G¤'Ÿô½Šðãs©­[ƒ+ÿ.Ê»vR÷î’åŸm€ÊÙ38ýôÓ]ÄŸ¨àq€S\„6yHÒqǧV­Z)ËòU’¢¢"uïÞ][¶pG£F ièÐàÝÏQöØcÒ_ÿê{ÑÁç2{Êÿ´iö³Ûµ“zö”rrìg*-;;[mÛ¶u6(--`Œá½äµP $éøãWóæÍ­ Õ­[7†•Úµ¥ñãƒ;„£&'Gzã é…|¯$zøÜC¢°PjÕJúôSûÙmÚPþ Äö Î8ã ñ'Hb€PË–d’ HöÀó÷:AªN:ªS§ŽV¬X¡D"‘TîÞvíÚ¥¥K—ªaƪV­šµ\ UªH¿þµtÈ!ÒHÏÂtæ˜c¤ƒ œ¨>wÏŠŠ¤«¯–&O¶ŸÝ¦Ô»7åB.++K 6Ôúõë]<.\KR»Æš8q"’!tBsÀ 4Ðe—]¦XÌîÛ7mÚ¤¼¼ÛEü1’ÆwéÒåLá@2B7¤ÓN;M—98-kãÆêÑ£‡vìØa=HÆÙgKŸ|"=ÿ|p›x˜üä'ÁvýúIGé{5é…Ï=…ö\ùwUþûô nïDF,Óu×]çjP¯¬¬lC„M(’túé§ëÒK/µž»nÝ:åççkçÎÖ³dT«&=ñ„´l™ôÐCÒa‡ù]ÏÉ'Ko¾)Íô&¸ÁçžÛ·ÿ0'ÚϾòÊàÊ?å"iÏàœsÎq_¯¬¬l¼1æ,á@e„v Igžy¦.¾øbë¹êÙ³§Š‹‹­gÉ:òHéå—¥U«‚+Ã'Ÿœºï‹II}û…ôw¿ãŽæTáswÄeùoÝ:8³e Òb±˜~õ«_¹-i\—.]œÜfTTLRR§íc’ZÀÝwß}Ð_3sæLMwðžæN8A·Þz«ªV­j=°%‘Î+ëÙS1"(ˆ6eeIç']wtË-Ò~d7•ÃçnÁöíÒ5ׯ^°íŠ+¤Aƒ‚Ói!‘HhÈ!š3gŽ‹øõ’šcæºÊ+Iš6mšfÍš•Ô÷ú! 4ÐM7ݤœ´¹Ü…t·x±4nœ4}º4{¶4¾T‘›YêÔ Šßyçï¤oÖ,MžñNs|î´cGPþdzŸÝª•4x0åÒP"‘ÐСC5{ölñ›%µ4ÆØ¿² ”Sd’4uêT'¹SN9E7Ýt“²³³­g®••IÁâ‚‚ ÷|óÍÿþ÷ºu¥êÕ¥O”Ž;N:âk…=|î°kWð®Å#ìg·l) Bù€4–H$4räH'w KÚ’••Õ277wš‹pà`"5¤)S¦hî\ûwΜqÆjÛ¶­²²B},à@Š‹ƒSù]”ÿ-‚ò_½ºýl@¨$ 5JÓ¦9éé[$µ2Æ|ê"8ÈµÝ /¼P 6´ž»hÑ" 0@eeeÖ³)P\ìîÊóæ”È ±XL­[·ÖÏþsñu$éҥ˅.Â‰Ü ‹éÒK/Õgœa={áÂ…2dˆ‰¤nФZq±Ô¦4|¸ýì_ü"xæŸòeÏà‚ .p_§¬¬lŒ1æ"áÀþDn ¿ñ‹_èÔSOµž=wî\ :”!DEq±Ô¶­4l˜ýìF¤‘#¥5ìgB/‹éŠ+®Ð…:¹X_[Òè.]ºØï9°‘HÁoÆ&Mšè”SN±ž={öl >œ!„]I‰Ô®4t¨ýìK/•F’;Ì~6 2b±˜ZµjålPVVö~—.].w|_dÒÿ†'t’õì™3gê½÷Þ³ž °dOù2Ä~ö%—PþÿµçN€F¹ˆ¯QVV6ÂÓØE8°·H$)++K-Züöî;*ªkmø3 (EPTD”"(Rl Ø°ÃØ°ÄDH7íÒôLL$cb®àk5 R¨±ÅEÔ ˆ»ˆˆ„óý1¾äÆÌÞœ™áý­u×]+Ê3o ³Ÿ³Ï>°²²bž}ðàA*!DÕÔ³f)ïÍgÍË HOÚ¶eŸM!D£ >>>><¢¤( ?á„ÔÑøøÿÀÒÒ’yö°gÏ湄Bš¨¦˜9ؼ™}¶§§òÊ?-þ !„<¿¿?·@ÅAüy„hI­ZµÂÈ‘#aaaÁ<;''ûöícžK!¤‘jj€Ù³M›Øg»»+!hbÂ>›BˆVñ÷÷ÇСCyDH!€G8!ZSÿ_têÔ‰yöîÝ»±ÿ~湄B¨¦˜3ذ}¶›™ ´oÏ>›BˆVòóóða\Îî3°ƒJƒV ¯¯1cÆ cǎ̳333qäÈ湄Bž¡¦xî9`ýzöÙ®®´ø'„Ò$¾¾¾¼J)‚ ó'-—Ö€²=z4Úsø0·sçN=z”y.!„'¨­æÎÖ­cŸÝ¿¿rñofÆ>›BH‹àëë‹€.ë[HR(cy„“–I+ hÓ¦ ‚ƒƒÑ®];æÙ)))ÈÏÏgžK!äˆ"ðÒK@|<ûì~ý€¬, CöÙ„BZooon%€(ŠI‚ ŒãNZ­-ÀÀÀcÆŒ ãDQĶmÛpòäI¦¹„BþB—_ââØgÓâŸBcÞÞÞ ä­ Q¡PŒçNZ­.ÀÈÈÁÁÁhËø‘N¢(bëÖ­8sæ Ó\B!P.þ_yX±‚}vß¾ÊÅ?‡³b!„´l^^^ÜJQA˜À#œ´Z_€±±1ÆŒCCC¦¹µµµHHHÀÙ³g™æBH‹&ŠÀ«¯ÿþ7ûlGG #ƒÿ„B¸ñòòBPPh} …b"pÒ2´ˆLLL0vìXæ%@MM PRRÂ4—BZ$Q^{ øþ{öÙ½z99€…ûlB!ä/<==1bÄÑz¢(&*Ši<‰ök1˜ššbôèÑhݺ5ÓÜGaãÆ8þ<Ó\BiQDxýu`ùröÙ´ø'„ÒÌŒ1cÆðˆÖEqB¡˜Á#œh·U€™™‚ƒƒ™—ÕÕÕØ´i.]ºÄ4—BZQÞxøî;öÙ@v6Ð¥ ûlB!ä)<<<Ì#ZWŵ‚ „ñ'Ú«ÅСCŒ5 úúúLs>|ˆõë×ãòåËLs !Dë½÷°lûÜž=•Wþ--ÙgB! àîcÇB&“±ŽÖ°F¡PÌdL´W‹,ÀÜÜ£F‚žžÓÜ`ýúõ¸víÓ\BÑZï½ÄİϥÅ?!„5áææ†àà`.%€(Š«A˜Å:˜h§[@çÎ1jÔ(´jÕŠiî½{÷7n0Í%„­óþû@t4û\ 3èÚ•}6!„Ònnn×ÊJyåŸÿ„B4ÏÀw‚ ¼Ê:˜h>*þ‡†ʼ¸uëÖ®]‹ÊÊJ¦¹„¢1¾øP(Øçvë¦\üÛÙ±Ï&„B8rqqáY,S(¯±&š €ÇèÕ«†Ê<÷ÆX·nîß¿Ï<›BÔÚ—_‘‘ìsëÿööì³ !„fàââ‚É“'óºà…B1Ÿu0Ñ\T×Ü\¹íßÙ™}6!„"¡: K—.(((€(Ьã‡ûùù=ÊÍÍÝË:˜h*ÀÒÒ555¸rå ÓÜòòr\ºt ...<¶ûBˆt–.Þz‹}®¹¹òÊ¿‹ ûlB!D tèЖ––8uêjkkYÇûûúúÖäææîaL4 ÔµkWÄõë×™æÞºu ×®]ƒ³³3óÇBH³Z¹xõU€õ¶ÅN€Ý»>}ØæB!jÊÌÌ ]»vEAAÀÏÏÏT´û wîÜ£££ÔãpU[[‹¤¤$Lž<?üðnÞ¼‰íÛ·ÃÞÞ}ûömöyÌÌÌ`ccƒ“'Oò¸X8Ä××× 777‹u0QO´  d2üüü`ooÏ<;//ÉÉÉ‹ÿ]»¶¹„B¤ªª qqqèÑ£¢¢¢PVV@¹-^.—K¶%ž—¬¬, 0ãÆC^^ÞcOMM æÌ™ƒuëÖ5ótJœK€ ‚ð%`¢^¨PŽŽammÍ<ûСC-®ÈÏχ\.‡§§'RRR(ßhç΋5kÖH;!äŸÖ¬^xýâßÔÈÈ `›K!䙪««;;;DDD<ö1Ø555˜5k6lØ Á„líÛ·Æ C`` ~ûí·gþþšš<÷Üs’] ²¶¶æY¼#ÂbÁD}P ¢º k׮̳<ˆÜÜ\æ¹ê¦  r¹ýúõCbbâ?~½¶¶sçÎÅŠ+$˜ŽòX›7ó]üÈ6—BÈSÕÖÖ"11NNNˆˆˆÀ¥K—žúû¥Þ¯ª >>>سgO£¾¶î•”%@XX¯à-A–ð&êd@GGvvv¸rå îÞ½Ë4ûüùóÐÕÕår«ÔJJJ‰ððpœ8q♿?55:uº*Hˆ´€°0 ¦†m®‰‰rÛÿ Als !„<Ñ_¼[±bEýVÿ†E;vì@÷îÝѯ_?ŽS²süøq¼öÚkxûí·Q\\ÜäQ±}ûvtîÜÜ®fjj [[[ †õÏcÀÓ×××"777•u0‘Œèèè {÷îøóÏ?QYYÉ4»¸¸zzz\n5Bii)Þ}÷]Ì;¿þúk£{ö,Ú¶m KKK¦¹¼Ý¸qü1¦M›†ÜÜ\&oNééé033à Ú*LHóHJ¦Mc¿ø74T.þUüYB!¤áÚ´ilß¾ÙsåëvØØØ ÿþL2U¡ÊŽÓ¦HKKCÇŽ%¹@Õ¶m[ØÙÙñ*Üt¥@{PÀ®®.ºwïŽ .àÁƒL³Ïž=‹öíÛ£sçÎLsyùý÷ßÑ¿äää0CJOO§„4‡­[ù-þSR??¶¹„Bž©wïÞèÕ«~úé'æ%€T[âàâÅ‹øè£0gÎ>|˜Ù¿[C¤¥¥Ivªm۶ׯ_wðõõÝž››Û|÷Wf¨húúú°±±Á¹sç˜þ%¬+,--affÆ,—OOO˜šš"##ƒK~vv6ôôô0tèP.ù„´éé|ÿ­[+9’m.!„•9;;ÃÙÙ™ùNÖ[â+++ñïÿr¹©©©jµðwvvÆòå˱téRÉÿuŒÑ«W/œ:uŠùNd½ôòõõý‰JÍC@3iݺu} Àrk’(Š(,,„••ÚµkÇ,—OOOXXX 55•K~vv6ZµjE%!M•‘Lœ0>»úúÀ–-@p0Û\B!Ì8;;ÃÕÕ[·nez=‹-ñUUUøá‡0yòd$%%¡²²’Ù|ª²µµELL V®\‰Þ½{C&“I=ÀÐЬwþ)K7__ß­¹¹¹ì¾YSTHÌÄÄæææ(**b^œ>}ŽŽŽ000`–Ë‹««+÷ ²²AAA̳ ÑH¿üŒÅoñ?mÛ\B!’éÑ£È|'@NNâãã±lÙ2üùçŸÌrUehhˆ—^z ‰‰‰˜0aÚ´i#õHLµiÓNNN(,,äQôàîëë»…JõD€011™™Š‹‹™.~>|ˆÂÂB8::jÄ—««+ðÓO?q)öïß»wïR @ÈþýüÿññÀôéls !„HÎÞÞC† Abb"ª««™åªÓá~úúúxþùç±eËÈårK=7u%§=xP  žÔûÈÊÄÖÖþþþÌO-//ǺuëPQQÁ4——iÓ¦aýúõÜUY¼x1Þ~ûm.Ù„h„ýû‘#Öï ººÀÚµ´ø'„-6lØ0¤¦¦jÝÂXOO3gÎÄ©S§ KKK©Gj¦¦¦˜={6Ú·oÏ#~$€íK–,Qÿ­È- jÄÎÎC‡…L&cš{ëÖ-¬]»V­ž›ú4S§NåZ,Y²o½õ—]„¨µ”Wþy,þ׬fÌ`›K!Dí :TkJ„††âäÉ“ˆ‡Ô#5;SSSÌ™3‡W tçΟ¨P/T¨‡'>E7oÞÄúõëqÿþ}æÙ.är96nÜÈ­X±b^zé%*ˆö;z ÊÊØæêè«V3g²Í%„¢ö† ¢‘%@@@Ž9‚äädôë×OêqÔ†‰‰ ž{î9têÔ‰GüP©T¨*Ô”‹‹ <==™ç^¹r6l@UUólBCC±iÓ&nÏ[EDDjkk¹ä"¹ßW.þoÝb›+“ßÌžÍ6—BˆÆðööFZZLLL¤噼½½ñóÏ?#33nnnR£–Œ1{öl^%€€´˜˜ÍjŒ´j¬OŸ>ððð`ž{ñâE¬_¿^cJ€®%ÀÊ•+ñâ‹/R @´Ï±c|ÿls !„hooolÞ¼­[·–z”ÇòòòÂîÝ»±oß>.·Ùj###ž%Àû÷ïS 1*Ôœ››\]]™ç^¸p›7ofú,Wž&OžŒmÛ¶qûá²råJ„‡‡S @´G^ܼÉ6W&–/^|‘m.!„SQQ˜˜L›6 >”zœ¿8p vìØ_~ùþþþR£QêJsssñÞ÷ïßOAý·h)*4À€¸Ü£T\\ŒÍ›7£¦¦†y6cÆŒÁÖ­[¹•?üðæÍ›G%Ñ|<ÿß}¼ôÛ\B!¥²²111°±±ATTÊËË¥©ž‹‹ pðàAŒ;Vêq4–‘‘f͚ŭ@%€D¨Ðƒ Bß¾}™ç!))Ic½£GƶmÛЦM.ù«V­Â /¼ 1„üÃñãÊÅÿlse2àÛo—_f›K!DcTUU!..=zô@TTÊX.«GGG¬]»yyy eþXí–¨n'@çÎyÄ{ÈˣȓQ A gggæ¹………UŒ5Šk °zõj̘1Ccn ¤^a!0bŸÅÿ7߯¼Â6—BˆF¨®®F\\ºwˆ\¹rEê‘êÙØØ 66ùùù˜5ktuu¥I«bΜ9èÒ¥ xw™T4/*4ˆL&ƒ··7™gŸ:u Û·oטGâ9?ýô·`óæÍ˜9s¦ä%À±cÇpýúuIg âôiÀßàñ¡,:xí5ö¹„BÔZmm-áä䄈ˆüùçŸRT¯[·nXºt)NŸ>ððpn&@›6m0kÖ,XZZòˆwõÙgŸuàNþ‰ #“Éàããƒ=z0Ï>~ü8vìØ¡1%Àˆ#°}ûvpÉß¼y³d;N:…Y³fÁÝÝC‡ÅåË—›}¢ANŸüüß'ÑÑÀ»ï²Ï%„¢¶þºð—Ëå(**’z¤¿ñðð@aa!æÏŸ¯¶OÐ6mÚ´ÁÌ™3y•®UUU™T4*4L&ƒŸŸìíí™g;v )))Sq-šµ())ADDúôéƒuëÖ¡¶¶………ð÷÷§€<Þ™3Ê+ÿ<¾?>û ˆŒdŸK!D-‰¢ˆääd¸»»C.—ãÌ™3RôXGŽÁ믿 ¾w IDAT®1·¯j‹º k×®<â]«ªª²AèÈ#œü?*4T] `ccÃ<ûèÑ£ÈÈÈ`žËK`` ÒÓÓallÌ%?!!Ó¦MCuu5—|@ùXÆùóçÃÑÑqqqÿx2Caa!üüüÔjëQgÏ*¯üóø¾øôSà½÷ØçBQKYYY8p ƇcÇŽI=Î3­Zµ aaaó4+mÁ¹è€JΨÐ`::: „••óìC‡a×®]Ìsy:t(RSS¹•III˜>}:óàúõëˆŠŠ‚ƒƒ–-[öÔgèž>}šJòÿx.þ?ùxÿ}ö¹„BÔξ}ûàëë‹ÀÀ@9rDêqeÓ¦M “ü̦–¦uëÖ˜9s&ºuëÆ#¾€=‚ Xð'Th¼º€Çý8Àž={˜çòâããƒÔÔT´mÛ–K~RR¦Nʤ¸yó&¢¢¢`kk‹˜˜—BˆäŠ‹‹¾}û"11Qmžô¤££Ãü)N‰‰‰Ün&ÿTWtïÞG|/9Ÿ|ò —S["*´Œ¾¾>FöíÛ3ÏÞ¹s'Ž=Ê<—///®%@ZZÚK€êêjÄÅÅÁÎθrå —Ο????œ;wŽK>Q.(¯üóXü¿óðÅìs !„Hª´´pppx솤€#GŽ //ùArIIITH@OOÓ¦MãU8 ¶¶‰‰‰prrBDDD³ÖG%€–»xQ¹øçñß÷í·/¿dŸK!D2×®]«ÂP\\œZm‰ÀáÇ‘™™ WWWôìÙ{÷îe¾}|Ë–-*ÙD𦮰³³ãßóÑ£GûA°åÞ’P ¥ 0fÌæW¿EQĶmÛpòäI¦¹<¹»»#33“[ ‘‘ñãÇcÆ prr‚\.GQQ—×z’ÒÒRøùù5ûëÎêÿ<þ»¾õðÕWìs !„HâÆ{Â:-~½½½‘““ƒÌÌL 0ào¿fkk‹ÜÜ\æWŽ›rfQçÀ@î¢E‹¸l3h)¨ÐbFFFf~ž(ŠØºu+Μ9Ã4—'777dee¡C‡\ò333&éŸIii)bbb${}ÂØÕ«@PðÇì³ßxX¼˜}.!„fwëÖ-‚Pÿ„¡º]‰ê`ðàÁرcöíÛ__ß'þ>äää0_46ôÌ&ÂV«V­0}út888ðˆ·©©©ÉKÃÐP åŒ1fÌ2Í­­­EBBΞ=Ë4—'WWWdffr+¤äííììlÄÅÅI= aáêUÀß8uŠ}öüùÀ×_³Ï%„Ò¬îÞ½[ÿha…B;wîH=R½>}ú !!û÷ïÇØ±cô5¼J€§ÙDøÑÕÕ…\.G¯^½xÄÛÈY´h‘=pmG@ `bb‚±cÇ2/jjj Q¢suuEVV—'%HaРAõͺŸŸŸÔã®]S.þ Øg‡‡ÓâŸB4ܽ{÷ðÍ7ßÔ?aèöíÛRTÏÉÉ ÈËËChh(d2Y£¾ÞÚÚ999°·g»®KOO§@ººº åUX×ÔÔP ÐT´¦¦¦=z4Z·nÍ4÷Ñ£Gظq#Ο?Ï4—§þýûk| лwo$$$àÀ nÖ‰à¹øŸ7X±hä‡1B!êá¯~ã7põêU©Gªgkk‹ØØXäçç7iáÿWu%@=N¨,ƯV·H´u%€££#x«ÿÞÀö›EËQЂ˜™™!88˜y P]]M›65ˉ÷¬ôë×{öì………Ô£4Š““Ö®]Ûäf¨±ë×áÃl¾ðK‹BÑ@ÕÕÕˆ‡££#"""pùòe©Gªgee…ØØXœ={áááÐÕÕe–Ë£صk×ßžÞDš‡®®.BBB¸•ö.Z´È‰G¸6¢ …éСF}}}¦¹>ÄúõëÕê‡Ò³899!;;]ºt‘z”gúk³>kÖ,èèÐ_]­R·ø?q‚}öóÏÓâŸB4PÝ£…]\\0{ölK=R½N:!::gΜAxx8ZµjÅü5ºu놽{÷ÂÙÙ™iî®]»0räHܽ{—i.yººNN\Öé555Ù‚ °ýfÑR´ŠhÌÍÍ1jÔ(èéé1Í}ðàÖ¯_k×®1ÍåIÝK+++,]º………L›u¢FÊÊ€‘#ü|öÙsçqqF„¢1DQDrr2\]]!—ËÕêÀå: ::çÏŸGdd$Ú´iÃõõ,,,ͼسgFM%@3ÓÑÑAhh(úôéÃ#Þ@öÇìÂ#\›Ð§ÂªsçÎ5jóÆöÞ½{ˆÇõë×™æòäè舜œtîÜYêQêýµYŸ?>óÛ6ˆš¸} ŽeŸýÜsÀÊ•´ø'„ ’••Œ7Ç—zœzmÛ¶Edd$ŠŠŠ ƒf{íÎ;#;;..l×u{÷îÅèÑ£QQQÁ4—¶p]»vEPPó{Ê+**°f͵z4Íÿºq㢢¢`kk‹˜˜TUUI6Ëÿ6ë¬ÙHÔÌíÛ@Ppäûì)S€~ Å?!D#Õx7`ÀüÆ£ U3û÷¿?qøða©Ç©×ºuk„‡‡£¨¨ÑÑÑhß¾½Ô#Á¹¹¹Ì®÷íÛ ˆŽŽf’GG&“a„ èׯxóÚÚZ*ž@@T%@•Wéë ÅÅÅØ½{7jkk™æ¶oßÏ=÷Ú¶mË4W·nݲeËðõ×_ãÎ;’Îbdd„W_}‘‘‘jñÕ4ƒòråâŸÇ=¹ذàp“:©­JJ€ÒRàÂàÊ ²xð¨©tu¶m## [7 kW G S'©''„ø þž÷öíÛc×®]ðððx:ö:„O>ù)))Rò7úúú˜3g.\KKK©Çy¬ëׯcøðáÈoâÙ9...X¸p!BBBèiJj@Elß¾yyy<âËttt,X ýmb#P@ê;w»wï†(ªô-ñfffxî¹ç`llÌ4·±îÞ½‹åË—#::Zò 2™ 3gÎDLLŒÆ=Ѝ ¼18tˆ}vh(°q£V.þ+*€Ü\ +KyÇÄñãÊÖX]ºýûƒ+ï¾8PYB¤#Š"RRRðÑG=vЮ];ìÚµ  `:öNœ8?þIIIÌ?o©BOOS§N… °³³“zœgº~ý:uNB÷î݅矞UV3¢(bÇŽ8vìø2A‚ pØv©™¨ súôiìÙ³‡ù¥Ž;bΜ9022bšÛ÷îÝÃÊ•+ñùçŸãêÕ«ÍþúOÒ¿dff¢cÇŽRBšÃ;Ê+ÿ<ÿ!!À¦MZµø¿}غUÙiìÙTW³ SS`Ü8`út @«þøÑYYYˆŠŠzæVÿvíÚ!##l¦ÉØ+,,ÄgŸ}† 60ßm© Lž<Ÿ~ú)zöì)õ8RVV†   yÆítÖÖÖøàƒ0wî\.+$lˆ¢ˆÔÔÔgþ÷l¢Û:::A ,ø•G¸¦¡›DÉßôêÕ C‡ež{ãÆ ¬[·÷ïßgžý$UUUˆ‹‹C=ðÆo¨ÕâŽ;†€€Ü¸qCêQo••Àر|ÿ“'kÕâ??_ù àùçÝ»ù,þ册uë€Q£++`Ñ"€þ:Âß¾}û0lØ06è>ÿÛ·o#((‡x¼‡rvþüyDDD OŸ>X·nÚ,þe2‚ƒƒqôèQ$$$hÜâPÞ"’™™ùÄÝ!ݺuÃÒ¥KqæÌ„‡‡Óâ_ÍÉd2Œ=š×nŸvµµµ»AÐÜ‘!*È?ôêÕ ^^^Ìs¯^½ŠøøxlÞ׿rX°°¶Þ|¸y³y_Ÿ–àÀ>|8|||°§‘ï‰ååå1b<Èi:¶.\¸€ùóç£W¯^ˆ‹‹Ã£G¤©^@@~ýõW$''ó:€­ÙÔÝ"ò×Ý!;v¤G)k(™L†Q£Fq+ìúøãñ×$TÇêÝ»7—­vW®\Áƹœ¸_[[‹ÄÄD¸¸¸`öìÙ8wîó×àáÔ©SðóóS뢂4ѽ{@p0ðóÏì³'N6oôôØg7£k×”WúÝÜ€´4@ê[bïß–.zö/Ôè3;!ëøñãËåðòòBvvv“sÊËË1räH8p€átl]¿~QQQpppÀ²eËð°¹Û̧ðööÆÏ?ÿŒÌÌL¸»»K=3íÚµCzz:ÿö(e©G#MPWpºåÇ´¶¶6C„Á<Â5@žê·ß~ãòkkk„……AÁâ¥î¡?ü°Q‡Á¨GGGdgg£K—.RBX¨[üçä°Ï5 ض Ðð«;wóæêÜ} ¬] 8:J= !š)11S¦Laz¶‰‰ ÒÒÒ¸ìVlª›7oâÛo¿Å’%KPÑ”SJ9òôôÄ'Ÿ|©G!¤ÁDQDFF¯[îèèèŒ\°`ú¶‰ÑòTîîîèß¿?óÜÒÒRlÞ¼Yå-qYYYðððÀ¸qã4zñ(òóóßþ)õ(DU÷î)ïùç±ø9Rãÿ/¼ ìGÔyñ(ŸÖèæüðƒÔ“¢™BCCñÞ{ï1ͼsç‚‚‚››Ë4·)îÞ½‹˜˜ØÛÛC¡P¨Õâ¿î9÷û÷ï§Å?Ñ82™ #FŒÀ A\vì›ÔÖÖf ‚àË#\ÝQ@žiàÀ\î;wî~üñGÔÔÔ4úk÷íÛ‡¡C‡"00Ge>›TNŸ>M%€¦»_y´¼ Û\ŸH ÿW¯þþšµ ¾_YX¼ù&Є·+BZ¼O?ý|ðÓÌÊÊJ#‡GÑÚÀ׉‰µµ5¢¢¢P^^.Éãââ‚„„;v ¡¡¡RCH“Éd2Œ9C† áo E¡PøñWgT8p \\\˜çþñÇHJJjð©¸û÷ï¯?@hïÞ½Ìçi ^‡Êœ9s~~~¸té—|ÂQÝâ÷nöÙAAÊÅ›6ì³›Ii)àé ìß/õ$M³t) —ó{*!Úì“O>Á‡~È4³®På\Æú놢¢¢PVVÖl¯ý,ŽŽŽX»v-òòò ™L&õH„0Q÷ÙŸ#QSAhQ[d¨ "“ÉàååÅå11………ضmÛSï<|ø0ÆŽ ooïfýAÿ8ÎÎÎHHH@II —RøÿàâÅ‹\ò ¡¡@VûìÀ@`ûv^ü_¼¨¼ò_\,õ$ªÙº˜6$¤)-Z„ 0ͼwïÆŽ‹Ý<Š×¿¨®®F\\ììì¡VOï±±±All,òóó1kÖ,èêêJ=!ÌùûûsyT9CÉ …b8puDi°à&§gc]¿~ý©'åæåå!55•Ëk7T÷îÝ‹ãÇ#44ؽ{7z÷îÍåõΞ= ”””pÉ' UU!!ÊSíXÓ‚ÅE0bPT$õ$llÙ¼úªÔS¢™ .\È4óÞ½{7n²8°uOª{´°:íΫ{ÎýéÓ§é9÷¤EðóóãVˆ¢¸C„áê† Ò ÷ïßÇÎ;qëÖ-æÙ˜5kÚ>Êmÿü(#QæÎ ¤ž„­ØX`åJ©§ D3 ‚€èèh¦™u%@ff&“¼¿.üår9ŠÔ¨Á¤çÜ“–ÌÏÏÆ ãm`‡B¡ä®N¨ ÏtïÞ=¤¤¤p]ü>ó÷¾ð X¹re³•æææõ?`ŸÖ¬›››c÷îÝèÓ§—9Ο????œ;wŽK>QAU•rÛr2ûl 502bŸÝŒ¾þHJ’z >^{ Ðð‡"™ÈÈHæ%Àýû÷1vìX¤¨XÈfeeÁÝÝr¹gΜa4êÌḬ̀páBÑsîI‹æëë‹€.ë DQL!˜G¸º €ÛÛ[+ÿðÊ+ÀÝ»ROÁ×áÃÊÛ!Móî»ïâË/¿dšYUU…ìh`A»oß>øùù!00GŽa:‹*ŒŒŒðú믣¨¨ÑÑÑh×®Ô#¢V8–ú¢(& ‚0ŽG¸Ôdž|ôz‚ Òááá*}=ᣢ¢)))¨¨¨`žmee…°°0èëë«”³yófÌœ9T<ŽÛØØ¯¼ò ¢¢¢˜üp-++CPP·VVVÈÎÎF=¸ä“g¨©€͛Ùg{yéé@Û¶ì³›ÙÁƒÊGþqÕ@vº0Ð À#e.(pÀ“ÏU™¥%pî@·áÒt‹/Æ;ï¼Ã4S__ ?~ücýàÁƒøè£¸¨ }}}Ì™3‚  K—.RCˆÚÛ¿?³ó?þG•L&“/\¸ÃéP@þáîÝ»HNNæ²ø·¶¶ÆŒ3T^ü×ùñÇÖ¤ÀÐÐ/¼ðÞÿ}tîÜ™ÉG#À ÀT£4ôì͇öH°ÀŸìÇZ±ˆˆ`ŸKHK²dɼýöÛL3õõõñã?b„ õÿ,??‹-Bbb"Ó×R•žž¦N …BîÝ»K=!åÀصkè*SAø‰G¸èò7³ø€)S¦`Æ zô¾¾>ÂÃÃñÇà›o¾a¾ø€víÚa×®]8p ól¸xñ"|||P mG««³š`Ö,>‹ÿÁƒµæÊ? ¼Îô¡2“ü à7ÿBÃÿ€òn>?‹œð#ÆÇu|÷ÛÛÍMyϿꔔ¤|üöØ€Åñ­Èüà{ŒŽZ8q8y’M!-Ù›o¾‰ï¿ÿži P]]ôéÓ‰‰‰™½A©F&“Õ/ühW!*òôôĘ1cxDëAYLçÞܨ ”‹ÿäädÜ»wy¶½½=“{þŸ&44›6m‚žžÞ?~­®Y?yòd³7릦¦ÈÈÈÀàÁƒ¹ä_½zþþþ8I+~jj€9s€ Øg»º™™@ûöì³%Ä챡Žðf”÷W:^‚rGA/6‘jtA‘öâ‹/âßÿþ7Ó ¶¶µµµÌòT€#GŽ !!½z1z"„ÀÃÃÁÁ\žâ§ ^¡PÌàÞœ¨ ¸}û6·Å=0uêÔFmÑoª¿•2™ ÁÁÁøý÷ß‘€ž={rŸáqLMM‘žžON'¢Õ•'Nœà’ߢÕÖÏ=¬_Ï>» + 03cŸ-¡Š à·ß=åýúF ²ž¦n‡³êQ?ÿ¬z!D)""±±±\û+…€€>|™™™pss“zB´’»»;·@ŵ‚ „ño.Úõ®JíöíÛHIIá²øïÙ³'¦L™Ò,‹ÿ:“'OÆæÍ›1aÂ;v ÉÉÉèÛ—ñ;M`jjŠÌÌLøúúrÉ¿v톎üü|.ù-Rm-0w.°nûl-]üÀï¿+ÿèT2@,šï'T'ÉT¼ ã÷ßÞú@Á¼yó°bÅ ­(¼½½‘ÌÌL 0@êqÑzîîî;v,ÓDÿ¥ `B¡˜É:¸¹hþ;*i²›7obÇŽZ³ø¯3iÒ$lÛ¶M-þedd„””*4(/¿ ¬]Ë>»_?åâ¿CöÙjàØ1t¡\üÿón¾ìªE”—ÅÅ,†!„Ô™7oâââ4¶4hvìØ}ûöÁÏÏOêqiQÜÜÜÌ¥EqµB¡˜Í:¸9hæ»)QÙÍ›7‘’’‚0ÏvvvÆÔ©S¡««Ë<[ÓÕ•¼>\¿~ÇÇñãǹä·u‹ÿØXöÙ}ûjõâ®]S1`$˜lÇo’p¨|ËÁ•+L&!„üÅóÏ?•+WjT лwo$$$àÀ;v¬ÔãÒb¹¹¹qÛ Šâ*Aæ°æMsÞI 37nÜ@JJ >|È<ÛÙÙ“'OÖ¨ÒÍ­®ð÷÷ç’ýúuøúúâÈ‘#\òBElÛ¶ ›7o–l†&EàÕW•ugÍÑÈÈ:vdŸ­FÊÊT àó×¢aŒ¨øÐ•ÿý !5wî\üç?ÿQûÏNNNX»v-òòòÊcÑAi$WWWŒ7ŽÇßG« ÅK¬ƒyRïwQÂÜ7°sçN.‹Zü7¡¡!’““1|øp.ùeee į¿þÊ%ÿi²²²0pà@Lš4 Ó§OÇ ‹iêÿßÏ>ÛÑÈÉ,,Øg«™ÊJ¤Þ¡b?£ò¿?!ä‰f̘¹sçJ=ÆcÙÚÚ"66ùùù˜5k}"DÍôïß“&MâñwS&ŠârA^fÌ ½;µ W¯^åvå¿wïÞ¼þRi-CCCìØ±\òoß¾   >|˜Kþÿúå—_àçç‡ÀÀÀúÝ¢(âå—_Æ÷<Õ,‰"ðúë|ÿ½zÙÙ-bñmÛªp™ÉMwIµ/7Qñ ABÈ?UWW#>>NNNøÏþ#õ8cee…¥K—¢°°ááátû#!j¬wïÞ˜8q"—Àw …âÖÁ<Ðj­…¸rå RSSQUUÅ<ÛÕÕ•ÿMTWrÉ¿}û6FŒÁµ8xð ÆŽ‹!C† 77÷¿.Š"^}õU,_¾œÛ *E`þ|à»ïØg;8(¯üwéÂ>[Mµk§b@*“1šæ7Í´oÏdB€ÚÚZ$&&ÂÅųgÏÆ¹s礩^§N3gÎ`þüùhݺµÔ#B€ãEK™(Šß ‚ð*ë`ÖhÅÖ\¹r¥ùx† IDATiii¨®®fžÍñ`ÃÀÀÉÉɼžWZ¿àСCLsóóó!—Ëáåå…”””§þ^QñÚk¯á;‹lUEEß~Ë>·.þ kWöø…Å$M°€Š©Êÿþ„ˆ¢ˆääd¸¹¹A.—ãìÙ³RT¯C‡ˆŽŽFII "##ѦM©G"„4ÇÛ–e– ‚ð:ë`–¨Ðr—/_æºøçôh§uëÖØ²e ·“‚ËËË1bÄ1~üx.ùwïÞŘ1c{¯þ“”––"""={öD\\œÊßS¢(â7ÞÀÒ¥KUÊQÉŸÎ>ׯÈÌlÑûÀÛ´¼½eðð'ƒ¬§ÉààŠêQœÎó$D«í߿LJöìÙ#õ8ÿ‰èèh´§>ÑJNNN˜:u*¯>>LsŸéÃÏ>cŸkm üü3`kË>[ÃÜ»¤²8Ìï€5ÌôƒrS+åÞð î“É€¸8‡ ÒB>|/¾ø"¢¢¢P\\,õ8O”““#ÍÏ*BH³éСºté‚‚‚‚&íp}†á~~~rss÷²n*Ú eJKK¹]ù÷òòBPPó\òOúúúHHHÀĉ¹äWVV"88999ÿøµ7n ** ¶¶¶ˆ‰‰Áƒ¸Ìï¿ÿ>>ã±’ €O?eŸkm äæÒâÿ¿&Ofp@[æp°*oÓÇ5è`)F½ÖàÁÊ „§;yò$är9üÌdÕE³ÿ¬"„4»ž={bêÔ©hÕªólQ?Q(1n"Ú EŠ‹‹‘••ÅüJ-x{{s{Ty¼º'OžÄ©S§˜çWWW#11±~'@EE–.]ŠÐÐPdggãÑ£GÌ_óq²³³ÑªU+ :”ï -\,ZÄ>×ÊJ¹ø·³cŸ­¡Œsç€cdž^° À÷þP  ãg|à €$ (¯øïpál¾þpvf›Iˆ6),,Ä[o½…W^y'NœzœFËÎΆžžÿŸU„ɘ™™ÁÒÒ§Nⱞòóõõsss›vC2(?5™ * ®Ò×¥sçÎ!;;›Ûâ?€nn•LMM fÍš…7rÉ744ÄôéÓ±eË”••qy†øøãñÑGœÊQA ö¹VVÊÿìíÙgk¸Ó§• boIg À@7&ÿýgµ®Cy~ÀiwøŽàèœ< °?CˆÍwþüy|öÙgXµjU³Ë<-Z´~ø¡ÔcB8***ÂæÍ›¹¼gÉd2aáÂ…>”6íÐEEEÈÉÉá²ø÷õõ…¿¿?ó\Òp:::˜0aŠŠŠŸŸÏ<¿ººGåºÕÿYôõõáàà€ádzßzõå—ÊûþYëÖMyåŸÿÕ±#PZ üþ;çªP à€ßþû¿£P.üÿðóëø÷¿þ¯Cˆ&¹xñ">úè#Ì™3‡æòE 999ÐÑÑÁ°aä…‰™™ºv튂‚ï]¾¾¾¾¹¹¹Y¬ƒŠ®Wh8ž‹???ú§&tuu±víZ„……I= S::: EAA–/_Ž6mÚ°}¯¾Þ}—m&XX(Oû§ÅÿS}ù%`n.õ| „„H=!ê£î,[¶ 6C ×Ì.\]e„µaoo°°0èëëóˆó¨†vh°?þø999·sg ;›ÿ0e ðúëROÁžŽ°~½òBZ²»wï"&&öööP(¸s‡ó¡ЧO$$$àĉÈÈÈ€±ñ³N mœ˜˜DEE1Í$„¨̘1ƒ×N€ ‚ðà§¡@bÏž=\ÿ#GŽÄàÁƒ™çvtuu±jÕ*+ð믿"33ýû÷ç÷BK—o½Å>×Üؽ›Žzo‚¯¾üü¤ž‚­O?F’z B¤SYY‰o¾ùöööˆŠŠÂíÛ·¥©ž³³3——‡ÐÐPÀСC‘ššÊ¥x—Ç­f„µammͳx[„Å<‚Ÿ„ sêÔ)n‹ÿQ£FaРAÌs {:::X½z5^|ñE©Gy&oooäææ"33|_ì›o€7ßdŸkn®¼òO'½5‰žœ hË]Eo½ÐE?ÒRUUU!..={öÄo¼k×®I=R½îÝ»#66ÇGhh(d2Ùß~ÝÇÇiiihÛ¶-Ó×ýòË/ñ/·œBÔ†µµ5Ï3Þa ”Oè㎠RPP€½{÷rÉ=z4È%›ð!“Éðý÷ß㥗^’z”Çñ÷2©©©ÌK€¯¾ú ïð¸õŒ¢6¬¬¬†Ö­[óˆS„ïÑ %âøñãØ·oó\™L†ñãÇcÀ€̳ 2™ Ë—/ǤI“¤¥^Ý=—h¾Ã‘V®^|`½3¦nñß»7ÛÜÊÔT¹‘bêT©'i¼V­€ï¿¾øBêIi^µµµHLL„³³3"""péÒ%©GªgnnŽèèèú…C#;dÈ.;/^Œ·ß~›i&!D½XYYaöìÙìŸ\¥ô¢ +À¹ @äååáàÁƒÌsëÿ\ïÇ&\?~S¦LÁÖ­[¥å±÷\6‹ÿüˆˆ`¿øoßHKúôa›ÛÂ7Ÿ®¼5@XXé通n¶!„ Qëþr¹üñ‡Ô#ÕëØ±#¢££QRR‚ÈÈÈ&]óööFzz:LLL˜Î¶dɼùæ›\nÕ$„¨‡.]º`Ö¬Y000à.B¬ ÜÖéT¨¹¼¼<:tˆy®L&Ä Я_?æÙ„¿“'OB.—£ÿþHLL”t[[Û§ÞsÉÕ?ðYü·kìÚÐcJ¹É”÷Ðÿöàê*õ4O äçÇK= !Í'++ îîîËå8}ú´ÔãÔ333ÃÂ… QTT„ÈÈH•?|{yy!;;íÛ·g4¡ÒÒ¥KñòË/S @ˆëÒ¥ fΜɫ˜€[ @€ã¹øŸ8q"úöíË<›ðUXXˆYÿÇÞ‡EYîÿ8¨€,⾡¢¸ïæ¾CiŠKÉ䯢)ÓbbZÊIÊ%&+—´K­Nƒf ® h¹ï+ˆ®å¾ (Ûüþà7|õäÌýðÌ ï×uë\ÁÌûùœâ|>Ïsß·ŸÚ´iƒ˜˜Y?\Ö\ž={ö¥k.%±läç‹Íurâã©7,$´jìÙ„‡,0%Íšl\¨ÓUªÈ] QéHHH@§Nàåå…#GŽÈ]N!{{{#-- aaaBïÚwèÐñññ¨\¹²°LX²d Þyçˆ,˜ÄOŒ)Å€uèÐ!Iš+++øøø k6+.\€F£A«V­°råJäååÉZá®PqÖ\ µ|90~¼øæßѱàÎ?›ÿRS¾< ¤¦“&‚Oè*¶úõᅫ”·¢Ò²k×.xxxÀËË »œB¶¶¶˜8q"RSS'''I®#Õ 22ù¢ÿ®""“Q£F øùùÁÖÖVŠø·,=àÀô‘qqqA@@€T¿Þ¼råÊÚ… {m204ÿgΜžmhþë—æZôRùùùˆ‰‰AóæÍ¡Ñhdý€©P($; R¯×câĉøöÛo Ú°¡`ÍN‰žlz>[[ 6ðð›KD&'99~~~hÓ¦ bbb ×¿|Åã™3gÌrðàÁhµZ¸¹¹A«Õ"++Kî’ uîÜë֭î]»àa¦¿{›6mŠÄÄÄg.±³³Cpp0.\¸€ððp8::ÊP!™ªÊ•+# Rĸ}ûöšâ8(eR6ÿåË—‡ŸŸ›“€æÍ›C­V#55UÖZ¼½½qäÈ$%%A«ÕJr ½^   ,\¸°d7o¼ˆ>ú°bE`Ý:ÀÓSl.™” .@£Ñ U«VX¹re±w»?{ö,zôèóçÏKS @ÐjµpuuEHHîÝ»'wI…Z¶l N‡={öÀÛÛ[îrŒÖ¤I“§†666 Djj*ÂÃÃáìì,s…Ddª*W®Œ1cÆÀÉÉIŠø·oß^VäõF”"½^íÛ·KÒüW¨P¾¾¾¨S§Žðl2N«V­P®œc;K¬{÷îØ±cÖ­[‡6mÚ>ùä|ùå—’\O¯×cÒ¤I˜?~ñÞ¸i0t¨øæ¿|ù‚Íûö›KD&ãÒ¥K B“&MiÔn÷çÏŸGŸ>}pîÜ9ŠóøñcDFF¢Q£F Á;wä.©P³fÍ…cÇŽÁÇÇ …Bî’„qwwǶmÛðá‡"==¨Q£†Üe‘prrB@@€TC€þŠ<à)¥D¯×#11Q’;À†æßÒv/¶$ׯ_Gß¾}%9êñEºu놙3gÂów½¿þúk|ôÑG’Õ0gÎL:õå/ܼ2½fÕÆ¦`?Äæ‘I2dþøã¡™ 6Dbb"êÕ«'4·¤²³³±bÅ |öÙg&·a¡««+¦M›†·ß~ÖÖÖr—CDd’îÝ»‡¨¨(©·›†Nž<ù…ëÀø@)ÈÏÏG||<›ÿ2¬Zµjغu+ZµjU*×ëÔ©SášË5ÿ0eÊ|ýõ×’Õ2mÚ4Ì™3çÅ/Ú²Eºæõj6ÿDe€N§Ã Aƒ„f¦§§£gÏžHOOš[\¹¹¹ˆŽŽF³fÍ ÑhLªù¯[·.æÏŸ””²ù'"zGGGøûûKµlèµû÷ïÿþÍ7ßT|Ñ‹8X~~>$YKhkk‹€€6ÿf¢4†-Z´€N§ÃÞ½{‹µæròäÉøæ›o$«kúôé˜={ö³¿ ,]óokO‰èålllƒÁƒ ͽxñ"<<<––&4·( ȶhÑþþþ²"žTµjU„‡‡ãÌ™3 BùòÅÞˆšˆ¨LrttD@@*W®,Eü«÷ïßß8wî\»ç½€ îüKÑüÛÙÙÁßßÕ«WžMÒ©Zµ*¶nÝŠÖ­[ ÍmÚ´©Ñk.?üðC|ÿý÷’­× ÅÌ™3Ÿþ¢”ÍL ›¢2ÆÆÆ:C† š[ÚC½^ØØX´oßjµZ’½ƒJŠçÜÏÁÁþþþR zgddl ³Ö79ˆ¡ù¿pá‚ðlCó_­Z5áÙ$½ªU«bûöíèØ±£ÑY®®®ˆˆˆÀ‰'àççgô£—ï¼óޤC€O?ýŸþyÁ?üõWÁ†¢«R*ü(0™Ã`èСBs/]ºÉOsIHHÀ+¯¼‚Aƒáرc’^«8xÎ=‘X3f ªV­*E|/Ïp ÜÜ\lܸQ’æßÞÞþþþRý P)qvvÆ–-[ðÊ+¯”èýuêÔyjÍ¥ÈS4 –,Y++i~=̘1ËÇŽ^ÈÈnhþ?LDæE©T"&&#FŒš{éÒ%ôìÙÉÉÉBs`çÎèÝ»7¼¼¼pèÐ!áù%Ås¤#qo×ÀF­VûÔÄ–Árss±iÓ&üý÷ß³%žQ)+É ´Ö\J6èÀgùràáC±ÁÖÖ@ttÁf‚DTæY[[cåÊ•9r¤ÐÜ«W¯ÂÓÓIIIBòöìÙ•J…ž={âÏ?ÿ’)Ϲ'"*†§»%êñzdee=5à@ Có/Åî¼oA2qrr–-[ЩS§¾®råÊO­¹¬Xñ…›{ 1~üxDDDt°À3$ÃÚX¹>\t2™1kkkDGGcôèÑBs C€S§N•8ãøñãP«ÕèÖ­¶nÝ*°:ã(•Jòœ{"¢R$ñïîYYY›Â„‘ºù—𸒙aйsç}ÏÞÞ^Ö5—ãÆÃÒ¥K… ºØ@øÿkk * ü¨/Ykkk¬X±BøàÚµkðôôÄÉ“'‹õ¾S§NA­V£mÛ¶ˆ‰‰Z“1¬¬¬àããƒäädDDD víÚr—DDT¦ØÙÙÁÏÏOª!@7[¿øâ gÈÎÎF\\œ$Í¿““Øü[8GGGlÞ¼]ºtPð `âĉHKKCxx8œœœd«mìØ±FºØ‰šÿ+€Q£D'‘1 üüü„æ^¿~}ûöʼn'^úÚsçÎA£Ñ M›6ˆ‰‰^¯ZKI=Ùøët:¸¹¹É]Q™%ñ“?~¼#eggcÆ ¸~ýºðìÊ•+c̘1²6Tz±iÓ&Ìš5 éééX°`Éœô0vìX¬ZµªD§ t„Íÿòå€à»zDd™¬­­±lÙ2øûû Í}ÙàâÅ‹Ðh4pwwGdd$òòò„^ß*• ‡‚N§ƒ»»»Üå[[[Œ3µjÕ’"¾ F²ùwqqA@@„g“érttÄôéÓM¦ñÒˆ#°jÕªb8Ðkþ…ÿ[YË–¾¾¢“‰È‚†Bsoܸ¾}ûâøñã…_»|ù2‚‚‚ ÿÜÜ\¡×4†J¥Â¶mÛÊ]ý *À××W’!%”õë×KÖüûûûóŒ]29Ç/ò €x¯(À÷ß‚å%¢²ÁÊÊ Ë–-Ã;ï¼#4÷ÆèÓ§www,\¸?zctïÞÛ·oG||<:vì(w9DDô†!€è=Y8(Gaݺu¸qã†ðì*Uª €Í?™¬·Þz ?ýôÓ ‡m$~f…¡ù \(++ _ý5 „û÷ïKv"’B¡Àwß}‡÷Þ{Ohî;wðꫯB«Õ"++Kh¶1ºt邸øxìܹ½{÷–»""*¢ *`ôèÑB‡SVVâââpûömáÙÕ«Wǘ1c`o/ü4"¡Ôj5~þùg(•Ê}OÒæñb@£ ÈÉÉAdd$5j„>ú±±±ðôôÄ;w$¹ÉK¡P`Ñ¢E‡¦²¹´jÕ :{öìJ¥’»""*ÓuêÔ’Wôż„¬¬,¬_¿^’æ¿Fðõõ…­­­ðl")øøø@¡P`äÈ‘ÈÉÉ´AAóï"úb °hð“‘ŸŸ5kÖ`êÔ©HKK{ê{‡‚——¶lÙ‚Ê•…4ˆHf†!€••-Z$w9¸»»ãã?ÆÀ¡P(píÚ5¹K""2 Õ«W—»„)_¾}àåå…C‡•¸¦£GB¥RáæÍ›%Î "ÓeLœ8QîR^¨råÊ ÅÁƒ1a”/_^î’ˆˆ¨† 4(ö{9x)›ÿzõêaôèÑü ›ÌÛ™3€‡påŠðè©´Ïøú/¿ü‚Ñ£G#77·H9†¯{öì‰;v©C"Ë×£GT«VMî2þÅÞÞ&LÀ¾}û0aÂÞD "*ÔJ%FŒQì!ÏðàÁÄÆÆâÁƒ³ëÕ«‡Q£FÁÆÆFx6Q©9{V²æ€ð|ÿ¿ÿýïK‡Ç‡Z­F·nݰuëVá5;v ½zõÂU ž| "ùüùçŸèׯÔj5®_¿.w9…ììì0aÂ:t¡¡¡¨T©’Ü%‘ 0 6lXä÷pð?îÝ»‡?þøC’æßÕÕ•Í?™?CóÿÏ?£C|Q„×ýúë¯5jÔ¿†IIIP«ÕhÛ¶-bbb„×÷¤äädxxxàŠC"*]»ví‚§§'Ôju±÷‘RÅŠ1nÜ8ìÝ»¡¡¡ptt”»$""21†åîîîEz=O¸wïbcc‘™™)<ÛÍÍ £GfóOæ-5µ ùÿûoáÑÿ0»¯×ét9r$rssqîÜ9h4´nÝ111Ð ÞðyNŸ> OOOü#Á0„ˆ¤·oß>x{{£GHLL”»œBJ¥¾¾¾Ø³gfÍš…ªU«Ê]™0kkk¨Õê" (Øl»ÄÂÂÂŒy;z¿(wïÞE\\œ$Í£FðÖ[oqw^2o.}úçÏ þÀ̾·aƸxñb‘÷B“&M°mÛ6ÔªUK¶ˆ¨èNž<‰Ï?ÿ«W¯.µaQ(•J 2}ô‘Ñç<Ñ¿U¯^]î$•——‡˜˜¤¤¤<÷5|Ò6ÿ7fóOæïâEÉšÿ(yóééé²6ÿ...3f œœœd«ˆŠ&99~~~hÓ¦M©>-ô2 …ÞÞÞØ±c¾ýö[6ÿDDT"ÖÖÖðññA“&Mžûš2?¸uëÖ­[ÇæŸèy$lþ¿ð¹ðÔÒQ©R%#-- ÁÁÁ°µµ•»$"zŽóçÏC£Ñ U«VX¹r%òóóå.é)åÊ•ƒO±6q"""zàiÓ¦Ïü~™ܺu qqqxôè‘ðìæÍ›cøðá°¶¶žMTj.]*Xóîœð蹂…§JÏÎÎÁÁÁ¸páÂÃù)‘ »té‚‚‚дiSDFF"//Oî’ž)''o¿ý6¶lÙ"w)DDd^4(³€›7o"..?žÝ¼ys¼ùæ›°²*³ÿ÷’%04ÿé飿µ±Á'ÂS¥eccƒÀÀ@¤¦¦"<<ÎÎÎr—DDÏqãÆ „„„ÀÝÝ .”äïzÑ C€Í›7Ë] Y+++¨Õj´lÙòé¯ËT¬nÞ¼‰õë×Kò E‹lþÉü]¾\Ðü§¥‰Ïž<áàà >[J¥8wî"""P£F ¹K"¢ç¸uëBBBP¿~}hµZIžð“RNNƇM›6É] Y…B7Þx­Zµ*üZ™ëR¯]»&Ùÿ–-[â7Þ`óOæíêUÀËKšæÿï¿F·nݰuëV“¾‹nee$''#""‚;ü™°@«ÕÂÍÍ Z­V’}}JKNNÆ7Ê] Y…B¡C‡¢uëÖÊØàêիذa²³³…g·k׎Í?™¿k×OOàôiñÙ“&ß|Sø;vD||<*W®,þZFx²ñ×étpss“»$"zŽŒŒ hµZ¸ºº"$$÷îÝ“»$!rrrˆõë×Ë] Y…B!C† uëÖegpõêUlܸ999³۷oooo( áÙD¥ÆÐü''‹Ï æÍû×—Ûµk‡àà`“Ø,S¡P`àÀ8tèt:ÜÝÝå.‰ˆž#;;‘‘‘hÔ¨BBBpçιKÎ0X»v­Ü¥‘0 ÊÄàÊ•+’6ÿdóOæíúu o_ )I|v`࿚½^ØØØÂ€Ü;s«T*8p±±±hÛ¶­¬µÑóåää 22 6„F£ÁÕ«Wå.©P:uðæ›o ý<——‡ &`Íš5Â2‰ˆ¨ìR(°øê/_¾ŒÍ›7KÒ`tèÐ `óOæíúõ‚;ÿ§N‰Ï?X²xâÏHBB‚ƒƒqøðañ×+¦îÝ»cöìÙèÝ»·Ü¥Ñ äççcÍš5˜:u*Ҥ؟Ä5kÖÄ{ï½ØØØ k×®øä“OŸŸ/$?//'N„^¯Ç°aÄdQÙeÑ€K—.aË–-’4ÿ]ºtÁ«¯¾ÊæŸÌÛwþ¥hþß~û©æ?!!Ó¦MÃÄ_«˜ºv튙3g¢oß¾r—BD/`hüCCCqæÌ¹ËyJåÊ•ñÞ{ïaܸq¨P¡Bá×G …B?þXè ((z½>>>B2‰ˆ¨l²Ø€”Í×®]ñꫯ Ï%*U†æÿäIñÙcÇ‘‘€•vïÞÐÐP$&&Š¿N 4mÚ›7oF¥J•ä.…ˆžC¯×#..Ÿ~ú)Ž=*w9Oqrr¸qã Ñhžû{dÔ¨QP(øè£„&Mš½^µZ-$“ˆˆÊ‹\¼x[¶lö—uë///á¹D¥êΠàÄ ñÙcÆK—bߘ5kâââÄ_çOŸFÿþý±qãFˆLPBB¦NŠƒÊ]ÊSììì0fÌ|ðÁptt|éëGŽ …B)S¦|øá‡À!•ˆÅ Î;‡­[·JÒüwïÞ*•Jx.Q©º{xõUàÐ!ñÙ89i>>«W¯†^¯ víÚ…þýûcÆ ppp»"°sçN„††bÇŽr—ò[[[Œ9“&MB•*UŠõÞ#F@¡P`òäÉ’< ðÖ[o É$"¢²Ã¢éé騶m›¢ç¹{ðò$¸³vÿõ×117+Ûµ“äÏ h†!ÀÆ9 ’ÑÞ½{Š­[·Ê]ÊS”J%†Ž>úÕ«W/qÎðáÃQ¡BL˜0¹¹¹BjËÏÏǤI“••…€€!™DDT6XÌ -- ‰‰‰’4}úôá.ádþîÝ+¸ó/Aó°aCôؼe>ί¸vïÞ OOOÄÇÇÃÙÙYîrˆÊ”'N`æÌ™ˆ‰‰‘»”§ÿÉ“'£fÍšB2‡ B‡z½S§Nˆˆ¨È¬ä.@)›6ÿdþ Í¿;𯶲B×ôt³kþ :///ܾ}[îRˆÊ„¤¤$¨Õj´iÓÆ¤š+++x{{ãÏ?ÿÄܹs…5ÿC† Áwß}‡råÄÝ{1 –/_.,“ˆˆ,›ÙRSS%{ìßÓÓ½zõžKTªîß^{ Ø¿_xôj#òó!æ~–|8 ’Þ¹sç ÑhкukÄÄĘÌ! …>>>HJJÂÒ¥KÑ AÉ®5hÐ I†Ó¦MòeË„e‘å2ë@JJ %ùñÚk¯¡gÏžÂs‰JUFàí ìÛ'>>P(r—ôB}ûö-ÖÀðtÔþýû1wî\T«VMâ ‰ˆÈR˜ÅàØ±cØ'Á.æ …C† A›6m„g•ª¬,`Ð `Û6ñÙ¯½¬]‹ à`|ýõ×âóÿ?•J…ƒ"66­[·.òû¤œ>}žžžøçŸ$É'ËPœ ï¶lÙbÖC€ììlDFF¢Q£F˜4i®]»&wI…êׯˆˆœ8qÂ,ÿ'yzz¾t T*áããƒ;wbîܹ¨Q£F)VHDD–ÀäR6ÿC‡-V£Ad’?||€­[Åg¿ú*ðûï@… €É“'ã›o¾z‰'wãnß¾}‰2êÖ­‹ÄÄÄ—>1PRÐóüï†wE}¼?>>ýúõÃÇ%®PœœœDGG£Y³fÐh4&õdLݺu³gÏ"00ÖÖÖr—T"žžžX±bÅ¿†VVVðööÆŽ;ðí·ßÂÕÕU¦ ‰ˆÈÜ™ôàСC’4ÿ†õÅ­ZµžMTª²³7ßÖ¯ŸíåõTóoðá‡âûï¿7úÎZ·nݰmÛ6a»q×­[ýõš5kftÖ³¤¤¤ÀÃÃÿý·$ùd^÷%x÷Ýw‹}gçÎ1}útÉ6äºzõ*úö틤¤$Iò7nŒÄÄDÔ®][’|2m>ÄâÅ‹¡ÕjqçÎ!™={öÄúõëQ©R%!y¢èõzÄÅÅ!44Ç—»œ§¸¸¸àã?ÆÄ‰Qñ¿§ŠË”–3ìÝ»vvv¼YAD$áD©²Ì$Ÿ8pà€dÍ¿›2ÙÙÀ°aÒ4ÿ={ÜùɇjFƒ%K–ù¸)ÃnÜ{öì‘t7î5j`Û¶mhÑ¢…$ùgÏž…‡‡._¾,I>™¶ÌÌL¬ZµJXóýõ^ýuHHH@çÎáåå%É ¾¤ìììŒ . <<œÇÝ•É Íÿ‰'„g—+W#GŽ„»»»ðl¢R•“¨Õç‹Ö½;°q#`o_¬·?ÿ¸ººîÆíççWä'D‘zpþüyôéÓçΓ$ŸL—TC€]»v¡_¿~¸ÿ¾Ðܢؽ{7úöí ///ìß¿¿Ô¯ÿ<åË—G`` RSSggg¹K"""2k&1Ðëõؽ{7Nž<)<[©TbĈÜ8‡ÌŸ¡ùÿãñÙݺ•¨ù77n–.] +++Ô­[óçÏGJJŠì»qKÕ¨\¸p}úô1©MѨtT­Z[·n~’Œ¡¹ÄàEöïßoootïÞÛ¤8F´„lllˆôôtDDDð¸;"""AdšÿS§N ÏfóO#/ðó+X›/Z·nÀ¦M€‘;»víÂÙ³gô³¬K“a Õ‘Ÿ/^„‡‡ÒÒÒ$É'ÓUµjUlß¾;vš{ðàAxyyáöíÛBsŸtòäI¨ÕjtéÒqRì%RBJ¥¾¾¾HNNFDDjÕª%wIDDDEöÀŽ;$kþGމ Ï&*Uyy€¯/ðßÿŠÏîÚµàο ÝÇ»téb2ÿ“¤jÔ 8(»œ…eù¤C‡I28}ú4üüüЦMÄÄÄû©Žç=uꢣ£9¸'""’ˆì€3gÎÏ44ÿõëמMTªòòà—_Ägwè¬_88ˆÏ6AÎÎÎØ²e‹ðFÍàÒ¥Kððð@jjª$ùÅQ’3é©äœœœ°eËtêÔIhîáÇ¡R©pëÖ-£³.\¸FƒV­ZaåÊ•ÈÏÏP¡ñ ˆÃ‡C§Ó¡qãÆr—DDDdÑdˆV¾|yøùù±ù'ó——?ý$>»}{ >(cjYúàúõë AõêÕñ»ËE蹜œœ°yófáC€#GŽ5¸té‚‚‚ФIDFF"77Wh}ÆP©T8pàbccѦM¹Ë!""*,jP¡Bøúú¢N:r—Bdœ¼<`Ì`Õ*ñÙíÚ•Éæß@ª»µ—/_FÏž=‘””$Iþ³Ü¼y!!!¨_¿>´Z->:t»""¢2Åb†æ¿víÚr—Bdœü|`ìX`åJñÙmÛ4ÿ•+‹Ï6#R5jW¯^…§§§äC€@«ÕÂÍÍ Z­ö©Gÿsrr V«ñ‹ËGè¹±yóftéÒEhnQ‡·nÝBXXXáÏÄ£G„ÖaŒ®]»"!!;wîD¯^½ä.‡ˆˆ¨L²ˆ€¡ùçnÁdöôzàÝwèhñÙmÚ €‹‹øl3$U£fpíÚ5xzzJ²ÉéÇ¡ÕjQ¯^=„„„<÷Üø¼¼<øúúâ')–‘Ðs~¶ºví*4÷رcèÕ«®^½ú¯ï~&ÜÜÜðÙgŸáÁƒB¯mŒÖ­[C§ÓqHDDDò1û€­­-Øü“ùÓë÷Þ"#Åg³ù&©5ÃàäÉ“Bò233±`Á4jÔ!!!¸{÷îKß“——¬’b9 =—ƒƒâããѧO¡¹ÉÉÉðððÀ•+WO ƒîÝ»'ôzÆhÑ¢t:Ž= ¹Ë!"""˜ùÀÎÎþþþ¨^½ºÜ¥G¯ÞX²D|vëÖÍ•*â³-€TšÁõë×Ñ·o_œ8q¢ÄÙÙÙˆŒŒDãÆ1iÒ$\»v­XïÏËËC@@VJ±¬„žËÎÎqqqðððš{úôixxx`îܹ…à;w14h€ˆˆ;v >>>P(r—DDDDÿŸ€Q‡‡……‰©¤˜ ÍÕªUe¹>‘0z=0aðÝwâ³›65Äg[˜ŒŒ 8Û·o—$¿jժغu+ZµjUä÷äääà—_~ÁgŸ}†ôôt£k°¶¶Æ²eËàççgt]ff&ˆÄÄD¹K‘T½zõ0}útŒ;åÊ•“»œ)îpˆˆÌ o›éööölþÉ2èõÀHÓü7iÂæ¿¤º[kpãÆ ôî݇zékóóóƒ-ZÀßß_Hó< 0vìXDEE É£¢±µµE\\<==å.EuêÔÁüùóqæÌšmóODDT˜ÝÀÁÁcÆŒaóOæO¯&N/ŸÍæ¿D C©µ;wîÀËË |æ÷õz=bccѾ}{¨Õjœ={Vx †!ÀŠ+„gÓóÙÚÚ"66Ö¢6Á«R¥ ÂÃÃqæÌ¡|ùòr—DDDD/aVGGG r?ÂŒ,€^Lš,Z$>ÛÝض ¨YS|v u£f8p੯'$$ cÇŽ4hŽ;&ɵ òóó1vìX|ÿý÷’^‡žfkk‹uëÖA¥RÉ]ŠQ*W®Œ3f -- ÁÁÁ¨X±¢Ü%Q™ÍÀÉÉ pvv–»"ãM ,\(>·qã‚;ÿ<Ã(R7jwïÞÅ«¯¾Šýû÷cçÎèÝ»7¼¼¼pøðaI®÷,z½ï¿ÿ>¾“bù =—a9À€ä.¥Øìí팴´4„……ÁÁÁAî’ˆˆˆ¨˜Ìb@'''øûûÃÉÉIòkInêT <\|®¡ù¯][|v•••…Áƒ#>>^’üråÊ!77W’ì¢R(X·n(keÍãÇ1lØ0ÄÅÅÉ]ÊKÙÚÚbܸq˜>}:ªU«&w9’â&€DD–›šÁ•+WƘ1cØü“e˜6MšæßÕˆgó/XÅŠ+Ys,wóß¼ysüúë¯fy7ÚÜ•/_kÖ¬···Ü¥<— ‘ššŠ X|óODDT˜ôÀÅÅ|Ì,Ch(ðÅâs]]íÛ þ›„3‡F­¸ ç´?~œç´Ë(%%666r—ñ/J¥¾¾¾8}ú4"""P“û‰Y “¸¸¸Àßß•*U’»"ãýç?ÀìÙâsëÕ+xì¿~}ñÙTÈÆÆ«W¯Æ Aƒä.Å(õêÕCDDDáqmÖÖÖr—T&%%%A­V£M›6X³fÜå²²²‚’’’ È] f’€*Uª €Í?Y†O?fÍŸ[¯^Á~H/666ˆ‰‰ÁàÁƒå.¥ØªU«†ððp¤¤¤ðœv?­[·FLL ôz£¶àF¡P6þ:5’»$"""’ˆÉ ªW¯Ž1cÆÀÞÞ^îRˆŒÌœ)>·nÝ‚;ÿlþK• t:† "w)Eb8§ýüùóF… ä.©Lºxñ"4 7nŒÈÈHäååÉ]R!•J…ƒB§Ó¡I“&r—CDDD3©@5àçç[[[¹K!2Þ—_Ÿ}&>·N‚æ¿aCñÙôR†!ÀСCå.å¹xN»i¸~ý:BBBФIDFFʾéã“T*öïßøøx´oß^îrˆˆˆ¨”˜Ìs †æŸTÉ"Ì ‹Ï54ÿnn⳩ȔJ%~ýõW >¿ýö›Üå²··Çû￞œ"£›7o⫯¾ÂÂ… ‘••%w9Oi×®¾þúkxxxÈ] ÉÀ$5kÖ„¯¯/›² _ |ò‰øÜêÕ-[®Ï5 ?FÇŽ‡ììlYk1œÓ>mÚ4žo+£à»ï¾Ãœ9spÿþ}¹Ëy¦þù‡Çù•a²jÕª___®M%ËðÍ7ÀG‰Ï­^ض hÖL|6KFF~øáÌ™3ׯ_—µ`ÆŒ¨U«–¬µ”e>Äâŋ޻wïÊ]Î ]»v žžžØºu+Z¶l)w9DDDTÊdøûû›ä9ÈDÅ6o0eŠøÜjÕ šÿæÍÅgS‘eggcÅŠ Õ+Wd­E©Tbøðá CCî!›ÌÌL,]º_|ñ®]»&w9EvýúuôíÛ hÕª•ÜåQ)’}@6ÿdæÏ&OŸËæ_v999ˆŒŒDÆ ¡Ñhdmþ ǵ:u ÑÑÑlþe’ÈÈH4nÜ“&M2«æßÀ08qâ„Ü¥Q)’}@dö,¦ù¯ZغhÑB|6½T~~>bbbмysh4üý÷ßr—„råÊaôèÑhܸ±Ü¥”I999ˆŽŽF³fÍ ÑhðÏ?ÿÈ]’Qnܸ¾}ûâøñãr—BDDD¥„"c,] |ø! ×‹Í54ÿ\£[êžlüÕj5RSSå.©PNN|||ðÇÈ]J™bø™hÑ¢üýý‘žž.wIÂܸq}úôÁÁƒå.…ˆˆˆJD%µt) ÑˆoþM›®Í-u èØ±#Ôj5RRRä.癲³³¡V«ñûï¿Ëh‰H IDAT]ŠÅÓëõˆEûöí¡V«qöìY¹K’Ä;wàåå…È] IŒ¢’øñGàwÄ7ÿNN@|<о½Ø\z¡„„têÔ ^^^8räˆÜå¼Tvv6Þzë-¬]»VîR,VBB^yå 4ÇŽ“»œB•*UBpp0Æ/4÷îÝ»xõÕW±ÿ~¡¹DDDdZ8 *®eË€À@ ?_l®¡ùïÐAl.=×®]»àááa–w? C€ß~ûMîR,ÊÎ;Ñ»woxyyáСCr—SÈÎÎÁÁÁ¸páÂÃà &½ÆÝ»wñÚk¯aß¾}Bs‰ˆˆÈtp@TË—ãÇKÓüoÙtì(6—žiïÞ½ðööF=°}ûv¹Ë)±œœ¨ÕjüüóÏr—bööìÙƒ¾}û¢gÏžøóÏ?å.§ ‘ššŠððp8;;(8báÂ…øàƒ„^C"""ËÆQQ­XŒ'¾ùwt6o^yEl.ýˉ' V«Ñ­[7ÄÅÅÉ]ŽyyyðóóÃO?ý$w)féøñã…?Û¶m“»œBJ¥HOOGDDjÔ¨ñ¯×( ,X°'Nzí{÷îáµ×^ÃÞ½{…æ‘ü8 *ŠÿþWÚæ¿S'±¹ô”¤¤$¨Õj´iÓ111Ћ޻Afyyyð÷÷ǪU«ä.Ålœ:u jµmÛ¶ELLŒÜå²²²‚’““Úµk¿ðõ …óçÏǤI“„ÖqïÞ=¨T*ìØ±Ch.É‹¢—Ñé__ /Ol®ƒCAóß¹³Ø\*tþüyh4´nÝZöÆ¿N:˜7ožðuÛyyyÀÊ•+%É·§OŸ†ŸŸŸÉ ƒžlüu:ÜÜÜŠü^…ByóæaêÔ©BkÊÈÈÀ€Ìz™ =­œÜ™45 ÈÍ›kgÄÆ²ù—Ðýû÷áéé‰sçÎÉZG50uêTh4”/_`ooððpá×ÊËËØ1c ×ëáçç'<ßœ]¸psæÌÁ²eË+úϳ  €™3g¢mÛ¶FeÍ™3 …sæÌT]Á`àÀˆ…‡‡‡°\"""’Ÿ zžÕ«¥kþׯzõ›KOqpp@bb"4h Ëõ]\\0cÆ œ9s'N,lþà‹/¾À´iÓ$¹n^^ÆŽ‹¨¨(IòÍÍåË—„&Mš 22Ò¤š•J…ýû÷#66Öèæß`öìÙ˜>}º,ÃÀ”öH ""¢’á€èYV¯FŒßüÛÚqq@ïÞbsé™\]]‘˜˜ˆ† –Ú5íí팴´4„……¡R¥JÏ|ša°bÅ IòÍÁÍ›7www,\¸?–»¤BÝ»wÇöíÛŽœü1kÖ,üç?ÿš™™™ oooˆˆˆÌDÿë·ß€‘#¥kþûô›K/TZCÃ9í/^Dxx8_úžY³f!44T’zòóó1vìX|ÿý÷’䛪۷o#,, nnnÐjµÈÊÊ’»¤B]ºtABBvî܉Þ?ÿüs|úé§B3 C€„„¡¹DDDTz¬„ÐÇÈf¦k×®(WŽ[‰X»>ÈÉ›kk[°æßÓSl.‰££#†ŠØØXܹsGh¶ Þ~ûm¬]»C† AÅŠ‹õ~OOOäççKvöü† PµjU¼báÇL>|øóæÍƒZ­ÆæÍ›MꎫV­°hÑ"|óÍ7¥ú4Ša;Èüsrr°zõjtêÔ©Xš‹ŒŒ ¹K "" ÙÛÛË]‚ìd¤¥¥¡yóæP*•FåmÃ@­²³ÅæV¬XÐü÷í+6—ŠåÉ!ÀíÛ·ÎS*•7n~ûí7Œ9Ò¨¿P¤hÔž´qãFT©R,ð¸ÉŒŒ |ÿý÷ðññÁüGÉ]R¡æÍ›cñâÅøöÛoÑ¢E YjèÓ§*V¬(ô®}nn.t:Ú¶m wwwa¹¦€""ËÆ€ >|ˆôôtH^7o¼ˆ¾kX±"°n R‰Í¥qttÄo¼aÔÀÊÊ Ã† ÃÚµkáçç!µIѨ=iãÆpqq±˜!@vv6~üñG¼ùæ›X½zµI5n 4€V«ÅÒ¥KѲeK( YëéÑ£‡ÐŸ-¥R‰·Þz jµÎÎÎB2M…)ý‘x˜ÈW®\Att´I­Õ¤2dÓ&išÿòå˜6ÿ&¦N:øë¯¿Ð¼yób½ÏpN{RRR±Ïi/ªàà`I޽^‰'âÛo¿•$¿´äää 22 6„F£Á•+Wä.©P½zõ3gÎ 00ÖÖÖr—T(88_~ù¥Q†?§NBtt´l'lQÉÉþ€Áǹ€JßæÍÀС€èdžml€5k€Åæ’ööö6l6lØ€7n¼ôõ*• 111˜8q"ªT©"im=zô€­­­dOlÚ´ NNNèÒ¥‹$ùRÉÏÏÇêÕ«ñÆo ::<»¤BÕªUÃþóüôÓOèܹ3¬¬Lb¶þ/Ý»w‡½½=âãã‹õ>…BB§Óa„ pqq‘¨Bùñ ""ËÆ'Lä ƒ«W¯"::™™™r—BeÁ–-À!Ò4ÿ«W³ù7qÕ«WǶmÛ^¸6[¥RáÀˆG»víJ­¶O>ùÄ軵ϣ×ëñá‡bþüù’䋦×ëƒæÍ›C­V#55Uî’ U©Rááá8þ<‚ƒƒQ¾|y¹Kz©>ú_}õU‘_¯R©pðàAÄÆÆ¢uëÖVFDDD¥Á¤píÚ5,_¾>”»²dññÀàÁÒ4ÿ11€··Ø\’„aвe˧¾Þ½{w$&&JvN{Q|üñÇÅjÔŠÃ0øâ‹/$É%!!:t€Z­FJJŠÜåª\¹2f̘´´4ûä¹M™2ß|óÍ _£R©°oß>ÄÇÇ£}ûö¥TIÍè%5¶ –Afffár¡ÙDHH¦ùW* šÿÁƒÅæ’¤ììì0lØ0lÞ¼ 6Äwß}­V‹úõëË]ºuëlÙ²E’ü­[·B©T¢W¯^’ä—TBB†Žððp\½zUîr ÙÛÛãÃ?DLL úõëgwüŸ§k×®prrú×ÏV·nÝ…O?ýµk×–©:ùp ‘eã@@oL€ FŽ)ɇå*UªÀÏÏ•*UžMeÔ_¯¿ˆ~ÂD©tº‚%d–233akk+wÏ4oÞ3ÜÚˆŠF›Kô:tt°k×.Ɇ†ãòÆ£GJ¶œ¡¸ÊÒ9÷ôbY6íð¿”J%FŒ† ŠŽ†³³3„Ÿ<@hÏž‚æÿþ}±¹ÖÖÀŠÀèÑbs‰ŠáÇD`` òóó%Éÿä“O Õj…d]ºt ³fͲeË››+$S•J­VË£î÷Ê’%5ä.ˆHV3f˜ÆM°’"4''?ÿü³$k:ïܹƒeË–áîݻ³ɂ>  ¾ù·²–/góO²{ûí·±téRXYIòk_~ù%>ùä£2nܸ¸»»#22Ò¤šžsODDDe‘4ŸäææB§Ó!%%Exö½{÷°bŠܹsGx6Y€Ã‡//@ôχ•°làë+6—¨„ÆŽ‹~øA²!ÀܹsññÇû}·nÝBHH\]]¡ÕjñèÑ# ª+™nݺaÛ¶mˆG§Nä.‡ˆˆˆ¨TI6¤DEEq@O;r¤ ù¿}[l®B|÷àï/6—ÈHcÆŒÁªU«P®\9Iò¿úê+L™2¥H¯}ðà´Z-ÜÜÜ Õj‘••%IM%Ñ©S'¬[·»v킇‡‡ÜåÉBÒPp:€N§ÃéÓ§…gž¸-ºÙ#ótô¨´Í¿F#6—H#F`åÊ•’ ¾ùæLž<ù¹ßÏÈÈ€V«…««+BBBpïÞ=Iê(‰–-[B§ÓaïÞ½ðöö–»""""YI> †111’ îß¿¨¨(ʺcÇ• ¸uKl®B,^ ¼óŽØ\"Á†.é“óæÍûï¾ûÔÎý?Fdd$5j„“z"«iÓ¦ˆŠŠÂ±cÇàãã…B!wIDDDD²+•ðC€äädáÙ÷ïßÇòåËqãÆ áÙd¤lþ-Þ}Wl.‘DÞzë-üôÓO’ –,Y‚wß}·°ñoذ!4 ®^½*ÉõJÂÕÕ8qâüüü$ÛˆˆˆÈIr à‹XYYaèСhÕª•ðl;;;øûû£jժ³ÉD?ôí ܼ)6W¡¾ýxÿ}±¹D¥ &&£FBNNŽ$ù¸/ú„ #Õ­[S¦LÁ;#òåËË]™)( HDeÅø"ùùùX»v-Ž?.<;##QQQ¸~ýºðl2A§O¯½&Mó¿`›2[>>>øù矡T*%É7¥æ¿jժǙ3gÄæŸˆˆˆèdy62??¿ÿþ»dC€èèh,]J àé Hñèqx8ðÁâs‰JѰaÃðË/¿H6›‹‹ f̘´´4£B… r—DDDDdòd[i;vLx6‡.%ðð®\Ÿ|ò‰ø\"¼ùæ›X»v­EÝ···Gpp0ÒÒÒ†J•*É]‘Ùuw¤üü|üñÇ’ ¢¢¢¸žÏÒœ9Spç_ŠæÎ 8X|.‘Œ €ß~ûÍì‡vvvÆÅ‹GGG¹K""""2;²ol=zTxvff&V¬XþùGx6ÉàìÙ‚;ÿRüûœ=˜:U|.‘ xýõ×±víZ³|LÞÆÆHMMExx8œå.‰ˆˆˆÈlÉ>¤—È„ôïß߬†J¥HOOGDDjÔà.âDDDDÆ2‰èõzüþûï8pà€ðlÃàï¿ÿžM¥àÊ•‚Çþ¥ø÷7k0}ºø\"Ô¯_?üþûï&=°²²‚’““ÚµkË]‘Å0™€Áúõë%¬ZµŠCsT£àí->÷³ÏØüS™ãîîOOO¹Ëø—'N777¹K""""²8&7 †û÷ïžkxàòå˳IB °x1ðÞ{â2gÌ>ýT\‘‰»xñ"4 ÜÝݱaùËyŠJ¥ÂÁƒ¡Óéàîî.w9DDDDË$°aÃìÛ·OxîãDZjÕ*ÌB,Z¼ÿ¾ñY „…ŸCd._¾Œ   ¸»»#22¹¹¹r—TH¥RáÀˆG»víä.‡ˆˆˆÈâ)èå.âEú÷ïÎ; ÏU*•5j\]]…g“„ôz`âÄ‚a@I|ô0w®ØšˆLÐÍ›7ñÕW_aáÂ…ÈÊÊ’»œ§tïÞ³fÍBŸ>}ä.…è)<:XK–pO""fÌ0¾u7Ù' 6n܈½{÷ ÏÍÉÉÁO?ý„óçÏ Ï& )ÀÂ…C€âš2…Í?Y¼Û·o#,, nnnÐjµ&ÕüwéÒñññعs'›""""XðPOîB^$55ÖÖÖÂïÖççç#)) uëÖ…“““Ðl’Bôëܽ u™ÈäÿÇÞ}‡GUæí¿'4Ž tBB/R˜¨ °´Œò*àêkâ«®¸®ï&¶\E“Ÿ® ödwId&I” „šÐ’Hh¡×ô6¿?f™ÔçÌsÎäþ\———™ä{nsîyÎsÞþþwesITPP€üãÐëõزe JKKeGúGy;vìà=þ¤j………²#8¤}û¾’ˆÈ!Lš´¤Á3œ< ±Á“íÛ· Ÿ[^^ŽU«VáäÉ“Âg“‚t:`Ù2À×·æï}ç^ü“Ã***ÂòåËáìì ___\¿~]v¤{JKKìY³PRR"; Q£å À4&ÉYj” X °zõj–ZôÅÀûïÛ~}Ñ"àÿ°_";)++C`` œñÎ;ïhâÞåÍ›7cöìÙ,ˆˆˆˆ$±î ©`Û¶mÂçZK€'NŸM ûüsàÃÿu//^ü“Ã)//Ghh( oooäççËŽT'›7oæJ""""Iîܰ)L&…ϵÞ••%|6)ì³Ï€>úõŸ_{ øé'Ë­D ªª F£ƒ ÂÂ… 5½b)&&3gÎTÕ…DDDDA“»þ¹€À8}ì§örssQQQ¾}û k6›‘‘‘®]»¢cÇŽBg“ÂÜÜ€ª*ÀÅ äÅ?9³ÙŒˆˆÌ;?ýô®^½*;’999Ø»w/æÎ‹f͚ɎC€›*…›‰!jÀ»˜ ¡ÁÓ–””„¸¸8ás+++a0™™)|6)ìoãÅ?9Œ¸¸8Œ=z½Þ!?Úºu+ž}öYÈŽBDDDÔ(Ü«~-T;@RRbcc…Ï­¬¬„ÑhtÈ7Ýÿ¤qqqq;v,<<<––&;Ž¢¶oߎçž{Ž%‘Ø*€_÷ÿ»`ÉÉÉØºu«ð¹ÖàØ±cÂgÝ-99nnnðððÀÞ½{eǹíþûïǼyóСCEæoß¾S§Ne @DDD¤°ê ÀRÌ€J€””ÅVDDD° "ÅìÞ½Ó§OÇO<“I= ¯š7o///dggcÕªUHHH@§N9ÖŽ;0eÊܺuK‘ùDDDDYEEvíÚUcÅÐH œœŒ-[¶Ÿk] ‘‘!|65^GŽ^¯Ç¸qã%;ÎmÍš5Ãüùó‘‘‘€€<ôÐC€áÇcûöíèÚµ«"ÇMJJb @DDD$PUURSSñÍ7ß`Ë–-µ*K 0 @´‚لعs'¢¢¢`6›…ε>‚ëðáÃBçQã“‘‘ `øðá0¿ª/'''xzzâèÑ£ ½çSVˆ„„tëÖM‘ ÉÉÉxöÙgqóæMEæ5f³éééøþûïuû–ÚP `õ|Leþ}û-üMµÙlÆúõëqèÐ!¡s‰¨qÈË˃··7†а°0TUUÉŽÐét˜6mÒÒÒ`0пÿj¿_é %%…%Q=Üyáo4÷麀¥˜ ”J¬0›ÍذaK"ªµÓ§OcÑ¢EpuuE`` *++eGºÍÝÝ{÷îEdd$†^ëŸ0`L&ÓíÛDÛ¹s'ÜÜÜ~÷‡ÝÛ‰'£Ñˆ+W®Üó{šÖc®u%@, T­ÔÔTÀ´iÓ øh8k `6›ëô†™ˆ—K—.áïÿ;–/_Ž’’Ùq~cüøñøüóÏñä“OÖ{†««+àææ†sçÎ Lg‘šš ÄÆÆ*ö""""­;qââããkõ~¬®+¬Ê`Y YÏŸ·›ÔÔTDFF*²à—_~ÁÁƒ…Î%"í»rå |}}Ñ»woøûû«êâÿñÇG||<’’’tñoåêê “É„‡~X@ºßKKKƒ‡‡‡Í›ˆˆˆ¨±:}ú4BBBVëcê[¿–0Ã.ÒÒÒ°qãFÅJ€KDÚtëÖ-øûû£_¿~ð÷÷GQQ‘ìH· 6 ƒÉÉÉpss:ÛÅÅ…%‘œ9s«W¯ÆŠ+››[§Ÿ±.¾9#, Tµ‘#GbÆŒBo°zî¹ç0zôhás‰Hý ñÝwßÁßß×®]“ç7ŒÅ‹cîܹŠüÞw§ÜÜ\Lž<¹ÎÕÖˆ#‹N:)2ŸèÂ… ²#8¤Ÿ~RæÑ¡",^,;‘}5d€UO¿˜¥¨ýû÷cíÚµŠì¼½{÷ ŸKDêUVV†ÀÀ@8;;Ã××WUÿ @HH<OOOÅ/þ wïÞHLLDŸ>}™àÀ¸»»ãòåËŠÌ'"""rt" ÀRèl4O1GŽÁºuë)6mÚÄ€¨(//G`` úöí oooœ?^v¤Ûzõê…€€>| ,@“&Mì~|“ɤX pðàA¸»»ãÒ¥KŠÌ'"""rd¢ ÀR<”J­Ø´iöìÙ#|.ÉWUU£ÑˆÂÛÛgÏž•é¶îÝ»cÙ²eÈÌÌ„——š6­ÏC^ÄèÕ«Ñ·o_Eæ|z½ãÆC||¼ì8·5kÖ ^^^8qâЭ[7Ù‘ÌZ ;99™%©Bqq±Ð ïÌf3-Z¤ÊàÔ©Sðöö†‹‹ yòG}¹»»#55ƒ®®®²ãØ…Ò%@^^&Mš„'N4xÖž={0}útŒ?¾N÷÷—––bîܹˆŒŒlp""""ì]¿–aŽ]'999X¹r%ʧ  IDATÊÊ„Ïf @jвeK¼÷Þ{hÑ¢…°™Ö`Ù²eÂf6ÄÅ‹áëë WWW*²²§¾ÜÝݱgÏÄÆÆbäÈ‘²ãØ]çÎaÆ)2ÿÔ©S˜ÁÍ›7?fm 2ƒ)))˜>}ºì8ªd`„ ÈÈÈøÝkgΜÁ¢E‹¿MÄZ¬_¿^‘ùDDDD5‘]–àh 8uꔢ%@tt´jv$§ÆiÊ”)X¿~½ðà£>§Ÿ~*t¦UQQ–/_gggøúúâúõ늧>ˆK’ÎÙÙcÇŽÅÚµk…^%&&B§Ó5èþ÷òòr¬\¹žžž CAA°| Õ£G|ùå— ˜1cà䤆EVÚsß}÷ÁÓÓ‰‰‰8sæŒðùEEEØ»w¯"›»ÖÖý÷ß~ýúaòäÉü½^EX(ƒ‘z¨íÝ©À~”¤&çÎCXX˜"Œ¥¦¦"**Š·TO?ý46oÞŒV­Z »dÉøúúÖù窪ª`41xð`,\¸PÈóÝEéܹ3üüü••///᫃£¶mÛbË–-7nœì(B5oÞ^^^ÈÎÎÆgŸ}Æ‹"""²+µ€¥x)BCC)ÒÒÒXt'NĦM›Ðºuk¡sýýýk]˜ÍfDFFbäÈ‘ÐëõÈÎΚ¥!:vì???äååÁÇÇGøÞ Ý<€ØØX‡xbB³fÍ0þ|;v èÖ­›ìHDDDÔ©±~-~¤&ùùù EQQ‘ðÙiiiˆŒŒd @R=ù䓊•ýë_«ýž¸¸8Œ=3fÌÀ¡C‡„¿!Ú´iäääÀÇÇ-[¶”ÉaµjÕ QQQš-œœœàé鉣G"44}úô‘‰ˆˆˆ1µ€¥x ¼Ø¿?6nÜÈ€¤š0a6oÞŒ6mÚûå—_âÿ÷÷õ¤¤$<ùä“ððð@ZZšÐc6D«V­àãー¼<øùù¡mÛ¶²#5 Ö`òäɲ£ÔšN§Ã´iÓ°ÿ~ ôïß_v$""""UÀ¯%À÷²ƒÔäüùóŠ•ÀºuëPUU%|6Qm=ñÄŠ”_}õÞ{ï=@JJ žzê)L˜0;vìzœ†hÑ¢¼¼¼püøqøùù¡}ûö²#5:ÖÀÍÍMv”¹»»cß¾}ˆŒŒÄ°aÃdÇ!"""ºM+»é| ËmªÖ¹sg,\¸Pøri2dfÍšÅÅIªäädL:7oÞ:·oß¾ªÚذlØöòË/cñâÅx衇dÇ!XvðŸ1câããeGùwww,]ºcÇŽ•…êéÂ… ²#8¤Ÿ~ê*;‚M‹ËN@Dd_Z¹’4ø€ïd©É¥K—‚[·n Ÿ}äÈ® éÆÍ›7ã:WMÿM›6Åüùó‘‘‘€€^ü«Èý÷ß7â‘G‘å¶Ç ˆåÅ?©šV ÀR¼ ËJUS²8zô(Ö®]Ë€¤²^ð8ÚRø»7lëÛ·¯ìHt—¤¤$<÷ÜsªØâÑGÅÆ‘œœ¬©ý ˆˆˆ¨ñÒRXJ€E¾‘¤&—/_V¬HOOg @Ò5 ±±±èСƒì( fݰ--- ƒ...²#Ñ]víÚ…éÓ§c„ HLL”šeÈ!0 عs'¦OŸ.5 Q]h­,%À;ÐH ¬X Á€¤r„ÀÝÝ{÷îEdd$†.;ÝåðáÃÐëõ7n¢¢¢¤f8p BBBpðàAxzzB§ÓÊ6:DDDDZ~÷¢ðXV¨ZÇŽ±páBá÷L@ÿþýñüóÏ£I“&ÂgÕÖþýûááá+W®ÈŽRkãÇÇÒ¥K1qâDÙQèÒÓÓ±dÉDDDH ªN§Ã»ï¾ þ^ëภ 2¸ à¯tŸØ÷xD¤f•l:ªÅVf°Lvš\¹r!!!ÂwM€ììl¬Y³•••ÂgÕÖÈ‘#‡Ž;ÊŽR£qãÆ!..III¼øW¡ÜÜ\x{{cذa0Ò/þÀl6ã§Ÿ~RÕ£)‰ˆˆˆêCËðk à';HM®\¹‚+VàÚµkÂggggãçŸFEE…ðÙDµ5bÄlܸ­Zµ’垆 ƒÁ€””<õÔS²ãÐ]N:oooôïߪ+5 1mÚ4˜L&ÙQˆˆˆˆêMë€Õû¾–¢&ׯ_GHHˆ"%ÀñãDZfÍ–$Eaa!üýý1mÚ4ÊŽóƒ†Á`Ààéé);ÝåâÅ‹ðõõ…««+Uý{˜µHHH…ˆˆˆ¨^¥€¿ø\vˆš\¿~ÁÁÁŠ•\ @öTVV†ÀÀ@8;;Ã××W‘_×õÕ§OpÃ6•º|ù2|}}Ñ»woøûû£¤¤Dv¤Z)**ÂôéÓ/; Q9RB%À7Œ«W¯ Ÿ““ÀW^^ŽÀÀ@ôíÛÞÞÞ8þ¼ìH·õìÙÈÊÊ‚——7mS™[·nÁßßýúõƒ¿¿?Š‹‹eGª³¢¢"̘1qqq²£Õ‰£€¥X*;DMnܸÅJ€ððp”—— ŸM[UUŒF#oooœ={Vv¤ÛºwïŽe˖ݾðoÚ´©ìHt‡‚‚øûû£gÏžðõõUdST{²–±±±²£Õš#ð€Ïd‡¨‰’+òòò°råJ”•• ŸMõÂРAÐëõÈÉÉ‘é¶N:ÁÏÏYYYX´hZ´h!;Ý¡¨¨Ë—/¿}›Èõë×eG¦¸¸Ó§OGTT”ì(DDDDµâ¨| ”7oÞÄŠ+péÒ%á³Yqqq=z4ôz=233eÇùAƒáرcðññAË–-eÇ¡;X÷‡èß¿?Þyç©ÏWwrrB¯^½™]ZZŠ9sæ 22R‘ùDDDD"5†]±þK j­[·ÆÂ… ѹsgá³{öì‰_|Í›7>›W\\Þÿ}ìÛ·Ov”jÍ™3«W¯F³fÍdG¡ÿX³f þú׿âÔ©SRs899á…^Àâŋѯ_?¼úê« QäXÍ›7‡ÑhÄŒ3™Oö!³¨rd?ýÔUv›/¶ïñtŸØ÷x^OâßZÛ–jÇc©ÙCÚÙxíµìûû €îÕ¼.ø¿§ÙÎ¿ßØÒn’ý?æÿü]µ ‚  K—.BgŸ:u áááx饗XP’’’ðñÇ#11Qv”ZY»v-fÏžˆˆ.ÿW‰ ¨¨Hjwww|ùå—1bÄí¯­X±)ÊÊÊàéé ƒÁ€?üáÂçQ= 0ÊŽÇkì@k†ÂöÇÌòí–¨z3T×O:èOG¾àN‹aY  jÖàâÅ‹ÂgŸ>}ááá(-->›î]»0}útL˜0A3ÿVQQQ˜3g}«Äðáñ}ûvtíjÿOýÜÝݱwï^ÄÆÆþæâ°¬ Â믿®È±ËÊÊ ×ë±aÃEæ©’€G¼K颅5æƒQýÅ¿k,`)T¿ðª°°!!!Š,C<}ú4BCC5ó¼m²Ã‡C¯×cܸqšÞÌ,::³gÏæ¯o•8p L&ºuëf—ã?‰‰‰ˆÅèÑ£m~ŸN§Ã?ü€ÿùŸÿQ$‡µX¿~½"󉈈T¥'/ÏÐÊBL€I²CÈÓ˜ XÀWvˆš"44T‘àܹs Õä³·I¬ôôtèõz >F£Qv!6mÚÄ@E €„„EK€Ç{ ±±±HJJÂĉkõ3:ßÿ=Þxã E2•——ãùçŸÇºuë™ODD$]k³¼ ˽ôZ2@'Ù!äiløC#%@pp0Î;'|v~~>ÂÂÂX4R¹¹¹ðööưaÃ`4a6›eGjóæÍ˜5kK•0`L&zè!¡s‡ ƒÁ€;wÂÝݽÎ?¯ÓéðÝwßáÍ7ߚ˪¼¼z½«V­Rd>‘Z\î'€'e‡«1lx/þÿù»ŸÔ5(..FXX^zé%<üðÃBgççç#44 ,àãÓ‰S§NaéÒ¥X±b***dÇù–-[ -¤bbb0sæL¬_¿ž¿¾UÀÕÕ&“ “'Onp©9hÐ ,Y²sçÎ…N×°w:ß~û-œœœðí·ß6hÖ½TVVbÁ‚0›ÍxñÅ…Ï'"¢¤Â²ë¼(ØÚ«û²Àã¨UOS¡½Oüï4@GÙ!äjŒ+¬üøÈQk pöìYá³ÏŸ?ÏÛ‹/Â××®®® TÕÅ¿»»;öìÙƒÌÌL8;; ½eËÌœ9“¿¾UÂÅÅ&“©ÞefïÞ½€C‡ÁÓÓ³ÁÿV:Ë—/ÇÛo¿-dÞÝ*++±páB„‡‡+2Ÿˆˆª‘ ]Ð_Maûâ¿ €A© ¨ËrÿBÇ”TOMLB¾Æ\ÀÿðWÙ!jRRR¢x û‘]$ÞåË—áëë‹Þ½{Ãßß_UKâÇ„„ÄÆÆb̘1èÑ£L&“ð`ëÖ­˜2e …Î¥ú±–Ý»W÷ÐÝßêÙ³' ///4iÒDx.N‡eË–aÑ¢EÂg–àå—_FXX˜"ó‰ˆHa˜fã53€_\²_»©Ërÿ*»| Cùhõò€v²CÈר øÀÿÊQk pæÌá³Y8–[·nÁßßýúõƒ¿¿¿ª>ôÑG±qãF$%%aòäÉ¿y­{÷îØ±c $ô˜Û¶mÃÔ©SQPP t.ÕOÿþý±cÇôîÝ»ÚïëÒ¥ üüü™™ ///4mªìkÖÀ×W™-b*++ñÇ?þ¡¡¡ŠÌ'""…ÜàyÍl¼ž Ë G4µÛÝ?Àb¨õ‰ÌMÝæ÷uíÚ ÂK€íÛ·³P‘Þ½{#11}úôùÝk:u‚ŸŸrssáããƒûî»Ï®Ù¾øâ |ðÁŠÌ®¬¬Ä+¯¼‚Eæ‘`:s´·ñúI ö‹cw5Ýmw €@8Ô¿ÂÈ¡,~õ€÷d‡¨III BCC‘››+|öåË—‹$òõõ…¯¯/®]»&;Êmƒ ‚Ñh¬Ó}Û>ø 0xð`¡YvìØ)S¦àÖ­[BçRýôêÕ &“év ЦMøøø ''>>>R7o\ºt)>üðCEf[K€   Eæ‘@“غ;ñ€XnhlÊlð´±ú¡9€ñ6^+·gu`ð[ðÙ!jRVV†U«V)Vó"Iƒ–/_ŽùóçËŽà·¶Õg·vk 0dÈ¡¹’’’X¨H¯^½€O?ý§N‚ŸŸx@õügŸ}†>úH‘ÙUUUxõÕWñã?*2Ÿˆˆpí%ã°lú×ïžÍð=€DX΃ŒÐê_¿à ³¨ €ßû*Nž<)|ö•+W‹$iÒ¤ ‚‚‚°páBizôèeË–áØ±c Þ°­K—.ˆÇСC&’““1eÊUÝ"јõîÝ}ôÚµSß®<Ÿ~ú)>þøcEf›Íf¼ùæ›øá‡™ODD ÐÀlØ^¿ @Þj«=çX Ëê­hàq¯m‡vJ XÜÛ×Þ•¢&,ènMš4ÁŠ+ì^tîÜ~~~ÈÊÊ¢E‹Ð¢EM»ÅÔK’íoû/^¬Èl³ÙŒ·Þz ßÿ½"󉈨šÁ²éŸ­·2©öÛ/ŽtŰlîà”ä,õ1À½î*¼Æõßñ,lû€?ËQ“òòr¬Zµ 'Nœ>ûÊ•+æE’Æ899!((¯¿þºâÇêØ±£â¶uîÜÛ¶mèQ£„ÎMII›››ªöL uZ²d üüü™m6›ñ§?ý ß~û­"ókãæÍ›X²d ^{í5TVVJËAD¤ ÐÅÆkgl¶cÙNø–Çûiq¯ƒû`yŒá½$h¤䱨Þ2XJUÿ’///ÇêÕ«)®^½Š   \¿~]ølRŽN§Ã?ü€7ÞxC‘ùwoØvÿý÷+r«öíÛ#66£G:755¸zõªÐ¹äx|||--Z„o¾ùF‘ù¶bùòåèß¿?>ùäüë_ÿ¼yóPQÑ×C–O‹míA\ ˦é¢ñ€Ù!`<,%ÀÝ®8dç,* fËü4RäääŸ}ýúu³ÐN‡ï¾ûNh ЪU+øøø //~~~hÛ¶­°Ù5±–cÆŒ:—%Õ–üýý™m6›ñÎ;ï`ùòåŠÌ¿SYYÑ¿¼óÎ;¸xñâí׌F#æÍ›‡òòF¸-25n=¸ÛxÍ `-¾ÖŽûaÙüï^TÙ/ŠÚ°¨h¨ÈÊÊ>ûÆæri±–o½õVƒæ4oÞ^^^8~ü8üüüо½­â*«]»vˆ‰‰~;@ZZšbÏ~'Çò׿þ_~ù¥"³­%€R+ ÊËËŠÀÛÛùùù÷ü¾ˆˆ–DÔ¸´ ‡í+£8â?c#%M€åñw»àˆ³¨ €Ú ð:T^TTT`Íš5ÈÌÌ>ûÆ a  1:ß|ó þô§?Õùg›5k///œ8qèÚµ« ë¦C‡ˆ‹‹Ã£Úº©«n ƒÁÀG²Q­½÷Þ{øê«¯›ÿþûïãóÏ?6¯ªª F£ƒ ÂÂ… kµqìÚµk1kÖ,”–– ËAD¤JN}€C‡ÁÓÓ:­gýýÞ_þòüýïWlþ‡~ˆ¥K—6h†Ùl¾}á¯×ëqüøñ:ý|tt4æÌ™Ã€ˆÛ=m¼vÀ;f!1ž„åiw» ÃÎYTˆ@Ýý–@ÕwŽXK€cÇŽ Ÿ}óæMóžiÑétX¶l-Zdó{î¼ð7 èׯŸÖMÛ¶mSç gÏž@VV¼¼¼Ð¤I…’£{÷Ýwñõ×_+V}ôÑGøì³Ïêõ³qqq5jôz}ƒÊàèèhÌš5 %%ZÞŠˆÈ†alí/\` v ÚÒÀ#6^‹‡Ê?ƵõóOXnP} `4‘‘!¾êºyó&‚‚‚péÒ%á³I9Öàý÷ßÿÝ×§M›†ÔÔT ¸¸¸HJX7mÛ¶E\\&NœXã÷véÒ~~~·/ü›6mj‡„äèþüç?ã‡~P¬øøãñé§ŸÖúûãââ0vìXxxx`ÿ~18Þ¼y3fϞ̀ˆ˃¦ÙxÍ àXî'm™à^Ÿíœ ~›4MbPšY ¡H PPP€–ôùçŸßÞôÎÝÝ{öìAdd$FŒ!9YݵjÕ ÑÑј4iÒ=_ïÔ©üüü›› ´hѾÉá½þúëøñÇ+þïÿþŸ|òIµß“œœ 777xxx`ïÞ½Â3lÞ¼™+ˆÈq´ð<î½L’¤Û/ ÒÀp¯%Ø3ˆº±h˜ð‚J£ÑˆÃ‡ Ÿ]XXÈ@£–.]ŠôôtÄÆÆbôh[ëß´¡U«VˆŠŠÂäÉ“o­C‡X¼x1rrràãブ-[JLHŽÎÛÛprRæÕ%K–À××÷w_ß½{7¦OŸŽ'žx&“I‘c[ÅÄÄ`æÌ™(..Vô8DDŠ›ÀÖ.ØËcä¸=¶LĽ¯nOƒOq¸×À6Ü¿ÿó÷@¨¸P©ªªÂúõëa6›1lØ0¡³­%À‚ Ð¥K¡³IY”A˜V­ZaãÆxá…0jÔ(¼ûî»hÛ¶­ìXÔˆ¼öÚk,+ªªÄ÷Âþþþ???9rûÛß³Ù~74nÙ²3gÎĆ Xª‘vU·ÅQw>8©–[ò`Ù@îÞOP%Ù:jã5~úÿ,Äø7,w ý*/6l°leªD Ê€¤jݺ5¢¢¢dÇ Fìµ×^ƒ““¼¼¼+¢¢¢‘‘¡ÈüÚØºu+¦L™‚¨¨(´nmë¹YDD¢%,O è ˳åψƒ¥ õpýWlœkß(j§Ú‹U Zà5¨üvk pðàAá³­+.^¼(|6‘V¼úê«øç?ÿ©ØíG•vñÝ»wǬY³Ð¬™­›g‰ˆXw <Þ" ]ØZԺ͞A´€X+ü74PüòË/8pà€ðÙEEE B~>×GQãõÊ+¯à_ÿú—b%€ Ö 5³²²°hÑ"n¨ID—Àcf‚%€Øúô?À);gÑÇyg¢A^P);Hu”,JJJŠsçÎ ŸMD¤üã®ùGNrCM""†ÁR<ÝÜëéÕfðÓ´ý®D½VÃòË. *>Çf³6l@yy9ÆŒ#tvII ÂÂÂ0þ|<ôÐCBgiżyó Óé0þ|TTTÈŽS'­[·Æ›o¾ ___´k×Nv""qRm|½,¼–eåµYèäà(€›b¢Q=…{úŸ ଳh„j/NÀÏÿù»ªKˆŽŽÅJ€—^z ?ü°ÐÙDDZñ /@§Óᥗ^ÒD ЪU+¼úê«øðù©+9¦ÚîÜ–åð€ïi Ëæ€ÑrQÝôÀ½Ÿè`hß(ZÂ[”õ3,·¨þ_tt4öìÙ#|®µ8{–5^Ï?ÿÖx)vïÞ-|nii)ÂÃÃYQ£6sæL¼òÊ+ÐéäoíääOOO¤§§#44}úô‘‰ˆH½*l¯æõ¾ö B€I6¾~Àe;æÐ öc€FJ€Í›7c×®]Âç–––"44¹¹¹Âg©YUUŒF#ˆ€€˜ÍfiYt:Ýí ƒÁgggiYˆˆ4ål?ìûA{iäúèy¯WŸþ× û2ø/h ˆ‰‰ÁŽ;„Ï-//ǪU«XQ£pç…¿^¯GNNŽÔ<îîîHMM…Á`€«««Ô,DDšS Û÷–sÛû™hãë\³gmb`Fó  ¿ø#> IDAT>>^ÑàäÉ“Âg©ÙlFdd$F½^¬¬êvRž»»;öìÙƒØØXŒ9Rj""M»bãë-`ûI$Î÷z¸X%ñ—-‰€°”岃Ô$>>Û·WwÃSý”——cõêÕ,ˆÈáÄÅÅa̘1˜1c8 ;ÜÜÜ#üQ¯DDÒÕj^kc·×£6¾ž Û›4Òo¨÷yDŽ/–}*WP×–ÐwIHH€ÙlÆÄ‰¶ÖÛÔµxá…з/wN!"mKJJÂG}„mÛÔubBB^zé%„……©ú1„DDšPTÍk| òZØøzOóë1¯c5¯Ùšw@t=Ž¥|' ×ZXV¨¾0™L X 0oÞ<–D¤I;wîÄÇŒøøxÙQlúùçŸa6›Î€ˆ¨!ª[¿këâ””×U™¶.MZ*p,;â-ò­ð4p;€ÉdB\\œð¹Xµj•ô{d‰ˆêâðáÃÐëõxüñÇU}ñoµfͼøâ‹¨¨Pý4DDêUÝ;v® ` ëÌP*;HM’’’)*++a0X‘ꥧ§C¯×cøðá0²ãÔ‰Á`Àýס¼\õ3‘:Ùz À++Òþ2Uhs ‘ 66Vø\k ™™)|6QC¡s‰ˆîf-Þzë­ÏrwwÇÞ½{‰#F4xÞÈ‘#«X °}ûvL:•%9ŽÖžð'ÿàYƒôÐÀƒú ÀÀ;& ú+¦‹ø¹i¨M±¦ˆÐJr–jíß¿˜5kœœÄöMÖ§Œ3Fè\"¢;ét:|óÍ7ÐétøöÛoëüóãÇÇÒ¥K1qâDáÙFމ¸¸8xxxàòåËÂçïØ±S§NEtt4Ú´i#|>‘:]þó×£ ˜S `#€*¡ˆìƒ+´k,w#©þ£™Ã‡cݺu¨ªÿ»ã¦M›°wï^ás‰ˆî¤Óé°|ùr¼ýöÛµþ™qãÆ!..IIIŠ\ü[1qqqèÔ©“"ó­%À­[·™OD¤IfQàãÿHsXhÛvÏA%À‘#G-öìÙ#|.Ñt:–-[†E‹Uû}Æ ƒÁ`@JJ žzê)»d>|8¶oß~ÏÇŠ””„)S¦° "€ À¥ÿ¤I,´o;4²àÈ‘#X»v­"%ÀæÍ›±{÷nás‰ˆîd-Þÿýß½6hÐ  8pžžžvÏ6pà@$$$ [·nŠÌONNƳÏ>‹›7o*2ŸˆH\8ï,€à“©I£X8†ÐH pôèQDDD ²²Røì˜˜–DdŸþ9>øà@Ÿ>}€C‡ÁÓÓ:NZ.¥K몆k×D¾›&"RÐnß‚e·þó°,߯‹*9~†åâÿ¼È€Dö%ï] )á ›aÙãTÕ „9sæ I“&Âg?õÔSxâ‰'„Ï%"º[||<&Nœˆ¦MÕµ§nff&ÜÜÜpîœ2¦5j¶nÝŠ:(2_– .ÈŽà~úI™[SDX¼Ø¾ÇÓ}bßã‘ ÷è ÓþjËcþîP˳¶ aùh-Àihàù[*Ò@3¯•¢îŒƒ0Ûù÷[ÔõŽ…* –§l êíšÓÓÓQQQ½^/üs||<Ìf3&L˜ t.ÑÝìu]¹ºº"!!A± 55ˆu¸€ˆ"X>ÑÏ‘ÄAUþç/R%Þàx¬%€êwjÊÊÊ‚Á`@EE…ð٠رc‡ð¹DDZáêê “É„‡~X‘ùiiipwwÇ•+W™ODDDâ±pLÉÐP °fÍÅJ€íÛ· ŸKD¤...HHHP¬Ø¿?.\¨Èl"""€ãJð,4PdggãçŸV¤0™Lضm›ð¹DDZáâ₤¤$ôîÝ[èÜŽ;bñâÅX½zµÐ¹DDD¤Ž-–@õÏl:~ü¸b%@bb"K"jÔz÷îÄÄDôéÓ§Á³Z·n äää`É’%hÓFÕ[ÎÑX8¾XnÐD °zõj”—— Ÿ˜˜ˆ¸¸8ás‰ˆ´¢W¯^0™Lõ.ZµjäååÁÏÏmÛ¶œˆˆˆ”Æ qÐÌJ€œœ¬\¹eeeÂg'''³ ¢F­W¯^HLLDß¾}ký3Í›7‡——Ž????îúODD¤a,Ü\“¤&¹¹¹Š–±±±ÂçiEÏž=a2™Ð¯_¿j¿¯Y³fðòò‰'€®]Õû,w"""ªK*We©I^^žb%@JJ K"jÔ¬%€³³óï^srr‚§§'ÒÓӠ؈ˆˆÈþX4>š*ÂÃÃQZZ*|vJJ ¶nÝ*|.‘VôèÑã7%Àþƒážåi €Æ) )N:…•+W*Rìܹ[¶l>—ˆH+ºwï“É„ÿþïÿÆÁƒa0àêê*;)D';Iõ€XªßÑ©Gx饗ТE á³G©S§B§ãÿDDÙ… dGpH?ý¤Þý#/–€ˆÈ¾¸ qKààŠì 59}ú´b·ìÛ·ÑÑÑ0›ÍÂg© ÚËíš(BBBP\\,|vjj*¢¢¢X‘Ãb@€¥ÐÄJ€sçÎ!44T‘ --%9,du)òóóŠ¢¢"á³ÓÒÒÉ€ˆˆˆˆˆ º“µ¸,;HM”,öïßÏ€ˆˆˆˆˆ º›fJ€óçÏ+Z¬[·Ž%9 t/ÁGŽÁºuëPUU%|6‘½± [xÀyÙAjrþüy¡  @øl–DDDDDä(XPu2¸A%À¥K—Œ[·n Ÿ}ôèQ–DDDDD¤y,¨&&È—¤&—/_FHHˆb%ÀÚµkY‘f± Ú8ËJ€F]¤§§³ """""Íb@µ¥© 887oÞ>;==kÖ¬Aee¥ðÙDDDDDDJb@uq –ÛÎÉR“+W® $$D‘ ++‹%i ª«LXVh¢X±b®_¿.|vvv6Ö¬YƒŠŠ ᳉ˆˆˆˆˆ”À€êC3%Àõë׌k×® ŸÍ€ˆˆˆˆˆ´„ÕW&4r;Àõë×¢H püøq–DDDDD¤ ,¨!²`)ÎÊRëJ€«W¯ Ÿ}üøqüüóÏ,ˆˆˆˆˆHÕXPCi¦¸qãBBB)rrrX‘ª± ²Á999GYY™ðÙDDDDDD Å€D±–gd©É7°bÅ \ºtIøì¼¼<¬\¹’%© )À¹’sÔ¨  !!!Š”§Nb @DDDDDªÃ€DË0 *.^¼(|6K"""""R¤„›ˆˆˆˆˆÈdo§¡±àÌ™3Âg³ """""{c@2XK€ã²ƒÔ¤¤¤ááኔ.\@PP „Ï&"""""º ’ES%@XXNŸ>-|öå˗€ˆˆˆˆˆÇ€d:`€ ÙAjRZZа°0äææ Ÿm-nݺ%|6‘ ’í<7h (++êU«pòäIá³Y‘ÒXXK€tÙAj¢d påÊ–DDDDD¤ìDwx@€A²ƒÔ¤Y³f˜7oúöí+|v‡ðòË/£M›6Âg‘m.\Á!ýôSWÙlZ¼Xve>ü vî쎴´nHO[áܹ6¸u«š5«DëÖeèС½{_‡‹ËŒq“&åÂÅåŠìèç_ž÷Úa@jó €xƒe©‰’%@»ví°páB´k×Nøl""º7Ê``iiÝ4‘‘.ÈË«ßû‡=n@¯?Š bØ0þÿP<ÿrð¼× R#M•/¼ðúõë'|vÛ¶mñòË/³ "²Ê` ³ذa þßÿ]»º =~ü)|ðÁL™’ ¯î‰ç_ž÷†qÐ-r]`¹@õ%@Ó¦M¡×ëáââ"|6K""ûa  ÊHJꉿüåìÙó°¢Çyì±3øþûh<òH¾¢ÇÑž9xÞ®‰ìD6ˆ0–2@µªªªžžŽ®]»¢S§NBg—––âØ±cpuuEË–-…Î&"¢ß*,,”Á!íÛ÷•ì6Mš$;AÝ6Ç{ï=7Þ˜†3gPüxgÎ<€ÿû\»Ö“'ç¢iÓ*Å©f<ÿrð¼‹Ã¤v]`¹`ˆì 5iÒ¤ ôz=\]]…ÏnÛ¶-.\ˆöíÛ ŸMDD\  ®';»#fÎ|éé¥ÿ‘Gò±fÎÎW¥_6ž9xÞÅâcIí.x ÀaÙAjRYY ƒÁ€cÇŽ Ÿ}ãÆ ãêUÇø‡ˆˆˆê&>¾/ÆŽ}MÚE`Ùpí±Çþ[ø}×ZÀó/Ï»x,H 4UFEJ€›7o"$$„%Q#ãŒiÓþ ׯß'; ®\¹O=µ[·ŠßY­xþåàyW ÒŠKÐX ‘‘!|öÍ›7„K—. ŸMDDDêc2õÁÌ™/ ¤¤©ì(·5ÃìÙÏ;Ì'¢Õáù—ƒç]9,HK¬%À!ÙAjb-ßW $$„%‘ƒËÊꈹsõ(-UÏEUaas<÷Ü‹8qÂq÷'âù—ƒç]Y,Hk.˜ UrŽUUUaýúõ8tH|_QXXˆ\¼xQøl"""’¯¨¨þð‡y¸zU½Oºzµ%ôzOU^¨5Ï¿<ïÊãcI‹JaY ðä,Õ2›ÍÈÌÌDûöíñàƒ ]^^ŽŒŒ 8;;£U«VBg5F|  2øÀúùË_žÁ¦M.²cÔ(?¿ ŠŠšá™grdGŠç_žwåqiÕ5OØ';HMªªª°aÛˆˆˆìÇhŒ={–£ÎRRz8Ä#Òxþåày·ä¬%ÀÙAjb6›±aÃìÛ'þÎ…’’„……± ""Ò°¯¿';B½-]ú¤ì Æó/Ï»ý° GqÀ3Ð@ QQQØ»Wü¢k pöìY᳉ˆˆHY»wwÇîÝÚ}Æøöí½‘ÑYvŒzãù—ƒçݾX#ÑÌJˆŽŽÆž=⣖”” <<œ%‘Æ„‡“¡ÁBC‡ËŽPo<ÿrð¼Û r47`)vËR›6mR¬ Ù3g„Ï&"""ñªªtX¿~€ì 1Hv„záù—ƒçÝþX#ºËíš)vïµ´´ááá,ˆˆˆ4àСqöì²c4Øñã›ÛNvŒ:ãù—ƒçÝþX£²–»d©Í›7c×.ñQKKKм¼<᳉ˆˆHœ]»´{ôÝúÈŽPg<ÿrð¼Û rdš*bbb)ÊË˱råJäææ ŸMDDDbhñh¶>ü ìuÆó/Ï»ý± Gw€;€í²ƒÔFLL vìØ!|nyy9V­ZÅ€ˆˆH¥rr:ÈŽ LFF'ÙêŒç_žwûc@A!€©¶ÉRñññؾ]|_a-Nž<)|65Ì©SmeGF+÷B߉ç_žwûc@E!€ç$JÎQ+ Š•«W¯f @DD¤2/¶’A˜7î“¡Îxþåày·?Ô˜˜ •Û¶‰_´`-Nœ8!|6ÕOE…ã¼-¿q£…ìuÆó/Ï»ý9Î'ªk `’¤6L&…ϵÞ••%|6Õ#]5ib–¡Îxþåày·?Ç9ãDµ§© 11qqqÂçVVVÂ`0° ""RV­ÊdGF‹ÿ.ZÌl‹–þ]´”µ&Zùwa@U4T$%%)Zdff ŸMDDDµ×¹s‘ì´kW";BñüËÁón,¨1³– ²ƒÔFRRbcc…Ï­¬¬„Ñhd @DD$Q·n·dG¦oßk²#ÔÏ¿<ïöÇ€»"Ó¡‘ 99[·n>×Z;vLøl""jœªªªpèÐ!Ù14cÈ‹²#ãì|Uv„:ãù—ƒçÝþXýZÄËR)))زe‹ð¹,ˆˆH³ÙŒ¬¬,)RZ;ªáÃ/ÈŽ ÌèÑçdG¨3ž9xÞí¯©ìD*Q`€_¸KÎR£;wžyæ¡s«ªª`41wî\ 8Pèl""rlf³ÙÙÙHJJÂÕ«Úø$LMžxâ”ìÂLœ˜';BñüËÁón\@ô+k ~·=ìܹQQQ0›Å>rÄZ>|Xè\""r\yyy ÃÆyñ_OC‡^@7dÇh°~ý®¢W¯ë²cÔÏ¿<ïöǀ跊a)Äï¶§€}ûö!::Zx `6›±~ýzÞ»IDDÕÊËËCxx8ŒF#.^tœ{ye™>]ûæ}þù£²#ÔÏ¿<ïöÅ€è÷ŠaÙ ZvÚØ·oŸ"+Ìf36lØÀ€ˆˆ~çܹs0 08þ¼ì8ãÕWÓdGh°yó´»‚ç_žwûb@to¥æˆ’¤6RSS-<(t.iS~~>Ö¯_U«VáÔ)ǹwW-y$cÆœ•£ÞÜÜNjzWwž9xÞí«‰ìD*V `€\$g©Q~~>nݺèt:¡³333Ñ®];tíÚUè\""5),,”Aµ._¾Œøøx˜L&\»V·g]7ož¢Pª†›4Iv‚ßëܹkÖ ‘£^þ?{wUuÿüuØ7A° ŵ~]Z7°n­;¢€ÊbíjW[[jk¥Õ¶jkUÜQ! È5È $lI ,ÂIHBöÉÌùýqÄJÈ,÷ιwòy>yÄ>š9óæ@’9ï9÷ܹ è{¡·Dæß ™÷è‘B_óN€$ÓA‚‘››ËçŸîÈN€Ï>ûŒ5kÖØ:®Bw+--%))‰¸¸8 MÇiî¹g£'ß :t;·Ü²ÕtŒˆÉü›!ó=²@ˆÖùKó giÕ¾}û(++ãüóÏwd'@=8ýôÓmW!Ü@v|¥¢¢‚´´4¾üòKJJJ"Kv„F)¸è¢ƒÄÅ}­íý=î”|úé N=ÕûßC2ÿfȼGB§ùrO” ´´Ô‘`óæÍtïÞ~ýúÙ:®B˜&TVV’ššÊ‚ l;ÜO €ÐqF%¥¥ÝÈÎîo:JPþô§ ~Ø;‡ µFæß ™÷è@ˆàI ÐDJ!D,jË@MM Ë—/gÞ¼yìÝ»×ÖKɤÏ 7“”4ˆz˜Žr\W^¹›©Sçо½½—š&óo†Ì»óä !BÓ<|f:H0òòòøøã ¶=oÞ<²³³mW!DôÔÖÖ’ššÊĉÉÎΦ±±Ñt$Ѥ{÷>ùd&={Ö™ŽÒ¢¾}«™9s6;úMG±Ì¿2ïΓB„®y'À`à|ÃYZuðàAJJJ8ÿüói×ÎÞÎoË–-tíÚ•þý½±UK!ާ-íðù|äää””Dqq±#Eq3Ù¾^½jùîww1kÖE46ºëe{·n>¾ürЧn*™3dÞå®Â;üÀ¤`Ë–-téÒEJ!„çµ… yáÿù石uëVü~çßÁ’ 2gžYÎWì%1ñBü~wlÞíÑ£Ï?ŸÎu×›Žâ8™3dÞþ…ÁZþm_ר€RÏ™áZî4# ¢TUž§#0…çŠØ…^ÈðáÃißÞþî鍊nâºë®³}\!„ˆ–ýû÷›ŽàŸÏÇúõëY±b555Q}î=þÕç ÅszÅ—–6€aÃFRZÚÍhŽÞ½køâ‹i\}õ.£9¢Mæß ™wûER\¬µ/Škhà”Za:ˆ+hý ðÓ1ÂХʢô\ž* Ĉ#èСƒícÿûßçú믷}\!„ˆ†X,ü~?ùùùdffRU^ü›¤°Ï¦M½>|$yy}<ÿWìaöìY PnäùM“ù7CæÝ^îØOá. xÞtá)>¬ƒ§›ŒM›61sæLGzZ²d ©©©¶+„"4@€üü|&OžÌÂ… -þ…½ *eåʉüîw+P*z§wèàOÊ =}RÌ,‚Â!óo†Ì»½d@ËnF©dÓ!Œ“¡hLŒòó†åÜsÏeäÈ‘Žì¸ñƹá†lW!œ ;´ÖlÞ¼™´´4:d4K  //k®Yh4ÇñxmÀÑV®ìÇãÿ€ÌÌ3}žë®+æ7æqÙeû}¯‘ù7Cæ=rR´lpUTk&7’ Tíà!ϲsÎ9‡Q£F9R :”!C†Ø>®B8ÅË€Öš¢¢"ÒÓÓ9xð é8’––Fyy9ãÇ›NÓ2/ZCRÒyüç?×–6ÀÖ±¯»®˜gŸMáÖ[·Ú:n,‘ù7Cæ=2Rßý(õ±éFIŽö@<ð°¡çÉ9çœÃÈ‘#騱£íc_{íµÜ|óͶ+„Nðj°cÇRSS]‘¿°°ŒŒ èo IDATÊʾú,@täæžÆô郙5ë"Š‹O kŒ˸÷Þ<úèj.¼Ð|‘ä%2ÿfȼ‡N €ãÛ\„Rö_,íR„ËS%ÀÀ5j””Bˆ6Í èPìÞ½›ôôtvîÜi: ÅÅŤ¤¤s¥ˆ¾O!3ó ²²ú³m[O¶m;™ÒÒ®ø|í©©éHïÞ5ôî]K¿~•\tÑA.¹d?C‡ngà@“/b‡Ì¿2ïÁ‘ u?F©I¦C#@$ÚqÀhÃ9‚2`À~øa:uêdûØR!¼À+Àž={HOO§¸Øü½¨‹‹‹IMMeß¾–¯“•@!ÜÃþ cÏßÑz:JÕš"<Ç<Òôß®/vìØÁG}äH ‘‘Öš[n¹ÅÖq…¢-Ù»w/+V¬`ëVóצºi÷BˆàIк~ÀcÀMžÔ\h`ŒÙ(­k.zè!:wîlëØ™™™h­¹õÖ[mW!b]ii)™™™šŽâªB!Dè¤ÎÓhýJUš"<Éü¨é¿=S<üðö—Ë—/@!‚PVVÆŠ+ذaZ›½)QII Ë—/wE !„"|Rç¬ëàÇÎ!¼«¹ÐÀXÃYZU\\ìh àóù¸ýöÛQ*ücH„"VUVV’••Åúõë F³¸i÷BˆÈI¼'Ðú”òÆ AÂüÀ£X%À8ÃYZU\\ÌÔ©S=z´í%ÀªU«ÐZsÇwH „M>ÌÊ•+Y»v-~¿ßh–ÊÊJV¬XA^^žñB!„}¤^àiàqÓA„§5—à`çÎÄÇÇ3f̺víjëØ999R!Ú¼ÚÚZV®\Inn.fï<|øða–/_. !„ˆQR„æ1´ž€RE¦ƒO ðÕN€GÌFiÝž={˜2eŠc%€Öš;ï¼SJ!D›SWWGnn.«V­¢¡¡Áh–ššrrrÈÉÉ1^B!„pŽ¡é<ËWº ®æ ø…á,­Ú³g Œ3†nݺÙ:vnn.€”Bˆ6Ãçó±zõj²²²¨¯¯7𥶶–U«V‘››‹Ïç3šE!„ó¤Ý´þJå›"ÇJ€5kÖÐØØÈ°aÃh×®­c !D´òòòÈÌ̤ªªÊh–ÆÆFÖ­[GVV–ñB!„9R„ïE`ˆé"fhà×Mÿí‰`òäÉŒ7Ž=zØ:v^^€”BÏÒZ³yófRSS)//7šÅM%„Bó¤ß h}J}i:ˆˆÍ%ÀÑ—¸ÖÁƒ‰‹‹cܸqœp ¶Ž——‡Öšûî»OJ!„g4/üÓÓÓ)++3š%°qãF222¨¨¨0šE!„{H™—ÐzJÉr…]4ð¾¾#ÀµJJJˆw¤ÈÏÏGkÍðáÃ¥B¸šÖš¢¢"2228pà€é8’žžÎ¡C‡LGBá2RDæRà~`–é "¦hà·MÿݦK€‚‚)„®µcÇÒÒÒØ·oŸé(‘––ÆÁƒMGBáRRDî´žƒRró\a§æ yG€«•””¹àÄO´uì‚‚´ÖÜÿýR!\c÷îݤ§§³sçNÓQ(..&%%…ýû÷›Ž"„Â夈ܹÀ€‰¦ƒˆ˜£ßñõ®UZZzd'€Ý%À† ˜1c#Gޤ}ûö¶Ž-„¡Ø»w/iii›ŽBqq1iiiìÝ»×t!„!o§Ùã9´¶÷~hBX4ð80Át`”––2iÒ$GN½Þ¼y33gÎÄï÷Û>¶B´¦¤¤„¤¤$>úè#ã‹ÿ={ö0kÖ,fÍš%‹!„!‘ö8ëÔö›"bRs м#ÀÕÊËË\pòÉ'Û:öæÍ›ìèÐA~| !œWZZJff&………¦£°wï^V¬XÁÖ­[MGBáQ²À>O£µ½«!¾Ò\¼h:H0ÊËˉwäê-[¶0sæLm[!šUTT°hÑ"âââŒ/þÞ} ‹!„‘À>'O˜!bÞÓx¨ˆ‹‹s¬˜1c†”BÛUVV²hÑ">üðCÖ®]‹ÖÚX–ÒÒRæÏŸO||¼ñB!DlÀ^£õ·L‡1ïià_¦C£¢¢‚¸¸8ÊÊÊl{ëÖ­R!lSYYÉ’%KŽ,ü€Ñ, .$>>žüü|£%„BˆØ"€½º1B´ Ïÿ4"ÄÇÇ;VL:ŸOîÂ)„OMM ‹/æ7Þ 77×èA£‡féÒ¥Lš4‰uëÖ-!„BÄ&9EË~?CëWQJ.ÒNûsÓçgŒ¦BóN€Gy„^½zÙ:öŽ;øè£x衇èÔ©“­c !bWmm-YYY¬X±‚úúz£YjjjÈÉÉ!''Gv5 !„p”öëŒÆÎ!Ú†?cøç־дÊÊJ&MšÄ¸qãèÓ§­c7—?ü°”Bˆãjhh`åÊ•¤§§SWWg4Kmm-«V­"77Wv2 !„ˆ ¹À¡õe¦Cˆ6ã/À ¦C£ªªŠøøx8`ûØÅÅÅ|ôÑG444Ø>¶Âû|>YYYL˜0Å‹]ü744Í|@VV–,þ…BDìpF;àyà.ÓAD›ñlÓgןAQUUEBBcÇŽ¥oß¾¶Ž]\\ÌÔ©S=z´ìBà÷ûY³f Ë–-£ªªÊhŸÏÇêÕ«ÉÎÎ6¾û@!DÛ$€sîDë!(•b:ˆh3žÅºàÙ־дæãƳ½عs'S§NåᇦsçζŽ-„ðŽ@ ÀúõëY¶låå寳äåå‘‘‘AuuµÑ,B!Ú6)œõp½é¢Mù+V ðWÓAZS]]M||Í ÿ%K–PZZj:………¤¥¥ß} „BM çý ­ç£”ÜÌWDÓsX;žkí M«®®&..Ž1cÆpúé§Û:öÞ½{™2eŠ”Bĸ¢¢"/^ÌÞ½{MG¡°°ôôt:d:ŠBñ R8o00 ˜f:ˆhsƵÀ‹†s´ª¶¶–)S¦0zôhúõëgëØ{÷î=²Ë@J!bKQQÉÉÉìÙ³ÇtŠŠŠHOOwä.'B!„]¤ˆŽÐz6JÉýÉD´½ÔôÙ3%À˜1cl/öíÛ'%€1dçÎ,Y²„íÛ·›ŽBqq1©©©ìÛ·Ït!„¢URDÇYÀO€·MmÒKX—¼ÔÚšVWWwd'@ÿþým»¹3f ݺu³ul!DtìÞ½›ÔÔT6mÚd: »wï&==;wšŽ"„BM €èù ZÇ£”ÜÿG˜ðrÓgO”S§Nu´;v¬”BxÈHII¡  ÀtöìÙCFF;vì0E!„Y;ÓÚӀߚ!Ú´—'M‡Fs °k×.ÛÇÞ¿?“'O–[r á%%%Ì™3‡wß}×øâ¿¤¤„¤¤$¦M›&‹!„ž%;¢ëI´~¥ÌÞ˜X´eÿƺàߦƒ´¦®®Ž„„zè!Î<óL[Ç.))!>>žqãÆÑ£G[ÇBD®¼¼œôôtrssÑZÍRRRÂòåË),,4šC!„°ƒÑÕëاLmÚš>»¾hhh`Ú´iŽ•qqqŒ7ŽN8ÁÖ±…ᩬ¬$55•Õ«W˜½{nEEYYYäååÏ"„BØE €èûZ¿‰Röïm"xÿÁÚ ðŸÖ¾Ð´æàÁ䬳βuìÒÒÒ#;¤œšš233ÉÊÊ¢±±Ñh–ÊÊJV¬X! !„1I €èëüxÌtÑæ½‚U¼b:HkŽÞ %€±£¶¶–ŒŒ ×,üSRRX»v­ñ,B!„S¤0ã'hý:Jm4D´yÿmúìúÀçóÙ pöÙgÛ:viié‘ËN<ñD[ÇB|SCC+W®$--úúz£YŽÞ}àóùŒfB!œ&€€ç€M«Ð|U¸–Ïçcúô鎔eeeLž<™qãÆÑ³gO[ÇBX|>ÙÙÙ¤§§SWWg4Kmm-YYY,_¾Üx !„BD‹æŒDë£T®é B¯b•¯šÒšæ#FŒ`РA¶Ž]^^N\\<òˆ”BØÈï÷³fÍ–.]JuuµÑ, ®)!„Bˆh“À¼Ün:ˆM^kúü_¬Ÿ®ÕØØÈ¬Y³)***Ž\pòÉ'Û:¶mMóÂ?%%…ÇÍÒÐÐÀêÕ«IMM5^B!„¦H`ÖÑúF”Zj:ˆM^jwð@ 0sæLFŒÁyçgëØG”@ˆÐÖ¯_OJJ ‡2𥹄X¶l™ñB!„0M ó^Dë6Dˆ&ï5}v} à÷û™5k<ð矾­c7ïxä‘G¤"HZk6lØ@rr2eeeF³½û ²²Òh!¢mýúSY¾¼?¹¹§QPЇº³gÏ >Ü™ŽýôèÑ@¯^µœyf9ƒ•rÙeû:t;ƒ•šŽdþÍyNø/îµ¾Xk_”6í”úÜtˆcÒúà¦c„¡7J™}õé}?ÞÅå%@ûöí)N<ñDÆG¯^½l[ˆX¡µfóæÍ,Y²„ýû÷ÏRPPàŠBXÆ7 eÏ=g:}rsOcòäï”4ˆ;Â;ÇæŒ3*1"Ÿ±c×rÉ%f¿—½Fæß ™÷ÐIàyÀe(å7ä¤hë~е#À%Àý÷ßÏ\`ûØ=zô`ìØ±ôéÓÇö±…𺢢"/^ÌÞ½{æh^ø/]º”’’£YÄ×Ià­áÓO/àå—¯eÅŠþ¶Ž}íµÅ<óL?üáf”ë_˜!óo†Ì{d¤pq(•`:Ä7H ¬à] é ­q²èÞ½;ãÆ“@ˆ&ÅÅÅ,Y²„;v˜ŽBQQ‹-2^Bˆc“Àééßæ‰'n#;»Ÿ£ÏóÝïîâ­·¾àòËåûëh2ÿfȼGN ÷Øœ‡RÂâ™ ]»v 6ŒÁƒÛ>¶”BÀÎ;Yºt)Û¶m3…¢¢"’““Ù½{·é(â8¤°Wuu'ž~ú&Þzë*è¼EÙ¾}€ßü&›_\LçÎQyN·’ù7CæÝ>R¸ËoQê Ó!¾F ñ•Ÿ`]à‰àÞ{ïå’K.±}ìîÝ»3vìXúöíkûØB¸ÙîÝ»IMMeÓ¦M¦£Ù}°}ûvÓQD¤°ÏæÍ½¹÷ÞQ˜)¢/¿|/3g&rÎ9mó%–Ì¿2ïöj‹À§À½¦C´à 0¥ÜsŸ")Ä×ý˜ˆGJ€{K/½Ôö±¥mÉÁƒY¶l¦£°k×.ÒÒÒ(,,4E„@ {$'ŸÍý÷ ¼¼‹Ñ½{×0wî4¾ûÝ]FsD›Ì¿2ïösý‹x¤_šÑ‚>Àã¦Cqb]0¤5@€Ï>ûŒµkíï)«««‰çÀ¶-„[”””0gÎÞyçã‹ÿýû÷“˜˜È| ‹Ñ&-XpwÞùñE@ii7nºi 4%jdþÍywF[,þî]Àü ­åmEáf“ðX °fÍÛÇ®©©aòäÉr蘈9Ì;—wÞy‡uëÖ¡µ6–åàÁƒ$&&òÎ;o,‡&-]z÷Þ;Šºº¦£QSÓ‘ûîiû ìn$óo†Ì»sÚf ÔZ`¶é-8xÒt!Z!%PWWGBB{öì±}l!¢­²²’ ðÆo““C `îÛ»¼¼œ¤¤$Yø‹6oÓ¦ÞÜÿêëݳjV]݉;îx˜¢¢“MGqŒÌ¿2ïÎj›€å/€Ïtˆü ­Ï0BˆVLÂ:Ðõ%€ÖšO?ý”•+WÚ>v]]S¦L‘@xVMM ‹/æ7Þ ++ ¿ßo,KEEIIIL˜0Áx !„i55¹çž)+ëj:J‹Êʺ2bÄ®\¨EJæß ™wçµÝ@©ÍÀdÓ1ZÐø«éBa200·bÁ_|áh ·"^R[[˲eËxýõ×ÉÈÈ ±ÑÜ-Žª««”²ðÂòÔS7³qã)¦c´*'çtžyæ&Ó1l'óo†Ì»óÚâ]ž@©ÿ õéÀf ›ÑDÇæ£Ô£)ä."8£€)€'ªÐÛo¿«®ºÊöq;wî̘1cèׯŸíc a—††V®\IZZõõõF³ÔÔÔ™™IVV>Ÿ[7å·Ý÷Ýúã´†_üÂþ<#w]zú·¹á†¡utîw©dg¿Ïw¾çâÈü›!óžx±î¥ö õ[ÀŸLG9†öÀßL"3š>{¢˜7oZk®¾új[Ç­¯¯gÊ”)Œ=šþý½}@Œˆ=>ŸììlÒÓÓ©««3𥾾Þ5%DP.½~ö³ÐH B¦5<ñÄmžY46¶ã׿¾ŒŒMG‰˜Ì¿2ïÑÓv/øÊ¿€C¦C´`8ZÛ»BÂ93°.0·8óçÏ'++Ëöqëëë™:u*»vyÿ>±"6øý~rrr˜0a‹/6ºøohh ==W_}•Å‹{cñ/D”%&^Dv¶÷v’efž·H“ù7Cæ=z¤PêðŠé-PÀó¦C‚™ÀÃx¨X±b…íãÖ×דÀöíÛm[ˆ`rrrxýõ×™;w.UUUƲø|>²²²\QBávÿýï÷LGÛ?þqƒé“ù7Cæ=z¤°¼ì3¢· µ7O˜mÕ,®ÏçcúôéRG1qâD)--5–CkM~~>o¿ý6sæÌ1ZB„  Üb8‡hãÅœ9盎±Ù³/4!,2ÿfȼGŸëO뎥|h=ës7ú'ZŽRžXL Ñ$ÐÀt<ðófÉ’%h­2dˆ­ã6—£Fâì³Ï¶ulѶ‘œœÌž={ŒæÐZ³yóf–,Y¾}n½¢î–Ïɦƒ°nÝ©ìÞ}¢éÛ²¥Û·÷äÌ3ËMG ‰Ì¿2ïÑ';¾n°ÆtˆœŒ5Bˆ0Ì\|“ï¯,]º”””ÛÇm.ŠŠŠl[´=ÅÅÅÄÅÅ1eÊã‹ÿæÝÓ¦MóÊâ0¸Yü Y±Â»×@ÿ¯%KÎ2!d2ÿfȼGŸëß‘‹*¥hýWàsÓQZðw´žŽRµ¦ƒ¢Ù|µ £á,­Zºt)>Ÿ›o¾ÙÖq™6m#FŒ`РA¶Ž-Ú†]»v±téRWIÅÅÅ$''³cÇÓQ‚•ü¯~ á*^¼ZKÖ¯?Õt„Éü›!ó}Rü/¥’Ð:°w°=ú¿^5Dˆ0|ŒµÀ%@zz:€í%€ßïgÖ¬YRˆ8p€”” LGaçÎ,Y²ÄKçZl^>ü†³Ñ¢­[{™Ž`› N1!d2ÿfȼGŸÇöÀþ#Áíñ ZˆR•¦ƒ†QÀ ÓA„°Á`2ðw`·á,B8æâ‹‘ñmÓ1lqÎ9e¦#„Læß ™÷è“ 8/?z™r ÃÐú{(µÜt!là¹@kÍ]wÝåH  µæÒK/µm\}~¿Ÿ5kÖ°lÙ2ªªªŒfihh ;;›ŒŒ jk=qH~ëN!Ï[ gÂq—^;7wºâŠ=¦#„Læß ™÷è“ J•£õËX ¹Ñ‹ÀÓ!„°Éà^àS}:û÷›»–±yáÿæ›o/!B܈µð—à¢ÍûñsMGˆØƒ®7!l2ÿfȼG—\ ¥ÑúoÀtÓQZðZÏA)Ÿé BØhðCà Üy;ίÉËËCkÍðáÃi×ÎÞŽuÞ¼yh­¹êª«lW„§¨¨ˆäädöì1{è֚͛7³dÉöíÛg4KVÿ’LÂM.¿|/W^¹›•+û™Ž–ï_|ÀtŒ°Éü›!ó]² t3·ÖTç˜!„R€ÛOœ`–ŸŸÏÇìÈN€ùóç“••eû¸"x;wî$>>ž)S¦_ü7ï>˜6mšWÿëÀ5Èâ_ˆczæ™4ÓÂöÔSé¦#DLæß ™÷è‘¡RJ£õ_€y¦£´`™3dÞ'@dþŒ{ßÕx­¿e:„JÇ*›ŒÍ›7;Z¤¦¦Ú>n[SYYÉܹsyã7ÈÉÉ1ºð?tèIII^Zø—`-üÏ^ꌦ"tïÞÀ'ŸÌ¤gO÷~;õí[ÍÌ™³éØÑ­/‡Ã'óo†Ì»ó¤ˆ„RyÀG¦c´ ;VA!D,ó\ 0cÆ GJ€¥K—’’’bû¸mAMM ‹/>²ðwâî Áª¨¨ ))ÉY‚tkÁ?°és­Ù8BÄ–sÎ)cΜtíê¾;›ÎUWí6Åq2ÿfȼ;dzéeJí@ë‰ÀoLG9†ŽX·]c8‡p‚Ö=€¡À-MçÞúH£õ`-Ö"z.Jyí'[ð`)¦OŸn•:±ç´ÓØ|î¹ì8óLöéCU÷îaÛ¡±‘ÚW_ÅçóqóÍ7Ûœºu%Àꦵ@Ö¿ڦñ{`%ÿ¦!XMW¨X¹r%iiiÔ××Û”.<555dff’••e¼„`à@¸ë.¸í6¸ä8ýô–¾²p~ÓDZԠõ à˦uRDàÄá‡?„»ï†+¯„³Ï†pn/@AdfBj*Ì+…€GÜvÛ-šÂ°a#)-íf4KïÞ5|ñÅ4®¾z—ÑÑ$óo†Ì»3TØÔú¬×x^óJý×Öµîƒõ:× ð(µ&¬Gký ð[EGo”*3ÂvZ+àF¬Óµï:9ñ,Xk¸ÙÀD”* }}VÎP• ÔÂx\³k°JŒƒ~Dð—¿„÷l³fAnnx½ùfz<öú¶Û¨sÁ,|åzTUqíµ×:^)Àr`°ÙÑg;¶AX·„¸ëÜñ0ŸÏGvv6éééÔÕ™½¶°¶¶–¬¬,–/_þõ¢}{øÇ?ÂôóÏ­…]¨N?~ùK6Ìz·ßÅX‡~€Rn>ÝéØ%Å“OÂK/…>Z ÞB cG9F†o„Nü¸¯«ƒùóaêTøôS+¯ÆwdX[<÷œé¡Ù´©7Ç$/¯¯‘ç¿âŠ=Ìž=‹Ê<¿i2ÿfȼÛKvØA©ƒhýð¬é(ÇÐø;p·é "Z·þˆµæq’.oúø3Z¼ŠRÛCãàÿ…ñÜ›€H €L¾º ¸ [7øáDÅz'-” S'¸çøã᪫¹…Aóê%##­5·Ür‹mcÂÚb±X„µ¥ß´MM¯a>÷3¬o”Sú¿ßÏš5kX¶lUUf¯vihh8~ Ѿ}øÿ÷ì ­¸àëßâèÑÎ,.¿îÛÀ À_Ñz6ðw”*túI=©sgkáÿì³pN8{\BÐ¥‹Uü EE0a¼û.Þ#Z6hP)+WNä©§nf„«›Þp^‡~ÿûå<ÿüR:wvÑeJQ&óo†Ì»½ä@ûüëòV7º ­ÝuQ°žÖwë°Þ=szñÿ¿º¿6£õëM—¸]&Ö啦ƒÑ®üä'Ö ìY³àª«{*­¾ú¥˜™™É¢E‹"o/ðp+Ö¢ú! w,þÿ×vକæÏ]~?999¼þúëÌ;×èâßçó‘••Å믿ÎâÅ‹Íî@èÝâã!/}4‹ÿ£uÂúg´­_Cë^Ñ|r×{äعÓúûqzñÿ¿Î>^{ V­‚ï~7ºÏ-BÒ¥K#¯½¶€¬¬¸æšŽ?ßu׳råD^~yQL-‚Â%óo†Ì»}¤°‹R‡±J·zÁt"­û¢õ\àsÀ±}¹Aê€U¬Gë[ g ÆràûXoZ›5x0dgÃûïC¿~Î?Ÿúz+ž™™ÉÂ… Câ0Üô~‰õŽ¿ ®PJV[60à‰ª*J .¶ýM%Ä„ ˜?>ÕÕvˆ¦‘#­+cÇZÅ”9ßa•‹#Mq…`Á˜<úô1›åâ‹!#^}5ÚåÑ•Wî&=ýC>ûl:×_¿Ãöñ¯»®˜/¿œBZÚ$.»lŸíã{Ì¿2ï‘“Kìõ&Ö"é ÓAŽá:´¾¥æ™"‚ õÉ|}'³œ ,@ë·ß¡”›o€šƒu8âBÀÌ»Œ?/¾hmé’c]À¼|ùr´ÖÜvÛm­>þ%¬k†jìf@CÇŽ¤ BÞàÁÜ÷ñÇôÛ³'jÏí÷ûÉËËcÙ²e:d¾‡¢kWˆ‹ƒ#L'ù_½€h}ÖÏ”¶wÁ1cà­·¬üÝ¢];ëç×å—ÃðáÖ„+)wß]ÈÝw’›{Ó§fÖ¬‹(.>)¬ñ,ãÞ{7ò裫¹ðƒ6§=2ÿfȼGF ;)U‡ÖÞ7¥/¢õ”rý¥Û4­ÿ†užDt.p ~ @ëQ(eø-Íãj.Í KøðCx表=e3­ŽýÏfÅŠ466rûí·£Zø€\bcñ´Ò^½˜ôã3téR®ËÈ@iç£×ZSPP@rr2ee.9‡´woë€Àk®1äx~ |­ï ñ¼ïR þö7ëÒã|Ouà •·Üb]Â$\íòË÷rùå{ù÷¿²qã)dfžAVV¶mëɶm'SZÚŸ¯=55éÝ»†Þ½kéׯ’‹.:È%—ìgèÐí è’Ÿ[$óo†Ì{褰ßd¬Só/0䣀i¦ƒˆc°ú{ë…°Ü ,Eë;QÊ­ç_€µ¦^ н;|ò ÜjèJ‰ã,$V­Z…Öš;î¸ã¸%@,ò·kGòM7q o_îýôSÚÛ|ÚyóÂéÒ¥”¸éÝҳ϶NyíãCÂr1†Ö·¡Té0ŽêÜ>øÀ:€ÑíÎ>–.…뮳Î'žpþù%œ~ >ºÚt”6Iæß ™÷àÈv³¶D»ù¦2/ µ\Ôç6ÖßÉl¼³øov%°­]´wõ˜r›g+ÞN¬ûj›ZüÓò€f999Ì;íà»àn¶~ð`fŽ…¯ƒ}ýwQQ'N$11Ñ]‹ÿSN/¿ôÊâ¿Y ­¿g:ˆc:v´n¹ç…ųoæÍƒž=M'B!)œ1È2¢g?6Bź—ÉÀ½¦£„éR`Z»}GÑj¬ Ô‘Ñ•²ú:Ô‘áƒ̲>77·M—›Î=—™£Fˆð¼¢¢"Þÿ}Ø»w¯MélÒµ«µí?Ú'ÉÛãd¬³F.1ÄvÍ?'~ðÓIBwñÅÖ®!„ž&€”ÒX×p»Õ³hÝÝtqÄËÀÓ!"ôàmÓ!‚°ërûK€ñã­“ÕM rknn.IIIm¶Ø2p ‚8ñXŠ‹‹‰'!!Ý»]xCD¥¬3(¾çé7ÑOæ¡uÓAlõÊ+0nœéá>{Ìt !„pû;vÞ¥Ô"´Nƺ“–Ûœ†u·‚™ÒæiýKà>à(vbÝá­«üë œ }#x®Ÿ¢u*JM(±óšw,zÛ2â}÷Á³îèüZ»àh«W[×ÈÝu×]Žž p2ð-¬\§cý£ëÐô¹YP húØìw,‘%ûª«èsð W®ZÔ×ïÚµ‹´´4 N¡?ü|0ÒQJ<`#°¨júèôÀúë;ë¥Ý"}ÂcèÌAë¡.?l48?¿ÿ½}ã:àóA `]‚tÊ)ÎßMà•W¬s%¶owöy„B8B g=u)€OÛz­ßC©¶u쥛hý࿌œ$‹PjSˆ™.Æz‡|$puÏý:Z/ãqѶ»J€Þ½áí·#;Å»²23!/Ï:i{Ç(-…†ëþ‰'ÒkÀ¾Ï=Ôœz*û›>öžvþöí¿6T¨ïç¯^½ŸÏÇ}÷Ýq Ð ¸ø.Ö)¨çça¡*))a~VËJJØÑ¿?ÛÏ<“âl½vàËÛnã¬mÛ8¥´åM! %%…üü|[ŸÛçž /¼  ï÷Nð°XÝ´›­uZw®nFvÞÈþ à-àÇ<žcÏÛK/=‰u—ÌдkÚ£õÿ™@8gð4Ë Øl£W¯ºc~µÖ'±¾¯îàë}[dºv…mÛQ*”{J¶Í­FBáBR8I©•h=¸Ït”cè ü «¤Ñf]‚1°ëñ>àC`Jm{¥ò°Þõ{­/Ǻ²î°f øýÇýò²5kHÏÊb̘1\Õݺ‚§¾sg¶ž}6…çGþÅÓØ¾}H;šååå0lØ0ëþßAꄵºøp#Öa‘þR©¨¨ --Õ«Wø6ðííÛ¹>=úÎÙxþù¬¾ì2¶Ÿyf„ÏdiìФ»ï摸¸oÜðàÁƒ¤§§³nÝ:o\*Ñ©S ¤K—³B|äb¬ÅmrЋþ£)Uß4Æb´~xëw˹!ulãÐzJͲi¼èÒºÖÝwB]ü§ñÀ”:ô£”ªÀ:ø4x­»ç°vzÙá´¾¥ÒlO!D”„ÿvu8ÏZû¢DÍ(åÄ»®Ç¦õyX *7–-µÀ ”ÚÕâWhý Öm ½¦·«w7hýöÆøÖ¿kgö%[EÀkÀ•Ox/47¡Ôya<.|#FÜÈÌ™KÂzìŒ0jThY±žÞÚBÆ¢²OŸ>Œ;–þg›ïáN ó{ßãÊ•+éu(øµÂÑ.ºè"f NâqJ„.ÀÝX÷½k/¸*++ÉÌÌdÕªUø[)CvŸ~:)C†°É¦îïøâ‹#—”——­„ˆªN ¾>¼Çh×.”[Ðnþ€RŸ†÷„Çaí ø=ðÀŽ3g—¢”™ûÐiÞ „¶ƒ! øJÙ{˜°Öí€qX;Ïì8Î1JÝÌŽïÞϹù¾MBá)¢AëIÀ¢úœÁ{¥Z>ÑG ûi}-Fä—†Ôa½£3!¬wíBaÝ©à·À¿Ž>Sô ­ûâüåæ°küò—”ñP§œr ãÆûF `‡…?þ1™ý¿yîÚwŸamg:ÉÆç«©©!33“¬¬,C~üæsÎaÞwp(ÂÛ“õ¨®æGÏ?OæâÅfþÍ")B3x¥;ú,Z_|‚uEH¤¢Tx'7F*ü Û_£ÔŽ>‹ÖÖÙ Öm\# «”YßÚJ „î!wˆŽg±Þmw£Ÿ4íRÑ`½ó‘/þK€ëQêuÇÿ`ÝÙB©×±v{;»`ˆEññÖ-´lXüƒu}|||<‡ÛÿWQQQqä¿;éX ÿûÿµµµ,[¶Œ &‘‘ÖâàÜ-[øÅ»ïrQ„×çWuïÎ[>999æÿÑ¡±¶çp|ñ4]’t0φÑnEë»lÇ>.q|ñ Ôn¬«vF:ð»È !„ˆ&)¢Áúeû®é-èHÿ=?¾á»P*¸£Ëí¤Ô¬ßáí1ok´†¿ý yÄ:ÌÏFN–ínرƒ‚@€YÀµ6ŽÝÐÐ@FF&L %%…zÞíî\_Ïý³g34%%¢qú“uÀYìÒÀïQêŨ‡Í¬¢a`Ç¥¯6]^Kþ Ü•B¦™uW…á@¤¿GF61 „Â#¤ˆž•¦C´`Z_n:DÌÓº ð|„£T·EtÐ_¤¬ëRïÅ:™Z´$€‡†ñã{Š’’ââ⨬´ïGËù……üæ7ø~\Ù3gu=~0|>YYYL˜0Å‹SWwìÌÃ¥€¡Ë–1tÙ²ðùÖ·àìŠäFO5íä‰>¥°î.²4‘¿Ž‰'cä]ççQêŸFX;á(1Ýš !D¬‘ º^!‡…ç‡h}£é1˺öÿñGy¥æÛÇJM¦˜ŽáJ¯½¯GïÖÒÒR&MšDyÓÂÝN›7ofæÌ™!_£ÈÉÉáõ×_gîܹTUUÙž­%wÌK߃Ã{ð7ÂgØȼ০C4Î:ëÖ¥áê Œ¶'1ŸàžËïˆìR€ÛѺ½]a„B8K €h²¶Û½h:Æq¼ØtÚ»°ß=@(·çú_ùÀßlÊb§ß{L‡p•œxꩨ?myy9qqq ó€ÇJ  µ¦  €·Þz‹¹sç:rFAk:øýÜõùçaÝf‘víàÁíM»vv–w´ð3”ª±yÜðYç—DºáMŪm1²íÿX¬ÏF0‰À%6¥Bá0¯þòô²·"Ó!Zp«',›é»o¡TTî ¥ùöÑØÑØhm!ÎmܾÁÉ`Ë–-Ç-Ž^ø'&&RVfî.œ~¿Ÿ²/¾ ãa¨~›‘;Í-®¢¶v˜Í㾉R6i‡çHÎ2„w¯=ÿETü ΗÀ¦]A„B8K €h³®Œô 8'ýC¶òÙLë>ÀÍŒ0¥ÒìŠã€D ËtWxûm((0¡¢¢‚¸¸8Gà[¶laÆŒß(ŠŠŠ˜8q"‰‰‰”––Úþ¼ÁÒZ“ŸŸÏÛo¿Íœ9sð…{ƒïk®‰æÝ2€¡Xw×°ûθsçM…æÓŽâÅQêKÓ!¾ÁÚða#H „!€S°¶t»ÑÅÀC¦CĘ€Ž<>’­™Î³^8ºåZVs*+­[þ¹@EEñññŽ”[·n=Rñþûï3eÊöíÛgûsKkͦM›xï½÷¾^BäæÂºu¡Ø¥ \kçÍi9V1xÙý [öjÓ5÷î¤ÔgÀŠF¸­O´+Nøq÷ÏÊ#xì`ÛR!„p”&(åÇÝ‹º¿Çà}–MÁcSQ*×¶$ÎYˆuÐXÛõÁ`pÛûÿrºxõÕW™2e {ö˜=¢°°÷Þ{iÓ¦»„˜1#¼‡(×q¬Ç:ï Ù©'ª€×ß.‘ܦ p·]A¢ Ñè-\[£ÔV`c˜>­#)º…BD‰¦(5ë 7:ø™é1AëžX/ôÃõŽ]QeíðFV'øýðÖ[¦S|CEE“&Mâ`¸'âGMÙ3劋‹™Átˆ0÷L…CX·ŠòŠ)€û*Œ†äd(rçÙžUUU$$$PRRb:Š-vìØÁäÉ“™4i;vìhý99P[ú ¶mGó6àçX§¤'Ñ:ù}b”ž'2J€"áûhÝÉ®8ÚŠs—zØ)’ó\γ-…BÇH`’R©X[§Ý¨Ö-ÞDd¾Ác¿h:4Ò¬wÜÒì^‰ÑxC7|‡&..Ž˜Ž¶Ý»w3}út&OžÜ¿™Ï^93`œÑååÅX ÿAX‹q$ƒ…hcÓ­ö¼b á#Ý€+mÌâ”Ù®¹íßñ­Žà±§Û–B!„c¤0ïI¬û4»Ñ“@_Ó!<.’à3ÛRD3GÆï‡O?5¢UÍ;œ¸ÀIûöícúôé¼ÿþû†7H8€Rpá…á<Û.àq¾Zøû¾‰ÎòÖ÷¡RÅD¶ðjS'Í7 H› ¿Œ9ÕÎ B!œ!€iJ­%²“wtÖ5«"Ö%…ùh?°ÈÆ4Ñæ×=¬±q=%%ÛMÇFUUqqqìß¿ßt”V•””0gÎ&NœþÂÿ«ÁÂ{Üg„ô,X—u ^Çìå0^ü>Œ¤´ˆ¤h†* Ótˆ (Uì óÑò†Bx€îðg̼K /\[éV*ÌÇæy䯯Sj7Âþìйób¬w ·N”êêj\[”——“””ÄÛo¿ÍÚµk lØ U]ÞãN;-˜¯*þ†uÚK@ØÊ;‹Í¯‹är¸ÿCëpÖFÃZ”ò™)„"†IàJm&›Ž!lwquë"‚áÅÅG$Ò±JñP gü~G«¬¬dÁ‚¼ùæ›ää䨳ðoÎ!€ßúÖñþß*¬ÿ@`>ž1cÆÐ¯_¿°Ç (ÅÎo›¢³Îbwÿþìî×Ú.]lLj€•ß̞×xxùû/’âóÛRØo—é! ÷K)„¤p¥¡õçMG¶8îÄÇq¥ÂÝ‚é;°ÞAòøê/(-xØ\,ÁºFÜÕêêê˜2e £G¦ÿà{«Æöí)<ï<6^p[¤¶kWSpÚi%XïHo1%H Œ{ºÆæ~{å<7^*r< a>ÎÆëv„B8E ÷yøá/…hÝ•ðwrì¶3JÔ)@ë}À™¦£DÁñŽÒ?z'€'J€©S§U”öîMÎå—³ö²Ë¨îÃÇ–\|qÞYüì@©p·o»A$÷{´÷{Õ˜"OàBá6r·Qªëp)ám‘¼õÚ»EÇ †`´v/½X%ÀÖ(d‰X]] lß¾ý˜ÿyÏž$Ýy'oýêWd^sMl/þ-^ÛÅâíòÐ:[!Üŧ› /—2B!bŒîôY0ˆõnýKZäåíÿÍÚJp(ˆ¯i.<ñNrCCÓ¦MûZ P×¥ IwÞÉ„ßü†œÿû?ÊÍ·\·•×vÉ4 "J5åa>úd´vca£QÊg:„BÑL 7²^,üÍt ‘H^ˆ–ږœXø3#ØwöGy9lÙ[·BQìÛû÷[Ÿ«ª¬ÿ_k8|­E}ÈßN;€I@#Z¿^¿¾óëÝçÕ`móˆµð?äãbᲚ`ÄÂÏŽH Ð*ÛR!„1ª­l‹Œ JíEë7°^ø 7Sª­k€na<ú[vÇ1@ €ð5—ÉÀ`GŸ©kWxøáð¿q# ‡‚]‡‡­ˆþFxåZ8߇^ @¸†z ÌÎ ÿ¿½{ת,ó?þ¹DÜ xˆQAÄÈI%mò€šZƒ§Æ)•©~5Y/Ç2jÔþfìg¦h3åϬQCÌŠ1ÍQqC@J )ÆÄÆIÜätÍ÷6ö³ÖzÖ½Öó|߯×óRaß÷úríÍv¯ë¹×}‹”ÝüùðÌ3=˜;·;/¼°+V4ðê«û°n]{ÚµÛBÇŽéÚu=¼†¾}Wr챯3rd#}ûæ²wKÍSýãPÝwO €ò¹øG kì ²[¯‡&×÷ÌʹÚÃ} sì%÷&y4Î=:'üT­[ÆW÷æ0¸øSŠyj¡©Öå~|ȽÉWk¼™ž—º7wnw~ò“ãx衾,Y²óíx6mjÃêÕX½º/¿Ü•É“·ý¸Ò³çZF~žK/}–£~#Ø5CõCu¯Œ(³5„Ý®¥ø’>`ÀaYÉYߨjÄ»M€çªv…‹/N>ö;ß?þ1»,ïµx€p*Â¥¤»ù80u¢r8$v€”’4Lß•æ±+‘Rs‡‰à„®àøã?Ãí·ÞåMÐî,[Ö™ï}oÇó9†¿ŒG9 W{m§Tÿ8T÷äÔ(§[Wb‡ÝJswTæ›èÃc¨!o#9™Ïܦ œtR²±Ë—Ã-·d›'pàa`0x)£y?˜ÑùÓÌšUýEN3fô`ðà1|ù˧óÎ;z‚XõCuφåõc`Qì²Kivr–YŠü•9{Qýø0ð»Ìf><ùØñã3‹LNΪq†àÑU˜³ÈŽŒ …£RŒÍ÷øL‘ˆ^z©ƒá¶Û†°u«åvÝ-[öà–[†2lØå,ZT¿[Q©þq¨îÙQ ¬Ì6ׯŽ!»”æÒ¸ï™Y’¼„M¼Ê|Rdﮘ—Él}¾ÙÚØ‹2é=>M¸ñ<•Å„;qLç.¢¡±¤pBбjH]˜<ùPà /Ä;ôcîÜî zEU–^ê‡êž-5Êm07vÙ ³×å Gw œï¤Ÿ´‰¢†­$Ôxvê™úôI6nÆŒ´WžEx·ÿ$ª{ãÿ®KJ)ÍMt<îJ8z+ðB†iD éÑGûpÖY³fMÒÃ2²³råÞœzê?0iRïØQr£úÇ¡ºgO €2 G}#v Ù¥))Æ~,³ù9/v€:°†° ÝÆ€‡&ÜpýÅ“^ñYÂ×ôPÂóþÕ羡ÑPOú–t#À4š—K{lªH+M™rçž{!6ç9äæævUÛ„­hTÿ8T÷êP ìÌþ›t7™R]O¤[®€{[`Tìubð»éÉì—pݲe•ŽXüp<ðkÂNÿyAXMSO 83vˆÎI1öéÌRˆЋ/vãŸ]ÈMÈššödÔ¨KøÓŸþ&v”ªQýãPÝ«G €Úp ùþP-­79ÅØCp‘Y’êûÐ-vˆ:²ø(03Ñ膆dW}ûíÖ~äà3@àn`K² ¦2:Â5‹àìØ*š‡išj‚KÍjnnÇÇ>v«V·—¹jUFþ»BÞ¨¥¥úÇ¡ºW—µÀly-©•ʘ-¯™>—U”|6v€:´8J›íÛC›„[5lذ»xøp8p°9Ù…Rrß›úm|÷„ž(> ¤yåÉŒrˆÎ5×|„… ÷c·æÌù cÇž;FæTÿ8T÷êR v|°’Ï„c?Ž{÷Ì’T‹û@ù¾ֆʛ{¥ØHgçcß$¬F: ¸x'ùE2ñ  Sä ±t.Œ¢cRŒ} ³W2K"R S§Äí·Ž£ÕƼyÅÿ‘¥µTÿ8T÷êS V˜ýøYìò¾îK1vO`lVAªè[„g%ŽÊšï¤¸7ï´Ã=õŸ¯7»]"Puî{_‰#²47ÕùqßtÏÿOÌ*ŠH‘¸ÃUW†{yþ׺yó|á eÜ‚dGªª{>Ô¨-×ÿ]7ÙžÙBÒ×øÜnÙž÷ÀÇcÇÖöØý9}6À–„ä÷êõM¸áï|hN6aUœ;DdCp;D+|hŸb|šV"…õÀG2kÖ±cTlúôž¥?" TÿXT÷|¨PKÌ ÏÜJñü4ÅØvÀ÷3Ê‘-÷6ÀíèÝÿ¢x‹p:ÀS»ýÈÖoæ÷^G½…pãaÉÿÚdU‰ûžÀ·cÇ(ˆoưKîÝ€/§˜a!fó²Š#R$7ß|Bì‰ÝpCùO_UýãPÝó¡@íù6°.vÙÁ]ÀÊãÏÁý“Y…ÉÐÕÀØ!ä=š;ªÿÏ.?ªòãü‚3Ï\‹û×€ÕÉ&¨º«#b‡(ˆü$‘¯nŸ†ñY)’™3{0sfyÏê©^,Xð¨ÙPýãPÝó£@­1{“°—‰YðԳ܊{qÖ¹®CÞW0Š]íŽÞؘlæ=öè O6¸ÊÜ'lˆ*Ûü÷v±CìÀ½ðÅ3l~’Q‘B¹÷Þ£cGHí!1Õ?Õ=?jÔ¦›H÷n³TÇ8`}Šñ]‡qOs\V6Ü?üŠtÏîJu5g±³&À¢Eiæ¾4ÍàªÇþ=÷Ðà8úÿ;Ä{„MïRGÁxíþ/µhëVcâÄ~±c¤ö‹_|(v„DTÿ8T÷|©P‹ÌÖÿ;†lÇlðƒ”³ô&âÞ1ƒDÉ„]»Ê»N«~¼Û˜²ÃïÌš•f޿ǽh»ôüp³+;º¶eÅNQŒNL1Þ›3Ê"R(Ï=wË——ÿÓE‹ºÒØØ%vŒŠ©þq¨îùR vÝ$|ÈWªè[Àk)ç8˜‚û¾䩌û€É@9Ö8 ì¬ ðÌ3iælOذÜÿøûØ1 l/àW-ãr?›ô›NÂì¹,âˆÍŒµÓ[â‰CbG¨˜ê‡êž/5j•Ù´vñ˜­#›g”ÓqÁ\­ã~0½ËZFÍ„&Àù•ÆÆäû—à~^ªTYp¿ŽpìZà׸Ç{kÂ}0p/é~öØ‚>ßRÃÊxÚÎÌŸ@ìSýãPÝó¥@m» X;„ìà?éÌs¡ ðÕ–£ÏªÃ}oÜ¿C¸ylm‹¶¨;Ä׳fàlþº ðøãËSÎùSÜãìÚãÞ÷¡(+1x¢åø½|¹%Ý®ÿwböû ‰ÒË/w!3 ä¿P1-Õ?Õ=_jÔ2³-Àu±cÈv̶Ÿ$›óÓÛö{X€û…¸·Í`ÎÀ}OÜ? ¼HXµÐ¦•#ç?Î,‡d©8‡ð¼ü)\qÅù)çë<Ž{¾„„ýþ1×ëֆ〧qÏo§"÷  ¤ÝÀt-pmú@"ŵtiçØ2S†g¡·§úÇ¡ºçK €Ú÷ `fì²³ÅÀÿÉpÆCû€FÜ¿‰ûQ‰fqß÷¸ßHØCâ. ’uY›Ë€‰®/yh>LÁl07å|ûÓp¿8u²Ýq·–¦Ô€S+ÙT¥DE³¥•w0 ÷OánUKãÞ€û8`ÅÆ¥_kÙLU¤f­XÑ;BfÖ®MsÐGªª{¾Ô¨ufŽÞ1)&³ñdŽõ„Ï÷|Ü_Åýg¸Åý¸ÆýHÜÆýPÜûã>¤eåÀµ¸ÿx˜|Ø?ÁõoÂìwþy¤ú¾—Á ÀÏp÷>Ì·#÷QÀïM©JÚëÏ·Œ©?¤õG6¾ÿ<ûñ™¦š  ýSF³þ†ðç©i›7×Îæk×–ï¤`Õ?Õ=_Ù-–â2›„ûd*{ÇLòñY pJæîTÿ]Ùm¦¡ç±Ëè焦ÑáÌup&î÷?¦¶4!“ »Ö_| H²ªe#áq›‹g(— ŸËÿWÁ˜Ù¸?A8=æaÌ6'ºº{'Âi _ Yš•7€ËR}-‰”D-ݵiS¾¿²ªª{¾Ô¨_#< P½åžR9³¸Ÿ<ÄÙL-/çböNÊyZ»„Y²b¶÷+ ÏÔg¡-á¦ý`î“Í¡g%Àê–}0Þ˽#Л°¹å0`$á¸É4?ü f¿Ç½^ß> ­`Œħkqxœ°ŸÇÌV½ï(÷„Ç ŽN'4²Þt ð)-ý—zÑа‘uëŠÿbk44”ïi@Õ?Õ=_jÔ ³Ù¸ÿÿØ.y/³µ¸ŸüPåÓÕµ …ÙŸ3˜kCsH¥ÌÃý—„Ç,õ.oym㾆pRÄV`o •-ëoG€›2ž³øÌ¶´ì“0“d;îw&|lûZp_¼MØDÒ€}ÏôwH·¾ŒYVÍ)‘ÂÛo¿æš¹êÒ¥|ÿKWýãPÝóU;ë-¤5¾FؤMŠÆìU»gsbG©Ð*à,Ìþ¸Ý¯']i’v$7hÌéZ]€Cïøw'û›ÿYÀï»Ò ˜-F“Ý÷û}Ÿ§Þ„ G÷#Ÿ›ÿ›1»-‡ëˆF÷îëbGÈÌ¡‡–ïD`Õ?Õ=_jÔ“p“vOì²a‰ëÉd·»Ú1{æ}~/é2àâ·Mk•Ùj³òeoÂ,ÎÄìíØA¢2{ ¸2vŒ&WÇ!’·£Žª§]úôyÿ§‡ŠLõCuÏ—õçzÊÿ~í2k"l¤ö¯„åÑE58¡åÆ÷“ô }mÆd6ƒÐ(ëJ¡ÅÀ阭Œ¤ÌþÊ6,Š;€OÖí ©kÇóFì™8ðÕØ*¦úÇ¡ºçK €zc¶øØ1dÌ6a6–°!ײØq¶³ø¿ÀpÌ^ßÅÇ%m4''Y1›Hxf¿l2Î#¬HY;H¡˜}øÅn(þµqÀg1+ÛןH&†¯oa'Ÿ¼$v„Š©þq¨îùR >ݼ;„ì†Ù“„“n¢ïŒÏcöuÌv·TŸ„ר5`efv7p&°6v”VšŒÀìµØA ÉìVÂQŠEÞš¸‰pÔß•:îOêYÿþoгgY¾õî\ïÞ«èÕkMìSýãPÝó¥@= »µ?v i³5˜]M8£ýgÄyWö9àRÂÍÿ¼VŽù@ÂkÕΰ²3›Œ^ˆeVc0»¨åñÙ³{€¿%<&Q4óA˜ý$v‘"8ûìcGHí‚ ž!1Õ?Õ=?jÔ¯›ÐÍVy˜-Áì“„Ó¿,¯ò7Îö>³{0«ä¹ðî ¯«¯É"1›ÜHñ xè‡Ù±ƒ”†ÙS@Â2û"<°ž°"mf b‡)ŠË/Ÿ;Bj]4?v„ÄTÿ8T÷ü¨P¯ÂÙÿ;†TÈlf×%4rž²X2»š°”úb`ÌNÇ챊—ãºjÔ³ ˜] ~9O§b6ºåä ©„YfW'OFJá„ï5ý0ûfë#å)¤^cРj÷ù«ç”S—zWwÕ?Õ=?mSŒÝB¸a(3¶ÍÎþNz³Vdµý ix7þ·-¯«q?8†ð¨@?ÂYÝû -¯}€5ÀÛõz…pdÚ -¯ÆŒž½í tL86ÆÖ©[Iþ½¬{3äÃì9à,܇_ÎÚçtõ· G˜þ³$ëëÖ“ìs\»{¥˜M>ŒûñÀUÀß‘îg‚ÖXÜ ü;f¨òµ²¶d_CEXiQ)ý})€±cŸæ¼ó.Œ#‘k®™;Bjªª{>,v©1‡Žî†YñPpß œ œLöÍ€EÀ$B“k2fë2ž¿˜Ü÷$ycéJÌÆ%¼î€³€Q„½fØ^aÕÆÃÀÌt“(™¹þúôÍþë®Ë"IöÜaÈ1Ìž}`ì(9²‘)S~;Fjªª{>ªÝí‘úÓ?á¸×tó_"aùýíÀí¸w†ö 8èôöoÅLk€—€…-ÿ>³?U#¶ìD8ÖóNàNÜÛ×?ÑòÏ}w3K3ás¸°ªh0³úY)#’3¸å–G1â2¶n-ÇûumÛneܸÿŽ#ªª{>Ô‘¬H8®[§ÊŽÂž"“[^Û¸ïtö"<Ò–pÃß 4ëÝà‚ 7ìSZ^ïåÞ™ð¹ÜñÑ"Ä ’©aÖñùÏÏâ¶Û†ÄŽÒ*W]5þýkg+Õ?Õ½úÊÑZ‘rpo ¬:%}+f_Ê8‘H¹Äz@¤„jù€w55íÉ '\ÎüùÄŽ²Kƒ-gÚ´»h×®hƤ£úÇ¡ºW—N‘,@²›€ßgDDD¤ì6ò«_ÝO—.ÅÝÃzÿý›¸ÿþ_”î&¨5Tÿ8T÷êR@D²tQбOfBDD¤Vô鳊‰'СæØQv°÷Þ›xè¡ñrHkÕ?Õ½zÔ‘l„¥Ë£Ž^†Yc†iDDDjÆÈ‘Lœx?íÛoŽå/:vÜÈCgðàòžÝÞZªª{u¨ "Y tK8vÇÍÆDDDä/N;m¿ýí=tëÖ; ݺ5óøãwsÊ)‹cGÉê‡êž=5D$=÷6À×SÌðDVQDDDjÕˆK˜>ýÇuÔŠh|•9sî`ÈW¢eˆEõCuÏ–"’… €~ ÇnÌ0‹ˆˆHÍêÛw%³gßÁ•WÎÀ,õA­Ö¶íV®¾zS§ÞE¯^kr»nѨþq¨îÙQ@DÒ ç‚ߘb†G0«ï¨"""9Øk¯ÍÜrˣ̜y'Æ-«úõ†_ÊìÙwðÝïþ¶PÏcÇ¢úÇ¡ºgC Ië{@ãÇgDDD¤ž ´œ©S̃ÞLjK2Ÿøð¥<öØ=<ýô]{ìë™Ï_vªª{:;€ˆ”˜û¥À¦˜a%гâô*’§pšÆ; G_‰Ù¸,ãˆÙõדzðu×e‘¤8æÎíÎ}÷õçç??’¥K;'š£wïUœ{îB.»lúЛ'¬mªª{eÔ‘dÜO&íSÌòMÌ®Ï&H P@¤ÕÔØµ… ÷eúôžÌœÙƒÅ‹»°xñß°re6mjCss;ºuk¦[·õxà[yä›}ôŒÙHïÞ«bG¯ ªªûî© ›{ÌÅŽQ÷“€_ÉÚ¬AÐ ³•Ù„©jˆ´š""•Ó"ñÝû#¸Ž¤UÜÏ%ÝÍ?Àÿ×Í¿ˆˆˆˆH~Ô)†3€™-€¿Å½x«sÜ÷Â}ðK CÊÙÖîä©"År0 x÷1¸wŠ÷³€¹À?‘Í£Cc1«½mUEDDDD L ‘bêܼ†û½¸ŸÖòlp~Ü÷Àý ܧGd4óLàGÍ%"""""­Ô6vÙ¥½KZ^oáþ(ð0ð$f˪rE÷c³€O‡f<{30³­Ï+"""""»¡€HytF·¼À}0 xxxXŠÙ¦VÏè~ÐÐò ôÈ0óöÆ`6¿Šó‹ˆˆˆˆÈN¨ R^= [^Û¸¯ÞVNØpÏ « Ú ÀÀ-ÿ—›1ŸãõDDDDD䯨 R{öoyÉ/¯Æ!""""RÏ´  ˆTÛýÀE˜mŽDDDDD¤ž© "ÕtpIEûˆˆˆˆˆHU¨ "Õðð%Ì.ÇlKì0"""""¢=D${K€ 0›;ˆˆˆˆˆˆl£"’•õÀ ÀQºù)5Dâ› ”ùy&ý0ûfoÇ$""""";R@$6³ÏÆ“ÏÏ—Á[ÀmÀ˜]„ÙÒØDDDDDdç´€H˜­îîĽøpppDÌhÛÙ<ü¸³u‘󈈈ˆˆH+© R4fMÀƒ-/pß8 tÏ)ÍVà%`&ðà1ÌÖætmÉ"Egö&ð_-¯À}_ /p8pÐèAh t©ð*+åÀRàÂMÿ`fo¥ûˆˆˆˆˆHXì"R%î]€Î@`¶5ü¶kÍÀ:`fë£d‘÷r7`@ÂÑË0[‘e‘ZçŽÇÎ "’'5DDDD¤.© "õF§ˆˆˆˆˆˆˆÔ5DDDDDDDê€"""""""u@ ‘: €ˆˆˆˆˆˆHP@DDDDDD¤¨ """"""RÔ©jˆˆˆˆˆˆˆÔ5DDDDDDDê€"""""""u@ ‘: €ˆˆˆˆˆˆHP@DDDDDD¤¨ """"""RÔ©jˆˆˆˆˆˆˆÔÿñ™b—„S{IEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_512x512.png0000644000175000017500000013124613070106167017060 00000000000000‰PNG  IHDRôxÔúsBIT|dˆ pHYsvv§ÂxêtEXtSoftwarewww.inkscape.org›î< IDATxœìÝwxåöÀñï$„Þ¤ PA:*EM€ˆT)ID¥£Àµ¡^½‚;"èý ˆ¨€( =€H %$iŠtAH=•dŒá"’ì»e6[ÎçyîsŸ‡œ™9 nΙ™·h!„]׆í8ìÐQ×õDS’B8LËÍÁ³kš¦u²X, .LKá$i„·å‚³ “®ëñ.8—¤BüÍ{ï½×,;;Û´uñ©åI€D!`já¿YЦi-Ëz¯!„P €~ÎU…¿@\¿~]%4UÓ´§,Ë:g®'„pŽ4Bø)W½ã¦U«V.\˜èèhRSSUK×4-Âb±,wæÚBÇI „Ÿquá¿ûî»oüÙéÓ§™5k)))*§È"t]_æLBÇH „Ÿ0³ðßìÌ™3DGG+7š¦EZ,–¥Îä$„°Ÿ4Bø8wþ›;wލ¨(®^½ªrê ài]׿u&?!„}¤ÂGåGá¿™M@¦¦iO[,–%Žä(„°Ÿ4Bø˜ü.ü7;þÛå‰!n@/å …ÿfÉÉÉDEEqùòe•ð,MÓúY,–Y¦&%„“@/ãm…ÿf/^$**Š‹/ª„gýu]69-!ü’4Bx o.ü7»té3gÎTn4M`±X¢ÌÎK# €ÎW ÿÍ.]ºDTT.\P Ïèº>Óܬ„ð/Òá¡|±ðßÌÎ&ÀªiÚK‹ås³óÂ_H „‡ñõ³˗/3sæLå&xY×õÏLNK¿ €Ÿ ÿÍ._¾LTTÉÉÉ*áVMÓ^±X,SÌÎK_' €ùÌ_ ÿÍ®^½Jtt4gÏžU ·jš6Äb±L6;/!|™4Bä)üwíÚ5¢¢¢”›à5]×?19-!|–4B¸™þÜ9м¡ëúD“ÓÂ'I „›HáWsíÚ5¢££ùóÏ?•â5M{Çb±|`rZBøi„0™~ûÙÛÃu]kfNBøi„0‰~礤¤Í™3gT¡ëú3s—H „‹Iáw´´4¢££9uê”R¼¦i#-Ëh“ÓÂ'H „‹Há7GZZ³fÍâäÉ“Jñš¦é‹e”Éi áõ¤ÂIRøÍgoŒ×u}¨™9 áí¤ÂARøÝ+--Ù³góǨ"M€y@;IáÏ?éééÌš5Ëž&àC]×ß63'!¼•4B(’ÂïÒÓÓ™={6'NœP=俺®¿efNBx#i„°A ¿çÉÈÈ`îܹ$%%©òº®¿ifNBxi„È…~Ï–™™Éܹs9zô¨ê!t]ÃÄ”„ð*Òq )üÞÃ&à ]×_ÄØG@¿& €‘Âï233™7o¿ÿþ»ê!Su]ÿÒ?' €ð{Rø½ŸMÀ4à_º®g›˜–Má·¤ðû–ÌÌLæÏŸÏ‘#GT™ –&@ø+i„ß‘Âï»®_¿Î¼yóìif¥ þHá7¤ðû‡¬¬,bbb8xð ê!_/H ü4ÂçIá÷?YYY,\¸¨2·nݺ½###³ÌÌKO" €ðYRøý›MÀ| —®ë×MLK! €ð9RøEެ¬,-Zį¿þªzÈ §4ÂH |†~q;41ÀsÒ_' €ðzRø…-ÙÙÙ,Z´ˆýû÷«²xVšáˤ^K ¿°‡ÕjeÉ’%ìÝ»WõE•*UzvРA™fæ%D~‘@x)üÂQ4‹+UªôŒ4ÂI ¼†~á V«•o¿ý–={ö¨²²L™2Ý_}õÕt3óÂݤO ¿p5«ÕÊÒ¥KÙ½{·ê!«€îº®§™˜–n% €ðXRø…™hbnÒ_! €ð8Rø…»X­V–-[Æ®]»TY t•&@øi„ÇÂ/òƒÕjeÕªUüôÓOª‡¬)Y²d×7Þx#Õ̼„0›4"ßIáùÍjµ˶mÛTY[²dÉ.Òo& €È7Rø…'q  ØtÐuýª‰i ai„ÛIážÊjµ²zõj~üñGÕC¤ ^Ká6Rø…7°Z­¬Y³†~øAõï‹)Òáí·ß¾bf^B¸š4ÂtRø…·q  ØX¤H‘öÒo" €0~áíÖ¯_ÏÆUÃ7íu]¿lbJB¸Œ4Âå¤ð _Ï÷߯¾h'M€ðÒ—‘Â/|UBB6lP ß^¨P¡°aÆ]03'!œ% €pš~áìm€'t]O61%!œ" €p˜~áoùî»ïTÃw,Xð‰wÞyç¼™9 á(i„ݤð ¶iÓ&âââTÃw,X0Lšá‰¤ʤð a°³ Ø„éº~ÎÄ”„°›4Â&)üBü“MÀn 4“H r%…_ˆ¼mÞ¼™uëÖ©†ïZéº~ÚÄ”„P& €ø)üB¨Û²e k×®U ÿ5((¨ÕðáÃO™™“*¤7HáÂ1ö6@k]×Oš˜’6I ¤ð á?ýô+W®T ?€ñ:@š‘o¤ðcRø…p­íÛ·³bÅ Õðƒ hõî»ïþafNBäF?$…_óØÙ*P @¨4"?HàG¤ð á;vì`ÅŠX­V•ð£@¨®ëGMMJˆ[Hà¤ð á~v6I¡#FŒøÝ켄È! €“Ÿ¿ÒÓáÔ)8w.^„"E lY¨PÊ”Éïì„;ìܹ“åË—K <’4>H þ°ZaýzX¹6o†;!3óö±÷ÜÍ›CHDFBÉ’nMU¸Ñ®]»X¶l™jp ãuÀ“ÓB_"…?¤¤À§ŸÂ´ipø°ýÇ/=zÀ›oB­Z®ÏO俟þ™%K–­~,00°Õˆ#ø¯IuÒø)üùgÕ*xùeøÝmƒ‚à_ÿ‚±c¡X1çÏ'<‹MÀqŒu~39-áǤðbRøóOv6 bÜù»Z½z ÁÁ®?·È_¿üò ß|ójpú¯'ûÍÎKø'i¼þü•‘½{Âæ]£reX½40ï"ìÛ·Å‹+7Ëï39-ᇤð"Rø=ÃóÏÃŒæ_ç®»`Ï™1à‹ìlδ9rä/fç%ü‹4^@ ¿çøæèÞÝ}×ëÞ-rßõ„ûìß¿ŸE‹)7@]×69-áG¤ð`Rø=KJ T«fÌëWvP( ¤b<еsl÷7ß@×®ö#¼Ã¡C‡X°`YYY*á´9rä^³óþA$…ß3}õ  Xxx¨Ë?¿egÀgÀO¶Oת•±¾€ðMv6gÿz M€pš4D ¿gkÚ~üÑFÐ3À§€Ê{{+0xHË=LÓàÀ¸ï>ÅD…×ùí·ßX°`ׯ_W ?‹ñ:`Éi ' €ÂïùRRŒ{ò\Ìíy`ö«ÖíÐuý]×—[p¢øÓ§Oú÷ï/ÅßdÇŽÙxÇ‹?@뼜”äĹóSFtî |ß™x…êÕ«Ó£G ( ^:;;{­®ë›—ðMJÿ• ×;~ïUº´€?œ¼À '¯ï‰22ŒyŒ+Wÿ³Záwò;+W½zuzöìÉܹsÉÈȰ^XûÞ{ïµ9ränHOøyàRø½ß™3pç6‚–ãØ¿ð%à~ŒW¹˜0^{Ísç—Œ ‡åËÿþç£GûïæON^&))Iµ ã¿¢'u]ßjrZ‡H`")ü¾Ãj…òåáüù<‚JË€–vœø"ð°!ï°5kà‰'ì8o~ÊÈ€ˆX¶ìö?ï=1½9y©cÇŽ1gÎå&  ÝÈ‘#·˜—ð ù€/Òuý‘ÏšŽž'88˜®]»Ji¯|ì;4 NŸ†­yÝ_¥³€d >PR!¶;`c×*U`Ò$/G—™ ‘‘¹€„ã/4$Ämiy«R¥JQ­Z5öíÛ§²N@a«ÕÚ#$$dsbbâQ7¤'¼œ<p!¹ã÷m@:6¦æZ`¬X¸œ~Öa4 ,Ðuv·œâÿí·jñk×BX˜¹9ùˆãÇ3{ölÕ'×4Mëd±XÌÎKx7i\@ ¿ÿè×fÎtßõ*W66*[Ö}×tHVôì óç«Å¿öš1°A(;~ü8sæÌ!==]%ƒŽNý—æöÿŒâïS¼ÃéÓ§‰ŽŽVmÒp]×W˜œ–ð"ÒäA ¿P±p!üç?pô¨ãç(R^zÉñ_¼¸ËR3Gv¶12:Z-¾˜>]Š¿ NŸ>ͬY³HIIQ ÏÐ4-Üb±,·*ü4·!…_Ø+;bc›Üuë@å¦LÓ A£>öî wÜa~žN³Zað`リè×¾üRŠ¿‰Îœ9Ctt´rD躞ÇB Â_Hp)üÂ23aÇØ²ÅØDèüy¸pÁ¸³/[ÖXQ°Q#hÖÌ ¦÷ÝÌj…ýËħ¢o_cc)þ¦;wîQQQ\½zU%ÿ\-þé§aΔÅFÝÅÞ&xZ×uÅU›„/òë@ ¿ ¬VcJÂgŸ©ÅGFÅ_mK[áBv6™@]׿19-á¡ü²Â/„"«^y¦LQ‹ˆ0ÖâŸoΟ?OTTW®\Q ÏÒ4­—ÅbQ\ÅIø¿j¤ð a«ÕXµïÓOÕâÃÃÕ¥øç;š€>‹eŽÙy Ïâ €~!ìdµÂ!0y²Z|÷îÆ>Rü=Frr23gÎTn€¾º®+.ì |O7Rø…pÐС0~¼Zl·nFñ 27'a·ääd¢¢¢¸|ù²Jx–¦iý,Ë,³óžÁ')üB8aØ07N-¶kWX°@Š¿»xñ"QQQ\¼xQ%òê@ ¿.2bŒ£ûä“Fñ/\ØÜœ„Ë9м¬ëºâÂÛxe …_9FV‹}â XºTŠ¿»|ù2QQQ$''«„[5M{Åb±(.!¼‰W5Rø…p1‹Þ{O-VŠ¿Ï°· ^Õu]qAá-¼¢Â/„ >üÞ~[-6,Ì(þEŠ˜›“p›«W¯ÍÙ³gUÂ­š¦ ±X,Š CoàÑ €~!LòÑGðŸÿ¨Å>ö¬ZÅŠ™›“p»k×®eOðºÅb™dv^Â=<²Â/„‰þû_xë-µØ–-â_¼¸¹9å!- Nž4¶U¾tÉxQ¦ T¨àeÛ){({›à ]×'šœ–pj¤ð a²?†ÿ[-öÑG!6ÖíÅ?;Ö¯‡+`Ëع®_¿}lµjТ„„;—,éÖT}Ƶk×ˆŽŽæÏ?ÿT=d¸®ëŠsF…§òˆ@ ¿n0a¼ñ†Zl‹°zµ[‹J |ò LŸGŽØ|±bУ¼ù&Ô®íúü|½M€¦iïZ,–÷MNK˜(_)üB¸Éĉðúëj±Í›Å¿D ssºÉÊ•ðòËpô¨óç ‚ýËXÓH†-Ø'%%…èèhΜ9£zÈ]מ&_)üB¸Ñ¤IðÚkj±ÍšÁš5n+þÙÙÆŽÃSL˜e^¯žñ#8ØõçöeiiiÌš5‹“'OªbÑu]q.©ð$nm¤ð áfÓ¦ÁàÁÆö¾¶<òˆQüÝô"=#z÷6ö2KåÊÆÃŒ Ì»†/²· Ð4M·X,£LNK¸˜[)üBäƒéÓaÐ µâߨÄÅÁw˜Ÿ×_ €¯¾2ÿ:wÝ»wËŒ{¥¥¥1{ölþøãÕCÆëº>ÔÌœ„k™ÚHá"Ÿ|ù¥Qü³³mÇ6lhÿ2eÌÏë/‹Cx¸Û.G·nÆ5…}h>Ôu]qu)‘ßLi¤ð{Žôt8}Ú˜Cœ E‹wB*¸õf/_øígÿê+xá-þ×®ÁÝwùsvT¸(¤g€ßì»î7ß@×®ö# ==Ù³gsâÄ ÕC>Òu]q•)‘Ÿ\ÚHáÏV+ÄÇÿoõŽ™yûØ{ï5|‡†BD„[}›ÂŸ?û _ Ï?¯Vü|Ð(þn~6>c†‘¢MåAÀ³@mþùÛê,°ø Øfût­Zë û9ÐüW×uÅÕ¦D~qI …?ÿ¥¦Â§Ÿc¾~³óÎŒéÞÏrÇo‚ùó `9ŒG¡{óÀO£¤7‡1R™4V»®›µØËŸ?û öÿûîó¨âÆT¼Þ½m]B×[ Ð¥c ú«‹Íâ_¥Š±€p­ÀÀ@"##©©>‡v0]×uSêPçÒ'rÇo>¥9Ô=€)#ªm±_¯âñs¨ýù³°j•±¦mzºíØ5ŒÑþwÝezZöúõW¨[Wm‹ -€ê+^Nb,þ³£ÉS`±S<…9²²²X¸p!ÔçäΫ[·n¯ÈÈÈ<&n 3¹¤ S§N<øàƒ®ÉJÜVjª±¿yž¿8` µ±÷-Û =ÇC¹üœCíÏŸ0æ%víªVü«U3Š¿7â}ûK¸KåÊÆ€Î|XúÀ¯8ÐÌz麮0˜E¸šKÁdggÇ9»÷ö:zÔF¼˜„cClÚ6ͱóݹ+ùóggõjŸ*þ`ŒÄ¿÷^÷\KÓŒ’¥ø›/00ˆˆjÕª¥zH`fLLL ‰i‰\¸ì̵k×ˆŽŽæÂ… ®:¥¸…Í8›Åœ¸@k'¯o"¿ýìkÖ¨ÿªUwþ^üÁØ{aÁ÷lÊ4fŒ üs§œ& víÚª‡<·oß¾Yº®03/ñO.„qåÊ¢££¹té’+O+þRº´å}:;ÞæõMä—Ÿ}íZèÒÒò #§ø«OÉÊwMšÀ† æ S0ž4¼óŽ9ç¹ËX¿~}ÕCžæM:5ÈÄ´Ä-\> óâÅ‹DGGsåÊWŸÚïÙ|dú3°ÂÁ“_Ä£çPûÝg_·žzJ­øÅß]ÏÔ]¨~}ؼÚ¶uíy«To¿5þùCÓ4ºuëFõå4ÃO:5Wš÷±Õäµjw®’““‰ŠŠâêÕ«Ž.rQ¡‚Â{Ì^Øœõ€ÎÀ±¼ÃêÖµó¼.äWŸ=.N½øW©âµÅ?GÕªÆ0‡ Œ! Î(RþýoØ¿:urM~Âqš¦ÑµkWî¿ÿ~ÕCÂO:õÍ'Ÿ|RÈ̼„!·  ìvôÄçÏŸgÖ¬Y¤¤¤8z q6çP_ZC06UÉKÆ6ªõ€ïó­RZÛxOn6¿øìßo<öOMµ›Sü}dy»ÈH8|V¬0Š·=;2Þ?Lœüÿý¯±ã ð š¦Ñ¥K{š€ŽÉÉÉ‹¥ 0ß­c¦ÀXó?<çgº“g+V¬HŸ>}(R¤ˆS熠NÅ9ÔÀcüouàp øˆ’Õ®ë s¨}þ³oÜh씣òä¬bE£ø×©c~^ù$#vì€-[àØ1cõÀädcaٲƊ‚Ã#Èo`µZYºt)»w+ßWÆÝt]Wx&‘Ó4ÇX;­·4Î6•*U¢wïÞöºMÖ=SÿþÆ´&w©\öì1~éæ7Ÿýì›6Á“Oªÿøøü}'#„hV]¥ 0GƽÐ&ŒÍ~ìžE`{á©S§˜3gv'(þiÒ$÷=õ €™3=£øƒ~öM›Ôïü+Tâ/¼–¦i<õÔSö,÷$°D×u¹{4A6g@çí±ÇCÓl÷ 'Nœ`Μ9dª¬a.òT¢„± ¼;¶©3ÂÂÌ¿Ž*Ÿûì›7Å_eÖŒá4M£sçÎ4iÒDõ'¥ü±¼Gv1§§Ö¬Y“Ç\© 8vìóçÏçºÊ¦"Os¨«T1çüÆ&8ÃòØ[=¿øÌgß²E½ø—/ë×C=‡&æáQ4M£}ûö<ôÐCª‡úÈ™å¾Ä-\²@Íš5iÞ¼¹Rì‘#GX°`YY²ÿƒ³êÕûß ¤+òeðâ‹®=¯+yýgß¾:t€Ë—mÇæõEU„ðxš¦Ñ®];~øaÕC¿víÚ*]×eއ‹¸l! zõêѬY3¥Øß~ûÅ‹“-ÛA;+8ØØ$náBçW€-RÞz˘CÝ¡ƒKÒ3•×~ö;Œw *Ëfßq‡±úb*Bx MÓxòÉ'íi¤ p—®Ø Aå÷:û÷ïgñâÅX•æt [ÂÃ9Ô«VkÈ-ªvœ¦ÁÀ'ŸÀÉ“ðá‡Æ®{ÞÄ«>ûÎêÅ¿ticEÀÆMNJˆü“Ó4mÚTõ–@ìøñãK˜˜–_Ð0vEÏ•­i€üÇŸmÛ¶;w*%ðÀðÔSO)!ê23Z³u«±‘ÍùóFÍ)V̘3]¾¼ñ.½Y3÷ ¨s'ýì»v+ %+,@SüÕJ áÕ¬V+k×®eëÖ­ª‡l*R¤H»·ß~[Öw) À?ü <׳aÆtêÔIšá»ví‚6mŒnÄ–R¥Œâ¯>@JŸ±~ýz6nܨ¾h§ëºÂ`q+—o”£iÓ¦<ðÀJ±;wîdÍš5f¥"DþÚ½Û¾â¿v­á·Z·nMË–-UÛ«u]/ibJ>Ë´àᇦ®âœå~øAšá{ö챯ø¯YꢄðI­Zµâ±ÇS oÄëºîc/3Ígj i-Z´ víÚJñ[·n%11ÑÌ”„pŸ_5ö¹=wÎvlÉ’Æ–xê¡„ði¡¡¡ö4uÒØÇÔŒ& eË–Ô¨QC)þ»ï¾ãûïmlÏ&„§;pBCáôi۱ŊÁò寮6BˆBCCyüñÇUÃqcÇŽõ…Ë=Ÿé M@hh(ÕqgÓ¦M&g%„Iì-þ+W‚úŽ~%$$„6§Œ4H IDATmÚ¨†7ÌÈÈ&@‘[ø_P­Z5¥ø¸¸8¶mÛfrVB¸ØÁƒÐªœ:e;¶hQX±Ôïp„ðK-Z´°§ x0###N×uÙ$Ú·5`ìFpp°RüªU«Ø¾}»ÉY á"‡wþ'OÚŽÍ)þ!!¦§%„/hÑ¢aê»s=H`ƒ[ø_P¹re¥ø•+W²gÏ“³ÂIöÿåËx!„²æÍ›ÛÓ<lÐuýNSòjno (À“O>I¥J•lÆZ­V¾ýö[~þùg7d&„’’Œå}ÿøÃvl‘"ÆnC­Z™Ÿ—>¨yóæ<ñĪáu€„÷ßßv±ñCùҀѴmÛ–òåËÛŒµZ­,Y²„¸!3!ì”d<ÆOJ²[¨,Zd,,„pX³fÍhÛ¶­jxíÌÌÌ]×Õ;û‘|k ,H‡(WÎökšììl.\È¡C‡Ü™ Ž3ã=j;¶`AX¼Ú·7=-!üÁ#k~^B˜ ..Žððp&OžÌùóçX½z5eÊ”¡iÓ¦¦\óêÕ«L˜0ÈÈHÖ¬YCzzúŸ;wŽ+VЭ[7¥qa·ªP¡åÊ•ã×_ÅjµÚ /eµZ»†„„,OLLL¶ûb^ÊcŸä(S¦ íÚµ£`Á‚6c/_¾ÌÌ™3¹té’éyedd0mÚ4jÔ¨Ák¯½Æ™3gcÕÂ×_>øÀô„‰Îž5VìûåÛ±0s¦á•âââx衇 c×®]û™ÕjeÈ!Lš4É¥×¼ví“&M¢zõê :”‹/Þ6îÀ´jÕÊáÁÞõêÕ³çI@0Æì€º]Ì yô€ÅŠ£R¥J9r„ììì..ŽÀÀ@üq—å Lrñ¢1Õï–Ç ·¥iðÅп¿ùy a¢&MšP©R%V­Zeó÷êúõë)X° r••Ett4|ýõ×J7N¹INNæÜ¹stíÚÕ¡ãË—/O… Ø¿¿R`µZÃCBBV'&&þéн€W5`L,_¾¼RpíÚ5>Lýúõ)P €ËrhѢŊcݺuJñ HàÉ.^4¶ôݾÝv¬¦ÁçŸÃ Aæç%„4nܘʕ+³råJ›¿Wããã)P @ž¯7­V+‹-"<<œ3f8Uø4hÀ§Ÿ~ÊðáÃ:Oùòå©\¹2ûöíSiŠa< X“à“M€×5`L¼ãŽ;8zô¨ÍÄ«W¯’””Dýúõ tY-Z´ D‰¬]»V)>11‘´´4Ú´i㲄‹äÜù«Ì{Ö4˜26?/!ܨqãÆÜu×]JM@BBB®O6ãâ∈ˆøÛlGÕ­[—)S¦0yòdêÕ«çÔ¹r”-[–J•*±ÿ~›¯“b= X“˜˜xÆ% x¯lî¸ãJ—.­´3àåË—IJJ¢^½z.mš7oNÉ’%•›€M›6Iài.]‚¶maÛ6Û±šŸ~ /¾h~^BäƒFÌŠ+”š€›ŸlÆÅÅÑ£GÆçð">9î¾ûnÆÏôéÓ©_¿¾ê¢>ÊÊ–-KåÊ••› G«V­â|jÙY¯mÀhJ”(¡´3àåË—9yò$õêÕS¢¤Y³f”*UÊ®& 55•°°0—å té’qçÿã¶c5 &O†—^2?/!òQÆ •›€ÄÄDŽ?ΤI“xï½÷œÞ›¥jÕª|øá‡|ýõ×<ôÐC.ý]}«2eÊØÓ±Z­!!!ë}f¯nÀèäŠ/®Ô\¸pÁ´& bÅŠ¬ZµJ)~Ó¦M¤¤¤HŸ._6îüU‹ÿ'ŸÀË/›Ÿ— aÆԬY“o¿ýÖf°sçNŽ=êÔõ*T¨Àˆ#˜={6M›65µð߬L™2Üu×]ìÛ·O© "[µjŸàM€×7åÊ•£P¡B?~Üfì… øóÏ?©[·®K+5iÒDy: ÀæÍ›¹víO<ñ„ËrŠ®]ƒŽaófÛ±š“&Á+¯˜Ÿ—¤AƒÔ¬Y“¥K—ªG‡”+WŽ‘#G2oÞ èѪU«Í ¶¡y Ÿkîºë.®_¿~cƒž¼œ>}šÔÔTjÔ¨áÒâkÏt€Ÿ~ú‰Ó§O;Ý\¸pÁc¿\ù&%:u‚„µø÷߇wÞ17'!<ÔÙ³g=z4={öä‡~pêÑÁ‚0`‹/&22’âÅ‹»0SsØÙüëIÀæÄÄÄ£nHÏ¥<~7@G=üðÃÊ GüøãÊÓøìÑ¿¾üòKå­S§NeðàÁJ í~þùg"## fýúõvï³RSâ¯?z´á—Ο?ÏСCoÌÁOKKsúœááá|ñÅT®\ÙºOÕªUéÙ³§ê+ŠbÀŠQ£F…šœ–ËùäMÓ&55•sçÎÙŒ?qâT¯^Ý¥yäL§QI»}ûvNž<©ü$`ÿþýüûßÿæÅ_ä—_~!33“E‹Ñ´iSî½÷^W| ;ƒjCôÞ{0b„¹9 áa®\¹Âĉ‰ˆˆ`ýúõdffºìÜ{÷îuÉ“Íü`ï“ "$$dkbb¢íÕé<„Ï6`4U«VåÊ•+$''ÛŒ?qâT«VÍ¥yØ;fÇŽœHÍš5]ö9¼BF†Qü×dà?ÿ1cÌÍI‘‘‘ÁŒ3èÖ­ß~û­Óúl¾¶´÷ɦ')Q¢÷Þ{¯=M@xHHȉ‰‰ÎO›0™Ïޏ™¦i„††*ßÙ¯_¿žÍ*‹ÄØéé§ŸfΜ9Ê‹]̘1ƒ^xììlΞ=ËСC©Y³&Ó¦MSù‘ôôtÂÃÃY¾|¹³©{œâ¿b…Zü[oÁøñææ$„ÈÌÌdÚ´iÜsÏ= 4Èéõú[´hÁwß}ÇÊ•+)\¸°ÍøéÓ§3hÐ Ó2S¥J•èÕ«—êë¢À²Q£FyüR¯gë¦ëzž'8p  Ó1Wvv6k׮娱cJñ:t I“&.ÏcáÂ…<÷ÜsÊïÚj×®MRR©©©]¯páÂüðÃÜÿýï522 "–-S‹óMøè#ss"Ÿegg³xñb† ÆáÇ>_³fÍ3f ­ZµºñgkÖ¬¡K—.JO À´iÓܶܯ+>}šèèhÕßÅ隦EX,½ó¾'Æ]wÝ¥¿råJvìØáò<"""˜;w®òêW¿þú«ÃÅ¿Y³f¬\¹Ò?Šd¤zñã )þ§egg³páBêÔ©Cdd¤ÓÅÿþûï'&&†Í›7ÿ­ø´mÛ–¥K—*Ý!ßüdÓÛÜyçôîÝ›¢E‹ª„²Z­‹t]ïlv^Žò« 00¶mÛR©R%¥ø+V°wï^—çμyóL[3¯/«ÏÉÌ„§Ÿ†¥KÕâ_þïÿÌÍIˆ|bµZY¾|97&22’ƒ:u¾zõêî]»ˆˆˆÈ5î‰'žPn¾úê+zöì©2ºÞãØÙzjàw @hÛ¶-*T°kµZY²d ¿üò‹ËóèÞ½;K–,qér˜ª_VŸ‘•½{÷ߪſö|ü±¹9 ‘Oâââx衇èܹ3»vírê\µk×&**ŠÝ»w¡4x/,,ŒÕ«W+-ø3oÞ¯½ö𣩿«råÊѧO{š€£FêjrZvñÛŒ& C‡”-[Öflvv6111:tÈ%×ÎÌÌ$::š:uê0yòd‡Vÿ翬^+çÎ_µøèö⟞II°cÄÅ»8 ³Q…—É™¥Æ•+WÜvÝ-[¶Ð¦MZ¶lÉwª›\å¢J•*Lœ8‘0pà@§¶æmÕª«W¯¦D‰¹Æ+VŒW_}•‘^¼þFN×ç¼IA«Õº@×õnfç¥Ê¯fä&--åË—+­P @ž{î9î¾ûn‡®•3"wøðáN7<ð7nôŠõµ]*+ úô9sÔâ_x¦N“ŸŠX­ÆŠÃ+VÀ–-FáÏm¢Ç½÷BóæjL\Pûý!"7n¤}ûökŠ ,Hß¾}Ñu]y,–§;þý¦MG6M+^žyƘ•èok6y««W¯2eÊÆwÛßÍ›7'66ÖåMÀ¾}ûÐuE‹9üÔ0G™2exå•Wxã7LmV6mÚD»víHKK£_¿~Œ9Ry&–7±· Ð4­ÅbQ¼‹1‡47¹zõ*Ë—/Wú,T¨½{÷VÚä"..Ž¡C‡:ýn.7~ÓdeA¿~0k–Z|ÿþ0}º©Å?>^|Ñx´ï¬  cv¢®ƒÂº*"Ÿ|õÕW¼õÖ[6—oÖ¬±±±”*UÊékþþûïŒ7Ž3f8=r¾xñâ¼ôÒK :”Ò¥K;›ŠíÛ·S¦Lî¹ç·\/¿$''3sæL{žôÕu]ñnÆõüz À­Š/N§N”©§§§3kÖ,N:•kÌÆyüñÇ]20'/+W®¤k×®.Ù½ËcegÝCŠv6¼ò ´níšâÆë‚ñãᡇàÄ ×œS¸^ëÖ­•Šú–-[hݺµÒ>$¹9vìƒ º±¨3Å?çûáÇ7nœÛŠ?KÆûzñã©JÿþýUÿn™º®÷69­\Ip‹âŋӡC¥waiiiÌž=›³gÏþíÏs¾ø-[¶dÆ åQ¬X1ºwïN±bÅ”âcccéÖ­›o6V«q›­ß·¯©Å?#ž{Îxìo†Ÿ†¦MÁ„å'„ T«V„„¥‚¶}ûvÂÂÂìnNœ8Á!CìZú;7 dàÀ:tˆI“&)MŽ+]º4}ûöµ§ øjÔ¨Q}LN붤¸k×®)/Ó{ýúõ¬Ò·eËâU÷Ÿ¿ÅÍ_ÖE‹«<È/66Ö÷žäÿ©SÕâûô3L}ìÿÒKê“uò$´oNÜ< U«VÄÄD¥-·wìØA›6m8þ¼ÍØsçÎÝØóã“O>qj‡¾   È‘#G˜:uªÏ ¸ó¥J•¢oß¾ÜqÇ*áV«õ+]×ûšœÖ?Hp‹S§N±fÍ¥Ž;((ˆgžyæ;¾ñÆL˜0Á®¹ø¹}Y[¶lIll¬ê4V¯^M—.]^:Ø£X­Fµýâ µø§Ÿ†/¿4µø/Yb\ÂNœ0f/ ÏTµjU”¶ÜÞ¹sgžM@rr2º®S½zuÆïÔ÷7 €ˆˆöíÛÇÔ©S}rÀ7(Uª}úôQm0žüËä´þqQñ—'N°jÕ*¥»ÿœA€¹M|íµ×øì³Ïl6*_ÖG}”U«V)79sxu`µÂË/Ã矫ÅGF3œ˜»lKJ dçAw6@sÀö ãß,^l4Â3ÙÓìÚµ‹6mÚpîܹvõêUÆOõêÕ5j—/_v8MÓnü.‰‰‰¡FŸK¸†M€fµZ§èºþ¢Ùyåà/ÇgÍš5Jƒl *D¯^½¨R¥Jžqƒæ‹/¾¸m`ï—õÑGµëIÀÚµki×®W¯^UŠ÷(V«1Âî³ÏÔâ#"Œ5L,þ`<ö¿e¸Ç핆{óÀOÀ:`p8ÌÀh L™â@²Âm‚ƒƒIHHP*¸9MÀñãÇ™4i5jÔ`èСJÓóÒ¦M¶oßNLL µjÕrê\µr^”)SF%\>5jÔK&§uãb~? ðøñã¬]»V©ø.\˜ž={ÚõXmúôé <øÆîWmÚ´áÃ?¤aÆvçºyófÚµk§|§ðØc±råJïY,Èj5–ì<æÍ3½øƒ10ïÇmõ¦*ßu+ð%ð*ǰ M3fÜwŸb¢"_œ>}šV­Z±ÿ~›± pÉømÚ´aìØ±<ôÐCNŸK˜ëêÕ«DEEýí P¬š¦ ±X,Š¿ã÷OŽ;¦|ç_¸pazõêe÷;µ^x)S¦ðä“O²mÛ6Ö­[çPñc‘øøxÕGJlذöíÛ{Ï“€¡CÕ‹÷î0w®[Šj*lÛf#h0µâFûýð-y~­Vøþ{ÅsŠ|sçwOݺumÆ:[ü[´hA||<ëÖ­“âï%Š/NŸ>}”öŸÁx0I×õWÍÌɯ€#GްvíZ¥}©‹-Jß¾}•þ¹ÁƒK“&M:þf7fݺuª”øþûïi×®[×(wÈСðá‡j±Ýºwþ&m§|«£GBœ«;€IEÝ^m3qà¼Âírš€zõê™rþ¦M›²lÙ26nÜHhh¨)׿±· &Ž5jˆYùømpäÈâã㕊±bÅèÓ§+VtCfjìm6nÜèTœœÌ°aجzwn¯aÃŒUpT´ooÜù»©øƒ±©OžšjK6Ü^k'¯/Êï×=½MÀ­k”gffMíÚµ4hPž›å1b£Gv,a‹Tˆ'ž€o¿Í÷-òzÛÚ²ã"Ð ·›|ÔlŒð¯RÅØtHx–~øN:Ñ¢E \rÎëׯóÅ_pBvƒòö0·Z­ïéº>Ò×ö‹à×_U.þv.ÚàQxà6lØÀwÞ©ŸÓ|ýõ×Ô­[—>}úðûï¿ÛuÍ‘#GòÞ{ïÙ—¨®ƒê1aaQüÁX–׿+Ø,ààŒf`0XÌ>žî˜6h»ÏbÀAÏñóÏ?I³fÍX±ÂÑ÷>¹;zô(!!!v…÷Ê™bnÇ,³Qº®+œÊÏ7û÷ï·»ø«Î±÷DuêÔ!!!Ayã;vп~ûí7‡®W©R%Ê”)£ôZ€>‚Q£ÔbÛ´¥KAagFw¨UËØhPIŒúOÏÿbÅM~*W6EùoÿþýôîÝ›x€… *ýNqTRR¡¡¡‘ùŸ~ÃufÞv¶ ðé`ß¾}|¯¸‚Š[8z´Úµkoêî_eË–eܸqüöÛo¼üòËjƒ”þû_øÏÔ.в¥qçï!Å?ǤIî3g‚âøNa’¤¤$ Dƒ ˜5k–z³{ÅŠãµ×^£Q£FJו&À¿8Ø(Οþ'ŸmöìÙÃÆ•bË–-Kÿþý}¢øç¨]»6 /\”›%JðöÛosøðaÞ~ûmŠ-ªvàÿý¼õ–Zì£ÂªUPÌ™‰õæ(QbbÀoˆÆŒ1Þ€ˆüqüøq† B­Zµ˜6mšÒj¡¹)T¨ä·ß~c„ ÄÇÇÓ´iS›Ç;vŒÐÐP>ìðµ…wQÝkæ&ÿÑuý#G®å“ Àîݻٺu«RlÙ²eéÓ§ò&;Þ¤V­ZÄÇÇ+ ÌK±bÅxûí·IJJbܸq”*UJýà?†7ßT‹mÑbcÁƒ÷.hÔ6l0ç™! ÀØh˜)K[Ξ=ËСC©Y³&Ÿ|ò éééŸëÖm¾sÆç”*UŠ5kÖðÈ#ØÞ³Kž\1JYÓ4zöìÉï¿ÿþ·;»Lœ¯¿®Û¼¹Qü½¨ 6ÞT,\êßÑÛ+RÄxC²?tèà’ô„¢+W®ÜXírüøñ¤¤¤8|®€€"""øå—_ˆŽŽ¦º#%K–dݺu„„„Ø<÷‰'hÙ²%ûöís8?á]‚‚‚xöÙgíiÞÐuýsw%ñ™`ûöíÊÅÿÎ;ï¤_¿~>Wü]9JÙjµ:·¨É'ŸÀo¨Å6kæuÅÿfáápø°Ñ <õ¨‹Ð4xàã¯êäIc$öà³®]»Æøñã©V­C‡åÒ¥KŸKÓ4:vìÈöíÛ‰‰‰¡fÍšÊÇ+VŒ+V(59[Kà?rš€{î¹GõÁªM€†±+y®t]ÏóTMÊ4?ýô“òÒ›wÞy'½{÷¦ˆ‡.wFRRcÇŽeÆŒN Tºœqv &œ> ²±}Þ_7†uëÀ‹§^Þ*3vî„­[M|Ο‡ Œâ^®”/oŒ#hÖÌ=ƒ =Y\\… ¢eË–n»fFF3gÎÄb±púôi§ÏצMÆGãÆ:ÏÕ«Wiß¾½Í™K 4`„ ´–Õ¡üJff&óæÍ³g}ˆiº®&ïõ À¶mÛØ¹s§Rl¥J•èÕ«—ÏÿãÇóßÿþ—©S§:5PÉ–š5k¯65åË/sTŠ£FçSÅ_¨Ù²e #FŒ`ýúõ-Z”¥K—Ò¦MS¯™™™É×_Í{ï½ÇüáôùZ´hÁûï¿Ïã?î‚ì )))têÔ‰øøøüìž{îaèС 0@–öS™™™ÌŸ?ßž©¡Ó1žÜvîª×¾°Z­lÙ²Å/‹¿«F)«þ]88˜>}úøDñ?sæ uëÖuj”rëÖ­Ù¼y3¿þú«ÍAJ9:Dhhhîk”õ•q篲HʃwþþþüÛüòË/DFFòàƒ²páÂü<55•N:¹tiÝ› dd¤Óséï¿ÿ~bbbؼy³©ß‹-ʲeËxæ™gøüóÏùí·ß8p  0íšÂ{(P€gŸ}Öžq&ÏÓo×x]`µZÙ¼y3?ÿü³R|ÕªUéÙ³'…òi9W«X±"ß|óCsî\âââhÖ¬U«V%!!5j(èÐ!Z¶lùÏwP_ /¼ Å_äjâĉ6¦¦§§Áš5kœ¾^\\7&22’ƒ:u®zõêî]»ˆˆˆp:7E‹eîܹ <˜   ·\SxÀÀ@"##íiú_ÞÚxUSüù奸ªU«òÜsÏQ°`A“3s¯–-[«¼~Aƒ r½s ¶« 8zô(¡¡¡ÿkf΄çŸW+þ<`YÛÖïL›67HKK£sçÎ,[¶Ì¡ëÄÅÅñÐCÆ®]»:GŽ{©S§²{÷n"""Ðlî%„ûä4µjÕR=¤0G×õ’¼¦°Z­|÷ÝwÊÅ¿Zµj>Yüs<úè£6›€ºuësãXnªT©Â÷ßO]ÅMç“’’ áÏɓՋÿý÷Kñ÷cš¦ñé§ŸòÒK/ÙŒÍÈÈ ""‚¥K—*ŸãÆ„„„ÆO?ýäLªòÎ]xÀÀ@"""ìiz³rš¯˜SüUåU¯^=zøÅ;³M›6Ѿ}{._¾|ãÏ-|æÌå9Æ‘À@éo¸vmHHG>Åjµ2dÈ&Ožl3¶`Á‚,X°€.]ºä³uëVÞ}÷Ý Q¥JÞ|óMì3¯ …ÈÊÊbÑ¢Eüú믪‡ÄÏyü«ÕJbb¢rñ¯Q£†ß0¦"ÅÆÆR²dI§ï\*V¬H||<õêÕË3.;Š­ZRüÅ š¦1iÒ$^}õU›±<ýôÓ,Y²ä?Û»wïÕ.-þåÊ•cܸq|˜àà`—¼òøóÏ?iݺõmZ†ó°³ø›¸-±ðNV«•×_I“&ÙŒ bþüùtëÖ}ûö¡ë:‹-rj¥K€2eÊðÊ+¯ðÆoP²dI§Î%„'°Z­,Y²Dy†œÇ>ÈÎÎ&..N¹øßwß}~uç«êÕ«»l¼C… X¿~= 4øÛŸwÇŽâ_³&ÄÇ+ÿììlbcc]¾’¡ðLš¦1qâD†j3633“ÈÈHZ·nÍý÷ßïô2×Å‹¿±¥µ®ëRü…ÏÐ4®]»þãwwn<²Zæÿ£G*ÅשS‡ððp<¶Ÿñ:9M@ëÖ­Ù»w/ݰ£øßwŸq篸|p\\o½õÖiVsçÎõÛFÎß|ðÁ0vìØ<ã²²²n»:ž=Š-JŸ>}xóÍ7©P¡`,¿+D~(X° )ƒÔsšMÓØ³gOž±÷[6;;›uëÖ‘””¤_·n]ºwï.ÅßåË—gýúõŒ}è!>LJBe6ò‘À@®OJM…âǰaÃþ6j;çînîܹ2ÿÙO¼ÿþûdffòÑG™rþ   zôèÁ›o¾IÅŠc# !ò›Y³Ô4M»1x6¯&À£{‹½zõèÖ­›•ÿé'&(n˜rh••EÚ3ϰ~ýú\nܸ‘wß}—ï¾ûî¶?Ïy¿;oÞxÛŸ{Ä€ëׯ³fÍåM:4hpã‡0‰ÅÿFñ?zÓŸåÌ$ˆ‹‹`ôèÑ·]>/+W®¤{÷î,^¼X¦fù¨«W¯2eÊ>øà.]ºäÔ¹4M£M›6 6LyQ+!|¦itîÜ™ üc‘¬|o®_¿ÎêÕ«9yò¤R|Æ éÔ©“3­]k…͆Ž!Àív¨þóÏ?y衇ÈÈÈpxÔöÚµkY¼x1Ï>û¬CÇ Ï”’’ÂôéÓùàƒ8sæŒÓç{ì±Ç1b„òèg!ü‰¦i´oßMÓØ¶mÛ?Ï×ÀÞâߨQ#:vì(ÅßLk×ÂSO)ÿãwþ·+þ9}„@÷îÝ;v¬ò>Âóedd0sæLF¥ü½·%ç—›!r§iíÚµ¸Ñä[`oñoܸ1:tâo¦uë K¥âŸ}×]¼^¾‰¦i‘ÁªU«”‹³fÍäÎßlß:€ÊÜèŠ×Õ«“––FãÆž‰Ñ¦M›ÿgï¾Ã¢ºò?Ž¿G1ö’Ä‚=šhLÔ$FcK,›%±gS$»éeR57â®ÉFÝ$«þ‚´X@c,¡+`£hT°*ؤ Âýý1%‰8—™3Ì\8¯çñ±9÷«âœÏœ{Ï98p€°°09ø×Š¢Ì£>Š›››Ùƒ¿aãc×üè£ðöö6ëZ’T×ét:ÆW»À0ø_¹rEUû'Ÿ|’±cÇZ¸ªz.6ž~ÔìˆÖ¾=DFrµ}{.\H÷îÝùú믩Tsð :”ÈÈHÂÂÂÿüó[g6˜£uëÖüíoãÏþsúš;w.:Ž¿ÿýïF_÷å—_RYYÉ;ï¼cV­’T×Xì!Àâââ þ£G–ƒ¿¥%%éïùmšŒ¬¨àˆ —éܹ3ßÿ='NTÕ¾¨¨ˆI“&eÂÕ꟢¢"“¼4ÇñãÇ™;w.?üð­SMÕ¬Y3<<}pwwÿöÙëÖ­cöìÙf Ìw’§§ç­5øæÉlooÏüùóÉÈÈ`åÊ•tèÐA`¥·Íœ9“¯¾úŠ 0|øpvî܉¿¿?=ôE®'Iu¸ëù_WùÀØÓO?-§ä,íða3rs·mÞ\¿ÃßcÝú¥K—.1fÌRRR~Ó´iÓ¦¼ñÆxxx¨þ$WVVÆóÏ?Ï–-[TµoÒ¤ [·nÅÕÕUUûº¦¸¸˜'Ÿ|RÕF:³gÏÆÇÇçÖzySåææ²bÅ ¾þúkÕÿ«c8ÌiñâŪ>}R¤f'J#.^¼È½÷Þkv?’diM›6ÅÉÉɪ5™(((`ëÖ­ªÞ4t:úÓŸäàoi¿ü¢ÿäoâàСC"##o­nÎ4®ƒƒ6là™gžQÕ¾¤¤„É“' Yb¦EŽŽŽ¬X±‚fÍšmÀÌ™3Mž (,,dÉ’%tïÞÏ?ÿܬÁ¿AƒLŸ>ÔÔTk}ê]þ’¤žÙ ??ŸmÛ¶©Jï†ÁÀ€æ^Vº›ãÇaìXÈÉ1Þöž{`×®? þíÛ·'<<OOONŸ>mÖ4®ƒƒL:UUû7n0mÚ4‚ƒƒMºžÖ=õÔSlß¾]U ¬q(**bÙ²etïÞOOOòóóÍ) ¤W¯^fõ%I’å™} ÀÑÑ‘ââbãÒéxæ™gèß¿Mê“jêøq5 .]2Þ¶iSؾjyùeEEsæÌaݺuªÚ×ô9‚êTVVš}p‘5ÄÅÅ1aÂUŸÌ§M›ÆÚµk±··¯¶MYY>>>,\¸‹/š]Ÿ‹‹ ‹/fРA&÷!ê€$iE¸ r⌭~ð ­õÁÀÎÎfÍš¥ª}YYÓ§OgëÖ­&]ϰ~}РAªÏ¢°%C‡eçÎÜsÏ=FÛnܸ‘3fP^^þ‡ß3¬&èÖ­îîîfþC‡%::š°°0³I’¬Ãâ‡t:Ï>û¬ü-íäIý'5oꎎVÜ~×ÎÎ___fÏž­ª}YYnnnª"„?®_ONNfĈ\RlÌ“O>IDD„ªç.6mÚÄÔ©So=½oXMзo_ÜÝÝ9þ¼Yµ<ñÄ„‡‡+·p–$ ³h°³³ÃÍÍ~ýúYò2’)ƒ¿ l»kgg‡sæÌQÕÞ°’`óæÍwm—••UíúõÔÔTF%dê»¶ 4ˆ°°0Zµje´mHHS§NeíÚµôíÛ777ÒÒÒ̺~¿~ý dïÞ½Œ3Ƭ¾$I²>³Ÿ¨ŽÓ§O§wïÞ&½^RéÔ)ý`þ»5âwäèÁÁúÛ6¤¢¢‚—^z ???UííííY¿~ý&ÌÎÎæ«¯¾bÙ²e”––ÞµÞ½{É}÷ÝgrÝÖ’””„«««ê¶ÌÕ·o_.\È´iÓTm»k ù €TßÔ‰gîDþµ$-MÿÉ_Íàߤ‰Mþ ÿzñööfÞ¼yªÚ———ãææÆÚµkýúõ… Ò½{w–,Ybtð8qâ£GþÃæ:Zðè£NëÖ­-z®]»²råJ~ùå¦OŸn±Á_’$ë>аaC^xá¹õ¦¥=«ÿäæŒñ¶MšÀ¶mú}lXee%/¿ü2>>>ªÚÛÙÙÝÚ5ÐÔµë½{÷&..Î⃩%$''ãêêJ®š½j sçÎ|üñǼôÒK4lhñÃ9 Õ?unÀÞÞž3fÈÁßÒj2ø7jAA6?øƒ~oooþò—¿¨j_QQÁæÍ›MüûõëÇ_|¡ÉÁà‘Gá?ÿùBúk׮ݭÜæÏŸ_kƒ¿$IÖ!ì¸aðïÚµ«¨.¥;ÉÌÔOû«ü`ãFPy,¯-Ðét|ûí·èt:¾ûî;‹\£6îi[Ú‘#Gøâ‹/ظq£YÇò´iÓ†>ø€·Þz‹&MšªP’$['$ØÛÛ3sæLœEt'U'+K?øŸ>m¼­aðWy¯-Ñétü÷¿ÿ½DqvvæÃ?äå—_6{ß|kIMMeÁ‚BþV­Zñæ›oòÞ{ï©Úc@’¤ºÅì ÿZbü32Œ·upÐOûOžlùº,D§Ó±lÙ2ÒÓÓÙ¹s§Y}Yãž¶hgΜañâÅüðÃBŽîÔ©{÷îåþûïP$IZdö3sçΕƒ¿¥;§üÓÓ·up€À@0sÛ\kªºq9ƒ]¸§••…»»;={ödÕªUBC¿3fÌ °°PH’$iÙïˆ;vQ‡TK—ÀÕUÝàoo6ÀŸþdùº,$<<œ¿ÿýï$''›ÕÏ3Ï<ÃÚµk5{OûÊ•+|ýõתö40Õž={˜0a‚ê‡$Iª[´w2J}rù²~ÝþñãÆÛÚÙŸ¨}:»víRußpÚ`AAÉ×”$I{d°EW®èÿ”ãm Ÿü56øïÛ·É“'óÔSOm‘k(ŠÂ›o¾Éÿû_‹ô/BQQK–,¡K—.xzz’ŸŸor_:ŽI“&‘œœL`` ®®®DEE©ºM'C€$Õ?2Øššþ¾¾0s¦åëäÈ‘#¸¹¹1dÈBBBLêÃÁÁG}TU[EQxë­·X¾|¹Iײ”7n°jÕ*ºw§'×®]3«?þÍÉ›={ödÏž=ªÔgôèÑf×"I’6È`K²³aÌ8vÌx[;;ðñY³,^–(üío#((Ȥ×ÛÛÛóꫯ’––Fbb"Ÿ~ú©ª×)ŠÂ;ï¼Ã²eËLº®Heee¬ZµŠnݺáîîÎåË—ÍêoèСÄÄÄVm(rvv&::ZÕ&]‰‰‰µzÐ$IÖ#€­0 þGokgkÖÀìÙ–¯K ;;;¶nÝÊäîO`¸§}ìØ1V­ZE§NøÇ?þÁgŸ}¦ªEQx÷Ýwùæ›oj\·åååøùùѧOÜÝÝÍ>„èÉ'Ÿ$""‚ØØX†n´}—.]ˆŠŠ’!@’¤[ÌYYY"ê¨ß®]ƒ àÈãm4oo˜3ÇòuY@£Fظq#STìS`¸§””D`` ={öüC›Ï?ÿœ ¨º¶!,^¼¸Æu›Ê°§Áƒ>ȼyóÈP³‘Ó]<öØclÛ¶¸¸8F×ðdÇ.]ºM·nÝŒ¶MJJÂÅÅEøAC’$Ù³€¿¿?gÔìK/ÝY^ž~b¢ñ¶:|÷Ìkùº,ÈÁÁ   þt—ý ªÞÓ~øá‡ïÚßÂ… ñòòR}ý>úˆþóŸªÛ›BQ‚ƒƒyôÑGqssãÔ©Sfõ÷àƒxëáISuîÜ™¨¨(£vµmۖ矞¦M›š|-I’l›Ù ¼¼œµk×Ê` SwwË×U  ä™ßí[ æžöxxx°dÉÕí?ùä-Z¤º}Mö4˜2e ‡6«¯x___>ÌôéÓ…^d=zôøÃïµnÝš žžŽ‡‡76ûz’$Ù&;`áÝ 2Ä誕••¤¤¤Ð¹sgZ´h!°¼:,?ÆŽ5kßu:øö[PyL®VØÙÙ1uêTŽ;F«V­ðññá‹/¾ K—.&õ7tèPš6mJXX˜ªöQQQØÙÙ1bÄ“®÷{±±±Ì™3‡E‹qñâE³úêÒ¥ ÿú׿X½z5<ò ˆ}\§yóæL:•àà`®^½Š““ï¾û.AAAŒ?žF ½ž1eee”——×ê5%Éš„åm*p×#Åî»ï>æÌ™£jKUy$°J†ÁÿÀãmu:øï᯵|]VRYY)t€[ºt)ûÛßT·ÿüóÏU?Lx'{÷îå“O>!22Òä> :vìÈ|Àk¯½V+ƒð¹sçX³f o¼ñ-[¶´øõªSXXHQQ‘Õ®/Iµ­iÓ¦899Yµ£3ׯ_'##ƒ|{{û»vf˜ ¸ÿþû­úfbÓòóaÜ8õƒÿŠðú떯ˊDLkWõä“OÒ¬Y3~þùgUí£££)--ÅÅÅ¥F×ùå—_xóÍ7yÿý÷9­æˆæ»hÛ¶-Ÿ}ö?þø#Æ «µƒ‹î¹çFŒaõ3ä €TßhbÀ &3 6dÆŒªž6®W ôƒÿ¾}ÆÛêt°l¼ù¦å몣þóŸÿðÞ{ï©nïáá¡êaÂcÇŽñù石qãFEÕŸjµnÝš7Þxƒ÷ß¿^È£¥€ â¹p!ÞÚeHgooorpv‰³óH³kPý1ãÂ… øúú2wî\ïÚöæÍ›¬]»777zõêev‘uBQLž¬nððò’ƒ¿™Þ}÷]t:ï½÷žªzÉ’%(ŠRíÄÇçË/¿díÚµfËëääÄ믿·~HóæÍÍêKª].Ä“°ÔÚeHõœˆ`ô@U………¤§§Ó·o_£·E!55•öíÛÓ¦M3ËÔ¸¢"˜8vïV×ÞË <<,[S=ñÄOСCBCCUµ‹‹£¸¸WW×[¿vöìY<<<˜?>‡2ëSÓ¦Myï½÷Ø´i“'O–OÙÿJK·ä €dm¢fj@†€+.†I“ &F]ûÅ‹ÁÓÓ²5Õ3ƒ âÞ{ïUâãã)**¢oß¾|úé§¼øâ‹8p€ÊÊJ“kpppàå—_fóæÍ<óÌ3V¿çnkd$õD“½¾tékÖ¬¡°°ÐhÛŠŠ ‚‚‚8®æLûºÆ0ø«=íîŸÿ”ƒ¿…ÌŸ?Ÿ•+Wª^m°téRºvíÊòå˹qã†É×µ··gþüùddd°r¶Œ}– IDATåJ:tè`r_’$I"™¼ö*;;®_¿n´m½ ÅÅú{þQQêÚ/Z}dÙšê¹W_}µF!àæÍ›&_Ëp~Ajj*+W®äþûï7¹/I’$K0kñuNN¾¾¾ªB€aOôÔÔTs.© %%0e ¨]þÅðñÇ–­Ià•W^aÕªUÂ7Ö10 ü)))ÝrW’$ÉZÌ~4%QsèVݸ¡ü#"ÔµÿÇ?à“O,[“ô/¿ü2«W¯ çÒ»wo¡}K’$‰&ä0'' Œ¶U…Í›7óË/¿ˆ¸´íiÔV×váBPy¦½$NYY7oÞäž{îÒŸ‹‹ $,,ŒGyDHŸ’$I–&l»±ÜÜ\|}}™7ožÑ7VEQزe ýû÷U‚íøòKýF>_~Y}›¿ÿTc+‰Q^^κuëX¸p¡Ù;÷þìE‹1räHó‹“$IRéÌ™h¢£Þµš• @ÈG¡ÜÜ\¼½½yñÅ dŠ¢=îU“þùOhÐ@ÿpßï}ðÔàä:É<•••lÚ´‰>úˆ´´4³ûk×®«W¯fÊ”)ª“$Iª™³gc8{ÖøÒrc 0¸*¤* //®]»f´­¢(lݺÕì#SmÖ_üqŠÿý÷áßÿ¶N=õŒ¢(Ñ·o_ÜÜÜ„ þW®\aÛ¶mfí I’dm €DÀ+‡€C‡‰º¼mùÇ?nOõ¿÷,•[ˆÖ†ððpˆ››'NœÞÿ?üÀ«¯¾*C€$Išex0 Á! ??®^5Þ¥!$$$ˆº¼mY¸v¾²v%u^xx8=ö®®®$''[ôZÞÞÞÌž=Ûìs$I’¬¡ê*€$ÀÁ!À××WU åàÁƒ¢.o[ƳvuZ\\£GÆÕÕÕ쯡6mÚ`gg§ªíºuë˜={¶Y›I’$YÃï—&ããs÷*Õ4lß¾ÄÄDQ——ê¸ýû÷3yòd† F”Ú]«Ñ®];¼¼¼ÈÊÊbëÖ­4jÔHÕëÖ¯_/C€$IšqýúuBCCï¸@0Èu±üü|¼½½ÉÎÎVÕ>$$„ˆº¼T=z777† BHHˆY}µiÓ///Μ9ƒ‡‡7fâĉlÚ´Iuذa³fÍ’!@’$›U\\Lxx8Ë—/'!!¡Ú€’Ñß ñõõUvìØÁþýûE]^ª#RSS™;w.?ü0AAAfÍÛ¬Y3<<²700™3gÊ I’M)))!::šåË—wë=ên;ÂB!àÊ•+ªÚïܹ“}ûö‰º¼¤agΜÁÝÝ~ýúáïïoÖÓ÷NNNxxxpöìY¼¼¼îºqÕ„ øé§ŸT‡€   f̘¡™£m%Iª»ÊÊʈ‹‹cùòåÄÄÄüádSŠ>a@QE5mÚ”yóæÑ®];UíÇŒðaÃD]^Ò¬¬,-Z„···ÙŸ¬yå•Wøè£hß¾}^»sçNž}öYJKKUµî¹çX·nööö¦”ZïRTTdí2TIHXJB‚¸å¼rCPÉZÔœ`˜ ÈuÑ¢¢"|}}¹|ù²ªöìÙ³GÔå% ÈÎÎÆÓÓ“^½z±jÕ*³æÏŸÏ©S§X¶lY€ñãdzeË–?Ü&¨Î¦M›xöÙgÿ¸%I’l…ÚÀcàçç§:DFF²{÷nQ——Œ¨¨¨°Ê’ÌÜÜ\<==qvvfÉ’%ª?q߉½½=sæÌ!55••+Wrß}÷™UÛ¸qãjBCCyî¹çd$É&Õä4ÀÃÀpà’¨‹áããÃ… TµŠŠ’!ÀÂE!88˜òøãóÍ7ßÔÊu¯_¿Î’%KèÞ½;K–,¡¸¸Øä¾4hÀôéÓ9vì~~~tëÖMXcÇŽeÇŽ899©jZ£[w¢(ŠEv3”$©~«éqÀ©èÏJJJð÷÷¯Qˆ‰1~‚Tsááá 4ˆ)S¦pøðaEáÝwßeñâÅ»fQQK–,¡K—.xzz’ŸŸor_:ŽI“&‘””D`` ={öXém#FŒ 44TuرcS§N5)„‡‡óøãóàƒâëë[ã×K’$U§¦ô!`pQT%%%pñ¢º.£££e(66–#FàêêJRRÒ~ÿ£>âË»ml‚²²2V­ZE=ðôôTunÄݸ¸¸pðàA‚ƒƒkåtÉádz}ûö…€šÌü~gÃŠŠ ^zé%|||̨Z’$é6SÀqô3ÂB@qq1¾¾¾œ?^UûèèhÂÃÃE]¾ÞÚµkÇ7zkåã?æ_ÿú—Ù×+//gÕªUtíÚwww.]2o2ièСÄÄÄÆÀÍ®¯&žzê)vìØA³fÍTµß¹s'Ï<ó %%%Õ¶¹ÛΆ•••¼ôÒK|ÿý÷fÕ-I’¦ЇW@ÝS|*”––âïïϹsçTµ‹‹“!ÀLãÆcõêÕ4h`üKÁÃÃ/¾øÂ¤ëTVVDŸ>}pwwW}˧:C† !""‚ØØX†nV_æ6lXBÀ®]»îÔîl¨( ¯¿þ:ß}÷YuK’$©;ñ¤zÙ@00P÷hÄÍ›7IIIÁÙÙù®´deeQ^^N÷îÝE\¾^zôÑGéÔ©!!!FwÖ‹ŠŠ¢AƒŒ1BUß•••lܸ‘çž{ŽÿýïfOõ÷ïߟ+Vðõ×_ÓµkW³ú¥sçÎŒ1‚7ªzâ?==ØØX¦M›Fzz:ï¿ÿ>ýë_9vì˜êkîØ±ƒ6mÚðØc™SºÍ(++ÓÌæI.ÄsáB¼°þFŽÖ•$Õˆš€Ôè Dæ­³ª¢Q£FÌž=›N:©j?dÈÆŽ+êòõÒš5kxå•WTí²·páBÜeEQ á³Ï>ãСCf×öàƒ²`Á¦M›†N'êËV¬øøx&L˜@AAªöíÚµ#''Çä] íì숯!@n$IµÏœ[U@ÿL€yóºUܸqΜ9£ªýÞ½{ùùçŸE]¾^úóŸÿL@@ 64ÚváÂ…xzzÞñ÷ÂÃÃÝf€'Ÿ|’ÈÈHZ¶l©ªý•+WLü «êÄà/I’uˆ  £ÊÊÊX»v-§OŸVÕ~ïÞ½ìڵˬbê»3fàïï¯*,Y²[?eäÈ‘¸ººš}¤s—.]X¹r%GŽaîܹØÙ™{·ªv 8°°0Zµje‘þ«®v0`€E®!IRý`ü]¾fN¢‘Àý":4„€™3gªºç»oß>ÊËË™8q¢MZ´e/¼ð:NÕ÷ÿú׿8þ<—.]"""ÂìkwìØ‘>ø€×^{MõQ¼¶Æ\]]¹zõª>‡Ê?ÿùOÕÏ^H’$c‰U¹Ü~0ÐøS|*TVV’’’BÇŽUM¯^¼x‘ÂÂBzöì)C€‰zè!xà¶lÙbtšúÈ‘#ªgiªÓ¦M>ûì36l˜ª[æääDNN0«Ÿ!C†àããâE‹pvvSœ ’JRíy  ªSègÔ-êW¡¼¼œuëÖ‘‘‘¡ª}bb¢ª§Ú¥ê¹¹¹±víZ‹žhתU+,X@zz:ª÷Ù·UUw6\¾|¹É_ýû÷'00øøxÆŒ#¸JI’$ñ·ª2„€H £ˆ !à…^Pµìϰ«Ý¤I“äL€‰ ÞÍœ9Sè'4'''^ýu<==iÑ¢…°~­¥¬¬ ,X`öæFݺu#22’Ö­[ ªNª‹tŸ[»Éš«G,5``êvöQÁNž<©ª}RRÁÁÁr&À =ö#ÍS6mÚ”·Þz‹ôôt¼¼¼4?ø‹ÞÙ ##ƒ±cÇ {~@’$éN,Ò€aÀQÞ¼y“ 6¨>!-99™mÛ¶ÉPCçÎãí·ß¦W¯^„……™Õ—ƒƒóçÏçÔ©S,[¶ŒvíÚ ªÒ:Dïlø{III¸ºº’››+´_I’$ƒÚg‘€yOŠUQQQA`` êpèÐ!~úé'“7]©Orrrðôô¤W¯^,_¾Ü¬óìííí™3gÇgåÊ•Ü{ï½+­}U~777ÒÓÓ-v-$I²¤Ú  £°@8~ü¸ªöGeóæÍ2TãêÕ«,\¸îÝ»³dÉ’»Z£ÖÔ©Sñññ±™m{ͱeËú÷ï›››ê[P¿×®];>üðCÕA(99rrrLºž$Ùœ6À½&|³÷-ýæ(¨ÏVXíÏYÛk­ 3Ñ€¡¢¢‚   ¦OŸÎ<`´ýÑ£GQ…©S§ª:§>(,,äÛo¿ÅËË‹¼¼<¡}oذfÍš±råJÍÿ}7lØ´´4“^ÛªU+Þ|óMÞ{ï=î¹çæÍ›ÇèÑ£UÝ:8tè...„‡‡Ó¦M“®/I6c*¦ tÖ|è±àô¯òk‰@õçv©ã¸U~­ÿœÖxGÎDÔ­çSÁRSSUµ?vì›6mª÷3ÅÅÅ,[¶Œ=zàéé)|ð7ø¿ÿû?æÏŸ¯ù¿ïI“&±iÓ¦mPää䄇‡ééé,\¸ðÖW½{÷&**ŠûïW·_ÖáÇqqq!;;Û¤Ú%I2Aàqà ~;ø‹2ŒßþµÌZÉ2Ñߎ9¢ª}JJJ½ eee¬ZµŠ=zðÎ;ïpù²y':«ùdÿÃ?ðꫯjþï{âĉüôÓO4nÜø®íyë­·HKK«vµC¯^½jFŒ!d¥$YM¢â[ÕUÇÖØ#Êx ei'`ú­kÎÉB€°§¨*++Ù¼y3¿üò‹ªö)))lܸQóƒ’ZåååøùùñÀàîîÎÅ‹ÍêoèСDFFIÓ¦M¶÷ööföìÙTTT˜u]k{úé§« †Õiii,[¶ŒöíÛßµ¯ž={EÇŽê¶ÊHMMeÔ¨QfÿÛI’Õ„AF¾ªî?Z‹õÝLæmý58Œ~Ôe8¿ý3ZµoÊZ$lÙ²EuHMMeýúõš”îÆðäzß¾}™7ožÙÛö>þøãlÛ¶ØØXFň#ؾ};NNNF_»nÝ:Ug غ &°yóæ[!ÀœÕ={ödÏž=ª”<~ü8£F¾ôP’lB`r•ŸïG?øÖ–ñ@ß*?¿x[Q'V7Ô—¬²°P8|XÝWÍ©S§Ø°aC iii¼ùæ›&?ÀfðÈ#̾}û˜>>¬X±ww÷zó@¬dczC«ü|b¸«‰2 öÝxè×—±¼– ¶.¡Ï‚ÂB@HHTÕ6==½Î†€»-=kÛ¶-^^^œªÚß-¨Ýæ¹®ì× i„ú‡þ {k]‚­WŽEµãöê‚2 ÞŠµüÊVX(lß¾]u8{ö,?þø#ee–œ²gggÂÃÃY¼x1§OŸÆÃÃGGQ›[ß6pà@ÂÂÂhÕª 6dΜ9¤¦¦²råJ“J¬O:tè@dd$}ûö5Þý×ìÈ‘#ÉÈÐï±UXXÈ’%KèÞ½;Ÿþ9Æo8z{{Ë ÕŽ?q{­}9ú¥vuï3—ÞhnÏr슭X˯jû,€šºŒþ¯-’ß®Ì4ËöíÛQ…ÇÜh[C˜5kVܳѺw§§Å¯3pà@"""prrR=¥-ÝfcÆŒáØ±cFÛgff2räHæÍ›ÇêÕ«MÚéÑÛÛ›’’üýýkü ˆ$©Võ]Ýý¾ø•è?þ¥¢Ÿ&¯ Ÿ¿îzýúãR`Ÿk©Â–g !Àø;_ ìØ±ƒ}ûÔý+dffÖÙ™€Ú2`À9ø›¡}ûöDDDðàƒªjŸ••Å¢E‹LÞæ¹OŸ>Œ?Ng¼±$‰Ô¸üýiyZWõÓ<ú`´ÀB!`çÎ5 2HVÓ¾}{"##y衇Œ76‘)K?%Éd«|ËF¿ùNU-€¸½iŽuâöòÆbô{ Ø-ýツ>ÙéÎ;Ù³gª¶YYYüæÉiIªMíÚµ#""‚~ýú í×Ü¥Ÿ’d’UU¾}ü ø–ß>ùÕûå^»FWùq6uKCKô!` ‚C@DD»wïVÕ6++ ???JKmdGªwÚµkGxx8]ºt1»/‘K?%Iˆ`#úy_uw¾lOWô§ ‚~gCu+ÑkÖÜêÎýU)22Ru¸pá~~~Õ.¥’$K g„ œ={Öä>,µôS’„PøíÇãÆS}H–$™Åý†9ƒ€GМSõöÀE`‹êª'êr Í$$$Ôh&ÀÇLJ‚‚‘%Hu\Ïž=Ù³gÎÎÎôë×ÀÀ@âãã3fLûrtt$88Xõkóóó?~¼ ’eœD¿ÁÍô[þÞI1¬áIÂԗþ›»€ÇEv:pà@&Mš¤êÌô-Z0oÞÐ?Wú4#²Ó£GªøøøpõêU‘%H’j2kÖ,þýïsæÌ<<„‰ì4==€€ÊÊÊŒ¶•!@’$IMuJÐ?*²Ó³gÏòã?ª 7nÜÀßߟsçΉ,A’$Iª§dPïðú³„1„€7n/àÆ d$I’Ì&@ÍܦaåàççÇ™3gD– I’$Õ32Ôœa& Xd§™™™ªC@yy9k×®•!@’$I2™ ¦)C? <Ô(œ>}Zd ’$IR=!€é !`›ÈN³²²ðõõ¥¤¤ÄhÛòòrÖ­['C€$I’Tc2˜§ ˜ŽàpáÂüýýk222D– I’$Õq ­]@`ÀŸDuzáÂüüü˜;w.Mš4¹k[C˜1cݺuU‚$IuÄ íÉÖ­pâDkÒÒZ‘—טvíŠèС.1eÊ ÆŽMÇÑÑøeµMËõÛríºZ½ZÝælžÙé½÷ÞËœ9sptt4ÚÖÎÎ777zõê%²I²¸ÂÂBŠŠŠ¬]†* KIHX*¬¿ „uõ%%ö,Y2”eËž /¯±Ñö-Z”âáË[oí·‰TËõk¡vIJHèСsçΕ!@ª³d/&Æ™_|†3gZÔøµ;ç³qc ƒ[o÷Q-ׯ•Úí,~…ú¥ø xè#ªÓÂÂBÒÓÓéÛ·/öööwm«( ©©©´oßž6mÚˆ*A’,ª¬¬LÕÙ¶àÂ…x.\ˆÖßȑºº%(èA¦N}žÜ\ãî$?¿1ýéÞý=tEpuÆi¹~-Õ.¯xØ,²ÓK—.±fÍ ¶­¨¨ ((ˆ'Nˆ,A’$ ض­7/¼07Ì{Ä«¤Äž9s¦Ö]Peêh¹~­Õ.€eBÀO";ÍÎÎÆ×ח뛣N IDATׯmkÇY‚$I6,=½óæ=Ke¥˜»»7o6àùç§‘‘ÑRHÆh¹~-Ö.€å”nÀ:‘šRSSE– I’rwŸ¤ê³š¸v­ |0VhŸÕÑrýZ¬]˪ækEvš““£:TVVÄ‘#GD– I’‰‹ëLD„e–oÞÜ‡ØØÎéÛ@Ëõkµv,¯˜‹B€ª ( ›7o–!@’ê°¯¾bÑþW­hÑþµ\¿Vk— vBÀ";ÍÍÍÅÇLJ‚‚£m !à—_~Y‚$I6 ¼ÜÎbŸ@ ‚ƒ{SVf™…cZ®_˵ËP{*€y@€ÈNsssñõõU¶lÙ"C€$Õ1ûöu¤  ‘E¯‘—ט¤¤{-Ò·–ë×rí2Ô® àE,¼½½¹víšÑ¶†pøða‘%H’dEééµó”~ffs‹ô«åúµ\» µÏüEvš——‡¯¯¯ê°uëV:$²I’¬DôÓçÕÉʲLÐrýZ®]ë¨þŒB€OB@BB‚È$I²‚ÒÒÚ9×­aÃJ‹ô«åúµ\» Öc~";ÍÏÏÇÇLJ«W¯ªjÊÁƒE– Iuš¢(Ö.á:v4þ ÷Þk|Õ‘)´\¿–k—Àº*€—_‘æççãëë«:lß¾]†IRáìÙ³6ùm·nÆgýDèÜ9ß"ýj¹~-×.€õY,Ôd&`ûöí8p@d ’Tgœ={–€€‚‚‚lòÔÂ.áäTfÑk´lY A,Ò·–ë×rí2؆Jô!ÀGd§x{{“­ªýŽ;d¤*Ο?O`` AAA\ºtÉÚåTËѱœ)S,{ø×øñi{@Ëõk¹vl‡!üOd§………øúúÖ(ìß¿_d ’¤9/^dóæÍ¬[·ŽÌÌLk—£ÊË/'Y¬oNáí·-û¾ åúµZ» ¶Eþ |/²SC¸rEÝÙÒ;wîdß¾}"K$MÈÉÉ!88˜ü‘ôôtk—S#£GŸfòdË|2å?~Î"}h¹~­Ön™}%smÚƒEuXVVFJJ ={ö¤iÓ¦FÛ§§§cggG—.]D• IÕ*++£¼¼Üj×ÏÍÍ%""‚ˆˆrssïÚÖÎ. ;»,a×9RXW tŸ”•‰[šÖºu1›6Ò²e©°>«£åúµX» ¶k;Ð! ¼¼œ””zôè“““Ñö§OŸ–!@ªÖ ùùùìÙ³‡]»v‘““£ê5¶Z·.á‘G.±aÃCBÎ¥oÐ@aãÆ >/ :ã´\¿k¿{•Šò(ÐÝbWÿ­ƒètgjéZÕS”Ñ@k õþ:]E Úë€ÿ¢¿- LÓ¦M™;w.íÛ·WÕ~Ô¨Q >\d ’ô………µút}AAû÷ïçÈ‘#TVÖìá*‡xâ…Õ²`°®n èÏ+¯LáÆ Ó?::–ãë»™iÓRV¦Ž–ë×RíÆÀwÀ_,ZÁm1èt#kéZÕS”xÀRg;:¢Ó•Ôð5:`ðºÈBš4iœ9s¸ï¾ûTµ9r$#FŒY‚$ÝR[ ¸¸˜„„’’’¸yó¦I}h!^ÿ” ’-¨¨¨àرcÄÇÇSXXhr?999ìÝ»—',»µ«$Ù[ Ÿ£(kÍœ.¯Ëà~;#`¶ÒÒRüüü˜9s&ÎÎÎFÛÇÇÇ£( cÇŽU‚$ÕHee%©©©ìÝ»—¼¼<“ûÉÍÍ%>>^üR½b«à~ôÏ|míBl˜¼Ëí0 DYYk×®UöîÝ‹¢(Œ7NT ’d”¢(œ:uŠ={öpíšéDZ°oß>Ž=Zãý$Iël5|ˆ¢ü:]µ ±a†P xŠêÔf̘A×®]¶ß·o7oÞäé§ŸF§3,IªŽ¢(ddd«ú€«;¹~ý:{÷î•¿T¯Ùrh¼Ègdû}øPT‡UgÔ„€„„Eaâĉ2HqöìYvïÞÍåË—M¸˜ÄÄDMÞ @’ê [ï¡(ߡәþ?¾þø}øHT‡ååå·fºuëf´}bb"Š¢0iÒ$$aΞ=Kll,/^4¹’’’[;ZóÐ!I²%¶œÐªv»Žûø×ï…†€uëÖ©IIús±eÌuáÂbccÉÌÌ4¹ÒÒR’’’HHH ¬¬L`u’¤}¶þ‚¢,G§Ë°v!ñ1ú™€5TË^xáºw7~6TRRŠ¢0yòd¤±_Ô€’T—i!8Ÿ/Z¹-ù}øDT‡†àææF¯^½Œ¶ONN!@RMÄü›7oòË/¿°ÿþZ=]P’´H `Šòt:mœÂa>ýõ{a!àæÍ›lذ777z÷îm´}rr2åååL:U†©Z999„……‘œœŒ¢˜v Hee%G5{# IªO´ g­\‡Ö|Š~&àSc Õª¨¨ 00Pu8zô(Ï>û, ØÒá“’µåçç³gÏ’’’¸qã†Iƒee%Ç'..Žüü| T)Iu—VÀ3(Ê“ètââ®>C>Õ¡!LŸ>xÀhû£G¢( S§N•!@¢  €øøx¨¨¨0¹Ÿ'NkÖF@’TŸi)xí]„öR‚‚‚˜6m}úô1Úþرc2ÔcÅÅÅÄÇdzÿ~³Öàgdd°gϳ6’$I{à)e:Ý.k¢A ÐÏÛX©¢¢‚7Ö((ŠÂsÏ='C@=RRRB\\0k ~ff&111fm$IÒmZ KP”0t:¹gÍ-JÐϤa˜ xöÙgéׯŸÑö)))2Ôeee,Ùihh(€ªžž.C€ÊÈÈ <<ܬ¥xEEEìÝ»—}ûöÉ¿–ݸÑÐОlÝú'N´&-­yyi×®ˆ 0àS¦œ`ìØtmïÙj-×o˵ßý„EùøKí”b² ':Ýy!½)J<0DH_äˆNWb¡¾EyøJt§O?ý4=ö˜ª¶]ºtaæÌ™888ˆ.Cª¡ÌÌL"##9{ö¬É}TÝМ€lÅÈ‘úo¢,¶5ו”سdÉP–-{‚¼¼ÆFÛ·hQЇG,o½µß&R-ׯ…ÚëBøî !=É6:wî̬Y³d°’sçÎÉéÓ§MîãÆKO¯§ô33›[¤_-ׯåÚ­ À@§Ûƒ¢ìÆ êqŠ„N'w’±ŒÕèŸX‰À ‹¢(¸ººmksçÎÅÑÑQT šdXƒmÖ2¼Ë—/³{÷nŽ;&°:R/ ÁÁQBøÓçÕÉʲLÐrýZ®Ýv€žú{"gàà;}IwöèCÀ*†€¸¸8U!àòåˬY³†yóæáää$ªͨ¬¬äÈ‘#DGG“——gr?W®\!&&ÆÿYàKà@üÍc €ÒÒÚy+oØÐ2ÙMËõk¹vÛ :Ýa%x^P Pt:A ”¥;øá×ï…‡EQ;ÖøØœœ|}}ëUP…ÔÔT"""¸zÕôÓ°¯]»Fll,ÉÉÉTV }ƒÉBžÄÿ¹ƒ…uìXP+×¹÷^˼•j¹~-×n[@ïS`*úí}ÍÕxý'Ér~@?°! >>EQ7Îø]¡ú ¿¹kðóóóÙ½{·%þlôÿ2@PKºu»V+×éÜ9ß"ýj¹~-×n{@§;…¢¬æ êñï(ÊÿÐéLÿ˜$©áýë÷BCÀÞ½{;v,:ÝÝWæääàããüyóhÖ¬™¨lFFFaaa\ºtÉä>ªntóæMÕ‘ üXÈ'3kÙ€—pr*£°Ðrgf´lY A—Ú®_˵ÛÒ*€ª>GÜ›Hsàï‚ú’îÎýsB?RîÝ»—ÐÐPUÛÕæææâëë+n[Z‘‘ÁêÕ«ñ÷÷7yð¯ºо}ûDþ×%@÷_¿—ƒ¿8:–3eÊ ‹^cüø4‹= åúµ\»mîð_=¾¢tØŸT½5èOeúÀWBB!!!ªC€æC€aûc“×à—””Ͳeˈ¥¼¼\TyEèü.è—ðZfnXRíå—“,Ö·N§ðöÛêŽò6•–ë×jí¶ô¢¦í£ßmLªë°@HLLT®^½Š···YOÆ[˹sçX·nYkðËÊʈeÙ²eDGG‹a¶:=GÐÿåW·Ga^^±±±·þ,¦0ìCAë‘›4Q£ôÇð>ô´o¯pÿýytìx…Æ;KÑÿñ÷Âÿ·wæñQÙÿ!lQ‰,² ŠKXŸ8²QGx*.£ê<7FÔÇsD3Ž:ê8Žu‘EADAYB "2DFQBÈ a Ôû£:’¾÷öR·»o§¾ŸO4ÜêS§;®s«Îù–"DèrƒnS³&ôê=zÀÅC³fp晘%%ðË/› ÙÙ‘;tÝcÄ×^»‰ñãg3lØ;úŸ\½z%L˜ð ©©9½sÆËþ{Í÷Øã€?¢²ŒÃE/©lÅ.R¶@é܃ÒB°ãÔ{!åZT°5!ªîKù.j]óÇßbºÅµé(€©ü™«[²²¬½»í6ÈñóGЬkæ‡{磻Iëçû¨URrR' à`)é{„úgXø p'0¨…Ú•ÈÊÊ «_JɺuëN Õ¨«W[?áw¿ƒ~¨úï))ðøã0p œ.§,€³}Êó v½ŽÙ!½7hÕ FŽ„¡C¡aCëq]*´V-+SŸ¿ü>û B Äb;îøž .ØÇ-· IC¾M›¦M›I÷îÑ Ž¼ì¿—|ý@ˆ¤|u©ƒk‘òj„ˆ¿dRÖB%;ŽÄúÆÓŽÎ(mÿÑHù?Q¹YË€Ucj§@ã#ßOjÔ8ý ¹2•5þëÖ…§ŸV‹V­ZšÓ.9up÷ÝwÓ Aƒ*cv£öº§£ZSêØÈ; |î{4—’[ׯ'ù“O( 1¿|áÏÈÈ`ïÞ½§.aÿ>&%þó9ç@z:Üzk(nÔFí EÊ)Àc±'CZ¨Sž}V-þ‰Aê‡Õ¨W]¥YYðûßû8=H·n;X·îMÆŽíΫ¯^ξ}Î_ ÉÉÅŒµœ#VR»¶Ö“» ñ²ÿ^ñÝ^YEÊ·€?¸4÷åñu@#UkßlàRMs¯z DÕp_ʨNenP!Üéa+eÔúe³ ÍÀ„(õÍñ%p¥ÅØGbl6S(’’À®yÍ¥—Âwß©ÿo×æÎ…öíó¾=W®¤ÿB•LsÖYgU ×±úVyyÜý7j~v·#IJ0l¼üW\Ë—û%¥Z´ËiÓæÌ / cê Â!°h‘åÞ½ÕCÏF 3éÈ‘Z,ZÔ– Îç›oZ’Ÿ_½{ëÑ ÁQÎ=÷:å3hÐOôí»9ê ¿?¼ì,ûû;B”!åhôµíŽêEþ©&{ÑEÊK€ù€î†ÑÍ‘rÈÉ |f nȧÌç¯kWX°À~k×YAEðàÁƒŒ?ž»îº‹Æ¾Eð‘ëT“תï ÎÐÉ“i€°ÏæÍ›Y²d ;tœU÷ë³g«}4 å1S§a[RR`þ|µ›¡‹äduš Ë–é³e’’ŽsÓMë¹é¦õÑv%$¼ì,ûëU§b.°L£Å—ÒR¶¢ñ/çfàŸšmÎnƒwð[·Vwþ!.þ "ŽŠ>|˜ &ŸŸ²Íp8œ”ÄÄ»îbŸÍkÊËËãƒ>`âĉzÿ /„>Ò½ø—S˜†”7ºa¼ çŸóæé]üË©SG½O-Zè·m0Ä^[G6cAѸ˜¨É^ä‘ò `*ù܉`.°UZ¹uÔh:ö€’N®Ìp¤\ªÃå ”ß)NÁ®ñSb"Ìšv‰~ûöÁO?A~>äçsöÙgÓ䢋ØÛ¸1û6D qÚ@9GŽ9™è´ž\ \‚ÊF­$ûÇQù¥¥,Ý¿ŸÕB°Ë7¯GëÖeêm·qÿ;ïX!'`ûöídee±aƒFa‘ºuaÚ´ãÔ¯o%Xþ*Uá'Ô–þ>Ôg£*7äF”€ Àd¤ì‰Áö>õùjÛ¶%*oÒ?M›þ¯¿¾‡Fª&r””œ`ÆêŸût~‹Zù:b½]V^Š·;3“.‡Ñ(HNæÛ.]XÝ¥ Gmî¸÷6lHFïÞô[´ˆÝ»wóå—_òãÁ®0iR-[¶óseðB|iû|)n@5üñg§œ3)HÙ=È¿«Å¾LœxV€’;Ïü-þ+IL\LçÎÖŸu% >Õ·Âzô²ËÚ!å‚ÊïÍE‘† q€7’+"egà?è;¾x!ÆT°ï$@)ûÖ™JН€!¾Þ ÁØn| t âY&Vž+ ®¦üÃáÑGÕ¿ íÛ·gÈ!Ô¬éçæ¦¤0é†H†£Dì(++cíÚµdffRPà_¬ãðg0wÀÖw°¡L(-å¼ÔT6Ú$ž9â”蟿£ƒÊï²ðêÇŽ¿ Ä3Á:ä›ã À" Ð/¨î¡ûM쵞çjT^Q’ͨÏb`ÅHK# ¢b‘H4üá€r„X‹J ÓÅÓHé­Þ±ª*âu‡QË€~A/þBä×îvÿ…—_†;îp\ü6nÜÈôéÓê|Wcÿ~df²zÏžÇ~ñ//Å{óÍ7™={¶åâpÆáÃÜ:}:=W®´SšÀÆ#st^QñTÐÉB¡Jßwù8R:ÅP:Ø\‰3ƒZü_)ð ØW|@J †èã½@ñ4êèUšlEŠ›»º§íÀo}_Ö¡!ÄAß<ÑÉ’óÇ /À¨QA=%'''   Í–-t[¶Œ™ãÇ[vÞ“R²qãFÞyçf̘¡x¤ßÂ…\¼v­õ€Ûo‡Úµ¶&âåŸ-Dðj‡ÉŠºÀÿ†²¹,ãQ‰bÑ£´TIÙÆ}’M›61uêTJPà+vìØq²oÒ¤Iþx ¨¨ˆÅ‹3îùç9‘žn=°OŸ`M^ÎãØ±@€g´‡€ïÎû-›õ€¤à „Ðs(Ä^”ކ)Zæ1b ïBìl¾MƒæA_ò[¬s öÉ›N¹Á¡¶{õÚ –… áûïÃ6“››Ë´iÓÞÿ}ÆÏÖ­[CšïèÑ£,Y²„×_åË—«y?ûÌú ½N,?ŒAU$ŽBU!Â.To <½žƒS²`¨¼¦ÙÞ,›k"eÄÎg †HáÝ@ñ  çnê ¶c¾6× P¢@ºù%–ÞwÊ7 œÜÜÜ€wBmÔsìØ1233IOO'++‹ãÇ+ì.ÿûßPd‘šÑ©“Êæ·æ8jo<ŠÒr†é¡WkTˆ|ì«Qz eh-­É¾Ðls͵Dà|Íó QÇÛ€PA€.îZk´§¥\h·ýÿ±+š*™0:²É¥¥ÅÌ™Sµ3alÞ¼™)S¦CII _}õééédddP\ìÇí²2°Ê!¨SG©ú1ZøÛ¢ÎÝC;‹€i!>Ï »F] X÷•¥Agü;³û<ÝAŒÁu¼(ÒQYï:¨‰{’º:8ûšåàuÇMÛÖ$$¬æøñA€Ö àçŸfÒ¤I;~¼TZZJvv6cÆŒaÑ¢EYÝá—c'?ܼyÅŸÊP½:¡þpô€à^Y§Ó®SwÍó£BöÚŒ8KûœC”ñ– ?„(FÊç·£íJpjyþA¹5ÿqѶÙ¨f}7³QG5ZÈËËcÊ”) :”Zµ¬rO§¸vmö4iÂÞF8R§y……lÝ·ã­[ÃÖ굧Ѷ­õ5¥m/QRÉ£Qw¦:øÎ…»f…û‘rð+‹šZõĭϹÝ1WðÝ †Çû€â=T-¿µÜZ|`—¤x¥çîߣîH#½kTþš¢ê±?Ec°uëV&OžÌСC©í§ÿpR:t çüóÙÕ¬…õ]^Zµú%ƒkw& n‡ßa8ÉU‹µòRx´¹æ-±0ƒ!â៚ٟ£íFhnsmBhÝ&? !cÿé%ÿ¾@zä”}äåå1yòäÓŽ~iÞœ† á=Æœë¯g}‡î/þ¯½6ý‹?¨&?nbg_÷±š³ dhØ%HÚfg ^$>ÅtàÛh;á2v‰H‘ÈÒ?9*S9èp%ضm&L`¿̺ùfÆ ƺŽ)­ñ?ëΈáh© ö“‘R×® KáÒ`0œ$~u¾ù§h»á2v_¢‘¸;Æ€¿9©è‚à—&Mxó¾ûø¾sgÛÅz·wNöí’W CˆŸ@ˆ@F´Ýp»L5­‹¡ÁuíÓƒUiV&pº|JIeË(mÚT‹¹Äí"§@[Þ†Á`ÐC¼$Vdª/xÜÝÂaF‰/Øz˜#¾Ÿg„l¥Q#˜3Î  Ò«¨H‰ù¬X7ÂŽ°};ìÚ¥®‚ô›l¿Hf"eözn\׿àq2gèCŒ€«ò3ⳃ—]’_$ê”c±úKÔNÀ8ÔÝlÔÙy¼Qì';öï·ûR6 k6)/B©Æ’ Õ«HyCX¤üÁnª‚!B¸yZÎÒ¥n’xÛ¯ú^}ÅǨNÞGˆ(Å;;nÖ å@¤t.H•²RÞ‚*ÛJ­tõðs(®Æ Ù@*¥¥ó)*Zf3®!0'¤ @ÊËQšñîgOGM`:R†v°(å0à#ÄŠìB"7×}…é­[Ýkcáeÿ½ê{õ „Àèh»¡‘{€]cÎCÝͯGÊò¤LAÊfHÙ)» åHùê¼{à¯@~°]«÷Ñep-[þÙa\7 ){lYʆHùwTù[ÃJW„ÔÊsÖæ#åË8Ržƒ”PUvßû€‘!yi™ÂB÷;‚oßî^K /ûïUßã¹€„XŒ”KÝÙБGˆ=¾­Ü œà´ž q¦·PelVÈmG!–!åbÀ®r¢°)3QIm_›|G1åÉ’ÍQ"?~¨Ö#;ÀõAõ0Õ’¸â·HJÓ`8RN>GåÉìFˆã¾PÍQ} ¢tê9Ì#á}!öjFq±û_ç5k–¹fÛËþ{Õ÷êµpŠQxuÁªŒ«Q_ÎnI¯îB§OŸDq¬óêÎ܉«Pb@?ÇòR¡Ê ×£ZÿÄzñŸˆÑêO± ¥càïs6ð°µSp ) Q} rO{q^üÒâ-‚¢eKÿzW:iÚÔ½¦Ž^öß«¾WÏ@-š³¢í†6„X \}e@(| ôEˆ"ßÏI6c­Z߯>B¬EeübŸõb_™¹À° íëEˆiÀ³ŽåÀ1!â©ÜÖS´m[à<(LZµ:àšm/ûïUß«g x 8m'´!D6ªà¿Uæ0ð0ps…ÅìûØ{»ß»³Q‚?nìd¼z/K\°BüUA¢s¬x !Fh´i’^½ÜO-éßß¶t6,¼ì¿W}¯¾€ªOžm7´"D!B܃êÜ7•à³}¨Úîvñ†Ÿm;Å·ÝAÎ{ñ/ úªv·#Äbbñ/GˆWQ-“u$unú „)ù‹2·Þê~ÓÅë®Ó¥‹U/ûïUß2Ѝ¨œ¦—X¸ûþ3ê‹01BóE&ï@ˆ5ÀíHÙ•ÜÖ%ÔŠSwñåg×?ë€ÅÀWáÿ÷"e=ì·…ª¬ØÆJC´B¬öÕîß‹Jœk‚•<Ô]ÿ?Â_·ÀCX¿æÈ¥1Ï÷:F «wŒÆ"„î]“X¿?nþ Ùý^b>Ç¥}û}\yåV²²lº\†Ajj\|¬@ñ²ÿ^õ=øfņꉔW¡jÚýqH² ¼Š”5Q‰W¡‚¨v@ V…Q'P;Q¥…‹€U>á©Húš€}PÝ!ü·’Vªÿ…~JAõ?¨¬ðWˆJt\,–Fü5z´4ÒpÈ»x6ЬŒøöÛftëv_H}èíB²zõ8RRvjµ[/ûïEß«_ !TìÚ\mˆ»Åð½¦%TnÁ¬ÊþjÅq4 žéE•3.ö=J8ªüȧȅ»|ƒ ¤¤ìä¾û²yûí®Z펱Òõżí¿}¯¾9†`ù͵ìˆy q! âbñ·Bé{fñ÷cÆÌ§OŸÍÚì]}õϼòÊ"möœð²ÿ^óÝg¤l‡}KàeòÄ`08˜XÊŒqÅág¦÷í›Ë¬YÓ]ªŒ—ý÷šï&0Â#XVʨ¸ul0¢Nrr1xäÿiNÔ¨!yøáo˜7ïC’“#/ñáeÿ½ä» öHÙn3"!vDʃÁ‰‰¥¤§ÏgåÊ÷èßSÀÏ»æšÍ¬^=Ž1cæGôο2^öß+¾›*ƒ5RÖ¾F•Zq'BLŽG+©0¸F¤«ìX·®1óæµã‹/ÎcëÖdòóëqôh"­[Òºu!½{oaðà#¢j ^ö?V}7€×‘òJ B,qœÝF¨æ0ÝmFmE‰ÅŽÈMuÅ1I,CeÌ€÷é,FÊorR†/j$åà?Ø/þ2‹¿Á`0xÄÝQ Žv"å»HÙ×§ÞR6@ÊÛ2 Õ¸¦…Ã3¾@ˆCw×`0 ÑÄÅ Q]ç†'r=ð-J­®%uz¥h×%Û ¥þh@¸ ÕÓÞ`0 ÅñMMà"ßC»±G£MƒÁ`0Ds`† ÀU±6ÚŽ ƒ!á+t¾³³3/¿ü2:t`íÚµ$%%©W9xÊåò4 wWÂBHð”aŠáwîÜ™²eË››ËŠ+¸té’zõÿ€^’”L$xJ(ªá+£GN=ärù ³w\¢HPÊ1‡á+“››ËÊ•+ILLT¿tÚÉÉ©ç·ß~›bžžKXIJ)æ6|eòòòX±b…68ãääÔC’ƒ$¥ K¾2ùùù„††rîÜ9õKg§׋԰„U‘ ”`-ÃW&??Ÿ°°0Ξ=«~éÐ]ûG€Ž- _}"P¦L™“&MºfÖJ˜IJ(¶6|eòóóY½z5gΜQ¿tq:pÕb—(’”0ìÉð•Ñ#IŽŽŽ=¾ûî;½C Û# @ Á^ _™‚‚V¯^ÍéÓ§Õ/]vttì.‰€ý! €S _AX·n'NœP¿tqaPcïPÂvH`§”4ÃWFŸ<ž\´E¿$4‘ÀÎ(Ɇ¯Œ ¬_¿žãÇ«_JF\¼`ƒnI¨! €PZ _Aذaÿý÷Ÿú¥«ˆÓIlŒ$6¦4¾2zDàÐS.—'Ø [‘ÀF”vÃWF6nÜȱcÇÔ/ÝDœH"`#$°2O“á+#[·nåðáÃê—n:88ôœ“'OÖ˜'H˜IЉdøÅ'22’½{÷ªßúÈåry‚„ù ˆH†o^¢¢¢Ø³gzñ=‡¾“'OÖ"H˜ILD2|ËÍîݻՋÓO$°’‰døÖA—}årù~t©T# €$÷>111ìÚµK½8ÓÁÁaÀäÉ“5.HIt ¾m‰%""B½8(—Ëc¬ß£Ò‰$jH†o?è™L6(000Ú}*mHðÉðí" ’ËåQ6èR©â©Éðퟸ¸8ÂÃÃÕ‹³d2ÙàÀÀÀH[ô©´ðÔ €dø%‹}ûö±sçNõâ,àu¹\®1D0ާN$Ã/¹èG€—\.ßlƒ.•xž(é†ð ìÙ‰‰ +BëÖЫÔ­këÞYdzeËõâG2™lh``à&[ô©$Sê ¤þ¦M :‚f9: A0{64h`ݾيøøx6oÖxáçCårùFt©ÄRj ¤~A|öüú«qõÝÜ 4ú÷·l¿ì]" “ɼ7Ø¢O%‘R'%ÝðL›ß}gÚ=..pà´ic™>ÙGŽaóæÍ‚ \œ “ËåëmÔ­E©€ÒbøW¯ŠÃùÜ\¥Bgàu 3P1²þF@íÄ|—. éJ_zÑ!¹2™lX``à:[õ«¤Pâ 4¾‚Y³àÿS*¨ lZk©ü'ð! ôùOL„çž³dí‹£G²iÓ& †Ëåòµ6êV‰ Ä @i4|ï¾ ÿþ«Tð;¢‘뢠ä»e‹×Ž…jÕ N = h;vŒ7ª‹@>0Z.—/·Q·ìž2¶î€©(¾ ¥Ê𸺪\ÕS91ÇŽåÊ™¹C ŽOOpw‡èh»f´mÛ–2eʰnÝ: ÅŽ@ˆ\.wËåKmØ=»¥ÄŒJó_ðõU*(ÌD¸(•_>”fº..pý:<£õ/T þûzö„Û·ÅŸ=< *ÊîöOž<©.ù2™ìÀÀÀ%¶ê—½b÷ð4¾‚¬,hÔRRÔ.T:åG‡GJŒ ÿücæ?.ZšjùO?©-VاNbíÚµ"Œ‘Ëå!6ê–]b·ð4¾2Û·‹>yy†ë*hÐ†Ê•ÍØ‘3g {w¸¡6ÏøüsÑûÈNIHH`Íš5ÚFcÛª_ö†Ý ÀÓnøÊlÙ£GÃ;†ë¾ü2¬[Ï>kÆœ= ݺiÿgŸÁ/¿˜ñA–A‡cåry°mze_ØH†¯ÔTøùgX¼nÝÒ¼Þ®|ø!øù‰nÁfãìYñͯ>ùôS˜3ÇŒ²,§OŸfõêÕê" Èd²ÿ´U¿ì› €døÆ!pú4\º$®T® ­ZAxعs¢ñ_¿®Z>aÌkZ–óçϳjÕ*òóó•‹à#¹\>ßFݲ l&’áÛ)çÏ‹Ã~uã7,™ÍßEB|"—Ë·Q·lŽÕÿ›’áÛ1çÏ‹oþk×TËß{‚‚J¬ñ+¸pá«V­"OueUÉd³U¿l‰Õþ£’áÛ9—/Ãk¯‰ß•y÷]ÑølÓ/3£K€Oår¹‘g/KÉðK—/‹Ãþ¤$Õò1càï¿Kñ+¸xñ"+W®Ô&ŸËåò’·ÈQ ,&’á—®\ÿÒ%ÕòwÞ=ŠJ™ñ+Ð!Èd²o´Q·¬ŽÙ@2ü„.ã÷óO#•RãWpùòe–/_NNNŽú¥oårùt[ôÉÚ˜M$Ã/a$'‹ÆŸ˜¨Zîë ÙøóóÅã™™P¥ T¨Pü®Z="ð\.Ÿf‹>Y“b €dø%«WEã¿xQµ|Ø0XºʘvH4?Ö¬•öî…ŒŒ'×êÕƒ¾}áý÷E§%{äÊ•+,[¶LCd2ÙäÀÀÀïmÔ-«Pd ¿„rõª¸Õwá‚j¹·7,[f²ñŸ;#GŠgôáà î&Λ'žX´7ôˆ€<00pŠºeqLÉðK07oŠÆú´jùС°|¹ÉÆŸ îªÔGÏž°m89™ô(«œœÌÒ¥KµMfÊåò[ôÉÒí=.—ËÝ»wïþ°¨‡­ÀÙÙ™Ž;2lØ07nL?PÖ 3StoÏÎßDfõŸ7@~¾h,·n‰Ïµê›ðæMèÑCÓø½¼`ÅŠ" ûûôÑ\?Ä×B-ļ=ùª—.]õÚk&=Î*T¬X‘úõë“ î1ع[·n®111¥.‘Á@ixã'%‰^¬7Ч[Q£Ê–OÑ £FY&’NAÁ“ùñž=ÚçÇ|mÛšÿمܺ%¾ùÕ“ ¼õ¬\Y¤×ñæÍâqe†“€Îvÿ”t§reÑÙP#ò‘’’BHH>T¿ô“\.Ÿh‹>Y P _Ęr9hþ/Uyî9†®]Í÷üóçÁÇGÌê£ÑÕ~î\ Œ nÝßü§N©–Ãø¾üR-€ +ÞÎ]DQP:X:éÑV!%%…%K–­~i–\.·¿((EDCJƒá+øøcøÝ„c..°aƒ8´-.§O‹ÃÜÔTãïéÕKœ›m攚*ÿÉ“ªåýûÃÚµÅR›wÞ³…À;znl}òãÆZFv†˜-—Ë¿´EŸÌ¶ÍÞË‚ Ì@‹ñ»ººÒ½{w>ÿüszõêeׯ¿v­ãw<€šš—=§¦,ji#?Þ~[‡ñ?4@5¶ßc""`º¹ÜORSÅ7uãï×¯ØÆâôE…ßt•÷jI¼ë×/Öã­B­Zµ5j”¶Ïùr¹|–-údn´ €Nß0a]»vÅÅ÷qÔøQÝ™³:°¸$!G¯Ÿ£òWHMU É]¶mèªà œnûÀ& ©jµ¹sÅÊb‘–&ÿ‰ªå}ûŠaƒÌðÿ2D­àÐ øˆÎ"Îÿ?º!æð}LӦвe±»`jÕªÅèÑ£qÕ\°øB.—ÏÁbjƒî^2™Œþýû—ø_m_º øÊ }uÙ€š¿WTTñž£V0XÅ“Å1G"XÄóÇܽ«EÀ|Äd]JÌœY²NëO*A¿*@Ö¯_ÏuÇ;F¹ºZ@3=7ôRý±¸Sû{è©ü  æ!Wäçß»'ÆíW-ïÝÖ¯·=ÌȈ…¦0}: lÖnX…š5kâëëK9Í­¢Oärùo”PP7m•òóóYµj—´núÚµk«-n'º‚Aç3T‹Š›ïBc~û;âÔCæšß»'ººKž§§EŒ |yqº3i’áæ=<Än|ýµÙ»a5jÔ¨Á;#»»»ú¥åry\./q§§n0îÀ@h·nÝ4~;€‚‚¨W¯•*U²Z‹‚££˜ÇBÅçeâÜÑ9å brÍw]ª÷÷o¯¨T©*‡›¼,CðqÎü 0•!rÓ¦0eЉCäôtqˆH-Sh¯^âr»7ÜË”7>ø@\twý)*T€&M`à@Q ~ÿš7·X7¬F¹råhܸ1§OŸV÷|¨Ó­[·Í111‚ŽÛíðð)ÿär¹Þœœœðññ¡žÆ2°}qê”èäcê‚Zûö[ü­8__1élØ`â9=]|ó«;té"¾žÝ´ê$ŠÉíÛ·Y¼x1÷ïßW¿´xO.—h¹Íîp¦¢c¿à•W^Qù977—åË—s]=h¤Ñ¢…x°Í”5¯Æ!,Ì<ûðü!:ß‹L&î\˜düâ›_Ýø;w†­[%ã· UªTÁ××—òåË«_, µ¢“yÑqäÊÝÔVuúõ뇓“W¯>ÉP™ŸŸOBB5Ò6²š5ÄÑ’fK ѱeåJ¨UKw=Spv†áÃEÃ>xP†ŸúõEWá±cMx@f¦8¾Ž‹S-õU1­ÿ_J åÊ•£I“&Ú¦­RSSwëÖmCLLŒ]d¨d–לŒ7€øøxâÕV—Ë•+‡ŸŸÕªU³h'ÍÁž=âðúèQñ\Œ³³¸0Õ±#Œ¡Å±ÅŒÜ¾ «V‰}HL·)«T·ÒúôóLudf€°KmñâÕWÅa¿æ[I‚ܹs‡Å‹“¡|ÐCdà#—ËMHðf]Œ€C‡qôèQ•ënnnøùùQµjU‹uRB‰¬,ÑøÕ ^yE|óKÆoîÝ»ÇâÅ‹¹wOc»'i¯"`Ò¶ÅË/¿L›6mTÊ233Y²d‰¶_\ÂÜde‰Ã~uãïÔIzóÛ˜J•*áçç§m‡ÌX.—Ëíïl<& @ûöíiÑ¢…JYFFÁÁÁ¤§ër—(6YYâé™èhÕò_³ˆÚ{ð½§€Š+âççGeÍôÌCAAAvÅdÉd¼òÊ+4k¦êZ—žžNHHˆ¶m‰â’-¿ºò /@x¸™óK‡Š+âëë«M¼RRRìNŠä¹$“Éèܹ3Ï?ÿ¼J¹b1äÁƒf霢ñ¬iüíÚIÆo§(FÏ<£±»>$%%eݯ¿þj7‡jŠìº(“ÉèÖ­ 6T)¿}û6K—.Õv†ZÂT=ãõE¨E¢jÛV,Óü€IØ *TÀ××W› ¸sçÎZ{bù.Ëd2ºw‡‡JùÍ›7u…T’0–œ1^ß–-ªå’ñ—*T¨À;ï¼£m›¼ÿ;wÖÉår›Ô(öá<==5\ƒoܸ¡5̲„(ŒófÕò6mDã¯RÅ6ý’0www|}}µ‰@?Àæ"`–ÓK xöÙgUʯ^½ª+̲„.rrÄaÿ¦Mªå­[KÆoa´8òMBBû÷ï×zÍÍÍM—ôÖÿòË/6 j¶ã‹ŽŽŽôéÓ‡Zj¾´ÉÉÉÚÒ1MRRcƌ᧟~2G7훜1AÇÆªåM›ÂŽ 9[Y„Û·o@Íš5ùá‡Lº7)) Z·nMÏž=‰ŒŒÔZO!Õ«WW¿Ô'##Ãf"`ð,À‹/¾htc<÷Üs\¿~ÌÌÌÂò»wïrýúuZ´hƒ‘9çnݺÅ÷߇&""GGG^³Ç€òæ 7WL͵aƒjy“&¢ãOM-A %ŠÍ_ýEÿþý‰ŽŽ&//¨¨(\]]éܹ³Þû’““ùꫯ3f ‡BrssY½z5:t Aƒ÷8;;Ó¼ys.\¸ b@ÃGuéÖ­Ûꘘ«—Í* Ž4hÀµk×ÈÊÊ*,¿{÷.·nÝ¢yóæÈŒ8ìþÛo¿1eÊ• ÑÑÑ”)S†®æŒÝmäç‹ñµV¯V-oÒDtü1× % ž}öY6lØ@ªRW}/›””¾ùæüüü8xð ªg}"0pà@jjmgggZ´hÁÅ‹ÕEÀ1‰UEÀì¢4lØääd•íÀ´´4RSSiÖ¬™Aèܹ3åÊ•#Bm ,::š‡Ò«W/w–0Æ¿r¥jyãÆ¢ñ×®m›~=%¸»»ãååÅÖ­[UD ::‡B¸}û6S§NÅÇÇ‡ØØXõÌA…´oßžß~ûMïKÊÉɉ–-[réÒ%uÇ9 K¿~ýVGDDXE,"ðd$påÊ•íÀ´´4ÒÓÓiÒ¤‰AxõÕWqww'<<\¥<66¶tˆ@~>Œ-¦æRæùçÅa¿düVA!Û¶mS˜˜2228vìC‡%22’ÜÜ\­m´hÑ‚?þøƒ_~ù…&Mš|f™2ehÑ¢…VÈË˳šXL@ü%µ‰ÀÍ›7W^y…òå˳sçN•òØØX²³³ñôô,rÿlJ~¾6hùrÕòçŸßüj;*–E!Û·oçÖ­[…åû÷ï'""‚Gi½¯iӦ̞=›ùóçÓ²eK£¦· "””¤.õòòòº>žh°™°¨€8Ü©_¿>III*Û7nÜ ;;›F%*TÐ*YYY%OòóÁÏOLÇ­Œ‡‡èò[·®Mºõ´ãææÆë¯¿ÎªU« žiñððà§Ÿ~âï¿ÿ¦]»vF/n«S¦Lš7o®U€×,->ž{î9.]º¤"×®]ãÑ£G4jÔÈ`:u¢bÅŠ"Gff&½{÷Ö{^^^‘ÿIf%?_ ?´t©j¹‡‡8ì/ )sJ!¹¹¹üûï¿øøøè wW§N¦NÊâÅ‹éСƒY>SÊ#5_„º@ï>}ú„EFFZÄ­ÖjáîîÎÀ5âªïß¿_èuñÙgŸ1þ|ìY³øâ‹/´Þsüøq¼½½éСwîÜ)ZçÍEAŒKÔ²hÖ«'û%ã·:„……ѬY3üýý ƺôòòb„ fO’ãââ‚uêÔQ¿ôâ£GÂår¹E|¿­2Pàâ₇‡—.]RYL¹zõ*g ´ñÒK/Q³fM¶¨ùÈïÛ·ŒŒ ú<ÎìyêÔ)>úè#>ùäN:EJJ áááxyyiKî`yƇ… UËëÕßüÅMF a¬^½š!C†°`ÁîÞ½«µ^™2eT¶úöïßσ Ž8‹B™2ehÕªW®\Q­QðìÝ»÷šÈÈH³ž²³ú˜¸bÅŠôïß_CA£££Ù»w¯Qmøûû¤1üš3g#FŒ`øðá´nÝš°°0áIij£GÒ»woëWVPjyݺâ›_2~«!›6mâÅ_ÄÛÛ›sçÎi­çîîÎĉ¹pá/¿ü²ÊµÙ³góùçŸ[¤NNNŒ9’úš£Árrr§OŸnV_p«Ž¸ººR·n].^¼¨²ŸzéÒ%œ©kÄ"Ø‹/¾HíÚµÙ²e‹Š‘Ÿü,P-W¿Úqj ËÁðáÙ={67nÜÐZÇÍÍ>ø€Õ«Wóúë¯S©R%†Jtt4×®]+¬·ÿ~n޼ɀLZù7GGGZ´hArr²z¨½Zùùù½»uë¶&&&&K×ý¦`³U±*Uª†W&<<œÃêé­tðÞ{ï1sæLƒÿ€Ö­[J\\={ö,rŸMFà£ÔÒuêHÆoEöîÝK·nÝðôôÔùÙrvvfܸqœ?žy󿩸ìWªT‰íÛ·óÒK/©Ü³`ÁkOÅÅÉɉ·ß~›ç4G‡m¹\n–ƒ!6]¯Q£ýû÷×-[¶päȽ÷¦¥¥ÀäÉ“µ¾í*W®ÌªU« 9¬Š ÀÇÃüùªå5jÀÎ&ÿÁƒ0{¶8˜3>û ‚ƒA)]C©äÒ¥Køûû3räH“”íÛ·^½zÑ¥Kv©‡PŒ““ãÆ#11‘   Ãl *W®LDD:tÄs/C‡Åßßß´_Èœœœ1b„6hì–ËåÅ> bRXpKqíÚ5¶oß®2Éd¼õÖ[´TK$çÎ~ýõWæÌ™cÔñÍwß}WëzE˜0~ûMµ¼F qŸß„$y›7C@€˜êLŽŽbİY³@Ëù“KJJ _ý5K—.-ü\Œ1‚%K–àè¨?éΉ'øþûï ÓYÇÁÁ!C†0}út£¶¡¤§§ȻᆱñÙ´¹¹¹¬\¹’ÄÄDõKgœœœz|ûí·zÒÞèÇ6ÆÅžžž*F*ëÖ­ãÌ™3ýTŒªËøAt+X·N °uk1úlg<óÌ3ܾ}[奰bÅ FŒ¡Ó7!!oooÚ´i£Óøoî„„BCCM2~±çÎk5ã‡'ÓÆ«_jš››õÃ?ù´˜] õŸ*B¡ãн{÷øçŸ´æ¨S§sçÎåêÕ«,[¶Œ2jivþý÷_Þ{ï=ëˆ@@¨Ç.0ÑøAÌ8ožñÍÌ„·Þ³"—\\\X³f ƒ R) ãí·ßVù¼(¦ Úv~”éÕ«‡&44Ô(}{ÂÑÑooo]"-—Ë‹tpÄ.àìÙ³DEE©¨bˆÖºuk@4ò={öÐ\ɈªV­ÊŒ38wî\¡sÆðáÃYºt©†,\¸§¸ÌÂ7ßÀÌ™ªeÕªAd¤˜­ÔH®^S„«àxó€EÀ4@uwŠGÄe‡Ò‚³³3«W¯f°ZÆÔÕ«W3bÄñ÷÷§qãÆüõ×_:ÿ·½zõâàÁƒ„‡‡Ó®];ktÝ"(D@‹x5¢§M›fò›¯œ9s†={ö¨¨¶L&ãÍ7ߤU«Võ¯_¿Ž——ƒæã?ÆMGÜÐÐP­ GÇgÉ’%Ql¾ý¦OW-S¿–ßC³fÁÿþ§TP ؆¸ô£ÎŸÀ‡¨üK—kANNÞÞÞlP –âàà wT÷ꫯ2mÚ4­í’N~~>aaaœ={VýÒù2eÊtŸ4iÒ5m÷iæ#mƯP9mÆP»vmâââÐiüÞÞÞ,_¾\c‡aåÊ•øøøè]Q>wîœÊž¯A&MÒ4þªU‹dü—=žð-Úà ›jÑéÓ&?Ò®qvv&44”þýû«”ë2þŽ;²qãÆÂí¿Ò†££#C‡ÕæÏò|^^Þ^¹\^ߨ¶l& ìÞ½[Ãø½¼¼Ìæ¨3tèP­"°jÕ*­£ƒ+W®àïïO‹-èܹ3—.]2üï¾õ8r•*‰‰:‹`ü®êÑáômõåj>-¶ðt¶$wîÜaúôé=E[µjUèvPÚÐ#õ˜ï¿ÿÞ¨1 MàĉÿL=¿P±ðòòbÅŠ"ÊÛo¿M^^·nÝ"  p.™——GRRÝ»w×/0mšjY¥JbÆžbxPªyžÂ,`6 ~(ôbêI¥7¾‹‹¸#P0fçGAÛ¶m9pàC‡5»gž½âàà€···¶ üüühcDÀêkÇן¬g…ÓllÙ²…!C†hvxþùçINNÖ™ÄdàÀlRÑ —k®ÔUª$:ùhX°ideA£F¢¾»[hT’È#%ÆŽ…þ)ÖãmNVVÿý7?þø#7oÞ4ú¾>}ú°~ýzÊ–µy¾ «¢Ø2?qâ„ú¥+@w¹\®á@ Àª#€ÿþûOÃøõìqš•°víZCHçÏŸ×jüõë×'((ˆõë×k6öóÏšÆ_±¢º»˜Æâ~Ñ"pRO#yØ„ûÑ0þ Ä®•Trrrøë¯¿hÔ¨Ÿ~ú©Nã¯[·.þù'o¿ý¶JùŽ;xýõןº´tŠEóÖšC¿z@ô÷߯ÓíÔjðßÿqàÀÅñ A IDAT•2…«£¶Ê– k×®uêÕ«GPPçÏŸgܸqš^g³fÁW_©–U¬(¾ùÛ·7[_ûôõëÏöò˰{wÉÌš››KHHM›6Åßߟ¡HõêÕ ·}ßÿ}BBBðññQ©³sçΧVÞxã ­"ŸŸ-—˵z/ñ£µ ‚ÀöíÛ9xð J¹YŽÄé2~777F­-'º]Ò¥KâǧáÌ™*ÆŸ |Û¨SÛ·G1F¸ÿ>óçÏçÇ$==… ¡m¶T3uêT=zÄOJ1teÕ‘ÉdôêÕ‹€€Z<>­+·„aœ^'‘ÉdôíÛ™L¦²+Wì)€ ìÞ½»Ä? òüÏ?«üQC9'NпnݺÅÌ™3ñðð  0~{jj*ݺu#>>Þ=·—/_ææÍ›C®uíÚ•;v°dÉ’Bã—°.2™Œ>}úбcDzbA`×®]±ÕÝÝÝ=z4ÕªU+NóÖeÑ"xï=1×crcp(RìÙ³‡:uêèÜ_vqqáÔ©S ¥no$''3kÖ,‚‚‚t&ÎqýgþüùGy%lƒBÊ”)ÃÞ½{‹>˜˜ ã¯P¡ï¼óNÉ2þà`Ñ›Fù|¹³3W~ù…Xµ!–6ã¯R¥ œ;wŽÑ£G[¸³¶%55µðä䯿þª×ø>|È?ü Ó½WÂ6ôìÙ“.]ºMA ::ZëB… øúúòŒ±ìöÀªUZ?åJâªTÑ›FL‘=æâÅ‹ÈårÊ—/o…Û†Û·o#—Ëiذ!3gÎÔyz²yóæxyy©”]¼x‘!C†H"`gôèÑÃô)@AA‘‘‘~Û+VÄ×××$ç › >>bh]ÎÎÄN˜À˜€i£4oÞœo¾ù† *X¸£¶ãÁƒüñÇ…‹ºhÒ¤ _~ù%D&“Ѽys¦NZx=11‘!C†°fÍÉQÇŽ0iPPP@DD„Vã÷óó+YÆ#G‚RT GG>«]›Î?ÿlÐø|¸Öd|ð†<|ø£GšÜ/ Ë`”°sçN._¾¬R^¥JÆŒS²ŒÍ1BÅøqt¤`ñb²ÔÂO+'‘øã?èÝ»7*®®`_"Á‹/¾ˆ¯½öš†W¦.rssù믿hРþþþ:“g*r0œ={V÷±i%>øà¦NJåÊ•ùòË/‰‹‹Óó-a; zŽ;–íÛ·kDÉ­R¥ ¾¾¾%kákíZ>”Wò!$Þ~»0üô¦M›2dÓ¦MÓ©è¿ÿþ+tyUÆ”Sq–`çÎôïß_%>~5ˆŒŒÔ¹÷^PPÀš5køú믹xñ¢Î¶«V­Ê—_~É'Ÿ|¢qxêîÝ»… \t‘““ƒ³³³ ¿„!LqÒ…AxöÙg5Œ¿jÕªøúúªøÎÛ=ëÖÁ°ašÆ¿x±¸𘜜 '=}ú4=zôÐxS¶mÛ–ˆˆ›‰ÀªU«4žW«VÈÈH•Pë ß4i’ÞõŽgžy†?þ˜Ï?ÿ\çb§1 a~Ì!§¥Âø·m‡ýêÆ¬bü þQ‰LܬY3¢¢¢4V´•Ĩ£<¿ŽŠŠ*Ò¯bˆaÆi¤GKMM¥gÏž?~§ /½ôÞÞÞ:_}‹³4ït<Í(S³fMF¥woÜîØ¾ÞxCÌ›¥ÀÑQôüS %UΜ9C=4ö¸Û´iS¸^››Ë¢E‹˜:uj¡ –+WŽ7Ò³gÏb÷AŠzÊ#wwwêÖ­Ëi=™CÜÜÜ;v,ß~û­ÑnÜÒÀ6Xe   V­ZŒ5JkX&»eûvxóMPvZqpߌ{gÏž¥G\¿~]¥\ärÞ¼y»' ŠÀ–-[,–½fõêÕ‰4u¡8“/—ËMÞ§—À6Xe %ÔøwîÔ4~™ æÏ7«ñƒè¥qžýÌ™3|öÙgZßÍÍwß}W%Ù©¹©S§Íš5Ó[Gq&ÿÌ™3IN:O Äÿë¯k7~‹<²I“&DGGklªãìì̸qã8þ<óæÍ³ÈiÉ'NàííM§N çýÚèÙ³' „„„X%:³„ýaP|}}K–ñ‡‡‹s~uãÿãxÿ}‹=6""‚‘#Gj]ü» ÃËËË¢oÚ„„¼½½iÓ¦ aaaë>|˜Û·o›½%ƒ žIǮٽ[ö+Gù•Éà÷ßáƒ,òȽ{÷Ò½{w<==9|ø°Îz‚ püøq‹ì…'%%áïïOëÖ­ Ó‰§]»v*ÏOOO§OŸ>Ùš$žlšܬìÙ@fæ“2™ ~û Æ7ûãöïßÏ AƒèÒ¥ 111×e2™FúòsçÎѽ{wÓRëA‘ÍøùçŸç¯¿þRqR¦W¯^ ¤·Í¾}û²qãF\]] 3!ÇÆÆJþúOŽ@-[¶ä­·ÞR ò¨'ß˜íØ·OL¡«nüÓ§Ã×_Û¦OzHNN¦{÷în¡-C²"ÇŒ3ôæßkÖ¬øøø ΩιsçhРÑ᥵!9Ù‹x´hÑ‚!C†hˆÀàÁƒiÛ¶m±höï?#Cµü‡à›olÓ'#HNN¦G\¸pA¥¼^½zDEE޲²²øûï¿ùñÇõ&4­_¿>_ý5cÇŽÕzßZXBÒÒNûYÛ,mÊ Ð·ï\jÖÔo¯Zï>uê‚ 0dÈ– lذÜÜ\a®U9rDœó«ÿ´ivmüuëÖeÏž=ôèÑCÅÿÊ•+tïÞ;w²{÷n¦L™¢áV¬ÞΤI“3fL±ÞÜöLNN))ûlÝÍdž³6ëüô$$$——‡···Ê‡lëÖ­¶£GÁÓÔ£Ô|ÿ=¨¥©²WjÖ¬ITTT¡ž‚äädZµj¥sEÄc½_|ñ&LPYÀ“(*z'ŒçÎcÕªUÊ­[·j¤²8ññbZ.õ¨;S§Â¤IÖíK1Qˆ€z]Æ_¥Jf̘ARR'N”Œ_Âl?ž?žU«V1lØ0•‘À¶mÛhß¾½åz§L•*P¹2(/†Éåð]É›' ‚`”€–/_žñãÇóõ×_S±bE+ôL¢4qãÆ1•ŸË–­¤±& â€N†kÔ¨ÇטsöíÛ—:»³Fqù²˜™÷Ò%øßÿ@)]I!""‚€€ƒ)ÄÜÜܧS'ƒÿ›c‰EÀë×ãØ¸ñ-³¶ù´ãáñ~~1*e@_DÐË… X¹r¥ÆÙòíÛ·[Ï—ÜÃ"#aÖ¬gü{÷îåµ×^ÃÓÓÓ¨ü™™™¼ùæ›9%$̉(±†*ë;v°oŸ•VlŸ{¾øÂ:Ï2ûöí+Lô{÷n­uœœœ=z´ÆÙý›7oÒ£G£#ûJH˜Â­[· ï}€C7]¼x‘eË–i ùvîÜÉž={ÌÞÉ’ÊñãÇñööæ•W^ÑÿOvüôéÓ,^¼˜ØØX^zé%•:·nÝ¢gÏžöï’-Qb¸wï›7ofÁ‚ÈÔ®¹›Mr5<<<9r¤†ëh÷îÝéÚµ«ùz[Â8uêS¦LaõêÕ:å:88è ;~÷î]úôéáC‡TÊ«U«FDD­[·¶Xß‹Š-×ê׿$ S¾|]ÜÝ;sãÆÂϦº”6c¤¼ýöÛ1ºuëÆk¯½f†.[—ŒŒŒ"G¿=sæ Ó§Ogùòå:åÊd2 À÷߯ףòÞ½{ôîÝ[C*W®Lxx¸Ý¥·¥të%ð£f7hóÈãV_¾|™eË–i¤ˆŽ‰‰)QçË™oëԩôiÓLº÷òåËøûûÓªU+–,Y¢÷Lþ¡C‡Ø´i“AwêJ•*±sçN-Ö»wï <΢E‹Lú$ž^t9eƒ0B®\¹Âòå˵Š@I8_þï¿ÿòÜsÏ1eÊîß¿Ïwß}ÇôéÓ ÞwõêU&L˜`Ô™ü˜˜“ßÜ PßbUˆ€úè ..Žž={Ò»woƌÌ3Œ~–ÄÓ‹¾$¹ÀD½#ÓÓÓ¹|ù2-Z´Pñ¸|ù2yyyZOºÙ Ï>û,6l 55µ°,** ™L¦5\wZZS§NÅÇÇ‡ØØXoüN:Ì´iÓ¨_ÄIjÙ²e:t(111*D>|HXX=zôàÚµk¼ÿþû¨-ŽŒŒÄÅÅ….]ºéÙ¦ððáC‡¢rÿ~2gÏ®2XOZ(†ÎŽf"N" 5”œœÌâÅ‹5ÎªÇÆÆ^ôZEî¼–-[ª”Ëår ¾sçr¹Üà™üÖ­[ZøF..+VdÇŽA÷îÝ£sçÎtìØQkd"ÿöꇦ$$”ж¨rÀ —¡Šµk×ÖFü•W^ÁÓÓÓôZ Åv›úžûgŸ}F5 žÉoÞ¼9r¹///d2cÿ¬Æ“™™ÉÀšV½úê«üðÃV[ˆ•K.ÆFȆ*^¿~7d\\;wî4½‡V¢zõê 4æÌ™C@@€Nãî¹ç âøñã :Ô"ÆâÔ£AƒzÛïÔ©…^‡†0õÓêŠ80ø*W$QÏ#رcGúôécâc­Çµk×èØ±£Á õêÕãÛo¿µø™ü«W¯òóÏ?¤±ÐªŒ‹‹ ;vì°‰áÛë@SJÎf”Ù | äÝô×15*p6âî€öI§)))„„„••¥R¾ÿ~¶lÙ¢ÓIÆVäææò×_Ñ¡C½Æ_§NæÎ˹sç7nœÅŒ_´qãÆüúë¯zàÑ£GRd_ “)JXðG€FˆÀ7´ŠÀáÇíF  £yóæøûûŒÙÿÖ[o1a‹&L9}ú4Ï=÷œÎÅÆ&Mš°hÑ"zôè¡R®X'ˆŽŽ¶Xß$Sqy\ÛWc=÷CM``ÌNãâ=³¨yC0R-Zĵ°ÝñññlÞ¼Ùf" B¡á{{{kÄéS þ†ÿõ×_ùüóÏ-ÚïfÍš1gΟõêÕ#((ˆ“'OâççǦM›èÕKu]V!ºÎH˜‰ @µ¯æÀ‹ˆ\Ê"˼èÏë*nâ÷{üÌÚêê 8‰ArE`“¡Š©©©,^¼˜ûj|9bˆˆˆàÅ_ÄÛÛ›³gÏj­ãîîÎĉ¹pႆGÞœ9s?~¼Eûýî»ïò÷ßãàà sÚQ®\96nܨ±»’••Å AƒˆŒ4¸{+QTN¿*}-<þ:R„öjí7Ýïꯈ†_©ÏR¢¸™r§ UÔ'›6m²šdgg3}útŽ=ªõº››'N$))‰3fàáá¡Õ#oÁ‚|ðÁí÷˜1cسgçÏŸ×9ípuueÓ¦M 8P¥<++‹ÁƒapãF¼TÂEÀT*IÀˆó ùU•:)Ex–æH – ÅHKKÓ*Gµš¸ºº²yóf¡³rÚî3fP¥J•Âk+Vdûöí#   >ýôS‹ö÷•W^1ÐÅÅ…5kÖh$Qˆ€.G,E6á/¿üÒlý}*yqø¿¸RÄ6N#Ї±~[/îq€_?æÊ ¨ †*¦¥¥¬á¡vôèQÖ®]kP:;991jÔ(ƒi»¾ù;vÄ“}dìØ±ï¯18;;³zõj¬RžÍ AƒT¼/]º¤’MxöìÙ|þùçÖîré >Ð8ô¤S>öNˆ¢sОÞhÌ™4ðƸ}û6‹/Ö“'O²víZôd–ÀÕÕ• 6pöìYBBB4’xjCá–;aÂŽ;ƦM›ìê|¾³³3aaa¼þúë*å=ÂËË‹… âïïOãÆ5² Ï™3ÇâSšRÉPDoš»ˆ+ñ–ñS¥#¢o®öS&aîìÀ Xo¨¢½ˆ€1†¯L… ˜;w®]¾2ÎÎ΄††òÆo¨”?zôˆ±cÇê<¹Ø²eKmE #x„xbæ5`ð¶…Ÿç‚x<ïp»øÍY"=¸I"°páBîª%ú8uê”ÕD 4¢¬Û¬Y3/^ÌÿýgQWæR˯ÀlàGàÐh¨÷ŽâÑ QÌðöˈG‰½u†*Þ»wÅ‹k5kÖH"PîܹÃ?ü 7FcõêÕ âĉŒ=Ú䤢j䊸¸Eõ0DYÄáÿÀpÖ/£°db¹\`°ÐëÔ}ïÞ=‚ƒƒñóóSÉvªH¥ž¨TB;Æfño^­Z5›&-u(6·Ê[¨ýʈoÿÖ€âôºbÀö*Ðtç“ÕÀÒV¥ ¬0T1==àà`þJHH`ÕªUf8QšÈÊÊbÞ¼y4jÔHçÉEu‚œœ† ÆÚµk­ÕÍÒâO¬ÿØFÑy€è#pqÇ!Ñ! D€xÄs»&`×j>0 #E`ñâÅ" ÈQ(‰€vvïÞÍW_}¥5•xµjÕ˜5kiiiøøø¨\ËÍÍÅÛÛ›åË—[««¥m–£|uG˵Æ@à㯢ž¸x _ùK‘Ò'ññÏ÷µßª k«"`ð“¦k$ ÈQ¨/{îÓJß¾}Y¿~½ŠÃPùòå™8q"çÏŸç‹/¾ÀÝÝàà`F¥ro~~>£GfÙ²eÖîvɦð>â¢\3ÄÚ=ÏËž³a¿LÄšë|`4`ð“–‘‘ÁÂ… Uâô$úèׯëÖ­£J•*Lœ8‘Ë—/3cÆ •¤¢ŽŽŽ,Z´___•{óóóñõõeéÒ¥ÖîvÉEqH³7â$·+¢ß ¥k%K.j#ðEô{òÑWñÁƒ,^¼___ªU«VX~á­ي%Ä‘À7ôþ]ù÷ßÂòüü|üüüprrbذaÖènÉæâ WÄE¿G@ºžúç€)&´ÿ‡‘õî˜Ø®¶XZÏüƒ¯…ܺuK¥\‘£P hbŒ(:::Ìûï¿_XæììÌØ±cŸê¬NE"¸…~ã·clõ Uˆ˜0¨^½zaùÅ‹Y¹r¥Ö”冑ÉdüñÇ‚€ Lš4‰ºuëÚº[VÆÖn_ŽÀ"ÄB½¸¹¹1zôhjÔ¨¡R®HO¦ž£PÂzØkL@ ÃØÚ»&x1T133“­.Ez2s%$žl- ŠÀŒàà`®_¿®R~åÊI$$Š€=<ņ*fgg³dÉà’HH˜Ž½˜I–.]j0„¶„„„ˆ= @¢ªøðáC­"œœ¬5e¹„„„&ö&ðDª¨õDŠD¥>´P%$Jö( z Žþ4TñáÇ,]ºTC™‰teñ•°_Q>æªøðáCBBBHJJR)OIIaÉ’%’HHèÀžDø#D ''‡åË—ki$ ¡àâÅgøä“~4nü1ÎÎßQµêWxzŽfÉ’6ß/Î’íÈ iCÏž¾T­úeËNâùç?áãû“”T´ !¶ö4ð;â´@/ÎÎÎŒ1B#ØgÍš5µf+–(>%Åðß_à£úóð¡v×ñί°fÍ*ªWÏ4¡§Öi?5Õ7ÞN\œvwm—<þüs ï¼£=á.ì} @10xFJ1¸té’J¹®D¥O+W¶ä½÷é4N€½{ë1`ÀH²³ìªýìl'z÷¥Óø=*ÃØ±ƒ kaRÛ%- Ü6ÄLíõU*(( !!:uê¨ÄÌÌÌäܹs4oÞ\:;`F>|höhM÷ï'söì*ƒõê׿ô‘ž^OÏÑ<|hØð®_/O¹r¹téb|ŠK·?}zWV®li¸"2¢£ŸÃß?ž²e;)[RF àÄé€^rssY±b‰‰‰*åŠôdêÙŠ%J/K—¶æÞ=ýéÕ”ùóÏ—1%?Š%Û/(ñçŸ/ÝvZZ9BC”4€'"𛡊¹¹¹,_¾œsçTc4I"ðt±gO=“ê_½ZÄÄgì¢ýsçªpó¦»IíïÞíatÝ’( ŠÀÄ´ zÉËË#44T«k$*•(}ܹãjò=©©Æ/[²}K÷½¤ ˆ"ð)0ÏPż¼8ltÛÕªe2|øIÃSÒ¶õ‰˜›¥‹¾J‚ púôiªW¯®møáÇœ={–¦M›ªÄ×—0Lq¶ÓÒÒˆŒŒ$::šôô'‘52pr:eð~c¶]]óððHgÍšfò}{ùåkm¦LãsRZºýöí¯³}{#RRôç“É/^OÛ¶7Œn[µ·‚ð`ôÝO˜Lv ÷)?ûOÄ=~cX‹L¶RǵéÀ׆pttÄËË‹fÍš©”W¬Xñ¸ÞÃÒIDAT???*U*škåÓHQ<oß¾M\\œÆºŒGÇd\] û˜â ¸hQ;Æ ÓY§k×ˬY³ŠªU‹æ,fÉöoÞtÇËË›½{µï8¸ºæ²`ÁfFþϤvÕ`°ÙäÞA,2Yç"ܧüì+€±ai@&›¤÷:|c¨Þ|óMZµj¥R^±bE|}}Uœˆ$tcФ§§sðàAŽ?Ž c3üÚµk\¸Á€©Z¯+cjPФ¤J̙ӉíÛqåJEÜÝsh×.?¿c ~¬Ü~~¾+W¶$$¤ GŽÔ"#Ã…úõïѯßy>ûl?¦OaÍ%ƒÉŠz¯¹`𭡆xã7hݺµJ¹$ÆcŒdddpàÀNœ8¡3åûõë×Ù»w/W®\¡~}ðó3ül)*pñ0g@ýéÂVd2ã'7–E!zE   €õëרˆ€"G¡¯¯/Ï|˜#GŽèLärãÆ öíÛÇÅ‹­Ü; s @+`Fäþ³"“w ôŽ" mÚ´),ÏÈÈ(LJ"‰€idggsèÐ!½†Ÿ––ƾ}ût®HXs§Ô™† „!“ÙShÞïEà;}• ذa‚ жmÛÂòŒŒ -ZÄèÑ£Uv $´óðáCŽ9B||¼Î¸Œ·oßæàÁƒ$$$è\°æ€úÀ{ŸÚÐZL~üÝ(TD@W¢R‰'äæærôèQ<¨3cFFû÷ïçäÉ“:×$¬‹%’êMFBÉì͵n2âH`²¾J‚ °~ýzrssyùå— Ë333%ÐBnn.ñññìÙ³Gg¬…û÷ïsøðaþûï?)¡«a ¨|Œ¸oo"Š@ ¡Š[¶lÐ*£GVITú4’ŸŸÏ±cLj‰‰!55U«#PVVñññÄÇÇK†o§X*­îWB2Ùm µ_ä¿%‚ оý“ø#Š…O«pâÄ bbbtºNggg®üçææZ¹‡¦`)¨|L´PûÅEŽ˜ÙÝàù­[·":t(,S ¨g+.­(\¨###¹sGûA–œœŽ;ƤÄ,%K À'ÂoÈdW Wµ 37(Û¶mP¬¬,‚ƒƒ5jµk×¶HíA8þù¤/ªz¥–)SÀ˜1G™5k'åË›¶öRÜÃ@;ÞêÀKÈdGô×2ûa ¢ð%ð³1{ôèA×®]UÊ\\\ðññ¡N:èšå¸ví»wïÖˆ›¨@aøQQQܾmsJK+G÷î~œ<©{çÆÁAàÏ?73n\¼±Ý´Zû ¼Ä‡Л]¨U«›ìÚLåÊÆgÁ*î`2b}‘ eˆÇsûóYÖ`ÖãïE ** AxMéÓ÷èѣ‘@I[·n±k×.´^W^¼qÃ@ wwxûí'?ÇÇ‹_v‚ŸßzÄáõ‡à…Rxé%íÓ[´¿>þ¸¿ÁÔb'NÔ`̘×Y·NW¨ MŠì:Fdðú"=Šù,k1 q$`èèhvíÚ¥RöèÑ#BBB¸|Ùø¸lÖ&--uëÖ±`ÁÆŸ˜˜ÈßÿÍòåË ?dP¹2=ù4Èìý.*±±õز¥±Quóò˜<¹»]µÿÝw=4¦ºX¿¾)ÿò1GLÀcV‚~DJJ.ÂÙÀÆTŒŽŽ&""B¥,77—eË–éœKÛŠ{÷î±yófæÏŸ¯3 Ç•+W&$$Dç" û€žÀ t×lˆ¡ºŒ'<¼!é鯇…³dûwî¸]ߤöMéOñ@&KC4C´ûyÖãàsc*îÝ»W«hËVl 222ؾ};¿ÿþ;ñññZ ?99™.\hLŸÞÀ+@”Ù;lfÎ36ÒœH^ž/Æ’í'&V&?ß43=s¦ªÑu͵ ð bæ^Cnq3„-Èd%Å1|Îã↑¸wï^AÀÓÓ³°L!Ú²[ƒ¬¬,âââ8pà€N_ü›7o²{÷nN2€8LV#.î–ZL‰ lÉö‹2h6¥ïæ .“=À¸Ã?M‘fy¦õ˜ƒ˜{Àà>66–;wª”)rªg+¶$ÙÙÙDDD0wî\bccµjj*aaaüùçŸÆÿÀh„QÂŒ¿qcÓv.œœòiÐà®]´ß¨Ñ“ýš4I3º®9ó, Ö‚)‚‹Ÿk æ"Žp ~ðãââtŠ€z¢Rs“““Cll,óæÍ#66VëAœ»wï²iÓ&c ÿ2àí)0o `+áå¥}¡S½z%R±¢ñ.Í–l¿rålzô0íå1dÈi£ëšOÄ(@S¨éø¡*i,>ÀHرc‡J™®D¥æ 77—ØØXæÌ™CDD„Öƒ8ééélÚ´‰ß~ûøøxC9®"&[iü””)›V^y%™AƒŒ ;æä”Ï÷ßGÛUû?üeô(à­·NÓ¡ƒñÇoÌí ¸q¸ÜÆ@½IÂ"› „¦@cÄõŠÛˆ[™GŒ côøûŸȱoß>A çÀܨU‹îîd•+Ç©ãÇùÂÑ‘—6Ôyoâd;q{¥,ð ¢5>¯TOùL¾®LÇÄÅÅqøðaÝgòŸyZµ‚ îÓºõv||–Pµj,2™yô5o @Íšðà\¼GŽ@“Š˜Bpðz^{í½{õŽŽÌŸ¿…_4ÍÀÒí¿üò5þøc+ãÇëwjÓæÿü³Ñ¤¶Í+2Y‚¬7P³¢P3b0‚àƒ˜ôD[òôTa 0™,AðBõlÀ[ÈdŠŒ Aˆ£€€Œ/¾€ñãŸÔìØRS¡aCöË¡áÃÉwWMïì²b_çåѤIr€p`-° з0Zèyâ'""tæ4T^Ì?–)Åj}õU¸qš5ƒ)S`ð`pq( }ü•ƒ l¾B&+Þ°åwà³ÏD‘Qçöm˜3~ù²÷`3•gžÉ&.î_þ÷?O.lGn®jR¬&MÒøí·mxz-2±¥Û÷÷?Œ‡Ç=>ý´/gϪ®ò—)SÀ¸qñ̘a²+°ùÏÈd„8Ä-"}üAX€LvËì}PF\oX¼®§V5Ä-¿Aˆ†Ð@éºú¦í_(D re(Uut„7Þ€åËÁÕUë¤9¿ €°°0†J“&MxXn䯓Ì”Éøõùçñúï?ª @vv6`ß¾}O¦•+£ÒÇ2e`Ø0ø÷_77]¯gÄ¿Ya2Ù#»ø77//ÝuªTiÓ o_8”Òƒ™›òå±`Áf¦N&2²W¯VÀÕ5—_L¡C‡«ÅN béöûö½À©Só9xðY®MvvêÖÍÀÓób‘³Yê0P°Û@wÄ€!F9Ü Ap@ܲ¨vå¤"†0{Qž6¿ÑúßÈdA(OÚ´+@‘_0/’’(WP€CíÚ ßL¯^ NIZµÄi@` (Cg½ð t3çÜ\*=~Ó988°ïÓO9W¾ûLþ2M±ÿêêj´ÖLœ8ñv¶†Ïç#½´”e™™|ݰ°­Ä8Òêë™¶v-ŽKUF©©lîÖ Â rH·¦æÿYüç€Ñ(z(UêZOGdÓfùß½YÈφŒ·¦6œlÙ2NŒËüi‰Æ2ì±5šõ°M<ó‚QªI‰Ä,´~0ò0ÇÌDžæÞ´\üF”ÚNðŽÁ9ZÃÌ™!‹?@MM 6lJÇM;{–ò²28p;¿¤¤ÄR‰çÖ­[¤åçÓÉ8ÿôé-}PFNŽUŸ†–‹?€RÉ}0V5}­H-µÑ/ò-ä(ÀY¥ŒGL¸g„\ ’,ìWp'`!¹ü¡Ù!ŸX^vîS… ™šššÛ]ˆh­)//§¸¸Ø²’ÐçóQ[[Kaa!]·ßúõÍ¿4h†#Æ÷A`*˜Õ;N‘kF•j"ø{»‹àcA8š°‘BR7€Í†w£u7›÷ðˆw €RÇ€b#Ÿ&r}ä|9ÂðÎî óg8”ú©r‹Žúú÷–ÚÚZ***"vÈÑZsðàAŠŠŠ¨¨¨ ¡ÁŸBjÌ*LK“—° qÆMZÊNYçÂÛa­éçHÑU(eW6Șº¦‡¬Gp[ Dì@J˜1 qxÇ‹a€1ݸÆáõÕˆ'Ü9Ï<ó[$¬¿Švÿþýh­™4i:ÉÐ+]»rlÈÎÞ?ÿMNæüõëÜxòIX´(øâ^¦Š¯¾}«¨¯Ÿì³ñ)팔:ƒÖ‡À·l^é$?ÖœßÝÁµ1à¾Pês´.Dú$ s=¤Ó˜I,1–³@À×ÑÔÕÕqëÖ-F¿ð[Çãø!ø¢)E«®žRv¶Saºã4€¯Ú¼ÆI@ß|LL²åw± ™ïzl˜Ÿ NSŽcÉF ää#a΂Ã\!4ˆÃsæ ;ÇT#åä8çTÊ×8¾ Z'£T¤j–;²p¨£‘ T#Z¿IpXÎMÌyýNŸ(±¬DãÙú=ÿÏ%´ô] ëÖ/þÝ»aíZØ·.^„†y}ù%ˆúÎb¿£ìqøŒv0/f·ÇHf´™‡‘\)8¨H]ý\š·’nbnZçô&ž`o»µX²$‡/¼ø"¼ý¶Õ<‡J@Œc^ ŸÉ©—ýÿ¯£Tty§ÈË£mñþ ¦ÔŸ¦¦$¶nMçøqÙ|‘ì줤ħ¡Ûó>œFUU?.\H!5µ‰ÌÌO>ܾ€‘Ä¥šÐú—ØK³óÞ™h[s2^¼Xƒ|×ÂxèÒÆoµq£Õâ?Ѝð¬!8º`÷,nÅ@`¤A¦ñìESÚ >Ÿbùò /Î ÑäKMm"7w' |µÛóòI/æÎÀöí¡êRcÆœ ¨h£cq’DlåŒüžðÅnñAÒ“Y4ß±­­$õßváS­FTuš·ÓéébŽ|ðqüIà9¤z±”ÐÐâ£DÏ7mÔº'ÁÀiD¥Màó)fÌxš×^k)ÈÙÐÐ…W^GNÎd,$[}þ={ú’‘1Ûrñ|ôQ:=ö<ûö9kQ—X IÛrlj†Âþ¢ÎúÇýÓF2Åô4‰IJŒÿ4ðÊü#VbZ÷Fú1DËd‡cÆóŸ1Ü·ÕÈÏÏ ´Ô¢ÙDIÉÃŒŠ8.‘ó_º”Ì”)Sil ¯$ÜØ˜ÌäÉßçêUûõDï@cµ ¸Ï*ÓÏËüE?-£õ]Øè#¥Àtà&f§žÚ‚T$êÈ4²ˆØò&¾ÖG%ßÇÃ;>ìd¶1®^½›%K2#ôóÆߥ©É¾ßØíù åôi{©§NugåJû›ÃÄ)LÉMÀ¶ü´Ê@ ~¬ýZ'!OÜ‘–¿/eÀ³?~£nß´iÐ:|øLô ~‡Ï°Ò¿½G.Á*[PÊ]aC¨¬ñéi¤¡¡ ••öUœÝžßißÄöˆ)Ùáò=4’{`”HyØ‹Ö3ÐzZwGëhƒÔÃÏðÛŒû”qùòh‚K^‡¥hjîµNBëבÔÜN@,ý¸ÿ‡ì4¶Ybi}·ßaûsûױÙ'¡­áT·àÈû×´µùÍŠAáHdÐL.Ísî Ô!Yëû4ç<‚(ܶD’*kÔ2ˆOü&”Ý$%ý O O¦Ùhý7à²ØÓqˆFˆƒ°ÝŒ[`¡ÿúG€:´®DÒŸ¿@~Oîàõ6Þæ½EÜÖÖw{~çsÛ÷2¶žPêh½c-½;÷ù ZG|†y1J¿BÔ8Íœ³RUh½)CìÈîAê'¬øÒa)–(Àß‘R饈áyÜÿ²B¹(µ"†ûµ*Ntò£¹Æýù/P]ÝÛÑx»´Î ™Ÿb£r.f”Ú†ÈK=lBž _ ÷*$Î> ¥–úͧyÏeN,Š÷ç+ÆÃŒºŒ‘Ž@©pãìÞó7È.'œC¶ÈB©Depº‚Sÿž=¯‘•u²ÍÌ?eг¾NÆß)Í:‹Öë‘e€ó(•˜òTÙKŽ@JnïCž¾ç܉6òï[š7àðk?”:eøýCHn@dGp)çmsM?Í™€v%Áòó3xõÕq¶îQP°‰y󜉹9ÿ•+yà—lEú÷¿Ä¡C+éÚÕŽÊ}ëúÚ&Z§œ‚š¸&÷²û¨ö¿‡¨7Õ%ôž fá©©éÍêÕ…—“SËË/;W$ssþnÝ®SQ±†ìì™a» ÷èÑDyùû¶?´þ -ò#‚«ðp¥àÝwËÉÏßB¡ýRS›((ØDqqET:·ç9ò {÷¾Cv¶uvìØ³gÏ;ޛ޴ÿ#€ÖQê¤Í±£AÀÌ^ú¢”ýN‘m‘HG€;ˆhF®]KbûöA·ÃkC‡^`̘$'ǧšÛó9Ò‹]»úsáB ½z]#3óS† qV #V u’XR¡ß”Ö}꺅—ÿâŽ_ü!¤¤Ü`„£Lp)þäöüÆ*ò`EG0£ü¯Uh}Ål@Ê~ƒ-®ù÷Ó‚=(CŒ`€è]ö?IEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_16x16.png0000644000175000017500000000155113070106167016711 00000000000000‰PNG  IHDRóÿasBIT|dˆ pHYs±±õƒíItEXtSoftwarewww.inkscape.org›î<æIDAT8…]HSÅÏÝn3)½Õ¿"±B"©e$ú$½)RôDÆBèê!ð5B‹RZúˆ}0ÄšÚ g‚ч $Ó6knZS¹›è6wçÝNeeQø¿óãü€¿Èd2åètº›ƒáH0¼TUUuÿoÞ jmmÍjooàp8Âü®ÙÙYÅjµžùo°­­­kll,B’·ÈQ7IY^‡ÄzzzŒÿ †B¤ª’++d @ª3³LôÛøø-…œÛèèèE£Q’dËsòíyËFŽ¿ö“/^PUÉûÃä/ïÄúúújúûûU»ÝΑ‘NNN~sÍÏ“ƒƒü]Š¢°±±‘ãããkëMDHIIÁêê*l6¢^/ökµ¸¾\‰£. xOñx]]]Pµµµ$IÌÈÈhéííÐÝÝ÷x<$ÉÈÌ »ëêèr¹¾™§Ífc}}=çææ(Ëò ôûýkâôôôZMMM‘<5…ªæf444 °°>ŸÕÕÕ(**‚,;áó}Ú°ŸÁP.jGvZZÚÁâÇìÝ‹ÎÎNdffÂëõ¢¬¬ ùùùˆD"º‚ÍY70£Zà,XJXUîB‡­ÃÃÃúm;v*(($IBEEJKKa6›‘›› ­V ·Û‚7Z.½àÉ '#ñ³Ž^¯o1™L‰?¦'¹°°À{÷ŽÑéÔÓãÙÆÝt:Óèó¥RÙ CV®nßÞà¢ÑhÖÁŠ¢Àl6cbâ*+Uèt„$)HNV¡ÓÅ!Øà,€]KÁà©+l’SS뎟<)ØŸ=K<²Zß?ýð!ïDfh«Û#lÙ²†—/óPRòééaˆT¯”زۯ]¸õ(;èÌÎ~˜¸sg€ë9S“—g1Š"Q^îÅÎËHJúÖà<€FÄ,¯67Ÿž²H>XN_t4ž Ñhâ+pÖã¾1ÕÎIEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_128x128.png0000644000175000017500000002523313070106167017064 00000000000000‰PNG  IHDR€€Ã>aËsBIT|dˆ pHYs‡‡åñetEXtSoftwarewww.inkscape.org›î< IDATxœíwX”ÇöÇ?ïRìèÅÞ Æ’½–ر'1ÁäÚÍš›b~)¶h\ËMÔ4cn%ÆHSc,˜A%QT슠(Ø@¤wdÙùý1ìfvaQðÞïóì³0;ïÌìžï;ï™sΜQøP«Õm€ÅÀdÀ¦ x0Y­VkÙÀ”G=€G‰¢‚W©TtéÒ…ÈÈHrssv8::þcöìÙyt •ˆÿJ¬\¹²¥F£YÌlE¡sçÎ 6 {{{bccñòò";;ÀßÞÞ~Â;3ûhG]9ø¯"@Y‚7D\\žžž:ì³··wyIð_Asoˆ"$ø ¯V«sΨk”Wð†ˆ‹‹ÃËË‹¬¬,€ýÀË KXBð†¸wïžžž% +XZð†HHHÀÃÃŒŒ €vvv/½÷Þ{Ùö#ÅcA€Ê¼!Šà:uêŒýðÃ3-ÖÁ#@µ&Àü!ñðð ==à0V­VgTJgÕ’Bð†(B‚?1Õ•ÕŠZð†(B‚àZµj™?~úC„P-P•oˆ¤¤$<< ]º@nÒ,!ÁY[[[çªJ‚‡J€Ê|L LŸAA•5o_ /¿\áæÍBFFžžžÜ¿à,òqðpGQ6 ÆT¯Ñ@×®på ÐèÄ—ÁÆ‚ƒ¡wo‹te2233ñððБàà\ÕHP©x˜ÏøÐPèÓè œê|ð>ð%¼÷|ñ… &&‚ƒC…ÇU„áÀPµZWá†-Ue4ºråÊ–jµzƒF£¹ ÌRÅÆÉɉ·Þz WW×JQðjÕ*ø#ˆ/ø;ˆ•Ö®mFc;wBË–àï_áqÕ©S‡iÓ¦ñä“O‚¤çáÿûߎnØB°è ð(µz!`ð`8r°Z÷t°«'B¡cGúå˜8òò@­†¥K-2¾ÌÌL<==‰ˆ@Îw-Òx`T•å\J ÌŸ›7òì¹çàË/¡W/øí7©-ææÂÀgŸYt|YYYxzzrïÞ=¨"$¨ªŠà‹"/nÝ‚† ÁÎÎÄ‹ …o¶Â`:rrrðòòâîÝ»‘ÖÖÖC/^|§R:3å"@U|¹±¿~NüßÿÉ)£Q„W‘3ÁíJí´˜E€ÇNðÀ¸qRøï¾ _}õPºÍÉÉÁÛÛ›;wîDCÔjuôCéÜ&à±<þܹ°vm‰UµZùh±¤U± b¬¬¬†,Y²ä†åz(¥à±<@@€~v6Ìšë׃Rüç …Å‹¥!éÁhß^N³g­n6rssñòòÒ‘à&r&¸^ñ–MƒÑ¯ð0ÿàXYÉWy“5k–³ó#G`ÌÈÌ„×_‡ ŒJóøq2r²‘[ `7ÀGÁÊ•åì¿rssñööæöíÛ7­¬¬†.Y²$Ê2­—ŽB† ‡aÀÙ²ºw‡:uäkà@8tÈ´ksr`ùri£©U 4€W^‘Ž“ñçŸ0v¬þ?ÿYâ°n]ðßRL`'`#U…\ í¬Q£S§N¥eË–-òóó¯X±¢­eZ/úo®V«7a°Mº[·n 8¿ýíoëlÝ:ù¨äÝ”/_ÖÖÒè6rdé×»¸H#5ÑߎŽrªnÞ¼ŒÃèÑ‘3gÂ?€ªdc¨³3<ì\ S€¶ $C|¼\jZ <ÀÛÛ›[·nÜ*Ð *u&0üö3›æÍ›óÖ[o1nÜ8‹ _X½ºàŸMÈ»)X(9eÙ\"" „ÿ2òNgæ±±àáQÆŽ•Ó¾‰Â?¾àW—éHcn dYáØÚÚ2yòdZ´hÐ}úpûöm®\¹‚ƒƒƒÎ‹eŒ çÎÁµóÀyà2X ©‹­YSº\¬¬`øpì‘pI„P¯ž ø˜0ÁÈEÇÿ%ü‰¥˱찳''èÑš41ûòrÁÊÊ '''îܹCrrr]!Ä„Áƒï *c®4 Ôj5³fÍâÔ©Sœ>}•J…››Mr£™Ž $lm¥“FÝ4hµR—»v žxBNÇFU•Ó§¥—œ nnàã#µÍj†üü|¶mÛÆÕ«WâU*•óÇl±éÙ Pèf€ž={Ò¤Iòóó‰%<<GGG,¡C£FЭ›Œ×3WÏT¹ |úiéÞÕÇâÌ9]$'ƒ««\{VCá¨T*œœœˆ‹‹#11±NÁLð{PPÐ=‹´_Ò½{÷¦{÷îäçç³}ûv¢££-Ñ_åãìYyç'%ÉçB5¾VVV†3ñ@ÐòåË{Z¢íRµ¡Þ½{ãää„F£aË–-•²:°( …ïâòX_+++\]]u$ø›V« P«ÕÏV´ÝR  ( ýû÷§S§Näåå±uëVͺêáÜ9)üÄD¹€ßºUFƒVäçç—úy\œ !Ô‘ S§N–/_nJ¨K‰(s=¤(   ]»vzÇE».^¼Èøñãù÷¿ÿ]‘1™óçÿþ˜1òί&Â÷ññ¡mÛ¶|òÉ'Å>»ténnn4kÖ KW4ÐjµÔju¹ã*E¡( ­Zµ"%%…„„®\¹Bûöí©S§N¡zîîî|÷Ýw:t•JÅ AƒÊ;.Óqå ÷ïKcÏ/¿<ü @JJ 7ndÿþý(ŠÂàÁƒ¹rå o½õo¿ý6—.]BArr2&LÀÖÖEQprrâþýû$$$Ô܆zøðáÃfOÏ&þ"ABB „‡‡#ÁÀ©]»6‘““ƒ³³³Ù?ŠÉ¸r† {÷äz×®j%|€–-[2`Àüüü8pà»wïfÙ²e\¸p!ݺuã›o¾á³Ï>ÃÖÖVŽIIIÄÇÇ×B¸<8(((ȬÈ"“  ë´M›6z\¾|™Ž;RÛ æºÿþÔ­[—€€Ž=Jvv6Ç/ÔŽ¥¢Îôˆ:â⤅i×® ø‡-¬¬¬ˆŠŠâòåËÄÅÅ¡ÕjéÒ¥ ß~û-ëÖ­£KãF@EQèÔ©ÉÉÉÜ»w¯&ðÊСCC>l²¶nö¾•JÅðáÃiÒ¤‰>Ô¹`_¼|ðŸþ9kÖ¬aÞ¼y„††ò /àææF^^ò/GFÊ;?6FŒ¨¶ÂOHH`Á‚tèÐ;vò÷=z4®®®eÞ(Š¢ðÒK/Ñ­[7€ºZ­vŸZ­lêʵ1ÄÊÊŠQ£FáèèHZZ›7o&55µP÷ߟ/ "k?ûì3ÚµkGŸ>}ð÷÷' €C¦…¡ð‡¯–ÂOJJB­VÓ¶m[V¯^Mvv6-[¶dÆ >|˜zõêñùçŸóᇚԞŽÝ»w¨ø/[¶lˆ)×–{gµµ5#GŽäÉ'Ÿ$55OOO]þ<=FͳÏÊ¥jTT666¼óÎ;DFF2²,ç¿1\½*…÷®Ôúwï6j ŒŠ‚ß—Ö`Ýþ€‡…°°0ÂÃÃ~–‘‘ÁêÕ«iÛ¶-Ë–-#--fÍš±víZ"""˜5kä·ß~ÃÎÎ///“rŠ¢0nÜ8= „þjµzhY×Uhk˜­­-cÆŒÁÁÁ¤¤$}:ÕèèhfÏžM×®]9uêÖƘ¼¼<¬¬¬Êç`ºví/á ïü"‰‘ ‚ví¤Nس§ü{×®Š|KÓáééI¯^½“·ø6h ÷xddÈËSSeü^yžýiii,[¶Œ™3g¢Ñ?9.00Þ½{3|øpΜ9ƒJ¥ÂÕÕ•Ë—/ãééIëÖ­Q…µk×2wî\FŽIýúõ͈ ( #GޤOŸ> ÃrýÔjõK`†˜žžŽ¿¿?ééé4oÞœI“&WØÊ€½½=·oߦE‹|ôÑGÌœ9???¦NʦM›¨ŸÍ—gÎHé=óŒÜ¾UŽÐthÓÆìË A—øÆ¤¥¥±uëVlll8zô(K–,áðáÀüq'L˜ÀŠ+Œ†ÎéHð¨¡#µµ5ÁÁÁ¶À¶eË–½b4&°(RSSÙ»w/YYY´hÑ‚I“&rL˜ƒ¨¨(š7o^èz___>˜2…†Î€èÑåàA°·'""‚fÍš•kITQÄÄÄ0dÈnܸA¿~ý¨_¿>¿ýö›þóaƱjÕ*ž~úé‡>6Sae$6 €€¼2gK  mÛâ;ž^2„1cwû6goÛ´aAr2k.dÓ¦MôéÓ‡_ý•zeè–FË–-ùæ›opssÓý`€ôz.Z´Hgp!!¡J%þÒÃÊÊŠ†Fv¯ >kkkŽ9bS*RRRð÷÷'++‹–-[òü£BÂ7Šøx:»Û·IiÕŠQ·osoçN6íÚ…V«ÅÆÆ'''²²²*ÂÃÃùôÓOñññѯåžyæ¼¼¼Ì~üU5 2­V[²h(ü¶mÛ2yòäJ>—/£éÒ…u/¾Hr7L«ÕÒ¼ysΟ?φ hT™;1 `hÆöòòB«ÕòÌ3ϰvíZZµjÅéÓ§™1c†îhÙjaÆ'@bb"{öì!++‹víÚñÊ+¯èíùÃýûÒpé÷i{ãK×­C£ÑЯ_?¬­­¹uëü±Q-Ü\!Jl¾uë³gϦ}ûö¸»»“ŸŸÏSO=…··7ûöíã•W^açδjÕŠC‡ ᪎(F€ÄÄDüýýÉÉÉ¡}ûöLœ8±ò„ñ"têD¼—YµkãììÌÉ“'9zô(¾¾¾ØØØàççÇ«¯¾Z¡ø¤¤$úöíKÇŽÙ½{w‘¡Ü×ûäÝÝÝÑh4tîÜÎ;Çøñãõæê&MšðË/¿ðÝwß±ÔBéã5Š­jÔ¨Ann®^øÆ´È !9Y:v¤u&(7&33³˜¦¿oß>\\\ÈÍÍÅÅÅE¿Ójµìܹggg“M«îîîÌ™3kkk|}}4hŸ}öß|óî@HZµjÅÂ… yíµ×ôß;;;[w$LµCIJ !ŠÀÉÉ }tŠÅ’"ýø:á>,7÷—‚_ý•ñãÇ“››ËرcyóÍ7ùè£8sæ Ï<ó &'®øá‡˜3g5kÖÔ ¾yóæ¼ÿþûÌ™3§˜r÷¸ ØÜ^©Â×Ýù:H¿mÂ3f ¿üò /½ôûöícß¾}€ÚÔ©SM¶dff’””¤|VVvvv,Z´ˆ¹sçR³šEY Å0a„ŠlEjªŒÝ;uJfY:|Øäm¶ÁÁÁ¬Y³†¡=;väøñã&Mÿ¹¹¹xxx°téRý‹ºuë’™™Iff&M›6ý¯>Q+Mø'Oš-üI“&1`À‚‚‚hذ!ÿüç?©Y³&¼úê«…]ÇE——‡»»;mÚ´aöìÙÄÅÅQ¯^=æÏŸÏíÛ·Ù¸q#B¦OŸŽ———¥¾mµƒžº‹z¬RSeÈö‰rKo@@A–Ó°dÉ:wîÌòå˹~ý:?üð»wï¦V­Zìß¿Ÿ—_~¹ ´Z-~~~tîÜYïf®S§óçÏ'&&†U«VQ¿~}fÎœÉÆ©Y³&/^4/Bé1‚^ ìÕ«—>ŠÄÀ}X~¤¥Iá?.…­ZUxÀ mÙãÆ#;;›#F°k×.jÔ¨ÁÏ?ÿÌâÅ‹‰ŒŒdÌâôéÓY¶l76ÚVVVV©± æ(±±¡¤¥E›ý}* *•ªP޽};Z´x®P=@š9_xáEaذa<÷\áÊSîÑ;rZ´Â7' „ 8räcÇŽ%##ƒ§Ÿ~šüü|Ο?È+3fÌàã?¦©3Ž1˜C€C‡Þ!2r{…ú«Ltï>—^Ú\¨L¿3 66–ôôt:tèÀ7°²²Ò%+2‹Ëݹ­ZÁXìÎ7DË–-©U«ÄÆÆrïÞ=T*&Là—_~aêÔ©Ø™œ*¼dh4“;7nüFb⥠÷YY°·oGÓ¦½yð ƒ5äoc…  ÒÇÇÆÆ’––FÇŽ‰ŽŽF¥R™O‚çž“áÛ?ýT)ÂfêÔ©¸»»zv?ûì³ìܹ³Äé¾þ<+W®ÄÏÏO_æìì̧Ÿ~ªßyÔ¡CFÍŸþÉèÑ£Iü€1Œœ,•*–{÷:Ó´iáÄVÈTˆÐ¼‹nݺ‰?þX¨Õj$, ѪU+±bÅŠbŸ]¼xQ¸ºº EQ„n<ýû÷/qGvvvúziiiB!‚‚‚„›››¸uë–ÙãËÊÊqqq&½¶lqj5…^ÑÑ!ªîËИÌD® ¦üàÊùóçÉÏÏÇÅÅ…   òòò,ºç¿Y³f$$$°dÉ222Xµj7nÜ`ÕªUüøãú]G}úôaåÊ• VòN§~ýú±ÿ~FÅÑ£Géß¿?œ$MHHˆå\ÕÆÌ~*d6ßi†…]ºtaüøñXYYÑ¿‹’àÏ?ÿdìØ±¤§§Ó£G.^¼¨èÚµ+K–,ÁÕÕÕäö¶oßΔ)Sôæã:uêðÖ[o•kWNE—Ó§K3HU…1G¿9dzd(ºT%...=z!D±ÄåEëÖ­9r$;vìàìÙ³€tJ©Õj³|Eøt{ÛµkǼyóÚ®œ’ CÊJj]‰Ô‚¦.+Éå§#Áz f‰Ë—/³mÛ64 !!!8p B²D‚²²²pqqÁËË [[[æÎËpppàܹs >\w˜sõÁäÃxð|)õT@`R‘rx(ÅéZšÏWÿ¾7øŸÈÈH¶oߎF£áرcüþûï¥4Q28@«V­ô ZµjŦM› ÂÎÎŽ/¾ø‚>øÀäöj×®ÍÁƒ™7oW¯^eíÚµ8;;€ƒƒ§OŸføðá$&VÉC¼ã0à…<£ ´C1#ÏN(j÷rZ¥Ä¯–åôÀ›HèoÅÈÈHýLpüøqöíÛg¶3ÅÙÙWWWž|òIV­ZExx83fÌ`À€ìß¿_Ÿ AgÞ5ŽŽŽ¬^½šfÍšéËž~úiiذa!äææâîîN¯^½¸fÖ‘#GžVr¥”:‡)¿ E  Óê_.½yS‚ýt$ÐÍ\½z•mÛ¶1qâDN:…‚±cÇšù„«W¯Ò¾}{¼½½9wîŽŽŽ„‡‡3tèPbccõ0£5Rƒy>’.üuˆ•1d#•G/äcà@A™”'òSï`„ÞÞÞäååqæÌ™*C{{{ñôôäòåËLš4 '''iÔ¨áááŒ1Bw¬{ÕBR“8hP~ãÊÝY#e7Jd (o诎߯ÄÄàíí̓8sæ {öì©$ppp`Ê”)…¦~'''>LÏž=ù׿þõÈDFq)ø`äYK:„cpÊ“Ž)‹’K?X‹$ƒ-Z´Ðï%|ê©§xùå—-fþ𸛂+*¼ ¬3,¼yó&ÞÞÞäæærñâEvîÜYh‡íÿPu`‰ÛRG‚¯ oÞ¼‰¹¹¹\ºté$¨¢°Ô¼¬#Á*ÃBÙàÒ¥KüüóÏÿ#Aƒ¥ã‘§úêÉÓÒÒ¸~ý:NNNú':wî\õ×Þ¨hL`2yUQœ8Ñ_ß®œ:Õ„&M2¨_¿ô>Ì©¯Õ*øûwd×®ÎDF:СC¶¶Æ¥©,)|,4,0L)×¹sg&L˜P-ÃÊP׬éÏ‚Î!þúõsؽۗAƒ¢¶kNýü|/¿<‘½{ÿJXÕ±cAA›iܸx¬deI`’zÄÆÆê“I‡‡‡ãëë[æaI#¢£°xñP½0RSkò¯µH}_ß§  "¢!Ë—ç¬Ì[ð# ÐéQ±±±xyy‘••¥w&ý·‘ ,¬ yyÅŸ¼—/?AJJq¿ˆ¹õCCo„9v¬¹ÑòÊžƒc„º™ÀЙTÝqçΓ×lØ0ËhyêÖ-~¸¥ê;8/áÅÀJ¸¸8= ®]»¦-¨ŽˆÅÏÏ­[·’™™Yfý~ýnѵkñS__{í ÖÖÅWHæÖŸ2å<µkO§3{¶q× $€­"ª„×Ïe~+!ιn«A%À ÃKâââøé§ŸÈÈÈàÚµkÕn&HHH`ïÞ½øøøÃLÊhc“ϯ¿ú0nÜj×ΣaÃ,>ø „¯¾Úo‘ú­['àIÏžw±µÍ§M›d6mÚ««ñKR³¢Òj\F¡(%Ç~ ‘Jñ€¤#(JQÍc9’ z4lØiÓ¦Q¯^=Ú¶m[9É*€¢«€ÄÄDBBBˆˆ?—ÎùÊèѹäŽÔ£ª›‚Mý¥W#DŠRQ+ÎÇH£¡üM IDATÑǺ‚„„<<<˜6mšÞ£X) )+ˆÔÔTNœ8ÁùóçB Ñh8þ<¡¡¡&MýU¦ ;à l³@ŸK‘$ÐçY3$ALL [¶l©2$HKK# € . ÕjÑjµ\¼x‘Çb¢9sí „Ø‰¢TàÀ?=Ôï…H°yóf= |||*œ—¸"ÈÌÌ䨱c“™™‰V«åÊ•+=z´ØyÕæ =0p·PßjdœŠÞ˜˜¨Ÿ tΤ‡M‚¬¬,BBB E£Ñ Ñhˆˆˆ 88˜ääRëÕæj[KÂE1¾¨4« Þ ‘`Ó¦MLŸ>ooïÊÉS\ÙÙÙ„††rüøqrssBpõêU<¨¶l6œ?߈ڵóèÒ%•ªôÀsë'&Ö&"ÂGÇ Z·.™¸e ™ÂÅM¡kʸάFê:2’’¢€$Ay¨0<àäÉ“ëN]¿~]Ÿy¤2؆W_@B‚ÌMôì³wÙ±c;-[¦X¤þçŸ÷cÑ¢az âäÉçÙ¸q5j_f—eòAF•b!B˜ŒGéXÌ7,HIIÁÃÃäädnݺ…‡‡G©iáÌE^^¡¡¡¬[·ŽÀÀ@rrr¸yó&?ýôžžž†ÂÏaΙáLžÊY!¤¤ÔdâDW½0Nj¬YÅô*Wý#GZòá‡# ™½½»ñå—}Ö/‹(bÀï—q]y°˜gX › ’““õ&äììÂ[MD~~>aaa¬[·Žýû÷“™™©'ئM› O÷Ê@ÎJ èÐA¦¸-Çñ5Eqôh ’’ŠÇh<ØšÌÌâ9sëué°gñrSLÁžA}!*–~Ë8> ˜œššÊæÍ›IJJÒ;“ÊC­V˹sçøÏþƒ¿¿?ܹs‡­[·òã?rã†~¢ËB†¸µPb@µe!„‚̃Q9õKBÙP”|ŠXïÛ ©m |ŽxxxèI`ÎL „àòåË|ûí·ìÚµ‹””âããñóóã‡~Ð[ô³;rµ3°¼æôïÓ¨Ãføð(£6|sëwÅ(1Æ3¾¹Ð4g¢ìŽ)…Å2B¼€›b'B¬FˆŽÑ!æ#Ä($ äÖàI“`þ|R³³ùñÔ)ö È׃ñZXYYYà4ð)r?ûËï^BpéêU6lØ€ŸŸIIIÜ¿ŸmÇŽñ½—5’ljΛϡCѤ¤"D8B׬tpt„¥KaÇðò’ã3#°¥Aƒ|}w ÎèÕëîî{-Rÿ¹çnòÅ EMzŽwß53®ƒJÈ"ó…AF>÷*ø,ÕÈgéGAˆ >ÏGˆÈ‚k³b^A¹¡á=Ž‘íÍ™#ÈËä剙™¢Ûùóâûï¿Þ99!„"„h"„è „°ÕjBˆ&wŸ~*Þ}÷]ѳgO¡R©C†Èö6nÔrýz Zm6BœEˆä‚þ/"Äcx•ï¾KCÁ¼yÉ$$ä“—§%.N£ÿ®>>ÀÍ È05GPv¶µ m*.^|Rhµeçò1·~BBmÒ\ÄÄÔ/µžéõù<!z˜A€)Ÿ…"„cA™ !f!Ä#€èè(„¤¦ &OÔ¬)êÖ­+^ûðC¡V«Å~~⻜‘.„ˆŠŠîîîbá§ŸŠgO!}}…µµµ>ÉC†ÈŸO«Õ DBØŒÃ!ÖŒaG‘qYPžƒK¢†Áï¦ñ³j5›«[’(sãRxºŠâ«„Òðïo (r¥(ZŹƒ­8Z¶¼È#A½½!'‡ŒŒ ¶¯_Ïýû÷©{élÚ„ßO?áååÅÝ»wÉKLDõöÛCìÀ†næ@fΜ£ï^CQ’ þÏÞ¢ñaìèÉ}(Ê2%·àšH¤â ÐόߡÊÀ<(J°£Héó˜²wUˆzH§R$ŠrÚH ßR¯?wî È—žžŽ‡‡÷ïß'>>ž ©©\nÖ ¾ÊÌäD×®ò YGG°·? †3yrÁéÔAQnù~dÒL™w£(v)»Xð^…¾%£<Ž÷ÅH]ËðZSˆÔ¸ ÞÍ>/ýxmoïUøø\Cæ(P@žeüÓÞ½ØïÝËínÝJ¾61ÑE¹[¤4º„ÚºòfF>»e¤,½àÝœ ÜU懄Éios9úÒÍÃ%õË²óæ “V½ÁLõí·Røß}÷W¾¢œ@Q^ta3ÆÂßKZDëÊ͹F‡H‡Ù  ÔdDа°&„…5A£)[ æÖOO¯AHHs""Ì<3ÈD,þ”œh¿8b‘kí¶·b´3± H}M½z cÆÀÙ³ðæ›ç6 ÝéóRÚiQFùÇ£‡ZM0r//j5jÀÁX½³g3~üDnÜ–Åví’Ø±c;Ý»Çm×Üú[¶teÖ¬ô–Â#¢ØºuööÅm'å •ÓéweÖ+|MðÐ(Ô.ƒÞ‹ŸZ]2¾Þ¡V-Jii™ÀDdb”½möFuJ ýJä¯q¨ Ú8bÆxL†F£bâDW½0®]³çÕW]ÈÏ/.së_»fÏôé/28Ж… 'ö¬HTð'”ºóÜ(V sº#ÄËá€]€1_‰úññ³ÈÊJeà@+„ˆA7E Ñ ™÷¸´6à;„¨]p £ÐøµàQgqDD4$2²øÄþW¯?þÎÜú¿ÿÞÎè>‚ŠøŒCQ’¯Ì¼æO`6ÒżH@jÑù+Ç@ñ`÷’±‘ÚµßFêG" !.´y(-‰¡ðp !‚Êßà:æÍFÕ: éø(Š“e\ÿ% Ì˜Æ Š²!~F#=‹QÀo€Î¿Y4Ú`_‰ý(ŠB\G*^­i×"ÕqÈ©ÜØæ¾D 7’x½‘¯À×(Jј/¤oຑvî »sFÇW:%бcB1åÌÉé>íÛÏdjnýQ£®Q£††ÜÜÂê]I¾€ªƒ¿LÄ£+¹Ÿ!F­œ†ZMtI–À3g‹öíß  íÛ¿-ÎkT¢µÎÜú[¶tvv õõGš,’’j•b ~˜âíBV6!j"Ä{få«QÞ•‰©ý?rÈËS‰Ó§EX˜£ÐhTešlÍ­Ÿ–VC„„4‘‘¥Ö{;0ÞÖ!½niÈUr*u-°Æ=ö°¶ÖòôÓ¦‡œ™[¿^½\úö5þ.Ô®É-Zã© Û •Át¤®ágÁ`ÓÒøaâ3»Ø4¬U‹Q@£Jî«Ü¨i:ª1„ 釨’¨ú):þ‡JÅÿü¿Ç®ÀžgIEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_32x32.png0000644000175000017500000000370613070106167016711 00000000000000‰PNG  IHDR szzôsBIT|dˆ pHYsbb8z™ÛtEXtSoftwarewww.inkscape.org›î<CIDATX…µ—L”÷Ç_ÏypÈ( Ð;f&õçnÿˆØš: MuWgý1Îh´[CÔ(ËÒ:á0sÓ¶HN.‹(`ç²m,ž €™’@gÅÁO)HAAO8{r÷Ù¿µéÞÉ“|žïçýþ¾?Ÿçû|…´4UDDÄ»ááá)ÍÍͿڹsgÍË>Gù>ÄZ­v]PPÐñññ?›>}ºJD(((p466®Ú¶mÛµÿ‹€‘ˆö‹V«Õáp8~½cÇŽÿü`z‰5Í®ùóçë‡QTTTûöíµ[·n½ò¢"žIl±X~sôèÑÿÚív¯øáó‰\¸$ÒÞ.#ÂçóÉÙ³gëÍfó씸UWE‚7‹l4 h,.&ÂjµÞÊÊÊš÷Òć¶D<ÐÊ*—Ëß`±ˆX­#:aµZ™™™qß›øúu‘Gúï¿úJ¤«kÀ‹EäÌq»EVìùèÄp……… ‹åÏ‘‘q©¼¼Ü7t·n‰„%‹¼ýA¿õ?h}^žÈ™3"ÒãÆÂß‹üñÈHŽù¤°°ð¶ÙlÙ‰ÔÔÔ®óçÏ‹Ãá6ùÜ¿DZZzb¯Wäl©ˆÓ)"ùù"ÃÙFAIIÉìììECùU111ØívèììäòåË,]:  –%B„5ÆŽ…+^¨¶Š‹‹ihh ««ëµéÓ§ç›ÍæÅÃôЍ­­¥££ƒÊÊJrrrú„ôáØ±òÕ«_ˆüÞ½{œ:uŠM›6±`Á C´^¯Ï;tèPBïõÀ 3fÌàâÅ‹èõzrrrGDP>ù4¾‰{ã.X;~›4œÔãñ`2™P—ËEFF.—‹ÐÐP C4—••õ»íÛ·õ l6 DEE‘˜˜ˆÑhääÉ“|ºlªÀ@X³õ·=ªƒúIÝn7"‚×ë%''‡ÖÖVt: **jHƒÁ0Q¥RåX,–÷HMMíº{÷®X­Vié­8yúô©ÔÕÕIÑÆrfíZ)//f555I\\œ¬_¿^ª««Åår=÷òf£ZQ®^½Êœ9sÐjµ}*Õj5?­®Æ5~÷÷îŸ2eJç‘#GÄçvféCcc£˜L&™;w®¼úªòR)èÐÈCDb‡øë¤I“$¢¹¹Y233eùòåíª×_ï$2’>￟(ûöÅ‹Èà8%å-9tèMAzßüy§"ËÒ;QQ»KJÞ«Ñjƒ—/§õÑ#:çD}}Wy@ÀMÑh’IJº„^à«-¾Q(ŠÐ›¹±J%(Š JA#"¡ˆ8¹È爼ÈJDv ¢çÂ…k“&O~¼)7W¦xÆ,]ZIK˧ˆ„ ² ‘‰ï´|™ôÿå(Ê#`éo邱$$üãNCÃßr½Þú[ãÆýÁ{îÜŸÐé:€ÞMÿ[¥­cÜä»"=NîÙ³“©ç@<0NM]ÂÇÏz¶ˆÓÀuÿC²ýéh@QlˆLâ€6 Ÿ¯šÍ›‹é9ÊÕs·ýó^ð©ÔÅŠÂ[ýV´½?*Uo FƒÈDæÒ3RsZ±ÝÝt½H þܼáY§ìðIEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_16x16@2x.png0000644000175000017500000000370613070106167017267 00000000000000‰PNG  IHDR szzôsBIT|dˆ pHYsbb8z™ÛtEXtSoftwarewww.inkscape.org›î<CIDATX…µ—L”÷Ç_ÏypÈ( Ð;f&õçnÿˆØš: MuWgý1Îh´[CÔ(ËÒ:á0sÓ¶HN.‹(`ç²m,ž €™’@gÅÁO)HAAO8{r÷Ù¿µéÞÉ“|žïçýþ¾?Ÿçû|…´4UDDÄ»ááá)ÍÍͿڹsgÍË>Gù>ÄZ­v]PPÐñññ?›>}ºJD(((p466®Ú¶mÛµÿ‹€‘ˆö‹V«Õáp8~½cÇŽÿü`z‰5Í®ùóçë‡QTTTûöíµ[·n½ò¢"žIl±X~sôèÑÿÚív¯øáó‰\¸$ÒÞ.#ÂçóÉÙ³gëÍfó씸UWE‚7‹l4 h,.&ÂjµÞÊÊÊš÷Òć¶D<ÐÊ*—Ëß`±ˆX­#:aµZ™™™qß›øúu‘Gúï¿úJ¤«kÀ‹EäÌq»EVìùèÄp……… ‹åÏ‘‘q©¼¼Ü7t·n‰„%‹¼ýA¿õ?h}^žÈ™3"ÒãÆÂß‹üñÈHŽù¤°°ð¶ÙlÙ‰ÔÔÔ®óçÏ‹Ãá6ùÜ¿DZZzb¯Wäl©ˆÓ)"ùù"ÃÙFAIIÉìììECùU111ØívèììäòåË,]:  –%B„5ÆŽ…+^¨¶Š‹‹ihh ««ëµéÓ§ç›ÍæÅÃôЍ­­¥££ƒÊÊJrrrú„ôáØ±òÕ«_ˆüÞ½{œ:uŠM›6±`Á C´^¯Ï;tèPBïõÀ 3fÌàâÅ‹èõzrrrGDP>ù4¾‰{ã.X;~›4œÔãñ`2™P—ËEFF.—‹ÐÐP C4—••õ»íÛ·õ l6 DEE‘˜˜ˆÑhääÉ“|ºlªÀ@X³õ·=ªƒúIÝn7"‚×ë%''‡ÖÖVt: **jHƒÁ0Q¥RåX,–÷HMMíº{÷®X­Vié­8yúô©ÔÕÕIÑÆrfíZ)//f555I\\œ¬_¿^ª««Åår=÷òf£ZQ®^½Êœ9sÐjµ}*Õj5?­®Æ5~÷÷îŸ2eJç‘#GÄçvféCcc£˜L&™;w®¼úªòR)èÐÈCDb‡øë¤I“$¢¹¹Y233eùòåíª×_ï$2’>￟(ûöÅ‹Èà8%å-9tèMAzßüy§"ËÒ;QQ»KJÞ«Ñjƒ—/§õÑ#:çD}}Wy@ÀMÑh’IJº„^à«-¾Q(ŠÐ›¹±J%(Š JA#"¡ˆ8¹È爼ÈJDv ¢çÂ…k“&O~¼)7W¦xÆ,]ZIK˧ˆ„ ² ‘‰ï´|™ôÿå(Ê#`éo邱$$üãNCÃßr½Þú[ãÆýÁ{îÜŸÐé:€ÞMÿ[¥­cÜä»"=NîÙ³“©ç@<0NM]ÂÇÏz¶ˆÓÀuÿC²ýéh@QlˆLâ€6 Ÿ¯šÍ›‹é9ÊÕs·ýó^ð©ÔÅŠÂ[ýV´½?*Uo FƒÈDæÒ3RsZ±ÝÝt½H þܼáY§ìðIEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_256x256.png0000644000175000017500000005415513070106167017075 00000000000000‰PNG  IHDR\r¨fsBIT|dˆ pHYs;;̶¡ƒtEXtSoftwarewww.inkscape.org›î< IDATxœìgTW†Ÿ "Øb7*F½¦X56ìš"¢F¢‰$¦˜öE’¹c4Ѩ)FR±ƒ½+ÕVÔX°#ŠŠ P@ióý/Þ^à6pžµX,Μ9s€»ß9eŸ½eHH(!—Ë+ŸŸÏh©r lÙ²}Ò­Û3 K ³u$ì# _™C@o¹\~Ïâ“°(’<åcø2™ AÔ‹»¸¸ôþúë¯ïZ¸‹D€§¹\î.“É>á+t¾³³3/¿ü2:t`íÚµ$%%©W9xÊåò4 wWÂBHð”aŠáwîÜ™²eË››ËŠ+¸té’zõÿ€^’”L$xJ(ªá+£GN=ärù ³w\¢HPÊ1‡á+“››ËÊ•+ILLT¿tÚÉÉ©ç·ß~›bžžKXIJ)æ6|eòòòX±b…68ãääÔC’ƒ$¥ K¾2ùùù„††rîÜ9õKg§׋԰„U‘ ”`-ÃW&??Ÿ°°0Ξ=«~éÐ]ûG€Ž- _}"P¦L™“&MºfÖJ˜IJ(¶6|eòóóY½z5gΜQ¿tq:pÕb—(’”0ìÉð•Ñ#IŽŽŽ=¾ûî;½C Û# @ Á^ _™‚‚V¯^ÍéÓ§Õ/]vttì.‰€ý! €S _AX·n'NœP¿tqaPcïPÂvH`§”4ÃWFŸ<ž\´E¿$4‘ÀÎ(Ɇ¯Œ ¬_¿žãÇ«_JF\¼`ƒnI¨! €PZ _Aذaÿý÷Ÿú¥«ˆÓIlŒ$6¦4¾2zDàÐS.—'Ø [‘ÀF”vÃWF6nÜȱcÇÔ/ÝDœH"`#$°2O“á+#[·nåðáÃê—n:88ôœ“'OÖ˜'H˜IЉdøÅ'22’½{÷ªßúÈåry‚„ù ˆH†o^¢¢¢Ø³gzñ=‡¾“'OÖ"H˜ILD2|ËÍîݻՋÓO$°’‰døÖA—}årù~t©T# €$÷>111ìÚµK½8ÓÁÁaÀäÉ“5.HIt ¾m‰%""B½8(—Ëc¬ß£Ò‰$jH†o?è™L6(000Ú}*mHðÉðí" ’ËåQ6èR©â©Éðퟸ¸8ÂÃÃÕ‹³d2ÙàÀÀÀH[ô©´ðÔ €dø%‹}ûö±sçNõâ,àu¹\®1D0ާN$Ã/¹èG€—\.ßlƒ.•xž(é†ð ìÙ‰‰ +BëÖЫÔ­këÞYdzeËõâG2™lh``à&[ô©$Sê ¤þ¦M :‚f9: A0{64h`ݾيøøx6oÖxáçCårùFt©ÄRj ¤~A|öüú«qõÝÜ 4ú÷·l¿ì]" “ɼ7Ø¢O%‘R'%ÝðL›ß}gÚ=..pà´ic™>ÙGŽaóæÍ‚ \œ “ËåëmÔ­E©€ÒbøW¯ŠÃùÜ\¥Bgàu 3P1²þF@íÄ|—. éJ_zÑ!¹2™lX``à:[õ«¤Pâ 4¾‚Y³àÿS*¨ lZk©ü'ð! ôùOL„çž³dí‹£G²iÓ& †Ëåòµ6êV‰ Ä @i4|ï¾ ÿþ«Tð;¢‘뢠ä»e‹×Ž…jÕ N = h;vŒ7ª‹@>0Z.—/·Q·ìž2¶î€©(¾ ¥Ê𸺪\ÕS91ÇŽåÊ™¹C ŽOOpw‡èh»f´mÛ–2eʰnÝ: ÅŽ@ˆ\.wËåKmØ=»¥ÄŒJó_ðõU*(ÌD¸(•_>”fº..pý:<£õ/T þûzö„Û·ÅŸ=< *ÊîöOž<©.ù2™ìÀÀÀ%¶ê—½b÷ð4¾‚¬,hÔRRÔ.T:åG‡GJŒ ÿücæ?.ZšjùO?©-VاNbíÚµ"Œ‘Ëå!6ê–]b·ð4¾2Û·‹>yy†ë*hÐ†Ê•ÍØ‘3g {w¸¡6ÏøüsÑûÈNIHH`Íš5ÚFcÛª_ö†Ý ÀÓnøÊlÙ£GÃ;†ë¾ü2¬[Ï>kÆœ= ݺiÿgŸÁ/¿˜ñA–A‡cåry°mze_ØH†¯ÔTøùgX¼nÝÒ¼Þ®|ø!øù‰nÁfãìYñͯ>ùôS˜3ÇŒ²,§OŸfõêÕê" Èd²ÿ´U¿ì› €døÆ!pú4\º$®T® ­ZAxعs¢ñ_¿®Z>aÌkZ–óçϳjÕ*òóó•‹à#¹\>ßFݲ l&’áÛ)çÏ‹Ã~uã7,™ÍßEB|"—Ë·Q·lŽÕÿ›’áÛ1çÏ‹oþk×TËß{‚‚J¬ñ+¸pá«V­"OueUÉd³U¿l‰Õþ£’áÛ9—/Ãk¯‰ß•y÷]ÑølÓ/3£K€Oår¹‘g/KÉðK—/‹Ãþ¤$Õò1càï¿Kñ+¸xñ"+W®Ô&ŸËåò’·ÈQ ,&’á—®\ÿÒ%ÕòwÞ=ŠJ™ñ+Ð!Èd²o´Q·¬ŽÙ@2ü„.ã÷óO#•RãWpùòe–/_NNNŽú¥oårùt[ôÉÚ˜M$Ã/a$'‹ÆŸ˜¨Zîë ÙøóóÅã™™P¥ T¨Pü®Z="ð\.Ÿf‹>Y“b €dø%«WEã¿xQµ|Ø0XºʘvH4?Ö¬•öî…ŒŒ'×êÕƒ¾}áý÷E§%{äÊ•+,[¶LCd2ÙäÀÀÀïmÔ-«Pd ¿„rõª¸Õwá‚j¹·7,[f²ñŸ;#GŠgôáà î&Λ'žX´7ôˆ€<00pŠºeqLÉðK07oŠÆú´jùС°|¹ÉÆŸ îªÔGÏž°m89™ô(«œœÌÒ¥KµMfÊåò[ôÉÒí=.—ËÝ»wïþ°¨‡­ÀÙÙ™Ž;2lØ07nL?PÖ 3StoÏÎßDfõŸ7@~¾h,·n‰Ïµê›ðæMèÑCÓø½¼`ÅŠ" ûûôÑ\?Ä×B-ļ=ùª—.]õÚk&=Î*T¬X‘úõë“ î1ع[·n®111¥.‘Á@ixã'%‰^¬7Ч[Q£Ê–OÑ £FY&’NAÁ“ùñž=ÚçÇ|mÛšÿمܺ%¾ùÕ“ ¼õ¬\Y¤×ñæÍâqe†“€Îvÿ”t§reÑÙP#ò‘’’BHH>T¿ô“\.Ÿh‹>Y P _Ęr9hþ/Uyî9†®]Í÷üóçÁÇGÌê£ÑÕ~î\ Œ nÝßü§N©–Ãø¾üR-€ +ÞÎ]DQP:X:éÑV!%%…%K–­~i–\.·¿((EDCJƒá+øøcøÝ„c..°aƒ8´-.§O‹ÃÜÔTãïéÕKœ›m攚*ÿÉ“ªåýûÃÚµÅR›wÞ³…À;znl}òãÆZFv†˜-—Ë¿´EŸÌ¶ÍÞË‚ Ì@‹ñ»ººÒ½{w>ÿüszõêeׯ¿v­ãw<€šš—=§¦,ji#?Þ~[‡ñ?4@5¶ßc""`º¹ÜORSÅ7uãï×¯ØÆâôE…ßt•÷jI¼ë×/Öã­B­Zµ5j”¶Ïùr¹|–-údn´ €Nß0a]»vÅÅ÷qÔøQÝ™³:°¸$!G¯Ÿ£òWHMU É]¶mèªà œnûÀ& ©jµ¹sÅÊb‘–&ÿ‰ªå}ûŠaƒÌðÿ2D­àÐ øˆÎ"Îÿ?º!æð}LӦвe±»`jÕªÅèÑ£qÕ\°øB.—ÏÁbjƒî^2™Œþýû—ø_m_º øÊ }uÙ€š¿WTTñž£V0XÅ“Å1G"XÄóÇܽ«EÀ|Äd]JÌœY²NëO*A¿*@Ö¯_ÏuÇ;F¹ºZ@3=7ôRý±¸Sû{è©ü  æ!Wäçß»'ÆíW-ïÝÖ¯·=ÌȈ…¦0}: lÖnX…š5kâëëK9Í­¢Oärùo”PP7m•òóóYµj—´núÚµk«-n'º‚Aç3T‹Š›ïBc~û;âÔCæšß»'ººKž§§EŒ |yqº3i’áæ=<Än|ýµÙ»a5jÔ¨Á;#»»»ú¥åry\./q§§n0îÀ@h·nÝ4~;€‚‚¨W¯•*U²Z‹‚££˜ÇBÅçeâÜÑ9å brÍw]ª÷÷o¯¨T©*‡›¼,CðqÎü 0•!rÓ¦0eЉCäôtqˆH-Sh¯^âr»7ÜË”7>ø@\twý)*T€&M`à@Q ~ÿš7·X7¬F¹råhܸ1§OŸV÷|¨Ó­[·Í111‚ŽÛíðð)ÿär¹Þœœœðññ¡žÆ2°}qê”èäcê‚Zûö[ü­8__1élØ`â9=]|ó«;té"¾žÝ´ê$ŠÉíÛ·Y¼x1÷ïßW¿´xO.—h¹Íîp¦¢c¿à•W^Qù977—åË—s]=h¤Ñ¢…x°Í”5¯Æ!,Ì<ûðü!:ß‹L&î\˜düâ›_Ýø;w†­[%ã· UªTÁ××—òåË«_, µ¢“yÑqäÊÝÔVuúõ뇓“W¯>ÉP™ŸŸOBB5Ò6²š5ÄÑ’fK ѱeåJ¨UKw=Spv†áÃEÃ>xP†ŸúõEWá±cMx@f¦8¾Ž‹S-õU1­ÿ_J åÊ•£I“&Ú¦­RSSwëÖmCLLŒ]d¨d–לŒ7€øøxâÕV—Ë•+‡ŸŸÕªU³h'ÍÁž=âðúèQñ\Œ³³¸0Õ±#Œ¡Å±ÅŒÜ¾ «V‰}HL·)«T·ÒúôóLudf€°KmñâÕWÅa¿æ[I‚ܹs‡Å‹“¡|ÐCdà#—ËMHðf]Œ€C‡qôèQ•ënnnøùùQµjU‹uRB‰¬,ÑøÕ ^yE|óKÆoîÝ»ÇâÅ‹¹wOc»'i¯"`Ò¶ÅË/¿L›6mTÊ233Y²d‰¶_\ÂÜde‰Ã~uãïÔIzóÛ˜J•*áçç§m‡ÌX.—Ëíïl<& @ûöíiÑ¢…JYFFÁÁÁ¤§ër—(6YYâé™èhÕò_³ˆÚ{ð½§€Š+âççGeÍôÌCAAAvÅdÉd¼òÊ+4k¦êZ—žžNHHˆ¶m‰â’-¿ºò /@x¸™óK‡Š+âëë«M¼RRRìNŠä¹$“Éèܹ3Ï?ÿ¼J¹b1äÁƒf霢ñ¬iüíÚIÆo§(FÏ<£±»>$%%eݯ¿þj7‡jŠìº(“ÉèÖ­ 6T)¿}û6K—.Õv†ZÂT=ãõE¨E¢jÛV,Óü€IØ *TÀ××W› ¸sçÎZ{bù.Ëd2ºw‡‡JùÍ›7u…T’0–œ1^ß–-ªå’ñ—*T¨À;ï¼£m›¼ÿ;wÖÉår›Ô(öá<==5\ƒoܸ¡5̲„(ŒófÕò6mDã¯RÅ6ý’0www|}}µ‰@?Àæ"`–ÓK xöÙgUʯ^½ª+̲„.rrÄaÿ¦Mªå­[KÆoa´8òMBBû÷ï×zÍÍÍM—ôÖÿòË/6 j¶ã‹ŽŽŽôéÓ‡Zj¾´ÉÉÉÚÒ1MRRcƌ᧟~2G7훜1AÇÆªåM›ÂŽ 9[Y„Û·o@Íš5ùá‡Lº7)) Z·nMÏž=‰ŒŒÔZO!Õ«WW¿Ô'##Ãf"`ð,À‹/¾htc<÷Üs\¿~ÌÌÌÂò»wïrýúuZ´hƒ‘9çnݺÅ÷߇&""GGG^³Ç€òæ 7WL͵aƒjy“&¢ãOM-A %ŠÍ_ýEÿþý‰ŽŽ&//¨¨(\]]éܹ³Þû’““ùꫯ3f ‡BrssY½z5:t Aƒ÷8;;Ó¼ys.\¸ b@ÃGuéÖ­Ûꘘ«—Í* Ž4hÀµk×ÈÊÊ*,¿{÷.·nÝ¢yóæÈŒ8ìþÛo¿1eÊ• ÑÑÑ”)S†®æŒÝmäç‹ñµV¯V-oÒDtü1× % ž}öY6lØ@ªRW}/›””¾ùæüüü8xð ªg}"0pà@jjmgggZ´hÁÅ‹ÕEÀ1‰UEÀì¢4lØääd•íÀ´´4RSSiÖ¬™Aèܹ3åÊ•#Bm ,::š‡Ò«W/w–0Æ¿r¥jyãÆ¢ñ×®m›~=%¸»»ãååÅÖ­[UD ::‡B¸}û6S§NÅÇÇ‡ØØXõÌA…´oßžß~ûMïKÊÉɉ–-[réÒ%uÇ9 K¿~ýVGDDXE,"ðd$påÊ•íÀ´´4ÒÓÓiÒ¤‰AxõÕWqww'<<\¥<66¶tˆ@~>Œ-¦æRæùçÅa¿düVA!Û¶mS˜˜2228vìC‡%22’ÜÜ\­m´hÑ‚?þøƒ_~ù…&Mš|f™2ehÑ¢…VÈË˳šXL@ü%µ‰ÀÍ›7W^y…òå˳sçN•òØØX²³³ñôô,rÿlJ~¾6hùrÕòçŸßüj;*–E!Û·oçÖ­[…åû÷ï'""‚Gi½¯iӦ̞=›ùóçÓ²eK£¦· "””¤.õòòòº>žh°™°¨€8Ü©_¿>III*Û7nÜ ;;›F%*TÐ*YYY%OòóÁÏOLÇ­Œ‡‡èò[·®Mºõ´ãææÆë¯¿ÎªU« žiñððà§Ÿ~âï¿ÿ¦]»vF/n«S¦Lš7o®U€×,->ž{î9.]º¤"×®]ãÑ£G4jÔÈ`:u¢bÅŠ"Gff&½{÷Ö{^^^‘ÿIf%?_ ?´t©j¹‡‡8ì/ )sJ!¹¹¹üûï¿øøøè wW§N¦NÊâÅ‹éСƒY>SÊ#5_„º@ï>}ú„EFFZÄ­ÖjáîîÎÀ5âªïß¿_èuñÙgŸ1þ|ìY³øâ‹/´Þsüøq¼½½éСwîÜ)ZçÍEAŒKÔ²hÖ«'û%ã·:„……ѬY3üýý ƺôòòb„ fO’ãââ‚uêÔQ¿ôâ£GÂår¹E|¿­2Pàâ₇‡—.]RYL¹zõ*g ´ñÒK/Q³fM¶¨ùÈïÛ·ŒŒ ú<ÎìyêÔ)>úè#>ùäN:EJJ áááxyyiKî`yƇ… UËëÕßüÅMF a¬^½š!C†°`ÁîÞ½«µ^™2eT¶úöïßσ Ž8‹B™2ehÕªW®\Q­QðìÝ»÷šÈÈH³ž²³ú˜¸bÅŠôïß_CA£££Ù»w¯Qmøûû¤1üš3g#FŒ`øðá´nÝš°°0áIij£GÒ»woëWVPjyݺâ›_2~«!›6mâÅ_ÄÛÛ›sçÎi­çîîÎĉ¹pá/¿ü²ÊµÙ³góùçŸ[¤NNNŒ9’úš£Árrr§OŸnV_p«Ž¸ººR·n].^¼¨²ŸzéÒ%œ©kÄ"Ø‹/¾HíÚµÙ²e‹Š‘Ÿü,P-W¿Úqj ËÁðáÙ={67nÜÐZÇÍÍ>ø€Õ«Wóúë¯S©R%†Jtt4×®]+¬·ÿ~n޼ɀLZù7GGGZ´hArr²z¨½Zùùù½»uë¶&&&&K×ý¦`³U±*Uª†W&<<œÃêé­tðÞ{ï1sæLƒÿ€Ö­[J\\={ö,rŸMFà£ÔÒuêHÆoEöîÝK·nÝðôôÔùÙrvvfܸqœ?žy󿩸ìWªT‰íÛ·óÒK/©Ü³`ÁkOÅÅÉɉ·ß~›ç4G‡m¹\n–ƒ!6]¯Q£ýû÷×-[¶päȽ÷¦¥¥ÀäÉ“µ¾í*W®ÌªU« 9¬Š ÀÇÃüùªå5jÀÎ&ÿÁƒ0{¶8˜3>û ‚ƒA)]C©äÒ¥Køûû3räH“”íÛ·^½zÑ¥Kv©‡PŒ““ãÆ#11‘   Ãl *W®LDD:tÄs/C‡Åßßß´_Èœœœ1b„6hì–ËåÅ> bRXpKqíÚ5¶oß®2Éd¼õÖ[´TK$çÎ~ýõWæÌ™cÔñÍwß}WëzE˜0~ûMµ¼F qŸß„$y›7C@€˜êLŽŽbİY³@Ëù“KJJ _ý5K—.-ü\Œ1‚%K–àè¨?éΉ'øþûï ÓYÇÁÁ!C†0}út£¶¡¤§§ȻᆱñÙ´¹¹¹¬\¹’ÄÄDõKgœœœz|ûí·zÒÞèÇ6ÆÅžžž*F*ëÖ­ãÌ™3ýTŒªËøAt+X·N °uk1úlg<óÌ3ܾ}[奰bÅ FŒ¡Ó7!!oooÚ´i£Óøoî„„BCCM2~±çÎk5ã‡'ÓÆ«_jš››õÃ?ù´˜] õŸ*B¡ãн{÷øçŸ´æ¨S§sçÎåêÕ«,[¶Œ2jivþý÷_Þ{ï=ëˆ@@¨Ç.0ÑøAÌ8ožñÍÌ„·Þ³"—\\\X³f ƒ R) ãí·ßVù¼(¦ Úv~”éÕ«‡&44Ô(}{ÂÑÑooo]"-—Ë‹tpÄ.àìÙ³DEE©¨bˆÖºuk@4ò={öÐ\ɈªV­ÊŒ38wî\¡sÆðáÃYºt©†,\¸§¸ÌÂ7ßÀÌ™ªeÕªAd¤˜­ÔH®^S„«àxó€EÀ4@uwŠGÄe‡Ò‚³³3«W¯f°ZÆÔÕ«W3bÄñ÷÷§qãÆüõ×_:ÿ·½zõâàÁƒ„‡‡Ó®];ktÝ"(D@‹x5¢§M›fò›¯œ9s†={ö¨¨¶L&ãÍ7ߤU«Võ¯_¿Ž——ƒæã?ÆMGÜÐÐP­ GÇgÉ’%Ql¾ý¦OW-S¿–ßC³fÁÿþ§TP ؆¸ô£ÎŸÀ‡¨üK—kANNÞÞÞlP –âàà wT÷ꫯ2mÚ4­í’N~~>aaaœ={VýÒù2eÊtŸ4iÒ5m÷iæ#mƯP9mÆP»vmâââÐiüÞÞÞ,_¾\c‡aåÊ•øøøè]Q>wîœÊž¯A&MÒ4þªU‹dü—=žð-Úà ›jÑéÓ&?Ò®qvv&44”þýû«”ë2þŽ;²qãÆÂí¿Ò†££#C‡ÕæÏò|^^Þ^¹\^ߨ¶l& ìÞ½[Ãø½¼¼Ìæ¨3tèP­"°jÕ*­£ƒ+W®àïïO‹-èܹ3—.]2üï¾õ8r•*‰‰:‹`ü®êÑáômõåj>-¶ðt¶$wîÜaúôé=E[µjUèvPÚÐ#õ˜ï¿ÿÞ¨1 MàĉÿL=¿P±ðòòbÅŠ"ÊÛo¿M^^·nÝ"  p.™——GRRÝ»w×/0mšjY¥JbÆžbxPªyžÂ,`6 ~(ôbêI¥7¾‹‹¸#P0fçGAÛ¶m9pàC‡5»gž½âàà€···¶ üüühcDÀêkÇן¬g…ÓllÙ²…!C†hvxþùçINNÖ™ÄdàÀlRÑ —k®ÔUª$:ùhX°ideA£F¢¾»[hT’È#%ÆŽ…þ)ÖãmNVVÿý7?þø#7oÞ4ú¾>}ú°~ýzÊ–µy¾ «¢Ø2?qâ„ú¥+@w¹\®á@ Àª#€ÿþûOÃøõìqš•°víZCHçÏŸ×jüõë×'((ˆõë×k6öóÏšÆ_±¢º»˜Æâ~Ñ"pRO#yØ„ûÑ0þ Ä®•Trrrøë¯¿hÔ¨Ÿ~ú©Nã¯[·.þù'o¿ý¶JùŽ;xýõןº´tŠEóÖšC¿z@ô÷߯ÓíÔjðßÿqàÀÅñ A IDAT•2…«£¶Ê– k×®uêÕ«GPPçÏŸgܸqš^g³fÁW_©–U¬(¾ùÛ·7[_ûôõëÏöò˰{wÉÌš››KHHM›6Åßߟ¡HõêÕ ·}ßÿ}BBBðññQ©³sçΧVÞxã ­"ŸŸ-—˵z/ñ£µ ‚ÀöíÛ9xð J¹YŽÄé2~777F­-'º]Ò¥KâǧáÌ™*ÆŸ |Û¨SÛ·G1F¸ÿ>óçÏçÇ$==… ¡m¶T3uêT=zÄOJ1teÕ‘ÉdôêÕ‹€€Z<>­+·„aœ^'‘ÉdôíÛ™L¦²+Wì)€ ìÞ½»Ä? òüÏ?«üQC9'NпnݺÅÌ™3ñðð  0~{jj*ݺu#>>Þ=·—/_ææÍ›C®uíÚ•;v°dÉ’Bã—°.2™Œ>}úбcDzbA`×®]±ÕÝÝÝ=z4ÕªU+NóÖeÑ"xï=1×crcp(RìÙ³‡:uêèÜ_vqqáÔ©S ¥no$''3kÖ,‚‚‚t&ÎqýgþüùGy%lƒBÊ”)ÃÞ½{‹>˜˜ ã¯P¡ï¼óNÉ2þà`Ñ›Fù|¹³3W~ù…Xµ!–6ã¯R¥ œ;wŽÑ£G[¸³¶%55µðä䯿þª×ø>|È?ü Ó½WÂ6ôìÙ“.]ºMA ::ZëB… øúúòŒ±ìöÀªUZ?åJâªTÑ›FL‘=æâÅ‹ÈårÊ—/o…Û†Û·o#—Ëiذ!3gÎÔyz²yóæxyy©”]¼x‘!C†H"`gôèÑÃô)@AA‘‘‘~Û+VÄ×××$ç › >>bh]ÎÎÄN˜À˜€i£4oÞœo¾ù† *X¸£¶ãÁƒüñÇ…‹ºhÒ¤ _~ù%D&“Ѽys¦NZx=11‘!C†°fÍÉQÇŽ0iPPP@DD„Vã÷óó+YÆ#G‚RT GG>«]›Î?ÿlÐø|¸Öd|ð†<|ø£GšÜ/ Ë`”°sçN._¾¬R^¥JÆŒS²ŒÍ1BÅøqt¤`ñb²ÔÂO+'‘øã?èÝ»7*®®`_"Á‹/¾ˆ¯½öš†W¦.rssù믿hРþþþ:“g*r0œ={V÷±i%>øà¦NJåÊ•ùòË/‰‹‹Óó-a; zŽ;–íÛ·kDÉ­R¥ ¾¾¾%kákíZ>”Wò!$Þ~»0üô¦M›2dÓ¦MÓ©è¿ÿþ+tyUÆ”Sq–`çÎôïß_%>~5ˆŒŒÔ¹÷^PPÀš5køú믹xñ¢Î¶«V­Ê—_~É'Ÿ|¢qxêîÝ»… \t‘““ƒ³³³ ¿„!LqÒ…AxöÙg5Œ¿jÕªøúúªøÎÛ=ëÖÁ°ašÆ¿x±¸𘜜 '=}ú4=zôÐxS¶mÛ–ˆˆ›‰ÀªU«4žW«VÈÈH•Pë ß4i’ÞõŽgžy†?þ˜Ï?ÿ\çb§1 a~Ì!§¥Âø·m‡ýêÆ¬bü þQ‰LܬY3¢¢¢4V´•Ĩ£<¿ŽŠŠ*Ò¯bˆaÆi¤GKMM¥gÏž?~§ /½ôÞÞÞ:_}‹³4ït<Í(S³fMF¥woÜîØ¾ÞxCÌ›¥ÀÑQôüS %UΜ9C=4ö¸Û´iS¸^››Ë¢E‹˜:uj¡ –+WŽ7Ò³gÏb÷AŠzÊ#wwwêÖ­Ëi=™CÜÜÜ;v,ß~û­ÑnÜÒÀ6Xe   V­ZŒ5JkX&»eûvxóMPvZqpߌ{gÏž¥G\¿~]¥\ärÞ¼y»' ŠÀ–-[,–½fõêÕ‰4u¡8“/—ËMÞ§—À6Xe %ÔøwîÔ4~™ æÏ7«ñƒè¥qžýÌ™3|öÙgZßÍÍwß}W%Ù©¹©S§Íš5Ó[Gq&ÿÌ™3IN:O Äÿë¯k7~‹<²I“&DGGklªãìì̸qã8þ<óæÍ³ÈiÉ'NàííM§N çýÚèÙ³' „„„X%:³„ýaP|}}K–ñ‡‡‹s~uãÿãxÿ}‹=6""‚‘#Gj]ü» ÃËËË¢oÚ„„¼½½iÓ¦ aaaë>|˜Û·o›½%ƒ žIǮٽ[ö+Gù•Éà÷ßáƒ,òȽ{÷Ò½{w<==9|ø°Îz‚ püøq‹ì…'%%áïïOëÖ­ Ó‰§]»v*ÏOOO§OŸ>Ùš$žlšܬìÙ@fæ“2™ ~û Æ7ûãöïßÏ AƒèÒ¥ 111×e2™FúòsçÎѽ{wÓRëA‘ÍøùçŸç¯¿þRqR¦W¯^ ¤·Í¾}û²qãF\]] 3!ÇÆÆJþúOŽ@-[¶ä­·ÞR ò¨'ß˜íØ·OL¡«nüÓ§Ã×_Û¦OzHNN¦{÷în¡-C²"ÇŒ3ôæßkÖ¬øøø ΩιsçhРÑ᥵!9Ù‹x´hÑ‚!C†hˆÀàÁƒiÛ¶m±höï?#Cµü‡à›olÓ'#HNN¦G\¸pA¥¼^½zDEE޲²²øûï¿ùñÇõ&4­_¿>_ý5cÇŽÕzßZXBÒÒNûYÛ,mÊ Ð·ï\jÖÔo¯Zï>uê‚ 0dÈ– lذÜÜ\a®U9rDœó«ÿ´ivmüuëÖeÏž=ôèÑCÅÿÊ•+tïÞ;w²{÷n¦L™¢áV¬ÞΤI“3fL±ÞÜöLNN))ûlÝÍdž³6ëüô$$$——‡···Ê‡lëÖ­¶£GÁÓÔ£Ô|ÿ=¨¥©²WjÖ¬ITTT¡ž‚äädZµj¥sEÄc½_|ñ&LPYÀ“(*z'ŒçÎcÕªUÊ­[·j¤²8ññbZ.õ¨;S§Â¤IÖíK1Qˆ€z]Æ_¥Jf̘ARR'N”Œ_Âl?ž?žU«V1lØ0•‘À¶mÛhß¾½åz§L•*P¹2(/†Éåð]É›' ‚`”€–/_žñãÇóõ×_S±bE+ôL¢4qãÆ1•ŸË–­¤±& â€N†kÔ¨ÇטsöíÛ—:»³Fqù²˜™÷Ò%øßÿ@)]I!""‚€€ƒ)ÄÜÜܧS'ƒÿ›c‰EÀë×ãØ¸ñ-³¶ù´ãáñ~~1*e@_DÐË… X¹r¥ÆÙòíÛ·[Ï—ÜÃ"#aÖ¬gü{÷îåµ×^ÃÓÓÓ¨ü™™™¼ùæ›9%$̉(±†*ë;v°oŸ•VlŸ{¾øÂ:Ï2ûöí+Lô{÷n­uœœœ=z´ÆÙý›7oÒ£G£#ûJH˜Â­[· ï}€C7]¼x‘eË–i ùvîÜÉž={ÌÞÉ’ÊñãÇñööæ•W^ÑÿOvüôéÓ,^¼˜ØØX^zé%•:·nÝ¢gÏžöï’-Qb¸wï›7ofÁ‚ÈÔ®¹›Mr5<<<9r¤†ëh÷îÝéÚµ«ùz[Â8uêS¦LaõêÕ:å:88è ;~÷î]úôéáC‡TÊ«U«FDD­[·¶Xß‹Š-×ê׿$ S¾|]ÜÝ;sãÆÂϦº”6c¤¼ýöÛ1ºuëÆk¯½f†.[—ŒŒŒ"G¿=sæ Ó§Ogùòå:åÊd2 À÷߯ףòÞ½{ôîÝ[C*W®Lxx¸Ý¥·¥të%ð£f7hóÈãV_¾|™eË–i¤ˆŽ‰‰)QçË™oëԩôiÓLº÷òåËøûûÓªU+–,Y¢÷Lþ¡C‡Ø´i“AwêJ•*±sçN-Ö»wï <΢E‹Lú$ž^t9eƒ0B®\¹Âòå˵Š@I8_þï¿ÿòÜsÏ1eÊîß¿Ïwß}ÇôéÓ ÞwõêU&L˜`Ô™ü˜˜“ßÜ PßbUˆ€úè ..Žž={Ò»woƌÌ3Œ~–ÄÓ‹¾$¹ÀD½#ÓÓÓ¹|ù2-Z´Pñ¸|ù2yyyZOºÙ Ï>û,6l 55µ°,** ™L¦5\wZZS§NÅÇÇ‡ØØXoüN:Ì´iÓ¨_ÄIjÙ²e:t(111*D>|HXX=zôàÚµk¼ÿþû¨-ŽŒŒÄÅÅ….]ºéÙ¦ððáC‡¢rÿ~2gÏ®2XOZ(†ÎŽf"N" 5”œœÌâÅ‹5ÎªÇÆÆ^ôZEî¼–-[ª”Ëår ¾sçr¹Üà™üÖ­[ZøF..+VdÇŽA÷îÝ£sçÎtìØQkd"ÿöꇦ$$”ж¨rÀ —¡Šµk×ÖFü•W^ÁÓÓÓôZ Åv›úžûgŸ}F5 žÉoÞ¼9r¹///d2cÿ¬Æ“™™ÉÀšV½úê«üðÃV[ˆ•K.ÆFȆ*^¿~7d\\;wî4½‡V¢zõê 4æÌ™C@@€Nãî¹ç âøñã :Ô"ÆâÔ£AƒzÛïÔ©…^‡†0õÓêŠ80ø*W$QÏ#رcGúôécâc­Çµk×èØ±£Á õêÕãÛo¿µø™ü«W¯òóÏ?¤±ÐªŒ‹‹ ;vì°‰áÛë@SJÎf”Ù | äÝô×15*p6âî€öI§)))„„„••¥R¾ÿ~¶lÙ¢ÓIÆVäææò×_Ñ¡C½Æ_§NæÎ˹sç7nœÅŒ_´qãÆüúë¯zàÑ£GRd_ “)JXðG€FˆÀ7´ŠÀáÇíF  £yóæøûûŒÙÿÖ[o1a‹&L9}ú4Ï=÷œÎÅÆ&Mš°hÑ"zôè¡R®X'ˆŽŽ¶Xß$Sqy\ÛWc=÷CM``ÌNãâ=³¨yC0R-Zĵ°ÝñññlÞ¼Ùf" B¡á{{{kÄéS þ†ÿõ×_ùüóÏ-ÚïfÍš1gΟõêÕ#((ˆ“'OâççǦM›èÕKu]V!ºÎH˜‰ @µ¯æÀ‹ˆ\Ê"˼èÏë*nâ÷{üÌÚêê 8‰ArE`“¡Š©©©,^¼˜ûj|9bˆˆˆàÅ_ÄÛÛ›³gÏj­ãîîÎĉ¹pႆGÞœ9s?~¼Eûýî»ïò÷ßãàà sÚQ®\96nܨ±»’••Å AƒˆŒ4¸{+QTN¿*}-<þ:R„öjí7Ýïꯈ†_©ÏR¢¸™r§ UÔ'›6m²šdgg3}útŽ=ªõº››'N$))‰3fàáá¡Õ#oÁ‚|ðÁí÷˜1cسgçÏŸ×9ípuueÓ¦M 8P¥<++‹ÁƒapãF¼TÂEÀT*IÀˆó ùU•:)Ex–æH – ÅHKKÓ*Gµš¸ºº²yóf¡³rÚî3fP¥J•Âk+Vdûöí#   >ýôS‹ö÷•W^1ÐÅÅ…5kÖh$Qˆ€.G,E6á/¿üÒlý}*yqø¿¸RÄ6N#Ї±~[/îq€_?æÊ ¨ †*¦¥¥¬á¡vôèQÖ®]kP:;991jÔ(ƒi»¾ù;vÄ“}dìØ±ï¯18;;³zõj¬RžÍ AƒT¼/]º¤’MxöìÙ|þùçÖîré >Ð8ô¤S>öNˆ¢sОÞhÌ™4ðƸ}û6‹/Ö“'O²víZôd–ÀÕÕ• 6pöìYBBB4’xjCá–;aÂŽ;ƦM›ìê|¾³³3aaa¼þúë*å=ÂËË‹… âïïOãÆ5² Ï™3ÇâSšRÉPDoš»ˆ+ñ–ñS¥#¢o®öS&aîìÀ Xo¨¢½ˆ€1†¯L… ˜;w®]¾2ÎÎ΄††òÆo¨”?zôˆ±cÇê<¹Ø²eKmE #x„xbæ5`ð¶…Ÿç‚x<ïp»øÍY"=¸I"°páBîª%ú8uê”ÕD 4¢¬Û¬Y3/^ÌÿýgQWæR˯ÀlàGàÐh¨÷ŽâÑ QÌðöˈG‰½u†*Þ»wÅ‹k5kÖH"PîܹÃ?ü 7FcõêÕ âĉŒ=Ú䤢j䊸¸Eõ0DYÄáÿÀpÖ/£°db¹\`°ÐëÔ}ïÞ=‚ƒƒñóóSÉvªH¥ž¨TB;Æfño^­Z5›&-u(6·Ê[¨ýʈoÿÖ€âôºbÀö*Ðtç“ÕÀÒV¥ ¬0T1==àà`þJHH`ÕªUf8QšÈÊÊbÞ¼y4jÔHçÉEu‚œœ† ÆÚµk­ÕÍÒâO¬ÿØFÑy€è#pqÇ!Ñ! D€xÄs»&`×j>0 #E`ñâÅ" ÈQ(‰€vvïÞÍW_}¥5•xµjÕ˜5kiiiøøø¨\ËÍÍÅÛÛ›åË—[««¥m–£|uG˵Æ@à㯢ž¸x _ùK‘Ò'ññÏ÷µßª k«"`ð“¦k$ ÈQ¨/{îÓJß¾}Y¿~½ŠÃPùòå™8q"çÏŸç‹/¾ÀÝÝàà`F¥ro~~>£GfÙ²eÖîvɦð>â¢\3ÄÚ=ÏËž³a¿LÄšë|`4`ð“–‘‘ÁÂ… Uâô$úèׯëÖ­£J•*Lœ8‘Ë—/3cÆ •¤¢ŽŽŽ,Z´___•{óóóñõõeéÒ¥ÖîvÉEqH³7â$·+¢ß ¥k%K.j#ðEô{òÑWñÁƒ,^¼___ªU«VX~á­ي%Ä‘À7ôþ]ù÷ßÂòüü|üüüprrbذaÖènÉæâ WÄE¿G@ºžúç€)&´ÿ‡‘õî˜Ø®¶XZÏüƒ¯…ܺuK¥\‘£P hbŒ(:::Ìûï¿_XæììÌØ±cŸê¬NE"¸…~ã·clõ Uˆ˜0¨^½zaùÅ‹Y¹r¥Ö”冑ÉdüñÇ‚€ Lš4‰ºuëÚº[VÆÖn_ŽÀ"ÄB½¸¹¹1zôhjÔ¨¡R®HO¦ž£PÂzØkL@ ÃØÚ»&x1T133“­.Ez2s%$žl- ŠÀŒàà`®_¿®R~åÊI$$Š€=<ņ*fgg³dÉà’HH˜Ž½˜I–.]j0„¶„„„ˆ= @¢ªøðáC­"œœ¬5e¹„„„&ö&ðDª¨õDŠD¥>´P%$Jö( z Žþ4TñáÇ,]ºTC™‰teñ•°_Q>æªøðáCBBBHJJR)OIIaÉ’%’HHèÀžDø#D ''‡åË—ki$ ¡àâÅgøä“~4nü1ÎÎßQµêWxzŽfÉ’6ß/Î’íÈ iCÏž¾T­úeËNâùç?áãû“”T´ !¶ö4ð;â´@/ÎÎÎŒ1B#ØgÍš5µf+–(>%Åðß_à£úóð¡v×ñί°fÍ*ªWÏ4¡§Öi?5Õ7ÞN\œvwm—<þüs ï¼£=á.ì} @10xFJ1¸té’J¹®D¥O+W¶ä½÷é4N€½{ë1`ÀH²³ìªýìl'z÷¥Óø=*ÃØ±ƒ kaRÛ%- Ü6ÄLíõU*(( !!:uê¨ÄÌÌÌäܹs4oÞ\:;`F>|höhM÷ï'söì*ƒõê׿ô‘ž^OÏÑ<|hØð®_/O¹r¹téb|ŠK·?}zWV®li¸"2¢£ŸÃß?ž²e;)[RF àÄé€^rssY±b‰‰‰*åŠôdêÙŠ%J/K—¶æÞ=ýéÕ”ùóÏ—1%?Š%Û/(ñçŸ/ÝvZZ9BC”4€'"𛡊¹¹¹,_¾œsçTc4I"ðt±gO=“ê_½ZÄÄgì¢ýsçªpó¦»IíïÞíatÝ’( ŠÀÄ´ zÉËË#44T«k$*•(}ܹãjò=©©Æ/[²}K÷½¤ ˆ"ð)0ÏPż¼8ltÛÕªe2|øIÃSÒ¶õ‰˜›¥‹¾J‚ púôiªW¯®møáÇœ={–¦M›ªÄ×—0Lq¶ÓÒÒˆŒŒ$::šôô'‘52pr:eð~c¶]]óððHgÍšfò}{ùåkm¦LãsRZºýöí¯³}{#RRôç“É/^OÛ¶7Œn[µ·‚ð`ôÝO˜Lv ÷)?ûOÄ=~cX‹L¶RǵéÀ׆pttÄËË‹fÍš©”W¬Xñ¸ÞÃÒIDAT???*U*škåÓHQ<oß¾M\\œÆºŒGÇd\] û˜â ¸hQ;Æ ÓY§k×ˬY³ŠªU‹æ,fÉöoÞtÇËË›½{µï8¸ºæ²`ÁfFþϤvÕ`°ÙäÞA,2Yç"ܧüì+€±ai@&›¤÷:|c¨Þ|óMZµj¥R^±bE|}}Uœˆ$tcФ§§sðàAŽ?Ž c3üÚµk\¸Á€©Z¯+cjPФ¤J̙ӉíÛqåJEÜÝsh×.?¿c ~¬Ü~~¾+W¶$$¤ GŽÔ"#Ã…úõïѯßy>ûl?¦OaÍ%ƒÉŠz¯¹`𭡆xã7hݺµJ¹$ÆcŒdddpàÀNœ8¡3åûõë×Ù»w/W®\¡~}ðó3ül)*pñ0g@ýéÂVd2ã'7–E!zE   €õëרˆ€"G¡¯¯/Ï|˜#GŽèLärãÆ öíÛÇÅ‹­Ü; s @+`Fäþ³"“w ôŽ" mÚ´),ÏÈÈ(LJ"‰€idggsèÐ!½†Ÿ––ƾ}ût®HXs§Ô™† „!“ÙShÞïEà;}• ذa‚ жmÛÂòŒŒ -ZÄèÑ£Uv $´óðáCŽ9B||¼Î¸Œ·oßæàÁƒ$$$è\°æ€úÀ{ŸÚÐZL~üÝ(TD@W¢R‰'äæærôèQ<¨3cFFû÷ïçäÉ“:×$¬‹%’êMFBÉì͵n2âH`²¾J‚ °~ýzrssyùå— Ë333%ÐBnn.ñññìÙ³Gg¬…û÷ïsøðaþûï?)¡«a ¨|Œ¸oo"Š@ ¡Š[¶lÐ*£GVITú4’ŸŸÏ±cLj‰‰!55U«#PVVñññÄÇÇK†o§X*­îWB2Ùm µ_ä¿%‚ оý“ø#Š…O«pâÄ bbbtºNggg®üçææZ¹‡¦`)¨|L´PûÅEŽ˜ÙÝàù­[·":t(,S ¨g+.­(\¨###¹sGûA–œœŽ;ƤÄ,%K À'ÂoÈdW Wµ 37(Û¶mP¬¬,‚ƒƒ5jµk×¶HíA8þù¤/ªz¥–)SÀ˜1G™5k'åË›¶öRÜÃ@;ÞêÀKÈdGô×2ûa ¢ð%ð³1{ôèA×®]UÊ\\\ðññ¡N:èšå¸ví»wïÖˆ›¨@aøQQQܾmsJK+G÷î~œ<©{çÆÁAàÏ?73n\¼±Ý´Zû ¼Ä‡Л]¨U«›ìÚLåÊÆgÁ*î`2b}‘ eˆÇsûóYÖ`ÖãïE ** AxMéÓ÷èѣ‘@I[·n±k×.´^W^¼qÃ@ wwxûí'?ÇÇ‹_v‚ŸßzÄáõ‡à…Rxé%íÓ[´¿>þ¸¿ÁÔb'NÔ`̘×Y·NW¨ MŠì:Fdðú"=Šù,k1 q$`èèhvíÚ¥RöèÑ#BBB¸|Ùø¸lÖ&--uëÖ±`ÁÆŸ˜˜ÈßÿÍòåË ?dP¹2=ù4Èìý.*±±õز¥±Quóò˜<¹»]µÿÝw=4¦ºX¿¾)ÿò1GLÀcV‚~DJJ.ÂÙÀÆTŒŽŽ&""B¥,77—eË–éœKÛŠ{÷î±yófæÏŸ¯3 Ç•+W&$$Dç" û€žÀ t×lˆ¡ºŒ'<¼!é鯇…³dûwî¸]ߤöMéOñ@&KC4C´ûyÖãàsc*îÝ»W«hËVl 222ؾ};¿ÿþ;ñññZ ?99™.\hLŸÞÀ+@”Ù;lfÎ36ÒœH^ž/Æ’í'&V&?ß43=s¦ªÑu͵ ð bæ^Cnq3„-Èd%Å1|Îã↑¸wï^AÀÓÓ³°L!Ú²[ƒ¬¬,âââ8pà€N_ü›7o²{÷nN2€8LV#.î–ZL‰ lÉö‹2h6¥ïæ .“=À¸Ã?M‘fy¦õ˜ƒ˜{Àà>66–;wª”)rªg+¶$ÙÙÙDDD0wî\bccµjj*aaaüùçŸÆÿÀh„QÂŒ¿qcÓv.œœòiÐà®]´ß¨Ñ“ýš4I3º®9ó, Ö‚)‚‹Ÿk æ"Žp ~ðãââtŠ€z¢Rs“““Cll,óæÍ#66VëAœ»wï²iÓ&c ÿ2àí)0o `+áå¥}¡S½z%R±¢ñ.Í–l¿rålzô0íå1dÈi£ëšOÄ(@S¨éø¡*i,>ÀHرc‡J™®D¥æ 77—ØØXæÌ™CDD„Öƒ8ééélÚ´‰ß~ûøøxC9®"&[iü””)›V^y%™AƒŒ ;æä”Ï÷ßGÛUû?üeô(à­·NÓ¡ƒñÇoÌí ¸q¸ÜÆ@½IÂ"› „¦@cÄõŠÛˆ[™GŒ côøûŸȱoß>A çÀܨU‹îîd•+Ç©ãÇùÂÑ‘—6Ôyoâd;q{¥,ð ¢5>¯TOùL¾®LÇÄÅÅqøðaÝgòŸyZµ‚ îÓºõv||–Pµj,2™yô5o @Íšðà\¼GŽ@“Š˜Bpðz^{í½{õŽŽÌŸ¿…_4ÍÀÒí¿üò5þøc+ãÇëwjÓæÿü³Ñ¤¶Í+2Y‚¬7P³¢P3b0‚àƒ˜ôD[òôTa 0™,AðBõlÀ[ÈdŠŒ Aˆ£€€Œ/¾€ñãŸÔìØRS¡aCöË¡áÃÉwWMïì²b_çåѤIr€p`-° з0Zèyâ'""tæ4T^Ì?–)Åj}õU¸qš5ƒ)S`ð`pq( }ü•ƒ l¾B&+Þ°åwà³ÏD‘Qçöm˜3~ù²÷`3•gžÉ&.î_þ÷?O.lGn®jR¬&MÒøí·mxz-2±¥Û÷÷?Œ‡Ç=>ý´/gϪ®ò—)SÀ¸qñ̘a²+°ùÏÈd„8Ä-"}üAX€LvËì}PF\oX¼®§V5Ä-¿Aˆ†Ð@éºú¦í_(D re(Uut„7Þ€åËÁÕUë¤9¿ €°°0†J“&MxXn䯓Ì”Éøõùçñúï?ª @vv6`ß¾}O¦•+£ÒÇ2e`Ø0ø÷_77]¯gÄ¿Ya2Ù#»ø77//ÝuªTiÓ o_8”Òƒ™›òå±`Áf¦N&2²W¯VÀÕ5—_L¡C‡«ÅN béöûö½À©Só9xðY®MvvêÖÍÀÓób‘³Yê0P°Û@wÄ€!F9Ü Ap@ܲ¨vå¤"†0{Qž6¿ÑúßÈdA(OÚ´+@‘_0/’’(WP€CíÚ ßL¯^ NIZµÄi@` (Cg½ð t3çÜ\*=~Ó988°ïÓO9W¾ûLþ2M±ÿêêj´ÖLœ8ñv¶†Ïç#½´”e™™|ݰ°­Ä8Òêë™¶v-ŽKUF©©lîÖ Â rH·¦æÿYüç€Ñ(z(UêZOGdÓfùß½YÈφŒ·¦6œlÙ2NŒËüi‰Æ2ì±5šõ°M<ó‚QªI‰Ä,´~0ò0ÇÌDžæÞ´\üF”ÚNðŽÁ9ZÃÌ™!‹?@MM 6lJÇM;{–ò²28p;¿¤¤ÄR‰çÖ­[¤åçÓÉ8ÿôé-}PFNŽUŸ†–‹?€RÉ}0V5}­H-µÑ/ò-ä(ÀY¥ŒGL¸g„\ ’,ìWp'`!¹ü¡Ù!ŸX^vîS… ™šššÛ]ˆh­)//§¸¸Ø²’ÐçóQ[[Kaa!]·ßúõÍ¿4h†#Æ÷A`*˜Õ;N‘kF•j"ø{»‹àcA8š°‘BR7€Í†w£u7›÷ðˆw €RÇ€b#Ÿ&r}ä|9ÂðÎî óg8”ú©r‹Žúú÷–ÚÚZ***"vÈÑZsðàAŠŠŠ¨¨¨ ¡ÁŸBjÌ*LK“—° qÆMZÊNYçÂÛa­éçHÑU(eW6Șº¦‡¬Gp[ Dì@J˜1 qxÇ‹a€1ݸÆáõÕˆ'Ü9Ï<ó[$¬¿Švÿþýh­™4i:ÉÐ+]»rlÈÎÞ?ÿMNæüõëÜxòIX´(øâ^¦Š¯¾}«¨¯Ÿì³ñ)팔:ƒÖ‡À·l^é$?ÖœßÝÁµ1à¾Pês´.Dú$ s=¤Ó˜I,1–³@À×ÑÔÕÕqëÖ-F¿ð[Çãø!ø¢)E«®žRv¶Saºã4€¯Ú¼ÆI@ß|LL²åw± ™ïzl˜Ÿ NSŽcÉF ää#a΂Ã\!4ˆÃsæ ;ÇT#åä8çTÊ×8¾ Z'£T¤j–;²p¨£‘ T#Z¿IpXÎMÌyýNŸ(±¬DãÙú=ÿÏ%´ô] ëÖ/þÝ»aíZØ·.^„†y}ù%ˆúÎb¿£ìqøŒv0/f·ÇHf´™‡‘\)8¨H]ý\š·’nbnZçô&ž`o»µX²$‡/¼ø"¼ý¶Õ<‡J@Œc^ ŸÉ©—ýÿ¯£Tty§ÈË£mñþ ¦ÔŸ¦¦$¶nMçøqÙ|‘ì줤ħ¡Ûó>œFUU?.\H!5µ‰ÌÌO>ܾ€‘Ä¥šÐú—ØK³óÞ™h[s2^¼Xƒ|×ÂxèÒÆoµq£Õâ?Ѝð¬!8º`÷,nÅ@`¤A¦ñìESÚ >Ÿbùò /Î ÑäKMm"7w' |µÛóòI/æÎÀöí¡êRcÆœ ¨h£cq’DlåŒüžðÅnñAÒ“Y4ß±­­$õßváS­FTuš·ÓéébŽ|ðqüIà9¤z±”ÐÐâ£DÏ7mÔº'ÁÀiD¥Màó)fÌxš×^k)ÈÙÐÐ…W^GNÎd,$[}þ={ú’‘1Ûrñ|ôQ:=ö<ûö9kQ—X IÛrlj†Âþ¢ÎúÇýÓF2Åô4‰IJŒÿ4ðÊü#VbZ÷Fú1DËd‡cÆóŸ1Ü·ÕÈÏÏ ´Ô¢ÙDIÉÃŒŠ8.‘ó_º”Ì”)Sil ¯$ÜØ˜ÌäÉßçêUûõDï@cµ ¸Ï*ÓÏËüE?-£õ]Øè#¥Àtà&f§žÚ‚T$êÈ4²ˆØò&¾ÖG%ßÇÃ;>ìd¶1®^½›%K2#ôóÆߥ©É¾ßØíù åôi{©§NugåJû›ÃÄ)LÉMÀ¶ü´Ê@ ~¬ýZ'!OÜ‘–¿/eÀ³?~£nß´iÐ:|øLô ~‡Ï°Ò¿½G.Á*[PÊ]aC¨¬ñéi¤¡¡ ••öUœÝžßißÄöˆ)Ùáò=4’{`”HyØ‹Ö3ÐzZwGëhƒÔÃÏðÛŒû”qùòh‚K^‡¥hjîµNBëבÔÜN@,ý¸ÿ‡ì4¶Ybi}·ßaûsûױÙ'¡­áT·àÈû×´µùÍŠAáHdÐL.Ísî Ô!Yëû4ç<‚(ܶD’*kÔ2ˆOü&”Ý$%ý O O¦Ùhý7à²ØÓqˆFˆƒ°ÝŒ[`¡ÿúG€:´®DÒŸ¿@~Oîàõ6Þæ½EÜÖÖw{~çsÛ÷2¶žPêh½c-½;÷ù ZG|†y1J¿BÔ8Íœ³RUh½)CìÈîAê'¬øÒa)–(Àß‘R饈áyÜÿ²B¹(µ"†ûµ*Ntò£¹Æýù/P]ÝÛÑx»´Î ™Ÿb£r.f”Ú†ÈK=lBž _ ÷*$Î> ¥–úͧyÏeN,Š÷ç+ÆÃŒºŒ‘Ž@©pãìÞó7È.'œC¶ÈB©Depº‚Sÿž=¯‘•u²ÍÌ?eг¾NÆß)Í:‹Öë‘e€ó(•˜òTÙKŽ@JnïCž¾ç܉6òï[š7àðk?”:eøýCHn@dGp)çmsM?Í™€v%Áòó3xõÕq¶îQP°‰y󜉹9ÿ•+yà—lEú÷¿Ä¡C+éÚÕŽÊ}ëúÚ&Z§œ‚š¸&÷²û¨ö¿‡¨7Õ%ôž fá©©éÍêÕ…—“SËË/;W$ssþnÝ®SQ±†ìì™a» ÷èÑDyùû¶?´þ -ò#‚«ðp¥àÝwËÉÏßB¡ýRS›((ØDqqET:·ç9ò {÷¾Cv¶uvìØ³gÏ;ޛ޴ÿ#€ÖQê¤Í±£AÀÌ^ú¢”ýN‘m‘HG€;ˆhF®]KbûöA·ÃkC‡^`̘$'ǧšÛó9Ò‹]»úsáB ½z]#3óS† qV #V u’XR¡ß”Ö}꺅—ÿâŽ_ü!¤¤Ü`„£Lp)þäöüÆ*ò`EG0£ü¯Uh}Ål@Ê~ƒ-®ù÷Ó‚=(CŒ`€è]ö?IEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_32x32@2x.png0000644000175000017500000001127513070106167017263 00000000000000‰PNG  IHDR@@ªiqÞsBIT|dˆ pHYsÄÄ•+tEXtSoftwarewww.inkscape.org›î<:IDATxœÕš{\•UºÇ¿/—À¼ b†Hi#‚¥MÞRòhŠ: ÆiÔL++òr´F¶ij‡2s4´ÃˆŠ©yIE¥`/hÚ€M2šyËÄPqDÜ{³ïÏùcî [Ø zÎù}>ûï³ÖzÞõû½ëú¬¥ð¿FÓÄÃÃc²§§ç\///_›Í¶aöìÙ“yPuPÔ‹¡ÑhTŠ¢Lôòòz?$$¤ILLŒPPk×®Õ–””ì0/i4Ûƒ¨ËÀ‘ø#<âëצM›ªt³Ù̺uëô×®]Ûa2™^|"<ê"î³ÙLFF†þúõ뙃aìýá¾ P⎨AwõêÕ¿uèÐatbb¢õ~Õñ¾ÐPâŽ0›Í¬_¿^õêÕ¿ÆÑÆr?êÚ¨4qGX,222ôÅÅÅ{M&SÂý¡Qhl⎰Z­lذAWTT”k4ã[„{à~w„ÕjeãÆú¢¢¢ƒÍš5ûÝk¯½fn,ß  ¾Ä øp)žq£`Ĉú¿³R„Ë—/jÞ¼ùˆÆ¡^T#îëëΟñ.¬8å#AýÚݺ¹Èh6ƒ·÷]ýX­V6mÚ¤¿téÒ·jµzÈÿøGc}êï ^îdj(ñJøù‚r(,àãã"ÓªU _~yW?žžž¼ð ~›6mêyéÒ¥¯–-[vÏ"ÔÚî•x%,HO‡Sg!~8<ûlµ «Wüy› =V§?›ÍƦM›ô?ÿüs¾ÉdzN£Ñê]© ¸ ±ˆ»…ôtÐhÜ&_ aëÖ­ú .ÆÁ ÁI€J`ÍxçØ»ÂÃÈ˳kñÄ0jTíÅE„mÛ¶•Ÿ?þ¸Ï ¤¤¤òúVA†ß³ * tN³Ù`óf8s† ƒßþÖ…ƒ/¾€¤$'òÇŽAl"è&‚ÿvX–'ÔN R„ .üC¥RÅ4DæÏŸÿïÕ«WŠ‹‹ÅlÞ,¢î$B²ˆ:T$7×9ýýÿQ÷QÞQ‹œ9SÍÁ_ˆ<ü°È©SNæ¬,u¤[D|‰,Nq«:b³ÙdóæÍúE‹Y²d‰o}¸{#¬Vk3Nç£V«Ý*t½l­.@ܸáœ~­Ì! ‘€/ܺå¸e üéO“;;•2R¦Bì&˜Þ’¦¹GBQFíÛ¡C‡§ŒFã~Fãç^Ið~ìß¿?غU¤M‘ÂÂÆ÷í›Í&;wîÔ/Z´è»>øà¡ºÈ{8©ÿôÓ´iÓ†õë×c2¹%ž{øòK˜:Õ¾ÐéÒ¥ñüba6›>|¸oDDD'«Õz¨.<ªºwïN³fÍÈÈȨá‡~ GüüóÏõ¯áöíðúë°kW£“˜4ióçÏG¯×“’’BÛ¶mÉÊÊbذa¾]ºt ·Ùl‡5M@m>ªº@寨¨H6oÞ,kÖ¬³Ù,""‹/–víÚÉùóçÝoYY"­[‹äçߟö."×®]“°°0Q«ÕÒ³gOÉÌ̬J³Ùl²{÷nâE‹~X´hQ3Wäk´°(}úôA¥R±qãF, ³fÍbÊ”)ôïߟéÓ§Áêÿ#¾ú &N´ù§Ÿ®ÏGu TzõêE“&MhÓ¦ ýúõcøðáN<†êóÄO<*"ßh4šæÕý¸ ²ð³Ï>‹¢(lÙ²ƒÁ@`` eee¤¦¦²téRZ´háºð×_ß!ß½;,X ‰!3³þd‹‹‹™6m:›ÍÆ–-[ˆˆˆ`ñâÅ$''sòäIòóóQ©Tètº<† âóä“O†ùøøÔ¡ÎÝ ÕjÅËË ­VËÉ“'9räÙÙÙŒ?žÜÜ\ÂÃñX,xyU¸ÊΆ ìL»wàÏ îl‡¿š ‡Bî²¾ ‚ƒƒñ÷÷§GxzzRVVÆœ9søÃþ€gÅ\Èüùó]–¯l ÞÞÞí Ž.\¸ð™9sæÜ¨U›ÍÆÞ½{ñõõeôèÑxxx°lÙ2"##Q…þýûMAAÇç¡£Gᥗ`çNèѣʗ[ÛáZ°wï^²³³¹|ù2-Z´   €   ú9bcc}E ­¡÷œ9sn¸ì•äýüüªÈ;âÆ¡ÕjÉÌÌdõêÕ}ºêùðáÃôë×1cƘ˜ÈÕ«WyþùçY¹re½ÉW"&&ƧGíE9¦Ñh‚j´‹ÅBNN$$$Ô àííM`` çÏŸgçÎ|ô»ßÑ ðúòKnwëFõ‰×Ë ^y¥îÊ;wŽW_}• °víZNœ8Á›o¾É®]»xè!»×Å‹5çw¡( ô¶Ùl¡ùùùÇœ°X,dggÓ´iSâãã]’`îܹLŽˆà%³™Ñ”͛ǵk×ÈÏÏÇ×·^{š7oN«V­˜0aÏ?ÿ}ê|V«åã?&99™öíÛsûömÒÓÓyÚM‘Á`Àju¾PZzž vºË¯Nèt×ÈÏO%2r2^À«€E«Õ¾˜ššê¯( "Bll¬s)xòÉÎvîÜI×®] E§Ó‘––ÆÂ… 騱#;vì _¿~UÝa÷îÝtêÔ‰‹/Ò­>›¼ü2Ôº»weˆ´Ç û¬7E«ÕŽ[±b…¿ÍfÃl63tèÐ:Ý”——3`À&MšÄòåË eÆ DGGWåILLÄh4J¥b̘1,_¾Ü½A· 0°ÞÅ\@€[UÓ ¯6N7>55Õ¿2[m"˜ÍfÊÊʸuëóæÍã£>bÊ”)5òåææ2cÆ žzê) ILLlùJüT aŸ¸HŠÇPEGà\Åÿ@èmøé-û£ãR¸²%”ëtº×*[‚ˆç²"K–,aýúõ¤¥¥¡×ëyï½÷˜0aÕÃë}ûöeÿþý„‡‡³mÛ6FŽÉöíÛ ã—_~¡oß¾õWÁnÇUs3 -vÚßÝIvµ~ ¼¼üµO?ýÔ_D† V#ãÌ™3™1cFÕ²yĈ5ȨT*Â+NÐét 2•JÅôéÓOà!@_ñ|ÐVüÜvÎ~·ÿÛÀJƒÁ KMMeß¾}dºå(Šâ´g¨Ü±Õ†;v””Ä!Cðôô¤³ŠÛðþ´‚*~•ðÀ>é·q`][Dh:`5 o¬\¹R-"X,FuOý7..Ž“'OLff&†>}úàSß(‰+ذõœÆ.F%ÎV¤Î9âÔ›`0ÞXµj•ìÁ’„„„‹àííMpp0`ï2#p_¦}Sä½¾ܹ!2 ƒÁðf¥À=‰ð nlúøO`¹Á`Ц¦¦rðàA¶nÝÚà¨LcàÒ¥@ÆŒIà•WFPZÚ¤N{aakâãÿƒ¤¤Á˜LwëqüÈ> ÀjµvýþûïUAAAèt::wîܨ-¡®¥p¯^Ф ¼ýö`Ö­ëÊwßµ!0ÐHT”}³t7ûر de=αc!tî\B—.×7/I9`6 &“iÚgŸ}ægµZ±Ùl÷¼°© W®\!77·†½U«;ñÿ–-u ¶{!Ò8ïàûcåN€]ä-`nÅÓevÞJKKóûÀøÂ /4ª¿þú+{÷îåòåËœ9“G¯^ÎéÉÉ +ÅßßÄïÿÏ:í©©{èÝû2aa7‰‰ù—ƒ'‘T®vì¿Ûˆ´vHŸíæ¸'}Ðy{{ËäÉ“%##C¬Vë=Ÿõ={V>ùäIJJ’îÝ»‹———tê„h4ö_iiµÚÞãÏUPcoêoÕñ‘ÞÊÍfóì¿þõ¯U72ÆŒã^@µJJJøúë¯),,$//‚‚,–ûrAÜ Õ°TØ&#²Eù©Žò Ìfóì´´4?«ÕŠˆ0vìX·E¸uë999œ:uŠ#GŽ——g1uŽM7oú’’ò ~~f¦Oÿ†&M,µÚù%¥K{ZÊ”)ÇÃC\ pPÝ 0Á  ±X,sÒÓÓýÀ~h1nܸZE(++cß¾}œ8q‚o¿ý–h C9ƒi‰‰ cæÌZ_:wî–/·¿©Õ&ÞzëX­ö7Þˆc÷îÇh×î#GþèRðg`7ð""»!ØÇ,˜իWûÙl6l6ãǯ!‚^¯'77—ãÇ“ŸŸOnn®¾¼¼ÜÌ>%((–-댇+Š8üßp{ͦ¦({9ôÇÞ þî²"IÀ(à pÈEQĺ~ý¼ô¼öôîÍ©œÂf½¢Pn³zñ"á6ðÏ'ØÕ¹³Ùb%?ÿ:ãéyE1âéiÀßßÌÊ•B×®žìÚeñØþ¾pºù5oÞÔjjµ‰É“ ê´¯X‘EÇŽÿ&,ì&ÇŸq"â8 |Saëã`ˬ1 ˆÄ"rDB¹Žˆ}QóæMÞ}×è¥RÉ„I“dáÖ­òUNŽ$¿÷ž´ß¿_|'N4·9tè&S"ÞˆD r¡Âß`DŠ CÄ‘Âømc߸_³€ëNª(G°w€á.r >GQŒ(Ê/ÀߪRš6½Å† ‹-&“.#=cÿøS……½{Û~jÝÚV>tèw@QQßá톢˜Q”SØ7²^ö£(Q”ràïEw¿o÷ukªç`\ÁŠs÷qîJ.¼,´ÚlºÌ äü¬YFóСŸÐ´i£GJ+r:n&„;w—-ç"ãOÝDªBhµ*’“œ<­VE]ö«WÕÌœKJJ,GÚ®ºÀ´Œj¦² ôBä8"#Ò‘U]@ä'Dìoöó{‡›7u¼úêcˆø!r‘+ò¥Wt/OD:"ò/DšTtt‡:¬Dd8€FCiex÷Ý$'÷¯ªáÝìãÆÅWÙÓÓ»:-„ÌÀÞŠ×ý€3’`‡ç+(Ê1D>V§€ì9€ÃT¶½þ}š6½ÆªUŸW”Ý€óW/v`VGQ ˆÜ¨VëÕêÕh³@Ã!Ò¡âo"çqy ­–ò鈸wÄTÇpû¶JæÎ ÉÉýE«UU}ѻٯ^õ—3b%%å1›=ªìõªs5ÿÈ~Dö 2 å5ˆô®O†¼Û·16æ,ðÿ.¤#ÂO@hcùû*¶EZçåÑIEND®B`‚ngraph-gtk-6.08.00/osx/ngraph.iconset/icon_256x256@2x.png0000644000175000017500000013124613070106167017444 00000000000000‰PNG  IHDRôxÔúsBIT|dˆ pHYsvv§ÂxêtEXtSoftwarewww.inkscape.org›î< IDATxœìÝwxåöÀñï$„Þ¤ PA:*EM€ˆT)ID¥£Àµ¡^½‚;"èý ˆ¨€( =€H %$iŠtAH=•dŒá"’ì»e6[ÎçyîsŸ‡œ™9 nΙ™·h!„]׆í8ìÐQ×õDS’B8LËÍÁ³kš¦u²X, .LKá$i„·å‚³ “®ëñ.8—¤BüÍ{ï½×,;;Û´uñ©åI€D!`já¿YЦi-Ëz¯!„P €~ÎU…¿@\¿~]%4UÓ´§,Ë:g®'„pŽ4Bø)W½ã¦U«V.\˜èèhRSSUK×4-Âb±,wæÚBÇI „Ÿquá¿ûî»oüÙéÓ§™5k)))*§È"t]_æLBÇH „Ÿ0³ðßìÌ™3DGG+7š¦EZ,–¥Îä$„°Ÿ4Bø8wþ›;wލ¨(®^½ªrê ài]׿u&?!„}¤ÂGåGá¿™M@¦¦iO[,–%Žä(„°Ÿ4Bø˜ü.ü7;þÛå‰!n@/å …ÿfÉÉÉDEEqùòe•ð,MÓúY,–Y¦&%„“@/ãm…ÿf/^$**Š‹/ª„gýu]69-!ü’4Bx o.ü7»té3gÎTn4M`±X¢ÌÎK# €ÎW ÿÍ.]ºDTT.\P Ïèº>Óܬ„ð/Òá¡|±ðßÌÎ&ÀªiÚK‹ås³óÂ_H „‡ñõ³˗/3sæLå&xY×õÏLNK¿ €Ÿ ÿÍ._¾LTTÉÉÉ*áVMÓ^±X,SÌÎK_' €ùÌ_ ÿÍ®^½Jtt4gÏžU ·jš6Äb±L6;/!|™4Bä)üwíÚ5¢¢¢”›à5]×?19-!|–4B¸™þÜ9м¡ëúD“ÓÂ'I „›HáWsíÚ5¢££ùóÏ?•â5M{Çb±|`rZBøi„0™~ûÙÛÃu]kfNBøi„0‰~礤¤Í™3gT¡ëú3s—H „‹Iáw´´4¢££9uê”R¼¦i#-Ëh“ÓÂ'H „‹Há7GZZ³fÍâäÉ“Jñš¦é‹e”Éi áõ¤ÂIRøÍgoŒ×u}¨™9 áí¤ÂARøÝ+--Ù³góǨ"M€y@;IáÏ?éééÌš5Ëž&àC]×ß63'!¼•4B(’ÂïÒÓÓ™={6'NœP=俺®¿efNBx#i„°A ¿çÉÈÈ`îܹ$%%©òº®¿ifNBxi„È…~Ï–™™Éܹs9zô¨ê!t]ÃÄ”„ð*Òq )üÞÃ&à ]×_ÄØG@¿& €‘Âï233™7o¿ÿþ»ê!Su]ÿÒ?' €ð{Rø½ŸMÀ4à_º®g›˜–Má·¤ðû–ÌÌLæÏŸÏ‘#GT™ –&@ø+i„ß‘Âï»®_¿Î¼yóìif¥ þHá7¤ðû‡¬¬,bbb8xð ê!_/H ü4ÂçIá÷?YYY,\¸¨2·nݺ½###³ÌÌKO" €ðYRøý›MÀ| —®ë×MLK! €ð9RøEެ¬,-Zį¿þªzÈ §4ÂH |†~q;41ÀsÒ_' €ðzRø…-ÙÙÙ,Z´ˆýû÷«²xVšáˤ^K ¿°‡ÕjeÉ’%ìÝ»WõE•*UzvРA™fæ%D~‘@x)üÂQ4‹+UªôŒ4ÂI ¼†~á V«•o¿ý–={ö¨²²L™2Ý_}õÕt3óÂݤO ¿p5«ÕÊÒ¥KÙ½{·ê!«€îº®§™˜–n% €ðXRø…™hbnÒ_! €ð8Rø…»X­V–-[Æ®]»TY t•&@øi„ÇÂ/òƒÕjeÕªUüôÓOª‡¬)Y²d×7Þx#Õ̼„0›4"ßIáùÍjµ˶mÛTY[²dÉ.Òo& €È7Rø…'q  ØtÐuýª‰i ai„ÛIážÊjµ²zõj~üñGÕC¤ ^Ká6Rø…7°Z­¬Y³†~øAõï‹)Òáí·ß¾bf^B¸š4ÂtRø…·q  ØX¤H‘öÒo" €0~áíÖ¯_ÏÆUÃ7íu]¿lbJB¸Œ4Âå¤ð _Ï÷߯¾h'M€ðÒ—‘Â/|UBB6lP ß^¨P¡°aÆ]03'!œ% €pš~áìm€'t]O61%!œ" €p˜~áoùî»ïTÃw,Xð‰wÞyç¼™9 á(i„ݤð ¶iÓ&âââTÃw,X0Lšá‰¤ʤð a°³ Ø„éº~ÎÄ”„°›4Â&)üBü“MÀn 4“H r%…_ˆ¼mÞ¼™uëÖ©†ïZéº~ÚÄ”„P& €ø)üB¨Û²e k×®U ÿ5((¨ÕðáÃO™™“*¤7HáÂ1ö6@k]×Oš˜’6I ¤ð á?ýô+W®T ?€ñ:@š‘o¤ðcRø…p­íÛ·³bÅ Õðƒ hõî»ïþafNBäF?$…_óØÙ*P @¨4"?HàG¤ð á;vì`ÅŠX­V•ð£@¨®ëGMMJˆ[Hà¤ð á~v6I¡#FŒøÝ켄È! €“Ÿ¿ÒÓáÔ)8w.^„"E lY¨PÊ”Éïì„;ìܹ“åË—K <’4>H þ°ZaýzX¹6o†;!3óö±÷ÜÍ›CHDFBÉ’nMU¸Ñ®]»X¶l™jp ãuÀ“ÓB_"…?¤¤À§ŸÂ´ipø°ýÇ/=zÀ›oB­Z®ÏO俟þ™%K–­~,00°Õˆ#ø¯IuÒø)üùgÕ*xùeøÝmƒ‚à_ÿ‚±c¡X1çÏ'<‹MÀqŒu~39-áǤðbRøóOv6 bÜù»Z½z ÁÁ®?·È_¿üò ß|ójpú¯'ûÍÎKø'i¼þü•‘½{Âæ]£reX½40ï"ìÛ·Å‹+7Ëï39-ᇤð"Rø=ÃóÏÃŒæ_ç®»`Ï™1à‹ìlδ9rä/fç%ü‹4^@ ¿çøæèÞÝ}×ëÞ-rßõ„ûìß¿ŸE‹)7@]×69-áG¤ð`Rø=KJ T«fÌëWvP( ¤b<еsl÷7ß@×®ö#¼Ã¡C‡X°`YYY*á´9rä^³óþA$…ß3}õ  Xxx¨Ë?¿egÀgÀO¶Oת•±¾€ðMv6gÿz M€pš4D ¿gkÚ~üÑFÐ3À§€Ê{{+0xHË=LÓàÀ¸ï>ÅD…×ùí·ßX°`ׯ_W ?‹ñ:`Éi ' €ÂïùRRŒ{ò\Ìíy`ö«ÖíÐuý]×—[p¢øÓ§Oú÷ï/ÅßdÇŽÙxÇ‹?@뼜”äĹóSFtî |ß™x…êÕ«Ó£G ( ^:;;{­®ë›—ðMJÿ• ×;~ïUº´€?œ¼À '¯ï‰22ŒyŒ+Wÿ³Záwò;+W½zuzöìÉܹsÉÈȰ^XûÞ{ïµ9ränHOøyàRø½ß™3pç6‚–ãØ¿ð%à~ŒW¹˜0^{Ísç—Œ ‡åËÿþç£GûïæON^&))Iµ ã¿¢'u]ßjrZ‡H`")ü¾Ãj…òåáüù<‚JË€–vœø"ð°!ï°5kà‰'ì8o~ÊÈ€ˆX¶ìö?ï=1½9y©cÇŽ1gÎå&  ÝÈ‘#·˜—ð ù€/Òuý‘ÏšŽž'88˜®]»Ji¯|ì;4 NŸ†­yÝ_¥³€d >PR!¶;`c×*U`Ò$/G—™ ‘‘¹€„ã/4$Ämiy«R¥JQ­Z5öíÛ§²N@a«ÕÚ#$$dsbbâQ7¤'¼œ<p!¹ã÷m@:6¦æZ`¬X¸œ~Öa4 ,Ðuv·œâÿí·jñk×BX˜¹9ùˆãÇ3{ölÕ'×4Mëd±XÌÎKx7i\@ ¿ÿè×fÎtßõ*W66*[Ö}×tHVôì óç«Å¿öš1°A(;~ü8sæÌ!==]%ƒŽNý—æöÿŒâïS¼ÃéÓ§‰ŽŽVmÒp]×W˜œ–ð"ÒäA ¿P±p!üç?pô¨ãç(R^zÉñ_¼¸ËR3Gv¶12:Z-¾˜>]Š¿ NŸ>ͬY³HIIQ ÏÐ4-Üb±,·*ü4·!…_Ø+;bc›Üuë@å¦LÓ A£>öî wÜa~žN³Zað`リè×¾üRŠ¿‰Îœ9Ctt´rD躞ÇB Â_Hp)üÂ23aÇØ²ÅØDèüy¸pÁ¸³/[ÖXQ°Q#hÖÌ ¦÷ÝÌj…ýËħ¢o_cc)þ¦;wîQQQ\½zU%ÿ\-þé§aΔÅFÝÅÞ&xZ×uÅU›„/òë@ ¿ ¬VcJÂgŸ©ÅGFÅ_mK[áBv6™@]׿19-á¡ü²Â/„"«^y¦LQ‹ˆ0ÖâŸoΟ?OTTW®\Q ÏÒ4­—ÅbQ\ÅIø¿j¤ð a«ÕXµïÓOÕâÃÃÕ¥øç;š€>‹eŽÙy Ïâ €~!ìdµÂ!0y²Z|÷îÆ>Rü=Frr23gÎTn€¾º®+.ì |O7Rø…pÐС0~¼Zl·nFñ 27'a·ääd¢¢¢¸|ù²Jx–¦iý,Ë,³óžÁ')üB8aØ07N-¶kWX°@Š¿»xñ"QQQ\¼xQ%òê@ ¿.2bŒ£ûä“Fñ/\ØÜœ„Ë9м¬ëºâÂÛxe …_9FV‹}â XºTŠ¿»|ù2QQQ$''«„[5M{Åb±(.!¼‰W5Rø…p1‹Þ{O-VŠ¿Ï°· ^Õu]qAá-¼¢Â/„ >üÞ~[-6,Ì(þEŠ˜›“p›«W¯ÍÙ³gUÂ­š¦ ±X,Š CoàÑ €~!LòÑGðŸÿ¨Å>ö¬ZÅŠ™›“p»k×®eOðºÅb™dv^Â=<²Â/„‰þû_xë-µØ–-â_¼¸¹9å!- Nž4¶U¾tÉxQ¦ T¨àeÛ){({›à ]×'šœ–pj¤ð a²?†ÿ[-öÑG!6ÖíÅ?;Ö¯‡+`Ëع®_¿}lµjТ„„;—,éÖT}Ƶk×ˆŽŽæÏ?ÿT=d¸®ëŠsF…§òˆ@ ¿n0a¼ñ†Zl‹°zµ[‹J |ò LŸGŽØ|±bУ¼ù&Ô®íúü|½M€¦iïZ,–÷MNK˜(_)üB¸Éĉðúëj±Í›Å¿D ssºÉÊ•ðòËpô¨óç ‚ýËXÓH†-Ø'%%…èèhΜ9£zÈ]מ&_)üB¸Ñ¤IðÚkj±ÍšÁš5n+þÙÙÆŽÃSL˜e^¯žñ#8ØõçöeiiiÌš5‹“'OªbÑu]q.©ð$nm¤ð áfÓ¦ÁàÁÆö¾¶<òˆQüÝô"=#z÷6ö2KåÊÆÃŒ Ì»†/²· Ð4M·X,£LNK¸˜[)üBäƒéÓaÐ µâߨÄÅÁw˜Ÿ×_ €¯¾2ÿ:wÝ»wËŒ{¥¥¥1{ölþøãÕCÆëº>ÔÌœ„k™ÚHá"Ÿ|ù¥Qü³³mÇ6lhÿ2eÌÏë/‹Cx¸Û.G·nÆ5…}h>Ôu]qu)‘ßLi¤ð{Žôt8}Ú˜Cœ E‹wB*¸õf/_øígÿê+xá-þ×®ÁÝwùsvT¸(¤g€ßì»î7ß@×®ö# ==Ù³gsâÄ ÕC>Òu]q•)‘Ÿ\ÚHáÏV+ÄÇÿoõŽ™yûØ{ï5|‡†BD„[}›ÂŸ?û _ Ï?¯Vü|Ð(þn~6>c†‘¢MåAÀ³@mþùÛê,°ø Øfût­Zë û9ÐüW×uÅÕ¦D~qI …?ÿ¥¦Â§Ÿc¾~³óÎŒéÞÏrÇo‚ùó `9ŒG¡{óÀO£¤7‡1R™4V»®›µØËŸ?û öÿûîó¨âÆT¼Þ½m]B×[ Ð¥c ú«‹Íâ_¥Š±€p­ÀÀ@"##©©>‡v0]×uSêPçÒ'rÇo>¥9Ô=€)#ªm±_¯âñs¨ýù³°j•±¦mzºíØ5ŒÑþwÝezZöúõW¨[Wm‹ -€ê+^Nb,þ³£ÉS`±S<…9²²²X¸p!ÔçäΫ[·n¯ÈÈÈ<&n 3¹¤ S§N<øàƒ®ÉJÜVjª±¿yž¿8` µ±÷-Û =ÇC¹üœCíÏŸ0æ%víªVü«U3Š¿7â}ûK¸KåÊÆ€Î|XúÀ¯8ÐÌz麮0˜E¸šKÁdggÇ9»÷ö:zÔF¼˜„cClÚ6ͱóݹ+ùóggõjŸ*þ`ŒÄ¿÷^÷\KÓŒ’¥ø›/00ˆˆjÕª¥zH`fLLL ‰i‰\¸ì̵k×ˆŽŽæÂ… ®:¥¸…Í8›Åœ¸@k'¯o"¿ýìkÖ¨ÿªUwþ^üÁØ{aÁ÷lÊ4fŒ üs§œ& víÚª‡<·oß¾Yº®03/ñO.„qåÊ¢££¹té’+O+þRº´å}:;ÞæõMä—Ÿ}íZèÒÒò #§ø«OÉÊwMšÀ† æ S0ž4¼óŽ9ç¹ËX¿~}ÕCžæM:5ÈÄ´Ä-\> óâÅ‹DGGsåÊWŸÚïÙ|dú3°ÂÁ“_Ä£çPûÝg_·žzJ­øÅß]ÏÔ]¨~}ؼÚ¶uíy«To¿5þùCÓ4ºuëFõå4ÃO:5Wš÷±Õäµjw®’““‰ŠŠâêÕ«Ž.rQ¡‚Â{Ì^Øœõ€ÎÀ±¼ÃêÖµó¼.äWŸ=.N½øW©âµÅ?GÕªÆ0‡ Œ! Î(RþýoØ¿:urM~Âqš¦ÑµkWî¿ÿ~ÕCÂO:õÍ'Ÿ|RÈ̼„!·  ìvôÄçÏŸgÖ¬Y¤¤¤8z q6çP_ZC06UÉKÆ6ªõ€ïó­RZÛxOn6¿øìßo<öOMµ›Sü}dy»ÈH8|V¬0Š·=;2Þ?Lœüÿý¯±ã ð š¦Ñ¥K{š€ŽÉÉÉ‹¥ 0ß­c¦ÀXó?<çgº“g+V¬HŸ>}(R¤ˆS熠NÅ9ÔÀcüouàp øˆ’Õ®ë s¨}þ³oÜh씣òä¬bE£ø×©c~^ù$#vì€-[àØ1cõÀädcaٲƊ‚Ã#Èo`µZYºt)»w+ßWÆÝt]Wx&‘Ó4ÇX;­·4Î6•*U¢wïÞöºMÖ=SÿþÆ´&w©\öì1~éæ7Ÿýì›6Á“Oªÿøøü}'#„hV]¥ 0GƽÐ&ŒÍ~ìžE`{á©S§˜3gv'(þiÒ$÷=õ €™3=£øƒ~öM›Ôïü+Tâ/¼–¦i<õÔSö,÷$°D×u¹{4A6g@çí±ÇCÓl÷ 'Nœ`Μ9dª¬a.òT¢„± ¼;¶©3ÂÂÌ¿Ž*Ÿûì›7Å_eÖŒá4M£sçÎ4iÒDõ'¥ü±¼Gv1§§Ö¬Y“Ç\© 8vìóçÏçºÊ¦"Os¨«T1çüÆ&8ÃòØ[=¿øÌgß²E½ø—/ë×C=‡&æáQ4M£}ûö<ôÐCª‡úÈ™å¾Ä-\²@Íš5iÞ¼¹Rì‘#GX°`YY²ÿƒ³êÕûß ¤+òeðâ‹®=¯+yýgß¾:t€Ë—mÇæõEU„ðxš¦Ñ®];~øaÕC¿víÚ*]×eއ‹¸l! zõêѬY3¥Øß~ûÅ‹“-ÛA;+8ØØ$náBçW€-RÞz˘CÝ¡ƒKÒ3•×~ö;Œw *Ëfßq‡±úb*Bx MÓxòÉ'íi¤ p—®Ø Aå÷:û÷ïgñâÅX•æt [ÂÃ9Ô«VkÈ-ªvœ¦ÁÀ'ŸÀÉ“ðá‡Æ®{ÞÄ«>ûÎêÅ¿ticEÀÆMNJˆü“Ó4mÚTõ–@ìøñãK˜˜–_Ð0vEÏ•­i€üÇŸmÛ¶;w*%ðÀðÔSO)!ê23Z³u«±‘ÍùóFÍ)V̘3]¾¼ñ.½Y3÷ ¨s'ýì»v+ %+,@SüÕJ áÕ¬V+k×®eëÖ­ª‡l*R¤H»·ß~[Öw) À?ü <׳aÆtêÔIšá»ví‚6mŒnÄ–R¥Œâ¯>@JŸ±~ýz6nܨ¾h§ëºÂ`q+—o”£iÓ¦<ðÀJ±;wîdÍš5f¥"DþÚ½Û¾â¿v­á·Z·nMË–-UÛ«u]/ibJ>Ë´àᇦ®âœå~øAšá{ö챯ø¯YꢄðI­Zµâ±ÇS oÄëºîc/3Ígj i-Z´ víÚJñ[·n%11ÑÌ”„pŸ_5ö¹=wÎvlÉ’Æ–xê¡„ði¡¡¡ö4uÒØÇÔŒ& eË–Ô¨QC)þ»ï¾ãûïmlÏ&„§;pBCáôi۱ŊÁò寮6BˆBCCyüñÇUÃqcÇŽõ…Ë=Ÿé M@hh(ÕqgÓ¦M&g%„Iì-þ+W‚úŽ~%$$„6§Œ4H IDATmÚ¨†7ÌÈÈ&@‘[ø_P­Z5¥ø¸¸8¶mÛfrVB¸ØÁƒÐªœ:e;¶hQX±Ôïp„ðK-Z´°§ x0###N×uÙ$Ú·5`ìFpp°RüªU«Ø¾}»ÉY á"‡wþ'OÚŽÍ)þ!!¦§%„/hÑ¢aê»s=H`ƒ[ø_P¹re¥ø•+W²gÏ“³ÂIöÿåËx!„²æÍ›ÛÓ<lÐuýNSòjno (À“O>I¥J•lÆZ­V¾ýö[~þùg7d&„’’Œå}ÿøÃvl‘"ÆnC­Z™Ÿ—>¨yóæ<ñĪáu€„÷ßßv±ñCùҀѴmÛ–òåËÛŒµZ­,Y²„¸!3!ì”d<ÆOJ²[¨,Zd,,„pX³fÍhÛ¶­jxíÌÌÌ]×Õ;û‘|k ,H‡(WÎökšììl.\È¡C‡Ü™ Ž3ã=j;¶`AX¼Ú·7=-!üÁ#k~^B˜ ..Žððp&OžÌùóçX½z5eÊ”¡iÓ¦¦\óêÕ«L˜0ÈÈHÖ¬YCzzúŸ;wŽ+VЭ[7¥qa·ªP¡åÊ•ã×_ÅjµÚ /eµZ»†„„,OLLL¶ûb^ÊcŸä(S¦ íÚµ£`Á‚6c/_¾ÌÌ™3¹té’éyedd0mÚ4jÔ¨Ák¯½Æ™3gcÕÂ×_>øÀô„‰Îž5VìûåÛ±0s¦á•âââx衇 c×®]û™ÕjeÈ!Lš4É¥×¼ví“&M¢zõê :”‹/Þ6îÀ´jÕÊáÁÞõêÕ³çI@0Æì€º]Ì yô€ÅŠ£R¥J9r„ììì..ŽÀÀ@üq—å Lrñ¢1Õï–Ç ·¥iðÅп¿ùy a¢&MšP©R%V­Zeó÷êúõë)X° r••Ett4|ýõ×J7N¹INNæÜ¹stíÚÕ¡ãË—/O… Ø¿¿R`µZÃCBBV'&&þéн€W5`L,_¾¼RpíÚ5>Lýúõ)P €ËrhѢŊcݺuJñ HàÉ.^4¶ôݾÝv¬¦ÁçŸÃ Aæç%„4nܘʕ+³råJ›¿Wããã)P @ž¯7­V+‹-"<<œ3f8Uø4hÀ§Ÿ~ÊðáÃ:Oùòå©\¹2ûöíSiŠa< X“à“M€×5`L¼ãŽ;8zô¨ÍÄ«W¯’””Dýúõ tY-Z´ D‰¬]»V)>11‘´´4Ú´i㲄‹äÜù«Ì{Ö4˜26?/!ܨqãÆÜu×]JM@BBB®O6ãâ∈ˆøÛlGÕ­[—)S¦0yòdêÕ«çÔ¹r”-[–J•*±ÿ~›¯“b= X“˜˜xÆ% x¯lî¸ãJ—.­´3àåË—IJJ¢^½z.mš7oNÉ’%•›€M›6Iài.]‚¶maÛ6Û±šŸ~ /¾h~^BäƒFÌŠ+”š€›ŸlÆÅÅÑ£GÆçð">9î¾ûnÆÏôéÓ©_¿¾ê¢>ÊÊ–-KåÊ••› G«V­â|jÙY¯mÀhJ”(¡´3àåË—9yò$õêÕS¢¤Y³f”*UÊ®& 55•°°0—å té’qçÿã¶c5 &O†—^2?/!òQÆ •›€ÄÄDŽ?ΤI“xï½÷œÞ›¥jÕª|øá‡|ýõ×<ôÐC.ý]}«2eÊØÓ±Z­!!!ë}f¯nÀèäŠ/®Ô\¸pÁ´& bÅŠ¬ZµJ)~Ó¦M¤¤¤HŸ._6îüU‹ÿ'ŸÀË/›Ÿ— aÆԬY“o¿ýÖf°sçNŽ=êÔõ*T¨Àˆ#˜={6M›65µð߬L™2Üu×]ìÛ·O© "[µjŸàM€×7åÊ•£P¡B?~Üfì… øóÏ?©[·®K+5iÒDy: ÀæÍ›¹víO<ñ„ËrŠ®]ƒŽaófÛ±š“&Á+¯˜Ÿ—¤AƒÔ¬Y“¥K—ªG‡”+WŽ‘#G2oÞ èѪU«Í ¶¡y Ÿkîºë.®_¿~cƒž¼œ>}šÔÔTjÔ¨áÒâkÏt€Ÿ~ú‰Ó§O;Ý\¸pÁc¿\ù&%:u‚„µø÷߇wÞ17'!<ÔÙ³g=z4={öä‡~pêÑÁ‚0`‹/&22’âÅ‹»0SsØÙüëIÀæÄÄÄ£nHÏ¥<~7@G=üðÃÊ GüøãÊÓøìÑ¿¾üòKå­S§NeðàÁJ í~þùg"## fýúõvï³RSâ¯?z´á—Ο?ÏСCoÌÁOKKsúœááá|ñÅT®\ÙºOÕªUéÙ³§ê+ŠbÀŠQ£F…šœ–ËùäMÓ&55•sçÎÙŒ?qâT¯^Ý¥yäL§QI»}ûvNž<©ü$`ÿþýüûßÿæÅ_ä—_~!33“E‹Ñ´iSî½÷^W| ;ƒjCôÞ{0b„¹9 áa®\¹Âĉ‰ˆˆ`ýúõdffºìÜ{÷îuÉ“Íü`ï“ "$$dkbb¢íÕé<„Ï6`4U«VåÊ•+$''ÛŒ?qâT«VÍ¥yØ;fÇŽœHÍš5]ö9¼BF†Qü×dà?ÿ1cÌÍI‘‘‘ÁŒ3èÖ­ß~û­Óúl¾¶´÷ɦ')Q¢÷Þ{¯=M@xHHȉ‰‰ÎO›0™Ïޏ™¦i„††*ßÙ¯_¿žÍ*‹ÄØéé§ŸfΜ9Ê‹]̘1ƒ^xììlΞ=ËСC©Y³&Ó¦MSù‘ôôtÂÃÃY¾|¹³©{œâ¿b…Zü[oÁøñææ$„ÈÌÌdÚ´iÜsÏ= 4Èéõú[´hÁwß}ÇÊ•+)\¸°ÍøéÓ§3hÐ Ó2S¥J•èÕ«—êë¢À²Q£FyüR¯gë¦ëzž'8p  Ó1Wvv6k׮娱cJñ:t I“&.ÏcáÂ…<÷ÜsÊïÚj×®MRR©©©]¯páÂüðÃÜÿýï522 "–-S‹óMøè#ss"Ÿegg³xñb† ÆáÇ>_³fÍ3f ­ZµºñgkÖ¬¡K—.JO À´iÓܶܯ+>}šèèhÕßÅ隦EX,½ó¾'Æ]wÝ¥¿råJvìØáò<"""˜;w®òêW¿þú«ÃÅ¿Y³f¬\¹Ò?Šd¤zñã )þ§egg³páBêÔ©Cdd¤ÓÅÿþûï'&&†Í›7ÿ­ø´mÛ–¥K—*Ý!ßüdÓÛÜyçôîÝ›¢E‹ª„²Z­‹t]ïlv^Žò« 00¶mÛR©R%¥ø+V°wï^—çμyóL[3¯/«ÏÉÌ„§Ÿ†¥KÕâ_þïÿÌÍIˆ|bµZY¾|97&22’ƒ:u¾zõêî]»ˆˆˆÈ5î‰'žPn¾úê+zöì©2ºÞãØÙzjàw @hÛ¶-*T°kµZY²d ¿üò‹ËóèÞ½;K–,qér˜ª_VŸ‘•½{÷ߪſö|ü±¹9 ‘Oâââx衇èܹ3»vírê\µk×&**ŠÝ»w¡4x/,,ŒÕ«W+-ø3oÞ¯½ö𣩿«råÊѧO{š€£FêjrZvñÛŒ& C‡”-[Öflvv6111:tÈ%×ÎÌÌ$::š:uê0yòd‡Vÿ翬^+çÎ_µøèö⟞II°cÄÅ»8 ³Q…—É™¥Æ•+WÜvÝ-[¶Ð¦MZ¶lÉwª›\å¢J•*Lœ8‘0pà@§¶æmÕª«W¯¦D‰¹Æ+VŒW_}•‘^¼þFN×ç¼IA«Õº@×õnfç¥Ê¯fä&--åË—+­P @ž{î9î¾ûn‡®•3"wøðáN7<ð7nôŠõµ]*+ úô9sÔâ_x¦N“ŸŠX­ÆŠÃ+VÀ–-FáÏm¢Ç½÷BóæjL\Pûý!"7n¤}ûökŠ ,Hß¾}Ñu]y,–§;þý¦MG6M+^žyƘ•èok6y««W¯2eÊÆwÛßÍ›7'66ÖåMÀ¾}ûÐuE‹9üÔ0G™2exå•Wxã7LmV6mÚD»víHKK£_¿~Œ9Ry&–7±· Ð4­ÅbQ¼‹1‡47¹zõ*Ë—/Wú,T¨½{÷VÚä"..Ž¡C‡:ýn.7~ÓdeA¿~0k–Z|ÿþ0}º©Å?>^|Ñx´ï¬  cv¢®ƒÂº*"Ÿ|õÕW¼õÖ[6—oÖ¬±±±”*UÊékþþûïŒ7Ž3f8=r¾xñâ¼ôÒK :”Ò¥K;›ŠíÛ·S¦Lî¹ç·\/¿$''3sæL{žôÕu]ñnÆõüz À­Š/N§N”©§§§3kÖ,N:•kÌÆyüñÇ]20'/+W®¤k×®.Ù½ËcegÝCŠv6¼ò ´níšâÆë‚ñãᡇàÄ ×œS¸^ëÖ­•Šú–-[hݺµÒ>$¹9vìƒ º±¨3Å?çûáÇ7nœÛŠ?KÆûzñã©JÿþýUÿn™º®÷69­\Ip‹âŋӡC¥waiiiÌž=›³gÏþíÏs¾ø-[¶dÆ åQ¬X1ºwïN±bÅ”âcccéÖ­›o6V«q›­ß·¯©Å?#ž{Îxìo†Ÿ†¦MÁ„å'„ T«V„„¥‚¶}ûvÂÂÂìnNœ8Á!CìZú;7 dàÀ:tˆI“&)MŽ+]º4}ûöµ§ øjÔ¨Q}LN붤¸k×®)/Ó{ýúõ¬Ò·eËâU÷Ÿ¿ÅÍ_ÖE‹«<È/66Ö÷žäÿ©SÕâûô3L}ìÿÒKê“uò$´oNÜ< U«VÄÄD¥-·wìØA›6m8þ¼ÍØsçÎÝØóã“O>qj‡¾   È‘#G˜:uªÏ ¸ó¥J•¢oß¾ÜqÇ*áV«õ+]×ûšœÖ?Hp‹S§N±fÍ¥Ž;((ˆgžyæ;¾ñÆL˜0Á®¹ø¹}Y[¶lIll¬ê4V¯^M—.]^:Ø£X­Fµýâ µø§Ÿ†/¿4µø/Yb\ÂNœ0f/ ÏTµjU”¶ÜÞ¹sgžM@rr2º®S½zuÆïÔ÷7 €ˆˆöíÛÇÔ©S}rÀ7(Uª}úôQm0žüËä´þqQñ—'N°jÕ*¥»ÿœA€¹M|íµ×øì³Ïl6*_ÖG}”U«V)79sxu`µÂË/Ã矫ÅGF3œ˜»lKJ dçAw6@sÀö ãß,^l4Â3ÙÓìÚµ‹6mÚpîܹvõêUÆOõêÕ5j—/_v8MÓnü.‰‰‰¡FŸK¸†M€fµZ§èºþ¢Ùyåà/ÇgÍš5Jƒl *D¯^½¨R¥Jžqƒæ‹/¾¸m`ï—õÑGµëIÀÚµki×®W¯^UŠ÷(V«1Âî³ÏÔâ#"Œ5L,þ`<ö¿e¸Ç핆{óÀOÀ:`p8ÌÀh L™â@²Âm‚ƒƒIHHP*¸9MÀñãÇ™4i5jÔ`èСJÓóÒ¦M¶oßNLL µjÕrê\µr^”)SF%\>5jÔK&§uãb~? ðøñã¬]»V©ø.\˜ž={ÚõXmúôé <øÆîWmÚ´áÃ?¤aÆvçºyófÚµk§|§ðØc±råJïY,Èj5–ì<æÍ3½øƒ10ïÇmõ¦*ßu+ð%ð*ǰ M3fÜwŸb¢"_œ>}šV­Z±ÿ~›± pÉømÚ´aìØ±<ôÐCNŸK˜ëêÕ«DEEýí P¬š¦ ±X,Š¿ã÷OŽ;¦|ç_¸pazõêe÷;µ^x)S¦ðä“O²mÛ6Ö­[çPñc‘øøxÕGJlذöíÛ{Ï“€¡CÕ‹÷î0w®[Šj*lÛf#h0µâFûýð-y~­Vøþ{ÅsŠ|sçwOݺumÆ:[ü[´hA||<ëÖ­“âï%Š/NŸ>}”öŸÁx0I×õWÍÌɯ€#GްvíZ¥}©‹-Jß¾}•þ¹ÁƒK“&M:þf7fݺuª”øþûïi×®[×(wÈСðá‡j±Ýºwþ&m§|«£GBœ«;€IEÝ^m3qà¼Âírš€zõê™rþ¦M›²lÙ26nÜHhh¨)׿±· &Ž5jˆYùømpäÈâã㕊±bÅèÓ§+VtCfjìm6nÜèTœœÌ°aجzwn¯aÃŒUpT´ooÜù»©øƒ±©OžšjK6Ü^k'¯/Êï×=½MÀ­k”gffMíÚµ4hPž›å1b£Gv,a‹Tˆ'ž€o¿Í÷-òzÛÚ²ã"Ð ·›|ÔlŒð¯RÅØtHx–~øN:Ñ¢E \rÎëׯóÅ_pBvƒòö0·Z­ïéº>Ò×ö‹à×_U.þv.ÚàQxà6lØÀwÞ©ŸÓ|ýõ×Ô­[—>}úðûï¿ÛuÍ‘#GòÞ{ïÙ—¨®ƒê1aaQüÁX–׿+Ø,ààŒf`0XÌ>žî˜6h»ÏbÀAÏñóÏ?I³fÍX±ÂÑ÷>¹;zô(!!!v…÷Ê™bnÇ,³Qº®+œÊÏ7û÷ï·»ø«Î±÷DuêÔ!!!Ayã;vп~ûí7‡®W©R%Ê”)£ôZ€>‚Q£ÔbÛ´¥KAagFw¨UËØhPIŒúOÏÿbÅM~*W6EùoÿþýôîÝ›x€… *ýNqTRR¡¡¡‘ùŸ~ÃufÞv¶ ðé`ß¾}|¯¸‚Š[8z´Úµkoêî_eË–eܸqüöÛo¼üòËjƒ”þû_øÏÔ.в¥qçï!Å?ǤIî3g‚âøNa’¤¤$ Dƒ ˜5k–z³{ÅŠãµ×^£Q£FJו&À¿8Ø(Οþ'ŸmöìÙÃÆ•bË–-Kÿþý}¢øç¨]»6 /\”›%JðöÛosøðaÞ~ûmŠ-ªvàÿý¼õ–Zì£ÂªUPÌ™‰õæ(QbbÀoˆÆŒ1Þ€ˆüqüøq† B­Zµ˜6mšÒj¡¹)T¨ä·ß~c„ ÄÇÇÓ´iS›Ç;vŒÐÐP>ìðµ…wQÝkæ&ÿÑuý#G®å“ Àîݻٺu«RlÙ²eéÓ§ò&;Þ¤V­ZÄÇÇ+ ÌK±bÅxûí·IJJbܸq”*UJýà?†7ßT‹mÑbcÁƒ÷.hÔ6l0ç™! ÀØh˜)K[Ξ=ËСC©Y³&Ÿ|ò éééŸëÖm¾sÆç”*UŠ5kÖðÈ#ØÞ³Kž\1JYÓ4zöìÉï¿ÿþ·;»Lœ¯¿®Û¼¹Qü½¨ 6ÞT,\êßÑÛ+RÄxC²?tèà’ô„¢+W®ÜXírüøñ¤¤¤8|®€€"""øå—_ˆŽŽ¦º#%K–dݺu„„„Ø<÷‰'hÙ²%ûöís8?á]‚‚‚xöÙgíiÞÐuýsw%ñ™`ûöíÊÅÿÎ;ï¤_¿~>Wü]9JÙjµ:·¨É'ŸÀo¨Å6kæuÅÿfáápø°Ñ <õ¨‹Ð4xàã¯êäIc$öà³®]»Æøñã©V­C‡åÒ¥KŸKÓ4:vìÈöíÛ‰‰‰¡fÍšÊÇ+VŒ+V(59[Kà?rš€{î¹GõÁªM€†±+y®t]ÏóTMÊ4?ýô“òÒ›wÞy'½{÷¦ˆ‡.wFRRcÇŽeÆŒN Tºœqv &œ> ²±}Þ_7†uëÀ‹§^Þ*3vî„­[M|Ο‡ Œâ^®”/oŒ#hÖÌ=ƒ =Y\\… ¢eË–n»fFF3gÎÄb±púôi§ÏצMÆGãÆ:ÏÕ«Wiß¾½Í™K 4`„ ´–Õ¡üJff&óæÍ³g}ˆiº®&ïõ À¶mÛØ¹s§Rl¥J•èÕ«—ÏÿãÇóßÿþ—©S§:5PÉ–š5k¯65åË/sTŠ£FçSÅ_¨Ù²e #FŒ`ýúõ-Z”¥K—Ò¦MS¯™™™É×_Í{ï½ÇüáôùZ´hÁûï¿Ïã?î‚ì )))têÔ‰øøøüìž{îaèС 0@–öS™™™ÌŸ?ßž©¡Ó1žÜvîª×¾°Z­lÙ²Å/‹¿«F)«þ]88˜>}úøDñ?sæ uëÖuj”rëÖ­Ù¼y3¿þú«ÍAJ9:Dhhhîk”õ•q篲HʃwþþþüÛüòË/DFFòàƒ²páÂü<55•N:¹tiÝ› dd¤Óséï¿ÿ~bbbؼy³©ß‹-ʲeËxæ™gøüóÏùí·ß8p  0íšÂ{(P€gŸ}Öžq&ÏÓo×x]`µZÙ¼y3?ÿü³R|ÕªUéÙ³'…òi9W«X±"ß|óCsî\âââhÖ¬U«V%!!5j(èÐ!Z¶lùÏwP_ /¼ Å_äjâĉ6¦¦§§Áš5kœ¾^\\7&22’ƒ:u®zõêî]»ˆˆˆp:7E‹eîܹ <˜   ·\SxÀÀ@"##íiú_ÞÚxUSüù奸ªU«òÜsÏQ°`A“3s¯–-[«¼~Aƒ r½s ¶« 8zô(¡¡¡ÿkf΄çŸW+þ<`YÛÖïL›67HKK£sçÎ,[¶Ì¡ëÄÅÅñÐCÆ®]»:GŽ{©S§²{÷n"""Ðlî%„ûä4µjÕR=¤0G×õ’¼¦°Z­|÷ÝwÊÅ¿Zµj>Yüs<úè£6›€ºuësãXnªT©Â÷ßO]ÅMç“’’ áÏɓՋÿý÷Kñ÷cš¦ñé§ŸòÒK/ÙŒÍÈÈ ""‚¥K—*ŸãÆ„„„ÆO?ýäLªòÎ]xÀÀ@"""ìiz³rš¯˜SüUåU¯^=zøÅ;³M›6Ѿ}{._¾|ãÏ-|æÌå9Æ‘À@éo¸vmHHG>Åjµ2dÈ&Ožl3¶`Á‚,X°€.]ºä³uëVÞ}÷Ý Q¥JÞ|óMì3¯ …ÈÊÊbÑ¢Eüú믪‡ÄÏyü«ÕJbb¢rñ¯Q£†ß0¦"ÅÆÆR²dI§ï\*V¬H||<õêÕË3.;Š­ZRüÅ š¦1iÒ$^}õU›±<ýôÓ,Y²ä?Û»wïÕ.-þåÊ•cܸq|˜àà`—¼òøóÏ?iݺõmZ†ó°³ø›¸-±ðNV«•×_I“&ÙŒ bþüùtëÖ}ûö¡ë:‹-rj¥K€2eÊðÊ+¯ðÆoP²dI§Î%„'°Z­,Y²Dy†œÇ>ÈÎÎ&..N¹øßwß}~uç«êÕ«»l¼C… X¿~= 4øÛŸwÇŽâ_³&ÄÇ+ÿììlbcc]¾’¡ðLš¦1qâD†j3633“ÈÈHZ·nÍý÷ßïô2×Å‹¿±¥µ®ëRü…ÏÐ4®]»þãwwn<²Zæÿ£G*ÅשS‡ððp<¶Ÿñ:9M@ëÖ­Ù»w/ݰ£øßwŸq篸|p\\o½õÖiVsçÎõÛFÎß|ðÁ0vìØ<ã²²²n»:ž=Š-JŸ>}xóÍ7©P¡`,¿+D~(X° )ƒÔsšMÓØ³gOž±÷[6;;›uëÖ‘””¤_·n]ºwï.ÅßåË—gýúõŒ}è!>LJBe6ò‘À@®OJM…âǰaÃþ6j;çînîܹ2ÿÙO¼ÿþûdffòÑG™rþ   zôèÁ›o¾IÅŠc# !ò›Y³Ô4M»1x6¯&À£{‹½zõèÖ­›•ÿé'&(n˜rh••EÚ3ϰ~ýú\nܸ‘wß}—ï¾ûî¶?Ïy¿;oÞxÛŸ{Ä€ëׯ³fÍåM:4hpã‡0‰ÅÿFñ?zÓŸåÌ$ˆ‹‹`ôèÑ·]>/+W®¤{÷î,^¼X¦fù¨«W¯2eÊ>øà.]ºäÔ¹4M£M›6 6LyQ+!|¦itîÜ™ üc‘¬|o®_¿ÎêÕ«9yò¤R|Æ éÔ©“3­]k…͆Ž!Àív¨þóÏ?y衇ÈÈÈpxÔöÚµkY¼x1Ï>û¬CÇ Ï”’’ÂôéÓùàƒ8sæŒÓç{ì±Ç1b„òèg!ü‰¦i´oßMÓØ¶mÛ?Ï×ÀÞâߨQ#:vì(ÅßLk×ÂSO)ÿãwþ·+þ9}„@÷îÝ;v¬ò>Âóedd0sæLF¥ü½·%ç—›!r§iíÚµ¸Ñä[`oñoܸ1:tâo¦uë K¥âŸ}×]¼^¾‰¦i‘ÁªU«”‹³fÍäÎßlß:€ÊÜèŠ×Õ«“––FãÆž‰Ñ¦M›ÿgï¾Ã¢ºò?Ž¿G1ö’Ä‚=šhLÔ$FcK,›%±gS$»éeR57â®ÉFÝ$«þ‚´X@c,¡+`£hT°*ؤ Âýý1%‰8—™3Ì\8¯çñ±9÷«âœÏœ{Ï98p€°°09ø×Š¢Ì£>Š›››Ùƒ¿aãc×üè£ðöö6ëZ’T×ét:ÆW»À0ø_¹rEUû'Ÿ|’±cÇZ¸ªz.6ž~ÔìˆÖ¾=DFrµ}{.\H÷îÝùú믩Tsð :”ÈÈHÂÂÂÿüó[g6˜£uëÖüíoãÏþsúš;w.:Ž¿ÿýïF_÷å—_RYYÉ;ï¼cV­’T×Xì!Àâââ þ£G–ƒ¿¥%%éïùmšŒ¬¨àˆ —éܹ3ßÿ='NTÕ¾¨¨ˆI“&eÂÕ꟢¢"“¼4ÇñãÇ™;w.?üð­SMÕ¬Y3<<}pwwÿöÙëÖ­cöìÙf Ìw’§§ç­5øæÉlooÏüùóÉÈÈ`åÊ•tèÐA`¥·Íœ9“¯¾úŠ 0|øpvî܉¿¿?=ôE®'Iu¸ëù_WùÀØÓO?-§ä,íða3rs·mÞ\¿ÃßcÝú¥K—.1fÌRRR~Ó´iÓ¦¼ñÆxxx¨þ$WVVÆóÏ?Ï–-[TµoÒ¤ [·nÅÕÕUUûº¦¸¸˜'Ÿ|RÕF:³gÏÆÇÇçÖzySåææ²bÅ ¾þúkÕÿ«c8ÌiñâŪ>}R¤f'J#.^¼È½÷Þkv?’diM›6ÅÉÉɪ5™(((`ëÖ­ªÞ4t:úÓŸäàoi¿ü¢ÿäoâàСC"##o­nÎ4®ƒƒ6là™gžQÕ¾¤¤„É“' Yb¦EŽŽŽ¬X±‚fÍšmÀÌ™3Mž (,,dÉ’%tïÞÏ?ÿܬÁ¿AƒLŸ>ÔÔTk}ê]þ’¤žÙ ??ŸmÛ¶©Jï†ÁÀ€æ^Vº›ãÇaìXÈÉ1Þöž{`×®? þíÛ·'<<OOONŸ>mÖ4®ƒƒL:UUû7n0mÚ4‚ƒƒMºžÖ=õÔSlß¾]U ¬q(**bÙ²etïÞOOOòóóÍ) ¤W¯^fõ%I’å™} ÀÑÑ‘ââbãÒéxæ™gèß¿Mê“jêøq5 .]2Þ¶iSؾjyùeEEsæÌaݺuªÚ×ô9‚êTVVš}p‘5ÄÅÅ1aÂUŸÌ§M›ÆÚµk±··¯¶MYY>>>,\¸‹/š]Ÿ‹‹ ‹/fРA&÷!ê€$iE¸ r⌭~ð ­õÁÀÎÎfÍš¥ª}YYÓ§OgëÖ­&]ϰ~}РAªÏ¢°%C‡eçÎÜsÏ=FÛnܸ‘3fP^^þ‡ß3¬&èÖ­îîîfþC‡%::š°°0³I’¬Ãâ‡t:Ï>û¬ü-íäIý'5oꎎVÜ~×ÎÎ___fÏž­ª}YYnnnª"„?®_ONNfĈ\RlÌ“O>IDD„ªç.6mÚÄÔ©So=½oXMзo_ÜÝÝ9þ¼Yµ<ñÄ„‡‡+·p–$ ³h°³³ÃÍÍ~ýúYò2’)ƒ¿ l»kgg‡sæÌQÕÞ°’`óæÍwm—••UíúõÔÔTF%dê»¶ 4ˆ°°0Zµje´mHHS§NeíÚµôíÛ777ÒÒÒ̺~¿~ý dïÞ½Œ3Ƭ¾$I²>³Ÿ¨ŽÓ§O§wïÞ&½^RéÔ)ý`þ»5âwäèÁÁúÛ6¤¢¢‚—^z ???UííííY¿~ý&ÌÎÎæ«¯¾bÙ²e”––ÞµÞ½{É}÷ÝgrÝÖ’””„«««ê¶ÌÕ·o_.\È´iÓTm»k ù €TßÔ‰gîDþµ$-MÿÉ_Íàߤ‰Mþ ÿzñööfÞ¼yªÚ———ãææÆÚµkýúõ… Ò½{w–,Ybtð8qâ£GþÃæ:Zðè£NëÖ­-z®]»²råJ~ùå¦OŸn±Á_’$ë>аaC^xá¹õ¦¥=«ÿäæŒñ¶MšÀ¶mú}lXee%/¿ü2>>>ªÚÛÙÙÝÚ5ÐÔµë½{÷&..Î⃩%$''ãêêJ®š½j sçÎ|üñǼôÒK4lhñÃ9 Õ?unÀÞÞž3fÈÁßÒj2ø7jAA6?øƒ~oooþò—¿¨j_QQÁæÍ›MüûõëÇ_|¡ÉÁà‘Gá?ÿùBúk׮ݭÜæÏŸ_kƒ¿$IÖ!ì¸aðïÚµ«¨.¥;ÉÌÔOû«ü`ãFPy,¯-Ðét|ûí·èt:¾ûî;‹\£6îi[Ú‘#Gøâ‹/ظq£YÇò´iÓ†>ø€·Þz‹&MšªP’$['$ØÛÛ3sæLœEt'U'+K?øŸ>m¼­aðWy¯-Ñétü÷¿ÿ½DqvvæÃ?äå—_6{ß|kIMMeÁ‚BþV­Zñæ›oòÞ{ï©Úc@’¤ºÅì ÿZbü32Œ·upÐOûOžlùº,D§Ó±lÙ2ÒÓÓÙ¹s§Y}Yãž¶hgΜañâÅüðÃBŽîÔ©{÷îåþûïP$IZdö3sçΕƒ¿¥;§üÓÓ·up€À@0sÛ\kªºq9ƒ]¸§••…»»;={ödÕªUBC¿3fÌ °°PH’$iÙïˆ;vQ‡TK—ÀÕUÝàoo6ÀŸþdùº,$<<œ¿ÿýï$''›ÕÏ3Ï<ÃÚµk5{OûÊ•+|ýõתö40Õž={˜0a‚ê‡$Iª[´w2J}rù²~ÝþñãÆÛÚÙŸ¨}:»víRußpÚ`AAÉ×”$I{d°EW®èÿ”ãm Ÿü56øïÛ·É“'óÔSOm‘k(ŠÂ›o¾Éÿû_‹ô/BQQK–,¡K—.xzz’ŸŸor_:ŽI“&‘œœL`` ®®®DEE©ºM'C€$Õ?2Øššþ¾¾0s¦åëäÈ‘#¸¹¹1dÈBBBLêÃÁÁG}TU[EQxë­·X¾|¹Iײ”7n°jÕ*ºw§'×®]3«?þÍÉ›={ödÏž=ªÔgôèÑf×"I’6È`K²³aÌ8vÌx[;;ðñY³,^–(üío#((Ȥ×ÛÛÛóꫯ’––Fbb"Ÿ~ú©ª×)ŠÂ;ï¼Ã²eËLº®Heee¬ZµŠnݺáîîÎåË—ÍêoèСÄÄÄVm(rvv&::ZÕ&]‰‰‰µzÐ$IÖ#€­0 þGokgkÖÀìÙ–¯K ;;;¶nÝÊäîO`¸§}ìØ1V­ZE§NøÇ?þÁgŸ}¦ªEQx÷Ýwùæ›oj\·åååøùùѧOÜÝÝÍ>„èÉ'Ÿ$""‚ØØX†n´}—.]ˆŠŠ’!@’¤[ÌYYY"ê¨ß®]ƒ àÈãm4oo˜3ÇòuY@£Fظq#STìS`¸§””D`` ={öüC›Ï?ÿœ ¨º¶!,^¼¸Æu›Ê°§Áƒ>ȼyóÈP³‘Ó]<öØclÛ¶¸¸8F×ðdÇ.]ºM·nÝŒ¶MJJÂÅÅEøAC’$Ù³€¿¿?gÔìK/ÝY^ž~b¢ñ¶:|÷Ìkùº,ÈÁÁ   þt—ý ªÞÓ~øá‡ïÚßÂ… ñòòR}ý>úˆþóŸªÛ›BQ‚ƒƒyôÑGqssãÔ©Sfõ÷àƒxëáISuîÜ™¨¨(£vµmۖ矞¦M›š|-I’l›Ù ¼¼œµk×Ê` SwwË×U  ä™ßí[ æžöxxx°dÉÕí?ùä-Z¤º}Mö4˜2e ‡6«¯x___>ÌôéÓ…^d=zôøÃïµnÝš žžŽ‡‡76ûz’$Ù&;`áÝ 2Ä誕••¤¤¤Ð¹sgZ´h!°¼:,?ÆŽ5kßu:øö[PyL®VØÙÙ1uêTŽ;F«V­ðññá‹/¾ K—.&õ7tèPš6mJXX˜ªöQQQØÙÙ1bÄ“®÷{±±±Ì™3‡E‹qñâE³úêÒ¥ ÿú׿X½z5<ò ˆ}\§yóæL:•àà`®^½Š““ï¾û.AAAŒ?žF ½ž1eee”——×ê5%Éš„åm*p×#Åî»ï>æÌ™£jKUy$°J†ÁÿÀãmu:øï᯵|]VRYY)t€[ºt)ûÛßT·ÿüóÏU?Lx'{÷îå“O>!22Òä> :vìÈ|Àk¯½V+ƒð¹sçX³f o¼ñ-[¶´øõªSXXHQQ‘Õ®/Iµ­iÓ¦899Yµ£3ׯ_'##ƒ|{{û»vf˜ ¸ÿþû­úfbÓòóaÜ8õƒÿŠðú떯ˊDLkWõä“OÒ¬Y3~þùgUí£££)--ÅÅÅ¥F×ùå—_xóÍ7yÿý÷9­æˆæ»hÛ¶-Ÿ}ö?þø#Æ «µƒ‹î¹çFŒaõ3ä €TßhbÀ &3 6dÆŒªž6®W ôƒÿ¾}ÆÛêt°l¼ù¦å몣þóŸÿðÞ{ï©nïáá¡êaÂcÇŽñù石qãFEÕŸjµnÝš7Þxƒ÷ß¿^È£¥€ â¹p!ÞÚeHgooorpv‰³óH³kPý1ãÂ… øúú2wî\ïÚöæÍ›¬]»777zõêev‘uBQLž¬nððò’ƒ¿™Þ}÷]t:ï½÷žªzÉ’%(ŠRíÄÇçË/¿díÚµfËëääÄ믿·~HóæÍÍêKª].Ä“°ÔÚeHõœˆ`ô@U………¤§§Ó·o_£·E!55•öíÛÓ¦M3ËÔ¸¢"˜8vïV×ÞË <<,[S=ñÄOСCBCCUµ‹‹£¸¸WW×[¿vöìY<<<˜?>‡2ëSÓ¦Myï½÷Ø´i“'O–OÙÿJK·ä €dm¢fj@†€+.†I“ &F]ûÅ‹ÁÓÓ²5Õ3ƒ âÞ{ïUâãã)**¢oß¾|úé§¼øâ‹8p€ÊÊJ“kpppàå—_fóæÍ<óÌ3V¿çnkd$õD“½¾tékÖ¬¡°°ÐhÛŠŠ ‚‚‚8®æLûºÆ0ø«=íîŸÿ”ƒ¿…ÌŸ?Ÿ•+Wª^m°téRºvíÊòå˹qã†É×µ··gþüùddd°r¶Œ}– IDATåJ:tè`r_’$I"™¼ö*;;®_¿n´m½ ÅÅú{þQQêÚ/Z}dÙšê¹W_}µF!àæÍ›&_Ëp~Ajj*+W®äþûï7¹/I’$K0kñuNN¾¾¾ªB€aOôÔÔTs.© %%0e ¨]þÅðñÇ–­Ià•W^aÕªUÂ7Ö10 ü)))ÝrW’$ÉZÌ~4%QsèVݸ¡ü#"ÔµÿÇ?à“O,[“ô/¿ü2«W¯ çÒ»wo¡}K’$‰&ä0'' Œ¶U…Í›7óË/¿ˆ¸´íiÔV×váBPy¦½$NYY7oÞäž{îÒŸ‹‹ $,,ŒGyDHŸ’$I–&l»±ÜÜ\|}}™7ožÑ7VEQزe ýû÷U‚íøòKýF>_~Y}›¿ÿTc+‰Q^^κuëX¸p¡Ù;÷þìE‹1räHó‹“$IRéÌ™h¢£Þµš• @ÈG¡ÜÜ\¼½½yñÅ dŠ¢=îU“þùOhÐ@ÿpßï}ðÔàä:É<•••lÚ´‰>úˆ´´4³ûk×®«W¯fÊ”)ª“$Iª™³gc8{ÖøÒrc 0¸*¤* //®]»f´­¢(lݺÕì#SmÖ_üqŠÿý÷áßÿ¶N=õŒ¢(Ñ·o_ÜÜÜ„ þW®\aÛ¶mfí I’dm €DÀ+‡€C‡‰º¼mùÇ?nOõ¿÷,•[ˆÖ†ððpˆ››'NœÞÿ?üÀ«¯¾*C€$Išex0 Á! ??®^5Þ¥!$$$ˆº¼mY¸v¾²v%u^xx8=ö®®®$''[ôZÞÞÞÌž=Ûìs$I’¬¡ê*€$ÀÁ!À××WU åàÁƒ¢.o[ƳvuZ\\£GÆÕÕÕ쯡6mÚ`gg§ªíºuë˜={¶Y›I’$YÃï—&ããs÷*Õ4lß¾ÄÄDQ——ê¸ýû÷3yòd† F”Ú]«Ñ®];¼¼¼ÈÊÊbëÖ­4jÔHÕëÖ¯_/C€$IšqýúuBCCï¸@0Èu±üü|¼½½ÉÎÎVÕ>$$„ˆº¼T=z777† BHHˆY}µiÓ///Μ9ƒ‡‡7fâĉlÚ´Iuذa³fÍ’!@’$›U\\Lxx8Ë—/'!!¡Ú€’Ñß ñõõUvìØÁþýûE]^ª#RSS™;w.?ü0AAAfÍÛ¬Y3<<²700™3gÊ I’M)))!::šåË—wë=ên;ÂB!àÊ•+ªÚïܹ“}ûö‰º¼¤agΜÁÝÝ~ýúáïïoÖÓ÷NNNxxxpöìY¼¼¼îºqÕ„ øé§ŸT‡€   f̘¡™£m%Iª»ÊÊʈ‹‹cùòåÄÄÄüádSŠ>a@QE5mÚ”yóæÑ®];UíÇŒðaÃD]^Ò¬¬,-Z„···ÙŸ¬yå•Wøè£hß¾}^»sçNž}öYJKKUµî¹çX·nööö¦”ZïRTTdí2TIHXJB‚¸å¼rCPÉZÔœ`˜ ÈuÑ¢¢"|}}¹|ù²ªöìÙ³GÔå% ÈÎÎÆÓÓ“^½z±jÕ*³æÏŸÏ©S§X¶lY€ñãdzeË–?Ü&¨Î¦M›xöÙgÿ¸%I’l…ÚÀcàçç§:DFF²{÷nQ——Œ¨¨¨°Ê’ÌÜÜ\<==qvvfÉ’%ª?q߉½½=sæÌ!55••+Wrß}÷™UÛ¸qãjBCCyî¹çd$É&Õä4ÀÃÀpà’¨‹áããÃ… TµŠŠ’!ÀÂE!88˜òøãóÍ7ßÔÊu¯_¿Î’%KèÞ½;K–,¡¸¸Øä¾4hÀôéÓ9vì~~~tëÖMXcÇŽeÇŽ899©jZ£[w¢(ŠEv3”$©~«éqÀ©èÏJJJð÷÷¯Qˆ‰1~‚Tsááá 4ˆ)S¦pøðaEáÝwßeñâÅ»fQQK–,¡K—.xzz’ŸŸor_:ŽI“&‘””D`` ={öXém#FŒ 44TuرcS§N5)„‡‡óøãóàƒâëë[ã×K’$U§¦ô!`pQT%%%pñ¢º.£££e(66–#FàêêJRRÒ~ÿ£>âË»ml‚²²2V­ZE=ðôôTunÄݸ¸¸pðàA‚ƒƒkåtÉádz}ûö…€šÌü~gÃŠŠ ^zé%|||̨Z’$é6SÀqô3ÂB@qq1¾¾¾œ?^UûèèhÂÃÃE]¾ÞÚµkÇ7zkåã?æ_ÿú—Ù×+//gÕªUtíÚwww.]2o2ièСÄÄÄÆÀÍ®¯&žzê)vìØA³fÍTµß¹s'Ï<ó %%%Õ¶¹ÛΆ•••¼ôÒK|ÿý÷fÕ-I’¦ЇW@ÝS|*”––âïïϹsçTµ‹‹“!ÀLãÆcõêÕ4h`üKÁÃÃ/¾øÂ¤ëTVVDŸ>}pwwW}˧:C† !""‚ØØX†nV_æ6lXBÀ®]»îÔîl¨( ¯¿þ:ß}÷YuK’$©;ñ¤zÙ@00P÷hÄÍ›7IIIÁÙÙù®´deeQ^^N÷îÝE\¾^zôÑGéÔ©!!!FwÖ‹ŠŠ¢AƒŒ1BUß•••lܸ‘çž{ŽÿýïfOõ÷ïߟ+Vðõ×_ÓµkW³ú¥sçÎŒ1‚7ªzâ?==ØØX¦M›Fzz:ï¿ÿ>ýë_9vì˜êkîØ±ƒ6mÚðØc™SºÍ(++ÓÌæI.ÄsáB¼°þFŽÖ•$Õˆš€Ôè Dæ­³ª¢Q£FÌž=›N:©j?dÈÆŽ+êòõÒš5kxå•WTí²·páBÜeEQ á³Ï>ãСCf×öàƒ²`Á¦M›†N'êËV¬øøx&L˜@AAªöíÚµ#''Çä] íì숯!@n$IµÏœ[U@ÿL€yóºUܸqΜ9£ªýÞ½{ùùçŸE]¾^úóŸÿL@@ 64ÚváÂ…xzzÞñ÷ÂÃÃÝf€'Ÿ|’ÈÈHZ¶l©ªý•+WLü «êÄà/I’uˆ  £ÊÊÊX»v-§OŸVÕ~ïÞ½ìڵˬbê»3fàïï¯*,Y²[?eäÈ‘¸ººš}¤s—.]X¹r%GŽaîܹØÙ™{·ªv 8°°0Zµje‘þ«®v0`€E®!IRý`ü]¾fN¢‘Àý":4„€™3gªºç»oß>ÊËË™8q¢MZ´e/¼ð:NÕ÷ÿú׿8þ<—.]"""ÂìkwìØ‘>ø€×^{MõQ¼¶Æ\]]¹zõª>‡Ê?ÿùOÕÏ^H’$c‰U¹Ü~0ÐøS|*TVV’’’BÇŽUM¯^¼x‘ÂÂBzöì)C€‰zè!xà¶lÙbtšúÈ‘#ªgiªÓ¦M>ûì36l˜ª[æääDNN0«Ÿ!C†àããâE‹pvvSœ ’JRíy  ªSègÔ-êW¡¼¼œuëÖ‘‘‘¡ª}bb¢ª§Ú¥ê¹¹¹±víZ‹žhתU+,X@zz:ª÷Ù·UUw6\¾|¹É_ýû÷'00øøxÆŒ#¸JI’$ñ·ª2„€H £ˆ !à…^Pµìϰ«Ý¤I“äL€‰ ÞÍœ9Sè'4'''^ýu<==iÑ¢…°~­¥¬¬ ,X`öæFݺu#22’Ö­[ ªNª‹tŸ[»Éš«G,5``êvöQÁNž<©ª}RRÁÁÁr&À =ö#ÍS6mÚ”·Þz‹ôôt¼¼¼4?ø‹ÞÙ ##ƒ±cÇ {~@’$éN,Ò€aÀQÞ¼y“ 6¨>!-99™mÛ¶ÉPCçÎãí·ß¦W¯^„……™Õ—ƒƒóçÏçÔ©S,[¶ŒvíÚ ªÒ:Dïlø{III¸ºº’››+´_I’$ƒÚg‘€yOŠUQQQA`` êpèÐ!~úé'“7]©Orrrðôô¤W¯^,_¾Ü¬óìííí™3gÇgåÊ•Ü{ï½+­}U~777ÒÓÓ-v-$I²¤Ú  £°@8~ü¸ªöGeóæÍ2TãêÕ«,\¸îÝ»³dÉ’»Z£ÖÔ©Sñññ±™m{ͱeËú÷ï›››ê[P¿×®];>üðCÕA(99rrrLºž$Ùœ6À½&|³÷-ýæ(¨ÏVXíÏYÛk­ 3Ñ€¡¢¢‚   ¦OŸÎ<`´ýÑ£GQ…©S§ª:§>(,,äÛo¿ÅËË‹¼¼<¡}oذfÍš±råJÍÿ}7lØ´´4“^ÛªU+Þ|óMÞ{ï=î¹çæÍ›ÇèÑ£UÝ:8tè...„‡‡Ó¦M“®/I6c*¦ tÖ|è±àô¯òk‰@õçv©ã¸U~­ÿœÖxGÎDÔ­çSÁRSSUµ?vì›6mª÷3ÅÅÅ,[¶Œ=zàéé)|ð7ø¿ÿû?æÏŸ¯ù¿ïI“&±iÓ¦mPää䄇‡ééé,\¸ðÖW½{÷&**ŠûïW·_ÖáÇqqq!;;Û¤Ú%I2Aàqà ~;ø‹2ŒßþµÌZÉ2Ñߎ9¢ª}JJJ½ eee¬ZµŠ=zðÎ;ïpù²y':«ùdÿÃ?ðꫯjþï{âĉüôÓO4nÜø®íyë­·HKK«vµC¯^½jFŒ!d¥$YM¢â[ÕUÇÖØ#Êx ei'`ú­kÎÉB€°§¨*++Ù¼y3¿üò‹ªö)))lܸQóƒ’ZåååøùùñÀàîîÎÅ‹ÍêoèСDFFIÓ¦M¶÷ööföìÙTTT˜u]k{úé§« †Õiii,[¶ŒöíÛßµ¯ž={EÇŽê¶ÊHMMeÔ¨QfÿÛI’Õ„AF¾ªî?Z‹õÝLæmý58Œ~Ôe8¿ý3ZµoÊZ$lÙ²EuHMMeýúõš”îÆðäzß¾}™7ožÙÛö>þøãlÛ¶ØØXFň#ؾ};NNNF_»nÝ:Ug غ &°yóæ[!ÀœÕ={ödÏž=ª”<~ü8£F¾ôP’lB`r•ŸïG?øÖ–ñ@ß*?¿x[Q'V7Ô—¬²°P8|XÝWÍ©S§Ø°aC iii¼ùæ›&?ÀfðÈ#̾}û˜>>¬X±ww÷zó@¬dczC«ü|b¸«‰2 öÝxè×—±¼– ¶.¡Ï‚ÂB@HHTÕ6==½Î†€»-=kÛ¶-^^^œªÚß-¨Ýæ¹®ì× i„ú‡þ {k]‚­WŽEµãöê‚2 ÞŠµüÊVX(lß¾]u8{ö,?þø#ee–œ²gggÂÃÃY¼x1§OŸÆÃÃGGQ›[ß6pà@ÂÂÂhÕª 6dΜ9¤¦¦²råJ“J¬O:tè@dd$}ûö5Þý×ìÈ‘#ÉÈÐï±UXXÈ’%KèÞ½;Ÿþ9Æo8z{{Ë ÕŽ?q{­}9ú¥vuï3—ÞhnÏr슭X˯jû,€šºŒþ¯-’ß®Ì4ËöíÛQ…ÇÜh[C˜5kVܳѺw§§Å¯3pà@"""prrR=¥-ÝfcÆŒáØ±cFÛgff2räHæÍ›ÇêÕ«MÚéÑÛÛ›’’üýýkü ˆ$©Võ]Ýý¾ø•è?þ¥¢Ÿ&¯ Ÿ¿îzýúãR`Ÿk©Â–g !Àø;_ ìØ±ƒ}ûÔý+dffÖÙ™€Ú2`À9ø›¡}ûöDDDðàƒªjŸ••Å¢E‹LÞæ¹OŸ>Œ?Ng¼±$‰Ô¸üýiyZWõÓ<ú`´ÀB!`çÎ5 2HVÓ¾}{"##y衇Œ76‘)K?%Éd«|ËF¿ùNU-€¸½iŽuâöòÆbô{ Ø-ýツ>ÙéÎ;Ù³gª¶YYYüæÉiIªMíÚµ#""‚~ýú í×Ü¥Ÿ’d’UU¾}ü ø–ß>ùÕûå^»FWùq6uKCKô!` ‚C@DD»wïVÕ6++ ???JKmdGªwÚµkGxx8]ºt1»/‘K?%Iˆ`#úy_uw¾lOWô§ ‚~gCu+ÑkÖÜêÎýU)22Ru¸pá~~~Õ.¥’$K g„ œ={Öä>,µôS’„PøíÇãÆS}H–$™Åý†9ƒ€GМSõöÀE`‹êª'êr Í$$$Ôh&ÀÇLJ‚‚‘%Hu\Ïž=Ù³gÎÎÎôë×ÀÀ@âãã3fLûrtt$88Xõkóóó?~¼ ’eœD¿ÁÍô[þÞI1¬áIÂԗþ›»€ÇEv:pà@&Mš¤êÌô-Z0oÞÐ?Wú4#²Ó£GªøøøpõêU‘%H’j2kÖ,þýïsæÌ<<„‰ì4==€€ÊÊÊŒ¶•!@’$IMuJÐ?*²Ó³gÏòã?ª 7nÜÀßߟsçΉ,A’$Iª§dPïðú³„1„€7n/àÆ d$I’Ì&@ÍܦaåàççÇ™3gD– I’$Õ32Ôœa& Xd§™™™ªC@yy9k×®•!@’$I2™ ¦)C? <Ô(œ>}Zd ’$IR=!€é !`›ÈN³²²ðõõ¥¤¤ÄhÛòòrÖ­['C€$I’Tc2˜§ ˜ŽàpáÂüýýk222D– I’$Õq ­]@`ÀŸDuzáÂüüü˜;w.Mš4¹k[C˜1cݺuU‚$IuÄ íÉÖ­pâDkÒÒZ‘—טvíŠèС.1eÊ ÆŽMÇÑÑøeµMËõÛríºZ½ZÝælžÙé½÷ÞËœ9sptt4ÚÖÎÎ777zõê%²I²¸ÂÂBŠŠŠ¬]†* KIHX*¬¿ „uõ%%ö,Y2”eËž /¯±Ñö-Z”âáË[oí·‰TËõk¡vIJHèСsçΕ!@ª³d/&Æ™_|†3gZÔøµ;ç³qc ƒ[o÷Q-ׯ•Úí,~…ú¥ø xè#ªÓÂÂBÒÓÓéÛ·/öööwm«( ©©©´oßž6mÚˆ*A’,ª¬¬LÕÙ¶àÂ…x.\ˆÖßȑºº%(èA¦N}žÜ\ãî$?¿1ýéÞý=tEpuÆi¹~-Õ.¯xØ,²ÓK—.±fÍ ¶­¨¨ ((ˆ'Nˆ,A’$ ض­7/¼07Ì{Ä«¤Äž9s¦Ö]Peêh¹~­Õ.€eBÀO";ÍÎÎÆ×ח뛣N IDATׯmkÇY‚$I6,=½óæ=Ke¥˜»»7o6àùç§‘‘ÑRHÆh¹~-Ö.€å”nÀ:‘šRSSE– I’rwŸ¤ê³š¸v­ |0VhŸÕÑrýZ¬]˪ækEvš““£:TVVÄ‘#GD– I’‰‹ëLD„e–oÞÜ‡ØØÎéÛ@Ëõkµv,¯˜‹B€ª ( ›7o–!@’ê°¯¾bÑþW­hÑþµ\¿Vk— vBÀ";ÍÍÍÅÇLJ‚‚£m !à—_~Y‚$I6 ¼ÜÎbŸ@ ‚ƒ{SVf™…cZ®_˵ËP{*€y@€ÈNsssñõõU¶lÙ"C€$Õ1ûöu¤  ‘E¯‘—ט¤¤{-Ò·–ë×rí2Ô® àE,¼½½¹víšÑ¶†pøða‘%H’dEééµó”~ffs‹ô«åúµ\» µÏüEvš——‡¯¯¯ê°uëV:$²I’¬DôÓçÕÉʲLÐrýZ®]ë¨þŒB€OB@BB‚È$I²‚ÒÒÚ9×­aÃJ‹ô«åúµ\» Öc~";ÍÏÏÇÇLJ«W¯ªjÊÁƒE– Iuš¢(Ö.á:v4þ ÷Þk|Õ‘)´\¿–k—Àº*€—_‘æççãëë«:lß¾]†IRáìÙ³6ùm·nÆgýDèÜ9ß"ýj¹~-×.€õY,Ôd&`ûöí8p@d ’Tgœ={–€€‚‚‚lòÔÂ.áäTfÑk´lY A,Ò·–ë×rí2؆Jô!ÀGd§x{{“­ªýŽ;d¤*Ο?O`` AAA\ºtÉÚåTËѱœ)S,{ø×øñi{@Ëõk¹vl‡!üOd§………øúúÖ(ìß¿_d ’¤9/^dóæÍ¬[·ŽÌÌLk—£ÊË/'Y¬oNáí·-û¾ åúµZ» ¶Eþ |/²SC¸rEÝÙÒ;wîdß¾}"K$MÈÉÉ!88˜ü‘ôôtk—S#£GŸfòdË|2å?~Î"}h¹~­Ön™}%smÚƒEuXVVFJJ ={ö¤iÓ¦FÛ§§§cggG—.]D• IÕ*++£¼¼Üj×ÏÍÍ%""‚ˆˆrssïÚÖÎ. ;»,a×9RXW tŸ”•‰[šÖºu1›6Ò²e©°>«£åúµX» ¶k;Ð! ¼¼œ””zôè“““Ñö§OŸ–!@ªÖ ùùùìÙ³‡]»v‘““£ê5¶Z·.á‘G.±aÃCBÎ¥oÐ@aãÆ >/ :ã´\¿k¿{•Šò(ÐÝbWÿ­ƒètgjéZÕS”Ñ@k õþ:]E Úë€ÿ¢¿- LÓ¦M™;w.íÛ·WÕ~Ô¨Q >\d ’ô………µút}AAû÷ïçÈ‘#TVÖìá*‡xâ…Õ²`°®n èÏ+¯LáÆ Ó?::–ãë»™iÓRV¦Ž–ë×RíÆÀwÀ_,ZÁm1èt#kéZÕS”xÀRg;:¢Ó•Ôð5:`ðºÈBš4iœ9s¸ï¾ûTµ9r$#FŒY‚$ÝR[ ¸¸˜„„’’’¸yó¦I}h!^ÿ” ’-¨¨¨àرcÄÇÇSXXhr?999ìÝ»—',»µ«$Ù[ Ÿ£(kÍœ.¯Ëà~;#`¶ÒÒRüüü˜9s&ÎÎÎFÛÇÇÇ£( cÇŽU‚$ÕHee%©©©ìÝ»—¼¼<“ûÉÍÍ%>>^üR½b«à~ôÏ|míBl˜¼Ëí0 DYYk×®UöîÝ‹¢(Œ7NT ’d”¢(œ:uŠ={öpíšéDZ°oß>Ž=Zãý$Iël5|ˆ¢ü:]µ ±a†P xŠêÔf̘A×®]¶ß·o7oÞäé§ŸF§3,IªŽ¢(ddd«ú€«;¹~ý:{÷î•¿T¯Ùrh¼Ègdû}øPT‡UgÔ„€„„Eaâĉ2HqöìYvïÞÍåË—M¸˜ÄÄDMÞ @’ê [ï¡(ߡәþ?¾þø}øHT‡ååå·fºuëf´}bb"Š¢0iÒ$$aΞ=Kll,/^4¹’’’[;ZóÐ!I²%¶œÐªv»Žûø×ï…†€uëÖ©IIús±eÌuáÂbccÉÌÌ4¹ÒÒR’’’HHH ¬¬L`u’¤}¶þ‚¢,G§Ë°v!ñ1ú™€5TË^xáºw7~6TRRŠ¢0yòd¤±_Ô€’T—i!8Ÿ/Z¹-ù}øDT‡†àææF¯^½Œ¶ONN!@RMÄü›7oòË/¿°ÿþZ=]P’´H `Šòt:mœÂa>ýõ{a!àæÍ›lذ777z÷îm´}rr2åååL:U†©Z999„……‘œœŒ¢˜v Hee%G5{# IªO´ g­\‡Ö|Š~&àSc Õª¨¨ 00Pu8zô(Ï>û, ØÒá“’µåçç³gÏ’’’¸qã†Iƒee%Ç'..Žüü| T)Iu—VÀ3(Ê“ètââ®>C>Õ¡!LŸ>xÀhû£G¢( S§N•!@¢  €øøx¨¨¨0¹Ÿ'NkÖF@’TŸi)xí]„öR‚‚‚˜6m}úô1Úþرc2ÔcÅÅÅÄÇdzÿ~³Öàgdd°gϳ6’$I{à)e:Ý.k¢A ÐÏÛX©¢¢‚7Ö((ŠÂsÏ='C@=RRRB\\0k ~ff&111fm$IÒmZ KP”0t:¹gÍ-JÐϤa˜ xöÙgéׯŸÑö)))2Ôeee,Ùihh(€ªžž.C€ÊÈÈ <<ܬ¥xEEEìÝ»—}ûöÉ¿–ݸÑÐОlÝú'N´&-­yyi×®ˆ 0àS¦œ`ìØtmïÙj-×o˵ßý„EùøKí”b² ':Ýy!½)J<0DH_äˆNWb¡¾EyøJt§O?ý4=ö˜ª¶]ºtaæÌ™888ˆ.Cª¡ÌÌL"##9{ö¬É}TÝМ€lÅÈ‘úo¢,¶5ו”سdÉP–-{‚¼¼ÆFÛ·hQЇG,o½µß&R-ׯ…ÚëBøî !=É6:wî̬Y³d°’sçÎÉéÓ§MîãÆKO¯§ô33›[¤_-ׯåÚ­ À@§Ûƒ¢ìÆ êqŠ„N'w’±ŒÕèŸX‰À ‹¢(¸ººmksçÎÅÑÑQT šdXƒmÖ2¼Ë—/³{÷nŽ;&°:R/ ÁÁQBøÓçÕÉʲLÐrýZ®Ýv€žú{"gàà;}IwöèCÀ*†€¸¸8U!àòåˬY³†yóæáää$ªͨ¬¬äÈ‘#DGG“——gr?W®\!&&ÆÿYàKà@üÍc €ÒÒÚy+oØÐ2ÙMËõk¹vÛ :Ýa%x^P Pt:A ”¥;øá×ï…‡EQ;ÖøØœœ|}}ëUP…ÔÔT"""¸zÕôÓ°¯]»Fll,ÉÉÉTV }ƒÉBžÄÿ¹ƒ…uìXP+×¹÷^˼•j¹~-×n[@ïS`*úí}ÍÕxý'Ér~@?°! >>EQ7Îø]¡ú ¿¹kðóóóÙ½{·%þlôÿ2@PKºu»V+×éÜ9ß"ýj¹~-×n{@§;…¢¬æ êñï(ÊÿÐéLÿ˜$©áýë÷BCÀÞ½{;v,:ÝÝWæääàããüyóhÖ¬™¨lFFFaaa\ºtÉä>ªntóæMÕ‘ üXÈ'3kÙ€—pr*£°Ðrgf´lY A—Ú®_˵ÛÒ*€ª>GÜ›Hsàï‚ú’îÎýsB?RîÝ»—ÐÐPUÛÕæææâëë+n[Z‘‘ÁêÕ«ñ÷÷7yð¯ºо}ûDþ×%@÷_¿—ƒ¿8:–3eÊ ‹^cüø4‹= åúµ\»mîð_=¾¢tØŸT½5èOeúÀWBB!!!ªC€æC€aûc“×à—””Ͳeˈ¥¼¼\TyEèü.è—ðZfnXRíå—“,Ö·N§ðöÛêŽò6•–ë×jí¶ô¢¦í£ßmLªë°@HLLT®^½Š···YOÆ[˹sçX·nYkðËÊʈeÙ²eDGG‹a¶:=GÐÿåW·Ga^^±±±·þ,¦0ìCAë‘›4Q£ôÇð>ô´o¯pÿýytìx…Æ;KÑÿñ÷Âÿ·wæñQÙÿ!lQ‰,² ŠKXŸ8²QGx*.£ê<7FÔÇsD3Ž:ê8Žu‘EADAYB "2DFQBÈ a Ôû£:’¾÷öR·»o§¾ŸO4ÜêS§;®s«Îù–"DèrƒnS³&ôê=zÀÅC³fp晘%%ðË/› ÙÙ‘;tÝcÄ×^»‰ñãg3lØ;úŸ\½z%L˜ð ©©9½sÆËþ{Í÷Øã€?¢²ŒÃE/©lÅ.R¶@é܃ÒB°ãÔ{!åZT°5!ªîKù.j]óÇßbºÅµé(€©ü™«[²²¬½»í6ÈñóGЬkæ‡{磻Iëçû¨URrR' à`)é{„úgXø p'0¨…Ú•ÈÊÊ «_JɺuëN Õ¨«W[?áw¿ƒ~¨úï))ðøã0p œ.§,€³}Êó v½ŽÙ!½7hÕ FŽ„¡C¡aCëq]*´V-+SŸ¿ü>û B Äb;îøž .ØÇ-· IC¾M›¦M›I÷îÑ Ž¼ì¿—|ý@ˆ¤|u©ƒk‘òj„ˆ¿dRÖB%;ŽÄúÆÓŽÎ(mÿÑHù?Q¹YË€Ucj§@ã#ßOjÔ8ý ¹2•5þëÖ…§ŸV‹V­ZšÓ.9up÷ÝwÓ Aƒ*cv£öº§£ZSêØÈ; |î{4—’[ׯ'ù“O( 1¿|áÏÈÈ`ïÞ½§.aÿ>&%þó9ç@z:Üzk(nÔFí EÊ)Àc±'CZ¨Sž}V-þ‰Aê‡Õ¨W]¥YYðûßû8=H·n;X·îMÆŽíΫ¯^ξ}Î_ ÉÉÅŒµœ#VR»¶Ö“» ñ²ÿ^ñÝ^YEÊ·€?¸4÷åñu@#UkßlàRMs¯z DÕp_ʨNenP!Üéa+eÔúe³ ÍÀ„(õÍñ%p¥ÅØGbl6S(’’À®yÍ¥—Âwß©ÿo×æÎ…öíó¾=W®¤ÿB•LsÖYgU ×±úVyyÜý7j~v·#IJ0l¼üW\Ë—û%¥Z´ËiÓæÌ / cê Â!°h‘åÞ½ÕCÏF 3éÈ‘Z,ZÔ– Îç›oZ’Ÿ_½{ëÑ ÁQÎ=÷:å3hÐOôí»9ê ¿?¼ì,ûû;B”!åhôµíŽêEþ©&{ÑEÊK€ù€î†ÑÍ‘rÈÉ |f nȧÌç¯kWX°À~k×YAEðàÁƒŒ?ž»îº‹Æ¾Eð‘ëT“תï ÎÐÉ“i€°ÏæÍ›Y²d ;tœU÷ë³g«}4 å1S§a[RR`þ|µ›¡‹äduš Ë–é³e’’ŽsÓMë¹é¦õÑv%$¼ì,ûëU§b.°L£Å—ÒR¶¢ñ/çfàŸšmÎnƒwð[·Vwþ!.þ "ŽŠ>|˜ &ŸŸ²Íp8œ”ÄÄ»îbŸÍkÊËËãƒ>`âĉzÿ /„>Ò½ø—S˜†”7ºa¼ çŸóæé]üË©SG½O-Zè·m0Ä^[G6cAѸ˜¨É^ä‘ò `*ù܉`.°UZ¹uÔh:ö€’N®Ìp¤\ªÃå ”ß)NÁ®ñSb"Ìšv‰~ûöÁO?A~>äçsöÙgÓ䢋ØÛ¸1û6D qÚ@9GŽ9™è´ž\ \‚ÊF­$ûÇQù¥¥,Ý¿ŸÕB°Ë7¯GëÖeêm·qÿ;ïX!'`ûöídee±aƒFa‘ºuaÚ´ãÔ¯o%Xþ*Uá'Ô–þ>Ôg£*7äF”€ Àd¤ì‰Áö>õùjÛ¶%*oÒ?M›þ¯¿¾‡Fª&r””œ`ÆêŸût~‹Zù:b½]V^Š·;3“.‡Ñ(HNæÛ.]XÝ¥ Gmî¸÷6lHFïÞô[´ˆÝ»wóå—_òãÁ®0iR-[¶óseðB|iû|)n@5üñg§œ3)HÙ=È¿«Å¾LœxV€’;Ïü-þ+IL\LçÎÖŸu% >Õ·Âzô²ËÚ!å‚ÊïÍE‘† q€7’+"egà?è;¾x!ÆT°ï$@)ûÖ™JН€!¾Þ ÁØn| t âY&Vž+ ®¦üÃáÑGÕ¿ íÛ·gÈ!Ô¬éçæ¦¤0é†H†£Dì(++cíÚµdffRPà_¬ãðg0wÀÖw°¡L(-å¼ÔT6Ú$ž9â”蟿£ƒÊï²ðêÇŽ¿ Ä3Á:ä›ã À" Ð/¨î¡ûM쵞çjT^Q’ͨÏb`ÅHK# ¢b‘H4üá€r„X‹J ÓÅÓHé­Þ±ª*âu‡QË€~A/þBä×îvÿ…—_†;îp\ü6nÜÈôéÓê|Wcÿ~df²zÏžÇ~ñ//Å{óÍ7™={¶åâpÆáÃÜ:}:=W®´SšÀÆ#st^QñTÐÉB¡Jßwù8R:ÅP:Ø\‰3ƒZü_)ð ØW|@J †èã½@ñ4êèUšlEŠ›»º§íÀo}_Ö¡!ÄAß<ÑÉ’óÇ /À¨QA=%'''   Í–-t[¶Œ™ãÇ[vÞ“R²qãFÞyçf̘¡x¤ßÂ…\¼v­õ€Ûo‡Úµ¶&âåŸ-Dðj‡ÉŠºÀÿ†²¹,ãQ‰bÑ£´TIÙÆ}’M›61uêTJPà+vìØq²oÒ¤Iþx ¨¨ˆÅ‹3îùç9‘žn=°OŸ`M^ÎãØ±@€g´‡€ïÎû-›õ€¤à „Ðs(Ä^”ކ)Zæ1b ïBìl¾MƒæA_ò[¬s öÉ›N¹Á¡¶{õÚ –… áûïÃ6“››Ë´iÓÞÿ}ÆÏÖ­[CšïèÑ£,Y²„×_åË—«y?ûÌú ½N,?ŒAU$ŽBU!Â.To <½žƒS²`¨¼¦ÙÞ,›k"eÄÎg †HáÝ@ñ  çnê ¶c¾6× P¢@ºù%–ÞwÊ7 œÜÜÜ€wBmÔsìØ1233IOO'++‹ãÇ+ì.ÿûßPd‘šÑ©“Êæ·æ8jo<ŠÒr†é¡WkTˆ|ì«Qz eh-­É¾Ðls͵Dà|Íó QÇÛ€PA€.îZk´§¥\h·ýÿ±+š*™0:²É¥¥ÅÌ™Sµ3alÞ¼™)S¦CII _}õééédddP\ìÇí²2°Ê!¨SG©ú1ZøÛ¢ÎÝC;‹€i!>Ï »F] X÷•¥Agü;³û<ÝAŒÁu¼(ÒQYï:¨‰{’º:8ûšåàuÇMÛÖ$$¬æøñA€Ö àçŸfÒ¤I;~¼TZZJvv6cÆŒaÑ¢EYÝá—c'?ܼyÅŸÊP½:¡þpô€à^Y§Ó®SwÍó£BöÚŒ8KûœC”ñ– ?„(FÊç·£íJpjyþA¹5ÿqѶÙ¨f}7³QG5ZÈËËcÊ”) :”Zµ¬rO§¸vmö4iÂÞF8R§y……lÝ·ã­[ÃÖ굧Ѷ­õ5¥m/QRÉ£Qw¦:øÎ…»f…û‘rð+‹šZõĭϹÝ1WðÝ †Çû€â=T-¿µÜZ|`—¤x¥çîߣîH#½kTþš¢ê±?Ec°uëV&OžÌСC©í§ÿpR:t çüóÙÕ¬…õ]^Zµú%ƒkw& n‡ßa8ÉU‹µòRx´¹æ-±0ƒ!â៚ٟ£íFhnsmBhÝ&? !cÿé%ÿ¾@zä”}äåå1yòäÓŽ~iÞœ† á=Æœë¯g}‡î/þ¯½6ý‹?¨&?nbg_÷±š³ dhØ%HÚfg ^$>ÅtàÛh;á2v‰H‘ÈÒ?9*S9èp%ضm&L`¿̺ùfÆ ƺŽ)­ñ?ëΈáh© ö“‘R×® KáÒ`0œ$~u¾ù§h»á2v_¢‘¸;Æ€¿9©è‚à—&Mxó¾ûø¾sgÛÅz·wNöí’W CˆŸ@ˆ@F´Ýp»L5­‹¡ÁuíÓƒUiV&pº|JIeË(mÚT‹¹Äí"§@[Þ†Á`ÐC¼$Vdª/xÜÝÂaF‰/Øz˜#¾Ÿg„l¥Q#˜3Î  Ò«¨H‰ù¬X7ÂŽ°};ìÚ¥®‚ô›l¿Hf"eözn\׿àq2gèCŒ€«ò3ⳃ—]’_$ê”c±úKÔNÀ8ÔÝlÔÙy¼Qì';öï·ûR6 k6)/B©Æ’ Õ«HyCX¤üÁnª‚!B¸yZÎÒ¥n’xÛ¯ú^}ÅǨNÞGˆ(Å;;nÖ å@¤t.H•²RÞ‚*ÛJ­tõðs(®Æ Ù@*¥¥ó)*Zf3®!0'¤ @ÊËQšñîgOGM`:R†v°(å0à#ÄŠìB"7×}…é­[Ýkcáeÿ½ê{õ „Àèh»¡‘{€]cÎCÝͯGÊò¤LAÊfHÙ)» åHùê¼{à¯@~°]«÷Ñep-[þÙa\7 ){lYʆHùwTù[ÃJW„ÔÊsÖæ#åË8Ržƒ”PUvßû€‘!yi™ÂB÷;‚oßî^K /ûïUßã¹€„XŒ”KÝÙБGˆ=¾­Ü œà´ž q¦·PelVÈmG!–!åbÀ®r¢°)3QIm_›|G1åÉ’ÍQ"?~¨Ö#;ÀõAõ0Õ’¸â·HJÓ`8RN>GåÉìFˆã¾PÍQ} ¢tê9Ì#á}!öjFq±û_ç5k–¹fÛËþ{Õ÷êµpŠQxuÁªŒ«Q_ÎnI¯îB§OŸDq¬óêÎ܉«Pb@?ÇòR¡Ê ×£ZÿÄzñŸˆÑêO± ¥càïs6ð°µSp ) Q} rO{q^üÒâ-‚¢eKÿzW:iÚÔ½¦Ž^öß«¾WÏ@-š³¢í†6„X \}e@(| ôEˆ"ßÏI6c­Z߯>B¬EeübŸõb_™¹À° íëEˆiÀ³ŽåÀ1!â©ÜÖS´m[à<(LZµ:àšm/ûïUß«g x 8m'´!D6ªà¿Uæ0ð0ps…ÅìûØ{»ß»³Q‚?nìd¼z/K\°BüUA¢s¬x !Fh´i’^½ÜO-éßß¶t6,¼ì¿W}¯¾€ªOžm7´"D!B܃êÜ7•à³}¨Úîvñ†Ÿm;Å·ÝAÎ{ñ/ úªv·#Äbbñ/GˆWQ-“u$unú „)ù‹2·Þê~ÓÅë®Ó¥‹U/ûïUß2Ѝ¨œ¦—X¸ûþ3ê‹01BóE&ï@ˆ5ÀíHÙ•ÜÖ%ÔŠSwñåg×?ë€ÅÀWáÿ÷"e=ì·…ª¬ØÆJC´B¬öÕîß‹Jœk‚•<Ô]ÿ?Â_·ÀCX¿æÈ¥1Ï÷:F «wŒÆ"„î]“X¿?nþ Ùý^b>Ç¥}û}\yåV²²lº\†Ajj\|¬@ñ²ÿ^õ=øfņꉔW¡jÚýqH² ¼Š”5Q‰W¡‚¨v@ V…Q'P;Q¥…‹€U>á©Húš€}PÝ!ü·’Vªÿ…~JAõ?¨¬ðWˆJt\,–Fü5z´4ÒpÈ»x6ЬŒøöÛftëv_H}èíB²zõ8RRvjµ[/ûïEß«_ !TìÚ\mˆ»Åð½¦%TnÁ¬ÊþjÅq4 žéE•3.ö=J8ªüȧȅ»|ƒ ¤¤ìä¾û²yûí®Z펱Òõżí¿}¯¾9†`ù͵ìˆy q! âbñ·Bé{fñ÷cÆÌ§OŸÍÚì]}õϼòÊ"möœð²ÿ^óÝg¤l‡}KàeòÄ`08˜XÊŒqÅág¦÷í›Ë¬YÓ]ªŒ—ý÷šï&0Â#XVʨ¸ul0¢Nrr1xäÿiNÔ¨!yøáo˜7ïC’“#/ñáeÿ½ä» öHÙn3"!vDʃÁ‰‰¥¤§ÏgåÊ÷èßSÀÏ»æšÍ¬^=Ž1cæGôο2^öß+¾›*ƒ5RÖ¾F•Zq'BLŽG+©0¸F¤«ìX·®1óæµã‹/ÎcëÖdòóëqôh"­[Òºu!½{oaðà#¢j ^ö?V}7€×‘òJ B,qœÝF¨æ0ÝmFmE‰ÅŽÈMuÅ1I,CeÌ€÷é,FÊorR†/j$åà?Ø/þ2‹¿Á`0xÄÝQ Žv"å»HÙ×§ÞR6@ÊÛ2 Õ¸¦…Ã3¾@ˆCw×`0 ÑÄÅ Q]ç†'r=ð-J­®%uz¥h×%Û ¥þh@¸ ÕÓÞ`0 ÅñMMà"ßC»±G£MƒÁ`0Ds`† ÀU±6ÚŽ ƒ!= 1.38 export PANGO_RC_FILE="$bundle_etc/pango/pangorc" export PANGO_SYSCONFDIR="$bundle_etc" export PANGO_LIBDIR="$bundle_lib" export GDK_PIXBUF_MODULE_FILE="$bundle_lib/gdk-pixbuf-2.0/2.10.0/loaders.cache" if [ `uname -r | cut -d . -f 1` -ge 10 ]; then export GTK_IM_MODULE_FILE="$bundle_etc/gtk-3.0/gtk.immodules" fi APP=$name I18NDIR="$bundle_data/locale" # Set the locale-related variables appropriately: unset LANG LC_MESSAGES LC_MONETARY LC_COLLATE # Has a language ordering been set? # If so, set LC_MESSAGES and LANG accordingly; otherwise skip it. # First step uses sed to clean off the quotes and commas, to change - to _, and change the names for the chinese scripts from "Hans" to CN and "Hant" to TW. APPLELANGUAGES=`defaults read .GlobalPreferences AppleLanguages | sed -En -e 's/\-/_/' -e 's/Hant/TW/' -e 's/Hans/CN/' -e 's/[[:space:]]*\"?([[:alnum:]_]+)\"?,?/\1/p' ` if test "$APPLELANGUAGES"; then # A language ordering exists. # Test, item per item, to see whether there is an corresponding locale. for L in $APPLELANGUAGES; do #test for exact matches: if test -f "$I18NDIR/${L}/LC_MESSAGES/$APP.mo"; then export LANG=$L break fi #This is a special case, because often the original strings are in US #English and there is no translation file. if test "x$L" == "xen_US"; then export LANG=$L break fi #OK, now test for just the first two letters: if test -f "$I18NDIR/${L:0:2}/LC_MESSAGES/$APP.mo"; then export LANG=${L:0:2} break fi #Same thing, but checking for any english variant. if test "x${L:0:2}" == "xen"; then export LANG=$L break fi; done fi unset APPLELANGUAGES L # If we didn't get a language from the language list, try the Collation preference, in case it's the only setting that exists. APPLECOLLATION=`defaults read .GlobalPreferences AppleCollationOrder` if test -z ${LANG} -a -n "$APPLECOLLATION"; then if test -f "$I18NDIR/${APPLECOLLATION:0:2}/LC_MESSAGES/$APP.mo"; then export LANG=${APPLECOLLATION:0:2} fi fi if test ! -z "$APPLECOLLATION"; then export LC_COLLATE="$APPLECOLLATION" fi unset APPLECOLLATION # Continue by attempting to find the Locale preference. APPLELOCALE=`defaults read .GlobalPreferences AppleLocale` if test -f "$I18NDIR/${APPLELOCALE:0:5}/LC_MESSAGES/$APP.mo"; then if test -z $LANG; then export LANG="${APPLELOCALE:0:5}" fi elif test -z $LANG -a -f "$I18NDIR/${APPLELOCALE:0:2}/LC_MESSAGES/$APP.mo"; then export LANG="${APPLELOCALE:0:2}" fi #Next we need to set LC_MESSAGES. If at all possilbe, we want a full #5-character locale to avoid the "Locale not supported by C library" #warning from Gtk -- even though Gtk will translate with a #two-character code. if test -n $LANG; then #If the language code matches the applelocale, then that's the message #locale; otherwise, if it's longer than two characters, then it's #probably a good message locale and we'll go with it. if test $LANG == ${APPLELOCALE:0:5} -o $LANG != ${LANG:0:2}; then export LC_MESSAGES=$LANG #Next try if the Applelocale is longer than 2 chars and the language #bit matches $LANG elif test $LANG == ${APPLELOCALE:0:2} -a $APPLELOCALE > ${APPLELOCALE:0:2}; then export LC_MESSAGES=${APPLELOCALE:0:5} #Fail. Get a list of the locales in $PREFIX/share/locale that match #our two letter language code and pick the first one, special casing #english to set en_US elif test $LANG == "en"; then export LC_MESSAGES="en_US" else LOC=`find $PREFIX/share/locale -name $LANG???` for L in $LOC; do export LC_MESSAGES=$L done fi else #All efforts have failed, so default to US english export LANG="en_US" export LC_MESSAGES="en_US" fi CURRENCY=`echo $APPLELOCALE | sed -En 's/.*currency=([[:alpha:]]+).*/\1/p'` if test "x$CURRENCY" != "x"; then #The user has set a special currency. Gtk doesn't install LC_MONETARY files, but Apple does in /usr/share/locale, so we're going to look there for a locale to set LC_CURRENCY to. if test -f /usr/local/share/$LC_MESSAGES/LC_MONETARY; then if test -a `cat /usr/local/share/$LC_MESSAGES/LC_MONETARY` == $CURRENCY; then export LC_MONETARY=$LC_MESSAGES fi fi if test -z "$LC_MONETARY"; then FILES=`find /usr/share/locale -name LC_MONETARY -exec grep -H $CURRENCY {} \;` if test -n "$FILES"; then export LC_MONETARY=`echo $FILES | sed -En 's%/usr/share/locale/([[:alpha:]_]+)/LC_MONETARY.*%\1%p'` fi fi fi #No currency value means that the AppleLocale governs: if test -z "$LC_MONETARY"; then LC_MONETARY=${APPLELOCALE:0:5} fi #For Gtk, which only looks at LC_ALL: export LC_ALL=$LC_MESSAGES unset APPLELOCALE FILES LOC if test -f "$bundle_lib/charset.alias"; then export CHARSETALIASDIR="$bundle_lib" fi # Extra arguments can be added in environment.sh. EXTRA_ARGS= if test -f "$bundle_res/environment.sh"; then source "$bundle_res/environment.sh" fi # Strip out the argument added by the OS. if /bin/expr "x$1" : '^x-psn_' > /dev/null; then shift 1 fi if [ `pwd` = "/" ] then cd "$HOME" fi $EXEC "$bundle_contents/MacOS/$name-bin" "$@" $EXTRA_ARGS ngraph-gtk-6.08.00/osx/ngraph-gtk.bundle0000644000175000017500000001267613237035064014735 00000000000000 ${env:JHBUILD_PREFIX} ${env:HOME}/Desktop ${project}/ngraph-launcher.sh gtk+-3.0 ${project}/Info-ngraph-gtk.plist ${prefix}/bin/ngraph ${prefix}/lib/${gtkdir}/${pkg:${gtk}:gtk_binary_version}/immodules/*.so ${prefix}/lib/${gtkdir}/${pkg:${gtk}:gtk_binary_version}/printbackends/*.so ${prefix}/lib/gdk-pixbuf-2.0/${pkg:gdk-pixbuf-2.0:gdk_pixbuf_binary_version}/loaders/*.so ${prefix}/lib/ngraph-gtk/plugins ${prefix}/libexec/ngraph-gtk/fft ${prefix}/libexec/ngraph-gtk/legend ${prefix}/libexec/ngraph-gtk/gimg2gra ${prefix}/libexec/ngraph-gtk/terminal ${prefix}/libexec/ngraph-gtk/fitrslt ${project}/ngraph-launcher.sh ${project}/ngraph-launcher.sh ${project}/ngraph-launcher.sh ${prefix}/lib/ngraph-gtk/ruby ${prefix}/share/ngraph-gtk ${prefix}/etc/ngraph-gtk ${prefix}/share/doc/ngraph-gtk ${prefix}/share/locale ${prefix}/share/locale ${prefix}/share/themes ${prefix}/share/icons ${prefix}/share/glib-2.0 ${prefix}/share/gtksourceview-3.0 ${project}/ngraph.icns ngraph-gtk-6.08.00/osx/Makefile.am0000644000175000017500000000145313070106167013521 00000000000000ICONSET = ngraph.iconset/icon_128x128.png \ ngraph.iconset/icon_128x128@2x.png \ ngraph.iconset/icon_16x16.png \ ngraph.iconset/icon_16x16@2x.png \ ngraph.iconset/icon_256x256.png \ ngraph.iconset/icon_256x256@2x.png \ ngraph.iconset/icon_32x32.png \ ngraph.iconset/icon_32x32@2x.png \ ngraph.iconset/icon_512x512.png \ ngraph.iconset/icon_512x512@2x.png EXTRA_DIST = Info-ngraph-gtk.plist.in ngraph-gtk.bundle ngraph-launcher.sh $(ICONSET) if OS_OSX ngraph.icns: $(ICONSET) iconutil -c icns ngraph.iconset Info-ngraph-gtk.plist: Info-ngraph-gtk.plist.in Makefile $(SED) -e "s/%VERSION%/$(VERSION)/" $< > $@ app_data = ngraph.icns Info-ngraph-gtk.plist BUILT_SOURCES = $(app_data) CLEANFILES = $(app_data) endif ngraph-gtk-6.08.00/osx/Makefile.in0000644000175000017500000003457613367273153013557 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = osx ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ ICONSET = ngraph.iconset/icon_128x128.png \ ngraph.iconset/icon_128x128@2x.png \ ngraph.iconset/icon_16x16.png \ ngraph.iconset/icon_16x16@2x.png \ ngraph.iconset/icon_256x256.png \ ngraph.iconset/icon_256x256@2x.png \ ngraph.iconset/icon_32x32.png \ ngraph.iconset/icon_32x32@2x.png \ ngraph.iconset/icon_512x512.png \ ngraph.iconset/icon_512x512@2x.png EXTRA_DIST = Info-ngraph-gtk.plist.in ngraph-gtk.bundle ngraph-launcher.sh $(ICONSET) @OS_OSX_TRUE@app_data = ngraph.icns Info-ngraph-gtk.plist @OS_OSX_TRUE@BUILT_SOURCES = $(app_data) @OS_OSX_TRUE@CLEANFILES = $(app_data) all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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) --gnu osx/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu osx/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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 tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-am all-am: Makefile installdirs: install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) 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-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: .MAKE: all check install 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-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 .PRECIOUS: Makefile @OS_OSX_TRUE@ngraph.icns: $(ICONSET) @OS_OSX_TRUE@ iconutil -c icns ngraph.iconset @OS_OSX_TRUE@Info-ngraph-gtk.plist: Info-ngraph-gtk.plist.in Makefile @OS_OSX_TRUE@ $(SED) -e "s/%VERSION%/$(VERSION)/" $< > $@ # 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: ngraph-gtk-6.08.00/pathconv.sh0000644000175000017500000000101113070106167013020 00000000000000#! /bin/sh if [ $# -ne 7 ] then echo "error: wrong number of arguments ($0)." exit fi BINDIR=$1 shift DOCDIR=$1 shift LIBEXECDIR=$1 shift LIBDIR=$1 shift DATADIR=$1 shift CONFDIR=$1 shift TARGET=`basename $1 .in` LC_ALL=C export LC_ALL cat $1 | sed -e "s!BINDIRDEF!$BINDIR!g" \ -e "s!DOCDIRDEF!$DOCDIR!g" \ -e "s!LIBEXECDIRDEF!$LIBEXECDIR!g" \ -e "s!LIBDIRDEF!$LIBDIR!g" \ -e "s!DATADIRDEF!$DATADIR!g" \ -e "s!CONFDIRDEF!$CONFDIR!g" > $TARGET ngraph-gtk-6.08.00/m4/0000755000175000017500000000000013375640226011260 500000000000000ngraph-gtk-6.08.00/m4/lock.m40000644000175000017500000000266713070106167012376 00000000000000# lock.m4 serial 13 (gettext-0.18.2) dnl Copyright (C) 2005-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([gl_LOCK], [ AC_REQUIRE([gl_THREADLIB]) if test "$gl_threads_api" = posix; then # OSF/1 4.0 and Mac OS X 10.1 lack the pthread_rwlock_t type and the # pthread_rwlock_* functions. AC_CHECK_TYPE([pthread_rwlock_t], [AC_DEFINE([HAVE_PTHREAD_RWLOCK], [1], [Define if the POSIX multithreading library has read/write locks.])], [], [#include ]) # glibc defines PTHREAD_MUTEX_RECURSIVE as enum, not as a macro. AC_COMPILE_IFELSE([ AC_LANG_PROGRAM( [[#include ]], [[ #if __FreeBSD__ == 4 error "No, in FreeBSD 4.0 recursive mutexes actually don't work." #elif (defined __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ \ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1070) error "No, in Mac OS X < 10.7 recursive mutexes actually don't work." #else int x = (int)PTHREAD_MUTEX_RECURSIVE; return !x; #endif ]])], [AC_DEFINE([HAVE_PTHREAD_MUTEX_RECURSIVE], [1], [Define if the defines PTHREAD_MUTEX_RECURSIVE.])]) fi gl_PREREQ_LOCK ]) # Prerequisites of lib/glthread/lock.c. AC_DEFUN([gl_PREREQ_LOCK], [:]) ngraph-gtk-6.08.00/m4/gettext.m40000644000175000017500000003676313070106167013136 00000000000000# gettext.m4 serial 68 (gettext-0.19.8) dnl Copyright (C) 1995-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2006, 2008-2010. dnl Macro to add for using GNU gettext. dnl Usage: AM_GNU_GETTEXT([INTLSYMBOL], [NEEDSYMBOL], [INTLDIR]). dnl INTLSYMBOL can be one of 'external', 'no-libtool', 'use-libtool'. The dnl default (if it is not specified or empty) is 'no-libtool'. dnl INTLSYMBOL should be 'external' for packages with no intl directory, dnl and 'no-libtool' or 'use-libtool' for packages with an intl directory. dnl If INTLSYMBOL is 'use-libtool', then a libtool library dnl $(top_builddir)/intl/libintl.la will be created (shared and/or static, dnl depending on --{enable,disable}-{shared,static} and on the presence of dnl AM-DISABLE-SHARED). If INTLSYMBOL is 'no-libtool', a static library dnl $(top_builddir)/intl/libintl.a will be created. dnl If NEEDSYMBOL is specified and is 'need-ngettext', then GNU gettext dnl implementations (in libc or libintl) without the ngettext() function dnl will be ignored. If NEEDSYMBOL is specified and is dnl 'need-formatstring-macros', then GNU gettext implementations that don't dnl support the ISO C 99 formatstring macros will be ignored. dnl INTLDIR is used to find the intl libraries. If empty, dnl the value '$(top_builddir)/intl/' is used. dnl dnl The result of the configuration is one of three cases: dnl 1) GNU gettext, as included in the intl subdirectory, will be compiled dnl and used. dnl Catalog format: GNU --> install in $(datadir) dnl Catalog extension: .mo after installation, .gmo in source tree dnl 2) GNU gettext has been found in the system's C library. dnl Catalog format: GNU --> install in $(datadir) dnl Catalog extension: .mo after installation, .gmo in source tree dnl 3) No internationalization, always use English msgid. dnl Catalog format: none dnl Catalog extension: none dnl If INTLSYMBOL is 'external', only cases 2 and 3 can occur. dnl The use of .gmo is historical (it was needed to avoid overwriting the dnl GNU format catalogs when building on a platform with an X/Open gettext), dnl but we keep it in order not to force irrelevant filename changes on the dnl maintainers. dnl AC_DEFUN([AM_GNU_GETTEXT], [ dnl Argument checking. ifelse([$1], [], , [ifelse([$1], [external], , [ifelse([$1], [no-libtool], , [ifelse([$1], [use-libtool], , [errprint([ERROR: invalid first argument to AM_GNU_GETTEXT ])])])])]) ifelse(ifelse([$1], [], [old])[]ifelse([$1], [no-libtool], [old]), [old], [AC_DIAGNOSE([obsolete], [Use of AM_GNU_GETTEXT without [external] argument is deprecated.])]) ifelse([$2], [], , [ifelse([$2], [need-ngettext], , [ifelse([$2], [need-formatstring-macros], , [errprint([ERROR: invalid second argument to AM_GNU_GETTEXT ])])])]) define([gt_included_intl], ifelse([$1], [external], ifdef([AM_GNU_GETTEXT_][INTL_SUBDIR], [yes], [no]), [yes])) define([gt_libtool_suffix_prefix], ifelse([$1], [use-libtool], [l], [])) gt_NEEDS_INIT AM_GNU_GETTEXT_NEED([$2]) AC_REQUIRE([AM_PO_SUBDIRS])dnl ifelse(gt_included_intl, yes, [ AC_REQUIRE([AM_INTL_SUBDIR])dnl ]) dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) dnl Sometimes libintl requires libiconv, so first search for libiconv. dnl Ideally we would do this search only after the dnl if test "$USE_NLS" = "yes"; then dnl if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then dnl tests. But if configure.in invokes AM_ICONV after AM_GNU_GETTEXT dnl the configure script would need to contain the same shell code dnl again, outside any 'if'. There are two solutions: dnl - Invoke AM_ICONV_LINKFLAGS_BODY here, outside any 'if'. dnl - Control the expansions in more detail using AC_PROVIDE_IFELSE. dnl Since AC_PROVIDE_IFELSE is only in autoconf >= 2.52 and not dnl documented, we avoid it. ifelse(gt_included_intl, yes, , [ AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) ]) dnl Sometimes, on Mac OS X, libintl requires linking with CoreFoundation. gt_INTL_MACOSX dnl Set USE_NLS. AC_REQUIRE([AM_NLS]) ifelse(gt_included_intl, yes, [ BUILD_INCLUDED_LIBINTL=no USE_INCLUDED_LIBINTL=no ]) LIBINTL= LTLIBINTL= POSUB= dnl Add a version number to the cache macros. case " $gt_needs " in *" need-formatstring-macros "*) gt_api_version=3 ;; *" need-ngettext "*) gt_api_version=2 ;; *) gt_api_version=1 ;; esac gt_func_gnugettext_libc="gt_cv_func_gnugettext${gt_api_version}_libc" gt_func_gnugettext_libintl="gt_cv_func_gnugettext${gt_api_version}_libintl" dnl If we use NLS figure out what method if test "$USE_NLS" = "yes"; then gt_use_preinstalled_gnugettext=no ifelse(gt_included_intl, yes, [ AC_MSG_CHECKING([whether included gettext is requested]) AC_ARG_WITH([included-gettext], [ --with-included-gettext use the GNU gettext library included here], nls_cv_force_use_gnu_gettext=$withval, nls_cv_force_use_gnu_gettext=no) AC_MSG_RESULT([$nls_cv_force_use_gnu_gettext]) nls_cv_use_gnu_gettext="$nls_cv_force_use_gnu_gettext" if test "$nls_cv_force_use_gnu_gettext" != "yes"; then ]) dnl User does not insist on using GNU NLS library. Figure out what dnl to use. If GNU gettext is available we use this. Else we have dnl to fall back to GNU NLS library. if test $gt_api_version -ge 3; then gt_revision_test_code=' #ifndef __GNU_GETTEXT_SUPPORTED_REVISION #define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) #endif changequote(,)dnl typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; changequote([,])dnl ' else gt_revision_test_code= fi if test $gt_api_version -ge 2; then gt_expression_test_code=' + * ngettext ("", "", 0)' else gt_expression_test_code= fi AC_CACHE_CHECK([for GNU gettext in libc], [$gt_func_gnugettext_libc], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern int *_nl_domain_bindings; #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_domain_bindings) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [eval "$gt_func_gnugettext_libc=yes"], [eval "$gt_func_gnugettext_libc=no"])]) if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then dnl Sometimes libintl requires libiconv, so first search for libiconv. ifelse(gt_included_intl, yes, , [ AM_ICONV_LINK ]) dnl Search for libintl and define LIBINTL, LTLIBINTL and INCINTL dnl accordingly. Don't use AC_LIB_LINKFLAGS_BODY([intl],[iconv]) dnl because that would add "-liconv" to LIBINTL and LTLIBINTL dnl even if libiconv doesn't exist. AC_LIB_LINKFLAGS_BODY([intl]) AC_CACHE_CHECK([for GNU gettext in libintl], [$gt_func_gnugettext_libintl], [gt_save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $INCINTL" gt_save_LIBS="$LIBS" LIBS="$LIBS $LIBINTL" dnl Now see whether libintl exists and does not depend on libiconv. AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [eval "$gt_func_gnugettext_libintl=yes"], [eval "$gt_func_gnugettext_libintl=no"]) dnl Now see whether libintl exists and depends on libiconv. if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" != yes; } && test -n "$LIBICONV"; then LIBS="$LIBS $LIBICONV" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [LIBINTL="$LIBINTL $LIBICONV" LTLIBINTL="$LTLIBINTL $LTLIBICONV" eval "$gt_func_gnugettext_libintl=yes" ]) fi CPPFLAGS="$gt_save_CPPFLAGS" LIBS="$gt_save_LIBS"]) fi dnl If an already present or preinstalled GNU gettext() is found, dnl use it. But if this macro is used in GNU gettext, and GNU dnl gettext is already preinstalled in libintl, we update this dnl libintl. (Cf. the install rule in intl/Makefile.in.) if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" = "yes"; } \ || { { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; } \ && test "$PACKAGE" != gettext-runtime \ && test "$PACKAGE" != gettext-tools; }; then gt_use_preinstalled_gnugettext=yes else dnl Reset the values set by searching for libintl. LIBINTL= LTLIBINTL= INCINTL= fi ifelse(gt_included_intl, yes, [ if test "$gt_use_preinstalled_gnugettext" != "yes"; then dnl GNU gettext is not found in the C library. dnl Fall back on included GNU gettext library. nls_cv_use_gnu_gettext=yes fi fi if test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Mark actions used to generate GNU NLS library. BUILD_INCLUDED_LIBINTL=yes USE_INCLUDED_LIBINTL=yes LIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LIBICONV $LIBTHREAD" LTLIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LTLIBICONV $LTLIBTHREAD" LIBS=`echo " $LIBS " | sed -e 's/ -lintl / /' -e 's/^ //' -e 's/ $//'` fi CATOBJEXT= if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Mark actions to use GNU gettext tools. CATOBJEXT=.gmo fi ]) if test -n "$INTL_MACOSX_LIBS"; then if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Some extra flags are needed during linking. LIBINTL="$LIBINTL $INTL_MACOSX_LIBS" LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS" fi fi if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then AC_DEFINE([ENABLE_NLS], [1], [Define to 1 if translation of program messages to the user's native language is requested.]) else USE_NLS=no fi fi AC_MSG_CHECKING([whether to use NLS]) AC_MSG_RESULT([$USE_NLS]) if test "$USE_NLS" = "yes"; then AC_MSG_CHECKING([where the gettext function comes from]) if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then gt_source="external libintl" else gt_source="libc" fi else gt_source="included intl directory" fi AC_MSG_RESULT([$gt_source]) fi if test "$USE_NLS" = "yes"; then if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then AC_MSG_CHECKING([how to link with libintl]) AC_MSG_RESULT([$LIBINTL]) AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCINTL]) fi dnl For backward compatibility. Some packages may be using this. AC_DEFINE([HAVE_GETTEXT], [1], [Define if the GNU gettext() function is already present or preinstalled.]) AC_DEFINE([HAVE_DCGETTEXT], [1], [Define if the GNU dcgettext() function is already present or preinstalled.]) fi dnl We need to process the po/ directory. POSUB=po fi ifelse(gt_included_intl, yes, [ dnl If this is used in GNU gettext we have to set BUILD_INCLUDED_LIBINTL dnl to 'yes' because some of the testsuite requires it. if test "$PACKAGE" = gettext-runtime || test "$PACKAGE" = gettext-tools; then BUILD_INCLUDED_LIBINTL=yes fi dnl Make all variables we use known to autoconf. AC_SUBST([BUILD_INCLUDED_LIBINTL]) AC_SUBST([USE_INCLUDED_LIBINTL]) AC_SUBST([CATOBJEXT]) dnl For backward compatibility. Some configure.ins may be using this. nls_cv_header_intl= nls_cv_header_libgt= dnl For backward compatibility. Some Makefiles may be using this. DATADIRNAME=share AC_SUBST([DATADIRNAME]) dnl For backward compatibility. Some Makefiles may be using this. INSTOBJEXT=.mo AC_SUBST([INSTOBJEXT]) dnl For backward compatibility. Some Makefiles may be using this. GENCAT=gencat AC_SUBST([GENCAT]) dnl For backward compatibility. Some Makefiles may be using this. INTLOBJS= if test "$USE_INCLUDED_LIBINTL" = yes; then INTLOBJS="\$(GETTOBJS)" fi AC_SUBST([INTLOBJS]) dnl Enable libtool support if the surrounding package wishes it. INTL_LIBTOOL_SUFFIX_PREFIX=gt_libtool_suffix_prefix AC_SUBST([INTL_LIBTOOL_SUFFIX_PREFIX]) ]) dnl For backward compatibility. Some Makefiles may be using this. INTLLIBS="$LIBINTL" AC_SUBST([INTLLIBS]) dnl Make all documented variables known to autoconf. AC_SUBST([LIBINTL]) AC_SUBST([LTLIBINTL]) AC_SUBST([POSUB]) ]) dnl gt_NEEDS_INIT ensures that the gt_needs variable is initialized. m4_define([gt_NEEDS_INIT], [ m4_divert_text([DEFAULTS], [gt_needs=]) m4_define([gt_NEEDS_INIT], []) ]) dnl Usage: AM_GNU_GETTEXT_NEED([NEEDSYMBOL]) AC_DEFUN([AM_GNU_GETTEXT_NEED], [ m4_divert_text([INIT_PREPARE], [gt_needs="$gt_needs $1"]) ]) dnl Usage: AM_GNU_GETTEXT_VERSION([gettext-version]) AC_DEFUN([AM_GNU_GETTEXT_VERSION], []) dnl Usage: AM_GNU_GETTEXT_REQUIRE_VERSION([gettext-version]) AC_DEFUN([AM_GNU_GETTEXT_REQUIRE_VERSION], []) ngraph-gtk-6.08.00/m4/lib-ld.m40000644000175000017500000000714313070106167012603 00000000000000# lib-ld.m4 serial 6 dnl Copyright (C) 1996-2003, 2009-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl Subroutines of libtool.m4, dnl with replacements s/_*LT_PATH/AC_LIB_PROG/ and s/lt_/acl_/ to avoid dnl collision with libtool.m4. dnl From libtool-2.4. Sets the variable with_gnu_ld to yes or no. AC_DEFUN([AC_LIB_PROG_LD_GNU], [AC_CACHE_CHECK([if the linker ($LD) is GNU ld], [acl_cv_prog_gnu_ld], [# I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 /dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi ac_prog=ld if test "$GCC" = yes; 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 "$with_gnu_ld" = yes; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL([acl_cv_path_LD], [if test -z "$LD"; then acl_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$acl_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then acl_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 `"$acl_cv_path_LD" -v 2>&1 . ]) # 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 # 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' ;; netbsdelf*-gnu) version_type=linux 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='NetBSD ld.elf_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* | netbsdelf*-gnu) 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* | netbsdelf*-gnu) ;; *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 ;; linux* | k*bsd*-gnu | gnu*) _LT_TAGVAR(link_all_deplibs, $1)=no ;; *) _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 ;; linux* | k*bsd*-gnu | gnu*) _LT_TAGVAR(link_all_deplibs, $1)=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* | netbsdelf*-gnu) 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 _LT_TAGVAR(link_all_deplibs, $1)=no 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* | netbsdelf*-gnu) 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 ngraph-gtk-6.08.00/m4/intl.m40000644000175000017500000002753013070106167012410 00000000000000# intl.m4 serial 29 (gettext-0.19) dnl Copyright (C) 1995-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2009. AC_PREREQ([2.60]) dnl Checks for all prerequisites of the intl subdirectory, dnl except for INTL_LIBTOOL_SUFFIX_PREFIX (and possibly LIBTOOL), INTLOBJS, dnl USE_INCLUDED_LIBINTL, BUILD_INCLUDED_LIBINTL. AC_DEFUN([AM_INTL_SUBDIR], [ AC_REQUIRE([AC_PROG_INSTALL])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([gt_GLIBC2])dnl AC_REQUIRE([AC_PROG_RANLIB])dnl AC_REQUIRE([gl_VISIBILITY])dnl AC_REQUIRE([gt_INTL_SUBDIR_CORE])dnl AC_REQUIRE([AC_TYPE_LONG_LONG_INT])dnl AC_REQUIRE([gt_TYPE_WCHAR_T])dnl AC_REQUIRE([gt_TYPE_WINT_T])dnl AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) AC_REQUIRE([gt_TYPE_INTMAX_T]) AC_REQUIRE([gt_PRINTF_POSIX]) AC_REQUIRE([gl_GLIBC21])dnl AC_REQUIRE([gl_XSIZE])dnl AC_REQUIRE([gl_FCNTL_O_FLAGS])dnl AC_REQUIRE([gt_INTL_MACOSX])dnl AC_REQUIRE([gl_EXTERN_INLINE])dnl AC_REQUIRE([gt_GL_ATTRIBUTE])dnl dnl Support for automake's --enable-silent-rules. case "$enable_silent_rules" in yes) INTL_DEFAULT_VERBOSITY=0;; no) INTL_DEFAULT_VERBOSITY=1;; *) INTL_DEFAULT_VERBOSITY=1;; esac AC_SUBST([INTL_DEFAULT_VERBOSITY]) AC_CHECK_TYPE([ptrdiff_t], , [AC_DEFINE([ptrdiff_t], [long], [Define as the type of the result of subtracting two pointers, if the system doesn't define it.]) ]) AC_CHECK_HEADERS([features.h stddef.h stdlib.h string.h]) AC_CHECK_FUNCS([asprintf fwprintf newlocale putenv setenv setlocale \ snprintf strnlen wcslen wcsnlen mbrtowc wcrtomb]) dnl Use the _snprintf function only if it is declared (because on NetBSD it dnl is defined as a weak alias of snprintf; we prefer to use the latter). AC_CHECK_DECLS([_snprintf, _snwprintf], , , [#include ]) dnl Use the *_unlocked functions only if they are declared. dnl (because some of them were defined without being declared in Solaris dnl 2.5.1 but were removed in Solaris 2.6, whereas we want binaries built dnl on Solaris 2.5.1 to run on Solaris 2.6). AC_CHECK_DECLS([getc_unlocked], , , [#include ]) case $gt_cv_func_printf_posix in *yes) HAVE_POSIX_PRINTF=1 ;; *) HAVE_POSIX_PRINTF=0 ;; esac AC_SUBST([HAVE_POSIX_PRINTF]) if test "$ac_cv_func_asprintf" = yes; then HAVE_ASPRINTF=1 else HAVE_ASPRINTF=0 fi AC_SUBST([HAVE_ASPRINTF]) if test "$ac_cv_func_snprintf" = yes; then HAVE_SNPRINTF=1 else HAVE_SNPRINTF=0 fi AC_SUBST([HAVE_SNPRINTF]) if test "$ac_cv_func_newlocale" = yes; then HAVE_NEWLOCALE=1 else HAVE_NEWLOCALE=0 fi AC_SUBST([HAVE_NEWLOCALE]) if test "$ac_cv_func_wprintf" = yes; then HAVE_WPRINTF=1 else HAVE_WPRINTF=0 fi AC_SUBST([HAVE_WPRINTF]) AM_LANGINFO_CODESET gt_LC_MESSAGES dnl Compilation on mingw and Cygwin needs special Makefile rules, because dnl 1. when we install a shared library, we must arrange to export dnl auxiliary pointer variables for every exported variable, dnl 2. when we install a shared library and a static library simultaneously, dnl the include file specifies __declspec(dllimport) and therefore we dnl must arrange to define the auxiliary pointer variables for the dnl exported variables _also_ in the static library. if test "$enable_shared" = yes; then case "$host_os" in mingw* | cygwin*) is_woe32dll=yes ;; *) is_woe32dll=no ;; esac else is_woe32dll=no fi WOE32DLL=$is_woe32dll AC_SUBST([WOE32DLL]) dnl On mingw and Cygwin, we can activate special Makefile rules which add dnl version information to the shared libraries and executables. case "$host_os" in mingw* | cygwin*) is_woe32=yes ;; *) is_woe32=no ;; esac WOE32=$is_woe32 AC_SUBST([WOE32]) if test $WOE32 = yes; then dnl Check for a program that compiles Windows resource files. AC_CHECK_TOOL([WINDRES], [windres]) fi dnl Determine whether when creating a library, "-lc" should be passed to dnl libtool or not. On many platforms, it is required for the libtool option dnl -no-undefined to work. On HP-UX, however, the -lc - stored by libtool dnl in the *.la files - makes it impossible to create multithreaded programs, dnl because libtool also reorders the -lc to come before the -pthread, and dnl this disables pthread_create() . case "$host_os" in hpux*) LTLIBC="" ;; *) LTLIBC="-lc" ;; esac AC_SUBST([LTLIBC]) dnl Rename some macros and functions used for locking. AH_BOTTOM([ #define __libc_lock_t gl_lock_t #define __libc_lock_define gl_lock_define #define __libc_lock_define_initialized gl_lock_define_initialized #define __libc_lock_init gl_lock_init #define __libc_lock_lock gl_lock_lock #define __libc_lock_unlock gl_lock_unlock #define __libc_lock_recursive_t gl_recursive_lock_t #define __libc_lock_define_recursive gl_recursive_lock_define #define __libc_lock_define_initialized_recursive gl_recursive_lock_define_initialized #define __libc_lock_init_recursive gl_recursive_lock_init #define __libc_lock_lock_recursive gl_recursive_lock_lock #define __libc_lock_unlock_recursive gl_recursive_lock_unlock #define glthread_in_use libintl_thread_in_use #define glthread_lock_init_func libintl_lock_init_func #define glthread_lock_lock_func libintl_lock_lock_func #define glthread_lock_unlock_func libintl_lock_unlock_func #define glthread_lock_destroy_func libintl_lock_destroy_func #define glthread_rwlock_init_multithreaded libintl_rwlock_init_multithreaded #define glthread_rwlock_init_func libintl_rwlock_init_func #define glthread_rwlock_rdlock_multithreaded libintl_rwlock_rdlock_multithreaded #define glthread_rwlock_rdlock_func libintl_rwlock_rdlock_func #define glthread_rwlock_wrlock_multithreaded libintl_rwlock_wrlock_multithreaded #define glthread_rwlock_wrlock_func libintl_rwlock_wrlock_func #define glthread_rwlock_unlock_multithreaded libintl_rwlock_unlock_multithreaded #define glthread_rwlock_unlock_func libintl_rwlock_unlock_func #define glthread_rwlock_destroy_multithreaded libintl_rwlock_destroy_multithreaded #define glthread_rwlock_destroy_func libintl_rwlock_destroy_func #define glthread_recursive_lock_init_multithreaded libintl_recursive_lock_init_multithreaded #define glthread_recursive_lock_init_func libintl_recursive_lock_init_func #define glthread_recursive_lock_lock_multithreaded libintl_recursive_lock_lock_multithreaded #define glthread_recursive_lock_lock_func libintl_recursive_lock_lock_func #define glthread_recursive_lock_unlock_multithreaded libintl_recursive_lock_unlock_multithreaded #define glthread_recursive_lock_unlock_func libintl_recursive_lock_unlock_func #define glthread_recursive_lock_destroy_multithreaded libintl_recursive_lock_destroy_multithreaded #define glthread_recursive_lock_destroy_func libintl_recursive_lock_destroy_func #define glthread_once_func libintl_once_func #define glthread_once_singlethreaded libintl_once_singlethreaded #define glthread_once_multithreaded libintl_once_multithreaded ]) ]) dnl Checks for the core files of the intl subdirectory: dnl dcigettext.c dnl eval-plural.h dnl explodename.c dnl finddomain.c dnl gettextP.h dnl gmo.h dnl hash-string.h hash-string.c dnl l10nflist.c dnl libgnuintl.h.in (except the *printf stuff) dnl loadinfo.h dnl loadmsgcat.c dnl localealias.c dnl log.c dnl plural-exp.h plural-exp.c dnl plural.y dnl Used by libglocale. AC_DEFUN([gt_INTL_SUBDIR_CORE], [ AC_REQUIRE([AC_C_INLINE])dnl AC_REQUIRE([AC_TYPE_SIZE_T])dnl AC_REQUIRE([gl_AC_HEADER_STDINT_H]) AC_REQUIRE([AC_FUNC_ALLOCA])dnl AC_REQUIRE([AC_FUNC_MMAP])dnl AC_REQUIRE([gt_INTDIV0])dnl AC_REQUIRE([gl_AC_TYPE_UINTMAX_T])dnl AC_REQUIRE([gt_INTTYPES_PRI])dnl AC_REQUIRE([gl_LOCK])dnl AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[int foo (int a) { a = __builtin_expect (a, 10); return a == 10 ? 0 : 1; }]], [[]])], [AC_DEFINE([HAVE_BUILTIN_EXPECT], [1], [Define to 1 if the compiler understands __builtin_expect.])]) AC_CHECK_HEADERS([argz.h inttypes.h limits.h unistd.h sys/param.h]) AC_CHECK_FUNCS([getcwd getegid geteuid getgid getuid mempcpy munmap \ stpcpy strcasecmp strdup strtoul tsearch uselocale argz_count \ argz_stringify argz_next __fsetlocking]) dnl Solaris 12 provides getlocalename_l, while Illumos doesn't have dnl it nor the equivalent. if test $ac_cv_func_uselocale = yes; then AC_CHECK_FUNCS([getlocalename_l]) fi dnl Use the *_unlocked functions only if they are declared. dnl (because some of them were defined without being declared in Solaris dnl 2.5.1 but were removed in Solaris 2.6, whereas we want binaries built dnl on Solaris 2.5.1 to run on Solaris 2.6). AC_CHECK_DECLS([feof_unlocked, fgets_unlocked], , , [#include ]) AM_ICONV dnl intl/plural.c is generated from intl/plural.y. It requires bison, dnl because plural.y uses bison specific features. It requires at least dnl bison-2.7 for %define api.pure. dnl bison is only needed for the maintainer (who touches plural.y). But in dnl order to avoid separate Makefiles or --enable-maintainer-mode, we put dnl the rule in general Makefile. Now, some people carelessly touch the dnl files or have a broken "make" program, hence the plural.c rule will dnl sometimes fire. To avoid an error, defines BISON to ":" if it is not dnl present or too old. AC_CHECK_PROGS([INTLBISON], [bison]) if test -z "$INTLBISON"; then ac_verc_fail=yes else dnl Found it, now check the version. AC_MSG_CHECKING([version of bison]) changequote(<<,>>)dnl ac_prog_version=`$INTLBISON --version 2>&1 | sed -n 's/^.*GNU Bison.* \([0-9]*\.[0-9.]*\).*$/\1/p'` case $ac_prog_version in '') ac_prog_version="v. ?.??, bad"; ac_verc_fail=yes;; 2.[7-9]* | [3-9].*) changequote([,])dnl ac_prog_version="$ac_prog_version, ok"; ac_verc_fail=no;; *) ac_prog_version="$ac_prog_version, bad"; ac_verc_fail=yes;; esac AC_MSG_RESULT([$ac_prog_version]) fi if test $ac_verc_fail = yes; then INTLBISON=: fi ]) dnl Copies _GL_UNUSED and _GL_ATTRIBUTE_PURE definitions from dnl gnulib-common.m4 as a fallback, if the project isn't using Gnulib. AC_DEFUN([gt_GL_ATTRIBUTE], [ m4_ifndef([gl_[]COMMON], AH_VERBATIM([gt_gl_attribute], [/* Define as a marker that can be attached to declarations that might not be used. This helps to reduce warnings, such as from GCC -Wunused-parameter. */ #ifndef _GL_UNUSED # if __GNUC__ >= 3 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7) # define _GL_UNUSED __attribute__ ((__unused__)) # else # define _GL_UNUSED # endif #endif /* The __pure__ attribute was added in gcc 2.96. */ #ifndef _GL_ATTRIBUTE_PURE # if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 96) # define _GL_ATTRIBUTE_PURE __attribute__ ((__pure__)) # else # define _GL_ATTRIBUTE_PURE /* empty */ # endif #endif ]))]) ngraph-gtk-6.08.00/m4/glibc21.m40000644000175000017500000000161313070106167012657 00000000000000# glibc21.m4 serial 5 dnl Copyright (C) 2000-2002, 2004, 2008, 2010-2016 Free Software Foundation, dnl Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. # Test for the GNU C Library, version 2.1 or newer, or uClibc. # From Bruno Haible. AC_DEFUN([gl_GLIBC21], [ AC_CACHE_CHECK([whether we are using the GNU C Library >= 2.1 or uClibc], [ac_cv_gnu_library_2_1], [AC_EGREP_CPP([Lucky], [ #include #ifdef __GNU_LIBRARY__ #if (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 1) || (__GLIBC__ > 2) Lucky GNU user #endif #endif #ifdef __UCLIBC__ Lucky user #endif ], [ac_cv_gnu_library_2_1=yes], [ac_cv_gnu_library_2_1=no]) ] ) AC_SUBST([GLIBC21]) GLIBC21="$ac_cv_gnu_library_2_1" ] ) ngraph-gtk-6.08.00/m4/wchar_t.m40000644000175000017500000000146213070106167013065 00000000000000# wchar_t.m4 serial 4 (gettext-0.18.2) dnl Copyright (C) 2002-2003, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Test whether has the 'wchar_t' type. dnl Prerequisite: AC_PROG_CC AC_DEFUN([gt_TYPE_WCHAR_T], [ AC_CACHE_CHECK([for wchar_t], [gt_cv_c_wchar_t], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[#include wchar_t foo = (wchar_t)'\0';]], [[]])], [gt_cv_c_wchar_t=yes], [gt_cv_c_wchar_t=no])]) if test $gt_cv_c_wchar_t = yes; then AC_DEFINE([HAVE_WCHAR_T], [1], [Define if you have the 'wchar_t' type.]) fi ]) ngraph-gtk-6.08.00/m4/stdint_h.m40000644000175000017500000000174313070106167013254 00000000000000# stdint_h.m4 serial 9 dnl Copyright (C) 1997-2004, 2006, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Paul Eggert. # Define HAVE_STDINT_H_WITH_UINTMAX if exists, # doesn't clash with , and declares uintmax_t. AC_DEFUN([gl_AC_HEADER_STDINT_H], [ AC_CACHE_CHECK([for stdint.h], [gl_cv_header_stdint_h], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[uintmax_t i = (uintmax_t) -1; return !i;]])], [gl_cv_header_stdint_h=yes], [gl_cv_header_stdint_h=no])]) if test $gl_cv_header_stdint_h = yes; then AC_DEFINE_UNQUOTED([HAVE_STDINT_H_WITH_UINTMAX], [1], [Define if exists, doesn't clash with , and declares uintmax_t. ]) fi ]) ngraph-gtk-6.08.00/m4/iconv.m40000644000175000017500000002207213310717145012555 00000000000000# iconv.m4 serial 19 (gettext-0.18.2) dnl Copyright (C) 2000-2002, 2007-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([AM_ICONV_LINKFLAGS_BODY], [ dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV dnl accordingly. AC_LIB_LINKFLAGS_BODY([iconv]) ]) AC_DEFUN([AM_ICONV_LINK], [ dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and dnl those with the standalone portable GNU libiconv installed). AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV dnl accordingly. AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) dnl Add $INCICONV to CPPFLAGS before performing the following checks, dnl because if the user has installed libiconv and not disabled its use dnl via --without-libiconv-prefix, he wants to use it. The first dnl AC_LINK_IFELSE will then fail, the second AC_LINK_IFELSE will succeed. am_save_CPPFLAGS="$CPPFLAGS" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCICONV]) AC_CACHE_CHECK([for iconv], [am_cv_func_iconv], [ am_cv_func_iconv="no, consider installing GNU libiconv" am_cv_lib_iconv=no AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #include ]], [[iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd);]])], [am_cv_func_iconv=yes]) if test "$am_cv_func_iconv" != yes; then am_save_LIBS="$LIBS" LIBS="$LIBS $LIBICONV" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #include ]], [[iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd);]])], [am_cv_lib_iconv=yes] [am_cv_func_iconv=yes]) LIBS="$am_save_LIBS" fi ]) if test "$am_cv_func_iconv" = yes; then AC_CACHE_CHECK([for working iconv], [am_cv_func_iconv_works], [ dnl This tests against bugs in AIX 5.1, AIX 6.1..7.1, HP-UX 11.11, dnl Solaris 10. am_save_LIBS="$LIBS" if test $am_cv_lib_iconv = yes; then LIBS="$LIBS $LIBICONV" fi am_cv_func_iconv_works=no for ac_iconv_const in '' 'const'; do AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[ #include #include #ifndef ICONV_CONST # define ICONV_CONST $ac_iconv_const #endif ]], [[int result = 0; /* Test against AIX 5.1 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_utf8_to_88591 = iconv_open ("ISO8859-1", "UTF-8"); if (cd_utf8_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\342\202\254"; /* EURO SIGN */ char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_utf8_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 1; iconv_close (cd_utf8_to_88591); } } /* Test against Solaris 10 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_ascii_to_88591 = iconv_open ("ISO8859-1", "646"); if (cd_ascii_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\263"; char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_ascii_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 2; iconv_close (cd_ascii_to_88591); } } /* Test against AIX 6.1..7.1 bug: Buffer overrun. */ { iconv_t cd_88591_to_utf8 = iconv_open ("UTF-8", "ISO-8859-1"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304"; static char buf[2] = { (char)0xDE, (char)0xAD }; ICONV_CONST char *inptr = input; size_t inbytesleft = 1; char *outptr = buf; size_t outbytesleft = 1; size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res != (size_t)(-1) || outptr - buf > 1 || buf[1] != (char)0xAD) result |= 4; iconv_close (cd_88591_to_utf8); } } #if 0 /* This bug could be worked around by the caller. */ /* Test against HP-UX 11.11 bug: Positive return value instead of 0. */ { iconv_t cd_88591_to_utf8 = iconv_open ("utf8", "iso88591"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337"; char buf[50]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if ((int)res > 0) result |= 8; iconv_close (cd_88591_to_utf8); } } #endif /* Test against HP-UX 11.11 bug: No converter from EUC-JP to UTF-8 is provided. */ if (/* Try standardized names. */ iconv_open ("UTF-8", "EUC-JP") == (iconv_t)(-1) /* Try IRIX, OSF/1 names. */ && iconv_open ("UTF-8", "eucJP") == (iconv_t)(-1) /* Try AIX names. */ && iconv_open ("UTF-8", "IBM-eucJP") == (iconv_t)(-1) /* Try HP-UX names. */ && iconv_open ("utf8", "eucJP") == (iconv_t)(-1)) result |= 16; return result; ]])], [am_cv_func_iconv_works=yes], , [case "$host_os" in aix* | hpux*) am_cv_func_iconv_works="guessing no" ;; *) am_cv_func_iconv_works="guessing yes" ;; esac]) test "$am_cv_func_iconv_works" = no || break done LIBS="$am_save_LIBS" ]) case "$am_cv_func_iconv_works" in *no) am_func_iconv=no am_cv_lib_iconv=no ;; *) am_func_iconv=yes ;; esac else am_func_iconv=no am_cv_lib_iconv=no fi if test "$am_func_iconv" = yes; then AC_DEFINE([HAVE_ICONV], [1], [Define if you have the iconv() function and it works.]) fi if test "$am_cv_lib_iconv" = yes; then AC_MSG_CHECKING([how to link with libiconv]) AC_MSG_RESULT([$LIBICONV]) else dnl If $LIBICONV didn't lead to a usable library, we don't need $INCICONV dnl either. CPPFLAGS="$am_save_CPPFLAGS" LIBICONV= LTLIBICONV= fi AC_SUBST([LIBICONV]) AC_SUBST([LTLIBICONV]) ]) dnl Define AM_ICONV using AC_DEFUN_ONCE for Autoconf >= 2.64, in order to dnl avoid warnings like dnl "warning: AC_REQUIRE: `AM_ICONV' was expanded before it was required". dnl This is tricky because of the way 'aclocal' is implemented: dnl - It requires defining an auxiliary macro whose name ends in AC_DEFUN. dnl Otherwise aclocal's initial scan pass would miss the macro definition. dnl - It requires a line break inside the AC_DEFUN_ONCE and AC_DEFUN expansions. dnl Otherwise aclocal would emit many "Use of uninitialized value $1" dnl warnings. m4_define([gl_iconv_AC_DEFUN], m4_version_prereq([2.64], [[AC_DEFUN_ONCE( [$1], [$2])]], [m4_ifdef([gl_00GNULIB], [[AC_DEFUN_ONCE( [$1], [$2])]], [[AC_DEFUN( [$1], [$2])]])])) gl_iconv_AC_DEFUN([AM_ICONV], [ AM_ICONV_LINK if test "$am_cv_func_iconv" = yes; then AC_MSG_CHECKING([for iconv declaration]) AC_CACHE_VAL([am_cv_proto_iconv], [ AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ #include #include extern #ifdef __cplusplus "C" #endif #if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus) size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft); #else size_t iconv(); #endif ]], [[]])], [am_cv_proto_iconv_arg1=""], [am_cv_proto_iconv_arg1="const"]) am_cv_proto_iconv="extern size_t iconv (iconv_t cd, $am_cv_proto_iconv_arg1 char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);"]) am_cv_proto_iconv=`echo "[$]am_cv_proto_iconv" | tr -s ' ' | sed -e 's/( /(/'` AC_MSG_RESULT([ $am_cv_proto_iconv]) AC_DEFINE_UNQUOTED([ICONV_CONST], [$am_cv_proto_iconv_arg1], [Define as const if the declaration of iconv() needs const.]) dnl Also substitute ICONV_CONST in the gnulib generated . m4_ifdef([gl_ICONV_H_DEFAULTS], [AC_REQUIRE([gl_ICONV_H_DEFAULTS]) if test -n "$am_cv_proto_iconv_arg1"; then ICONV_CONST="const" fi ]) fi ]) ngraph-gtk-6.08.00/m4/lcmessage.m40000644000175000017500000000252513070106167013402 00000000000000# lcmessage.m4 serial 7 (gettext-0.18.2) dnl Copyright (C) 1995-2002, 2004-2005, 2008-2014, 2016 Free Software dnl Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995. # Check whether LC_MESSAGES is available in . AC_DEFUN([gt_LC_MESSAGES], [ AC_CACHE_CHECK([for LC_MESSAGES], [gt_cv_val_LC_MESSAGES], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[return LC_MESSAGES]])], [gt_cv_val_LC_MESSAGES=yes], [gt_cv_val_LC_MESSAGES=no])]) if test $gt_cv_val_LC_MESSAGES = yes; then AC_DEFINE([HAVE_LC_MESSAGES], [1], [Define if your file defines LC_MESSAGES.]) fi ]) ngraph-gtk-6.08.00/m4/ltoptions.m40000644000175000017500000003426213342745520013501 00000000000000# 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])]) ngraph-gtk-6.08.00/m4/intldir.m40000644000175000017500000000162513070106167013104 00000000000000# intldir.m4 serial 2 (gettext-0.18) dnl Copyright (C) 2006, 2009-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. AC_PREREQ([2.52]) dnl Tells the AM_GNU_GETTEXT macro to consider an intl/ directory. AC_DEFUN([AM_GNU_GETTEXT_INTL_SUBDIR], []) ngraph-gtk-6.08.00/m4/xsize.m40000644000175000017500000000062613070106167012601 00000000000000# xsize.m4 serial 5 dnl Copyright (C) 2003-2004, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. AC_DEFUN([gl_XSIZE], [ dnl Prerequisites of lib/xsize.h. AC_REQUIRE([gl_SIZE_MAX]) AC_CHECK_HEADERS([stdint.h]) ]) ngraph-gtk-6.08.00/m4/gsl.m40000644000175000017500000001174313070106167012226 00000000000000# Configure path for the GNU Scientific Library # Christopher R. Gabriel , April 2000 AC_DEFUN([AX_PATH_GSL], [ AC_ARG_WITH(gsl-prefix,[ --with-gsl-prefix=PFX Prefix where GSL is installed (optional)], gsl_prefix="$withval", gsl_prefix="") AC_ARG_WITH(gsl-exec-prefix,[ --with-gsl-exec-prefix=PFX Exec prefix where GSL is installed (optional)], gsl_exec_prefix="$withval", gsl_exec_prefix="") AC_ARG_ENABLE(gsltest, [ --disable-gsltest Do not try to compile and run a test GSL program], , enable_gsltest=yes) if test "x${GSL_CONFIG+set}" != xset ; then if test "x$gsl_prefix" != x ; then GSL_CONFIG="$gsl_prefix/bin/gsl-config" fi if test "x$gsl_exec_prefix" != x ; then GSL_CONFIG="$gsl_exec_prefix/bin/gsl-config" fi fi AC_PATH_PROG(GSL_CONFIG, gsl-config, no) min_gsl_version=ifelse([$1], ,0.2.5,$1) AC_MSG_CHECKING(for GSL - version >= $min_gsl_version) no_gsl="" if test "$GSL_CONFIG" = "no" ; then no_gsl=yes else GSL_CFLAGS=`$GSL_CONFIG --cflags` GSL_LIBS=`$GSL_CONFIG --libs` gsl_major_version=`$GSL_CONFIG --version | \ sed 's/^\([[0-9]]*\).*/\1/'` if test "x${gsl_major_version}" = "x" ; then gsl_major_version=0 fi gsl_minor_version=`$GSL_CONFIG --version | \ sed 's/^\([[0-9]]*\)\.\{0,1\}\([[0-9]]*\).*/\2/'` if test "x${gsl_minor_version}" = "x" ; then gsl_minor_version=0 fi gsl_micro_version=`$GSL_CONFIG --version | \ sed 's/^\([[0-9]]*\)\.\{0,1\}\([[0-9]]*\)\.\{0,1\}\([[0-9]]*\).*/\3/'` if test "x${gsl_micro_version}" = "x" ; then gsl_micro_version=0 fi if test "x$enable_gsltest" = "xyes" ; then ac_save_CFLAGS="$CFLAGS" ac_save_LIBS="$LIBS" CFLAGS="$CFLAGS $GSL_CFLAGS" LIBS="$LIBS $GSL_LIBS" rm -f conf.gsltest AC_TRY_RUN([ #include #include #include char* my_strdup (const char *str); char* my_strdup (const char *str) { char *new_str; if (str) { new_str = (char *)malloc ((strlen (str) + 1) * sizeof(char)); strcpy (new_str, str); } else new_str = NULL; return new_str; } int main (void) { int major = 0, minor = 0, micro = 0; int n; char *tmp_version; system ("touch conf.gsltest"); /* HP/UX 9 (%@#!) writes to sscanf strings */ tmp_version = my_strdup("$min_gsl_version"); n = sscanf(tmp_version, "%d.%d.%d", &major, &minor, µ) ; if (n != 2 && n != 3) { printf("%s, bad version string\n", "$min_gsl_version"); exit(1); } if (($gsl_major_version > major) || (($gsl_major_version == major) && ($gsl_minor_version > minor)) || (($gsl_major_version == major) && ($gsl_minor_version == minor) && ($gsl_micro_version >= micro))) { exit(0); } else { exit(1); } } ],, no_gsl=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi if test "x$no_gsl" = x ; then AC_MSG_RESULT(yes) ifelse([$2], , :, [$2]) else AC_MSG_RESULT(no) if test "$GSL_CONFIG" = "no" ; then echo "*** The gsl-config script installed by GSL could not be found" echo "*** If GSL was installed in PREFIX, make sure PREFIX/bin is in" echo "*** your path, or set the GSL_CONFIG environment variable to the" echo "*** full path to gsl-config." else if test -f conf.gsltest ; then : else echo "*** Could not run GSL test program, checking why..." CFLAGS="$CFLAGS $GSL_CFLAGS" LIBS="$LIBS $GSL_LIBS" AC_TRY_LINK([ #include ], [ return 0; ], [ echo "*** The test program compiled, but did not run. This usually means" echo "*** that the run-time linker is not finding GSL or finding the wrong" echo "*** version of GSL. If it is not finding GSL, you'll need to set your" echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" echo "*** to the installed location Also, make sure you have run ldconfig if that" echo "*** is required on your system" echo "***" echo "*** If you have an old version installed, it is best to remove it, although" echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"], [ echo "*** The test program failed to compile or link. See the file config.log for the" echo "*** exact error that occured. This usually means GSL was incorrectly installed" echo "*** or that you have moved GSL since it was installed. In the latter case, you" echo "*** may want to edit the gsl-config script: $GSL_CONFIG" ]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi # GSL_CFLAGS="" # GSL_LIBS="" ifelse([$3], , :, [$3]) fi AC_SUBST(GSL_CFLAGS) AC_SUBST(GSL_LIBS) rm -f conf.gsltest ]) AU_ALIAS([AM_PATH_GSL], [AX_PATH_GSL]) ngraph-gtk-6.08.00/m4/inttypes-pri.m40000644000175000017500000000234513070106167014106 00000000000000# inttypes-pri.m4 serial 7 (gettext-0.18.2) dnl Copyright (C) 1997-2002, 2006, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_PREREQ([2.53]) # Define PRI_MACROS_BROKEN if exists and defines the PRI* # macros to non-string values. This is the case on AIX 4.3.3. AC_DEFUN([gt_INTTYPES_PRI], [ AC_CHECK_HEADERS([inttypes.h]) if test $ac_cv_header_inttypes_h = yes; then AC_CACHE_CHECK([whether the inttypes.h PRIxNN macros are broken], [gt_cv_inttypes_pri_broken], [ AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifdef PRId32 char *p = PRId32; #endif ]], [[]])], [gt_cv_inttypes_pri_broken=no], [gt_cv_inttypes_pri_broken=yes]) ]) fi if test "$gt_cv_inttypes_pri_broken" = yes; then AC_DEFINE_UNQUOTED([PRI_MACROS_BROKEN], [1], [Define if exists and defines unusable PRI* macros.]) PRI_MACROS_BROKEN=1 else PRI_MACROS_BROKEN=0 fi AC_SUBST([PRI_MACROS_BROKEN]) ]) ngraph-gtk-6.08.00/m4/visibility.m40000644000175000017500000000642713070106167013633 00000000000000# visibility.m4 serial 5 (gettext-0.18.2) dnl Copyright (C) 2005, 2008, 2010-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Tests whether the compiler supports the command-line option dnl -fvisibility=hidden and the function and variable attributes dnl __attribute__((__visibility__("hidden"))) and dnl __attribute__((__visibility__("default"))). dnl Does *not* test for __visibility__("protected") - which has tricky dnl semantics (see the 'vismain' test in glibc) and does not exist e.g. on dnl Mac OS X. dnl Does *not* test for __visibility__("internal") - which has processor dnl dependent semantics. dnl Does *not* test for #pragma GCC visibility push(hidden) - which is dnl "really only recommended for legacy code". dnl Set the variable CFLAG_VISIBILITY. dnl Defines and sets the variable HAVE_VISIBILITY. AC_DEFUN([gl_VISIBILITY], [ AC_REQUIRE([AC_PROG_CC]) CFLAG_VISIBILITY= HAVE_VISIBILITY=0 if test -n "$GCC"; then dnl First, check whether -Werror can be added to the command line, or dnl whether it leads to an error because of some other option that the dnl user has put into $CC $CFLAGS $CPPFLAGS. AC_MSG_CHECKING([whether the -Werror option is usable]) AC_CACHE_VAL([gl_cv_cc_vis_werror], [ gl_save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -Werror" AC_COMPILE_IFELSE( [AC_LANG_PROGRAM([[]], [[]])], [gl_cv_cc_vis_werror=yes], [gl_cv_cc_vis_werror=no]) CFLAGS="$gl_save_CFLAGS"]) AC_MSG_RESULT([$gl_cv_cc_vis_werror]) dnl Now check whether visibility declarations are supported. AC_MSG_CHECKING([for simple visibility declarations]) AC_CACHE_VAL([gl_cv_cc_visibility], [ gl_save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -fvisibility=hidden" dnl We use the option -Werror and a function dummyfunc, because on some dnl platforms (Cygwin 1.7) the use of -fvisibility triggers a warning dnl "visibility attribute not supported in this configuration; ignored" dnl at the first function definition in every compilation unit, and we dnl don't want to use the option in this case. if test $gl_cv_cc_vis_werror = yes; then CFLAGS="$CFLAGS -Werror" fi AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[extern __attribute__((__visibility__("hidden"))) int hiddenvar; extern __attribute__((__visibility__("default"))) int exportedvar; extern __attribute__((__visibility__("hidden"))) int hiddenfunc (void); extern __attribute__((__visibility__("default"))) int exportedfunc (void); void dummyfunc (void) {} ]], [[]])], [gl_cv_cc_visibility=yes], [gl_cv_cc_visibility=no]) CFLAGS="$gl_save_CFLAGS"]) AC_MSG_RESULT([$gl_cv_cc_visibility]) if test $gl_cv_cc_visibility = yes; then CFLAG_VISIBILITY="-fvisibility=hidden" HAVE_VISIBILITY=1 fi fi AC_SUBST([CFLAG_VISIBILITY]) AC_SUBST([HAVE_VISIBILITY]) AC_DEFINE_UNQUOTED([HAVE_VISIBILITY], [$HAVE_VISIBILITY], [Define to 1 or 0, depending whether the compiler supports simple visibility declarations.]) ]) ngraph-gtk-6.08.00/m4/codeset.m40000644000175000017500000000151213310717145013061 00000000000000# codeset.m4 serial 5 (gettext-0.18.2) dnl Copyright (C) 2000-2002, 2006, 2008-2014, 2016 Free Software Foundation, dnl Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([AM_LANGINFO_CODESET], [ AC_CACHE_CHECK([for nl_langinfo and CODESET], [am_cv_langinfo_codeset], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[char* cs = nl_langinfo(CODESET); return !cs;]])], [am_cv_langinfo_codeset=yes], [am_cv_langinfo_codeset=no]) ]) if test $am_cv_langinfo_codeset = yes; then AC_DEFINE([HAVE_LANGINFO_CODESET], [1], [Define if you have and nl_langinfo(CODESET).]) fi ]) ngraph-gtk-6.08.00/m4/lib-link.m40000644000175000017500000010044313070106167013136 00000000000000# lib-link.m4 serial 26 (gettext-0.18.2) dnl Copyright (C) 2001-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_PREREQ([2.54]) dnl AC_LIB_LINKFLAGS(name [, dependencies]) searches for libname and dnl the libraries corresponding to explicit and implicit dependencies. dnl Sets and AC_SUBSTs the LIB${NAME} and LTLIB${NAME} variables and dnl augments the CPPFLAGS variable. dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_LINKFLAGS], [ AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) pushdef([Name],[m4_translit([$1],[./+-], [____])]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) AC_CACHE_CHECK([how to link with lib[]$1], [ac_cv_lib[]Name[]_libs], [ AC_LIB_LINKFLAGS_BODY([$1], [$2]) ac_cv_lib[]Name[]_libs="$LIB[]NAME" ac_cv_lib[]Name[]_ltlibs="$LTLIB[]NAME" ac_cv_lib[]Name[]_cppflags="$INC[]NAME" ac_cv_lib[]Name[]_prefix="$LIB[]NAME[]_PREFIX" ]) LIB[]NAME="$ac_cv_lib[]Name[]_libs" LTLIB[]NAME="$ac_cv_lib[]Name[]_ltlibs" INC[]NAME="$ac_cv_lib[]Name[]_cppflags" LIB[]NAME[]_PREFIX="$ac_cv_lib[]Name[]_prefix" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) AC_SUBST([LIB]NAME) AC_SUBST([LTLIB]NAME) AC_SUBST([LIB]NAME[_PREFIX]) dnl Also set HAVE_LIB[]NAME so that AC_LIB_HAVE_LINKFLAGS can reuse the dnl results of this search when this library appears as a dependency. HAVE_LIB[]NAME=yes popdef([NAME]) popdef([Name]) ]) dnl AC_LIB_HAVE_LINKFLAGS(name, dependencies, includes, testcode, [missing-message]) dnl searches for libname and the libraries corresponding to explicit and dnl implicit dependencies, together with the specified include files and dnl the ability to compile and link the specified testcode. The missing-message dnl defaults to 'no' and may contain additional hints for the user. dnl If found, it sets and AC_SUBSTs HAVE_LIB${NAME}=yes and the LIB${NAME} dnl and LTLIB${NAME} variables and augments the CPPFLAGS variable, and dnl #defines HAVE_LIB${NAME} to 1. Otherwise, it sets and AC_SUBSTs dnl HAVE_LIB${NAME}=no and LIB${NAME} and LTLIB${NAME} to empty. dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_HAVE_LINKFLAGS], [ AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) pushdef([Name],[m4_translit([$1],[./+-], [____])]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) dnl Search for lib[]Name and define LIB[]NAME, LTLIB[]NAME and INC[]NAME dnl accordingly. AC_LIB_LINKFLAGS_BODY([$1], [$2]) dnl Add $INC[]NAME to CPPFLAGS before performing the following checks, dnl because if the user has installed lib[]Name and not disabled its use dnl via --without-lib[]Name-prefix, he wants to use it. ac_save_CPPFLAGS="$CPPFLAGS" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) AC_CACHE_CHECK([for lib[]$1], [ac_cv_lib[]Name], [ ac_save_LIBS="$LIBS" dnl If $LIB[]NAME contains some -l options, add it to the end of LIBS, dnl because these -l options might require -L options that are present in dnl LIBS. -l options benefit only from the -L options listed before it. dnl Otherwise, add it to the front of LIBS, because it may be a static dnl library that depends on another static library that is present in LIBS. dnl Static libraries benefit only from the static libraries listed after dnl it. case " $LIB[]NAME" in *" -l"*) LIBS="$LIBS $LIB[]NAME" ;; *) LIBS="$LIB[]NAME $LIBS" ;; esac AC_LINK_IFELSE( [AC_LANG_PROGRAM([[$3]], [[$4]])], [ac_cv_lib[]Name=yes], [ac_cv_lib[]Name='m4_if([$5], [], [no], [[$5]])']) LIBS="$ac_save_LIBS" ]) if test "$ac_cv_lib[]Name" = yes; then HAVE_LIB[]NAME=yes AC_DEFINE([HAVE_LIB]NAME, 1, [Define if you have the lib][$1 library.]) AC_MSG_CHECKING([how to link with lib[]$1]) AC_MSG_RESULT([$LIB[]NAME]) else HAVE_LIB[]NAME=no dnl If $LIB[]NAME didn't lead to a usable library, we don't need dnl $INC[]NAME either. CPPFLAGS="$ac_save_CPPFLAGS" LIB[]NAME= LTLIB[]NAME= LIB[]NAME[]_PREFIX= fi AC_SUBST([HAVE_LIB]NAME) AC_SUBST([LIB]NAME) AC_SUBST([LTLIB]NAME) AC_SUBST([LIB]NAME[_PREFIX]) popdef([NAME]) popdef([Name]) ]) dnl Determine the platform dependent parameters needed to use rpath: dnl acl_libext, dnl acl_shlibext, dnl acl_libname_spec, dnl acl_library_names_spec, dnl acl_hardcode_libdir_flag_spec, dnl acl_hardcode_libdir_separator, dnl acl_hardcode_direct, dnl acl_hardcode_minus_L. AC_DEFUN([AC_LIB_RPATH], [ dnl Tell automake >= 1.10 to complain if config.rpath is missing. m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([config.rpath])]) AC_REQUIRE([AC_PROG_CC]) dnl we use $CC, $GCC, $LDFLAGS AC_REQUIRE([AC_LIB_PROG_LD]) dnl we use $LD, $with_gnu_ld AC_REQUIRE([AC_CANONICAL_HOST]) dnl we use $host AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT]) dnl we use $ac_aux_dir AC_CACHE_CHECK([for shared library run path origin], [acl_cv_rpath], [ CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \ ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh . ./conftest.sh rm -f ./conftest.sh acl_cv_rpath=done ]) wl="$acl_cv_wl" acl_libext="$acl_cv_libext" acl_shlibext="$acl_cv_shlibext" acl_libname_spec="$acl_cv_libname_spec" acl_library_names_spec="$acl_cv_library_names_spec" acl_hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec" acl_hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator" acl_hardcode_direct="$acl_cv_hardcode_direct" acl_hardcode_minus_L="$acl_cv_hardcode_minus_L" dnl Determine whether the user wants rpath handling at all. AC_ARG_ENABLE([rpath], [ --disable-rpath do not hardcode runtime library paths], :, enable_rpath=yes) ]) dnl AC_LIB_FROMPACKAGE(name, package) dnl declares that libname comes from the given package. The configure file dnl will then not have a --with-libname-prefix option but a dnl --with-package-prefix option. Several libraries can come from the same dnl package. This declaration must occur before an AC_LIB_LINKFLAGS or similar dnl macro call that searches for libname. AC_DEFUN([AC_LIB_FROMPACKAGE], [ pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) define([acl_frompackage_]NAME, [$2]) popdef([NAME]) pushdef([PACK],[$2]) pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) define([acl_libsinpackage_]PACKUP, m4_ifdef([acl_libsinpackage_]PACKUP, [m4_defn([acl_libsinpackage_]PACKUP)[, ]],)[lib$1]) popdef([PACKUP]) popdef([PACK]) ]) dnl AC_LIB_LINKFLAGS_BODY(name [, dependencies]) searches for libname and dnl the libraries corresponding to explicit and implicit dependencies. dnl Sets the LIB${NAME}, LTLIB${NAME} and INC${NAME} variables. dnl Also, sets the LIB${NAME}_PREFIX variable to nonempty if libname was found dnl in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_LINKFLAGS_BODY], [ AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) pushdef([PACK],[m4_ifdef([acl_frompackage_]NAME, [acl_frompackage_]NAME, lib[$1])]) pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) pushdef([PACKLIBS],[m4_ifdef([acl_frompackage_]NAME, [acl_libsinpackage_]PACKUP, lib[$1])]) dnl Autoconf >= 2.61 supports dots in --with options. pushdef([P_A_C_K],[m4_if(m4_version_compare(m4_defn([m4_PACKAGE_VERSION]),[2.61]),[-1],[m4_translit(PACK,[.],[_])],PACK)]) dnl By default, look in $includedir and $libdir. use_additional=yes AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) AC_ARG_WITH(P_A_C_K[-prefix], [[ --with-]]P_A_C_K[[-prefix[=DIR] search for ]PACKLIBS[ in DIR/include and DIR/lib --without-]]P_A_C_K[[-prefix don't search for ]PACKLIBS[ in includedir and libdir]], [ if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" if test "$acl_libdirstem2" != "$acl_libdirstem" \ && ! test -d "$withval/$acl_libdirstem"; then additional_libdir="$withval/$acl_libdirstem2" fi fi fi ]) dnl Search the library and its dependencies in $additional_libdir and dnl $LDFLAGS. Using breadth-first-seach. LIB[]NAME= LTLIB[]NAME= INC[]NAME= LIB[]NAME[]_PREFIX= dnl HAVE_LIB${NAME} is an indicator that LIB${NAME}, LTLIB${NAME} have been dnl computed. So it has to be reset here. HAVE_LIB[]NAME= rpathdirs= ltrpathdirs= names_already_handled= names_next_round='$1 $2' while test -n "$names_next_round"; do names_this_round="$names_next_round" names_next_round= for name in $names_this_round; do already_handled= for n in $names_already_handled; do if test "$n" = "$name"; then already_handled=yes break fi done if test -z "$already_handled"; then names_already_handled="$names_already_handled $name" dnl See if it was already located by an earlier AC_LIB_LINKFLAGS dnl or AC_LIB_HAVE_LINKFLAGS call. uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./+-|ABCDEFGHIJKLMNOPQRSTUVWXYZ____|'` eval value=\"\$HAVE_LIB$uppername\" if test -n "$value"; then if test "$value" = yes; then eval value=\"\$LIB$uppername\" test -z "$value" || LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$value" eval value=\"\$LTLIB$uppername\" test -z "$value" || LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$value" else dnl An earlier call to AC_LIB_HAVE_LINKFLAGS has determined dnl that this library doesn't exist. So just drop it. : fi else dnl Search the library lib$name in $additional_libdir and $LDFLAGS dnl and the already constructed $LIBNAME/$LTLIBNAME. found_dir= found_la= found_so= found_a= eval libname=\"$acl_libname_spec\" # typically: libname=lib$name if test -n "$acl_shlibext"; then shrext=".$acl_shlibext" # typically: shrext=.so else shrext= fi if test $use_additional = yes; then dir="$additional_libdir" dnl The same code as in the loop below: dnl First look for a shared library. if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi dnl Then look for a static library. if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext"; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi fi if test "X$found_dir" = "X"; then for x in $LDFLAGS $LTLIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) case "$x" in -L*) dir=`echo "X$x" | sed -e 's/^X-L//'` dnl First look for a shared library. if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi dnl Then look for a static library. if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext"; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi ;; esac if test "X$found_dir" != "X"; then break fi done fi if test "X$found_dir" != "X"; then dnl Found the library. LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$found_dir -l$name" if test "X$found_so" != "X"; then dnl Linking with a shared library. We attempt to hardcode its dnl directory into the executable's runpath, unless it's the dnl standard /usr/lib. if test "$enable_rpath" = no \ || test "X$found_dir" = "X/usr/$acl_libdirstem" \ || test "X$found_dir" = "X/usr/$acl_libdirstem2"; then dnl No hardcoding is needed. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else dnl Use an explicit option to hardcode DIR into the resulting dnl binary. dnl Potentially add DIR to ltrpathdirs. dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. haveit= for x in $ltrpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $found_dir" fi dnl The hardcoding into $LIBNAME is system dependent. if test "$acl_hardcode_direct" = yes; then dnl Using DIR/libNAME.so during linking hardcodes DIR into the dnl resulting binary. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then dnl Use an explicit option to hardcode DIR into the resulting dnl binary. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" dnl Potentially add DIR to rpathdirs. dnl The rpathdirs will be appended to $LIBNAME at the end. haveit= for x in $rpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $found_dir" fi else dnl Rely on "-L$found_dir". dnl But don't add it if it's already contained in the LDFLAGS dnl or the already constructed $LIBNAME haveit= for x in $LDFLAGS $LIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir" fi if test "$acl_hardcode_minus_L" != no; then dnl FIXME: Not sure whether we should use dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" dnl here. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else dnl We cannot use $acl_hardcode_runpath_var and LD_RUN_PATH dnl here, because this doesn't fit in flags passed to the dnl compiler. So give up. No hardcoding. This affects only dnl very old systems. dnl FIXME: Not sure whether we should use dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" dnl here. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" fi fi fi fi else if test "X$found_a" != "X"; then dnl Linking with a static library. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_a" else dnl We shouldn't come here, but anyway it's good to have a dnl fallback. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir -l$name" fi fi dnl Assume the include files are nearby. additional_includedir= case "$found_dir" in */$acl_libdirstem | */$acl_libdirstem/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'` if test "$name" = '$1'; then LIB[]NAME[]_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem2 | */$acl_libdirstem2/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem2/"'*$,,'` if test "$name" = '$1'; then LIB[]NAME[]_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; esac if test "X$additional_includedir" != "X"; then dnl Potentially add $additional_includedir to $INCNAME. dnl But don't add it dnl 1. if it's the standard /usr/include, dnl 2. if it's /usr/local/include and we are using GCC on Linux, dnl 3. if it's already present in $CPPFLAGS or the already dnl constructed $INCNAME, dnl 4. if it doesn't exist as a directory. if test "X$additional_includedir" != "X/usr/include"; then haveit= if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then for x in $CPPFLAGS $INC[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_includedir"; then dnl Really add $additional_includedir to $INCNAME. INC[]NAME="${INC[]NAME}${INC[]NAME:+ }-I$additional_includedir" fi fi fi fi fi dnl Look for dependencies. if test -n "$found_la"; then dnl Read the .la file. It defines the variables dnl dlname, library_names, old_library, dependency_libs, current, dnl age, revision, installed, dlopen, dlpreopen, libdir. save_libdir="$libdir" case "$found_la" in */* | *\\*) . "$found_la" ;; *) . "./$found_la" ;; esac libdir="$save_libdir" dnl We use only dependency_libs. for dep in $dependency_libs; do case "$dep" in -L*) additional_libdir=`echo "X$dep" | sed -e 's/^X-L//'` dnl Potentially add $additional_libdir to $LIBNAME and $LTLIBNAME. dnl But don't add it dnl 1. if it's the standard /usr/lib, dnl 2. if it's /usr/local/lib and we are using GCC on Linux, dnl 3. if it's already present in $LDFLAGS or the already dnl constructed $LIBNAME, dnl 4. if it doesn't exist as a directory. if test "X$additional_libdir" != "X/usr/$acl_libdirstem" \ && test "X$additional_libdir" != "X/usr/$acl_libdirstem2"; then haveit= if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem" \ || test "X$additional_libdir" = "X/usr/local/$acl_libdirstem2"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then haveit= for x in $LDFLAGS $LIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$additional_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_libdir"; then dnl Really add $additional_libdir to $LIBNAME. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$additional_libdir" fi fi haveit= for x in $LDFLAGS $LTLIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$additional_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_libdir"; then dnl Really add $additional_libdir to $LTLIBNAME. LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$additional_libdir" fi fi fi fi ;; -R*) dir=`echo "X$dep" | sed -e 's/^X-R//'` if test "$enable_rpath" != no; then dnl Potentially add DIR to rpathdirs. dnl The rpathdirs will be appended to $LIBNAME at the end. haveit= for x in $rpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $dir" fi dnl Potentially add DIR to ltrpathdirs. dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. haveit= for x in $ltrpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $dir" fi fi ;; -l*) dnl Handle this in the next round. names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` ;; *.la) dnl Handle this in the next round. Throw away the .la's dnl directory; it is already contained in a preceding -L dnl option. names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` ;; *) dnl Most likely an immediate library name. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$dep" LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$dep" ;; esac done fi else dnl Didn't find the library; assume it is in the system directories dnl known to the linker and runtime loader. (All the system dnl directories known to the linker should also be known to the dnl runtime loader, otherwise the system is severely misconfigured.) LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-l$name" fi fi fi done done if test "X$rpathdirs" != "X"; then if test -n "$acl_hardcode_libdir_separator"; then dnl Weird platform: only the last -rpath option counts, the user must dnl pass all path elements in one option. We can arrange that for a dnl single library, but not when more than one $LIBNAMEs are used. alldirs= for found_dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir" done dnl Note: acl_hardcode_libdir_flag_spec uses $libdir and $wl. acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" else dnl The -rpath options are cumulative. for found_dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$found_dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" done fi fi if test "X$ltrpathdirs" != "X"; then dnl When using libtool, the option that works for both libraries and dnl executables is -R. The -R options are cumulative. for found_dir in $ltrpathdirs; do LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-R$found_dir" done fi popdef([P_A_C_K]) popdef([PACKLIBS]) popdef([PACKUP]) popdef([PACK]) popdef([NAME]) ]) dnl AC_LIB_APPENDTOVAR(VAR, CONTENTS) appends the elements of CONTENTS to VAR, dnl unless already present in VAR. dnl Works only for CPPFLAGS, not for LIB* variables because that sometimes dnl contains two or three consecutive elements that belong together. AC_DEFUN([AC_LIB_APPENDTOVAR], [ for element in [$2]; do haveit= for x in $[$1]; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X$element"; then haveit=yes break fi done if test -z "$haveit"; then [$1]="${[$1]}${[$1]:+ }$element" fi done ]) dnl For those cases where a variable contains several -L and -l options dnl referring to unknown libraries and directories, this macro determines the dnl necessary additional linker options for the runtime path. dnl AC_LIB_LINKFLAGS_FROM_LIBS([LDADDVAR], [LIBSVALUE], [USE-LIBTOOL]) dnl sets LDADDVAR to linker options needed together with LIBSVALUE. dnl If USE-LIBTOOL evaluates to non-empty, linking with libtool is assumed, dnl otherwise linking without libtool is assumed. AC_DEFUN([AC_LIB_LINKFLAGS_FROM_LIBS], [ AC_REQUIRE([AC_LIB_RPATH]) AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) $1= if test "$enable_rpath" != no; then if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then dnl Use an explicit option to hardcode directories into the resulting dnl binary. rpathdirs= next= for opt in $2; do if test -n "$next"; then dir="$next" dnl No need to hardcode the standard /usr/lib. if test "X$dir" != "X/usr/$acl_libdirstem" \ && test "X$dir" != "X/usr/$acl_libdirstem2"; then rpathdirs="$rpathdirs $dir" fi next= else case $opt in -L) next=yes ;; -L*) dir=`echo "X$opt" | sed -e 's,^X-L,,'` dnl No need to hardcode the standard /usr/lib. if test "X$dir" != "X/usr/$acl_libdirstem" \ && test "X$dir" != "X/usr/$acl_libdirstem2"; then rpathdirs="$rpathdirs $dir" fi next= ;; *) next= ;; esac fi done if test "X$rpathdirs" != "X"; then if test -n ""$3""; then dnl libtool is used for linking. Use -R options. for dir in $rpathdirs; do $1="${$1}${$1:+ }-R$dir" done else dnl The linker is used for linking directly. if test -n "$acl_hardcode_libdir_separator"; then dnl Weird platform: only the last -rpath option counts, the user dnl must pass all path elements in one option. alldirs= for dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$dir" done acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" $1="$flag" else dnl The -rpath options are cumulative. for dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" $1="${$1}${$1:+ }$flag" done fi fi fi fi fi AC_SUBST([$1]) ]) ngraph-gtk-6.08.00/m4/lt~obsolete.m40000644000175000017500000001377413342745520014025 00000000000000# 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])]) ngraph-gtk-6.08.00/m4/intmax.m40000644000175000017500000000214313070106167012733 00000000000000# intmax.m4 serial 6 (gettext-0.18.2) dnl Copyright (C) 2002-2005, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Test whether the system has the 'intmax_t' type, but don't attempt to dnl find a replacement if it is lacking. AC_DEFUN([gt_TYPE_INTMAX_T], [ AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) AC_REQUIRE([gl_AC_HEADER_STDINT_H]) AC_CACHE_CHECK([for intmax_t], [gt_cv_c_intmax_t], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ #include #include #if HAVE_STDINT_H_WITH_UINTMAX #include #endif #if HAVE_INTTYPES_H_WITH_UINTMAX #include #endif ]], [[intmax_t x = -1; return !x;]])], [gt_cv_c_intmax_t=yes], [gt_cv_c_intmax_t=no])]) if test $gt_cv_c_intmax_t = yes; then AC_DEFINE([HAVE_INTMAX_T], [1], [Define if you have the 'intmax_t' type in or .]) fi ]) ngraph-gtk-6.08.00/m4/ChangeLog0000644000175000017500000000302713314701637012751 000000000000002018-06-27 Hiroyuki Ito * glib-2.0.m4: added. * gtk-2.0.m4: removed. 2013-10-23 Ito Hiroyuki * gtk-3.0.m4: added. * gtk-2.0.m4: added. 2008-05-27 gettextize * gettext.m4: New file, from gettext-0.17. * iconv.m4: New file, from gettext-0.17. * lib-ld.m4: New file, from gettext-0.17. * lib-link.m4: New file, from gettext-0.17. * lib-prefix.m4: New file, from gettext-0.17. * nls.m4: New file, from gettext-0.17. * po.m4: New file, from gettext-0.17. * progtest.m4: New file, from gettext-0.17. * codeset.m4: New file, from gettext-0.17. * glibc2.m4: New file, from gettext-0.17. * glibc21.m4: New file, from gettext-0.17. * intdiv0.m4: New file, from gettext-0.17. * intl.m4: New file, from gettext-0.17. * intldir.m4: New file, from gettext-0.17. * intlmacosx.m4: New file, from gettext-0.17. * intmax.m4: New file, from gettext-0.17. * inttypes_h.m4: New file, from gettext-0.17. * inttypes-pri.m4: New file, from gettext-0.17. * lcmessage.m4: New file, from gettext-0.17. * lock.m4: New file, from gettext-0.17. * longlong.m4: New file, from gettext-0.17. * printf-posix.m4: New file, from gettext-0.17. * size_max.m4: New file, from gettext-0.17. * stdint_h.m4: New file, from gettext-0.17. * uintmax_t.m4: New file, from gettext-0.17. * visibility.m4: New file, from gettext-0.17. * wchar_t.m4: New file, from gettext-0.17. * wint_t.m4: New file, from gettext-0.17. * xsize.m4: New file, from gettext-0.17. * Makefile.am: New file. ngraph-gtk-6.08.00/m4/inttypes_h.m40000644000175000017500000000177413070106167013632 00000000000000# inttypes_h.m4 serial 10 dnl Copyright (C) 1997-2004, 2006, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Paul Eggert. # Define HAVE_INTTYPES_H_WITH_UINTMAX if exists, # doesn't clash with , and declares uintmax_t. AC_DEFUN([gl_AC_HEADER_INTTYPES_H], [ AC_CACHE_CHECK([for inttypes.h], [gl_cv_header_inttypes_h], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ #include #include ]], [[uintmax_t i = (uintmax_t) -1; return !i;]])], [gl_cv_header_inttypes_h=yes], [gl_cv_header_inttypes_h=no])]) if test $gl_cv_header_inttypes_h = yes; then AC_DEFINE_UNQUOTED([HAVE_INTTYPES_H_WITH_UINTMAX], [1], [Define if exists, doesn't clash with , and declares uintmax_t. ]) fi ]) ngraph-gtk-6.08.00/m4/gtk-3.0.m40000644000175000017500000002021313310717145012515 00000000000000# Configure paths for GTK+ # Owen Taylor 1997-2001 dnl AM_PATH_GTK_3_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]]) dnl Test for GTK+, and define GTK_CFLAGS and GTK_LIBS, if gthread is specified in MODULES, dnl pass to pkg-config dnl AC_DEFUN([AM_PATH_GTK_3_0], [m4_warn([obsolete], [AM_PATH_GTK_3_0 is deprecated, use PKG_CHECK_MODULES([GTK], [gtk+-3.0]) instead]) dnl Get the cflags and libraries from pkg-config dnl AC_ARG_ENABLE(gtktest, [ --disable-gtktest do not try to compile and run a test GTK+ program], , enable_gtktest=yes) min_gtk_version=ifelse([$1], [], [3.0.0], [$1]) pkg_config_args="gtk+-3.0 >= $min_gtk_version" for module in . $4 do case "$module" in gthread) pkg_config_args="$pkg_config_args gthread-2.0" ;; esac done no_gtk="" AC_PATH_TOOL([PKG_CONFIG], [pkg-config], [no]) if test x$PKG_CONFIG != xno ; then if $PKG_CONFIG --atleast-pkgconfig-version 0.7 ; then : else echo "*** pkg-config too old; version 0.7 or better required." no_gtk=yes PKG_CONFIG=no fi else no_gtk=yes fi AC_MSG_CHECKING(for GTK+ - version >= $min_gtk_version) if test x$PKG_CONFIG != xno ; then ## don't try to run the test against uninstalled libtool libs if $PKG_CONFIG --uninstalled $pkg_config_args; then echo "Will use uninstalled version of GTK+ found in PKG_CONFIG_PATH" enable_gtktest=no fi if $PKG_CONFIG $pkg_config_args; then : else no_gtk=yes fi fi if test x"$no_gtk" = x ; then GTK_CFLAGS=`$PKG_CONFIG $pkg_config_args --cflags` GTK_LIBS=`$PKG_CONFIG $pkg_config_args --libs` gtk_config_major_version=`$PKG_CONFIG --modversion gtk+-3.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'` gtk_config_minor_version=`$PKG_CONFIG --modversion gtk+-3.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'` gtk_config_micro_version=`$PKG_CONFIG --modversion gtk+-3.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'` if test "x$enable_gtktest" = "xyes" ; then ac_save_CFLAGS="$CFLAGS" ac_save_LIBS="$LIBS" CFLAGS="$CFLAGS $GTK_CFLAGS" LIBS="$GTK_LIBS $LIBS" dnl dnl Now check if the installed GTK+ is sufficiently new. (Also sanity dnl checks the results of pkg-config to some extent) dnl rm -f conf.gtktest AC_TRY_RUN([ #include #include #include int main () { unsigned int major, minor, micro; fclose (fopen ("conf.gtktest", "w")); if (sscanf("$min_gtk_version", "%u.%u.%u", &major, &minor, µ) != 3) { printf("%s, bad version string\n", "$min_gtk_version"); exit(1); } if ((gtk_major_version != $gtk_config_major_version) || (gtk_minor_version != $gtk_config_minor_version) || (gtk_micro_version != $gtk_config_micro_version)) { printf("\n*** 'pkg-config --modversion gtk+-3.0' returned %d.%d.%d, but GTK+ (%d.%d.%d)\n", $gtk_config_major_version, $gtk_config_minor_version, $gtk_config_micro_version, gtk_major_version, gtk_minor_version, gtk_micro_version); printf ("*** was found! If pkg-config was correct, then it is best\n"); printf ("*** to remove the old version of GTK+. You may also be able to fix the error\n"); printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n"); printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n"); printf("*** required on your system.\n"); printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n"); printf("*** to point to the correct configuration files\n"); } else if ((gtk_major_version != GTK_MAJOR_VERSION) || (gtk_minor_version != GTK_MINOR_VERSION) || (gtk_micro_version != GTK_MICRO_VERSION)) { printf("*** GTK+ header files (version %d.%d.%d) do not match\n", GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION); printf("*** library (version %d.%d.%d)\n", gtk_major_version, gtk_minor_version, gtk_micro_version); } else { if ((gtk_major_version > major) || ((gtk_major_version == major) && (gtk_minor_version > minor)) || ((gtk_major_version == major) && (gtk_minor_version == minor) && (gtk_micro_version >= micro))) { return 0; } else { printf("\n*** An old version of GTK+ (%u.%u.%u) was found.\n", gtk_major_version, gtk_minor_version, gtk_micro_version); printf("*** You need a version of GTK+ newer than %u.%u.%u. The latest version of\n", major, minor, micro); printf("*** GTK+ is always available from ftp://ftp.gtk.org.\n"); printf("***\n"); printf("*** If you have already installed a sufficiently new version, this error\n"); printf("*** probably means that the wrong copy of the pkg-config shell script is\n"); printf("*** being found. The easiest way to fix this is to remove the old version\n"); printf("*** of GTK+, but you can also set the PKG_CONFIG environment to point to the\n"); printf("*** correct copy of pkg-config. (In this case, you will have to\n"); printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n"); printf("*** so that the correct libraries are found at run-time))\n"); } } return 1; } ],, no_gtk=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi if test "x$no_gtk" = x ; then AC_MSG_RESULT(yes (version $gtk_config_major_version.$gtk_config_minor_version.$gtk_config_micro_version)) ifelse([$2], , :, [$2]) else AC_MSG_RESULT(no) if test "$PKG_CONFIG" = "no" ; then echo "*** A new enough version of pkg-config was not found." echo "*** See http://pkgconfig.sourceforge.net" else if test -f conf.gtktest ; then : else echo "*** Could not run GTK+ test program, checking why..." ac_save_CFLAGS="$CFLAGS" ac_save_LIBS="$LIBS" CFLAGS="$CFLAGS $GTK_CFLAGS" LIBS="$LIBS $GTK_LIBS" AC_TRY_LINK([ #include #include ], [ return ((gtk_major_version) || (gtk_minor_version) || (gtk_micro_version)); ], [ echo "*** The test program compiled, but did not run. This usually means" echo "*** that the run-time linker is not finding GTK+ or finding the wrong" echo "*** version of GTK+. If it is not finding GTK+, you'll need to set your" echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" echo "*** to the installed location Also, make sure you have run ldconfig if that" echo "*** is required on your system" echo "***" echo "*** If you have an old version installed, it is best to remove it, although" echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" ], [ echo "*** The test program failed to compile or link. See the file config.log for the" echo "*** exact error that occurred. This usually means GTK+ is incorrectly installed."]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi GTK_CFLAGS="" GTK_LIBS="" ifelse([$3], , :, [$3]) fi AC_SUBST(GTK_CFLAGS) AC_SUBST(GTK_LIBS) rm -f conf.gtktest ]) dnl GTK_CHECK_BACKEND(BACKEND-NAME [, MINIMUM-VERSION [, ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]]) dnl Tests for BACKEND-NAME in the GTK targets list dnl AC_DEFUN([GTK_CHECK_BACKEND], [m4_warn([obsolete], [GTK_CHECK_BACKEND is deprecated, use PKG_CHECK_MODULES([GTK_X11], [gtk+-x11-3.0]) or similar instead]) pkg_config_args=ifelse([$1],,gtk+-3.0, gtk+-$1-3.0) min_gtk_version=ifelse([$2],,3.0.0,$2) pkg_config_args="$pkg_config_args >= $min_gtk_version" AC_PATH_TOOL([PKG_CONFIG], [pkg-config], [AC_MSG_ERROR([No pkg-config found])]) if $PKG_CONFIG $pkg_config_args ; then target_found=yes else target_found=no fi if test "x$target_found" = "xno"; then ifelse([$4],,[AC_MSG_ERROR([Backend $backend not found.])],[$4]) else ifelse([$3],,[:],[$3]) fi ]) ngraph-gtk-6.08.00/m4/size_max.m40000644000175000017500000000577013070106167013263 00000000000000# size_max.m4 serial 10 dnl Copyright (C) 2003, 2005-2006, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([gl_SIZE_MAX], [ AC_CHECK_HEADERS([stdint.h]) dnl First test whether the system already has SIZE_MAX. AC_CACHE_CHECK([for SIZE_MAX], [gl_cv_size_max], [ gl_cv_size_max= AC_EGREP_CPP([Found it], [ #include #if HAVE_STDINT_H #include #endif #ifdef SIZE_MAX Found it #endif ], [gl_cv_size_max=yes]) if test -z "$gl_cv_size_max"; then dnl Define it ourselves. Here we assume that the type 'size_t' is not wider dnl than the type 'unsigned long'. Try hard to find a definition that can dnl be used in a preprocessor #if, i.e. doesn't contain a cast. AC_COMPUTE_INT([size_t_bits_minus_1], [sizeof (size_t) * CHAR_BIT - 1], [#include #include ], [size_t_bits_minus_1=]) AC_COMPUTE_INT([fits_in_uint], [sizeof (size_t) <= sizeof (unsigned int)], [#include ], [fits_in_uint=]) if test -n "$size_t_bits_minus_1" && test -n "$fits_in_uint"; then if test $fits_in_uint = 1; then dnl Even though SIZE_MAX fits in an unsigned int, it must be of type dnl 'unsigned long' if the type 'size_t' is the same as 'unsigned long'. AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[#include extern size_t foo; extern unsigned long foo; ]], [[]])], [fits_in_uint=0]) fi dnl We cannot use 'expr' to simplify this expression, because 'expr' dnl works only with 'long' integers in the host environment, while we dnl might be cross-compiling from a 32-bit platform to a 64-bit platform. if test $fits_in_uint = 1; then gl_cv_size_max="(((1U << $size_t_bits_minus_1) - 1) * 2 + 1)" else gl_cv_size_max="(((1UL << $size_t_bits_minus_1) - 1) * 2 + 1)" fi else dnl Shouldn't happen, but who knows... gl_cv_size_max='((size_t)~(size_t)0)' fi fi ]) if test "$gl_cv_size_max" != yes; then AC_DEFINE_UNQUOTED([SIZE_MAX], [$gl_cv_size_max], [Define as the maximum value of type 'size_t', if the system doesn't define it.]) fi dnl Don't redefine SIZE_MAX in config.h if config.h is re-included after dnl . Remember that the #undef in AH_VERBATIM gets replaced with dnl #define by AC_DEFINE_UNQUOTED. AH_VERBATIM([SIZE_MAX], [/* Define as the maximum value of type 'size_t', if the system doesn't define it. */ #ifndef SIZE_MAX # undef SIZE_MAX #endif]) ]) dnl Autoconf >= 2.61 has AC_COMPUTE_INT built-in. dnl Remove this when we can assume autoconf >= 2.61. m4_ifdef([AC_COMPUTE_INT], [], [ AC_DEFUN([AC_COMPUTE_INT], [_AC_COMPUTE_INT([$2],[$1],[$3],[$4])]) ]) ngraph-gtk-6.08.00/m4/glibc2.m40000644000175000017500000000147613070106167012605 00000000000000# glibc2.m4 serial 3 dnl Copyright (C) 2000-2002, 2004, 2008, 2010-2016 Free Software Foundation, dnl Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. # Test for the GNU C Library, version 2.0 or newer. # From Bruno Haible. AC_DEFUN([gt_GLIBC2], [ AC_CACHE_CHECK([whether we are using the GNU C Library 2 or newer], [ac_cv_gnu_library_2], [AC_EGREP_CPP([Lucky GNU user], [ #include #ifdef __GNU_LIBRARY__ #if (__GLIBC__ >= 2) && !defined __UCLIBC__ Lucky GNU user #endif #endif ], [ac_cv_gnu_library_2=yes], [ac_cv_gnu_library_2=no]) ] ) AC_SUBST([GLIBC2]) GLIBC2="$ac_cv_gnu_library_2" ] ) ngraph-gtk-6.08.00/m4/progtest.m40000644000175000017500000000602413070106167013304 00000000000000# progtest.m4 serial 7 (gettext-0.18.2) dnl Copyright (C) 1996-2003, 2005, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1996. AC_PREREQ([2.50]) # Search path for a program which passes the given test. dnl AM_PATH_PROG_WITH_TEST(VARIABLE, PROG-TO-CHECK-FOR, dnl TEST-PERFORMED-ON-FOUND_PROGRAM [, VALUE-IF-NOT-FOUND [, PATH]]) AC_DEFUN([AM_PATH_PROG_WITH_TEST], [ # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. 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 # Find out how to test for executable files. Don't use a zero-byte file, # as systems may use methods other than mode bits to determine executability. cat >conf$$.file <<_ASEOF #! /bin/sh exit 0 _ASEOF chmod +x conf$$.file if test -x conf$$.file >/dev/null 2>&1; then ac_executable_p="test -x" else ac_executable_p="test -f" fi rm -f conf$$.file # Extract the first word of "$2", so it can be a program name with args. set dummy $2; ac_word=[$]2 AC_MSG_CHECKING([for $ac_word]) AC_CACHE_VAL([ac_cv_path_$1], [case "[$]$1" in [[\\/]]* | ?:[[\\/]]*) ac_cv_path_$1="[$]$1" # Let the user override the test with a path. ;; *) ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in ifelse([$5], , $PATH, [$5]); do IFS="$ac_save_IFS" test -z "$ac_dir" && ac_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then echo "$as_me: trying $ac_dir/$ac_word..." >&AS_MESSAGE_LOG_FD if [$3]; then ac_cv_path_$1="$ac_dir/$ac_word$ac_exec_ext" break 2 fi fi done done IFS="$ac_save_IFS" dnl If no 4th arg is given, leave the cache variable unset, dnl so AC_PATH_PROGS will keep looking. ifelse([$4], , , [ test -z "[$]ac_cv_path_$1" && ac_cv_path_$1="$4" ])dnl ;; esac])dnl $1="$ac_cv_path_$1" if test ifelse([$4], , [-n "[$]$1"], ["[$]$1" != "$4"]); then AC_MSG_RESULT([$][$1]) else AC_MSG_RESULT([no]) fi AC_SUBST([$1])dnl ]) ngraph-gtk-6.08.00/m4/ltsugar.m40000644000175000017500000001044013342745520013117 00000000000000# 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 ]) ngraph-gtk-6.08.00/m4/intlmacosx.m40000644000175000017500000000474513070106167013626 00000000000000# intlmacosx.m4 serial 5 (gettext-0.18.2) dnl Copyright (C) 2004-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Checks for special options needed on Mac OS X. dnl Defines INTL_MACOSX_LIBS. AC_DEFUN([gt_INTL_MACOSX], [ dnl Check for API introduced in Mac OS X 10.2. AC_CACHE_CHECK([for CFPreferencesCopyAppValue], [gt_cv_func_CFPreferencesCopyAppValue], [gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[CFPreferencesCopyAppValue(NULL, NULL)]])], [gt_cv_func_CFPreferencesCopyAppValue=yes], [gt_cv_func_CFPreferencesCopyAppValue=no]) LIBS="$gt_save_LIBS"]) if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then AC_DEFINE([HAVE_CFPREFERENCESCOPYAPPVALUE], [1], [Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework.]) fi dnl Check for API introduced in Mac OS X 10.3. AC_CACHE_CHECK([for CFLocaleCopyCurrent], [gt_cv_func_CFLocaleCopyCurrent], [gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[CFLocaleCopyCurrent();]])], [gt_cv_func_CFLocaleCopyCurrent=yes], [gt_cv_func_CFLocaleCopyCurrent=no]) LIBS="$gt_save_LIBS"]) if test $gt_cv_func_CFLocaleCopyCurrent = yes; then AC_DEFINE([HAVE_CFLOCALECOPYCURRENT], [1], [Define to 1 if you have the Mac OS X function CFLocaleCopyCurrent in the CoreFoundation framework.]) fi INTL_MACOSX_LIBS= if test $gt_cv_func_CFPreferencesCopyAppValue = yes || test $gt_cv_func_CFLocaleCopyCurrent = yes; then INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" fi AC_SUBST([INTL_MACOSX_LIBS]) ]) ngraph-gtk-6.08.00/m4/intdiv0.m40000644000175000017500000000455313070106167013017 00000000000000# intdiv0.m4 serial 6 (gettext-0.18.2) dnl Copyright (C) 2002, 2007-2008, 2010-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([gt_INTDIV0], [ AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_CACHE_CHECK([whether integer division by zero raises SIGFPE], gt_cv_int_divbyzero_sigfpe, [ gt_cv_int_divbyzero_sigfpe= changequote(,)dnl case "$host_os" in macos* | darwin[6-9]* | darwin[1-9][0-9]*) # On Mac OS X 10.2 or newer, just assume the same as when cross- # compiling. If we were to perform the real test, 1 Crash Report # dialog window would pop up. case "$host_cpu" in i[34567]86 | x86_64) gt_cv_int_divbyzero_sigfpe="guessing yes" ;; esac ;; esac changequote([,])dnl if test -z "$gt_cv_int_divbyzero_sigfpe"; then AC_RUN_IFELSE( [AC_LANG_SOURCE([[ #include #include static void sigfpe_handler (int sig) { /* Exit with code 0 if SIGFPE, with code 1 if any other signal. */ _exit (sig != SIGFPE); } int x = 1; int y = 0; int z; int nan; int main () { signal (SIGFPE, sigfpe_handler); /* IRIX and AIX (when "xlc -qcheck" is used) yield signal SIGTRAP. */ #if (defined (__sgi) || defined (_AIX)) && defined (SIGTRAP) signal (SIGTRAP, sigfpe_handler); #endif /* Linux/SPARC yields signal SIGILL. */ #if defined (__sparc__) && defined (__linux__) signal (SIGILL, sigfpe_handler); #endif z = x / y; nan = y / y; exit (2); } ]])], [gt_cv_int_divbyzero_sigfpe=yes], [gt_cv_int_divbyzero_sigfpe=no], [ # Guess based on the CPU. changequote(,)dnl case "$host_cpu" in alpha* | i[34567]86 | x86_64 | m68k | s390*) gt_cv_int_divbyzero_sigfpe="guessing yes";; *) gt_cv_int_divbyzero_sigfpe="guessing no";; esac changequote([,])dnl ]) fi ]) case "$gt_cv_int_divbyzero_sigfpe" in *yes) value=1;; *) value=0;; esac AC_DEFINE_UNQUOTED([INTDIV0_RAISES_SIGFPE], [$value], [Define if integer division by zero raises signal SIGFPE.]) ]) ngraph-gtk-6.08.00/m4/uintmax_t.m40000644000175000017500000000213113070106167013440 00000000000000# uintmax_t.m4 serial 12 dnl Copyright (C) 1997-2004, 2007-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Paul Eggert. AC_PREREQ([2.13]) # Define uintmax_t to 'unsigned long' or 'unsigned long long' # if it is not already defined in or . AC_DEFUN([gl_AC_TYPE_UINTMAX_T], [ AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) AC_REQUIRE([gl_AC_HEADER_STDINT_H]) if test $gl_cv_header_inttypes_h = no && test $gl_cv_header_stdint_h = no; then AC_REQUIRE([AC_TYPE_UNSIGNED_LONG_LONG_INT]) test $ac_cv_type_unsigned_long_long_int = yes \ && ac_type='unsigned long long' \ || ac_type='unsigned long' AC_DEFINE_UNQUOTED([uintmax_t], [$ac_type], [Define to unsigned long or unsigned long long if and don't define.]) else AC_DEFINE([HAVE_UINTMAX_T], [1], [Define if you have the 'uintmax_t' type in or .]) fi ]) ngraph-gtk-6.08.00/m4/nls.m40000644000175000017500000000230713070106167012231 00000000000000# nls.m4 serial 5 (gettext-0.18) dnl Copyright (C) 1995-2003, 2005-2006, 2008-2014, 2016 Free Software dnl Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2003. AC_PREREQ([2.50]) AC_DEFUN([AM_NLS], [ AC_MSG_CHECKING([whether NLS is requested]) dnl Default is enabled NLS AC_ARG_ENABLE([nls], [ --disable-nls do not use Native Language Support], USE_NLS=$enableval, USE_NLS=yes) AC_MSG_RESULT([$USE_NLS]) AC_SUBST([USE_NLS]) ]) ngraph-gtk-6.08.00/m4/wint_t.m40000644000175000017500000000203513070106167012737 00000000000000# wint_t.m4 serial 5 (gettext-0.18.2) dnl Copyright (C) 2003, 2007-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Test whether has the 'wint_t' type. dnl Prerequisite: AC_PROG_CC AC_DEFUN([gt_TYPE_WINT_T], [ AC_CACHE_CHECK([for wint_t], [gt_cv_c_wint_t], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ /* Tru64 with Desktop Toolkit C has a bug: must be included before . BSD/OS 4.0.1 has a bug: , and must be included before . */ #include #include #include #include wint_t foo = (wchar_t)'\0';]], [[]])], [gt_cv_c_wint_t=yes], [gt_cv_c_wint_t=no])]) if test $gt_cv_c_wint_t = yes; then AC_DEFINE([HAVE_WINT_T], [1], [Define if you have the 'wint_t' type.]) fi ]) ngraph-gtk-6.08.00/m4/Makefile.am0000644000175000017500000000071113314701637013230 00000000000000EXTRA_DIST = codeset.m4 gettext.m4 glibc2.m4 glibc21.m4 gsl.m4 \ glib-2.0.m4 gtk-3.0.m4 iconv.m4 intdiv0.m4 intl.m4 intldir.m4 \ intlmacosx.m4 intmax.m4 inttypes-pri.m4 inttypes_h.m4 \ lcmessage.m4 lib-ld.m4 lib-link.m4 lib-prefix.m4 libtool.m4 \ lock.m4 longlong.m4 ltoptions.m4 ltsugar.m4 ltversion.m4 \ lt~obsolete.m4 nls.m4 po.m4 printf-posix.m4 progtest.m4 \ size_max.m4 stdint_h.m4 uintmax_t.m4 visibility.m4 wchar_t.m4 \ wint_t.m4 xsize.m4 ngraph-gtk-6.08.00/m4/printf-posix.m40000644000175000017500000000305313070106167014076 00000000000000# printf-posix.m4 serial 6 (gettext-0.18.2) dnl Copyright (C) 2003, 2007, 2009-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Test whether the printf() function supports POSIX/XSI format strings with dnl positions. AC_DEFUN([gt_PRINTF_POSIX], [ AC_REQUIRE([AC_PROG_CC]) AC_CACHE_CHECK([whether printf() supports POSIX/XSI format strings], gt_cv_func_printf_posix, [ AC_RUN_IFELSE( [AC_LANG_SOURCE([[ #include #include /* The string "%2$d %1$d", with dollar characters protected from the shell's dollar expansion (possibly an autoconf bug). */ static char format[] = { '%', '2', '$', 'd', ' ', '%', '1', '$', 'd', '\0' }; static char buf[100]; int main () { sprintf (buf, format, 33, 55); return (strcmp (buf, "55 33") != 0); }]])], [gt_cv_func_printf_posix=yes], [gt_cv_func_printf_posix=no], [ AC_EGREP_CPP([notposix], [ #if defined __NetBSD__ || defined __BEOS__ || defined _MSC_VER || defined __MINGW32__ || defined __CYGWIN__ notposix #endif ], [gt_cv_func_printf_posix="guessing no"], [gt_cv_func_printf_posix="guessing yes"]) ]) ]) case $gt_cv_func_printf_posix in *yes) AC_DEFINE([HAVE_POSIX_PRINTF], [1], [Define if your printf() function supports format strings with positions.]) ;; esac ]) ngraph-gtk-6.08.00/m4/longlong.m40000644000175000017500000001120313070106167013247 00000000000000# longlong.m4 serial 17 dnl Copyright (C) 1999-2007, 2009-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Paul Eggert. # Define HAVE_LONG_LONG_INT if 'long long int' works. # This fixes a bug in Autoconf 2.61, and can be faster # than what's in Autoconf 2.62 through 2.68. # Note: If the type 'long long int' exists but is only 32 bits large # (as on some very old compilers), HAVE_LONG_LONG_INT will not be # defined. In this case you can treat 'long long int' like 'long int'. AC_DEFUN([AC_TYPE_LONG_LONG_INT], [ AC_REQUIRE([AC_TYPE_UNSIGNED_LONG_LONG_INT]) AC_CACHE_CHECK([for long long int], [ac_cv_type_long_long_int], [ac_cv_type_long_long_int=yes if test "x${ac_cv_prog_cc_c99-no}" = xno; then ac_cv_type_long_long_int=$ac_cv_type_unsigned_long_long_int if test $ac_cv_type_long_long_int = yes; then dnl Catch a bug in Tandem NonStop Kernel (OSS) cc -O circa 2004. dnl If cross compiling, assume the bug is not important, since dnl nobody cross compiles for this platform as far as we know. AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[@%:@include @%:@ifndef LLONG_MAX @%:@ define HALF \ (1LL << (sizeof (long long int) * CHAR_BIT - 2)) @%:@ define LLONG_MAX (HALF - 1 + HALF) @%:@endif]], [[long long int n = 1; int i; for (i = 0; ; i++) { long long int m = n << i; if (m >> i != n) return 1; if (LLONG_MAX / 2 < m) break; } return 0;]])], [], [ac_cv_type_long_long_int=no], [:]) fi fi]) if test $ac_cv_type_long_long_int = yes; then AC_DEFINE([HAVE_LONG_LONG_INT], [1], [Define to 1 if the system has the type 'long long int'.]) fi ]) # Define HAVE_UNSIGNED_LONG_LONG_INT if 'unsigned long long int' works. # This fixes a bug in Autoconf 2.61, and can be faster # than what's in Autoconf 2.62 through 2.68. # Note: If the type 'unsigned long long int' exists but is only 32 bits # large (as on some very old compilers), AC_TYPE_UNSIGNED_LONG_LONG_INT # will not be defined. In this case you can treat 'unsigned long long int' # like 'unsigned long int'. AC_DEFUN([AC_TYPE_UNSIGNED_LONG_LONG_INT], [ AC_CACHE_CHECK([for unsigned long long int], [ac_cv_type_unsigned_long_long_int], [ac_cv_type_unsigned_long_long_int=yes if test "x${ac_cv_prog_cc_c99-no}" = xno; then AC_LINK_IFELSE( [_AC_TYPE_LONG_LONG_SNIPPET], [], [ac_cv_type_unsigned_long_long_int=no]) fi]) if test $ac_cv_type_unsigned_long_long_int = yes; then AC_DEFINE([HAVE_UNSIGNED_LONG_LONG_INT], [1], [Define to 1 if the system has the type 'unsigned long long int'.]) fi ]) # Expands to a C program that can be used to test for simultaneous support # of 'long long' and 'unsigned long long'. We don't want to say that # 'long long' is available if 'unsigned long long' is not, or vice versa, # because too many programs rely on the symmetry between signed and unsigned # integer types (excluding 'bool'). AC_DEFUN([_AC_TYPE_LONG_LONG_SNIPPET], [ AC_LANG_PROGRAM( [[/* For now, do not test the preprocessor; as of 2007 there are too many implementations with broken preprocessors. Perhaps this can be revisited in 2012. In the meantime, code should not expect #if to work with literals wider than 32 bits. */ /* Test literals. */ long long int ll = 9223372036854775807ll; long long int nll = -9223372036854775807LL; unsigned long long int ull = 18446744073709551615ULL; /* Test constant expressions. */ typedef int a[((-9223372036854775807LL < 0 && 0 < 9223372036854775807ll) ? 1 : -1)]; typedef int b[(18446744073709551615ULL <= (unsigned long long int) -1 ? 1 : -1)]; int i = 63;]], [[/* Test availability of runtime routines for shift and division. */ long long int llmax = 9223372036854775807ll; unsigned long long int ullmax = 18446744073709551615ull; return ((ll << 63) | (ll >> 63) | (ll < i) | (ll > i) | (llmax / ll) | (llmax % ll) | (ull << 63) | (ull >> 63) | (ull << i) | (ull >> i) | (ullmax / ull) | (ullmax % ull));]]) ]) ngraph-gtk-6.08.00/m4/glib-2.0.m40000644000175000017500000002017013314701637012651 00000000000000# Configure paths for GLIB # Owen Taylor 1997-2001 # Increment this whenever this file is changed. #serial 1 dnl AM_PATH_GLIB_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]]) dnl Test for GLIB, and define GLIB_CFLAGS and GLIB_LIBS, if gmodule, gobject, dnl gthread, or gio is specified in MODULES, pass to pkg-config dnl AC_DEFUN([AM_PATH_GLIB_2_0], [dnl dnl Get the cflags and libraries from pkg-config dnl AC_ARG_ENABLE(glibtest, [ --disable-glibtest do not try to compile and run a test GLIB program], , enable_glibtest=yes) pkg_config_args=glib-2.0 for module in . $4 do case "$module" in gmodule) pkg_config_args="$pkg_config_args gmodule-2.0" ;; gmodule-no-export) pkg_config_args="$pkg_config_args gmodule-no-export-2.0" ;; gobject) pkg_config_args="$pkg_config_args gobject-2.0" ;; gthread) pkg_config_args="$pkg_config_args gthread-2.0" ;; gio*) pkg_config_args="$pkg_config_args $module-2.0" ;; esac done PKG_PROG_PKG_CONFIG([0.16]) no_glib="" if test "x$PKG_CONFIG" = x ; then no_glib=yes PKG_CONFIG=no fi min_glib_version=ifelse([$1], ,2.0.0,$1) AC_MSG_CHECKING(for GLIB - version >= $min_glib_version) if test x$PKG_CONFIG != xno ; then ## don't try to run the test against uninstalled libtool libs if $PKG_CONFIG --uninstalled $pkg_config_args; then echo "Will use uninstalled version of GLib found in PKG_CONFIG_PATH" enable_glibtest=no fi if $PKG_CONFIG --atleast-version $min_glib_version $pkg_config_args; then : else no_glib=yes fi fi if test x"$no_glib" = x ; then GLIB_GENMARSHAL=`$PKG_CONFIG --variable=glib_genmarshal glib-2.0` GOBJECT_QUERY=`$PKG_CONFIG --variable=gobject_query glib-2.0` GLIB_MKENUMS=`$PKG_CONFIG --variable=glib_mkenums glib-2.0` GLIB_COMPILE_RESOURCES=`$PKG_CONFIG --variable=glib_compile_resources gio-2.0` GLIB_CFLAGS=`$PKG_CONFIG --cflags $pkg_config_args` GLIB_LIBS=`$PKG_CONFIG --libs $pkg_config_args` glib_config_major_version=`$PKG_CONFIG --modversion glib-2.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'` glib_config_minor_version=`$PKG_CONFIG --modversion glib-2.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'` glib_config_micro_version=`$PKG_CONFIG --modversion glib-2.0 | \ sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'` if test "x$enable_glibtest" = "xyes" ; then ac_save_CFLAGS="$CFLAGS" ac_save_LIBS="$LIBS" CFLAGS="$CFLAGS $GLIB_CFLAGS" LIBS="$GLIB_LIBS $LIBS" dnl dnl Now check if the installed GLIB is sufficiently new. (Also sanity dnl checks the results of pkg-config to some extent) dnl rm -f conf.glibtest AC_TRY_RUN([ #include #include #include int main (void) { unsigned int major, minor, micro; fclose (fopen ("conf.glibtest", "w")); if (sscanf("$min_glib_version", "%u.%u.%u", &major, &minor, µ) != 3) { printf("%s, bad version string\n", "$min_glib_version"); exit(1); } if ((glib_major_version != $glib_config_major_version) || (glib_minor_version != $glib_config_minor_version) || (glib_micro_version != $glib_config_micro_version)) { printf("\n*** 'pkg-config --modversion glib-2.0' returned %d.%d.%d, but GLIB (%d.%d.%d)\n", $glib_config_major_version, $glib_config_minor_version, $glib_config_micro_version, glib_major_version, glib_minor_version, glib_micro_version); printf ("*** was found! If pkg-config was correct, then it is best\n"); printf ("*** to remove the old version of GLib. You may also be able to fix the error\n"); printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n"); printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n"); printf("*** required on your system.\n"); printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n"); printf("*** to point to the correct configuration files\n"); } else if ((glib_major_version != GLIB_MAJOR_VERSION) || (glib_minor_version != GLIB_MINOR_VERSION) || (glib_micro_version != GLIB_MICRO_VERSION)) { printf("*** GLIB header files (version %d.%d.%d) do not match\n", GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION); printf("*** library (version %d.%d.%d)\n", glib_major_version, glib_minor_version, glib_micro_version); } else { if ((glib_major_version > major) || ((glib_major_version == major) && (glib_minor_version > minor)) || ((glib_major_version == major) && (glib_minor_version == minor) && (glib_micro_version >= micro))) { return 0; } else { printf("\n*** An old version of GLIB (%u.%u.%u) was found.\n", glib_major_version, glib_minor_version, glib_micro_version); printf("*** You need a version of GLIB newer than %u.%u.%u. The latest version of\n", major, minor, micro); printf("*** GLIB is always available from ftp://ftp.gtk.org.\n"); printf("***\n"); printf("*** If you have already installed a sufficiently new version, this error\n"); printf("*** probably means that the wrong copy of the pkg-config shell script is\n"); printf("*** being found. The easiest way to fix this is to remove the old version\n"); printf("*** of GLIB, but you can also set the PKG_CONFIG environment to point to the\n"); printf("*** correct copy of pkg-config. (In this case, you will have to\n"); printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n"); printf("*** so that the correct libraries are found at run-time))\n"); } } return 1; } ],, no_glib=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi if test "x$no_glib" = x ; then AC_MSG_RESULT(yes (version $glib_config_major_version.$glib_config_minor_version.$glib_config_micro_version)) ifelse([$2], , :, [$2]) else AC_MSG_RESULT(no) if test "$PKG_CONFIG" = "no" ; then echo "*** A new enough version of pkg-config was not found." echo "*** See http://www.freedesktop.org/software/pkgconfig/" else if test -f conf.glibtest ; then : else echo "*** Could not run GLIB test program, checking why..." ac_save_CFLAGS="$CFLAGS" ac_save_LIBS="$LIBS" CFLAGS="$CFLAGS $GLIB_CFLAGS" LIBS="$LIBS $GLIB_LIBS" AC_TRY_LINK([ #include #include ], [ return ((glib_major_version) || (glib_minor_version) || (glib_micro_version)); ], [ echo "*** The test program compiled, but did not run. This usually means" echo "*** that the run-time linker is not finding GLIB or finding the wrong" echo "*** version of GLIB. If it is not finding GLIB, you'll need to set your" echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" echo "*** to the installed location Also, make sure you have run ldconfig if that" echo "*** is required on your system" echo "***" echo "*** If you have an old version installed, it is best to remove it, although" echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" ], [ echo "*** The test program failed to compile or link. See the file config.log for the" echo "*** exact error that occured. This usually means GLIB is incorrectly installed."]) CFLAGS="$ac_save_CFLAGS" LIBS="$ac_save_LIBS" fi fi GLIB_CFLAGS="" GLIB_LIBS="" GLIB_GENMARSHAL="" GOBJECT_QUERY="" GLIB_MKENUMS="" GLIB_COMPILE_RESOURCES="" ifelse([$3], , :, [$3]) fi AC_SUBST(GLIB_CFLAGS) AC_SUBST(GLIB_LIBS) AC_SUBST(GLIB_GENMARSHAL) AC_SUBST(GOBJECT_QUERY) AC_SUBST(GLIB_MKENUMS) AC_SUBST(GLIB_COMPILE_RESOURCES) rm -f conf.glibtest ]) ngraph-gtk-6.08.00/m4/lib-prefix.m40000644000175000017500000002042213070106167013474 00000000000000# lib-prefix.m4 serial 7 (gettext-0.18) dnl Copyright (C) 2001-2005, 2008-2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl AC_LIB_ARG_WITH is synonymous to AC_ARG_WITH in autoconf-2.13, and dnl similar to AC_ARG_WITH in autoconf 2.52...2.57 except that is doesn't dnl require excessive bracketing. ifdef([AC_HELP_STRING], [AC_DEFUN([AC_LIB_ARG_WITH], [AC_ARG_WITH([$1],[[$2]],[$3],[$4])])], [AC_DEFUN([AC_][LIB_ARG_WITH], [AC_ARG_WITH([$1],[$2],[$3],[$4])])]) dnl AC_LIB_PREFIX adds to the CPPFLAGS and LDFLAGS the flags that are needed dnl to access previously installed libraries. The basic assumption is that dnl a user will want packages to use other packages he previously installed dnl with the same --prefix option. dnl This macro is not needed if only AC_LIB_LINKFLAGS is used to locate dnl libraries, but is otherwise very convenient. AC_DEFUN([AC_LIB_PREFIX], [ AC_BEFORE([$0], [AC_LIB_LINKFLAGS]) AC_REQUIRE([AC_PROG_CC]) AC_REQUIRE([AC_CANONICAL_HOST]) AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) dnl By default, look in $includedir and $libdir. use_additional=yes AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) AC_LIB_ARG_WITH([lib-prefix], [ --with-lib-prefix[=DIR] search for libraries in DIR/include and DIR/lib --without-lib-prefix don't search for libraries in includedir and libdir], [ if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" fi fi ]) if test $use_additional = yes; then dnl Potentially add $additional_includedir to $CPPFLAGS. dnl But don't add it dnl 1. if it's the standard /usr/include, dnl 2. if it's already present in $CPPFLAGS, dnl 3. if it's /usr/local/include and we are using GCC on Linux, dnl 4. if it doesn't exist as a directory. if test "X$additional_includedir" != "X/usr/include"; then haveit= for x in $CPPFLAGS; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then if test -d "$additional_includedir"; then dnl Really add $additional_includedir to $CPPFLAGS. CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-I$additional_includedir" fi fi fi fi dnl Potentially add $additional_libdir to $LDFLAGS. dnl But don't add it dnl 1. if it's the standard /usr/lib, dnl 2. if it's already present in $LDFLAGS, dnl 3. if it's /usr/local/lib and we are using GCC on Linux, dnl 4. if it doesn't exist as a directory. if test "X$additional_libdir" != "X/usr/$acl_libdirstem"; then haveit= for x in $LDFLAGS; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$additional_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem"; then if test -n "$GCC"; then case $host_os in linux*) haveit=yes;; esac fi fi if test -z "$haveit"; then if test -d "$additional_libdir"; then dnl Really add $additional_libdir to $LDFLAGS. LDFLAGS="${LDFLAGS}${LDFLAGS:+ }-L$additional_libdir" fi fi fi fi fi ]) dnl AC_LIB_PREPARE_PREFIX creates variables acl_final_prefix, dnl acl_final_exec_prefix, containing the values to which $prefix and dnl $exec_prefix will expand at the end of the configure script. AC_DEFUN([AC_LIB_PREPARE_PREFIX], [ dnl Unfortunately, prefix and exec_prefix get only finally determined dnl at the end of configure. if test "X$prefix" = "XNONE"; then acl_final_prefix="$ac_default_prefix" else acl_final_prefix="$prefix" fi if test "X$exec_prefix" = "XNONE"; then acl_final_exec_prefix='${prefix}' else acl_final_exec_prefix="$exec_prefix" fi acl_save_prefix="$prefix" prefix="$acl_final_prefix" eval acl_final_exec_prefix=\"$acl_final_exec_prefix\" prefix="$acl_save_prefix" ]) dnl AC_LIB_WITH_FINAL_PREFIX([statement]) evaluates statement, with the dnl variables prefix and exec_prefix bound to the values they will have dnl at the end of the configure script. AC_DEFUN([AC_LIB_WITH_FINAL_PREFIX], [ acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" $1 exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" ]) dnl AC_LIB_PREPARE_MULTILIB creates dnl - a variable acl_libdirstem, containing the basename of the libdir, either dnl "lib" or "lib64" or "lib/64", dnl - a variable acl_libdirstem2, as a secondary possible value for dnl acl_libdirstem, either the same as acl_libdirstem or "lib/sparcv9" or dnl "lib/amd64". AC_DEFUN([AC_LIB_PREPARE_MULTILIB], [ dnl There is no formal standard regarding lib and lib64. dnl On glibc systems, the current practice is that on a system supporting dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under dnl $prefix/lib64 and 32-bit libraries go under $prefix/lib. We determine dnl the compiler's default mode by looking at the compiler's library search dnl path. If at least one of its elements ends in /lib64 or points to a dnl directory whose absolute pathname ends in /lib64, we assume a 64-bit ABI. dnl Otherwise we use the default, namely "lib". dnl On Solaris systems, the current practice is that on a system supporting dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under dnl $prefix/lib/64 (which is a symlink to either $prefix/lib/sparcv9 or dnl $prefix/lib/amd64) and 32-bit libraries go under $prefix/lib. AC_REQUIRE([AC_CANONICAL_HOST]) acl_libdirstem=lib acl_libdirstem2= case "$host_os" in solaris*) dnl See Solaris 10 Software Developer Collection > Solaris 64-bit Developer's Guide > The Development Environment dnl . dnl "Portable Makefiles should refer to any library directories using the 64 symbolic link." dnl But we want to recognize the sparcv9 or amd64 subdirectory also if the dnl symlink is missing, so we set acl_libdirstem2 too. AC_CACHE_CHECK([for 64-bit host], [gl_cv_solaris_64bit], [AC_EGREP_CPP([sixtyfour bits], [ #ifdef _LP64 sixtyfour bits #endif ], [gl_cv_solaris_64bit=yes], [gl_cv_solaris_64bit=no]) ]) if test $gl_cv_solaris_64bit = yes; then acl_libdirstem=lib/64 case "$host_cpu" in sparc*) acl_libdirstem2=lib/sparcv9 ;; i*86 | x86_64) acl_libdirstem2=lib/amd64 ;; esac fi ;; *) searchpath=`(LC_ALL=C $CC -print-search-dirs) 2>/dev/null | sed -n -e 's,^libraries: ,,p' | sed -e 's,^=,,'` if test -n "$searchpath"; then acl_save_IFS="${IFS= }"; IFS=":" for searchdir in $searchpath; do if test -d "$searchdir"; then case "$searchdir" in */lib64/ | */lib64 ) acl_libdirstem=lib64 ;; */../ | */.. ) # Better ignore directories of this form. They are misleading. ;; *) searchdir=`cd "$searchdir" && pwd` case "$searchdir" in */lib64 ) acl_libdirstem=lib64 ;; esac ;; esac fi done IFS="$acl_save_IFS" fi ;; esac test -n "$acl_libdirstem2" || acl_libdirstem2="$acl_libdirstem" ]) ngraph-gtk-6.08.00/m4/Makefile.in0000644000175000017500000003334313367273152013254 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = m4 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in ChangeLog DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ EXTRA_DIST = codeset.m4 gettext.m4 glibc2.m4 glibc21.m4 gsl.m4 \ glib-2.0.m4 gtk-3.0.m4 iconv.m4 intdiv0.m4 intl.m4 intldir.m4 \ intlmacosx.m4 intmax.m4 inttypes-pri.m4 inttypes_h.m4 \ lcmessage.m4 lib-ld.m4 lib-link.m4 lib-prefix.m4 libtool.m4 \ lock.m4 longlong.m4 ltoptions.m4 ltsugar.m4 ltversion.m4 \ lt~obsolete.m4 nls.m4 po.m4 printf-posix.m4 progtest.m4 \ size_max.m4 stdint_h.m4 uintmax_t.m4 visibility.m4 wchar_t.m4 \ wint_t.m4 xsize.m4 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) --gnu m4/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu m4/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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 tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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 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 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-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: .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-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 .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: ngraph-gtk-6.08.00/m4/po.m40000644000175000017500000004503113070106167012054 00000000000000# po.m4 serial 24 (gettext-0.19) dnl Copyright (C) 1995-2014, 2016 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Library General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Library General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2003. AC_PREREQ([2.60]) dnl Checks for all prerequisites of the po subdirectory. AC_DEFUN([AM_PO_SUBDIRS], [ AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl AC_REQUIRE([AC_PROG_SED])dnl AC_REQUIRE([AM_NLS])dnl dnl Release version of the gettext macros. This is used to ensure that dnl the gettext macros and po/Makefile.in.in are in sync. AC_SUBST([GETTEXT_MACRO_VERSION], [0.19]) dnl Perform the following tests also if --disable-nls has been given, dnl because they are needed for "make dist" to work. dnl Search for GNU msgfmt in the PATH. dnl The first test excludes Solaris msgfmt and early GNU msgfmt versions. dnl The second test excludes FreeBSD msgfmt. AM_PATH_PROG_WITH_TEST(MSGFMT, msgfmt, [$ac_dir/$ac_word --statistics /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], :) AC_PATH_PROG([GMSGFMT], [gmsgfmt], [$MSGFMT]) dnl Test whether it is GNU msgfmt >= 0.15. changequote(,)dnl case `$MSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) MSGFMT_015=: ;; *) MSGFMT_015=$MSGFMT ;; esac changequote([,])dnl AC_SUBST([MSGFMT_015]) changequote(,)dnl case `$GMSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) GMSGFMT_015=: ;; *) GMSGFMT_015=$GMSGFMT ;; esac changequote([,])dnl AC_SUBST([GMSGFMT_015]) dnl Search for GNU xgettext 0.12 or newer in the PATH. dnl The first test excludes Solaris xgettext and early GNU xgettext versions. dnl The second test excludes FreeBSD xgettext. AM_PATH_PROG_WITH_TEST(XGETTEXT, xgettext, [$ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], :) dnl Remove leftover from FreeBSD xgettext call. rm -f messages.po dnl Test whether it is GNU xgettext >= 0.15. changequote(,)dnl case `$XGETTEXT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) XGETTEXT_015=: ;; *) XGETTEXT_015=$XGETTEXT ;; esac changequote([,])dnl AC_SUBST([XGETTEXT_015]) dnl Search for GNU msgmerge 0.11 or newer in the PATH. AM_PATH_PROG_WITH_TEST(MSGMERGE, msgmerge, [$ac_dir/$ac_word --update -q /dev/null /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1], :) dnl Installation directories. dnl Autoconf >= 2.60 defines localedir. For older versions of autoconf, we dnl have to define it here, so that it can be used in po/Makefile. test -n "$localedir" || localedir='${datadir}/locale' AC_SUBST([localedir]) dnl Support for AM_XGETTEXT_OPTION. test -n "${XGETTEXT_EXTRA_OPTIONS+set}" || XGETTEXT_EXTRA_OPTIONS= AC_SUBST([XGETTEXT_EXTRA_OPTIONS]) AC_CONFIG_COMMANDS([po-directories], [[ for ac_file in $CONFIG_FILES; do # Support "outfile[:infile[:infile...]]" case "$ac_file" in *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; esac # PO directories have a Makefile.in generated from Makefile.in.in. case "$ac_file" in */Makefile.in) # Adjust a relative srcdir. ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'` ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` # In autoconf-2.13 it is called $ac_given_srcdir. # In autoconf-2.50 it is called $srcdir. test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" case "$ac_given_srcdir" in .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; /*) top_srcdir="$ac_given_srcdir" ;; *) top_srcdir="$ac_dots$ac_given_srcdir" ;; esac # Treat a directory as a PO directory if and only if it has a # POTFILES.in file. This allows packages to have multiple PO # directories under different names or in different locations. if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then rm -f "$ac_dir/POTFILES" test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES" gt_tab=`printf '\t'` cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ${gt_tab}]*\$/d" -e "s,.*, $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES" POMAKEFILEDEPS="POTFILES.in" # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend # on $ac_dir but don't depend on user-specified configuration # parameters. if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then # The LINGUAS file contains the set of available languages. if test -n "$OBSOLETE_ALL_LINGUAS"; then test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete" fi ALL_LINGUAS_=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"` # Hide the ALL_LINGUAS assignment from automake < 1.5. eval 'ALL_LINGUAS''=$ALL_LINGUAS_' POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS" else # The set of available languages was given in configure.in. # Hide the ALL_LINGUAS assignment from automake < 1.5. eval 'ALL_LINGUAS''=$OBSOLETE_ALL_LINGUAS' fi # Compute POFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po) # Compute UPDATEPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).po-update) # Compute DUMMYPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).nop) # Compute GMOFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo) case "$ac_given_srcdir" in .) srcdirpre= ;; *) srcdirpre='$(srcdir)/' ;; esac POFILES= UPDATEPOFILES= DUMMYPOFILES= GMOFILES= for lang in $ALL_LINGUAS; do POFILES="$POFILES $srcdirpre$lang.po" UPDATEPOFILES="$UPDATEPOFILES $lang.po-update" DUMMYPOFILES="$DUMMYPOFILES $lang.nop" GMOFILES="$GMOFILES $srcdirpre$lang.gmo" done # CATALOGS depends on both $ac_dir and the user's LINGUAS # environment variable. INST_LINGUAS= if test -n "$ALL_LINGUAS"; then for presentlang in $ALL_LINGUAS; do useit=no if test "%UNSET%" != "$LINGUAS"; then desiredlanguages="$LINGUAS" else desiredlanguages="$ALL_LINGUAS" fi for desiredlang in $desiredlanguages; do # Use the presentlang catalog if desiredlang is # a. equal to presentlang, or # b. a variant of presentlang (because in this case, # presentlang can be used as a fallback for messages # which are not translated in the desiredlang catalog). case "$desiredlang" in "$presentlang"*) useit=yes;; esac done if test $useit = yes; then INST_LINGUAS="$INST_LINGUAS $presentlang" fi done fi CATALOGS= if test -n "$INST_LINGUAS"; then for lang in $INST_LINGUAS; do CATALOGS="$CATALOGS $lang.gmo" done fi test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile" sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile" for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do if test -f "$f"; then case "$f" in *.orig | *.bak | *~) ;; *) cat "$f" >> "$ac_dir/Makefile" ;; esac fi done fi ;; esac done]], [# Capture the value of obsolete ALL_LINGUAS because we need it to compute # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. But hide it # from automake < 1.5. eval 'OBSOLETE_ALL_LINGUAS''="$ALL_LINGUAS"' # Capture the value of LINGUAS because we need it to compute CATALOGS. LINGUAS="${LINGUAS-%UNSET%}" ]) ]) dnl Postprocesses a Makefile in a directory containing PO files. AC_DEFUN([AM_POSTPROCESS_PO_MAKEFILE], [ # When this code is run, in config.status, two variables have already been # set: # - OBSOLETE_ALL_LINGUAS is the value of LINGUAS set in configure.in, # - LINGUAS is the value of the environment variable LINGUAS at configure # time. changequote(,)dnl # Adjust a relative srcdir. ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'` ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` # In autoconf-2.13 it is called $ac_given_srcdir. # In autoconf-2.50 it is called $srcdir. test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" case "$ac_given_srcdir" in .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; /*) top_srcdir="$ac_given_srcdir" ;; *) top_srcdir="$ac_dots$ac_given_srcdir" ;; esac # Find a way to echo strings without interpreting backslash. if test "X`(echo '\t') 2>/dev/null`" = 'X\t'; then gt_echo='echo' else if test "X`(printf '%s\n' '\t') 2>/dev/null`" = 'X\t'; then gt_echo='printf %s\n' else echo_func () { cat < "$ac_file.tmp" tab=`printf '\t'` if grep -l '@TCLCATALOGS@' "$ac_file" > /dev/null; then # Add dependencies that cannot be formulated as a simple suffix rule. for lang in $ALL_LINGUAS; do frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'` cat >> "$ac_file.tmp" < /dev/null; then # Add dependencies that cannot be formulated as a simple suffix rule. for lang in $ALL_LINGUAS; do frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'` cat >> "$ac_file.tmp" <> "$ac_file.tmp" < #include #include "config.h" #include "../src/ngraph.h" #ifdef TRUE #undef TRUE #endif #define TRUE 1 #ifdef FALSE #undef FALSE #endif #define FALSE 0 static int Initialized = FALSE; static char *DummyArgv[] = {"ngraph_ruby", NULL}; static char **DummyArgvPtr = DummyArgv; static int DummyArgc = 1; #ifdef __MINGW32__ #define WINDOWS 1 #else #define WINDOWS 0 #endif #ifdef __APPLE__ #define MAC_OS 1 #else #define MAC_OS 0 #endif #if WINDOWS || MAC_OS static char * get_ext_name(void) { int n, i; struct objlist *sys; char *ext_name, *plugin_path, ext_basename[] = "ruby/ngraph.rb"; ngraph_returned_value val; ngraph_arg arg; sys = ngraph_get_object("system"); if (sys == NULL) { return NULL; } arg.num = 0; ngraph_object_get(sys, "plugin_dir", 0, &arg, &val); if (val.str == NULL) { return NULL; } plugin_path = strdup(val.str); if (plugin_path == NULL) { return NULL; } n = strlen(plugin_path); for (i = n - 1; i >= 0; i--) { if (plugin_path[i] == '/') { plugin_path[i] = '\0'; break; } } ext_name = malloc(n + sizeof(ext_basename) + 1); if (ext_name == NULL) { free(plugin_path); return NULL; } sprintf(ext_name, "%s/%s", plugin_path, ext_basename); free(plugin_path); return ext_name; } #endif static VALUE require_files(VALUE data) { VALUE result; rb_require("enc/encdb"); rb_require("enc/trans/transdb"); rb_require("rubygems"); result = rb_require((char *) data); return result; } int ngraph_plugin_open_ruby(void) { rb_encoding *enc; #if WINDOWS || MAC_OS char *ext_name; #endif VALUE result, arg; int status; if (Initialized) { return 0; } #if WINDOWS || MAC_OS ext_name = get_ext_name(); if (ext_name == NULL) { return 1; } #endif ruby_sysinit(&DummyArgc, &DummyArgvPtr); { RUBY_INIT_STACK; ruby_init(); ruby_script("Embedded Ruby on Ngraph"); ruby_init_loadpath(); rb_enc_find_index("encdb"); /* http://www.artonx.org/diary/20090206.html */ enc = rb_locale_encoding(); if (enc) { rb_enc_set_default_external(rb_enc_from_encoding(enc)); } rb_enc_set_default_internal(rb_enc_from_encoding(rb_utf8_encoding())); #if WINDOWS || MAC_OS arg = (VALUE) ext_name; #else arg = (VALUE) "ngraph.rb"; #endif result = rb_protect(require_files, arg, &status); } #if WINDOWS || MAC_OS free(ext_name); #endif if (status) { return 1; } Initialized = TRUE; return ! RTEST(result); } void ngraph_plugin_close_ruby(void) { if (Initialized) { ruby_finalize(); } } ngraph-gtk-6.08.00/plugins/ruby/0000755000175000017500000000000013375640234013401 500000000000000ngraph-gtk-6.08.00/plugins/ruby/ngraph.c0000644000175000017500000011252013070106167014737 00000000000000#include #include #include #include #ifdef TRUE #undef TRUE #endif #define TRUE 1 #ifdef FALSE #undef FALSE #endif #define FALSE 0 static char *DummyArgv[] = {"ngraph_ruby", NULL}; static char **DummyArgvPtr = DummyArgv; static int DummyArgc = 1, Initialized = FALSE; static VALUE NgraphClass, NgraphModule; static ID Uniq, ExpandPath; #define VAL2INT(val) (NIL_P(val) ? 0 : NUM2INT(val)) #define VAL2DBL(val) (NIL_P(val) ? 0.0 : NUM2DBL(val)) #define VAL2STR(val) (NIL_P(val) ? NULL : StringValueCStr(val)) struct ngraph_instance { int id, oid, rcode; struct objlist *obj; }; struct obj_ids { int *ids, num; struct objlist *obj; }; static VALUE get_ngraph_obj(const char *name); static VALUE str2inst_get_ary(VALUE data1); static VALUE str2inst_ensure(VALUE data2); static VALUE obj_get(VALUE klass, VALUE id_value, const char *name); static VALUE tainted_utf8_str_new(const char *str); static VALUE tainted_utf8_str_new(const char *str) { size_t l; VALUE s; if (str == NULL) { return Qnil; } l = strlen(str); s = rb_enc_str_new(str, l, rb_utf8_encoding()); rb_obj_taint(s); return s; } static VALUE ngraph_inst_method_equal(VALUE klass1, VALUE klass2) { struct ngraph_instance *inst1, *inst2; if (! rb_obj_is_kind_of(klass2, NgraphClass)) { return Qfalse; } Data_Get_Struct(klass1, struct ngraph_instance, inst1); Data_Get_Struct(klass2, struct ngraph_instance, inst2); if (inst1->obj == inst2->obj && inst1->oid == inst2->oid) { return Qtrue; } return Qfalse; } static VALUE ngraph_inst_method_compare(VALUE klass1, VALUE klass2) { struct ngraph_instance *inst1, *inst2; int r; if (! rb_obj_is_kind_of(klass2, NgraphClass)) { return Qnil; } Data_Get_Struct(klass1, struct ngraph_instance, inst1); Data_Get_Struct(klass2, struct ngraph_instance, inst2); if (inst1->obj != inst2->obj) { return Qnil; } if (inst1->oid == inst2->oid) { r = 0; } else if (inst1->oid > inst2->oid) { r = 1; } else { r = -1; } return INT2FIX(r); } static struct ngraph_instance * check_id(VALUE klass) { struct ngraph_instance *inst; int id, r, last; ngraph_arg arg; ngraph_returned_value oid; Data_Get_Struct(klass, struct ngraph_instance, inst); if (inst->id < 0) { rb_raise(rb_eArgError, "%s: the instance is already deleted.", rb_obj_classname(klass)); } last = ngraph_get_object_last_id(inst->obj); if (inst->id <= last) { arg.num = 0; r = ngraph_object_get(inst->obj, "oid", inst->id, &arg, &oid); if (r >= 0 && inst->oid == oid.i) { return inst; } if (r < 0) { inst->id = -1; rb_raise(rb_eArgError, "%s: the instance is already deleted.", rb_obj_classname(klass)); } } id = ngraph_object_get_id_by_oid(inst->obj, inst->oid); inst->id = id; return inst; } static VALUE ngraph_inst_method_move_up(VALUE klass) { struct ngraph_instance *inst; inst = check_id(klass); if (inst == NULL) { return Qnil; } inst->id = ngraph_object_move_up(inst->obj, inst->id); return klass; } static VALUE ngraph_inst_method_move_down(VALUE klass) { struct ngraph_instance *inst; inst = check_id(klass); if (inst == NULL) { return Qnil; } inst->id = ngraph_object_move_down(inst->obj, inst->id); return klass; } static VALUE ngraph_inst_method_move_top(VALUE klass) { struct ngraph_instance *inst; inst = check_id(klass); if (inst == NULL) { return Qnil; } inst->id = ngraph_object_move_top(inst->obj, inst->id); return klass; } static VALUE ngraph_inst_method_move_last(VALUE klass) { struct ngraph_instance *inst; inst = check_id(klass); if (inst == NULL) { return Qnil; } inst->id = ngraph_object_move_last(inst->obj, inst->id); return klass; } static int check_inst_args(VALUE self, VALUE arg, const char *field, struct ngraph_instance **inst1, struct ngraph_instance **inst2) { *inst1 = check_id(self); if (*inst1 == NULL) { return 1; } if (! rb_obj_is_kind_of(arg, NgraphClass)) { rb_raise(rb_eArgError, "%s#%s: illegal type of the argument (%s).", rb_obj_classname(self), field, rb_obj_classname(arg)); } *inst2 = check_id(arg); if (*inst2 == NULL) { return 1; } if ((*inst1)->obj != (*inst2)->obj) { rb_raise(rb_eArgError, "%s#%s: illegal type of the argument (%s).", rb_obj_classname(self), field, rb_obj_classname(arg)); } return 0; } static VALUE ngraph_inst_method_exchange(VALUE self, VALUE arg) { struct ngraph_instance *inst1, *inst2; int id, r; r = check_inst_args(self, arg, "exchange", &inst1, &inst2); if (r) { return Qnil; } r = ngraph_object_exchange(inst1->obj, inst1->id, inst2->id); if (r < 0) { return Qnil; } id = inst1->id; inst1->id = inst2->id; inst2->id = id; return self; } static VALUE ngraph_inst_method_copy(VALUE self, VALUE arg) { struct ngraph_instance *inst1, *inst2; int r; r = check_inst_args(self, arg, "copy", &inst1, &inst2); if (r) { return Qnil; } r = ngraph_object_copy(inst1->obj, inst1->id, inst2->id); if (r < 0) { return Qnil; } return self; } static VALUE ngraph_inst_method_to_str(VALUE klass) { struct ngraph_instance *inst; const char *name; VALUE rstr; inst = check_id(klass); if (inst == NULL) { return Qnil; } name = ngraph_get_object_name(inst->obj); rstr = rb_sprintf("%s:%d", name, inst->id); return rstr; } static VALUE ngraph_inst_method_rcode(VALUE klass) { struct ngraph_instance *inst; inst = check_id(klass); if (inst == NULL) { return Qnil; } return INT2FIX(inst->rcode); } static VALUE str2inst_get_ary(VALUE data1) { const char *name; int i, n; VALUE ary, obj, klass; struct obj_ids *obj_ids; obj_ids = (struct obj_ids *) data1; name = ngraph_get_object_name(obj_ids->obj); klass = get_ngraph_obj(name); ary = rb_ary_new2(obj_ids->num); n = obj_ids->num; for (i = 0; i < n; i++) { obj = obj_get(klass, INT2FIX(obj_ids->ids[i]), name); rb_ary_push(ary, obj); } return ary; } static VALUE str2inst_ensure(VALUE data2) { int *ids; ids = (int *) data2; ngraph_free(ids); return Qnil; } static VALUE obj_get_from_str(VALUE klass, VALUE arg, const char *name) { const char *str; struct obj_ids obj_ids; VALUE ary, inst; str = StringValueCStr(arg); inst = rb_sprintf("%s:%s", name, str); obj_ids.obj = ngraph_get_object_instances_by_str(StringValueCStr(inst), &obj_ids.num, &obj_ids.ids); if (obj_ids.obj == NULL) { return rb_ary_new(); } ary = rb_ensure(str2inst_get_ary, (VALUE) &obj_ids, str2inst_ensure, (VALUE) obj_ids.ids); return ary; } static VALUE obj_get(VALUE klass, VALUE id_value, const char *name) { struct ngraph_instance *inst; struct objlist *nobj; ngraph_returned_value oid; ngraph_arg arg; VALUE new_inst; int id, n; if (RB_TYPE_P(id_value, T_STRING)) { return obj_get_from_str(klass, id_value, name); } id = NUM2INT(id_value); nobj = ngraph_get_object(name); n = ngraph_get_object_last_id(nobj); if (id < 0) { id = n + id + 1; } if (id < 0 || id > n) { return Qnil; } new_inst = Data_Make_Struct(klass, struct ngraph_instance, 0, -1, inst); inst->obj = nobj; inst->id = id; inst->rcode = id; arg.num = 0; ngraph_object_get(inst->obj, "oid", inst->id, &arg, &oid); inst->oid = oid.i; return new_inst; } static VALUE obj_field_args(VALUE klass, VALUE field, const char *name) { struct objlist *nobj; const char* args; enum ngraph_object_field_type type; nobj = ngraph_get_object(name); type = ngraph_get_object_field_type(nobj, StringValueCStr(field)); if (type < NVFUNC) { return Qnil; } args = ngraph_get_object_field_args(nobj, StringValueCStr(field)); if (args == NULL) { args = ""; } else if (args[0] == '\0') { args = "void"; } return rb_str_new2(args); } static VALUE obj_field_type(VALUE klass, VALUE field, const char *name) { struct objlist *nobj; enum ngraph_object_field_type type; nobj = ngraph_get_object(name); type = ngraph_get_object_field_type(nobj, StringValueCStr(field)); return INT2FIX(type); } static VALUE obj_field_permission(VALUE klass, VALUE field, const char *name) { struct objlist *nobj; int perm; nobj = ngraph_get_object(name); perm = ngraph_get_object_field_permission(nobj, StringValueCStr(field)); return INT2FIX(perm); } static void set_ngraph_obj_class_name(const char *name, char *buf, int len) { int i; buf[0] = toupper(name[0]); for (i = 1; i < len - 1; i++) { buf[i] = name[i]; if (name[i] == '\0') { break; } } buf[len - 1] = '\0'; } static VALUE get_ngraph_obj(const char *name) { char buf[64]; set_ngraph_obj_class_name(name, buf, sizeof(buf)); return rb_const_get(NgraphModule, rb_intern(buf)); } static void add_child(VALUE ary, struct objlist *parent, int noinst) { struct objlist *ocur; VALUE obj; int id; const char *name; ocur = ngraph_get_root_object(); while (ocur) { if (ngraph_get_parent_object(ocur) == parent) { id = ngraph_get_object_last_id(ocur); if (id != -1 || ! noinst) { name = ngraph_get_object_name(ocur); obj = get_ngraph_obj(name); if (! NIL_P(obj)) { rb_ary_push(ary, obj); } } add_child(ary, ocur, noinst); } ocur = ngraph_get_next_object(ocur); } } static VALUE obj_derive(VALUE klass, VALUE arg, const char *name) { struct objlist *obj; int noinst, id; VALUE robj, ary; noinst = RTEST(arg); obj = ngraph_get_object(name); if (obj == NULL) { return Qnil; } ary = rb_ary_new(); id = ngraph_get_object_last_id(obj); if (id != -1 || ! noinst) { robj = get_ngraph_obj(name); if (! NIL_P(robj)) { rb_ary_push(ary, robj); } } add_child(ary, obj, noinst); return ary; } static VALUE obj_each(VALUE klass, const char *name) { struct objlist *nobj; int i, n; VALUE inst, id, ary; nobj = ngraph_get_object(name); n = ngraph_get_object_last_id(nobj) + 1; if (n < 1) { return klass; } name = ngraph_get_object_name(nobj); ary = rb_ary_new2(n); for (i = 0; i < n; i++) { id = INT2FIX(i); inst = obj_get(klass, id, name); rb_ary_store(ary, i, inst); } rb_ary_each(ary); return klass; } static VALUE obj_move_up(VALUE klass, VALUE arg, const char *name) { struct objlist *nobj; int id, r; nobj = ngraph_get_object(name); id = NUM2INT(arg); r = ngraph_object_move_up(nobj, id); if (r < 0) { return Qnil; } return klass; } static VALUE obj_move_down(VALUE klass, VALUE arg, const char *name) { struct objlist *nobj; int id, r; nobj = ngraph_get_object(name); id = NUM2INT(arg); r = ngraph_object_move_down(nobj, id); if (r < 0) { return Qnil; } return klass; } static VALUE obj_move_top(VALUE klass, VALUE arg, const char *name) { struct objlist *nobj; int id, r; nobj = ngraph_get_object(name); id = NUM2INT(arg); r = ngraph_object_move_top(nobj, id); if (r < 0) { return Qnil; } return klass; } static VALUE obj_move_last(VALUE klass, VALUE arg, const char *name) { struct objlist *nobj; int id, r; nobj = ngraph_get_object(name); id = NUM2INT(arg); r = ngraph_object_move_last(nobj, id); if (r < 0) { return Qnil; } return klass; } static VALUE obj_exchange(VALUE klass, VALUE arg1, VALUE arg2, const char *name) { struct objlist *nobj; int id1, id2, r; nobj = ngraph_get_object(name); id1 = NUM2INT(arg1); id2 = NUM2INT(arg2); r = ngraph_object_exchange(nobj, id1, id2); if (r < 0) { return Qnil; } return klass; } static VALUE obj_copy(VALUE klass, VALUE arg1, VALUE arg2, const char *name) { struct objlist *nobj; int id1, id2, r; nobj = ngraph_get_object(name); id1 = NUM2INT(arg1); id2 = NUM2INT(arg2); r = ngraph_object_copy(nobj, id1, id2); if (r < 0) { return Qnil; } return klass; } static VALUE obj_size(VALUE klass, const char *name) { struct objlist *nobj; int n; nobj = ngraph_get_object(name); n = ngraph_get_object_last_id(nobj); n = (n >= 0) ? n + 1 : 0; return INT2FIX(n); } static VALUE obj_exist(VALUE klass, const char *name) { struct objlist *nobj; int n; nobj = ngraph_get_object(name); n = ngraph_get_object_last_id(nobj); return (n >= 0) ? Qtrue : Qfalse; } static VALUE obj_del_from_str(VALUE klass, VALUE arg, const char *name) { const char *str; int i, *ids, n; struct objlist *obj; VALUE inst; str = StringValueCStr(arg); inst = rb_sprintf("%s:%s", name, str); obj = ngraph_get_object_instances_by_str(StringValueCStr(inst), &n, &ids); if (obj == NULL) { return klass; } for (i = n - 1; i >= 0; i--) { ngraph_object_del(obj, ids[i]); } ngraph_free(ids); return klass; } static VALUE obj_del(VALUE klass, VALUE id_value, const char *name) { int id, n; struct objlist *nobj; if (RB_TYPE_P(id_value, T_STRING)) { return obj_del_from_str(klass, id_value, name); } id = NUM2INT(id_value); nobj = ngraph_get_object(name); n = ngraph_get_object_last_id(nobj); if (id < 0) { id = n + id + 1; } if (id < 0 || id > n) { return Qnil; } ngraph_object_del(nobj, id); return klass; } static VALUE ngraph_inst_method_del(VALUE self) { int id; struct ngraph_instance *inst; inst = check_id(self); if (inst == NULL) { return Qnil; } id = inst->id; inst->id = -1; ngraph_object_del(inst->obj, id); return INT2FIX(id); } static VALUE obj_new_with_block_body(VALUE arg) { return rb_yield(arg); } static VALUE obj_new_with_block_ensure(VALUE arg) { return ngraph_inst_method_del(arg); } static VALUE obj_new(VALUE klass, const char *name) { VALUE new_inst; struct objlist *nobj; int r; nobj = ngraph_get_object(name); r = ngraph_object_new(nobj); if (r < 0) { return Qnil; } new_inst = obj_get(klass, INT2FIX(r), name); if (RTEST(rb_block_given_p())) { new_inst = rb_ensure(obj_new_with_block_body, new_inst, obj_new_with_block_ensure, new_inst); } return new_inst; } static VALUE obj_current(VALUE klass, const char *name) { VALUE new_inst; struct objlist *nobj; int id; nobj = ngraph_get_object(name); id = ngraph_get_object_current_id(nobj); if (id < 0) { return Qnil; } new_inst = obj_get(klass, INT2FIX(id), name); return new_inst; } static VALUE inst_get_int(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value num; ngraph_arg carg; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &num); if (inst->rcode < 0) { return Qnil; } return INT2NUM(num.i); } static VALUE inst_get_double(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value num; ngraph_arg carg; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &num); if (inst->rcode < 0) { return Qnil; } return rb_float_new(num.d); } static VALUE inst_get_bool(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value num; ngraph_arg carg; VALUE val; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &num); if (inst->rcode < 0) { return Qnil; } val = num.i ? Qtrue : Qfalse; return val; } static VALUE inst_get_str(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value str; ngraph_arg carg; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &str); if (inst->rcode < 0) { return Qnil; } return tainted_utf8_str_new(str.str); } static VALUE inst_get_obj(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value str; ngraph_arg carg; const char *name; int id, n, *ids; struct objlist *obj; VALUE klass; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &str); if (inst->rcode < 0) { return Qnil; } if (str.str == NULL) { return Qnil; } obj = ngraph_get_object_instances_by_str(str.str, &n, &ids); if (obj == NULL) { return Qnil; } id = ids[n - 1]; ngraph_free(ids); name = ngraph_get_object_name(obj); if (name == NULL) { return Qnil; } klass = get_ngraph_obj(name); return obj_get(klass, INT2FIX(id), name); } static VALUE inst_put_int(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst; ngraph_value num; inst = check_id(self); if (inst == NULL) { return Qnil; } num.i = NUM2INT(arg); inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &num); if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_double(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst; ngraph_value num; inst = check_id(self); if (inst == NULL) { return Qnil; } num.d = NUM2DBL(arg); inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &num); if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_bool(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst; ngraph_value num; inst = check_id(self); if (inst == NULL) { return Qnil; } num.i = RTEST(arg) ? 1 : 0; inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &num); if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_enum(VALUE self, VALUE arg, const char *field, int max) { struct ngraph_instance *inst; ngraph_value num; inst = check_id(self); if (inst == NULL) { return Qnil; } num.i = NUM2INT(arg); if (num.i < 0 || num.i > max) { return Qnil; } inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &num); if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_str(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst; ngraph_value str; inst = check_id(self); if (inst == NULL) { return Qnil; } if (NIL_P(arg)) { str.str = NULL; } else { str.str = StringValueCStr(arg); } inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &str); if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_obj(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst1, *inst2; ngraph_value str; char buf[128]; const char *name, *ptr; int *ids; struct objlist *obj; switch (TYPE(arg)) { case T_NIL: ptr = NULL; break; case T_STRING: ptr = StringValueCStr(arg); obj = ngraph_get_object_instances_by_str(ptr, NULL, &ids); if (obj == NULL) { rb_raise(rb_eArgError, "%s#%s: illegal instance representation (%s).", rb_obj_classname(self), field, ptr); } ngraph_free(ids); break; default: if (! rb_obj_is_kind_of(arg, NgraphClass)) { rb_raise(rb_eArgError, "%s#%s: illegal type of the argument (%s).", rb_obj_classname(self), field, rb_obj_classname(arg)); } inst2 = check_id(arg); if (inst2 == NULL) { return Qnil; } name = ngraph_get_object_name(inst2->obj); #if 0 snprintf(buf, sizeof(buf), "%s:%d", name, inst2->id); #else snprintf(buf, sizeof(buf), "%s:^%d", name, inst2->oid); /* shoud instance be tighten? */ #endif ptr = buf; } inst1 = check_id(self); if (inst1 == NULL) { return Qnil; } str.str = ptr; inst1->rcode = ngraph_object_put(inst1->obj, field, inst1->id, &str); if (inst1->rcode < 0) { return Qnil; } return arg; } static VALUE inst_put_iarray(VALUE self, VALUE arg, const char *field) { VALUE tmpstr; struct ngraph_instance *inst; ngraph_value ary; int num, i; inst = check_id(self); if (inst == NULL) { return Qnil; } if (NIL_P(arg)) { num = 0; } else { if (!RB_TYPE_P(arg, T_ARRAY)) { rb_raise(rb_eArgError, "%s#%s: the argument must be an Array", rb_obj_classname(self), field); } num = RARRAY_LEN(arg); } ary.ary = NULL; if (num > 0) { ary.ary = rb_alloc_tmp_buffer(&tmpstr, sizeof(*ary.ary) + sizeof(ngraph_value) * num); ary.ary->num = num; if (ary.ary) { for (i = 0; i < num; i++) { ary.ary->ary[i].i = NUM2INT(rb_ary_entry(arg, i)); } } } inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &ary); if (ary.ary) { rb_free_tmp_buffer(&tmpstr); } if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_get_iarray(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value cary; ngraph_arg carg; VALUE ary; int i; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &cary); if (inst->rcode < 0) { return Qnil; } ary = rb_ary_new2(cary.ary.num); for (i = 0; i < cary.ary.num; i++) { rb_ary_store(ary, i, INT2NUM(cary.ary.data.ia[i])); } return ary; } static VALUE inst_put_darray(VALUE self, VALUE arg, const char *field) { VALUE tmpstr; struct ngraph_instance *inst; ngraph_value ary; int num, i; inst = check_id(self); if (inst == NULL) { return Qnil; } if (NIL_P(arg)) { num = 0; } else { if (!RB_TYPE_P(arg, T_ARRAY)) { rb_raise(rb_eArgError, "%s#%s: the argument must be an Array", rb_obj_classname(self), field); } num = RARRAY_LEN(arg); } ary.ary = NULL; if (num > 0) { ary.ary = rb_alloc_tmp_buffer(&tmpstr, sizeof(*ary.ary) + sizeof(ngraph_value) * num); ary.ary->num = num; if (ary.ary) { for (i = 0; i < num; i++) { ary.ary->ary[i].d = NUM2DBL(rb_ary_entry(arg, i)); } } } inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &ary); if (ary.ary) { rb_free_tmp_buffer(&tmpstr); } if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_get_darray(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value cary; ngraph_arg carg; VALUE ary; int i; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &cary); if (inst->rcode < 0) { return Qnil; } ary = rb_ary_new2(cary.ary.num); for (i = 0; i < cary.ary.num; i++) { rb_ary_store(ary, i, rb_float_new(cary.ary.data.da[i])); } return ary; } static VALUE inst_put_sarray(VALUE self, VALUE arg, const char *field) { struct ngraph_instance *inst; ngraph_value ary; int num, i; VALUE str, tmpstr; inst = check_id(self); if (inst == NULL) { return Qnil; } if (NIL_P(arg)) { num = 0; } else { if (!RB_TYPE_P(arg, T_ARRAY)) { rb_raise(rb_eArgError, "%s#%s: the argument must be an Array", rb_obj_classname(self), field); } num = RARRAY_LEN(arg); } ary.ary = NULL; if (num > 0) { ary.ary = rb_alloc_tmp_buffer(&tmpstr, sizeof(*ary.ary) + sizeof(ngraph_value) * num); ary.ary->num = num; if (ary.ary) { for (i = 0; i < num; i++) { str = rb_ary_entry(arg, i); ary.ary->ary[i].str = StringValueCStr(str); } } } inst->rcode = ngraph_object_put(inst->obj, field, inst->id, &ary); if (ary.ary) { rb_free_tmp_buffer(&tmpstr); } if (inst->rcode < 0) { return Qnil; } return arg; } static VALUE inst_get_sarray(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_returned_value cary; ngraph_arg carg; VALUE ary; int i; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &cary); if (inst->rcode < 0) { return Qnil; } ary = rb_ary_new2(cary.ary.num); for (i = 0; i < cary.ary.num; i++) { rb_ary_store(ary, i, tainted_utf8_str_new(cary.ary.data.sa[i])); } return ary; } static VALUE inst_exe_void_func(VALUE self, const char *field) { struct ngraph_instance *inst; ngraph_arg carg; inst = check_id(self); if (inst == NULL) { return Qnil; } carg.num = 0; inst->rcode = ngraph_object_exe(inst->obj, field, inst->id, &carg); if (inst->rcode < 0) { return Qnil; } return self; } static VALUE get_array_arg(VALUE self, const char *field, VALUE arg, int *num) { int n; VALUE ary, val; if (NIL_P(arg)) { *num = 0; return Qnil; } if (!RB_TYPE_P(arg, T_ARRAY)) { rb_raise(rb_eArgError, "%s#%s: the argument must be an Array", rb_obj_classname(self), field); } n = RARRAY_LEN(arg); ary = arg; if (n == 1) { val = rb_ary_entry(arg, 0); if (RB_TYPE_P(val, T_ARRAY)) { ary = val; n = RARRAY_LEN(val); } } *num = n; return ary; } static struct ngraph_array * allocate_iarray(VALUE self, volatile VALUE *tmpstr, VALUE arg, const char *field) { struct ngraph_array *narray; int i, num; VALUE ary; ary = get_array_arg(self, field, arg, &num); narray = rb_alloc_tmp_buffer(tmpstr, sizeof(*narray) + sizeof(ngraph_value) * num); if (narray == NULL) { return NULL; } narray->num = num; for (i = 0; i < num; i++) { narray->ary[i].i = NUM2INT(rb_ary_entry(ary, i)); } return narray; } static struct ngraph_array * allocate_darray(VALUE self, volatile VALUE *tmpstr, VALUE arg, const char *field) { struct ngraph_array *narray; int i, num; VALUE ary; ary = get_array_arg(self, field, arg, &num); narray = rb_alloc_tmp_buffer(tmpstr, sizeof(*narray) + sizeof(ngraph_value) * num); if (narray == NULL) { return NULL; } narray->num = num; for (i = 0; i < num; i++) { narray->ary[i].d = NUM2DBL(rb_ary_entry(ary, i)); } return narray; } static struct ngraph_array * allocate_sarray(VALUE self, volatile VALUE *tmpstr, VALUE arg, const char *field) { struct ngraph_array *narray; int i, num; VALUE str; VALUE ary; ary = get_array_arg(self, field, arg, &num); narray = rb_alloc_tmp_buffer(tmpstr, sizeof(*narray) + sizeof(ngraph_value) * num); if (narray == NULL) { return NULL; } narray->num = num; for (i = 0; i < num; i++) { str = rb_ary_entry(ary, i); narray->ary[i].str = StringValueCStr(str); } return narray; } static VALUE create_obj_arg(VALUE args) { int i, n; VALUE arg, str, uniq_args; struct ngraph_instance *inst; struct objlist *obj = NULL; const char *name; uniq_args = rb_funcall(args, Uniq, 0); n = RARRAY_LEN(uniq_args); str = rb_str_new2(""); for (i = 0; i < n; i++) { arg = rb_ary_entry(uniq_args, i); if (! rb_obj_is_kind_of(arg, NgraphClass)) { return Qnil; } inst = check_id(arg); if (inst == NULL) { return Qnil; } if (obj == NULL) { obj = inst->obj; name = ngraph_get_object_name(inst->obj); rb_str_cat2(str, name); } else if (obj != inst->obj) { return Qnil; } rb_str_catf(str, "%c%d", (i) ? ',' : ':', inst->id); } return str; } static VALUE obj_func_obj(VALUE self, VALUE argv, const char *field, int type) { VALUE arg, rstr, val; int i, n; struct ngraph_instance *inst; ngraph_arg carg; int argc; ngraph_returned_value rval; const char *str; inst = check_id(self); if (inst == NULL) { return Qnil; } argc = RARRAY_LEN(argv); if (argc < 1) { str = NULL; } else { arg = rb_ary_entry(argv, 0); if (RB_TYPE_P(arg, T_ARRAY)) { if (argc > 1) { return Qnil; } n = RARRAY_LEN(arg); if (n < 1) { str = NULL; } else { rstr = create_obj_arg(arg); if (NIL_P(rstr)) { return Qnil; } str = StringValueCStr(rstr); } } else { rstr = create_obj_arg(argv); if (NIL_P(rstr)) { return Qnil; } str = StringValueCStr(rstr); } } carg.num = 1; carg.ary[0].str = str; if (type == NVFUNC) { inst->rcode = ngraph_object_exe(inst->obj, field, inst->id, &carg); } else { inst->rcode = ngraph_object_get(inst->obj, field, inst->id, &carg, &rval); } if (inst->rcode < 0) { return Qnil; } switch (type) { case NVFUNC: val = self; break; case NBFUNC: val = (rval.i) ? Qtrue : Qfalse; break; #if USE_NCHAR case NCFUNC: #endif case NIFUNC: val = INT2NUM(rval.i); break; case NDFUNC: val = rb_float_new(rval.d); break; case NSFUNC: val = tainted_utf8_str_new(rval.str); break; case NIAFUNC: val = rb_ary_new2(rval.ary.num); for (i = 0; i < rval.ary.num; i++) { rb_ary_store(val, i, INT2NUM(rval.ary.data.ia[i])); } break; case NDAFUNC: val = rb_ary_new2(rval.ary.num); for (i = 0; i < rval.ary.num; i++) { rb_ary_store(val, i, rb_float_new(rval.ary.data.da[i])); } break; case NSAFUNC: val = rb_ary_new2(rval.ary.num); for (i = 0; i < rval.ary.num; i++) { rb_ary_store(val, i, tainted_utf8_str_new(rval.ary.data.sa[i])); } break; default: val = Qnil; } return val; } #if 0 static VALUE get_str_func_argv(VALUE self, VALUE argv, const char *field) { ngraph_returned_value rval; struct ngraph_instance *inst; ngraph_arg *carg; VALUE tmpstr; inst = check_id(self); if (inst == NULL) { return Qnil; } carg = allocate_sarray(self, &tmpstr, argv, field); inst->rcode = ngraph_object_get(inst->obj, field, inst->id, carg, &rval); rb_free_tmp_buffer(&tmpstr); if (inst->rcode < 0) { return Qnil; } return tainted_utf8_str_new(rval.str ? rval.str : ""); } #endif static void add_obj_name_const(VALUE klass, struct objlist *nobj, const char *name) { const char *obj_name; char str[64]; VALUE val; if (nobj == NULL) { val = Qnil; } else { obj_name = ngraph_get_object_name(nobj); set_ngraph_obj_class_name(obj_name, str, sizeof(str)); val = ID2SYM(rb_intern(str)); } rb_define_const(klass, name, val); } static void add_obj_str_const(VALUE klass, const char *name, const char *str) { VALUE val; val = rb_str_new2(str); OBJ_FREEZE(val); rb_define_const(klass, name, val); } static void add_obj_const(VALUE klass, const char *name) { struct objlist *nobj, *next, *child, *parent; const char *str; nobj = ngraph_get_object(name); next = ngraph_get_next_object(nobj); child = ngraph_get_child_object(nobj); parent = ngraph_get_parent_object(nobj); str = ngraph_get_object_version(nobj); add_obj_str_const(klass, "VERSION", str); add_obj_str_const(klass, "NAME", name); add_obj_name_const(klass, parent, "PARENT"); add_obj_name_const(klass, next, "NEXT"); add_obj_name_const(klass, child, "CHILD"); } static void setup_obj_common(VALUE obj) { rb_extend_object(obj, rb_mEnumerable); rb_include_module(obj, rb_mComparable); rb_define_method(obj, "del", ngraph_inst_method_del, 0); rb_define_method(obj, "===", ngraph_inst_method_equal, 1); rb_define_method(obj, "<=>", ngraph_inst_method_compare, 1); rb_define_method(obj, "move_up", ngraph_inst_method_move_up, 0); rb_define_method(obj, "move_down", ngraph_inst_method_move_down, 0); rb_define_method(obj, "move_top", ngraph_inst_method_move_top, 0); rb_define_method(obj, "move_last", ngraph_inst_method_move_last, 0); rb_define_method(obj, "exchange", ngraph_inst_method_exchange, 1); rb_define_method(obj, "to_s", ngraph_inst_method_to_str, 0); rb_define_method(obj, "rcode", ngraph_inst_method_rcode, 0); rb_define_method(obj, "copy", ngraph_inst_method_copy, 1); } static void store_field_names(VALUE fields, const char *name) { VALUE field; field = rb_str_new2(name); OBJ_FREEZE(field); rb_ary_push(fields, field); } #include "ruby_ngraph.h" static void add_common_const(VALUE ngraph_module) { VALUE type, attr; type = rb_define_module_under(ngraph_module, "FIELD_TYPE"); #if USE_NCHAR rb_define_const(type, "CHAR", INT2FIX(NCHAR)); #endif rb_define_const(type, "VOID", INT2FIX(NVOID)); rb_define_const(type, "BOOL", INT2FIX(NBOOL)); rb_define_const(type, "INT", INT2FIX(NINT)); rb_define_const(type, "DOUBLE", INT2FIX(NDOUBLE)); rb_define_const(type, "STR", INT2FIX(NSTR)); rb_define_const(type, "POINTER", INT2FIX(NPOINTER)); rb_define_const(type, "IARRAY", INT2FIX(NIARRAY)); rb_define_const(type, "DARRAY", INT2FIX(NDARRAY)); rb_define_const(type, "SARRAY", INT2FIX(NSARRAY)); rb_define_const(type, "ENUM", INT2FIX(NENUM)); rb_define_const(type, "OBJ", INT2FIX(NOBJ)); #if USE_LABEL rb_define_const(type, "LABEL", INT2FIX(NLABEL)); #endif rb_define_const(type, "VFUNC", INT2FIX(NVFUNC)); rb_define_const(type, "BFUNC", INT2FIX(NBFUNC)); #if USE_NCHAR rb_define_const(type, "CFUNC", INT2FIX(NCFUNC)); #endif rb_define_const(type, "IFUNC", INT2FIX(NIFUNC)); rb_define_const(type, "DFUNC", INT2FIX(NDFUNC)); rb_define_const(type, "SFUNC", INT2FIX(NSFUNC)); rb_define_const(type, "IAFUNC", INT2FIX(NIAFUNC)); rb_define_const(type, "DAFUNC", INT2FIX(NDAFUNC)); rb_define_const(type, "SAFUNC", INT2FIX(NSAFUNC)); attr = rb_define_module_under(ngraph_module, "FIELD_PERMISSION"); rb_define_const(attr, "READ", INT2FIX(NREAD)); rb_define_const(attr, "WRITE", INT2FIX(NWRITE)); rb_define_const(attr, "EXEC", INT2FIX(NEXEC)); } static VALUE ngraph_class_new(VALUE self) { rb_raise(rb_eNotImpError, "%s: creation of an instance is forbidden.", rb_obj_classname(self)); return Qnil; } static VALUE nputs(VALUE module, VALUE str) { ngraph_puts(StringValueCStr(str)); return Qnil; } static VALUE nputerr(VALUE module, VALUE str) { ngraph_err_puts(StringValueCStr(str)); return Qnil; } static VALUE nsleep(VALUE module, VALUE arg) { double t; t = NUM2DBL(arg); ngraph_sleep(t); return Qnil; } static VALUE ngraph_str2inst(VALUE module, VALUE arg) { const char *str; VALUE ary; struct obj_ids obj_ids; str = StringValueCStr(arg); obj_ids.obj = ngraph_get_object_instances_by_str(str, &obj_ids.num, &obj_ids.ids); if (obj_ids.obj == NULL) { return Qnil; } ary = rb_ensure(str2inst_get_ary, (VALUE) &obj_ids, str2inst_ensure, (VALUE) obj_ids.ids); return ary; } static VALUE ngraph_save_hist(VALUE module) { ngraph_save_shell_history(); return Qnil; } static VALUE ruby_ngraph_init_file(VALUE module, VALUE arg) { char *file; const char *init_file; size_t len; init_file = StringValueCStr(arg); file = ngraph_get_init_file(init_file); if (file == NULL) { return Qnil; } len = strlen(file); return rb_enc_str_new(file, len, rb_utf8_encoding()); } static VALUE ruby_ngraph_exec_loginshell(VALUE module, VALUE cmd, VALUE nobj) { int r; size_t len; const char *str; char *loginshell; static struct ngraph_instance *inst; if (! rb_obj_is_kind_of(nobj, NgraphClass)) { rb_raise(rb_eArgError, "%s: illegal type of the argument (%s).", rb_obj_classname(module), rb_obj_classname(nobj)); } if (NIL_P(cmd)) { loginshell = NULL; } else { str = StringValueCStr(cmd); len = strlen(str) + 1; loginshell = ALLOCA_N(char, len); if (loginshell == NULL) { rb_raise(rb_eSysStackError, "%s: cannot allocate enough memory.", rb_obj_classname(module)); } strcpy(loginshell, str); } inst = check_id(nobj); r = ngraph_exec_loginshell(loginshell, inst->obj, inst->id); return INT2FIX(r); } static VALUE wrap_load_script(VALUE file) { rb_load(file, 1); return Qnil; } static int load_script(int argc, char **argv) { VALUE r_argv, fname; int state, i; if (argc < 1) { return 0; } r_argv = rb_const_get(rb_mKernel, rb_intern("ARGV")); rb_ary_clear(r_argv); for (i = 1; i < argc; i++) { rb_ary_push(r_argv, rb_tainted_str_new2(argv[i])); } fname = rb_funcall(rb_cFile, ExpandPath, 1, rb_str_new2(argv[0])); rb_protect(wrap_load_script, fname, &state); if (state) { VALUE errinfo, errstr, errat; int n, i; const char *cstr; errinfo = rb_errinfo(); errstr = rb_obj_as_string(errinfo); cstr = StringValueCStr(errstr); if (strcmp(cstr, "exit")) { ngraph_err_puts(cstr); errat = rb_funcall(errinfo, rb_intern("backtrace"), 0); if (! NIL_P(errat)) { n = RARRAY_LEN(errat); for (i = 0; i < n; i ++) { errstr = rb_str_new2("\tfrom "); rb_str_append(errstr, rb_ary_entry(errat, i)); ngraph_err_puts(StringValueCStr(errstr)); } } } } rb_gc_start(); return 0; } static VALUE ruby_ngraph_init(VALUE module, VALUE arg) { char *str; if (Initialized) { return Qnil; } if (! NIL_P(arg)) { str = strdup(StringValueCStr(arg)); if (str) { DummyArgv[0] = str; } } ngraph_initialize(&DummyArgc, &DummyArgvPtr); create_ngraph_classes(module, NgraphClass); Initialized = TRUE; ngraph_set_exec_func("ruby", load_script); return Qnil; } void Init_ngraph(void) { if (Initialized) { return; } Uniq = rb_intern("uniq"); ExpandPath = rb_intern("expand_path"); NgraphModule = rb_define_module("Ngraph"); rb_define_singleton_method(NgraphModule, "puts", nputs, 1); rb_define_singleton_method(NgraphModule, "err_puts", nputerr, 1); rb_define_singleton_method(NgraphModule, "sleep", nsleep, 1); rb_define_singleton_method(NgraphModule, "str2inst", ngraph_str2inst, 1); rb_define_singleton_method(NgraphModule, "save_shell_history", ngraph_save_hist, 0); rb_define_singleton_method(NgraphModule, "ngraph_initialize", ruby_ngraph_init, 1); rb_define_singleton_method(NgraphModule, "get_initialize_file", ruby_ngraph_init_file, 1); rb_define_singleton_method(NgraphModule, "execute_loginshell", ruby_ngraph_exec_loginshell, 2); NgraphClass = rb_define_class_under(NgraphModule, "NgraphObject", rb_cObject); rb_define_method(NgraphClass, "initialize", ngraph_class_new, 0); add_common_const(NgraphModule); } ngraph-gtk-6.08.00/plugins/ruby/lib/0000755000175000017500000000000013375640234014147 500000000000000ngraph-gtk-6.08.00/plugins/ruby/lib/ngraph.rb.osx0000644000175000017500000000067013070106167016500 00000000000000# -*- coding: utf-8 -*- rb_path = File.dirname(File.expand_path(__FILE__)) if (ENV['NGRAPH_APP_CONTENTS']) bin_path = ENV['NGRAPH_APP_CONTENTS'] + "/MacOS" else bin_path = File.dirname(File.dirname(File.dirname(rb_path))) + "/bin" end ENV['PATH'] += ":#{bin_path}" unless (ENV['PATH'].index(bin_path)) if (require "#{rb_path}/ngraph.bundle") Ngraph::ngraph_initialize(bin_path + "/Ngaph-GTK") end require "#{rb_path}/ngraph/ngp2" ngraph-gtk-6.08.00/plugins/ruby/lib/ngraph.rb.win0000644000175000017500000000056713070106167016471 00000000000000# -*- coding: utf-8 -*- rb_path = File.dirname(File.expand_path(__FILE__)) bin_path = File.dirname(File.dirname(rb_path)) + '/bin' win_bin_path = bin_path.gsub("/",'\\\\') ENV['PATH'] += ";#{win_bin_path}" unless (ENV['PATH'].index(win_bin_path)) if (require "#{rb_path}/ngraph.so") Ngraph::ngraph_initialize(bin_path + "/ngraph.exe") end require "#{rb_path}/ngraph/ngp2" ngraph-gtk-6.08.00/plugins/ruby/lib/ngraph/0000755000175000017500000000000013375640234015426 500000000000000ngraph-gtk-6.08.00/plugins/ruby/lib/ngraph/ngp2.rb0000644000175000017500000000732113070106167016536 00000000000000module Ngraph class Ngp2 NULL_DEVICE = "/dev/null" AUTO_SCALE = 1 AUTO_SCALE_FORCE = 2 attr_accessor :ignore_path, :auto_scale, :chdir, :dpi def initialize @ignore_path = false @auto_scale = nil @chdir = false @dpi = 86 @ngp_name = "" @path_name = "." @menu = Ngraph::Menu[0] || Ngraph::Menu.new @system = Ngraph::System[0] end def clear_viewer Ngraph::Draw.derive(true).each {|obj| obj.del("0-!") } Ngraph::Gra.del("viewer") end def copy_viewer(gra) viewer = Ngraph::Gra["viewer"][-1] gra.copy(viewer) if (viewer) gra.name = nil end def suppress_fitting_messages Ngraph::Fit.each {|fit| fit.display = false } end def save_image(format, file) gra2cairofile = Ngraph::Gra2cairofile.new gra = Ngraph::Gra.new copy_viewer(gra) gra2cairofile.format = format gra2cairofile.file = file gra2cairofile.dpi = @dpi suppress_fitting_messages gra.device = gra2cairofile gra.open gra.draw gra.close gra.del gra2cairofile.del end def save_gra(file) gra2cairofile = Ngraph::Gra2cairofile.new gra2cairofile.file = NULL_DEVICE dummy = Ngraph::Gra.new dummy.device = gra2cairofile dummy.open gra2file = Ngraph::Gra2file.new gra2file.file = file gra = Ngraph::Gra.new copy_viewer(gra) suppress_fitting_messages gra.device = gra2file gra.open gra.draw gra.close gra.del gra2file.del dummy.close dummy.del gra2cairofile.del end def auto_scale return unless (@auto_scale) files = Ngraph::File.to_a Ngraph::Axis.each {|axis| case @auto_scale when AUTO_SCALE_FORCE axis.clear axis.auto_scale(files) when AUTO_SCALE axis.auto_scale(files) end } Ngraph::Axis.each {|axis| axis.adjust } end def load_ngp(ngp_file) return unless (FileTest.readable?(ngp_file)) clear_viewer @ngp_name = ::File.basename(ngp_file, ".ngp") @path_name = ::File.dirname(ngp_file) @menu.fullpath_ngp = ngp_file if (@menu) Ngraph::Shell.new {|shell| shell.shell(ngp_file) } Ngraph::File.each {|file| file.file = ::File.basename(file) } if (@ignore_path) end def convert(format = Ngraph::Gra2cairofile::Format::EPS3, img_file = nil) pwd = Dir.pwd Dir.chdir(@path_name) if (@chdir) auto_scale rval = nil case format when Ngraph::Gra2cairofile::Format::PS3 save_image(format, img_file || "#{@ngp_name}.ps") when Ngraph::Gra2cairofile::Format::PS2 save_image(format, img_file || "#{@ngp_name}.ps") when Ngraph::Gra2cairofile::Format::EPS3 save_image(format, img_file || "#{@ngp_name}.eps") when Ngraph::Gra2cairofile::Format::EPS2 save_image(format, img_file || "#{@ngp_name}.eps") when Ngraph::Gra2cairofile::Format::PDF save_image(format, img_file || "#{@ngp_name}.pdf") when Ngraph::Gra2cairofile::Format::SVG1_1 save_image(format, img_file || "#{@ngp_name}.svg") when Ngraph::Gra2cairofile::Format::SVG1_2 save_image(format, img_file || "#{@ngp_name}.svg") when Ngraph::Gra2cairofile::Format::PNG save_image(format, img_file || "#{@ngp_name}.png") when "-" tmpfile = @system.temp_file save_gra(tmpfile) rval = IO.readlines(tmpfile) @system.unlink_temp_file(tmpfile) else save_gra(img_file || "#{@ngp_name}.gra") end Dir.chdir(pwd) if (@chdir) rval end end end ngraph-gtk-6.08.00/plugins/ruby/lib/ngraph.rb0000644000175000017500000000012513070106167015663 00000000000000if (require 'ngraph.so') Ngraph::ngraph_initialize(nil) end require 'ngraph/ngp2' ngraph-gtk-6.08.00/plugins/ruby/extconf.rb0000644000175000017500000000033313070106167015305 00000000000000prefix = ARGV.shift require 'mkmf' $configure_args["--vendor"] = true unless (prefix =~ /.*local.*/) dir_config("ngraph") have_header("ngraph.h") have_library("ngraph", "ngraph_get_object") create_makefile("ngraph") ngraph-gtk-6.08.00/plugins/ruby/getobj.nsc0000644000175000017500000000015413070106167015272 00000000000000#! /usr/bin/ngraph echo "#" > $1 for i in `object` do object $i >> $1 echo "#" >> $1 done del system ngraph-gtk-6.08.00/plugins/ruby/create_objs.rb0000644000175000017500000005554413070106167016135 00000000000000#! /usr/bin/ruby ADD_QUESTION_MARK_TO_BOOL_FIELD = false class Field attr_reader :name, :func, :argc def initialize(name, func, argc) @name = name @func = func @argc = argc end end class EnumItem attr_reader :const, :name, :num def initialize(enum, i) @const = enum.upcase.gsub(".", "_") @num = i @name = enum end end class Enum attr_reader :module, :enum, :max def initialize(name, enum) @module = name.capitalize i = 0; @enum = [] enum.each_with_index {|e, i| @enum.push(EnumItem.new(e, i)) } @max = enum.size - 1 end end class NgraphObj attr_reader :name, :fields attr_accessor :abstruct, :singleton SINGLETON_METHOD = [ ["new", "new", 0], ["[]", "get", 1], ["del", "del", 1], ["each", "each", 0], ["size", "size", 0], ["current", "current", 0], ] SINGLETON_METHOD2 = [ ["move_up", "move_up", 1], ["move_down", "move_down", 1], ["move_top", "move_top", 1], ["move_last", "move_last", 1], ["exchange", "exchange", 2], ["copy", "copy", 2], ] SINGLETON_METHOD3 = [ ["exist?", "exist", 0], ["get_field_args", "field_args", 1], ["get_field_type", "field_type", 1], ["get_field_permission", "field_permission", 1], ["derive", "derive", 1], ] FUNC_FIELD_COMMON = <<-EOF struct ngraph_instance *inst; inst = check_id(self); if (inst == NULL) { return Qnil; } EOF FUNC_FIELD_VAL = " ngraph_returned_value rval;\n" FUNC_FIELD_ARY = <<-EOF ngraph_returned_value rval; VALUE ary; int i; EOF def initialize(name, aliases, cfile, version, parent) @name = name @fields = [] @methods = [] @enum = {} @cfile = cfile @version = version @parent = (parent == "(null)") ? nil : parent @abstruct = false @singleton = false @func = "" @alias = if (aliases) aliases.split(":").map {|s| s.capitalize} else [] end end def put_indented_str(s) @cfile.puts(s.gsub(/^ /, "")) end def add_singleton_method_func(method, func, argc) @cfile.puts("static VALUE") @cfile.print("#{@name}_#{func}(VALUE klass") if (argc > 0) @cfile.print(", ") argc.times { |i| @cfile.print("VALUE arg#{i}") if (i == argc - 1) @cfile.puts(")\n{") else @cfile.print(", ") end } else @cfile.puts(")\n{") end @cfile.print(" return obj_#{func}(klass, ") argc.times { |i| @cfile.print("arg#{i}, ") } @cfile.puts(%Q!"#{@name}");\n}!); end def create_obj unless (@abstruct) put_indented_str(@func) SINGLETON_METHOD.each { |method, func, argc| add_singleton_method_func(method, func, argc) } unless (@singleton) SINGLETON_METHOD2.each { |method, func, argc| add_singleton_method_func(method, func, argc) } end end SINGLETON_METHOD3.each { |method, func, argc| add_singleton_method_func(method, func, argc) } @enum.each { |key, val| put_indented_str <<-EOF static VALUE #{@name}_get_#{val.module}(VALUE klass, VALUE arg) { int i; i = VAL2INT(arg); switch (i) { EOF val.enum.each { |enum| @cfile.puts(" case #{enum.num}:") @cfile.puts(%Q! return rb_str_new2("#{enum.name}");!) } put_indented_str <<-EOF } return Qnil; } EOF } put_indented_str <<-EOF static void create_#{@name}_object(VALUE ngraph_module, VALUE ngraph_class) { VALUE obj; VALUE fields; #{(@enum.size > 0) ? " VALUE module;" : ""} obj = rb_define_class_under(ngraph_module, "#{@name.capitalize}", ngraph_class); EOF @alias.each {|name| @cfile.puts(%Q! rb_define_const(ngraph_module, "#{name}", obj);!) } unless (@abstruct) SINGLETON_METHOD.each { |method, func, argc| @cfile.puts(%Q! rb_define_singleton_method(obj, "#{method}", #{@name}_#{func}, #{argc});!) } unless (@singleton) SINGLETON_METHOD2.each { |method, func, argc| @cfile.puts(%Q! rb_define_singleton_method(obj, "#{method}", #{@name}_#{func}, #{argc});!) } end end SINGLETON_METHOD3.each { |method, func, argc| @cfile.puts(%Q! rb_define_singleton_method(obj, "#{method}", #{@name}_#{func}, #{argc});!) } @cfile.puts(" setup_obj_common(obj);") unless (@abstruct) put_indented_str <<-EOF add_obj_const(obj, "#{@name}"); fields = rb_ary_new2(#{@fields.size}); rb_define_const(obj, "FIELDS", fields); EOF @fields.each_with_index { |field, i| @cfile.puts(%Q! store_field_names(fields, "#{field}");!) } @cfile.puts(" OBJ_FREEZE(fields);") unless (@abstruct) @methods.each { |field| @cfile.puts(%Q! rb_define_method(obj, "#{field.name}", #{field.func}, #{field.argc});!) } end @enum.each { |key, val| @cfile.puts(%Q! module = rb_define_module_under(obj, "#{val.module}");!) @cfile.puts(%Q! rb_extend_object(module, rb_mEnumerable);!) @cfile.puts(%Q! rb_define_singleton_method(module, "[]", #{@name}_get_#{val.module}, 1);!) val.enum.each { |enum| @cfile.puts(%Q! rb_define_const(module, "#{enum.const}", INT2FIX(#{enum.num}));!) } } @cfile.puts("}") end def create_rw_field_func(func, rw, type, field) if (rw == "put") parm = ", VALUE arg" arg = ", arg" else arg = "" parm = "" end @func += <<-EOF static VALUE #{func}(VALUE self#{parm}) { return inst_#{rw}_#{type}(self#{arg}, "#{field}"); } EOF end def create_put_obj_func(func, field) create_rw_field_func(func, "put", "obj", field) end def create_get_obj_func(func, field) create_rw_field_func(func, "get", "obj", field) end def create_put_str_func(func, field) create_rw_field_func(func, "put", "str", field) end def create_get_str_func(func, field) create_rw_field_func(func, "get", "str", field) end def create_put_int_func(func, field) create_rw_field_func(func, "put", "int", field) end def create_get_int_func(func, field) create_rw_field_func(func, "get", "int", field) end def create_put_double_func(func, field) create_rw_field_func(func, "put", "double", field) end def create_get_double_func(func, field) create_rw_field_func(func, "get", "double", field) end def create_put_bool_func(func, field) create_rw_field_func(func, "put", "bool", field) end def create_get_bool_func(func, field) create_rw_field_func(func, "get", "bool", field) end def create_put_enum_func(func, field, enum) @func += <<-EOF static VALUE #{func}(VALUE self, VALUE arg) { return inst_put_enum(self, arg, "#{field}", #{enum.max}); } EOF end def add_enum(field, ary) return @enum[field] if (@enum[field]) enum = Enum.new(field, ary) @enum[field] = enum enum end def create_get_enum_func(func, field) create_rw_field_func(func, "get", "int", field) end def create_put_int_array_func(func, field) create_rw_field_func(func, "put", "iarray", field) end def create_get_int_array_func(func, field) create_rw_field_func(func, "get", "iarray", field) end def create_put_double_array_func(func, field) create_rw_field_func(func, "put", "darray", field) end def create_get_double_array_func(func, field) create_rw_field_func(func, "get", "darray", field) end def create_put_str_array_func(func, field) create_rw_field_func(func, "put", "sarray", field) end def create_get_str_array_func(func, field) create_rw_field_func(func, "get", "sarray", field) end def field2method(field) method = field.gsub("-", "_").gsub("%", "prm") method = "value" if (method == "@") method.downcase end def add_put_method(ary) field = ary[1] type = ary[2] method = field2method(field) func = "#{@name}_field_put_#{method}" case type when "bool" create_put_bool_func(func, field) when "int" create_put_int_func(func, field) when "double" create_put_double_func(func, field) when "obj" create_put_obj_func(func, field) when "char*" create_put_str_func(func, field) when "enum(" n = ary.size - 4 enum = add_enum(field, ary[3, n]) create_put_enum_func(func, field, enum) when "int[]" create_put_int_array_func(func, field) when "double[]" create_put_double_array_func(func, field) when "char*[]" create_put_str_array_func(func, field) end field = Field.new("#{method}=", func, 1) @methods.push(field) end def add_get_method(ary) field = ary[1] type = ary[2] method = field2method(field) func = "#{@name}_field_get_#{method}" case type when "bool" create_get_bool_func(func, field) method += "?" if (ADD_QUESTION_MARK_TO_BOOL_FIELD) when "int" create_get_int_func(func, field) when "double" create_get_double_func(func, field) when "obj" create_get_obj_func(func, field) when "char*" create_get_str_func(func, field) when "enum(" n = ary.size - 4 add_enum(field, ary[3, n]) create_get_enum_func(func, field) when "int[]" create_get_int_array_func(func, field) when "double[]" create_get_double_array_func(func, field) when "char*[]" create_get_str_array_func(func, field) end field = Field.new("#{method}", func, 0) @methods.push(field) end def create_void_exe_func(func, field) @func += <<-EOF static VALUE #{func}(VALUE self) { return inst_exe_void_func(self, "#{field}"); } EOF end def check_args(ary) n = ary.size - 4 case (n) when 0 [-2, []] when 1 if (ary[3][-1] == "]") [-2, ary[3, n]] elsif (ary[3] == "void") [0, []] else [-1, ary[3, n]] end else [-1, ary[3, n]] end end def create_func_type(func, args) @func += "static VALUE\n#{func}(int argc, VALUE *argv, VALUE self)\n{\n" @func += " VALUE arg[#{args.size}];\n" @func += " VALUE tmpstr;\n" if (args.find {|s| s[-1] == "]"}) @func += " ngraph_arg *carg;\n" end def create_arguments(field, args) array = false @func += (%Q! rb_scan_args(argc, argv, "0#{args.size}", !) args.size.times { |i| @func += ("arg + #{i}") if (i == args.size - 1) @func += (");\n") else @func += (", ") end } @func += (" carg = alloca(sizeof(*carg) + sizeof(ngraph_value) * #{args.size});\n") @func += (%Q! if (carg == NULL) {\n rb_raise(rb_eSysStackError, "%s: cannot allocate enough memory.", rb_obj_classname(self));\n }\n!) @func += (" carg->num = #{args.size};\n") args.each_with_index { |arg, i| case arg when "int" @func += (" carg->ary[#{i}].i = VAL2INT(arg[#{i}]);\n") when "double" @func += (" carg->ary[#{i}].d = VAL2DBL(arg[#{i}]);\n") when "char*" @func += (" carg->ary[#{i}].str = VAL2STR(arg[#{i}]);\n") when "bool" @func += (" carg->ary[#{i}].i = RTEST(arg[#{i}]) ? 1 : 0;\n") when "int[]" @func += (%Q! carg->ary[#{i}].ary = allocate_iarray(self, &tmpstr, arg[#{i}], "#{field}");\n!) array = true when "double[]" @func += (%Q! carg->ary[#{i}].ary = allocate_darray(self, &tmpstr, arg[#{i}], "#{field}");\n!) array = true when "char*[]" @func += (%Q! carg->ary[#{i}].ary = allocate_sarray(self, &tmpstr, arg[#{i}], "#{field}");\n!) array = true end } array end def create_finalize_arguments(args) args.each_with_index { |arg, i| case arg when "int[]", "double[]", "char*[]" @func += (" if (carg->ary[#{i}].ary) {\n rb_free_tmp_buffer(&tmpstr);\n }\n") end } end def add_arg_array(arg, field) unless (arg) @func += %Q! carg = allocate_sarray(self, &tmpstr, argv, "#{field}");\n! return end case (arg) when "int[]" @func += %Q! carg.ary[0].ary = allocate_iarray(self, &tmpstr, argv, "#{field}");\n! when "double[]" @func += %Q! carg.ary[0].ary = allocate_darray(self, &tmpstr, argv, "#{field}");\n! when "char*[]" @func += %Q! carg.ary[0].ary = allocate_sarray(self, &tmpstr, argv, "#{field}");\n! else @func += %Q! carg.ary[0].ary = allocate_sarray(self, &tmpstr, argv, "#{field}");\n! end @func += " carg.num = 1;\n" end def create_val_func_with_argv(func, field, args, comv) varg = (args.size == 0) @func += ("static VALUE\n#{func}(VALUE self, VALUE argv)\n{\n") @func += (" VALUE tmpstr;\n") @func += (FUNC_FIELD_VAL) @func += " ngraph_arg #{(varg) ? '*' : ''}carg;\n" @func += (FUNC_FIELD_COMMON) add_arg_array(args[0], field) @func += <<-EOF inst->rcode = ngraph_object_get(inst->obj, "#{field}", inst->id, #{varg ? '' : '&'}carg, &rval); rb_free_tmp_buffer(&tmpstr); if (inst->rcode < 0) { return Qnil; } return #{comv}; } EOF end def create_void_func_with_argv(func, field, args) varg = (args.size == 0) @func += <<-EOF static VALUE #{func}(VALUE self, VALUE argv) { struct ngraph_instance *inst; ngraph_arg #{(varg) ? '*' : ''}carg; VALUE tmpstr; inst = check_id(self); if (inst == NULL) { return Qnil; } EOF add_arg_array(args[0], field) @func += <<-EOF inst->rcode = ngraph_object_exe(inst->obj, "#{field}", inst->id, #{varg ? '' : '&'}carg); rb_free_tmp_buffer(&tmpstr); if (inst->rcode < 0) { return Qnil; } return self; } EOF end def create_array_func_with_argv(func, field, args, comv) varg = (args.size == 0) @func += ("static VALUE\n#{func}(VALUE self, VALUE argv)\n{") @func += (" VALUE tmpstr;\n") @func += (FUNC_FIELD_ARY) @func += " ngraph_arg #{(varg) ? '*' : ''}carg;\n" @func += (FUNC_FIELD_COMMON) add_arg_array(args[0], field) @func += <<-EOF inst->rcode = ngraph_object_get(inst->obj, "#{field}", inst->id, #{varg ? '' : '&'}carg, &rval); rb_free_tmp_buffer(&tmpstr); if (inst->rcode < 0) { return Qnil; } ary = rb_ary_new2(rval.ary.num); for (i = 0; i < rval.ary.num; i++) { rb_ary_store(ary, i, #{comv}); } return ary; } EOF end def create_val_func_with_args(func, field, args, conv) create_func_type(func, args) @func += (FUNC_FIELD_VAL) @func += (FUNC_FIELD_COMMON) array = create_arguments(field, args) @func += (%Q! inst->rcode = ngraph_object_get(inst->obj, "#{field}", inst->id, carg, &rval);\n!) @func += (%Q! rb_free_tmp_buffer(&tmpstr);\n!) if (array) @func += <<-EOF if (inst->rcode < 0) { return Qnil; } return #{conv}; } EOF end def create_void_func_with_args(func, field, args) create_func_type(func, args) @func += (FUNC_FIELD_COMMON) array = create_arguments(field, args) @func += (%Q! inst->rcode = ngraph_object_exe(inst->obj, "#{field}", inst->id, carg);\n!) @func += (%Q! rb_free_tmp_buffer(&tmpstr);\n!) if (array) @func += <<-EOF if (inst->rcode < 0) { return Qnil; } return self; } EOF end def create_array_func_with_args(func, field, args, comv) create_func_type(func, args) @func += (FUNC_FIELD_ARY) @func += (FUNC_FIELD_COMMON) array = create_arguments(field, args) @func += (%Q! inst->rcode = ngraph_object_get(inst->obj, "#{field}", inst->id, carg, &rval);\n!) @func += (%Q! rb_free_tmp_buffer(&tmpstr);\n!) if (array) @func += <<-EOF if (inst->rcode < 0) { return Qnil; } ary = rb_ary_new2(rval.ary.num); for (i = 0; i < rval.ary.num; i++) { rb_ary_store(ary, i, #{comv}); } return ary; } EOF end def create_bool_func_with_args(func, field, args) create_val_func_with_args(func, field, args, 'rval.i ? Qtrue : Qfalse') end def create_int_func_with_args(func, field, args) create_val_func_with_args(func, field, args, 'INT2NUM(rval.i)') end def create_double_func_with_args(func, field, args) create_val_func_with_args(func, field, args, 'rb_float_new(rval.d)') end def create_str_func_with_args(func, field, args) create_val_func_with_args(func, field, args, 'tainted_utf8_str_new(rval.str ? rval.str : "")') end def create_bool_func_with_argv(func, field, args) create_val_func_with_argv(func, field, args, 'rval.i ? Qtrue : Qfalse') end def create_int_func_with_argv(func, field, args) create_val_func_with_argv(func, field, args, 'INT2NUM(rval.i)') end def create_double_func_with_argv(func, field, args) create_val_func_with_argv(func, field, args, 'rb_float_new(rval.d)') end def create_str_func_with_argv(func, field, args) create_val_func_with_argv(func, field, args, 'tainted_utf8_str_new(rval.str ? rval.str : "")') end def add_bool_func(func, field, argc, args) case (argc) when 0 create_get_bool_func(func, field) when -2 create_bool_func_with_argv(func, field, args) else create_bool_func_with_args(func, field, args) end end def add_int_func(func, field, argc, args) case (argc) when 0 create_get_int_func(func, field) when -2 create_int_func_with_argv(func, field, args) else create_int_func_with_args(func, field, args) end end def add_double_func(func, field, argc, args) case (argc) when 0 create_get_double_func(func, field) when -2 create_double_func_with_argv(func, field, args) else create_double_func_with_args(func, field, args) end end def add_str_func(func, field, argc, args) case (argc) when 0 create_get_str_func(func, field) when -2 create_str_func_with_argv(func, field, args) else create_str_func_with_args(func, field, args) end end def add_int_array_func(func, field, argc, args) case (argc) when 0 create_get_int_array_func(func, field) when -2 create_array_func_with_argv(func, field, args, 'INT2NUM(rval.ary.data.ia[i])') else create_array_func_with_args(func, field, args, 'INT2NUM(rval.ary.data.ia[i])') end end def add_double_array_func(func, field, argc, args) case (argc) when 0 create_get_double_array_func(func, field) when -2 create_array_func_with_argv(func, field, args, 'rb_float_new(rval.ary.data.da[i])') else create_array_func_with_args(func, field, args, 'rb_float_new(rval.ary.data.da[i])') end end def add_str_array_func(func, field, argc, args) case (argc) when 0 create_get_str_array_func(func, field) when -2 create_array_func_with_argv(func, field, args, 'tainted_utf8_str_new(rval.ary.data.sa[i] ? rval.ary.data.sa[i] : "")') else create_array_func_with_args(func, field, args, 'tainted_utf8_str_new(rval.ary.data.sa[i] ? rval.ary.data.sa[i] : "")') end end def add_void_func(func, field, argc, args) case (argc) when 0 create_void_exe_func(func, field) when -2 create_void_func_with_argv(func, field, args) else create_void_func_with_args(func, field, args) end end def add_func_obj(type, func, field, args) rtype = case type when "bool(" "NBFUNC" when "int(" "NIFUNC" when "char*(" "NSFUNC" when "int[](" "NIAFUNC" when "double[](" "NDAFUNC" when "char*[](" "NSAFUNC" when "void(" "NVFUNC" else "NVFUNC" end @func += <<-EOF static VALUE #{func}(VALUE self, VALUE argv) { return obj_func_obj(self, argv, "#{field}", #{rtype}); } EOF end def add_func_method(ary) field = ary[1] type = ary[2] method = field2method(field) func = "#{@name}_field_#{method}" argc, args = check_args(ary) if (ary[3] == "obj") argc = -2; add_func_obj(type, func, field, args) else case type when "bool(" add_bool_func(func, field, argc, args) when "int(" add_int_func(func, field, argc, args) when "double(" add_double_func(func, field, argc, args) when "char*(" add_str_func(func, field, argc, args) when "int[](" add_int_array_func(func, field, argc, args) when "double[](" add_double_array_func(func, field, argc, args) when "char*[](" add_str_array_func(func, field, argc, args) when "void(" add_void_func(func, field, argc, args) end end if (ADD_QUESTION_MARK_TO_BOOL_FIELD) method += "?" if (type == "bool(") end field = Field.new("#{method}", func, argc) @methods.push(field) end def add_method(ary) case ary[0] when "-w-" add_put_method(ary) when "r--" add_get_method(ary) when "r-x" add_func_method(ary) when "rw-" add_put_method(ary) add_get_method(ary) end end end def create_obj_funcs(file, cfile, name, aliases, version, parent) obj = NgraphObj.new(name, aliases, cfile, version, parent) singleton = true while (true) ary = file.gets.chomp.split singleton = false if (ary[1] == "next") case ary[0] when "#" break when "---" obj.abstruct = true if (ary[1] == "init") when "--x" # can't execute when "r--" obj.add_method(ary) when "-w-" # obj.add_method(ary) # only used for backword compatibility. when "r-x" obj.add_method(ary) when "rw-" obj.add_method(ary) else next end obj.fields.push(ary[1]) end obj.singleton = singleton obj.create_obj obj end objs = [] File.open(ARGV[1], "w") { |cfile| File.open(ARGV[0], "r") { |file| while (l = file.gets) str_ary = l.chomp.split case (str_ary[0]) when "object:" name = str_ary[1] next when "alias:" aliases = str_ary[1] next when "version:" version = str_ary[1] next when "parent:" parent = str_ary[1] else next end obj = create_obj_funcs(file, cfile, name, aliases, version, parent) objs.push(obj) end } str = <<-EOF static void create_ngraph_classes(VALUE ngraph_module, VALUE ngraph_class) { VALUE objs; objs = rb_ary_new2(#{objs.size}); rb_define_const(ngraph_module, "OBJECTS", objs); EOF cfile.puts(str.gsub(/^ /, "")) objs.each_with_index {|obj, i| cfile.puts(" create_#{obj.name}_object(ngraph_module, ngraph_class);\n") cfile.puts(%Q! rb_ary_store(objs, #{i}, ID2SYM(rb_intern("#{obj.name.capitalize}")));\n!) } cfile.puts(" OBJ_FREEZE(objs);\n") cfile.puts("}") } ngraph-gtk-6.08.00/plugins/ruby/Makefile.am0000644000175000017500000000351113363041667015357 00000000000000EXTRA_DIST = create_objs.rb extconf.rb getobj.nsc ngraph.c lib/ngraph.rb lib/ngraph.rb.win lib/ngraph.rb.osx lib/ngraph/ngp2.rb if HAVE_RUBY_DEV ruby_ext = ngraph.$(RUBY_DLEXT) if OS_OSX $(ruby_ext): ngraph.c ruby_ngraph.h mv Makefile Makefile.org ARCHFLAGS="-arch x86_64" ruby $(srcdir)/extconf.rb $(prefix) --with-ngraph-include=$(top_srcdir)/src --with-ngraph-lib=$(top_builddir)/src/.libs $(MAKE) $(AM_MAKEFLAGS) mv Makefile Makefile.ruby mv Makefile.org Makefile else $(ruby_ext): ngraph.c ruby_ngraph.h mv Makefile Makefile.org ruby $(srcdir)/extconf.rb $(prefix) --with-ngraph-include=$(top_srcdir)/src --with-ngraph-lib=$(top_builddir)/src/.libs $(MAKE) $(AM_MAKEFLAGS) mv Makefile Makefile.ruby mv Makefile.org Makefile endif if OS_WIN32 install-data-local: $(ruby_ext) $(MKDIR_P) $(DESTDIR)$(pkglibdir)/ruby/ngraph $(INSTALL) $(builddir)/$(ruby_ext) $(DESTDIR)$(pkglibdir)/ruby/$(ruby_ext) $(INSTALL_DATA) $(srcdir)/lib/ngraph.rb.win $(DESTDIR)$(pkglibdir)/ruby/ngraph.rb $(INSTALL_DATA) $(srcdir)/lib/ngraph/ngp2.rb $(DESTDIR)$(pkglibdir)/ruby/ngraph/ngp2.rb else if OS_OSX install-data-local: $(ruby_ext) $(MKDIR_P) $(DESTDIR)$(pkglibdir)/ruby/ngraph $(INSTALL) $(builddir)/$(ruby_ext) $(DESTDIR)$(pkglibdir)/ruby/$(ruby_ext) $(INSTALL_DATA) $(srcdir)/lib/ngraph.rb.osx $(DESTDIR)$(pkglibdir)/ruby/ngraph.rb $(INSTALL_DATA) $(srcdir)/lib/ngraph/ngp2.rb $(DESTDIR)$(pkglibdir)/ruby/ngraph/ngp2.rb else install-data-local: $(ruby_ext) $(MAKE) -f Makefile.ruby install endif endif obj.txt: getobj.nsc $(top_builddir)/src/libngraph.la $(top_builddir)/src/ngraph -i $(srcdir)/getobj.nsc > $(srcdir)/obj.txt ruby_ngraph.h: obj.txt ruby $(srcdir)/create_objs.rb $(srcdir)/obj.txt $(srcdir)/ruby_ngraph.h BUILT_SOURCES = $(ruby_ext) CLEANFILES = mkmf.log obj.txt ruby_ngraph.h $(ruby_ext) Makefile.ruby ngraph.o .*.time endif ngraph-gtk-6.08.00/plugins/ruby/Makefile.in0000644000175000017500000004060513367273153015376 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = plugins/ruby ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ EXTRA_DIST = create_objs.rb extconf.rb getobj.nsc ngraph.c lib/ngraph.rb lib/ngraph.rb.win lib/ngraph.rb.osx lib/ngraph/ngp2.rb @HAVE_RUBY_DEV_TRUE@ruby_ext = ngraph.$(RUBY_DLEXT) @HAVE_RUBY_DEV_TRUE@BUILT_SOURCES = $(ruby_ext) @HAVE_RUBY_DEV_TRUE@CLEANFILES = mkmf.log obj.txt ruby_ngraph.h $(ruby_ext) Makefile.ruby ngraph.o .*.time all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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) --gnu plugins/ruby/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu plugins/ruby/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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 tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-am all-am: Makefile installdirs: install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) @HAVE_RUBY_DEV_FALSE@install-data-local: 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-data-local 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: .MAKE: all check install 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-data-local 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 .PRECIOUS: Makefile @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@$(ruby_ext): ngraph.c ruby_ngraph.h @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@ mv Makefile Makefile.org @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@ ARCHFLAGS="-arch x86_64" ruby $(srcdir)/extconf.rb $(prefix) --with-ngraph-include=$(top_srcdir)/src --with-ngraph-lib=$(top_builddir)/src/.libs @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@ $(MAKE) $(AM_MAKEFLAGS) @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@ mv Makefile Makefile.ruby @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@ mv Makefile.org Makefile @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@$(ruby_ext): ngraph.c ruby_ngraph.h @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@ mv Makefile Makefile.org @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@ ruby $(srcdir)/extconf.rb $(prefix) --with-ngraph-include=$(top_srcdir)/src --with-ngraph-lib=$(top_builddir)/src/.libs @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@ $(MAKE) $(AM_MAKEFLAGS) @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@ mv Makefile Makefile.ruby @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@ mv Makefile.org Makefile @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@install-data-local: $(ruby_ext) @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(MKDIR_P) $(DESTDIR)$(pkglibdir)/ruby/ngraph @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(INSTALL) $(builddir)/$(ruby_ext) $(DESTDIR)$(pkglibdir)/ruby/$(ruby_ext) @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(INSTALL_DATA) $(srcdir)/lib/ngraph.rb.win $(DESTDIR)$(pkglibdir)/ruby/ngraph.rb @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(INSTALL_DATA) $(srcdir)/lib/ngraph/ngp2.rb $(DESTDIR)$(pkglibdir)/ruby/ngraph/ngp2.rb @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@@OS_WIN32_FALSE@install-data-local: $(ruby_ext) @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@@OS_WIN32_FALSE@ $(MKDIR_P) $(DESTDIR)$(pkglibdir)/ruby/ngraph @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@@OS_WIN32_FALSE@ $(INSTALL) $(builddir)/$(ruby_ext) $(DESTDIR)$(pkglibdir)/ruby/$(ruby_ext) @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@@OS_WIN32_FALSE@ $(INSTALL_DATA) $(srcdir)/lib/ngraph.rb.osx $(DESTDIR)$(pkglibdir)/ruby/ngraph.rb @HAVE_RUBY_DEV_TRUE@@OS_OSX_TRUE@@OS_WIN32_FALSE@ $(INSTALL_DATA) $(srcdir)/lib/ngraph/ngp2.rb $(DESTDIR)$(pkglibdir)/ruby/ngraph/ngp2.rb @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@@OS_WIN32_FALSE@install-data-local: $(ruby_ext) @HAVE_RUBY_DEV_TRUE@@OS_OSX_FALSE@@OS_WIN32_FALSE@ $(MAKE) -f Makefile.ruby install @HAVE_RUBY_DEV_TRUE@obj.txt: getobj.nsc $(top_builddir)/src/libngraph.la @HAVE_RUBY_DEV_TRUE@ $(top_builddir)/src/ngraph -i $(srcdir)/getobj.nsc > $(srcdir)/obj.txt @HAVE_RUBY_DEV_TRUE@ruby_ngraph.h: obj.txt @HAVE_RUBY_DEV_TRUE@ ruby $(srcdir)/create_objs.rb $(srcdir)/obj.txt $(srcdir)/ruby_ngraph.h # 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: ngraph-gtk-6.08.00/plugins/libruby_resource.rc.in0000644000175000017500000000107613070106167016650 000000000000001 VERSIONINFO FILEVERSION %VERSION% PRODUCTVERSION %VERSION% BEGIN BLOCK "StringFileInfo" BEGIN BLOCK "040904B0" BEGIN VALUE "CompanyName", "" VALUE "FileDescription", "Ngraph-gtk" VALUE "FileVersion", "%VERSION%" VALUE "InternalName", "libruby" VALUE "LegalCopyright", "Copyright (C) 2003 Satoshi ISHIZAKA" VALUE "OriginalFilename", "libruby.dll" VALUE "ProductName", "Ngraph-gtk" VALUE "ProductVersion", "%VERSION%" END END BLOCK "VarFileInfo" BEGIN VALUE "Translation", 0x409, 1252 END END ngraph-gtk-6.08.00/plugins/Makefile.am0000644000175000017500000000244413247521473014401 00000000000000SUBDIRS = ruby extra_dist_common = libruby.def libruby_resource.rc.in if HAVE_RUBY_DEV ngraphplugindir = $(pkglibdir)/plugins RUBY_INCRUDEDIR = `ruby -r rbconfig -e "print RbConfig::CONFIG['rubyhdrdir']"` RUBY_ARCH = `ruby -r rbconfig -e "print RbConfig::CONFIG['rubyarchhdrdir']"` built_sources = clean_files = ngraphplugin_LTLIBRARIES = libruby.la libruby_la_SOURCES = ruby.c libruby_la_CFLAGS = -I$(top_srcdir) -I $(RUBY_INCRUDEDIR) -I $(RUBY_ARCH) libruby_ldflags = -L$(top_builddir)/src -avoid-version -module `ruby -e 'puts(RbConfig::CONFIG["LIBRUBYARG_SHARED"])'` if OS_WIN32 libruby_ldflags += -no-undefined -L`ruby -e 'puts(RbConfig::CONFIG["libdir"])'` -export-symbols $(srcdir)/libruby.def -Wl,$(builddir)/libruby_resource.o built_sources += libruby_resource.o libruby_la_LIBADD = -lngraph clean_files += libruby_resource.rc libruby_resource.rc: libruby_resource.rc.in $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ .rc.o: $(WINDRES) -o $@ $< endif libruby_la_LDFLAGS = $(libruby_ldflags) extra_dist = $(extra_dist_common) libruby_la_DEPENDENCIES = $(top_builddir)/src/libngraph.la else extra_dist = $(extra_dist_common) ruby.c endif EXTRA_DIST = $(extra_dist) BUILT_SOURCES = $(built_sources) CLEANFILES = $(BUILT_SOURCES) $(clean_files) ngraph-gtk-6.08.00/plugins/Makefile.in0000644000175000017500000007210413367273153014414 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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@ @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@am__append_1 = -no-undefined -L`ruby -e 'puts(RbConfig::CONFIG["libdir"])'` -export-symbols $(srcdir)/libruby.def -Wl,$(builddir)/libruby_resource.o @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@am__append_2 = libruby_resource.o @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@am__append_3 = libruby_resource.rc @HAVE_RUBY_DEV_FALSE@libruby_la_DEPENDENCIES = subdir = plugins ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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)$(ngraphplugindir)" LTLIBRARIES = $(ngraphplugin_LTLIBRARIES) am__libruby_la_SOURCES_DIST = ruby.c @HAVE_RUBY_DEV_TRUE@am_libruby_la_OBJECTS = libruby_la-ruby.lo libruby_la_OBJECTS = $(am_libruby_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 = libruby_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(libruby_la_CFLAGS) \ $(CFLAGS) $(libruby_la_LDFLAGS) $(LDFLAGS) -o $@ @HAVE_RUBY_DEV_TRUE@am_libruby_la_rpath = -rpath $(ngraphplugindir) 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__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libruby_la-ruby.Plo 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 = $(libruby_la_SOURCES) DIST_SOURCES = $(am__libruby_la_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 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 distdir-am 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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ SUBDIRS = ruby extra_dist_common = libruby.def libruby_resource.rc.in @HAVE_RUBY_DEV_TRUE@ngraphplugindir = $(pkglibdir)/plugins @HAVE_RUBY_DEV_TRUE@RUBY_INCRUDEDIR = `ruby -r rbconfig -e "print RbConfig::CONFIG['rubyhdrdir']"` @HAVE_RUBY_DEV_TRUE@RUBY_ARCH = `ruby -r rbconfig -e "print RbConfig::CONFIG['rubyarchhdrdir']"` @HAVE_RUBY_DEV_TRUE@built_sources = $(am__append_2) @HAVE_RUBY_DEV_TRUE@clean_files = $(am__append_3) @HAVE_RUBY_DEV_TRUE@ngraphplugin_LTLIBRARIES = libruby.la @HAVE_RUBY_DEV_TRUE@libruby_la_SOURCES = ruby.c @HAVE_RUBY_DEV_TRUE@libruby_la_CFLAGS = -I$(top_srcdir) -I $(RUBY_INCRUDEDIR) -I $(RUBY_ARCH) @HAVE_RUBY_DEV_TRUE@libruby_ldflags = -L$(top_builddir)/src \ @HAVE_RUBY_DEV_TRUE@ -avoid-version -module `ruby -e \ @HAVE_RUBY_DEV_TRUE@ 'puts(RbConfig::CONFIG["LIBRUBYARG_SHARED"])'` \ @HAVE_RUBY_DEV_TRUE@ $(am__append_1) @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@libruby_la_LIBADD = -lngraph @HAVE_RUBY_DEV_TRUE@libruby_la_LDFLAGS = $(libruby_ldflags) @HAVE_RUBY_DEV_FALSE@extra_dist = $(extra_dist_common) ruby.c @HAVE_RUBY_DEV_TRUE@extra_dist = $(extra_dist_common) @HAVE_RUBY_DEV_TRUE@libruby_la_DEPENDENCIES = $(top_builddir)/src/libngraph.la EXTRA_DIST = $(extra_dist) BUILT_SOURCES = $(built_sources) CLEANFILES = $(BUILT_SOURCES) $(clean_files) all: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) all-recursive .SUFFIXES: .SUFFIXES: .c .lo .o .obj .rc $(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) --gnu plugins/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu plugins/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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-ngraphpluginLTLIBRARIES: $(ngraphplugin_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(ngraphplugin_LTLIBRARIES)'; test -n "$(ngraphplugindir)" || 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)$(ngraphplugindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(ngraphplugindir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(ngraphplugindir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(ngraphplugindir)"; \ } uninstall-ngraphpluginLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(ngraphplugin_LTLIBRARIES)'; test -n "$(ngraphplugindir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(ngraphplugindir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(ngraphplugindir)/$$f"; \ done clean-ngraphpluginLTLIBRARIES: -test -z "$(ngraphplugin_LTLIBRARIES)" || rm -f $(ngraphplugin_LTLIBRARIES) @list='$(ngraphplugin_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}; \ } libruby.la: $(libruby_la_OBJECTS) $(libruby_la_DEPENDENCIES) $(EXTRA_libruby_la_DEPENDENCIES) $(AM_V_CCLD)$(libruby_la_LINK) $(am_libruby_la_rpath) $(libruby_la_OBJECTS) $(libruby_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libruby_la-ruby.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .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 $@ $< libruby_la-ruby.lo: ruby.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libruby_la_CFLAGS) $(CFLAGS) -MT libruby_la-ruby.lo -MD -MP -MF $(DEPDIR)/libruby_la-ruby.Tpo -c -o libruby_la-ruby.lo `test -f 'ruby.c' || echo '$(srcdir)/'`ruby.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libruby_la-ruby.Tpo $(DEPDIR)/libruby_la-ruby.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='ruby.c' object='libruby_la-ruby.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libruby_la_CFLAGS) $(CFLAGS) -c -o libruby_la-ruby.lo `test -f 'ruby.c' || echo '$(srcdir)/'`ruby.c 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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) check-recursive all-am: Makefile $(LTLIBRARIES) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(ngraphplugindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) 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." -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) clean: clean-recursive clean-am: clean-generic clean-libtool clean-ngraphpluginLTLIBRARIES \ mostlyclean-am distclean: distclean-recursive -rm -f ./$(DEPDIR)/libruby_la-ruby.Plo -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-ngraphpluginLTLIBRARIES 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 ./$(DEPDIR)/libruby_la-ruby.Plo -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-ngraphpluginLTLIBRARIES .MAKE: $(am__recursive_targets) all check install install-am \ install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--depfiles check check-am clean clean-generic clean-libtool \ clean-ngraphpluginLTLIBRARIES 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-ngraphpluginLTLIBRARIES \ 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-ngraphpluginLTLIBRARIES .PRECIOUS: Makefile @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@libruby_resource.rc: libruby_resource.rc.in @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(AWK) -f $(top_srcdir)/winrc_version.awk -v VERSION=$(VERSION) $^ > $@ @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@.rc.o: @HAVE_RUBY_DEV_TRUE@@OS_WIN32_TRUE@ $(WINDRES) -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: ngraph-gtk-6.08.00/missing0000755000175000017500000001533613342745531012266 00000000000000#! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2018-03-07.03; # UTC # Copyright (C) 1996-2018 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=https://www.perl.org/ flex_URL=https://github.com/westes/flex gnu_software_URL=https://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 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: ngraph-gtk-6.08.00/config.h.in0000644000175000017500000002045013367273174012711 00000000000000/* config.h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if the `closedir' function returns void instead of `int'. */ #undef CLOSEDIR_VOID /* Define to one of `_getb67', `GETB67', `getb67' for Cray-2 and Cray-YMP systems. This function is required for `alloca.c' support on those systems. */ #undef CRAY_STACKSEG_END /* Define to 1 if using `alloca.c'. */ #undef C_ALLOCA /* Define to 1 if translation of program messages to the user's native language is requested. */ #undef ENABLE_NLS /* Define to 1 if you have the `alarm' function. */ #undef HAVE_ALARM /* Define to 1 if you have `alloca', as a function or macro. */ #undef HAVE_ALLOCA /* Define to 1 if you have and it should be used (not on Ultrix). */ #undef HAVE_ALLOCA_H /* Define to 1 if you have the Mac OS X function CFLocaleCopyCurrent in the CoreFoundation framework. */ #undef HAVE_CFLOCALECOPYCURRENT /* Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework. */ #undef HAVE_CFPREFERENCESCOPYAPPVALUE /* Define if the GNU dcgettext() function is already present or preinstalled. */ #undef HAVE_DCGETTEXT /* Define to 1 if you have the header file, and it defines `DIR'. */ #undef HAVE_DIRENT_H /* Define to 1 if you have the header file. */ #undef HAVE_DLFCN_H /* Define to 1 if you don't have `vprintf' but do have `_doprnt.' */ #undef HAVE_DOPRNT /* Define to 1 if you have the `dup2' function. */ #undef HAVE_DUP2 /* Define to 1 if you have the `fabsl' function. */ #undef HAVE_FABSL /* Define to 1 if you have the header file. */ #undef HAVE_FCNTL_H /* Define to 1 if you have the `finite' function. */ #undef HAVE_FINITE /* Define to 1 if you have the `floorl' function. */ #undef HAVE_FLOORL /* Define to 1 if you have the `fork' function. */ #undef HAVE_FORK /* Define to 1 if you have the `getcwd' function. */ #undef HAVE_GETCWD /* Define to 1 if you have the `getpagesize' function. */ #undef HAVE_GETPAGESIZE /* Define if the GNU gettext() function is already present or preinstalled. */ #undef HAVE_GETTEXT /* Define if you have the iconv() function and it works. */ #undef HAVE_ICONV /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H /* Define to 1 if you have the `isfinite' function. */ #undef HAVE_ISFINITE /* have GNU Scientific Library */ #undef HAVE_LIBGSL /* Define to 1 if you have the `m' library (-lm). */ #undef HAVE_LIBM /* have readline library */ #undef HAVE_LIBREADLINE /* Define to 1 if you have the header file. */ #undef HAVE_LIMITS_H /* Define to 1 if you have the `log10l' function. */ #undef HAVE_LOG10L /* Define to 1 if your system has a GNU libc compatible `malloc' function, and to 0 otherwise. */ #undef HAVE_MALLOC /* Define to 1 if you have the header file. */ #undef HAVE_MEMORY_H /* Define to 1 if you have the `mkdir' function. */ #undef HAVE_MKDIR /* Define to 1 if you have a working `mmap' system call. */ #undef HAVE_MMAP /* Define to 1 if you have the `nanosleep' function. */ #undef HAVE_NANOSLEEP /* Define to 1 if you have the header file, and it defines `DIR'. */ #undef HAVE_NDIR_H /* Define to 1 if you have the `pow' function. */ #undef HAVE_POW /* Define to 1 if you have the `powl' function. */ #undef HAVE_POWL /* Define to 1 if you have the header file. */ #undef HAVE_READLINE_READLINE_H /* Define to 1 if your system has a GNU libc compatible `realloc' function, and to 0 otherwise. */ #undef HAVE_REALLOC /* Define to 1 if you have the `sigaction' function. */ #undef HAVE_SIGACTION /* Define to 1 if you have the `sigsuspend' function. */ #undef HAVE_SIGSUSPEND /* Define to 1 if you have the `sleep' function. */ #undef HAVE_SLEEP /* Define to 1 if you have the `sqrt' function. */ #undef HAVE_SQRT /* Define to 1 if `stat' has the bug that it succeeds when given the zero-length file name argument. */ #undef HAVE_STAT_EMPTY_STRING_BUG /* 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 `strchr' function. */ #undef HAVE_STRCHR /* Define to 1 if you have the `strdup' function. */ #undef HAVE_STRDUP /* Define to 1 if you have the `strerror' function. */ #undef HAVE_STRERROR /* 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 `strncasecmp' function. */ #undef HAVE_STRNCASECMP /* Define to 1 if you have the `strstr' function. */ #undef HAVE_STRSTR /* Define to 1 if you have the `strtol' function. */ #undef HAVE_STRTOL /* Define to 1 if you have the header file, and it defines `DIR'. */ #undef HAVE_SYS_DIR_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_IOCTL_H /* Define to 1 if you have the header file, and it defines `DIR'. */ #undef HAVE_SYS_NDIR_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_PARAM_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_TIME_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_TYPES_H /* Define to 1 if you have that is POSIX.1 compatible. */ #undef HAVE_SYS_WAIT_H /* Define to 1 if you have the header file. */ #undef HAVE_UNISTD_H /* Define to 1 if you have the `utime' function. */ #undef HAVE_UTIME /* Define to 1 if you have the header file. */ #undef HAVE_UTIME_H /* Define to 1 if `utime(file, NULL)' sets file's timestamp to the present. */ #undef HAVE_UTIME_NULL /* Define to 1 if you have the `vfork' function. */ #undef HAVE_VFORK /* Define to 1 if you have the header file. */ #undef HAVE_VFORK_H /* Define to 1 if you have the `vprintf' function. */ #undef HAVE_VPRINTF /* Define to 1 if `fork' works. */ #undef HAVE_WORKING_FORK /* Define to 1 if `vfork' works. */ #undef HAVE_WORKING_VFORK /* Define to 1 if `lstat' dereferences a symlink specified with a trailing slash. */ #undef LSTAT_FOLLOWS_SLASHED_SYMLINK /* 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 as the return type of signal handlers (`int' or `void'). */ #undef RETSIGTYPE /* If using the C implementation of alloca, define if you know the direction of stack growth for your system; otherwise it will be automatically deduced at runtime. STACK_DIRECTION > 0 => grows toward higher addresses STACK_DIRECTION < 0 => grows toward lower addresses STACK_DIRECTION = 0 => direction of growth unknown */ #undef STACK_DIRECTION /* Define to 1 if you have the ANSI C header files. */ #undef STDC_HEADERS /* Define to 1 if you can safely include both and . */ #undef TIME_WITH_SYS_TIME /* Define to 1 if your declares `struct tm'. */ #undef TM_IN_SYS_TIME /* Version number of package */ #undef VERSION /* Enable large inode numbers on Mac OS X 10.5. */ #ifndef _DARWIN_USE_64_BIT_INODE # define _DARWIN_USE_64_BIT_INODE 1 #endif /* Number of bits in a file offset, on hosts where this is settable. */ #undef _FILE_OFFSET_BITS /* Define for large files, on AIX-style hosts. */ #undef _LARGE_FILES /* Define to empty if `const' does not conform to ANSI C. */ #undef const /* Define to rpl_malloc if the replacement function should be used. */ #undef malloc /* Define to `int' if does not define. */ #undef pid_t /* Define to rpl_realloc if the replacement function should be used. */ #undef realloc /* Define to `unsigned int' if does not define. */ #undef size_t /* Define as `fork' if `vfork' does not work. */ #undef vfork ngraph-gtk-6.08.00/demo/0000755000175000017500000000000013375640232011661 500000000000000ngraph-gtk-6.08.00/demo/demo5b.ngp0000644000175000017500000000060013070106167013452 00000000000000#! ngraph # new text text::x=3000 text::y=6500 text::font="Sans-serif" text::style=1 text::text="Demo #5B: MARK" # for i in `seq 0 8` do for j in `seq 0 9` do new mark x:"2500+${j}*1800" y:"8000+${i}*1800" put mark R:0 G:0 B:0 R2:0 G2:128 B2:128 put mark size:1600 put mark style: put mark width:100 put mark type:`iexpr $i\*10+$j` done done # new gra ngraph-gtk-6.08.00/demo/windows_demo.sed0000644000175000017500000000001713070106167014766 00000000000000s!DOCDIRDEF/!! ngraph-gtk-6.08.00/demo/demo3.dat0000644000175000017500000000016513070106167013300 00000000000000Samp.1 0.5 0.05 Samp.2 2.1 0.9 Samp.3 2.9 1.0 Samp.4 4.5 1.01 Samp.5 5.0 1.02 Samp.6 5.5 1.03 Samp.7 5.8 1.04 ngraph-gtk-6.08.00/demo/demo1.ngp.in0000644000175000017500000002306313230344424013717 00000000000000#! ngraph new axis name:frameX axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-5.200000000000000e-01 axis::max=1.520000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=22000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=300 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameY axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-5.200000000000000e-01 axis::max=1.520000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=300 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameU axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=8000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameR axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=19000 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::grouping 1 0 1 2 3 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x='HSB(1-%03/1.6,1,1);x' data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=10 data::mark_size=250 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo1.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x='COLOR(0,255*%03/1.6);COLOR(1,255*%03/1.6);COLOR(2,255*%03/1.6);x' data::math_y='y+1' data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=10 data::mark_size=250 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo1.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x='MARKSIZE(%03*300);x+1' data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=250 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo1.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x='RGB(%03/1.6,1-%03/1.6,1);x+1' data::math_y='y+1' data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=10 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo1.dat' new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='x axis (lattice constant)' text::x=8790 text::y=23500 text::pt=2000 text::font='Sans-serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='y axis (lattice constant)' text::x=3783 text::y=18057 text::pt=2000 text::font='Sans-serif' text::style=3 text::space=0 text::direction=9000 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Demo #1:' text::x=1900 text::y=6100 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='COLOR(), RGB(), HSB() and MARKSIZE() FUNCTION' text::x=1900 text::y=7300 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj= ngraph-gtk-6.08.00/demo/demo9.dat0000644000175000017500000000004213230544574013306 000000000000002 3 4 5 3 2 5 4 2 4 5 3 6 4 5 2 3 ngraph-gtk-6.08.00/demo/demo1.dat0000644000175000017500000014377413070106167013314 00000000000000 -0.49 -0.49 0.10 -0.49 -0.46 0.12 -0.49 -0.44 0.19 -0.49 -0.41 0.32 -0.49 -0.39 0.47 -0.49 -0.36 0.52 -0.49 -0.34 0.41 -0.49 -0.31 0.21 -0.49 -0.29 0.95E-01 -0.49 -0.26 0.22 -0.49 -0.24 0.56 -0.49 -0.21 0.92 -0.49 -0.19 1.1 -0.49 -0.16 0.89 -0.49 -0.14 0.56 -0.49 -0.11 0.29 -0.49 -0.87E-01 0.25 -0.49 -0.63E-01 0.41 -0.49 -0.37E-01 0.66 -0.49 -0.13E-01 0.83 -0.49 0.13E-01 0.83 -0.49 0.38E-01 0.66 -0.49 0.63E-01 0.41 -0.49 0.88E-01 0.25 -0.49 0.11 0.29 -0.49 0.14 0.56 -0.49 0.16 0.89 -0.49 0.19 1.1 -0.49 0.21 0.92 -0.49 0.24 0.56 -0.49 0.26 0.22 -0.49 0.29 0.95E-01 -0.49 0.31 0.21 -0.49 0.34 0.41 -0.49 0.36 0.52 -0.49 0.39 0.47 -0.49 0.41 0.32 -0.49 0.44 0.19 -0.49 0.46 0.12 -0.49 0.49 0.10 -0.46 -0.49 0.12 -0.46 -0.46 0.31 -0.46 -0.44 0.59 -0.46 -0.41 0.81 -0.46 -0.39 0.88 -0.46 -0.36 0.75 -0.46 -0.34 0.48 -0.46 -0.31 0.20 -0.46 -0.29 0.53E-01 -0.46 -0.26 0.12 -0.46 -0.24 0.34 -0.46 -0.21 0.56 -0.46 -0.19 0.66 -0.46 -0.16 0.63 -0.46 -0.14 0.55 -0.46 -0.11 0.52 -0.46 -0.87E-01 0.55 -0.46 -0.63E-01 0.57 -0.46 -0.37E-01 0.55 -0.46 -0.13E-01 0.52 -0.46 0.13E-01 0.52 -0.46 0.38E-01 0.55 -0.46 0.63E-01 0.57 -0.46 0.88E-01 0.55 -0.46 0.11 0.52 -0.46 0.14 0.55 -0.46 0.16 0.63 -0.46 0.19 0.66 -0.46 0.21 0.56 -0.46 0.24 0.34 -0.46 0.26 0.12 -0.46 0.29 0.53E-01 -0.46 0.31 0.20 -0.46 0.34 0.48 -0.46 0.36 0.75 -0.46 0.39 0.88 -0.46 0.41 0.81 -0.46 0.44 0.59 -0.46 0.46 0.31 -0.46 0.49 0.12 -0.44 -0.49 0.19 -0.44 -0.46 0.59 -0.44 -0.44 1.1 -0.44 -0.41 1.4 -0.44 -0.39 1.3 -0.44 -0.36 0.92 -0.44 -0.34 0.48 -0.44 -0.31 0.16 -0.44 -0.29 0.57E-01 -0.44 -0.26 0.10 -0.44 -0.24 0.18 -0.44 -0.21 0.21 -0.44 -0.19 0.24 -0.44 -0.16 0.34 -0.44 -0.14 0.59 -0.44 -0.11 0.87 -0.44 -0.87E-01 1.0 -0.44 -0.63E-01 0.85 -0.44 -0.37E-01 0.50 -0.44 -0.13E-01 0.21 -0.44 0.13E-01 0.21 -0.44 0.38E-01 0.50 -0.44 0.63E-01 0.85 -0.44 0.88E-01 1.0 -0.44 0.11 0.87 -0.44 0.14 0.59 -0.44 0.16 0.34 -0.44 0.19 0.24 -0.44 0.21 0.21 -0.44 0.24 0.18 -0.44 0.26 0.10 -0.44 0.29 0.57E-01 -0.44 0.31 0.16 -0.44 0.34 0.48 -0.44 0.36 0.92 -0.44 0.39 1.3 -0.44 0.41 1.4 -0.44 0.44 1.1 -0.44 0.46 0.59 -0.44 0.49 0.19 -0.41 -0.49 0.32 -0.41 -0.46 0.81 -0.41 -0.44 1.4 -0.41 -0.41 1.6 -0.41 -0.39 1.4 -0.41 -0.36 0.81 -0.41 -0.34 0.33 -0.41 -0.31 0.14 -0.41 -0.29 0.21 -0.41 -0.26 0.33 -0.41 -0.24 0.34 -0.41 -0.21 0.22 -0.41 -0.19 0.11 -0.41 -0.16 0.24 -0.41 -0.14 0.65 -0.41 -0.11 1.1 -0.41 -0.87E-01 1.3 -0.41 -0.63E-01 1.1 -0.41 -0.37E-01 0.61 -0.41 -0.13E-01 0.18 -0.41 0.13E-01 0.18 -0.41 0.38E-01 0.61 -0.41 0.63E-01 1.1 -0.41 0.88E-01 1.3 -0.41 0.11 1.1 -0.41 0.14 0.65 -0.41 0.16 0.24 -0.41 0.19 0.11 -0.41 0.21 0.22 -0.41 0.24 0.34 -0.41 0.26 0.33 -0.41 0.29 0.21 -0.41 0.31 0.14 -0.41 0.34 0.33 -0.41 0.36 0.81 -0.41 0.39 1.4 -0.41 0.41 1.6 -0.41 0.44 1.4 -0.41 0.46 0.81 -0.41 0.49 0.32 -0.39 -0.49 0.47 -0.39 -0.46 0.88 -0.39 -0.44 1.3 -0.39 -0.41 1.4 -0.39 -0.39 0.98 -0.39 -0.36 0.45 -0.39 -0.34 0.14 -0.39 -0.31 0.20 -0.39 -0.29 0.50 -0.39 -0.26 0.76 -0.39 -0.24 0.78 -0.39 -0.21 0.56 -0.39 -0.19 0.31 -0.39 -0.16 0.31 -0.39 -0.14 0.63 -0.39 -0.11 1.1 -0.39 -0.87E-01 1.3 -0.39 -0.63E-01 1.2 -0.39 -0.37E-01 0.73 -0.39 -0.13E-01 0.35 -0.39 0.13E-01 0.35 -0.39 0.38E-01 0.73 -0.39 0.63E-01 1.2 -0.39 0.88E-01 1.3 -0.39 0.11 1.1 -0.39 0.14 0.63 -0.39 0.16 0.31 -0.39 0.19 0.31 -0.39 0.21 0.56 -0.39 0.24 0.78 -0.39 0.26 0.76 -0.39 0.29 0.50 -0.39 0.31 0.20 -0.39 0.34 0.14 -0.39 0.36 0.45 -0.39 0.39 0.98 -0.39 0.41 1.4 -0.39 0.44 1.3 -0.39 0.46 0.88 -0.39 0.49 0.47 -0.36 -0.49 0.52 -0.36 -0.46 0.75 -0.36 -0.44 0.92 -0.36 -0.41 0.81 -0.36 -0.39 0.45 -0.36 -0.36 0.11 -0.36 -0.34 0.66E-01 -0.36 -0.31 0.34 -0.36 -0.29 0.77 -0.36 -0.26 1.1 -0.36 -0.24 1.1 -0.36 -0.21 0.90 -0.36 -0.19 0.56 -0.36 -0.16 0.38 -0.36 -0.14 0.48 -0.36 -0.11 0.77 -0.36 -0.87E-01 0.99 -0.36 -0.63E-01 0.95 -0.36 -0.37E-01 0.69 -0.36 -0.13E-01 0.45 -0.36 0.13E-01 0.45 -0.36 0.38E-01 0.69 -0.36 0.63E-01 0.95 -0.36 0.88E-01 0.99 -0.36 0.11 0.77 -0.36 0.14 0.48 -0.36 0.16 0.38 -0.36 0.19 0.56 -0.36 0.21 0.90 -0.36 0.24 1.1 -0.36 0.26 1.1 -0.36 0.29 0.77 -0.36 0.31 0.34 -0.36 0.34 0.66E-01 -0.36 0.36 0.11 -0.36 0.39 0.45 -0.36 0.41 0.81 -0.36 0.44 0.92 -0.36 0.46 0.75 -0.36 0.49 0.52 -0.34 -0.49 0.41 -0.34 -0.46 0.48 -0.34 -0.44 0.48 -0.34 -0.41 0.33 -0.34 -0.39 0.14 -0.34 -0.36 0.66E-01 -0.34 -0.34 0.21 -0.34 -0.31 0.51 -0.34 -0.29 0.84 -0.34 -0.26 1.1 -0.34 -0.24 1.1 -0.34 -0.21 0.93 -0.34 -0.19 0.63 -0.34 -0.16 0.36 -0.34 -0.14 0.28 -0.34 -0.11 0.37 -0.34 -0.87E-01 0.51 -0.34 -0.63E-01 0.54 -0.34 -0.37E-01 0.47 -0.34 -0.13E-01 0.38 -0.34 0.13E-01 0.38 -0.34 0.38E-01 0.47 -0.34 0.63E-01 0.54 -0.34 0.88E-01 0.51 -0.34 0.11 0.37 -0.34 0.14 0.28 -0.34 0.16 0.36 -0.34 0.19 0.63 -0.34 0.21 0.93 -0.34 0.24 1.1 -0.34 0.26 1.1 -0.34 0.29 0.84 -0.34 0.31 0.51 -0.34 0.34 0.21 -0.34 0.36 0.66E-01 -0.34 0.39 0.14 -0.34 0.41 0.33 -0.34 0.44 0.48 -0.34 0.46 0.48 -0.34 0.49 0.41 -0.31 -0.49 0.21 -0.31 -0.46 0.20 -0.31 -0.44 0.16 -0.31 -0.41 0.14 -0.31 -0.39 0.20 -0.31 -0.36 0.34 -0.31 -0.34 0.51 -0.31 -0.31 0.62 -0.31 -0.29 0.67 -0.31 -0.26 0.72 -0.31 -0.24 0.75 -0.31 -0.21 0.70 -0.31 -0.19 0.55 -0.31 -0.16 0.35 -0.31 -0.14 0.21 -0.31 -0.11 0.16 -0.31 -0.87E-01 0.20 -0.31 -0.63E-01 0.23 -0.31 -0.37E-01 0.24 -0.31 -0.13E-01 0.22 -0.31 0.13E-01 0.22 -0.31 0.38E-01 0.24 -0.31 0.63E-01 0.23 -0.31 0.88E-01 0.20 -0.31 0.11 0.16 -0.31 0.14 0.21 -0.31 0.16 0.35 -0.31 0.19 0.55 -0.31 0.21 0.70 -0.31 0.24 0.75 -0.31 0.26 0.72 -0.31 0.29 0.67 -0.31 0.31 0.62 -0.31 0.34 0.51 -0.31 0.36 0.34 -0.31 0.39 0.20 -0.31 0.41 0.14 -0.31 0.44 0.16 -0.31 0.46 0.20 -0.31 0.49 0.21 -0.29 -0.49 0.95E-01 -0.29 -0.46 0.53E-01 -0.29 -0.44 0.57E-01 -0.29 -0.41 0.21 -0.29 -0.39 0.50 -0.29 -0.36 0.77 -0.29 -0.34 0.84 -0.29 -0.31 0.67 -0.29 -0.29 0.43 -0.29 -0.26 0.30 -0.29 -0.24 0.35 -0.29 -0.21 0.48 -0.29 -0.19 0.54 -0.29 -0.16 0.48 -0.29 -0.14 0.36 -0.29 -0.11 0.25 -0.29 -0.87E-01 0.19 -0.29 -0.63E-01 0.16 -0.29 -0.37E-01 0.15 -0.29 -0.13E-01 0.15 -0.29 0.13E-01 0.15 -0.29 0.38E-01 0.15 -0.29 0.63E-01 0.16 -0.29 0.88E-01 0.19 -0.29 0.11 0.25 -0.29 0.14 0.36 -0.29 0.16 0.48 -0.29 0.19 0.54 -0.29 0.21 0.48 -0.29 0.24 0.35 -0.29 0.26 0.30 -0.29 0.29 0.43 -0.29 0.31 0.67 -0.29 0.34 0.84 -0.29 0.36 0.77 -0.29 0.39 0.50 -0.29 0.41 0.21 -0.29 0.44 0.57E-01 -0.29 0.46 0.53E-01 -0.29 0.49 0.95E-01 -0.26 -0.49 0.22 -0.26 -0.46 0.12 -0.26 -0.44 0.10 -0.26 -0.41 0.33 -0.26 -0.39 0.76 -0.26 -0.36 1.1 -0.26 -0.34 1.1 -0.26 -0.31 0.72 -0.26 -0.29 0.30 -0.26 -0.26 0.11 -0.26 -0.24 0.23 -0.26 -0.21 0.50 -0.26 -0.19 0.71 -0.26 -0.16 0.76 -0.26 -0.14 0.67 -0.26 -0.11 0.52 -0.26 -0.87E-01 0.39 -0.26 -0.63E-01 0.29 -0.26 -0.37E-01 0.23 -0.26 -0.13E-01 0.20 -0.26 0.13E-01 0.20 -0.26 0.38E-01 0.23 -0.26 0.63E-01 0.29 -0.26 0.88E-01 0.39 -0.26 0.11 0.52 -0.26 0.14 0.67 -0.26 0.16 0.76 -0.26 0.19 0.71 -0.26 0.21 0.50 -0.26 0.24 0.23 -0.26 0.26 0.11 -0.26 0.29 0.30 -0.26 0.31 0.72 -0.26 0.34 1.1 -0.26 0.36 1.1 -0.26 0.39 0.76 -0.26 0.41 0.33 -0.26 0.44 0.10 -0.26 0.46 0.12 -0.26 0.49 0.22 -0.24 -0.49 0.56 -0.24 -0.46 0.34 -0.24 -0.44 0.18 -0.24 -0.41 0.34 -0.24 -0.39 0.78 -0.24 -0.36 1.1 -0.24 -0.34 1.1 -0.24 -0.31 0.75 -0.24 -0.29 0.35 -0.24 -0.26 0.23 -0.24 -0.24 0.43 -0.24 -0.21 0.77 -0.24 -0.19 1.0 -0.24 -0.16 1.1 -0.24 -0.14 0.99 -0.24 -0.11 0.80 -0.24 -0.87E-01 0.61 -0.24 -0.63E-01 0.45 -0.24 -0.37E-01 0.35 -0.24 -0.13E-01 0.30 -0.24 0.13E-01 0.30 -0.24 0.38E-01 0.35 -0.24 0.63E-01 0.45 -0.24 0.88E-01 0.61 -0.24 0.11 0.80 -0.24 0.14 0.99 -0.24 0.16 1.1 -0.24 0.19 1.0 -0.24 0.21 0.77 -0.24 0.24 0.43 -0.24 0.26 0.23 -0.24 0.29 0.35 -0.24 0.31 0.75 -0.24 0.34 1.1 -0.24 0.36 1.1 -0.24 0.39 0.78 -0.24 0.41 0.34 -0.24 0.44 0.18 -0.24 0.46 0.34 -0.24 0.49 0.56 -0.21 -0.49 0.92 -0.21 -0.46 0.56 -0.21 -0.44 0.21 -0.21 -0.41 0.22 -0.21 -0.39 0.56 -0.21 -0.36 0.90 -0.21 -0.34 0.93 -0.21 -0.31 0.70 -0.21 -0.29 0.48 -0.21 -0.26 0.50 -0.21 -0.24 0.77 -0.21 -0.21 1.1 -0.21 -0.19 1.3 -0.21 -0.16 1.3 -0.21 -0.14 1.2 -0.21 -0.11 0.95 -0.21 -0.87E-01 0.72 -0.21 -0.63E-01 0.54 -0.21 -0.37E-01 0.42 -0.21 -0.13E-01 0.37 -0.21 0.13E-01 0.37 -0.21 0.38E-01 0.42 -0.21 0.63E-01 0.54 -0.21 0.88E-01 0.72 -0.21 0.11 0.95 -0.21 0.14 1.2 -0.21 0.16 1.3 -0.21 0.19 1.3 -0.21 0.21 1.1 -0.21 0.24 0.77 -0.21 0.26 0.50 -0.21 0.29 0.48 -0.21 0.31 0.70 -0.21 0.34 0.93 -0.21 0.36 0.90 -0.21 0.39 0.56 -0.21 0.41 0.22 -0.21 0.44 0.21 -0.21 0.46 0.56 -0.21 0.49 0.92 -0.19 -0.49 1.1 -0.19 -0.46 0.66 -0.19 -0.44 0.24 -0.19 -0.41 0.11 -0.19 -0.39 0.31 -0.19 -0.36 0.56 -0.19 -0.34 0.63 -0.19 -0.31 0.55 -0.19 -0.29 0.54 -0.19 -0.26 0.71 -0.19 -0.24 1.0 -0.19 -0.21 1.3 -0.19 -0.19 1.4 -0.19 -0.16 1.4 -0.19 -0.14 1.2 -0.19 -0.11 0.94 -0.19 -0.87E-01 0.71 -0.19 -0.63E-01 0.54 -0.19 -0.37E-01 0.42 -0.19 -0.13E-01 0.36 -0.19 0.13E-01 0.36 -0.19 0.38E-01 0.42 -0.19 0.63E-01 0.54 -0.19 0.88E-01 0.71 -0.19 0.11 0.94 -0.19 0.14 1.2 -0.19 0.16 1.4 -0.19 0.19 1.4 -0.19 0.21 1.3 -0.19 0.24 1.0 -0.19 0.26 0.71 -0.19 0.29 0.54 -0.19 0.31 0.55 -0.19 0.34 0.63 -0.19 0.36 0.56 -0.19 0.39 0.31 -0.19 0.41 0.11 -0.19 0.44 0.24 -0.19 0.46 0.66 -0.19 0.49 1.1 -0.16 -0.49 0.89 -0.16 -0.46 0.63 -0.16 -0.44 0.34 -0.16 -0.41 0.24 -0.16 -0.39 0.31 -0.16 -0.36 0.38 -0.16 -0.34 0.36 -0.16 -0.31 0.35 -0.16 -0.29 0.48 -0.16 -0.26 0.76 -0.16 -0.24 1.1 -0.16 -0.21 1.3 -0.16 -0.19 1.4 -0.16 -0.16 1.3 -0.16 -0.14 1.1 -0.16 -0.11 0.82 -0.16 -0.87E-01 0.62 -0.16 -0.63E-01 0.46 -0.16 -0.37E-01 0.36 -0.16 -0.13E-01 0.31 -0.16 0.13E-01 0.31 -0.16 0.38E-01 0.36 -0.16 0.63E-01 0.46 -0.16 0.88E-01 0.62 -0.16 0.11 0.82 -0.16 0.14 1.1 -0.16 0.16 1.3 -0.16 0.19 1.4 -0.16 0.21 1.3 -0.16 0.24 1.1 -0.16 0.26 0.76 -0.16 0.29 0.48 -0.16 0.31 0.35 -0.16 0.34 0.36 -0.16 0.36 0.38 -0.16 0.39 0.31 -0.16 0.41 0.24 -0.16 0.44 0.34 -0.16 0.46 0.63 -0.16 0.49 0.89 -0.14 -0.49 0.56 -0.14 -0.46 0.55 -0.14 -0.44 0.59 -0.14 -0.41 0.65 -0.14 -0.39 0.63 -0.14 -0.36 0.48 -0.14 -0.34 0.28 -0.14 -0.31 0.21 -0.14 -0.29 0.36 -0.14 -0.26 0.67 -0.14 -0.24 0.99 -0.14 -0.21 1.2 -0.14 -0.19 1.2 -0.14 -0.16 1.1 -0.14 -0.14 0.86 -0.14 -0.11 0.66 -0.14 -0.87E-01 0.49 -0.14 -0.63E-01 0.36 -0.14 -0.37E-01 0.28 -0.14 -0.13E-01 0.24 -0.14 0.13E-01 0.24 -0.14 0.38E-01 0.28 -0.14 0.63E-01 0.36 -0.14 0.88E-01 0.49 -0.14 0.11 0.66 -0.14 0.14 0.86 -0.14 0.16 1.1 -0.14 0.19 1.2 -0.14 0.21 1.2 -0.14 0.24 0.99 -0.14 0.26 0.67 -0.14 0.29 0.36 -0.14 0.31 0.21 -0.14 0.34 0.28 -0.14 0.36 0.48 -0.14 0.39 0.63 -0.14 0.41 0.65 -0.14 0.44 0.59 -0.14 0.46 0.55 -0.14 0.49 0.56 -0.11 -0.49 0.29 -0.11 -0.46 0.52 -0.11 -0.44 0.87 -0.11 -0.41 1.1 -0.11 -0.39 1.1 -0.11 -0.36 0.77 -0.11 -0.34 0.37 -0.11 -0.31 0.16 -0.11 -0.29 0.25 -0.11 -0.26 0.52 -0.11 -0.24 0.80 -0.11 -0.21 0.95 -0.11 -0.19 0.94 -0.11 -0.16 0.82 -0.11 -0.14 0.66 -0.11 -0.11 0.51 -0.11 -0.87E-01 0.37 -0.11 -0.63E-01 0.27 -0.11 -0.37E-01 0.20 -0.11 -0.13E-01 0.17 -0.11 0.13E-01 0.17 -0.11 0.38E-01 0.20 -0.11 0.63E-01 0.27 -0.11 0.88E-01 0.37 -0.11 0.11 0.51 -0.11 0.14 0.66 -0.11 0.16 0.82 -0.11 0.19 0.94 -0.11 0.21 0.95 -0.11 0.24 0.80 -0.11 0.26 0.52 -0.11 0.29 0.25 -0.11 0.31 0.16 -0.11 0.34 0.37 -0.11 0.36 0.77 -0.11 0.39 1.1 -0.11 0.41 1.1 -0.11 0.44 0.87 -0.11 0.46 0.52 -0.11 0.49 0.29 -0.87E-01 -0.49 0.25 -0.87E-01 -0.46 0.55 -0.87E-01 -0.44 1.0 -0.87E-01 -0.41 1.3 -0.87E-01 -0.39 1.3 -0.87E-01 -0.36 0.99 -0.87E-01 -0.34 0.51 -0.87E-01 -0.31 0.20 -0.87E-01 -0.29 0.19 -0.87E-01 -0.26 0.39 -0.87E-01 -0.24 0.61 -0.87E-01 -0.21 0.72 -0.87E-01 -0.19 0.71 -0.87E-01 -0.16 0.62 -0.87E-01 -0.14 0.49 -0.87E-01 -0.11 0.37 -0.87E-01 -0.87E-01 0.27 -0.87E-01 -0.63E-01 0.19 -0.87E-01 -0.37E-01 0.14 -0.87E-01 -0.13E-01 0.12 -0.87E-01 0.13E-01 0.12 -0.87E-01 0.38E-01 0.14 -0.87E-01 0.63E-01 0.19 -0.87E-01 0.88E-01 0.27 -0.87E-01 0.11 0.37 -0.87E-01 0.14 0.49 -0.87E-01 0.16 0.62 -0.87E-01 0.19 0.71 -0.87E-01 0.21 0.72 -0.87E-01 0.24 0.61 -0.87E-01 0.26 0.39 -0.87E-01 0.29 0.19 -0.87E-01 0.31 0.20 -0.87E-01 0.34 0.51 -0.87E-01 0.36 0.99 -0.87E-01 0.39 1.3 -0.87E-01 0.41 1.3 -0.87E-01 0.44 1.0 -0.87E-01 0.46 0.55 -0.87E-01 0.49 0.25 -0.63E-01 -0.49 0.41 -0.63E-01 -0.46 0.57 -0.63E-01 -0.44 0.85 -0.63E-01 -0.41 1.1 -0.63E-01 -0.39 1.2 -0.63E-01 -0.36 0.95 -0.63E-01 -0.34 0.54 -0.63E-01 -0.31 0.23 -0.63E-01 -0.29 0.16 -0.63E-01 -0.26 0.29 -0.63E-01 -0.24 0.45 -0.63E-01 -0.21 0.54 -0.63E-01 -0.19 0.54 -0.63E-01 -0.16 0.46 -0.63E-01 -0.14 0.36 -0.63E-01 -0.11 0.27 -0.63E-01 -0.87E-01 0.19 -0.63E-01 -0.63E-01 0.13 -0.63E-01 -0.37E-01 0.97E-01 -0.63E-01 -0.13E-01 0.79E-01 -0.63E-01 0.13E-01 0.79E-01 -0.63E-01 0.38E-01 0.97E-01 -0.63E-01 0.63E-01 0.13 -0.63E-01 0.88E-01 0.19 -0.63E-01 0.11 0.27 -0.63E-01 0.14 0.36 -0.63E-01 0.16 0.46 -0.63E-01 0.19 0.54 -0.63E-01 0.21 0.54 -0.63E-01 0.24 0.45 -0.63E-01 0.26 0.29 -0.63E-01 0.29 0.16 -0.63E-01 0.31 0.23 -0.63E-01 0.34 0.54 -0.63E-01 0.36 0.95 -0.63E-01 0.39 1.2 -0.63E-01 0.41 1.1 -0.63E-01 0.44 0.85 -0.63E-01 0.46 0.57 -0.63E-01 0.49 0.41 -0.37E-01 -0.49 0.66 -0.37E-01 -0.46 0.55 -0.37E-01 -0.44 0.50 -0.37E-01 -0.41 0.61 -0.37E-01 -0.39 0.73 -0.37E-01 -0.36 0.69 -0.37E-01 -0.34 0.47 -0.37E-01 -0.31 0.24 -0.37E-01 -0.29 0.15 -0.37E-01 -0.26 0.23 -0.37E-01 -0.24 0.35 -0.37E-01 -0.21 0.42 -0.37E-01 -0.19 0.42 -0.37E-01 -0.16 0.36 -0.37E-01 -0.14 0.28 -0.37E-01 -0.11 0.20 -0.37E-01 -0.87E-01 0.14 -0.37E-01 -0.63E-01 0.97E-01 -0.37E-01 -0.37E-01 0.69E-01 -0.37E-01 -0.13E-01 0.56E-01 -0.37E-01 0.13E-01 0.56E-01 -0.37E-01 0.38E-01 0.69E-01 -0.37E-01 0.63E-01 0.97E-01 -0.37E-01 0.88E-01 0.14 -0.37E-01 0.11 0.20 -0.37E-01 0.14 0.28 -0.37E-01 0.16 0.36 -0.37E-01 0.19 0.42 -0.37E-01 0.21 0.42 -0.37E-01 0.24 0.35 -0.37E-01 0.26 0.23 -0.37E-01 0.29 0.15 -0.37E-01 0.31 0.24 -0.37E-01 0.34 0.47 -0.37E-01 0.36 0.69 -0.37E-01 0.39 0.73 -0.37E-01 0.41 0.61 -0.37E-01 0.44 0.50 -0.37E-01 0.46 0.55 -0.37E-01 0.49 0.66 -0.13E-01 -0.49 0.83 -0.13E-01 -0.46 0.52 -0.13E-01 -0.44 0.21 -0.13E-01 -0.41 0.18 -0.13E-01 -0.39 0.35 -0.13E-01 -0.36 0.45 -0.13E-01 -0.34 0.38 -0.13E-01 -0.31 0.22 -0.13E-01 -0.29 0.15 -0.13E-01 -0.26 0.20 -0.13E-01 -0.24 0.30 -0.13E-01 -0.21 0.37 -0.13E-01 -0.19 0.36 -0.13E-01 -0.16 0.31 -0.13E-01 -0.14 0.24 -0.13E-01 -0.11 0.17 -0.13E-01 -0.87E-01 0.12 -0.13E-01 -0.63E-01 0.79E-01 -0.13E-01 -0.37E-01 0.56E-01 -0.13E-01 -0.13E-01 0.46E-01 -0.13E-01 0.13E-01 0.46E-01 -0.13E-01 0.38E-01 0.56E-01 -0.13E-01 0.63E-01 0.79E-01 -0.13E-01 0.88E-01 0.12 -0.13E-01 0.11 0.17 -0.13E-01 0.14 0.24 -0.13E-01 0.16 0.31 -0.13E-01 0.19 0.36 -0.13E-01 0.21 0.37 -0.13E-01 0.24 0.30 -0.13E-01 0.26 0.20 -0.13E-01 0.29 0.15 -0.13E-01 0.31 0.22 -0.13E-01 0.34 0.38 -0.13E-01 0.36 0.45 -0.13E-01 0.39 0.35 -0.13E-01 0.41 0.18 -0.13E-01 0.44 0.21 -0.13E-01 0.46 0.52 -0.13E-01 0.49 0.83 0.13E-01 -0.49 0.83 0.13E-01 -0.46 0.52 0.13E-01 -0.44 0.21 0.13E-01 -0.41 0.18 0.13E-01 -0.39 0.35 0.13E-01 -0.36 0.45 0.13E-01 -0.34 0.38 0.13E-01 -0.31 0.22 0.13E-01 -0.29 0.15 0.13E-01 -0.26 0.20 0.13E-01 -0.24 0.30 0.13E-01 -0.21 0.37 0.13E-01 -0.19 0.36 0.13E-01 -0.16 0.31 0.13E-01 -0.14 0.24 0.13E-01 -0.11 0.17 0.13E-01 -0.87E-01 0.12 0.13E-01 -0.63E-01 0.79E-01 0.13E-01 -0.37E-01 0.56E-01 0.13E-01 -0.13E-01 0.46E-01 0.13E-01 0.13E-01 0.46E-01 0.13E-01 0.38E-01 0.56E-01 0.13E-01 0.63E-01 0.79E-01 0.13E-01 0.88E-01 0.12 0.13E-01 0.11 0.17 0.13E-01 0.14 0.24 0.13E-01 0.16 0.31 0.13E-01 0.19 0.36 0.13E-01 0.21 0.37 0.13E-01 0.24 0.30 0.13E-01 0.26 0.20 0.13E-01 0.29 0.15 0.13E-01 0.31 0.22 0.13E-01 0.34 0.38 0.13E-01 0.36 0.45 0.13E-01 0.39 0.35 0.13E-01 0.41 0.18 0.13E-01 0.44 0.21 0.13E-01 0.46 0.52 0.13E-01 0.49 0.83 0.38E-01 -0.49 0.66 0.38E-01 -0.46 0.55 0.38E-01 -0.44 0.50 0.38E-01 -0.41 0.61 0.38E-01 -0.39 0.73 0.38E-01 -0.36 0.69 0.38E-01 -0.34 0.47 0.38E-01 -0.31 0.24 0.38E-01 -0.29 0.15 0.38E-01 -0.26 0.23 0.38E-01 -0.24 0.35 0.38E-01 -0.21 0.42 0.38E-01 -0.19 0.42 0.38E-01 -0.16 0.36 0.38E-01 -0.14 0.28 0.38E-01 -0.11 0.20 0.38E-01 -0.87E-01 0.14 0.38E-01 -0.63E-01 0.97E-01 0.38E-01 -0.37E-01 0.69E-01 0.38E-01 -0.13E-01 0.56E-01 0.38E-01 0.13E-01 0.56E-01 0.38E-01 0.38E-01 0.69E-01 0.38E-01 0.63E-01 0.97E-01 0.38E-01 0.88E-01 0.14 0.38E-01 0.11 0.20 0.38E-01 0.14 0.28 0.38E-01 0.16 0.36 0.38E-01 0.19 0.42 0.38E-01 0.21 0.42 0.38E-01 0.24 0.35 0.38E-01 0.26 0.23 0.38E-01 0.29 0.15 0.38E-01 0.31 0.24 0.38E-01 0.34 0.47 0.38E-01 0.36 0.69 0.38E-01 0.39 0.73 0.38E-01 0.41 0.61 0.38E-01 0.44 0.50 0.38E-01 0.46 0.55 0.38E-01 0.49 0.66 0.63E-01 -0.49 0.41 0.63E-01 -0.46 0.57 0.63E-01 -0.44 0.85 0.63E-01 -0.41 1.1 0.63E-01 -0.39 1.2 0.63E-01 -0.36 0.95 0.63E-01 -0.34 0.54 0.63E-01 -0.31 0.23 0.63E-01 -0.29 0.16 0.63E-01 -0.26 0.29 0.63E-01 -0.24 0.45 0.63E-01 -0.21 0.54 0.63E-01 -0.19 0.54 0.63E-01 -0.16 0.46 0.63E-01 -0.14 0.36 0.63E-01 -0.11 0.27 0.63E-01 -0.87E-01 0.19 0.63E-01 -0.63E-01 0.13 0.63E-01 -0.37E-01 0.97E-01 0.63E-01 -0.13E-01 0.79E-01 0.63E-01 0.13E-01 0.79E-01 0.63E-01 0.38E-01 0.97E-01 0.63E-01 0.63E-01 0.13 0.63E-01 0.88E-01 0.19 0.63E-01 0.11 0.27 0.63E-01 0.14 0.36 0.63E-01 0.16 0.46 0.63E-01 0.19 0.54 0.63E-01 0.21 0.54 0.63E-01 0.24 0.45 0.63E-01 0.26 0.29 0.63E-01 0.29 0.16 0.63E-01 0.31 0.23 0.63E-01 0.34 0.54 0.63E-01 0.36 0.95 0.63E-01 0.39 1.2 0.63E-01 0.41 1.1 0.63E-01 0.44 0.85 0.63E-01 0.46 0.57 0.63E-01 0.49 0.41 0.88E-01 -0.49 0.25 0.88E-01 -0.46 0.55 0.88E-01 -0.44 1.0 0.88E-01 -0.41 1.3 0.88E-01 -0.39 1.3 0.88E-01 -0.36 0.99 0.88E-01 -0.34 0.51 0.88E-01 -0.31 0.20 0.88E-01 -0.29 0.19 0.88E-01 -0.26 0.39 0.88E-01 -0.24 0.61 0.88E-01 -0.21 0.72 0.88E-01 -0.19 0.71 0.88E-01 -0.16 0.62 0.88E-01 -0.14 0.49 0.88E-01 -0.11 0.37 0.88E-01 -0.87E-01 0.27 0.88E-01 -0.63E-01 0.19 0.88E-01 -0.37E-01 0.14 0.88E-01 -0.13E-01 0.12 0.88E-01 0.13E-01 0.12 0.88E-01 0.38E-01 0.14 0.88E-01 0.63E-01 0.19 0.88E-01 0.88E-01 0.27 0.88E-01 0.11 0.37 0.88E-01 0.14 0.49 0.88E-01 0.16 0.62 0.88E-01 0.19 0.71 0.88E-01 0.21 0.72 0.88E-01 0.24 0.61 0.88E-01 0.26 0.39 0.88E-01 0.29 0.19 0.88E-01 0.31 0.20 0.88E-01 0.34 0.51 0.88E-01 0.36 0.99 0.88E-01 0.39 1.3 0.88E-01 0.41 1.3 0.88E-01 0.44 1.0 0.88E-01 0.46 0.55 0.88E-01 0.49 0.25 0.11 -0.49 0.29 0.11 -0.46 0.52 0.11 -0.44 0.87 0.11 -0.41 1.1 0.11 -0.39 1.1 0.11 -0.36 0.77 0.11 -0.34 0.37 0.11 -0.31 0.16 0.11 -0.29 0.25 0.11 -0.26 0.52 0.11 -0.24 0.80 0.11 -0.21 0.95 0.11 -0.19 0.94 0.11 -0.16 0.82 0.11 -0.14 0.66 0.11 -0.11 0.51 0.11 -0.87E-01 0.37 0.11 -0.63E-01 0.27 0.11 -0.37E-01 0.20 0.11 -0.13E-01 0.17 0.11 0.13E-01 0.17 0.11 0.38E-01 0.20 0.11 0.63E-01 0.27 0.11 0.88E-01 0.37 0.11 0.11 0.51 0.11 0.14 0.66 0.11 0.16 0.82 0.11 0.19 0.94 0.11 0.21 0.95 0.11 0.24 0.80 0.11 0.26 0.52 0.11 0.29 0.25 0.11 0.31 0.16 0.11 0.34 0.37 0.11 0.36 0.77 0.11 0.39 1.1 0.11 0.41 1.1 0.11 0.44 0.87 0.11 0.46 0.52 0.11 0.49 0.29 0.14 -0.49 0.56 0.14 -0.46 0.55 0.14 -0.44 0.59 0.14 -0.41 0.65 0.14 -0.39 0.63 0.14 -0.36 0.48 0.14 -0.34 0.28 0.14 -0.31 0.21 0.14 -0.29 0.36 0.14 -0.26 0.67 0.14 -0.24 0.99 0.14 -0.21 1.2 0.14 -0.19 1.2 0.14 -0.16 1.1 0.14 -0.14 0.86 0.14 -0.11 0.66 0.14 -0.87E-01 0.49 0.14 -0.63E-01 0.36 0.14 -0.37E-01 0.28 0.14 -0.13E-01 0.24 0.14 0.13E-01 0.24 0.14 0.38E-01 0.28 0.14 0.63E-01 0.36 0.14 0.88E-01 0.49 0.14 0.11 0.66 0.14 0.14 0.86 0.14 0.16 1.1 0.14 0.19 1.2 0.14 0.21 1.2 0.14 0.24 0.99 0.14 0.26 0.67 0.14 0.29 0.36 0.14 0.31 0.21 0.14 0.34 0.28 0.14 0.36 0.48 0.14 0.39 0.63 0.14 0.41 0.65 0.14 0.44 0.59 0.14 0.46 0.55 0.14 0.49 0.56 0.16 -0.49 0.89 0.16 -0.46 0.63 0.16 -0.44 0.34 0.16 -0.41 0.24 0.16 -0.39 0.31 0.16 -0.36 0.38 0.16 -0.34 0.36 0.16 -0.31 0.35 0.16 -0.29 0.48 0.16 -0.26 0.76 0.16 -0.24 1.1 0.16 -0.21 1.3 0.16 -0.19 1.4 0.16 -0.16 1.3 0.16 -0.14 1.1 0.16 -0.11 0.82 0.16 -0.87E-01 0.62 0.16 -0.63E-01 0.46 0.16 -0.37E-01 0.36 0.16 -0.13E-01 0.31 0.16 0.13E-01 0.31 0.16 0.38E-01 0.36 0.16 0.63E-01 0.46 0.16 0.88E-01 0.62 0.16 0.11 0.82 0.16 0.14 1.1 0.16 0.16 1.3 0.16 0.19 1.4 0.16 0.21 1.3 0.16 0.24 1.1 0.16 0.26 0.76 0.16 0.29 0.48 0.16 0.31 0.35 0.16 0.34 0.36 0.16 0.36 0.38 0.16 0.39 0.31 0.16 0.41 0.24 0.16 0.44 0.34 0.16 0.46 0.63 0.16 0.49 0.89 0.19 -0.49 1.1 0.19 -0.46 0.66 0.19 -0.44 0.24 0.19 -0.41 0.11 0.19 -0.39 0.31 0.19 -0.36 0.56 0.19 -0.34 0.63 0.19 -0.31 0.55 0.19 -0.29 0.54 0.19 -0.26 0.71 0.19 -0.24 1.0 0.19 -0.21 1.3 0.19 -0.19 1.4 0.19 -0.16 1.4 0.19 -0.14 1.2 0.19 -0.11 0.94 0.19 -0.87E-01 0.71 0.19 -0.63E-01 0.54 0.19 -0.37E-01 0.42 0.19 -0.13E-01 0.36 0.19 0.13E-01 0.36 0.19 0.38E-01 0.42 0.19 0.63E-01 0.54 0.19 0.88E-01 0.71 0.19 0.11 0.94 0.19 0.14 1.2 0.19 0.16 1.4 0.19 0.19 1.4 0.19 0.21 1.3 0.19 0.24 1.0 0.19 0.26 0.71 0.19 0.29 0.54 0.19 0.31 0.55 0.19 0.34 0.63 0.19 0.36 0.56 0.19 0.39 0.31 0.19 0.41 0.11 0.19 0.44 0.24 0.19 0.46 0.66 0.19 0.49 1.1 0.21 -0.49 0.92 0.21 -0.46 0.56 0.21 -0.44 0.21 0.21 -0.41 0.22 0.21 -0.39 0.56 0.21 -0.36 0.90 0.21 -0.34 0.93 0.21 -0.31 0.70 0.21 -0.29 0.48 0.21 -0.26 0.50 0.21 -0.24 0.77 0.21 -0.21 1.1 0.21 -0.19 1.3 0.21 -0.16 1.3 0.21 -0.14 1.2 0.21 -0.11 0.95 0.21 -0.87E-01 0.72 0.21 -0.63E-01 0.54 0.21 -0.37E-01 0.42 0.21 -0.13E-01 0.37 0.21 0.13E-01 0.37 0.21 0.38E-01 0.42 0.21 0.63E-01 0.54 0.21 0.88E-01 0.72 0.21 0.11 0.95 0.21 0.14 1.2 0.21 0.16 1.3 0.21 0.19 1.3 0.21 0.21 1.1 0.21 0.24 0.77 0.21 0.26 0.50 0.21 0.29 0.48 0.21 0.31 0.70 0.21 0.34 0.93 0.21 0.36 0.90 0.21 0.39 0.56 0.21 0.41 0.22 0.21 0.44 0.21 0.21 0.46 0.56 0.21 0.49 0.92 0.24 -0.49 0.56 0.24 -0.46 0.34 0.24 -0.44 0.18 0.24 -0.41 0.34 0.24 -0.39 0.78 0.24 -0.36 1.1 0.24 -0.34 1.1 0.24 -0.31 0.75 0.24 -0.29 0.35 0.24 -0.26 0.23 0.24 -0.24 0.43 0.24 -0.21 0.77 0.24 -0.19 1.0 0.24 -0.16 1.1 0.24 -0.14 0.99 0.24 -0.11 0.80 0.24 -0.87E-01 0.61 0.24 -0.63E-01 0.45 0.24 -0.37E-01 0.35 0.24 -0.13E-01 0.30 0.24 0.13E-01 0.30 0.24 0.38E-01 0.35 0.24 0.63E-01 0.45 0.24 0.88E-01 0.61 0.24 0.11 0.80 0.24 0.14 0.99 0.24 0.16 1.1 0.24 0.19 1.0 0.24 0.21 0.77 0.24 0.24 0.43 0.24 0.26 0.23 0.24 0.29 0.35 0.24 0.31 0.75 0.24 0.34 1.1 0.24 0.36 1.1 0.24 0.39 0.78 0.24 0.41 0.34 0.24 0.44 0.18 0.24 0.46 0.34 0.24 0.49 0.56 0.26 -0.49 0.22 0.26 -0.46 0.12 0.26 -0.44 0.10 0.26 -0.41 0.33 0.26 -0.39 0.76 0.26 -0.36 1.1 0.26 -0.34 1.1 0.26 -0.31 0.72 0.26 -0.29 0.30 0.26 -0.26 0.11 0.26 -0.24 0.23 0.26 -0.21 0.50 0.26 -0.19 0.71 0.26 -0.16 0.76 0.26 -0.14 0.67 0.26 -0.11 0.52 0.26 -0.87E-01 0.39 0.26 -0.63E-01 0.29 0.26 -0.37E-01 0.23 0.26 -0.13E-01 0.20 0.26 0.13E-01 0.20 0.26 0.38E-01 0.23 0.26 0.63E-01 0.29 0.26 0.88E-01 0.39 0.26 0.11 0.52 0.26 0.14 0.67 0.26 0.16 0.76 0.26 0.19 0.71 0.26 0.21 0.50 0.26 0.24 0.23 0.26 0.26 0.11 0.26 0.29 0.30 0.26 0.31 0.72 0.26 0.34 1.1 0.26 0.36 1.1 0.26 0.39 0.76 0.26 0.41 0.33 0.26 0.44 0.10 0.26 0.46 0.12 0.26 0.49 0.22 0.29 -0.49 0.95E-01 0.29 -0.46 0.53E-01 0.29 -0.44 0.57E-01 0.29 -0.41 0.21 0.29 -0.39 0.50 0.29 -0.36 0.77 0.29 -0.34 0.84 0.29 -0.31 0.67 0.29 -0.29 0.43 0.29 -0.26 0.30 0.29 -0.24 0.35 0.29 -0.21 0.48 0.29 -0.19 0.54 0.29 -0.16 0.48 0.29 -0.14 0.36 0.29 -0.11 0.25 0.29 -0.87E-01 0.19 0.29 -0.63E-01 0.16 0.29 -0.37E-01 0.15 0.29 -0.13E-01 0.15 0.29 0.13E-01 0.15 0.29 0.38E-01 0.15 0.29 0.63E-01 0.16 0.29 0.88E-01 0.19 0.29 0.11 0.25 0.29 0.14 0.36 0.29 0.16 0.48 0.29 0.19 0.54 0.29 0.21 0.48 0.29 0.24 0.35 0.29 0.26 0.30 0.29 0.29 0.43 0.29 0.31 0.67 0.29 0.34 0.84 0.29 0.36 0.77 0.29 0.39 0.50 0.29 0.41 0.21 0.29 0.44 0.57E-01 0.29 0.46 0.53E-01 0.29 0.49 0.95E-01 0.31 -0.49 0.21 0.31 -0.46 0.20 0.31 -0.44 0.16 0.31 -0.41 0.14 0.31 -0.39 0.20 0.31 -0.36 0.34 0.31 -0.34 0.51 0.31 -0.31 0.62 0.31 -0.29 0.67 0.31 -0.26 0.72 0.31 -0.24 0.75 0.31 -0.21 0.70 0.31 -0.19 0.55 0.31 -0.16 0.35 0.31 -0.14 0.21 0.31 -0.11 0.16 0.31 -0.87E-01 0.20 0.31 -0.63E-01 0.23 0.31 -0.37E-01 0.24 0.31 -0.13E-01 0.22 0.31 0.13E-01 0.22 0.31 0.38E-01 0.24 0.31 0.63E-01 0.23 0.31 0.88E-01 0.20 0.31 0.11 0.16 0.31 0.14 0.21 0.31 0.16 0.35 0.31 0.19 0.55 0.31 0.21 0.70 0.31 0.24 0.75 0.31 0.26 0.72 0.31 0.29 0.67 0.31 0.31 0.62 0.31 0.34 0.51 0.31 0.36 0.34 0.31 0.39 0.20 0.31 0.41 0.14 0.31 0.44 0.16 0.31 0.46 0.20 0.31 0.49 0.21 0.34 -0.49 0.41 0.34 -0.46 0.48 0.34 -0.44 0.48 0.34 -0.41 0.33 0.34 -0.39 0.14 0.34 -0.36 0.66E-01 0.34 -0.34 0.21 0.34 -0.31 0.51 0.34 -0.29 0.84 0.34 -0.26 1.1 0.34 -0.24 1.1 0.34 -0.21 0.93 0.34 -0.19 0.63 0.34 -0.16 0.36 0.34 -0.14 0.28 0.34 -0.11 0.37 0.34 -0.87E-01 0.51 0.34 -0.63E-01 0.54 0.34 -0.37E-01 0.47 0.34 -0.13E-01 0.38 0.34 0.13E-01 0.38 0.34 0.38E-01 0.47 0.34 0.63E-01 0.54 0.34 0.88E-01 0.51 0.34 0.11 0.37 0.34 0.14 0.28 0.34 0.16 0.36 0.34 0.19 0.63 0.34 0.21 0.93 0.34 0.24 1.1 0.34 0.26 1.1 0.34 0.29 0.84 0.34 0.31 0.51 0.34 0.34 0.21 0.34 0.36 0.66E-01 0.34 0.39 0.14 0.34 0.41 0.33 0.34 0.44 0.48 0.34 0.46 0.48 0.34 0.49 0.41 0.36 -0.49 0.52 0.36 -0.46 0.75 0.36 -0.44 0.92 0.36 -0.41 0.81 0.36 -0.39 0.45 0.36 -0.36 0.11 0.36 -0.34 0.66E-01 0.36 -0.31 0.34 0.36 -0.29 0.77 0.36 -0.26 1.1 0.36 -0.24 1.1 0.36 -0.21 0.90 0.36 -0.19 0.56 0.36 -0.16 0.38 0.36 -0.14 0.48 0.36 -0.11 0.77 0.36 -0.87E-01 0.99 0.36 -0.63E-01 0.95 0.36 -0.37E-01 0.69 0.36 -0.13E-01 0.45 0.36 0.13E-01 0.45 0.36 0.38E-01 0.69 0.36 0.63E-01 0.95 0.36 0.88E-01 0.99 0.36 0.11 0.77 0.36 0.14 0.48 0.36 0.16 0.38 0.36 0.19 0.56 0.36 0.21 0.90 0.36 0.24 1.1 0.36 0.26 1.1 0.36 0.29 0.77 0.36 0.31 0.34 0.36 0.34 0.66E-01 0.36 0.36 0.11 0.36 0.39 0.45 0.36 0.41 0.81 0.36 0.44 0.92 0.36 0.46 0.75 0.36 0.49 0.52 0.39 -0.49 0.47 0.39 -0.46 0.88 0.39 -0.44 1.3 0.39 -0.41 1.4 0.39 -0.39 0.98 0.39 -0.36 0.45 0.39 -0.34 0.14 0.39 -0.31 0.20 0.39 -0.29 0.50 0.39 -0.26 0.76 0.39 -0.24 0.78 0.39 -0.21 0.56 0.39 -0.19 0.31 0.39 -0.16 0.31 0.39 -0.14 0.63 0.39 -0.11 1.1 0.39 -0.87E-01 1.3 0.39 -0.63E-01 1.2 0.39 -0.37E-01 0.73 0.39 -0.13E-01 0.35 0.39 0.13E-01 0.35 0.39 0.38E-01 0.73 0.39 0.63E-01 1.2 0.39 0.88E-01 1.3 0.39 0.11 1.1 0.39 0.14 0.63 0.39 0.16 0.31 0.39 0.19 0.31 0.39 0.21 0.56 0.39 0.24 0.78 0.39 0.26 0.76 0.39 0.29 0.50 0.39 0.31 0.20 0.39 0.34 0.14 0.39 0.36 0.45 0.39 0.39 0.98 0.39 0.41 1.4 0.39 0.44 1.3 0.39 0.46 0.88 0.39 0.49 0.47 0.41 -0.49 0.32 0.41 -0.46 0.81 0.41 -0.44 1.4 0.41 -0.41 1.6 0.41 -0.39 1.4 0.41 -0.36 0.81 0.41 -0.34 0.33 0.41 -0.31 0.14 0.41 -0.29 0.21 0.41 -0.26 0.33 0.41 -0.24 0.34 0.41 -0.21 0.22 0.41 -0.19 0.11 0.41 -0.16 0.24 0.41 -0.14 0.65 0.41 -0.11 1.1 0.41 -0.87E-01 1.3 0.41 -0.63E-01 1.1 0.41 -0.37E-01 0.61 0.41 -0.13E-01 0.18 0.41 0.13E-01 0.18 0.41 0.38E-01 0.61 0.41 0.63E-01 1.1 0.41 0.88E-01 1.3 0.41 0.11 1.1 0.41 0.14 0.65 0.41 0.16 0.24 0.41 0.19 0.11 0.41 0.21 0.22 0.41 0.24 0.34 0.41 0.26 0.33 0.41 0.29 0.21 0.41 0.31 0.14 0.41 0.34 0.33 0.41 0.36 0.81 0.41 0.39 1.4 0.41 0.41 1.6 0.41 0.44 1.4 0.41 0.46 0.81 0.41 0.49 0.32 0.44 -0.49 0.19 0.44 -0.46 0.59 0.44 -0.44 1.1 0.44 -0.41 1.4 0.44 -0.39 1.3 0.44 -0.36 0.92 0.44 -0.34 0.48 0.44 -0.31 0.16 0.44 -0.29 0.57E-01 0.44 -0.26 0.10 0.44 -0.24 0.18 0.44 -0.21 0.21 0.44 -0.19 0.24 0.44 -0.16 0.34 0.44 -0.14 0.59 0.44 -0.11 0.87 0.44 -0.87E-01 1.0 0.44 -0.63E-01 0.85 0.44 -0.37E-01 0.50 0.44 -0.13E-01 0.21 0.44 0.13E-01 0.21 0.44 0.38E-01 0.50 0.44 0.63E-01 0.85 0.44 0.88E-01 1.0 0.44 0.11 0.87 0.44 0.14 0.59 0.44 0.16 0.34 0.44 0.19 0.24 0.44 0.21 0.21 0.44 0.24 0.18 0.44 0.26 0.10 0.44 0.29 0.57E-01 0.44 0.31 0.16 0.44 0.34 0.48 0.44 0.36 0.92 0.44 0.39 1.3 0.44 0.41 1.4 0.44 0.44 1.1 0.44 0.46 0.59 0.44 0.49 0.19 0.46 -0.49 0.12 0.46 -0.46 0.31 0.46 -0.44 0.59 0.46 -0.41 0.81 0.46 -0.39 0.88 0.46 -0.36 0.75 0.46 -0.34 0.48 0.46 -0.31 0.20 0.46 -0.29 0.53E-01 0.46 -0.26 0.12 0.46 -0.24 0.34 0.46 -0.21 0.56 0.46 -0.19 0.66 0.46 -0.16 0.63 0.46 -0.14 0.55 0.46 -0.11 0.52 0.46 -0.87E-01 0.55 0.46 -0.63E-01 0.57 0.46 -0.37E-01 0.55 0.46 -0.13E-01 0.52 0.46 0.13E-01 0.52 0.46 0.38E-01 0.55 0.46 0.63E-01 0.57 0.46 0.88E-01 0.55 0.46 0.11 0.52 0.46 0.14 0.55 0.46 0.16 0.63 0.46 0.19 0.66 0.46 0.21 0.56 0.46 0.24 0.34 0.46 0.26 0.12 0.46 0.29 0.53E-01 0.46 0.31 0.20 0.46 0.34 0.48 0.46 0.36 0.75 0.46 0.39 0.88 0.46 0.41 0.81 0.46 0.44 0.59 0.46 0.46 0.31 0.46 0.49 0.12 0.49 -0.49 0.10 0.49 -0.46 0.12 0.49 -0.44 0.19 0.49 -0.41 0.32 0.49 -0.39 0.47 0.49 -0.36 0.52 0.49 -0.34 0.41 0.49 -0.31 0.21 0.49 -0.29 0.95E-01 0.49 -0.26 0.22 0.49 -0.24 0.56 0.49 -0.21 0.92 0.49 -0.19 1.1 0.49 -0.16 0.89 0.49 -0.14 0.56 0.49 -0.11 0.29 0.49 -0.87E-01 0.25 0.49 -0.63E-01 0.41 0.49 -0.37E-01 0.66 0.49 -0.13E-01 0.83 0.49 0.13E-01 0.83 0.49 0.38E-01 0.66 0.49 0.63E-01 0.41 0.49 0.88E-01 0.25 0.49 0.11 0.29 0.49 0.14 0.56 0.49 0.16 0.89 0.49 0.19 1.1 0.49 0.21 0.92 0.49 0.24 0.56 0.49 0.26 0.22 0.49 0.29 0.95E-01 0.49 0.31 0.21 0.49 0.34 0.41 0.49 0.36 0.52 0.49 0.39 0.47 0.49 0.41 0.32 0.49 0.44 0.19 0.49 0.46 0.12 0.49 0.49 0.10 ngraph-gtk-6.08.00/demo/demo2.ngp.in0000644000175000017500000003545013230344424013723 00000000000000#! ngraph #%creator: Ngraph for GTK+ #%version: 6.03.48.gtk-23 new axis name:cX1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-2.500000000000000e+00 axis::max=3.200000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=4000 axis::y=16510 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis='axis:1' axis::adjust_position=0 axis::arrow=end axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=both axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=150 axis::gauge_width1=40 axis::gauge_length2=300 axis::gauge_width2=40 axis::gauge_length3=400 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=true axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=350 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:cY1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-5.000000000000000e+00 axis::max=4.200000000000000e+01 axis::inc=1.000000000000000e+01 axis::div=0 axis::type=linear axis::x=10140 axis::y=18000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis='axis:0' axis::adjust_position=0 axis::arrow=end axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=both axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=150 axis::gauge_width1=40 axis::gauge_length2=300 axis::gauge_width2=40 axis::gauge_length3=400 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=true axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=350 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::grouping 3 0 1 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo2.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=errorbar_y data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo2.dat' new fit fit::profile= fit::type=user fit::min=0.000000000000000e+00 fit::max=0.000000000000000e+00 fit::div=500 fit::interpolation=false fit::through_point=false fit::point_x=0.000000000000000e+00 fit::point_y=0.000000000000000e+00 fit::equation='3.334342264725757e+01*EXP(-(((X--1.323840682693712e+00)*1.167633670539841e+00)^2))+7.533588819881534e+00*EXP(-(((X-1.423928452598031e+00)*1.482809609014573e+00)^2))+-1.391372284014659e+00' fit::poly_dimension=5 fit::weight_func= fit::user_func='%01*EXP(-(((X-%02)*%03)^2))+%04*EXP(-(((X-%05)*%06)^2))+%00' fit::derivative=true fit::derivative0='1' fit::derivative1='EXP(-(((X-%02)*%03)^2))' fit::derivative2='2*(X-%02)*%03^2*%01*EXP(-(((X-%02)*%03)^2))' fit::derivative3='-2*%03*(X-%02)^2*%01*EXP(-(((X-%02)*%03)^2))' fit::derivative4='EXP(-(((X-%05)*%06)^2))' fit::derivative5='2*(X-%05)*%06^2*%04*EXP(-(((X-%05)*%06)^2))' fit::derivative6='-2*%06*(X-%05)^2*%04*EXP(-(((X-%05)*%06)^2))' fit::derivative7= fit::derivative8= fit::derivative9= fit::converge=1.000000000000000e+00 fit::parameter0=0.000000000000000e+00 fit::parameter1=3.000000000000000e+01 fit::parameter2=-1.000000000000000e+00 fit::parameter3=1.000000000000000e+00 fit::parameter4=5.000000000000000e+00 fit::parameter5=1.500000000000000e+00 fit::parameter6=1.000000000000000e+00 fit::parameter7=0.000000000000000e+00 fit::parameter8=0.000000000000000e+00 fit::parameter9=0.000000000000000e+00 fit::display=true new data data::hidden=false data::R=255 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=fit data::interpolation=spline data::math_x= data::math_y= data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo2.dat' data::fit='fit:^'${fit::oid} new fit fit::profile= fit::type=user fit::min=0.000000000000000e+00 fit::max=0.000000000000000e+00 fit::div=500 fit::interpolation=false fit::through_point=false fit::point_x=0.000000000000000e+00 fit::point_y=0.000000000000000e+00 fit::equation='3.228016431016133e+01*EXP(-(((X--1.324333233615322e+00)*1.229080100751821e+00)^2))+6.052084367385491e+00*EXP(-(((X-1.465076470890410e+00)*1.601264690141752e+00)^2))+-5.392649863737123e-02' fit::poly_dimension=5 fit::weight_func= fit::user_func='%01*EXP(-(((X-%02)*%03)^2))+%04*EXP(-(((X-%05)*%06)^2))+%00' fit::derivative=true fit::derivative0='1' fit::derivative1='EXP(-(((X-%02)*%03)^2))' fit::derivative2='2*(X-%02)*%03^2*%01*EXP(-(((X-%02)*%03)^2))' fit::derivative3='-2*%03*(X-%02)^2*%01*EXP(-(((X-%02)*%03)^2))' fit::derivative4='EXP(-(((X-%05)*%06)^2))' fit::derivative5='2*(X-%05)*%06^2*%04*EXP(-(((X-%05)*%06)^2))' fit::derivative6='-2*%06*(X-%05)^2*%04*EXP(-(((X-%05)*%06)^2))' fit::derivative7= fit::derivative8= fit::derivative9= fit::converge=1.000000000000000e+00 fit::parameter0=0.000000000000000e+00 fit::parameter1=3.000000000000000e+01 fit::parameter2=-1.000000000000000e+00 fit::parameter3=1.000000000000000e+00 fit::parameter4=5.000000000000000e+00 fit::parameter5=1.500000000000000e+00 fit::parameter6=1.000000000000000e+00 fit::parameter7=0.000000000000000e+00 fit::parameter8=0.000000000000000e+00 fit::parameter9=0.000000000000000e+00 fit::display=true new data data::hidden=false data::R=0 data::G=0 data::B=255 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=fit data::interpolation=spline data::math_x= data::math_y= data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask='36 37 39' data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo2.dat' data::fit='fit:^'${fit::oid} new rectangle rectangle::hidden=false rectangle::fill_R=255 rectangle::fill_G=255 rectangle::fill_B=128 rectangle::clip=true rectangle::redraw_flag=true rectangle::x1=13718 rectangle::y1=4859 rectangle::x2=20575 rectangle::y2=7093 rectangle::fill=true rectangle::stroke=true rectangle::stroke_R=0 rectangle::stroke_G=0 rectangle::stroke_B=0 rectangle::width=40 rectangle::style= new rectangle rectangle::hidden=false rectangle::fill_R=255 rectangle::fill_G=255 rectangle::fill_B=128 rectangle::clip=true rectangle::redraw_flag=true rectangle::x1=13718 rectangle::y1=9859 rectangle::x2=20590 rectangle::y2=12093 rectangle::fill=true rectangle::stroke=true rectangle::stroke_R=0 rectangle::stroke_G=0 rectangle::stroke_B=0 rectangle::width=40 rectangle::style= new path path::type=line path::hidden=false path::R=255 path::G=0 path::B=0 path::clip=true path::redraw_flag=true path::points='10947 4274 13053 4274' path::width=40 path::style= path::join=miter path::miter_limit=1000 path::arrow=none path::arrow_length=72420 path::arrow_width=60000 new path path::type=line path::hidden=false path::R=0 path::G=0 path::B=255 path::clip=true path::redraw_flag=true path::points='10947 8674 13053 8674' path::width=40 path::style= path::join=miter path::miter_limit=1000 path::arrow=none path::arrow_length=72420 path::arrow_width=60000 new path path::type=line path::hidden=false path::R=0 path::G=0 path::B=0 path::clip=true path::redraw_flag=true path::points='13300 19300 15621 17844' path::width=40 path::style= path::join=miter path::miter_limit=1000 path::arrow=end path::arrow_length=72420 path::arrow_width=60000 new path path::type=line path::hidden=false path::R=0 path::G=0 path::B=0 path::clip=true path::redraw_flag=true path::points='8086 5622 7173 6309' path::width=40 path::style= path::join=miter path::miter_limit=1000 path::arrow=end path::arrow_length=72426 path::arrow_width=60000 new arc arc::hidden=false arc::R=0 arc::G=0 arc::B=0 arc::clip=true arc::redraw_flag=true arc::x=16441 arc::y=17573 arc::rx=1000 arc::ry=500 arc::angle1=0 arc::angle2=36000 arc::fill=false arc::pieslice=true arc::width=30 arc::style= new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Demo #2: LEAST SQUARE FIT' text::x=4000 text::y=2842 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Double Gaussian Fit' text::x=13474 text::y=4537 text::pt=1800 text::font='Sans-serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='0' text::x=9500 text::y=17400 text::pt=2400 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Double Gaussian Fit\n(masked)' text::x=13474 text::y=8937 text::pt=1800 text::font='Sans-serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='masked data' text::x=9815 text::y=19527 text::pt=1600 text::font='Sans-serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='peak-1: (%pf{%+#.4g %{file:2:fit_prm:2}}, %pf{%+#.4g %{file:2:fit_calc %{file:2:fit_prm:2}}})' text::x=14000 text::y=6164 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='peak-2: (%pf{%+#.4g %{file:2:fit_prm:5}}, %pf{%+#.4g %{file:2:fit_calc %{file:2:fit_prm:5}}})' text::x=14000 text::y=6840 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='peak-1: (%pf{%+#.4g %{file:3:fit_prm:2}}, %pf{%+#.4g %{file:3:fit_calc %{file:3:fit_prm:2}}})' text::x=14000 text::y=11164 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='peak-2: (%pf{%+#.4g %{file:3:fit_prm:5}}, %pf{%+#.4g %{file:3:fit_calc %{file:3:fit_prm:5}}})' text::x=14000 text::y=11840 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='# %{file:2:dnum}' text::x=14000 text::y=5564 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='# %{file:3:dnum} (%pf{%d %[%{file:2:dnum}-%{file:3:dnum}]} masked)' text::x=14000 text::y=10564 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='%pf{%.4g %{file:0:dy 7}}' text::x=8157 text::y=5812 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=4000 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj= ngraph-gtk-6.08.00/demo/demo6.ngp.in0000644000175000017500000003440313230344424013724 00000000000000#!ngraph #%creator: Ngraph #%version: 6.06.04 new axis name:fX1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-2.500000000000000e+01 axis::max=2.500000000000000e+01 axis::inc=1.000000000000000e+01 axis::div=0 axis::type=linear axis::x=2200 axis::y=22000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fY1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-2.500000000000000e+01 axis::max=2.500000000000000e+01 axis::inc=1.000000000000000e+01 axis::div=0 axis::type=linear axis::x=2200 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fU1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=2200 axis::y=8000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fR1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=16200 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::grouping 1 0 1 2 3 new axis name:fX2 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-1.000000000000000e+00 axis::max=1.000000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=18000 axis::y=22000 axis::direction=0 axis::baseline=true axis::length=600 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=none axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fY2 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=18000 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fU2 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=18000 axis::y=8000 axis::direction=0 axis::baseline=true axis::length=600 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:4' axis::gauge=none axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= new axis name:fR2 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=4.000000000000000e+03 axis::inc=1.000000000000000e+03 axis::div=0 axis::type=linear axis::x=18600 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=0 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:5' axis::gauge=none axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=1 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::grouping 1 4 5 6 7 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=polygon_solid_fill data::interpolation=spline data::fit= data::math_x= data::math_y='HSB(%03, 1, 1);Y' data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#' data::ifs=' , (' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo6.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=1 data::y=2 data::type=polygon data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=10 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#' data::ifs=' , (' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::file='DOCDIRDEF/demo6.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=0 data::y=0 data::type=line data::interpolation=spline data::fit= data::math_x='0' data::math_y='HSB((Y-1)/MAXY, 1, 1);MAXY-Y' data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=600 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#' data::ifs=' , (' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:7' data::data_clip=true data::file='DOCDIRDEF/demo6.dat' new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Demo #6: POLYGON PLOT' text::x=2500 text::y=6800 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj='axisgrid file axis merge legend rectangle arc path mark text' ngraph-gtk-6.08.00/demo/demo5c.ngp0000644000175000017500000000376013070106167013465 00000000000000#! ngraph # new text text::x=3000 text::y=6500 text::font="Sans-serif" text::style=1 text::text="Demo #5C: TEXT" # for i in `seq 0 4500 31500` do new text text::x=11000 text::y=13500 text::pt=6000 text::font=Sans-serif text::style=3 text::direction=$i text::R=0xff text::G=0xcf text::B=0xff text::A=0x7f text::text=" "${system::name} done # Y=8000 for i in "Hello, world!" \ "Здравей, ÑвÑÑ‚!" \ "Hola, món!" \ "Hej verden!" \ "Hallo, Welt!" \ "Γεια σου, κόσμε!" \ "Saluton, mondo!" \ "¡Hola mundo!" \ "Tere kõik!" \ "Kaixo, mundu!" \ "سلام بر همه!" \ "Terve maailma!" \ "Bonjour, le monde!" \ "Dia duit, a dhomhain!" \ "¡Ola, mundo!" do new text text::x=500 text::y=${Y} text::pt=2000 text::font=Serif text::direction=0 text::text="${i}" Y=`iexpr $Y+800` done Y=8000 for i in "!×לועה לכל ×ולש" \ "Pozdrav, svijete!" \ "Szia Világ!" \ "Halo, dunia!" \ "Salve, mondo!" \ "世界よã€ã“ã‚“ã«ã¡ã¯ï¼" \ "სáƒáƒšáƒáƒ›áƒ˜ მსáƒáƒ¤áƒšáƒ˜áƒáƒ¡!" \ "안녕하세요, 여러분!" \ "Sveika, pasaule!" \ "Hello, Duniaku!" \ "Hei, verden!" \ "Hallo, wereld!" \ "Hei, verda!" \ "Witaj Å›wiecie!" \ "Olá, mundo!" do new text text::x=7500 text::y=${Y} text::pt=2000 text::font=Serif text::direction=0 text::text="${i}" Y=`iexpr $Y+800` done Y=8000 for i in "Bom dia, mundo!" \ "Chau, muond!" \ "Hello, world!" \ "ЗдравÑтвуй, мир!" \ "Ahoj, svet!" \ "Zdravo, svet!" \ "Поздрав Ñвима!" \ "Hej, världen!" \ "สวัสดี, ชาวโลà¸!" \ "Merhaba, dünya!" \ "Привіт Ñвіт!" \ "Chào thế giá»›i !" \ "世界你好ï¼" \ "哈囉,大家好ï¼" do new text text::x=15500 text::y=${Y} text::pt=2000 text::font=Serif text::direction=0 text::text="${i}" Y=`iexpr $Y+800` done # new text R:255 G:0 B:0 text::x=3000 text::y=22000 text::pt=4000 text::font=Serif text::style=3 text::direction=0 text::text="date: %{system::date:0}\ntime: %{system::time:0}" # new gra ngraph-gtk-6.08.00/demo/demo7.ngp0000644000175000017500000002615413070106167013326 00000000000000#!ngraph #%creator: Ngraph #%version: 6.07.00 new axis name:fX1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-3.000000000000000e+00 axis::max=1.000000000000000e+01 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=3000 axis::y=21800 axis::direction=0 axis::baseline=true axis::length=14140 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=363 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=121 axis::gauge_width1=40 axis::gauge_length2=242 axis::gauge_width2=40 axis::gauge_length3=363 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2420 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fY1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-3.000000000000000e+00 axis::max=1.000000000000000e+01 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=3000 axis::y=21800 axis::direction=9000 axis::baseline=true axis::length=14140 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=363 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=121 axis::gauge_width1=40 axis::gauge_length2=242 axis::gauge_width2=40 axis::gauge_length3=363 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2420 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fU1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=3000 axis::y=7660 axis::direction=0 axis::baseline=true axis::length=14140 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=363 axis::wave_width=40 axis::reference='axis:0' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=121 axis::gauge_width1=40 axis::gauge_length2=242 axis::gauge_width2=40 axis::gauge_length3=363 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2420 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fR1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=17140 axis::y=21800 axis::direction=9000 axis::baseline=true axis::length=14140 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=363 axis::wave_width=40 axis::reference='axis:1' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=121 axis::gauge_width1=40 axis::gauge_length2=242 axis::gauge_width2=40 axis::gauge_length3=363 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2420 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= axis::grouping 1 0 1 2 3 new data data::hidden=false data::R=237 data::G=212 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x='F(X)*sin(X)' data::math_y='F(X)*cos(X)+7' data::func_f='cos((3+1/2)*X)/2+2' data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=80 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=0.000000000000000e+00 data::range_max=1.884955592153876e+01 data::range_div=512 data::array= data::file= new data data::hidden=false data::R=245 data::G=121 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=polygon data::interpolation=spline data::fit= data::math_x='F(X)*sin(X)' data::math_y='F(X)*cos(X)' data::func_f='cos((3+1/3)*X)/2+2' data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=80 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=0.000000000000000e+00 data::range_max=1.884955592153876e+01 data::range_div=512 data::array= data::file= new data data::hidden=false data::R=52 data::G=101 data::B=164 data::A=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=polygon data::interpolation=spline data::fit= data::math_x='F(X)*sin(X)+7' data::math_y='F(X)*cos(X)' data::func_f='cos((4+1/3)*X)/2+2' data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=80 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=0.000000000000000e+00 data::range_max=1.884955592153876e+01 data::range_div=512 data::array= data::file= new data data::hidden=false data::R=115 data::G=210 data::B=22 data::A=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x='F(X)*sin(X)+7' data::math_y='F(X)*cos(X)+7' data::func_f='cos((5+1/2)*X)/2+2' data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=80 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=0.000000000000000e+00 data::range_max=1.884955592153876e+01 data::range_div=512 data::array= data::file= new data data::hidden=false data::R=173 data::G=127 data::B=168 data::A=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x='2.5*sin(x*F())*cos(x/F())+cos(x*F())*sin(x/F())/1.5+3.4' data::math_y='2.5*sin(x*F())*sin(x/F())-cos(x*F())*cos(x/F())/1.5+3.5' data::func_f='3' data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=80 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=false data::range_min=0.000000000000000e+00 data::range_max=1.884955592153876e+01 data::range_div=512 data::array= data::file= new text text::hidden=false text::R=0 text::G=0 text::B=0 text::A=255 text::clip=true text::redraw_flag=true text::text='Demo #7: FUNCTION PLOT' text::x=2500 text::y=6800 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj='axisgrid axis data merge legend rectangle arc path mark text' ngraph-gtk-6.08.00/demo/demo2.dat0000644000175000017500000000550013070106167013275 00000000000000-2.3750000000E+00 6.3853206635E+00 -5.3208610535E-01 5.1208610535E-01 -1.8750000000E+00 1.6853206635E+01 -5.6208610535E-01 5.6208610535E-01 -1.7500000000E+00 2.5078868867E+01 -1.8241024023E+00 1.8241024023E+00 -1.6250000000E+00 3.0353093393E+01 -1.7673212325E+00 1.7673212325E+00 -1.5000000000E+00 3.1408799923E+01 -9.3877496140E-01 9.3877496140E-01 -1.3750000000E+00 3.2429282847E+01 -1.1462057545E+00 1.1462057545E+00 -1.2500000000E+00 3.3987725690E+01 -2.4259917514E+00 2.4259917514E+00 -1.1250000000E+00 2.8208945768E+01 -6.2218833831E-01 6.2218833831E-01 -1.0000000000E+00 2.7270073024E+01 -1.6350365122E+00 1.6350365122E+00 -8.7500000000E-01 2.0984815797E+01 -2.1126470994E-01 2.1126470994E-01 -7.5000000000E-01 1.8000241324E+01 -5.4064800555E-01 5.4064800555E-01 -6.2500000000E-01 1.7279030306E+01 -1.9953043375E+00 1.9953043375E+00 -5.0000000000E-01 1.3373603736E+01 -1.7649268679E+00 1.7649268679E+00 -3.7500000000E-01 8.7321208054E+00 -1.0079518822E+00 1.0079518822E+00 -2.5000000000E-01 7.7763810440E+00 -1.8886788032E+00 1.8886788032E+00 -1.2500000000E-01 4.1519917478E+00 -1.2005228514E+00 1.2005228514E+00 0.0000000000E+00 1.6535825690E+00 -8.2679128449E-01 8.2679128449E-01 1.2500000000E-01 -1.1561405845E+00 -4.8379292712E-02 1.1379292712E+00 2.5000000000E-01 -1.5127512394E-02 -1.0075729626E+00 1.5075729626E+00 3.7500000000E-01 -2.0045571146E+00 -1.8493152573E-01 1.8493152573E+00 5.0000000000E-01 1.1148215260E+00 -1.7292857630E+00 1.7292857630E+00 6.2500000000E-01 2.2247068724E+00 -2.1169158141E+00 2.1169158141E+00 7.5000000000E-01 3.3490430529E+00 -2.3996191827E+00 2.3996191827E+00 8.7500000000E-01 1.7226515696E+00 -1.2371955358E+00 1.2371955358E+00 1.0000000000E+00 3.3536891581E+00 -1.6768445791E+00 1.6768445791E+00 1.1250000000E+00 3.5535274167E+00 -1.4162748167E+00 1.4162748167E+00 1.2500000000E+00 6.0451963649E+00 -2.3560942762E+00 2.3560942762E+00 1.3750000000E+00 4.9219230353E+00 -1.5772487491E+00 1.5772487491E+00 1.5000000000E+00 6.8925221867E+00 -2.4618860934E+00 2.4618860934E+00 1.6250000000E+00 6.3929323899E+00 -2.2472932213E+00 2.2472932213E+00 1.7500000000E+00 3.4379028028E+00 -9.4990843267E-01 9.4990843267E-01 1.8750000000E+00 3.4705525381E+00 -1.2882700434E+00 1.2882700434E+00 2.0000000000E+00 4.9368886871E+00 -2.4684443435E+00 2.4684443435E+00 2.1250000000E+00 4.1309615225E-01 -7.4583945796E-01 7.4583945796E-01 2.2500000000E+00 1.3865790900E+00 -1.8138950138E+00 1.8138950138E+00 2.3750000000E+00 -3.9947766964E+00 -1.7688228167E-01 3.7688228167E+00 2.5000000000E+00 -2.5849221658E+00 -8.1691391708E-01 3.1691391708E+00 2.6250000000E+00 2.6704813354E-02 -1.3252878315E+00 0.3252878315E+00 2.7500000000E+00 -3.3922680540E+00 -4.4693237927E-01 4.4693237927E+00 2.8750000000E+00 1.6707247891E+00 -0.2725114424E+00 0.2725114424E+00 ngraph-gtk-6.08.00/demo/demo9.ngp.in0000644000175000017500000003555413244172342013742 00000000000000#!ngraph #%creator: Ngraph #%version: 6.07.05 new axis name:fX1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=1.000000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=24600 axis::direction=0 axis::baseline=true axis::length=11000 axis::width=40 axis::style= axis::auto_scale_margin=0 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fY1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=7.000000000000000e-01 axis::max=4.300000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=24600 axis::direction=9000 axis::baseline=false axis::length=11000 axis::width=40 axis::style= axis::auto_scale_margin=1000 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=none axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fU1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=13600 axis::direction=0 axis::baseline=true axis::length=11000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fR1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=16000 axis::y=24600 axis::direction=9000 axis::baseline=true axis::length=11000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= axis::grouping 1 0 1 2 3 new axis name:fX2 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=5.000000000000000e-01 axis::max=4.500000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=1000 axis::y=12400 axis::direction=0 axis::baseline=false axis::length=19000 axis::width=40 axis::style= axis::auto_scale_margin=0 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=none axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fY2 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=-5.000000000000000e-01 axis::max=5.000000000000000e-01 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=1000 axis::y=12400 axis::direction=9000 axis::baseline=true axis::length=4500 axis::width=40 axis::style= axis::auto_scale_margin=1000 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fU2 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=1000 axis::y=7900 axis::direction=0 axis::baseline=true axis::length=19000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:4' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fR2 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=20000 axis::y=12400 axis::direction=9000 axis::baseline=true axis::length=4500 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:5' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= axis::grouping 1 4 5 6 7 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=file data::save_path=unchange data::x=1 data::y=0 data::type=mark data::interpolation=spline data::fit= data::math_x='const HEIGHT := 0.5; # height of a bar graph shift(col); # remove %0 from the array col n := size(col); # number of the data total := array_sum(col); # summation of the data start := 0; # start position of a rectangle for(0, 0, n - 1, 1, # draw rectangle for each data progn( i := RM(0), # index of the array width := col[i] / total, # width of a rectangle hsb2(i / n, 0.7, 1), # set fill color draw_rect(start, y - HEIGHT / 2, width, HEIGHT, TRUE, TRUE), start += width))' data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=0 data::line_width=40 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=1.000000000000000e+00 data::range_max=1.000000000000000e+01 data::range_div=512 data::array= data::file='DOCDIRDEF/demo9.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=file data::save_path=unchange data::x=1 data::y=0 data::type=mark data::interpolation=spline data::fit= data::math_x='const R := 0.4; # radius of a pie chart shift(col); # remove %0 from the array col n := size(col); # number of the data total := array_sum(col); # summation of the data for(0, 0, n - 1, 1, # draw pie-slice for each data progn( i := RM(0), # index of the array angle := col[i] / total * 360, hsb2(i / n, 0.7, 1), # set fill color draw_arc(y, 0, R, R, sum(angle), -angle, TRUE, TRUE, TRUE, TRUE)))' data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=0 data::line_width=40 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::data_clip=true data::range_min=1.000000000000000e+00 data::range_max=1.000000000000000e+01 data::range_div=512 data::array= data::file='DOCDIRDEF/demo9.dat' new text text::hidden=false text::R=0 text::G=0 text::B=0 text::A=255 text::clip=true text::redraw_flag=true text::text='Demo #9:\nDRAW\_RECT() and DRAW\_ARC() FUNCTION' text::x=4000 text::y=6842 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj='axisgrid axis data merge legend rectangle arc path mark text' ngraph-gtk-6.08.00/demo/demo.ngp.in0000644000175000017500000000315013230513526013632 00000000000000#! ngraph set +e ID=${gra:viewer:id} new sarray name="FILE" for demo in demo1 demo2 demo3 demo4 demo5a demo5b demo5c demo5d demo5e demo6 demo7 demo8 demo9 do sarray::add $demo done new sarray name="CAPTION" sarray::add "Demo #_1: COLOR(), RGB(), HSB() and MARKSIZE() FUNCTION" sarray::add "Demo #_2: LEAST SQUARE FIT" sarray::add "Demo #_3: AXIS DIVISION" sarray::add "Demo #_4: MULTI GRAPH" sarray::add "Demo #5_A: ARROW" sarray::add "Demo #5_B: MARK" sarray::add "Demo #5_C: TEXT" sarray::add "Demo #5_D: CURVE" sarray::add "Demo #5_E: AXIS" sarray::add "Demo #_6: POLYGON PLOT" sarray::add "Demo #_7: FUNCTION PLOT" sarray::add 'Demo #_8: DRAW__RECT(), DRAW__LINE() and COL[]' sarray::add 'Demo #_9: DRAW__RECT() and DRAW__ARC() FUNCTION' sarray::add "_Quit demo" caption="'${sarray::join="' '"}'" caption_num="${sarray:CAPTION:num}" del sarray:CAPTION new dialog dialog::title="demo" dialog::caption="select demonstration" dialog::select="0" while true do FILE_INDEX=`get dialog: -field radio:"$caption"` if [ -z "$FILE_INDEX" ] then break fi if [ "$FILE_INDEX" -ge ${sarray:FILE:num} ] then break fi demo=`get sarray:FILE -field get:$FILE_INDEX` for drawrable in `derive -instance draw` do del ${drawrable}:0-! done gra:$ID:clear . DOCDIRDEF/${demo}.ngp ID2=${gra::id} if [ $ID != $ID2 ] then gra:$ID:close for field in top_margin left_margin zoom draw_obj do cpy gra:$ID2,$ID $field done gra:$ID:open del gra:$ID2 fi menu::draw dialog::select=`iexpr "($FILE_INDEX + 1) \\ $caption_num"` done del dialog del sarray:FILE set -e ngraph-gtk-6.08.00/demo/demo4.ngp0000644000175000017500000005676213230344424013331 00000000000000#! ngraph new axisgrid axisgrid::hidden=false axisgrid::R=0 axisgrid::G=0 axisgrid::B=0 axisgrid::clip=true axisgrid::redraw_flag=true axisgrid::axis_x='axis:0' axisgrid::axis_y='axis:1' axisgrid::width1=0 axisgrid::style1='150 150' axisgrid::width2=0 axisgrid::style2= axisgrid::width3=40 axisgrid::style3='450 150 150 150' axisgrid::grid_x=false axisgrid::grid_y=true axisgrid::background=true axisgrid::BR=128 axisgrid::BG=255 axisgrid::BB=255 new axisgrid axisgrid::hidden=false axisgrid::R=0 axisgrid::G=0 axisgrid::B=0 axisgrid::clip=true axisgrid::redraw_flag=true axisgrid::axis_x='axis:4' axisgrid::axis_y='axis:5' axisgrid::width1=0 axisgrid::style1='150 150' axisgrid::width2=0 axisgrid::style2= axisgrid::width3=40 axisgrid::style3='450 150 150 150' axisgrid::grid_x=false axisgrid::grid_y=true axisgrid::background=true axisgrid::BR=128 axisgrid::BG=255 axisgrid::BB=255 new axis name:frameX axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=5.000000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=10500 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=right axis::num_begin=0 axis::num_step=1 axis::num_num=0 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameY axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-2.200000000000000e+00 axis::max=4.200000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=10500 axis::direction=9000 axis::baseline=true axis::length=7000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%+g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameU axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=3500 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=300 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameR axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=19000 axis::y=10500 axis::direction=9000 axis::baseline=true axis::length=7000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=300 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::grouping 1 0 1 2 3 new axis name:frameX_a axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=5.000000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=18000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=right axis::num_begin=0 axis::num_step=1 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameY_a axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=-1.200000000000000e+00 axis::max=1.200000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=18000 axis::direction=9000 axis::baseline=true axis::length=7000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2400 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameU_a axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=5000 axis::y=11000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:4' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameR_a axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=19000 axis::y=18000 axis::direction=9000 axis::baseline=true axis::length=7000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:5' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::grouping 1 4 5 6 7 new data data::hidden=false data::R=255 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='GAMMA(X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=0 data::B=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='EI(X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=0 data::B=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='EI(-X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=128 data::B=128 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='1-ERFC(X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=255 data::G=0 data::B=128 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='JN(0,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=255 data::G=0 data::B=128 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='JN(1,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=255 data::G=0 data::B=128 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='JN(2,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=128 data::B=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='YN(0,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style='200 50 100 50 100 50' data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=128 data::B=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='YN(1,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style='200 50 100 50 100 50' data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new data data::hidden=false data::R=0 data::G=128 data::B=255 data::clip=true data::redraw_flag=true data::source=range data::save_path=unchange data::x=1 data::y=2 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y='YN(2,X)' data::func_f='X' data::func_g='Y' data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=200 data::line_width=40 data::line_style='200 50 100 50 100 50' data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=2 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::range_min=0 data::range_max=5 data::range_div=512 new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Demo #4: MULTI GRAPH' text::x=3500 text::y=2842 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='X-Axis' text::x=11289 text::y=19500 text::pt=2400 text::font='Sans-serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Y-Axis' text::x=3263 text::y=12026 text::pt=2400 text::font='Sans-serif' text::style=3 text::space=0 text::direction=9000 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Γ(x)' text::x=14684 text::y=5553 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Ei(x)' text::x=8789 text::y=5553 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Ei(-x)' text::x=7053 text::y=8947 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='erf(x)' text::x=17184 text::y=6763 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Special function' text::x=13842 text::y=10026 text::pt=2000 text::font='Serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='J_0' text::x=6500 text::y=11600 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='J_1' text::x=7200 text::y=13000 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='J_2' text::x=7000 text::y=14100 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Y_0' text::x=5800 text::y=15500 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Y_1' text::x=8600 text::y=15500 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Y_2' text::x=10900 text::y=15700 text::pt=1600 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Bessel function' text::x=14000 text::y=17600 text::pt=2000 text::font='Serif' text::style=3 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=4000 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj= ngraph-gtk-6.08.00/demo/demo5e.ngp0000644000175000017500000000174613070106167013471 00000000000000#! ngraph # new text text::x=3000 text::y=6500 text::font="Sans-serif" text::style=1 text::text="Demo #5E: AXIS" # for i in `seq 0 3000 15000` do new axis name:axis${i} axis::min=0.0 axis::max=0.145 axis::inc=0.01 axis::type=linear axis::x=11000 axis::y=15000 axis::direction=$i axis::length=8000 axis::gauge=both axis::num=left axis::num_align=center axis::num_direction=normal axis::num_shift_n=300 axis::num_log_pow=TRUE axis::num_format="%g" axis::num_no_zero=true axis::num_pt=1200 axis::arrow=end done # for i in `seq 18000 3000 33000` do new axis name:axis${i} axis::min=0.0 axis::max=0.145 axis::inc=0.01 axis::type=linear axis::x=11000 axis::y=15000 axis::direction=$i axis::length=8000 axis::gauge=both axis::num=left axis::num_align=center axis::num_direction=parallel2 axis::num_shift_n=300 axis::num_log_pow=TRUE axis::num_format="%g" axis::num_no_zero=true axis::num_pt=1200 axis::arrow=end done # new gra ngraph-gtk-6.08.00/demo/demo5a.ngp0000644000175000017500000000175213070106167013462 00000000000000#! ngraph # new text text::x=3000 text::y=6500 text::font="Sans-serif" text::style=3 text::text="Demo #5A: ARROW" # new path type=line put path points="4000 7000 4000 12000" put path width=500 put path arrow=both put path arrow_length=36213 put path arrow_width=30000 # new path type=line put path points="7000 7000 15000 12000" put path style="600 300 200 300" put path arrow_length=36213 put path arrow_width=30000 put path width=500 put path arrow=begin # new path type=line put path points="7000 12000 15000 7000" put path style="600 300 200 300" put path arrow_length=36213 put path arrow_width=30000 put path width=500 put path arrow=end # for i in `seq 4 2 18` do new path type=line put path points="10000 18000 ${i}000 12500" put path width=${i}0 put path arrow=end done # for i in `seq 4 2 18` do new path type=line put path arrow_length=80000 put path arrow_width=160000 put path points="10000 18000 ${i}000 23500" put path width=${i}0 put path arrow=end done # new gra ngraph-gtk-6.08.00/demo/demo8.dat0000644000175000017500000240000013230344424013275 000000000000005.005E-03 4.634E-03 4.261E-03 3.891E-03 3.524E-03 3.164E-03 2.813E-03 2.473E-03 2.145E-03 1.834E-03 1.540E-03 1.265E-03 1.013E-03 7.841E-04 5.812E-04 4.060E-04 2.601E-04 1.451E-04 6.260E-05 1.389E-05 2.521E-07 2.278E-05 8.243E-05 1.800E-04 3.162E-04 4.916E-04 7.064E-04 9.609E-04 1.255E-03 1.589E-03 1.963E-03 2.375E-03 2.826E-03 3.314E-03 3.840E-03 4.402E-03 4.998E-03 5.628E-03 6.291E-03 6.984E-03 7.707E-03 8.458E-03 9.234E-03 1.004E-02 1.086E-02 1.170E-02 1.257E-02 1.344E-02 1.434E-02 1.525E-02 1.616E-02 1.709E-02 1.802E-02 1.896E-02 1.989E-02 2.083E-02 2.177E-02 2.270E-02 2.363E-02 2.455E-02 2.547E-02 2.637E-02 2.726E-02 2.814E-02 2.900E-02 2.985E-02 3.067E-02 3.148E-02 3.227E-02 3.304E-02 3.379E-02 3.452E-02 3.522E-02 3.590E-02 3.656E-02 3.719E-02 3.779E-02 3.838E-02 3.893E-02 3.946E-02 3.997E-02 4.045E-02 4.091E-02 4.134E-02 4.175E-02 4.213E-02 4.250E-02 4.283E-02 4.315E-02 4.344E-02 4.372E-02 4.397E-02 4.420E-02 4.442E-02 4.462E-02 4.479E-02 4.496E-02 4.510E-02 4.524E-02 4.535E-02 4.546E-02 4.555E-02 4.563E-02 4.570E-02 4.576E-02 4.581E-02 4.585E-02 4.589E-02 4.591E-02 4.593E-02 4.595E-02 4.596E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.596E-02 4.596E-02 4.595E-02 4.594E-02 4.594E-02 4.593E-02 4.592E-02 4.592E-02 4.591E-02 4.591E-02 4.590E-02 4.590E-02 4.590E-02 4.590E-02 4.590E-02 4.591E-02 4.591E-02 4.592E-02 4.592E-02 4.593E-02 4.594E-02 4.594E-02 4.595E-02 4.596E-02 4.596E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.596E-02 4.595E-02 4.593E-02 4.591E-02 4.589E-02 4.585E-02 4.581E-02 4.576E-02 4.570E-02 4.563E-02 4.555E-02 4.546E-02 4.535E-02 4.524E-02 4.510E-02 4.496E-02 4.479E-02 4.462E-02 4.442E-02 4.420E-02 4.397E-02 4.372E-02 4.344E-02 4.315E-02 4.283E-02 4.250E-02 4.213E-02 4.175E-02 4.134E-02 4.091E-02 4.045E-02 3.997E-02 3.946E-02 3.893E-02 3.838E-02 3.779E-02 3.719E-02 3.656E-02 3.590E-02 3.522E-02 3.452E-02 3.379E-02 3.304E-02 3.227E-02 3.148E-02 3.067E-02 2.985E-02 2.900E-02 2.814E-02 2.726E-02 2.637E-02 2.547E-02 2.455E-02 2.363E-02 2.270E-02 2.177E-02 2.083E-02 1.989E-02 1.896E-02 1.802E-02 1.709E-02 1.616E-02 1.525E-02 1.434E-02 1.344E-02 1.257E-02 1.170E-02 1.086E-02 1.004E-02 9.234E-03 8.458E-03 7.707E-03 6.984E-03 6.291E-03 5.628E-03 4.998E-03 4.402E-03 3.840E-03 3.314E-03 2.826E-03 2.375E-03 1.963E-03 1.589E-03 1.255E-03 9.609E-04 7.064E-04 4.916E-04 3.162E-04 1.800E-04 8.243E-05 2.278E-05 2.521E-07 1.389E-05 6.260E-05 1.451E-04 2.601E-04 4.060E-04 5.812E-04 7.841E-04 1.013E-03 1.265E-03 1.540E-03 1.834E-03 2.145E-03 2.473E-03 2.813E-03 3.164E-03 3.524E-03 3.891E-03 4.261E-03 4.634E-03 4.634E-03 4.258E-03 3.885E-03 3.516E-03 3.153E-03 2.799E-03 2.456E-03 2.127E-03 1.813E-03 1.518E-03 1.243E-03 9.900E-04 7.617E-04 5.598E-04 3.863E-04 2.428E-04 1.312E-04 5.282E-05 9.190E-06 1.565E-06 3.108E-05 9.874E-05 2.054E-04 3.517E-04 5.381E-04 7.652E-04 1.033E-03 1.342E-03 1.691E-03 2.081E-03 2.511E-03 2.980E-03 3.488E-03 4.033E-03 4.616E-03 5.234E-03 5.887E-03 6.573E-03 7.290E-03 8.037E-03 8.813E-03 9.614E-03 1.044E-02 1.129E-02 1.216E-02 1.305E-02 1.395E-02 1.487E-02 1.580E-02 1.674E-02 1.769E-02 1.865E-02 1.961E-02 2.057E-02 2.153E-02 2.249E-02 2.344E-02 2.439E-02 2.533E-02 2.626E-02 2.717E-02 2.808E-02 2.897E-02 2.984E-02 3.069E-02 3.153E-02 3.235E-02 3.314E-02 3.391E-02 3.466E-02 3.539E-02 3.609E-02 3.676E-02 3.741E-02 3.804E-02 3.864E-02 3.921E-02 3.975E-02 4.027E-02 4.076E-02 4.123E-02 4.167E-02 4.208E-02 4.247E-02 4.283E-02 4.317E-02 4.349E-02 4.378E-02 4.405E-02 4.430E-02 4.452E-02 4.473E-02 4.492E-02 4.508E-02 4.523E-02 4.537E-02 4.548E-02 4.559E-02 4.567E-02 4.575E-02 4.581E-02 4.586E-02 4.590E-02 4.593E-02 4.595E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.595E-02 4.594E-02 4.592E-02 4.590E-02 4.588E-02 4.585E-02 4.583E-02 4.580E-02 4.578E-02 4.575E-02 4.573E-02 4.571E-02 4.569E-02 4.567E-02 4.565E-02 4.564E-02 4.563E-02 4.562E-02 4.562E-02 4.561E-02 4.562E-02 4.562E-02 4.563E-02 4.564E-02 4.565E-02 4.567E-02 4.569E-02 4.571E-02 4.573E-02 4.575E-02 4.578E-02 4.580E-02 4.583E-02 4.585E-02 4.588E-02 4.590E-02 4.592E-02 4.594E-02 4.595E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.595E-02 4.593E-02 4.590E-02 4.586E-02 4.581E-02 4.575E-02 4.567E-02 4.559E-02 4.548E-02 4.537E-02 4.523E-02 4.508E-02 4.492E-02 4.473E-02 4.452E-02 4.430E-02 4.405E-02 4.378E-02 4.349E-02 4.317E-02 4.283E-02 4.247E-02 4.208E-02 4.167E-02 4.123E-02 4.076E-02 4.027E-02 3.975E-02 3.921E-02 3.864E-02 3.804E-02 3.741E-02 3.676E-02 3.609E-02 3.539E-02 3.466E-02 3.391E-02 3.314E-02 3.235E-02 3.153E-02 3.069E-02 2.984E-02 2.897E-02 2.808E-02 2.717E-02 2.626E-02 2.533E-02 2.439E-02 2.344E-02 2.249E-02 2.153E-02 2.057E-02 1.961E-02 1.865E-02 1.769E-02 1.674E-02 1.580E-02 1.487E-02 1.395E-02 1.305E-02 1.216E-02 1.129E-02 1.044E-02 9.614E-03 8.813E-03 8.037E-03 7.290E-03 6.573E-03 5.887E-03 5.234E-03 4.616E-03 4.033E-03 3.488E-03 2.980E-03 2.511E-03 2.081E-03 1.691E-03 1.342E-03 1.033E-03 7.652E-04 5.381E-04 3.517E-04 2.054E-04 9.874E-05 3.108E-05 1.565E-06 9.190E-06 5.282E-05 1.312E-04 2.428E-04 3.863E-04 5.598E-04 7.617E-04 9.900E-04 1.243E-03 1.518E-03 1.813E-03 2.127E-03 2.456E-03 2.799E-03 3.153E-03 3.516E-03 3.885E-03 4.258E-03 4.261E-03 3.885E-03 3.513E-03 3.147E-03 2.790E-03 2.445E-03 2.113E-03 1.798E-03 1.501E-03 1.225E-03 9.715E-04 7.432E-04 5.419E-04 3.697E-04 2.283E-04 1.195E-04 4.486E-05 5.812E-06 3.699E-06 3.969E-05 1.148E-04 2.299E-04 3.858E-04 5.828E-04 8.215E-04 1.102E-03 1.424E-03 1.789E-03 2.194E-03 2.641E-03 3.128E-03 3.654E-03 4.220E-03 4.823E-03 5.463E-03 6.137E-03 6.846E-03 7.586E-03 8.357E-03 9.157E-03 9.983E-03 1.083E-02 1.171E-02 1.260E-02 1.352E-02 1.445E-02 1.539E-02 1.635E-02 1.731E-02 1.828E-02 1.926E-02 2.024E-02 2.123E-02 2.221E-02 2.318E-02 2.416E-02 2.512E-02 2.608E-02 2.702E-02 2.795E-02 2.887E-02 2.977E-02 3.065E-02 3.151E-02 3.235E-02 3.317E-02 3.397E-02 3.474E-02 3.549E-02 3.622E-02 3.691E-02 3.758E-02 3.822E-02 3.884E-02 3.943E-02 3.999E-02 4.052E-02 4.102E-02 4.149E-02 4.194E-02 4.236E-02 4.275E-02 4.312E-02 4.346E-02 4.377E-02 4.406E-02 4.433E-02 4.457E-02 4.479E-02 4.498E-02 4.516E-02 4.531E-02 4.545E-02 4.557E-02 4.567E-02 4.575E-02 4.582E-02 4.588E-02 4.592E-02 4.595E-02 4.596E-02 4.597E-02 4.597E-02 4.596E-02 4.594E-02 4.591E-02 4.588E-02 4.585E-02 4.581E-02 4.576E-02 4.572E-02 4.567E-02 4.562E-02 4.557E-02 4.552E-02 4.547E-02 4.542E-02 4.538E-02 4.533E-02 4.529E-02 4.526E-02 4.522E-02 4.519E-02 4.517E-02 4.515E-02 4.513E-02 4.512E-02 4.511E-02 4.511E-02 4.511E-02 4.512E-02 4.513E-02 4.515E-02 4.517E-02 4.519E-02 4.522E-02 4.526E-02 4.529E-02 4.533E-02 4.538E-02 4.542E-02 4.547E-02 4.552E-02 4.557E-02 4.562E-02 4.567E-02 4.572E-02 4.576E-02 4.581E-02 4.585E-02 4.588E-02 4.591E-02 4.594E-02 4.596E-02 4.597E-02 4.597E-02 4.596E-02 4.595E-02 4.592E-02 4.588E-02 4.582E-02 4.575E-02 4.567E-02 4.557E-02 4.545E-02 4.531E-02 4.516E-02 4.498E-02 4.479E-02 4.457E-02 4.433E-02 4.406E-02 4.377E-02 4.346E-02 4.312E-02 4.275E-02 4.236E-02 4.194E-02 4.149E-02 4.102E-02 4.052E-02 3.999E-02 3.943E-02 3.884E-02 3.822E-02 3.758E-02 3.691E-02 3.622E-02 3.549E-02 3.474E-02 3.397E-02 3.317E-02 3.235E-02 3.151E-02 3.065E-02 2.977E-02 2.887E-02 2.795E-02 2.702E-02 2.608E-02 2.512E-02 2.416E-02 2.318E-02 2.221E-02 2.123E-02 2.024E-02 1.926E-02 1.828E-02 1.731E-02 1.635E-02 1.539E-02 1.445E-02 1.352E-02 1.260E-02 1.171E-02 1.083E-02 9.983E-03 9.157E-03 8.357E-03 7.586E-03 6.846E-03 6.137E-03 5.463E-03 4.823E-03 4.220E-03 3.654E-03 3.128E-03 2.641E-03 2.194E-03 1.789E-03 1.424E-03 1.102E-03 8.215E-04 5.828E-04 3.858E-04 2.299E-04 1.148E-04 3.969E-05 3.699E-06 5.812E-06 4.486E-05 1.195E-04 2.283E-04 3.697E-04 5.419E-04 7.432E-04 9.715E-04 1.225E-03 1.501E-03 1.798E-03 2.113E-03 2.445E-03 2.790E-03 3.147E-03 3.513E-03 3.885E-03 3.891E-03 3.516E-03 3.147E-03 2.787E-03 2.440E-03 2.106E-03 1.788E-03 1.489E-03 1.212E-03 9.572E-04 7.285E-04 5.275E-04 3.562E-04 2.164E-04 1.099E-04 3.847E-05 3.484E-06 6.341E-06 4.826E-05 1.303E-04 2.533E-04 4.181E-04 6.251E-04 8.748E-04 1.167E-03 1.503E-03 1.881E-03 2.302E-03 2.765E-03 3.269E-03 3.814E-03 4.398E-03 5.021E-03 5.682E-03 6.378E-03 7.108E-03 7.871E-03 8.665E-03 9.488E-03 1.034E-02 1.121E-02 1.211E-02 1.303E-02 1.397E-02 1.492E-02 1.589E-02 1.687E-02 1.786E-02 1.886E-02 1.986E-02 2.086E-02 2.186E-02 2.286E-02 2.386E-02 2.485E-02 2.583E-02 2.680E-02 2.776E-02 2.870E-02 2.963E-02 3.054E-02 3.143E-02 3.229E-02 3.314E-02 3.396E-02 3.476E-02 3.553E-02 3.628E-02 3.700E-02 3.769E-02 3.835E-02 3.899E-02 3.959E-02 4.016E-02 4.071E-02 4.122E-02 4.171E-02 4.216E-02 4.259E-02 4.299E-02 4.336E-02 4.370E-02 4.401E-02 4.430E-02 4.456E-02 4.479E-02 4.500E-02 4.519E-02 4.535E-02 4.550E-02 4.562E-02 4.572E-02 4.580E-02 4.587E-02 4.592E-02 4.595E-02 4.597E-02 4.597E-02 4.596E-02 4.595E-02 4.592E-02 4.588E-02 4.583E-02 4.578E-02 4.572E-02 4.565E-02 4.558E-02 4.551E-02 4.543E-02 4.536E-02 4.528E-02 4.520E-02 4.512E-02 4.504E-02 4.497E-02 4.489E-02 4.483E-02 4.476E-02 4.470E-02 4.464E-02 4.459E-02 4.454E-02 4.450E-02 4.446E-02 4.443E-02 4.441E-02 4.439E-02 4.438E-02 4.438E-02 4.438E-02 4.439E-02 4.441E-02 4.443E-02 4.446E-02 4.450E-02 4.454E-02 4.459E-02 4.464E-02 4.470E-02 4.476E-02 4.483E-02 4.489E-02 4.497E-02 4.504E-02 4.512E-02 4.520E-02 4.528E-02 4.536E-02 4.543E-02 4.551E-02 4.558E-02 4.565E-02 4.572E-02 4.578E-02 4.583E-02 4.588E-02 4.592E-02 4.595E-02 4.596E-02 4.597E-02 4.597E-02 4.595E-02 4.592E-02 4.587E-02 4.580E-02 4.572E-02 4.562E-02 4.550E-02 4.535E-02 4.519E-02 4.500E-02 4.479E-02 4.456E-02 4.430E-02 4.401E-02 4.370E-02 4.336E-02 4.299E-02 4.259E-02 4.216E-02 4.171E-02 4.122E-02 4.071E-02 4.016E-02 3.959E-02 3.899E-02 3.835E-02 3.769E-02 3.700E-02 3.628E-02 3.553E-02 3.476E-02 3.396E-02 3.314E-02 3.229E-02 3.143E-02 3.054E-02 2.963E-02 2.870E-02 2.776E-02 2.680E-02 2.583E-02 2.485E-02 2.386E-02 2.286E-02 2.186E-02 2.086E-02 1.986E-02 1.886E-02 1.786E-02 1.687E-02 1.589E-02 1.492E-02 1.397E-02 1.303E-02 1.211E-02 1.121E-02 1.034E-02 9.488E-03 8.665E-03 7.871E-03 7.108E-03 6.378E-03 5.682E-03 5.021E-03 4.398E-03 3.814E-03 3.269E-03 2.765E-03 2.302E-03 1.881E-03 1.503E-03 1.167E-03 8.748E-04 6.251E-04 4.181E-04 2.533E-04 1.303E-04 4.826E-05 6.341E-06 3.484E-06 3.847E-05 1.099E-04 2.164E-04 3.562E-04 5.275E-04 7.285E-04 9.572E-04 1.212E-03 1.489E-03 1.788E-03 2.106E-03 2.440E-03 2.787E-03 3.147E-03 3.516E-03 3.524E-03 3.153E-03 2.790E-03 2.440E-03 2.103E-03 1.783E-03 1.482E-03 1.203E-03 9.471E-04 7.176E-04 5.164E-04 3.455E-04 2.068E-04 1.022E-04 3.344E-05 1.956E-06 9.211E-06 5.645E-05 1.448E-04 2.751E-04 4.481E-04 6.645E-04 9.246E-04 1.229E-03 1.577E-03 1.969E-03 2.404E-03 2.882E-03 3.403E-03 3.965E-03 4.568E-03 5.210E-03 5.891E-03 6.608E-03 7.359E-03 8.145E-03 8.961E-03 9.807E-03 1.068E-02 1.158E-02 1.250E-02 1.344E-02 1.441E-02 1.538E-02 1.638E-02 1.738E-02 1.839E-02 1.941E-02 2.043E-02 2.145E-02 2.247E-02 2.349E-02 2.451E-02 2.551E-02 2.651E-02 2.750E-02 2.847E-02 2.942E-02 3.036E-02 3.127E-02 3.217E-02 3.304E-02 3.389E-02 3.472E-02 3.552E-02 3.629E-02 3.703E-02 3.774E-02 3.843E-02 3.908E-02 3.970E-02 4.029E-02 4.085E-02 4.138E-02 4.187E-02 4.234E-02 4.277E-02 4.318E-02 4.355E-02 4.389E-02 4.420E-02 4.449E-02 4.474E-02 4.497E-02 4.518E-02 4.535E-02 4.551E-02 4.563E-02 4.574E-02 4.583E-02 4.589E-02 4.593E-02 4.596E-02 4.597E-02 4.597E-02 4.594E-02 4.591E-02 4.586E-02 4.581E-02 4.574E-02 4.566E-02 4.558E-02 4.548E-02 4.539E-02 4.528E-02 4.518E-02 4.507E-02 4.496E-02 4.485E-02 4.473E-02 4.462E-02 4.451E-02 4.440E-02 4.430E-02 4.420E-02 4.410E-02 4.401E-02 4.392E-02 4.384E-02 4.377E-02 4.370E-02 4.364E-02 4.359E-02 4.354E-02 4.350E-02 4.347E-02 4.345E-02 4.344E-02 4.343E-02 4.344E-02 4.345E-02 4.347E-02 4.350E-02 4.354E-02 4.359E-02 4.364E-02 4.370E-02 4.377E-02 4.384E-02 4.392E-02 4.401E-02 4.410E-02 4.420E-02 4.430E-02 4.440E-02 4.451E-02 4.462E-02 4.473E-02 4.485E-02 4.496E-02 4.507E-02 4.518E-02 4.528E-02 4.539E-02 4.548E-02 4.558E-02 4.566E-02 4.574E-02 4.581E-02 4.586E-02 4.591E-02 4.594E-02 4.597E-02 4.597E-02 4.596E-02 4.593E-02 4.589E-02 4.583E-02 4.574E-02 4.563E-02 4.551E-02 4.535E-02 4.518E-02 4.497E-02 4.474E-02 4.449E-02 4.420E-02 4.389E-02 4.355E-02 4.318E-02 4.277E-02 4.234E-02 4.187E-02 4.138E-02 4.085E-02 4.029E-02 3.970E-02 3.908E-02 3.843E-02 3.774E-02 3.703E-02 3.629E-02 3.552E-02 3.472E-02 3.389E-02 3.304E-02 3.217E-02 3.127E-02 3.036E-02 2.942E-02 2.847E-02 2.750E-02 2.651E-02 2.551E-02 2.451E-02 2.349E-02 2.247E-02 2.145E-02 2.043E-02 1.941E-02 1.839E-02 1.738E-02 1.638E-02 1.538E-02 1.441E-02 1.344E-02 1.250E-02 1.158E-02 1.068E-02 9.807E-03 8.961E-03 8.145E-03 7.359E-03 6.608E-03 5.891E-03 5.210E-03 4.568E-03 3.965E-03 3.403E-03 2.882E-03 2.404E-03 1.969E-03 1.577E-03 1.229E-03 9.246E-04 6.645E-04 4.481E-04 2.751E-04 1.448E-04 5.645E-05 9.211E-06 1.956E-06 3.344E-05 1.022E-04 2.068E-04 3.455E-04 5.164E-04 7.176E-04 9.471E-04 1.203E-03 1.482E-03 1.783E-03 2.103E-03 2.440E-03 2.790E-03 3.153E-03 3.164E-03 2.799E-03 2.445E-03 2.106E-03 1.783E-03 1.480E-03 1.198E-03 9.410E-04 7.104E-04 5.085E-04 3.376E-04 1.995E-04 9.628E-05 2.957E-05 1.016E-06 1.206E-05 6.401E-05 1.580E-04 2.949E-04 4.756E-04 7.007E-04 9.705E-04 1.285E-03 1.645E-03 2.050E-03 2.499E-03 2.992E-03 3.529E-03 4.108E-03 4.729E-03 5.389E-03 6.089E-03 6.826E-03 7.599E-03 8.405E-03 9.244E-03 1.011E-02 1.101E-02 1.193E-02 1.288E-02 1.384E-02 1.483E-02 1.583E-02 1.684E-02 1.787E-02 1.890E-02 1.994E-02 2.098E-02 2.202E-02 2.307E-02 2.410E-02 2.513E-02 2.616E-02 2.717E-02 2.816E-02 2.915E-02 3.011E-02 3.106E-02 3.198E-02 3.288E-02 3.376E-02 3.461E-02 3.544E-02 3.623E-02 3.700E-02 3.774E-02 3.844E-02 3.912E-02 3.976E-02 4.037E-02 4.094E-02 4.148E-02 4.199E-02 4.247E-02 4.291E-02 4.332E-02 4.370E-02 4.405E-02 4.436E-02 4.464E-02 4.490E-02 4.512E-02 4.531E-02 4.548E-02 4.562E-02 4.574E-02 4.583E-02 4.590E-02 4.594E-02 4.597E-02 4.597E-02 4.596E-02 4.593E-02 4.588E-02 4.582E-02 4.574E-02 4.565E-02 4.555E-02 4.544E-02 4.532E-02 4.520E-02 4.506E-02 4.492E-02 4.478E-02 4.464E-02 4.449E-02 4.434E-02 4.419E-02 4.404E-02 4.390E-02 4.375E-02 4.361E-02 4.347E-02 4.334E-02 4.321E-02 4.309E-02 4.298E-02 4.287E-02 4.277E-02 4.268E-02 4.260E-02 4.252E-02 4.246E-02 4.240E-02 4.236E-02 4.232E-02 4.230E-02 4.228E-02 4.227E-02 4.228E-02 4.230E-02 4.232E-02 4.236E-02 4.240E-02 4.246E-02 4.252E-02 4.260E-02 4.268E-02 4.277E-02 4.287E-02 4.298E-02 4.309E-02 4.321E-02 4.334E-02 4.347E-02 4.361E-02 4.375E-02 4.390E-02 4.404E-02 4.419E-02 4.434E-02 4.449E-02 4.464E-02 4.478E-02 4.492E-02 4.506E-02 4.520E-02 4.532E-02 4.544E-02 4.555E-02 4.565E-02 4.574E-02 4.582E-02 4.588E-02 4.593E-02 4.596E-02 4.597E-02 4.597E-02 4.594E-02 4.590E-02 4.583E-02 4.574E-02 4.562E-02 4.548E-02 4.531E-02 4.512E-02 4.490E-02 4.464E-02 4.436E-02 4.405E-02 4.370E-02 4.332E-02 4.291E-02 4.247E-02 4.199E-02 4.148E-02 4.094E-02 4.037E-02 3.976E-02 3.912E-02 3.844E-02 3.774E-02 3.700E-02 3.623E-02 3.544E-02 3.461E-02 3.376E-02 3.288E-02 3.198E-02 3.106E-02 3.011E-02 2.915E-02 2.816E-02 2.717E-02 2.616E-02 2.513E-02 2.410E-02 2.307E-02 2.202E-02 2.098E-02 1.994E-02 1.890E-02 1.787E-02 1.684E-02 1.583E-02 1.483E-02 1.384E-02 1.288E-02 1.193E-02 1.101E-02 1.011E-02 9.244E-03 8.405E-03 7.599E-03 6.826E-03 6.089E-03 5.389E-03 4.729E-03 4.108E-03 3.529E-03 2.992E-03 2.499E-03 2.050E-03 1.645E-03 1.285E-03 9.705E-04 7.007E-04 4.756E-04 2.949E-04 1.580E-04 6.401E-05 1.206E-05 1.016E-06 2.957E-05 9.628E-05 1.995E-04 3.376E-04 5.085E-04 7.104E-04 9.410E-04 1.198E-03 1.480E-03 1.783E-03 2.106E-03 2.445E-03 2.799E-03 2.813E-03 2.456E-03 2.113E-03 1.788E-03 1.482E-03 1.198E-03 9.390E-04 7.068E-04 5.038E-04 3.324E-04 1.944E-04 9.192E-05 2.673E-05 4.832E-07 1.469E-05 7.067E-05 1.696E-04 3.125E-04 5.001E-04 7.331E-04 1.012E-03 1.337E-03 1.708E-03 2.124E-03 2.587E-03 3.094E-03 3.646E-03 4.241E-03 4.879E-03 5.557E-03 6.276E-03 7.032E-03 7.825E-03 8.652E-03 9.512E-03 1.040E-02 1.132E-02 1.226E-02 1.323E-02 1.422E-02 1.523E-02 1.625E-02 1.729E-02 1.833E-02 1.939E-02 2.045E-02 2.151E-02 2.257E-02 2.363E-02 2.469E-02 2.573E-02 2.677E-02 2.780E-02 2.881E-02 2.980E-02 3.077E-02 3.173E-02 3.266E-02 3.356E-02 3.444E-02 3.530E-02 3.612E-02 3.691E-02 3.767E-02 3.840E-02 3.910E-02 3.976E-02 4.039E-02 4.099E-02 4.154E-02 4.207E-02 4.256E-02 4.301E-02 4.343E-02 4.381E-02 4.416E-02 4.448E-02 4.476E-02 4.501E-02 4.523E-02 4.542E-02 4.558E-02 4.571E-02 4.581E-02 4.589E-02 4.594E-02 4.597E-02 4.597E-02 4.595E-02 4.591E-02 4.586E-02 4.578E-02 4.569E-02 4.558E-02 4.546E-02 4.533E-02 4.518E-02 4.503E-02 4.487E-02 4.470E-02 4.452E-02 4.434E-02 4.416E-02 4.397E-02 4.378E-02 4.359E-02 4.340E-02 4.321E-02 4.303E-02 4.285E-02 4.267E-02 4.250E-02 4.233E-02 4.217E-02 4.202E-02 4.187E-02 4.174E-02 4.161E-02 4.149E-02 4.138E-02 4.128E-02 4.120E-02 4.112E-02 4.106E-02 4.100E-02 4.096E-02 4.093E-02 4.091E-02 4.091E-02 4.091E-02 4.093E-02 4.096E-02 4.100E-02 4.106E-02 4.112E-02 4.120E-02 4.128E-02 4.138E-02 4.149E-02 4.161E-02 4.174E-02 4.187E-02 4.202E-02 4.217E-02 4.233E-02 4.250E-02 4.267E-02 4.285E-02 4.303E-02 4.321E-02 4.340E-02 4.359E-02 4.378E-02 4.397E-02 4.416E-02 4.434E-02 4.452E-02 4.470E-02 4.487E-02 4.503E-02 4.518E-02 4.533E-02 4.546E-02 4.558E-02 4.569E-02 4.578E-02 4.586E-02 4.591E-02 4.595E-02 4.597E-02 4.597E-02 4.594E-02 4.589E-02 4.581E-02 4.571E-02 4.558E-02 4.542E-02 4.523E-02 4.501E-02 4.476E-02 4.448E-02 4.416E-02 4.381E-02 4.343E-02 4.301E-02 4.256E-02 4.207E-02 4.154E-02 4.099E-02 4.039E-02 3.976E-02 3.910E-02 3.840E-02 3.767E-02 3.691E-02 3.612E-02 3.530E-02 3.444E-02 3.356E-02 3.266E-02 3.173E-02 3.077E-02 2.980E-02 2.881E-02 2.780E-02 2.677E-02 2.573E-02 2.469E-02 2.363E-02 2.257E-02 2.151E-02 2.045E-02 1.939E-02 1.833E-02 1.729E-02 1.625E-02 1.523E-02 1.422E-02 1.323E-02 1.226E-02 1.132E-02 1.040E-02 9.512E-03 8.652E-03 7.825E-03 7.032E-03 6.276E-03 5.557E-03 4.879E-03 4.241E-03 3.646E-03 3.094E-03 2.587E-03 2.124E-03 1.708E-03 1.337E-03 1.012E-03 7.331E-04 5.001E-04 3.125E-04 1.696E-04 7.067E-05 1.469E-05 4.832E-07 2.673E-05 9.192E-05 1.944E-04 3.324E-04 5.038E-04 7.068E-04 9.390E-04 1.198E-03 1.482E-03 1.788E-03 2.113E-03 2.456E-03 2.473E-03 2.127E-03 1.798E-03 1.489E-03 1.203E-03 9.410E-04 7.068E-04 5.023E-04 3.298E-04 1.913E-04 8.907E-05 2.478E-05 2.117E-07 1.691E-05 7.626E-05 1.795E-04 3.276E-04 5.214E-04 7.616E-04 1.049E-03 1.383E-03 1.764E-03 2.192E-03 2.667E-03 3.188E-03 3.754E-03 4.364E-03 5.018E-03 5.714E-03 6.450E-03 7.225E-03 8.037E-03 8.884E-03 9.765E-03 1.068E-02 1.162E-02 1.258E-02 1.357E-02 1.458E-02 1.561E-02 1.666E-02 1.771E-02 1.878E-02 1.986E-02 2.094E-02 2.202E-02 2.310E-02 2.418E-02 2.525E-02 2.631E-02 2.736E-02 2.840E-02 2.942E-02 3.042E-02 3.141E-02 3.237E-02 3.330E-02 3.421E-02 3.509E-02 3.594E-02 3.676E-02 3.755E-02 3.831E-02 3.903E-02 3.972E-02 4.037E-02 4.098E-02 4.156E-02 4.210E-02 4.260E-02 4.307E-02 4.350E-02 4.389E-02 4.425E-02 4.457E-02 4.485E-02 4.510E-02 4.532E-02 4.550E-02 4.566E-02 4.578E-02 4.587E-02 4.593E-02 4.596E-02 4.597E-02 4.595E-02 4.591E-02 4.585E-02 4.577E-02 4.566E-02 4.554E-02 4.540E-02 4.525E-02 4.508E-02 4.490E-02 4.471E-02 4.451E-02 4.430E-02 4.409E-02 4.386E-02 4.364E-02 4.341E-02 4.318E-02 4.295E-02 4.271E-02 4.248E-02 4.225E-02 4.203E-02 4.181E-02 4.159E-02 4.138E-02 4.118E-02 4.098E-02 4.080E-02 4.062E-02 4.045E-02 4.029E-02 4.015E-02 4.001E-02 3.988E-02 3.977E-02 3.967E-02 3.958E-02 3.951E-02 3.945E-02 3.940E-02 3.937E-02 3.935E-02 3.934E-02 3.935E-02 3.937E-02 3.940E-02 3.945E-02 3.951E-02 3.958E-02 3.967E-02 3.977E-02 3.988E-02 4.001E-02 4.015E-02 4.029E-02 4.045E-02 4.062E-02 4.080E-02 4.098E-02 4.118E-02 4.138E-02 4.159E-02 4.181E-02 4.203E-02 4.225E-02 4.248E-02 4.271E-02 4.295E-02 4.318E-02 4.341E-02 4.364E-02 4.386E-02 4.409E-02 4.430E-02 4.451E-02 4.471E-02 4.490E-02 4.508E-02 4.525E-02 4.540E-02 4.554E-02 4.566E-02 4.577E-02 4.585E-02 4.591E-02 4.595E-02 4.597E-02 4.596E-02 4.593E-02 4.587E-02 4.578E-02 4.566E-02 4.550E-02 4.532E-02 4.510E-02 4.485E-02 4.457E-02 4.425E-02 4.389E-02 4.350E-02 4.307E-02 4.260E-02 4.210E-02 4.156E-02 4.098E-02 4.037E-02 3.972E-02 3.903E-02 3.831E-02 3.755E-02 3.676E-02 3.594E-02 3.509E-02 3.421E-02 3.330E-02 3.237E-02 3.141E-02 3.042E-02 2.942E-02 2.840E-02 2.736E-02 2.631E-02 2.525E-02 2.418E-02 2.310E-02 2.202E-02 2.094E-02 1.986E-02 1.878E-02 1.771E-02 1.666E-02 1.561E-02 1.458E-02 1.357E-02 1.258E-02 1.162E-02 1.068E-02 9.765E-03 8.884E-03 8.037E-03 7.225E-03 6.450E-03 5.714E-03 5.018E-03 4.364E-03 3.754E-03 3.188E-03 2.667E-03 2.192E-03 1.764E-03 1.383E-03 1.049E-03 7.616E-04 5.214E-04 3.276E-04 1.795E-04 7.626E-05 1.691E-05 2.117E-07 2.478E-05 8.907E-05 1.913E-04 3.298E-04 5.023E-04 7.068E-04 9.410E-04 1.203E-03 1.489E-03 1.798E-03 2.127E-03 2.145E-03 1.813E-03 1.501E-03 1.212E-03 9.471E-04 7.104E-04 5.038E-04 3.298E-04 1.903E-04 8.765E-05 2.365E-05 9.200E-08 1.859E-05 8.059E-05 1.873E-04 3.399E-04 5.391E-04 7.858E-04 1.080E-03 1.423E-03 1.813E-03 2.252E-03 2.738E-03 3.272E-03 3.852E-03 4.477E-03 5.146E-03 5.858E-03 6.611E-03 7.404E-03 8.235E-03 9.102E-03 1.000E-02 1.093E-02 1.189E-02 1.288E-02 1.389E-02 1.492E-02 1.597E-02 1.704E-02 1.812E-02 1.921E-02 2.030E-02 2.140E-02 2.250E-02 2.360E-02 2.469E-02 2.578E-02 2.686E-02 2.792E-02 2.897E-02 3.001E-02 3.102E-02 3.201E-02 3.297E-02 3.391E-02 3.482E-02 3.571E-02 3.656E-02 3.737E-02 3.816E-02 3.890E-02 3.962E-02 4.029E-02 4.093E-02 4.153E-02 4.209E-02 4.261E-02 4.309E-02 4.353E-02 4.393E-02 4.430E-02 4.463E-02 4.492E-02 4.517E-02 4.538E-02 4.556E-02 4.571E-02 4.582E-02 4.590E-02 4.595E-02 4.597E-02 4.596E-02 4.593E-02 4.586E-02 4.578E-02 4.567E-02 4.554E-02 4.538E-02 4.521E-02 4.503E-02 4.483E-02 4.461E-02 4.438E-02 4.414E-02 4.389E-02 4.363E-02 4.337E-02 4.310E-02 4.283E-02 4.255E-02 4.227E-02 4.200E-02 4.172E-02 4.145E-02 4.117E-02 4.091E-02 4.064E-02 4.039E-02 4.014E-02 3.990E-02 3.967E-02 3.944E-02 3.923E-02 3.903E-02 3.884E-02 3.866E-02 3.849E-02 3.834E-02 3.820E-02 3.807E-02 3.796E-02 3.786E-02 3.778E-02 3.771E-02 3.765E-02 3.762E-02 3.759E-02 3.758E-02 3.759E-02 3.762E-02 3.765E-02 3.771E-02 3.778E-02 3.786E-02 3.796E-02 3.807E-02 3.820E-02 3.834E-02 3.849E-02 3.866E-02 3.884E-02 3.903E-02 3.923E-02 3.944E-02 3.967E-02 3.990E-02 4.014E-02 4.039E-02 4.064E-02 4.091E-02 4.117E-02 4.145E-02 4.172E-02 4.200E-02 4.227E-02 4.255E-02 4.283E-02 4.310E-02 4.337E-02 4.363E-02 4.389E-02 4.414E-02 4.438E-02 4.461E-02 4.483E-02 4.503E-02 4.521E-02 4.538E-02 4.554E-02 4.567E-02 4.578E-02 4.586E-02 4.593E-02 4.596E-02 4.597E-02 4.595E-02 4.590E-02 4.582E-02 4.571E-02 4.556E-02 4.538E-02 4.517E-02 4.492E-02 4.463E-02 4.430E-02 4.393E-02 4.353E-02 4.309E-02 4.261E-02 4.209E-02 4.153E-02 4.093E-02 4.029E-02 3.962E-02 3.890E-02 3.816E-02 3.737E-02 3.656E-02 3.571E-02 3.482E-02 3.391E-02 3.297E-02 3.201E-02 3.102E-02 3.001E-02 2.897E-02 2.792E-02 2.686E-02 2.578E-02 2.469E-02 2.360E-02 2.250E-02 2.140E-02 2.030E-02 1.921E-02 1.812E-02 1.704E-02 1.597E-02 1.492E-02 1.389E-02 1.288E-02 1.189E-02 1.093E-02 1.000E-02 9.102E-03 8.235E-03 7.404E-03 6.611E-03 5.858E-03 5.146E-03 4.477E-03 3.852E-03 3.272E-03 2.738E-03 2.252E-03 1.813E-03 1.423E-03 1.080E-03 7.858E-04 5.391E-04 3.399E-04 1.873E-04 8.059E-05 1.859E-05 9.200E-08 2.365E-05 8.765E-05 1.903E-04 3.298E-04 5.038E-04 7.104E-04 9.471E-04 1.212E-03 1.501E-03 1.813E-03 1.834E-03 1.518E-03 1.225E-03 9.572E-04 7.176E-04 5.085E-04 3.324E-04 1.913E-04 8.765E-05 2.328E-05 5.057E-08 1.964E-05 8.354E-05 1.931E-04 3.493E-04 5.532E-04 8.054E-04 1.106E-03 1.457E-03 1.856E-03 2.304E-03 2.801E-03 3.347E-03 3.939E-03 4.578E-03 5.262E-03 5.989E-03 6.759E-03 7.569E-03 8.418E-03 9.303E-03 1.022E-02 1.117E-02 1.215E-02 1.316E-02 1.419E-02 1.525E-02 1.632E-02 1.740E-02 1.850E-02 1.961E-02 2.072E-02 2.184E-02 2.296E-02 2.408E-02 2.519E-02 2.629E-02 2.738E-02 2.846E-02 2.952E-02 3.056E-02 3.158E-02 3.258E-02 3.355E-02 3.449E-02 3.541E-02 3.629E-02 3.713E-02 3.795E-02 3.872E-02 3.946E-02 4.016E-02 4.083E-02 4.145E-02 4.203E-02 4.257E-02 4.307E-02 4.353E-02 4.394E-02 4.432E-02 4.466E-02 4.495E-02 4.521E-02 4.543E-02 4.561E-02 4.575E-02 4.585E-02 4.593E-02 4.596E-02 4.597E-02 4.594E-02 4.589E-02 4.581E-02 4.570E-02 4.556E-02 4.540E-02 4.522E-02 4.502E-02 4.480E-02 4.457E-02 4.431E-02 4.405E-02 4.377E-02 4.348E-02 4.318E-02 4.287E-02 4.256E-02 4.224E-02 4.192E-02 4.159E-02 4.127E-02 4.094E-02 4.062E-02 4.030E-02 3.998E-02 3.967E-02 3.937E-02 3.907E-02 3.878E-02 3.850E-02 3.823E-02 3.796E-02 3.772E-02 3.748E-02 3.725E-02 3.704E-02 3.684E-02 3.666E-02 3.649E-02 3.633E-02 3.619E-02 3.607E-02 3.596E-02 3.587E-02 3.579E-02 3.573E-02 3.569E-02 3.567E-02 3.566E-02 3.567E-02 3.569E-02 3.573E-02 3.579E-02 3.587E-02 3.596E-02 3.607E-02 3.619E-02 3.633E-02 3.649E-02 3.666E-02 3.684E-02 3.704E-02 3.725E-02 3.748E-02 3.772E-02 3.796E-02 3.823E-02 3.850E-02 3.878E-02 3.907E-02 3.937E-02 3.967E-02 3.998E-02 4.030E-02 4.062E-02 4.094E-02 4.127E-02 4.159E-02 4.192E-02 4.224E-02 4.256E-02 4.287E-02 4.318E-02 4.348E-02 4.377E-02 4.405E-02 4.431E-02 4.457E-02 4.480E-02 4.502E-02 4.522E-02 4.540E-02 4.556E-02 4.570E-02 4.581E-02 4.589E-02 4.594E-02 4.597E-02 4.596E-02 4.593E-02 4.585E-02 4.575E-02 4.561E-02 4.543E-02 4.521E-02 4.495E-02 4.466E-02 4.432E-02 4.394E-02 4.353E-02 4.307E-02 4.257E-02 4.203E-02 4.145E-02 4.083E-02 4.016E-02 3.946E-02 3.872E-02 3.795E-02 3.713E-02 3.629E-02 3.541E-02 3.449E-02 3.355E-02 3.258E-02 3.158E-02 3.056E-02 2.952E-02 2.846E-02 2.738E-02 2.629E-02 2.519E-02 2.408E-02 2.296E-02 2.184E-02 2.072E-02 1.961E-02 1.850E-02 1.740E-02 1.632E-02 1.525E-02 1.419E-02 1.316E-02 1.215E-02 1.117E-02 1.022E-02 9.303E-03 8.418E-03 7.569E-03 6.759E-03 5.989E-03 5.262E-03 4.578E-03 3.939E-03 3.347E-03 2.801E-03 2.304E-03 1.856E-03 1.457E-03 1.106E-03 8.054E-04 5.532E-04 3.493E-04 1.931E-04 8.354E-05 1.964E-05 5.057E-08 2.328E-05 8.765E-05 1.913E-04 3.324E-04 5.085E-04 7.176E-04 9.572E-04 1.225E-03 1.518E-03 1.540E-03 1.243E-03 9.715E-04 7.285E-04 5.164E-04 3.376E-04 1.944E-04 8.907E-05 2.365E-05 5.057E-08 2.000E-05 8.504E-05 1.965E-04 3.556E-04 5.633E-04 8.203E-04 1.127E-03 1.484E-03 1.891E-03 2.348E-03 2.855E-03 3.411E-03 4.016E-03 4.667E-03 5.365E-03 6.108E-03 6.893E-03 7.720E-03 8.586E-03 9.488E-03 1.043E-02 1.140E-02 1.240E-02 1.342E-02 1.447E-02 1.555E-02 1.664E-02 1.774E-02 1.886E-02 1.999E-02 2.112E-02 2.226E-02 2.340E-02 2.453E-02 2.565E-02 2.677E-02 2.788E-02 2.897E-02 3.004E-02 3.109E-02 3.212E-02 3.312E-02 3.410E-02 3.504E-02 3.596E-02 3.684E-02 3.768E-02 3.849E-02 3.926E-02 3.999E-02 4.067E-02 4.132E-02 4.193E-02 4.249E-02 4.301E-02 4.349E-02 4.392E-02 4.431E-02 4.466E-02 4.496E-02 4.523E-02 4.545E-02 4.563E-02 4.577E-02 4.587E-02 4.594E-02 4.597E-02 4.596E-02 4.592E-02 4.585E-02 4.575E-02 4.562E-02 4.546E-02 4.528E-02 4.507E-02 4.484E-02 4.458E-02 4.431E-02 4.402E-02 4.372E-02 4.340E-02 4.307E-02 4.273E-02 4.238E-02 4.202E-02 4.165E-02 4.128E-02 4.091E-02 4.054E-02 4.016E-02 3.979E-02 3.942E-02 3.905E-02 3.869E-02 3.834E-02 3.799E-02 3.765E-02 3.731E-02 3.699E-02 3.668E-02 3.638E-02 3.609E-02 3.582E-02 3.556E-02 3.531E-02 3.508E-02 3.486E-02 3.466E-02 3.447E-02 3.430E-02 3.415E-02 3.402E-02 3.390E-02 3.380E-02 3.372E-02 3.365E-02 3.361E-02 3.358E-02 3.357E-02 3.358E-02 3.361E-02 3.365E-02 3.372E-02 3.380E-02 3.390E-02 3.402E-02 3.415E-02 3.430E-02 3.447E-02 3.466E-02 3.486E-02 3.508E-02 3.531E-02 3.556E-02 3.582E-02 3.609E-02 3.638E-02 3.668E-02 3.699E-02 3.731E-02 3.765E-02 3.799E-02 3.834E-02 3.869E-02 3.905E-02 3.942E-02 3.979E-02 4.016E-02 4.054E-02 4.091E-02 4.128E-02 4.165E-02 4.202E-02 4.238E-02 4.273E-02 4.307E-02 4.340E-02 4.372E-02 4.402E-02 4.431E-02 4.458E-02 4.484E-02 4.507E-02 4.528E-02 4.546E-02 4.562E-02 4.575E-02 4.585E-02 4.592E-02 4.596E-02 4.597E-02 4.594E-02 4.587E-02 4.577E-02 4.563E-02 4.545E-02 4.523E-02 4.496E-02 4.466E-02 4.431E-02 4.392E-02 4.349E-02 4.301E-02 4.249E-02 4.193E-02 4.132E-02 4.067E-02 3.999E-02 3.926E-02 3.849E-02 3.768E-02 3.684E-02 3.596E-02 3.504E-02 3.410E-02 3.312E-02 3.212E-02 3.109E-02 3.004E-02 2.897E-02 2.788E-02 2.677E-02 2.565E-02 2.453E-02 2.340E-02 2.226E-02 2.112E-02 1.999E-02 1.886E-02 1.774E-02 1.664E-02 1.555E-02 1.447E-02 1.342E-02 1.240E-02 1.140E-02 1.043E-02 9.488E-03 8.586E-03 7.720E-03 6.893E-03 6.108E-03 5.365E-03 4.667E-03 4.016E-03 3.411E-03 2.855E-03 2.348E-03 1.891E-03 1.484E-03 1.127E-03 8.203E-04 5.633E-04 3.556E-04 1.965E-04 8.504E-05 2.000E-05 5.057E-08 2.365E-05 8.907E-05 1.944E-04 3.376E-04 5.164E-04 7.285E-04 9.715E-04 1.243E-03 1.265E-03 9.900E-04 7.432E-04 5.275E-04 3.455E-04 1.995E-04 9.192E-05 2.478E-05 9.200E-08 1.964E-05 8.504E-05 1.977E-04 3.588E-04 5.694E-04 8.303E-04 1.142E-03 1.505E-03 1.919E-03 2.384E-03 2.900E-03 3.466E-03 4.081E-03 4.745E-03 5.456E-03 6.212E-03 7.012E-03 7.854E-03 8.737E-03 9.657E-03 1.061E-02 1.160E-02 1.262E-02 1.366E-02 1.473E-02 1.583E-02 1.694E-02 1.806E-02 1.920E-02 2.035E-02 2.150E-02 2.265E-02 2.381E-02 2.495E-02 2.610E-02 2.723E-02 2.835E-02 2.945E-02 3.053E-02 3.159E-02 3.262E-02 3.363E-02 3.461E-02 3.556E-02 3.647E-02 3.735E-02 3.819E-02 3.899E-02 3.975E-02 4.047E-02 4.115E-02 4.178E-02 4.237E-02 4.291E-02 4.341E-02 4.386E-02 4.427E-02 4.463E-02 4.495E-02 4.523E-02 4.545E-02 4.564E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.596E-02 4.591E-02 4.582E-02 4.570E-02 4.555E-02 4.537E-02 4.516E-02 4.492E-02 4.466E-02 4.438E-02 4.408E-02 4.375E-02 4.341E-02 4.305E-02 4.268E-02 4.230E-02 4.190E-02 4.150E-02 4.109E-02 4.067E-02 4.025E-02 3.983E-02 3.940E-02 3.898E-02 3.856E-02 3.814E-02 3.772E-02 3.731E-02 3.691E-02 3.652E-02 3.613E-02 3.576E-02 3.539E-02 3.504E-02 3.470E-02 3.437E-02 3.406E-02 3.376E-02 3.348E-02 3.321E-02 3.296E-02 3.273E-02 3.251E-02 3.231E-02 3.213E-02 3.197E-02 3.183E-02 3.170E-02 3.159E-02 3.151E-02 3.144E-02 3.139E-02 3.136E-02 3.135E-02 3.136E-02 3.139E-02 3.144E-02 3.151E-02 3.159E-02 3.170E-02 3.183E-02 3.197E-02 3.213E-02 3.231E-02 3.251E-02 3.273E-02 3.296E-02 3.321E-02 3.348E-02 3.376E-02 3.406E-02 3.437E-02 3.470E-02 3.504E-02 3.539E-02 3.576E-02 3.613E-02 3.652E-02 3.691E-02 3.731E-02 3.772E-02 3.814E-02 3.856E-02 3.898E-02 3.940E-02 3.983E-02 4.025E-02 4.067E-02 4.109E-02 4.150E-02 4.190E-02 4.230E-02 4.268E-02 4.305E-02 4.341E-02 4.375E-02 4.408E-02 4.438E-02 4.466E-02 4.492E-02 4.516E-02 4.537E-02 4.555E-02 4.570E-02 4.582E-02 4.591E-02 4.596E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.564E-02 4.545E-02 4.523E-02 4.495E-02 4.463E-02 4.427E-02 4.386E-02 4.341E-02 4.291E-02 4.237E-02 4.178E-02 4.115E-02 4.047E-02 3.975E-02 3.899E-02 3.819E-02 3.735E-02 3.647E-02 3.556E-02 3.461E-02 3.363E-02 3.262E-02 3.159E-02 3.053E-02 2.945E-02 2.835E-02 2.723E-02 2.610E-02 2.495E-02 2.381E-02 2.265E-02 2.150E-02 2.035E-02 1.920E-02 1.806E-02 1.694E-02 1.583E-02 1.473E-02 1.366E-02 1.262E-02 1.160E-02 1.061E-02 9.657E-03 8.737E-03 7.854E-03 7.012E-03 6.212E-03 5.456E-03 4.745E-03 4.081E-03 3.466E-03 2.900E-03 2.384E-03 1.919E-03 1.505E-03 1.142E-03 8.303E-04 5.694E-04 3.588E-04 1.977E-04 8.504E-05 1.964E-05 9.200E-08 2.478E-05 9.192E-05 1.995E-04 3.455E-04 5.275E-04 7.432E-04 9.900E-04 1.013E-03 7.617E-04 5.419E-04 3.562E-04 2.068E-04 9.628E-05 2.673E-05 2.117E-07 1.859E-05 8.354E-05 1.965E-04 3.588E-04 5.715E-04 8.353E-04 1.151E-03 1.519E-03 1.939E-03 2.411E-03 2.935E-03 3.510E-03 4.135E-03 4.810E-03 5.533E-03 6.302E-03 7.116E-03 7.973E-03 8.871E-03 9.807E-03 1.078E-02 1.179E-02 1.282E-02 1.389E-02 1.497E-02 1.609E-02 1.721E-02 1.836E-02 1.951E-02 2.068E-02 2.185E-02 2.302E-02 2.419E-02 2.535E-02 2.651E-02 2.766E-02 2.879E-02 2.990E-02 3.099E-02 3.206E-02 3.310E-02 3.412E-02 3.510E-02 3.605E-02 3.696E-02 3.783E-02 3.867E-02 3.946E-02 4.022E-02 4.092E-02 4.159E-02 4.220E-02 4.277E-02 4.330E-02 4.377E-02 4.420E-02 4.458E-02 4.492E-02 4.520E-02 4.544E-02 4.564E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.579E-02 4.566E-02 4.549E-02 4.529E-02 4.506E-02 4.480E-02 4.451E-02 4.420E-02 4.386E-02 4.350E-02 4.312E-02 4.273E-02 4.232E-02 4.189E-02 4.145E-02 4.100E-02 4.054E-02 4.008E-02 3.961E-02 3.914E-02 3.866E-02 3.819E-02 3.772E-02 3.724E-02 3.678E-02 3.631E-02 3.586E-02 3.541E-02 3.497E-02 3.454E-02 3.413E-02 3.372E-02 3.333E-02 3.295E-02 3.258E-02 3.223E-02 3.189E-02 3.157E-02 3.127E-02 3.099E-02 3.072E-02 3.047E-02 3.024E-02 3.003E-02 2.984E-02 2.967E-02 2.951E-02 2.938E-02 2.927E-02 2.918E-02 2.910E-02 2.905E-02 2.902E-02 2.901E-02 2.902E-02 2.905E-02 2.910E-02 2.918E-02 2.927E-02 2.938E-02 2.951E-02 2.967E-02 2.984E-02 3.003E-02 3.024E-02 3.047E-02 3.072E-02 3.099E-02 3.127E-02 3.157E-02 3.189E-02 3.223E-02 3.258E-02 3.295E-02 3.333E-02 3.372E-02 3.413E-02 3.454E-02 3.497E-02 3.541E-02 3.586E-02 3.631E-02 3.678E-02 3.724E-02 3.772E-02 3.819E-02 3.866E-02 3.914E-02 3.961E-02 4.008E-02 4.054E-02 4.100E-02 4.145E-02 4.189E-02 4.232E-02 4.273E-02 4.312E-02 4.350E-02 4.386E-02 4.420E-02 4.451E-02 4.480E-02 4.506E-02 4.529E-02 4.549E-02 4.566E-02 4.579E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.564E-02 4.544E-02 4.520E-02 4.492E-02 4.458E-02 4.420E-02 4.377E-02 4.330E-02 4.277E-02 4.220E-02 4.159E-02 4.092E-02 4.022E-02 3.946E-02 3.867E-02 3.783E-02 3.696E-02 3.605E-02 3.510E-02 3.412E-02 3.310E-02 3.206E-02 3.099E-02 2.990E-02 2.879E-02 2.766E-02 2.651E-02 2.535E-02 2.419E-02 2.302E-02 2.185E-02 2.068E-02 1.951E-02 1.836E-02 1.721E-02 1.609E-02 1.497E-02 1.389E-02 1.282E-02 1.179E-02 1.078E-02 9.807E-03 8.871E-03 7.973E-03 7.116E-03 6.302E-03 5.533E-03 4.810E-03 4.135E-03 3.510E-03 2.935E-03 2.411E-03 1.939E-03 1.519E-03 1.151E-03 8.353E-04 5.715E-04 3.588E-04 1.965E-04 8.354E-05 1.859E-05 2.117E-07 2.673E-05 9.628E-05 2.068E-04 3.562E-04 5.419E-04 7.617E-04 7.841E-04 5.598E-04 3.697E-04 2.164E-04 1.022E-04 2.957E-05 4.832E-07 1.691E-05 8.059E-05 1.931E-04 3.556E-04 5.694E-04 8.353E-04 1.154E-03 1.526E-03 1.951E-03 2.429E-03 2.960E-03 3.543E-03 4.177E-03 4.862E-03 5.596E-03 6.378E-03 7.205E-03 8.076E-03 8.988E-03 9.940E-03 1.093E-02 1.195E-02 1.300E-02 1.409E-02 1.519E-02 1.632E-02 1.747E-02 1.863E-02 1.981E-02 2.099E-02 2.217E-02 2.336E-02 2.455E-02 2.573E-02 2.690E-02 2.806E-02 2.920E-02 3.032E-02 3.143E-02 3.250E-02 3.355E-02 3.457E-02 3.555E-02 3.650E-02 3.741E-02 3.829E-02 3.912E-02 3.990E-02 4.065E-02 4.134E-02 4.199E-02 4.259E-02 4.314E-02 4.364E-02 4.410E-02 4.450E-02 4.485E-02 4.516E-02 4.541E-02 4.562E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.588E-02 4.578E-02 4.563E-02 4.545E-02 4.523E-02 4.498E-02 4.470E-02 4.438E-02 4.404E-02 4.368E-02 4.328E-02 4.287E-02 4.244E-02 4.199E-02 4.152E-02 4.104E-02 4.054E-02 4.004E-02 3.953E-02 3.901E-02 3.849E-02 3.796E-02 3.744E-02 3.691E-02 3.639E-02 3.587E-02 3.535E-02 3.484E-02 3.434E-02 3.385E-02 3.336E-02 3.289E-02 3.243E-02 3.198E-02 3.155E-02 3.113E-02 3.072E-02 3.033E-02 2.996E-02 2.961E-02 2.927E-02 2.895E-02 2.865E-02 2.837E-02 2.811E-02 2.787E-02 2.765E-02 2.744E-02 2.726E-02 2.710E-02 2.697E-02 2.685E-02 2.675E-02 2.668E-02 2.662E-02 2.659E-02 2.658E-02 2.659E-02 2.662E-02 2.668E-02 2.675E-02 2.685E-02 2.697E-02 2.710E-02 2.726E-02 2.744E-02 2.765E-02 2.787E-02 2.811E-02 2.837E-02 2.865E-02 2.895E-02 2.927E-02 2.961E-02 2.996E-02 3.033E-02 3.072E-02 3.113E-02 3.155E-02 3.198E-02 3.243E-02 3.289E-02 3.336E-02 3.385E-02 3.434E-02 3.484E-02 3.535E-02 3.587E-02 3.639E-02 3.691E-02 3.744E-02 3.796E-02 3.849E-02 3.901E-02 3.953E-02 4.004E-02 4.054E-02 4.104E-02 4.152E-02 4.199E-02 4.244E-02 4.287E-02 4.328E-02 4.368E-02 4.404E-02 4.438E-02 4.470E-02 4.498E-02 4.523E-02 4.545E-02 4.563E-02 4.578E-02 4.588E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.562E-02 4.541E-02 4.516E-02 4.485E-02 4.450E-02 4.410E-02 4.364E-02 4.314E-02 4.259E-02 4.199E-02 4.134E-02 4.065E-02 3.990E-02 3.912E-02 3.829E-02 3.741E-02 3.650E-02 3.555E-02 3.457E-02 3.355E-02 3.250E-02 3.143E-02 3.032E-02 2.920E-02 2.806E-02 2.690E-02 2.573E-02 2.455E-02 2.336E-02 2.217E-02 2.099E-02 1.981E-02 1.863E-02 1.747E-02 1.632E-02 1.519E-02 1.409E-02 1.300E-02 1.195E-02 1.093E-02 9.940E-03 8.988E-03 8.076E-03 7.205E-03 6.378E-03 5.596E-03 4.862E-03 4.177E-03 3.543E-03 2.960E-03 2.429E-03 1.951E-03 1.526E-03 1.154E-03 8.353E-04 5.694E-04 3.556E-04 1.931E-04 8.059E-05 1.691E-05 4.832E-07 2.957E-05 1.022E-04 2.164E-04 3.697E-04 5.598E-04 5.812E-04 3.863E-04 2.283E-04 1.099E-04 3.344E-05 1.016E-06 1.469E-05 7.626E-05 1.873E-04 3.493E-04 5.633E-04 8.303E-04 1.151E-03 1.526E-03 1.955E-03 2.438E-03 2.975E-03 3.565E-03 4.208E-03 4.902E-03 5.646E-03 6.439E-03 7.278E-03 8.162E-03 9.088E-03 1.005E-02 1.106E-02 1.210E-02 1.317E-02 1.427E-02 1.539E-02 1.654E-02 1.770E-02 1.888E-02 2.007E-02 2.127E-02 2.247E-02 2.368E-02 2.488E-02 2.608E-02 2.726E-02 2.843E-02 2.959E-02 3.072E-02 3.183E-02 3.292E-02 3.397E-02 3.499E-02 3.598E-02 3.693E-02 3.784E-02 3.871E-02 3.953E-02 4.031E-02 4.104E-02 4.173E-02 4.236E-02 4.294E-02 4.348E-02 4.396E-02 4.439E-02 4.476E-02 4.509E-02 4.536E-02 4.558E-02 4.575E-02 4.587E-02 4.595E-02 4.597E-02 4.595E-02 4.588E-02 4.577E-02 4.562E-02 4.543E-02 4.519E-02 4.492E-02 4.462E-02 4.429E-02 4.392E-02 4.352E-02 4.310E-02 4.266E-02 4.219E-02 4.170E-02 4.119E-02 4.067E-02 4.013E-02 3.958E-02 3.903E-02 3.846E-02 3.789E-02 3.731E-02 3.674E-02 3.616E-02 3.558E-02 3.501E-02 3.444E-02 3.387E-02 3.332E-02 3.277E-02 3.223E-02 3.170E-02 3.118E-02 3.068E-02 3.019E-02 2.972E-02 2.926E-02 2.882E-02 2.839E-02 2.798E-02 2.759E-02 2.722E-02 2.687E-02 2.654E-02 2.622E-02 2.593E-02 2.566E-02 2.541E-02 2.518E-02 2.497E-02 2.479E-02 2.462E-02 2.448E-02 2.436E-02 2.426E-02 2.418E-02 2.413E-02 2.409E-02 2.408E-02 2.409E-02 2.413E-02 2.418E-02 2.426E-02 2.436E-02 2.448E-02 2.462E-02 2.479E-02 2.497E-02 2.518E-02 2.541E-02 2.566E-02 2.593E-02 2.622E-02 2.654E-02 2.687E-02 2.722E-02 2.759E-02 2.798E-02 2.839E-02 2.882E-02 2.926E-02 2.972E-02 3.019E-02 3.068E-02 3.118E-02 3.170E-02 3.223E-02 3.277E-02 3.332E-02 3.387E-02 3.444E-02 3.501E-02 3.558E-02 3.616E-02 3.674E-02 3.731E-02 3.789E-02 3.846E-02 3.903E-02 3.958E-02 4.013E-02 4.067E-02 4.119E-02 4.170E-02 4.219E-02 4.266E-02 4.310E-02 4.352E-02 4.392E-02 4.429E-02 4.462E-02 4.492E-02 4.519E-02 4.543E-02 4.562E-02 4.577E-02 4.588E-02 4.595E-02 4.597E-02 4.595E-02 4.587E-02 4.575E-02 4.558E-02 4.536E-02 4.509E-02 4.476E-02 4.439E-02 4.396E-02 4.348E-02 4.294E-02 4.236E-02 4.173E-02 4.104E-02 4.031E-02 3.953E-02 3.871E-02 3.784E-02 3.693E-02 3.598E-02 3.499E-02 3.397E-02 3.292E-02 3.183E-02 3.072E-02 2.959E-02 2.843E-02 2.726E-02 2.608E-02 2.488E-02 2.368E-02 2.247E-02 2.127E-02 2.007E-02 1.888E-02 1.770E-02 1.654E-02 1.539E-02 1.427E-02 1.317E-02 1.210E-02 1.106E-02 1.005E-02 9.088E-03 8.162E-03 7.278E-03 6.439E-03 5.646E-03 4.902E-03 4.208E-03 3.565E-03 2.975E-03 2.438E-03 1.955E-03 1.526E-03 1.151E-03 8.303E-04 5.633E-04 3.493E-04 1.873E-04 7.626E-05 1.469E-05 1.016E-06 3.344E-05 1.099E-04 2.283E-04 3.863E-04 4.060E-04 2.428E-04 1.195E-04 3.847E-05 1.956E-06 1.206E-05 7.067E-05 1.795E-04 3.399E-04 5.532E-04 8.203E-04 1.142E-03 1.519E-03 1.951E-03 2.438E-03 2.980E-03 3.576E-03 4.226E-03 4.928E-03 5.682E-03 6.484E-03 7.335E-03 8.231E-03 9.170E-03 1.015E-02 1.117E-02 1.222E-02 1.331E-02 1.442E-02 1.556E-02 1.673E-02 1.791E-02 1.911E-02 2.031E-02 2.153E-02 2.275E-02 2.397E-02 2.519E-02 2.640E-02 2.760E-02 2.878E-02 2.995E-02 3.109E-02 3.221E-02 3.330E-02 3.436E-02 3.539E-02 3.638E-02 3.733E-02 3.824E-02 3.910E-02 3.992E-02 4.069E-02 4.141E-02 4.208E-02 4.270E-02 4.327E-02 4.378E-02 4.424E-02 4.464E-02 4.499E-02 4.529E-02 4.553E-02 4.572E-02 4.585E-02 4.594E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.562E-02 4.542E-02 4.518E-02 4.489E-02 4.458E-02 4.422E-02 4.383E-02 4.341E-02 4.296E-02 4.248E-02 4.198E-02 4.146E-02 4.091E-02 4.035E-02 3.977E-02 3.918E-02 3.858E-02 3.796E-02 3.735E-02 3.672E-02 3.609E-02 3.546E-02 3.483E-02 3.421E-02 3.358E-02 3.296E-02 3.235E-02 3.175E-02 3.115E-02 3.057E-02 3.000E-02 2.944E-02 2.890E-02 2.837E-02 2.786E-02 2.736E-02 2.688E-02 2.642E-02 2.598E-02 2.555E-02 2.515E-02 2.477E-02 2.440E-02 2.406E-02 2.374E-02 2.344E-02 2.316E-02 2.290E-02 2.267E-02 2.245E-02 2.226E-02 2.210E-02 2.195E-02 2.183E-02 2.172E-02 2.164E-02 2.159E-02 2.155E-02 2.154E-02 2.155E-02 2.159E-02 2.164E-02 2.172E-02 2.183E-02 2.195E-02 2.210E-02 2.226E-02 2.245E-02 2.267E-02 2.290E-02 2.316E-02 2.344E-02 2.374E-02 2.406E-02 2.440E-02 2.477E-02 2.515E-02 2.555E-02 2.598E-02 2.642E-02 2.688E-02 2.736E-02 2.786E-02 2.837E-02 2.890E-02 2.944E-02 3.000E-02 3.057E-02 3.115E-02 3.175E-02 3.235E-02 3.296E-02 3.358E-02 3.421E-02 3.483E-02 3.546E-02 3.609E-02 3.672E-02 3.735E-02 3.796E-02 3.858E-02 3.918E-02 3.977E-02 4.035E-02 4.091E-02 4.146E-02 4.198E-02 4.248E-02 4.296E-02 4.341E-02 4.383E-02 4.422E-02 4.458E-02 4.489E-02 4.518E-02 4.542E-02 4.562E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.594E-02 4.585E-02 4.572E-02 4.553E-02 4.529E-02 4.499E-02 4.464E-02 4.424E-02 4.378E-02 4.327E-02 4.270E-02 4.208E-02 4.141E-02 4.069E-02 3.992E-02 3.910E-02 3.824E-02 3.733E-02 3.638E-02 3.539E-02 3.436E-02 3.330E-02 3.221E-02 3.109E-02 2.995E-02 2.878E-02 2.760E-02 2.640E-02 2.519E-02 2.397E-02 2.275E-02 2.153E-02 2.031E-02 1.911E-02 1.791E-02 1.673E-02 1.556E-02 1.442E-02 1.331E-02 1.222E-02 1.117E-02 1.015E-02 9.170E-03 8.231E-03 7.335E-03 6.484E-03 5.682E-03 4.928E-03 4.226E-03 3.576E-03 2.980E-03 2.438E-03 1.951E-03 1.519E-03 1.142E-03 8.203E-04 5.532E-04 3.399E-04 1.795E-04 7.067E-05 1.206E-05 1.956E-06 3.847E-05 1.195E-04 2.428E-04 2.601E-04 1.312E-04 4.486E-05 3.484E-06 9.211E-06 6.401E-05 1.696E-04 3.276E-04 5.391E-04 8.054E-04 1.127E-03 1.505E-03 1.939E-03 2.429E-03 2.975E-03 3.576E-03 4.232E-03 4.942E-03 5.703E-03 6.515E-03 7.376E-03 8.283E-03 9.234E-03 1.023E-02 1.126E-02 1.233E-02 1.343E-02 1.456E-02 1.572E-02 1.689E-02 1.809E-02 1.931E-02 2.053E-02 2.176E-02 2.300E-02 2.424E-02 2.547E-02 2.669E-02 2.790E-02 2.910E-02 3.028E-02 3.143E-02 3.256E-02 3.366E-02 3.472E-02 3.575E-02 3.675E-02 3.770E-02 3.860E-02 3.946E-02 4.028E-02 4.104E-02 4.175E-02 4.241E-02 4.301E-02 4.356E-02 4.405E-02 4.449E-02 4.487E-02 4.519E-02 4.546E-02 4.567E-02 4.582E-02 4.592E-02 4.597E-02 4.596E-02 4.590E-02 4.579E-02 4.564E-02 4.543E-02 4.518E-02 4.489E-02 4.456E-02 4.419E-02 4.378E-02 4.334E-02 4.286E-02 4.236E-02 4.182E-02 4.127E-02 4.069E-02 4.009E-02 3.947E-02 3.884E-02 3.819E-02 3.753E-02 3.686E-02 3.619E-02 3.551E-02 3.483E-02 3.415E-02 3.347E-02 3.280E-02 3.212E-02 3.146E-02 3.080E-02 3.015E-02 2.951E-02 2.889E-02 2.828E-02 2.768E-02 2.709E-02 2.653E-02 2.598E-02 2.544E-02 2.493E-02 2.443E-02 2.396E-02 2.350E-02 2.307E-02 2.266E-02 2.226E-02 2.189E-02 2.154E-02 2.122E-02 2.091E-02 2.063E-02 2.037E-02 2.013E-02 1.991E-02 1.972E-02 1.955E-02 1.940E-02 1.928E-02 1.918E-02 1.910E-02 1.904E-02 1.901E-02 1.900E-02 1.901E-02 1.904E-02 1.910E-02 1.918E-02 1.928E-02 1.940E-02 1.955E-02 1.972E-02 1.991E-02 2.013E-02 2.037E-02 2.063E-02 2.091E-02 2.122E-02 2.154E-02 2.189E-02 2.226E-02 2.266E-02 2.307E-02 2.350E-02 2.396E-02 2.443E-02 2.493E-02 2.544E-02 2.598E-02 2.653E-02 2.709E-02 2.768E-02 2.828E-02 2.889E-02 2.951E-02 3.015E-02 3.080E-02 3.146E-02 3.212E-02 3.280E-02 3.347E-02 3.415E-02 3.483E-02 3.551E-02 3.619E-02 3.686E-02 3.753E-02 3.819E-02 3.884E-02 3.947E-02 4.009E-02 4.069E-02 4.127E-02 4.182E-02 4.236E-02 4.286E-02 4.334E-02 4.378E-02 4.419E-02 4.456E-02 4.489E-02 4.518E-02 4.543E-02 4.564E-02 4.579E-02 4.590E-02 4.596E-02 4.597E-02 4.592E-02 4.582E-02 4.567E-02 4.546E-02 4.519E-02 4.487E-02 4.449E-02 4.405E-02 4.356E-02 4.301E-02 4.241E-02 4.175E-02 4.104E-02 4.028E-02 3.946E-02 3.860E-02 3.770E-02 3.675E-02 3.575E-02 3.472E-02 3.366E-02 3.256E-02 3.143E-02 3.028E-02 2.910E-02 2.790E-02 2.669E-02 2.547E-02 2.424E-02 2.300E-02 2.176E-02 2.053E-02 1.931E-02 1.809E-02 1.689E-02 1.572E-02 1.456E-02 1.343E-02 1.233E-02 1.126E-02 1.023E-02 9.234E-03 8.283E-03 7.376E-03 6.515E-03 5.703E-03 4.942E-03 4.232E-03 3.576E-03 2.975E-03 2.429E-03 1.939E-03 1.505E-03 1.127E-03 8.054E-04 5.391E-04 3.276E-04 1.696E-04 6.401E-05 9.211E-06 3.484E-06 4.486E-05 1.312E-04 1.451E-04 5.282E-05 5.812E-06 6.341E-06 5.645E-05 1.580E-04 3.125E-04 5.214E-04 7.858E-04 1.106E-03 1.484E-03 1.919E-03 2.411E-03 2.960E-03 3.565E-03 4.226E-03 4.942E-03 5.710E-03 6.530E-03 7.400E-03 8.318E-03 9.280E-03 1.029E-02 1.133E-02 1.241E-02 1.353E-02 1.467E-02 1.584E-02 1.704E-02 1.825E-02 1.948E-02 2.072E-02 2.197E-02 2.322E-02 2.448E-02 2.572E-02 2.696E-02 2.818E-02 2.939E-02 3.058E-02 3.175E-02 3.288E-02 3.399E-02 3.506E-02 3.609E-02 3.709E-02 3.804E-02 3.894E-02 3.980E-02 4.061E-02 4.136E-02 4.206E-02 4.270E-02 4.329E-02 4.382E-02 4.430E-02 4.471E-02 4.507E-02 4.536E-02 4.560E-02 4.578E-02 4.590E-02 4.596E-02 4.597E-02 4.592E-02 4.582E-02 4.567E-02 4.547E-02 4.521E-02 4.492E-02 4.458E-02 4.419E-02 4.377E-02 4.331E-02 4.281E-02 4.228E-02 4.172E-02 4.113E-02 4.052E-02 3.988E-02 3.923E-02 3.856E-02 3.787E-02 3.717E-02 3.645E-02 3.573E-02 3.501E-02 3.428E-02 3.355E-02 3.281E-02 3.209E-02 3.136E-02 3.064E-02 2.993E-02 2.923E-02 2.854E-02 2.786E-02 2.719E-02 2.654E-02 2.590E-02 2.528E-02 2.468E-02 2.409E-02 2.353E-02 2.298E-02 2.245E-02 2.195E-02 2.146E-02 2.100E-02 2.056E-02 2.014E-02 1.974E-02 1.937E-02 1.902E-02 1.869E-02 1.838E-02 1.810E-02 1.784E-02 1.760E-02 1.739E-02 1.719E-02 1.702E-02 1.688E-02 1.675E-02 1.665E-02 1.657E-02 1.652E-02 1.648E-02 1.647E-02 1.648E-02 1.652E-02 1.657E-02 1.665E-02 1.675E-02 1.688E-02 1.702E-02 1.719E-02 1.739E-02 1.760E-02 1.784E-02 1.810E-02 1.838E-02 1.869E-02 1.902E-02 1.937E-02 1.974E-02 2.014E-02 2.056E-02 2.100E-02 2.146E-02 2.195E-02 2.245E-02 2.298E-02 2.353E-02 2.409E-02 2.468E-02 2.528E-02 2.590E-02 2.654E-02 2.719E-02 2.786E-02 2.854E-02 2.923E-02 2.993E-02 3.064E-02 3.136E-02 3.209E-02 3.281E-02 3.355E-02 3.428E-02 3.501E-02 3.573E-02 3.645E-02 3.717E-02 3.787E-02 3.856E-02 3.923E-02 3.988E-02 4.052E-02 4.113E-02 4.172E-02 4.228E-02 4.281E-02 4.331E-02 4.377E-02 4.419E-02 4.458E-02 4.492E-02 4.521E-02 4.547E-02 4.567E-02 4.582E-02 4.592E-02 4.597E-02 4.596E-02 4.590E-02 4.578E-02 4.560E-02 4.536E-02 4.507E-02 4.471E-02 4.430E-02 4.382E-02 4.329E-02 4.270E-02 4.206E-02 4.136E-02 4.061E-02 3.980E-02 3.894E-02 3.804E-02 3.709E-02 3.609E-02 3.506E-02 3.399E-02 3.288E-02 3.175E-02 3.058E-02 2.939E-02 2.818E-02 2.696E-02 2.572E-02 2.448E-02 2.322E-02 2.197E-02 2.072E-02 1.948E-02 1.825E-02 1.704E-02 1.584E-02 1.467E-02 1.353E-02 1.241E-02 1.133E-02 1.029E-02 9.280E-03 8.318E-03 7.400E-03 6.530E-03 5.710E-03 4.942E-03 4.226E-03 3.565E-03 2.960E-03 2.411E-03 1.919E-03 1.484E-03 1.106E-03 7.858E-04 5.214E-04 3.125E-04 1.580E-04 5.645E-05 6.341E-06 5.812E-06 5.282E-05 6.260E-05 9.190E-06 3.699E-06 4.826E-05 1.448E-04 2.949E-04 5.001E-04 7.616E-04 1.080E-03 1.457E-03 1.891E-03 2.384E-03 2.935E-03 3.543E-03 4.208E-03 4.928E-03 5.703E-03 6.530E-03 7.409E-03 8.335E-03 9.308E-03 1.032E-02 1.138E-02 1.248E-02 1.360E-02 1.476E-02 1.595E-02 1.716E-02 1.839E-02 1.963E-02 2.089E-02 2.215E-02 2.342E-02 2.469E-02 2.595E-02 2.720E-02 2.844E-02 2.966E-02 3.086E-02 3.203E-02 3.318E-02 3.429E-02 3.537E-02 3.641E-02 3.740E-02 3.835E-02 3.926E-02 4.011E-02 4.091E-02 4.165E-02 4.234E-02 4.298E-02 4.355E-02 4.406E-02 4.451E-02 4.491E-02 4.524E-02 4.550E-02 4.571E-02 4.586E-02 4.594E-02 4.597E-02 4.594E-02 4.585E-02 4.571E-02 4.551E-02 4.527E-02 4.497E-02 4.462E-02 4.423E-02 4.379E-02 4.332E-02 4.280E-02 4.225E-02 4.167E-02 4.106E-02 4.041E-02 3.975E-02 3.905E-02 3.834E-02 3.762E-02 3.687E-02 3.612E-02 3.535E-02 3.458E-02 3.380E-02 3.302E-02 3.224E-02 3.146E-02 3.068E-02 2.991E-02 2.915E-02 2.839E-02 2.765E-02 2.691E-02 2.619E-02 2.549E-02 2.480E-02 2.413E-02 2.347E-02 2.284E-02 2.222E-02 2.162E-02 2.105E-02 2.049E-02 1.996E-02 1.945E-02 1.896E-02 1.850E-02 1.805E-02 1.763E-02 1.724E-02 1.687E-02 1.652E-02 1.619E-02 1.588E-02 1.560E-02 1.535E-02 1.511E-02 1.490E-02 1.471E-02 1.454E-02 1.440E-02 1.428E-02 1.418E-02 1.410E-02 1.404E-02 1.401E-02 1.400E-02 1.401E-02 1.404E-02 1.410E-02 1.418E-02 1.428E-02 1.440E-02 1.454E-02 1.471E-02 1.490E-02 1.511E-02 1.535E-02 1.560E-02 1.588E-02 1.619E-02 1.652E-02 1.687E-02 1.724E-02 1.763E-02 1.805E-02 1.850E-02 1.896E-02 1.945E-02 1.996E-02 2.049E-02 2.105E-02 2.162E-02 2.222E-02 2.284E-02 2.347E-02 2.413E-02 2.480E-02 2.549E-02 2.619E-02 2.691E-02 2.765E-02 2.839E-02 2.915E-02 2.991E-02 3.068E-02 3.146E-02 3.224E-02 3.302E-02 3.380E-02 3.458E-02 3.535E-02 3.612E-02 3.687E-02 3.762E-02 3.834E-02 3.905E-02 3.975E-02 4.041E-02 4.106E-02 4.167E-02 4.225E-02 4.280E-02 4.332E-02 4.379E-02 4.423E-02 4.462E-02 4.497E-02 4.527E-02 4.551E-02 4.571E-02 4.585E-02 4.594E-02 4.597E-02 4.594E-02 4.586E-02 4.571E-02 4.550E-02 4.524E-02 4.491E-02 4.451E-02 4.406E-02 4.355E-02 4.298E-02 4.234E-02 4.165E-02 4.091E-02 4.011E-02 3.926E-02 3.835E-02 3.740E-02 3.641E-02 3.537E-02 3.429E-02 3.318E-02 3.203E-02 3.086E-02 2.966E-02 2.844E-02 2.720E-02 2.595E-02 2.469E-02 2.342E-02 2.215E-02 2.089E-02 1.963E-02 1.839E-02 1.716E-02 1.595E-02 1.476E-02 1.360E-02 1.248E-02 1.138E-02 1.032E-02 9.308E-03 8.335E-03 7.409E-03 6.530E-03 5.703E-03 4.928E-03 4.208E-03 3.543E-03 2.935E-03 2.384E-03 1.891E-03 1.457E-03 1.080E-03 7.616E-04 5.001E-04 2.949E-04 1.448E-04 4.826E-05 3.699E-06 9.190E-06 1.389E-05 1.565E-06 3.969E-05 1.303E-04 2.751E-04 4.756E-04 7.331E-04 1.049E-03 1.423E-03 1.856E-03 2.348E-03 2.900E-03 3.510E-03 4.177E-03 4.902E-03 5.682E-03 6.515E-03 7.400E-03 8.335E-03 9.317E-03 1.034E-02 1.141E-02 1.252E-02 1.366E-02 1.483E-02 1.603E-02 1.726E-02 1.850E-02 1.976E-02 2.103E-02 2.231E-02 2.359E-02 2.487E-02 2.615E-02 2.741E-02 2.867E-02 2.990E-02 3.111E-02 3.229E-02 3.345E-02 3.457E-02 3.565E-02 3.669E-02 3.769E-02 3.864E-02 3.954E-02 4.039E-02 4.119E-02 4.192E-02 4.260E-02 4.322E-02 4.378E-02 4.428E-02 4.471E-02 4.508E-02 4.538E-02 4.562E-02 4.580E-02 4.592E-02 4.597E-02 4.596E-02 4.589E-02 4.576E-02 4.558E-02 4.534E-02 4.504E-02 4.470E-02 4.430E-02 4.386E-02 4.337E-02 4.285E-02 4.228E-02 4.168E-02 4.104E-02 4.037E-02 3.967E-02 3.895E-02 3.820E-02 3.744E-02 3.666E-02 3.586E-02 3.505E-02 3.423E-02 3.341E-02 3.258E-02 3.175E-02 3.092E-02 3.009E-02 2.927E-02 2.845E-02 2.765E-02 2.685E-02 2.606E-02 2.529E-02 2.453E-02 2.379E-02 2.307E-02 2.236E-02 2.168E-02 2.101E-02 2.037E-02 1.974E-02 1.914E-02 1.856E-02 1.801E-02 1.748E-02 1.697E-02 1.648E-02 1.602E-02 1.558E-02 1.517E-02 1.478E-02 1.441E-02 1.407E-02 1.375E-02 1.345E-02 1.317E-02 1.292E-02 1.269E-02 1.249E-02 1.230E-02 1.214E-02 1.200E-02 1.189E-02 1.179E-02 1.171E-02 1.166E-02 1.163E-02 1.162E-02 1.163E-02 1.166E-02 1.171E-02 1.179E-02 1.189E-02 1.200E-02 1.214E-02 1.230E-02 1.249E-02 1.269E-02 1.292E-02 1.317E-02 1.345E-02 1.375E-02 1.407E-02 1.441E-02 1.478E-02 1.517E-02 1.558E-02 1.602E-02 1.648E-02 1.697E-02 1.748E-02 1.801E-02 1.856E-02 1.914E-02 1.974E-02 2.037E-02 2.101E-02 2.168E-02 2.236E-02 2.307E-02 2.379E-02 2.453E-02 2.529E-02 2.606E-02 2.685E-02 2.765E-02 2.845E-02 2.927E-02 3.009E-02 3.092E-02 3.175E-02 3.258E-02 3.341E-02 3.423E-02 3.505E-02 3.586E-02 3.666E-02 3.744E-02 3.820E-02 3.895E-02 3.967E-02 4.037E-02 4.104E-02 4.168E-02 4.228E-02 4.285E-02 4.337E-02 4.386E-02 4.430E-02 4.470E-02 4.504E-02 4.534E-02 4.558E-02 4.576E-02 4.589E-02 4.596E-02 4.597E-02 4.592E-02 4.580E-02 4.562E-02 4.538E-02 4.508E-02 4.471E-02 4.428E-02 4.378E-02 4.322E-02 4.260E-02 4.192E-02 4.119E-02 4.039E-02 3.954E-02 3.864E-02 3.769E-02 3.669E-02 3.565E-02 3.457E-02 3.345E-02 3.229E-02 3.111E-02 2.990E-02 2.867E-02 2.741E-02 2.615E-02 2.487E-02 2.359E-02 2.231E-02 2.103E-02 1.976E-02 1.850E-02 1.726E-02 1.603E-02 1.483E-02 1.366E-02 1.252E-02 1.141E-02 1.034E-02 9.317E-03 8.335E-03 7.400E-03 6.515E-03 5.682E-03 4.902E-03 4.177E-03 3.510E-03 2.900E-03 2.348E-03 1.856E-03 1.423E-03 1.049E-03 7.331E-04 4.756E-04 2.751E-04 1.303E-04 3.969E-05 1.565E-06 2.521E-07 3.108E-05 1.148E-04 2.533E-04 4.481E-04 7.007E-04 1.012E-03 1.383E-03 1.813E-03 2.304E-03 2.855E-03 3.466E-03 4.135E-03 4.862E-03 5.646E-03 6.484E-03 7.376E-03 8.318E-03 9.308E-03 1.034E-02 1.142E-02 1.254E-02 1.369E-02 1.488E-02 1.609E-02 1.733E-02 1.859E-02 1.986E-02 2.115E-02 2.244E-02 2.374E-02 2.503E-02 2.632E-02 2.760E-02 2.887E-02 3.011E-02 3.133E-02 3.253E-02 3.369E-02 3.482E-02 3.591E-02 3.695E-02 3.795E-02 3.890E-02 3.980E-02 4.065E-02 4.144E-02 4.217E-02 4.284E-02 4.344E-02 4.399E-02 4.447E-02 4.488E-02 4.523E-02 4.551E-02 4.572E-02 4.587E-02 4.595E-02 4.597E-02 4.593E-02 4.582E-02 4.565E-02 4.542E-02 4.514E-02 4.480E-02 4.441E-02 4.396E-02 4.347E-02 4.294E-02 4.236E-02 4.174E-02 4.108E-02 4.039E-02 3.967E-02 3.891E-02 3.814E-02 3.734E-02 3.652E-02 3.568E-02 3.483E-02 3.397E-02 3.310E-02 3.223E-02 3.135E-02 3.047E-02 2.960E-02 2.872E-02 2.786E-02 2.700E-02 2.615E-02 2.531E-02 2.449E-02 2.368E-02 2.289E-02 2.212E-02 2.136E-02 2.063E-02 1.991E-02 1.922E-02 1.855E-02 1.791E-02 1.728E-02 1.668E-02 1.611E-02 1.556E-02 1.503E-02 1.453E-02 1.405E-02 1.360E-02 1.317E-02 1.277E-02 1.239E-02 1.204E-02 1.170E-02 1.139E-02 1.111E-02 1.085E-02 1.060E-02 1.039E-02 1.019E-02 1.001E-02 9.859E-03 9.726E-03 9.614E-03 9.522E-03 9.451E-03 9.401E-03 9.370E-03 9.360E-03 9.370E-03 9.401E-03 9.451E-03 9.522E-03 9.614E-03 9.726E-03 9.859E-03 1.001E-02 1.019E-02 1.039E-02 1.060E-02 1.085E-02 1.111E-02 1.139E-02 1.170E-02 1.204E-02 1.239E-02 1.277E-02 1.317E-02 1.360E-02 1.405E-02 1.453E-02 1.503E-02 1.556E-02 1.611E-02 1.668E-02 1.728E-02 1.791E-02 1.855E-02 1.922E-02 1.991E-02 2.063E-02 2.136E-02 2.212E-02 2.289E-02 2.368E-02 2.449E-02 2.531E-02 2.615E-02 2.700E-02 2.786E-02 2.872E-02 2.960E-02 3.047E-02 3.135E-02 3.223E-02 3.310E-02 3.397E-02 3.483E-02 3.568E-02 3.652E-02 3.734E-02 3.814E-02 3.891E-02 3.967E-02 4.039E-02 4.108E-02 4.174E-02 4.236E-02 4.294E-02 4.347E-02 4.396E-02 4.441E-02 4.480E-02 4.514E-02 4.542E-02 4.565E-02 4.582E-02 4.593E-02 4.597E-02 4.595E-02 4.587E-02 4.572E-02 4.551E-02 4.523E-02 4.488E-02 4.447E-02 4.399E-02 4.344E-02 4.284E-02 4.217E-02 4.144E-02 4.065E-02 3.980E-02 3.890E-02 3.795E-02 3.695E-02 3.591E-02 3.482E-02 3.369E-02 3.253E-02 3.133E-02 3.011E-02 2.887E-02 2.760E-02 2.632E-02 2.503E-02 2.374E-02 2.244E-02 2.115E-02 1.986E-02 1.859E-02 1.733E-02 1.609E-02 1.488E-02 1.369E-02 1.254E-02 1.142E-02 1.034E-02 9.308E-03 8.318E-03 7.376E-03 6.484E-03 5.646E-03 4.862E-03 4.135E-03 3.466E-03 2.855E-03 2.304E-03 1.813E-03 1.383E-03 1.012E-03 7.007E-04 4.481E-04 2.533E-04 1.148E-04 3.108E-05 2.278E-05 9.874E-05 2.299E-04 4.181E-04 6.645E-04 9.705E-04 1.337E-03 1.764E-03 2.252E-03 2.801E-03 3.411E-03 4.081E-03 4.810E-03 5.596E-03 6.439E-03 7.335E-03 8.283E-03 9.280E-03 1.032E-02 1.141E-02 1.254E-02 1.370E-02 1.490E-02 1.613E-02 1.738E-02 1.865E-02 1.994E-02 2.124E-02 2.255E-02 2.386E-02 2.517E-02 2.647E-02 2.776E-02 2.904E-02 3.030E-02 3.153E-02 3.273E-02 3.391E-02 3.504E-02 3.614E-02 3.719E-02 3.819E-02 3.914E-02 4.004E-02 4.088E-02 4.167E-02 4.239E-02 4.305E-02 4.364E-02 4.417E-02 4.463E-02 4.503E-02 4.535E-02 4.561E-02 4.580E-02 4.592E-02 4.597E-02 4.595E-02 4.587E-02 4.573E-02 4.552E-02 4.525E-02 4.492E-02 4.454E-02 4.410E-02 4.361E-02 4.307E-02 4.248E-02 4.185E-02 4.118E-02 4.047E-02 3.973E-02 3.895E-02 3.814E-02 3.731E-02 3.646E-02 3.559E-02 3.470E-02 3.380E-02 3.289E-02 3.197E-02 3.105E-02 3.012E-02 2.920E-02 2.828E-02 2.736E-02 2.645E-02 2.555E-02 2.467E-02 2.379E-02 2.294E-02 2.210E-02 2.127E-02 2.047E-02 1.969E-02 1.893E-02 1.819E-02 1.748E-02 1.679E-02 1.612E-02 1.548E-02 1.487E-02 1.428E-02 1.371E-02 1.317E-02 1.266E-02 1.218E-02 1.171E-02 1.128E-02 1.087E-02 1.048E-02 1.012E-02 9.777E-03 9.461E-03 9.169E-03 8.898E-03 8.650E-03 8.424E-03 8.218E-03 8.034E-03 7.870E-03 7.726E-03 7.602E-03 7.498E-03 7.413E-03 7.347E-03 7.300E-03 7.272E-03 7.262E-03 7.272E-03 7.300E-03 7.347E-03 7.413E-03 7.498E-03 7.602E-03 7.726E-03 7.870E-03 8.034E-03 8.218E-03 8.424E-03 8.650E-03 8.898E-03 9.169E-03 9.461E-03 9.777E-03 1.012E-02 1.048E-02 1.087E-02 1.128E-02 1.171E-02 1.218E-02 1.266E-02 1.317E-02 1.371E-02 1.428E-02 1.487E-02 1.548E-02 1.612E-02 1.679E-02 1.748E-02 1.819E-02 1.893E-02 1.969E-02 2.047E-02 2.127E-02 2.210E-02 2.294E-02 2.379E-02 2.467E-02 2.555E-02 2.645E-02 2.736E-02 2.828E-02 2.920E-02 3.012E-02 3.105E-02 3.197E-02 3.289E-02 3.380E-02 3.470E-02 3.559E-02 3.646E-02 3.731E-02 3.814E-02 3.895E-02 3.973E-02 4.047E-02 4.118E-02 4.185E-02 4.248E-02 4.307E-02 4.361E-02 4.410E-02 4.454E-02 4.492E-02 4.525E-02 4.552E-02 4.573E-02 4.587E-02 4.595E-02 4.597E-02 4.592E-02 4.580E-02 4.561E-02 4.535E-02 4.503E-02 4.463E-02 4.417E-02 4.364E-02 4.305E-02 4.239E-02 4.167E-02 4.088E-02 4.004E-02 3.914E-02 3.819E-02 3.719E-02 3.614E-02 3.504E-02 3.391E-02 3.273E-02 3.153E-02 3.030E-02 2.904E-02 2.776E-02 2.647E-02 2.517E-02 2.386E-02 2.255E-02 2.124E-02 1.994E-02 1.865E-02 1.738E-02 1.613E-02 1.490E-02 1.370E-02 1.254E-02 1.141E-02 1.032E-02 9.280E-03 8.283E-03 7.335E-03 6.439E-03 5.596E-03 4.810E-03 4.081E-03 3.411E-03 2.801E-03 2.252E-03 1.764E-03 1.337E-03 9.705E-04 6.645E-04 4.181E-04 2.299E-04 9.874E-05 8.243E-05 2.054E-04 3.858E-04 6.251E-04 9.246E-04 1.285E-03 1.708E-03 2.192E-03 2.738E-03 3.347E-03 4.016E-03 4.745E-03 5.533E-03 6.378E-03 7.278E-03 8.231E-03 9.234E-03 1.029E-02 1.138E-02 1.252E-02 1.369E-02 1.490E-02 1.614E-02 1.740E-02 1.869E-02 1.999E-02 2.130E-02 2.263E-02 2.395E-02 2.527E-02 2.659E-02 2.790E-02 2.919E-02 3.046E-02 3.170E-02 3.292E-02 3.410E-02 3.524E-02 3.634E-02 3.740E-02 3.840E-02 3.936E-02 4.026E-02 4.110E-02 4.187E-02 4.259E-02 4.324E-02 4.382E-02 4.434E-02 4.478E-02 4.516E-02 4.546E-02 4.570E-02 4.586E-02 4.595E-02 4.597E-02 4.592E-02 4.581E-02 4.562E-02 4.538E-02 4.507E-02 4.470E-02 4.427E-02 4.378E-02 4.324E-02 4.266E-02 4.202E-02 4.134E-02 4.061E-02 3.985E-02 3.905E-02 3.823E-02 3.737E-02 3.649E-02 3.558E-02 3.466E-02 3.372E-02 3.277E-02 3.181E-02 3.084E-02 2.987E-02 2.890E-02 2.793E-02 2.697E-02 2.601E-02 2.506E-02 2.413E-02 2.320E-02 2.230E-02 2.141E-02 2.054E-02 1.969E-02 1.886E-02 1.805E-02 1.727E-02 1.652E-02 1.578E-02 1.508E-02 1.440E-02 1.375E-02 1.312E-02 1.252E-02 1.195E-02 1.140E-02 1.089E-02 1.040E-02 9.931E-03 9.492E-03 9.078E-03 8.690E-03 8.326E-03 7.986E-03 7.669E-03 7.375E-03 7.104E-03 6.854E-03 6.625E-03 6.417E-03 6.229E-03 6.061E-03 5.911E-03 5.780E-03 5.668E-03 5.573E-03 5.496E-03 5.437E-03 5.395E-03 5.369E-03 5.361E-03 5.369E-03 5.395E-03 5.437E-03 5.496E-03 5.573E-03 5.668E-03 5.780E-03 5.911E-03 6.061E-03 6.229E-03 6.417E-03 6.625E-03 6.854E-03 7.104E-03 7.375E-03 7.669E-03 7.986E-03 8.326E-03 8.690E-03 9.078E-03 9.492E-03 9.931E-03 1.040E-02 1.089E-02 1.140E-02 1.195E-02 1.252E-02 1.312E-02 1.375E-02 1.440E-02 1.508E-02 1.578E-02 1.652E-02 1.727E-02 1.805E-02 1.886E-02 1.969E-02 2.054E-02 2.141E-02 2.230E-02 2.320E-02 2.413E-02 2.506E-02 2.601E-02 2.697E-02 2.793E-02 2.890E-02 2.987E-02 3.084E-02 3.181E-02 3.277E-02 3.372E-02 3.466E-02 3.558E-02 3.649E-02 3.737E-02 3.823E-02 3.905E-02 3.985E-02 4.061E-02 4.134E-02 4.202E-02 4.266E-02 4.324E-02 4.378E-02 4.427E-02 4.470E-02 4.507E-02 4.538E-02 4.562E-02 4.581E-02 4.592E-02 4.597E-02 4.595E-02 4.586E-02 4.570E-02 4.546E-02 4.516E-02 4.478E-02 4.434E-02 4.382E-02 4.324E-02 4.259E-02 4.187E-02 4.110E-02 4.026E-02 3.936E-02 3.840E-02 3.740E-02 3.634E-02 3.524E-02 3.410E-02 3.292E-02 3.170E-02 3.046E-02 2.919E-02 2.790E-02 2.659E-02 2.527E-02 2.395E-02 2.263E-02 2.130E-02 1.999E-02 1.869E-02 1.740E-02 1.614E-02 1.490E-02 1.369E-02 1.252E-02 1.138E-02 1.029E-02 9.234E-03 8.231E-03 7.278E-03 6.378E-03 5.533E-03 4.745E-03 4.016E-03 3.347E-03 2.738E-03 2.192E-03 1.708E-03 1.285E-03 9.246E-04 6.251E-04 3.858E-04 2.054E-04 1.800E-04 3.517E-04 5.828E-04 8.748E-04 1.229E-03 1.645E-03 2.124E-03 2.667E-03 3.272E-03 3.939E-03 4.667E-03 5.456E-03 6.302E-03 7.205E-03 8.162E-03 9.170E-03 1.023E-02 1.133E-02 1.248E-02 1.366E-02 1.488E-02 1.613E-02 1.740E-02 1.870E-02 2.001E-02 2.134E-02 2.268E-02 2.402E-02 2.535E-02 2.668E-02 2.800E-02 2.931E-02 3.059E-02 3.184E-02 3.307E-02 3.426E-02 3.541E-02 3.652E-02 3.758E-02 3.859E-02 3.955E-02 4.045E-02 4.128E-02 4.206E-02 4.277E-02 4.341E-02 4.398E-02 4.449E-02 4.492E-02 4.527E-02 4.556E-02 4.577E-02 4.590E-02 4.597E-02 4.596E-02 4.588E-02 4.573E-02 4.551E-02 4.522E-02 4.487E-02 4.446E-02 4.399E-02 4.346E-02 4.287E-02 4.223E-02 4.155E-02 4.082E-02 4.004E-02 3.923E-02 3.838E-02 3.750E-02 3.659E-02 3.566E-02 3.470E-02 3.373E-02 3.274E-02 3.174E-02 3.073E-02 2.972E-02 2.870E-02 2.769E-02 2.668E-02 2.567E-02 2.468E-02 2.369E-02 2.272E-02 2.177E-02 2.083E-02 1.991E-02 1.902E-02 1.815E-02 1.730E-02 1.647E-02 1.567E-02 1.490E-02 1.415E-02 1.344E-02 1.275E-02 1.209E-02 1.146E-02 1.086E-02 1.028E-02 9.736E-03 9.219E-03 8.729E-03 8.267E-03 7.832E-03 7.422E-03 7.039E-03 6.680E-03 6.345E-03 6.034E-03 5.746E-03 5.479E-03 5.234E-03 5.010E-03 4.805E-03 4.620E-03 4.453E-03 4.304E-03 4.173E-03 4.058E-03 3.959E-03 3.877E-03 3.809E-03 3.758E-03 3.721E-03 3.699E-03 3.691E-03 3.699E-03 3.721E-03 3.758E-03 3.809E-03 3.877E-03 3.959E-03 4.058E-03 4.173E-03 4.304E-03 4.453E-03 4.620E-03 4.805E-03 5.010E-03 5.234E-03 5.479E-03 5.746E-03 6.034E-03 6.345E-03 6.680E-03 7.039E-03 7.422E-03 7.832E-03 8.267E-03 8.729E-03 9.219E-03 9.736E-03 1.028E-02 1.086E-02 1.146E-02 1.209E-02 1.275E-02 1.344E-02 1.415E-02 1.490E-02 1.567E-02 1.647E-02 1.730E-02 1.815E-02 1.902E-02 1.991E-02 2.083E-02 2.177E-02 2.272E-02 2.369E-02 2.468E-02 2.567E-02 2.668E-02 2.769E-02 2.870E-02 2.972E-02 3.073E-02 3.174E-02 3.274E-02 3.373E-02 3.470E-02 3.566E-02 3.659E-02 3.750E-02 3.838E-02 3.923E-02 4.004E-02 4.082E-02 4.155E-02 4.223E-02 4.287E-02 4.346E-02 4.399E-02 4.446E-02 4.487E-02 4.522E-02 4.551E-02 4.573E-02 4.588E-02 4.596E-02 4.597E-02 4.590E-02 4.577E-02 4.556E-02 4.527E-02 4.492E-02 4.449E-02 4.398E-02 4.341E-02 4.277E-02 4.206E-02 4.128E-02 4.045E-02 3.955E-02 3.859E-02 3.758E-02 3.652E-02 3.541E-02 3.426E-02 3.307E-02 3.184E-02 3.059E-02 2.931E-02 2.800E-02 2.668E-02 2.535E-02 2.402E-02 2.268E-02 2.134E-02 2.001E-02 1.870E-02 1.740E-02 1.613E-02 1.488E-02 1.366E-02 1.248E-02 1.133E-02 1.023E-02 9.170E-03 8.162E-03 7.205E-03 6.302E-03 5.456E-03 4.667E-03 3.939E-03 3.272E-03 2.667E-03 2.124E-03 1.645E-03 1.229E-03 8.748E-04 5.828E-04 3.517E-04 3.162E-04 5.381E-04 8.215E-04 1.167E-03 1.577E-03 2.050E-03 2.587E-03 3.188E-03 3.852E-03 4.578E-03 5.365E-03 6.212E-03 7.116E-03 8.076E-03 9.088E-03 1.015E-02 1.126E-02 1.241E-02 1.360E-02 1.483E-02 1.609E-02 1.738E-02 1.869E-02 2.001E-02 2.136E-02 2.270E-02 2.406E-02 2.541E-02 2.675E-02 2.808E-02 2.940E-02 3.069E-02 3.196E-02 3.320E-02 3.440E-02 3.556E-02 3.668E-02 3.774E-02 3.876E-02 3.972E-02 4.062E-02 4.145E-02 4.222E-02 4.293E-02 4.356E-02 4.413E-02 4.462E-02 4.503E-02 4.537E-02 4.563E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.564E-02 4.538E-02 4.506E-02 4.467E-02 4.422E-02 4.370E-02 4.312E-02 4.249E-02 4.181E-02 4.107E-02 4.029E-02 3.947E-02 3.861E-02 3.771E-02 3.678E-02 3.582E-02 3.483E-02 3.383E-02 3.280E-02 3.177E-02 3.072E-02 2.967E-02 2.861E-02 2.755E-02 2.649E-02 2.544E-02 2.440E-02 2.337E-02 2.235E-02 2.135E-02 2.037E-02 1.940E-02 1.846E-02 1.754E-02 1.665E-02 1.578E-02 1.494E-02 1.413E-02 1.335E-02 1.260E-02 1.187E-02 1.118E-02 1.052E-02 9.890E-03 9.290E-03 8.719E-03 8.179E-03 7.669E-03 7.188E-03 6.735E-03 6.309E-03 5.911E-03 5.539E-03 5.193E-03 4.871E-03 4.572E-03 4.296E-03 4.042E-03 3.809E-03 3.596E-03 3.402E-03 3.227E-03 3.068E-03 2.927E-03 2.801E-03 2.690E-03 2.594E-03 2.512E-03 2.443E-03 2.388E-03 2.345E-03 2.314E-03 2.296E-03 2.290E-03 2.296E-03 2.314E-03 2.345E-03 2.388E-03 2.443E-03 2.512E-03 2.594E-03 2.690E-03 2.801E-03 2.927E-03 3.068E-03 3.227E-03 3.402E-03 3.596E-03 3.809E-03 4.042E-03 4.296E-03 4.572E-03 4.871E-03 5.193E-03 5.539E-03 5.911E-03 6.309E-03 6.735E-03 7.188E-03 7.669E-03 8.179E-03 8.719E-03 9.290E-03 9.890E-03 1.052E-02 1.118E-02 1.187E-02 1.260E-02 1.335E-02 1.413E-02 1.494E-02 1.578E-02 1.665E-02 1.754E-02 1.846E-02 1.940E-02 2.037E-02 2.135E-02 2.235E-02 2.337E-02 2.440E-02 2.544E-02 2.649E-02 2.755E-02 2.861E-02 2.967E-02 3.072E-02 3.177E-02 3.280E-02 3.383E-02 3.483E-02 3.582E-02 3.678E-02 3.771E-02 3.861E-02 3.947E-02 4.029E-02 4.107E-02 4.181E-02 4.249E-02 4.312E-02 4.370E-02 4.422E-02 4.467E-02 4.506E-02 4.538E-02 4.564E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.563E-02 4.537E-02 4.503E-02 4.462E-02 4.413E-02 4.356E-02 4.293E-02 4.222E-02 4.145E-02 4.062E-02 3.972E-02 3.876E-02 3.774E-02 3.668E-02 3.556E-02 3.440E-02 3.320E-02 3.196E-02 3.069E-02 2.940E-02 2.808E-02 2.675E-02 2.541E-02 2.406E-02 2.270E-02 2.136E-02 2.001E-02 1.869E-02 1.738E-02 1.609E-02 1.483E-02 1.360E-02 1.241E-02 1.126E-02 1.015E-02 9.088E-03 8.076E-03 7.116E-03 6.212E-03 5.365E-03 4.578E-03 3.852E-03 3.188E-03 2.587E-03 2.050E-03 1.577E-03 1.167E-03 8.215E-04 5.381E-04 4.916E-04 7.652E-04 1.102E-03 1.503E-03 1.969E-03 2.499E-03 3.094E-03 3.754E-03 4.477E-03 5.262E-03 6.108E-03 7.012E-03 7.973E-03 8.988E-03 1.005E-02 1.117E-02 1.233E-02 1.353E-02 1.476E-02 1.603E-02 1.733E-02 1.865E-02 1.999E-02 2.134E-02 2.270E-02 2.407E-02 2.543E-02 2.679E-02 2.814E-02 2.947E-02 3.077E-02 3.205E-02 3.330E-02 3.451E-02 3.568E-02 3.681E-02 3.788E-02 3.890E-02 3.986E-02 4.076E-02 4.160E-02 4.237E-02 4.307E-02 4.370E-02 4.425E-02 4.473E-02 4.513E-02 4.545E-02 4.570E-02 4.587E-02 4.596E-02 4.597E-02 4.590E-02 4.576E-02 4.554E-02 4.525E-02 4.489E-02 4.446E-02 4.397E-02 4.341E-02 4.279E-02 4.211E-02 4.138E-02 4.060E-02 3.977E-02 3.890E-02 3.799E-02 3.704E-02 3.606E-02 3.505E-02 3.402E-02 3.296E-02 3.189E-02 3.081E-02 2.972E-02 2.862E-02 2.752E-02 2.642E-02 2.532E-02 2.424E-02 2.316E-02 2.210E-02 2.105E-02 2.002E-02 1.901E-02 1.802E-02 1.706E-02 1.612E-02 1.521E-02 1.433E-02 1.348E-02 1.266E-02 1.187E-02 1.112E-02 1.040E-02 9.706E-03 9.048E-03 8.424E-03 7.832E-03 7.272E-03 6.744E-03 6.247E-03 5.780E-03 5.344E-03 4.936E-03 4.556E-03 4.203E-03 3.877E-03 3.575E-03 3.296E-03 3.041E-03 2.807E-03 2.594E-03 2.400E-03 2.224E-03 2.066E-03 1.924E-03 1.797E-03 1.684E-03 1.585E-03 1.499E-03 1.424E-03 1.361E-03 1.309E-03 1.266E-03 1.234E-03 1.211E-03 1.197E-03 1.193E-03 1.197E-03 1.211E-03 1.234E-03 1.266E-03 1.309E-03 1.361E-03 1.424E-03 1.499E-03 1.585E-03 1.684E-03 1.797E-03 1.924E-03 2.066E-03 2.224E-03 2.400E-03 2.594E-03 2.807E-03 3.041E-03 3.296E-03 3.575E-03 3.877E-03 4.203E-03 4.556E-03 4.936E-03 5.344E-03 5.780E-03 6.247E-03 6.744E-03 7.272E-03 7.832E-03 8.424E-03 9.048E-03 9.706E-03 1.040E-02 1.112E-02 1.187E-02 1.266E-02 1.348E-02 1.433E-02 1.521E-02 1.612E-02 1.706E-02 1.802E-02 1.901E-02 2.002E-02 2.105E-02 2.210E-02 2.316E-02 2.424E-02 2.532E-02 2.642E-02 2.752E-02 2.862E-02 2.972E-02 3.081E-02 3.189E-02 3.296E-02 3.402E-02 3.505E-02 3.606E-02 3.704E-02 3.799E-02 3.890E-02 3.977E-02 4.060E-02 4.138E-02 4.211E-02 4.279E-02 4.341E-02 4.397E-02 4.446E-02 4.489E-02 4.525E-02 4.554E-02 4.576E-02 4.590E-02 4.597E-02 4.596E-02 4.587E-02 4.570E-02 4.545E-02 4.513E-02 4.473E-02 4.425E-02 4.370E-02 4.307E-02 4.237E-02 4.160E-02 4.076E-02 3.986E-02 3.890E-02 3.788E-02 3.681E-02 3.568E-02 3.451E-02 3.330E-02 3.205E-02 3.077E-02 2.947E-02 2.814E-02 2.679E-02 2.543E-02 2.407E-02 2.270E-02 2.134E-02 1.999E-02 1.865E-02 1.733E-02 1.603E-02 1.476E-02 1.353E-02 1.233E-02 1.117E-02 1.005E-02 8.988E-03 7.973E-03 7.012E-03 6.108E-03 5.262E-03 4.477E-03 3.754E-03 3.094E-03 2.499E-03 1.969E-03 1.503E-03 1.102E-03 7.652E-04 7.064E-04 1.033E-03 1.424E-03 1.881E-03 2.404E-03 2.992E-03 3.646E-03 4.364E-03 5.146E-03 5.989E-03 6.893E-03 7.854E-03 8.871E-03 9.940E-03 1.106E-02 1.222E-02 1.343E-02 1.467E-02 1.595E-02 1.726E-02 1.859E-02 1.994E-02 2.130E-02 2.268E-02 2.406E-02 2.543E-02 2.681E-02 2.816E-02 2.951E-02 3.083E-02 3.212E-02 3.338E-02 3.460E-02 3.578E-02 3.691E-02 3.799E-02 3.902E-02 3.999E-02 4.089E-02 4.173E-02 4.250E-02 4.319E-02 4.381E-02 4.436E-02 4.483E-02 4.522E-02 4.553E-02 4.575E-02 4.590E-02 4.597E-02 4.595E-02 4.586E-02 4.569E-02 4.544E-02 4.512E-02 4.472E-02 4.425E-02 4.372E-02 4.312E-02 4.246E-02 4.174E-02 4.096E-02 4.013E-02 3.926E-02 3.834E-02 3.738E-02 3.638E-02 3.535E-02 3.429E-02 3.321E-02 3.211E-02 3.100E-02 2.987E-02 2.873E-02 2.759E-02 2.645E-02 2.531E-02 2.418E-02 2.306E-02 2.195E-02 2.085E-02 1.978E-02 1.872E-02 1.769E-02 1.668E-02 1.571E-02 1.475E-02 1.383E-02 1.295E-02 1.209E-02 1.127E-02 1.048E-02 9.726E-03 9.008E-03 8.326E-03 7.678E-03 7.066E-03 6.489E-03 5.946E-03 5.437E-03 4.961E-03 4.516E-03 4.103E-03 3.721E-03 3.367E-03 3.041E-03 2.742E-03 2.468E-03 2.218E-03 1.991E-03 1.786E-03 1.601E-03 1.434E-03 1.285E-03 1.152E-03 1.035E-03 9.309E-04 8.399E-04 7.605E-04 6.919E-04 6.330E-04 5.831E-04 5.414E-04 5.072E-04 4.801E-04 4.594E-04 4.450E-04 4.364E-04 4.335E-04 4.364E-04 4.450E-04 4.594E-04 4.801E-04 5.072E-04 5.414E-04 5.831E-04 6.330E-04 6.919E-04 7.605E-04 8.399E-04 9.309E-04 1.035E-03 1.152E-03 1.285E-03 1.434E-03 1.601E-03 1.786E-03 1.991E-03 2.218E-03 2.468E-03 2.742E-03 3.041E-03 3.367E-03 3.721E-03 4.103E-03 4.516E-03 4.961E-03 5.437E-03 5.946E-03 6.489E-03 7.066E-03 7.678E-03 8.326E-03 9.008E-03 9.726E-03 1.048E-02 1.127E-02 1.209E-02 1.295E-02 1.383E-02 1.475E-02 1.571E-02 1.668E-02 1.769E-02 1.872E-02 1.978E-02 2.085E-02 2.195E-02 2.306E-02 2.418E-02 2.531E-02 2.645E-02 2.759E-02 2.873E-02 2.987E-02 3.100E-02 3.211E-02 3.321E-02 3.429E-02 3.535E-02 3.638E-02 3.738E-02 3.834E-02 3.926E-02 4.013E-02 4.096E-02 4.174E-02 4.246E-02 4.312E-02 4.372E-02 4.425E-02 4.472E-02 4.512E-02 4.544E-02 4.569E-02 4.586E-02 4.595E-02 4.597E-02 4.590E-02 4.575E-02 4.553E-02 4.522E-02 4.483E-02 4.436E-02 4.381E-02 4.319E-02 4.250E-02 4.173E-02 4.089E-02 3.999E-02 3.902E-02 3.799E-02 3.691E-02 3.578E-02 3.460E-02 3.338E-02 3.212E-02 3.083E-02 2.951E-02 2.816E-02 2.681E-02 2.543E-02 2.406E-02 2.268E-02 2.130E-02 1.994E-02 1.859E-02 1.726E-02 1.595E-02 1.467E-02 1.343E-02 1.222E-02 1.106E-02 9.940E-03 8.871E-03 7.854E-03 6.893E-03 5.989E-03 5.146E-03 4.364E-03 3.646E-03 2.992E-03 2.404E-03 1.881E-03 1.424E-03 1.033E-03 9.609E-04 1.342E-03 1.789E-03 2.302E-03 2.882E-03 3.529E-03 4.241E-03 5.018E-03 5.858E-03 6.759E-03 7.720E-03 8.737E-03 9.807E-03 1.093E-02 1.210E-02 1.331E-02 1.456E-02 1.584E-02 1.716E-02 1.850E-02 1.986E-02 2.124E-02 2.263E-02 2.402E-02 2.541E-02 2.679E-02 2.816E-02 2.952E-02 3.085E-02 3.216E-02 3.343E-02 3.466E-02 3.585E-02 3.699E-02 3.808E-02 3.912E-02 4.009E-02 4.100E-02 4.183E-02 4.260E-02 4.330E-02 4.391E-02 4.445E-02 4.491E-02 4.529E-02 4.559E-02 4.580E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.562E-02 4.534E-02 4.498E-02 4.455E-02 4.405E-02 4.347E-02 4.283E-02 4.213E-02 4.137E-02 4.054E-02 3.967E-02 3.875E-02 3.778E-02 3.678E-02 3.573E-02 3.466E-02 3.355E-02 3.243E-02 3.128E-02 3.012E-02 2.895E-02 2.777E-02 2.659E-02 2.541E-02 2.424E-02 2.307E-02 2.192E-02 2.078E-02 1.965E-02 1.855E-02 1.748E-02 1.643E-02 1.540E-02 1.441E-02 1.345E-02 1.252E-02 1.163E-02 1.077E-02 9.951E-03 9.169E-03 8.424E-03 7.717E-03 7.048E-03 6.417E-03 5.824E-03 5.268E-03 4.749E-03 4.265E-03 3.817E-03 3.402E-03 3.021E-03 2.671E-03 2.351E-03 2.060E-03 1.797E-03 1.559E-03 1.347E-03 1.157E-03 9.884E-04 8.399E-04 7.096E-04 5.962E-04 4.981E-04 4.139E-04 3.421E-04 2.815E-04 2.307E-04 1.886E-04 1.541E-04 1.261E-04 1.036E-04 8.587E-05 7.214E-05 6.178E-05 5.426E-05 4.919E-05 4.626E-05 4.531E-05 4.626E-05 4.919E-05 5.426E-05 6.178E-05 7.214E-05 8.587E-05 1.036E-04 1.261E-04 1.541E-04 1.886E-04 2.307E-04 2.815E-04 3.421E-04 4.139E-04 4.981E-04 5.962E-04 7.096E-04 8.399E-04 9.884E-04 1.157E-03 1.347E-03 1.559E-03 1.797E-03 2.060E-03 2.351E-03 2.671E-03 3.021E-03 3.402E-03 3.817E-03 4.265E-03 4.749E-03 5.268E-03 5.824E-03 6.417E-03 7.048E-03 7.717E-03 8.424E-03 9.169E-03 9.951E-03 1.077E-02 1.163E-02 1.252E-02 1.345E-02 1.441E-02 1.540E-02 1.643E-02 1.748E-02 1.855E-02 1.965E-02 2.078E-02 2.192E-02 2.307E-02 2.424E-02 2.541E-02 2.659E-02 2.777E-02 2.895E-02 3.012E-02 3.128E-02 3.243E-02 3.355E-02 3.466E-02 3.573E-02 3.678E-02 3.778E-02 3.875E-02 3.967E-02 4.054E-02 4.137E-02 4.213E-02 4.283E-02 4.347E-02 4.405E-02 4.455E-02 4.498E-02 4.534E-02 4.562E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.580E-02 4.559E-02 4.529E-02 4.491E-02 4.445E-02 4.391E-02 4.330E-02 4.260E-02 4.183E-02 4.100E-02 4.009E-02 3.912E-02 3.808E-02 3.699E-02 3.585E-02 3.466E-02 3.343E-02 3.216E-02 3.085E-02 2.952E-02 2.816E-02 2.679E-02 2.541E-02 2.402E-02 2.263E-02 2.124E-02 1.986E-02 1.850E-02 1.716E-02 1.584E-02 1.456E-02 1.331E-02 1.210E-02 1.093E-02 9.807E-03 8.737E-03 7.720E-03 6.759E-03 5.858E-03 5.018E-03 4.241E-03 3.529E-03 2.882E-03 2.302E-03 1.789E-03 1.342E-03 1.255E-03 1.691E-03 2.194E-03 2.765E-03 3.403E-03 4.108E-03 4.879E-03 5.714E-03 6.611E-03 7.569E-03 8.586E-03 9.657E-03 1.078E-02 1.195E-02 1.317E-02 1.442E-02 1.572E-02 1.704E-02 1.839E-02 1.976E-02 2.115E-02 2.255E-02 2.395E-02 2.535E-02 2.675E-02 2.814E-02 2.951E-02 3.085E-02 3.217E-02 3.345E-02 3.470E-02 3.590E-02 3.705E-02 3.815E-02 3.919E-02 4.017E-02 4.108E-02 4.192E-02 4.269E-02 4.339E-02 4.400E-02 4.453E-02 4.499E-02 4.535E-02 4.564E-02 4.583E-02 4.594E-02 4.597E-02 4.591E-02 4.577E-02 4.554E-02 4.523E-02 4.485E-02 4.438E-02 4.384E-02 4.323E-02 4.255E-02 4.181E-02 4.100E-02 4.014E-02 3.922E-02 3.826E-02 3.724E-02 3.619E-02 3.510E-02 3.398E-02 3.283E-02 3.166E-02 3.047E-02 2.927E-02 2.806E-02 2.684E-02 2.562E-02 2.440E-02 2.319E-02 2.199E-02 2.081E-02 1.964E-02 1.850E-02 1.737E-02 1.628E-02 1.521E-02 1.418E-02 1.317E-02 1.221E-02 1.128E-02 1.039E-02 9.533E-03 8.719E-03 7.947E-03 7.216E-03 6.525E-03 5.876E-03 5.268E-03 4.700E-03 4.173E-03 3.684E-03 3.234E-03 2.820E-03 2.443E-03 2.101E-03 1.791E-03 1.514E-03 1.266E-03 1.047E-03 8.554E-04 6.883E-04 5.445E-04 4.223E-04 3.197E-04 2.350E-04 1.664E-04 1.123E-04 7.095E-05 4.068E-05 1.993E-05 7.209E-06 1.084E-06 2.162E-07 3.357E-06 9.360E-06 1.718E-05 2.589E-05 3.466E-05 4.280E-05 4.974E-05 5.502E-05 5.831E-05 5.944E-05 5.831E-05 5.502E-05 4.974E-05 4.280E-05 3.466E-05 2.589E-05 1.718E-05 9.360E-06 3.357E-06 2.162E-07 1.084E-06 7.209E-06 1.993E-05 4.068E-05 7.095E-05 1.123E-04 1.664E-04 2.350E-04 3.197E-04 4.223E-04 5.445E-04 6.883E-04 8.554E-04 1.047E-03 1.266E-03 1.514E-03 1.791E-03 2.101E-03 2.443E-03 2.820E-03 3.234E-03 3.684E-03 4.173E-03 4.700E-03 5.268E-03 5.876E-03 6.525E-03 7.216E-03 7.947E-03 8.719E-03 9.533E-03 1.039E-02 1.128E-02 1.221E-02 1.317E-02 1.418E-02 1.521E-02 1.628E-02 1.737E-02 1.850E-02 1.964E-02 2.081E-02 2.199E-02 2.319E-02 2.440E-02 2.562E-02 2.684E-02 2.806E-02 2.927E-02 3.047E-02 3.166E-02 3.283E-02 3.398E-02 3.510E-02 3.619E-02 3.724E-02 3.826E-02 3.922E-02 4.014E-02 4.100E-02 4.181E-02 4.255E-02 4.323E-02 4.384E-02 4.438E-02 4.485E-02 4.523E-02 4.554E-02 4.577E-02 4.591E-02 4.597E-02 4.594E-02 4.583E-02 4.564E-02 4.535E-02 4.499E-02 4.453E-02 4.400E-02 4.339E-02 4.269E-02 4.192E-02 4.108E-02 4.017E-02 3.919E-02 3.815E-02 3.705E-02 3.590E-02 3.470E-02 3.345E-02 3.217E-02 3.085E-02 2.951E-02 2.814E-02 2.675E-02 2.535E-02 2.395E-02 2.255E-02 2.115E-02 1.976E-02 1.839E-02 1.704E-02 1.572E-02 1.442E-02 1.317E-02 1.195E-02 1.078E-02 9.657E-03 8.586E-03 7.569E-03 6.611E-03 5.714E-03 4.879E-03 4.108E-03 3.403E-03 2.765E-03 2.194E-03 1.691E-03 1.589E-03 2.081E-03 2.641E-03 3.269E-03 3.965E-03 4.729E-03 5.557E-03 6.450E-03 7.404E-03 8.418E-03 9.488E-03 1.061E-02 1.179E-02 1.300E-02 1.427E-02 1.556E-02 1.689E-02 1.825E-02 1.963E-02 2.103E-02 2.244E-02 2.386E-02 2.527E-02 2.668E-02 2.808E-02 2.947E-02 3.083E-02 3.216E-02 3.345E-02 3.471E-02 3.593E-02 3.709E-02 3.820E-02 3.925E-02 4.023E-02 4.115E-02 4.199E-02 4.277E-02 4.346E-02 4.407E-02 4.460E-02 4.505E-02 4.541E-02 4.568E-02 4.586E-02 4.596E-02 4.596E-02 4.588E-02 4.572E-02 4.547E-02 4.513E-02 4.471E-02 4.422E-02 4.364E-02 4.300E-02 4.228E-02 4.150E-02 4.065E-02 3.975E-02 3.879E-02 3.778E-02 3.672E-02 3.562E-02 3.449E-02 3.333E-02 3.213E-02 3.092E-02 2.969E-02 2.844E-02 2.719E-02 2.593E-02 2.468E-02 2.343E-02 2.218E-02 2.096E-02 1.974E-02 1.855E-02 1.739E-02 1.625E-02 1.513E-02 1.405E-02 1.301E-02 1.200E-02 1.103E-02 1.011E-02 9.219E-03 8.375E-03 7.574E-03 6.817E-03 6.105E-03 5.437E-03 4.814E-03 4.234E-03 3.699E-03 3.206E-03 2.755E-03 2.345E-03 1.974E-03 1.642E-03 1.347E-03 1.086E-03 8.593E-04 6.639E-04 4.981E-04 3.601E-04 2.478E-04 1.593E-04 9.249E-05 4.531E-05 1.574E-05 1.762E-06 1.402E-06 1.271E-05 3.381E-05 6.286E-05 9.812E-05 1.379E-04 1.807E-04 2.249E-04 2.693E-04 3.124E-04 3.533E-04 3.908E-04 4.241E-04 4.524E-04 4.751E-04 4.916E-04 5.017E-04 5.051E-04 5.017E-04 4.916E-04 4.751E-04 4.524E-04 4.241E-04 3.908E-04 3.533E-04 3.124E-04 2.693E-04 2.249E-04 1.807E-04 1.379E-04 9.812E-05 6.286E-05 3.381E-05 1.271E-05 1.402E-06 1.762E-06 1.574E-05 4.531E-05 9.249E-05 1.593E-04 2.478E-04 3.601E-04 4.981E-04 6.639E-04 8.593E-04 1.086E-03 1.347E-03 1.642E-03 1.974E-03 2.345E-03 2.755E-03 3.206E-03 3.699E-03 4.234E-03 4.814E-03 5.437E-03 6.105E-03 6.817E-03 7.574E-03 8.375E-03 9.219E-03 1.011E-02 1.103E-02 1.200E-02 1.301E-02 1.405E-02 1.513E-02 1.625E-02 1.739E-02 1.855E-02 1.974E-02 2.096E-02 2.218E-02 2.343E-02 2.468E-02 2.593E-02 2.719E-02 2.844E-02 2.969E-02 3.092E-02 3.213E-02 3.333E-02 3.449E-02 3.562E-02 3.672E-02 3.778E-02 3.879E-02 3.975E-02 4.065E-02 4.150E-02 4.228E-02 4.300E-02 4.364E-02 4.422E-02 4.471E-02 4.513E-02 4.547E-02 4.572E-02 4.588E-02 4.596E-02 4.596E-02 4.586E-02 4.568E-02 4.541E-02 4.505E-02 4.460E-02 4.407E-02 4.346E-02 4.277E-02 4.199E-02 4.115E-02 4.023E-02 3.925E-02 3.820E-02 3.709E-02 3.593E-02 3.471E-02 3.345E-02 3.216E-02 3.083E-02 2.947E-02 2.808E-02 2.668E-02 2.527E-02 2.386E-02 2.244E-02 2.103E-02 1.963E-02 1.825E-02 1.689E-02 1.556E-02 1.427E-02 1.300E-02 1.179E-02 1.061E-02 9.488E-03 8.418E-03 7.404E-03 6.450E-03 5.557E-03 4.729E-03 3.965E-03 3.269E-03 2.641E-03 2.081E-03 1.963E-03 2.511E-03 3.128E-03 3.814E-03 4.568E-03 5.389E-03 6.276E-03 7.225E-03 8.235E-03 9.303E-03 1.043E-02 1.160E-02 1.282E-02 1.409E-02 1.539E-02 1.673E-02 1.809E-02 1.948E-02 2.089E-02 2.231E-02 2.374E-02 2.517E-02 2.659E-02 2.800E-02 2.940E-02 3.077E-02 3.212E-02 3.343E-02 3.470E-02 3.593E-02 3.710E-02 3.822E-02 3.928E-02 4.027E-02 4.120E-02 4.205E-02 4.282E-02 4.352E-02 4.413E-02 4.466E-02 4.510E-02 4.545E-02 4.571E-02 4.588E-02 4.596E-02 4.596E-02 4.586E-02 4.567E-02 4.539E-02 4.503E-02 4.458E-02 4.406E-02 4.345E-02 4.277E-02 4.202E-02 4.120E-02 4.031E-02 3.937E-02 3.837E-02 3.731E-02 3.622E-02 3.508E-02 3.390E-02 3.269E-02 3.146E-02 3.020E-02 2.893E-02 2.765E-02 2.635E-02 2.506E-02 2.377E-02 2.249E-02 2.122E-02 1.996E-02 1.872E-02 1.751E-02 1.632E-02 1.517E-02 1.404E-02 1.296E-02 1.191E-02 1.090E-02 9.931E-03 9.008E-03 8.131E-03 7.300E-03 6.516E-03 5.780E-03 5.093E-03 4.453E-03 3.862E-03 3.318E-03 2.820E-03 2.369E-03 1.963E-03 1.601E-03 1.280E-03 1.001E-03 7.605E-04 5.573E-04 3.892E-04 2.544E-04 1.507E-04 7.576E-05 2.751E-05 3.609E-06 1.764E-06 1.967E-05 5.502E-05 1.055E-04 1.690E-04 2.431E-04 3.258E-04 4.149E-04 5.085E-04 6.046E-04 7.014E-04 7.971E-04 8.902E-04 9.791E-04 1.062E-03 1.139E-03 1.208E-03 1.267E-03 1.317E-03 1.357E-03 1.386E-03 1.403E-03 1.409E-03 1.403E-03 1.386E-03 1.357E-03 1.317E-03 1.267E-03 1.208E-03 1.139E-03 1.062E-03 9.791E-04 8.902E-04 7.971E-04 7.014E-04 6.046E-04 5.085E-04 4.149E-04 3.258E-04 2.431E-04 1.690E-04 1.055E-04 5.502E-05 1.967E-05 1.764E-06 3.609E-06 2.751E-05 7.576E-05 1.507E-04 2.544E-04 3.892E-04 5.573E-04 7.605E-04 1.001E-03 1.280E-03 1.601E-03 1.963E-03 2.369E-03 2.820E-03 3.318E-03 3.862E-03 4.453E-03 5.093E-03 5.780E-03 6.516E-03 7.300E-03 8.131E-03 9.008E-03 9.931E-03 1.090E-02 1.191E-02 1.296E-02 1.404E-02 1.517E-02 1.632E-02 1.751E-02 1.872E-02 1.996E-02 2.122E-02 2.249E-02 2.377E-02 2.506E-02 2.635E-02 2.765E-02 2.893E-02 3.020E-02 3.146E-02 3.269E-02 3.390E-02 3.508E-02 3.622E-02 3.731E-02 3.837E-02 3.937E-02 4.031E-02 4.120E-02 4.202E-02 4.277E-02 4.345E-02 4.406E-02 4.458E-02 4.503E-02 4.539E-02 4.567E-02 4.586E-02 4.596E-02 4.596E-02 4.588E-02 4.571E-02 4.545E-02 4.510E-02 4.466E-02 4.413E-02 4.352E-02 4.282E-02 4.205E-02 4.120E-02 4.027E-02 3.928E-02 3.822E-02 3.710E-02 3.593E-02 3.470E-02 3.343E-02 3.212E-02 3.077E-02 2.940E-02 2.800E-02 2.659E-02 2.517E-02 2.374E-02 2.231E-02 2.089E-02 1.948E-02 1.809E-02 1.673E-02 1.539E-02 1.409E-02 1.282E-02 1.160E-02 1.043E-02 9.303E-03 8.235E-03 7.225E-03 6.276E-03 5.389E-03 4.568E-03 3.814E-03 3.128E-03 2.511E-03 2.375E-03 2.980E-03 3.654E-03 4.398E-03 5.210E-03 6.089E-03 7.032E-03 8.037E-03 9.102E-03 1.022E-02 1.140E-02 1.262E-02 1.389E-02 1.519E-02 1.654E-02 1.791E-02 1.931E-02 2.072E-02 2.215E-02 2.359E-02 2.503E-02 2.647E-02 2.790E-02 2.931E-02 3.069E-02 3.205E-02 3.338E-02 3.466E-02 3.590E-02 3.709E-02 3.822E-02 3.929E-02 4.029E-02 4.122E-02 4.208E-02 4.286E-02 4.356E-02 4.417E-02 4.470E-02 4.514E-02 4.548E-02 4.574E-02 4.590E-02 4.597E-02 4.594E-02 4.583E-02 4.562E-02 4.532E-02 4.494E-02 4.446E-02 4.391E-02 4.327E-02 4.256E-02 4.177E-02 4.091E-02 3.999E-02 3.901E-02 3.796E-02 3.687E-02 3.573E-02 3.455E-02 3.333E-02 3.209E-02 3.081E-02 2.951E-02 2.820E-02 2.688E-02 2.555E-02 2.423E-02 2.290E-02 2.159E-02 2.029E-02 1.901E-02 1.775E-02 1.652E-02 1.531E-02 1.414E-02 1.301E-02 1.192E-02 1.087E-02 9.859E-03 8.898E-03 7.986E-03 7.122E-03 6.309E-03 5.548E-03 4.838E-03 4.180E-03 3.575E-03 3.021E-03 2.518E-03 2.066E-03 1.663E-03 1.309E-03 1.001E-03 7.385E-04 5.195E-04 3.421E-04 2.042E-04 1.036E-04 3.801E-05 5.093E-06 2.384E-06 2.738E-05 7.755E-05 1.503E-04 2.431E-04 3.533E-04 4.784E-04 6.158E-04 7.631E-04 9.178E-04 1.078E-03 1.240E-03 1.403E-03 1.565E-03 1.723E-03 1.875E-03 2.021E-03 2.157E-03 2.284E-03 2.399E-03 2.501E-03 2.589E-03 2.662E-03 2.720E-03 2.761E-03 2.786E-03 2.795E-03 2.786E-03 2.761E-03 2.720E-03 2.662E-03 2.589E-03 2.501E-03 2.399E-03 2.284E-03 2.157E-03 2.021E-03 1.875E-03 1.723E-03 1.565E-03 1.403E-03 1.240E-03 1.078E-03 9.178E-04 7.631E-04 6.158E-04 4.784E-04 3.533E-04 2.431E-04 1.503E-04 7.755E-05 2.738E-05 2.384E-06 5.093E-06 3.801E-05 1.036E-04 2.042E-04 3.421E-04 5.195E-04 7.385E-04 1.001E-03 1.309E-03 1.663E-03 2.066E-03 2.518E-03 3.021E-03 3.575E-03 4.180E-03 4.838E-03 5.548E-03 6.309E-03 7.122E-03 7.986E-03 8.898E-03 9.859E-03 1.087E-02 1.192E-02 1.301E-02 1.414E-02 1.531E-02 1.652E-02 1.775E-02 1.901E-02 2.029E-02 2.159E-02 2.290E-02 2.423E-02 2.555E-02 2.688E-02 2.820E-02 2.951E-02 3.081E-02 3.209E-02 3.333E-02 3.455E-02 3.573E-02 3.687E-02 3.796E-02 3.901E-02 3.999E-02 4.091E-02 4.177E-02 4.256E-02 4.327E-02 4.391E-02 4.446E-02 4.494E-02 4.532E-02 4.562E-02 4.583E-02 4.594E-02 4.597E-02 4.590E-02 4.574E-02 4.548E-02 4.514E-02 4.470E-02 4.417E-02 4.356E-02 4.286E-02 4.208E-02 4.122E-02 4.029E-02 3.929E-02 3.822E-02 3.709E-02 3.590E-02 3.466E-02 3.338E-02 3.205E-02 3.069E-02 2.931E-02 2.790E-02 2.647E-02 2.503E-02 2.359E-02 2.215E-02 2.072E-02 1.931E-02 1.791E-02 1.654E-02 1.519E-02 1.389E-02 1.262E-02 1.140E-02 1.022E-02 9.102E-03 8.037E-03 7.032E-03 6.089E-03 5.210E-03 4.398E-03 3.654E-03 2.980E-03 2.826E-03 3.488E-03 4.220E-03 5.021E-03 5.891E-03 6.826E-03 7.825E-03 8.884E-03 1.000E-02 1.117E-02 1.240E-02 1.366E-02 1.497E-02 1.632E-02 1.770E-02 1.911E-02 2.053E-02 2.197E-02 2.342E-02 2.487E-02 2.632E-02 2.776E-02 2.919E-02 3.059E-02 3.196E-02 3.330E-02 3.460E-02 3.585E-02 3.705E-02 3.820E-02 3.928E-02 4.029E-02 4.123E-02 4.210E-02 4.289E-02 4.359E-02 4.420E-02 4.473E-02 4.517E-02 4.551E-02 4.576E-02 4.591E-02 4.597E-02 4.593E-02 4.580E-02 4.558E-02 4.526E-02 4.485E-02 4.435E-02 4.377E-02 4.310E-02 4.236E-02 4.154E-02 4.064E-02 3.969E-02 3.866E-02 3.758E-02 3.645E-02 3.527E-02 3.405E-02 3.280E-02 3.151E-02 3.019E-02 2.886E-02 2.751E-02 2.615E-02 2.479E-02 2.343E-02 2.207E-02 2.073E-02 1.940E-02 1.810E-02 1.682E-02 1.557E-02 1.435E-02 1.317E-02 1.204E-02 1.094E-02 9.890E-03 8.888E-03 7.937E-03 7.039E-03 6.193E-03 5.403E-03 4.668E-03 3.989E-03 3.367E-03 2.801E-03 2.290E-03 1.835E-03 1.434E-03 1.086E-03 7.903E-04 5.445E-04 3.472E-04 1.963E-04 8.981E-05 2.532E-05 4.667E-07 1.271E-05 5.944E-05 1.379E-04 2.454E-04 3.791E-04 5.360E-04 7.135E-04 9.085E-04 1.118E-03 1.340E-03 1.571E-03 1.808E-03 2.049E-03 2.291E-03 2.532E-03 2.770E-03 3.001E-03 3.224E-03 3.437E-03 3.639E-03 3.826E-03 3.998E-03 4.153E-03 4.291E-03 4.409E-03 4.506E-03 4.583E-03 4.639E-03 4.672E-03 4.683E-03 4.672E-03 4.639E-03 4.583E-03 4.506E-03 4.409E-03 4.291E-03 4.153E-03 3.998E-03 3.826E-03 3.639E-03 3.437E-03 3.224E-03 3.001E-03 2.770E-03 2.532E-03 2.291E-03 2.049E-03 1.808E-03 1.571E-03 1.340E-03 1.118E-03 9.085E-04 7.135E-04 5.360E-04 3.791E-04 2.454E-04 1.379E-04 5.944E-05 1.271E-05 4.667E-07 2.532E-05 8.981E-05 1.963E-04 3.472E-04 5.445E-04 7.903E-04 1.086E-03 1.434E-03 1.835E-03 2.290E-03 2.801E-03 3.367E-03 3.989E-03 4.668E-03 5.403E-03 6.193E-03 7.039E-03 7.937E-03 8.888E-03 9.890E-03 1.094E-02 1.204E-02 1.317E-02 1.435E-02 1.557E-02 1.682E-02 1.810E-02 1.940E-02 2.073E-02 2.207E-02 2.343E-02 2.479E-02 2.615E-02 2.751E-02 2.886E-02 3.019E-02 3.151E-02 3.280E-02 3.405E-02 3.527E-02 3.645E-02 3.758E-02 3.866E-02 3.969E-02 4.064E-02 4.154E-02 4.236E-02 4.310E-02 4.377E-02 4.435E-02 4.485E-02 4.526E-02 4.558E-02 4.580E-02 4.593E-02 4.597E-02 4.591E-02 4.576E-02 4.551E-02 4.517E-02 4.473E-02 4.420E-02 4.359E-02 4.289E-02 4.210E-02 4.123E-02 4.029E-02 3.928E-02 3.820E-02 3.705E-02 3.585E-02 3.460E-02 3.330E-02 3.196E-02 3.059E-02 2.919E-02 2.776E-02 2.632E-02 2.487E-02 2.342E-02 2.197E-02 2.053E-02 1.911E-02 1.770E-02 1.632E-02 1.497E-02 1.366E-02 1.240E-02 1.117E-02 1.000E-02 8.884E-03 7.825E-03 6.826E-03 5.891E-03 5.021E-03 4.220E-03 3.488E-03 3.314E-03 4.033E-03 4.823E-03 5.682E-03 6.608E-03 7.599E-03 8.652E-03 9.765E-03 1.093E-02 1.215E-02 1.342E-02 1.473E-02 1.609E-02 1.747E-02 1.888E-02 2.031E-02 2.176E-02 2.322E-02 2.469E-02 2.615E-02 2.760E-02 2.904E-02 3.046E-02 3.184E-02 3.320E-02 3.451E-02 3.578E-02 3.699E-02 3.815E-02 3.925E-02 4.027E-02 4.122E-02 4.210E-02 4.289E-02 4.360E-02 4.422E-02 4.475E-02 4.519E-02 4.553E-02 4.578E-02 4.592E-02 4.597E-02 4.592E-02 4.578E-02 4.554E-02 4.520E-02 4.477E-02 4.425E-02 4.364E-02 4.295E-02 4.217E-02 4.132E-02 4.039E-02 3.940E-02 3.834E-02 3.723E-02 3.606E-02 3.484E-02 3.358E-02 3.229E-02 3.096E-02 2.961E-02 2.823E-02 2.685E-02 2.545E-02 2.406E-02 2.267E-02 2.128E-02 1.991E-02 1.856E-02 1.724E-02 1.594E-02 1.468E-02 1.345E-02 1.226E-02 1.112E-02 1.002E-02 8.978E-03 7.986E-03 7.048E-03 6.167E-03 5.344E-03 4.580E-03 3.877E-03 3.234E-03 2.651E-03 2.130E-03 1.668E-03 1.266E-03 9.228E-04 6.364E-04 4.056E-04 2.286E-04 1.036E-04 2.826E-05 2.914E-07 1.718E-05 7.627E-05 1.748E-04 3.098E-04 4.784E-04 6.775E-04 9.039E-04 1.155E-03 1.426E-03 1.716E-03 2.021E-03 2.337E-03 2.662E-03 2.992E-03 3.325E-03 3.658E-03 3.988E-03 4.312E-03 4.628E-03 4.933E-03 5.225E-03 5.502E-03 5.762E-03 6.003E-03 6.223E-03 6.421E-03 6.595E-03 6.745E-03 6.869E-03 6.966E-03 7.036E-03 7.078E-03 7.092E-03 7.078E-03 7.036E-03 6.966E-03 6.869E-03 6.745E-03 6.595E-03 6.421E-03 6.223E-03 6.003E-03 5.762E-03 5.502E-03 5.225E-03 4.933E-03 4.628E-03 4.312E-03 3.988E-03 3.658E-03 3.325E-03 2.992E-03 2.662E-03 2.337E-03 2.021E-03 1.716E-03 1.426E-03 1.155E-03 9.039E-04 6.775E-04 4.784E-04 3.098E-04 1.748E-04 7.627E-05 1.718E-05 2.914E-07 2.826E-05 1.036E-04 2.286E-04 4.056E-04 6.364E-04 9.228E-04 1.266E-03 1.668E-03 2.130E-03 2.651E-03 3.234E-03 3.877E-03 4.580E-03 5.344E-03 6.167E-03 7.048E-03 7.986E-03 8.978E-03 1.002E-02 1.112E-02 1.226E-02 1.345E-02 1.468E-02 1.594E-02 1.724E-02 1.856E-02 1.991E-02 2.128E-02 2.267E-02 2.406E-02 2.545E-02 2.685E-02 2.823E-02 2.961E-02 3.096E-02 3.229E-02 3.358E-02 3.484E-02 3.606E-02 3.723E-02 3.834E-02 3.940E-02 4.039E-02 4.132E-02 4.217E-02 4.295E-02 4.364E-02 4.425E-02 4.477E-02 4.520E-02 4.554E-02 4.578E-02 4.592E-02 4.597E-02 4.592E-02 4.578E-02 4.553E-02 4.519E-02 4.475E-02 4.422E-02 4.360E-02 4.289E-02 4.210E-02 4.122E-02 4.027E-02 3.925E-02 3.815E-02 3.699E-02 3.578E-02 3.451E-02 3.320E-02 3.184E-02 3.046E-02 2.904E-02 2.760E-02 2.615E-02 2.469E-02 2.322E-02 2.176E-02 2.031E-02 1.888E-02 1.747E-02 1.609E-02 1.473E-02 1.342E-02 1.215E-02 1.093E-02 9.765E-03 8.652E-03 7.599E-03 6.608E-03 5.682E-03 4.823E-03 4.033E-03 3.840E-03 4.616E-03 5.463E-03 6.378E-03 7.359E-03 8.405E-03 9.512E-03 1.068E-02 1.189E-02 1.316E-02 1.447E-02 1.583E-02 1.721E-02 1.863E-02 2.007E-02 2.153E-02 2.300E-02 2.448E-02 2.595E-02 2.741E-02 2.887E-02 3.030E-02 3.170E-02 3.307E-02 3.440E-02 3.568E-02 3.691E-02 3.808E-02 3.919E-02 4.023E-02 4.120E-02 4.208E-02 4.289E-02 4.360E-02 4.423E-02 4.476E-02 4.520E-02 4.554E-02 4.579E-02 4.593E-02 4.597E-02 4.591E-02 4.576E-02 4.550E-02 4.515E-02 4.470E-02 4.416E-02 4.352E-02 4.280E-02 4.200E-02 4.112E-02 4.016E-02 3.914E-02 3.805E-02 3.690E-02 3.569E-02 3.444E-02 3.314E-02 3.181E-02 3.044E-02 2.905E-02 2.765E-02 2.622E-02 2.480E-02 2.337E-02 2.195E-02 2.054E-02 1.914E-02 1.777E-02 1.643E-02 1.511E-02 1.383E-02 1.260E-02 1.140E-02 1.026E-02 9.169E-03 8.131E-03 7.150E-03 6.229E-03 5.369E-03 4.572E-03 3.839E-03 3.171E-03 2.568E-03 2.031E-03 1.559E-03 1.152E-03 8.092E-04 5.289E-04 3.099E-04 1.507E-04 4.919E-05 3.342E-06 1.073E-05 6.879E-05 1.748E-04 3.258E-04 5.187E-04 7.505E-04 1.018E-03 1.317E-03 1.646E-03 2.000E-03 2.375E-03 2.770E-03 3.179E-03 3.600E-03 4.029E-03 4.463E-03 4.898E-03 5.332E-03 5.762E-03 6.184E-03 6.595E-03 6.994E-03 7.376E-03 7.741E-03 8.084E-03 8.406E-03 8.703E-03 8.973E-03 9.215E-03 9.428E-03 9.611E-03 9.762E-03 9.880E-03 9.965E-03 1.002E-02 1.003E-02 1.002E-02 9.965E-03 9.880E-03 9.762E-03 9.611E-03 9.428E-03 9.215E-03 8.973E-03 8.703E-03 8.406E-03 8.084E-03 7.741E-03 7.376E-03 6.994E-03 6.595E-03 6.184E-03 5.762E-03 5.332E-03 4.898E-03 4.463E-03 4.029E-03 3.600E-03 3.179E-03 2.770E-03 2.375E-03 2.000E-03 1.646E-03 1.317E-03 1.018E-03 7.505E-04 5.187E-04 3.258E-04 1.748E-04 6.879E-05 1.073E-05 3.342E-06 4.919E-05 1.507E-04 3.099E-04 5.289E-04 8.092E-04 1.152E-03 1.559E-03 2.031E-03 2.568E-03 3.171E-03 3.839E-03 4.572E-03 5.369E-03 6.229E-03 7.150E-03 8.131E-03 9.169E-03 1.026E-02 1.140E-02 1.260E-02 1.383E-02 1.511E-02 1.643E-02 1.777E-02 1.914E-02 2.054E-02 2.195E-02 2.337E-02 2.480E-02 2.622E-02 2.765E-02 2.905E-02 3.044E-02 3.181E-02 3.314E-02 3.444E-02 3.569E-02 3.690E-02 3.805E-02 3.914E-02 4.016E-02 4.112E-02 4.200E-02 4.280E-02 4.352E-02 4.416E-02 4.470E-02 4.515E-02 4.550E-02 4.576E-02 4.591E-02 4.597E-02 4.593E-02 4.579E-02 4.554E-02 4.520E-02 4.476E-02 4.423E-02 4.360E-02 4.289E-02 4.208E-02 4.120E-02 4.023E-02 3.919E-02 3.808E-02 3.691E-02 3.568E-02 3.440E-02 3.307E-02 3.170E-02 3.030E-02 2.887E-02 2.741E-02 2.595E-02 2.448E-02 2.300E-02 2.153E-02 2.007E-02 1.863E-02 1.721E-02 1.583E-02 1.447E-02 1.316E-02 1.189E-02 1.068E-02 9.512E-03 8.405E-03 7.359E-03 6.378E-03 5.463E-03 4.616E-03 4.402E-03 5.234E-03 6.137E-03 7.108E-03 8.145E-03 9.244E-03 1.040E-02 1.162E-02 1.288E-02 1.419E-02 1.555E-02 1.694E-02 1.836E-02 1.981E-02 2.127E-02 2.275E-02 2.424E-02 2.572E-02 2.720E-02 2.867E-02 3.011E-02 3.153E-02 3.292E-02 3.426E-02 3.556E-02 3.681E-02 3.799E-02 3.912E-02 4.017E-02 4.115E-02 4.205E-02 4.286E-02 4.359E-02 4.422E-02 4.476E-02 4.521E-02 4.555E-02 4.579E-02 4.593E-02 4.597E-02 4.591E-02 4.574E-02 4.547E-02 4.510E-02 4.464E-02 4.408E-02 4.342E-02 4.268E-02 4.185E-02 4.094E-02 3.996E-02 3.890E-02 3.778E-02 3.659E-02 3.535E-02 3.406E-02 3.273E-02 3.136E-02 2.996E-02 2.854E-02 2.709E-02 2.564E-02 2.418E-02 2.272E-02 2.127E-02 1.984E-02 1.842E-02 1.702E-02 1.566E-02 1.433E-02 1.304E-02 1.180E-02 1.060E-02 9.461E-03 8.375E-03 7.347E-03 6.381E-03 5.479E-03 4.644E-03 3.877E-03 3.178E-03 2.550E-03 1.991E-03 1.504E-03 1.086E-03 7.385E-04 4.594E-04 2.478E-04 1.022E-04 2.057E-05 9.375E-07 4.092E-05 1.379E-04 2.892E-04 4.916E-04 7.422E-04 1.038E-03 1.374E-03 1.749E-03 2.157E-03 2.597E-03 3.063E-03 3.552E-03 4.060E-03 4.583E-03 5.119E-03 5.662E-03 6.210E-03 6.759E-03 7.304E-03 7.844E-03 8.375E-03 8.893E-03 9.396E-03 9.880E-03 1.034E-02 1.078E-02 1.120E-02 1.158E-02 1.194E-02 1.226E-02 1.255E-02 1.280E-02 1.302E-02 1.319E-02 1.333E-02 1.344E-02 1.350E-02 1.352E-02 1.350E-02 1.344E-02 1.333E-02 1.319E-02 1.302E-02 1.280E-02 1.255E-02 1.226E-02 1.194E-02 1.158E-02 1.120E-02 1.078E-02 1.034E-02 9.880E-03 9.396E-03 8.893E-03 8.375E-03 7.844E-03 7.304E-03 6.759E-03 6.210E-03 5.662E-03 5.119E-03 4.583E-03 4.060E-03 3.552E-03 3.063E-03 2.597E-03 2.157E-03 1.749E-03 1.374E-03 1.038E-03 7.422E-04 4.916E-04 2.892E-04 1.379E-04 4.092E-05 9.375E-07 2.057E-05 1.022E-04 2.478E-04 4.594E-04 7.385E-04 1.086E-03 1.504E-03 1.991E-03 2.550E-03 3.178E-03 3.877E-03 4.644E-03 5.479E-03 6.381E-03 7.347E-03 8.375E-03 9.461E-03 1.060E-02 1.180E-02 1.304E-02 1.433E-02 1.566E-02 1.702E-02 1.842E-02 1.984E-02 2.127E-02 2.272E-02 2.418E-02 2.564E-02 2.709E-02 2.854E-02 2.996E-02 3.136E-02 3.273E-02 3.406E-02 3.535E-02 3.659E-02 3.778E-02 3.890E-02 3.996E-02 4.094E-02 4.185E-02 4.268E-02 4.342E-02 4.408E-02 4.464E-02 4.510E-02 4.547E-02 4.574E-02 4.591E-02 4.597E-02 4.593E-02 4.579E-02 4.555E-02 4.521E-02 4.476E-02 4.422E-02 4.359E-02 4.286E-02 4.205E-02 4.115E-02 4.017E-02 3.912E-02 3.799E-02 3.681E-02 3.556E-02 3.426E-02 3.292E-02 3.153E-02 3.011E-02 2.867E-02 2.720E-02 2.572E-02 2.424E-02 2.275E-02 2.127E-02 1.981E-02 1.836E-02 1.694E-02 1.555E-02 1.419E-02 1.288E-02 1.162E-02 1.040E-02 9.244E-03 8.145E-03 7.108E-03 6.137E-03 5.234E-03 4.998E-03 5.887E-03 6.846E-03 7.871E-03 8.961E-03 1.011E-02 1.132E-02 1.258E-02 1.389E-02 1.525E-02 1.664E-02 1.806E-02 1.951E-02 2.099E-02 2.247E-02 2.397E-02 2.547E-02 2.696E-02 2.844E-02 2.990E-02 3.133E-02 3.273E-02 3.410E-02 3.541E-02 3.668E-02 3.788E-02 3.902E-02 4.009E-02 4.108E-02 4.199E-02 4.282E-02 4.356E-02 4.420E-02 4.475E-02 4.520E-02 4.555E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.573E-02 4.545E-02 4.507E-02 4.459E-02 4.401E-02 4.334E-02 4.257E-02 4.172E-02 4.079E-02 3.977E-02 3.869E-02 3.753E-02 3.631E-02 3.504E-02 3.372E-02 3.235E-02 3.095E-02 2.951E-02 2.806E-02 2.658E-02 2.509E-02 2.360E-02 2.212E-02 2.064E-02 1.918E-02 1.774E-02 1.632E-02 1.494E-02 1.360E-02 1.230E-02 1.106E-02 9.859E-03 8.719E-03 7.640E-03 6.625E-03 5.677E-03 4.797E-03 3.989E-03 3.254E-03 2.594E-03 2.008E-03 1.499E-03 1.065E-03 7.061E-04 4.223E-04 2.122E-04 7.455E-05 7.597E-06 9.360E-06 7.755E-05 2.096E-04 4.028E-04 6.540E-04 9.600E-04 1.317E-03 1.723E-03 2.172E-03 2.662E-03 3.188E-03 3.746E-03 4.333E-03 4.944E-03 5.576E-03 6.223E-03 6.882E-03 7.550E-03 8.221E-03 8.893E-03 9.561E-03 1.022E-02 1.087E-02 1.151E-02 1.212E-02 1.272E-02 1.329E-02 1.384E-02 1.436E-02 1.484E-02 1.529E-02 1.571E-02 1.608E-02 1.642E-02 1.671E-02 1.697E-02 1.717E-02 1.734E-02 1.745E-02 1.752E-02 1.755E-02 1.752E-02 1.745E-02 1.734E-02 1.717E-02 1.697E-02 1.671E-02 1.642E-02 1.608E-02 1.571E-02 1.529E-02 1.484E-02 1.436E-02 1.384E-02 1.329E-02 1.272E-02 1.212E-02 1.151E-02 1.087E-02 1.022E-02 9.561E-03 8.893E-03 8.221E-03 7.550E-03 6.882E-03 6.223E-03 5.576E-03 4.944E-03 4.333E-03 3.746E-03 3.188E-03 2.662E-03 2.172E-03 1.723E-03 1.317E-03 9.600E-04 6.540E-04 4.028E-04 2.096E-04 7.755E-05 9.360E-06 7.597E-06 7.455E-05 2.122E-04 4.223E-04 7.061E-04 1.065E-03 1.499E-03 2.008E-03 2.594E-03 3.254E-03 3.989E-03 4.797E-03 5.677E-03 6.625E-03 7.640E-03 8.719E-03 9.859E-03 1.106E-02 1.230E-02 1.360E-02 1.494E-02 1.632E-02 1.774E-02 1.918E-02 2.064E-02 2.212E-02 2.360E-02 2.509E-02 2.658E-02 2.806E-02 2.951E-02 3.095E-02 3.235E-02 3.372E-02 3.504E-02 3.631E-02 3.753E-02 3.869E-02 3.977E-02 4.079E-02 4.172E-02 4.257E-02 4.334E-02 4.401E-02 4.459E-02 4.507E-02 4.545E-02 4.573E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.555E-02 4.520E-02 4.475E-02 4.420E-02 4.356E-02 4.282E-02 4.199E-02 4.108E-02 4.009E-02 3.902E-02 3.788E-02 3.668E-02 3.541E-02 3.410E-02 3.273E-02 3.133E-02 2.990E-02 2.844E-02 2.696E-02 2.547E-02 2.397E-02 2.247E-02 2.099E-02 1.951E-02 1.806E-02 1.664E-02 1.525E-02 1.389E-02 1.258E-02 1.132E-02 1.011E-02 8.961E-03 7.871E-03 6.846E-03 5.887E-03 5.628E-03 6.573E-03 7.586E-03 8.665E-03 9.807E-03 1.101E-02 1.226E-02 1.357E-02 1.492E-02 1.632E-02 1.774E-02 1.920E-02 2.068E-02 2.217E-02 2.368E-02 2.519E-02 2.669E-02 2.818E-02 2.966E-02 3.111E-02 3.253E-02 3.391E-02 3.524E-02 3.652E-02 3.774E-02 3.890E-02 3.999E-02 4.100E-02 4.192E-02 4.277E-02 4.352E-02 4.417E-02 4.473E-02 4.519E-02 4.554E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.504E-02 4.455E-02 4.396E-02 4.327E-02 4.248E-02 4.161E-02 4.065E-02 3.961E-02 3.850E-02 3.731E-02 3.607E-02 3.476E-02 3.341E-02 3.201E-02 3.057E-02 2.910E-02 2.761E-02 2.611E-02 2.459E-02 2.307E-02 2.155E-02 2.005E-02 1.856E-02 1.710E-02 1.567E-02 1.428E-02 1.292E-02 1.162E-02 1.036E-02 9.169E-03 8.034E-03 6.964E-03 5.964E-03 5.035E-03 4.180E-03 3.402E-03 2.703E-03 2.083E-03 1.544E-03 1.086E-03 7.096E-04 4.139E-04 1.983E-04 6.178E-05 2.840E-06 1.967E-05 1.101E-04 2.717E-04 5.017E-04 7.971E-04 1.155E-03 1.571E-03 2.042E-03 2.564E-03 3.134E-03 3.746E-03 4.398E-03 5.084E-03 5.800E-03 6.541E-03 7.304E-03 8.084E-03 8.877E-03 9.678E-03 1.048E-02 1.129E-02 1.209E-02 1.288E-02 1.366E-02 1.442E-02 1.516E-02 1.588E-02 1.658E-02 1.724E-02 1.787E-02 1.847E-02 1.903E-02 1.955E-02 2.002E-02 2.045E-02 2.084E-02 2.117E-02 2.146E-02 2.170E-02 2.188E-02 2.201E-02 2.209E-02 2.212E-02 2.209E-02 2.201E-02 2.188E-02 2.170E-02 2.146E-02 2.117E-02 2.084E-02 2.045E-02 2.002E-02 1.955E-02 1.903E-02 1.847E-02 1.787E-02 1.724E-02 1.658E-02 1.588E-02 1.516E-02 1.442E-02 1.366E-02 1.288E-02 1.209E-02 1.129E-02 1.048E-02 9.678E-03 8.877E-03 8.084E-03 7.304E-03 6.541E-03 5.800E-03 5.084E-03 4.398E-03 3.746E-03 3.134E-03 2.564E-03 2.042E-03 1.571E-03 1.155E-03 7.971E-04 5.017E-04 2.717E-04 1.101E-04 1.967E-05 2.840E-06 6.178E-05 1.983E-04 4.139E-04 7.096E-04 1.086E-03 1.544E-03 2.083E-03 2.703E-03 3.402E-03 4.180E-03 5.035E-03 5.964E-03 6.964E-03 8.034E-03 9.169E-03 1.036E-02 1.162E-02 1.292E-02 1.428E-02 1.567E-02 1.710E-02 1.856E-02 2.005E-02 2.155E-02 2.307E-02 2.459E-02 2.611E-02 2.761E-02 2.910E-02 3.057E-02 3.201E-02 3.341E-02 3.476E-02 3.607E-02 3.731E-02 3.850E-02 3.961E-02 4.065E-02 4.161E-02 4.248E-02 4.327E-02 4.396E-02 4.455E-02 4.504E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.554E-02 4.519E-02 4.473E-02 4.417E-02 4.352E-02 4.277E-02 4.192E-02 4.100E-02 3.999E-02 3.890E-02 3.774E-02 3.652E-02 3.524E-02 3.391E-02 3.253E-02 3.111E-02 2.966E-02 2.818E-02 2.669E-02 2.519E-02 2.368E-02 2.217E-02 2.068E-02 1.920E-02 1.774E-02 1.632E-02 1.492E-02 1.357E-02 1.226E-02 1.101E-02 9.807E-03 8.665E-03 7.586E-03 6.573E-03 6.291E-03 7.290E-03 8.357E-03 9.488E-03 1.068E-02 1.193E-02 1.323E-02 1.458E-02 1.597E-02 1.740E-02 1.886E-02 2.035E-02 2.185E-02 2.336E-02 2.488E-02 2.640E-02 2.790E-02 2.939E-02 3.086E-02 3.229E-02 3.369E-02 3.504E-02 3.634E-02 3.758E-02 3.876E-02 3.986E-02 4.089E-02 4.183E-02 4.269E-02 4.346E-02 4.413E-02 4.470E-02 4.517E-02 4.553E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.503E-02 4.452E-02 4.392E-02 4.321E-02 4.241E-02 4.152E-02 4.054E-02 3.948E-02 3.834E-02 3.713E-02 3.585E-02 3.452E-02 3.313E-02 3.170E-02 3.023E-02 2.873E-02 2.721E-02 2.567E-02 2.413E-02 2.258E-02 2.104E-02 1.951E-02 1.800E-02 1.652E-02 1.507E-02 1.366E-02 1.229E-02 1.098E-02 9.726E-03 8.532E-03 7.403E-03 6.345E-03 5.361E-03 4.453E-03 3.625E-03 2.880E-03 2.218E-03 1.642E-03 1.152E-03 7.495E-04 4.335E-04 2.042E-04 6.067E-05 1.762E-06 2.589E-05 1.311E-04 3.151E-04 5.752E-04 9.085E-04 1.312E-03 1.782E-03 2.314E-03 2.906E-03 3.552E-03 4.248E-03 4.991E-03 5.774E-03 6.595E-03 7.448E-03 8.329E-03 9.232E-03 1.015E-02 1.109E-02 1.203E-02 1.298E-02 1.392E-02 1.486E-02 1.580E-02 1.671E-02 1.762E-02 1.849E-02 1.935E-02 2.017E-02 2.097E-02 2.172E-02 2.244E-02 2.312E-02 2.375E-02 2.434E-02 2.487E-02 2.536E-02 2.579E-02 2.617E-02 2.650E-02 2.676E-02 2.697E-02 2.712E-02 2.721E-02 2.724E-02 2.721E-02 2.712E-02 2.697E-02 2.676E-02 2.650E-02 2.617E-02 2.579E-02 2.536E-02 2.487E-02 2.434E-02 2.375E-02 2.312E-02 2.244E-02 2.172E-02 2.097E-02 2.017E-02 1.935E-02 1.849E-02 1.762E-02 1.671E-02 1.580E-02 1.486E-02 1.392E-02 1.298E-02 1.203E-02 1.109E-02 1.015E-02 9.232E-03 8.329E-03 7.448E-03 6.595E-03 5.774E-03 4.991E-03 4.248E-03 3.552E-03 2.906E-03 2.314E-03 1.782E-03 1.312E-03 9.085E-04 5.752E-04 3.151E-04 1.311E-04 2.589E-05 1.762E-06 6.067E-05 2.042E-04 4.335E-04 7.495E-04 1.152E-03 1.642E-03 2.218E-03 2.880E-03 3.625E-03 4.453E-03 5.361E-03 6.345E-03 7.403E-03 8.532E-03 9.726E-03 1.098E-02 1.229E-02 1.366E-02 1.507E-02 1.652E-02 1.800E-02 1.951E-02 2.104E-02 2.258E-02 2.413E-02 2.567E-02 2.721E-02 2.873E-02 3.023E-02 3.170E-02 3.313E-02 3.452E-02 3.585E-02 3.713E-02 3.834E-02 3.948E-02 4.054E-02 4.152E-02 4.241E-02 4.321E-02 4.392E-02 4.452E-02 4.503E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.553E-02 4.517E-02 4.470E-02 4.413E-02 4.346E-02 4.269E-02 4.183E-02 4.089E-02 3.986E-02 3.876E-02 3.758E-02 3.634E-02 3.504E-02 3.369E-02 3.229E-02 3.086E-02 2.939E-02 2.790E-02 2.640E-02 2.488E-02 2.336E-02 2.185E-02 2.035E-02 1.886E-02 1.740E-02 1.597E-02 1.458E-02 1.323E-02 1.193E-02 1.068E-02 9.488E-03 8.357E-03 7.290E-03 6.984E-03 8.037E-03 9.157E-03 1.034E-02 1.158E-02 1.288E-02 1.422E-02 1.561E-02 1.704E-02 1.850E-02 1.999E-02 2.150E-02 2.302E-02 2.455E-02 2.608E-02 2.760E-02 2.910E-02 3.058E-02 3.203E-02 3.345E-02 3.482E-02 3.614E-02 3.740E-02 3.859E-02 3.972E-02 4.076E-02 4.173E-02 4.260E-02 4.339E-02 4.407E-02 4.466E-02 4.514E-02 4.551E-02 4.578E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.502E-02 4.451E-02 4.390E-02 4.318E-02 4.236E-02 4.145E-02 4.045E-02 3.937E-02 3.820E-02 3.697E-02 3.567E-02 3.430E-02 3.289E-02 3.143E-02 2.993E-02 2.840E-02 2.685E-02 2.528E-02 2.370E-02 2.213E-02 2.056E-02 1.901E-02 1.748E-02 1.597E-02 1.451E-02 1.309E-02 1.171E-02 1.040E-02 9.139E-03 7.947E-03 6.826E-03 5.780E-03 4.814E-03 3.929E-03 3.130E-03 2.418E-03 1.797E-03 1.266E-03 8.283E-04 4.831E-04 2.307E-04 7.095E-05 2.840E-06 2.515E-05 1.362E-04 3.339E-04 6.158E-04 9.791E-04 1.421E-03 1.937E-03 2.524E-03 3.179E-03 3.896E-03 4.672E-03 5.502E-03 6.381E-03 7.304E-03 8.267E-03 9.264E-03 1.029E-02 1.134E-02 1.241E-02 1.350E-02 1.459E-02 1.569E-02 1.678E-02 1.787E-02 1.896E-02 2.002E-02 2.107E-02 2.209E-02 2.309E-02 2.406E-02 2.499E-02 2.588E-02 2.673E-02 2.754E-02 2.830E-02 2.900E-02 2.966E-02 3.026E-02 3.080E-02 3.128E-02 3.170E-02 3.206E-02 3.236E-02 3.259E-02 3.275E-02 3.285E-02 3.288E-02 3.285E-02 3.275E-02 3.259E-02 3.236E-02 3.206E-02 3.170E-02 3.128E-02 3.080E-02 3.026E-02 2.966E-02 2.900E-02 2.830E-02 2.754E-02 2.673E-02 2.588E-02 2.499E-02 2.406E-02 2.309E-02 2.209E-02 2.107E-02 2.002E-02 1.896E-02 1.787E-02 1.678E-02 1.569E-02 1.459E-02 1.350E-02 1.241E-02 1.134E-02 1.029E-02 9.264E-03 8.267E-03 7.304E-03 6.381E-03 5.502E-03 4.672E-03 3.896E-03 3.179E-03 2.524E-03 1.937E-03 1.421E-03 9.791E-04 6.158E-04 3.339E-04 1.362E-04 2.515E-05 2.840E-06 7.095E-05 2.307E-04 4.831E-04 8.283E-04 1.266E-03 1.797E-03 2.418E-03 3.130E-03 3.929E-03 4.814E-03 5.780E-03 6.826E-03 7.947E-03 9.139E-03 1.040E-02 1.171E-02 1.309E-02 1.451E-02 1.597E-02 1.748E-02 1.901E-02 2.056E-02 2.213E-02 2.370E-02 2.528E-02 2.685E-02 2.840E-02 2.993E-02 3.143E-02 3.289E-02 3.430E-02 3.567E-02 3.697E-02 3.820E-02 3.937E-02 4.045E-02 4.145E-02 4.236E-02 4.318E-02 4.390E-02 4.451E-02 4.502E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.578E-02 4.551E-02 4.514E-02 4.466E-02 4.407E-02 4.339E-02 4.260E-02 4.173E-02 4.076E-02 3.972E-02 3.859E-02 3.740E-02 3.614E-02 3.482E-02 3.345E-02 3.203E-02 3.058E-02 2.910E-02 2.760E-02 2.608E-02 2.455E-02 2.302E-02 2.150E-02 1.999E-02 1.850E-02 1.704E-02 1.561E-02 1.422E-02 1.288E-02 1.158E-02 1.034E-02 9.157E-03 8.037E-03 7.707E-03 8.813E-03 9.983E-03 1.121E-02 1.250E-02 1.384E-02 1.523E-02 1.666E-02 1.812E-02 1.961E-02 2.112E-02 2.265E-02 2.419E-02 2.573E-02 2.726E-02 2.878E-02 3.028E-02 3.175E-02 3.318E-02 3.457E-02 3.591E-02 3.719E-02 3.840E-02 3.955E-02 4.062E-02 4.160E-02 4.250E-02 4.330E-02 4.400E-02 4.460E-02 4.510E-02 4.548E-02 4.576E-02 4.592E-02 4.597E-02 4.591E-02 4.573E-02 4.543E-02 4.503E-02 4.451E-02 4.389E-02 4.316E-02 4.233E-02 4.141E-02 4.039E-02 3.928E-02 3.810E-02 3.684E-02 3.551E-02 3.413E-02 3.268E-02 3.119E-02 2.967E-02 2.811E-02 2.653E-02 2.493E-02 2.333E-02 2.172E-02 2.013E-02 1.855E-02 1.700E-02 1.548E-02 1.400E-02 1.256E-02 1.118E-02 9.859E-03 8.601E-03 7.413E-03 6.300E-03 5.268E-03 4.320E-03 3.459E-03 2.690E-03 2.014E-03 1.434E-03 9.513E-04 5.669E-04 2.815E-04 9.521E-05 7.597E-06 1.779E-05 1.244E-04 3.258E-04 6.196E-04 1.003E-03 1.474E-03 2.028E-03 2.662E-03 3.372E-03 4.153E-03 5.002E-03 5.913E-03 6.882E-03 7.904E-03 8.973E-03 1.008E-02 1.123E-02 1.241E-02 1.362E-02 1.484E-02 1.608E-02 1.734E-02 1.859E-02 1.985E-02 2.110E-02 2.233E-02 2.356E-02 2.476E-02 2.594E-02 2.709E-02 2.820E-02 2.928E-02 3.032E-02 3.131E-02 3.226E-02 3.315E-02 3.399E-02 3.477E-02 3.549E-02 3.616E-02 3.675E-02 3.728E-02 3.775E-02 3.814E-02 3.847E-02 3.872E-02 3.890E-02 3.901E-02 3.905E-02 3.901E-02 3.890E-02 3.872E-02 3.847E-02 3.814E-02 3.775E-02 3.728E-02 3.675E-02 3.616E-02 3.549E-02 3.477E-02 3.399E-02 3.315E-02 3.226E-02 3.131E-02 3.032E-02 2.928E-02 2.820E-02 2.709E-02 2.594E-02 2.476E-02 2.356E-02 2.233E-02 2.110E-02 1.985E-02 1.859E-02 1.734E-02 1.608E-02 1.484E-02 1.362E-02 1.241E-02 1.123E-02 1.008E-02 8.973E-03 7.904E-03 6.882E-03 5.913E-03 5.002E-03 4.153E-03 3.372E-03 2.662E-03 2.028E-03 1.474E-03 1.003E-03 6.196E-04 3.258E-04 1.244E-04 1.779E-05 7.597E-06 9.521E-05 2.815E-04 5.669E-04 9.513E-04 1.434E-03 2.014E-03 2.690E-03 3.459E-03 4.320E-03 5.268E-03 6.300E-03 7.413E-03 8.601E-03 9.859E-03 1.118E-02 1.256E-02 1.400E-02 1.548E-02 1.700E-02 1.855E-02 2.013E-02 2.172E-02 2.333E-02 2.493E-02 2.653E-02 2.811E-02 2.967E-02 3.119E-02 3.268E-02 3.413E-02 3.551E-02 3.684E-02 3.810E-02 3.928E-02 4.039E-02 4.141E-02 4.233E-02 4.316E-02 4.389E-02 4.451E-02 4.503E-02 4.543E-02 4.573E-02 4.591E-02 4.597E-02 4.592E-02 4.576E-02 4.548E-02 4.510E-02 4.460E-02 4.400E-02 4.330E-02 4.250E-02 4.160E-02 4.062E-02 3.955E-02 3.840E-02 3.719E-02 3.591E-02 3.457E-02 3.318E-02 3.175E-02 3.028E-02 2.878E-02 2.726E-02 2.573E-02 2.419E-02 2.265E-02 2.112E-02 1.961E-02 1.812E-02 1.666E-02 1.523E-02 1.384E-02 1.250E-02 1.121E-02 9.983E-03 8.813E-03 8.458E-03 9.614E-03 1.083E-02 1.211E-02 1.344E-02 1.483E-02 1.625E-02 1.771E-02 1.921E-02 2.072E-02 2.226E-02 2.381E-02 2.535E-02 2.690E-02 2.843E-02 2.995E-02 3.143E-02 3.288E-02 3.429E-02 3.565E-02 3.695E-02 3.819E-02 3.936E-02 4.045E-02 4.145E-02 4.237E-02 4.319E-02 4.391E-02 4.453E-02 4.505E-02 4.545E-02 4.574E-02 4.591E-02 4.597E-02 4.591E-02 4.574E-02 4.545E-02 4.504E-02 4.452E-02 4.390E-02 4.316E-02 4.232E-02 4.138E-02 4.035E-02 3.923E-02 3.802E-02 3.674E-02 3.539E-02 3.398E-02 3.251E-02 3.100E-02 2.944E-02 2.786E-02 2.625E-02 2.462E-02 2.299E-02 2.136E-02 1.974E-02 1.815E-02 1.657E-02 1.503E-02 1.354E-02 1.209E-02 1.070E-02 9.370E-03 8.111E-03 6.928E-03 5.824E-03 4.805E-03 3.877E-03 3.041E-03 2.302E-03 1.663E-03 1.126E-03 6.919E-04 3.627E-04 1.389E-04 2.057E-05 7.280E-06 9.812E-05 2.917E-04 5.861E-04 9.791E-04 1.468E-03 2.049E-03 2.720E-03 3.475E-03 4.312E-03 5.225E-03 6.210E-03 7.262E-03 8.375E-03 9.544E-03 1.076E-02 1.203E-02 1.333E-02 1.467E-02 1.604E-02 1.743E-02 1.883E-02 2.025E-02 2.167E-02 2.309E-02 2.451E-02 2.591E-02 2.730E-02 2.866E-02 3.000E-02 3.131E-02 3.259E-02 3.382E-02 3.501E-02 3.616E-02 3.725E-02 3.829E-02 3.927E-02 4.019E-02 4.104E-02 4.183E-02 4.255E-02 4.320E-02 4.378E-02 4.429E-02 4.472E-02 4.507E-02 4.535E-02 4.554E-02 4.566E-02 4.570E-02 4.566E-02 4.554E-02 4.535E-02 4.507E-02 4.472E-02 4.429E-02 4.378E-02 4.320E-02 4.255E-02 4.183E-02 4.104E-02 4.019E-02 3.927E-02 3.829E-02 3.725E-02 3.616E-02 3.501E-02 3.382E-02 3.259E-02 3.131E-02 3.000E-02 2.866E-02 2.730E-02 2.591E-02 2.451E-02 2.309E-02 2.167E-02 2.025E-02 1.883E-02 1.743E-02 1.604E-02 1.467E-02 1.333E-02 1.203E-02 1.076E-02 9.544E-03 8.375E-03 7.262E-03 6.210E-03 5.225E-03 4.312E-03 3.475E-03 2.720E-03 2.049E-03 1.468E-03 9.791E-04 5.861E-04 2.917E-04 9.812E-05 7.280E-06 2.057E-05 1.389E-04 3.627E-04 6.919E-04 1.126E-03 1.663E-03 2.302E-03 3.041E-03 3.877E-03 4.805E-03 5.824E-03 6.928E-03 8.111E-03 9.370E-03 1.070E-02 1.209E-02 1.354E-02 1.503E-02 1.657E-02 1.815E-02 1.974E-02 2.136E-02 2.299E-02 2.462E-02 2.625E-02 2.786E-02 2.944E-02 3.100E-02 3.251E-02 3.398E-02 3.539E-02 3.674E-02 3.802E-02 3.923E-02 4.035E-02 4.138E-02 4.232E-02 4.316E-02 4.390E-02 4.452E-02 4.504E-02 4.545E-02 4.574E-02 4.591E-02 4.597E-02 4.591E-02 4.574E-02 4.545E-02 4.505E-02 4.453E-02 4.391E-02 4.319E-02 4.237E-02 4.145E-02 4.045E-02 3.936E-02 3.819E-02 3.695E-02 3.565E-02 3.429E-02 3.288E-02 3.143E-02 2.995E-02 2.843E-02 2.690E-02 2.535E-02 2.381E-02 2.226E-02 2.072E-02 1.921E-02 1.771E-02 1.625E-02 1.483E-02 1.344E-02 1.211E-02 1.083E-02 9.614E-03 9.234E-03 1.044E-02 1.171E-02 1.303E-02 1.441E-02 1.583E-02 1.729E-02 1.878E-02 2.030E-02 2.184E-02 2.340E-02 2.495E-02 2.651E-02 2.806E-02 2.959E-02 3.109E-02 3.256E-02 3.399E-02 3.537E-02 3.669E-02 3.795E-02 3.914E-02 4.026E-02 4.128E-02 4.222E-02 4.307E-02 4.381E-02 4.445E-02 4.499E-02 4.541E-02 4.571E-02 4.590E-02 4.597E-02 4.592E-02 4.576E-02 4.547E-02 4.507E-02 4.455E-02 4.392E-02 4.318E-02 4.233E-02 4.138E-02 4.034E-02 3.920E-02 3.798E-02 3.668E-02 3.531E-02 3.387E-02 3.238E-02 3.084E-02 2.926E-02 2.765E-02 2.601E-02 2.436E-02 2.270E-02 2.105E-02 1.940E-02 1.778E-02 1.619E-02 1.463E-02 1.312E-02 1.166E-02 1.026E-02 8.928E-03 7.669E-03 6.489E-03 5.395E-03 4.390E-03 3.481E-03 2.671E-03 1.963E-03 1.361E-03 8.671E-04 4.831E-04 2.102E-04 4.919E-05 2.162E-07 6.286E-05 2.362E-04 5.187E-04 9.085E-04 1.403E-03 2.000E-03 2.695E-03 3.485E-03 4.365E-03 5.332E-03 6.381E-03 7.506E-03 8.703E-03 9.965E-03 1.129E-02 1.266E-02 1.409E-02 1.555E-02 1.706E-02 1.859E-02 2.015E-02 2.172E-02 2.331E-02 2.490E-02 2.650E-02 2.808E-02 2.966E-02 3.122E-02 3.275E-02 3.426E-02 3.574E-02 3.718E-02 3.857E-02 3.993E-02 4.123E-02 4.248E-02 4.367E-02 4.480E-02 4.586E-02 4.686E-02 4.779E-02 4.864E-02 4.943E-02 5.013E-02 5.076E-02 5.130E-02 5.177E-02 5.215E-02 5.244E-02 5.266E-02 5.279E-02 5.283E-02 5.279E-02 5.266E-02 5.244E-02 5.215E-02 5.177E-02 5.130E-02 5.076E-02 5.013E-02 4.943E-02 4.864E-02 4.779E-02 4.686E-02 4.586E-02 4.480E-02 4.367E-02 4.248E-02 4.123E-02 3.993E-02 3.857E-02 3.718E-02 3.574E-02 3.426E-02 3.275E-02 3.122E-02 2.966E-02 2.808E-02 2.650E-02 2.490E-02 2.331E-02 2.172E-02 2.015E-02 1.859E-02 1.706E-02 1.555E-02 1.409E-02 1.266E-02 1.129E-02 9.965E-03 8.703E-03 7.506E-03 6.381E-03 5.332E-03 4.365E-03 3.485E-03 2.695E-03 2.000E-03 1.403E-03 9.085E-04 5.187E-04 2.362E-04 6.286E-05 2.162E-07 4.919E-05 2.102E-04 4.831E-04 8.671E-04 1.361E-03 1.963E-03 2.671E-03 3.481E-03 4.390E-03 5.395E-03 6.489E-03 7.669E-03 8.928E-03 1.026E-02 1.166E-02 1.312E-02 1.463E-02 1.619E-02 1.778E-02 1.940E-02 2.105E-02 2.270E-02 2.436E-02 2.601E-02 2.765E-02 2.926E-02 3.084E-02 3.238E-02 3.387E-02 3.531E-02 3.668E-02 3.798E-02 3.920E-02 4.034E-02 4.138E-02 4.233E-02 4.318E-02 4.392E-02 4.455E-02 4.507E-02 4.547E-02 4.576E-02 4.592E-02 4.597E-02 4.590E-02 4.571E-02 4.541E-02 4.499E-02 4.445E-02 4.381E-02 4.307E-02 4.222E-02 4.128E-02 4.026E-02 3.914E-02 3.795E-02 3.669E-02 3.537E-02 3.399E-02 3.256E-02 3.109E-02 2.959E-02 2.806E-02 2.651E-02 2.495E-02 2.340E-02 2.184E-02 2.030E-02 1.878E-02 1.729E-02 1.583E-02 1.441E-02 1.303E-02 1.171E-02 1.044E-02 1.004E-02 1.129E-02 1.260E-02 1.397E-02 1.538E-02 1.684E-02 1.833E-02 1.986E-02 2.140E-02 2.296E-02 2.453E-02 2.610E-02 2.766E-02 2.920E-02 3.072E-02 3.221E-02 3.366E-02 3.506E-02 3.641E-02 3.769E-02 3.890E-02 4.004E-02 4.110E-02 4.206E-02 4.293E-02 4.370E-02 4.436E-02 4.491E-02 4.535E-02 4.568E-02 4.588E-02 4.597E-02 4.593E-02 4.578E-02 4.550E-02 4.510E-02 4.459E-02 4.396E-02 4.321E-02 4.236E-02 4.141E-02 4.035E-02 3.920E-02 3.796E-02 3.665E-02 3.526E-02 3.380E-02 3.229E-02 3.072E-02 2.911E-02 2.748E-02 2.581E-02 2.414E-02 2.245E-02 2.078E-02 1.911E-02 1.747E-02 1.585E-02 1.428E-02 1.275E-02 1.128E-02 9.869E-03 8.532E-03 7.272E-03 6.096E-03 5.010E-03 4.020E-03 3.130E-03 2.345E-03 1.668E-03 1.104E-03 6.535E-04 3.197E-04 1.036E-04 6.105E-06 2.738E-05 1.670E-04 4.241E-04 7.971E-04 1.284E-03 1.882E-03 2.589E-03 3.400E-03 4.312E-03 5.320E-03 6.421E-03 7.608E-03 8.877E-03 1.022E-02 1.164E-02 1.312E-02 1.465E-02 1.624E-02 1.787E-02 1.955E-02 2.125E-02 2.298E-02 2.473E-02 2.650E-02 2.826E-02 3.003E-02 3.180E-02 3.355E-02 3.529E-02 3.700E-02 3.868E-02 4.033E-02 4.194E-02 4.351E-02 4.503E-02 4.650E-02 4.791E-02 4.926E-02 5.055E-02 5.177E-02 5.291E-02 5.399E-02 5.499E-02 5.591E-02 5.674E-02 5.750E-02 5.817E-02 5.875E-02 5.925E-02 5.966E-02 5.998E-02 6.021E-02 6.034E-02 6.039E-02 6.034E-02 6.021E-02 5.998E-02 5.966E-02 5.925E-02 5.875E-02 5.817E-02 5.750E-02 5.674E-02 5.591E-02 5.499E-02 5.399E-02 5.291E-02 5.177E-02 5.055E-02 4.926E-02 4.791E-02 4.650E-02 4.503E-02 4.351E-02 4.194E-02 4.033E-02 3.868E-02 3.700E-02 3.529E-02 3.355E-02 3.180E-02 3.003E-02 2.826E-02 2.650E-02 2.473E-02 2.298E-02 2.125E-02 1.955E-02 1.787E-02 1.624E-02 1.465E-02 1.312E-02 1.164E-02 1.022E-02 8.877E-03 7.608E-03 6.421E-03 5.320E-03 4.312E-03 3.400E-03 2.589E-03 1.882E-03 1.284E-03 7.971E-04 4.241E-04 1.670E-04 2.738E-05 6.105E-06 1.036E-04 3.197E-04 6.535E-04 1.104E-03 1.668E-03 2.345E-03 3.130E-03 4.020E-03 5.010E-03 6.096E-03 7.272E-03 8.532E-03 9.869E-03 1.128E-02 1.275E-02 1.428E-02 1.585E-02 1.747E-02 1.911E-02 2.078E-02 2.245E-02 2.414E-02 2.581E-02 2.748E-02 2.911E-02 3.072E-02 3.229E-02 3.380E-02 3.526E-02 3.665E-02 3.796E-02 3.920E-02 4.035E-02 4.141E-02 4.236E-02 4.321E-02 4.396E-02 4.459E-02 4.510E-02 4.550E-02 4.578E-02 4.593E-02 4.597E-02 4.588E-02 4.568E-02 4.535E-02 4.491E-02 4.436E-02 4.370E-02 4.293E-02 4.206E-02 4.110E-02 4.004E-02 3.890E-02 3.769E-02 3.641E-02 3.506E-02 3.366E-02 3.221E-02 3.072E-02 2.920E-02 2.766E-02 2.610E-02 2.453E-02 2.296E-02 2.140E-02 1.986E-02 1.833E-02 1.684E-02 1.538E-02 1.397E-02 1.260E-02 1.129E-02 1.086E-02 1.216E-02 1.352E-02 1.492E-02 1.638E-02 1.787E-02 1.939E-02 2.094E-02 2.250E-02 2.408E-02 2.565E-02 2.723E-02 2.879E-02 3.032E-02 3.183E-02 3.330E-02 3.472E-02 3.609E-02 3.740E-02 3.864E-02 3.980E-02 4.088E-02 4.187E-02 4.277E-02 4.356E-02 4.425E-02 4.483E-02 4.529E-02 4.564E-02 4.586E-02 4.596E-02 4.594E-02 4.580E-02 4.554E-02 4.515E-02 4.464E-02 4.401E-02 4.327E-02 4.241E-02 4.145E-02 4.039E-02 3.923E-02 3.798E-02 3.665E-02 3.524E-02 3.376E-02 3.223E-02 3.064E-02 2.901E-02 2.735E-02 2.566E-02 2.396E-02 2.225E-02 2.055E-02 1.886E-02 1.719E-02 1.556E-02 1.397E-02 1.242E-02 1.094E-02 9.522E-03 8.179E-03 6.918E-03 5.746E-03 4.668E-03 3.691E-03 2.820E-03 2.060E-03 1.414E-03 8.868E-04 4.801E-04 1.963E-04 3.715E-05 3.357E-06 9.524E-05 3.124E-04 6.540E-04 1.118E-03 1.703E-03 2.406E-03 3.224E-03 4.153E-03 5.189E-03 6.328E-03 7.564E-03 8.893E-03 1.031E-02 1.180E-02 1.337E-02 1.501E-02 1.671E-02 1.847E-02 2.027E-02 2.212E-02 2.400E-02 2.591E-02 2.784E-02 2.978E-02 3.173E-02 3.369E-02 3.563E-02 3.757E-02 3.949E-02 4.138E-02 4.324E-02 4.507E-02 4.686E-02 4.860E-02 5.030E-02 5.193E-02 5.351E-02 5.503E-02 5.648E-02 5.786E-02 5.916E-02 6.039E-02 6.154E-02 6.260E-02 6.358E-02 6.447E-02 6.528E-02 6.599E-02 6.661E-02 6.714E-02 6.757E-02 6.791E-02 6.815E-02 6.830E-02 6.835E-02 6.830E-02 6.815E-02 6.791E-02 6.757E-02 6.714E-02 6.661E-02 6.599E-02 6.528E-02 6.447E-02 6.358E-02 6.260E-02 6.154E-02 6.039E-02 5.916E-02 5.786E-02 5.648E-02 5.503E-02 5.351E-02 5.193E-02 5.030E-02 4.860E-02 4.686E-02 4.507E-02 4.324E-02 4.138E-02 3.949E-02 3.757E-02 3.563E-02 3.369E-02 3.173E-02 2.978E-02 2.784E-02 2.591E-02 2.400E-02 2.212E-02 2.027E-02 1.847E-02 1.671E-02 1.501E-02 1.337E-02 1.180E-02 1.031E-02 8.893E-03 7.564E-03 6.328E-03 5.189E-03 4.153E-03 3.224E-03 2.406E-03 1.703E-03 1.118E-03 6.540E-04 3.124E-04 9.524E-05 3.357E-06 3.715E-05 1.963E-04 4.801E-04 8.868E-04 1.414E-03 2.060E-03 2.820E-03 3.691E-03 4.668E-03 5.746E-03 6.918E-03 8.179E-03 9.522E-03 1.094E-02 1.242E-02 1.397E-02 1.556E-02 1.719E-02 1.886E-02 2.055E-02 2.225E-02 2.396E-02 2.566E-02 2.735E-02 2.901E-02 3.064E-02 3.223E-02 3.376E-02 3.524E-02 3.665E-02 3.798E-02 3.923E-02 4.039E-02 4.145E-02 4.241E-02 4.327E-02 4.401E-02 4.464E-02 4.515E-02 4.554E-02 4.580E-02 4.594E-02 4.596E-02 4.586E-02 4.564E-02 4.529E-02 4.483E-02 4.425E-02 4.356E-02 4.277E-02 4.187E-02 4.088E-02 3.980E-02 3.864E-02 3.740E-02 3.609E-02 3.472E-02 3.330E-02 3.183E-02 3.032E-02 2.879E-02 2.723E-02 2.565E-02 2.408E-02 2.250E-02 2.094E-02 1.939E-02 1.787E-02 1.638E-02 1.492E-02 1.352E-02 1.216E-02 1.170E-02 1.305E-02 1.445E-02 1.589E-02 1.738E-02 1.890E-02 2.045E-02 2.202E-02 2.360E-02 2.519E-02 2.677E-02 2.835E-02 2.990E-02 3.143E-02 3.292E-02 3.436E-02 3.575E-02 3.709E-02 3.835E-02 3.954E-02 4.065E-02 4.167E-02 4.259E-02 4.341E-02 4.413E-02 4.473E-02 4.522E-02 4.559E-02 4.583E-02 4.596E-02 4.596E-02 4.583E-02 4.558E-02 4.520E-02 4.470E-02 4.408E-02 4.334E-02 4.248E-02 4.152E-02 4.045E-02 3.928E-02 3.802E-02 3.668E-02 3.526E-02 3.376E-02 3.221E-02 3.060E-02 2.895E-02 2.726E-02 2.555E-02 2.383E-02 2.210E-02 2.037E-02 1.866E-02 1.697E-02 1.531E-02 1.370E-02 1.214E-02 1.065E-02 9.219E-03 7.870E-03 6.607E-03 5.437E-03 4.367E-03 3.402E-03 2.550E-03 1.813E-03 1.197E-03 7.061E-04 3.421E-04 1.079E-04 5.093E-06 3.466E-05 1.969E-04 4.916E-04 9.178E-04 1.474E-03 2.157E-03 2.966E-03 3.896E-03 4.944E-03 6.106E-03 7.376E-03 8.750E-03 1.022E-02 1.179E-02 1.344E-02 1.516E-02 1.697E-02 1.883E-02 2.076E-02 2.274E-02 2.476E-02 2.682E-02 2.891E-02 3.102E-02 3.315E-02 3.529E-02 3.743E-02 3.956E-02 4.168E-02 4.378E-02 4.586E-02 4.791E-02 4.992E-02 5.189E-02 5.382E-02 5.569E-02 5.750E-02 5.925E-02 6.094E-02 6.255E-02 6.410E-02 6.556E-02 6.695E-02 6.825E-02 6.947E-02 7.060E-02 7.163E-02 7.258E-02 7.343E-02 7.418E-02 7.484E-02 7.539E-02 7.585E-02 7.621E-02 7.646E-02 7.661E-02 7.666E-02 7.661E-02 7.646E-02 7.621E-02 7.585E-02 7.539E-02 7.484E-02 7.418E-02 7.343E-02 7.258E-02 7.163E-02 7.060E-02 6.947E-02 6.825E-02 6.695E-02 6.556E-02 6.410E-02 6.255E-02 6.094E-02 5.925E-02 5.750E-02 5.569E-02 5.382E-02 5.189E-02 4.992E-02 4.791E-02 4.586E-02 4.378E-02 4.168E-02 3.956E-02 3.743E-02 3.529E-02 3.315E-02 3.102E-02 2.891E-02 2.682E-02 2.476E-02 2.274E-02 2.076E-02 1.883E-02 1.697E-02 1.516E-02 1.344E-02 1.179E-02 1.022E-02 8.750E-03 7.376E-03 6.106E-03 4.944E-03 3.896E-03 2.966E-03 2.157E-03 1.474E-03 9.178E-04 4.916E-04 1.969E-04 3.466E-05 5.093E-06 1.079E-04 3.421E-04 7.061E-04 1.197E-03 1.813E-03 2.550E-03 3.402E-03 4.367E-03 5.437E-03 6.607E-03 7.870E-03 9.219E-03 1.065E-02 1.214E-02 1.370E-02 1.531E-02 1.697E-02 1.866E-02 2.037E-02 2.210E-02 2.383E-02 2.555E-02 2.726E-02 2.895E-02 3.060E-02 3.221E-02 3.376E-02 3.526E-02 3.668E-02 3.802E-02 3.928E-02 4.045E-02 4.152E-02 4.248E-02 4.334E-02 4.408E-02 4.470E-02 4.520E-02 4.558E-02 4.583E-02 4.596E-02 4.596E-02 4.583E-02 4.559E-02 4.522E-02 4.473E-02 4.413E-02 4.341E-02 4.259E-02 4.167E-02 4.065E-02 3.954E-02 3.835E-02 3.709E-02 3.575E-02 3.436E-02 3.292E-02 3.143E-02 2.990E-02 2.835E-02 2.677E-02 2.519E-02 2.360E-02 2.202E-02 2.045E-02 1.890E-02 1.738E-02 1.589E-02 1.445E-02 1.305E-02 1.257E-02 1.395E-02 1.539E-02 1.687E-02 1.839E-02 1.994E-02 2.151E-02 2.310E-02 2.469E-02 2.629E-02 2.788E-02 2.945E-02 3.099E-02 3.250E-02 3.397E-02 3.539E-02 3.675E-02 3.804E-02 3.926E-02 4.039E-02 4.144E-02 4.239E-02 4.324E-02 4.398E-02 4.462E-02 4.513E-02 4.553E-02 4.580E-02 4.594E-02 4.596E-02 4.586E-02 4.562E-02 4.526E-02 4.477E-02 4.416E-02 4.342E-02 4.257E-02 4.161E-02 4.054E-02 3.937E-02 3.810E-02 3.674E-02 3.531E-02 3.380E-02 3.223E-02 3.060E-02 2.893E-02 2.722E-02 2.549E-02 2.374E-02 2.198E-02 2.023E-02 1.850E-02 1.679E-02 1.511E-02 1.348E-02 1.191E-02 1.040E-02 8.958E-03 7.602E-03 6.336E-03 5.168E-03 4.103E-03 3.150E-03 2.314E-03 1.601E-03 1.014E-03 5.573E-04 2.350E-04 4.919E-05 1.764E-06 9.381E-05 3.258E-04 6.974E-04 1.208E-03 1.855E-03 2.637E-03 3.552E-03 4.594E-03 5.762E-03 7.050E-03 8.452E-03 9.965E-03 1.158E-02 1.329E-02 1.510E-02 1.699E-02 1.896E-02 2.099E-02 2.309E-02 2.525E-02 2.745E-02 2.969E-02 3.196E-02 3.426E-02 3.658E-02 3.890E-02 4.123E-02 4.355E-02 4.586E-02 4.815E-02 5.042E-02 5.266E-02 5.486E-02 5.701E-02 5.912E-02 6.117E-02 6.316E-02 6.509E-02 6.695E-02 6.874E-02 7.045E-02 7.208E-02 7.363E-02 7.509E-02 7.646E-02 7.774E-02 7.893E-02 8.002E-02 8.101E-02 8.190E-02 8.269E-02 8.338E-02 8.396E-02 8.444E-02 8.481E-02 8.508E-02 8.524E-02 8.529E-02 8.524E-02 8.508E-02 8.481E-02 8.444E-02 8.396E-02 8.338E-02 8.269E-02 8.190E-02 8.101E-02 8.002E-02 7.893E-02 7.774E-02 7.646E-02 7.509E-02 7.363E-02 7.208E-02 7.045E-02 6.874E-02 6.695E-02 6.509E-02 6.316E-02 6.117E-02 5.912E-02 5.701E-02 5.486E-02 5.266E-02 5.042E-02 4.815E-02 4.586E-02 4.355E-02 4.123E-02 3.890E-02 3.658E-02 3.426E-02 3.196E-02 2.969E-02 2.745E-02 2.525E-02 2.309E-02 2.099E-02 1.896E-02 1.699E-02 1.510E-02 1.329E-02 1.158E-02 9.965E-03 8.452E-03 7.050E-03 5.762E-03 4.594E-03 3.552E-03 2.637E-03 1.855E-03 1.208E-03 6.974E-04 3.258E-04 9.381E-05 1.764E-06 4.919E-05 2.350E-04 5.573E-04 1.014E-03 1.601E-03 2.314E-03 3.150E-03 4.103E-03 5.168E-03 6.336E-03 7.602E-03 8.958E-03 1.040E-02 1.191E-02 1.348E-02 1.511E-02 1.679E-02 1.850E-02 2.023E-02 2.198E-02 2.374E-02 2.549E-02 2.722E-02 2.893E-02 3.060E-02 3.223E-02 3.380E-02 3.531E-02 3.674E-02 3.810E-02 3.937E-02 4.054E-02 4.161E-02 4.257E-02 4.342E-02 4.416E-02 4.477E-02 4.526E-02 4.562E-02 4.586E-02 4.596E-02 4.594E-02 4.580E-02 4.553E-02 4.513E-02 4.462E-02 4.398E-02 4.324E-02 4.239E-02 4.144E-02 4.039E-02 3.926E-02 3.804E-02 3.675E-02 3.539E-02 3.397E-02 3.250E-02 3.099E-02 2.945E-02 2.788E-02 2.629E-02 2.469E-02 2.310E-02 2.151E-02 1.994E-02 1.839E-02 1.687E-02 1.539E-02 1.395E-02 1.344E-02 1.487E-02 1.635E-02 1.786E-02 1.941E-02 2.098E-02 2.257E-02 2.418E-02 2.578E-02 2.738E-02 2.897E-02 3.053E-02 3.206E-02 3.355E-02 3.499E-02 3.638E-02 3.770E-02 3.894E-02 4.011E-02 4.119E-02 4.217E-02 4.305E-02 4.382E-02 4.449E-02 4.503E-02 4.545E-02 4.575E-02 4.593E-02 4.597E-02 4.588E-02 4.567E-02 4.532E-02 4.485E-02 4.425E-02 4.352E-02 4.268E-02 4.172E-02 4.065E-02 3.948E-02 3.820E-02 3.684E-02 3.539E-02 3.387E-02 3.229E-02 3.064E-02 2.895E-02 2.722E-02 2.547E-02 2.369E-02 2.192E-02 2.014E-02 1.838E-02 1.665E-02 1.496E-02 1.331E-02 1.171E-02 1.019E-02 8.739E-03 7.375E-03 6.105E-03 4.936E-03 3.877E-03 2.933E-03 2.112E-03 1.419E-03 8.593E-04 4.364E-04 1.541E-04 1.518E-05 2.164E-05 1.748E-04 4.751E-04 9.224E-04 1.516E-03 2.254E-03 3.134E-03 4.153E-03 5.308E-03 6.595E-03 8.009E-03 9.544E-03 1.120E-02 1.296E-02 1.482E-02 1.678E-02 1.883E-02 2.097E-02 2.317E-02 2.545E-02 2.778E-02 3.016E-02 3.259E-02 3.505E-02 3.753E-02 4.004E-02 4.255E-02 4.507E-02 4.759E-02 5.009E-02 5.257E-02 5.503E-02 5.745E-02 5.984E-02 6.218E-02 6.447E-02 6.671E-02 6.888E-02 7.099E-02 7.303E-02 7.499E-02 7.687E-02 7.867E-02 8.038E-02 8.200E-02 8.353E-02 8.497E-02 8.631E-02 8.755E-02 8.868E-02 8.972E-02 9.065E-02 9.147E-02 9.218E-02 9.279E-02 9.329E-02 9.367E-02 9.395E-02 9.412E-02 9.417E-02 9.412E-02 9.395E-02 9.367E-02 9.329E-02 9.279E-02 9.218E-02 9.147E-02 9.065E-02 8.972E-02 8.868E-02 8.755E-02 8.631E-02 8.497E-02 8.353E-02 8.200E-02 8.038E-02 7.867E-02 7.687E-02 7.499E-02 7.303E-02 7.099E-02 6.888E-02 6.671E-02 6.447E-02 6.218E-02 5.984E-02 5.745E-02 5.503E-02 5.257E-02 5.009E-02 4.759E-02 4.507E-02 4.255E-02 4.004E-02 3.753E-02 3.505E-02 3.259E-02 3.016E-02 2.778E-02 2.545E-02 2.317E-02 2.097E-02 1.883E-02 1.678E-02 1.482E-02 1.296E-02 1.120E-02 9.544E-03 8.009E-03 6.595E-03 5.308E-03 4.153E-03 3.134E-03 2.254E-03 1.516E-03 9.224E-04 4.751E-04 1.748E-04 2.164E-05 1.518E-05 1.541E-04 4.364E-04 8.593E-04 1.419E-03 2.112E-03 2.933E-03 3.877E-03 4.936E-03 6.105E-03 7.375E-03 8.739E-03 1.019E-02 1.171E-02 1.331E-02 1.496E-02 1.665E-02 1.838E-02 2.014E-02 2.192E-02 2.369E-02 2.547E-02 2.722E-02 2.895E-02 3.064E-02 3.229E-02 3.387E-02 3.539E-02 3.684E-02 3.820E-02 3.948E-02 4.065E-02 4.172E-02 4.268E-02 4.352E-02 4.425E-02 4.485E-02 4.532E-02 4.567E-02 4.588E-02 4.597E-02 4.593E-02 4.575E-02 4.545E-02 4.503E-02 4.449E-02 4.382E-02 4.305E-02 4.217E-02 4.119E-02 4.011E-02 3.894E-02 3.770E-02 3.638E-02 3.499E-02 3.355E-02 3.206E-02 3.053E-02 2.897E-02 2.738E-02 2.578E-02 2.418E-02 2.257E-02 2.098E-02 1.941E-02 1.786E-02 1.635E-02 1.487E-02 1.434E-02 1.580E-02 1.731E-02 1.886E-02 2.043E-02 2.202E-02 2.363E-02 2.525E-02 2.686E-02 2.846E-02 3.004E-02 3.159E-02 3.310E-02 3.457E-02 3.598E-02 3.733E-02 3.860E-02 3.980E-02 4.091E-02 4.192E-02 4.284E-02 4.364E-02 4.434E-02 4.492E-02 4.537E-02 4.570E-02 4.590E-02 4.597E-02 4.591E-02 4.572E-02 4.539E-02 4.494E-02 4.435E-02 4.364E-02 4.280E-02 4.185E-02 4.079E-02 3.961E-02 3.834E-02 3.697E-02 3.551E-02 3.398E-02 3.238E-02 3.072E-02 2.901E-02 2.726E-02 2.549E-02 2.369E-02 2.189E-02 2.010E-02 1.832E-02 1.656E-02 1.484E-02 1.317E-02 1.156E-02 1.002E-02 8.561E-03 7.188E-03 5.911E-03 4.741E-03 3.684E-03 2.748E-03 1.940E-03 1.266E-03 7.312E-04 3.396E-04 9.521E-05 1.084E-06 5.944E-05 2.717E-04 6.386E-04 1.160E-03 1.835E-03 2.662E-03 3.639E-03 4.762E-03 6.028E-03 7.434E-03 8.973E-03 1.064E-02 1.243E-02 1.434E-02 1.635E-02 1.847E-02 2.068E-02 2.298E-02 2.536E-02 2.781E-02 3.032E-02 3.288E-02 3.549E-02 3.814E-02 4.082E-02 4.351E-02 4.622E-02 4.893E-02 5.164E-02 5.433E-02 5.701E-02 5.966E-02 6.228E-02 6.485E-02 6.738E-02 6.986E-02 7.228E-02 7.463E-02 7.692E-02 7.913E-02 8.127E-02 8.332E-02 8.529E-02 8.717E-02 8.896E-02 9.065E-02 9.224E-02 9.373E-02 9.512E-02 9.640E-02 9.758E-02 9.865E-02 9.961E-02 1.005E-01 1.012E-01 1.018E-01 1.023E-01 1.027E-01 1.030E-01 1.032E-01 1.033E-01 1.032E-01 1.030E-01 1.027E-01 1.023E-01 1.018E-01 1.012E-01 1.005E-01 9.961E-02 9.865E-02 9.758E-02 9.640E-02 9.512E-02 9.373E-02 9.224E-02 9.065E-02 8.896E-02 8.717E-02 8.529E-02 8.332E-02 8.127E-02 7.913E-02 7.692E-02 7.463E-02 7.228E-02 6.986E-02 6.738E-02 6.485E-02 6.228E-02 5.966E-02 5.701E-02 5.433E-02 5.164E-02 4.893E-02 4.622E-02 4.351E-02 4.082E-02 3.814E-02 3.549E-02 3.288E-02 3.032E-02 2.781E-02 2.536E-02 2.298E-02 2.068E-02 1.847E-02 1.635E-02 1.434E-02 1.243E-02 1.064E-02 8.973E-03 7.434E-03 6.028E-03 4.762E-03 3.639E-03 2.662E-03 1.835E-03 1.160E-03 6.386E-04 2.717E-04 5.944E-05 1.084E-06 9.521E-05 3.396E-04 7.312E-04 1.266E-03 1.940E-03 2.748E-03 3.684E-03 4.741E-03 5.911E-03 7.188E-03 8.561E-03 1.002E-02 1.156E-02 1.317E-02 1.484E-02 1.656E-02 1.832E-02 2.010E-02 2.189E-02 2.369E-02 2.549E-02 2.726E-02 2.901E-02 3.072E-02 3.238E-02 3.398E-02 3.551E-02 3.697E-02 3.834E-02 3.961E-02 4.079E-02 4.185E-02 4.280E-02 4.364E-02 4.435E-02 4.494E-02 4.539E-02 4.572E-02 4.591E-02 4.597E-02 4.590E-02 4.570E-02 4.537E-02 4.492E-02 4.434E-02 4.364E-02 4.284E-02 4.192E-02 4.091E-02 3.980E-02 3.860E-02 3.733E-02 3.598E-02 3.457E-02 3.310E-02 3.159E-02 3.004E-02 2.846E-02 2.686E-02 2.525E-02 2.363E-02 2.202E-02 2.043E-02 1.886E-02 1.731E-02 1.580E-02 1.525E-02 1.674E-02 1.828E-02 1.986E-02 2.145E-02 2.307E-02 2.469E-02 2.631E-02 2.792E-02 2.952E-02 3.109E-02 3.262E-02 3.412E-02 3.555E-02 3.693E-02 3.824E-02 3.946E-02 4.061E-02 4.165E-02 4.260E-02 4.344E-02 4.417E-02 4.478E-02 4.527E-02 4.563E-02 4.587E-02 4.597E-02 4.593E-02 4.577E-02 4.547E-02 4.503E-02 4.446E-02 4.377E-02 4.295E-02 4.200E-02 4.094E-02 3.977E-02 3.850E-02 3.713E-02 3.567E-02 3.413E-02 3.251E-02 3.084E-02 2.911E-02 2.735E-02 2.555E-02 2.374E-02 2.192E-02 2.010E-02 1.829E-02 1.652E-02 1.478E-02 1.309E-02 1.146E-02 9.900E-03 8.424E-03 7.039E-03 5.754E-03 4.580E-03 3.524E-03 2.594E-03 1.797E-03 1.139E-03 6.262E-04 2.633E-04 5.426E-05 2.384E-06 1.101E-04 3.791E-04 8.101E-04 1.403E-03 2.157E-03 3.071E-03 4.143E-03 5.369E-03 6.745E-03 8.267E-03 9.931E-03 1.173E-02 1.366E-02 1.571E-02 1.787E-02 2.015E-02 2.252E-02 2.499E-02 2.754E-02 3.016E-02 3.285E-02 3.560E-02 3.839E-02 4.123E-02 4.409E-02 4.698E-02 4.988E-02 5.279E-02 5.569E-02 5.857E-02 6.144E-02 6.429E-02 6.709E-02 6.986E-02 7.258E-02 7.524E-02 7.784E-02 8.038E-02 8.285E-02 8.524E-02 8.755E-02 8.977E-02 9.191E-02 9.395E-02 9.590E-02 9.775E-02 9.950E-02 1.011E-01 1.027E-01 1.041E-01 1.054E-01 1.067E-01 1.078E-01 1.087E-01 1.096E-01 1.104E-01 1.110E-01 1.115E-01 1.120E-01 1.122E-01 1.124E-01 1.125E-01 1.124E-01 1.122E-01 1.120E-01 1.115E-01 1.110E-01 1.104E-01 1.096E-01 1.087E-01 1.078E-01 1.067E-01 1.054E-01 1.041E-01 1.027E-01 1.011E-01 9.950E-02 9.775E-02 9.590E-02 9.395E-02 9.191E-02 8.977E-02 8.755E-02 8.524E-02 8.285E-02 8.038E-02 7.784E-02 7.524E-02 7.258E-02 6.986E-02 6.709E-02 6.429E-02 6.144E-02 5.857E-02 5.569E-02 5.279E-02 4.988E-02 4.698E-02 4.409E-02 4.123E-02 3.839E-02 3.560E-02 3.285E-02 3.016E-02 2.754E-02 2.499E-02 2.252E-02 2.015E-02 1.787E-02 1.571E-02 1.366E-02 1.173E-02 9.931E-03 8.267E-03 6.745E-03 5.369E-03 4.143E-03 3.071E-03 2.157E-03 1.403E-03 8.101E-04 3.791E-04 1.101E-04 2.384E-06 5.426E-05 2.633E-04 6.262E-04 1.139E-03 1.797E-03 2.594E-03 3.524E-03 4.580E-03 5.754E-03 7.039E-03 8.424E-03 9.900E-03 1.146E-02 1.309E-02 1.478E-02 1.652E-02 1.829E-02 2.010E-02 2.192E-02 2.374E-02 2.555E-02 2.735E-02 2.911E-02 3.084E-02 3.251E-02 3.413E-02 3.567E-02 3.713E-02 3.850E-02 3.977E-02 4.094E-02 4.200E-02 4.295E-02 4.377E-02 4.446E-02 4.503E-02 4.547E-02 4.577E-02 4.593E-02 4.597E-02 4.587E-02 4.563E-02 4.527E-02 4.478E-02 4.417E-02 4.344E-02 4.260E-02 4.165E-02 4.061E-02 3.946E-02 3.824E-02 3.693E-02 3.555E-02 3.412E-02 3.262E-02 3.109E-02 2.952E-02 2.792E-02 2.631E-02 2.469E-02 2.307E-02 2.145E-02 1.986E-02 1.828E-02 1.674E-02 1.616E-02 1.769E-02 1.926E-02 2.086E-02 2.247E-02 2.410E-02 2.573E-02 2.736E-02 2.897E-02 3.056E-02 3.212E-02 3.363E-02 3.510E-02 3.650E-02 3.784E-02 3.910E-02 4.028E-02 4.136E-02 4.234E-02 4.322E-02 4.399E-02 4.463E-02 4.516E-02 4.556E-02 4.582E-02 4.596E-02 4.595E-02 4.582E-02 4.554E-02 4.513E-02 4.458E-02 4.391E-02 4.310E-02 4.217E-02 4.112E-02 3.996E-02 3.869E-02 3.731E-02 3.585E-02 3.430E-02 3.268E-02 3.100E-02 2.926E-02 2.748E-02 2.566E-02 2.383E-02 2.198E-02 2.014E-02 1.832E-02 1.652E-02 1.475E-02 1.304E-02 1.139E-02 9.818E-03 8.326E-03 6.928E-03 5.634E-03 4.453E-03 3.395E-03 2.468E-03 1.679E-03 1.035E-03 5.414E-04 2.042E-04 2.751E-05 1.486E-05 1.690E-04 4.916E-04 9.839E-04 1.646E-03 2.477E-03 3.475E-03 4.639E-03 5.964E-03 7.448E-03 9.086E-03 1.087E-02 1.280E-02 1.486E-02 1.706E-02 1.937E-02 2.180E-02 2.434E-02 2.697E-02 2.969E-02 3.249E-02 3.536E-02 3.829E-02 4.127E-02 4.429E-02 4.734E-02 5.042E-02 5.351E-02 5.661E-02 5.971E-02 6.279E-02 6.585E-02 6.888E-02 7.188E-02 7.484E-02 7.774E-02 8.059E-02 8.338E-02 8.609E-02 8.874E-02 9.130E-02 9.379E-02 9.618E-02 9.848E-02 1.007E-01 1.028E-01 1.048E-01 1.067E-01 1.085E-01 1.102E-01 1.118E-01 1.132E-01 1.146E-01 1.158E-01 1.170E-01 1.180E-01 1.189E-01 1.196E-01 1.203E-01 1.208E-01 1.212E-01 1.215E-01 1.217E-01 1.218E-01 1.217E-01 1.215E-01 1.212E-01 1.208E-01 1.203E-01 1.196E-01 1.189E-01 1.180E-01 1.170E-01 1.158E-01 1.146E-01 1.132E-01 1.118E-01 1.102E-01 1.085E-01 1.067E-01 1.048E-01 1.028E-01 1.007E-01 9.848E-02 9.618E-02 9.379E-02 9.130E-02 8.874E-02 8.609E-02 8.338E-02 8.059E-02 7.774E-02 7.484E-02 7.188E-02 6.888E-02 6.585E-02 6.279E-02 5.971E-02 5.661E-02 5.351E-02 5.042E-02 4.734E-02 4.429E-02 4.127E-02 3.829E-02 3.536E-02 3.249E-02 2.969E-02 2.697E-02 2.434E-02 2.180E-02 1.937E-02 1.706E-02 1.486E-02 1.280E-02 1.087E-02 9.086E-03 7.448E-03 5.964E-03 4.639E-03 3.475E-03 2.477E-03 1.646E-03 9.839E-04 4.916E-04 1.690E-04 1.486E-05 2.751E-05 2.042E-04 5.414E-04 1.035E-03 1.679E-03 2.468E-03 3.395E-03 4.453E-03 5.634E-03 6.928E-03 8.326E-03 9.818E-03 1.139E-02 1.304E-02 1.475E-02 1.652E-02 1.832E-02 2.014E-02 2.198E-02 2.383E-02 2.566E-02 2.748E-02 2.926E-02 3.100E-02 3.268E-02 3.430E-02 3.585E-02 3.731E-02 3.869E-02 3.996E-02 4.112E-02 4.217E-02 4.310E-02 4.391E-02 4.458E-02 4.513E-02 4.554E-02 4.582E-02 4.595E-02 4.596E-02 4.582E-02 4.556E-02 4.516E-02 4.463E-02 4.399E-02 4.322E-02 4.234E-02 4.136E-02 4.028E-02 3.910E-02 3.784E-02 3.650E-02 3.510E-02 3.363E-02 3.212E-02 3.056E-02 2.897E-02 2.736E-02 2.573E-02 2.410E-02 2.247E-02 2.086E-02 1.926E-02 1.769E-02 1.709E-02 1.865E-02 2.024E-02 2.186E-02 2.349E-02 2.513E-02 2.677E-02 2.840E-02 3.001E-02 3.158E-02 3.312E-02 3.461E-02 3.605E-02 3.741E-02 3.871E-02 3.992E-02 4.104E-02 4.206E-02 4.298E-02 4.378E-02 4.447E-02 4.503E-02 4.546E-02 4.577E-02 4.593E-02 4.597E-02 4.586E-02 4.562E-02 4.523E-02 4.471E-02 4.406E-02 4.327E-02 4.236E-02 4.132E-02 4.016E-02 3.890E-02 3.753E-02 3.607E-02 3.452E-02 3.289E-02 3.119E-02 2.944E-02 2.765E-02 2.581E-02 2.396E-02 2.210E-02 2.023E-02 1.838E-02 1.656E-02 1.478E-02 1.304E-02 1.137E-02 9.777E-03 8.267E-03 6.854E-03 5.548E-03 4.359E-03 3.296E-03 2.369E-03 1.585E-03 9.513E-04 4.741E-04 1.593E-04 1.154E-05 3.466E-05 2.316E-04 6.046E-04 1.155E-03 1.882E-03 2.786E-03 3.866E-03 5.119E-03 6.541E-03 8.130E-03 9.880E-03 1.179E-02 1.384E-02 1.604E-02 1.837E-02 2.084E-02 2.342E-02 2.611E-02 2.891E-02 3.180E-02 3.477E-02 3.782E-02 4.093E-02 4.409E-02 4.730E-02 5.055E-02 5.382E-02 5.710E-02 6.039E-02 6.367E-02 6.695E-02 7.020E-02 7.343E-02 7.661E-02 7.976E-02 8.285E-02 8.588E-02 8.885E-02 9.174E-02 9.456E-02 9.730E-02 9.995E-02 1.025E-01 1.050E-01 1.073E-01 1.096E-01 1.118E-01 1.138E-01 1.158E-01 1.176E-01 1.193E-01 1.209E-01 1.224E-01 1.238E-01 1.251E-01 1.262E-01 1.272E-01 1.281E-01 1.289E-01 1.296E-01 1.301E-01 1.305E-01 1.308E-01 1.310E-01 1.311E-01 1.310E-01 1.308E-01 1.305E-01 1.301E-01 1.296E-01 1.289E-01 1.281E-01 1.272E-01 1.262E-01 1.251E-01 1.238E-01 1.224E-01 1.209E-01 1.193E-01 1.176E-01 1.158E-01 1.138E-01 1.118E-01 1.096E-01 1.073E-01 1.050E-01 1.025E-01 9.995E-02 9.730E-02 9.456E-02 9.174E-02 8.885E-02 8.588E-02 8.285E-02 7.976E-02 7.661E-02 7.343E-02 7.020E-02 6.695E-02 6.367E-02 6.039E-02 5.710E-02 5.382E-02 5.055E-02 4.730E-02 4.409E-02 4.093E-02 3.782E-02 3.477E-02 3.180E-02 2.891E-02 2.611E-02 2.342E-02 2.084E-02 1.837E-02 1.604E-02 1.384E-02 1.179E-02 9.880E-03 8.130E-03 6.541E-03 5.119E-03 3.866E-03 2.786E-03 1.882E-03 1.155E-03 6.046E-04 2.316E-04 3.466E-05 1.154E-05 1.593E-04 4.741E-04 9.513E-04 1.585E-03 2.369E-03 3.296E-03 4.359E-03 5.548E-03 6.854E-03 8.267E-03 9.777E-03 1.137E-02 1.304E-02 1.478E-02 1.656E-02 1.838E-02 2.023E-02 2.210E-02 2.396E-02 2.581E-02 2.765E-02 2.944E-02 3.119E-02 3.289E-02 3.452E-02 3.607E-02 3.753E-02 3.890E-02 4.016E-02 4.132E-02 4.236E-02 4.327E-02 4.406E-02 4.471E-02 4.523E-02 4.562E-02 4.586E-02 4.597E-02 4.593E-02 4.577E-02 4.546E-02 4.503E-02 4.447E-02 4.378E-02 4.298E-02 4.206E-02 4.104E-02 3.992E-02 3.871E-02 3.741E-02 3.605E-02 3.461E-02 3.312E-02 3.158E-02 3.001E-02 2.840E-02 2.677E-02 2.513E-02 2.349E-02 2.186E-02 2.024E-02 1.865E-02 1.802E-02 1.961E-02 2.123E-02 2.286E-02 2.451E-02 2.616E-02 2.780E-02 2.942E-02 3.102E-02 3.258E-02 3.410E-02 3.556E-02 3.696E-02 3.829E-02 3.953E-02 4.069E-02 4.175E-02 4.270E-02 4.355E-02 4.428E-02 4.488E-02 4.535E-02 4.570E-02 4.590E-02 4.597E-02 4.590E-02 4.569E-02 4.534E-02 4.485E-02 4.422E-02 4.345E-02 4.256E-02 4.154E-02 4.039E-02 3.914E-02 3.778E-02 3.631E-02 3.476E-02 3.313E-02 3.143E-02 2.967E-02 2.786E-02 2.601E-02 2.414E-02 2.225E-02 2.037E-02 1.850E-02 1.665E-02 1.484E-02 1.309E-02 1.139E-02 9.777E-03 8.248E-03 6.817E-03 5.496E-03 4.296E-03 3.227E-03 2.296E-03 1.514E-03 8.868E-04 4.223E-04 1.261E-04 3.342E-06 5.831E-05 2.943E-04 7.135E-04 1.317E-03 2.107E-03 3.080E-03 4.237E-03 5.576E-03 7.092E-03 8.782E-03 1.064E-02 1.266E-02 1.484E-02 1.717E-02 1.965E-02 2.225E-02 2.499E-02 2.784E-02 3.080E-02 3.385E-02 3.700E-02 4.022E-02 4.351E-02 4.686E-02 5.025E-02 5.369E-02 5.714E-02 6.062E-02 6.410E-02 6.757E-02 7.104E-02 7.448E-02 7.790E-02 8.127E-02 8.460E-02 8.787E-02 9.108E-02 9.423E-02 9.730E-02 1.003E-01 1.032E-01 1.060E-01 1.087E-01 1.114E-01 1.139E-01 1.163E-01 1.186E-01 1.208E-01 1.229E-01 1.249E-01 1.267E-01 1.285E-01 1.301E-01 1.316E-01 1.330E-01 1.343E-01 1.354E-01 1.364E-01 1.374E-01 1.381E-01 1.388E-01 1.393E-01 1.398E-01 1.401E-01 1.402E-01 1.403E-01 1.402E-01 1.401E-01 1.398E-01 1.393E-01 1.388E-01 1.381E-01 1.374E-01 1.364E-01 1.354E-01 1.343E-01 1.330E-01 1.316E-01 1.301E-01 1.285E-01 1.267E-01 1.249E-01 1.229E-01 1.208E-01 1.186E-01 1.163E-01 1.139E-01 1.114E-01 1.087E-01 1.060E-01 1.032E-01 1.003E-01 9.730E-02 9.423E-02 9.108E-02 8.787E-02 8.460E-02 8.127E-02 7.790E-02 7.448E-02 7.104E-02 6.757E-02 6.410E-02 6.062E-02 5.714E-02 5.369E-02 5.025E-02 4.686E-02 4.351E-02 4.022E-02 3.700E-02 3.385E-02 3.080E-02 2.784E-02 2.499E-02 2.225E-02 1.965E-02 1.717E-02 1.484E-02 1.266E-02 1.064E-02 8.782E-03 7.092E-03 5.576E-03 4.237E-03 3.080E-03 2.107E-03 1.317E-03 7.135E-04 2.943E-04 5.831E-05 3.342E-06 1.261E-04 4.223E-04 8.868E-04 1.514E-03 2.296E-03 3.227E-03 4.296E-03 5.496E-03 6.817E-03 8.248E-03 9.777E-03 1.139E-02 1.309E-02 1.484E-02 1.665E-02 1.850E-02 2.037E-02 2.225E-02 2.414E-02 2.601E-02 2.786E-02 2.967E-02 3.143E-02 3.313E-02 3.476E-02 3.631E-02 3.778E-02 3.914E-02 4.039E-02 4.154E-02 4.256E-02 4.345E-02 4.422E-02 4.485E-02 4.534E-02 4.569E-02 4.590E-02 4.597E-02 4.590E-02 4.570E-02 4.535E-02 4.488E-02 4.428E-02 4.355E-02 4.270E-02 4.175E-02 4.069E-02 3.953E-02 3.829E-02 3.696E-02 3.556E-02 3.410E-02 3.258E-02 3.102E-02 2.942E-02 2.780E-02 2.616E-02 2.451E-02 2.286E-02 2.123E-02 1.961E-02 1.896E-02 2.057E-02 2.221E-02 2.386E-02 2.551E-02 2.717E-02 2.881E-02 3.042E-02 3.201E-02 3.355E-02 3.504E-02 3.647E-02 3.783E-02 3.912E-02 4.031E-02 4.141E-02 4.241E-02 4.329E-02 4.406E-02 4.471E-02 4.523E-02 4.561E-02 4.586E-02 4.597E-02 4.593E-02 4.576E-02 4.544E-02 4.498E-02 4.438E-02 4.364E-02 4.277E-02 4.177E-02 4.064E-02 3.940E-02 3.805E-02 3.659E-02 3.504E-02 3.341E-02 3.170E-02 2.993E-02 2.811E-02 2.625E-02 2.436E-02 2.245E-02 2.055E-02 1.866E-02 1.679E-02 1.496E-02 1.317E-02 1.146E-02 9.818E-03 8.267E-03 6.817E-03 5.479E-03 4.265E-03 3.185E-03 2.248E-03 1.464E-03 8.399E-04 3.839E-04 1.022E-04 2.914E-07 8.280E-05 3.533E-04 8.144E-04 1.468E-03 2.314E-03 3.353E-03 4.583E-03 6.003E-03 7.608E-03 9.396E-03 1.136E-02 1.350E-02 1.580E-02 1.825E-02 2.086E-02 2.361E-02 2.650E-02 2.950E-02 3.262E-02 3.584E-02 3.916E-02 4.255E-02 4.602E-02 4.955E-02 5.313E-02 5.674E-02 6.039E-02 6.405E-02 6.772E-02 7.139E-02 7.504E-02 7.867E-02 8.227E-02 8.583E-02 8.934E-02 9.279E-02 9.618E-02 9.950E-02 1.027E-01 1.059E-01 1.090E-01 1.120E-01 1.148E-01 1.176E-01 1.203E-01 1.228E-01 1.253E-01 1.276E-01 1.299E-01 1.320E-01 1.340E-01 1.358E-01 1.376E-01 1.392E-01 1.407E-01 1.421E-01 1.434E-01 1.445E-01 1.456E-01 1.465E-01 1.472E-01 1.479E-01 1.484E-01 1.489E-01 1.492E-01 1.493E-01 1.494E-01 1.493E-01 1.492E-01 1.489E-01 1.484E-01 1.479E-01 1.472E-01 1.465E-01 1.456E-01 1.445E-01 1.434E-01 1.421E-01 1.407E-01 1.392E-01 1.376E-01 1.358E-01 1.340E-01 1.320E-01 1.299E-01 1.276E-01 1.253E-01 1.228E-01 1.203E-01 1.176E-01 1.148E-01 1.120E-01 1.090E-01 1.059E-01 1.027E-01 9.950E-02 9.618E-02 9.279E-02 8.934E-02 8.583E-02 8.227E-02 7.867E-02 7.504E-02 7.139E-02 6.772E-02 6.405E-02 6.039E-02 5.674E-02 5.313E-02 4.955E-02 4.602E-02 4.255E-02 3.916E-02 3.584E-02 3.262E-02 2.950E-02 2.650E-02 2.361E-02 2.086E-02 1.825E-02 1.580E-02 1.350E-02 1.136E-02 9.396E-03 7.608E-03 6.003E-03 4.583E-03 3.353E-03 2.314E-03 1.468E-03 8.144E-04 3.533E-04 8.280E-05 2.914E-07 1.022E-04 3.839E-04 8.399E-04 1.464E-03 2.248E-03 3.185E-03 4.265E-03 5.479E-03 6.817E-03 8.267E-03 9.818E-03 1.146E-02 1.317E-02 1.496E-02 1.679E-02 1.866E-02 2.055E-02 2.245E-02 2.436E-02 2.625E-02 2.811E-02 2.993E-02 3.170E-02 3.341E-02 3.504E-02 3.659E-02 3.805E-02 3.940E-02 4.064E-02 4.177E-02 4.277E-02 4.364E-02 4.438E-02 4.498E-02 4.544E-02 4.576E-02 4.593E-02 4.597E-02 4.586E-02 4.561E-02 4.523E-02 4.471E-02 4.406E-02 4.329E-02 4.241E-02 4.141E-02 4.031E-02 3.912E-02 3.783E-02 3.647E-02 3.504E-02 3.355E-02 3.201E-02 3.042E-02 2.881E-02 2.717E-02 2.551E-02 2.386E-02 2.221E-02 2.057E-02 1.989E-02 2.153E-02 2.318E-02 2.485E-02 2.651E-02 2.816E-02 2.980E-02 3.141E-02 3.297E-02 3.449E-02 3.596E-02 3.735E-02 3.867E-02 3.990E-02 4.104E-02 4.208E-02 4.301E-02 4.382E-02 4.451E-02 4.508E-02 4.551E-02 4.580E-02 4.595E-02 4.596E-02 4.582E-02 4.554E-02 4.512E-02 4.455E-02 4.384E-02 4.300E-02 4.202E-02 4.091E-02 3.969E-02 3.834E-02 3.690E-02 3.535E-02 3.372E-02 3.201E-02 3.023E-02 2.840E-02 2.653E-02 2.462E-02 2.270E-02 2.078E-02 1.886E-02 1.697E-02 1.511E-02 1.331E-02 1.156E-02 9.900E-03 8.326E-03 6.854E-03 5.496E-03 4.265E-03 3.171E-03 2.224E-03 1.434E-03 8.092E-04 3.575E-04 8.587E-05 2.162E-07 1.055E-04 4.058E-04 9.039E-04 1.602E-03 2.501E-03 3.600E-03 4.898E-03 6.394E-03 8.084E-03 9.965E-03 1.203E-02 1.427E-02 1.669E-02 1.927E-02 2.201E-02 2.490E-02 2.793E-02 3.109E-02 3.436E-02 3.775E-02 4.123E-02 4.480E-02 4.844E-02 5.215E-02 5.591E-02 5.971E-02 6.353E-02 6.738E-02 7.124E-02 7.509E-02 7.893E-02 8.274E-02 8.652E-02 9.026E-02 9.395E-02 9.758E-02 1.011E-01 1.046E-01 1.080E-01 1.114E-01 1.146E-01 1.177E-01 1.208E-01 1.237E-01 1.265E-01 1.292E-01 1.318E-01 1.343E-01 1.366E-01 1.389E-01 1.410E-01 1.430E-01 1.448E-01 1.466E-01 1.482E-01 1.497E-01 1.511E-01 1.523E-01 1.535E-01 1.545E-01 1.554E-01 1.562E-01 1.568E-01 1.573E-01 1.578E-01 1.580E-01 1.582E-01 1.583E-01 1.582E-01 1.580E-01 1.578E-01 1.573E-01 1.568E-01 1.562E-01 1.554E-01 1.545E-01 1.535E-01 1.523E-01 1.511E-01 1.497E-01 1.482E-01 1.466E-01 1.448E-01 1.430E-01 1.410E-01 1.389E-01 1.366E-01 1.343E-01 1.318E-01 1.292E-01 1.265E-01 1.237E-01 1.208E-01 1.177E-01 1.146E-01 1.114E-01 1.080E-01 1.046E-01 1.011E-01 9.758E-02 9.395E-02 9.026E-02 8.652E-02 8.274E-02 7.893E-02 7.509E-02 7.124E-02 6.738E-02 6.353E-02 5.971E-02 5.591E-02 5.215E-02 4.844E-02 4.480E-02 4.123E-02 3.775E-02 3.436E-02 3.109E-02 2.793E-02 2.490E-02 2.201E-02 1.927E-02 1.669E-02 1.427E-02 1.203E-02 9.965E-03 8.084E-03 6.394E-03 4.898E-03 3.600E-03 2.501E-03 1.602E-03 9.039E-04 4.058E-04 1.055E-04 2.162E-07 8.587E-05 3.575E-04 8.092E-04 1.434E-03 2.224E-03 3.171E-03 4.265E-03 5.496E-03 6.854E-03 8.326E-03 9.900E-03 1.156E-02 1.331E-02 1.511E-02 1.697E-02 1.886E-02 2.078E-02 2.270E-02 2.462E-02 2.653E-02 2.840E-02 3.023E-02 3.201E-02 3.372E-02 3.535E-02 3.690E-02 3.834E-02 3.969E-02 4.091E-02 4.202E-02 4.300E-02 4.384E-02 4.455E-02 4.512E-02 4.554E-02 4.582E-02 4.596E-02 4.595E-02 4.580E-02 4.551E-02 4.508E-02 4.451E-02 4.382E-02 4.301E-02 4.208E-02 4.104E-02 3.990E-02 3.867E-02 3.735E-02 3.596E-02 3.449E-02 3.297E-02 3.141E-02 2.980E-02 2.816E-02 2.651E-02 2.485E-02 2.318E-02 2.153E-02 2.083E-02 2.249E-02 2.416E-02 2.583E-02 2.750E-02 2.915E-02 3.077E-02 3.237E-02 3.391E-02 3.541E-02 3.684E-02 3.819E-02 3.946E-02 4.065E-02 4.173E-02 4.270E-02 4.356E-02 4.430E-02 4.491E-02 4.538E-02 4.572E-02 4.592E-02 4.597E-02 4.588E-02 4.564E-02 4.525E-02 4.472E-02 4.405E-02 4.323E-02 4.228E-02 4.120E-02 3.999E-02 3.866E-02 3.723E-02 3.569E-02 3.406E-02 3.235E-02 3.057E-02 2.873E-02 2.685E-02 2.493E-02 2.299E-02 2.105E-02 1.911E-02 1.719E-02 1.531E-02 1.348E-02 1.171E-02 1.002E-02 8.424E-03 6.928E-03 5.548E-03 4.296E-03 3.185E-03 2.224E-03 1.424E-03 7.941E-04 3.421E-04 7.576E-05 1.402E-06 1.244E-04 4.492E-04 9.791E-04 1.716E-03 2.662E-03 3.816E-03 5.178E-03 6.745E-03 8.514E-03 1.048E-02 1.264E-02 1.499E-02 1.752E-02 2.022E-02 2.309E-02 2.611E-02 2.928E-02 3.259E-02 3.602E-02 3.956E-02 4.320E-02 4.694E-02 5.076E-02 5.464E-02 5.857E-02 6.255E-02 6.657E-02 7.060E-02 7.463E-02 7.867E-02 8.269E-02 8.668E-02 9.065E-02 9.456E-02 9.843E-02 1.022E-01 1.060E-01 1.096E-01 1.132E-01 1.167E-01 1.200E-01 1.233E-01 1.265E-01 1.296E-01 1.325E-01 1.354E-01 1.381E-01 1.407E-01 1.431E-01 1.455E-01 1.477E-01 1.498E-01 1.518E-01 1.537E-01 1.554E-01 1.570E-01 1.585E-01 1.598E-01 1.611E-01 1.622E-01 1.632E-01 1.640E-01 1.648E-01 1.654E-01 1.659E-01 1.663E-01 1.666E-01 1.668E-01 1.669E-01 1.668E-01 1.666E-01 1.663E-01 1.659E-01 1.654E-01 1.648E-01 1.640E-01 1.632E-01 1.622E-01 1.611E-01 1.598E-01 1.585E-01 1.570E-01 1.554E-01 1.537E-01 1.518E-01 1.498E-01 1.477E-01 1.455E-01 1.431E-01 1.407E-01 1.381E-01 1.354E-01 1.325E-01 1.296E-01 1.265E-01 1.233E-01 1.200E-01 1.167E-01 1.132E-01 1.096E-01 1.060E-01 1.022E-01 9.843E-02 9.456E-02 9.065E-02 8.668E-02 8.269E-02 7.867E-02 7.463E-02 7.060E-02 6.657E-02 6.255E-02 5.857E-02 5.464E-02 5.076E-02 4.694E-02 4.320E-02 3.956E-02 3.602E-02 3.259E-02 2.928E-02 2.611E-02 2.309E-02 2.022E-02 1.752E-02 1.499E-02 1.264E-02 1.048E-02 8.514E-03 6.745E-03 5.178E-03 3.816E-03 2.662E-03 1.716E-03 9.791E-04 4.492E-04 1.244E-04 1.402E-06 7.576E-05 3.421E-04 7.941E-04 1.424E-03 2.224E-03 3.185E-03 4.296E-03 5.548E-03 6.928E-03 8.424E-03 1.002E-02 1.171E-02 1.348E-02 1.531E-02 1.719E-02 1.911E-02 2.105E-02 2.299E-02 2.493E-02 2.685E-02 2.873E-02 3.057E-02 3.235E-02 3.406E-02 3.569E-02 3.723E-02 3.866E-02 3.999E-02 4.120E-02 4.228E-02 4.323E-02 4.405E-02 4.472E-02 4.525E-02 4.564E-02 4.588E-02 4.597E-02 4.592E-02 4.572E-02 4.538E-02 4.491E-02 4.430E-02 4.356E-02 4.270E-02 4.173E-02 4.065E-02 3.946E-02 3.819E-02 3.684E-02 3.541E-02 3.391E-02 3.237E-02 3.077E-02 2.915E-02 2.750E-02 2.583E-02 2.416E-02 2.249E-02 2.177E-02 2.344E-02 2.512E-02 2.680E-02 2.847E-02 3.011E-02 3.173E-02 3.330E-02 3.482E-02 3.629E-02 3.768E-02 3.899E-02 4.022E-02 4.134E-02 4.236E-02 4.327E-02 4.405E-02 4.471E-02 4.524E-02 4.562E-02 4.587E-02 4.597E-02 4.592E-02 4.573E-02 4.538E-02 4.489E-02 4.425E-02 4.347E-02 4.255E-02 4.150E-02 4.031E-02 3.901E-02 3.758E-02 3.606E-02 3.444E-02 3.273E-02 3.095E-02 2.910E-02 2.721E-02 2.528E-02 2.333E-02 2.136E-02 1.940E-02 1.747E-02 1.556E-02 1.370E-02 1.191E-02 1.019E-02 8.561E-03 7.039E-03 5.634E-03 4.359E-03 3.227E-03 2.248E-03 1.434E-03 7.941E-04 3.371E-04 7.095E-05 2.612E-06 1.379E-04 4.817E-04 1.038E-03 1.808E-03 2.795E-03 3.998E-03 5.417E-03 7.050E-03 8.893E-03 1.094E-02 1.319E-02 1.564E-02 1.828E-02 2.110E-02 2.408E-02 2.724E-02 3.054E-02 3.399E-02 3.757E-02 4.127E-02 4.507E-02 4.897E-02 5.296E-02 5.701E-02 6.112E-02 6.528E-02 6.947E-02 7.368E-02 7.790E-02 8.211E-02 8.631E-02 9.048E-02 9.462E-02 9.871E-02 1.027E-01 1.067E-01 1.106E-01 1.144E-01 1.181E-01 1.218E-01 1.253E-01 1.287E-01 1.320E-01 1.352E-01 1.383E-01 1.413E-01 1.441E-01 1.468E-01 1.494E-01 1.519E-01 1.542E-01 1.564E-01 1.585E-01 1.604E-01 1.622E-01 1.639E-01 1.655E-01 1.669E-01 1.682E-01 1.694E-01 1.705E-01 1.715E-01 1.723E-01 1.731E-01 1.737E-01 1.742E-01 1.746E-01 1.749E-01 1.750E-01 1.751E-01 1.750E-01 1.749E-01 1.746E-01 1.742E-01 1.737E-01 1.731E-01 1.723E-01 1.715E-01 1.705E-01 1.694E-01 1.682E-01 1.669E-01 1.655E-01 1.639E-01 1.622E-01 1.604E-01 1.585E-01 1.564E-01 1.542E-01 1.519E-01 1.494E-01 1.468E-01 1.441E-01 1.413E-01 1.383E-01 1.352E-01 1.320E-01 1.287E-01 1.253E-01 1.218E-01 1.181E-01 1.144E-01 1.106E-01 1.067E-01 1.027E-01 9.871E-02 9.462E-02 9.048E-02 8.631E-02 8.211E-02 7.790E-02 7.368E-02 6.947E-02 6.528E-02 6.112E-02 5.701E-02 5.296E-02 4.897E-02 4.507E-02 4.127E-02 3.757E-02 3.399E-02 3.054E-02 2.724E-02 2.408E-02 2.110E-02 1.828E-02 1.564E-02 1.319E-02 1.094E-02 8.893E-03 7.050E-03 5.417E-03 3.998E-03 2.795E-03 1.808E-03 1.038E-03 4.817E-04 1.379E-04 2.612E-06 7.095E-05 3.371E-04 7.941E-04 1.434E-03 2.248E-03 3.227E-03 4.359E-03 5.634E-03 7.039E-03 8.561E-03 1.019E-02 1.191E-02 1.370E-02 1.556E-02 1.747E-02 1.940E-02 2.136E-02 2.333E-02 2.528E-02 2.721E-02 2.910E-02 3.095E-02 3.273E-02 3.444E-02 3.606E-02 3.758E-02 3.901E-02 4.031E-02 4.150E-02 4.255E-02 4.347E-02 4.425E-02 4.489E-02 4.538E-02 4.573E-02 4.592E-02 4.597E-02 4.587E-02 4.562E-02 4.524E-02 4.471E-02 4.405E-02 4.327E-02 4.236E-02 4.134E-02 4.022E-02 3.899E-02 3.768E-02 3.629E-02 3.482E-02 3.330E-02 3.173E-02 3.011E-02 2.847E-02 2.680E-02 2.512E-02 2.344E-02 2.270E-02 2.439E-02 2.608E-02 2.776E-02 2.942E-02 3.106E-02 3.266E-02 3.421E-02 3.571E-02 3.713E-02 3.849E-02 3.975E-02 4.092E-02 4.199E-02 4.294E-02 4.378E-02 4.449E-02 4.507E-02 4.550E-02 4.580E-02 4.595E-02 4.595E-02 4.581E-02 4.551E-02 4.506E-02 4.446E-02 4.372E-02 4.283E-02 4.181E-02 4.065E-02 3.937E-02 3.796E-02 3.645E-02 3.484E-02 3.314E-02 3.136E-02 2.951E-02 2.761E-02 2.567E-02 2.370E-02 2.172E-02 1.974E-02 1.778E-02 1.585E-02 1.397E-02 1.214E-02 1.040E-02 8.739E-03 7.188E-03 5.754E-03 4.453E-03 3.296E-03 2.296E-03 1.464E-03 8.092E-04 3.421E-04 7.095E-05 3.098E-06 1.449E-04 5.017E-04 1.078E-03 1.875E-03 2.897E-03 4.143E-03 5.613E-03 7.304E-03 9.215E-03 1.134E-02 1.368E-02 1.622E-02 1.896E-02 2.188E-02 2.499E-02 2.826E-02 3.170E-02 3.529E-02 3.901E-02 4.286E-02 4.682E-02 5.088E-02 5.503E-02 5.925E-02 6.353E-02 6.786E-02 7.223E-02 7.661E-02 8.101E-02 8.540E-02 8.977E-02 9.412E-02 9.843E-02 1.027E-01 1.069E-01 1.110E-01 1.151E-01 1.190E-01 1.229E-01 1.267E-01 1.304E-01 1.339E-01 1.374E-01 1.407E-01 1.439E-01 1.469E-01 1.499E-01 1.527E-01 1.554E-01 1.579E-01 1.603E-01 1.626E-01 1.648E-01 1.668E-01 1.687E-01 1.705E-01 1.721E-01 1.736E-01 1.750E-01 1.763E-01 1.775E-01 1.785E-01 1.794E-01 1.802E-01 1.809E-01 1.815E-01 1.820E-01 1.824E-01 1.826E-01 1.828E-01 1.829E-01 1.828E-01 1.826E-01 1.824E-01 1.820E-01 1.815E-01 1.809E-01 1.802E-01 1.794E-01 1.785E-01 1.775E-01 1.763E-01 1.750E-01 1.736E-01 1.721E-01 1.705E-01 1.687E-01 1.668E-01 1.648E-01 1.626E-01 1.603E-01 1.579E-01 1.554E-01 1.527E-01 1.499E-01 1.469E-01 1.439E-01 1.407E-01 1.374E-01 1.339E-01 1.304E-01 1.267E-01 1.229E-01 1.190E-01 1.151E-01 1.110E-01 1.069E-01 1.027E-01 9.843E-02 9.412E-02 8.977E-02 8.540E-02 8.101E-02 7.661E-02 7.223E-02 6.786E-02 6.353E-02 5.925E-02 5.503E-02 5.088E-02 4.682E-02 4.286E-02 3.901E-02 3.529E-02 3.170E-02 2.826E-02 2.499E-02 2.188E-02 1.896E-02 1.622E-02 1.368E-02 1.134E-02 9.215E-03 7.304E-03 5.613E-03 4.143E-03 2.897E-03 1.875E-03 1.078E-03 5.017E-04 1.449E-04 3.098E-06 7.095E-05 3.421E-04 8.092E-04 1.464E-03 2.296E-03 3.296E-03 4.453E-03 5.754E-03 7.188E-03 8.739E-03 1.040E-02 1.214E-02 1.397E-02 1.585E-02 1.778E-02 1.974E-02 2.172E-02 2.370E-02 2.567E-02 2.761E-02 2.951E-02 3.136E-02 3.314E-02 3.484E-02 3.645E-02 3.796E-02 3.937E-02 4.065E-02 4.181E-02 4.283E-02 4.372E-02 4.446E-02 4.506E-02 4.551E-02 4.581E-02 4.595E-02 4.595E-02 4.580E-02 4.550E-02 4.507E-02 4.449E-02 4.378E-02 4.294E-02 4.199E-02 4.092E-02 3.975E-02 3.849E-02 3.713E-02 3.571E-02 3.421E-02 3.266E-02 3.106E-02 2.942E-02 2.776E-02 2.608E-02 2.439E-02 2.363E-02 2.533E-02 2.702E-02 2.870E-02 3.036E-02 3.198E-02 3.356E-02 3.509E-02 3.656E-02 3.795E-02 3.926E-02 4.047E-02 4.159E-02 4.259E-02 4.348E-02 4.424E-02 4.487E-02 4.536E-02 4.571E-02 4.592E-02 4.597E-02 4.587E-02 4.562E-02 4.522E-02 4.467E-02 4.397E-02 4.312E-02 4.213E-02 4.100E-02 3.975E-02 3.837E-02 3.687E-02 3.527E-02 3.358E-02 3.181E-02 2.996E-02 2.806E-02 2.611E-02 2.413E-02 2.213E-02 2.013E-02 1.815E-02 1.619E-02 1.428E-02 1.242E-02 1.065E-02 8.958E-03 7.375E-03 5.911E-03 4.580E-03 3.395E-03 2.369E-03 1.514E-03 8.399E-04 3.575E-04 7.576E-05 2.612E-06 1.449E-04 5.085E-04 1.098E-03 1.916E-03 2.966E-03 4.248E-03 5.762E-03 7.506E-03 9.478E-03 1.167E-02 1.409E-02 1.671E-02 1.955E-02 2.258E-02 2.579E-02 2.919E-02 3.275E-02 3.647E-02 4.033E-02 4.433E-02 4.844E-02 5.266E-02 5.697E-02 6.135E-02 6.580E-02 7.030E-02 7.484E-02 7.939E-02 8.396E-02 8.852E-02 9.307E-02 9.758E-02 1.021E-01 1.065E-01 1.108E-01 1.151E-01 1.193E-01 1.234E-01 1.275E-01 1.314E-01 1.352E-01 1.389E-01 1.424E-01 1.459E-01 1.492E-01 1.523E-01 1.554E-01 1.583E-01 1.611E-01 1.637E-01 1.662E-01 1.685E-01 1.708E-01 1.728E-01 1.748E-01 1.766E-01 1.783E-01 1.799E-01 1.814E-01 1.827E-01 1.839E-01 1.850E-01 1.860E-01 1.869E-01 1.876E-01 1.883E-01 1.889E-01 1.893E-01 1.897E-01 1.899E-01 1.901E-01 1.901E-01 1.901E-01 1.899E-01 1.897E-01 1.893E-01 1.889E-01 1.883E-01 1.876E-01 1.869E-01 1.860E-01 1.850E-01 1.839E-01 1.827E-01 1.814E-01 1.799E-01 1.783E-01 1.766E-01 1.748E-01 1.728E-01 1.708E-01 1.685E-01 1.662E-01 1.637E-01 1.611E-01 1.583E-01 1.554E-01 1.523E-01 1.492E-01 1.459E-01 1.424E-01 1.389E-01 1.352E-01 1.314E-01 1.275E-01 1.234E-01 1.193E-01 1.151E-01 1.108E-01 1.065E-01 1.021E-01 9.758E-02 9.307E-02 8.852E-02 8.396E-02 7.939E-02 7.484E-02 7.030E-02 6.580E-02 6.135E-02 5.697E-02 5.266E-02 4.844E-02 4.433E-02 4.033E-02 3.647E-02 3.275E-02 2.919E-02 2.579E-02 2.258E-02 1.955E-02 1.671E-02 1.409E-02 1.167E-02 9.478E-03 7.506E-03 5.762E-03 4.248E-03 2.966E-03 1.916E-03 1.098E-03 5.085E-04 1.449E-04 2.612E-06 7.576E-05 3.575E-04 8.399E-04 1.514E-03 2.369E-03 3.395E-03 4.580E-03 5.911E-03 7.375E-03 8.958E-03 1.065E-02 1.242E-02 1.428E-02 1.619E-02 1.815E-02 2.013E-02 2.213E-02 2.413E-02 2.611E-02 2.806E-02 2.996E-02 3.181E-02 3.358E-02 3.527E-02 3.687E-02 3.837E-02 3.975E-02 4.100E-02 4.213E-02 4.312E-02 4.397E-02 4.467E-02 4.522E-02 4.562E-02 4.587E-02 4.597E-02 4.592E-02 4.571E-02 4.536E-02 4.487E-02 4.424E-02 4.348E-02 4.259E-02 4.159E-02 4.047E-02 3.926E-02 3.795E-02 3.656E-02 3.509E-02 3.356E-02 3.198E-02 3.036E-02 2.870E-02 2.702E-02 2.533E-02 2.455E-02 2.626E-02 2.795E-02 2.963E-02 3.127E-02 3.288E-02 3.444E-02 3.594E-02 3.737E-02 3.872E-02 3.999E-02 4.115E-02 4.220E-02 4.314E-02 4.396E-02 4.464E-02 4.519E-02 4.560E-02 4.586E-02 4.597E-02 4.593E-02 4.573E-02 4.538E-02 4.487E-02 4.422E-02 4.341E-02 4.246E-02 4.137E-02 4.014E-02 3.879E-02 3.731E-02 3.573E-02 3.405E-02 3.229E-02 3.044E-02 2.854E-02 2.658E-02 2.459E-02 2.258E-02 2.056E-02 1.855E-02 1.657E-02 1.463E-02 1.275E-02 1.094E-02 9.219E-03 7.602E-03 6.105E-03 4.741E-03 3.524E-03 2.468E-03 1.585E-03 8.868E-04 3.839E-04 8.587E-05 1.402E-06 1.379E-04 5.017E-04 1.098E-03 1.930E-03 3.001E-03 4.312E-03 5.863E-03 7.652E-03 9.678E-03 1.194E-02 1.442E-02 1.713E-02 2.005E-02 2.317E-02 2.650E-02 3.000E-02 3.369E-02 3.753E-02 4.153E-02 4.566E-02 4.992E-02 5.429E-02 5.875E-02 6.330E-02 6.791E-02 7.258E-02 7.728E-02 8.200E-02 8.674E-02 9.147E-02 9.618E-02 1.009E-01 1.055E-01 1.101E-01 1.146E-01 1.190E-01 1.234E-01 1.276E-01 1.318E-01 1.358E-01 1.398E-01 1.436E-01 1.472E-01 1.508E-01 1.542E-01 1.575E-01 1.606E-01 1.636E-01 1.664E-01 1.691E-01 1.717E-01 1.741E-01 1.764E-01 1.785E-01 1.805E-01 1.824E-01 1.841E-01 1.857E-01 1.872E-01 1.886E-01 1.899E-01 1.910E-01 1.920E-01 1.929E-01 1.938E-01 1.945E-01 1.951E-01 1.956E-01 1.960E-01 1.963E-01 1.966E-01 1.967E-01 1.968E-01 1.967E-01 1.966E-01 1.963E-01 1.960E-01 1.956E-01 1.951E-01 1.945E-01 1.938E-01 1.929E-01 1.920E-01 1.910E-01 1.899E-01 1.886E-01 1.872E-01 1.857E-01 1.841E-01 1.824E-01 1.805E-01 1.785E-01 1.764E-01 1.741E-01 1.717E-01 1.691E-01 1.664E-01 1.636E-01 1.606E-01 1.575E-01 1.542E-01 1.508E-01 1.472E-01 1.436E-01 1.398E-01 1.358E-01 1.318E-01 1.276E-01 1.234E-01 1.190E-01 1.146E-01 1.101E-01 1.055E-01 1.009E-01 9.618E-02 9.147E-02 8.674E-02 8.200E-02 7.728E-02 7.258E-02 6.791E-02 6.330E-02 5.875E-02 5.429E-02 4.992E-02 4.566E-02 4.153E-02 3.753E-02 3.369E-02 3.000E-02 2.650E-02 2.317E-02 2.005E-02 1.713E-02 1.442E-02 1.194E-02 9.678E-03 7.652E-03 5.863E-03 4.312E-03 3.001E-03 1.930E-03 1.098E-03 5.017E-04 1.379E-04 1.402E-06 8.587E-05 3.839E-04 8.868E-04 1.585E-03 2.468E-03 3.524E-03 4.741E-03 6.105E-03 7.602E-03 9.219E-03 1.094E-02 1.275E-02 1.463E-02 1.657E-02 1.855E-02 2.056E-02 2.258E-02 2.459E-02 2.658E-02 2.854E-02 3.044E-02 3.229E-02 3.405E-02 3.573E-02 3.731E-02 3.879E-02 4.014E-02 4.137E-02 4.246E-02 4.341E-02 4.422E-02 4.487E-02 4.538E-02 4.573E-02 4.593E-02 4.597E-02 4.586E-02 4.560E-02 4.519E-02 4.464E-02 4.396E-02 4.314E-02 4.220E-02 4.115E-02 3.999E-02 3.872E-02 3.737E-02 3.594E-02 3.444E-02 3.288E-02 3.127E-02 2.963E-02 2.795E-02 2.626E-02 2.547E-02 2.717E-02 2.887E-02 3.054E-02 3.217E-02 3.376E-02 3.530E-02 3.676E-02 3.816E-02 3.946E-02 4.067E-02 4.178E-02 4.277E-02 4.364E-02 4.439E-02 4.499E-02 4.546E-02 4.578E-02 4.594E-02 4.596E-02 4.582E-02 4.552E-02 4.507E-02 4.446E-02 4.370E-02 4.279E-02 4.174E-02 4.054E-02 3.922E-02 3.778E-02 3.622E-02 3.455E-02 3.280E-02 3.096E-02 2.905E-02 2.709E-02 2.509E-02 2.307E-02 2.104E-02 1.901E-02 1.700E-02 1.503E-02 1.312E-02 1.128E-02 9.522E-03 7.870E-03 6.336E-03 4.936E-03 3.684E-03 2.594E-03 1.679E-03 9.513E-04 4.223E-04 1.022E-04 2.162E-07 1.244E-04 4.817E-04 1.078E-03 1.916E-03 3.001E-03 4.333E-03 5.913E-03 7.741E-03 9.812E-03 1.212E-02 1.467E-02 1.745E-02 2.045E-02 2.367E-02 2.709E-02 3.070E-02 3.450E-02 3.847E-02 4.259E-02 4.686E-02 5.126E-02 5.577E-02 6.039E-02 6.509E-02 6.986E-02 7.468E-02 7.955E-02 8.444E-02 8.934E-02 9.423E-02 9.910E-02 1.039E-01 1.087E-01 1.135E-01 1.181E-01 1.227E-01 1.272E-01 1.316E-01 1.359E-01 1.401E-01 1.441E-01 1.480E-01 1.518E-01 1.554E-01 1.589E-01 1.623E-01 1.655E-01 1.685E-01 1.714E-01 1.742E-01 1.768E-01 1.793E-01 1.816E-01 1.838E-01 1.858E-01 1.877E-01 1.895E-01 1.911E-01 1.926E-01 1.940E-01 1.953E-01 1.964E-01 1.975E-01 1.984E-01 1.993E-01 2.000E-01 2.007E-01 2.012E-01 2.017E-01 2.021E-01 2.024E-01 2.026E-01 2.027E-01 2.027E-01 2.027E-01 2.026E-01 2.024E-01 2.021E-01 2.017E-01 2.012E-01 2.007E-01 2.000E-01 1.993E-01 1.984E-01 1.975E-01 1.964E-01 1.953E-01 1.940E-01 1.926E-01 1.911E-01 1.895E-01 1.877E-01 1.858E-01 1.838E-01 1.816E-01 1.793E-01 1.768E-01 1.742E-01 1.714E-01 1.685E-01 1.655E-01 1.623E-01 1.589E-01 1.554E-01 1.518E-01 1.480E-01 1.441E-01 1.401E-01 1.359E-01 1.316E-01 1.272E-01 1.227E-01 1.181E-01 1.135E-01 1.087E-01 1.039E-01 9.910E-02 9.423E-02 8.934E-02 8.444E-02 7.955E-02 7.468E-02 6.986E-02 6.509E-02 6.039E-02 5.577E-02 5.126E-02 4.686E-02 4.259E-02 3.847E-02 3.450E-02 3.070E-02 2.709E-02 2.367E-02 2.045E-02 1.745E-02 1.467E-02 1.212E-02 9.812E-03 7.741E-03 5.913E-03 4.333E-03 3.001E-03 1.916E-03 1.078E-03 4.817E-04 1.244E-04 2.162E-07 1.022E-04 4.223E-04 9.513E-04 1.679E-03 2.594E-03 3.684E-03 4.936E-03 6.336E-03 7.870E-03 9.522E-03 1.128E-02 1.312E-02 1.503E-02 1.700E-02 1.901E-02 2.104E-02 2.307E-02 2.509E-02 2.709E-02 2.905E-02 3.096E-02 3.280E-02 3.455E-02 3.622E-02 3.778E-02 3.922E-02 4.054E-02 4.174E-02 4.279E-02 4.370E-02 4.446E-02 4.507E-02 4.552E-02 4.582E-02 4.596E-02 4.594E-02 4.578E-02 4.546E-02 4.499E-02 4.439E-02 4.364E-02 4.277E-02 4.178E-02 4.067E-02 3.946E-02 3.816E-02 3.676E-02 3.530E-02 3.376E-02 3.217E-02 3.054E-02 2.887E-02 2.717E-02 2.637E-02 2.808E-02 2.977E-02 3.143E-02 3.304E-02 3.461E-02 3.612E-02 3.755E-02 3.890E-02 4.016E-02 4.132E-02 4.237E-02 4.330E-02 4.410E-02 4.476E-02 4.529E-02 4.567E-02 4.590E-02 4.597E-02 4.589E-02 4.565E-02 4.525E-02 4.470E-02 4.399E-02 4.312E-02 4.211E-02 4.096E-02 3.967E-02 3.826E-02 3.672E-02 3.508E-02 3.333E-02 3.151E-02 2.961E-02 2.765E-02 2.564E-02 2.360E-02 2.155E-02 1.951E-02 1.748E-02 1.548E-02 1.354E-02 1.166E-02 9.869E-03 8.179E-03 6.607E-03 5.168E-03 3.877E-03 2.748E-03 1.797E-03 1.035E-03 4.741E-04 1.261E-04 2.914E-07 1.055E-04 4.492E-04 1.038E-03 1.875E-03 2.966E-03 4.312E-03 5.913E-03 7.770E-03 9.880E-03 1.224E-02 1.484E-02 1.769E-02 2.076E-02 2.406E-02 2.757E-02 3.128E-02 3.518E-02 3.927E-02 4.351E-02 4.791E-02 5.244E-02 5.710E-02 6.186E-02 6.671E-02 7.163E-02 7.661E-02 8.164E-02 8.668E-02 9.174E-02 9.680E-02 1.018E-01 1.068E-01 1.118E-01 1.167E-01 1.215E-01 1.262E-01 1.308E-01 1.354E-01 1.398E-01 1.441E-01 1.482E-01 1.522E-01 1.561E-01 1.598E-01 1.634E-01 1.668E-01 1.701E-01 1.732E-01 1.761E-01 1.789E-01 1.816E-01 1.841E-01 1.864E-01 1.886E-01 1.906E-01 1.926E-01 1.943E-01 1.960E-01 1.975E-01 1.989E-01 2.001E-01 2.013E-01 2.024E-01 2.033E-01 2.042E-01 2.049E-01 2.056E-01 2.062E-01 2.066E-01 2.071E-01 2.074E-01 2.077E-01 2.078E-01 2.079E-01 2.080E-01 2.079E-01 2.078E-01 2.077E-01 2.074E-01 2.071E-01 2.066E-01 2.062E-01 2.056E-01 2.049E-01 2.042E-01 2.033E-01 2.024E-01 2.013E-01 2.001E-01 1.989E-01 1.975E-01 1.960E-01 1.943E-01 1.926E-01 1.906E-01 1.886E-01 1.864E-01 1.841E-01 1.816E-01 1.789E-01 1.761E-01 1.732E-01 1.701E-01 1.668E-01 1.634E-01 1.598E-01 1.561E-01 1.522E-01 1.482E-01 1.441E-01 1.398E-01 1.354E-01 1.308E-01 1.262E-01 1.215E-01 1.167E-01 1.118E-01 1.068E-01 1.018E-01 9.680E-02 9.174E-02 8.668E-02 8.164E-02 7.661E-02 7.163E-02 6.671E-02 6.186E-02 5.710E-02 5.244E-02 4.791E-02 4.351E-02 3.927E-02 3.518E-02 3.128E-02 2.757E-02 2.406E-02 2.076E-02 1.769E-02 1.484E-02 1.224E-02 9.880E-03 7.770E-03 5.913E-03 4.312E-03 2.966E-03 1.875E-03 1.038E-03 4.492E-04 1.055E-04 2.914E-07 1.261E-04 4.741E-04 1.035E-03 1.797E-03 2.748E-03 3.877E-03 5.168E-03 6.607E-03 8.179E-03 9.869E-03 1.166E-02 1.354E-02 1.548E-02 1.748E-02 1.951E-02 2.155E-02 2.360E-02 2.564E-02 2.765E-02 2.961E-02 3.151E-02 3.333E-02 3.508E-02 3.672E-02 3.826E-02 3.967E-02 4.096E-02 4.211E-02 4.312E-02 4.399E-02 4.470E-02 4.525E-02 4.565E-02 4.589E-02 4.597E-02 4.590E-02 4.567E-02 4.529E-02 4.476E-02 4.410E-02 4.330E-02 4.237E-02 4.132E-02 4.016E-02 3.890E-02 3.755E-02 3.612E-02 3.461E-02 3.304E-02 3.143E-02 2.977E-02 2.808E-02 2.726E-02 2.897E-02 3.065E-02 3.229E-02 3.389E-02 3.544E-02 3.691E-02 3.831E-02 3.962E-02 4.083E-02 4.193E-02 4.291E-02 4.377E-02 4.450E-02 4.509E-02 4.553E-02 4.582E-02 4.596E-02 4.594E-02 4.576E-02 4.542E-02 4.492E-02 4.427E-02 4.346E-02 4.249E-02 4.138E-02 4.013E-02 3.875E-02 3.724E-02 3.562E-02 3.390E-02 3.209E-02 3.019E-02 2.823E-02 2.622E-02 2.418E-02 2.212E-02 2.005E-02 1.800E-02 1.597E-02 1.400E-02 1.209E-02 1.026E-02 8.532E-03 6.918E-03 5.437E-03 4.103E-03 2.933E-03 1.940E-03 1.139E-03 5.414E-04 1.593E-04 3.342E-06 8.280E-05 4.058E-04 9.791E-04 1.808E-03 2.897E-03 4.248E-03 5.863E-03 7.741E-03 9.880E-03 1.228E-02 1.493E-02 1.783E-02 2.097E-02 2.434E-02 2.793E-02 3.173E-02 3.574E-02 3.993E-02 4.429E-02 4.881E-02 5.347E-02 5.826E-02 6.316E-02 6.815E-02 7.323E-02 7.836E-02 8.353E-02 8.874E-02 9.395E-02 9.916E-02 1.043E-01 1.095E-01 1.146E-01 1.196E-01 1.246E-01 1.294E-01 1.342E-01 1.389E-01 1.434E-01 1.478E-01 1.520E-01 1.562E-01 1.601E-01 1.639E-01 1.676E-01 1.710E-01 1.744E-01 1.775E-01 1.805E-01 1.833E-01 1.860E-01 1.885E-01 1.908E-01 1.930E-01 1.951E-01 1.970E-01 1.987E-01 2.004E-01 2.019E-01 2.032E-01 2.045E-01 2.056E-01 2.066E-01 2.076E-01 2.084E-01 2.092E-01 2.098E-01 2.104E-01 2.109E-01 2.113E-01 2.116E-01 2.119E-01 2.121E-01 2.123E-01 2.124E-01 2.124E-01 2.124E-01 2.123E-01 2.121E-01 2.119E-01 2.116E-01 2.113E-01 2.109E-01 2.104E-01 2.098E-01 2.092E-01 2.084E-01 2.076E-01 2.066E-01 2.056E-01 2.045E-01 2.032E-01 2.019E-01 2.004E-01 1.987E-01 1.970E-01 1.951E-01 1.930E-01 1.908E-01 1.885E-01 1.860E-01 1.833E-01 1.805E-01 1.775E-01 1.744E-01 1.710E-01 1.676E-01 1.639E-01 1.601E-01 1.562E-01 1.520E-01 1.478E-01 1.434E-01 1.389E-01 1.342E-01 1.294E-01 1.246E-01 1.196E-01 1.146E-01 1.095E-01 1.043E-01 9.916E-02 9.395E-02 8.874E-02 8.353E-02 7.836E-02 7.323E-02 6.815E-02 6.316E-02 5.826E-02 5.347E-02 4.881E-02 4.429E-02 3.993E-02 3.574E-02 3.173E-02 2.793E-02 2.434E-02 2.097E-02 1.783E-02 1.493E-02 1.228E-02 9.880E-03 7.741E-03 5.863E-03 4.248E-03 2.897E-03 1.808E-03 9.791E-04 4.058E-04 8.280E-05 3.342E-06 1.593E-04 5.414E-04 1.139E-03 1.940E-03 2.933E-03 4.103E-03 5.437E-03 6.918E-03 8.532E-03 1.026E-02 1.209E-02 1.400E-02 1.597E-02 1.800E-02 2.005E-02 2.212E-02 2.418E-02 2.622E-02 2.823E-02 3.019E-02 3.209E-02 3.390E-02 3.562E-02 3.724E-02 3.875E-02 4.013E-02 4.138E-02 4.249E-02 4.346E-02 4.427E-02 4.492E-02 4.542E-02 4.576E-02 4.594E-02 4.596E-02 4.582E-02 4.553E-02 4.509E-02 4.450E-02 4.377E-02 4.291E-02 4.193E-02 4.083E-02 3.962E-02 3.831E-02 3.691E-02 3.544E-02 3.389E-02 3.229E-02 3.065E-02 2.897E-02 2.814E-02 2.984E-02 3.151E-02 3.314E-02 3.472E-02 3.623E-02 3.767E-02 3.903E-02 4.029E-02 4.145E-02 4.249E-02 4.341E-02 4.420E-02 4.485E-02 4.536E-02 4.572E-02 4.592E-02 4.597E-02 4.585E-02 4.558E-02 4.514E-02 4.454E-02 4.378E-02 4.287E-02 4.181E-02 4.060E-02 3.926E-02 3.778E-02 3.619E-02 3.449E-02 3.269E-02 3.081E-02 2.886E-02 2.685E-02 2.480E-02 2.272E-02 2.064E-02 1.856E-02 1.652E-02 1.451E-02 1.256E-02 1.070E-02 8.928E-03 7.272E-03 5.746E-03 4.367E-03 3.150E-03 2.112E-03 1.266E-03 6.262E-04 2.042E-04 1.154E-05 5.831E-05 3.533E-04 9.039E-04 1.716E-03 2.795E-03 4.143E-03 5.762E-03 7.652E-03 9.812E-03 1.224E-02 1.493E-02 1.787E-02 2.107E-02 2.451E-02 2.817E-02 3.206E-02 3.616E-02 4.044E-02 4.491E-02 4.955E-02 5.433E-02 5.925E-02 6.429E-02 6.942E-02 7.463E-02 7.991E-02 8.524E-02 9.059E-02 9.596E-02 1.013E-01 1.067E-01 1.120E-01 1.172E-01 1.224E-01 1.275E-01 1.325E-01 1.374E-01 1.421E-01 1.468E-01 1.513E-01 1.556E-01 1.598E-01 1.639E-01 1.677E-01 1.714E-01 1.750E-01 1.783E-01 1.815E-01 1.845E-01 1.874E-01 1.901E-01 1.926E-01 1.949E-01 1.971E-01 1.991E-01 2.010E-01 2.027E-01 2.043E-01 2.057E-01 2.071E-01 2.083E-01 2.094E-01 2.103E-01 2.112E-01 2.120E-01 2.127E-01 2.133E-01 2.139E-01 2.144E-01 2.148E-01 2.151E-01 2.154E-01 2.156E-01 2.158E-01 2.159E-01 2.160E-01 2.160E-01 2.160E-01 2.159E-01 2.158E-01 2.156E-01 2.154E-01 2.151E-01 2.148E-01 2.144E-01 2.139E-01 2.133E-01 2.127E-01 2.120E-01 2.112E-01 2.103E-01 2.094E-01 2.083E-01 2.071E-01 2.057E-01 2.043E-01 2.027E-01 2.010E-01 1.991E-01 1.971E-01 1.949E-01 1.926E-01 1.901E-01 1.874E-01 1.845E-01 1.815E-01 1.783E-01 1.750E-01 1.714E-01 1.677E-01 1.639E-01 1.598E-01 1.556E-01 1.513E-01 1.468E-01 1.421E-01 1.374E-01 1.325E-01 1.275E-01 1.224E-01 1.172E-01 1.120E-01 1.067E-01 1.013E-01 9.596E-02 9.059E-02 8.524E-02 7.991E-02 7.463E-02 6.942E-02 6.429E-02 5.925E-02 5.433E-02 4.955E-02 4.491E-02 4.044E-02 3.616E-02 3.206E-02 2.817E-02 2.451E-02 2.107E-02 1.787E-02 1.493E-02 1.224E-02 9.812E-03 7.652E-03 5.762E-03 4.143E-03 2.795E-03 1.716E-03 9.039E-04 3.533E-04 5.831E-05 1.154E-05 2.042E-04 6.262E-04 1.266E-03 2.112E-03 3.150E-03 4.367E-03 5.746E-03 7.272E-03 8.928E-03 1.070E-02 1.256E-02 1.451E-02 1.652E-02 1.856E-02 2.064E-02 2.272E-02 2.480E-02 2.685E-02 2.886E-02 3.081E-02 3.269E-02 3.449E-02 3.619E-02 3.778E-02 3.926E-02 4.060E-02 4.181E-02 4.287E-02 4.378E-02 4.454E-02 4.514E-02 4.558E-02 4.585E-02 4.597E-02 4.592E-02 4.572E-02 4.536E-02 4.485E-02 4.420E-02 4.341E-02 4.249E-02 4.145E-02 4.029E-02 3.903E-02 3.767E-02 3.623E-02 3.472E-02 3.314E-02 3.151E-02 2.984E-02 2.900E-02 3.069E-02 3.235E-02 3.396E-02 3.552E-02 3.700E-02 3.840E-02 3.972E-02 4.093E-02 4.203E-02 4.301E-02 4.386E-02 4.458E-02 4.516E-02 4.558E-02 4.585E-02 4.597E-02 4.592E-02 4.571E-02 4.534E-02 4.480E-02 4.410E-02 4.324E-02 4.223E-02 4.107E-02 3.977E-02 3.834E-02 3.678E-02 3.510E-02 3.333E-02 3.146E-02 2.951E-02 2.751E-02 2.545E-02 2.337E-02 2.127E-02 1.918E-02 1.710E-02 1.507E-02 1.309E-02 1.118E-02 9.370E-03 7.669E-03 6.096E-03 4.668E-03 3.402E-03 2.314E-03 1.419E-03 7.312E-04 2.633E-04 2.751E-05 3.466E-05 2.943E-04 8.144E-04 1.602E-03 2.662E-03 3.998E-03 5.613E-03 7.506E-03 9.678E-03 1.212E-02 1.484E-02 1.783E-02 2.107E-02 2.456E-02 2.830E-02 3.226E-02 3.644E-02 4.082E-02 4.539E-02 5.013E-02 5.503E-02 6.007E-02 6.523E-02 7.050E-02 7.585E-02 8.127E-02 8.674E-02 9.224E-02 9.775E-02 1.033E-01 1.087E-01 1.142E-01 1.196E-01 1.249E-01 1.301E-01 1.352E-01 1.402E-01 1.451E-01 1.499E-01 1.545E-01 1.589E-01 1.632E-01 1.673E-01 1.713E-01 1.750E-01 1.786E-01 1.820E-01 1.852E-01 1.882E-01 1.911E-01 1.938E-01 1.962E-01 1.986E-01 2.007E-01 2.027E-01 2.045E-01 2.062E-01 2.077E-01 2.091E-01 2.104E-01 2.115E-01 2.125E-01 2.135E-01 2.143E-01 2.150E-01 2.156E-01 2.162E-01 2.167E-01 2.171E-01 2.175E-01 2.178E-01 2.180E-01 2.182E-01 2.184E-01 2.185E-01 2.186E-01 2.187E-01 2.187E-01 2.187E-01 2.186E-01 2.185E-01 2.184E-01 2.182E-01 2.180E-01 2.178E-01 2.175E-01 2.171E-01 2.167E-01 2.162E-01 2.156E-01 2.150E-01 2.143E-01 2.135E-01 2.125E-01 2.115E-01 2.104E-01 2.091E-01 2.077E-01 2.062E-01 2.045E-01 2.027E-01 2.007E-01 1.986E-01 1.962E-01 1.938E-01 1.911E-01 1.882E-01 1.852E-01 1.820E-01 1.786E-01 1.750E-01 1.713E-01 1.673E-01 1.632E-01 1.589E-01 1.545E-01 1.499E-01 1.451E-01 1.402E-01 1.352E-01 1.301E-01 1.249E-01 1.196E-01 1.142E-01 1.087E-01 1.033E-01 9.775E-02 9.224E-02 8.674E-02 8.127E-02 7.585E-02 7.050E-02 6.523E-02 6.007E-02 5.503E-02 5.013E-02 4.539E-02 4.082E-02 3.644E-02 3.226E-02 2.830E-02 2.456E-02 2.107E-02 1.783E-02 1.484E-02 1.212E-02 9.678E-03 7.506E-03 5.613E-03 3.998E-03 2.662E-03 1.602E-03 8.144E-04 2.943E-04 3.466E-05 2.751E-05 2.633E-04 7.312E-04 1.419E-03 2.314E-03 3.402E-03 4.668E-03 6.096E-03 7.669E-03 9.370E-03 1.118E-02 1.309E-02 1.507E-02 1.710E-02 1.918E-02 2.127E-02 2.337E-02 2.545E-02 2.751E-02 2.951E-02 3.146E-02 3.333E-02 3.510E-02 3.678E-02 3.834E-02 3.977E-02 4.107E-02 4.223E-02 4.324E-02 4.410E-02 4.480E-02 4.534E-02 4.571E-02 4.592E-02 4.597E-02 4.585E-02 4.558E-02 4.516E-02 4.458E-02 4.386E-02 4.301E-02 4.203E-02 4.093E-02 3.972E-02 3.840E-02 3.700E-02 3.552E-02 3.396E-02 3.235E-02 3.069E-02 2.985E-02 3.153E-02 3.317E-02 3.476E-02 3.629E-02 3.774E-02 3.910E-02 4.037E-02 4.153E-02 4.257E-02 4.349E-02 4.427E-02 4.492E-02 4.541E-02 4.575E-02 4.594E-02 4.596E-02 4.582E-02 4.551E-02 4.504E-02 4.441E-02 4.361E-02 4.266E-02 4.155E-02 4.029E-02 3.890E-02 3.738E-02 3.573E-02 3.398E-02 3.213E-02 3.020E-02 2.820E-02 2.615E-02 2.406E-02 2.195E-02 1.984E-02 1.774E-02 1.567E-02 1.366E-02 1.171E-02 9.859E-03 8.111E-03 6.489E-03 5.010E-03 3.691E-03 2.550E-03 1.601E-03 8.593E-04 3.396E-04 5.426E-05 1.486E-05 2.316E-04 7.135E-04 1.468E-03 2.501E-03 3.816E-03 5.417E-03 7.304E-03 9.478E-03 1.194E-02 1.467E-02 1.769E-02 2.097E-02 2.451E-02 2.830E-02 3.232E-02 3.658E-02 4.104E-02 4.570E-02 5.055E-02 5.555E-02 6.071E-02 6.599E-02 7.139E-02 7.687E-02 8.243E-02 8.803E-02 9.367E-02 9.933E-02 1.050E-01 1.106E-01 1.162E-01 1.217E-01 1.272E-01 1.325E-01 1.378E-01 1.429E-01 1.479E-01 1.528E-01 1.575E-01 1.620E-01 1.663E-01 1.705E-01 1.745E-01 1.783E-01 1.820E-01 1.854E-01 1.886E-01 1.916E-01 1.945E-01 1.971E-01 1.996E-01 2.019E-01 2.040E-01 2.059E-01 2.077E-01 2.093E-01 2.107E-01 2.120E-01 2.132E-01 2.143E-01 2.152E-01 2.160E-01 2.167E-01 2.174E-01 2.179E-01 2.184E-01 2.188E-01 2.191E-01 2.194E-01 2.197E-01 2.199E-01 2.200E-01 2.201E-01 2.202E-01 2.203E-01 2.204E-01 2.204E-01 2.204E-01 2.204E-01 2.204E-01 2.203E-01 2.202E-01 2.201E-01 2.200E-01 2.199E-01 2.197E-01 2.194E-01 2.191E-01 2.188E-01 2.184E-01 2.179E-01 2.174E-01 2.167E-01 2.160E-01 2.152E-01 2.143E-01 2.132E-01 2.120E-01 2.107E-01 2.093E-01 2.077E-01 2.059E-01 2.040E-01 2.019E-01 1.996E-01 1.971E-01 1.945E-01 1.916E-01 1.886E-01 1.854E-01 1.820E-01 1.783E-01 1.745E-01 1.705E-01 1.663E-01 1.620E-01 1.575E-01 1.528E-01 1.479E-01 1.429E-01 1.378E-01 1.325E-01 1.272E-01 1.217E-01 1.162E-01 1.106E-01 1.050E-01 9.933E-02 9.367E-02 8.803E-02 8.243E-02 7.687E-02 7.139E-02 6.599E-02 6.071E-02 5.555E-02 5.055E-02 4.570E-02 4.104E-02 3.658E-02 3.232E-02 2.830E-02 2.451E-02 2.097E-02 1.769E-02 1.467E-02 1.194E-02 9.478E-03 7.304E-03 5.417E-03 3.816E-03 2.501E-03 1.468E-03 7.135E-04 2.316E-04 1.486E-05 5.426E-05 3.396E-04 8.593E-04 1.601E-03 2.550E-03 3.691E-03 5.010E-03 6.489E-03 8.111E-03 9.859E-03 1.171E-02 1.366E-02 1.567E-02 1.774E-02 1.984E-02 2.195E-02 2.406E-02 2.615E-02 2.820E-02 3.020E-02 3.213E-02 3.398E-02 3.573E-02 3.738E-02 3.890E-02 4.029E-02 4.155E-02 4.266E-02 4.361E-02 4.441E-02 4.504E-02 4.551E-02 4.582E-02 4.596E-02 4.594E-02 4.575E-02 4.541E-02 4.492E-02 4.427E-02 4.349E-02 4.257E-02 4.153E-02 4.037E-02 3.910E-02 3.774E-02 3.629E-02 3.476E-02 3.317E-02 3.153E-02 3.067E-02 3.235E-02 3.397E-02 3.553E-02 3.703E-02 3.844E-02 3.976E-02 4.098E-02 4.209E-02 4.307E-02 4.392E-02 4.463E-02 4.520E-02 4.562E-02 4.587E-02 4.597E-02 4.590E-02 4.567E-02 4.527E-02 4.470E-02 4.396E-02 4.307E-02 4.202E-02 4.082E-02 3.947E-02 3.799E-02 3.638E-02 3.466E-02 3.283E-02 3.092E-02 2.893E-02 2.688E-02 2.479E-02 2.267E-02 2.054E-02 1.842E-02 1.632E-02 1.428E-02 1.229E-02 1.040E-02 8.601E-03 6.928E-03 5.395E-03 4.020E-03 2.820E-03 1.813E-03 1.014E-03 4.364E-04 9.521E-05 2.384E-06 1.690E-04 6.046E-04 1.317E-03 2.314E-03 3.600E-03 5.178E-03 7.050E-03 9.215E-03 1.167E-02 1.442E-02 1.745E-02 2.076E-02 2.434E-02 2.817E-02 3.226E-02 3.658E-02 4.112E-02 4.586E-02 5.080E-02 5.591E-02 6.117E-02 6.657E-02 7.208E-02 7.769E-02 8.338E-02 8.912E-02 9.490E-02 1.007E-01 1.065E-01 1.122E-01 1.180E-01 1.236E-01 1.292E-01 1.347E-01 1.401E-01 1.453E-01 1.504E-01 1.554E-01 1.602E-01 1.648E-01 1.692E-01 1.735E-01 1.775E-01 1.814E-01 1.850E-01 1.884E-01 1.917E-01 1.947E-01 1.975E-01 2.001E-01 2.026E-01 2.048E-01 2.068E-01 2.087E-01 2.104E-01 2.119E-01 2.133E-01 2.145E-01 2.155E-01 2.165E-01 2.173E-01 2.180E-01 2.186E-01 2.191E-01 2.196E-01 2.199E-01 2.202E-01 2.204E-01 2.206E-01 2.208E-01 2.209E-01 2.210E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.210E-01 2.209E-01 2.208E-01 2.206E-01 2.204E-01 2.202E-01 2.199E-01 2.196E-01 2.191E-01 2.186E-01 2.180E-01 2.173E-01 2.165E-01 2.155E-01 2.145E-01 2.133E-01 2.119E-01 2.104E-01 2.087E-01 2.068E-01 2.048E-01 2.026E-01 2.001E-01 1.975E-01 1.947E-01 1.917E-01 1.884E-01 1.850E-01 1.814E-01 1.775E-01 1.735E-01 1.692E-01 1.648E-01 1.602E-01 1.554E-01 1.504E-01 1.453E-01 1.401E-01 1.347E-01 1.292E-01 1.236E-01 1.180E-01 1.122E-01 1.065E-01 1.007E-01 9.490E-02 8.912E-02 8.338E-02 7.769E-02 7.208E-02 6.657E-02 6.117E-02 5.591E-02 5.080E-02 4.586E-02 4.112E-02 3.658E-02 3.226E-02 2.817E-02 2.434E-02 2.076E-02 1.745E-02 1.442E-02 1.167E-02 9.215E-03 7.050E-03 5.178E-03 3.600E-03 2.314E-03 1.317E-03 6.046E-04 1.690E-04 2.384E-06 9.521E-05 4.364E-04 1.014E-03 1.813E-03 2.820E-03 4.020E-03 5.395E-03 6.928E-03 8.601E-03 1.040E-02 1.229E-02 1.428E-02 1.632E-02 1.842E-02 2.054E-02 2.267E-02 2.479E-02 2.688E-02 2.893E-02 3.092E-02 3.283E-02 3.466E-02 3.638E-02 3.799E-02 3.947E-02 4.082E-02 4.202E-02 4.307E-02 4.396E-02 4.470E-02 4.527E-02 4.567E-02 4.590E-02 4.597E-02 4.587E-02 4.562E-02 4.520E-02 4.463E-02 4.392E-02 4.307E-02 4.209E-02 4.098E-02 3.976E-02 3.844E-02 3.703E-02 3.553E-02 3.397E-02 3.235E-02 3.148E-02 3.314E-02 3.474E-02 3.628E-02 3.774E-02 3.912E-02 4.039E-02 4.156E-02 4.261E-02 4.353E-02 4.431E-02 4.495E-02 4.544E-02 4.578E-02 4.595E-02 4.595E-02 4.579E-02 4.547E-02 4.497E-02 4.430E-02 4.347E-02 4.248E-02 4.134E-02 4.004E-02 3.861E-02 3.704E-02 3.535E-02 3.355E-02 3.166E-02 2.969E-02 2.765E-02 2.555E-02 2.343E-02 2.128E-02 1.914E-02 1.702E-02 1.494E-02 1.292E-02 1.098E-02 9.139E-03 7.413E-03 5.824E-03 4.390E-03 3.130E-03 2.060E-03 1.197E-03 5.573E-04 1.541E-04 1.084E-06 1.101E-04 4.916E-04 1.155E-03 2.107E-03 3.353E-03 4.898E-03 6.745E-03 8.893E-03 1.134E-02 1.409E-02 1.713E-02 2.045E-02 2.406E-02 2.793E-02 3.206E-02 3.644E-02 4.104E-02 4.586E-02 5.088E-02 5.608E-02 6.144E-02 6.695E-02 7.258E-02 7.831E-02 8.412E-02 8.999E-02 9.590E-02 1.018E-01 1.078E-01 1.137E-01 1.195E-01 1.253E-01 1.310E-01 1.366E-01 1.421E-01 1.475E-01 1.527E-01 1.578E-01 1.626E-01 1.673E-01 1.718E-01 1.761E-01 1.802E-01 1.841E-01 1.878E-01 1.912E-01 1.945E-01 1.975E-01 2.003E-01 2.029E-01 2.052E-01 2.074E-01 2.094E-01 2.111E-01 2.127E-01 2.141E-01 2.154E-01 2.165E-01 2.174E-01 2.182E-01 2.189E-01 2.195E-01 2.200E-01 2.203E-01 2.206E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.210E-01 2.209E-01 2.209E-01 2.208E-01 2.208E-01 2.208E-01 2.208E-01 2.208E-01 2.209E-01 2.209E-01 2.210E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.206E-01 2.203E-01 2.200E-01 2.195E-01 2.189E-01 2.182E-01 2.174E-01 2.165E-01 2.154E-01 2.141E-01 2.127E-01 2.111E-01 2.094E-01 2.074E-01 2.052E-01 2.029E-01 2.003E-01 1.975E-01 1.945E-01 1.912E-01 1.878E-01 1.841E-01 1.802E-01 1.761E-01 1.718E-01 1.673E-01 1.626E-01 1.578E-01 1.527E-01 1.475E-01 1.421E-01 1.366E-01 1.310E-01 1.253E-01 1.195E-01 1.137E-01 1.078E-01 1.018E-01 9.590E-02 8.999E-02 8.412E-02 7.831E-02 7.258E-02 6.695E-02 6.144E-02 5.608E-02 5.088E-02 4.586E-02 4.104E-02 3.644E-02 3.206E-02 2.793E-02 2.406E-02 2.045E-02 1.713E-02 1.409E-02 1.134E-02 8.893E-03 6.745E-03 4.898E-03 3.353E-03 2.107E-03 1.155E-03 4.916E-04 1.101E-04 1.084E-06 1.541E-04 5.573E-04 1.197E-03 2.060E-03 3.130E-03 4.390E-03 5.824E-03 7.413E-03 9.139E-03 1.098E-02 1.292E-02 1.494E-02 1.702E-02 1.914E-02 2.128E-02 2.343E-02 2.555E-02 2.765E-02 2.969E-02 3.166E-02 3.355E-02 3.535E-02 3.704E-02 3.861E-02 4.004E-02 4.134E-02 4.248E-02 4.347E-02 4.430E-02 4.497E-02 4.547E-02 4.579E-02 4.595E-02 4.595E-02 4.578E-02 4.544E-02 4.495E-02 4.431E-02 4.353E-02 4.261E-02 4.156E-02 4.039E-02 3.912E-02 3.774E-02 3.628E-02 3.474E-02 3.314E-02 3.227E-02 3.391E-02 3.549E-02 3.700E-02 3.843E-02 3.976E-02 4.099E-02 4.210E-02 4.309E-02 4.394E-02 4.466E-02 4.523E-02 4.564E-02 4.589E-02 4.597E-02 4.589E-02 4.564E-02 4.521E-02 4.462E-02 4.386E-02 4.294E-02 4.185E-02 4.061E-02 3.923E-02 3.771E-02 3.606E-02 3.429E-02 3.243E-02 3.047E-02 2.844E-02 2.635E-02 2.423E-02 2.207E-02 1.991E-02 1.777E-02 1.566E-02 1.360E-02 1.162E-02 9.726E-03 7.947E-03 6.300E-03 4.805E-03 3.481E-03 2.345E-03 1.414E-03 7.061E-04 2.350E-04 1.518E-05 5.944E-05 3.791E-04 9.839E-04 1.882E-03 3.080E-03 4.583E-03 6.394E-03 8.514E-03 1.094E-02 1.368E-02 1.671E-02 2.005E-02 2.367E-02 2.757E-02 3.173E-02 3.616E-02 4.082E-02 4.570E-02 5.080E-02 5.608E-02 6.154E-02 6.714E-02 7.288E-02 7.872E-02 8.465E-02 9.065E-02 9.668E-02 1.027E-01 1.088E-01 1.148E-01 1.208E-01 1.267E-01 1.326E-01 1.383E-01 1.439E-01 1.494E-01 1.547E-01 1.599E-01 1.648E-01 1.696E-01 1.742E-01 1.786E-01 1.827E-01 1.866E-01 1.903E-01 1.938E-01 1.970E-01 2.000E-01 2.027E-01 2.053E-01 2.076E-01 2.097E-01 2.116E-01 2.132E-01 2.147E-01 2.160E-01 2.171E-01 2.181E-01 2.189E-01 2.195E-01 2.201E-01 2.205E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.207E-01 2.205E-01 2.203E-01 2.201E-01 2.200E-01 2.198E-01 2.197E-01 2.196E-01 2.195E-01 2.195E-01 2.195E-01 2.195E-01 2.195E-01 2.196E-01 2.197E-01 2.198E-01 2.200E-01 2.201E-01 2.203E-01 2.205E-01 2.207E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.205E-01 2.201E-01 2.195E-01 2.189E-01 2.181E-01 2.171E-01 2.160E-01 2.147E-01 2.132E-01 2.116E-01 2.097E-01 2.076E-01 2.053E-01 2.027E-01 2.000E-01 1.970E-01 1.938E-01 1.903E-01 1.866E-01 1.827E-01 1.786E-01 1.742E-01 1.696E-01 1.648E-01 1.599E-01 1.547E-01 1.494E-01 1.439E-01 1.383E-01 1.326E-01 1.267E-01 1.208E-01 1.148E-01 1.088E-01 1.027E-01 9.668E-02 9.065E-02 8.465E-02 7.872E-02 7.288E-02 6.714E-02 6.154E-02 5.608E-02 5.080E-02 4.570E-02 4.082E-02 3.616E-02 3.173E-02 2.757E-02 2.367E-02 2.005E-02 1.671E-02 1.368E-02 1.094E-02 8.514E-03 6.394E-03 4.583E-03 3.080E-03 1.882E-03 9.839E-04 3.791E-04 5.944E-05 1.518E-05 2.350E-04 7.061E-04 1.414E-03 2.345E-03 3.481E-03 4.805E-03 6.300E-03 7.947E-03 9.726E-03 1.162E-02 1.360E-02 1.566E-02 1.777E-02 1.991E-02 2.207E-02 2.423E-02 2.635E-02 2.844E-02 3.047E-02 3.243E-02 3.429E-02 3.606E-02 3.771E-02 3.923E-02 4.061E-02 4.185E-02 4.294E-02 4.386E-02 4.462E-02 4.521E-02 4.564E-02 4.589E-02 4.597E-02 4.589E-02 4.564E-02 4.523E-02 4.466E-02 4.394E-02 4.309E-02 4.210E-02 4.099E-02 3.976E-02 3.843E-02 3.700E-02 3.549E-02 3.391E-02 3.304E-02 3.466E-02 3.622E-02 3.769E-02 3.908E-02 4.037E-02 4.154E-02 4.260E-02 4.353E-02 4.432E-02 4.496E-02 4.545E-02 4.578E-02 4.595E-02 4.595E-02 4.578E-02 4.543E-02 4.492E-02 4.423E-02 4.337E-02 4.236E-02 4.118E-02 3.985E-02 3.838E-02 3.678E-02 3.505E-02 3.321E-02 3.128E-02 2.927E-02 2.719E-02 2.506E-02 2.290E-02 2.073E-02 1.856E-02 1.643E-02 1.433E-02 1.230E-02 1.036E-02 8.532E-03 6.826E-03 5.268E-03 3.877E-03 2.671E-03 1.668E-03 8.868E-04 3.421E-04 4.919E-05 2.164E-05 2.717E-04 8.101E-04 1.646E-03 2.786E-03 4.237E-03 6.003E-03 8.084E-03 1.048E-02 1.319E-02 1.622E-02 1.955E-02 2.317E-02 2.709E-02 3.128E-02 3.574E-02 4.044E-02 4.539E-02 5.055E-02 5.591E-02 6.144E-02 6.714E-02 7.298E-02 7.893E-02 8.497E-02 9.108E-02 9.724E-02 1.034E-01 1.096E-01 1.158E-01 1.219E-01 1.279E-01 1.339E-01 1.398E-01 1.455E-01 1.511E-01 1.565E-01 1.618E-01 1.668E-01 1.717E-01 1.763E-01 1.807E-01 1.849E-01 1.889E-01 1.926E-01 1.960E-01 1.992E-01 2.022E-01 2.049E-01 2.074E-01 2.096E-01 2.116E-01 2.134E-01 2.150E-01 2.164E-01 2.175E-01 2.185E-01 2.193E-01 2.200E-01 2.204E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.209E-01 2.207E-01 2.205E-01 2.202E-01 2.198E-01 2.195E-01 2.192E-01 2.188E-01 2.185E-01 2.182E-01 2.179E-01 2.176E-01 2.174E-01 2.173E-01 2.171E-01 2.171E-01 2.171E-01 2.171E-01 2.171E-01 2.173E-01 2.174E-01 2.176E-01 2.179E-01 2.182E-01 2.185E-01 2.188E-01 2.192E-01 2.195E-01 2.198E-01 2.202E-01 2.205E-01 2.207E-01 2.209E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.204E-01 2.200E-01 2.193E-01 2.185E-01 2.175E-01 2.164E-01 2.150E-01 2.134E-01 2.116E-01 2.096E-01 2.074E-01 2.049E-01 2.022E-01 1.992E-01 1.960E-01 1.926E-01 1.889E-01 1.849E-01 1.807E-01 1.763E-01 1.717E-01 1.668E-01 1.618E-01 1.565E-01 1.511E-01 1.455E-01 1.398E-01 1.339E-01 1.279E-01 1.219E-01 1.158E-01 1.096E-01 1.034E-01 9.724E-02 9.108E-02 8.497E-02 7.893E-02 7.298E-02 6.714E-02 6.144E-02 5.591E-02 5.055E-02 4.539E-02 4.044E-02 3.574E-02 3.128E-02 2.709E-02 2.317E-02 1.955E-02 1.622E-02 1.319E-02 1.048E-02 8.084E-03 6.003E-03 4.237E-03 2.786E-03 1.646E-03 8.101E-04 2.717E-04 2.164E-05 4.919E-05 3.421E-04 8.868E-04 1.668E-03 2.671E-03 3.877E-03 5.268E-03 6.826E-03 8.532E-03 1.036E-02 1.230E-02 1.433E-02 1.643E-02 1.856E-02 2.073E-02 2.290E-02 2.506E-02 2.719E-02 2.927E-02 3.128E-02 3.321E-02 3.505E-02 3.678E-02 3.838E-02 3.985E-02 4.118E-02 4.236E-02 4.337E-02 4.423E-02 4.492E-02 4.543E-02 4.578E-02 4.595E-02 4.595E-02 4.578E-02 4.545E-02 4.496E-02 4.432E-02 4.353E-02 4.260E-02 4.154E-02 4.037E-02 3.908E-02 3.769E-02 3.622E-02 3.466E-02 3.379E-02 3.539E-02 3.691E-02 3.835E-02 3.970E-02 4.094E-02 4.207E-02 4.307E-02 4.393E-02 4.466E-02 4.523E-02 4.564E-02 4.589E-02 4.597E-02 4.588E-02 4.562E-02 4.518E-02 4.458E-02 4.379E-02 4.285E-02 4.174E-02 4.047E-02 3.905E-02 3.750E-02 3.582E-02 3.402E-02 3.211E-02 3.012E-02 2.806E-02 2.593E-02 2.377E-02 2.159E-02 1.940E-02 1.724E-02 1.511E-02 1.304E-02 1.106E-02 9.169E-03 7.403E-03 5.780E-03 4.320E-03 3.041E-03 1.963E-03 1.104E-03 4.801E-04 1.079E-04 1.764E-06 1.748E-04 6.386E-04 1.403E-03 2.477E-03 3.866E-03 5.576E-03 7.608E-03 9.965E-03 1.264E-02 1.564E-02 1.896E-02 2.258E-02 2.650E-02 3.070E-02 3.518E-02 3.993E-02 4.491E-02 5.013E-02 5.555E-02 6.117E-02 6.695E-02 7.288E-02 7.893E-02 8.508E-02 9.130E-02 9.758E-02 1.039E-01 1.102E-01 1.165E-01 1.227E-01 1.289E-01 1.350E-01 1.410E-01 1.468E-01 1.525E-01 1.580E-01 1.634E-01 1.685E-01 1.735E-01 1.782E-01 1.826E-01 1.869E-01 1.908E-01 1.946E-01 1.980E-01 2.012E-01 2.042E-01 2.068E-01 2.093E-01 2.114E-01 2.133E-01 2.150E-01 2.165E-01 2.177E-01 2.187E-01 2.196E-01 2.202E-01 2.207E-01 2.210E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.206E-01 2.202E-01 2.198E-01 2.193E-01 2.188E-01 2.182E-01 2.177E-01 2.171E-01 2.166E-01 2.161E-01 2.156E-01 2.152E-01 2.148E-01 2.144E-01 2.141E-01 2.139E-01 2.137E-01 2.136E-01 2.136E-01 2.136E-01 2.137E-01 2.139E-01 2.141E-01 2.144E-01 2.148E-01 2.152E-01 2.156E-01 2.161E-01 2.166E-01 2.171E-01 2.177E-01 2.182E-01 2.188E-01 2.193E-01 2.198E-01 2.202E-01 2.206E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.210E-01 2.207E-01 2.202E-01 2.196E-01 2.187E-01 2.177E-01 2.165E-01 2.150E-01 2.133E-01 2.114E-01 2.093E-01 2.068E-01 2.042E-01 2.012E-01 1.980E-01 1.946E-01 1.908E-01 1.869E-01 1.826E-01 1.782E-01 1.735E-01 1.685E-01 1.634E-01 1.580E-01 1.525E-01 1.468E-01 1.410E-01 1.350E-01 1.289E-01 1.227E-01 1.165E-01 1.102E-01 1.039E-01 9.758E-02 9.130E-02 8.508E-02 7.893E-02 7.288E-02 6.695E-02 6.117E-02 5.555E-02 5.013E-02 4.491E-02 3.993E-02 3.518E-02 3.070E-02 2.650E-02 2.258E-02 1.896E-02 1.564E-02 1.264E-02 9.965E-03 7.608E-03 5.576E-03 3.866E-03 2.477E-03 1.403E-03 6.386E-04 1.748E-04 1.764E-06 1.079E-04 4.801E-04 1.104E-03 1.963E-03 3.041E-03 4.320E-03 5.780E-03 7.403E-03 9.169E-03 1.106E-02 1.304E-02 1.511E-02 1.724E-02 1.940E-02 2.159E-02 2.377E-02 2.593E-02 2.806E-02 3.012E-02 3.211E-02 3.402E-02 3.582E-02 3.750E-02 3.905E-02 4.047E-02 4.174E-02 4.285E-02 4.379E-02 4.458E-02 4.518E-02 4.562E-02 4.588E-02 4.597E-02 4.589E-02 4.564E-02 4.523E-02 4.466E-02 4.393E-02 4.307E-02 4.207E-02 4.094E-02 3.970E-02 3.835E-02 3.691E-02 3.539E-02 3.452E-02 3.609E-02 3.758E-02 3.899E-02 4.029E-02 4.148E-02 4.256E-02 4.350E-02 4.430E-02 4.495E-02 4.545E-02 4.578E-02 4.595E-02 4.595E-02 4.577E-02 4.542E-02 4.489E-02 4.419E-02 4.332E-02 4.228E-02 4.108E-02 3.973E-02 3.823E-02 3.659E-02 3.483E-02 3.296E-02 3.100E-02 2.895E-02 2.684E-02 2.468E-02 2.249E-02 2.029E-02 1.810E-02 1.594E-02 1.383E-02 1.180E-02 9.859E-03 8.034E-03 6.345E-03 4.814E-03 3.459E-03 2.302E-03 1.361E-03 6.535E-04 1.963E-04 5.093E-06 9.381E-05 4.751E-04 1.160E-03 2.157E-03 3.475E-03 5.119E-03 7.092E-03 9.396E-03 1.203E-02 1.499E-02 1.828E-02 2.188E-02 2.579E-02 3.000E-02 3.450E-02 3.927E-02 4.429E-02 4.955E-02 5.503E-02 6.071E-02 6.657E-02 7.258E-02 7.872E-02 8.497E-02 9.130E-02 9.769E-02 1.041E-01 1.105E-01 1.170E-01 1.233E-01 1.296E-01 1.358E-01 1.419E-01 1.479E-01 1.537E-01 1.593E-01 1.648E-01 1.700E-01 1.750E-01 1.798E-01 1.843E-01 1.886E-01 1.926E-01 1.963E-01 1.998E-01 2.030E-01 2.059E-01 2.085E-01 2.109E-01 2.130E-01 2.148E-01 2.164E-01 2.177E-01 2.188E-01 2.197E-01 2.203E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.209E-01 2.206E-01 2.201E-01 2.196E-01 2.190E-01 2.183E-01 2.176E-01 2.169E-01 2.161E-01 2.153E-01 2.145E-01 2.138E-01 2.130E-01 2.124E-01 2.117E-01 2.111E-01 2.106E-01 2.101E-01 2.097E-01 2.094E-01 2.092E-01 2.091E-01 2.090E-01 2.091E-01 2.092E-01 2.094E-01 2.097E-01 2.101E-01 2.106E-01 2.111E-01 2.117E-01 2.124E-01 2.130E-01 2.138E-01 2.145E-01 2.153E-01 2.161E-01 2.169E-01 2.176E-01 2.183E-01 2.190E-01 2.196E-01 2.201E-01 2.206E-01 2.209E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.203E-01 2.197E-01 2.188E-01 2.177E-01 2.164E-01 2.148E-01 2.130E-01 2.109E-01 2.085E-01 2.059E-01 2.030E-01 1.998E-01 1.963E-01 1.926E-01 1.886E-01 1.843E-01 1.798E-01 1.750E-01 1.700E-01 1.648E-01 1.593E-01 1.537E-01 1.479E-01 1.419E-01 1.358E-01 1.296E-01 1.233E-01 1.170E-01 1.105E-01 1.041E-01 9.769E-02 9.130E-02 8.497E-02 7.872E-02 7.258E-02 6.657E-02 6.071E-02 5.503E-02 4.955E-02 4.429E-02 3.927E-02 3.450E-02 3.000E-02 2.579E-02 2.188E-02 1.828E-02 1.499E-02 1.203E-02 9.396E-03 7.092E-03 5.119E-03 3.475E-03 2.157E-03 1.160E-03 4.751E-04 9.381E-05 5.093E-06 1.963E-04 6.535E-04 1.361E-03 2.302E-03 3.459E-03 4.814E-03 6.345E-03 8.034E-03 9.859E-03 1.180E-02 1.383E-02 1.594E-02 1.810E-02 2.029E-02 2.249E-02 2.468E-02 2.684E-02 2.895E-02 3.100E-02 3.296E-02 3.483E-02 3.659E-02 3.823E-02 3.973E-02 4.108E-02 4.228E-02 4.332E-02 4.419E-02 4.489E-02 4.542E-02 4.577E-02 4.595E-02 4.595E-02 4.578E-02 4.545E-02 4.495E-02 4.430E-02 4.350E-02 4.256E-02 4.148E-02 4.029E-02 3.899E-02 3.758E-02 3.609E-02 3.522E-02 3.676E-02 3.822E-02 3.959E-02 4.085E-02 4.199E-02 4.301E-02 4.389E-02 4.463E-02 4.521E-02 4.563E-02 4.589E-02 4.597E-02 4.588E-02 4.562E-02 4.518E-02 4.456E-02 4.377E-02 4.280E-02 4.168E-02 4.039E-02 3.895E-02 3.737E-02 3.566E-02 3.383E-02 3.189E-02 2.987E-02 2.777E-02 2.562E-02 2.343E-02 2.122E-02 1.901E-02 1.682E-02 1.468E-02 1.260E-02 1.060E-02 8.719E-03 6.964E-03 5.361E-03 3.929E-03 2.690E-03 1.663E-03 8.671E-04 3.197E-04 3.715E-05 3.466E-05 3.258E-04 9.224E-04 1.835E-03 3.071E-03 4.639E-03 6.541E-03 8.782E-03 1.136E-02 1.427E-02 1.752E-02 2.110E-02 2.499E-02 2.919E-02 3.369E-02 3.847E-02 4.351E-02 4.881E-02 5.433E-02 6.007E-02 6.599E-02 7.208E-02 7.831E-02 8.465E-02 9.108E-02 9.758E-02 1.041E-01 1.107E-01 1.172E-01 1.237E-01 1.301E-01 1.364E-01 1.427E-01 1.487E-01 1.547E-01 1.604E-01 1.659E-01 1.713E-01 1.764E-01 1.812E-01 1.858E-01 1.901E-01 1.941E-01 1.979E-01 2.014E-01 2.045E-01 2.074E-01 2.100E-01 2.123E-01 2.143E-01 2.160E-01 2.175E-01 2.187E-01 2.196E-01 2.203E-01 2.208E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.203E-01 2.198E-01 2.191E-01 2.183E-01 2.174E-01 2.165E-01 2.155E-01 2.145E-01 2.135E-01 2.124E-01 2.114E-01 2.104E-01 2.094E-01 2.085E-01 2.076E-01 2.068E-01 2.060E-01 2.054E-01 2.048E-01 2.043E-01 2.040E-01 2.037E-01 2.035E-01 2.035E-01 2.035E-01 2.037E-01 2.040E-01 2.043E-01 2.048E-01 2.054E-01 2.060E-01 2.068E-01 2.076E-01 2.085E-01 2.094E-01 2.104E-01 2.114E-01 2.124E-01 2.135E-01 2.145E-01 2.155E-01 2.165E-01 2.174E-01 2.183E-01 2.191E-01 2.198E-01 2.203E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.208E-01 2.203E-01 2.196E-01 2.187E-01 2.175E-01 2.160E-01 2.143E-01 2.123E-01 2.100E-01 2.074E-01 2.045E-01 2.014E-01 1.979E-01 1.941E-01 1.901E-01 1.858E-01 1.812E-01 1.764E-01 1.713E-01 1.659E-01 1.604E-01 1.547E-01 1.487E-01 1.427E-01 1.364E-01 1.301E-01 1.237E-01 1.172E-01 1.107E-01 1.041E-01 9.758E-02 9.108E-02 8.465E-02 7.831E-02 7.208E-02 6.599E-02 6.007E-02 5.433E-02 4.881E-02 4.351E-02 3.847E-02 3.369E-02 2.919E-02 2.499E-02 2.110E-02 1.752E-02 1.427E-02 1.136E-02 8.782E-03 6.541E-03 4.639E-03 3.071E-03 1.835E-03 9.224E-04 3.258E-04 3.466E-05 3.715E-05 3.197E-04 8.671E-04 1.663E-03 2.690E-03 3.929E-03 5.361E-03 6.964E-03 8.719E-03 1.060E-02 1.260E-02 1.468E-02 1.682E-02 1.901E-02 2.122E-02 2.343E-02 2.562E-02 2.777E-02 2.987E-02 3.189E-02 3.383E-02 3.566E-02 3.737E-02 3.895E-02 4.039E-02 4.168E-02 4.280E-02 4.377E-02 4.456E-02 4.518E-02 4.562E-02 4.588E-02 4.597E-02 4.589E-02 4.563E-02 4.521E-02 4.463E-02 4.389E-02 4.301E-02 4.199E-02 4.085E-02 3.959E-02 3.822E-02 3.676E-02 3.590E-02 3.741E-02 3.884E-02 4.016E-02 4.138E-02 4.247E-02 4.343E-02 4.425E-02 4.492E-02 4.543E-02 4.577E-02 4.595E-02 4.595E-02 4.578E-02 4.543E-02 4.489E-02 4.419E-02 4.331E-02 4.225E-02 4.104E-02 3.967E-02 3.814E-02 3.649E-02 3.470E-02 3.280E-02 3.081E-02 2.873E-02 2.659E-02 2.440E-02 2.218E-02 1.996E-02 1.775E-02 1.557E-02 1.345E-02 1.140E-02 9.461E-03 7.640E-03 5.964E-03 4.453E-03 3.130E-03 2.014E-03 1.126E-03 4.831E-04 1.036E-04 3.357E-06 1.969E-04 6.974E-04 1.516E-03 2.662E-03 4.143E-03 5.964E-03 8.130E-03 1.064E-02 1.350E-02 1.669E-02 2.022E-02 2.408E-02 2.826E-02 3.275E-02 3.753E-02 4.259E-02 4.791E-02 5.347E-02 5.925E-02 6.523E-02 7.139E-02 7.769E-02 8.412E-02 9.065E-02 9.724E-02 1.039E-01 1.105E-01 1.172E-01 1.238E-01 1.304E-01 1.368E-01 1.431E-01 1.493E-01 1.554E-01 1.612E-01 1.669E-01 1.723E-01 1.775E-01 1.824E-01 1.870E-01 1.914E-01 1.955E-01 1.992E-01 2.027E-01 2.058E-01 2.087E-01 2.112E-01 2.135E-01 2.154E-01 2.170E-01 2.184E-01 2.194E-01 2.202E-01 2.208E-01 2.211E-01 2.211E-01 2.210E-01 2.207E-01 2.202E-01 2.195E-01 2.187E-01 2.177E-01 2.167E-01 2.155E-01 2.143E-01 2.130E-01 2.117E-01 2.104E-01 2.091E-01 2.078E-01 2.065E-01 2.052E-01 2.040E-01 2.029E-01 2.018E-01 2.008E-01 2.000E-01 1.992E-01 1.985E-01 1.979E-01 1.975E-01 1.972E-01 1.970E-01 1.969E-01 1.970E-01 1.972E-01 1.975E-01 1.979E-01 1.985E-01 1.992E-01 2.000E-01 2.008E-01 2.018E-01 2.029E-01 2.040E-01 2.052E-01 2.065E-01 2.078E-01 2.091E-01 2.104E-01 2.117E-01 2.130E-01 2.143E-01 2.155E-01 2.167E-01 2.177E-01 2.187E-01 2.195E-01 2.202E-01 2.207E-01 2.210E-01 2.211E-01 2.211E-01 2.208E-01 2.202E-01 2.194E-01 2.184E-01 2.170E-01 2.154E-01 2.135E-01 2.112E-01 2.087E-01 2.058E-01 2.027E-01 1.992E-01 1.955E-01 1.914E-01 1.870E-01 1.824E-01 1.775E-01 1.723E-01 1.669E-01 1.612E-01 1.554E-01 1.493E-01 1.431E-01 1.368E-01 1.304E-01 1.238E-01 1.172E-01 1.105E-01 1.039E-01 9.724E-02 9.065E-02 8.412E-02 7.769E-02 7.139E-02 6.523E-02 5.925E-02 5.347E-02 4.791E-02 4.259E-02 3.753E-02 3.275E-02 2.826E-02 2.408E-02 2.022E-02 1.669E-02 1.350E-02 1.064E-02 8.130E-03 5.964E-03 4.143E-03 2.662E-03 1.516E-03 6.974E-04 1.969E-04 3.357E-06 1.036E-04 4.831E-04 1.126E-03 2.014E-03 3.130E-03 4.453E-03 5.964E-03 7.640E-03 9.461E-03 1.140E-02 1.345E-02 1.557E-02 1.775E-02 1.996E-02 2.218E-02 2.440E-02 2.659E-02 2.873E-02 3.081E-02 3.280E-02 3.470E-02 3.649E-02 3.814E-02 3.967E-02 4.104E-02 4.225E-02 4.331E-02 4.419E-02 4.489E-02 4.543E-02 4.578E-02 4.595E-02 4.595E-02 4.577E-02 4.543E-02 4.492E-02 4.425E-02 4.343E-02 4.247E-02 4.138E-02 4.016E-02 3.884E-02 3.741E-02 3.656E-02 3.804E-02 3.943E-02 4.071E-02 4.187E-02 4.291E-02 4.381E-02 4.457E-02 4.517E-02 4.561E-02 4.587E-02 4.597E-02 4.589E-02 4.563E-02 4.519E-02 4.458E-02 4.378E-02 4.281E-02 4.167E-02 4.037E-02 3.891E-02 3.731E-02 3.558E-02 3.373E-02 3.177E-02 2.972E-02 2.759E-02 2.541E-02 2.319E-02 2.096E-02 1.872E-02 1.652E-02 1.435E-02 1.226E-02 1.026E-02 8.375E-03 6.625E-03 5.035E-03 3.625E-03 2.418E-03 1.434E-03 6.919E-04 2.102E-04 6.105E-06 9.524E-05 4.916E-04 1.208E-03 2.254E-03 3.639E-03 5.369E-03 7.448E-03 9.880E-03 1.266E-02 1.580E-02 1.927E-02 2.309E-02 2.724E-02 3.170E-02 3.647E-02 4.153E-02 4.686E-02 5.244E-02 5.826E-02 6.429E-02 7.050E-02 7.687E-02 8.338E-02 8.999E-02 9.668E-02 1.034E-01 1.102E-01 1.170E-01 1.237E-01 1.304E-01 1.369E-01 1.434E-01 1.497E-01 1.559E-01 1.618E-01 1.676E-01 1.731E-01 1.783E-01 1.833E-01 1.880E-01 1.925E-01 1.966E-01 2.004E-01 2.038E-01 2.070E-01 2.098E-01 2.123E-01 2.145E-01 2.163E-01 2.179E-01 2.191E-01 2.200E-01 2.207E-01 2.210E-01 2.211E-01 2.210E-01 2.207E-01 2.201E-01 2.193E-01 2.184E-01 2.173E-01 2.161E-01 2.148E-01 2.133E-01 2.118E-01 2.103E-01 2.086E-01 2.070E-01 2.054E-01 2.038E-01 2.022E-01 2.006E-01 1.991E-01 1.977E-01 1.963E-01 1.951E-01 1.940E-01 1.929E-01 1.920E-01 1.912E-01 1.906E-01 1.901E-01 1.897E-01 1.895E-01 1.894E-01 1.895E-01 1.897E-01 1.901E-01 1.906E-01 1.912E-01 1.920E-01 1.929E-01 1.940E-01 1.951E-01 1.963E-01 1.977E-01 1.991E-01 2.006E-01 2.022E-01 2.038E-01 2.054E-01 2.070E-01 2.086E-01 2.103E-01 2.118E-01 2.133E-01 2.148E-01 2.161E-01 2.173E-01 2.184E-01 2.193E-01 2.201E-01 2.207E-01 2.210E-01 2.211E-01 2.210E-01 2.207E-01 2.200E-01 2.191E-01 2.179E-01 2.163E-01 2.145E-01 2.123E-01 2.098E-01 2.070E-01 2.038E-01 2.004E-01 1.966E-01 1.925E-01 1.880E-01 1.833E-01 1.783E-01 1.731E-01 1.676E-01 1.618E-01 1.559E-01 1.497E-01 1.434E-01 1.369E-01 1.304E-01 1.237E-01 1.170E-01 1.102E-01 1.034E-01 9.668E-02 8.999E-02 8.338E-02 7.687E-02 7.050E-02 6.429E-02 5.826E-02 5.244E-02 4.686E-02 4.153E-02 3.647E-02 3.170E-02 2.724E-02 2.309E-02 1.927E-02 1.580E-02 1.266E-02 9.880E-03 7.448E-03 5.369E-03 3.639E-03 2.254E-03 1.208E-03 4.916E-04 9.524E-05 6.105E-06 2.102E-04 6.919E-04 1.434E-03 2.418E-03 3.625E-03 5.035E-03 6.625E-03 8.375E-03 1.026E-02 1.226E-02 1.435E-02 1.652E-02 1.872E-02 2.096E-02 2.319E-02 2.541E-02 2.759E-02 2.972E-02 3.177E-02 3.373E-02 3.558E-02 3.731E-02 3.891E-02 4.037E-02 4.167E-02 4.281E-02 4.378E-02 4.458E-02 4.519E-02 4.563E-02 4.589E-02 4.597E-02 4.587E-02 4.561E-02 4.517E-02 4.457E-02 4.381E-02 4.291E-02 4.187E-02 4.071E-02 3.943E-02 3.804E-02 3.719E-02 3.864E-02 3.999E-02 4.122E-02 4.234E-02 4.332E-02 4.416E-02 4.485E-02 4.538E-02 4.575E-02 4.594E-02 4.596E-02 4.579E-02 4.545E-02 4.492E-02 4.422E-02 4.334E-02 4.228E-02 4.106E-02 3.967E-02 3.814E-02 3.646E-02 3.466E-02 3.274E-02 3.072E-02 2.862E-02 2.645E-02 2.424E-02 2.199E-02 1.974E-02 1.751E-02 1.531E-02 1.317E-02 1.112E-02 9.169E-03 7.347E-03 5.677E-03 4.180E-03 2.880E-03 1.797E-03 9.513E-04 3.627E-04 4.919E-05 2.738E-05 3.124E-04 9.178E-04 1.855E-03 3.134E-03 4.762E-03 6.745E-03 9.086E-03 1.179E-02 1.484E-02 1.825E-02 2.201E-02 2.611E-02 3.054E-02 3.529E-02 4.033E-02 4.566E-02 5.126E-02 5.710E-02 6.316E-02 6.942E-02 7.585E-02 8.243E-02 8.912E-02 9.590E-02 1.027E-01 1.096E-01 1.165E-01 1.233E-01 1.301E-01 1.368E-01 1.434E-01 1.498E-01 1.561E-01 1.622E-01 1.680E-01 1.736E-01 1.790E-01 1.841E-01 1.889E-01 1.933E-01 1.975E-01 2.013E-01 2.048E-01 2.079E-01 2.107E-01 2.132E-01 2.153E-01 2.171E-01 2.185E-01 2.196E-01 2.204E-01 2.209E-01 2.211E-01 2.211E-01 2.207E-01 2.202E-01 2.194E-01 2.183E-01 2.171E-01 2.158E-01 2.143E-01 2.126E-01 2.109E-01 2.091E-01 2.072E-01 2.053E-01 2.033E-01 2.014E-01 1.994E-01 1.975E-01 1.956E-01 1.938E-01 1.921E-01 1.904E-01 1.889E-01 1.875E-01 1.861E-01 1.850E-01 1.839E-01 1.830E-01 1.823E-01 1.817E-01 1.813E-01 1.811E-01 1.810E-01 1.811E-01 1.813E-01 1.817E-01 1.823E-01 1.830E-01 1.839E-01 1.850E-01 1.861E-01 1.875E-01 1.889E-01 1.904E-01 1.921E-01 1.938E-01 1.956E-01 1.975E-01 1.994E-01 2.014E-01 2.033E-01 2.053E-01 2.072E-01 2.091E-01 2.109E-01 2.126E-01 2.143E-01 2.158E-01 2.171E-01 2.183E-01 2.194E-01 2.202E-01 2.207E-01 2.211E-01 2.211E-01 2.209E-01 2.204E-01 2.196E-01 2.185E-01 2.171E-01 2.153E-01 2.132E-01 2.107E-01 2.079E-01 2.048E-01 2.013E-01 1.975E-01 1.933E-01 1.889E-01 1.841E-01 1.790E-01 1.736E-01 1.680E-01 1.622E-01 1.561E-01 1.498E-01 1.434E-01 1.368E-01 1.301E-01 1.233E-01 1.165E-01 1.096E-01 1.027E-01 9.590E-02 8.912E-02 8.243E-02 7.585E-02 6.942E-02 6.316E-02 5.710E-02 5.126E-02 4.566E-02 4.033E-02 3.529E-02 3.054E-02 2.611E-02 2.201E-02 1.825E-02 1.484E-02 1.179E-02 9.086E-03 6.745E-03 4.762E-03 3.134E-03 1.855E-03 9.178E-04 3.124E-04 2.738E-05 4.919E-05 3.627E-04 9.513E-04 1.797E-03 2.880E-03 4.180E-03 5.677E-03 7.347E-03 9.169E-03 1.112E-02 1.317E-02 1.531E-02 1.751E-02 1.974E-02 2.199E-02 2.424E-02 2.645E-02 2.862E-02 3.072E-02 3.274E-02 3.466E-02 3.646E-02 3.814E-02 3.967E-02 4.106E-02 4.228E-02 4.334E-02 4.422E-02 4.492E-02 4.545E-02 4.579E-02 4.596E-02 4.594E-02 4.575E-02 4.538E-02 4.485E-02 4.416E-02 4.332E-02 4.234E-02 4.122E-02 3.999E-02 3.864E-02 3.779E-02 3.921E-02 4.052E-02 4.171E-02 4.277E-02 4.370E-02 4.448E-02 4.510E-02 4.556E-02 4.585E-02 4.597E-02 4.591E-02 4.566E-02 4.523E-02 4.462E-02 4.383E-02 4.286E-02 4.172E-02 4.041E-02 3.895E-02 3.734E-02 3.559E-02 3.372E-02 3.174E-02 2.967E-02 2.752E-02 2.531E-02 2.307E-02 2.081E-02 1.855E-02 1.632E-02 1.414E-02 1.204E-02 1.002E-02 8.131E-03 6.381E-03 4.797E-03 3.402E-03 2.218E-03 1.266E-03 5.669E-04 1.389E-04 2.162E-07 1.670E-04 6.540E-04 1.474E-03 2.637E-03 4.153E-03 6.028E-03 8.267E-03 1.087E-02 1.384E-02 1.717E-02 2.086E-02 2.490E-02 2.928E-02 3.399E-02 3.901E-02 4.433E-02 4.992E-02 5.577E-02 6.186E-02 6.815E-02 7.463E-02 8.127E-02 8.803E-02 9.490E-02 1.018E-01 1.088E-01 1.158E-01 1.227E-01 1.296E-01 1.364E-01 1.431E-01 1.497E-01 1.561E-01 1.623E-01 1.682E-01 1.740E-01 1.794E-01 1.846E-01 1.895E-01 1.940E-01 1.982E-01 2.021E-01 2.056E-01 2.087E-01 2.115E-01 2.139E-01 2.160E-01 2.177E-01 2.191E-01 2.201E-01 2.207E-01 2.211E-01 2.211E-01 2.209E-01 2.203E-01 2.195E-01 2.185E-01 2.172E-01 2.158E-01 2.141E-01 2.123E-01 2.104E-01 2.083E-01 2.062E-01 2.040E-01 2.017E-01 1.994E-01 1.971E-01 1.948E-01 1.926E-01 1.904E-01 1.882E-01 1.861E-01 1.842E-01 1.823E-01 1.806E-01 1.790E-01 1.775E-01 1.762E-01 1.750E-01 1.740E-01 1.732E-01 1.726E-01 1.721E-01 1.718E-01 1.717E-01 1.718E-01 1.721E-01 1.726E-01 1.732E-01 1.740E-01 1.750E-01 1.762E-01 1.775E-01 1.790E-01 1.806E-01 1.823E-01 1.842E-01 1.861E-01 1.882E-01 1.904E-01 1.926E-01 1.948E-01 1.971E-01 1.994E-01 2.017E-01 2.040E-01 2.062E-01 2.083E-01 2.104E-01 2.123E-01 2.141E-01 2.158E-01 2.172E-01 2.185E-01 2.195E-01 2.203E-01 2.209E-01 2.211E-01 2.211E-01 2.207E-01 2.201E-01 2.191E-01 2.177E-01 2.160E-01 2.139E-01 2.115E-01 2.087E-01 2.056E-01 2.021E-01 1.982E-01 1.940E-01 1.895E-01 1.846E-01 1.794E-01 1.740E-01 1.682E-01 1.623E-01 1.561E-01 1.497E-01 1.431E-01 1.364E-01 1.296E-01 1.227E-01 1.158E-01 1.088E-01 1.018E-01 9.490E-02 8.803E-02 8.127E-02 7.463E-02 6.815E-02 6.186E-02 5.577E-02 4.992E-02 4.433E-02 3.901E-02 3.399E-02 2.928E-02 2.490E-02 2.086E-02 1.717E-02 1.384E-02 1.087E-02 8.267E-03 6.028E-03 4.153E-03 2.637E-03 1.474E-03 6.540E-04 1.670E-04 2.162E-07 1.389E-04 5.669E-04 1.266E-03 2.218E-03 3.402E-03 4.797E-03 6.381E-03 8.131E-03 1.002E-02 1.204E-02 1.414E-02 1.632E-02 1.855E-02 2.081E-02 2.307E-02 2.531E-02 2.752E-02 2.967E-02 3.174E-02 3.372E-02 3.559E-02 3.734E-02 3.895E-02 4.041E-02 4.172E-02 4.286E-02 4.383E-02 4.462E-02 4.523E-02 4.566E-02 4.591E-02 4.597E-02 4.585E-02 4.556E-02 4.510E-02 4.448E-02 4.370E-02 4.277E-02 4.171E-02 4.052E-02 3.921E-02 3.838E-02 3.975E-02 4.102E-02 4.216E-02 4.318E-02 4.405E-02 4.476E-02 4.532E-02 4.571E-02 4.593E-02 4.596E-02 4.582E-02 4.549E-02 4.498E-02 4.429E-02 4.341E-02 4.236E-02 4.113E-02 3.975E-02 3.820E-02 3.652E-02 3.470E-02 3.277E-02 3.073E-02 2.861E-02 2.642E-02 2.418E-02 2.192E-02 1.964E-02 1.739E-02 1.517E-02 1.301E-02 1.094E-02 8.978E-03 7.150E-03 5.479E-03 3.989E-03 2.703E-03 1.642E-03 8.283E-04 2.815E-04 2.057E-05 6.286E-05 4.241E-04 1.118E-03 2.157E-03 3.552E-03 5.308E-03 7.434E-03 9.931E-03 1.280E-02 1.604E-02 1.965E-02 2.361E-02 2.793E-02 3.259E-02 3.757E-02 4.286E-02 4.844E-02 5.429E-02 6.039E-02 6.671E-02 7.323E-02 7.991E-02 8.674E-02 9.367E-02 1.007E-01 1.078E-01 1.148E-01 1.219E-01 1.289E-01 1.358E-01 1.427E-01 1.493E-01 1.559E-01 1.622E-01 1.682E-01 1.741E-01 1.796E-01 1.849E-01 1.899E-01 1.945E-01 1.987E-01 2.027E-01 2.062E-01 2.094E-01 2.121E-01 2.146E-01 2.166E-01 2.182E-01 2.195E-01 2.204E-01 2.209E-01 2.211E-01 2.210E-01 2.206E-01 2.198E-01 2.188E-01 2.175E-01 2.160E-01 2.143E-01 2.124E-01 2.103E-01 2.080E-01 2.056E-01 2.032E-01 2.006E-01 1.980E-01 1.954E-01 1.927E-01 1.901E-01 1.875E-01 1.849E-01 1.824E-01 1.800E-01 1.777E-01 1.755E-01 1.734E-01 1.714E-01 1.697E-01 1.680E-01 1.666E-01 1.653E-01 1.642E-01 1.633E-01 1.626E-01 1.621E-01 1.618E-01 1.617E-01 1.618E-01 1.621E-01 1.626E-01 1.633E-01 1.642E-01 1.653E-01 1.666E-01 1.680E-01 1.697E-01 1.714E-01 1.734E-01 1.755E-01 1.777E-01 1.800E-01 1.824E-01 1.849E-01 1.875E-01 1.901E-01 1.927E-01 1.954E-01 1.980E-01 2.006E-01 2.032E-01 2.056E-01 2.080E-01 2.103E-01 2.124E-01 2.143E-01 2.160E-01 2.175E-01 2.188E-01 2.198E-01 2.206E-01 2.210E-01 2.211E-01 2.209E-01 2.204E-01 2.195E-01 2.182E-01 2.166E-01 2.146E-01 2.121E-01 2.094E-01 2.062E-01 2.027E-01 1.987E-01 1.945E-01 1.899E-01 1.849E-01 1.796E-01 1.741E-01 1.682E-01 1.622E-01 1.559E-01 1.493E-01 1.427E-01 1.358E-01 1.289E-01 1.219E-01 1.148E-01 1.078E-01 1.007E-01 9.367E-02 8.674E-02 7.991E-02 7.323E-02 6.671E-02 6.039E-02 5.429E-02 4.844E-02 4.286E-02 3.757E-02 3.259E-02 2.793E-02 2.361E-02 1.965E-02 1.604E-02 1.280E-02 9.931E-03 7.434E-03 5.308E-03 3.552E-03 2.157E-03 1.118E-03 4.241E-04 6.286E-05 2.057E-05 2.815E-04 8.283E-04 1.642E-03 2.703E-03 3.989E-03 5.479E-03 7.150E-03 8.978E-03 1.094E-02 1.301E-02 1.517E-02 1.739E-02 1.964E-02 2.192E-02 2.418E-02 2.642E-02 2.861E-02 3.073E-02 3.277E-02 3.470E-02 3.652E-02 3.820E-02 3.975E-02 4.113E-02 4.236E-02 4.341E-02 4.429E-02 4.498E-02 4.549E-02 4.582E-02 4.596E-02 4.593E-02 4.571E-02 4.532E-02 4.476E-02 4.405E-02 4.318E-02 4.216E-02 4.102E-02 3.975E-02 3.893E-02 4.027E-02 4.149E-02 4.259E-02 4.355E-02 4.436E-02 4.501E-02 4.550E-02 4.582E-02 4.596E-02 4.592E-02 4.570E-02 4.529E-02 4.470E-02 4.392E-02 4.296E-02 4.182E-02 4.052E-02 3.905E-02 3.744E-02 3.568E-02 3.380E-02 3.181E-02 2.972E-02 2.755E-02 2.532E-02 2.306E-02 2.078E-02 1.850E-02 1.625E-02 1.404E-02 1.192E-02 9.890E-03 7.986E-03 6.229E-03 4.644E-03 3.254E-03 2.083E-03 1.152E-03 4.831E-04 9.521E-05 7.280E-06 2.362E-04 7.971E-04 1.703E-03 2.966E-03 4.594E-03 6.595E-03 8.973E-03 1.173E-02 1.486E-02 1.837E-02 2.225E-02 2.650E-02 3.109E-02 3.602E-02 4.127E-02 4.682E-02 5.266E-02 5.875E-02 6.509E-02 7.163E-02 7.836E-02 8.524E-02 9.224E-02 9.933E-02 1.065E-01 1.137E-01 1.208E-01 1.279E-01 1.350E-01 1.419E-01 1.487E-01 1.554E-01 1.618E-01 1.680E-01 1.740E-01 1.796E-01 1.850E-01 1.901E-01 1.948E-01 1.991E-01 2.031E-01 2.066E-01 2.098E-01 2.126E-01 2.150E-01 2.170E-01 2.186E-01 2.198E-01 2.206E-01 2.211E-01 2.211E-01 2.208E-01 2.202E-01 2.193E-01 2.181E-01 2.165E-01 2.148E-01 2.128E-01 2.105E-01 2.081E-01 2.056E-01 2.029E-01 2.001E-01 1.972E-01 1.942E-01 1.912E-01 1.882E-01 1.852E-01 1.822E-01 1.793E-01 1.764E-01 1.737E-01 1.710E-01 1.684E-01 1.660E-01 1.637E-01 1.616E-01 1.597E-01 1.579E-01 1.563E-01 1.549E-01 1.538E-01 1.528E-01 1.520E-01 1.515E-01 1.511E-01 1.510E-01 1.511E-01 1.515E-01 1.520E-01 1.528E-01 1.538E-01 1.549E-01 1.563E-01 1.579E-01 1.597E-01 1.616E-01 1.637E-01 1.660E-01 1.684E-01 1.710E-01 1.737E-01 1.764E-01 1.793E-01 1.822E-01 1.852E-01 1.882E-01 1.912E-01 1.942E-01 1.972E-01 2.001E-01 2.029E-01 2.056E-01 2.081E-01 2.105E-01 2.128E-01 2.148E-01 2.165E-01 2.181E-01 2.193E-01 2.202E-01 2.208E-01 2.211E-01 2.211E-01 2.206E-01 2.198E-01 2.186E-01 2.170E-01 2.150E-01 2.126E-01 2.098E-01 2.066E-01 2.031E-01 1.991E-01 1.948E-01 1.901E-01 1.850E-01 1.796E-01 1.740E-01 1.680E-01 1.618E-01 1.554E-01 1.487E-01 1.419E-01 1.350E-01 1.279E-01 1.208E-01 1.137E-01 1.065E-01 9.933E-02 9.224E-02 8.524E-02 7.836E-02 7.163E-02 6.509E-02 5.875E-02 5.266E-02 4.682E-02 4.127E-02 3.602E-02 3.109E-02 2.650E-02 2.225E-02 1.837E-02 1.486E-02 1.173E-02 8.973E-03 6.595E-03 4.594E-03 2.966E-03 1.703E-03 7.971E-04 2.362E-04 7.280E-06 9.521E-05 4.831E-04 1.152E-03 2.083E-03 3.254E-03 4.644E-03 6.229E-03 7.986E-03 9.890E-03 1.192E-02 1.404E-02 1.625E-02 1.850E-02 2.078E-02 2.306E-02 2.532E-02 2.755E-02 2.972E-02 3.181E-02 3.380E-02 3.568E-02 3.744E-02 3.905E-02 4.052E-02 4.182E-02 4.296E-02 4.392E-02 4.470E-02 4.529E-02 4.570E-02 4.592E-02 4.596E-02 4.582E-02 4.550E-02 4.501E-02 4.436E-02 4.355E-02 4.259E-02 4.149E-02 4.027E-02 3.946E-02 4.076E-02 4.194E-02 4.299E-02 4.389E-02 4.464E-02 4.523E-02 4.566E-02 4.590E-02 4.597E-02 4.585E-02 4.555E-02 4.506E-02 4.438E-02 4.352E-02 4.248E-02 4.127E-02 3.988E-02 3.834E-02 3.666E-02 3.483E-02 3.289E-02 3.084E-02 2.870E-02 2.649E-02 2.424E-02 2.195E-02 1.965E-02 1.737E-02 1.513E-02 1.296E-02 1.087E-02 8.888E-03 7.048E-03 5.369E-03 3.877E-03 2.594E-03 1.544E-03 7.495E-04 2.307E-04 7.597E-06 9.812E-05 5.187E-04 1.284E-03 2.406E-03 3.896E-03 5.762E-03 8.009E-03 1.064E-02 1.366E-02 1.706E-02 2.084E-02 2.499E-02 2.950E-02 3.436E-02 3.956E-02 4.507E-02 5.088E-02 5.697E-02 6.330E-02 6.986E-02 7.661E-02 8.353E-02 9.059E-02 9.775E-02 1.050E-01 1.122E-01 1.195E-01 1.267E-01 1.339E-01 1.410E-01 1.479E-01 1.547E-01 1.612E-01 1.676E-01 1.736E-01 1.794E-01 1.849E-01 1.901E-01 1.948E-01 1.993E-01 2.033E-01 2.069E-01 2.102E-01 2.130E-01 2.154E-01 2.174E-01 2.189E-01 2.201E-01 2.208E-01 2.211E-01 2.211E-01 2.206E-01 2.198E-01 2.187E-01 2.173E-01 2.155E-01 2.135E-01 2.112E-01 2.087E-01 2.060E-01 2.032E-01 2.001E-01 1.970E-01 1.937E-01 1.904E-01 1.871E-01 1.837E-01 1.803E-01 1.770E-01 1.737E-01 1.704E-01 1.673E-01 1.642E-01 1.613E-01 1.585E-01 1.559E-01 1.534E-01 1.511E-01 1.490E-01 1.471E-01 1.455E-01 1.440E-01 1.427E-01 1.417E-01 1.408E-01 1.403E-01 1.399E-01 1.398E-01 1.399E-01 1.403E-01 1.408E-01 1.417E-01 1.427E-01 1.440E-01 1.455E-01 1.471E-01 1.490E-01 1.511E-01 1.534E-01 1.559E-01 1.585E-01 1.613E-01 1.642E-01 1.673E-01 1.704E-01 1.737E-01 1.770E-01 1.803E-01 1.837E-01 1.871E-01 1.904E-01 1.937E-01 1.970E-01 2.001E-01 2.032E-01 2.060E-01 2.087E-01 2.112E-01 2.135E-01 2.155E-01 2.173E-01 2.187E-01 2.198E-01 2.206E-01 2.211E-01 2.211E-01 2.208E-01 2.201E-01 2.189E-01 2.174E-01 2.154E-01 2.130E-01 2.102E-01 2.069E-01 2.033E-01 1.993E-01 1.948E-01 1.901E-01 1.849E-01 1.794E-01 1.736E-01 1.676E-01 1.612E-01 1.547E-01 1.479E-01 1.410E-01 1.339E-01 1.267E-01 1.195E-01 1.122E-01 1.050E-01 9.775E-02 9.059E-02 8.353E-02 7.661E-02 6.986E-02 6.330E-02 5.697E-02 5.088E-02 4.507E-02 3.956E-02 3.436E-02 2.950E-02 2.499E-02 2.084E-02 1.706E-02 1.366E-02 1.064E-02 8.009E-03 5.762E-03 3.896E-03 2.406E-03 1.284E-03 5.187E-04 9.812E-05 7.597E-06 2.307E-04 7.495E-04 1.544E-03 2.594E-03 3.877E-03 5.369E-03 7.048E-03 8.888E-03 1.087E-02 1.296E-02 1.513E-02 1.737E-02 1.965E-02 2.195E-02 2.424E-02 2.649E-02 2.870E-02 3.084E-02 3.289E-02 3.483E-02 3.666E-02 3.834E-02 3.988E-02 4.127E-02 4.248E-02 4.352E-02 4.438E-02 4.506E-02 4.555E-02 4.585E-02 4.597E-02 4.590E-02 4.566E-02 4.523E-02 4.464E-02 4.389E-02 4.299E-02 4.194E-02 4.076E-02 3.997E-02 4.123E-02 4.236E-02 4.336E-02 4.420E-02 4.490E-02 4.542E-02 4.578E-02 4.595E-02 4.594E-02 4.575E-02 4.537E-02 4.480E-02 4.404E-02 4.310E-02 4.198E-02 4.069E-02 3.923E-02 3.762E-02 3.586E-02 3.397E-02 3.197E-02 2.987E-02 2.769E-02 2.544E-02 2.316E-02 2.085E-02 1.855E-02 1.628E-02 1.405E-02 1.191E-02 9.859E-03 7.937E-03 6.167E-03 4.572E-03 3.178E-03 2.008E-03 1.086E-03 4.335E-04 7.095E-05 1.779E-05 2.917E-04 9.085E-04 1.882E-03 3.224E-03 4.944E-03 7.050E-03 9.544E-03 1.243E-02 1.571E-02 1.937E-02 2.342E-02 2.784E-02 3.262E-02 3.775E-02 4.320E-02 4.897E-02 5.503E-02 6.135E-02 6.791E-02 7.468E-02 8.164E-02 8.874E-02 9.596E-02 1.033E-01 1.106E-01 1.180E-01 1.253E-01 1.326E-01 1.398E-01 1.468E-01 1.537E-01 1.604E-01 1.669E-01 1.731E-01 1.790E-01 1.846E-01 1.899E-01 1.948E-01 1.993E-01 2.034E-01 2.071E-01 2.104E-01 2.132E-01 2.156E-01 2.176E-01 2.191E-01 2.202E-01 2.209E-01 2.211E-01 2.210E-01 2.204E-01 2.195E-01 2.182E-01 2.165E-01 2.145E-01 2.123E-01 2.097E-01 2.070E-01 2.040E-01 2.008E-01 1.974E-01 1.940E-01 1.904E-01 1.867E-01 1.830E-01 1.792E-01 1.755E-01 1.717E-01 1.680E-01 1.644E-01 1.609E-01 1.575E-01 1.542E-01 1.510E-01 1.480E-01 1.452E-01 1.426E-01 1.401E-01 1.379E-01 1.359E-01 1.341E-01 1.325E-01 1.312E-01 1.301E-01 1.292E-01 1.286E-01 1.282E-01 1.281E-01 1.282E-01 1.286E-01 1.292E-01 1.301E-01 1.312E-01 1.325E-01 1.341E-01 1.359E-01 1.379E-01 1.401E-01 1.426E-01 1.452E-01 1.480E-01 1.510E-01 1.542E-01 1.575E-01 1.609E-01 1.644E-01 1.680E-01 1.717E-01 1.755E-01 1.792E-01 1.830E-01 1.867E-01 1.904E-01 1.940E-01 1.974E-01 2.008E-01 2.040E-01 2.070E-01 2.097E-01 2.123E-01 2.145E-01 2.165E-01 2.182E-01 2.195E-01 2.204E-01 2.210E-01 2.211E-01 2.209E-01 2.202E-01 2.191E-01 2.176E-01 2.156E-01 2.132E-01 2.104E-01 2.071E-01 2.034E-01 1.993E-01 1.948E-01 1.899E-01 1.846E-01 1.790E-01 1.731E-01 1.669E-01 1.604E-01 1.537E-01 1.468E-01 1.398E-01 1.326E-01 1.253E-01 1.180E-01 1.106E-01 1.033E-01 9.596E-02 8.874E-02 8.164E-02 7.468E-02 6.791E-02 6.135E-02 5.503E-02 4.897E-02 4.320E-02 3.775E-02 3.262E-02 2.784E-02 2.342E-02 1.937E-02 1.571E-02 1.243E-02 9.544E-03 7.050E-03 4.944E-03 3.224E-03 1.882E-03 9.085E-04 2.917E-04 1.779E-05 7.095E-05 4.335E-04 1.086E-03 2.008E-03 3.178E-03 4.572E-03 6.167E-03 7.937E-03 9.859E-03 1.191E-02 1.405E-02 1.628E-02 1.855E-02 2.085E-02 2.316E-02 2.544E-02 2.769E-02 2.987E-02 3.197E-02 3.397E-02 3.586E-02 3.762E-02 3.923E-02 4.069E-02 4.198E-02 4.310E-02 4.404E-02 4.480E-02 4.537E-02 4.575E-02 4.594E-02 4.595E-02 4.578E-02 4.542E-02 4.490E-02 4.420E-02 4.336E-02 4.236E-02 4.123E-02 4.045E-02 4.167E-02 4.275E-02 4.370E-02 4.449E-02 4.512E-02 4.558E-02 4.587E-02 4.597E-02 4.589E-02 4.562E-02 4.516E-02 4.451E-02 4.368E-02 4.266E-02 4.146E-02 4.009E-02 3.856E-02 3.687E-02 3.505E-02 3.310E-02 3.105E-02 2.890E-02 2.668E-02 2.440E-02 2.210E-02 1.978E-02 1.748E-02 1.521E-02 1.301E-02 1.090E-02 8.898E-03 7.039E-03 5.344E-03 3.839E-03 2.550E-03 1.499E-03 7.096E-04 2.042E-04 2.840E-06 1.244E-04 5.861E-04 1.403E-03 2.589E-03 4.153E-03 6.106E-03 8.452E-03 1.120E-02 1.434E-02 1.787E-02 2.180E-02 2.611E-02 3.080E-02 3.584E-02 4.123E-02 4.694E-02 5.296E-02 5.925E-02 6.580E-02 7.258E-02 7.955E-02 8.668E-02 9.395E-02 1.013E-01 1.087E-01 1.162E-01 1.236E-01 1.310E-01 1.383E-01 1.455E-01 1.525E-01 1.593E-01 1.659E-01 1.723E-01 1.783E-01 1.841E-01 1.895E-01 1.945E-01 1.991E-01 2.033E-01 2.071E-01 2.104E-01 2.133E-01 2.158E-01 2.178E-01 2.193E-01 2.204E-01 2.210E-01 2.211E-01 2.209E-01 2.202E-01 2.191E-01 2.176E-01 2.158E-01 2.136E-01 2.111E-01 2.083E-01 2.053E-01 2.020E-01 1.985E-01 1.948E-01 1.910E-01 1.871E-01 1.830E-01 1.790E-01 1.748E-01 1.707E-01 1.666E-01 1.625E-01 1.585E-01 1.546E-01 1.508E-01 1.471E-01 1.436E-01 1.403E-01 1.371E-01 1.341E-01 1.313E-01 1.287E-01 1.264E-01 1.242E-01 1.224E-01 1.207E-01 1.193E-01 1.182E-01 1.173E-01 1.166E-01 1.162E-01 1.161E-01 1.162E-01 1.166E-01 1.173E-01 1.182E-01 1.193E-01 1.207E-01 1.224E-01 1.242E-01 1.264E-01 1.287E-01 1.313E-01 1.341E-01 1.371E-01 1.403E-01 1.436E-01 1.471E-01 1.508E-01 1.546E-01 1.585E-01 1.625E-01 1.666E-01 1.707E-01 1.748E-01 1.790E-01 1.830E-01 1.871E-01 1.910E-01 1.948E-01 1.985E-01 2.020E-01 2.053E-01 2.083E-01 2.111E-01 2.136E-01 2.158E-01 2.176E-01 2.191E-01 2.202E-01 2.209E-01 2.211E-01 2.210E-01 2.204E-01 2.193E-01 2.178E-01 2.158E-01 2.133E-01 2.104E-01 2.071E-01 2.033E-01 1.991E-01 1.945E-01 1.895E-01 1.841E-01 1.783E-01 1.723E-01 1.659E-01 1.593E-01 1.525E-01 1.455E-01 1.383E-01 1.310E-01 1.236E-01 1.162E-01 1.087E-01 1.013E-01 9.395E-02 8.668E-02 7.955E-02 7.258E-02 6.580E-02 5.925E-02 5.296E-02 4.694E-02 4.123E-02 3.584E-02 3.080E-02 2.611E-02 2.180E-02 1.787E-02 1.434E-02 1.120E-02 8.452E-03 6.106E-03 4.153E-03 2.589E-03 1.403E-03 5.861E-04 1.244E-04 2.840E-06 2.042E-04 7.096E-04 1.499E-03 2.550E-03 3.839E-03 5.344E-03 7.039E-03 8.898E-03 1.090E-02 1.301E-02 1.521E-02 1.748E-02 1.978E-02 2.210E-02 2.440E-02 2.668E-02 2.890E-02 3.105E-02 3.310E-02 3.505E-02 3.687E-02 3.856E-02 4.009E-02 4.146E-02 4.266E-02 4.368E-02 4.451E-02 4.516E-02 4.562E-02 4.589E-02 4.597E-02 4.587E-02 4.558E-02 4.512E-02 4.449E-02 4.370E-02 4.275E-02 4.167E-02 4.091E-02 4.208E-02 4.312E-02 4.401E-02 4.474E-02 4.531E-02 4.571E-02 4.593E-02 4.596E-02 4.581E-02 4.546E-02 4.492E-02 4.420E-02 4.328E-02 4.219E-02 4.091E-02 3.947E-02 3.787E-02 3.612E-02 3.423E-02 3.223E-02 3.012E-02 2.793E-02 2.567E-02 2.337E-02 2.105E-02 1.872E-02 1.643E-02 1.418E-02 1.200E-02 9.931E-03 7.986E-03 6.193E-03 4.580E-03 3.171E-03 1.991E-03 1.065E-03 4.139E-04 6.067E-05 2.515E-05 3.258E-04 9.791E-04 2.000E-03 3.400E-03 5.189E-03 7.376E-03 9.965E-03 1.296E-02 1.635E-02 2.015E-02 2.434E-02 2.891E-02 3.385E-02 3.916E-02 4.480E-02 5.076E-02 5.701E-02 6.353E-02 7.030E-02 7.728E-02 8.444E-02 9.174E-02 9.916E-02 1.067E-01 1.142E-01 1.217E-01 1.292E-01 1.366E-01 1.439E-01 1.511E-01 1.580E-01 1.648E-01 1.713E-01 1.775E-01 1.833E-01 1.889E-01 1.940E-01 1.987E-01 2.031E-01 2.069E-01 2.104E-01 2.133E-01 2.158E-01 2.179E-01 2.194E-01 2.204E-01 2.210E-01 2.211E-01 2.208E-01 2.200E-01 2.188E-01 2.171E-01 2.151E-01 2.128E-01 2.100E-01 2.070E-01 2.037E-01 2.001E-01 1.963E-01 1.924E-01 1.882E-01 1.839E-01 1.796E-01 1.751E-01 1.706E-01 1.661E-01 1.616E-01 1.572E-01 1.528E-01 1.485E-01 1.443E-01 1.403E-01 1.364E-01 1.326E-01 1.291E-01 1.257E-01 1.226E-01 1.197E-01 1.170E-01 1.145E-01 1.123E-01 1.104E-01 1.087E-01 1.072E-01 1.060E-01 1.051E-01 1.044E-01 1.040E-01 1.039E-01 1.040E-01 1.044E-01 1.051E-01 1.060E-01 1.072E-01 1.087E-01 1.104E-01 1.123E-01 1.145E-01 1.170E-01 1.197E-01 1.226E-01 1.257E-01 1.291E-01 1.326E-01 1.364E-01 1.403E-01 1.443E-01 1.485E-01 1.528E-01 1.572E-01 1.616E-01 1.661E-01 1.706E-01 1.751E-01 1.796E-01 1.839E-01 1.882E-01 1.924E-01 1.963E-01 2.001E-01 2.037E-01 2.070E-01 2.100E-01 2.128E-01 2.151E-01 2.171E-01 2.188E-01 2.200E-01 2.208E-01 2.211E-01 2.210E-01 2.204E-01 2.194E-01 2.179E-01 2.158E-01 2.133E-01 2.104E-01 2.069E-01 2.031E-01 1.987E-01 1.940E-01 1.889E-01 1.833E-01 1.775E-01 1.713E-01 1.648E-01 1.580E-01 1.511E-01 1.439E-01 1.366E-01 1.292E-01 1.217E-01 1.142E-01 1.067E-01 9.916E-02 9.174E-02 8.444E-02 7.728E-02 7.030E-02 6.353E-02 5.701E-02 5.076E-02 4.480E-02 3.916E-02 3.385E-02 2.891E-02 2.434E-02 2.015E-02 1.635E-02 1.296E-02 9.965E-03 7.376E-03 5.189E-03 3.400E-03 2.000E-03 9.791E-04 3.258E-04 2.515E-05 6.067E-05 4.139E-04 1.065E-03 1.991E-03 3.171E-03 4.580E-03 6.193E-03 7.986E-03 9.931E-03 1.200E-02 1.418E-02 1.643E-02 1.872E-02 2.105E-02 2.337E-02 2.567E-02 2.793E-02 3.012E-02 3.223E-02 3.423E-02 3.612E-02 3.787E-02 3.947E-02 4.091E-02 4.219E-02 4.328E-02 4.420E-02 4.492E-02 4.546E-02 4.581E-02 4.596E-02 4.593E-02 4.571E-02 4.531E-02 4.474E-02 4.401E-02 4.312E-02 4.208E-02 4.134E-02 4.247E-02 4.346E-02 4.430E-02 4.497E-02 4.548E-02 4.581E-02 4.596E-02 4.593E-02 4.570E-02 4.528E-02 4.466E-02 4.386E-02 4.287E-02 4.170E-02 4.035E-02 3.884E-02 3.717E-02 3.535E-02 3.341E-02 3.135E-02 2.920E-02 2.697E-02 2.468E-02 2.235E-02 2.002E-02 1.769E-02 1.540E-02 1.317E-02 1.103E-02 9.008E-03 7.122E-03 5.403E-03 3.877E-03 2.568E-03 1.504E-03 7.061E-04 1.983E-04 1.762E-06 1.362E-04 6.196E-04 1.468E-03 2.695E-03 4.312E-03 6.328E-03 8.750E-03 1.158E-02 1.482E-02 1.847E-02 2.252E-02 2.697E-02 3.180E-02 3.700E-02 4.255E-02 4.844E-02 5.464E-02 6.112E-02 6.786E-02 7.484E-02 8.200E-02 8.934E-02 9.680E-02 1.043E-01 1.120E-01 1.196E-01 1.272E-01 1.347E-01 1.421E-01 1.494E-01 1.565E-01 1.634E-01 1.700E-01 1.764E-01 1.824E-01 1.880E-01 1.933E-01 1.982E-01 2.027E-01 2.066E-01 2.102E-01 2.132E-01 2.158E-01 2.179E-01 2.194E-01 2.205E-01 2.210E-01 2.211E-01 2.207E-01 2.198E-01 2.185E-01 2.167E-01 2.146E-01 2.120E-01 2.091E-01 2.058E-01 2.023E-01 1.984E-01 1.944E-01 1.901E-01 1.856E-01 1.810E-01 1.763E-01 1.714E-01 1.666E-01 1.617E-01 1.568E-01 1.520E-01 1.473E-01 1.426E-01 1.380E-01 1.336E-01 1.293E-01 1.252E-01 1.213E-01 1.176E-01 1.142E-01 1.109E-01 1.079E-01 1.051E-01 1.026E-01 1.003E-01 9.826E-02 9.651E-02 9.502E-02 9.380E-02 9.285E-02 9.218E-02 9.177E-02 9.163E-02 9.177E-02 9.218E-02 9.285E-02 9.380E-02 9.502E-02 9.651E-02 9.826E-02 1.003E-01 1.026E-01 1.051E-01 1.079E-01 1.109E-01 1.142E-01 1.176E-01 1.213E-01 1.252E-01 1.293E-01 1.336E-01 1.380E-01 1.426E-01 1.473E-01 1.520E-01 1.568E-01 1.617E-01 1.666E-01 1.714E-01 1.763E-01 1.810E-01 1.856E-01 1.901E-01 1.944E-01 1.984E-01 2.023E-01 2.058E-01 2.091E-01 2.120E-01 2.146E-01 2.167E-01 2.185E-01 2.198E-01 2.207E-01 2.211E-01 2.210E-01 2.205E-01 2.194E-01 2.179E-01 2.158E-01 2.132E-01 2.102E-01 2.066E-01 2.027E-01 1.982E-01 1.933E-01 1.880E-01 1.824E-01 1.764E-01 1.700E-01 1.634E-01 1.565E-01 1.494E-01 1.421E-01 1.347E-01 1.272E-01 1.196E-01 1.120E-01 1.043E-01 9.680E-02 8.934E-02 8.200E-02 7.484E-02 6.786E-02 6.112E-02 5.464E-02 4.844E-02 4.255E-02 3.700E-02 3.180E-02 2.697E-02 2.252E-02 1.847E-02 1.482E-02 1.158E-02 8.750E-03 6.328E-03 4.312E-03 2.695E-03 1.468E-03 6.196E-04 1.362E-04 1.762E-06 1.983E-04 7.061E-04 1.504E-03 2.568E-03 3.877E-03 5.403E-03 7.122E-03 9.008E-03 1.103E-02 1.317E-02 1.540E-02 1.769E-02 2.002E-02 2.235E-02 2.468E-02 2.697E-02 2.920E-02 3.135E-02 3.341E-02 3.535E-02 3.717E-02 3.884E-02 4.035E-02 4.170E-02 4.287E-02 4.386E-02 4.466E-02 4.528E-02 4.570E-02 4.593E-02 4.596E-02 4.581E-02 4.548E-02 4.497E-02 4.430E-02 4.346E-02 4.247E-02 4.175E-02 4.283E-02 4.377E-02 4.456E-02 4.518E-02 4.562E-02 4.589E-02 4.597E-02 4.586E-02 4.556E-02 4.507E-02 4.438E-02 4.350E-02 4.244E-02 4.119E-02 3.977E-02 3.819E-02 3.645E-02 3.458E-02 3.258E-02 3.047E-02 2.828E-02 2.601E-02 2.369E-02 2.135E-02 1.901E-02 1.668E-02 1.441E-02 1.221E-02 1.011E-02 8.131E-03 6.309E-03 4.668E-03 3.234E-03 2.031E-03 1.086E-03 4.223E-04 6.178E-05 2.589E-05 3.339E-04 1.003E-03 2.049E-03 3.485E-03 5.320E-03 7.564E-03 1.022E-02 1.329E-02 1.678E-02 2.068E-02 2.499E-02 2.969E-02 3.477E-02 4.022E-02 4.602E-02 5.215E-02 5.857E-02 6.528E-02 7.223E-02 7.939E-02 8.674E-02 9.423E-02 1.018E-01 1.095E-01 1.172E-01 1.249E-01 1.325E-01 1.401E-01 1.475E-01 1.547E-01 1.618E-01 1.685E-01 1.750E-01 1.812E-01 1.870E-01 1.925E-01 1.975E-01 2.021E-01 2.062E-01 2.098E-01 2.130E-01 2.156E-01 2.178E-01 2.194E-01 2.205E-01 2.211E-01 2.211E-01 2.207E-01 2.197E-01 2.183E-01 2.164E-01 2.141E-01 2.114E-01 2.083E-01 2.048E-01 2.010E-01 1.969E-01 1.926E-01 1.880E-01 1.832E-01 1.783E-01 1.732E-01 1.680E-01 1.628E-01 1.576E-01 1.523E-01 1.471E-01 1.420E-01 1.370E-01 1.320E-01 1.272E-01 1.226E-01 1.182E-01 1.139E-01 1.098E-01 1.060E-01 1.024E-01 9.907E-02 9.597E-02 9.313E-02 9.054E-02 8.823E-02 8.618E-02 8.441E-02 8.290E-02 8.167E-02 8.071E-02 8.003E-02 7.962E-02 7.948E-02 7.962E-02 8.003E-02 8.071E-02 8.167E-02 8.290E-02 8.441E-02 8.618E-02 8.823E-02 9.054E-02 9.313E-02 9.597E-02 9.907E-02 1.024E-01 1.060E-01 1.098E-01 1.139E-01 1.182E-01 1.226E-01 1.272E-01 1.320E-01 1.370E-01 1.420E-01 1.471E-01 1.523E-01 1.576E-01 1.628E-01 1.680E-01 1.732E-01 1.783E-01 1.832E-01 1.880E-01 1.926E-01 1.969E-01 2.010E-01 2.048E-01 2.083E-01 2.114E-01 2.141E-01 2.164E-01 2.183E-01 2.197E-01 2.207E-01 2.211E-01 2.211E-01 2.205E-01 2.194E-01 2.178E-01 2.156E-01 2.130E-01 2.098E-01 2.062E-01 2.021E-01 1.975E-01 1.925E-01 1.870E-01 1.812E-01 1.750E-01 1.685E-01 1.618E-01 1.547E-01 1.475E-01 1.401E-01 1.325E-01 1.249E-01 1.172E-01 1.095E-01 1.018E-01 9.423E-02 8.674E-02 7.939E-02 7.223E-02 6.528E-02 5.857E-02 5.215E-02 4.602E-02 4.022E-02 3.477E-02 2.969E-02 2.499E-02 2.068E-02 1.678E-02 1.329E-02 1.022E-02 7.564E-03 5.320E-03 3.485E-03 2.049E-03 1.003E-03 3.339E-04 2.589E-05 6.178E-05 4.223E-04 1.086E-03 2.031E-03 3.234E-03 4.668E-03 6.309E-03 8.131E-03 1.011E-02 1.221E-02 1.441E-02 1.668E-02 1.901E-02 2.135E-02 2.369E-02 2.601E-02 2.828E-02 3.047E-02 3.258E-02 3.458E-02 3.645E-02 3.819E-02 3.977E-02 4.119E-02 4.244E-02 4.350E-02 4.438E-02 4.507E-02 4.556E-02 4.586E-02 4.597E-02 4.589E-02 4.562E-02 4.518E-02 4.456E-02 4.377E-02 4.283E-02 4.213E-02 4.317E-02 4.406E-02 4.479E-02 4.535E-02 4.574E-02 4.594E-02 4.595E-02 4.578E-02 4.540E-02 4.484E-02 4.408E-02 4.312E-02 4.199E-02 4.067E-02 3.918E-02 3.753E-02 3.573E-02 3.380E-02 3.175E-02 2.960E-02 2.736E-02 2.506E-02 2.272E-02 2.037E-02 1.802E-02 1.571E-02 1.345E-02 1.128E-02 9.219E-03 7.300E-03 5.548E-03 3.989E-03 2.651E-03 1.559E-03 7.385E-04 2.122E-04 2.840E-06 1.311E-04 6.158E-04 1.474E-03 2.720E-03 4.365E-03 6.421E-03 8.893E-03 1.179E-02 1.510E-02 1.883E-02 2.298E-02 2.754E-02 3.249E-02 3.782E-02 4.351E-02 4.955E-02 5.591E-02 6.255E-02 6.947E-02 7.661E-02 8.396E-02 9.147E-02 9.910E-02 1.068E-01 1.146E-01 1.224E-01 1.301E-01 1.378E-01 1.453E-01 1.527E-01 1.599E-01 1.668E-01 1.735E-01 1.798E-01 1.858E-01 1.914E-01 1.966E-01 2.013E-01 2.056E-01 2.094E-01 2.126E-01 2.154E-01 2.176E-01 2.193E-01 2.204E-01 2.210E-01 2.211E-01 2.206E-01 2.197E-01 2.182E-01 2.162E-01 2.138E-01 2.109E-01 2.076E-01 2.040E-01 2.000E-01 1.956E-01 1.910E-01 1.861E-01 1.811E-01 1.758E-01 1.704E-01 1.649E-01 1.594E-01 1.538E-01 1.482E-01 1.426E-01 1.371E-01 1.317E-01 1.264E-01 1.212E-01 1.162E-01 1.114E-01 1.068E-01 1.024E-01 9.826E-02 9.435E-02 9.068E-02 8.727E-02 8.413E-02 8.126E-02 7.866E-02 7.633E-02 7.428E-02 7.250E-02 7.100E-02 6.977E-02 6.881E-02 6.813E-02 6.772E-02 6.759E-02 6.772E-02 6.813E-02 6.881E-02 6.977E-02 7.100E-02 7.250E-02 7.428E-02 7.633E-02 7.866E-02 8.126E-02 8.413E-02 8.727E-02 9.068E-02 9.435E-02 9.826E-02 1.024E-01 1.068E-01 1.114E-01 1.162E-01 1.212E-01 1.264E-01 1.317E-01 1.371E-01 1.426E-01 1.482E-01 1.538E-01 1.594E-01 1.649E-01 1.704E-01 1.758E-01 1.811E-01 1.861E-01 1.910E-01 1.956E-01 2.000E-01 2.040E-01 2.076E-01 2.109E-01 2.138E-01 2.162E-01 2.182E-01 2.197E-01 2.206E-01 2.211E-01 2.210E-01 2.204E-01 2.193E-01 2.176E-01 2.154E-01 2.126E-01 2.094E-01 2.056E-01 2.013E-01 1.966E-01 1.914E-01 1.858E-01 1.798E-01 1.735E-01 1.668E-01 1.599E-01 1.527E-01 1.453E-01 1.378E-01 1.301E-01 1.224E-01 1.146E-01 1.068E-01 9.910E-02 9.147E-02 8.396E-02 7.661E-02 6.947E-02 6.255E-02 5.591E-02 4.955E-02 4.351E-02 3.782E-02 3.249E-02 2.754E-02 2.298E-02 1.883E-02 1.510E-02 1.179E-02 8.893E-03 6.421E-03 4.365E-03 2.720E-03 1.474E-03 6.158E-04 1.311E-04 2.840E-06 2.122E-04 7.385E-04 1.559E-03 2.651E-03 3.989E-03 5.548E-03 7.300E-03 9.219E-03 1.128E-02 1.345E-02 1.571E-02 1.802E-02 2.037E-02 2.272E-02 2.506E-02 2.736E-02 2.960E-02 3.175E-02 3.380E-02 3.573E-02 3.753E-02 3.918E-02 4.067E-02 4.199E-02 4.312E-02 4.408E-02 4.484E-02 4.540E-02 4.578E-02 4.595E-02 4.594E-02 4.574E-02 4.535E-02 4.479E-02 4.406E-02 4.317E-02 4.250E-02 4.349E-02 4.433E-02 4.500E-02 4.551E-02 4.583E-02 4.597E-02 4.591E-02 4.567E-02 4.522E-02 4.458E-02 4.375E-02 4.273E-02 4.152E-02 4.013E-02 3.858E-02 3.686E-02 3.501E-02 3.302E-02 3.092E-02 2.872E-02 2.645E-02 2.413E-02 2.177E-02 1.940E-02 1.706E-02 1.475E-02 1.252E-02 1.039E-02 8.375E-03 6.516E-03 4.838E-03 3.367E-03 2.130E-03 1.152E-03 4.594E-04 7.455E-05 1.967E-05 3.151E-04 9.791E-04 2.028E-03 3.475E-03 5.332E-03 7.608E-03 1.031E-02 1.344E-02 1.699E-02 2.097E-02 2.536E-02 3.016E-02 3.536E-02 4.093E-02 4.686E-02 5.313E-02 5.971E-02 6.657E-02 7.368E-02 8.101E-02 8.852E-02 9.618E-02 1.039E-01 1.118E-01 1.196E-01 1.275E-01 1.352E-01 1.429E-01 1.504E-01 1.578E-01 1.648E-01 1.717E-01 1.782E-01 1.843E-01 1.901E-01 1.955E-01 2.004E-01 2.048E-01 2.087E-01 2.121E-01 2.150E-01 2.174E-01 2.191E-01 2.204E-01 2.210E-01 2.211E-01 2.207E-01 2.197E-01 2.181E-01 2.161E-01 2.136E-01 2.106E-01 2.072E-01 2.033E-01 1.991E-01 1.946E-01 1.897E-01 1.846E-01 1.792E-01 1.737E-01 1.679E-01 1.621E-01 1.562E-01 1.503E-01 1.443E-01 1.384E-01 1.325E-01 1.267E-01 1.211E-01 1.156E-01 1.102E-01 1.051E-01 1.001E-01 9.543E-02 9.095E-02 8.673E-02 8.276E-02 7.907E-02 7.565E-02 7.250E-02 6.963E-02 6.704E-02 6.473E-02 6.270E-02 6.095E-02 5.947E-02 5.826E-02 5.732E-02 5.665E-02 5.625E-02 5.612E-02 5.625E-02 5.665E-02 5.732E-02 5.826E-02 5.947E-02 6.095E-02 6.270E-02 6.473E-02 6.704E-02 6.963E-02 7.250E-02 7.565E-02 7.907E-02 8.276E-02 8.673E-02 9.095E-02 9.543E-02 1.001E-01 1.051E-01 1.102E-01 1.156E-01 1.211E-01 1.267E-01 1.325E-01 1.384E-01 1.443E-01 1.503E-01 1.562E-01 1.621E-01 1.679E-01 1.737E-01 1.792E-01 1.846E-01 1.897E-01 1.946E-01 1.991E-01 2.033E-01 2.072E-01 2.106E-01 2.136E-01 2.161E-01 2.181E-01 2.197E-01 2.207E-01 2.211E-01 2.210E-01 2.204E-01 2.191E-01 2.174E-01 2.150E-01 2.121E-01 2.087E-01 2.048E-01 2.004E-01 1.955E-01 1.901E-01 1.843E-01 1.782E-01 1.717E-01 1.648E-01 1.578E-01 1.504E-01 1.429E-01 1.352E-01 1.275E-01 1.196E-01 1.118E-01 1.039E-01 9.618E-02 8.852E-02 8.101E-02 7.368E-02 6.657E-02 5.971E-02 5.313E-02 4.686E-02 4.093E-02 3.536E-02 3.016E-02 2.536E-02 2.097E-02 1.699E-02 1.344E-02 1.031E-02 7.608E-03 5.332E-03 3.475E-03 2.028E-03 9.791E-04 3.151E-04 1.967E-05 7.455E-05 4.594E-04 1.152E-03 2.130E-03 3.367E-03 4.838E-03 6.516E-03 8.375E-03 1.039E-02 1.252E-02 1.475E-02 1.706E-02 1.940E-02 2.177E-02 2.413E-02 2.645E-02 2.872E-02 3.092E-02 3.302E-02 3.501E-02 3.686E-02 3.858E-02 4.013E-02 4.152E-02 4.273E-02 4.375E-02 4.458E-02 4.522E-02 4.567E-02 4.591E-02 4.597E-02 4.583E-02 4.551E-02 4.500E-02 4.433E-02 4.349E-02 4.283E-02 4.378E-02 4.457E-02 4.519E-02 4.563E-02 4.590E-02 4.597E-02 4.585E-02 4.554E-02 4.502E-02 4.431E-02 4.341E-02 4.232E-02 4.104E-02 3.958E-02 3.796E-02 3.619E-02 3.428E-02 3.224E-02 3.009E-02 2.786E-02 2.555E-02 2.320E-02 2.083E-02 1.846E-02 1.612E-02 1.383E-02 1.163E-02 9.533E-03 7.574E-03 5.780E-03 4.180E-03 2.801E-03 1.668E-03 8.092E-04 2.478E-04 7.597E-06 1.101E-04 5.752E-04 1.421E-03 2.662E-03 4.312E-03 6.381E-03 8.877E-03 1.180E-02 1.516E-02 1.896E-02 2.317E-02 2.781E-02 3.285E-02 3.829E-02 4.409E-02 5.025E-02 5.674E-02 6.353E-02 7.060E-02 7.790E-02 8.540E-02 9.307E-02 1.009E-01 1.087E-01 1.167E-01 1.246E-01 1.325E-01 1.402E-01 1.479E-01 1.554E-01 1.626E-01 1.696E-01 1.763E-01 1.826E-01 1.886E-01 1.941E-01 1.992E-01 2.038E-01 2.079E-01 2.115E-01 2.146E-01 2.170E-01 2.189E-01 2.202E-01 2.210E-01 2.211E-01 2.207E-01 2.197E-01 2.182E-01 2.161E-01 2.135E-01 2.104E-01 2.069E-01 2.029E-01 1.985E-01 1.937E-01 1.887E-01 1.833E-01 1.777E-01 1.718E-01 1.658E-01 1.597E-01 1.534E-01 1.471E-01 1.408E-01 1.346E-01 1.284E-01 1.222E-01 1.162E-01 1.104E-01 1.047E-01 9.920E-02 9.394E-02 8.891E-02 8.413E-02 7.962E-02 7.537E-02 7.141E-02 6.772E-02 6.433E-02 6.122E-02 5.839E-02 5.585E-02 5.359E-02 5.161E-02 4.991E-02 4.847E-02 4.731E-02 4.640E-02 4.576E-02 4.537E-02 4.524E-02 4.537E-02 4.576E-02 4.640E-02 4.731E-02 4.847E-02 4.991E-02 5.161E-02 5.359E-02 5.585E-02 5.839E-02 6.122E-02 6.433E-02 6.772E-02 7.141E-02 7.537E-02 7.962E-02 8.413E-02 8.891E-02 9.394E-02 9.920E-02 1.047E-01 1.104E-01 1.162E-01 1.222E-01 1.284E-01 1.346E-01 1.408E-01 1.471E-01 1.534E-01 1.597E-01 1.658E-01 1.718E-01 1.777E-01 1.833E-01 1.887E-01 1.937E-01 1.985E-01 2.029E-01 2.069E-01 2.104E-01 2.135E-01 2.161E-01 2.182E-01 2.197E-01 2.207E-01 2.211E-01 2.210E-01 2.202E-01 2.189E-01 2.170E-01 2.146E-01 2.115E-01 2.079E-01 2.038E-01 1.992E-01 1.941E-01 1.886E-01 1.826E-01 1.763E-01 1.696E-01 1.626E-01 1.554E-01 1.479E-01 1.402E-01 1.325E-01 1.246E-01 1.167E-01 1.087E-01 1.009E-01 9.307E-02 8.540E-02 7.790E-02 7.060E-02 6.353E-02 5.674E-02 5.025E-02 4.409E-02 3.829E-02 3.285E-02 2.781E-02 2.317E-02 1.896E-02 1.516E-02 1.180E-02 8.877E-03 6.381E-03 4.312E-03 2.662E-03 1.421E-03 5.752E-04 1.101E-04 7.597E-06 2.478E-04 8.092E-04 1.668E-03 2.801E-03 4.180E-03 5.780E-03 7.574E-03 9.533E-03 1.163E-02 1.383E-02 1.612E-02 1.846E-02 2.083E-02 2.320E-02 2.555E-02 2.786E-02 3.009E-02 3.224E-02 3.428E-02 3.619E-02 3.796E-02 3.958E-02 4.104E-02 4.232E-02 4.341E-02 4.431E-02 4.502E-02 4.554E-02 4.585E-02 4.597E-02 4.590E-02 4.563E-02 4.519E-02 4.457E-02 4.378E-02 4.315E-02 4.405E-02 4.479E-02 4.535E-02 4.574E-02 4.594E-02 4.595E-02 4.577E-02 4.538E-02 4.480E-02 4.402E-02 4.305E-02 4.189E-02 4.054E-02 3.903E-02 3.735E-02 3.551E-02 3.355E-02 3.146E-02 2.927E-02 2.700E-02 2.467E-02 2.230E-02 1.991E-02 1.754E-02 1.521E-02 1.295E-02 1.077E-02 8.719E-03 6.817E-03 5.093E-03 3.575E-03 2.290E-03 1.266E-03 5.289E-04 1.022E-04 9.360E-06 2.717E-04 9.085E-04 1.937E-03 3.372E-03 5.225E-03 7.506E-03 1.022E-02 1.337E-02 1.697E-02 2.099E-02 2.545E-02 3.032E-02 3.560E-02 4.127E-02 4.730E-02 5.369E-02 6.039E-02 6.738E-02 7.463E-02 8.211E-02 8.977E-02 9.758E-02 1.055E-01 1.135E-01 1.215E-01 1.294E-01 1.374E-01 1.451E-01 1.528E-01 1.602E-01 1.673E-01 1.742E-01 1.807E-01 1.869E-01 1.926E-01 1.979E-01 2.027E-01 2.070E-01 2.107E-01 2.139E-01 2.166E-01 2.186E-01 2.201E-01 2.209E-01 2.211E-01 2.208E-01 2.198E-01 2.183E-01 2.162E-01 2.136E-01 2.104E-01 2.068E-01 2.027E-01 1.981E-01 1.932E-01 1.879E-01 1.823E-01 1.764E-01 1.703E-01 1.640E-01 1.576E-01 1.510E-01 1.444E-01 1.378E-01 1.312E-01 1.246E-01 1.182E-01 1.118E-01 1.056E-01 9.961E-02 9.380E-02 8.823E-02 8.290E-02 7.784E-02 7.305E-02 6.854E-02 6.433E-02 6.041E-02 5.679E-02 5.346E-02 5.043E-02 4.770E-02 4.524E-02 4.307E-02 4.118E-02 3.955E-02 3.819E-02 3.708E-02 3.623E-02 3.562E-02 3.526E-02 3.513E-02 3.526E-02 3.562E-02 3.623E-02 3.708E-02 3.819E-02 3.955E-02 4.118E-02 4.307E-02 4.524E-02 4.770E-02 5.043E-02 5.346E-02 5.679E-02 6.041E-02 6.433E-02 6.854E-02 7.305E-02 7.784E-02 8.290E-02 8.823E-02 9.380E-02 9.961E-02 1.056E-01 1.118E-01 1.182E-01 1.246E-01 1.312E-01 1.378E-01 1.444E-01 1.510E-01 1.576E-01 1.640E-01 1.703E-01 1.764E-01 1.823E-01 1.879E-01 1.932E-01 1.981E-01 2.027E-01 2.068E-01 2.104E-01 2.136E-01 2.162E-01 2.183E-01 2.198E-01 2.208E-01 2.211E-01 2.209E-01 2.201E-01 2.186E-01 2.166E-01 2.139E-01 2.107E-01 2.070E-01 2.027E-01 1.979E-01 1.926E-01 1.869E-01 1.807E-01 1.742E-01 1.673E-01 1.602E-01 1.528E-01 1.451E-01 1.374E-01 1.294E-01 1.215E-01 1.135E-01 1.055E-01 9.758E-02 8.977E-02 8.211E-02 7.463E-02 6.738E-02 6.039E-02 5.369E-02 4.730E-02 4.127E-02 3.560E-02 3.032E-02 2.545E-02 2.099E-02 1.697E-02 1.337E-02 1.022E-02 7.506E-03 5.225E-03 3.372E-03 1.937E-03 9.085E-04 2.717E-04 9.360E-06 1.022E-04 5.289E-04 1.266E-03 2.290E-03 3.575E-03 5.093E-03 6.817E-03 8.719E-03 1.077E-02 1.295E-02 1.521E-02 1.754E-02 1.991E-02 2.230E-02 2.467E-02 2.700E-02 2.927E-02 3.146E-02 3.355E-02 3.551E-02 3.735E-02 3.903E-02 4.054E-02 4.189E-02 4.305E-02 4.402E-02 4.480E-02 4.538E-02 4.577E-02 4.595E-02 4.594E-02 4.574E-02 4.535E-02 4.479E-02 4.405E-02 4.344E-02 4.430E-02 4.498E-02 4.550E-02 4.583E-02 4.597E-02 4.591E-02 4.566E-02 4.521E-02 4.457E-02 4.372E-02 4.268E-02 4.145E-02 4.004E-02 3.846E-02 3.672E-02 3.483E-02 3.281E-02 3.068E-02 2.845E-02 2.615E-02 2.379E-02 2.141E-02 1.902E-02 1.665E-02 1.433E-02 1.209E-02 9.951E-03 7.947E-03 6.105E-03 4.453E-03 3.021E-03 1.835E-03 9.228E-04 3.099E-04 2.057E-05 7.755E-05 5.017E-04 1.312E-03 2.524E-03 4.153E-03 6.210E-03 8.703E-03 1.164E-02 1.501E-02 1.883E-02 2.309E-02 2.778E-02 3.288E-02 3.839E-02 4.429E-02 5.055E-02 5.714E-02 6.405E-02 7.124E-02 7.867E-02 8.631E-02 9.412E-02 1.021E-01 1.101E-01 1.181E-01 1.262E-01 1.342E-01 1.421E-01 1.499E-01 1.575E-01 1.648E-01 1.718E-01 1.786E-01 1.849E-01 1.908E-01 1.963E-01 2.014E-01 2.058E-01 2.098E-01 2.132E-01 2.160E-01 2.182E-01 2.198E-01 2.208E-01 2.211E-01 2.209E-01 2.200E-01 2.185E-01 2.164E-01 2.138E-01 2.106E-01 2.069E-01 2.027E-01 1.980E-01 1.929E-01 1.875E-01 1.816E-01 1.755E-01 1.692E-01 1.626E-01 1.559E-01 1.490E-01 1.421E-01 1.352E-01 1.282E-01 1.213E-01 1.145E-01 1.079E-01 1.013E-01 9.502E-02 8.891E-02 8.304E-02 7.743E-02 7.209E-02 6.704E-02 6.230E-02 5.786E-02 5.373E-02 4.991E-02 4.640E-02 4.320E-02 4.030E-02 3.770E-02 3.538E-02 3.333E-02 3.156E-02 3.005E-02 2.878E-02 2.776E-02 2.697E-02 2.641E-02 2.608E-02 2.597E-02 2.608E-02 2.641E-02 2.697E-02 2.776E-02 2.878E-02 3.005E-02 3.156E-02 3.333E-02 3.538E-02 3.770E-02 4.030E-02 4.320E-02 4.640E-02 4.991E-02 5.373E-02 5.786E-02 6.230E-02 6.704E-02 7.209E-02 7.743E-02 8.304E-02 8.891E-02 9.502E-02 1.013E-01 1.079E-01 1.145E-01 1.213E-01 1.282E-01 1.352E-01 1.421E-01 1.490E-01 1.559E-01 1.626E-01 1.692E-01 1.755E-01 1.816E-01 1.875E-01 1.929E-01 1.980E-01 2.027E-01 2.069E-01 2.106E-01 2.138E-01 2.164E-01 2.185E-01 2.200E-01 2.209E-01 2.211E-01 2.208E-01 2.198E-01 2.182E-01 2.160E-01 2.132E-01 2.098E-01 2.058E-01 2.014E-01 1.963E-01 1.908E-01 1.849E-01 1.786E-01 1.718E-01 1.648E-01 1.575E-01 1.499E-01 1.421E-01 1.342E-01 1.262E-01 1.181E-01 1.101E-01 1.021E-01 9.412E-02 8.631E-02 7.867E-02 7.124E-02 6.405E-02 5.714E-02 5.055E-02 4.429E-02 3.839E-02 3.288E-02 2.778E-02 2.309E-02 1.883E-02 1.501E-02 1.164E-02 8.703E-03 6.210E-03 4.153E-03 2.524E-03 1.312E-03 5.017E-04 7.755E-05 2.057E-05 3.099E-04 9.228E-04 1.835E-03 3.021E-03 4.453E-03 6.105E-03 7.947E-03 9.951E-03 1.209E-02 1.433E-02 1.665E-02 1.902E-02 2.141E-02 2.379E-02 2.615E-02 2.845E-02 3.068E-02 3.281E-02 3.483E-02 3.672E-02 3.846E-02 4.004E-02 4.145E-02 4.268E-02 4.372E-02 4.457E-02 4.521E-02 4.566E-02 4.591E-02 4.597E-02 4.583E-02 4.550E-02 4.498E-02 4.430E-02 4.372E-02 4.452E-02 4.516E-02 4.562E-02 4.589E-02 4.597E-02 4.586E-02 4.554E-02 4.503E-02 4.431E-02 4.340E-02 4.230E-02 4.100E-02 3.953E-02 3.789E-02 3.609E-02 3.415E-02 3.209E-02 2.991E-02 2.765E-02 2.531E-02 2.294E-02 2.054E-02 1.815E-02 1.578E-02 1.348E-02 1.127E-02 9.169E-03 7.216E-03 5.437E-03 3.862E-03 2.518E-03 1.434E-03 6.364E-04 1.507E-04 9.375E-07 2.096E-04 7.971E-04 1.782E-03 3.179E-03 5.002E-03 7.262E-03 9.965E-03 1.312E-02 1.671E-02 2.076E-02 2.525E-02 3.016E-02 3.549E-02 4.123E-02 4.734E-02 5.382E-02 6.062E-02 6.772E-02 7.509E-02 8.269E-02 9.048E-02 9.843E-02 1.065E-01 1.146E-01 1.227E-01 1.308E-01 1.389E-01 1.468E-01 1.545E-01 1.620E-01 1.692E-01 1.761E-01 1.827E-01 1.889E-01 1.946E-01 1.998E-01 2.045E-01 2.087E-01 2.123E-01 2.153E-01 2.177E-01 2.195E-01 2.206E-01 2.211E-01 2.210E-01 2.202E-01 2.188E-01 2.167E-01 2.141E-01 2.109E-01 2.072E-01 2.029E-01 1.981E-01 1.929E-01 1.873E-01 1.813E-01 1.750E-01 1.684E-01 1.616E-01 1.546E-01 1.475E-01 1.403E-01 1.330E-01 1.257E-01 1.185E-01 1.114E-01 1.044E-01 9.759E-02 9.095E-02 8.454E-02 7.838E-02 7.250E-02 6.691E-02 6.162E-02 5.665E-02 5.201E-02 4.770E-02 4.371E-02 4.005E-02 3.672E-02 3.369E-02 3.098E-02 2.855E-02 2.641E-02 2.454E-02 2.292E-02 2.155E-02 2.042E-02 1.950E-02 1.880E-02 1.830E-02 1.801E-02 1.791E-02 1.801E-02 1.830E-02 1.880E-02 1.950E-02 2.042E-02 2.155E-02 2.292E-02 2.454E-02 2.641E-02 2.855E-02 3.098E-02 3.369E-02 3.672E-02 4.005E-02 4.371E-02 4.770E-02 5.201E-02 5.665E-02 6.162E-02 6.691E-02 7.250E-02 7.838E-02 8.454E-02 9.095E-02 9.759E-02 1.044E-01 1.114E-01 1.185E-01 1.257E-01 1.330E-01 1.403E-01 1.475E-01 1.546E-01 1.616E-01 1.684E-01 1.750E-01 1.813E-01 1.873E-01 1.929E-01 1.981E-01 2.029E-01 2.072E-01 2.109E-01 2.141E-01 2.167E-01 2.188E-01 2.202E-01 2.210E-01 2.211E-01 2.206E-01 2.195E-01 2.177E-01 2.153E-01 2.123E-01 2.087E-01 2.045E-01 1.998E-01 1.946E-01 1.889E-01 1.827E-01 1.761E-01 1.692E-01 1.620E-01 1.545E-01 1.468E-01 1.389E-01 1.308E-01 1.227E-01 1.146E-01 1.065E-01 9.843E-02 9.048E-02 8.269E-02 7.509E-02 6.772E-02 6.062E-02 5.382E-02 4.734E-02 4.123E-02 3.549E-02 3.016E-02 2.525E-02 2.076E-02 1.671E-02 1.312E-02 9.965E-03 7.262E-03 5.002E-03 3.179E-03 1.782E-03 7.971E-04 2.096E-04 9.375E-07 1.507E-04 6.364E-04 1.434E-03 2.518E-03 3.862E-03 5.437E-03 7.216E-03 9.169E-03 1.127E-02 1.348E-02 1.578E-02 1.815E-02 2.054E-02 2.294E-02 2.531E-02 2.765E-02 2.991E-02 3.209E-02 3.415E-02 3.609E-02 3.789E-02 3.953E-02 4.100E-02 4.230E-02 4.340E-02 4.431E-02 4.503E-02 4.554E-02 4.586E-02 4.597E-02 4.589E-02 4.562E-02 4.516E-02 4.452E-02 4.397E-02 4.473E-02 4.531E-02 4.572E-02 4.593E-02 4.596E-02 4.578E-02 4.540E-02 4.483E-02 4.405E-02 4.307E-02 4.190E-02 4.054E-02 3.901E-02 3.731E-02 3.546E-02 3.347E-02 3.136E-02 2.915E-02 2.685E-02 2.449E-02 2.210E-02 1.969E-02 1.730E-02 1.494E-02 1.266E-02 1.048E-02 8.424E-03 6.525E-03 4.814E-03 3.318E-03 2.066E-03 1.086E-03 4.056E-04 4.919E-05 4.092E-05 4.028E-04 1.155E-03 2.314E-03 3.896E-03 5.913E-03 8.375E-03 1.129E-02 1.465E-02 1.847E-02 2.274E-02 2.745E-02 3.259E-02 3.814E-02 4.409E-02 5.042E-02 5.710E-02 6.410E-02 7.139E-02 7.893E-02 8.668E-02 9.462E-02 1.027E-01 1.108E-01 1.190E-01 1.272E-01 1.354E-01 1.434E-01 1.513E-01 1.589E-01 1.663E-01 1.735E-01 1.802E-01 1.866E-01 1.926E-01 1.980E-01 2.030E-01 2.074E-01 2.112E-01 2.145E-01 2.171E-01 2.191E-01 2.204E-01 2.211E-01 2.211E-01 2.204E-01 2.191E-01 2.171E-01 2.146E-01 2.114E-01 2.076E-01 2.033E-01 1.985E-01 1.932E-01 1.875E-01 1.813E-01 1.748E-01 1.680E-01 1.610E-01 1.538E-01 1.464E-01 1.389E-01 1.313E-01 1.237E-01 1.162E-01 1.088E-01 1.015E-01 9.435E-02 8.741E-02 8.071E-02 7.428E-02 6.813E-02 6.230E-02 5.679E-02 5.161E-02 4.679E-02 4.231E-02 3.819E-02 3.441E-02 3.098E-02 2.787E-02 2.508E-02 2.260E-02 2.042E-02 1.850E-02 1.684E-02 1.543E-02 1.424E-02 1.326E-02 1.248E-02 1.189E-02 1.147E-02 1.122E-02 1.114E-02 1.122E-02 1.147E-02 1.189E-02 1.248E-02 1.326E-02 1.424E-02 1.543E-02 1.684E-02 1.850E-02 2.042E-02 2.260E-02 2.508E-02 2.787E-02 3.098E-02 3.441E-02 3.819E-02 4.231E-02 4.679E-02 5.161E-02 5.679E-02 6.230E-02 6.813E-02 7.428E-02 8.071E-02 8.741E-02 9.435E-02 1.015E-01 1.088E-01 1.162E-01 1.237E-01 1.313E-01 1.389E-01 1.464E-01 1.538E-01 1.610E-01 1.680E-01 1.748E-01 1.813E-01 1.875E-01 1.932E-01 1.985E-01 2.033E-01 2.076E-01 2.114E-01 2.146E-01 2.171E-01 2.191E-01 2.204E-01 2.211E-01 2.211E-01 2.204E-01 2.191E-01 2.171E-01 2.145E-01 2.112E-01 2.074E-01 2.030E-01 1.980E-01 1.926E-01 1.866E-01 1.802E-01 1.735E-01 1.663E-01 1.589E-01 1.513E-01 1.434E-01 1.354E-01 1.272E-01 1.190E-01 1.108E-01 1.027E-01 9.462E-02 8.668E-02 7.893E-02 7.139E-02 6.410E-02 5.710E-02 5.042E-02 4.409E-02 3.814E-02 3.259E-02 2.745E-02 2.274E-02 1.847E-02 1.465E-02 1.129E-02 8.375E-03 5.913E-03 3.896E-03 2.314E-03 1.155E-03 4.028E-04 4.092E-05 4.919E-05 4.056E-04 1.086E-03 2.066E-03 3.318E-03 4.814E-03 6.525E-03 8.424E-03 1.048E-02 1.266E-02 1.494E-02 1.730E-02 1.969E-02 2.210E-02 2.449E-02 2.685E-02 2.915E-02 3.136E-02 3.347E-02 3.546E-02 3.731E-02 3.901E-02 4.054E-02 4.190E-02 4.307E-02 4.405E-02 4.483E-02 4.540E-02 4.578E-02 4.596E-02 4.593E-02 4.572E-02 4.531E-02 4.473E-02 4.420E-02 4.492E-02 4.545E-02 4.580E-02 4.596E-02 4.593E-02 4.569E-02 4.525E-02 4.461E-02 4.377E-02 4.273E-02 4.150E-02 4.008E-02 3.849E-02 3.674E-02 3.483E-02 3.280E-02 3.064E-02 2.839E-02 2.606E-02 2.368E-02 2.127E-02 1.886E-02 1.647E-02 1.413E-02 1.187E-02 9.726E-03 7.717E-03 5.876E-03 4.234E-03 2.820E-03 1.663E-03 7.903E-04 2.286E-04 3.342E-06 1.379E-04 6.540E-04 1.571E-03 2.906E-03 4.672E-03 6.882E-03 9.544E-03 1.266E-02 1.624E-02 2.027E-02 2.476E-02 2.969E-02 3.505E-02 4.082E-02 4.698E-02 5.351E-02 6.039E-02 6.757E-02 7.504E-02 8.274E-02 9.065E-02 9.871E-02 1.069E-01 1.151E-01 1.234E-01 1.316E-01 1.398E-01 1.478E-01 1.556E-01 1.632E-01 1.705E-01 1.775E-01 1.841E-01 1.903E-01 1.960E-01 2.012E-01 2.059E-01 2.100E-01 2.135E-01 2.163E-01 2.185E-01 2.201E-01 2.209E-01 2.211E-01 2.206E-01 2.195E-01 2.176E-01 2.151E-01 2.120E-01 2.083E-01 2.040E-01 1.991E-01 1.937E-01 1.879E-01 1.816E-01 1.750E-01 1.680E-01 1.608E-01 1.533E-01 1.457E-01 1.379E-01 1.301E-01 1.222E-01 1.144E-01 1.067E-01 9.907E-02 9.163E-02 8.441E-02 7.743E-02 7.072E-02 6.433E-02 5.826E-02 5.254E-02 4.718E-02 4.219E-02 3.757E-02 3.333E-02 2.947E-02 2.597E-02 2.282E-02 2.001E-02 1.752E-02 1.534E-02 1.344E-02 1.181E-02 1.041E-02 9.244E-03 8.276E-03 7.491E-03 6.874E-03 6.409E-03 6.085E-03 5.894E-03 5.831E-03 5.894E-03 6.085E-03 6.409E-03 6.874E-03 7.491E-03 8.276E-03 9.244E-03 1.041E-02 1.181E-02 1.344E-02 1.534E-02 1.752E-02 2.001E-02 2.282E-02 2.597E-02 2.947E-02 3.333E-02 3.757E-02 4.219E-02 4.718E-02 5.254E-02 5.826E-02 6.433E-02 7.072E-02 7.743E-02 8.441E-02 9.163E-02 9.907E-02 1.067E-01 1.144E-01 1.222E-01 1.301E-01 1.379E-01 1.457E-01 1.533E-01 1.608E-01 1.680E-01 1.750E-01 1.816E-01 1.879E-01 1.937E-01 1.991E-01 2.040E-01 2.083E-01 2.120E-01 2.151E-01 2.176E-01 2.195E-01 2.206E-01 2.211E-01 2.209E-01 2.201E-01 2.185E-01 2.163E-01 2.135E-01 2.100E-01 2.059E-01 2.012E-01 1.960E-01 1.903E-01 1.841E-01 1.775E-01 1.705E-01 1.632E-01 1.556E-01 1.478E-01 1.398E-01 1.316E-01 1.234E-01 1.151E-01 1.069E-01 9.871E-02 9.065E-02 8.274E-02 7.504E-02 6.757E-02 6.039E-02 5.351E-02 4.698E-02 4.082E-02 3.505E-02 2.969E-02 2.476E-02 2.027E-02 1.624E-02 1.266E-02 9.544E-03 6.882E-03 4.672E-03 2.906E-03 1.571E-03 6.540E-04 1.379E-04 3.342E-06 2.286E-04 7.903E-04 1.663E-03 2.820E-03 4.234E-03 5.876E-03 7.717E-03 9.726E-03 1.187E-02 1.413E-02 1.647E-02 1.886E-02 2.127E-02 2.368E-02 2.606E-02 2.839E-02 3.064E-02 3.280E-02 3.483E-02 3.674E-02 3.849E-02 4.008E-02 4.150E-02 4.273E-02 4.377E-02 4.461E-02 4.525E-02 4.569E-02 4.593E-02 4.596E-02 4.580E-02 4.545E-02 4.492E-02 4.442E-02 4.508E-02 4.557E-02 4.587E-02 4.597E-02 4.588E-02 4.558E-02 4.508E-02 4.438E-02 4.348E-02 4.238E-02 4.109E-02 3.961E-02 3.796E-02 3.616E-02 3.421E-02 3.212E-02 2.993E-02 2.765E-02 2.529E-02 2.289E-02 2.047E-02 1.805E-02 1.567E-02 1.335E-02 1.112E-02 9.008E-03 7.048E-03 5.268E-03 3.699E-03 2.369E-03 1.309E-03 5.445E-04 1.036E-04 1.073E-05 2.892E-04 9.600E-04 2.042E-03 3.552E-03 5.502E-03 7.904E-03 1.076E-02 1.409E-02 1.787E-02 2.212E-02 2.682E-02 3.196E-02 3.753E-02 4.351E-02 4.988E-02 5.661E-02 6.367E-02 7.104E-02 7.867E-02 8.652E-02 9.456E-02 1.027E-01 1.110E-01 1.193E-01 1.276E-01 1.359E-01 1.441E-01 1.520E-01 1.598E-01 1.673E-01 1.745E-01 1.814E-01 1.878E-01 1.938E-01 1.992E-01 2.042E-01 2.085E-01 2.123E-01 2.154E-01 2.179E-01 2.196E-01 2.207E-01 2.211E-01 2.208E-01 2.198E-01 2.182E-01 2.158E-01 2.128E-01 2.091E-01 2.048E-01 2.000E-01 1.946E-01 1.887E-01 1.823E-01 1.755E-01 1.684E-01 1.610E-01 1.533E-01 1.455E-01 1.374E-01 1.293E-01 1.212E-01 1.131E-01 1.051E-01 9.718E-02 8.946E-02 8.194E-02 7.469E-02 6.772E-02 6.108E-02 5.479E-02 4.886E-02 4.333E-02 3.819E-02 3.345E-02 2.912E-02 2.519E-02 2.166E-02 1.850E-02 1.571E-02 1.326E-02 1.114E-02 9.320E-03 7.773E-03 6.474E-03 5.398E-03 4.519E-03 3.813E-03 3.258E-03 2.832E-03 2.520E-03 2.307E-03 2.184E-03 2.143E-03 2.184E-03 2.307E-03 2.520E-03 2.832E-03 3.258E-03 3.813E-03 4.519E-03 5.398E-03 6.474E-03 7.773E-03 9.320E-03 1.114E-02 1.326E-02 1.571E-02 1.850E-02 2.166E-02 2.519E-02 2.912E-02 3.345E-02 3.819E-02 4.333E-02 4.886E-02 5.479E-02 6.108E-02 6.772E-02 7.469E-02 8.194E-02 8.946E-02 9.718E-02 1.051E-01 1.131E-01 1.212E-01 1.293E-01 1.374E-01 1.455E-01 1.533E-01 1.610E-01 1.684E-01 1.755E-01 1.823E-01 1.887E-01 1.946E-01 2.000E-01 2.048E-01 2.091E-01 2.128E-01 2.158E-01 2.182E-01 2.198E-01 2.208E-01 2.211E-01 2.207E-01 2.196E-01 2.179E-01 2.154E-01 2.123E-01 2.085E-01 2.042E-01 1.992E-01 1.938E-01 1.878E-01 1.814E-01 1.745E-01 1.673E-01 1.598E-01 1.520E-01 1.441E-01 1.359E-01 1.276E-01 1.193E-01 1.110E-01 1.027E-01 9.456E-02 8.652E-02 7.867E-02 7.104E-02 6.367E-02 5.661E-02 4.988E-02 4.351E-02 3.753E-02 3.196E-02 2.682E-02 2.212E-02 1.787E-02 1.409E-02 1.076E-02 7.904E-03 5.502E-03 3.552E-03 2.042E-03 9.600E-04 2.892E-04 1.073E-05 1.036E-04 5.445E-04 1.309E-03 2.369E-03 3.699E-03 5.268E-03 7.048E-03 9.008E-03 1.112E-02 1.335E-02 1.567E-02 1.805E-02 2.047E-02 2.289E-02 2.529E-02 2.765E-02 2.993E-02 3.212E-02 3.421E-02 3.616E-02 3.796E-02 3.961E-02 4.109E-02 4.238E-02 4.348E-02 4.438E-02 4.508E-02 4.558E-02 4.588E-02 4.597E-02 4.587E-02 4.557E-02 4.508E-02 4.462E-02 4.523E-02 4.567E-02 4.592E-02 4.597E-02 4.582E-02 4.546E-02 4.490E-02 4.414E-02 4.318E-02 4.202E-02 4.067E-02 3.914E-02 3.744E-02 3.558E-02 3.358E-02 3.146E-02 2.923E-02 2.691E-02 2.453E-02 2.212E-02 1.969E-02 1.727E-02 1.490E-02 1.260E-02 1.040E-02 8.326E-03 6.417E-03 4.700E-03 3.206E-03 1.963E-03 1.001E-03 3.472E-04 2.826E-05 6.879E-05 4.916E-04 1.317E-03 2.564E-03 4.248E-03 6.381E-03 8.973E-03 1.203E-02 1.555E-02 1.955E-02 2.400E-02 2.891E-02 3.426E-02 4.004E-02 4.622E-02 5.279E-02 5.971E-02 6.695E-02 7.448E-02 8.227E-02 9.026E-02 9.843E-02 1.067E-01 1.151E-01 1.234E-01 1.318E-01 1.401E-01 1.482E-01 1.562E-01 1.639E-01 1.713E-01 1.783E-01 1.850E-01 1.912E-01 1.970E-01 2.022E-01 2.068E-01 2.109E-01 2.143E-01 2.170E-01 2.191E-01 2.204E-01 2.211E-01 2.210E-01 2.202E-01 2.187E-01 2.165E-01 2.136E-01 2.100E-01 2.058E-01 2.010E-01 1.956E-01 1.897E-01 1.833E-01 1.764E-01 1.692E-01 1.616E-01 1.538E-01 1.457E-01 1.374E-01 1.291E-01 1.207E-01 1.123E-01 1.040E-01 9.583E-02 8.782E-02 8.003E-02 7.250E-02 6.528E-02 5.839E-02 5.188E-02 4.576E-02 4.005E-02 3.477E-02 2.993E-02 2.552E-02 2.155E-02 1.801E-02 1.488E-02 1.214E-02 9.783E-03 7.773E-03 6.085E-03 4.690E-03 3.556E-03 2.652E-03 1.946E-03 1.408E-03 1.007E-03 7.180E-04 5.163E-04 3.816E-04 2.974E-04 2.518E-04 2.374E-04 2.518E-04 2.974E-04 3.816E-04 5.163E-04 7.180E-04 1.007E-03 1.408E-03 1.946E-03 2.652E-03 3.556E-03 4.690E-03 6.085E-03 7.773E-03 9.783E-03 1.214E-02 1.488E-02 1.801E-02 2.155E-02 2.552E-02 2.993E-02 3.477E-02 4.005E-02 4.576E-02 5.188E-02 5.839E-02 6.528E-02 7.250E-02 8.003E-02 8.782E-02 9.583E-02 1.040E-01 1.123E-01 1.207E-01 1.291E-01 1.374E-01 1.457E-01 1.538E-01 1.616E-01 1.692E-01 1.764E-01 1.833E-01 1.897E-01 1.956E-01 2.010E-01 2.058E-01 2.100E-01 2.136E-01 2.165E-01 2.187E-01 2.202E-01 2.210E-01 2.211E-01 2.204E-01 2.191E-01 2.170E-01 2.143E-01 2.109E-01 2.068E-01 2.022E-01 1.970E-01 1.912E-01 1.850E-01 1.783E-01 1.713E-01 1.639E-01 1.562E-01 1.482E-01 1.401E-01 1.318E-01 1.234E-01 1.151E-01 1.067E-01 9.843E-02 9.026E-02 8.227E-02 7.448E-02 6.695E-02 5.971E-02 5.279E-02 4.622E-02 4.004E-02 3.426E-02 2.891E-02 2.400E-02 1.955E-02 1.555E-02 1.203E-02 8.973E-03 6.381E-03 4.248E-03 2.564E-03 1.317E-03 4.916E-04 6.879E-05 2.826E-05 3.472E-04 1.001E-03 1.963E-03 3.206E-03 4.700E-03 6.417E-03 8.326E-03 1.040E-02 1.260E-02 1.490E-02 1.727E-02 1.969E-02 2.212E-02 2.453E-02 2.691E-02 2.923E-02 3.146E-02 3.358E-02 3.558E-02 3.744E-02 3.914E-02 4.067E-02 4.202E-02 4.318E-02 4.414E-02 4.490E-02 4.546E-02 4.582E-02 4.597E-02 4.592E-02 4.567E-02 4.523E-02 4.479E-02 4.537E-02 4.575E-02 4.595E-02 4.594E-02 4.574E-02 4.533E-02 4.471E-02 4.389E-02 4.287E-02 4.165E-02 4.025E-02 3.866E-02 3.691E-02 3.501E-02 3.296E-02 3.080E-02 2.854E-02 2.619E-02 2.379E-02 2.136E-02 1.893E-02 1.652E-02 1.415E-02 1.187E-02 9.706E-03 7.678E-03 5.824E-03 4.173E-03 2.755E-03 1.601E-03 7.385E-04 1.963E-04 2.914E-07 1.748E-04 7.422E-04 1.723E-03 3.134E-03 4.991E-03 7.304E-03 1.008E-02 1.333E-02 1.706E-02 2.125E-02 2.591E-02 3.102E-02 3.658E-02 4.255E-02 4.893E-02 5.569E-02 6.279E-02 7.020E-02 7.790E-02 8.583E-02 9.395E-02 1.022E-01 1.106E-01 1.190E-01 1.275E-01 1.358E-01 1.441E-01 1.522E-01 1.601E-01 1.677E-01 1.750E-01 1.820E-01 1.884E-01 1.945E-01 2.000E-01 2.049E-01 2.093E-01 2.130E-01 2.160E-01 2.184E-01 2.200E-01 2.209E-01 2.211E-01 2.206E-01 2.193E-01 2.173E-01 2.145E-01 2.111E-01 2.070E-01 2.023E-01 1.969E-01 1.910E-01 1.846E-01 1.777E-01 1.703E-01 1.626E-01 1.546E-01 1.464E-01 1.379E-01 1.293E-01 1.207E-01 1.121E-01 1.035E-01 9.502E-02 8.673E-02 7.866E-02 7.086E-02 6.338E-02 5.625E-02 4.952E-02 4.320E-02 3.733E-02 3.191E-02 2.697E-02 2.250E-02 1.850E-02 1.497E-02 1.189E-02 9.244E-03 7.009E-03 5.157E-03 3.658E-03 2.477E-03 1.578E-03 9.237E-04 4.758E-04 1.968E-04 4.997E-05 9.434E-07 1.796E-05 7.283E-05 1.415E-04 2.048E-04 2.485E-04 2.640E-04 2.485E-04 2.048E-04 1.415E-04 7.283E-05 1.796E-05 9.434E-07 4.997E-05 1.968E-04 4.758E-04 9.237E-04 1.578E-03 2.477E-03 3.658E-03 5.157E-03 7.009E-03 9.244E-03 1.189E-02 1.497E-02 1.850E-02 2.250E-02 2.697E-02 3.191E-02 3.733E-02 4.320E-02 4.952E-02 5.625E-02 6.338E-02 7.086E-02 7.866E-02 8.673E-02 9.502E-02 1.035E-01 1.121E-01 1.207E-01 1.293E-01 1.379E-01 1.464E-01 1.546E-01 1.626E-01 1.703E-01 1.777E-01 1.846E-01 1.910E-01 1.969E-01 2.023E-01 2.070E-01 2.111E-01 2.145E-01 2.173E-01 2.193E-01 2.206E-01 2.211E-01 2.209E-01 2.200E-01 2.184E-01 2.160E-01 2.130E-01 2.093E-01 2.049E-01 2.000E-01 1.945E-01 1.884E-01 1.820E-01 1.750E-01 1.677E-01 1.601E-01 1.522E-01 1.441E-01 1.358E-01 1.275E-01 1.190E-01 1.106E-01 1.022E-01 9.395E-02 8.583E-02 7.790E-02 7.020E-02 6.279E-02 5.569E-02 4.893E-02 4.255E-02 3.658E-02 3.102E-02 2.591E-02 2.125E-02 1.706E-02 1.333E-02 1.008E-02 7.304E-03 4.991E-03 3.134E-03 1.723E-03 7.422E-04 1.748E-04 2.914E-07 1.963E-04 7.385E-04 1.601E-03 2.755E-03 4.173E-03 5.824E-03 7.678E-03 9.706E-03 1.187E-02 1.415E-02 1.652E-02 1.893E-02 2.136E-02 2.379E-02 2.619E-02 2.854E-02 3.080E-02 3.296E-02 3.501E-02 3.691E-02 3.866E-02 4.025E-02 4.165E-02 4.287E-02 4.389E-02 4.471E-02 4.533E-02 4.574E-02 4.594E-02 4.595E-02 4.575E-02 4.537E-02 4.496E-02 4.548E-02 4.582E-02 4.597E-02 4.591E-02 4.565E-02 4.518E-02 4.451E-02 4.363E-02 4.256E-02 4.128E-02 3.983E-02 3.819E-02 3.639E-02 3.444E-02 3.235E-02 3.015E-02 2.786E-02 2.549E-02 2.307E-02 2.063E-02 1.819E-02 1.578E-02 1.344E-02 1.118E-02 9.048E-03 7.066E-03 5.268E-03 3.684E-03 2.345E-03 1.280E-03 5.195E-04 8.981E-05 1.718E-05 3.258E-04 1.038E-03 2.172E-03 3.746E-03 5.774E-03 8.267E-03 1.123E-02 1.467E-02 1.859E-02 2.298E-02 2.784E-02 3.315E-02 3.890E-02 4.507E-02 5.164E-02 5.857E-02 6.585E-02 7.343E-02 8.127E-02 8.934E-02 9.758E-02 1.060E-01 1.144E-01 1.229E-01 1.314E-01 1.398E-01 1.480E-01 1.561E-01 1.639E-01 1.714E-01 1.786E-01 1.854E-01 1.917E-01 1.975E-01 2.027E-01 2.074E-01 2.114E-01 2.148E-01 2.175E-01 2.194E-01 2.207E-01 2.211E-01 2.209E-01 2.198E-01 2.181E-01 2.155E-01 2.123E-01 2.083E-01 2.037E-01 1.984E-01 1.926E-01 1.861E-01 1.792E-01 1.718E-01 1.640E-01 1.559E-01 1.475E-01 1.389E-01 1.301E-01 1.212E-01 1.123E-01 1.035E-01 9.475E-02 8.618E-02 7.784E-02 6.977E-02 6.203E-02 5.466E-02 4.770E-02 4.118E-02 3.513E-02 2.958E-02 2.454E-02 2.001E-02 1.599E-02 1.248E-02 9.473E-03 6.941E-03 4.863E-03 3.209E-03 1.946E-03 1.036E-03 4.369E-04 1.066E-04 2.496E-07 7.283E-05 2.800E-04 5.789E-04 9.292E-04 1.294E-03 1.640E-03 1.939E-03 2.169E-03 2.314E-03 2.364E-03 2.314E-03 2.169E-03 1.939E-03 1.640E-03 1.294E-03 9.292E-04 5.789E-04 2.800E-04 7.283E-05 2.496E-07 1.066E-04 4.369E-04 1.036E-03 1.946E-03 3.209E-03 4.863E-03 6.941E-03 9.473E-03 1.248E-02 1.599E-02 2.001E-02 2.454E-02 2.958E-02 3.513E-02 4.118E-02 4.770E-02 5.466E-02 6.203E-02 6.977E-02 7.784E-02 8.618E-02 9.475E-02 1.035E-01 1.123E-01 1.212E-01 1.301E-01 1.389E-01 1.475E-01 1.559E-01 1.640E-01 1.718E-01 1.792E-01 1.861E-01 1.926E-01 1.984E-01 2.037E-01 2.083E-01 2.123E-01 2.155E-01 2.181E-01 2.198E-01 2.209E-01 2.211E-01 2.207E-01 2.194E-01 2.175E-01 2.148E-01 2.114E-01 2.074E-01 2.027E-01 1.975E-01 1.917E-01 1.854E-01 1.786E-01 1.714E-01 1.639E-01 1.561E-01 1.480E-01 1.398E-01 1.314E-01 1.229E-01 1.144E-01 1.060E-01 9.758E-02 8.934E-02 8.127E-02 7.343E-02 6.585E-02 5.857E-02 5.164E-02 4.507E-02 3.890E-02 3.315E-02 2.784E-02 2.298E-02 1.859E-02 1.467E-02 1.123E-02 8.267E-03 5.774E-03 3.746E-03 2.172E-03 1.038E-03 3.258E-04 1.718E-05 8.981E-05 5.195E-04 1.280E-03 2.345E-03 3.684E-03 5.268E-03 7.066E-03 9.048E-03 1.118E-02 1.344E-02 1.578E-02 1.819E-02 2.063E-02 2.307E-02 2.549E-02 2.786E-02 3.015E-02 3.235E-02 3.444E-02 3.639E-02 3.819E-02 3.983E-02 4.128E-02 4.256E-02 4.363E-02 4.451E-02 4.518E-02 4.565E-02 4.591E-02 4.597E-02 4.582E-02 4.548E-02 4.510E-02 4.559E-02 4.588E-02 4.597E-02 4.586E-02 4.555E-02 4.503E-02 4.430E-02 4.337E-02 4.224E-02 4.091E-02 3.940E-02 3.772E-02 3.587E-02 3.387E-02 3.175E-02 2.951E-02 2.719E-02 2.480E-02 2.236E-02 1.991E-02 1.748E-02 1.508E-02 1.275E-02 1.052E-02 8.424E-03 6.489E-03 4.749E-03 3.234E-03 1.974E-03 1.001E-03 3.421E-04 2.532E-05 7.627E-05 5.187E-04 1.374E-03 2.662E-03 4.398E-03 6.595E-03 9.264E-03 1.241E-02 1.604E-02 2.015E-02 2.473E-02 2.978E-02 3.529E-02 4.123E-02 4.759E-02 5.433E-02 6.144E-02 6.888E-02 7.661E-02 8.460E-02 9.279E-02 1.011E-01 1.096E-01 1.181E-01 1.267E-01 1.352E-01 1.436E-01 1.518E-01 1.598E-01 1.676E-01 1.750E-01 1.820E-01 1.886E-01 1.947E-01 2.003E-01 2.053E-01 2.096E-01 2.133E-01 2.164E-01 2.187E-01 2.202E-01 2.210E-01 2.211E-01 2.203E-01 2.188E-01 2.165E-01 2.135E-01 2.097E-01 2.053E-01 2.001E-01 1.944E-01 1.880E-01 1.811E-01 1.737E-01 1.658E-01 1.576E-01 1.490E-01 1.403E-01 1.313E-01 1.222E-01 1.131E-01 1.040E-01 9.502E-02 8.618E-02 7.756E-02 6.922E-02 6.122E-02 5.359E-02 4.640E-02 3.968E-02 3.345E-02 2.776E-02 2.260E-02 1.801E-02 1.397E-02 1.049E-02 7.561E-03 5.157E-03 3.258E-03 1.832E-03 8.437E-04 2.518E-04 1.105E-05 7.283E-05 3.863E-04 8.991E-04 1.559E-03 2.314E-03 3.115E-03 3.914E-03 4.670E-03 5.343E-03 5.901E-03 6.319E-03 6.577E-03 6.665E-03 6.577E-03 6.319E-03 5.901E-03 5.343E-03 4.670E-03 3.914E-03 3.115E-03 2.314E-03 1.559E-03 8.991E-04 3.863E-04 7.283E-05 1.105E-05 2.518E-04 8.437E-04 1.832E-03 3.258E-03 5.157E-03 7.561E-03 1.049E-02 1.397E-02 1.801E-02 2.260E-02 2.776E-02 3.345E-02 3.968E-02 4.640E-02 5.359E-02 6.122E-02 6.922E-02 7.756E-02 8.618E-02 9.502E-02 1.040E-01 1.131E-01 1.222E-01 1.313E-01 1.403E-01 1.490E-01 1.576E-01 1.658E-01 1.737E-01 1.811E-01 1.880E-01 1.944E-01 2.001E-01 2.053E-01 2.097E-01 2.135E-01 2.165E-01 2.188E-01 2.203E-01 2.211E-01 2.210E-01 2.202E-01 2.187E-01 2.164E-01 2.133E-01 2.096E-01 2.053E-01 2.003E-01 1.947E-01 1.886E-01 1.820E-01 1.750E-01 1.676E-01 1.598E-01 1.518E-01 1.436E-01 1.352E-01 1.267E-01 1.181E-01 1.096E-01 1.011E-01 9.279E-02 8.460E-02 7.661E-02 6.888E-02 6.144E-02 5.433E-02 4.759E-02 4.123E-02 3.529E-02 2.978E-02 2.473E-02 2.015E-02 1.604E-02 1.241E-02 9.264E-03 6.595E-03 4.398E-03 2.662E-03 1.374E-03 5.187E-04 7.627E-05 2.532E-05 3.421E-04 1.001E-03 1.974E-03 3.234E-03 4.749E-03 6.489E-03 8.424E-03 1.052E-02 1.275E-02 1.508E-02 1.748E-02 1.991E-02 2.236E-02 2.480E-02 2.719E-02 2.951E-02 3.175E-02 3.387E-02 3.587E-02 3.772E-02 3.940E-02 4.091E-02 4.224E-02 4.337E-02 4.430E-02 4.503E-02 4.555E-02 4.586E-02 4.597E-02 4.588E-02 4.559E-02 4.524E-02 4.567E-02 4.592E-02 4.596E-02 4.581E-02 4.544E-02 4.487E-02 4.409E-02 4.310E-02 4.192E-02 4.054E-02 3.898E-02 3.724E-02 3.535E-02 3.332E-02 3.115E-02 2.889E-02 2.654E-02 2.413E-02 2.168E-02 1.922E-02 1.679E-02 1.440E-02 1.209E-02 9.890E-03 7.832E-03 5.946E-03 4.265E-03 2.820E-03 1.642E-03 7.605E-04 2.042E-04 4.667E-07 1.748E-04 7.505E-04 1.749E-03 3.188E-03 5.084E-03 7.448E-03 1.029E-02 1.362E-02 1.743E-02 2.172E-02 2.650E-02 3.173E-02 3.743E-02 4.355E-02 5.009E-02 5.701E-02 6.429E-02 7.188E-02 7.976E-02 8.787E-02 9.618E-02 1.046E-01 1.132E-01 1.218E-01 1.304E-01 1.389E-01 1.472E-01 1.554E-01 1.634E-01 1.710E-01 1.783E-01 1.852E-01 1.916E-01 1.975E-01 2.029E-01 2.076E-01 2.116E-01 2.150E-01 2.177E-01 2.196E-01 2.208E-01 2.211E-01 2.207E-01 2.195E-01 2.175E-01 2.148E-01 2.112E-01 2.070E-01 2.020E-01 1.963E-01 1.901E-01 1.832E-01 1.758E-01 1.679E-01 1.597E-01 1.510E-01 1.421E-01 1.330E-01 1.237E-01 1.144E-01 1.051E-01 9.583E-02 8.673E-02 7.784E-02 6.922E-02 6.095E-02 5.307E-02 4.563E-02 3.868E-02 3.227E-02 2.641E-02 2.114E-02 1.646E-02 1.240E-02 8.941E-03 6.085E-03 3.813E-03 2.103E-03 9.237E-04 2.374E-04 9.434E-07 1.654E-04 6.775E-04 1.481E-03 2.515E-03 3.721E-03 5.037E-03 6.405E-03 7.765E-03 9.066E-03 1.026E-02 1.129E-02 1.214E-02 1.277E-02 1.315E-02 1.328E-02 1.315E-02 1.277E-02 1.214E-02 1.129E-02 1.026E-02 9.066E-03 7.765E-03 6.405E-03 5.037E-03 3.721E-03 2.515E-03 1.481E-03 6.775E-04 1.654E-04 9.434E-07 2.374E-04 9.237E-04 2.103E-03 3.813E-03 6.085E-03 8.941E-03 1.240E-02 1.646E-02 2.114E-02 2.641E-02 3.227E-02 3.868E-02 4.563E-02 5.307E-02 6.095E-02 6.922E-02 7.784E-02 8.673E-02 9.583E-02 1.051E-01 1.144E-01 1.237E-01 1.330E-01 1.421E-01 1.510E-01 1.597E-01 1.679E-01 1.758E-01 1.832E-01 1.901E-01 1.963E-01 2.020E-01 2.070E-01 2.112E-01 2.148E-01 2.175E-01 2.195E-01 2.207E-01 2.211E-01 2.208E-01 2.196E-01 2.177E-01 2.150E-01 2.116E-01 2.076E-01 2.029E-01 1.975E-01 1.916E-01 1.852E-01 1.783E-01 1.710E-01 1.634E-01 1.554E-01 1.472E-01 1.389E-01 1.304E-01 1.218E-01 1.132E-01 1.046E-01 9.618E-02 8.787E-02 7.976E-02 7.188E-02 6.429E-02 5.701E-02 5.009E-02 4.355E-02 3.743E-02 3.173E-02 2.650E-02 2.172E-02 1.743E-02 1.362E-02 1.029E-02 7.448E-03 5.084E-03 3.188E-03 1.749E-03 7.505E-04 1.748E-04 4.667E-07 2.042E-04 7.605E-04 1.642E-03 2.820E-03 4.265E-03 5.946E-03 7.832E-03 9.890E-03 1.209E-02 1.440E-02 1.679E-02 1.922E-02 2.168E-02 2.413E-02 2.654E-02 2.889E-02 3.115E-02 3.332E-02 3.535E-02 3.724E-02 3.898E-02 4.054E-02 4.192E-02 4.310E-02 4.409E-02 4.487E-02 4.544E-02 4.581E-02 4.596E-02 4.592E-02 4.567E-02 4.535E-02 4.575E-02 4.595E-02 4.595E-02 4.574E-02 4.532E-02 4.470E-02 4.386E-02 4.283E-02 4.159E-02 4.016E-02 3.856E-02 3.678E-02 3.484E-02 3.277E-02 3.057E-02 2.828E-02 2.590E-02 2.347E-02 2.101E-02 1.855E-02 1.612E-02 1.375E-02 1.146E-02 9.290E-03 7.272E-03 5.437E-03 3.817E-03 2.443E-03 1.347E-03 5.573E-04 1.036E-04 1.271E-05 3.098E-04 1.018E-03 2.157E-03 3.746E-03 5.800E-03 8.329E-03 1.134E-02 1.484E-02 1.883E-02 2.331E-02 2.826E-02 3.369E-02 3.956E-02 4.586E-02 5.257E-02 5.966E-02 6.709E-02 7.484E-02 8.285E-02 9.108E-02 9.950E-02 1.080E-01 1.167E-01 1.253E-01 1.339E-01 1.424E-01 1.508E-01 1.589E-01 1.668E-01 1.744E-01 1.815E-01 1.882E-01 1.945E-01 2.001E-01 2.052E-01 2.097E-01 2.134E-01 2.165E-01 2.188E-01 2.203E-01 2.211E-01 2.210E-01 2.202E-01 2.185E-01 2.160E-01 2.128E-01 2.087E-01 2.040E-01 1.985E-01 1.924E-01 1.856E-01 1.783E-01 1.704E-01 1.621E-01 1.534E-01 1.444E-01 1.352E-01 1.257E-01 1.162E-01 1.067E-01 9.718E-02 8.782E-02 7.866E-02 6.977E-02 6.122E-02 5.307E-02 4.537E-02 3.819E-02 3.156E-02 2.552E-02 2.011E-02 1.534E-02 1.122E-02 7.773E-03 4.980E-03 2.832E-03 1.310E-03 3.816E-04 1.105E-05 1.532E-04 7.568E-04 1.765E-03 3.115E-03 4.742E-03 6.577E-03 8.552E-03 1.060E-02 1.264E-02 1.462E-02 1.648E-02 1.815E-02 1.959E-02 2.076E-02 2.162E-02 2.214E-02 2.232E-02 2.214E-02 2.162E-02 2.076E-02 1.959E-02 1.815E-02 1.648E-02 1.462E-02 1.264E-02 1.060E-02 8.552E-03 6.577E-03 4.742E-03 3.115E-03 1.765E-03 7.568E-04 1.532E-04 1.105E-05 3.816E-04 1.310E-03 2.832E-03 4.980E-03 7.773E-03 1.122E-02 1.534E-02 2.011E-02 2.552E-02 3.156E-02 3.819E-02 4.537E-02 5.307E-02 6.122E-02 6.977E-02 7.866E-02 8.782E-02 9.718E-02 1.067E-01 1.162E-01 1.257E-01 1.352E-01 1.444E-01 1.534E-01 1.621E-01 1.704E-01 1.783E-01 1.856E-01 1.924E-01 1.985E-01 2.040E-01 2.087E-01 2.128E-01 2.160E-01 2.185E-01 2.202E-01 2.210E-01 2.211E-01 2.203E-01 2.188E-01 2.165E-01 2.134E-01 2.097E-01 2.052E-01 2.001E-01 1.945E-01 1.882E-01 1.815E-01 1.744E-01 1.668E-01 1.589E-01 1.508E-01 1.424E-01 1.339E-01 1.253E-01 1.167E-01 1.080E-01 9.950E-02 9.108E-02 8.285E-02 7.484E-02 6.709E-02 5.966E-02 5.257E-02 4.586E-02 3.956E-02 3.369E-02 2.826E-02 2.331E-02 1.883E-02 1.484E-02 1.134E-02 8.329E-03 5.800E-03 3.746E-03 2.157E-03 1.018E-03 3.098E-04 1.271E-05 1.036E-04 5.573E-04 1.347E-03 2.443E-03 3.817E-03 5.437E-03 7.272E-03 9.290E-03 1.146E-02 1.375E-02 1.612E-02 1.855E-02 2.101E-02 2.347E-02 2.590E-02 2.828E-02 3.057E-02 3.277E-02 3.484E-02 3.678E-02 3.856E-02 4.016E-02 4.159E-02 4.283E-02 4.386E-02 4.470E-02 4.532E-02 4.574E-02 4.595E-02 4.595E-02 4.575E-02 4.546E-02 4.581E-02 4.596E-02 4.592E-02 4.566E-02 4.520E-02 4.452E-02 4.364E-02 4.255E-02 4.127E-02 3.979E-02 3.814E-02 3.631E-02 3.434E-02 3.223E-02 3.000E-02 2.768E-02 2.528E-02 2.284E-02 2.037E-02 1.791E-02 1.548E-02 1.312E-02 1.086E-02 8.719E-03 6.744E-03 4.961E-03 3.402E-03 2.101E-03 1.086E-03 3.892E-04 3.801E-05 5.944E-05 4.784E-04 1.317E-03 2.597E-03 4.333E-03 6.541E-03 9.232E-03 1.241E-02 1.608E-02 2.025E-02 2.490E-02 3.003E-02 3.563E-02 4.168E-02 4.815E-02 5.503E-02 6.228E-02 6.986E-02 7.774E-02 8.588E-02 9.423E-02 1.027E-01 1.114E-01 1.200E-01 1.287E-01 1.374E-01 1.459E-01 1.542E-01 1.623E-01 1.701E-01 1.775E-01 1.845E-01 1.911E-01 1.971E-01 2.026E-01 2.074E-01 2.116E-01 2.150E-01 2.177E-01 2.197E-01 2.208E-01 2.211E-01 2.207E-01 2.194E-01 2.172E-01 2.143E-01 2.105E-01 2.060E-01 2.008E-01 1.948E-01 1.882E-01 1.810E-01 1.732E-01 1.649E-01 1.562E-01 1.471E-01 1.378E-01 1.282E-01 1.185E-01 1.088E-01 9.907E-02 8.946E-02 8.003E-02 7.086E-02 6.203E-02 5.359E-02 4.563E-02 3.819E-02 3.133E-02 2.508E-02 1.950E-02 1.460E-02 1.041E-02 6.941E-03 4.187E-03 2.143E-03 7.923E-04 1.066E-04 5.039E-05 5.789E-04 1.640E-03 3.173E-03 5.113E-03 7.388E-03 9.923E-03 1.264E-02 1.546E-02 1.831E-02 2.110E-02 2.376E-02 2.623E-02 2.843E-02 3.031E-02 3.183E-02 3.294E-02 3.362E-02 3.385E-02 3.362E-02 3.294E-02 3.183E-02 3.031E-02 2.843E-02 2.623E-02 2.376E-02 2.110E-02 1.831E-02 1.546E-02 1.264E-02 9.923E-03 7.388E-03 5.113E-03 3.173E-03 1.640E-03 5.789E-04 5.039E-05 1.066E-04 7.923E-04 2.143E-03 4.187E-03 6.941E-03 1.041E-02 1.460E-02 1.950E-02 2.508E-02 3.133E-02 3.819E-02 4.563E-02 5.359E-02 6.203E-02 7.086E-02 8.003E-02 8.946E-02 9.907E-02 1.088E-01 1.185E-01 1.282E-01 1.378E-01 1.471E-01 1.562E-01 1.649E-01 1.732E-01 1.810E-01 1.882E-01 1.948E-01 2.008E-01 2.060E-01 2.105E-01 2.143E-01 2.172E-01 2.194E-01 2.207E-01 2.211E-01 2.208E-01 2.197E-01 2.177E-01 2.150E-01 2.116E-01 2.074E-01 2.026E-01 1.971E-01 1.911E-01 1.845E-01 1.775E-01 1.701E-01 1.623E-01 1.542E-01 1.459E-01 1.374E-01 1.287E-01 1.200E-01 1.114E-01 1.027E-01 9.423E-02 8.588E-02 7.774E-02 6.986E-02 6.228E-02 5.503E-02 4.815E-02 4.168E-02 3.563E-02 3.003E-02 2.490E-02 2.025E-02 1.608E-02 1.241E-02 9.232E-03 6.541E-03 4.333E-03 2.597E-03 1.317E-03 4.784E-04 5.944E-05 3.801E-05 3.892E-04 1.086E-03 2.101E-03 3.402E-03 4.961E-03 6.744E-03 8.719E-03 1.086E-02 1.312E-02 1.548E-02 1.791E-02 2.037E-02 2.284E-02 2.528E-02 2.768E-02 3.000E-02 3.223E-02 3.434E-02 3.631E-02 3.814E-02 3.979E-02 4.127E-02 4.255E-02 4.364E-02 4.452E-02 4.520E-02 4.566E-02 4.592E-02 4.596E-02 4.581E-02 4.555E-02 4.586E-02 4.597E-02 4.588E-02 4.558E-02 4.506E-02 4.434E-02 4.341E-02 4.227E-02 4.094E-02 3.942E-02 3.772E-02 3.586E-02 3.385E-02 3.170E-02 2.944E-02 2.709E-02 2.468E-02 2.222E-02 1.974E-02 1.728E-02 1.487E-02 1.252E-02 1.028E-02 8.179E-03 6.247E-03 4.516E-03 3.021E-03 1.791E-03 8.593E-04 2.544E-04 5.093E-06 1.379E-04 6.775E-04 1.646E-03 3.063E-03 4.944E-03 7.304E-03 1.015E-02 1.350E-02 1.734E-02 2.167E-02 2.650E-02 3.180E-02 3.757E-02 4.378E-02 5.042E-02 5.745E-02 6.485E-02 7.258E-02 8.059E-02 8.885E-02 9.730E-02 1.059E-01 1.146E-01 1.233E-01 1.320E-01 1.407E-01 1.492E-01 1.575E-01 1.655E-01 1.732E-01 1.805E-01 1.874E-01 1.938E-01 1.996E-01 2.048E-01 2.094E-01 2.132E-01 2.164E-01 2.187E-01 2.203E-01 2.211E-01 2.210E-01 2.201E-01 2.183E-01 2.158E-01 2.124E-01 2.081E-01 2.032E-01 1.974E-01 1.910E-01 1.839E-01 1.763E-01 1.680E-01 1.594E-01 1.503E-01 1.408E-01 1.312E-01 1.213E-01 1.114E-01 1.015E-01 9.163E-02 8.194E-02 7.250E-02 6.338E-02 5.466E-02 4.640E-02 3.868E-02 3.156E-02 2.508E-02 1.930E-02 1.424E-02 9.939E-03 6.409E-03 3.658E-03 1.685E-03 4.758E-04 8.147E-06 2.485E-04 1.154E-03 2.672E-03 4.742E-03 7.295E-03 1.026E-02 1.354E-02 1.707E-02 2.076E-02 2.450E-02 2.822E-02 3.183E-02 3.524E-02 3.837E-02 4.115E-02 4.352E-02 4.542E-02 4.681E-02 4.766E-02 4.794E-02 4.766E-02 4.681E-02 4.542E-02 4.352E-02 4.115E-02 3.837E-02 3.524E-02 3.183E-02 2.822E-02 2.450E-02 2.076E-02 1.707E-02 1.354E-02 1.026E-02 7.295E-03 4.742E-03 2.672E-03 1.154E-03 2.485E-04 8.147E-06 4.758E-04 1.685E-03 3.658E-03 6.409E-03 9.939E-03 1.424E-02 1.930E-02 2.508E-02 3.156E-02 3.868E-02 4.640E-02 5.466E-02 6.338E-02 7.250E-02 8.194E-02 9.163E-02 1.015E-01 1.114E-01 1.213E-01 1.312E-01 1.408E-01 1.503E-01 1.594E-01 1.680E-01 1.763E-01 1.839E-01 1.910E-01 1.974E-01 2.032E-01 2.081E-01 2.124E-01 2.158E-01 2.183E-01 2.201E-01 2.210E-01 2.211E-01 2.203E-01 2.187E-01 2.164E-01 2.132E-01 2.094E-01 2.048E-01 1.996E-01 1.938E-01 1.874E-01 1.805E-01 1.732E-01 1.655E-01 1.575E-01 1.492E-01 1.407E-01 1.320E-01 1.233E-01 1.146E-01 1.059E-01 9.730E-02 8.885E-02 8.059E-02 7.258E-02 6.485E-02 5.745E-02 5.042E-02 4.378E-02 3.757E-02 3.180E-02 2.650E-02 2.167E-02 1.734E-02 1.350E-02 1.015E-02 7.304E-03 4.944E-03 3.063E-03 1.646E-03 6.775E-04 1.379E-04 5.093E-06 2.544E-04 8.593E-04 1.791E-03 3.021E-03 4.516E-03 6.247E-03 8.179E-03 1.028E-02 1.252E-02 1.487E-02 1.728E-02 1.974E-02 2.222E-02 2.468E-02 2.709E-02 2.944E-02 3.170E-02 3.385E-02 3.586E-02 3.772E-02 3.942E-02 4.094E-02 4.227E-02 4.341E-02 4.434E-02 4.506E-02 4.558E-02 4.588E-02 4.597E-02 4.586E-02 4.563E-02 4.590E-02 4.597E-02 4.583E-02 4.548E-02 4.492E-02 4.416E-02 4.318E-02 4.200E-02 4.062E-02 3.905E-02 3.731E-02 3.541E-02 3.336E-02 3.118E-02 2.890E-02 2.653E-02 2.409E-02 2.162E-02 1.914E-02 1.668E-02 1.428E-02 1.195E-02 9.736E-03 7.669E-03 5.780E-03 4.103E-03 2.671E-03 1.514E-03 6.639E-04 1.507E-04 2.384E-06 2.454E-04 9.039E-04 2.000E-03 3.552E-03 5.576E-03 8.084E-03 1.109E-02 1.459E-02 1.859E-02 2.309E-02 2.808E-02 3.355E-02 3.949E-02 4.586E-02 5.266E-02 5.984E-02 6.738E-02 7.524E-02 8.338E-02 9.174E-02 1.003E-01 1.090E-01 1.177E-01 1.265E-01 1.352E-01 1.439E-01 1.523E-01 1.606E-01 1.685E-01 1.761E-01 1.833E-01 1.901E-01 1.962E-01 2.019E-01 2.068E-01 2.111E-01 2.147E-01 2.175E-01 2.196E-01 2.208E-01 2.211E-01 2.207E-01 2.193E-01 2.171E-01 2.141E-01 2.103E-01 2.056E-01 2.001E-01 1.940E-01 1.871E-01 1.796E-01 1.714E-01 1.628E-01 1.538E-01 1.443E-01 1.346E-01 1.246E-01 1.145E-01 1.044E-01 9.435E-02 8.441E-02 7.469E-02 6.528E-02 5.625E-02 4.770E-02 3.968E-02 3.227E-02 2.552E-02 1.950E-02 1.424E-02 9.783E-03 6.149E-03 3.356E-03 1.408E-03 2.974E-04 7.911E-06 5.102E-04 1.765E-03 3.721E-03 6.319E-03 9.489E-03 1.315E-02 1.723E-02 2.162E-02 2.623E-02 3.096E-02 3.571E-02 4.038E-02 4.487E-02 4.909E-02 5.295E-02 5.636E-02 5.926E-02 6.158E-02 6.327E-02 6.430E-02 6.465E-02 6.430E-02 6.327E-02 6.158E-02 5.926E-02 5.636E-02 5.295E-02 4.909E-02 4.487E-02 4.038E-02 3.571E-02 3.096E-02 2.623E-02 2.162E-02 1.723E-02 1.315E-02 9.489E-03 6.319E-03 3.721E-03 1.765E-03 5.102E-04 7.911E-06 2.974E-04 1.408E-03 3.356E-03 6.149E-03 9.783E-03 1.424E-02 1.950E-02 2.552E-02 3.227E-02 3.968E-02 4.770E-02 5.625E-02 6.528E-02 7.469E-02 8.441E-02 9.435E-02 1.044E-01 1.145E-01 1.246E-01 1.346E-01 1.443E-01 1.538E-01 1.628E-01 1.714E-01 1.796E-01 1.871E-01 1.940E-01 2.001E-01 2.056E-01 2.103E-01 2.141E-01 2.171E-01 2.193E-01 2.207E-01 2.211E-01 2.208E-01 2.196E-01 2.175E-01 2.147E-01 2.111E-01 2.068E-01 2.019E-01 1.962E-01 1.901E-01 1.833E-01 1.761E-01 1.685E-01 1.606E-01 1.523E-01 1.439E-01 1.352E-01 1.265E-01 1.177E-01 1.090E-01 1.003E-01 9.174E-02 8.338E-02 7.524E-02 6.738E-02 5.984E-02 5.266E-02 4.586E-02 3.949E-02 3.355E-02 2.808E-02 2.309E-02 1.859E-02 1.459E-02 1.109E-02 8.084E-03 5.576E-03 3.552E-03 2.000E-03 9.039E-04 2.454E-04 2.384E-06 1.507E-04 6.639E-04 1.514E-03 2.671E-03 4.103E-03 5.780E-03 7.669E-03 9.736E-03 1.195E-02 1.428E-02 1.668E-02 1.914E-02 2.162E-02 2.409E-02 2.653E-02 2.890E-02 3.118E-02 3.336E-02 3.541E-02 3.731E-02 3.905E-02 4.062E-02 4.200E-02 4.318E-02 4.416E-02 4.492E-02 4.548E-02 4.583E-02 4.597E-02 4.590E-02 4.570E-02 4.593E-02 4.596E-02 4.578E-02 4.539E-02 4.478E-02 4.397E-02 4.295E-02 4.172E-02 4.030E-02 3.869E-02 3.691E-02 3.497E-02 3.289E-02 3.068E-02 2.837E-02 2.598E-02 2.353E-02 2.105E-02 1.856E-02 1.611E-02 1.371E-02 1.140E-02 9.219E-03 7.188E-03 5.344E-03 3.721E-03 2.351E-03 1.266E-03 4.981E-04 7.576E-05 2.738E-05 3.791E-04 1.155E-03 2.375E-03 4.060E-03 6.223E-03 8.877E-03 1.203E-02 1.569E-02 1.985E-02 2.451E-02 2.966E-02 3.529E-02 4.138E-02 4.791E-02 5.486E-02 6.218E-02 6.986E-02 7.784E-02 8.609E-02 9.456E-02 1.032E-01 1.120E-01 1.208E-01 1.296E-01 1.383E-01 1.469E-01 1.554E-01 1.636E-01 1.714E-01 1.789E-01 1.860E-01 1.926E-01 1.986E-01 2.040E-01 2.087E-01 2.127E-01 2.160E-01 2.185E-01 2.202E-01 2.210E-01 2.210E-01 2.202E-01 2.184E-01 2.158E-01 2.123E-01 2.080E-01 2.029E-01 1.970E-01 1.904E-01 1.830E-01 1.751E-01 1.666E-01 1.576E-01 1.482E-01 1.384E-01 1.284E-01 1.182E-01 1.079E-01 9.759E-02 8.741E-02 7.743E-02 6.772E-02 5.839E-02 4.952E-02 4.118E-02 3.345E-02 2.641E-02 2.011E-02 1.460E-02 9.939E-03 6.149E-03 3.258E-03 1.278E-03 2.099E-04 4.383E-05 7.568E-04 2.314E-03 4.670E-03 7.765E-03 1.153E-02 1.589E-02 2.076E-02 2.603E-02 3.161E-02 3.739E-02 4.325E-02 4.909E-02 5.479E-02 6.024E-02 6.534E-02 6.998E-02 7.408E-02 7.754E-02 8.031E-02 8.233E-02 8.356E-02 8.397E-02 8.356E-02 8.233E-02 8.031E-02 7.754E-02 7.408E-02 6.998E-02 6.534E-02 6.024E-02 5.479E-02 4.909E-02 4.325E-02 3.739E-02 3.161E-02 2.603E-02 2.076E-02 1.589E-02 1.153E-02 7.765E-03 4.670E-03 2.314E-03 7.568E-04 4.383E-05 2.099E-04 1.278E-03 3.258E-03 6.149E-03 9.939E-03 1.460E-02 2.011E-02 2.641E-02 3.345E-02 4.118E-02 4.952E-02 5.839E-02 6.772E-02 7.743E-02 8.741E-02 9.759E-02 1.079E-01 1.182E-01 1.284E-01 1.384E-01 1.482E-01 1.576E-01 1.666E-01 1.751E-01 1.830E-01 1.904E-01 1.970E-01 2.029E-01 2.080E-01 2.123E-01 2.158E-01 2.184E-01 2.202E-01 2.210E-01 2.210E-01 2.202E-01 2.185E-01 2.160E-01 2.127E-01 2.087E-01 2.040E-01 1.986E-01 1.926E-01 1.860E-01 1.789E-01 1.714E-01 1.636E-01 1.554E-01 1.469E-01 1.383E-01 1.296E-01 1.208E-01 1.120E-01 1.032E-01 9.456E-02 8.609E-02 7.784E-02 6.986E-02 6.218E-02 5.486E-02 4.791E-02 4.138E-02 3.529E-02 2.966E-02 2.451E-02 1.985E-02 1.569E-02 1.203E-02 8.877E-03 6.223E-03 4.060E-03 2.375E-03 1.155E-03 3.791E-04 2.738E-05 7.576E-05 4.981E-04 1.266E-03 2.351E-03 3.721E-03 5.344E-03 7.188E-03 9.219E-03 1.140E-02 1.371E-02 1.611E-02 1.856E-02 2.105E-02 2.353E-02 2.598E-02 2.837E-02 3.068E-02 3.289E-02 3.497E-02 3.691E-02 3.869E-02 4.030E-02 4.172E-02 4.295E-02 4.397E-02 4.478E-02 4.539E-02 4.578E-02 4.596E-02 4.593E-02 4.576E-02 4.595E-02 4.594E-02 4.572E-02 4.528E-02 4.464E-02 4.378E-02 4.271E-02 4.145E-02 3.998E-02 3.834E-02 3.652E-02 3.454E-02 3.243E-02 3.019E-02 2.786E-02 2.544E-02 2.298E-02 2.049E-02 1.801E-02 1.556E-02 1.317E-02 1.089E-02 8.729E-03 6.735E-03 4.936E-03 3.367E-03 2.060E-03 1.047E-03 3.601E-04 2.751E-05 7.755E-05 5.360E-04 1.426E-03 2.770E-03 4.583E-03 6.882E-03 9.678E-03 1.298E-02 1.678E-02 2.110E-02 2.591E-02 3.122E-02 3.700E-02 4.324E-02 4.992E-02 5.701E-02 6.447E-02 7.228E-02 8.038E-02 8.874E-02 9.730E-02 1.060E-01 1.148E-01 1.237E-01 1.325E-01 1.413E-01 1.499E-01 1.583E-01 1.664E-01 1.742E-01 1.816E-01 1.885E-01 1.949E-01 2.007E-01 2.059E-01 2.104E-01 2.141E-01 2.171E-01 2.193E-01 2.207E-01 2.211E-01 2.208E-01 2.195E-01 2.173E-01 2.143E-01 2.104E-01 2.056E-01 2.001E-01 1.937E-01 1.867E-01 1.790E-01 1.706E-01 1.617E-01 1.523E-01 1.426E-01 1.325E-01 1.222E-01 1.118E-01 1.013E-01 9.095E-02 8.071E-02 7.072E-02 6.108E-02 5.188E-02 4.320E-02 3.513E-02 2.776E-02 2.114E-02 1.534E-02 1.041E-02 6.409E-03 3.356E-03 1.278E-03 1.840E-04 7.283E-05 9.292E-04 2.725E-03 5.421E-03 8.962E-03 1.328E-02 1.831E-02 2.395E-02 3.010E-02 3.666E-02 4.352E-02 5.055E-02 5.764E-02 6.465E-02 7.145E-02 7.793E-02 8.397E-02 8.946E-02 9.429E-02 9.837E-02 1.016E-01 1.040E-01 1.054E-01 1.059E-01 1.054E-01 1.040E-01 1.016E-01 9.837E-02 9.429E-02 8.946E-02 8.397E-02 7.793E-02 7.145E-02 6.465E-02 5.764E-02 5.055E-02 4.352E-02 3.666E-02 3.010E-02 2.395E-02 1.831E-02 1.328E-02 8.962E-03 5.421E-03 2.725E-03 9.292E-04 7.283E-05 1.840E-04 1.278E-03 3.356E-03 6.409E-03 1.041E-02 1.534E-02 2.114E-02 2.776E-02 3.513E-02 4.320E-02 5.188E-02 6.108E-02 7.072E-02 8.071E-02 9.095E-02 1.013E-01 1.118E-01 1.222E-01 1.325E-01 1.426E-01 1.523E-01 1.617E-01 1.706E-01 1.790E-01 1.867E-01 1.937E-01 2.001E-01 2.056E-01 2.104E-01 2.143E-01 2.173E-01 2.195E-01 2.208E-01 2.211E-01 2.207E-01 2.193E-01 2.171E-01 2.141E-01 2.104E-01 2.059E-01 2.007E-01 1.949E-01 1.885E-01 1.816E-01 1.742E-01 1.664E-01 1.583E-01 1.499E-01 1.413E-01 1.325E-01 1.237E-01 1.148E-01 1.060E-01 9.730E-02 8.874E-02 8.038E-02 7.228E-02 6.447E-02 5.701E-02 4.992E-02 4.324E-02 3.700E-02 3.122E-02 2.591E-02 2.110E-02 1.678E-02 1.298E-02 9.678E-03 6.882E-03 4.583E-03 2.770E-03 1.426E-03 5.360E-04 7.755E-05 2.751E-05 3.601E-04 1.047E-03 2.060E-03 3.367E-03 4.936E-03 6.735E-03 8.729E-03 1.089E-02 1.317E-02 1.556E-02 1.801E-02 2.049E-02 2.298E-02 2.544E-02 2.786E-02 3.019E-02 3.243E-02 3.454E-02 3.652E-02 3.834E-02 3.998E-02 4.145E-02 4.271E-02 4.378E-02 4.464E-02 4.528E-02 4.572E-02 4.594E-02 4.595E-02 4.581E-02 4.597E-02 4.591E-02 4.565E-02 4.518E-02 4.449E-02 4.359E-02 4.248E-02 4.117E-02 3.967E-02 3.799E-02 3.613E-02 3.413E-02 3.198E-02 2.972E-02 2.736E-02 2.493E-02 2.245E-02 1.996E-02 1.748E-02 1.503E-02 1.266E-02 1.040E-02 8.267E-03 6.309E-03 4.556E-03 3.041E-03 1.797E-03 8.554E-04 2.478E-04 3.609E-06 1.503E-04 7.135E-04 1.716E-03 3.179E-03 5.119E-03 7.550E-03 1.048E-02 1.392E-02 1.787E-02 2.233E-02 2.730E-02 3.275E-02 3.868E-02 4.507E-02 5.189E-02 5.912E-02 6.671E-02 7.463E-02 8.285E-02 9.130E-02 9.995E-02 1.087E-01 1.176E-01 1.265E-01 1.354E-01 1.441E-01 1.527E-01 1.611E-01 1.691E-01 1.768E-01 1.841E-01 1.908E-01 1.971E-01 2.027E-01 2.077E-01 2.119E-01 2.154E-01 2.181E-01 2.200E-01 2.210E-01 2.211E-01 2.203E-01 2.187E-01 2.161E-01 2.126E-01 2.083E-01 2.032E-01 1.972E-01 1.904E-01 1.830E-01 1.748E-01 1.661E-01 1.568E-01 1.471E-01 1.371E-01 1.267E-01 1.162E-01 1.056E-01 9.502E-02 8.454E-02 7.428E-02 6.433E-02 5.479E-02 4.576E-02 3.733E-02 2.958E-02 2.260E-02 1.646E-02 1.122E-02 6.941E-03 3.658E-03 1.408E-03 2.099E-04 7.283E-05 9.907E-04 2.944E-03 5.901E-03 9.814E-03 1.462E-02 2.025E-02 2.662E-02 3.362E-02 4.115E-02 4.909E-02 5.732E-02 6.569E-02 7.408E-02 8.233E-02 9.032E-02 9.791E-02 1.050E-01 1.114E-01 1.170E-01 1.217E-01 1.255E-01 1.283E-01 1.299E-01 1.305E-01 1.299E-01 1.283E-01 1.255E-01 1.217E-01 1.170E-01 1.114E-01 1.050E-01 9.791E-02 9.032E-02 8.233E-02 7.408E-02 6.569E-02 5.732E-02 4.909E-02 4.115E-02 3.362E-02 2.662E-02 2.025E-02 1.462E-02 9.814E-03 5.901E-03 2.944E-03 9.907E-04 7.283E-05 2.099E-04 1.408E-03 3.658E-03 6.941E-03 1.122E-02 1.646E-02 2.260E-02 2.958E-02 3.733E-02 4.576E-02 5.479E-02 6.433E-02 7.428E-02 8.454E-02 9.502E-02 1.056E-01 1.162E-01 1.267E-01 1.371E-01 1.471E-01 1.568E-01 1.661E-01 1.748E-01 1.830E-01 1.904E-01 1.972E-01 2.032E-01 2.083E-01 2.126E-01 2.161E-01 2.187E-01 2.203E-01 2.211E-01 2.210E-01 2.200E-01 2.181E-01 2.154E-01 2.119E-01 2.077E-01 2.027E-01 1.971E-01 1.908E-01 1.841E-01 1.768E-01 1.691E-01 1.611E-01 1.527E-01 1.441E-01 1.354E-01 1.265E-01 1.176E-01 1.087E-01 9.995E-02 9.130E-02 8.285E-02 7.463E-02 6.671E-02 5.912E-02 5.189E-02 4.507E-02 3.868E-02 3.275E-02 2.730E-02 2.233E-02 1.787E-02 1.392E-02 1.048E-02 7.550E-03 5.119E-03 3.179E-03 1.716E-03 7.135E-04 1.503E-04 3.609E-06 2.478E-04 8.554E-04 1.797E-03 3.041E-03 4.556E-03 6.309E-03 8.267E-03 1.040E-02 1.266E-02 1.503E-02 1.748E-02 1.996E-02 2.245E-02 2.493E-02 2.736E-02 2.972E-02 3.198E-02 3.413E-02 3.613E-02 3.799E-02 3.967E-02 4.117E-02 4.248E-02 4.359E-02 4.449E-02 4.518E-02 4.565E-02 4.591E-02 4.597E-02 4.585E-02 4.597E-02 4.588E-02 4.558E-02 4.507E-02 4.434E-02 4.340E-02 4.225E-02 4.091E-02 3.937E-02 3.765E-02 3.576E-02 3.372E-02 3.155E-02 2.926E-02 2.688E-02 2.443E-02 2.195E-02 1.945E-02 1.697E-02 1.453E-02 1.218E-02 9.931E-03 7.832E-03 5.911E-03 4.203E-03 2.742E-03 1.559E-03 6.883E-04 1.593E-04 1.764E-06 2.431E-04 9.085E-04 2.021E-03 3.600E-03 5.662E-03 8.221E-03 1.129E-02 1.486E-02 1.896E-02 2.356E-02 2.866E-02 3.426E-02 4.033E-02 4.686E-02 5.382E-02 6.117E-02 6.888E-02 7.692E-02 8.524E-02 9.379E-02 1.025E-01 1.114E-01 1.203E-01 1.292E-01 1.381E-01 1.468E-01 1.554E-01 1.637E-01 1.717E-01 1.793E-01 1.864E-01 1.930E-01 1.991E-01 2.045E-01 2.093E-01 2.133E-01 2.165E-01 2.189E-01 2.204E-01 2.211E-01 2.209E-01 2.198E-01 2.177E-01 2.148E-01 2.109E-01 2.062E-01 2.006E-01 1.942E-01 1.871E-01 1.792E-01 1.707E-01 1.616E-01 1.520E-01 1.420E-01 1.317E-01 1.211E-01 1.104E-01 9.961E-02 8.891E-02 7.838E-02 6.813E-02 5.826E-02 4.886E-02 4.005E-02 3.191E-02 2.454E-02 1.801E-02 1.240E-02 7.773E-03 4.187E-03 1.685E-03 2.974E-04 4.383E-05 9.292E-04 2.944E-03 6.066E-03 1.026E-02 1.546E-02 2.162E-02 2.863E-02 3.642E-02 4.487E-02 5.387E-02 6.327E-02 7.294E-02 8.274E-02 9.251E-02 1.021E-01 1.114E-01 1.201E-01 1.283E-01 1.356E-01 1.421E-01 1.475E-01 1.519E-01 1.550E-01 1.570E-01 1.576E-01 1.570E-01 1.550E-01 1.519E-01 1.475E-01 1.421E-01 1.356E-01 1.283E-01 1.201E-01 1.114E-01 1.021E-01 9.251E-02 8.274E-02 7.294E-02 6.327E-02 5.387E-02 4.487E-02 3.642E-02 2.863E-02 2.162E-02 1.546E-02 1.026E-02 6.066E-03 2.944E-03 9.292E-04 4.383E-05 2.974E-04 1.685E-03 4.187E-03 7.773E-03 1.240E-02 1.801E-02 2.454E-02 3.191E-02 4.005E-02 4.886E-02 5.826E-02 6.813E-02 7.838E-02 8.891E-02 9.961E-02 1.104E-01 1.211E-01 1.317E-01 1.420E-01 1.520E-01 1.616E-01 1.707E-01 1.792E-01 1.871E-01 1.942E-01 2.006E-01 2.062E-01 2.109E-01 2.148E-01 2.177E-01 2.198E-01 2.209E-01 2.211E-01 2.204E-01 2.189E-01 2.165E-01 2.133E-01 2.093E-01 2.045E-01 1.991E-01 1.930E-01 1.864E-01 1.793E-01 1.717E-01 1.637E-01 1.554E-01 1.468E-01 1.381E-01 1.292E-01 1.203E-01 1.114E-01 1.025E-01 9.379E-02 8.524E-02 7.692E-02 6.888E-02 6.117E-02 5.382E-02 4.686E-02 4.033E-02 3.426E-02 2.866E-02 2.356E-02 1.896E-02 1.486E-02 1.129E-02 8.221E-03 5.662E-03 3.600E-03 2.021E-03 9.085E-04 2.431E-04 1.764E-06 1.593E-04 6.883E-04 1.559E-03 2.742E-03 4.203E-03 5.911E-03 7.832E-03 9.931E-03 1.218E-02 1.453E-02 1.697E-02 1.945E-02 2.195E-02 2.443E-02 2.688E-02 2.926E-02 3.155E-02 3.372E-02 3.576E-02 3.765E-02 3.937E-02 4.091E-02 4.225E-02 4.340E-02 4.434E-02 4.507E-02 4.558E-02 4.588E-02 4.597E-02 4.589E-02 4.597E-02 4.585E-02 4.551E-02 4.496E-02 4.419E-02 4.321E-02 4.203E-02 4.064E-02 3.907E-02 3.731E-02 3.539E-02 3.333E-02 3.113E-02 2.882E-02 2.642E-02 2.396E-02 2.146E-02 1.896E-02 1.648E-02 1.405E-02 1.171E-02 9.492E-03 7.422E-03 5.539E-03 3.877E-03 2.468E-03 1.347E-03 5.445E-04 9.249E-05 1.967E-05 3.533E-04 1.118E-03 2.337E-03 4.029E-03 6.210E-03 8.893E-03 1.209E-02 1.580E-02 2.002E-02 2.476E-02 3.000E-02 3.574E-02 4.194E-02 4.860E-02 5.569E-02 6.316E-02 7.099E-02 7.913E-02 8.755E-02 9.618E-02 1.050E-01 1.139E-01 1.228E-01 1.318E-01 1.407E-01 1.494E-01 1.579E-01 1.662E-01 1.741E-01 1.816E-01 1.886E-01 1.951E-01 2.010E-01 2.062E-01 2.107E-01 2.145E-01 2.174E-01 2.195E-01 2.208E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.133E-01 2.091E-01 2.040E-01 1.980E-01 1.912E-01 1.837E-01 1.755E-01 1.666E-01 1.572E-01 1.473E-01 1.370E-01 1.264E-01 1.156E-01 1.047E-01 9.380E-02 8.304E-02 7.250E-02 6.230E-02 5.254E-02 4.333E-02 3.477E-02 2.697E-02 2.001E-02 1.397E-02 8.941E-03 4.980E-03 2.143E-03 4.758E-04 7.911E-06 7.568E-04 2.725E-03 5.901E-03 1.026E-02 1.575E-02 2.232E-02 2.989E-02 3.837E-02 4.766E-02 5.764E-02 6.817E-02 7.912E-02 9.032E-02 1.016E-01 1.129E-01 1.239E-01 1.345E-01 1.445E-01 1.538E-01 1.622E-01 1.695E-01 1.757E-01 1.807E-01 1.843E-01 1.865E-01 1.872E-01 1.865E-01 1.843E-01 1.807E-01 1.757E-01 1.695E-01 1.622E-01 1.538E-01 1.445E-01 1.345E-01 1.239E-01 1.129E-01 1.016E-01 9.032E-02 7.912E-02 6.817E-02 5.764E-02 4.766E-02 3.837E-02 2.989E-02 2.232E-02 1.575E-02 1.026E-02 5.901E-03 2.725E-03 7.568E-04 7.911E-06 4.758E-04 2.143E-03 4.980E-03 8.941E-03 1.397E-02 2.001E-02 2.697E-02 3.477E-02 4.333E-02 5.254E-02 6.230E-02 7.250E-02 8.304E-02 9.380E-02 1.047E-01 1.156E-01 1.264E-01 1.370E-01 1.473E-01 1.572E-01 1.666E-01 1.755E-01 1.837E-01 1.912E-01 1.980E-01 2.040E-01 2.091E-01 2.133E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.208E-01 2.195E-01 2.174E-01 2.145E-01 2.107E-01 2.062E-01 2.010E-01 1.951E-01 1.886E-01 1.816E-01 1.741E-01 1.662E-01 1.579E-01 1.494E-01 1.407E-01 1.318E-01 1.228E-01 1.139E-01 1.050E-01 9.618E-02 8.755E-02 7.913E-02 7.099E-02 6.316E-02 5.569E-02 4.860E-02 4.194E-02 3.574E-02 3.000E-02 2.476E-02 2.002E-02 1.580E-02 1.209E-02 8.893E-03 6.210E-03 4.029E-03 2.337E-03 1.118E-03 3.533E-04 1.967E-05 9.249E-05 5.445E-04 1.347E-03 2.468E-03 3.877E-03 5.539E-03 7.422E-03 9.492E-03 1.171E-02 1.405E-02 1.648E-02 1.896E-02 2.146E-02 2.396E-02 2.642E-02 2.882E-02 3.113E-02 3.333E-02 3.539E-02 3.731E-02 3.907E-02 4.064E-02 4.203E-02 4.321E-02 4.419E-02 4.496E-02 4.551E-02 4.585E-02 4.597E-02 4.591E-02 4.597E-02 4.581E-02 4.543E-02 4.485E-02 4.404E-02 4.303E-02 4.181E-02 4.039E-02 3.878E-02 3.699E-02 3.504E-02 3.295E-02 3.072E-02 2.839E-02 2.598E-02 2.350E-02 2.100E-02 1.850E-02 1.602E-02 1.360E-02 1.128E-02 9.078E-03 7.039E-03 5.193E-03 3.575E-03 2.218E-03 1.157E-03 4.223E-04 4.531E-05 5.502E-05 4.784E-04 1.340E-03 2.662E-03 4.463E-03 6.759E-03 9.561E-03 1.288E-02 1.671E-02 2.107E-02 2.594E-02 3.131E-02 3.718E-02 4.351E-02 5.030E-02 5.750E-02 6.509E-02 7.303E-02 8.127E-02 8.977E-02 9.848E-02 1.073E-01 1.163E-01 1.253E-01 1.343E-01 1.431E-01 1.519E-01 1.603E-01 1.685E-01 1.764E-01 1.838E-01 1.906E-01 1.970E-01 2.027E-01 2.077E-01 2.120E-01 2.155E-01 2.182E-01 2.201E-01 2.210E-01 2.210E-01 2.201E-01 2.183E-01 2.155E-01 2.118E-01 2.072E-01 2.017E-01 1.954E-01 1.882E-01 1.803E-01 1.717E-01 1.625E-01 1.528E-01 1.426E-01 1.320E-01 1.212E-01 1.102E-01 9.920E-02 8.823E-02 7.743E-02 6.691E-02 5.679E-02 4.718E-02 3.819E-02 2.993E-02 2.250E-02 1.599E-02 1.049E-02 6.085E-03 2.832E-03 7.923E-04 8.147E-06 5.102E-04 2.314E-03 5.421E-03 9.814E-03 1.546E-02 2.232E-02 3.031E-02 3.937E-02 4.938E-02 6.024E-02 7.182E-02 8.397E-02 9.654E-02 1.094E-01 1.223E-01 1.350E-01 1.475E-01 1.595E-01 1.709E-01 1.814E-01 1.909E-01 1.992E-01 2.062E-01 2.118E-01 2.159E-01 2.183E-01 2.192E-01 2.183E-01 2.159E-01 2.118E-01 2.062E-01 1.992E-01 1.909E-01 1.814E-01 1.709E-01 1.595E-01 1.475E-01 1.350E-01 1.223E-01 1.094E-01 9.654E-02 8.397E-02 7.182E-02 6.024E-02 4.938E-02 3.937E-02 3.031E-02 2.232E-02 1.546E-02 9.814E-03 5.421E-03 2.314E-03 5.102E-04 8.147E-06 7.923E-04 2.832E-03 6.085E-03 1.049E-02 1.599E-02 2.250E-02 2.993E-02 3.819E-02 4.718E-02 5.679E-02 6.691E-02 7.743E-02 8.823E-02 9.920E-02 1.102E-01 1.212E-01 1.320E-01 1.426E-01 1.528E-01 1.625E-01 1.717E-01 1.803E-01 1.882E-01 1.954E-01 2.017E-01 2.072E-01 2.118E-01 2.155E-01 2.183E-01 2.201E-01 2.210E-01 2.210E-01 2.201E-01 2.182E-01 2.155E-01 2.120E-01 2.077E-01 2.027E-01 1.970E-01 1.906E-01 1.838E-01 1.764E-01 1.685E-01 1.603E-01 1.519E-01 1.431E-01 1.343E-01 1.253E-01 1.163E-01 1.073E-01 9.848E-02 8.977E-02 8.127E-02 7.303E-02 6.509E-02 5.750E-02 5.030E-02 4.351E-02 3.718E-02 3.131E-02 2.594E-02 2.107E-02 1.671E-02 1.288E-02 9.561E-03 6.759E-03 4.463E-03 2.662E-03 1.340E-03 4.784E-04 5.502E-05 4.531E-05 4.223E-04 1.157E-03 2.218E-03 3.575E-03 5.193E-03 7.039E-03 9.078E-03 1.128E-02 1.360E-02 1.602E-02 1.850E-02 2.100E-02 2.350E-02 2.598E-02 2.839E-02 3.072E-02 3.295E-02 3.504E-02 3.699E-02 3.878E-02 4.039E-02 4.181E-02 4.303E-02 4.404E-02 4.485E-02 4.543E-02 4.581E-02 4.597E-02 4.593E-02 4.595E-02 4.576E-02 4.536E-02 4.473E-02 4.390E-02 4.285E-02 4.159E-02 4.014E-02 3.850E-02 3.668E-02 3.470E-02 3.258E-02 3.033E-02 2.798E-02 2.555E-02 2.307E-02 2.056E-02 1.805E-02 1.558E-02 1.317E-02 1.087E-02 8.690E-03 6.680E-03 4.871E-03 3.296E-03 1.991E-03 9.884E-04 3.197E-04 1.574E-05 1.055E-04 6.158E-04 1.571E-03 2.992E-03 4.898E-03 7.304E-03 1.022E-02 1.366E-02 1.762E-02 2.209E-02 2.709E-02 3.259E-02 3.857E-02 4.503E-02 5.193E-02 5.925E-02 6.695E-02 7.499E-02 8.332E-02 9.191E-02 1.007E-01 1.096E-01 1.186E-01 1.276E-01 1.366E-01 1.455E-01 1.542E-01 1.626E-01 1.708E-01 1.785E-01 1.858E-01 1.926E-01 1.987E-01 2.043E-01 2.091E-01 2.132E-01 2.165E-01 2.189E-01 2.205E-01 2.211E-01 2.208E-01 2.196E-01 2.174E-01 2.143E-01 2.103E-01 2.053E-01 1.994E-01 1.927E-01 1.852E-01 1.770E-01 1.680E-01 1.585E-01 1.485E-01 1.380E-01 1.272E-01 1.162E-01 1.051E-01 9.394E-02 8.290E-02 7.209E-02 6.162E-02 5.161E-02 4.219E-02 3.345E-02 2.552E-02 1.850E-02 1.248E-02 7.561E-03 3.813E-03 1.310E-03 1.066E-04 2.485E-04 1.765E-03 4.670E-03 8.962E-03 1.462E-02 2.162E-02 2.989E-02 3.937E-02 4.997E-02 6.158E-02 7.408E-02 8.732E-02 1.012E-01 1.154E-01 1.299E-01 1.445E-01 1.589E-01 1.730E-01 1.865E-01 1.992E-01 2.110E-01 2.217E-01 2.310E-01 2.389E-01 2.451E-01 2.497E-01 2.525E-01 2.534E-01 2.525E-01 2.497E-01 2.451E-01 2.389E-01 2.310E-01 2.217E-01 2.110E-01 1.992E-01 1.865E-01 1.730E-01 1.589E-01 1.445E-01 1.299E-01 1.154E-01 1.012E-01 8.732E-02 7.408E-02 6.158E-02 4.997E-02 3.937E-02 2.989E-02 2.162E-02 1.462E-02 8.962E-03 4.670E-03 1.765E-03 2.485E-04 1.066E-04 1.310E-03 3.813E-03 7.561E-03 1.248E-02 1.850E-02 2.552E-02 3.345E-02 4.219E-02 5.161E-02 6.162E-02 7.209E-02 8.290E-02 9.394E-02 1.051E-01 1.162E-01 1.272E-01 1.380E-01 1.485E-01 1.585E-01 1.680E-01 1.770E-01 1.852E-01 1.927E-01 1.994E-01 2.053E-01 2.103E-01 2.143E-01 2.174E-01 2.196E-01 2.208E-01 2.211E-01 2.205E-01 2.189E-01 2.165E-01 2.132E-01 2.091E-01 2.043E-01 1.987E-01 1.926E-01 1.858E-01 1.785E-01 1.708E-01 1.626E-01 1.542E-01 1.455E-01 1.366E-01 1.276E-01 1.186E-01 1.096E-01 1.007E-01 9.191E-02 8.332E-02 7.499E-02 6.695E-02 5.925E-02 5.193E-02 4.503E-02 3.857E-02 3.259E-02 2.709E-02 2.209E-02 1.762E-02 1.366E-02 1.022E-02 7.304E-03 4.898E-03 2.992E-03 1.571E-03 6.158E-04 1.055E-04 1.574E-05 3.197E-04 9.884E-04 1.991E-03 3.296E-03 4.871E-03 6.680E-03 8.690E-03 1.087E-02 1.317E-02 1.558E-02 1.805E-02 2.056E-02 2.307E-02 2.555E-02 2.798E-02 3.033E-02 3.258E-02 3.470E-02 3.668E-02 3.850E-02 4.014E-02 4.159E-02 4.285E-02 4.390E-02 4.473E-02 4.536E-02 4.576E-02 4.595E-02 4.595E-02 4.594E-02 4.572E-02 4.528E-02 4.462E-02 4.375E-02 4.267E-02 4.138E-02 3.990E-02 3.823E-02 3.638E-02 3.437E-02 3.223E-02 2.996E-02 2.759E-02 2.515E-02 2.266E-02 2.014E-02 1.763E-02 1.517E-02 1.277E-02 1.048E-02 8.326E-03 6.345E-03 4.572E-03 3.041E-03 1.786E-03 8.399E-04 2.350E-04 1.762E-06 1.690E-04 7.631E-04 1.808E-03 3.325E-03 5.332E-03 7.844E-03 1.087E-02 1.442E-02 1.849E-02 2.309E-02 2.820E-02 3.382E-02 3.993E-02 4.650E-02 5.351E-02 6.094E-02 6.874E-02 7.687E-02 8.529E-02 9.395E-02 1.028E-01 1.118E-01 1.208E-01 1.299E-01 1.389E-01 1.477E-01 1.564E-01 1.648E-01 1.728E-01 1.805E-01 1.877E-01 1.943E-01 2.004E-01 2.057E-01 2.104E-01 2.143E-01 2.173E-01 2.195E-01 2.208E-01 2.211E-01 2.206E-01 2.190E-01 2.165E-01 2.130E-01 2.086E-01 2.033E-01 1.971E-01 1.901E-01 1.822E-01 1.737E-01 1.644E-01 1.546E-01 1.443E-01 1.336E-01 1.226E-01 1.114E-01 1.001E-01 8.891E-02 7.784E-02 6.704E-02 5.665E-02 4.679E-02 3.757E-02 2.912E-02 2.155E-02 1.497E-02 9.473E-03 5.157E-03 2.103E-03 3.816E-04 5.039E-05 1.154E-03 3.721E-03 7.765E-03 1.328E-02 2.025E-02 2.863E-02 3.837E-02 4.938E-02 6.158E-02 7.484E-02 8.903E-02 1.040E-01 1.196E-01 1.356E-01 1.519E-01 1.682E-01 1.843E-01 2.000E-01 2.151E-01 2.293E-01 2.424E-01 2.543E-01 2.647E-01 2.735E-01 2.805E-01 2.856E-01 2.887E-01 2.897E-01 2.887E-01 2.856E-01 2.805E-01 2.735E-01 2.647E-01 2.543E-01 2.424E-01 2.293E-01 2.151E-01 2.000E-01 1.843E-01 1.682E-01 1.519E-01 1.356E-01 1.196E-01 1.040E-01 8.903E-02 7.484E-02 6.158E-02 4.938E-02 3.837E-02 2.863E-02 2.025E-02 1.328E-02 7.765E-03 3.721E-03 1.154E-03 5.039E-05 3.816E-04 2.103E-03 5.157E-03 9.473E-03 1.497E-02 2.155E-02 2.912E-02 3.757E-02 4.679E-02 5.665E-02 6.704E-02 7.784E-02 8.891E-02 1.001E-01 1.114E-01 1.226E-01 1.336E-01 1.443E-01 1.546E-01 1.644E-01 1.737E-01 1.822E-01 1.901E-01 1.971E-01 2.033E-01 2.086E-01 2.130E-01 2.165E-01 2.190E-01 2.206E-01 2.211E-01 2.208E-01 2.195E-01 2.173E-01 2.143E-01 2.104E-01 2.057E-01 2.004E-01 1.943E-01 1.877E-01 1.805E-01 1.728E-01 1.648E-01 1.564E-01 1.477E-01 1.389E-01 1.299E-01 1.208E-01 1.118E-01 1.028E-01 9.395E-02 8.529E-02 7.687E-02 6.874E-02 6.094E-02 5.351E-02 4.650E-02 3.993E-02 3.382E-02 2.820E-02 2.309E-02 1.849E-02 1.442E-02 1.087E-02 7.844E-03 5.332E-03 3.325E-03 1.808E-03 7.631E-04 1.690E-04 1.762E-06 2.350E-04 8.399E-04 1.786E-03 3.041E-03 4.572E-03 6.345E-03 8.326E-03 1.048E-02 1.277E-02 1.517E-02 1.763E-02 2.014E-02 2.266E-02 2.515E-02 2.759E-02 2.996E-02 3.223E-02 3.437E-02 3.638E-02 3.823E-02 3.990E-02 4.138E-02 4.267E-02 4.375E-02 4.462E-02 4.528E-02 4.572E-02 4.594E-02 4.596E-02 4.592E-02 4.567E-02 4.520E-02 4.451E-02 4.361E-02 4.250E-02 4.118E-02 3.967E-02 3.796E-02 3.609E-02 3.406E-02 3.189E-02 2.961E-02 2.722E-02 2.477E-02 2.226E-02 1.974E-02 1.724E-02 1.478E-02 1.239E-02 1.012E-02 7.986E-03 6.034E-03 4.296E-03 2.807E-03 1.601E-03 7.096E-04 1.664E-04 1.402E-06 2.431E-04 9.178E-04 2.049E-03 3.658E-03 5.762E-03 8.375E-03 1.151E-02 1.516E-02 1.935E-02 2.406E-02 2.928E-02 3.501E-02 4.123E-02 4.791E-02 5.503E-02 6.255E-02 7.045E-02 7.867E-02 8.717E-02 9.590E-02 1.048E-01 1.138E-01 1.229E-01 1.320E-01 1.410E-01 1.498E-01 1.585E-01 1.668E-01 1.748E-01 1.824E-01 1.895E-01 1.960E-01 2.019E-01 2.071E-01 2.115E-01 2.152E-01 2.180E-01 2.200E-01 2.210E-01 2.211E-01 2.202E-01 2.183E-01 2.155E-01 2.117E-01 2.070E-01 2.014E-01 1.948E-01 1.875E-01 1.793E-01 1.704E-01 1.609E-01 1.508E-01 1.403E-01 1.293E-01 1.182E-01 1.068E-01 9.543E-02 8.413E-02 7.305E-02 6.230E-02 5.201E-02 4.231E-02 3.333E-02 2.519E-02 1.801E-02 1.189E-02 6.941E-03 3.258E-03 9.237E-04 1.105E-05 5.789E-04 2.672E-03 6.319E-03 1.153E-02 1.831E-02 2.662E-02 3.642E-02 4.766E-02 6.024E-02 7.408E-02 8.903E-02 1.050E-01 1.217E-01 1.391E-01 1.570E-01 1.750E-01 1.931E-01 2.110E-01 2.284E-01 2.451E-01 2.609E-01 2.755E-01 2.887E-01 3.003E-01 3.100E-01 3.178E-01 3.234E-01 3.268E-01 3.280E-01 3.268E-01 3.234E-01 3.178E-01 3.100E-01 3.003E-01 2.887E-01 2.755E-01 2.609E-01 2.451E-01 2.284E-01 2.110E-01 1.931E-01 1.750E-01 1.570E-01 1.391E-01 1.217E-01 1.050E-01 8.903E-02 7.408E-02 6.024E-02 4.766E-02 3.642E-02 2.662E-02 1.831E-02 1.153E-02 6.319E-03 2.672E-03 5.789E-04 1.105E-05 9.237E-04 3.258E-03 6.941E-03 1.189E-02 1.801E-02 2.519E-02 3.333E-02 4.231E-02 5.201E-02 6.230E-02 7.305E-02 8.413E-02 9.543E-02 1.068E-01 1.182E-01 1.293E-01 1.403E-01 1.508E-01 1.609E-01 1.704E-01 1.793E-01 1.875E-01 1.948E-01 2.014E-01 2.070E-01 2.117E-01 2.155E-01 2.183E-01 2.202E-01 2.211E-01 2.210E-01 2.200E-01 2.180E-01 2.152E-01 2.115E-01 2.071E-01 2.019E-01 1.960E-01 1.895E-01 1.824E-01 1.748E-01 1.668E-01 1.585E-01 1.498E-01 1.410E-01 1.320E-01 1.229E-01 1.138E-01 1.048E-01 9.590E-02 8.717E-02 7.867E-02 7.045E-02 6.255E-02 5.503E-02 4.791E-02 4.123E-02 3.501E-02 2.928E-02 2.406E-02 1.935E-02 1.516E-02 1.151E-02 8.375E-03 5.762E-03 3.658E-03 2.049E-03 9.178E-04 2.431E-04 1.402E-06 1.664E-04 7.096E-04 1.601E-03 2.807E-03 4.296E-03 6.034E-03 7.986E-03 1.012E-02 1.239E-02 1.478E-02 1.724E-02 1.974E-02 2.226E-02 2.477E-02 2.722E-02 2.961E-02 3.189E-02 3.406E-02 3.609E-02 3.796E-02 3.967E-02 4.118E-02 4.250E-02 4.361E-02 4.451E-02 4.520E-02 4.567E-02 4.592E-02 4.597E-02 4.590E-02 4.562E-02 4.512E-02 4.440E-02 4.347E-02 4.233E-02 4.098E-02 3.944E-02 3.772E-02 3.582E-02 3.376E-02 3.157E-02 2.927E-02 2.687E-02 2.440E-02 2.189E-02 1.937E-02 1.687E-02 1.441E-02 1.204E-02 9.777E-03 7.669E-03 5.746E-03 4.042E-03 2.594E-03 1.434E-03 5.962E-04 1.123E-04 1.271E-05 3.258E-04 1.078E-03 2.291E-03 3.988E-03 6.184E-03 8.893E-03 1.212E-02 1.588E-02 2.017E-02 2.499E-02 3.032E-02 3.616E-02 4.248E-02 4.926E-02 5.648E-02 6.410E-02 7.208E-02 8.038E-02 8.896E-02 9.775E-02 1.067E-01 1.158E-01 1.249E-01 1.340E-01 1.430E-01 1.518E-01 1.604E-01 1.687E-01 1.766E-01 1.841E-01 1.911E-01 1.975E-01 2.032E-01 2.083E-01 2.125E-01 2.160E-01 2.186E-01 2.203E-01 2.211E-01 2.209E-01 2.198E-01 2.176E-01 2.145E-01 2.104E-01 2.054E-01 1.994E-01 1.926E-01 1.849E-01 1.764E-01 1.673E-01 1.575E-01 1.471E-01 1.364E-01 1.252E-01 1.139E-01 1.024E-01 9.095E-02 7.962E-02 6.854E-02 5.786E-02 4.770E-02 3.819E-02 2.947E-02 2.166E-02 1.488E-02 9.244E-03 4.863E-03 1.832E-03 2.374E-04 1.532E-04 1.640E-03 4.742E-03 9.489E-03 1.589E-02 2.395E-02 3.362E-02 4.487E-02 5.764E-02 7.182E-02 8.732E-02 1.040E-01 1.217E-01 1.403E-01 1.595E-01 1.793E-01 1.992E-01 2.192E-01 2.389E-01 2.581E-01 2.765E-01 2.939E-01 3.100E-01 3.245E-01 3.373E-01 3.481E-01 3.566E-01 3.629E-01 3.667E-01 3.680E-01 3.667E-01 3.629E-01 3.566E-01 3.481E-01 3.373E-01 3.245E-01 3.100E-01 2.939E-01 2.765E-01 2.581E-01 2.389E-01 2.192E-01 1.992E-01 1.793E-01 1.595E-01 1.403E-01 1.217E-01 1.040E-01 8.732E-02 7.182E-02 5.764E-02 4.487E-02 3.362E-02 2.395E-02 1.589E-02 9.489E-03 4.742E-03 1.640E-03 1.532E-04 2.374E-04 1.832E-03 4.863E-03 9.244E-03 1.488E-02 2.166E-02 2.947E-02 3.819E-02 4.770E-02 5.786E-02 6.854E-02 7.962E-02 9.095E-02 1.024E-01 1.139E-01 1.252E-01 1.364E-01 1.471E-01 1.575E-01 1.673E-01 1.764E-01 1.849E-01 1.926E-01 1.994E-01 2.054E-01 2.104E-01 2.145E-01 2.176E-01 2.198E-01 2.209E-01 2.211E-01 2.203E-01 2.186E-01 2.160E-01 2.125E-01 2.083E-01 2.032E-01 1.975E-01 1.911E-01 1.841E-01 1.766E-01 1.687E-01 1.604E-01 1.518E-01 1.430E-01 1.340E-01 1.249E-01 1.158E-01 1.067E-01 9.775E-02 8.896E-02 8.038E-02 7.208E-02 6.410E-02 5.648E-02 4.926E-02 4.248E-02 3.616E-02 3.032E-02 2.499E-02 2.017E-02 1.588E-02 1.212E-02 8.893E-03 6.184E-03 3.988E-03 2.291E-03 1.078E-03 3.258E-04 1.271E-05 1.123E-04 5.962E-04 1.434E-03 2.594E-03 4.042E-03 5.746E-03 7.669E-03 9.777E-03 1.204E-02 1.441E-02 1.687E-02 1.937E-02 2.189E-02 2.440E-02 2.687E-02 2.927E-02 3.157E-02 3.376E-02 3.582E-02 3.772E-02 3.944E-02 4.098E-02 4.233E-02 4.347E-02 4.440E-02 4.512E-02 4.562E-02 4.590E-02 4.597E-02 4.588E-02 4.557E-02 4.504E-02 4.430E-02 4.334E-02 4.217E-02 4.080E-02 3.923E-02 3.748E-02 3.556E-02 3.348E-02 3.127E-02 2.895E-02 2.654E-02 2.406E-02 2.154E-02 1.902E-02 1.652E-02 1.407E-02 1.170E-02 9.461E-03 7.375E-03 5.479E-03 3.809E-03 2.400E-03 1.285E-03 4.981E-04 7.095E-05 3.381E-05 4.149E-04 1.240E-03 2.532E-03 4.312E-03 6.595E-03 9.396E-03 1.272E-02 1.658E-02 2.097E-02 2.588E-02 3.131E-02 3.725E-02 4.367E-02 5.055E-02 5.786E-02 6.556E-02 7.363E-02 8.200E-02 9.065E-02 9.950E-02 1.085E-01 1.176E-01 1.267E-01 1.358E-01 1.448E-01 1.537E-01 1.622E-01 1.705E-01 1.783E-01 1.857E-01 1.926E-01 1.989E-01 2.045E-01 2.094E-01 2.135E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.207E-01 2.193E-01 2.169E-01 2.135E-01 2.091E-01 2.038E-01 1.975E-01 1.904E-01 1.824E-01 1.737E-01 1.642E-01 1.542E-01 1.436E-01 1.326E-01 1.213E-01 1.098E-01 9.826E-02 8.673E-02 7.537E-02 6.433E-02 5.373E-02 4.371E-02 3.441E-02 2.597E-02 1.850E-02 1.214E-02 7.009E-03 3.209E-03 8.437E-04 9.434E-07 7.568E-04 3.173E-03 7.295E-03 1.315E-02 2.076E-02 3.010E-02 4.115E-02 5.387E-02 6.817E-02 8.397E-02 1.012E-01 1.196E-01 1.391E-01 1.595E-01 1.807E-01 2.023E-01 2.242E-01 2.461E-01 2.676E-01 2.887E-01 3.089E-01 3.280E-01 3.457E-01 3.616E-01 3.757E-01 3.875E-01 3.970E-01 4.038E-01 4.080E-01 4.094E-01 4.080E-01 4.038E-01 3.970E-01 3.875E-01 3.757E-01 3.616E-01 3.457E-01 3.280E-01 3.089E-01 2.887E-01 2.676E-01 2.461E-01 2.242E-01 2.023E-01 1.807E-01 1.595E-01 1.391E-01 1.196E-01 1.012E-01 8.397E-02 6.817E-02 5.387E-02 4.115E-02 3.010E-02 2.076E-02 1.315E-02 7.295E-03 3.173E-03 7.568E-04 9.434E-07 8.437E-04 3.209E-03 7.009E-03 1.214E-02 1.850E-02 2.597E-02 3.441E-02 4.371E-02 5.373E-02 6.433E-02 7.537E-02 8.673E-02 9.826E-02 1.098E-01 1.213E-01 1.326E-01 1.436E-01 1.542E-01 1.642E-01 1.737E-01 1.824E-01 1.904E-01 1.975E-01 2.038E-01 2.091E-01 2.135E-01 2.169E-01 2.193E-01 2.207E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.135E-01 2.094E-01 2.045E-01 1.989E-01 1.926E-01 1.857E-01 1.783E-01 1.705E-01 1.622E-01 1.537E-01 1.448E-01 1.358E-01 1.267E-01 1.176E-01 1.085E-01 9.950E-02 9.065E-02 8.200E-02 7.363E-02 6.556E-02 5.786E-02 5.055E-02 4.367E-02 3.725E-02 3.131E-02 2.588E-02 2.097E-02 1.658E-02 1.272E-02 9.396E-03 6.595E-03 4.312E-03 2.532E-03 1.240E-03 4.149E-04 3.381E-05 7.095E-05 4.981E-04 1.285E-03 2.400E-03 3.809E-03 5.479E-03 7.375E-03 9.461E-03 1.170E-02 1.407E-02 1.652E-02 1.902E-02 2.154E-02 2.406E-02 2.654E-02 2.895E-02 3.127E-02 3.348E-02 3.556E-02 3.748E-02 3.923E-02 4.080E-02 4.217E-02 4.334E-02 4.430E-02 4.504E-02 4.557E-02 4.588E-02 4.597E-02 4.585E-02 4.552E-02 4.497E-02 4.420E-02 4.321E-02 4.202E-02 4.062E-02 3.903E-02 3.725E-02 3.531E-02 3.321E-02 3.099E-02 2.865E-02 2.622E-02 2.374E-02 2.122E-02 1.869E-02 1.619E-02 1.375E-02 1.139E-02 9.169E-03 7.104E-03 5.234E-03 3.596E-03 2.224E-03 1.152E-03 4.139E-04 4.068E-05 6.286E-05 5.085E-04 1.403E-03 2.770E-03 4.628E-03 6.994E-03 9.880E-03 1.329E-02 1.724E-02 2.172E-02 2.673E-02 3.226E-02 3.829E-02 4.480E-02 5.177E-02 5.916E-02 6.695E-02 7.509E-02 8.353E-02 9.224E-02 1.011E-01 1.102E-01 1.193E-01 1.285E-01 1.376E-01 1.466E-01 1.554E-01 1.639E-01 1.721E-01 1.799E-01 1.872E-01 1.940E-01 2.001E-01 2.056E-01 2.103E-01 2.143E-01 2.174E-01 2.196E-01 2.208E-01 2.211E-01 2.205E-01 2.188E-01 2.161E-01 2.124E-01 2.078E-01 2.022E-01 1.956E-01 1.882E-01 1.800E-01 1.710E-01 1.613E-01 1.510E-01 1.403E-01 1.291E-01 1.176E-01 1.060E-01 9.435E-02 8.276E-02 7.141E-02 6.041E-02 4.991E-02 4.005E-02 3.098E-02 2.282E-02 1.571E-02 9.783E-03 5.157E-03 1.946E-03 2.518E-04 1.654E-04 1.765E-03 5.113E-03 1.026E-02 1.723E-02 2.603E-02 3.666E-02 4.909E-02 6.327E-02 7.912E-02 9.654E-02 1.154E-01 1.356E-01 1.570E-01 1.793E-01 2.023E-01 2.259E-01 2.497E-01 2.735E-01 2.971E-01 3.200E-01 3.421E-01 3.629E-01 3.822E-01 3.997E-01 4.151E-01 4.281E-01 4.384E-01 4.460E-01 4.506E-01 4.521E-01 4.506E-01 4.460E-01 4.384E-01 4.281E-01 4.151E-01 3.997E-01 3.822E-01 3.629E-01 3.421E-01 3.200E-01 2.971E-01 2.735E-01 2.497E-01 2.259E-01 2.023E-01 1.793E-01 1.570E-01 1.356E-01 1.154E-01 9.654E-02 7.912E-02 6.327E-02 4.909E-02 3.666E-02 2.603E-02 1.723E-02 1.026E-02 5.113E-03 1.765E-03 1.654E-04 2.518E-04 1.946E-03 5.157E-03 9.783E-03 1.571E-02 2.282E-02 3.098E-02 4.005E-02 4.991E-02 6.041E-02 7.141E-02 8.276E-02 9.435E-02 1.060E-01 1.176E-01 1.291E-01 1.403E-01 1.510E-01 1.613E-01 1.710E-01 1.800E-01 1.882E-01 1.956E-01 2.022E-01 2.078E-01 2.124E-01 2.161E-01 2.188E-01 2.205E-01 2.211E-01 2.208E-01 2.196E-01 2.174E-01 2.143E-01 2.103E-01 2.056E-01 2.001E-01 1.940E-01 1.872E-01 1.799E-01 1.721E-01 1.639E-01 1.554E-01 1.466E-01 1.376E-01 1.285E-01 1.193E-01 1.102E-01 1.011E-01 9.224E-02 8.353E-02 7.509E-02 6.695E-02 5.916E-02 5.177E-02 4.480E-02 3.829E-02 3.226E-02 2.673E-02 2.172E-02 1.724E-02 1.329E-02 9.880E-03 6.994E-03 4.628E-03 2.770E-03 1.403E-03 5.085E-04 6.286E-05 4.068E-05 4.139E-04 1.152E-03 2.224E-03 3.596E-03 5.234E-03 7.104E-03 9.169E-03 1.139E-02 1.375E-02 1.619E-02 1.869E-02 2.122E-02 2.374E-02 2.622E-02 2.865E-02 3.099E-02 3.321E-02 3.531E-02 3.725E-02 3.903E-02 4.062E-02 4.202E-02 4.321E-02 4.420E-02 4.497E-02 4.552E-02 4.585E-02 4.597E-02 4.583E-02 4.547E-02 4.489E-02 4.410E-02 4.309E-02 4.187E-02 4.045E-02 3.884E-02 3.704E-02 3.508E-02 3.296E-02 3.072E-02 2.837E-02 2.593E-02 2.344E-02 2.091E-02 1.838E-02 1.588E-02 1.345E-02 1.111E-02 8.898E-03 6.854E-03 5.010E-03 3.402E-03 2.066E-03 1.035E-03 3.421E-04 1.993E-05 9.812E-05 6.046E-04 1.565E-03 3.001E-03 4.933E-03 7.376E-03 1.034E-02 1.384E-02 1.787E-02 2.244E-02 2.754E-02 3.315E-02 3.927E-02 4.586E-02 5.291E-02 6.039E-02 6.825E-02 7.646E-02 8.497E-02 9.373E-02 1.027E-01 1.118E-01 1.209E-01 1.301E-01 1.392E-01 1.482E-01 1.570E-01 1.655E-01 1.736E-01 1.814E-01 1.886E-01 1.953E-01 2.013E-01 2.066E-01 2.112E-01 2.150E-01 2.179E-01 2.199E-01 2.210E-01 2.211E-01 2.202E-01 2.182E-01 2.153E-01 2.114E-01 2.065E-01 2.006E-01 1.938E-01 1.861E-01 1.777E-01 1.684E-01 1.585E-01 1.480E-01 1.371E-01 1.257E-01 1.142E-01 1.024E-01 9.068E-02 7.907E-02 6.772E-02 5.679E-02 4.640E-02 3.672E-02 2.787E-02 2.001E-02 1.326E-02 7.773E-03 3.658E-03 1.036E-03 1.105E-05 6.775E-04 3.115E-03 7.388E-03 1.354E-02 2.162E-02 3.161E-02 4.352E-02 5.732E-02 7.294E-02 9.032E-02 1.094E-01 1.299E-01 1.519E-01 1.750E-01 1.992E-01 2.242E-01 2.497E-01 2.755E-01 3.013E-01 3.268E-01 3.517E-01 3.757E-01 3.983E-01 4.194E-01 4.384E-01 4.552E-01 4.694E-01 4.808E-01 4.891E-01 4.941E-01 4.958E-01 4.941E-01 4.891E-01 4.808E-01 4.694E-01 4.552E-01 4.384E-01 4.194E-01 3.983E-01 3.757E-01 3.517E-01 3.268E-01 3.013E-01 2.755E-01 2.497E-01 2.242E-01 1.992E-01 1.750E-01 1.519E-01 1.299E-01 1.094E-01 9.032E-02 7.294E-02 5.732E-02 4.352E-02 3.161E-02 2.162E-02 1.354E-02 7.388E-03 3.115E-03 6.775E-04 1.105E-05 1.036E-03 3.658E-03 7.773E-03 1.326E-02 2.001E-02 2.787E-02 3.672E-02 4.640E-02 5.679E-02 6.772E-02 7.907E-02 9.068E-02 1.024E-01 1.142E-01 1.257E-01 1.371E-01 1.480E-01 1.585E-01 1.684E-01 1.777E-01 1.861E-01 1.938E-01 2.006E-01 2.065E-01 2.114E-01 2.153E-01 2.182E-01 2.202E-01 2.211E-01 2.210E-01 2.199E-01 2.179E-01 2.150E-01 2.112E-01 2.066E-01 2.013E-01 1.953E-01 1.886E-01 1.814E-01 1.736E-01 1.655E-01 1.570E-01 1.482E-01 1.392E-01 1.301E-01 1.209E-01 1.118E-01 1.027E-01 9.373E-02 8.497E-02 7.646E-02 6.825E-02 6.039E-02 5.291E-02 4.586E-02 3.927E-02 3.315E-02 2.754E-02 2.244E-02 1.787E-02 1.384E-02 1.034E-02 7.376E-03 4.933E-03 3.001E-03 1.565E-03 6.046E-04 9.812E-05 1.993E-05 3.421E-04 1.035E-03 2.066E-03 3.402E-03 5.010E-03 6.854E-03 8.898E-03 1.111E-02 1.345E-02 1.588E-02 1.838E-02 2.091E-02 2.344E-02 2.593E-02 2.837E-02 3.072E-02 3.296E-02 3.508E-02 3.704E-02 3.884E-02 4.045E-02 4.187E-02 4.309E-02 4.410E-02 4.489E-02 4.547E-02 4.583E-02 4.596E-02 4.580E-02 4.542E-02 4.483E-02 4.401E-02 4.298E-02 4.174E-02 4.029E-02 3.866E-02 3.684E-02 3.486E-02 3.273E-02 3.047E-02 2.811E-02 2.566E-02 2.316E-02 2.063E-02 1.810E-02 1.560E-02 1.317E-02 1.085E-02 8.650E-03 6.625E-03 4.805E-03 3.227E-03 1.924E-03 9.309E-04 2.815E-04 7.209E-06 1.379E-04 7.014E-04 1.723E-03 3.224E-03 5.225E-03 7.741E-03 1.078E-02 1.436E-02 1.847E-02 2.312E-02 2.830E-02 3.399E-02 4.019E-02 4.686E-02 5.399E-02 6.154E-02 6.947E-02 7.774E-02 8.631E-02 9.512E-02 1.041E-01 1.132E-01 1.224E-01 1.316E-01 1.407E-01 1.497E-01 1.585E-01 1.669E-01 1.750E-01 1.827E-01 1.899E-01 1.964E-01 2.024E-01 2.076E-01 2.120E-01 2.156E-01 2.184E-01 2.202E-01 2.211E-01 2.210E-01 2.198E-01 2.177E-01 2.145E-01 2.104E-01 2.052E-01 1.991E-01 1.921E-01 1.842E-01 1.755E-01 1.660E-01 1.559E-01 1.452E-01 1.341E-01 1.226E-01 1.109E-01 9.907E-02 8.727E-02 7.565E-02 6.433E-02 5.346E-02 4.320E-02 3.369E-02 2.508E-02 1.752E-02 1.114E-02 6.085E-03 2.477E-03 4.369E-04 7.283E-05 1.481E-03 4.742E-03 9.923E-03 1.707E-02 2.623E-02 3.739E-02 5.055E-02 6.569E-02 8.274E-02 1.016E-01 1.223E-01 1.445E-01 1.682E-01 1.931E-01 2.192E-01 2.461E-01 2.735E-01 3.013E-01 3.291E-01 3.566E-01 3.835E-01 4.094E-01 4.340E-01 4.568E-01 4.775E-01 4.958E-01 5.113E-01 5.237E-01 5.328E-01 5.383E-01 5.402E-01 5.383E-01 5.328E-01 5.237E-01 5.113E-01 4.958E-01 4.775E-01 4.568E-01 4.340E-01 4.094E-01 3.835E-01 3.566E-01 3.291E-01 3.013E-01 2.735E-01 2.461E-01 2.192E-01 1.931E-01 1.682E-01 1.445E-01 1.223E-01 1.016E-01 8.274E-02 6.569E-02 5.055E-02 3.739E-02 2.623E-02 1.707E-02 9.923E-03 4.742E-03 1.481E-03 7.283E-05 4.369E-04 2.477E-03 6.085E-03 1.114E-02 1.752E-02 2.508E-02 3.369E-02 4.320E-02 5.346E-02 6.433E-02 7.565E-02 8.727E-02 9.907E-02 1.109E-01 1.226E-01 1.341E-01 1.452E-01 1.559E-01 1.660E-01 1.755E-01 1.842E-01 1.921E-01 1.991E-01 2.052E-01 2.104E-01 2.145E-01 2.177E-01 2.198E-01 2.210E-01 2.211E-01 2.202E-01 2.184E-01 2.156E-01 2.120E-01 2.076E-01 2.024E-01 1.964E-01 1.899E-01 1.827E-01 1.750E-01 1.669E-01 1.585E-01 1.497E-01 1.407E-01 1.316E-01 1.224E-01 1.132E-01 1.041E-01 9.512E-02 8.631E-02 7.774E-02 6.947E-02 6.154E-02 5.399E-02 4.686E-02 4.019E-02 3.399E-02 2.830E-02 2.312E-02 1.847E-02 1.436E-02 1.078E-02 7.741E-03 5.225E-03 3.224E-03 1.723E-03 7.014E-04 1.379E-04 7.209E-06 2.815E-04 9.309E-04 1.924E-03 3.227E-03 4.805E-03 6.625E-03 8.650E-03 1.085E-02 1.317E-02 1.560E-02 1.810E-02 2.063E-02 2.316E-02 2.566E-02 2.811E-02 3.047E-02 3.273E-02 3.486E-02 3.684E-02 3.866E-02 4.029E-02 4.174E-02 4.298E-02 4.401E-02 4.483E-02 4.542E-02 4.580E-02 4.596E-02 4.578E-02 4.538E-02 4.476E-02 4.392E-02 4.287E-02 4.161E-02 4.015E-02 3.849E-02 3.666E-02 3.466E-02 3.251E-02 3.024E-02 2.787E-02 2.541E-02 2.290E-02 2.037E-02 1.784E-02 1.535E-02 1.292E-02 1.060E-02 8.424E-03 6.417E-03 4.620E-03 3.068E-03 1.797E-03 8.399E-04 2.307E-04 1.084E-06 1.807E-04 7.971E-04 1.875E-03 3.437E-03 5.502E-03 8.084E-03 1.120E-02 1.484E-02 1.903E-02 2.375E-02 2.900E-02 3.477E-02 4.104E-02 4.779E-02 5.499E-02 6.260E-02 7.060E-02 7.893E-02 8.755E-02 9.640E-02 1.054E-01 1.146E-01 1.238E-01 1.330E-01 1.421E-01 1.511E-01 1.598E-01 1.682E-01 1.763E-01 1.839E-01 1.910E-01 1.975E-01 2.033E-01 2.084E-01 2.127E-01 2.162E-01 2.188E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.138E-01 2.094E-01 2.040E-01 1.977E-01 1.904E-01 1.823E-01 1.734E-01 1.637E-01 1.534E-01 1.426E-01 1.313E-01 1.197E-01 1.079E-01 9.597E-02 8.413E-02 7.250E-02 6.122E-02 5.043E-02 4.030E-02 3.098E-02 2.260E-02 1.534E-02 9.320E-03 4.690E-03 1.578E-03 1.066E-04 3.863E-04 2.515E-03 6.577E-03 1.264E-02 2.076E-02 3.096E-02 4.325E-02 5.764E-02 7.408E-02 9.251E-02 1.129E-01 1.350E-01 1.589E-01 1.843E-01 2.110E-01 2.389E-01 2.676E-01 2.971E-01 3.268E-01 3.566E-01 3.862E-01 4.151E-01 4.430E-01 4.694E-01 4.941E-01 5.166E-01 5.365E-01 5.533E-01 5.669E-01 5.768E-01 5.828E-01 5.849E-01 5.828E-01 5.768E-01 5.669E-01 5.533E-01 5.365E-01 5.166E-01 4.941E-01 4.694E-01 4.430E-01 4.151E-01 3.862E-01 3.566E-01 3.268E-01 2.971E-01 2.676E-01 2.389E-01 2.110E-01 1.843E-01 1.589E-01 1.350E-01 1.129E-01 9.251E-02 7.408E-02 5.764E-02 4.325E-02 3.096E-02 2.076E-02 1.264E-02 6.577E-03 2.515E-03 3.863E-04 1.066E-04 1.578E-03 4.690E-03 9.320E-03 1.534E-02 2.260E-02 3.098E-02 4.030E-02 5.043E-02 6.122E-02 7.250E-02 8.413E-02 9.597E-02 1.079E-01 1.197E-01 1.313E-01 1.426E-01 1.534E-01 1.637E-01 1.734E-01 1.823E-01 1.904E-01 1.977E-01 2.040E-01 2.094E-01 2.138E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.188E-01 2.162E-01 2.127E-01 2.084E-01 2.033E-01 1.975E-01 1.910E-01 1.839E-01 1.763E-01 1.682E-01 1.598E-01 1.511E-01 1.421E-01 1.330E-01 1.238E-01 1.146E-01 1.054E-01 9.640E-02 8.755E-02 7.893E-02 7.060E-02 6.260E-02 5.499E-02 4.779E-02 4.104E-02 3.477E-02 2.900E-02 2.375E-02 1.903E-02 1.484E-02 1.120E-02 8.084E-03 5.502E-03 3.437E-03 1.875E-03 7.971E-04 1.807E-04 1.084E-06 2.307E-04 8.399E-04 1.797E-03 3.068E-03 4.620E-03 6.417E-03 8.424E-03 1.060E-02 1.292E-02 1.535E-02 1.784E-02 2.037E-02 2.290E-02 2.541E-02 2.787E-02 3.024E-02 3.251E-02 3.466E-02 3.666E-02 3.849E-02 4.015E-02 4.161E-02 4.287E-02 4.392E-02 4.476E-02 4.538E-02 4.578E-02 4.595E-02 4.575E-02 4.533E-02 4.470E-02 4.384E-02 4.277E-02 4.149E-02 4.001E-02 3.834E-02 3.649E-02 3.447E-02 3.231E-02 3.003E-02 2.765E-02 2.518E-02 2.267E-02 2.013E-02 1.760E-02 1.511E-02 1.269E-02 1.039E-02 8.218E-03 6.229E-03 4.453E-03 2.927E-03 1.684E-03 7.605E-04 1.886E-04 2.162E-07 2.249E-04 8.902E-04 2.021E-03 3.639E-03 5.762E-03 8.406E-03 1.158E-02 1.529E-02 1.955E-02 2.434E-02 2.966E-02 3.549E-02 4.183E-02 4.864E-02 5.591E-02 6.358E-02 7.163E-02 8.002E-02 8.868E-02 9.758E-02 1.067E-01 1.158E-01 1.251E-01 1.343E-01 1.434E-01 1.523E-01 1.611E-01 1.694E-01 1.775E-01 1.850E-01 1.920E-01 1.984E-01 2.042E-01 2.092E-01 2.133E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.207E-01 2.192E-01 2.166E-01 2.130E-01 2.085E-01 2.029E-01 1.963E-01 1.889E-01 1.806E-01 1.714E-01 1.616E-01 1.511E-01 1.401E-01 1.287E-01 1.170E-01 1.051E-01 9.313E-02 8.126E-02 6.963E-02 5.839E-02 4.770E-02 3.770E-02 2.855E-02 2.042E-02 1.344E-02 7.773E-03 3.556E-03 9.237E-04 2.496E-07 8.991E-04 3.721E-03 8.552E-03 1.546E-02 2.450E-02 3.571E-02 4.909E-02 6.465E-02 8.233E-02 1.021E-01 1.239E-01 1.475E-01 1.730E-01 2.000E-01 2.284E-01 2.581E-01 2.887E-01 3.200E-01 3.517E-01 3.835E-01 4.151E-01 4.460E-01 4.759E-01 5.044E-01 5.310E-01 5.552E-01 5.768E-01 5.952E-01 6.099E-01 6.208E-01 6.274E-01 6.296E-01 6.274E-01 6.208E-01 6.099E-01 5.952E-01 5.768E-01 5.552E-01 5.310E-01 5.044E-01 4.759E-01 4.460E-01 4.151E-01 3.835E-01 3.517E-01 3.200E-01 2.887E-01 2.581E-01 2.284E-01 2.000E-01 1.730E-01 1.475E-01 1.239E-01 1.021E-01 8.233E-02 6.465E-02 4.909E-02 3.571E-02 2.450E-02 1.546E-02 8.552E-03 3.721E-03 8.991E-04 2.496E-07 9.237E-04 3.556E-03 7.773E-03 1.344E-02 2.042E-02 2.855E-02 3.770E-02 4.770E-02 5.839E-02 6.963E-02 8.126E-02 9.313E-02 1.051E-01 1.170E-01 1.287E-01 1.401E-01 1.511E-01 1.616E-01 1.714E-01 1.806E-01 1.889E-01 1.963E-01 2.029E-01 2.085E-01 2.130E-01 2.166E-01 2.192E-01 2.207E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.133E-01 2.092E-01 2.042E-01 1.984E-01 1.920E-01 1.850E-01 1.775E-01 1.694E-01 1.611E-01 1.523E-01 1.434E-01 1.343E-01 1.251E-01 1.158E-01 1.067E-01 9.758E-02 8.868E-02 8.002E-02 7.163E-02 6.358E-02 5.591E-02 4.864E-02 4.183E-02 3.549E-02 2.966E-02 2.434E-02 1.955E-02 1.529E-02 1.158E-02 8.406E-03 5.762E-03 3.639E-03 2.021E-03 8.902E-04 2.249E-04 2.162E-07 1.886E-04 7.605E-04 1.684E-03 2.927E-03 4.453E-03 6.229E-03 8.218E-03 1.039E-02 1.269E-02 1.511E-02 1.760E-02 2.013E-02 2.267E-02 2.518E-02 2.765E-02 3.003E-02 3.231E-02 3.447E-02 3.649E-02 3.834E-02 4.001E-02 4.149E-02 4.277E-02 4.384E-02 4.470E-02 4.533E-02 4.575E-02 4.594E-02 4.573E-02 4.529E-02 4.464E-02 4.377E-02 4.268E-02 4.138E-02 3.988E-02 3.820E-02 3.633E-02 3.430E-02 3.213E-02 2.984E-02 2.744E-02 2.497E-02 2.245E-02 1.991E-02 1.739E-02 1.490E-02 1.249E-02 1.019E-02 8.034E-03 6.061E-03 4.304E-03 2.801E-03 1.585E-03 6.919E-04 1.541E-04 3.357E-06 2.693E-04 9.791E-04 2.157E-03 3.826E-03 6.003E-03 8.703E-03 1.194E-02 1.571E-02 2.002E-02 2.487E-02 3.026E-02 3.616E-02 4.255E-02 4.943E-02 5.674E-02 6.447E-02 7.258E-02 8.101E-02 8.972E-02 9.865E-02 1.078E-01 1.170E-01 1.262E-01 1.354E-01 1.445E-01 1.535E-01 1.622E-01 1.705E-01 1.785E-01 1.860E-01 1.929E-01 1.993E-01 2.049E-01 2.098E-01 2.139E-01 2.171E-01 2.194E-01 2.208E-01 2.211E-01 2.205E-01 2.188E-01 2.161E-01 2.124E-01 2.076E-01 2.018E-01 1.951E-01 1.875E-01 1.790E-01 1.697E-01 1.597E-01 1.490E-01 1.379E-01 1.264E-01 1.145E-01 1.026E-01 9.054E-02 7.866E-02 6.704E-02 5.585E-02 4.524E-02 3.538E-02 2.641E-02 1.850E-02 1.181E-02 6.474E-03 2.652E-03 4.758E-04 7.283E-05 1.559E-03 5.037E-03 1.060E-02 1.831E-02 2.822E-02 4.038E-02 5.479E-02 7.145E-02 9.032E-02 1.114E-01 1.345E-01 1.595E-01 1.865E-01 2.151E-01 2.451E-01 2.765E-01 3.089E-01 3.421E-01 3.757E-01 4.094E-01 4.430E-01 4.759E-01 5.078E-01 5.383E-01 5.669E-01 5.931E-01 6.164E-01 6.364E-01 6.525E-01 6.643E-01 6.716E-01 6.740E-01 6.716E-01 6.643E-01 6.525E-01 6.364E-01 6.164E-01 5.931E-01 5.669E-01 5.383E-01 5.078E-01 4.759E-01 4.430E-01 4.094E-01 3.757E-01 3.421E-01 3.089E-01 2.765E-01 2.451E-01 2.151E-01 1.865E-01 1.595E-01 1.345E-01 1.114E-01 9.032E-02 7.145E-02 5.479E-02 4.038E-02 2.822E-02 1.831E-02 1.060E-02 5.037E-03 1.559E-03 7.283E-05 4.758E-04 2.652E-03 6.474E-03 1.181E-02 1.850E-02 2.641E-02 3.538E-02 4.524E-02 5.585E-02 6.704E-02 7.866E-02 9.054E-02 1.026E-01 1.145E-01 1.264E-01 1.379E-01 1.490E-01 1.597E-01 1.697E-01 1.790E-01 1.875E-01 1.951E-01 2.018E-01 2.076E-01 2.124E-01 2.161E-01 2.188E-01 2.205E-01 2.211E-01 2.208E-01 2.194E-01 2.171E-01 2.139E-01 2.098E-01 2.049E-01 1.993E-01 1.929E-01 1.860E-01 1.785E-01 1.705E-01 1.622E-01 1.535E-01 1.445E-01 1.354E-01 1.262E-01 1.170E-01 1.078E-01 9.865E-02 8.972E-02 8.101E-02 7.258E-02 6.447E-02 5.674E-02 4.943E-02 4.255E-02 3.616E-02 3.026E-02 2.487E-02 2.002E-02 1.571E-02 1.194E-02 8.703E-03 6.003E-03 3.826E-03 2.157E-03 9.791E-04 2.693E-04 3.357E-06 1.541E-04 6.919E-04 1.585E-03 2.801E-03 4.304E-03 6.061E-03 8.034E-03 1.019E-02 1.249E-02 1.490E-02 1.739E-02 1.991E-02 2.245E-02 2.497E-02 2.744E-02 2.984E-02 3.213E-02 3.430E-02 3.633E-02 3.820E-02 3.988E-02 4.138E-02 4.268E-02 4.377E-02 4.464E-02 4.529E-02 4.573E-02 4.594E-02 4.571E-02 4.526E-02 4.459E-02 4.370E-02 4.260E-02 4.128E-02 3.977E-02 3.807E-02 3.619E-02 3.415E-02 3.197E-02 2.967E-02 2.726E-02 2.479E-02 2.226E-02 1.972E-02 1.719E-02 1.471E-02 1.230E-02 1.001E-02 7.870E-03 5.911E-03 4.173E-03 2.690E-03 1.499E-03 6.330E-04 1.261E-04 9.360E-06 3.124E-04 1.062E-03 2.284E-03 3.998E-03 6.223E-03 8.973E-03 1.226E-02 1.608E-02 2.045E-02 2.536E-02 3.080E-02 3.675E-02 4.320E-02 5.013E-02 5.750E-02 6.528E-02 7.343E-02 8.190E-02 9.065E-02 9.961E-02 1.087E-01 1.180E-01 1.272E-01 1.364E-01 1.456E-01 1.545E-01 1.632E-01 1.715E-01 1.794E-01 1.869E-01 1.938E-01 2.000E-01 2.056E-01 2.104E-01 2.144E-01 2.175E-01 2.197E-01 2.209E-01 2.211E-01 2.203E-01 2.185E-01 2.156E-01 2.117E-01 2.068E-01 2.008E-01 1.940E-01 1.861E-01 1.775E-01 1.680E-01 1.579E-01 1.471E-01 1.359E-01 1.242E-01 1.123E-01 1.003E-01 8.823E-02 7.633E-02 6.473E-02 5.359E-02 4.307E-02 3.333E-02 2.454E-02 1.684E-02 1.041E-02 5.398E-03 1.946E-03 1.968E-04 2.800E-04 2.314E-03 6.405E-03 1.264E-02 2.110E-02 3.183E-02 4.487E-02 6.024E-02 7.793E-02 9.791E-02 1.201E-01 1.445E-01 1.709E-01 1.992E-01 2.293E-01 2.609E-01 2.939E-01 3.280E-01 3.629E-01 3.983E-01 4.340E-01 4.694E-01 5.044E-01 5.383E-01 5.708E-01 6.014E-01 6.296E-01 6.548E-01 6.765E-01 6.941E-01 7.071E-01 7.151E-01 7.178E-01 7.151E-01 7.071E-01 6.941E-01 6.765E-01 6.548E-01 6.296E-01 6.014E-01 5.708E-01 5.383E-01 5.044E-01 4.694E-01 4.340E-01 3.983E-01 3.629E-01 3.280E-01 2.939E-01 2.609E-01 2.293E-01 1.992E-01 1.709E-01 1.445E-01 1.201E-01 9.791E-02 7.793E-02 6.024E-02 4.487E-02 3.183E-02 2.110E-02 1.264E-02 6.405E-03 2.314E-03 2.800E-04 1.968E-04 1.946E-03 5.398E-03 1.041E-02 1.684E-02 2.454E-02 3.333E-02 4.307E-02 5.359E-02 6.473E-02 7.633E-02 8.823E-02 1.003E-01 1.123E-01 1.242E-01 1.359E-01 1.471E-01 1.579E-01 1.680E-01 1.775E-01 1.861E-01 1.940E-01 2.008E-01 2.068E-01 2.117E-01 2.156E-01 2.185E-01 2.203E-01 2.211E-01 2.209E-01 2.197E-01 2.175E-01 2.144E-01 2.104E-01 2.056E-01 2.000E-01 1.938E-01 1.869E-01 1.794E-01 1.715E-01 1.632E-01 1.545E-01 1.456E-01 1.364E-01 1.272E-01 1.180E-01 1.087E-01 9.961E-02 9.065E-02 8.190E-02 7.343E-02 6.528E-02 5.750E-02 5.013E-02 4.320E-02 3.675E-02 3.080E-02 2.536E-02 2.045E-02 1.608E-02 1.226E-02 8.973E-03 6.223E-03 3.998E-03 2.284E-03 1.062E-03 3.124E-04 9.360E-06 1.261E-04 6.330E-04 1.499E-03 2.690E-03 4.173E-03 5.911E-03 7.870E-03 1.001E-02 1.230E-02 1.471E-02 1.719E-02 1.972E-02 2.226E-02 2.479E-02 2.726E-02 2.967E-02 3.197E-02 3.415E-02 3.619E-02 3.807E-02 3.977E-02 4.128E-02 4.260E-02 4.370E-02 4.459E-02 4.526E-02 4.571E-02 4.593E-02 4.569E-02 4.522E-02 4.454E-02 4.364E-02 4.252E-02 4.120E-02 3.967E-02 3.796E-02 3.607E-02 3.402E-02 3.183E-02 2.951E-02 2.710E-02 2.462E-02 2.210E-02 1.955E-02 1.702E-02 1.454E-02 1.214E-02 9.859E-03 7.726E-03 5.780E-03 4.058E-03 2.594E-03 1.424E-03 5.831E-04 1.036E-04 1.718E-05 3.533E-04 1.139E-03 2.399E-03 4.153E-03 6.421E-03 9.215E-03 1.255E-02 1.642E-02 2.084E-02 2.579E-02 3.128E-02 3.728E-02 4.378E-02 5.076E-02 5.817E-02 6.599E-02 7.418E-02 8.269E-02 9.147E-02 1.005E-01 1.096E-01 1.189E-01 1.281E-01 1.374E-01 1.465E-01 1.554E-01 1.640E-01 1.723E-01 1.802E-01 1.876E-01 1.945E-01 2.007E-01 2.062E-01 2.109E-01 2.148E-01 2.178E-01 2.199E-01 2.210E-01 2.211E-01 2.201E-01 2.182E-01 2.152E-01 2.111E-01 2.060E-01 2.000E-01 1.929E-01 1.850E-01 1.762E-01 1.666E-01 1.563E-01 1.455E-01 1.341E-01 1.224E-01 1.104E-01 9.826E-02 8.618E-02 7.428E-02 6.270E-02 5.161E-02 4.118E-02 3.156E-02 2.292E-02 1.543E-02 9.244E-03 4.519E-03 1.408E-03 4.997E-05 5.789E-04 3.115E-03 7.765E-03 1.462E-02 2.376E-02 3.524E-02 4.909E-02 6.534E-02 8.397E-02 1.050E-01 1.283E-01 1.538E-01 1.814E-01 2.110E-01 2.424E-01 2.755E-01 3.100E-01 3.457E-01 3.822E-01 4.194E-01 4.568E-01 4.941E-01 5.310E-01 5.669E-01 6.014E-01 6.341E-01 6.643E-01 6.915E-01 7.151E-01 7.344E-01 7.487E-01 7.576E-01 7.605E-01 7.576E-01 7.487E-01 7.344E-01 7.151E-01 6.915E-01 6.643E-01 6.341E-01 6.014E-01 5.669E-01 5.310E-01 4.941E-01 4.568E-01 4.194E-01 3.822E-01 3.457E-01 3.100E-01 2.755E-01 2.424E-01 2.110E-01 1.814E-01 1.538E-01 1.283E-01 1.050E-01 8.397E-02 6.534E-02 4.909E-02 3.524E-02 2.376E-02 1.462E-02 7.765E-03 3.115E-03 5.789E-04 4.997E-05 1.408E-03 4.519E-03 9.244E-03 1.543E-02 2.292E-02 3.156E-02 4.118E-02 5.161E-02 6.270E-02 7.428E-02 8.618E-02 9.826E-02 1.104E-01 1.224E-01 1.341E-01 1.455E-01 1.563E-01 1.666E-01 1.762E-01 1.850E-01 1.929E-01 2.000E-01 2.060E-01 2.111E-01 2.152E-01 2.182E-01 2.201E-01 2.211E-01 2.210E-01 2.199E-01 2.178E-01 2.148E-01 2.109E-01 2.062E-01 2.007E-01 1.945E-01 1.876E-01 1.802E-01 1.723E-01 1.640E-01 1.554E-01 1.465E-01 1.374E-01 1.281E-01 1.189E-01 1.096E-01 1.005E-01 9.147E-02 8.269E-02 7.418E-02 6.599E-02 5.817E-02 5.076E-02 4.378E-02 3.728E-02 3.128E-02 2.579E-02 2.084E-02 1.642E-02 1.255E-02 9.215E-03 6.421E-03 4.153E-03 2.399E-03 1.139E-03 3.533E-04 1.718E-05 1.036E-04 5.831E-04 1.424E-03 2.594E-03 4.058E-03 5.780E-03 7.726E-03 9.859E-03 1.214E-02 1.454E-02 1.702E-02 1.955E-02 2.210E-02 2.462E-02 2.710E-02 2.951E-02 3.183E-02 3.402E-02 3.607E-02 3.796E-02 3.967E-02 4.120E-02 4.252E-02 4.364E-02 4.454E-02 4.522E-02 4.569E-02 4.592E-02 4.567E-02 4.519E-02 4.450E-02 4.359E-02 4.246E-02 4.112E-02 3.958E-02 3.786E-02 3.596E-02 3.390E-02 3.170E-02 2.938E-02 2.697E-02 2.448E-02 2.195E-02 1.940E-02 1.688E-02 1.440E-02 1.200E-02 9.726E-03 7.602E-03 5.668E-03 3.959E-03 2.512E-03 1.361E-03 5.414E-04 8.587E-05 2.589E-05 3.908E-04 1.208E-03 2.501E-03 4.291E-03 6.595E-03 9.428E-03 1.280E-02 1.671E-02 2.117E-02 2.617E-02 3.170E-02 3.775E-02 4.429E-02 5.130E-02 5.875E-02 6.661E-02 7.484E-02 8.338E-02 9.218E-02 1.012E-01 1.104E-01 1.196E-01 1.289E-01 1.381E-01 1.472E-01 1.562E-01 1.648E-01 1.731E-01 1.809E-01 1.883E-01 1.951E-01 2.012E-01 2.066E-01 2.113E-01 2.151E-01 2.180E-01 2.200E-01 2.210E-01 2.210E-01 2.200E-01 2.179E-01 2.148E-01 2.106E-01 2.054E-01 1.992E-01 1.920E-01 1.839E-01 1.750E-01 1.653E-01 1.549E-01 1.440E-01 1.325E-01 1.207E-01 1.087E-01 9.651E-02 8.441E-02 7.250E-02 6.095E-02 4.991E-02 3.955E-02 3.005E-02 2.155E-02 1.424E-02 8.276E-03 3.813E-03 1.007E-03 9.434E-07 9.292E-04 3.914E-03 9.066E-03 1.648E-02 2.623E-02 3.837E-02 5.295E-02 6.998E-02 8.946E-02 1.114E-01 1.356E-01 1.622E-01 1.909E-01 2.217E-01 2.543E-01 2.887E-01 3.245E-01 3.616E-01 3.997E-01 4.384E-01 4.775E-01 5.166E-01 5.552E-01 5.931E-01 6.296E-01 6.643E-01 6.967E-01 7.260E-01 7.516E-01 7.728E-01 7.886E-01 7.985E-01 8.019E-01 7.985E-01 7.886E-01 7.728E-01 7.516E-01 7.260E-01 6.967E-01 6.643E-01 6.296E-01 5.931E-01 5.552E-01 5.166E-01 4.775E-01 4.384E-01 3.997E-01 3.616E-01 3.245E-01 2.887E-01 2.543E-01 2.217E-01 1.909E-01 1.622E-01 1.356E-01 1.114E-01 8.946E-02 6.998E-02 5.295E-02 3.837E-02 2.623E-02 1.648E-02 9.066E-03 3.914E-03 9.292E-04 9.434E-07 1.007E-03 3.813E-03 8.276E-03 1.424E-02 2.155E-02 3.005E-02 3.955E-02 4.991E-02 6.095E-02 7.250E-02 8.441E-02 9.651E-02 1.087E-01 1.207E-01 1.325E-01 1.440E-01 1.549E-01 1.653E-01 1.750E-01 1.839E-01 1.920E-01 1.992E-01 2.054E-01 2.106E-01 2.148E-01 2.179E-01 2.200E-01 2.210E-01 2.210E-01 2.200E-01 2.180E-01 2.151E-01 2.113E-01 2.066E-01 2.012E-01 1.951E-01 1.883E-01 1.809E-01 1.731E-01 1.648E-01 1.562E-01 1.472E-01 1.381E-01 1.289E-01 1.196E-01 1.104E-01 1.012E-01 9.218E-02 8.338E-02 7.484E-02 6.661E-02 5.875E-02 5.130E-02 4.429E-02 3.775E-02 3.170E-02 2.617E-02 2.117E-02 1.671E-02 1.280E-02 9.428E-03 6.595E-03 4.291E-03 2.501E-03 1.208E-03 3.908E-04 2.589E-05 8.587E-05 5.414E-04 1.361E-03 2.512E-03 3.959E-03 5.668E-03 7.602E-03 9.726E-03 1.200E-02 1.440E-02 1.688E-02 1.940E-02 2.195E-02 2.448E-02 2.697E-02 2.938E-02 3.170E-02 3.390E-02 3.596E-02 3.786E-02 3.958E-02 4.112E-02 4.246E-02 4.359E-02 4.450E-02 4.519E-02 4.567E-02 4.592E-02 4.565E-02 4.517E-02 4.446E-02 4.354E-02 4.240E-02 4.106E-02 3.951E-02 3.778E-02 3.587E-02 3.380E-02 3.159E-02 2.927E-02 2.685E-02 2.436E-02 2.183E-02 1.928E-02 1.675E-02 1.428E-02 1.189E-02 9.614E-03 7.498E-03 5.573E-03 3.877E-03 2.443E-03 1.309E-03 5.072E-04 7.214E-05 3.466E-05 4.241E-04 1.267E-03 2.589E-03 4.409E-03 6.745E-03 9.611E-03 1.302E-02 1.697E-02 2.146E-02 2.650E-02 3.206E-02 3.814E-02 4.472E-02 5.177E-02 5.925E-02 6.714E-02 7.539E-02 8.396E-02 9.279E-02 1.018E-01 1.110E-01 1.203E-01 1.296E-01 1.388E-01 1.479E-01 1.568E-01 1.654E-01 1.737E-01 1.815E-01 1.889E-01 1.956E-01 2.017E-01 2.071E-01 2.116E-01 2.154E-01 2.182E-01 2.201E-01 2.211E-01 2.210E-01 2.198E-01 2.176E-01 2.144E-01 2.101E-01 2.048E-01 1.985E-01 1.912E-01 1.830E-01 1.740E-01 1.642E-01 1.538E-01 1.427E-01 1.312E-01 1.193E-01 1.072E-01 9.502E-02 8.290E-02 7.100E-02 5.947E-02 4.847E-02 3.819E-02 2.878E-02 2.042E-02 1.326E-02 7.491E-03 3.258E-03 7.180E-04 1.796E-05 1.294E-03 4.670E-03 1.026E-02 1.815E-02 2.843E-02 4.115E-02 5.636E-02 7.408E-02 9.429E-02 1.170E-01 1.421E-01 1.695E-01 1.992E-01 2.310E-01 2.647E-01 3.003E-01 3.373E-01 3.757E-01 4.151E-01 4.552E-01 4.958E-01 5.365E-01 5.768E-01 6.164E-01 6.548E-01 6.915E-01 7.260E-01 7.576E-01 7.854E-01 8.087E-01 8.264E-01 8.376E-01 8.414E-01 8.376E-01 8.264E-01 8.087E-01 7.854E-01 7.576E-01 7.260E-01 6.915E-01 6.548E-01 6.164E-01 5.768E-01 5.365E-01 4.958E-01 4.552E-01 4.151E-01 3.757E-01 3.373E-01 3.003E-01 2.647E-01 2.310E-01 1.992E-01 1.695E-01 1.421E-01 1.170E-01 9.429E-02 7.408E-02 5.636E-02 4.115E-02 2.843E-02 1.815E-02 1.026E-02 4.670E-03 1.294E-03 1.796E-05 7.180E-04 3.258E-03 7.491E-03 1.326E-02 2.042E-02 2.878E-02 3.819E-02 4.847E-02 5.947E-02 7.100E-02 8.290E-02 9.502E-02 1.072E-01 1.193E-01 1.312E-01 1.427E-01 1.538E-01 1.642E-01 1.740E-01 1.830E-01 1.912E-01 1.985E-01 2.048E-01 2.101E-01 2.144E-01 2.176E-01 2.198E-01 2.210E-01 2.211E-01 2.201E-01 2.182E-01 2.154E-01 2.116E-01 2.071E-01 2.017E-01 1.956E-01 1.889E-01 1.815E-01 1.737E-01 1.654E-01 1.568E-01 1.479E-01 1.388E-01 1.296E-01 1.203E-01 1.110E-01 1.018E-01 9.279E-02 8.396E-02 7.539E-02 6.714E-02 5.925E-02 5.177E-02 4.472E-02 3.814E-02 3.206E-02 2.650E-02 2.146E-02 1.697E-02 1.302E-02 9.611E-03 6.745E-03 4.409E-03 2.589E-03 1.267E-03 4.241E-04 3.466E-05 7.214E-05 5.072E-04 1.309E-03 2.443E-03 3.877E-03 5.573E-03 7.498E-03 9.614E-03 1.189E-02 1.428E-02 1.675E-02 1.928E-02 2.183E-02 2.436E-02 2.685E-02 2.927E-02 3.159E-02 3.380E-02 3.587E-02 3.778E-02 3.951E-02 4.106E-02 4.240E-02 4.354E-02 4.446E-02 4.517E-02 4.565E-02 4.591E-02 4.564E-02 4.515E-02 4.443E-02 4.350E-02 4.236E-02 4.100E-02 3.945E-02 3.771E-02 3.579E-02 3.372E-02 3.151E-02 2.918E-02 2.675E-02 2.426E-02 2.172E-02 1.918E-02 1.665E-02 1.418E-02 1.179E-02 9.522E-03 7.413E-03 5.496E-03 3.809E-03 2.388E-03 1.266E-03 4.801E-04 6.178E-05 4.280E-05 4.524E-04 1.317E-03 2.662E-03 4.506E-03 6.869E-03 9.762E-03 1.319E-02 1.717E-02 2.170E-02 2.676E-02 3.236E-02 3.847E-02 4.507E-02 5.215E-02 5.966E-02 6.757E-02 7.585E-02 8.444E-02 9.329E-02 1.023E-01 1.115E-01 1.208E-01 1.301E-01 1.393E-01 1.484E-01 1.573E-01 1.659E-01 1.742E-01 1.820E-01 1.893E-01 1.960E-01 2.021E-01 2.074E-01 2.119E-01 2.156E-01 2.184E-01 2.202E-01 2.211E-01 2.209E-01 2.197E-01 2.174E-01 2.141E-01 2.097E-01 2.043E-01 1.979E-01 1.906E-01 1.823E-01 1.732E-01 1.633E-01 1.528E-01 1.417E-01 1.301E-01 1.182E-01 1.060E-01 9.380E-02 8.167E-02 6.977E-02 5.826E-02 4.731E-02 3.708E-02 2.776E-02 1.950E-02 1.248E-02 6.874E-03 2.832E-03 5.163E-04 7.283E-05 1.640E-03 5.343E-03 1.129E-02 1.959E-02 3.031E-02 4.352E-02 5.926E-02 7.754E-02 9.837E-02 1.217E-01 1.475E-01 1.757E-01 2.062E-01 2.389E-01 2.735E-01 3.100E-01 3.481E-01 3.875E-01 4.281E-01 4.694E-01 5.113E-01 5.533E-01 5.952E-01 6.364E-01 6.765E-01 7.151E-01 7.516E-01 7.854E-01 8.157E-01 8.414E-01 8.615E-01 8.744E-01 8.789E-01 8.744E-01 8.615E-01 8.414E-01 8.157E-01 7.854E-01 7.516E-01 7.151E-01 6.765E-01 6.364E-01 5.952E-01 5.533E-01 5.113E-01 4.694E-01 4.281E-01 3.875E-01 3.481E-01 3.100E-01 2.735E-01 2.389E-01 2.062E-01 1.757E-01 1.475E-01 1.217E-01 9.837E-02 7.754E-02 5.926E-02 4.352E-02 3.031E-02 1.959E-02 1.129E-02 5.343E-03 1.640E-03 7.283E-05 5.163E-04 2.832E-03 6.874E-03 1.248E-02 1.950E-02 2.776E-02 3.708E-02 4.731E-02 5.826E-02 6.977E-02 8.167E-02 9.380E-02 1.060E-01 1.182E-01 1.301E-01 1.417E-01 1.528E-01 1.633E-01 1.732E-01 1.823E-01 1.906E-01 1.979E-01 2.043E-01 2.097E-01 2.141E-01 2.174E-01 2.197E-01 2.209E-01 2.211E-01 2.202E-01 2.184E-01 2.156E-01 2.119E-01 2.074E-01 2.021E-01 1.960E-01 1.893E-01 1.820E-01 1.742E-01 1.659E-01 1.573E-01 1.484E-01 1.393E-01 1.301E-01 1.208E-01 1.115E-01 1.023E-01 9.329E-02 8.444E-02 7.585E-02 6.757E-02 5.966E-02 5.215E-02 4.507E-02 3.847E-02 3.236E-02 2.676E-02 2.170E-02 1.717E-02 1.319E-02 9.762E-03 6.869E-03 4.506E-03 2.662E-03 1.317E-03 4.524E-04 4.280E-05 6.178E-05 4.801E-04 1.266E-03 2.388E-03 3.809E-03 5.496E-03 7.413E-03 9.522E-03 1.179E-02 1.418E-02 1.665E-02 1.918E-02 2.172E-02 2.426E-02 2.675E-02 2.918E-02 3.151E-02 3.372E-02 3.579E-02 3.771E-02 3.945E-02 4.100E-02 4.236E-02 4.350E-02 4.443E-02 4.515E-02 4.564E-02 4.591E-02 4.563E-02 4.513E-02 4.441E-02 4.347E-02 4.232E-02 4.096E-02 3.940E-02 3.765E-02 3.573E-02 3.365E-02 3.144E-02 2.910E-02 2.668E-02 2.418E-02 2.164E-02 1.910E-02 1.657E-02 1.410E-02 1.171E-02 9.451E-03 7.347E-03 5.437E-03 3.758E-03 2.345E-03 1.234E-03 4.594E-04 5.426E-05 4.974E-05 4.751E-04 1.357E-03 2.720E-03 4.583E-03 6.966E-03 9.880E-03 1.333E-02 1.734E-02 2.188E-02 2.697E-02 3.259E-02 3.872E-02 4.535E-02 5.244E-02 5.998E-02 6.791E-02 7.621E-02 8.481E-02 9.367E-02 1.027E-01 1.120E-01 1.212E-01 1.305E-01 1.398E-01 1.489E-01 1.578E-01 1.663E-01 1.746E-01 1.824E-01 1.897E-01 1.963E-01 2.024E-01 2.077E-01 2.121E-01 2.158E-01 2.185E-01 2.203E-01 2.211E-01 2.209E-01 2.196E-01 2.173E-01 2.139E-01 2.094E-01 2.040E-01 1.975E-01 1.901E-01 1.817E-01 1.726E-01 1.626E-01 1.520E-01 1.408E-01 1.292E-01 1.173E-01 1.051E-01 9.285E-02 8.071E-02 6.881E-02 5.732E-02 4.640E-02 3.623E-02 2.697E-02 1.880E-02 1.189E-02 6.409E-03 2.520E-03 3.816E-04 1.415E-04 1.939E-03 5.901E-03 1.214E-02 2.076E-02 3.183E-02 4.542E-02 6.158E-02 8.031E-02 1.016E-01 1.255E-01 1.519E-01 1.807E-01 2.118E-01 2.451E-01 2.805E-01 3.178E-01 3.566E-01 3.970E-01 4.384E-01 4.808E-01 5.237E-01 5.669E-01 6.099E-01 6.525E-01 6.941E-01 7.344E-01 7.728E-01 8.087E-01 8.414E-01 8.700E-01 8.930E-01 9.083E-01 9.138E-01 9.083E-01 8.930E-01 8.700E-01 8.414E-01 8.087E-01 7.728E-01 7.344E-01 6.941E-01 6.525E-01 6.099E-01 5.669E-01 5.237E-01 4.808E-01 4.384E-01 3.970E-01 3.566E-01 3.178E-01 2.805E-01 2.451E-01 2.118E-01 1.807E-01 1.519E-01 1.255E-01 1.016E-01 8.031E-02 6.158E-02 4.542E-02 3.183E-02 2.076E-02 1.214E-02 5.901E-03 1.939E-03 1.415E-04 3.816E-04 2.520E-03 6.409E-03 1.189E-02 1.880E-02 2.697E-02 3.623E-02 4.640E-02 5.732E-02 6.881E-02 8.071E-02 9.285E-02 1.051E-01 1.173E-01 1.292E-01 1.408E-01 1.520E-01 1.626E-01 1.726E-01 1.817E-01 1.901E-01 1.975E-01 2.040E-01 2.094E-01 2.139E-01 2.173E-01 2.196E-01 2.209E-01 2.211E-01 2.203E-01 2.185E-01 2.158E-01 2.121E-01 2.077E-01 2.024E-01 1.963E-01 1.897E-01 1.824E-01 1.746E-01 1.663E-01 1.578E-01 1.489E-01 1.398E-01 1.305E-01 1.212E-01 1.120E-01 1.027E-01 9.367E-02 8.481E-02 7.621E-02 6.791E-02 5.998E-02 5.244E-02 4.535E-02 3.872E-02 3.259E-02 2.697E-02 2.188E-02 1.734E-02 1.333E-02 9.880E-03 6.966E-03 4.583E-03 2.720E-03 1.357E-03 4.751E-04 4.974E-05 5.426E-05 4.594E-04 1.234E-03 2.345E-03 3.758E-03 5.437E-03 7.347E-03 9.451E-03 1.171E-02 1.410E-02 1.657E-02 1.910E-02 2.164E-02 2.418E-02 2.668E-02 2.910E-02 3.144E-02 3.365E-02 3.573E-02 3.765E-02 3.940E-02 4.096E-02 4.232E-02 4.347E-02 4.441E-02 4.513E-02 4.563E-02 4.590E-02 4.562E-02 4.512E-02 4.439E-02 4.345E-02 4.230E-02 4.093E-02 3.937E-02 3.762E-02 3.569E-02 3.361E-02 3.139E-02 2.905E-02 2.662E-02 2.413E-02 2.159E-02 1.904E-02 1.652E-02 1.404E-02 1.166E-02 9.401E-03 7.300E-03 5.395E-03 3.721E-03 2.314E-03 1.211E-03 4.450E-04 4.919E-05 5.502E-05 4.916E-04 1.386E-03 2.761E-03 4.639E-03 7.036E-03 9.965E-03 1.344E-02 1.745E-02 2.201E-02 2.712E-02 3.275E-02 3.890E-02 4.554E-02 5.266E-02 6.021E-02 6.815E-02 7.646E-02 8.508E-02 9.395E-02 1.030E-01 1.122E-01 1.215E-01 1.308E-01 1.401E-01 1.492E-01 1.580E-01 1.666E-01 1.749E-01 1.826E-01 1.899E-01 1.966E-01 2.026E-01 2.078E-01 2.123E-01 2.159E-01 2.186E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.137E-01 2.092E-01 2.037E-01 1.972E-01 1.897E-01 1.813E-01 1.721E-01 1.621E-01 1.515E-01 1.403E-01 1.286E-01 1.166E-01 1.044E-01 9.218E-02 8.003E-02 6.813E-02 5.665E-02 4.576E-02 3.562E-02 2.641E-02 1.830E-02 1.147E-02 6.085E-03 2.307E-03 2.974E-04 2.048E-04 2.169E-03 6.319E-03 1.277E-02 2.162E-02 3.294E-02 4.681E-02 6.327E-02 8.233E-02 1.040E-01 1.283E-01 1.550E-01 1.843E-01 2.159E-01 2.497E-01 2.856E-01 3.234E-01 3.629E-01 4.038E-01 4.460E-01 4.891E-01 5.328E-01 5.768E-01 6.208E-01 6.643E-01 7.071E-01 7.487E-01 7.886E-01 8.264E-01 8.615E-01 8.930E-01 9.195E-01 9.386E-01 9.458E-01 9.386E-01 9.195E-01 8.930E-01 8.615E-01 8.264E-01 7.886E-01 7.487E-01 7.071E-01 6.643E-01 6.208E-01 5.768E-01 5.328E-01 4.891E-01 4.460E-01 4.038E-01 3.629E-01 3.234E-01 2.856E-01 2.497E-01 2.159E-01 1.843E-01 1.550E-01 1.283E-01 1.040E-01 8.233E-02 6.327E-02 4.681E-02 3.294E-02 2.162E-02 1.277E-02 6.319E-03 2.169E-03 2.048E-04 2.974E-04 2.307E-03 6.085E-03 1.147E-02 1.830E-02 2.641E-02 3.562E-02 4.576E-02 5.665E-02 6.813E-02 8.003E-02 9.218E-02 1.044E-01 1.166E-01 1.286E-01 1.403E-01 1.515E-01 1.621E-01 1.721E-01 1.813E-01 1.897E-01 1.972E-01 2.037E-01 2.092E-01 2.137E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.186E-01 2.159E-01 2.123E-01 2.078E-01 2.026E-01 1.966E-01 1.899E-01 1.826E-01 1.749E-01 1.666E-01 1.580E-01 1.492E-01 1.401E-01 1.308E-01 1.215E-01 1.122E-01 1.030E-01 9.395E-02 8.508E-02 7.646E-02 6.815E-02 6.021E-02 5.266E-02 4.554E-02 3.890E-02 3.275E-02 2.712E-02 2.201E-02 1.745E-02 1.344E-02 9.965E-03 7.036E-03 4.639E-03 2.761E-03 1.386E-03 4.916E-04 5.502E-05 4.919E-05 4.450E-04 1.211E-03 2.314E-03 3.721E-03 5.395E-03 7.300E-03 9.401E-03 1.166E-02 1.404E-02 1.652E-02 1.904E-02 2.159E-02 2.413E-02 2.662E-02 2.905E-02 3.139E-02 3.361E-02 3.569E-02 3.762E-02 3.937E-02 4.093E-02 4.230E-02 4.345E-02 4.439E-02 4.512E-02 4.562E-02 4.590E-02 4.562E-02 4.511E-02 4.438E-02 4.344E-02 4.228E-02 4.091E-02 3.935E-02 3.759E-02 3.567E-02 3.358E-02 3.136E-02 2.902E-02 2.659E-02 2.409E-02 2.155E-02 1.901E-02 1.648E-02 1.401E-02 1.163E-02 9.370E-03 7.272E-03 5.369E-03 3.699E-03 2.296E-03 1.197E-03 4.364E-04 4.626E-05 5.831E-05 5.017E-04 1.403E-03 2.786E-03 4.672E-03 7.078E-03 1.002E-02 1.350E-02 1.752E-02 2.209E-02 2.721E-02 3.285E-02 3.901E-02 4.566E-02 5.279E-02 6.034E-02 6.830E-02 7.661E-02 8.524E-02 9.412E-02 1.032E-01 1.124E-01 1.217E-01 1.310E-01 1.402E-01 1.493E-01 1.582E-01 1.668E-01 1.750E-01 1.828E-01 1.901E-01 1.967E-01 2.027E-01 2.079E-01 2.124E-01 2.160E-01 2.187E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.136E-01 2.091E-01 2.035E-01 1.970E-01 1.895E-01 1.811E-01 1.718E-01 1.618E-01 1.511E-01 1.399E-01 1.282E-01 1.162E-01 1.040E-01 9.177E-02 7.962E-02 6.772E-02 5.625E-02 4.537E-02 3.526E-02 2.608E-02 1.801E-02 1.122E-02 5.894E-03 2.184E-03 2.518E-04 2.485E-04 2.314E-03 6.577E-03 1.315E-02 2.214E-02 3.362E-02 4.766E-02 6.430E-02 8.356E-02 1.054E-01 1.299E-01 1.570E-01 1.865E-01 2.183E-01 2.525E-01 2.887E-01 3.268E-01 3.667E-01 4.080E-01 4.506E-01 4.941E-01 5.383E-01 5.828E-01 6.274E-01 6.716E-01 7.151E-01 7.576E-01 7.985E-01 8.376E-01 8.744E-01 9.083E-01 9.386E-01 9.632E-01 9.747E-01 9.632E-01 9.386E-01 9.083E-01 8.744E-01 8.376E-01 7.985E-01 7.576E-01 7.151E-01 6.716E-01 6.274E-01 5.828E-01 5.383E-01 4.941E-01 4.506E-01 4.080E-01 3.667E-01 3.268E-01 2.887E-01 2.525E-01 2.183E-01 1.865E-01 1.570E-01 1.299E-01 1.054E-01 8.356E-02 6.430E-02 4.766E-02 3.362E-02 2.214E-02 1.315E-02 6.577E-03 2.314E-03 2.485E-04 2.518E-04 2.184E-03 5.894E-03 1.122E-02 1.801E-02 2.608E-02 3.526E-02 4.537E-02 5.625E-02 6.772E-02 7.962E-02 9.177E-02 1.040E-01 1.162E-01 1.282E-01 1.399E-01 1.511E-01 1.618E-01 1.718E-01 1.811E-01 1.895E-01 1.970E-01 2.035E-01 2.091E-01 2.136E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.187E-01 2.160E-01 2.124E-01 2.079E-01 2.027E-01 1.967E-01 1.901E-01 1.828E-01 1.750E-01 1.668E-01 1.582E-01 1.493E-01 1.402E-01 1.310E-01 1.217E-01 1.124E-01 1.032E-01 9.412E-02 8.524E-02 7.661E-02 6.830E-02 6.034E-02 5.279E-02 4.566E-02 3.901E-02 3.285E-02 2.721E-02 2.209E-02 1.752E-02 1.350E-02 1.002E-02 7.078E-03 4.672E-03 2.786E-03 1.403E-03 5.017E-04 5.831E-05 4.626E-05 4.364E-04 1.197E-03 2.296E-03 3.699E-03 5.369E-03 7.272E-03 9.370E-03 1.163E-02 1.401E-02 1.648E-02 1.901E-02 2.155E-02 2.409E-02 2.659E-02 2.902E-02 3.136E-02 3.358E-02 3.567E-02 3.759E-02 3.935E-02 4.091E-02 4.228E-02 4.344E-02 4.438E-02 4.511E-02 4.562E-02 4.590E-02 4.561E-02 4.511E-02 4.438E-02 4.343E-02 4.227E-02 4.091E-02 3.934E-02 3.758E-02 3.566E-02 3.357E-02 3.135E-02 2.901E-02 2.658E-02 2.408E-02 2.154E-02 1.900E-02 1.647E-02 1.400E-02 1.162E-02 9.360E-03 7.262E-03 5.361E-03 3.691E-03 2.290E-03 1.193E-03 4.335E-04 4.531E-05 5.944E-05 5.051E-04 1.409E-03 2.795E-03 4.683E-03 7.092E-03 1.003E-02 1.352E-02 1.755E-02 2.212E-02 2.724E-02 3.288E-02 3.905E-02 4.570E-02 5.283E-02 6.039E-02 6.835E-02 7.666E-02 8.529E-02 9.417E-02 1.033E-01 1.125E-01 1.218E-01 1.311E-01 1.403E-01 1.494E-01 1.583E-01 1.669E-01 1.751E-01 1.829E-01 1.901E-01 1.968E-01 2.027E-01 2.080E-01 2.124E-01 2.160E-01 2.187E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.136E-01 2.090E-01 2.035E-01 1.969E-01 1.894E-01 1.810E-01 1.717E-01 1.617E-01 1.510E-01 1.398E-01 1.281E-01 1.161E-01 1.039E-01 9.163E-02 7.948E-02 6.759E-02 5.612E-02 4.524E-02 3.513E-02 2.597E-02 1.791E-02 1.114E-02 5.831E-03 2.143E-03 2.374E-04 2.640E-04 2.364E-03 6.665E-03 1.328E-02 2.232E-02 3.385E-02 4.794E-02 6.465E-02 8.397E-02 1.059E-01 1.305E-01 1.576E-01 1.872E-01 2.192E-01 2.534E-01 2.897E-01 3.280E-01 3.680E-01 4.094E-01 4.521E-01 4.958E-01 5.402E-01 5.849E-01 6.296E-01 6.740E-01 7.178E-01 7.605E-01 8.019E-01 8.414E-01 8.789E-01 9.138E-01 9.458E-01 9.747E-01 1.000E+00 9.747E-01 9.458E-01 9.138E-01 8.789E-01 8.414E-01 8.019E-01 7.605E-01 7.178E-01 6.740E-01 6.296E-01 5.849E-01 5.402E-01 4.958E-01 4.521E-01 4.094E-01 3.680E-01 3.280E-01 2.897E-01 2.534E-01 2.192E-01 1.872E-01 1.576E-01 1.305E-01 1.059E-01 8.397E-02 6.465E-02 4.794E-02 3.385E-02 2.232E-02 1.328E-02 6.665E-03 2.364E-03 2.640E-04 2.374E-04 2.143E-03 5.831E-03 1.114E-02 1.791E-02 2.597E-02 3.513E-02 4.524E-02 5.612E-02 6.759E-02 7.948E-02 9.163E-02 1.039E-01 1.161E-01 1.281E-01 1.398E-01 1.510E-01 1.617E-01 1.717E-01 1.810E-01 1.894E-01 1.969E-01 2.035E-01 2.090E-01 2.136E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.187E-01 2.160E-01 2.124E-01 2.080E-01 2.027E-01 1.968E-01 1.901E-01 1.829E-01 1.751E-01 1.669E-01 1.583E-01 1.494E-01 1.403E-01 1.311E-01 1.218E-01 1.125E-01 1.033E-01 9.417E-02 8.529E-02 7.666E-02 6.835E-02 6.039E-02 5.283E-02 4.570E-02 3.905E-02 3.288E-02 2.724E-02 2.212E-02 1.755E-02 1.352E-02 1.003E-02 7.092E-03 4.683E-03 2.795E-03 1.409E-03 5.051E-04 5.944E-05 4.531E-05 4.335E-04 1.193E-03 2.290E-03 3.691E-03 5.361E-03 7.262E-03 9.360E-03 1.162E-02 1.400E-02 1.647E-02 1.900E-02 2.154E-02 2.408E-02 2.658E-02 2.901E-02 3.135E-02 3.357E-02 3.566E-02 3.758E-02 3.934E-02 4.091E-02 4.227E-02 4.343E-02 4.438E-02 4.511E-02 4.561E-02 4.590E-02 4.562E-02 4.511E-02 4.438E-02 4.344E-02 4.228E-02 4.091E-02 3.935E-02 3.759E-02 3.567E-02 3.358E-02 3.136E-02 2.902E-02 2.659E-02 2.409E-02 2.155E-02 1.901E-02 1.648E-02 1.401E-02 1.163E-02 9.370E-03 7.272E-03 5.369E-03 3.699E-03 2.296E-03 1.197E-03 4.364E-04 4.626E-05 5.831E-05 5.017E-04 1.403E-03 2.786E-03 4.672E-03 7.078E-03 1.002E-02 1.350E-02 1.752E-02 2.209E-02 2.721E-02 3.285E-02 3.901E-02 4.566E-02 5.279E-02 6.034E-02 6.830E-02 7.661E-02 8.524E-02 9.412E-02 1.032E-01 1.124E-01 1.217E-01 1.310E-01 1.402E-01 1.493E-01 1.582E-01 1.668E-01 1.750E-01 1.828E-01 1.901E-01 1.967E-01 2.027E-01 2.079E-01 2.124E-01 2.160E-01 2.187E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.136E-01 2.091E-01 2.035E-01 1.970E-01 1.895E-01 1.811E-01 1.718E-01 1.618E-01 1.511E-01 1.399E-01 1.282E-01 1.162E-01 1.040E-01 9.177E-02 7.962E-02 6.772E-02 5.625E-02 4.537E-02 3.526E-02 2.608E-02 1.801E-02 1.122E-02 5.894E-03 2.184E-03 2.518E-04 2.485E-04 2.314E-03 6.577E-03 1.315E-02 2.214E-02 3.362E-02 4.766E-02 6.430E-02 8.356E-02 1.054E-01 1.299E-01 1.570E-01 1.865E-01 2.183E-01 2.525E-01 2.887E-01 3.268E-01 3.667E-01 4.080E-01 4.506E-01 4.941E-01 5.383E-01 5.828E-01 6.274E-01 6.716E-01 7.151E-01 7.576E-01 7.985E-01 8.376E-01 8.744E-01 9.083E-01 9.386E-01 9.632E-01 9.747E-01 9.632E-01 9.386E-01 9.083E-01 8.744E-01 8.376E-01 7.985E-01 7.576E-01 7.151E-01 6.716E-01 6.274E-01 5.828E-01 5.383E-01 4.941E-01 4.506E-01 4.080E-01 3.667E-01 3.268E-01 2.887E-01 2.525E-01 2.183E-01 1.865E-01 1.570E-01 1.299E-01 1.054E-01 8.356E-02 6.430E-02 4.766E-02 3.362E-02 2.214E-02 1.315E-02 6.577E-03 2.314E-03 2.485E-04 2.518E-04 2.184E-03 5.894E-03 1.122E-02 1.801E-02 2.608E-02 3.526E-02 4.537E-02 5.625E-02 6.772E-02 7.962E-02 9.177E-02 1.040E-01 1.162E-01 1.282E-01 1.399E-01 1.511E-01 1.618E-01 1.718E-01 1.811E-01 1.895E-01 1.970E-01 2.035E-01 2.091E-01 2.136E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.187E-01 2.160E-01 2.124E-01 2.079E-01 2.027E-01 1.967E-01 1.901E-01 1.828E-01 1.750E-01 1.668E-01 1.582E-01 1.493E-01 1.402E-01 1.310E-01 1.217E-01 1.124E-01 1.032E-01 9.412E-02 8.524E-02 7.661E-02 6.830E-02 6.034E-02 5.279E-02 4.566E-02 3.901E-02 3.285E-02 2.721E-02 2.209E-02 1.752E-02 1.350E-02 1.002E-02 7.078E-03 4.672E-03 2.786E-03 1.403E-03 5.017E-04 5.831E-05 4.626E-05 4.364E-04 1.197E-03 2.296E-03 3.699E-03 5.369E-03 7.272E-03 9.370E-03 1.163E-02 1.401E-02 1.648E-02 1.901E-02 2.155E-02 2.409E-02 2.659E-02 2.902E-02 3.136E-02 3.358E-02 3.567E-02 3.759E-02 3.935E-02 4.091E-02 4.228E-02 4.344E-02 4.438E-02 4.511E-02 4.562E-02 4.590E-02 4.562E-02 4.512E-02 4.439E-02 4.345E-02 4.230E-02 4.093E-02 3.937E-02 3.762E-02 3.569E-02 3.361E-02 3.139E-02 2.905E-02 2.662E-02 2.413E-02 2.159E-02 1.904E-02 1.652E-02 1.404E-02 1.166E-02 9.401E-03 7.300E-03 5.395E-03 3.721E-03 2.314E-03 1.211E-03 4.450E-04 4.919E-05 5.502E-05 4.916E-04 1.386E-03 2.761E-03 4.639E-03 7.036E-03 9.965E-03 1.344E-02 1.745E-02 2.201E-02 2.712E-02 3.275E-02 3.890E-02 4.554E-02 5.266E-02 6.021E-02 6.815E-02 7.646E-02 8.508E-02 9.395E-02 1.030E-01 1.122E-01 1.215E-01 1.308E-01 1.401E-01 1.492E-01 1.580E-01 1.666E-01 1.749E-01 1.826E-01 1.899E-01 1.966E-01 2.026E-01 2.078E-01 2.123E-01 2.159E-01 2.186E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.137E-01 2.092E-01 2.037E-01 1.972E-01 1.897E-01 1.813E-01 1.721E-01 1.621E-01 1.515E-01 1.403E-01 1.286E-01 1.166E-01 1.044E-01 9.218E-02 8.003E-02 6.813E-02 5.665E-02 4.576E-02 3.562E-02 2.641E-02 1.830E-02 1.147E-02 6.085E-03 2.307E-03 2.974E-04 2.048E-04 2.169E-03 6.319E-03 1.277E-02 2.162E-02 3.294E-02 4.681E-02 6.327E-02 8.233E-02 1.040E-01 1.283E-01 1.550E-01 1.843E-01 2.159E-01 2.497E-01 2.856E-01 3.234E-01 3.629E-01 4.038E-01 4.460E-01 4.891E-01 5.328E-01 5.768E-01 6.208E-01 6.643E-01 7.071E-01 7.487E-01 7.886E-01 8.264E-01 8.615E-01 8.930E-01 9.195E-01 9.386E-01 9.458E-01 9.386E-01 9.195E-01 8.930E-01 8.615E-01 8.264E-01 7.886E-01 7.487E-01 7.071E-01 6.643E-01 6.208E-01 5.768E-01 5.328E-01 4.891E-01 4.460E-01 4.038E-01 3.629E-01 3.234E-01 2.856E-01 2.497E-01 2.159E-01 1.843E-01 1.550E-01 1.283E-01 1.040E-01 8.233E-02 6.327E-02 4.681E-02 3.294E-02 2.162E-02 1.277E-02 6.319E-03 2.169E-03 2.048E-04 2.974E-04 2.307E-03 6.085E-03 1.147E-02 1.830E-02 2.641E-02 3.562E-02 4.576E-02 5.665E-02 6.813E-02 8.003E-02 9.218E-02 1.044E-01 1.166E-01 1.286E-01 1.403E-01 1.515E-01 1.621E-01 1.721E-01 1.813E-01 1.897E-01 1.972E-01 2.037E-01 2.092E-01 2.137E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.186E-01 2.159E-01 2.123E-01 2.078E-01 2.026E-01 1.966E-01 1.899E-01 1.826E-01 1.749E-01 1.666E-01 1.580E-01 1.492E-01 1.401E-01 1.308E-01 1.215E-01 1.122E-01 1.030E-01 9.395E-02 8.508E-02 7.646E-02 6.815E-02 6.021E-02 5.266E-02 4.554E-02 3.890E-02 3.275E-02 2.712E-02 2.201E-02 1.745E-02 1.344E-02 9.965E-03 7.036E-03 4.639E-03 2.761E-03 1.386E-03 4.916E-04 5.502E-05 4.919E-05 4.450E-04 1.211E-03 2.314E-03 3.721E-03 5.395E-03 7.300E-03 9.401E-03 1.166E-02 1.404E-02 1.652E-02 1.904E-02 2.159E-02 2.413E-02 2.662E-02 2.905E-02 3.139E-02 3.361E-02 3.569E-02 3.762E-02 3.937E-02 4.093E-02 4.230E-02 4.345E-02 4.439E-02 4.512E-02 4.562E-02 4.591E-02 4.563E-02 4.513E-02 4.441E-02 4.347E-02 4.232E-02 4.096E-02 3.940E-02 3.765E-02 3.573E-02 3.365E-02 3.144E-02 2.910E-02 2.668E-02 2.418E-02 2.164E-02 1.910E-02 1.657E-02 1.410E-02 1.171E-02 9.451E-03 7.347E-03 5.437E-03 3.758E-03 2.345E-03 1.234E-03 4.594E-04 5.426E-05 4.974E-05 4.751E-04 1.357E-03 2.720E-03 4.583E-03 6.966E-03 9.880E-03 1.333E-02 1.734E-02 2.188E-02 2.697E-02 3.259E-02 3.872E-02 4.535E-02 5.244E-02 5.998E-02 6.791E-02 7.621E-02 8.481E-02 9.367E-02 1.027E-01 1.120E-01 1.212E-01 1.305E-01 1.398E-01 1.489E-01 1.578E-01 1.663E-01 1.746E-01 1.824E-01 1.897E-01 1.963E-01 2.024E-01 2.077E-01 2.121E-01 2.158E-01 2.185E-01 2.203E-01 2.211E-01 2.209E-01 2.196E-01 2.173E-01 2.139E-01 2.094E-01 2.040E-01 1.975E-01 1.901E-01 1.817E-01 1.726E-01 1.626E-01 1.520E-01 1.408E-01 1.292E-01 1.173E-01 1.051E-01 9.285E-02 8.071E-02 6.881E-02 5.732E-02 4.640E-02 3.623E-02 2.697E-02 1.880E-02 1.189E-02 6.409E-03 2.520E-03 3.816E-04 1.415E-04 1.939E-03 5.901E-03 1.214E-02 2.076E-02 3.183E-02 4.542E-02 6.158E-02 8.031E-02 1.016E-01 1.255E-01 1.519E-01 1.807E-01 2.118E-01 2.451E-01 2.805E-01 3.178E-01 3.566E-01 3.970E-01 4.384E-01 4.808E-01 5.237E-01 5.669E-01 6.099E-01 6.525E-01 6.941E-01 7.344E-01 7.728E-01 8.087E-01 8.414E-01 8.700E-01 8.930E-01 9.083E-01 9.138E-01 9.083E-01 8.930E-01 8.700E-01 8.414E-01 8.087E-01 7.728E-01 7.344E-01 6.941E-01 6.525E-01 6.099E-01 5.669E-01 5.237E-01 4.808E-01 4.384E-01 3.970E-01 3.566E-01 3.178E-01 2.805E-01 2.451E-01 2.118E-01 1.807E-01 1.519E-01 1.255E-01 1.016E-01 8.031E-02 6.158E-02 4.542E-02 3.183E-02 2.076E-02 1.214E-02 5.901E-03 1.939E-03 1.415E-04 3.816E-04 2.520E-03 6.409E-03 1.189E-02 1.880E-02 2.697E-02 3.623E-02 4.640E-02 5.732E-02 6.881E-02 8.071E-02 9.285E-02 1.051E-01 1.173E-01 1.292E-01 1.408E-01 1.520E-01 1.626E-01 1.726E-01 1.817E-01 1.901E-01 1.975E-01 2.040E-01 2.094E-01 2.139E-01 2.173E-01 2.196E-01 2.209E-01 2.211E-01 2.203E-01 2.185E-01 2.158E-01 2.121E-01 2.077E-01 2.024E-01 1.963E-01 1.897E-01 1.824E-01 1.746E-01 1.663E-01 1.578E-01 1.489E-01 1.398E-01 1.305E-01 1.212E-01 1.120E-01 1.027E-01 9.367E-02 8.481E-02 7.621E-02 6.791E-02 5.998E-02 5.244E-02 4.535E-02 3.872E-02 3.259E-02 2.697E-02 2.188E-02 1.734E-02 1.333E-02 9.880E-03 6.966E-03 4.583E-03 2.720E-03 1.357E-03 4.751E-04 4.974E-05 5.426E-05 4.594E-04 1.234E-03 2.345E-03 3.758E-03 5.437E-03 7.347E-03 9.451E-03 1.171E-02 1.410E-02 1.657E-02 1.910E-02 2.164E-02 2.418E-02 2.668E-02 2.910E-02 3.144E-02 3.365E-02 3.573E-02 3.765E-02 3.940E-02 4.096E-02 4.232E-02 4.347E-02 4.441E-02 4.513E-02 4.563E-02 4.591E-02 4.564E-02 4.515E-02 4.443E-02 4.350E-02 4.236E-02 4.100E-02 3.945E-02 3.771E-02 3.579E-02 3.372E-02 3.151E-02 2.918E-02 2.675E-02 2.426E-02 2.172E-02 1.918E-02 1.665E-02 1.418E-02 1.179E-02 9.522E-03 7.413E-03 5.496E-03 3.809E-03 2.388E-03 1.266E-03 4.801E-04 6.178E-05 4.280E-05 4.524E-04 1.317E-03 2.662E-03 4.506E-03 6.869E-03 9.762E-03 1.319E-02 1.717E-02 2.170E-02 2.676E-02 3.236E-02 3.847E-02 4.507E-02 5.215E-02 5.966E-02 6.757E-02 7.585E-02 8.444E-02 9.329E-02 1.023E-01 1.115E-01 1.208E-01 1.301E-01 1.393E-01 1.484E-01 1.573E-01 1.659E-01 1.742E-01 1.820E-01 1.893E-01 1.960E-01 2.021E-01 2.074E-01 2.119E-01 2.156E-01 2.184E-01 2.202E-01 2.211E-01 2.209E-01 2.197E-01 2.174E-01 2.141E-01 2.097E-01 2.043E-01 1.979E-01 1.906E-01 1.823E-01 1.732E-01 1.633E-01 1.528E-01 1.417E-01 1.301E-01 1.182E-01 1.060E-01 9.380E-02 8.167E-02 6.977E-02 5.826E-02 4.731E-02 3.708E-02 2.776E-02 1.950E-02 1.248E-02 6.874E-03 2.832E-03 5.163E-04 7.283E-05 1.640E-03 5.343E-03 1.129E-02 1.959E-02 3.031E-02 4.352E-02 5.926E-02 7.754E-02 9.837E-02 1.217E-01 1.475E-01 1.757E-01 2.062E-01 2.389E-01 2.735E-01 3.100E-01 3.481E-01 3.875E-01 4.281E-01 4.694E-01 5.113E-01 5.533E-01 5.952E-01 6.364E-01 6.765E-01 7.151E-01 7.516E-01 7.854E-01 8.157E-01 8.414E-01 8.615E-01 8.744E-01 8.789E-01 8.744E-01 8.615E-01 8.414E-01 8.157E-01 7.854E-01 7.516E-01 7.151E-01 6.765E-01 6.364E-01 5.952E-01 5.533E-01 5.113E-01 4.694E-01 4.281E-01 3.875E-01 3.481E-01 3.100E-01 2.735E-01 2.389E-01 2.062E-01 1.757E-01 1.475E-01 1.217E-01 9.837E-02 7.754E-02 5.926E-02 4.352E-02 3.031E-02 1.959E-02 1.129E-02 5.343E-03 1.640E-03 7.283E-05 5.163E-04 2.832E-03 6.874E-03 1.248E-02 1.950E-02 2.776E-02 3.708E-02 4.731E-02 5.826E-02 6.977E-02 8.167E-02 9.380E-02 1.060E-01 1.182E-01 1.301E-01 1.417E-01 1.528E-01 1.633E-01 1.732E-01 1.823E-01 1.906E-01 1.979E-01 2.043E-01 2.097E-01 2.141E-01 2.174E-01 2.197E-01 2.209E-01 2.211E-01 2.202E-01 2.184E-01 2.156E-01 2.119E-01 2.074E-01 2.021E-01 1.960E-01 1.893E-01 1.820E-01 1.742E-01 1.659E-01 1.573E-01 1.484E-01 1.393E-01 1.301E-01 1.208E-01 1.115E-01 1.023E-01 9.329E-02 8.444E-02 7.585E-02 6.757E-02 5.966E-02 5.215E-02 4.507E-02 3.847E-02 3.236E-02 2.676E-02 2.170E-02 1.717E-02 1.319E-02 9.762E-03 6.869E-03 4.506E-03 2.662E-03 1.317E-03 4.524E-04 4.280E-05 6.178E-05 4.801E-04 1.266E-03 2.388E-03 3.809E-03 5.496E-03 7.413E-03 9.522E-03 1.179E-02 1.418E-02 1.665E-02 1.918E-02 2.172E-02 2.426E-02 2.675E-02 2.918E-02 3.151E-02 3.372E-02 3.579E-02 3.771E-02 3.945E-02 4.100E-02 4.236E-02 4.350E-02 4.443E-02 4.515E-02 4.564E-02 4.592E-02 4.565E-02 4.517E-02 4.446E-02 4.354E-02 4.240E-02 4.106E-02 3.951E-02 3.778E-02 3.587E-02 3.380E-02 3.159E-02 2.927E-02 2.685E-02 2.436E-02 2.183E-02 1.928E-02 1.675E-02 1.428E-02 1.189E-02 9.614E-03 7.498E-03 5.573E-03 3.877E-03 2.443E-03 1.309E-03 5.072E-04 7.214E-05 3.466E-05 4.241E-04 1.267E-03 2.589E-03 4.409E-03 6.745E-03 9.611E-03 1.302E-02 1.697E-02 2.146E-02 2.650E-02 3.206E-02 3.814E-02 4.472E-02 5.177E-02 5.925E-02 6.714E-02 7.539E-02 8.396E-02 9.279E-02 1.018E-01 1.110E-01 1.203E-01 1.296E-01 1.388E-01 1.479E-01 1.568E-01 1.654E-01 1.737E-01 1.815E-01 1.889E-01 1.956E-01 2.017E-01 2.071E-01 2.116E-01 2.154E-01 2.182E-01 2.201E-01 2.211E-01 2.210E-01 2.198E-01 2.176E-01 2.144E-01 2.101E-01 2.048E-01 1.985E-01 1.912E-01 1.830E-01 1.740E-01 1.642E-01 1.538E-01 1.427E-01 1.312E-01 1.193E-01 1.072E-01 9.502E-02 8.290E-02 7.100E-02 5.947E-02 4.847E-02 3.819E-02 2.878E-02 2.042E-02 1.326E-02 7.491E-03 3.258E-03 7.180E-04 1.796E-05 1.294E-03 4.670E-03 1.026E-02 1.815E-02 2.843E-02 4.115E-02 5.636E-02 7.408E-02 9.429E-02 1.170E-01 1.421E-01 1.695E-01 1.992E-01 2.310E-01 2.647E-01 3.003E-01 3.373E-01 3.757E-01 4.151E-01 4.552E-01 4.958E-01 5.365E-01 5.768E-01 6.164E-01 6.548E-01 6.915E-01 7.260E-01 7.576E-01 7.854E-01 8.087E-01 8.264E-01 8.376E-01 8.414E-01 8.376E-01 8.264E-01 8.087E-01 7.854E-01 7.576E-01 7.260E-01 6.915E-01 6.548E-01 6.164E-01 5.768E-01 5.365E-01 4.958E-01 4.552E-01 4.151E-01 3.757E-01 3.373E-01 3.003E-01 2.647E-01 2.310E-01 1.992E-01 1.695E-01 1.421E-01 1.170E-01 9.429E-02 7.408E-02 5.636E-02 4.115E-02 2.843E-02 1.815E-02 1.026E-02 4.670E-03 1.294E-03 1.796E-05 7.180E-04 3.258E-03 7.491E-03 1.326E-02 2.042E-02 2.878E-02 3.819E-02 4.847E-02 5.947E-02 7.100E-02 8.290E-02 9.502E-02 1.072E-01 1.193E-01 1.312E-01 1.427E-01 1.538E-01 1.642E-01 1.740E-01 1.830E-01 1.912E-01 1.985E-01 2.048E-01 2.101E-01 2.144E-01 2.176E-01 2.198E-01 2.210E-01 2.211E-01 2.201E-01 2.182E-01 2.154E-01 2.116E-01 2.071E-01 2.017E-01 1.956E-01 1.889E-01 1.815E-01 1.737E-01 1.654E-01 1.568E-01 1.479E-01 1.388E-01 1.296E-01 1.203E-01 1.110E-01 1.018E-01 9.279E-02 8.396E-02 7.539E-02 6.714E-02 5.925E-02 5.177E-02 4.472E-02 3.814E-02 3.206E-02 2.650E-02 2.146E-02 1.697E-02 1.302E-02 9.611E-03 6.745E-03 4.409E-03 2.589E-03 1.267E-03 4.241E-04 3.466E-05 7.214E-05 5.072E-04 1.309E-03 2.443E-03 3.877E-03 5.573E-03 7.498E-03 9.614E-03 1.189E-02 1.428E-02 1.675E-02 1.928E-02 2.183E-02 2.436E-02 2.685E-02 2.927E-02 3.159E-02 3.380E-02 3.587E-02 3.778E-02 3.951E-02 4.106E-02 4.240E-02 4.354E-02 4.446E-02 4.517E-02 4.565E-02 4.592E-02 4.567E-02 4.519E-02 4.450E-02 4.359E-02 4.246E-02 4.112E-02 3.958E-02 3.786E-02 3.596E-02 3.390E-02 3.170E-02 2.938E-02 2.697E-02 2.448E-02 2.195E-02 1.940E-02 1.688E-02 1.440E-02 1.200E-02 9.726E-03 7.602E-03 5.668E-03 3.959E-03 2.512E-03 1.361E-03 5.414E-04 8.587E-05 2.589E-05 3.908E-04 1.208E-03 2.501E-03 4.291E-03 6.595E-03 9.428E-03 1.280E-02 1.671E-02 2.117E-02 2.617E-02 3.170E-02 3.775E-02 4.429E-02 5.130E-02 5.875E-02 6.661E-02 7.484E-02 8.338E-02 9.218E-02 1.012E-01 1.104E-01 1.196E-01 1.289E-01 1.381E-01 1.472E-01 1.562E-01 1.648E-01 1.731E-01 1.809E-01 1.883E-01 1.951E-01 2.012E-01 2.066E-01 2.113E-01 2.151E-01 2.180E-01 2.200E-01 2.210E-01 2.210E-01 2.200E-01 2.179E-01 2.148E-01 2.106E-01 2.054E-01 1.992E-01 1.920E-01 1.839E-01 1.750E-01 1.653E-01 1.549E-01 1.440E-01 1.325E-01 1.207E-01 1.087E-01 9.651E-02 8.441E-02 7.250E-02 6.095E-02 4.991E-02 3.955E-02 3.005E-02 2.155E-02 1.424E-02 8.276E-03 3.813E-03 1.007E-03 9.434E-07 9.292E-04 3.914E-03 9.066E-03 1.648E-02 2.623E-02 3.837E-02 5.295E-02 6.998E-02 8.946E-02 1.114E-01 1.356E-01 1.622E-01 1.909E-01 2.217E-01 2.543E-01 2.887E-01 3.245E-01 3.616E-01 3.997E-01 4.384E-01 4.775E-01 5.166E-01 5.552E-01 5.931E-01 6.296E-01 6.643E-01 6.967E-01 7.260E-01 7.516E-01 7.728E-01 7.886E-01 7.985E-01 8.019E-01 7.985E-01 7.886E-01 7.728E-01 7.516E-01 7.260E-01 6.967E-01 6.643E-01 6.296E-01 5.931E-01 5.552E-01 5.166E-01 4.775E-01 4.384E-01 3.997E-01 3.616E-01 3.245E-01 2.887E-01 2.543E-01 2.217E-01 1.909E-01 1.622E-01 1.356E-01 1.114E-01 8.946E-02 6.998E-02 5.295E-02 3.837E-02 2.623E-02 1.648E-02 9.066E-03 3.914E-03 9.292E-04 9.434E-07 1.007E-03 3.813E-03 8.276E-03 1.424E-02 2.155E-02 3.005E-02 3.955E-02 4.991E-02 6.095E-02 7.250E-02 8.441E-02 9.651E-02 1.087E-01 1.207E-01 1.325E-01 1.440E-01 1.549E-01 1.653E-01 1.750E-01 1.839E-01 1.920E-01 1.992E-01 2.054E-01 2.106E-01 2.148E-01 2.179E-01 2.200E-01 2.210E-01 2.210E-01 2.200E-01 2.180E-01 2.151E-01 2.113E-01 2.066E-01 2.012E-01 1.951E-01 1.883E-01 1.809E-01 1.731E-01 1.648E-01 1.562E-01 1.472E-01 1.381E-01 1.289E-01 1.196E-01 1.104E-01 1.012E-01 9.218E-02 8.338E-02 7.484E-02 6.661E-02 5.875E-02 5.130E-02 4.429E-02 3.775E-02 3.170E-02 2.617E-02 2.117E-02 1.671E-02 1.280E-02 9.428E-03 6.595E-03 4.291E-03 2.501E-03 1.208E-03 3.908E-04 2.589E-05 8.587E-05 5.414E-04 1.361E-03 2.512E-03 3.959E-03 5.668E-03 7.602E-03 9.726E-03 1.200E-02 1.440E-02 1.688E-02 1.940E-02 2.195E-02 2.448E-02 2.697E-02 2.938E-02 3.170E-02 3.390E-02 3.596E-02 3.786E-02 3.958E-02 4.112E-02 4.246E-02 4.359E-02 4.450E-02 4.519E-02 4.567E-02 4.593E-02 4.569E-02 4.522E-02 4.454E-02 4.364E-02 4.252E-02 4.120E-02 3.967E-02 3.796E-02 3.607E-02 3.402E-02 3.183E-02 2.951E-02 2.710E-02 2.462E-02 2.210E-02 1.955E-02 1.702E-02 1.454E-02 1.214E-02 9.859E-03 7.726E-03 5.780E-03 4.058E-03 2.594E-03 1.424E-03 5.831E-04 1.036E-04 1.718E-05 3.533E-04 1.139E-03 2.399E-03 4.153E-03 6.421E-03 9.215E-03 1.255E-02 1.642E-02 2.084E-02 2.579E-02 3.128E-02 3.728E-02 4.378E-02 5.076E-02 5.817E-02 6.599E-02 7.418E-02 8.269E-02 9.147E-02 1.005E-01 1.096E-01 1.189E-01 1.281E-01 1.374E-01 1.465E-01 1.554E-01 1.640E-01 1.723E-01 1.802E-01 1.876E-01 1.945E-01 2.007E-01 2.062E-01 2.109E-01 2.148E-01 2.178E-01 2.199E-01 2.210E-01 2.211E-01 2.201E-01 2.182E-01 2.152E-01 2.111E-01 2.060E-01 2.000E-01 1.929E-01 1.850E-01 1.762E-01 1.666E-01 1.563E-01 1.455E-01 1.341E-01 1.224E-01 1.104E-01 9.826E-02 8.618E-02 7.428E-02 6.270E-02 5.161E-02 4.118E-02 3.156E-02 2.292E-02 1.543E-02 9.244E-03 4.519E-03 1.408E-03 4.997E-05 5.789E-04 3.115E-03 7.765E-03 1.462E-02 2.376E-02 3.524E-02 4.909E-02 6.534E-02 8.397E-02 1.050E-01 1.283E-01 1.538E-01 1.814E-01 2.110E-01 2.424E-01 2.755E-01 3.100E-01 3.457E-01 3.822E-01 4.194E-01 4.568E-01 4.941E-01 5.310E-01 5.669E-01 6.014E-01 6.341E-01 6.643E-01 6.915E-01 7.151E-01 7.344E-01 7.487E-01 7.576E-01 7.605E-01 7.576E-01 7.487E-01 7.344E-01 7.151E-01 6.915E-01 6.643E-01 6.341E-01 6.014E-01 5.669E-01 5.310E-01 4.941E-01 4.568E-01 4.194E-01 3.822E-01 3.457E-01 3.100E-01 2.755E-01 2.424E-01 2.110E-01 1.814E-01 1.538E-01 1.283E-01 1.050E-01 8.397E-02 6.534E-02 4.909E-02 3.524E-02 2.376E-02 1.462E-02 7.765E-03 3.115E-03 5.789E-04 4.997E-05 1.408E-03 4.519E-03 9.244E-03 1.543E-02 2.292E-02 3.156E-02 4.118E-02 5.161E-02 6.270E-02 7.428E-02 8.618E-02 9.826E-02 1.104E-01 1.224E-01 1.341E-01 1.455E-01 1.563E-01 1.666E-01 1.762E-01 1.850E-01 1.929E-01 2.000E-01 2.060E-01 2.111E-01 2.152E-01 2.182E-01 2.201E-01 2.211E-01 2.210E-01 2.199E-01 2.178E-01 2.148E-01 2.109E-01 2.062E-01 2.007E-01 1.945E-01 1.876E-01 1.802E-01 1.723E-01 1.640E-01 1.554E-01 1.465E-01 1.374E-01 1.281E-01 1.189E-01 1.096E-01 1.005E-01 9.147E-02 8.269E-02 7.418E-02 6.599E-02 5.817E-02 5.076E-02 4.378E-02 3.728E-02 3.128E-02 2.579E-02 2.084E-02 1.642E-02 1.255E-02 9.215E-03 6.421E-03 4.153E-03 2.399E-03 1.139E-03 3.533E-04 1.718E-05 1.036E-04 5.831E-04 1.424E-03 2.594E-03 4.058E-03 5.780E-03 7.726E-03 9.859E-03 1.214E-02 1.454E-02 1.702E-02 1.955E-02 2.210E-02 2.462E-02 2.710E-02 2.951E-02 3.183E-02 3.402E-02 3.607E-02 3.796E-02 3.967E-02 4.120E-02 4.252E-02 4.364E-02 4.454E-02 4.522E-02 4.569E-02 4.594E-02 4.571E-02 4.526E-02 4.459E-02 4.370E-02 4.260E-02 4.128E-02 3.977E-02 3.807E-02 3.619E-02 3.415E-02 3.197E-02 2.967E-02 2.726E-02 2.479E-02 2.226E-02 1.972E-02 1.719E-02 1.471E-02 1.230E-02 1.001E-02 7.870E-03 5.911E-03 4.173E-03 2.690E-03 1.499E-03 6.330E-04 1.261E-04 9.360E-06 3.124E-04 1.062E-03 2.284E-03 3.998E-03 6.223E-03 8.973E-03 1.226E-02 1.608E-02 2.045E-02 2.536E-02 3.080E-02 3.675E-02 4.320E-02 5.013E-02 5.750E-02 6.528E-02 7.343E-02 8.190E-02 9.065E-02 9.961E-02 1.087E-01 1.180E-01 1.272E-01 1.364E-01 1.456E-01 1.545E-01 1.632E-01 1.715E-01 1.794E-01 1.869E-01 1.938E-01 2.000E-01 2.056E-01 2.104E-01 2.144E-01 2.175E-01 2.197E-01 2.209E-01 2.211E-01 2.203E-01 2.185E-01 2.156E-01 2.117E-01 2.068E-01 2.008E-01 1.940E-01 1.861E-01 1.775E-01 1.680E-01 1.579E-01 1.471E-01 1.359E-01 1.242E-01 1.123E-01 1.003E-01 8.823E-02 7.633E-02 6.473E-02 5.359E-02 4.307E-02 3.333E-02 2.454E-02 1.684E-02 1.041E-02 5.398E-03 1.946E-03 1.968E-04 2.800E-04 2.314E-03 6.405E-03 1.264E-02 2.110E-02 3.183E-02 4.487E-02 6.024E-02 7.793E-02 9.791E-02 1.201E-01 1.445E-01 1.709E-01 1.992E-01 2.293E-01 2.609E-01 2.939E-01 3.280E-01 3.629E-01 3.983E-01 4.340E-01 4.694E-01 5.044E-01 5.383E-01 5.708E-01 6.014E-01 6.296E-01 6.548E-01 6.765E-01 6.941E-01 7.071E-01 7.151E-01 7.178E-01 7.151E-01 7.071E-01 6.941E-01 6.765E-01 6.548E-01 6.296E-01 6.014E-01 5.708E-01 5.383E-01 5.044E-01 4.694E-01 4.340E-01 3.983E-01 3.629E-01 3.280E-01 2.939E-01 2.609E-01 2.293E-01 1.992E-01 1.709E-01 1.445E-01 1.201E-01 9.791E-02 7.793E-02 6.024E-02 4.487E-02 3.183E-02 2.110E-02 1.264E-02 6.405E-03 2.314E-03 2.800E-04 1.968E-04 1.946E-03 5.398E-03 1.041E-02 1.684E-02 2.454E-02 3.333E-02 4.307E-02 5.359E-02 6.473E-02 7.633E-02 8.823E-02 1.003E-01 1.123E-01 1.242E-01 1.359E-01 1.471E-01 1.579E-01 1.680E-01 1.775E-01 1.861E-01 1.940E-01 2.008E-01 2.068E-01 2.117E-01 2.156E-01 2.185E-01 2.203E-01 2.211E-01 2.209E-01 2.197E-01 2.175E-01 2.144E-01 2.104E-01 2.056E-01 2.000E-01 1.938E-01 1.869E-01 1.794E-01 1.715E-01 1.632E-01 1.545E-01 1.456E-01 1.364E-01 1.272E-01 1.180E-01 1.087E-01 9.961E-02 9.065E-02 8.190E-02 7.343E-02 6.528E-02 5.750E-02 5.013E-02 4.320E-02 3.675E-02 3.080E-02 2.536E-02 2.045E-02 1.608E-02 1.226E-02 8.973E-03 6.223E-03 3.998E-03 2.284E-03 1.062E-03 3.124E-04 9.360E-06 1.261E-04 6.330E-04 1.499E-03 2.690E-03 4.173E-03 5.911E-03 7.870E-03 1.001E-02 1.230E-02 1.471E-02 1.719E-02 1.972E-02 2.226E-02 2.479E-02 2.726E-02 2.967E-02 3.197E-02 3.415E-02 3.619E-02 3.807E-02 3.977E-02 4.128E-02 4.260E-02 4.370E-02 4.459E-02 4.526E-02 4.571E-02 4.594E-02 4.573E-02 4.529E-02 4.464E-02 4.377E-02 4.268E-02 4.138E-02 3.988E-02 3.820E-02 3.633E-02 3.430E-02 3.213E-02 2.984E-02 2.744E-02 2.497E-02 2.245E-02 1.991E-02 1.739E-02 1.490E-02 1.249E-02 1.019E-02 8.034E-03 6.061E-03 4.304E-03 2.801E-03 1.585E-03 6.919E-04 1.541E-04 3.357E-06 2.693E-04 9.791E-04 2.157E-03 3.826E-03 6.003E-03 8.703E-03 1.194E-02 1.571E-02 2.002E-02 2.487E-02 3.026E-02 3.616E-02 4.255E-02 4.943E-02 5.674E-02 6.447E-02 7.258E-02 8.101E-02 8.972E-02 9.865E-02 1.078E-01 1.170E-01 1.262E-01 1.354E-01 1.445E-01 1.535E-01 1.622E-01 1.705E-01 1.785E-01 1.860E-01 1.929E-01 1.993E-01 2.049E-01 2.098E-01 2.139E-01 2.171E-01 2.194E-01 2.208E-01 2.211E-01 2.205E-01 2.188E-01 2.161E-01 2.124E-01 2.076E-01 2.018E-01 1.951E-01 1.875E-01 1.790E-01 1.697E-01 1.597E-01 1.490E-01 1.379E-01 1.264E-01 1.145E-01 1.026E-01 9.054E-02 7.866E-02 6.704E-02 5.585E-02 4.524E-02 3.538E-02 2.641E-02 1.850E-02 1.181E-02 6.474E-03 2.652E-03 4.758E-04 7.283E-05 1.559E-03 5.037E-03 1.060E-02 1.831E-02 2.822E-02 4.038E-02 5.479E-02 7.145E-02 9.032E-02 1.114E-01 1.345E-01 1.595E-01 1.865E-01 2.151E-01 2.451E-01 2.765E-01 3.089E-01 3.421E-01 3.757E-01 4.094E-01 4.430E-01 4.759E-01 5.078E-01 5.383E-01 5.669E-01 5.931E-01 6.164E-01 6.364E-01 6.525E-01 6.643E-01 6.716E-01 6.740E-01 6.716E-01 6.643E-01 6.525E-01 6.364E-01 6.164E-01 5.931E-01 5.669E-01 5.383E-01 5.078E-01 4.759E-01 4.430E-01 4.094E-01 3.757E-01 3.421E-01 3.089E-01 2.765E-01 2.451E-01 2.151E-01 1.865E-01 1.595E-01 1.345E-01 1.114E-01 9.032E-02 7.145E-02 5.479E-02 4.038E-02 2.822E-02 1.831E-02 1.060E-02 5.037E-03 1.559E-03 7.283E-05 4.758E-04 2.652E-03 6.474E-03 1.181E-02 1.850E-02 2.641E-02 3.538E-02 4.524E-02 5.585E-02 6.704E-02 7.866E-02 9.054E-02 1.026E-01 1.145E-01 1.264E-01 1.379E-01 1.490E-01 1.597E-01 1.697E-01 1.790E-01 1.875E-01 1.951E-01 2.018E-01 2.076E-01 2.124E-01 2.161E-01 2.188E-01 2.205E-01 2.211E-01 2.208E-01 2.194E-01 2.171E-01 2.139E-01 2.098E-01 2.049E-01 1.993E-01 1.929E-01 1.860E-01 1.785E-01 1.705E-01 1.622E-01 1.535E-01 1.445E-01 1.354E-01 1.262E-01 1.170E-01 1.078E-01 9.865E-02 8.972E-02 8.101E-02 7.258E-02 6.447E-02 5.674E-02 4.943E-02 4.255E-02 3.616E-02 3.026E-02 2.487E-02 2.002E-02 1.571E-02 1.194E-02 8.703E-03 6.003E-03 3.826E-03 2.157E-03 9.791E-04 2.693E-04 3.357E-06 1.541E-04 6.919E-04 1.585E-03 2.801E-03 4.304E-03 6.061E-03 8.034E-03 1.019E-02 1.249E-02 1.490E-02 1.739E-02 1.991E-02 2.245E-02 2.497E-02 2.744E-02 2.984E-02 3.213E-02 3.430E-02 3.633E-02 3.820E-02 3.988E-02 4.138E-02 4.268E-02 4.377E-02 4.464E-02 4.529E-02 4.573E-02 4.595E-02 4.575E-02 4.533E-02 4.470E-02 4.384E-02 4.277E-02 4.149E-02 4.001E-02 3.834E-02 3.649E-02 3.447E-02 3.231E-02 3.003E-02 2.765E-02 2.518E-02 2.267E-02 2.013E-02 1.760E-02 1.511E-02 1.269E-02 1.039E-02 8.218E-03 6.229E-03 4.453E-03 2.927E-03 1.684E-03 7.605E-04 1.886E-04 2.162E-07 2.249E-04 8.902E-04 2.021E-03 3.639E-03 5.762E-03 8.406E-03 1.158E-02 1.529E-02 1.955E-02 2.434E-02 2.966E-02 3.549E-02 4.183E-02 4.864E-02 5.591E-02 6.358E-02 7.163E-02 8.002E-02 8.868E-02 9.758E-02 1.067E-01 1.158E-01 1.251E-01 1.343E-01 1.434E-01 1.523E-01 1.611E-01 1.694E-01 1.775E-01 1.850E-01 1.920E-01 1.984E-01 2.042E-01 2.092E-01 2.133E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.207E-01 2.192E-01 2.166E-01 2.130E-01 2.085E-01 2.029E-01 1.963E-01 1.889E-01 1.806E-01 1.714E-01 1.616E-01 1.511E-01 1.401E-01 1.287E-01 1.170E-01 1.051E-01 9.313E-02 8.126E-02 6.963E-02 5.839E-02 4.770E-02 3.770E-02 2.855E-02 2.042E-02 1.344E-02 7.773E-03 3.556E-03 9.237E-04 2.496E-07 8.991E-04 3.721E-03 8.552E-03 1.546E-02 2.450E-02 3.571E-02 4.909E-02 6.465E-02 8.233E-02 1.021E-01 1.239E-01 1.475E-01 1.730E-01 2.000E-01 2.284E-01 2.581E-01 2.887E-01 3.200E-01 3.517E-01 3.835E-01 4.151E-01 4.460E-01 4.759E-01 5.044E-01 5.310E-01 5.552E-01 5.768E-01 5.952E-01 6.099E-01 6.208E-01 6.274E-01 6.296E-01 6.274E-01 6.208E-01 6.099E-01 5.952E-01 5.768E-01 5.552E-01 5.310E-01 5.044E-01 4.759E-01 4.460E-01 4.151E-01 3.835E-01 3.517E-01 3.200E-01 2.887E-01 2.581E-01 2.284E-01 2.000E-01 1.730E-01 1.475E-01 1.239E-01 1.021E-01 8.233E-02 6.465E-02 4.909E-02 3.571E-02 2.450E-02 1.546E-02 8.552E-03 3.721E-03 8.991E-04 2.496E-07 9.237E-04 3.556E-03 7.773E-03 1.344E-02 2.042E-02 2.855E-02 3.770E-02 4.770E-02 5.839E-02 6.963E-02 8.126E-02 9.313E-02 1.051E-01 1.170E-01 1.287E-01 1.401E-01 1.511E-01 1.616E-01 1.714E-01 1.806E-01 1.889E-01 1.963E-01 2.029E-01 2.085E-01 2.130E-01 2.166E-01 2.192E-01 2.207E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.133E-01 2.092E-01 2.042E-01 1.984E-01 1.920E-01 1.850E-01 1.775E-01 1.694E-01 1.611E-01 1.523E-01 1.434E-01 1.343E-01 1.251E-01 1.158E-01 1.067E-01 9.758E-02 8.868E-02 8.002E-02 7.163E-02 6.358E-02 5.591E-02 4.864E-02 4.183E-02 3.549E-02 2.966E-02 2.434E-02 1.955E-02 1.529E-02 1.158E-02 8.406E-03 5.762E-03 3.639E-03 2.021E-03 8.902E-04 2.249E-04 2.162E-07 1.886E-04 7.605E-04 1.684E-03 2.927E-03 4.453E-03 6.229E-03 8.218E-03 1.039E-02 1.269E-02 1.511E-02 1.760E-02 2.013E-02 2.267E-02 2.518E-02 2.765E-02 3.003E-02 3.231E-02 3.447E-02 3.649E-02 3.834E-02 4.001E-02 4.149E-02 4.277E-02 4.384E-02 4.470E-02 4.533E-02 4.575E-02 4.596E-02 4.578E-02 4.538E-02 4.476E-02 4.392E-02 4.287E-02 4.161E-02 4.015E-02 3.849E-02 3.666E-02 3.466E-02 3.251E-02 3.024E-02 2.787E-02 2.541E-02 2.290E-02 2.037E-02 1.784E-02 1.535E-02 1.292E-02 1.060E-02 8.424E-03 6.417E-03 4.620E-03 3.068E-03 1.797E-03 8.399E-04 2.307E-04 1.084E-06 1.807E-04 7.971E-04 1.875E-03 3.437E-03 5.502E-03 8.084E-03 1.120E-02 1.484E-02 1.903E-02 2.375E-02 2.900E-02 3.477E-02 4.104E-02 4.779E-02 5.499E-02 6.260E-02 7.060E-02 7.893E-02 8.755E-02 9.640E-02 1.054E-01 1.146E-01 1.238E-01 1.330E-01 1.421E-01 1.511E-01 1.598E-01 1.682E-01 1.763E-01 1.839E-01 1.910E-01 1.975E-01 2.033E-01 2.084E-01 2.127E-01 2.162E-01 2.188E-01 2.204E-01 2.211E-01 2.208E-01 2.195E-01 2.171E-01 2.138E-01 2.094E-01 2.040E-01 1.977E-01 1.904E-01 1.823E-01 1.734E-01 1.637E-01 1.534E-01 1.426E-01 1.313E-01 1.197E-01 1.079E-01 9.597E-02 8.413E-02 7.250E-02 6.122E-02 5.043E-02 4.030E-02 3.098E-02 2.260E-02 1.534E-02 9.320E-03 4.690E-03 1.578E-03 1.066E-04 3.863E-04 2.515E-03 6.577E-03 1.264E-02 2.076E-02 3.096E-02 4.325E-02 5.764E-02 7.408E-02 9.251E-02 1.129E-01 1.350E-01 1.589E-01 1.843E-01 2.110E-01 2.389E-01 2.676E-01 2.971E-01 3.268E-01 3.566E-01 3.862E-01 4.151E-01 4.430E-01 4.694E-01 4.941E-01 5.166E-01 5.365E-01 5.533E-01 5.669E-01 5.768E-01 5.828E-01 5.849E-01 5.828E-01 5.768E-01 5.669E-01 5.533E-01 5.365E-01 5.166E-01 4.941E-01 4.694E-01 4.430E-01 4.151E-01 3.862E-01 3.566E-01 3.268E-01 2.971E-01 2.676E-01 2.389E-01 2.110E-01 1.843E-01 1.589E-01 1.350E-01 1.129E-01 9.251E-02 7.408E-02 5.764E-02 4.325E-02 3.096E-02 2.076E-02 1.264E-02 6.577E-03 2.515E-03 3.863E-04 1.066E-04 1.578E-03 4.690E-03 9.320E-03 1.534E-02 2.260E-02 3.098E-02 4.030E-02 5.043E-02 6.122E-02 7.250E-02 8.413E-02 9.597E-02 1.079E-01 1.197E-01 1.313E-01 1.426E-01 1.534E-01 1.637E-01 1.734E-01 1.823E-01 1.904E-01 1.977E-01 2.040E-01 2.094E-01 2.138E-01 2.171E-01 2.195E-01 2.208E-01 2.211E-01 2.204E-01 2.188E-01 2.162E-01 2.127E-01 2.084E-01 2.033E-01 1.975E-01 1.910E-01 1.839E-01 1.763E-01 1.682E-01 1.598E-01 1.511E-01 1.421E-01 1.330E-01 1.238E-01 1.146E-01 1.054E-01 9.640E-02 8.755E-02 7.893E-02 7.060E-02 6.260E-02 5.499E-02 4.779E-02 4.104E-02 3.477E-02 2.900E-02 2.375E-02 1.903E-02 1.484E-02 1.120E-02 8.084E-03 5.502E-03 3.437E-03 1.875E-03 7.971E-04 1.807E-04 1.084E-06 2.307E-04 8.399E-04 1.797E-03 3.068E-03 4.620E-03 6.417E-03 8.424E-03 1.060E-02 1.292E-02 1.535E-02 1.784E-02 2.037E-02 2.290E-02 2.541E-02 2.787E-02 3.024E-02 3.251E-02 3.466E-02 3.666E-02 3.849E-02 4.015E-02 4.161E-02 4.287E-02 4.392E-02 4.476E-02 4.538E-02 4.578E-02 4.596E-02 4.580E-02 4.542E-02 4.483E-02 4.401E-02 4.298E-02 4.174E-02 4.029E-02 3.866E-02 3.684E-02 3.486E-02 3.273E-02 3.047E-02 2.811E-02 2.566E-02 2.316E-02 2.063E-02 1.810E-02 1.560E-02 1.317E-02 1.085E-02 8.650E-03 6.625E-03 4.805E-03 3.227E-03 1.924E-03 9.309E-04 2.815E-04 7.209E-06 1.379E-04 7.014E-04 1.723E-03 3.224E-03 5.225E-03 7.741E-03 1.078E-02 1.436E-02 1.847E-02 2.312E-02 2.830E-02 3.399E-02 4.019E-02 4.686E-02 5.399E-02 6.154E-02 6.947E-02 7.774E-02 8.631E-02 9.512E-02 1.041E-01 1.132E-01 1.224E-01 1.316E-01 1.407E-01 1.497E-01 1.585E-01 1.669E-01 1.750E-01 1.827E-01 1.899E-01 1.964E-01 2.024E-01 2.076E-01 2.120E-01 2.156E-01 2.184E-01 2.202E-01 2.211E-01 2.210E-01 2.198E-01 2.177E-01 2.145E-01 2.104E-01 2.052E-01 1.991E-01 1.921E-01 1.842E-01 1.755E-01 1.660E-01 1.559E-01 1.452E-01 1.341E-01 1.226E-01 1.109E-01 9.907E-02 8.727E-02 7.565E-02 6.433E-02 5.346E-02 4.320E-02 3.369E-02 2.508E-02 1.752E-02 1.114E-02 6.085E-03 2.477E-03 4.369E-04 7.283E-05 1.481E-03 4.742E-03 9.923E-03 1.707E-02 2.623E-02 3.739E-02 5.055E-02 6.569E-02 8.274E-02 1.016E-01 1.223E-01 1.445E-01 1.682E-01 1.931E-01 2.192E-01 2.461E-01 2.735E-01 3.013E-01 3.291E-01 3.566E-01 3.835E-01 4.094E-01 4.340E-01 4.568E-01 4.775E-01 4.958E-01 5.113E-01 5.237E-01 5.328E-01 5.383E-01 5.402E-01 5.383E-01 5.328E-01 5.237E-01 5.113E-01 4.958E-01 4.775E-01 4.568E-01 4.340E-01 4.094E-01 3.835E-01 3.566E-01 3.291E-01 3.013E-01 2.735E-01 2.461E-01 2.192E-01 1.931E-01 1.682E-01 1.445E-01 1.223E-01 1.016E-01 8.274E-02 6.569E-02 5.055E-02 3.739E-02 2.623E-02 1.707E-02 9.923E-03 4.742E-03 1.481E-03 7.283E-05 4.369E-04 2.477E-03 6.085E-03 1.114E-02 1.752E-02 2.508E-02 3.369E-02 4.320E-02 5.346E-02 6.433E-02 7.565E-02 8.727E-02 9.907E-02 1.109E-01 1.226E-01 1.341E-01 1.452E-01 1.559E-01 1.660E-01 1.755E-01 1.842E-01 1.921E-01 1.991E-01 2.052E-01 2.104E-01 2.145E-01 2.177E-01 2.198E-01 2.210E-01 2.211E-01 2.202E-01 2.184E-01 2.156E-01 2.120E-01 2.076E-01 2.024E-01 1.964E-01 1.899E-01 1.827E-01 1.750E-01 1.669E-01 1.585E-01 1.497E-01 1.407E-01 1.316E-01 1.224E-01 1.132E-01 1.041E-01 9.512E-02 8.631E-02 7.774E-02 6.947E-02 6.154E-02 5.399E-02 4.686E-02 4.019E-02 3.399E-02 2.830E-02 2.312E-02 1.847E-02 1.436E-02 1.078E-02 7.741E-03 5.225E-03 3.224E-03 1.723E-03 7.014E-04 1.379E-04 7.209E-06 2.815E-04 9.309E-04 1.924E-03 3.227E-03 4.805E-03 6.625E-03 8.650E-03 1.085E-02 1.317E-02 1.560E-02 1.810E-02 2.063E-02 2.316E-02 2.566E-02 2.811E-02 3.047E-02 3.273E-02 3.486E-02 3.684E-02 3.866E-02 4.029E-02 4.174E-02 4.298E-02 4.401E-02 4.483E-02 4.542E-02 4.580E-02 4.597E-02 4.583E-02 4.547E-02 4.489E-02 4.410E-02 4.309E-02 4.187E-02 4.045E-02 3.884E-02 3.704E-02 3.508E-02 3.296E-02 3.072E-02 2.837E-02 2.593E-02 2.344E-02 2.091E-02 1.838E-02 1.588E-02 1.345E-02 1.111E-02 8.898E-03 6.854E-03 5.010E-03 3.402E-03 2.066E-03 1.035E-03 3.421E-04 1.993E-05 9.812E-05 6.046E-04 1.565E-03 3.001E-03 4.933E-03 7.376E-03 1.034E-02 1.384E-02 1.787E-02 2.244E-02 2.754E-02 3.315E-02 3.927E-02 4.586E-02 5.291E-02 6.039E-02 6.825E-02 7.646E-02 8.497E-02 9.373E-02 1.027E-01 1.118E-01 1.209E-01 1.301E-01 1.392E-01 1.482E-01 1.570E-01 1.655E-01 1.736E-01 1.814E-01 1.886E-01 1.953E-01 2.013E-01 2.066E-01 2.112E-01 2.150E-01 2.179E-01 2.199E-01 2.210E-01 2.211E-01 2.202E-01 2.182E-01 2.153E-01 2.114E-01 2.065E-01 2.006E-01 1.938E-01 1.861E-01 1.777E-01 1.684E-01 1.585E-01 1.480E-01 1.371E-01 1.257E-01 1.142E-01 1.024E-01 9.068E-02 7.907E-02 6.772E-02 5.679E-02 4.640E-02 3.672E-02 2.787E-02 2.001E-02 1.326E-02 7.773E-03 3.658E-03 1.036E-03 1.105E-05 6.775E-04 3.115E-03 7.388E-03 1.354E-02 2.162E-02 3.161E-02 4.352E-02 5.732E-02 7.294E-02 9.032E-02 1.094E-01 1.299E-01 1.519E-01 1.750E-01 1.992E-01 2.242E-01 2.497E-01 2.755E-01 3.013E-01 3.268E-01 3.517E-01 3.757E-01 3.983E-01 4.194E-01 4.384E-01 4.552E-01 4.694E-01 4.808E-01 4.891E-01 4.941E-01 4.958E-01 4.941E-01 4.891E-01 4.808E-01 4.694E-01 4.552E-01 4.384E-01 4.194E-01 3.983E-01 3.757E-01 3.517E-01 3.268E-01 3.013E-01 2.755E-01 2.497E-01 2.242E-01 1.992E-01 1.750E-01 1.519E-01 1.299E-01 1.094E-01 9.032E-02 7.294E-02 5.732E-02 4.352E-02 3.161E-02 2.162E-02 1.354E-02 7.388E-03 3.115E-03 6.775E-04 1.105E-05 1.036E-03 3.658E-03 7.773E-03 1.326E-02 2.001E-02 2.787E-02 3.672E-02 4.640E-02 5.679E-02 6.772E-02 7.907E-02 9.068E-02 1.024E-01 1.142E-01 1.257E-01 1.371E-01 1.480E-01 1.585E-01 1.684E-01 1.777E-01 1.861E-01 1.938E-01 2.006E-01 2.065E-01 2.114E-01 2.153E-01 2.182E-01 2.202E-01 2.211E-01 2.210E-01 2.199E-01 2.179E-01 2.150E-01 2.112E-01 2.066E-01 2.013E-01 1.953E-01 1.886E-01 1.814E-01 1.736E-01 1.655E-01 1.570E-01 1.482E-01 1.392E-01 1.301E-01 1.209E-01 1.118E-01 1.027E-01 9.373E-02 8.497E-02 7.646E-02 6.825E-02 6.039E-02 5.291E-02 4.586E-02 3.927E-02 3.315E-02 2.754E-02 2.244E-02 1.787E-02 1.384E-02 1.034E-02 7.376E-03 4.933E-03 3.001E-03 1.565E-03 6.046E-04 9.812E-05 1.993E-05 3.421E-04 1.035E-03 2.066E-03 3.402E-03 5.010E-03 6.854E-03 8.898E-03 1.111E-02 1.345E-02 1.588E-02 1.838E-02 2.091E-02 2.344E-02 2.593E-02 2.837E-02 3.072E-02 3.296E-02 3.508E-02 3.704E-02 3.884E-02 4.045E-02 4.187E-02 4.309E-02 4.410E-02 4.489E-02 4.547E-02 4.583E-02 4.597E-02 4.585E-02 4.552E-02 4.497E-02 4.420E-02 4.321E-02 4.202E-02 4.062E-02 3.903E-02 3.725E-02 3.531E-02 3.321E-02 3.099E-02 2.865E-02 2.622E-02 2.374E-02 2.122E-02 1.869E-02 1.619E-02 1.375E-02 1.139E-02 9.169E-03 7.104E-03 5.234E-03 3.596E-03 2.224E-03 1.152E-03 4.139E-04 4.068E-05 6.286E-05 5.085E-04 1.403E-03 2.770E-03 4.628E-03 6.994E-03 9.880E-03 1.329E-02 1.724E-02 2.172E-02 2.673E-02 3.226E-02 3.829E-02 4.480E-02 5.177E-02 5.916E-02 6.695E-02 7.509E-02 8.353E-02 9.224E-02 1.011E-01 1.102E-01 1.193E-01 1.285E-01 1.376E-01 1.466E-01 1.554E-01 1.639E-01 1.721E-01 1.799E-01 1.872E-01 1.940E-01 2.001E-01 2.056E-01 2.103E-01 2.143E-01 2.174E-01 2.196E-01 2.208E-01 2.211E-01 2.205E-01 2.188E-01 2.161E-01 2.124E-01 2.078E-01 2.022E-01 1.956E-01 1.882E-01 1.800E-01 1.710E-01 1.613E-01 1.510E-01 1.403E-01 1.291E-01 1.176E-01 1.060E-01 9.435E-02 8.276E-02 7.141E-02 6.041E-02 4.991E-02 4.005E-02 3.098E-02 2.282E-02 1.571E-02 9.783E-03 5.157E-03 1.946E-03 2.518E-04 1.654E-04 1.765E-03 5.113E-03 1.026E-02 1.723E-02 2.603E-02 3.666E-02 4.909E-02 6.327E-02 7.912E-02 9.654E-02 1.154E-01 1.356E-01 1.570E-01 1.793E-01 2.023E-01 2.259E-01 2.497E-01 2.735E-01 2.971E-01 3.200E-01 3.421E-01 3.629E-01 3.822E-01 3.997E-01 4.151E-01 4.281E-01 4.384E-01 4.460E-01 4.506E-01 4.521E-01 4.506E-01 4.460E-01 4.384E-01 4.281E-01 4.151E-01 3.997E-01 3.822E-01 3.629E-01 3.421E-01 3.200E-01 2.971E-01 2.735E-01 2.497E-01 2.259E-01 2.023E-01 1.793E-01 1.570E-01 1.356E-01 1.154E-01 9.654E-02 7.912E-02 6.327E-02 4.909E-02 3.666E-02 2.603E-02 1.723E-02 1.026E-02 5.113E-03 1.765E-03 1.654E-04 2.518E-04 1.946E-03 5.157E-03 9.783E-03 1.571E-02 2.282E-02 3.098E-02 4.005E-02 4.991E-02 6.041E-02 7.141E-02 8.276E-02 9.435E-02 1.060E-01 1.176E-01 1.291E-01 1.403E-01 1.510E-01 1.613E-01 1.710E-01 1.800E-01 1.882E-01 1.956E-01 2.022E-01 2.078E-01 2.124E-01 2.161E-01 2.188E-01 2.205E-01 2.211E-01 2.208E-01 2.196E-01 2.174E-01 2.143E-01 2.103E-01 2.056E-01 2.001E-01 1.940E-01 1.872E-01 1.799E-01 1.721E-01 1.639E-01 1.554E-01 1.466E-01 1.376E-01 1.285E-01 1.193E-01 1.102E-01 1.011E-01 9.224E-02 8.353E-02 7.509E-02 6.695E-02 5.916E-02 5.177E-02 4.480E-02 3.829E-02 3.226E-02 2.673E-02 2.172E-02 1.724E-02 1.329E-02 9.880E-03 6.994E-03 4.628E-03 2.770E-03 1.403E-03 5.085E-04 6.286E-05 4.068E-05 4.139E-04 1.152E-03 2.224E-03 3.596E-03 5.234E-03 7.104E-03 9.169E-03 1.139E-02 1.375E-02 1.619E-02 1.869E-02 2.122E-02 2.374E-02 2.622E-02 2.865E-02 3.099E-02 3.321E-02 3.531E-02 3.725E-02 3.903E-02 4.062E-02 4.202E-02 4.321E-02 4.420E-02 4.497E-02 4.552E-02 4.585E-02 4.597E-02 4.588E-02 4.557E-02 4.504E-02 4.430E-02 4.334E-02 4.217E-02 4.080E-02 3.923E-02 3.748E-02 3.556E-02 3.348E-02 3.127E-02 2.895E-02 2.654E-02 2.406E-02 2.154E-02 1.902E-02 1.652E-02 1.407E-02 1.170E-02 9.461E-03 7.375E-03 5.479E-03 3.809E-03 2.400E-03 1.285E-03 4.981E-04 7.095E-05 3.381E-05 4.149E-04 1.240E-03 2.532E-03 4.312E-03 6.595E-03 9.396E-03 1.272E-02 1.658E-02 2.097E-02 2.588E-02 3.131E-02 3.725E-02 4.367E-02 5.055E-02 5.786E-02 6.556E-02 7.363E-02 8.200E-02 9.065E-02 9.950E-02 1.085E-01 1.176E-01 1.267E-01 1.358E-01 1.448E-01 1.537E-01 1.622E-01 1.705E-01 1.783E-01 1.857E-01 1.926E-01 1.989E-01 2.045E-01 2.094E-01 2.135E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.207E-01 2.193E-01 2.169E-01 2.135E-01 2.091E-01 2.038E-01 1.975E-01 1.904E-01 1.824E-01 1.737E-01 1.642E-01 1.542E-01 1.436E-01 1.326E-01 1.213E-01 1.098E-01 9.826E-02 8.673E-02 7.537E-02 6.433E-02 5.373E-02 4.371E-02 3.441E-02 2.597E-02 1.850E-02 1.214E-02 7.009E-03 3.209E-03 8.437E-04 9.434E-07 7.568E-04 3.173E-03 7.295E-03 1.315E-02 2.076E-02 3.010E-02 4.115E-02 5.387E-02 6.817E-02 8.397E-02 1.012E-01 1.196E-01 1.391E-01 1.595E-01 1.807E-01 2.023E-01 2.242E-01 2.461E-01 2.676E-01 2.887E-01 3.089E-01 3.280E-01 3.457E-01 3.616E-01 3.757E-01 3.875E-01 3.970E-01 4.038E-01 4.080E-01 4.094E-01 4.080E-01 4.038E-01 3.970E-01 3.875E-01 3.757E-01 3.616E-01 3.457E-01 3.280E-01 3.089E-01 2.887E-01 2.676E-01 2.461E-01 2.242E-01 2.023E-01 1.807E-01 1.595E-01 1.391E-01 1.196E-01 1.012E-01 8.397E-02 6.817E-02 5.387E-02 4.115E-02 3.010E-02 2.076E-02 1.315E-02 7.295E-03 3.173E-03 7.568E-04 9.434E-07 8.437E-04 3.209E-03 7.009E-03 1.214E-02 1.850E-02 2.597E-02 3.441E-02 4.371E-02 5.373E-02 6.433E-02 7.537E-02 8.673E-02 9.826E-02 1.098E-01 1.213E-01 1.326E-01 1.436E-01 1.542E-01 1.642E-01 1.737E-01 1.824E-01 1.904E-01 1.975E-01 2.038E-01 2.091E-01 2.135E-01 2.169E-01 2.193E-01 2.207E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.135E-01 2.094E-01 2.045E-01 1.989E-01 1.926E-01 1.857E-01 1.783E-01 1.705E-01 1.622E-01 1.537E-01 1.448E-01 1.358E-01 1.267E-01 1.176E-01 1.085E-01 9.950E-02 9.065E-02 8.200E-02 7.363E-02 6.556E-02 5.786E-02 5.055E-02 4.367E-02 3.725E-02 3.131E-02 2.588E-02 2.097E-02 1.658E-02 1.272E-02 9.396E-03 6.595E-03 4.312E-03 2.532E-03 1.240E-03 4.149E-04 3.381E-05 7.095E-05 4.981E-04 1.285E-03 2.400E-03 3.809E-03 5.479E-03 7.375E-03 9.461E-03 1.170E-02 1.407E-02 1.652E-02 1.902E-02 2.154E-02 2.406E-02 2.654E-02 2.895E-02 3.127E-02 3.348E-02 3.556E-02 3.748E-02 3.923E-02 4.080E-02 4.217E-02 4.334E-02 4.430E-02 4.504E-02 4.557E-02 4.588E-02 4.597E-02 4.590E-02 4.562E-02 4.512E-02 4.440E-02 4.347E-02 4.233E-02 4.098E-02 3.944E-02 3.772E-02 3.582E-02 3.376E-02 3.157E-02 2.927E-02 2.687E-02 2.440E-02 2.189E-02 1.937E-02 1.687E-02 1.441E-02 1.204E-02 9.777E-03 7.669E-03 5.746E-03 4.042E-03 2.594E-03 1.434E-03 5.962E-04 1.123E-04 1.271E-05 3.258E-04 1.078E-03 2.291E-03 3.988E-03 6.184E-03 8.893E-03 1.212E-02 1.588E-02 2.017E-02 2.499E-02 3.032E-02 3.616E-02 4.248E-02 4.926E-02 5.648E-02 6.410E-02 7.208E-02 8.038E-02 8.896E-02 9.775E-02 1.067E-01 1.158E-01 1.249E-01 1.340E-01 1.430E-01 1.518E-01 1.604E-01 1.687E-01 1.766E-01 1.841E-01 1.911E-01 1.975E-01 2.032E-01 2.083E-01 2.125E-01 2.160E-01 2.186E-01 2.203E-01 2.211E-01 2.209E-01 2.198E-01 2.176E-01 2.145E-01 2.104E-01 2.054E-01 1.994E-01 1.926E-01 1.849E-01 1.764E-01 1.673E-01 1.575E-01 1.471E-01 1.364E-01 1.252E-01 1.139E-01 1.024E-01 9.095E-02 7.962E-02 6.854E-02 5.786E-02 4.770E-02 3.819E-02 2.947E-02 2.166E-02 1.488E-02 9.244E-03 4.863E-03 1.832E-03 2.374E-04 1.532E-04 1.640E-03 4.742E-03 9.489E-03 1.589E-02 2.395E-02 3.362E-02 4.487E-02 5.764E-02 7.182E-02 8.732E-02 1.040E-01 1.217E-01 1.403E-01 1.595E-01 1.793E-01 1.992E-01 2.192E-01 2.389E-01 2.581E-01 2.765E-01 2.939E-01 3.100E-01 3.245E-01 3.373E-01 3.481E-01 3.566E-01 3.629E-01 3.667E-01 3.680E-01 3.667E-01 3.629E-01 3.566E-01 3.481E-01 3.373E-01 3.245E-01 3.100E-01 2.939E-01 2.765E-01 2.581E-01 2.389E-01 2.192E-01 1.992E-01 1.793E-01 1.595E-01 1.403E-01 1.217E-01 1.040E-01 8.732E-02 7.182E-02 5.764E-02 4.487E-02 3.362E-02 2.395E-02 1.589E-02 9.489E-03 4.742E-03 1.640E-03 1.532E-04 2.374E-04 1.832E-03 4.863E-03 9.244E-03 1.488E-02 2.166E-02 2.947E-02 3.819E-02 4.770E-02 5.786E-02 6.854E-02 7.962E-02 9.095E-02 1.024E-01 1.139E-01 1.252E-01 1.364E-01 1.471E-01 1.575E-01 1.673E-01 1.764E-01 1.849E-01 1.926E-01 1.994E-01 2.054E-01 2.104E-01 2.145E-01 2.176E-01 2.198E-01 2.209E-01 2.211E-01 2.203E-01 2.186E-01 2.160E-01 2.125E-01 2.083E-01 2.032E-01 1.975E-01 1.911E-01 1.841E-01 1.766E-01 1.687E-01 1.604E-01 1.518E-01 1.430E-01 1.340E-01 1.249E-01 1.158E-01 1.067E-01 9.775E-02 8.896E-02 8.038E-02 7.208E-02 6.410E-02 5.648E-02 4.926E-02 4.248E-02 3.616E-02 3.032E-02 2.499E-02 2.017E-02 1.588E-02 1.212E-02 8.893E-03 6.184E-03 3.988E-03 2.291E-03 1.078E-03 3.258E-04 1.271E-05 1.123E-04 5.962E-04 1.434E-03 2.594E-03 4.042E-03 5.746E-03 7.669E-03 9.777E-03 1.204E-02 1.441E-02 1.687E-02 1.937E-02 2.189E-02 2.440E-02 2.687E-02 2.927E-02 3.157E-02 3.376E-02 3.582E-02 3.772E-02 3.944E-02 4.098E-02 4.233E-02 4.347E-02 4.440E-02 4.512E-02 4.562E-02 4.590E-02 4.596E-02 4.592E-02 4.567E-02 4.520E-02 4.451E-02 4.361E-02 4.250E-02 4.118E-02 3.967E-02 3.796E-02 3.609E-02 3.406E-02 3.189E-02 2.961E-02 2.722E-02 2.477E-02 2.226E-02 1.974E-02 1.724E-02 1.478E-02 1.239E-02 1.012E-02 7.986E-03 6.034E-03 4.296E-03 2.807E-03 1.601E-03 7.096E-04 1.664E-04 1.402E-06 2.431E-04 9.178E-04 2.049E-03 3.658E-03 5.762E-03 8.375E-03 1.151E-02 1.516E-02 1.935E-02 2.406E-02 2.928E-02 3.501E-02 4.123E-02 4.791E-02 5.503E-02 6.255E-02 7.045E-02 7.867E-02 8.717E-02 9.590E-02 1.048E-01 1.138E-01 1.229E-01 1.320E-01 1.410E-01 1.498E-01 1.585E-01 1.668E-01 1.748E-01 1.824E-01 1.895E-01 1.960E-01 2.019E-01 2.071E-01 2.115E-01 2.152E-01 2.180E-01 2.200E-01 2.210E-01 2.211E-01 2.202E-01 2.183E-01 2.155E-01 2.117E-01 2.070E-01 2.014E-01 1.948E-01 1.875E-01 1.793E-01 1.704E-01 1.609E-01 1.508E-01 1.403E-01 1.293E-01 1.182E-01 1.068E-01 9.543E-02 8.413E-02 7.305E-02 6.230E-02 5.201E-02 4.231E-02 3.333E-02 2.519E-02 1.801E-02 1.189E-02 6.941E-03 3.258E-03 9.237E-04 1.105E-05 5.789E-04 2.672E-03 6.319E-03 1.153E-02 1.831E-02 2.662E-02 3.642E-02 4.766E-02 6.024E-02 7.408E-02 8.903E-02 1.050E-01 1.217E-01 1.391E-01 1.570E-01 1.750E-01 1.931E-01 2.110E-01 2.284E-01 2.451E-01 2.609E-01 2.755E-01 2.887E-01 3.003E-01 3.100E-01 3.178E-01 3.234E-01 3.268E-01 3.280E-01 3.268E-01 3.234E-01 3.178E-01 3.100E-01 3.003E-01 2.887E-01 2.755E-01 2.609E-01 2.451E-01 2.284E-01 2.110E-01 1.931E-01 1.750E-01 1.570E-01 1.391E-01 1.217E-01 1.050E-01 8.903E-02 7.408E-02 6.024E-02 4.766E-02 3.642E-02 2.662E-02 1.831E-02 1.153E-02 6.319E-03 2.672E-03 5.789E-04 1.105E-05 9.237E-04 3.258E-03 6.941E-03 1.189E-02 1.801E-02 2.519E-02 3.333E-02 4.231E-02 5.201E-02 6.230E-02 7.305E-02 8.413E-02 9.543E-02 1.068E-01 1.182E-01 1.293E-01 1.403E-01 1.508E-01 1.609E-01 1.704E-01 1.793E-01 1.875E-01 1.948E-01 2.014E-01 2.070E-01 2.117E-01 2.155E-01 2.183E-01 2.202E-01 2.211E-01 2.210E-01 2.200E-01 2.180E-01 2.152E-01 2.115E-01 2.071E-01 2.019E-01 1.960E-01 1.895E-01 1.824E-01 1.748E-01 1.668E-01 1.585E-01 1.498E-01 1.410E-01 1.320E-01 1.229E-01 1.138E-01 1.048E-01 9.590E-02 8.717E-02 7.867E-02 7.045E-02 6.255E-02 5.503E-02 4.791E-02 4.123E-02 3.501E-02 2.928E-02 2.406E-02 1.935E-02 1.516E-02 1.151E-02 8.375E-03 5.762E-03 3.658E-03 2.049E-03 9.178E-04 2.431E-04 1.402E-06 1.664E-04 7.096E-04 1.601E-03 2.807E-03 4.296E-03 6.034E-03 7.986E-03 1.012E-02 1.239E-02 1.478E-02 1.724E-02 1.974E-02 2.226E-02 2.477E-02 2.722E-02 2.961E-02 3.189E-02 3.406E-02 3.609E-02 3.796E-02 3.967E-02 4.118E-02 4.250E-02 4.361E-02 4.451E-02 4.520E-02 4.567E-02 4.592E-02 4.595E-02 4.594E-02 4.572E-02 4.528E-02 4.462E-02 4.375E-02 4.267E-02 4.138E-02 3.990E-02 3.823E-02 3.638E-02 3.437E-02 3.223E-02 2.996E-02 2.759E-02 2.515E-02 2.266E-02 2.014E-02 1.763E-02 1.517E-02 1.277E-02 1.048E-02 8.326E-03 6.345E-03 4.572E-03 3.041E-03 1.786E-03 8.399E-04 2.350E-04 1.762E-06 1.690E-04 7.631E-04 1.808E-03 3.325E-03 5.332E-03 7.844E-03 1.087E-02 1.442E-02 1.849E-02 2.309E-02 2.820E-02 3.382E-02 3.993E-02 4.650E-02 5.351E-02 6.094E-02 6.874E-02 7.687E-02 8.529E-02 9.395E-02 1.028E-01 1.118E-01 1.208E-01 1.299E-01 1.389E-01 1.477E-01 1.564E-01 1.648E-01 1.728E-01 1.805E-01 1.877E-01 1.943E-01 2.004E-01 2.057E-01 2.104E-01 2.143E-01 2.173E-01 2.195E-01 2.208E-01 2.211E-01 2.206E-01 2.190E-01 2.165E-01 2.130E-01 2.086E-01 2.033E-01 1.971E-01 1.901E-01 1.822E-01 1.737E-01 1.644E-01 1.546E-01 1.443E-01 1.336E-01 1.226E-01 1.114E-01 1.001E-01 8.891E-02 7.784E-02 6.704E-02 5.665E-02 4.679E-02 3.757E-02 2.912E-02 2.155E-02 1.497E-02 9.473E-03 5.157E-03 2.103E-03 3.816E-04 5.039E-05 1.154E-03 3.721E-03 7.765E-03 1.328E-02 2.025E-02 2.863E-02 3.837E-02 4.938E-02 6.158E-02 7.484E-02 8.903E-02 1.040E-01 1.196E-01 1.356E-01 1.519E-01 1.682E-01 1.843E-01 2.000E-01 2.151E-01 2.293E-01 2.424E-01 2.543E-01 2.647E-01 2.735E-01 2.805E-01 2.856E-01 2.887E-01 2.897E-01 2.887E-01 2.856E-01 2.805E-01 2.735E-01 2.647E-01 2.543E-01 2.424E-01 2.293E-01 2.151E-01 2.000E-01 1.843E-01 1.682E-01 1.519E-01 1.356E-01 1.196E-01 1.040E-01 8.903E-02 7.484E-02 6.158E-02 4.938E-02 3.837E-02 2.863E-02 2.025E-02 1.328E-02 7.765E-03 3.721E-03 1.154E-03 5.039E-05 3.816E-04 2.103E-03 5.157E-03 9.473E-03 1.497E-02 2.155E-02 2.912E-02 3.757E-02 4.679E-02 5.665E-02 6.704E-02 7.784E-02 8.891E-02 1.001E-01 1.114E-01 1.226E-01 1.336E-01 1.443E-01 1.546E-01 1.644E-01 1.737E-01 1.822E-01 1.901E-01 1.971E-01 2.033E-01 2.086E-01 2.130E-01 2.165E-01 2.190E-01 2.206E-01 2.211E-01 2.208E-01 2.195E-01 2.173E-01 2.143E-01 2.104E-01 2.057E-01 2.004E-01 1.943E-01 1.877E-01 1.805E-01 1.728E-01 1.648E-01 1.564E-01 1.477E-01 1.389E-01 1.299E-01 1.208E-01 1.118E-01 1.028E-01 9.395E-02 8.529E-02 7.687E-02 6.874E-02 6.094E-02 5.351E-02 4.650E-02 3.993E-02 3.382E-02 2.820E-02 2.309E-02 1.849E-02 1.442E-02 1.087E-02 7.844E-03 5.332E-03 3.325E-03 1.808E-03 7.631E-04 1.690E-04 1.762E-06 2.350E-04 8.399E-04 1.786E-03 3.041E-03 4.572E-03 6.345E-03 8.326E-03 1.048E-02 1.277E-02 1.517E-02 1.763E-02 2.014E-02 2.266E-02 2.515E-02 2.759E-02 2.996E-02 3.223E-02 3.437E-02 3.638E-02 3.823E-02 3.990E-02 4.138E-02 4.267E-02 4.375E-02 4.462E-02 4.528E-02 4.572E-02 4.594E-02 4.593E-02 4.595E-02 4.576E-02 4.536E-02 4.473E-02 4.390E-02 4.285E-02 4.159E-02 4.014E-02 3.850E-02 3.668E-02 3.470E-02 3.258E-02 3.033E-02 2.798E-02 2.555E-02 2.307E-02 2.056E-02 1.805E-02 1.558E-02 1.317E-02 1.087E-02 8.690E-03 6.680E-03 4.871E-03 3.296E-03 1.991E-03 9.884E-04 3.197E-04 1.574E-05 1.055E-04 6.158E-04 1.571E-03 2.992E-03 4.898E-03 7.304E-03 1.022E-02 1.366E-02 1.762E-02 2.209E-02 2.709E-02 3.259E-02 3.857E-02 4.503E-02 5.193E-02 5.925E-02 6.695E-02 7.499E-02 8.332E-02 9.191E-02 1.007E-01 1.096E-01 1.186E-01 1.276E-01 1.366E-01 1.455E-01 1.542E-01 1.626E-01 1.708E-01 1.785E-01 1.858E-01 1.926E-01 1.987E-01 2.043E-01 2.091E-01 2.132E-01 2.165E-01 2.189E-01 2.205E-01 2.211E-01 2.208E-01 2.196E-01 2.174E-01 2.143E-01 2.103E-01 2.053E-01 1.994E-01 1.927E-01 1.852E-01 1.770E-01 1.680E-01 1.585E-01 1.485E-01 1.380E-01 1.272E-01 1.162E-01 1.051E-01 9.394E-02 8.290E-02 7.209E-02 6.162E-02 5.161E-02 4.219E-02 3.345E-02 2.552E-02 1.850E-02 1.248E-02 7.561E-03 3.813E-03 1.310E-03 1.066E-04 2.485E-04 1.765E-03 4.670E-03 8.962E-03 1.462E-02 2.162E-02 2.989E-02 3.937E-02 4.997E-02 6.158E-02 7.408E-02 8.732E-02 1.012E-01 1.154E-01 1.299E-01 1.445E-01 1.589E-01 1.730E-01 1.865E-01 1.992E-01 2.110E-01 2.217E-01 2.310E-01 2.389E-01 2.451E-01 2.497E-01 2.525E-01 2.534E-01 2.525E-01 2.497E-01 2.451E-01 2.389E-01 2.310E-01 2.217E-01 2.110E-01 1.992E-01 1.865E-01 1.730E-01 1.589E-01 1.445E-01 1.299E-01 1.154E-01 1.012E-01 8.732E-02 7.408E-02 6.158E-02 4.997E-02 3.937E-02 2.989E-02 2.162E-02 1.462E-02 8.962E-03 4.670E-03 1.765E-03 2.485E-04 1.066E-04 1.310E-03 3.813E-03 7.561E-03 1.248E-02 1.850E-02 2.552E-02 3.345E-02 4.219E-02 5.161E-02 6.162E-02 7.209E-02 8.290E-02 9.394E-02 1.051E-01 1.162E-01 1.272E-01 1.380E-01 1.485E-01 1.585E-01 1.680E-01 1.770E-01 1.852E-01 1.927E-01 1.994E-01 2.053E-01 2.103E-01 2.143E-01 2.174E-01 2.196E-01 2.208E-01 2.211E-01 2.205E-01 2.189E-01 2.165E-01 2.132E-01 2.091E-01 2.043E-01 1.987E-01 1.926E-01 1.858E-01 1.785E-01 1.708E-01 1.626E-01 1.542E-01 1.455E-01 1.366E-01 1.276E-01 1.186E-01 1.096E-01 1.007E-01 9.191E-02 8.332E-02 7.499E-02 6.695E-02 5.925E-02 5.193E-02 4.503E-02 3.857E-02 3.259E-02 2.709E-02 2.209E-02 1.762E-02 1.366E-02 1.022E-02 7.304E-03 4.898E-03 2.992E-03 1.571E-03 6.158E-04 1.055E-04 1.574E-05 3.197E-04 9.884E-04 1.991E-03 3.296E-03 4.871E-03 6.680E-03 8.690E-03 1.087E-02 1.317E-02 1.558E-02 1.805E-02 2.056E-02 2.307E-02 2.555E-02 2.798E-02 3.033E-02 3.258E-02 3.470E-02 3.668E-02 3.850E-02 4.014E-02 4.159E-02 4.285E-02 4.390E-02 4.473E-02 4.536E-02 4.576E-02 4.595E-02 4.591E-02 4.597E-02 4.581E-02 4.543E-02 4.485E-02 4.404E-02 4.303E-02 4.181E-02 4.039E-02 3.878E-02 3.699E-02 3.504E-02 3.295E-02 3.072E-02 2.839E-02 2.598E-02 2.350E-02 2.100E-02 1.850E-02 1.602E-02 1.360E-02 1.128E-02 9.078E-03 7.039E-03 5.193E-03 3.575E-03 2.218E-03 1.157E-03 4.223E-04 4.531E-05 5.502E-05 4.784E-04 1.340E-03 2.662E-03 4.463E-03 6.759E-03 9.561E-03 1.288E-02 1.671E-02 2.107E-02 2.594E-02 3.131E-02 3.718E-02 4.351E-02 5.030E-02 5.750E-02 6.509E-02 7.303E-02 8.127E-02 8.977E-02 9.848E-02 1.073E-01 1.163E-01 1.253E-01 1.343E-01 1.431E-01 1.519E-01 1.603E-01 1.685E-01 1.764E-01 1.838E-01 1.906E-01 1.970E-01 2.027E-01 2.077E-01 2.120E-01 2.155E-01 2.182E-01 2.201E-01 2.210E-01 2.210E-01 2.201E-01 2.183E-01 2.155E-01 2.118E-01 2.072E-01 2.017E-01 1.954E-01 1.882E-01 1.803E-01 1.717E-01 1.625E-01 1.528E-01 1.426E-01 1.320E-01 1.212E-01 1.102E-01 9.920E-02 8.823E-02 7.743E-02 6.691E-02 5.679E-02 4.718E-02 3.819E-02 2.993E-02 2.250E-02 1.599E-02 1.049E-02 6.085E-03 2.832E-03 7.923E-04 8.147E-06 5.102E-04 2.314E-03 5.421E-03 9.814E-03 1.546E-02 2.232E-02 3.031E-02 3.937E-02 4.938E-02 6.024E-02 7.182E-02 8.397E-02 9.654E-02 1.094E-01 1.223E-01 1.350E-01 1.475E-01 1.595E-01 1.709E-01 1.814E-01 1.909E-01 1.992E-01 2.062E-01 2.118E-01 2.159E-01 2.183E-01 2.192E-01 2.183E-01 2.159E-01 2.118E-01 2.062E-01 1.992E-01 1.909E-01 1.814E-01 1.709E-01 1.595E-01 1.475E-01 1.350E-01 1.223E-01 1.094E-01 9.654E-02 8.397E-02 7.182E-02 6.024E-02 4.938E-02 3.937E-02 3.031E-02 2.232E-02 1.546E-02 9.814E-03 5.421E-03 2.314E-03 5.102E-04 8.147E-06 7.923E-04 2.832E-03 6.085E-03 1.049E-02 1.599E-02 2.250E-02 2.993E-02 3.819E-02 4.718E-02 5.679E-02 6.691E-02 7.743E-02 8.823E-02 9.920E-02 1.102E-01 1.212E-01 1.320E-01 1.426E-01 1.528E-01 1.625E-01 1.717E-01 1.803E-01 1.882E-01 1.954E-01 2.017E-01 2.072E-01 2.118E-01 2.155E-01 2.183E-01 2.201E-01 2.210E-01 2.210E-01 2.201E-01 2.182E-01 2.155E-01 2.120E-01 2.077E-01 2.027E-01 1.970E-01 1.906E-01 1.838E-01 1.764E-01 1.685E-01 1.603E-01 1.519E-01 1.431E-01 1.343E-01 1.253E-01 1.163E-01 1.073E-01 9.848E-02 8.977E-02 8.127E-02 7.303E-02 6.509E-02 5.750E-02 5.030E-02 4.351E-02 3.718E-02 3.131E-02 2.594E-02 2.107E-02 1.671E-02 1.288E-02 9.561E-03 6.759E-03 4.463E-03 2.662E-03 1.340E-03 4.784E-04 5.502E-05 4.531E-05 4.223E-04 1.157E-03 2.218E-03 3.575E-03 5.193E-03 7.039E-03 9.078E-03 1.128E-02 1.360E-02 1.602E-02 1.850E-02 2.100E-02 2.350E-02 2.598E-02 2.839E-02 3.072E-02 3.295E-02 3.504E-02 3.699E-02 3.878E-02 4.039E-02 4.181E-02 4.303E-02 4.404E-02 4.485E-02 4.543E-02 4.581E-02 4.597E-02 4.589E-02 4.597E-02 4.585E-02 4.551E-02 4.496E-02 4.419E-02 4.321E-02 4.203E-02 4.064E-02 3.907E-02 3.731E-02 3.539E-02 3.333E-02 3.113E-02 2.882E-02 2.642E-02 2.396E-02 2.146E-02 1.896E-02 1.648E-02 1.405E-02 1.171E-02 9.492E-03 7.422E-03 5.539E-03 3.877E-03 2.468E-03 1.347E-03 5.445E-04 9.249E-05 1.967E-05 3.533E-04 1.118E-03 2.337E-03 4.029E-03 6.210E-03 8.893E-03 1.209E-02 1.580E-02 2.002E-02 2.476E-02 3.000E-02 3.574E-02 4.194E-02 4.860E-02 5.569E-02 6.316E-02 7.099E-02 7.913E-02 8.755E-02 9.618E-02 1.050E-01 1.139E-01 1.228E-01 1.318E-01 1.407E-01 1.494E-01 1.579E-01 1.662E-01 1.741E-01 1.816E-01 1.886E-01 1.951E-01 2.010E-01 2.062E-01 2.107E-01 2.145E-01 2.174E-01 2.195E-01 2.208E-01 2.211E-01 2.206E-01 2.191E-01 2.167E-01 2.133E-01 2.091E-01 2.040E-01 1.980E-01 1.912E-01 1.837E-01 1.755E-01 1.666E-01 1.572E-01 1.473E-01 1.370E-01 1.264E-01 1.156E-01 1.047E-01 9.380E-02 8.304E-02 7.250E-02 6.230E-02 5.254E-02 4.333E-02 3.477E-02 2.697E-02 2.001E-02 1.397E-02 8.941E-03 4.980E-03 2.143E-03 4.758E-04 7.911E-06 7.568E-04 2.725E-03 5.901E-03 1.026E-02 1.575E-02 2.232E-02 2.989E-02 3.837E-02 4.766E-02 5.764E-02 6.817E-02 7.912E-02 9.032E-02 1.016E-01 1.129E-01 1.239E-01 1.345E-01 1.445E-01 1.538E-01 1.622E-01 1.695E-01 1.757E-01 1.807E-01 1.843E-01 1.865E-01 1.872E-01 1.865E-01 1.843E-01 1.807E-01 1.757E-01 1.695E-01 1.622E-01 1.538E-01 1.445E-01 1.345E-01 1.239E-01 1.129E-01 1.016E-01 9.032E-02 7.912E-02 6.817E-02 5.764E-02 4.766E-02 3.837E-02 2.989E-02 2.232E-02 1.575E-02 1.026E-02 5.901E-03 2.725E-03 7.568E-04 7.911E-06 4.758E-04 2.143E-03 4.980E-03 8.941E-03 1.397E-02 2.001E-02 2.697E-02 3.477E-02 4.333E-02 5.254E-02 6.230E-02 7.250E-02 8.304E-02 9.380E-02 1.047E-01 1.156E-01 1.264E-01 1.370E-01 1.473E-01 1.572E-01 1.666E-01 1.755E-01 1.837E-01 1.912E-01 1.980E-01 2.040E-01 2.091E-01 2.133E-01 2.167E-01 2.191E-01 2.206E-01 2.211E-01 2.208E-01 2.195E-01 2.174E-01 2.145E-01 2.107E-01 2.062E-01 2.010E-01 1.951E-01 1.886E-01 1.816E-01 1.741E-01 1.662E-01 1.579E-01 1.494E-01 1.407E-01 1.318E-01 1.228E-01 1.139E-01 1.050E-01 9.618E-02 8.755E-02 7.913E-02 7.099E-02 6.316E-02 5.569E-02 4.860E-02 4.194E-02 3.574E-02 3.000E-02 2.476E-02 2.002E-02 1.580E-02 1.209E-02 8.893E-03 6.210E-03 4.029E-03 2.337E-03 1.118E-03 3.533E-04 1.967E-05 9.249E-05 5.445E-04 1.347E-03 2.468E-03 3.877E-03 5.539E-03 7.422E-03 9.492E-03 1.171E-02 1.405E-02 1.648E-02 1.896E-02 2.146E-02 2.396E-02 2.642E-02 2.882E-02 3.113E-02 3.333E-02 3.539E-02 3.731E-02 3.907E-02 4.064E-02 4.203E-02 4.321E-02 4.419E-02 4.496E-02 4.551E-02 4.585E-02 4.597E-02 4.585E-02 4.597E-02 4.588E-02 4.558E-02 4.507E-02 4.434E-02 4.340E-02 4.225E-02 4.091E-02 3.937E-02 3.765E-02 3.576E-02 3.372E-02 3.155E-02 2.926E-02 2.688E-02 2.443E-02 2.195E-02 1.945E-02 1.697E-02 1.453E-02 1.218E-02 9.931E-03 7.832E-03 5.911E-03 4.203E-03 2.742E-03 1.559E-03 6.883E-04 1.593E-04 1.764E-06 2.431E-04 9.085E-04 2.021E-03 3.600E-03 5.662E-03 8.221E-03 1.129E-02 1.486E-02 1.896E-02 2.356E-02 2.866E-02 3.426E-02 4.033E-02 4.686E-02 5.382E-02 6.117E-02 6.888E-02 7.692E-02 8.524E-02 9.379E-02 1.025E-01 1.114E-01 1.203E-01 1.292E-01 1.381E-01 1.468E-01 1.554E-01 1.637E-01 1.717E-01 1.793E-01 1.864E-01 1.930E-01 1.991E-01 2.045E-01 2.093E-01 2.133E-01 2.165E-01 2.189E-01 2.204E-01 2.211E-01 2.209E-01 2.198E-01 2.177E-01 2.148E-01 2.109E-01 2.062E-01 2.006E-01 1.942E-01 1.871E-01 1.792E-01 1.707E-01 1.616E-01 1.520E-01 1.420E-01 1.317E-01 1.211E-01 1.104E-01 9.961E-02 8.891E-02 7.838E-02 6.813E-02 5.826E-02 4.886E-02 4.005E-02 3.191E-02 2.454E-02 1.801E-02 1.240E-02 7.773E-03 4.187E-03 1.685E-03 2.974E-04 4.383E-05 9.292E-04 2.944E-03 6.066E-03 1.026E-02 1.546E-02 2.162E-02 2.863E-02 3.642E-02 4.487E-02 5.387E-02 6.327E-02 7.294E-02 8.274E-02 9.251E-02 1.021E-01 1.114E-01 1.201E-01 1.283E-01 1.356E-01 1.421E-01 1.475E-01 1.519E-01 1.550E-01 1.570E-01 1.576E-01 1.570E-01 1.550E-01 1.519E-01 1.475E-01 1.421E-01 1.356E-01 1.283E-01 1.201E-01 1.114E-01 1.021E-01 9.251E-02 8.274E-02 7.294E-02 6.327E-02 5.387E-02 4.487E-02 3.642E-02 2.863E-02 2.162E-02 1.546E-02 1.026E-02 6.066E-03 2.944E-03 9.292E-04 4.383E-05 2.974E-04 1.685E-03 4.187E-03 7.773E-03 1.240E-02 1.801E-02 2.454E-02 3.191E-02 4.005E-02 4.886E-02 5.826E-02 6.813E-02 7.838E-02 8.891E-02 9.961E-02 1.104E-01 1.211E-01 1.317E-01 1.420E-01 1.520E-01 1.616E-01 1.707E-01 1.792E-01 1.871E-01 1.942E-01 2.006E-01 2.062E-01 2.109E-01 2.148E-01 2.177E-01 2.198E-01 2.209E-01 2.211E-01 2.204E-01 2.189E-01 2.165E-01 2.133E-01 2.093E-01 2.045E-01 1.991E-01 1.930E-01 1.864E-01 1.793E-01 1.717E-01 1.637E-01 1.554E-01 1.468E-01 1.381E-01 1.292E-01 1.203E-01 1.114E-01 1.025E-01 9.379E-02 8.524E-02 7.692E-02 6.888E-02 6.117E-02 5.382E-02 4.686E-02 4.033E-02 3.426E-02 2.866E-02 2.356E-02 1.896E-02 1.486E-02 1.129E-02 8.221E-03 5.662E-03 3.600E-03 2.021E-03 9.085E-04 2.431E-04 1.764E-06 1.593E-04 6.883E-04 1.559E-03 2.742E-03 4.203E-03 5.911E-03 7.832E-03 9.931E-03 1.218E-02 1.453E-02 1.697E-02 1.945E-02 2.195E-02 2.443E-02 2.688E-02 2.926E-02 3.155E-02 3.372E-02 3.576E-02 3.765E-02 3.937E-02 4.091E-02 4.225E-02 4.340E-02 4.434E-02 4.507E-02 4.558E-02 4.588E-02 4.597E-02 4.581E-02 4.597E-02 4.591E-02 4.565E-02 4.518E-02 4.449E-02 4.359E-02 4.248E-02 4.117E-02 3.967E-02 3.799E-02 3.613E-02 3.413E-02 3.198E-02 2.972E-02 2.736E-02 2.493E-02 2.245E-02 1.996E-02 1.748E-02 1.503E-02 1.266E-02 1.040E-02 8.267E-03 6.309E-03 4.556E-03 3.041E-03 1.797E-03 8.554E-04 2.478E-04 3.609E-06 1.503E-04 7.135E-04 1.716E-03 3.179E-03 5.119E-03 7.550E-03 1.048E-02 1.392E-02 1.787E-02 2.233E-02 2.730E-02 3.275E-02 3.868E-02 4.507E-02 5.189E-02 5.912E-02 6.671E-02 7.463E-02 8.285E-02 9.130E-02 9.995E-02 1.087E-01 1.176E-01 1.265E-01 1.354E-01 1.441E-01 1.527E-01 1.611E-01 1.691E-01 1.768E-01 1.841E-01 1.908E-01 1.971E-01 2.027E-01 2.077E-01 2.119E-01 2.154E-01 2.181E-01 2.200E-01 2.210E-01 2.211E-01 2.203E-01 2.187E-01 2.161E-01 2.126E-01 2.083E-01 2.032E-01 1.972E-01 1.904E-01 1.830E-01 1.748E-01 1.661E-01 1.568E-01 1.471E-01 1.371E-01 1.267E-01 1.162E-01 1.056E-01 9.502E-02 8.454E-02 7.428E-02 6.433E-02 5.479E-02 4.576E-02 3.733E-02 2.958E-02 2.260E-02 1.646E-02 1.122E-02 6.941E-03 3.658E-03 1.408E-03 2.099E-04 7.283E-05 9.907E-04 2.944E-03 5.901E-03 9.814E-03 1.462E-02 2.025E-02 2.662E-02 3.362E-02 4.115E-02 4.909E-02 5.732E-02 6.569E-02 7.408E-02 8.233E-02 9.032E-02 9.791E-02 1.050E-01 1.114E-01 1.170E-01 1.217E-01 1.255E-01 1.283E-01 1.299E-01 1.305E-01 1.299E-01 1.283E-01 1.255E-01 1.217E-01 1.170E-01 1.114E-01 1.050E-01 9.791E-02 9.032E-02 8.233E-02 7.408E-02 6.569E-02 5.732E-02 4.909E-02 4.115E-02 3.362E-02 2.662E-02 2.025E-02 1.462E-02 9.814E-03 5.901E-03 2.944E-03 9.907E-04 7.283E-05 2.099E-04 1.408E-03 3.658E-03 6.941E-03 1.122E-02 1.646E-02 2.260E-02 2.958E-02 3.733E-02 4.576E-02 5.479E-02 6.433E-02 7.428E-02 8.454E-02 9.502E-02 1.056E-01 1.162E-01 1.267E-01 1.371E-01 1.471E-01 1.568E-01 1.661E-01 1.748E-01 1.830E-01 1.904E-01 1.972E-01 2.032E-01 2.083E-01 2.126E-01 2.161E-01 2.187E-01 2.203E-01 2.211E-01 2.210E-01 2.200E-01 2.181E-01 2.154E-01 2.119E-01 2.077E-01 2.027E-01 1.971E-01 1.908E-01 1.841E-01 1.768E-01 1.691E-01 1.611E-01 1.527E-01 1.441E-01 1.354E-01 1.265E-01 1.176E-01 1.087E-01 9.995E-02 9.130E-02 8.285E-02 7.463E-02 6.671E-02 5.912E-02 5.189E-02 4.507E-02 3.868E-02 3.275E-02 2.730E-02 2.233E-02 1.787E-02 1.392E-02 1.048E-02 7.550E-03 5.119E-03 3.179E-03 1.716E-03 7.135E-04 1.503E-04 3.609E-06 2.478E-04 8.554E-04 1.797E-03 3.041E-03 4.556E-03 6.309E-03 8.267E-03 1.040E-02 1.266E-02 1.503E-02 1.748E-02 1.996E-02 2.245E-02 2.493E-02 2.736E-02 2.972E-02 3.198E-02 3.413E-02 3.613E-02 3.799E-02 3.967E-02 4.117E-02 4.248E-02 4.359E-02 4.449E-02 4.518E-02 4.565E-02 4.591E-02 4.597E-02 4.576E-02 4.595E-02 4.594E-02 4.572E-02 4.528E-02 4.464E-02 4.378E-02 4.271E-02 4.145E-02 3.998E-02 3.834E-02 3.652E-02 3.454E-02 3.243E-02 3.019E-02 2.786E-02 2.544E-02 2.298E-02 2.049E-02 1.801E-02 1.556E-02 1.317E-02 1.089E-02 8.729E-03 6.735E-03 4.936E-03 3.367E-03 2.060E-03 1.047E-03 3.601E-04 2.751E-05 7.755E-05 5.360E-04 1.426E-03 2.770E-03 4.583E-03 6.882E-03 9.678E-03 1.298E-02 1.678E-02 2.110E-02 2.591E-02 3.122E-02 3.700E-02 4.324E-02 4.992E-02 5.701E-02 6.447E-02 7.228E-02 8.038E-02 8.874E-02 9.730E-02 1.060E-01 1.148E-01 1.237E-01 1.325E-01 1.413E-01 1.499E-01 1.583E-01 1.664E-01 1.742E-01 1.816E-01 1.885E-01 1.949E-01 2.007E-01 2.059E-01 2.104E-01 2.141E-01 2.171E-01 2.193E-01 2.207E-01 2.211E-01 2.208E-01 2.195E-01 2.173E-01 2.143E-01 2.104E-01 2.056E-01 2.001E-01 1.937E-01 1.867E-01 1.790E-01 1.706E-01 1.617E-01 1.523E-01 1.426E-01 1.325E-01 1.222E-01 1.118E-01 1.013E-01 9.095E-02 8.071E-02 7.072E-02 6.108E-02 5.188E-02 4.320E-02 3.513E-02 2.776E-02 2.114E-02 1.534E-02 1.041E-02 6.409E-03 3.356E-03 1.278E-03 1.840E-04 7.283E-05 9.292E-04 2.725E-03 5.421E-03 8.962E-03 1.328E-02 1.831E-02 2.395E-02 3.010E-02 3.666E-02 4.352E-02 5.055E-02 5.764E-02 6.465E-02 7.145E-02 7.793E-02 8.397E-02 8.946E-02 9.429E-02 9.837E-02 1.016E-01 1.040E-01 1.054E-01 1.059E-01 1.054E-01 1.040E-01 1.016E-01 9.837E-02 9.429E-02 8.946E-02 8.397E-02 7.793E-02 7.145E-02 6.465E-02 5.764E-02 5.055E-02 4.352E-02 3.666E-02 3.010E-02 2.395E-02 1.831E-02 1.328E-02 8.962E-03 5.421E-03 2.725E-03 9.292E-04 7.283E-05 1.840E-04 1.278E-03 3.356E-03 6.409E-03 1.041E-02 1.534E-02 2.114E-02 2.776E-02 3.513E-02 4.320E-02 5.188E-02 6.108E-02 7.072E-02 8.071E-02 9.095E-02 1.013E-01 1.118E-01 1.222E-01 1.325E-01 1.426E-01 1.523E-01 1.617E-01 1.706E-01 1.790E-01 1.867E-01 1.937E-01 2.001E-01 2.056E-01 2.104E-01 2.143E-01 2.173E-01 2.195E-01 2.208E-01 2.211E-01 2.207E-01 2.193E-01 2.171E-01 2.141E-01 2.104E-01 2.059E-01 2.007E-01 1.949E-01 1.885E-01 1.816E-01 1.742E-01 1.664E-01 1.583E-01 1.499E-01 1.413E-01 1.325E-01 1.237E-01 1.148E-01 1.060E-01 9.730E-02 8.874E-02 8.038E-02 7.228E-02 6.447E-02 5.701E-02 4.992E-02 4.324E-02 3.700E-02 3.122E-02 2.591E-02 2.110E-02 1.678E-02 1.298E-02 9.678E-03 6.882E-03 4.583E-03 2.770E-03 1.426E-03 5.360E-04 7.755E-05 2.751E-05 3.601E-04 1.047E-03 2.060E-03 3.367E-03 4.936E-03 6.735E-03 8.729E-03 1.089E-02 1.317E-02 1.556E-02 1.801E-02 2.049E-02 2.298E-02 2.544E-02 2.786E-02 3.019E-02 3.243E-02 3.454E-02 3.652E-02 3.834E-02 3.998E-02 4.145E-02 4.271E-02 4.378E-02 4.464E-02 4.528E-02 4.572E-02 4.594E-02 4.595E-02 4.570E-02 4.593E-02 4.596E-02 4.578E-02 4.539E-02 4.478E-02 4.397E-02 4.295E-02 4.172E-02 4.030E-02 3.869E-02 3.691E-02 3.497E-02 3.289E-02 3.068E-02 2.837E-02 2.598E-02 2.353E-02 2.105E-02 1.856E-02 1.611E-02 1.371E-02 1.140E-02 9.219E-03 7.188E-03 5.344E-03 3.721E-03 2.351E-03 1.266E-03 4.981E-04 7.576E-05 2.738E-05 3.791E-04 1.155E-03 2.375E-03 4.060E-03 6.223E-03 8.877E-03 1.203E-02 1.569E-02 1.985E-02 2.451E-02 2.966E-02 3.529E-02 4.138E-02 4.791E-02 5.486E-02 6.218E-02 6.986E-02 7.784E-02 8.609E-02 9.456E-02 1.032E-01 1.120E-01 1.208E-01 1.296E-01 1.383E-01 1.469E-01 1.554E-01 1.636E-01 1.714E-01 1.789E-01 1.860E-01 1.926E-01 1.986E-01 2.040E-01 2.087E-01 2.127E-01 2.160E-01 2.185E-01 2.202E-01 2.210E-01 2.210E-01 2.202E-01 2.184E-01 2.158E-01 2.123E-01 2.080E-01 2.029E-01 1.970E-01 1.904E-01 1.830E-01 1.751E-01 1.666E-01 1.576E-01 1.482E-01 1.384E-01 1.284E-01 1.182E-01 1.079E-01 9.759E-02 8.741E-02 7.743E-02 6.772E-02 5.839E-02 4.952E-02 4.118E-02 3.345E-02 2.641E-02 2.011E-02 1.460E-02 9.939E-03 6.149E-03 3.258E-03 1.278E-03 2.099E-04 4.383E-05 7.568E-04 2.314E-03 4.670E-03 7.765E-03 1.153E-02 1.589E-02 2.076E-02 2.603E-02 3.161E-02 3.739E-02 4.325E-02 4.909E-02 5.479E-02 6.024E-02 6.534E-02 6.998E-02 7.408E-02 7.754E-02 8.031E-02 8.233E-02 8.356E-02 8.397E-02 8.356E-02 8.233E-02 8.031E-02 7.754E-02 7.408E-02 6.998E-02 6.534E-02 6.024E-02 5.479E-02 4.909E-02 4.325E-02 3.739E-02 3.161E-02 2.603E-02 2.076E-02 1.589E-02 1.153E-02 7.765E-03 4.670E-03 2.314E-03 7.568E-04 4.383E-05 2.099E-04 1.278E-03 3.258E-03 6.149E-03 9.939E-03 1.460E-02 2.011E-02 2.641E-02 3.345E-02 4.118E-02 4.952E-02 5.839E-02 6.772E-02 7.743E-02 8.741E-02 9.759E-02 1.079E-01 1.182E-01 1.284E-01 1.384E-01 1.482E-01 1.576E-01 1.666E-01 1.751E-01 1.830E-01 1.904E-01 1.970E-01 2.029E-01 2.080E-01 2.123E-01 2.158E-01 2.184E-01 2.202E-01 2.210E-01 2.210E-01 2.202E-01 2.185E-01 2.160E-01 2.127E-01 2.087E-01 2.040E-01 1.986E-01 1.926E-01 1.860E-01 1.789E-01 1.714E-01 1.636E-01 1.554E-01 1.469E-01 1.383E-01 1.296E-01 1.208E-01 1.120E-01 1.032E-01 9.456E-02 8.609E-02 7.784E-02 6.986E-02 6.218E-02 5.486E-02 4.791E-02 4.138E-02 3.529E-02 2.966E-02 2.451E-02 1.985E-02 1.569E-02 1.203E-02 8.877E-03 6.223E-03 4.060E-03 2.375E-03 1.155E-03 3.791E-04 2.738E-05 7.576E-05 4.981E-04 1.266E-03 2.351E-03 3.721E-03 5.344E-03 7.188E-03 9.219E-03 1.140E-02 1.371E-02 1.611E-02 1.856E-02 2.105E-02 2.353E-02 2.598E-02 2.837E-02 3.068E-02 3.289E-02 3.497E-02 3.691E-02 3.869E-02 4.030E-02 4.172E-02 4.295E-02 4.397E-02 4.478E-02 4.539E-02 4.578E-02 4.596E-02 4.593E-02 4.563E-02 4.590E-02 4.597E-02 4.583E-02 4.548E-02 4.492E-02 4.416E-02 4.318E-02 4.200E-02 4.062E-02 3.905E-02 3.731E-02 3.541E-02 3.336E-02 3.118E-02 2.890E-02 2.653E-02 2.409E-02 2.162E-02 1.914E-02 1.668E-02 1.428E-02 1.195E-02 9.736E-03 7.669E-03 5.780E-03 4.103E-03 2.671E-03 1.514E-03 6.639E-04 1.507E-04 2.384E-06 2.454E-04 9.039E-04 2.000E-03 3.552E-03 5.576E-03 8.084E-03 1.109E-02 1.459E-02 1.859E-02 2.309E-02 2.808E-02 3.355E-02 3.949E-02 4.586E-02 5.266E-02 5.984E-02 6.738E-02 7.524E-02 8.338E-02 9.174E-02 1.003E-01 1.090E-01 1.177E-01 1.265E-01 1.352E-01 1.439E-01 1.523E-01 1.606E-01 1.685E-01 1.761E-01 1.833E-01 1.901E-01 1.962E-01 2.019E-01 2.068E-01 2.111E-01 2.147E-01 2.175E-01 2.196E-01 2.208E-01 2.211E-01 2.207E-01 2.193E-01 2.171E-01 2.141E-01 2.103E-01 2.056E-01 2.001E-01 1.940E-01 1.871E-01 1.796E-01 1.714E-01 1.628E-01 1.538E-01 1.443E-01 1.346E-01 1.246E-01 1.145E-01 1.044E-01 9.435E-02 8.441E-02 7.469E-02 6.528E-02 5.625E-02 4.770E-02 3.968E-02 3.227E-02 2.552E-02 1.950E-02 1.424E-02 9.783E-03 6.149E-03 3.356E-03 1.408E-03 2.974E-04 7.911E-06 5.102E-04 1.765E-03 3.721E-03 6.319E-03 9.489E-03 1.315E-02 1.723E-02 2.162E-02 2.623E-02 3.096E-02 3.571E-02 4.038E-02 4.487E-02 4.909E-02 5.295E-02 5.636E-02 5.926E-02 6.158E-02 6.327E-02 6.430E-02 6.465E-02 6.430E-02 6.327E-02 6.158E-02 5.926E-02 5.636E-02 5.295E-02 4.909E-02 4.487E-02 4.038E-02 3.571E-02 3.096E-02 2.623E-02 2.162E-02 1.723E-02 1.315E-02 9.489E-03 6.319E-03 3.721E-03 1.765E-03 5.102E-04 7.911E-06 2.974E-04 1.408E-03 3.356E-03 6.149E-03 9.783E-03 1.424E-02 1.950E-02 2.552E-02 3.227E-02 3.968E-02 4.770E-02 5.625E-02 6.528E-02 7.469E-02 8.441E-02 9.435E-02 1.044E-01 1.145E-01 1.246E-01 1.346E-01 1.443E-01 1.538E-01 1.628E-01 1.714E-01 1.796E-01 1.871E-01 1.940E-01 2.001E-01 2.056E-01 2.103E-01 2.141E-01 2.171E-01 2.193E-01 2.207E-01 2.211E-01 2.208E-01 2.196E-01 2.175E-01 2.147E-01 2.111E-01 2.068E-01 2.019E-01 1.962E-01 1.901E-01 1.833E-01 1.761E-01 1.685E-01 1.606E-01 1.523E-01 1.439E-01 1.352E-01 1.265E-01 1.177E-01 1.090E-01 1.003E-01 9.174E-02 8.338E-02 7.524E-02 6.738E-02 5.984E-02 5.266E-02 4.586E-02 3.949E-02 3.355E-02 2.808E-02 2.309E-02 1.859E-02 1.459E-02 1.109E-02 8.084E-03 5.576E-03 3.552E-03 2.000E-03 9.039E-04 2.454E-04 2.384E-06 1.507E-04 6.639E-04 1.514E-03 2.671E-03 4.103E-03 5.780E-03 7.669E-03 9.736E-03 1.195E-02 1.428E-02 1.668E-02 1.914E-02 2.162E-02 2.409E-02 2.653E-02 2.890E-02 3.118E-02 3.336E-02 3.541E-02 3.731E-02 3.905E-02 4.062E-02 4.200E-02 4.318E-02 4.416E-02 4.492E-02 4.548E-02 4.583E-02 4.597E-02 4.590E-02 4.555E-02 4.586E-02 4.597E-02 4.588E-02 4.558E-02 4.506E-02 4.434E-02 4.341E-02 4.227E-02 4.094E-02 3.942E-02 3.772E-02 3.586E-02 3.385E-02 3.170E-02 2.944E-02 2.709E-02 2.468E-02 2.222E-02 1.974E-02 1.728E-02 1.487E-02 1.252E-02 1.028E-02 8.179E-03 6.247E-03 4.516E-03 3.021E-03 1.791E-03 8.593E-04 2.544E-04 5.093E-06 1.379E-04 6.775E-04 1.646E-03 3.063E-03 4.944E-03 7.304E-03 1.015E-02 1.350E-02 1.734E-02 2.167E-02 2.650E-02 3.180E-02 3.757E-02 4.378E-02 5.042E-02 5.745E-02 6.485E-02 7.258E-02 8.059E-02 8.885E-02 9.730E-02 1.059E-01 1.146E-01 1.233E-01 1.320E-01 1.407E-01 1.492E-01 1.575E-01 1.655E-01 1.732E-01 1.805E-01 1.874E-01 1.938E-01 1.996E-01 2.048E-01 2.094E-01 2.132E-01 2.164E-01 2.187E-01 2.203E-01 2.211E-01 2.210E-01 2.201E-01 2.183E-01 2.158E-01 2.124E-01 2.081E-01 2.032E-01 1.974E-01 1.910E-01 1.839E-01 1.763E-01 1.680E-01 1.594E-01 1.503E-01 1.408E-01 1.312E-01 1.213E-01 1.114E-01 1.015E-01 9.163E-02 8.194E-02 7.250E-02 6.338E-02 5.466E-02 4.640E-02 3.868E-02 3.156E-02 2.508E-02 1.930E-02 1.424E-02 9.939E-03 6.409E-03 3.658E-03 1.685E-03 4.758E-04 8.147E-06 2.485E-04 1.154E-03 2.672E-03 4.742E-03 7.295E-03 1.026E-02 1.354E-02 1.707E-02 2.076E-02 2.450E-02 2.822E-02 3.183E-02 3.524E-02 3.837E-02 4.115E-02 4.352E-02 4.542E-02 4.681E-02 4.766E-02 4.794E-02 4.766E-02 4.681E-02 4.542E-02 4.352E-02 4.115E-02 3.837E-02 3.524E-02 3.183E-02 2.822E-02 2.450E-02 2.076E-02 1.707E-02 1.354E-02 1.026E-02 7.295E-03 4.742E-03 2.672E-03 1.154E-03 2.485E-04 8.147E-06 4.758E-04 1.685E-03 3.658E-03 6.409E-03 9.939E-03 1.424E-02 1.930E-02 2.508E-02 3.156E-02 3.868E-02 4.640E-02 5.466E-02 6.338E-02 7.250E-02 8.194E-02 9.163E-02 1.015E-01 1.114E-01 1.213E-01 1.312E-01 1.408E-01 1.503E-01 1.594E-01 1.680E-01 1.763E-01 1.839E-01 1.910E-01 1.974E-01 2.032E-01 2.081E-01 2.124E-01 2.158E-01 2.183E-01 2.201E-01 2.210E-01 2.211E-01 2.203E-01 2.187E-01 2.164E-01 2.132E-01 2.094E-01 2.048E-01 1.996E-01 1.938E-01 1.874E-01 1.805E-01 1.732E-01 1.655E-01 1.575E-01 1.492E-01 1.407E-01 1.320E-01 1.233E-01 1.146E-01 1.059E-01 9.730E-02 8.885E-02 8.059E-02 7.258E-02 6.485E-02 5.745E-02 5.042E-02 4.378E-02 3.757E-02 3.180E-02 2.650E-02 2.167E-02 1.734E-02 1.350E-02 1.015E-02 7.304E-03 4.944E-03 3.063E-03 1.646E-03 6.775E-04 1.379E-04 5.093E-06 2.544E-04 8.593E-04 1.791E-03 3.021E-03 4.516E-03 6.247E-03 8.179E-03 1.028E-02 1.252E-02 1.487E-02 1.728E-02 1.974E-02 2.222E-02 2.468E-02 2.709E-02 2.944E-02 3.170E-02 3.385E-02 3.586E-02 3.772E-02 3.942E-02 4.094E-02 4.227E-02 4.341E-02 4.434E-02 4.506E-02 4.558E-02 4.588E-02 4.597E-02 4.586E-02 4.546E-02 4.581E-02 4.596E-02 4.592E-02 4.566E-02 4.520E-02 4.452E-02 4.364E-02 4.255E-02 4.127E-02 3.979E-02 3.814E-02 3.631E-02 3.434E-02 3.223E-02 3.000E-02 2.768E-02 2.528E-02 2.284E-02 2.037E-02 1.791E-02 1.548E-02 1.312E-02 1.086E-02 8.719E-03 6.744E-03 4.961E-03 3.402E-03 2.101E-03 1.086E-03 3.892E-04 3.801E-05 5.944E-05 4.784E-04 1.317E-03 2.597E-03 4.333E-03 6.541E-03 9.232E-03 1.241E-02 1.608E-02 2.025E-02 2.490E-02 3.003E-02 3.563E-02 4.168E-02 4.815E-02 5.503E-02 6.228E-02 6.986E-02 7.774E-02 8.588E-02 9.423E-02 1.027E-01 1.114E-01 1.200E-01 1.287E-01 1.374E-01 1.459E-01 1.542E-01 1.623E-01 1.701E-01 1.775E-01 1.845E-01 1.911E-01 1.971E-01 2.026E-01 2.074E-01 2.116E-01 2.150E-01 2.177E-01 2.197E-01 2.208E-01 2.211E-01 2.207E-01 2.194E-01 2.172E-01 2.143E-01 2.105E-01 2.060E-01 2.008E-01 1.948E-01 1.882E-01 1.810E-01 1.732E-01 1.649E-01 1.562E-01 1.471E-01 1.378E-01 1.282E-01 1.185E-01 1.088E-01 9.907E-02 8.946E-02 8.003E-02 7.086E-02 6.203E-02 5.359E-02 4.563E-02 3.819E-02 3.133E-02 2.508E-02 1.950E-02 1.460E-02 1.041E-02 6.941E-03 4.187E-03 2.143E-03 7.923E-04 1.066E-04 5.039E-05 5.789E-04 1.640E-03 3.173E-03 5.113E-03 7.388E-03 9.923E-03 1.264E-02 1.546E-02 1.831E-02 2.110E-02 2.376E-02 2.623E-02 2.843E-02 3.031E-02 3.183E-02 3.294E-02 3.362E-02 3.385E-02 3.362E-02 3.294E-02 3.183E-02 3.031E-02 2.843E-02 2.623E-02 2.376E-02 2.110E-02 1.831E-02 1.546E-02 1.264E-02 9.923E-03 7.388E-03 5.113E-03 3.173E-03 1.640E-03 5.789E-04 5.039E-05 1.066E-04 7.923E-04 2.143E-03 4.187E-03 6.941E-03 1.041E-02 1.460E-02 1.950E-02 2.508E-02 3.133E-02 3.819E-02 4.563E-02 5.359E-02 6.203E-02 7.086E-02 8.003E-02 8.946E-02 9.907E-02 1.088E-01 1.185E-01 1.282E-01 1.378E-01 1.471E-01 1.562E-01 1.649E-01 1.732E-01 1.810E-01 1.882E-01 1.948E-01 2.008E-01 2.060E-01 2.105E-01 2.143E-01 2.172E-01 2.194E-01 2.207E-01 2.211E-01 2.208E-01 2.197E-01 2.177E-01 2.150E-01 2.116E-01 2.074E-01 2.026E-01 1.971E-01 1.911E-01 1.845E-01 1.775E-01 1.701E-01 1.623E-01 1.542E-01 1.459E-01 1.374E-01 1.287E-01 1.200E-01 1.114E-01 1.027E-01 9.423E-02 8.588E-02 7.774E-02 6.986E-02 6.228E-02 5.503E-02 4.815E-02 4.168E-02 3.563E-02 3.003E-02 2.490E-02 2.025E-02 1.608E-02 1.241E-02 9.232E-03 6.541E-03 4.333E-03 2.597E-03 1.317E-03 4.784E-04 5.944E-05 3.801E-05 3.892E-04 1.086E-03 2.101E-03 3.402E-03 4.961E-03 6.744E-03 8.719E-03 1.086E-02 1.312E-02 1.548E-02 1.791E-02 2.037E-02 2.284E-02 2.528E-02 2.768E-02 3.000E-02 3.223E-02 3.434E-02 3.631E-02 3.814E-02 3.979E-02 4.127E-02 4.255E-02 4.364E-02 4.452E-02 4.520E-02 4.566E-02 4.592E-02 4.596E-02 4.581E-02 4.535E-02 4.575E-02 4.595E-02 4.595E-02 4.574E-02 4.532E-02 4.470E-02 4.386E-02 4.283E-02 4.159E-02 4.016E-02 3.856E-02 3.678E-02 3.484E-02 3.277E-02 3.057E-02 2.828E-02 2.590E-02 2.347E-02 2.101E-02 1.855E-02 1.612E-02 1.375E-02 1.146E-02 9.290E-03 7.272E-03 5.437E-03 3.817E-03 2.443E-03 1.347E-03 5.573E-04 1.036E-04 1.271E-05 3.098E-04 1.018E-03 2.157E-03 3.746E-03 5.800E-03 8.329E-03 1.134E-02 1.484E-02 1.883E-02 2.331E-02 2.826E-02 3.369E-02 3.956E-02 4.586E-02 5.257E-02 5.966E-02 6.709E-02 7.484E-02 8.285E-02 9.108E-02 9.950E-02 1.080E-01 1.167E-01 1.253E-01 1.339E-01 1.424E-01 1.508E-01 1.589E-01 1.668E-01 1.744E-01 1.815E-01 1.882E-01 1.945E-01 2.001E-01 2.052E-01 2.097E-01 2.134E-01 2.165E-01 2.188E-01 2.203E-01 2.211E-01 2.210E-01 2.202E-01 2.185E-01 2.160E-01 2.128E-01 2.087E-01 2.040E-01 1.985E-01 1.924E-01 1.856E-01 1.783E-01 1.704E-01 1.621E-01 1.534E-01 1.444E-01 1.352E-01 1.257E-01 1.162E-01 1.067E-01 9.718E-02 8.782E-02 7.866E-02 6.977E-02 6.122E-02 5.307E-02 4.537E-02 3.819E-02 3.156E-02 2.552E-02 2.011E-02 1.534E-02 1.122E-02 7.773E-03 4.980E-03 2.832E-03 1.310E-03 3.816E-04 1.105E-05 1.532E-04 7.568E-04 1.765E-03 3.115E-03 4.742E-03 6.577E-03 8.552E-03 1.060E-02 1.264E-02 1.462E-02 1.648E-02 1.815E-02 1.959E-02 2.076E-02 2.162E-02 2.214E-02 2.232E-02 2.214E-02 2.162E-02 2.076E-02 1.959E-02 1.815E-02 1.648E-02 1.462E-02 1.264E-02 1.060E-02 8.552E-03 6.577E-03 4.742E-03 3.115E-03 1.765E-03 7.568E-04 1.532E-04 1.105E-05 3.816E-04 1.310E-03 2.832E-03 4.980E-03 7.773E-03 1.122E-02 1.534E-02 2.011E-02 2.552E-02 3.156E-02 3.819E-02 4.537E-02 5.307E-02 6.122E-02 6.977E-02 7.866E-02 8.782E-02 9.718E-02 1.067E-01 1.162E-01 1.257E-01 1.352E-01 1.444E-01 1.534E-01 1.621E-01 1.704E-01 1.783E-01 1.856E-01 1.924E-01 1.985E-01 2.040E-01 2.087E-01 2.128E-01 2.160E-01 2.185E-01 2.202E-01 2.210E-01 2.211E-01 2.203E-01 2.188E-01 2.165E-01 2.134E-01 2.097E-01 2.052E-01 2.001E-01 1.945E-01 1.882E-01 1.815E-01 1.744E-01 1.668E-01 1.589E-01 1.508E-01 1.424E-01 1.339E-01 1.253E-01 1.167E-01 1.080E-01 9.950E-02 9.108E-02 8.285E-02 7.484E-02 6.709E-02 5.966E-02 5.257E-02 4.586E-02 3.956E-02 3.369E-02 2.826E-02 2.331E-02 1.883E-02 1.484E-02 1.134E-02 8.329E-03 5.800E-03 3.746E-03 2.157E-03 1.018E-03 3.098E-04 1.271E-05 1.036E-04 5.573E-04 1.347E-03 2.443E-03 3.817E-03 5.437E-03 7.272E-03 9.290E-03 1.146E-02 1.375E-02 1.612E-02 1.855E-02 2.101E-02 2.347E-02 2.590E-02 2.828E-02 3.057E-02 3.277E-02 3.484E-02 3.678E-02 3.856E-02 4.016E-02 4.159E-02 4.283E-02 4.386E-02 4.470E-02 4.532E-02 4.574E-02 4.595E-02 4.595E-02 4.575E-02 4.524E-02 4.567E-02 4.592E-02 4.596E-02 4.581E-02 4.544E-02 4.487E-02 4.409E-02 4.310E-02 4.192E-02 4.054E-02 3.898E-02 3.724E-02 3.535E-02 3.332E-02 3.115E-02 2.889E-02 2.654E-02 2.413E-02 2.168E-02 1.922E-02 1.679E-02 1.440E-02 1.209E-02 9.890E-03 7.832E-03 5.946E-03 4.265E-03 2.820E-03 1.642E-03 7.605E-04 2.042E-04 4.667E-07 1.748E-04 7.505E-04 1.749E-03 3.188E-03 5.084E-03 7.448E-03 1.029E-02 1.362E-02 1.743E-02 2.172E-02 2.650E-02 3.173E-02 3.743E-02 4.355E-02 5.009E-02 5.701E-02 6.429E-02 7.188E-02 7.976E-02 8.787E-02 9.618E-02 1.046E-01 1.132E-01 1.218E-01 1.304E-01 1.389E-01 1.472E-01 1.554E-01 1.634E-01 1.710E-01 1.783E-01 1.852E-01 1.916E-01 1.975E-01 2.029E-01 2.076E-01 2.116E-01 2.150E-01 2.177E-01 2.196E-01 2.208E-01 2.211E-01 2.207E-01 2.195E-01 2.175E-01 2.148E-01 2.112E-01 2.070E-01 2.020E-01 1.963E-01 1.901E-01 1.832E-01 1.758E-01 1.679E-01 1.597E-01 1.510E-01 1.421E-01 1.330E-01 1.237E-01 1.144E-01 1.051E-01 9.583E-02 8.673E-02 7.784E-02 6.922E-02 6.095E-02 5.307E-02 4.563E-02 3.868E-02 3.227E-02 2.641E-02 2.114E-02 1.646E-02 1.240E-02 8.941E-03 6.085E-03 3.813E-03 2.103E-03 9.237E-04 2.374E-04 9.434E-07 1.654E-04 6.775E-04 1.481E-03 2.515E-03 3.721E-03 5.037E-03 6.405E-03 7.765E-03 9.066E-03 1.026E-02 1.129E-02 1.214E-02 1.277E-02 1.315E-02 1.328E-02 1.315E-02 1.277E-02 1.214E-02 1.129E-02 1.026E-02 9.066E-03 7.765E-03 6.405E-03 5.037E-03 3.721E-03 2.515E-03 1.481E-03 6.775E-04 1.654E-04 9.434E-07 2.374E-04 9.237E-04 2.103E-03 3.813E-03 6.085E-03 8.941E-03 1.240E-02 1.646E-02 2.114E-02 2.641E-02 3.227E-02 3.868E-02 4.563E-02 5.307E-02 6.095E-02 6.922E-02 7.784E-02 8.673E-02 9.583E-02 1.051E-01 1.144E-01 1.237E-01 1.330E-01 1.421E-01 1.510E-01 1.597E-01 1.679E-01 1.758E-01 1.832E-01 1.901E-01 1.963E-01 2.020E-01 2.070E-01 2.112E-01 2.148E-01 2.175E-01 2.195E-01 2.207E-01 2.211E-01 2.208E-01 2.196E-01 2.177E-01 2.150E-01 2.116E-01 2.076E-01 2.029E-01 1.975E-01 1.916E-01 1.852E-01 1.783E-01 1.710E-01 1.634E-01 1.554E-01 1.472E-01 1.389E-01 1.304E-01 1.218E-01 1.132E-01 1.046E-01 9.618E-02 8.787E-02 7.976E-02 7.188E-02 6.429E-02 5.701E-02 5.009E-02 4.355E-02 3.743E-02 3.173E-02 2.650E-02 2.172E-02 1.743E-02 1.362E-02 1.029E-02 7.448E-03 5.084E-03 3.188E-03 1.749E-03 7.505E-04 1.748E-04 4.667E-07 2.042E-04 7.605E-04 1.642E-03 2.820E-03 4.265E-03 5.946E-03 7.832E-03 9.890E-03 1.209E-02 1.440E-02 1.679E-02 1.922E-02 2.168E-02 2.413E-02 2.654E-02 2.889E-02 3.115E-02 3.332E-02 3.535E-02 3.724E-02 3.898E-02 4.054E-02 4.192E-02 4.310E-02 4.409E-02 4.487E-02 4.544E-02 4.581E-02 4.596E-02 4.592E-02 4.567E-02 4.510E-02 4.559E-02 4.588E-02 4.597E-02 4.586E-02 4.555E-02 4.503E-02 4.430E-02 4.337E-02 4.224E-02 4.091E-02 3.940E-02 3.772E-02 3.587E-02 3.387E-02 3.175E-02 2.951E-02 2.719E-02 2.480E-02 2.236E-02 1.991E-02 1.748E-02 1.508E-02 1.275E-02 1.052E-02 8.424E-03 6.489E-03 4.749E-03 3.234E-03 1.974E-03 1.001E-03 3.421E-04 2.532E-05 7.627E-05 5.187E-04 1.374E-03 2.662E-03 4.398E-03 6.595E-03 9.264E-03 1.241E-02 1.604E-02 2.015E-02 2.473E-02 2.978E-02 3.529E-02 4.123E-02 4.759E-02 5.433E-02 6.144E-02 6.888E-02 7.661E-02 8.460E-02 9.279E-02 1.011E-01 1.096E-01 1.181E-01 1.267E-01 1.352E-01 1.436E-01 1.518E-01 1.598E-01 1.676E-01 1.750E-01 1.820E-01 1.886E-01 1.947E-01 2.003E-01 2.053E-01 2.096E-01 2.133E-01 2.164E-01 2.187E-01 2.202E-01 2.210E-01 2.211E-01 2.203E-01 2.188E-01 2.165E-01 2.135E-01 2.097E-01 2.053E-01 2.001E-01 1.944E-01 1.880E-01 1.811E-01 1.737E-01 1.658E-01 1.576E-01 1.490E-01 1.403E-01 1.313E-01 1.222E-01 1.131E-01 1.040E-01 9.502E-02 8.618E-02 7.756E-02 6.922E-02 6.122E-02 5.359E-02 4.640E-02 3.968E-02 3.345E-02 2.776E-02 2.260E-02 1.801E-02 1.397E-02 1.049E-02 7.561E-03 5.157E-03 3.258E-03 1.832E-03 8.437E-04 2.518E-04 1.105E-05 7.283E-05 3.863E-04 8.991E-04 1.559E-03 2.314E-03 3.115E-03 3.914E-03 4.670E-03 5.343E-03 5.901E-03 6.319E-03 6.577E-03 6.665E-03 6.577E-03 6.319E-03 5.901E-03 5.343E-03 4.670E-03 3.914E-03 3.115E-03 2.314E-03 1.559E-03 8.991E-04 3.863E-04 7.283E-05 1.105E-05 2.518E-04 8.437E-04 1.832E-03 3.258E-03 5.157E-03 7.561E-03 1.049E-02 1.397E-02 1.801E-02 2.260E-02 2.776E-02 3.345E-02 3.968E-02 4.640E-02 5.359E-02 6.122E-02 6.922E-02 7.756E-02 8.618E-02 9.502E-02 1.040E-01 1.131E-01 1.222E-01 1.313E-01 1.403E-01 1.490E-01 1.576E-01 1.658E-01 1.737E-01 1.811E-01 1.880E-01 1.944E-01 2.001E-01 2.053E-01 2.097E-01 2.135E-01 2.165E-01 2.188E-01 2.203E-01 2.211E-01 2.210E-01 2.202E-01 2.187E-01 2.164E-01 2.133E-01 2.096E-01 2.053E-01 2.003E-01 1.947E-01 1.886E-01 1.820E-01 1.750E-01 1.676E-01 1.598E-01 1.518E-01 1.436E-01 1.352E-01 1.267E-01 1.181E-01 1.096E-01 1.011E-01 9.279E-02 8.460E-02 7.661E-02 6.888E-02 6.144E-02 5.433E-02 4.759E-02 4.123E-02 3.529E-02 2.978E-02 2.473E-02 2.015E-02 1.604E-02 1.241E-02 9.264E-03 6.595E-03 4.398E-03 2.662E-03 1.374E-03 5.187E-04 7.627E-05 2.532E-05 3.421E-04 1.001E-03 1.974E-03 3.234E-03 4.749E-03 6.489E-03 8.424E-03 1.052E-02 1.275E-02 1.508E-02 1.748E-02 1.991E-02 2.236E-02 2.480E-02 2.719E-02 2.951E-02 3.175E-02 3.387E-02 3.587E-02 3.772E-02 3.940E-02 4.091E-02 4.224E-02 4.337E-02 4.430E-02 4.503E-02 4.555E-02 4.586E-02 4.597E-02 4.588E-02 4.559E-02 4.496E-02 4.548E-02 4.582E-02 4.597E-02 4.591E-02 4.565E-02 4.518E-02 4.451E-02 4.363E-02 4.256E-02 4.128E-02 3.983E-02 3.819E-02 3.639E-02 3.444E-02 3.235E-02 3.015E-02 2.786E-02 2.549E-02 2.307E-02 2.063E-02 1.819E-02 1.578E-02 1.344E-02 1.118E-02 9.048E-03 7.066E-03 5.268E-03 3.684E-03 2.345E-03 1.280E-03 5.195E-04 8.981E-05 1.718E-05 3.258E-04 1.038E-03 2.172E-03 3.746E-03 5.774E-03 8.267E-03 1.123E-02 1.467E-02 1.859E-02 2.298E-02 2.784E-02 3.315E-02 3.890E-02 4.507E-02 5.164E-02 5.857E-02 6.585E-02 7.343E-02 8.127E-02 8.934E-02 9.758E-02 1.060E-01 1.144E-01 1.229E-01 1.314E-01 1.398E-01 1.480E-01 1.561E-01 1.639E-01 1.714E-01 1.786E-01 1.854E-01 1.917E-01 1.975E-01 2.027E-01 2.074E-01 2.114E-01 2.148E-01 2.175E-01 2.194E-01 2.207E-01 2.211E-01 2.209E-01 2.198E-01 2.181E-01 2.155E-01 2.123E-01 2.083E-01 2.037E-01 1.984E-01 1.926E-01 1.861E-01 1.792E-01 1.718E-01 1.640E-01 1.559E-01 1.475E-01 1.389E-01 1.301E-01 1.212E-01 1.123E-01 1.035E-01 9.475E-02 8.618E-02 7.784E-02 6.977E-02 6.203E-02 5.466E-02 4.770E-02 4.118E-02 3.513E-02 2.958E-02 2.454E-02 2.001E-02 1.599E-02 1.248E-02 9.473E-03 6.941E-03 4.863E-03 3.209E-03 1.946E-03 1.036E-03 4.369E-04 1.066E-04 2.496E-07 7.283E-05 2.800E-04 5.789E-04 9.292E-04 1.294E-03 1.640E-03 1.939E-03 2.169E-03 2.314E-03 2.364E-03 2.314E-03 2.169E-03 1.939E-03 1.640E-03 1.294E-03 9.292E-04 5.789E-04 2.800E-04 7.283E-05 2.496E-07 1.066E-04 4.369E-04 1.036E-03 1.946E-03 3.209E-03 4.863E-03 6.941E-03 9.473E-03 1.248E-02 1.599E-02 2.001E-02 2.454E-02 2.958E-02 3.513E-02 4.118E-02 4.770E-02 5.466E-02 6.203E-02 6.977E-02 7.784E-02 8.618E-02 9.475E-02 1.035E-01 1.123E-01 1.212E-01 1.301E-01 1.389E-01 1.475E-01 1.559E-01 1.640E-01 1.718E-01 1.792E-01 1.861E-01 1.926E-01 1.984E-01 2.037E-01 2.083E-01 2.123E-01 2.155E-01 2.181E-01 2.198E-01 2.209E-01 2.211E-01 2.207E-01 2.194E-01 2.175E-01 2.148E-01 2.114E-01 2.074E-01 2.027E-01 1.975E-01 1.917E-01 1.854E-01 1.786E-01 1.714E-01 1.639E-01 1.561E-01 1.480E-01 1.398E-01 1.314E-01 1.229E-01 1.144E-01 1.060E-01 9.758E-02 8.934E-02 8.127E-02 7.343E-02 6.585E-02 5.857E-02 5.164E-02 4.507E-02 3.890E-02 3.315E-02 2.784E-02 2.298E-02 1.859E-02 1.467E-02 1.123E-02 8.267E-03 5.774E-03 3.746E-03 2.172E-03 1.038E-03 3.258E-04 1.718E-05 8.981E-05 5.195E-04 1.280E-03 2.345E-03 3.684E-03 5.268E-03 7.066E-03 9.048E-03 1.118E-02 1.344E-02 1.578E-02 1.819E-02 2.063E-02 2.307E-02 2.549E-02 2.786E-02 3.015E-02 3.235E-02 3.444E-02 3.639E-02 3.819E-02 3.983E-02 4.128E-02 4.256E-02 4.363E-02 4.451E-02 4.518E-02 4.565E-02 4.591E-02 4.597E-02 4.582E-02 4.548E-02 4.479E-02 4.537E-02 4.575E-02 4.595E-02 4.594E-02 4.574E-02 4.533E-02 4.471E-02 4.389E-02 4.287E-02 4.165E-02 4.025E-02 3.866E-02 3.691E-02 3.501E-02 3.296E-02 3.080E-02 2.854E-02 2.619E-02 2.379E-02 2.136E-02 1.893E-02 1.652E-02 1.415E-02 1.187E-02 9.706E-03 7.678E-03 5.824E-03 4.173E-03 2.755E-03 1.601E-03 7.385E-04 1.963E-04 2.914E-07 1.748E-04 7.422E-04 1.723E-03 3.134E-03 4.991E-03 7.304E-03 1.008E-02 1.333E-02 1.706E-02 2.125E-02 2.591E-02 3.102E-02 3.658E-02 4.255E-02 4.893E-02 5.569E-02 6.279E-02 7.020E-02 7.790E-02 8.583E-02 9.395E-02 1.022E-01 1.106E-01 1.190E-01 1.275E-01 1.358E-01 1.441E-01 1.522E-01 1.601E-01 1.677E-01 1.750E-01 1.820E-01 1.884E-01 1.945E-01 2.000E-01 2.049E-01 2.093E-01 2.130E-01 2.160E-01 2.184E-01 2.200E-01 2.209E-01 2.211E-01 2.206E-01 2.193E-01 2.173E-01 2.145E-01 2.111E-01 2.070E-01 2.023E-01 1.969E-01 1.910E-01 1.846E-01 1.777E-01 1.703E-01 1.626E-01 1.546E-01 1.464E-01 1.379E-01 1.293E-01 1.207E-01 1.121E-01 1.035E-01 9.502E-02 8.673E-02 7.866E-02 7.086E-02 6.338E-02 5.625E-02 4.952E-02 4.320E-02 3.733E-02 3.191E-02 2.697E-02 2.250E-02 1.850E-02 1.497E-02 1.189E-02 9.244E-03 7.009E-03 5.157E-03 3.658E-03 2.477E-03 1.578E-03 9.237E-04 4.758E-04 1.968E-04 4.997E-05 9.434E-07 1.796E-05 7.283E-05 1.415E-04 2.048E-04 2.485E-04 2.640E-04 2.485E-04 2.048E-04 1.415E-04 7.283E-05 1.796E-05 9.434E-07 4.997E-05 1.968E-04 4.758E-04 9.237E-04 1.578E-03 2.477E-03 3.658E-03 5.157E-03 7.009E-03 9.244E-03 1.189E-02 1.497E-02 1.850E-02 2.250E-02 2.697E-02 3.191E-02 3.733E-02 4.320E-02 4.952E-02 5.625E-02 6.338E-02 7.086E-02 7.866E-02 8.673E-02 9.502E-02 1.035E-01 1.121E-01 1.207E-01 1.293E-01 1.379E-01 1.464E-01 1.546E-01 1.626E-01 1.703E-01 1.777E-01 1.846E-01 1.910E-01 1.969E-01 2.023E-01 2.070E-01 2.111E-01 2.145E-01 2.173E-01 2.193E-01 2.206E-01 2.211E-01 2.209E-01 2.200E-01 2.184E-01 2.160E-01 2.130E-01 2.093E-01 2.049E-01 2.000E-01 1.945E-01 1.884E-01 1.820E-01 1.750E-01 1.677E-01 1.601E-01 1.522E-01 1.441E-01 1.358E-01 1.275E-01 1.190E-01 1.106E-01 1.022E-01 9.395E-02 8.583E-02 7.790E-02 7.020E-02 6.279E-02 5.569E-02 4.893E-02 4.255E-02 3.658E-02 3.102E-02 2.591E-02 2.125E-02 1.706E-02 1.333E-02 1.008E-02 7.304E-03 4.991E-03 3.134E-03 1.723E-03 7.422E-04 1.748E-04 2.914E-07 1.963E-04 7.385E-04 1.601E-03 2.755E-03 4.173E-03 5.824E-03 7.678E-03 9.706E-03 1.187E-02 1.415E-02 1.652E-02 1.893E-02 2.136E-02 2.379E-02 2.619E-02 2.854E-02 3.080E-02 3.296E-02 3.501E-02 3.691E-02 3.866E-02 4.025E-02 4.165E-02 4.287E-02 4.389E-02 4.471E-02 4.533E-02 4.574E-02 4.594E-02 4.595E-02 4.575E-02 4.537E-02 4.462E-02 4.523E-02 4.567E-02 4.592E-02 4.597E-02 4.582E-02 4.546E-02 4.490E-02 4.414E-02 4.318E-02 4.202E-02 4.067E-02 3.914E-02 3.744E-02 3.558E-02 3.358E-02 3.146E-02 2.923E-02 2.691E-02 2.453E-02 2.212E-02 1.969E-02 1.727E-02 1.490E-02 1.260E-02 1.040E-02 8.326E-03 6.417E-03 4.700E-03 3.206E-03 1.963E-03 1.001E-03 3.472E-04 2.826E-05 6.879E-05 4.916E-04 1.317E-03 2.564E-03 4.248E-03 6.381E-03 8.973E-03 1.203E-02 1.555E-02 1.955E-02 2.400E-02 2.891E-02 3.426E-02 4.004E-02 4.622E-02 5.279E-02 5.971E-02 6.695E-02 7.448E-02 8.227E-02 9.026E-02 9.843E-02 1.067E-01 1.151E-01 1.234E-01 1.318E-01 1.401E-01 1.482E-01 1.562E-01 1.639E-01 1.713E-01 1.783E-01 1.850E-01 1.912E-01 1.970E-01 2.022E-01 2.068E-01 2.109E-01 2.143E-01 2.170E-01 2.191E-01 2.204E-01 2.211E-01 2.210E-01 2.202E-01 2.187E-01 2.165E-01 2.136E-01 2.100E-01 2.058E-01 2.010E-01 1.956E-01 1.897E-01 1.833E-01 1.764E-01 1.692E-01 1.616E-01 1.538E-01 1.457E-01 1.374E-01 1.291E-01 1.207E-01 1.123E-01 1.040E-01 9.583E-02 8.782E-02 8.003E-02 7.250E-02 6.528E-02 5.839E-02 5.188E-02 4.576E-02 4.005E-02 3.477E-02 2.993E-02 2.552E-02 2.155E-02 1.801E-02 1.488E-02 1.214E-02 9.783E-03 7.773E-03 6.085E-03 4.690E-03 3.556E-03 2.652E-03 1.946E-03 1.408E-03 1.007E-03 7.180E-04 5.163E-04 3.816E-04 2.974E-04 2.518E-04 2.374E-04 2.518E-04 2.974E-04 3.816E-04 5.163E-04 7.180E-04 1.007E-03 1.408E-03 1.946E-03 2.652E-03 3.556E-03 4.690E-03 6.085E-03 7.773E-03 9.783E-03 1.214E-02 1.488E-02 1.801E-02 2.155E-02 2.552E-02 2.993E-02 3.477E-02 4.005E-02 4.576E-02 5.188E-02 5.839E-02 6.528E-02 7.250E-02 8.003E-02 8.782E-02 9.583E-02 1.040E-01 1.123E-01 1.207E-01 1.291E-01 1.374E-01 1.457E-01 1.538E-01 1.616E-01 1.692E-01 1.764E-01 1.833E-01 1.897E-01 1.956E-01 2.010E-01 2.058E-01 2.100E-01 2.136E-01 2.165E-01 2.187E-01 2.202E-01 2.210E-01 2.211E-01 2.204E-01 2.191E-01 2.170E-01 2.143E-01 2.109E-01 2.068E-01 2.022E-01 1.970E-01 1.912E-01 1.850E-01 1.783E-01 1.713E-01 1.639E-01 1.562E-01 1.482E-01 1.401E-01 1.318E-01 1.234E-01 1.151E-01 1.067E-01 9.843E-02 9.026E-02 8.227E-02 7.448E-02 6.695E-02 5.971E-02 5.279E-02 4.622E-02 4.004E-02 3.426E-02 2.891E-02 2.400E-02 1.955E-02 1.555E-02 1.203E-02 8.973E-03 6.381E-03 4.248E-03 2.564E-03 1.317E-03 4.916E-04 6.879E-05 2.826E-05 3.472E-04 1.001E-03 1.963E-03 3.206E-03 4.700E-03 6.417E-03 8.326E-03 1.040E-02 1.260E-02 1.490E-02 1.727E-02 1.969E-02 2.212E-02 2.453E-02 2.691E-02 2.923E-02 3.146E-02 3.358E-02 3.558E-02 3.744E-02 3.914E-02 4.067E-02 4.202E-02 4.318E-02 4.414E-02 4.490E-02 4.546E-02 4.582E-02 4.597E-02 4.592E-02 4.567E-02 4.523E-02 4.442E-02 4.508E-02 4.557E-02 4.587E-02 4.597E-02 4.588E-02 4.558E-02 4.508E-02 4.438E-02 4.348E-02 4.238E-02 4.109E-02 3.961E-02 3.796E-02 3.616E-02 3.421E-02 3.212E-02 2.993E-02 2.765E-02 2.529E-02 2.289E-02 2.047E-02 1.805E-02 1.567E-02 1.335E-02 1.112E-02 9.008E-03 7.048E-03 5.268E-03 3.699E-03 2.369E-03 1.309E-03 5.445E-04 1.036E-04 1.073E-05 2.892E-04 9.600E-04 2.042E-03 3.552E-03 5.502E-03 7.904E-03 1.076E-02 1.409E-02 1.787E-02 2.212E-02 2.682E-02 3.196E-02 3.753E-02 4.351E-02 4.988E-02 5.661E-02 6.367E-02 7.104E-02 7.867E-02 8.652E-02 9.456E-02 1.027E-01 1.110E-01 1.193E-01 1.276E-01 1.359E-01 1.441E-01 1.520E-01 1.598E-01 1.673E-01 1.745E-01 1.814E-01 1.878E-01 1.938E-01 1.992E-01 2.042E-01 2.085E-01 2.123E-01 2.154E-01 2.179E-01 2.196E-01 2.207E-01 2.211E-01 2.208E-01 2.198E-01 2.182E-01 2.158E-01 2.128E-01 2.091E-01 2.048E-01 2.000E-01 1.946E-01 1.887E-01 1.823E-01 1.755E-01 1.684E-01 1.610E-01 1.533E-01 1.455E-01 1.374E-01 1.293E-01 1.212E-01 1.131E-01 1.051E-01 9.718E-02 8.946E-02 8.194E-02 7.469E-02 6.772E-02 6.108E-02 5.479E-02 4.886E-02 4.333E-02 3.819E-02 3.345E-02 2.912E-02 2.519E-02 2.166E-02 1.850E-02 1.571E-02 1.326E-02 1.114E-02 9.320E-03 7.773E-03 6.474E-03 5.398E-03 4.519E-03 3.813E-03 3.258E-03 2.832E-03 2.520E-03 2.307E-03 2.184E-03 2.143E-03 2.184E-03 2.307E-03 2.520E-03 2.832E-03 3.258E-03 3.813E-03 4.519E-03 5.398E-03 6.474E-03 7.773E-03 9.320E-03 1.114E-02 1.326E-02 1.571E-02 1.850E-02 2.166E-02 2.519E-02 2.912E-02 3.345E-02 3.819E-02 4.333E-02 4.886E-02 5.479E-02 6.108E-02 6.772E-02 7.469E-02 8.194E-02 8.946E-02 9.718E-02 1.051E-01 1.131E-01 1.212E-01 1.293E-01 1.374E-01 1.455E-01 1.533E-01 1.610E-01 1.684E-01 1.755E-01 1.823E-01 1.887E-01 1.946E-01 2.000E-01 2.048E-01 2.091E-01 2.128E-01 2.158E-01 2.182E-01 2.198E-01 2.208E-01 2.211E-01 2.207E-01 2.196E-01 2.179E-01 2.154E-01 2.123E-01 2.085E-01 2.042E-01 1.992E-01 1.938E-01 1.878E-01 1.814E-01 1.745E-01 1.673E-01 1.598E-01 1.520E-01 1.441E-01 1.359E-01 1.276E-01 1.193E-01 1.110E-01 1.027E-01 9.456E-02 8.652E-02 7.867E-02 7.104E-02 6.367E-02 5.661E-02 4.988E-02 4.351E-02 3.753E-02 3.196E-02 2.682E-02 2.212E-02 1.787E-02 1.409E-02 1.076E-02 7.904E-03 5.502E-03 3.552E-03 2.042E-03 9.600E-04 2.892E-04 1.073E-05 1.036E-04 5.445E-04 1.309E-03 2.369E-03 3.699E-03 5.268E-03 7.048E-03 9.008E-03 1.112E-02 1.335E-02 1.567E-02 1.805E-02 2.047E-02 2.289E-02 2.529E-02 2.765E-02 2.993E-02 3.212E-02 3.421E-02 3.616E-02 3.796E-02 3.961E-02 4.109E-02 4.238E-02 4.348E-02 4.438E-02 4.508E-02 4.558E-02 4.588E-02 4.597E-02 4.587E-02 4.557E-02 4.508E-02 4.420E-02 4.492E-02 4.545E-02 4.580E-02 4.596E-02 4.593E-02 4.569E-02 4.525E-02 4.461E-02 4.377E-02 4.273E-02 4.150E-02 4.008E-02 3.849E-02 3.674E-02 3.483E-02 3.280E-02 3.064E-02 2.839E-02 2.606E-02 2.368E-02 2.127E-02 1.886E-02 1.647E-02 1.413E-02 1.187E-02 9.726E-03 7.717E-03 5.876E-03 4.234E-03 2.820E-03 1.663E-03 7.903E-04 2.286E-04 3.342E-06 1.379E-04 6.540E-04 1.571E-03 2.906E-03 4.672E-03 6.882E-03 9.544E-03 1.266E-02 1.624E-02 2.027E-02 2.476E-02 2.969E-02 3.505E-02 4.082E-02 4.698E-02 5.351E-02 6.039E-02 6.757E-02 7.504E-02 8.274E-02 9.065E-02 9.871E-02 1.069E-01 1.151E-01 1.234E-01 1.316E-01 1.398E-01 1.478E-01 1.556E-01 1.632E-01 1.705E-01 1.775E-01 1.841E-01 1.903E-01 1.960E-01 2.012E-01 2.059E-01 2.100E-01 2.135E-01 2.163E-01 2.185E-01 2.201E-01 2.209E-01 2.211E-01 2.206E-01 2.195E-01 2.176E-01 2.151E-01 2.120E-01 2.083E-01 2.040E-01 1.991E-01 1.937E-01 1.879E-01 1.816E-01 1.750E-01 1.680E-01 1.608E-01 1.533E-01 1.457E-01 1.379E-01 1.301E-01 1.222E-01 1.144E-01 1.067E-01 9.907E-02 9.163E-02 8.441E-02 7.743E-02 7.072E-02 6.433E-02 5.826E-02 5.254E-02 4.718E-02 4.219E-02 3.757E-02 3.333E-02 2.947E-02 2.597E-02 2.282E-02 2.001E-02 1.752E-02 1.534E-02 1.344E-02 1.181E-02 1.041E-02 9.244E-03 8.276E-03 7.491E-03 6.874E-03 6.409E-03 6.085E-03 5.894E-03 5.831E-03 5.894E-03 6.085E-03 6.409E-03 6.874E-03 7.491E-03 8.276E-03 9.244E-03 1.041E-02 1.181E-02 1.344E-02 1.534E-02 1.752E-02 2.001E-02 2.282E-02 2.597E-02 2.947E-02 3.333E-02 3.757E-02 4.219E-02 4.718E-02 5.254E-02 5.826E-02 6.433E-02 7.072E-02 7.743E-02 8.441E-02 9.163E-02 9.907E-02 1.067E-01 1.144E-01 1.222E-01 1.301E-01 1.379E-01 1.457E-01 1.533E-01 1.608E-01 1.680E-01 1.750E-01 1.816E-01 1.879E-01 1.937E-01 1.991E-01 2.040E-01 2.083E-01 2.120E-01 2.151E-01 2.176E-01 2.195E-01 2.206E-01 2.211E-01 2.209E-01 2.201E-01 2.185E-01 2.163E-01 2.135E-01 2.100E-01 2.059E-01 2.012E-01 1.960E-01 1.903E-01 1.841E-01 1.775E-01 1.705E-01 1.632E-01 1.556E-01 1.478E-01 1.398E-01 1.316E-01 1.234E-01 1.151E-01 1.069E-01 9.871E-02 9.065E-02 8.274E-02 7.504E-02 6.757E-02 6.039E-02 5.351E-02 4.698E-02 4.082E-02 3.505E-02 2.969E-02 2.476E-02 2.027E-02 1.624E-02 1.266E-02 9.544E-03 6.882E-03 4.672E-03 2.906E-03 1.571E-03 6.540E-04 1.379E-04 3.342E-06 2.286E-04 7.903E-04 1.663E-03 2.820E-03 4.234E-03 5.876E-03 7.717E-03 9.726E-03 1.187E-02 1.413E-02 1.647E-02 1.886E-02 2.127E-02 2.368E-02 2.606E-02 2.839E-02 3.064E-02 3.280E-02 3.483E-02 3.674E-02 3.849E-02 4.008E-02 4.150E-02 4.273E-02 4.377E-02 4.461E-02 4.525E-02 4.569E-02 4.593E-02 4.596E-02 4.580E-02 4.545E-02 4.492E-02 4.397E-02 4.473E-02 4.531E-02 4.572E-02 4.593E-02 4.596E-02 4.578E-02 4.540E-02 4.483E-02 4.405E-02 4.307E-02 4.190E-02 4.054E-02 3.901E-02 3.731E-02 3.546E-02 3.347E-02 3.136E-02 2.915E-02 2.685E-02 2.449E-02 2.210E-02 1.969E-02 1.730E-02 1.494E-02 1.266E-02 1.048E-02 8.424E-03 6.525E-03 4.814E-03 3.318E-03 2.066E-03 1.086E-03 4.056E-04 4.919E-05 4.092E-05 4.028E-04 1.155E-03 2.314E-03 3.896E-03 5.913E-03 8.375E-03 1.129E-02 1.465E-02 1.847E-02 2.274E-02 2.745E-02 3.259E-02 3.814E-02 4.409E-02 5.042E-02 5.710E-02 6.410E-02 7.139E-02 7.893E-02 8.668E-02 9.462E-02 1.027E-01 1.108E-01 1.190E-01 1.272E-01 1.354E-01 1.434E-01 1.513E-01 1.589E-01 1.663E-01 1.735E-01 1.802E-01 1.866E-01 1.926E-01 1.980E-01 2.030E-01 2.074E-01 2.112E-01 2.145E-01 2.171E-01 2.191E-01 2.204E-01 2.211E-01 2.211E-01 2.204E-01 2.191E-01 2.171E-01 2.146E-01 2.114E-01 2.076E-01 2.033E-01 1.985E-01 1.932E-01 1.875E-01 1.813E-01 1.748E-01 1.680E-01 1.610E-01 1.538E-01 1.464E-01 1.389E-01 1.313E-01 1.237E-01 1.162E-01 1.088E-01 1.015E-01 9.435E-02 8.741E-02 8.071E-02 7.428E-02 6.813E-02 6.230E-02 5.679E-02 5.161E-02 4.679E-02 4.231E-02 3.819E-02 3.441E-02 3.098E-02 2.787E-02 2.508E-02 2.260E-02 2.042E-02 1.850E-02 1.684E-02 1.543E-02 1.424E-02 1.326E-02 1.248E-02 1.189E-02 1.147E-02 1.122E-02 1.114E-02 1.122E-02 1.147E-02 1.189E-02 1.248E-02 1.326E-02 1.424E-02 1.543E-02 1.684E-02 1.850E-02 2.042E-02 2.260E-02 2.508E-02 2.787E-02 3.098E-02 3.441E-02 3.819E-02 4.231E-02 4.679E-02 5.161E-02 5.679E-02 6.230E-02 6.813E-02 7.428E-02 8.071E-02 8.741E-02 9.435E-02 1.015E-01 1.088E-01 1.162E-01 1.237E-01 1.313E-01 1.389E-01 1.464E-01 1.538E-01 1.610E-01 1.680E-01 1.748E-01 1.813E-01 1.875E-01 1.932E-01 1.985E-01 2.033E-01 2.076E-01 2.114E-01 2.146E-01 2.171E-01 2.191E-01 2.204E-01 2.211E-01 2.211E-01 2.204E-01 2.191E-01 2.171E-01 2.145E-01 2.112E-01 2.074E-01 2.030E-01 1.980E-01 1.926E-01 1.866E-01 1.802E-01 1.735E-01 1.663E-01 1.589E-01 1.513E-01 1.434E-01 1.354E-01 1.272E-01 1.190E-01 1.108E-01 1.027E-01 9.462E-02 8.668E-02 7.893E-02 7.139E-02 6.410E-02 5.710E-02 5.042E-02 4.409E-02 3.814E-02 3.259E-02 2.745E-02 2.274E-02 1.847E-02 1.465E-02 1.129E-02 8.375E-03 5.913E-03 3.896E-03 2.314E-03 1.155E-03 4.028E-04 4.092E-05 4.919E-05 4.056E-04 1.086E-03 2.066E-03 3.318E-03 4.814E-03 6.525E-03 8.424E-03 1.048E-02 1.266E-02 1.494E-02 1.730E-02 1.969E-02 2.210E-02 2.449E-02 2.685E-02 2.915E-02 3.136E-02 3.347E-02 3.546E-02 3.731E-02 3.901E-02 4.054E-02 4.190E-02 4.307E-02 4.405E-02 4.483E-02 4.540E-02 4.578E-02 4.596E-02 4.593E-02 4.572E-02 4.531E-02 4.473E-02 4.372E-02 4.452E-02 4.516E-02 4.562E-02 4.589E-02 4.597E-02 4.586E-02 4.554E-02 4.503E-02 4.431E-02 4.340E-02 4.230E-02 4.100E-02 3.953E-02 3.789E-02 3.609E-02 3.415E-02 3.209E-02 2.991E-02 2.765E-02 2.531E-02 2.294E-02 2.054E-02 1.815E-02 1.578E-02 1.348E-02 1.127E-02 9.169E-03 7.216E-03 5.437E-03 3.862E-03 2.518E-03 1.434E-03 6.364E-04 1.507E-04 9.375E-07 2.096E-04 7.971E-04 1.782E-03 3.179E-03 5.002E-03 7.262E-03 9.965E-03 1.312E-02 1.671E-02 2.076E-02 2.525E-02 3.016E-02 3.549E-02 4.123E-02 4.734E-02 5.382E-02 6.062E-02 6.772E-02 7.509E-02 8.269E-02 9.048E-02 9.843E-02 1.065E-01 1.146E-01 1.227E-01 1.308E-01 1.389E-01 1.468E-01 1.545E-01 1.620E-01 1.692E-01 1.761E-01 1.827E-01 1.889E-01 1.946E-01 1.998E-01 2.045E-01 2.087E-01 2.123E-01 2.153E-01 2.177E-01 2.195E-01 2.206E-01 2.211E-01 2.210E-01 2.202E-01 2.188E-01 2.167E-01 2.141E-01 2.109E-01 2.072E-01 2.029E-01 1.981E-01 1.929E-01 1.873E-01 1.813E-01 1.750E-01 1.684E-01 1.616E-01 1.546E-01 1.475E-01 1.403E-01 1.330E-01 1.257E-01 1.185E-01 1.114E-01 1.044E-01 9.759E-02 9.095E-02 8.454E-02 7.838E-02 7.250E-02 6.691E-02 6.162E-02 5.665E-02 5.201E-02 4.770E-02 4.371E-02 4.005E-02 3.672E-02 3.369E-02 3.098E-02 2.855E-02 2.641E-02 2.454E-02 2.292E-02 2.155E-02 2.042E-02 1.950E-02 1.880E-02 1.830E-02 1.801E-02 1.791E-02 1.801E-02 1.830E-02 1.880E-02 1.950E-02 2.042E-02 2.155E-02 2.292E-02 2.454E-02 2.641E-02 2.855E-02 3.098E-02 3.369E-02 3.672E-02 4.005E-02 4.371E-02 4.770E-02 5.201E-02 5.665E-02 6.162E-02 6.691E-02 7.250E-02 7.838E-02 8.454E-02 9.095E-02 9.759E-02 1.044E-01 1.114E-01 1.185E-01 1.257E-01 1.330E-01 1.403E-01 1.475E-01 1.546E-01 1.616E-01 1.684E-01 1.750E-01 1.813E-01 1.873E-01 1.929E-01 1.981E-01 2.029E-01 2.072E-01 2.109E-01 2.141E-01 2.167E-01 2.188E-01 2.202E-01 2.210E-01 2.211E-01 2.206E-01 2.195E-01 2.177E-01 2.153E-01 2.123E-01 2.087E-01 2.045E-01 1.998E-01 1.946E-01 1.889E-01 1.827E-01 1.761E-01 1.692E-01 1.620E-01 1.545E-01 1.468E-01 1.389E-01 1.308E-01 1.227E-01 1.146E-01 1.065E-01 9.843E-02 9.048E-02 8.269E-02 7.509E-02 6.772E-02 6.062E-02 5.382E-02 4.734E-02 4.123E-02 3.549E-02 3.016E-02 2.525E-02 2.076E-02 1.671E-02 1.312E-02 9.965E-03 7.262E-03 5.002E-03 3.179E-03 1.782E-03 7.971E-04 2.096E-04 9.375E-07 1.507E-04 6.364E-04 1.434E-03 2.518E-03 3.862E-03 5.437E-03 7.216E-03 9.169E-03 1.127E-02 1.348E-02 1.578E-02 1.815E-02 2.054E-02 2.294E-02 2.531E-02 2.765E-02 2.991E-02 3.209E-02 3.415E-02 3.609E-02 3.789E-02 3.953E-02 4.100E-02 4.230E-02 4.340E-02 4.431E-02 4.503E-02 4.554E-02 4.586E-02 4.597E-02 4.589E-02 4.562E-02 4.516E-02 4.452E-02 4.344E-02 4.430E-02 4.498E-02 4.550E-02 4.583E-02 4.597E-02 4.591E-02 4.566E-02 4.521E-02 4.457E-02 4.372E-02 4.268E-02 4.145E-02 4.004E-02 3.846E-02 3.672E-02 3.483E-02 3.281E-02 3.068E-02 2.845E-02 2.615E-02 2.379E-02 2.141E-02 1.902E-02 1.665E-02 1.433E-02 1.209E-02 9.951E-03 7.947E-03 6.105E-03 4.453E-03 3.021E-03 1.835E-03 9.228E-04 3.099E-04 2.057E-05 7.755E-05 5.017E-04 1.312E-03 2.524E-03 4.153E-03 6.210E-03 8.703E-03 1.164E-02 1.501E-02 1.883E-02 2.309E-02 2.778E-02 3.288E-02 3.839E-02 4.429E-02 5.055E-02 5.714E-02 6.405E-02 7.124E-02 7.867E-02 8.631E-02 9.412E-02 1.021E-01 1.101E-01 1.181E-01 1.262E-01 1.342E-01 1.421E-01 1.499E-01 1.575E-01 1.648E-01 1.718E-01 1.786E-01 1.849E-01 1.908E-01 1.963E-01 2.014E-01 2.058E-01 2.098E-01 2.132E-01 2.160E-01 2.182E-01 2.198E-01 2.208E-01 2.211E-01 2.209E-01 2.200E-01 2.185E-01 2.164E-01 2.138E-01 2.106E-01 2.069E-01 2.027E-01 1.980E-01 1.929E-01 1.875E-01 1.816E-01 1.755E-01 1.692E-01 1.626E-01 1.559E-01 1.490E-01 1.421E-01 1.352E-01 1.282E-01 1.213E-01 1.145E-01 1.079E-01 1.013E-01 9.502E-02 8.891E-02 8.304E-02 7.743E-02 7.209E-02 6.704E-02 6.230E-02 5.786E-02 5.373E-02 4.991E-02 4.640E-02 4.320E-02 4.030E-02 3.770E-02 3.538E-02 3.333E-02 3.156E-02 3.005E-02 2.878E-02 2.776E-02 2.697E-02 2.641E-02 2.608E-02 2.597E-02 2.608E-02 2.641E-02 2.697E-02 2.776E-02 2.878E-02 3.005E-02 3.156E-02 3.333E-02 3.538E-02 3.770E-02 4.030E-02 4.320E-02 4.640E-02 4.991E-02 5.373E-02 5.786E-02 6.230E-02 6.704E-02 7.209E-02 7.743E-02 8.304E-02 8.891E-02 9.502E-02 1.013E-01 1.079E-01 1.145E-01 1.213E-01 1.282E-01 1.352E-01 1.421E-01 1.490E-01 1.559E-01 1.626E-01 1.692E-01 1.755E-01 1.816E-01 1.875E-01 1.929E-01 1.980E-01 2.027E-01 2.069E-01 2.106E-01 2.138E-01 2.164E-01 2.185E-01 2.200E-01 2.209E-01 2.211E-01 2.208E-01 2.198E-01 2.182E-01 2.160E-01 2.132E-01 2.098E-01 2.058E-01 2.014E-01 1.963E-01 1.908E-01 1.849E-01 1.786E-01 1.718E-01 1.648E-01 1.575E-01 1.499E-01 1.421E-01 1.342E-01 1.262E-01 1.181E-01 1.101E-01 1.021E-01 9.412E-02 8.631E-02 7.867E-02 7.124E-02 6.405E-02 5.714E-02 5.055E-02 4.429E-02 3.839E-02 3.288E-02 2.778E-02 2.309E-02 1.883E-02 1.501E-02 1.164E-02 8.703E-03 6.210E-03 4.153E-03 2.524E-03 1.312E-03 5.017E-04 7.755E-05 2.057E-05 3.099E-04 9.228E-04 1.835E-03 3.021E-03 4.453E-03 6.105E-03 7.947E-03 9.951E-03 1.209E-02 1.433E-02 1.665E-02 1.902E-02 2.141E-02 2.379E-02 2.615E-02 2.845E-02 3.068E-02 3.281E-02 3.483E-02 3.672E-02 3.846E-02 4.004E-02 4.145E-02 4.268E-02 4.372E-02 4.457E-02 4.521E-02 4.566E-02 4.591E-02 4.597E-02 4.583E-02 4.550E-02 4.498E-02 4.430E-02 4.315E-02 4.405E-02 4.479E-02 4.535E-02 4.574E-02 4.594E-02 4.595E-02 4.577E-02 4.538E-02 4.480E-02 4.402E-02 4.305E-02 4.189E-02 4.054E-02 3.903E-02 3.735E-02 3.551E-02 3.355E-02 3.146E-02 2.927E-02 2.700E-02 2.467E-02 2.230E-02 1.991E-02 1.754E-02 1.521E-02 1.295E-02 1.077E-02 8.719E-03 6.817E-03 5.093E-03 3.575E-03 2.290E-03 1.266E-03 5.289E-04 1.022E-04 9.360E-06 2.717E-04 9.085E-04 1.937E-03 3.372E-03 5.225E-03 7.506E-03 1.022E-02 1.337E-02 1.697E-02 2.099E-02 2.545E-02 3.032E-02 3.560E-02 4.127E-02 4.730E-02 5.369E-02 6.039E-02 6.738E-02 7.463E-02 8.211E-02 8.977E-02 9.758E-02 1.055E-01 1.135E-01 1.215E-01 1.294E-01 1.374E-01 1.451E-01 1.528E-01 1.602E-01 1.673E-01 1.742E-01 1.807E-01 1.869E-01 1.926E-01 1.979E-01 2.027E-01 2.070E-01 2.107E-01 2.139E-01 2.166E-01 2.186E-01 2.201E-01 2.209E-01 2.211E-01 2.208E-01 2.198E-01 2.183E-01 2.162E-01 2.136E-01 2.104E-01 2.068E-01 2.027E-01 1.981E-01 1.932E-01 1.879E-01 1.823E-01 1.764E-01 1.703E-01 1.640E-01 1.576E-01 1.510E-01 1.444E-01 1.378E-01 1.312E-01 1.246E-01 1.182E-01 1.118E-01 1.056E-01 9.961E-02 9.380E-02 8.823E-02 8.290E-02 7.784E-02 7.305E-02 6.854E-02 6.433E-02 6.041E-02 5.679E-02 5.346E-02 5.043E-02 4.770E-02 4.524E-02 4.307E-02 4.118E-02 3.955E-02 3.819E-02 3.708E-02 3.623E-02 3.562E-02 3.526E-02 3.513E-02 3.526E-02 3.562E-02 3.623E-02 3.708E-02 3.819E-02 3.955E-02 4.118E-02 4.307E-02 4.524E-02 4.770E-02 5.043E-02 5.346E-02 5.679E-02 6.041E-02 6.433E-02 6.854E-02 7.305E-02 7.784E-02 8.290E-02 8.823E-02 9.380E-02 9.961E-02 1.056E-01 1.118E-01 1.182E-01 1.246E-01 1.312E-01 1.378E-01 1.444E-01 1.510E-01 1.576E-01 1.640E-01 1.703E-01 1.764E-01 1.823E-01 1.879E-01 1.932E-01 1.981E-01 2.027E-01 2.068E-01 2.104E-01 2.136E-01 2.162E-01 2.183E-01 2.198E-01 2.208E-01 2.211E-01 2.209E-01 2.201E-01 2.186E-01 2.166E-01 2.139E-01 2.107E-01 2.070E-01 2.027E-01 1.979E-01 1.926E-01 1.869E-01 1.807E-01 1.742E-01 1.673E-01 1.602E-01 1.528E-01 1.451E-01 1.374E-01 1.294E-01 1.215E-01 1.135E-01 1.055E-01 9.758E-02 8.977E-02 8.211E-02 7.463E-02 6.738E-02 6.039E-02 5.369E-02 4.730E-02 4.127E-02 3.560E-02 3.032E-02 2.545E-02 2.099E-02 1.697E-02 1.337E-02 1.022E-02 7.506E-03 5.225E-03 3.372E-03 1.937E-03 9.085E-04 2.717E-04 9.360E-06 1.022E-04 5.289E-04 1.266E-03 2.290E-03 3.575E-03 5.093E-03 6.817E-03 8.719E-03 1.077E-02 1.295E-02 1.521E-02 1.754E-02 1.991E-02 2.230E-02 2.467E-02 2.700E-02 2.927E-02 3.146E-02 3.355E-02 3.551E-02 3.735E-02 3.903E-02 4.054E-02 4.189E-02 4.305E-02 4.402E-02 4.480E-02 4.538E-02 4.577E-02 4.595E-02 4.594E-02 4.574E-02 4.535E-02 4.479E-02 4.405E-02 4.283E-02 4.378E-02 4.457E-02 4.519E-02 4.563E-02 4.590E-02 4.597E-02 4.585E-02 4.554E-02 4.502E-02 4.431E-02 4.341E-02 4.232E-02 4.104E-02 3.958E-02 3.796E-02 3.619E-02 3.428E-02 3.224E-02 3.009E-02 2.786E-02 2.555E-02 2.320E-02 2.083E-02 1.846E-02 1.612E-02 1.383E-02 1.163E-02 9.533E-03 7.574E-03 5.780E-03 4.180E-03 2.801E-03 1.668E-03 8.092E-04 2.478E-04 7.597E-06 1.101E-04 5.752E-04 1.421E-03 2.662E-03 4.312E-03 6.381E-03 8.877E-03 1.180E-02 1.516E-02 1.896E-02 2.317E-02 2.781E-02 3.285E-02 3.829E-02 4.409E-02 5.025E-02 5.674E-02 6.353E-02 7.060E-02 7.790E-02 8.540E-02 9.307E-02 1.009E-01 1.087E-01 1.167E-01 1.246E-01 1.325E-01 1.402E-01 1.479E-01 1.554E-01 1.626E-01 1.696E-01 1.763E-01 1.826E-01 1.886E-01 1.941E-01 1.992E-01 2.038E-01 2.079E-01 2.115E-01 2.146E-01 2.170E-01 2.189E-01 2.202E-01 2.210E-01 2.211E-01 2.207E-01 2.197E-01 2.182E-01 2.161E-01 2.135E-01 2.104E-01 2.069E-01 2.029E-01 1.985E-01 1.937E-01 1.887E-01 1.833E-01 1.777E-01 1.718E-01 1.658E-01 1.597E-01 1.534E-01 1.471E-01 1.408E-01 1.346E-01 1.284E-01 1.222E-01 1.162E-01 1.104E-01 1.047E-01 9.920E-02 9.394E-02 8.891E-02 8.413E-02 7.962E-02 7.537E-02 7.141E-02 6.772E-02 6.433E-02 6.122E-02 5.839E-02 5.585E-02 5.359E-02 5.161E-02 4.991E-02 4.847E-02 4.731E-02 4.640E-02 4.576E-02 4.537E-02 4.524E-02 4.537E-02 4.576E-02 4.640E-02 4.731E-02 4.847E-02 4.991E-02 5.161E-02 5.359E-02 5.585E-02 5.839E-02 6.122E-02 6.433E-02 6.772E-02 7.141E-02 7.537E-02 7.962E-02 8.413E-02 8.891E-02 9.394E-02 9.920E-02 1.047E-01 1.104E-01 1.162E-01 1.222E-01 1.284E-01 1.346E-01 1.408E-01 1.471E-01 1.534E-01 1.597E-01 1.658E-01 1.718E-01 1.777E-01 1.833E-01 1.887E-01 1.937E-01 1.985E-01 2.029E-01 2.069E-01 2.104E-01 2.135E-01 2.161E-01 2.182E-01 2.197E-01 2.207E-01 2.211E-01 2.210E-01 2.202E-01 2.189E-01 2.170E-01 2.146E-01 2.115E-01 2.079E-01 2.038E-01 1.992E-01 1.941E-01 1.886E-01 1.826E-01 1.763E-01 1.696E-01 1.626E-01 1.554E-01 1.479E-01 1.402E-01 1.325E-01 1.246E-01 1.167E-01 1.087E-01 1.009E-01 9.307E-02 8.540E-02 7.790E-02 7.060E-02 6.353E-02 5.674E-02 5.025E-02 4.409E-02 3.829E-02 3.285E-02 2.781E-02 2.317E-02 1.896E-02 1.516E-02 1.180E-02 8.877E-03 6.381E-03 4.312E-03 2.662E-03 1.421E-03 5.752E-04 1.101E-04 7.597E-06 2.478E-04 8.092E-04 1.668E-03 2.801E-03 4.180E-03 5.780E-03 7.574E-03 9.533E-03 1.163E-02 1.383E-02 1.612E-02 1.846E-02 2.083E-02 2.320E-02 2.555E-02 2.786E-02 3.009E-02 3.224E-02 3.428E-02 3.619E-02 3.796E-02 3.958E-02 4.104E-02 4.232E-02 4.341E-02 4.431E-02 4.502E-02 4.554E-02 4.585E-02 4.597E-02 4.590E-02 4.563E-02 4.519E-02 4.457E-02 4.378E-02 4.250E-02 4.349E-02 4.433E-02 4.500E-02 4.551E-02 4.583E-02 4.597E-02 4.591E-02 4.567E-02 4.522E-02 4.458E-02 4.375E-02 4.273E-02 4.152E-02 4.013E-02 3.858E-02 3.686E-02 3.501E-02 3.302E-02 3.092E-02 2.872E-02 2.645E-02 2.413E-02 2.177E-02 1.940E-02 1.706E-02 1.475E-02 1.252E-02 1.039E-02 8.375E-03 6.516E-03 4.838E-03 3.367E-03 2.130E-03 1.152E-03 4.594E-04 7.455E-05 1.967E-05 3.151E-04 9.791E-04 2.028E-03 3.475E-03 5.332E-03 7.608E-03 1.031E-02 1.344E-02 1.699E-02 2.097E-02 2.536E-02 3.016E-02 3.536E-02 4.093E-02 4.686E-02 5.313E-02 5.971E-02 6.657E-02 7.368E-02 8.101E-02 8.852E-02 9.618E-02 1.039E-01 1.118E-01 1.196E-01 1.275E-01 1.352E-01 1.429E-01 1.504E-01 1.578E-01 1.648E-01 1.717E-01 1.782E-01 1.843E-01 1.901E-01 1.955E-01 2.004E-01 2.048E-01 2.087E-01 2.121E-01 2.150E-01 2.174E-01 2.191E-01 2.204E-01 2.210E-01 2.211E-01 2.207E-01 2.197E-01 2.181E-01 2.161E-01 2.136E-01 2.106E-01 2.072E-01 2.033E-01 1.991E-01 1.946E-01 1.897E-01 1.846E-01 1.792E-01 1.737E-01 1.679E-01 1.621E-01 1.562E-01 1.503E-01 1.443E-01 1.384E-01 1.325E-01 1.267E-01 1.211E-01 1.156E-01 1.102E-01 1.051E-01 1.001E-01 9.543E-02 9.095E-02 8.673E-02 8.276E-02 7.907E-02 7.565E-02 7.250E-02 6.963E-02 6.704E-02 6.473E-02 6.270E-02 6.095E-02 5.947E-02 5.826E-02 5.732E-02 5.665E-02 5.625E-02 5.612E-02 5.625E-02 5.665E-02 5.732E-02 5.826E-02 5.947E-02 6.095E-02 6.270E-02 6.473E-02 6.704E-02 6.963E-02 7.250E-02 7.565E-02 7.907E-02 8.276E-02 8.673E-02 9.095E-02 9.543E-02 1.001E-01 1.051E-01 1.102E-01 1.156E-01 1.211E-01 1.267E-01 1.325E-01 1.384E-01 1.443E-01 1.503E-01 1.562E-01 1.621E-01 1.679E-01 1.737E-01 1.792E-01 1.846E-01 1.897E-01 1.946E-01 1.991E-01 2.033E-01 2.072E-01 2.106E-01 2.136E-01 2.161E-01 2.181E-01 2.197E-01 2.207E-01 2.211E-01 2.210E-01 2.204E-01 2.191E-01 2.174E-01 2.150E-01 2.121E-01 2.087E-01 2.048E-01 2.004E-01 1.955E-01 1.901E-01 1.843E-01 1.782E-01 1.717E-01 1.648E-01 1.578E-01 1.504E-01 1.429E-01 1.352E-01 1.275E-01 1.196E-01 1.118E-01 1.039E-01 9.618E-02 8.852E-02 8.101E-02 7.368E-02 6.657E-02 5.971E-02 5.313E-02 4.686E-02 4.093E-02 3.536E-02 3.016E-02 2.536E-02 2.097E-02 1.699E-02 1.344E-02 1.031E-02 7.608E-03 5.332E-03 3.475E-03 2.028E-03 9.791E-04 3.151E-04 1.967E-05 7.455E-05 4.594E-04 1.152E-03 2.130E-03 3.367E-03 4.838E-03 6.516E-03 8.375E-03 1.039E-02 1.252E-02 1.475E-02 1.706E-02 1.940E-02 2.177E-02 2.413E-02 2.645E-02 2.872E-02 3.092E-02 3.302E-02 3.501E-02 3.686E-02 3.858E-02 4.013E-02 4.152E-02 4.273E-02 4.375E-02 4.458E-02 4.522E-02 4.567E-02 4.591E-02 4.597E-02 4.583E-02 4.551E-02 4.500E-02 4.433E-02 4.349E-02 4.213E-02 4.317E-02 4.406E-02 4.479E-02 4.535E-02 4.574E-02 4.594E-02 4.595E-02 4.578E-02 4.540E-02 4.484E-02 4.408E-02 4.312E-02 4.199E-02 4.067E-02 3.918E-02 3.753E-02 3.573E-02 3.380E-02 3.175E-02 2.960E-02 2.736E-02 2.506E-02 2.272E-02 2.037E-02 1.802E-02 1.571E-02 1.345E-02 1.128E-02 9.219E-03 7.300E-03 5.548E-03 3.989E-03 2.651E-03 1.559E-03 7.385E-04 2.122E-04 2.840E-06 1.311E-04 6.158E-04 1.474E-03 2.720E-03 4.365E-03 6.421E-03 8.893E-03 1.179E-02 1.510E-02 1.883E-02 2.298E-02 2.754E-02 3.249E-02 3.782E-02 4.351E-02 4.955E-02 5.591E-02 6.255E-02 6.947E-02 7.661E-02 8.396E-02 9.147E-02 9.910E-02 1.068E-01 1.146E-01 1.224E-01 1.301E-01 1.378E-01 1.453E-01 1.527E-01 1.599E-01 1.668E-01 1.735E-01 1.798E-01 1.858E-01 1.914E-01 1.966E-01 2.013E-01 2.056E-01 2.094E-01 2.126E-01 2.154E-01 2.176E-01 2.193E-01 2.204E-01 2.210E-01 2.211E-01 2.206E-01 2.197E-01 2.182E-01 2.162E-01 2.138E-01 2.109E-01 2.076E-01 2.040E-01 2.000E-01 1.956E-01 1.910E-01 1.861E-01 1.811E-01 1.758E-01 1.704E-01 1.649E-01 1.594E-01 1.538E-01 1.482E-01 1.426E-01 1.371E-01 1.317E-01 1.264E-01 1.212E-01 1.162E-01 1.114E-01 1.068E-01 1.024E-01 9.826E-02 9.435E-02 9.068E-02 8.727E-02 8.413E-02 8.126E-02 7.866E-02 7.633E-02 7.428E-02 7.250E-02 7.100E-02 6.977E-02 6.881E-02 6.813E-02 6.772E-02 6.759E-02 6.772E-02 6.813E-02 6.881E-02 6.977E-02 7.100E-02 7.250E-02 7.428E-02 7.633E-02 7.866E-02 8.126E-02 8.413E-02 8.727E-02 9.068E-02 9.435E-02 9.826E-02 1.024E-01 1.068E-01 1.114E-01 1.162E-01 1.212E-01 1.264E-01 1.317E-01 1.371E-01 1.426E-01 1.482E-01 1.538E-01 1.594E-01 1.649E-01 1.704E-01 1.758E-01 1.811E-01 1.861E-01 1.910E-01 1.956E-01 2.000E-01 2.040E-01 2.076E-01 2.109E-01 2.138E-01 2.162E-01 2.182E-01 2.197E-01 2.206E-01 2.211E-01 2.210E-01 2.204E-01 2.193E-01 2.176E-01 2.154E-01 2.126E-01 2.094E-01 2.056E-01 2.013E-01 1.966E-01 1.914E-01 1.858E-01 1.798E-01 1.735E-01 1.668E-01 1.599E-01 1.527E-01 1.453E-01 1.378E-01 1.301E-01 1.224E-01 1.146E-01 1.068E-01 9.910E-02 9.147E-02 8.396E-02 7.661E-02 6.947E-02 6.255E-02 5.591E-02 4.955E-02 4.351E-02 3.782E-02 3.249E-02 2.754E-02 2.298E-02 1.883E-02 1.510E-02 1.179E-02 8.893E-03 6.421E-03 4.365E-03 2.720E-03 1.474E-03 6.158E-04 1.311E-04 2.840E-06 2.122E-04 7.385E-04 1.559E-03 2.651E-03 3.989E-03 5.548E-03 7.300E-03 9.219E-03 1.128E-02 1.345E-02 1.571E-02 1.802E-02 2.037E-02 2.272E-02 2.506E-02 2.736E-02 2.960E-02 3.175E-02 3.380E-02 3.573E-02 3.753E-02 3.918E-02 4.067E-02 4.199E-02 4.312E-02 4.408E-02 4.484E-02 4.540E-02 4.578E-02 4.595E-02 4.594E-02 4.574E-02 4.535E-02 4.479E-02 4.406E-02 4.317E-02 4.175E-02 4.283E-02 4.377E-02 4.456E-02 4.518E-02 4.562E-02 4.589E-02 4.597E-02 4.586E-02 4.556E-02 4.507E-02 4.438E-02 4.350E-02 4.244E-02 4.119E-02 3.977E-02 3.819E-02 3.645E-02 3.458E-02 3.258E-02 3.047E-02 2.828E-02 2.601E-02 2.369E-02 2.135E-02 1.901E-02 1.668E-02 1.441E-02 1.221E-02 1.011E-02 8.131E-03 6.309E-03 4.668E-03 3.234E-03 2.031E-03 1.086E-03 4.223E-04 6.178E-05 2.589E-05 3.339E-04 1.003E-03 2.049E-03 3.485E-03 5.320E-03 7.564E-03 1.022E-02 1.329E-02 1.678E-02 2.068E-02 2.499E-02 2.969E-02 3.477E-02 4.022E-02 4.602E-02 5.215E-02 5.857E-02 6.528E-02 7.223E-02 7.939E-02 8.674E-02 9.423E-02 1.018E-01 1.095E-01 1.172E-01 1.249E-01 1.325E-01 1.401E-01 1.475E-01 1.547E-01 1.618E-01 1.685E-01 1.750E-01 1.812E-01 1.870E-01 1.925E-01 1.975E-01 2.021E-01 2.062E-01 2.098E-01 2.130E-01 2.156E-01 2.178E-01 2.194E-01 2.205E-01 2.211E-01 2.211E-01 2.207E-01 2.197E-01 2.183E-01 2.164E-01 2.141E-01 2.114E-01 2.083E-01 2.048E-01 2.010E-01 1.969E-01 1.926E-01 1.880E-01 1.832E-01 1.783E-01 1.732E-01 1.680E-01 1.628E-01 1.576E-01 1.523E-01 1.471E-01 1.420E-01 1.370E-01 1.320E-01 1.272E-01 1.226E-01 1.182E-01 1.139E-01 1.098E-01 1.060E-01 1.024E-01 9.907E-02 9.597E-02 9.313E-02 9.054E-02 8.823E-02 8.618E-02 8.441E-02 8.290E-02 8.167E-02 8.071E-02 8.003E-02 7.962E-02 7.948E-02 7.962E-02 8.003E-02 8.071E-02 8.167E-02 8.290E-02 8.441E-02 8.618E-02 8.823E-02 9.054E-02 9.313E-02 9.597E-02 9.907E-02 1.024E-01 1.060E-01 1.098E-01 1.139E-01 1.182E-01 1.226E-01 1.272E-01 1.320E-01 1.370E-01 1.420E-01 1.471E-01 1.523E-01 1.576E-01 1.628E-01 1.680E-01 1.732E-01 1.783E-01 1.832E-01 1.880E-01 1.926E-01 1.969E-01 2.010E-01 2.048E-01 2.083E-01 2.114E-01 2.141E-01 2.164E-01 2.183E-01 2.197E-01 2.207E-01 2.211E-01 2.211E-01 2.205E-01 2.194E-01 2.178E-01 2.156E-01 2.130E-01 2.098E-01 2.062E-01 2.021E-01 1.975E-01 1.925E-01 1.870E-01 1.812E-01 1.750E-01 1.685E-01 1.618E-01 1.547E-01 1.475E-01 1.401E-01 1.325E-01 1.249E-01 1.172E-01 1.095E-01 1.018E-01 9.423E-02 8.674E-02 7.939E-02 7.223E-02 6.528E-02 5.857E-02 5.215E-02 4.602E-02 4.022E-02 3.477E-02 2.969E-02 2.499E-02 2.068E-02 1.678E-02 1.329E-02 1.022E-02 7.564E-03 5.320E-03 3.485E-03 2.049E-03 1.003E-03 3.339E-04 2.589E-05 6.178E-05 4.223E-04 1.086E-03 2.031E-03 3.234E-03 4.668E-03 6.309E-03 8.131E-03 1.011E-02 1.221E-02 1.441E-02 1.668E-02 1.901E-02 2.135E-02 2.369E-02 2.601E-02 2.828E-02 3.047E-02 3.258E-02 3.458E-02 3.645E-02 3.819E-02 3.977E-02 4.119E-02 4.244E-02 4.350E-02 4.438E-02 4.507E-02 4.556E-02 4.586E-02 4.597E-02 4.589E-02 4.562E-02 4.518E-02 4.456E-02 4.377E-02 4.283E-02 4.134E-02 4.247E-02 4.346E-02 4.430E-02 4.497E-02 4.548E-02 4.581E-02 4.596E-02 4.593E-02 4.570E-02 4.528E-02 4.466E-02 4.386E-02 4.287E-02 4.170E-02 4.035E-02 3.884E-02 3.717E-02 3.535E-02 3.341E-02 3.135E-02 2.920E-02 2.697E-02 2.468E-02 2.235E-02 2.002E-02 1.769E-02 1.540E-02 1.317E-02 1.103E-02 9.008E-03 7.122E-03 5.403E-03 3.877E-03 2.568E-03 1.504E-03 7.061E-04 1.983E-04 1.762E-06 1.362E-04 6.196E-04 1.468E-03 2.695E-03 4.312E-03 6.328E-03 8.750E-03 1.158E-02 1.482E-02 1.847E-02 2.252E-02 2.697E-02 3.180E-02 3.700E-02 4.255E-02 4.844E-02 5.464E-02 6.112E-02 6.786E-02 7.484E-02 8.200E-02 8.934E-02 9.680E-02 1.043E-01 1.120E-01 1.196E-01 1.272E-01 1.347E-01 1.421E-01 1.494E-01 1.565E-01 1.634E-01 1.700E-01 1.764E-01 1.824E-01 1.880E-01 1.933E-01 1.982E-01 2.027E-01 2.066E-01 2.102E-01 2.132E-01 2.158E-01 2.179E-01 2.194E-01 2.205E-01 2.210E-01 2.211E-01 2.207E-01 2.198E-01 2.185E-01 2.167E-01 2.146E-01 2.120E-01 2.091E-01 2.058E-01 2.023E-01 1.984E-01 1.944E-01 1.901E-01 1.856E-01 1.810E-01 1.763E-01 1.714E-01 1.666E-01 1.617E-01 1.568E-01 1.520E-01 1.473E-01 1.426E-01 1.380E-01 1.336E-01 1.293E-01 1.252E-01 1.213E-01 1.176E-01 1.142E-01 1.109E-01 1.079E-01 1.051E-01 1.026E-01 1.003E-01 9.826E-02 9.651E-02 9.502E-02 9.380E-02 9.285E-02 9.218E-02 9.177E-02 9.163E-02 9.177E-02 9.218E-02 9.285E-02 9.380E-02 9.502E-02 9.651E-02 9.826E-02 1.003E-01 1.026E-01 1.051E-01 1.079E-01 1.109E-01 1.142E-01 1.176E-01 1.213E-01 1.252E-01 1.293E-01 1.336E-01 1.380E-01 1.426E-01 1.473E-01 1.520E-01 1.568E-01 1.617E-01 1.666E-01 1.714E-01 1.763E-01 1.810E-01 1.856E-01 1.901E-01 1.944E-01 1.984E-01 2.023E-01 2.058E-01 2.091E-01 2.120E-01 2.146E-01 2.167E-01 2.185E-01 2.198E-01 2.207E-01 2.211E-01 2.210E-01 2.205E-01 2.194E-01 2.179E-01 2.158E-01 2.132E-01 2.102E-01 2.066E-01 2.027E-01 1.982E-01 1.933E-01 1.880E-01 1.824E-01 1.764E-01 1.700E-01 1.634E-01 1.565E-01 1.494E-01 1.421E-01 1.347E-01 1.272E-01 1.196E-01 1.120E-01 1.043E-01 9.680E-02 8.934E-02 8.200E-02 7.484E-02 6.786E-02 6.112E-02 5.464E-02 4.844E-02 4.255E-02 3.700E-02 3.180E-02 2.697E-02 2.252E-02 1.847E-02 1.482E-02 1.158E-02 8.750E-03 6.328E-03 4.312E-03 2.695E-03 1.468E-03 6.196E-04 1.362E-04 1.762E-06 1.983E-04 7.061E-04 1.504E-03 2.568E-03 3.877E-03 5.403E-03 7.122E-03 9.008E-03 1.103E-02 1.317E-02 1.540E-02 1.769E-02 2.002E-02 2.235E-02 2.468E-02 2.697E-02 2.920E-02 3.135E-02 3.341E-02 3.535E-02 3.717E-02 3.884E-02 4.035E-02 4.170E-02 4.287E-02 4.386E-02 4.466E-02 4.528E-02 4.570E-02 4.593E-02 4.596E-02 4.581E-02 4.548E-02 4.497E-02 4.430E-02 4.346E-02 4.247E-02 4.091E-02 4.208E-02 4.312E-02 4.401E-02 4.474E-02 4.531E-02 4.571E-02 4.593E-02 4.596E-02 4.581E-02 4.546E-02 4.492E-02 4.420E-02 4.328E-02 4.219E-02 4.091E-02 3.947E-02 3.787E-02 3.612E-02 3.423E-02 3.223E-02 3.012E-02 2.793E-02 2.567E-02 2.337E-02 2.105E-02 1.872E-02 1.643E-02 1.418E-02 1.200E-02 9.931E-03 7.986E-03 6.193E-03 4.580E-03 3.171E-03 1.991E-03 1.065E-03 4.139E-04 6.067E-05 2.515E-05 3.258E-04 9.791E-04 2.000E-03 3.400E-03 5.189E-03 7.376E-03 9.965E-03 1.296E-02 1.635E-02 2.015E-02 2.434E-02 2.891E-02 3.385E-02 3.916E-02 4.480E-02 5.076E-02 5.701E-02 6.353E-02 7.030E-02 7.728E-02 8.444E-02 9.174E-02 9.916E-02 1.067E-01 1.142E-01 1.217E-01 1.292E-01 1.366E-01 1.439E-01 1.511E-01 1.580E-01 1.648E-01 1.713E-01 1.775E-01 1.833E-01 1.889E-01 1.940E-01 1.987E-01 2.031E-01 2.069E-01 2.104E-01 2.133E-01 2.158E-01 2.179E-01 2.194E-01 2.204E-01 2.210E-01 2.211E-01 2.208E-01 2.200E-01 2.188E-01 2.171E-01 2.151E-01 2.128E-01 2.100E-01 2.070E-01 2.037E-01 2.001E-01 1.963E-01 1.924E-01 1.882E-01 1.839E-01 1.796E-01 1.751E-01 1.706E-01 1.661E-01 1.616E-01 1.572E-01 1.528E-01 1.485E-01 1.443E-01 1.403E-01 1.364E-01 1.326E-01 1.291E-01 1.257E-01 1.226E-01 1.197E-01 1.170E-01 1.145E-01 1.123E-01 1.104E-01 1.087E-01 1.072E-01 1.060E-01 1.051E-01 1.044E-01 1.040E-01 1.039E-01 1.040E-01 1.044E-01 1.051E-01 1.060E-01 1.072E-01 1.087E-01 1.104E-01 1.123E-01 1.145E-01 1.170E-01 1.197E-01 1.226E-01 1.257E-01 1.291E-01 1.326E-01 1.364E-01 1.403E-01 1.443E-01 1.485E-01 1.528E-01 1.572E-01 1.616E-01 1.661E-01 1.706E-01 1.751E-01 1.796E-01 1.839E-01 1.882E-01 1.924E-01 1.963E-01 2.001E-01 2.037E-01 2.070E-01 2.100E-01 2.128E-01 2.151E-01 2.171E-01 2.188E-01 2.200E-01 2.208E-01 2.211E-01 2.210E-01 2.204E-01 2.194E-01 2.179E-01 2.158E-01 2.133E-01 2.104E-01 2.069E-01 2.031E-01 1.987E-01 1.940E-01 1.889E-01 1.833E-01 1.775E-01 1.713E-01 1.648E-01 1.580E-01 1.511E-01 1.439E-01 1.366E-01 1.292E-01 1.217E-01 1.142E-01 1.067E-01 9.916E-02 9.174E-02 8.444E-02 7.728E-02 7.030E-02 6.353E-02 5.701E-02 5.076E-02 4.480E-02 3.916E-02 3.385E-02 2.891E-02 2.434E-02 2.015E-02 1.635E-02 1.296E-02 9.965E-03 7.376E-03 5.189E-03 3.400E-03 2.000E-03 9.791E-04 3.258E-04 2.515E-05 6.067E-05 4.139E-04 1.065E-03 1.991E-03 3.171E-03 4.580E-03 6.193E-03 7.986E-03 9.931E-03 1.200E-02 1.418E-02 1.643E-02 1.872E-02 2.105E-02 2.337E-02 2.567E-02 2.793E-02 3.012E-02 3.223E-02 3.423E-02 3.612E-02 3.787E-02 3.947E-02 4.091E-02 4.219E-02 4.328E-02 4.420E-02 4.492E-02 4.546E-02 4.581E-02 4.596E-02 4.593E-02 4.571E-02 4.531E-02 4.474E-02 4.401E-02 4.312E-02 4.208E-02 4.045E-02 4.167E-02 4.275E-02 4.370E-02 4.449E-02 4.512E-02 4.558E-02 4.587E-02 4.597E-02 4.589E-02 4.562E-02 4.516E-02 4.451E-02 4.368E-02 4.266E-02 4.146E-02 4.009E-02 3.856E-02 3.687E-02 3.505E-02 3.310E-02 3.105E-02 2.890E-02 2.668E-02 2.440E-02 2.210E-02 1.978E-02 1.748E-02 1.521E-02 1.301E-02 1.090E-02 8.898E-03 7.039E-03 5.344E-03 3.839E-03 2.550E-03 1.499E-03 7.096E-04 2.042E-04 2.840E-06 1.244E-04 5.861E-04 1.403E-03 2.589E-03 4.153E-03 6.106E-03 8.452E-03 1.120E-02 1.434E-02 1.787E-02 2.180E-02 2.611E-02 3.080E-02 3.584E-02 4.123E-02 4.694E-02 5.296E-02 5.925E-02 6.580E-02 7.258E-02 7.955E-02 8.668E-02 9.395E-02 1.013E-01 1.087E-01 1.162E-01 1.236E-01 1.310E-01 1.383E-01 1.455E-01 1.525E-01 1.593E-01 1.659E-01 1.723E-01 1.783E-01 1.841E-01 1.895E-01 1.945E-01 1.991E-01 2.033E-01 2.071E-01 2.104E-01 2.133E-01 2.158E-01 2.178E-01 2.193E-01 2.204E-01 2.210E-01 2.211E-01 2.209E-01 2.202E-01 2.191E-01 2.176E-01 2.158E-01 2.136E-01 2.111E-01 2.083E-01 2.053E-01 2.020E-01 1.985E-01 1.948E-01 1.910E-01 1.871E-01 1.830E-01 1.790E-01 1.748E-01 1.707E-01 1.666E-01 1.625E-01 1.585E-01 1.546E-01 1.508E-01 1.471E-01 1.436E-01 1.403E-01 1.371E-01 1.341E-01 1.313E-01 1.287E-01 1.264E-01 1.242E-01 1.224E-01 1.207E-01 1.193E-01 1.182E-01 1.173E-01 1.166E-01 1.162E-01 1.161E-01 1.162E-01 1.166E-01 1.173E-01 1.182E-01 1.193E-01 1.207E-01 1.224E-01 1.242E-01 1.264E-01 1.287E-01 1.313E-01 1.341E-01 1.371E-01 1.403E-01 1.436E-01 1.471E-01 1.508E-01 1.546E-01 1.585E-01 1.625E-01 1.666E-01 1.707E-01 1.748E-01 1.790E-01 1.830E-01 1.871E-01 1.910E-01 1.948E-01 1.985E-01 2.020E-01 2.053E-01 2.083E-01 2.111E-01 2.136E-01 2.158E-01 2.176E-01 2.191E-01 2.202E-01 2.209E-01 2.211E-01 2.210E-01 2.204E-01 2.193E-01 2.178E-01 2.158E-01 2.133E-01 2.104E-01 2.071E-01 2.033E-01 1.991E-01 1.945E-01 1.895E-01 1.841E-01 1.783E-01 1.723E-01 1.659E-01 1.593E-01 1.525E-01 1.455E-01 1.383E-01 1.310E-01 1.236E-01 1.162E-01 1.087E-01 1.013E-01 9.395E-02 8.668E-02 7.955E-02 7.258E-02 6.580E-02 5.925E-02 5.296E-02 4.694E-02 4.123E-02 3.584E-02 3.080E-02 2.611E-02 2.180E-02 1.787E-02 1.434E-02 1.120E-02 8.452E-03 6.106E-03 4.153E-03 2.589E-03 1.403E-03 5.861E-04 1.244E-04 2.840E-06 2.042E-04 7.096E-04 1.499E-03 2.550E-03 3.839E-03 5.344E-03 7.039E-03 8.898E-03 1.090E-02 1.301E-02 1.521E-02 1.748E-02 1.978E-02 2.210E-02 2.440E-02 2.668E-02 2.890E-02 3.105E-02 3.310E-02 3.505E-02 3.687E-02 3.856E-02 4.009E-02 4.146E-02 4.266E-02 4.368E-02 4.451E-02 4.516E-02 4.562E-02 4.589E-02 4.597E-02 4.587E-02 4.558E-02 4.512E-02 4.449E-02 4.370E-02 4.275E-02 4.167E-02 3.997E-02 4.123E-02 4.236E-02 4.336E-02 4.420E-02 4.490E-02 4.542E-02 4.578E-02 4.595E-02 4.594E-02 4.575E-02 4.537E-02 4.480E-02 4.404E-02 4.310E-02 4.198E-02 4.069E-02 3.923E-02 3.762E-02 3.586E-02 3.397E-02 3.197E-02 2.987E-02 2.769E-02 2.544E-02 2.316E-02 2.085E-02 1.855E-02 1.628E-02 1.405E-02 1.191E-02 9.859E-03 7.937E-03 6.167E-03 4.572E-03 3.178E-03 2.008E-03 1.086E-03 4.335E-04 7.095E-05 1.779E-05 2.917E-04 9.085E-04 1.882E-03 3.224E-03 4.944E-03 7.050E-03 9.544E-03 1.243E-02 1.571E-02 1.937E-02 2.342E-02 2.784E-02 3.262E-02 3.775E-02 4.320E-02 4.897E-02 5.503E-02 6.135E-02 6.791E-02 7.468E-02 8.164E-02 8.874E-02 9.596E-02 1.033E-01 1.106E-01 1.180E-01 1.253E-01 1.326E-01 1.398E-01 1.468E-01 1.537E-01 1.604E-01 1.669E-01 1.731E-01 1.790E-01 1.846E-01 1.899E-01 1.948E-01 1.993E-01 2.034E-01 2.071E-01 2.104E-01 2.132E-01 2.156E-01 2.176E-01 2.191E-01 2.202E-01 2.209E-01 2.211E-01 2.210E-01 2.204E-01 2.195E-01 2.182E-01 2.165E-01 2.145E-01 2.123E-01 2.097E-01 2.070E-01 2.040E-01 2.008E-01 1.974E-01 1.940E-01 1.904E-01 1.867E-01 1.830E-01 1.792E-01 1.755E-01 1.717E-01 1.680E-01 1.644E-01 1.609E-01 1.575E-01 1.542E-01 1.510E-01 1.480E-01 1.452E-01 1.426E-01 1.401E-01 1.379E-01 1.359E-01 1.341E-01 1.325E-01 1.312E-01 1.301E-01 1.292E-01 1.286E-01 1.282E-01 1.281E-01 1.282E-01 1.286E-01 1.292E-01 1.301E-01 1.312E-01 1.325E-01 1.341E-01 1.359E-01 1.379E-01 1.401E-01 1.426E-01 1.452E-01 1.480E-01 1.510E-01 1.542E-01 1.575E-01 1.609E-01 1.644E-01 1.680E-01 1.717E-01 1.755E-01 1.792E-01 1.830E-01 1.867E-01 1.904E-01 1.940E-01 1.974E-01 2.008E-01 2.040E-01 2.070E-01 2.097E-01 2.123E-01 2.145E-01 2.165E-01 2.182E-01 2.195E-01 2.204E-01 2.210E-01 2.211E-01 2.209E-01 2.202E-01 2.191E-01 2.176E-01 2.156E-01 2.132E-01 2.104E-01 2.071E-01 2.034E-01 1.993E-01 1.948E-01 1.899E-01 1.846E-01 1.790E-01 1.731E-01 1.669E-01 1.604E-01 1.537E-01 1.468E-01 1.398E-01 1.326E-01 1.253E-01 1.180E-01 1.106E-01 1.033E-01 9.596E-02 8.874E-02 8.164E-02 7.468E-02 6.791E-02 6.135E-02 5.503E-02 4.897E-02 4.320E-02 3.775E-02 3.262E-02 2.784E-02 2.342E-02 1.937E-02 1.571E-02 1.243E-02 9.544E-03 7.050E-03 4.944E-03 3.224E-03 1.882E-03 9.085E-04 2.917E-04 1.779E-05 7.095E-05 4.335E-04 1.086E-03 2.008E-03 3.178E-03 4.572E-03 6.167E-03 7.937E-03 9.859E-03 1.191E-02 1.405E-02 1.628E-02 1.855E-02 2.085E-02 2.316E-02 2.544E-02 2.769E-02 2.987E-02 3.197E-02 3.397E-02 3.586E-02 3.762E-02 3.923E-02 4.069E-02 4.198E-02 4.310E-02 4.404E-02 4.480E-02 4.537E-02 4.575E-02 4.594E-02 4.595E-02 4.578E-02 4.542E-02 4.490E-02 4.420E-02 4.336E-02 4.236E-02 4.123E-02 3.946E-02 4.076E-02 4.194E-02 4.299E-02 4.389E-02 4.464E-02 4.523E-02 4.566E-02 4.590E-02 4.597E-02 4.585E-02 4.555E-02 4.506E-02 4.438E-02 4.352E-02 4.248E-02 4.127E-02 3.988E-02 3.834E-02 3.666E-02 3.483E-02 3.289E-02 3.084E-02 2.870E-02 2.649E-02 2.424E-02 2.195E-02 1.965E-02 1.737E-02 1.513E-02 1.296E-02 1.087E-02 8.888E-03 7.048E-03 5.369E-03 3.877E-03 2.594E-03 1.544E-03 7.495E-04 2.307E-04 7.597E-06 9.812E-05 5.187E-04 1.284E-03 2.406E-03 3.896E-03 5.762E-03 8.009E-03 1.064E-02 1.366E-02 1.706E-02 2.084E-02 2.499E-02 2.950E-02 3.436E-02 3.956E-02 4.507E-02 5.088E-02 5.697E-02 6.330E-02 6.986E-02 7.661E-02 8.353E-02 9.059E-02 9.775E-02 1.050E-01 1.122E-01 1.195E-01 1.267E-01 1.339E-01 1.410E-01 1.479E-01 1.547E-01 1.612E-01 1.676E-01 1.736E-01 1.794E-01 1.849E-01 1.901E-01 1.948E-01 1.993E-01 2.033E-01 2.069E-01 2.102E-01 2.130E-01 2.154E-01 2.174E-01 2.189E-01 2.201E-01 2.208E-01 2.211E-01 2.211E-01 2.206E-01 2.198E-01 2.187E-01 2.173E-01 2.155E-01 2.135E-01 2.112E-01 2.087E-01 2.060E-01 2.032E-01 2.001E-01 1.970E-01 1.937E-01 1.904E-01 1.871E-01 1.837E-01 1.803E-01 1.770E-01 1.737E-01 1.704E-01 1.673E-01 1.642E-01 1.613E-01 1.585E-01 1.559E-01 1.534E-01 1.511E-01 1.490E-01 1.471E-01 1.455E-01 1.440E-01 1.427E-01 1.417E-01 1.408E-01 1.403E-01 1.399E-01 1.398E-01 1.399E-01 1.403E-01 1.408E-01 1.417E-01 1.427E-01 1.440E-01 1.455E-01 1.471E-01 1.490E-01 1.511E-01 1.534E-01 1.559E-01 1.585E-01 1.613E-01 1.642E-01 1.673E-01 1.704E-01 1.737E-01 1.770E-01 1.803E-01 1.837E-01 1.871E-01 1.904E-01 1.937E-01 1.970E-01 2.001E-01 2.032E-01 2.060E-01 2.087E-01 2.112E-01 2.135E-01 2.155E-01 2.173E-01 2.187E-01 2.198E-01 2.206E-01 2.211E-01 2.211E-01 2.208E-01 2.201E-01 2.189E-01 2.174E-01 2.154E-01 2.130E-01 2.102E-01 2.069E-01 2.033E-01 1.993E-01 1.948E-01 1.901E-01 1.849E-01 1.794E-01 1.736E-01 1.676E-01 1.612E-01 1.547E-01 1.479E-01 1.410E-01 1.339E-01 1.267E-01 1.195E-01 1.122E-01 1.050E-01 9.775E-02 9.059E-02 8.353E-02 7.661E-02 6.986E-02 6.330E-02 5.697E-02 5.088E-02 4.507E-02 3.956E-02 3.436E-02 2.950E-02 2.499E-02 2.084E-02 1.706E-02 1.366E-02 1.064E-02 8.009E-03 5.762E-03 3.896E-03 2.406E-03 1.284E-03 5.187E-04 9.812E-05 7.597E-06 2.307E-04 7.495E-04 1.544E-03 2.594E-03 3.877E-03 5.369E-03 7.048E-03 8.888E-03 1.087E-02 1.296E-02 1.513E-02 1.737E-02 1.965E-02 2.195E-02 2.424E-02 2.649E-02 2.870E-02 3.084E-02 3.289E-02 3.483E-02 3.666E-02 3.834E-02 3.988E-02 4.127E-02 4.248E-02 4.352E-02 4.438E-02 4.506E-02 4.555E-02 4.585E-02 4.597E-02 4.590E-02 4.566E-02 4.523E-02 4.464E-02 4.389E-02 4.299E-02 4.194E-02 4.076E-02 3.893E-02 4.027E-02 4.149E-02 4.259E-02 4.355E-02 4.436E-02 4.501E-02 4.550E-02 4.582E-02 4.596E-02 4.592E-02 4.570E-02 4.529E-02 4.470E-02 4.392E-02 4.296E-02 4.182E-02 4.052E-02 3.905E-02 3.744E-02 3.568E-02 3.380E-02 3.181E-02 2.972E-02 2.755E-02 2.532E-02 2.306E-02 2.078E-02 1.850E-02 1.625E-02 1.404E-02 1.192E-02 9.890E-03 7.986E-03 6.229E-03 4.644E-03 3.254E-03 2.083E-03 1.152E-03 4.831E-04 9.521E-05 7.280E-06 2.362E-04 7.971E-04 1.703E-03 2.966E-03 4.594E-03 6.595E-03 8.973E-03 1.173E-02 1.486E-02 1.837E-02 2.225E-02 2.650E-02 3.109E-02 3.602E-02 4.127E-02 4.682E-02 5.266E-02 5.875E-02 6.509E-02 7.163E-02 7.836E-02 8.524E-02 9.224E-02 9.933E-02 1.065E-01 1.137E-01 1.208E-01 1.279E-01 1.350E-01 1.419E-01 1.487E-01 1.554E-01 1.618E-01 1.680E-01 1.740E-01 1.796E-01 1.850E-01 1.901E-01 1.948E-01 1.991E-01 2.031E-01 2.066E-01 2.098E-01 2.126E-01 2.150E-01 2.170E-01 2.186E-01 2.198E-01 2.206E-01 2.211E-01 2.211E-01 2.208E-01 2.202E-01 2.193E-01 2.181E-01 2.165E-01 2.148E-01 2.128E-01 2.105E-01 2.081E-01 2.056E-01 2.029E-01 2.001E-01 1.972E-01 1.942E-01 1.912E-01 1.882E-01 1.852E-01 1.822E-01 1.793E-01 1.764E-01 1.737E-01 1.710E-01 1.684E-01 1.660E-01 1.637E-01 1.616E-01 1.597E-01 1.579E-01 1.563E-01 1.549E-01 1.538E-01 1.528E-01 1.520E-01 1.515E-01 1.511E-01 1.510E-01 1.511E-01 1.515E-01 1.520E-01 1.528E-01 1.538E-01 1.549E-01 1.563E-01 1.579E-01 1.597E-01 1.616E-01 1.637E-01 1.660E-01 1.684E-01 1.710E-01 1.737E-01 1.764E-01 1.793E-01 1.822E-01 1.852E-01 1.882E-01 1.912E-01 1.942E-01 1.972E-01 2.001E-01 2.029E-01 2.056E-01 2.081E-01 2.105E-01 2.128E-01 2.148E-01 2.165E-01 2.181E-01 2.193E-01 2.202E-01 2.208E-01 2.211E-01 2.211E-01 2.206E-01 2.198E-01 2.186E-01 2.170E-01 2.150E-01 2.126E-01 2.098E-01 2.066E-01 2.031E-01 1.991E-01 1.948E-01 1.901E-01 1.850E-01 1.796E-01 1.740E-01 1.680E-01 1.618E-01 1.554E-01 1.487E-01 1.419E-01 1.350E-01 1.279E-01 1.208E-01 1.137E-01 1.065E-01 9.933E-02 9.224E-02 8.524E-02 7.836E-02 7.163E-02 6.509E-02 5.875E-02 5.266E-02 4.682E-02 4.127E-02 3.602E-02 3.109E-02 2.650E-02 2.225E-02 1.837E-02 1.486E-02 1.173E-02 8.973E-03 6.595E-03 4.594E-03 2.966E-03 1.703E-03 7.971E-04 2.362E-04 7.280E-06 9.521E-05 4.831E-04 1.152E-03 2.083E-03 3.254E-03 4.644E-03 6.229E-03 7.986E-03 9.890E-03 1.192E-02 1.404E-02 1.625E-02 1.850E-02 2.078E-02 2.306E-02 2.532E-02 2.755E-02 2.972E-02 3.181E-02 3.380E-02 3.568E-02 3.744E-02 3.905E-02 4.052E-02 4.182E-02 4.296E-02 4.392E-02 4.470E-02 4.529E-02 4.570E-02 4.592E-02 4.596E-02 4.582E-02 4.550E-02 4.501E-02 4.436E-02 4.355E-02 4.259E-02 4.149E-02 4.027E-02 3.838E-02 3.975E-02 4.102E-02 4.216E-02 4.318E-02 4.405E-02 4.476E-02 4.532E-02 4.571E-02 4.593E-02 4.596E-02 4.582E-02 4.549E-02 4.498E-02 4.429E-02 4.341E-02 4.236E-02 4.113E-02 3.975E-02 3.820E-02 3.652E-02 3.470E-02 3.277E-02 3.073E-02 2.861E-02 2.642E-02 2.418E-02 2.192E-02 1.964E-02 1.739E-02 1.517E-02 1.301E-02 1.094E-02 8.978E-03 7.150E-03 5.479E-03 3.989E-03 2.703E-03 1.642E-03 8.283E-04 2.815E-04 2.057E-05 6.286E-05 4.241E-04 1.118E-03 2.157E-03 3.552E-03 5.308E-03 7.434E-03 9.931E-03 1.280E-02 1.604E-02 1.965E-02 2.361E-02 2.793E-02 3.259E-02 3.757E-02 4.286E-02 4.844E-02 5.429E-02 6.039E-02 6.671E-02 7.323E-02 7.991E-02 8.674E-02 9.367E-02 1.007E-01 1.078E-01 1.148E-01 1.219E-01 1.289E-01 1.358E-01 1.427E-01 1.493E-01 1.559E-01 1.622E-01 1.682E-01 1.741E-01 1.796E-01 1.849E-01 1.899E-01 1.945E-01 1.987E-01 2.027E-01 2.062E-01 2.094E-01 2.121E-01 2.146E-01 2.166E-01 2.182E-01 2.195E-01 2.204E-01 2.209E-01 2.211E-01 2.210E-01 2.206E-01 2.198E-01 2.188E-01 2.175E-01 2.160E-01 2.143E-01 2.124E-01 2.103E-01 2.080E-01 2.056E-01 2.032E-01 2.006E-01 1.980E-01 1.954E-01 1.927E-01 1.901E-01 1.875E-01 1.849E-01 1.824E-01 1.800E-01 1.777E-01 1.755E-01 1.734E-01 1.714E-01 1.697E-01 1.680E-01 1.666E-01 1.653E-01 1.642E-01 1.633E-01 1.626E-01 1.621E-01 1.618E-01 1.617E-01 1.618E-01 1.621E-01 1.626E-01 1.633E-01 1.642E-01 1.653E-01 1.666E-01 1.680E-01 1.697E-01 1.714E-01 1.734E-01 1.755E-01 1.777E-01 1.800E-01 1.824E-01 1.849E-01 1.875E-01 1.901E-01 1.927E-01 1.954E-01 1.980E-01 2.006E-01 2.032E-01 2.056E-01 2.080E-01 2.103E-01 2.124E-01 2.143E-01 2.160E-01 2.175E-01 2.188E-01 2.198E-01 2.206E-01 2.210E-01 2.211E-01 2.209E-01 2.204E-01 2.195E-01 2.182E-01 2.166E-01 2.146E-01 2.121E-01 2.094E-01 2.062E-01 2.027E-01 1.987E-01 1.945E-01 1.899E-01 1.849E-01 1.796E-01 1.741E-01 1.682E-01 1.622E-01 1.559E-01 1.493E-01 1.427E-01 1.358E-01 1.289E-01 1.219E-01 1.148E-01 1.078E-01 1.007E-01 9.367E-02 8.674E-02 7.991E-02 7.323E-02 6.671E-02 6.039E-02 5.429E-02 4.844E-02 4.286E-02 3.757E-02 3.259E-02 2.793E-02 2.361E-02 1.965E-02 1.604E-02 1.280E-02 9.931E-03 7.434E-03 5.308E-03 3.552E-03 2.157E-03 1.118E-03 4.241E-04 6.286E-05 2.057E-05 2.815E-04 8.283E-04 1.642E-03 2.703E-03 3.989E-03 5.479E-03 7.150E-03 8.978E-03 1.094E-02 1.301E-02 1.517E-02 1.739E-02 1.964E-02 2.192E-02 2.418E-02 2.642E-02 2.861E-02 3.073E-02 3.277E-02 3.470E-02 3.652E-02 3.820E-02 3.975E-02 4.113E-02 4.236E-02 4.341E-02 4.429E-02 4.498E-02 4.549E-02 4.582E-02 4.596E-02 4.593E-02 4.571E-02 4.532E-02 4.476E-02 4.405E-02 4.318E-02 4.216E-02 4.102E-02 3.975E-02 3.779E-02 3.921E-02 4.052E-02 4.171E-02 4.277E-02 4.370E-02 4.448E-02 4.510E-02 4.556E-02 4.585E-02 4.597E-02 4.591E-02 4.566E-02 4.523E-02 4.462E-02 4.383E-02 4.286E-02 4.172E-02 4.041E-02 3.895E-02 3.734E-02 3.559E-02 3.372E-02 3.174E-02 2.967E-02 2.752E-02 2.531E-02 2.307E-02 2.081E-02 1.855E-02 1.632E-02 1.414E-02 1.204E-02 1.002E-02 8.131E-03 6.381E-03 4.797E-03 3.402E-03 2.218E-03 1.266E-03 5.669E-04 1.389E-04 2.162E-07 1.670E-04 6.540E-04 1.474E-03 2.637E-03 4.153E-03 6.028E-03 8.267E-03 1.087E-02 1.384E-02 1.717E-02 2.086E-02 2.490E-02 2.928E-02 3.399E-02 3.901E-02 4.433E-02 4.992E-02 5.577E-02 6.186E-02 6.815E-02 7.463E-02 8.127E-02 8.803E-02 9.490E-02 1.018E-01 1.088E-01 1.158E-01 1.227E-01 1.296E-01 1.364E-01 1.431E-01 1.497E-01 1.561E-01 1.623E-01 1.682E-01 1.740E-01 1.794E-01 1.846E-01 1.895E-01 1.940E-01 1.982E-01 2.021E-01 2.056E-01 2.087E-01 2.115E-01 2.139E-01 2.160E-01 2.177E-01 2.191E-01 2.201E-01 2.207E-01 2.211E-01 2.211E-01 2.209E-01 2.203E-01 2.195E-01 2.185E-01 2.172E-01 2.158E-01 2.141E-01 2.123E-01 2.104E-01 2.083E-01 2.062E-01 2.040E-01 2.017E-01 1.994E-01 1.971E-01 1.948E-01 1.926E-01 1.904E-01 1.882E-01 1.861E-01 1.842E-01 1.823E-01 1.806E-01 1.790E-01 1.775E-01 1.762E-01 1.750E-01 1.740E-01 1.732E-01 1.726E-01 1.721E-01 1.718E-01 1.717E-01 1.718E-01 1.721E-01 1.726E-01 1.732E-01 1.740E-01 1.750E-01 1.762E-01 1.775E-01 1.790E-01 1.806E-01 1.823E-01 1.842E-01 1.861E-01 1.882E-01 1.904E-01 1.926E-01 1.948E-01 1.971E-01 1.994E-01 2.017E-01 2.040E-01 2.062E-01 2.083E-01 2.104E-01 2.123E-01 2.141E-01 2.158E-01 2.172E-01 2.185E-01 2.195E-01 2.203E-01 2.209E-01 2.211E-01 2.211E-01 2.207E-01 2.201E-01 2.191E-01 2.177E-01 2.160E-01 2.139E-01 2.115E-01 2.087E-01 2.056E-01 2.021E-01 1.982E-01 1.940E-01 1.895E-01 1.846E-01 1.794E-01 1.740E-01 1.682E-01 1.623E-01 1.561E-01 1.497E-01 1.431E-01 1.364E-01 1.296E-01 1.227E-01 1.158E-01 1.088E-01 1.018E-01 9.490E-02 8.803E-02 8.127E-02 7.463E-02 6.815E-02 6.186E-02 5.577E-02 4.992E-02 4.433E-02 3.901E-02 3.399E-02 2.928E-02 2.490E-02 2.086E-02 1.717E-02 1.384E-02 1.087E-02 8.267E-03 6.028E-03 4.153E-03 2.637E-03 1.474E-03 6.540E-04 1.670E-04 2.162E-07 1.389E-04 5.669E-04 1.266E-03 2.218E-03 3.402E-03 4.797E-03 6.381E-03 8.131E-03 1.002E-02 1.204E-02 1.414E-02 1.632E-02 1.855E-02 2.081E-02 2.307E-02 2.531E-02 2.752E-02 2.967E-02 3.174E-02 3.372E-02 3.559E-02 3.734E-02 3.895E-02 4.041E-02 4.172E-02 4.286E-02 4.383E-02 4.462E-02 4.523E-02 4.566E-02 4.591E-02 4.597E-02 4.585E-02 4.556E-02 4.510E-02 4.448E-02 4.370E-02 4.277E-02 4.171E-02 4.052E-02 3.921E-02 3.719E-02 3.864E-02 3.999E-02 4.122E-02 4.234E-02 4.332E-02 4.416E-02 4.485E-02 4.538E-02 4.575E-02 4.594E-02 4.596E-02 4.579E-02 4.545E-02 4.492E-02 4.422E-02 4.334E-02 4.228E-02 4.106E-02 3.967E-02 3.814E-02 3.646E-02 3.466E-02 3.274E-02 3.072E-02 2.862E-02 2.645E-02 2.424E-02 2.199E-02 1.974E-02 1.751E-02 1.531E-02 1.317E-02 1.112E-02 9.169E-03 7.347E-03 5.677E-03 4.180E-03 2.880E-03 1.797E-03 9.513E-04 3.627E-04 4.919E-05 2.738E-05 3.124E-04 9.178E-04 1.855E-03 3.134E-03 4.762E-03 6.745E-03 9.086E-03 1.179E-02 1.484E-02 1.825E-02 2.201E-02 2.611E-02 3.054E-02 3.529E-02 4.033E-02 4.566E-02 5.126E-02 5.710E-02 6.316E-02 6.942E-02 7.585E-02 8.243E-02 8.912E-02 9.590E-02 1.027E-01 1.096E-01 1.165E-01 1.233E-01 1.301E-01 1.368E-01 1.434E-01 1.498E-01 1.561E-01 1.622E-01 1.680E-01 1.736E-01 1.790E-01 1.841E-01 1.889E-01 1.933E-01 1.975E-01 2.013E-01 2.048E-01 2.079E-01 2.107E-01 2.132E-01 2.153E-01 2.171E-01 2.185E-01 2.196E-01 2.204E-01 2.209E-01 2.211E-01 2.211E-01 2.207E-01 2.202E-01 2.194E-01 2.183E-01 2.171E-01 2.158E-01 2.143E-01 2.126E-01 2.109E-01 2.091E-01 2.072E-01 2.053E-01 2.033E-01 2.014E-01 1.994E-01 1.975E-01 1.956E-01 1.938E-01 1.921E-01 1.904E-01 1.889E-01 1.875E-01 1.861E-01 1.850E-01 1.839E-01 1.830E-01 1.823E-01 1.817E-01 1.813E-01 1.811E-01 1.810E-01 1.811E-01 1.813E-01 1.817E-01 1.823E-01 1.830E-01 1.839E-01 1.850E-01 1.861E-01 1.875E-01 1.889E-01 1.904E-01 1.921E-01 1.938E-01 1.956E-01 1.975E-01 1.994E-01 2.014E-01 2.033E-01 2.053E-01 2.072E-01 2.091E-01 2.109E-01 2.126E-01 2.143E-01 2.158E-01 2.171E-01 2.183E-01 2.194E-01 2.202E-01 2.207E-01 2.211E-01 2.211E-01 2.209E-01 2.204E-01 2.196E-01 2.185E-01 2.171E-01 2.153E-01 2.132E-01 2.107E-01 2.079E-01 2.048E-01 2.013E-01 1.975E-01 1.933E-01 1.889E-01 1.841E-01 1.790E-01 1.736E-01 1.680E-01 1.622E-01 1.561E-01 1.498E-01 1.434E-01 1.368E-01 1.301E-01 1.233E-01 1.165E-01 1.096E-01 1.027E-01 9.590E-02 8.912E-02 8.243E-02 7.585E-02 6.942E-02 6.316E-02 5.710E-02 5.126E-02 4.566E-02 4.033E-02 3.529E-02 3.054E-02 2.611E-02 2.201E-02 1.825E-02 1.484E-02 1.179E-02 9.086E-03 6.745E-03 4.762E-03 3.134E-03 1.855E-03 9.178E-04 3.124E-04 2.738E-05 4.919E-05 3.627E-04 9.513E-04 1.797E-03 2.880E-03 4.180E-03 5.677E-03 7.347E-03 9.169E-03 1.112E-02 1.317E-02 1.531E-02 1.751E-02 1.974E-02 2.199E-02 2.424E-02 2.645E-02 2.862E-02 3.072E-02 3.274E-02 3.466E-02 3.646E-02 3.814E-02 3.967E-02 4.106E-02 4.228E-02 4.334E-02 4.422E-02 4.492E-02 4.545E-02 4.579E-02 4.596E-02 4.594E-02 4.575E-02 4.538E-02 4.485E-02 4.416E-02 4.332E-02 4.234E-02 4.122E-02 3.999E-02 3.864E-02 3.656E-02 3.804E-02 3.943E-02 4.071E-02 4.187E-02 4.291E-02 4.381E-02 4.457E-02 4.517E-02 4.561E-02 4.587E-02 4.597E-02 4.589E-02 4.563E-02 4.519E-02 4.458E-02 4.378E-02 4.281E-02 4.167E-02 4.037E-02 3.891E-02 3.731E-02 3.558E-02 3.373E-02 3.177E-02 2.972E-02 2.759E-02 2.541E-02 2.319E-02 2.096E-02 1.872E-02 1.652E-02 1.435E-02 1.226E-02 1.026E-02 8.375E-03 6.625E-03 5.035E-03 3.625E-03 2.418E-03 1.434E-03 6.919E-04 2.102E-04 6.105E-06 9.524E-05 4.916E-04 1.208E-03 2.254E-03 3.639E-03 5.369E-03 7.448E-03 9.880E-03 1.266E-02 1.580E-02 1.927E-02 2.309E-02 2.724E-02 3.170E-02 3.647E-02 4.153E-02 4.686E-02 5.244E-02 5.826E-02 6.429E-02 7.050E-02 7.687E-02 8.338E-02 8.999E-02 9.668E-02 1.034E-01 1.102E-01 1.170E-01 1.237E-01 1.304E-01 1.369E-01 1.434E-01 1.497E-01 1.559E-01 1.618E-01 1.676E-01 1.731E-01 1.783E-01 1.833E-01 1.880E-01 1.925E-01 1.966E-01 2.004E-01 2.038E-01 2.070E-01 2.098E-01 2.123E-01 2.145E-01 2.163E-01 2.179E-01 2.191E-01 2.200E-01 2.207E-01 2.210E-01 2.211E-01 2.210E-01 2.207E-01 2.201E-01 2.193E-01 2.184E-01 2.173E-01 2.161E-01 2.148E-01 2.133E-01 2.118E-01 2.103E-01 2.086E-01 2.070E-01 2.054E-01 2.038E-01 2.022E-01 2.006E-01 1.991E-01 1.977E-01 1.963E-01 1.951E-01 1.940E-01 1.929E-01 1.920E-01 1.912E-01 1.906E-01 1.901E-01 1.897E-01 1.895E-01 1.894E-01 1.895E-01 1.897E-01 1.901E-01 1.906E-01 1.912E-01 1.920E-01 1.929E-01 1.940E-01 1.951E-01 1.963E-01 1.977E-01 1.991E-01 2.006E-01 2.022E-01 2.038E-01 2.054E-01 2.070E-01 2.086E-01 2.103E-01 2.118E-01 2.133E-01 2.148E-01 2.161E-01 2.173E-01 2.184E-01 2.193E-01 2.201E-01 2.207E-01 2.210E-01 2.211E-01 2.210E-01 2.207E-01 2.200E-01 2.191E-01 2.179E-01 2.163E-01 2.145E-01 2.123E-01 2.098E-01 2.070E-01 2.038E-01 2.004E-01 1.966E-01 1.925E-01 1.880E-01 1.833E-01 1.783E-01 1.731E-01 1.676E-01 1.618E-01 1.559E-01 1.497E-01 1.434E-01 1.369E-01 1.304E-01 1.237E-01 1.170E-01 1.102E-01 1.034E-01 9.668E-02 8.999E-02 8.338E-02 7.687E-02 7.050E-02 6.429E-02 5.826E-02 5.244E-02 4.686E-02 4.153E-02 3.647E-02 3.170E-02 2.724E-02 2.309E-02 1.927E-02 1.580E-02 1.266E-02 9.880E-03 7.448E-03 5.369E-03 3.639E-03 2.254E-03 1.208E-03 4.916E-04 9.524E-05 6.105E-06 2.102E-04 6.919E-04 1.434E-03 2.418E-03 3.625E-03 5.035E-03 6.625E-03 8.375E-03 1.026E-02 1.226E-02 1.435E-02 1.652E-02 1.872E-02 2.096E-02 2.319E-02 2.541E-02 2.759E-02 2.972E-02 3.177E-02 3.373E-02 3.558E-02 3.731E-02 3.891E-02 4.037E-02 4.167E-02 4.281E-02 4.378E-02 4.458E-02 4.519E-02 4.563E-02 4.589E-02 4.597E-02 4.587E-02 4.561E-02 4.517E-02 4.457E-02 4.381E-02 4.291E-02 4.187E-02 4.071E-02 3.943E-02 3.804E-02 3.590E-02 3.741E-02 3.884E-02 4.016E-02 4.138E-02 4.247E-02 4.343E-02 4.425E-02 4.492E-02 4.543E-02 4.577E-02 4.595E-02 4.595E-02 4.578E-02 4.543E-02 4.489E-02 4.419E-02 4.331E-02 4.225E-02 4.104E-02 3.967E-02 3.814E-02 3.649E-02 3.470E-02 3.280E-02 3.081E-02 2.873E-02 2.659E-02 2.440E-02 2.218E-02 1.996E-02 1.775E-02 1.557E-02 1.345E-02 1.140E-02 9.461E-03 7.640E-03 5.964E-03 4.453E-03 3.130E-03 2.014E-03 1.126E-03 4.831E-04 1.036E-04 3.357E-06 1.969E-04 6.974E-04 1.516E-03 2.662E-03 4.143E-03 5.964E-03 8.130E-03 1.064E-02 1.350E-02 1.669E-02 2.022E-02 2.408E-02 2.826E-02 3.275E-02 3.753E-02 4.259E-02 4.791E-02 5.347E-02 5.925E-02 6.523E-02 7.139E-02 7.769E-02 8.412E-02 9.065E-02 9.724E-02 1.039E-01 1.105E-01 1.172E-01 1.238E-01 1.304E-01 1.368E-01 1.431E-01 1.493E-01 1.554E-01 1.612E-01 1.669E-01 1.723E-01 1.775E-01 1.824E-01 1.870E-01 1.914E-01 1.955E-01 1.992E-01 2.027E-01 2.058E-01 2.087E-01 2.112E-01 2.135E-01 2.154E-01 2.170E-01 2.184E-01 2.194E-01 2.202E-01 2.208E-01 2.211E-01 2.211E-01 2.210E-01 2.207E-01 2.202E-01 2.195E-01 2.187E-01 2.177E-01 2.167E-01 2.155E-01 2.143E-01 2.130E-01 2.117E-01 2.104E-01 2.091E-01 2.078E-01 2.065E-01 2.052E-01 2.040E-01 2.029E-01 2.018E-01 2.008E-01 2.000E-01 1.992E-01 1.985E-01 1.979E-01 1.975E-01 1.972E-01 1.970E-01 1.969E-01 1.970E-01 1.972E-01 1.975E-01 1.979E-01 1.985E-01 1.992E-01 2.000E-01 2.008E-01 2.018E-01 2.029E-01 2.040E-01 2.052E-01 2.065E-01 2.078E-01 2.091E-01 2.104E-01 2.117E-01 2.130E-01 2.143E-01 2.155E-01 2.167E-01 2.177E-01 2.187E-01 2.195E-01 2.202E-01 2.207E-01 2.210E-01 2.211E-01 2.211E-01 2.208E-01 2.202E-01 2.194E-01 2.184E-01 2.170E-01 2.154E-01 2.135E-01 2.112E-01 2.087E-01 2.058E-01 2.027E-01 1.992E-01 1.955E-01 1.914E-01 1.870E-01 1.824E-01 1.775E-01 1.723E-01 1.669E-01 1.612E-01 1.554E-01 1.493E-01 1.431E-01 1.368E-01 1.304E-01 1.238E-01 1.172E-01 1.105E-01 1.039E-01 9.724E-02 9.065E-02 8.412E-02 7.769E-02 7.139E-02 6.523E-02 5.925E-02 5.347E-02 4.791E-02 4.259E-02 3.753E-02 3.275E-02 2.826E-02 2.408E-02 2.022E-02 1.669E-02 1.350E-02 1.064E-02 8.130E-03 5.964E-03 4.143E-03 2.662E-03 1.516E-03 6.974E-04 1.969E-04 3.357E-06 1.036E-04 4.831E-04 1.126E-03 2.014E-03 3.130E-03 4.453E-03 5.964E-03 7.640E-03 9.461E-03 1.140E-02 1.345E-02 1.557E-02 1.775E-02 1.996E-02 2.218E-02 2.440E-02 2.659E-02 2.873E-02 3.081E-02 3.280E-02 3.470E-02 3.649E-02 3.814E-02 3.967E-02 4.104E-02 4.225E-02 4.331E-02 4.419E-02 4.489E-02 4.543E-02 4.578E-02 4.595E-02 4.595E-02 4.577E-02 4.543E-02 4.492E-02 4.425E-02 4.343E-02 4.247E-02 4.138E-02 4.016E-02 3.884E-02 3.741E-02 3.522E-02 3.676E-02 3.822E-02 3.959E-02 4.085E-02 4.199E-02 4.301E-02 4.389E-02 4.463E-02 4.521E-02 4.563E-02 4.589E-02 4.597E-02 4.588E-02 4.562E-02 4.518E-02 4.456E-02 4.377E-02 4.280E-02 4.168E-02 4.039E-02 3.895E-02 3.737E-02 3.566E-02 3.383E-02 3.189E-02 2.987E-02 2.777E-02 2.562E-02 2.343E-02 2.122E-02 1.901E-02 1.682E-02 1.468E-02 1.260E-02 1.060E-02 8.719E-03 6.964E-03 5.361E-03 3.929E-03 2.690E-03 1.663E-03 8.671E-04 3.197E-04 3.715E-05 3.466E-05 3.258E-04 9.224E-04 1.835E-03 3.071E-03 4.639E-03 6.541E-03 8.782E-03 1.136E-02 1.427E-02 1.752E-02 2.110E-02 2.499E-02 2.919E-02 3.369E-02 3.847E-02 4.351E-02 4.881E-02 5.433E-02 6.007E-02 6.599E-02 7.208E-02 7.831E-02 8.465E-02 9.108E-02 9.758E-02 1.041E-01 1.107E-01 1.172E-01 1.237E-01 1.301E-01 1.364E-01 1.427E-01 1.487E-01 1.547E-01 1.604E-01 1.659E-01 1.713E-01 1.764E-01 1.812E-01 1.858E-01 1.901E-01 1.941E-01 1.979E-01 2.014E-01 2.045E-01 2.074E-01 2.100E-01 2.123E-01 2.143E-01 2.160E-01 2.175E-01 2.187E-01 2.196E-01 2.203E-01 2.208E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.203E-01 2.198E-01 2.191E-01 2.183E-01 2.174E-01 2.165E-01 2.155E-01 2.145E-01 2.135E-01 2.124E-01 2.114E-01 2.104E-01 2.094E-01 2.085E-01 2.076E-01 2.068E-01 2.060E-01 2.054E-01 2.048E-01 2.043E-01 2.040E-01 2.037E-01 2.035E-01 2.035E-01 2.035E-01 2.037E-01 2.040E-01 2.043E-01 2.048E-01 2.054E-01 2.060E-01 2.068E-01 2.076E-01 2.085E-01 2.094E-01 2.104E-01 2.114E-01 2.124E-01 2.135E-01 2.145E-01 2.155E-01 2.165E-01 2.174E-01 2.183E-01 2.191E-01 2.198E-01 2.203E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.208E-01 2.203E-01 2.196E-01 2.187E-01 2.175E-01 2.160E-01 2.143E-01 2.123E-01 2.100E-01 2.074E-01 2.045E-01 2.014E-01 1.979E-01 1.941E-01 1.901E-01 1.858E-01 1.812E-01 1.764E-01 1.713E-01 1.659E-01 1.604E-01 1.547E-01 1.487E-01 1.427E-01 1.364E-01 1.301E-01 1.237E-01 1.172E-01 1.107E-01 1.041E-01 9.758E-02 9.108E-02 8.465E-02 7.831E-02 7.208E-02 6.599E-02 6.007E-02 5.433E-02 4.881E-02 4.351E-02 3.847E-02 3.369E-02 2.919E-02 2.499E-02 2.110E-02 1.752E-02 1.427E-02 1.136E-02 8.782E-03 6.541E-03 4.639E-03 3.071E-03 1.835E-03 9.224E-04 3.258E-04 3.466E-05 3.715E-05 3.197E-04 8.671E-04 1.663E-03 2.690E-03 3.929E-03 5.361E-03 6.964E-03 8.719E-03 1.060E-02 1.260E-02 1.468E-02 1.682E-02 1.901E-02 2.122E-02 2.343E-02 2.562E-02 2.777E-02 2.987E-02 3.189E-02 3.383E-02 3.566E-02 3.737E-02 3.895E-02 4.039E-02 4.168E-02 4.280E-02 4.377E-02 4.456E-02 4.518E-02 4.562E-02 4.588E-02 4.597E-02 4.589E-02 4.563E-02 4.521E-02 4.463E-02 4.389E-02 4.301E-02 4.199E-02 4.085E-02 3.959E-02 3.822E-02 3.676E-02 3.452E-02 3.609E-02 3.758E-02 3.899E-02 4.029E-02 4.148E-02 4.256E-02 4.350E-02 4.430E-02 4.495E-02 4.545E-02 4.578E-02 4.595E-02 4.595E-02 4.577E-02 4.542E-02 4.489E-02 4.419E-02 4.332E-02 4.228E-02 4.108E-02 3.973E-02 3.823E-02 3.659E-02 3.483E-02 3.296E-02 3.100E-02 2.895E-02 2.684E-02 2.468E-02 2.249E-02 2.029E-02 1.810E-02 1.594E-02 1.383E-02 1.180E-02 9.859E-03 8.034E-03 6.345E-03 4.814E-03 3.459E-03 2.302E-03 1.361E-03 6.535E-04 1.963E-04 5.093E-06 9.381E-05 4.751E-04 1.160E-03 2.157E-03 3.475E-03 5.119E-03 7.092E-03 9.396E-03 1.203E-02 1.499E-02 1.828E-02 2.188E-02 2.579E-02 3.000E-02 3.450E-02 3.927E-02 4.429E-02 4.955E-02 5.503E-02 6.071E-02 6.657E-02 7.258E-02 7.872E-02 8.497E-02 9.130E-02 9.769E-02 1.041E-01 1.105E-01 1.170E-01 1.233E-01 1.296E-01 1.358E-01 1.419E-01 1.479E-01 1.537E-01 1.593E-01 1.648E-01 1.700E-01 1.750E-01 1.798E-01 1.843E-01 1.886E-01 1.926E-01 1.963E-01 1.998E-01 2.030E-01 2.059E-01 2.085E-01 2.109E-01 2.130E-01 2.148E-01 2.164E-01 2.177E-01 2.188E-01 2.197E-01 2.203E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.209E-01 2.206E-01 2.201E-01 2.196E-01 2.190E-01 2.183E-01 2.176E-01 2.169E-01 2.161E-01 2.153E-01 2.145E-01 2.138E-01 2.130E-01 2.124E-01 2.117E-01 2.111E-01 2.106E-01 2.101E-01 2.097E-01 2.094E-01 2.092E-01 2.091E-01 2.090E-01 2.091E-01 2.092E-01 2.094E-01 2.097E-01 2.101E-01 2.106E-01 2.111E-01 2.117E-01 2.124E-01 2.130E-01 2.138E-01 2.145E-01 2.153E-01 2.161E-01 2.169E-01 2.176E-01 2.183E-01 2.190E-01 2.196E-01 2.201E-01 2.206E-01 2.209E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.203E-01 2.197E-01 2.188E-01 2.177E-01 2.164E-01 2.148E-01 2.130E-01 2.109E-01 2.085E-01 2.059E-01 2.030E-01 1.998E-01 1.963E-01 1.926E-01 1.886E-01 1.843E-01 1.798E-01 1.750E-01 1.700E-01 1.648E-01 1.593E-01 1.537E-01 1.479E-01 1.419E-01 1.358E-01 1.296E-01 1.233E-01 1.170E-01 1.105E-01 1.041E-01 9.769E-02 9.130E-02 8.497E-02 7.872E-02 7.258E-02 6.657E-02 6.071E-02 5.503E-02 4.955E-02 4.429E-02 3.927E-02 3.450E-02 3.000E-02 2.579E-02 2.188E-02 1.828E-02 1.499E-02 1.203E-02 9.396E-03 7.092E-03 5.119E-03 3.475E-03 2.157E-03 1.160E-03 4.751E-04 9.381E-05 5.093E-06 1.963E-04 6.535E-04 1.361E-03 2.302E-03 3.459E-03 4.814E-03 6.345E-03 8.034E-03 9.859E-03 1.180E-02 1.383E-02 1.594E-02 1.810E-02 2.029E-02 2.249E-02 2.468E-02 2.684E-02 2.895E-02 3.100E-02 3.296E-02 3.483E-02 3.659E-02 3.823E-02 3.973E-02 4.108E-02 4.228E-02 4.332E-02 4.419E-02 4.489E-02 4.542E-02 4.577E-02 4.595E-02 4.595E-02 4.578E-02 4.545E-02 4.495E-02 4.430E-02 4.350E-02 4.256E-02 4.148E-02 4.029E-02 3.899E-02 3.758E-02 3.609E-02 3.379E-02 3.539E-02 3.691E-02 3.835E-02 3.970E-02 4.094E-02 4.207E-02 4.307E-02 4.393E-02 4.466E-02 4.523E-02 4.564E-02 4.589E-02 4.597E-02 4.588E-02 4.562E-02 4.518E-02 4.458E-02 4.379E-02 4.285E-02 4.174E-02 4.047E-02 3.905E-02 3.750E-02 3.582E-02 3.402E-02 3.211E-02 3.012E-02 2.806E-02 2.593E-02 2.377E-02 2.159E-02 1.940E-02 1.724E-02 1.511E-02 1.304E-02 1.106E-02 9.169E-03 7.403E-03 5.780E-03 4.320E-03 3.041E-03 1.963E-03 1.104E-03 4.801E-04 1.079E-04 1.764E-06 1.748E-04 6.386E-04 1.403E-03 2.477E-03 3.866E-03 5.576E-03 7.608E-03 9.965E-03 1.264E-02 1.564E-02 1.896E-02 2.258E-02 2.650E-02 3.070E-02 3.518E-02 3.993E-02 4.491E-02 5.013E-02 5.555E-02 6.117E-02 6.695E-02 7.288E-02 7.893E-02 8.508E-02 9.130E-02 9.758E-02 1.039E-01 1.102E-01 1.165E-01 1.227E-01 1.289E-01 1.350E-01 1.410E-01 1.468E-01 1.525E-01 1.580E-01 1.634E-01 1.685E-01 1.735E-01 1.782E-01 1.826E-01 1.869E-01 1.908E-01 1.946E-01 1.980E-01 2.012E-01 2.042E-01 2.068E-01 2.093E-01 2.114E-01 2.133E-01 2.150E-01 2.165E-01 2.177E-01 2.187E-01 2.196E-01 2.202E-01 2.207E-01 2.210E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.206E-01 2.202E-01 2.198E-01 2.193E-01 2.188E-01 2.182E-01 2.177E-01 2.171E-01 2.166E-01 2.161E-01 2.156E-01 2.152E-01 2.148E-01 2.144E-01 2.141E-01 2.139E-01 2.137E-01 2.136E-01 2.136E-01 2.136E-01 2.137E-01 2.139E-01 2.141E-01 2.144E-01 2.148E-01 2.152E-01 2.156E-01 2.161E-01 2.166E-01 2.171E-01 2.177E-01 2.182E-01 2.188E-01 2.193E-01 2.198E-01 2.202E-01 2.206E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.210E-01 2.207E-01 2.202E-01 2.196E-01 2.187E-01 2.177E-01 2.165E-01 2.150E-01 2.133E-01 2.114E-01 2.093E-01 2.068E-01 2.042E-01 2.012E-01 1.980E-01 1.946E-01 1.908E-01 1.869E-01 1.826E-01 1.782E-01 1.735E-01 1.685E-01 1.634E-01 1.580E-01 1.525E-01 1.468E-01 1.410E-01 1.350E-01 1.289E-01 1.227E-01 1.165E-01 1.102E-01 1.039E-01 9.758E-02 9.130E-02 8.508E-02 7.893E-02 7.288E-02 6.695E-02 6.117E-02 5.555E-02 5.013E-02 4.491E-02 3.993E-02 3.518E-02 3.070E-02 2.650E-02 2.258E-02 1.896E-02 1.564E-02 1.264E-02 9.965E-03 7.608E-03 5.576E-03 3.866E-03 2.477E-03 1.403E-03 6.386E-04 1.748E-04 1.764E-06 1.079E-04 4.801E-04 1.104E-03 1.963E-03 3.041E-03 4.320E-03 5.780E-03 7.403E-03 9.169E-03 1.106E-02 1.304E-02 1.511E-02 1.724E-02 1.940E-02 2.159E-02 2.377E-02 2.593E-02 2.806E-02 3.012E-02 3.211E-02 3.402E-02 3.582E-02 3.750E-02 3.905E-02 4.047E-02 4.174E-02 4.285E-02 4.379E-02 4.458E-02 4.518E-02 4.562E-02 4.588E-02 4.597E-02 4.589E-02 4.564E-02 4.523E-02 4.466E-02 4.393E-02 4.307E-02 4.207E-02 4.094E-02 3.970E-02 3.835E-02 3.691E-02 3.539E-02 3.304E-02 3.466E-02 3.622E-02 3.769E-02 3.908E-02 4.037E-02 4.154E-02 4.260E-02 4.353E-02 4.432E-02 4.496E-02 4.545E-02 4.578E-02 4.595E-02 4.595E-02 4.578E-02 4.543E-02 4.492E-02 4.423E-02 4.337E-02 4.236E-02 4.118E-02 3.985E-02 3.838E-02 3.678E-02 3.505E-02 3.321E-02 3.128E-02 2.927E-02 2.719E-02 2.506E-02 2.290E-02 2.073E-02 1.856E-02 1.643E-02 1.433E-02 1.230E-02 1.036E-02 8.532E-03 6.826E-03 5.268E-03 3.877E-03 2.671E-03 1.668E-03 8.868E-04 3.421E-04 4.919E-05 2.164E-05 2.717E-04 8.101E-04 1.646E-03 2.786E-03 4.237E-03 6.003E-03 8.084E-03 1.048E-02 1.319E-02 1.622E-02 1.955E-02 2.317E-02 2.709E-02 3.128E-02 3.574E-02 4.044E-02 4.539E-02 5.055E-02 5.591E-02 6.144E-02 6.714E-02 7.298E-02 7.893E-02 8.497E-02 9.108E-02 9.724E-02 1.034E-01 1.096E-01 1.158E-01 1.219E-01 1.279E-01 1.339E-01 1.398E-01 1.455E-01 1.511E-01 1.565E-01 1.618E-01 1.668E-01 1.717E-01 1.763E-01 1.807E-01 1.849E-01 1.889E-01 1.926E-01 1.960E-01 1.992E-01 2.022E-01 2.049E-01 2.074E-01 2.096E-01 2.116E-01 2.134E-01 2.150E-01 2.164E-01 2.175E-01 2.185E-01 2.193E-01 2.200E-01 2.204E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.209E-01 2.207E-01 2.205E-01 2.202E-01 2.198E-01 2.195E-01 2.192E-01 2.188E-01 2.185E-01 2.182E-01 2.179E-01 2.176E-01 2.174E-01 2.173E-01 2.171E-01 2.171E-01 2.171E-01 2.171E-01 2.171E-01 2.173E-01 2.174E-01 2.176E-01 2.179E-01 2.182E-01 2.185E-01 2.188E-01 2.192E-01 2.195E-01 2.198E-01 2.202E-01 2.205E-01 2.207E-01 2.209E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.204E-01 2.200E-01 2.193E-01 2.185E-01 2.175E-01 2.164E-01 2.150E-01 2.134E-01 2.116E-01 2.096E-01 2.074E-01 2.049E-01 2.022E-01 1.992E-01 1.960E-01 1.926E-01 1.889E-01 1.849E-01 1.807E-01 1.763E-01 1.717E-01 1.668E-01 1.618E-01 1.565E-01 1.511E-01 1.455E-01 1.398E-01 1.339E-01 1.279E-01 1.219E-01 1.158E-01 1.096E-01 1.034E-01 9.724E-02 9.108E-02 8.497E-02 7.893E-02 7.298E-02 6.714E-02 6.144E-02 5.591E-02 5.055E-02 4.539E-02 4.044E-02 3.574E-02 3.128E-02 2.709E-02 2.317E-02 1.955E-02 1.622E-02 1.319E-02 1.048E-02 8.084E-03 6.003E-03 4.237E-03 2.786E-03 1.646E-03 8.101E-04 2.717E-04 2.164E-05 4.919E-05 3.421E-04 8.868E-04 1.668E-03 2.671E-03 3.877E-03 5.268E-03 6.826E-03 8.532E-03 1.036E-02 1.230E-02 1.433E-02 1.643E-02 1.856E-02 2.073E-02 2.290E-02 2.506E-02 2.719E-02 2.927E-02 3.128E-02 3.321E-02 3.505E-02 3.678E-02 3.838E-02 3.985E-02 4.118E-02 4.236E-02 4.337E-02 4.423E-02 4.492E-02 4.543E-02 4.578E-02 4.595E-02 4.595E-02 4.578E-02 4.545E-02 4.496E-02 4.432E-02 4.353E-02 4.260E-02 4.154E-02 4.037E-02 3.908E-02 3.769E-02 3.622E-02 3.466E-02 3.227E-02 3.391E-02 3.549E-02 3.700E-02 3.843E-02 3.976E-02 4.099E-02 4.210E-02 4.309E-02 4.394E-02 4.466E-02 4.523E-02 4.564E-02 4.589E-02 4.597E-02 4.589E-02 4.564E-02 4.521E-02 4.462E-02 4.386E-02 4.294E-02 4.185E-02 4.061E-02 3.923E-02 3.771E-02 3.606E-02 3.429E-02 3.243E-02 3.047E-02 2.844E-02 2.635E-02 2.423E-02 2.207E-02 1.991E-02 1.777E-02 1.566E-02 1.360E-02 1.162E-02 9.726E-03 7.947E-03 6.300E-03 4.805E-03 3.481E-03 2.345E-03 1.414E-03 7.061E-04 2.350E-04 1.518E-05 5.944E-05 3.791E-04 9.839E-04 1.882E-03 3.080E-03 4.583E-03 6.394E-03 8.514E-03 1.094E-02 1.368E-02 1.671E-02 2.005E-02 2.367E-02 2.757E-02 3.173E-02 3.616E-02 4.082E-02 4.570E-02 5.080E-02 5.608E-02 6.154E-02 6.714E-02 7.288E-02 7.872E-02 8.465E-02 9.065E-02 9.668E-02 1.027E-01 1.088E-01 1.148E-01 1.208E-01 1.267E-01 1.326E-01 1.383E-01 1.439E-01 1.494E-01 1.547E-01 1.599E-01 1.648E-01 1.696E-01 1.742E-01 1.786E-01 1.827E-01 1.866E-01 1.903E-01 1.938E-01 1.970E-01 2.000E-01 2.027E-01 2.053E-01 2.076E-01 2.097E-01 2.116E-01 2.132E-01 2.147E-01 2.160E-01 2.171E-01 2.181E-01 2.189E-01 2.195E-01 2.201E-01 2.205E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.207E-01 2.205E-01 2.203E-01 2.201E-01 2.200E-01 2.198E-01 2.197E-01 2.196E-01 2.195E-01 2.195E-01 2.195E-01 2.195E-01 2.195E-01 2.196E-01 2.197E-01 2.198E-01 2.200E-01 2.201E-01 2.203E-01 2.205E-01 2.207E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.205E-01 2.201E-01 2.195E-01 2.189E-01 2.181E-01 2.171E-01 2.160E-01 2.147E-01 2.132E-01 2.116E-01 2.097E-01 2.076E-01 2.053E-01 2.027E-01 2.000E-01 1.970E-01 1.938E-01 1.903E-01 1.866E-01 1.827E-01 1.786E-01 1.742E-01 1.696E-01 1.648E-01 1.599E-01 1.547E-01 1.494E-01 1.439E-01 1.383E-01 1.326E-01 1.267E-01 1.208E-01 1.148E-01 1.088E-01 1.027E-01 9.668E-02 9.065E-02 8.465E-02 7.872E-02 7.288E-02 6.714E-02 6.154E-02 5.608E-02 5.080E-02 4.570E-02 4.082E-02 3.616E-02 3.173E-02 2.757E-02 2.367E-02 2.005E-02 1.671E-02 1.368E-02 1.094E-02 8.514E-03 6.394E-03 4.583E-03 3.080E-03 1.882E-03 9.839E-04 3.791E-04 5.944E-05 1.518E-05 2.350E-04 7.061E-04 1.414E-03 2.345E-03 3.481E-03 4.805E-03 6.300E-03 7.947E-03 9.726E-03 1.162E-02 1.360E-02 1.566E-02 1.777E-02 1.991E-02 2.207E-02 2.423E-02 2.635E-02 2.844E-02 3.047E-02 3.243E-02 3.429E-02 3.606E-02 3.771E-02 3.923E-02 4.061E-02 4.185E-02 4.294E-02 4.386E-02 4.462E-02 4.521E-02 4.564E-02 4.589E-02 4.597E-02 4.589E-02 4.564E-02 4.523E-02 4.466E-02 4.394E-02 4.309E-02 4.210E-02 4.099E-02 3.976E-02 3.843E-02 3.700E-02 3.549E-02 3.391E-02 3.148E-02 3.314E-02 3.474E-02 3.628E-02 3.774E-02 3.912E-02 4.039E-02 4.156E-02 4.261E-02 4.353E-02 4.431E-02 4.495E-02 4.544E-02 4.578E-02 4.595E-02 4.595E-02 4.579E-02 4.547E-02 4.497E-02 4.430E-02 4.347E-02 4.248E-02 4.134E-02 4.004E-02 3.861E-02 3.704E-02 3.535E-02 3.355E-02 3.166E-02 2.969E-02 2.765E-02 2.555E-02 2.343E-02 2.128E-02 1.914E-02 1.702E-02 1.494E-02 1.292E-02 1.098E-02 9.139E-03 7.413E-03 5.824E-03 4.390E-03 3.130E-03 2.060E-03 1.197E-03 5.573E-04 1.541E-04 1.084E-06 1.101E-04 4.916E-04 1.155E-03 2.107E-03 3.353E-03 4.898E-03 6.745E-03 8.893E-03 1.134E-02 1.409E-02 1.713E-02 2.045E-02 2.406E-02 2.793E-02 3.206E-02 3.644E-02 4.104E-02 4.586E-02 5.088E-02 5.608E-02 6.144E-02 6.695E-02 7.258E-02 7.831E-02 8.412E-02 8.999E-02 9.590E-02 1.018E-01 1.078E-01 1.137E-01 1.195E-01 1.253E-01 1.310E-01 1.366E-01 1.421E-01 1.475E-01 1.527E-01 1.578E-01 1.626E-01 1.673E-01 1.718E-01 1.761E-01 1.802E-01 1.841E-01 1.878E-01 1.912E-01 1.945E-01 1.975E-01 2.003E-01 2.029E-01 2.052E-01 2.074E-01 2.094E-01 2.111E-01 2.127E-01 2.141E-01 2.154E-01 2.165E-01 2.174E-01 2.182E-01 2.189E-01 2.195E-01 2.200E-01 2.203E-01 2.206E-01 2.208E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.210E-01 2.209E-01 2.209E-01 2.208E-01 2.208E-01 2.208E-01 2.208E-01 2.208E-01 2.209E-01 2.209E-01 2.210E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.208E-01 2.206E-01 2.203E-01 2.200E-01 2.195E-01 2.189E-01 2.182E-01 2.174E-01 2.165E-01 2.154E-01 2.141E-01 2.127E-01 2.111E-01 2.094E-01 2.074E-01 2.052E-01 2.029E-01 2.003E-01 1.975E-01 1.945E-01 1.912E-01 1.878E-01 1.841E-01 1.802E-01 1.761E-01 1.718E-01 1.673E-01 1.626E-01 1.578E-01 1.527E-01 1.475E-01 1.421E-01 1.366E-01 1.310E-01 1.253E-01 1.195E-01 1.137E-01 1.078E-01 1.018E-01 9.590E-02 8.999E-02 8.412E-02 7.831E-02 7.258E-02 6.695E-02 6.144E-02 5.608E-02 5.088E-02 4.586E-02 4.104E-02 3.644E-02 3.206E-02 2.793E-02 2.406E-02 2.045E-02 1.713E-02 1.409E-02 1.134E-02 8.893E-03 6.745E-03 4.898E-03 3.353E-03 2.107E-03 1.155E-03 4.916E-04 1.101E-04 1.084E-06 1.541E-04 5.573E-04 1.197E-03 2.060E-03 3.130E-03 4.390E-03 5.824E-03 7.413E-03 9.139E-03 1.098E-02 1.292E-02 1.494E-02 1.702E-02 1.914E-02 2.128E-02 2.343E-02 2.555E-02 2.765E-02 2.969E-02 3.166E-02 3.355E-02 3.535E-02 3.704E-02 3.861E-02 4.004E-02 4.134E-02 4.248E-02 4.347E-02 4.430E-02 4.497E-02 4.547E-02 4.579E-02 4.595E-02 4.595E-02 4.578E-02 4.544E-02 4.495E-02 4.431E-02 4.353E-02 4.261E-02 4.156E-02 4.039E-02 3.912E-02 3.774E-02 3.628E-02 3.474E-02 3.314E-02 3.067E-02 3.235E-02 3.397E-02 3.553E-02 3.703E-02 3.844E-02 3.976E-02 4.098E-02 4.209E-02 4.307E-02 4.392E-02 4.463E-02 4.520E-02 4.562E-02 4.587E-02 4.597E-02 4.590E-02 4.567E-02 4.527E-02 4.470E-02 4.396E-02 4.307E-02 4.202E-02 4.082E-02 3.947E-02 3.799E-02 3.638E-02 3.466E-02 3.283E-02 3.092E-02 2.893E-02 2.688E-02 2.479E-02 2.267E-02 2.054E-02 1.842E-02 1.632E-02 1.428E-02 1.229E-02 1.040E-02 8.601E-03 6.928E-03 5.395E-03 4.020E-03 2.820E-03 1.813E-03 1.014E-03 4.364E-04 9.521E-05 2.384E-06 1.690E-04 6.046E-04 1.317E-03 2.314E-03 3.600E-03 5.178E-03 7.050E-03 9.215E-03 1.167E-02 1.442E-02 1.745E-02 2.076E-02 2.434E-02 2.817E-02 3.226E-02 3.658E-02 4.112E-02 4.586E-02 5.080E-02 5.591E-02 6.117E-02 6.657E-02 7.208E-02 7.769E-02 8.338E-02 8.912E-02 9.490E-02 1.007E-01 1.065E-01 1.122E-01 1.180E-01 1.236E-01 1.292E-01 1.347E-01 1.401E-01 1.453E-01 1.504E-01 1.554E-01 1.602E-01 1.648E-01 1.692E-01 1.735E-01 1.775E-01 1.814E-01 1.850E-01 1.884E-01 1.917E-01 1.947E-01 1.975E-01 2.001E-01 2.026E-01 2.048E-01 2.068E-01 2.087E-01 2.104E-01 2.119E-01 2.133E-01 2.145E-01 2.155E-01 2.165E-01 2.173E-01 2.180E-01 2.186E-01 2.191E-01 2.196E-01 2.199E-01 2.202E-01 2.204E-01 2.206E-01 2.208E-01 2.209E-01 2.210E-01 2.210E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.211E-01 2.210E-01 2.210E-01 2.209E-01 2.208E-01 2.206E-01 2.204E-01 2.202E-01 2.199E-01 2.196E-01 2.191E-01 2.186E-01 2.180E-01 2.173E-01 2.165E-01 2.155E-01 2.145E-01 2.133E-01 2.119E-01 2.104E-01 2.087E-01 2.068E-01 2.048E-01 2.026E-01 2.001E-01 1.975E-01 1.947E-01 1.917E-01 1.884E-01 1.850E-01 1.814E-01 1.775E-01 1.735E-01 1.692E-01 1.648E-01 1.602E-01 1.554E-01 1.504E-01 1.453E-01 1.401E-01 1.347E-01 1.292E-01 1.236E-01 1.180E-01 1.122E-01 1.065E-01 1.007E-01 9.490E-02 8.912E-02 8.338E-02 7.769E-02 7.208E-02 6.657E-02 6.117E-02 5.591E-02 5.080E-02 4.586E-02 4.112E-02 3.658E-02 3.226E-02 2.817E-02 2.434E-02 2.076E-02 1.745E-02 1.442E-02 1.167E-02 9.215E-03 7.050E-03 5.178E-03 3.600E-03 2.314E-03 1.317E-03 6.046E-04 1.690E-04 2.384E-06 9.521E-05 4.364E-04 1.014E-03 1.813E-03 2.820E-03 4.020E-03 5.395E-03 6.928E-03 8.601E-03 1.040E-02 1.229E-02 1.428E-02 1.632E-02 1.842E-02 2.054E-02 2.267E-02 2.479E-02 2.688E-02 2.893E-02 3.092E-02 3.283E-02 3.466E-02 3.638E-02 3.799E-02 3.947E-02 4.082E-02 4.202E-02 4.307E-02 4.396E-02 4.470E-02 4.527E-02 4.567E-02 4.590E-02 4.597E-02 4.587E-02 4.562E-02 4.520E-02 4.463E-02 4.392E-02 4.307E-02 4.209E-02 4.098E-02 3.976E-02 3.844E-02 3.703E-02 3.553E-02 3.397E-02 3.235E-02 2.985E-02 3.153E-02 3.317E-02 3.476E-02 3.629E-02 3.774E-02 3.910E-02 4.037E-02 4.153E-02 4.257E-02 4.349E-02 4.427E-02 4.492E-02 4.541E-02 4.575E-02 4.594E-02 4.596E-02 4.582E-02 4.551E-02 4.504E-02 4.441E-02 4.361E-02 4.266E-02 4.155E-02 4.029E-02 3.890E-02 3.738E-02 3.573E-02 3.398E-02 3.213E-02 3.020E-02 2.820E-02 2.615E-02 2.406E-02 2.195E-02 1.984E-02 1.774E-02 1.567E-02 1.366E-02 1.171E-02 9.859E-03 8.111E-03 6.489E-03 5.010E-03 3.691E-03 2.550E-03 1.601E-03 8.593E-04 3.396E-04 5.426E-05 1.486E-05 2.316E-04 7.135E-04 1.468E-03 2.501E-03 3.816E-03 5.417E-03 7.304E-03 9.478E-03 1.194E-02 1.467E-02 1.769E-02 2.097E-02 2.451E-02 2.830E-02 3.232E-02 3.658E-02 4.104E-02 4.570E-02 5.055E-02 5.555E-02 6.071E-02 6.599E-02 7.139E-02 7.687E-02 8.243E-02 8.803E-02 9.367E-02 9.933E-02 1.050E-01 1.106E-01 1.162E-01 1.217E-01 1.272E-01 1.325E-01 1.378E-01 1.429E-01 1.479E-01 1.528E-01 1.575E-01 1.620E-01 1.663E-01 1.705E-01 1.745E-01 1.783E-01 1.820E-01 1.854E-01 1.886E-01 1.916E-01 1.945E-01 1.971E-01 1.996E-01 2.019E-01 2.040E-01 2.059E-01 2.077E-01 2.093E-01 2.107E-01 2.120E-01 2.132E-01 2.143E-01 2.152E-01 2.160E-01 2.167E-01 2.174E-01 2.179E-01 2.184E-01 2.188E-01 2.191E-01 2.194E-01 2.197E-01 2.199E-01 2.200E-01 2.201E-01 2.202E-01 2.203E-01 2.204E-01 2.204E-01 2.204E-01 2.204E-01 2.204E-01 2.203E-01 2.202E-01 2.201E-01 2.200E-01 2.199E-01 2.197E-01 2.194E-01 2.191E-01 2.188E-01 2.184E-01 2.179E-01 2.174E-01 2.167E-01 2.160E-01 2.152E-01 2.143E-01 2.132E-01 2.120E-01 2.107E-01 2.093E-01 2.077E-01 2.059E-01 2.040E-01 2.019E-01 1.996E-01 1.971E-01 1.945E-01 1.916E-01 1.886E-01 1.854E-01 1.820E-01 1.783E-01 1.745E-01 1.705E-01 1.663E-01 1.620E-01 1.575E-01 1.528E-01 1.479E-01 1.429E-01 1.378E-01 1.325E-01 1.272E-01 1.217E-01 1.162E-01 1.106E-01 1.050E-01 9.933E-02 9.367E-02 8.803E-02 8.243E-02 7.687E-02 7.139E-02 6.599E-02 6.071E-02 5.555E-02 5.055E-02 4.570E-02 4.104E-02 3.658E-02 3.232E-02 2.830E-02 2.451E-02 2.097E-02 1.769E-02 1.467E-02 1.194E-02 9.478E-03 7.304E-03 5.417E-03 3.816E-03 2.501E-03 1.468E-03 7.135E-04 2.316E-04 1.486E-05 5.426E-05 3.396E-04 8.593E-04 1.601E-03 2.550E-03 3.691E-03 5.010E-03 6.489E-03 8.111E-03 9.859E-03 1.171E-02 1.366E-02 1.567E-02 1.774E-02 1.984E-02 2.195E-02 2.406E-02 2.615E-02 2.820E-02 3.020E-02 3.213E-02 3.398E-02 3.573E-02 3.738E-02 3.890E-02 4.029E-02 4.155E-02 4.266E-02 4.361E-02 4.441E-02 4.504E-02 4.551E-02 4.582E-02 4.596E-02 4.594E-02 4.575E-02 4.541E-02 4.492E-02 4.427E-02 4.349E-02 4.257E-02 4.153E-02 4.037E-02 3.910E-02 3.774E-02 3.629E-02 3.476E-02 3.317E-02 3.153E-02 2.900E-02 3.069E-02 3.235E-02 3.396E-02 3.552E-02 3.700E-02 3.840E-02 3.972E-02 4.093E-02 4.203E-02 4.301E-02 4.386E-02 4.458E-02 4.516E-02 4.558E-02 4.585E-02 4.597E-02 4.592E-02 4.571E-02 4.534E-02 4.480E-02 4.410E-02 4.324E-02 4.223E-02 4.107E-02 3.977E-02 3.834E-02 3.678E-02 3.510E-02 3.333E-02 3.146E-02 2.951E-02 2.751E-02 2.545E-02 2.337E-02 2.127E-02 1.918E-02 1.710E-02 1.507E-02 1.309E-02 1.118E-02 9.370E-03 7.669E-03 6.096E-03 4.668E-03 3.402E-03 2.314E-03 1.419E-03 7.312E-04 2.633E-04 2.751E-05 3.466E-05 2.943E-04 8.144E-04 1.602E-03 2.662E-03 3.998E-03 5.613E-03 7.506E-03 9.678E-03 1.212E-02 1.484E-02 1.783E-02 2.107E-02 2.456E-02 2.830E-02 3.226E-02 3.644E-02 4.082E-02 4.539E-02 5.013E-02 5.503E-02 6.007E-02 6.523E-02 7.050E-02 7.585E-02 8.127E-02 8.674E-02 9.224E-02 9.775E-02 1.033E-01 1.087E-01 1.142E-01 1.196E-01 1.249E-01 1.301E-01 1.352E-01 1.402E-01 1.451E-01 1.499E-01 1.545E-01 1.589E-01 1.632E-01 1.673E-01 1.713E-01 1.750E-01 1.786E-01 1.820E-01 1.852E-01 1.882E-01 1.911E-01 1.938E-01 1.962E-01 1.986E-01 2.007E-01 2.027E-01 2.045E-01 2.062E-01 2.077E-01 2.091E-01 2.104E-01 2.115E-01 2.125E-01 2.135E-01 2.143E-01 2.150E-01 2.156E-01 2.162E-01 2.167E-01 2.171E-01 2.175E-01 2.178E-01 2.180E-01 2.182E-01 2.184E-01 2.185E-01 2.186E-01 2.187E-01 2.187E-01 2.187E-01 2.186E-01 2.185E-01 2.184E-01 2.182E-01 2.180E-01 2.178E-01 2.175E-01 2.171E-01 2.167E-01 2.162E-01 2.156E-01 2.150E-01 2.143E-01 2.135E-01 2.125E-01 2.115E-01 2.104E-01 2.091E-01 2.077E-01 2.062E-01 2.045E-01 2.027E-01 2.007E-01 1.986E-01 1.962E-01 1.938E-01 1.911E-01 1.882E-01 1.852E-01 1.820E-01 1.786E-01 1.750E-01 1.713E-01 1.673E-01 1.632E-01 1.589E-01 1.545E-01 1.499E-01 1.451E-01 1.402E-01 1.352E-01 1.301E-01 1.249E-01 1.196E-01 1.142E-01 1.087E-01 1.033E-01 9.775E-02 9.224E-02 8.674E-02 8.127E-02 7.585E-02 7.050E-02 6.523E-02 6.007E-02 5.503E-02 5.013E-02 4.539E-02 4.082E-02 3.644E-02 3.226E-02 2.830E-02 2.456E-02 2.107E-02 1.783E-02 1.484E-02 1.212E-02 9.678E-03 7.506E-03 5.613E-03 3.998E-03 2.662E-03 1.602E-03 8.144E-04 2.943E-04 3.466E-05 2.751E-05 2.633E-04 7.312E-04 1.419E-03 2.314E-03 3.402E-03 4.668E-03 6.096E-03 7.669E-03 9.370E-03 1.118E-02 1.309E-02 1.507E-02 1.710E-02 1.918E-02 2.127E-02 2.337E-02 2.545E-02 2.751E-02 2.951E-02 3.146E-02 3.333E-02 3.510E-02 3.678E-02 3.834E-02 3.977E-02 4.107E-02 4.223E-02 4.324E-02 4.410E-02 4.480E-02 4.534E-02 4.571E-02 4.592E-02 4.597E-02 4.585E-02 4.558E-02 4.516E-02 4.458E-02 4.386E-02 4.301E-02 4.203E-02 4.093E-02 3.972E-02 3.840E-02 3.700E-02 3.552E-02 3.396E-02 3.235E-02 3.069E-02 2.814E-02 2.984E-02 3.151E-02 3.314E-02 3.472E-02 3.623E-02 3.767E-02 3.903E-02 4.029E-02 4.145E-02 4.249E-02 4.341E-02 4.420E-02 4.485E-02 4.536E-02 4.572E-02 4.592E-02 4.597E-02 4.585E-02 4.558E-02 4.514E-02 4.454E-02 4.378E-02 4.287E-02 4.181E-02 4.060E-02 3.926E-02 3.778E-02 3.619E-02 3.449E-02 3.269E-02 3.081E-02 2.886E-02 2.685E-02 2.480E-02 2.272E-02 2.064E-02 1.856E-02 1.652E-02 1.451E-02 1.256E-02 1.070E-02 8.928E-03 7.272E-03 5.746E-03 4.367E-03 3.150E-03 2.112E-03 1.266E-03 6.262E-04 2.042E-04 1.154E-05 5.831E-05 3.533E-04 9.039E-04 1.716E-03 2.795E-03 4.143E-03 5.762E-03 7.652E-03 9.812E-03 1.224E-02 1.493E-02 1.787E-02 2.107E-02 2.451E-02 2.817E-02 3.206E-02 3.616E-02 4.044E-02 4.491E-02 4.955E-02 5.433E-02 5.925E-02 6.429E-02 6.942E-02 7.463E-02 7.991E-02 8.524E-02 9.059E-02 9.596E-02 1.013E-01 1.067E-01 1.120E-01 1.172E-01 1.224E-01 1.275E-01 1.325E-01 1.374E-01 1.421E-01 1.468E-01 1.513E-01 1.556E-01 1.598E-01 1.639E-01 1.677E-01 1.714E-01 1.750E-01 1.783E-01 1.815E-01 1.845E-01 1.874E-01 1.901E-01 1.926E-01 1.949E-01 1.971E-01 1.991E-01 2.010E-01 2.027E-01 2.043E-01 2.057E-01 2.071E-01 2.083E-01 2.094E-01 2.103E-01 2.112E-01 2.120E-01 2.127E-01 2.133E-01 2.139E-01 2.144E-01 2.148E-01 2.151E-01 2.154E-01 2.156E-01 2.158E-01 2.159E-01 2.160E-01 2.160E-01 2.160E-01 2.159E-01 2.158E-01 2.156E-01 2.154E-01 2.151E-01 2.148E-01 2.144E-01 2.139E-01 2.133E-01 2.127E-01 2.120E-01 2.112E-01 2.103E-01 2.094E-01 2.083E-01 2.071E-01 2.057E-01 2.043E-01 2.027E-01 2.010E-01 1.991E-01 1.971E-01 1.949E-01 1.926E-01 1.901E-01 1.874E-01 1.845E-01 1.815E-01 1.783E-01 1.750E-01 1.714E-01 1.677E-01 1.639E-01 1.598E-01 1.556E-01 1.513E-01 1.468E-01 1.421E-01 1.374E-01 1.325E-01 1.275E-01 1.224E-01 1.172E-01 1.120E-01 1.067E-01 1.013E-01 9.596E-02 9.059E-02 8.524E-02 7.991E-02 7.463E-02 6.942E-02 6.429E-02 5.925E-02 5.433E-02 4.955E-02 4.491E-02 4.044E-02 3.616E-02 3.206E-02 2.817E-02 2.451E-02 2.107E-02 1.787E-02 1.493E-02 1.224E-02 9.812E-03 7.652E-03 5.762E-03 4.143E-03 2.795E-03 1.716E-03 9.039E-04 3.533E-04 5.831E-05 1.154E-05 2.042E-04 6.262E-04 1.266E-03 2.112E-03 3.150E-03 4.367E-03 5.746E-03 7.272E-03 8.928E-03 1.070E-02 1.256E-02 1.451E-02 1.652E-02 1.856E-02 2.064E-02 2.272E-02 2.480E-02 2.685E-02 2.886E-02 3.081E-02 3.269E-02 3.449E-02 3.619E-02 3.778E-02 3.926E-02 4.060E-02 4.181E-02 4.287E-02 4.378E-02 4.454E-02 4.514E-02 4.558E-02 4.585E-02 4.597E-02 4.592E-02 4.572E-02 4.536E-02 4.485E-02 4.420E-02 4.341E-02 4.249E-02 4.145E-02 4.029E-02 3.903E-02 3.767E-02 3.623E-02 3.472E-02 3.314E-02 3.151E-02 2.984E-02 2.726E-02 2.897E-02 3.065E-02 3.229E-02 3.389E-02 3.544E-02 3.691E-02 3.831E-02 3.962E-02 4.083E-02 4.193E-02 4.291E-02 4.377E-02 4.450E-02 4.509E-02 4.553E-02 4.582E-02 4.596E-02 4.594E-02 4.576E-02 4.542E-02 4.492E-02 4.427E-02 4.346E-02 4.249E-02 4.138E-02 4.013E-02 3.875E-02 3.724E-02 3.562E-02 3.390E-02 3.209E-02 3.019E-02 2.823E-02 2.622E-02 2.418E-02 2.212E-02 2.005E-02 1.800E-02 1.597E-02 1.400E-02 1.209E-02 1.026E-02 8.532E-03 6.918E-03 5.437E-03 4.103E-03 2.933E-03 1.940E-03 1.139E-03 5.414E-04 1.593E-04 3.342E-06 8.280E-05 4.058E-04 9.791E-04 1.808E-03 2.897E-03 4.248E-03 5.863E-03 7.741E-03 9.880E-03 1.228E-02 1.493E-02 1.783E-02 2.097E-02 2.434E-02 2.793E-02 3.173E-02 3.574E-02 3.993E-02 4.429E-02 4.881E-02 5.347E-02 5.826E-02 6.316E-02 6.815E-02 7.323E-02 7.836E-02 8.353E-02 8.874E-02 9.395E-02 9.916E-02 1.043E-01 1.095E-01 1.146E-01 1.196E-01 1.246E-01 1.294E-01 1.342E-01 1.389E-01 1.434E-01 1.478E-01 1.520E-01 1.562E-01 1.601E-01 1.639E-01 1.676E-01 1.710E-01 1.744E-01 1.775E-01 1.805E-01 1.833E-01 1.860E-01 1.885E-01 1.908E-01 1.930E-01 1.951E-01 1.970E-01 1.987E-01 2.004E-01 2.019E-01 2.032E-01 2.045E-01 2.056E-01 2.066E-01 2.076E-01 2.084E-01 2.092E-01 2.098E-01 2.104E-01 2.109E-01 2.113E-01 2.116E-01 2.119E-01 2.121E-01 2.123E-01 2.124E-01 2.124E-01 2.124E-01 2.123E-01 2.121E-01 2.119E-01 2.116E-01 2.113E-01 2.109E-01 2.104E-01 2.098E-01 2.092E-01 2.084E-01 2.076E-01 2.066E-01 2.056E-01 2.045E-01 2.032E-01 2.019E-01 2.004E-01 1.987E-01 1.970E-01 1.951E-01 1.930E-01 1.908E-01 1.885E-01 1.860E-01 1.833E-01 1.805E-01 1.775E-01 1.744E-01 1.710E-01 1.676E-01 1.639E-01 1.601E-01 1.562E-01 1.520E-01 1.478E-01 1.434E-01 1.389E-01 1.342E-01 1.294E-01 1.246E-01 1.196E-01 1.146E-01 1.095E-01 1.043E-01 9.916E-02 9.395E-02 8.874E-02 8.353E-02 7.836E-02 7.323E-02 6.815E-02 6.316E-02 5.826E-02 5.347E-02 4.881E-02 4.429E-02 3.993E-02 3.574E-02 3.173E-02 2.793E-02 2.434E-02 2.097E-02 1.783E-02 1.493E-02 1.228E-02 9.880E-03 7.741E-03 5.863E-03 4.248E-03 2.897E-03 1.808E-03 9.791E-04 4.058E-04 8.280E-05 3.342E-06 1.593E-04 5.414E-04 1.139E-03 1.940E-03 2.933E-03 4.103E-03 5.437E-03 6.918E-03 8.532E-03 1.026E-02 1.209E-02 1.400E-02 1.597E-02 1.800E-02 2.005E-02 2.212E-02 2.418E-02 2.622E-02 2.823E-02 3.019E-02 3.209E-02 3.390E-02 3.562E-02 3.724E-02 3.875E-02 4.013E-02 4.138E-02 4.249E-02 4.346E-02 4.427E-02 4.492E-02 4.542E-02 4.576E-02 4.594E-02 4.596E-02 4.582E-02 4.553E-02 4.509E-02 4.450E-02 4.377E-02 4.291E-02 4.193E-02 4.083E-02 3.962E-02 3.831E-02 3.691E-02 3.544E-02 3.389E-02 3.229E-02 3.065E-02 2.897E-02 2.637E-02 2.808E-02 2.977E-02 3.143E-02 3.304E-02 3.461E-02 3.612E-02 3.755E-02 3.890E-02 4.016E-02 4.132E-02 4.237E-02 4.330E-02 4.410E-02 4.476E-02 4.529E-02 4.567E-02 4.590E-02 4.597E-02 4.589E-02 4.565E-02 4.525E-02 4.470E-02 4.399E-02 4.312E-02 4.211E-02 4.096E-02 3.967E-02 3.826E-02 3.672E-02 3.508E-02 3.333E-02 3.151E-02 2.961E-02 2.765E-02 2.564E-02 2.360E-02 2.155E-02 1.951E-02 1.748E-02 1.548E-02 1.354E-02 1.166E-02 9.869E-03 8.179E-03 6.607E-03 5.168E-03 3.877E-03 2.748E-03 1.797E-03 1.035E-03 4.741E-04 1.261E-04 2.914E-07 1.055E-04 4.492E-04 1.038E-03 1.875E-03 2.966E-03 4.312E-03 5.913E-03 7.770E-03 9.880E-03 1.224E-02 1.484E-02 1.769E-02 2.076E-02 2.406E-02 2.757E-02 3.128E-02 3.518E-02 3.927E-02 4.351E-02 4.791E-02 5.244E-02 5.710E-02 6.186E-02 6.671E-02 7.163E-02 7.661E-02 8.164E-02 8.668E-02 9.174E-02 9.680E-02 1.018E-01 1.068E-01 1.118E-01 1.167E-01 1.215E-01 1.262E-01 1.308E-01 1.354E-01 1.398E-01 1.441E-01 1.482E-01 1.522E-01 1.561E-01 1.598E-01 1.634E-01 1.668E-01 1.701E-01 1.732E-01 1.761E-01 1.789E-01 1.816E-01 1.841E-01 1.864E-01 1.886E-01 1.906E-01 1.926E-01 1.943E-01 1.960E-01 1.975E-01 1.989E-01 2.001E-01 2.013E-01 2.024E-01 2.033E-01 2.042E-01 2.049E-01 2.056E-01 2.062E-01 2.066E-01 2.071E-01 2.074E-01 2.077E-01 2.078E-01 2.079E-01 2.080E-01 2.079E-01 2.078E-01 2.077E-01 2.074E-01 2.071E-01 2.066E-01 2.062E-01 2.056E-01 2.049E-01 2.042E-01 2.033E-01 2.024E-01 2.013E-01 2.001E-01 1.989E-01 1.975E-01 1.960E-01 1.943E-01 1.926E-01 1.906E-01 1.886E-01 1.864E-01 1.841E-01 1.816E-01 1.789E-01 1.761E-01 1.732E-01 1.701E-01 1.668E-01 1.634E-01 1.598E-01 1.561E-01 1.522E-01 1.482E-01 1.441E-01 1.398E-01 1.354E-01 1.308E-01 1.262E-01 1.215E-01 1.167E-01 1.118E-01 1.068E-01 1.018E-01 9.680E-02 9.174E-02 8.668E-02 8.164E-02 7.661E-02 7.163E-02 6.671E-02 6.186E-02 5.710E-02 5.244E-02 4.791E-02 4.351E-02 3.927E-02 3.518E-02 3.128E-02 2.757E-02 2.406E-02 2.076E-02 1.769E-02 1.484E-02 1.224E-02 9.880E-03 7.770E-03 5.913E-03 4.312E-03 2.966E-03 1.875E-03 1.038E-03 4.492E-04 1.055E-04 2.914E-07 1.261E-04 4.741E-04 1.035E-03 1.797E-03 2.748E-03 3.877E-03 5.168E-03 6.607E-03 8.179E-03 9.869E-03 1.166E-02 1.354E-02 1.548E-02 1.748E-02 1.951E-02 2.155E-02 2.360E-02 2.564E-02 2.765E-02 2.961E-02 3.151E-02 3.333E-02 3.508E-02 3.672E-02 3.826E-02 3.967E-02 4.096E-02 4.211E-02 4.312E-02 4.399E-02 4.470E-02 4.525E-02 4.565E-02 4.589E-02 4.597E-02 4.590E-02 4.567E-02 4.529E-02 4.476E-02 4.410E-02 4.330E-02 4.237E-02 4.132E-02 4.016E-02 3.890E-02 3.755E-02 3.612E-02 3.461E-02 3.304E-02 3.143E-02 2.977E-02 2.808E-02 2.547E-02 2.717E-02 2.887E-02 3.054E-02 3.217E-02 3.376E-02 3.530E-02 3.676E-02 3.816E-02 3.946E-02 4.067E-02 4.178E-02 4.277E-02 4.364E-02 4.439E-02 4.499E-02 4.546E-02 4.578E-02 4.594E-02 4.596E-02 4.582E-02 4.552E-02 4.507E-02 4.446E-02 4.370E-02 4.279E-02 4.174E-02 4.054E-02 3.922E-02 3.778E-02 3.622E-02 3.455E-02 3.280E-02 3.096E-02 2.905E-02 2.709E-02 2.509E-02 2.307E-02 2.104E-02 1.901E-02 1.700E-02 1.503E-02 1.312E-02 1.128E-02 9.522E-03 7.870E-03 6.336E-03 4.936E-03 3.684E-03 2.594E-03 1.679E-03 9.513E-04 4.223E-04 1.022E-04 2.162E-07 1.244E-04 4.817E-04 1.078E-03 1.916E-03 3.001E-03 4.333E-03 5.913E-03 7.741E-03 9.812E-03 1.212E-02 1.467E-02 1.745E-02 2.045E-02 2.367E-02 2.709E-02 3.070E-02 3.450E-02 3.847E-02 4.259E-02 4.686E-02 5.126E-02 5.577E-02 6.039E-02 6.509E-02 6.986E-02 7.468E-02 7.955E-02 8.444E-02 8.934E-02 9.423E-02 9.910E-02 1.039E-01 1.087E-01 1.135E-01 1.181E-01 1.227E-01 1.272E-01 1.316E-01 1.359E-01 1.401E-01 1.441E-01 1.480E-01 1.518E-01 1.554E-01 1.589E-01 1.623E-01 1.655E-01 1.685E-01 1.714E-01 1.742E-01 1.768E-01 1.793E-01 1.816E-01 1.838E-01 1.858E-01 1.877E-01 1.895E-01 1.911E-01 1.926E-01 1.940E-01 1.953E-01 1.964E-01 1.975E-01 1.984E-01 1.993E-01 2.000E-01 2.007E-01 2.012E-01 2.017E-01 2.021E-01 2.024E-01 2.026E-01 2.027E-01 2.027E-01 2.027E-01 2.026E-01 2.024E-01 2.021E-01 2.017E-01 2.012E-01 2.007E-01 2.000E-01 1.993E-01 1.984E-01 1.975E-01 1.964E-01 1.953E-01 1.940E-01 1.926E-01 1.911E-01 1.895E-01 1.877E-01 1.858E-01 1.838E-01 1.816E-01 1.793E-01 1.768E-01 1.742E-01 1.714E-01 1.685E-01 1.655E-01 1.623E-01 1.589E-01 1.554E-01 1.518E-01 1.480E-01 1.441E-01 1.401E-01 1.359E-01 1.316E-01 1.272E-01 1.227E-01 1.181E-01 1.135E-01 1.087E-01 1.039E-01 9.910E-02 9.423E-02 8.934E-02 8.444E-02 7.955E-02 7.468E-02 6.986E-02 6.509E-02 6.039E-02 5.577E-02 5.126E-02 4.686E-02 4.259E-02 3.847E-02 3.450E-02 3.070E-02 2.709E-02 2.367E-02 2.045E-02 1.745E-02 1.467E-02 1.212E-02 9.812E-03 7.741E-03 5.913E-03 4.333E-03 3.001E-03 1.916E-03 1.078E-03 4.817E-04 1.244E-04 2.162E-07 1.022E-04 4.223E-04 9.513E-04 1.679E-03 2.594E-03 3.684E-03 4.936E-03 6.336E-03 7.870E-03 9.522E-03 1.128E-02 1.312E-02 1.503E-02 1.700E-02 1.901E-02 2.104E-02 2.307E-02 2.509E-02 2.709E-02 2.905E-02 3.096E-02 3.280E-02 3.455E-02 3.622E-02 3.778E-02 3.922E-02 4.054E-02 4.174E-02 4.279E-02 4.370E-02 4.446E-02 4.507E-02 4.552E-02 4.582E-02 4.596E-02 4.594E-02 4.578E-02 4.546E-02 4.499E-02 4.439E-02 4.364E-02 4.277E-02 4.178E-02 4.067E-02 3.946E-02 3.816E-02 3.676E-02 3.530E-02 3.376E-02 3.217E-02 3.054E-02 2.887E-02 2.717E-02 2.455E-02 2.626E-02 2.795E-02 2.963E-02 3.127E-02 3.288E-02 3.444E-02 3.594E-02 3.737E-02 3.872E-02 3.999E-02 4.115E-02 4.220E-02 4.314E-02 4.396E-02 4.464E-02 4.519E-02 4.560E-02 4.586E-02 4.597E-02 4.593E-02 4.573E-02 4.538E-02 4.487E-02 4.422E-02 4.341E-02 4.246E-02 4.137E-02 4.014E-02 3.879E-02 3.731E-02 3.573E-02 3.405E-02 3.229E-02 3.044E-02 2.854E-02 2.658E-02 2.459E-02 2.258E-02 2.056E-02 1.855E-02 1.657E-02 1.463E-02 1.275E-02 1.094E-02 9.219E-03 7.602E-03 6.105E-03 4.741E-03 3.524E-03 2.468E-03 1.585E-03 8.868E-04 3.839E-04 8.587E-05 1.402E-06 1.379E-04 5.017E-04 1.098E-03 1.930E-03 3.001E-03 4.312E-03 5.863E-03 7.652E-03 9.678E-03 1.194E-02 1.442E-02 1.713E-02 2.005E-02 2.317E-02 2.650E-02 3.000E-02 3.369E-02 3.753E-02 4.153E-02 4.566E-02 4.992E-02 5.429E-02 5.875E-02 6.330E-02 6.791E-02 7.258E-02 7.728E-02 8.200E-02 8.674E-02 9.147E-02 9.618E-02 1.009E-01 1.055E-01 1.101E-01 1.146E-01 1.190E-01 1.234E-01 1.276E-01 1.318E-01 1.358E-01 1.398E-01 1.436E-01 1.472E-01 1.508E-01 1.542E-01 1.575E-01 1.606E-01 1.636E-01 1.664E-01 1.691E-01 1.717E-01 1.741E-01 1.764E-01 1.785E-01 1.805E-01 1.824E-01 1.841E-01 1.857E-01 1.872E-01 1.886E-01 1.899E-01 1.910E-01 1.920E-01 1.929E-01 1.938E-01 1.945E-01 1.951E-01 1.956E-01 1.960E-01 1.963E-01 1.966E-01 1.967E-01 1.968E-01 1.967E-01 1.966E-01 1.963E-01 1.960E-01 1.956E-01 1.951E-01 1.945E-01 1.938E-01 1.929E-01 1.920E-01 1.910E-01 1.899E-01 1.886E-01 1.872E-01 1.857E-01 1.841E-01 1.824E-01 1.805E-01 1.785E-01 1.764E-01 1.741E-01 1.717E-01 1.691E-01 1.664E-01 1.636E-01 1.606E-01 1.575E-01 1.542E-01 1.508E-01 1.472E-01 1.436E-01 1.398E-01 1.358E-01 1.318E-01 1.276E-01 1.234E-01 1.190E-01 1.146E-01 1.101E-01 1.055E-01 1.009E-01 9.618E-02 9.147E-02 8.674E-02 8.200E-02 7.728E-02 7.258E-02 6.791E-02 6.330E-02 5.875E-02 5.429E-02 4.992E-02 4.566E-02 4.153E-02 3.753E-02 3.369E-02 3.000E-02 2.650E-02 2.317E-02 2.005E-02 1.713E-02 1.442E-02 1.194E-02 9.678E-03 7.652E-03 5.863E-03 4.312E-03 3.001E-03 1.930E-03 1.098E-03 5.017E-04 1.379E-04 1.402E-06 8.587E-05 3.839E-04 8.868E-04 1.585E-03 2.468E-03 3.524E-03 4.741E-03 6.105E-03 7.602E-03 9.219E-03 1.094E-02 1.275E-02 1.463E-02 1.657E-02 1.855E-02 2.056E-02 2.258E-02 2.459E-02 2.658E-02 2.854E-02 3.044E-02 3.229E-02 3.405E-02 3.573E-02 3.731E-02 3.879E-02 4.014E-02 4.137E-02 4.246E-02 4.341E-02 4.422E-02 4.487E-02 4.538E-02 4.573E-02 4.593E-02 4.597E-02 4.586E-02 4.560E-02 4.519E-02 4.464E-02 4.396E-02 4.314E-02 4.220E-02 4.115E-02 3.999E-02 3.872E-02 3.737E-02 3.594E-02 3.444E-02 3.288E-02 3.127E-02 2.963E-02 2.795E-02 2.626E-02 2.363E-02 2.533E-02 2.702E-02 2.870E-02 3.036E-02 3.198E-02 3.356E-02 3.509E-02 3.656E-02 3.795E-02 3.926E-02 4.047E-02 4.159E-02 4.259E-02 4.348E-02 4.424E-02 4.487E-02 4.536E-02 4.571E-02 4.592E-02 4.597E-02 4.587E-02 4.562E-02 4.522E-02 4.467E-02 4.397E-02 4.312E-02 4.213E-02 4.100E-02 3.975E-02 3.837E-02 3.687E-02 3.527E-02 3.358E-02 3.181E-02 2.996E-02 2.806E-02 2.611E-02 2.413E-02 2.213E-02 2.013E-02 1.815E-02 1.619E-02 1.428E-02 1.242E-02 1.065E-02 8.958E-03 7.375E-03 5.911E-03 4.580E-03 3.395E-03 2.369E-03 1.514E-03 8.399E-04 3.575E-04 7.576E-05 2.612E-06 1.449E-04 5.085E-04 1.098E-03 1.916E-03 2.966E-03 4.248E-03 5.762E-03 7.506E-03 9.478E-03 1.167E-02 1.409E-02 1.671E-02 1.955E-02 2.258E-02 2.579E-02 2.919E-02 3.275E-02 3.647E-02 4.033E-02 4.433E-02 4.844E-02 5.266E-02 5.697E-02 6.135E-02 6.580E-02 7.030E-02 7.484E-02 7.939E-02 8.396E-02 8.852E-02 9.307E-02 9.758E-02 1.021E-01 1.065E-01 1.108E-01 1.151E-01 1.193E-01 1.234E-01 1.275E-01 1.314E-01 1.352E-01 1.389E-01 1.424E-01 1.459E-01 1.492E-01 1.523E-01 1.554E-01 1.583E-01 1.611E-01 1.637E-01 1.662E-01 1.685E-01 1.708E-01 1.728E-01 1.748E-01 1.766E-01 1.783E-01 1.799E-01 1.814E-01 1.827E-01 1.839E-01 1.850E-01 1.860E-01 1.869E-01 1.876E-01 1.883E-01 1.889E-01 1.893E-01 1.897E-01 1.899E-01 1.901E-01 1.901E-01 1.901E-01 1.899E-01 1.897E-01 1.893E-01 1.889E-01 1.883E-01 1.876E-01 1.869E-01 1.860E-01 1.850E-01 1.839E-01 1.827E-01 1.814E-01 1.799E-01 1.783E-01 1.766E-01 1.748E-01 1.728E-01 1.708E-01 1.685E-01 1.662E-01 1.637E-01 1.611E-01 1.583E-01 1.554E-01 1.523E-01 1.492E-01 1.459E-01 1.424E-01 1.389E-01 1.352E-01 1.314E-01 1.275E-01 1.234E-01 1.193E-01 1.151E-01 1.108E-01 1.065E-01 1.021E-01 9.758E-02 9.307E-02 8.852E-02 8.396E-02 7.939E-02 7.484E-02 7.030E-02 6.580E-02 6.135E-02 5.697E-02 5.266E-02 4.844E-02 4.433E-02 4.033E-02 3.647E-02 3.275E-02 2.919E-02 2.579E-02 2.258E-02 1.955E-02 1.671E-02 1.409E-02 1.167E-02 9.478E-03 7.506E-03 5.762E-03 4.248E-03 2.966E-03 1.916E-03 1.098E-03 5.085E-04 1.449E-04 2.612E-06 7.576E-05 3.575E-04 8.399E-04 1.514E-03 2.369E-03 3.395E-03 4.580E-03 5.911E-03 7.375E-03 8.958E-03 1.065E-02 1.242E-02 1.428E-02 1.619E-02 1.815E-02 2.013E-02 2.213E-02 2.413E-02 2.611E-02 2.806E-02 2.996E-02 3.181E-02 3.358E-02 3.527E-02 3.687E-02 3.837E-02 3.975E-02 4.100E-02 4.213E-02 4.312E-02 4.397E-02 4.467E-02 4.522E-02 4.562E-02 4.587E-02 4.597E-02 4.592E-02 4.571E-02 4.536E-02 4.487E-02 4.424E-02 4.348E-02 4.259E-02 4.159E-02 4.047E-02 3.926E-02 3.795E-02 3.656E-02 3.509E-02 3.356E-02 3.198E-02 3.036E-02 2.870E-02 2.702E-02 2.533E-02 2.270E-02 2.439E-02 2.608E-02 2.776E-02 2.942E-02 3.106E-02 3.266E-02 3.421E-02 3.571E-02 3.713E-02 3.849E-02 3.975E-02 4.092E-02 4.199E-02 4.294E-02 4.378E-02 4.449E-02 4.507E-02 4.550E-02 4.580E-02 4.595E-02 4.595E-02 4.581E-02 4.551E-02 4.506E-02 4.446E-02 4.372E-02 4.283E-02 4.181E-02 4.065E-02 3.937E-02 3.796E-02 3.645E-02 3.484E-02 3.314E-02 3.136E-02 2.951E-02 2.761E-02 2.567E-02 2.370E-02 2.172E-02 1.974E-02 1.778E-02 1.585E-02 1.397E-02 1.214E-02 1.040E-02 8.739E-03 7.188E-03 5.754E-03 4.453E-03 3.296E-03 2.296E-03 1.464E-03 8.092E-04 3.421E-04 7.095E-05 3.098E-06 1.449E-04 5.017E-04 1.078E-03 1.875E-03 2.897E-03 4.143E-03 5.613E-03 7.304E-03 9.215E-03 1.134E-02 1.368E-02 1.622E-02 1.896E-02 2.188E-02 2.499E-02 2.826E-02 3.170E-02 3.529E-02 3.901E-02 4.286E-02 4.682E-02 5.088E-02 5.503E-02 5.925E-02 6.353E-02 6.786E-02 7.223E-02 7.661E-02 8.101E-02 8.540E-02 8.977E-02 9.412E-02 9.843E-02 1.027E-01 1.069E-01 1.110E-01 1.151E-01 1.190E-01 1.229E-01 1.267E-01 1.304E-01 1.339E-01 1.374E-01 1.407E-01 1.439E-01 1.469E-01 1.499E-01 1.527E-01 1.554E-01 1.579E-01 1.603E-01 1.626E-01 1.648E-01 1.668E-01 1.687E-01 1.705E-01 1.721E-01 1.736E-01 1.750E-01 1.763E-01 1.775E-01 1.785E-01 1.794E-01 1.802E-01 1.809E-01 1.815E-01 1.820E-01 1.824E-01 1.826E-01 1.828E-01 1.829E-01 1.828E-01 1.826E-01 1.824E-01 1.820E-01 1.815E-01 1.809E-01 1.802E-01 1.794E-01 1.785E-01 1.775E-01 1.763E-01 1.750E-01 1.736E-01 1.721E-01 1.705E-01 1.687E-01 1.668E-01 1.648E-01 1.626E-01 1.603E-01 1.579E-01 1.554E-01 1.527E-01 1.499E-01 1.469E-01 1.439E-01 1.407E-01 1.374E-01 1.339E-01 1.304E-01 1.267E-01 1.229E-01 1.190E-01 1.151E-01 1.110E-01 1.069E-01 1.027E-01 9.843E-02 9.412E-02 8.977E-02 8.540E-02 8.101E-02 7.661E-02 7.223E-02 6.786E-02 6.353E-02 5.925E-02 5.503E-02 5.088E-02 4.682E-02 4.286E-02 3.901E-02 3.529E-02 3.170E-02 2.826E-02 2.499E-02 2.188E-02 1.896E-02 1.622E-02 1.368E-02 1.134E-02 9.215E-03 7.304E-03 5.613E-03 4.143E-03 2.897E-03 1.875E-03 1.078E-03 5.017E-04 1.449E-04 3.098E-06 7.095E-05 3.421E-04 8.092E-04 1.464E-03 2.296E-03 3.296E-03 4.453E-03 5.754E-03 7.188E-03 8.739E-03 1.040E-02 1.214E-02 1.397E-02 1.585E-02 1.778E-02 1.974E-02 2.172E-02 2.370E-02 2.567E-02 2.761E-02 2.951E-02 3.136E-02 3.314E-02 3.484E-02 3.645E-02 3.796E-02 3.937E-02 4.065E-02 4.181E-02 4.283E-02 4.372E-02 4.446E-02 4.506E-02 4.551E-02 4.581E-02 4.595E-02 4.595E-02 4.580E-02 4.550E-02 4.507E-02 4.449E-02 4.378E-02 4.294E-02 4.199E-02 4.092E-02 3.975E-02 3.849E-02 3.713E-02 3.571E-02 3.421E-02 3.266E-02 3.106E-02 2.942E-02 2.776E-02 2.608E-02 2.439E-02 2.177E-02 2.344E-02 2.512E-02 2.680E-02 2.847E-02 3.011E-02 3.173E-02 3.330E-02 3.482E-02 3.629E-02 3.768E-02 3.899E-02 4.022E-02 4.134E-02 4.236E-02 4.327E-02 4.405E-02 4.471E-02 4.524E-02 4.562E-02 4.587E-02 4.597E-02 4.592E-02 4.573E-02 4.538E-02 4.489E-02 4.425E-02 4.347E-02 4.255E-02 4.150E-02 4.031E-02 3.901E-02 3.758E-02 3.606E-02 3.444E-02 3.273E-02 3.095E-02 2.910E-02 2.721E-02 2.528E-02 2.333E-02 2.136E-02 1.940E-02 1.747E-02 1.556E-02 1.370E-02 1.191E-02 1.019E-02 8.561E-03 7.039E-03 5.634E-03 4.359E-03 3.227E-03 2.248E-03 1.434E-03 7.941E-04 3.371E-04 7.095E-05 2.612E-06 1.379E-04 4.817E-04 1.038E-03 1.808E-03 2.795E-03 3.998E-03 5.417E-03 7.050E-03 8.893E-03 1.094E-02 1.319E-02 1.564E-02 1.828E-02 2.110E-02 2.408E-02 2.724E-02 3.054E-02 3.399E-02 3.757E-02 4.127E-02 4.507E-02 4.897E-02 5.296E-02 5.701E-02 6.112E-02 6.528E-02 6.947E-02 7.368E-02 7.790E-02 8.211E-02 8.631E-02 9.048E-02 9.462E-02 9.871E-02 1.027E-01 1.067E-01 1.106E-01 1.144E-01 1.181E-01 1.218E-01 1.253E-01 1.287E-01 1.320E-01 1.352E-01 1.383E-01 1.413E-01 1.441E-01 1.468E-01 1.494E-01 1.519E-01 1.542E-01 1.564E-01 1.585E-01 1.604E-01 1.622E-01 1.639E-01 1.655E-01 1.669E-01 1.682E-01 1.694E-01 1.705E-01 1.715E-01 1.723E-01 1.731E-01 1.737E-01 1.742E-01 1.746E-01 1.749E-01 1.750E-01 1.751E-01 1.750E-01 1.749E-01 1.746E-01 1.742E-01 1.737E-01 1.731E-01 1.723E-01 1.715E-01 1.705E-01 1.694E-01 1.682E-01 1.669E-01 1.655E-01 1.639E-01 1.622E-01 1.604E-01 1.585E-01 1.564E-01 1.542E-01 1.519E-01 1.494E-01 1.468E-01 1.441E-01 1.413E-01 1.383E-01 1.352E-01 1.320E-01 1.287E-01 1.253E-01 1.218E-01 1.181E-01 1.144E-01 1.106E-01 1.067E-01 1.027E-01 9.871E-02 9.462E-02 9.048E-02 8.631E-02 8.211E-02 7.790E-02 7.368E-02 6.947E-02 6.528E-02 6.112E-02 5.701E-02 5.296E-02 4.897E-02 4.507E-02 4.127E-02 3.757E-02 3.399E-02 3.054E-02 2.724E-02 2.408E-02 2.110E-02 1.828E-02 1.564E-02 1.319E-02 1.094E-02 8.893E-03 7.050E-03 5.417E-03 3.998E-03 2.795E-03 1.808E-03 1.038E-03 4.817E-04 1.379E-04 2.612E-06 7.095E-05 3.371E-04 7.941E-04 1.434E-03 2.248E-03 3.227E-03 4.359E-03 5.634E-03 7.039E-03 8.561E-03 1.019E-02 1.191E-02 1.370E-02 1.556E-02 1.747E-02 1.940E-02 2.136E-02 2.333E-02 2.528E-02 2.721E-02 2.910E-02 3.095E-02 3.273E-02 3.444E-02 3.606E-02 3.758E-02 3.901E-02 4.031E-02 4.150E-02 4.255E-02 4.347E-02 4.425E-02 4.489E-02 4.538E-02 4.573E-02 4.592E-02 4.597E-02 4.587E-02 4.562E-02 4.524E-02 4.471E-02 4.405E-02 4.327E-02 4.236E-02 4.134E-02 4.022E-02 3.899E-02 3.768E-02 3.629E-02 3.482E-02 3.330E-02 3.173E-02 3.011E-02 2.847E-02 2.680E-02 2.512E-02 2.344E-02 2.083E-02 2.249E-02 2.416E-02 2.583E-02 2.750E-02 2.915E-02 3.077E-02 3.237E-02 3.391E-02 3.541E-02 3.684E-02 3.819E-02 3.946E-02 4.065E-02 4.173E-02 4.270E-02 4.356E-02 4.430E-02 4.491E-02 4.538E-02 4.572E-02 4.592E-02 4.597E-02 4.588E-02 4.564E-02 4.525E-02 4.472E-02 4.405E-02 4.323E-02 4.228E-02 4.120E-02 3.999E-02 3.866E-02 3.723E-02 3.569E-02 3.406E-02 3.235E-02 3.057E-02 2.873E-02 2.685E-02 2.493E-02 2.299E-02 2.105E-02 1.911E-02 1.719E-02 1.531E-02 1.348E-02 1.171E-02 1.002E-02 8.424E-03 6.928E-03 5.548E-03 4.296E-03 3.185E-03 2.224E-03 1.424E-03 7.941E-04 3.421E-04 7.576E-05 1.402E-06 1.244E-04 4.492E-04 9.791E-04 1.716E-03 2.662E-03 3.816E-03 5.178E-03 6.745E-03 8.514E-03 1.048E-02 1.264E-02 1.499E-02 1.752E-02 2.022E-02 2.309E-02 2.611E-02 2.928E-02 3.259E-02 3.602E-02 3.956E-02 4.320E-02 4.694E-02 5.076E-02 5.464E-02 5.857E-02 6.255E-02 6.657E-02 7.060E-02 7.463E-02 7.867E-02 8.269E-02 8.668E-02 9.065E-02 9.456E-02 9.843E-02 1.022E-01 1.060E-01 1.096E-01 1.132E-01 1.167E-01 1.200E-01 1.233E-01 1.265E-01 1.296E-01 1.325E-01 1.354E-01 1.381E-01 1.407E-01 1.431E-01 1.455E-01 1.477E-01 1.498E-01 1.518E-01 1.537E-01 1.554E-01 1.570E-01 1.585E-01 1.598E-01 1.611E-01 1.622E-01 1.632E-01 1.640E-01 1.648E-01 1.654E-01 1.659E-01 1.663E-01 1.666E-01 1.668E-01 1.669E-01 1.668E-01 1.666E-01 1.663E-01 1.659E-01 1.654E-01 1.648E-01 1.640E-01 1.632E-01 1.622E-01 1.611E-01 1.598E-01 1.585E-01 1.570E-01 1.554E-01 1.537E-01 1.518E-01 1.498E-01 1.477E-01 1.455E-01 1.431E-01 1.407E-01 1.381E-01 1.354E-01 1.325E-01 1.296E-01 1.265E-01 1.233E-01 1.200E-01 1.167E-01 1.132E-01 1.096E-01 1.060E-01 1.022E-01 9.843E-02 9.456E-02 9.065E-02 8.668E-02 8.269E-02 7.867E-02 7.463E-02 7.060E-02 6.657E-02 6.255E-02 5.857E-02 5.464E-02 5.076E-02 4.694E-02 4.320E-02 3.956E-02 3.602E-02 3.259E-02 2.928E-02 2.611E-02 2.309E-02 2.022E-02 1.752E-02 1.499E-02 1.264E-02 1.048E-02 8.514E-03 6.745E-03 5.178E-03 3.816E-03 2.662E-03 1.716E-03 9.791E-04 4.492E-04 1.244E-04 1.402E-06 7.576E-05 3.421E-04 7.941E-04 1.424E-03 2.224E-03 3.185E-03 4.296E-03 5.548E-03 6.928E-03 8.424E-03 1.002E-02 1.171E-02 1.348E-02 1.531E-02 1.719E-02 1.911E-02 2.105E-02 2.299E-02 2.493E-02 2.685E-02 2.873E-02 3.057E-02 3.235E-02 3.406E-02 3.569E-02 3.723E-02 3.866E-02 3.999E-02 4.120E-02 4.228E-02 4.323E-02 4.405E-02 4.472E-02 4.525E-02 4.564E-02 4.588E-02 4.597E-02 4.592E-02 4.572E-02 4.538E-02 4.491E-02 4.430E-02 4.356E-02 4.270E-02 4.173E-02 4.065E-02 3.946E-02 3.819E-02 3.684E-02 3.541E-02 3.391E-02 3.237E-02 3.077E-02 2.915E-02 2.750E-02 2.583E-02 2.416E-02 2.249E-02 1.989E-02 2.153E-02 2.318E-02 2.485E-02 2.651E-02 2.816E-02 2.980E-02 3.141E-02 3.297E-02 3.449E-02 3.596E-02 3.735E-02 3.867E-02 3.990E-02 4.104E-02 4.208E-02 4.301E-02 4.382E-02 4.451E-02 4.508E-02 4.551E-02 4.580E-02 4.595E-02 4.596E-02 4.582E-02 4.554E-02 4.512E-02 4.455E-02 4.384E-02 4.300E-02 4.202E-02 4.091E-02 3.969E-02 3.834E-02 3.690E-02 3.535E-02 3.372E-02 3.201E-02 3.023E-02 2.840E-02 2.653E-02 2.462E-02 2.270E-02 2.078E-02 1.886E-02 1.697E-02 1.511E-02 1.331E-02 1.156E-02 9.900E-03 8.326E-03 6.854E-03 5.496E-03 4.265E-03 3.171E-03 2.224E-03 1.434E-03 8.092E-04 3.575E-04 8.587E-05 2.162E-07 1.055E-04 4.058E-04 9.039E-04 1.602E-03 2.501E-03 3.600E-03 4.898E-03 6.394E-03 8.084E-03 9.965E-03 1.203E-02 1.427E-02 1.669E-02 1.927E-02 2.201E-02 2.490E-02 2.793E-02 3.109E-02 3.436E-02 3.775E-02 4.123E-02 4.480E-02 4.844E-02 5.215E-02 5.591E-02 5.971E-02 6.353E-02 6.738E-02 7.124E-02 7.509E-02 7.893E-02 8.274E-02 8.652E-02 9.026E-02 9.395E-02 9.758E-02 1.011E-01 1.046E-01 1.080E-01 1.114E-01 1.146E-01 1.177E-01 1.208E-01 1.237E-01 1.265E-01 1.292E-01 1.318E-01 1.343E-01 1.366E-01 1.389E-01 1.410E-01 1.430E-01 1.448E-01 1.466E-01 1.482E-01 1.497E-01 1.511E-01 1.523E-01 1.535E-01 1.545E-01 1.554E-01 1.562E-01 1.568E-01 1.573E-01 1.578E-01 1.580E-01 1.582E-01 1.583E-01 1.582E-01 1.580E-01 1.578E-01 1.573E-01 1.568E-01 1.562E-01 1.554E-01 1.545E-01 1.535E-01 1.523E-01 1.511E-01 1.497E-01 1.482E-01 1.466E-01 1.448E-01 1.430E-01 1.410E-01 1.389E-01 1.366E-01 1.343E-01 1.318E-01 1.292E-01 1.265E-01 1.237E-01 1.208E-01 1.177E-01 1.146E-01 1.114E-01 1.080E-01 1.046E-01 1.011E-01 9.758E-02 9.395E-02 9.026E-02 8.652E-02 8.274E-02 7.893E-02 7.509E-02 7.124E-02 6.738E-02 6.353E-02 5.971E-02 5.591E-02 5.215E-02 4.844E-02 4.480E-02 4.123E-02 3.775E-02 3.436E-02 3.109E-02 2.793E-02 2.490E-02 2.201E-02 1.927E-02 1.669E-02 1.427E-02 1.203E-02 9.965E-03 8.084E-03 6.394E-03 4.898E-03 3.600E-03 2.501E-03 1.602E-03 9.039E-04 4.058E-04 1.055E-04 2.162E-07 8.587E-05 3.575E-04 8.092E-04 1.434E-03 2.224E-03 3.171E-03 4.265E-03 5.496E-03 6.854E-03 8.326E-03 9.900E-03 1.156E-02 1.331E-02 1.511E-02 1.697E-02 1.886E-02 2.078E-02 2.270E-02 2.462E-02 2.653E-02 2.840E-02 3.023E-02 3.201E-02 3.372E-02 3.535E-02 3.690E-02 3.834E-02 3.969E-02 4.091E-02 4.202E-02 4.300E-02 4.384E-02 4.455E-02 4.512E-02 4.554E-02 4.582E-02 4.596E-02 4.595E-02 4.580E-02 4.551E-02 4.508E-02 4.451E-02 4.382E-02 4.301E-02 4.208E-02 4.104E-02 3.990E-02 3.867E-02 3.735E-02 3.596E-02 3.449E-02 3.297E-02 3.141E-02 2.980E-02 2.816E-02 2.651E-02 2.485E-02 2.318E-02 2.153E-02 1.896E-02 2.057E-02 2.221E-02 2.386E-02 2.551E-02 2.717E-02 2.881E-02 3.042E-02 3.201E-02 3.355E-02 3.504E-02 3.647E-02 3.783E-02 3.912E-02 4.031E-02 4.141E-02 4.241E-02 4.329E-02 4.406E-02 4.471E-02 4.523E-02 4.561E-02 4.586E-02 4.597E-02 4.593E-02 4.576E-02 4.544E-02 4.498E-02 4.438E-02 4.364E-02 4.277E-02 4.177E-02 4.064E-02 3.940E-02 3.805E-02 3.659E-02 3.504E-02 3.341E-02 3.170E-02 2.993E-02 2.811E-02 2.625E-02 2.436E-02 2.245E-02 2.055E-02 1.866E-02 1.679E-02 1.496E-02 1.317E-02 1.146E-02 9.818E-03 8.267E-03 6.817E-03 5.479E-03 4.265E-03 3.185E-03 2.248E-03 1.464E-03 8.399E-04 3.839E-04 1.022E-04 2.914E-07 8.280E-05 3.533E-04 8.144E-04 1.468E-03 2.314E-03 3.353E-03 4.583E-03 6.003E-03 7.608E-03 9.396E-03 1.136E-02 1.350E-02 1.580E-02 1.825E-02 2.086E-02 2.361E-02 2.650E-02 2.950E-02 3.262E-02 3.584E-02 3.916E-02 4.255E-02 4.602E-02 4.955E-02 5.313E-02 5.674E-02 6.039E-02 6.405E-02 6.772E-02 7.139E-02 7.504E-02 7.867E-02 8.227E-02 8.583E-02 8.934E-02 9.279E-02 9.618E-02 9.950E-02 1.027E-01 1.059E-01 1.090E-01 1.120E-01 1.148E-01 1.176E-01 1.203E-01 1.228E-01 1.253E-01 1.276E-01 1.299E-01 1.320E-01 1.340E-01 1.358E-01 1.376E-01 1.392E-01 1.407E-01 1.421E-01 1.434E-01 1.445E-01 1.456E-01 1.465E-01 1.472E-01 1.479E-01 1.484E-01 1.489E-01 1.492E-01 1.493E-01 1.494E-01 1.493E-01 1.492E-01 1.489E-01 1.484E-01 1.479E-01 1.472E-01 1.465E-01 1.456E-01 1.445E-01 1.434E-01 1.421E-01 1.407E-01 1.392E-01 1.376E-01 1.358E-01 1.340E-01 1.320E-01 1.299E-01 1.276E-01 1.253E-01 1.228E-01 1.203E-01 1.176E-01 1.148E-01 1.120E-01 1.090E-01 1.059E-01 1.027E-01 9.950E-02 9.618E-02 9.279E-02 8.934E-02 8.583E-02 8.227E-02 7.867E-02 7.504E-02 7.139E-02 6.772E-02 6.405E-02 6.039E-02 5.674E-02 5.313E-02 4.955E-02 4.602E-02 4.255E-02 3.916E-02 3.584E-02 3.262E-02 2.950E-02 2.650E-02 2.361E-02 2.086E-02 1.825E-02 1.580E-02 1.350E-02 1.136E-02 9.396E-03 7.608E-03 6.003E-03 4.583E-03 3.353E-03 2.314E-03 1.468E-03 8.144E-04 3.533E-04 8.280E-05 2.914E-07 1.022E-04 3.839E-04 8.399E-04 1.464E-03 2.248E-03 3.185E-03 4.265E-03 5.479E-03 6.817E-03 8.267E-03 9.818E-03 1.146E-02 1.317E-02 1.496E-02 1.679E-02 1.866E-02 2.055E-02 2.245E-02 2.436E-02 2.625E-02 2.811E-02 2.993E-02 3.170E-02 3.341E-02 3.504E-02 3.659E-02 3.805E-02 3.940E-02 4.064E-02 4.177E-02 4.277E-02 4.364E-02 4.438E-02 4.498E-02 4.544E-02 4.576E-02 4.593E-02 4.597E-02 4.586E-02 4.561E-02 4.523E-02 4.471E-02 4.406E-02 4.329E-02 4.241E-02 4.141E-02 4.031E-02 3.912E-02 3.783E-02 3.647E-02 3.504E-02 3.355E-02 3.201E-02 3.042E-02 2.881E-02 2.717E-02 2.551E-02 2.386E-02 2.221E-02 2.057E-02 1.802E-02 1.961E-02 2.123E-02 2.286E-02 2.451E-02 2.616E-02 2.780E-02 2.942E-02 3.102E-02 3.258E-02 3.410E-02 3.556E-02 3.696E-02 3.829E-02 3.953E-02 4.069E-02 4.175E-02 4.270E-02 4.355E-02 4.428E-02 4.488E-02 4.535E-02 4.570E-02 4.590E-02 4.597E-02 4.590E-02 4.569E-02 4.534E-02 4.485E-02 4.422E-02 4.345E-02 4.256E-02 4.154E-02 4.039E-02 3.914E-02 3.778E-02 3.631E-02 3.476E-02 3.313E-02 3.143E-02 2.967E-02 2.786E-02 2.601E-02 2.414E-02 2.225E-02 2.037E-02 1.850E-02 1.665E-02 1.484E-02 1.309E-02 1.139E-02 9.777E-03 8.248E-03 6.817E-03 5.496E-03 4.296E-03 3.227E-03 2.296E-03 1.514E-03 8.868E-04 4.223E-04 1.261E-04 3.342E-06 5.831E-05 2.943E-04 7.135E-04 1.317E-03 2.107E-03 3.080E-03 4.237E-03 5.576E-03 7.092E-03 8.782E-03 1.064E-02 1.266E-02 1.484E-02 1.717E-02 1.965E-02 2.225E-02 2.499E-02 2.784E-02 3.080E-02 3.385E-02 3.700E-02 4.022E-02 4.351E-02 4.686E-02 5.025E-02 5.369E-02 5.714E-02 6.062E-02 6.410E-02 6.757E-02 7.104E-02 7.448E-02 7.790E-02 8.127E-02 8.460E-02 8.787E-02 9.108E-02 9.423E-02 9.730E-02 1.003E-01 1.032E-01 1.060E-01 1.087E-01 1.114E-01 1.139E-01 1.163E-01 1.186E-01 1.208E-01 1.229E-01 1.249E-01 1.267E-01 1.285E-01 1.301E-01 1.316E-01 1.330E-01 1.343E-01 1.354E-01 1.364E-01 1.374E-01 1.381E-01 1.388E-01 1.393E-01 1.398E-01 1.401E-01 1.402E-01 1.403E-01 1.402E-01 1.401E-01 1.398E-01 1.393E-01 1.388E-01 1.381E-01 1.374E-01 1.364E-01 1.354E-01 1.343E-01 1.330E-01 1.316E-01 1.301E-01 1.285E-01 1.267E-01 1.249E-01 1.229E-01 1.208E-01 1.186E-01 1.163E-01 1.139E-01 1.114E-01 1.087E-01 1.060E-01 1.032E-01 1.003E-01 9.730E-02 9.423E-02 9.108E-02 8.787E-02 8.460E-02 8.127E-02 7.790E-02 7.448E-02 7.104E-02 6.757E-02 6.410E-02 6.062E-02 5.714E-02 5.369E-02 5.025E-02 4.686E-02 4.351E-02 4.022E-02 3.700E-02 3.385E-02 3.080E-02 2.784E-02 2.499E-02 2.225E-02 1.965E-02 1.717E-02 1.484E-02 1.266E-02 1.064E-02 8.782E-03 7.092E-03 5.576E-03 4.237E-03 3.080E-03 2.107E-03 1.317E-03 7.135E-04 2.943E-04 5.831E-05 3.342E-06 1.261E-04 4.223E-04 8.868E-04 1.514E-03 2.296E-03 3.227E-03 4.296E-03 5.496E-03 6.817E-03 8.248E-03 9.777E-03 1.139E-02 1.309E-02 1.484E-02 1.665E-02 1.850E-02 2.037E-02 2.225E-02 2.414E-02 2.601E-02 2.786E-02 2.967E-02 3.143E-02 3.313E-02 3.476E-02 3.631E-02 3.778E-02 3.914E-02 4.039E-02 4.154E-02 4.256E-02 4.345E-02 4.422E-02 4.485E-02 4.534E-02 4.569E-02 4.590E-02 4.597E-02 4.590E-02 4.570E-02 4.535E-02 4.488E-02 4.428E-02 4.355E-02 4.270E-02 4.175E-02 4.069E-02 3.953E-02 3.829E-02 3.696E-02 3.556E-02 3.410E-02 3.258E-02 3.102E-02 2.942E-02 2.780E-02 2.616E-02 2.451E-02 2.286E-02 2.123E-02 1.961E-02 1.709E-02 1.865E-02 2.024E-02 2.186E-02 2.349E-02 2.513E-02 2.677E-02 2.840E-02 3.001E-02 3.158E-02 3.312E-02 3.461E-02 3.605E-02 3.741E-02 3.871E-02 3.992E-02 4.104E-02 4.206E-02 4.298E-02 4.378E-02 4.447E-02 4.503E-02 4.546E-02 4.577E-02 4.593E-02 4.597E-02 4.586E-02 4.562E-02 4.523E-02 4.471E-02 4.406E-02 4.327E-02 4.236E-02 4.132E-02 4.016E-02 3.890E-02 3.753E-02 3.607E-02 3.452E-02 3.289E-02 3.119E-02 2.944E-02 2.765E-02 2.581E-02 2.396E-02 2.210E-02 2.023E-02 1.838E-02 1.656E-02 1.478E-02 1.304E-02 1.137E-02 9.777E-03 8.267E-03 6.854E-03 5.548E-03 4.359E-03 3.296E-03 2.369E-03 1.585E-03 9.513E-04 4.741E-04 1.593E-04 1.154E-05 3.466E-05 2.316E-04 6.046E-04 1.155E-03 1.882E-03 2.786E-03 3.866E-03 5.119E-03 6.541E-03 8.130E-03 9.880E-03 1.179E-02 1.384E-02 1.604E-02 1.837E-02 2.084E-02 2.342E-02 2.611E-02 2.891E-02 3.180E-02 3.477E-02 3.782E-02 4.093E-02 4.409E-02 4.730E-02 5.055E-02 5.382E-02 5.710E-02 6.039E-02 6.367E-02 6.695E-02 7.020E-02 7.343E-02 7.661E-02 7.976E-02 8.285E-02 8.588E-02 8.885E-02 9.174E-02 9.456E-02 9.730E-02 9.995E-02 1.025E-01 1.050E-01 1.073E-01 1.096E-01 1.118E-01 1.138E-01 1.158E-01 1.176E-01 1.193E-01 1.209E-01 1.224E-01 1.238E-01 1.251E-01 1.262E-01 1.272E-01 1.281E-01 1.289E-01 1.296E-01 1.301E-01 1.305E-01 1.308E-01 1.310E-01 1.311E-01 1.310E-01 1.308E-01 1.305E-01 1.301E-01 1.296E-01 1.289E-01 1.281E-01 1.272E-01 1.262E-01 1.251E-01 1.238E-01 1.224E-01 1.209E-01 1.193E-01 1.176E-01 1.158E-01 1.138E-01 1.118E-01 1.096E-01 1.073E-01 1.050E-01 1.025E-01 9.995E-02 9.730E-02 9.456E-02 9.174E-02 8.885E-02 8.588E-02 8.285E-02 7.976E-02 7.661E-02 7.343E-02 7.020E-02 6.695E-02 6.367E-02 6.039E-02 5.710E-02 5.382E-02 5.055E-02 4.730E-02 4.409E-02 4.093E-02 3.782E-02 3.477E-02 3.180E-02 2.891E-02 2.611E-02 2.342E-02 2.084E-02 1.837E-02 1.604E-02 1.384E-02 1.179E-02 9.880E-03 8.130E-03 6.541E-03 5.119E-03 3.866E-03 2.786E-03 1.882E-03 1.155E-03 6.046E-04 2.316E-04 3.466E-05 1.154E-05 1.593E-04 4.741E-04 9.513E-04 1.585E-03 2.369E-03 3.296E-03 4.359E-03 5.548E-03 6.854E-03 8.267E-03 9.777E-03 1.137E-02 1.304E-02 1.478E-02 1.656E-02 1.838E-02 2.023E-02 2.210E-02 2.396E-02 2.581E-02 2.765E-02 2.944E-02 3.119E-02 3.289E-02 3.452E-02 3.607E-02 3.753E-02 3.890E-02 4.016E-02 4.132E-02 4.236E-02 4.327E-02 4.406E-02 4.471E-02 4.523E-02 4.562E-02 4.586E-02 4.597E-02 4.593E-02 4.577E-02 4.546E-02 4.503E-02 4.447E-02 4.378E-02 4.298E-02 4.206E-02 4.104E-02 3.992E-02 3.871E-02 3.741E-02 3.605E-02 3.461E-02 3.312E-02 3.158E-02 3.001E-02 2.840E-02 2.677E-02 2.513E-02 2.349E-02 2.186E-02 2.024E-02 1.865E-02 1.616E-02 1.769E-02 1.926E-02 2.086E-02 2.247E-02 2.410E-02 2.573E-02 2.736E-02 2.897E-02 3.056E-02 3.212E-02 3.363E-02 3.510E-02 3.650E-02 3.784E-02 3.910E-02 4.028E-02 4.136E-02 4.234E-02 4.322E-02 4.399E-02 4.463E-02 4.516E-02 4.556E-02 4.582E-02 4.596E-02 4.595E-02 4.582E-02 4.554E-02 4.513E-02 4.458E-02 4.391E-02 4.310E-02 4.217E-02 4.112E-02 3.996E-02 3.869E-02 3.731E-02 3.585E-02 3.430E-02 3.268E-02 3.100E-02 2.926E-02 2.748E-02 2.566E-02 2.383E-02 2.198E-02 2.014E-02 1.832E-02 1.652E-02 1.475E-02 1.304E-02 1.139E-02 9.818E-03 8.326E-03 6.928E-03 5.634E-03 4.453E-03 3.395E-03 2.468E-03 1.679E-03 1.035E-03 5.414E-04 2.042E-04 2.751E-05 1.486E-05 1.690E-04 4.916E-04 9.839E-04 1.646E-03 2.477E-03 3.475E-03 4.639E-03 5.964E-03 7.448E-03 9.086E-03 1.087E-02 1.280E-02 1.486E-02 1.706E-02 1.937E-02 2.180E-02 2.434E-02 2.697E-02 2.969E-02 3.249E-02 3.536E-02 3.829E-02 4.127E-02 4.429E-02 4.734E-02 5.042E-02 5.351E-02 5.661E-02 5.971E-02 6.279E-02 6.585E-02 6.888E-02 7.188E-02 7.484E-02 7.774E-02 8.059E-02 8.338E-02 8.609E-02 8.874E-02 9.130E-02 9.379E-02 9.618E-02 9.848E-02 1.007E-01 1.028E-01 1.048E-01 1.067E-01 1.085E-01 1.102E-01 1.118E-01 1.132E-01 1.146E-01 1.158E-01 1.170E-01 1.180E-01 1.189E-01 1.196E-01 1.203E-01 1.208E-01 1.212E-01 1.215E-01 1.217E-01 1.218E-01 1.217E-01 1.215E-01 1.212E-01 1.208E-01 1.203E-01 1.196E-01 1.189E-01 1.180E-01 1.170E-01 1.158E-01 1.146E-01 1.132E-01 1.118E-01 1.102E-01 1.085E-01 1.067E-01 1.048E-01 1.028E-01 1.007E-01 9.848E-02 9.618E-02 9.379E-02 9.130E-02 8.874E-02 8.609E-02 8.338E-02 8.059E-02 7.774E-02 7.484E-02 7.188E-02 6.888E-02 6.585E-02 6.279E-02 5.971E-02 5.661E-02 5.351E-02 5.042E-02 4.734E-02 4.429E-02 4.127E-02 3.829E-02 3.536E-02 3.249E-02 2.969E-02 2.697E-02 2.434E-02 2.180E-02 1.937E-02 1.706E-02 1.486E-02 1.280E-02 1.087E-02 9.086E-03 7.448E-03 5.964E-03 4.639E-03 3.475E-03 2.477E-03 1.646E-03 9.839E-04 4.916E-04 1.690E-04 1.486E-05 2.751E-05 2.042E-04 5.414E-04 1.035E-03 1.679E-03 2.468E-03 3.395E-03 4.453E-03 5.634E-03 6.928E-03 8.326E-03 9.818E-03 1.139E-02 1.304E-02 1.475E-02 1.652E-02 1.832E-02 2.014E-02 2.198E-02 2.383E-02 2.566E-02 2.748E-02 2.926E-02 3.100E-02 3.268E-02 3.430E-02 3.585E-02 3.731E-02 3.869E-02 3.996E-02 4.112E-02 4.217E-02 4.310E-02 4.391E-02 4.458E-02 4.513E-02 4.554E-02 4.582E-02 4.595E-02 4.596E-02 4.582E-02 4.556E-02 4.516E-02 4.463E-02 4.399E-02 4.322E-02 4.234E-02 4.136E-02 4.028E-02 3.910E-02 3.784E-02 3.650E-02 3.510E-02 3.363E-02 3.212E-02 3.056E-02 2.897E-02 2.736E-02 2.573E-02 2.410E-02 2.247E-02 2.086E-02 1.926E-02 1.769E-02 1.525E-02 1.674E-02 1.828E-02 1.986E-02 2.145E-02 2.307E-02 2.469E-02 2.631E-02 2.792E-02 2.952E-02 3.109E-02 3.262E-02 3.412E-02 3.555E-02 3.693E-02 3.824E-02 3.946E-02 4.061E-02 4.165E-02 4.260E-02 4.344E-02 4.417E-02 4.478E-02 4.527E-02 4.563E-02 4.587E-02 4.597E-02 4.593E-02 4.577E-02 4.547E-02 4.503E-02 4.446E-02 4.377E-02 4.295E-02 4.200E-02 4.094E-02 3.977E-02 3.850E-02 3.713E-02 3.567E-02 3.413E-02 3.251E-02 3.084E-02 2.911E-02 2.735E-02 2.555E-02 2.374E-02 2.192E-02 2.010E-02 1.829E-02 1.652E-02 1.478E-02 1.309E-02 1.146E-02 9.900E-03 8.424E-03 7.039E-03 5.754E-03 4.580E-03 3.524E-03 2.594E-03 1.797E-03 1.139E-03 6.262E-04 2.633E-04 5.426E-05 2.384E-06 1.101E-04 3.791E-04 8.101E-04 1.403E-03 2.157E-03 3.071E-03 4.143E-03 5.369E-03 6.745E-03 8.267E-03 9.931E-03 1.173E-02 1.366E-02 1.571E-02 1.787E-02 2.015E-02 2.252E-02 2.499E-02 2.754E-02 3.016E-02 3.285E-02 3.560E-02 3.839E-02 4.123E-02 4.409E-02 4.698E-02 4.988E-02 5.279E-02 5.569E-02 5.857E-02 6.144E-02 6.429E-02 6.709E-02 6.986E-02 7.258E-02 7.524E-02 7.784E-02 8.038E-02 8.285E-02 8.524E-02 8.755E-02 8.977E-02 9.191E-02 9.395E-02 9.590E-02 9.775E-02 9.950E-02 1.011E-01 1.027E-01 1.041E-01 1.054E-01 1.067E-01 1.078E-01 1.087E-01 1.096E-01 1.104E-01 1.110E-01 1.115E-01 1.120E-01 1.122E-01 1.124E-01 1.125E-01 1.124E-01 1.122E-01 1.120E-01 1.115E-01 1.110E-01 1.104E-01 1.096E-01 1.087E-01 1.078E-01 1.067E-01 1.054E-01 1.041E-01 1.027E-01 1.011E-01 9.950E-02 9.775E-02 9.590E-02 9.395E-02 9.191E-02 8.977E-02 8.755E-02 8.524E-02 8.285E-02 8.038E-02 7.784E-02 7.524E-02 7.258E-02 6.986E-02 6.709E-02 6.429E-02 6.144E-02 5.857E-02 5.569E-02 5.279E-02 4.988E-02 4.698E-02 4.409E-02 4.123E-02 3.839E-02 3.560E-02 3.285E-02 3.016E-02 2.754E-02 2.499E-02 2.252E-02 2.015E-02 1.787E-02 1.571E-02 1.366E-02 1.173E-02 9.931E-03 8.267E-03 6.745E-03 5.369E-03 4.143E-03 3.071E-03 2.157E-03 1.403E-03 8.101E-04 3.791E-04 1.101E-04 2.384E-06 5.426E-05 2.633E-04 6.262E-04 1.139E-03 1.797E-03 2.594E-03 3.524E-03 4.580E-03 5.754E-03 7.039E-03 8.424E-03 9.900E-03 1.146E-02 1.309E-02 1.478E-02 1.652E-02 1.829E-02 2.010E-02 2.192E-02 2.374E-02 2.555E-02 2.735E-02 2.911E-02 3.084E-02 3.251E-02 3.413E-02 3.567E-02 3.713E-02 3.850E-02 3.977E-02 4.094E-02 4.200E-02 4.295E-02 4.377E-02 4.446E-02 4.503E-02 4.547E-02 4.577E-02 4.593E-02 4.597E-02 4.587E-02 4.563E-02 4.527E-02 4.478E-02 4.417E-02 4.344E-02 4.260E-02 4.165E-02 4.061E-02 3.946E-02 3.824E-02 3.693E-02 3.555E-02 3.412E-02 3.262E-02 3.109E-02 2.952E-02 2.792E-02 2.631E-02 2.469E-02 2.307E-02 2.145E-02 1.986E-02 1.828E-02 1.674E-02 1.434E-02 1.580E-02 1.731E-02 1.886E-02 2.043E-02 2.202E-02 2.363E-02 2.525E-02 2.686E-02 2.846E-02 3.004E-02 3.159E-02 3.310E-02 3.457E-02 3.598E-02 3.733E-02 3.860E-02 3.980E-02 4.091E-02 4.192E-02 4.284E-02 4.364E-02 4.434E-02 4.492E-02 4.537E-02 4.570E-02 4.590E-02 4.597E-02 4.591E-02 4.572E-02 4.539E-02 4.494E-02 4.435E-02 4.364E-02 4.280E-02 4.185E-02 4.079E-02 3.961E-02 3.834E-02 3.697E-02 3.551E-02 3.398E-02 3.238E-02 3.072E-02 2.901E-02 2.726E-02 2.549E-02 2.369E-02 2.189E-02 2.010E-02 1.832E-02 1.656E-02 1.484E-02 1.317E-02 1.156E-02 1.002E-02 8.561E-03 7.188E-03 5.911E-03 4.741E-03 3.684E-03 2.748E-03 1.940E-03 1.266E-03 7.312E-04 3.396E-04 9.521E-05 1.084E-06 5.944E-05 2.717E-04 6.386E-04 1.160E-03 1.835E-03 2.662E-03 3.639E-03 4.762E-03 6.028E-03 7.434E-03 8.973E-03 1.064E-02 1.243E-02 1.434E-02 1.635E-02 1.847E-02 2.068E-02 2.298E-02 2.536E-02 2.781E-02 3.032E-02 3.288E-02 3.549E-02 3.814E-02 4.082E-02 4.351E-02 4.622E-02 4.893E-02 5.164E-02 5.433E-02 5.701E-02 5.966E-02 6.228E-02 6.485E-02 6.738E-02 6.986E-02 7.228E-02 7.463E-02 7.692E-02 7.913E-02 8.127E-02 8.332E-02 8.529E-02 8.717E-02 8.896E-02 9.065E-02 9.224E-02 9.373E-02 9.512E-02 9.640E-02 9.758E-02 9.865E-02 9.961E-02 1.005E-01 1.012E-01 1.018E-01 1.023E-01 1.027E-01 1.030E-01 1.032E-01 1.033E-01 1.032E-01 1.030E-01 1.027E-01 1.023E-01 1.018E-01 1.012E-01 1.005E-01 9.961E-02 9.865E-02 9.758E-02 9.640E-02 9.512E-02 9.373E-02 9.224E-02 9.065E-02 8.896E-02 8.717E-02 8.529E-02 8.332E-02 8.127E-02 7.913E-02 7.692E-02 7.463E-02 7.228E-02 6.986E-02 6.738E-02 6.485E-02 6.228E-02 5.966E-02 5.701E-02 5.433E-02 5.164E-02 4.893E-02 4.622E-02 4.351E-02 4.082E-02 3.814E-02 3.549E-02 3.288E-02 3.032E-02 2.781E-02 2.536E-02 2.298E-02 2.068E-02 1.847E-02 1.635E-02 1.434E-02 1.243E-02 1.064E-02 8.973E-03 7.434E-03 6.028E-03 4.762E-03 3.639E-03 2.662E-03 1.835E-03 1.160E-03 6.386E-04 2.717E-04 5.944E-05 1.084E-06 9.521E-05 3.396E-04 7.312E-04 1.266E-03 1.940E-03 2.748E-03 3.684E-03 4.741E-03 5.911E-03 7.188E-03 8.561E-03 1.002E-02 1.156E-02 1.317E-02 1.484E-02 1.656E-02 1.832E-02 2.010E-02 2.189E-02 2.369E-02 2.549E-02 2.726E-02 2.901E-02 3.072E-02 3.238E-02 3.398E-02 3.551E-02 3.697E-02 3.834E-02 3.961E-02 4.079E-02 4.185E-02 4.280E-02 4.364E-02 4.435E-02 4.494E-02 4.539E-02 4.572E-02 4.591E-02 4.597E-02 4.590E-02 4.570E-02 4.537E-02 4.492E-02 4.434E-02 4.364E-02 4.284E-02 4.192E-02 4.091E-02 3.980E-02 3.860E-02 3.733E-02 3.598E-02 3.457E-02 3.310E-02 3.159E-02 3.004E-02 2.846E-02 2.686E-02 2.525E-02 2.363E-02 2.202E-02 2.043E-02 1.886E-02 1.731E-02 1.580E-02 1.344E-02 1.487E-02 1.635E-02 1.786E-02 1.941E-02 2.098E-02 2.257E-02 2.418E-02 2.578E-02 2.738E-02 2.897E-02 3.053E-02 3.206E-02 3.355E-02 3.499E-02 3.638E-02 3.770E-02 3.894E-02 4.011E-02 4.119E-02 4.217E-02 4.305E-02 4.382E-02 4.449E-02 4.503E-02 4.545E-02 4.575E-02 4.593E-02 4.597E-02 4.588E-02 4.567E-02 4.532E-02 4.485E-02 4.425E-02 4.352E-02 4.268E-02 4.172E-02 4.065E-02 3.948E-02 3.820E-02 3.684E-02 3.539E-02 3.387E-02 3.229E-02 3.064E-02 2.895E-02 2.722E-02 2.547E-02 2.369E-02 2.192E-02 2.014E-02 1.838E-02 1.665E-02 1.496E-02 1.331E-02 1.171E-02 1.019E-02 8.739E-03 7.375E-03 6.105E-03 4.936E-03 3.877E-03 2.933E-03 2.112E-03 1.419E-03 8.593E-04 4.364E-04 1.541E-04 1.518E-05 2.164E-05 1.748E-04 4.751E-04 9.224E-04 1.516E-03 2.254E-03 3.134E-03 4.153E-03 5.308E-03 6.595E-03 8.009E-03 9.544E-03 1.120E-02 1.296E-02 1.482E-02 1.678E-02 1.883E-02 2.097E-02 2.317E-02 2.545E-02 2.778E-02 3.016E-02 3.259E-02 3.505E-02 3.753E-02 4.004E-02 4.255E-02 4.507E-02 4.759E-02 5.009E-02 5.257E-02 5.503E-02 5.745E-02 5.984E-02 6.218E-02 6.447E-02 6.671E-02 6.888E-02 7.099E-02 7.303E-02 7.499E-02 7.687E-02 7.867E-02 8.038E-02 8.200E-02 8.353E-02 8.497E-02 8.631E-02 8.755E-02 8.868E-02 8.972E-02 9.065E-02 9.147E-02 9.218E-02 9.279E-02 9.329E-02 9.367E-02 9.395E-02 9.412E-02 9.417E-02 9.412E-02 9.395E-02 9.367E-02 9.329E-02 9.279E-02 9.218E-02 9.147E-02 9.065E-02 8.972E-02 8.868E-02 8.755E-02 8.631E-02 8.497E-02 8.353E-02 8.200E-02 8.038E-02 7.867E-02 7.687E-02 7.499E-02 7.303E-02 7.099E-02 6.888E-02 6.671E-02 6.447E-02 6.218E-02 5.984E-02 5.745E-02 5.503E-02 5.257E-02 5.009E-02 4.759E-02 4.507E-02 4.255E-02 4.004E-02 3.753E-02 3.505E-02 3.259E-02 3.016E-02 2.778E-02 2.545E-02 2.317E-02 2.097E-02 1.883E-02 1.678E-02 1.482E-02 1.296E-02 1.120E-02 9.544E-03 8.009E-03 6.595E-03 5.308E-03 4.153E-03 3.134E-03 2.254E-03 1.516E-03 9.224E-04 4.751E-04 1.748E-04 2.164E-05 1.518E-05 1.541E-04 4.364E-04 8.593E-04 1.419E-03 2.112E-03 2.933E-03 3.877E-03 4.936E-03 6.105E-03 7.375E-03 8.739E-03 1.019E-02 1.171E-02 1.331E-02 1.496E-02 1.665E-02 1.838E-02 2.014E-02 2.192E-02 2.369E-02 2.547E-02 2.722E-02 2.895E-02 3.064E-02 3.229E-02 3.387E-02 3.539E-02 3.684E-02 3.820E-02 3.948E-02 4.065E-02 4.172E-02 4.268E-02 4.352E-02 4.425E-02 4.485E-02 4.532E-02 4.567E-02 4.588E-02 4.597E-02 4.593E-02 4.575E-02 4.545E-02 4.503E-02 4.449E-02 4.382E-02 4.305E-02 4.217E-02 4.119E-02 4.011E-02 3.894E-02 3.770E-02 3.638E-02 3.499E-02 3.355E-02 3.206E-02 3.053E-02 2.897E-02 2.738E-02 2.578E-02 2.418E-02 2.257E-02 2.098E-02 1.941E-02 1.786E-02 1.635E-02 1.487E-02 1.257E-02 1.395E-02 1.539E-02 1.687E-02 1.839E-02 1.994E-02 2.151E-02 2.310E-02 2.469E-02 2.629E-02 2.788E-02 2.945E-02 3.099E-02 3.250E-02 3.397E-02 3.539E-02 3.675E-02 3.804E-02 3.926E-02 4.039E-02 4.144E-02 4.239E-02 4.324E-02 4.398E-02 4.462E-02 4.513E-02 4.553E-02 4.580E-02 4.594E-02 4.596E-02 4.586E-02 4.562E-02 4.526E-02 4.477E-02 4.416E-02 4.342E-02 4.257E-02 4.161E-02 4.054E-02 3.937E-02 3.810E-02 3.674E-02 3.531E-02 3.380E-02 3.223E-02 3.060E-02 2.893E-02 2.722E-02 2.549E-02 2.374E-02 2.198E-02 2.023E-02 1.850E-02 1.679E-02 1.511E-02 1.348E-02 1.191E-02 1.040E-02 8.958E-03 7.602E-03 6.336E-03 5.168E-03 4.103E-03 3.150E-03 2.314E-03 1.601E-03 1.014E-03 5.573E-04 2.350E-04 4.919E-05 1.764E-06 9.381E-05 3.258E-04 6.974E-04 1.208E-03 1.855E-03 2.637E-03 3.552E-03 4.594E-03 5.762E-03 7.050E-03 8.452E-03 9.965E-03 1.158E-02 1.329E-02 1.510E-02 1.699E-02 1.896E-02 2.099E-02 2.309E-02 2.525E-02 2.745E-02 2.969E-02 3.196E-02 3.426E-02 3.658E-02 3.890E-02 4.123E-02 4.355E-02 4.586E-02 4.815E-02 5.042E-02 5.266E-02 5.486E-02 5.701E-02 5.912E-02 6.117E-02 6.316E-02 6.509E-02 6.695E-02 6.874E-02 7.045E-02 7.208E-02 7.363E-02 7.509E-02 7.646E-02 7.774E-02 7.893E-02 8.002E-02 8.101E-02 8.190E-02 8.269E-02 8.338E-02 8.396E-02 8.444E-02 8.481E-02 8.508E-02 8.524E-02 8.529E-02 8.524E-02 8.508E-02 8.481E-02 8.444E-02 8.396E-02 8.338E-02 8.269E-02 8.190E-02 8.101E-02 8.002E-02 7.893E-02 7.774E-02 7.646E-02 7.509E-02 7.363E-02 7.208E-02 7.045E-02 6.874E-02 6.695E-02 6.509E-02 6.316E-02 6.117E-02 5.912E-02 5.701E-02 5.486E-02 5.266E-02 5.042E-02 4.815E-02 4.586E-02 4.355E-02 4.123E-02 3.890E-02 3.658E-02 3.426E-02 3.196E-02 2.969E-02 2.745E-02 2.525E-02 2.309E-02 2.099E-02 1.896E-02 1.699E-02 1.510E-02 1.329E-02 1.158E-02 9.965E-03 8.452E-03 7.050E-03 5.762E-03 4.594E-03 3.552E-03 2.637E-03 1.855E-03 1.208E-03 6.974E-04 3.258E-04 9.381E-05 1.764E-06 4.919E-05 2.350E-04 5.573E-04 1.014E-03 1.601E-03 2.314E-03 3.150E-03 4.103E-03 5.168E-03 6.336E-03 7.602E-03 8.958E-03 1.040E-02 1.191E-02 1.348E-02 1.511E-02 1.679E-02 1.850E-02 2.023E-02 2.198E-02 2.374E-02 2.549E-02 2.722E-02 2.893E-02 3.060E-02 3.223E-02 3.380E-02 3.531E-02 3.674E-02 3.810E-02 3.937E-02 4.054E-02 4.161E-02 4.257E-02 4.342E-02 4.416E-02 4.477E-02 4.526E-02 4.562E-02 4.586E-02 4.596E-02 4.594E-02 4.580E-02 4.553E-02 4.513E-02 4.462E-02 4.398E-02 4.324E-02 4.239E-02 4.144E-02 4.039E-02 3.926E-02 3.804E-02 3.675E-02 3.539E-02 3.397E-02 3.250E-02 3.099E-02 2.945E-02 2.788E-02 2.629E-02 2.469E-02 2.310E-02 2.151E-02 1.994E-02 1.839E-02 1.687E-02 1.539E-02 1.395E-02 1.170E-02 1.305E-02 1.445E-02 1.589E-02 1.738E-02 1.890E-02 2.045E-02 2.202E-02 2.360E-02 2.519E-02 2.677E-02 2.835E-02 2.990E-02 3.143E-02 3.292E-02 3.436E-02 3.575E-02 3.709E-02 3.835E-02 3.954E-02 4.065E-02 4.167E-02 4.259E-02 4.341E-02 4.413E-02 4.473E-02 4.522E-02 4.559E-02 4.583E-02 4.596E-02 4.596E-02 4.583E-02 4.558E-02 4.520E-02 4.470E-02 4.408E-02 4.334E-02 4.248E-02 4.152E-02 4.045E-02 3.928E-02 3.802E-02 3.668E-02 3.526E-02 3.376E-02 3.221E-02 3.060E-02 2.895E-02 2.726E-02 2.555E-02 2.383E-02 2.210E-02 2.037E-02 1.866E-02 1.697E-02 1.531E-02 1.370E-02 1.214E-02 1.065E-02 9.219E-03 7.870E-03 6.607E-03 5.437E-03 4.367E-03 3.402E-03 2.550E-03 1.813E-03 1.197E-03 7.061E-04 3.421E-04 1.079E-04 5.093E-06 3.466E-05 1.969E-04 4.916E-04 9.178E-04 1.474E-03 2.157E-03 2.966E-03 3.896E-03 4.944E-03 6.106E-03 7.376E-03 8.750E-03 1.022E-02 1.179E-02 1.344E-02 1.516E-02 1.697E-02 1.883E-02 2.076E-02 2.274E-02 2.476E-02 2.682E-02 2.891E-02 3.102E-02 3.315E-02 3.529E-02 3.743E-02 3.956E-02 4.168E-02 4.378E-02 4.586E-02 4.791E-02 4.992E-02 5.189E-02 5.382E-02 5.569E-02 5.750E-02 5.925E-02 6.094E-02 6.255E-02 6.410E-02 6.556E-02 6.695E-02 6.825E-02 6.947E-02 7.060E-02 7.163E-02 7.258E-02 7.343E-02 7.418E-02 7.484E-02 7.539E-02 7.585E-02 7.621E-02 7.646E-02 7.661E-02 7.666E-02 7.661E-02 7.646E-02 7.621E-02 7.585E-02 7.539E-02 7.484E-02 7.418E-02 7.343E-02 7.258E-02 7.163E-02 7.060E-02 6.947E-02 6.825E-02 6.695E-02 6.556E-02 6.410E-02 6.255E-02 6.094E-02 5.925E-02 5.750E-02 5.569E-02 5.382E-02 5.189E-02 4.992E-02 4.791E-02 4.586E-02 4.378E-02 4.168E-02 3.956E-02 3.743E-02 3.529E-02 3.315E-02 3.102E-02 2.891E-02 2.682E-02 2.476E-02 2.274E-02 2.076E-02 1.883E-02 1.697E-02 1.516E-02 1.344E-02 1.179E-02 1.022E-02 8.750E-03 7.376E-03 6.106E-03 4.944E-03 3.896E-03 2.966E-03 2.157E-03 1.474E-03 9.178E-04 4.916E-04 1.969E-04 3.466E-05 5.093E-06 1.079E-04 3.421E-04 7.061E-04 1.197E-03 1.813E-03 2.550E-03 3.402E-03 4.367E-03 5.437E-03 6.607E-03 7.870E-03 9.219E-03 1.065E-02 1.214E-02 1.370E-02 1.531E-02 1.697E-02 1.866E-02 2.037E-02 2.210E-02 2.383E-02 2.555E-02 2.726E-02 2.895E-02 3.060E-02 3.221E-02 3.376E-02 3.526E-02 3.668E-02 3.802E-02 3.928E-02 4.045E-02 4.152E-02 4.248E-02 4.334E-02 4.408E-02 4.470E-02 4.520E-02 4.558E-02 4.583E-02 4.596E-02 4.596E-02 4.583E-02 4.559E-02 4.522E-02 4.473E-02 4.413E-02 4.341E-02 4.259E-02 4.167E-02 4.065E-02 3.954E-02 3.835E-02 3.709E-02 3.575E-02 3.436E-02 3.292E-02 3.143E-02 2.990E-02 2.835E-02 2.677E-02 2.519E-02 2.360E-02 2.202E-02 2.045E-02 1.890E-02 1.738E-02 1.589E-02 1.445E-02 1.305E-02 1.086E-02 1.216E-02 1.352E-02 1.492E-02 1.638E-02 1.787E-02 1.939E-02 2.094E-02 2.250E-02 2.408E-02 2.565E-02 2.723E-02 2.879E-02 3.032E-02 3.183E-02 3.330E-02 3.472E-02 3.609E-02 3.740E-02 3.864E-02 3.980E-02 4.088E-02 4.187E-02 4.277E-02 4.356E-02 4.425E-02 4.483E-02 4.529E-02 4.564E-02 4.586E-02 4.596E-02 4.594E-02 4.580E-02 4.554E-02 4.515E-02 4.464E-02 4.401E-02 4.327E-02 4.241E-02 4.145E-02 4.039E-02 3.923E-02 3.798E-02 3.665E-02 3.524E-02 3.376E-02 3.223E-02 3.064E-02 2.901E-02 2.735E-02 2.566E-02 2.396E-02 2.225E-02 2.055E-02 1.886E-02 1.719E-02 1.556E-02 1.397E-02 1.242E-02 1.094E-02 9.522E-03 8.179E-03 6.918E-03 5.746E-03 4.668E-03 3.691E-03 2.820E-03 2.060E-03 1.414E-03 8.868E-04 4.801E-04 1.963E-04 3.715E-05 3.357E-06 9.524E-05 3.124E-04 6.540E-04 1.118E-03 1.703E-03 2.406E-03 3.224E-03 4.153E-03 5.189E-03 6.328E-03 7.564E-03 8.893E-03 1.031E-02 1.180E-02 1.337E-02 1.501E-02 1.671E-02 1.847E-02 2.027E-02 2.212E-02 2.400E-02 2.591E-02 2.784E-02 2.978E-02 3.173E-02 3.369E-02 3.563E-02 3.757E-02 3.949E-02 4.138E-02 4.324E-02 4.507E-02 4.686E-02 4.860E-02 5.030E-02 5.193E-02 5.351E-02 5.503E-02 5.648E-02 5.786E-02 5.916E-02 6.039E-02 6.154E-02 6.260E-02 6.358E-02 6.447E-02 6.528E-02 6.599E-02 6.661E-02 6.714E-02 6.757E-02 6.791E-02 6.815E-02 6.830E-02 6.835E-02 6.830E-02 6.815E-02 6.791E-02 6.757E-02 6.714E-02 6.661E-02 6.599E-02 6.528E-02 6.447E-02 6.358E-02 6.260E-02 6.154E-02 6.039E-02 5.916E-02 5.786E-02 5.648E-02 5.503E-02 5.351E-02 5.193E-02 5.030E-02 4.860E-02 4.686E-02 4.507E-02 4.324E-02 4.138E-02 3.949E-02 3.757E-02 3.563E-02 3.369E-02 3.173E-02 2.978E-02 2.784E-02 2.591E-02 2.400E-02 2.212E-02 2.027E-02 1.847E-02 1.671E-02 1.501E-02 1.337E-02 1.180E-02 1.031E-02 8.893E-03 7.564E-03 6.328E-03 5.189E-03 4.153E-03 3.224E-03 2.406E-03 1.703E-03 1.118E-03 6.540E-04 3.124E-04 9.524E-05 3.357E-06 3.715E-05 1.963E-04 4.801E-04 8.868E-04 1.414E-03 2.060E-03 2.820E-03 3.691E-03 4.668E-03 5.746E-03 6.918E-03 8.179E-03 9.522E-03 1.094E-02 1.242E-02 1.397E-02 1.556E-02 1.719E-02 1.886E-02 2.055E-02 2.225E-02 2.396E-02 2.566E-02 2.735E-02 2.901E-02 3.064E-02 3.223E-02 3.376E-02 3.524E-02 3.665E-02 3.798E-02 3.923E-02 4.039E-02 4.145E-02 4.241E-02 4.327E-02 4.401E-02 4.464E-02 4.515E-02 4.554E-02 4.580E-02 4.594E-02 4.596E-02 4.586E-02 4.564E-02 4.529E-02 4.483E-02 4.425E-02 4.356E-02 4.277E-02 4.187E-02 4.088E-02 3.980E-02 3.864E-02 3.740E-02 3.609E-02 3.472E-02 3.330E-02 3.183E-02 3.032E-02 2.879E-02 2.723E-02 2.565E-02 2.408E-02 2.250E-02 2.094E-02 1.939E-02 1.787E-02 1.638E-02 1.492E-02 1.352E-02 1.216E-02 1.004E-02 1.129E-02 1.260E-02 1.397E-02 1.538E-02 1.684E-02 1.833E-02 1.986E-02 2.140E-02 2.296E-02 2.453E-02 2.610E-02 2.766E-02 2.920E-02 3.072E-02 3.221E-02 3.366E-02 3.506E-02 3.641E-02 3.769E-02 3.890E-02 4.004E-02 4.110E-02 4.206E-02 4.293E-02 4.370E-02 4.436E-02 4.491E-02 4.535E-02 4.568E-02 4.588E-02 4.597E-02 4.593E-02 4.578E-02 4.550E-02 4.510E-02 4.459E-02 4.396E-02 4.321E-02 4.236E-02 4.141E-02 4.035E-02 3.920E-02 3.796E-02 3.665E-02 3.526E-02 3.380E-02 3.229E-02 3.072E-02 2.911E-02 2.748E-02 2.581E-02 2.414E-02 2.245E-02 2.078E-02 1.911E-02 1.747E-02 1.585E-02 1.428E-02 1.275E-02 1.128E-02 9.869E-03 8.532E-03 7.272E-03 6.096E-03 5.010E-03 4.020E-03 3.130E-03 2.345E-03 1.668E-03 1.104E-03 6.535E-04 3.197E-04 1.036E-04 6.105E-06 2.738E-05 1.670E-04 4.241E-04 7.971E-04 1.284E-03 1.882E-03 2.589E-03 3.400E-03 4.312E-03 5.320E-03 6.421E-03 7.608E-03 8.877E-03 1.022E-02 1.164E-02 1.312E-02 1.465E-02 1.624E-02 1.787E-02 1.955E-02 2.125E-02 2.298E-02 2.473E-02 2.650E-02 2.826E-02 3.003E-02 3.180E-02 3.355E-02 3.529E-02 3.700E-02 3.868E-02 4.033E-02 4.194E-02 4.351E-02 4.503E-02 4.650E-02 4.791E-02 4.926E-02 5.055E-02 5.177E-02 5.291E-02 5.399E-02 5.499E-02 5.591E-02 5.674E-02 5.750E-02 5.817E-02 5.875E-02 5.925E-02 5.966E-02 5.998E-02 6.021E-02 6.034E-02 6.039E-02 6.034E-02 6.021E-02 5.998E-02 5.966E-02 5.925E-02 5.875E-02 5.817E-02 5.750E-02 5.674E-02 5.591E-02 5.499E-02 5.399E-02 5.291E-02 5.177E-02 5.055E-02 4.926E-02 4.791E-02 4.650E-02 4.503E-02 4.351E-02 4.194E-02 4.033E-02 3.868E-02 3.700E-02 3.529E-02 3.355E-02 3.180E-02 3.003E-02 2.826E-02 2.650E-02 2.473E-02 2.298E-02 2.125E-02 1.955E-02 1.787E-02 1.624E-02 1.465E-02 1.312E-02 1.164E-02 1.022E-02 8.877E-03 7.608E-03 6.421E-03 5.320E-03 4.312E-03 3.400E-03 2.589E-03 1.882E-03 1.284E-03 7.971E-04 4.241E-04 1.670E-04 2.738E-05 6.105E-06 1.036E-04 3.197E-04 6.535E-04 1.104E-03 1.668E-03 2.345E-03 3.130E-03 4.020E-03 5.010E-03 6.096E-03 7.272E-03 8.532E-03 9.869E-03 1.128E-02 1.275E-02 1.428E-02 1.585E-02 1.747E-02 1.911E-02 2.078E-02 2.245E-02 2.414E-02 2.581E-02 2.748E-02 2.911E-02 3.072E-02 3.229E-02 3.380E-02 3.526E-02 3.665E-02 3.796E-02 3.920E-02 4.035E-02 4.141E-02 4.236E-02 4.321E-02 4.396E-02 4.459E-02 4.510E-02 4.550E-02 4.578E-02 4.593E-02 4.597E-02 4.588E-02 4.568E-02 4.535E-02 4.491E-02 4.436E-02 4.370E-02 4.293E-02 4.206E-02 4.110E-02 4.004E-02 3.890E-02 3.769E-02 3.641E-02 3.506E-02 3.366E-02 3.221E-02 3.072E-02 2.920E-02 2.766E-02 2.610E-02 2.453E-02 2.296E-02 2.140E-02 1.986E-02 1.833E-02 1.684E-02 1.538E-02 1.397E-02 1.260E-02 1.129E-02 9.234E-03 1.044E-02 1.171E-02 1.303E-02 1.441E-02 1.583E-02 1.729E-02 1.878E-02 2.030E-02 2.184E-02 2.340E-02 2.495E-02 2.651E-02 2.806E-02 2.959E-02 3.109E-02 3.256E-02 3.399E-02 3.537E-02 3.669E-02 3.795E-02 3.914E-02 4.026E-02 4.128E-02 4.222E-02 4.307E-02 4.381E-02 4.445E-02 4.499E-02 4.541E-02 4.571E-02 4.590E-02 4.597E-02 4.592E-02 4.576E-02 4.547E-02 4.507E-02 4.455E-02 4.392E-02 4.318E-02 4.233E-02 4.138E-02 4.034E-02 3.920E-02 3.798E-02 3.668E-02 3.531E-02 3.387E-02 3.238E-02 3.084E-02 2.926E-02 2.765E-02 2.601E-02 2.436E-02 2.270E-02 2.105E-02 1.940E-02 1.778E-02 1.619E-02 1.463E-02 1.312E-02 1.166E-02 1.026E-02 8.928E-03 7.669E-03 6.489E-03 5.395E-03 4.390E-03 3.481E-03 2.671E-03 1.963E-03 1.361E-03 8.671E-04 4.831E-04 2.102E-04 4.919E-05 2.162E-07 6.286E-05 2.362E-04 5.187E-04 9.085E-04 1.403E-03 2.000E-03 2.695E-03 3.485E-03 4.365E-03 5.332E-03 6.381E-03 7.506E-03 8.703E-03 9.965E-03 1.129E-02 1.266E-02 1.409E-02 1.555E-02 1.706E-02 1.859E-02 2.015E-02 2.172E-02 2.331E-02 2.490E-02 2.650E-02 2.808E-02 2.966E-02 3.122E-02 3.275E-02 3.426E-02 3.574E-02 3.718E-02 3.857E-02 3.993E-02 4.123E-02 4.248E-02 4.367E-02 4.480E-02 4.586E-02 4.686E-02 4.779E-02 4.864E-02 4.943E-02 5.013E-02 5.076E-02 5.130E-02 5.177E-02 5.215E-02 5.244E-02 5.266E-02 5.279E-02 5.283E-02 5.279E-02 5.266E-02 5.244E-02 5.215E-02 5.177E-02 5.130E-02 5.076E-02 5.013E-02 4.943E-02 4.864E-02 4.779E-02 4.686E-02 4.586E-02 4.480E-02 4.367E-02 4.248E-02 4.123E-02 3.993E-02 3.857E-02 3.718E-02 3.574E-02 3.426E-02 3.275E-02 3.122E-02 2.966E-02 2.808E-02 2.650E-02 2.490E-02 2.331E-02 2.172E-02 2.015E-02 1.859E-02 1.706E-02 1.555E-02 1.409E-02 1.266E-02 1.129E-02 9.965E-03 8.703E-03 7.506E-03 6.381E-03 5.332E-03 4.365E-03 3.485E-03 2.695E-03 2.000E-03 1.403E-03 9.085E-04 5.187E-04 2.362E-04 6.286E-05 2.162E-07 4.919E-05 2.102E-04 4.831E-04 8.671E-04 1.361E-03 1.963E-03 2.671E-03 3.481E-03 4.390E-03 5.395E-03 6.489E-03 7.669E-03 8.928E-03 1.026E-02 1.166E-02 1.312E-02 1.463E-02 1.619E-02 1.778E-02 1.940E-02 2.105E-02 2.270E-02 2.436E-02 2.601E-02 2.765E-02 2.926E-02 3.084E-02 3.238E-02 3.387E-02 3.531E-02 3.668E-02 3.798E-02 3.920E-02 4.034E-02 4.138E-02 4.233E-02 4.318E-02 4.392E-02 4.455E-02 4.507E-02 4.547E-02 4.576E-02 4.592E-02 4.597E-02 4.590E-02 4.571E-02 4.541E-02 4.499E-02 4.445E-02 4.381E-02 4.307E-02 4.222E-02 4.128E-02 4.026E-02 3.914E-02 3.795E-02 3.669E-02 3.537E-02 3.399E-02 3.256E-02 3.109E-02 2.959E-02 2.806E-02 2.651E-02 2.495E-02 2.340E-02 2.184E-02 2.030E-02 1.878E-02 1.729E-02 1.583E-02 1.441E-02 1.303E-02 1.171E-02 1.044E-02 8.458E-03 9.614E-03 1.083E-02 1.211E-02 1.344E-02 1.483E-02 1.625E-02 1.771E-02 1.921E-02 2.072E-02 2.226E-02 2.381E-02 2.535E-02 2.690E-02 2.843E-02 2.995E-02 3.143E-02 3.288E-02 3.429E-02 3.565E-02 3.695E-02 3.819E-02 3.936E-02 4.045E-02 4.145E-02 4.237E-02 4.319E-02 4.391E-02 4.453E-02 4.505E-02 4.545E-02 4.574E-02 4.591E-02 4.597E-02 4.591E-02 4.574E-02 4.545E-02 4.504E-02 4.452E-02 4.390E-02 4.316E-02 4.232E-02 4.138E-02 4.035E-02 3.923E-02 3.802E-02 3.674E-02 3.539E-02 3.398E-02 3.251E-02 3.100E-02 2.944E-02 2.786E-02 2.625E-02 2.462E-02 2.299E-02 2.136E-02 1.974E-02 1.815E-02 1.657E-02 1.503E-02 1.354E-02 1.209E-02 1.070E-02 9.370E-03 8.111E-03 6.928E-03 5.824E-03 4.805E-03 3.877E-03 3.041E-03 2.302E-03 1.663E-03 1.126E-03 6.919E-04 3.627E-04 1.389E-04 2.057E-05 7.280E-06 9.812E-05 2.917E-04 5.861E-04 9.791E-04 1.468E-03 2.049E-03 2.720E-03 3.475E-03 4.312E-03 5.225E-03 6.210E-03 7.262E-03 8.375E-03 9.544E-03 1.076E-02 1.203E-02 1.333E-02 1.467E-02 1.604E-02 1.743E-02 1.883E-02 2.025E-02 2.167E-02 2.309E-02 2.451E-02 2.591E-02 2.730E-02 2.866E-02 3.000E-02 3.131E-02 3.259E-02 3.382E-02 3.501E-02 3.616E-02 3.725E-02 3.829E-02 3.927E-02 4.019E-02 4.104E-02 4.183E-02 4.255E-02 4.320E-02 4.378E-02 4.429E-02 4.472E-02 4.507E-02 4.535E-02 4.554E-02 4.566E-02 4.570E-02 4.566E-02 4.554E-02 4.535E-02 4.507E-02 4.472E-02 4.429E-02 4.378E-02 4.320E-02 4.255E-02 4.183E-02 4.104E-02 4.019E-02 3.927E-02 3.829E-02 3.725E-02 3.616E-02 3.501E-02 3.382E-02 3.259E-02 3.131E-02 3.000E-02 2.866E-02 2.730E-02 2.591E-02 2.451E-02 2.309E-02 2.167E-02 2.025E-02 1.883E-02 1.743E-02 1.604E-02 1.467E-02 1.333E-02 1.203E-02 1.076E-02 9.544E-03 8.375E-03 7.262E-03 6.210E-03 5.225E-03 4.312E-03 3.475E-03 2.720E-03 2.049E-03 1.468E-03 9.791E-04 5.861E-04 2.917E-04 9.812E-05 7.280E-06 2.057E-05 1.389E-04 3.627E-04 6.919E-04 1.126E-03 1.663E-03 2.302E-03 3.041E-03 3.877E-03 4.805E-03 5.824E-03 6.928E-03 8.111E-03 9.370E-03 1.070E-02 1.209E-02 1.354E-02 1.503E-02 1.657E-02 1.815E-02 1.974E-02 2.136E-02 2.299E-02 2.462E-02 2.625E-02 2.786E-02 2.944E-02 3.100E-02 3.251E-02 3.398E-02 3.539E-02 3.674E-02 3.802E-02 3.923E-02 4.035E-02 4.138E-02 4.232E-02 4.316E-02 4.390E-02 4.452E-02 4.504E-02 4.545E-02 4.574E-02 4.591E-02 4.597E-02 4.591E-02 4.574E-02 4.545E-02 4.505E-02 4.453E-02 4.391E-02 4.319E-02 4.237E-02 4.145E-02 4.045E-02 3.936E-02 3.819E-02 3.695E-02 3.565E-02 3.429E-02 3.288E-02 3.143E-02 2.995E-02 2.843E-02 2.690E-02 2.535E-02 2.381E-02 2.226E-02 2.072E-02 1.921E-02 1.771E-02 1.625E-02 1.483E-02 1.344E-02 1.211E-02 1.083E-02 9.614E-03 7.707E-03 8.813E-03 9.983E-03 1.121E-02 1.250E-02 1.384E-02 1.523E-02 1.666E-02 1.812E-02 1.961E-02 2.112E-02 2.265E-02 2.419E-02 2.573E-02 2.726E-02 2.878E-02 3.028E-02 3.175E-02 3.318E-02 3.457E-02 3.591E-02 3.719E-02 3.840E-02 3.955E-02 4.062E-02 4.160E-02 4.250E-02 4.330E-02 4.400E-02 4.460E-02 4.510E-02 4.548E-02 4.576E-02 4.592E-02 4.597E-02 4.591E-02 4.573E-02 4.543E-02 4.503E-02 4.451E-02 4.389E-02 4.316E-02 4.233E-02 4.141E-02 4.039E-02 3.928E-02 3.810E-02 3.684E-02 3.551E-02 3.413E-02 3.268E-02 3.119E-02 2.967E-02 2.811E-02 2.653E-02 2.493E-02 2.333E-02 2.172E-02 2.013E-02 1.855E-02 1.700E-02 1.548E-02 1.400E-02 1.256E-02 1.118E-02 9.859E-03 8.601E-03 7.413E-03 6.300E-03 5.268E-03 4.320E-03 3.459E-03 2.690E-03 2.014E-03 1.434E-03 9.513E-04 5.669E-04 2.815E-04 9.521E-05 7.597E-06 1.779E-05 1.244E-04 3.258E-04 6.196E-04 1.003E-03 1.474E-03 2.028E-03 2.662E-03 3.372E-03 4.153E-03 5.002E-03 5.913E-03 6.882E-03 7.904E-03 8.973E-03 1.008E-02 1.123E-02 1.241E-02 1.362E-02 1.484E-02 1.608E-02 1.734E-02 1.859E-02 1.985E-02 2.110E-02 2.233E-02 2.356E-02 2.476E-02 2.594E-02 2.709E-02 2.820E-02 2.928E-02 3.032E-02 3.131E-02 3.226E-02 3.315E-02 3.399E-02 3.477E-02 3.549E-02 3.616E-02 3.675E-02 3.728E-02 3.775E-02 3.814E-02 3.847E-02 3.872E-02 3.890E-02 3.901E-02 3.905E-02 3.901E-02 3.890E-02 3.872E-02 3.847E-02 3.814E-02 3.775E-02 3.728E-02 3.675E-02 3.616E-02 3.549E-02 3.477E-02 3.399E-02 3.315E-02 3.226E-02 3.131E-02 3.032E-02 2.928E-02 2.820E-02 2.709E-02 2.594E-02 2.476E-02 2.356E-02 2.233E-02 2.110E-02 1.985E-02 1.859E-02 1.734E-02 1.608E-02 1.484E-02 1.362E-02 1.241E-02 1.123E-02 1.008E-02 8.973E-03 7.904E-03 6.882E-03 5.913E-03 5.002E-03 4.153E-03 3.372E-03 2.662E-03 2.028E-03 1.474E-03 1.003E-03 6.196E-04 3.258E-04 1.244E-04 1.779E-05 7.597E-06 9.521E-05 2.815E-04 5.669E-04 9.513E-04 1.434E-03 2.014E-03 2.690E-03 3.459E-03 4.320E-03 5.268E-03 6.300E-03 7.413E-03 8.601E-03 9.859E-03 1.118E-02 1.256E-02 1.400E-02 1.548E-02 1.700E-02 1.855E-02 2.013E-02 2.172E-02 2.333E-02 2.493E-02 2.653E-02 2.811E-02 2.967E-02 3.119E-02 3.268E-02 3.413E-02 3.551E-02 3.684E-02 3.810E-02 3.928E-02 4.039E-02 4.141E-02 4.233E-02 4.316E-02 4.389E-02 4.451E-02 4.503E-02 4.543E-02 4.573E-02 4.591E-02 4.597E-02 4.592E-02 4.576E-02 4.548E-02 4.510E-02 4.460E-02 4.400E-02 4.330E-02 4.250E-02 4.160E-02 4.062E-02 3.955E-02 3.840E-02 3.719E-02 3.591E-02 3.457E-02 3.318E-02 3.175E-02 3.028E-02 2.878E-02 2.726E-02 2.573E-02 2.419E-02 2.265E-02 2.112E-02 1.961E-02 1.812E-02 1.666E-02 1.523E-02 1.384E-02 1.250E-02 1.121E-02 9.983E-03 8.813E-03 6.984E-03 8.037E-03 9.157E-03 1.034E-02 1.158E-02 1.288E-02 1.422E-02 1.561E-02 1.704E-02 1.850E-02 1.999E-02 2.150E-02 2.302E-02 2.455E-02 2.608E-02 2.760E-02 2.910E-02 3.058E-02 3.203E-02 3.345E-02 3.482E-02 3.614E-02 3.740E-02 3.859E-02 3.972E-02 4.076E-02 4.173E-02 4.260E-02 4.339E-02 4.407E-02 4.466E-02 4.514E-02 4.551E-02 4.578E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.502E-02 4.451E-02 4.390E-02 4.318E-02 4.236E-02 4.145E-02 4.045E-02 3.937E-02 3.820E-02 3.697E-02 3.567E-02 3.430E-02 3.289E-02 3.143E-02 2.993E-02 2.840E-02 2.685E-02 2.528E-02 2.370E-02 2.213E-02 2.056E-02 1.901E-02 1.748E-02 1.597E-02 1.451E-02 1.309E-02 1.171E-02 1.040E-02 9.139E-03 7.947E-03 6.826E-03 5.780E-03 4.814E-03 3.929E-03 3.130E-03 2.418E-03 1.797E-03 1.266E-03 8.283E-04 4.831E-04 2.307E-04 7.095E-05 2.840E-06 2.515E-05 1.362E-04 3.339E-04 6.158E-04 9.791E-04 1.421E-03 1.937E-03 2.524E-03 3.179E-03 3.896E-03 4.672E-03 5.502E-03 6.381E-03 7.304E-03 8.267E-03 9.264E-03 1.029E-02 1.134E-02 1.241E-02 1.350E-02 1.459E-02 1.569E-02 1.678E-02 1.787E-02 1.896E-02 2.002E-02 2.107E-02 2.209E-02 2.309E-02 2.406E-02 2.499E-02 2.588E-02 2.673E-02 2.754E-02 2.830E-02 2.900E-02 2.966E-02 3.026E-02 3.080E-02 3.128E-02 3.170E-02 3.206E-02 3.236E-02 3.259E-02 3.275E-02 3.285E-02 3.288E-02 3.285E-02 3.275E-02 3.259E-02 3.236E-02 3.206E-02 3.170E-02 3.128E-02 3.080E-02 3.026E-02 2.966E-02 2.900E-02 2.830E-02 2.754E-02 2.673E-02 2.588E-02 2.499E-02 2.406E-02 2.309E-02 2.209E-02 2.107E-02 2.002E-02 1.896E-02 1.787E-02 1.678E-02 1.569E-02 1.459E-02 1.350E-02 1.241E-02 1.134E-02 1.029E-02 9.264E-03 8.267E-03 7.304E-03 6.381E-03 5.502E-03 4.672E-03 3.896E-03 3.179E-03 2.524E-03 1.937E-03 1.421E-03 9.791E-04 6.158E-04 3.339E-04 1.362E-04 2.515E-05 2.840E-06 7.095E-05 2.307E-04 4.831E-04 8.283E-04 1.266E-03 1.797E-03 2.418E-03 3.130E-03 3.929E-03 4.814E-03 5.780E-03 6.826E-03 7.947E-03 9.139E-03 1.040E-02 1.171E-02 1.309E-02 1.451E-02 1.597E-02 1.748E-02 1.901E-02 2.056E-02 2.213E-02 2.370E-02 2.528E-02 2.685E-02 2.840E-02 2.993E-02 3.143E-02 3.289E-02 3.430E-02 3.567E-02 3.697E-02 3.820E-02 3.937E-02 4.045E-02 4.145E-02 4.236E-02 4.318E-02 4.390E-02 4.451E-02 4.502E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.578E-02 4.551E-02 4.514E-02 4.466E-02 4.407E-02 4.339E-02 4.260E-02 4.173E-02 4.076E-02 3.972E-02 3.859E-02 3.740E-02 3.614E-02 3.482E-02 3.345E-02 3.203E-02 3.058E-02 2.910E-02 2.760E-02 2.608E-02 2.455E-02 2.302E-02 2.150E-02 1.999E-02 1.850E-02 1.704E-02 1.561E-02 1.422E-02 1.288E-02 1.158E-02 1.034E-02 9.157E-03 8.037E-03 6.291E-03 7.290E-03 8.357E-03 9.488E-03 1.068E-02 1.193E-02 1.323E-02 1.458E-02 1.597E-02 1.740E-02 1.886E-02 2.035E-02 2.185E-02 2.336E-02 2.488E-02 2.640E-02 2.790E-02 2.939E-02 3.086E-02 3.229E-02 3.369E-02 3.504E-02 3.634E-02 3.758E-02 3.876E-02 3.986E-02 4.089E-02 4.183E-02 4.269E-02 4.346E-02 4.413E-02 4.470E-02 4.517E-02 4.553E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.503E-02 4.452E-02 4.392E-02 4.321E-02 4.241E-02 4.152E-02 4.054E-02 3.948E-02 3.834E-02 3.713E-02 3.585E-02 3.452E-02 3.313E-02 3.170E-02 3.023E-02 2.873E-02 2.721E-02 2.567E-02 2.413E-02 2.258E-02 2.104E-02 1.951E-02 1.800E-02 1.652E-02 1.507E-02 1.366E-02 1.229E-02 1.098E-02 9.726E-03 8.532E-03 7.403E-03 6.345E-03 5.361E-03 4.453E-03 3.625E-03 2.880E-03 2.218E-03 1.642E-03 1.152E-03 7.495E-04 4.335E-04 2.042E-04 6.067E-05 1.762E-06 2.589E-05 1.311E-04 3.151E-04 5.752E-04 9.085E-04 1.312E-03 1.782E-03 2.314E-03 2.906E-03 3.552E-03 4.248E-03 4.991E-03 5.774E-03 6.595E-03 7.448E-03 8.329E-03 9.232E-03 1.015E-02 1.109E-02 1.203E-02 1.298E-02 1.392E-02 1.486E-02 1.580E-02 1.671E-02 1.762E-02 1.849E-02 1.935E-02 2.017E-02 2.097E-02 2.172E-02 2.244E-02 2.312E-02 2.375E-02 2.434E-02 2.487E-02 2.536E-02 2.579E-02 2.617E-02 2.650E-02 2.676E-02 2.697E-02 2.712E-02 2.721E-02 2.724E-02 2.721E-02 2.712E-02 2.697E-02 2.676E-02 2.650E-02 2.617E-02 2.579E-02 2.536E-02 2.487E-02 2.434E-02 2.375E-02 2.312E-02 2.244E-02 2.172E-02 2.097E-02 2.017E-02 1.935E-02 1.849E-02 1.762E-02 1.671E-02 1.580E-02 1.486E-02 1.392E-02 1.298E-02 1.203E-02 1.109E-02 1.015E-02 9.232E-03 8.329E-03 7.448E-03 6.595E-03 5.774E-03 4.991E-03 4.248E-03 3.552E-03 2.906E-03 2.314E-03 1.782E-03 1.312E-03 9.085E-04 5.752E-04 3.151E-04 1.311E-04 2.589E-05 1.762E-06 6.067E-05 2.042E-04 4.335E-04 7.495E-04 1.152E-03 1.642E-03 2.218E-03 2.880E-03 3.625E-03 4.453E-03 5.361E-03 6.345E-03 7.403E-03 8.532E-03 9.726E-03 1.098E-02 1.229E-02 1.366E-02 1.507E-02 1.652E-02 1.800E-02 1.951E-02 2.104E-02 2.258E-02 2.413E-02 2.567E-02 2.721E-02 2.873E-02 3.023E-02 3.170E-02 3.313E-02 3.452E-02 3.585E-02 3.713E-02 3.834E-02 3.948E-02 4.054E-02 4.152E-02 4.241E-02 4.321E-02 4.392E-02 4.452E-02 4.503E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.553E-02 4.517E-02 4.470E-02 4.413E-02 4.346E-02 4.269E-02 4.183E-02 4.089E-02 3.986E-02 3.876E-02 3.758E-02 3.634E-02 3.504E-02 3.369E-02 3.229E-02 3.086E-02 2.939E-02 2.790E-02 2.640E-02 2.488E-02 2.336E-02 2.185E-02 2.035E-02 1.886E-02 1.740E-02 1.597E-02 1.458E-02 1.323E-02 1.193E-02 1.068E-02 9.488E-03 8.357E-03 7.290E-03 5.628E-03 6.573E-03 7.586E-03 8.665E-03 9.807E-03 1.101E-02 1.226E-02 1.357E-02 1.492E-02 1.632E-02 1.774E-02 1.920E-02 2.068E-02 2.217E-02 2.368E-02 2.519E-02 2.669E-02 2.818E-02 2.966E-02 3.111E-02 3.253E-02 3.391E-02 3.524E-02 3.652E-02 3.774E-02 3.890E-02 3.999E-02 4.100E-02 4.192E-02 4.277E-02 4.352E-02 4.417E-02 4.473E-02 4.519E-02 4.554E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.572E-02 4.543E-02 4.504E-02 4.455E-02 4.396E-02 4.327E-02 4.248E-02 4.161E-02 4.065E-02 3.961E-02 3.850E-02 3.731E-02 3.607E-02 3.476E-02 3.341E-02 3.201E-02 3.057E-02 2.910E-02 2.761E-02 2.611E-02 2.459E-02 2.307E-02 2.155E-02 2.005E-02 1.856E-02 1.710E-02 1.567E-02 1.428E-02 1.292E-02 1.162E-02 1.036E-02 9.169E-03 8.034E-03 6.964E-03 5.964E-03 5.035E-03 4.180E-03 3.402E-03 2.703E-03 2.083E-03 1.544E-03 1.086E-03 7.096E-04 4.139E-04 1.983E-04 6.178E-05 2.840E-06 1.967E-05 1.101E-04 2.717E-04 5.017E-04 7.971E-04 1.155E-03 1.571E-03 2.042E-03 2.564E-03 3.134E-03 3.746E-03 4.398E-03 5.084E-03 5.800E-03 6.541E-03 7.304E-03 8.084E-03 8.877E-03 9.678E-03 1.048E-02 1.129E-02 1.209E-02 1.288E-02 1.366E-02 1.442E-02 1.516E-02 1.588E-02 1.658E-02 1.724E-02 1.787E-02 1.847E-02 1.903E-02 1.955E-02 2.002E-02 2.045E-02 2.084E-02 2.117E-02 2.146E-02 2.170E-02 2.188E-02 2.201E-02 2.209E-02 2.212E-02 2.209E-02 2.201E-02 2.188E-02 2.170E-02 2.146E-02 2.117E-02 2.084E-02 2.045E-02 2.002E-02 1.955E-02 1.903E-02 1.847E-02 1.787E-02 1.724E-02 1.658E-02 1.588E-02 1.516E-02 1.442E-02 1.366E-02 1.288E-02 1.209E-02 1.129E-02 1.048E-02 9.678E-03 8.877E-03 8.084E-03 7.304E-03 6.541E-03 5.800E-03 5.084E-03 4.398E-03 3.746E-03 3.134E-03 2.564E-03 2.042E-03 1.571E-03 1.155E-03 7.971E-04 5.017E-04 2.717E-04 1.101E-04 1.967E-05 2.840E-06 6.178E-05 1.983E-04 4.139E-04 7.096E-04 1.086E-03 1.544E-03 2.083E-03 2.703E-03 3.402E-03 4.180E-03 5.035E-03 5.964E-03 6.964E-03 8.034E-03 9.169E-03 1.036E-02 1.162E-02 1.292E-02 1.428E-02 1.567E-02 1.710E-02 1.856E-02 2.005E-02 2.155E-02 2.307E-02 2.459E-02 2.611E-02 2.761E-02 2.910E-02 3.057E-02 3.201E-02 3.341E-02 3.476E-02 3.607E-02 3.731E-02 3.850E-02 3.961E-02 4.065E-02 4.161E-02 4.248E-02 4.327E-02 4.396E-02 4.455E-02 4.504E-02 4.543E-02 4.572E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.554E-02 4.519E-02 4.473E-02 4.417E-02 4.352E-02 4.277E-02 4.192E-02 4.100E-02 3.999E-02 3.890E-02 3.774E-02 3.652E-02 3.524E-02 3.391E-02 3.253E-02 3.111E-02 2.966E-02 2.818E-02 2.669E-02 2.519E-02 2.368E-02 2.217E-02 2.068E-02 1.920E-02 1.774E-02 1.632E-02 1.492E-02 1.357E-02 1.226E-02 1.101E-02 9.807E-03 8.665E-03 7.586E-03 6.573E-03 4.998E-03 5.887E-03 6.846E-03 7.871E-03 8.961E-03 1.011E-02 1.132E-02 1.258E-02 1.389E-02 1.525E-02 1.664E-02 1.806E-02 1.951E-02 2.099E-02 2.247E-02 2.397E-02 2.547E-02 2.696E-02 2.844E-02 2.990E-02 3.133E-02 3.273E-02 3.410E-02 3.541E-02 3.668E-02 3.788E-02 3.902E-02 4.009E-02 4.108E-02 4.199E-02 4.282E-02 4.356E-02 4.420E-02 4.475E-02 4.520E-02 4.555E-02 4.579E-02 4.593E-02 4.597E-02 4.590E-02 4.573E-02 4.545E-02 4.507E-02 4.459E-02 4.401E-02 4.334E-02 4.257E-02 4.172E-02 4.079E-02 3.977E-02 3.869E-02 3.753E-02 3.631E-02 3.504E-02 3.372E-02 3.235E-02 3.095E-02 2.951E-02 2.806E-02 2.658E-02 2.509E-02 2.360E-02 2.212E-02 2.064E-02 1.918E-02 1.774E-02 1.632E-02 1.494E-02 1.360E-02 1.230E-02 1.106E-02 9.859E-03 8.719E-03 7.640E-03 6.625E-03 5.677E-03 4.797E-03 3.989E-03 3.254E-03 2.594E-03 2.008E-03 1.499E-03 1.065E-03 7.061E-04 4.223E-04 2.122E-04 7.455E-05 7.597E-06 9.360E-06 7.755E-05 2.096E-04 4.028E-04 6.540E-04 9.600E-04 1.317E-03 1.723E-03 2.172E-03 2.662E-03 3.188E-03 3.746E-03 4.333E-03 4.944E-03 5.576E-03 6.223E-03 6.882E-03 7.550E-03 8.221E-03 8.893E-03 9.561E-03 1.022E-02 1.087E-02 1.151E-02 1.212E-02 1.272E-02 1.329E-02 1.384E-02 1.436E-02 1.484E-02 1.529E-02 1.571E-02 1.608E-02 1.642E-02 1.671E-02 1.697E-02 1.717E-02 1.734E-02 1.745E-02 1.752E-02 1.755E-02 1.752E-02 1.745E-02 1.734E-02 1.717E-02 1.697E-02 1.671E-02 1.642E-02 1.608E-02 1.571E-02 1.529E-02 1.484E-02 1.436E-02 1.384E-02 1.329E-02 1.272E-02 1.212E-02 1.151E-02 1.087E-02 1.022E-02 9.561E-03 8.893E-03 8.221E-03 7.550E-03 6.882E-03 6.223E-03 5.576E-03 4.944E-03 4.333E-03 3.746E-03 3.188E-03 2.662E-03 2.172E-03 1.723E-03 1.317E-03 9.600E-04 6.540E-04 4.028E-04 2.096E-04 7.755E-05 9.360E-06 7.597E-06 7.455E-05 2.122E-04 4.223E-04 7.061E-04 1.065E-03 1.499E-03 2.008E-03 2.594E-03 3.254E-03 3.989E-03 4.797E-03 5.677E-03 6.625E-03 7.640E-03 8.719E-03 9.859E-03 1.106E-02 1.230E-02 1.360E-02 1.494E-02 1.632E-02 1.774E-02 1.918E-02 2.064E-02 2.212E-02 2.360E-02 2.509E-02 2.658E-02 2.806E-02 2.951E-02 3.095E-02 3.235E-02 3.372E-02 3.504E-02 3.631E-02 3.753E-02 3.869E-02 3.977E-02 4.079E-02 4.172E-02 4.257E-02 4.334E-02 4.401E-02 4.459E-02 4.507E-02 4.545E-02 4.573E-02 4.590E-02 4.597E-02 4.593E-02 4.579E-02 4.555E-02 4.520E-02 4.475E-02 4.420E-02 4.356E-02 4.282E-02 4.199E-02 4.108E-02 4.009E-02 3.902E-02 3.788E-02 3.668E-02 3.541E-02 3.410E-02 3.273E-02 3.133E-02 2.990E-02 2.844E-02 2.696E-02 2.547E-02 2.397E-02 2.247E-02 2.099E-02 1.951E-02 1.806E-02 1.664E-02 1.525E-02 1.389E-02 1.258E-02 1.132E-02 1.011E-02 8.961E-03 7.871E-03 6.846E-03 5.887E-03 4.402E-03 5.234E-03 6.137E-03 7.108E-03 8.145E-03 9.244E-03 1.040E-02 1.162E-02 1.288E-02 1.419E-02 1.555E-02 1.694E-02 1.836E-02 1.981E-02 2.127E-02 2.275E-02 2.424E-02 2.572E-02 2.720E-02 2.867E-02 3.011E-02 3.153E-02 3.292E-02 3.426E-02 3.556E-02 3.681E-02 3.799E-02 3.912E-02 4.017E-02 4.115E-02 4.205E-02 4.286E-02 4.359E-02 4.422E-02 4.476E-02 4.521E-02 4.555E-02 4.579E-02 4.593E-02 4.597E-02 4.591E-02 4.574E-02 4.547E-02 4.510E-02 4.464E-02 4.408E-02 4.342E-02 4.268E-02 4.185E-02 4.094E-02 3.996E-02 3.890E-02 3.778E-02 3.659E-02 3.535E-02 3.406E-02 3.273E-02 3.136E-02 2.996E-02 2.854E-02 2.709E-02 2.564E-02 2.418E-02 2.272E-02 2.127E-02 1.984E-02 1.842E-02 1.702E-02 1.566E-02 1.433E-02 1.304E-02 1.180E-02 1.060E-02 9.461E-03 8.375E-03 7.347E-03 6.381E-03 5.479E-03 4.644E-03 3.877E-03 3.178E-03 2.550E-03 1.991E-03 1.504E-03 1.086E-03 7.385E-04 4.594E-04 2.478E-04 1.022E-04 2.057E-05 9.375E-07 4.092E-05 1.379E-04 2.892E-04 4.916E-04 7.422E-04 1.038E-03 1.374E-03 1.749E-03 2.157E-03 2.597E-03 3.063E-03 3.552E-03 4.060E-03 4.583E-03 5.119E-03 5.662E-03 6.210E-03 6.759E-03 7.304E-03 7.844E-03 8.375E-03 8.893E-03 9.396E-03 9.880E-03 1.034E-02 1.078E-02 1.120E-02 1.158E-02 1.194E-02 1.226E-02 1.255E-02 1.280E-02 1.302E-02 1.319E-02 1.333E-02 1.344E-02 1.350E-02 1.352E-02 1.350E-02 1.344E-02 1.333E-02 1.319E-02 1.302E-02 1.280E-02 1.255E-02 1.226E-02 1.194E-02 1.158E-02 1.120E-02 1.078E-02 1.034E-02 9.880E-03 9.396E-03 8.893E-03 8.375E-03 7.844E-03 7.304E-03 6.759E-03 6.210E-03 5.662E-03 5.119E-03 4.583E-03 4.060E-03 3.552E-03 3.063E-03 2.597E-03 2.157E-03 1.749E-03 1.374E-03 1.038E-03 7.422E-04 4.916E-04 2.892E-04 1.379E-04 4.092E-05 9.375E-07 2.057E-05 1.022E-04 2.478E-04 4.594E-04 7.385E-04 1.086E-03 1.504E-03 1.991E-03 2.550E-03 3.178E-03 3.877E-03 4.644E-03 5.479E-03 6.381E-03 7.347E-03 8.375E-03 9.461E-03 1.060E-02 1.180E-02 1.304E-02 1.433E-02 1.566E-02 1.702E-02 1.842E-02 1.984E-02 2.127E-02 2.272E-02 2.418E-02 2.564E-02 2.709E-02 2.854E-02 2.996E-02 3.136E-02 3.273E-02 3.406E-02 3.535E-02 3.659E-02 3.778E-02 3.890E-02 3.996E-02 4.094E-02 4.185E-02 4.268E-02 4.342E-02 4.408E-02 4.464E-02 4.510E-02 4.547E-02 4.574E-02 4.591E-02 4.597E-02 4.593E-02 4.579E-02 4.555E-02 4.521E-02 4.476E-02 4.422E-02 4.359E-02 4.286E-02 4.205E-02 4.115E-02 4.017E-02 3.912E-02 3.799E-02 3.681E-02 3.556E-02 3.426E-02 3.292E-02 3.153E-02 3.011E-02 2.867E-02 2.720E-02 2.572E-02 2.424E-02 2.275E-02 2.127E-02 1.981E-02 1.836E-02 1.694E-02 1.555E-02 1.419E-02 1.288E-02 1.162E-02 1.040E-02 9.244E-03 8.145E-03 7.108E-03 6.137E-03 5.234E-03 3.840E-03 4.616E-03 5.463E-03 6.378E-03 7.359E-03 8.405E-03 9.512E-03 1.068E-02 1.189E-02 1.316E-02 1.447E-02 1.583E-02 1.721E-02 1.863E-02 2.007E-02 2.153E-02 2.300E-02 2.448E-02 2.595E-02 2.741E-02 2.887E-02 3.030E-02 3.170E-02 3.307E-02 3.440E-02 3.568E-02 3.691E-02 3.808E-02 3.919E-02 4.023E-02 4.120E-02 4.208E-02 4.289E-02 4.360E-02 4.423E-02 4.476E-02 4.520E-02 4.554E-02 4.579E-02 4.593E-02 4.597E-02 4.591E-02 4.576E-02 4.550E-02 4.515E-02 4.470E-02 4.416E-02 4.352E-02 4.280E-02 4.200E-02 4.112E-02 4.016E-02 3.914E-02 3.805E-02 3.690E-02 3.569E-02 3.444E-02 3.314E-02 3.181E-02 3.044E-02 2.905E-02 2.765E-02 2.622E-02 2.480E-02 2.337E-02 2.195E-02 2.054E-02 1.914E-02 1.777E-02 1.643E-02 1.511E-02 1.383E-02 1.260E-02 1.140E-02 1.026E-02 9.169E-03 8.131E-03 7.150E-03 6.229E-03 5.369E-03 4.572E-03 3.839E-03 3.171E-03 2.568E-03 2.031E-03 1.559E-03 1.152E-03 8.092E-04 5.289E-04 3.099E-04 1.507E-04 4.919E-05 3.342E-06 1.073E-05 6.879E-05 1.748E-04 3.258E-04 5.187E-04 7.505E-04 1.018E-03 1.317E-03 1.646E-03 2.000E-03 2.375E-03 2.770E-03 3.179E-03 3.600E-03 4.029E-03 4.463E-03 4.898E-03 5.332E-03 5.762E-03 6.184E-03 6.595E-03 6.994E-03 7.376E-03 7.741E-03 8.084E-03 8.406E-03 8.703E-03 8.973E-03 9.215E-03 9.428E-03 9.611E-03 9.762E-03 9.880E-03 9.965E-03 1.002E-02 1.003E-02 1.002E-02 9.965E-03 9.880E-03 9.762E-03 9.611E-03 9.428E-03 9.215E-03 8.973E-03 8.703E-03 8.406E-03 8.084E-03 7.741E-03 7.376E-03 6.994E-03 6.595E-03 6.184E-03 5.762E-03 5.332E-03 4.898E-03 4.463E-03 4.029E-03 3.600E-03 3.179E-03 2.770E-03 2.375E-03 2.000E-03 1.646E-03 1.317E-03 1.018E-03 7.505E-04 5.187E-04 3.258E-04 1.748E-04 6.879E-05 1.073E-05 3.342E-06 4.919E-05 1.507E-04 3.099E-04 5.289E-04 8.092E-04 1.152E-03 1.559E-03 2.031E-03 2.568E-03 3.171E-03 3.839E-03 4.572E-03 5.369E-03 6.229E-03 7.150E-03 8.131E-03 9.169E-03 1.026E-02 1.140E-02 1.260E-02 1.383E-02 1.511E-02 1.643E-02 1.777E-02 1.914E-02 2.054E-02 2.195E-02 2.337E-02 2.480E-02 2.622E-02 2.765E-02 2.905E-02 3.044E-02 3.181E-02 3.314E-02 3.444E-02 3.569E-02 3.690E-02 3.805E-02 3.914E-02 4.016E-02 4.112E-02 4.200E-02 4.280E-02 4.352E-02 4.416E-02 4.470E-02 4.515E-02 4.550E-02 4.576E-02 4.591E-02 4.597E-02 4.593E-02 4.579E-02 4.554E-02 4.520E-02 4.476E-02 4.423E-02 4.360E-02 4.289E-02 4.208E-02 4.120E-02 4.023E-02 3.919E-02 3.808E-02 3.691E-02 3.568E-02 3.440E-02 3.307E-02 3.170E-02 3.030E-02 2.887E-02 2.741E-02 2.595E-02 2.448E-02 2.300E-02 2.153E-02 2.007E-02 1.863E-02 1.721E-02 1.583E-02 1.447E-02 1.316E-02 1.189E-02 1.068E-02 9.512E-03 8.405E-03 7.359E-03 6.378E-03 5.463E-03 4.616E-03 3.314E-03 4.033E-03 4.823E-03 5.682E-03 6.608E-03 7.599E-03 8.652E-03 9.765E-03 1.093E-02 1.215E-02 1.342E-02 1.473E-02 1.609E-02 1.747E-02 1.888E-02 2.031E-02 2.176E-02 2.322E-02 2.469E-02 2.615E-02 2.760E-02 2.904E-02 3.046E-02 3.184E-02 3.320E-02 3.451E-02 3.578E-02 3.699E-02 3.815E-02 3.925E-02 4.027E-02 4.122E-02 4.210E-02 4.289E-02 4.360E-02 4.422E-02 4.475E-02 4.519E-02 4.553E-02 4.578E-02 4.592E-02 4.597E-02 4.592E-02 4.578E-02 4.554E-02 4.520E-02 4.477E-02 4.425E-02 4.364E-02 4.295E-02 4.217E-02 4.132E-02 4.039E-02 3.940E-02 3.834E-02 3.723E-02 3.606E-02 3.484E-02 3.358E-02 3.229E-02 3.096E-02 2.961E-02 2.823E-02 2.685E-02 2.545E-02 2.406E-02 2.267E-02 2.128E-02 1.991E-02 1.856E-02 1.724E-02 1.594E-02 1.468E-02 1.345E-02 1.226E-02 1.112E-02 1.002E-02 8.978E-03 7.986E-03 7.048E-03 6.167E-03 5.344E-03 4.580E-03 3.877E-03 3.234E-03 2.651E-03 2.130E-03 1.668E-03 1.266E-03 9.228E-04 6.364E-04 4.056E-04 2.286E-04 1.036E-04 2.826E-05 2.914E-07 1.718E-05 7.627E-05 1.748E-04 3.098E-04 4.784E-04 6.775E-04 9.039E-04 1.155E-03 1.426E-03 1.716E-03 2.021E-03 2.337E-03 2.662E-03 2.992E-03 3.325E-03 3.658E-03 3.988E-03 4.312E-03 4.628E-03 4.933E-03 5.225E-03 5.502E-03 5.762E-03 6.003E-03 6.223E-03 6.421E-03 6.595E-03 6.745E-03 6.869E-03 6.966E-03 7.036E-03 7.078E-03 7.092E-03 7.078E-03 7.036E-03 6.966E-03 6.869E-03 6.745E-03 6.595E-03 6.421E-03 6.223E-03 6.003E-03 5.762E-03 5.502E-03 5.225E-03 4.933E-03 4.628E-03 4.312E-03 3.988E-03 3.658E-03 3.325E-03 2.992E-03 2.662E-03 2.337E-03 2.021E-03 1.716E-03 1.426E-03 1.155E-03 9.039E-04 6.775E-04 4.784E-04 3.098E-04 1.748E-04 7.627E-05 1.718E-05 2.914E-07 2.826E-05 1.036E-04 2.286E-04 4.056E-04 6.364E-04 9.228E-04 1.266E-03 1.668E-03 2.130E-03 2.651E-03 3.234E-03 3.877E-03 4.580E-03 5.344E-03 6.167E-03 7.048E-03 7.986E-03 8.978E-03 1.002E-02 1.112E-02 1.226E-02 1.345E-02 1.468E-02 1.594E-02 1.724E-02 1.856E-02 1.991E-02 2.128E-02 2.267E-02 2.406E-02 2.545E-02 2.685E-02 2.823E-02 2.961E-02 3.096E-02 3.229E-02 3.358E-02 3.484E-02 3.606E-02 3.723E-02 3.834E-02 3.940E-02 4.039E-02 4.132E-02 4.217E-02 4.295E-02 4.364E-02 4.425E-02 4.477E-02 4.520E-02 4.554E-02 4.578E-02 4.592E-02 4.597E-02 4.592E-02 4.578E-02 4.553E-02 4.519E-02 4.475E-02 4.422E-02 4.360E-02 4.289E-02 4.210E-02 4.122E-02 4.027E-02 3.925E-02 3.815E-02 3.699E-02 3.578E-02 3.451E-02 3.320E-02 3.184E-02 3.046E-02 2.904E-02 2.760E-02 2.615E-02 2.469E-02 2.322E-02 2.176E-02 2.031E-02 1.888E-02 1.747E-02 1.609E-02 1.473E-02 1.342E-02 1.215E-02 1.093E-02 9.765E-03 8.652E-03 7.599E-03 6.608E-03 5.682E-03 4.823E-03 4.033E-03 2.826E-03 3.488E-03 4.220E-03 5.021E-03 5.891E-03 6.826E-03 7.825E-03 8.884E-03 1.000E-02 1.117E-02 1.240E-02 1.366E-02 1.497E-02 1.632E-02 1.770E-02 1.911E-02 2.053E-02 2.197E-02 2.342E-02 2.487E-02 2.632E-02 2.776E-02 2.919E-02 3.059E-02 3.196E-02 3.330E-02 3.460E-02 3.585E-02 3.705E-02 3.820E-02 3.928E-02 4.029E-02 4.123E-02 4.210E-02 4.289E-02 4.359E-02 4.420E-02 4.473E-02 4.517E-02 4.551E-02 4.576E-02 4.591E-02 4.597E-02 4.593E-02 4.580E-02 4.558E-02 4.526E-02 4.485E-02 4.435E-02 4.377E-02 4.310E-02 4.236E-02 4.154E-02 4.064E-02 3.969E-02 3.866E-02 3.758E-02 3.645E-02 3.527E-02 3.405E-02 3.280E-02 3.151E-02 3.019E-02 2.886E-02 2.751E-02 2.615E-02 2.479E-02 2.343E-02 2.207E-02 2.073E-02 1.940E-02 1.810E-02 1.682E-02 1.557E-02 1.435E-02 1.317E-02 1.204E-02 1.094E-02 9.890E-03 8.888E-03 7.937E-03 7.039E-03 6.193E-03 5.403E-03 4.668E-03 3.989E-03 3.367E-03 2.801E-03 2.290E-03 1.835E-03 1.434E-03 1.086E-03 7.903E-04 5.445E-04 3.472E-04 1.963E-04 8.981E-05 2.532E-05 4.667E-07 1.271E-05 5.944E-05 1.379E-04 2.454E-04 3.791E-04 5.360E-04 7.135E-04 9.085E-04 1.118E-03 1.340E-03 1.571E-03 1.808E-03 2.049E-03 2.291E-03 2.532E-03 2.770E-03 3.001E-03 3.224E-03 3.437E-03 3.639E-03 3.826E-03 3.998E-03 4.153E-03 4.291E-03 4.409E-03 4.506E-03 4.583E-03 4.639E-03 4.672E-03 4.683E-03 4.672E-03 4.639E-03 4.583E-03 4.506E-03 4.409E-03 4.291E-03 4.153E-03 3.998E-03 3.826E-03 3.639E-03 3.437E-03 3.224E-03 3.001E-03 2.770E-03 2.532E-03 2.291E-03 2.049E-03 1.808E-03 1.571E-03 1.340E-03 1.118E-03 9.085E-04 7.135E-04 5.360E-04 3.791E-04 2.454E-04 1.379E-04 5.944E-05 1.271E-05 4.667E-07 2.532E-05 8.981E-05 1.963E-04 3.472E-04 5.445E-04 7.903E-04 1.086E-03 1.434E-03 1.835E-03 2.290E-03 2.801E-03 3.367E-03 3.989E-03 4.668E-03 5.403E-03 6.193E-03 7.039E-03 7.937E-03 8.888E-03 9.890E-03 1.094E-02 1.204E-02 1.317E-02 1.435E-02 1.557E-02 1.682E-02 1.810E-02 1.940E-02 2.073E-02 2.207E-02 2.343E-02 2.479E-02 2.615E-02 2.751E-02 2.886E-02 3.019E-02 3.151E-02 3.280E-02 3.405E-02 3.527E-02 3.645E-02 3.758E-02 3.866E-02 3.969E-02 4.064E-02 4.154E-02 4.236E-02 4.310E-02 4.377E-02 4.435E-02 4.485E-02 4.526E-02 4.558E-02 4.580E-02 4.593E-02 4.597E-02 4.591E-02 4.576E-02 4.551E-02 4.517E-02 4.473E-02 4.420E-02 4.359E-02 4.289E-02 4.210E-02 4.123E-02 4.029E-02 3.928E-02 3.820E-02 3.705E-02 3.585E-02 3.460E-02 3.330E-02 3.196E-02 3.059E-02 2.919E-02 2.776E-02 2.632E-02 2.487E-02 2.342E-02 2.197E-02 2.053E-02 1.911E-02 1.770E-02 1.632E-02 1.497E-02 1.366E-02 1.240E-02 1.117E-02 1.000E-02 8.884E-03 7.825E-03 6.826E-03 5.891E-03 5.021E-03 4.220E-03 3.488E-03 2.375E-03 2.980E-03 3.654E-03 4.398E-03 5.210E-03 6.089E-03 7.032E-03 8.037E-03 9.102E-03 1.022E-02 1.140E-02 1.262E-02 1.389E-02 1.519E-02 1.654E-02 1.791E-02 1.931E-02 2.072E-02 2.215E-02 2.359E-02 2.503E-02 2.647E-02 2.790E-02 2.931E-02 3.069E-02 3.205E-02 3.338E-02 3.466E-02 3.590E-02 3.709E-02 3.822E-02 3.929E-02 4.029E-02 4.122E-02 4.208E-02 4.286E-02 4.356E-02 4.417E-02 4.470E-02 4.514E-02 4.548E-02 4.574E-02 4.590E-02 4.597E-02 4.594E-02 4.583E-02 4.562E-02 4.532E-02 4.494E-02 4.446E-02 4.391E-02 4.327E-02 4.256E-02 4.177E-02 4.091E-02 3.999E-02 3.901E-02 3.796E-02 3.687E-02 3.573E-02 3.455E-02 3.333E-02 3.209E-02 3.081E-02 2.951E-02 2.820E-02 2.688E-02 2.555E-02 2.423E-02 2.290E-02 2.159E-02 2.029E-02 1.901E-02 1.775E-02 1.652E-02 1.531E-02 1.414E-02 1.301E-02 1.192E-02 1.087E-02 9.859E-03 8.898E-03 7.986E-03 7.122E-03 6.309E-03 5.548E-03 4.838E-03 4.180E-03 3.575E-03 3.021E-03 2.518E-03 2.066E-03 1.663E-03 1.309E-03 1.001E-03 7.385E-04 5.195E-04 3.421E-04 2.042E-04 1.036E-04 3.801E-05 5.093E-06 2.384E-06 2.738E-05 7.755E-05 1.503E-04 2.431E-04 3.533E-04 4.784E-04 6.158E-04 7.631E-04 9.178E-04 1.078E-03 1.240E-03 1.403E-03 1.565E-03 1.723E-03 1.875E-03 2.021E-03 2.157E-03 2.284E-03 2.399E-03 2.501E-03 2.589E-03 2.662E-03 2.720E-03 2.761E-03 2.786E-03 2.795E-03 2.786E-03 2.761E-03 2.720E-03 2.662E-03 2.589E-03 2.501E-03 2.399E-03 2.284E-03 2.157E-03 2.021E-03 1.875E-03 1.723E-03 1.565E-03 1.403E-03 1.240E-03 1.078E-03 9.178E-04 7.631E-04 6.158E-04 4.784E-04 3.533E-04 2.431E-04 1.503E-04 7.755E-05 2.738E-05 2.384E-06 5.093E-06 3.801E-05 1.036E-04 2.042E-04 3.421E-04 5.195E-04 7.385E-04 1.001E-03 1.309E-03 1.663E-03 2.066E-03 2.518E-03 3.021E-03 3.575E-03 4.180E-03 4.838E-03 5.548E-03 6.309E-03 7.122E-03 7.986E-03 8.898E-03 9.859E-03 1.087E-02 1.192E-02 1.301E-02 1.414E-02 1.531E-02 1.652E-02 1.775E-02 1.901E-02 2.029E-02 2.159E-02 2.290E-02 2.423E-02 2.555E-02 2.688E-02 2.820E-02 2.951E-02 3.081E-02 3.209E-02 3.333E-02 3.455E-02 3.573E-02 3.687E-02 3.796E-02 3.901E-02 3.999E-02 4.091E-02 4.177E-02 4.256E-02 4.327E-02 4.391E-02 4.446E-02 4.494E-02 4.532E-02 4.562E-02 4.583E-02 4.594E-02 4.597E-02 4.590E-02 4.574E-02 4.548E-02 4.514E-02 4.470E-02 4.417E-02 4.356E-02 4.286E-02 4.208E-02 4.122E-02 4.029E-02 3.929E-02 3.822E-02 3.709E-02 3.590E-02 3.466E-02 3.338E-02 3.205E-02 3.069E-02 2.931E-02 2.790E-02 2.647E-02 2.503E-02 2.359E-02 2.215E-02 2.072E-02 1.931E-02 1.791E-02 1.654E-02 1.519E-02 1.389E-02 1.262E-02 1.140E-02 1.022E-02 9.102E-03 8.037E-03 7.032E-03 6.089E-03 5.210E-03 4.398E-03 3.654E-03 2.980E-03 1.963E-03 2.511E-03 3.128E-03 3.814E-03 4.568E-03 5.389E-03 6.276E-03 7.225E-03 8.235E-03 9.303E-03 1.043E-02 1.160E-02 1.282E-02 1.409E-02 1.539E-02 1.673E-02 1.809E-02 1.948E-02 2.089E-02 2.231E-02 2.374E-02 2.517E-02 2.659E-02 2.800E-02 2.940E-02 3.077E-02 3.212E-02 3.343E-02 3.470E-02 3.593E-02 3.710E-02 3.822E-02 3.928E-02 4.027E-02 4.120E-02 4.205E-02 4.282E-02 4.352E-02 4.413E-02 4.466E-02 4.510E-02 4.545E-02 4.571E-02 4.588E-02 4.596E-02 4.596E-02 4.586E-02 4.567E-02 4.539E-02 4.503E-02 4.458E-02 4.406E-02 4.345E-02 4.277E-02 4.202E-02 4.120E-02 4.031E-02 3.937E-02 3.837E-02 3.731E-02 3.622E-02 3.508E-02 3.390E-02 3.269E-02 3.146E-02 3.020E-02 2.893E-02 2.765E-02 2.635E-02 2.506E-02 2.377E-02 2.249E-02 2.122E-02 1.996E-02 1.872E-02 1.751E-02 1.632E-02 1.517E-02 1.404E-02 1.296E-02 1.191E-02 1.090E-02 9.931E-03 9.008E-03 8.131E-03 7.300E-03 6.516E-03 5.780E-03 5.093E-03 4.453E-03 3.862E-03 3.318E-03 2.820E-03 2.369E-03 1.963E-03 1.601E-03 1.280E-03 1.001E-03 7.605E-04 5.573E-04 3.892E-04 2.544E-04 1.507E-04 7.576E-05 2.751E-05 3.609E-06 1.764E-06 1.967E-05 5.502E-05 1.055E-04 1.690E-04 2.431E-04 3.258E-04 4.149E-04 5.085E-04 6.046E-04 7.014E-04 7.971E-04 8.902E-04 9.791E-04 1.062E-03 1.139E-03 1.208E-03 1.267E-03 1.317E-03 1.357E-03 1.386E-03 1.403E-03 1.409E-03 1.403E-03 1.386E-03 1.357E-03 1.317E-03 1.267E-03 1.208E-03 1.139E-03 1.062E-03 9.791E-04 8.902E-04 7.971E-04 7.014E-04 6.046E-04 5.085E-04 4.149E-04 3.258E-04 2.431E-04 1.690E-04 1.055E-04 5.502E-05 1.967E-05 1.764E-06 3.609E-06 2.751E-05 7.576E-05 1.507E-04 2.544E-04 3.892E-04 5.573E-04 7.605E-04 1.001E-03 1.280E-03 1.601E-03 1.963E-03 2.369E-03 2.820E-03 3.318E-03 3.862E-03 4.453E-03 5.093E-03 5.780E-03 6.516E-03 7.300E-03 8.131E-03 9.008E-03 9.931E-03 1.090E-02 1.191E-02 1.296E-02 1.404E-02 1.517E-02 1.632E-02 1.751E-02 1.872E-02 1.996E-02 2.122E-02 2.249E-02 2.377E-02 2.506E-02 2.635E-02 2.765E-02 2.893E-02 3.020E-02 3.146E-02 3.269E-02 3.390E-02 3.508E-02 3.622E-02 3.731E-02 3.837E-02 3.937E-02 4.031E-02 4.120E-02 4.202E-02 4.277E-02 4.345E-02 4.406E-02 4.458E-02 4.503E-02 4.539E-02 4.567E-02 4.586E-02 4.596E-02 4.596E-02 4.588E-02 4.571E-02 4.545E-02 4.510E-02 4.466E-02 4.413E-02 4.352E-02 4.282E-02 4.205E-02 4.120E-02 4.027E-02 3.928E-02 3.822E-02 3.710E-02 3.593E-02 3.470E-02 3.343E-02 3.212E-02 3.077E-02 2.940E-02 2.800E-02 2.659E-02 2.517E-02 2.374E-02 2.231E-02 2.089E-02 1.948E-02 1.809E-02 1.673E-02 1.539E-02 1.409E-02 1.282E-02 1.160E-02 1.043E-02 9.303E-03 8.235E-03 7.225E-03 6.276E-03 5.389E-03 4.568E-03 3.814E-03 3.128E-03 2.511E-03 1.589E-03 2.081E-03 2.641E-03 3.269E-03 3.965E-03 4.729E-03 5.557E-03 6.450E-03 7.404E-03 8.418E-03 9.488E-03 1.061E-02 1.179E-02 1.300E-02 1.427E-02 1.556E-02 1.689E-02 1.825E-02 1.963E-02 2.103E-02 2.244E-02 2.386E-02 2.527E-02 2.668E-02 2.808E-02 2.947E-02 3.083E-02 3.216E-02 3.345E-02 3.471E-02 3.593E-02 3.709E-02 3.820E-02 3.925E-02 4.023E-02 4.115E-02 4.199E-02 4.277E-02 4.346E-02 4.407E-02 4.460E-02 4.505E-02 4.541E-02 4.568E-02 4.586E-02 4.596E-02 4.596E-02 4.588E-02 4.572E-02 4.547E-02 4.513E-02 4.471E-02 4.422E-02 4.364E-02 4.300E-02 4.228E-02 4.150E-02 4.065E-02 3.975E-02 3.879E-02 3.778E-02 3.672E-02 3.562E-02 3.449E-02 3.333E-02 3.213E-02 3.092E-02 2.969E-02 2.844E-02 2.719E-02 2.593E-02 2.468E-02 2.343E-02 2.218E-02 2.096E-02 1.974E-02 1.855E-02 1.739E-02 1.625E-02 1.513E-02 1.405E-02 1.301E-02 1.200E-02 1.103E-02 1.011E-02 9.219E-03 8.375E-03 7.574E-03 6.817E-03 6.105E-03 5.437E-03 4.814E-03 4.234E-03 3.699E-03 3.206E-03 2.755E-03 2.345E-03 1.974E-03 1.642E-03 1.347E-03 1.086E-03 8.593E-04 6.639E-04 4.981E-04 3.601E-04 2.478E-04 1.593E-04 9.249E-05 4.531E-05 1.574E-05 1.762E-06 1.402E-06 1.271E-05 3.381E-05 6.286E-05 9.812E-05 1.379E-04 1.807E-04 2.249E-04 2.693E-04 3.124E-04 3.533E-04 3.908E-04 4.241E-04 4.524E-04 4.751E-04 4.916E-04 5.017E-04 5.051E-04 5.017E-04 4.916E-04 4.751E-04 4.524E-04 4.241E-04 3.908E-04 3.533E-04 3.124E-04 2.693E-04 2.249E-04 1.807E-04 1.379E-04 9.812E-05 6.286E-05 3.381E-05 1.271E-05 1.402E-06 1.762E-06 1.574E-05 4.531E-05 9.249E-05 1.593E-04 2.478E-04 3.601E-04 4.981E-04 6.639E-04 8.593E-04 1.086E-03 1.347E-03 1.642E-03 1.974E-03 2.345E-03 2.755E-03 3.206E-03 3.699E-03 4.234E-03 4.814E-03 5.437E-03 6.105E-03 6.817E-03 7.574E-03 8.375E-03 9.219E-03 1.011E-02 1.103E-02 1.200E-02 1.301E-02 1.405E-02 1.513E-02 1.625E-02 1.739E-02 1.855E-02 1.974E-02 2.096E-02 2.218E-02 2.343E-02 2.468E-02 2.593E-02 2.719E-02 2.844E-02 2.969E-02 3.092E-02 3.213E-02 3.333E-02 3.449E-02 3.562E-02 3.672E-02 3.778E-02 3.879E-02 3.975E-02 4.065E-02 4.150E-02 4.228E-02 4.300E-02 4.364E-02 4.422E-02 4.471E-02 4.513E-02 4.547E-02 4.572E-02 4.588E-02 4.596E-02 4.596E-02 4.586E-02 4.568E-02 4.541E-02 4.505E-02 4.460E-02 4.407E-02 4.346E-02 4.277E-02 4.199E-02 4.115E-02 4.023E-02 3.925E-02 3.820E-02 3.709E-02 3.593E-02 3.471E-02 3.345E-02 3.216E-02 3.083E-02 2.947E-02 2.808E-02 2.668E-02 2.527E-02 2.386E-02 2.244E-02 2.103E-02 1.963E-02 1.825E-02 1.689E-02 1.556E-02 1.427E-02 1.300E-02 1.179E-02 1.061E-02 9.488E-03 8.418E-03 7.404E-03 6.450E-03 5.557E-03 4.729E-03 3.965E-03 3.269E-03 2.641E-03 2.081E-03 1.255E-03 1.691E-03 2.194E-03 2.765E-03 3.403E-03 4.108E-03 4.879E-03 5.714E-03 6.611E-03 7.569E-03 8.586E-03 9.657E-03 1.078E-02 1.195E-02 1.317E-02 1.442E-02 1.572E-02 1.704E-02 1.839E-02 1.976E-02 2.115E-02 2.255E-02 2.395E-02 2.535E-02 2.675E-02 2.814E-02 2.951E-02 3.085E-02 3.217E-02 3.345E-02 3.470E-02 3.590E-02 3.705E-02 3.815E-02 3.919E-02 4.017E-02 4.108E-02 4.192E-02 4.269E-02 4.339E-02 4.400E-02 4.453E-02 4.499E-02 4.535E-02 4.564E-02 4.583E-02 4.594E-02 4.597E-02 4.591E-02 4.577E-02 4.554E-02 4.523E-02 4.485E-02 4.438E-02 4.384E-02 4.323E-02 4.255E-02 4.181E-02 4.100E-02 4.014E-02 3.922E-02 3.826E-02 3.724E-02 3.619E-02 3.510E-02 3.398E-02 3.283E-02 3.166E-02 3.047E-02 2.927E-02 2.806E-02 2.684E-02 2.562E-02 2.440E-02 2.319E-02 2.199E-02 2.081E-02 1.964E-02 1.850E-02 1.737E-02 1.628E-02 1.521E-02 1.418E-02 1.317E-02 1.221E-02 1.128E-02 1.039E-02 9.533E-03 8.719E-03 7.947E-03 7.216E-03 6.525E-03 5.876E-03 5.268E-03 4.700E-03 4.173E-03 3.684E-03 3.234E-03 2.820E-03 2.443E-03 2.101E-03 1.791E-03 1.514E-03 1.266E-03 1.047E-03 8.554E-04 6.883E-04 5.445E-04 4.223E-04 3.197E-04 2.350E-04 1.664E-04 1.123E-04 7.095E-05 4.068E-05 1.993E-05 7.209E-06 1.084E-06 2.162E-07 3.357E-06 9.360E-06 1.718E-05 2.589E-05 3.466E-05 4.280E-05 4.974E-05 5.502E-05 5.831E-05 5.944E-05 5.831E-05 5.502E-05 4.974E-05 4.280E-05 3.466E-05 2.589E-05 1.718E-05 9.360E-06 3.357E-06 2.162E-07 1.084E-06 7.209E-06 1.993E-05 4.068E-05 7.095E-05 1.123E-04 1.664E-04 2.350E-04 3.197E-04 4.223E-04 5.445E-04 6.883E-04 8.554E-04 1.047E-03 1.266E-03 1.514E-03 1.791E-03 2.101E-03 2.443E-03 2.820E-03 3.234E-03 3.684E-03 4.173E-03 4.700E-03 5.268E-03 5.876E-03 6.525E-03 7.216E-03 7.947E-03 8.719E-03 9.533E-03 1.039E-02 1.128E-02 1.221E-02 1.317E-02 1.418E-02 1.521E-02 1.628E-02 1.737E-02 1.850E-02 1.964E-02 2.081E-02 2.199E-02 2.319E-02 2.440E-02 2.562E-02 2.684E-02 2.806E-02 2.927E-02 3.047E-02 3.166E-02 3.283E-02 3.398E-02 3.510E-02 3.619E-02 3.724E-02 3.826E-02 3.922E-02 4.014E-02 4.100E-02 4.181E-02 4.255E-02 4.323E-02 4.384E-02 4.438E-02 4.485E-02 4.523E-02 4.554E-02 4.577E-02 4.591E-02 4.597E-02 4.594E-02 4.583E-02 4.564E-02 4.535E-02 4.499E-02 4.453E-02 4.400E-02 4.339E-02 4.269E-02 4.192E-02 4.108E-02 4.017E-02 3.919E-02 3.815E-02 3.705E-02 3.590E-02 3.470E-02 3.345E-02 3.217E-02 3.085E-02 2.951E-02 2.814E-02 2.675E-02 2.535E-02 2.395E-02 2.255E-02 2.115E-02 1.976E-02 1.839E-02 1.704E-02 1.572E-02 1.442E-02 1.317E-02 1.195E-02 1.078E-02 9.657E-03 8.586E-03 7.569E-03 6.611E-03 5.714E-03 4.879E-03 4.108E-03 3.403E-03 2.765E-03 2.194E-03 1.691E-03 9.609E-04 1.342E-03 1.789E-03 2.302E-03 2.882E-03 3.529E-03 4.241E-03 5.018E-03 5.858E-03 6.759E-03 7.720E-03 8.737E-03 9.807E-03 1.093E-02 1.210E-02 1.331E-02 1.456E-02 1.584E-02 1.716E-02 1.850E-02 1.986E-02 2.124E-02 2.263E-02 2.402E-02 2.541E-02 2.679E-02 2.816E-02 2.952E-02 3.085E-02 3.216E-02 3.343E-02 3.466E-02 3.585E-02 3.699E-02 3.808E-02 3.912E-02 4.009E-02 4.100E-02 4.183E-02 4.260E-02 4.330E-02 4.391E-02 4.445E-02 4.491E-02 4.529E-02 4.559E-02 4.580E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.562E-02 4.534E-02 4.498E-02 4.455E-02 4.405E-02 4.347E-02 4.283E-02 4.213E-02 4.137E-02 4.054E-02 3.967E-02 3.875E-02 3.778E-02 3.678E-02 3.573E-02 3.466E-02 3.355E-02 3.243E-02 3.128E-02 3.012E-02 2.895E-02 2.777E-02 2.659E-02 2.541E-02 2.424E-02 2.307E-02 2.192E-02 2.078E-02 1.965E-02 1.855E-02 1.748E-02 1.643E-02 1.540E-02 1.441E-02 1.345E-02 1.252E-02 1.163E-02 1.077E-02 9.951E-03 9.169E-03 8.424E-03 7.717E-03 7.048E-03 6.417E-03 5.824E-03 5.268E-03 4.749E-03 4.265E-03 3.817E-03 3.402E-03 3.021E-03 2.671E-03 2.351E-03 2.060E-03 1.797E-03 1.559E-03 1.347E-03 1.157E-03 9.884E-04 8.399E-04 7.096E-04 5.962E-04 4.981E-04 4.139E-04 3.421E-04 2.815E-04 2.307E-04 1.886E-04 1.541E-04 1.261E-04 1.036E-04 8.587E-05 7.214E-05 6.178E-05 5.426E-05 4.919E-05 4.626E-05 4.531E-05 4.626E-05 4.919E-05 5.426E-05 6.178E-05 7.214E-05 8.587E-05 1.036E-04 1.261E-04 1.541E-04 1.886E-04 2.307E-04 2.815E-04 3.421E-04 4.139E-04 4.981E-04 5.962E-04 7.096E-04 8.399E-04 9.884E-04 1.157E-03 1.347E-03 1.559E-03 1.797E-03 2.060E-03 2.351E-03 2.671E-03 3.021E-03 3.402E-03 3.817E-03 4.265E-03 4.749E-03 5.268E-03 5.824E-03 6.417E-03 7.048E-03 7.717E-03 8.424E-03 9.169E-03 9.951E-03 1.077E-02 1.163E-02 1.252E-02 1.345E-02 1.441E-02 1.540E-02 1.643E-02 1.748E-02 1.855E-02 1.965E-02 2.078E-02 2.192E-02 2.307E-02 2.424E-02 2.541E-02 2.659E-02 2.777E-02 2.895E-02 3.012E-02 3.128E-02 3.243E-02 3.355E-02 3.466E-02 3.573E-02 3.678E-02 3.778E-02 3.875E-02 3.967E-02 4.054E-02 4.137E-02 4.213E-02 4.283E-02 4.347E-02 4.405E-02 4.455E-02 4.498E-02 4.534E-02 4.562E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.580E-02 4.559E-02 4.529E-02 4.491E-02 4.445E-02 4.391E-02 4.330E-02 4.260E-02 4.183E-02 4.100E-02 4.009E-02 3.912E-02 3.808E-02 3.699E-02 3.585E-02 3.466E-02 3.343E-02 3.216E-02 3.085E-02 2.952E-02 2.816E-02 2.679E-02 2.541E-02 2.402E-02 2.263E-02 2.124E-02 1.986E-02 1.850E-02 1.716E-02 1.584E-02 1.456E-02 1.331E-02 1.210E-02 1.093E-02 9.807E-03 8.737E-03 7.720E-03 6.759E-03 5.858E-03 5.018E-03 4.241E-03 3.529E-03 2.882E-03 2.302E-03 1.789E-03 1.342E-03 7.064E-04 1.033E-03 1.424E-03 1.881E-03 2.404E-03 2.992E-03 3.646E-03 4.364E-03 5.146E-03 5.989E-03 6.893E-03 7.854E-03 8.871E-03 9.940E-03 1.106E-02 1.222E-02 1.343E-02 1.467E-02 1.595E-02 1.726E-02 1.859E-02 1.994E-02 2.130E-02 2.268E-02 2.406E-02 2.543E-02 2.681E-02 2.816E-02 2.951E-02 3.083E-02 3.212E-02 3.338E-02 3.460E-02 3.578E-02 3.691E-02 3.799E-02 3.902E-02 3.999E-02 4.089E-02 4.173E-02 4.250E-02 4.319E-02 4.381E-02 4.436E-02 4.483E-02 4.522E-02 4.553E-02 4.575E-02 4.590E-02 4.597E-02 4.595E-02 4.586E-02 4.569E-02 4.544E-02 4.512E-02 4.472E-02 4.425E-02 4.372E-02 4.312E-02 4.246E-02 4.174E-02 4.096E-02 4.013E-02 3.926E-02 3.834E-02 3.738E-02 3.638E-02 3.535E-02 3.429E-02 3.321E-02 3.211E-02 3.100E-02 2.987E-02 2.873E-02 2.759E-02 2.645E-02 2.531E-02 2.418E-02 2.306E-02 2.195E-02 2.085E-02 1.978E-02 1.872E-02 1.769E-02 1.668E-02 1.571E-02 1.475E-02 1.383E-02 1.295E-02 1.209E-02 1.127E-02 1.048E-02 9.726E-03 9.008E-03 8.326E-03 7.678E-03 7.066E-03 6.489E-03 5.946E-03 5.437E-03 4.961E-03 4.516E-03 4.103E-03 3.721E-03 3.367E-03 3.041E-03 2.742E-03 2.468E-03 2.218E-03 1.991E-03 1.786E-03 1.601E-03 1.434E-03 1.285E-03 1.152E-03 1.035E-03 9.309E-04 8.399E-04 7.605E-04 6.919E-04 6.330E-04 5.831E-04 5.414E-04 5.072E-04 4.801E-04 4.594E-04 4.450E-04 4.364E-04 4.335E-04 4.364E-04 4.450E-04 4.594E-04 4.801E-04 5.072E-04 5.414E-04 5.831E-04 6.330E-04 6.919E-04 7.605E-04 8.399E-04 9.309E-04 1.035E-03 1.152E-03 1.285E-03 1.434E-03 1.601E-03 1.786E-03 1.991E-03 2.218E-03 2.468E-03 2.742E-03 3.041E-03 3.367E-03 3.721E-03 4.103E-03 4.516E-03 4.961E-03 5.437E-03 5.946E-03 6.489E-03 7.066E-03 7.678E-03 8.326E-03 9.008E-03 9.726E-03 1.048E-02 1.127E-02 1.209E-02 1.295E-02 1.383E-02 1.475E-02 1.571E-02 1.668E-02 1.769E-02 1.872E-02 1.978E-02 2.085E-02 2.195E-02 2.306E-02 2.418E-02 2.531E-02 2.645E-02 2.759E-02 2.873E-02 2.987E-02 3.100E-02 3.211E-02 3.321E-02 3.429E-02 3.535E-02 3.638E-02 3.738E-02 3.834E-02 3.926E-02 4.013E-02 4.096E-02 4.174E-02 4.246E-02 4.312E-02 4.372E-02 4.425E-02 4.472E-02 4.512E-02 4.544E-02 4.569E-02 4.586E-02 4.595E-02 4.597E-02 4.590E-02 4.575E-02 4.553E-02 4.522E-02 4.483E-02 4.436E-02 4.381E-02 4.319E-02 4.250E-02 4.173E-02 4.089E-02 3.999E-02 3.902E-02 3.799E-02 3.691E-02 3.578E-02 3.460E-02 3.338E-02 3.212E-02 3.083E-02 2.951E-02 2.816E-02 2.681E-02 2.543E-02 2.406E-02 2.268E-02 2.130E-02 1.994E-02 1.859E-02 1.726E-02 1.595E-02 1.467E-02 1.343E-02 1.222E-02 1.106E-02 9.940E-03 8.871E-03 7.854E-03 6.893E-03 5.989E-03 5.146E-03 4.364E-03 3.646E-03 2.992E-03 2.404E-03 1.881E-03 1.424E-03 1.033E-03 4.916E-04 7.652E-04 1.102E-03 1.503E-03 1.969E-03 2.499E-03 3.094E-03 3.754E-03 4.477E-03 5.262E-03 6.108E-03 7.012E-03 7.973E-03 8.988E-03 1.005E-02 1.117E-02 1.233E-02 1.353E-02 1.476E-02 1.603E-02 1.733E-02 1.865E-02 1.999E-02 2.134E-02 2.270E-02 2.407E-02 2.543E-02 2.679E-02 2.814E-02 2.947E-02 3.077E-02 3.205E-02 3.330E-02 3.451E-02 3.568E-02 3.681E-02 3.788E-02 3.890E-02 3.986E-02 4.076E-02 4.160E-02 4.237E-02 4.307E-02 4.370E-02 4.425E-02 4.473E-02 4.513E-02 4.545E-02 4.570E-02 4.587E-02 4.596E-02 4.597E-02 4.590E-02 4.576E-02 4.554E-02 4.525E-02 4.489E-02 4.446E-02 4.397E-02 4.341E-02 4.279E-02 4.211E-02 4.138E-02 4.060E-02 3.977E-02 3.890E-02 3.799E-02 3.704E-02 3.606E-02 3.505E-02 3.402E-02 3.296E-02 3.189E-02 3.081E-02 2.972E-02 2.862E-02 2.752E-02 2.642E-02 2.532E-02 2.424E-02 2.316E-02 2.210E-02 2.105E-02 2.002E-02 1.901E-02 1.802E-02 1.706E-02 1.612E-02 1.521E-02 1.433E-02 1.348E-02 1.266E-02 1.187E-02 1.112E-02 1.040E-02 9.706E-03 9.048E-03 8.424E-03 7.832E-03 7.272E-03 6.744E-03 6.247E-03 5.780E-03 5.344E-03 4.936E-03 4.556E-03 4.203E-03 3.877E-03 3.575E-03 3.296E-03 3.041E-03 2.807E-03 2.594E-03 2.400E-03 2.224E-03 2.066E-03 1.924E-03 1.797E-03 1.684E-03 1.585E-03 1.499E-03 1.424E-03 1.361E-03 1.309E-03 1.266E-03 1.234E-03 1.211E-03 1.197E-03 1.193E-03 1.197E-03 1.211E-03 1.234E-03 1.266E-03 1.309E-03 1.361E-03 1.424E-03 1.499E-03 1.585E-03 1.684E-03 1.797E-03 1.924E-03 2.066E-03 2.224E-03 2.400E-03 2.594E-03 2.807E-03 3.041E-03 3.296E-03 3.575E-03 3.877E-03 4.203E-03 4.556E-03 4.936E-03 5.344E-03 5.780E-03 6.247E-03 6.744E-03 7.272E-03 7.832E-03 8.424E-03 9.048E-03 9.706E-03 1.040E-02 1.112E-02 1.187E-02 1.266E-02 1.348E-02 1.433E-02 1.521E-02 1.612E-02 1.706E-02 1.802E-02 1.901E-02 2.002E-02 2.105E-02 2.210E-02 2.316E-02 2.424E-02 2.532E-02 2.642E-02 2.752E-02 2.862E-02 2.972E-02 3.081E-02 3.189E-02 3.296E-02 3.402E-02 3.505E-02 3.606E-02 3.704E-02 3.799E-02 3.890E-02 3.977E-02 4.060E-02 4.138E-02 4.211E-02 4.279E-02 4.341E-02 4.397E-02 4.446E-02 4.489E-02 4.525E-02 4.554E-02 4.576E-02 4.590E-02 4.597E-02 4.596E-02 4.587E-02 4.570E-02 4.545E-02 4.513E-02 4.473E-02 4.425E-02 4.370E-02 4.307E-02 4.237E-02 4.160E-02 4.076E-02 3.986E-02 3.890E-02 3.788E-02 3.681E-02 3.568E-02 3.451E-02 3.330E-02 3.205E-02 3.077E-02 2.947E-02 2.814E-02 2.679E-02 2.543E-02 2.407E-02 2.270E-02 2.134E-02 1.999E-02 1.865E-02 1.733E-02 1.603E-02 1.476E-02 1.353E-02 1.233E-02 1.117E-02 1.005E-02 8.988E-03 7.973E-03 7.012E-03 6.108E-03 5.262E-03 4.477E-03 3.754E-03 3.094E-03 2.499E-03 1.969E-03 1.503E-03 1.102E-03 7.652E-04 3.162E-04 5.381E-04 8.215E-04 1.167E-03 1.577E-03 2.050E-03 2.587E-03 3.188E-03 3.852E-03 4.578E-03 5.365E-03 6.212E-03 7.116E-03 8.076E-03 9.088E-03 1.015E-02 1.126E-02 1.241E-02 1.360E-02 1.483E-02 1.609E-02 1.738E-02 1.869E-02 2.001E-02 2.136E-02 2.270E-02 2.406E-02 2.541E-02 2.675E-02 2.808E-02 2.940E-02 3.069E-02 3.196E-02 3.320E-02 3.440E-02 3.556E-02 3.668E-02 3.774E-02 3.876E-02 3.972E-02 4.062E-02 4.145E-02 4.222E-02 4.293E-02 4.356E-02 4.413E-02 4.462E-02 4.503E-02 4.537E-02 4.563E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.564E-02 4.538E-02 4.506E-02 4.467E-02 4.422E-02 4.370E-02 4.312E-02 4.249E-02 4.181E-02 4.107E-02 4.029E-02 3.947E-02 3.861E-02 3.771E-02 3.678E-02 3.582E-02 3.483E-02 3.383E-02 3.280E-02 3.177E-02 3.072E-02 2.967E-02 2.861E-02 2.755E-02 2.649E-02 2.544E-02 2.440E-02 2.337E-02 2.235E-02 2.135E-02 2.037E-02 1.940E-02 1.846E-02 1.754E-02 1.665E-02 1.578E-02 1.494E-02 1.413E-02 1.335E-02 1.260E-02 1.187E-02 1.118E-02 1.052E-02 9.890E-03 9.290E-03 8.719E-03 8.179E-03 7.669E-03 7.188E-03 6.735E-03 6.309E-03 5.911E-03 5.539E-03 5.193E-03 4.871E-03 4.572E-03 4.296E-03 4.042E-03 3.809E-03 3.596E-03 3.402E-03 3.227E-03 3.068E-03 2.927E-03 2.801E-03 2.690E-03 2.594E-03 2.512E-03 2.443E-03 2.388E-03 2.345E-03 2.314E-03 2.296E-03 2.290E-03 2.296E-03 2.314E-03 2.345E-03 2.388E-03 2.443E-03 2.512E-03 2.594E-03 2.690E-03 2.801E-03 2.927E-03 3.068E-03 3.227E-03 3.402E-03 3.596E-03 3.809E-03 4.042E-03 4.296E-03 4.572E-03 4.871E-03 5.193E-03 5.539E-03 5.911E-03 6.309E-03 6.735E-03 7.188E-03 7.669E-03 8.179E-03 8.719E-03 9.290E-03 9.890E-03 1.052E-02 1.118E-02 1.187E-02 1.260E-02 1.335E-02 1.413E-02 1.494E-02 1.578E-02 1.665E-02 1.754E-02 1.846E-02 1.940E-02 2.037E-02 2.135E-02 2.235E-02 2.337E-02 2.440E-02 2.544E-02 2.649E-02 2.755E-02 2.861E-02 2.967E-02 3.072E-02 3.177E-02 3.280E-02 3.383E-02 3.483E-02 3.582E-02 3.678E-02 3.771E-02 3.861E-02 3.947E-02 4.029E-02 4.107E-02 4.181E-02 4.249E-02 4.312E-02 4.370E-02 4.422E-02 4.467E-02 4.506E-02 4.538E-02 4.564E-02 4.582E-02 4.593E-02 4.597E-02 4.593E-02 4.582E-02 4.563E-02 4.537E-02 4.503E-02 4.462E-02 4.413E-02 4.356E-02 4.293E-02 4.222E-02 4.145E-02 4.062E-02 3.972E-02 3.876E-02 3.774E-02 3.668E-02 3.556E-02 3.440E-02 3.320E-02 3.196E-02 3.069E-02 2.940E-02 2.808E-02 2.675E-02 2.541E-02 2.406E-02 2.270E-02 2.136E-02 2.001E-02 1.869E-02 1.738E-02 1.609E-02 1.483E-02 1.360E-02 1.241E-02 1.126E-02 1.015E-02 9.088E-03 8.076E-03 7.116E-03 6.212E-03 5.365E-03 4.578E-03 3.852E-03 3.188E-03 2.587E-03 2.050E-03 1.577E-03 1.167E-03 8.215E-04 5.381E-04 1.800E-04 3.517E-04 5.828E-04 8.748E-04 1.229E-03 1.645E-03 2.124E-03 2.667E-03 3.272E-03 3.939E-03 4.667E-03 5.456E-03 6.302E-03 7.205E-03 8.162E-03 9.170E-03 1.023E-02 1.133E-02 1.248E-02 1.366E-02 1.488E-02 1.613E-02 1.740E-02 1.870E-02 2.001E-02 2.134E-02 2.268E-02 2.402E-02 2.535E-02 2.668E-02 2.800E-02 2.931E-02 3.059E-02 3.184E-02 3.307E-02 3.426E-02 3.541E-02 3.652E-02 3.758E-02 3.859E-02 3.955E-02 4.045E-02 4.128E-02 4.206E-02 4.277E-02 4.341E-02 4.398E-02 4.449E-02 4.492E-02 4.527E-02 4.556E-02 4.577E-02 4.590E-02 4.597E-02 4.596E-02 4.588E-02 4.573E-02 4.551E-02 4.522E-02 4.487E-02 4.446E-02 4.399E-02 4.346E-02 4.287E-02 4.223E-02 4.155E-02 4.082E-02 4.004E-02 3.923E-02 3.838E-02 3.750E-02 3.659E-02 3.566E-02 3.470E-02 3.373E-02 3.274E-02 3.174E-02 3.073E-02 2.972E-02 2.870E-02 2.769E-02 2.668E-02 2.567E-02 2.468E-02 2.369E-02 2.272E-02 2.177E-02 2.083E-02 1.991E-02 1.902E-02 1.815E-02 1.730E-02 1.647E-02 1.567E-02 1.490E-02 1.415E-02 1.344E-02 1.275E-02 1.209E-02 1.146E-02 1.086E-02 1.028E-02 9.736E-03 9.219E-03 8.729E-03 8.267E-03 7.832E-03 7.422E-03 7.039E-03 6.680E-03 6.345E-03 6.034E-03 5.746E-03 5.479E-03 5.234E-03 5.010E-03 4.805E-03 4.620E-03 4.453E-03 4.304E-03 4.173E-03 4.058E-03 3.959E-03 3.877E-03 3.809E-03 3.758E-03 3.721E-03 3.699E-03 3.691E-03 3.699E-03 3.721E-03 3.758E-03 3.809E-03 3.877E-03 3.959E-03 4.058E-03 4.173E-03 4.304E-03 4.453E-03 4.620E-03 4.805E-03 5.010E-03 5.234E-03 5.479E-03 5.746E-03 6.034E-03 6.345E-03 6.680E-03 7.039E-03 7.422E-03 7.832E-03 8.267E-03 8.729E-03 9.219E-03 9.736E-03 1.028E-02 1.086E-02 1.146E-02 1.209E-02 1.275E-02 1.344E-02 1.415E-02 1.490E-02 1.567E-02 1.647E-02 1.730E-02 1.815E-02 1.902E-02 1.991E-02 2.083E-02 2.177E-02 2.272E-02 2.369E-02 2.468E-02 2.567E-02 2.668E-02 2.769E-02 2.870E-02 2.972E-02 3.073E-02 3.174E-02 3.274E-02 3.373E-02 3.470E-02 3.566E-02 3.659E-02 3.750E-02 3.838E-02 3.923E-02 4.004E-02 4.082E-02 4.155E-02 4.223E-02 4.287E-02 4.346E-02 4.399E-02 4.446E-02 4.487E-02 4.522E-02 4.551E-02 4.573E-02 4.588E-02 4.596E-02 4.597E-02 4.590E-02 4.577E-02 4.556E-02 4.527E-02 4.492E-02 4.449E-02 4.398E-02 4.341E-02 4.277E-02 4.206E-02 4.128E-02 4.045E-02 3.955E-02 3.859E-02 3.758E-02 3.652E-02 3.541E-02 3.426E-02 3.307E-02 3.184E-02 3.059E-02 2.931E-02 2.800E-02 2.668E-02 2.535E-02 2.402E-02 2.268E-02 2.134E-02 2.001E-02 1.870E-02 1.740E-02 1.613E-02 1.488E-02 1.366E-02 1.248E-02 1.133E-02 1.023E-02 9.170E-03 8.162E-03 7.205E-03 6.302E-03 5.456E-03 4.667E-03 3.939E-03 3.272E-03 2.667E-03 2.124E-03 1.645E-03 1.229E-03 8.748E-04 5.828E-04 3.517E-04 8.243E-05 2.054E-04 3.858E-04 6.251E-04 9.246E-04 1.285E-03 1.708E-03 2.192E-03 2.738E-03 3.347E-03 4.016E-03 4.745E-03 5.533E-03 6.378E-03 7.278E-03 8.231E-03 9.234E-03 1.029E-02 1.138E-02 1.252E-02 1.369E-02 1.490E-02 1.614E-02 1.740E-02 1.869E-02 1.999E-02 2.130E-02 2.263E-02 2.395E-02 2.527E-02 2.659E-02 2.790E-02 2.919E-02 3.046E-02 3.170E-02 3.292E-02 3.410E-02 3.524E-02 3.634E-02 3.740E-02 3.840E-02 3.936E-02 4.026E-02 4.110E-02 4.187E-02 4.259E-02 4.324E-02 4.382E-02 4.434E-02 4.478E-02 4.516E-02 4.546E-02 4.570E-02 4.586E-02 4.595E-02 4.597E-02 4.592E-02 4.581E-02 4.562E-02 4.538E-02 4.507E-02 4.470E-02 4.427E-02 4.378E-02 4.324E-02 4.266E-02 4.202E-02 4.134E-02 4.061E-02 3.985E-02 3.905E-02 3.823E-02 3.737E-02 3.649E-02 3.558E-02 3.466E-02 3.372E-02 3.277E-02 3.181E-02 3.084E-02 2.987E-02 2.890E-02 2.793E-02 2.697E-02 2.601E-02 2.506E-02 2.413E-02 2.320E-02 2.230E-02 2.141E-02 2.054E-02 1.969E-02 1.886E-02 1.805E-02 1.727E-02 1.652E-02 1.578E-02 1.508E-02 1.440E-02 1.375E-02 1.312E-02 1.252E-02 1.195E-02 1.140E-02 1.089E-02 1.040E-02 9.931E-03 9.492E-03 9.078E-03 8.690E-03 8.326E-03 7.986E-03 7.669E-03 7.375E-03 7.104E-03 6.854E-03 6.625E-03 6.417E-03 6.229E-03 6.061E-03 5.911E-03 5.780E-03 5.668E-03 5.573E-03 5.496E-03 5.437E-03 5.395E-03 5.369E-03 5.361E-03 5.369E-03 5.395E-03 5.437E-03 5.496E-03 5.573E-03 5.668E-03 5.780E-03 5.911E-03 6.061E-03 6.229E-03 6.417E-03 6.625E-03 6.854E-03 7.104E-03 7.375E-03 7.669E-03 7.986E-03 8.326E-03 8.690E-03 9.078E-03 9.492E-03 9.931E-03 1.040E-02 1.089E-02 1.140E-02 1.195E-02 1.252E-02 1.312E-02 1.375E-02 1.440E-02 1.508E-02 1.578E-02 1.652E-02 1.727E-02 1.805E-02 1.886E-02 1.969E-02 2.054E-02 2.141E-02 2.230E-02 2.320E-02 2.413E-02 2.506E-02 2.601E-02 2.697E-02 2.793E-02 2.890E-02 2.987E-02 3.084E-02 3.181E-02 3.277E-02 3.372E-02 3.466E-02 3.558E-02 3.649E-02 3.737E-02 3.823E-02 3.905E-02 3.985E-02 4.061E-02 4.134E-02 4.202E-02 4.266E-02 4.324E-02 4.378E-02 4.427E-02 4.470E-02 4.507E-02 4.538E-02 4.562E-02 4.581E-02 4.592E-02 4.597E-02 4.595E-02 4.586E-02 4.570E-02 4.546E-02 4.516E-02 4.478E-02 4.434E-02 4.382E-02 4.324E-02 4.259E-02 4.187E-02 4.110E-02 4.026E-02 3.936E-02 3.840E-02 3.740E-02 3.634E-02 3.524E-02 3.410E-02 3.292E-02 3.170E-02 3.046E-02 2.919E-02 2.790E-02 2.659E-02 2.527E-02 2.395E-02 2.263E-02 2.130E-02 1.999E-02 1.869E-02 1.740E-02 1.614E-02 1.490E-02 1.369E-02 1.252E-02 1.138E-02 1.029E-02 9.234E-03 8.231E-03 7.278E-03 6.378E-03 5.533E-03 4.745E-03 4.016E-03 3.347E-03 2.738E-03 2.192E-03 1.708E-03 1.285E-03 9.246E-04 6.251E-04 3.858E-04 2.054E-04 2.278E-05 9.874E-05 2.299E-04 4.181E-04 6.645E-04 9.705E-04 1.337E-03 1.764E-03 2.252E-03 2.801E-03 3.411E-03 4.081E-03 4.810E-03 5.596E-03 6.439E-03 7.335E-03 8.283E-03 9.280E-03 1.032E-02 1.141E-02 1.254E-02 1.370E-02 1.490E-02 1.613E-02 1.738E-02 1.865E-02 1.994E-02 2.124E-02 2.255E-02 2.386E-02 2.517E-02 2.647E-02 2.776E-02 2.904E-02 3.030E-02 3.153E-02 3.273E-02 3.391E-02 3.504E-02 3.614E-02 3.719E-02 3.819E-02 3.914E-02 4.004E-02 4.088E-02 4.167E-02 4.239E-02 4.305E-02 4.364E-02 4.417E-02 4.463E-02 4.503E-02 4.535E-02 4.561E-02 4.580E-02 4.592E-02 4.597E-02 4.595E-02 4.587E-02 4.573E-02 4.552E-02 4.525E-02 4.492E-02 4.454E-02 4.410E-02 4.361E-02 4.307E-02 4.248E-02 4.185E-02 4.118E-02 4.047E-02 3.973E-02 3.895E-02 3.814E-02 3.731E-02 3.646E-02 3.559E-02 3.470E-02 3.380E-02 3.289E-02 3.197E-02 3.105E-02 3.012E-02 2.920E-02 2.828E-02 2.736E-02 2.645E-02 2.555E-02 2.467E-02 2.379E-02 2.294E-02 2.210E-02 2.127E-02 2.047E-02 1.969E-02 1.893E-02 1.819E-02 1.748E-02 1.679E-02 1.612E-02 1.548E-02 1.487E-02 1.428E-02 1.371E-02 1.317E-02 1.266E-02 1.218E-02 1.171E-02 1.128E-02 1.087E-02 1.048E-02 1.012E-02 9.777E-03 9.461E-03 9.169E-03 8.898E-03 8.650E-03 8.424E-03 8.218E-03 8.034E-03 7.870E-03 7.726E-03 7.602E-03 7.498E-03 7.413E-03 7.347E-03 7.300E-03 7.272E-03 7.262E-03 7.272E-03 7.300E-03 7.347E-03 7.413E-03 7.498E-03 7.602E-03 7.726E-03 7.870E-03 8.034E-03 8.218E-03 8.424E-03 8.650E-03 8.898E-03 9.169E-03 9.461E-03 9.777E-03 1.012E-02 1.048E-02 1.087E-02 1.128E-02 1.171E-02 1.218E-02 1.266E-02 1.317E-02 1.371E-02 1.428E-02 1.487E-02 1.548E-02 1.612E-02 1.679E-02 1.748E-02 1.819E-02 1.893E-02 1.969E-02 2.047E-02 2.127E-02 2.210E-02 2.294E-02 2.379E-02 2.467E-02 2.555E-02 2.645E-02 2.736E-02 2.828E-02 2.920E-02 3.012E-02 3.105E-02 3.197E-02 3.289E-02 3.380E-02 3.470E-02 3.559E-02 3.646E-02 3.731E-02 3.814E-02 3.895E-02 3.973E-02 4.047E-02 4.118E-02 4.185E-02 4.248E-02 4.307E-02 4.361E-02 4.410E-02 4.454E-02 4.492E-02 4.525E-02 4.552E-02 4.573E-02 4.587E-02 4.595E-02 4.597E-02 4.592E-02 4.580E-02 4.561E-02 4.535E-02 4.503E-02 4.463E-02 4.417E-02 4.364E-02 4.305E-02 4.239E-02 4.167E-02 4.088E-02 4.004E-02 3.914E-02 3.819E-02 3.719E-02 3.614E-02 3.504E-02 3.391E-02 3.273E-02 3.153E-02 3.030E-02 2.904E-02 2.776E-02 2.647E-02 2.517E-02 2.386E-02 2.255E-02 2.124E-02 1.994E-02 1.865E-02 1.738E-02 1.613E-02 1.490E-02 1.370E-02 1.254E-02 1.141E-02 1.032E-02 9.280E-03 8.283E-03 7.335E-03 6.439E-03 5.596E-03 4.810E-03 4.081E-03 3.411E-03 2.801E-03 2.252E-03 1.764E-03 1.337E-03 9.705E-04 6.645E-04 4.181E-04 2.299E-04 9.874E-05 2.521E-07 3.108E-05 1.148E-04 2.533E-04 4.481E-04 7.007E-04 1.012E-03 1.383E-03 1.813E-03 2.304E-03 2.855E-03 3.466E-03 4.135E-03 4.862E-03 5.646E-03 6.484E-03 7.376E-03 8.318E-03 9.308E-03 1.034E-02 1.142E-02 1.254E-02 1.369E-02 1.488E-02 1.609E-02 1.733E-02 1.859E-02 1.986E-02 2.115E-02 2.244E-02 2.374E-02 2.503E-02 2.632E-02 2.760E-02 2.887E-02 3.011E-02 3.133E-02 3.253E-02 3.369E-02 3.482E-02 3.591E-02 3.695E-02 3.795E-02 3.890E-02 3.980E-02 4.065E-02 4.144E-02 4.217E-02 4.284E-02 4.344E-02 4.399E-02 4.447E-02 4.488E-02 4.523E-02 4.551E-02 4.572E-02 4.587E-02 4.595E-02 4.597E-02 4.593E-02 4.582E-02 4.565E-02 4.542E-02 4.514E-02 4.480E-02 4.441E-02 4.396E-02 4.347E-02 4.294E-02 4.236E-02 4.174E-02 4.108E-02 4.039E-02 3.967E-02 3.891E-02 3.814E-02 3.734E-02 3.652E-02 3.568E-02 3.483E-02 3.397E-02 3.310E-02 3.223E-02 3.135E-02 3.047E-02 2.960E-02 2.872E-02 2.786E-02 2.700E-02 2.615E-02 2.531E-02 2.449E-02 2.368E-02 2.289E-02 2.212E-02 2.136E-02 2.063E-02 1.991E-02 1.922E-02 1.855E-02 1.791E-02 1.728E-02 1.668E-02 1.611E-02 1.556E-02 1.503E-02 1.453E-02 1.405E-02 1.360E-02 1.317E-02 1.277E-02 1.239E-02 1.204E-02 1.170E-02 1.139E-02 1.111E-02 1.085E-02 1.060E-02 1.039E-02 1.019E-02 1.001E-02 9.859E-03 9.726E-03 9.614E-03 9.522E-03 9.451E-03 9.401E-03 9.370E-03 9.360E-03 9.370E-03 9.401E-03 9.451E-03 9.522E-03 9.614E-03 9.726E-03 9.859E-03 1.001E-02 1.019E-02 1.039E-02 1.060E-02 1.085E-02 1.111E-02 1.139E-02 1.170E-02 1.204E-02 1.239E-02 1.277E-02 1.317E-02 1.360E-02 1.405E-02 1.453E-02 1.503E-02 1.556E-02 1.611E-02 1.668E-02 1.728E-02 1.791E-02 1.855E-02 1.922E-02 1.991E-02 2.063E-02 2.136E-02 2.212E-02 2.289E-02 2.368E-02 2.449E-02 2.531E-02 2.615E-02 2.700E-02 2.786E-02 2.872E-02 2.960E-02 3.047E-02 3.135E-02 3.223E-02 3.310E-02 3.397E-02 3.483E-02 3.568E-02 3.652E-02 3.734E-02 3.814E-02 3.891E-02 3.967E-02 4.039E-02 4.108E-02 4.174E-02 4.236E-02 4.294E-02 4.347E-02 4.396E-02 4.441E-02 4.480E-02 4.514E-02 4.542E-02 4.565E-02 4.582E-02 4.593E-02 4.597E-02 4.595E-02 4.587E-02 4.572E-02 4.551E-02 4.523E-02 4.488E-02 4.447E-02 4.399E-02 4.344E-02 4.284E-02 4.217E-02 4.144E-02 4.065E-02 3.980E-02 3.890E-02 3.795E-02 3.695E-02 3.591E-02 3.482E-02 3.369E-02 3.253E-02 3.133E-02 3.011E-02 2.887E-02 2.760E-02 2.632E-02 2.503E-02 2.374E-02 2.244E-02 2.115E-02 1.986E-02 1.859E-02 1.733E-02 1.609E-02 1.488E-02 1.369E-02 1.254E-02 1.142E-02 1.034E-02 9.308E-03 8.318E-03 7.376E-03 6.484E-03 5.646E-03 4.862E-03 4.135E-03 3.466E-03 2.855E-03 2.304E-03 1.813E-03 1.383E-03 1.012E-03 7.007E-04 4.481E-04 2.533E-04 1.148E-04 3.108E-05 1.389E-05 1.565E-06 3.969E-05 1.303E-04 2.751E-04 4.756E-04 7.331E-04 1.049E-03 1.423E-03 1.856E-03 2.348E-03 2.900E-03 3.510E-03 4.177E-03 4.902E-03 5.682E-03 6.515E-03 7.400E-03 8.335E-03 9.317E-03 1.034E-02 1.141E-02 1.252E-02 1.366E-02 1.483E-02 1.603E-02 1.726E-02 1.850E-02 1.976E-02 2.103E-02 2.231E-02 2.359E-02 2.487E-02 2.615E-02 2.741E-02 2.867E-02 2.990E-02 3.111E-02 3.229E-02 3.345E-02 3.457E-02 3.565E-02 3.669E-02 3.769E-02 3.864E-02 3.954E-02 4.039E-02 4.119E-02 4.192E-02 4.260E-02 4.322E-02 4.378E-02 4.428E-02 4.471E-02 4.508E-02 4.538E-02 4.562E-02 4.580E-02 4.592E-02 4.597E-02 4.596E-02 4.589E-02 4.576E-02 4.558E-02 4.534E-02 4.504E-02 4.470E-02 4.430E-02 4.386E-02 4.337E-02 4.285E-02 4.228E-02 4.168E-02 4.104E-02 4.037E-02 3.967E-02 3.895E-02 3.820E-02 3.744E-02 3.666E-02 3.586E-02 3.505E-02 3.423E-02 3.341E-02 3.258E-02 3.175E-02 3.092E-02 3.009E-02 2.927E-02 2.845E-02 2.765E-02 2.685E-02 2.606E-02 2.529E-02 2.453E-02 2.379E-02 2.307E-02 2.236E-02 2.168E-02 2.101E-02 2.037E-02 1.974E-02 1.914E-02 1.856E-02 1.801E-02 1.748E-02 1.697E-02 1.648E-02 1.602E-02 1.558E-02 1.517E-02 1.478E-02 1.441E-02 1.407E-02 1.375E-02 1.345E-02 1.317E-02 1.292E-02 1.269E-02 1.249E-02 1.230E-02 1.214E-02 1.200E-02 1.189E-02 1.179E-02 1.171E-02 1.166E-02 1.163E-02 1.162E-02 1.163E-02 1.166E-02 1.171E-02 1.179E-02 1.189E-02 1.200E-02 1.214E-02 1.230E-02 1.249E-02 1.269E-02 1.292E-02 1.317E-02 1.345E-02 1.375E-02 1.407E-02 1.441E-02 1.478E-02 1.517E-02 1.558E-02 1.602E-02 1.648E-02 1.697E-02 1.748E-02 1.801E-02 1.856E-02 1.914E-02 1.974E-02 2.037E-02 2.101E-02 2.168E-02 2.236E-02 2.307E-02 2.379E-02 2.453E-02 2.529E-02 2.606E-02 2.685E-02 2.765E-02 2.845E-02 2.927E-02 3.009E-02 3.092E-02 3.175E-02 3.258E-02 3.341E-02 3.423E-02 3.505E-02 3.586E-02 3.666E-02 3.744E-02 3.820E-02 3.895E-02 3.967E-02 4.037E-02 4.104E-02 4.168E-02 4.228E-02 4.285E-02 4.337E-02 4.386E-02 4.430E-02 4.470E-02 4.504E-02 4.534E-02 4.558E-02 4.576E-02 4.589E-02 4.596E-02 4.597E-02 4.592E-02 4.580E-02 4.562E-02 4.538E-02 4.508E-02 4.471E-02 4.428E-02 4.378E-02 4.322E-02 4.260E-02 4.192E-02 4.119E-02 4.039E-02 3.954E-02 3.864E-02 3.769E-02 3.669E-02 3.565E-02 3.457E-02 3.345E-02 3.229E-02 3.111E-02 2.990E-02 2.867E-02 2.741E-02 2.615E-02 2.487E-02 2.359E-02 2.231E-02 2.103E-02 1.976E-02 1.850E-02 1.726E-02 1.603E-02 1.483E-02 1.366E-02 1.252E-02 1.141E-02 1.034E-02 9.317E-03 8.335E-03 7.400E-03 6.515E-03 5.682E-03 4.902E-03 4.177E-03 3.510E-03 2.900E-03 2.348E-03 1.856E-03 1.423E-03 1.049E-03 7.331E-04 4.756E-04 2.751E-04 1.303E-04 3.969E-05 1.565E-06 6.260E-05 9.190E-06 3.699E-06 4.826E-05 1.448E-04 2.949E-04 5.001E-04 7.616E-04 1.080E-03 1.457E-03 1.891E-03 2.384E-03 2.935E-03 3.543E-03 4.208E-03 4.928E-03 5.703E-03 6.530E-03 7.409E-03 8.335E-03 9.308E-03 1.032E-02 1.138E-02 1.248E-02 1.360E-02 1.476E-02 1.595E-02 1.716E-02 1.839E-02 1.963E-02 2.089E-02 2.215E-02 2.342E-02 2.469E-02 2.595E-02 2.720E-02 2.844E-02 2.966E-02 3.086E-02 3.203E-02 3.318E-02 3.429E-02 3.537E-02 3.641E-02 3.740E-02 3.835E-02 3.926E-02 4.011E-02 4.091E-02 4.165E-02 4.234E-02 4.298E-02 4.355E-02 4.406E-02 4.451E-02 4.491E-02 4.524E-02 4.550E-02 4.571E-02 4.586E-02 4.594E-02 4.597E-02 4.594E-02 4.585E-02 4.571E-02 4.551E-02 4.527E-02 4.497E-02 4.462E-02 4.423E-02 4.379E-02 4.332E-02 4.280E-02 4.225E-02 4.167E-02 4.106E-02 4.041E-02 3.975E-02 3.905E-02 3.834E-02 3.762E-02 3.687E-02 3.612E-02 3.535E-02 3.458E-02 3.380E-02 3.302E-02 3.224E-02 3.146E-02 3.068E-02 2.991E-02 2.915E-02 2.839E-02 2.765E-02 2.691E-02 2.619E-02 2.549E-02 2.480E-02 2.413E-02 2.347E-02 2.284E-02 2.222E-02 2.162E-02 2.105E-02 2.049E-02 1.996E-02 1.945E-02 1.896E-02 1.850E-02 1.805E-02 1.763E-02 1.724E-02 1.687E-02 1.652E-02 1.619E-02 1.588E-02 1.560E-02 1.535E-02 1.511E-02 1.490E-02 1.471E-02 1.454E-02 1.440E-02 1.428E-02 1.418E-02 1.410E-02 1.404E-02 1.401E-02 1.400E-02 1.401E-02 1.404E-02 1.410E-02 1.418E-02 1.428E-02 1.440E-02 1.454E-02 1.471E-02 1.490E-02 1.511E-02 1.535E-02 1.560E-02 1.588E-02 1.619E-02 1.652E-02 1.687E-02 1.724E-02 1.763E-02 1.805E-02 1.850E-02 1.896E-02 1.945E-02 1.996E-02 2.049E-02 2.105E-02 2.162E-02 2.222E-02 2.284E-02 2.347E-02 2.413E-02 2.480E-02 2.549E-02 2.619E-02 2.691E-02 2.765E-02 2.839E-02 2.915E-02 2.991E-02 3.068E-02 3.146E-02 3.224E-02 3.302E-02 3.380E-02 3.458E-02 3.535E-02 3.612E-02 3.687E-02 3.762E-02 3.834E-02 3.905E-02 3.975E-02 4.041E-02 4.106E-02 4.167E-02 4.225E-02 4.280E-02 4.332E-02 4.379E-02 4.423E-02 4.462E-02 4.497E-02 4.527E-02 4.551E-02 4.571E-02 4.585E-02 4.594E-02 4.597E-02 4.594E-02 4.586E-02 4.571E-02 4.550E-02 4.524E-02 4.491E-02 4.451E-02 4.406E-02 4.355E-02 4.298E-02 4.234E-02 4.165E-02 4.091E-02 4.011E-02 3.926E-02 3.835E-02 3.740E-02 3.641E-02 3.537E-02 3.429E-02 3.318E-02 3.203E-02 3.086E-02 2.966E-02 2.844E-02 2.720E-02 2.595E-02 2.469E-02 2.342E-02 2.215E-02 2.089E-02 1.963E-02 1.839E-02 1.716E-02 1.595E-02 1.476E-02 1.360E-02 1.248E-02 1.138E-02 1.032E-02 9.308E-03 8.335E-03 7.409E-03 6.530E-03 5.703E-03 4.928E-03 4.208E-03 3.543E-03 2.935E-03 2.384E-03 1.891E-03 1.457E-03 1.080E-03 7.616E-04 5.001E-04 2.949E-04 1.448E-04 4.826E-05 3.699E-06 9.190E-06 1.451E-04 5.282E-05 5.812E-06 6.341E-06 5.645E-05 1.580E-04 3.125E-04 5.214E-04 7.858E-04 1.106E-03 1.484E-03 1.919E-03 2.411E-03 2.960E-03 3.565E-03 4.226E-03 4.942E-03 5.710E-03 6.530E-03 7.400E-03 8.318E-03 9.280E-03 1.029E-02 1.133E-02 1.241E-02 1.353E-02 1.467E-02 1.584E-02 1.704E-02 1.825E-02 1.948E-02 2.072E-02 2.197E-02 2.322E-02 2.448E-02 2.572E-02 2.696E-02 2.818E-02 2.939E-02 3.058E-02 3.175E-02 3.288E-02 3.399E-02 3.506E-02 3.609E-02 3.709E-02 3.804E-02 3.894E-02 3.980E-02 4.061E-02 4.136E-02 4.206E-02 4.270E-02 4.329E-02 4.382E-02 4.430E-02 4.471E-02 4.507E-02 4.536E-02 4.560E-02 4.578E-02 4.590E-02 4.596E-02 4.597E-02 4.592E-02 4.582E-02 4.567E-02 4.547E-02 4.521E-02 4.492E-02 4.458E-02 4.419E-02 4.377E-02 4.331E-02 4.281E-02 4.228E-02 4.172E-02 4.113E-02 4.052E-02 3.988E-02 3.923E-02 3.856E-02 3.787E-02 3.717E-02 3.645E-02 3.573E-02 3.501E-02 3.428E-02 3.355E-02 3.281E-02 3.209E-02 3.136E-02 3.064E-02 2.993E-02 2.923E-02 2.854E-02 2.786E-02 2.719E-02 2.654E-02 2.590E-02 2.528E-02 2.468E-02 2.409E-02 2.353E-02 2.298E-02 2.245E-02 2.195E-02 2.146E-02 2.100E-02 2.056E-02 2.014E-02 1.974E-02 1.937E-02 1.902E-02 1.869E-02 1.838E-02 1.810E-02 1.784E-02 1.760E-02 1.739E-02 1.719E-02 1.702E-02 1.688E-02 1.675E-02 1.665E-02 1.657E-02 1.652E-02 1.648E-02 1.647E-02 1.648E-02 1.652E-02 1.657E-02 1.665E-02 1.675E-02 1.688E-02 1.702E-02 1.719E-02 1.739E-02 1.760E-02 1.784E-02 1.810E-02 1.838E-02 1.869E-02 1.902E-02 1.937E-02 1.974E-02 2.014E-02 2.056E-02 2.100E-02 2.146E-02 2.195E-02 2.245E-02 2.298E-02 2.353E-02 2.409E-02 2.468E-02 2.528E-02 2.590E-02 2.654E-02 2.719E-02 2.786E-02 2.854E-02 2.923E-02 2.993E-02 3.064E-02 3.136E-02 3.209E-02 3.281E-02 3.355E-02 3.428E-02 3.501E-02 3.573E-02 3.645E-02 3.717E-02 3.787E-02 3.856E-02 3.923E-02 3.988E-02 4.052E-02 4.113E-02 4.172E-02 4.228E-02 4.281E-02 4.331E-02 4.377E-02 4.419E-02 4.458E-02 4.492E-02 4.521E-02 4.547E-02 4.567E-02 4.582E-02 4.592E-02 4.597E-02 4.596E-02 4.590E-02 4.578E-02 4.560E-02 4.536E-02 4.507E-02 4.471E-02 4.430E-02 4.382E-02 4.329E-02 4.270E-02 4.206E-02 4.136E-02 4.061E-02 3.980E-02 3.894E-02 3.804E-02 3.709E-02 3.609E-02 3.506E-02 3.399E-02 3.288E-02 3.175E-02 3.058E-02 2.939E-02 2.818E-02 2.696E-02 2.572E-02 2.448E-02 2.322E-02 2.197E-02 2.072E-02 1.948E-02 1.825E-02 1.704E-02 1.584E-02 1.467E-02 1.353E-02 1.241E-02 1.133E-02 1.029E-02 9.280E-03 8.318E-03 7.400E-03 6.530E-03 5.710E-03 4.942E-03 4.226E-03 3.565E-03 2.960E-03 2.411E-03 1.919E-03 1.484E-03 1.106E-03 7.858E-04 5.214E-04 3.125E-04 1.580E-04 5.645E-05 6.341E-06 5.812E-06 5.282E-05 2.601E-04 1.312E-04 4.486E-05 3.484E-06 9.211E-06 6.401E-05 1.696E-04 3.276E-04 5.391E-04 8.054E-04 1.127E-03 1.505E-03 1.939E-03 2.429E-03 2.975E-03 3.576E-03 4.232E-03 4.942E-03 5.703E-03 6.515E-03 7.376E-03 8.283E-03 9.234E-03 1.023E-02 1.126E-02 1.233E-02 1.343E-02 1.456E-02 1.572E-02 1.689E-02 1.809E-02 1.931E-02 2.053E-02 2.176E-02 2.300E-02 2.424E-02 2.547E-02 2.669E-02 2.790E-02 2.910E-02 3.028E-02 3.143E-02 3.256E-02 3.366E-02 3.472E-02 3.575E-02 3.675E-02 3.770E-02 3.860E-02 3.946E-02 4.028E-02 4.104E-02 4.175E-02 4.241E-02 4.301E-02 4.356E-02 4.405E-02 4.449E-02 4.487E-02 4.519E-02 4.546E-02 4.567E-02 4.582E-02 4.592E-02 4.597E-02 4.596E-02 4.590E-02 4.579E-02 4.564E-02 4.543E-02 4.518E-02 4.489E-02 4.456E-02 4.419E-02 4.378E-02 4.334E-02 4.286E-02 4.236E-02 4.182E-02 4.127E-02 4.069E-02 4.009E-02 3.947E-02 3.884E-02 3.819E-02 3.753E-02 3.686E-02 3.619E-02 3.551E-02 3.483E-02 3.415E-02 3.347E-02 3.280E-02 3.212E-02 3.146E-02 3.080E-02 3.015E-02 2.951E-02 2.889E-02 2.828E-02 2.768E-02 2.709E-02 2.653E-02 2.598E-02 2.544E-02 2.493E-02 2.443E-02 2.396E-02 2.350E-02 2.307E-02 2.266E-02 2.226E-02 2.189E-02 2.154E-02 2.122E-02 2.091E-02 2.063E-02 2.037E-02 2.013E-02 1.991E-02 1.972E-02 1.955E-02 1.940E-02 1.928E-02 1.918E-02 1.910E-02 1.904E-02 1.901E-02 1.900E-02 1.901E-02 1.904E-02 1.910E-02 1.918E-02 1.928E-02 1.940E-02 1.955E-02 1.972E-02 1.991E-02 2.013E-02 2.037E-02 2.063E-02 2.091E-02 2.122E-02 2.154E-02 2.189E-02 2.226E-02 2.266E-02 2.307E-02 2.350E-02 2.396E-02 2.443E-02 2.493E-02 2.544E-02 2.598E-02 2.653E-02 2.709E-02 2.768E-02 2.828E-02 2.889E-02 2.951E-02 3.015E-02 3.080E-02 3.146E-02 3.212E-02 3.280E-02 3.347E-02 3.415E-02 3.483E-02 3.551E-02 3.619E-02 3.686E-02 3.753E-02 3.819E-02 3.884E-02 3.947E-02 4.009E-02 4.069E-02 4.127E-02 4.182E-02 4.236E-02 4.286E-02 4.334E-02 4.378E-02 4.419E-02 4.456E-02 4.489E-02 4.518E-02 4.543E-02 4.564E-02 4.579E-02 4.590E-02 4.596E-02 4.597E-02 4.592E-02 4.582E-02 4.567E-02 4.546E-02 4.519E-02 4.487E-02 4.449E-02 4.405E-02 4.356E-02 4.301E-02 4.241E-02 4.175E-02 4.104E-02 4.028E-02 3.946E-02 3.860E-02 3.770E-02 3.675E-02 3.575E-02 3.472E-02 3.366E-02 3.256E-02 3.143E-02 3.028E-02 2.910E-02 2.790E-02 2.669E-02 2.547E-02 2.424E-02 2.300E-02 2.176E-02 2.053E-02 1.931E-02 1.809E-02 1.689E-02 1.572E-02 1.456E-02 1.343E-02 1.233E-02 1.126E-02 1.023E-02 9.234E-03 8.283E-03 7.376E-03 6.515E-03 5.703E-03 4.942E-03 4.232E-03 3.576E-03 2.975E-03 2.429E-03 1.939E-03 1.505E-03 1.127E-03 8.054E-04 5.391E-04 3.276E-04 1.696E-04 6.401E-05 9.211E-06 3.484E-06 4.486E-05 1.312E-04 4.060E-04 2.428E-04 1.195E-04 3.847E-05 1.956E-06 1.206E-05 7.067E-05 1.795E-04 3.399E-04 5.532E-04 8.203E-04 1.142E-03 1.519E-03 1.951E-03 2.438E-03 2.980E-03 3.576E-03 4.226E-03 4.928E-03 5.682E-03 6.484E-03 7.335E-03 8.231E-03 9.170E-03 1.015E-02 1.117E-02 1.222E-02 1.331E-02 1.442E-02 1.556E-02 1.673E-02 1.791E-02 1.911E-02 2.031E-02 2.153E-02 2.275E-02 2.397E-02 2.519E-02 2.640E-02 2.760E-02 2.878E-02 2.995E-02 3.109E-02 3.221E-02 3.330E-02 3.436E-02 3.539E-02 3.638E-02 3.733E-02 3.824E-02 3.910E-02 3.992E-02 4.069E-02 4.141E-02 4.208E-02 4.270E-02 4.327E-02 4.378E-02 4.424E-02 4.464E-02 4.499E-02 4.529E-02 4.553E-02 4.572E-02 4.585E-02 4.594E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.562E-02 4.542E-02 4.518E-02 4.489E-02 4.458E-02 4.422E-02 4.383E-02 4.341E-02 4.296E-02 4.248E-02 4.198E-02 4.146E-02 4.091E-02 4.035E-02 3.977E-02 3.918E-02 3.858E-02 3.796E-02 3.735E-02 3.672E-02 3.609E-02 3.546E-02 3.483E-02 3.421E-02 3.358E-02 3.296E-02 3.235E-02 3.175E-02 3.115E-02 3.057E-02 3.000E-02 2.944E-02 2.890E-02 2.837E-02 2.786E-02 2.736E-02 2.688E-02 2.642E-02 2.598E-02 2.555E-02 2.515E-02 2.477E-02 2.440E-02 2.406E-02 2.374E-02 2.344E-02 2.316E-02 2.290E-02 2.267E-02 2.245E-02 2.226E-02 2.210E-02 2.195E-02 2.183E-02 2.172E-02 2.164E-02 2.159E-02 2.155E-02 2.154E-02 2.155E-02 2.159E-02 2.164E-02 2.172E-02 2.183E-02 2.195E-02 2.210E-02 2.226E-02 2.245E-02 2.267E-02 2.290E-02 2.316E-02 2.344E-02 2.374E-02 2.406E-02 2.440E-02 2.477E-02 2.515E-02 2.555E-02 2.598E-02 2.642E-02 2.688E-02 2.736E-02 2.786E-02 2.837E-02 2.890E-02 2.944E-02 3.000E-02 3.057E-02 3.115E-02 3.175E-02 3.235E-02 3.296E-02 3.358E-02 3.421E-02 3.483E-02 3.546E-02 3.609E-02 3.672E-02 3.735E-02 3.796E-02 3.858E-02 3.918E-02 3.977E-02 4.035E-02 4.091E-02 4.146E-02 4.198E-02 4.248E-02 4.296E-02 4.341E-02 4.383E-02 4.422E-02 4.458E-02 4.489E-02 4.518E-02 4.542E-02 4.562E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.594E-02 4.585E-02 4.572E-02 4.553E-02 4.529E-02 4.499E-02 4.464E-02 4.424E-02 4.378E-02 4.327E-02 4.270E-02 4.208E-02 4.141E-02 4.069E-02 3.992E-02 3.910E-02 3.824E-02 3.733E-02 3.638E-02 3.539E-02 3.436E-02 3.330E-02 3.221E-02 3.109E-02 2.995E-02 2.878E-02 2.760E-02 2.640E-02 2.519E-02 2.397E-02 2.275E-02 2.153E-02 2.031E-02 1.911E-02 1.791E-02 1.673E-02 1.556E-02 1.442E-02 1.331E-02 1.222E-02 1.117E-02 1.015E-02 9.170E-03 8.231E-03 7.335E-03 6.484E-03 5.682E-03 4.928E-03 4.226E-03 3.576E-03 2.980E-03 2.438E-03 1.951E-03 1.519E-03 1.142E-03 8.203E-04 5.532E-04 3.399E-04 1.795E-04 7.067E-05 1.206E-05 1.956E-06 3.847E-05 1.195E-04 2.428E-04 5.812E-04 3.863E-04 2.283E-04 1.099E-04 3.344E-05 1.016E-06 1.469E-05 7.626E-05 1.873E-04 3.493E-04 5.633E-04 8.303E-04 1.151E-03 1.526E-03 1.955E-03 2.438E-03 2.975E-03 3.565E-03 4.208E-03 4.902E-03 5.646E-03 6.439E-03 7.278E-03 8.162E-03 9.088E-03 1.005E-02 1.106E-02 1.210E-02 1.317E-02 1.427E-02 1.539E-02 1.654E-02 1.770E-02 1.888E-02 2.007E-02 2.127E-02 2.247E-02 2.368E-02 2.488E-02 2.608E-02 2.726E-02 2.843E-02 2.959E-02 3.072E-02 3.183E-02 3.292E-02 3.397E-02 3.499E-02 3.598E-02 3.693E-02 3.784E-02 3.871E-02 3.953E-02 4.031E-02 4.104E-02 4.173E-02 4.236E-02 4.294E-02 4.348E-02 4.396E-02 4.439E-02 4.476E-02 4.509E-02 4.536E-02 4.558E-02 4.575E-02 4.587E-02 4.595E-02 4.597E-02 4.595E-02 4.588E-02 4.577E-02 4.562E-02 4.543E-02 4.519E-02 4.492E-02 4.462E-02 4.429E-02 4.392E-02 4.352E-02 4.310E-02 4.266E-02 4.219E-02 4.170E-02 4.119E-02 4.067E-02 4.013E-02 3.958E-02 3.903E-02 3.846E-02 3.789E-02 3.731E-02 3.674E-02 3.616E-02 3.558E-02 3.501E-02 3.444E-02 3.387E-02 3.332E-02 3.277E-02 3.223E-02 3.170E-02 3.118E-02 3.068E-02 3.019E-02 2.972E-02 2.926E-02 2.882E-02 2.839E-02 2.798E-02 2.759E-02 2.722E-02 2.687E-02 2.654E-02 2.622E-02 2.593E-02 2.566E-02 2.541E-02 2.518E-02 2.497E-02 2.479E-02 2.462E-02 2.448E-02 2.436E-02 2.426E-02 2.418E-02 2.413E-02 2.409E-02 2.408E-02 2.409E-02 2.413E-02 2.418E-02 2.426E-02 2.436E-02 2.448E-02 2.462E-02 2.479E-02 2.497E-02 2.518E-02 2.541E-02 2.566E-02 2.593E-02 2.622E-02 2.654E-02 2.687E-02 2.722E-02 2.759E-02 2.798E-02 2.839E-02 2.882E-02 2.926E-02 2.972E-02 3.019E-02 3.068E-02 3.118E-02 3.170E-02 3.223E-02 3.277E-02 3.332E-02 3.387E-02 3.444E-02 3.501E-02 3.558E-02 3.616E-02 3.674E-02 3.731E-02 3.789E-02 3.846E-02 3.903E-02 3.958E-02 4.013E-02 4.067E-02 4.119E-02 4.170E-02 4.219E-02 4.266E-02 4.310E-02 4.352E-02 4.392E-02 4.429E-02 4.462E-02 4.492E-02 4.519E-02 4.543E-02 4.562E-02 4.577E-02 4.588E-02 4.595E-02 4.597E-02 4.595E-02 4.587E-02 4.575E-02 4.558E-02 4.536E-02 4.509E-02 4.476E-02 4.439E-02 4.396E-02 4.348E-02 4.294E-02 4.236E-02 4.173E-02 4.104E-02 4.031E-02 3.953E-02 3.871E-02 3.784E-02 3.693E-02 3.598E-02 3.499E-02 3.397E-02 3.292E-02 3.183E-02 3.072E-02 2.959E-02 2.843E-02 2.726E-02 2.608E-02 2.488E-02 2.368E-02 2.247E-02 2.127E-02 2.007E-02 1.888E-02 1.770E-02 1.654E-02 1.539E-02 1.427E-02 1.317E-02 1.210E-02 1.106E-02 1.005E-02 9.088E-03 8.162E-03 7.278E-03 6.439E-03 5.646E-03 4.902E-03 4.208E-03 3.565E-03 2.975E-03 2.438E-03 1.955E-03 1.526E-03 1.151E-03 8.303E-04 5.633E-04 3.493E-04 1.873E-04 7.626E-05 1.469E-05 1.016E-06 3.344E-05 1.099E-04 2.283E-04 3.863E-04 7.841E-04 5.598E-04 3.697E-04 2.164E-04 1.022E-04 2.957E-05 4.832E-07 1.691E-05 8.059E-05 1.931E-04 3.556E-04 5.694E-04 8.353E-04 1.154E-03 1.526E-03 1.951E-03 2.429E-03 2.960E-03 3.543E-03 4.177E-03 4.862E-03 5.596E-03 6.378E-03 7.205E-03 8.076E-03 8.988E-03 9.940E-03 1.093E-02 1.195E-02 1.300E-02 1.409E-02 1.519E-02 1.632E-02 1.747E-02 1.863E-02 1.981E-02 2.099E-02 2.217E-02 2.336E-02 2.455E-02 2.573E-02 2.690E-02 2.806E-02 2.920E-02 3.032E-02 3.143E-02 3.250E-02 3.355E-02 3.457E-02 3.555E-02 3.650E-02 3.741E-02 3.829E-02 3.912E-02 3.990E-02 4.065E-02 4.134E-02 4.199E-02 4.259E-02 4.314E-02 4.364E-02 4.410E-02 4.450E-02 4.485E-02 4.516E-02 4.541E-02 4.562E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.588E-02 4.578E-02 4.563E-02 4.545E-02 4.523E-02 4.498E-02 4.470E-02 4.438E-02 4.404E-02 4.368E-02 4.328E-02 4.287E-02 4.244E-02 4.199E-02 4.152E-02 4.104E-02 4.054E-02 4.004E-02 3.953E-02 3.901E-02 3.849E-02 3.796E-02 3.744E-02 3.691E-02 3.639E-02 3.587E-02 3.535E-02 3.484E-02 3.434E-02 3.385E-02 3.336E-02 3.289E-02 3.243E-02 3.198E-02 3.155E-02 3.113E-02 3.072E-02 3.033E-02 2.996E-02 2.961E-02 2.927E-02 2.895E-02 2.865E-02 2.837E-02 2.811E-02 2.787E-02 2.765E-02 2.744E-02 2.726E-02 2.710E-02 2.697E-02 2.685E-02 2.675E-02 2.668E-02 2.662E-02 2.659E-02 2.658E-02 2.659E-02 2.662E-02 2.668E-02 2.675E-02 2.685E-02 2.697E-02 2.710E-02 2.726E-02 2.744E-02 2.765E-02 2.787E-02 2.811E-02 2.837E-02 2.865E-02 2.895E-02 2.927E-02 2.961E-02 2.996E-02 3.033E-02 3.072E-02 3.113E-02 3.155E-02 3.198E-02 3.243E-02 3.289E-02 3.336E-02 3.385E-02 3.434E-02 3.484E-02 3.535E-02 3.587E-02 3.639E-02 3.691E-02 3.744E-02 3.796E-02 3.849E-02 3.901E-02 3.953E-02 4.004E-02 4.054E-02 4.104E-02 4.152E-02 4.199E-02 4.244E-02 4.287E-02 4.328E-02 4.368E-02 4.404E-02 4.438E-02 4.470E-02 4.498E-02 4.523E-02 4.545E-02 4.563E-02 4.578E-02 4.588E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.562E-02 4.541E-02 4.516E-02 4.485E-02 4.450E-02 4.410E-02 4.364E-02 4.314E-02 4.259E-02 4.199E-02 4.134E-02 4.065E-02 3.990E-02 3.912E-02 3.829E-02 3.741E-02 3.650E-02 3.555E-02 3.457E-02 3.355E-02 3.250E-02 3.143E-02 3.032E-02 2.920E-02 2.806E-02 2.690E-02 2.573E-02 2.455E-02 2.336E-02 2.217E-02 2.099E-02 1.981E-02 1.863E-02 1.747E-02 1.632E-02 1.519E-02 1.409E-02 1.300E-02 1.195E-02 1.093E-02 9.940E-03 8.988E-03 8.076E-03 7.205E-03 6.378E-03 5.596E-03 4.862E-03 4.177E-03 3.543E-03 2.960E-03 2.429E-03 1.951E-03 1.526E-03 1.154E-03 8.353E-04 5.694E-04 3.556E-04 1.931E-04 8.059E-05 1.691E-05 4.832E-07 2.957E-05 1.022E-04 2.164E-04 3.697E-04 5.598E-04 1.013E-03 7.617E-04 5.419E-04 3.562E-04 2.068E-04 9.628E-05 2.673E-05 2.117E-07 1.859E-05 8.354E-05 1.965E-04 3.588E-04 5.715E-04 8.353E-04 1.151E-03 1.519E-03 1.939E-03 2.411E-03 2.935E-03 3.510E-03 4.135E-03 4.810E-03 5.533E-03 6.302E-03 7.116E-03 7.973E-03 8.871E-03 9.807E-03 1.078E-02 1.179E-02 1.282E-02 1.389E-02 1.497E-02 1.609E-02 1.721E-02 1.836E-02 1.951E-02 2.068E-02 2.185E-02 2.302E-02 2.419E-02 2.535E-02 2.651E-02 2.766E-02 2.879E-02 2.990E-02 3.099E-02 3.206E-02 3.310E-02 3.412E-02 3.510E-02 3.605E-02 3.696E-02 3.783E-02 3.867E-02 3.946E-02 4.022E-02 4.092E-02 4.159E-02 4.220E-02 4.277E-02 4.330E-02 4.377E-02 4.420E-02 4.458E-02 4.492E-02 4.520E-02 4.544E-02 4.564E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.579E-02 4.566E-02 4.549E-02 4.529E-02 4.506E-02 4.480E-02 4.451E-02 4.420E-02 4.386E-02 4.350E-02 4.312E-02 4.273E-02 4.232E-02 4.189E-02 4.145E-02 4.100E-02 4.054E-02 4.008E-02 3.961E-02 3.914E-02 3.866E-02 3.819E-02 3.772E-02 3.724E-02 3.678E-02 3.631E-02 3.586E-02 3.541E-02 3.497E-02 3.454E-02 3.413E-02 3.372E-02 3.333E-02 3.295E-02 3.258E-02 3.223E-02 3.189E-02 3.157E-02 3.127E-02 3.099E-02 3.072E-02 3.047E-02 3.024E-02 3.003E-02 2.984E-02 2.967E-02 2.951E-02 2.938E-02 2.927E-02 2.918E-02 2.910E-02 2.905E-02 2.902E-02 2.901E-02 2.902E-02 2.905E-02 2.910E-02 2.918E-02 2.927E-02 2.938E-02 2.951E-02 2.967E-02 2.984E-02 3.003E-02 3.024E-02 3.047E-02 3.072E-02 3.099E-02 3.127E-02 3.157E-02 3.189E-02 3.223E-02 3.258E-02 3.295E-02 3.333E-02 3.372E-02 3.413E-02 3.454E-02 3.497E-02 3.541E-02 3.586E-02 3.631E-02 3.678E-02 3.724E-02 3.772E-02 3.819E-02 3.866E-02 3.914E-02 3.961E-02 4.008E-02 4.054E-02 4.100E-02 4.145E-02 4.189E-02 4.232E-02 4.273E-02 4.312E-02 4.350E-02 4.386E-02 4.420E-02 4.451E-02 4.480E-02 4.506E-02 4.529E-02 4.549E-02 4.566E-02 4.579E-02 4.589E-02 4.595E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.564E-02 4.544E-02 4.520E-02 4.492E-02 4.458E-02 4.420E-02 4.377E-02 4.330E-02 4.277E-02 4.220E-02 4.159E-02 4.092E-02 4.022E-02 3.946E-02 3.867E-02 3.783E-02 3.696E-02 3.605E-02 3.510E-02 3.412E-02 3.310E-02 3.206E-02 3.099E-02 2.990E-02 2.879E-02 2.766E-02 2.651E-02 2.535E-02 2.419E-02 2.302E-02 2.185E-02 2.068E-02 1.951E-02 1.836E-02 1.721E-02 1.609E-02 1.497E-02 1.389E-02 1.282E-02 1.179E-02 1.078E-02 9.807E-03 8.871E-03 7.973E-03 7.116E-03 6.302E-03 5.533E-03 4.810E-03 4.135E-03 3.510E-03 2.935E-03 2.411E-03 1.939E-03 1.519E-03 1.151E-03 8.353E-04 5.715E-04 3.588E-04 1.965E-04 8.354E-05 1.859E-05 2.117E-07 2.673E-05 9.628E-05 2.068E-04 3.562E-04 5.419E-04 7.617E-04 1.265E-03 9.900E-04 7.432E-04 5.275E-04 3.455E-04 1.995E-04 9.192E-05 2.478E-05 9.200E-08 1.964E-05 8.504E-05 1.977E-04 3.588E-04 5.694E-04 8.303E-04 1.142E-03 1.505E-03 1.919E-03 2.384E-03 2.900E-03 3.466E-03 4.081E-03 4.745E-03 5.456E-03 6.212E-03 7.012E-03 7.854E-03 8.737E-03 9.657E-03 1.061E-02 1.160E-02 1.262E-02 1.366E-02 1.473E-02 1.583E-02 1.694E-02 1.806E-02 1.920E-02 2.035E-02 2.150E-02 2.265E-02 2.381E-02 2.495E-02 2.610E-02 2.723E-02 2.835E-02 2.945E-02 3.053E-02 3.159E-02 3.262E-02 3.363E-02 3.461E-02 3.556E-02 3.647E-02 3.735E-02 3.819E-02 3.899E-02 3.975E-02 4.047E-02 4.115E-02 4.178E-02 4.237E-02 4.291E-02 4.341E-02 4.386E-02 4.427E-02 4.463E-02 4.495E-02 4.523E-02 4.545E-02 4.564E-02 4.578E-02 4.589E-02 4.595E-02 4.597E-02 4.596E-02 4.591E-02 4.582E-02 4.570E-02 4.555E-02 4.537E-02 4.516E-02 4.492E-02 4.466E-02 4.438E-02 4.408E-02 4.375E-02 4.341E-02 4.305E-02 4.268E-02 4.230E-02 4.190E-02 4.150E-02 4.109E-02 4.067E-02 4.025E-02 3.983E-02 3.940E-02 3.898E-02 3.856E-02 3.814E-02 3.772E-02 3.731E-02 3.691E-02 3.652E-02 3.613E-02 3.576E-02 3.539E-02 3.504E-02 3.470E-02 3.437E-02 3.406E-02 3.376E-02 3.348E-02 3.321E-02 3.296E-02 3.273E-02 3.251E-02 3.231E-02 3.213E-02 3.197E-02 3.183E-02 3.170E-02 3.159E-02 3.151E-02 3.144E-02 3.139E-02 3.136E-02 3.135E-02 3.136E-02 3.139E-02 3.144E-02 3.151E-02 3.159E-02 3.170E-02 3.183E-02 3.197E-02 3.213E-02 3.231E-02 3.251E-02 3.273E-02 3.296E-02 3.321E-02 3.348E-02 3.376E-02 3.406E-02 3.437E-02 3.470E-02 3.504E-02 3.539E-02 3.576E-02 3.613E-02 3.652E-02 3.691E-02 3.731E-02 3.772E-02 3.814E-02 3.856E-02 3.898E-02 3.940E-02 3.983E-02 4.025E-02 4.067E-02 4.109E-02 4.150E-02 4.190E-02 4.230E-02 4.268E-02 4.305E-02 4.341E-02 4.375E-02 4.408E-02 4.438E-02 4.466E-02 4.492E-02 4.516E-02 4.537E-02 4.555E-02 4.570E-02 4.582E-02 4.591E-02 4.596E-02 4.597E-02 4.595E-02 4.589E-02 4.578E-02 4.564E-02 4.545E-02 4.523E-02 4.495E-02 4.463E-02 4.427E-02 4.386E-02 4.341E-02 4.291E-02 4.237E-02 4.178E-02 4.115E-02 4.047E-02 3.975E-02 3.899E-02 3.819E-02 3.735E-02 3.647E-02 3.556E-02 3.461E-02 3.363E-02 3.262E-02 3.159E-02 3.053E-02 2.945E-02 2.835E-02 2.723E-02 2.610E-02 2.495E-02 2.381E-02 2.265E-02 2.150E-02 2.035E-02 1.920E-02 1.806E-02 1.694E-02 1.583E-02 1.473E-02 1.366E-02 1.262E-02 1.160E-02 1.061E-02 9.657E-03 8.737E-03 7.854E-03 7.012E-03 6.212E-03 5.456E-03 4.745E-03 4.081E-03 3.466E-03 2.900E-03 2.384E-03 1.919E-03 1.505E-03 1.142E-03 8.303E-04 5.694E-04 3.588E-04 1.977E-04 8.504E-05 1.964E-05 9.200E-08 2.478E-05 9.192E-05 1.995E-04 3.455E-04 5.275E-04 7.432E-04 9.900E-04 1.540E-03 1.243E-03 9.715E-04 7.285E-04 5.164E-04 3.376E-04 1.944E-04 8.907E-05 2.365E-05 5.057E-08 2.000E-05 8.504E-05 1.965E-04 3.556E-04 5.633E-04 8.203E-04 1.127E-03 1.484E-03 1.891E-03 2.348E-03 2.855E-03 3.411E-03 4.016E-03 4.667E-03 5.365E-03 6.108E-03 6.893E-03 7.720E-03 8.586E-03 9.488E-03 1.043E-02 1.140E-02 1.240E-02 1.342E-02 1.447E-02 1.555E-02 1.664E-02 1.774E-02 1.886E-02 1.999E-02 2.112E-02 2.226E-02 2.340E-02 2.453E-02 2.565E-02 2.677E-02 2.788E-02 2.897E-02 3.004E-02 3.109E-02 3.212E-02 3.312E-02 3.410E-02 3.504E-02 3.596E-02 3.684E-02 3.768E-02 3.849E-02 3.926E-02 3.999E-02 4.067E-02 4.132E-02 4.193E-02 4.249E-02 4.301E-02 4.349E-02 4.392E-02 4.431E-02 4.466E-02 4.496E-02 4.523E-02 4.545E-02 4.563E-02 4.577E-02 4.587E-02 4.594E-02 4.597E-02 4.596E-02 4.592E-02 4.585E-02 4.575E-02 4.562E-02 4.546E-02 4.528E-02 4.507E-02 4.484E-02 4.458E-02 4.431E-02 4.402E-02 4.372E-02 4.340E-02 4.307E-02 4.273E-02 4.238E-02 4.202E-02 4.165E-02 4.128E-02 4.091E-02 4.054E-02 4.016E-02 3.979E-02 3.942E-02 3.905E-02 3.869E-02 3.834E-02 3.799E-02 3.765E-02 3.731E-02 3.699E-02 3.668E-02 3.638E-02 3.609E-02 3.582E-02 3.556E-02 3.531E-02 3.508E-02 3.486E-02 3.466E-02 3.447E-02 3.430E-02 3.415E-02 3.402E-02 3.390E-02 3.380E-02 3.372E-02 3.365E-02 3.361E-02 3.358E-02 3.357E-02 3.358E-02 3.361E-02 3.365E-02 3.372E-02 3.380E-02 3.390E-02 3.402E-02 3.415E-02 3.430E-02 3.447E-02 3.466E-02 3.486E-02 3.508E-02 3.531E-02 3.556E-02 3.582E-02 3.609E-02 3.638E-02 3.668E-02 3.699E-02 3.731E-02 3.765E-02 3.799E-02 3.834E-02 3.869E-02 3.905E-02 3.942E-02 3.979E-02 4.016E-02 4.054E-02 4.091E-02 4.128E-02 4.165E-02 4.202E-02 4.238E-02 4.273E-02 4.307E-02 4.340E-02 4.372E-02 4.402E-02 4.431E-02 4.458E-02 4.484E-02 4.507E-02 4.528E-02 4.546E-02 4.562E-02 4.575E-02 4.585E-02 4.592E-02 4.596E-02 4.597E-02 4.594E-02 4.587E-02 4.577E-02 4.563E-02 4.545E-02 4.523E-02 4.496E-02 4.466E-02 4.431E-02 4.392E-02 4.349E-02 4.301E-02 4.249E-02 4.193E-02 4.132E-02 4.067E-02 3.999E-02 3.926E-02 3.849E-02 3.768E-02 3.684E-02 3.596E-02 3.504E-02 3.410E-02 3.312E-02 3.212E-02 3.109E-02 3.004E-02 2.897E-02 2.788E-02 2.677E-02 2.565E-02 2.453E-02 2.340E-02 2.226E-02 2.112E-02 1.999E-02 1.886E-02 1.774E-02 1.664E-02 1.555E-02 1.447E-02 1.342E-02 1.240E-02 1.140E-02 1.043E-02 9.488E-03 8.586E-03 7.720E-03 6.893E-03 6.108E-03 5.365E-03 4.667E-03 4.016E-03 3.411E-03 2.855E-03 2.348E-03 1.891E-03 1.484E-03 1.127E-03 8.203E-04 5.633E-04 3.556E-04 1.965E-04 8.504E-05 2.000E-05 5.057E-08 2.365E-05 8.907E-05 1.944E-04 3.376E-04 5.164E-04 7.285E-04 9.715E-04 1.243E-03 1.834E-03 1.518E-03 1.225E-03 9.572E-04 7.176E-04 5.085E-04 3.324E-04 1.913E-04 8.765E-05 2.328E-05 5.057E-08 1.964E-05 8.354E-05 1.931E-04 3.493E-04 5.532E-04 8.054E-04 1.106E-03 1.457E-03 1.856E-03 2.304E-03 2.801E-03 3.347E-03 3.939E-03 4.578E-03 5.262E-03 5.989E-03 6.759E-03 7.569E-03 8.418E-03 9.303E-03 1.022E-02 1.117E-02 1.215E-02 1.316E-02 1.419E-02 1.525E-02 1.632E-02 1.740E-02 1.850E-02 1.961E-02 2.072E-02 2.184E-02 2.296E-02 2.408E-02 2.519E-02 2.629E-02 2.738E-02 2.846E-02 2.952E-02 3.056E-02 3.158E-02 3.258E-02 3.355E-02 3.449E-02 3.541E-02 3.629E-02 3.713E-02 3.795E-02 3.872E-02 3.946E-02 4.016E-02 4.083E-02 4.145E-02 4.203E-02 4.257E-02 4.307E-02 4.353E-02 4.394E-02 4.432E-02 4.466E-02 4.495E-02 4.521E-02 4.543E-02 4.561E-02 4.575E-02 4.585E-02 4.593E-02 4.596E-02 4.597E-02 4.594E-02 4.589E-02 4.581E-02 4.570E-02 4.556E-02 4.540E-02 4.522E-02 4.502E-02 4.480E-02 4.457E-02 4.431E-02 4.405E-02 4.377E-02 4.348E-02 4.318E-02 4.287E-02 4.256E-02 4.224E-02 4.192E-02 4.159E-02 4.127E-02 4.094E-02 4.062E-02 4.030E-02 3.998E-02 3.967E-02 3.937E-02 3.907E-02 3.878E-02 3.850E-02 3.823E-02 3.796E-02 3.772E-02 3.748E-02 3.725E-02 3.704E-02 3.684E-02 3.666E-02 3.649E-02 3.633E-02 3.619E-02 3.607E-02 3.596E-02 3.587E-02 3.579E-02 3.573E-02 3.569E-02 3.567E-02 3.566E-02 3.567E-02 3.569E-02 3.573E-02 3.579E-02 3.587E-02 3.596E-02 3.607E-02 3.619E-02 3.633E-02 3.649E-02 3.666E-02 3.684E-02 3.704E-02 3.725E-02 3.748E-02 3.772E-02 3.796E-02 3.823E-02 3.850E-02 3.878E-02 3.907E-02 3.937E-02 3.967E-02 3.998E-02 4.030E-02 4.062E-02 4.094E-02 4.127E-02 4.159E-02 4.192E-02 4.224E-02 4.256E-02 4.287E-02 4.318E-02 4.348E-02 4.377E-02 4.405E-02 4.431E-02 4.457E-02 4.480E-02 4.502E-02 4.522E-02 4.540E-02 4.556E-02 4.570E-02 4.581E-02 4.589E-02 4.594E-02 4.597E-02 4.596E-02 4.593E-02 4.585E-02 4.575E-02 4.561E-02 4.543E-02 4.521E-02 4.495E-02 4.466E-02 4.432E-02 4.394E-02 4.353E-02 4.307E-02 4.257E-02 4.203E-02 4.145E-02 4.083E-02 4.016E-02 3.946E-02 3.872E-02 3.795E-02 3.713E-02 3.629E-02 3.541E-02 3.449E-02 3.355E-02 3.258E-02 3.158E-02 3.056E-02 2.952E-02 2.846E-02 2.738E-02 2.629E-02 2.519E-02 2.408E-02 2.296E-02 2.184E-02 2.072E-02 1.961E-02 1.850E-02 1.740E-02 1.632E-02 1.525E-02 1.419E-02 1.316E-02 1.215E-02 1.117E-02 1.022E-02 9.303E-03 8.418E-03 7.569E-03 6.759E-03 5.989E-03 5.262E-03 4.578E-03 3.939E-03 3.347E-03 2.801E-03 2.304E-03 1.856E-03 1.457E-03 1.106E-03 8.054E-04 5.532E-04 3.493E-04 1.931E-04 8.354E-05 1.964E-05 5.057E-08 2.328E-05 8.765E-05 1.913E-04 3.324E-04 5.085E-04 7.176E-04 9.572E-04 1.225E-03 1.518E-03 2.145E-03 1.813E-03 1.501E-03 1.212E-03 9.471E-04 7.104E-04 5.038E-04 3.298E-04 1.903E-04 8.765E-05 2.365E-05 9.200E-08 1.859E-05 8.059E-05 1.873E-04 3.399E-04 5.391E-04 7.858E-04 1.080E-03 1.423E-03 1.813E-03 2.252E-03 2.738E-03 3.272E-03 3.852E-03 4.477E-03 5.146E-03 5.858E-03 6.611E-03 7.404E-03 8.235E-03 9.102E-03 1.000E-02 1.093E-02 1.189E-02 1.288E-02 1.389E-02 1.492E-02 1.597E-02 1.704E-02 1.812E-02 1.921E-02 2.030E-02 2.140E-02 2.250E-02 2.360E-02 2.469E-02 2.578E-02 2.686E-02 2.792E-02 2.897E-02 3.001E-02 3.102E-02 3.201E-02 3.297E-02 3.391E-02 3.482E-02 3.571E-02 3.656E-02 3.737E-02 3.816E-02 3.890E-02 3.962E-02 4.029E-02 4.093E-02 4.153E-02 4.209E-02 4.261E-02 4.309E-02 4.353E-02 4.393E-02 4.430E-02 4.463E-02 4.492E-02 4.517E-02 4.538E-02 4.556E-02 4.571E-02 4.582E-02 4.590E-02 4.595E-02 4.597E-02 4.596E-02 4.593E-02 4.586E-02 4.578E-02 4.567E-02 4.554E-02 4.538E-02 4.521E-02 4.503E-02 4.483E-02 4.461E-02 4.438E-02 4.414E-02 4.389E-02 4.363E-02 4.337E-02 4.310E-02 4.283E-02 4.255E-02 4.227E-02 4.200E-02 4.172E-02 4.145E-02 4.117E-02 4.091E-02 4.064E-02 4.039E-02 4.014E-02 3.990E-02 3.967E-02 3.944E-02 3.923E-02 3.903E-02 3.884E-02 3.866E-02 3.849E-02 3.834E-02 3.820E-02 3.807E-02 3.796E-02 3.786E-02 3.778E-02 3.771E-02 3.765E-02 3.762E-02 3.759E-02 3.758E-02 3.759E-02 3.762E-02 3.765E-02 3.771E-02 3.778E-02 3.786E-02 3.796E-02 3.807E-02 3.820E-02 3.834E-02 3.849E-02 3.866E-02 3.884E-02 3.903E-02 3.923E-02 3.944E-02 3.967E-02 3.990E-02 4.014E-02 4.039E-02 4.064E-02 4.091E-02 4.117E-02 4.145E-02 4.172E-02 4.200E-02 4.227E-02 4.255E-02 4.283E-02 4.310E-02 4.337E-02 4.363E-02 4.389E-02 4.414E-02 4.438E-02 4.461E-02 4.483E-02 4.503E-02 4.521E-02 4.538E-02 4.554E-02 4.567E-02 4.578E-02 4.586E-02 4.593E-02 4.596E-02 4.597E-02 4.595E-02 4.590E-02 4.582E-02 4.571E-02 4.556E-02 4.538E-02 4.517E-02 4.492E-02 4.463E-02 4.430E-02 4.393E-02 4.353E-02 4.309E-02 4.261E-02 4.209E-02 4.153E-02 4.093E-02 4.029E-02 3.962E-02 3.890E-02 3.816E-02 3.737E-02 3.656E-02 3.571E-02 3.482E-02 3.391E-02 3.297E-02 3.201E-02 3.102E-02 3.001E-02 2.897E-02 2.792E-02 2.686E-02 2.578E-02 2.469E-02 2.360E-02 2.250E-02 2.140E-02 2.030E-02 1.921E-02 1.812E-02 1.704E-02 1.597E-02 1.492E-02 1.389E-02 1.288E-02 1.189E-02 1.093E-02 1.000E-02 9.102E-03 8.235E-03 7.404E-03 6.611E-03 5.858E-03 5.146E-03 4.477E-03 3.852E-03 3.272E-03 2.738E-03 2.252E-03 1.813E-03 1.423E-03 1.080E-03 7.858E-04 5.391E-04 3.399E-04 1.873E-04 8.059E-05 1.859E-05 9.200E-08 2.365E-05 8.765E-05 1.903E-04 3.298E-04 5.038E-04 7.104E-04 9.471E-04 1.212E-03 1.501E-03 1.813E-03 2.473E-03 2.127E-03 1.798E-03 1.489E-03 1.203E-03 9.410E-04 7.068E-04 5.023E-04 3.298E-04 1.913E-04 8.907E-05 2.478E-05 2.117E-07 1.691E-05 7.626E-05 1.795E-04 3.276E-04 5.214E-04 7.616E-04 1.049E-03 1.383E-03 1.764E-03 2.192E-03 2.667E-03 3.188E-03 3.754E-03 4.364E-03 5.018E-03 5.714E-03 6.450E-03 7.225E-03 8.037E-03 8.884E-03 9.765E-03 1.068E-02 1.162E-02 1.258E-02 1.357E-02 1.458E-02 1.561E-02 1.666E-02 1.771E-02 1.878E-02 1.986E-02 2.094E-02 2.202E-02 2.310E-02 2.418E-02 2.525E-02 2.631E-02 2.736E-02 2.840E-02 2.942E-02 3.042E-02 3.141E-02 3.237E-02 3.330E-02 3.421E-02 3.509E-02 3.594E-02 3.676E-02 3.755E-02 3.831E-02 3.903E-02 3.972E-02 4.037E-02 4.098E-02 4.156E-02 4.210E-02 4.260E-02 4.307E-02 4.350E-02 4.389E-02 4.425E-02 4.457E-02 4.485E-02 4.510E-02 4.532E-02 4.550E-02 4.566E-02 4.578E-02 4.587E-02 4.593E-02 4.596E-02 4.597E-02 4.595E-02 4.591E-02 4.585E-02 4.577E-02 4.566E-02 4.554E-02 4.540E-02 4.525E-02 4.508E-02 4.490E-02 4.471E-02 4.451E-02 4.430E-02 4.409E-02 4.386E-02 4.364E-02 4.341E-02 4.318E-02 4.295E-02 4.271E-02 4.248E-02 4.225E-02 4.203E-02 4.181E-02 4.159E-02 4.138E-02 4.118E-02 4.098E-02 4.080E-02 4.062E-02 4.045E-02 4.029E-02 4.015E-02 4.001E-02 3.988E-02 3.977E-02 3.967E-02 3.958E-02 3.951E-02 3.945E-02 3.940E-02 3.937E-02 3.935E-02 3.934E-02 3.935E-02 3.937E-02 3.940E-02 3.945E-02 3.951E-02 3.958E-02 3.967E-02 3.977E-02 3.988E-02 4.001E-02 4.015E-02 4.029E-02 4.045E-02 4.062E-02 4.080E-02 4.098E-02 4.118E-02 4.138E-02 4.159E-02 4.181E-02 4.203E-02 4.225E-02 4.248E-02 4.271E-02 4.295E-02 4.318E-02 4.341E-02 4.364E-02 4.386E-02 4.409E-02 4.430E-02 4.451E-02 4.471E-02 4.490E-02 4.508E-02 4.525E-02 4.540E-02 4.554E-02 4.566E-02 4.577E-02 4.585E-02 4.591E-02 4.595E-02 4.597E-02 4.596E-02 4.593E-02 4.587E-02 4.578E-02 4.566E-02 4.550E-02 4.532E-02 4.510E-02 4.485E-02 4.457E-02 4.425E-02 4.389E-02 4.350E-02 4.307E-02 4.260E-02 4.210E-02 4.156E-02 4.098E-02 4.037E-02 3.972E-02 3.903E-02 3.831E-02 3.755E-02 3.676E-02 3.594E-02 3.509E-02 3.421E-02 3.330E-02 3.237E-02 3.141E-02 3.042E-02 2.942E-02 2.840E-02 2.736E-02 2.631E-02 2.525E-02 2.418E-02 2.310E-02 2.202E-02 2.094E-02 1.986E-02 1.878E-02 1.771E-02 1.666E-02 1.561E-02 1.458E-02 1.357E-02 1.258E-02 1.162E-02 1.068E-02 9.765E-03 8.884E-03 8.037E-03 7.225E-03 6.450E-03 5.714E-03 5.018E-03 4.364E-03 3.754E-03 3.188E-03 2.667E-03 2.192E-03 1.764E-03 1.383E-03 1.049E-03 7.616E-04 5.214E-04 3.276E-04 1.795E-04 7.626E-05 1.691E-05 2.117E-07 2.478E-05 8.907E-05 1.913E-04 3.298E-04 5.023E-04 7.068E-04 9.410E-04 1.203E-03 1.489E-03 1.798E-03 2.127E-03 2.813E-03 2.456E-03 2.113E-03 1.788E-03 1.482E-03 1.198E-03 9.390E-04 7.068E-04 5.038E-04 3.324E-04 1.944E-04 9.192E-05 2.673E-05 4.832E-07 1.469E-05 7.067E-05 1.696E-04 3.125E-04 5.001E-04 7.331E-04 1.012E-03 1.337E-03 1.708E-03 2.124E-03 2.587E-03 3.094E-03 3.646E-03 4.241E-03 4.879E-03 5.557E-03 6.276E-03 7.032E-03 7.825E-03 8.652E-03 9.512E-03 1.040E-02 1.132E-02 1.226E-02 1.323E-02 1.422E-02 1.523E-02 1.625E-02 1.729E-02 1.833E-02 1.939E-02 2.045E-02 2.151E-02 2.257E-02 2.363E-02 2.469E-02 2.573E-02 2.677E-02 2.780E-02 2.881E-02 2.980E-02 3.077E-02 3.173E-02 3.266E-02 3.356E-02 3.444E-02 3.530E-02 3.612E-02 3.691E-02 3.767E-02 3.840E-02 3.910E-02 3.976E-02 4.039E-02 4.099E-02 4.154E-02 4.207E-02 4.256E-02 4.301E-02 4.343E-02 4.381E-02 4.416E-02 4.448E-02 4.476E-02 4.501E-02 4.523E-02 4.542E-02 4.558E-02 4.571E-02 4.581E-02 4.589E-02 4.594E-02 4.597E-02 4.597E-02 4.595E-02 4.591E-02 4.586E-02 4.578E-02 4.569E-02 4.558E-02 4.546E-02 4.533E-02 4.518E-02 4.503E-02 4.487E-02 4.470E-02 4.452E-02 4.434E-02 4.416E-02 4.397E-02 4.378E-02 4.359E-02 4.340E-02 4.321E-02 4.303E-02 4.285E-02 4.267E-02 4.250E-02 4.233E-02 4.217E-02 4.202E-02 4.187E-02 4.174E-02 4.161E-02 4.149E-02 4.138E-02 4.128E-02 4.120E-02 4.112E-02 4.106E-02 4.100E-02 4.096E-02 4.093E-02 4.091E-02 4.091E-02 4.091E-02 4.093E-02 4.096E-02 4.100E-02 4.106E-02 4.112E-02 4.120E-02 4.128E-02 4.138E-02 4.149E-02 4.161E-02 4.174E-02 4.187E-02 4.202E-02 4.217E-02 4.233E-02 4.250E-02 4.267E-02 4.285E-02 4.303E-02 4.321E-02 4.340E-02 4.359E-02 4.378E-02 4.397E-02 4.416E-02 4.434E-02 4.452E-02 4.470E-02 4.487E-02 4.503E-02 4.518E-02 4.533E-02 4.546E-02 4.558E-02 4.569E-02 4.578E-02 4.586E-02 4.591E-02 4.595E-02 4.597E-02 4.597E-02 4.594E-02 4.589E-02 4.581E-02 4.571E-02 4.558E-02 4.542E-02 4.523E-02 4.501E-02 4.476E-02 4.448E-02 4.416E-02 4.381E-02 4.343E-02 4.301E-02 4.256E-02 4.207E-02 4.154E-02 4.099E-02 4.039E-02 3.976E-02 3.910E-02 3.840E-02 3.767E-02 3.691E-02 3.612E-02 3.530E-02 3.444E-02 3.356E-02 3.266E-02 3.173E-02 3.077E-02 2.980E-02 2.881E-02 2.780E-02 2.677E-02 2.573E-02 2.469E-02 2.363E-02 2.257E-02 2.151E-02 2.045E-02 1.939E-02 1.833E-02 1.729E-02 1.625E-02 1.523E-02 1.422E-02 1.323E-02 1.226E-02 1.132E-02 1.040E-02 9.512E-03 8.652E-03 7.825E-03 7.032E-03 6.276E-03 5.557E-03 4.879E-03 4.241E-03 3.646E-03 3.094E-03 2.587E-03 2.124E-03 1.708E-03 1.337E-03 1.012E-03 7.331E-04 5.001E-04 3.125E-04 1.696E-04 7.067E-05 1.469E-05 4.832E-07 2.673E-05 9.192E-05 1.944E-04 3.324E-04 5.038E-04 7.068E-04 9.390E-04 1.198E-03 1.482E-03 1.788E-03 2.113E-03 2.456E-03 3.164E-03 2.799E-03 2.445E-03 2.106E-03 1.783E-03 1.480E-03 1.198E-03 9.410E-04 7.104E-04 5.085E-04 3.376E-04 1.995E-04 9.628E-05 2.957E-05 1.016E-06 1.206E-05 6.401E-05 1.580E-04 2.949E-04 4.756E-04 7.007E-04 9.705E-04 1.285E-03 1.645E-03 2.050E-03 2.499E-03 2.992E-03 3.529E-03 4.108E-03 4.729E-03 5.389E-03 6.089E-03 6.826E-03 7.599E-03 8.405E-03 9.244E-03 1.011E-02 1.101E-02 1.193E-02 1.288E-02 1.384E-02 1.483E-02 1.583E-02 1.684E-02 1.787E-02 1.890E-02 1.994E-02 2.098E-02 2.202E-02 2.307E-02 2.410E-02 2.513E-02 2.616E-02 2.717E-02 2.816E-02 2.915E-02 3.011E-02 3.106E-02 3.198E-02 3.288E-02 3.376E-02 3.461E-02 3.544E-02 3.623E-02 3.700E-02 3.774E-02 3.844E-02 3.912E-02 3.976E-02 4.037E-02 4.094E-02 4.148E-02 4.199E-02 4.247E-02 4.291E-02 4.332E-02 4.370E-02 4.405E-02 4.436E-02 4.464E-02 4.490E-02 4.512E-02 4.531E-02 4.548E-02 4.562E-02 4.574E-02 4.583E-02 4.590E-02 4.594E-02 4.597E-02 4.597E-02 4.596E-02 4.593E-02 4.588E-02 4.582E-02 4.574E-02 4.565E-02 4.555E-02 4.544E-02 4.532E-02 4.520E-02 4.506E-02 4.492E-02 4.478E-02 4.464E-02 4.449E-02 4.434E-02 4.419E-02 4.404E-02 4.390E-02 4.375E-02 4.361E-02 4.347E-02 4.334E-02 4.321E-02 4.309E-02 4.298E-02 4.287E-02 4.277E-02 4.268E-02 4.260E-02 4.252E-02 4.246E-02 4.240E-02 4.236E-02 4.232E-02 4.230E-02 4.228E-02 4.227E-02 4.228E-02 4.230E-02 4.232E-02 4.236E-02 4.240E-02 4.246E-02 4.252E-02 4.260E-02 4.268E-02 4.277E-02 4.287E-02 4.298E-02 4.309E-02 4.321E-02 4.334E-02 4.347E-02 4.361E-02 4.375E-02 4.390E-02 4.404E-02 4.419E-02 4.434E-02 4.449E-02 4.464E-02 4.478E-02 4.492E-02 4.506E-02 4.520E-02 4.532E-02 4.544E-02 4.555E-02 4.565E-02 4.574E-02 4.582E-02 4.588E-02 4.593E-02 4.596E-02 4.597E-02 4.597E-02 4.594E-02 4.590E-02 4.583E-02 4.574E-02 4.562E-02 4.548E-02 4.531E-02 4.512E-02 4.490E-02 4.464E-02 4.436E-02 4.405E-02 4.370E-02 4.332E-02 4.291E-02 4.247E-02 4.199E-02 4.148E-02 4.094E-02 4.037E-02 3.976E-02 3.912E-02 3.844E-02 3.774E-02 3.700E-02 3.623E-02 3.544E-02 3.461E-02 3.376E-02 3.288E-02 3.198E-02 3.106E-02 3.011E-02 2.915E-02 2.816E-02 2.717E-02 2.616E-02 2.513E-02 2.410E-02 2.307E-02 2.202E-02 2.098E-02 1.994E-02 1.890E-02 1.787E-02 1.684E-02 1.583E-02 1.483E-02 1.384E-02 1.288E-02 1.193E-02 1.101E-02 1.011E-02 9.244E-03 8.405E-03 7.599E-03 6.826E-03 6.089E-03 5.389E-03 4.729E-03 4.108E-03 3.529E-03 2.992E-03 2.499E-03 2.050E-03 1.645E-03 1.285E-03 9.705E-04 7.007E-04 4.756E-04 2.949E-04 1.580E-04 6.401E-05 1.206E-05 1.016E-06 2.957E-05 9.628E-05 1.995E-04 3.376E-04 5.085E-04 7.104E-04 9.410E-04 1.198E-03 1.480E-03 1.783E-03 2.106E-03 2.445E-03 2.799E-03 3.524E-03 3.153E-03 2.790E-03 2.440E-03 2.103E-03 1.783E-03 1.482E-03 1.203E-03 9.471E-04 7.176E-04 5.164E-04 3.455E-04 2.068E-04 1.022E-04 3.344E-05 1.956E-06 9.211E-06 5.645E-05 1.448E-04 2.751E-04 4.481E-04 6.645E-04 9.246E-04 1.229E-03 1.577E-03 1.969E-03 2.404E-03 2.882E-03 3.403E-03 3.965E-03 4.568E-03 5.210E-03 5.891E-03 6.608E-03 7.359E-03 8.145E-03 8.961E-03 9.807E-03 1.068E-02 1.158E-02 1.250E-02 1.344E-02 1.441E-02 1.538E-02 1.638E-02 1.738E-02 1.839E-02 1.941E-02 2.043E-02 2.145E-02 2.247E-02 2.349E-02 2.451E-02 2.551E-02 2.651E-02 2.750E-02 2.847E-02 2.942E-02 3.036E-02 3.127E-02 3.217E-02 3.304E-02 3.389E-02 3.472E-02 3.552E-02 3.629E-02 3.703E-02 3.774E-02 3.843E-02 3.908E-02 3.970E-02 4.029E-02 4.085E-02 4.138E-02 4.187E-02 4.234E-02 4.277E-02 4.318E-02 4.355E-02 4.389E-02 4.420E-02 4.449E-02 4.474E-02 4.497E-02 4.518E-02 4.535E-02 4.551E-02 4.563E-02 4.574E-02 4.583E-02 4.589E-02 4.593E-02 4.596E-02 4.597E-02 4.597E-02 4.594E-02 4.591E-02 4.586E-02 4.581E-02 4.574E-02 4.566E-02 4.558E-02 4.548E-02 4.539E-02 4.528E-02 4.518E-02 4.507E-02 4.496E-02 4.485E-02 4.473E-02 4.462E-02 4.451E-02 4.440E-02 4.430E-02 4.420E-02 4.410E-02 4.401E-02 4.392E-02 4.384E-02 4.377E-02 4.370E-02 4.364E-02 4.359E-02 4.354E-02 4.350E-02 4.347E-02 4.345E-02 4.344E-02 4.343E-02 4.344E-02 4.345E-02 4.347E-02 4.350E-02 4.354E-02 4.359E-02 4.364E-02 4.370E-02 4.377E-02 4.384E-02 4.392E-02 4.401E-02 4.410E-02 4.420E-02 4.430E-02 4.440E-02 4.451E-02 4.462E-02 4.473E-02 4.485E-02 4.496E-02 4.507E-02 4.518E-02 4.528E-02 4.539E-02 4.548E-02 4.558E-02 4.566E-02 4.574E-02 4.581E-02 4.586E-02 4.591E-02 4.594E-02 4.597E-02 4.597E-02 4.596E-02 4.593E-02 4.589E-02 4.583E-02 4.574E-02 4.563E-02 4.551E-02 4.535E-02 4.518E-02 4.497E-02 4.474E-02 4.449E-02 4.420E-02 4.389E-02 4.355E-02 4.318E-02 4.277E-02 4.234E-02 4.187E-02 4.138E-02 4.085E-02 4.029E-02 3.970E-02 3.908E-02 3.843E-02 3.774E-02 3.703E-02 3.629E-02 3.552E-02 3.472E-02 3.389E-02 3.304E-02 3.217E-02 3.127E-02 3.036E-02 2.942E-02 2.847E-02 2.750E-02 2.651E-02 2.551E-02 2.451E-02 2.349E-02 2.247E-02 2.145E-02 2.043E-02 1.941E-02 1.839E-02 1.738E-02 1.638E-02 1.538E-02 1.441E-02 1.344E-02 1.250E-02 1.158E-02 1.068E-02 9.807E-03 8.961E-03 8.145E-03 7.359E-03 6.608E-03 5.891E-03 5.210E-03 4.568E-03 3.965E-03 3.403E-03 2.882E-03 2.404E-03 1.969E-03 1.577E-03 1.229E-03 9.246E-04 6.645E-04 4.481E-04 2.751E-04 1.448E-04 5.645E-05 9.211E-06 1.956E-06 3.344E-05 1.022E-04 2.068E-04 3.455E-04 5.164E-04 7.176E-04 9.471E-04 1.203E-03 1.482E-03 1.783E-03 2.103E-03 2.440E-03 2.790E-03 3.153E-03 3.891E-03 3.516E-03 3.147E-03 2.787E-03 2.440E-03 2.106E-03 1.788E-03 1.489E-03 1.212E-03 9.572E-04 7.285E-04 5.275E-04 3.562E-04 2.164E-04 1.099E-04 3.847E-05 3.484E-06 6.341E-06 4.826E-05 1.303E-04 2.533E-04 4.181E-04 6.251E-04 8.748E-04 1.167E-03 1.503E-03 1.881E-03 2.302E-03 2.765E-03 3.269E-03 3.814E-03 4.398E-03 5.021E-03 5.682E-03 6.378E-03 7.108E-03 7.871E-03 8.665E-03 9.488E-03 1.034E-02 1.121E-02 1.211E-02 1.303E-02 1.397E-02 1.492E-02 1.589E-02 1.687E-02 1.786E-02 1.886E-02 1.986E-02 2.086E-02 2.186E-02 2.286E-02 2.386E-02 2.485E-02 2.583E-02 2.680E-02 2.776E-02 2.870E-02 2.963E-02 3.054E-02 3.143E-02 3.229E-02 3.314E-02 3.396E-02 3.476E-02 3.553E-02 3.628E-02 3.700E-02 3.769E-02 3.835E-02 3.899E-02 3.959E-02 4.016E-02 4.071E-02 4.122E-02 4.171E-02 4.216E-02 4.259E-02 4.299E-02 4.336E-02 4.370E-02 4.401E-02 4.430E-02 4.456E-02 4.479E-02 4.500E-02 4.519E-02 4.535E-02 4.550E-02 4.562E-02 4.572E-02 4.580E-02 4.587E-02 4.592E-02 4.595E-02 4.597E-02 4.597E-02 4.596E-02 4.595E-02 4.592E-02 4.588E-02 4.583E-02 4.578E-02 4.572E-02 4.565E-02 4.558E-02 4.551E-02 4.543E-02 4.536E-02 4.528E-02 4.520E-02 4.512E-02 4.504E-02 4.497E-02 4.489E-02 4.483E-02 4.476E-02 4.470E-02 4.464E-02 4.459E-02 4.454E-02 4.450E-02 4.446E-02 4.443E-02 4.441E-02 4.439E-02 4.438E-02 4.438E-02 4.438E-02 4.439E-02 4.441E-02 4.443E-02 4.446E-02 4.450E-02 4.454E-02 4.459E-02 4.464E-02 4.470E-02 4.476E-02 4.483E-02 4.489E-02 4.497E-02 4.504E-02 4.512E-02 4.520E-02 4.528E-02 4.536E-02 4.543E-02 4.551E-02 4.558E-02 4.565E-02 4.572E-02 4.578E-02 4.583E-02 4.588E-02 4.592E-02 4.595E-02 4.596E-02 4.597E-02 4.597E-02 4.595E-02 4.592E-02 4.587E-02 4.580E-02 4.572E-02 4.562E-02 4.550E-02 4.535E-02 4.519E-02 4.500E-02 4.479E-02 4.456E-02 4.430E-02 4.401E-02 4.370E-02 4.336E-02 4.299E-02 4.259E-02 4.216E-02 4.171E-02 4.122E-02 4.071E-02 4.016E-02 3.959E-02 3.899E-02 3.835E-02 3.769E-02 3.700E-02 3.628E-02 3.553E-02 3.476E-02 3.396E-02 3.314E-02 3.229E-02 3.143E-02 3.054E-02 2.963E-02 2.870E-02 2.776E-02 2.680E-02 2.583E-02 2.485E-02 2.386E-02 2.286E-02 2.186E-02 2.086E-02 1.986E-02 1.886E-02 1.786E-02 1.687E-02 1.589E-02 1.492E-02 1.397E-02 1.303E-02 1.211E-02 1.121E-02 1.034E-02 9.488E-03 8.665E-03 7.871E-03 7.108E-03 6.378E-03 5.682E-03 5.021E-03 4.398E-03 3.814E-03 3.269E-03 2.765E-03 2.302E-03 1.881E-03 1.503E-03 1.167E-03 8.748E-04 6.251E-04 4.181E-04 2.533E-04 1.303E-04 4.826E-05 6.341E-06 3.484E-06 3.847E-05 1.099E-04 2.164E-04 3.562E-04 5.275E-04 7.285E-04 9.572E-04 1.212E-03 1.489E-03 1.788E-03 2.106E-03 2.440E-03 2.787E-03 3.147E-03 3.516E-03 4.261E-03 3.885E-03 3.513E-03 3.147E-03 2.790E-03 2.445E-03 2.113E-03 1.798E-03 1.501E-03 1.225E-03 9.715E-04 7.432E-04 5.419E-04 3.697E-04 2.283E-04 1.195E-04 4.486E-05 5.812E-06 3.699E-06 3.969E-05 1.148E-04 2.299E-04 3.858E-04 5.828E-04 8.215E-04 1.102E-03 1.424E-03 1.789E-03 2.194E-03 2.641E-03 3.128E-03 3.654E-03 4.220E-03 4.823E-03 5.463E-03 6.137E-03 6.846E-03 7.586E-03 8.357E-03 9.157E-03 9.983E-03 1.083E-02 1.171E-02 1.260E-02 1.352E-02 1.445E-02 1.539E-02 1.635E-02 1.731E-02 1.828E-02 1.926E-02 2.024E-02 2.123E-02 2.221E-02 2.318E-02 2.416E-02 2.512E-02 2.608E-02 2.702E-02 2.795E-02 2.887E-02 2.977E-02 3.065E-02 3.151E-02 3.235E-02 3.317E-02 3.397E-02 3.474E-02 3.549E-02 3.622E-02 3.691E-02 3.758E-02 3.822E-02 3.884E-02 3.943E-02 3.999E-02 4.052E-02 4.102E-02 4.149E-02 4.194E-02 4.236E-02 4.275E-02 4.312E-02 4.346E-02 4.377E-02 4.406E-02 4.433E-02 4.457E-02 4.479E-02 4.498E-02 4.516E-02 4.531E-02 4.545E-02 4.557E-02 4.567E-02 4.575E-02 4.582E-02 4.588E-02 4.592E-02 4.595E-02 4.596E-02 4.597E-02 4.597E-02 4.596E-02 4.594E-02 4.591E-02 4.588E-02 4.585E-02 4.581E-02 4.576E-02 4.572E-02 4.567E-02 4.562E-02 4.557E-02 4.552E-02 4.547E-02 4.542E-02 4.538E-02 4.533E-02 4.529E-02 4.526E-02 4.522E-02 4.519E-02 4.517E-02 4.515E-02 4.513E-02 4.512E-02 4.511E-02 4.511E-02 4.511E-02 4.512E-02 4.513E-02 4.515E-02 4.517E-02 4.519E-02 4.522E-02 4.526E-02 4.529E-02 4.533E-02 4.538E-02 4.542E-02 4.547E-02 4.552E-02 4.557E-02 4.562E-02 4.567E-02 4.572E-02 4.576E-02 4.581E-02 4.585E-02 4.588E-02 4.591E-02 4.594E-02 4.596E-02 4.597E-02 4.597E-02 4.596E-02 4.595E-02 4.592E-02 4.588E-02 4.582E-02 4.575E-02 4.567E-02 4.557E-02 4.545E-02 4.531E-02 4.516E-02 4.498E-02 4.479E-02 4.457E-02 4.433E-02 4.406E-02 4.377E-02 4.346E-02 4.312E-02 4.275E-02 4.236E-02 4.194E-02 4.149E-02 4.102E-02 4.052E-02 3.999E-02 3.943E-02 3.884E-02 3.822E-02 3.758E-02 3.691E-02 3.622E-02 3.549E-02 3.474E-02 3.397E-02 3.317E-02 3.235E-02 3.151E-02 3.065E-02 2.977E-02 2.887E-02 2.795E-02 2.702E-02 2.608E-02 2.512E-02 2.416E-02 2.318E-02 2.221E-02 2.123E-02 2.024E-02 1.926E-02 1.828E-02 1.731E-02 1.635E-02 1.539E-02 1.445E-02 1.352E-02 1.260E-02 1.171E-02 1.083E-02 9.983E-03 9.157E-03 8.357E-03 7.586E-03 6.846E-03 6.137E-03 5.463E-03 4.823E-03 4.220E-03 3.654E-03 3.128E-03 2.641E-03 2.194E-03 1.789E-03 1.424E-03 1.102E-03 8.215E-04 5.828E-04 3.858E-04 2.299E-04 1.148E-04 3.969E-05 3.699E-06 5.812E-06 4.486E-05 1.195E-04 2.283E-04 3.697E-04 5.419E-04 7.432E-04 9.715E-04 1.225E-03 1.501E-03 1.798E-03 2.113E-03 2.445E-03 2.790E-03 3.147E-03 3.513E-03 3.885E-03 4.634E-03 4.258E-03 3.885E-03 3.516E-03 3.153E-03 2.799E-03 2.456E-03 2.127E-03 1.813E-03 1.518E-03 1.243E-03 9.900E-04 7.617E-04 5.598E-04 3.863E-04 2.428E-04 1.312E-04 5.282E-05 9.190E-06 1.565E-06 3.108E-05 9.874E-05 2.054E-04 3.517E-04 5.381E-04 7.652E-04 1.033E-03 1.342E-03 1.691E-03 2.081E-03 2.511E-03 2.980E-03 3.488E-03 4.033E-03 4.616E-03 5.234E-03 5.887E-03 6.573E-03 7.290E-03 8.037E-03 8.813E-03 9.614E-03 1.044E-02 1.129E-02 1.216E-02 1.305E-02 1.395E-02 1.487E-02 1.580E-02 1.674E-02 1.769E-02 1.865E-02 1.961E-02 2.057E-02 2.153E-02 2.249E-02 2.344E-02 2.439E-02 2.533E-02 2.626E-02 2.717E-02 2.808E-02 2.897E-02 2.984E-02 3.069E-02 3.153E-02 3.235E-02 3.314E-02 3.391E-02 3.466E-02 3.539E-02 3.609E-02 3.676E-02 3.741E-02 3.804E-02 3.864E-02 3.921E-02 3.975E-02 4.027E-02 4.076E-02 4.123E-02 4.167E-02 4.208E-02 4.247E-02 4.283E-02 4.317E-02 4.349E-02 4.378E-02 4.405E-02 4.430E-02 4.452E-02 4.473E-02 4.492E-02 4.508E-02 4.523E-02 4.537E-02 4.548E-02 4.559E-02 4.567E-02 4.575E-02 4.581E-02 4.586E-02 4.590E-02 4.593E-02 4.595E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.595E-02 4.594E-02 4.592E-02 4.590E-02 4.588E-02 4.585E-02 4.583E-02 4.580E-02 4.578E-02 4.575E-02 4.573E-02 4.571E-02 4.569E-02 4.567E-02 4.565E-02 4.564E-02 4.563E-02 4.562E-02 4.562E-02 4.561E-02 4.562E-02 4.562E-02 4.563E-02 4.564E-02 4.565E-02 4.567E-02 4.569E-02 4.571E-02 4.573E-02 4.575E-02 4.578E-02 4.580E-02 4.583E-02 4.585E-02 4.588E-02 4.590E-02 4.592E-02 4.594E-02 4.595E-02 4.597E-02 4.597E-02 4.597E-02 4.597E-02 4.595E-02 4.593E-02 4.590E-02 4.586E-02 4.581E-02 4.575E-02 4.567E-02 4.559E-02 4.548E-02 4.537E-02 4.523E-02 4.508E-02 4.492E-02 4.473E-02 4.452E-02 4.430E-02 4.405E-02 4.378E-02 4.349E-02 4.317E-02 4.283E-02 4.247E-02 4.208E-02 4.167E-02 4.123E-02 4.076E-02 4.027E-02 3.975E-02 3.921E-02 3.864E-02 3.804E-02 3.741E-02 3.676E-02 3.609E-02 3.539E-02 3.466E-02 3.391E-02 3.314E-02 3.235E-02 3.153E-02 3.069E-02 2.984E-02 2.897E-02 2.808E-02 2.717E-02 2.626E-02 2.533E-02 2.439E-02 2.344E-02 2.249E-02 2.153E-02 2.057E-02 1.961E-02 1.865E-02 1.769E-02 1.674E-02 1.580E-02 1.487E-02 1.395E-02 1.305E-02 1.216E-02 1.129E-02 1.044E-02 9.614E-03 8.813E-03 8.037E-03 7.290E-03 6.573E-03 5.887E-03 5.234E-03 4.616E-03 4.033E-03 3.488E-03 2.980E-03 2.511E-03 2.081E-03 1.691E-03 1.342E-03 1.033E-03 7.652E-04 5.381E-04 3.517E-04 2.054E-04 9.874E-05 3.108E-05 1.565E-06 9.190E-06 5.282E-05 1.312E-04 2.428E-04 3.863E-04 5.598E-04 7.617E-04 9.900E-04 1.243E-03 1.518E-03 1.813E-03 2.127E-03 2.456E-03 2.799E-03 3.153E-03 3.516E-03 3.885E-03 4.258E-03 ngraph-gtk-6.08.00/demo/demo5d.ngp0000644000175000017500000000121213070106167013454 00000000000000#! ngraph # new text text::x=3000 text::y=6500 text::font="Sans-serif" text::style=1 text::text="Demo #5D: CURVE" # STYLE="" drawcurve() { for i in `seq 0 10` do new path type=curve put path points:"3000 2000 10000 2000 15000 11000 20000 6000 \ 15000 1000 10000 10000 3000 10000" put path R:$R G:$G B:$B put path interpolation:$INTP put path style:"$STYLE" put path width:20 exe path move:"0 7000+${i}*500" done } # R=0 G=256 B=256 INTP=spline drawcurve R=0 G=128 B=256 INTP=spline_close drawcurve STYLE="300 50 50 50" R=0 G=64 B=256 INTP=bspline drawcurve R=0 G=0 B=256 INTP=bspline_close drawcurve # new gra ngraph-gtk-6.08.00/demo/demo3.ngp.in0000644000175000017500000003336413230344424013726 00000000000000#! ngraph new axis name:frameX axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=6.000000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=4500 axis::y=20500 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=true axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameY axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=7.000000000000000e-01 axis::max=1.100000000000000e+00 axis::inc=1.000000000000000e-01 axis::div=5 axis::type=linear axis::x=4500 axis::y=17500 axis::direction=9000 axis::baseline=true axis::length=8000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=begin axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=7.100000000000000e-01 axis::gauge_max=2.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameU axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=4500 axis::y=9500 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:frameR axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=18500 axis::y=17500 axis::direction=9000 axis::baseline=true axis::length=8000 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=begin axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:single_a axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=1.500000000000000e-01 axis::inc=1.000000000000000e-01 axis::div=5 axis::type=linear axis::x=4500 axis::y=20500 axis::direction=9000 axis::baseline=true axis::length=2500 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=end axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=-1.000000000000000e+00 axis::gauge_max=1.400000000000000e-01 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=true axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new axis name:single_b axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=18500 axis::y=20500 axis::direction=9000 axis::baseline=true axis::length=2500 axis::width=40 axis::style= axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=end axis::wave_length=300 axis::wave_width=40 axis::reference='axis:4' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::num=none axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=normal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=2 data::y=3 data::type=line data::interpolation=bspline data::fit= data::math_x= data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=100 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo3.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=2 data::y=3 data::type=mark data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=30 data::mark_size=400 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::file='DOCDIRDEF/demo3.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=2 data::y=3 data::type=line data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=100 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:4' data::file='DOCDIRDEF/demo3.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::clip=true data::redraw_flag=true data::save_path=unchange data::x=2 data::y=3 data::type=mark data::interpolation=spline data::fit= data::math_x= data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=30 data::mark_size=400 data::line_width=40 data::line_style= data::line_join=miter data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::remark='#%'\''' data::ifs=' , ()' data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:4' data::file='DOCDIRDEF/demo3.dat' new path path::type=line path::hidden=false path::R=0 path::G=0 path::B=0 path::clip=true path::redraw_flag=true path::points='4500 10500 6000 10500' path::width=80 path::style= path::join=miter path::miter_limit=1000 path::arrow=begin path::arrow_length=44100 path::arrow_width=28000 new rectangle rectangle::hidden=false rectangle::fill_R=0 rectangle::fill_G=0 rectangle::fill_B=0 rectangle::fill_A=64 rectangle::clip=true rectangle::redraw_flag=true rectangle::x1=11000 rectangle::y1=14200 rectangle::x2=18200 rectangle::y2=19900 rectangle::fill=true rectangle::stroke=false rectangle::stroke_R=0 rectangle::stroke_G=0 rectangle::stroke_B=0 rectangle::width=40 rectangle::style= new rectangle rectangle::hidden=false rectangle::fill_R=128 rectangle::fill_G=255 rectangle::fill_B=255 rectangle::clip=true rectangle::redraw_flag=true rectangle::x1=10700 rectangle::y1=13900 rectangle::x2=17900 rectangle::y2=19600 rectangle::fill=true rectangle::stroke=true rectangle::stroke_R=0 rectangle::stroke_G=0 rectangle::stroke_B=0 rectangle::width=40 rectangle::style= new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='0' text::x=4000 text::y=21000 text::pt=2000 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='%{file:0:column:1 0}\n%{file:0:column:2 0}\n%{file:0:column:3 0}\n%{file:0:column:4 0}\n%{file:0:column:5 0}\n%{file:0:column:6 0}\n%{file:0:column:7 0}' text::x=11000 text::y=14900 text::pt=2000 text::font='Monospace' text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Demo #3: AXIS DIVISION' text::x=2500 text::y=7500 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Sample length (μm)' text::x=9000 text::y=22000 text::pt=2000 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='Resistance (KΩ)' text::x=3000 text::y=17000 text::pt=2000 text::font='Sans-serif' text::style=0 text::space=0 text::direction=9000 text::script_size=7000 text::raw=false new text text::hidden=false text::R=0 text::G=0 text::B=0 text::clip=true text::redraw_flag=true text::text='critical value' text::x=6100 text::y=10700 text::pt=2000 text::font='Sans-serif' text::style=0 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj='rectangle axisgrid axis file merge legend arc path mark text' ngraph-gtk-6.08.00/demo/demo6.dat0000644000175000017500000027525013070106167013314 00000000000000 40.0000 0.0000 1.000 42.8995 2.6990 1.000 45.4200 5.7379 1.000 47.3606 9.0345 1.000 48.5569 12.4673 1.000 48.8964 15.8874 1.000 48.3264 19.1338 1.000 46.8587 22.0500 1.000 44.5671 24.5010 1.000 41.5799 26.3874 1.000 38.0670 27.6573 1.000 34.2243 28.3128 1.000 30.2551 28.4114 1.000 26.3523 28.0624 1.000 22.6811 27.4168 1.000 19.3655 26.6543 1.000 16.4787 25.9663 1.000 14.0393 25.5374 1.000 12.0123 25.5275 1.000 10.3162 26.0558 1.000 8.8340 27.1882 1.000 7.4279 28.9297 1.000 5.9560 31.2224 1.000 4.2888 33.9491 1.000 2.3242 36.9427 1.000 -0.0000 40.0000 1.000 -2.6990 42.8995 1.000 -5.7379 45.4200 1.000 -9.0345 47.3606 1.000 -12.4673 48.5569 1.000 -15.8874 48.8964 1.000 -19.1338 48.3264 1.000 -22.0500 46.8587 1.000 -24.5010 44.5671 1.000 -26.3874 41.5799 1.000 -27.6573 38.0670 1.000 -28.3128 34.2243 1.000 -28.4114 30.2551 1.000 -28.0624 26.3523 1.000 -27.4168 22.6811 1.000 -26.6543 19.3655 1.000 -25.9663 16.4787 1.000 -25.5374 14.0393 1.000 -25.5275 12.0123 1.000 -26.0558 10.3162 1.000 -27.1882 8.8340 1.000 -28.9297 7.4279 1.000 -31.2224 5.9560 1.000 -33.9491 4.2888 1.000 -36.9427 2.3242 1.000 -40.0000 -0.0000 1.000 -42.8995 -2.6990 1.000 -45.4200 -5.7379 1.000 -47.3606 -9.0345 1.000 -48.5569 -12.4673 1.000 -48.8964 -15.8874 1.000 -48.3264 -19.1338 1.000 -46.8587 -22.0500 1.000 -44.5671 -24.5010 1.000 -41.5799 -26.3874 1.000 -38.0670 -27.6573 1.000 -34.2243 -28.3128 1.000 -30.2551 -28.4114 1.000 -26.3523 -28.0624 1.000 -22.6811 -27.4168 1.000 -19.3655 -26.6543 1.000 -16.4787 -25.9663 1.000 -14.0393 -25.5374 1.000 -12.0123 -25.5275 1.000 -10.3162 -26.0558 1.000 -8.8340 -27.1882 1.000 -7.4279 -28.9297 1.000 -5.9560 -31.2224 1.000 -4.2888 -33.9491 1.000 -2.3242 -36.9427 1.000 -0.0000 -40.0000 1.000 2.6990 -42.8995 1.000 5.7379 -45.4200 1.000 9.0345 -47.3606 1.000 12.4673 -48.5569 1.000 15.8874 -48.8964 1.000 19.1338 -48.3264 1.000 22.0500 -46.8587 1.000 24.5010 -44.5671 1.000 26.3874 -41.5799 1.000 27.6573 -38.0670 1.000 28.3128 -34.2243 1.000 28.4114 -30.2551 1.000 28.0624 -26.3523 1.000 27.4168 -22.6811 1.000 26.6543 -19.3655 1.000 25.9663 -16.4787 1.000 25.5374 -14.0393 1.000 25.5275 -12.0123 1.000 26.0558 -10.3162 1.000 27.1882 -8.8340 1.000 28.9297 -7.4279 1.000 31.2224 -5.9560 1.000 33.9491 -4.2888 1.000 36.9427 -2.3242 1.000 = = = 40.0017 0.1250 0.975 42.7913 2.8093 0.975 45.1560 5.8137 0.975 46.9072 9.0492 0.975 47.8961 12.3905 0.975 48.0269 15.6893 0.975 47.2639 18.7886 0.975 45.6343 21.5401 0.975 43.2248 23.8193 0.975 40.1722 25.5397 0.975 36.6509 26.6626 0.975 32.8563 27.2027 0.975 28.9867 27.2279 0.975 25.2259 26.8548 0.975 21.7273 26.2376 0.975 18.6009 25.5548 0.975 15.9059 24.9917 0.975 13.6478 24.7229 0.975 11.7808 24.8949 0.975 10.2156 25.6111 0.975 8.8315 26.9209 0.975 7.4909 28.8133 0.975 6.0561 31.2167 0.975 4.4048 34.0033 0.975 2.4450 36.9997 0.975 0.1250 40.0017 0.975 -2.5593 42.7913 0.975 -5.5637 45.1560 0.975 -8.7992 46.9072 0.975 -12.1405 47.8961 0.975 -15.4393 48.0269 0.975 -18.5386 47.2639 0.975 -21.2901 45.6343 0.975 -23.5693 43.2248 0.975 -25.2897 40.1722 0.975 -26.4126 36.6509 0.975 -26.9527 32.8563 0.975 -26.9779 28.9867 0.975 -26.6048 25.2259 0.975 -25.9876 21.7273 0.975 -25.3048 18.6009 0.975 -24.7417 15.9059 0.975 -24.4729 13.6478 0.975 -24.6449 11.7808 0.975 -25.3611 10.2156 0.975 -26.6709 8.8315 0.975 -28.5633 7.4909 0.975 -30.9667 6.0561 0.975 -33.7533 4.4048 0.975 -36.7497 2.4450 0.975 -39.7517 0.1250 0.975 -42.5413 -2.5593 0.975 -44.9060 -5.5637 0.975 -46.6572 -8.7992 0.975 -47.6461 -12.1405 0.975 -47.7769 -15.4393 0.975 -47.0139 -18.5386 0.975 -45.3843 -21.2901 0.975 -42.9748 -23.5693 0.975 -39.9222 -25.2897 0.975 -36.4009 -26.4126 0.975 -32.6063 -26.9527 0.975 -28.7367 -26.9779 0.975 -24.9759 -26.6048 0.975 -21.4773 -25.9876 0.975 -18.3509 -25.3048 0.975 -15.6559 -24.7417 0.975 -13.3978 -24.4729 0.975 -11.5308 -24.6449 0.975 -9.9656 -25.3611 0.975 -8.5815 -26.6709 0.975 -7.2409 -28.5633 0.975 -5.8061 -30.9667 0.975 -4.1548 -33.7533 0.975 -2.1950 -36.7497 0.975 0.1250 -39.7517 0.975 2.8093 -42.5413 0.975 5.8137 -44.9060 0.975 9.0492 -46.6572 0.975 12.3905 -47.6461 0.975 15.6893 -47.7769 0.975 18.7886 -47.0139 0.975 21.5401 -45.3843 0.975 23.8193 -42.9748 0.975 25.5397 -39.9222 0.975 26.6626 -36.4009 0.975 27.2027 -32.6063 0.975 27.2279 -28.7367 0.975 26.8548 -24.9759 0.975 26.2376 -21.4773 0.975 25.5548 -18.3509 0.975 24.9917 -15.6559 0.975 24.7229 -13.3978 0.975 24.8949 -11.5308 0.975 25.6111 -9.9656 0.975 26.9209 -8.5815 0.975 28.8133 -7.2409 0.975 31.2167 -5.8061 0.975 34.0033 -4.1548 0.975 36.9997 -2.1950 0.975 = = = 39.9536 0.2500 0.950 42.6195 2.9157 0.950 44.8190 5.8804 0.950 46.3763 9.0491 0.950 47.1586 12.2941 0.950 47.0864 15.4681 0.950 46.1407 18.4194 0.950 44.3631 21.0081 0.950 41.8516 23.1207 0.950 38.7508 24.6833 0.950 35.2378 25.6701 0.950 31.5063 26.1074 0.950 27.7486 26.0729 0.950 24.1387 25.6889 0.950 20.8175 25.1118 0.950 17.8814 24.5175 0.950 15.3758 24.0844 0.950 13.2937 23.9764 0.950 11.5793 24.3260 0.950 10.1368 25.2212 0.950 8.8426 26.6952 0.950 7.5604 28.7221 0.950 6.1573 31.2173 0.950 4.5192 34.0440 0.950 2.5636 37.0241 0.950 0.2500 39.9536 0.950 -2.4157 42.6195 0.950 -5.3804 44.8190 0.950 -8.5491 46.3763 0.950 -11.7941 47.1586 0.950 -14.9681 47.0864 0.950 -17.9194 46.1407 0.950 -20.5081 44.3631 0.950 -22.6207 41.8516 0.950 -24.1833 38.7508 0.950 -25.1701 35.2378 0.950 -25.6074 31.5063 0.950 -25.5729 27.7486 0.950 -25.1889 24.1387 0.950 -24.6118 20.8175 0.950 -24.0175 17.8814 0.950 -23.5844 15.3758 0.950 -23.4764 13.2937 0.950 -23.8260 11.5793 0.950 -24.7212 10.1368 0.950 -26.1952 8.8426 0.950 -28.2221 7.5604 0.950 -30.7173 6.1573 0.950 -33.5440 4.5192 0.950 -36.5241 2.5636 0.950 -39.4536 0.2500 0.950 -42.1195 -2.4157 0.950 -44.3190 -5.3804 0.950 -45.8763 -8.5491 0.950 -46.6586 -11.7941 0.950 -46.5864 -14.9681 0.950 -45.6407 -17.9194 0.950 -43.8631 -20.5081 0.950 -41.3516 -22.6207 0.950 -38.2508 -24.1833 0.950 -34.7378 -25.1701 0.950 -31.0063 -25.6074 0.950 -27.2486 -25.5729 0.950 -23.6387 -25.1889 0.950 -20.3175 -24.6118 0.950 -17.3814 -24.0175 0.950 -14.8758 -23.5844 0.950 -12.7937 -23.4764 0.950 -11.0793 -23.8260 0.950 -9.6368 -24.7212 0.950 -8.3426 -26.1952 0.950 -7.0604 -28.2221 0.950 -5.6573 -30.7173 0.950 -4.0192 -33.5440 0.950 -2.0636 -36.5241 0.950 0.2500 -39.4536 0.950 2.9157 -42.1195 0.950 5.8804 -44.3190 0.950 9.0491 -45.8763 0.950 12.2941 -46.6586 0.950 15.4681 -46.5864 0.950 18.4194 -45.6407 0.950 21.0081 -43.8631 0.950 23.1207 -41.3516 0.950 24.6833 -38.2508 0.950 25.6701 -34.7378 0.950 26.1074 -31.0063 0.950 26.0729 -27.2486 0.950 25.6889 -23.6387 0.950 25.1118 -20.3175 0.950 24.5175 -17.3814 0.950 24.0844 -14.8758 0.950 23.9764 -12.7937 0.950 24.3260 -11.0793 0.950 25.2212 -9.6368 0.950 26.6952 -8.3426 0.950 28.7221 -7.0604 0.950 31.2173 -5.6573 0.950 34.0440 -4.0192 0.950 37.0241 -2.0636 0.950 = = = 39.8515 0.3750 0.925 42.3815 3.0178 0.925 44.4079 5.9376 0.925 45.7687 9.0343 0.925 46.3466 12.1785 0.925 46.0789 15.2251 0.925 44.9618 18.0282 0.925 43.0507 20.4567 0.925 40.4538 22.4085 0.925 37.3216 23.8220 0.925 33.8331 24.6837 0.925 30.1789 25.0310 0.925 26.5444 24.9497 0.925 23.0930 24.5672 0.925 19.9530 24.0407 0.925 17.2071 23.5424 0.925 14.8875 23.2430 0.925 12.9753 23.2949 0.925 11.4058 23.8167 0.925 10.0775 24.8808 0.925 8.8651 26.5049 0.925 7.6345 28.6491 0.925 6.2585 31.2172 0.925 4.6310 34.0647 0.925 2.6799 37.0104 0.925 0.3750 39.8515 0.925 -2.2678 42.3815 0.925 -5.1876 44.4079 0.925 -8.2843 45.7687 0.925 -11.4285 46.3466 0.925 -14.4751 46.0789 0.925 -17.2782 44.9618 0.925 -19.7067 43.0507 0.925 -21.6585 40.4538 0.925 -23.0720 37.3216 0.925 -23.9337 33.8331 0.925 -24.2810 30.1789 0.925 -24.1997 26.5444 0.925 -23.8172 23.0930 0.925 -23.2907 19.9530 0.925 -22.7924 17.2071 0.925 -22.4930 14.8875 0.925 -22.5449 12.9753 0.925 -23.0667 11.4058 0.925 -24.1308 10.0775 0.925 -25.7549 8.8651 0.925 -27.8991 7.6345 0.925 -30.4672 6.2585 0.925 -33.3147 4.6310 0.925 -36.2604 2.6799 0.925 -39.1015 0.3750 0.925 -41.6315 -2.2678 0.925 -43.6579 -5.1876 0.925 -45.0187 -8.2843 0.925 -45.5966 -11.4285 0.925 -45.3289 -14.4751 0.925 -44.2118 -17.2782 0.925 -42.3007 -19.7067 0.925 -39.7038 -21.6585 0.925 -36.5716 -23.0720 0.925 -33.0831 -23.9337 0.925 -29.4289 -24.2810 0.925 -25.7944 -24.1997 0.925 -22.3430 -23.8172 0.925 -19.2030 -23.2907 0.925 -16.4571 -22.7924 0.925 -14.1375 -22.4930 0.925 -12.2253 -22.5449 0.925 -10.6558 -23.0667 0.925 -9.3275 -24.1308 0.925 -8.1151 -25.7549 0.925 -6.8845 -27.8991 0.925 -5.5085 -30.4672 0.925 -3.8810 -33.3147 0.925 -1.9299 -36.2604 0.925 0.3750 -39.1015 0.925 3.0178 -41.6315 0.925 5.9376 -43.6579 0.925 9.0343 -45.0187 0.925 12.1785 -45.5966 0.925 15.2251 -45.3289 0.925 18.0282 -44.2118 0.925 20.4567 -42.3007 0.925 22.4085 -39.7038 0.925 23.8220 -36.5716 0.925 24.6837 -33.0831 0.925 25.0310 -29.4289 0.925 24.9497 -25.7944 0.925 24.5672 -22.3430 0.925 24.0407 -19.2030 0.925 23.5424 -16.4571 0.925 23.2430 -14.1375 0.925 23.2949 -12.2253 0.925 23.8167 -10.6558 0.925 24.8808 -9.3275 0.925 26.5049 -8.1151 0.925 28.6491 -6.8845 0.925 31.2172 -5.5085 0.925 34.0647 -3.8810 0.925 37.0104 -1.9299 0.925 = = = 39.6916 0.5000 0.900 42.0750 3.1157 0.900 43.9223 5.9855 0.900 45.0855 9.0051 0.900 45.4632 12.0446 0.900 45.0084 14.9617 0.900 43.7324 17.6169 0.900 41.7030 19.8886 0.900 39.0371 21.6860 0.900 35.8904 22.9594 0.900 32.4420 23.7072 0.900 28.8785 23.9768 0.900 25.3773 23.8613 0.900 22.0909 23.4920 0.900 19.1347 23.0254 0.900 16.5779 22.6293 0.900 14.4399 22.4658 0.900 12.6910 22.6753 0.900 11.2582 23.3623 0.900 10.0356 24.5841 0.900 8.8971 26.3436 0.900 7.7117 28.5876 0.900 6.3582 31.2099 0.900 4.7396 34.0595 0.900 2.7935 36.9534 0.900 0.5000 39.6916 0.900 -2.1157 42.0750 0.900 -4.9855 43.9223 0.900 -8.0051 45.0855 0.900 -11.0446 45.4632 0.900 -13.9617 45.0084 0.900 -16.6169 43.7324 0.900 -18.8886 41.7030 0.900 -20.6860 39.0371 0.900 -21.9594 35.8904 0.900 -22.7072 32.4420 0.900 -22.9768 28.8785 0.900 -22.8613 25.3773 0.900 -22.4920 22.0909 0.900 -22.0254 19.1347 0.900 -21.6293 16.5779 0.900 -21.4658 14.4399 0.900 -21.6753 12.6910 0.900 -22.3623 11.2582 0.900 -23.5841 10.0356 0.900 -25.3436 8.8971 0.900 -27.5876 7.7117 0.900 -30.2099 6.3582 0.900 -33.0595 4.7396 0.900 -35.9534 2.7935 0.900 -38.6916 0.5000 0.900 -41.0750 -2.1157 0.900 -42.9223 -4.9855 0.900 -44.0855 -8.0051 0.900 -44.4632 -11.0446 0.900 -44.0084 -13.9617 0.900 -42.7324 -16.6169 0.900 -40.7030 -18.8886 0.900 -38.0371 -20.6860 0.900 -34.8904 -21.9594 0.900 -31.4420 -22.7072 0.900 -27.8785 -22.9768 0.900 -24.3773 -22.8613 0.900 -21.0909 -22.4920 0.900 -18.1347 -22.0254 0.900 -15.5779 -21.6293 0.900 -13.4399 -21.4658 0.900 -11.6910 -21.6753 0.900 -10.2582 -22.3623 0.900 -9.0356 -23.5841 0.900 -7.8971 -25.3436 0.900 -6.7117 -27.5876 0.900 -5.3582 -30.2099 0.900 -3.7396 -33.0595 0.900 -1.7935 -35.9534 0.900 0.5000 -38.6916 0.900 3.1157 -41.0750 0.900 5.9855 -42.9223 0.900 9.0051 -44.0855 0.900 12.0446 -44.4632 0.900 14.9617 -44.0084 0.900 17.6169 -42.7324 0.900 19.8886 -40.7030 0.900 21.6860 -38.0371 0.900 22.9594 -34.8904 0.900 23.7072 -31.4420 0.900 23.9768 -27.8785 0.900 23.8613 -24.3773 0.900 23.4920 -21.0909 0.900 23.0254 -18.1347 0.900 22.6293 -15.5779 0.900 22.4658 -13.4399 0.900 22.6753 -11.6910 0.900 23.3623 -10.2582 0.900 24.5841 -9.0356 0.900 26.3436 -7.8971 0.900 28.5876 -6.7117 0.900 31.2099 -5.3582 0.900 34.0595 -3.7396 0.900 36.9534 -1.7935 0.900 = = = 39.4709 0.6250 0.875 41.6986 3.2091 0.875 43.3624 6.0240 0.875 44.3287 8.9619 0.875 44.5116 11.8932 0.875 43.8796 14.6793 0.875 42.4580 17.1879 0.875 40.3258 19.3068 0.875 37.6077 20.9564 0.875 34.4629 22.0992 0.875 31.0695 22.7442 0.875 27.6091 22.9482 0.875 24.2502 22.8105 0.875 21.1340 22.4648 0.875 18.3629 22.0665 0.875 15.9931 21.7774 0.875 14.0316 21.7504 0.875 12.4386 22.1138 0.875 11.1341 22.9580 0.875 10.0087 24.3254 0.875 8.9364 26.2049 0.875 7.7901 28.5312 0.875 6.4554 31.1891 0.875 4.8441 34.0228 0.875 2.9040 36.8486 0.875 0.6250 39.4709 0.875 -1.9591 41.6986 0.875 -4.7740 43.3624 0.875 -7.7119 44.3287 0.875 -10.6432 44.5116 0.875 -13.4293 43.8796 0.875 -15.9379 42.4580 0.875 -18.0568 40.3258 0.875 -19.7064 37.6077 0.875 -20.8492 34.4629 0.875 -21.4942 31.0695 0.875 -21.6982 27.6091 0.875 -21.5605 24.2502 0.875 -21.2148 21.1340 0.875 -20.8165 18.3629 0.875 -20.5274 15.9931 0.875 -20.5004 14.0316 0.875 -20.8638 12.4386 0.875 -21.7080 11.1341 0.875 -23.0754 10.0087 0.875 -24.9549 8.9364 0.875 -27.2812 7.7901 0.875 -29.9391 6.4554 0.875 -32.7728 4.8441 0.875 -35.5986 2.9040 0.875 -38.2209 0.6250 0.875 -40.4486 -1.9591 0.875 -42.1124 -4.7740 0.875 -43.0787 -7.7119 0.875 -43.2616 -10.6432 0.875 -42.6296 -13.4293 0.875 -41.2080 -15.9379 0.875 -39.0758 -18.0568 0.875 -36.3577 -19.7064 0.875 -33.2129 -20.8492 0.875 -29.8195 -21.4942 0.875 -26.3591 -21.6982 0.875 -23.0002 -21.5605 0.875 -19.8840 -21.2148 0.875 -17.1129 -20.8165 0.875 -14.7431 -20.5274 0.875 -12.7816 -20.5004 0.875 -11.1886 -20.8638 0.875 -9.8841 -21.7080 0.875 -8.7587 -23.0754 0.875 -7.6864 -24.9549 0.875 -6.5401 -27.2812 0.875 -5.2054 -29.9391 0.875 -3.5941 -32.7728 0.875 -1.6540 -35.5986 0.875 0.6250 -38.2209 0.875 3.2091 -40.4486 0.875 6.0240 -42.1124 0.875 8.9619 -43.0787 0.875 11.8932 -43.2616 0.875 14.6793 -42.6296 0.875 17.1879 -41.2080 0.875 19.3068 -39.0758 0.875 20.9564 -36.3577 0.875 22.0992 -33.2129 0.875 22.7442 -29.8195 0.875 22.9482 -26.3591 0.875 22.8105 -23.0002 0.875 22.4648 -19.8840 0.875 22.0665 -17.1129 0.875 21.7774 -14.7431 0.875 21.7504 -12.7816 0.875 22.1138 -11.1886 0.875 22.9580 -9.8841 0.875 24.3254 -8.7587 0.875 26.2049 -7.6864 0.875 28.5312 -6.5401 0.875 31.1891 -5.2054 0.875 34.0228 -3.5941 0.875 36.8486 -1.6540 0.875 = = = 39.1866 0.7500 0.850 41.2513 3.2981 0.850 42.7289 6.0532 0.850 43.5006 8.9051 0.850 43.4956 11.7252 0.850 42.6973 14.3795 0.850 41.1442 16.7432 0.850 38.9251 18.7139 0.850 36.1715 20.2232 0.850 33.0445 21.2447 0.850 29.7203 21.7981 0.850 26.3742 21.9482 0.850 23.1654 21.7995 0.850 20.2235 21.4871 0.850 17.6378 21.1639 0.850 15.4518 20.9852 0.850 13.6608 21.0942 0.850 12.2160 21.6066 0.850 11.0312 22.5987 0.850 9.9944 24.0987 0.850 8.9810 26.0823 0.850 7.8681 28.4733 0.850 6.5489 31.1488 0.850 4.9440 33.9493 0.850 3.0113 36.6921 0.850 0.7500 39.1866 0.850 -1.7981 41.2513 0.850 -4.5532 42.7289 0.850 -7.4051 43.5006 0.850 -10.2252 43.4956 0.850 -12.8795 42.6973 0.850 -15.2432 41.1442 0.850 -17.2139 38.9251 0.850 -18.7232 36.1715 0.850 -19.7447 33.0445 0.850 -20.2981 29.7203 0.850 -20.4482 26.3742 0.850 -20.2995 23.1654 0.850 -19.9871 20.2235 0.850 -19.6639 17.6378 0.850 -19.4852 15.4518 0.850 -19.5942 13.6608 0.850 -20.1066 12.2160 0.850 -21.0987 11.0312 0.850 -22.5987 9.9944 0.850 -24.5823 8.9810 0.850 -26.9733 7.8681 0.850 -29.6488 6.5489 0.850 -32.4493 4.9440 0.850 -35.1921 3.0113 0.850 -37.6866 0.7500 0.850 -39.7513 -1.7981 0.850 -41.2289 -4.5532 0.850 -42.0006 -7.4051 0.850 -41.9956 -10.2252 0.850 -41.1973 -12.8795 0.850 -39.6442 -15.2432 0.850 -37.4251 -17.2139 0.850 -34.6715 -18.7232 0.850 -31.5445 -19.7447 0.850 -28.2203 -20.2981 0.850 -24.8742 -20.4482 0.850 -21.6654 -20.2995 0.850 -18.7235 -19.9871 0.850 -16.1378 -19.6639 0.850 -13.9518 -19.4852 0.850 -12.1608 -19.5942 0.850 -10.7160 -20.1066 0.850 -9.5312 -21.0987 0.850 -8.4944 -22.5987 0.850 -7.4810 -24.5823 0.850 -6.3681 -26.9733 0.850 -5.0489 -29.6488 0.850 -3.4440 -32.4493 0.850 -1.5113 -35.1921 0.850 0.7500 -37.6866 0.850 3.2981 -39.7513 0.850 6.0532 -41.2289 0.850 8.9051 -42.0006 0.850 11.7252 -41.9956 0.850 14.3795 -41.1973 0.850 16.7432 -39.6442 0.850 18.7139 -37.4251 0.850 20.2232 -34.6715 0.850 21.2447 -31.5445 0.850 21.7981 -28.2203 0.850 21.9482 -24.8742 0.850 21.7995 -21.6654 0.850 21.4871 -18.7235 0.850 21.1639 -16.1378 0.850 20.9852 -13.9518 0.850 21.0942 -12.1608 0.850 21.6066 -10.7160 0.850 22.5987 -9.5312 0.850 24.0987 -8.4944 0.850 26.0823 -7.4810 0.850 28.4733 -6.3681 0.850 31.1488 -5.0489 0.850 33.9493 -3.4440 0.850 36.6921 -1.5113 0.850 = = = 38.8370 0.8750 0.825 40.7328 3.3826 0.825 42.0232 6.0732 0.825 42.6040 8.8352 0.825 42.4194 11.5418 0.825 41.4668 14.0641 0.825 39.7967 16.2852 0.825 37.5071 18.1128 0.825 34.7343 19.4893 0.825 31.6405 20.3994 0.825 28.3986 20.8721 0.825 25.1770 20.9794 0.825 22.1250 20.8301 0.825 19.3601 20.5596 0.825 16.9590 20.3172 0.825 14.9526 20.2512 0.825 13.3257 20.4941 0.825 12.0208 21.1491 0.825 10.9469 22.2789 0.825 9.9904 23.8979 0.825 9.0287 25.9695 0.825 7.9442 28.4076 0.825 6.6375 31.0831 0.825 5.0387 33.8342 0.825 3.1151 36.4803 0.825 0.8750 38.8370 0.825 -1.6326 40.7328 0.825 -4.3232 42.0232 0.825 -7.0852 42.6040 0.825 -9.7918 42.4194 0.825 -12.3141 41.4668 0.825 -14.5352 39.7967 0.825 -16.3628 37.5071 0.825 -17.7393 34.7343 0.825 -18.6494 31.6405 0.825 -19.1221 28.3986 0.825 -19.2294 25.1770 0.825 -19.0801 22.1250 0.825 -18.8096 19.3601 0.825 -18.5672 16.9590 0.825 -18.5012 14.9526 0.825 -18.7441 13.3257 0.825 -19.3991 12.0208 0.825 -20.5289 10.9469 0.825 -22.1479 9.9904 0.825 -24.2195 9.0287 0.825 -26.6576 7.9442 0.825 -29.3331 6.6375 0.825 -32.0842 5.0387 0.825 -34.7303 3.1151 0.825 -37.0870 0.8750 0.825 -38.9828 -1.6326 0.825 -40.2732 -4.3232 0.825 -40.8540 -7.0852 0.825 -40.6694 -9.7918 0.825 -39.7168 -12.3141 0.825 -38.0467 -14.5352 0.825 -35.7571 -16.3628 0.825 -32.9843 -17.7393 0.825 -29.8905 -18.6494 0.825 -26.6486 -19.1221 0.825 -23.4270 -19.2294 0.825 -20.3750 -19.0801 0.825 -17.6101 -18.8096 0.825 -15.2090 -18.5672 0.825 -13.2026 -18.5012 0.825 -11.5757 -18.7441 0.825 -10.2708 -19.3991 0.825 -9.1969 -20.5289 0.825 -8.2404 -22.1479 0.825 -7.2787 -24.2195 0.825 -6.1942 -26.6576 0.825 -4.8875 -29.3331 0.825 -3.2887 -32.0842 0.825 -1.3651 -34.7303 0.825 0.8750 -37.0870 0.825 3.3826 -38.9828 0.825 6.0732 -40.2732 0.825 8.8352 -40.8540 0.825 11.5418 -40.6694 0.825 14.0641 -39.7168 0.825 16.2852 -38.0467 0.825 18.1128 -35.7571 0.825 19.4893 -32.9843 0.825 20.3994 -29.8905 0.825 20.8721 -26.6486 0.825 20.9794 -23.4270 0.825 20.8301 -20.3750 0.825 20.5596 -17.6101 0.825 20.3172 -15.2090 0.825 20.2512 -13.2026 0.825 20.4941 -11.5757 0.825 21.1491 -10.2708 0.825 22.2789 -9.1969 0.825 23.8979 -8.2404 0.825 25.9695 -7.2787 0.825 28.4076 -6.1942 0.825 31.0831 -4.8875 0.825 33.8342 -3.2887 0.825 36.4803 -1.3651 0.825 = = = 38.4206 1.0000 0.800 40.1433 3.4627 0.800 41.2472 6.0844 0.800 41.6424 8.7529 0.800 41.2875 11.3441 0.800 40.1935 13.7347 0.800 38.4216 15.8163 0.800 36.0776 17.5063 0.800 33.3017 18.7580 0.800 30.2557 19.5663 0.800 27.1085 19.9689 0.800 24.0205 20.0442 0.800 21.1306 19.9039 0.800 18.5443 19.6828 0.800 16.3258 19.5257 0.800 14.4941 19.5730 0.800 13.0239 19.9466 0.800 11.8505 20.7370 0.800 10.8787 21.9933 0.800 9.9943 23.7170 0.800 9.0776 25.8603 0.800 8.0167 28.3283 0.800 6.7203 30.9869 0.800 5.1276 33.6734 0.800 3.2152 36.2102 0.800 1.0000 38.4206 0.800 -1.4627 40.1433 0.800 -4.0844 41.2472 0.800 -6.7529 41.6424 0.800 -9.3441 41.2875 0.800 -11.7347 40.1935 0.800 -13.8163 38.4216 0.800 -15.5063 36.0776 0.800 -16.7580 33.3017 0.800 -17.5663 30.2557 0.800 -17.9689 27.1085 0.800 -18.0442 24.0205 0.800 -17.9039 21.1306 0.800 -17.6828 18.5443 0.800 -17.5257 16.3258 0.800 -17.5730 14.4941 0.800 -17.9466 13.0239 0.800 -18.7370 11.8505 0.800 -19.9933 10.8787 0.800 -21.7170 9.9943 0.800 -23.8603 9.0776 0.800 -26.3283 8.0167 0.800 -28.9869 6.7203 0.800 -31.6734 5.1276 0.800 -34.2102 3.2152 0.800 -36.4206 1.0000 0.800 -38.1433 -1.4627 0.800 -39.2472 -4.0844 0.800 -39.6424 -6.7529 0.800 -39.2875 -9.3441 0.800 -38.1935 -11.7347 0.800 -36.4216 -13.8163 0.800 -34.0776 -15.5063 0.800 -31.3017 -16.7580 0.800 -28.2557 -17.5663 0.800 -25.1085 -17.9689 0.800 -22.0205 -18.0442 0.800 -19.1306 -17.9039 0.800 -16.5443 -17.6828 0.800 -14.3258 -17.5257 0.800 -12.4941 -17.5730 0.800 -11.0239 -17.9466 0.800 -9.8505 -18.7370 0.800 -8.8787 -19.9933 0.800 -7.9943 -21.7170 0.800 -7.0776 -23.8603 0.800 -6.0167 -26.3283 0.800 -4.7203 -28.9869 0.800 -3.1276 -31.6734 0.800 -1.2152 -34.2102 0.800 1.0000 -36.4206 0.800 3.4627 -38.1433 0.800 6.0844 -39.2472 0.800 8.7529 -39.6424 0.800 11.3441 -39.2875 0.800 13.7347 -38.1935 0.800 15.8163 -36.4216 0.800 17.5063 -34.0776 0.800 18.7580 -31.3017 0.800 19.5663 -28.2557 0.800 19.9689 -25.1085 0.800 20.0442 -22.0205 0.800 19.9039 -19.1306 0.800 19.6828 -16.5443 0.800 19.5257 -14.3258 0.800 19.5730 -12.4941 0.800 19.9466 -11.0239 0.800 20.7370 -9.8505 0.800 21.9933 -8.8787 0.800 23.7170 -7.9943 0.800 25.8603 -7.0776 0.800 28.3283 -6.0167 0.800 30.9869 -4.7203 0.800 33.6734 -3.1276 0.800 36.2102 -1.2152 0.800 = = = 37.9365 1.1250 0.775 39.4838 3.5383 0.775 40.4033 6.0870 0.775 40.6195 8.6590 0.775 40.1049 11.1333 0.775 38.8830 13.3933 0.775 37.0247 15.3387 0.775 34.6425 16.8971 0.775 31.8791 18.0322 0.775 28.8949 18.7483 0.775 25.8534 19.0913 0.775 22.9069 19.1446 0.775 20.1834 19.0220 0.775 17.7761 18.8566 0.775 15.7372 18.7881 0.775 14.0743 18.9482 0.775 12.7531 19.4479 0.775 11.7024 20.3652 0.775 10.8238 21.7361 0.775 10.0037 23.5500 0.775 9.1257 25.7485 0.775 8.0843 28.2295 0.775 6.7963 30.8551 0.775 5.2102 33.4629 0.775 3.3116 35.8796 0.775 1.1250 37.9365 0.775 -1.2883 39.4838 0.775 -3.8370 40.4033 0.775 -6.4090 40.6195 0.775 -8.8833 40.1049 0.775 -11.1433 38.8830 0.775 -13.0887 37.0247 0.775 -14.6471 34.6425 0.775 -15.7822 31.8791 0.775 -16.4983 28.8949 0.775 -16.8413 25.8534 0.775 -16.8946 22.9069 0.775 -16.7720 20.1834 0.775 -16.6066 17.7761 0.775 -16.5381 15.7372 0.775 -16.6982 14.0743 0.775 -17.1979 12.7531 0.775 -18.1152 11.7024 0.775 -19.4861 10.8238 0.775 -21.3000 10.0037 0.775 -23.4985 9.1257 0.775 -25.9795 8.0843 0.775 -28.6051 6.7963 0.775 -31.2129 5.2102 0.775 -33.6296 3.3116 0.775 -35.6865 1.1250 0.775 -37.2338 -1.2883 0.775 -38.1533 -3.8370 0.775 -38.3695 -6.4090 0.775 -37.8549 -8.8833 0.775 -36.6330 -11.1433 0.775 -34.7747 -13.0887 0.775 -32.3925 -14.6471 0.775 -29.6291 -15.7822 0.775 -26.6449 -16.4983 0.775 -23.6034 -16.8413 0.775 -20.6569 -16.8946 0.775 -17.9334 -16.7720 0.775 -15.5261 -16.6066 0.775 -13.4872 -16.5381 0.775 -11.8243 -16.6982 0.775 -10.5031 -17.1979 0.775 -9.4524 -18.1152 0.775 -8.5738 -19.4861 0.775 -7.7537 -21.3000 0.775 -6.8757 -23.4985 0.775 -5.8343 -25.9795 0.775 -4.5463 -28.6051 0.775 -2.9602 -31.2129 0.775 -1.0616 -33.6296 0.775 1.1250 -35.6865 0.775 3.5383 -37.2338 0.775 6.0870 -38.1533 0.775 8.6590 -38.3695 0.775 11.1333 -37.8549 0.775 13.3933 -36.6330 0.775 15.3387 -34.7747 0.775 16.8971 -32.3925 0.775 18.0322 -29.6291 0.775 18.7483 -26.6449 0.775 19.0913 -23.6034 0.775 19.1446 -20.6569 0.775 19.0220 -17.9334 0.775 18.8566 -15.5261 0.775 18.7881 -13.4872 0.775 18.9482 -11.8243 0.775 19.4479 -10.5031 0.775 20.3652 -9.4524 0.775 21.7361 -8.5738 0.775 23.5500 -7.7537 0.775 25.7485 -6.8757 0.775 28.2295 -5.8343 0.775 30.8551 -4.5463 0.775 33.4629 -2.9602 0.775 35.8796 -1.0616 0.775 = = = 37.3847 1.2500 0.750 38.7555 3.6096 0.750 39.4944 6.0814 0.750 39.5395 8.5541 0.750 38.8768 10.9109 0.750 37.5410 13.0417 0.750 35.6121 14.8549 0.750 33.2076 16.2881 0.750 30.4717 17.3148 0.750 27.5623 17.9483 0.750 24.6367 18.2414 0.750 21.8383 18.2821 0.750 19.2839 18.1850 0.750 17.0550 18.0806 0.750 15.1917 18.1026 0.750 13.6912 18.3738 0.750 12.5107 18.9940 0.750 11.5737 20.0288 0.750 10.7798 21.5018 0.750 10.0161 23.3908 0.750 9.1710 25.6283 0.750 8.1454 28.1060 0.750 6.8647 30.6834 0.750 5.2862 33.1995 0.750 3.4040 35.4867 0.750 1.2500 37.3847 0.750 -1.1096 38.7555 0.750 -3.5814 39.4944 0.750 -6.0541 39.5395 0.750 -8.4109 38.8768 0.750 -10.5417 37.5410 0.750 -12.3549 35.6121 0.750 -13.7881 33.2076 0.750 -14.8148 30.4717 0.750 -15.4483 27.5623 0.750 -15.7414 24.6367 0.750 -15.7821 21.8383 0.750 -15.6850 19.2839 0.750 -15.5806 17.0550 0.750 -15.6026 15.1917 0.750 -15.8738 13.6912 0.750 -16.4940 12.5107 0.750 -17.5288 11.5737 0.750 -19.0018 10.7798 0.750 -20.8908 10.0161 0.750 -23.1283 9.1710 0.750 -25.6060 8.1454 0.750 -28.1834 6.8647 0.750 -30.6995 5.2862 0.750 -32.9867 3.4040 0.750 -34.8847 1.2500 0.750 -36.2555 -1.1096 0.750 -36.9944 -3.5814 0.750 -37.0395 -6.0541 0.750 -36.3768 -8.4109 0.750 -35.0410 -10.5417 0.750 -33.1121 -12.3549 0.750 -30.7076 -13.7881 0.750 -27.9717 -14.8148 0.750 -25.0623 -15.4483 0.750 -22.1367 -15.7414 0.750 -19.3383 -15.7821 0.750 -16.7839 -15.6850 0.750 -14.5550 -15.5806 0.750 -12.6917 -15.6026 0.750 -11.1912 -15.8738 0.750 -10.0107 -16.4940 0.750 -9.0737 -17.5288 0.750 -8.2798 -19.0018 0.750 -7.5161 -20.8908 0.750 -6.6710 -23.1283 0.750 -5.6454 -25.6060 0.750 -4.3647 -28.1834 0.750 -2.7862 -30.6995 0.750 -0.9040 -32.9867 0.750 1.2500 -34.8847 0.750 3.6096 -36.2555 0.750 6.0814 -36.9944 0.750 8.5541 -37.0395 0.750 10.9109 -36.3768 0.750 13.0417 -35.0410 0.750 14.8549 -33.1121 0.750 16.2881 -30.7076 0.750 17.3148 -27.9717 0.750 17.9483 -25.0623 0.750 18.2414 -22.1367 0.750 18.2821 -19.3383 0.750 18.1850 -16.7839 0.750 18.0806 -14.5550 0.750 18.1026 -12.6917 0.750 18.3738 -11.1912 0.750 18.9940 -10.0107 0.750 20.0288 -9.0737 0.750 21.5018 -8.2798 0.750 23.3908 -7.5161 0.750 25.6283 -6.6710 0.750 28.1060 -5.6454 0.750 30.6834 -4.3647 0.750 33.1995 -2.7862 0.750 35.4867 -0.9040 0.750 = = = 36.7656 1.3750 0.725 37.9606 3.6768 0.725 38.5238 6.0680 0.725 38.4069 8.4392 0.725 37.6084 10.6782 0.725 36.1735 12.6817 0.725 34.1897 14.3672 0.725 31.7785 15.6818 0.725 29.0844 16.6084 0.725 26.2617 17.1686 0.725 23.4611 17.4215 0.725 20.8161 17.4581 0.725 18.4327 17.3932 0.725 16.3802 17.3539 0.725 14.6876 17.4672 0.725 13.3423 17.8466 0.725 12.2940 18.5806 0.725 11.4617 19.7226 0.725 10.7437 21.2845 0.725 10.0294 23.2336 0.725 9.2118 25.4941 0.725 8.1990 27.9527 0.725 6.9247 30.4677 0.725 5.3551 32.8807 0.725 3.4924 35.0301 0.725 1.3750 36.7656 0.725 -0.9268 37.9606 0.725 -3.3180 38.5238 0.725 -5.6892 38.4069 0.725 -7.9282 37.6084 0.725 -9.9317 36.1735 0.725 -11.6172 34.1897 0.725 -12.9318 31.7785 0.725 -13.8584 29.0844 0.725 -14.4186 26.2617 0.725 -14.6715 23.4611 0.725 -14.7081 20.8161 0.725 -14.6432 18.4327 0.725 -14.6039 16.3802 0.725 -14.7172 14.6876 0.725 -15.0966 13.3423 0.725 -15.8306 12.2940 0.725 -16.9726 11.4617 0.725 -18.5345 10.7437 0.725 -20.4836 10.0294 0.725 -22.7441 9.2118 0.725 -25.2027 8.1990 0.725 -27.7177 6.9247 0.725 -30.1307 5.3551 0.725 -32.2801 3.4924 0.725 -34.0156 1.3750 0.725 -35.2106 -0.9268 0.725 -35.7738 -3.3180 0.725 -35.6569 -5.6892 0.725 -34.8584 -7.9282 0.725 -33.4235 -9.9317 0.725 -31.4397 -11.6172 0.725 -29.0285 -12.9318 0.725 -26.3344 -13.8584 0.725 -23.5117 -14.4186 0.725 -20.7111 -14.6715 0.725 -18.0661 -14.7081 0.725 -15.6827 -14.6432 0.725 -13.6302 -14.6039 0.725 -11.9376 -14.7172 0.725 -10.5923 -15.0966 0.725 -9.5440 -15.8306 0.725 -8.7117 -16.9726 0.725 -7.9937 -18.5345 0.725 -7.2794 -20.4836 0.725 -6.4618 -22.7441 0.725 -5.4490 -25.2027 0.725 -4.1747 -27.7177 0.725 -2.6051 -30.1307 0.725 -0.7424 -32.2801 0.725 1.3750 -34.0156 0.725 3.6768 -35.2106 0.725 6.0680 -35.7738 0.725 8.4392 -35.6569 0.725 10.6782 -34.8584 0.725 12.6817 -33.4235 0.725 14.3672 -31.4397 0.725 15.6818 -29.0285 0.725 16.6084 -26.3344 0.725 17.1686 -23.5117 0.725 17.4215 -20.7111 0.725 17.4581 -18.0661 0.725 17.3932 -15.6827 0.725 17.3539 -13.6302 0.725 17.4672 -11.9376 0.725 17.8466 -10.5923 0.725 18.5806 -9.5440 0.725 19.7226 -8.7117 0.725 21.2845 -7.9937 0.725 23.2336 -7.2794 0.725 25.4941 -6.4618 0.725 27.9527 -5.4490 0.725 30.4677 -4.1747 0.725 32.8807 -2.6051 0.725 35.0301 -0.7424 0.725 = = = 36.0799 1.5000 0.700 37.1014 3.7398 0.700 37.4954 6.0473 0.700 37.2267 8.3152 0.700 36.3054 10.4365 0.700 34.7863 12.3154 0.700 32.7632 13.8780 0.700 30.3604 15.0807 0.700 27.7217 15.9155 0.700 24.9968 16.4115 0.700 22.3288 16.6330 0.700 19.8415 16.6734 0.700 17.6294 16.6465 0.700 15.7506 16.6753 0.700 14.2230 16.8794 0.700 13.0250 17.3629 0.700 12.1000 18.2029 0.700 11.3633 19.4413 0.700 10.7130 21.0787 0.700 10.0412 23.0726 0.700 9.2462 25.3405 0.700 8.2437 27.7651 0.700 6.9757 30.2046 0.700 5.4167 32.5041 0.700 3.5768 34.5094 0.700 1.5000 36.0799 0.700 -0.7398 37.1014 0.700 -3.0473 37.4954 0.700 -5.3152 37.2267 0.700 -7.4365 36.3054 0.700 -9.3154 34.7863 0.700 -10.8780 32.7632 0.700 -12.0807 30.3604 0.700 -12.9155 27.7217 0.700 -13.4115 24.9968 0.700 -13.6330 22.3288 0.700 -13.6734 19.8415 0.700 -13.6465 17.6294 0.700 -13.6753 15.7506 0.700 -13.8794 14.2230 0.700 -14.3629 13.0250 0.700 -15.2029 12.1000 0.700 -16.4413 11.3633 0.700 -18.0787 10.7130 0.700 -20.0726 10.0412 0.700 -22.3405 9.2462 0.700 -24.7651 8.2437 0.700 -27.2046 6.9757 0.700 -29.5041 5.4167 0.700 -31.5094 3.5768 0.700 -33.0799 1.5000 0.700 -34.1014 -0.7398 0.700 -34.4954 -3.0473 0.700 -34.2267 -5.3152 0.700 -33.3054 -7.4365 0.700 -31.7863 -9.3154 0.700 -29.7632 -10.8780 0.700 -27.3604 -12.0807 0.700 -24.7217 -12.9155 0.700 -21.9968 -13.4115 0.700 -19.3288 -13.6330 0.700 -16.8415 -13.6734 0.700 -14.6294 -13.6465 0.700 -12.7506 -13.6753 0.700 -11.2230 -13.8794 0.700 -10.0250 -14.3629 0.700 -9.1000 -15.2029 0.700 -8.3633 -16.4413 0.700 -7.7130 -18.0787 0.700 -7.0412 -20.0726 0.700 -6.2462 -22.3405 0.700 -5.2437 -24.7651 0.700 -3.9757 -27.2046 0.700 -2.4167 -29.5041 0.700 -0.5768 -31.5094 0.700 1.5000 -33.0799 0.700 3.7398 -34.1014 0.700 6.0473 -34.4954 0.700 8.3152 -34.2267 0.700 10.4365 -33.3054 0.700 12.3154 -31.7863 0.700 13.8780 -29.7632 0.700 15.0807 -27.3604 0.700 15.9155 -24.7217 0.700 16.4115 -21.9968 0.700 16.6330 -19.3288 0.700 16.6734 -16.8415 0.700 16.6465 -14.6294 0.700 16.6753 -12.7506 0.700 16.8794 -11.2230 0.700 17.3629 -10.0250 0.700 18.2029 -9.1000 0.700 19.4413 -8.3633 0.700 21.0787 -7.7130 0.700 23.0726 -7.0412 0.700 25.3405 -6.2462 0.700 27.7651 -5.2437 0.700 30.2046 -3.9757 0.700 32.5041 -2.4167 0.700 34.5094 -0.5768 0.700 = = = 35.3294 1.6250 0.675 36.1808 3.7991 0.675 36.4134 6.0198 0.675 36.0039 8.1831 0.675 34.9736 10.1875 0.675 33.3853 11.9445 0.675 31.3383 13.3893 0.675 28.9586 14.4872 0.675 26.3879 15.2385 0.675 23.7707 15.6791 0.675 21.2419 15.8775 0.675 18.9151 15.9286 0.675 16.8737 15.9445 0.675 15.1645 16.0431 0.675 13.7954 16.3365 0.675 12.7367 16.9189 0.675 11.9258 17.8565 0.675 11.2758 19.1797 0.675 10.6851 20.8786 0.675 10.0493 22.9025 0.675 9.2728 25.1625 0.675 8.2786 27.5390 0.675 7.0170 29.8910 0.675 5.4709 32.0683 0.675 3.6571 33.9245 0.675 1.6250 35.3294 0.675 -0.5491 36.1808 0.675 -2.7698 36.4134 0.675 -4.9331 36.0039 0.675 -6.9375 34.9736 0.675 -8.6945 33.3853 0.675 -10.1393 31.3383 0.675 -11.2372 28.9586 0.675 -11.9885 26.3879 0.675 -12.4291 23.7707 0.675 -12.6275 21.2419 0.675 -12.6786 18.9151 0.675 -12.6945 16.8737 0.675 -12.7931 15.1645 0.675 -13.0865 13.7954 0.675 -13.6689 12.7367 0.675 -14.6065 11.9258 0.675 -15.9297 11.2758 0.675 -17.6286 10.6851 0.675 -19.6525 10.0493 0.675 -21.9125 9.2728 0.675 -24.2890 8.2786 0.675 -26.6410 7.0170 0.675 -28.8183 5.4709 0.675 -30.6745 3.6571 0.675 -32.0794 1.6250 0.675 -32.9308 -0.5491 0.675 -33.1634 -2.7698 0.675 -32.7539 -4.9331 0.675 -31.7236 -6.9375 0.675 -30.1353 -8.6945 0.675 -28.0883 -10.1393 0.675 -25.7086 -11.2372 0.675 -23.1379 -11.9885 0.675 -20.5207 -12.4291 0.675 -17.9919 -12.6275 0.675 -15.6651 -12.6786 0.675 -13.6237 -12.6945 0.675 -11.9145 -12.7931 0.675 -10.5454 -13.0865 0.675 -9.4867 -13.6689 0.675 -8.6758 -14.6065 0.675 -8.0258 -15.9297 0.675 -7.4351 -17.6286 0.675 -6.7993 -19.6525 0.675 -6.0228 -21.9125 0.675 -5.0286 -24.2890 0.675 -3.7670 -26.6410 0.675 -2.2209 -28.8183 0.675 -0.4071 -30.6745 0.675 1.6250 -32.0794 0.675 3.7991 -32.9308 0.675 6.0198 -33.1634 0.675 8.1831 -32.7539 0.675 10.1875 -31.7236 0.675 11.9445 -30.1353 0.675 13.3893 -28.0883 0.675 14.4872 -25.7086 0.675 15.2385 -23.1379 0.675 15.6791 -20.5207 0.675 15.8775 -17.9919 0.675 15.9286 -15.6651 0.675 15.9445 -13.6237 0.675 16.0431 -11.9145 0.675 16.3365 -10.5454 0.675 16.9189 -9.4867 0.675 17.8565 -8.6758 0.675 19.1797 -8.0258 0.675 20.8786 -7.4351 0.675 22.9025 -6.7993 0.675 25.1625 -6.0228 0.675 27.5390 -5.0286 0.675 29.8910 -3.7670 0.675 32.0683 -2.2209 0.675 33.9245 -0.4071 0.675 = = = 34.5159 1.7500 0.650 35.2024 3.8546 0.650 35.2822 5.9861 0.650 34.7439 8.0439 0.650 33.6185 9.9325 0.650 31.9764 11.5711 0.650 29.9206 12.9035 0.650 27.5778 13.9037 0.650 25.0868 14.5795 0.650 22.5860 14.9729 0.650 20.2017 15.1559 0.650 18.0371 15.2238 0.650 16.1645 15.2861 0.650 14.6202 15.4554 0.650 13.4024 15.8354 0.650 12.4742 16.5106 0.650 11.7683 17.5363 0.650 11.1960 18.9322 0.650 10.6573 20.6789 0.650 10.0517 22.7178 0.650 9.2899 24.9555 0.650 8.3026 27.2707 0.650 7.0483 29.5245 0.650 5.5174 31.5723 0.650 3.7334 33.2758 0.650 1.7500 34.5159 0.650 -0.3546 35.2024 0.650 -2.4861 35.2822 0.650 -4.5439 34.7439 0.650 -6.4325 33.6185 0.650 -8.0711 31.9764 0.650 -9.4035 29.9206 0.650 -10.4037 27.5778 0.650 -11.0795 25.0868 0.650 -11.4729 22.5860 0.650 -11.6559 20.2017 0.650 -11.7238 18.0371 0.650 -11.7861 16.1645 0.650 -11.9554 14.6202 0.650 -12.3354 13.4024 0.650 -13.0106 12.4742 0.650 -14.0363 11.7683 0.650 -15.4322 11.1960 0.650 -17.1789 10.6573 0.650 -19.2178 10.0517 0.650 -21.4555 9.2899 0.650 -23.7707 8.3026 0.650 -26.0245 7.0483 0.650 -28.0723 5.5174 0.650 -29.7758 3.7334 0.650 -31.0159 1.7500 0.650 -31.7024 -0.3546 0.650 -31.7822 -2.4861 0.650 -31.2439 -4.5439 0.650 -30.1185 -6.4325 0.650 -28.4764 -8.0711 0.650 -26.4206 -9.4035 0.650 -24.0778 -10.4037 0.650 -21.5868 -11.0795 0.650 -19.0860 -11.4729 0.650 -16.7017 -11.6559 0.650 -14.5371 -11.7238 0.650 -12.6645 -11.7861 0.650 -11.1202 -11.9554 0.650 -9.9024 -12.3354 0.650 -8.9742 -13.0106 0.650 -8.2683 -14.0363 0.650 -7.6960 -15.4322 0.650 -7.1573 -17.1789 0.650 -6.5517 -19.2178 0.650 -5.7899 -21.4555 0.650 -4.8026 -23.7707 0.650 -3.5483 -26.0245 0.650 -2.0174 -28.0723 0.650 -0.2334 -29.7758 0.650 1.7500 -31.0159 0.650 3.8546 -31.7024 0.650 5.9861 -31.7822 0.650 8.0439 -31.2439 0.650 9.9325 -30.1185 0.650 11.5711 -28.4764 0.650 12.9035 -26.4206 0.650 13.9037 -24.0778 0.650 14.5795 -21.5868 0.650 14.9729 -19.0860 0.650 15.1559 -16.7017 0.650 15.2238 -14.5371 0.650 15.2861 -12.6645 0.650 15.4554 -11.1202 0.650 15.8354 -9.9024 0.650 16.5106 -8.9742 0.650 17.5363 -8.2683 0.650 18.9322 -7.6960 0.650 20.6789 -7.1573 0.650 22.7178 -6.5517 0.650 24.9555 -5.7899 0.650 27.2707 -4.8026 0.650 29.5245 -3.5483 0.650 31.5723 -2.0174 0.650 33.2758 -0.2334 0.650 = = = 33.6420 1.8750 0.625 34.1698 3.9068 0.625 34.1067 5.9468 0.625 33.4522 7.8987 0.625 32.2462 9.6730 0.625 30.5652 11.1970 0.625 28.5153 12.4226 0.625 26.2226 13.3321 0.625 23.8219 13.9404 0.625 21.4450 14.2945 0.625 19.2091 14.4690 0.625 17.2072 14.5589 0.625 15.5006 14.6703 0.625 14.1154 14.9097 0.625 13.0412 15.3727 0.625 12.2345 16.1336 0.625 11.6243 17.2374 0.625 11.1212 18.6937 0.625 10.6271 20.4741 0.625 10.0464 22.5137 0.625 9.2962 24.7152 0.625 8.3150 26.9570 0.625 7.0691 29.1032 0.625 5.5563 31.0155 0.625 3.8058 32.5645 0.625 1.8750 33.6420 0.625 -0.1568 34.1698 0.625 -2.1968 34.1067 0.625 -4.1487 33.4522 0.625 -5.9230 32.2462 0.625 -7.4470 30.5652 0.625 -8.6726 28.5153 0.625 -9.5821 26.2226 0.625 -10.1904 23.8219 0.625 -10.5445 21.4450 0.625 -10.7190 19.2091 0.625 -10.8089 17.2072 0.625 -10.9203 15.5006 0.625 -11.1597 14.1154 0.625 -11.6227 13.0412 0.625 -12.3836 12.2345 0.625 -13.4874 11.6243 0.625 -14.9437 11.1212 0.625 -16.7241 10.6271 0.625 -18.7637 10.0464 0.625 -20.9652 9.2962 0.625 -23.2070 8.3150 0.625 -25.3532 7.0691 0.625 -27.2655 5.5563 0.625 -28.8145 3.8058 0.625 -29.8920 1.8750 0.625 -30.4198 -0.1568 0.625 -30.3567 -2.1968 0.625 -29.7022 -4.1487 0.625 -28.4962 -5.9230 0.625 -26.8152 -7.4470 0.625 -24.7653 -8.6726 0.625 -22.4726 -9.5821 0.625 -20.0719 -10.1904 0.625 -17.6950 -10.5445 0.625 -15.4591 -10.7190 0.625 -13.4572 -10.8089 0.625 -11.7506 -10.9203 0.625 -10.3654 -11.1597 0.625 -9.2912 -11.6227 0.625 -8.4845 -12.3836 0.625 -7.8743 -13.4874 0.625 -7.3712 -14.9437 0.625 -6.8771 -16.7241 0.625 -6.2964 -18.7637 0.625 -5.5462 -20.9652 0.625 -4.5650 -23.2070 0.625 -3.3191 -25.3532 0.625 -1.8063 -27.2655 0.625 -0.0558 -28.8145 0.625 1.8750 -29.8920 0.625 3.9068 -30.4198 0.625 5.9468 -30.3567 0.625 7.8987 -29.7022 0.625 9.6730 -28.4962 0.625 11.1970 -26.8152 0.625 12.4226 -24.7653 0.625 13.3321 -22.4726 0.625 13.9404 -20.0719 0.625 14.2945 -17.6950 0.625 14.4690 -15.4591 0.625 14.5589 -13.4572 0.625 14.6703 -11.7506 0.625 14.9097 -10.3654 0.625 15.3727 -9.2912 0.625 16.1336 -8.4845 0.625 17.2374 -7.8743 0.625 18.6937 -7.3712 0.625 20.4741 -6.8771 0.625 22.5137 -6.2964 0.625 24.7152 -5.5462 0.625 26.9570 -4.5650 0.625 29.1032 -3.3191 0.625 31.0155 -1.8063 0.625 32.5645 -0.0558 0.625 = = = 32.7107 2.0000 0.600 33.0872 3.9558 0.600 32.8920 5.9026 0.600 32.1345 7.7485 0.600 30.8624 9.4106 0.600 29.1574 10.8240 0.600 27.1274 11.9486 0.600 24.8969 12.7745 0.600 22.5962 13.3229 0.600 20.3495 13.6450 0.600 18.2649 13.8171 0.600 16.4248 13.9332 0.600 14.8803 14.0954 0.600 13.6477 14.4036 0.600 12.7088 14.9447 0.600 12.0143 15.7836 0.600 11.4907 16.9549 0.600 11.0483 18.4588 0.600 10.5921 20.2592 0.600 10.0316 22.2854 0.600 9.2905 24.4377 0.600 8.3150 26.5952 0.600 7.0791 28.6258 0.600 5.5875 30.3980 0.600 3.8744 31.7921 0.600 2.0000 32.7107 0.600 0.0442 33.0872 0.600 -1.9026 32.8920 0.600 -3.7485 32.1345 0.600 -5.4106 30.8624 0.600 -6.8240 29.1574 0.600 -7.9486 27.1274 0.600 -8.7745 24.8969 0.600 -9.3229 22.5962 0.600 -9.6450 20.3495 0.600 -9.8171 18.2649 0.600 -9.9332 16.4248 0.600 -10.0954 14.8803 0.600 -10.4036 13.6477 0.600 -10.9447 12.7088 0.600 -11.7836 12.0143 0.600 -12.9549 11.4907 0.600 -14.4588 11.0483 0.600 -16.2592 10.5921 0.600 -18.2854 10.0316 0.600 -20.4377 9.2905 0.600 -22.5952 8.3150 0.600 -24.6258 7.0791 0.600 -26.3980 5.5875 0.600 -27.7921 3.8744 0.600 -28.7107 2.0000 0.600 -29.0872 0.0442 0.600 -28.8920 -1.9026 0.600 -28.1345 -3.7485 0.600 -26.8624 -5.4106 0.600 -25.1574 -6.8240 0.600 -23.1274 -7.9486 0.600 -20.8969 -8.7745 0.600 -18.5962 -9.3229 0.600 -16.3495 -9.6450 0.600 -14.2649 -9.8171 0.600 -12.4248 -9.9332 0.600 -10.8803 -10.0954 0.600 -9.6477 -10.4036 0.600 -8.7088 -10.9447 0.600 -8.0143 -11.7836 0.600 -7.4907 -12.9549 0.600 -7.0483 -14.4588 0.600 -6.5921 -16.2592 0.600 -6.0316 -18.2854 0.600 -5.2905 -20.4377 0.600 -4.3150 -22.5952 0.600 -3.0791 -24.6258 0.600 -1.5875 -26.3980 0.600 0.1256 -27.7921 0.600 2.0000 -28.7107 0.600 3.9558 -29.0872 0.600 5.9026 -28.8920 0.600 7.7485 -28.1345 0.600 9.4106 -26.8624 0.600 10.8240 -25.1574 0.600 11.9486 -23.1274 0.600 12.7745 -20.8969 0.600 13.3229 -18.5962 0.600 13.6450 -16.3495 0.600 13.8171 -14.2649 0.600 13.9332 -12.4248 0.600 14.0954 -10.8803 0.600 14.4036 -9.6477 0.600 14.9447 -8.7088 0.600 15.7836 -8.0143 0.600 16.9549 -7.4907 0.600 18.4588 -7.0483 0.600 20.2592 -6.5921 0.600 22.2854 -6.0316 0.600 24.4377 -5.2905 0.600 26.5952 -4.3150 0.600 28.6258 -3.0791 0.600 30.3980 -1.5875 0.600 31.7921 0.1256 0.600 = = = 31.7253 2.1250 0.575 31.9592 4.0020 0.575 31.6433 5.8540 0.575 30.7963 7.5943 0.575 29.4728 9.1467 0.575 27.7584 10.4538 0.575 25.7616 11.4834 0.575 23.6046 12.2326 0.575 21.4122 12.7282 0.575 19.3008 13.0251 0.575 17.3689 13.2003 0.575 15.6888 13.3460 0.575 14.3015 13.5595 0.575 13.2144 13.9340 0.575 12.4020 14.5478 0.575 11.8105 15.4560 0.575 11.3643 16.6838 0.575 10.9747 18.2226 0.575 10.5501 20.0293 0.575 10.0055 22.0288 0.575 9.2715 24.1198 0.575 8.3021 26.1830 0.575 7.0783 28.0913 0.575 5.6111 29.7206 0.575 3.9392 30.9608 0.575 2.1250 31.7253 0.575 0.2480 31.9592 0.575 -1.6040 31.6433 0.575 -3.3443 30.7963 0.575 -4.8967 29.4728 0.575 -6.2038 27.7584 0.575 -7.2334 25.7616 0.575 -7.9826 23.6046 0.575 -8.4782 21.4122 0.575 -8.7751 19.3008 0.575 -8.9503 17.3689 0.575 -9.0960 15.6888 0.575 -9.3095 14.3015 0.575 -9.6840 13.2144 0.575 -10.2978 12.4020 0.575 -11.2060 11.8105 0.575 -12.4338 11.3643 0.575 -13.9726 10.9747 0.575 -15.7793 10.5501 0.575 -17.7788 10.0055 0.575 -19.8698 9.2715 0.575 -21.9330 8.3021 0.575 -23.8413 7.0783 0.575 -25.4706 5.6111 0.575 -26.7108 3.9392 0.575 -27.4753 2.1250 0.575 -27.7092 0.2480 0.575 -27.3933 -1.6040 0.575 -26.5463 -3.3443 0.575 -25.2228 -4.8967 0.575 -23.5084 -6.2038 0.575 -21.5116 -7.2334 0.575 -19.3546 -7.9826 0.575 -17.1622 -8.4782 0.575 -15.0508 -8.7751 0.575 -13.1189 -8.9503 0.575 -11.4388 -9.0960 0.575 -10.0515 -9.3095 0.575 -8.9644 -9.6840 0.575 -8.1520 -10.2978 0.575 -7.5605 -11.2060 0.575 -7.1143 -12.4338 0.575 -6.7247 -13.9726 0.575 -6.3001 -15.7793 0.575 -5.7555 -17.7788 0.575 -5.0215 -19.8698 0.575 -4.0521 -21.9330 0.575 -2.8283 -23.8413 0.575 -1.3611 -25.4706 0.575 0.3108 -26.7108 0.575 2.1250 -27.4753 0.575 4.0020 -27.7092 0.575 5.8540 -27.3933 0.575 7.5943 -26.5463 0.575 9.1467 -25.2228 0.575 10.4538 -23.5084 0.575 11.4834 -21.5116 0.575 12.2326 -19.3546 0.575 12.7282 -17.1622 0.575 13.0251 -15.0508 0.575 13.2003 -13.1189 0.575 13.3460 -11.4388 0.575 13.5595 -10.0515 0.575 13.9340 -8.9644 0.575 14.5478 -8.1520 0.575 15.4560 -7.5605 0.575 16.6838 -7.1143 0.575 18.2226 -6.7247 0.575 20.0293 -6.3001 0.575 22.0288 -5.7555 0.575 24.1198 -5.0215 0.575 26.1830 -4.0521 0.575 28.0913 -2.8283 0.575 29.7206 -1.3611 0.575 30.9608 0.3108 0.575 = = = 30.6898 2.2500 0.550 30.7905 4.0456 0.550 30.3661 5.8019 0.550 29.4435 7.4374 0.550 28.0831 8.8828 0.550 26.3733 10.0881 0.550 24.4223 11.0286 0.550 22.3491 11.7079 0.550 20.2721 12.1577 0.550 18.2997 12.4355 0.550 16.5208 12.6184 0.550 14.9978 12.7959 0.550 13.7620 13.0605 0.550 12.8125 13.4979 0.550 12.1175 14.1778 0.550 11.6196 15.1461 0.550 11.2419 16.4190 0.550 10.8976 17.9799 0.550 10.4988 19.7796 0.550 9.9665 21.7398 0.550 9.2385 23.7584 0.550 8.2758 25.7189 0.550 7.0666 27.4996 0.550 5.6273 28.9844 0.550 4.0005 30.0730 0.550 2.2500 30.6898 0.550 0.4544 30.7905 0.550 -1.3019 30.3661 0.550 -2.9374 29.4435 0.550 -4.3828 28.0831 0.550 -5.5881 26.3733 0.550 -6.5286 24.4223 0.550 -7.2079 22.3491 0.550 -7.6577 20.2721 0.550 -7.9355 18.2997 0.550 -8.1184 16.5208 0.550 -8.2959 14.9978 0.550 -8.5605 13.7620 0.550 -8.9979 12.8125 0.550 -9.6778 12.1175 0.550 -10.6461 11.6196 0.550 -11.9190 11.2419 0.550 -13.4799 10.8976 0.550 -15.2796 10.4988 0.550 -17.2398 9.9665 0.550 -19.2584 9.2385 0.550 -21.2189 8.2758 0.550 -22.9996 7.0666 0.550 -24.4844 5.6273 0.550 -25.5730 4.0005 0.550 -26.1898 2.2500 0.550 -26.2905 0.4544 0.550 -25.8661 -1.3019 0.550 -24.9435 -2.9374 0.550 -23.5831 -4.3828 0.550 -21.8733 -5.5881 0.550 -19.9223 -6.5286 0.550 -17.8491 -7.2079 0.550 -15.7721 -7.6577 0.550 -13.7997 -7.9355 0.550 -12.0208 -8.1184 0.550 -10.4978 -8.2959 0.550 -9.2620 -8.5605 0.550 -8.3125 -8.9979 0.550 -7.6175 -9.6778 0.550 -7.1196 -10.6461 0.550 -6.7419 -11.9190 0.550 -6.3976 -13.4799 0.550 -5.9988 -15.2796 0.550 -5.4665 -17.2398 0.550 -4.7385 -19.2584 0.550 -3.7758 -21.2189 0.550 -2.5666 -22.9996 0.550 -1.1273 -24.4844 0.550 0.4995 -25.5730 0.550 2.2500 -26.1898 0.550 4.0456 -26.2905 0.550 5.8019 -25.8661 0.550 7.4374 -24.9435 0.550 8.8828 -23.5831 0.550 10.0881 -21.8733 0.550 11.0286 -19.9223 0.550 11.7079 -17.8491 0.550 12.1577 -15.7721 0.550 12.4355 -13.7997 0.550 12.6184 -12.0208 0.550 12.7959 -10.4978 0.550 13.0605 -9.2620 0.550 13.4979 -8.3125 0.550 14.1778 -7.6175 0.550 15.1461 -7.1196 0.550 16.4190 -6.7419 0.550 17.9799 -6.3976 0.550 19.7796 -5.9988 0.550 21.7398 -5.4665 0.550 23.7584 -4.7385 0.550 25.7189 -3.7758 0.550 27.4996 -2.5666 0.550 28.9844 -1.1273 0.550 30.0730 0.4995 0.550 = = = 29.6082 2.3750 0.525 29.5862 4.0870 0.525 29.0660 5.7469 0.525 28.0818 7.2788 0.525 26.6987 8.6203 0.525 25.0069 9.7286 0.525 23.1135 10.5860 0.525 21.1330 11.2019 0.525 19.1775 11.6122 0.525 17.3467 11.8763 0.525 15.7199 12.0707 0.525 14.3499 12.2815 0.525 13.2590 12.5958 0.525 12.4387 13.0918 0.525 11.8520 13.8307 0.525 11.4382 14.8495 0.525 11.1206 16.1558 0.525 10.8143 17.7260 0.525 10.4363 19.5061 0.525 9.9134 21.4149 0.525 9.1906 23.3512 0.525 8.2359 25.2017 0.525 7.0440 26.8509 0.525 5.6363 28.1910 0.525 4.0584 29.1318 0.525 2.3750 29.6082 0.525 0.6630 29.5862 0.525 -0.9969 29.0660 0.525 -2.5288 28.0818 0.525 -3.8703 26.6987 0.525 -4.9786 25.0069 0.525 -5.8360 23.1135 0.525 -6.4519 21.1330 0.525 -6.8622 19.1775 0.525 -7.1263 17.3467 0.525 -7.3207 15.7199 0.525 -7.5315 14.3499 0.525 -7.8458 13.2590 0.525 -8.3418 12.4387 0.525 -9.0807 11.8520 0.525 -10.0995 11.4382 0.525 -11.4058 11.1206 0.525 -12.9760 10.8143 0.525 -14.7561 10.4363 0.525 -16.6649 9.9134 0.525 -18.6012 9.1906 0.525 -20.4517 8.2359 0.525 -22.1009 7.0440 0.525 -23.4410 5.6363 0.525 -24.3818 4.0584 0.525 -24.8582 2.3750 0.525 -24.8362 0.6630 0.525 -24.3160 -0.9969 0.525 -23.3318 -2.5288 0.525 -21.9487 -3.8703 0.525 -20.2569 -4.9786 0.525 -18.3635 -5.8360 0.525 -16.3830 -6.4519 0.525 -14.4275 -6.8622 0.525 -12.5967 -7.1263 0.525 -10.9699 -7.3207 0.525 -9.5999 -7.5315 0.525 -8.5090 -7.8458 0.525 -7.6887 -8.3418 0.525 -7.1020 -9.0807 0.525 -6.6882 -10.0995 0.525 -6.3706 -11.4058 0.525 -6.0643 -12.9760 0.525 -5.6863 -14.7561 0.525 -5.1634 -16.6649 0.525 -4.4406 -18.6012 0.525 -3.4859 -20.4517 0.525 -2.2940 -22.1009 0.525 -0.8863 -23.4410 0.525 0.6916 -24.3818 0.525 2.3750 -24.8582 0.525 4.0870 -24.8362 0.525 5.7469 -24.3160 0.525 7.2788 -23.3318 0.525 8.6203 -21.9487 0.525 9.7286 -20.2569 0.525 10.5860 -18.3635 0.525 11.2019 -16.3830 0.525 11.6122 -14.4275 0.525 11.8763 -12.5967 0.525 12.0707 -10.9699 0.525 12.2815 -9.5999 0.525 12.5958 -8.5090 0.525 13.0918 -7.6887 0.525 13.8307 -7.1020 0.525 14.8495 -6.6882 0.525 16.1558 -6.3706 0.525 17.7260 -6.0643 0.525 19.5061 -5.6863 0.525 21.4149 -5.1634 0.525 23.3512 -4.4406 0.525 25.2017 -3.4859 0.525 26.8509 -2.2940 0.525 28.1910 -0.8863 0.525 29.1318 0.6916 0.525 = = = 28.4850 2.5000 0.500 28.3514 4.1264 0.500 27.7485 5.6896 0.500 26.7167 7.1196 0.500 25.3249 8.3604 0.500 23.6640 9.3766 0.500 21.8388 10.1568 0.500 19.9590 10.7156 0.500 18.1296 11.0924 0.500 16.4416 11.3476 0.500 14.9650 11.5563 0.500 13.7430 11.8010 0.500 12.7897 12.1627 0.500 12.0898 12.7121 0.500 11.6018 13.5022 0.500 11.2630 14.5613 0.500 10.9971 15.8894 0.500 10.7224 17.4565 0.500 10.3606 19.2046 0.500 9.8449 21.0511 0.500 9.1271 22.8962 0.500 8.1822 24.6307 0.500 7.0107 26.1459 0.500 5.6384 27.3428 0.500 4.1132 28.1407 0.500 2.5000 28.4850 0.500 0.8736 28.3514 0.500 -0.6896 27.7485 0.500 -2.1196 26.7167 0.500 -3.3604 25.3249 0.500 -4.3766 23.6640 0.500 -5.1568 21.8388 0.500 -5.7156 19.9590 0.500 -6.0924 18.1296 0.500 -6.3476 16.4416 0.500 -6.5563 14.9650 0.500 -6.8010 13.7430 0.500 -7.1627 12.7897 0.500 -7.7121 12.0898 0.500 -8.5022 11.6018 0.500 -9.5613 11.2630 0.500 -10.8894 10.9971 0.500 -12.4565 10.7224 0.500 -14.2046 10.3606 0.500 -16.0511 9.8449 0.500 -17.8962 9.1271 0.500 -19.6307 8.1822 0.500 -21.1459 7.0107 0.500 -22.3428 5.6384 0.500 -23.1407 4.1132 0.500 -23.4850 2.5000 0.500 -23.3514 0.8736 0.500 -22.7485 -0.6896 0.500 -21.7167 -2.1196 0.500 -20.3249 -3.3604 0.500 -18.6640 -4.3766 0.500 -16.8388 -5.1568 0.500 -14.9590 -5.7156 0.500 -13.1296 -6.0924 0.500 -11.4416 -6.3476 0.500 -9.9650 -6.5563 0.500 -8.7430 -6.8010 0.500 -7.7897 -7.1627 0.500 -7.0898 -7.7121 0.500 -6.6018 -8.5022 0.500 -6.2630 -9.5613 0.500 -5.9971 -10.8894 0.500 -5.7224 -12.4565 0.500 -5.3606 -14.2046 0.500 -4.8449 -16.0511 0.500 -4.1271 -17.8962 0.500 -3.1822 -19.6307 0.500 -2.0107 -21.1459 0.500 -0.6384 -22.3428 0.500 0.8868 -23.1407 0.500 2.5000 -23.4850 0.500 4.1264 -23.3514 0.500 5.6896 -22.7485 0.500 7.1196 -21.7167 0.500 8.3604 -20.3249 0.500 9.3766 -18.6640 0.500 10.1568 -16.8388 0.500 10.7156 -14.9590 0.500 11.0924 -13.1296 0.500 11.3476 -11.4416 0.500 11.5563 -9.9650 0.500 11.8010 -8.7430 0.500 12.1627 -7.7897 0.500 12.7121 -7.0898 0.500 13.5022 -6.6018 0.500 14.5613 -6.2630 0.500 15.8894 -5.9971 0.500 17.4565 -5.7224 0.500 19.2046 -5.3606 0.500 21.0511 -4.8449 0.500 22.8962 -4.1271 0.500 24.6307 -3.1822 0.500 26.1459 -2.0107 0.500 27.3428 -0.6384 0.500 28.1407 0.8868 0.500 = = = 27.3249 2.6250 0.475 27.0915 4.1643 0.475 26.4192 5.6309 0.475 25.3538 6.9608 0.475 23.9667 8.1046 0.475 22.3486 9.0336 0.475 20.6013 9.7423 0.475 18.8290 10.2500 0.475 17.1291 10.5987 0.475 15.5840 10.8490 0.475 14.2543 11.0742 0.475 13.1745 11.3523 0.475 12.3509 11.7582 0.475 11.7623 12.3553 0.475 11.3635 13.1881 0.475 11.0907 14.2771 0.475 10.8688 15.6151 0.475 10.6196 17.1671 0.475 10.2701 18.8716 0.475 9.7599 20.6458 0.475 9.0477 22.3919 0.475 8.1147 24.0059 0.475 6.9669 25.3861 0.475 5.6338 26.4421 0.475 4.1651 27.1034 0.475 2.6250 27.3249 0.475 1.0857 27.0915 0.475 -0.3809 26.4192 0.475 -1.7108 25.3538 0.475 -2.8546 23.9667 0.475 -3.7836 22.3486 0.475 -4.4923 20.6013 0.475 -5.0000 18.8290 0.475 -5.3487 17.1291 0.475 -5.5990 15.5840 0.475 -5.8242 14.2543 0.475 -6.1023 13.1745 0.475 -6.5082 12.3509 0.475 -7.1053 11.7623 0.475 -7.9381 11.3635 0.475 -9.0271 11.0907 0.475 -10.3651 10.8688 0.475 -11.9171 10.6196 0.475 -13.6216 10.2701 0.475 -15.3958 9.7599 0.475 -17.1419 9.0477 0.475 -18.7559 8.1147 0.475 -20.1361 6.9669 0.475 -21.1921 5.6338 0.475 -21.8534 4.1651 0.475 -22.0749 2.6250 0.475 -21.8415 1.0857 0.475 -21.1692 -0.3809 0.475 -20.1038 -1.7108 0.475 -18.7167 -2.8546 0.475 -17.0986 -3.7836 0.475 -15.3513 -4.4923 0.475 -13.5790 -5.0000 0.475 -11.8791 -5.3487 0.475 -10.3340 -5.5990 0.475 -9.0043 -5.8242 0.475 -7.9245 -6.1023 0.475 -7.1009 -6.5082 0.475 -6.5123 -7.1053 0.475 -6.1135 -7.9381 0.475 -5.8407 -9.0271 0.475 -5.6188 -10.3651 0.475 -5.3696 -11.9171 0.475 -5.0201 -13.6216 0.475 -4.5099 -15.3958 0.475 -3.7977 -17.1419 0.475 -2.8647 -18.7559 0.475 -1.7169 -20.1361 0.475 -0.3838 -21.1921 0.475 1.0849 -21.8534 0.475 2.6250 -22.0749 0.475 4.1643 -21.8415 0.475 5.6309 -21.1692 0.475 6.9608 -20.1038 0.475 8.1046 -18.7167 0.475 9.0336 -17.0986 0.475 9.7423 -15.3513 0.475 10.2500 -13.5790 0.475 10.5987 -11.8791 0.475 10.8490 -10.3340 0.475 11.0742 -9.0043 0.475 11.3523 -7.9245 0.475 11.7582 -7.1009 0.475 12.3553 -6.5123 0.475 13.1881 -6.1135 0.475 14.2771 -5.8407 0.475 15.6151 -5.6188 0.475 17.1671 -5.3696 0.475 18.8716 -5.0201 0.475 20.6458 -4.5099 0.475 22.3919 -3.7977 0.475 24.0059 -2.8647 0.475 25.3861 -1.7169 0.475 26.4421 -0.3838 0.475 27.1034 1.0849 0.475 = = = 26.1331 2.7500 0.450 25.8121 4.2009 0.450 25.0839 5.5714 0.450 23.9985 6.8034 0.450 22.6289 7.8540 0.450 21.0646 8.7008 0.450 19.4038 9.3437 0.450 17.7445 9.8059 0.450 16.1763 10.1311 0.450 14.7728 10.3799 0.450 13.5859 10.6227 0.450 12.6416 10.9330 0.450 11.9393 11.3793 0.450 11.4526 12.0173 0.450 11.1335 12.8840 0.450 10.9179 13.9922 0.450 10.7327 15.3287 0.450 10.5036 16.8538 0.450 10.1632 18.5039 0.450 9.6576 20.1967 0.450 8.9519 21.8375 0.450 8.0335 23.3277 0.450 6.9130 24.5730 0.450 5.6230 25.4923 0.450 4.2143 26.0242 0.450 2.7500 26.1331 0.450 1.2991 25.8121 0.450 -0.0714 25.0839 0.450 -1.3034 23.9985 0.450 -2.3540 22.6289 0.450 -3.2008 21.0646 0.450 -3.8437 19.4038 0.450 -4.3059 17.7445 0.450 -4.6311 16.1763 0.450 -4.8799 14.7728 0.450 -5.1227 13.5859 0.450 -5.4330 12.6416 0.450 -5.8793 11.9393 0.450 -6.5173 11.4526 0.450 -7.3840 11.1335 0.450 -8.4922 10.9179 0.450 -9.8287 10.7327 0.450 -11.3538 10.5036 0.450 -13.0039 10.1632 0.450 -14.6967 9.6576 0.450 -16.3375 8.9519 0.450 -17.8277 8.0335 0.450 -19.0730 6.9130 0.450 -19.9923 5.6230 0.450 -20.5242 4.2143 0.450 -20.6331 2.7500 0.450 -20.3121 1.2991 0.450 -19.5839 -0.0714 0.450 -18.4985 -1.3034 0.450 -17.1289 -2.3540 0.450 -15.5646 -3.2008 0.450 -13.9038 -3.8437 0.450 -12.2445 -4.3059 0.450 -10.6763 -4.6311 0.450 -9.2728 -4.8799 0.450 -8.0859 -5.1227 0.450 -7.1416 -5.4330 0.450 -6.4393 -5.8793 0.450 -5.9526 -6.5173 0.450 -5.6335 -7.3840 0.450 -5.4179 -8.4922 0.450 -5.2327 -9.8287 0.450 -5.0036 -11.3538 0.450 -4.6632 -13.0039 0.450 -4.1576 -14.6967 0.450 -3.4519 -16.3375 0.450 -2.5335 -17.8277 0.450 -1.4130 -19.0730 0.450 -0.1230 -19.9923 0.450 1.2857 -20.5242 0.450 2.7500 -20.6331 0.450 4.2009 -20.3121 0.450 5.5714 -19.5839 0.450 6.8034 -18.4985 0.450 7.8540 -17.1289 0.450 8.7008 -15.5646 0.450 9.3437 -13.9038 0.450 9.8059 -12.2445 0.450 10.1311 -10.6763 0.450 10.3799 -9.2728 0.450 10.6227 -8.0859 0.450 10.9330 -7.1416 0.450 11.3793 -6.4393 0.450 12.0173 -5.9526 0.450 12.8840 -5.6335 0.450 13.9922 -5.4179 0.450 15.3287 -5.2327 0.450 16.8538 -5.0036 0.450 18.5039 -4.6632 0.450 20.1967 -4.1576 0.450 21.8375 -3.4519 0.450 23.3277 -2.5335 0.450 24.5730 -1.4130 0.450 25.4923 -0.1230 0.450 26.0242 1.2857 0.450 = = = 24.9145 2.8750 0.425 24.5186 4.2367 0.425 23.7479 5.5119 0.425 22.6557 6.6484 0.425 21.3158 7.6098 0.425 19.8155 8.3793 0.425 18.2485 8.9618 0.425 16.7064 9.3836 0.425 15.2708 9.6897 0.425 14.0067 9.9394 0.425 12.9574 10.2003 0.425 12.1412 10.5407 0.425 11.5512 11.0225 0.425 11.1569 11.6944 0.425 10.9083 12.5856 0.425 10.7416 13.7024 0.425 10.5862 15.0260 0.425 10.3726 16.5130 0.425 10.0388 18.0988 0.425 9.5374 19.7023 0.425 8.8397 21.2326 0.425 7.9387 22.5970 0.425 6.8493 23.7092 0.425 5.6065 24.4967 0.425 4.2612 24.9074 0.425 2.8750 24.9145 0.425 1.5133 24.5186 0.425 0.2381 23.7479 0.425 -0.8984 22.6557 0.425 -1.8598 21.3158 0.425 -2.6293 19.8155 0.425 -3.2118 18.2485 0.425 -3.6336 16.7064 0.425 -3.9397 15.2708 0.425 -4.1894 14.0067 0.425 -4.4503 12.9574 0.425 -4.7907 12.1412 0.425 -5.2725 11.5512 0.425 -5.9444 11.1569 0.425 -6.8356 10.9083 0.425 -7.9524 10.7416 0.425 -9.2760 10.5862 0.425 -10.7630 10.3726 0.425 -12.3488 10.0388 0.425 -13.9523 9.5374 0.425 -15.4826 8.8397 0.425 -16.8470 7.9387 0.425 -17.9592 6.8493 0.425 -18.7467 5.6065 0.425 -19.1574 4.2612 0.425 -19.1645 2.8750 0.425 -18.7686 1.5133 0.425 -17.9979 0.2381 0.425 -16.9057 -0.8984 0.425 -15.5658 -1.8598 0.425 -14.0655 -2.6293 0.425 -12.4985 -3.2118 0.425 -10.9564 -3.6336 0.425 -9.5208 -3.9397 0.425 -8.2567 -4.1894 0.425 -7.2074 -4.4503 0.425 -6.3912 -4.7907 0.425 -5.8012 -5.2725 0.425 -5.4069 -5.9444 0.425 -5.1583 -6.8356 0.425 -4.9916 -7.9524 0.425 -4.8362 -9.2760 0.425 -4.6226 -10.7630 0.425 -4.2888 -12.3488 0.425 -3.7874 -13.9523 0.425 -3.0897 -15.4826 0.425 -2.1887 -16.8470 0.425 -1.0993 -17.9592 0.425 0.1435 -18.7467 0.425 1.4888 -19.1574 0.425 2.8750 -19.1645 0.425 4.2367 -18.7686 0.425 5.5119 -17.9979 0.425 6.6484 -16.9057 0.425 7.6098 -15.5658 0.425 8.3793 -14.0655 0.425 8.9618 -12.4985 0.425 9.3836 -10.9564 0.425 9.6897 -9.5208 0.425 9.9394 -8.2567 0.425 10.2003 -7.2074 0.425 10.5407 -6.3912 0.425 11.0225 -5.8012 0.425 11.6944 -5.4069 0.425 12.5856 -5.1583 0.425 13.7024 -4.9916 0.425 15.0260 -4.8362 0.425 16.5130 -4.6226 0.425 18.0988 -4.2888 0.425 19.7023 -3.7874 0.425 21.2326 -3.0897 0.425 22.5970 -2.1887 0.425 23.7092 -1.0993 0.425 24.4967 0.1435 0.425 24.9074 1.4888 0.425 = = = 23.6745 3.0000 0.400 23.2164 4.2719 0.400 22.4166 5.4529 0.400 21.3305 6.4967 0.400 20.0315 7.3729 0.400 18.6043 8.0701 0.400 17.1373 8.5974 0.400 15.7154 8.9834 0.400 14.4121 9.2738 0.400 13.2840 9.5264 0.400 12.3662 9.8049 0.400 11.6701 10.1725 0.400 11.1832 10.6845 0.400 10.8717 11.3825 0.400 10.6843 12.2887 0.400 10.5585 13.4034 0.400 10.4269 14.7030 0.400 10.2246 16.1415 0.400 9.8956 17.6540 0.400 9.3987 19.1613 0.400 8.7112 20.5771 0.400 7.8309 21.8152 0.400 6.7765 22.7971 0.400 5.5846 23.4590 0.400 4.3060 23.7578 0.400 3.0000 23.6745 0.400 1.7281 23.2164 0.400 0.5471 22.4166 0.400 -0.4967 21.3305 0.400 -1.3729 20.0315 0.400 -2.0701 18.6043 0.400 -2.5974 17.1373 0.400 -2.9834 15.7154 0.400 -3.2738 14.4121 0.400 -3.5264 13.2840 0.400 -3.8049 12.3662 0.400 -4.1725 11.6701 0.400 -4.6845 11.1832 0.400 -5.3825 10.8717 0.400 -6.2887 10.6843 0.400 -7.4034 10.5585 0.400 -8.7030 10.4269 0.400 -10.1415 10.2246 0.400 -11.6540 9.8956 0.400 -13.1613 9.3987 0.400 -14.5771 8.7112 0.400 -15.8152 7.8309 0.400 -16.7971 6.7765 0.400 -17.4590 5.5846 0.400 -17.7578 4.3060 0.400 -17.6745 3.0000 0.400 -17.2164 1.7281 0.400 -16.4166 0.5471 0.400 -15.3305 -0.4967 0.400 -14.0315 -1.3729 0.400 -12.6043 -2.0701 0.400 -11.1373 -2.5974 0.400 -9.7154 -2.9834 0.400 -8.4121 -3.2738 0.400 -7.2840 -3.5264 0.400 -6.3662 -3.8049 0.400 -5.6701 -4.1725 0.400 -5.1832 -4.6845 0.400 -4.8717 -5.3825 0.400 -4.6843 -6.2887 0.400 -4.5585 -7.4034 0.400 -4.4269 -8.7030 0.400 -4.2246 -10.1415 0.400 -3.8956 -11.6540 0.400 -3.3987 -13.1613 0.400 -2.7112 -14.5771 0.400 -1.8309 -15.8152 0.400 -0.7765 -16.7971 0.400 0.4154 -17.4590 0.400 1.6940 -17.7578 0.400 3.0000 -17.6745 0.400 4.2719 -17.2164 0.400 5.4529 -16.4166 0.400 6.4967 -15.3305 0.400 7.3729 -14.0315 0.400 8.0701 -12.6043 0.400 8.5974 -11.1373 0.400 8.9834 -9.7154 0.400 9.2738 -8.4121 0.400 9.5264 -7.2840 0.400 9.8049 -6.3662 0.400 10.1725 -5.6701 0.400 10.6845 -5.1832 0.400 11.3825 -4.8717 0.400 12.2887 -4.6843 0.400 13.4034 -4.5585 0.400 14.7030 -4.4269 0.400 16.1415 -4.2246 0.400 17.6540 -3.8956 0.400 19.1613 -3.3987 0.400 20.5771 -2.7112 0.400 21.8152 -1.8309 0.400 22.7971 -0.7765 0.400 23.4590 0.4154 0.400 23.7578 1.6940 0.400 = = = 22.4184 3.1250 0.375 21.9111 4.3069 0.375 21.0951 5.3952 0.375 20.0273 6.3493 0.375 18.7797 7.1444 0.375 17.4335 7.7741 0.375 16.0715 8.2509 0.375 14.7715 8.6054 0.375 13.5989 8.8831 0.375 12.6023 9.1395 0.375 11.8092 9.4345 0.375 11.2246 9.8255 0.375 10.8313 10.3617 0.375 10.5930 11.0776 0.375 10.4581 11.9892 0.375 10.3658 13.0912 0.375 10.2525 14.3561 0.375 10.0582 15.7364 0.375 9.7329 17.1675 0.375 9.2413 18.5731 0.375 8.5664 19.8718 0.375 7.7105 20.9843 0.375 6.6951 21.8400 0.375 5.5579 22.3836 0.375 4.3490 22.5802 0.375 3.1250 22.4184 0.375 1.9431 21.9111 0.375 0.8548 21.0951 0.375 -0.0993 20.0273 0.375 -0.8944 18.7797 0.375 -1.5241 17.4335 0.375 -2.0009 16.0715 0.375 -2.3554 14.7715 0.375 -2.6331 13.5989 0.375 -2.8895 12.6023 0.375 -3.1845 11.8092 0.375 -3.5755 11.2246 0.375 -4.1117 10.8313 0.375 -4.8276 10.5930 0.375 -5.7392 10.4581 0.375 -6.8412 10.3658 0.375 -8.1061 10.2525 0.375 -9.4864 10.0582 0.375 -10.9175 9.7329 0.375 -12.3231 9.2413 0.375 -13.6218 8.5664 0.375 -14.7343 7.7105 0.375 -15.5900 6.6951 0.375 -16.1336 5.5579 0.375 -16.3302 4.3490 0.375 -16.1684 3.1250 0.375 -15.6611 1.9431 0.375 -14.8451 0.8548 0.375 -13.7773 -0.0993 0.375 -12.5297 -0.8944 0.375 -11.1835 -1.5241 0.375 -9.8215 -2.0009 0.375 -8.5215 -2.3554 0.375 -7.3489 -2.6331 0.375 -6.3523 -2.8895 0.375 -5.5592 -3.1845 0.375 -4.9746 -3.5755 0.375 -4.5813 -4.1117 0.375 -4.3430 -4.8276 0.375 -4.2081 -5.7392 0.375 -4.1158 -6.8412 0.375 -4.0025 -8.1061 0.375 -3.8082 -9.4864 0.375 -3.4829 -10.9175 0.375 -2.9913 -12.3231 0.375 -2.3164 -13.6218 0.375 -1.4605 -14.7343 0.375 -0.4451 -15.5900 0.375 0.6921 -16.1336 0.375 1.9010 -16.3302 0.375 3.1250 -16.1684 0.375 4.3069 -15.6611 0.375 5.3952 -14.8451 0.375 6.3493 -13.7773 0.375 7.1444 -12.5297 0.375 7.7741 -11.1835 0.375 8.2509 -9.8215 0.375 8.6054 -8.5215 0.375 8.8831 -7.3489 0.375 9.1395 -6.3523 0.375 9.4345 -5.5592 0.375 9.8255 -4.9746 0.375 10.3617 -4.5813 0.375 11.0776 -4.3430 0.375 11.9892 -4.2081 0.375 13.0912 -4.1158 0.375 14.3561 -4.0025 0.375 15.7364 -3.8082 0.375 17.1675 -3.4829 0.375 18.5731 -2.9913 0.375 19.8718 -2.3164 0.375 20.9843 -1.4605 0.375 21.8400 -0.4451 0.375 22.3836 0.6921 0.375 22.5802 1.9010 0.375 = = = 21.1516 3.2500 0.350 20.6081 4.3421 0.350 19.7886 5.3393 0.350 18.7504 6.2069 0.350 17.5636 6.9251 0.350 16.3052 7.4919 0.350 15.0519 7.9227 0.350 13.8742 8.2494 0.350 12.8298 8.5165 0.350 11.9593 8.7771 0.350 11.2833 9.0865 0.350 10.8010 9.4968 0.350 10.4918 10.0505 0.350 10.3173 10.7759 0.350 10.2264 11.6830 0.350 10.1608 12.7619 0.350 10.0609 13.9822 0.350 9.8720 15.2953 0.350 9.5499 16.6379 0.350 9.0651 17.9374 0.350 8.4057 19.1177 0.350 7.5780 20.1066 0.350 6.6057 20.8413 0.350 5.5271 21.2748 0.350 4.3906 21.3799 0.350 3.2500 21.1516 0.350 2.1579 20.6081 0.350 1.1607 19.7886 0.350 0.2931 18.7504 0.350 -0.4251 17.5636 0.350 -0.9919 16.3052 0.350 -1.4227 15.0519 0.350 -1.7494 13.8742 0.350 -2.0165 12.8298 0.350 -2.2771 11.9593 0.350 -2.5865 11.2833 0.350 -2.9968 10.8010 0.350 -3.5505 10.4918 0.350 -4.2759 10.3173 0.350 -5.1830 10.2264 0.350 -6.2619 10.1608 0.350 -7.4822 10.0609 0.350 -8.7953 9.8720 0.350 -10.1379 9.5499 0.350 -11.4374 9.0651 0.350 -12.6177 8.4057 0.350 -13.6066 7.5780 0.350 -14.3413 6.6057 0.350 -14.7748 5.5271 0.350 -14.8799 4.3906 0.350 -14.6516 3.2500 0.350 -14.1081 2.1579 0.350 -13.2886 1.1607 0.350 -12.2504 0.2931 0.350 -11.0636 -0.4251 0.350 -9.8052 -0.9919 0.350 -8.5519 -1.4227 0.350 -7.3742 -1.7494 0.350 -6.3298 -2.0165 0.350 -5.4593 -2.2771 0.350 -4.7833 -2.5865 0.350 -4.3010 -2.9968 0.350 -3.9918 -3.5505 0.350 -3.8173 -4.2759 0.350 -3.7264 -5.1830 0.350 -3.6608 -6.2619 0.350 -3.5609 -7.4822 0.350 -3.3720 -8.7953 0.350 -3.0499 -10.1379 0.350 -2.5651 -11.4374 0.350 -1.9057 -12.6177 0.350 -1.0780 -13.6066 0.350 -0.1057 -14.3413 0.350 0.9729 -14.7748 0.350 2.1094 -14.8799 0.350 3.2500 -14.6516 0.350 4.3421 -14.1081 0.350 5.3393 -13.2886 0.350 6.2069 -12.2504 0.350 6.9251 -11.0636 0.350 7.4919 -9.8052 0.350 7.9227 -8.5519 0.350 8.2494 -7.3742 0.350 8.5165 -6.3298 0.350 8.7771 -5.4593 0.350 9.0865 -4.7833 0.350 9.4968 -4.3010 0.350 10.0505 -3.9918 0.350 10.7759 -3.8173 0.350 11.6830 -3.7264 0.350 12.7619 -3.6608 0.350 13.9822 -3.5609 0.350 15.2953 -3.3720 0.350 16.6379 -3.0499 0.350 17.9374 -2.5651 0.350 19.1177 -1.9057 0.350 20.1066 -1.0780 0.350 20.8413 -0.1057 0.350 21.2748 0.9729 0.350 21.3799 2.1094 0.350 = = = 19.8796 3.3750 0.325 19.3124 4.3777 0.325 18.5015 5.2859 0.325 17.5036 6.0702 0.325 16.3861 6.7157 0.325 15.2210 7.2240 0.325 14.0789 7.6130 0.325 13.0227 7.9149 0.325 12.1026 8.1731 0.325 11.3519 8.4373 0.325 10.7848 8.7585 0.325 10.3956 9.1830 0.325 10.1607 9.7472 0.325 10.0408 10.4733 0.325 9.9860 11.3663 0.325 9.9409 12.4121 0.325 9.8502 13.5783 0.325 9.6648 14.8161 0.325 9.3462 16.0644 0.325 8.8703 17.2545 0.325 8.2298 18.3164 0.325 7.4343 19.1848 0.325 6.5092 19.8048 0.325 5.4926 20.1372 0.325 4.4311 20.1618 0.325 3.3750 19.8796 0.325 2.3723 19.3124 0.325 1.4641 18.5015 0.325 0.6798 17.5036 0.325 0.0343 16.3861 0.325 -0.4740 15.2210 0.325 -0.8630 14.0789 0.325 -1.1649 13.0227 0.325 -1.4231 12.1026 0.325 -1.6873 11.3519 0.325 -2.0085 10.7848 0.325 -2.4330 10.3956 0.325 -2.9972 10.1607 0.325 -3.7233 10.0408 0.325 -4.6163 9.9860 0.325 -5.6621 9.9409 0.325 -6.8283 9.8502 0.325 -8.0661 9.6648 0.325 -9.3144 9.3462 0.325 -10.5045 8.8703 0.325 -11.5664 8.2298 0.325 -12.4348 7.4343 0.325 -13.0548 6.5092 0.325 -13.3872 5.4926 0.325 -13.4118 4.4311 0.325 -13.1296 3.3750 0.325 -12.5624 2.3723 0.325 -11.7515 1.4641 0.325 -10.7536 0.6798 0.325 -9.6361 0.0343 0.325 -8.4710 -0.4740 0.325 -7.3289 -0.8630 0.325 -6.2727 -1.1649 0.325 -5.3526 -1.4231 0.325 -4.6019 -1.6873 0.325 -4.0348 -2.0085 0.325 -3.6456 -2.4330 0.325 -3.4107 -2.9972 0.325 -3.2908 -3.7233 0.325 -3.2360 -4.6163 0.325 -3.1909 -5.6621 0.325 -3.1002 -6.8283 0.325 -2.9148 -8.0661 0.325 -2.5962 -9.3144 0.325 -2.1203 -10.5045 0.325 -1.4798 -11.5664 0.325 -0.6843 -12.4348 0.325 0.2408 -13.0548 0.325 1.2574 -13.3872 0.325 2.3189 -13.4118 0.325 3.3750 -13.1296 0.325 4.3777 -12.5624 0.325 5.2859 -11.7515 0.325 6.0702 -10.7536 0.325 6.7157 -9.6361 0.325 7.2240 -8.4710 0.325 7.6130 -7.3289 0.325 7.9149 -6.2727 0.325 8.1731 -5.3526 0.325 8.4373 -4.6019 0.325 8.7585 -4.0348 0.325 9.1830 -3.6456 0.325 9.7472 -3.4107 0.325 10.4733 -3.2908 0.325 11.3663 -3.2360 0.325 12.4121 -3.1909 0.325 13.5783 -3.1002 0.325 14.8161 -2.9148 0.325 16.0644 -2.5962 0.325 17.2545 -2.1203 0.325 18.3164 -1.4798 0.325 19.1848 -0.6843 0.325 19.8048 0.2408 0.325 20.1372 1.2574 0.325 20.1618 2.3189 0.325 = = = 18.6076 3.5000 0.300 18.0292 4.4141 0.300 17.2384 5.2356 0.300 16.2905 5.9399 0.300 15.2495 6.5168 0.300 14.1821 6.9708 0.300 13.1523 7.3216 0.300 12.2157 7.6013 0.300 11.4151 7.8514 0.300 10.7771 8.1182 0.300 10.3100 8.4478 0.300 10.0044 8.8809 0.300 9.8341 9.4481 0.300 9.7600 10.1662 0.300 9.7338 11.0354 0.300 9.7036 12.0385 0.300 9.6189 13.1418 0.300 9.4359 14.2973 0.300 9.1215 15.4464 0.300 8.6571 16.5252 0.300 8.0391 17.4699 0.300 7.2800 18.2221 0.300 6.4062 18.7347 0.300 5.4550 18.9757 0.300 4.4709 18.9314 0.300 3.5000 18.6076 0.300 2.5859 18.0292 0.300 1.7644 17.2384 0.300 1.0601 16.2905 0.300 0.4832 15.2495 0.300 0.0292 14.1821 0.300 -0.3216 13.1523 0.300 -0.6013 12.2157 0.300 -0.8514 11.4151 0.300 -1.1182 10.7771 0.300 -1.4478 10.3100 0.300 -1.8809 10.0044 0.300 -2.4481 9.8341 0.300 -3.1662 9.7600 0.300 -4.0354 9.7338 0.300 -5.0385 9.7036 0.300 -6.1418 9.6189 0.300 -7.2973 9.4359 0.300 -8.4464 9.1215 0.300 -9.5252 8.6571 0.300 -10.4699 8.0391 0.300 -11.2221 7.2800 0.300 -11.7347 6.4062 0.300 -11.9757 5.4550 0.300 -11.9314 4.4709 0.300 -11.6076 3.5000 0.300 -11.0292 2.5859 0.300 -10.2384 1.7644 0.300 -9.2905 1.0601 0.300 -8.2495 0.4832 0.300 -7.1821 0.0292 0.300 -6.1523 -0.3216 0.300 -5.2157 -0.6013 0.300 -4.4151 -0.8514 0.300 -3.7771 -1.1182 0.300 -3.3100 -1.4478 0.300 -3.0044 -1.8809 0.300 -2.8341 -2.4481 0.300 -2.7600 -3.1662 0.300 -2.7338 -4.0354 0.300 -2.7036 -5.0385 0.300 -2.6189 -6.1418 0.300 -2.4359 -7.2973 0.300 -2.1215 -8.4464 0.300 -1.6571 -9.5252 0.300 -1.0391 -10.4699 0.300 -0.2800 -11.2221 0.300 0.5938 -11.7347 0.300 1.5450 -11.9757 0.300 2.5291 -11.9314 0.300 3.5000 -11.6076 0.300 4.4141 -11.0292 0.300 5.2356 -10.2384 0.300 5.9399 -9.2905 0.300 6.5168 -8.2495 0.300 6.9708 -7.1821 0.300 7.3216 -6.1523 0.300 7.6013 -5.2157 0.300 7.8514 -4.4151 0.300 8.1182 -3.7771 0.300 8.4478 -3.3100 0.300 8.8809 -3.0044 0.300 9.4481 -2.8341 0.300 10.1662 -2.7600 0.300 11.0354 -2.7338 0.300 12.0385 -2.7036 0.300 13.1418 -2.6189 0.300 14.2973 -2.4359 0.300 15.4464 -2.1215 0.300 16.5252 -1.6571 0.300 17.4699 -1.0391 0.300 18.2221 -0.2800 0.300 18.7347 0.5938 0.300 18.9757 1.5450 0.300 18.9314 2.5291 0.300 = = = 17.3408 3.6250 0.275 16.7632 4.4516 0.275 16.0033 5.1887 0.275 15.1142 5.8167 0.275 14.1557 6.3288 0.275 13.1890 6.7325 0.275 12.2714 7.0484 0.275 11.4514 7.3078 0.275 10.7646 7.5500 0.275 10.2314 7.8175 0.275 9.8552 8.1515 0.275 9.6233 8.5872 0.275 9.5083 9.1498 0.275 9.4715 9.8509 0.275 9.4671 10.6868 0.275 9.4469 11.6382 0.275 9.3655 12.6707 0.275 9.1844 13.7376 0.275 8.8760 14.7839 0.275 8.4259 15.7508 0.275 7.8345 16.5805 0.275 7.1161 17.2220 0.275 6.2976 17.6354 0.275 5.4151 17.7954 0.275 4.5101 17.6938 0.275 3.6250 17.3408 0.275 2.7984 16.7632 0.275 2.0613 16.0033 0.275 1.4333 15.1142 0.275 0.9212 14.1557 0.275 0.5175 13.1890 0.275 0.2016 12.2714 0.275 -0.0578 11.4514 0.275 -0.3000 10.7646 0.275 -0.5675 10.2314 0.275 -0.9015 9.8552 0.275 -1.3372 9.6233 0.275 -1.8998 9.5083 0.275 -2.6009 9.4715 0.275 -3.4368 9.4671 0.275 -4.3882 9.4469 0.275 -5.4207 9.3655 0.275 -6.4876 9.1844 0.275 -7.5339 8.8760 0.275 -8.5008 8.4259 0.275 -9.3305 7.8345 0.275 -9.9720 7.1161 0.275 -10.3854 6.2976 0.275 -10.5454 5.4151 0.275 -10.4438 4.5101 0.275 -10.0908 3.6250 0.275 -9.5132 2.7984 0.275 -8.7533 2.0613 0.275 -7.8642 1.4333 0.275 -6.9057 0.9212 0.275 -5.9390 0.5175 0.275 -5.0214 0.2016 0.275 -4.2014 -0.0578 0.275 -3.5146 -0.3000 0.275 -2.9814 -0.5675 0.275 -2.6052 -0.9015 0.275 -2.3733 -1.3372 0.275 -2.2583 -1.8998 0.275 -2.2215 -2.6009 0.275 -2.2171 -3.4368 0.275 -2.1969 -4.3882 0.275 -2.1155 -5.4207 0.275 -1.9344 -6.4876 0.275 -1.6260 -7.5339 0.275 -1.1759 -8.5008 0.275 -0.5845 -9.3305 0.275 0.1339 -9.9720 0.275 0.9524 -10.3854 0.275 1.8349 -10.5454 0.275 2.7399 -10.4438 0.275 3.6250 -10.0908 0.275 4.4516 -9.5132 0.275 5.1887 -8.7533 0.275 5.8167 -7.8642 0.275 6.3288 -6.9057 0.275 6.7325 -5.9390 0.275 7.0484 -5.0214 0.275 7.3078 -4.2014 0.275 7.5500 -3.5146 0.275 7.8175 -2.9814 0.275 8.1515 -2.6052 0.275 8.5872 -2.3733 0.275 9.1498 -2.2583 0.275 9.8509 -2.2215 0.275 10.6868 -2.2171 0.275 11.6382 -2.1969 0.275 12.6707 -2.1155 0.275 13.7376 -1.9344 0.275 14.7839 -1.6260 0.275 15.7508 -1.1759 0.275 16.5805 -0.5845 0.275 17.2220 0.1339 0.275 17.6354 0.9524 0.275 17.7954 1.8349 0.275 17.6938 2.7399 0.275 = = = 16.0842 3.7500 0.250 15.5190 4.4904 0.250 14.7998 5.1459 0.250 13.9771 5.7009 0.250 13.1061 6.1522 0.250 12.2420 6.5092 0.250 11.4353 6.7928 0.250 10.7275 7.0334 0.250 10.1479 7.2673 0.250 9.7110 7.5330 0.250 9.4163 7.8668 0.250 9.2484 8.2986 0.250 9.1794 8.8485 0.250 9.1719 9.5237 0.250 9.1830 10.3174 0.250 9.1690 11.2085 0.250 9.0891 12.1630 0.250 8.9102 13.1364 0.250 8.6097 14.0775 0.250 8.1776 14.9328 0.250 7.6169 15.6511 0.250 6.9436 16.1884 0.250 6.1844 16.5115 0.250 5.3735 16.6012 0.250 4.5493 16.4544 0.250 3.7500 16.0842 0.250 3.0096 15.5190 0.250 2.3541 14.7998 0.250 1.7991 13.9771 0.250 1.3478 13.1061 0.250 0.9908 12.2420 0.250 0.7072 11.4353 0.250 0.4666 10.7275 0.250 0.2327 10.1479 0.250 -0.0330 9.7110 0.250 -0.3668 9.4163 0.250 -0.7986 9.2484 0.250 -1.3485 9.1794 0.250 -2.0237 9.1719 0.250 -2.8174 9.1830 0.250 -3.7085 9.1690 0.250 -4.6630 9.0891 0.250 -5.6364 8.9102 0.250 -6.5775 8.6097 0.250 -7.4328 8.1776 0.250 -8.1511 7.6169 0.250 -8.6884 6.9436 0.250 -9.0115 6.1844 0.250 -9.1012 5.3735 0.250 -8.9544 4.5493 0.250 -8.5842 3.7500 0.250 -8.0190 3.0096 0.250 -7.2998 2.3541 0.250 -6.4771 1.7991 0.250 -5.6061 1.3478 0.250 -4.7420 0.9908 0.250 -3.9353 0.7072 0.250 -3.2275 0.4666 0.250 -2.6479 0.2327 0.250 -2.2110 -0.0330 0.250 -1.9163 -0.3668 0.250 -1.7484 -0.7986 0.250 -1.6794 -1.3485 0.250 -1.6719 -2.0237 0.250 -1.6830 -2.8174 0.250 -1.6690 -3.7085 0.250 -1.5891 -4.6630 0.250 -1.4102 -5.6364 0.250 -1.1097 -6.5775 0.250 -0.6776 -7.4328 0.250 -0.1169 -8.1511 0.250 0.5564 -8.6884 0.250 1.3156 -9.0115 0.250 2.1265 -9.1012 0.250 2.9507 -8.9544 0.250 3.7500 -8.5842 0.250 4.4904 -8.0190 0.250 5.1459 -7.2998 0.250 5.7009 -6.4771 0.250 6.1522 -5.6061 0.250 6.5092 -4.7420 0.250 6.7928 -3.9353 0.250 7.0334 -3.2275 0.250 7.2673 -2.6479 0.250 7.5330 -2.2110 0.250 7.8668 -1.9163 0.250 8.2986 -1.7484 0.250 8.8485 -1.6794 0.250 9.5237 -1.6719 0.250 10.3174 -1.6830 0.250 11.2085 -1.6690 0.250 12.1630 -1.5891 0.250 13.1364 -1.4102 0.250 14.0775 -1.1097 0.250 14.9328 -0.6776 0.250 15.6511 -0.1169 0.250 16.1884 0.5564 0.250 16.5115 1.3156 0.250 16.6012 2.1265 0.250 16.4544 2.9507 0.250 = = = 14.8428 3.8750 0.225 14.3006 4.5309 0.225 13.6312 5.1075 0.225 12.8815 5.5931 0.225 12.1016 5.9872 0.225 11.3407 6.3007 0.225 10.6424 6.5544 0.225 10.0417 6.7768 0.225 9.5617 7.0013 0.225 9.2122 7.2621 0.225 8.9891 7.5906 0.225 8.8755 8.0118 0.225 8.8437 8.5409 0.225 8.8581 9.1815 0.225 8.8794 9.9243 0.225 8.8680 10.7473 0.225 8.7886 11.6176 0.225 8.6130 12.4934 0.225 8.3232 13.3279 0.225 7.9128 14.0734 0.225 7.3874 14.6850 0.225 6.7636 15.1254 0.225 6.0674 15.3678 0.225 5.3307 15.3984 0.225 4.5887 15.2183 0.225 3.8750 14.8428 0.225 3.2191 14.3006 0.225 2.6425 13.6312 0.225 2.1569 12.8815 0.225 1.7628 12.1016 0.225 1.4493 11.3407 0.225 1.1956 10.6424 0.225 0.9732 10.0417 0.225 0.7487 9.5617 0.225 0.4879 9.2122 0.225 0.1594 8.9891 0.225 -0.2618 8.8755 0.225 -0.7909 8.8437 0.225 -1.4315 8.8581 0.225 -2.1743 8.8794 0.225 -2.9973 8.8680 0.225 -3.8676 8.7886 0.225 -4.7434 8.6130 0.225 -5.5779 8.3232 0.225 -6.3234 7.9128 0.225 -6.9350 7.3874 0.225 -7.3754 6.7636 0.225 -7.6178 6.0674 0.225 -7.6484 5.3307 0.225 -7.4683 4.5887 0.225 -7.0928 3.8750 0.225 -6.5506 3.2191 0.225 -5.8812 2.6425 0.225 -5.1315 2.1569 0.225 -4.3516 1.7628 0.225 -3.5907 1.4493 0.225 -2.8924 1.1956 0.225 -2.2917 0.9732 0.225 -1.8117 0.7487 0.225 -1.4622 0.4879 0.225 -1.2391 0.1594 0.225 -1.1255 -0.2618 0.225 -1.0937 -0.7909 0.225 -1.1081 -1.4315 0.225 -1.1294 -2.1743 0.225 -1.1180 -2.9973 0.225 -1.0386 -3.8676 0.225 -0.8630 -4.7434 0.225 -0.5732 -5.5779 0.225 -0.1628 -6.3234 0.225 0.3626 -6.9350 0.225 0.9864 -7.3754 0.225 1.6826 -7.6178 0.225 2.4193 -7.6484 0.225 3.1613 -7.4683 0.225 3.8750 -7.0928 0.225 4.5309 -6.5506 0.225 5.1075 -5.8812 0.225 5.5931 -5.1315 0.225 5.9872 -4.3516 0.225 6.3007 -3.5907 0.225 6.5544 -2.8924 0.225 6.7768 -2.2917 0.225 7.0013 -1.8117 0.225 7.2621 -1.4622 0.225 7.5906 -1.2391 0.225 8.0118 -1.1255 0.225 8.5409 -1.0937 0.225 9.1815 -1.1081 0.225 9.9243 -1.1294 0.225 10.7473 -1.1180 0.225 11.6176 -1.0386 0.225 12.4934 -0.8630 0.225 13.3279 -0.5732 0.225 14.0734 -0.1628 0.225 14.6850 0.3626 0.225 15.1254 0.9864 0.225 15.3678 1.6826 0.225 15.3984 2.4193 0.225 15.2183 3.1613 0.225 = = = 13.6211 4.0000 0.200 13.1120 4.5733 0.200 12.5004 5.0739 0.200 11.8291 5.4935 0.200 11.1427 5.8339 0.200 10.4841 6.1068 0.200 9.8906 6.3323 0.200 9.3908 6.5367 0.200 9.0024 6.7501 0.200 8.7308 7.0023 0.200 8.5695 7.3200 0.200 8.5008 7.7233 0.200 8.4976 8.2236 0.200 8.5272 8.8210 0.200 8.5539 9.5047 0.200 8.5428 10.2527 0.200 8.4636 11.0335 0.200 8.2929 11.8088 0.200 8.0171 12.5367 0.200 7.6327 13.1751 0.200 7.1471 13.6856 0.200 6.5771 14.0373 0.200 5.9475 14.2091 0.200 5.2876 14.1922 0.200 4.6286 13.9905 0.200 4.0000 13.6211 0.200 3.4267 13.1120 0.200 2.9261 12.5004 0.200 2.5065 11.8291 0.200 2.1661 11.1427 0.200 1.8932 10.4841 0.200 1.6677 9.8906 0.200 1.4633 9.3908 0.200 1.2499 9.0024 0.200 0.9977 8.7308 0.200 0.6800 8.5695 0.200 0.2767 8.5008 0.200 -0.2236 8.4976 0.200 -0.8210 8.5272 0.200 -1.5047 8.5539 0.200 -2.2527 8.5428 0.200 -3.0335 8.4636 0.200 -3.8088 8.2929 0.200 -4.5367 8.0171 0.200 -5.1751 7.6327 0.200 -5.6856 7.1471 0.200 -6.0373 6.5771 0.200 -6.2091 5.9475 0.200 -6.1922 5.2876 0.200 -5.9905 4.6286 0.200 -5.6211 4.0000 0.200 -5.1120 3.4267 0.200 -4.5004 2.9261 0.200 -3.8291 2.5065 0.200 -3.1427 2.1661 0.200 -2.4841 1.8932 0.200 -1.8906 1.6677 0.200 -1.3908 1.4633 0.200 -1.0024 1.2499 0.200 -0.7308 0.9977 0.200 -0.5695 0.6800 0.200 -0.5008 0.2767 0.200 -0.4976 -0.2236 0.200 -0.5272 -0.8210 0.200 -0.5539 -1.5047 0.200 -0.5428 -2.2527 0.200 -0.4636 -3.0335 0.200 -0.2929 -3.8088 0.200 -0.0171 -4.5367 0.200 0.3673 -5.1751 0.200 0.8529 -5.6856 0.200 1.4229 -6.0373 0.200 2.0525 -6.2091 0.200 2.7124 -6.1922 0.200 3.3714 -5.9905 0.200 4.0000 -5.6211 0.200 4.5733 -5.1120 0.200 5.0739 -4.5004 0.200 5.4935 -3.8291 0.200 5.8339 -3.1427 0.200 6.1068 -2.4841 0.200 6.3323 -1.8906 0.200 6.5367 -1.3908 0.200 6.7501 -1.0024 0.200 7.0023 -0.7308 0.200 7.3200 -0.5695 0.200 7.7233 -0.5008 0.200 8.2236 -0.4976 0.200 8.8210 -0.5272 0.200 9.5047 -0.5539 0.200 10.2527 -0.5428 0.200 11.0335 -0.4636 0.200 11.8088 -0.2929 0.200 12.5367 -0.0171 0.200 13.1751 0.3673 0.200 13.6856 0.8529 0.200 14.0373 1.4229 0.200 14.2091 2.0525 0.200 14.1922 2.7124 0.200 13.9905 3.3714 0.200 = = = 12.4235 4.1250 0.175 11.9567 4.6177 0.175 11.4098 5.0453 0.175 10.8210 5.4023 0.175 10.2292 5.6923 0.175 9.6711 5.9271 0.175 9.1777 6.1255 0.175 8.7717 6.3116 0.175 8.4660 6.5115 0.175 8.2627 6.7509 0.175 8.1534 7.0518 0.175 8.1202 7.4301 0.175 8.1379 7.8934 0.175 8.1766 8.4395 0.175 8.2047 9.0565 0.175 8.1923 9.7231 0.175 8.1137 10.4102 0.175 7.9504 11.0833 0.175 7.6921 11.7056 0.175 7.3383 12.2408 0.175 6.8972 12.6569 0.175 6.3854 12.9287 0.175 5.8257 13.0406 0.175 5.2446 12.9875 0.175 4.6693 12.7760 0.175 4.1250 12.4235 0.175 3.6323 11.9567 0.175 3.2047 11.4098 0.175 2.8477 10.8210 0.175 2.5577 10.2292 0.175 2.3229 9.6711 0.175 2.1245 9.1777 0.175 1.9384 8.7717 0.175 1.7385 8.4660 0.175 1.4991 8.2627 0.175 1.1982 8.1534 0.175 0.8199 8.1202 0.175 0.3566 8.1379 0.175 -0.1895 8.1766 0.175 -0.8065 8.2047 0.175 -1.4731 8.1923 0.175 -2.1602 8.1137 0.175 -2.8333 7.9504 0.175 -3.4556 7.6921 0.175 -3.9908 7.3383 0.175 -4.4069 6.8972 0.175 -4.6787 6.3854 0.175 -4.7906 5.8257 0.175 -4.7375 5.2446 0.175 -4.5260 4.6693 0.175 -4.1735 4.1250 0.175 -3.7067 3.6323 0.175 -3.1598 3.2047 0.175 -2.5710 2.8477 0.175 -1.9792 2.5577 0.175 -1.4211 2.3229 0.175 -0.9277 2.1245 0.175 -0.5217 1.9384 0.175 -0.2160 1.7385 0.175 -0.0127 1.4991 0.175 0.0966 1.1982 0.175 0.1298 0.8199 0.175 0.1121 0.3566 0.175 0.0734 -0.1895 0.175 0.0453 -0.8065 0.175 0.0577 -1.4731 0.175 0.1363 -2.1602 0.175 0.2996 -2.8333 0.175 0.5579 -3.4556 0.175 0.9117 -3.9908 0.175 1.3528 -4.4069 0.175 1.8646 -4.6787 0.175 2.4243 -4.7906 0.175 3.0054 -4.7375 0.175 3.5807 -4.5260 0.175 4.1250 -4.1735 0.175 4.6177 -3.7067 0.175 5.0453 -3.1598 0.175 5.4023 -2.5710 0.175 5.6923 -1.9792 0.175 5.9271 -1.4211 0.175 6.1255 -0.9277 0.175 6.3116 -0.5217 0.175 6.5115 -0.2160 0.175 6.7509 -0.0127 0.175 7.0518 0.0966 0.175 7.4301 0.1298 0.175 7.8934 0.1121 0.175 8.4395 0.0734 0.175 9.0565 0.0453 0.175 9.7231 0.0577 0.175 10.4102 0.1363 0.175 11.0833 0.2996 0.175 11.7056 0.5579 0.175 12.2408 0.9117 0.175 12.6569 1.3528 0.175 12.9287 1.8646 0.175 13.0406 2.4243 0.175 12.9875 3.0054 0.175 12.7760 3.5807 0.175 = = = 11.2538 4.2500 0.150 10.8377 4.6645 0.150 10.3613 5.0220 0.150 9.8579 5.3198 0.150 9.3606 5.5622 0.150 8.8999 5.7609 0.150 8.5008 5.9330 0.150 8.1808 6.0997 0.150 7.9486 6.2833 0.150 7.8037 6.5052 0.150 7.7366 6.7832 0.150 7.7301 7.1290 0.150 7.7613 7.5473 0.150 7.8037 8.0343 0.150 7.8302 8.5777 0.150 7.8156 9.1576 0.150 7.7390 9.7477 0.150 7.5859 10.3180 0.150 7.3495 10.8367 0.150 7.0309 11.2737 0.150 6.6391 11.6028 0.150 6.1896 11.8044 0.150 5.7031 11.8672 0.150 5.2025 11.7895 0.150 4.7111 11.5794 0.150 4.2500 11.2538 0.150 3.8355 10.8377 0.150 3.4780 10.3613 0.150 3.1802 9.8579 0.150 2.9378 9.3606 0.150 2.7391 8.8999 0.150 2.5670 8.5008 0.150 2.4003 8.1808 0.150 2.2167 7.9486 0.150 1.9948 7.8037 0.150 1.7168 7.7366 0.150 1.3710 7.7301 0.150 0.9527 7.7613 0.150 0.4657 7.8037 0.150 -0.0777 7.8302 0.150 -0.6576 7.8156 0.150 -1.2477 7.7390 0.150 -1.8180 7.5859 0.150 -2.3367 7.3495 0.150 -2.7737 7.0309 0.150 -3.1028 6.6391 0.150 -3.3044 6.1896 0.150 -3.3672 5.7031 0.150 -3.2895 5.2025 0.150 -3.0794 4.7111 0.150 -2.7538 4.2500 0.150 -2.3377 3.8355 0.150 -1.8613 3.4780 0.150 -1.3579 3.1802 0.150 -0.8606 2.9378 0.150 -0.3999 2.7391 0.150 -0.0008 2.5670 0.150 0.3192 2.4003 0.150 0.5514 2.2167 0.150 0.6963 1.9948 0.150 0.7634 1.7168 0.150 0.7699 1.3710 0.150 0.7387 0.9527 0.150 0.6963 0.4657 0.150 0.6698 -0.0777 0.150 0.6844 -0.6576 0.150 0.7610 -1.2477 0.150 0.9141 -1.8180 0.150 1.1505 -2.3367 0.150 1.4691 -2.7737 0.150 1.8609 -3.1028 0.150 2.3104 -3.3044 0.150 2.7969 -3.3672 0.150 3.2975 -3.2895 0.150 3.7889 -3.0794 0.150 4.2500 -2.7538 0.150 4.6645 -2.3377 0.150 5.0220 -1.8613 0.150 5.3198 -1.3579 0.150 5.5622 -0.8606 0.150 5.7609 -0.3999 0.150 5.9330 -0.0008 0.150 6.0997 0.3192 0.150 6.2833 0.5514 0.150 6.5052 0.6963 0.150 6.7832 0.7634 0.150 7.1290 0.7699 0.150 7.5473 0.7387 0.150 8.0343 0.6963 0.150 8.5777 0.6698 0.150 9.1576 0.6844 0.150 9.7477 0.7610 0.150 10.3180 0.9141 0.150 10.8367 1.1505 0.150 11.2737 1.4691 0.150 11.6028 1.8609 0.150 11.8044 2.3104 0.150 11.8672 2.7969 0.150 11.7895 3.2975 0.150 11.5794 3.7889 0.150 = = = 10.1159 4.3750 0.125 9.7576 4.7136 0.125 9.3563 5.0043 0.125 8.9399 5.2458 0.125 8.5358 5.4433 0.125 8.1683 5.6075 0.125 7.8569 5.7536 0.125 7.6143 5.8993 0.125 7.4459 6.0633 0.125 7.3494 6.2626 0.125 7.3150 6.5110 0.125 7.3268 6.8170 0.125 7.3649 7.1827 0.125 7.4065 7.6032 0.125 7.4291 8.0667 0.125 7.4122 8.5554 0.125 7.3396 9.0464 0.125 7.2003 9.5143 0.125 6.9903 9.9327 0.125 6.7119 10.2774 0.125 6.3741 10.5277 0.125 5.9910 10.6691 0.125 5.5804 10.6940 0.125 5.1618 10.6031 0.125 4.7544 10.4050 0.125 4.3750 10.1159 0.125 4.0364 9.7576 0.125 3.7457 9.3563 0.125 3.5042 8.9399 0.125 3.3067 8.5358 0.125 3.1425 8.1683 0.125 2.9964 7.8569 0.125 2.8507 7.6143 0.125 2.6867 7.4459 0.125 2.4874 7.3494 0.125 2.2390 7.3150 0.125 1.9330 7.3268 0.125 1.5673 7.3649 0.125 1.1468 7.4065 0.125 0.6833 7.4291 0.125 0.1946 7.4122 0.125 -0.2964 7.3396 0.125 -0.7643 7.2003 0.125 -1.1827 6.9903 0.125 -1.5274 6.7119 0.125 -1.7777 6.3741 0.125 -1.9191 5.9910 0.125 -1.9440 5.5804 0.125 -1.8531 5.1618 0.125 -1.6550 4.7544 0.125 -1.3659 4.3750 0.125 -1.0076 4.0364 0.125 -0.6063 3.7457 0.125 -0.1899 3.5042 0.125 0.2142 3.3067 0.125 0.5817 3.1425 0.125 0.8931 2.9964 0.125 1.1357 2.8507 0.125 1.3041 2.6867 0.125 1.4006 2.4874 0.125 1.4350 2.2390 0.125 1.4232 1.9330 0.125 1.3851 1.5673 0.125 1.3435 1.1468 0.125 1.3209 0.6833 0.125 1.3378 0.1946 0.125 1.4104 -0.2964 0.125 1.5497 -0.7643 0.125 1.7597 -1.1827 0.125 2.0381 -1.5274 0.125 2.3759 -1.7777 0.125 2.7590 -1.9191 0.125 3.1696 -1.9440 0.125 3.5882 -1.8531 0.125 3.9956 -1.6550 0.125 4.3750 -1.3659 0.125 4.7136 -1.0076 0.125 5.0043 -0.6063 0.125 5.2458 -0.1899 0.125 5.4433 0.2142 0.125 5.6075 0.5817 0.125 5.7536 0.8931 0.125 5.8993 1.1357 0.125 6.0633 1.3041 0.125 6.2626 1.4006 0.125 6.5110 1.4350 0.125 6.8170 1.4232 0.125 7.1827 1.3851 0.125 7.6032 1.3435 0.125 8.0667 1.3209 0.125 8.5554 1.3378 0.125 9.0464 1.4104 0.125 9.5143 1.5497 0.125 9.9327 1.7597 0.125 10.2774 2.0381 0.125 10.5277 2.3759 0.125 10.6691 2.7590 0.125 10.6940 3.1696 0.125 10.6031 3.5882 0.125 10.4050 3.9956 0.125 = = = 9.0129 4.5000 0.100 8.7186 4.7654 0.100 8.3958 4.9922 0.100 8.0669 5.1804 0.100 7.7533 5.3353 0.100 7.4737 5.4662 0.100 7.2423 5.5858 0.100 7.0681 5.7085 0.100 6.9537 5.8489 0.100 6.8955 6.0202 0.100 6.8845 6.2324 0.100 6.9069 6.4912 0.100 6.9458 6.7968 0.100 6.9830 7.1441 0.100 7.0003 7.5224 0.100 6.9821 7.9163 0.100 6.9160 8.3071 0.100 6.7947 8.6741 0.100 6.6159 8.9966 0.100 6.3829 9.2558 0.100 6.1039 9.4362 0.100 5.7909 9.5277 0.100 5.4587 9.5259 0.100 5.1232 9.4329 0.100 4.7993 9.2571 0.100 4.5000 9.0129 0.100 4.2346 8.7186 0.100 4.0078 8.3958 0.100 3.8196 8.0669 0.100 3.6647 7.7533 0.100 3.5338 7.4737 0.100 3.4142 7.2423 0.100 3.2915 7.0681 0.100 3.1511 6.9537 0.100 2.9798 6.8955 0.100 2.7676 6.8845 0.100 2.5088 6.9069 0.100 2.2032 6.9458 0.100 1.8559 6.9830 0.100 1.4776 7.0003 0.100 1.0837 6.9821 0.100 0.6929 6.9160 0.100 0.3259 6.7947 0.100 0.0034 6.6159 0.100 -0.2558 6.3829 0.100 -0.4362 6.1039 0.100 -0.5277 5.7909 0.100 -0.5259 5.4587 0.100 -0.4329 5.1232 0.100 -0.2571 4.7993 0.100 -0.0129 4.5000 0.100 0.2814 4.2346 0.100 0.6042 4.0078 0.100 0.9331 3.8196 0.100 1.2467 3.6647 0.100 1.5263 3.5338 0.100 1.7577 3.4142 0.100 1.9319 3.2915 0.100 2.0463 3.1511 0.100 2.1045 2.9798 0.100 2.1155 2.7676 0.100 2.0931 2.5088 0.100 2.0542 2.2032 0.100 2.0170 1.8559 0.100 1.9997 1.4776 0.100 2.0179 1.0837 0.100 2.0840 0.6929 0.100 2.2053 0.3259 0.100 2.3841 0.0034 0.100 2.6171 -0.2558 0.100 2.8961 -0.4362 0.100 3.2091 -0.5277 0.100 3.5413 -0.5259 0.100 3.8768 -0.4329 0.100 4.2007 -0.2571 0.100 4.5000 -0.0129 0.100 4.7654 0.2814 0.100 4.9922 0.6042 0.100 5.1804 0.9331 0.100 5.3353 1.2467 0.100 5.4662 1.5263 0.100 5.5858 1.7577 0.100 5.7085 1.9319 0.100 5.8489 2.0463 0.100 6.0202 2.1045 0.100 6.2324 2.1155 0.100 6.4912 2.0931 0.100 6.7968 2.0542 0.100 7.1441 2.0170 0.100 7.5224 1.9997 0.100 7.9163 2.0179 0.100 8.3071 2.0840 0.100 8.6741 2.2053 0.100 8.9966 2.3841 0.100 9.2558 2.6171 0.100 9.4362 2.8961 0.100 9.5277 3.2091 0.100 9.5259 3.5413 0.100 9.4329 3.8768 0.100 9.2571 4.2007 0.100 = = = 7.9476 4.6250 0.075 7.7224 4.8199 0.075 7.4802 4.9857 0.075 7.2379 5.1234 0.075 7.0111 5.2376 0.075 6.8130 5.3359 0.075 6.6535 5.4281 0.075 6.5380 5.5252 0.075 6.4674 5.6378 0.075 6.4378 5.7754 0.075 6.4414 5.9447 0.075 6.4671 6.1489 0.075 6.5018 6.3875 0.075 6.5316 6.6554 0.075 6.5432 6.9438 0.075 6.5252 7.2404 0.075 6.4692 7.5310 0.075 6.3703 7.7998 0.075 6.2280 8.0316 0.075 6.0455 8.2128 0.075 5.8298 8.3329 0.075 5.5905 8.3853 0.075 5.3390 8.3678 0.075 5.0872 8.2834 0.075 4.8461 8.1395 0.075 4.6250 7.9476 0.075 4.4301 7.7224 0.075 4.2643 7.4802 0.075 4.1266 7.2379 0.075 4.0124 7.0111 0.075 3.9141 6.8130 0.075 3.8219 6.6535 0.075 3.7248 6.5380 0.075 3.6122 6.4674 0.075 3.4746 6.4378 0.075 3.3053 6.4414 0.075 3.1011 6.4671 0.075 2.8625 6.5018 0.075 2.5946 6.5316 0.075 2.3062 6.5432 0.075 2.0096 6.5252 0.075 1.7190 6.4692 0.075 1.4502 6.3703 0.075 1.2184 6.2280 0.075 1.0372 6.0455 0.075 0.9171 5.8298 0.075 0.8647 5.5905 0.075 0.8822 5.3390 0.075 0.9666 5.0872 0.075 1.1105 4.8461 0.075 1.3024 4.6250 0.075 1.5276 4.4301 0.075 1.7698 4.2643 0.075 2.0121 4.1266 0.075 2.2389 4.0124 0.075 2.4370 3.9141 0.075 2.5965 3.8219 0.075 2.7120 3.7248 0.075 2.7826 3.6122 0.075 2.8122 3.4746 0.075 2.8086 3.3053 0.075 2.7829 3.1011 0.075 2.7482 2.8625 0.075 2.7184 2.5946 0.075 2.7068 2.3062 0.075 2.7248 2.0096 0.075 2.7808 1.7190 0.075 2.8797 1.4502 0.075 3.0220 1.2184 0.075 3.2045 1.0372 0.075 3.4202 0.9171 0.075 3.6595 0.8647 0.075 3.9110 0.8822 0.075 4.1628 0.9666 0.075 4.4039 1.1105 0.075 4.6250 1.3024 0.075 4.8199 1.5276 0.075 4.9857 1.7698 0.075 5.1234 2.0121 0.075 5.2376 2.2389 0.075 5.3359 2.4370 0.075 5.4281 2.5965 0.075 5.5252 2.7120 0.075 5.6378 2.7826 0.075 5.7754 2.8122 0.075 5.9447 2.8086 0.075 6.1489 2.7829 0.075 6.3875 2.7482 0.075 6.6554 2.7184 0.075 6.9438 2.7068 0.075 7.2404 2.7248 0.075 7.5310 2.7808 0.075 7.7998 2.8797 0.075 8.0316 3.0220 0.075 8.2128 3.2045 0.075 8.3329 3.4202 0.075 8.3853 3.6595 0.075 8.3678 3.9110 0.075 8.2834 4.1628 0.075 8.1395 4.4039 0.075 = = = 6.9225 4.7500 0.050 6.7702 4.8771 0.050 6.6095 4.9849 0.050 6.4517 5.0746 0.050 6.3067 5.1497 0.050 6.1830 5.2156 0.050 6.0864 5.2791 0.050 6.0196 5.3474 0.050 5.9826 5.4276 0.050 5.9720 5.5255 0.050 5.9819 5.6450 0.050 6.0045 5.7878 0.050 6.0307 5.9526 0.050 6.0513 6.1357 0.050 6.0575 6.3305 0.050 6.0421 6.5284 0.050 6.0000 6.7197 0.050 5.9286 6.8939 0.050 5.8281 7.0412 0.050 5.7014 7.1529 0.050 5.5534 7.2226 0.050 5.3910 7.2467 0.050 5.2220 7.2245 0.050 5.0543 7.1589 0.050 4.8950 7.0554 0.050 4.7500 6.9225 0.050 4.6229 6.7702 0.050 4.5151 6.6095 0.050 4.4254 6.4517 0.050 4.3503 6.3067 0.050 4.2844 6.1830 0.050 4.2209 6.0864 0.050 4.1526 6.0196 0.050 4.0724 5.9826 0.050 3.9745 5.9720 0.050 3.8550 5.9819 0.050 3.7122 6.0045 0.050 3.5474 6.0307 0.050 3.3643 6.0513 0.050 3.1695 6.0575 0.050 2.9716 6.0421 0.050 2.7803 6.0000 0.050 2.6061 5.9286 0.050 2.4588 5.8281 0.050 2.3471 5.7014 0.050 2.2774 5.5534 0.050 2.2533 5.3910 0.050 2.2755 5.2220 0.050 2.3411 5.0543 0.050 2.4446 4.8950 0.050 2.5775 4.7500 0.050 2.7298 4.6229 0.050 2.8905 4.5151 0.050 3.0483 4.4254 0.050 3.1933 4.3503 0.050 3.3170 4.2844 0.050 3.4136 4.2209 0.050 3.4804 4.1526 0.050 3.5174 4.0724 0.050 3.5280 3.9745 0.050 3.5181 3.8550 0.050 3.4955 3.7122 0.050 3.4693 3.5474 0.050 3.4487 3.3643 0.050 3.4425 3.1695 0.050 3.4579 2.9716 0.050 3.5000 2.7803 0.050 3.5714 2.6061 0.050 3.6719 2.4588 0.050 3.7986 2.3471 0.050 3.9466 2.2774 0.050 4.1090 2.2533 0.050 4.2780 2.2755 0.050 4.4457 2.3411 0.050 4.6050 2.4446 0.050 4.7500 2.5775 0.050 4.8771 2.7298 0.050 4.9849 2.8905 0.050 5.0746 3.0483 0.050 5.1497 3.1933 0.050 5.2156 3.3170 0.050 5.2791 3.4136 0.050 5.3474 3.4804 0.050 5.4276 3.5174 0.050 5.5255 3.5280 0.050 5.6450 3.5181 0.050 5.7878 3.4955 0.050 5.9526 3.4693 0.050 6.1357 3.4487 0.050 6.3305 3.4425 0.050 6.5284 3.4579 0.050 6.7197 3.5000 0.050 6.8939 3.5714 0.050 7.0412 3.6719 0.050 7.1529 3.7986 0.050 7.2226 3.9466 0.050 7.2467 4.1090 0.050 7.2245 4.2780 0.050 7.1589 4.4457 0.050 7.0554 4.6050 0.050 = = = 5.9395 4.8750 0.025 5.8626 4.9371 0.025 5.7831 4.9897 0.025 5.7064 5.0336 0.025 5.6374 5.0708 0.025 5.5800 5.1041 0.025 5.5367 5.1370 0.025 5.5085 5.1731 0.025 5.4949 5.2158 0.025 5.4940 5.2678 0.025 5.5025 5.3309 0.025 5.5162 5.4055 0.025 5.5306 5.4906 0.025 5.5409 5.5841 0.025 5.5430 5.6824 0.025 5.5334 5.7811 0.025 5.5098 5.8752 0.025 5.4712 5.9596 0.025 5.4182 6.0293 0.025 5.3523 6.0804 0.025 5.2763 6.1100 0.025 5.1938 6.1167 0.025 5.1088 6.1005 0.025 5.0251 6.0632 0.025 4.9463 6.0081 0.025 4.8750 5.9395 0.025 4.8129 5.8626 0.025 4.7603 5.7831 0.025 4.7164 5.7064 0.025 4.6792 5.6374 0.025 4.6459 5.5800 0.025 4.6130 5.5367 0.025 4.5769 5.5085 0.025 4.5342 5.4949 0.025 4.4822 5.4940 0.025 4.4191 5.5025 0.025 4.3445 5.5162 0.025 4.2594 5.5306 0.025 4.1659 5.5409 0.025 4.0676 5.5430 0.025 3.9689 5.5334 0.025 3.8748 5.5098 0.025 3.7904 5.4712 0.025 3.7207 5.4182 0.025 3.6696 5.3523 0.025 3.6400 5.2763 0.025 3.6333 5.1938 0.025 3.6495 5.1088 0.025 3.6868 5.0251 0.025 3.7419 4.9463 0.025 3.8105 4.8750 0.025 3.8874 4.8129 0.025 3.9669 4.7603 0.025 4.0436 4.7164 0.025 4.1126 4.6792 0.025 4.1700 4.6459 0.025 4.2133 4.6130 0.025 4.2415 4.5769 0.025 4.2551 4.5342 0.025 4.2560 4.4822 0.025 4.2475 4.4191 0.025 4.2338 4.3445 0.025 4.2194 4.2594 0.025 4.2091 4.1659 0.025 4.2070 4.0676 0.025 4.2166 3.9689 0.025 4.2402 3.8748 0.025 4.2788 3.7904 0.025 4.3318 3.7207 0.025 4.3977 3.6696 0.025 4.4737 3.6400 0.025 4.5562 3.6333 0.025 4.6412 3.6495 0.025 4.7249 3.6868 0.025 4.8037 3.7419 0.025 4.8750 3.8105 0.025 4.9371 3.8874 0.025 4.9897 3.9669 0.025 5.0336 4.0436 0.025 5.0708 4.1126 0.025 5.1041 4.1700 0.025 5.1370 4.2133 0.025 5.1731 4.2415 0.025 5.2158 4.2551 0.025 5.2678 4.2560 0.025 5.3309 4.2475 0.025 5.4055 4.2338 0.025 5.4906 4.2194 0.025 5.5841 4.2091 0.025 5.6824 4.2070 0.025 5.7811 4.2166 0.025 5.8752 4.2402 0.025 5.9596 4.2788 0.025 6.0293 4.3318 0.025 6.0804 4.3977 0.025 6.1100 4.4737 0.025 6.1167 4.5562 0.025 6.1005 4.6412 0.025 6.0632 4.7249 0.025 6.0081 4.8037 0.025 ngraph-gtk-6.08.00/demo/Makefile.am0000644000175000017500000000166113230344424013633 00000000000000demodir = $(pkgdatadir)/demo dist_demo_DATA = demo1.dat demo2.dat demo3.dat demo6.dat demo8.dat \ demo9.dat demo4.ngp demo5a.ngp demo5b.ngp demo5c.ngp \ demo5d.ngp demo5e.ngp demo7.ngp nodist_demo_DATA = demo.ngp demo1.ngp demo2.ngp demo3.ngp demo6.ngp \ demo8.ngp demo9.ngp EXTRA_DIST = demo.ngp.in demo1.ngp.in demo2.ngp.in demo3.ngp.in \ demo6.ngp.in demo8.ngp.in demo9.ngp.in windows_demo.sed demo.ngp: Makefile demo1.ngp: Makefile demo2.ngp: Makefile demo3.ngp: Makefile demo6.ngp: Makefile demo8.ngp: Makefile demo9.ngp: Makefile SUFFIXES = .ngp.in .ngp if OS_WIN32 .ngp.in.ngp: $(SED) -f $(srcdir)/windows_demo.sed $< > $@ else if OS_OSX .ngp.in.ngp: $(SED) -f $(srcdir)/windows_demo.sed $< > $@ else .ngp.in.ngp: $(SHELL) $(top_srcdir)/pathconv.sh "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" $< endif endif CLEANFILES = demo.ngp demo1.ngp demo2.ngp demo3.ngp demo6.ngp demo8.ngp demo9.ngp ngraph-gtk-6.08.00/demo/demo8.ngp.in0000644000175000017500000003322313246234367013740 00000000000000#!ngraph #%creator: Ngraph #%version: 6.07.05 new axis name:fX1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=2.550000000000000e+02 axis::inc=1.000000000000000e+02 axis::div=0 axis::type=linear axis::x=3600 axis::y=22000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=0 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fY1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=2.550000000000000e+02 axis::inc=1.000000000000000e+02 axis::div=0 axis::type=linear axis::x=3600 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=0 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference= axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=400 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fU1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=3600 axis::y=8000 axis::direction=0 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:0' axis::gauge=left axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:fR1 axis::hidden=false axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=0.000000000000000e+00 axis::inc=0.000000000000000e+00 axis::div=0 axis::type=linear axis::x=17600 axis::y=22000 axis::direction=9000 axis::baseline=true axis::length=14000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=300 axis::wave_width=40 axis::reference='axis:1' axis::gauge=right axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=100 axis::gauge_width1=40 axis::gauge_length2=200 axis::gauge_width2=40 axis::gauge_length3=300 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=right axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=2000 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=left axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= axis::grouping 1 0 1 2 3 new axis name:cX1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=2.700000000000000e+02 axis::inc=1.000000000000000e+02 axis::div=0 axis::type=linear axis::x=6500 axis::y=26000 axis::direction=4500 axis::baseline=true axis::length=5400 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=178 axis::wave_width=40 axis::reference= axis::gauge=both axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=59 axis::gauge_width1=40 axis::gauge_length2=119 axis::gauge_width2=40 axis::gauge_length3=178 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=1191 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=center axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=100 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= new axis name:cY1 axis::hidden=true axis::R=0 axis::G=0 axis::B=0 axis::A=255 axis::clip=true axis::redraw_flag=true axis::min=0.000000000000000e+00 axis::max=3.300000000000000e+00 axis::inc=1.000000000000000e+00 axis::div=0 axis::type=linear axis::x=6500 axis::y=26000 axis::direction=9000 axis::baseline=true axis::length=8000 axis::width=40 axis::style= axis::auto_scale_margin=500 axis::adjust_axis= axis::adjust_position=0 axis::arrow=none axis::arrow_length=72426 axis::arrow_width=60000 axis::wave=none axis::wave_length=178 axis::wave_width=40 axis::reference= axis::gauge=both axis::gauge_min=0.000000000000000e+00 axis::gauge_max=0.000000000000000e+00 axis::gauge_style= axis::gauge_length1=59 axis::gauge_width1=40 axis::gauge_length2=119 axis::gauge_width2=40 axis::gauge_length3=178 axis::gauge_width3=40 axis::gauge_R=0 axis::gauge_G=0 axis::gauge_B=0 axis::gauge_A=255 axis::num=left axis::num_begin=0 axis::num_step=0 axis::num_num=-1 axis::num_auto_norm=5 axis::num_head= axis::num_format='%g' axis::num_tail= axis::num_log_pow=true axis::num_pt=1191 axis::num_space=0 axis::num_font='Sans-serif' axis::num_font_style=0 axis::num_script_size=7000 axis::num_align=right axis::num_no_zero=false axis::num_direction=horizontal axis::num_shift_p=0 axis::num_shift_n=400 axis::num_R=0 axis::num_G=0 axis::num_B=0 axis::num_A=255 axis::num_date_format= axis::num_math= axis::grouping 3 4 5 new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=file data::save_path=unchange data::x=0 data::y=2 data::type=mark data::interpolation=spline data::fit= data::math_x='ofst_x := %0 * 2.5; ofst_y := -%0 / 40; shift(col); # remove %0 from the array col n := size(col); # number of the data for(0, 0, n - 1, 1, # initialize arrays for polyline progn( i := rm(0), # index of the array ax[i] := i + ofst_x, ay[i] := col[i] + ofst_y)); unshift(ax, ax[0]); # add first x for a polygon mask unshift(ay, ofst_y); # add first y for a polygon mask push(ax, ax[-1]); # add last x for a polygon mask push(ay, ofst_y); # add last y for a polygon mask draw_polygon(ax, ay, FALSE, FILL_RULE_WINDING); shift(ax); # remove first x for a polygon mask shift(ay); # remove first y for a polygon mask pop(ax); # remove last x for a polygon mask pop(ay); # remove last y for a polygon mask draw_polyline(ax, ay); # draw a polyline x;' data::math_y= data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=0 data::line_width=20 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=2 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:4' data::axis_y='axis:5' data::data_clip=false data::range_min=1.000000000000000e+00 data::range_max=1.000000000000000e+01 data::range_div=512 data::array= data::file='DOCDIRDEF/demo8.dat' new data data::hidden=false data::R=0 data::G=0 data::B=0 data::A=255 data::clip=true data::redraw_flag=true data::source=file data::save_path=unchange data::x=0 data::y=0 data::type=mark data::interpolation=spline data::fit= data::math_x='for(0, 1, SIZE(col) - 1, 1, # draw rectangle for each column progn( i := rm(0), # index of the column hsb2((1 - col[i]) * 0.68, 1, 1), # set fill color draw_rect(i, y, -1.1, -1.1, FALSE, TRUE))); x - 1' data::math_y='y - 1' data::func_f= data::func_g= data::func_h= data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=0 data::line_width=10 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=1.000000000000000e+00 data::range_max=1.000000000000000e+01 data::range_div=512 data::array= data::file='DOCDIRDEF/demo8.dat' new data data::hidden=false data::R=252 data::G=233 data::B=79 data::A=255 data::clip=true data::redraw_flag=true data::source=file data::save_path=unchange data::x=96 data::y=128 data::type=line data::interpolation=spline data::fit= data::math_x='if(%0 == NUM, # at the last data progn( color(3,128), # set line color draw_line(COLX, 0, COLX, NUM), # draw a vertical line draw_line(0, COLY, size(col), COLY))); # draw a horizontal line x * h();' data::math_y='const SCALE := h(); n := size(col); # number of the data if(%0 == COLY, # if data row is COLY for(0, 1, n - 1, 1, # draw horizontal data progn( i := rm(0), draw_line(i - 1, col[i] * SCALE, i, col[i + 1] * SCALE)))); %0' data::func_f= data::func_g= data::func_h='100' data::smooth_x=0 data::smooth_y=0 data::mark_type=0 data::mark_size=0 data::line_width=40 data::line_style= data::line_join=bevel data::line_miter_limit=1000 data::R2=255 data::G2=255 data::B2=255 data::A2=255 data::remark='#%'\''' data::ifs=' , ()' data::csv=false data::head_skip=0 data::read_step=1 data::final_line=-1 data::mask= data::move_data= data::move_data_x= data::move_data_y= data::axis_x='axis:0' data::axis_y='axis:1' data::data_clip=true data::range_min=1.000000000000000e+00 data::range_max=1.000000000000000e+01 data::range_div=512 data::array= data::file='DOCDIRDEF/demo8.dat' new text text::hidden=false text::R=0 text::G=0 text::B=0 text::A=255 text::clip=true text::redraw_flag=true text::text='Demo #8:\nDRAW\_RECT(), DRAW\_LINE() and COL[ ]' text::x=4000 text::y=6842 text::pt=2000 text::font='Sans-serif' text::style=1 text::space=0 text::direction=0 text::script_size=7000 text::raw=false new gra name:viewer gra::left_margin=0 gra::top_margin=0 gra::zoom=10000 gra::paper_width=21000 gra::paper_height=29700 gra::draw_obj='axisgrid axis data merge legend rectangle arc path mark text' ngraph-gtk-6.08.00/demo/Makefile.in0000644000175000017500000004300213367273151013650 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = demo ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_demo_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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)$(demodir)" "$(DESTDIR)$(demodir)" DATA = $(dist_demo_DATA) $(nodist_demo_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ demodir = $(pkgdatadir)/demo dist_demo_DATA = demo1.dat demo2.dat demo3.dat demo6.dat demo8.dat \ demo9.dat demo4.ngp demo5a.ngp demo5b.ngp demo5c.ngp \ demo5d.ngp demo5e.ngp demo7.ngp nodist_demo_DATA = demo.ngp demo1.ngp demo2.ngp demo3.ngp demo6.ngp \ demo8.ngp demo9.ngp EXTRA_DIST = demo.ngp.in demo1.ngp.in demo2.ngp.in demo3.ngp.in \ demo6.ngp.in demo8.ngp.in demo9.ngp.in windows_demo.sed SUFFIXES = .ngp.in .ngp CLEANFILES = demo.ngp demo1.ngp demo2.ngp demo3.ngp demo6.ngp demo8.ngp demo9.ngp all: all-am .SUFFIXES: .SUFFIXES: .ngp.in .ngp $(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) --gnu demo/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu demo/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_demoDATA: $(dist_demo_DATA) @$(NORMAL_INSTALL) @list='$(dist_demo_DATA)'; test -n "$(demodir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(demodir)'"; \ $(MKDIR_P) "$(DESTDIR)$(demodir)" || 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)$(demodir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(demodir)" || exit $$?; \ done uninstall-dist_demoDATA: @$(NORMAL_UNINSTALL) @list='$(dist_demo_DATA)'; test -n "$(demodir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(demodir)'; $(am__uninstall_files_from_dir) install-nodist_demoDATA: $(nodist_demo_DATA) @$(NORMAL_INSTALL) @list='$(nodist_demo_DATA)'; test -n "$(demodir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(demodir)'"; \ $(MKDIR_P) "$(DESTDIR)$(demodir)" || 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)$(demodir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(demodir)" || exit $$?; \ done uninstall-nodist_demoDATA: @$(NORMAL_UNINSTALL) @list='$(nodist_demo_DATA)'; test -n "$(demodir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(demodir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)$(demodir)" "$(DESTDIR)$(demodir)"; 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-dist_demoDATA install-nodist_demoDATA 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_demoDATA uninstall-nodist_demoDATA .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_demoDATA install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-nodist_demoDATA \ 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_demoDATA \ uninstall-nodist_demoDATA .PRECIOUS: Makefile demo.ngp: Makefile demo1.ngp: Makefile demo2.ngp: Makefile demo3.ngp: Makefile demo6.ngp: Makefile demo8.ngp: Makefile demo9.ngp: Makefile @OS_WIN32_TRUE@.ngp.in.ngp: @OS_WIN32_TRUE@ $(SED) -f $(srcdir)/windows_demo.sed $< > $@ @OS_OSX_TRUE@@OS_WIN32_FALSE@.ngp.in.ngp: @OS_OSX_TRUE@@OS_WIN32_FALSE@ $(SED) -f $(srcdir)/windows_demo.sed $< > $@ @OS_OSX_FALSE@@OS_WIN32_FALSE@.ngp.in.ngp: @OS_OSX_FALSE@@OS_WIN32_FALSE@ $(SHELL) $(top_srcdir)/pathconv.sh "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" "$(demodir)" $< # 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: ngraph-gtk-6.08.00/AUTHORS0000644000175000017500000000015213070106167011717 00000000000000Original authors: Satoshi ISHIZAKA GTK: Ito Hiroyuki ngraph-gtk-6.08.00/doc/0000755000175000017500000000000013375640232011502 500000000000000ngraph-gtk-6.08.00/doc/html/0000755000175000017500000000000013375640233012447 500000000000000ngraph-gtk-6.08.00/doc/html/objlist.nsc0000755000175000017500000000201413070106167014535 00000000000000#! /usr/bin/ngraph -i TMP_FILE=${system::temp_file} new io new string new regexp regexp::@="(current instance:)|(last instance id:)" new regexp regexp::@='([^\s]+)\s+([^\s]+)\s+(.+)' for obj in `object` do echo '

'$obj'

' object $obj > $TMP_FILE io::open "$TMP_FILE" table=0 echo '
'
    while true
    do
	string::@="${io::gets}"
	if io::eof
	then
	    break
	fi

	if regexp:0:match "${string::@}"
	then
	    continue
	elif [ "${string::@}" = "alias:" ]
	then
	    continue
	elif string::index ": 0"
	then
	    echo "${string::@}"
	else
	    if [ $table = "0" ]
	    then
		echo '
' echo '' echo "" table=1 fi get regexp:1 -field replace:"'${string::@}' ''" fi done io::close echo "
permissionfield namefield type
\1\2\3
" echo done echo '
' echo '
' echo '
' echo '' echo '' del system ngraph-gtk-6.08.00/doc/html/img/0000755000175000017500000000000013375640233013223 500000000000000ngraph-gtk-6.08.00/doc/html/img/trimming.png0000644000175000017500000000564413070106167015503 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿ3'|ó pHYs  šœtIMEÜ0°‰%tEXtCommentCreated with GIMPW ÿIDATxÚíÝOˆUÇñ_ugH‘`¦%‹–1"š1CtCÖD" doñàÍ“âDă¢‚âUD"Ùhà ‰I˜É8³Y4®x D”dTtÓ¡Óé= 5Tjªºëß«WÕõý@“žžI¿ªW¯ëýê½ê*§×ëõ€ÄjT €@@  P€@@  P¨@  P¨T PähUÀX^–þü3ýûlܸò@,N¯×ëQ ”ÜcI}”þ}^zIzí5ê3&¦üT* * €@@þ¸õ EõûïÒ«¯J³³Òµkýÿö·ß¤v;}™6H7Þ8øïFF¤'Ÿ”ž}VZ¿ž@E  àNœžzJ:}Úþ²LO¯üûÎ;Òw²mT”H¯'}ø¡ôâ‹Ò… ù—¿u«ôÖ[ÒÌ Û‚@@Éýñ‡ôÆÒÛoKW®˜/oãFéå—WFÈFF¨Cäǥ瞓0óþµšôÄÒë¯K›7Sß*†Ø—_JO?--.f÷ž÷ß/½û®´mõ5R”ØHóóÒûïK7ßœî½n»MúøcéèQÂTLŒP0,~ýUzåé½÷¤N'úÿÛ°Azáéùç¥Fƒz$P}û­ôÌ3ÒçŸHŽôè£Ò›oJ·ÞJ½¨À‡­«ï¾[û»;VΓºï>ê)œCÀ°Ú·OZZZ¹ÄÂM7­¼vË-ÒH_M˜Ê#TTÁ/¿HŸ|"=þx´[Ë€@§u³³³Ú¿¿–——×ürllL—.]Zý¹ÕjQcþ@%IËËË«áÉ¢¼?iÚ½!"V­ž”îQA¯ $PmÚ´éºÝðä VkÊÏ?JÕív5¿0¯s?œS»ÝÎe†î¿C“wOª^¯³@1•žü!Êÿºßü¼~úù'mþËfu®vrYà‘úˆ.ü|AZ”¦&§Ø‚ÀºTS~ßÿð½FoU·ÛUÍ©åòè^ëj´1ªsÿ=ÇÖÅ T?DyOP W—Û—Õ½Ö•ã8¹>º½®®´¯°õ@!¤šò“¤Z»×€jKý-¿¼G§Ü@¡UÒ)?ie„ÊÆ#Šf³©f³¹ægïkA‡äΞ=K%|^@{©œÔS~ŽŠ9ZÔl6uñâÅ5Ïý¯…ý‰å¨‚óçÏkbb‚OÀçl/6ú¤A¶ûȰ勻\뤕)?ï½ü¼S~ƒ®îÔÊ5ýæV\PE™S¶CU¿õU¬Aö<×Ùvù(O»ŒÃd²½_(ê~ÉÛ' 0˜Ôëõ‚3„ÅSxµá¸ýgª {F©ŒGfY}~ààÂtDA (ËF4­hó¨`ƒ‡©Àš¤£0Q·ý–# l»|˜ 5Yl;·“t'öó²íÊt §­4›Mõz=9ŽctyÝm¬lÖÇ °u[¦ÿ–ŸS‹ô¡sçºpõé??5^aÞðÖ¸Ó~Ywy&ÿªw$ÃX¿ƒÖÏôN;hgÔ !Ìs;ˆ»Þa§0ø·Ó°ž3jû@¶ÒIû$Ó¡ª(A*Îr¹uUê)¿(Ê{dâþüð?^ýù³CŸÝÉøÏŸªÊŽØTX¬J˜Š²0q¤e›ywަBMÔ ©N#,Øe ðyïã¼í?îs¡Ávh)j›qûh“¡ªH#Taû¸ etë$Ê6M=åW«÷T[53=ÚQ9Ž£‡ö=tÝßçuô`ºÁûGò.PçSÆU•‘©¨ëæ¶«¬vàqÔ©PwýMo“°Q ¢w”yÝiÊÑû¤~£2Y·Ÿ¢ŽPei5 ùCTÐëoáv1ƒ*Ù}HÒÌôLê÷ŒRž÷èÞÔ9hd,Ïòm¯?a ÃÒE}½H˘Õß—94T±ü¸}’û³7äöz½Ì—¿È×ô/[ÒeM?åñšPþi?ÿï\_üë‹Ü‚…·ü¼Goª^>a*|ã®_V£TIG§²¹Iòÿ«®“¶—¬:¢¤ÏMÖ‡ÍQDÛå5LGÙ¯ô[¾2|ÎS_Ø3ÊUÍ[‡[¤u¸¥Öá–ñ+¥ý_ï(™wôÆÄ‘JžåÛ^Â0ܼûŒ¸Ï‘ÿ~Ô­ÿ ™ ÿ(•©Q °2¢^ÂÀt;NÓNSOùÕëõHA¦÷NG~¯(ï—$áz7v·x5ïòm¯?a eÚ]з‡m/gÔe©Â]!˜ò ßÿ{Oº V&C•ÿ ½ßrúe‘Û½üÂFGÜŠ–¤÷5wÊØÑ¥ÿÜ&éËT¹|F9â€Ø¸Ø·ü~¡Êä6³Ý•_”Qª~#»¦§¸ŠraÏ8m%¯Qÿ²îϼ¡'Ëõ°ý ?ogª¤žòËb´È5wfNÛ'·¯®ðÜ™¹\w–YWx¿û&åQ¾íõ–£YÛËaêÍ¢—_†í^ôÐWÕ Îúï~×Xóß(ÙÆö0y hÒ:÷IPˆò¿$«Ä] ‹ Úv×6-,.XM±Y]Ø3î{qÛÐi|fM õ[>ÓWLfé§ü Tü7Kß Í‡¡jG½[¶láSðyAAÛK”ý;Q)Uª)¿ŒG¨PnTÀç´—j*7<ùC”ÿõ YžCPÚ@•tÊo´1ªÎÕŽë¹.t»ÝÖúÆz¶(„T÷ò»}üv-þ{Q«Õjµ\NGKÿYÒÖñ­l=P©¦üî¹ûY<£#_Ñåÿ]ÎeGoÕø_Ç5y×$['P%ò«×ëššœÒÔä5 *+Õ”2¸—@ÕÅšòkµZÔ€Ïÿž²9l‘¡„ºIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/winlgnd.png0000644000175000017500000000026313070106167015307 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑBIDAT×ch`0`ØÿÃV¶âûö¿âï@ükÃî?6þÒ@ù½P¼„¿åEDù  N ' æ+ˆIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bdraw.png0000644000175000017500000000054513070106167014747 00000000000000‰PNG  IHDRÝÁNbKGDÿÿÿÿÿÿ X÷Ü pHYsHHFÉk> vpAg£;*ÑŽIDATHÇíÕÛ À PÛ™²“3¹Sv²©­¡y‚´ÞŸ BrÑ”þZ­ö8"¢ºÅ®hcÙsNÓ¨(Ù JبÞ÷©õ¨N 3CìC0ÄRúFSÀž@94öúžÐ”èwþÏ!ÒÐX˜ø„ÆÂH @Îz¨¬uì—ÚËì[ñÊ4Töݺô%tEXtdate:create2011-02-17T10:47:16+09:00~Âýk%tEXtdate:modify2011-02-17T10:45:38+09:00péÊIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/lapoint.png0000644000175000017500000000565313070106167015323 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿ3'|ó pHYs  šœtIMEÜ/ s‰tEXtCommentCreated with GIMPW IDATxÚíÝOˆUÇñ_ugH‘`¦%‹–1"š1CtCÖD" doñàÍ“âDă¢‚âUD"Ùhà ‰I˜É8³Y4®x D”dTtÓ¡Óé= 5Tjªºëß«WÕõý@“žžI׫z¯ëýê½ê*§×ëõ€Äjl €@@  €@@  P€@@  P¨@ ÈÑ:£ï¾¼,ýùgú÷Ù¸qåP@N¯×ë{÷Ç“>ú(ýû¼ô’ôÚkÔ($¦üT* * €@@þâßzæ÷ߥW_•fg¥k×úÿío¿IívúRnØ Ýxãà¿‘ž|RzöYiýzj4P¹NœžzJ:}ÚþZLO¯üûÎ;ÒwR« $J’z=éÃ¥_”.\È¿ô[·Jo½%ÍÌP“ ¤ÊõÇÒoHo¿-]¹b¾Ô7J/¿¼2B62B-€!T®”ž{N:pÀLik5é‰'¤×_—6o¦öÀ*×—_JO?--.f÷ž÷ß/½û®´mµ ÅÌex@šŸ—Þ_ºùætïuÛmÒÇKG¦@!™¡òúõWé•W¤÷Þ“:èÿoÃ酤矗 j T8P¹¾ýVzæéóϔȑ}TzóMéÖ[©!@ ZãС•`õÝwk·cÇÊyR÷ÝGÍ€ÒÈÿÖ3ûöIKK+—X¸é¦•×n¹Eúàéë¯ S tò¡òúåé“O¤ÇvkÀðY7;;«ýû÷kyyyÍ/ÇÆÆtéÒ¥ÕŸ[­[ À¨$iyyy5º½®®´¯P{ RMùIR­Vc+€JKý-¿¼G§Ü@¡UÒ)?ie„ÊÆ#Šf³©f³¹ægïkA‡äΞ=ËFø¼€öR9©§üs´¨ÙlêâÅ‹kžû_ û;娂óçÏkbb‚OÀçl/6ú¤A¶ûȰòÅ-×:ieÊÏ{/?ï”ß +¤;µrM¿¹.hC™S¶CU¿õU¬Aö<×ÙöòQžv‡É6d{¿PÔý’·O `0©×ëg‹§ð jÃqûÏTöŒ²1™ydõùƒ Ó5 ,Uд¢Í£‚a ¦k’ŽÂĶíWŽ<‚²íåÃl¨É¢îÜNÒqœØÏ˶_(Ótœ¶Òl6Õëõä8ŽÑòºu¬lnAa/j]¦ÿ–ŸS‹ô¡sçºpõé??5¾Á¼á)¬#p§ý²îòLþUïH†qûZ?Ó;í MP'X„0;Ìí îz‡Â௧a=gÔöl¤“öI¦CUQ‚Tœr¹Û$ªÔS~Q•÷ÈÄýùá<¼úóg‡>3º“ñŸ?U•±©°X•0e`âH;JywަBMÔ ©N#,Øe ðyïã¼í?îs¡Ávh)j›qûh“¡ªH#Taû¸ 2ºÛ$J¦žò«Õûªƒ­ƒš™ž í¨ÇÑCûºîïó:z0Ýàý£y/PçSÆU•‘©¨ëæ¶«¬vàqÔ©PwýM×IØ(PÑ;ʼŽî‹4å‡è}R¿Q™¬ÛOQG¨²´š†ü!*èõÀ7ˆp»˜AÙ}HÒÌôLê÷Œ²<ïѽ©rÐÈXžË·½þ„) Kõõ"•1«¿/sh¨âòãöIîÏÞÛëõ2/‘¯!é/[Ò²¦Ÿò‹xM(ÿ´Ÿÿw®/þõEnÁ»ü¼Goª¾|ÂTø:Æ]¿¬F©’ŽNe9r“äÿW=\'m/YuDIŸ›Ü6Gm/¿¨a:Ê~¥_ùÊð9O}aÏ(W5on ,HëpK­Ã-ãWJú¿ÞQ2ïè‰#•<—o{ý SÀpóî3â>GþûQwûÍLøG©L…-#ê% L·ã4í4õ”_½^ôdzïtä÷Šò~I®·²³è¸ýëy/ßöú¦Pö(¨Ý}{Øv9£–¥ w…`Ê/|ÿï=é:(X™ Uþƒö~åô?Ê"·{ù…ޏZ’Üó µ{ùyƒ„ ¬úò S@òŽ2ÎIüY~–üû÷8ÏMn›û Û˪üÁÊ_¯þogÙVŠÂ_ž Àg!õ”_½Vô8òÕ‘ÀæU{wïô~YnDïò³<ª;RÉkù¶×Ÿ0 ·2NùUù¾­îº‰°{ßzŸU[‰öM}i*Jœ4¦žò‹:¢ä/ØÑcG׬Œ»±÷ü}±*ç´ü¬*0èH%ÏåÛ^ÂT²ºIú­­¬NOúù"ø–# c ˆ{þÉmP–où…ªA9Í:Åé»MÝî*¬üƒ2FÔe§žò‹{Þ“[Ðz½®c'Ž…vê»wíÎüª°‘[¡¢êË'L¡èô 6X„N3É·ü²Ü‡Øšòó`DýÙtÝyÊÏ_Nˆ:àΪΒŽNf5Mí¯ï(e‰»ìôö¬E¿&Ôñ“ǵóÞ:~òøš×¼—Up/,¶ëo»®û[SªÙl.?ÍW_ûÝî&åÛ^ÿ,|œÞ°„¯¸—@ÈúJøAíÑ©ðíTôP˜×åWl\سßÅVûý\åûPú/ìõâžî>!‹ø¨AÆt»5ñ¬ôßò‹x•û8yúdàka#%;ïÝ™ù9TþeMu¤©ñ6Ö †kzù¶×Øør„·>ú?àý]Ö;o{ˆ²Ž¦v~açP˜<·"Éûé¹e¸iFñò¸©x™.ì9¨dñ»8#T&?S¦ÂÔêUš {:µl:•Ss§´cûŽÕ£w…OÍ2vté?·É{dnúòU^>£ñF@l\ìλü~¡ÊdÙnƒ–_”Qª~#»¦§¸ŠraÏ8m%¯Qÿ²îϼ¡'Ëõ°ý ?ogª¤žòËb´È5wfNÛ'·¯®ðÜ™¹\w–Yoð~÷MÊcù¶×XŽfm—ÃÔ šE_~ê½è¡¯ª@œõÞý®±æ¿Q²ú0y hÒ:÷IPˆò¿$«Ä] ‹ Úv×6-,.XM±Y]Ø3î{qÛÐi|fM õ+Ÿé+¦³ôS~6ü7Kß Í‡¡jG½[¶láSðyAAÛK”ý;Q)Uª)¿ŒG¨Pnl€Ï h/Õ Tnxò‡(ÿëA²<‡  ´*é”ßhcT«5Ö7r-t»ÝÖúÆzjBª{ùÝ>~»ÿ½¨ÎÕŽjµZ.N§£¥ÿ,iëøVjBª)¿{î¾GgÏèÈWGtù—s)ðè £ÿë¸&ö@qUÒ)¿z½®©É)MMN±%@e¥šò@÷ò¨ºXS~­V‹-àó-9l›È£™IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bline.png0000644000175000017500000000026213070106167014735 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑAIDAT×cøÿÿÿ3`øÿ§€áÿ û#?âã@ÜÄòþÙ`øSÿáPíG > Ä ÀnÆÿÍ2‹Àeh£IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/blgndpo.png0000644000175000017500000000030413070106167015266 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑSIDAT× ‰± @`o [Ø@i{ð­V´ÖPèè0Ìk%¿÷yÅår9žÑ9wçœyKgKNiœoIÜ(ª‰bÄëÄ”¿7ÔÖ¨[Qu£+Ù²c,/’IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bframe.png0000644000175000017500000000024313070106167015077 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ2IDAT×cøÿÿ ?`0`xw{Ãûû@üÃóÿ`„ÿC°áâ@u õ }P3´§0¦c6ëIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/windata.png0000644000175000017500000000024213070106167015271 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ1IDAT×ch`0`ØÿÃ^¾ Á ±@¼*¶Ml¿ï*„o``8À ®()(cIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bpreview.png0000644000175000017500000000023313070106167015465 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ*IDAT×cøÿÿÃ…Ð÷ÿoã;ÌîþÆAj@jAú€f»)ª £–ÈIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/wincoord.png0000644000175000017500000000025613070106167015473 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ=IDAT×ch`0`Øÿoâ…P¼Ù(vˆ?ñŸ p5Ûó&0ìú:aïo ÄÛ«!â  H}&©+!¯IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bload.png0000644000175000017500000000027113070106167014725 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑHIDAT×c`ÿÀPÿƒÿ}  ±ÿÿ!¸ÿCÿç 0tZÀÐÐü€¡AkÃU ~îÀðHÿa û]')\2pàrIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/addgraph.png0000644000175000017500000000567713070106167015435 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœtIMEÜ()é/تtEXtCommentCreated with GIMPW IDATxÚíÝ_hÕÇñßì64±RlV*bA¸ÔŠ´±¡j鵕 Þ â[‹øà›OŠ|PñA|Á\D("½Õ…[l±´¶%iLo/Z_ ¥ŠÞ¦l·{â„édfwþ9gv¿XºÙ¤{fΜó›sfg¼N§Ó2«Q* €@ €@@  €@@  P€@P¢UT  ҟ柵k—€C¼N§Ó¡Æ=ú¨ôá‡ùßçÅ¥W_¥>á¦üT* * €@@ù¸õ »ß—^yEšž–®^íþ·¿ý&-.æ/sÍéúë{ÿÝÐôÄÒ3ÏH«W³­@ 8îØ1éÉ'¥“'í/ËääÒ¿o¿-ÝqÛ*@…t:ÒH/¼ ?_~ù›6Io¾)MM±-@ TÜH¯¿.½õ–tù²ùòÖ®•^zii„lhˆú ÐG~üQzöYiß>3ï_«I?.½öš´~=õ  }ñ…ôÔSÒü|qïyÿýÒ;ïH›7S¿p—M˜õÀÒì¬ôÞ{Ò7æ{¯[o•>úH:|˜0§0B(ϯ¿J/¿,½û®Ôj%ÿkÖHÏ?/=÷œ4¤ó?Ÿ—楉ñ ¶ °.×”ßw?|§‘ëFÔn·Uój¥<ÚWÛÑÙïϲõ€;ÊŸò ‡¨à êQáêÒâ%µ¯¶åy^©v§­Ë‹—ÙzÀ ¹¦ü$©Vãî5`°åþ–_Ù£SþÀ©@•uÊOZ¡²ñH¢Ñh¨Ñh¬ø9øZÔß!»3gÎP Ÿ`àäžòóäæhQ£ÑÐ…¿®B|~-îïL,Ç 8wîœÆÆÆød|^àxßXf™ÝØî#ã–/ír­’–¦ü‚÷ò NùõºBºWó*טâ*ÊD˜²ªº­/;‡jµY[; Ûå£:í2 “mÈö~ÁÕýR°OŠ`0©ÓéDg‹§ðôjÃiûÏ\öLRL=²ü|ßþ}ÎtDQ ¨ÈF5­hó¨ ƒ‡©Àš¥£0Q·Ý–£Œ l»|˜ 5El;¿“ô1^aÁð×øÓ~Ewe&ÿAïHú±~{­ŸévÔÎ&ªt!Ìös;H»Þq§0„·S¿ž3jû@Ö…é¬}’éPåJJ³\~$•{Ê/I  ™ø??ü‡—þôÀ§Fw2áó§eGl*,J˜J²0q¤d›wަBMÒ ©N#.ØU ðeïã‚í?ís¡ÁvhqµÍø}´ÉPåÒUÜ>.jý:I²MsOùÕêÝÕþæ~MMNÅvTžçé¡Ý]ó÷e=˜nðáQ„²ËïÕùT1d ÊÈTÒuóÛUQ;ð´aÊT¨J»þ¦·IÜ(ëeYG÷.Mù!yŸÔmT¦èöãêU‘–ÓP8DE½ù nÓ«’ý‡$MMNå~Ï$åîMí£FÆÊ,ßöú¦Ð/PÒ×]ZÆ¢þ¾Ê¡aËOÛ'ù?Cn§Ó)|ù]¾†dxÙ².kþ)¿„ׄ Oû…çûüߟ—,‚å—=z3èå¦â×1íú5J•utªÈ‘›,ÿÐÃuÖöRTG”õ¹Éú°9Šh»|WÃt’ýJ·å«Âç<÷…=“\Õ¼y°ÙsAš›jl¿RzÔÿ Ž’GoL©”Y¾íõ'Lý-¸ÏHûåïGýúš™R™Š+#é% L·ã<í4÷”_½^Oôèer×dâ÷Jò~YnpcÑq‡‡WË.ßöú¦Põ(ªÝE}{Øör&]–A¸+S~ñûÿàI×QÁÊd¨ ´w[Îð£*J»—_Üèˆ_Ñ’ôàέÝË/$llÀA/Ÿ0dï(ÓœÄ_äg)¼OóÜd}ØÜgØ.?i¨ «ðv “¸È¶âŠðòD¾4ƒ ¹§üêµz¢Ç¡/E†°p¨ÚµcW¢÷+²ƒåyTw¤RVù¶×Ÿ0ô·*Nù ò}[ýu q÷¾ þ¾¨¶’$ì›úÒT’þ8kÌ=å—tD)¼`‡^±2~eïüûNc#TáÎ9ªü¢6`Ô‘J™åÛ^ÂT¶m“õ[[EžõóEð­F@èÇ@‘öü“uP•oùE…ª^9Ï:¥é»MÝî*nù{eŒ¤eçžòK{Þ“¿ õz]GމíÔwlßQø9Tq#5¶BÅ —O˜‚ët¯6èB§™å[~EîClMù…G0’þlzÛ¹<å^Îpˆˆ:à.j›e,jš:¼½“,KÚ²ó_س–üšPGÕ¶{¶éèñ£+^ ^VÁ¿°Øöû¶_ó·¦U£Ñˆ,?ÏW_»Ýòm¯ >ͯ_ÂWÚK }%ü¨öÀèT|=¹ ˺üŠ {v»Øj·Ÿù>”á {&½¸§¿O(â>i1ÝnM|+ÿ·üžCå?ŽŸ<ùZÜHɶ{¶~U¸¬¨©Ž¼#5ÁÆÕpM—o{ýû/G·G·ó‚¿+zçlIÖÑÔÎ/î “çVdy_—.[… ‘º0ŠWÆMÅ«taÏ^í¤ˆoÜ¥¡2ù™2¦–G¨ò\ØÓ«Ó©œ˜9¡­[¶.Åø+|b愱£Ëð¹MÁ#sÓ—/äòåH7bãbwÁò»…*“ÛÌv{èU¾+£TÝFvMOq¹raÏ4m¥¬QÿªîÏ‚¡§Èõ°ý ¿`gªäžò+b´È7sjF[Æ·,¯ðÌ©™Rw–EWx·û&•Q¾íõï—£YÛËaêM×˯Âvw=ô êg݃w·k¬…o”lc{˜³&º-Ÿé+¦÷³üS~*þëÓ_÷͇aÐŽz7lØÀ§ àó‚ ‡=¢rª\S~P¡ÚÆÆÆ¨€Ï 0˜ÊOá~=J‘çPT6PeòQëJKë‡K]èÅÅE­^ÍÖNÈu/¿Û6Þ¦ùÿÌ«u¥¥Z­VÊ£ÕjéôOkÓÆMl=à„\S~wßu·NÍŸÒ¡/éÒÿ.•²À#×hãß6jüÎq¶p'Peò«×뚟ÐÄø5 V®)?ð-?@6£~= ïUÒ)¿f³I@öPÈ€~Ø]ÿD§?HÂö~¢IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bcross.png0000644000175000017500000000023713070106167015141 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ.IDAT×cøÿÿïbù ÿø¡l(“]Àð{·Ã0ýÈ‹CÌŸï/–iOMCIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/pointer.png0000644000175000017500000001313413070106167015326 00000000000000‰PNG  IHDRTx4ilMsRGB®ÎébKGDùC» pHYs  šœtIMEÜ &UT utEXtCommentCreated with GIMPW·IDATxÚíÝŒõýÇñ×Þrh0ª¢T”`=ØõR8m¢ ¶$Ò¨(Úh¢˜#1V"jlZÑFLŠ!JD­ˆGz‰Æ‡èý¿~íQ+¶ˆJýqJ…;½;öûÇû;ìîÜìîÌîÎþ|>’ÍìÎÎ}>Ÿùq3ïù|>û™H,‹ Y«aPPPP€€  äªHÄ^•¨×­’·7UPÀ—:6A NmQ¡Æ=e|UÊV°ªÏ?—V­’N;M:î8iòdéòË¥>½l_ŸtÉ%Ò„ ÒøñRK‹´e‹wÓ–ßt¿Ý¾]ZºTŠF¥†iÖ,éᇥ£GG—¡­mtòeóæx™êë¥Ù³¥ûï—FFìû+컦¦ø<ÉÞ75Ùw+V$¯›£¿_ºùfiÆ [DZcíý 7H»vqäPB")=㮡ùôSiáBéÀÑËN˜ ½ù¦4gŽ}þ׿,`øê«Ô9g“n¦>F=$ÝtSð2øY/?ý©ôöÛ£çßstçÒ‘#¶nï¿/­['Ýr‹}¿n´zµtöÙ54ŒÎ¯µUÚ±#»²€‚ò_Cµf=«WKûöI?ü }ù¥ôè£ÒwßI·ß_öî»-il”Þ}W:|ئ¹¥ë˜:UÚºÕjq”n¼Ñæ?öØè2,X uw[º»ís¾ìÜiM,& J¯¿nó7n´é¸qÒ³ÏZíØš5ÒÇÛ:Þu—‹[¶X0ååµ×âÓáa+o¯ôàƒÒ¼y¹”ÿ5T'Ÿ,}öYꔎ?^:tÈÞŸt’5ã½û®Õ9ºº¤ùó³O×)ÓŽÒEÅ—ùæiâDk.üþûä2ôô$r==ñ€$qÕýþÂÎù› ’ž{NÚ¿_Š/SW—üù/‘–/·Z'Ijo—ž~ZZ¶,õönl”vï¶ÀkÖ,ÛNçž+ýêWÒ´i¹”e@5fŒÕ”ø 6œeI®9rÄjk²M×)ÓÀ€õYr=*ÕÖ&/[Wg}•ü”!›€jÕ*é̼œS¾éÓ­vJ’N?]Ú»7^f¯íÝÕ%ýö·Òž=ÉéÖÕIO=%]y%G/%“ߔ)6íë‹7s¹_ŽÉ“mºwor^׃¤ëH ¦$©Æc5œ2ôõ%ÏwN €¼òL5ëV›nÜ(}û­}×ßïö½÷Z0uñÅöúè#iíÚôÛ»©Éj¨°f¿Í›¥ë¯·àóÎ;9r(Ë€ª­Í¦Ë—[GêÁAëãÔÓ#­_oÊ“âM[+WZP00`5.W_[ºA8e¸öZë{40`Ó•+ó³åœ&½I“,ÀûðÃø/öíÜiÔ'L6l°×øñ6oçÎÔé77Û²‡YÇöË.³_6JÖ‘” ÿM~Jço¶òâ,ävAÒM÷Ë;÷wûöYRÕ¥J'Uzn×\#=ñDú´²¾PûöI<"ýîwöÝ#د§M³ ï„Fç—® ²­Múë_9z(þk¨N<Ñ:™ßv›4s¦‹äŒ´r¥ÔÙ_öÔSm¸ƒ¥K­6&•Î?_zòIû¾®.»tƒ˜6ÍʰdIržy&?[nýzéºë¬ÉrìX œ6mJ^fÕ* ¦š›mü(Ç7Ú¼}ûl/´q†õ3s¶É­·ŽÎUêª\µ¶Z-LK‹û÷K<`ÍXçœ3º³5•;åMVuuÒóÏÇû”¹ðŽüòËÒâÅÖÜ6fŒtÊ)6îRg'Á¨(áÕPT‰š‚çØÑa¿Rëè`몬ìß/mÛfS*”o@‰øþ먨¨ÊÂçŸÛ£\N;M:î8iòdéòË¥>½l_ŸtÉ%öÐâñãmD÷-[¼›Ûü¦ëüíöí6ÖV4*54H³fI?,=:º mm£ËÊJáǡڸQZ±ÂžëwÕU9”Üõ0áO?•.”½ì„ ö\¿9sìs‡7I7S¿§‡²Çñ-(i•SCµf=«WÛC‡øAúòKéÑG¥ï¾“n¿=¾ìÝw[ ÓØhf>|ئ¹¥ë˜:UÚºUêï—´‡!KÒc.ÂRw·•¡»Û>€²R95T'Ÿ,}öYêå?^:tÈÞŸt’5ã½û®Õ9ºº¤ùó³O×)ÓŽÒEÅ—ùæiâDk.üþûä2ôô$r==Ò¼yÉe%­rj¨¾ø"ý÷ÿýoüý—_ÚtÖ¬äeÎ:+·t‹%>á›þðÃètgÌH^ÖýPÌ”)6í볚¯—còd›îÝ›œ†Wçõ é:êë][Ùc3;eèëKžïþ ¨ ¦­Í¦Ë—K»vIƒƒÖÇ©§GZ¿>Þ”'I­­6]¹RÚ½[°æ¾«¯Î-Ý œ2\{­ÔÛkeèíµ2€²R9}¨”Î;Ï:ާâ,ävAÒu—)]y÷í³2ô÷gN”´Ê©¡:ñDëd~ÛmÒÌ™ÒØ±öš1Ãj}:;ãËžzª w°t©ÿJçŸoAž$ÕÕe—nÓ¦Y–,I.Ã3ÏpTPfÊ·†*W­­6&TK‹Hû÷K< mØ sŽ´gGð¥®j×|Ç{Ú"uÒ}÷qdߪ÷Y~/¿,-^lÍmcÆH§œ"-[fMxK—rdߪ·†êç?·@Žª¯†ª£Ã†Bèè`窱ìß/mÛfSª2‰ÄǦª¤¼  ÆªŽMP$Œ‚@Å †*ˆÍ›ã56õõÒìÙÒý÷K##öýŠö]SS|ždì»+lž»æ§¿_ºùf½¡!>û 7Ø3ýèë³÷&Øp--Ò–-Ù­‹SÆÄ÷^µU~Ò ÒÅ íÉ'c1ɦÅKþçžkë~Ýs}øp,6{¶Í[·.þw<`óÎ>;;rÄæ9ë¸øbï´ÝË¥òñDZX4ê?Lë’XÆ\Ó ÂQCÄÎñapPzýu›¿q£MÇ“ž}Öj‡Ö¬‘>þØ‚|×]Vk´e‹Õ>yyíµøtxX:|Xêí•|Pš7/sÙî¾Ûö¼`ÔÝmßÝmŸ³Y‹¶“ß;¯ éPá¨üV¯–Î8C:î8kÞZ´È¾û÷¿ãËu–ô§?IGŽH×]']½½ß°ÁšðR™9Ó¦K—JÍÍÒ¯-mß.]v™ÔÕ•¹|¯¼bÓ ¤¹s-¸›;Wzì±ì×%_Û*H’n¹EZ·Núè#ih(ù»ááäÏW^)M›&µ·ÛëôÓ¥+®HŸþŸÿ,Í™#}÷õ™zþyéöÛ¥3Ï”ž~:sù¾øÂ¦î Í+ˆ ².ùÚ&PA[·ÚtãFéÛo­‰«¿ß{Ù{ﵦ¾‹/¶×GIkצO¿©IÚ½[:pÀšý6o¶Ú­áaéÎ;3—oòd›öõ%Ïwº.ùÚ&PáX ̤IÖ´õá‡ñ_ì%Ú¹Sºçë3µaƒ½Æ·y;w¦N¿¹Ù–=tHZ¸Ðšúœ‡4úiæòµ¶ÚôÚk­ïÕÀ€MW®Ì~]$éøãmÚÕ5ºÿTt¨`ŒCå×/~!=ñ„t饩—9tÈšû†‡­FêÔSmþÚµÒM7Ùw½½Ò 'ŒþÛÎN{y¹ðÂÌå»ë.éÅ¥wÞ±¾S¹®‹cæLKsþüø<'° ’Œ*¿Ö¯·NæS¦ØQÒ¦MÉˬZeM}ÍÍ6~”ãÆmÞ¾}¶Œ—ÎNéšk¬ƒ÷˜1ñq¨n½ut>^¦M“Þ|SZ²ÄjÄ¢Qéüó¥gžÉn]¿ÿ½4}º÷héAÒ ‚El¸¡ڸњ…ž|RºêªÂ¯q±ó‡*****NG‡ÔÖfÓjÌ*älÿ~iÛ6›VcþP€€ €€ €€ €€ TTTT>ÄbÒ³Ïæo9ò/¯ü  Êƒ§ž’®¸BºãŽôËÝq‡-÷ÔSä_Iù@@•Ë—K—\"­]+=þ¸÷2?.ÝwŸ-÷›ß%å@•¨ 5õÚZiófé‚ ¤U«¤ý(ùûíۥ믗,°åjkÉ¿’ò J„ß)}Ü8饗ìb~ùåROÍïî¶f¦SN±ïÇ#ÿJÌ€*‰Åb±‚äô÷¿KÍÍR|Þ¤IÒ[oI3f¥ç@+ܰ 3gJ/¼<ï… w1'ÿâæUž,Z$=ú¨½ÿä–‘å@…*\“_¢÷Þ“Î9§xkMþÅÍ€J ¨6mÚ[¶l™úûÖü¿I“&é믿>ö¹½½-àR'IýýýÇ‚§Ä *ñó¤I“ÔÚÚÊp9Ö‡ÊDyÍ@Š€jâĉI3à)1°€·@M~îZª‘‘u÷vkï?÷jpp° ®¯¯×Œé34÷'sUËÈÞ T*'xrQîùnݽÝúü?ŸkʉS44{]NM~ÿøç?Ô0®A###ª‰Ôä5rtD õ Úûá^ö(€ÊiòsQ‰Ô½‚«ÁQ$)èk$6¢ï¿gS“Ÿ$ÕÔÔ°@UËùW~…®r^%PeÛä'Y U1^~D£QE£ÑQŸçy-‡ì½ÿþûl€ÿp¼Tœ›ü"*ÍÚ¢h4ª¯¾újÔ{÷¼TË…QŽjðÉ'ŸhöìÙügü¿ —b\“2UXû™ª|AËU'Y“_â³ü›ü2©)¯æ7gÃym¨0‚©bUéÖ·TCÀêõÏ^Èu.vþ(Ÿã2ˆ0¡bŸJõ¼”xMòª`S,óŽ!ŠØ…'Ó1ôú™ÓÀž~6Æ/Û~yìýs/=W2"¯(Ÿ•W³b1ï *1ð+`ÍæBƶMWŽBÊÅÎá5ùØwÎE2‰~_nç…rº‘r¬D£QÅb1E"‘PËëìóTU1·G¦`Ïï¾ÌýW~‘_ÿt‘H$)¸z~Ûó¡o°Äà)Õ…ÀiöË÷Å¡‘µ_H*qûfZ¿°OÚ^'¯‹`)³•|]ïT]Üû©RûŒûF¶n¤³½&…T•J ¤\Î6ñ+ç&??Uâ‰óù²¥—ûüâË/†z’q÷Ÿª–qXÁbµS~NaÜiûÙg‰'ǰ‚¿'À°.©€båÀú—xü}_Œ ¡ØAK©3Î5:Ì ª”j¨Rã¼Êèl?û4ç&¿šÚôÕKí/©­µ-å…*‰èÒ%—&-_¨»‡°xw-B¡óÏtñ)Ç «Zj¦ü®›s\åë4˜ +¨ ºþaï“Tµ@¥~¡,ÔÝ})5ùÁÿ5)]­L¾ŸR­¡Ê§cÑ;ˆòšï™€ÇÅdÚÈÎK’ÚZÛrNÓO~‰w÷a½jÆ ™±×Ÿ` •rò;¿”ʘ¯åË9h¨Æüƒ^“œÏ‰An,Ë{ùKy IwÙ²-kîM~>Ç„r7û¹¿s¼ò·W X$æ_èÚ›jÏŸ`*õ:]¿|ÕRe[;•Ïš›lþ¾Úƒël—|]ˆ²}æö(f-b±ó/Õ`ÚÏy%]ùÊáÿ<ç=ýŒjÞÞÑž± ííjïh}¤t¯¿M¬%K¬½ ãN¥ù{ý ¦€Ê–xÎú…?:Ûß«eÂ]KV-Pª<üaöqœËqšs“_mm­¯W&­‹[}§å'½l"ÜÄ ·»zµÐù{ý ¦Pî ¯ãÎë×ÃÅ.§ß²TÃS!hòK}þOìtíX…T¹oÚÓ•Óý*{–_ªÚgCKÒ…?»°hÏòK $б«=‚) û eNüùü_rŸßƒ¼s{óœQìüýUîÀʽ_Ý¿$Îç±R*Üåñ ø‚T2äÜäW[Sëëõêë¯zaî jñ‹}¥—Ϙ˜>ï*RÝ©*ÿb¯?ÁPÙʱɯšŸÛꬻW ‘êÙ·‰ßçëXñì‡õ£)?×ãlÀœ›üüÖ(¹ öÚ¯ZgcÿlÑÏB«¡r_œ½òÏ×ôºS)dþÅ^‚©ìöM¶¿ÚÊW‡ðlÿ¿|Ë#@¨Ä€"hÿ›0·A¹üÊÏ+¨Ê0ç²NA®Ýa=î*Uù3Å~óιÉ/h¿'§ µµµz£ó”õ Z.È{ªT55Å *ª=‚)”ú:Ó1X Íl~å—ÏsH±šüÜ5~?‡½ïJ¹ÉÏ]Nwáuï}–míd¾š©ÝûÛOY‚æûÀž5þÇ„zëí·Ô|n³Þzû­Qó‡Upk9¯%iÙ°ªh4ê™.?}M÷¸›Bä_ìõÏÇä„W)ÁWÐ!ò=¾×ñ@íTêíTêAa¡†_)ÆÀžé[M÷¹šŸCéØÓïàžÎ9!7ð~™°Û0~€•û¯ü|ö¡r^o¿ó¶ç¼T5%Íç6罕;/¯¦Ž\kjV¯7ìü‹½þ• ?ŽHÜéú$~—ï“OâñàgÃ:ù¥êCfߊlÒ-¥rËa ÒR¨Å+ÄCÅËi`ÏLÇI>~q¤†*Ìÿ©°‚©c5T¹ ì©ÉÏEeW×.-lZxì.ÆYá]]»B»»t÷mJ¼3{ø‚jΟZŽ`5 Åì.1ÿtAU˜û¬ØÇC¦üK¥–*]ÍnØM\¥2°gc¥Pµþåz>K zò¹Åþ…_â5.¬ã ç&¿|Ô9ºzºÔ4·éØ wõtôd™ï žî¹I…È¿Øë_)w³Å.GX4K=ÿrØï¥ôUë 7géïtc¬¹”\Œýæb˜êœ7^A”{¾—|uwôîéUãœFõîé-j›¯=ƒ¦ÅcÀEà6̤tå {ÄôJ–{“_~÷{»+柡Úîz§NÊÀÿ Jôxñs~ç&*‡€*§&¿<×P¡¼Íž=›ðÿŽ—ê ¨œàÉD¹ç{Ég*€² ¨²mòk¨oÐÐðêÇִЃƒƒ[?–½JBNÏòûñôkÏÿìÑÐðjjj òÒ{ÿûžÎœ~&{”„œšüæýdžzöôèÕ×_ÕÀ‘‚¸a\ƒ¦Ÿ>]sçÌeï€Ò ¨²mò«­­Õü¹ó5î|¶$¨Z95ù Ïò¨všüÚÛÛÙb.ÿ˜¥,Kž+üIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/eval.png0000644000175000017500000000565313070106167014604 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿ3'|ó pHYs  šœtIMEÜ. ƒv›ýtEXtCommentCreated with GIMPW IDATxÚíÝOˆUÇñ_ugH‘`¦%‹–1"š1CtCÖD" doñàÍ“âDă¢‚âUD"Ùhà ‰I˜É8³Y4®x D”dTtÓ¡Óé= 5TjªºëÏ{õ§ëû&==“~U¯^×ûÕ{ÕUN¯×ë ‰Õ¨ €@@  €@@  P€@@  P¨@ ÈÐ:ª¤²¼,ýùgú÷Ù¸qåQBN¯×ëÑ@b=&}ôQú÷yé%éµ×JYLù¨T*T* *€ìqë°Öï¿K¯¾*ÍÎJ×®õÿÛß~“ÚíôenØ Ýxãà¿‘ž|RzöYiýz(¸'¤§ž’NŸÎY¦§Wþ}çéÎ; UM*Ð_¯'}ø¡ôâ‹Ò… Ù—¿u«ôÖ[ÒÌLa«ˆ@¢ùãé7¤·ß–®\±_ÞÆÒË/¯ŒŒºjT ž”ž{N:pÀÎû×jÒOH¯¿.mÞ\Š*!P€d¾üRzúiiqÑÜ{Þ¿ôî»Ò¶m¥ª .›’yài~^zÿ}鿛ӽ×m·I,=Zº0%1BLøõWé•W¤÷Þ“:èÿoÃ酤矗Ү> ˜óí·Ò3ÏHŸ> 8Ò£Jo¾)ÝzkéW›@Ì;th%X}÷ÝÚßíØ±ržÔ}÷ Íêr0oß>iiiå 7Ý´òÚ-·H| }ýõP…)‰*`Û/¿HŸ|"=þx´[˨ªgÝìì¬öï߯ååå5¿Ó¥K—VnµZÔ€?PIÒòòòjxò†(ïÏcccšvoJ€U«'¥ûCTÐë T›6mºîE7¢ ?_¥©É)¶ È]ª)¿ïø^£7ŒªÛíªæÔ2yt¯u5ÚÕ¹ÿžcë€â*wÊÏ¢¼'¨…«ËíËê^ëÊqœLÝ^WWÚWØz RMùIR­ÆÝk@µ¥þ–_Ö£Sî P*锟´2B•Ç#Šf³©f³¹ægïkA‡äΞ=K%|^@{©œÔS~ŽŠ9ZÔl6uñâÅ5Ïý¯…ý娂óçÏkbb‚OÀçl/yôIƒ,òî#Ö/îr­“V¦ü¼÷òóNù ºBºS+×ô›[qAe#Låªú­ï0¨B` ú°g¹Îy—ò´Ë8l¶¡¼÷ EÝ/yû¤ ›z½^p†ÈñžAm8nÿ™êžQ*ã‘™GVŸ8x 0QP2Ù¨‚¦ó<*Æàa+°&é(lÔm¿åÈ"(ç]>ì†ÛÎí$ljý¼lû…2HÇi+ÍfS½^OŽãX]^w›‡«<ëcPØ‹º-ÓËÏ©EúÐ9Žs]¸úôŸŸZ¯0ox ëÜi?ÓC–É¿êÉ0Öï õ³½ÓÚÙu‚E³ÃÜâ®wØ) þí4¬çŒæ} [„é¤}’íPU” g¹Ü:‰*õ”_”@å=2q~ø¯þü١ϬîdüçOUeGl+,V%LEÙØ8ÒŽ²Í¼;G[¡&êÐV§òe ðYïã¼í?îó$ifz&õ{F)Ï{tok‡42–eùy¯?a ÃÒE}½HËhêï˪X~Ü>ÉýÙr{½žñå/ò5$ýË–tYÓOùE¼&”ÚÏÿ;×ÿú"³`á-?ëÑ›ª—O˜ _Ǹëgj”*éè”É‘›$ÿ¿êá:i{1Õ%}n³>òEÌ»ü¢†é(û•~ËW†Ïyê {F¹ªyëpkà‚´·Ô:ܲ~¥ô ÿë%óŽÞØ8Rɲü¼×Ÿ0 7ï>#îsd¿uë?hfÂ?Jek(¬Œ¨—0°ÝŽÓ´ÓÔS~õz=Òcé½Ó‘ß+Êû%I¸Þm¢ãö¯f]~ÞëO˜BÙ;  vôíá¼—3ê²Tá®Lù…ïÿ½']+›¡ÊÐÞo9ý²Èì^~a£#nEKÒƒ{Ìí^~Þ ‘Ǭzù„) yGç$~“Ÿ%ÿþ=Îs›õ‘ç>#ïò£†*°òoWÿ7‰M¶•¢ð/OPà‹3Èzʯ^«GzùêH`󇪽»÷Fz?“•è-ßäQEØ‘JVåç½þ„)`¸•qʯÊ÷mu×=(H„ÝûÖû{Sm%JØ·õ¥©(ýqÒ˜zÊ/ꈒÁŽ;ºfeÜÊÞó÷=ÖF¨üsPù¦6`БJ–åç½þ„©dÛ&é·¶LžôóEð-G@Æ@÷ü›uP–où…ªA9Í:Åé»mÝî*lùeŒ¨e§žò‹{Þ“» õz]ÇN íÔwïÚmüª°‘š¼BEÕË'L¡èô 6X„N3É·üLîCòšòó`DýÙö¶+ò”Ÿ9ý!"è€ÛÔ6K::ijšÚ¿½£,KܲÓ_سýšPÇO×Î{wêøÉãk^ó^VÁ½°Ø®¿íºîom5ªf³X~š¯¾ö»ÝMåç½þ&|œÞ°„¯¸—@0}%ü öÀèTx==fuù•<.ìÙïb«ý~®ò}(ýöŒzqOwŸ`â>j±Ýnm|+ý·ü"žCå>Nž>øZØHÉÎ{w?‡Ê_VÐTGÚ‘oc j¸¶ËÏ{ý‡A_Žðn~çxgzçãmQÖÑÖÎ/ì ›çV$yß"] · "-Â(^7/Ó…=µ߸‹3Beó3e+L­ŽP¥¹°§S3Ó©œš;¥Ûw¬Ÿ+|j£Kÿ¹MÞ#sÛ—/¨rùŒrÄÉãbwÞòû…*›Û,ïö0¨ü¢ŒRõÙµ=ÅU” {Æi+Yú—uæ =&×#ïoøyû8[í õ”Ÿ‰Ñ"×Ü™9mŸÜ¾ºÂsgæ2ÝYš®ð~÷MÊ¢ü¼×XŽfó^['h½ü2l÷¢‡¾ªqpÖ?x÷»ÆšÿFÉyl›Š6­sŸ…(ÿëAL îZX\ж»¶iaq!×kêžqß‹Û&€Nà3kó©ßòÙ¾bú0K?åg¡â¿Yúfh> U;êݲe Ÿ*€Ï Ú^¢ìß9ˆJ¨RMù¡B¹MLLP ŸÐ^ª¨ÜðäQþ׃˜<‡  ´*é”ßhcT«5Ö72]èv»­õõl=P©îåwûøíZü÷¢:W;ªÕj™<:Ž–þ³¤­ã[Ùz RMùÝs÷=:³xFG¾:¢Ëÿ»œÉÞ0ªñ¿Žkò®I¶(N J:åW¯×559¥©É)jTVª)?¸—@ÕÅšòkµZÔ€Ïÿ$V9l/>lIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bmark.png0000644000175000017500000000024513070106167014741 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ4IDAT×cøÿÿ³`øÃøáÇ Ÿ0 vpAg£;*ÑIDAT×cøÿÿ `(ãÏÿˆÇ0=P3]Û.R#ÞsIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/math.png0000644000175000017500000001270513070106167014602 00000000000000‰PNG  IHDRTPFtbKGDùC» pHYs  šœtIMEÞ %$ó«zNtEXtCommentCreated with GIMPW-IDATxÚíy|噀Ÿd[¶äK¾â8qâ8qî’p%. -GÙ–m¡Øî²ÐîÑ(´Ûe¡zý¶Ð²½è¶]Z Ð¥åjI( WHHœ„æ>|ÄÎáøŒ%[¶¬¹öYŠíØ9lÙ²Éûüâß(#YóÍ3ïû]RlÛ¶A†Œ*E ‚ BA¡ ‚ ˆPAª ‚UA„*‚ BAD¨‚ "TA„1&E Â9q‚Á¡¿×ù£(2—_„!sóÍðÌ3CŸ¯~XR~A„óª ‚UA„*‚ BAD¨‚ "TAª ‚UA¡ ‚ $™z*BÿðÍoÂêÕ`Y§­ß¡ÐÐ?35ÒÒÎü:§>ÿy¸ûnHJ¡ ‚0Fظ¾øEز%ñDzredûØc0}ºD¨‚ ŒAl~óøÚ× ®nä?êTøþ÷áê«%åáCB{;|ë[ðè£ÐÕ5üŸçõÂý÷G"d§sÔU„s§ºî¹^xaxÞ_UásŸƒGÜÜ1S,"TAÏúõð¥/ÁŽñ{ÏË.ƒþæÍsÅ!æA<+VÀ¶mðÓŸ‚Ï7´÷š8~û[xë­1)S‰PAˆ­­ðoÀ º~ö¿—š ÷Ý_ù $'é"¡ ‚_ö탻kÏ`nº ¾û](,üPüé"TA†‡5k"bÝ¿ÿÔç.¼0ÒNºdɇêO–6TA†‡~vîŒ ±ÊȈì+(€'Ÿ„M›>t2•U„‘¡±žn¹å즖ŠPAÎo$åAˆÚ³Ï>Ë7ÞHKKË)OfeeõÚ¿nÝ:)1A„„ ÐÒÒ“gO‰öÝ¿2ºÒ‹ ‚0pÊßW¢ýíAÎ Ôží)ϾûA„3µgTÚ7:ío¿ ‚ )¿ ‚¤ü‚ ’ò ‚ HÊ/)¿ ‚¤ü‚ ’ò ‚ Œ]´Rþ¾©þ¹¦üa=Ìá#5457`&`]‡Å¶m4M#%ÙMZª×KNv.ª¿¥6nÜÈÒ¥KÏ‹“XÛº‹gþú$ki||ÆÝLÊœ÷Ï8ŸÊó|EÎqœ„ÚwÎ~Ï”°m§5µÕø²},œA¿¢4MÝ0‡»8Vw”›ßarq)ùy(Š2ä?,|èN–mÛT×äDë‰^ûŸ®ý×\úYÞ9úžxç.®Íûš¦aÛ‘›˜/ÓGIÉ´!•뇱<9ÇÃ"Ô³Ë.r­o¨ãÂEKu…°,˲"?¶…e™`ƒªª$¹’(™TÊäâ)ìÚ³ƒ÷Þ‡ ,Áår%´`¶l}—·ßþºqêwã$'§°êÊOP6möˆÊ´êÐA¼é^fÍœ‡CUQEQøÑ¯Ž1%wU®µlØ¿ƒ…ó“••‰mÛ˜¦Å‘c5ì?¸—i¥Óãr³*ÙÙÙ477‰ d,ëh)¯Á2œåVÓtà;›ÞÓ¿ßÔ{Ñ’âÿõÔÖò뺢(†ŽmÛX¶‰˜¬ÈÖ²,tC§³«¿ßO®/Ÿùs’îÍàýò÷¸hñ¥8Ž„UŒ7ß\ÃÅ_†ªª'oÝ7†P(ÄÚuÏ“•é#7·`Dާº¦‚_yyºŽ©*¨ªÚ+úª2l'55³»¬ ŠÐT}ö0}ÚÌQqÁQeggCyù°ë­ÿx;uÇëãò^é^Oÿï¯HJJJh&u®(Š2lån?HíÆë™qÅ‹¸3gÓXùkš>Jþ¬ïŒ”ß4#í¦–eQ¼žpX?íkwíÚŲ˖Q2y m[¶nbñ%,¢ …º°m›ƒ»OyÎãÉ`„b~ýôXy4ÍɲKW²pÁÅq9žæ–&ÆG ­‡CCsh84 íä=1†Ãá@QUË´L‚m¤¸ÝÔ7O¨PûF/=/ ÓE6‰oT¦À°Jµ±©‰`0Èíÿ¦OŸÁ¬³õ>ì§|{9k_[OMía¦–NIèÍè\®Ûá\ã>*ÓYW¾BJúT,³…ÌÂË9´ý¡áêp¤ü¦i`wVN®/vwLE¬îʶ-üí­Ø¶¢(Ìž=—æ-465’›“› a˜&~+á®ð©xWO%%S°M³»#}[v$ŠÕu¿¼¹&nBµ,‹$W2U‡*Q»S}EQQÔS+nõ¡*m­˜¦‹¬‹'NƲ¬„^d=åÙSNgJG:ší%S€E‹†Mª55µ`Û¦iìhçÛßý6­'Zü¿ßÇãAUU223¸ç®{°Ë´ðeeq¨¦&áBŠRQ”3n‡W¦gæGž'ÙS„ÑùŠ#ƒ–ïâ)¸zX>sØR~Óˆ´“Z¶Ec}ú¾§»«#Ì‹/½HVV&—]ºŒ¢Â"ŽÕM˜PM䥥™ŽŽNšš:hl œQJªª’“ãÅçKE×Ãq;˲PUC7(,,ÄétÆ"Õ¾äåä‘•‰®ë„B!ŽÕÃ0Ì„ u0mhCi“‹§L‡KªÕ55dg¥cÛ6.§“ªêJš›˜?Û·pÊ6¬X„Ãa4M£¹©™†ÆzœN–e‘žî¡ªºšó¨Lg\ñ4)Þ"Œà›¨Z.­Ç^§ró€mq¢úúý]Wê$R2á)¸OþÇFIʽxm›ìœÌ^w-ÛzD«î´dê×S]]Í /üžK.½”òm›™3{^b"Tౡp¸+’š5xæ©Õ8úXßÈü3Ÿ½ wŠWY–…¢ª†Ã¡¡ DnXý|F -€CSÑ ]×éèìÀ4Q/ÔÑÒf:LY´(îóÁŠ r|Ù˜¦‰CSi>áˆÉ³ïÖét2gÎ.ZÀ´iSq:8NÚÛÚ°,“¬Ì *ªªFEyF£Ï3mã.Ó`‡Þ»žY—ÿ‚O!áÀËh) p¸¦‘=aÝtËÀQ56f¸™P[%•›î£½ámòg=Œ¢:ò›±ljhî‹zzÒ½,_¾œÎPÕßߋ̡¶¶¶öšÃ¡qâÄé/¤ÌÌl,Ë¢££Õ¡ÆU¨ªê‘¶Ýürë—q;½,›tã)¯-o|‘ÍûŸÃãÌayÞí¨Ù£X¨}å4ÒQé¹È4Þ͇âÊ,òLœIN¦”–pÿ_°]QU¨}šy SGsi¸’\äºSy÷½-£"ÝO5[î$»èB’=ytùŸ«‹°~–Q»âDÕ INÊìU¯p胇9²ýnŠ>žà”ß<)P_NöÉ.èžÞ©ÚØÑÛii|>ŠâH؉1M½ŸŽ´òí›Oû{sùUèa‡K‹{ʯëÏîx€‹W‘äJæÍí¿<åµÊkÜzÕ]l<þ[ÞØþs–(ÿŒª¨c"BíO¦ÃÝ~z®2ç1­;Nii Ìž1H#[×!%%…V¿Ã0Ð4-aç1}öl'=Ýãx2aÑÏ8øÖ5¤¥ÿœÌüŒðN´”Åh)s1»öŸáN`aÛèmëP›)ž÷U¶¼¼’ŽÖ¸3fŸP‡%å7ŒHÁ¢ÐØØtJ„êÐäæúz‹Ö>v£@XïJX…0 úy²hþ…çPñMùU%Ò†jX:Á Lt—qÓe÷òξc¯»dÎ*.+û$û:×Ñaø±­$:»:q:c.剎¨DÊ@×uvìÜEcCy¹ùCê¦M›H÷fDêËyüíðIi“™rÙKì[-S\AfÞxÂíÀ‘4P(™÷_¾ ÛîÿZp8dåM¦léW±ôrŒÎ÷™ºø>ªvÿ„ÉK~:R~ÈÉóEÚü%âÏè¶ûqo¡FâU%Ò±• LÓĶ{Þ¹D¨}£ôxE¨¡Pˆéöu¬ßüþéÍ´׳xÚõ±×eMpRÞþU5Ôîmavð6l'8®1!ÔÑЛ?R2Fgû÷¤¾þ8W´†$Ô}ûîMOhºÝ_Ê6ãM²§”©Ë_aï×2má²r‹ÖwÎÃ,\õ•»ßeÊÒŸzÝëíÛû8 ‡wS0iá¶—Hɸ“`ëÏ›òÝ2qt·*JT¨ ‘ݦŠü7êÒ^¡j<…4˜6TºÕ=ùíííL?é´bª««#êÜq½!X–…a\°hº1—™- xj×=øOü•ŽY­ø’&Ъæàž#˜|²àûä¸'’—›;f"Ôž)ÿpÊ5;;›ò'`Q!™Fi ‡uRSSÑ4…óG. µwöÖŸÞX¿ŽŒÌHTªíÁà¨8‰Lù£¤xK™~Å+ì|ýZ¦/˜EvÎT:›ÿ-uß BM#·äV*6ÞÈøi×cuÜêù4m'ôòÁȧü¦‘¥ê ¾®žpøì†9EŠzI9QjOººÂ8¸—·ßYÇ¡CÝMý¶áLH®ËÉ>øo‘±µ³æóÉOÜ6x¡š†iPQYÁ† 8rô(*Kñnb«/%3`CåÞ£˜•…$WÏc-oQRRÂåËWP\÷sfNŸÁõ×Ý€Ó™Ô+šî{—=¹²TTì¡©¥uȪiØŠÅ⥲8ö̧ºï‚‘Íò| è1Ÿ@·Â±:ŸSþ¥:BÇdÛ6i©nŽ­'=Í ”NžÈ²+ðǸ¢ìfŽÒ|·ÛKqqÉÐ#TÓÀïÐÕÕEWWÕÕUTVU2¥¤”ââb€û¦P\¹1ùýtCÇ2Çn8bR½cädª( ùùùÜñ¹Ûøå“¿¦´¤˜@ ÔT7éÉ鸲Ýã¨lÚ†nv’“VÄ–Ú54³²ìvÜ)Étvv2ibµ5µ|lÕ*f͜Ʉ¢¢„ŒÝËØV#¶Q…epj©Xê2Êß\MÆøO“U¸ìì…:\)4>\{䔩§±H´GLD jYÙÊ·¾Ëò˰±b²<)LzI6:óë¤L{ x÷î=ÜòÙ;‡|\ÑN)¿ßÛWYUÅŸ¾™gV?ÅŽ;bûÿî†Oñ‹¿ï!T?ºNx„Ú³Ãi0ƒ÷ã-ÕEwD$ÚŸTG¢éAQ<¥¥¥„õ0%%“ùóŸ×£9{t.Môœ\0|Eñ­±ç[[L_UÆëo¼ÉÒ%K˜5k©©© _¦q4¥ügCWØöàP Á°èôïdÛÛO”u%Sçü º®Ç²À„¤ü D ¬¿6TP0-“S¢ö(ã‘m›²²™<÷Ü“¤º5Š‹'½#éèãÈq[1qF†YÙÝ‹\DæÍoÛ¶ƒ´Ô Š‹K†¼D$B5 øO.\6m:¾ìnÿ‡;èê Åö···õ’gÀ)ÿ@‹£œ­ˆ‡Cr=#ÒD´ã:E¡©±‰ãuG9T]ÍíwÞNZšgàò¸ø ¨ªƒÃo<ÊÑ#‡Ù»gm?šÓ‰Ûí5éþXÂßROýáÍ´Ö@(X‡m;ÈœüY‹±í³Ÿ`4,)¿®ë²s×æÌž;¨>Xq€\_ndŽóUÛ¶q84–/¿Š?þñwüå/†ô~ii^n¸á–˜l[Ñ»§¾:zE¨íÁv^{ýOìÝ·‡P(Ôë"8qâÉÊâ÷Ç$ߨØHNNΘ«ðñ–ÜhZ‹Õ4MB¼½a mmíºIWóÙ7š;úưm‹p¸‹ö¶v6lÚJ¨3„q†ˆFê<%bêðPñåÏ$+w:º®‡1MMÓp¹\8γ¾vãžòÛ¶Mss3iî4^{mÏ<ût¤w::h¿GO~l{.²U…œœ\Š'L¢¾¾žÂÂÂiR…¤¤$–,¹˜œœü!uvFF¥¥¥$%% é®ÝÔÔ„æÐX³öUü="Ô‰& ™?o~Ÿ¿C%5ÕÝC¨^~å%\NMMM ê¹Êìþb~rr2Š;?ØŽ¢ªlz¿ü¬ëKggû÷ìÆårŠT,Ÿ/UUIJJÒâÜqOùE!++‹²²éL™R:ät(77wÄØEAÓ4²²²ðz½CN‘UUEÓ44MRE÷ù|ÆTlÛ¦¼|+<øà9ý¾×ëeþÜE(Š‚ÏçC=D;¦~ôøãÔÖÖbšæ9Õ÷è ºñãÇ3~üxéŒJ0Ã’ò»\.ŠŠŠâv× ^¯wП]m´´)åääÄ¢ÊïÍù¯„T”Á–§pæºáõzYºt) ,ôׇ¸\.RRR†T×äÇá|®^½Ú^¹r倩ý`{ùAÎ7ÔRþþö ‚ gjOöMùA„sjϨ´otÚß~AAR~AIùA$åA”_R~AIùAÀÿÝÆà°u¸IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bpoint.png0000644000175000017500000000027613070106167015144 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑMIDAT×̱ €0 ÑÛ„hÙ*£0ÛPÐEì@á2_JA€1O×îⳄ5äN”94a›ØK0Q«8‡0‰#'nëñ:â-z%üù?/<Ã3ÀÎ2IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/barc.png0000644000175000017500000000024513070106167014554 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ4IDAT×cøÿÿ³`øÃøáÇ Ÿÿ0<ÿoÆçÿOÀÀ09:z>~ 9~ù/ArF%åIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bscundo.png0000644000175000017500000000201013070106167015272 00000000000000‰PNG  IHDRàw=øsBIT|dˆ pHYs × ×B(›xtEXtSoftwarewww.inkscape.org›î<tEXtTitleOptical Drive>gº fIDATH‰Õ•h”uÇ_ßçyînÏ.7g?¶±öÏÖô²¦ábè 7+)ˆ,A%ƒÈ¬ÿªá?FZ`mؼ­I KœnkM9ŒÆŽZN—ìæÚmóvçþpÝnνáó×÷ÃûýùýU"Âí„v[Ùÿ c®‡®FU*Š÷µä%¼·¦V¢ V‘YÖõ%®F}0>Ü-Žhä3élä“L¾óÙ¬ýÒ hzÛÊ Ýþ%÷#nŒ¼¢'@xvÁÑ3£DWȵ¶Ï+ÈZTŒ}9ŒÒø¡[PWÇô*yùÓ­Ù¹÷a'»ÑŒ{:M¤sˆ{#ž> [ß"M³ÚT™¦´ã=ÕRhæ–bM´b˜«Ð½ËæPœô“ñ>úºß&ëÙ›m±=¸U,˜*‘ãp 0°¡0kQ>©ñpS¤­³7YšQD–)åëZè××?Ó ¼<ÁOŸ«2MSÇ—W¾R˜WPŠ=ù+†ù†¹'™'‘$núJÏÛû'›×ºñKÁµ¯Jxº­ûT—¶Ý\—/ödóηHƇ8ñ}-2Gt‡%ù%*w"Ö) óaã NþøÚšm²ezL«·JoÚ¦êLÇ·Ñ‘Áº§˜ÄИþ;®ÛíòuÍ6Q3-³r¢ç#õ~Ã0W‘Ž7c..ÅqxfœŠõuÒëU᎖è߃ýž¥\þ€œ»+qÖdÊ`ã‰[)ö ü~ÝÀMž@“1l—(5kÑÖ×Io:MU¸óh4z!†æ{’èَáL{ö(Ÿ£¨.*©I¸Ö(Ý$kÁu‘Œ·è¹7¥7ô±z,ÜÕ¾iß„"$.»®õ9ø¡*C£¢Ä¼+¸¬²¶¢xùfìÑzîNo_tƒs¬;7#ì#–!;ˆ!#H_œR Ö±láA®ˆËNôé1Ì-œ ØDÖX·èHeÃU/z4”!¹}?ý¾ýuËй…¡ãc®áº;nàp€ã_«ɰé\2”-@l€h¿V-dN”áI ô‹ ‹» Dm>B UHA€Ü «¼fÃ?éZ`JÙ®7IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/infowin.png0000644000175000017500000001574713070106167015333 00000000000000‰PNG  IHDR]P#ƒÀÜsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœtIMEÜ90ÜÛí#tEXtCommentCreated with GIMPWBIDATxÚíÝy|[åïñÏ9ZlÉ–y‰ljÇYÈB6²@! Ð&PJ‡ÛÒJioïeÊôöÞ¶@ép[n§S:´}ÝÒåN§-öR ¡À”µaO “}ñ’8‹ã5–lÙ²Î6ÈRdÅvd[–dò{¿ÈKîÑöôèHç{~Ïsž£X–e!„B!Æ•*«@!„BB—B!„„.!„B!¡K!„BB—B!„„.!„B!¡K!„BB—B!„Ð%„B!¡K!„BB—B!„-»¬!tæ c¼¼ð?!„E.x-D‚n¹}tì¯óïÀ}÷ÉúBˆ Œt/ !„BHèB!„Ð%„B!$t !„BHèB!„Ð%„B!$t !„BHèB!„º„B!$t !„B|XÉe€Ä…Íï‡üGذLsøÇú| Žý=sr 7÷üs8àïþî¼²²ä³B ]B|lÙ_ÿ:lÛ–þ¶¬[¾ýÙÏ`î\ùl„BB—2–? ÷ÜMM©ÿY³à§?…뮓ÏB!$t qèî†ú'xàèëÿ÷Ë˃{ï WÚYÿB!¡Kˆ LCÜu<õÔø¼¾ªÂ—¿ ?ü!”–ÊúB ]B\à6o†o|vïNÞk^qüâ°h‘¬_!„¸@È”BœÏÚµ°s'üú×P\<¶×š6 ÞxC—B\`¤Ò%ÄHtvÂ÷¿¿úhZâÏËÉo¾õ-ÈΖõ(„º„ 9xî¸6n<Ï7L›o†ÿ**d½ !„„.!Ĩ¼øb8|:tî}Ë—‡Çm­\)ëI!„ŒébL®½öì O/QP^V^=[·JàB%•.!’¥µž|n½5±Ëü!„Ð%„B!’ËþØcqÓM7ÑÑÑqÎ^¯wÀòM›6ÉB!„Mèèè般ؠ¿|]äB¼B!„bD¢éãƒÖ`Ë…B!ÄBWlÈŠ XñË…B!ÄBWlu+¾Ê5Ør!„B1ŠÐ XñA+~¹B!„Cè’îE!„Bˆ„.é^B!„HA芬ø ¿\!„BŒ!tI÷¢B!D B—t/ !„BŒ/{lÀŠ ZñÝŠÒ½(DúmÙ²…U«Vúù!-ÄñÇhkoA× À"rùU˲°Ûí¸²ÝäæxðäåQRTŠªªÓþ‰¤±s/þÇwɶçò7ÝÉôÂÅ·=!Û[BWü5c»Ç¶ŠŠŠ’ÖÐööö1¿†´GÚ3Ñùýþ1=ÿXcÅEÅ,]|É aÊ0t4]'êãTÓI¶¼ÿ3ªj(›TŽ¢(io&²,‹†cG8ÓyfÀòG¿Ê'.ÿo|˜ß¾u×Oú>v»Ë ÝâÂbª«gi½~×§Üÿûm4nNÊkåçyxäÿÿ¬¬,ÙÞÒº½öâhXä(z,Eáž{îáþûïOʤ´GÚ3ŠŠ¼qA/óªÃÍ-M,_¶’`_Ó40M3üÏ21M,PU•,gÕÓk˜Q5“½ûwóî{oqÉ’•8δ¶ÛŽ·yóÍ—Ðtíœû²³]¬ÿا˜3{AJWýÑ#äåç1Þ"lªŠ¢((ŠÂ?ÿá3KQïÜÈ;‡v³tñ ¼ÞB,ËÂ0LNœ:Æ¡#˜]37)69åàd"µ5ZÛÚÜö_?Ïܹ1ÿ¢ù£zDZ}×v6¾¼™cÇ™U33-Ÿ]&<‡ ´þ¶wñ”­£xÖÝØ³JÇ'tEV|Њ_ž Š¢$eGšl™Ð®HÒÝ–±ì2ñ³Meв,ˆ¬¾Øû2%€išŽ¢(躆eY˜–®¼˜á[Ó4ÑtÞ¾^|>¥Åe,¾x)ùy¼·ý].]q96›-míýõ¹ì²+PUõl`ìÁ`›žÄ[XLiiyJÚÓp¬–’â&M*G×4 UAUÕUÄÈ·)è&'Ç…Ñ¿®+Ê+±«vÞÏÜÙóÒb&J˜)**‚íÛǽ­™PYŠ8v¬‘òòr,ËÄ0t=ÝÜÿãûé<Ó9äs|>UU)(,à®;îÂR,LäØëåè±ci ]£ÝO(Š2nŸy¨û[nࢫžÆ]¸€Öº?ÒväÊæÿh|B×xu/N‘‘i0Ò®tµ)ò¾±ëe¸¿?ìë#‘À¼b› ÁË0Âã¸LÓ¤ùt3¡6ìc÷îÝËê+VS=c&]~?ÛvleÅ%—¦­2 öaYGj÷sŸÇSÀÔ©Uüñ‘ÿ7ä6b·;X}ù:–.¹,)íiïhcòäÉø»:±ÙìØmvlv;ö³Ç³Q6› EUQLÃ4ôtár»in9ÖÐ_yˆÝ± W•HG8‹.`\ƒW¦U–Ž£È›eY8êêhkmcñâEìÚõÁ9·áï¯I(Ân·ÓÞÖNKk3‡ Ó4ÉÏ÷PßÐû·tÌG×ü=‡+¦ÑAaÅ•Ýõƒñ ]ãÙ½8ÒêNª«=ñ|&¯ÁÂMºJ†ú;•ŸS&|Fñ+Ñç¤;x†ŽÕÿÙ•”‡«\ýƒé#ÿÌþJŒe™øº;£ßÇ .¦ýL­m­”–”¦¥ýºaàóuê úZðx ¨®ž‰eý]¦á*ži…«aš¦ñÚë/&-t™¦I–3›ú£u¨ýÝŠŠ¢¢¨çîPŽÖãïêÄ0Œh…®jÚ LÓLë6°bÌùºR]¸–-·à•i•¥#µµ”a6»Jû@4`Åß:.\ÈÒeK˜={‡‡ÃAwW¦ià-, ¶¾>#öqçËãy€\ü«Ÿ$ÛS‰ÞûŠ­€Žã/à)¿n\Þó‚?{1S‚Ml[âÛ‘®.ÇDß3Æ£dBàR”Á«\™¼ =võjLÓÀ‘å`fM5÷~ï;Cþ>«ª 5.øë††ÝiÇ™å¤ÔÃÛïnãB \]õ®¼JôÀë¨öR:O½BÝûßËäLÃï}®3g:®ÂexÊ?§ìã#]©ì^,P w+Ò¼}¯ñ>‰ø.ÍÌêÎìíȈìà-‹¢’ÂëײÀ‚˜ª—;7›æÓÍ444ðÔSá#—_Îöï³pÁ¢ôTºtÖ–B¡>Z[ý<ú§ Ø 9ñ¾ÏáfÜ.%©!Ç4MUE×ul6; J8Ôòþ.?6»Š¦khšFOo†¡g|èJÿAÎð‹eË’^yË´ÊÒɦÓÔÔTÓÓÛ‹:®r×¾£<ÿÚö9I0¤³ ¦‚µ+/âêËžXr¼ñ.—‹NŸ]×±Ûíiü½TºMzà Ôsôݘå¿âòTò?‹Ýµ›s6ESçséÍ·½/µ쪣në·ény“²ù÷¡¨ŽÄCWªº3q'ÿgrØKG÷küzêït„ÀL _ƒ½u&°ð˜®ðG[K{ÿ\]ÃËÏ+`Íš5ô{°©6|¾Îh…'•®ÎÎΡÇf³sæÌð;ÛÂÂ"LÓ¤§§Õ–¼v›¦‰ª„C׉®}ü~Ç7q;òX=ý¦s»½õiÞ?ôg<ŽÖLº µ§=ƒCW|€Iuuk$+öñÉ^™VYÒ4Ý{öÒÚÒ¤Ҳ¡K× ~~›÷˜R³œšEKÈɲ±¿î4ý.sžx™¯Ý|¹îð þ­[·’ŸWÞ~3dØJªÛv;E•ËÉöL¢Ï÷˜}„´+‘ŠÕ^AvÎ,¬Ž£Ülj]wR¹ô—‰‡®ØêÖxv/fRW^º«H‰œtU•âÃh¢§ûË›Šð5\×âPák°×HWc$t—=µ.v]öW¼,"g„ors=£(¶´}W Ã@dðÿö]ïû¼^yMxçÒ°9“wd Ÿš¦óØîï±vÅz²œÙ¼¾ë÷ç<¶Vy™/^s[N?Ϋ»d¥ò?PuBTº \ã=žk¤+™mJ¤²”¨dT–,ËâС#47Ÿæªnÿ€ö<¾iÛN1}ÙÖÌË£¦ÔFn¶93Ø”ïåTc<ô:ß¼5<©éÁƒ‡ÉÏËψ³õã÷iÃýLS—ý†#o|‚Üü),«FíÁîZÝu1Fß¡ó|&–ÕƒÖµ Åö>U‹þžmÏ®£§sî‚óOW“òîÅøP‘îô­â–Š3Q×{&w;fL¥K×Ãë…ÖÖ¶s*]6»ÒÒâa,š½,P ¤õ¥­ýºn gÝ/[¼|ë ¹Ý‹ªÓ¥›µw˜æžÃÍWÜÍ[ŸŽ>î# ×sÅœOs°w=ºËÌ¢·¯‡Ã1áºS1x>ë|•¥‘JVe©; ÒÈÉÉÁn·³tÑ 9ÅT_u'ÕË£uŸaÃ#O0½ª“\·‹ú#nŠg^§¸’£Ùu¨•Ë—NGÓuº úw0+w3¯x†ƒ›¯gÖ’«(œ4…P÷óزf fóÞ³_²ÿ^Ú¼“f0gÕßcjÛÑ{ßcÖŠoS¿ï_˜±ò׉…®Tw/fêÔ ™p–`"•®TV¸&b`“°uþJ—”L*AR”pÆŠÜÆ–+\÷RPƒñÓØþÁNVH´Ò_íKV¥+ 2×ú$›ßÿ¾¹ítU5³bö ÑÇy§:ØÞý'êÕÒx ƒ/a9ÀápNˆÐ• g)¦*p¯²4Rc­,EžçówaZðÕÿy7º®óóŸ?@«á啃ÙüíœÞ¿‰¿½Ý  ÀÓæbþ-ëøÚ½›°M¾Œ¼Òüâw¿gÓ3~LÓBÓŒè™Ê™ð;Ž3ä³=5ÌZó^½žÙKWâ-­$ÐüMÜ%÷±týϨÛ÷63WýæÜß ­›S~IËñ}”O_B¨ë\·èüMBï›–îÅÁ–¥s ýpa'ã–2%”fÚ<]" •¢þÀaë¥(‘Ð¥þ¯ÿs ÿÏHÞPòJfhy¥ÎèoÇÙjfww7Ó¦LvÒÔÔD0ظ“MÓD×u.Y¶ M¿˜yKøÓÞ»ðùzæwRœ5€¶`GöŸÀh-àÓå?¥Ä=I¥¥¦ÒÛ½8ž¬¨¨ˆí¿…eƒ­®á*KJì@kð!¯nÞDAa¸º5ÖÊ’eY俏9q²™ü\7(P3c«×®åû>aÎÂßÒȕ˦p㊢  ™!¼®r>wm¿{©§Ç‹é,¤«ë4ªªÒè%;+ 5¿Ûéì^ŒpåÕ0÷ªçØóÊõÌ]2Ÿ¢’Yô¶þ€¼²ßÒÑô£!*]¹”V‘Ú-71eö ˜=÷¢z>G×™Ã~›† ]©ê^œ(Ý>Cu^¨2až®ó}.©úÌÚÛ;F5GWük¤µÒ¥€¢Úhnj&Jlú‡ÃNåÔÊÁ-•ºˆ¾¾‡àÍ·6qôh-z÷é`¦NÍÿè9üŸø_á¹Çæ/æÓŸúÒèC—a¢:µuµ¼óÎ;œ8y•Uø*¶²Ãw€ê‹ü`AÝ“ud7,b#oP]]Í•kÖRU5CÎ^ÄÁ+k¸ÊÒ'ÿË'x÷Ø¿Ñ:û¾Y¶\–V\ƒ×UÀ‹_àwþoN'“J “RYúá?|¯ßu7mg|L./Ó—GaA!›‹žî3`èôN =%œéiæÝ£O *º´É{|h–…¢ØðuP»ÍƾwoZ¯.‘)\y5Ì¿ú9v¿|=³ÎaRåUœnxŠÂÉë‡8Ð Ñqj3Õ×ajµ(6Žç°9ŠÏ¸¢¡+UÝ‹™6~°‰Q‡»/UmΔjW¦ÍÓ5ܘ¿ }<àH*E ª¢0¹¢‘ªI&UçR*2iž®D©®D*Eft[j:uš¾¾ÄÅ;f̘ n©¶mÛ®ûø'),ôöGª³ý:¦eÑÛ ¥åÁ`Ot†ýhN´Îž‰Ù4 ŠØ»o?Ÿ¿ùoǺtࣣƒ%‹–’ëñà°;p8œý·á¹{4M럟+„¦ktwu±óƒhš6a+]©˜‘>¼R‡ª,å–u’Åœüå¸J©kÛÅéÞZŠòËp9<âv»)-Q8ÚxbÌ•%EQðx<ÔÔÔÒBTWÏàßÿ}3v›U‹ªùÕãocsºÐ”"¾ùÝ7ùÔG»°ÛËyöµ&:»½XªB^ð0sjŠØÑ¨±jåJæÏŸONNNZ‡…dB÷ —§ŠÙ«~ÂìU?ôþÜ‚*ò½Øl:6««ç¨j–}){Þÿ³.ý×ÄCWª'GÍôñ?C§º ±ë)ÝÀ΄yºÒ<?ê}cÚ/dž­RUL™SáR^Ʀÿïð¶gbZgƒL:ÆtM¯ª!Òðù;è tÇ„( Ó ÿ­ª*.w΀ÀeÅ\ÓŠù?~·;ªªê±Wº ŸÏO__}}}44ÔSW_ÇÌꪪªb–ͤª*^}>?š®a·{1eÁë+© \ÃU–ò³óq;<¹'S×¶Íè¥$·’m/Ò8κ9·áveÓÛÛËôi•4kLJeÉf³¡( m­mœn:Éцn»ý6rs=LÉqp¢×‰-;ÉÓ¦RߦÀ´és8µç8%.k/.ä‰'ÿB·faw8p»ÝÒµ8Ò}²ÙŠ¥×cšGöLu5Û_ß@Á”Ïá­XxèJç䨙>#½uN_•Ì„yºbƒV¦¯ÁšYYEqÁëè@ôðüAñ—ŠV´bÎdŒ†•4†®9s²}ÇÛ¬Y» 3¨Î†*±È ûg×À¶oß~nýÂícnWd ½Ïç‹.««¯ç¦ÏÝ£þÄî=»£Ë?sãgyêé¿Ä„.šJ{¥+vüh&@MvðZö•pÐ,x¥¢›s¸ÊR f@ü4Ïâèßk«¾½¿³ÓÏÜõsxåÕדVY2 ƒ`o/o¾³®®ntÍ /dZ~M×9Ýâ@­ŽoR‡SM­Ð²“ÂJvg9W®¹œ—^ÙL_0˜qûÖL7<œ¾ #äÁ¦T€nÒëÛÃÎ7K–÷cÌZø54M‹V¶Ïºb«[©>{1S«[™ÜÆTv»N´ d*Û¼Î÷[š ëlP¯£ÁÆt‚aœ3QWÌjMõ@z˲˜3gþóCä¸íTUMVä"‡ÛmFÃUxŠ «ÿÂÅáëîܹ›ÜœªªªÇ\yWº ü>ÿÙ€8{.ÅE%Üöß¾B_ßÙ\ww×€€å÷ù3¢{q¨ ^'ÖÆ#ÅV¶RUáJ´²4äú¸ì«¨ªã¯>ÀÉÇ9°?]~_Ò*KÙÙÙ( ìù`Šª²õ½í·Ý¬"zÝåÔµxAµC°Åw˜}'|Zç²nÍr–,ZÈÿð —^ziÆÐO¾Žfš¿OgóMX–Â?Ä[¾ËJ|Âèqï^Ì´•+í‘ö$;xÝ y36hAx\Qyy{öîfá‚‹GµnÔ¦´¸4|MºuOX–…ÍfgÍškøë_ÿ×^{gL¯—››Ç7Þ d£ÝÆZ[[û/CdPéêtóò+/qàà~‚1U›ÍÆ´iÓÎþˆû|Ñ ØÚÚJIIÉ„Û%;¥cÀþH+KCä|õçX–I(ÔGwW7ïlÝA°7ˆ~ž‹Ê'ú;XVVÆ?ÿò—466bF‚]•«©¯¯cÓ‹å…—ºX÷ѵlÙ²•7^ßÌ•W]¶m&—”«â²yxKç¢i¡PÃ0°Ûí8NG¿#ãÚ½ØÞÞÎ=÷Ü“Q?ÒiO*X¦±,‹öövrݹ¼üò&}ì‘ðYw‘‰OcÎPŒÞFï ß*ŠBII)US§ÓÜÜLEEEJÎ~R…¬¬,V®¼Œ’’²1PSSCVVÖ˜B}[[v›7¾€/¦Ò5mêT‹-Žûÿ¡’“㎠]~ž}îœ'mmmi]# <™ÆÃy+KÃèííáÐþ}8Τ XW…¼¼ö D«ªŠÝnÇn·)4¶¶¶rúôi,Ëâ‘ ã÷ûGôü¼¼ vpAg£;*ÑFIDAT×cøÿÿ300üûáïÿ ¿ÿ€ñ÷€˜ˆžÿs`8ÀÐÀÐÀÈÀ°(¶øˆÒ@º(6õ^)…ã22IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bscale.png0000644000175000017500000000025113070106167015073 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ8IDAT×cøÿÿÃw ~ Ä€l††ïvPüˆÅCÔ€iû?Pî¿Ã0 âÍŒÔ/§ÎK LIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bzoom.png0000644000175000017500000000026113070106167014771 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ@IDAT×cøÿÿÃÿÆ ÿ þÔ0üùoÀðóùn„b(ÿPîCàÚCŒŽõžâÇ 3 Û$-UõºèIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/legend.png0000644000175000017500000000603513070106167015106 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿ3'|ó pHYs  šœtIMEÜ+.\fÊtEXtCommentCreated with GIMPW xIDATxÚíÝoˆTåÇñß™qq6e[wÂk$—͈½”›‹uÅ›¦Â‚w‰è]¾ˆÞôªè!TTЋ’^Doc!!‰ðZWRMe×m½{+»ÒA)t5lYǹ/–³Ïž™9ÿžóo¾œ]ç9ç9gžçwžçÌ9V³Ùl ¡•¨ €@@  €@@  P€@@  P¨@ HÐ2ªÈ¹ÙYéÏ?£¿O_ߘÕl6›TcÏ<#}öYô÷yã éw¨O)? €@@  €@@  P€@ÆÆØ@ rîÚ5é½÷¤?”nÜ0_^_Ÿ´gÏÂYOõ* @~ýUzåiÿ~3ï_*IÏ>+½û®´z5õ * À¾ýVzñEiz:¾÷|ôQ飤 ¨_r,J9õØcÒä¤ôÉ'Ò]wE{¯uë¤Ï?—Ž!L@ŒPEpåŠôÖ[ÒÇKóóþÿߊÒk¯I¯¾*U*Ô#¨è§Ÿ¤—^’¾þºÃ'ß’ž~Zzÿ}éž{¨7 PXâàÁ…`õóÏK·iÓÂyR=õÔSš]òË]¾|yñçZ­Fa‰ž¹9í|óMõŸ?Oeœ|î9Û¾ŠŠ¨$ivvv1<9C”óçÚ7G¬«WÕ·gê»wknï^*è üãêÛ¾][·Nƒ´«@!,ž”îQ^¯ E ZµjÕm/Úáɬà-ДŸ{”ªÑhhrjRgÏU½^Od+•Šî¼Oë\.³@6•žÜ!ÊýºÛäÔ¤.þvQ«ÿ²Zó7çYàžr.üvAš–F†GØ‚ u‘¦ü~9÷‹zïèU£ÑPÉ*%òhÜj¨·Ò«³ÿ;ËÖÙ Tö”Ÿ;D9OP÷ W×ë×Õ¸ÕeY‰>͆nÔo°õ@&Dšò“¤R‰»×€îù[~INÙ€Lª°S~ÒÂU?ªÕªªÕê’Ÿ¯yý›™™¡Ÿ.^¼H%€öµ "OùYÊæhQµZÕ¥K—–\¹rEýTl_Óè“: X¤ÝG¶Z¾ ËµLZ˜òsÞËÏ9å×é éV)_ÓovÅyU”‰0•v¨j·¾EÐ ÕëÞä:§]>ò³_arJ»]Èj»ä쓼Lj6›Þ"ÅSx:íÃAûÏHöôSOŽ=¹ø|ÿý™éˆ¼v 8w*¯iÅ4 ŠÍÂtØ>Ét¨ÊJ ²\vøyÊÏO r™Ø??ñÏ'þêàWF÷ùSÝÒ› ‹Ý¦ü4&Ž´ýl3gãh*ÔømMu­@Á />é6ιÿ}žFhH;´duŸ±ûh“¡*K#T­Ú8¯e´ëÄÏ6<åW*·Tj46:Ö²£²,Kïzü¶¿OêèÁôïEHºüNOCV·ŒLù]7{¿Š«¦L…ª ëoz›´ÊzG™ÔÑ}–¦üà¿Oj7*÷þ“Õª8-¦!wˆòzÝó |Ü.¦S%ÛI‹üž~ÊsÝ›j½FÆ’,?íõ'L¡(ß׳´Œqý}žCC7–´O²v†Üf³ûògù’îe »¬Ñ§ü|^Ê=íçþ훓X°p–ŸôèM·—O˜j½ŽA×/®Qª°£SqŽÜ„ùÿÝ®Ãî/quDaŸ›¬4GÓ.?«aÚO»Ònùòð9|aO?W5¯ªu\Ú¡šj‡jƯ”îõ£dÎÑG*I–Ÿöú¦€bs¶AŸ#ùvÔ®¯™ ÷(•©Q Veø½„éý8Ê~yʯ\.ûzt2ºcÔ÷{ùy¿0 ×¹±ãè¸ÝëI—Ÿöú¦÷Èk¿óúöpÚËéwYºá®Lùµnÿ']{+“¡Ê}ÐÞn9ݼHì^~­FG슖¤Ûv¦v/?gHcv{ù„) |Gä$þ8?Kîö=Ès“õ‘f›‘vù~C•;X¹·«û›Äqî+Yá^¯Àd!ò”_¹Töõ8üÝaÏæU;¶îðõ~qV¢³ü8*Z©$U~ÚëO˜Š-S~Ý|ßV{ݽ‚D«{ß:×¾â'ì›úÒ”Ÿþ8lŒ<åçwDɽ`GŽY²2veoûÇ6c#TîÎÙ«ü¸6 ×‘J’å§½þ„©pÛ&ì·¶â:!<ìç‹à›€PÄ@ôü“u—oùy…ªN9Ê:é»MÝîªÕòwÊ~ËŽ<åô¼'{AË岎?Ú²SߺekìçPµ©I+Tt{ù„)d½ƒî´f¡Ó ó-¿8Û´¦üÜ#~6½í²<åç^Nwˆð:àŽk›…ŒkšÚ½½ý,Kв£_سäÿšPÇNÓæ‡7ëØ‰cK^s^VÁ¾°Ø–¿o¹íoMíTÕjÕ³ü(_}mw»›$ÊO{ýãØáƒ4xE _A/÷•ð½öF§Z×SÖCaR—_Iãží.¶Úîçn¾¥ûž~/îi· qÀû 2¦÷[_ÀŠþ-?ŸçPÙ§Nx¾Öj¤dóÛc?‡Ê]–×TGÔ‘çÎêµãš.?íõ/‚4¾áÜíÎpþ.îÆÇ¹?øYGS_«s(Lž[æ}³tÜ<\ˆ4 £xIÜT·ÉydnúòÝ\>£ÁF@Ҹسüv¡Êä6K{èT~VF©ÚìšžâÊÊ…=ƒì+Iúçµ=s†ž8×#íoø9û8SûAä)¿8F‹l§'´qxãâ OœžH´±Œ»ÂÛÝ7)‰òÓ^ÿ¢ͦ½¦NÐÌzùyØîY}ÝzÄÁYûàÝîkî%§±=L(š´Ì~â¢Ü¯{‰ëqÛÔô”6<°ASÓS©¦Ø¸.ìô½¸mè´>³&Ú-Ÿé+¦Yô)?ÿÙ óaè¶£Þµk×ò©|êïï§hûê§}ç *B Š4åóòmhhˆJ|Z³fêTh_‹¨ìðäQî×½Äy@nUØ)¿ÞJ¯æoΫ²¼’èB×ëu-¯,gë€Lˆt/¿{ïÕô¦5s^¥R)‘Çüü¼Îü÷ŒÖ®gë€Lˆ4å÷Ѓéôôiþî°®Ï]Od{ïèÕà_5üÀ0[d'P…ò+—ËÑÈð5 ºV¤)?Äð-?@–¥[wÞ©Êø¸*ããÔàSsåJ*(R ò;åW«Õ¨1,Ñ37§×®‰KÁÌÌÌèí*Pÿ½\™ñ^¡%IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bgauss.png0000644000175000017500000000023513070106167015130 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ,IDAT×cøÿÿîâò ÿŠøÏOTüóÿùÀpðÃá0½‡5‚¯;ËIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/wininfo.png0000644000175000017500000000054713070106167015323 00000000000000‰PNG  IHDRÝÁNbKGDÿÿÿÿÿÿ X÷Ü pHYsHHFÉk> vpAg£;*ÑIDATHÇí–QÀ CÅìþWf_3[â”’¹dýÕÒTbk‹KETUÍ8'd´@޵Œg¯«˜ ÷ìí(SVŽD O!™û6 N5z¦Ð]Q¦6ÔèírübÎÜ9Æc™yiG\¥ Xõ£*3Uú&à[G=Ë…? èÌœB ¡}·X°)@|•éP¢6@+yfl%tEXtdate:create2011-02-17T10:47:16+09:00~Âýk%tEXtdate:modify2011-02-17T10:45:42+09:00·Å¿IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bsingle.png0000644000175000017500000000021713070106167015267 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑIDAT×cøÿÿïbù ÿø¡l(Ÿ$öÿä2ˆ´WNIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bsection.png0000644000175000017500000000021513070106167015450 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑIDAT×cøÿÿ`0`¸»ŒÉaCÍÏ%% 3ݹkIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/scundo.png0000644000175000017500000001270113070106167015140 00000000000000‰PNG  IHDRTPFtbKGDùC» pHYs  šœtIMEÞ #ƒ(ídtEXtCommentCreated with GIMPW)IDATxÚíy|噀Ÿd[¶äK¾â8qâ8qç$áÈ]Z޲-ÛB)°Ýe¡Ý£-Ph·ËB ôúm¡e{Ñm»´@ KËÕ’4P®8 Í}øˆÃñK¶lIsí²Û±'>d'ïó‹#FšÉ7ß<ó¾ß7ßgŶmAaШR‚ "TAª ‚UA¡ ‚ ˆPAD¨‚ "TAA„*‚ BAóhR‚ œWœ8Áàà¿ÇëþœŠŒåá¼â–[àÙgÿ=_ÿ:<òˆ¤ü‚ ñ@„*‚ BA¡ ‚ ˆPAª ‚UA„*‚ BAD¨‚ qD†ž ‚0ú à›ß„Õ«Á²N¿­ß¡Ðà÷™œ ))gÞÎé„Ïî¹G„*ÂbãFøâaË–øËÊ•ÑåãÃôé¡ ‚0±møÍoàk_ƒÚÚ‘ßÿÔ©ðýïÃ5×HÊ/ÂyB[|ë[ðØcÿþ¼^xàh„ìtö¹‰U„±MUÜ{/¼øâð|¿ªÂç>> ÙÙ§ÝT„*ÂùÁúõð¥/ÁŽC÷K—Âsç̽rA8/X±¶mƒŸþ|¾Á}×ĉðÛßÂÛoX¦¡ ‚p~ÒÒßøüøÇ ëÿ\r2Ü?|å+˜xÖ»¡ ‚pþ²oÜ}7¬]{*póÍðÝïB~þ9ïN„*ÂùÏš5Q±îßê{_m']¼xл‘6TAÎ>úQع3úˆUZZt]^<õlÚ4$2•U„ †xá¸õÖ -¡ ‚ Œ<’ò ‚ ÚsÏ=ÇM7ÝDssó)ofddôX¿nÝ:)1A„þ„ ÐÜÜÜ%Ïîí½~elvA¡ÿ”¿·DûZ/‚ œA¨ÝÚ]ž½× ‚ gj÷¨´wtÚ×zAAR~AIùA$åA”_R~AIùA$åA»hý¥ü½Sý³Mù#z„ÃGªilªÇ0LÀ&6‹mÛhšFR¢›”d¯—¬ÌlTuè¦ظq#K–,¹ NbMË.žý먥ðñ÷0)}ÞïãB*Ï 9ÇC$ÔÞcö»§üçÚvZ]S…/ÓÇ‚yõ)JÓ4Ð ƒH$̱ڣlÜü.“ ‹ÉÍÉCQ”AÿÇÀyw²lÛ¦ªú 'ZNôXÿL͸öòÏòîÑßðä»ws]Î7Ð4 ÛŽÞÄ|é>ŠŠ¦ ª\ÏÇòä‹P:–ÿläZW_ËÅ  ‡°,˲¢?¶…e™`ƒªª$¸(šTÌäÂ)ìÚ³ƒ÷?x—‹æ/Æårŵ`¶l}wÞùºqêߣILLbÕUŸ dÚ¬•i塃xS½”Μ‹CUQEQøÑ¯Ž1%{.•®µlØ¿ƒó‘‘‘ŽmÛ˜¦Å‘cÕì?¸—iÅÓ‡äf5X233ijjÈX:ÖÑR^çÊp–s$XEãïl|OîJ|SïCKÈ;)¿®(Š‚aèØ¶e[шɊ.-ËB7t:Âøý~²}¹Ì›³€To”½Ï%‹.ÇápÄ­b¼õÖ.½t)ªªž¼tÞB¡k×½@Fºìì¼9žªêr²|Yäääaè:¦ª ªjè?¦Ê`°ää$ÌβÎÏ+@S5öØÃôi3GÅ7D•™™ eeÃ~¬·ýãÔ¯’ïJõzxæEBBB\3©³EQ”a+çHÛAj6ÞÀŒ+_Â>‹†Š_Óxð1rK¿3vR~ÓŒ¶›Z–EÝñ:"ý´ÛîÚµ‹eK—Q4y ­[¶nbÑE—Ä-¢ …ÂØ¶ÍÁòݧ¼çñ¤1aB!¿~æ¿û­<šædÙå+Y0ÿÒ!9ž¦æFÆG µ‡CCsh84 íä=± ‡Ã¢ª(–…i™Û[Ir»©«?W¡öŽ^º_@§‹lâ!Þ˜La•jCc#Á`;þþ3LŸ>ƒÒ¥çô=ì§l{k__OuÍa¦O‰ëÍèl®Ûáœã>&ÓÒ«^%)u*–ÙLzþÚþðð u8R~Ó4°; ++ÛN;;¦b?VgeÛþ¶lÛFQfÍšCÓ‰fÈÎÊŽK…0L¿¿…H8rê®ÇãI£¨h ¶iv6cD£oËŽF±º®ó—·Ö ™P-Ë"Á•Hå¡ ÔÎT_QTõÔŠ[u¨’@k ¦ivEÖ…'cYV\/²îòì.§3¥‰#Íö)ÀÂ…Ã&Õêêòòò°m Ó4¶·ñíï~›–-ý~Æï÷ãñxPU•´ô4î½û^lÅÆ2-|ª®Ž»Pc¢TåŒËá•éÇ™ù‘Hô`t|ˆâH£ùðkxò®–}[ÊoÑvR˶h¨kD?Ã߯·Gxéå—ÈÈHgéåË(È/àXíѸ Õ4Lš››hoï ±±††À¥¤ª*YY^|¾dt=2dÇcYªªbèùùù8ήHµ79Y9dd¦£ë:¡PˆcµÇ0 3îB=—6´Á´É ¥L‡KªUÕÕdf¤bÛ6.§“ʪ ™7o.Û·xÊ2¬XD"4M£©±‰ú†:œN–e‘šê¡²ªŠ ˜Lg\ù IÞŒà[¨Z6-ÇÞ bó€mq¢êúü¬+yIé ñä]‹'÷c£$å]¼¶MfVz»–mƒ Ý¢UwJ"uÇ먪ªâÅÏe—_NÙ¶ÍÌž57>ªaÐP_O$ަf ž}z5Ž>Ö;2ÿÌgoƤ ©À,ËBQU ÃÀáÐPP¢7¬>öh àÐTtCG×uÚ;Ú1McÔ u´´™ö'S.òˆù`y9Y¾LLÓÄ¡©4ðtɳ÷Òét2{öl,œÏ´iSq:8NÚZ[±,“Œô4Ê++GEyÆ¢Ï3-‡\¦ÁJ½¥Wü‚$O>‘À+hIóq¸¦‘9¡”Kn¾µÿ¨3ÒD¨µ‚ŠM÷ÓVÿ¹¥ ¨Îx§üf×6Ö7u>‹zzR½i,_¾œŽP;ÕßßÒ™Å#Bmiié!4‡CãĉÓ_Héé™X–E{{ªCR¡ªJT¨GZwóË­_Æíô²lÒM§l[Öð›÷?Ç™Åòœ;PÛ31F±P{Ëi¤£Ò³‘éP7C:tˆ«>² Ë2q&8™R\Ä~½ßvEUu öjæ1LÍ¥áJp‘íNæ½÷·ŒŠt?^To¹‹Ì‚‹Iôäö?V˜ˆ>À¨]q¢jù$&OeÖªW9ôá#Ù~ žˆsÊož¨/+ódt÷ïŒTmìØí€”>ŸEqÄíʦ‰ÞGGZÙöͧýÜß\q5zDÇáÒ†<å×uƒçv<ÈŠE«Hp%òÖö_ž²m¹ò:·]}7ÿ–7·ÿœÅÊ?£*ꘈPû’ép·Ÿž­L‡ò˜ŽÖ§¸¸ˆöŽvf͘7¨'[×!))‰¿Ã0Ð4-nç1}vo'=Ýë¡dŸqðíkIIý9é¹E‘hI‹Ð’æ`†÷ŸáN`aÛíè­ëP›)œûU¶¼²’ö–¸Óf L¨Ã’òF´`Qhhh<%Buh²³}=EkŸ »Q ¢‡ãV! Â>žÉ¾Žu´~l+ŽpN§sÌ¥ü#ÑO™èºÎŽ»h¨¯'';wPBÝ´i©Þ´h}¹€ÿ:|BÊd¦,}™}ë¯cêü+IÏO¤í8¦ %òÁ+·cÛ}_ §“ŒœÉ”,ù*–^†ÑñSÝOåîŸ0yñOGCÊY9¾h›Ÿ¢Dý[v¾î)Ôh¼ª D;¶â„išØvÏÃ;›µw”>Tj(bº}=ë7?Žz­…u,švC×vœ”µ=Meu95{›™¼Û N§kLu4ôæ”LcÑÙþý©«;ΕmA uß¾¤zSãšn÷•òäõP“è)fêòWÙûæuL[°˜Œì‚u_Æõ V=NÅî÷˜²äg§^÷zÇö>AýáÝäMšO¤õe’Òî"Øò³ø¦üF§L퟊ªBô_§©¢¿Æ\Ú#TJ!K*jü¶¶6&ŽŸtZ1ÕÖÖ …÷Þ,ËÂ0 .Z¸ݘÃÌæù<½ë^ü'þJ{i ¾„I4†ª8¸çfCŸÌû>Yî‰ädg™µ{Ê?œrÍÌ̤ìIXØ—DGH¦1Ú‚A"ääd4McÁÜEÑKC홽õåŸ7ׯ#-=•ê†A[08*Îcù”ß4£²TÔÕÖ‰ ì"§S£`BA)Ç+BíN8áÀÁ½¼óî:*ÇèlÒè³ gBj´p]Nþó¡‹>[[:O~âösªia˜åålذ#G¢²þ&¶ú÷R4#6Tì=ŠY‘ObÕ\Öò6EEE\±|……“¥—¿ú•êÈ4& ˆ/üë}†Á~ð×ÿíµ¼_ý;Z#'÷›àHaAþÕd$å°fík|éžÇér‘“•ŽeÙèºÙõŒ·•jéG^eÇë×1uv 9Wr¼êEÒÇ­ê'p‰Ð|l=ùE×`éå(Ž$‚ͯâpúÎ(ÓáMù UQ—Ÿ×5î¼ÇO,<¨ÝÙ=eÇ"TcÄOÀ_û?ÊÊÞ'3+-:0¡3ZÎÍMâ¹çÎÌé3¸áúq:zDÓ½ï²'gÖ‚òò=46· :B5 [±X´äbu½ó©Î»`t±<Ⱥ'ЭH¿X]È)¿R¡c²m›”d7GŽÖ‘šâŠ'OdÙŠøc\Yr Gi &b¶£©.R’SHNrpÙe—ó‡5k©oh¢µµUUi v˜€ç9âòwÇZÌœUk©Ùõön–¬Âk(œs_m:•· ”“‘3ž¼ÂOa¶<Œ3iþz?)¾EñMùMÓê ýk'X“ÓédòäIÝÒî‘eË–\ó±ëIOÏ «E·óÄ[¶MGGúúc„Bí]#¿ºîöÉ'bu%--“]»÷ð™›ÿið)¿iÒÜÜÌü¹ HñxpjNœNWç2úœœ®ëÏŸFÐ ¶ÖV¶}¸]×ÇlÔ2#¥º¤:‚ô¡ùâ½÷ÑxÂϸ¼\<^/éié$§gŒ´˜˜@IêŤ%eSѸãåd¦æ’äôžžŽÛí&;KáPÍEAs8xøÁâ:ÆhIù{DªžB¦-ùÓ–|¯Ï÷SÒ IÍÈÇá0pØØí¿BUÃØÚvnþ1S/ùÅÀ…:<öŸŒ.óÇ뙪=‡Nv¾Ž¬…eŸ”T<ÚP'‰èøÍ´Ûº ÒÆ²¢¯UU%ÉÜC¦]•¢3ÊŽý~øðaÜn/……EƒPM¿?@8&SUUIEeSŠŠ),,è¶n ……Ñ“ß@7t,sì¦#&Õ;GN¦Š¢››ËŸ»_>õkŠ‹ ZINv“š˜ŠÛé!Ó=ŽŠÆmèfY)l©YCSð0+KîÀ”HGG“&PS]ÃÇV­¢tæL&ÄåÙí±Œm5`•XÖ! §–Œ¥.£ì­Õ¤ÿ4ùË.ÔáJùcéðáš#§ =íŠD»õøw‰(ŽB-)™MÙÖ÷X¾b6V—,O “’ü:)ÓžÞ½{·~ö®AW¬SÊï÷w­«¨¬ä¦Oß³«ŸfÇÎ]ëÿîÆOñâK¿ï&T?º‰{„Ú½Ãé\Þj©.¼3*Ѿ¤:MŠ¢àñx(..&¢G(*šÌŸÿ¼Íá Ø­si¢çä„á+ oèz¿¥%ÀôU%¼ñæ[,Y¼˜ÒÒR’““ã>MãhJùB8âÀŒxp(ù`Xtøw²í'IÈ¸Š©³ÿ]×»²À¸¤üQ D ¬¯6TP0-“SDíVÆ#Ý)eÛ6%%3yþù§HvkNzFÒ±×Ñ㶺Ä}ÌÊîœä":n~Û¶¤$§QXX4è‰ ¢ªIÀrà’iÓñefqÇ?ÜI8êZßÖÖÚCž`T¤üýMŽ2P‡äºG¤ñhÇu8(ŠBcC#Çkr¨ªŠ;”OÿåqéPU‡ß|Œ£G³wÏZ~4§·Û=jÒý±„¿¹ŽºÃ›i©ûP°Ûv>ùQ2òaÛ`4,)¿®ëäåå³s×fÏšsN|°üÙ¾ìèçª ¶mãph,_~5üãïøË_6 êûRR¼Üxã­]²=׊ÖÐÐÐ9ôÕÑ#Bm ¶ñúbï¾=„B¡éĉOV¿¿Kò dee¹ ?Ô’Ms±š¦I¨£ƒw6l¡µµ C7 w;Ÿ½£¹£oþÛ¶ˆD´µ¶±aÓVB!Œ3L@4Rç)C‡‹/w&ÙÓÑuH$‚išhš†ËåÂétøÚò”ß¶mšššHq§ðúëëxö¹g¢½Ó±‡ö»õäw-»Þ‹.E!++›Â “¨««#??DÚ„E!!!Å‹/%++wÐ:;--ââbu×nllDsh¬YûþnêÄ ƒÌ›;¯×ÿC%9ÙÝM¨^yõe\NqêÙÊì|Ÿ1?11EnGQU6}P6àúÒÑÑÎþ=»q¹\£"ÕËçKUU59÷§üŠ¢‘‘AIÉt¦L)t:”=b 슢 ix½ÞA§Èªª¢iš¦ ª¢û|> c*¶mSV¶•zè¬>ïõz™7g!Š¢àóùF±Ž©=ñ555˜¦yVõ=6‚nüøñŒ?^:£â̰¤ü.—‹‚‚‚!»kœ ^¯÷œ÷›m´´)eeeuE•ß›ý_q©(çZžÂ™ë†×ëeÉ’%ÌŸ?ÿœÿ|ˆËå"))iPuMÎñœÏÕ«WÛ+W®ì7µ?×^~A„ µ¿”¿¯õ‚ „Ú] ½S~Aá,„Ú=*íöµ^A”_AR~AIùA$å—”_AR~A„8ðÿ\–ÆÒr0ÀIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/winaxis.png0000644000175000017500000000024713070106167015331 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ6IDAT×ch`0`ØÿÃ> ÞS?a‡=„ 㣰ñÍ  4˜”éo``8À Ä%ƒEÔ^IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/aclear.png0000644000175000017500000001267613070106167015107 00000000000000‰PNG  IHDRTPFtbKGDùC» pHYs  šœtIMEÞ "ãïdtEXtCommentCreated with GIMPW&IDATxÚíy|噀Ÿd[¶äKòljljsŸ„+ tIh9ʶl ¥Àv—…v¶@¡Ý. -Ðë·…–íE·íÒ.-WKÒ@i¸BBâ$4÷á#vÇg,Û²%͵ÈRlÇÎáK6yŸ_üy$K“ïûæ™÷ýŽ‘bÛ¶ ‚0hT)Aª ‚UA„*‚ ˆPAD¨‚ "TAª ‚ BA¡ ‚ Œy4)aD8q‚ÁÁ¿×ý„Qˆ"kù…áæ›á™gÿ>_ÿ:<ü°”§ )¿ ‚UA¡ ‚ ˆPAD¨‚ "TAA„*‚ BA¡ ‚ "TA„aA–ž §µ¾ùMX½,ëô¯  üg¦¦BZÚ™_çtÂç?wß IIRW‚U#lÜ_ü"lÙ’øcY¹2º}ì1˜>]êF¡ cÛ†ßü¾ö5¨­ùÏŸ:¾ÿ}¸új© A„*|Hho‡o} }Âááÿ<¯î¿?!;Rþ‚UøRU÷Ü/¼0<ﯪð¹ÏÁ#@NŽ”· BÎÖ¯‡/} vìº÷¼ì2øáaÞ<)_aT!Ó¦„áeŠض ~úSðù÷^'Âo o½%2$BÎsZZà߀ÿtýìÿ.5òHN–rD¨‚gß>¸ë.X»ö ­S›n‚ï~ ¤Üª ôËš5Q±îßês^í']²DÊI3Hª8>úQع3:Å*##º/?ž|6m™ ¡ €hh€çŸ‡[n9»¥¥‚ BA”_A8Ú³Ï>Ë7ÞHssó)OfeeõØ¿nÝ:)1A„þ„ ÐÜÜ—gw‰öÞ¿2v'A¡ÿ”¿·DûÚ/‚ œA¨ÝÚ]ž½÷ ‚ gj÷¨´wtÚ×~AAR~AIùA$åA”_R~AIùA$åA»hý¥ü½SýsMù#z„ÃGªilªÇ0LÀ&vÛ¶Ñ4”d7i©<^/þìTuèn-°qãF–.]z^TbMË.žù묥ññw3)sþÆùTžç+RÇC$ÔÞkö»§üí;­®©Â—ícáü ú¥iè†A$æXíQ6n~‡ÉE%ä忣(Ê ÿc­­­ºÊ²m›ªêƒœh9ÑcÿÓ5_àšK?Ë;GÃïÜŵ¹ß@Ó4l;zóeú(.ž6¨rý0–§ u<,B=Ûµüç"׺úZ.\´„P8„e™X–ý±-,ËTU%É•Dñ¤&Maמ¼÷þ;\°` .—+¡³e뻼ýöŸÐS¿û(99…UW~‚Òi³GT¦•‡âM÷2kæ<ªŠ¢((ŠÂ~uŒ)9ó¨t­eÃþ,œ¿˜¬¬LlÛÆ4-Ž«fÿÁ½L+™>$«Á’MSSÓ˜8AÆÒ±Ž–ò(ÃYΑ`¾C°ñ=rròGäxªªËñûüäææcè:¦ª ªjè?¦Ê`°ÔÔÌ®².È/DS5öØÃôi3GÅ 7D• eeÃ~¬·þãíÔ¯’÷J÷zxúERRRB3©sEQ”a+çHûAj6^ÏŒ+^Ä9›†Š_ÓxðQòf}gì¤ü¦í7µ,‹ºãuD"úi_»k×.–]¶ŒâÉShkmeËÖM,¾à¢„ET¡PÛ¶9X¾û”ç<ž &L(â×Oÿw¿GÓœ,»t% \<$ÇÓÔÜȸqãhmkÁáÐÐMC;yMŒãp8PTŲ0-“`G)n7uõÇ*ÔÞÑK÷èt‘M"Ä“)0¬Rmhl$ rû߆éÓg0kƬ½Ïû)Û^ÆÚ×ÖS]s˜©%Sz1:—óv8ïq“é¬+_!%}*–ÙLfÁåÚþÐð u8R~Ó4°» ËŸã‹F§]S±«+‚²m‹@{ ¶m£( ³gÏ¥éD3 äøsÒ Ó$h!Žœz‚‡ëñx2(.ž‚mš]ÝÑèÛ²£Q¬®ëüåÍ5C&T˲Hr%Sy¨µ+ÕWE=µáVª¤µ­Ó4ã‘uÑÄÉX–•Г¬»<»ËéLiâHG³=d °hѰIµºº†üü|lÛÂ4 ‚í|û»ß¦åDK¿ðx<¨ªJFf÷Üu¶bc™¾¬,UW'\¨1Q*ŠrÆíðÊôãÌüÈó${ 1:?@qdÐ|øU<ùWËg[ÊoÑ~R˶h¨kD?Ã÷°‡;"¼øÒ‹deerÙ¥Ë(,(äXíÑ„ Õ4Lš››èèè ±±ƒ††Ö3JIUUü~/>_*º²ã±, UU1tƒ‚‚œNg)m2S.{‰}ë¯eê‚+ÈÌO¤ý8’¦ %óþË·aÛ}Ÿ §“¬ÜÉ”.ý*–^†Ñù>SßGåîŸ0yÉOGCÊþ\_´ÏOQ¢þŒm»÷j4^UP¢[ Â4Ml»çáK„Ú;Jª5 1ݾŽõ›#0½‰¶¢:O»>þº¬ NÊÚŸ¢²ºœš½ÍÌÞ†í§Ó5&„:FóGJ¦±èlÿþƒÔÕçŠöÖA uß¾¤{Óšn÷•òŸÍã¡&ÙSÂÔ寰÷k™¶p Y9…뾌Ûÿ0 W=FÅîw™²ôg§ž÷z;Çö>NýáÝäOZ@¤í%R2î$Øò³Ä¦üF—L]ýŸŠªBô_—©¢¿Æ\Ú#TJ! ¤•.µÇ*¿½½‰ã'VLµµµ„BaÀ=¤˲0 ƒ -B7æ2³yOíº‡À‰¿Ò1«_Ò$CUÜs³!ƒOæ¿{"¹99c&Bížò§\³³³){õ%Ñ’iŒö`HD'55MÓX8oqôÔP{fo}ùçõëÈÈŒF¥ºaÐ ŽŠzLdÊ#Å[Âô+^açë×2}Á,²ýSélxoÞ4×~§Ÿ5œâ[)ßx#ã§]Õq?ªçÓ´8ÐÃ#Ÿò›fT–ªƒºÚ:"‘³›BätjN(ì!åDE¨Ý ‡#8¸—·ßYÇ¡Cå]]}öáLH®ËÉ>øoѹµ³æóÉOÜ6p¡š†iP^QΆ 8rô(*K lbk`/Å3ZÁ†Š½G1+ H®šÇZÞ¢¸¸˜Ë—¯ ¨h²Œò÷A¿R™ÆDhmòá ÿz/†aðƒ<Êu{ ïUÿ޶ÈÉÏMr¤±°à*²R X³öU¾t÷¿ãt¹ÈõgbY6ºnÆçx Q©ÎúÈ+ìxíZ¦Î)%·ð ŽW½@æ¸Uý.š­§ øj,½Å‘B°ùNße:¼)¿a¢  * ã òãëÎ{üÄÂÓØÚ]ÃSv,B5F¼þøêÿQVöÙþŒè„®h9//…gŸû93§ÏàúënÀéLêM÷¾Êž¼³”—¹eЪiØŠÅ⥲8þ̧º®‚ÑÍò< è¶ž@·"ýN±:ŸSþ~¥:BÇdÛ6i©nŽ­#=Í ”LžÈ²+Ǹ¢ôf޶¤1x˜ˆÙ¦ºHKM#5Å À%—\ÊÖ¬¥¾¡‰¶¶TU¥=ØIrRj‚ïÙ蔿;îôæ®ZKÍ®Ÿ°wû3ø‹®¦hî½=^ÓÙZIkãvB­ådåŽ'¿èS˜-áL™M >@šoqbS~Ó´â¡í±ã„Ãg7Àät:™ØŠ®ëc6j‰•Rq©Ž°àyð¾xϽ4ž0.?×KfF&©™9#-$''Qš~!)9T4nçxg9Ùéy¤8=dffâv»Éñ+ª9‚¢(h=pBïƒ1ZRþ‘ª§ˆiK¿Ç´¥ßëóù´Œ"Ò³ p8 vvǯPÕ0¶¶›ÌÔ‹~qöBž‰ý'£Ë‚ñãºE¦jÏ¥“]£kaÙ'%•ˆ>ÔIE%D":Öf:‚íÝicYÑǪª’âNí!Óx£èвc¿>|·ÛKQQñà#TÓ h%‡©ªª¤¢²‚)Å%tÛ7…¢¢è…)hE7t,sì¦#&Õ;FN¦Š¢——ÇŸ»_>ùkJŠ‹hmm#5ÕMzr:n§‡l÷8*·¡›øÓ ÙR³†¦àaV–ÞŽ;%™ÎÎN&M,¤¦º†­ZŬ™3™PX˜¹ÛcÛjÀ6*±¬C@=N-K]FÙ›«Éÿi² –½P‡+å¥Ã‡kŽœ²ô4‰vñ‹(B--CÙÖwY¾b6V\–'…IÉÆV~”iOïÞ½‡[>{ç +6(âû**+¹ñÓ7óÌê§Ø±sG|ÿßÝð)^xñ÷Ý„@×# P»8 dòþPKuÑQ‰ö%Õ‘èzPÇCII =BqñdþüçõhÁnƒK='o¾¢èV€øó--­L_UÊëo¼ÉÒ%K˜5k©©© ¿MãhJùφpÄñàP À°è ìdÛÛO”u%Sçü º®Ç³À„¤üQ D ¬¯>TP0-“S&¢v+ã‘”²m›ÒÒ™<÷Ü“¤º5ŠŠ&=#éØãèq[qqF§YÙ]7¹ˆ®›ß¶mi©úFÑÕ¤5pò&À¥Ó¦ãËösû?ÜA8Šïoooë!ÏÖ@ë¨Hùû»9ÊÙŠx8$×="MD?®Ãá@Q9^{”CUUÜ~çí¤¥yú/‹¿€ª:8üÆ£=r˜½{öÐÖ@s:q»Ý£&ÝKšë¨;¼™–ºk±m™“!+1¶}ö Œ†%å×uüüvîÚÁœÙsTÀËãˉ®q¡bÛ6‡ÆòåWñÇ?þŽ¿üeàÞ/-ÍË 7Ü—í@ZCCC×ÒWGµ=ØÎk¯ÿ‰½ûö …zœ¤'N<ÙX¸äðûýc®ÁµäFÓ½XMÓ$ÔÙÉÛ¶ÐÖÖŽ¡›„»Õgïhîè?À¶-"‘0ímílØ´•Pgã 7 ©zJÄÒáÁâË›IVÎtt]'‰`š&š¦ár¹p:g}îyÊoÛ6MMM¤¹Óxíµu<óìÓÑÑ騤ýn#ùñmü¹èVQüþŠ&L¢®®Ž‚‚‚éR…¤¤$–,¹¿?oÐ_‘‘AII IIIƒºj766¢94Ö¬}•@·uâ„ ƒAæÏ›ßëÿ¡’šêî&ÔV^~å%\N ê¹ÊìÃ~Çüäädv~°EUÙô~ÙY·—ÎÎöïÙËå©þX®/UUIJJÔ͹‡<åW…¬¬,JK§3eJÉ Ó¡œœœë`WMÓÈÊÊÂëõ:EVUMÓÐ4mP ÝçóaS±m›²²­<ðàƒçô÷^¯—ùs¡( >Ÿaô˜úÑãSSSƒišçÔÞc+èÆÏøñãe0*Á KÊïr¹(,,²«Æ@ðz½þ¼Ø-ÑFKŸ’ßïG•ß›ó_ i(-OáÌmÃëõ²téR,X0à¯q¹\¤¤¤ ª­IA}®^½Ú^¹re¿©ý@GùAÎ7ÔþRþ¾ö ‚ gjwöNùA„sj÷¨´wtÚ×~AAR~AIùA$åA”_R~AIùAÀÿ zÆàtÆ|IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/btext.png0000644000175000017500000000022513070106167014771 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ$IDAT×cøÿÿ2~À`Àð¸Ï€áy?ÿïÿ€ÿaDÑi³0]zŽ‚IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bclear.png0000644000175000017500000000031213070106167015070 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑYIDAT×cøÿÿÃÿƒ@¼ˆÃ þ­ÞÀð7ôïU¾†20¼ZÅÀp5D€áÔ †­ »|`Øëøa_ó†ûìÞ¿ÿÀðõþ†ö@ýÿ?»-+d?”§IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bdataopn.png0000644000175000017500000000027513070106167015440 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑLIDAT×%Ʊ €@ @Ñ¿#¹šà"©]BqWW‰‚lŽ+ƒÿ‰0¶´¤+íqÞÆQÜhÚ£´"ÔUðQñI~½ÙÏœ?ð×p/æ\ ÜIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bmath.png0000644000175000017500000000022613070106167014737 00000000000000‰PNG  IHDR7ˆÂÌbKGDª#2 pHYsHHFÉk> vpAg\Æ­Ã%IDAT×cøÿŸ¡aÿg† K&ƒäBØÈŒf†ÿÿáu†ÑIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/bsave.png0000644000175000017500000000027013070106167014743 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑGIDAT×c`ÿÀPÿƒÿ}  ±ÿÿ?0¼âã?š??``|´€áø! n~Àp|Õ†ƒ ¼ÿÃC ý„ìÿ m|)ë°u IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/btrim.png0000644000175000017500000000030113070106167014753 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*ÑPIDAT×cøÿÿÃw ~¸ÿÃÁx ;ˆ·`x¼HßýÀðˆo¾ýÀð®ÈßlÀðø@Ãׇ¾ (0<þÚÀðý)Pü Pï7 ýãÙS1žx4!—IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/fopen.png0000644000175000017500000001270713070106167014762 00000000000000‰PNG  IHDRTPFtbKGDùC» pHYs  šœtIMEÞ ! ¢r°tEXtCommentCreated with GIMPW/IDATxÚíix[Õ™€ß{u%Û²%oòljlj³¯„- tHhYÊ´L ¥Àt†v–¶@¡-Ðí™BËt£Óvh@‡–­%i 4l!!qš}ñ;‹ã5–mÙ’î6?d)²c'N¼È&ßûÄÏ•¯Ÿœsï{¿ïœ{ŽÛ¶mA„A£J‚ ˆPAD¨‚ "TAA„*‚ BA¡ ‚ ˆPAª ‚UA„*‚ DІåSOœ€@`ðŸãõF~AÆÊ°,ŽróÍðÌ3ƒÿœ¯~XZIIùAD¨‚ ‚UA„*‚ BAD¨‚ "TAª ‚UA¡ ‚ ŒŸzÚÖßü&¬^ –uú×úý ¾t©©–væ×9ðùÏÃÝwCR’´ª £\¨Q6n„/~¶lI|éW®Œl{ ¦O—ÖaŒ À¶á7¿¯} êêF¾ÔS§Â÷¿W_--(Âj”ŽøÖ·àÑG!þÒz½pÿý‘Ùé”ÖáC$Ô(ÕÕpÏ=ð ÃSJU…Ï}yrs¥ÕAø 5Êúõð¥/ÁŽCWÂË.ƒþæÍ“ÖaT3´·M­XÛ¶ÁO >ßà>kâDøíoá­·D¦‚ œ‡j<­­ðoÀ º>ð÷¥¦Â}÷ÁW¾ÉÉÒB‚ ˆPcìÛwÝkמ¡$ Üt|÷»PX(-#‚µ_Ö¬‰ˆuÿþSŸ»ðÂH?é’%Ò"‚ ŒYFnêéG? ;wFn±ÊȈì+(€'Ÿ„M›D¦‚ H„zN46ÂóÏÃ-· lj© ‚UáüA{öÙg¹ñÆiii9åɬ¬¬û×­['5&‚ПPZZZbòŒ—hïý+£‹‘‚ §”ê-Ѿö ‚ gj¼@ãåÙ{¿ ‚p¡ÆG¥½£Ó¾ö ‚ ’ò ‚ HÊ/‚ )¿ ‚¤ü’ò ‚ HÊ/‚ )¿ ÂØEë/åïêŸmÊÖÃ>RCSs†a6ÑelÛFÓ4R’ݤ¥zðx½äd碪C·øÕÆYºtéyшµ­»xæ¯ÿA²–ÆÇgÜͤÌùCþ7Χú<_‘6"¡öž³ŸòŸkßiMm5¾l ç_Ч(MÓ@7 ÂáÇꎲqó;L..%?¯EQýkkkûÐ5–mÛT×äDë‰ûŸ®ý×\úYÞ9úžxç.®Íûš¦aÛ‘‹˜/ÓGIÉ´AÕ뇱>iãaê@çòŸ\ëê¸pÑ‚¡ –ebYVäǶ°,lPU•$W%“J™\<…]{vðÞûïpÁ‚%¸\®„VÌ–­ïòöÛB7Nýú–ääV]ù ʦÍQ™V:ˆ7Ýˬ™óp¨*Š¢ ( ?úÕ1¦äΣʵ– ûw°pþb²²2±mÓ´8r¬†ý÷2­tú\¬Kvv6ÍÍÍcâKe-õu® g=‡Õ4ø¦÷ðä¯Ä7õ^´¤¡ÿåaKùuÝ@Q CǶm,ÛŠDLVdkYº¡ÓêÂï÷“ëËgþÜ…¤{3x¿ü=.Z|)‡#aÆ›o®áâ‹/CUÕ“ƒî C0díºçÉÊô‘›[0"å©®© Ç—C^^†®cª ªªöˆþ£ª :HMMÁì®ë‚"4Ucß=LŸ6sTœpcATÙÙÙP^>ìe½õo§îxý|Vº×ÃÓÿû+’’’šI-Š¢ [=‡;R»ñzf\ñ"îÌÙ4Vþš¦ƒ’?ë;c'å7ÍH¿©eYÔ¯'ÖOûÚ]»v±ì²e”LžB{[[¶nbñ%,¢ CضÍÁŠÝ§<çñd0aB1¿~ú¿û=x4ÍɲKW²pÁÅCRžæ–&ÆG[{+‡†æÐphÚÉkb ‡Ã¢ª(–…i™:ÛIq»©o8žP¡öŽ^âO ÓE6‰oT¦À°Jµ±©‰@ Àíÿ¦OŸÁ¬³ÎésØOùörÖ¾¶žšÚÃL-’ЋÑÙœ·Ã¹$sT¦³®|…”ô©Xf ™…—shûCÃ'ÔáHùMÓÀœ\_$:혊þXÝ”m[ø;Z±mEQ˜={.Í'Zhlj$7'7!„ašøý­„CáSOðPO%%S°M³»#}[v$ŠÕu¿¼¹fÈ„jYI®dªU¢v§úŠ¢¢¨§¸Õ‡ªhkoÅ4ÍXd]{îeHfYŠªb‡†‚¹`õñ7ÚÚÛph*º¡£ë:]˜¦1ê…:ZúLû“)‹ yÄ|°¢‚_6¦iâÐTšOøbòì½u:Ì™3‡…‹0mÚTœN'N§“Žöv,Ë$+3ƒŠªªQQŸÑèóLÛ!—i ŠCï]ϬËAЧpÛËh) p¸¦‘=aÝtKÿQ56f¸™`{%•›î££ámòg=Œ¢:ò›±654wß‹zzÒ½,_¾œ®`'Õßߋ̡¶¶¶öšÃ¡qâÄéO¤ÌÌl,Ë¢³³ Õ¡©PU%"Ô#í»ùåÖ/ãvzY6éÆS^[Þø"›÷?‡Ç™Ãò¼ÛQ;³1F±P{Ëi¤£Ò³‘éPwC:tˆ+?² Ë2q&9™RZÂý|½ß~EUu öêæ1LÍ¥áJr‘ëNåÝ÷¶ŒŠt?QÔl¹“ì¢ Iöäò? Vˆ°>À¨]q¢j…$§NeöªW8ôÁÃÙ~7E OpÊož¨/'ûät|…wGª6vôò@ZšŸÏ‡¢8Ö0¦i¢÷1V¾}óiß÷7—_€Öq¸´!OùuÝàÙ°bñ*’\ɼ¹ý—§¼¶By[¯º‹ÇËÛÎåŸQuLD¨}Ét¸ûOÏV¦CY¦£uÇ)--¡³«“Ù3æêΖõGHII¡ÕïÇ0 4MKX;F£Ïø~ÒÓ=J&,úߺ†´ôŸ“™_‚Þ‰–²-e.fhÿ®¶Ý‰Þ¾ű™ây_eËË+él݉;cöÀ„:,)¿aD*…ÆÆ¦S"T‡æ 7××S´öɰÂz(a„aXÐÇ'‹æ_xu0´)¿ªDúP K§"°‰î2nºì^ÞÙ÷bìu—ÌYÅeeŸd_×:: ?¶•DW¨ §Ó9æRþ‘ˆJ¤Lt]gÇÎ]464—›?(¡nÚ´‰toFäx9¿Ì8)m2S.{‰}ë¯eê‚+ÈÌO¸ã8’¦ &óþË·aÛ}Ÿ §“¬¼É”-ý*–^ŽÑõ>SßGÕîŸ0yÉOGCÊ9y¾HŸŸ¢DüÝv?î)ÔH¼ª D¶„išØvÏâM„Ú;Jª5 2ݾŽõ›Ã?½™öâzO»>öº¬ NÊ;ž¢ª¦‚Ú½-Ì܆í§Ó5&„:FóGJ¦ÑèlÿþƒÔ×犎¶A uß¾¤{Ó ß _†<j’=¥L]þ {߸–i —•[D þ˸sfáªÇ¨Üý.S–þìÔó^ïàØÞÇi8¼›‚I ·¿DJÆZ–Ø”ßè–‰£»ÿSQ¢BUˆüë6UäרK{„ªC)¤séC¥[íÑÆïèè`âøI§S]]Á`péÁ², Ãà‚E‹Ð¹ÌlYÀS»îÁâ¯tÎjÅ—4 €¦`5÷ÁlÌà“ß'Ç=‘¼ÜÜ1¡Æ§üÃ)×ììlÊŸ€E}It„d¥# ÖIMMEÓ4Î[95ÔžÙ[_þycý:22#Q©nt£¢™òGIñ–2ýŠWØùúµL_0‹ìœ©t5>„7ÿ Zê¾ÓO„šFnÉ­Tl¼‘ñÓ®Çê¼ÕóiÚOèბOùM3"KÕA}]=áðÀn!r:5Š&õr¢"ÔxB¡0îåíwÖqèPFw—FŸ}8Ò#•ëròŸþ[äÞÚYóùä'n;w¡š†iPQYÁ† 8rô(*Kñnb«/%3ÚÀ†Ê½G1+ I®žÇZÞ¢¤¤„Ë—¯ ¸x²Œò÷A¿R™FEâokDzá ÿz/†aðƒ<Êu{ ïÕüŽöðÉ¿›äHcaáUd¥°fí«|éîÇér‘—“‰eÙ躻Ç[ˆHuÖG^aÇk×2uNyEWp¼ú2Ç­ê'p Órl=…%Wcé(Ž-¯àpúÎ(ÓáMù UQWX›wÞã'žF jwOÙÑÕñøã«ÿGyù{dçdD&&tGËùù)<ûÜÏ™9}×_wNgRhº÷UöäÊZPQ±‡¦–ÖAG¨¦a`+‹—^ÈâØ3Ÿê¾ F6Ëó| n>n…û½Åê|Nùû•ê•ɶmÒRÝ9ZOzš(<‘e+Và7ŽqEÙÍm;HSà0a³Mu‘–šFjŠ€K.¹”?¬YKCc3íí¨ªJG ‹ä¤$Ô¯Ùè”?wz)sW­¥v×OØ»ýrН¦xî½=^ÓÕVE[Óv‚mdå§ øS˜­áL™¿ÁOšoqbS~Ó´b¡ݱã„B`r:Lž<).íY¶lÙÈÕ»ŽÌÌ,b=ºÝ oÙ6]]Ž vÆf~Å®öÉ;¢ÇJFF6»vïá37ýÓàS~Ó¤¥¥…ó’æñàÔœ8®îmä>9]×»ï? £:íílû`+º®Ù¨e$fJŤ:‚äÁøâ=÷ÒtÂϸ‚|<^/™™¤fæ·’œœDYú…d¤äRÙ´ã]d§ç“âô™™‰Ûí&7GáPíEAs8xèûºÆhIù{Dªžb¦-ýÓ–~¯ÏçÓ2ŠIÏ*Äá0pؕؿBUCØÚBvnþ1S/úÅÀ…:<7öŸŒ. Ç‹‹LÕžS'»G*Ö²OJ*}¨“ŠK ‡uüm-t:âicY‘Ǫª’âNí!ÓØAÑeG?|ø0n·—ââ’ÁG¨¦ßßF(" Q]]EeU%SJJ)..ˆÛ7…ââÈ…ÉïoC7t,sì¦#&Õ;FN¦Š¢ŸŸÏŸ»_>ùkJKŠikk'5ÕMzr:n§‡l÷8*›¶¡›]䤱¥v Íì,»wJ2]]]LšXDmM-[µŠY3g2¡¨(!÷nel«ۨ² 8µT,uåo®&cü§É*\6p¡WÊM‡×9eêi,ñ‰(B-+›CùÖwY¾b6VL–'…IÉFg~”iOïÞ½‡[>{ç Ë”òûý±}•UUÜøé›yfõSìØ¹#¶ÿïnø/¼øû8¡úÑõpÂ#Ôø§s¹y¨¥ºèŽˆDû’êHt=(Š‚Çã¡´´”°¦¤d2þóz4‡ƒ@ÜàÒDÏÉÃWß {¾µµé«Êxý7Yºd ³fÍ"555áË4ަ” „Â̰‡R†E—'ÛÞ~‚¤¬+™:ç_Ðu=–&$åH Ra}õ¡‚‚i™œr#j\ô ”mÛ”•Íä¹çž$Õ­Q\<èIGGÊmÅĹÍÊî^ä"2o~Û¶¤¥fP\\2è… "ªI›ÿä"ÀeÓ¦ãËÎáö¸ƒP(ÛßÑÑÞCžmþ¶Q‘ò÷·8Ê@E<’‹HÑëp8P…¦Æ&Ž×åPu5·ßy;iižþëãâ/ ª¿ñ(Gfïž=´·ùÑœNÜn÷¨I÷Çþ–zêo¦µþ‚:lÛAæäGÈ*XŒm|‚Ѱ¤üº®SPPÈÎ];˜3{î9UðÁŠäúr#sœGè±m‡Ccùò«øãÇ_þ²aPŸ—–æå†n‰Éö\´ÆÆÆî©¯ŽjG ƒ×^ÿ{÷í! ö8I'Nœxò`ñûc’oll$''gÌðC-¹Ñ´«iš»ºx{ÃÚÛ;0t“P\{ö޿޾ñlÛ"ÑÑÞÁ†M[ v1ΰÑHµS"¦_þL²r§£ë:ápÓ4Ñ4 —Ë…Óéð¹;ä)¿mÛ477“æNãµ×Öñ̳OGF§£7íÇäǶ±ç"[EQÈÉÉ¥xÂ$êëë),,‘>!EQHJJbÉ’‹ÉÉÉôWggddPZZJRRÒ ®ÚMMMh5k_Å¡Nœ0@ Àüyó{ý?TRSÝqBmãåW^ÂåtÑÔÔ”p¡ž­Ì>ì+æ'''£(°óƒí(ªÊ¦÷Ë|¼tuu²Ïn\.רHõÇr{©ªJRRÒ çò”_Q²²²(+›Î”)¥ƒN‡rssG¬ƒ]Q4M#++ ¯×;èYUU4MCÓ´Aè>ŸØŠmÛ”—oå<«÷{½^æÏ]„¢(ø|>„ÑCt`êG?Nmm-¦ižÕñA7~üxÆ/ƒQ fXR~—ËEQQÑ]5ί×{Î/º$ÚhéSÊÉɉE•ß›ó_ 9Pε>…3^¯—¥K—²`Á‚sþú—ËEJJÊ Ž5iã!hÏÕ«WÛ+W®ì7µ?×Q~A„ó µ¿”¿¯ý‚ „/ÐÞ)¿ ‚pBJ{G§}íA$åA”_AR~AIù%åA”_!ü?£fÆàê IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/beval.png0000644000175000017500000000025113070106167014733 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ8IDAT×cøÿÿCCý†ý@ÜN0`hw`Øï?¡ˆ÷×0ôW0쯀Êé ™Ä*'&Ç`¥ŽIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/draw.png0000644000175000017500000001270313070106167014604 00000000000000‰PNG  IHDRTPFtbKGDÿÿÿ ½§“ pHYs  šœtIMEÞ  “ÝøBtEXtCommentCreated with GIMPW+IDATxÚíix[Õ™€ß{u%Û²%oòljlj³¯„- tHhYÊ´L ¥Àt†v–¶@¡-Ðí™BËt£Óvh@‡–­%i 4l!!qš}ñ;‹ã5–lÙ’î6?d)¶c'N¼È&ßûÄÏ•¯déæœsßó}çÜ{¤Ø¶m#‚ UŠ@A„*‚ BA¡ ‚ "TAª ‚UA„*‚ ˆPAD¨‚ "TA!Š&E œœ8ÁààßÇëþB(²8Šp^póÍðÌ3ƒŸ¯~XÊS”_A„*‚ BA¡ ‚ "TAª ‚UA¡ ‚ ˆPAD¨‚ RäÖSaìÀ7¿ «Wƒeþµ~?„BƒÿÌÔTHK;óëœNøüçáî»!)IêJ„*c„á‹_„-[,+WF·=Ó§K݈Pa bÛð›ßÀ×¾uu#ÿùS§Â÷¿W_-u!B„ ííð­oÁ£B8<üŸçõÂý÷G#d§SÊ_„*B>„TWÃ=÷À / Ïû«*|îsðÈ#›+å-ˆP…ó€õëáK_‚;†î=/» ~øC˜7OÊWèÙÏJjV¬€mÛà§?Ÿopï5q"üö·ðÖ["SA"Tá<§µ¾ñ øñA×þw©©pß}ð•¯@r²”£ B„8ûöÁ]wÁÚµg8;¸é&øîw¡°PÊM¡ B¿¬Yëþý§>wá…ÑqÒ%K¤œ„#c¨ÂùËG? ;wF/±ÊȈî+(€'Ÿ„M›D¦‚D¨‚pN46ÂóÏÃ-· ìÖRA¡ ‚ Ú³Ï>Ë7ÞHKKË)OfeeõØ¿nÝ:)1A„þ„ ÐÒÒ—gw‰öÞ¿2¶ðƒ ‚p ñI©Þík¿ ‚p¡vhwyöÞ/‚ œA¨Ý£ÒÞÑi_ûAIùA$åA”_AR~IùA$åA”_aì¢õ—ò÷NõÏ6åè©¡©¹Ã0›Ø²¶m£i)ÉnÒR=x¼^r²sQÕ¡[üjãÆ,]ºô¼¨ÄÚÖ]<ó×ÿ YKãã3îfRæü!ÿŒó©<ÏW¤Ž‡H¨½ïÙïžòŸëØiMm5¾l ç_Ч(MÓ@7 "‘0Çꎲqó;L..%?¯EQý ºÊ²m›êšƒœh=ÑcÿÓµ_àšK?Ë;GÃïÜŵyß@Ó4l;Ú‰ù2}””LT¹~ËS:¡ô^þ³‘k}C.ZB(²L,ËŠþØ–e‚ ªª’äJ¢dR)“‹§°kÏÞ{ÿ.X°—˕Ђٲõ]Þ~ûOèÆ©_•‘œœÂª+?AÙ´Ù#*ÓªCñ¦{™5sUEQEáG¿:Æ”ÜyT¹Ö²aÿÎ_LVV&¶mcšGŽÕ°ÿà^¦•N’Îj°dggÓÜÜ<&N±t¬£¥¼Î•á,çH°š¦ß!Øôžü•ø¦Þ‹–4ôßV;l)¿®(Š‚aèØ¶e[шɊn-ËB7t:Ãøý~r}ùÌŸ»toï—¿ÇE‹/Åáp$¬a¼ùæ.¾ø2TU=Ùtu ¡Pˆµëž'+ÓGnnÁˆOuM9¾òò 0tSUPUµGôSe0ØNjj fWY¡©ûìaú´™£â„ ¢ÊÎΆòòa?Ö[ÿñvêŽ×É{¥{=<ý¿¿")))¡™ÔÙ¢(ʰ•s¤ý µ¯gÆ/âΜMcå¯i:ø(ù³¾3vR~ÓŒŽ›Z–Eýñz"ý´¯ÝµkË.[FÉä)´lÙº‰Å\”°ˆ* cÛ6+vŸòœÇ“Á„ Åüúéÿî·ñhš“e—®dá‚‹‡äxš[š7n¶V Í¡áÐ4´“}b‡Ã¢ª(–…i™;ÚHq»©o8žP¡öŽ^ºŸ@§‹l!Þ˜La•jcSÁ`Ûÿþ3LŸ>ƒY3fÓû8°Ÿòíå¬}m=5µ‡™Z:%¡ÑÙœ·Ã¹$sL¦³®|…”ô©Xf ™…—shûCÃ'ÔáHùMÓÀî*¬œ\_4:횘ŠýX]”m[øÛ[±mEQ˜={.Í'Zhlj$7'7! Â0MüþV"áÈ©'x¸'ƒ’’)ئÙ5Œ¾-;ÅêºÎ_Þ\3dBµ,‹$W2U‡*Q»R}EQQÔSnõ¡*m­˜¦¬‹'NƲ¬„ždÝåÙ]NgJG:ší!S€E‹†Mª55µ`Û¦iìhçÛßý6­'Zûý¿ßÇãAUU223¸ç®{°Ë´ðeeq¨¦&áB‰RQ”3n‡W¦gæGž'ÙS„ÑùŠ#ƒ–ïâ)¸zX>sØR~ÓˆŽ“Z¶Ec}ú¾¶7ÜáÅ—^$++“Ë.]FQaÇêŽ&L¨¦aÒÒÒLGG'MM46Î(%UUÉÉñâó¥¢ë‘!;˲PUC7(,,ÄétÆ#ÕÞäåä‘•‰®ë„B!ŽÕÃ0Ì„ õ\ÆÐ3&7”2.©V×Ô•ŽmÛ¸œNªª+ijlbþüylßþÁ)Ûh°b‰DÐ4æ¦fëq:X–Ezº‡ªêjÎwb2qÅÓ¤x‹0‚o¢j¹´{ÊÍÿ¶Å‰êÿéóo]©“HÉ\„§à<ù%)ìäµm²s2{ôZ¶ 66t‹VÝiÉÔ¯§ººš^ø=—\z)åÛ63gö¼ÄD¨†AcC‘H8šš5xæ©Õ8úXïÈü3Ÿ½ wŠ2¤³, EU1 ‡CCA‰vX}|F -€CSÑ ]×éèìÀ4Q/ÔÑ2fÚŸLY´hÈ#æƒäø²1M‡¦Ò|—gï­ÓédΜ9,\´€iÓ¦ât:q:´·µaY&Y™TTUŠòŒEŸgÚ¹LƒUzïzf]þ R<…D/£¥,ÀášFö„Y\tÓ-ýGÕØ˜‘fBm•Tnºö†·ÉŸõ0ŠêLtÊoư©¡¹ëZÔÓ“îÍ`ùòåt†:p¨üþÖxd–ˆµµµµ‡Ð'N"effcY¨uH…ª*Q¡iÛÍ/·~·Ó˲I7žòÚòÆÙ¼ÿ9<ΖçÝŽÚ‘1Š…Ú[N#•žL‡zâСC\ù‘eX–‰3ÉÉ”ÒîàëýŽ+ªªµ×0aêh. W’‹\w*ï¾·eT¤û‰¢fËd]H²'°ÿI°ÂDôFíŠU+$9u*³W½Â¡æÈö»)Zøx‚S~ó¤@}9Ù'§ »xW¤jcǺÒÒ<ø|>Å‘°Š1M½‰´òí›OûwsùUè‡Kò”_× žÝñ+¯"ɕ̛ÛyÊk+”׸õª»Øxü·¼±ýç,QþUQÇD„Ú—L‡{üôle:”Çt´î8¥¥%ttv0{ÆüA]Ùr¸ö)))´úý†¦i «ÇXôÙ}œôt‡’ ‹~ÆÁ·®!-ýçdæ—`Dv¢¥,FK™‹Þ†žÀ¶;ÐÛÖ¡86S<ï«lyy%­;qg̘P‡%å7ŒhÁ¢ÐØØtJ„êÐäæúzŠÖ>v£@D'¬A†}\y²hþ…gQC›ò«Jt Õ°t*‚˜è.ã¦Ëîå}/Æ_wÉœU\VöIöu®£Ãðc[It†;q:c.剉¨DÊ@×uvìÜEcCy¹ùƒê¦M›H÷fDÛËyüeÆIi“™rÙKì[-S\AfÞx"íÀ‘4P(™÷_¾ Ûîû\p8dåM¦léW±ôrŒÎ÷™ºø>ªvÿ„ÉK~:R~ÈÉóEÇü%êÏØ¶ëqO¡FãU%:±• LÓĶ{ÞÙD¨½£ô¡ŠPC¡ÓíëX¿ù1üÓ›i+®gñ´ëã¯Ëšà¤¼ý)ªj*¨ÝÛÂìàmØNp:]cB¨£a6¤d‹Îöï?H}ýq®h J¨ûö Ý›ÎhøføîÇ0ÇCM²§”©Ë_aï×2má²r‹ÖwÎÃ,\õ•»ßeÊÒŸzÞëíÛû8 ‡wS0i‘¶—Hɸ“`ëÏ›ò]2qt*JL¨ Ñ]¦ŠþsiPu(…t.c¨t©=VùíííL?é´bª««# î!í,ËÂ0 .X´ݘËÌ–<µëü'þJǬV|I“h UspÏÌÆ >Yð}rÜÉËÍ3j÷”8åšMù°¨/‰ŽLc´ƒD":©©©hšÆÂy‹£§†Ú3{ëË?o¬_GFf4*Õ ƒö`pTÔc"Sþ)ÞR¦_ñ ;_¿–é f‘3•ÎÆ‡ðæ?AKÝwú‰PÓÈ-¹•Š72~ÚõX÷£z>MÛ‰=|0ò)¿iFe©:¨¯«'Ø%DN§FÑ„¢RNT„Úp8ƒ{yûu:TÑ5¤Ñç΄ôhẜüçƒÿ½¶vÖ|>ù‰ÛÎ]¨¦…aTTV°aÃŽ=ŠÊRü…›ØêßKÉŒØP¹÷(fe!ÉÕóXË[”””pùòO–Yþ>èWª# Ó˜Hü6,¾ð¯÷b?øÁ£\÷·×ð^Íïh‹œüÜ$G ¯"+¥€5k_åKwÿ;N—‹¼œL,ËF×Íø5ÞBTª³>ò ;^»–©sÊÈ+º‚ãÕ/9nU?K„–cë),¹K¯@q¤ly‡ÓwF™oÊo˜((¨ŠÂ¸Â‚ø}ç=~báiì@í®é);¡#^|õÿ(/윌è ]Ñr~~ Ï>÷sfNŸÁõ×Ý€Ó™Ô#šîÝËž\Y **öÐÔÒ:èÕ4 lÅbñÒ YæS]½`t³<ȺÝO [‘~/±:ŸSþ~¥:BÇdÛ6i©nŽ­'=Í ”NžÈ²+ðǸ¢ìfŽÒÀ>yÅB¬­ddd³k÷>sÓ? >å7MZZZX0o!iN͉ÓéêÚF¯“Óu½ëúÓº¡ÓÞÖÆ¶¶¢ëú˜ZFâN©¸TGXð<ø_¼ç^šNøWÇë%3#“ÔÌ\‚‘V’““(K¿Œ”\*›¶s¼³‚ìô|Rœ233q»Ýäæ(ª=‚¢(h=pB×Á-)HÕSÌ´¥ßcÚÒïõù|ZF1éY…8»»ãW¨j[[ÈÎÍ?fêE¿¸P‡çÂþ“ÑeáøqÝ"Sµç­“]£kaÙ'%•ˆ1ÔIÅ¥D":þ@ Áön‚´±¬ècUUIq§öi¼QtEÙ±ß>ŒÛí¥¸¸dðªià÷‡Ã„Ãaª««¨¬ªdJI)ÅÅÅÝöM¡¸8Ú1ùýtCÇ2Çn8bR½cädª( ùùùÜñ¹Ûøå“¿¦´¤˜@ ÔT7éÉ鸲Ýã¨lÚ†nv’“VÄ–Ú54³²ìvÜ)Étvv2ibµ5µ|lÕ*f͜Ʉ¢¢„\»=–±­Fl£ Ë:4àÔR±Ôe”¿¹šŒñŸ&«pÙÀ…:\),>\{ä”[Oã‘h·ÿ¸ˆ(Ô²²9”o}—å+–acÅeyR˜ôlìί“2í)àÝ»÷pËgïôqÅ&¥ü~|_eU7~úfžYý;vîˆïÿ»>Å /þ¾›Pýèz$áj÷ §s¹x¨¥ºèލDû’êH =(Š‚Çã¡´´”ˆ¡¤d2þóz4‡ƒ`·É¥‰ž“ †¯(¾ þ|kk€é«Êxý7Yºd ³fÍ"555áË4ަ” „#̈‡R†E§'ÛÞ~‚¤¬+™:ç_Ðu=ž&$åJ Z`}¡‚‚i™œr!j·2éI)Û¶)+›ÉsÏ=Iª[£¸x"Ð3’Ž=Ž·gô2+»k‘‹è}óÛ¶í -5ƒââ’A/PMþ“‹—M›Ž/;‡ÛÿáÂáP|{{[yüQ‘ò÷·8Ê@E<’ë‘&b×áp ( MM¯;Ê¡êjn¿óvÒÒ<ý—ÇÅ_@U~ãQŽ9ÌÞ={h øÑœNÜn÷¨I÷Çþ–zêo¦µþBÁ:lÛAæäGÈ*XŒmü£aIùu]§  »v0göÜs*àƒÈõåFïq¡bÛ6‡ÆòåWñÇ?þŽ¿üeàÞ/-ÍË 7Ü—í¹6´ÆÆÆ®[_="Ôö`;¯½þ'öîÛC(êq’Nœ8ñdcñûã’oll$''gÌ5ø¡–ÜhZ‹Õ4MB¼½a mmíºI¸[}ö޿޾ñlÛ" ÓÞÖΆM[ u†0ΰÑHÕS"n,¾ü™dåNG×u"‘¦i¢i.— §Ó9àswÈS~Û¶inn&ÍÆk¯­ã™gŸŽÎNÇ.Úï6“߯Ÿ‹nE!''—â “¨¯¯§°°pDÆ„E!))‰%K.&''Ð_‘‘Aii)IIIƒêµ›ššÐkÖ¾Š¿[„:q‚Á óçÍïõÿPIMuwj€—_y —ÓESSSÂ…z¶2û°¯˜ŸœœŒ¢À棨*›Þ/p{éìì`ÿžÝ¸\®Q‘êåúRU•¤¤¤A-Î=ä)¿¢(deeQV6)SJ忿ި»¢(hšFVV^¯wÐ)²ªªhš†¦iƒjè>ŸØŠmÛ”—oå<«¿÷z½ÌŸ»EQðù|£‡ØÄÔœÚÚZLÓ<«ö»ƒnüøñŒ?^&£̰¤ü.—‹¢¢¢!ë5ί×{Ο[m´Œ)åääÄ£ÊïÍù¯„4”s-OáÌmÃëõ²téR,XpÎ_âr¹HIIT[“:‚ú\½zµ½råÊ~SûsåA8ßPûKùûÚ/‚ œA¨ÝÚ;åAÎB¨Ý£ÒÞÑi_ûAIùA$åA”_AR~IùA$åAHÿækÆàÛíú-IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/axispo.png0000644000175000017500000000573513070106167015161 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDùC» pHYs  šœtIMEÜ ^ThtEXtCommentCreated with GIMPW 8IDATxÚíÝ_hÕÇñßì64±RlVz Â%V$  Õ[zm¥B 7ˆøV|óIñ"⃢‚*>ˆ¯"¡ˆôVn±ÅÒÚ–¤1¹½h½âK¡¢´QÑÛ”ívïC˜0ÌìÎìœ3gfçû¥›MºsΙ³3¿9gvÆët: o5š€@@  P¨@  P¨T P¨T*¨r´Îø;.-Iþ™ý}6n\y”MÕë@yN§cô{Lúè£ìïóÒKÒk¯•¯E«^*ˆ)? €@@  €@@  P€@¿d·žùýwéÕW¥™éÚµîûÛoÒòrö’mØ Ýxcï¿’ž|RzöYiýz;­TõúÊwâ„ôÔSÒéÓîK>5µòï;ïHwÞ™Ï2«^` PIR§#}ø¡ôâ‹Ò… ù—xëVé­·¤éi7-VõúÊ÷ÇÒoHo¿-]¹b¿¤7J/¿¼2B44ä¾åª^` Pù~üQzî9éÀ;%¬Õ¤'ž^]Ú¼¹x-XõúÊ÷å—ÒÓOK æJwÿýÒ»ïJÛ¶¿%«^*ÌÜex@š›“Þ_ºùælïuÛmÒÇKG–'LT½þT˜¹ª _•^yEzï=©ÕJþÿ6l^xAzþyix¸¼­Zõú@ 2èÛo¥gž‘>ÿ¼G)<éÑG¥7ß”n½upZ·êõ€@eСC+Áâ»ïÖþnÇŽ•ó„î»op[¹êõ`Àåsë™}û¤ÅÅ•K ÜtÓÊk·Ü"}ðôõ׃&ª^\>#TA¿ü"}ò‰ôøãÉn­2hª^T[733£ýû÷kiiiÍ/GGGuéÒ¥ÕŸ›Í&-T’´´´´ž‚!*øóè訦üò`ÕêIéáõ:bÕ¦M›®{ÑOÁ`€h©¦ü£Tív[sós:÷Ã9-//çRàááaÝ1v‡&îžP½^g €b*?<…CTøõ°¹ù9ýôóOÚü—Íj]måRà¡ú.ü|AZ&'&YƒÀ¹LS~ßÿð½FnQ»ÝVÍ«åòh_kkdxDçþ{޵Ѝü)¿pˆ ž ®./_VûZ[žçåúhwÚº²|…µ !Ó”Ÿ$Õj5ZTZæoùå=:å? ¨úò“VF¨\<’h4j4k~¾õwèßÙ³gi€Ï è/•“yÊÏS1G‹†.^¼¸æyøµ¸¿³QŽ*8þ¼ÆÇÇùd|^PÀþâbŸÔkÀÂõ>2®|i˵NZ™ò ÞË/8å×ë é^­\Óo~ÃE5”0å:Tu«ï ¨B`ú°çYg×ËGyúe6ûëíBQ·KÁ}RÔƒMN':C8<…§WN»ÿÌtaÏ$ñÈô#«Ïì†ëÎßIzž—úyÙ¶ e:NÓW†:Ž<ϳZ^Ç+—íÑ+ì%]—Ù¿åçÕ}è<Ï».\}úÏO­7X0<Åíüi?Ó;‡<“Õw$ƒØ¾½êg{£µ±‰Ú !Ìr?H[ï¸SÂëiPÏu} [„é~÷I¶CUQ‚Tšrùm’Tæ)¿$*xdâÿüð?^ýù³CŸYÝȄϟªÊ†ØVX¬J˜J²°q¤d7޶BMÒ  ­F\p ÊàóÞÆûÚç.BƒëÐRÔ>ãï£m†ª"PÅmã¢Êè·I’ušyʯVï¨6jzj:vGåyžÚ÷ÐuŸ×уíEÈ{ù½v>e YU™JZ7¿_™Ú€§ S¶BUÚúÛ^'q£@EßQæut_¤)?$ß'u•1ÝŠ:BeÒj ‡¨¨×#ß Áíbz5²ÿ¤é©éÌï™dyÁ£{[䨑±<—ïºþ„) Ê(éëE*£©¿/sh¨âòÓî“üŸƒ!·Óé/‘¯!.[¿eÍ>å—ðšPái¿ðï|_üë‹Ü‚EpùyÞT}ù„©ø:¦­Ÿ©Qª~G§LŽÜôóÿ«®ûí/¦vDý>·Ù.G]/¿¨a:Év¥[ùÊð9Ï|aÏ$W5onö,HópSÍÃMëWJú¿ÁQ²àè#•<—ïºþ„)`°·iŸ#ÿí¨ßþQ3áQ*[£@qËHz Ûý8K?Í<åW¯×=z™Ú;•ø½’¼_? 7¸²Mì¸Ãëy/ßuý S(û(ªßE}{Øu9“–¥ w…`Ê/~û<é:*XÙ Uáƒönå ?Ê"·{ùÅŽø -IîyÐÙ½ü‚AÂÅ ¬úò S@ÿ;Ê4'ñ›ü,…·ïižÛl—Û ×ËOªÂÁ*¼^Ãß$6ÙWŠ"\ž¨À—f!ó”_½VOô8òÕ‘ÈU{wïMô~&1¸|“GqG*y-ßuý SÀ`+ã”_•ïÛê×=*HÄÝû6ø{S}%IØ·õ¥©$ûã~`æ)¿¤#Já‚=vtMeüÆÞó÷=ÖF¨Â;ç¨å›ZQG*y.ßuý Sý­›~¿µeê„ð~?_ßr„A iÏ¿±Ùeù–_T¨ê˜³Ô);ÛÖí®âÊß+c$]væ)¿´ç=ù­×ë:vâXìN}÷®ÝÆÏ¡Š©q*ª¾|ÂоƒîÕ‹°Óìç[~&·!®¦üÂ#I¶½îŠ<å.g8DDp›ZgýŽNšš¦¯ï$eI»ììö¬%¿&Ôñ“ǵóÞ:~òøš×‚—Uð/,¶ëo»®û[[ªÑhD.?ËW_»Ýî&å»®¿‰Ÿfƒ7(á+í%L_ ?ª?0:ßNE…y]~ÅÅ…=»]lµÛÏU¾eøÂžI/îéoLÀ' 2¶û­/`eÿ–_Âs¨üÇÉÓ'#_‹)ÙyïNãçP…—5Õ‘u¤&ØY£:®íå»®ÿ pñåˆàúèvþ@ðw¦7>Áþ¤Ž¶6~qçPØ<·¢Ÿ÷-ÒrËp!Ò"ŒâåqSñ2]سW?1ñ»4#T6?S¶ÂÔêU– {z53;•S³§´cûŽÕ£¿Â§fOY;º ŸÛ<2·}ù‚*/ŸQŽt# ..v\~·Pes¹î½–_”Qªn#»¶§¸ŠraÏ4}%¯Qÿ²nÏ‚¡Çd=\Ã/¸³Õ2Où™-òÍž™Õö‰í«ž=3›ëÆÒtƒw»oRËw]ÿA9šu]['h}ùeXïE}U=âà¬{ðîvµð’]¬›Š6­óŸD…¨ðëQL î›_˜×¶»¶i~aÞiŠ5uaÏ´ïÅmÀNà3kó©[ùl_1}eŸò³Ððß,~30†ªõnÙ²…OÀçí/I¶ïDeT™¦ü P¡ÜÆÇÇi€Ï è/Õ T~x ‡¨ðëQLžCPÚ@Õï”ßÈðˆZW[^?œk¡———µ~x=kB¦{ùÝ>v»þ½ ÖÕ–jµZ.V«¥Åÿ,jëØVÖ(„LS~÷Ü}Î,œÑ‘¯Žèòÿ.çRà‘F4ö×1MÜ5ÁÚÅ TýNùÕëuMNLjrb’–••iÊîåPu©¦üšÍ&-ò0†•:\J]IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/winmerge.png0000644000175000017500000000024013070106167015455 00000000000000‰PNG  IHDR¥ò  bKGDª#2 pHYsHHFÉk> vpAg£;*Ñ/IDAT×ch`0`ØÿÆ k·M`XÿoÃò?ĉ#ßÀ Àp€A ¶"á’`@)IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/datapo.png0000644000175000017500000000564413070106167015125 00000000000000‰PNG  IHDRTPß–ësRGB®ÎébKGDÿ3'|ó pHYs  šœtIMEÜ-">ÒtEXtCommentCreated with GIMPW ÿIDATxÚíÝOˆUÇñ_ugH‘`¦%‹–1"š1CtCÖD" doñàÍ“âDă¢‚âUD"Ùhà ‰I˜É8³Y4®x D”dTtÓ¡Óé= 5Tjªºëß«WÕõý@“žžI¿ªW¯ëýê½ê*§×ëõ€ÄjT €@@  P€@@  P¨@  P¨T PähU0¤–—¥?ÿLÿ>7®<@(§×ëõ¨†!ôØcÒG¥Ÿ—^’^{ú ¦üT* * €@@þ¸õL™üþ»ôê«Òì¬tíZÿ¿ýí7©ÝN_æ† Ò7þ»‘éÉ'¥gŸ•Ö¯g[T(¸'¤§ž’NŸ¶¿,ÓÓ+ÿ¾óŽtçl %ÒëI~(½ø¢táBþåoÝ*½õ–43ö¨T%÷ÇÒoHo¿-]¹b¾¼¥—_^!¡þ P ‘”ž{N:pÀÌû×jÒOH¯¿.mÞL}@ b_~)=ý´´¸˜Ý{Þ¿ôî»Ò¶mÔ/¸l°yài~^zÿ}鿛ӽ×m·I,=J˜ F¨†Ù¯¿J¯¼"½÷žÔéDÿ6H/¼ =ÿ¼ÔhP¨ o¿•žyFúüó­Á‘}TzóMéÖ[©7TXãС•`õÝwk·cÇÊyR÷ÝG=çPUɾ}ÒÒÒÊ%nºiåµ[n‘>ø@úúk 1BUU¿ü"}ò‰ôøãÑn-T¦¬›Õþýûµ¼¼¼æ—cccºtéÒêÏ­V‹ð*IZ^^^ OÞåýyllLÓîp°jõ¤tˆ z!jÓ¦M×½è†'o°@°XS~þQªn·«ù…yûáœÚív. Üh4tÇøš¼{Rõz-ЍÜðäQþ×ýææõÓÏ?ió_6«sµ“ËÔGtáç Ò¢459ÅÖ¥šòûþ‡ï5zèºÝ®jN-—G÷ZW£Qûï9¶(N r§üü!Ê{‚zP¸ºÜ¾¬îµ®ÇÉõÑíuu¥}…­ !Õ”Ÿ$ÕjܽT[êoùå=:å> ¨’NùI+#T6Q4›M5›Í5?{_ ú;$wöìY*àóÚK夞òsTÌÑ¢f³©‹/®yî-ìïL,Gœ?^|²>/(`{±Ñ' °°ÝG†-_ÜåZ'­Lùyïåçòt…t§V®é7·â‚*ÊD˜²ªú­ï0¨B` ú°ç¹Î¶ËGyÚe&ÛíýBQ÷KÞ>)h€Á¤^¯œ!,žÂ3¨ Çí?S]Ø3Je<2óÈêó¦# j@Y6ª iE›GÃ…½¨Û2ý·üœZ¤ã8×…«Oÿù©ñ 󆧰ŽÀö˺sÈ3ùW½#Æú´~¦wÚA;› N°av˜ÛAÜõ;…Á¿†õœQÛ²E8NÚ'™UE Rq–Ë­“¨ROùE TÞ#÷ç‡ÿñðêÏŸúÌèNÆþTUvĦÂbUÂT”€‰#í(ÛÌ»s4j¢îMuaÀF0(K€Ï{çmÿqŸÛ ¶CKQÛŒÛG› UE¡ ÛÇ-£['Q¶iê)¿Z½ :Ø:¨™é™ÐŽÊq=´ï¡ëþ>¯£Ó Þ?Šwùƒ:Ÿ2†¬ªŒLE]7·]eµ¦L…ª¸ëoz›„½£Ìëè¾HS~ˆÞ'õ•ɺýu„*K«iÈ¢‚^|ƒ·‹TÉîC’f¦gR¿g”ò¼G÷¦vÈA#cy–o{ý S–(êëEZƬþ¾Ì¡¡ŠåÇí“ÜŸ½!·×ëe¾üE¾†¤Ù’.kú)¿ˆ×„òOûùçúâ__ä,¼åç=zSõò Sáëwý²¥J::•åÈM’ÿ_õp´½dÕ%}n²>lŽ"Ú.¿¨a:Ê~¥ßò•ásžúžQ®jÞ:ܸ ­Ã-µ·Œ_)=èÿzGɼ£7&ŽTò,ßöú¦€áæÝgÄ}Žü÷£nýÍLøG©L…•õ¦Ûqšvšzʯ^¯Gz 2½w:ò{Ey¿$ ×»±³è¸ýëy—o{ý S({Ô=l{9£.Kî Á”_øþß{ÒuP°2ªüíý–Óÿ(‹Üîå6:âV´$=¸çAk÷òó °ê妀äeœ“ø³ü,ù÷ïqž›¬›û ÛåG Uþ`åß®þogÙVŠÂ¿ÎoXÂWÜK d}%ü öÀèTx==æuùöìw±Õ~?Wù>”þ {F½¸§»OÈâ>j1ÝnM|+ý·ü"žCå>Nž>øZØHÉÎ{wf~•¿¬ ©Ž´#5ÞÆÔpM—o{ý‡/Gx·G¿ó¼¿ËzçãmQÖÑÔÎ/ì “çV$yß"] · "-Â(^7/Ó…=µ“,¾qg„ÊägÊT˜Z¡JsaO§–M§rjî”vlß±zã®ð©¹SÆŽ.ýç6yÌM_¾ Êå3ÊoÄÆÅî¼å÷ U&·™íö0¨ü¢ŒRõÙ5=ÅU” {Æi+yú—uæ =Y®‡íoøyû8Sí õ”_£E®¹3sÚ>¹}u…çÎÌ庳̺ÂûÝ7)òm¯ÿ°ÍÚ^S'h½ü2l÷¢‡¾ªqpÖ?x÷»ÆšÿFÉ6¶‡ÉE“Ö¹O‚B”ÿõ Y îZX\ж»¶iaqÁjŠÍêžqß‹Û&€Nà3kò©ßò™¾bú0K?åg â¿Yúfh> U;êݲe Ÿ*€Ï Ú^¢ìß9ˆJ¨RMùe/ ½T3P¹áÉ¢ü¯Éò*€Òª¤S~£Qu®vÔXßÈu¡Ûí¶Ö7Ö³õ@!¤º—ßíã·kñß‹ê\í¨V«åòèt:ZúÏ’¶Žoeë€BH5åwÏÝ÷èÌâùêˆ.ÿïr. vpAg£;*ÑJIDAT×cøÿÿ?âÃP bÿ±ÿÀð·ˆ?0üùoÀðïOÿŸþÕÕç0üw7`ø<á¿ä†ÿ{€ô? ÿû&/‘`w¡IEND®B`‚ngraph-gtk-6.08.00/doc/html/img/Makefile.am0000644000175000017500000000117713070106167015200 00000000000000htmlimgdir = $(docdir)/html/img dist_htmlimg_DATA = barc.png baxispo.png bclear.png bcross.png \ bdataopn.png bdatapo.png bdraw.png beval.png bframe.png \ bgauss.png blgndpo.png bline.png bload.png bmark.png \ bmath.png bpoint.png bpreview.png bprint.png brect.png \ bsave.png bscale.png bscundo.png bsection.png bsingle.png \ btext.png btrim.png bzoom.png winaxis.png wincoord.png \ windata.png wininfo.png winlgnd.png winmerge.png icon.png \ aclear.png addgraph.png axispo.png datapo.png draw.png \ eval.png fopen.png infowin.png lapoint.png legend.png \ lwindow.png math.png pointer.png scundo.png trimming.png ngraph-gtk-6.08.00/doc/html/img/lwindow.png0000644000175000017500000001574713070106167015345 00000000000000‰PNG  IHDR]P#ƒÀÜsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœtIMEÜ:²)â•tEXtCommentCreated with GIMPWBIDATxÚíÝy|åçñOUR·Ô:Z‡%˲eËò|á¶Ä†2lB!Ùì2a²ÙM„ ›°™LÈäµ!ÇN& ™d `Â0†sÛà‹ñ}I²åCÖiuK-µº®ù£Õr«-Ém©Õ]¿÷ ¿ºS}=©.u}ë÷<õ”bY–…B!„Sª¬!„B ]B!„º„B!„„.!„B ]B!„º„B!„„.!„B ]B!„BB—B!„„.!„B ]B!„b¤œ² 2èôi…Fÿ>yyÑB!„°-E.xA·Ü>:ú÷ùÎwà¾ûd} !„6&Ý‹B!„º„B!$t !„B ]B!„º„B!$t !„B ]B!„º„B!„„.!„B ]B!„Vr T áÿÖ­Óþ¹„ãÿÌœÈÍ=÷ó\.ø»¿ƒ;,ù®„B ]›6Á׿[¶d¾-kÖDoö3˜=[¾!„BBׇŒeÁÃÃ=÷@ccú?Æ øéOáºëä»B!$t]ººàŸþ xz{ÇþóòòàÞ{£•6—KÖ¿B!¡ëS_wÝO=56ﯪðå/Ã¥¥²¾…B ]¸á߀;S÷žW\¿ø,X ëW!„°!™2"V¯†íÛá׿†ââѽה)ðøãðÆ¸„B“JW¦utÀ÷¿¿úhZò¯ËÉo¾õ-ÈΖõ(„BHèIÙ¿î¸Ö¯?Ç7¦ÀÍ7à ²Þ„B ]bD^|1¾8û±¥K£ã¶–/—õ$„BŒ32¦Ën®½víŠN/QP]V^=›7KàB!Æ)©tÙYK <ù$Üzkr—ùB!„„.!„Bˆ ™ó±Ç㦛n¢½½ý¬ý~ÿ€å6l5&„B1’ÐÐÞÞÞ°âƒVâò5± ' !„BˆóÒ?>1h ¶\!„BŒ"tҬø€•¸\!„BŒ"tÅW·«\ƒ-B!„#]±€•´— !„BˆQ„.é^B!„HCè’îE!„Bˆ4„®XÀJ Z‰Ë…B!Ä(B—t/ !„B¤!tI÷¢B!ÄØrƬø •Ø­(Ý‹BdÞ¦M›X±bň_Ñ";~”Ö¶ftÝ,b—_µ, §Ó‰'ÛKnŽ_^%E¥¨ªj›ö' »yô?¾K¶3—¿¹èN¦.´Ýö „lo]‰×XŒï^MØ***JYCÛÚÚFýÒiÏx Gõú£ õ³xá%ƒ†)ÃÐÑtH¤—“'Øôþ[L«ª¡lB9Š¢d¼ývdYõGqºãô€å4|•O\þÞ:ñ0¿}뮟ð}œN'– ºÅ…ÅTWÏÕzý0®O1¸/þ÷Ûh<Õ”’÷ÊÏóñÈÿÿYYY²½e"t%{íÅ‘°ØQôh(ŠÂ=÷ÜÃý÷ߟ’Hi´g,ù‚žýªÃMÍ,]²œpoÓ40M3úÏ21M,PU•,wÕSk˜V5Ý{wòî{oqÉ¢å¸Ý˶·yóÍ—Ðtí¬Ç²³=¬ýا˜5s^ZWÝ‘Cäåç1wÎªŠ¢((ŠÂ?ÿá$ÓKPç^Ï;v²xá2üþB,ËÂ0LŽŸ<ÊCû˜Y3;%69ãåàd<µ5ZZ[ …BÜö_?ÏìÙ1÷¢¹#zŸƒ°uÇVÖ¿¼‘£ ǘQ3=#ßž#¡zZþˆPë»øÊÖP<ãnœY¥cºb+1h%.OEQR²#M5;´+Ö†L·e4;;~·é Z–±Õÿ˜]˜¦é(Š‚®kX–…i™ÑÊ‹½5MM×èéí!PZ\ÆÂ‹“ŸWÀ{[ßåÒe—ãp82Öþ×_‘Ë.»UUÏƾð‡Y¿áIü…Å”––§¥=õGSR\„ å蚆¡*¨ª: Šûk …ºÈÉñ`ô­ëŠòJœª“ý÷2{朌‡˜ñfŠŠŠ`ëÖ1o«*K1G6P^^Že™†N¨»‹û|?§;†|M Àçó¡ª*…ÜuÇ]XŠ…i˜ûý9z4#¡k¤û EQÆì;t¢aÓ \tÕÓx çÑRûGZ=@ÙÜMè«îÅñ"2ìcíÊT›bŸ¿^†»ÿa_É®Äàÿ\;/ÈŽã2M“¦SMD"Ú°Ïݽ{7+¯XIõ´étƒlÙ¶™e—\š±ÊL8Ü‹eY:¼ç¬Ç|¾&O®âü¿!·§ÓÅÊË×°xÑe)iO[{+'N$ØÙÃáÄépâp:qž9žíçp8PTÅ41LƒPw'¯—¦æS ]‰•‡øÛpU‰L„³XàÆ4xÙ­²Tô(Eþ|,ËÂírQW_KkK+ .`ÇŽκþýšD"œN'm­m4·4ár90M“ü|uõõ¶Ø¿eú`>¸æ~ì9<ù30v +®äÈŽŒ]èËîÅó­î¤»Ú“øÅÛ)x n2}T2Ôýt~OvøŽW²¯Étð2 «ï»+)-ŽV¹úÓÇþ™}•Ë2 tuôÿ=Λw1m§Ûiim¡´¤4#í× ƒ@ ƒHoäìÐÛŒÏW@uõt,Ãèë2VñL+Z Ó4×^1e¡Ë4M²ÜÙÔ©EíëVTE={‡R¤Ž`g†aôW誦LÃ4ÍŒnñ+>Àœ«(ÝU± `É’1 ^v«,:|˜’â" ÃÀáTi;èX‰·.—‹ùóç³xÉ"fΜËåÂårÑÕÙ‰iø 8\Wg‹}ܹ2ÀXàE×ß0çê'ÉöU¢÷|€â( ýØ øÊ¯“ϼàÏ^´K°‰oKb;2Õå˜ìgÚa<Š—¢ ^å²Sð2ôè¸-Ó2iijEÓ´aŸßÛáégžÆï/äŠËWRYQÉÉÆ ]†nÐÞÞFww­­Ý´´Ï\TU¥¤$ââ4-’²ö˜¦‰ªªèšNEE.—«¿â•hBÉüE…hšF8ædãItÝÈxèJ6” WËTà«àe·ÊÒ‘#GøØÕ+1MW–‹é5ÕÜû½ï ùû¬ªÔ„à¯N·w–›Roo¿»… Y,p]tÕ#xò*ÑC¯£:Ké8ù µï,“Óõ¿ôµîœ©x —à+ÿ¾²ŸèJg÷â`b¸[‘¹à•ìgõÑHâg$viÚ«KØÞÛ‘ÛÁ[E%…Ö¯e…qU/on6M§š¨¯¯ç©§þÂG.¿œ­Ûßgþ¼™©té:-ÍÍD"½´´yôOëp r+|ŸÿÂÍx=JJCŽiš(ªŠ®ë8N”h¨ä3‚ANM×Ð4îžn C·}èÊüAÎð‹%KR^y³[eéDã)jjªéîéfÞE W¹cÏžm» Ñ™WSÁêåqõeO,9ÖpÇCG €®ë8Î þ^*Iݦ¸ã;î¤rñ/“]ñÕ­±ì^´SW^¦«HÉœLU•Ãh²÷3ýÇ›Žð5\×âPák°÷ÈTc,t—9µ.~]öU¼,bgDors}£(ŽŒý­†6Èàÿ­;Þöu½òšèÎ+¢áp§îÈ>>5Mç±ßcõ²µd¹³y}ÇïÏzîaåe¾xÍl:õ8¯îxåÊÿ@UÔqQé,põx®ó \©lS2•¥d¥¢²dY¢©éWu´çñ »Ør¢ˆ©KV±jN5¥r³̪˜Æ†|?'êyà¡×ùæ­ÑIM÷ï?H~^¾-ÎÖOܧ w?•&/ù ‡Þø¹ùRXVÙ…Ó³ §çbŒÞçø2L,«­sŠã}ªü=[ž]CwÇ.¼çž®&íÝ‹‰¡"ÓéÇ[Å-!g¼®w;w;Ú¦Ò¥ëÑu„BKKëY•.‡ÓAiiñÀ0ÖŸ½,P ¢õf¬ýºn gÝ/Y¸ô<ÖAj»U%:¦K75‡ÞaŠw7_q7oíºÿy™¿–+f}šý=èÖXf=½=¸\®q×½˜ŽÁó™ \çª,¯TU–ºB!"œœœN'‹,ÕSLõUwR½t!Z×iÖ=òS«:Èõz¨;ä¥xúøŠ+9²¯Z¸|ñT4]§+º ³r§1ýŠgØ¿ñzf,ºŠÂ “ˆt=#k&áp6ï=û%,kð¿K‡Ë…Â4f­ø{Lm+zÏ{ÌXömêöü Ó–ÿ:¹Ð•îîE»NÍ`‡³“©t¥³Â5›„­sWº, dBqt ’¢D3Vì6¾t׺¢u/%:?ƒíìd…d+]‰Õ¾TUºÂá0³­O²ñýŸ˜ÝFgUËfÞÐÿ<ÿd[»þDÝÑÃ4ìkg^èKX.p¹Üã"tÙá,Åt®sU–Î×h+K±×‚˜|õÞ®ëüüçÐbøye6¡`§önàoo7((ðâvx˜{˾vï/#¯t¿øÝïÙðLÓ´Ð4£ÿLe;üNgâ ùl_ 3V=ǾW¯gæâåøK+ 5}oÉ},^û3j÷¼Íô¿9û7Hëâä¾_Ò|låSé|OÁí„:~“Ôçf¤{q°e™H?\ØÉĸ%»„R»ÍÓ%RP)ê ޾ñXŠ ] Ñÿú¾ÇèÿŒå­%¯T†–ó¯Ô}í8SÍìêêbʤ©Ãî@ ‡{oJC£išèºÎ%K– é3§}Ú}ÓÿA÷Üг¦Ð®çÐÞã-|ºü§”x§0¡´tÜTºâ»Ç2€±õ·°d° •¦À5\e @‰h >¤àÕ((ŒV·F[Y²,‹Ü/ÇO4‘Ÿëj¦MaåêÕ|ÿÁç1Ì›¸rÉ$n\öQ43‚ßSÎç®måw/Õáöù1Ý…tvžBUUºB=dge¡fðw;“Ý‹1ž¼f_õ»^¹žÙ‹æRT2ƒž–Wö[Ú4D¥+—Òê/rxÓMLšyf÷½¨¾ÏÑyúà€ß¦aCWººÇK·ÏP] *;ÌÓu®ï%]ßY[[ûˆæèJ|ŒVºPTMMD"ÉMŸàr9©œ\9 ¸e²RÓÛáà¡}¼ùÖŽ9ŒÞ×}:˜É“ó£?znÿçþWtî±¹ ùô§¾4òÐe˜è†ÎáÚüóÎ;?q•*6³-°ê‹‚`Aí¾µd×/`=oP]]Í•«VSU5MÎ^ÄÁ+ k¸ÊÒ'ÿË'x÷è¿Ñ9ó¹YŽ\W\ƒßSÀ‹ë_àwþo\n7J SRYúá?|¯ßu7­§L,/×—GaA!.‡‡î®Ó`è„ô }%œînâÝ#O *.:µ‰„»h–…¢8t†P§ÃÁ¾woF¯.až¼æ^ý;_¾žóg1¡ò*NÕ?EáĵChEh?¹‘Šêë0µÃ(¡öçp¸ŠÏ¸úCWººí6~°‰Q‡{,]m¶KµËnót 7æïBx>•"UQ˜XQÞÀÿbe.Μ`õÝFƒžövÿõ…'غõ]ŠJ ¢“»öUÝÊÊ<<öç™3û"nøä¸\YªrCOQ‡掠½cÔ•.C×±“e+–²¬ÿ‘ÏöÁFoV•e@Üœ¬šrz »ÉÄìóg¯4µi¸ÊR@?ÉU³náDð­¡cDŒnœª›Üœ\r<^>ò‘ËyþÅõ4·´ÑÙÙ=êÊ’¢(”••ñ•/‰ß?ôGjª«;ÉÉñ²hv5ïíÝâöðö{Íl=´™K¦_Š/«˜ö®ž\¿ÞÞ2¬p3%¹Z§ÉÇ×®eîœ9L®¬ÌÈÈçs0Ÿ®ßqo~ ¯]OÃîaߎG)©ºŽª‹ïðœž`ÁÖ„ƒ‡ñO˜DyÕg1:~€Ë3@s€ÜâeI}VF®½8ØŽ=é“©šØ©:—îPa§yº’ ¤¸’©™ýÛRãÉSôö&7(Þår1mÚÔþà–n[¶l⺒ÂB_¤:Ó¯cZ==!š›Ow÷ϰߟ­3gbÆ6‚‚"vïÙËçoþÛQ‡.Ý0hoogÑ‚Åäú|¸œ.\.wßmtîMÓúæçŠ é]lÿ`š¦ÛJW:f¤ï^iCU–r K E:ÈÎÎbVþR <¥Ô¶îàTÏaŠòËð¸|âõz)-Q8Òp|Ô•%EQðù|ÔÔÔÑ"TWOãßÿ}#N‡ƒ ªùÕãoãp{Д"¾ùÝ7ùÔG;q:ËyöµF:ºüXªB^ø ³jŠØÖ ±bùræÎKNNNF‡…Ø¡{q@ÅËWÅÌ?a抟 úxnAùþ ‡U‹ÕýTµ˹˜]ïÿŠ—þkò¡+Ý“£Ú}üÏPGÇénCüzÊô°í0OW&‚çàGý#ïbÌøe€Ì3UªŠIã*\êÀËØôÝn{&¦u&ÈdbL×Ôª"@°îPW\ˆ²0Íè}UUñxs.+VÜßѱcÇðz󨪪}¥ËÐ ‚ôööÒÛÛK}}µuµL¯®¡ªª nÙtªª¢á5¢é¦1~»Ó¼¾’¾À5\e)?;¯ËG‘w"µ­ÛÑŒJr+ÙÒð"m¡c¬™u^O6===LRIÃц”T–Š¢ÐÚÒʩƩ¯ç¶Ûo#7×ǤÇ{Ü8²ó˜8e2uÍ L™:‹“»ŽQâѸöâBžxò/tiN— ¯×+]‹ç»O6[°ô:LóЌ˙ƒ©®dëëë(˜ô9ü+“]™œÕî3Ò[èäq‰UI;ÌÓ´ì¼kFlYlÙâ‚×ýÑ£ó%^¨¿¢w&cXÉ`èš5k>[·½ÍªÕ+±0ûÕ™PÅ€ ›aÿLàÒöìÙË­_¸}ÔíŠ ¤ýËjëê¸és·ðèº?±s×Îþ培ñ³<õô_âBWM‹d¼Ò?H~$ ¦:x-ùJ4h ¼ÒÑÍ9\e)7 ~ŠoaÿýÕU_è¼£#Èìµ³xåÕ×SVY2 ƒpOo¾³…ÎÎ.tÍ 7fJ~M×9ÕaßaÀ„"\.''[ y;…•>œîr®\u9/½²‘ÞpØvûV»ŒNoÄñáP*@7é ìbû›¿%Ëÿ1fÌÿš¦õW¶Ïºâ«[é>{Ñ®Õ-;·1ݮ㭙ζǯsý–Ú!p Ñu4ؘ.P0Lƒ³&êŠ[­éHoY³fÍáÏ~ˆ¯“ªª)ÀÀŠ\ì~´Ýf¸ŠN1aõ]¸8zÃíÛw’›S@UUõ¨+ïÑJ—A0<gΦ¸¨„ÛþÛWèí=³ƒëêê°‚ -º‡ºàu²am,‚P|e+]®d+KC®Ë¾Šª:8öêœ8~Œ}{÷Ò ¤¬²”¢À®v ¨*›ßÛ:pÛÍ*¢Ç[Nm³T'„ÛPÙs<@¨e6kV-eÑ‚ùüñré¥—Úæ€~¼´7Ñtì}:š> jIJNû!þòeXVòFy÷¢ÝV®´GÚ“êàuf'ä·mЂ踢òò víÞÉüyhÝ:|ÒâÒè5éÒÔ=aY‡“U«®á¯ý7^{íQ½_nn7Þxk é6ÖÒÒÒw"Ç€JWW¨‹—_y‰}û÷Ž«*8¦L™ræG<è‚---”””Œ»QªƒP&ìŸoei¨ƒ¼¯þË2‰DzéêìâÍÛ÷„ÑÏqQùdËÊÊøç_þ’†† ÃH²«r%uuµlxñ¯¼ðR'k>ºšM›6óÆë¹òª«3¶Ídâ’R£U\6él4M#‰`N§·ÛËåJúwdL»ÛÚÚ¸çž{lõ!í‘ö¤#€ÙeY´µµ‘ëÍåå—7ðècDϺ‹M|w†bÿmÿcÑ[EQ())¥jòTššš¨¨¨HËÙOŠ¢••Åòå—QRR6êÁ‚‚jjjÈÊÊU¨ommÅépòâúÄUº¦LžL(bá‚… ÿ?Trr¼q¡+ȳÏ=ƒÛ妵µ5ã¡ë|ÒX8gei==ÝØ»·Û’늢——ÇŠ+X´hÑyWô?sãgøö·îäµobzÆfÇë¶£ª*YYYdeeü»\·nµfÍš Çb½bô6lØ@âßk²"‘ÃÎe• ‡ÃAyyùˆ~xFÚþØØ)]ý¢UUÅétât:G[ZZ8uê–eñȺ‡ ƒçõú¼¼ vpAg£;*ÑMIDAT×cøÿÿÃ{ >ÄÍP6±ÿÀð¶ˆ?0ùoÀðîOûŸŽÕåó Þ»04O`x/y€áýž Çÿõ²Þ-šJºùÇIEND®B`‚ngraph-gtk-6.08.00/doc/html/img/Makefile.in0000644000175000017500000004027013367273152015216 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc/html/img ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_htmlimg_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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)$(htmlimgdir)" DATA = $(dist_htmlimg_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ htmlimgdir = $(docdir)/html/img dist_htmlimg_DATA = barc.png baxispo.png bclear.png bcross.png \ bdataopn.png bdatapo.png bdraw.png beval.png bframe.png \ bgauss.png blgndpo.png bline.png bload.png bmark.png \ bmath.png bpoint.png bpreview.png bprint.png brect.png \ bsave.png bscale.png bscundo.png bsection.png bsingle.png \ btext.png btrim.png bzoom.png winaxis.png wincoord.png \ windata.png wininfo.png winlgnd.png winmerge.png icon.png \ aclear.png addgraph.png axispo.png datapo.png draw.png \ eval.png fopen.png infowin.png lapoint.png legend.png \ lwindow.png math.png pointer.png scundo.png trimming.png 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) --gnu doc/html/img/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/html/img/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_htmlimgDATA: $(dist_htmlimg_DATA) @$(NORMAL_INSTALL) @list='$(dist_htmlimg_DATA)'; test -n "$(htmlimgdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmlimgdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmlimgdir)" || 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)$(htmlimgdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmlimgdir)" || exit $$?; \ done uninstall-dist_htmlimgDATA: @$(NORMAL_UNINSTALL) @list='$(dist_htmlimg_DATA)'; test -n "$(htmlimgdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmlimgdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)$(htmlimgdir)"; 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_htmlimgDATA 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_htmlimgDATA .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_htmlimgDATA 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_htmlimgDATA .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: ngraph-gtk-6.08.00/doc/html/index.html0000644000175000017500000000037313070106167014362 00000000000000 Ngraph-gtk User's Manual

Ngraph-gtk User's Manual

ngraph-gtk-6.08.00/doc/html/ja/0000755000175000017500000000000013375640233013041 500000000000000ngraph-gtk-6.08.00/doc/html/ja/gra.html0000644000175000017500000002604713251137216014424 00000000000000 GRA  

GRAファイル




概è¦


GRAファイルã¯, ç›´ç·š, 円ãªã©ã®ã‚°ãƒ©ãƒ•ィックス命令を記述ã—ãŸ, グラフã®ãƒžãƒ¼ã‚¸ç­‰ã«ä½¿ã‚れるNgraph独自ã®ãƒ•ァイル形å¼ã§ã™ã€‚

ã¾ãŸã€External driverã¸ã‚°ãƒ©ãƒ•ィックス命令をé€ã‚‹ã®ã«ã‚‚使ã‚れã¾ã™ã€‚

GRAファイルã®äº’æ›æ€§

  • Ngraph version 6.x ã® GRA ファイルã¯, DOS 版 Ngraph (version 5.x) ã® GRA ファイルã¨åƒ…ã‹ã«ç•°ãªã‚‹ãŸã‚,äº’æ›æ€§ã¯ã‚りã¾ã›ã‚“。
  • ãŸã ã—Ngraph version 6.x ã§ DOS 版 Ngraph (version 5.x) ã® GRA ファ イルをマージã™ã‚‹ã“ã¨ã¯å¯èƒ½ã§ã™ã€‚
  • DOS 版 Ngraph ã® GRA ãƒ•ã‚¡ã‚¤ãƒ«ã®æ§‹é€ ãŠã‚ˆã³ã‚³ãƒžãƒ³ãƒ‰ã«ã¤ã„ã¦ã¯ DOS 版 Ngraph ã«æ·»ä»˜ã•れã¦ã„るマニュアルをå‚ç…§ã—ã¦ãã ã•ã„。
  • Ngraph version 6.04 ã§ H コマンド (フォントメトリック指定命令) ãŒæ‹¡ å¼µã•れã¾ã—ãŸã€‚ version 6.04 ã§ä½œæˆã—㟠GRA ファイルã¯ãれ以å‰ã®ãƒãƒ¼ ジョンã§èª­ã¿è¾¼ã‚€ã“ã¨ã¯ã§ãã¾ã›ã‚“。
  • Ngraph version 6.05 ã§ C コマンド (楕円æç”»å‘½ä»¤) 㨠G コマンド(カラー 指定命令) ãŒæ‹¡å¼µã•れã¾ã—ãŸã€‚ version 6.05 ã§ä½œæˆã—㟠GRAファイル㯠ãれ以å‰ã®ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã§èª­ã¿è¾¼ã‚€ã“ã¨ã¯ã§ãã¾ã›ã‚“。



GRAãƒ•ã‚¡ã‚¤ãƒ«ã®æ§‹é€ 


下ã«GRAファイルã®ä¾‹ã‚’示ã—ã¾ã™ã€‚
%Ngraph GRAF
%Creator: Ngraph ver 6.00.01
I,5,0,0,21000,29700,10000
V,5,0,0,21000,29700,1
G,3,0,0,0
A,5,0,40,2,0,1000
L,4,3500,22000,17500,22000
L,4,3500,22000,3500,8000
L,4,3500,8000,17500,8000
L,4,17500,22000,17500,8000
E,0

GRAファイルã®ç¬¬ä¸€è¡Œã¯GRAファイルã®è­˜åˆ¥å­ã§ã‚ã‚‹æ¬¡ã®æ–‡å­—列ã§ãªã‘れã°ãªã‚Šã¾ã›ã‚“。

%Ngraph GRAF

第2行以é™ã¯1行ã«1ã¤ãšã¤ã‚°ãƒ©ãƒ•ィックスコマンドãŒè¨˜è¿°ã•れã¾ã™ã€‚グラフィックスコマンドã®å½¢å¼ã‚’示ã—ã¾ã™ã€‚

command, n, arg1, arg2, ..., argn
  • commandã¯ã‚°ãƒ©ãƒ•ィックスコマンドを指定ã™ã‚‹ã‚¢ãƒ«ãƒ•ァベット一文字㧠I, E, V, A, G, M, N, L, T, C, B, P, R, D, H ã®ã„ãšã‚Œã‹ã§ã™ã€‚
  • n ã¯å¼•æ•°ã®æ•°(æ•´æ•°)ã‚’ç¾ã—ã¾ã™ã€‚
  • arg1, ..., argnã¯ã‚°ãƒ©ãƒ•ィックスコマンドã®å¼•æ•°(æ•´æ•°)ã§ã™ã€‚

コマンドã®åŒºåˆ‡ã‚Šã«ã¯ã‚¹ãƒšãƒ¼ã‚¹, タブ, コンマãŒä½¿ãˆã¾ã™ã€‚ ãŸã ã—commandãŒ%, F, S ã®å ´åˆã«ã¯æ¬¡ã®ã‚ˆã†ã«ã‚³ãƒžãƒ³ãƒ‰ç›´å¾Œã« 文字列ã®å¼•æ•°(下ã®ä¾‹ã§ã¯this is a string)を記述ã—ã¾ã™ã€‚

Sthis is a string

ã“ã®å ´åˆ, 文字列引数ã®ä¸­ã®ã‚¹ãƒšãƒ¼ã‚¹ãƒ»ã‚¿ãƒ–・コンマã¯é€šå¸¸ã®æ–‡å­—ã¨ã—ã¦æ‰±ã‚れã¾ã™ã€‚


GRAファイルã®ã‚°ãƒ©ãƒ•ィックコマンド

グラフィックコマンドã®å¼•æ•°ã¯ç‰¹ã«æŒ‡å®šã®ãªã„é™ã‚Šå˜ä½ã¯0.01mmã§ã™ã€‚ X座標増加方å‘ã¯å³, Y座標増加方å‘ã¯ä¸‹ã§ã™ã€‚ 数値引数ã¯ã™ã¹ã¦æ•´æ•°å€¤ã§ãªã‘れã°ãªã‚Šã¾ã›ã‚“。

コマンド機能書å¼
IåˆæœŸåŒ–命令I,5,arg1,arg2,arg3,arg4,arg5
arg1
左マージン
arg2
上マージン
arg3
出力用紙幅
arg4
出力用紙高
arg5
拡大率(0.01%å˜ä½)
  • 出力デãƒã‚¤ã‚¹ã®åˆæœŸåŒ–を行ã†ã€‚1å›žã®æç”»ã§åˆã‚ã«ä¸€åº¦ã ã‘呼ã°ã‚Œã‚‹ã€‚
コマンド機能書å¼
E終了命令E,0
  • ä¸€å›žã®æç”»ã§æœ€å¾Œã«ä¸€åº¦ã ã‘呼ã°ã‚Œã‚‹ã€‚出力デãƒã‚¤ã‚¹ã®å¾Œå‡¦ç†ã‚’行ã†ã€‚
コマンド機能書å¼
%コメント%comment
  • 文字列引数(コメント)
コマンド機能書å¼
Vクリッピング領域, 原点移動命令V,5,arg1,arg2,arg3,arg4,arg5
arg1
左上X座標, æ–°ã—ã„X座標原点
arg2
左上Y座標, æ–°ã—ã„Y座標原点
arg3
å³ä¸‹X座標
arg4
å³ä¸‹Y座標
arg5
  • 0:クリッピングオフ
  • 1:クリッピングオン
  • ã“ã®å‘½ä»¤ä»¥é™, V命令を除ãã™ã¹ã¦ã®å‘½ä»¤ã¯åŽŸç‚¹ã‚’ã‚¯ãƒªãƒƒãƒ”ãƒ³ã‚°é ˜åŸŸå·¦ä¸Šã¨ã—ãŸã‚‚ã®ã«ãªã‚‹ã€‚
  • パラメタ㯠A4用紙左上を原点ã¨ã™ã‚‹0.01mmå˜ä½ã§æŒ‡å®šã—ã¾ã™ã€‚
  • クリッピング処ç†ã¯åŸºæœ¬çš„ã«Ngraph内部ã§è¡Œã£ã¦ã„ã‚‹ã®ã§å¿…ãšã—ã‚‚å¿…è¦ã§ã¯ãªã„ãŒ, クリッピングã™ã‚‹ã®ãŒæœ›ã¾ã—ã„(原点移動ã¯å¿…é ˆ)。
コマンド機能書å¼
A線属性指定命令A,n,arg1,arg2,....
n
点線è¦ç´ ã®æ•°+5
arg1
0:実線 >1:点線è¦ç´ ã®æ•°
arg2
ç·šå¹…
arg3
線端形状
  • 0:Butt
  • 1:Round
  • 2:Projecting
arg4
線交差形状
  • 0:Miter
  • 1:Round
  • 2:Bevel
arg5
Miter limit
arg(i) - arg(i + 5) i = 1 - arg1
点線è¦ç´ 
コマンド機能書å¼
Gカラー指定命令G,4,arg1,arg2,arg3,arg4
arg1
R(8bit)
arg2
G(8bit)
arg3
B(8bit)
arg4
A(8bit) (ä¸é€æ˜Žåº¦)
  • arg4 ã¯è¨­å®šã«ã‚ˆã£ã¦ã€ã‚ã‚‹ã„ã¯ãƒ‰ãƒ©ã‚¤ãƒã«ã‚ˆã£ã¦ç„¡è¦–ã•れるã“ã¨ãŒã‚る。
コマンド機能書å¼
Mカレントãƒã‚¤ãƒ³ãƒˆç§»å‹•命令M,2,arg1,arg2
arg1
X座標
arg2
Y座標
コマンド機能書å¼
Nカレントãƒã‚¤ãƒ³ãƒˆç›¸å¯¾ç§»å‹•命令N,2,arg1,arg2
arg1
Xæ–¹å‘移動é‡
arg2
Yæ–¹å‘移動é‡
コマンド機能書å¼
Lç·šæç”»å‘½ä»¤L,4,arg1,arg2,arg3,arg4
arg1
始点X座標
arg2
始点Y座標
arg3
終点X座標
arg4
終点Y座標
コマンド機能書å¼
Tカレントãƒã‚¤ãƒ³ãƒˆç›¸å¯¾ãƒ»ç·šæç”»å‘½ä»¤T,2,arg1,arg2
arg1
終点X座標, æ–°ã—ã„カレントãƒã‚¤ãƒ³ãƒˆX座標
arg2
終点Y座標, æ–°ã—ã„カレントãƒã‚¤ãƒ³ãƒˆY座標
  • 本命令実行後, カレントãƒã‚¤ãƒ³ãƒˆã¯çµ‚点ã«ç§»å‹•ã™ã‚‹ã€‚
コマンド機能書å¼
C楕円æç”»å‘½ä»¤C,7,arg1,arg2,arg3,arg4,arg5,arg6,arg7
arg1
中心ã®X座標
arg2
中心ã®Y座標
arg3
Xæ–¹å‘åŠå¾„
arg4
Yæ–¹å‘åŠå¾„
arg5
楕円弧開始角度, 0.01度å˜ä½(0-36000)
arg6
楕円弧開始角度, 0.01度å˜ä½(0-36000)
arg7
  • 0:円ã®è¼ªéƒ­ï¼ˆå†…部ã¯å¡—りã¤ã¶ã•ãªã„)
  • 1:扇形内部を塗りã¤ã¶ã™
  • 2:円弧内部を塗りã¤ã¶ã™
  • 3:扇形ã«è¼ªéƒ­ã‚’æç”»
  • 4:弓形ã«è¼ªéƒ­ã‚’æç”»
  • arg5ã‹ã‚‰é–‹å§‹ã—ã¦arg6ã®è§’度ã ã‘åæ™‚è¨ˆå›žã‚Šã«æ¥•円弧をæã。
  • 角度ã¯, 楕円 (x/a)^2+(y/b)^2=1 ã‚’ x=a*cosθ, y=b*sinθ ã¨åª’介変数表示ã—ãŸæ™‚ã®Î¸ã€‚
コマンド機能書å¼
B四角形æç”»å‘½ä»¤B,5,arg1,arg2,arg3,arg4,arg5
arg1
X座標
arg2
Y座標
arg3
対角ã®X座標
arg4
対角ã®Y座標
arg5
  • 0:四角形ã®è¼ªéƒ­ï¼ˆå†…部ã¯å¡—りã¤ã¶ã•ãªã„)
  • 1:内部を塗りã¤ã¶ã™
コマンド機能書å¼
P点æç”»å‘½ä»¤P,2,arg1,arg2
arg1
X座標
arg2
Y座標
コマンド機能書å¼
R多角形æç”»å‘½ä»¤R,n,arg1,arg2,...
n
åº§æ¨™ç‚¹ã®æ•°*2+1
arg1
åº§æ¨™ç‚¹ã®æ•°
arg(i * 2 + 0) i = 1 - arg1
X座標
arg(i * 2 + 1) i = 1 - arg1
Y座標
コマンド機能書å¼
D閉多角形æç”»å‘½ä»¤D,n,arg1,arg2,...
n
åº§æ¨™ç‚¹ã®æ•°*2+2
arg1
åº§æ¨™ç‚¹ã®æ•°
arg2
  • 0:多角形ã®è¼ªéƒ­ï¼ˆå†…部ã¯å¡—りã¤ã¶ã•ãªã„)
  • 1:内部を塗りã¤ã¶ã™(EvenOddRule)
  • 2:内部を塗りã¤ã¶ã™(WindingRule)
arg(i * 2 + 1) i = 1 - arg1
X座標
arg(i * 2 + 2) i = 1 - arg1
Y座標
コマンド機能書å¼
Fãƒ•ã‚©ãƒ³ãƒˆé¸æŠžå‘½ä»¤Ffont
  • 文字列引数(font フォントエイリアスå)
  • 実際ã®ãƒ•ォントã¸ã®ãƒžãƒƒãƒ”ングã¯ãƒ‰ãƒ©ã‚¤ãƒã«ä¾å­˜
コマンド機能書å¼
Hフォントメトリック指定命令H,4,arg1,arg2,arg3,arg4
arg1
文字ã®ãƒã‚¤ãƒ³ãƒˆã‚µã‚¤ã‚º, 0.01ptå˜ä½ï¼ˆ1pt=1/72inch)
arg2
文字スペーシング・ãƒã‚¤ãƒ³ãƒˆé‡, 0.01ptå˜ä½
arg3
æç”»æ–¹å‘, X軸ã‹ã‚‰å時計回りã«0.01度å˜ä½
arg4
スタイル, 0:normal, 1: bold, 2:italic ã®å’Œ
  • 文字ã¯å…¨ã¦ã‚¹ã‚±ãƒ¼ãƒ©ãƒ–ルã§ãªã‘れã°ãªã‚Šã¾ã›ã‚“。
コマンド機能書å¼
S文字列æç”»å‘½ä»¤Sstring
  • 文字列引数 (string 㯠UTF-8 文字列)

ngraph-gtk-6.08.00/doc/html/ja/intro.html.in0000644000175000017500000000751413251134117015406 00000000000000 Introduction  

Ngraphã®æ¦‚è¦




Ngraphã¨ã¯ï¼Ÿ


  • Ngraph ã¯ç†å·¥ç³»å­¦ç”Ÿã€ç ”ç©¶è€…ã€æŠ€è¡“è€…ã®ãŸã‚ã«ä½œã‚‰ã‚ŒãŸï¼’æ¬¡å…ƒã‚°ãƒ©ãƒ•ä½œæˆ ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã§ã™ã€‚
  • 汎用性ã®ã‚るテキストファイルã‹ã‚‰æ•°å€¤ãƒ‡ãƒ¼ã‚¿ã‚’読ã¿è¾¼ã¿ã‚°ãƒ©ãƒ•ã«ãƒ—ロッ トã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚
  • プレゼンテーション用ã€è«–文用グラフã®ä½œæˆãŒã§ãã¾ã™ã€‚
  • ç°¡å˜ãªãƒ‡ãƒ¼ã‚¿è§£æžã‚’アシストã—ã¾ã™ã€‚



使用è¦å®šãƒ»é…布等


Ngraph, Ngraph for X11 ã®è‘—作権ã¯çŸ³å‚智(ã„ã—ã–ã‹ã•ã¨ã—)ãŒä¿æœ‰ã—ã¦ã„ã¾ã™ã€‚

Copyright (C) 2002, Satoshi ISHIZAKA.

ã“ã®ãƒ—ログラムã¯ãƒ•リーソフトウェアã§ã™ã€‚ã‚ãªãŸã¯ã“れをã€ãƒ•リーソフトウェ ア財団ã«ã‚ˆã£ã¦ç™ºè¡Œã•れ㟠GNU一般公衆利用許諾契約書(ãƒãƒ¼ã‚¸ãƒ§ãƒ³2ã‹ã€å¸Œæœ› ã«ã‚ˆã£ã¦ã¯ãれ以é™ã®ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã®ã†ã¡ã©ã‚Œã‹)ã®å®šã‚ã‚‹æ¡ä»¶ã®ä¸‹ã§å†é ’布㾠ãŸã¯æ”¹å¤‰ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

ã“ã®ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã¯æœ‰ç”¨ã§ã‚ã‚‹ã“ã¨ã‚’願ã£ã¦é ’布ã•れã¾ã™ãŒã€*å…¨ãã®ç„¡ä¿è¨¼* ã§ã™ã€‚商業å¯èƒ½æ€§ã®ä¿è¨¼ã‚„特定ã®ç›®çš„ã¸ã®é©åˆæ€§ã¯ã€è¨€å¤–ã«ç¤ºã•れãŸã‚‚ã®ã‚‚å« ã‚å…¨ã存在ã—ã¾ã›ã‚“。詳ã—ãã¯GNU一般公衆利用許諾契約書をã”覧ãã ã•ã„。

ã‚ãªãŸã¯ã“ã®ãƒ—ログラムã¨å…±ã«ã€GNU一般公衆利用許諾契約書ã®è¤‡è£½ç‰©ã‚’一部 å—ã‘å–ã£ãŸã¯ãšã§ã™ã€‚ã‚‚ã—å—ã‘å–ã£ã¦ã„ãªã‘れã°ã€ãƒ•リーソフトウェア財団㾠ã§è«‹æ±‚ã—ã¦ãã ã•ã„(宛先㯠the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA)。




環境設定


  • Ngraphã‚’ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã‚¢ãƒƒãƒ—ã—ãŸéš›ã«ã¯ã€~/.Ngraph ã«ä½œæˆã•れ㟠Ngraph.ini を削除ã™ã‚‹ã®ã‚’忘れãªã„ã§ä¸‹ã•ã„。ãã†ã—ãªã„㨠Ngraph.ini ã®æ§‹æˆãŒå¤‰æ›´ã•れãŸã¨ã—ã¦ã‚‚å¤ã„ Ngraph.ini ãŒãƒ­ãƒ¼ãƒ‰ã•れã¦ã—ã¾ã„ã¾ã™ã€‚

以下ã«ã€Ngraph ãŒä½¿ç”¨ã™ã‚‹ãƒ•ァイルã®ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªæ¤œç´¢é †ã‚’記述ã—ã¾ã™ã€‚

(1) åˆæœŸåŒ–ファイルã®èª­è¾¼

Ngraphã¯2ã¤ã®åˆæœŸåŒ–ファイルを必è¦ã¨ã—ã¾ã™ã€‚

Ngraph.nsc
デフォルトã®ã‚°ãƒ©ãƒ•スタイルã®èª­ã¿è¾¼ã¿ã‚„コマンドラインオプションã®è§£ æžã‚’行ã†ã‚¹ã‚¯ãƒªãƒ—トファイル。ã“ã®ã‚¹ã‚¯ãƒªãƒ—ãƒˆãƒ•ã‚¡ã‚¤ãƒ«ã¯æ›´ã« Ngraph.ngp を読ã¿è¾¼ã¿ã¾ã™ã€‚
Ngraph.ini
Ngraphã®è¨­å®šåˆæœŸå€¤ã‚’列挙ã—ãŸãƒ•ァイル

ã“れらã®ãƒ•ァイル読ã¿è¾¼ã¿ã®æ¤œç´¢é †ã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚

  1. ~/.Ngraph
  2. CONFDIRDEF

(2) åˆæœŸåŒ–ãƒ•ã‚¡ã‚¤ãƒ«ã®æ›¸ãè¾¼ã¿

Ngraph 終了時ã«ã¯ ~/.Ngraph ã« Ngraph.ini を作æˆã—ã¾ã™ã€‚ã¾ãŸã€ [Graph]-[save as default(Graph)] メニューã§ã¯ Ngraph.ngp を作æˆã—ã¾ã™ã€‚ ã“れらファイルã®ä½œæˆãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã®å„ªå…ˆé †ã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚

  1. ~/.Ngraph
  2. CONFDIRDEF

(3) プリンタドライãƒã€ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—トã®å®Ÿè¡Œ

プリンタドライãƒã‚„アドインスクリプトãªã©ã®å¤–éƒ¨ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã®æ¤œç´¢é †ã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚

  1. ~/.Ngraph
  2. DATADIRDEF
  3. LIBDIRDEF
  4. 環境変数 PATH



ngraph-gtk-6.08.00/doc/html/ja/refer.html0000644000175000017500000015176613362760447015000 00000000000000 Reference  

リファレンス




[グラフ]メニュー

æ–°è¦ä½œæˆ ç¾åœ¨ã®ã‚°ãƒ©ãƒ•を破棄ã—ã¦æ–°ã—ã„グラフを作æˆã—ã¾ã™ã€‚ ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã«ã‚°ãƒ©ãƒ•を追加ã™ã‚‹ã®ã¯[軸]-[追加作æˆ]メニューã§ã™ã€‚
é–‹ã ä¿å­˜ã—ã¦ã‚るグラフファイル(NGPファイル)を読ã¿è¾¼ã¿ã¾ã™ã€‚ DOS 版 Ngraph ã® PRM ファイル㯠load PRM アドインを使用ã—ã¦èª­ã¿è¾¼ã‚“ã§ãã ã•ã„。
åå‰ã‚’付ã‘ã¦ä¿å­˜ ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã«åå‰ã‚’ã¤ã‘ã¦ä¿å­˜ã—ã¾ã™ã€‚
ä¿å­˜ ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã‚’ä¿å­˜ã—ã¾ã™ã€‚
ç”»åƒã«ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆ GRA, PostScript, EPS, SVG, PDF, PNG ã®å„å½¢å¼ã®ãƒ•ァイルを出力ã—ã¾ã™ã€‚
æç”»é † æç”»ã™ã‚‹ã‚°ãƒ©ãƒ•ィックスオブジェクトを指定ã—ãŸã‚Šã€æç”»é †ã‚’変更ã—ã¾ã™ã€‚
用紙 用紙ã®ãƒžãƒ¼ã‚¸ãƒ³ã‚„ã€å…¨ä½“ã®æ‹¡å¤§çŽ‡ç­‰ã‚’æŒ‡å®šã—ã¾ã™ã€‚
å°åˆ·ãƒ—レビュー プレビュー表示を行ã„ã¾ã™ã€‚
å°åˆ· å°åˆ·ã—ã¾ã™ã€‚
ç¾åœ¨ã®ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒª ç¾åœ¨ã®ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã‚’変更ã—ã¾ã™ã€‚
アドイン ã¡ã‚‡ã£ã¨ã—ãŸæ©Ÿèƒ½ã‚’æŒã£ãŸå‰¯ãƒ—ログラムを実行ã—ã¾ã™ã€‚ アドインをå‚ç…§ã—ã¦ãã ã•ã„。
Ngraphシェル Unixã® sh ライクãªã‚·ã‚§ãƒ«(ã‚³ãƒžãƒ³ãƒ‰ã‚¤ãƒ³ã‚¿ãƒ¼ãƒ—ãƒªã‚¿ãƒ¼ã®æ§˜ãªã‚‚ã®)ã‚’èµ·å‹•ã—ã¾ã™ã€‚
終了 Ngraphを終了ã—ã¾ã™ã€‚ グラフã«å¤‰æ›´ãŒåŠ ãˆã‚‰ã‚Œã¦ã„ã¦ä¿å­˜ã•れã¦ã„ãªã„å ´åˆã«ã¯ä¿å­˜ã™ã‚‹ã‹ã©ã†ã‹å•ã„åˆã‚ã¾ã™ã€‚



[編集]メニュー

å…ƒã«æˆ»ã™ ç›´å‰ã®æ“ä½œã‚’å…ƒã«æˆ»ã—ã¾ã™ (「グラフã€ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã®ã€Œæç”»é †ã€ã¨ã€Œãƒšãƒ¼ã‚¸è¨­å®šã€ã¯å…ƒã«æˆ»ã›ã¾ã›ã‚“) 。
ã‚„ã‚Šç›´ã— å…ƒã«æˆ»ã—ãŸæ“作をやり直ã—ã¾ã™ã€‚
切りå–り
コピー
é¸æŠžã—㟠legend, merge オブジェクトã«å¯¾ã—ã¦ã€Œåˆ‡ã‚Šå–りã€ã¾ãŸã¯ã€Œã‚³ãƒ”ー〠を行ã„ã¾ã™ (axis オブジェクトã®åˆ‡ã‚Šå–りã€ã‚³ãƒ”ーã¯å‡ºæ¥ã¾ã›ã‚“) 。
貼り付㑠クリップボードã«ä¿å­˜ã•れã¦ã„る文字列ã¾ãŸã¯ legend, merge オブジェクトを 貼り付ã‘ã¾ã™ã€‚
削除 é¸æŠžã—ãŸã‚ªãƒ–ジェクトを削除ã—ã¾ã™ã€‚
ä½ç½®åˆã› é¸æŠžã—ãŸã‚ªãƒ–ジェクトã®ä½ç½®åˆã›ã‚’行ã„ã¾ã™ã€‚
90° 時計回り回転
90° åæ™‚計回り回転
é¸æŠžã—㟠legend, axis オブジェクトを回転ã—ã¾ã™ (merge オブジェクトã¯å›žè»¢ ã§ãã¾ã›ã‚“) 。mark オブジェクトã¯å›žè»¢ã«ã‚ˆã‚Šä½ç½®ã®ã¿å¤‰åŒ–ã—ã¾ã™ã€‚
æ°´å¹³å転
垂直å転
é¸æŠžã—㟠legend, axis オブジェクトをå転ã—ã¾ã™ (merge ãŠã‚ˆã³ text オブジェ クトã¯å転ã§ãã¾ã›ã‚“) 。mark オブジェクトã¯å転ã«ã‚ˆã‚Šä½ç½®ã®ã¿å¤‰åŒ–ã—ã¾ã™ã€‚



[表示]メニュー

æç”» グラフをæç”»ã—ã¾ã™ã€‚ ボタンを押ã™ã»ã†ãŒç°¡å˜ã§ã™ã€‚
Information 表示をクリア Information 表示をクリアã—ã¾ã™ã€‚
サイドãƒãƒ¼
ステータスãƒãƒ¼
ルーラー
スクロールãƒãƒ¼
コマンドツールãƒãƒ¼
ツールボックス
クロスゲージ
グリッド
表示ã€éžè¡¨ç¤ºã‚’切り替ãˆã¾ã™ã€‚



[オブジェクト]メニュー

[データ]メニュー

追加
  • ファイル: データファイルをプロットデータã¨ã—ã¦é–‹ãã¾ã™ã€‚
  • 範囲:指定ã—ãŸç¯„å›²ã®æ•°å€¤ã‚’プロットデータã¨ã—ã¦é–‹ãã¾ã™ã€‚æ•°å¼å¤‰ æ›æ©Ÿèƒ½ã‚’利用ã—ã¦ã€ä»»æ„ã®é–¢æ•°ã‚’æç”»ã§ãã¾ã™ã€‚
  • 最近使用ã—ãŸãƒ•ァイル:最近使用ã—ãŸãƒ•ァイルã‹ã‚‰é¸ã‚“ã§ãƒ—ロットデータã¨ã—ã¦é–‹ãã¾ã™ã€‚
設定 プロット方法ãªã©ã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã«é–¢ã™ã‚‹è¨­å®šã‚’行ã„ã¾ã™ã€‚
é–‰ã˜ã‚‹ データファイルをプロットデータã‹ã‚‰å¤–ã—é–‰ã˜ã¾ã™ã€‚
編集 エディターを起動ã—ã¦ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを編集ã—ã¾ã™ã€‚
データã®ä¿å­˜ データファイルã¨ã—ã¦å‡ºåŠ›ã—ã¾ã™ã€‚æ•°å¼å¤‰æ›æ©Ÿèƒ½ãªã©ã‚’使ã£ã¦ã„ã‚‹å ´åˆã€å¤‰æ›å¾Œã®ãƒ‡ãƒ¼ã‚¿ãŒå¾—られã¾ã™ã€‚
変æ›å¼ã®ä¸€æ‹¬å…¥åŠ› æ•°å¼å¤‰æ›æ©Ÿèƒ½ã®ä¸€æ‹¬è¨­å®šã‚’行ã„ã¾ã™ã€‚



[軸]メニュー

è¿½åŠ ä½œæˆ ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã«åŠ ãˆã¦ã€æ–°ã—ã„別ã®ã‚°ãƒ©ãƒ•(軸)を追加ã—ã¾ã™ã€‚
設定 軸ã«é–¢ã™ã‚‹è¨­å®šã‚’行ã„ã¾ã™ã€‚
削除 グラフ(軸)を削除ã—ã¾ã™ã€‚
スケールズーム 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’拡大ã€ç¸®å°ã—ã¾ã™ã€‚
スケールクリア 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’未設定状態ã«ã—ã¾ã™ã€‚æ¬¡ã«æç”»ã™ã‚‹ã¨ã€è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ãŒè‡ªå‹•çš„ã«æ±ºã‚られã¾ã™ã€‚
グリッド æ–¹çœ¼ã‚°ãƒ©ãƒ•ã®æ–¹çœ¼ã«é–¢ã™ã‚‹è¨­å®šã‚’ã—ã¾ã™ã€‚



パスã€çŸ©å½¢ã€å††ã€ãƒžãƒ¼ã‚¯ã€ãƒ†ã‚­ã‚¹ãƒˆãƒ¡ãƒ‹ãƒ¥ãƒ¼

パス 凡例(直線・曲線)ã®è¨­å®šã€å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ æ–°è¦ä½œæˆã¯ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§ã¯ã§ãã¾ã›ã‚“。 æ–°è¦ä½œæˆã¯ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’指定ã—ã¦ãã ã•ã„。
矩形 凡例(矩形)ã®è¨­å®šã€å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ æ–°è¦ä½œæˆã¯ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§ã¯ã§ãã¾ã›ã‚“。 æ–°è¦ä½œæˆã¯ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’指定ã—ã¦ãã ã•ã„。
円 凡例(円)ã®è¨­å®šã€å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ æ–°è¦ä½œæˆã¯ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§ã¯ã§ãã¾ã›ã‚“。 æ–°è¦ä½œæˆã¯ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’指定ã—ã¦ãã ã•ã„。
マーク 凡例(マーク)ã®è¨­å®šã€å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ æ–°è¦ä½œæˆã¯ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§ã¯ã§ãã¾ã›ã‚“。 æ–°è¦ä½œæˆã¯ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’指定ã—ã¦ãã ã•ã„。
テキスト 凡例(テキスト)ã®è¨­å®šã€å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ æ–°è¦ä½œæˆã¯ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§ã¯ã§ãã¾ã›ã‚“。 æ–°è¦ä½œæˆã¯ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’指定ã—ã¦ãã ã•ã„。



[åˆæˆ]メニュー

é–‹ã åˆæˆã™ã‚‹åˆæˆãƒ•ァイル(*.GRA)ã‚’é–‹ãã¾ã™ã€‚
設定 åˆæˆã®ä½ç½®ã€æ‹¡å¤§çއãªã©ã®è¨­å®šã‚’行ã„ã¾ã™ã€‚
é–‰ã˜ã‚‹ åˆæˆã™ã‚‹åˆæˆãƒ•ァイル(*.GRA)ã‚’é–‰ã˜ã¾ã™ã€‚






[設定]メニュー

フォント 目盛数字やレジェンドテキストã§ç”¨ã„られるフォントã®è¿½åŠ ã‚„å‰Šé™¤ã‚’ã—ã¾ã™ã€‚ ダイアログã®[OK]ボタンを押ã—ãŸå ´åˆã¯ãƒ—ログラム終了時ã«è¨­å®šã®å¤‰æ›´ã¯ä¿å­˜ã• れã¾ã›ã‚“。[ä¿å­˜]ボタンを押ã—ãŸå ´åˆã¯æ¬¡å›žä»¥é™ã®èµ·å‹•時ã«ã‚‚設定ã®å¤‰æ›´ãŒæœ‰åй ã«ãªã‚Šã¾ã™ã€‚
ビューア グラフã®è§£åƒåº¦ãªã©ã‚’指定ã—ã¾ã™ã€‚ ダイアログã®[OK]ボタンを押ã—ãŸå ´åˆã¯ãƒ—ログラム終了時ã«è¨­å®šã®å¤‰æ›´ã¯ä¿å­˜ã• れã¾ã›ã‚“。[ä¿å­˜]ボタンを押ã—ãŸå ´åˆã¯æ¬¡å›žä»¥é™ã®èµ·å‹•時ã«ã‚‚設定ã®å¤‰æ›´ãŒæœ‰åŠ¹ã« ãªã‚Šã¾ã™ã€‚
外部ビューア 外部ビューアã®è§£åƒåº¦ãªã©ã‚’指定ã—ã¾ã™ã€‚ ダイアログã®[OK]ボタンを押ã—ãŸå ´åˆã¯ãƒ—ログラム終了時ã«è¨­å®šã®å¤‰æ›´ã¯ä¿å­˜ã• れã¾ã›ã‚“。[ä¿å­˜]ボタンを押ã—ãŸå ´åˆã¯æ¬¡å›žä»¥é™ã®èµ·å‹•時ã«ã‚‚設定ã®å¤‰æ›´ãŒæœ‰åŠ¹ã« ãªã‚Šã¾ã™ã€‚
アドインスクリプト æ–°ã—ã„アドインを追加ã—ãŸã‚Šã€å‰Šé™¤ã—ãŸã‚Šã—ã¾ã™ã€‚ ダイアログã®[OK]ボタンを押ã—ãŸå ´åˆã¯ãƒ—ログラム終了時ã«è¨­å®šã®å¤‰æ›´ã¯ä¿å­˜ã• れã¾ã›ã‚“。[ä¿å­˜]ボタンを押ã—ãŸå ´åˆã¯æ¬¡å›žä»¥é™ã®èµ·å‹•時ã«ã‚‚設定ã®å¤‰æ›´ãŒæœ‰åŠ¹ã« ãªã‚Šã¾ã™ã€‚
ãã®ä»– エディターを指定ã—ãŸã‚Šã€ã‚°ãƒ©ãƒ•ã®ä¿å­˜æ–¹æ³•ã®ãƒ‡ãƒ•ォルト値を変更ã—ãŸã‚Šã—ã¾ã™ã€‚ ダイアログã®[OK]ボタンを押ã—ãŸå ´åˆã¯ãƒ—ログラム終了時ã«è¨­å®šã®å¤‰æ›´ã¯ä¿å­˜ã• れã¾ã›ã‚“。[ä¿å­˜]ボタンを押ã—ãŸå ´åˆã¯æ¬¡å›žä»¥é™ã®èµ·å‹•時ã«ã‚‚設定ã®å¤‰æ›´ãŒæœ‰åŠ¹ã« ãªã‚Šã¾ã™ã€‚
åˆæœŸçŠ¶æ…‹ã¨ã—ã¦ã‚»ãƒ¼ãƒ–(å„種設定) 次ã«Ngraphã‚’èµ·å‹•ã—ãŸæ™‚も上ã®è¨­å®šå¤‰æ›´ãŒæœ‰åйã«ãªã‚‹ã‚ˆã†å„種設定をä¿å­˜ã—ã¾ã™ã€‚
åˆæœŸçŠ¶æ…‹ã¨ã—ã¦ã‚»ãƒ¼ãƒ–(グラフ) ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã‚’åˆæœŸçŠ¶æ…‹ã¨ãªã‚‹ã‚ˆã†ã«ã—ã¾ã™ã€‚é…布状態ã§ã¯ãƒ•レームグラフãŒåˆæœŸçŠ¶æ…‹ã§ã™ã€‚
ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«åˆæœŸçŠ¶æ…‹ データダイアログボックスã®åˆæœŸçŠ¶æ…‹ã‚’å¤‰æ›´ã—ã¾ã™ã€‚
ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ãƒ†ã‚­ã‚¹ãƒˆåˆæœŸçŠ¶æ…‹ レジェンドテキストã®åˆæœŸçŠ¶æ…‹ã‚’å¤‰æ›´ã—ã¾ã™ã€‚



[ヘルプ]メニュー

ヘルプ ヘルプドキュメントを表示ã—ã¾ã™ã€‚
ã“ã®ã‚¢ãƒ—リケーションã«ã¤ã„㦠Ngraphãƒãƒ¼ã‚¸ãƒ§ãƒ³æƒ…å ±ãªã©ã‚’表示ã—ã¾ã™ã€‚



データ・ダイアログボックス



ファイルå データファイルå。
ファイルã‹ã‚‰è¨­å®šèª­è¾¼ データファイルã®å…ˆé ­ã«è¨­å®šãƒ‘ラメターãŒè¨˜è¿°ã•れã¦ã„ã‚‹å ´åˆã«ã€ãã®ãƒ‘ラメターをå–り込む。 データファイルã¸ã®è¨­å®šãƒ‘ラメターã®è¨˜è¿°ã®æ–¹æ³•ã¯ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル埋ã‚è¾¼ã¿ã‚ªãƒ—ションをå‚照。
編集 データファイルを編集ã™ã‚‹ãŸã‚ã«ã‚¨ãƒ‡ã‚£ã‚¿ãƒ¼ã‚’é–‹ã。 èµ·å‹•ã•れるエディターã¯[設定]-[ãã®ä»–]メニューã§å¤‰æ›´å¯èƒ½ã€‚
Xカラム 横軸ã¨ã—ã¦ä½¿ç”¨ã™ã‚‹ãƒ‡ãƒ¼ã‚¿ã®ã€ãƒ‡ãƒ¼ã‚¿ã«ãŠã‘るカラム数。 0ã®æ™‚㯠1,2,3,... ãŒãƒ‡ãƒ¼ã‚¿ã¨ãªã‚‹ã€‚
X軸 横軸ã¨ã—ã¦ä½¿ç”¨ã™ã‚‹è»¸ã€‚ 軸ã®é€šã—番å·(Axis タブã®è¡Œå…ˆé ­ã«è¡¨ç¤ºã•れる数字)ã§æŒ‡å®šã™ã‚‹ãŒã€ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ã®ãƒªã‚¹ãƒˆã«ã¯è»¸ã®åå‰ã§ä¸€è¦§è¡¨ç¤ºã•れる。
Yカラム 縦軸ã¨ã—ã¦ä½¿ç”¨ã™ã‚‹ãƒ‡ãƒ¼ã‚¿ã®ã€ãƒ‡ãƒ¼ã‚¿ã«ãŠã‘るカラム数。 0ã®æ™‚㯠1,2,3,... ãŒãƒ‡ãƒ¼ã‚¿ã¨ãªã‚‹ã€‚
Y軸 縦軸ã¨ã—ã¦ä½¿ç”¨ã™ã‚‹è»¸ã€‚ 軸ã®é€šã—番å·(Axis タブã®è¡Œå…ˆé ­ã«è¡¨ç¤ºã•れる数字)ã§æŒ‡å®šã™ã‚‹ãŒã€ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ã®ãƒªã‚¹ãƒˆã«ã¯è»¸ã®åå‰ã§ä¸€è¦§è¡¨ç¤ºã•れる。
プロット
タイプ mark, line ç­‰ã®ãƒ—ロットã™ã‚‹æ–¹æ³•。
マーク タイプ㌠mark ã®æ™‚ã«ãƒ—ロットã«ä½¿ã‚れるマークã®ç¨®é¡žã€‚
曲線 タイプ㌠curve ã®æ™‚ã«ä½¿ã‚れる補間方法。 spline(スプライン補間), spline_close(閉スプライン補間), bspline(Bスプライン補間), bspline_close(é–‰Bスプライン補間)。 Bスプライン補間を使ã†ã«ã¯ãƒ‡ãƒ¼ã‚¿æ•°ãŒ7点以上必è¦ã€‚
フィット タイプ㌠fit ã®æ™‚ã«ãƒ•ã‚£ãƒƒãƒ†ã‚£ãƒ³ã‚°ã®æ–¹æ³•を指定ã™ã‚‹ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’é–‹ã。 タイプを fit ã«ã—ãŸã‚‰å¿…ãšä¸€åº¦ã¯ã“ã®ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒ•ィッティング方法を指定ã—ãªã„ã¨ã€ æç”»æ™‚ã« `fit' is not specified ã®ã‚¨ãƒ©ãƒ¼ã«ãªã‚‹ã€‚
色1 プロットã™ã‚‹ç·šã€ãƒžãƒ¼ã‚¯ç­‰ã®è‰²ã€‚
色2 タイプ㌠mark, rectangle_fill, bar_fill_x, bar_fill_y ã®æ™‚ã®ç¬¬2色。
クリップ ãƒã‚§ãƒƒã‚¯ã—ãªã„状態ã§ã¯ã€ãƒ‡ãƒ¼ã‚¿ã¯è»¸ã®å¤–å´ã«ã‚‚プロットã•れる。
線種 プロットã™ã‚‹ç·šã®ç¨®é¡žã€‚ 点線ã®é•·ã•ã€é–“éš”ã‚’è©³ç´°ã«æŒ‡å®šã™ã‚‹ã«ã¯ã€"100 10" ã®æ§˜ã«ç‚¹ç·šã®ç¹°ã‚Šè¿”ã—è¦ç´ ã®é•·ã•を指定ã™ã‚‹ã€‚
ç·šå¹… プロットã™ã‚‹ç·šã®å¹…。
サイズ マークã®å¤§ãã•ã€ã‚¨ãƒ©ãƒ¼ãƒãƒ¼ã®ãƒãƒ¼ã®é•·ã•ãªã©ã®ã‚µã‚¤ã‚ºã€‚
マイター マイターリミット。折れ線ã®è§’ã§è¼ªéƒ­ã‚’ã©ã“ã¾ã§æç”»ã™ã‚‹ã‹ã‚’決ã‚る。
ジョイン 折れ線ã®è§’ã®è¼ªéƒ­å½¢çŠ¶ã€‚
å¤‰æ›æ•°å¼
éš£æŽ¥å¹³å‡ éš£æŽ¥å¹³å‡ã™ã‚‹ãƒ‡ãƒ¼ã‚¿æ•°ã€‚1 ã®æ™‚ã€å‰å¾Œ1ã¤ã®ãƒ‡ãƒ¼ã‚¿ã¨åˆã‚ã›ã¦3ã¤ã®ãƒ‡ãƒ¼ã‚¿ã®å¹³å‡ãŒã¨ã‚‰ã‚Œã‚‹ã€‚
å¤‰æ›æ•°å¼ データを数å¼ã§å¤‰æ›ã—ã¦ãƒ—ロットã—ãŸã„å ´åˆã®å¤‰æ›å¼ã€‚
F(X,Y,Z)=
G(X,Y,Z)=
H(X,Y,Z)=
ユーザ定義関数。ã“ã“ã§å®šç¾©ã—ãŸé–¢æ•°ãŒã€å¤‰æ›æ•°å¼ä¸­ã§ F(), G(), H() ã¨ã—ã¦ä½¿ç”¨ã§ãる。
読込
先頭スキップ行 データã®å…ˆé ­ã§èª­ã¿è¾¼ã¿ã‚’スキップã•ã›ã‚‹è¡Œæ•°ã€‚
読込ステップ行 2ã®æ™‚ã€ãƒ‡ãƒ¼ã‚¿ã¯ä¸€è¡ŒãŠãã«èª­ã¿è¾¼ã¾ã‚Œã‚‹ã€‚
最終行 読ã¿è¾¼ã¿ã‚’åœæ­¢ã•ã›ã‚‹è¡Œã€‚è² ã®å ´åˆãƒ‡ãƒ¼ã‚¿æœ€å¾Œã‹ã‚‰ã®è¡Œæ•°ã«ãªã‚‹ (-1 ã§ãƒ‡ãƒ¼ã‚¿ã®æœ€å¾Œã¾ã§èª­ã¿è¾¼ã¾ã‚Œã‚‹) 。
コメント行 ã“ã“ã§æŒ‡å®šã—ãŸæ–‡å­—ã§å§‹ã¾ã‚‹è¡Œã¯ã‚³ãƒ¡ãƒ³ãƒˆè¡Œã¨ã¿ãªã•れ読ã¿è¾¼ã¾ã‚Œãªã„。
区切り文字 データã®åŒºåˆ‡ã‚Šã¨ã—ã¦ä½¿ç”¨ã•れる文字。デフォルトã¯ã‚¹ãƒšãƒ¼ã‚¹ã€ã‚¿ãƒ–ã€ã‚³ãƒ³ãƒžã€æ‹¬å¼§ã€‚
CSVå½¢å¼ ã“れをãƒã‚§ãƒƒã‚¯ã™ã‚‹ã¨ã€ã‚¹ãƒšãƒ¼ã‚¹ä»¥å¤–ã®ã€ŒåŒºåˆ‡ã‚Šæ–‡å­—ã€ãŒé€£ç¶šã—ãŸå ´åˆã€é€£ç¶šã—ãŸæ•°ã ã‘データãŒç„¡ã„ã‚‚ã®ã¨ã—ã¦æ‰±ã‚れる。
マスク
追加 「新è¦è¡Œã€ã«æŒ‡å®šã—ãŸãƒ‡ãƒ¼ã‚¿è¡Œã‚’マスクã¨ã—ã¦è¿½åŠ ã™ã‚‹ã€‚ マスクã®è¿½åŠ ã¯ãƒ¢ãƒ¼ãƒ‰ã‚’用ã„ã€ãƒžã‚¦ã‚¹ã§ãƒ—ロットã•れãŸãƒ‡ãƒ¼ã‚¿ã‚’指定ã™ã‚‹ã“ã¨ã§ã‚‚å¯èƒ½ã€‚
削除 「マスク行ã€ãƒªã‚¹ãƒˆã®ä¸­ã§é¸æŠžã—ãŸãƒ‡ãƒ¼ã‚¿è¡Œã®ãƒžã‚¹ã‚¯ã‚’解除ã™ã‚‹ã€‚
移動
追加 「新è¦è¡Œã€ã«æŒ‡å®šã—ãŸãƒ‡ãƒ¼ã‚¿è¡Œã®ãƒ‡ãƒ¼ã‚¿ã‚’「X, Yã€ã§æŒ‡å®šã•れるデータã¨ã—ã¦è§£é‡ˆã™ã‚‹ã‚ˆã†ã«ã€Œç§»å‹•行ã€ãƒªã‚¹ãƒˆã«è¿½åŠ ã™ã‚‹ã€‚ データã®ç§»å‹•ã¯ãƒ¢ãƒ¼ãƒ‰ã‚’用ã„ã€ãƒžã‚¦ã‚¹ã§ãƒ—ロットã•れãŸãƒ‡ãƒ¼ã‚¿ã‚’指定ã™ã‚‹ã“ã¨ã§ã‚‚å¯èƒ½ã€‚
削除 「移動行ã€ãƒªã‚¹ãƒˆã®ä¸­ã§é¸æŠžã—ãŸãƒ‡ãƒ¼ã‚¿è¡Œã®ãƒ‡ãƒ¼ã‚¿ç§»å‹•を解除ã™ã‚‹ã€‚
å…¨ã¦ã«é©ç”¨ ãƒ‡ãƒ¼ã‚¿é¸æŠžãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã§ã€è¤‡æ•°ã®ãƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸå ´åˆã€ ã“れ以é™ã®ãƒ‡ãƒ¼ã‚¿ã«å¯¾ã—ã¦ã¯ç¾åœ¨ã®è¨­å®šã‚’用ã„る。
設定ã®ã‚³ãƒ”ー ãれãžã‚Œã®ã‚¿ãƒ–ã§è¨­å®šã™ã‚‹ãƒ‘ラメータを他ã®ãƒ‡ãƒ¼ã‚¿ã‹ã‚‰å–り込む。



フィット・ダイアログボックス



種類 フィッティングã®ç¨®é¡žã€‚多項å¼, ã¹ã関数 (y=a*x^b), 指数関数 (y=exp(a*x+b)), 対数 (y=a*log(x)+b), ユーザ定義(ユーザ定義å¼ã«ã‚ˆã‚‹ãƒ•ィット)ã‹ã‚‰é¸æŠžã€‚
å¤šé …å¼æ¬¡å…ƒ 種類ãŒpolyã®æ™‚ã®å¤šé …å¼ã®æ¬¡æ•°ã€‚
通éŽç‚¹ ãƒã‚§ãƒƒã‚¯ã™ã‚‹ã¨ã€ŒX, Yã€ã«æŒ‡å®šã—ãŸç‚¹ã‚’通るæ¡ä»¶ä»˜ãã§ãƒ•ィットãŒè¡Œã‚れる。 種類㌠user ã«å ´åˆã«ã€ã“ã®ã‚ªãƒ—ã‚·ãƒ§ãƒ³ã¯æŒ‡å®šã§ããªã„。
é‡ã¿ä»˜ã‘ データã«é‡ã¿ä»˜ã‘ã‚’ã—ã¦ãƒ•ィットã™ã‚‹ã€‚æ•°å¼å¤‰æ›ã¨ åŒæ§˜ã®é–¢æ•°ãŒä½¿ç”¨ã§ãã‚‹ãŒã€ãƒ‡ãƒ¼ã‚¿ãƒ‘ラメータ %Fxxxx ã‚„ F(), G(), H(), COLOR(), MARKSIZE() 関数ãªã©ã¯ä½¿ç”¨ã§ããªã„。通常ã®ãƒ•ィットã¯ã€ é‡ã¿ä»˜ã‘ 1 ã«å¯¾å¿œã™ã‚‹ã€‚
最å°ã€æœ€å¤§ã€åˆ†å‰² ãƒ•ã‚£ãƒƒãƒˆçµæžœã®æç”»æ³•を設定ã™ã‚‹ã€‚ ãƒ•ã‚£ãƒƒãƒˆçµæžœå¼ã®Xã®å€¤ã‚’ã€ã€Œæœ€å°ã€ã‹ã‚‰ã€Œæœ€å¤§ã€ã¾ã§ã‚’ã€Œåˆ†å‰²ã€æ•°ã ã‘分割ã—ã¦è©•価ã—㦠Y ã®å€¤ã‚’求ã‚ã¦ç›´ç·šã§çµã¶ã€‚ 「最大ã€ã€Œæœ€å°ã€ãŒå…±ã« 0 ã®æ™‚㯠X è»¸ã®æœ€å°ã¨æœ€å¤§ãŒç”¨ã„られる。
補間 ãƒã‚§ãƒƒã‚¯ã—ã¦ã‚ã‚‹å ´åˆã€ãƒ•ã‚£ãƒƒãƒˆçµæžœã¯ç›´ç·šã®é›†ã¾ã‚Šã§ã¯ãªãã€ã‚¹ãƒ—ライン補間ã—ã¦æ›²ç·šã§æç”»ã•れる。
ãƒ•ã‚£ãƒƒãƒˆå¼ ç¨®é¡žãŒ user ã®æ™‚ã«ãƒ•ィットã«ç”¨ã„られるå¼ã€‚ %01ã‹ã‚‰%09ã¾ã§ãŒãƒ•ã‚£ãƒƒãƒˆã§æ±‚ã‚られるパラメターã¨ãªã‚‹ã€‚
åŽæŸ 種類㌠user ã®æ™‚ã€åŽæŸæ¡ä»¶ã‚’ % ã§æŒ‡å®šã™ã‚‹ã€‚デフォルトã§ã¯ 1% ãªã®ã§ã€ãƒ•ã‚£ãƒƒãƒˆçµæžœã¯1/100 ã®ç²¾åº¦ã¨ãªã‚‹ã€‚
å¾®åˆ†å¼æŒ‡å®š ãƒã‚§ãƒƒã‚¯ã—ã¦ã‚ã‚‹å ´åˆã€å¾®åˆ†å¼ã‚’使ã£ã¦ãƒ‘ラメター微分ã®å€¤ã‚’計算ã™ã‚‹ã€‚ ãƒã‚§ãƒƒã‚¯ã—ã¦ã„ãªã„å ´åˆã€æ•°å€¤çš„ã«ãƒ‘ラメター微分ã®è¿‘似値を計算ã™ã‚‹ã€‚
%00-%09 種類㌠user ã®å ´åˆã«ã¯ãƒ•ィッティングパラメターã¯ç¹°ã‚Šè¿”ã—処ç†ã§æ±‚ã‚られるãŒã€ãã®ç¹°ã‚Šè¿”ã—処ç†ã®åˆæœŸå€¤ã‚’指定ã™ã‚‹ã€‚ フィット関数ã«ã‚ˆã£ã¦ã¯ã€ãƒ•ã‚£ãƒƒãƒ†ã‚£ãƒ³ã‚°çµæžœã«è¿‘ã„値を入れãªã„ã¨åŽæŸã—ãªã„。
dF/d(%00)-dF/d(%09) フィットå¼ã‚’フィッティングパラメター%00-%09ã§å微分ã—ãŸå¼ã€‚ ã€Œå¾®åˆ†å¼æŒ‡å®šã€ã‚’ãƒã‚§ãƒƒã‚¯ã—ãŸå ´åˆã«æŒ‡å®šã™ã‚‹å¿…è¦ãŒã‚る。
çµæžœè¡¨ç¤º ãƒ•ã‚£ãƒƒãƒˆçµæžœã‚’表示ã™ã‚‹ã€‚
Copy ä»–ã®ãƒ‡ãƒ¼ã‚¿ã®ãƒ•ィット設定をå–り込む。
設定読込 ä¿å­˜ã—ã¦ã‚るフィット設定を読ã¿è¾¼ã‚€ã€‚
設定ä¿å­˜ ç¾åœ¨ã®ãƒ•ィット設定をä¿å­˜ã™ã‚‹ã€‚後ã§èª­ã¿è¾¼ã‚€éš›ã«åŒºåˆ¥ãŒã¤ãよã†ã«ã€Œãƒ—ロファイルã€ã‚’指定ã™ã‚‹ã€‚ 設定㯠fit.ngp ã®åå‰ã®ãƒ•ァイルã«ä¿å­˜ã•れる。



軸・ダイアログボックス

スケール
最å°å€¤ã€æœ€å¤§å€¤ 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã®æœ€å¤§ã¨æœ€å°ã€‚ 「最å°å€¤ã€ã€Œæœ€å¤§å€¤ã€ã€Œå¢—分ã€ã®å…¨ã¦ãŒ 0 ã®æ™‚ã€ã‚¹ã‚±ãƒ¼ãƒ«ã¯æœªè¨­å®šçŠ¶æ…‹ã¨ã¿ãªã•れæç”»æ™‚ã«è‡ªå‹•çš„ã«è¨­å®šã•れる。
増分 目盛数字ã¯ã€Œå¢—分ã€ã®å€¤æ¯Žã«ä»˜ã‘られã€ç›®ç››ç·šã¯ã€Œå¢—分ã€ã‚’「分割数ã€ã ã‘分割ã—ãŸå€¤æ¯Žã«ä»˜ã‘られる。 「スケール法ã€ãŒ log ã®æ™‚ã€ã€Œå¢—分ã€ãŒ10 ã§ã¯ 10, 100, 1000 ã®æ§˜ã«ç›®ç››æ•°å­—ãŒä»˜ã‘られ〠「増分ã€ãŒ 1 ã®æ™‚ã«ã¯ 1, 2, 3 ã®æ§˜ã«ç›®ç››æ•°å­—ãŒä»˜ã‘られる。
スケール法

linear(通常ã®ç·šå½¢è»¸), log(対数軸), inverse(逆数軸), MJD(軸ã®å€¤ã‚’ MJD ã¨ã—ã¦æ—¥æ™‚ã§è¡¨ç¤º) ã‹ã‚‰é¸æŠžã€‚

クリア スケールを未設定状態(「最å°å€¤ã€ã€Œæœ€å¤§å€¤ã€ã€Œå¢—分ã€ã®å…¨ã¦ãŒ 0)ã«ã™ã‚‹ã€‚
データ 指定ã—ãŸãƒ‡ãƒ¼ã‚¿ã§ã‚¹ã‚±ãƒ¼ãƒ«ã‚’自動設定ã™ã‚‹ã€‚
分割数 「増分ã€ã‚’æ›´ã«åˆ†å‰²ã™ã‚‹åˆ†å‰²æ•°ã€‚
å‚照軸 ã‚¹ã‚±ãƒ¼ãƒ«ãŒæœªè¨­å®šçŠ¶æ…‹(「最å°å€¤ã€ã€Œæœ€å¤§å€¤ã€ã€Œå¢—分ã€ã®å…¨ã¦ãŒ 0)ã®æ™‚ã€ã“ã“ã«æŒ‡å®šã—ãŸè»¸ã®è¨­å®šãŒä»£ã‚りã«ä½¿ã‚れる。 軸ã®é€šã—番å·ã§ã¯ãªãã€å®Ÿè¡Œæ™‚ã«æ±ºã¾ã‚‹ä¸€æ„ã®ç•ªå·(Axis タブã®è¡Œæœ«ã«è¡¨ç¤ºã•れる^ã§å§‹ã¾ã‚‹æ•°å­—)ã§æŒ‡å®šã™ã‚‹ãŒã€ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ã®ãƒªã‚¹ãƒˆã«ã¯è»¸ã®åå‰ã§ä¸€è¦§è¡¨ç¤ºã•れる。
オートスケール余白 オートスケール時ã®ä½™ç™½ã‚’ % ã§æŒ‡å®šã—ã¾ã™ã€‚
軸基線
基線æç”» ãƒã‚§ãƒƒã‚¯ã‚’外ã™ã¨è»¸ã®åŸºç·šã‚’æç”»ã—ãªããªã‚‹ã€‚
線種 基線ã®ç¨®é¡žã€‚ 点線ã®é•·ã•ã€é–“éš”ã‚’è©³ç´°ã«æŒ‡å®šã™ã‚‹ã«ã¯ã€"100 10" ã®æ§˜ã«ç‚¹ç·šã®ç¹°ã‚Šè¿”ã—è¦ç´ ã®é•·ã•を指定ã™ã‚‹ã€‚
ç·šå¹…ã€è‰² 基線ã®å¹…ã¨è‰²ã€‚
矢å°ã€æ³¢åž‹ 軸基線ã®ç«¯ã«ã¯çŸ¢å°ã‚„波型を付加ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚矢å°ã¯äº¤å·®ã‚°ãƒ©ãƒ•ã®è»¸ã«ã€æ³¢åž‹ã¯ï¼’ã¤ã®è»¸ã‚’使ã£ã¦åˆ†æ–­ã•れãŸè»¸ã‚’表ç¾ã™ã‚‹ã®ã«ä½¿ã†ã€‚ 矢å°ã®ã€Œé•·ã•ã€ã¨ã€Œå¹…ã€ã¯ã€åŸºç·šã®ã€Œç·šå¹…ã€ã«å¯¾ã—㦠% ã§æŒ‡å®šã™ã‚‹ã€‚
目盛線
ä½ç½® none(目盛線ãªã—), right(軸基線ã®å³å›žã‚Šæ–¹å‘), left(軸基線ã®å·¦å›žã‚Šæ–¹å‘), both(両å´)ã‹ã‚‰é¸æŠžã€‚
範囲最å°å€¤ã€ç¯„囲最大値 目盛線を付ã‘る軸スケールã®ç¯„囲を指定ã™ã‚‹ã€‚両方共ã«0ã®æ™‚ã¯ã€è»¸å…¨ä½“ã«ç›®ç››ãŒä»˜ã‘られる。
線種 目盛線ã®ç¨®é¡žã€‚ 点線ã®é•·ã•ã€é–“éš”ã‚’è©³ç´°ã«æŒ‡å®šã™ã‚‹ã«ã¯ã€"100 10" ã®æ§˜ã«ç‚¹ç·šã®ç¹°ã‚Šè¿”ã—è¦ç´ ã®é•·ã•を指定ã™ã‚‹ã€‚
色 目盛線ã®è‰²ã€‚
é•·ã•1, 2, 3 目盛線ã®é•·ã•。目盛線ã®ã‚¹ã‚±ãƒ¼ãƒ«ã®ç´°ã‹ã„æ–¹ã‹ã‚‰å¹…1, 2, 3ã¨ã™ã‚‹ã€‚
ç·šå¹…1, 2, 3 目盛線ã®å¹…。目盛線ã®ã‚¹ã‚±ãƒ¼ãƒ«ã®ç´°ã‹ã„æ–¹ã‹ã‚‰å¹…1, 2, 3ã¨ã™ã‚‹ã€‚
目盛数字
ä½ç½® none(目盛線ãªã—), right(軸基線ã®å³å›žã‚Šæ–¹å‘), left(軸基線ã®å·¦å›žã‚Šæ–¹å‘), both(両å´)ã‹ã‚‰é¸æŠžã€‚
開始点ã€å€‹æ•° 目盛数字ã¯ã‚¹ã‚±ãƒ¼ãƒ«ã®ã€Œå¢—分ã€(ã‚ã‚‹ã„ã¯ãã®æ•´æ•°å€)毎ã«ä»˜ã‘ã‚‹ãŒã€ä½•番目ã‹ã‚‰ä»˜ã‘ã‚‹ã‹ã‚’「開始点ã€ã§ã€ 付ã‘る個数を「個数ã€ã§æŒ‡å®šã™ã‚‹ã€‚ 「開始点ã€ãŒ0ã§åˆã‚ã‹ã‚‰ä»˜ã‘られã€ã€Œå€‹æ•°ã€ãŒ-1ã§æœ€å¾Œã¾ã§ä»˜ã‘られる。
é–“éš” 目盛数字をスケールã®ã€Œå¢—分ã€ã®æ•´æ•°å€æ¯Žã«ä»˜ã‘ã‚‹å ´åˆã€ãã®æ•´æ•°å€ã®å€¤ã€‚ 0ã§è‡ªå‹•設定。
+付加 目盛数字ãŒ0ã¾ãŸã¯æ­£ã®å€¤ã®æ™‚ã€+ã‚’å¿…ãšè¿½åŠ ã™ã‚‹ã€‚
å°æ•°éƒ¨æ¡ 目盛数字ã®å°æ•°éƒ¨ã®æ¡æ•°ã€‚
先頭 å„目盛数字ã®å…ˆé ­ã«ä»˜ã‘る文字列。
後続 å„目盛数字ã®å¾Œç¶šã«ä»˜ã‘る文字列。
æ—¥æ™‚æ›¸å¼ ã‚¹ã‚±ãƒ¼ãƒ«æ³•ãŒ MJD ã®æ™‚ã®æ—¥æ™‚書å¼ã‚’指定ã™ã‚‹ã€‚利用ã§ãる設定ã«ã¤ã„ ã¦ã¯ä¸‹è¨˜ã‚’å‚照。指定ã—ãªã„å ´åˆã¯ã€ã‚¹ã‚±ãƒ¼ãƒ«ã®ç¯„囲ã‹ã‚‰è‡ªå‹•設定ã•れる。
ä½ç½®åˆã‚ã› center(中心æƒãˆ), left(å·¦æƒãˆ), right(峿ƒãˆ), point(å°æ•°ç‚¹ä½ç½®æƒãˆ)ã‹ã‚‰é¸æŠžã€‚
æ–¹å‘ ç›®ç››æ•°å­—ã®æ–‡å­—æç”»ã®æ–¹å‘。
å¹³è¡Œã‚·ãƒ•ãƒˆé‡ ç›®ç››æ•°å­—ã®ä½ç½®ã‚’軸基線ã«å¹³è¡Œã«ãšã‚‰ã™ã€‚
åž‚ç›´ã‚·ãƒ•ãƒˆé‡ ç›®ç››æ•°å­—ã®ä½ç½®ã‚’軸基線ã«åž‚ç›´ã«ãšã‚‰ã™ã€‚
ベキ形å¼(ログ) 対数グラフã®ç›®ç››æ•°å­—ã‚’ 1, 10, 100 ã¨ã™ã‚‹ã‹ 10^0, 10^1, 10^2 ã¨ã™ã‚‹ã‹ã®æŒ‡å®šã€‚
ゼロéžè¡¨ç¤º 0ã®ç›®ç››æ•°å­—ã‚’æç”»ã—ãªã„。X軸-Y軸㮠(0,0) ã‚’ã¾ã¨ã‚ã¦ä¸€ã¤ã® 0 ã¨ã—ãŸã„å ´åˆã«ã€ã“ã®ã‚ªãƒ—ションを使ã£ã¦ 0 を表示ã—ãªã„よã†ã«ã—ã¦ã€æ‰‹å‹•ã§ 0 を入れる。
自動スケール 目盛数字ãŒã“ã“ã§æŒ‡å®šã™ã‚‹æ¡æ•°ã‚ˆã‚Šå¤§ãã(100000ã®æ§˜ã«)ã€ã‚ã‚‹ã„ã¯å°ã•ããªã£ãŸå ´åˆ(0.00001ã®æ§˜ã«)ã«ã¯æ­£è¦åŒ–ã•れã€[1x10^5] ã®æ§˜ãªå‡¡ä¾‹ãŒè»¸ã«ä»˜ã‘られる。
æ•°å¼å¤‰æ› 目盛数値を指定ã—ãŸæ•°å¼ã§å¤‰æ›ã—ã¦è¡¨ç¤ºã—ã¾ã™ã€‚
"日時書å¼" ã§åˆ©ç”¨ã§ãã‚‹å¤‰æ›æŒ‡å®šã®æ–‡å­—ã¯ä»¥ä¸‹ã®ã¨ãŠã‚Šã€‚
%a曜日ã®çœç•¥å。
%A曜日。
%b月ã®çœç•¥å。
%B月ã®å®Œå…¨ãªåå‰ã€‚
%c%a %b %e %T %Y ã¨åŒç­‰ã€‚
%C世紀 (西暦年ã®ä¸Š 2 æ¡)。
%d月内通算日 (01-31)。
%D%m/%d/%y ã¨åŒç­‰ã€‚
%e %d ã¨åŒæ§˜ã«æœˆå†…通算日を 10 進数ã§è¡¨ç¾ã™ã‚‹ãŒã€ 1 æ¡ã®å ´åˆ 10 ã®ä½ ã«ã‚¼ãƒ­ã‚’ç½®ã‹ãšã‚¹ãƒšãƒ¼ã‚¹ã‚’ç½®ã。
%F%Y-%m-%d ã¨åŒç­‰ã€‚
%G ISO 8601 週å˜ä½è¡¨è¨˜ã®å¹´ã€‚世紀も 10 進数ã§è¡¨ã™ã€‚ ISO é€±ç•ªå· (%V ã‚’å‚ç…§) ã«å¯¾å¿œã—㟠4 æ¡ã®è¥¿æš¦å¹´ã€‚㓠れã¯åŸºæœ¬çš„ã«ã¯ %Y ã¨åŒã˜å½¢å¼ã ãŒã€ISO 週数ãŒå‰å¹´ã‚„ 翌年ã«ãªã‚‹ å ´åˆã«ã¯ãã®å¹´ãŒä½¿ç”¨ã•れる点ãŒç•°ãªã‚‹ã€‚
%g%G ã¨åŒæ§˜ã€‚但ã—ã€ä¸–紀をå«ã¾ãšä¸‹ 2 æ¡ã®ã¿ã‚’表示 (00-99)。
%H24 時間表記ã§ã®æ™‚ (00 to 23)。
%I12 時間表記ã§ã®æ™‚ (01 to 12)。
%jå¹´ã®åˆã‚ã‹ã‚‰é€šç®—ã®æ—¥æ•° (001 to 366)。
%k24 時間表記ã§ã®æ™‚ (0-23)。1 æ¡ã®å ´åˆã«ã¯å‰ã«ã‚¼ãƒ­ã§ãªãスペースãŒç½®ã‹ã‚Œã‚‹ã€‚
%l12 時間表記ã§ã®æ™‚ (0-23)。1 æ¡ã®å ´åˆã«ã¯å‰ã«ã‚¼ãƒ­ã§ãªãスペースãŒç½®ã‹ã‚Œã‚‹ã€‚
%m月 (01 to 12)。
%M分 (00 to 59)。
%n改行。
%p"AM" ã¾ãŸã¯ "PM"。
%P"am" ã¾ãŸã¯ "pm"。
%r%I:%M:%S %p ã¨åŒç­‰ã€‚
%R%H:%M ã¨åŒç­‰ã€‚
%S秒 (00 to 60)。
%tタブ文字。
%T%H:%M:%S ã¨åŒç­‰ã€‚
%u週ã®ä½•ç•ªç›®ã®æ—¥ (10 進数表記) ã‹ã€‚月曜日を 1 ã¨ã™ã‚‹ (1 to 7)。
%U å¹´ã®åˆã‚ã‹ã‚‰ã®é€šç®—ã®é€±ç•ªå· (10 進数表記) (00-53)。 ãã®å¹´ã®æœ€åˆ ã®æ—¥æ›œæ—¥ã‚’ã€ç¬¬ 1 週ã®å§‹ã¾ã‚Šã¨ã—ã¦è¨ˆç®—ã™ã‚‹ã€‚ %V 㨠%W ã‚‚å‚ç…§ã™ã‚‹ ã“ã¨ã€‚
%V ISO 8601 å½¢å¼ã§ã®å¹´ã®å§‹ã‚ã‹ã‚‰ã®é€±ç•ªå·ã€‚ 10 進 数表記ã§ã€01 ã‹ã‚‰ 53 ã®å€¤ã¨ãªã‚‹ã€‚週番å·ã¯ã€ æ–°ã—ã„ å¹´ãŒå°‘ãªãã¨ã‚‚ 4 日以上å«ã¾ã‚Œã‚‹æœ€åˆã®é€±ã‚’ 1 ã¨ã—㦠計算ã™ã‚‹ã€‚ %U 㨠%W ã‚‚å‚ç…§ã®ã“ã¨ã€‚
%w週ã®ä½•ç•ªç›®ã®æ—¥ (10 進数表記) ã‹ã€‚日曜日を 0 ã¨ã™ã‚‹ (0 to 6)。
%W å¹´ã®åˆã‚ã‹ã‚‰ã®é€šç®—ã®é€±ç•ªå· (10 進数表記) (00-53)。ãã®å¹´ã®æœ€åˆ ã®æœˆæ›œæ—¥ã‚’ã€ç¬¬ 1 週ã®å§‹ã¾ã‚Šã¨ã—ã¦è¨ˆç®—ã™ã‚‹ã€‚
%x%D ã¨åŒç­‰ã€‚
%X%T ã¨åŒç­‰ã€‚
%y西暦ã®ä¸‹2æ¡ (世紀部分をå«ã¾ãªã„å¹´) (00 to 99)。
%Y西暦年。
%z+0000
%ZGMT
%+%a %b %e %T %Z %Y ã¨åŒç­‰ã€‚
%%'%' 文字。
フォント
ãƒã‚¤ãƒ³ãƒˆ ç›®ç››æ•°å­—ã®æ–‡å­—ã®å¤§ãã•(ãƒã‚¤ãƒ³ãƒˆ)。ptå˜ä½ã§æŒ‡å®šã€‚
文字間 文字ã®é–“を空ã‘ãŸã„ã¨ãã« pt å˜ä½ã§æŒ‡å®šã€‚
スクリプトサイズ 上付ãã€ä¸‹ä»˜ãæ–‡å­—ã‚’é€šå¸¸ã®æ–‡å­—ã®ä½•パーセントã«ã™ã‚‹ã‹ã‚’ %å˜ä½ã§æŒ‡å®šã€‚
フォント 目盛数字ã®ãƒ•ォント。
å¤ªå­—ã€æ–œä½“ フォントã®ã‚¹ã‚¿ã‚¤ãƒ«æŒ‡å®šã€‚
色 目盛数字ã®è‰²ã€‚
ä½ç½®
X, Y, é•·ã•ã€æ–¹å‘ 軸ã®ä½ç½®ã€é•·ã•ã€æ–¹å‘を指定。通常ã®ä½¿ç”¨ã§ã¯ã‚°ãƒ©ãƒ•上ã§ãƒžã‚¦ スを使ã£ã¦ã‚°ãƒ©ãƒ•ã®ä½ç½®ã€å½¢çŠ¶ã‚’å¤‰ãˆã‚‹ã‹ã€è»¸ã‚’ダブルクリックã—ã¦ç¾ れるグラフダイアログボックスã§å¤‰æ›´ã™ã‚‹ãŒã€ãれã§ã¯ã§ããªã„変更 (グラフを構æˆã™ã‚‹è»¸ã‚’個別ã«å¤‰æ›´ã—ãŸã„å ´åˆç­‰)ã‚’ã—ãŸã„æ™‚ã«æŒ‡å®šã™ã‚‹ã€‚
交差軸 交差グラフã§äº¤å·®ã™ã‚‹ã‚‚ã†ä¸€æ–¹ã®è»¸ã€‚
交差ä½ç½® 交差グラフã§ã‚‚ã†ä¸€æ–¹ã®è»¸ã¨äº¤å·®ã™ã‚‹ä½ç½®ã‚’スケールã®ã€Œå¢—分ã€å˜ä½ã§æŒ‡å®šã™ã‚‹ã€‚0ã§è‡ªå‹•設定。



グリッド・ダイアログボックス



X軸ã€Y軸 グリッドを付ã‘ã‚‹2ã¤ã®è»¸ã‚’指定ã™ã‚‹ã€‚ 軸ã®é€šã—番å·ã§ã¯ãªãã€å®Ÿè¡Œæ™‚ã«æ±ºã¾ã‚‹ä¸€æ„ã®ç•ªå·(Axis タブã®è¡Œæœ«ã«è¡¨ç¤ºã•れる^ã§å§‹ã¾ã‚‹æ•°å­—)ã§æŒ‡å®šã™ã‚‹ãŒã€ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ã®ãƒªã‚¹ãƒˆã«ã¯è»¸ã®åå‰ã§ä¸€è¦§è¡¨ç¤ºã•れる。
Xグリッドæç”»ã€Yグリッドæç”» ãれãžã‚Œã®ã‚°ãƒªãƒƒãƒ‰ç·šæç”»ã®æœ‰ç„¡ã‚’指定ã™ã‚‹ã€‚
線種1, 2, 3 グリッド線ã®ç¨®é¡žã€‚グリッドã®ã‚¹ã‚±ãƒ¼ãƒ«ã®ç´°ã‹ã„æ–¹ã‹ã‚‰ç·šç¨®1, 2, 3ã¨ã™ã‚‹ã€‚ 点線ã®é•·ã•ã€é–“éš”ã‚’è©³ç´°ã«æŒ‡å®šã™ã‚‹ã«ã¯ã€"100 10" ã®æ§˜ã«ç‚¹ç·šã®ç¹°ã‚Šè¿”ã—è¦ç´ ã®é•·ã•を指定ã™ã‚‹ã€‚
ç·šå¹…1, 2, 3 グリッド線ã®å¹…。グリッドã®ã‚¹ã‚±ãƒ¼ãƒ«ã®ç´°ã‹ã„æ–¹ã‹ã‚‰å¹…1, 2, 3ã¨ã™ã‚‹ã€‚
色 グリッドã®è‰²ã€‚
背景ã€èƒŒæ™¯è‰² 「背景ã€ã‚’ãƒã‚§ãƒƒã‚¯ã™ã‚‹ã¨ã€ã‚°ãƒ©ãƒ•ã®èƒŒæ™¯ã‚’一様ã«ã€ŒèƒŒæ™¯è‰²ã€ã§å¡—りã¤ã¶ã™ã€‚



レジェンド(凡例)・ダイアログボックス

共通項目
線種 ç·šã®ç¨®é¡žã€‚点線ã®é•·ã•ã€é–“éš”ã‚’è©³ç´°ã«æŒ‡å®šã™ã‚‹ã«ã¯ã€"100 10" ã®æ§˜ã«ç‚¹ç·šã®ç¹°ã‚Šè¿”ã—è¦ç´ ã®é•·ã•を指定ã™ã‚‹ã€‚
ç·šå¹… ç·šã®å¹…。
マイター マイターリミット。折れ線ã®è§’ã§è¼ªéƒ­ã‚’ã©ã“ã¾ã§æç”»ã™ã‚‹ã‹ã‚’決ã‚る。
ジョイン 折れ線ã®è§’ã®è¼ªéƒ­å½¢çŠ¶ã€‚
色 レジェンドã®è‰²ã€‚
パス
座標 ç›´ç·šã€æ›²ç·šã€å¤šè§’å½¢ã®å ´åˆã«ç‚¹åˆ—ã®åº§æ¨™ã‚’指定ã™ã‚‹ã€‚「追加ã€ã€Œå‰Šé™¤ã€ã®ãƒœã‚¿ãƒ³ã§åº§æ¨™ã‚’追加ã¾ãŸã¯å‰Šé™¤ã§ãる。ã¾ãŸã€è¡Œã‚’ドラッグã™ã‚‹ã“ã¨ã§åº§æ¨™ã®é †ç•ªã‚’変ãˆã‚‹ã“ã¨ãŒå‡ºæ¥ã‚‹ã€‚
タイプ 「直線ã€ã€Œæ›²ç·šã€ã‹ã‚‰é¸æŠžã€‚
補間法 æ›²ç·šã®æç”»ã«ä½¿ã‚れる補間法。「スプラインã€,「閉スプラインã€,「Bスプラインã€, 「閉Bスプラインã€ã‹ã‚‰é¸æŠžã€‚ Bスプラインを使ã†ã«ã¯åº§æ¨™ç‚¹ãŒ7点以上必è¦ã€‚
ストローク 輪郭をæç”»ã™ã‚‹ã€‚
パスを閉ã˜ã‚‹ 終点ã¨å§‹ç‚¹ã‚’ç›´ç·šã§çµã¶ã€‚
マーカ ç›´ç·šã®å§‹ç‚¹ã€çµ‚点ã«ãƒžãƒ¼ã‚«ã‚’付加ã™ã‚‹ã€‚ãªã—, 矢å°, 波線, マーク, 棒ã‹ã‚‰é¸æŠžã€‚
塗りã¤ã¶ã— 内部を塗りã¤ã¶ã™ã€‚
ルール 塗りã¤ã¶ã—ã®æ–¹æ³•。even_odd_rule, winding_rule ã‹ã‚‰é¸æŠžã€‚
スライダ 矢å°ã®å½¢çжã€å¤§ãã•を指定ã™ã‚‹ã€‚上ã®ã‚¹ãƒ©ã‚¤ãƒ€ã¯çŸ¢å°»ã®è§’度ã€ä¸‹ã®ã‚¹ãƒ©ã‚¤ãƒ€ã¯çŸ¢å°»ã®é•·ã•ã‚’ç·šå¹…ã‚’å˜ä½ã«ã—ã¦æŒ‡å®šã™ã‚‹ã€‚ 矢尻ã®å½¢çжã¯ã‚°ãƒ©ãƒ•ィカルã«è¡¨ç¤ºã•れã€å…ˆç«¯ã®è§’度も表示ã•れる。 矢å°ä»¥å¤–ã®ãƒžãƒ¼ã‚«ã«ã¯ä¸‹ã®ã‚¹ãƒ©ã‚¤ãƒ€ã®è¨­å®šå€¤ã ã‘ãŒä½¿ã‚れる。
四角形
X1, Y1, X2, Y2 四角形ã®åº§æ¨™ã€‚
塗りã¤ã¶ã— 四角形ã®å†…部を「色ã€ã§å¡—りã¤ã¶ã™ã€‚
ストローク 四角形ã®è¼ªéƒ­ã‚’「色ã€ã§æç”»ã€‚
円
X, Y, RX, RY 円ã®ä¸­å¿ƒåº§æ¨™(X,Y) ã¨Xæ–¹å‘åŠå¾„ RX, Yæ–¹å‘åŠå¾„ RY。
é–‹å§‹è§’ã€å††å¼§è§’ 円弧ã¯ã€Œé–‹å§‹è§’ã€ã‹ã‚‰å時計回りã«ã€Œå††å¼§è§’ã€ã ã‘æç”»ã•れる。1度å˜ä½ã€‚
扇形 円ã®ä¸­å¿ƒã‚’円弧ã®ç«¯ã‚’çµã‚“ã æ‰‡å½¢ã¨ã—ã¦æç”»ã™ã‚‹ã€‚
ストローク 扇形ã¾ãŸã¯å¼¦å½¢ã®è¼ªéƒ­ã‚’「色ã€ã§æç”»ã€‚
パスを閉ã˜ã‚‹ 扇形ã®å ´åˆã¯å††ã®ä¸­å¿ƒã‚’円弧ã®ç«¯ã‚’çµã‚“ã æ‰‡å½¢ã¨ã—ã¦æç”»ã™ã‚‹ã€‚扇形 ã§ãªã„å ´åˆã¯å††å¼§ã®ç«¯ã‚’ç›´ç·šã§çµã¶ã€‚
マーカ 円弧ã®å§‹ç‚¹ã€çµ‚点ã«ãƒžãƒ¼ã‚«ã‚’付加ã™ã‚‹ã€‚ãªã—, 矢å°, 波線, マーク, 棒ã‹ã‚‰é¸æŠžã€‚
塗りã¤ã¶ã— 扇形ã¾ãŸã¯å¼¦å½¢ã¨ã—ã¦å¡—りã¤ã¶ã™ã€‚
スライダ 矢å°ã®å½¢çжã€å¤§ãã•を指定ã™ã‚‹ã€‚上ã®ã‚¹ãƒ©ã‚¤ãƒ€ã¯çŸ¢å°»ã®è§’度ã€ä¸‹ã®ã‚¹ãƒ©ã‚¤ãƒ€ã¯çŸ¢å°»ã®é•·ã•ã‚’ç·šå¹…ã‚’å˜ä½ã«ã—ã¦æŒ‡å®šã™ã‚‹ã€‚ 矢尻ã®å½¢çжã¯ã‚°ãƒ©ãƒ•ィカルã«è¡¨ç¤ºã•れã€å…ˆç«¯ã®è§’度も表示ã•れる。 矢å°ä»¥å¤–ã®ãƒžãƒ¼ã‚«ã«ã¯ä¸‹ã®ã‚¹ãƒ©ã‚¤ãƒ€ã®è¨­å®šå€¤ã ã‘ãŒä½¿ã‚れる。
マーク
X, Y マークã®ä¸­å¿ƒåº§æ¨™ã€‚
マーク マークã®ç¨®é¡žã€‚
サイズ マークã®ã‚µã‚¤ã‚ºã€‚
色1, 色2 マークã®ç¬¬ä¸€è‰²ã€Œè‰²1ã€ã¨ç¬¬äºŒè‰²ã€Œè‰²2ã€ã€‚
テキスト
X, Y テキストã®å·¦ä¸‹ç«¯(æ–¹å‘0ã®æ™‚)ã®åº§æ¨™ã€‚
テキスト 文字列中ã«åˆ¶å¾¡æ–‡å­—を入れる事ã§ã€ãƒ•ォントを文字列å˜ä½ã§å¤‰ãˆãŸã‚ŠãŒå¯èƒ½ã€‚詳細ã¯ãƒ†ã‚­ã‚¹ãƒˆæç”»ã®åˆ¶å¾¡æ–‡å­—ã‚’å‚照。
ãƒã‚¤ãƒ³ãƒˆã€æ–‡å­—é–“ 文字ã®ãƒã‚¤ãƒ³ãƒˆæ•°(ptå˜ä½)ã¨æ–‡å­—é–“ã®ã‚¹ãƒšãƒ¼ã‚¹(ptå˜ä½)。
スクリプトサイズ ä¸Šä»˜ãæ–‡å­—ã€ä¸‹ä»˜ã文字をã€é€šå¸¸ã®æ–‡å­—ã®å¤§ãã•ã®ä½•パーセントã®å¤§ãã•ã«ã™ã‚‹ã‹ã‚’ %å˜ä½ã§æŒ‡å®šã™ã‚‹ã€‚
フォント 使用ã™ã‚‹ãƒ•ォント。
å¤ªå­—ã€æ–œä½“ フォントã®ã‚¹ã‚¿ã‚¤ãƒ«æŒ‡å®šã€‚
æ–¹å‘ æ–‡å­—åˆ—ã‚’æç”»ã™ã‚‹æ–¹å‘。1度å˜ä½ã€‚
Raw テキストæç”»ã®åˆ¶å¾¡æ–‡å­—ã®æ©Ÿèƒ½ã‚’無効ã«ã—ã€ã€Œãƒ†ã‚­ã‚¹ãƒˆã€ã®æ–‡å­—列をãã®ã¾ã¾æç”»ã™ã‚‹ã€‚
ガウス関数
ガウス関数ã€ãƒ­ãƒ¼ãƒ¬ãƒ³ãƒ„é–¢æ•°ã€æ”¾ç‰©ç·šã€ä¸‰è§’関数。 é¸æŠžã—ãŸé–¢æ•°å½¢ã‚’ã‚‚ã¤ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã€Œæ›²ç·šã€ã‚’生æˆã™ã‚‹ã€‚ダイアログボックスを閉ã˜ãŸæ™‚点ã§ã€Œæ›²ç·šã€ã«å±•é–‹ã•れる。
分割数 曲線ã«å±•é–‹ã™ã‚‹éš›ã«ã€é–¢æ•°å½¢ã‚’何分割ã™ã‚‹ã‹ã‚’指定。
上ã€ä¸‹ã€å·¦ã€å³ é–¢æ•°å½¢ã®æ–¹å‘。
スライダ 関数形を変更ã™ã‚‹ã€‚



åˆæˆãƒ•ァイル・ダイアログボックス



ファイルå GRAファイル(*.GRA)ã®ãƒ•ァイルåを指定ã™ã‚‹ã€‚
左マージンã€ä¸Šãƒžãƒ¼ã‚¸ãƒ³ åˆæˆãƒ•ã‚¡ã‚¤ãƒ«ã‚’åˆæˆã™ã‚‹ä½ç½®ã€‚
ズーム åˆæˆãƒ•ァイルを拡大ã€ç¸®å°ã—ã¦åˆæˆã™ã‚‹éš›ã®æ‹¡å¤§çŽ‡ã€‚%å˜ä½ã€‚



グラフã®èª­è¾¼ã€ä¿å­˜ãƒ»ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹

グラフã®èª­è¾¼
データã®å±•é–‹ ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã‚„åˆæˆãƒ•ァイルをå«ã‚ãŸå½¢ã§ã‚»ãƒ¼ãƒ–ã—㟠NGP ファイルを読む際ã«ã€ãれらファイルを展開ã™ã‚‹ã€‚
展開フォルダ 「データã®å±•é–‹ã€ã«ã‚ˆã£ã¦ãƒ•ァイルを展開ã™ã‚‹ãƒ•ォルダ。デフォルトã¯ã‚«ãƒ¬ãƒ³ãƒˆãƒ•ォルダ(.\)。
パス情報無視 ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã‚„åˆæˆãƒ•ァイルã®ãƒ‘ス情報(フォルダå)を無視ã—ã€ãれらファイルãŒã‚«ãƒ¬ãƒ³ãƒˆãƒ•ォルダã«ã‚ã‚‹ã‚‚ã®ã¨ã—ã¦å–り扱ã†ã€‚
グラフã®ä¿å­˜
パス情報 ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã‚„åˆæˆãƒ•ァイルã®ãƒ‘ス情報をä¿å­˜ã™ã‚‹æ–¹æ³•。「変更ã—ãªã„ã€(設定ã®ã¾ã¾), 「フルパスã€(絶対パスã«å¤‰æ›´), 「ç·ä½“パスã€(カレントフォルダã‹ã‚‰ã®ç›¸å¯¾ãƒ‘ス), 「ファイルåã®ã¿ã€(パス情報ãªã—)ã‹ã‚‰é¸æŠžã€‚
データファイルをå«ã‚ã‚‹ NGPファイル中ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルもå«ã‚る。
åˆæˆãƒ•ァイルをå«ã‚ã‚‹ NGPファイル中ã«åˆæˆãƒ•ァイル(GRAファイル)ã‚‚å«ã‚る。



æç”»é †ãƒ»ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹


æç”»ã‚ªãƒ–ジェクト(æç”»é †) ã“ã®ãƒªã‚¹ãƒˆãƒœãƒƒã‚¯ã‚¹ã«æŒ‡å®šã•れãŸã‚°ãƒ©ãƒ•ィックスオブジェクトãŒã€ãã®é †ç•ªã§æç”»ãŒè¡Œã‚れる。 空白ã®å ´åˆã¯ãƒ‡ãƒ•ã‚©ãƒ«ãƒˆã®æç”»é †(å³ã®ã€Œã‚ªãƒ–ジェクトã€ãƒªã‚¹ãƒˆã®é †)ã§å…¨ã¦ã®ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆãŒæç”»ã•れる。
è¿½åŠ ã€æŒ¿å…¥ å³ã®ã€Œã‚ªãƒ–ジェクトã€ãƒªã‚¹ãƒˆã§é¸æŠžã•れã¦ã„るオブジェクトãŒã€ã€Œæç”»ã‚ªãƒ–ジェクト(æç”»é †)ã€ã®ãƒªã‚¹ãƒˆã«è¿½åŠ ã€æŒ¿å…¥ã•れる。
最åˆã¸ã€æœ€å¾Œã¸ã€ä¸Šã¸ã€ä¸‹ã¸ 「æç”»ã‚ªãƒ–ジェクト(æç”»é †)ã€ã®ãƒªã‚¹ãƒˆã§é¸æŠžã•れã¦ã„るオブジェクトã®é †ç•ªã‚’変更ã—ã¦æœ€åˆã€æœ€å¾Œã€ä¸Šã€ä¸‹ã«ç§»å‹•ã™ã‚‹ã€‚



ãã®ä»–設定・ダイアログボックス



エディター データダイアログボックスã®ã€ŒEditã€ã€Data タブã®ãƒãƒƒãƒ—アップメニューã®ã€ŒEditã€ã§ã€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを編集ã™ã‚‹ãŸã‚ã«èµ·å‹•ã•れるエディター。
ヘルプ・ブラウザ ヘルプを表示ã™ã‚‹ãŸã‚ã®ãƒ–ラウザ。
パス情報ã€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルをå«ã‚ã‚‹ã€åˆæˆãƒ•ァイルをå«ã‚ã‚‹ 「グラフã®ä¿å­˜ã€ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®åˆæœŸçŠ¶æ…‹ã‚’æ±ºã‚る。
データファイルã®å±•é–‹ã€å±•開ディレクトリã€ãƒ‘ス情報無視 「グラフã®èª­è¾¼ã€ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®åˆæœŸçŠ¶æ…‹ã‚’æ±ºã‚る。
補完履歴ã®ã‚µã‚¤ã‚º ãƒ†ã‚­ã‚¹ãƒˆã€æ•°å¼å¤‰æ›ã®å…¥åŠ›è£œå®Œã®ãŸã‚ã«ä¿å­˜ã•れる件数を指定ã™ã‚‹ã€‚
Information 表示ã®è¡Œæ•° Information 表示ã®è¡Œæ•°ã‚’指定ã™ã‚‹ã€‚
データプレビューã®è¡Œæ•° データ・ダイアログボックスã«è¡¨ç¤ºã•れるデータプレビューã®è¡Œæ•°ã‚’指定ã™ã‚‹ã€‚
データプレビューã®ãƒ•ォント データ・ダイアログボックスã«è¡¨ç¤ºã•れるデータプレビューã®ãƒ•ォントを指定ã™ã‚‹ã€‚
coordinate 表示ã®ãƒ•ォント coordinate 表示ã«ä½¿ã‚れるフォントを指定ã™ã‚‹ã€‚
information 表示ã®ãƒ•ォント information 表示ã«ä½¿ã‚れるフォントを指定ã™ã‚‹ã€‚
「カレントディレクトリを移動ã€ã‚’ãƒã‚§ãƒƒã‚¯ ãƒ•ã‚¡ã‚¤ãƒ«ã‚’é¸æŠžã™ã‚‹ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’é–‹ã„ãŸæ™‚ã€ã€Œã‚«ãƒ¬ãƒ³ãƒˆãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã‚’移動ã€ãŒåˆæœŸçŠ¶æ…‹ã§ãƒã‚§ãƒƒã‚¯ã•れã¦ã„るよã†ã«ã™ã‚‹ã€‚
ä¸é€æ˜Žåº¦ã‚’使ㆠグラフやレジェンドã®è‰²æŒ‡å®šã§é€æ˜Žåº¦ã‚’使用ã™ã‚‹ã‹ã©ã†ã‹ã‚’設定ã™ã‚‹ã€‚ ãŸã ã—ã€PostScript ãªã©ä¸é€æ˜Žåº¦ã«å¯¾å¿œã—ã¦ã„ãªã„フォーマットã«ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆã™ã‚‹æ™‚ã¯ä¸é€æ˜Žåº¦è¨­å®šã‚’使ã£ãŸéƒ¨åˆ†ãŒãƒ“ットマップã§å‡ºåŠ›ã•れるã“ã¨ãŒã‚る。
エクスãƒãƒ¼ãƒˆæ™‚ã«ãƒ‡ãƒ¼ã‚¿é¸æŠžãƒ€ã‚¤ã‚¢ãƒ­ã‚°ã‚’表示 ç”»åƒã«ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆã™ã‚‹éš›ã«ãƒ•ã‚¡ã‚¤ãƒ«é¸æŠžãƒ€ã‚¤ã‚¢ãƒ­ã‚°ã‚’è¡¨ç¤ºã™ã‚‹ã‹ã©ã†ã‹ã‚’指定ã™ã‚‹ã€‚
カスタムパレットを使ã†ã€ã‚«ã‚¹ã‚¿ãƒ ãƒ‘レットã®ç·¨é›† è‰²é¸æŠžãƒ€ã‚¤ã‚¢ãƒ­ã‚°ã§ã€ç‹¬è‡ªã®è‰²ã‚’é¸æŠžã§ãるよã†ã«ã—ã¾ã™ã€‚
æ•°å¼å¤‰æ›å…¥åŠ›ã®è¡¨ç¤ºã‚¹ã‚¿ã‚¤ãƒ« è¤‡æ•°è¡Œå…¥åŠ›ã®æ•°å¼å¤‰æ›ã§ã¤ã‹ã†è¡¨ç¤ºã‚¹ã‚¿ã‚¤ãƒ«ã‚’é¸æŠžã™ã‚‹ã€‚



ngraph-gtk-6.08.00/doc/html/ja/script.html.in0000644000175000017500000001714013246234367015567 00000000000000 Script  

Ngraphスクリプト




概è¦


Ngraph ã¯ã‚¹ã‚¯ãƒªãƒ—ト言語(Ngraph スクリプト)ã®ã‚¤ãƒ³ã‚¿ãƒ¼ãƒ—リタを備ãˆã¦ã„ã¾ã™ã€‚ グラフã®è¨­å®š(実際ã«ã¯å„オブジェクトOBJECTã®ãƒ•ィールド値)ã‚‚Ngraph スクリプト形å¼ã§ä¿å­˜ã•れã¾ã™ã€‚




ã‚¹ã‚¯ãƒªãƒ—ãƒˆã®æ–‡æ³•


Ngraph ã‚¹ã‚¯ãƒªãƒ—ãƒˆã®æ–‡æ³•ã¯ï¼Œ UNIX ã® sh (シェル) ã‹ã‚‰ã‚¸ãƒ§ãƒ–制御機能をå–り去り, オブジェクトæ“作命令を追加ã—ãŸã‚‚ã®ã«ãªã£ã¦ã„ã¾ã™ã€‚

shã¨åŒç­‰ã®æ–‡æ³•・コマンドã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™(sh ã®æ–‡æ³•ã®è©³ç´°ã«ã¤ã„ã¦ã¯ UNIX ã®ãƒžãƒ‹ãƒ¥ã‚¢ãƒ«ã‚’å‚ç…§ã—ã¦ãã ã•ã„)。

コマンド

name1=val1 name2=val2 ... command arg1 arg2 arg3 ...

コメント

# comment

制御構造

(for, case, if, while, until æ–‡)

for name [in word] do list done
case word in [pattern [|pattern] ...list;;] ... esac
if list then list [elif list then list]...[else list] fi
while list do list done
until list do list done

関数定義

name() { list; }

({}ã¯å¸¸ã«å¿…è¦)

ファイルåç½®æ›

*?[]

コマンド置æ›

`command`

変数定義

name=value [ name=value ] ...

変数置æ›

$# $? $num $* $@
${name}
${name:-word}
${name:=word}
${name:?word}
${name:+word}
${name#word}
${name##word}
${name%word}
${name%%word}

リダイレクト・パイプ

< file
<<[-]word
> file
>> file
command | command

特殊コマンド

:
. file
break [n]
continue [n]
cd
echo [-q]
eval [arg]
exit [n]
export [name]
pwd
return [n]
set
shift [n]
unset
test
[
sleep
true
false
read [val]
seq [last | first last | first incr last]
basename name [suffix]
dirname name
which [-q]



独自ã«è¿½åŠ ã—ãŸæ–‡æ³•・コマンドã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚


オブジェクト定義

(objectã®instance_listã®fieldã«valueを設定)

object:instance_list:field=value

オブジェクト置æ›

(objectã®instance_listã®fieldã®å€¤)

${object:instance_list:field=argument}

オブジェクトæ“作コマンド

new object [field=value, ...]
del object:instance_list
exist [-q] object:instance_list
get object:instance_list [-write -field -id -quote] field=argument ...
put object:instance_list field=value ...
exe object:instance_list field=argument ...
cpy object:source,destination[,destination,...] field ...
dup object:instance_list
move object:instance1,instance2
movetop object:instance
movelast object:instance
exch object:instance1,instance2
object [object1 object2 ... [-name -version -parent -id -field -size -current -last -instnace -instances] [field ...]]
derive [-instance] object

評価コマンド

(æ•°å¼expを評価)

dexpr exp
iexpr exp




スタートアップスクリプト


Ngraph ã¯å®Ÿè¡Œæ™‚ã«
  1. ~/.Ngraph
  2. CONFDIRDEF
ã‚’ã“ã®é †ç•ªã§æ¤œç´¢ã—, ã¯ã˜ã‚ã«è¦‹ã¤ã‹ã£ãŸã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—スクリプトファイル (Ngraph.nsc) を自動的ã«èª­ã¿è¾¼ã¿ã¾ã™ã€‚

コマンドラインオプション

-i script_name

ã§ã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—ã‚¹ã‚¯ãƒªãƒ—ãƒˆã‚’æ˜Žç¤ºçš„ã«æŒ‡å®šã™ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚
スタートアップスクリプトファイル㯠Ngraph 独自ã®ãƒžã‚¯ãƒ­è¨€èªž (Ngraph スク リプト) ã§è¨˜è¿°ã•れã¦ãŠã‚Š, ユーザãŒã‚«ã‚¹ã‚¿ãƒžã‚¤ã‚ºã™ã‚‹ã“ã¨ã‚‚ã§ãã¾ã™ã€‚

  • Ngraph ã®ã‚³ãƒžãƒ³ãƒ‰ãƒ©ã‚¤ãƒ³ã‚ªãƒ—ションã¯(上記 -i オプションを除ã„ã¦)å…¨ã¦ã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—ã‚¹ã‚¯ãƒªãƒ—ãƒˆãƒ•ã‚¡ã‚¤ãƒ«ã«æ¸¡ã•れã¾ã™ã€‚
  • é…布状態ã§ã¯, スタートアップスクリプトファイルã¯
    1. èµ·å‹•ã™ã‚‹ãƒ¦ãƒ¼ã‚¶ã‚¤ãƒ³ã‚¿ãƒ¼ãƒ•ã‚§ãƒ¼ã‚¹ã®æŒ‡å®š(system::login_shell)
    2. アドインスクリプト設定メニューã®ç™»éŒ²
    3. Ngraph.ngp ã®èª­è¾¼ (Ngraph.ngp ã¯[設定]-[åˆæœŸçŠ¶æ…‹ã¨ã—ã¦ä¿å­˜(グラフ)]ã§ä½œæˆã§ãã¾ã™)
    4. コマンドラインオプションã®è§£æž
    を行ã„ã¾ã™ã€‚



コマンドラインオプション


Ngraph ã‚’èµ·å‹•ã™ã‚‹æ™‚ã®ã‚³ãƒžãƒ³ãƒ‰ãƒ©ã‚¤ãƒ³ã‚ªãƒ—ションã®å½¢å¼ã¯

ngraph [-i script_name] [option1 option2 ...]

ã§ã€-i オプションã§ã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—スクリプトを指定ã—ã¾ã™ã€‚ 残りã®ã‚ªãƒ—ションã¯å…¨ã¦ã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—ã‚¹ã‚¯ãƒªãƒ—ãƒˆã«æ¸¡ã•れã€ãã®ä¸­ã§è§£æžã•れã¾ã™ã€‚ スタートアップスクリプトã¯ãƒ¦ãƒ¼ã‚¶ãŒã‚«ã‚¹ã‚¿ãƒžã‚¤ã‚ºã™ã‚‹äº‹ãŒã§ãã‚‹ã®ã§ã€ç‹¬è‡ªã®ã‚³ãƒžãƒ³ãƒ‰ãƒ©ã‚¤ãƒ³ã‚ªãƒ—ションを作æˆã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

é…布状態ã®ã‚¹ã‚¿ãƒ¼ãƒˆã‚¢ãƒƒãƒ—スクリプト(Ngraph.nsc)ã§æœ‰åйãªã‚³ãƒžãƒ³ãƒ‰ãƒ©ã‚¤ãƒ³ã‚ªãƒ—ションã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚
-x num
x 軸ã®ãƒ‡ãƒ¼ã‚¿ã‚«ãƒ©ãƒ ã‚’ num ã«ã—ã¾ã™ã€‚
-y num
y 軸ã®ãƒ‡ãƒ¼ã‚¿ã‚«ãƒ©ãƒ ã‚’ num ã«ã—ã¾ã™ã€‚
-X -U
データ㮠x 軸をãれãžã‚Œ X, U 軸ã«ã—ã¾ã™ã€‚
-Y -R
データ㮠y 軸をãれãžã‚Œ Y, R 軸ã«ã—ã¾ã™ã€‚
-d type
プロットタイプを type ã«ã—ã¾ã™ã€‚
-m num
マークを num ã«ã—ã¾ã™ã€‚
-o num
マークã®ã‚µã‚¤ã‚º num ã«ã—ã¾ã™ã€‚
-l sylte
線種を style ã«ã—ã¾ã™(-l "100 100" ã®æ§˜ã«æŒ‡å®š)。
-w num
ç·šå¹…ã‚’ num ã«ã—ã¾ã™ã€‚
-cr R -cg G -cb B
プロット色を R G B ã«ã—ã¾ã™ã€‚
-CR R -CG G -CB B
第二プロット色を R G B ã«ã—ã¾ã™ã€‚
-s num
先頭スキップ行を num ã«ã—ã¾ã™ã€‚
-r num
読込ステップ行数を num ã«ã—ã¾ã™ã€‚
-f num
最終行数を num ã«ã—ã¾ã™ã€‚
-vx num
x éš£æŽ¥å¹³å‡æ•°ã‚’ num ã«ã—ã¾ã™ã€‚
-vy num
y éš£æŽ¥å¹³å‡æ•°ã‚’ num ã«ã—ã¾ã™ã€‚
-mx math
x å¤‰æ›æ•°å¼ã‚’ math ã«ã—ã¾ã™ã€‚
-my math
y å¤‰æ›æ•°å¼ã‚’ math ã«ã—ã¾ã™ã€‚
-ex type
x 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«æ–¹æ³•ã‚’ type (linear, log, inverse) ã«ã—ã¾ã™ã€‚
-ey type
y 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«æ–¹æ³•ã‚’ type (linear, log, inverse) ã«ã—ã¾ã™ã€‚
-minx min -maxx max -incx inc
x 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’ min, max, inc ã«ã—ã¾ã™ã€‚
-miny min -maxy max -incy inc
y 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’ min, max, inc ã«ã—ã¾ã™ã€‚
-g
データファイルã‹ã‚‰è¨­å®šã‚’読ã¿è¾¼ã¿ã¾ã™ã€‚
-png file -pdf file -ps file -eps file -svg file -gra file
ngp ファイルをãれãžã‚Œã®ç”»åƒãƒ•ァイルã«å¤‰æ›ã—ã¾ã™ã€‚
-p ngp_file
ngp_file ã‚’å°åˆ·ã—ã¾ã™ã€‚
-P
ngp ファイルを外部ドライãƒã‚’利用ã—ã¦å°åˆ·ã—ã¾ã™ã€‚



ngraph-gtk-6.08.00/doc/html/ja/addin.html0000644000175000017500000002664613246234367014750 00000000000000 Add-in  

アドイン




概è¦

Ngraph ã®[アドイン]メニューã§ç™»éŒ²ã•れã¦ã„るアドインをé¸ã¶ã¨ Ngraph ã¯ãれ を「Ngraphマクロスクリプトã€ã¨ã—ã¦å®Ÿè¡Œã—ã¾ã™ã€‚アドインプログラムã®è¿½åŠ ã¯ [Preference]-[Addin script]ã§è¡Œã„ã¾ã™ã€‚以下ã®ã‚¢ãƒ‰ã‚¤ãƒ³ãƒ—ログラムã¯é…布パッ ケージã«å«ã¾ã‚Œã¦ãŠã‚Šã€ç°¡å˜ã«è¿½åŠ ã§ãるよã†ã«ãªã£ã¦ã„ã¾ã™ã€‚

legend.nsc

凡例を自動生æˆã™ã‚‹ç‚ºã®ã‚¢ãƒ‰ã‚¤ãƒ³ã€‚「Mix:ã€ã‚’ãƒã‚§ãƒƒã‚¯ã™ã‚‹ã¨ãƒ•ァイル åã€Xカラムã€YカラムãŒåŒã˜ãƒ‡ãƒ¼ã‚¿ã‚’ã¾ã¨ã‚ã¦ä¸€ã¤ã®å‡¡ä¾‹ã¨ã—ã¦æ‰±ã†ã‚ˆã† ã«ãªã‚Šã¾ã™ã€‚リストボックスã‹ã‚‰ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルåã‚’é¸ã³ã€ã€ŒCaption:〠ã«å‡¡ä¾‹ãƒ†ã‚­ã‚¹ãƒˆã‚’入力ã—ã¦ãã ã•ã„。デフォルトã§ã¯ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルå㌠使ã‚れã¾ã™ã€‚

fitrslt.nsc

フィッティングã®çµæžœã®å‡¡ä¾‹ã‚’作æˆã™ã‚‹ç‚ºã®ã‚¢ãƒ‰ã‚¤ãƒ³ã€‚「Expandã€ã‚’ ãƒã‚§ãƒƒã‚¯ã—ãŸå ´åˆã€ç¾åœ¨ã®ãƒ•ã‚£ãƒƒãƒˆçµæžœã®æ•°å€¤ã‚’Legend-Text ã¨ã—ã¦ç”Ÿæˆ ã—ã¾ã™ã®ã§ã€ãƒ•ã‚£ãƒƒãƒˆçµæžœãŒå¤‰ã‚ã£ã¦ã‚‚ Legend-Textã¯å¤‰æ›´ã•れã¾ã›ã‚“。 éžãƒã‚§ãƒƒã‚¯ã®å ´åˆã«ã¯Legend-Textã®ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆç½®æ›æ©Ÿèƒ½ã‚’使ã„ã¾ã™ã®ã§ã€ ãƒ•ã‚£ãƒƒãƒˆçµæžœãŒå¤‰ã‚れã°ã€Legend-Textã®å†…容も自動的ã«å¤‰åŒ–ã—ã¾ã™ã€‚

append.nsc

ã™ã§ã«èª­ã¿è¾¼ã‚“ã§ã‚るグラフをクリアã›ãšã«NGPファイルを読ã¿è¾¼ã‚€ç‚º ã®ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—ト。

math.nsc

一行電å“ã®ç‚ºã®ã‚¢ãƒ‰ã‚¤ãƒ³ã€‚æ•°å¼ã‚’入力ã™ã‚‹ã¨ç­”ãˆã‚’表示ã—ã¾ã™ã€‚ Ngraphã®æ•°å¼å¤‰æ›æ©Ÿèƒ½ã®é–¢æ•°ãŒä½¿ãˆã¾ã™ã€‚

text-in.nsc

ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã®æŒ‡å®šã—ãŸã‚«ãƒ©ãƒ ã‚’ legend-text ã¨ã—ã¦ãƒ—ロットデー タ点ã®éš£ã«æŒ¿å…¥ã™ã‚‹ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—ト。データを扱ã†ã‚¹ã‚¯ãƒªãƒ—トã®ä¾‹ã« ã‚‚ãªã£ã¦ã„ã¾ã™ã€‚

cal.nsc

インフォメーションウィンドウã«ã‚«ãƒ¬ãƒ³ãƒ€ãƒ¼ã‚’表示ã™ã‚‹ã‚¢ãƒ‰ã‚¤ãƒ³ã§ã™ã€‚ /usr/bin/cal を利用ã—ã¦ã„ã¾ã™ã€‚

ps2gra.nsc

PostScript ã‚’ GRA ã«å¤‰æ›ã—ã¦ã‚¤ãƒ³ãƒãƒ¼ãƒˆã™ã‚‹ãƒžã‚¯ãƒ­ã§ã™ã€‚ビットマッ プを使用ã—ãŸã‚‚ã®ãªã©ã€æ­£å¸¸ã«å¤‰æ›ã§ããªã„å ´åˆã‚‚ã‚りã¾ã™ã€‚文字ã¯ç›´ç·šã€ 曲線ã«å±•é–‹ã•れ文字ã¨ã—ã¦ã®æƒ…å ±ã¯å¤±ã‚れã¦ã„ã¾ã™ã€‚実行ã«ã¯ ruby åŠã³ pstoedit ãŒå¿…è¦ã§ã™ã€‚

tex_equation.nsc

LaTeX ã®æ•°å¼ã‚’ GRA ファイルã¨ã—ã¦ã‚¤ãƒ³ãƒãƒ¼ãƒˆã™ã‚‹ã‚¢ãƒ‰ã‚¤ãƒ³ã§ã™ã€‚レ ジェンドテキスト㫠LaTeX ã®æ•°å¼ã‚’入力ã—ã¦ã€ãã®ãƒ†ã‚­ã‚¹ãƒˆã‚’é¸æŠžçŠ¶æ…‹ã« ã—ã¦ã‹ã‚‰å®Ÿè¡Œã™ã‚‹ã¨ GRA ファイルãŒç”Ÿæˆã•れã€ãƒžãƒ¼ã‚¸ãƒ•ァイルã¨ã—ã¦ç™»éŒ² ã•れã¾ã™ã€‚æ•°å¼ã¯ç›´ç·šã€æ›²ç·šã§æ§‹æˆã•ã‚Œæ–‡å­—ã®æƒ…å ±ã¯å¤±ã‚れã¦ã„ã¾ã™ã€‚実 行ã«ã¯ ruby, pdflatex åŠã³ pstoedit ãŒå¿…è¦ã§ã™ã€‚

load_prm.nsc

DOS版Ngraphã®ã‚°ãƒ©ãƒ• (PRM ファイル) を読ã¿è¾¼ã‚€ã‚¢ãƒ‰ã‚¤ãƒ³ã§ã™ã€‚

spellchecker.rb

レジェンドテキストã®ã‚¹ãƒšãƒ«ãƒã‚§ãƒƒã‚¯ã‚’行ã†ãŸã‚ã®ãƒžã‚¯ãƒ­ã§ã™ã€‚ raspell ライブラリを使用ã§ãã‚‹ Ruby ãŒå¿…è¦ã§ã™ã€‚

アドインプログラムã¯ãƒ¦ãƒ¼ã‚¶ãŒä½œæˆã™ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚マクロスクリプトã«ã¯ Ngraph 内部ã®è¨­å®šãƒ‘ラメター全ã¦ã‚’å‚ç…§ã€å¤‰æ›´ã™ã‚‹æ©Ÿèƒ½ãŒã‚りã¾ã™ã®ã§ã€ã‚¢ãƒ‰ã‚¤ ンプログラム㯠Ngraph ã®çŠ¶æ…‹å¤‰æ•°ã«ã‚¢ã‚¯ã‚»ã‚¹ã—ã¦ï¼Œç¾åœ¨ã® Ngraph ã®çŠ¶æ…‹ã‚’å– å¾—ã—ãŸã‚Šï¼Œå¤‰æ›´ã—ãŸã‚Šã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚マクロスクリプトã ã‘ã§ã‚‚ã‹ãªã‚Šã® 事ãŒã§ãã‚‹ã®ã§ã™ãŒã€ãƒ¦ãƒ¼ã‚¶ã‚¤ãƒ³ã‚¿ãƒ¼ãƒ•ェースãªã©ã®ç‚¹ã‹ã‚‰ã€ç‹¬ç«‹ã—ãŸå€‹ã€…ã®ãƒ— ログラムを起動ã—ãŸæ–¹ãŒåŠ¹çŽ‡ãŒè‰¯ã„å ´åˆãŒã‚りã¾ã™ã€‚マクロスクリプトã«ã¯å¤–部 プログラムを起動ã™ã‚‹æ©Ÿèƒ½ãŒã‚りã¾ã™ã®ã§ã€ã“れもå¯èƒ½ã§ã™ãŒã€ãã®å ´åˆã«ã¯

  • ã©ã†ã®ã‚ˆã†ã«å¤–部プログラム㫠Ngraph ã®çŠ¶æ…‹ã‚’çŸ¥ã‚‰ã›ã‚‹ã‹ï¼Ÿ
  • 外部プログラムã‹ã‚‰ã€ã©ã®æ§˜ã« Ngraph ã®çŠ¶æ…‹ã‚’å¤‰æ›´ã•ã›ã‚‹ã‹ï¼Ÿ
ãŒå•題ã¨ãªã‚Šã¾ã™ã€‚ãã®ç°¡å˜ãªä¸€ã¤ã®æ–¹æ³•ã®ä¾‹ã¨ã—㦠legend.nsc ã‚’å–り上ã’〠以下ã§èª¬æ˜Žã—ã¾ã™ã€‚




legend.nsc ã®å‹•作

legend.nsc ãŒèµ·å‹•ã™ã‚‹å¤–部プログラム㯠legend ã§ã™ã€‚ ã¾ãš legend ãŒå¿…è¦ã¨ã™ã‚‹ç¾åœ¨ã® Ngraph ã®çŠ¶æ…‹ã‚’è¨˜è¿°ã—ãŸä¸­é–“ファイルを 作æˆã—ã¾ã™ã€‚

DATALIST=${system:0:temp_file}
object data -instance > "$DATALIST"
get data:0-! -id -field file x y type >> "$DATALIST"

ã“ã“ã§ã¯ã€system:0:temp_file ã§ãƒ†ãƒ³ãƒãƒ©ãƒªãƒ•ァイルåã‚’å–å¾—ã—ã€objectコマンド ã§ data (データファイル)ã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ã®æ•°ã‚’ã€get コマンドã§å„種設定パラメ ターをå–å¾—ã—ã€ãƒ†ãƒ³ãƒãƒ©ãƒªãƒ•ã‚¡ã‚¤ãƒ«ã«æ›¸ã込んã§ã„ã¾ã™ã€‚ã“ã®ä¸­é–“ファイルã®ãƒ•ã‚© ーマットã¯èµ·å‹•ã™ã‚‹å¤–部プログラム(今ã®å ´åˆã«ã¯ legend)固有ã®ãƒ•ォーマッ トã«ãªã‚Šã¾ã™ã€‚ã“ã®ãƒ•ァイルã®ä¸­èº«ã¯ç¾åœ¨ã® Ngraph ã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®è¨­å®šçŠ¶æ³ ã‚’ãƒªã‚¹ãƒˆã—ãŸ

1
demo1.dat
1
2
mark

ã®æ§˜ãªã‚‚ã®ã«ãªã‚Šã¾ã™ã€‚次ã«

SCRIPT=${system:0:temp_file}

ã§ legend ã®å‡ºåŠ›ç”¨ã«åˆ¥ã®ãƒ†ãƒ³ãƒãƒ©ãƒªãƒ•ァイルåã‚’å–å¾—ã—ã€å¤‰æ•°SCRIPT ã«æ ¼ç´ã—ã¦ã„ã¾ã™ã€‚後ã«ã“ã®ãƒ•ァイル㌠Ngraph マクロスクリプトã¨ã—ã¦å®Ÿè¡Œ ã•れã¾ã™ã€‚従ã£ã¦ã€ã“ã®ãƒ•ァイルã®ä¸­èº«ã¯ãƒžã‚¯ãƒ­ã‚¹ã‚¯ãƒªãƒ—ãƒˆã®æ–‡æ³•ã«å‰‡ã£ã¦ã„ ãªã‘れã°ãªã‚Šã¾ã›ã‚“。

legend "$DATALIST" "$SCRIPT"

ã“ã“ã§å¤–部プログラム legend ã‚’èµ·å‹•ã—ã¦ã„ã¾ã™ã€‚legend 㯠コマン ドラインã®1ç•ªç›®ã«æŒ‡å®šã•れãŸãƒ•ァイルã‹ã‚‰ Ngraph ã®çŠ¶æ…‹ã‚’å–å¾—ã—ã€2番目 ã«æŒ‡å®šã•れãŸãƒ•ァイルã«å¤‰æ›´ã™ã¹ã状態をマクロスクリプトã¨ã—ã¦å‡ºåŠ›ã™ã‚‹ よã†ã«è¨­è¨ˆã•れã¦ã„ã¾ã™ã€‚例ãˆã° "STRING" ã¨è¨€ã† legend-text ã‚’(0,0)ã«ç”Ÿ æˆã™ã‚‹ã«ã¯ã€$SCRIPT ã®ãƒ•ァイルã®å†…容ã¯

new text
text::x=0
text::y=0
text::text="STRING"

ã¨ãªã‚Šã¾ã™ã€‚ã¾ãŸã‚°ãƒ©ãƒ•ã«å¤‰æ›´ã‚’加ãˆãŸã¨ãã¯ã€"menu::modified=TRUE" を実行 ã—ã¦ã€ã‚°ãƒ©ãƒ•ã‚’é–‰ã˜ã‚‹ã¨ãã«ä¿å­˜ã®ç¢ºèªãŒè¡Œã‚れるよã†ã«ã—ã¦ãŠãã¾ã™ã€‚ã“ã®ã‚¹ クリプトを実行ã™ã‚‹ã®ã¯

if [ -f "$SCRIPT" ];
then
new shell
shell::shell "$SCRIPT"
del shell
fi

ã§ã™ã€‚ã“ã“ã§ã€å¤‰æ•° SCRIPT ã«æ ¼ç´ã—ãŸãƒ•ァイルãŒå­˜åœ¨ã—ã„ã¦ã„ã‚‹å ´åˆ(ifæ–‡) ã«ã€shell オプジェクトã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ã‚’生æˆ(new)ã—ã€ãã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ã« ãã®ãƒ•ァイルを解釈実行(shell)ã•ã›ã€æœ€å¾Œã«ä¸è¦ã«ãªã£ãŸã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ã‚’削 除(del)ã—ã¦ã„ã¾ã™ã€‚

system:0:unlink_temp_file "$DATALIST"
system:0:unlink_temp_file "$SCRIPT"

最後ã«ä¸å¿…è¦ã«ãªã£ãŸä¸­é–“ファイル($DATALIST)ã¨ã‚¹ã‚¯ãƒªãƒ—トファイル($SCRIPT) を削除ã—ã¾ã™ã€‚




アドインスクリプトã®å½¢å¼

外部プログラムを起動ã™ã‚‹ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—トã¯ã€

... 外部プログラムã«å¿…è¦ãªä¸­é–“ファイルを生æˆã™ã‚‹ ...
SCRIPT=${system:0:temp_file}
å¤–éƒ¨ãƒ—ãƒ­ã‚°ãƒ©ãƒ å  ä¸­é–“ãƒ•ã‚¡ã‚¤ãƒ«å  "$SCRIPT"
if [ -f "$SCRIPT" ];
then
new shell
shell::shell "$SCRIPT"
del shell
fi
system:0:unlink_temp_file "$SCRIPT"

ã¨ãªã‚Šã¾ã™ã€‚

ã‚‚ã¡ã‚ã‚“ã€Ngraphã®ç¾åœ¨ã®çŠ¶æ…‹ã‚’å–å¾—ã™ã‚‹å¿…è¦ãŒãªã‘れã°ã€

SCRIPT=${system:0:temp_file}
å¤–éƒ¨ãƒ—ãƒ­ã‚°ãƒ©ãƒ å  "$SCRIPT"
if [ -f "$SCRIPT" ];
then
new shell
shell::shell "$SCRIPT"
del shell
fi
system:0:unlink_temp_file "$SCRIPT"

ã ã‘ã§å分ã§ã™ã€‚




データを扱ã†ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—ト

アドインスクリプトã®ä¸­ã‹ã‚‰ãƒ‡ãƒ¼ã‚¿ã‚’直接扱ã†äº‹ã‚‚ã§ãã¾ã™ã€‚ãã®ä¾‹ã¨ã—㦠text-in.nsc を説明ã—ã¾ã™ã€‚次ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ãŒæœ‰ã‚‹ã¨ã—ã¾ã™ã€‚

=====test.dat=========
0 0 sampleA
1 1 sampleB
2 2 sampleC
======================

第一カラムをx座標ã«ã€ç¬¬äºŒã‚«ãƒ©ãƒ ã‚’y座標ã«ã—ãŸã‚°ãƒ©ãƒ•を作æˆã—ãŸã¨ã—ã¾ã™ã€‚ Ngraphã«ã¯ã™ã§ã«test.datãŒé–‹ã„ã¦ã‚りã€ãƒ—ロットタイプ "mark" ã§ãƒ—ロット ã•れã¦ã„ã‚‹ã¨ã—ã¾ã™ã€‚ã“ã“ã§ text-in.nsc を実行ã—〠"Input legend-text column" ã« 3 を入力ã™ã‚‹ã¨ã€ãƒ‡ãƒ¼ã‚¿ç‚¹ã®éš£ã«ç¬¬ä¸‰ã‚«ãƒ©ãƒ  ã®ãƒ†ã‚­ã‚¹ãƒˆã‚’legend-textã¨ã—ã¦æŒ¿å…¥ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

ã“ã®ã‚¹ã‚¯ãƒªãƒ—トã§ã¯ã€ã¾ãš dialog オブジェクトを使ã£ã¦ã€legend-text ã®ã‚«ãƒ© ム数を入力ã•ã›ã€å¤‰æ•°(COLUMN)ã«ä»£å…¥ã—ã¾ã™ã€‚

new dialog
COLUMN=${dialog::input:'Input legend-text column'}
del dialog

次㫠data オブジェクト㮠data::opendatac を使ã£ã¦ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを開ã〠data::getdata ã§ãƒ‡ãƒ¼ã‚¿ãŒç„¡ããªã‚‹ã¾ã§ãƒ‡ãƒ¼ã‚¿ã‚’å–å¾—ã—ã€æœ€å¾Œã« data::closedata ã§ãƒ‡ãƒ¼ã‚¿ã‚’é–‰ã˜ã¾ã™ã€‚

data:0:opendatac
while data:0:getdata
do
... テキストã®è¨­å®š ...
done
data:0:closedata

while ループã®ä¸­ã§ã¯ã€ã¾ãš text オブジェクトを生æˆã—ã¾ã™ã€‚

new text

ã¾ãŸ data::getdata を実行ã—ãŸæ™‚ã€ãƒ‡ãƒ¼ã‚¿ã®æ•°å€¤ã¯ data::data_x, data::data_y ã«å…¥ã‚Šã€0.01mmå˜ä½ã§ã®ç”¨ç´™ä¸Šã§ã®ä½ç½®ã¯ data::coord_x, data::coord_y ã«å…¥ りã€è¡Œç•ªå·ã¯ data::line ã«å…¥ã‚Šã¾ã™ã€‚ã“れらを用ã„ã¦ç”Ÿæˆã—ãŸtextã®åº§æ¨™å€¤ã‚’設 定ã—ã¦ã„ã¾ã™ã€‚

text::x=${data:0:coord_x}
text::y=${data:0:coord_y}

ã¾ãŸ data::column を用ã„ã¦ã‚«ãƒ©ãƒ ã®ãƒˆãƒ¼ã‚¯ãƒ³ã‚’å–り出ã—ã¦ã„ã¾ã™ã€‚data::column ã®ç¬¬ä¸€å¼•æ•°ã¯ãƒ•ァイルã®è¡Œæ•°ã§ã€data::line を使ã„ã€ç¬¬äºŒå¼•æ•°ã¯å–り出ã™ã‚«ãƒ©ãƒ æ•° ã§å¤‰æ•° COLUMN ã®å€¤ã‚’用ã„ã¦ã„ã¾ã™ã€‚å–り出ã—ãŸãƒˆãƒ¼ã‚¯ãƒ³ã‚’ text::text ã«è¨­å®šã— ã¾ã™ã€‚

text::text=`get data:0 -field column:"${data:0:line} ${COLUMN}"`

ãŸã ã—ã€data::column ã¯å‘¼ã³å‡ºã•れる毎ã«ãƒ•ァイルã®å…ˆé ­ã‹ã‚‰èµ°æŸ»ã—ã¦ç›®çš„ã®æ–‡å­— 列をå–å¾—ã—ã¾ã™ã®ã§ã€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルãŒå¤§ãã„å ´åˆã«ã¯å‹•作ãŒé…ã„ã§ã™ã€‚

一般的ã«ãƒ‡ãƒ¼ã‚¿ã‚’扱ã†ã‚¢ãƒ‰ã‚¤ãƒ³ã‚¹ã‚¯ãƒªãƒ—トã¯ã€

data::opendatac
while data::getdata
do
... ç›®çš„ã®æ“作
data::data_x data::data_y data::coord_x data::coord_y data::line ãŒä½¿ãˆã‚‹
done
data::closedata

ã¨ãªã‚Šã¾ã™ã€‚data::opendatac ã®ä»£ã‚り㫠data::opendata を用ã„ãŸå ´åˆã€ data::coord_x, data::coord_y ã®å€¤ã¯ä¸å®šã¨ãªã‚Šã¾ã™ãŒã€ãã®ä»£ã‚り軸ã®è¨­å®šãŒãªã• れã¦ã„ãªãã¦ã‚‚エラーã«ã¯ãªã‚Šã¾ã›ã‚“。




ngraph-gtk-6.08.00/doc/html/ja/text.html0000644000175000017500000001547513246234367014653 00000000000000 Text  

フォント/テキスト




ãƒ•ã‚©ãƒ³ãƒˆã®æ‰±ã„


[Legend]-[Text] ã§æŒ‡å®šã™ã‚‹ãƒ•ォントåã¯ã™ã¹ã¦ã‚¨ã‚¤ãƒªã‚¢ã‚¹ï¼ˆåˆ¥å)ã§ã™ã€‚ Ngraphã§ã¯ç•°ãªã‚‹ã‚ªãƒšãƒ¬ãƒ¼ãƒ†ã‚£ãƒ³ã‚°ã‚·ã‚¹ãƒ†ãƒ ã¨ã®äº’æ›æ€§ã‚’考ãˆã¦ãŠã‚Š, フォントåを直接指定ã™ã‚‹äº‹ã¯ã§ãã¾ã›ã‚“。

フォントã®é¸æŠžãƒ»å‡ºåŠ›ã¯, エイリアスåã‹ã‚‰å®Ÿéš›ã®ãƒ•ォントåã«ãƒžãƒƒãƒ”ングã—ã¦è¡Œã£ã¦ã¾ã™ã€‚マッピング情報㯠Ngraph.ini ã«è¨˜è¿°ã•れã¦ã„ã¾ã™ã€‚


インストール時ã«å®šç¾©ã•れã¦ã„るフォントマッピング

Ngraph定義åフォントå
Windows, macOSãれ以外
SerifTimes New RomanLiberation Sans
Sans-serifArialLiberation Serif
MonospaceCourier NewLiberation Mono



テキストæç”»ã®åˆ¶å¾¡æ–‡å­—


Legend textダイアログボックスã®Textã§æ–‡å­—列中ã«åˆ¶å¾¡æ–‡å­—を挿入ã—ã¦, 書å¼ã‚’一文字å˜ä½ã§å¤‰æ›´ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

基本
^ç¶šãæ–‡å­—ã¯ä¸Šä»˜ã文字ã«ãªã‚‹
_ç¶šãæ–‡å­—ã¯ä¸‹ä»˜ã文字ã«ãªã‚‹
@ä¸Šä»˜ãæ–‡å­—, ä¸‹ä»˜ãæ–‡å­—を解除ã™ã‚‹
\Bç¶šãæ–‡å­—ã¯å¤ªå­— (bold) ã«ãªã‚‹
\Iç¶šãæ–‡å­—ã¯æ–œä½“ (italic) ã«ãªã‚‹
\Nå¤ªå­—ã€æ–œä½“を解除ã™ã‚‹
\.スペースã¨åŒç­‰
\bãƒãƒƒã‚¯ã‚¹ãƒšãƒ¼ã‚¹(å¹…ã¯'h')
\n改行
\-ãƒã‚¤ãƒ•ン
\&テキストãŒ\nã®æ”¹è¡Œã«ã‚ˆã£ã¦è¤‡æ•°è¡Œã‚ã‚‹ã¨ã\&ã®ä½ç½®ã§ä½ç½®åˆã‚ã›ã‚’ã™ã‚‹
\æ¬¡ã®æ–‡å­—ãŒ%\@^_ã®æ™‚, ãれらを制御文字ã¨ã—ã¦æ‰±ã‚ãšã«å‡ºåŠ›ã™ã‚‹


フォント
%F{エイリアスå}フォントをエイリアスåã«å¤‰æ›´ã™ã‚‹
%S{æ•´æ•°}フォントã®ã‚µã‚¤ã‚ºã‚’ãƒã‚¤ãƒ³ãƒˆã§æŒ‡å®šã™ã‚‹
%P{æ•´æ•°}文字間隔をãƒã‚¤ãƒ³ãƒˆã§æŒ‡å®šã™ã‚‹
%N{æ•´æ•°}\nã§æ”¹è¡Œã—ãŸæ™‚ã®è¡Œé–“ã‚’ãƒã‚¤ãƒ³ãƒˆã§æŒ‡å®šã™ã‚‹
%X{æ•´æ•°}カレントãƒã‚¤ãƒ³ãƒˆã‚’峿–¹å‘ã«ç§»å‹•ã•ã›ã‚‹é‡ã‚’ãƒã‚¤ãƒ³ãƒˆã§æŒ‡å®šã™ã‚‹
%Y{æ•´æ•°}カレントãƒã‚¤ãƒ³ãƒˆã‚’下方å‘ã«ç§»å‹•ã•ã›ã‚‹é‡ã‚’ãƒã‚¤ãƒ³ãƒˆã§æŒ‡å®šã™ã‚‹
%C{æ•´æ•°}文字ã®è‰²ã‚’16進形å¼ã§æŒ‡å®šã™ã‚‹ã€‚
%A{æ•´æ•°}文字ã®ä¸é€æ˜Žåº¦ (0-255) を指定ã™ã‚‹ã€‚


æ•°å¼
%[å¼]å¼ã®å€¤


æ•´å½¢
%pf{format value}value ã‚’ format ã§æ•´å½¢ã—ã¦å‡ºåŠ›ã™ã‚‹
  • format ã«ã¤ã„ã¦è©³ã—ã㯠man 3 printf ã‚’å‚ç…§ã—ã¦ãã ã•ã„。
  • 精度指定㫠'*' ã‚„ `*m$' ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。
  • é•·ã•修飾å­ã« hh, h, L, q, j, z, Z, t ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。
  • å¤‰æ›æŒ‡å®šå­ã« F, a, A, m, n, p, C, S ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。
  • フラグ文字㫠'^' を指定ã§ãã¾ã™ã€‚e, E, g G å¤‰æ›æ™‚ã«æŒ‡æ•°è¡¨è¨˜ã‚’ "×10-3" ã®ã‚ˆã†ã«è¡¨ç¤ºã—ã¾ã™ (フィールド幅指定ã«ã¯æœªå¯¾å¿œ) 。

例:
%pf{%e 1} 㯠1.000000e+00
%pf{%^.3e 1E-3} 㯠1.000×10-3
%pf{%2.2f %[exp(1)]} 㯠2.72


オブジェクト
%{object:id:field parameter}オブジェクト(object)ã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹(id)ã®ãƒ•ィールド(field)ã®å€¤


ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆã®æŒ‡å®šä¾‹
%{system::date 0}Fri Feb 2 1990 åž‹ã®æ—¥ä»˜
%{system::date 1}2-2-1990 åž‹ã®æ—¥ä»˜
%{system::date 2}Feb 2 1990 åž‹ã®æ—¥ä»˜
%{system::time 0}00:00:00 åž‹ã®æ™‚刻
%{system::time 1}12:00:00 am åž‹ã®æ™‚刻
%{system::time 2}00:00 åž‹ã®æ™‚刻
%{system::time 3}12:00 am åž‹ã®æ™‚刻
%{menu::ngp}ngpファイルå
%{menu::fullpath_ngp}フルパスã®NGPファイルå
%{data:X:file}ファイルå (X ã¯ãƒ•ァイル番å·)
%{data:X:basename}フォルダåを除ã„ãŸãƒ•ァイルå (X ã¯ãƒ•ァイル番å·)
%{data:X:date 0}ãƒ•ã‚¡ã‚¤ãƒ«ã®æ—¥ä»˜
%{data:X:time 0}ãƒ•ã‚¡ã‚¤ãƒ«ã®æ™‚刻
%{data:X:column:l c}ファイル㮠l 行㮠c カラムã®å†…容
%{data:X:dnum}ファイルXã®ãƒ‡ãƒ¼ã‚¿æ•°
%{data:X:dx n}ファイルXã®n行目ã®å€¤(x)
%{data:X:dminx}ファイルXã®æœ€å°å€¤(x)
%{data:X:dmaxx}ファイルXã®æœ€å¤§å€¤(x)
%{data:X:davx}ファイルXã®å¹³å‡å€¤(x)
%{data:X:dsigx}ファイルXã®æ¨™æº–åå·®(x)
%{data:X:dy n}ファイルXã®n行目ã®å€¤(y)
%{data:X:dminy}ファイルXã®æœ€å°å€¤(y)
%{data:X:dmaxy}ファイルXã®æœ€å¤§å€¤(y)
%{data:X:davy}ファイルXã®å¹³å‡å€¤(y)
%{data:X:dsigy}ファイルXã®æ¨™æº–åå·®(y)
%{data:X:fit_prm:n} ファイルXã®ãƒ—ロットタイプ㌠Fit ã®ã¨ãã€ãƒ•ィットã®çµæžœ f(x) ã«å¯¾ã—㦠%0n ã‚’è¿”ã™ã€‚
%{data:X:fit_calc:a} ファイルXã®ãƒ—ロットタイプ㌠Fit ã®ã¨ãã€ãƒ•ィットã®çµæžœ f(x) ã«å¯¾ã—㦠f(a) を計算ã™ã‚‹ã€‚
%{data:X:fit_newton:a b} ファイルXã®ãƒ—ロットタイプ㌠Fit ã®ã¨ãã€ãƒ•ィットã®çµæžœ f(x) ã«å¯¾ã—㦠f(x)=b ã¨ãªã‚‹ xã‚’åˆæœŸå€¤ x=a ã¨ã—ã¦ãƒ‹ãƒ¥ãƒ¼ãƒˆãƒ³æ³•ã§æ±‚ã‚る。
%{fit:0:%00}fit:0:%00



ngraph-gtk-6.08.00/doc/html/ja/math.html0000644000175000017500000011650213315651332014601 00000000000000 Math  

データã®åŠ å·¥




概è¦


æç”»ã¯éš£æŽ¥å¹³å‡, æ•°å¼å¤‰æ›ãªã©ãƒ‡ãƒ¼ã‚¿ã®åŠ å·¥ã‚’è¡Œã£ãŸå¾Œã«è¡Œã‚れã¾ã™ã€‚ グラフを作æˆã™ã‚‹éš›ãã®å‡¦ç†æ‰‹é †ã‚’æ„è­˜ã™ã‚‹ã“ã¨ãŒé‡è¦ãªå ´åˆãŒã‚りã¾ã™ã€‚ 以下ã«ãƒ‡ãƒ¼ã‚¿ã®æµã‚Œã‚’示ã—ã¾ã™ã€‚

データ
↓
æ•°å¼å¤‰æ›
↓
マスクã•れãŸãƒ‡ãƒ¼ã‚¿ã‚’削除
↓
移動ã•れãŸãƒ‡ãƒ¼ã‚¿ã‚’移動
↓
隣接平å‡
↓
[曲線ã®è£œé–“ä¿‚æ•°, 最å°äºŒä¹—フィットã®ä¿‚数を求ã‚ã‚‹]
↓
出力(グラフæç”»)

ロググラフを作æˆã™ã‚‹å ´åˆ, 曲線ã®è£œé–“ã¯ãƒ‡ãƒ¼ã‚¿ã‚’対数変æ›ã—ãŸå¾Œã«è¡Œã‚れるã®ã§é€šå¸¸ã®ç·šå½¢ã‚°ãƒ©ãƒ•ã¨ãƒ­ã‚°ã‚°ãƒ©ãƒ•ã§ã¯çµæžœãŒç•°ãªã‚Šã¾ã™ã€‚ 最å°äºŒä¹—法ã«é–¢ã—ã¦ã¯ãƒ­ã‚°ã‚°ãƒ©ãƒ•ã§ã‚‚通常ã®ç·šå½¢ã‚°ãƒ©ãƒ•ã¨åŒã˜ä¿‚数を求ã‚ã¾ã™ã€‚



æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãるコメント

#ã‹ã‚‰è¡Œæœ«ã¾ã§ã‚’コメントã¨è¦‹ãªã—ã¾ã™ã€‚

æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãる数値リテラル


1
1.0
1.0E3

æµ®å‹•å°æ•°ç‚¹

0xffff

16進整数

0b1011

2進整数

0o377

8進整数

æ•°å­—ãŒé€£ç¶šã—ã¦ã„る部分ã¯è¦‹ã‚„ã™ãã™ã‚‹ãŸã‚ä»»æ„ã®ç®‡æ‰€ã«ç©ºç™½ã‚’入れるã“ã¨ãŒå‡ºæ¥ã¾ã™ (例 123 456.789 E8) 。




æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãる定数


PI円周率
E自然対数ã®åº•
EULERオイラーã®å®šæ•°
NAN欠æãƒ‡ãƒ¼ã‚¿ エラー表示
UNDEF欠æãƒ‡ãƒ¼ã‚¿ エラーéžè¡¨ç¤º
CONT欠æãƒ‡ãƒ¼ã‚¿ (データ線ã¯çµåˆ)
BREAK欠æãƒ‡ãƒ¼ã‚¿ (データ線ã¯åˆ†æ–­)
NUMデータã®å€‹æ•°
MINX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æœ€å°å€¤
MAXX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æœ€å¤§å€¤
MINY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æœ€å°å€¤
MAXY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æœ€å¤§å€¤
SUMX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®å’Œ
SUMY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®å’Œ
SUMXX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®äºŒä¹—å’Œ
SUMYY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®äºŒä¹—å’Œ
SUMXY(X) column, (Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®ç©å’Œ
AVX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®å¹³å‡
AVY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®å¹³å‡
STDEVPX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æ¨™æº–åå·® (SGX も利用å¯)
STDEVPY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®æ¨™æº–åå·® (SGY も利用å¯)
STDEVX(X) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®ä¸å標準åå·®
STDEVY(Y) column ã®ç”Ÿãƒ‡ãƒ¼ã‚¿ã®ä¸å標準åå·®
FIRSTdiagonal, errorbar ãªã©ä¸€è¡Œã®ãƒ‡ãƒ¼ã‚¿ã§2回ã®å¤‰æ›ãŒè¡Œã‚れる場åˆã€1回目ã®å‘¼å‡ºã—ã§çœŸ(=1)ã€2回目ã®å‘¼å‡ºã—ã§å½(=0)
MASKマスクã«è¨­å®šã•れãŸè¡Œæ•°
MOVE移動ã«è¨­å®šã•れãŸè¡Œæ•°
COLX「X カラムã€ã«æŒ‡å®šã•ã‚ŒãŸæ•°
COLY「Y カラムã€ã«æŒ‡å®šã•ã‚ŒãŸæ•°
AXISX「X 軸ã€ã«æŒ‡å®šã•れ㟠axis オブジェクト㮠ID
AXISX_MIN「X 軸ã€ã®æœ€å°å€¤
AXISX_MAX「X 軸ã€ã®æœ€å¤§å€¤
AXISX_LEN「X 軸ã€ã®é•·ã•
AXISY「Y 軸ã€ã«æŒ‡å®šã•れ㟠axis オブジェクト㮠ID
AXISY_MIN「Y 軸ã€ã®æœ€å°å€¤
AXISY_MAX「X 軸ã€ã®æœ€å¤§å€¤
AXISY_LEN「Y 軸ã€ã®é•·ã•
HSKIP「先頭スキップ行ã€ã«æŒ‡å®šã•れãŸè¡Œæ•°
RSTEP「読込ステップ行ã€ã«æŒ‡å®šã•れãŸè¡Œæ•°
FLINE「最終行ã€ã«æŒ‡å®šã•れãŸè¡Œæ•°
DATA_OBJdata オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
PATH_OBJpath オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
RECT_OBJrectangle オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
ARC_OBJarc オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
MARK_OBJmark オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
TEXT_OBJtext オブジェクトã®ã‚ªãƒ–ジェクト識別番å·
%Dデータã®ç•ªå·
%Nデータオブジェクトã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹æ•°
TRUE代表的ãªçœŸã®å€¤
FALSEå½ã®å€¤
FILL_RULE_NONEãƒãƒªã‚´ãƒ³ã‚’塗りã¤ã¶ã•ãªã„。draw_polygon() 関数ã§åˆ©ç”¨ã™ã‚‹ã€‚
FILL_RULE_EVEN_ODDãƒãƒªã‚´ãƒ³ã‚’å¶å¥‡å‰‡ã§å¡—りã¤ã¶ã™ã€‚draw_polygon() 関数ã§åˆ©ç”¨ã™ã‚‹ã€‚
FILL_RULE_WINDINGãƒãƒªã‚´ãƒ³ã‚’ワインディング則ã§å¡—りã¤ã¶ã™ã€‚draw_polygon() 関数ã§åˆ©ç”¨ã™ã‚‹ã€‚



定数定義


const x:=exp x ã¯è‹±å­—ã¾ãŸã¯ _ ã§å§‹ã¾ã‚Šè‹±æ•°å­—ã¾ãŸã¯ _ ã‹ã‚‰æ§‹æˆã•れる文字列ã€exp ã¯ä»»æ„ã®æ•°å¼ã€‚
  • 既存ã®å®šæ•°ã¯ä¸Šæ›¸ãã§ãã¾ã›ã‚“。
  • æ•°å¼ exp ã¯æ•°å¼å¤‰æ›å®Ÿè¡Œæ™‚ã§ã¯ãªãæ§‹æ–‡è§£æžæ™‚ã«è©•価ã•れã¾ã™ã€‚
  • æ•°å¼ exp 中ã§ã¯ãƒ‘ラメータã€é–¢æ•° sum(), dif() ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。



æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãるパラメータ


%0データを読ã¿è¾¼ã‚“ã é †ç•ªã«1ã‹ã‚‰ç•ªå·ã‚’ã¤ã‘ãŸã¨ãã®å€¤
%1〜%999åŒä¸€è¡Œä¸­ 1〜999 カラムã®ç”Ÿãƒ‡ãƒ¼ã‚¿
%Fxx1〜%Fxx999データ xx ã®åŒã˜è¡Œã® 1〜999 カラムã®ç”Ÿãƒ‡ãƒ¼ã‚¿



æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãる変数

変数㯠X, Y ã®å¤‰æ›å¼ã§ç‹¬ç«‹ã§ã™ã€‚


PI, E, X, Y 以外ã®ã€è‹±å­—ã§å§‹ã¾ã‚Šè‹±æ•°å­—ã¾ãŸã¯ _ ã‹ã‚‰æ§‹æˆã•れる2æ–‡å­—ä»¥ä¸‹ã®æ–‡å­—列ã€ã¾ãŸã¯ _ ã§å§‹ã¾ã‚Šè‹±æ•°å­—ã¾ãŸã¯ _ ã‹ã‚‰æ§‹æˆã•れる文字列。ユーザãŒè‡ªç”±ã«ä½¿ç”¨ã§ãã¾ã™ (代入ã•れã¦ã„ãªã„変数㯠0 ã«åˆæœŸåŒ–ã•れã¦ã„ã¾ã™) 。
X(X)column ã®ç”Ÿã®ãƒ‡ãƒ¼ã‚¿ (変数ã¸ã®ä»£å…¥ã¯å¯èƒ½ã§ã™ãŒã€ãƒ‡ãƒ¼ã‚¿èª­è¾¼æ™‚ã«ç”Ÿãƒ‡ãƒ¼ã‚¿ã§ä¸Šæ›¸ãã•れã¾ã™)
Y(Y)column ã®ç”Ÿã®ãƒ‡ãƒ¼ã‚¿ (変数ã¸ã®ä»£å…¥ã¯å¯èƒ½ã§ã™ãŒã€ãƒ‡ãƒ¼ã‚¿èª­è¾¼æ™‚ã«ç”Ÿãƒ‡ãƒ¼ã‚¿ã§ä¸Šæ›¸ãã•れã¾ã™)



é…列


COL[n] COL[0] ã¯ãƒ‘ラメータ %0 ã¨ãŠãªã˜ã€ãれ以外ã¯åŒä¸€è¡Œä¸­ n カラムã®ç”Ÿ データ (999 カラム以é™ã‚‚å‚ç…§å¯èƒ½)。
X[n] X ã¯è‹±å­—ã¾ãŸã¯ _ ã§å§‹ã¾ã‚Šè‹±æ•°å­—ã¾ãŸã¯ _ ã‹ã‚‰æ§‹æˆã•れる文字列ã€n ã¯ä»»æ„ã®æ•°å¼ã€‚
未代入ã®é…列è¦ç´ ã¯ 0 ã«åˆæœŸåŒ–ã•れã¦ã„ã¾ã™ã€‚
é…åˆ—ã®æ·»å­—ã¯æ•´æ•°ã«ä¸¸ã‚られã¾ã™ã€‚
é…åˆ—ã®æ·»å­—ã®ä¸Šé™ã¯ 65535 ã§ã™ã€‚
é…åˆ—ã®æ·»å­—ã«è² ã®æ•°å€¤ã‚’使用ã—ãŸå ´åˆã€é…åˆ—ã®æœ«å°¾ã‹ã‚‰ã®ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ã¨ã¿ãªã—ã¾ã™ã€‚



ユーザ定義関数


def func(a,b,...) {exp} 仮引数 a, b, ... ã®é–¢æ•° func を定義ã—ã¾ã™ã€‚
é…列を渡ã™ã¨ãã¯ä»®å¼•æ•°ã‚’ @a ã®æ§˜ã«æŒ‡å®šã—ã¦ãã ã•ã„。é…列ã¯å‚照渡ã—ã¨ãªã‚Šã¾ã™ã€‚
exp ã«ã¯ä»»æ„ã®æ•°å¼ã‚’指定ã§ãã¾ã™ãŒã€ä»¥ä¸‹ã®åˆ¶é™ãŒã‚りã¾ã™ã€‚
  • パラメータ (%0, %F0001 ãªã©) ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。
  • 関数 dif(), sum() ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。
  • 関数定義ã¯ãƒã‚¹ãƒˆã§ãã¾ã›ã‚“。



æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãる演算å­


-+符å·
+ - * /四則演算
\æµ®å‹•å°æ•°ç‚¹å‰°ä½™
^ベキ乗
!階乗(引数㯠169 ä»¥ä¸‹ã®æ­£ã®æ•´æ•°)
:=代入
-=自己代入
+=自己代入
*=自己代入
/=自己代入
\=自己代入
^=自己代入
==比較
!=比較
<=比較
>=比較
<比較
>比較
&&è«–ç†ç©
||è«–ç†å’Œ
exp1 && exp2 㨠AND(exp1, exp2) ã®é•ã„。

exp1 && exp2 㯠exp1 ãŒå½ã®æ™‚ exp2 を評価ã—ã¾ã›ã‚“。ã¾ãŸ exp1 ãŒçœŸã®å ´åˆã€exp2 を評価ã—ãŸå€¤ã‚’è¿”ã—ã¾ã™ã€‚

exp1 || exp2 㨠OR(exp1, exp2) ã®é•ã„。

exp1 || exp2 㯠exp1 ãŒçœŸã®æ™‚ exp2 を評価ã—ã¾ã›ã‚“。ã¾ãŸ exp1 ãŒçœŸã®å ´åˆã¯ exp1ã€exp1 ãŒå½ã®å ´åˆã¯ exp2 を評価ã—ãŸå€¤ã‚’è¿”ã—ã¾ã™ã€‚

;

; ã¯å¼ã®çµ‚端を表ã—ã¾ã™(çœç•¥å¯èƒ½)。; ã®å¾Œã«åˆ¥ã®å¼ã‚’後ã«ç¶šã‘ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

括弧 ()

括弧 () ã®æ•°ã«åˆ¶é™ã¯ã‚りã¾ã›ã‚“。




æ•°å¼å¤‰æ›ã§ä½¿ç”¨ã§ãる関数

  • 引数ã¯çœç•¥ã™ã‚‹ã“ã¨ãŒå‡ºæ¥ã¾ã™ã€‚引数ãŒçœç•¥ã•れãŸå ´åˆ 0 ãŒæ¸¡ã•れã¾ã™ã€‚
  • IF() 関数ã®ãƒã‚¹ãƒˆæ•°ã€DIF(), SUM() é–¢æ•°ã®æ•°ã®åˆ¶é™ã¯ãªããªã‚Šã¾ã—ãŸã€‚
  • 引数ã¯å·¦ã‹ã‚‰è©•価ã•れã¾ã™ã€‚

変æ›é–¢æ•°

ABS(x)絶対値
SIGN(x)正負ã®ç¬¦å· (x < 0 ã§ -1ã€x >= 0 ã§ 1)
INT(x)0ã«å‘ã‹ã£ã¦åˆ‡æ¨ã¦ãŸæ•´æ•°éƒ¨
GAUSS(x)ガウスã®è¨˜å·[ ] ([n]ã¯nã‚’è¶Šãˆãªã„æœ€å¤§ã®æ•´æ•°)
FRAC(x)å°æ•°éƒ¨
ROUND(x)å››æ¨äº”å…¥ã—ãŸæ•´æ•°éƒ¨
MIN(a,b,c,...)引数ã®ã†ã¡ã‚‚ã£ã¨ã‚‚å°ã•ãªå€¤
MAX(a,b,c,...)引数ã®ã†ã¡ã‚‚ã£ã¨ã‚‚大ããªå€¤
SUMSQ(a,b,c,...)引数ã®è‡ªä¹—å’Œ

åˆç­‰é–¢æ•°

SQR(x)二乗
SQRT(x)平方根
EXP(x)指数(x≦690)
LN(x)自然対数
LOG(x)常用対数
SIN(x)サイン
COS(x)コサイン
TAN(x)タンジェント
ASIN(x)逆サイン
ACOS(x)逆コサイン
ATAN(x)逆タンジェント
SINH(x)ãƒã‚¤ãƒ‘ボリックサイン
COSH(x)ãƒã‚¤ãƒ‘ボリックコサイン
TANH(x)ãƒã‚¤ãƒ‘ボリックタンジェント
ASINH(x)逆ãƒã‚¤ãƒ‘ボリックサイン
ACOSH(x)逆ãƒã‚¤ãƒ‘ボリックコサイン
ATANH(x)逆ãƒã‚¤ãƒ‘ボリックタンジェント
FMOD(x, y)x ã‚’ y ã§å‰²ã£ãŸæµ®å‹•å°æ•°ç‚¹å‰°ä½™
CHOOSE(n,m)the combinatorial factor n choose m: n!/(m!(n-m)!)

特殊関数

RAND(x)0≦RAND(x)<x (x>0ã®ã¨ã)ã®ä¹±æ•°
SRAND(x)RAND() 関数ã§ä½œã‚‰ã‚Œã‚‹ç–‘ä¼¼ä¹±æ•°ç³»åˆ—ã®æ–°ã—ã„種を設定ã™ã‚‹ã€‚
THETA(x)階段関数(x≧0 ã®ã¨ã 1, ãれ以外㯠0 )
DELTA(x)クロãƒãƒƒã‚«ãƒ¼ã®Î´(x=0 ã®ã¨ã 1, ãれ以外㯠0)
GAMMA(x)ガンマ関数 Γ(x)
ICGAM(m,x)ä¸å®Œå…¨ã‚¬ãƒ³ãƒžé–¢æ•° Γ(μ,x)
ERF(x)誤差関数 Erf(x)
ERFC(x)相補誤差関数 Erfc(x)
QINV(x)誤差関数 Erfc(x) ã®é€†é–¢æ•°
EI(x)ç©åˆ†æŒ‡æ•°é–¢æ•° Ei(x)
BETA(p,q)ベータ関数 B(p,q)
ICBETA(a,b,x)ä¸å®Œå…¨ãƒ™ãƒ¼ã‚¿é–¢æ•° I(a,b,x) (0 <= x <= 1)
JN(n,x)第1種n次ベッセル関数
YN(n,x)第2種n次ベッセル関数
IN(n,x)第1種n次変形ベッセル関数
KN(n,x)第2種n次変形ベッセル関数
JL(l,x)第1種l次çƒãƒ™ãƒƒã‚»ãƒ«é–¢æ•°
YL(l,x)第2種l次çƒãƒ™ãƒƒã‚»ãƒ«é–¢æ•°
JNU(nu,x)第1種nu次ベッセル関数 (nu ã¯æ­£ã®å®Ÿæ•°)
YNU(nu,x)第2種nu次ベッセル関数 (nu ã¯æ­£ã®å®Ÿæ•°)
INU(nu,x)第1種nu次変形ベッセル関数 (nu ã¯æ­£ã®å®Ÿæ•°)
KNU(nu,x)第2種nu次変形ベッセル関数 (nu ã¯æ­£ã®å®Ÿæ•°)
PN(n,x)ルジャンドル多項å¼
LGN(n,a,x)ラゲールå€å¤šé …å¼
HN(n,x)エルミート多項å¼
TN(n,x)ãƒã‚§ãƒ“シフ多項å¼
ZETA(x)リーマンゼータ関数 ζ(x)
ZETA_INT(x)リーマンゼータ関数 ζ(x) (x ã¯æ•´æ•°)
ZETAM1(x)リーマンゼータ関数 ζ(x) - 1
ZETAM1_INT(x)リーマンゼータ関数 ζ(x) - 1 (x ã¯æ•´æ•°)

日付時刻関数


MJD(year,month,day,hour,min,sec)修正ユリウス日(year, month, day ã¯ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã€hour,min,sec 㯠UTC 時刻ã€ã†ã‚‹ã†ç§’ã¯è€ƒæ…®ã•れãªã„)
UNIX2MJD(time)修正ユリウス日(time 㯠1970å¹´1月1æ—¥00:00:00 UTC ã‹ã‚‰ã®çµŒéŽç§’æ•°ã€ã†ã‚‹ã†ç§’ã¯è€ƒæ…®ã•れãªã„)
MJD2UNIX(mjd)修正ユリウス日 mjd ã®1970å¹´1月1æ—¥00:00:00 UTC ã‹ã‚‰ã®çµŒéŽç§’æ•°(ã†ã‚‹ã†ç§’ã¯è€ƒæ…®ã•れãªã„)
MJD2YEAR(mjd)修正ユリウス日ã«å¯¾å¿œã™ã‚‹ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã®å¹´
MJD2MONTH(mjd)修正ユリウス日ã«å¯¾å¿œã™ã‚‹ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã®æœˆ
MJD2DAY(mjd)修正ユリウス日ã«å¯¾å¿œã™ã‚‹ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã®æ—¥
MJD2WDAY(mjd)修正ユリウス日ã«å¯¾å¿œã™ã‚‹ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã®æ›œæ—¥ (1:月曜日 ã‹ã‚‰ 7:日曜日)
MJD2YDAY(mjd)修正ユリウス日ã«å¯¾å¿œã™ã‚‹ã‚°ãƒ¬ã‚´ãƒªã‚ªæš¦ã® 1 月 1 æ—¥ã‹ã‚‰ã®é€šç®—日数 (1 ã‹ã‚‰ 366)
TIME()紀元 (1970å¹´1月1æ—¥00:00:00 UTC) ã‹ã‚‰ã®çµŒéŽæ™‚é–“ã‚’ç§’å˜ä½ã§è¿”ã™ã€‚

è«–ç†é–¢æ•°

  • 0 ã‚’å½, ãれ以外を真ã¨ã™ã‚‹ã€‚

EQ(x,y,prec)xï¼y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯å®Œå…¨ä¸€è‡´) 。
NEQ(x,y,prec)x≠y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯å®Œå…¨ä¸€è‡´) 。
GE(x,y,prec)x≧y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯æ¡æ•°æŒ‡å®šãªã—) 。
GT(x,y,prec)x>y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯æ¡æ•°æŒ‡å®šãªã—) 。
LE(x,y,prec)x≦y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯æ¡æ•°æŒ‡å®šãªã—) 。
LT(x,y,prec)x<y ã®ã¨ã真(=1)。prec ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã§ãã‚‹ (prec == 0 ã¯æ¡æ•°æŒ‡å®šãªã—) 。
NOT(x)xï¼0 ã®ã¨ã真(=1)
OR(x,y)(x≠0) or (y≠0) ã®ã¨ã真(=1)
AND(x,y)(x≠0) and (y≠0) ã®ã¨ã真(=1)
XOR(x,y)(x≠0) xor (y≠0) ã®ã¨ã真(=1)

é…列æ“作関数

ARRAY(a, v1, v2, ...)é…列 a を残りã®å¼•æ•°ã§åˆæœŸåŒ–ã™ã‚‹ã€‚é…列ã®è¦ç´ æ•°ã‚’è¿”ã™ã€‚
SIZE(a)é…列 a ã®è¦ç´ æ•°
SORT(a)é…列 a を整列ã™ã‚‹
RSORT(a)é…列 a ã‚’é€†é †ã«æ•´åˆ—ã™ã‚‹
POP(a)é…列 a ã‹ã‚‰æœ«å°¾ã®è¦ç´ ã‚’å–り除ã„ã¦ãれを返ã™
PUSH(a,x)é…列 a ã®æœ«å°¾ã« x を追加ã™ã‚‹ (戻り値㯠x)
SHIFT(a)é…列 a ã®å…ˆé ­ã®è¦ç´ ã‚’å–り除ã„ã¦ãれを返ã™ã€‚残りã®è¦ç´ ã¯ã²ã¨ã¤ãšã¤å‰ã«è©°ã‚られる
UNSHIFT(a,x)é…列 a ã®å…ˆé ­ã« x を挿入ã™ã‚‹ (戻り値㯠x)
ARRAY_SUM(a)é…列 a ã®è¦ç´ ã®å’Œã‚’è¿”ã™
ARRAY_SUMSQ(a)é…列 a ã®è¦ç´ ã®è‡ªä¹—和を返ã™
ARRAY_AVERAGE(a)é…列 a ã®è¦ç´ ã®å¹³å‡ã‚’è¿”ã™
ARRAY_STDEVP(a)é…列 a ã®è¦ç´ ã®æ¨™æº–å差を返ã™
ARRAY_STDEV(a)é…列 a ã®è¦ç´ ã®ä¸å標準å差を返ã™
ARRAY_MAX(a)é…列 a ã«å«ã¾ã‚Œã‚‹æœ€å¤§ã®å€¤ã‚’è¿”ã™
ARRAY_MIN(a)é…列 a ã«å«ã¾ã‚Œã‚‹æœ€å°ã®å€¤ã‚’è¿”ã™
ARRAY_CLEAR(a)é…列 a ã®é…列ã®è¦ç´ æ•°ã‚’ 0 ã«ã™ã‚‹
ARRAY_COMPACT(a)é…列 a ã®é…列ã®è¦ç´ ã‹ã‚‰é€šå¸¸ã®æ•°å€¤ä»¥å¤–ã‚’å–り除ãã€å–り除ã„ãŸå¾Œã®è¦ç´ æ•°ã‚’è¿”ã™

メモリーæ“作関数

メモリーã¯å…¨ã¦ã®æ•°å¼å¤‰æ›ã§å…±æœ‰ã•れã¾ã™ã€‚

M(i,x)引数を第iメモリーã«ä»£å…¥ã™ã‚‹(i=0〜65535)ã€i ãŒè² ã®ã¨ãã¯æœ«å°¾ã‹ã‚‰ã®ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ (戻り値㯠x)
RM(i)ç¾åœ¨ã®ç¬¬iメモリーã®å€¤(i=0〜65535)ã€i ãŒè² ã®ã¨ãã¯æœ«å°¾ã‹ã‚‰ã®ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹
CM(x,n)先頭ã‹ã‚‰n個ã®ãƒ¡ãƒ¢ãƒªãƒ¼ã‚’ x ã§åˆæœŸåŒ–ã™ã‚‹ã€n ㌠0 ã®ã¨ãã¯ãƒ¡ãƒ¢ãƒªãƒ¼å…¨ä½“ã€n ãŒè² ã®ã¨ãã¯æœ«å°¾ã‹ã‚‰ n 個ã®ãƒ¡ãƒ¢ãƒªãƒ¼ã‚’ x ã§åˆæœŸåŒ–ã™ã‚‹ (戻り値㯠x)
AM(a)é…列 a ã®å†…容をメモリーã«ã‚³ãƒ”ーã™ã‚‹ (戻り値ã¯ã‚³ãƒ”ーã—ãŸè¦ç´ æ•°)

図形æç”»é–¢æ•°

図形をæç”»ã—ã¾ã™ã€‚

  • 本æ¥ã®ãƒ—ロットもæç”»ã•れるã®ã§ã€ä¸è¦ãªå ´åˆã¯ãƒ—ロットタイプを mark ã«ã€ã‚µã‚¤ã‚ºã‚’ 0 ã«ã™ã‚‹ã“ã¨ã§ã€å›³å½¢ã®ã¿æç”»ã•ã›ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚
  • æç”»ã•れる図形ã¯è»¸ã®ã‚ªãƒ¼ãƒˆã‚¹ã‚±ãƒ¼ãƒ«ã«ã¯è€ƒæ…®ã•れã¾ã›ã‚“。
  • 図形ã®è‰²ã‚„線幅・線種ã¯ãã®ãƒ•ァイルオブジェクトã®è¨­å®šãŒä½¿ã‚れ㾠ã™ã€‚変ãˆãŸã„å ´åˆã¯ COLOR() 関数ãªã©ã‚’利用ã—ã¾ã™ã€‚
DRAW_RECT(x, y, w, h, stroke, fill) (x, y) 㨠(x + w, y + h) を対角ã®é ‚点ã¨ã™ã‚‹çŸ©å½¢ã‚’æç”»ã—ã¾ã™ã€‚stroke, fill ㌠0 ã®å ´åˆã¯ãれãžã‚Œè¼ªéƒ­ã€å¡—りã¤ã¶ã—ã‚’æç”»ã—ã¾ã›ã‚“。
DRAW_ARC(x, y, rx, ry, start, stop, pieslice, stroke, fill, close) (x, y) を中心ã¨ã— X æ–¹å‘åŠå¾„ rx, Y æ–¹å‘åŠå¾„ ry ã®å††å¼§ã‚’æç”»ã—ã¾ ã™ã€‚start, stop ã§é–‹å§‹è§’ã€å††å¼§è§’を指定ã—ã¾ã™ã€‚stroke, fill ㌠0 ã®å ´åˆã¯ãれãžã‚Œè¼ªéƒ­ã€å¡—りã¤ã¶ã—ã‚’æç”»ã—ã¾ã›ã‚“。pieslice ㌠0 以 外ã®å ´åˆã¯æ‰‡å½¢ã‚’æç”»ã—ã¾ã™ã€‚close ㌠0 以外ã®å ´åˆã¯è¼ªéƒ­ã‚’é–‰ã˜ã¾ ã™ã€‚
DRAW_MARK(x, y, size) (x, y) ã«ãƒžãƒ¼ã‚¯ã‚’æç”»ã—ã¾ã™ã€‚size ã§ãƒžãƒ¼ã‚¯ã®ã‚µã‚¤ã‚ºã‚’指定ã§ãã¾ã™ã€‚ size ㌠0 ã®ã¨ãã¯ãƒ•ァイルオブジェクトã®ã‚µã‚¤ã‚ºæŒ‡å®šãŒä½¿ã‚れã¾ã™ã€‚
DRAW_LINE(x1, y1, x2, y2) (x1, y1) ã‹ã‚‰ (x2, y2) ã«ç›´ç·šã‚’æç”»ã—ã¾ã™ã€‚
DRAW_POLYLINE(ax, ay) 座標 (ax[0], ay[0]), (ax[1], ay[1]), ... ã‚’ç›´ç·šã§çµã³ã¾ã™ã€‚
DRAW_POLYGON(ax, ay, stroke, fill) 座標 (ax[0], ay[0]), (ax[1], ay[1]), ... ã§å›²ã¾ã‚ŒãŸé ˜åŸŸã‚’æç”»ã—ã¾ã™ã€‚ stroke, fill ㌠0 ã®å ´åˆã¯ãれãžã‚Œè¼ªéƒ­ã€å¡—りã¤ã¶ã—ã‚’æç”»ã—ã¾ã›ã‚“。
DRAW_ERRORBAR(x, y, erx, ery, size) (x - erx, y) ã‹ã‚‰ (x + erx, y) ãŠã‚ˆã³ (x, y - ery) ã‹ã‚‰ (x, y + ery) ã«èª¤å·®æ£’ã‚’æç”»ã™ã‚‹ã€‚size ã§ tick ã®é•·ã•を指定ã§ãる。size ㌠0 ã®ã¨ãã¯ãƒ•ァイルオブジェクトã®ã‚µã‚¤ã‚ºæŒ‡å®šãŒä½¿ã‚れる。
DRAW_ERRORBAR2(x1, y1, x2, y2, size) (x1, y1) ã‹ã‚‰ (x2, y2) ã«èª¤å·®æ£’ã‚’æç”»ã™ã‚‹ã€‚size ã§ tick ã®é•·ã•ã‚’ 指定ã§ãる。size ㌠0 ã®ã¨ãã¯ãƒ•ァイルオブジェクトã®ã‚µã‚¤ã‚ºæŒ‡å®šãŒ 使ã‚れる。

ãã®ä»–ã®é–¢æ•°

FIT_PRM(id,x) ID ㌠id ã® data オブジェクトã®ãƒ—ロットタイプ㌠fit ã®ã¨ãã€å¯¾å¿œã™ ã‚‹ fit object ã®ãƒ•ィールド "%0x" ã®å€¤ã€‚
FIT_CALC(id,x) ID ㌠id ã® data オブジェクトã®ãƒ—ロットタイプ㌠fit ã®ã¨ãã€å¯¾å¿œã™ã‚‹ fit çµæžœ f(x) を計算ã™ã‚‹ã€‚
LINE_NUMBER()処ç†ä¸­ã®ãƒ•ã‚¡ã‚¤ãƒ«è¡Œç•ªå· (1行目ãŒ1)
ISNORMAL(x)x ãŒé€šå¸¸ã®æ•°å€¤ã®å ´åˆçœŸ
ISBREAK(x)x ㌠BREAK ã®å ´åˆçœŸ
ISCONT(x)x ㌠CONT ã®å ´åˆçœŸ
ISNAN(x)x ㌠NAN ã®å ´åˆçœŸ
ISUNDEF(x)x ㌠UNDEF ã®å ´åˆçœŸ
SUM(x)ç©ç®—
DIF(x)差分
F(x,y,z)ユーザ定義関数
G(x,y,z)ユーザ定義関数
H(x,y,z)ユーザ定義関数
COLOR(0,x)R値を x (0≦x<256)ã«è¨­å®š
COLOR(1,x)G値を x (0≦x<256)ã«è¨­å®š
COLOR(2,x)B値を x (0≦x<256)ã«è¨­å®š
COLOR(3,x)RGB値を x (0≦x<256)ã«è¨­å®š
COLOR(4,x)R2値を x (0≦x<256)ã«è¨­å®š
COLOR(5,x)G2値を x (0≦x<256)ã«è¨­å®š
COLOR(6,x)B2値を x (0≦x<256)ã«è¨­å®š
COLOR(7,x)R2, G2, B2 値を x (0≦x<256)ã«è¨­å®š
COLOR(8,x)x ã‚’ 6 æ¡ã® 16 進数ã¨ã—ã¦ã€ 2 æ¡ãšã¤ R, G, B 値ã«è¨­å®š
COLOR(9,x)x ã‚’ 6 æ¡ã® 16 進数ã¨ã—ã¦ã€ 2 æ¡ãšã¤ R2, G2, B2 値ã«è¨­å®š
OBJ_COLOR(id, DATA_OBJ), OBJ_COLOR(id)R, G, B, R2, G2, B2 値を ID ㌠id ã® data オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_COLOR(id, PATH_OBJ)R, G, B, R2, G2, B2 値を ID ㌠id ã® path オブジェクト㮠stroke_R, stroke_G, stroke_B, fill_R, fill_G, fill_B ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_COLOR(id, RECT_OBJ)R, G, B, R2, G2, B2 値を ID ㌠id ã® rectangle オブジェクト㮠stroke_R, stroke_G, stroke_B, fill_R, fill_G, fill_B ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_COLOR(id, ARC_OBJ)R, G, B, R2, G2, B2 値を ID ㌠id ã® arc オブジェクト㮠stroke_R, stroke_G, stroke_B, fill_R, fill_G, fill_B ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_COLOR(id, MARK_OBJ)R, G, B, R2, G2, B2 値を ID ㌠id ã® mark オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_COLOR(id, TEXT_OBJ)R, G, B 値を ID ㌠id ã® text オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
ALPHA(x)A, A2 値を x (0≦x<256)ã«è¨­å®š
ALPHA(x,1)A 値を x (0≦x<256)ã«è¨­å®š
ALPHA(x,2)A2 値を x (0≦x<256)ã«è¨­å®š
OBJ_ALPHA(id, DATA_OBJ), OBJ_ALPHA(id)A, A2 値を ID ㌠id ã® data オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_ALPHA(id, PATH_OBJ)A, A2 値を ID ㌠id ã® path オブジェクト㮠stroke_A, fill_A ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_ALPHA(id, RECT_OBJ)A, A2 値を ID ㌠id ã® rectangle オブジェクト㮠stroke_A, fill_A ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_ALPHA(id, ARC_OBJ)A, A2 値を ID ㌠id ã® arc オブジェクト㮠stroke_A, fill_A ã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_ALPHA(id, MARK_OBJ)A, A2 値を ID ㌠id ã® mark オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
OBJ_ALPHA(id, TEXT_OBJ)A 値を ID ㌠id ã® text オブジェクトã¨åŒã˜å€¤ã«ã™ã‚‹ã€‚
RGB(r,g,b)色ã®RGB値をãれãžã‚Œ r, g, b (0≦r,g,b≦1)ã«è¨­å®š
RGB2(r,g,b)R2, G2, B2, ã®å€¤ã‚’ r, g, b (0≦r,g,b≦1)ã«è¨­å®š
HSB(h,s,b)色ã®HSB値をãれãžã‚Œ h, s, b (0≦h,s,b≦1)ã«è¨­å®š
HSB2(h,s,b)R2, G2, B2, ã®å€¤ã‚’ã€HSB値ã‹ã‚‰ãれãžã‚Œ h, s, b (0≦h,s,b≦1)ã«è¨­å®š
MARKSIZE(x)マークã®ã‚µã‚¤ã‚ºã‚’Xã«è¨­å®š
MARKTYPE(x)マークã®ç¨®é¡žã‚’Xã«è¨­å®š
IF(x,ex1,ex2)x ≠ 0 ã®ã¨ã ex1, x = 0 ã®ã¨ã ex2
UNLESS(x,ex1,ex2)x ≠ 0 ã®ã¨ã ex2, x = 0 ã®ã¨ã ex1
FOR(m,begin,end,step,ex)第mメモリーã®å€¤ã« begin ã‹ã‚‰ end ã¾ã§ step 㧠値を設定ã—ã€ex を繰り返ã™ã€‚ m ãŒè² ã®æ™‚ã¯ãƒ¡ãƒ¢ãƒªãƒ¼ã¸ã®è¨­å®šã¯è¡Œã‚れãªã„。 最後ã«è©•価ã•れ㟠ex ã®å€¤ã‚’è¿”ã™ã€‚
PROG1(arg1,arg2,...)引数を評価ã—ã€æœ€åˆã®å¼•æ•°ã®å€¤ã‚’è¿”ã™
PROG2(arg1,arg2,...)引数を評価ã—ã€2 番目ã®å¼•æ•°ã®å€¤ã‚’è¿”ã™
PROGN(arg1,arg2,...)引数を評価ã—ã€æœ€å¾Œã®å¼•æ•°ã®å€¤ã‚’è¿”ã™



演算å­ã®å„ªå…ˆé †ä½

æ¼”ç®—å­ + - (正負ã®ç¬¦å·) ã®å„ªå…ˆé †ä½ãŒ Version 6.03 以å‰ã¨ç•°ãªã£ã¦ã„ã¾ã™ã€‚


高!
↑^
+ - (正負ã®ç¬¦å·)
* / \
+ -
< <= > >=
== !=
&&
↓||
低:=(+=, -= ... )



æ•°å¼å¤‰æ›ã®ä½¿ç”¨ä¾‹


  • ; 使用例

    ; ã¯å¼ã®çµ‚端を示ã—ã¾ã™ãŒã€ã•らã«ç¶šã‘ã¦åˆ¥ã®å¼ã‚’書ãã“ã¨ãŒã§ãã¾ã™ã€‚ å¼ã®å€¤ã¯ä¸€ç•ªæœ€å¾Œã®å¼ã®å€¤ã«ãªã‚Šã¾ã™ã€‚ 例ãˆã°ã€é•·ã„å¼ãŒä½•度もç¾ã‚Œã‚‹ã¨ã変数ã¸ã®ä»£å…¥ã¨çµ„ã¿åˆã‚ã›ã¦

          a:=...å¼...; ... a ....;
          
    ã®ã‚ˆã†ã«ã™ã‚Œã°åŒã˜å¼ã¯ï¼‘度書ãã ã‘ã§ã™ã¿ã¾ã™ã€‚ã¾ãŸå¼æœ€å¾Œã® ; ã¯çœç•¥ã§ãã¾ã™ã€‚

    (従æ¥ã¯å¼ã®çµ‚端ã¨ã—㦠"=" ãŒä½¿ã‚れã¦ã„ã¾ã—ãŸãŒ version 6.06.10 ä»¥é™ ã¯ ";" を推奨ã¨ã—ã¾ã™ã€‚)

  • メモリー関数 M(), RM() 使用例

    M() ã¯ãƒ¡ãƒ¢ãƒªãƒ¼ã¸ã®ä»£å…¥ã€RM() ã¯èª­ã¿ã ã—ã§ã™ã€‚å…¨ã¦ã®æ•°å¼å¤‰æ›ã§ãƒ¡ãƒ¢ãƒªãƒ¼ã¯ 共有ã•れるãŸã‚ã€ãƒ‡ãƒ¼ã‚¿é–“ã§ã®å€¤ã®å—ã‘æ¸¡ã—ã«åˆ©ç”¨ã§ãã¾ã™ã€‚メ モリー㯠65536 個 (0〜65535) ã¾ã§åˆ©ç”¨ã§ãã¾ã™ã€‚ã¾ãŸã€æœªä½¿ç”¨ã®ãƒ¡ãƒ¢ãƒªãƒ¼ã¯ 0 ã«åˆæœŸåŒ–ã•れã¦ã„ã¾ã™ã€‚

  • 比較関数 EQ(), NEQ(), LT(), GT(), LE(), GE() 使用例

    æ•°å€¤ã®æ¯”較を行ã†é–¢æ•°ã§ã™ãŒã€ä¸‹è¨˜ã®ä¾‹ã®ã‚ˆã†ã«æµ®å‹•å°æ•°ç‚¹èª¤å·®ã«ã‚ˆã‚Š æ€ã£ãŸé€šã‚Šã®çµæžœãŒå¾—られãªã„å ´åˆãŒã‚りã¾ã™ã€‚

          Ngraph$ iexpr 'EQ(0.5 - 0.4, 0.1)'
          0
          

    ã“ã®ã‚ˆã†ãªå ´åˆã«ã€ï¼“番目ã®å¼•æ•°ã§æ¯”è¼ƒã®æ¡æ•°ã‚’指定ã™ã‚‹ã¨æœŸå¾…ã™ã‚‹çµæžœ ãŒå¾—られるã“ã¨ãŒå¤šããªã‚Šã¾ã™ã€‚

          Ngraph$ iexpr 'EQ(0.5 - 0.4, 0.1, 14)'
          1
          

    計算ã«ã‚ˆã£ã¦ã¯æµ®å‹•å°æ•°ç‚¹èª¤å·®ã®å½±éŸ¿ãŒå¤§ãããªã‚‹å ´åˆã‚‚ã‚りã¾ã™ã®ã§æ³¨ æ„ãŒå¿…è¦ã§ã™ã€‚

  • 関数 DIF() 使用例

    関数 DIF() ã¯å¾®åˆ†ã§ãªã差分を返ã™é–¢æ•°ã§ã™ã€‚ ç¾åœ¨ã®ãƒ‡ãƒ¼ã‚¿ãŒãƒ‡ãƒ¼ã‚¿ä¸­ n 番目ã¨ã—ãれを Y(n) ã§è¡¨ã™ã¨ã™ã‚‹ã¨

    DIF(Y)=Y(n) - Y(n-1)

    ã§ã™ã€‚ã“れを用ã„ç°¡å˜ã«å¾®åˆ†è¿‘似値を求ã‚ã‚‹ã«ã¯
          DIF(Y)/DIF(X)
          
    ã¨ã—ã¾ã™ã€‚

    DIF(Y)/DIF(X)㯠{Y(n)-Y(n-1)} / {X(n)-X(n-1)} ã«ãªã‚Šã¾ã™ã€‚

    ã“ã®æ™‚ã€Xã®å¤‰æ›æ•°å¼ã‚’
          X-DIF(X)*0.5
          
    ã¨ã—ã¦Xã‚’"ç¾åœ¨ã®ãƒ‡ãƒ¼ã‚¿ã¨ä¸€ã¤å‰ã®ãƒ‡ãƒ¼ã‚¿ã®ä¸­é–“値"ã¨ã—ã¦ãŠã„ãŸæ–¹ãŒã‚ˆã‚ŠçœŸã«è¿‘ã„グラフãŒå¾—ã‚‰ã‚Œã‚‹ã¨æ€ã‚れã¾ã™ã€‚

    X変æ›å¼: X-DIF(X)*0.5 (ã“れ㯠{ X(n-1)+X(n) }*0.5 ã«ãªã‚Šã¾ã™)
    Y変æ›å¼: DIF(Y)/DIF(X) (ã“れ㯠{ Y(n)-Y(n-1) } / { X(n)-X(n-1) } ã«ãªã‚Šã¾ã™)

    DIF() ã¯ç¾åœ¨ã®ãƒ‡ãƒ¼ã‚¿ã¨ä¸€ã¤å‰ã®ãƒ‡ãƒ¼ã‚¿ã¨ã®å·®åˆ†ã‚’è¿”ã—ã¾ã™ã‹ã‚‰ã€Y-DIF(Y) ã¨ã™ã‚‹ã“ã¨ã§ä¸€ã¤å‰ã®ãƒ‡ãƒ¼ã‚¿ã‚’å–り出ã™ã“ã¨ãŒã§ãã¾ã™ã€‚ åŒæ§˜ã« Y-DIF(Y)-DIF(Y-DIF(Y)) ã§2ã¤å‰ã®ãƒ‡ãƒ¼ã‚¿ã‚’å–り出ã™ã“ã¨ãŒã§ãã¾ã™ã€‚ Y-DIF(Y)-DIF(Y-DIF(Y))-DIF(Y-DIF(Y)-DIF(Y-DIF(Y)))ã¯3ã¤å‰ã®ãƒ‡ãƒ¼ã‚¿ã§ã™ï¼Ž

    一番åˆã‚ã® DIF() ã®æˆ»ã‚Šå€¤ã¯"ä¸å®š"ã§ã™ï¼Žã“ã®ãŸã‚,å¼å…¨ä½“ã®å€¤ã‚‚"ä¸å®š"ã¨ãªã‚Šã€çµæžœã¨ã—ã¦ãƒ‡ãƒ¼ã‚¿ã®å€‹æ•°ã¯1ã¤æ¸›ã‚Šã¾ã™(一番åˆã‚ã®ãƒ‡ãƒ¼ã‚¿ã«å·®åˆ†ã¯å­˜åœ¨ã—ãªã„)。 ã¾ãŸ DIF() ã‚’ã„ãã¤ã‚‚å«ã‚€å¼ã§ã¯ã€å…¨ã¦ã® DIF() ãŒåˆæœŸåŒ–ã•れるã¾ã§å¼å…¨ä½“ã®å€¤ã¯"ä¸å®š"ã§ã™ã€‚ 例ãˆã° DIF() ã‚’ãƒã‚¹ãƒˆã—㦠DIF(DIF()) ã®ã‚ˆã†ã«ä½¿ã£ãŸå ´åˆã€ä¸€ç•ªåˆã‚ã®ãƒ‡ãƒ¼ã‚¿ã§ã¯å†…å´ã® DIF() ãŒåˆæœŸåŒ–ã•れãã®æˆ»ã‚Šå€¤ã¯ä¸å®šã®ç‚ºã€å¤–å´ã® DIF() ã®åˆæœŸåŒ–ã¯è¡Œã‚れã¾ã›ã‚“。 外å´ã® DIF() ãŒåˆæœŸåŒ–ã•れるã®ã¯ 2番目ã®ãƒ‡ãƒ¼ã‚¿ã®æ™‚ã§ã™ã€‚ 従ã£ã¦ãƒ‡ãƒ¼ã‚¿ã®å€‹æ•°ã¯2ã¤æ¸›ã‚‹ã“ã¨ã«ãªã‚Šã¾ã™ã€‚



  • 関数 SUM() 使用例

    関数 SUM() ã¯ç©ç®—ã‚’è¿”ã™é–¢æ•°ã§ã™ã€‚ ç¾åœ¨ã®ãƒ‡ãƒ¼ã‚¿ãŒ n 番目ã¨ã—ãれを Y(n) ã§è¡¨ã™ã¨ã™ã‚‹ã¨

    SUM(Y)=Σ Y(n) (n=1..n)

    ã“れを用ã„ç°¡å˜ã«ç©åˆ†è¿‘似値を求ã‚ã‚‹ã«ã¯
          SUM(Y*DIF(X))
          
    ã¨ã—ã¾ã™ã€‚

    SUM(Y * DIF(X)) 㯠Σ Y(n) * {X(n) - X(n-1)} (n = 1..n) ã«ãªã‚Šã¾ã™ã€‚

    ã¾ãŸã€å°å½¢å…¬å¼ã‚’用ã„ã¦ç©åˆ†è¿‘似値を評価ã—ãŸã„å ´åˆ
          SUM(0.5 * (2 * Y - DIF(Y)) * DIF(X))
          
    ã¨ã—ã¾ã™ã€‚

    SUM(0.5 * (2 * Y - DIF(Y)) * DIF(X)) 㯠Σ(Y(n-1) + Y(n)) / 2 *{X(n) - X(n-1)} (n = 1..n) ã«ãªã‚Šã¾ã™ã€‚

    ã•らã«ç©åˆ†ã®ä¸Šé™(b)ã€ä¸‹é™(a)を指定ã—ãŸã„å ´åˆã¯éšŽæ®µé–¢æ•° THETA() を用ã„
          SUM(0.5 * (2 * Y-DIF(Y)) * DIF(X) * THETA(X-a) * THETA(b-X))
          
    ã¨ã—ã¾ã™ã€‚IF() を使ã£ã¦
          IF(X >= a && X <= b, SUM(0.5 * (2 * Y - DIF(Y)) * DIF(X)), 0)
          
    ã¨ã—ã¦ã‚‚å¯èƒ½ã§ã™ã€‚

  • 関数 IF() 使用例

    IF(x,ex1,ex2) 㯠x ãŒçœŸ(<>0)ã®ã¨ã ex1 を,å½(=0)ã®ã¨ã ex2 ã‚’è¿”ã™é–¢æ•°ã§ã™ã€‚例ãˆã°æ¬¡ã®å¼
          IF( x < 0, 0, SQRT(x) )
          
    㯠x<0 ã®ã¨ã 0ã€x>=0 ã®ã¨ã√x ã‚’è¿”ã™é–¢æ•°ã«ãªã‚Šã¾ã™ã€‚ã¾ãŸå¿…ãš ex1, ex2 ã©ã¡ã‚‰ã‹ä¸€æ–¹ã—ã‹è©•価ã•れã¾ã›ã‚“。

  • 関数 MARKSIZE(), COLOR() 使用例

    MARKSIZE()ã€COLOR()é–¢æ•°ã¯æ•°å­¦é–¢æ•°ã§ã¯ç„¡ãã€ãれãžã‚Œãƒ—ロットã•れãŸãƒžãƒ¼ã‚¯ã®ã‚µã‚¤ã‚ºã€è‰²ã‚’指定ã™ã‚‹é–¢æ•°ã§ã™ã€‚ 例ãˆã°ã€(x,y,z) ã® 3 カラムã‹ã‚‰æˆã‚‹ãƒ‡ãƒ¼ã‚¿ãŒã‚りã€ãƒžãƒ¼ã‚¯ã®ã‚µã‚¤ã‚ºã‚’ z ã®å€¤ã§å¤‰æ›´ã—ãŸã„よã†ãªå ´åˆã«ã¯
          MARKSIZE(%03)
          
    ã¨ã—ã¾ã™ã€‚ãŸã ã“れã§ã™ã¨ã€ãƒ—ロットã•れるデータも %03 ã¨ãªã‚Šã¾ã™ã®ã§ã€å‰è¿°ã® ; を使ã£ã¦
          MARKSIZE(%03);Y
          
    ã¨ã™ã‚‹ã®ãŒæ­£ã—ã„ä½¿ã„æ–¹ã§ã™ã€‚ COLOR()é–¢æ•°ã‚‚åŒæ§˜ã§
          COLOR(3,%03);Y
          
    ã®ã‚ˆã†ã«ä½¿ã„ã¾ã™ã€‚
  • 関数 OBJ_COLOR() 使用例

    data, path, rectangle, arc, mark, text ã®å„オブジェクトã®è¨­å®šè‰²ã‚’æ 画色ã«ã—ã¾ã™ã€‚例ãˆã°ã„ãã¤ã‹ã®ãƒ•ã‚£ãƒƒãƒ†ã‚£ãƒ³ã‚°çµæžœã‚’ã‚‚ã¨ã«ãƒ•ィッティ ングパラメータをグラフã«ã™ã‚‹ã‚ˆã†ãªå ´åˆã€

          OBJ_COLOR(X);FIT_PRM(X,1)
          
    ã®ã‚ˆã†ã«ã—ã¦ã€ãƒ•ィッティングã¨ãƒ—ロットã®è‰²ã‚’æƒãˆã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚ ã“ã®æ™‚ X ã¯ãƒ•ィッティングプロットã«ã—㟠data オブジェクトã®ã‚¤ãƒ³ã‚¹ã‚¿ ンス ID ã§ã™ã€‚

  • 関数 FIT_PRM(), FIT_CALC() 使用例

    フィッティングã®çµæžœã‹ã‚‰ãã®ãƒ‘ラメータやã€ãƒ•ィッティングå¼ã®è¨ˆç®—ã‚’ 行ã†é–¢æ•°ã§ã™ã€‚

    例ãˆã°ã€ã„ãã¤ã‹ã®ï¼‘次フィットã‹ã‚‰ãã®å‚¾ãをプロットã—ãŸã„å ´åˆã€

          FIT_PRM(X,1)
          
    ã®ã‚ˆã†ã«ã—ã¾ã™ã€‚ã“ã®æ™‚ X ã¯ãƒ•ィッティングプロットã«ã—㟠data オブジェ クトã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ ID ã§ã™ã€‚

    ã¾ãŸã€ï¼‘次ドリフトã®ã‚るデータã‹ã‚‰ãƒ‰ãƒªãƒ•トæˆåˆ†ã‚’引ã„ã¦ãƒ—ロット㗠ãŸã„å ´åˆ (id ㌠0 ã® data オブジェクトã§ãƒ•ィッティングを行ã£ã¦ã„ ã‚‹ã¨ã—ã¦)ã€

          Y-FIT_CALC(0,X)
          
    ã®ã‚ˆã†ã«ã—ã¾ã™ã€‚

    ã“れらã®é–¢æ•°ã¯ãƒ•ィッティングã®çµæžœãŒç¢ºå®šã—ã¦ã„ãªã„ã¨è¨ˆç®—ã«å¤±æ•—ã—ã¾ ã™ã€‚ãƒ‡ãƒ¼ã‚¿ã®æç”»é †ã«æ³¨æ„ã—ã¦ãã ã•ã„。ã¾ãŸã€åˆå›žã®ãƒ—ロットã§ã‚ªãƒ¼ トスケールã«å映ã•れãªã„ã“ã¨ãŒã‚りã¾ã™ã€‚

  • 関数 PROG1(), PROG2(), PROGN() 使用例

    関数 PROG1(), PROG1(), PROGN() ã¯è¤‡æ•°ã®å¼•数を評価ã—ã¦ã€æœ€åˆã€2番 ç›®ã¾ãŸã¯æœ€å¾Œã®å¼•æ•°ã®å€¤ã‚’è¿”ã™é–¢æ•°ã§ã™ã€‚IF(), UNLESS(), FOR() 関数 ã®å¼•æ•°ã«ä½¿ç”¨ã—ã¦è¤‡æ•°ã®å¼ã‚’評価ã™ã‚‹ãŸã‚ã«åˆ©ç”¨ã§ãã¾ã™ã€‚下記ã®ä¾‹ã§ 㯠X ã®å€¤ãŒ 1 以上変化ã™ã‚‹æ¯Žã« Y ã®å¹³å‡å€¤ã‚’計算ã—ã¦ã„ã¾ã™ (X 㯠1 よりも大ãã„ã“ã¨ã‚’仮定) 。

          IF(X - A < 1, PROGN(B += Y, N += 1, CONT), PROG1(IF(N, B / N, CONT), B := Y, N := 1, A := X))
          
  • 図形æç”»é–¢æ•°ã®ä½¿ç”¨ä¾‹

    データã‹ã‚‰å††ã‚„矩形をæç”»ã§ãã¾ã™ã€‚例ãˆã°ã€ä»¥ä¸‹ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ã‹ã‚‰ 円グラフを作æˆã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

    データ

         1
         2
         3
         4
       

    変æ›å¼

         HSB2(%0/NUM,1,1); X*=360/SUMX; DRAW_ARC(0,0,1,1,SUM(X),-X,1,1,1,1)
       

    HSB2() 関数ã§å¡—りã¤ã¶ã—ã®è‰²ã‚’変ãˆãªãŒã‚‰ DRAW_ARC() é–¢æ•°ã§æ‰‡å½¢ã‚’æ ç”»ã—ã¾ã™ã€‚

ngraph-gtk-6.08.00/doc/html/ja/operate.html0000644000175000017500000002744513246234367015326 00000000000000 Operation  

æ“作方法




ウィンドウ


Ngraph ã§ä½¿ç”¨ã™ã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã‚’説明ã—ã¾ã™ã€‚

Main WindowグラフãŒè¡¨ç¤ºã•れã¦ã„るウィンドウã§ã™ã€‚マウスã«ã‚ˆã‚‹å„種設定ãŒã§ãã¾ã™

シングルウィンドウモードã§ãªã„å ´åˆã¯ä¸‹è¨˜ã®ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã‚‚表示・éžè¡¨ç¤ºã‚’切り替ãˆã¦ä½¿ç”¨ã§ãã¾ã™ã€‚

Data Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚データã®ãƒ‘ラメタを一覧表示ã—ã¾ã™
Axis Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚軸ã®ãƒ‘ラメタを一覧表示ã—ã¾ã™
Legend Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚凡例ã®ãƒ‘ラメタを一覧表示ã—ã¾ã™
Merge Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚マージã™ã‚‹ãƒ•ァイルã®ãƒ‘ラメタを一覧表示ã—ã¾ã™
Coordinate Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚Viewer Window 上ã®ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ä½ç½®ã®1mmå˜ä½ã§ã®åº§æ¨™å€¤ã‚’表示ã—ã¾ã™ã€‚軸ãŒè¨­å®šã•れã¦ã„れã°å¯¾å¿œã™ã‚‹æ•°å€¤ã‚’表示ã—ã¾ã™
Information Windowを押ã™ã¨é–‹ã‹ã‚Œã‚‹ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã™ã€‚フィッティングã®çµæžœã‚’表示ã—ã¾ã™



コントロールボタン


メニューã®ä¸‹ã®ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’使ã£ã¦, より効果的ã«ã‚°ãƒ©ãƒ•を作æˆã§ãã¾ã™ã€‚ コントロールボタンã§ã¯Legendä½ç½®ã®ãƒžã‚¦ã‚¹ã«ã‚ˆã‚‹å…¥åŠ›ã‚„è©•ä¾¡æ©Ÿèƒ½ãªã©ï¼Œãƒ¡ãƒ‹ãƒ¥ãƒ¼ã«ã¯ãªã„機能も割り当ã¦ã‚‰ã‚Œã¦ã„ã¾ã™ã€‚

次ã®ãƒœã‚¿ãƒ³ã¯ã‚·ãƒ³ã‚°ãƒ«ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ãƒ¢ãƒ¼ãƒ‰ã®å ´åˆã¯è¡¨ç¤ºã•れã¾ã›ã‚“。

Data Window ã‚’é–‹ãã¾ã™
Axis Window ã‚’é–‹ãã¾ã™
Legend Window ã‚’é–‹ãã¾ã™
Merge Window ã‚’é–‹ãã¾ã™
Coodinate Window ã‚’é–‹ãã¾ã™
Information Window ã‚’é–‹ãã¾ã™

データファイルを開ãã¾ã™ã€‚メニューã®[データ]-[追加]-[ファイル]ã¨åŒã˜ã§ã™
グラフã®é–‹ã„ã¦èª­ã¿è¾¼ã¿ã¾ã™ã€‚メニューã®[グラフ]-[é–‹ã]ã¨åŒã˜ã§ã™
グラフをä¿å­˜ã—ã¾ã™ã€‚メニューã®[グラフ]-[ä¿å­˜]ã¨åŒã˜ã§ã™
軸ã®è¨­å®šã‚’クリアã—ã¾ã™ã€‚メニューã®[軸]-[スケールクリア]ã¨åŒã˜ã§ã™
Viewer Window を消去ã—, æ–°ãŸã«ã‚°ãƒ©ãƒ•ã®æç”»ã‚’è¡Œã„ã¾ã™ã€‚ãã®éš›ãƒ‡ãƒ¼ã‚¿ã®é¸æŠžã‚’行ã‚ãšã«æç”»ã‚’行ã„ã¾ã™
グラフをå°åˆ·ã—ã¾ã™ã€‚メニューã®[グラフ]-[å°åˆ·]ã¨åŒã˜ã§ã™
å¤‰æ›æ•°å¼ã‚’複数ã®ãƒ‡ãƒ¼ã‚¿ã«ã¾ãŸãŒã£ã¦å…¥åŠ›ã—ã¾ã™
å„軸㮠min, max, inc ã®è¨­å®šã‚’自動的ã«ä¿å­˜ã•れã¦ã„る履歴ã«å¾“ã£ã¦å…ƒã«æˆ»ã—ã¾ã™

使用å¯èƒ½ãªã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³

次ã®ãƒœã‚¿ãƒ³ã¯ Viewer Window ã§ã®ãƒžã‚¦ã‚¹æ“作モードを設定ã—ã¾ã™ã€‚

軸ã¨å‡¡ä¾‹ã®é¸æŠž, パラメタã®å¤‰æ›´ã‚’ã—ã¾ã™ã€‚
凡例ã®é¸æŠž, パラメタã®å¤‰æ›´ã‚’ã—ã¾ã™ã€‚è»¸ã‚’é¸æŠžã™ã‚‹ã“ã¨ã¯ã§ãã¾ã›ã‚“。
軸ã®é¸æŠž, パラメタã®å¤‰æ›´ã‚’ã—ã¾ã™ã€‚凡例ã®é¸æŠžã‚’ã™ã‚‹ã“ã¨ã¯ã§ãã¾ã›ã‚“。
データ点をクリックã—ã¦ã€ãƒ—ロットパラメタを変更ã—ã¾ã™ã€‚
直線・曲線を作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
矩形を作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
円・楕円を作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
ãƒ‡ãƒ¼ã‚¿ãƒ—ãƒ­ãƒƒãƒˆå½¢å¼ "mark"ã«å¯¾å¿œã™ã‚‹ãƒžãƒ¼ã‚¯ã‚’作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
テキストを作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
ガウス関数, ローレンツ関数, 放物線, 正弦曲線を作æˆã—ã¾ã™ã€‚作æˆã—ãŸæ›²ç·šã¯ãŸã ã¡ã«ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰-曲線ã«å±•é–‹ã•れるã®ã§, 一度作æˆã™ã‚‹ã¨é–¢æ•°ã¨ã—ã¦ã®å¤‰æ›´ã¯ã§ãã¾ã›ã‚“。複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
フレームグラフを作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
方眼グラフを作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
交差グラフを作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
å˜ç‹¬ã®è»¸ã‚’作æˆã—ã¾ã™ã€‚複数作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。
指定ã—ãŸç¯„囲ã«è»¸ã®æœ€å¤§ãƒ»æœ€å°ã‚’トリミングã—ã¾ã™
ãƒžã‚¦ã‚¹ã§æŒ‡å®šã—ãŸç¯„囲内ã®ãƒ‡ãƒ¼ã‚¿ç‚¹ã®å€¤ã‚’表示ã—ã¾ã™ã€‚値ã®è¡¨ç¤ºå¾Œ, ãれらデータ点をマスクã™ã‚‹ã“ã¨ã‚‚ã§ãã¾ã™
グラフã®è¡¨ç¤ºã‚’拡大縮å°ã—ã¾ã™ã€‚ãƒžã‚¦ã‚¹å·¦ãƒœã‚¿ãƒ³ã§æ‹¡å¤§ã€å³ãƒœã‚¿ãƒ³ã§ç¸®å°ã—ã¾ã™ã€‚SHIFTキーを押ã—ãªãŒã‚‰ãƒžã‚¦ã‚¹ãƒœã‚¿ãƒ³ã‚’押ã™ã¨ã€ã‚»ãƒ³ã‚¿ãƒªãƒ³ã‚°ãƒ„ールã«ãªã‚Šã¾ã™



マウスã«ã‚ˆã‚‹æ“作


Data タブ, Axis タブ, å„種 Legend タブ, Merge タブã®ãƒ‘ラメタ一覧ã§ã¯...
  • 左ボタンクリックã§ãƒ•ォーカスã—ã¾ã™ã€‚
  • 左ボタンã®ãƒ€ãƒ–ルクリックã§ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’オープンã—ã¾ã™ã€‚
  • å³ãƒœã‚¿ãƒ³ã§ãƒãƒƒãƒ—アップメニューãŒç¾ã‚Œã€å„種æ“作ãŒè¡Œãˆã¾ã™ã€‚
  • ã„ãã¤ã‹ã®ãƒ‘ラメタã«ã¤ã„ã¦ã¯ã€é¸æŠžã•れã¦ã„る行ã®ã‚«ãƒ©ãƒ ã‚’クリック㙠るã‹ã€ã‚«ãƒ¼ã‚½ãƒ«ã‚’ãã®ã‚«ãƒ©ãƒ ã«ç§»å‹•ã—㦠Shift + Enter ã§ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ã‚’ é–‹ã‹ãšã«ã€ç›´æŽ¥è¨­å®šã®å¤‰æ›´ãŒå‡ºæ¥ã¾ã™ã€‚

グリッド: グラフ上ã§ã¯ï¼Œå‡¡ä¾‹ã‚„è»¸ã®æ–°è¦ä½œæˆ, 移動ã¯ã‚°ãƒªãƒƒãƒ‰ã«æ²¿ã£ã¦è¡Œã‚れã¾ã™ã€‚
  • グリッドã®å¤§ãã•㯠[設定]-[ビューア] ã§è¡Œã„ã¾ã™ã€‚
  • SHIFTキー押下中ã¯ã‚°ãƒªãƒƒãƒ‰ãŒè§£é™¤ã•れã¾ã™ã€‚

オブジェクトã®é¸æŠž
  • グラフ上ã§Legendや軸ã®é¸æŠžã‚’行ã†ã¨ãã«ã¯é¸æŠžã—ãŸã„グラフィックス ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆã«æœ‰ã£ãŸãƒžã‚¦ã‚¹ãƒ¢ãƒ¼ãƒ‰ã‚’é¸ã³(コントロールボタン ã®ã„ãšã‚Œã‹ã‚’é¸ã³ã¾ã™)ã€ãƒžã‚¦ã‚¹ã§ã‚¯ãƒªãƒƒã‚¯ã™ã‚‹ã‹ã€å›²ã‚€ã‚ˆã†ã«ã—ã¦é¸æŠžã—ã¾ã™ã€‚
  • グラフ上ã§Legendや軸ã®é¸æŠžã‚’行ã†ã¨ãã«ã€ãれらãŒè¾¼ã¿åˆã£ã¦ã„ã¦ãƒžã‚¦ã‚¹ ã§ã®å€‹åˆ¥é¸æŠžãŒå›°é›£ãªæ™‚ã«ã¯ã€å„種 Legend タブã€Axis タブã§é¸æŠžã—ãŸã„ オブジェクトをé¸ã³[Space]を押ã—ã¾ã™(ã‚ã‚‹ã„ã¯ãƒãƒƒãƒ—アップメニューを出 ã—ã¦"Focus"メニューをé¸ã³ã¾ã™)。ã™ã‚‹ã¨ã€å¯¾å¿œã™ã‚‹ã‚°ãƒ©ãƒ•ィックスオブジェ クトãŒã‚°ãƒ©ãƒ•上ã§é¸æŠžçŠ¶æ…‹ã«ãªã‚Šã¾ã™ã€‚SHIFT キーを押ã—ãªãŒã‚‰ [SPACE] を押ã™ã“ã¨ã§è¤‡æ•°ã®ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆã‚’é¸æŠžçŠ¶æ…‹ã«å‡ºæ¥ã¾ã™ã€‚

複数点ã‹ã‚‰ãªã‚‹å‡¡ä¾‹ã®ä½œæˆ
  • レジェンド㮠path ã®ä½œæˆï¼š 複数ã®ç‚¹ã‚’ãƒžã‚¦ã‚¹ã§æŒ‡å®šã—ã¾ã™ã€‚
  • 作æˆã‚’終了: 左ボタンをダブルクリックã—ã¾ã™ã€‚
  • ã²ã¨ã¤å‰ã®ç‚¹ã®å…¥åŠ›ã«æˆ»ã‚‹ï¼š å³ãƒœã‚¿ãƒ³ã‚’クリックã—ã¾ã™ã€‚
  • 凡例ã®ä½œæˆå¾Œã¯ãƒžã‚¦ã‚¹ãƒ¢ãƒ¼ãƒ‰ãŒç›´å‰ã«é¸æŠžã•れã¦ã„ãŸã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆé¸æŠžãƒ¢ãƒ¼ ドã«ãªã‚Šã¾ã™ã€‚複数ã®å‡¡ä¾‹ã‚’一度ã«ä½œæˆã—ãŸã„å ´åˆã¯ SHIFT キーを押ã—㪠ãŒã‚‰ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’é¸æŠžã™ã‚‹ã“ã¨ã§ã€å‡¡ä¾‹ã®ä½œæˆå¾Œã‚‚マウスモード ãŒå¤‰ã‚らãªããªã‚Šã¾ã™ã€‚



数値パラメタ

ã„ãã¤ã‹ã®ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®æ•°å€¤å…¥åŠ›ã§ã¯æ•°å¼ã‚’用ã„ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

例ãˆã°è»¸ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œå¢—分ã€ã« PIを入力ã™ã‚Œã° 3.141592653589793e+00 ãŒå…¥åŠ›ã•れã¾ã™ã€‚




ngraph-gtk-6.08.00/doc/html/ja/tutorial/0000755000175000017500000000000013375640233014704 500000000000000ngraph-gtk-6.08.00/doc/html/ja/tutorial/fdialog2.png0000644000175000017500000004137513070106167017026 00000000000000‰PNG  IHDRôô¬/ þbKGDùC» IDATxÚíwx\ÅÕÆ÷Þí’lUK¶d˽÷*ã˜âÐlÀ„„H0„ 1%„H¡BI(¡Ûôæ‚Û€q•{¯rQßzÛ|¬ÚªK–l•yŸgigçÖ™wN™3s”’â"!„@B !!Ñ~á°,‹-›6rðÀ~Âáˆ|#í™Ð[6mÄï÷3uúix¼^ùF$$Ú1Ôýûö2bÔhIf ‰Ž@èp8ŒW’YB¢c¨Üò´]X¶À¶ • ªª ©Š$t{CX7ysq.+7í'¿8$_H§§2¤$úÈÚ“ OŠÛ©IB·!x}Q.&*·_{šC6“˜¦Ég+sykÉF.;k„$tû!4|¹a?½þz§Ç玎ƶˆªàªU½ä÷Îõݶ°Çá¿o}VgßÑ.¾pö¼AC†Jµ!Ø^_œËŒœáôHr—ÙѰvË~^þ`áˆAŸÌTù½|å£o±mAZRn—ƱRo6ìàŒñýjWÍÿû¯¿‹YÍ‘,jcΰ›»€ûx1»ûøhù&¦íGœ×-_NgS³-›í{²vë>.9k¹ûJxö¥ùÝm3k­¯ÊWÖ6 ­Lå‚M»òð¸œòÅtB84•¾=S),sŒªªŠaYu×—¯¬mBÓ¢c­¢(\4c4ªªDãí%:œšÊMߊ%˜¦]gÝ$¡¦a vè÷M-#° +½«ìÕ`¥Ì$kB‡#f›z`½4—_ýð:®úþ=|ßþçmª†R¶îµW·í¡Ô4eèK+¶ó_]F4ÀHÁ´ZœÐ6Ór~×*7o™:!«J÷6–e5øùæg÷rî¼gù÷þǸ4önM³Ll ËÄ0ŒŠO$‰ù^QÏ61êQmNˆ„&jC8R\û ¦ëMú´ ™m› ºŸÝaK2¯*q7Š¢€B½ý²Y6t¸hñCêì$¶-ðxšê‘ªÌo>t›/zŽ_ŽI xäKÞûüpƒGoÙaN¼ŠêH!ѱ¿J‡3YòÄ-¬üKî='›}ï<¼{*~ÿøO8ëü3+¾÷¹äA~yn&{?ø÷oœÄßžP»V#´#:ÖªŠÂœ3ÇÔø,‹sÏ=·ÑïÖ2‹—,jB¿ùÏ7™{Ûþøc Ä /¼€U­ÝLÓäùçŸgðàÁ,Z´¨:ª½™-eCÛf„'®{˜Ÿ?¿”/ßÉo6ôá?øcz&àph¨ŠBèÈ»ÄeΪ1’[¦Â…ûXôþBÞ]´ŠäQ3ù÷§›)yãÖã~Y¹¯íãÂ9±ÃÊß®äû/Ÿºœ=çzV^±Îʪ(ëš”ØÚ>ZtÞYQ`Σëí$«_•a_ŠÇ¡Æ¼sÿ±µÜ4û7<üþÄUó4ÕIærÅj$¶aÑo.%ã‘’îTk¸CGеÿE’ÉUàñxÈÏÏçæ›oFÁÕW_¦id¾õÖ[ñx<1{¨ŠÂÍ—NÅ*‹ën±À’/ž¸† ç=Ç}½»@ï'x`õ‡<õèüÎÀ-·ÿ˜éƒSÙþïE ¹éšX©¾ý ~; {”àIÉæ¬ó.äOÿ¼Ÿªðô·¿cóØÞ¡|‘Kèw÷Dx:ùø2Þ”Y„÷ÜT†Ç¾¿êÝVoxMSAQPPȬoZØû^æÒ?fóæOrÐTÛ4(ص˜›/˜ï¾¸ït«¡ÖÍœ9³ ÷¢ñÉ'ŸÄ˜J›þ÷sþ¾ÏëU§9µõïŸ2ñ§·J—Ԋ´iÓ˜?>·Ür ·Ür W\qÿùϸõÖ[q»Ý<óÌ3L™2¥† íq»@´ „¦ûm¼tùøŠ¯™cfòÈ_gRº{%y|.O÷Â\v˜ÖŪ`¾c¸éž™dwëÒ zŒÍŽ7~ˆçº_Õøi—•†÷8=ÔŠê%ÍÚuÂß¡©Ø–E(dáÒ\túð:뎺åߌ¹ðžžþ× ‰gé à×/îâáWÞdj–—H$\ã˜>x¿I÷s!H2›·¾;±ÖsèÁcüâU›ç~‘RgΊK.™ƒiüèG?ææ›oféÒ¥¼øâ‹¸ÝnžzêI.ºè˜wf Á3¯~É/‚mÛõ–4‰ÐÓ.Ÿ^kyBïIüüO/°ò×gqgⓌUÏœqýÉŽ£UÈì?ò7øqZë…‹v6„¨5 Ä2Â,ùÃ5$þäïôp©2dµ\vÙe?þñ+Èüä“OrÉ%—Ôx_B|'BØ4XÒ±ÜË4Ù·ì¯ÜøN_>Xvæ‰p/`™¥û—ñƒ9¿äæ×Þ!Ë]ÓcxJ\ [ƒ&ƒ|ÍL3¸•’¸É±Òçx¹ËKàüéC$…;n8Ïÿu:ç<žÀK?¾§Ê '’°- CçÓç~ÆïöÏâÓ_ ’d®—Ô—ât:øàƒ8ï¼ó¸ð k}_ pÝ㣃gk–D7æ·±m3|Œ×žz˜'Wzxuñ|z¸´VyxÛ¶Ë®)0xóOóÌ{yüòïqvÿÚUù™³zñô¶Bþ<*­Ù×-Úö Ù³®Ž);{ôwX²iQ«¢ º§Ä7‚ Ý&ÜÁYgpׂ3y|v?Z;&Ú&aÛØÂbÛ—ïñìüçÐ&ßÂGOÏB©C‚KTââ‹/æâ‹/®àU]†u¼Š¢´d`‰À0LŠóv³aíj>_ò +·8ëš[ùâîSh•k›‹« ß|ö!ssùæë¯9Hàì˯ãӧ⪧Ó¹c.‹¯ÿkÁÕÔ5sU¯¤Þ¿ˆ¹{¤Æ{h]ýv碨›·—mfÖô!1øùÎÃÿãÕißå«Ó>fR×ÖÓ"l+ÈK–±÷rׯeÇÁbz=‹›þòC»yÊ#IØy×BðüÛßòƒ9“°l³åK,ý0?¸é^º¤ödððQœó#ü¢êqÝìÕW_Õ¨zöä“6t:?¿ævztiÜÚ`_ê%ü,q2¯í½€K³»ÖjK/Ù´¸NZ•ì}ƒ?wù)_¥yyLË!XåÎ;VÚhÕUs¥ò§oá]¥L•ÜzƒŽ€ÍûòÉê3šο†ÞÝâc48‰–|ׯ×Y–®ªþÀ’¿c‰ÚÁ÷/ú3.ø#îÆëV$;fßÍÞü;¼'vÙxùŽ%÷Þ8‹ž]•’™– {vg—ÔÀ®|‹¿¿²¸ÎK:üo?æ¿p%/~~ˆÎÈjôq‡>—Ëþûì 's¹¤rÇ›Œä8)õ:9‚aÛÙ²%íÞ”n8£iÇdqY'ñž5M†úÙðþò­œ7e ìÕØ†~áýµÜpá8„Ý’%'N³PU„-Ø-`™VŶD̆¶m|'Ø¥åK$N ¡5ò‰ÇÓÇGW2E ªª¢”ÙÚò{ÇþnY6N‡Æg/ ,qÔX"÷ån‹#²€Å«v1fX6 .›Äx7 X¸l++sÑ·S“ß;Á÷U›Ñ»{WÜ.(ÖU>ûz3³ë˜Æ”ûr·E›É<ô%\zÞd2º(¸Õš#²(#~UÔH"ëuœz†­r¸Tðô‹Ÿð—Ÿœ/UîöEaýÓùòÛ-œ2vH4À¤ò× ·5°(Ç’õ:v=[˜,_µÓ'ô—6tû"´ÂœÓ‡óú§xê…) D¢ö‘ªâqG›ÌéÐp9¢ÁãÖÐ…]‡Šd½\OQF èÁE§ Û’„nW¤6—Ÿ=Š«Î[±sT±zY•2UQe½\À¶lLÓº=Â4zOB¢:äĦ„„$´„„„$´„„„$´„„„$´„„$´„„Dû…œ¶jÃ(ß³«-AQ”Š-’Єa¬]½šÝ{v Ú“‰‹‹£wvoFƒæ]GZ¢QB°fõjR.ºx]º&¶‰û***äóÏ–²vÍÆŽ/JÚÐÅ®];˜~êém†Ì‰‰IäLžB^^žl Ih‰&길Üm/Qº/.Ž@Ð/›GZ¢)*w$Æét¶¹{ÓuÇ#IÚÐMi5­lË™ÚÇÜÖö4וAUUl[î@* -Ñxe[QÐT˲QÕæ‘Dz,lÛ®ALUUQUµÁŒ%uM—)Š‚]ÏžV’еGÕêÍaT‘ý~?¯¿þ: .dݺu¢( IIIŒ=šY³fqÑE×èTDU˶dIBK48 ¢‰„ÖuW_}•ûî»={öÔø½°°;wòÆoðàƒòÈ#0gÎM˜SVUÛ’„n³ýF¾‚¶ ­‰: 2wî\®¾úêZÉ\;wîäÊ+¯ä®»î"‰4ɰl©rK ÝB– š¥ƒ7ŒªªØ¢qÄ1 ƒ;¿þõ¯Mº†mÛ<ñÄض͟þô§F9ÚE•º#Hh]×›ôi-lü˃ì 7­CÙ¦YÅ3«G"1ßk ¶I$¢Ç|¯/Év«HhMmT·mÛ¼ñÆM&sÕãçÏŸÏÂ… ?ÐH Ýþ%ôÅs.i¬ E˜|ôÑû­!ŸYðü~tË/Ðõ𤶅Àãv× ç’'naåà_rï9ÙLÉîÉ©/®â÷3zÖ"é{ß˸«>ãXÞJö~ð;îß8‰¿ß9‡zbtƒP8ŒÓéjÔ~¿Ÿ»ï¾û¸®eš&wÝu3gÎÄë¦Î­ëº‘HWÎC·{B¿óvãFp[ÏgÊøŸ·ÊÍZ‘Cü³4‰¯®¸¬V²/^²œâÂÃ1¥û=Äíy»ŒÌO/÷ßͱSþCš'ÖËk…r÷ýzU)Ï>÷çÜœ{ó>ÀÃgõj}³¢,°Äår5XoÁ‚²™ÂîÝ»yûí·¹ôÒKÔÔd`Ig±¡…ͦÿÞLÏ»Ó*7»ïã{ýûñêŽk±­KIé>%vp1ò¹õÎ-¼¼z^¬¨ºyø©±\õ—U¼÷³‰Uì›oþôŒŸÿ{/¼ 昜;_âñ1W¿j)NµŠú®ãr»ZÞÒ4lÛBÓõªËU•£z/\¸°ABËÀ’bCW4|AÉÁOùþ_Óø×ýZ^:ëEÌûUO]P»„4‚›pu™Sv`É„o}€8­¦šœ2ê.¾»ê–„*ÕÜüÏùÙšK¹kdrMgσ?Ô™»ä`LùiCNoñg-,i qV¯^Ýb×m̹TU•%‰ÐkÞzƒHu‘° ®ç–‹å·þ€¯šy¼5a™,úí¤?ô4ÝœµßrèÈBºö¿0¦låoWòý9u«ÈWÿõîûÑ«XB „É‹?ü%?{eõ³ç\ÏÊß®Œ)ëšÔ:«¡X"„àðáÃ-¦æ:t¨Qƒ ,é@*·8ð*Wü¥'¯Þ1 MQ°-“’}Ÿsó¿æ’½ÆÙ¾ÇÌš}a“®ñÁûïÅ|ßúÚýü)t3ïž[w ö­ÿXÌø;oŽ){wO„§“ë¶÷Ü]§ñ‡‘ðÔ†s¹ÜzžWÆ>·]ÝuÖ÷¦Ì"¼ç6 2¹ßû«Þm‘VUˆ„C@íRÚáˆoÍ Òù®]S2 9mÕ‘=îÇ/1ႉ<7ã}nÚ…Ï^úý{½öÓ2ãEЦ¢Û° yû²‰õ8Ë ¹ÿuÁßîïS¾ËJÃÛ€Wzì/ðø³Mæ¥Ew4 5½¤Y»NHÔ–ÔçåV…ÌÌL¶lÙÒ"dÎÌÌŒ‘ØuT”%‰Ð q×ÿžçüœø8ÕOŸ nåî#^k½éœ¤áë±é –üþJºþädºc=ÖñPoŠêLæ/Mà#Î"ÙÙ"B¦¼sÿöH 5¼ÅŸWÂá0‡£A•Ûívóë_ÿšï~÷»˜¦Ù¬ë¹Ýn~øá˜¥”uGŠÉÀ’Khՙ“¯ÞÆ‚]~rF'·ÚM*(lÚ[@Vï1|ÿ¼ké“Þ8;Ö—z ?KœÌk{/àÒì®¶ô’M‹<6¶Ž dïü¹ËOù*Í[O½¶¡-«ÁõÊŠ¢0kÖ,î¾ûn}ôQ¬&Ú·N§“{ï½—sÎ9§Æ Rûõ%•Ð]û_Áµ­nx¸ñº+›uèåÏþ—ï_ôKN]ðG2ÜZ³ÎaEó‹›Þá…7ÿ~B¥2°ÄnÔ (UUùÕ¯~E0äÉ'ŸÄ4Í%»¢(¸\.æÎË}÷ÝW«–P×q2°¤ÚÐífÄòöcþ Wòî燚}ŽCŸ¿Ëeÿ}–Þ·Ú4úY¿S¬º¤}ì±Çx饗0`N§MÓbfŠ¢ i.—‹!C†ð¿ÿýG}´v- N§˜ ,éк=À›’à g4ÿø¬3n ëD´jtݱhÂn"Š¢0gÎÎ;ï<.\ȇ~È·ß~ËîÝ»èÓ§ãÇgæÌ™œþù¸Ýîzíø:Un9m% -Ñ4hª†hfn+ÇÃ¥—^ÚàB‹úP÷ue`‰$´D³$´U¡[;‰]ý6´”Ð’ÐM“КŠ-D“bÇŽ=)÷%%’ÐMF8ÆépÔê;™0 ·Ç-HZ¢)ˆ'Ò¥k—6sOB Ý@Uäf±’ÐMB÷ÌLÖ­[ÃèÑc+¦‰ââ*W³Ù¶cˆ]&Í[«^À_ʆõë8xˆl Ih‰ÆBQFËêo¿eñ¢Oðú|¨ŠB~~>u˜9ÊÙiš†£lÙát¶Z=EQHII!+«'£ÇŒ‘Ž1Ih‰&ê·L˜0‘œÉ“+<ÎUUÝw™ˆ-k­z¶°±-Ó4dûHBK4¦iHòH4 Ò»!!! -!!! -!!! -!!! -!! -!!Ñ~!§­Ú0„­¾ªJ¢mBQ”fíæ* ÝFaš&Û·nåðáC„ÃaùB: ‘·ÇCFFúØàžr’ÐíD2oߺ…P(Ä”i§/_J'BÀïgÝÚ5ìØ¶µÉqó’Ðmy‡0õÔx}>¹þ¸“Áëó1xÈ0Ö­ùVªÜ†aâp:›¼-¯DQ½U°›±£ôr·Q¨ªÚæ678í¯¨ÍÒ̤„n³„V½/·D”Њ" ݱTÅ6RFKB·KB ÝóY¢Ü†R¶hj·°£‹¢ªÈ&:q„ÍH9äh~# ”*ÉÔm!P`¤mX¨ÎÚæÕ,d¤È$hUmèúvý–Qˆj¸¼NBA!«¾^Ù Ú8~bNó4Û"oë׺e@yªb!ÜÈQ5ƒžéI1}¬£™q J³Â~Mèàþµä¬ìz‰Ÿ=Ÿ-C”©€ÅçÅŽ Ièí1’á=ã@X¬]±ñLšžˆç—ì½èçv×cÓÆdÖÈ+VçuEó‡Žmb—èKN¯V˜ˆi‚‚kÙTìeÌèI¤Ä{(ç€mú9¸_Ç¡©˜–7}0½ý+Ø^Ô…IícOé’’bÜO£u¤œ:¢É–^Ê’Å»ðÅÅðû«þ¶‚ªÕÛ«ðdÂò¥‹HŽ‹'{ä0•ñåã'æßà€ šäL±Ì0»sW£§ ed·$T#@ÄŠ^Ó“ÑÇîí|õõ^² ¢[¢§VSOØ&d¦{Û%¡ƒÁ ñ ]ZÐF¨„IS¿ƒÇÕÒ/^EÆŒ QõødC!§ŽH® ô' ñ8U ìbuAq˜e›mŽJÆ©Øl`Yñ–êpÄ5›ør#ŽõëKÖXÜèÍèõŒÀ.Ör2cÆXâœ6¡P°Š¡’’á‹ÚøefHbßñìX² Μ UÒ¡¶Õ©!µ éd²VÕªŽmù’ä¡“PˆµÇ4w=z:p8ÔzÉ)>Ä‘ä LËŒÃ2M"ÁPìuþóŠÚBÈßÇÖ­‡È2Ž¡Y)(f˜°%ª8 Ýôè;œÌ~av­_ËÚC) Ü—ªÄd‘ýìÉO¤wf†yâ#íÊÖԵȢ¡ß£þ©ÖvŠ©Á²ŒØ&Û¬P¹…B!‚e*·0Bhjttô¦ §Ç®¥¬[ý'OçðНé–:‰¸¬L“YƒÐ˿ΧܟÊ_‹Ýgñ^¿RCÈ_¿¬qgïøýáZ;³Qu=ÅÁÀÞëŠlF%T¾ª/?ùŒ©gŸÖ& -lÑlQ`±¹8ƒSG%c„ü5¤½° t«~’ù„quÓ°‚~ÄMJú^ß TÞ±ÃŇٹ}+V|/†O™FRœ #@¯•Œ!\dÏ!+pŒ8Ÿ‡H(\Ùý…À¿?i½ûàv(èÆ‰÷Ÿ;z„ ë×1`à`zdfÆVÁýûÙ¾m #FŽ"%5­V•»N[E,¾«J8åz%Æ“Ð3ÌV]Ãòcß®aÓ®­tÓ[!¡ ·Ò+'ôpÌxu°ÄdlJF°ñÂ×£7ÇVå㙞F¨¬£8Nââ ”úÛ¡•èÌA3·Œ WífäÔéx4¸yR*"£·Û6*ÚÓ ífÍú#:>R˜Ï„³ÏÅ¥Äö!ÀÒC9Ä‘übœ]ºqð˜ŸÙ§BµuB? ŽÂBó%¡vµAÂdçc‡ÇcDJONûi†®³qÃ:@Ð#3+:%öïcã†õ¨ªŠZ×jª1]îE.wŠUýލö½üã›6ÄðW¸Š Çâ0Œòs‹×/ÍéÀi毷1tâ@@0ÐYLÐŽ.%;´àÁÅ6L7^‡B8ÔøÑWsuÇ ¬Csg@¡'>¥MFX*ŠJs'­l3Âöo¿!yÔTÒ»xù›7X ÛdW0éqNŒ@°Bv8¼}˜3¯×Ù ûÁ¤$&á/.D 0üر'ŸpÄDsùHMïÁȉÃq;Tön]‡Ë©Q\nâóê1ŽRÿÁõÐo8>§M |r7))™a#F’»~7¬ {LØ_Aæa#F’””\§S´Õ ½jùR(s‚EJüìû|Ytj¥Ì)¶¼ÔfHŒ.ûRi âÆòv#òå·¤ŒÆ¡cЫp›·¶@u÷E1óÆM$Ý.ä›5ùŒÍ胊E@xðhªÆ:̦ÎÓ*nQ ª¨Ôǃ~Û#´ª¢‡#ØÎ¦4ªÀ²tölX‹?â"£‹Pq!a£ÒY‡×¡ôè‡K1(GªË^¡ˆf8 õ` mŽD·ÕxzôíAJ¢MQ¶…®).­$e$i¶6h†òY¿[eÂÔ¯2à IDATT¬@1‘ˆyÒÚ0%5AC†²eÓFrׯ#ÿØ1òDUU JrJjÏjFë–L˜r:-z‘ÃKV‘qÚ„ B’[ÈÔɶÕ'¹…•ÒôÐ:òÒ¦d™ÂfíÚÜ5m$ûzÑŒ},Ùì¥KâP¶­ØLGöøÉø<á80Qj¡mfW›ŠÂ p4Íu`ã@´ƒ5)ÑÀ’¦ÐÔ‹Ù±q]úŽeX†ƒµ_|AdøPº69D`é…lÙi1â´LDÈߌñÀ¦xW.)ƒÆã²CUTQ/nEò—TþÍrÿÔ´ÅÍP›ÖïeÀ„It³)*0Oz;¦gt`˦1dр†Ö¼À’&ÛÐåSN±`ÝN1ˆ:ÅÂG#tëåÃV@Q}tÂãéI©¿˜Ë73"g:{×èŒîºž ®±ŒJî‚ €d‡A‰%jÜhòˆä._ÏÀ©ƒJí \Ý{(¬R GJÌÑv½Ü¶¢á&¶M¨ðÛw=|"=3’0…ôчíë6¢ BB#I-„.`˺dŽÎ¡[•âcz“ÌaÛíb§‘IN÷T"%…±9a`ÖÒ^µýß8o²Mñá=ì>¢ßø ôL‹Ç_PØf‚‰ÊÉ[ŸOJj*iÝÒ|FEi^î&õäªÑXUmh»,r'æ{”úHô8*&NRµBtönX‰6p<© ^,Û"yäd;W‘ï/Á,{àÔ ÛŠô7êðe3¦§Îçk¶Q6b®m~òö׌\3ü;ñftQ9ò­Xôy۔ЊҘ°L#ÀþíØU(1i"ÙÝ».) ¤Û(Ž8úìÍu›Ô¥v—y™…mcAïÙκM‡ÈàžÉ„ ‹°DcH=‡*aÿŽ ì.ñ0~ä âÕ ~£%§*#õ°Ÿ#v±ií Œ8Æ2‰ìÔx‚…èvÛrŒtKÏ`ðÐa¤uKo¬ÑÕº%Õmh݈±¡CÁÚmh!t{z3L«Œ4Ëœ8†õ_|†š9†¡™IØ!?BEõ0jb_V,[Ǹ©#ñª* ýú³vÍ~FON¯.(GbOÎgçÖõì4š¢`Ù6šæ!­÷œN ð*:ÂÑMGé7n<¢Z¾(_B<Á6æå.))ÆårÕÛ¨–`ãÆ=ôè3”AYi8í0Åù…ÄÐG‹cÀˆ,¶¬ÛÊÐqƒkœ¯¤àÁ@)%%%è–ƒ”=™<¬'ñna~YOÝý„ÃBA?%Å%Xª‡îÙÃÔ=§¡ (Ø(uºªFUï3ëylÝr[بnɩݑ3‚Ÿ+ 0¿´C¬P …B­X‚¢ÆØÐQ“ZA訚¨TØÐ‹6–3£G¥ãzåba:8‡ÌÔv}¹˜º…–:8Ⳙ0Ââˆå$[µÀE?ÇRÝH©EŸpuIaè˜ \nWT•DÝãB`è•3p€ÎÌèêA¯bžræô6¹‚HUÕZ͆®:â1jIIq„üÅê˜TV]]2ª+‰)‰‹%|$¬ãMÊ ³ÿpâ½nTÅ&QiBŽäÁá‰#!¹;= #ÎíB&¡` £i6`zF÷¥’æêÆ‘}HLô¢¶mbèJ üt¤š¢ÍÞŠºë€i16tCÈéíªð,Ç{B!“”‰#¢âíFªâÄ è>z½¼q8UFtºÂ”M/‡‡°Ñ-Aæ¨q¬û*—ÄœahµzS ÂÁº³4 +ÌæµyŒËÉÁE„@µNÓÖæ +mÛ( íú( Š>¡E%5ºHZx|>° üÅÕëꎛ^}ûŸ€°-L3Bi±Ÿæh»Š¢0`Ð`B¡`ÃV¢S\êÐkÅOÈŽ%v¤i¿|¡F4²¨Le*w¢ ³¬EŒP€êtf½BˆgøØ-tï¢4¹!#yô7–ä¡@°}4hY`‰Ò‚ŽaÕîõ ÇuÞÒÒ’»Ç⢢Ƈ #j7jÙñ–Ht ݶ &z3§«Fµ B«*ÂU’ºS¢™;–ÈèÚ¬Ê-%tg‡ÜÆ·CZ“y­:uûË]?;š†i˜8Nù2:!"‘N—Kº£ µ[{÷ì¢Oß~h «ê¦ U²i¸Ü•;°aËz žièìß·ìÞ}$¡;†?D¡ÿÀÁlÛ²™õk×T¨ÞÑõ³Q+Éáp **%%ÅÇhšCÖëõ\Niéô00f„nǶÍà!Ã6bdµÊÿ”‘\Q«ü$d½PO °-Ó4¤„îH0M£Y*щiòHHHBKHHHBKHHHBKHHHBKHHBKHH´[Èi«6Œò½ºÚêJé"! -˜¦Éö­[9|øáp¸íp{ƒ‡ cÝšoeÃIBKÔÃ0q8X–Õ.îWQ›· _¢e!½ÜmµaTÚÑÍÝ¥RBJèNBh¥Í¦é©UB7sS; IèNEQ±…Ýnv“„–„–¨×&U£»>žDµ[ˆò #´°åhÒ†>AhoÒ#šN6ºô½1S×+þ·ÌJM»ÑÇVÿX¶@‹#…¥ØB`‹†¡™éO%N¡c³K6ôikøð½wš)¥ì!Y×óŠ*b­%Ò˜ªªÍ&DƒaÛ\±„RËÛ¦dÛjòÂØ¶UýSyNaÕüݲ,V­/À¶ ì’Cl\¿ž½y~„]ÿ½(eýC¢¨Ü¶YÈ7ßliT]˲™Ÿ§ÞeòÆk ñÅÅlbΤ†²-ÖkÜ5Åàk$BÇ6±Kô%§W +LÄ´QT“§ŠmÖLáa„ƒxÓÓÛ¿‚Å]éŸèjöµKJŠq{< ‰ t4OŸÁ¸Ð)-ÙJ°ç$fŒíÉ‚W^ââK/¯i† ‹@ „n÷aò©ÙhUÞ›‚5Kö1þ´ìŠÔÀBTl+L(T»Z ›•þTâd:Å„I0ào@Z” j]šÓ+l‹›7Ó}È0´Zxi[µì‡À¸3ûá¨R/’¿wjÏŒòl³ «$:ë×—2þ¬±¸Ñ ÆäÓ²ëÍ’˜Øw<;—~ 3r ŠÚ”i(UUU_Ø‚]›Ž2ôô©Ø‘0ûÖbÄ)#Pôè`ªiJŠ‹ê !ü~³RÎ*à³cØé„BæùÉìžÐ€¯ñ…D;rŠÙúaTOte†Ù±î+"©}ñx½µv¼¯>ÛT©Ò÷³Çˆ½õðѽ(Zýq˶]ûÃQ»·•L¡üµØ}†ïÕEš˜PKq0 Û`}‰]1x!Xþé²&9Å„mW¬¸ªýc*ØÄþIj‚“ÂC9š<œ”7á²{¶m«Ì6¶, Û®<6Rº™åË–³êë¯Xõõ×|»ú ˆsçcÍÜaFòØuDÇáPë½9mÕþ$t#<|˜øÞÂhXZ A ÿÛw%sȲҺ‚ªÕBëí9€éƒ#Á׳;y{à èF/S Í€Õé²êNJ—ìƒ{·°ÃÂéíBJZ:éiI¨ª‚1ê~áÖBzå$ƒ®!wlÛŽ:‰*n¯æÒAo÷lŽ­ÎÇ3-P™tw:Ä%Ä7*uy:ÙúF\ÛŠ°m{´ Xäæ–0öÔÑ8Ì a}Ç_|¶³Ü` §‚Q_“ÊyèHh!صÃÏ 3±u½V#¢S"EG°oßA ÕLNÍÉÁçv`„ƒ˜uÌe&öëBn‘Å8<ý°÷ïÅ9¬?zYêB3…nJýª[V_âSºãИÁ"òî#÷ÛmOWÒ»w§[jbEBù£A‹Ñ ŒPi57Ìêo¾Á¬Ò»Õðáƒbêi® ¬Àz4w˜6Š¢0ñ´S=WÛP:Y!lŽl^EÒðIä}¶ Eu2lâxã„JÃeçP˜vÚÕ˜hE‚„ C¬€•ÆvKwJ:›è‘f±ã ñû ‡KtâIBw(B GÖS”<‚‰ N"þP ûûàž=¡6 ©™ ™x*ßì ï‚@°þDìΤޔl,Æ56ž°¥1 ±œˆX³”ü´d4Õ¤!Eß2t,CÕE·^éÑwv¸ˆ{÷°Ç›@߸(¥ƒGƒP5µ\Q=Œ›˜ƒU}¿l!b×-+náÕ UÒÙ7ÖQ¨¨*z8‚í¬$–YÄ>­?㓺PnŒÅ ¸°ÛŠ5' òkBª‰° "!ÀT-,ÛÀéèÛv Á9`(n‡NQqýk² Ã%…ÐBŒÀ!Ö䆘pF?43DXÔT›] ) í;¯Û¢€m#¶·ÁkhÎt¦Žv ¹€IÆè‘èVtCñ® 쓃ôhJha[ºª‡î}‡âp:QÍKàÀD©SBÚ„C¡†ý 8ÍtSDKêyŽDFöuâµü5œ‡±æ#9E-{÷%(q0£æƒ"naGëd9v±úh6&¥cùKÀ¶ªV§CQ‘%íŸÐåvpÉálÚ^İé“IÓùkÍ´”DªE$¬7+¢Q&*<ÒƒAô¢Ýìd0ââ‰èæ?‹maD*;d²Ã ÄÍ~AÂ*Åp¤Ä MórkÛBˆzî@èúE¬IS­m–-YŒ^nþ( ñ½†Ò7ɉ¥çáŠOeåŠoЭ¨ó­k¿h–…i–r8âÀŒK!Þ¥SP`àß³ æ82œj]&´T¹Û#¡Ë#§l#Hþ‘<<Œ3)‹‰§M¡‹×I8¤¾f5ÍãÅ£V l“£{·r ÏØ‘鸈jA/5ÃǶ"a.hN75ü»ñfô®ðö !X¹ø &Ÿ1­q„V”ãžR…SgœI$‰mƒ@·‘Ùo,½Ó3ÁçÎå …PÁn¶­ÝFƨ‰°m%Sðá‚)CÒðF Õª:ÈÀ’vIèâMëØ4Ð\>’RÓ9y(ñ^ÂÔ úMî„M –ŸÃ‡ŽQTX@P‡Ô¬L”†Sµ …ÍUئ ¡_Ö®ÙÏèÉéDª¨±;àØ–£ô7QÍÖö%Äl„—»¤¤—ËÕ IªKåÚþ¯nC as Àˈ1^‚þcD CaQrd?{ùÉ1ž‰ùvÅ6FŽîÅ!#™^=dת]…B!XÒ 8t4<>\ª"š!/ð7[štëÚøh*! „3>CûÒ%Þƒª€©Gé KýÓÏ<»I÷¥¹³èçXÊA£)U8|Ê™Ó<Ö `—s §wñ ‡üÒròÓ½zJUÕFGÎÕ5ÈÔU.¬¬ô>ĹMŠJ¢Oøèv ŒdÆä £KœQ¦–Èþ:¹ë¾ÅÛ{8>U§PP§Ê-KÚ© m…ƒ„Zèú§{1­FvrGÝ34œ#jÒ"—Ë…¿´¤I÷–9jë¾Ê%1gUãÞê›GV˜Íkó;9Õî1è4žÐ¶Ò@Ä¢(L™~Z I^Wyô=&2<Û…ôWèIÞnƒèïíŠGÑ)̯  Ý1¾7‰]â0ý…õ˜rÇ’vïk)DÌ&taÕàÐHõ´Qæ€Ïð±=8Z"èÞ¥q6m¤ ãÆ’ç"ÔÀT\ý„Ž–(¼ç¼C›T.D„‚jã’,¢¶ÙfK,Ѐ‘!b’Ðíš+‰ ·§f£7bàñ¤õÆçpa„BO÷n(°¤­A–HB·½ áܶ©÷%UEX¡¶RËKÚÆÀ*_Amµ}IhÛøJBKÔCh­]Íë–ïR*!Un‰ÚÆ¡aN§³í[$B‰DpºÜ²á$¡%jCj·nìݳ›Þ}ûUÌE[¦Eù\¯Ëí®B(;ºWØIªgšû÷í#»woÙp’ÐÕ¡( ý b›½…ÜõëP¥"HÄáÐP•’²½ÑEAs8*Ôô]O¼¾8R»¥ÓoÀ@lKÚÑ’Ð5ÕXÛfð¡ 1¢¬ üOôU©tÄ8ÏNB=!D…¤–„–¨¦iH’H4 ÒË-!! -!!! -!!! -!!! -!! -!!Ñ~!§­Ú0lËj0ÇDÃ(Ìiê6T’Ð-]×Y·f {÷ímrÒ?‰XøââÈî•ͨ1cp8’Ð'BÖ¬^M(`ö…Ñ¥k¢|)Ç¢¢"¾X¶”ukÖ0vüxiCKœxìÞ½“é§ž.ÉÜHLLdRÎ)äååuøg•„n£Z× ¼¾8ù2ZN— Ó2%¡%N<4UE¹a@‹utU‰. íà6tÛdtYÂ÷Öónûýþ6ùèñññ­Dh «l‘ÔLB š–óB¢ÉœV5,Ëj•)+Ó4éÚµkÛëŒGlÏ–|Ÿ b­v³Tn3˜GPîðØÊ*¢›T^âøÞg'IÐ BÛ|1ïþ¹ãáp¸â°$Ç[ š*3Q´¬Æ£`ÙÒ†®pÑ:îû:•»oci¹në,_¶‚×¶ï!'ÁÕ¤óYF„°nç­ówKqârÄŽ=Â2Ñ 3ªü+e)£‡Ã…C‹š¶©£ Sk„ÖTlékY mI:V6›^¿û.xãÎHò”³™=‹æqEúÕM&³©‡Yúì\õÈ·äZQÓR·t?ù#V ½»gfÇ|ç— yê?ïP€ŸBa·¯3¯¹•9“{°ï“Ç™·aÏÞq&.­}ÙüŠªJ?E ¿O[Jèªä2ØüÆ=¼Ôÿ!^óRá¼Ð¹Üü‹¼üÑ=eB¼^oƒd~ïñy¿Ëôõ®­íŠìùôaž?à­*d¶ÁgOÞÎýk{ñìcÏ24ÅSñ›^º›wß)‚2Bgçnʽ>ÀÃ3{·z!(,( >>¾Uœbm96¼µî­¤¤„¤ädIèr»yïÏ1ûö—1õ ×^[ùK`ß ô´ñÜuÃ÷*ÊBGöòö’åõ4šÎ+^Í·îeþÿã”?ÔrEý·ýl;¯¬Š Õ+Þú7½•ÂÚÅ?Ç[ÍàJèÍEWÄ–Mšûw9ÇN_@š«ò€P0„×çm»*¢õrkš†D Hh¥s$¤o¡ÍÐN®ûÓî;w×ýý1¿­}t:£îy=¦lÍgÔ{¾Ð±…lõ øîÐ:ëì_üŒþ _5Uyñ]Opí_—× s ©Å1ï“;à¿3{V”Ÿ1üL¾ÜùEÛì|1%’Ð-2@v’À’FÑÂáíÏǯ?ư„–ÉŒàK»„‡ê!3ÀŠß}Å÷/îU£ü•MAîèß´9Ô싯ç«ßÅÚèÉ©)mXœ´~`Iç#tç,iô´•C‰ÚµU§ªÂá0º¥Ô(kR¾ç:ðÞÞç'{j”°SjHí†àM9ŸðÞ÷cÊÞùjawâhrÚªå,óNXÒ$/·eåÚkÿ¯ZiT+óï:Ì{ßí¶Òðª5‰ÛÇ‘O‘a“äT›@/iÖîv§"F¡òl4- Ól»‹"‘Ö‰³LSz¹«Cstã•Wþ×`½‚5ï£ë6.Wó×~$À®E…¸|lååáÑéM8›M„vÕ0Z™„–^î–Ry:G`I«¬¶J1Ÿ?¶ö¸ÎqJB)[5³FLûýOxó¶ßSÔ©ab ³ußl¡4arLY(jÛ„ÖT,;ËÝŸ¶LèÖz^Ë]c”k\GæÄÇ[oÛœ™d3kaòø^×ðü5³nü kÅØîþüí¼õʆÇm}–ÞœSvθóÚ¸ ­"’Ð-Ih©rW“qŠƒ!ܪR‡ë‚Ü7ÿÁˆ+ži¼Óª–ùàÁsçòÙ b¾u5Žj†äø›þÌË£ðÇærÄvás(„Ã_:ç\[µbòÁ¼¥ÌýÛojHÀ¶Ü© ðù|Rån!”––ÊÀ’êÈš5+¯º ¯Ã…ÛãÆéPÁ¶1 Ó41,0"8»åéë{4ú¼Ÿnø¤F™/u?MšÊk»Îç²¾I5¢¼²&Íæ±I³êízƒ§ïbyš·Ák¶5 mšf«–tFBËÀ’ZÐmâ}¼û&Xz˜@0T¶8BAs:ñ¸Üx|ž5Ê/›ÿon¼d§¾þ8Ý=MïØV8y?zŸÿ¼ö\»j”ª%B¨’Ð-ã“;–Ô©z»Q¤—[âä!XbÉ48-hDËK$N¡Ëv,‘„nAá/ -q²àt:‰„uô#zÄ9«Vgñ“?bÕÐû¸{fv Éw~¹§þóxð9 6pûº1óš[™3¹'û>yœyÆñìgâÒڗͯ”í•%ÑrïSn´# 6¿q/õˆ×¼‡Ð¹Üü‹¼üÑ=eB¼^oç:²â¿(£/ç¹[V”­é&fÿt _?}V…ßóéÃ<)~À[UÈ,lƒÏž¼û×öâÙÇžehJeŽ-½t7ï¾Se„ÎþÎ=Ü”{!|2€‡gön7ô(O'ßéâ¸[ëyKJJd:ÙªvóÞ/žcöí/3bêA®½¶ò—À¾èiã¹ë†ïU”…Žìåí%Ëë<[÷SïäÒje#.û3…÷]D mëǸígÛyeUl¨^ñÖç¸é­Ö.þ9ÞjWBo.º"¶lÒÜøã¸Ë9vúÒ\•„‚¡ZóR·Q‹z¹Ûª7ºÝIh™N¶fh'×ýi÷;Žëþþ¿˜ßÖ>:Q÷¼S¶æ3š>2£àrVn„¾ñO0~ø+|ÕTåÅw=Áµ]^ƒÌu6¤Ǽ[LîX|€ÿÎìYQ~Æð3ùrçm³óÅ–HB·È)Kª°ÞÛŸ_Œa ­—y `ëSø¦ÞPñ}Åï¾âû÷ªQï•MAîèßµIçξøz¾úÝŠ˜²äÔ”6,Nd`I˺s–4zÚÊ¡DåhÕ©ªp8Œn)5Ê"fÓFB+RÂïoy•ßþaJEÙ{{#œŸ\3õ;¥†ÔnÞ”ó ï}?¦ì¯¶q'Ž&§­ZÎ2ï4%Mòr[æQ®½öÿª•f@µ2ÿ®Ã¼÷P#­s#»\ÿûÿªôœ»­4¼jMâöqäSdØ$9Õ&ÃKšµ»Ý©ˆ‘p¥•»áCÌ·®ÆQÍÓŸyyôþøÀ\ŽØ.|…pØÀãKçœëo«ÖAL>˜·”¹ûM Ø–;uaA>ŸOªÜ-„ÒÒRXRY³¦såUWáu¸p{Ü8*Ø6†a`š&†%Fg÷±<}}:ÏÓcÚSìÙRÿµ|©søiÒT^Ûu>—õMªå•5i6MšÝP÷ h×ÝðI›—ЦivºÀ’Ö"´ ,©Ý&ÞÇ»o‚¥‡ Ce‹#4§ËÇçiQ£ü²ùÿæÆKæqêëÓÝÓôŽm…ó˜÷£÷ùÏkϵ«F©X"„* Ý2>±NXÒ¬ 4—‡..Oëßœ·/OýûJ^þòß›‘Õäã}ù—=?ŸþÞv¶¹©]>iY6ª*Uî–!´*w,i ð¦Lâ{3šwlÖŒï‘ÕNFÑZwÚª­ªŸ­w_B–Hœ<¨ªŠ°ì²…Þ-‚ücë}¢H/·ÄÉC4°Ä’ipZЈ–;–Hœlª¦ÉzµÔKˆ'+«'£FîðžnIè6kð ÆŸÀ¤œœ²ïå¢ÿ¨JeÀIy™¬W{=!¶ecš†”Ð'¦itŠN(Ñr¹­$$$¡%$$Ú"þ]·?°2j]IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/filedlg.png0000644000175000017500000014370613070106167016746 00000000000000‰PNG  IHDR„8[µ„ÝgAMA± üasRGB®Îé cHRMz&€„ú€èu0ê`:˜pœºQ<bKGDùC» pHYsHHFÉk>€IDATxÚìýg”$Izž‰>æî¡uDjYZ«®Özô€ÀìÄ K‚ È»äYPÝÃ]’üÁ%Èåbïáár—\^‚±\3`T÷¨Ó¢Dwi™••Z‡VînvxDdDŠªÌêꮬ*ÏÉ™.37s3wûÌ>ñ~âþè?©«W¯Q©Tðûý¸páÂ…‹Ç¶mS,éííÅØ½k7Õª‰eY$“I:;;tÿ\¸páÂÅ'!Õj•ÑÑQ?†eY,--áõz²Ù ¨ÝM.\¸pñI`~ažd2IµZÁ°,“d2‰×ëeÿ¾}Äãq\‰àÂ… :ï½÷>UËDJ‰aY6MÓPJ5þ\¸pñè@ñ »ðØa£ut;Ì…Ó7…„#lÛjT>êÂypü|¸pqß wÜÄ•J%æææ°-ëAwõ±€¦i$“I¢±Øš:¥K‹‹d2™¶ñöùýtttàñxZÊ‚m×:öè¯’Ó y®M,SµìÝ.î 4!èJ†ØÕŸÄе5õJ)ff¦ioï$áþ?^ \.3~{Œ@0زè !(‹¤3†‡G0 ã݆ œmÿìÌ4 ôôô´ÔK[bØÉâXª˜œ»µÄž‘>>Ãý0\<ü¨}á×oÏ19Ÿc¸;Ž\õb×UÀø|¾ÝãÇáH„éé)lÛ^³ 7M“P(Dª­íœ„X–ÅÄøí5u5•‘ýÈÛ „Ó²‘JcÿP^Cûè7uáb› +Q¬äV¶€«Pÿ¾õï|»@*‰b}[R x ¶Z¥š¶v ¬©Œ¶³^Q „úè»yåÜKÓ„{2pñÈA*…”jC¥¯@ ”ÜF¡fÇÛbÖ.°Ž\ý\BˆuËÖƒRÊÙ1Ö®¯_÷QÆJàÜo½{M Xí¼#¨woußëêüú:¸Þ³m %åšRÛ9!ÜùEYO’€#M¶¸9‹­gΜaß¾}øüí;81ÒÆÛ?xÙì¦l¦ùÞG9y|„#Ç åfÍhÞ³ƒsœ¥<}‘W~î/ Ç(e_È …É--³kÿ®Æ8,Lß"cùéë$uçåLä:sÁ*ÿÉÕÑ FoÜ¢¢…Xš¼ÒðKvvñ…O¿Ê;¯3ãUvuz9{yŒÝ{ö“JF8vòI/ã£70¢ÝL]½È|z ¯ÏG¼˜]ŒÝ£³„hÀ³êä±ö=±¥ÄØ”Rx¼!öï?ØØ}!˜œ¼ÅÙs78~ü•J…÷Þ{R¹‚`[6}=½<|°±° !–ÉäØ Îž¿LÿžÃx5&çΟ'sáÂ|>mmm€ ”žå÷ÏPÔ’sŠ7Þõ¹WøOïMñöëï³;rYјZ¨ ™›Ÿ'OP ì,™äª6JZhÞ*š4ø=èF7JÇÎ6ÊWÇñû|æsŸãíÿ2Çt¡ÊÎ0HiòÞ{§H  ³¸ÈõK×Ù}p7Òrì~ŸŸ¼ûÑè§i‹QJ!e͆°Þf¹Iu§”B(‹«—Oqs^±cÀÃÌl†½{†°Í³~ƒ©ÅiNýÙw0vâöµ2Õé1–;ÚÑD0Xœàô…1^zeˆkopèä:º;0ü Ë_àÌÙÍlj§ŸC–³|çû?Á ó§?Ew{ŒjvééIžøôID>ƒÐ´šàÑ0„FßðNN_ÿ!3Ke¦.ž£o¨Ÿžþ@ Õ%³m3?~›±Ûc\½vCû÷0zí<ó9Eµ˜!>p˜Dqœ‹ã³¤:»éß±ŸO•‰±[”¥Iª«‘áa&ï½ù³%Q)’Í屪®ß¸Âüü"*8È«Gz™¸}‹‚Y¢½»‘‘‘½Þ¸Øæ°¥‰) drúúúÑj p:&—Ë`©öÖê.v6J:±FªfOK$R€¹ù«Ä:;Ñ J)†††I† –«BçÌù ,tÍ&—Ë’I/3:z‹7Þø1ŸýÒW9r`/†V?‘K4Í9ÑÔ#_,R5a``'}g/³ã…çñ,,b”—™ËUÉæŠDý’7ÎOðôáN–§ÉæK´÷ ±ïN"/»†z™ËUP"ÀL©ÂôÂ<Þ… ä¼q:Nüw„ y[ŠüñdøÙçÙÓÓ…ˆà“%v ö²PÒ±K®ßºMW›`vjŒôÀóÓiæçý;tÊùE>(zš(²«[#?}›¥B'†{™¸ruESû ':éîpæòŸ}jç*Õ·Zw2š€…Ðìëàý‹× d2”*¯×ƒ%|Ä ?±xOìÞË% J8ê&!@×}èÆ/ž¦mè ñ§i-x4gMÞµ‹3ß}‡…L™Ž¨wE­Ó3Ó41)¶±ëiCå"4¬rŽË—g8øÌ~¨YªÛ;:(^~SØ”•—ãO@)¨—¸té ÞP’žÁÌ.,Óߙ¶k¿¥*86€àÊKk9sé=öì<ާ²È{o¾Ë…ó—Ù±?×/œåÒÍö÷u@Þ&ò²˜‡¥Åy.]º„ÇàÐÁý„Ã4+Dii‘#'®Ø)¨Ù`è î?ÈÞ›³<õä“ä—yÿ{?fø™°%Œ^¼N|ЋDjï -$à‹²{ßAvìÙá É1}sŠÏÿò_!;=Æ×§¿n‰†#,.æ¸öÁY¾øòavï;ÈàŽAW¸Ø¦–nðîí?$à 2?ÆÐEºjU(”s,Ü(YʾǙ‹»Ù»s¶6xû×IgË<{dÓ21M“`0Êüø%~”žfia–CO|Ãçå÷f9~r'ºerîôû,u³ÿàQº:–mc[6óóבý{ñÙa|KYôéyR‡=;M!“c|ô<{º;±Ò7X.t37—'X±ñiÓ4±,“ªY¥î®okž`/éË·0R÷Útþýñ–RbšU§^UXžCÊ«\5½L\ —/’S!=IìCŠdO7L-Qµ%–(Û¦Xš#SÎ3>–áȈ‡jµJ±ãÂ…óLÍ&édp á`f%Ååª6,ÛDʵk¾mÛw>!Ô%É,ÍqöÔûzv2ÒÓÞÐY*»ÌõŒŸ½ƒÃ ïJáózPJwòìs]èºÎÄÄDÍp´¢z*e–±,I0áœ4!¿yå‡Jš›ãÓ˜•¾öóÏÐÖã¥øÁ Ù’‰®+$Îýz{xá…PJ"¥B))MgEªšQY¬HF¥Ò±ŸF(ÌàÎÝD¼^¯Ÿ`ÀKjp‘ËÏsáÒ4þgžiáü2”KLÓ¬ßÞqœÐ—ßy›Ó`h°Û×j¾¾ÒB©{3Ö¹xü`š*v&È›„霢[T)VrkôÁ¶¼³ Á¶-¤4Z¾A! ˜Ïsíâ9FM>õ™ýHËl0Œ-)‹~Þ×ëöL”æçÀ‘§Ñ4 ˲ð–e56zʪ°45Ilϧ±Š(Ës“LŽeyvW€Ñë׉#¼‚™²b)JWo„…ù9”w?÷ù/O´ã3ttM091ÊôämÌ1n\¿ÌRYê rôÄ~nÍ,âóxÙ±»üü×®¼Eßž. Ÿ]ûö3ÒÑA$æ§’›gâúEn—¢ìÛsœCý6Ò)"Á$íÃ^|á0ŸÎËç™.Z¼ðÜSÜ<÷ž»B§×ÆV6–mSW¯·Rü(,»Š:RÚ ;‹³®®cC¨Œc i};‡¸y¹B8Z&³T"#|Xþ*‹‹iF5?:3sóÌ,äIæ‹hB079Ž¡I*¶3þ>ˆ§Ÿ~šÎÞN¤åôeaR‚”ŽÚÈ ! :iwâÜHOÜæÃ«W)™6};8°w'†p¬ÖB(®_:ˆGiëé«7—Æ*‰tmEge›UÞ{ç½;Еð#„ÆéSïÑÖÕÏ‘c'H„ý ñã…Ó\¼p–è\PLf¢œØÁT4ÀôR¡ãVŒ]BPÉ/£éYbmœ}÷4}Cýôô XM»¨PÀƒÏSàÇoŸáä‘=ì9²—sgΈ…Ùsø(æüW¯ß Wª %èqþâ9|‘3££ôô¶Ó½£‡oû;V¯îÁëó‘ŸŸc¬¸LWÍ\0ÐââåóxÂqv w?èõÆÅ6‡mK–3‹ÊÙZÉÊ÷iK›öP«Ç‘]Ûø| kž:RJj¾‹T³i><{†…b™P4Å«Ÿz™¨ß@ÖŒ¿óÓ·¸=·ÀϽˆÏãiùÆœ>Ú+¶ )'”«ž!#¼°³Ë禸uó:oúýì8tœ n36>C×î#|pê,™|–hçnº¢DÚÛ ¦3;9 Ø,LOpñÒ-ž|å§)§çÈ ›½öòþõ ¥ÎN®_ºJ¤­ešÜšœ¦£w€‹§ÞâúôOH…´M ¹ Fv¿nÑÖ=ÈÔ‚"¦gÙ™êáÚ­óŒ ‚ù~n/½Å­rœ“G÷³4o’Ýû<(%ˆÆãì}ò9:3Yüþ0mG0 ƒž^–3Yt¯a ¤F²h†‡€áúv?ñ í»²øü!\¸¸RÑnžÞýåuO• E2Ú…&V6Xš&@×64*KÛ ßs¥Ð|~†÷îg—?D$dÃ;P)…?œàéçž#òbÙMê¨U^F/½ô>Ÿ¯±Àµwñùñi0²c¡pŒöÎ¢á ¶U¤ïÀaz1®_ÝÇŽÞ¶hš’’Üò<—®Žb)A8çÓ_øiº;RT³6=±v–æsìêjGè~á/ý¬R–åå Byæ…}P-˜¿}“ÅÛ£ÄãmÙÕ'ÒGhOH î# kL[»HgK<û©ÉÎM3zãJMøA<Ñ…?1ÂH{œ×npp÷?ýç¿T kÒˆF¼,ÍM²X òì`{c×oK‰Úº±J©†aYÕÜA?t©ïÑvгUªÉbQPR‚öž!öJ",›ìÂ]C=,.Ìa=;2ñÎYæÓ|ú§>C±T!ð‚ÛäÚµ1úúw ÔÜT…p¼×6ð¿÷{ÿNišN0äè‘ÃÄãñÖCÍ÷N§ˆÍJ¬¾®ùßùòֵ͇%RZÌ.,“L¶áóh+†i±¸0O$ÙßЇ¯Ù2… ï\Yà¿{ù>àâÑÁ[ç'°Ë9ïèX£:’Rrãúu†FFðz½-u÷#ÈiÃ{ÔN}÷€‰•ÝkmÁt£hZÄTÃ5³îƒ¯V<>[»†ñVÓ/›z”041<¯ì‰›ñz[Ë,3·œ§³-ÕÂ¥”"¿<‡iI4¹”K)¹yý:}}}øšâG„d2i–——nµ'6"ý¨ßK­Y+WǤӋH-H*lÛ¬°°´D¢­OS¿3é4ËËK 9¶Ð÷Þ?…eYŒßÆPRÁÖÇUA k«7÷BÝ)pc£{Ô'«ùšAwgÇÚ`6Í ½³§1á­»70ÍÅ£ ¥ÔmB8úo¹¢•7†´7*¿ïš կ׭SÖ¸nÊ:tÝKw[Ò±áX­§¶P¬mÕ½œ…ºY“ÒÒMœ`¨•ÑGA,ꨴװÙêÚÛ;[ú×^ç}‘Rb\»~½{÷}ÄN}ò¸“YwØ„ãvZ±dø\ôiŽlÞJ™ †î–¹e¦ ž®;˜€O¤ÆwÂZ ÷C]Ö¼ÁÜrÛ;_'•Ú°­Zý»wË)#µßjgž{…T\·j3ßÜçõú'¥Ä¸~ý:ûöíçQ†>±Á·ßº„ÇÐÑ4A¹jŽAN×Ä'\æœX´Zùö*³uOe•ªUs"h.³‘(ŒuÊtMkŒÍG*3ƒÞš2é¸B>jeUÓÆ– ÃÐБN®­ÜìÕ"ëê“Z¹„†À-[]F#VêŽeÐ2¦ °,«E-¶z1²-{Å^Sk' µ/S™RŠjµŠ¶Uº´%F]÷¨CׇGÚ(”WŽUõ¨>™ë• ÀvËÖ-“«>$·ì>•ÕtÚ›*Ó~Žß«mè÷'˜¿Ç0jËY]0Ôlt÷½ÌÁÃ\Ö¼åÞj™RŠP(´Æf£”" ¢i7oÜ@¯9¨¦~½/g™R’®®µÞŽ–mc¨{$³z¡k‚XÈóÑoäÂÅv‚º³*º½£x"Þ Tp®­7hvÜh-«ïˆÝ²­• !ðx<ëž Ã`phË´+ôÝÈòîw™a躾æ#¥!Õ]Þ¦G Ñ£ºpÑ€Çãi<›Ù;?éÅhËe5Ï ·ŒÆÂp_Êî²Èhš†×ï[Ó®¹í'Q¶RÖ¸ŒÜ5Ò…‹Çõ…`ÏÁH.ݲ{/Ûwñ²|}“Ra¬›Äaƒ@5.\<Xo·íÂÅ ”ÂX퀛ËfÉdÒ÷œ(Ã… º®“H& :æååer¹ìºq†a8”Ö8¶«bRÑ4mݺÕp®Õ|9›­sññÂq1]-÷ùü¤ÚÚš¯Æpo;¾c^žTª­‘±È… T*æçæè¤PÈ3??Ï• âEYÉ´… £=ŹÓï3“Óøü?C4°²G”V™7¾ÿÓ9Á¾ø¢Ïú\BË,ñî[oñü«ŸÁ×ì]#ùÌ2ï¼õÏ¿òœõÆÅ'…R©H¹\f½3b&“aiq±]®T1Ž=ê0ß mYèºN$}ÐÏáÂ…‹{„ß ½¼ŒR ³ZÅ2-nN- Ø»ÿV-¢UÓuÒ“ãÜœœäÊí)zFò¹çW‚T§.ßäÆÄW'fè>È^Ø8^)_,óÆûòÊg¿@(Üš°PªðÆûçyù3kë\|¼Ð4Í9å­£6”J‘^^ϳ’íÁðo ±·[lB¥ÒD7ý£æµ}--¶Õu¿ßÿ‰ê‘«Õ*fµê:+lðx=˜æVéÒ^¯·á÷¾†L öu“ËåZË…`2]ÀÐ4îÙ‹™¹ 4 „t]íÙS«[•J…™™¤”tttЖŒÓßÛµnp\*c ¯ëŽi>]|<¨¯5ëñÄ­…†±Ý§HÔ2EMOM=ôÆ1Û¶©TÊ´7e¡Ûô,/ãõz C[(J*‚¡ ©Têc>!ù|ž‰ññý·Ux¼Þ }Ø7‚RŠj¥BOOÁPhÃkÖlò„ÂZ.Ð{¤¡[ªýBa§ ô ¡­ªËd2|ÿûßDz,^y冇‡ïH'ãÚ$·?`<èNléô2CC´·wÜ•lo»BA¥Rfrbœ½ûl¹íØ­QÂá©¶¶MŸÞ„”J%®^¾D2™üDj&“¡£«‹¾¾þ‡v®êÑÇãã·ÁãñlržÀ¨Ñ›7Èåóë ¥ðz½MuÓ=¥”ŒìäÚØ(—/Žñ¥¯¾ÒÒldÇ ïœŽqéÂ(?óÕ—Zê:::øå_þåÆ¿mÛ&¯K«,„ ‰¬[çb;A=Á`ð0HµRÙn­éêLM›iâd¢ûdÕŠ` ðÌÕ')%†alqGí_†‡r¹´á}wïÞƒRv ¨R’P[_ùÚ_ bA*•hilëå+_û‹TlH%w꺮óÕ¯~•@ °nÝW¾ò•uë\llê„°÷ÚkÖÞ(AÄF÷ߟü¢ö1⸣ê¤YŠõ ¯û: †JaK{s¿±Á<×wÃJê=M4؆WÝGs] ?š“Ôl5ËTÍ9d-åbŽŠ-HĽë0£ îtx¢•³g=XÕ’ã®.t"Aÿ¦ë\l#(0r¹‰DrÝzÛ¶¨V-Á(I±TÂë P'ÊÂIZ1~3G²ÝO(b¢‘n/ŸÏ“Ïç÷Ó4d2Ùpi(–³E~ÿ“ÖMlÕ–ú`ÇU)²éeª–R¯/L‡)<<ñäóìßÕWK¼¢QX˜àOþìÛ\™*òWÿÚ¯r`xÅÖT\˜àþà¹2Uâ¯üõ_åàðv(eñíÿöG\›ZÄëå/ÿâ—ñyk{Meó¯ÿ1W'ðE{øËÿýÏâ÷>$Š‰Ç J'Ö×í U.ðÆß ]¬’™ç­ŸœÆ”+쌣7ùöŸý)ÿ÷ÿó þÛ׿ɟýÙ·øÆ7¾A6—CÓtæçøàƒ9wî~xŽK—.ašfm·)ÕgοM¶ªÖìPDÓ6Fn¸óÙž¶Í­79{ê]~ïßüÞ9{cÕÀ·îôë;ðæ¿5ɼ•sF¨·¯·+•Jüê¯þ*—/_nÚÕ§í.1%Ê6y÷í7™\ÌS),ñã7~B±j×2ÔI><õ>ô_ÿˆo~ç5Ο{‹½ùþë·~Èåó:÷ozêžÌR†ï~ç;œ>s–|÷Û\|ÐS³í±B>·2Ïu·Á:Y}¼›ßzÝ:¤HMçéç_a¤;Nz9ݘMÓ½9 ÒžR\»t±¥åèè$Z0HG›âÚÅ öYÚ&í{ùê—¿H9½@Õlb–UÚú÷ðÕ/ÿ•Ì"fÕÂÅö„R c£]%JáÇé‰sæ½÷ÕƒûŽôê„xÉöŽ}L•ÆÙ½³›® üŸÿ ó „C>"‘ ÇŽm¹§iš 7Èt¦ˆ¹É°ÑØÝ(!(æ ŒÝ¼Íþ#Ž œª±4>,Ð ƒ‡ö0óíQ<ý*¯ö³ô–ÂÒ0+»¹rñ:Žîw$)ê…© g1" >ûÊK,L\äOÞ¾Æî¡^ô‡g*?q4«Œ„ ¾÷½ïqòäIúûû™™™áÍ7ßä•W^!‹µl4M[sbSJÑÝ3ÀøÍ+,W½¼p`÷ʉQ@Ñ´¨,/±cçQ<ªØÒ¶hYT—ÙslMÝÜÜú§ŠeY¼úê«Ú7ÄûoßäÄ‹/­¨…4=ÀÁ=ƒ|ýƉ_"vUFÛŠ ¸Œ(ÁÎý‡xë÷þ*±›Wú;ZŒ]Áp„€×¦¯·ÀÀÎ~ºÃ^"áf%ÃÅ ç(•WR·3<üÔ/þ<ÁÒôuCƒx5™—¨Sôwµƒhµ?8*£‡Hg˜å~*é)Î^¾Í“‡€šNßvvI†að½ï}ßùßiìú,ËâK_ú¿ñ¿Þk)Ù¶mcÛ6J)J¥"¿þë¿Î… ¸~ý:¿õ[¿EGG;¿û»ÿû÷ï«%üv‚ ï˜zgÑèÚÍÙÎóÎm?ë…¡FŠ=%mJKó(ÃO)[¤(¡éFÒ@6æ¶1WMäòS &½‰8&†K—Q¶ †¿TãýpŒÅRJÞxãÇ|ýë_çoý­¿Å¿þ×ÿÛ¶x饗°íz" ©dÍÏ¿UÚ ¡1yóš\=÷>·–<Î++ˌΖÙw´Ãáx9õáÚÚ^$qàè~lÛ®µÕ:£r ÖÃç¾ØÃìô8ßø³³5àì ëv–eñüóÏñïÿýï­Ì‰‚p8DµZmQض…e[˜–‰’]×ù‡ÿð·Y^^æ¯ÿõ¿Î¯ýÚ¯qüøqR©•J¥±Ã4-˾Ë1]Jù RóÒ…ùtžždØI¨iØÂ`i~*:J™ÌNM°0·Ìr²Ä€×Ãá‡j„¦Q—A¤¢œri—°=w1ØLÓll¼^çïüþñ?þÇü•¿òW8|ø0ÿàü}‚ÁÕjpÞi;öªµÃë|åá ŸKçÎö=Aoo¯ãÉdKzwïã˜i2“‘œ<¶³¥eÏ®½z†™´âäñ]-u>ŸÁÁA¤•#O°B6(IÅw²xû5&®_ "-æ¤ÍÀ*—ÄfAïÛÃÉœÉåsà &yñÄA\Ü5!Þ¬šµ,‹D"οøE¤” a°òî8›‹z¬fóÓ£üðctìãðÞá•ée•øÑwßb:+øÂ?ëÛÕ»b•ùÑë¯1ÓLn·^—í oþàuÆ—*¼òéÏЕµÔ½õÃï3¶PâÕO†®¤Ëe´]¡”Âx÷Ýwxæ™gY½ WJGÙ æxùx‚Ø»·‘¥è¡«æf¸ûÐSì9ì´­'Ý1 ƒ}â øñy<(%ë–lžÿôgZ^ꆱԖM°ïÈ>Ǩé$’åaò;ºÎþc'YMVOr-¥Ü’êD©œ¾Ý¼¬©…R©õDêÍ÷°áα†×ÏþÃ{k' ƒÝ{öÕ„Žs»p4Áó‡ŸG×<Ø}_C÷ðj`UJ—CÇ­,`-¥±cßavìÃÅ&Q?9®N\%mÍîÃÍ^dõïhÝiVTK%:º:8wê}ö ÷á÷9 »¦iL^½Â‡W.såö4ñŽ!>×D`7uí ^¹Äµñ¢íƒ|áÅõ#ì­JÃF˜ œzç4?õùuvµˆî¡Yó¼÷“Óüô_|ÐCìb=ˆ…—s>`hbõû¬-CŠÅ"R)tÃpv‘›i«Õjõ¥¿öz½¤—— ‚ z­†ªé ¶]YöáA—iB`Û6™LÆyßjïˆVS›6‚ÐPhBk)Ëçò$“Éu¨a`òúy.Oe0-›Á]á–X–;¹6v‹+—ÆøÒ/¬"·Û9È;gb\º8Æ—¾úrK]GGé/9†äjfŽ?þÏÌr©Š?܉áY±CXÅ ¯}ó¿²T¬âuàq=Œ¶5Ä¿ü—ÿR…B!"‘»wîÀ²Lú·•ŠÆ¶m°,«IW½ÕÛð³ßîe€-m ÃmYÎǮկÓîX¦”B×4t]ǺS[!ÚJ™×ë%ÕÖvWÃòý‚”’¥ÅE*Õª“z±fbå¤w_ÊX¡4¹oe5¡ùñ”9Þ;•I)ñ”JÅšýF4ÒWBSDûª2MÉTªaƒ¸=v‹Á!2éenß¾iÙh?ñX¤eë722‚¡‰¹]|Ͷ0—Y¦b RÉøÍ^¹Ì2™\‘d[;A¿wÓu.>^‹Ê¥µ¤‡õ Øôò23só˜¦ÉåË—¶S]×éêî~ÐݸO¨ÈEÝÊÜZ·^Y£™ºóuë¶ýd¹è5M££skù\Ü ››ïæY7¼ÄâA ùÜúa›ðt»"±^Csb‘ð®­óhH¹¶ÎÅöÂC!€OtQsñÑàÎÕö‚¦ÁÍ‹§ùÆŸ}Ÿ¿ö7þ6>Ÿ³( ¡Q˜çO¾õ.×Èí®"·ûÿá¹çМ‚5CöÉíJ–Mey‰‘=Gð¨V=tÜNJÉüèÝÙ9ÒG>›i¹nqj”o½q–ëÔ¹Ø~p‚ 0”-ÇÊ/qëÖ-2™L#ñnävÝñ JùÉÍOÐvàÕ–º:¹‚J¹D4:Êèåóøý¾@/ÑXŒ[WÎ5Ò‚>LÌÅ\àÂÅ# !/¿ò ÁP˜ƒöÑ×׷¢['·³,f7"·{f–™´âÉ;ÛìÚ½‡©©)r¹\Ë‚ßÝÓË_ÿkÿ/¦¦¦Èf³®0Øæxh‚û"Ý;>ibw®î÷ºƒ¾3'–c/8tèЪ¨õ¹ÝKŸ]·S÷96‹žžž;ÖÝ©ÞÅöÀC!lÛ¦\.¯óÒ?ŒVª{àej¦¹_KyÇvºa|¢iRJÊå2ryœ]¬†ÀëñÔ(ÎÕææÙ‰FÄëõ®›BU}—óW—éêèà™gŸ]ÉpwŸÈíìêò§ßdnÞâÕW_fÇŽ+uæ"ßüÓ?afÎâÕW^bçθؾØöAJÉøømÊ¥òC¿ó´m›J¥LGÇýô… “^Æëõ7Ÿ,¨A± •jÛ\›¥SS“äsù‡~®¼^/†ÇãD'oJ)*• Ý==k¨Ô…’LOŽbûv1´cG kðý"·«äf¹|{‘'¿@ûª”jn–K·9yô:ººô𺸠¶½@¨V*H©8vâ 4íáK”S‡c|+399ÎÞ}¶ÜvìÖ(áp„T[ۦǠžsùêåK$“¿1϶,J¥2‡k]l‡¯“ïºT*¡é|^ƒR¹ÌÂÂm&r’}==$1n-”ñ{t:#FKŽŒ:ùZóbfW+Š%¢ñøƒ˜€‡µl ÷ÐÈ÷Õ߈v>ÉàA8ÃÐV®PJlëã+_û r»fS½µ:‡Ün#’|éç¾JÕÖhO%[êü‰N¾ôs_¡bk´§zx]Üžë…¦17~·ßû%tò˳üøÍw©XNúG³Zá'?ú!_ÿúŸòÿÇoð­o}‹¯ãœ>}MÓ°,›«W¯qþüy.\8Ϲsç™››kœ„¦1?v†ó“SNR•æßnJËX§÷}”ùô<ÿÇÿ÷ÿ`ôÆí–òÕªŸ‹eÓßÊ5õ1€úBÑÜ®T*ñ7þÆßàòåË+Ý«N u*ðuçYhä§øñ›ïPµÁ,eyãÇo)šhB°4?Ï÷¾ó'üßÿõœ~ÿ Þ{ÿm¾õú[¼öýË,¡iZK:Ðf·I«RâÍ|—÷oþcK¢%Ù{ç¿ësXãúØ6(àëóÜ4îë²Çë'ðQÈçYw”b#!¤îP×Ôk¢‘Xò¥òšºH4^«ss!lwlxBPRÑ3¼›k7_çêèm–n]¤wx?ဒ Ýð°kÿ~©9 ¾ Çõ219Å™Óg8qâÕj]»v¶¼à…iš†@2z#Oÿ¾A„P „ÐWÏ_¥£»ƒx*iº«œçóâ w‚m5lã¿„är9[Ú†ÃaR©TÓõ+z3—ýìì,KKKŒ3::J*•¢­­ ŸÏ×"ô;¥$‰îA¢×orþÊ <…iÂíý´ÇHþÌ,I¯$–êdòÊ5Ž¥d/úÌ{hÅYn-ðy=t÷u×Þ›•|Ñã“רø;‰Òµä-÷Ã…ƒf•‘‚B¡Àw¿û]Nž<ÉÀÀÓÓÓ¼ù曼úê«Äb±–Í…¦iëè_ÕüçΟgz¹Ì³/}ŽŽp-»Úý#·»ué]¾÷Æiý‡ùò_ÂhÚã]|—ï¾qŠxß!¾üS/ãqÍKÛwP)tO'ó_þäOh:Ê“;ú©5M#ÕÞI1s{éêê¦ZµœÝ¨’ÌÍÜâúÍù¦`òâU>ûå/Ñ;ÐG5¿D^Tˆµµc• ܼq“þ=hÚŠkœ‚‡QQ„²9î,îì̪ÖÔ¡Jaׄa¼öÚkü“òO»>˲ø™Ÿù~ã7~}%¢TjHé¤Â´m¥¥R‘ßüÍßäÂ… \»vðþíüóþ»ìß¿¯¡ª³-ëî)45ƒ#'NðoüWìp?_úün„R  Ì\†J±ˆ´é… m 4]CÎÎTZËé­YeÔ7°—T[•?¹|õá yP÷ÃÙH)yë­7ùÆ7¾Áßü›“óoþ5RJ^yåelÛª  YK¡¹ú{š`v*ÏÌxžho~ŸÞØbµ’Û¸~é"‡Wò!¯Û•¸~é‡F^Z¿ÏRqúÍ)4|¤’1š´R(¥8ýÖ©d¼¥ÎÅöÃmJIýÄ)ö÷áÑDÓÑ_ ¬2£×sì<©]_EèQ:;vcçîHµ¸Ì·*`„!X^š£ƒ¶°¤`a~+ÔÎþá.öØ…”+ÇàæãòÀÜâ§Î^bx·äܹ³,çÒ ìBלÌf¦iÎâÿüóÏsàÀþµK(¢Z­¶¨ lÛÆ²­ZÐ’D×u~û·ÿ?¤ÓiþÚ_ûëüOÿÓ¯qüøq’É$•J¥1^¦e6Ð&šP¬¶D‘ö.B>Û¶(4ŸŸ\¾Dº´@§G_^ÄÊMb,,Q1mw ¢¤“Ó¹>Wu è1¼T5sÓa.˜¦ÙØ x½þößþÛüÎïüõ¯þUŽ9Âßÿû@ @µZœ÷CÚ6JÉ5~Ár1K9 ®Êܸv“Î'bÛò¾ÛÙ¶Í‹/¼ÀÍÜ<íâƒ÷ÞáÉ#{ ‡œüÉJ)®gf9xl7¾ÿž<²—HØÍ­¼]qw·S¡ah|k’jH®ž?‹J’ˆú™™fâÆBíNµRHÛ¦\.‘Y^äòåKt î =¢˜Ïqêíðö qõòE²ÙóKó\Z8ÅŽ?ÇØå«´wµ¿ƒ!k;#ïáË?÷³¡1?:Íàà~¿³¶P×ÏzÐX(Ô·æ¶m·dÒròìªFRu!„Ãaúúúèë룧§«v"¨ Q'YûÝWd'›óNJT×0±¾!¢s°g8Â|4JÄ›B/…ñ·®ßÂëóÐÝ[ :ZG-•›a³°kóÛ|bL&“üÏÿóÿÌ»ï¾Ë±cÇèììIJ¬–÷£þެ†BÑÕÉtLK¶Øëî¹RŠöT’c>$6J‰O'MÀñA?RÔëô»¸î*¤”ì9¸›H<ÒòÂYÕ UËˉãû‘¥9.œ»H¡êáù§v5v§“““\»q4ƒ»2Ô߉°4;C^i2KÌj’x<ÁϼÄä\†R±²òÒç”ò0tÃO2é삞xæ â‰xíS) :܃fÅx¬¤rÔ„êµ]¸ÇÃ?ûgÿ+Ñh´±cln«”Ú”‡“’Š¡ƒBÆ®”"ÞÖÎSÏ>Ó°¿-ÏŸ¼wª¹%J¶Þò×7Í1^¯—£':)+]Ü5!Þ‡`Yñxœ/|á H)Â`åÝq6º®¯yŸ””´Œ­Z,ä%ûöïlxÝOr»ã/~Šï~ÿM^øô«„‚M^ƒBãÄKŸæ»¯¿ÁóŸ~µqrp±=±©œÊB«'ó^Õ¸îÿŒ@ÓZ=M*• ¶Tƒ4h¸(Ö=%š£±F¡éZÃ_¿T*±°°À‘£ÇôX}dT+._ºHßÀÀ–b*4!˜šœ  K$VÆm•J­ž¬½£~chxø®Bu}!%‹²>MR‘‚χ4ËHšám´1M“‰‰ Ž?á¦Ý¤”\»z…d*å¨m²&3ÓÓ()éêîÆ¶í–œÊSÓ3Dã '³eµ¸ ŒŒH¸î *>–œÊ©VüÔºn…>ŸoEuÑÜN©õ Â2Í¿×HVþ¨¦á¨}¶ò,²¾àKéü­¤­·oªdͽ©ž­{ZQ€NÀ…N@sÔYhžZJßÕ†n`ÚG´í†ZpÓm„@Ռʫ…¾‚……^{ýû”Ë%ž8ù ;Fûß'r;€ïÿû\½r‰H4ÅŸÿùŸÃëY¹Ï~ð®\¾H8šäçÿüÏáõÞ‡˜ >vꊼ8ˆ•PGA4"•·2.5Ø [h{/4t»åÿ×ï¦pÂG„£V¬m6‹Æ qm¥‘H„“OœàÝ7^#SÕNÌ÷‹ÜàÐáÃÄ<&?üà6ö*÷⃇œºœ½……ŽÛÛžËH×uLÓd~n×»”S_…@×4çC’²vj¹ÿe-¿{e•J™R©D.—[‰*¢hŠ”ë—iBP,‘J¡éºcƒØD[%UÓüÄè¯ëjÀù¹9ü?Bh .%¥”Óíã-SJ!X™@Ú=— ¶m“ÉdœØå¼AšEß)sÜ}›Ëò¹<Édr]aìóù ûAz’ìèÄ–+ªÛJn'¥¤££ƒ¶TŠQi±{ßQžÖw­-•䖴ص÷(A¯«JÜÎØöÁãñÐÞÞÎìì P3È"F‹šGKÃå‘Ueë]÷1–ã%²Q|~?¹\»fl,,°¦ h Ô’\6Û([ﺖ2ÛÆçõÒý %&Ñ4ŽŽæ©®Æhœ¤ÜDÙzm¥2Çóju™R @©T¬iHwÚ®ׯ*Ó„ ‘HØ@ £·ðÇ„^çÇà¾ÛY–Å+¯¼B8àáÊå[<ñÓϬù}i•¸ri”ãî©Oä=tqïØö ‰Ft7î3š3Þl¦¬¹|+mïÊh³…B„Ã.ÅñýEÍ]sµ±UÙ†ó,-–—èìÚ!vçØý ·(ÌÞ j´ÑŸXû––¦©)ú“±=.B l…òÙŃ…;WÛƒO¾€æõ5ÔEpÿÈí©¾ú ½ýkéIÉ~¾ú =ëÖ¹Ø^pz.\<òT*%2éÌÇDn¶´H///–×ÔÉF]é®÷qñ`ñPœ\¸pqoBcarœ·ß?Mƒ“O½ÈÝ5»Û}"·SŠï}ý¹0>K(Öïü…ŸÇç­/-Šï}ã?sþö Áh7¿ò¿‚ßë.;Ûî Á…‹GB ù,º?DWgåJ¥amj%·S\¿t±¥í ¹\¿taãQ’ù¹yví݇PÒáIjÔ)æçæÙ¹w/«ê\l;ÜUT?L”÷ ª)÷€ 3¤m1;5E©\%_(Ñ;x`% ô>ÛI)9´k˜\ÕfáêUô@gKþ¥™ 2å*óW¯¡:ÐÝöm;gL«V±-k³÷zt ^¯÷Žy\¸x ¥dzfžýO¿ÈÂØ5òé4BôC-ëG%·šÆÒø(¶äÕžà;ß}Ë4Áë|;Kó‹ØzˆW_<Éw¾û¦iá÷¹*£íŠ g&ŸË‘Ífðx½F„ð ¥s´íèì@×Ý—×Åà M×yöÅç¸ró¾xûî¾ïäv½)r¥ù¢‰‹í‹ OÍû À¶)ä2”ª_€n‘/”° ÉxzjHA>—Ãç÷ã1 Ðt<£Fa-±LÛ–hº§‰"—:ÙÛ*8¿m9'á$·JYÒÙ"~oˆH¢ž¸gÖ[ÚhšŽ&–ebYNF1ÃãA J ë­ Ê·ÌHêÂÅ6„Ã{¤¨X ŠË—'bÄ©»Oävím)*UKÂòø‡Øæ é4Q®ZØ–'?À6?¸ô×Û „zN‚º¾Ñ–’bÉIx#D K™„#q–+:Õ²‰¨,’+[ØJ£Z5©TÊhBÃÔCt¦"Â&—ÍP*U°ÊeÑ(ºÇG4¥(dÓ”ªVC$•ÀŒ‹ø0sËèšÇ 8Üï¶”¨†ÖH­Ÿ^@AµT _¶H$â”òY2¹"^Ÿ×!ö „ñê6é\x"á¸ÄÕ Jþ3¤”tõu³ËpõæûÛ÷4%Xºäv6¯¼ò"O>ûo:EAúÊ‚/4ÁÉgNðöéÓdMw…ÁvƆA:ô‹+iQxôú©APT>’þ¢˜aq¡DG*HØ •ªD™i4ÃC0oCSä²YÐýÄ“arÙ2ÉT„Lz™BÅKÈkà …ñ‡´ÆF¿j) åìàmeÛH»ŒmV)—+辡X¤Aèµ®áWÙdr9"‰„]%N“èì%àÑ‘g30È’+Vˆ­Jï÷8Æ`¸x´ òy2ËÂáv†v76{÷ÜNY¼öͳ²eŽ>ñ4æšÊffjšB¶Ì‘OpShnkÜQe$Ukþ^_ ˆ!ùL†ù™iÌj•`$Ž7£”/x±‹y„?€ÏëEh Í*š´ ÅBsó_йŸ?L¡$ ù@Óô­´4!»áQÊf@÷âñDb Ã@H›B¡@¡o]¼B!ü,ŸG§\*£ ŸGÇlŽ­o H:[&òÕN@ÂU¹x$ ”¢­³—_íAé^âÑP#…fƒÜîþ{Ê´¥ZSiS½üü/ü÷T,'§Á†/|êóì;ž#™jíuÏ¿ú9öË’Hµ·Ö¹Øv¸£@0M«‘¸]I›|6CÅVx|¼^ÂãE „†Y)²´¼L¢-…Y51s9dÕ‹ßBÇBÚŠªY%—)N„©VªT«e¦)Ö¤à4-‰´$fU8y™#q'Ïl-3TµZqú©iD¢1„h¶+t]§R® •c7°M [JJå bUf)ÓR`W0-»‘WÀ1X»ÁÅ#M'OnÈD‰'ˆlÐ4O²xazá-×¹Ø^¸ƒÛ©hÉíª,“²YÁŒPªZB~çgQšž¸—J¹ˆ]-QÈç°¤$Oô8Ù½¤-¨(Iey G£\*R(ˆÆ“HÛv¢¢ë™œÓV(¥#•Ô…rCT:~¡éx £)1|ë"oY()$UËF:B¤—Ò^”’aàóy°­NYýƒq<¬ôô¸pq õÐzù¯]¸hƆÁ¶WÔ*Í; Û²6T+±$º…|iUˆ¶u€U¡äÒK•Bh:‘hŸ×G¹\!™J"-“R©ììúueZŽ©ZyI‚pÈ’Ý¢R,QaÅ—H÷øðzÅsÏ Ã@ ¨”Jø}^ÂÑ(år³ZE Ð@)I¹X!;¶ŠzJCáœ>\¸xØ ‡H$­^t('‹ŸR”JÅpwÛ–¹5ê¡M¹ {ˆ'ÚÑ5˜¦}®”vN݃fH]#ÕhÜà ò[xG| $¶T„£Ñš¨B#ŽÔòÄ6u¢v­Ðt‘HMX¬dŠªçUÞx§#†‚Tª6Ê«B#¡iõS…ªV0ü!üÝá`ëe(sáâáE8"™ˆ¯«.RJR*ºÁ…ƒ; V¼¨ås•J‚-k\vãZÛ2¹`¡Éeµñ"®ìæ•mÓ¼·W6Hì{zˆ;QKhº?àô§®þj>TÝCУcšæJâ{pÓ\<2hùŽ]¸¸îrBh*P›XW¿hÛéÅ«SYË;ôIJ»éz×ËÈ… '6‡R±Pª§å¨kùÁ2”ƒ!¥Äð®ÒÈ…  ÖJ)â‰$™ô2¦i:Ö·Q}ý(—iš ­­ŸÏïž\¸pñØ`®ë¤ÚÚ›¼~Ö²=Òe®ÎÕÅCŠõ|,\S›A×­B7 *•2ÙlCwÕ%.\Ñ([£2ŠD¢D"ÑÝW.\|4H)… ™J‘L¥t—\<ØÐ¨ìÂ…‹Gî÷ìb#¬V#ºÜ .\¸páp‚ .\¸¨aÊȉÏz8-OõÜÈ.\¸pábëX#nÏd›Í¢6)œ´Åª5ŸÁ&š*Eîún ¸høU;m亱b†.éŽ2Ü“X¡žØîAŠûï´±µ~ßù×ïÅËðÞê&ì>Ùý'¸÷l©îÄÅ£„†@ò¥*?º˜_MÓÙ,ÛgBà°–n¢ÍÝ¿%…V#Õk”l¦@Ù6Sæ ûu¢!ïÖŒïáÃVMÿ»•Fµ€Çëmd‰û¨ý½k‚Ÿuú¢kÓ²6¿Ømaì¶4fŒU}œ@aYw#DÜ\^‹Í$CZý˜‡âÅð¸y‚]<h:!8ÒŠ¥21Ÿ Ò¼·;~̦ 7rB.”˜˜˜¤§#¾¥[KTò&Úšvwê³Ðš„Zhou3J**•2º¦ãóû6¼Ÿ‚Fí9ä¹"Êmm_X¦‰ešøü~t]ßÔ84~gc·™1sžÉ!–ZuV¡¨V*!ðûw…­÷Î}»óX‰¦{µöö,:»ºñù6ž/.¬QÝ‘â©#;‰¸7½©e>>hšÆ;(b!A2•üH}ûX":7yÏÉÛ·ñü$S©Í=ƒ¸G‹Ï:ý@¹\fr|œîÞÞM „ÖÛÞ±»³^IÓSSèºFª­mí8‰saýÿ?jß6h'€¹ÙYòù~¿[}.\Ü š‚Cìxˆ… ºè5Ÿ‚)-2éáh¡¯k„Vjs‰Eat#ÕÀÊu¢å¾+ûmš&½€éduk׉ÖªÖþiÔò>Øh:º®aÛ­äw-»Â >z'éÎ m¶j²}Ô®lÄW%áiN„†¦ë VCe#ý¨ç¹Òh5 ×«ž@¨9èêß[¯¼¹L)…¦kÎŽ¹>֫DZyŽ›­þ»ýÖzýkË5M[3Nš&°­*år•@0ˆY®â ú[žc¥NÆ0yÑܵQ¹ioœµÏ…‹‡ -'!@×DKþU[Z”+Õ–qñꇜ¾1CÏÈIîI°œN¯ÜD) ‡T2yצÐ4NŸ>C__íM;½úÇkVËXJCY&Ù\„F4'à3(”ÊøüôºÁ'3[=´lÛfyyÛ¶)—*,LÏÓ3܇ ˆ½\»EGÇn&Ï½ÏØÌ"J‹ð̳Ok,,/™³‰„%eok.ÃðꪌúB¡i‚›×f(ægˆu÷ÑÝžD(I©\F÷x)–ʄáZ_Å|ÃãÇ–6¯½‘ÁÍwiÛ+* iqëÊynÎféê ì·¸5±D ¤¯¯ƒˆa1›³èïíáüÙ3,-ÌpâäS$Ú:R!„¢TtúaU*øƒF¿-³BÕ‚€ßÛxžúÜK)¡¦Ž*•Jd2™5óˆF£H)Y^^¦Z5B0ðÆ/Vq~ix'’PKQ*kNåRÍðR*•†Bµñ(²Ý J¢{|ºV§š*ÉV+9¿¥Í¥3rõÊUv>BW"À^{"BïÁ#ìŒE¹|éùL†GOÐÞ–âöT‰‘¾`£ÏåR±Ñ@(„§Þb¡9ýÐ<><ºæ¼£ ¡çž \<hšz³ÞUPÌÎðÞé‹”«µ<ÃBcáæ)2Þ^toþé7)Š´Õt!/^ä~áèïïwî%%榄 %m¨éÔ5!øàƒƒttt ­•üŸ¶UὟ¼EÇ®cŒ¾ÿ–óYâ‰0YÓç_y±‹ï¡bCÙ3à,,Êf¶µ"LÓäò¥ LO1¶T& Hÿè##IŽ>BÀ°ø£oý'ºã}d沄ƒnO-a[y^|îI&®Ýäü™Û„â~R}1.\œaçÌeD¬‡d‚Û£×tÙžºIÀoâKDø©ŸúDq‰ó·æÙ³søoÿ€Ÿþů2Ò“¢RLóûÿçðò¾æ2EO‡w"¥têÚb\_è,ËâæäÓó‹x°°bANŸ¹J{GñD„DgœÙó爄b ï܉?7I~y–h²”"3?ɇקٻg§~øŸù™O£ÕR›V iN}x•ƒGOùœq“ £¶‚ååeΟ¿°ò¢¨– 䊂Ÿÿó?…”’ë×oN§š RÌR¨xù¹ŸýÐuKÏsùæýݘ¦‰Çãåå—_¢°4ËÙ«·Ù¿o?ÿñßþ>/ÿÌϰGv¥ÀúwÿÃO?G¸Z¢p0Êðð ®púâ ö8ÌúÿýÏ~þóÞ3€4Kü—ßÿì:r‚®¤ÁTÁÉC»kBM°žÃ…‹‡kO͹”•Ânçä“Ϭœ4[mi.1Ä‘Cœy?ÇK/¾È®]»R¢:óós”ŠE„€ëço‘ˆëL/Œ1xà9äÍðuôãµ£”¢Z­réÊu"Ñ8±xŒ€Ïfo_bº óTw’ …*'O>ÉŽ=Cüûßû:³3ËìØ±“ïüèú{ˆù5”]KÚÅLúÈâìÝ¡ÑÙ5ÈÅË%úÛòhž ‰¨bp¤}>Kß‘C0VÁ·ëIö&nceçɤ—yÿ½7vv3<ßÅ`g;]!“)M["J¥ÐŽeK4MgoÛ»÷Ó=²ƒ!ùÉÅ‹t Å+QÃææ•Ët¥N2zå2EFY6ý}ƒ|ÿÍŸÐÓÝI2` ¡¶;·‘õYJ¢^¡£ùÃäò9º:Bx½6•ª†)}CÃ}‚!/Wôf$_¶Á®rþâ½ èŠB¾àÜ·¶ó÷…’´ù%ç®ÞàÙ#û –H)‰´í†Z®½­W^zQcÐBqîý·XR‰FÚÑÇ5Õ½MÞÓæ,ÔJQ*d˜Ëç9üÜ ´=äó‹|çõxáÙ2/'Ò¶‡ G#¤+Æo\¦¿'ÅìËdìʲéîâò÷ÀtO7]_mœœ¾ÖÇIJÉõ›7xûÒ%Œ¾>Žy‚³ç>ÀN ±s°ôØ ìbÓ¶Yœ™EG£dê,ܺMG ÊäRž@l°×éÇÔÍ+ öu°tû2K¦eJºú†¸øÚëLööÐ 4ú±9å¨ Û«‚@×VtÐŽêÆ \¹L׋·‡ŽvbhZÃEÒ¶íF*Jg‡î윪™K\ýÌ͘ĺò'mÚƒ OL¡”D¨ä—øàÌû˜–M¼½‹ÃG3~þ*;vÆÐœ—óóóx  “`$D8éÇ”~榉·£¤jRÙ(f¥‚iè¢ÂìXšÂr–öŽ} P*å±0BhDCeÂw{”+7ns¬}‰—ãÇŸ ³3‰RyD°ÊL:ÅŽdŸ²ÙeN}0E[[’î¤l$ÂþD‚Rz‘òü"ÝOǰr9bí=´…ïüä'(a°s¨Û¶ñ…#(bfrøŽ”ÂÑiÛÛ–8ÆEOÿ žDryŠSS¼qŠ¥ nñðöÇxúÙ#´Ù92Å*~™¡X®"* 3sì"U.ÕÔQMö!hâ½Üàäþh™;¹ÊíUôô-n/•Ù¿g7.~À­ù /¼0Œ´¬Ûˆ&½x–ѹ/¿O¬c„Ý]¡!‹S${{©”ªd'¦9vøLÓ$œh§7éçýw~‚R‚Ý;‘¶ÇÄH0qk–ÎCýdFRÊ•~ AÜÅÅ y.߸EfqžR:K¡0G»e“žžDi‚ÂÜ]»waîæg¬2Ëc“úìq,Ó$MÑßæÔ{ï $ìÙ5„’º×O ÚÆí3ôrú!ÝT«.Í3£o>K$B9*MLߺÄí²àPª£&ši²ëÞ!¢±ÓíÚ+íáä®8~•æ†O‘ŒÆ@J”èºÎác'ؽk'Ë‹‹ÌÌÍ’-WX.öÔŽiV¸~ý…JÏ>÷ ©  ÍÒ ZlôW`Y&Õª (”€PØËì™iÒU]=q¦.¿I9¿›Ï½ò,³ãט›f|±‚78‡eèV‘ÔR•¹¹ Ò”ÈÎ[Ú;?ÇÕñ ö8Š”ÇŽcv9ÁŽá.:â~ôî8ÅþÒ…¥’°-ŠUË– 0þƒ÷ØûäIF3ç1MÓR(¬bÓL ¥Â¶-¤-0Í*5Ý “£W¹8™¡-aÇáýÌWÛÐ Š!O‰¶övvõéT2YÎO^#Õ;ŒVœãÒõ[ u$(iR4MliaZfcŽlåCå—1«´šýȶmªÕ*†¡7æÕŽ1sê,ç>8Owo7O>y¯PTªUGÕ%-nݸ¹/âwQ*—1|¤´iï¤/ǬV±Í2œ»ÅÈŽ˜–I¾¨ð*gÎL˦g`˜ñ¿Çà¡#,ܾi™T- eéX…eL³ Û–Ø–eYµq%-¦g3ìÞG›?D&&MÑ‹0=Ÿ¦¯=‰îñbÛ6ÂãŪ̑&0Ë6vÕ"[x•IÅTT-‹®¾!&ß:E÷žýäçg1- Ó´‘–æ¦Ù‹mK,Û£¼®‡‘‹GÆÙ³g9yò$õˆ`]«íR/¸À´ªäsY¦Çoqîò('žy‘hШ-`6333g—®kd³gs+%‘p»¼eÒé"\ºJ¬k˜xÐpt暣ê±m¥ÑD’X2…óIÉR•a¥0 ÇŽbdÏÒ¶QRaÛl£ŒDk'G`Õuð¦Ya9[æØSÏrùâ%¦g&z8rð¶e'Þ5@ßËOáMÏðöûïjáØÁhK%Ñ«òWÇÀ¦¤ŸËoÝ@³Ò2±=³T&ŸO35Y[ÃÏ2—.½GÅA(–Ë&šr/Ãâùϼ€áñrÍrŒÆ¶YÂðGC²¢U7Èj‰üìþp³fÏ«ÂS`Jù!U¢\­’ÉßæÖ\ŽDOÇúå(gÏRŒñ†‹% ¿’‹EæççBà ù¨gÑRRÖì1u;FÝŸ 4o€cÇñíï½ÃÎ}ûù li‚b!Ã¥ (I//~þ§X¿Î;o¿Ë“O äóâ G(åsÌç²Ü¸~-ÖÅÎþn4³„?¤X(šD5ç]Ò ϼú<†ÇËìÍ›HÛƒ´ª˜2C ¸»v­”lDÈ[–‰7ÑEO÷{öŒP±Læ§nðþµq^|ᢢB¨½ƒÙñÛø’1²eÝ%ezPUI(óE“”OwÔeº—'_~Ããåìô$¶UÅ´—ñF‡k†Åjo*.fè/¾øâowvvhkkC× ¢á0õ…@˜»ÅÙ³RÅËɧŸ¦¯3áŠq°ÉÉIæç晞™fjjŠ`0Èûñú| ,Æn]âÒ•qºv²{¸¯æèImlÑÙÑI0XñQ OÀÃù £ `èɶ^¿¯d4?9ÆÌ|šÃ‡÷¡×úšÍæ(rø}ÀQÌÎL³¸œÆðI$ø<Ë‹óXv•|fŠ øª’¥t‘ãO>Mܧ¸5>…ŽQZ^ ¤ ºÚâ,ÌŒìa×@’‰…EÂk—¯R,e1 IGW7‰ Î™w/±w×>l»J¾,èHFÑ D[²æšê,øñDŒJ1Íäô{÷ï¨y U«U””x}^çJËdææ% F”bAâ÷{èëèâêg° ó {™OÏ 5‹j©Èøí[ŒOLQ5mzzº¨˜%Ò›®ö8¹lšål†¥åe„'D<âåÊù ${ºéLÅPÒQã•Êe|^_í$Q‹W 0BØk“©JRñh-VE±´¼ˆÔCÜ¿¿Ç žJAµˆÐ½„‚~æ¹xéËÙ<=ƒ;Ø·k]M×Éó,fLº:èºF²=Y Lsî‰EPV‰Ñ±IöÜ·6†¦ib[6¾Ú;!4D4Dzjš`gŠë7®S’'ާ§#FzyޱÉY°%±ŽL¡ Î^š&Ñ·¯_2»X¢§3…¦i$Û5/9§áhMU¹qã6{îÁ«¯ôÃ0Ä›`G_[c7& m.Ÿÿ€Pç]ŽªEÓãSÌÎN‹„©»†f³94à  ¡iÒ6Éåòè†À¦jŽÂãâ÷yI>—Gx|(³Š/Ä«kTÊe Ÿ EŬ¢ '²Ûç`èZÍ›Ê&—w\'­R†kc3ìÚ½›€Wo‰„Besëúôhý‰†÷L!_À–v-I‘³óYŠU¯×ÏïÃçÑɦ3h†ÝÐÐt‹L®ÐØ1kšN,îæ¹zs’»wö{V\{”sKN÷ìÁohµyU¤——‰D£†gͼ‚IJUÚãê.˜õø ç¿-ÛBJ…¯F7¡ê»f9Ç•ã ïÜM$àY5Nbüæ5L_‚áÞöÆ=K¥"fÕ$kZˆkv#¥ Ê•*áp¸ñÎU*%ò' Ü0 Ð <¢J¾b‹Æf‘Ë×o1°c7± w~Àä­k”ô(;ú;ý(—Ëzûúô·íÂÅ–!„à½÷OaY—/_FüËù/U("³oß>|>íím+\¬ ÔÜ:uO 9Ø ®ù¾õr¥œÅÇcè-ô J9znÝð4î'LMO3==E4Úü€lý‘6 Û¶`3mý .YsÅm®-‹Ø–µjÇY L[ܶZU±Q•£ÚÑñuHÛB ½‰þÂi‘0žOˆ£g£þÕ:„m[hMs P.•¨V«Dc±MÿÎzÁqÍãx/ý¨”ËøAúú>‘±ráâ~bµ@hÉ©,-ÇFÝG\1ÕªÅ~3÷vʆ¾ª?µr]7ZH‡«ÆÙQn½n]õ!7 ÑtÝÑÛס…3çþ=ƒ&Öï‡Ðô[íêH[ußûp/ý['cÍ8ÕÕ•q}RýX e_™îÂÅCˆ¶Sœ¬\*RÈ{ÏêfÆíš0“¶E6“á¡Ì&.À¶,l[¢²Ùkš&…|ÞXÛñE`[6¶m‘Ëæh?””˜U“‰ñ±=*.\lŽZ?¶¬”FS½ãÁa[ø‡ÒµÚŽDîë®ñ“Æ:´Ç²]·Ë#ÿãÂÅQ(äÉgs-6úëúKmY6–yô×.>¶Ã²²úð(ôñ a°wábchš†Ï룠åi~_Z鯅 —Í¢¤tÔ.\¸pá⑃RŠr¹Œ×ã¥ùDÙJ]¤Ói††GˆDc< ;%·ÁCŠí`hÿ$áν +XMsá܇IcÓ5ÆÚF²ó°/ ¦i233C¹\zÐ]yàð:»ºº+Ÿòù<33ÓX¦õÑoæÂÅ6A8Á2MLÓÜ’©ÈïÐÕÕÕp%¯çòX½Æ›¿åÃ!sssèºÆŽ»…ÃÎG ÒËKÌLO3<2ò {ó±CJÉäÄñDŸÏÿÑoèÂÅ6€²™4í‚Á-92ÌÌΰ0?OOoï7ú¬@¨V+ôôö‹m-Çò£Ã0X^ZjIì󨢞[bhxäžÒ€ºp±]q[ÚDc±-ô…˜¦ÉìÌô]¯Ý’@XNòžÑÈüñ&B«ñólNýÕºX6'ê|4 ·8ØÍGÊzòµA}}N·‹àµèëG]ø¹xü°:Eîݯw®ÝÌ÷¯ÝõŠ&‹f7Hc£<»u´Ðj ÑøÓ4Jvž·ßz‹‰¹\Ë}êõ+üHâ#}КÈzn‡Õ9~Q+%,©n¸B*…2VÕB Óª0³\jðò<Ì=ÔÖâ3J¹b#GÆR®@¾"4Ò2ÉòȇQ¥T$ÎbYÒaAošÓ•¿µïÆÇ!Ö§öPJQ,”×lBÌr³ìÐhKi1½TDn¹æÂE d n+ß>Рü¹6}BЄÅw¾÷]tw†‘R …ˆÇc-˜³“´½~#ÙGgÀæÆèU«fÍÖ4–.ž!cĨXKtE7Æçhù¹rõ:“Ó „BAR};銰T°Ø9Ô@­û‘ß u¡RGµjòÎ;?!_( ìç¯_¢oð( ¿``pˆÞ^Ξ:K²£—L¥ÊèÍ3,5»vòüÓGHÆ<Û&þh£ç݈§Øtf/¥`âæunO-ÓÓÛÕ[£LÏÞÂçocdø0ûû½¼þÆ;è~T2‹è/Áø GŽ"*L®ß£»„ÌÌ ®ÜšB×½ Œì§;.¸5½ÌŽ‘a -Ïé&GbEèH›K?ü6× e+>|ïGŸÚjÏéçü©÷ñ…Û†‡«×N3›©Ð×1Ä“Oœ ¯óñ0»x8 ­³™ºÛw_Çf>³M !¥Ì™¹3Œé{X˜ÌÏÏaÙù—ÿBKdp!»Äù?d¹¢ñLïN àÜ£~/%°bnåªüÂÁç>ø€Š¿“‘Áû½ú-F††î% Ûœ}ÿGøCaúRQ Å2¡ppÓƒgYVSÞ[…¡Ûø“´LŽk£c¨å…ø‹3aöîïàÖµ+|pááÛs¤½í”æóôƽœ=?Íýûka{J˲Èår$ „X–E6›%‹¡ë:¶”ÿÓ& ¤ÉÛoÆ6ã ®ÌÌ2†rf‘¯,±o ‹™\Ž„-¨˜iÇ/ˆ$Hy¢Tì27®Ü`"#èë5yÿ‡oqðÕÏ zÑ<¼>ÁâíwPº—½Ã½ä³yB[ #ÜTÿkß4MCI‰=?A®ì¡P±™™žav6…ðùÐ ‹¹ÉÛ¼óþ%â‰0¥ðScKììðqéÊ}\àb[Á‰;¬3;ëZ&“! áõ:‰šÒé4@¯×Ûh'm‰± {ÚæTFJréâEâí#ìäéç^â…§÷£ù»@I ¹4Sãœ~ïþÏÿóß·=¼òÒóÄ^<þûöæÈ‘#ÎßÑ# Æ{xöä Ú|SÓSìÚ5„×ë'ÕÖN<– -ÕF2Áгc¸3—&Èç œzûÔ–Ô ¢Åè!ÐE•ÙÒùɪå2;öáŠ[ã*¦‡þÈŽaWÒd*%†‡Gèé'‰¦mOAPι¹9~ã7~ƒ×_˲øýßÿ}þÉ?ù'”Ëå¦yÜÜ3è†Áξ‹s³T “øâmô÷öÑßÛG"âE Áòåw™¼~–…¥ÊU‹\.Ëõs3ä&2LܺÊÈž]üÚºSLNM#щGýhÞ »wðá•Û”JUÞ}ã]¤}ÿ©Fê6*axØù©/ ûœä~µ÷'oãsÏí «»°œ¡\ʲ”[``x=]} öwá5¶ïœ»x<¡¤jÐÔT«UþÅ¿øüïÿûÿN¥RáÝwßå×~í×mÙ «M†Ü}Ë(Õb[…xþÅ£Ìܺƛ?z©kÙõò—QÊbfò·gK  Œ%éï&àqv¥P—dÎÇh—3\¯ðÄp‚l¾‚V$Cÿ¼XGÿL S8u†È xòù“[VY¶…UËû«I Ë4v-c™m!°kYÛL2ÓèZ]jéq®ÏXœË™=1 2eù6dÂ|R©Ï<ó ÿôŸþS¾õ­oqîÜ9~í×~ ŸÏ‹e™Hio’ãI`›Ò¶ERù(Z‚`a”ï_(2¼«“¡?†¡Û‹9?†ö ðx} ^Šy‹âb•ž˜t'_þ,·Goræý·ˆtíæ™£»&(ÍÜÄcè<ýÒÓhú–LY›žûú«’³= î:@{o•ôT‰#GŽà Ыræxb„”ÎR~Å´ÉåÉO>» ¿‘’zz]¸h‚“”I×»B>õ©Wù_þ—Ì×¹qãŸùÌgèíí¡Z­4elÛBÞ‚Rþ ÇŸzÝÐiO>‰~ê nwpxg? áÝÇØ±OÇÐuÞü±Ï1|4ßC4åbžS?y_[7] r³ÓMb+X9Ì´¶UÊD^œ [ÛI !jAÕš@0±- ¯¡3¼s'‰a4,–rKX¶"TȰ»«“l9Ê®Ã1>¼1ù³LÌåx5r²™mS•‘‚Ÿÿù?ðÍo~“¿ûwÿ.Ï=÷¬À‚£Rrøþï:á 5Ú5“Xç³¾8Ý{ªüY¶ÀÕ®±ÿÄQf¦géd÷¡a––§ÈÍÜB)ˆuúˆ&=èBb*0$(áaçþôu´ñG_'ípæT7 ëAÀ !ÚÊîhtlœ¥ÅEæ'®pyþ<á‹íŒtÆ‘–b8VeOgŠr.ÎÐHŠÉÅi¦nz¸~c–O}®óAO« -PÔHH¥ÝXì;ÆoüƯó/þÅ¿àóŸÿ¿ôKÃ0°,'(Sá$ÛÄ·¶iB¡˜cvjŠÛ·o“«*þÜÏ~‰xÐÛè”’)º®¯ñ0Z^˜çÊ•Ë,,¥‰¤zxñ‰£è("± vÄÏÌRþ¤cƒäîBÒSWèÚÕK.›çì;gxés/mzQ®gmkä'–’J1‡ˆ§HÏÞfta ”ÄïIà÷™˜Œâ«äJU¸:qΞ=DžïGj7˜^Ê0ÔÛ¶FåºïýÏþìÏòÅ/~‘`0XËU]ß!8Éz6ƒª K ùL”Š©¥0‡îÂØbqn’½Ïd$«cçM<úrÃxïñWЊ@WŒ±Ù ûz\þðs9Ê¥÷úý<%Ô=«jÞMwïdtT€fðwŸÿ 3“¤ºfêÚ¢˜`(%¹yݶyæå§ñxãm9·ÄíÉñgú‰„|œÜ¢ÊhE 8©…ò2I1‘-“ê ¾¬”"›™eèðnÌTLàW:³7Çè8<Ì@¢¼PNž‚ú:ÜõBà÷ûÏŽˆ†‘usn¼^¿Ã¯>…waŽdg€Îå7Ç9øìS óx /ú;˜¿MV´ŸD aø(‰{vïçÒÍ«ìèzŠ]ûvÓ],#4x<ŽUÎq}<ËáCÇñû=<ýÒS÷W@í4©6¤Ù±1ÊÊdzÏ=O4äg¸¯—k×®166ÇðžaÚ¢QÞ*ŸÅÑqrí1 ¾ÊBõQŒFqñPCdm“ÛX‹š¾{pNõ ±ú»kKYKuglJ (CC;¬ñom¹N1<<ÜR¯”¢­£ƒ¶Ž•kê-•T í=„aË’h†  4®QJqüÉ'HE0í`(¸5‚VËí\;^!t|#‡Ö{ÆZŸwtƒRt Aw{;N𜠊#e·{Z¬5ãÓ4–RÊZÓ;?ƒ¦i´¥ ‡Ág^‰‡PJ1ØÓÅPo÷úã(ˆ@Ó’„B¡H£¾Z¶Øôm© …C‹®áz'Ç2ÜTÇ8|ì‰Æ¿CÃŽj(t×_T üqL µïxµú|½ïš{”¼O6„¦Ül´ïfÊêšAOgG‹©??’" X[·IhBk¯Vܵ>¢GËvÕÝ¢ÖoU‡Íˆ4µŠW½ ¯ çChtvt¬{'¥#$îyN7û¼­f.\<5•‘’›×VÔÒ±ß?ÂÇ…Fm¡i¦e®9Õ(¥jùŽy,ÊÌjµ–7û“9áÜi¡ÿØ ó5 ˶1jêÇÕÏí–¹ew*[¡×¹Oe«rnßk™ZÃc°…V†Ö調¬Îe´l ðq!žˆsûö8™t¦…>¡Ù»åq(sò§Ú´·µ?è)ùD ë:ÁPˆË—.âõ4寸e¨¬nÙ–ËlËbi±\_QËë½BO±Q™RŠÞÞ»;H<²A)E$e÷î݈eg|š¬.u?Î2§à“-Sªé£tÊ4Mkp¡?èêêZã&¼zGå–¹e[™aÓAó÷^7 ®WVogkVã‘ux<ž–îÇ«í„ø|>—íÔÅ#…õ„ÅVÚÝ ¼@€O@gíbÛÂ{">®÷ú‘÷s‡è..ÜÓÁ½Ã}×O<ÒÁ²,––©V«ù^†aL¦{õÓÂG"§²pÜ 5¡¡[Rû)°,Ãðl)²N ‡Ã´wt¸ÙæC<²AÔò£ ««{•ËÖoF6“aiq‘®îî{¼‰‹O JNe!ËK‹ø|>ºzz·”àH*Éè cl’ö¼ö£ÌÏÍ’N§×0¸xôñÈ Ó4‰Åø Œ1 Z½d½@ªú¿Ã‘óŃ~$›À£’SYÇãÁ²L¢Ñè–i[‚ÁÑhÔ9%lá7+å2™Ìòƒ~|´@€Ê¥TÍãÈÐÖX^^¦\.ãõzI$øý¾Æ‡g™&•j¥é'yÜXmî–S¹QÞ µÙ¼lsß‘œÊ«Ó·nJJ”r8¶ºËw¢aëÎðÛa6]|Rx¤‚³ Õø{V®]»Æ¿ý·ÿ–ï}ï{,..Fyî¹çø•_ùŽ;æ\W‹ùV56ÏÍä$}”PÊ D‚h²¼?‘€ŽRP±E.³´)‘Xœ ßWº•´§Îx:¬¸ëGrÞ?l”SùaÇ–ÂÚÕƒ47¢“—Òá½qÙ??|rAI¸ ÛÞfsƒnBh­»«Ú­Îž=˯þê¯òöÛo·ÜÿìÙ³|ÿûßçw÷wùô§? ª•[éQ[`6‚RwÊ©|ˆc{S¼vö6‘ kñ ãã3!Ð=ž~åU†Û×Go“ìè`b²Àá}},ÝàÆ%N¼z’âü-¤†Vª`D:èNmMrwlŽÕõ“@)Ÿæìé³ä+]ý#Ü;Ò$ %¼û¡D/;w 3ví×nM¡{ƒ9vŒdt%]ìýMÓ¸qã?þñùÅ_üE c½%à£QƸxx±)ÞáB¡ÀüÜóóõ¿yæfgÉf²›ûð„ °´D>›£R.S.—»Je[ LÓbnn»y«$Kó³˜Õ*ÅBÓº—ݹj,êÇär9þÑ?úG¼õÖ[ë.B/^ä·û·™ššjI²ò¸ ‘Sylì:ï|0Ê;WfÑ-'§òù«iN]áõ7Þã{ïžçVa_ª“þ^„уfú¹yõ"óEüºÁìÅw)K“kcÓ|øÁÛäl››×gÉÌzgß²-©”+T+Ý œù®çT~°|øî)x=´‡ëÞáút¶Q;;vƒo÷“cS”—ÆyûƒËì:p„ö É~rºAÃè¼{+ièºÞòW¿®åµæýB0>>ÎüÁ4¦é†þX½ó.lê„à÷ûk\ÛŽNQA>»Œ)µÍíâ¥E¶RÁP`ÙŽ^Þ¶ ¯¿—åå š7ŒPŠìÂ<þPˆh(@©gn.M8š@C’ÍfH¥’Ø–…&´M%{¨‰UíO§Nâõ×_¿c»÷ߟ×_¯}ík„R(%·ÁóÉ žSùÍ37ˆvhøâ]ôw*,[³<¨`Š}O¡ªÈôkQKH£ ”YfüæUFžùi¢!Þ(·&–ñx‰>ÂÔè =M²k?>ôs—Ê¡Çñøüì>°ë¾äX®3¼>HXU‹ùÑYžÿ…ÏhïaâÚ8»ºPHÏpñæ8‡Ÿ8Žßk09:M"Î`OÕd€·~ÿ‡T+k]f•RüÞïýçÏŸo1˜ÿâ/þ"‡r¸ðÓ"DFGoòïþÝïqýº“jñ7ó7Ùµk¿üË¿Ü8)¬äá} CçâaSA×u¬jtàZ.P*[´uµ9YÈ*•UFW‡gÃ[£(æ²øƒQÚÚ(¥(å—IçÊ®R­ViK1ËE"Ñ(v¥DÙKU¢ñ8B€?"SXÄ´…L–P8ŒÇ»Ï T5ªØÚ áÚµk,/ßÙƒ¢R©páÂ@5tÞJ=.Á:wΩ¼cȇ¤ %¦åÛ:ÞègÇ%)Ÿ¢RIRX4é‰ùº‡v-J~æ Ùžè´™^ºMiZpô˜¿ö>µQ˜™æØ±½ØRÞaµ…í¤RP1uºó]è‡m–*?þÑÛ$öaO³”.â!Œ§–HVè~t»ê¨Y)íZ^ìúÖÆQý4ø¹ÄÊ5vmüÚwÛI[ÛÌX–…¦ ´ÚfÊùÕ¸¦>n¦YEÕ<µwÞE›´!l«B&#ðP(”I´µãÑ–eS,Ö¼8š®ãõùAI:ñx i[  ˜+Œ¶a™6šÒÐ5¨*Ð Á€…¹b©v”Ì8Mº¶†²Mb‰8š®oÊ'[°L«AræoJ+w÷¶iKªÕjÃ#i«9N¨;æT>øÄQ”¡¡”$Ÿ]fúÆ;^ÝÇ•\‰>sŒbz]SGBÏŽÿù»?fçÁ“´ wòƒÿúmR»á©mI!üÊJ޷ŧ9§òƒ„aâIÁXºÈî.…ÒF|?åÜ2áX˜ja‘›££H©1Ò±“ë…PJC,ŒVË%nYvËû÷•¯üüš÷ضmÊåòÊ,*éØÚŸmÛô÷÷ó÷ÿþßçµ×^czzš¿÷÷þ>ŸÛ¶' MÓ°lë1y×]¬Æ&‚ÂŒ`ägX\®Ðß߇¡;^ š¦‘L¥Ö]h£§F8÷Ïb.C/É ³T¨©V®÷B$SÁp€bz¹^á0wÖŒÄÒÚ\~Еã¯ó'mÉîÝ»I&“,..nØÎï÷sðàÁ59ôóIáN9•çç¦8rb€©Å"Z®L¤¿¾þnYEzE‰HÈG®–Sù@Š@¤5æ¡ãX‚p A×Ò Cᓺ†UÉc–gh8Ê•sWðüì>°û£ŸÔJNå ¡{Øuâ)Þ{óGÜ û°”‡˜ÈsýZžç_ú q”j¥Êž§2þíïño}³˜ã‰cÇðÖ‚“•’-ü÷›á¶¯»›6gײm›R©Doo/_ûÚ/"¥\s/'«ž#·ÝE3¶ÂH"Õ†\\´-4±¢¿¼ÛbY­”) ˜–…fxéèh%Ñ=:¶&¨˜ÎQÖ0 Ðþ`%%º¡£iÒª"4Ãë!³°H(²9•‘#°V‚-mŽ?Ág?ûYþðÿpÃvO?ý4ŸúÔ§Z>B%ÂÝr*'C:'†cxFqßcnv’A/de˜¡Ž!öÆÚ¸tó*#ÝOãõzùÊÿø%<hðâ¯üèž JJ&ÇFñEèO°Â»œä÷Ae¤hÊ©ü€10²x[åªE$G§õ[Ù{hoMéå¥W_%“É£y¼Äc±Æ5RÖöMnH+±²9c €Rô÷÷388¸r2h'MÔÕIÚ·Á¸øä±%·S¡{ˆ'â i[ YQ€/"âõÖ8¹k|Þº‡ßO©'‰H%œ€˜ZpS<•Ä0trËŽ BMÄÐ }SéàÞ¬­H$ÄoýÖo155Å~ô£5‚ìðáÃüÃøéìì¤X‹L^Éýà˜O›É©ûéÆÈ¨Z¬†’6"Ã2m|>P4ÒÃ`Øq1UÒ&Mp²¯ ](4Ÿï¾>öÑ h,AtƒêæÇ ­=°æšÕ'„»Áˆ²Ñnµú§YETûÆJ!U“’¸¶‡`xœw+¯‰×ëk| R¶zAÃQªæJ›æ—^Óœ£7Äë 4TT›P_Xy©kÿwàÀþ¯ÿëÿâßÿûßЧ¦R)žþy~é—~‰C‡5®_éz¬ÓVçPXCéQÿÿõtÍÍ9•WnÖz¡‘ìè©©wîoßµœÊJ:Î ›=!8mdMðÊ-Ù4!¶íœ°pã”7|bi'dx½6|õ„ÀãõßÓb,„Öâ‹]7® ñ[¿ù›üê¯þ*år ¯×G,Ãëõ6> Ff¢ZnÊm±ã|H°™±úØÆ³žSÙ²0Ve‰{Я¶^¶òîn•˨a?Û )žpÒ­jµ!<ŽxH¨+>«¹ L©T¤R)·T !Jk%vÔæ¦« Ê®@x8ÐÈ©|ù^×ÙL4-ºuZí^&4B>Y­R®”1«&B4MkسLsý2äs9&''Є¶áu«Ë,ËÂëõÒÝӳ铸‹G‰@¸7x½²ÙìJnaVíJk;É»• !(—Ë•ò#¤Šx”ÑœSyûìö·^ÖÞÞ^‹©P¨&Cy=΢/°^YC »ú:J¬_†Rü»®ÂèñÃ#+”RÄIÇÛ4±mÛ‰:®}(B¤e­-³­Zrê•2Û¶ƒÄ W<$ps*ß;Ü“ðã‹GV @Í[¦­ƒû±&ÔwY..¸‹› ›Ç#-€š‹ëƒî…‹÷tpop…èã‹G^ Àã»0<Îv©Tbiq¡Õßþ!„“ýMC7¶˜ù­‘SÙ`+Gd‚AâñÄcˆéb¼@¨V«X–Åãh Ó5½A0ø8A)ÅÜì >¯¿ßÿО…d2iü]Ý›WY GŒŽÒÕÓ‹aè›ý… —ÍÏåˆÅãõ¦âqÄ£+„ ŸË±´¸€Çë}нùäÇ­0ŽH&tw>QÔ£sc‰‡{—['UÔ ŸÏ·å8ǃÏçÛ ÎÆ¿Y.—¨–+úñ]<<²Aù\–d*E"™zÐÝy ( ÌÍÎÚ«¹]Ì&VµL¾PÀ¶p„ ßá“¶E.›Å’Ÿ?H8¤\ÌS,•B'âõµ×¥ž|óäv«Ón6L¡P`ii‘ÞÞ¾;ÐÖ»áqÄV”‹XùºßKÑRø=†æDFÚ–Iµbá ø°Ì*¹R¿×ÏçÅÐ5”´QÔŽïJR­šNJKMÇcèØR¢éú}"Îq{e·Tã¦Z­¶~†ápÞH»‘qª³˜'W,ã ĉÅ|T+µ¶µ…¼Ñ¶åû© %k¹}õZ¢ ^癯  ùÞ=<ýê³Ë¿k¬±Rn,ì6€RŠtz™åì2>¯IÑ£Q-f( /z\ŽDš~PR)ÉesøÂ1 ]Cx½$’I„Ð@Ù,.,Muà÷HË"É‘h뤘Y@*D2Ž”ªF¡ ÈfÒxÛÚP¶3Î[=•Ôs_lcºBá†Á6Y\ÌàïiG‚\fK  {ɤ—QÒ¦X,‹'±Ê9–ÓY:ÚS+wÙ âºù™×ü»ö×B)¥b‘ÉñÛôôô®{ŠBkIÏéâñÁ¦‚UΑÉ©¤ xÂA2Eاáñ‰†ƒ,Í-âñ{)T,rù,>]QÊ—ðt$½¤Óiü‘8~l'1¦cèÑHˆb.ð†ˆý÷u³\_ /¼rŽÃ…BÞáŠA`š^:;Û°¬*ÙlÙ” Ô,e15?Go²&;œ?Àãñ U뤤M!›¥¢ O Í éLo L(@ÓVɪ)ñû ']âV°ÕBdÍ¿ëÔÚ–·ËB"‘&6þ@‚W§b(Ššp$‚@Q5«˜U“R±H6›¡w`äÿßÞ›=É•dùyŸûÝb_rO, ±ÕŽBªª«ª÷eFš5&ÅYD3’2½Q| h¤‘Óä?0zá“hÒ ¥‘F2l$R£Ù§§zX=Óݵ/(,…}rŒõn‘™2Q‰B"q¿¶ìJxÞˆ{¯Ç ?îç??2žÓ¯H›HÍHS-g1h¤t(WGÝ´ÈÕÅV4ëË„ FÆFX^X 2Rű­$@= ZdÙ.媇{Ž(ɸY—›…1É`ø ™BÛÁ]Ôí õÚò¨óh¥’r.ø‘"o bÉgtŒTÔǑܷRÉ`ßssNLL2995|c†ä0·ÙŠ!p\—™ƒ‡X\X ð}fBH9$˜#„èˆmÒ)_)v­V#—ËÝýÚh:í&‘ï£lA@Il\À"“ÍbAh»ÓæÎ\D!3>™#P’\WðܶA¬X³-@H„14¹b~ µQ†áP«1šV£N§íãå t:u(hÓ Û"#l'KÑ+®z!X6Qâfr8¶CGD¡O†ýÃCç×É Å–†`Õõm†}ûpñÂy>ÿô*#£ìÚ½§?+Œã¥|§nø4 ”b¥š¸yz±cÐ}íâ•ÛE­VÃr2ŒW˜©ÑX®S­âå\jˆ|â0¤Ñh$φL.“Ô!NÖ£U_Ærr›tõ|îÛvc‘…¥Åb‘V³0I\+_ª°\[¤cIŒŒŒR_Zban£¥b±?(f %ÿ¾÷½õµÄ^%÷~<Ïcjz×€KjÕûuõËSž<ìŸþô§üê¯þ*Å~ p¤äóÂPà t¤&Ÿ·‰}ƒŽ5&Ð8ÒEb\±Ñ2±¿€°m\:Jáà+—˜_\FtƒÖày–T™Hj6—·Îe$úé’+_¦8i6š8n–‰]#4k‹Ôk”*¥þIÅ1aèÓîTGÇ1zev†2(­QQD»ÝÂË—±„&îº”Š‰¢¨ë>MÅDQHà8Ù<•r¡{ìƒß£ëe80sˆV³A©\ITæú?ÏLYËv(VªØ¶(i­³SÖ’’ѱ•}I©2‚c[ýãó¥2Y•(p9™n{ßɸ.åjX–…”‚v£åæñl‰U,`YÖ¦wÓŸ<úYn&_aW&ÐÔR2âxhm°m)Õ‘ÑĘ ‰ã؟݃¤œ®¯vgŒÁËd˜ÌNßuå,é á Å>vìØ½¿8"q´[-Œ q§ƒc ~[ ´ƒ°rØ… ®‰@ZÄJ"-ÅØÔN›\¡H½Ñ¢ñp¼<£#íN‡ãd°,IÐna[6®c ±e.£^†Ï°APäK²žCÇdòhwèè À÷}×c|¢‚†8^™e‡A@Ç÷±,›beϱ‰£x8“T<Êꢛ6ù¸¯âz;è7½SYënµØÍïTÖZww*?D9¿”mÉŽ5ÀÖh*¯þNl³Zû‹õÒ~Íuï]ô/H A»’Ï{ý#6Úg½ó$µŒV’V×6ºÛûõÓ‰wØgô ¥+Ö{]/Mùn»ØµÖ]Á§mQ*å+dg„õ4•»íku'×ÇhƒìÕÅÙÀ`´PJñî»ï±T[ê #¾öµ×™œšªu#¤$hÕ9õ*OÍ¥èÚ´š üþøŒï~ë0–•”|Áó¼{ž[Ç/_alj/¾û/žx…ñrŒæÃ¿ù £»f°E¹1v•ïaœÍÊ@Ç!ïýõ;Œí>ÈÁCûé4k|üáÇ4ƒ˜©½3<ÿôLWgc™>üˆ¦3µg†çŸ9ÀÕs§8wù&–›ãØñ㌔VÊÒoÕã&¥äÂ… ¼óÎ;üæoþæ]öj¾?ü3¨Æô !¨×—‡Ä=†Î­5Z'%©ƒÀ'¢®XˆºOmµ¦²énèõëu‚N‡å¥yZí~§ßñIËÀÇï´i·Ú,,,3wçµåV²ŒfE¼üñ«´q¤”=z„W^y…—çåã/óòKÏá·[ÔZÙpEW7zöú%þê'ÿ‘Vh‘µ-„”,\>MÛ?Ïç§Oñùç'ù½ßû=>?uÛ¶û¯]ý#¥àÒ¹Ó\máHÉ?þK>ùôFH–ç®ñGü îÜœ#ëJ>yÿ=üXøA¢I1øÌÓ­tûï¶51Ÿ}ü.?}ÿ·®ÞàÓwÿŠ–[奎rþó_pþV0|úî_Ñ´+¼ôÂQ.œ~?ù”_|z†ÃÏc<ñ“Ÿد|Õ{æz)ÍãÁŸÞqC?¬­x*„àÚµküîïþîÀ*lø8)-l{óeÇS6´BÐZÑnµTí £Œ`j×ôºÙ=mÝ!ŒNT Vm­oÔd2ÙµË|£Y®-‘)Vi.,€8ž‡ãeVÌr£M¹RźKíö5šÊZ±Üj‘ËçX\¬£u‘‘„´°¤Åâì2^Î"Ž5­z@¾äEñŠp=+©€;!#Õ ‹wîPžÜ…k>ÿðÇws`ß$q²¼¼Lmi‘K/ñÁ‡ò_üÆßgfï.¤€°µÌgçnóÜ‘#Lï=À§¦PQ%Ët:mæææ×œ3›ÍR)d¹zá ßø[ØÂ°wÿlž‹W¯3{ù"ûŸyÇ’ŒïÚ‡ýÙ).ܨ#k7°l‡£/E«•çPÀWîïP* ¼{†×_v°„­˜»t‡¯ÿú/QÉgŸ˜áúùkž|𹋷yë×@%Ÿerú¿øÓw9þúaöíš Éò7ÿÛ_k'\Æ~çw~‡“'OÌó7“^xa¸èâ@Ùl)%—.]äù_~‡óçÏsáÂ~ë·~‹Ã‡óþÁ?è¯VÜ‚_i×¥l6d,Ëadtleǯtš5j Õ—“ìþŒ¢Y¯#l—B!1†v³ƒëü°C¶8‚i/cy9D7ûÁC³ÙÂpœn!Ú "lF³. #¨Ž$.‡äÕØ4hùyÏ¡ÓjS( ‹ü¬WáÔo6ˆ‚6‘mQ›¤Q›'_(`ºÅâXa+‰ce™±pÊEšm…‰àM¯Dăj?.àÒ'i]¹CNÕ¹SùÆ·¾k ÂNƒó_œ"9v8Ìg§¿àÀîÉnytÉòü"»gžåÀÞQN}~Š3¿Ë›·xá­ÿ”¥Å%>ùôÓáÏI¦§§yæèšs!»Êq! Ï=s˜¿üË·ÙýÌ1öM7“ÁÍöp Z·oòÊ+GQZè•>ÿj±ì<û§óÌž¿ŽR  ‘EÖJžKx¨°“¬R#‹l÷²¤Gàû8$¼°2X*L&Pô4•£Dð¨{WRÊwžX9Fuû!YY+¢(ĘdrÖ“Æì‰ß$ÿ5ýczýEa_`(]%ÍFéxx®‡“ÉS(dè,û9Ms~ ¯P.¡½$FZ<âU~÷þ]ªŽñ+?ø6'q#8™ '^ÿRJö€ª™1šêôÆöXHKòú׊üùüßLÎcW9ƒ(OñÃ_ù•uÏé7›Ø–&î. ÖT&öòÖ7,ªÓ»ùägï­¸ìP鬫èO<ºÁ¬÷|HKR\©µ92åÐêÜÄ®<ƒ ª£2iÏ:4[7Ø{d³~“èÔ®A¹€´] ‰¨SEýgûïþÝÿrMŒD)…ïû+×`—ªîþ(¥Ø»w/ÿú_ÿk~üãsëÖ-þÕ¿úWxž7¤©,eRu'»DSîΕ;­~,™Êgº3M³ÙIJlÈ”)3t?ëÊDÚ&W´°DLCBƶèÍv„Ë<×%ŽcÂ0@#PZ`K& \Š%¼Œ·âŠ6B·±›œ•_ç!ÖTV:ÆÉ䢃—qh5›8Žƒ—É µ!Œ:D"Â÷5±%Ñ€N`(U$ßﻉ¢(^3#ÝqC¦0Âø=Þ;s#å€ &Œ´NŒíêÀ¤0??Ëí›×¹vý&îäa¾ùÚ+3‡Y‹—qÈOW¸tg™ÃãòÅ–¥]›/çºC»ŽÑšÉ§Žp"SHÛu‚´™L†ï|÷;Cñ"­×nÜéñòko2>VEn$…Ñvyúèóœºø§^ç{?ü–mu«¸*ž?þ´oa#c‹Ñ†‰§f [F)C>ŸZM¸ž‹À-”yíÕ,aÞú»Ð¥ÿ{HƒBHJå*¥uŽ[Ýî¸YÆÆ³kûeÕ á¾ýHoõ¦‡V=]DÝôÕBô'KéF„' ;“¥’ËwRÍÝ&¥¬ÍÚÉ… “-’+Xke¡X,­ûv¼,ùlL*ò…|÷ðä˜8 °3ržƒÖš|!¿&Ûiµ¦2$šÈå®ßÔq<Ï#Œ"´Rdóy¤P(#)”*Hn6ÇX®ˆ%4±êÍ:7/Mø8s¿h=óƒhù&H&'&î.`dbWß ¯G"±s³Dãxã+„ä5Ý•ñ:á^H!ÐJ Ià¦<9l*†°‘âZwû&Ù9wýÝ6å ‰óê¿[ŽGÑ[ "›õOºnvo¶5ø{²™ÉÇÝì C?×>Š7¥‘Š?D¾´ŒiW9.Šc¬î¾‡Õ¯}|Ú̦W°ßÑZ#7S¯kÒ“Éc²Syí£¹‘àzšÊw/}°2ãÜHymvxPù1Ʋ,rù1ÞîŒîmè\YAÜ«mhå±Ñ×v³ÆRùÑ'“û©÷5•( 4‡B âÛrù\Zét›#„Àó¼Ç¾Úé£`§ï±I¹;;Ö @WSyl|Ë5•S­âLJtpKIÙ8;Ú @ª©ü$³ÝJ/l·ëIIYÍŽ7ðxˆ¤¤ÅÖÒl4˜›η„ùBÉÉɯ¾ kJÊÙñÁ÷ý~éŠíŠmÛd³ÙÇÂp=h­¹yó&Ó»v“/xô9C‰.ǵ+WY®ÕM')Û’k„,--1{ç6ž—½ŸÎ#%ª• ““é@±ôö¦LLL`m“l!ËËËÛ~r’òd³=¾-‰ÚÒ»÷ìejz׆Ú­ž¡oôœµZË—.2>1ñÈúj# ¦&nw’J·9P²Dt7¬%öè¦onèÊÎËAu¾ýtÒ4°•²Ù”Axƒb¶íl¨ŒBo`^XXøÒ†ÁC©TbtttCÇÚ¶½-ˆÁ~PqÀb½†‘ã…×6ó^«wáÞ]yø9ëO7KŸåð.ô­"–ê …2ž“Ô¢ò#2Ž ÝŽÉf„0øQiåpÊh µùY„›§\Ì?ÐwÁ½m6¾¥¤¬fãA+ÚA›L®„uî^Ù€•/Ëðã¿z›þÃ42¢«°ƒ ¥ä÷ÿ÷ùÑ~4¤Dõ ÄqÌßÿûŸßþíßÞ`PÓl³Ï‚È_àãOO]bß¾ªyÅ铟€W¢ôÊkdlÁêòz}Ü«ýtóÊ9Ún‰ƒSãܺü‘[e÷Ô8½:ˆJ›d–¸xé “{g(el„”\¾pױѺƒÈßCKyèÄ«ºXséüiÎ\¹I©<Éó3ã,ÔÛÌ‹i\ òk\'?ZféúU.Þú·òáì¹KàfxöÅÌ<55dÈWºõ ß6´û))}6d„”Ôf/óÿþé_0:ùf“¯ïLWËki‚N‹ TKE‚8è‹lÆEE!‹KKÄÚàeòTŠ9Ú¾—Ía=¿ì·Û(­V‹;wîlɹkµÚ†ˆmVÉ í33GX\X¤Yo31:Á±gp¡náX’Ðï°´´„ê‰&Y.##U\[ö'~«ÎÙÓŸs}®É‰7Þ@ãº|ôÑ/¸9½ŸW?-4§.œ£P} 5–k‹†‡ì¤º\¿t\!Çþ}~þþ{T¿ÿ]D@wóÙš«ïj*÷&BÀõËŸòGñsÆ 9n\¿J¡ø&ÁÜm.ÁÌÞQ>úàCƒF^çµW^Fq“®—92V¡Õ¬ñÓ·ßæÆRÀ×Þx ݘãí?û.=ó2o8FÆIêþ4 ŠÅ¤ {£Ñ@kÝÿw¯Òîã¶ÊNyr¸þ›DíïüõÏ™:ð<£9‹ËWo1?;O½¾xï]n-µˆƒ&ïüämÞÿø3Ξ=ÃéÓ ‚ˆ‹§?âÌÅë+¢í[ˆîÊÂ:䫊ÞõŽÙjîuÞÞù´Ù^’œBæùäÓ“,Ô}¦§*X–ÅÂ9ÂV˲ðu¾8}šS§NsæÌiþì¯ÎpåFKBÐnpëæ >ûø~çwþWÎ_ŸçÛßý“•ÆÀØ®|ÿ{ßåà®Ä¥¶›\ûâ4Y7æÊù3Ì=‚3н¾ßµ[\¼QçÒ—¸zñÒZÿêMÙâ(¯Ÿ8NëÒœ8~‚xö&Ù‘=L—‘¶ÃÑ}´æ8{ö§?þ”;WÛ\ûüs._­Ól‡dª»Ø39Â˸µ°ÌÞ™ƒ8®MÓA$+Ì·ß~›ßú­ßâöíÛܹs‡ýèGüøÇ?N3MAÊ6æ¾A øì£÷¹zöVrûüÇÌìåÆŸq郟 º»01—®] 3¶ϲ@î\=Ã\àq`×—>y—ºÈóƒ|Ÿï|û;¼~â9¼L†f¸pæ¡áìɳÔk[fîY u€‡5cÛÈûö+Rn£Ütc #Õ޽ø{¦'RuꜻQcÏä>„Qä*Y¼¼Û ä<8°8w•³ç.àÇ(M±{jœRÎÒ¤p2y&¦wc¡9õÙÇdÆQr]MåÁRϦ§Öl{8]-å#Ïaÿ¡}ë*×õŸ(ŠP*Fi…Xœþô³óóœúè3ªÓS4ççX®-²pûõ8Â0‰}ý=.ݼˆ+s×¹T_d¤Zeo¶A‡DQ˜¨ð-Ïsh"Gµ`E1Qñê«'PJñÏþÙ?ãŸÿóNø¼þúkýëÐZ=R%·””ûq_—‘1°ßa /-Q~þ9–¸A~Ïs€…™=»r’CG^¤Z^ä7o"„àúé zú8¶%¸ze‘_9#“øƒÕ•Ð,ŽE ³5lÇ Ì1Š!< 6ÌN®¶×ÌÑñ<Æ'&h./òþïQœÚÏ®‰"Z¤•åð‘g‰"…%Æm%³r#™Úû »öIÛæü§Ö郤¤ørm‰³§N2ׄo}ëi„ ±-MdÀI:tL3hàU§À(ŒP`9‰!ºkŸ%n…ôâWY'ÂÊOñÒ¡ƒÈ’áäÕrQ‹‹—瘟à°]§R#.Ï1¾kÇÀo~Á;³5Zí6já<Ï>ó=„å"¤¤yåCLí*Ñä^´Š¨V«üËù/ø7ÿæß µæŸü“ÂÈÈaôµŠÍ¶Š¥¤ sƒrYÎ-Îrå“O0Q qé6: ˜(°§+¤Ïq¬8½Üìî.é‹y‹ùV‡™×1¤‹¥:hqä¹#¨XmÙà-„ ŒBÂ0ØÀ*AÇñ–u¬ÖŠ0 6TDq"г}¨°Å¹ ¹y{ŽN2¹ç/>sÑáÖçùôÓÏŒA ¸µ”eÿ¾±$¨ë»×Æ`I‰Ò a¸uã'?¿ŒÒš‘ÉÝ|çÄ3d]”!¿«ÊåÛË<»;ËGÆâÂ2¾‚™Ã{:MÂö-ö?÷"_|~n­–òPÿ¯è)¸}õ®à#(ïòÆxå•°®‡ bæO5)fÆðƒ®Ÿû‚xYu®±\8ÐÕ#0I¹h-Ò"ŽcTW¢²/ÚÇŒŽŽò£ýHäEã8îg¥»Ç9\;§¸·¯¥œôÝújmƒ ÕÝ3ì^lQ÷žçÅg_DJëØì®hÀ¦øíWX¸2RÎr»Y§\˜@Ż٭3H!ˆKû8{òttù¼4=‰Vñ{Kw•øâÞgoL?óNXrÛ}Ö))=6dì¬ÃÕúïÿáa‰d~¶ 2rùg‡’ª ¥Ï{­»Ÿ{Ÿ~x‰Ö¡ªS3|ï-›3.sKJÕ)víæÎëd3.SE®,lm`9Žc0IÐö~Á¼Í*Rݳ¡÷4Æ+õ¥S]·ƒí•8r´BïÃ]]ÝÕö<ÆVm¤[}¯ÆvíÚµæo™L‰l69Ïàûm˜Ø;ƒÈ”QJP­ŒôÎŽVš\©Êk»ÝSKºéž‚~¦ÆËexþk¯u½U+3úé’Ó=Ù“çðøîî;2ݽö½Ï§^>ÖÇkR\ÍúÕu_¦ZÅ)Û—ûc°²e޼ñ+L7Ú(­Rb[6…R‰‚+†”Æò…|²Œ×šêÄ>Ž>Õ`v¡Î¾©*ã»÷1±gÿ­u²°ÔàÅã¯à Ãáç¯ìæÜúKu¥î›|*µÞR?~ÏE îS&;™9êM¥Ç~UÜoÅ´Ñ ù:­÷%]Må! a!Ÿ¾§–ò I*¯N~’ ¹Ûn°7îÑxÙ5&Õ*NÙÆlpcš XªR,­…YW½7° Éáçž'V+Ç /,?ûVw7ñVKú»U{ƒÂ=ˆã˜¯¼Ì¿üÿâK§€j­y饗6äª2ÝþÚŒúNçn}¶™‰‚I–Qâ ~öE›‚(Šp'5)Û– ïT~ÐY»@âÜÍ"–õðÊ6Ù%n ÛGiÍñãÇ9qâ•nÙš/'®µÞpéecL*¸³…X–E©\áÚÕ«‰+n`£\ßeô·%ed¢â—~Ö)Û”]ÜÎó<–——û…Îz_ÊÄ/Å6iƒV³‰çeuwí(¦§§]Ñ œ·¦mEc{£m¶mo³XQJÊ0;Ö cŸ@kC»ÓFˆd ¯UW+YÈ•ôÈ-l£W6am®ënûJ§ÛMS9Í,JÙîh­w®A€Äu°gÏžG}"!<Ò8%ec„Q¼³ ¤mJJJÊý0áÎ7°ý5•ÓYlJJÊ£FÚîÎ7aGÑ£¾Œ{bYî6òw§¤¤Ë…;m^|ñ Y›ÞîçÕ¬§a¼éÍ””'mv°AÀ$¹þ›*·•n› ÕXHê7m·ÒB®\¹ÂÒÒ"ÅR €åå:W¯^áÈáüüʉ5{iY\ùä#;û÷c´Æóþ˜WOœ@J¹æßƒçM>«¤ÀƒÀ°8k·–蕵6qÄ­ÏÞ§Uz†©ñªÔd¾c1³wšÚÜMNž>GÇxù*Ç^x–幫›`÷ø¤7SRžPŒÙˆbÚÀÑJm]y评n!¾û©–­ìdH!·äG 6q^¶™„fB§Óæð‘£¼öú¼ðâK|ôñ'Ô–Äw3°*äìí«|zå6§Nžäý÷ßãÿ?~­ aòþ{ïõH†¼7ðoß;Ë·¯ˆ[‹¨N½;»þŸm æ²uÌH–ñqøù{Ÿáx9‚úmþüíŸRšÜË‹/¾À¾]S#È:Ÿ¾ÿ.íh;•OIÙN$…7¶B‚8hsgn/“#Ž"FÆ'ñ{h`ÐJ%F…Àéi#h…F`uËKGaÔÕʵpl ¥5RZ[:1ï_¶ý²Ü÷Ÿ„0«uã¼{ŒÌý?³m…Sþú¯ÿšvÇçÔ©SÌÎÎòOÿéÇ…óçÖ¬h„ܼtŽX”ùõ¿û2¶Emþÿ禧˜1ü!k,™<~Ò’Ü#£ã¨(Äu¥ppÈ•KÌ/.#1É^'å©¥P ÂrhÖ·Öe”xÕ aã¢7½kÜnH)Éåòë\¯Y·­Z¡Zéÿ{õq–åñâó/$Z׫þnT*ST*ÝÞ[µúØw`ÿÈÁ~•–Ëñ×_g©­ÐF#„¤Ü½†^ßf e^{í¶L=F))wCŠ ¸Œ„%é„>Ë·o'óD“ˆ°ÛñK`4ÈEf³9B¿Y2ŵå&ÏÃñòŒX´;>1`»,Kâ·[X¶ƒëX„Bl©ËH)…”ÖÆ ÂVöî&¤@µÖÛ¶Nþf ÕF®y€×ßKEÍË™ÎÝ-f´9éÍ””'Ãõ„å¯N’Ó&I7)D ì' JÊÕñ’`Œ"—‰ c…çX8^†J&Û?FkE)*Õ FkrÅ–î(ímøÚxPyk:¶/’Òõo䓨Ž+„džûdˆ¥}›’²6±SÙ²,X5‰]ýE[;ä‹%"Ï«ŽJå¡å–~uÅðæ°ûE!´·æÔ½àùýΛ­tÐJIIyô|E¥+î#4ÿ°4•…Ø”…QJ¡Tç«é’Þ½÷þ»Í‚Ê)))OfKh¸ŽK½^ïE—ûú¶}± Ú‚ÀÇõ¼GÝ])))O0Ž!<Žc¨T« ÃÄ5£ Jwµ§mP?yƒmÙlnÛU:MIIy²0;]SYJÉØØøC©“´•R—QJJÊ£eg äônÒè4Ý0%%%å~lªüuJJJJÊŽÅ„”””””.©AHIIIIRƒ’’’’B²™65))))O8ÆšÔ ¤¤¤¤¤ PÒM BJJJJ iÚiJJJJJ‚Á¤!%%%%…t…’’’’’nLKIIII’"Ì©AHIIIIÁ„”””””„Ô ¤¤¤¤¤¤1„”””””.i !%%%%îµBØæ c)))))[‹1ëlL“BÇñ£¾¶”””””‡h­1Æ ô…mK Kh \­°07ÏâÂ"¢Û–’’’’²3$«ÇuqC!`¢ì­ÒT6†R±ÌôîÝÄQô¨¯;%%%%å! ¤$ Cúm–\µBèáº.®ë>êkNIIIIyH¨uBöÝ6&u¥¤¤¤ìDcƒ¤i§)))))À=V=îfIv:é )%%åIãž!‚uýL;!p]Û¾¯½LIIIÙ1¬?â Acy™¥¥%\×yÔ×ø•£µÁÍäÔtjRRRžÖíÐhÔ§\©<êküÊ1ÆpíÊÂ0HòtS÷QJJÊÀ=§¿R ”R‰rÂv£Ûx×&BŠÔ¤¤¤q–—#_*®1\Ã7¡¨7š”ª BjµÕÉÝd Ý¿7‡:ŽO9Ÿ]y­H BJJÊ“Å] ‚môëÄÍä°\ƒ@ÒX^fîö-¢($W¨àæËtšŠÅ<ªÝDx\ÇEJƒŽ"¤VäËyÚ9„—ÀËhu4y„L\:=çPcPJѩ׶ƒm;KUlÛFhE«Õ¢Õj ÞÆ@.Ÿ'ãØk\Ç"èøHaã9ÑàÞ !p²9juŸr>ƒÖIIX£ & "¤¤¤—º]ƒ’L6›ì]èÞ_¸™<žc%¢@bàýõ§“’’’òrÏ rBwCX/ÐŒÒÉ`Ù]EôdGCéšÃî—aŒR¬8y FæÁ¸×~i9dºÉC=÷Wï¿ÂrÈ:Q%Æeð=Ó BJJÊÄ= ‚ž!›»Ï˜WÈÛiCWïZô=®Iëa÷Xߦk„”””'ˆ»×uiµš3å^ ‰®KǰcÛŒNVE¶ýäUzMIIyrY× c¨ŽŒ „ ŠBDÏ]¤u7;G<”6„HâhÓZþöþm’‰É)2™Ì¶Zí¤¤¤¤“’a+¯‘«« ¯>^kZgÎP÷]ÔÂD²PÀ}ê)Êo½…;6¶þ5tÏf?‡^ÁÇ{p×{^íòZxï5ƒ­ˆ ÖR eï½Î@-„àòÓ\¼ý)‡¦_b×è RXkŽY}}«ïñn¿¯¹/‘·-³;Æ$eîò†©AHyèô´²7[?V* ©7–1¡T,b[IÞ( ÐJ¯Ô(ìé~{R T moíØn ~«…–’v£F¨Àµ,¢ "_*P*—h/ÌÑQ£b@ , %Jå2YG¢âxE\)T¬°Ý¤¢Žc²«í±AºØ`Éu!Å#1Híg?£þ†8$ ‚ºÝÆŸÅ¿z•‰¿ów𦧇 •”’úYâ0ddïž¾žÈšN_ÕdT„Ædr¹¡Á¹oŒ¡}ý3rÓO#lwà¶’#}ßG)…eYÄqL¡PX™Õ«˜V’ËåF³´¸H'ˆ°l—jµŠŽ}ŒtɺöšgGƤ£#ú0E­„4Ú5~vöÿÁr›\þô¾þô¯sd÷ˉ,‰~yi‘V'À²ª##¸–¤Yo’Íe‘– ^oÍç±0´ü€l6‡% õ¥Eši9ŒŒŒà:’Ào£°Éeœ/mz/õÝ LjR:½qn3ÆhÚíÍV‡|¡:dq~Ž\¡D6ëÑnµ…;4íFƒX Å"U×Å(ƒ_kóè,/Ñ B@àe ‹Y´Žé„/›¥½äSÌÙ´ÅH&—LŒbÊc¨F ,'W ÖVÄÊ ðYª·¨TG°tuj‹5&öíôZR.6D_™®ôÙà‹5IÚ—.±ô'‚„ããD×®au:D»wc».òêUæÿø™þ{é$†ªÓ\b©ÞææGP[Zâ©×ÞÄHÉž½O‘ﺦ|?ÂhC.ïõ/Â*lóáÏ…i޽p”|ÆCë˜sm¦ÇŠrûì/p# 6ÌÍÎr§¶È±7¿ÏÁ±§Nb~~ž©©)nܸÁøC”RàÜéYP%^ñ'?ø9çn,R)å1Æá™ç!Û×8}³Å׿v[®šY÷:§[¨xpE%Ä—wç¬YÙhÃGߦ£nP±]À!ëΣ9wòcN]ºM©”'ì4n™7ßúoÿÉÛ¼õí¯±¼t“ ·Z¼ùæ«Ü¸ø9×›_{ù9Îþ1Ÿ_¼I©T ê41N‰¯ãM:s×ùôÒ?}öü ®t|2 ‹ŠEtw†/,‹gÏqëÆ-†ù;×édGyùðA¬L‰c¯¼ÊçŸ}Æ;³<°ŸÖÜ%>>{Ç:Êg~@íì%JÁ…êåR‘óç/àt0 èø>QÑét’û3à/ßæÓ ·øÎ÷ŽÑ¸}™ÏÎ]æÿÙßf¢œ%ŽZäÈAN~þœ»9ó{Fûýiº®!WúLiMÜ54[çÛO–LÁõÅóœ¾þŠ¥ù¥€Ã¿Ì®Ñ´Ñ!iÍß⣓gøÆò«ì)¢ÂoÿùñþçWñ[MÎ|öm«È‰¯àÄu>:{™×¿ñÂ¥[|tò4oþÒ¯²g´ˆŠ|~òçÄ»Ÿ]æ»/Ï`ŸúœÓWïpüàô—Z%ôŒ¥c[ÝìÚ8BjR¾F'_à~QÝLÉl £5õÅeÏ#WïúÖWAØZ&6’±b­’<$ƒMlKŒÖDQŒe»X–À Ñ±¢Ñhâ![+aLÁͱ0Fc[ÙêÊ‘ËÆÎæ…ÖŠ¨P©8(¥ˆƒ6‘q¨]–-²Y7)í.]‚¶WÊÜSó{c zÀ|ˆn Ęá>3JÑ:ž¨^'jµ˜ýÝßeêý#ƾùMjo¿ÍÒŸþ)& ‰•¢sã¹C1Ê0¾ûi~é©çiÜþˆ?½~‡—žGÇXV2HÜ:s’“'ßáô|?ç¢ë·ñËmÌ‘ƒcÈ«¼úÆ×“AE…œ9}ñânF+%^:~œvf–=¯aÙ¼ûÎ_²ÿùW™.ç‰]"DvÀ·o¸~ë"§?¹Æˆ+©–3|ñEÉB‰ñJŽ8Š–À’.Õ©ý\8}çžÅÄf¨ÏVÇ]V|ò_~up}þ<Ÿ\ú Ïí}“é‘üüÌ å<­ŽÀfÇg¾Ó¿! ssË”œ S#Eâ8Ær<¦÷=Ëé3WXœ»Ãl³Íõ_ÿ=*Û_\"§"ÆG‹Ü8u…¢å±k´¼ÎvÙµÿ9>;yñÚaÆöÌpêÔµ®Aø+„äb“ïáJË©AHy舮vvO¦t£øÍ~Ó®·p=‡NÐÁñrä².A§ÕÁÍæ“Í[ÙKZtvšíR©Lvÿn Ž›¡Ù6ØR⇆bÖ"ˆG†FË1‡j·¶ÕjÓŽ•RX´Š‰•¢±\ánBZ6ù|Ç‚8VXVDYkªIÞ ¥Z­(÷ !‰ãhÍÆ4£5QµZèN‡(ŽÑÆ £ˆÀš¾Ýé ¥$Š#Â0ÀÄŠ>ú˜ÛwîwøÅåÖõÏçž{ž©É r£ã¼ôõo1û‹[ö¸ÌÓûŽbBŸ°«"(„@«ˆó§?åò|‡ï¾´­4¥BžÀ‚ ÐQ‹‘É}ì:0Cú( úMdöi¢°M+‚vƒóŸ~ˆ¯+¸±FG!®­©uÚ4Û>ŽÐýØ„²$Z»¨ÆaÇjàsÖÃ}&B‚0øRYFBêíEþ¿÷þÚÑ.ÜúJÙý,´NQ((ê ‡ï<÷Kdì1K BÊCGˆî ½‰‚œLײZàe2dr™¡Œ%Ës¨·Ú”¥…e­68±6É€ì·ÛÉ )%®ë¢#Ÿ°ÙÂ*”p—BFR«7Ð^¥!Îä«Vˆ,‰´¬LÑQÒ† ÖX:"ˆ4ccX"q)øv>ƒ6Â.`´ÞÐ aP¿¼7³”2éº]Ÿ¶·oÍwÞÁÊåØûk¿FëÝw¹ù³Ÿ1ýÿ!á·¿Íâ¿ÿ÷ˆ‘Ü©)TƒÖìß¿éé)â¨É¥ù«¼ðü òÙL–X)œlŽ1×ã€ÿp†ç§P.u`Emi‘ÚÒ—/]&Àã·¾FΨX!дrn^¼Êh¾€å¹ÌÏÞbdtœöÂM._^âÍîfîÒi–kK|üá{DÞnŽÚ||a™–1¾wæÔ~öîGÜ3NDK#ŒŽäý[ÈÊ*Ž“D‚n_$ý»T„­B˜^$ôŒ±V­#´=˵¥k².Ë Ã¾êw94yŒXÅ+11­©NM’ÉØüìçpdß4~c‹®òÒ7¾Ï‡7/òÒ‰ã\½r‰wß™uéXõNHej’lÎáo~þG÷ïÂo.rþÜ^úÆ÷‰£ˆ }YC«ûÀ/¢Ö Œ^·o„©AHyø$†`ã……a@«ÕBAØ ˆuLÛoP,–°, ËÍ‘‰šÔ—k ÙB‘Œc'£1VÇnBÏKüé&× „t: kk?"›Ï&Ù4B`,I½¾L'Òäªe”íâ7›ä²¹bÇÄJãe<"lT¢xžŽ£ û|ÑÝ f7† t×ð­Ú»!%¥WO0÷ÇŒºy“[ÿîßÑ>wŽ¸Ñ }û6¶ Âò±q§§1J1”ŠED©DUÙU^¢\Ê“Í$g£Tרh&_¥ayì/ú®£®^½ÀR]±ïð³ìžžÄµ­þìÜAiâ>:É­X‚ÒÈÅr…¹[s<óê[ìÉ¡ëc8¶K( œ8vWtPg/qëÎ{'ª|ë[ßâÔé3œ>5ãåyö¹:·o.ðÂ[ÇP±JÇTJõI !RÝcî2èmè³ÀPÊŽðŸŸøÇ¼sêÿâÜ·qÝ?±Ì^;ô+XÂZÉpêaexëëßäôé3œ9sËrxùo±{´@ûÅ£J#¼ôòçÎ]Æ.`Û7nÜæàž Þ|«ûºÓ§‘¶Ãñ7¾ÉžÑ"~«Îõ+wxæ•C(¥6¼â¼Ë ­ Ž%‡J¤ òoÿí¿5ù|žB¡ÀKÇ^¤R©E0R€Å;×¹:ßæ¹§'›éV¿X¼y™Ë1Ï=}­H¨ ¼óéu^>8B¥˜ï½ÿqsæÌ™t…òð"Ù¹™Òê½ÁG›µ>S­×¶­‰Wí‚6Ý×®ö» Q7p©‡bÉï*xŸî,T+…’L6‹f;ȃ›É"¥$Š7éëímê"… 6Éà¯N÷:‹o¼ïy,ÿÉŸ;‡iµ“8/½Dù{ßÃO\'–µF(6—Ï$·¶Îg!°’ý«7™ûì!1†õîXä½÷~‚•ÏÉF¦÷R×­ÐbxÈÆPÚˈå`ŒF¯z_Í`€´;KÒ&Ù̵¹O`í-iFrlßw)g§¹½t‘Ó¯Óñ;ضÝÿ‘R®œënÏ·2k~/OótU­Å:û, űiž™´ïÚ¿›¡7§Rª£IƒÊ)!ú›ÇvÊêó^÷ñ ?ÃÚÕ†1zMÜ¥÷[¡P ÷o¾ò Q·t…ÌfqK%Ç鯊ôj#¹ëØLûFîë^ïÑ«À¹Þ³a!-0šÕž ŒhwcšEwe‚fÝ]v›i3Û²°¤äé½/qtÏK}×ÞÊJ w fÓç0ìnéÞÆ¶ÁãVîðïpmÆ$.ÎÁrƒ¤!å¡#…$Ta2Óíý¬W’â n[³Š‘’8ŠQqÜ=|%Ógp_B&—#“Ï÷1Z¥Ò-{0üÚÑÇñOÝ’ÉJ4ˆt7¨l†º½_øo°úÈfÚLÊ—˜î¾{ó`ï·¡¶Þ9¶æýB5X&Ãt'+}”„”‡Š1†\>O«Õd~öN?pjz[ýûOãµõŸþ‡Ñ– L[ÞÖàJår¿X[¡P`iq‘K/ö・™{åðžä6£“>sc •bûNƒw>»%%–DJ+ƒe ,!¶u›{KÚ4–”H™œC)M¤4–%‘&* 9HVƒ±‹Ô ¤>™mtƒØN·4‡2®Í‰£St‚¸›xÔ‹]u‘¾Â¶^ýáµ%“ÿͶI!Èz¶%±m‡v«9ô¦!å+Am§Ûfèí›d»°íÖÖñnÞy(ŸÇNA‰R*10v°‡\•ú”’’²íXï;š¶¥l„^¢”»ëj[×e¤µf©VCÝ£VvJJJJÊcŠ8¶C«ÕĶí~[§ÓÁê®Þm˲¨ÕjT*.^¼4´Q'%%%%eç°ÞÊÊCÇ÷‰ã;ŸÏsûömîܹC¾›¾–’²¥ZklÛ~äËõX©¡tLÇq†²;c J©þƒ^Ûýتϫ'[™²³ÐZsëÖ-lÛæÿÁ¦ùÍ ‚%tEXtdate:create2013-01-21T18:26:03+09:000)Ý %tEXtdate:modify2013-01-21T17:37:50+09:001@…IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/graphf.jpg0000644000175000017500000001277413070106167016603 00000000000000ÿØÿàJFIFHHÿí Photoshop 3.08BIMíHH8BIMó8BIM 8BIM' 8BIMõH/fflff/ff¡™š2Z5-8BIMøpÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿè8BIM@@8BIM  €|€º „ÿØÿàJFIFHHÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„            ÿÀ|€"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?õT+m{^ÖVÍîp'S´Ý¾NýôTöºÏNÏËRJbë²hôÜbCôn…ÛŸíú>݉YvS\1÷ÇæµâOÃsZÕ˳*·ìõ±ô¾à̧ˆ1¬êè#¤’‹2Œ~…£ûù‚‹.Ê{w}š‘µÏ¡-üÖ»éFåa$”×mÙD¸zl1%ú;@íÌöývÏrz²ûì¡ìØúØÇ’ ‚lkwÝú(á[—k²~ÒÆ1¬¹ÌÇ,$î¨CìܲÏWÕnÅ€ý«{úÕå$§ÿÐõTGÚë=ý;?-JWÜÚ*u®kœÖò$ÇÁW£3'!©Ò^ˆ&}[»é5õé)6e/¿Ê«vË f·ëíx÷Tý>–Ë]µN›[u,¹°[cCÚA‘¹SUzycYf;[³ìö9…³Øþ•‡üË’›I$’JRI$’”’I$¥$’I)J/xc÷kA$%S©Y@Åq#íOm0ËO¾æ'v;-ILð+}x•‹ºÇ ö~“ϨèÝîÚ×;k*ö®AïèQÿW”­ª•ûW$i"Š'Çéå$§ÿÑõ+j®Ö†Ø%¡ÁÀI´ïgÊj (¦œ– šÇ’‘©¿ôZ¬ ¸µÖ;úv~Z’ReXzŒÎ-€kº½Û»‡°†¹®þ»,fÏø·«*‡XÊÆÁǯ¨dÝèUu{ÞA ‹\1=7ŠåÛ\ëÛÿ\ôÞ’›é$’JRI$’”’I$¥$’I)J«Úmê –¸ì.7Ùì¿É­¯ÿ=ZYÝ7©â»ªáÚoÆÌy4?kÙì¯ô¾Áoé+±ÿCóÒS¢ªUµ2<} ?êò•µR¢?jäŽþ…õyI)ÿÒõTÖ«ðv~Z‘\Z¬ÁÙùjII”-g©SëÓÞÒÝuˆÕM$”ƒ ×Ý‹U–4²Âر§³‡¶ÁþxGU(ÙNmÔLCxÿEp¯ûM®Ç·ý%ÿËVÒR’I$”¤’I%)$’IH3oû>-–€K€†É{½•0^Ç5¨”ÔÚie,ѵ´5º“ y(‘f]Y7=­ðo±›Ïî¹ïþß§ü…i%)T¨ÿ•2üõyJÚ©Qÿ*dø ?êò’SÿÓôü»ÝŽûšÏP²=³H×kÿ5WÆË9"k,ØÏþþÍúþZ¼‚ïéUÿÅÙùjII’I$”ÕÍ>Ÿ¥’\ZÚ_6i2ÇMÓí­ÜÛ?°­!äRÛ貇5¶±Ìs˜â×á¶Yc}Ì¿Lý(Ãu®ºÌ8¡öXK¬ph•·=ßÎ[m>–Ùùö¤¦âI$’”’I$¥$’§Õ›ëa?¶¾‹sǪʉm/Ýe/oвª›eÛ¿àÒS,m7e6çE1¬VÁ±šÿ-þ­ßõÕiBªÙUL©‚[CZ9Ð ¡M%)T¨ÿ•rD(£^ßO)[U+ÿ•2?â(ÿ«ÊIOÿÔõTK¯Oðvkó©Óöªü=;?-I)2I$’”«[4å2ív[YÄþÃý£èÿ×+VT.¦»ê}6 ̰¸y”Í%S¦ädÝAfebœºœæZÀàà@s›NC\?3&¦¶ïø/æ?œ©[IJI$’R•Z‰¿1÷j*¢j¬ãëþOó-ÿ¯(õ<¬œz0éV½¬ª§;`‚G«sŸµÞÌzwßÿ ³ÑþvÆ+4ÔÚjeMú,y1Üÿ)%3I$’R•J¿å\?ÀQ¯öò•µR©ý«‘áèQ¯öò’SÿÕõTOÚ«ðôìüµ#,üCŸë3íA»¡ÞE>¦ÍŸðßCæ$§A$’IJI$’S[*«C†N0öhöh=Fkúóôv¹ÛêwïÿÆX‰•’Òê^´í{9ŽÞ¬úuYîþnÏz*ªz},}·bãd\w[c?Hè Ègøo£·ý.Ïð¬IM¤+²h£oªðÂùØÒ}Î nÛ[>þCGíOX´Š=HCåû½i;é}CfÏo­ê$ÞC¯§/,7'3;ѽÌl×¼m·ìÜú£}÷ú¯ùÛ,ILñ™is¯¼m±ú2¹ŒüÖþï¨ï§nßø¿ðJÂI$¥$’I)J¥SûW#ÃУþ¯)[TéÝûW'tG£FØðÝ•ÊJÿÖõTYi±–U¶ZÒ?´öþ¢2I)¥‘“}Nd¾°C†úÚ ÜAkDK}?¿ÕD³íϬŠS~‹È.û>ÝÊ9³÷ÙêìõvSoó»$sé~›ÓV›·hÛcHâR}°ƒ·Ó;IÜcÁ?ëŸðô‘’IHÛ{úgSHiÙ3FpsËNi °C†Ñ ¤þ¿sÕ„’SI·d»-ÌmŒ;ê íþsw©ô¿šs}ˆ®ÅÌ-55 ’ñ;„´Ì÷írMûÛ·oÚ¶ ñÎßÍŸÍÿ¿« )ûiz`Èýã¤û’?mƒ˜1¡÷QÒIHGÛ4ŸLøý%Æxd=Õ=ÒeÀ9¢ %£o»è³kU„’SOì«M¥®­ÍÚÖ–¹¥°\ßøO~çzžÄJhµ¹6äX[62ºÃ[:l6»tŸÞõ”¨ô7ÝéNíÿ¥™ÐßßþFߣìFIOÿÙ8BIMÿÿÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„##""     ÿÀ’–"ÿÝ ÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?î=á.:ÇaçíN‡ó6ÿÕ5%+Õwú7Ñÿɦmû†æÖøÔpgâeU—O­Ppnç6 ,sª±ÿÔIKúþíž›÷<·÷ÿ”œÜ@“[ÿüš"I)ªïônÿ£ÿ“H\LÅoÓCÇþM$”ˆß 5¾]$h?7ûÊI÷ìcžæ85 ’tà{¿}"u’‘‹I+t‡þM0¾Kš+|·C î7þú*I)¸‚¦ýxãÿ&—ªÑ»ðÿÉ¢$’‘‹IŠß^ßù4Âùqh­òØ'AùßÛþJ*I)¯ÛÖýHAËŽßßOê;ý¿èÿäÔoÉ®ƒP³wé¬7h.÷;vßSoóuû’R/´Wè}£_Onî5ꤪÞ<ÀóòI%?ÿÐîïþoæßú¦¢!ßüßÍ¿õMIIj!·[TGîÿ©k± ÂæßQZíÌw–ž«?óÒJJ’I$¥$’I)I$’JRI$’”’I$¥$’I) Ü‘]q;A°ÿ'üçï³þÛFA¥Ûí¹ýšáX>;çÿà¶#$§?_Øþ~ðI/ûÇÿ­’SÿÑí­vÊÜéÛdÑý…Ddd?ÛcAã´Ðæ¿é9Ÿ¦õ¿ðçlZwÿ7óoýSRRD ïD¹ŸJ²?²w=¿Û­"AФ¥$…¸Tó¹Ì%¥Þ;NÆ»üÄT”¤’I%)$’IJI$’R’I$”¤Ïpc÷hÖ‚Iò вœÀÆÿ„piŸÝúVÿàI)XÁÞƒ Ä=Ãs‡òŸúGÿÕ"¤’Jsÿïc_G’IÞ?ýkø$’ŸÿÒîïÒ¿›Ꚉ‡wó6ÿÕ5%$I$’SR»©f}˜ÛÇ«c§ßlý–ËèT­ _µªâ8vÂïÙìÿÏÞŠ:JRI$’”’I$¥$’I)I$’JR¨Û©¿9Õ1áÏÄh63»_pýïúÃlÿ·U´ `Ãê\ÝM®$Ÿ&~‚¿üö’“¤’I)Ï‘û{z?Á$¿ïþµüIOÿÓîïþoæßú¦¢!߸óoýSRRD’I%1±›ës8Ü"|ï&¥î}MsÄ>=Àq¸{_ÿMM¨®û*“îý+AóöÜÖÿ×?Iÿ^IIÒI$”¤’I%)$’IJI$’R<‡=µ;f¯>ÖÿYÞÅ61¬cXÑ h „è³!¬“ î·;utîÿÁQ’R’I$”çÀý½à’QþGøà’JÿÔíÞÐö9§‡>õ@a¾  ­‘Ïý¥«þ‡Ù¿ðU ‡ó6ÿÕ5%$I$’R•lëëŨeXíµÔFóÞÇ–ÕôkÜÿ§é«) ê„$¥$ƒŒHa­Â GgÅ£ù§ÿn¤d”¤’I%)$’IJQ¶ÖSSí°Åu´¹æ †´oµŠH9àÚ@ŸTûC?Âÿé/úâJc†ám#$ûDX4ƒ°Õ÷nÿVI%)$’IN|‘ãþŸ’IÞ?ýkø$’ŸÿÕîïþoæßú¦¢!ßüßÍ¿õMIII$”¤’I%!³ôv¶Ð:aÿÏ/ÿ·?óê2g±¯ac„µÂò(–Øö9–°²ÊœXgóÚ?šÉgÒýCSa$’IJI$’Ri›ëÌ€}•ƒû€ÿ9ÿ^þé!åÝ`}xõ°¼ÞH{Ò®=ùk¿þþ1ZÐ IJI$’R’I$”çëûÏÑþ %ÿxÿõž>I$§ÿÖîïþoæßú¦¢*¶äÖK«Ô‘$ñì4=ÿùþ´”ÚI A5„’R’I$”¤+˜éÖ&Æi¶csI÷³ÿI"¤’˜ÖöØÀökµ J«ñî#"›6²©e¯;vÝêý:ìc¦üÊ+cßqôE`—ïGçïúÿ­¤¤ê6XÚØ^îaÉ?ºÄ3’Â@¬ µF‘ûϳùµ |{›e–äZm.vêÙ6€FßF½¿ÏÇX’’ÔÇ {ÿœw?É™WöI%)$’IJI$‰I0ÏDÎÆÈàÂELeRÚÁÔ{w{ Ûs¶Ť¦È ‰ÁÍ$€d·G 7!WMe.`"¾ÏG;¯:$¤„€@<žCô)ýÁ÷%èSûƒîIIHÔ4¸´s`‘á?ECЧ÷Ü—Ùè™ØÙ<˜ILÜæ¶ ŒIO‰öµ:«}Lk«ÚÆ–—á¶Oò5þš7¡Oî¹%4ÿï#þµüWö3fÍ£dFØöÇîíI%?ÿÐî^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/window.png0000644000175000017500000030466213070106167016647 00000000000000‰PNG  IHDR_&DögAMA± üasRGB®Îé cHRMz&€„ú€èu0ê`:˜pœºQ<bKGDÿÿÿ ½§“ pHYs  šœ€IDATxÚìýw˜g}èfæé}{ï»Ú]iW«Þ%K–»mlj€ðƒH ï›ò’79‡„“'$!À1` 6\dY¶¬ÞÛªlï½>½ÏÌïgŸÇ»«í+[²ý|®K—vwfî¹çž™ûþη ÇŽSÝÞ6»›ÕŒFH’$I’$I’¼µÈ²L__‹F³¨cÝn7f³I’uœ ¸\.L&Ó‚Î öŽŽŽþèĉß1™L½§ËC~AÕ•‹î@’$I’$I’diȲL  55½^ªª :NDQ$-- ­V»àã&›ššº cA ´´Ôâr¹þ,555û™gžùŠ& Q—‹(Š(Šr³Ç1I’$I’$yO ( ªª ½þ*ŠB$!.ú¼²,/úX½^/”––~pË–-TIQUuQRK’$I’$I’déÄ×ÜP(´hÁA–e¢Ñ(²,/ú¼K=V§Ó ©©©ŸÖDÂaEIj’$¹…EUUX®,WKÆ¿lÞJâçŠOF±kXþ‰ ‚œ£’¼ëˆ¿¡PhÑ‹¸¢(D£QB¡ÐŒíÆaQÇÎ… deeY4‘H$©mH’äBUUö8@ͪUädg'þG„ÄïñŸUUM,°ñßEQ¤¿¿ŸW_{Ûví¤ ?Æ eúñ“Ï'¨*êÄßfš„âûõõ÷sôØqöܶ‹ÔÔT¼~’â"ЋЦ;¥íIí^×7UA »§‡Æ¦föܶkÖó'IòN$þÌ/ÖÜgã&‡Éï’ÝnÇn·'öu:¸Ýî)ïÎlÇÚl64 .— ‡ÃA$¹îX,ËIÁ!I’›L|ñ †BŒñ»ÿúéiédfd066†N§Ãb±àñx‰D#h4šÄËï°Û‘$‰@ ˆÇëÁj±`4 †B<óÜoùíó¿§´´„‚‚„æÁãõD'&šØd †p¹]‚€Ýn'à÷ †ÐôØm¶ÄW¿(Šˆ¢˜è·¢(‚@ÿÀÿþãŸàóûùÈçÀ믳wÏJKJðûý8].ìv@@0€V«E§Õ0èõX­VÜnwì¼z=©©)t÷ôò‡_beuf“‹Å<§“$É;…øs¬(Ê’Lñ÷oòï6› Qéíí¥  «ÕÊøøøu‚ÃLdžB!rssIIIA£ÑÐÑÑ,ËSŽUMÜL‘’$¹¹8N~ö˧fpp•çÿë4µ´ ïßüêÙß0:6†,ËØ¬VÜnÜw/›7nä—¿þ5ãN'V‹…ô#œ=ž¨,³¦®.ñâÇß÷ïýàãr»‰D"ÜyÇ^vnÛÆÏù4½}}ô òg_øžÿÃÁl6óðC²qýz®54röÜ9U%-5•Ý·íÂb6£( åe¥ ŒpþâE4 ‚ àñxxòOÑÝÓCÿÀ_úüçyqß>‡Ø°~Y™™´¶µ14<ÌG>ø8Ïüæ·ô`1›yôýïGE::;ù—üo´Z-Ÿû̧ÉÎÊJÎYIÞñLfÚg&!Y’¤ëޏ@àóù"55I’®[üãæËéÂÊØØ‡ƒ’’ÚÛÛ-“û¡ª*šø‰’Z‡$In’$q­±‘îîþü+Oðíï|—±±qöxªÊJFFG¸|õ.—‹î½—^z™Ý»vâõù9}ö,v›ÎÎ.þ¯'þ”o}ç»=~‚ß¿ð™ô ðúÁ7(+)!##Y–w¹xß}÷áñz8{î<™é´µ·óç_þ2ÿÝÂðã÷ûyü200Èkß`Ýš5‚@4%0á …P'>ŸŸ‡Þ÷[·læÂÅK¤§¥q±¾žæ–Vü?xøý8.¼~];wPR\Ä?ÿ9þñý3dge%}’¼£‰/ÂÓUUÑjµäææ"IÑh”¾¾>¢Ñè³ÂdÁaú‡AFF†ÔÔTFGG‘eyŠ–0î4ùXUUÉÎÎÆápÐÜÜLzz:ÙÙÙ _¯qH I’Ü|EÁfµ 9ðÚëŒŒŽ ×ëHOOC–£¬_·ŽÕ5«8zì6›“Ñ€ÕjE¯Ó‡±Z-„#Ž8‰N§#=-;÷îÅçõÒÔÜ‚$iPU8xè0¥%Å‚€ÍjA’ÄÄñ‘H”×Âér" Ë .^ÂåvSXPèçÊê*jkV±É&&&¬H$Šòr›šyù•WPy«Å‚,˼þÆ!ÆãÇ)Yæ/¾DfF:ZY–Q…‹—êñäçåª"IšDÜydÂÄ’œ¯’¼“™ì[ÿ=Ž,ËŒ'œã‚ÅlÏüd¿¡¾¾>FGG˜! ÎèCÿ}òß].###x<úúúÐjµ×µ =ôÐCÿ£¢¢N—|“$¹I¨ªJJJ ééi  QZ\̆õ먭©! Å…EX,JŠ‹°ÙlbµZ°ÛíÔ­®%=-áÑvïÜAmM «ª«Y][Kjj ·íÜAFF:-­­¤§¥á°Û)..Âb6c·ÙY][Knn6}}ý´´¶²eó&®\½Š ¬­«ãö=»sDüKeú„&6›’âbòórIq¤PU¹‚‚‚|rrbm7·´²eÓ&òóó)*, %%…´ÔT¢²LQQÕÕUœ;EVXS·š;öìF¯ùX IJŠ‹°Z,Éù*É»§ÓI$ó[’$ I’ŸÏ‡ßï' ¡ÕjÛâÿâSeÊß#‘>Ÿ@ @ Hh0rl4ÊÍfsâýž~l$AøÏÿüOõ¾ûîÃ’|“$¹éH’”P)ÆU“ñßeYFEä ŸS¢ ±mŽª(È“TŸñ b²z3ÞŽˆ’„ßïçðÑc\½vÁAþôOþ„ÿýïÿΣ¿Ÿëׇ”a.>ù‚€F’…`0Ä‘c±¶ûúûyâ‹_ ///1IÅû¿ÆÿñÿÉûî¿­›7‡c× ŠD'®QU”ä\•ä]€ªªtttà÷û•¹9þÞh4B¡Ð¢…—s,ÄMܳ2i/L’äæ3SXÖd¦ø{:Óû:[H×ä¿Çž||\È0™Œòà‘‘Îý÷ÞKNvvÌa õd/mUU ÇÏ!ÄÚ.((àûî%###!LªÜwÏ=äåæN9o¼Ý¥dÉK’äVEUU ‘HdI5'DQœâ¼øVÿ8~ô£©÷Üs‹å¦`’$Inq;küË?¢×NÄ57¢mE‘Q”¹…qÞ$IÞ)„B!§80.„å„$/çØÑÑQ4qÉ#i¦H’佋ªªD"‘Äï‚ $~ŸîXu#Úž‹uÞ$IÞ èt:rrrðù|‹–§;,.†åëóùÐLo(I’$I&Ï7znXh{É9)É{¸vÏáp¼#4l.— M8š1,#I’$I’$IòÖTºÕ™”=vqI’$I’$I’÷.š¹´ ÓmŒñ¯ø¶éÌe7y+´ñóL?ßdñÉÙ¹nt?&‡M››^0h¶¾Ýè~ĉ÷g!j¯·b\¦¶  Â[xžøµÌÖþô<í‚ ÄÂûጴÐó¾¶ùé÷r¶bUqé[á·4¹ˆÖäóÆŸé©E³@ßÚgëF\O4]´7{’$ïu4³ÕíU…îžrsr0 4·´ÐÙÕÍÊê*2ÒÓq¹ÝSAƒÞ€ÙlBUUÁàÔ‰ Ðjµh41—ŠÉ -DATE%:Q­K¯×ÏÛqY–inmÅa·344œÓ’$‰òò2ÆÇ P\XDcs3ùyyج, Z­6‘ÀÆh4oªŠÂáð‚ΉDp{< Bý•+dd¤“•…F’°ÙlŒÓÞÙ:Ƀ\¯×S¹¢½^Ÿ¨…n0ã϶Ð>‚A‚›Ô‡†¤¬´”ü¼¼9'mUUéêîÆn³c6›}ˆ @¡p­F3%{X|qZhÁD"*ÊÊÑé´\º|™•UUèõúXØ^8œˆ+'TaêÄ ‚xnæBQ|>?‹yFÉét•£˜L&ô:Í--ôôö±je59ÙÙsŽS8F«ÕNYŒ'/ CCØÌ&Ì&¡Pˆ@08¥(T$Á`0LÃP8Œ^¯C`~áNE<^/§ÏœEE6nXÙdDQbÏlp¢4n[[;>¿§Óɦ ëIKKKTÀ3S²-Æ#‘L$ˆ™Î®.†††q8bÕ÷1™L¬®©A’$¼>ª¢ÐÞÙ‰¢¨”Md¨4›ÍH’D8A„Äs–‚¡znQö]QfÌ忞‰›„nҳϿcãã\kh$7'›s>oKéc’$ïV43M—ñ¬U/¾¼šU«°Z,ô Ä&QÄç÷sü䩉T– ¨*奥ÔÕÖ 9xè0þ‰lw~¿ŸÜœlîØ³·×ËÑcÇÙ¹};n›«×e™²Ò2339rì»¶oÇl6Ï9™Ÿ>{ŽúË—)ÈÏg`p0QWÜh4’Å^|‘±ñqrsr¸|õ*Õ•UØí6nÛ¹ƒì¬,.]¾ŒÏçÇãõÄRîZ¬ÔÖ¬âô™³lß¶uÎÌt‚ àv»9rü8Á`ˆËW¯’‘žNVf&9ÙYlÛ²IÑHTQ FªŠF#%¾Úššèíë#';›š•+‘e™« äçåqúÌY¶nÙŒÝf›÷k­««‹††&DQ %ÅÉhZÐÍD"ìÛÿ*³«ÕŠ? ´¸˜Ö …xãÐajV­äÊÕkD"ìv«V®Äl2qðÐa6oÚHŠÃ1gÔÖ¶6^Ù€p$̶ÍN$Ä‘cÇgm]‹…ƒ‡³qý:ôz=ç.\dmÝjl6MÍÍŒ³uóæyÇ!òÒ+¯ðàý÷%éÉôö÷q­¡«ÅÂö­[‰Fc‚cü¹y³Ð›¨S4Hç.\dtt”Í›6’ž–Àðð‹£ÑÀé³g©(/§´¤˜7Ža||œÝ»v‘›“C[{;ýäåæb2šÈÎÊ$"Ë>r”5u«ÉÌȘ÷Úzz{9~ò¹9Ù(²Â˯ìgÛ–Íädgs©þ2õW®––ÊÕk ˆ¢ˆA¯Çb±°kÇvºº{èìêDU¡¬´„¢ÂB¢Ñ(‡¥¢¼œp8BGg»v옳Š¢ÐÑÙIgW7Y™™h4œ.'—ô´4Âá0‡#-5¯×‹ t÷t322ÊÞ={(.*äÈÑc”—•ÒÑÙ…ÛíÆn·³~íNœ:MuU%¹99 J2$/7gJÆ[Q¹z-ö¬ èô:ÖÖÕ¡( @ã'OàtºïàðÈ&“ Q(+-娉“˜LF+ÊËQ… —.QYQÁ©3g(/+»®4y’$ïEfÕÓ6µ´b±XÐé´„#aº{zÈËÍ!339*S»jׯgúõlZ¿ìÌ,¢Ñ(zƒÛ¶rÇžÝìݳ›;oßC劸\nDI¢­­Pñx=±EËb&//—hTÆd4¢**ísJöÂÄ"908ÈØØn‡åT”—‰Dðx¼ŒŒŽMô_‡V«Åd2b³Z±˜-ƒAššš±˜Mttt²²²ŠŠ²²ÄWb[[ûœç•.µ““ÃnÇl2aµXIq8b¹õ« ŒŒŽ22:J__?ccãôõ÷ÓÖÞN$¡¡¡‘ÌŒ ŽŸ8‰ÛãatlŒsç/`2™Ðh$Z[Ûæýº …䥥±uËf¶mÙÌ–M›¨®¬bEE¹99 ­Êôªª" ]èõz6oÜÈöm[ÉÌÈ`pxQéêî‰ ‚@{G+*ʉFeö½²YQÐëõ47·ÌÙGI’ƒÈr­FËÕ†ZÛÚ1tttÒÙÙE__^¯—””ZÛÛ9rìdffÒÑщÇã™w,TUÁçó] ¿f“ÑȆukY[W‡Ñh ¼¬½^GVf&Š¢péòe^yõÏüæ7ìí5›šíÔÖ¬Ân³q±¾>¡A8tô¯‡Ã¸ÝnDQ¤²¢‚õk×a6™e™+×HOK§¥µ¾~QD«Õb±˜ihlšSß ==½ìÛÿ*>Ÿp8B$Åívóò¾Wdtl ¯×‹FÒPZRBÍÊ•lÛº…ü¼ÜØsxív»7æ¥}¯‰DimoçÙç~GOO/Y™ôõõ_Wvw&4RLû‹;bóÆ :Œ×ç#??^Vû2×iuäçå¡×ëfxx³Ù̵†*ÊËéîéáZc©))\½Ö0ÿlELÓøúÁ7xiß>^yõápxŠÉ2  … †B„CáÄs ×ëX·f-»vî`çŽíܶs'åee(ŠÂÚº:ÆÇ  ¡(*íí1í—(råê5Âá0©)1Á,)4$I2ƒƒ ŒÑÖÞÎý÷ÞCFz:‘H„ŽÎ.Ì¥sÛÚÛéèêš03‰¿}äƒÇL6[¢=Qñû}dffÐÝÛCQA!MMTVT°iÃÆÇÇ'¾˜Er²³éêéNÑ™ UUÑëô„B!:ººA;QÂ×d2‘“Ŧ ëiljBUPß\DEÆë  …ÈHÏÀåvsµ¡œœìĿήnÖÔ­žõü‚ ÐÓÛËðð.·§Ó…Åb! qùê5RRRÈÎÊfpp£ÑÈÁC‡Ù±}+Ñh”ô´t¼^/>¿Ÿ´´¶ÑÝ݃×磰 ‹ÙLnNÍ-­¬[»fÖ>ˆ‚ÀÀÀ ç/\@E†‡cæšììllV+›7nàòÕ«tvvM]5«k),(àʵ«TU®àì…ód¤g06>NA~¢(ÒÓ4 6›”—•ñÜïžghh˜‚ü<.Ö_f“²~Îlll|B-¯gxd„²ÒRtz=•žÞ>222èï`׎íttv±²º›ÕŠF£axdÛ¼Ú—7}:@Eê/_A”DV”—384Dooåe¥dggÑÙÕÅèDÉXAˆ}q¦8RØ·?»oÛ…ÕbM´l1›Ù¹c;ápFCsK ѨLjJJ,GA4xººÈÉΦ¬´£ÑH(b|lŒœœlº{z¦˜%òrs9~òT,íó, ¶ªª¤¥¥rÇí{&‰-„µ«V‘™™AŠÃ¢( …™GFGÙ¹}áp˜‘ÑQÖ¯]KqQªªræÜYº»{¨[]‹(‰˜ÍfL&ýƒƒ¤§¥!Ï2Æ¢(b±XÞ4e p©þ2N—‹ô´TjW­bl|œ@ @wO/mííTWUbµZIOKãü…‹ØívŒ’$a0Ðëõˆ¢HnnWˆD¢h4³û‚ÀÙó†B|üc嵃o°ÿÀkÜuÇÞ˜©E™;5MÂC]UU.\ºDYi)©©)S´`€Õµ5¤¥¥qîü, f“‰#G"+2rTf`pAÈÉɦþòe"‘È‚Ì:I’¼›¹Î˜§ª*&“‰;oßCjj*ªªÒØÜŒ$Ф¥¦°~ÝZÖ¯[›Pç âñxõ.&;öôöÒÙÕÍý÷Þ³gCØlÖ Ó‡…@ À™sç¹ÖØÈ‡{ ³ÙL0œ³Óàñz1X,::;q¹Ýˆ‚ˆÏçÃårc0è1Œ±É,  22:ÊàÐF£­V‹N§Ån³QU¹«Õ<Œ&BÓ|4f#³É„ Æ®o׎í 'r[-FGcššU+©¿r…¼Ü\Ž?ÁªêjüZ³ÑÈŠòr®56"›7n@UUŒFSÂn=ŠªRŸG^n’$±ÿÀk˜Í&¶lÚ”ˆ ®\±‚‚‚©vt¬V+’FÃm;w’–šÊªêj^{ã ®54°{×Î Õn€ŒôôÄ‘ê$»q¬²alaœïû+¾0«ªŠN§Ãåráñz Mø7ø~²22w:¹|õ*9Ù±EvËæMd¤§£Õi … ¶- ‚€(Iô púìYî¾ó´ [7oNd#tº\œ>{ŽukêÐh4(Š‚ÝfCE¬Kì¼ZíuN¶z½ž®înŽ8Éí·Ý–ØG§Ó±kDz²2imkçБ£ìܾ-–Ubš4Þ|'T%6~áp8Qdf6 gÎ'‰âpÐ9ÖM_?Þáp˜ÌÌ \N‡£ÇNP^VJZj@ˆ¥{ÖH›6mä/¾ÄêšRÓRï©^¯½s󌱬Äo‹Å‚ÍfÃëõb·ÙHKIÅ ×Sù ))RSœ<5’ðÈHOÇðÇIÂíñpîÂòrsXY]E  ‰ ª 0óXĵ/Í--ÜÏÝX-î¾c//¼¼¯dïžX.ŸßGNVvBär»¹T_OEyù¡¡£³“á‘vnÛ†,Ëø~¬f3¢(’Muee¬œq?ŠªbЈÊ2²¢’¼×™1ªB¯×#+ =½½´¶µÓÓÛËî];§TÇ‹D¢‚9}ú «VV'lò‘H„ñq'í45·°aýº„mØl2áóû©(/çÀÁƒh5VT”Ó××øý>L‹³!ˆ"nNG4Åfµá÷DI# ‡Ðju˜LFzûz ¸=JŠ‹€˜#'Ä©â§(Äßü~F£qNÏxUUA«Ñâ°ÛÙ²ygΞãÜù |äC#õW.S³jUÌL–qØídf¤Så «V®A SZRÌ«¯¿ŽÝfK8éùý~Œ3Øé§·ÁwvuÑ?0À½wß5eÁKqÄ&ñé«»:q V‹•±±1ºº{p¹Ü¼ïþû¡ÙlJ,<^¯—®înzûú‡ÃdefÒÝÓƒÑ`˜sœE!3#“ш,Ëääæ`±Xñx<‰1¶˜ÍCAZZÛ¨«­eÕÊjΜ=Gk[i©©D ý‚TÄáH„‘‘Q®64p©¾žµkÖ›“ƒ¢ª</=½½465QVVFYiiL˜PUœãã8.ÜCÃÃ1óÓ„0éñzéí룽£“ÁÁA¶nÙLqqÑ›‚… F“‘‚òóò…Bˆ¢H4M“ª¢24YY™³ž_E´:-Ý==ôôöáq{ÈÊ̤¤¤˜k 8ö„Ùá£GÚU«ÈÈÈ@ÒÓÓiïèÀj±•™‰(’—››pÈÊÍÉ!'gnoÿxÅ™³çذn팎[ª:!(Lú§©¹™“§OFÙ´q#ee±v‰i4ZZÛ(/+cdd”þ´Z-Û¶lÆn·sáâ%233ÈËͳÑh—ÛÙl&#=ή.´Z #£#’“MCS39ÙYTV¬ ;; »ÍŽ¢ÈH Í-­¬­«›·‹ªª457ÓÕݪ¨lݲ™ŠòòØ6àêÕkœ½pAX¿n-U+V$´‘h”ó.ÒÙÝFë[0";;Qhmk£¹¥•ì¬L¶oÛz]´ÊàPLÍ_Ðâ.5 ½}}¢@zZ*í ÆLýX­ÖÄ»1—¯^£··Á¡!::»hmkC«ÕPTP@o_{÷ìFUbÂìÞÝ·qåÚ5¼>›7n`p8f·ÏÊÊ$;;‹‡F‹,+¤8ˆ‚Äå«WY[W7£Séäñ½TI’ƒx<²³²ÈÌÈ`xx$fÆÑjX³ºŽæ–\.CÃô´¶a±ÄJ_kh¤´¸­VKvVVBs­¡NGYiéœã`6›¯«â«Õj)-.Áf·ÑÜÜBnN6e%%8].)//gãúõ÷u”£'N¢ÕjÙ¾u …S¢L®54PTXˆÃnK˜¡U!''‡ööDQdEE9I’¼W§Ó‰ðƒ|_}ÿûžòÅ]Š×ŸÆ' ¡( &£1Qâ7NügF3åØx´Æñ“§ØºyÓu…µ<^/ÇŽŸ`Ƕ­˜L¦9'ÔH$¸ӉÅl&‰$Êû|>ÒÓÓ‰F"˜ã_N'Y™™D"Bá0³9)°~ÝÚD}>GŽgûÖ-óFu„B!ÆÆÆÑé´ ŒF#’$átº0ôÆDhœÅbÁj±Lqâºz­ Àúµk¦ÄÃC!9ÊÖÍ›°Z­ó.*ñ³ÉÞå %^*yr¨àäñ=|ô(ëÖ®%mÂdß' qèÈQ6mXÝnŸó¼¢(âr¹ƒ^?ÀjµâõxÐêtôz9ʺ5kHMM™’‡ ¡±§ËŦ tmÁ`Qœî7ùzA˜¢5›þBLÏõ0=WB\»2ýØP(„¤Ñ ™frE‘öŽNúúúضuK¢ýh4ÊëobMÝjÒÓÒæ½¶‘‘Q$”îÃá0ª¢’’â c4ðûýhµ:ôzn·EQq8ìtvuÓÕÝÅŽmÛ®»Qikï §·—í[·Ì;¾}ýýˆ‚ #Eì¾LQ’ÐH&“)á Q”˜/ˆÁ`àðÑcT”—‘Ÿ—7ÅáÇ©®ª";+kI·±8˜X•OÍÄ|wÖétS*Šª¡§3ÝÇ#ÇŽSR\DaAA¢ñ¹íÃG¨(/›WPN’äÝŒ ttt üàûßWßÿðÃóª*gkd)/Q³Öô±ZêøÍÔöäñœž˜)þÜÍu®H4Š Ê•1[ªéWüoñpì7Í›3çI…B _˜›I$Ef‹[¥I’ÜL₃f9ÓìR'iý,jçX ºn^‡»¹Î¯Î°m¦Ÿ%QDšÖQ'ìé ;ÿL h¦Ÿk.sÇLêwA0 oÛ8×Yf3,¶3ÿä¿ÍvžÅz¯ß¬/ÁùÌIÓíåŒßlÛf{ÞAÀ ×ÏzŸµ æë‡:Ë{ Æ~xó\³ÜÏ·óyŸ ­vö±Xn“G’wñaÍ›Ion nöôq Ì_·Ä$únèã­ÌÛ9~·úz'rs–ç#ÒÙÕIvvö¼ÎÒ³ö׃Ûí&ož”ü nÏçÁår‘Ÿ·ü¬¢^Ÿ—qç8ùoû½ðü457a1Å|aBBP!0îGc2-,=q’$I’$YFƒ‹Ù² }ã¹t¬ë‚ˆù‰¢¸às¼ÝÄM—Û?“É„ÅbA¯[ºXÜyöF•ŠJ4½qc/@8¾i÷R”DŒ#ƒ`0ĸӅ^¯Ãa³#J±ðjMRÛ$I’$³³ÿ„…V©Îb+vŠ¢xÓTÛ ‡ùòt,I’Tn9}™U¯ * IšÙÛ“×B,…ûlíI¢4c;7ÊWFQbù[fÊ%¿žh4JGg'#££hµZ*Ê˰XÌh"áȼƒ<µópk „ýìVìßÍc¡Û­¦âL’äf£ª*n·À¿$Û¼0Qä/';gQÇMâ_È’$!O¤Ôžé<“ŸÏK(žâ "f‹­fi¹/ƒÁ .—“ŒŒÌXÊî@—Ë9‘ØOFFæ¬s(ˆ7FpX¦C|¬fëK ৯¯ÆæVV­"'7—Ɔkhu:ª«VÎÚÞL }¬½}ý½465P]µ’Üœ<ššE‘U+kÜ¿áá!úúû(+-C¥7Îrcc£H’»Ý>QÌ/8©h¬@{Gmím”—•_w]±ë‘eÇ“ˆÌòz}X'R(h…ŒfÂðøÒ’(¡ÓéÐë ó>|ñˆ‚Ù.LÄ)À\sÍŽ(A\¡A¬ºtô’yARå\ýe”oÔ‚*¢ OÊy±cÂl}ŒD"x½>U™ñ}‹¹Æ †D‰ñéÈŠ<닯]0ÓùAHÄÓ/ðj'õ*I’›‹ øü>BáùyùKþÚóûýX­Öï_ˆâçs¹\\¹z™Šò š[šÙ²yëu‰é scS#==ÝSBs½^;wÞFA~¬Bª×ëÒ†F«Álš¥,½ËÉ™3§0Œ¤OÔ–£¾þ"¥¥eôôt³û¶Ûg#A­E™‰¥q˜­/N§“óÎÑ?Ї×ãÅn·3::Š(Å¥Õµu× ns E.·“ ÎÓ×ß‹ÇãÁaw066:‘ 1ÈêÚ5×µ7Sÿ:»:¨¿|‰Î®Y!³g÷ídddNÙO–e:»:¹ték×®Ãn·3<<Äé3§š—Ó‰ÙbÁëñÌ8>¢$UäØúõ~s^Ö8RRfœØ#‘0 ŸôôŒDµ¸ÊÅåv¢Õh±Û³Þœp8̸s|FgE‘iëlÄå ¼$RTXNZJƤ®©S’JÍD4! ƒþvFÕfŒ¾LŠmkQ&½è´3;ÑD"FÇGÉÉšùK@Ξ=Kvv6ùùùSTŽŠ¢$lv Eœ.×ZZؼví¼uâ}|sÑ¿~uÎE_ENž>Íé³g(È/ ‰L]’UÐê´ŒŽŽ`±XùÐc]÷ÀF£Q††‡ÈÍɱýk×®qöìÙó€ƒAvìØAѼÙT%D4Ø êÑ2™£pk’$o‘H$Q›c©Ä³ˆ.IŠ €ŸúËijn"ðÓÙÕÑBUeÕ”wuú‡RͪZª*«Aˆ}„B!Þ8ô:‚ÛÇãqsîüYBáÑhIÒp×÷$÷E£Q<7íí±¯Ó‚BêêÖ&>"TEAž¨ÿŸcjýë¾Éý‹F£È²Œ^¯'MäpYØøÄÇ%þñD" γ1¹/²%•å bI ½ˆ¢„Ó5ÎØø(éi±¯ôöVV­\5óB?1&Ñh4Q¿&ñöD\.'cc£dN,ömmm¬¬ž¡=¦ÞK¯×CGG;…ETW¯B#I:|pÊz‡¢±©·ÇÍÚºuÄJ,¤§g°g÷Þ„ÆL@àø‰£ ÔÔ®žq|$Q"ªÎ¾Æifè¨,#L<ô>¿U‘Q”ØÃd·9ðxÜ8]ã8ì)3ðfêT à§¾þQ%„,GQUèíí ++/fnPUl6¥%•³>PŠ¢ Çrìk5:İ€VРÈŒFŠ*ã÷ùb/í m¨jÌ¡e&DQäâÅ‹<ñĬY³†¿üË¿dÿþýŒPSSÃÞ½{¬z¯ÇÃÿ|åžw¹ø†ÓÉã·ßÎ\b‘(Š?yŠsçÏ‘ŸŸý¢O,.~dd»ÝÎã~iš-¶èSZRˆÍbáĉ“±‡G}éô:Ö®]KmM5.^Æãõ’âpLÍ @¬úãl}ljjŠåÿok›r\¼pÒ¥K—øû¿ÿû9U ñµ 79ˆ„F‘#&$] Lô•¤ù)É;˜¥h-ã ‘,+ødY&øßw]{‚8u±ÑétS"<Šªà˜(”f·;عã6®^»B(" NIÂÖ?ÐÏÅ‹ç ‡Ã‰bë×o@3IÓ•£h¤¸f$öau©>Vµ¬´|Öþ9]N.\8GyYím¬©[GJÊÌëÈtâ•YeYæø‰£”–”!Imm­lÛ¶cAZÉ‚ƒËíæÜ¹3”•UÐÙÕAfFápP%Û#Ññ<$ÂÌíM̽ƒ46^cû¶œ;w^Ÿ¨jk7VSâ9T„9û1íQjj:žS§Ob·Ù³Ù‚¢(\ª¿HGg;’¤alt„õë7RRòfúvF3%Ks($ R·z FƒqÆóϦaN´9£Š&ìj‘H„ðD¹^U…H4ŒgÐCjJj,²yÏßY„?EQp{Ü‚Á(žñ1?ííG‹ÅDVfvûÌ‘XöÇØËÕÈD#БxÁ¢r9EUÔ™ î ³÷OUUŠ‹‹ùÀ>@]]/¿ü2?ûÙÏØ¹s'@€çŸžŠŠ J'Š$ÍE\høÿ^z‰Ÿ8Èü?û÷C8Ìc÷Ü3ër‰D¢¬´³ÉÄÉ“'Å©ü~ìE^·ŽÚš*.Õ_Åçó^—þ9ãñ¸)(ÈÆ`4PTR„€Š×QdeUùŒŽŽ•£x<ÞDŽþéÒlhµZü©µãcÿ»N§Ã3ƒ*lÊX+A"¾f &+ {%äGÔ˜AU$=’6I—J’$ïâ_Ö±¤x±Räz½IÒ ×®{'EAŒ™gÀï÷qáâ9òróžúñt>Ÿ/Qدnu]¢]‹ÙÌêÚ:))ôööÐÖÖšÐVÄq¹\˜L¦D!3ŸÏGooY™Y×õa²:?=-Ô”Töx…-›·.XhHŒ ’F"-5¶ö64’DJJê‚M!“ÆÔ”TÒÓ3xõÀ+lÞ¸…Œô 4Z-‘h$Qž]UTTaö?“ú´´4‚Á -­Í¸Ü.V®¬A«Ñ…Ñhµ±5)ž´mý¨(¯@¯7 Óéèîîbÿ«ûXµª£Ñˆ¢(dge“››‡ÕbåȱC³:]BLØ»|%Vs&{6¿ AhvaWÓÛÛ{ýÂ01H²¬LZDAE#i(††'l-¡Dî÷Å06:ÆøøkÖìd÷î½15±t´ÇŽáRýqes€ a9€[î'({b1¨Q¾ftн´´pUUIMM%''‡¼¼<´Z-þçNnn.û÷ï_°©b²Ððc‡¹±zzkhàÿùÝï° ÷Þwߌm…Ã!<^E…¹è zŠŠ‹&jU4-…E…ääd3::J$Áãõ☦-ˆÊ2n·½®ˆ5«×PS³š“—éïð£"Ðé‘(ÓÛ1ƒÈÑè¼åÌgBQbE€âþ ’$%**ŠÂÈÈÈœ70乆^“-U•ø˜„ ÛQd?Zcþ’îg’$ï4â_°15tY– GbÚx™ÉL÷ì—e™ÁèééÆáHaumÝ”cúfó¦-dffMùʵÙìØlöDÛÓÏ766F[[+«kcÂÆøøÇNÅnw̸ M^\Ãá0>¿‡ÃÛåJD,„É jII)Í-¬^½fÁc+ˆoŽU$Áçóáp8p¹]¤¤¦`µZñù¼8)ƒAL&#‚¯Ç4³/W¼_Fƒ‘¢ÂbÎ?ËÊêUô,V+¯‡ÕJ0Àd4!LøºÍÜÞä{i2™edd„ήŠ‹KY]»ÞXøœ‰gEžðG¼¾M§ÓI_/½½=ƒA¶nÙ6gfày5}}}3~Qª¨ w<÷|ì+RÒh°XÌh´Zº»»m뇘Pâ÷ûñzýètzA%*‡'$ɘ·h(Ž_3K>1·¾Q}'’F‡^Ò#Œ‰Íîò­5,UÅ­ªj¢žÄ®]»p¹\|âŸÀårñÅ/~‘¢¢¢9µ ±rÌ>þ¿—÷Å4 Bpì•7RZV6«Sa4óhÕ ¬©[úµë§l«?ý¾ÑY}èíëGU£ŒsêÊ -‘UçA¶CÃ+—4´w_ Ä2@cS3÷ß·4¯q§Ó‰^¯ULÌÎÆårá÷û L ˆá`3Iƒ I'èB–£‰gR«3`49ð{ûQ´©1MDÒl‘ä&Ñ××Ǿ}û¡uÓçA‡ÃlÞ¼™ššš%ž…D†E‹ÅºµXµ²½ÎÀšºµ×ûˆ¢úæb‰DèîîB–£¬Y³ŽÜœ©É¤E¡ ªÊj²²²çÔ*êõl6û”}†G†(**¦¸¸„¡á!Ìf3™™TWUÏøå?y1 ü¤¦¦R·z í& ß-t\Z‹»#Qí|b»ƒÚšÕtvu "+** ‡B¬¨XAcc’¤IøøÍgªÈÍËãÂÅsb1›©(_A(Œµ×ÔøfáHEžÑ×múÂív»¸TFCyyE…ų,ú6«mÆ*·Ã#C ô“—›Oqq såoæ íUÌ‹…)h4ZŒFL\Œ(‰1§:m,Ä’ªÙ rT ?·Û×ëô:=^¯‡h4‚×çÅjuÌø Æ•=&1•QOz{U hÃÆ5dJH’xCRHÇ#7jkk©©©áCú‘HdÎkÃ<ý³oó‡¨y0õM¡áèQ¶mÚÄ÷¾ÿ}ÊÊÊf¼èéíEdFGGijj@!æl£õˆ‚Äšµuô ÐÔÔ<ãR*ˆ"‘H„#ÇN2<2ÎDT*Ãä¦[éÐpèâõ®ƒˆJi áRªªbµZ‰YÒÒÒ0 ±4»££ó¯3ò*xÝ—0YBÈŠUS‚FŸ‚ª*„]HZ/!ä¨Qk¹5ò‚'yOÒÑÑA0dïÞ½œ9s†Õ«WO™¨%IâäÉ“<ùä“|ë[ßZr¢$¾=’’ÂŽí»Ðét³ªäEAD§úmÚ¸yö¨6Qduíš©÷órsÉš¦‘¨(_‘pÏÊÌJ8UÎÆäÅÚnw`·;®Ó‚ÌÇä-  X=ÉIJ&/Ì6›U«b^mMÌQ0++›ŒŒLÒÒÒ())Ãj±&¢Rfª·2Ý'add˜ÌÌ,ÒRÓÐh4¬¬^k/5ÞžU×3£óþtAÄáHa×ÎÝhµÚ9¯SEÖ®Y?ã=-+-§¼¬bÁΣójfÝ¢¾Õ‰È1ÕÊ„úX4’e’¶p¢Ñ(­­ ˆ"˜Ìf»¸rEN8Ž@L ,/¯àøñ¬Z¹ŽU«Ö¡ªÓ¾îUPdQÑañ—QÇ@Ðz èü6Ìö–›N;þbÄ ³ÙŒN§Ãï÷O‘|g:ÎãõáîØÇÿ:À·ïb¤mŽeë¦MüË÷¾7·Ð@l"‡#:r’ÕN/Ûv¯f$ÜADQ‘¶‘ˆWâ×Ïý†Ñ±1T…}£ÁÀ®í;xú™_SVZÞ z{(ËÚJHÓÓ=ˆ{Ô‰1æ¾;v‘“½$AP–c÷/‰Fc~1áð¼þqô–R‚€×Óˆ ™0s5¢a7'Ѩ.™=ÉÍEUUòòòX±b/¾ø"ÅÅÅ455%æ/­VKNNÇ_V÷äÉ_ÅDÔÔl!ÓÓ¯…$žZ¨O€$i®sRŸ|®xHö\ܰP“ÂTE¡¬¬|Ñ92¦ YÓÑh4‰6ÓRÓŸ­Âìô…Öh0R[»:!H-·½Ù "ÎÄlm.fìr¯4ñЛé¨jìÆˆ‚øfE,IB”$PA£Ñ¢È‹A  ÐÛ×É®Ûv£ªÊDH!ôqu˜Í± •N§‡#Ù‹˜mL¢ ·9ZˆN«#b #Úc_ÚÑHdÁ}›ŽÏçÃét222B?Š¢ð‰O|QùùÏŽÉdâ±Ç›óå Ëp{‰Iy‰ÿù‡0å7ñ½ï}òòò9…UU1c‹þ¯~ó,ååeÜuûýxB£„¢~Âr€T©ˆý¯```;nßKvVÖu÷BEÖÔ­æõƒ¯Ñ×Û¨‹24ääGÏ\#Å.ÒØì!WÛCi^6xäL&Ó’J«ûý~ü~Ì´¢×Çæ,ÈTñ&K)²!A%¨2M6B$"*g ×Ù’Ú†$7¸?OQQZ­ÇC0D„ÄWár3üÅM! EEõÖ)V8cÿn@ÖÃÉãb2™b!§‹äF唘­½‚‚ÂÚÞÛ ÄœOçB³råÊY&ø˜ÆA’bIŸL&#£1æí>aß[Ì<®ª*ƒ½ÞÄØØð¤…*n³WPäØÿN—›5ÌÌÙ‹¶DeE‘„X"§Ó‡ 0Q…N@]dÿ∢H[[çÏŸgdd„ÆÆÆ7ËqK$sï½÷b³ÙfìŸF#p±Ãvà0«|üáu|ø¿ý¯y…†8’$±¦n5ßxŽöv¾zE‰¢êÍ(j,’¡²¢‚G~ÿŒybýÐÐ××ÏÅ‹IMKDzs¹>ˆN¯Gi #SARlD£‘ æC–e:::Êzzz××ÜÜ<% hÞkÖ˜ãO Šªò{‰Æ‡M˜ìÕˆâÒ2Þ%Ir#‰ûõ 088ÈöíÛÚ5FÉ'–}ŽÑÑQRS)ˆD"Øíö›=<3  …B‰pÐ¥266†ÃáXt^ŒÉ„B!À¢¢9æ"ã÷ûoh{>ŸÔÔ›I‰DpŽ;™+E§f&G ˆ}ã'bYaª?ƒªªŒ“–š>{fXƒ$I¢° ŒC‡:…F&¤óx›±ƒTUE£Ñ±~]ͬH4I¼,’¤! ÅÔ…ªŠÑd"ð£( v»ƒÁpý‚8Çú¨( 555|ö³Ÿ%77—ìììÄÄ IµµµØl6ìvûŒêxUU±Y­|ëÿƒ`( *¤¥¥‘‘¾(gRVKoo?—.]âÌÙ³ˆ »¨5UTúºÚع}&“iÆE_UUÒÒÒøâŸü #££ˆ¢€€¢‘P ‹çÎ2>:DgGÙ³UÖ›e¬dYfûöí4440222‘ -”Øž››ËÆ!Œ¼¹Ÿ hÐê³ÄT v=ÍÒ‹Ú$Ir£‘$‰ææf6mÚÄÉ“'Yu:ÙÙÙËj[UUz{{±Ûí <ç–¼^/ãããËz{{1›ÍË|>ÃÃÃ7l¡÷ù| Þ°ö7MpˆŸ®{¥™)I“ªª F Šo†wL«SQTTŒÙlžya˜Õ3³´´‚œœ¼¹mü¢8§ç§F£ÅaOÁéÇçó¿YD ‡Âˆ‚HJj*:~ÖÈ…¹ì8²,³fÍšÄÏq¢Ñ(6ļœç²á‹¢HqqQâ\ÊD†µ…¢ª*éii|é ÂèØâ j>EU)-)A§Óͺ8 víÚ5ëÜuÇ477±¢²ræ}æð°‡­þÕ_ýլױØëžÜ7Ö„Fk"é×äVÃçóQTTDAAåååS4.\XvûÁ`pQÚ¿h4:ÅOìV#îµ\B¡Ð’æ“·¢/qâ™o7ºK¹žØà¿Ï7ãZ­–¼¼¼yO2Ûí×éÉLÏœE}.-(…ë\/ŽF£!55u^©l¶6´Z-YYK:v¡îrp£ÑÈm·Ý¶¬6âÌf_LIMeó–­³f·“$‰ìÌÙ¿ fËzcH In=TU%''‡p8Ì™3gÈÍÍ%±ye®÷AUU‘©‹ŸF£AQc¶{fy•8“$¹q̱þšÌ³ÇÅ/Ç+X„9ÕI7¢pÔ[Ù¿÷ ó¥ÃMŽS’$S¯×;‘}/;á wŽœ‹¾Ú;[PÔxÝ•0&š½Y˜ :>º=oÞ26²,ãõz1ózÛc³Z—ü˲L Äd4Ψ¡Çb±Ì{Ý‹EUU|>­ƒ~éfÊx²)V‹Ùl^Ð1Š¢àñz1èõ³F),†H$B0Äl6ßÈ’[ÍXÀ“$I’ä½€V«åµ×^£©©‰¡¡!Nœ81åK_’$g5ÃŽŒ ‘•‘‡¨5aÒ‰ ºBì¿õ‰“—›»ä¶Þ~æ0UÄUlI’$I’dnV¯^MOOýýý'’ÃʼnF£”••QRR2£éÀ ×ÓïÓòòåq6é Óå›&£›ó‘Ĺ#›:»ºáÃ|œ—^ÞÇÅKõìܱ}Ê>ªªÒÐÔDsK ìÞµ“†Æ&ºº»YY]…N§ãÒ¥zdEÁb1ã÷ûY¿n’(rþâEŒF#këêðx½\½v «Åš(Ìo¿©¹™¦æ®64°aý:9J8bíš5¼úÚë´´´òø¡¢¼œ¥“ÍŽíÛhmm[ò½šU+Y»¦Ž}û_¥­½m^Áa`pή.ÿÀ£>r”ÓgÏqÏ]w.¹’(²iãzz{§8Ž/™ÎÎX2AaÖBKPTù7"=ÿ¦Šñññ¤m,I’$I€Á`à‘GYÔ1“ó:ôFBn‘Ža?’(àDÑFÝ|lO9¹ió«Òc‘l©˜M& ¼nŸîžŽ=FÝêZ,f3=½½?q’ÌŒ þð‹TWWÑÒÖ†Ýfãêµkdgeqâä)B¡))º»{ˆF£ ’••‰ÛãÁãñ’3áêÔÛ×Ç¡#G©[]‹yÂÝh0p­¡P8LZj*þ\¢|ôRÇÙn³O„Ö/“ÉDcS3n·›;÷Þ>ïþ.— ›ÕŠÍj¥¸¨ˆËW®,ëü¢(â°ÛoˆÉ€@ÆÇç²²׿Ðäää܃ŷõ$M%oN,³U}/z‘eù:Á6A3é÷÷Óß™éãð^ùÆdúÏÓy»ÆÉëóbŸ(¥ÕêØ´"«=nŽ4ŽQ›oæƒ{Vé0,¨-›Íʵ†dYfxx»ýz3Åèè)›6làÚµFFFéíë#555¡v//+¥ ¿€k ר\QÉ¥úz¼>/;¶m¥£³‹öŽTTº{z¹rõii©”£ÕjÇf³ÅÚoh`xd„Ʀf¼>n·‡ŠòLB¡ÐŒ}[<Ë::»8uæ4÷Þuéééóîo±Xp¹Ý„Ãa††‡äÄÿv] UU±7Íd§™x©êE9³ SÓ€.QÑjµ„Ãa¬Vë{ZãϼØÜÜLee%@ƒ!VF7`±XÞ55‹!sõêUjkkñù|‰°_ŸÏ‡ÕjEQ|>‹å¦fY{»E‘ööv4 ‰wÇëõ"Ë2f³9¡ ]¨Ø;Qéîî&‰••E$ÁjµÆBÈÕX(ŸÏ‡ªªSÆ$VD.šÈ½ðV£ÓêsœÙlEŽøyxc……Ú’tRÌZŒÆ…ݳâ¢"ê/_ágOýغyóuûpæÜYž~æYFFGÙ¼i#+ÊËÑiµäçå%¾â%IB«Õ!If³‰œœl^yõ²"³mËÊËÊPNÇm;v26>ÆÀÀ………œ:sš§Ÿy†‘‘Q‚EAFFFÑët˜ŒFÒRS9rì8MÍ-¬¨Xš©b``€ÃGŽÐÙÝÍù e¬©[\=Š8ÇŽ§¯€ÃG±º¶†²ÒÒ9÷ÏÉÉ!3#ƒ§žþ5Šªpß=w/ëÞ˲ÌÙsç¹ÖÐ@4Åfµ,H€¹5˜ÃÇ!¤( Cô ô-*¼N’$r³rÉÉÎYð ¼üòËjkkyÞ«NžÉÎ;éïïghhˆÂÂBü~?ÃÃÔ––²{÷î›ÝÝ·…¦¦& ^¯—^x/~ñ‹|ÿûß§ººš²²²Dþ€»îº‹œœ¥;¦½“èèèHD5=z”ŠŠ úûû‘e™•+WÒ0ñu¾gÏŠŠŠǽ¸N÷¦à`³Ø‰D˜Í*¤§Äº‰Í¢ôz=Üw/Ã##8¬3dfMKKåñG?À¸Ó‰Ñ` ==ÜœÆÆÇ1›Í1!JUÑh4dge¢ÓéÈÉÉÆh00X:„N§#}B3!Š"Üw/³™¨,c4°Ùl<þ裌;1ô¤¤¤°¢¢EV°Ûm˜L&>øè#³ÖÕXV«•Û÷ìŽÑ[DöÙéÜuǸÜ8ó/ØZ†{¡áa¬ë²µ&¢(RXXÀüãH’øêçðqŒIàr”¾þ>œ.ç¢Ux""é ɉ§ke÷îÝœ9sæ=/8@LÛSXXˆ×륣£ƒ¾¾>î¼óN:ôžâØív §££ƒ{ßþö·h4Þ÷¾÷ñÊ+¯°k×®÷ŒVFUU***áuÕÕÕ„Ãa.]ºDVVÑh”ööö÷Œà±—¢¢"ZZZÃjµb·ÛÙ¿?µµµFZZZ¦ E£Ñàõy ˆ¢øf2¼"˦׊ ‚€N·<{·Á` `ç7»Ý6eѳÙl3ªÝãáœñÿgòú·O'Iú‰ý¦·—3-[ærŸ?³ÙLÉ XdÓÓÓHO_\T„N§#9Œ‚ S"NÞ-hi2'ŠZi$Í”ŠÓ½†§£ªê¢M76› ‹Å™3g(++[Ð1Š¢‰Díd‡‘$iÑê쥷Ô>BL¥•ŸŸOgg'“ÉÄ /¼@AAN§Y–±ÛíSâ±ßÎk‹'Šâ¢bÂUU% 1[jóùðûýtuu‘žžNjj*ÇŽ£²²’`0ÈÑ£G)..ž"4D"‘%åžXÊqK½¶åŒ‰ ôööÒÛÛK__•••>|˜üü|Q…ÚÚÚë® Xt¬ýR ƒèõúE«–—zœ¢(¼üòËȲ̪U«8wîN§“­[·ÒÕÕ…¢(ìØ±cÑc­ª*f“·Ûͥ˗fÏ’;‚ ÈËË#7ûŠ—$ÉìL©U_DQ¤¹©™î®nªª«HKOÃh4Î(D¨ªº¨(no|ðÁñù| Îë><<ÌÁƒùà?¸¨ |饗¨­­¥tÛÖt^~ùeV­Zµ`ÁbÏûöíã#ùÈ¢ÎÇl6³qãF²²²8uêŸøÄ'6Æ;vðÿøSò¡¿úê«”––RµHg™PTTÄÊ•+uÜ믿N~~>«V­Zð1^¯—ßþö·üÑýÑ’l”’$ñðãHàâr¹ÈÌÌ$266FfæTÏíC‡‘–––H¾PŽ9‚Ýngݺu >& òë_ÿš}ìc‹zB¡¿úÕ¯øèG?º¤Ä<üÉŸü iii„B!|ðA²²²õB2¦ÅìŸ:u I’زeË¢ÎsæÌTU]”Æ+‰ðôÓOóáxQtü¸}èCK¨n¿ýviiiäää ËrbLâ?/…xê{­VKfFæ’‡qç8м¼,²I’¼ýÌ>_‹“_I’Ðh4hµZZZZ¥³½“çû<_?ÈÐЪ³Mþ' ‹WÛívòóó§Lœ^¯—Ë—/ϸ4e|||Æm ³ns¹\³æýžë8·Û=cÜ­ßï§¾¾~Ñ} \ºtiÎ1±Z­¢×ëÙ¹s'ÿôOÿ”pü‹¿ø‹ëЍÌÖGˆU¦žq›Çã™õ¸–––9 ƒ×ý= qñâÅ'UY–Ÿq[8žõ¸8Z­–ÂÂBrrr°ÙlÐÛÛ‹Çã¡  àºÅÉëõ2[n’öövúûûgÜ6ßq}}}×ý]QÆÆÆfì4åÂ… 3¦_êqð¦à]ZZŠÝn'33“ÜÜ\z{{‰D"dff^' ù|>ü~ÿŒíuwwÓÝÝ=ã¶ÙŽ“e™ .̘ä(^ün¦kS… .ÌêC5Ûq½½½tvv2‚ žžNAA&“‰ŒŒ ²³³éïïO|œ¼]ØïGÝ$I¦|îH’„V£Ejjjð¸<|å+_¡½½cÇŽqìØ1Ü7ý£&&lUUkWÝ8p`ÊD-ccc\¾|ùº¢L‚ 0>>ÎåË—ùÅ/~1e›(Š;vŒ’’rrr¦L¸¢(ræÌ†‡‡9wîÜuÛŽ?NQQ¹¹¹×m;}ú4S&qAp¹\œ?žÝ»w_×G·ÛÍÅ‹¯ëc|Û¹sçf<ÎãñpéÒ%~þóŸO+QÙµk@€ .pæÌ™)÷êÔ©StvvråÊ•)ýoËÊÊ¢°°ðºm§OŸ¦­­k׮͸-===‘Üfò¶3gÎÐÜÜLccã”m~¿Ÿ“'O²{÷îë&è@ @}}=¿øÅ/fÜvüøqöìÙsݶ`08ãq’$qîÜ9l6e^ß“·?«ÕJ{{ûŒÛ,Ë”¢Dñm.\Àl6ÓÙÙ9ã6“ÉÄŠ+¦,–áp˜Ë—/óÔSO]çc‡9|ø0{öì™q[ü¸é M$áСCìÞ½{Ê6I’¸|ù2†)ý$‰úúz$IbåÊ•×m»rå ¢(288xݶ˗/#«V­ºnÛÕ«W˜¶oz¡·7ÞxƒÛn»í:‰,Ë\¾|™§Ÿ~zÆmd×®]×™?&7y›$I444‡Y½zõu}lll$ ár¹fÜ ©««›²-^5vÓ¦M7Ô7FQN:ŪU«ÞaNpI’,áÇ?þ±zÏ=÷ÄÌ­ÍDå(±\ìÏ>ó,ÿóÿ“ÜÜ\ø‹¿ø JËJÙuۮĤ¦ª*­†ŠÒŠÙBUU%Ðßß?¥dw¢CÂì™ÓfÛ¶”cÞ)Û$IBUÕ¿@çŠQ¿ÛÞ®1I^÷­±ízݪª¢×ëÉÏÏG«ÕÎxl\ ˆ›"‘Èœ¦ AøÉO~ÂÏ~ö3þõ_ÿ•ªª*EIs¸[X6?UU9yò$k×®]°¹§···ÛMuuõ‚ö»`dd„šššeµs#³¡¡!X½zõ ¹¶‘‘z{{©««»!펎ÒÝݽhsëÂétN|xfs±¾žp8Œªª“MSKš„_ˆ-Rñ—---ÌÌÌÄ€N¯Ãb±$ü`ÂÇA¦xÏ& D"†‡‡¹xñâ’ý’$I’d¹œ={–ãdzfÍšM'V«uÞRqAà§?ý)ÿþïÿÎ׿þu*++g55‚~úzˆDÂÄlÈ*³ñ¨­F¢*÷Æj*fKvãÚŸ=‰a’w/SŠ\I’4EÒ®]]Ëxö7Ï’™‘ÉŸ~éOùîw¿‹ ìºm׌Β‚ LIZ¤( ²,c0xöÙg1™Lx<ž›}ÝI’$yɳff[ø§þíßþ¯ýëÜu×]³¸hïjÅëõ`ÔPUˆÊ Ç›Æir9±›ôüßï«@šÃô«( MMô÷°}ë–yIÏœ=GUe%VëÒr!ŒsáÒ%¶lÚ4c^†³çα¢¢|Jhf|]XŽ¿‡ÛíáÜ…ódefR½ŒL‰4µ´`µXX[W· ÇÛÁÁ!._½JVVìÜÒ2ÌYªªÒÚÖN{G;[6m^ò}¸Õã!FB"ªB£Ñ ‘4ÒÓÓCUUF“‘Ÿüä'|å+_áê•«=zt"ó˜6&$LÈ‚ $Bý$IbllŒo}ë[8N¼^o"Ä+I’$IÞÉ,VhPd«#î@&G½ÁÚ<6Fœ>ÖšÑHs/Ráp˜¡¡!ŽŸ<‰{ްp$¸ÓÉ™sçðù}D"Ün²,ÇÊrû|x¼^ ^¯UUQU׋Â÷L–e9Ê /íÃåvOi?‰àt¹8sîn¯×‹g"ç¥úz:´¬¢NN—“¶öΞ¿°ä6TU% ‘–’JCc§Îœ÷ÇË /¿Œ =vœ+W®.ùüóæÔé3ŒŒŽ,«-€H$V®b®‹È߸d¦jD qÒƒëp8ø³'þ £ÑˆF£á·¿ý-O>ù$›6mâ•W^aë–­Æ9½âEáÉ'Ÿ¤³³“•+W’ššúÖ_U’$I’¼…L¾ño$„†¹|8LF#W¢^Ü·ñ±q:»ºƒ¼ðÒËŒQ\TDzz^?ˆ(Šˆ’ªÊm;w¢¢rñR=‚ °wÏnÆÆÇ‘$‘•Õ•1›Ä~¿Ÿ÷½ÂØØíøNŸ=ËÀÀ[7o¡þÊ®54’•™EͪŅ|Ç),(`Ƕmœ¿xaY÷¨ªráp˜ŽÎÎDA®¹èÀh4pûîÛ°Y­457³ºvé~Z­–­[6ÓÖÑ1çs±P.^„óça6%ˆ¢À¦MpcÜ-æÈ9ùI”ÐHš)ᛩ)© ÿ…Ç{Œß>÷[öíÛÇç>ÿ9l6[¬¾Å?wßy]?q’Þ¾>l6MM-dges÷]™H¢H{g'áp8ÖþS¿DE²³²èîî¡©¥™êª*ÒRÓ–,4Leyc …xåÕdd¤³¦n~gHEQP•Øz§Ñ.>ÇÊÜW±üû[UsÇ\F†î{=SFF”æÉ (À#>ÂÝ÷ÜÝnO pDœÛü`·ÛùêW¿Š$Ió I’$Ir«"I×®]ãŸþ韅Büçþ'?úÑÛUUå«_ý*{öì™q®Óét”¤˜øØö<~}¤ûÖæ±u…í)EQq:Çq¹ÝŒŽ‘–šzÝœ­Óéñx<ô à÷ûÑh´˜Œ&òóóX][ƒ×çC¯×cµÆÝ­ ¨±¾  át9±ÛílX·×Ko_ééiü‚¡ z¯×K?@€¦æ1Èr,ûðèè(@`Éõ*"‘ccc¸\N<OÂA±=~œááa6®_G8ž·?YY™x}>ê/_æÊ•«T®X±¬çEUU</N—‹±±Q òÑ.!é[‹åF óö~Ö-S‡x:aaöv4 ½!¦vßþÑå‡ìÏ5N³QQ^NEùÒÊOG’$vîØÎÎÛ—ßØÛÎL¢(’š’Š,˳V€fjHˆùFÌǺuëØ¾}û‚Ü’$I’äVd!~]“y»Ò]'IrcY ©¸Î9rÆæn€wh’$I’¼ðù|Øíö›Ý$IÉ#Tb9âu$âµ%G¢ÀÑ|!˜I’$I’$†V«½õI’¼Í,Bã >Ÿ?üሢˆÓ餷·—{ï½—ŽŽ4 ÷Þ{/&“))<$I’$É<ètº™Í¼I’¼C™QpãÒ¥KH’D$AQZ[[ ‡ÃTVV 1- ™F’$I’¼ˆÊQ"‘Èâ?–„XháB &Irk±SÅ„×ð–-[E‘ññqº»»Ù¸q#ýýýx½ÞDâ§… Ù¿?~¿ŸK—.±gÏž›=I’$I²(œN'ÑhtÑ‚ƒ€€?àOäPU•H4‚ªN.Ý®AQ%D–*I’å3‡©bºÃ¯ªª¤¤¤ðÐC!I¿üå/‘$‰gŸ}–êêj6lØ€ßï_pBI’(//'ÒÚÚš4o$I’äGzZúœeµg#^V;YÑ?ÔK{G òDt™€Š,šiñea6èøàÖÜy‘H„@0ˆN«·h“ÓåÂb6ÏØoE! a0fŒq¹\˜—ÑþlÄêLi–J$%  Ñj1. ÀUüšýzî†hŠ¢Ñ(ápƒÁ°¤\·"¢Æà˜—ùäEQ8uæ Ïýîy~þ˧éëëŸu_UUyeÿ«Œ;K¾¾ú+WøÎ?ý/ÆÆÇgÜþÊ×›ò7§ÓÉÀàà²Æµ³«‹ûÑòò+¯,¹ UU9ñÏ=ÿó™Ïð…/|F3£`0ñ»¡uÀ‡€Š;  „\üÑedÌ_„@¬ × G"¬¬®ºnŸÞÞ>:ÄÊêj ½ý}?q‚ô´tZZZ¨¬¬äʵkجV††‡ÉÌÈ   …1›ÍôõõŽD$;;¯Ï‡ÏçO´ßß?Àk²jåJô:Š¢"IMMAì6ééi¤¦,!5æ&“‰Ô”:»æ×Ì…Ål¦µ­ —ÛÍ{vÏ»¿ÓéÄn³áp8(-)åò•+Ë:¿(Ф¥¦.¹fÇtÜnèïŸ[pXư/M0*Ïê<÷w¨®®æ§?ý) üéŸþ)’$ñÿøüéŸþ)©©©ï9¿…p8L0DUUDQÄ`0¼m^Ó‘HI’H$’°ÿE£QÚ9잪ªâ÷û‘e“É”°K†B!B¡:I’Q3ñ¨šøïÁ`Q§¼‘H¿ßŸ°ªªŠ ˜Íæ÷ï ×b4E1f»È¢ª*&± bjDŸÏ‡(Š˜L¦ÄĦ´ß7~þé¿'I²$Iâ©§ž¢¾¾žþð‡ ràÀúúúøÖ·¾…(Š|ñ‹_œñX­VǦiÔw¹9Ñê¤:ÇȇvU“ºðg²µ­sçÏsï=wϸ8 “’â`ûÖ-´´¶244DwO/v›«Í¨¬¨¨  ?« T­¨äR}=¯—m[·ÐÑÙI[{;ѨÌèÈ(—ê/ãpØ).*D£Ñ02:‚ÃnO´?6>FKK+^¯§ËEEyÑhôºKa¹a¬Ý==;q’»ïØ» ]³ÙŒÛã!‰02:²äâZ×_ÇÉ ºreìßÍF”a.çI 6˜ƒƒƒ|å+_á©§žÂf³188ÈéÓ§ß5΋áÙgŸeÛ¶mÜ{ï½<øàƒ|ö³ŸåСCo¹¥ª*¯¾ú*}}}ôõõ±oß¾ëúôío{Öãý~?ŸøÄ'رc¿úÕ¯€˜Àñõ¯M›6ñÿð¼øâ‹ìÝ»—––^xáöîÝËÅ‹ùä'?É׿þõ)m¾úê«Üwß}Üyçìܹ“{G}”úúz>õ©Oñµ¯}íº>üŸÿóøÈG>Â<ÀÃ?Ì·¿ýmœN'û÷ïgûöíÜ}÷ÝÜÿý<øàƒüà?H¨øŽ?ÎwÜÁƒ>˜èß«¯¾ÊŽ;¸ûï¾ûxøá‡ùÿøÜn7Ÿþô§ùë¿þk &ìMþ=I’¥ ýýýüþ÷¿çãÿ8eeeS„P(ÄücZZZfœM& ªìç›3yl½•íÈ!Ë¡Ç`0/¸¯¿qˆá‘Ž?NOOïuÛóóóã™çžcxx˜Â‚BÊJK1”¡ÓéÐh$$IB«Ñ"I1aº¬´”W¼Æµ†ÖÔÕñÑ}O~üزy#»vì`llœKõ—ÉÏËÃérÅÚÁëõ204„^oÀ`ГâH¡©¥…–ÖÖ%óààGãʵk‰"QKáð‘£ô pòô™™=rsrHMIá—¿~†–Ö¶•âž Y–9sî×8rì8£££ËjïVA“c3Î)7ȲÌÝwßÍöíÛÉÈÈ %%…oûÛlÞ¼™½{÷.8g{cc#/^äöÛ_täVcxx˜ŽŽ~þóŸãp8øÁ~Àg?ûYžzê)Ö®]KKK ÇÇb±°gÏŒF#¿ÿýïcj?¯—p8ÌæÍ›9}ú4Š¢°wï^, ÝÝÝ=z”`0Ȇ XµjUbRR…ÁÁAššš¨ªªâêÕ« »cww7?ûÙϸví½½±‰¤¡¡ãÇóÐC‘šššh£¹¹™ÖÖV^zé%>ð044Ähnn¦··—‚‚®\¹’øŠçÊ•+øý~𛛝ûZß¼y3?üáùíoË7¿ùM~ò“Ÿ°zõj²²²hhh¸ÎÛúW¿ú_ýêWùüç?Ï]wÝÅÁƒyúé§©­­ÅãñÐÔÔÄ“O>IMM ?øÁøÆ7¾Áž={¨©©áøƒƒƒôôôpàÀ***p¹\466òÓŸþ”ÚÚZ¾ÿýïó·û·¬[·Ž¶¶6"‘HâÚ[ZZ¦Øj“$Y,’$ÑÒÒB0dݺu3îÓÙÙI}}=ÕÕÕD£Ñ)ÛìVáH£QåýÛZK ­vá‘÷Ýs7nT›íú/âŒôtôFÇÆÙ¶e ÙYYääd3:2ŠÅjÁj± ª*Z­–ÌŒ ôz=YYY˜M&zûúb¿O|K’Ä÷Þ‹Õj%*Ëèt:;=ú££clÛ²…ô´4*ÊÊ‘™‡³ÙÌ£ïó2rý˜Ì&¶oÝʶ-[°Û–ž®{ïž=8]NTUÅápÌ»¿V«åÞ{îf``›Í¶,s ÄL9ÙÙ|ì#F¥w¶S³IN«Õ’ššJ4¥¤¤„o~ó›X,–Yíx3‘ššJúDeµw’$Q]]Mee%iiiÜ{ï½¼ôÒK¤¤¤ðéOI’ãÔ©S<ñÄüíßþ-v»‚‚<È]wÝ…ßïçðáÃ|ç;ßá®»îâ¿ý·ÿÆøø8‹…þçæ_ÿõ_Ù²e +mûôÓOsöìYAàܹsÔÔÔàv»yê©§())¡´´4!È?~œ¿üË¿dãÆ Áb‚àš5kèë룵µ•«W¯b³Ùæ,<©©©¤¦¦rîÜ9DQ¤²²’U«Váóù®Û7 ñë_ÿšªª*žxâ Ìf3+V¬à 77——^z)V†öâEÜn7]]]ãp8áÀ<þøãôõõñÒK/ñéOˆ —.]ÂívÓÑÑAVV‹Qiiiá‡?ü!áp˜ÁÁÁduÖ$ËBUÕ„©pºPGÅYçFAÐë8¹99äΡ–’’2ÅTâp2é×ë§ü_TX8c[ÃÄ~ÓÛËÏÏ›rLA~þ²®Ñj±`­¨XVYY™de-ÎÏ ×ÏëD¹PA ï­öT¼ ,ØÎ E!%%eQB@FFyyyïJˆÌÌLt:ããã=z”Ó§OSWWGNN¿ùÍo@UU ùæ7¿‰Ùl&‰ðÿðX­V.\¸ÀáÇ9~ü8ßøÆ7ø·û7ÆÆÆxþùçç0›Í¬ZµŠx€Ç{ŒuëÖñØcÑÞÞΫ¯¾Êƒ>˜ðIe™‡zˆ×_òiåaE¡¨¨ˆ¢¢"öíÛÇáÇټy3v»ý-¿7²,322BZZ6›ð¾÷½}ìcüó?ÿ3‚  ( W®\á7¿ù çÎãk_ûùùùœ÷9ž|òIE™’I7''‡¿üË¿$33EQ’‚j’w%76Ý×{ˆP(ÄÓO?Ùlæ™gžaݺuÜÿýôööR\\LFF‘H«Õ:¯g®¢(lذÂÂB¾óïžžžð}ˆ“““æM›xðÁikkcåÊ•Ü{ï½ŒŽŽ²nÝ:<ÿøÇ©««ã¡‡â¹çžãïþîïøå/ÉŠ+¦œOUUvìØÁ×¾ö5V®\Iee%Š¢ ( k×®¥¬¬Œ¿ÿû¿çĉüò—¿äî»ï¦  ˆùNüÛ¿ý[ÂFúÐC-Ø¥ÕjùÔ§>žð¾üå/³sçNššš…BÔÕÕM‰ÌÈÎÎæÿøùö·¿Mee%àÃþ0O<ñáp˜¯~õ«üáàá‡NNÎIÞVEaëÖ­‚À~ô#ZZZÐétlݺ•/|á ÜyçImC’w5Ò<ð?***nX8¡ èõú'ó .`4ñz½lذáf_û’ñù|¨ªŠÓéÄét²wï^þâ/þ‚¼¼<²³³©ªª¢µµ‹ÅÂ?øAŠŠŠ |mm-###‰Ÿ‡‡‡Y»v-wÜquuuôõõ¡( _úÒ—¸çž{$ x3´ªªŠ±±1òóóIKKÃd2‘Mff&N§“mÛ¶±uëV†††ãŽ;îÀf³±ydd„ºº:n»í6A`Ïž=¬^½š¡¡!êêê¸óÎ;Ù°aN§“þþ~îºë.žxâ ÒÓÓE«ÕÒÓÓCoo/ƒƒƒlÞ¼‡Ã‘ɼ뮻p8‰s­^½šõë×'Æ®¸¸˜­[·2::Jkk+)))üÙŸý?þ8Á`pJÅÅÅø|>ÆÇÇÉÍÍåSŸúëׯ'//´´4Âá0ÕÕÕX­Vî¼óÎ)6ÝøùW­ZÅÆ¯û=É{›®®.œN'3j¡ Aƒ(Š‚Ùüf䃢(°wï^6mÚÄG>ò>ùÉO²jÕª)BCüxI’ïáBèíí%''gÁ©œ=¡PˆŒŒŒ›=´3âõzñûýËÎÿÓÛÛ›0 /ŸÏ‡×ë½aI ý~?‡ìììÒ^ Àívß°öK0¤··‹ÅÂàÐPâyvØíX-FÇF~ò“Ÿ¨wÝuF£ñ:„¢(H’´(Ó„(ŠØl¶C‘~ò“ŸššÊÀÀŸýìgoÊ $I’$É‘#GhoogëÖ­‰È›ÉØíö„ÙnÜ9N$™±V… SòŒÌ´Ýér¢ÕjÉÏ[˜Ã ªªœ"Ñp"µ‘Ùlŵ£ÕH”g-=„1I’·‹ëÔ‚ 8qâgΜ¡¹¹9‘Qp)H’DQQåååS“$I’ä½€F£Idçmïlehh€€Ï‡×ëÃíö°ÿl;?;ÔÁ³'zˆÊs;ïF£2—¯\áÀë¯ÓÙÙ5ï¹Ï¿€×ë]rß.GŽ#0K…ó.âñx¦üMQ”DõÏ¥âõz9zì8MÍÍËj§»»‡×ßxƒ3gÏ …tÌðÈ‡Ž¡¡±iÙÎÔªªÒÞÑÉÁC‡ñ΢~k3»ïØu‚CÜkxÏž=¬]»I’øÅ/~Á±cÇ){ã¶¿… Õj©©©aÍš5ïÚpÌ$I’$™ ½NŸH•#ØSóŠfbO+`0’F«ÛưÓKmž4w„¼¢È„Ã1ÓÊï_xaÆ|)Ëëñx8uæ ^ŸhTÆçó!O8Aü~?¡p €ªª)é‰V–e9ÊoŸÿ/\.×õí{½œ>{—Ûko"iÜ•«W9rôèŒ& …2:6ÆÕ†N9»ä6TUÅãõ`4¹X_Ïé³ó·åõúøÃ‹/ †8xèW¯5,ùüñqêíëåð‘£ /«-YQÉ2áYþ…dyÙBÛ¤œuËŒ¦Š¸Ç¼Á`àìÙ³dggsþüyöíÛGEEv»­[·¾'ëT$I’佇,ËD¢‘EÏw±DQqçs“Áȵ¡(ÏœgužwH {ÈÅí+S¸kmÞ¼íét:ª*Wð‡_J”óžŽßàåW^axd˜öŽNB¡/î{™‘áÊÊJIMMåÀk¯'>EaÏm»PU8wá’$²wÏÆÇÇQU5VHkÒe^Þÿ*CCC´µ·ã8õÊ~††Ù¶e+.]äZC#©)©ÔÖ¬ZÒxrÛΜ¿xaÉ÷,^3Ò××^7¿¿Hÿ@?z½ž»îØËé3gilj¢fÕÒ‹ChµZvlÛFgW÷ Y+Ï pa`€ÙŠS*ªÊƼ<êÞâêÕš™J} ‚€×ëe||œ’’’Dø[>I’HMI¡»·7–zÚö¶ö6BáŸøØÇxêé_ÑÚÖÆÙ³ç)+-áä©ÓlX¿ŽÒ’²²²hjn¦¢¼Œ«×ðù}ÜqûítvvqìÄ zzûH±Ûimkãbý%23÷"Š"í±º7û(¿xúWH¢D^n.½½½465±²ªŠô´ô% SY^¨u8æÕ×^Ãáp°vÍü΋“×3NwÃ>ŒoTÀøŠ´4rç ï·-Сv9hf ÷Ñétèõz¶lÙ³Ï>‹ÏçÃb±pöìY¶lÙÂí·ßž’$Iòž =-}ƨŠùˆGeÄM»Z­ž²T ݞ˯·qïº?£ccB± µz½ŽÜÜ\V­Z‰ßïÇh4à°Û°˜ÍØm6º&ªÑŽãõy±˜-Ü÷ݸ½::;±ÙlBá0Z¿?Ö~(¢¹¥…†ÆF Q9Š4ÑN(ZpTÈt¢Ñ(N—ǃÏç[rÅñ'â{ï%*Ëó†·fffâõz¹ÖÐÀÕk×(+-]ÒyãÄ+»=œ.ÑhtÁ!¶3aÓëßÁ`>fâV«%==«ÕÊsÏ=G[[ŸÿüçùÁ~À‘#G’ÂÃéëëãØ±cÜqÇ8¢Ñh,Kä“’  ž´³ïÛݪ:_1ÖŸ÷Ýpó¶kpö¾ Â"Îu«Ž€þm,O³pØSðù¼Ô)z9c¬R¥Ù´°òÍáp˜SgÎ244ÄÎÛ±X,×íSVZJo_?"#=Úšú0 defF±Ûíâ°;(++%3#ƒ§Na6™Ù¹}K"qÏçgÕʘÀ108DuU%=½½Ï<ó _øÂøö·¿^¯gÛ¶m ò<ýý¤ÍÔÖ"Qgg'Öœ´Fã²ÚDgw7½sFÆìm  D†›²I)q¡3ù¯÷ÑBn7þ±1Rn@1E–kk#¥¨I¯_Þ¸ ®®.tV+Æ””e·#äñà(*º®-U(io'h±Ð—‘8×¹9a¼½´²2„%LÂÓïìĘ’‚Án_ö³áîïç¡uëøð‡?¼ì~½H’„(Ѝª:%ãi\˜š­–^gH¹J_B™Á``ïžÝsî£Õj¯Ûç¶];gÜ7¾ˆåäÄ’ ÍTœjǶ­±¬ÖD‚©=·Ý6eŸ²’’)¿èñÇ–5¾ùùüñÇÿhYmÜs×SîÓ|TUVRUY¹ìsCì9¹mçn۹ㆴ÷ö2ûx]W3^/¡¶¶–®®.ªªª0›ÍF|ðA~ñ‹_ðýï£ÑHZZÚ‚»àp8ÞSá˜/¾ø"ÍÍÍ|ï{ß›ò÷£GÒÙÙIvvvâkmxdoEÕŸûê4 Ž hC!*òäûïÇYX8§ààéëÃuâé?¼ìkˆƒtþä'ä<ôÖ¼¼å-’„çµ×Ð;d¬]‹:›°)@óK1ëÈúhI«0ýD‘¡Ë—:uŠŠO|–™r: 1üûßã¸ûnô‹Èî7sÿúñ Œ+V±yóu÷sQM‰"Ã×®éî&ýŽ;¦lSãø8ë~üc.~øÃdäåÍþ\Lr»iûѨøÔ§bÒ2PUç¾}˜++I--]–æAÔhð8ÀP{û²úôvrèÐ!:;;1›Í„ÃaEÁh4â÷ûIMMeïÞ½KaOrãI¦¥_ sDUÌô«ªJVVëׯGE***X±bŠ¢ðñœçž{ŽÕ«WSUUµ`SEff&ùùùïê( UU c6E¿ßO H¤«5¸\.ž}öY~øaÚÛÛc!’(" ‚V‹Æ0µì®`± ÚíØ€ Å2§£¾¼œ”‚4ˬû.Q­ƒÕŠÁjÅh±,Kõ.wÞ‰ ŠHZíŒm ÀÀ%pwÀºO)U?ë~«£ÕŠa¹ =€ÅÂê­Á°l!D 6F› £ÉÄr£ wÍrjk¯[èU úÀ¼55++™ïn € ªèÍf 6Ò (ZVõ¾÷!j4HÍ’Ÿè„s¶8)ã­Ž üÇüªªòÄOðµ¯}¡¡!þå_þ…_ýêWÔ×׳k×®¤àä]ËŒ^Š¢°bÅŠ„`0Ù!Š"üà”1í½F0ä¯þê¯8wî}}}î¼óN ùîw¿Ë+¯¼Bff&Û·oç;ßùNâ8UQèŒ~Z’¡[™ÏLlñ<þªª‰D(--åË_þr²|{’wsø8Ü쮽›$‰ªª*Þxã ‚Á`¢2ä“O>Ék¯½Fkk+Ñh”«W¯òå/™ÿýƒ`u8Hq8f]b‚CÆÕ«oû5½‹Œ*CÃïÀ’ …;~Î[i|»ú¥ X¸ú裋Ž¿ÕÆLk4":³ÞA‚Ãd3ãô¿¿›Í±IÞK,ÒÇáF¢( ^¯7Qã½Âúõë),,Lü~Ï=÷$*×¹\.¾ò•¯ð¥/}‰••´öö¢Îcß ¤¥ap:oX"‘[h?A'¬ýï 3÷MCSöÊ+´íÝKØl~×<ïÄ¥V„DúýøÏ¢(Ωmˆir£(ªš¸w¢(¡"" ‰ï–;šäÝÌ[.8~ó›ßàñx¨¯¯§  àf_óÛ®]»¦üž™™™¨Eïóùxì±Çؾ};ƒaþ|@ÐnG ‡ÑúýDLïŽ zqgÈžS1gH­á¹€¼]¨@Þ‰DõzÖ¬y× ïDA`llŒãÇ3::J0äùçŸgË–-sÖäî§µ£ùÍÄM ™iõgaÖëxts΂îk$I+sáñx0™LKö¹P…H4ŠN«12Áãñ`4šÐhn¼OG(B’¤e%L’e9ÖŽFƒ~Á ß…‡c&-buKtºwJ®’%˜*AHdþZŽpa6›ùä'?‰ üøÇ?NÚþ&ÆäoþæouLT¯GÑhÐy½„M¦wü¢!®hü=¬z ,YI¡a.TÀ42BÑ‘#\úèGQ$éÿ ¼ÓÑébÙ¿þõ¯1m‚q'ÛÁá~ÒS²ÐLè5"#ž0û/Òá£$ÃŒªæÌØ ùéÏ~NqQQ"OÁL¨ªÊ¾ý¯rÛ®d¤§/é¯^»Æï_x‘Ï}úÿ7c8ý+°cÛ6²&>Š\n7¡PˆÌ‰œK¡³«‹çÿë”–”ðÀ}÷.© UU9wþW®]C–eîÜ{;… øpD"<õô¯°X-<úþ÷/ù &x=ó›çðx½èõz6®_¿¬Úo/s˜*Ün÷u’¤(Š;vŒï|ç;|å+_açÎËrˆŒ·ŸŒ¥]:²Á€¬Óap:ñNzI߉@ЗÅ{ ½2)4̇T¼ôƒµµ8‹Š’BÃM&^E8îÃGQ”9?´ô:=£!û/xØTl¤u8H—KDGˆG6U ‰ógã<{>–‰Ð矽Ls{G­mm\kldçŽí´wtÐÓÓËŠhµZ®54¢(2f³¿?ÀêšDIäò•+ FV­¬ÆçóqáR=¢  O­ÓÑÑÙIKk×®5²nÍN>C$¡¦f^{Ööv>ððû)).^Òø¦¥¥±aÝ::»ç/>‚ PY¹‚ššU¼zà5$8\¬¯ÇãõÞÈUUq{ xgW¨@ž²,‹iuÑhfÒ(‚@OO/^¤­­5kÖ Óé0 Ȳœtþ¹ D% z:–þ~FV¬X~ƒ7óZÂpù×±è‰ÂmI¡a>T ûâEÌCCKrˆLòÖ°ÐôÉLFƒ·K¥±Ï‹¢(¸ƒ rÀÉßQFqÖü‹JgW7MÍ-ÔÕÖ208ˆ¢(×å¿èíëcÿ×XQQV£¡¿¿Ÿc'N’š’Bcs3+*ʹT‹ÅÂÈè(iiø|>Âá0:–Ž‰ŠšCÃCäædã÷û™\ ±`€W^=@eE’$¡( ²"Så ¯“É„ÍjM¤¬^ ³™ôôtº{{–ulV+¸Ýnöì¾mÞý¹x©ž5u«imm#‰,+ º(Š”sþÂEŽ?Á}÷ܽda €±´ÏžoFUÁ¬}뇙E–ezè!Ö­[ÇéÓ§ùÞ÷¾‡ ÔÔÔ°~ýz¬V+f³9)@¼€;/GgçÍîÊòPc¹D TÜË+÷.ÆàrQ¶?M÷ßOä]`¦z¯áóû°Ûìhµ:6­Håb§›³.*2õ|è®ròÓVÄihxÇÉӧeë–-NýŠ"-5•Ý»vÒÙÕÅÀà ]]X,f z=ª¢RUYIA~W¨Z±‚Kõ—ñx½¼ÿ}ÐÑÙEK[áPˆ¾þ.^º„Íf¥ ?FÃÐð0‡ƒÛví¤£« §ËEGg^Ÿq§“åe(ŠBú"2 ÏÆrµÔ½}}9zŒ½·ï!';{Þý‡GFðz½œ:}†Îîn¶nÙÌŠŠŠeõ?nNzõµ×¸z­ay‚CMfìßMfV­VKUU¯¿þ:;w¸˜£Gòì³ÏÒÞÞÎã?Ζ-[’> o#îü|rOŸF”eÔw`‚™x…»Ö|$mRÛ°V¼ðcee WW'…†w I“MF3ªäñ­YäÛdÖWd’aÓa0,ÌáyúulX·ŽúË—imk¿NhÈÏËãÔéÓ<÷üïfýÚµ”–”`µXÉÍ͈êˆi*4’Q”0 ¤§§qàõƒ„Âa6®_Ouå "Ñ(O=ý+víØÁØø8ƒƒCäåærüÄIž{þy†‡‡q:]ôöõa4ÐëtØívŽ;N[û J§Õ°X(CÃÜ8y’¶Žê/_¡fÕÊ% o>Bÿà .^" S\T8çþ5+WR³r%-­­œ9wžò²²eÝ{YŽibzzzbûÖ­ËjïVaΨŠh4Êúõë¹xñ"<ð|ë[ßB¯×“’’²¨%*@&Yñ\¢¢`p¹ð§¦¾£¸Ý'bzKRh˜È=wk?§?÷¹wÔýNò&z½aâîÙmBáFƒÊvÙQUQÒ Ó.Ìã?¾xV”—Ï¡–™‘Áy„‘‘Ö¯]K^n9ÙY `³Y±Ùl¨ªŠN«%#=ƒÁ@ff³™®în ¹99±ŒªZ-÷ßw/v»=VZ’HMMå±Gfx¢ý¬ÌLÊJKˆFeÒÒR±Z­<øÀýX-KW—ôÖ¯_Ǻµk½ÖLæ¶;GUÁj¿?ññ-,( -5uÙiÐA =5 VËÆõëÉÌ\ºÃè­Äœ‚ƒªª”””ðÛßþ–††¢Ñ(éé錓?Cµ¹¸pá§OŸæáP|é½JÄd"b4bÁÿ*&ãÐôB,t2‚b~TÀ24DùË/så±ÇÞU9މȲL4]´yV¢ÑhÂN."ýòÓ›Æ9#8ÒÓÒ¦˜ ÒÒÒf,Jh˜Hÿ¿¬´tƶ´ Ɖý¦·W<­Jí²Ôñ€Ífe•­zÙã”—›K^nî¢Óëõè—Yb>ùùy@Þ²Ûº•˜3HUUURSSY¹r%?ýéO¹rå _ùÊW$‰ï~÷»|éK_Ân·/èeÚ°a;vìHš6–<á iíë{Ç8H €o.? ew%#(ŠSý›ßлq#£I¡á&3æ# /Ipðüä½7ò×$yo° Pƒ®®.¾ð…/ðÓŸþ”|à¼þúë?~œûî»oÁ¡šÉpÌå!ž¼<ïòÃò@ý/!w=ämH AJ@ÑhèØ½;)4ܤ§¥“•‘µèQw'ç¾$ï@æH5ߢ/Ë2÷Þ{/Ø£æÔ€IDATÛ·o';;›´´4¾ýío³qãFöîÝ›,xu#PU”p˜èD¬ô\%Ýùùä:õŽpŒ†bBƒ-J÷&…†…½Ìª¯çìg>ƒ¬Õ¾«9Aäiyn5â> ÓA$ A®«$p^v¹\vá²,``X 6Œmœ=öŒ'ç$rV+vNUõþÑR4£,Mð¸ŸåéPuêœSÕu¾õ–®.Ê^|‘‹?LÐé¼eÏï\Ѱk=55 ÔÕ±}õê›Ýi!mmmìÛ·EQX±beeeÉ{b’ÛÍT½F‡ Š¢àr¹’UàæI«¥`à ¶mCÒj&ȱXÛíØ››ñÏ0ì öeôÂ’G“a—SEïó1ÿ yãFz**n{¡ wͲ—/§åÀ„·QÔ•(Š<ýôÓüîw¿Ãáp O?ý4wÝuŸüä'gíŸ$É­ÌŒ*xL&0„Ãa¢Ñè¨Ï$IJ†cŽƒ N¬éé¨L¼È*@_I ©ÕÕ´/[v³»~íX€¦½Ðs)v©3%…†© F£TýéOxsrh^¿þ!4$À”’‚ÐÞ~³»3%$IâOúo½õßüæ7Y°`¢(rùòeþó?ÿ“_þò—|úÓŸó>Ž„èrwÄï ‚ÅlÅ#[ÑJ…i³¸H’äz3ûÒ_W!Š"gΜáðáÂÈÝ>üùtÃ8ß ¨WýM„ô–—“uâÚp˜Ø„ ÍÐv ZÂâ€Ñyíx„cùzø=¼ E¡ü¯EŠF©Ù¹“I«1öܽ]çm*×ý­‚ tuuñ‡?üÏþó,[¶ŒH$‚¢(TTTðñœø‡`ëÖ­cš-šêèG¯Ó¡¨ ¨*.vR=èÄjÔó¥ûJ',­­( §Ïœ¥·¯A˜?¯ŠÌŒŒq·?}æ,¥%ŘÍSËLy5¯—‹—ªY¼pA"ds$gΞ£¨¨pTΆamôl´.~¿Ÿó.’ššJIñÌ’HA.{¼tõûYYlG#‰jt#‘»ßz‹Ë–a2™Æ­£0\NúðÑ£dd¤c4‡jQèH4 ªŠ(J(Šœ¨‚‰DDV‹¢(ìÝ·Ÿ7vï¦0?o”à Ë2áH„ÃG’šš‚n¨z½ž‹—.Ñ?0ÀšU«f\(ÊÝÓÉS§°X,3TU¥¿¿c'NX·vͤûu»Ýü陿‘‘>kÁAQöìÝGYi)))Ž) .ã7¨‚<‰˜- ÎŪ0ƒ¨ŠD1« ªp‰¢xT)<÷ÜsìܹI’Û$í~sCL§Ã›“CÊåËô‘°åF#ý pái¨z¤AÍ«»hÚ»“Ë¿AiµT½ë]h†ÆîK—hÞ»—ï{_âS¢QªŸ{ŽyïyÖŒŒ·ÍSèLQüýûI?{–SûØ5Ižäh”ßÿ~|ÎD‘”ÒRÊﻚ^Àœ‘AêˆúƒMMtŸ=˼w¿ûfë¶gø>6Ö½s¤†u,Àd4r±;ÆÓÇXœ«g0ÍÝî(·sϲɵ±‚ Š"]în °Ûl×l …xõµ×éè줡±‘H$ÂK¯¼JWw7åe¥8Nv½ñ&¢(¢Õj‰Åblݼ 8vâ8Iö­[èïï'‹1¯ªŠ‘C …B¼ºë :::¨ohÀpøèQÜî6¬[˱'¹xéV‹•E ÌhŽ Øºy3'OŸšñyóç“eÜ==Sbb±GŽcñ¢…øýþ)er$I¢§·«ÅBÊ,²`p²NwŽ/(*¬È†EÓkwL&ˆªk2eY¦³«“˜›°M»ÝŽÓáõQU—ËŇ?üaöíÛÇüùóÉȘ‹A$‰»ªŠÂ={v옒jûz!Þ8ó”Þéóâ—[Øë¥òÈ[¹…øuñû©}é%ª~˜¶C‡ÈZ¶ŒŽS§ÈZº”ˆ×Ë`s3©ee´=JÅ}÷Ýì)¾®¨@î‘#ä8À™|„@jê52º‹¡5Yùwwš•$›šö÷“¹t)mG޳j­â(( ~×.¼ííØ²³o{¡ëf!Ë2óçÏÇáp°wï^xàÂá0>;zô(^¯—õë×)XèõòÒŒhpÓЧ% ±¶HÏÝKÓÑi&°Òét<òÐCô °ÿàA$IbéâÅ£¶©¯¯Çðó‘~€'ÿðGêêë9zü8%EEì?pˆ•+–‘Ÿ—GFF:µµ—)-)áÜ… øý¶lÚDsK3¢µ­ §ÓIcc#ç.œ'== QihŒW›üð?ÀïŸúI"/7—öö.\ºÄ¼ªJÒ\©3F3»{[4e×›»±X,,[ºdÒí/\ºÄé3g(Èϧ®¡öö²³³f||I’xà¾ôõõsøèQ¢±(ׯŸù€Jœ6I$¤Ã0µ¶fÁ˜‚ƒ$IdgMž¦SÆ®‹Å //oV¥U“Œ æç£õû1»ÝøÒÓoйb8+äéßBÁ&ÈY_@•e÷ìÁÛÙ‰‹á(( ¥¤o{;Ñ@€°Ï‡«²’þ†j_|U–)Ø´ T5þ^Uoª@t=QœcÇ(ܽ›³øÞÌÌñÏŸ H‚$!ÍÍØrsI))¡úùçñ<ó ¢FCîš5tŸ;‡§¥{Rp¸n¨ªŠÝnçSŸúO<ñªªrÇw Š"ûöíãü#ùÈGÈÎÎFQ”kò>hµzÊS¬¼mOí­ç®¥9lšïL¨ú§Bjj f‹§ÃA$½æ{Q …Âø|þ¸IÐh4dffRUYI0Äl6‘âtbµZq:´´µ!‰"~¿P(„Á``ûÖ­x½j/_Æ`0 …ˆF£H’H8ÂçóF©½|™KÕ5ètºD=‹ÁAϬJR˲Œ×çÅï÷ 'L¯=‡Ž¥³³“ûïÛ9¥(ÀìÌ,î¹ë.ZZ[Ðjµ³*© ñëÅáp`2š¨«¯ó|M ‡á†“1næÈÙd:3™L¬Y³F3ë‰O26a«O^égÎàÛ¾ý†_B8ó[È\…¯Rl Æ”,(±ú*UU–QÁ@JQgþû¿±deaËÎ&80@,Oí{;fÛS¼C‡(|óMÎ|øÃ æåMKè‹…BhFt –Œ Ž=þ8k>ÿy´’„Æh$–Œ\ºîȲ̦M›øùÏÎO~òTUÅjµòþ÷¿Ÿ|p\_.»Í?àcI‘ÂÔRlf=ZIÂbšZA¨H$Âþƒ‡hïè 33ƒE æ_³MIq1--­¼òúëØívΟ¢¨tvua4Hs¹ˆÆbج6rss°Ùlž–Æ¡#G1™LlÚ°»=þ› ƒ,Z°ŸßOgg'U••457óÊk¯c·Û(.*¢·¯Y–).,¢  €ó.R]SÂùó§4®«ioïàä©Óx<Nž:ÍšÕ«fdêöx<øü~žáEV¯\IUeńۻ\©¸\©äæd“––FZÚìBÞeYæØñã466‘’’ªËgÕޭœ;G ‚@uu5GŽÁf³qÏ=÷`4Î:IæŽöåË){ñEš6mB¹ÁZÄç~Îb(#+¤ Ф–—“¹d Š,ƒª …ˆ;ù‰¢HÔï§õȲ—/GÔépWW£5з£?ŒªR¸w/¹‡qæCš¶Ð 3›ñwuðùèFÔhœõ9*ݱƒ@Býªª*™K—bJM½ÙCN2¢$&‹]%¹­˜òJ.¡Pˆþçæ»ßý.Á`pÜO§ÓQVVöŽÃ|þùçùÙÏ~–x_[[Kjj*ÿõ_ÿÅÿøG¾ÿýï³gÏZš›g%PRR詨 à­·®ï€¨yünXø~ÐègoJ°fd QdÍèpÜ6‹Ÿ ¤ÔÕ±âg?c  €3úМ ’Á€-++ñûD[v6Ò-”E4É zC¢ºf’$·SÒ8 ßþö·9vì?øÁ0›ÍÉ"Wc‰Du9‚Á ±X EQX³f «V­J„Åb1\.«5î¼£(q3Žª"L3ÛZÓÆ,ÿÅ/°vuá‚í|&Ô½Oò´ôc 3Ïÿ:Éû·+B,Fá¾}ä>LÝwÒ¾lsûÐy»Ì*Ë(’„:‰ºÿf£(Ê•¤xÓ`Ø÷!]–ävbRÁa¤ÐpäÈ~ô£QUU5©]ïH0äÿùþNžö±ñîw¿›ßÿþ÷´´´ð?ÿçÿD§Óáp8ˆF£<õÔS¼òÊ+<úè£lÛ¶ ˆ{Ïg-]JÞ¦MñPÄij éŽ;XñÓŸ’zù2½¥¥s²X @óh9K?¦Ô¤Ð0.ŠBæÙ³”½ü2Ýóæqî}ﻦîD’kÉ\¼˜ÔòrÚB¸…5˜®éié3Ò8 $ÌJ]îêk‰ ÝCT•&ƒŽ‡VLMcF‰F£ † M>¿£Á0㚪ª“e4’4¦iÚï÷c˜Eû“QÅYµ­(J\ ¬Ñ âÃ\I'>ãŠÅbD£QT@§Õ¢™F?nU4ãù)ŒŽ=Ê~ô#æÍ›wMÑ–É<ùä“x½^Î;ǃ>x³Ç|Ý$‰E‹pøðab±ë‡Ò‹Æb1üq.^¼È?ýÓ?QTt¥p‹(ŠX³²H-*šq¥À ÃAÃÖ­”½ø"žOš˜avÙÅ ý4î†EKzRh 0 Pöâ‹XÛÛ¹ôÀ¸«ªæÜ4q»bIOG¼ÍÍ·tY홆Ô]½Ogw;NG½ ­F¤Ïáµs½4ôPà2¡ª“†!V×Ôpüä)LF#Û·n72KUU^}íuîØ°—kf¾C/Uó×_äSŸøø(G÷a^}}ë×­Mäwðz}„#a\³ðWjniṿ¾@qQ÷Þ}׌ÚPU•'OqîÂyTîܶœœÉ3"Çb1žüãÓXÌfzàþâ‚Ëÿü ƒèôzV­X>ã¤X7ž Š\y<žk7‚Á ßùÎwØ¿??üá)))Iý­V;¥’Ùlæcû’$½£ªc.Z´ˆÌÌÌÄû7ß|“ÿøÇ<úè£=z”C‡¡ÑhزeKÂ3~6å… }Å ÒΟ§ðÍ7©½çž/\qÓDíKñJ—Žü¤Ðp5* Åbd=JÁÞ½ô••qôoÿ–ˆÅ’¦ÁTËÉßj¨ªŠC¡ÕjÇÕèu:ú#FÞ8ëce¡‰Ë]Z<$%ÌC+KDaB­F?/¼ô2¹¹9”—•b2]· ¹¥…ú†F.VW³~ÝZš[Zhko§¬´¤¡ær-Ь`6› ̯ªBE.\º„Ñ`¤²¢ ÀÉS§ˆÉ2¡«´Å-­­ñö/]bÉâÅœh=I4c^e»Þ|“†ÆF~è! ògVBÚép°xÑBZ[Ûf|ŽA ´´„ªÊ v½¹›s/LIp8{î<}}}sâçª*¬[³šÂ‚‚Ù—`èôA·ütüª YH»¾Ur5ç@’$þøÇ?ò‹_ü‚ììl¾ño$|UUIMMåÿïÿMZZÚ”&wXÝóN Ç6C #Ë2•••=z”#GŽ`0˜?oÞœ%QD‘êûïgÙ/‰'7—®… §½ˆ @o-\z濜Eo¿›úõDU%µ®Žâ×^àÂ{ÞCßP~ФÐpû#IçÎã«_ýê5ßE£Q¾ò•¯°eË–1MºFƒ‘†•ó­~"1oH%ìëç“Û‹)ɲOzì.·›ÁAV¯ZÅ[ûö#U••£¶éèèàåW_£¸¨0²ÝÕÅÁC‡±Ûl\ºTMii 'OÆl6Ó×ßOªÓ‰Çã—`pp`(ˆÛí&++‹`(D8|¥|xgW/¿úE…¨*(ŠL0âìùó zÐétèõzŒ†™GùX­V2Ò3hïè˜Õ¹rØí´´¶âñzÙ<…"WÝn7§Îœaù²¥ÔÕ7$Ì43Eòóò8zì8â޻0ï .¸'®Ž©çHp˜ :fNNÎ5‹¿,ËlÙ²…?ÿùÏñ¾ŒÐ¨ªŠ^¯Ç: djÜ}÷ÝÜ}÷Ýc~w©±æÀ–6ì(y顇¨úóŸ ¦¤àÉÉ™òb&Mpþi¨¸\I¡a@U±uvRøÆX:;iÞ¸‘Ž¥K‘µÚw¼À rEspuÖÏÛ- ¨  â÷ûùîw¿‹N§K|÷o|ƒîîîq´Z=«ÊS8Ù0ÀéVE©:>²£„‚Œ©%‚ªŠ Ö¯]ƒÏç£Ûí¾Vpèê"55…í[·ÒÖÞAGG TUV"ˆ"²¬0¯ªŠÜœ.^ºDeE9gΞÃëóñÐ÷ÓØÔÄåº: ÑH„ÓçÎa1›ÉÍÉF£ÑÐÕÝÃnO´ïñxiëhÇçóÑÛ×Gyi<ýô\¤lžíCUgg{öîcËwLIÛÐÙÕE?‡¡¹¥•Õ+WRQ^6…#s¾D‘÷Äïû¯íÚŹóçg'8,ʘ£’ÙSaSÅX'f8ûcaaá˜;M%[Z’›ƒôTTмq# ÷;N}ìcSJ %ž8÷$”쀌·×Í~¦$†Ž Þz [K K—r顇ˆ˜ÍI- G£´<‰£°½ÕЧ­ gq1‚(¢ª*}uuX23ÑÍ"Kê­†ªªØl66lØ€a„?ÑdZX£ÑŒ@ˆ÷¯Ï"ûl+«*2ɰë0èMS9,™™™„Âaž}þ¯ ²cÛÖk¶ÉÎÊâð‘#<÷ tww³tÉb p:dgeFQQŠ;Š¢ˆ^¯Çétòæî=„Â!–-YBUe%±XŒßþþI6¬_GÿÀÝÝÝdgeqàà!žûë t»ÝôöõÒÜÜ‚ÑhD§Õb³ÙØwà M•Ìh~{zz8rìuõõ\¸x1.ôÌ@ˆxó­=tuuqáÒ%dE&?oâE{Á¼y̯ªâr]=ÇN§tHš)²,sáâ%ÚÚÛikogíêÕ³jïÆ2Æa<@Î+äm‡4¯_&bɯÍ©GPxˆ'v:ûäß9+’Bƒ Š‚£¥…üýû±µ´Ðµh—﹇ ÝþŽTE!£Ñé†r/¨ªJëÁƒ´?޳¤„Ú—^Bg±R\ k±šè8q‚ùïyÏm[*}ªØ­‘Y:ïß<UU% zÝÔÔú6«•‡î¿¶öÒÓÓF9%“™‘ÁÃ=D·ÛÍüªyäç‘™žAWwv»»Ý×ët¤¦¤`2q¹\X-1Œäåå" :Žûî¹§ÓI4##=—ËÅ#ïzˆ®înæÏ«"++‹Â‚b1™´4v›{ï¾kÆ¥°!î'²pþ<æUUÎ*-ÿúµkéíí;1O¡?Ãæô‚ü…sH» Š"–Œ RJJ¨yá.=û,ª¢P±|9½ÕÕ 45áx‡ I’¼}˜ÀTÑßßC4ÙÙÙ%*o0жbþ´4ªþüg\ÕÕTß?ÔTb!8÷X² ôNÞQ+ã°° ÷xp]ºDæéÓ{{(,äÒƒ2PXˆ"Iïha$¡þ~ºÏCÅ ˆ"&— kv6}µµ q3†ÑˆN£Á–ÍáÿwVþÝß¡ÓhИLÄ‚Á›=Œ9Cz{{yúé§G9G¶´´Üv%”“$¹ÍTC*“¼}€‚ŽýíßR¼kËþ8ÍËÖðBË$«–Ê™F¹³·'Ãÿ¢¢`$µ¦†ô 0wuHM¥sñbzªª •?N WPsz:YK—Rqÿýzz0¹\ñ˜ñ‹¤ÖlÆ×ÙI(¤ýÄ ô£ 46\¸¨Ï‡eD^“·3Š¢àr¹(--å©§žõ]jj*yyyÉ{j’ÛÍDæQÇͽ0“‚/In3©¾ï>:/ÁýÏÕt½Î‚Oéé ­$d±&¶»¨‰D0ww“Z[KÊåËúú¤¥á®ªâÒƒLIIl{»Œ.QWe%ÍÍœùÝï0¥¤Pz、”–"¦ôtPU¬ÙÙ4ïÛGOM ނзm£ëÌú𴵑»fÍma¦P…ÒÒR~ñ‹_Œ»M2ê,ÉíŒf¼Å_ª««¹páÂ5‚Åbaýúõ˜L¦¤ðð6CN\Ì¥oA.[>×HÊñ·Èûc Ò±lƒùùĆT¯o§E4¡QPU4á0¦žMMØ1÷ô ˆ"ÞœÚV­¢¿°°ÝŽÂaáí4Ö›¨ÕR~ï½(wߘÊﻀŒ… Û9‹Šð¶·S6”³$cÑ"ê^}{^–¬¬ÛBpH’äθÕ64 Ï<ó O?ý4‹/N@€ÚÚZžyæ™dií¹d(åôÕêß¹d¸h•û ,ýR 9UU€¹»›ì'¨xî9TA` °žÊJöð\ÔÔÖÒÙÙ”“›“3«6o®{}OA°X,‰üåI®E”$RËÊÈYµ ÕŠ0Ç5= ¿ªŸ×Ÿ°å\›@Ñjé+.¦¯¸QU1 bkoÇÖÞNú… èÝnÄ@¿ÙLOJ ÙÙt»\xu:‚á0j €‰ Ë2òà ‹"ÂPi\ièµ ªh£ÑøŸ,£—e´‘úp}0ˆ!@ï÷£FчBh‚A$E!‘Á`~>Þü|ü……PZŠW’P4šxİeQ¬ÃœcFhNÆâòÔ{+MMEU:u:Äw€_@$&5­€.¿Haªžê?µƒƒtôùX²ÄŠ$‰cks†Ðh4(ŠÂ›»÷ ÕhƆËI<|—+“ÑH4M,œ1YUEEEI|F„ø1TUeïþ¼¶k_ùÒ—ÈÈHÕ~4åБÃ8vôCæM­VKuM-ƒžAV._>ãúD]]]8|‡Í6cÁAUUÜî‚¡gÎÃçõ±fõªI÷ëééå©§ÿDFzú¬EQص{7Å……8ŽY×kRÔÉ5¤"×?ÏÚut:«VÅOVmmmòæ<¢(â(,$sÁ‚9¯8œòü¡ôîñëO ÛùU@V"²Ì€$Qçrá7™ef úûÑôõ¡WU4Ú®.lÑ(ŽÁA,>¦HC,†AUÑ9Ø ‚‚€2¤©~•µZdƒ˜Á€¬Ó¡8Ä22Ûí„m6"6~›°Å‚¢Ó!VÀÊçÇ©¼ênM†zÚÚnݲÚ*CÚ1U™Þ•$Â(í¬Éhä’;ÆÓÇXš«§?$ÐÜícm‰•+r'­ëa³YY³j\̸ĒÅ×&I …üþÆ´¶¶ÑÐØH4å•×^§£³“ÊŠrvoìÞ €^¯'²uófŽ;†V£eÛÖ-ô÷ …˜WU5꾇Ùõæî¡ ™ ܱaÏ¿ø"½½}lX·Ž#GUÙ4°h„ÿËt(*,dÇÖ-œ<}zƧM-\€,Ë Nií‘e™ÃÇŽ²pþ|‚s>,‰¯—ËEšË5«¶Nu™®‰k\-φ…³/2!×]pH29*̺¬öxDüpöIÈ^9˯´?,(ÈCå}>ÇC("‹!IF££ÑˆÓéĘ•…ÞhD¯×# å8G´åWUüªbRU„X 1»ò%(’4J€6—¨C‚ÅÕs0™oER x{3|þne#‘V§¥·¿—P84í}Áy¹ñì…z½ì‚⦾OK0bE¾–Ë3Ðk§^èîÀÁCTTT`6_[±¾¾žÁA>øþ÷ñÔŸ¦®¾ž#GQ\\ÈÞ}ûY±|YY™d¤¥S[WGey9gÏÃpdžõ4·´°ÿÀAZÛÚHMI¡¥µ•‹Õ—HOOCE›èíëãï{/Oýñi4 ùùtttrþªª*q¹Rg,4Œœ½Ù‹ÅxsÏ Ë—-tû —.qúôŠŠ ©««§³³“ÌY„K’Äλ獵·—c'N…Y¿níŒÛ+t€Ã0ñý0åäYœTp»ŒÅb‚@,Kj Þ&(1¸ø X3¡hóFAU G"x<úûûñz½„B!DIÂl2a³ÛÉÉÉÁl6£Ó뇴#Ÿ„FžýQ ýÐâŸ`~ɇ$·ªªb6™).,žÑþ‚ Ð?p%ÉžF«£2×Î{Wgò‡} ܹ$›m SÐi§þ[ilj¦Ûíæî;wŒ»M$%2d6TAˆ§‰./-#cµXp¹Rév»IMM¡­£ˆD"Äb1´Z-›6nÀãñráâ%DQ$‹Å@ˆ›4"‘Š"S{ù2«kÐiµDcQ4 ^ŸŸX,†f†¾ZŠ¢ø ƒ„Ã᛹;N{{Üß”|.2ÒÓÙ¶e ­mmñó7KÓ‚ªª¤§§át:hmk#š¾ð9’ã &cܳªª*:Žßýîwœ®ÔTt u»@AÙ½$C’$I’$Éu!)8Ü@‚Á §N¢§§‡²²2ÊËË'´Ô.tvvÒÑÙïIKcñâÅ˜ÍæÄ6=—¡õ0,û$hôIMC’$I’$¹>LIpY^;YN{r‚Á O>ù$÷Ýwiii@<>ú{ßû¯¾ú*v»¿ßÏW¾òî¹çžk”Ãï}~?-­­¸»»1 àr¹F99ª@Ä —žg†´d$…†$IneEadBtQP‰§C¿Mœî“ÜæL(8 {Ð^¼x‘ššŒF#k×®Åjµ&C1'  òóŸÿœU«V%‡³gÏòæ›oò¯ÿú¯,[¶ŒŸýìgüú׿fóæÍ£<•UU¥`€––<^/N‡ƒE‹a·ÙÆÈ¬ˆ µ/‚=²–&…†$Ineܽ]Ô5Ô“£Äã+T$½Æ@:&½Žû–¥OjeNÈ'IÒ¤û@ƒÁ0cÏþáBuãE&AôzÝu‰\+|t&ýÆbHCõr¦Êðú6ÃEþ ^uúfGyÌšñB{A ó£ýˆC‡Å«¹©*¿þõ¯ùâ¿ÈªU«¦’‡9tèáp˜ššÖ®yºÍ[úúzNŸ>Ï磯¯]»vQSSCEEçÏŸ'??Ÿ¥K—¢Ñh¸ë®»øóŸÿLwWW<þE"\¸pP(DVf&••†ŠÇŒW_¢ó xÚaŧãO+W§k+}óÕ¨W}?Ù>Ó=ÆXß«l?—ǘúœÊØ30šø­^Ml?œ2Kg!^‰u(©òè÷×öp8OçÕǘ(!¹ÀP©ëDâæá›2Îu3ü}¼ß#sƒŽ5ŽÑß÷XH´0Þ<ü^¸f{uè?U¸µ“NÏí­8lN 3Q ?e×ù>êÜ䥘ع4}R­Ã¡#G8}æ,y¹¹ÜµcÍØ ‘ªª¼úú.6¬_‡+5uFý­©­å…—^æã~4‘j$¯½±‹u«W' ®)F"8ÎÏSKk+}ñ%Š‹ ¹kÇŽµ¡ª*'Nžâìùóˆ‚ÀŽmÛÈÊš<}t,ãé??ƒÙlæþ÷Îx @þôÌ_èëïG§Õ²jå ÜU`5Ã’ÐÕD£Q~øÃ‹ÅøÞ÷¾GQQ¡Pˆ½{÷òóŸÿI’X¾|ù¤Âƒ 膿™¦}»páÂ~ùË_"Ë2ÝÝÝ<óÌ3˜L&yä‚Á F£1’êp8ˆD"„Âab‘gŸ}–Ëâõxp: äçã7™(Ü´ SZM{÷âmk#wíZœEE´;F×ÙfÞ(%µâ—ž‹¢ÄRËËÉ[½šþÆFš÷ïÇ–“CÁwp»i|ë-äHäJ‡U­ÅBñ¶mh ê^}•ˆ×KñöíSRhܽo{ûhý© µt)éUUt;GÇÉ“¤UU‘³b} ´ìß?z{UÅœžNáæÍD~v¿‰(Io݆¨ÑPÿÆë„Fi]A$ÃX³sh9p€þú²W¬$µ¼œÎS§é:s%0TYÁQXDÁÆ ¶¶Ó¸{?Æ”trW¯'ìõÑzè(±PAU‘t:²—-Cc4ÑqâaŸôù ÑYôT_&Ø×;$‰‰ÄbKF–¬Lî^[;0:R°ååöøljc¤ ª½kv6ª¢àíhUÅš jð¶w ‡GM•"‹.´&Áþ"^/‡½ÝFØã%40ß.* ¯»h Œ.r$D §I§Å’‘"Ëø»º#2Š|å©IÌiiH:=~·›X(„É•†Öd$ØÛOÄïãjaFo³br9ˆøüÜÝhMfÌÄ‚A|]]WUsTµ:,™™ ø;;‰…eL®L$W7±PE–‰ø¼¨Š‚ Jø»Ù|—ífÿ„¯;z­ŽÁ˜™gOXYh¦¦3J³Gƒ ñàŠb$Q˜Ð,+ gΞ£¸¨ˆšÚZB¡ ‹åšíÚÚÛiljââ¥K¬]³š¶öv:::)..B#IÔÕ7 ( &“‰`0HEy9¢$RSSƒÁ` ¬´”@ À±ã'ƒ„®J•ÜÞÑoÿâ%/\HûÙ³È1™Šò2Þܽ‡Æ¦&ÞõÀäæÎ¬„´Íf£ª²‚ŽŽÎϵ RVVÊ›»÷pæÜ¹) ç/\¤³«‹”””YŸoUUéíëcýÚ5äçy®¦ƒÛ=ñMZª éfHYõ)£Ëä I‡æØ±cüä'?!-- Y–Ñëõìܹ“ööv~õ«_1oÞ<ôzý„ºN§Khêëëokÿˆ;wrß}÷ÑÛÛËý÷ßÏ~ô#,XÀOúÓQBV$ARŸ ’DZe%Y«W' DI’V‹ÆhAÀš•…Ö`@o§¦5¹\ôÖhÉ^‘BþúBYM,Ò:«•”ÒRŒN'£gq1ÊU‚¢F§CÒjD{^±pÁ?fv6Z“iÔU*†¡'cªWE–t"`´YI­(CUñ§¢³ØˆEÂ=‚PH,(⾤EUD¼mù„ú]Ä"rb!Pb~· ½zk2ðuI 4Ù±d@_]*¥ˆR¼O±0(Qs†‹Ž“ê7ÑWWŒÎb§ç¢ˆÕãi/DUd$­ˆ ‰ˆI'õëôw6ŠŒˆZõ¥£È6 Hq(_½HÀm:žQÔ iñw‚"›Ð ®Ì‘( j$Q â“$Sj ¢*YÀàÌD”TÄQ²ô•Ä@–Ld8@Iz«[Ž5¡tHhlÅ=ôØr²@5"¨æôÌ1K4‹’D°d¥‚ª H¬YvTåÚÔÇ‚("é@UŒ8 ²¤á÷zlyWÝˆÕøø%]ü)ØšéBUU$A°ç9Qeh.âû ’D÷i‚Ðw³Â׃ÁH}§ÂéfÁˆŒ7¬ðôó‰mÅ”ç8&Ý_RSRسw/ÙYYc&ƒêìêâÅ—_!7'YVèîîæàá#XÌfÎ_¼HIqÇŽŸÀl6300€Ãá  ŸH$J4Åãñq÷¸ÉÊÊ"Fíww»yᥗÉÍÉ!‹‹Å«Ož¿p‘¾þ¾„IUÒÌ\%o·ÙÈÎʦ«»{VóâtÒÖÞŽ×çcé’Å“nßÓÛË©3gX¹b ÈŠ‚4 s… dggqèð:ÌÎ{î™±0Ðî…sÝTÇ–dÞÁa,{‹(мñÆ,X°€ôôtFj%¢Ñ(Û·oç‰'ž ««‹‚‚‚ÛZ˜‰B6 åååWª‘òÒK/ÑÓÓƒË墺º«Õ¯Ñ.Id-^LɦM×(~‡Å:Wyù(•½.Äì‚埽%7±ý°BÛœšŠ%55ñ^o³‘»|ù˜ý>Fæ¢Eñ°Ï¡÷é••£ \©CßÉQôƒËAoÏÁ× }u ¸ˆ]Dƒq@Ž€E†ú×AÒjôË%è< è­‹ÐÛAÒ€¤&iAA }a ’¶Q¢Š·ç"jrµ j†êjI JïHÚø8ã—¥A*ý =ôF¨ ŽXüT@°#`ŸàLë‡þ†‘€Ñ•gF›K®u'š¬œ—0Éû±¶×^õ~2 Ÿ4ô7ÞûɶÃ$Ǹº8‘îš-D@«QÛ禌ñ­ŒN§ge¹“cõ\hó’çÐð7Û‹(ΜZ­Šæ–üÿÅÿ¯¼ö:gÎcíêÕ£¶iïè %%…{n·›¶öêê멬¨@Qb± æÏ'7'›‹—ª©ªŽéõùxèûilj¢º¦¯ÏG,ãì¹ó˜L&²³³ÑH]8ìöDû~¿·»¿ßOOO/e¥%ˆ¢HÖ,ªJ3ÛÍÝÝnvïy‹;6¬'?/oÒíÛÚÚéîîÆÝÓCKK +W¬ ¢¼lÆÇE‘ﻀW_ÓçÎÎJpXœ ‹&™Öá_;îe¢–ÆfØÇAUUÖ®]ˉ'8sæ ¥¥¥¬ZµŠÇœo}ë[¬ZµŠ'Ÿ|’õëדêr¡* Š $¬Þc1ÒÂ-‡¡öe(Ü:ËØÖá±,âY‘‡—1…xUM9 Á~ôB°=ñݱD| D㋼Öïƒnè_£4Æøwh WÞ‹šøAE4…+ÇùïXc™ˆñ¾Ÿt©Çßi¶W¸:Îë$c£¼C &D1Â7dóæ©ÖTe‘íÔa0L­ä¡Ñh$‰päØ1‚¡©c¨Ó³239tø/¾ü ÝÝÝ,^´‚¼<\©©dee‡‘e%-'Š":ŽœœlÞÚ»@0À¢… ™_UE$å‰ß?Éúµkèˆk!22Øà /¾ü n·›®n7 ˜L&4 ‹•ýÑÜÒ2¥Åz,zûú8~ò$—ëꨮ®¡¼¼lFBÄ{öÐÕÝM}}¢(&jrŒÇ‚ùó˜WUÉåº:Ž8AiÉ̪¢#Ë2Õ55tttÒÚÚΪ•ËgÕÜ)zÆdYfÇŽ|÷»ßMÔ#Ö:hµZ^yå,X@VVV2ºb.\à¿øEâÇ8ìýüàƒòØcñ­o}‹Çœgžy†-[¶ðñ˜ÞÂ"Í@o…ÌÅ3[”Fjä(„ÀÛÞ6ðvÆÃ;c¡ø‚¯·ÅS*¤–Þ?¶Î×â Àè z: g²vF’w ›“P8HvŠŽm«@5S.‘žÎCÜO[[;ó«æ‘““}Í6Y™™<ôÀýtuuSR\LqQ!éétttât:p:(ªŠA¯Çétb2™HMqbµÙ¨««Ãh4RXP€(Š%‰÷ÜMjJ¼¢fJJ ééé¼ëÁèì좤¸˜Üœlòór‰Åbd¤§ãp8ؾmë¬J ˆ¢HYI ÅE…èôº·³zå ºÝn€)õG’$$I¢° €gÊì# ƒÞ€Ãá ¬¬”¼ÜÜÙµw‹0¦à ( K–,aýúõüøÇ?æƒü %%%„B!þú׿rôèQ>ûÙÏ¢×ë§]ìêvfçÎÜ{ïµ^¸Ã’òüùóùá8£ŠxÃú í,úP\=?ÕÅvøhr nèo€Fð»ãÚc ˜\¾ .$˜ÒâZA-Œ'$ka$I29¢(b2šgÕFšËEšË5á6ÙYYdge%ÞgefŽi:0™âÆpóпóçÍ»f›áýt:]b»«Û«¬¨µÏ¼IÊWO†Óá`Å” .*,¤¨°pÚûÆQ¦æ™"‰"ÅÅE³nçVc\S…F£á³Ÿý,?ýéOùÚ×¾–øÜjµòÅ/~‘Å‹OKhhjj¢ººšuëÖÝì1_7®.G;Ñv3jhÜ ©¥`Ï|¡>J4Ü`°)îs`NS°æDÉ^¡bΈg›EW'¶¼|TUe°¹cj*:‹eÔ±”XŒÁæfl¹¹Hº™? $I’$I’[I’Ðëõ„ÃaDQŒB ­–ÕÖjµ|á _àÞ{ïM¨°V¬XÉdš¶¦AœfŽ$£ˆ›zk`ù§&ßVQ`° :OA]\;‘R €½ßÜEËþ}tÛ¨²‚¤ÓQõðèC†ÿžššßz‹ø@7gDƒàª€yïkHÒ•”CÁ¾~Êw>@öòåñó©ªDü~wïÆš•Eëä¬Z…~(¶%%}þ|ZÁUUEî]ä¬\‰ÑáH I’$Ir›a·Û°ÛãùU"Ñx )edR%éyˆg‡l²c¯Ä ã 4½OÌ[÷WÐEË ‡R^Ù>FË¡CûûQd{^–¬,ššˆøýD|>œ%%(Š‚bÍÊâòË/3ÐÔ„ ä¬ZEûÑ£x;:0Ž‘Q.I’$I’Ü>Œª¯r³;“dj´€´y`t\›^y Nþ š÷AÑ6XõÈY×iQ% Q£A”¤¡$Gq”¡BfZ³÷Å‹üq”h£ÓÉ…§Ÿ&¥´­FƒÆ`  ÝáAI’$I’äÆp{瀾MôÅ,-ýÄ•Ïâ –÷@ûqÈ[ykâY§á JÙ+V½bŠ,ƒªL|‡ õùH«ª"µ¼œˆ×Kom- Þÿ~Ü.à,*" ¡5’fŠ$I¦H$¡·ÏM,Mx/›f|Š$’í˜ZXf’$7“ë.8¨ªJ$A’$Æ«‹‘d|âþ ް¤ðQè‡sXö7`vM/$Ò˜šJÍ_ÿJÓÞ½ñ×z=e÷܃£°ÙŒÎj¥ïòe²–.EEÜMM¸**(Ú¶ÖC‡è­©!ìñ`ò•$I’‰il®£§§V‹¢Æïõ½2ÕžT,=_¼7^¯b"¨kh Õ™BAAþ„QZ/USŸ—»œ.@€ú†ÊËÊ5‡Fr©º†¼Ü\Ìæ¹Íq …¨­«ÃiwÌ*Óbw·›æÖ, ¥ÅÅS®—ÔÔÜŒ 3N`5’Ëuõtuw#……£Âdß®L:‹# ‚€V«×“Ÿ¢“c à÷¿ÿ=^¯—sçÎñÐCÝì1¿­ˆ†âa”UÇß À`+œý}ÜtQzgôþ÷Ϩ UUiïè ¿¿Ÿã'Nâô°jåŠI÷ëëëãwOýŒô4>ñ裳:ß²,óÚ®]äåæâ°Ûgí+¨2fù™Q '仞h” z!Iµµµ<õÔS;v ³ÙÌ>ð¶mÛ6iq«aL&ýèG‘$‰ÿüÏÿL:YŽˆB¼ØñÈ´ÓÐw9žÁÑžÿl°Nÿ7n†üµ  3Ì)ãæ`PÔòòQ®Fú@¨ªJÖ²eñÊ7{ò’¼­®=úÎÀd4Rë–ùñ–æéé @K·Ÿ…fî_™/ÈªŽŸÖßãñâ÷Øy÷=¼ºkMÍ ÁaxŸp8Ì»÷ÐÒÚÊåºzîÜå•×^£­­yóªp8¼¹{‚  ×ë‰D"lݼ 8zìZ–­›7ÓßßÇ㡼¬ E¾rßG"¼¹gÍÍ-\®«cãúuüåùçéíícÓÆ <|„ /¡ÕjY´pA¢oÓ‰¨+.*âÎíÛ9yúԨϧӆ ,Y¼EQ_"‹NÚŽ,Ë8|˜Š²2Âáð”Ž3ÙØDQ$bµZG _“µ9§;áìDE®TX– ó§v˜q=Ù:­éôÇ,Ñ)Š"§NâßþíßX¶lùùùüæ7¿áµ×^ã _ø_úÒ—¦$<¼“ÊjÏ9£éÈ‚~?–¬,rV­B”$T ã$d,Io7œþ-mû3\×E[°çåy Q£ÁYX˜’ÌšÖ£Gñ´µÑsþ<›ŠgWàV&ðû‘D-6=äÙô “eQ†Â=‹SPba|‘ø ;%%…P(D,KÜcAÀh4™Éž~šP8L~n¡P(ž‘r¨Dvkk~¿Ÿ»ïÜÁÁC‡éììÄï°rù2.V× Çbäåæ`µZéìꢸ°†ÆFB¡0‹.ÀÝÓÃ…‹ñûü,\0Ÿêš¢±(~¿AhïèÀëñr÷;8pЊ$I¬]½šË—/ÓÜÒÂÂùóÈÍɦ¸¨ŸÏ‡ ˆ¢ˆÅb!LéáQҼجVü~âs§ÓI$ œŠ!Š"—ëêe™ÊòrOdxu_DQ¤³« UQ‡êUÔ'Ž=Þ±†56Ö¡~ŽÜnø»õk×Òíîæè±c”•–Œ;‚  ( 6›mŒöÀ)Á|ûøeµl"øý“k&&:~ZZÚ„ó«É´¯9€ ¸Ýnþå_þ…¯}íklܸ‘o}ë[@¼ô~ð²²²øä'?™L9=:“ ½ÃÎdJ¤xöƒ¯ÊwB$çž„œ•7@hBáwI’L­ÑˆÁnGg6ß¶Ñ9½½½Ä"q! E ï[:'­AS úü4ù®,¢(ÒÞÞ>f{¥%Åä#Š"‚ ÐÐÐ0 466¢ª*ó«* øý,œO!]9T$jÁ¼x}Œ§€ô¡ÔÕ#…“Ìôôx?TE¡¬¤¿Ï‡ßçKl»`^¿ŸE æ…ˆ„ä¹\‰vŒ™™´´´\™ƒ¡þ555?OC íHŠ hnn5/]]]ÓÒ¿Ù'‡·?±Pˆóø=/¢5›q²èÞv;ªªrø‡?DÒëYù™ÏŒú.îXÛÏ_ÿ:‡ƒ-ÿë!Žˆhª}é%j^|‘ÌÅ‹Yú‰O\#XL¹CSüøÇ¨ŠÂêÏþ¶$Q"ÅéB#igÝ–Šš°§¦¦’â¼Ùû%öèOrk"Šª€:A(EQX²d ÿøÿÈSO=Ess3;wîœv‡‘Üêá˜ûöíC’$*++ùÞ÷¾ÇÓO?MFFßùÎwøÍo~ƒÝn¿!ýˆ…ãÑ¢ŽB°ç$…†Ûh?vŒW¾ô%v|÷»ä­[GãîÝ(CÉծΙ!×þ {ÏC\SÿR@‰FãéÁ¹¢Å$ I«¥óÔ)\••£¶hnf×?þ#Ù+VÄ‹˜É2’ į¯áß³ª"ˆb\0ÅD)uUUã}ÕhpŸ;ÇÙßÿž•Ÿýl¼¶É°ó—ª"+JâÉQÒz$Ú Ç8W¢ˆÉdŸÿ-­F‹¬Êx}ÞQ…‚’\‹@<{‘ªªÓ~äú£ª*z½~âÌ‘²,SZZÊ×¾öµgŽ|;‰DÈÏÏ'òúë¯ó¡}ˆOúÓüíßþ-n·û†è‰û8"TŒF#pã$ZxA«XL.°f' · *³|9ë¿üeÚãÏù§N¡ª* o¼Þf£ãäINýêWT?ÿ<{¿óün7þô'Žþô§¼õíoS´u+…[¶ D£4½õ‚(rùÕWÙýÍo’¹x1§OÓ~âÁ¾>‚½½¸*+GåGÐh –~â˜ÓÒh=|˜Ðà µ/¾H_]‚(RÿÚkÄ‚AL.çž|’Ž'xõË_¦¿¾žÅý(ÖìlüÝÝlÞLÑæÍ4íÙƒªªœúiŽüøÇX³³Ùûÿþ¿ô\ºDOM ­‡á(,¤·ºšKù êÛ ÷‹$Š8çÈT?÷Óûßh¿ª[asŽªª‰ðÕá×ÃߩƮy­¢^ßåM<7ëZÎ'qõ€fªi5ß lذÏ}îs¼úê«<öØclذ¯ýë8NÒÒÒnHT ¿!Q‘¾ žð#)8Ü„ý~b¾üe2/湿ùÎüö·mÙ‚F¯k†Lçÿð‚}}X³²ØùÿÁ±Ÿþ“ËEÞš5èÍfÜçÏ£³Z1gd°ïŸÿÕŠ5+‹`?ÅÛ·3ØÒ‚ÆhÄ–››¸~T ·¦Sz:Öìl.=û,–¬,Aˆ 7âmoGc4R¸y3ÍûöaJKÃßÝMÓž=Üóÿ/iEEDý~‚}}¤Ï›‡·£Å‚5;›S¿ú:‹Ga!Ñ`_WÞövrV®Ä’™IhpÌ¥Kßæ Q”°™Ì³~`ˆ?Eûèvw£×ë§ücöý ƸÉg²}ˆF£È²ŒÁ`˜ûÆõnÿªctvw&>êìî$`0®ù|˜®î®ëÓ/! Fã‘7úf,Äë“èõúx=‘q|!®}D"qSЈÏE¡··^?÷e\eY¾&ôòV®ŽÙÒÒBoo/%%%|æ3ŸáóŸÿ<¢(‹ÅXµjï{ßûp8sr¬a)z¤ô6’X¼m€®Ê›=3Iæ è>wŽæ½{YñØc¤””`NOÇYT„ûâEL.ž¶6Býý”ïÜÉ…§ŸÆ’™ÉªÏQ’% E– y<„½^ºÏŸÇœ–†Ùå"ìõà¾t‰@w7©ee¸‡¿ÏÈHôA‘ez.]Â’žŽ9-¾Ë—1Ølô76âmo'¥´”ž‹1§¥ar¹è:{SZ–ÌLTE!ãd°©‰`_–ÌLºÎœÁèraÉÈ@g± Ê2ÝgÏ’µt)‡o[å;wâw»ñuv’VUõ¶Ð(GcQºZÛÈH›}TE4%Í•F^nÞ”UU¹\™ÂüÂqóèŒDzûz ƒäæäιvTúúûðûýSÃ\SW_GnN.×c½šl샞Aúú)Ì/¼)c¯o¬'3#“qn+Ž?hpw»q÷¸aDД@$! £™k5ˆ(Š;vŒC‡%LËäÙ³goÉê˜Ï<ó ÿñÿÁ£>ÊîÝ»©¨¨ ªªŠ²²2–,YBfffb±Ÿ)Š¢°gÏž|òIººº(((àÑGeÙ²e£´`r8Q‘½"ž1òV¿Á&™*`t: öõqô'?! ±üSŸbÞ»ßÍó=†ªªt>Íš/~‘ʇÂ’•Å™ÿþoªŸ{Ž¢-[Xû?þ§ó.ýå/l܈1%…Ôòrb‘Ëþæo¨~î9üÝÝä­_¤Ó¡³ZI­¨ :”› <8ˆ§¥WU:›Ò»î¢ûÜ9PU 6nLìW|çSS1§§“‰ZVÆÆ¯}î³g±dfb/(`ÁûÞ‡§µE–I«¬$ ±úóŸçøÏŽª(Üõýï£1ÉX´ˆÜ5k¬eË´Ú·Å5-‰"NûÜ™*†\§š9P«Õ&ÌÃSA£Ñ Ñh¦|Œé¢‘®oû“_«™Ö|Ì%’$¡ÕhoÚØµšé] s(Šˆ‚ˆÇã¥ËÝÑ`$+33Þa eµ§‹¢(,[¶ ›Í† ”””$|$þë¿þë– ·¹ë®»0™L‰Jq¯½ö¿ûÝï…B¤¤¤PVVƯ~õ+òfQ›ýرc|ýë_gÇŽlß¾={öðµ¯}ß=ñ‚(&êS„a V~fƇJr 2\qtë·¾~E4Z-ÞÎNÉ[·Ž-ßúV"¯Cá¦MlØ€ª(ˆ Be%yk×¢( ’FCZUU\˜Eìyy”Ý{/‚ °ú _ˆG/ etD•øµåmoÇïvSõÈ#ˆ‚ÀÊÏ|e(¤rÉÇ?žØâù¶}ûÛ‰6ÖUVÆ#*DQ’¸ÿñÇã¾ #"Aœ……Üûÿ/@¼H›ªòÞ§ŸNlûàóÏßìÓ0e®6UÌô¾5Ó̺Ò4Í9Ã…¤F¢ª*½½=X,Ö¸‰á*úúzÑéô˜ÍfzzÜX­V ãØí‹£Û…B×$0Œ£¢çb±^Ÿ‡Ý1«Ewä|(ŠB ¸f^5 ƒaÔq<^:­nÌñÏtnÃá¢(‰„³ÙÌààzƒƒÞèc,C«ÕFÑjµ3¿(‰×ì‡Ñh4Ó¾NÆbø:QU—+-! Åb1šZšñx¼ˆ¢ˆ^¯ÃétÄçz¢' Ÿ™{¬ýúúú8}ú4óæÍK|>µÛÍ ¢¢‚ŠŠ Ž;Æ~ðRSSimm¥¹¹™K—.ÑÞÞ>kIÓn·óÿølß¾FÃÊ•+ùð‡?L_?Š,#«*àms:Ørnö¬$¹’„fèÇ®î‹q¢·Ù `IK»RV]’þêÐûá… I£4U#C.ÇºêØª¢¹d yk×m Œ¹ßȾŽ:ÆÐïW%.(\ÿa¸Ã¯„DþƸŸÜ eµÃá0í(ŠBVf&&“qÈTÑNZJ>¿ŸHô*{ïTâ‹l^îô:$QJœ”X,F àÇh4 °Zm×ÜDAµ¸©ªJíåÜ+Õ…Á`Àáp²lérü~?MÍT×T£×ëÉÌÈäâÅó‘—›GAAá5Bˆ ˆÒ•ÏŽ;LCcZ抪²qýäç$¶àà¡Ü}çÝhµºŸ#I”cèç•W_Š C¡Â²¯è¸mëv4m¢?'Ož ++‹ò²Š[ÄQ ô¹óçÐjãkÜàà …\ºt‘²Ò2–.]Ž(ŠÔÔ\Âçó1oÞ>À¢…‹q¹fæ''‰Ò¨k/rðÐìv;©)©¨¨X-VœÎ”1שAÏ --ÍT”W¢Ñhp»»ñü€€ @0¤ær5¢ ²aýFœÎ ¾Æ‡Ã‘D~p8œèǸ’A8æÐ¡C„B!¤¡§‡adY¦¨¨ˆ¢¢¢1¥iQ)((àüùó3>Y7ƒ“'Oòä“OòÃþ5kÖ°fÍZ[[ùë_ÿ:kÉnX8øàùçŸgÑ¢Eäåå±÷ÀêΜAç´R÷Z6zk9ÆÔ¤™â@ÁwP°q#ªª&žÌ¯*¾p!ïûÓŸ®ëq¦K÷ùóø{zè:}õ9 _MGgmC¶E¡´¤IIq¸‡ÃhµZJKJgüðàóù¦e›Iº²X ôsôØ.\ÄÙsgÙ±íÎkêF>Çb1NŸ9Å… çHOK§¢¼’³çΠ×E‘h,ÊÅKðz½€Š"ËdddÒ×ß ¨]Ó'QãÂ̇ÁÄ“¼ŠJ8&Ž×áèíí!¡Õh ‡ÃøÜîFŠ‹Jft/¹O4£·¯V—8'ÑhFƒªÂå˵445 Í-ÍtuwÒÜÒŒF£aÑÂŤ -ŒÓ9Ãs;88@cSÁ@€P(„ÙbáàÁý8NÎ_<Ïüù ðx¼œ=w–U+Wc2™0›-9v„-›¶&¢ô¦;ö«µ(­m-‚~z{{èéí!͕ƖÍÛFm§( ­m­œ:u‚ŒŒ¸™AQÚÚ[éìêŒkGÂôôô››—º&cLÁAEúúúøìg?Ë<À¢E‹øÊW¾ÂÖ­[y衇øö·¿ÍÝwßÍ7¿ùÍ1eY¦¾¾žÁÁAº»»IOOŸödÝ xàNž<Éç?ÿyþáþ††üqb±÷ÜsÏ´ÚjnnæÂ… ¨ªJaa!UUñr¶}}}<þøã477óå/½^‹ÄïÆAJ hgá¼ÜînRS]ˆ’ˆ“éèìÀápRR\‚  Ó_¸GŽ]Ò´ËŠ‚¢ª0 ª¢"ýìÝ·‡ÁÁAΞ;åꋄÂašš0èõܱqó´!û@|ÏŸ?‡F£!Í•FYiµ—k†Ì'q‡~ÇCoo—ë/ÓãîfåŠÕ”••'®á%‹—[WwoíÝͪ•«±Z­SêÓ¸)§µZ-Û·oçsŸû\|C†‚‚yäúúú&Ìç ëÖ­cýúõ·|¶È‘dddðo|ƒ¿ýÛ¿å‘GÁétòž÷¼‡~ô£äææN«­S§Nñ£ýUUy×»ÞEUU üŸÿóÈÎÎæŸþéŸp¹\ñùErV,gþв2ÄÌ*F¼¤–”Ìz>Y¦¯¶–Ì… ™Ý"!mmh ,©©³n+ìñÐ__OÉŠ,Ó[_³°i–æ4ljB§×#•”̪ê£úû û|8fá_“ £·ºáÞ{çÄ4ÐßÔ„ÑéÄ`³Í¸üU«V­â²ÃAôâÅ9èÕìh,Jwk:á†{òÃaÃ`0Ÿ—×ç%7'p8L~~þ5‚ÌHS…V«%+3‹¶¶6úûûè§´¤Œ£ÇSPPDVfª2”ÿ@QPÕá?uÜ|#“aGE«ÍF8& £×ëãv}Y& Ó××Ëüy ‹ºÕb%5%•¦æ¦ ’tÅt£ÕjÑhµFúûûý6Ÿ;NœN'}}½D"Y&?¯`ÆÂŸ  mKŠ3…ÌŒ,U¡££ŸÏ‡F£Åï÷“‘‘V«eÉ¢¥ À‘£‡Y¾lÑhŸ×CFFæŒý]†µO^¯EQX·vMM¼¹{^Ÿ—U+×ÐÓÛÃñãGÑjµ ¬VÅÅÅ£Æ~µ`ØÜÜDš+ ‡Ý1å>+8¸\.¾óï Ñhhoog¼S"‘ïÿûÆ,p% :t§ÓÉöíÛ?¼©ĺYœ9s†oûÛœ>}šòòòD±¯%K–L»­ûî»{hŸø®®.¾ýío³zõj>ö±¡Óé®Dj( =Õ5\Þu€öãY¤”vѰ/Ìtëà‚€·£ƒÖƒ©zøáY… ‚@,¦¯®Ž–C‡èKOO¤ž ¢FCÃo`°ÛÉZ¶,QdiF}Eúëëé«­¥aÏž·3Œ‰Pýì³”Þ}7z›mÖóÖ{éÑ@€ØÐMkÆs&I¸/\`°µ•’íÛgݯˆßO}=o½•ðW˜ —_~WEÎ’’Y_í§O³ðÊïªHåfå¹Ö8„BAšZšðù¼´´6ãõzijn"7'o”&cäâÖÛÛÉ“Ç F6mÜŒ(‰ÔÔTÓÑÑNVfCNw#µ!XbF &6« »ÝN0@«Ñ`6›1›ÌÈrŒ¼Ü>ŸX4F8¦ °ˆö¶VAÀl¶ I‹-AQQ•xVÇŒô ó fþÔ=dªèëïCŽÅ) :Ž´´tj/×2¯j>½}½;z­N˪Ukô ràà>Á ç/šv„Åȱ÷ööàv»ãÑÑ(F“éŠeèšèéqsâÄqJKËðz=4·4£ÓÍÜÜ%JWLqÓB'---ôô¸Ñjµ£|'´ZmB8.®v5áp˜³çÎÐÕÕ‰¬È¬\¾ŠÌ̬iõiR;‚(ЉÁðë‰9©ªJzz:˜ÍfV¬XÁÚ¡p²[•|÷¼ç=8ñêu_úÒ—°Ûí|ÿûßgùòå͸í7òË_þrÔø%I"33“ôôtÊËËoöð“$I2’1Ö·‹/òûßÿž””ÑvÃ7hAèïïgåÊ•Üwß}3>ô°ö@§ÕQ\TL4¥¨°Q”ÈÉνæáMDT1Þ‡áœFƒ«ÅJ àGD´Z-V› Q”ÈÈÈD«Õ`4)*,ÂÝãÆï÷SUQ5fFj4|>/”—•ÓÞÑŽ×ãaÉ’e(ŠB{{Ë—­ ##“óÎQ[[“pÌ3™L,Y¼tFó1üÄ/Ë2¡PˆÅ‹– ×ë©®©F£Ñ°}Ûº»»éëëÅç÷‘ž‘μªèõzÒÓÒ¹cÃ&.V_ÄðÏHp»$iX½z 6«÷Åøtz 6[¼(Zk[+…”—ròÔqz{{Y°`ጇ«£*ü~?Z­–Å‹—’‘‘nœh³ÉBA~á˜Ç5,˜¿ôŒŒù}L(8‚@cc#Ç'ÒÜÜ̘?þ¸v?EQX¿~=uuuñp‘ÔÔD[·j8æ0£mo:ŽÇ{Œ¢¢"L¦Ùeí*,,¤°°ðf1I’$³ ¯¯Å‹óÐCÑÑÑÁý×ñž÷¼‡ÂÂxVAFÃÞ½{yöÙg¹çž{f¾XŒØÏf³³bùJA 5Õ5©óâ0™Üuç= ?3Y–Q‡´ «V®Ž·³4®]ÉÊÊfá‚Eh4c÷wdû™™Y‰'ÔŠŠ*AH¬ʈʨå•• Óéf•6žªÑhNžŠ¢PQQ…Áh@%*G=WÏQJJ*ëÖ¬Ÿ¹©bhL‡‡ÃªªlÞ´N ȲŒ,ËH’Ä‹ZˆµkÖ3sfdA¦Z:ìëq5z½žyóf§Ý›TãF1™Lüû¿ÿ;¢(&oL”ØDt:ÝÛÊ1RUU|>}}}ôõõÑÓÓCss3õõõô÷÷³hÑ¢›ÝÅ$I’Ü Û×wïÞÍO<Ùlæ‹_übbqÐëõ³NM|)bÄÂ1‚( ^åòzµ¹td›W·?ÙÂ>ÞÂwõÓûÈí†5sÁHÁ‘ÇÖhO47Sý~¢ýÆ:#“eëÈmç"ÛãH‡[… Ϫªª”””PVV6êóX,6îCEöîÝKoo/~¿Ÿw½ë] ­Ã­ŠÏçã«_ý*gÏž¥··—ÞÞ^<’$‘žžNnnî-ïØ™$I’ËwÞÉÁƒyàæ<° N/½±€pÝ+8ÞÌÅKoâ±oRªé[aìã1éÕ>œ:säß„ƒzzz(//Oh(nuÂá0¯½öÕÕÕìܹ“Ÿýìg|èCâÞ{ïåÕW_åOúÓ´Ã1“$Ir{#Š"ÑhtÎUUéhï˜VQÀaméõÂï÷ÓÛÛ{ÝÚŸŒÎŽÎ›V$1àv»oÚØ»:»ˆD"7íøcq]jU¬\¹’ƒ’––†ÃáàðáÄÃaêëëoIíƒÝnçßøÿþïÿÎÞ½{Y°`.— N7+‡È©RSSÃ[{÷bµZÑ ³öÄŸmA®ëÒÖ°×±0£Ä½×ö+Þ¹[oœCm%Ç9E†*îyX½z5 .œ“¾Ý¢Ñ('‘@ª¥¥eVõlFÒÑÑAzzú”Uý>ŸÇCÚuʾé÷ûéïï¿iÉü:;;III¹)~rÁ`·ÛMffæM{WWW|m¸ ùDÆcÎUU)..¦°0îÍF ƒ„ÃákŠ¢Ü*h4>ð°aÃ~þóŸóOÿôOôôôpß}÷ g”&t:ìÝ¿ŸÇOœ`ÞƒΪAðvvÒvø0<0ë~É‘—_y…üuë0¹\³²ÛŠ’Dãž=èív2/žUÜ¿  46â¾t‰Ò»îš“qÖ¼ð%Û·£³Ùf%¸ ‚@ýo`ËÉÁUY9»qŠ"=ÕÕxZ[)Ú²eÖãŒÔ¼ðU=4û<ªJÝ믓ZV†³¸xVãÄh¤­¦ÿ›o¾-A\¼x§ÓÉþýû9x𠯼ò =ôМ8AO7úLUÕYûULÖþÍŒˆS妔´ûÍ:öðØo5®‹÷âÈ ½^ÏæÍ›‰¤nUòòòøÆ7¾Áý÷ßÏ~ð^ýu>ò‘ð¹Ï}Ž 6\?gOA cáBÊî¼sV™!žÂ7{åJÒ*+g2ë±Pˆ¾†òï¸{Nά³=:KKÑXÓÓgÝV×ùó(‚@ÉwÎrÆâ™#%%¤–” éf^ˆg¸ož®.ÒÊËÉ[µjÖ™#3—.%äõ’2‹QØëÅ]]Mñ޳'€£´Sj*&‡cVçSd¨ Ö-’9r2Fý+iªC¡Á`pÂ}£±(ý½ÄbQ†LFÅ„FI·Íþ¼$¹}QU•ÎÎ.RSS$‰æ–E¡ ??þ]WWÂO’$²23 G"ȱ¶Ydx½š·OØÃ B’$V®\ÉÏþs^|ñEþõ_ÿ•OúÓ¼òÊ+×Ïl1$ÑÊÌ>÷¿ÆlÆUY‰B|Aì8q½Í†«búÕáTQÄQT„d0 ÌAßì¨ÀlÝL@kµbÏÏŸµ €$ÅËT3³4ßWcÍÉAçpÌÉù4¤¦bLM³q:Š‹QaNÚKªÅ1'nâˆn„™,ËX,îºë.|>÷Þ{/ƒ{ï½—ââb80î¾Íut»;ÑJ”¸Šæ•Kƒ.,F_¸»iϳA‡––ÒÓÒIO¿Ö4¡( MM€€ÉdD§Ó‘âtÒÑÙ‰ÕbA«ÕRߨHŠÃIFÆ­UGHQZZ[ ƒ̪ötQU•¦¦fܽ=äçå‘qM3‘H„ƦfL&#¹9c—G>{þ<'Ož¢¬¬”ú†Fúúú% “ÑÈ}÷ÞÞ½û†êˆÈ¤¤8™WUIMm-«V¬L 7“ÉÄ»ßýnÖ¯_ϳÏ>;gö¥öövšššX¼xq"7„8¢|ò\X¬Tw7õ¯¿ÎƯ~uÚíH:e÷Þ‹ ŠsRdi®tM*`ÏËÃ6‡«s©+ܼyN‹fÍU;Z“‰yr²³Ñj4\ª©A§ÕRQ^Æ@ÿáH³ÉD__Ë—-#%Å9ÍÞLÌ”F“("òNàå—_&ððÃóØcÍÚ¡,‹ñÄOðì³ÏrêÔ)^xá…DÅL‹ÝŽÍnŸó1ˆ ùkÖ0P_?ã6æj‘™snrˆÔÄ]»5û·ðùäºGŽÜán‰Ð»qLªóçÏç«_ý*ýýýžg‡Ã1fˆ¦É`¤Ö-óç},Ë×Óë‡&w€E¹\•LJ ±¹£ÁÀ{~¯¾¾‹ó.\#8œ:}†öŽYaá‚ùÔ\¾ÌÏ~þKÞõà¸RSq¥¦rçöíT×ÔܤŸ³çϳeÓdfdð_¿ù-ƒƒƒs¾èMDÃ׿þõQs¨ÑhÐÎqŸáôoP%>–[xaK’äF“âp28èAURRRâÉíÆÙV„Y¥‡×ë ¤ZõD"nêzµøü!ªÒT^…I?ùs\(J˜tì6Ýc„ Ž„™7¯ IIMqÒÙÕ9joÁܲ,‡1èõzt:-ÑØs¨—$‰Û¶Ñíîf÷[{ñùý¬\¾ü†ÎÁDçEUÕÄù6™Œˆ’DMm-~€E 磑4¤§¥‘‘žŽÇãÁ`0pøè1*ËË)))žÛ~N¶A$áÉ'Ÿ¤µµ•^xÓ§OÏ(ÙI[[õõõ·äÓØàà _þò—9räHâ3“É4§á/‹…Ï}îs¬X±bÌ,mÂPX›2âOeæŽÞ^==Ä5¾ÎNŽþä'œ}òIb¡ÐJ’dŽˆß„n¦ÄåJ¥ª²‚ªªJ2¯ƒÍßãõ$œÂµZ ¼ky]=¬.2ó¡-eXLS»×¤§§ÑívÓÝÝM}c#Yc„J¢ˆ$iD‘¦æf.×5ð÷¾—W_ß…(¯N8!‰ÜR’$áJM¥º¦††Æ¦D9î… ²rùròóó¼ás‰ÄÏËXˆñj©aÒ\.ù¹¹è´:<žAbÑXÜ_E€ò²RRRR(/+ãÁûv2èää©ÓsÚÏ E\Qq»Ýüîw¿ã7¿ù ¿þõ¯ùË_þÂ’%K¦m²ˆD"7­Díd˜Íf´Z-=ößüæ7yàxøá‡ñz½7äør,Fë©SèU- ¥LŒ&+²^"fÐ5j‰šµD,:bF Š(¢ qabX»Z€¦&š÷ïÇY\Ljy9'Nà,*Â×ÙÉ@c#i••sj£N’d&tœ:…¯«‹î³gQÆq»Þ‚€Í_ ®GÔ—Õb½RÙêÀð²¶ÜB‘«€t‡ FÄlšÚ™›“CeE9Ͻð"Y™,˜?ÿšmÌf3éi.jj/³zå -\@ ¤©©³ÙÄC‡äè±ã¬^µò–y Û°~¯ïzƒ††F6¬[‡Ét}CáGFÙðX,Ö®^}CÇÞÞÑÁî=oÑÑÕÅC‡Ø¸~ý¨‡LY–ÑëuX­VÒÒ\ô÷›“M^nNÜ'¤ºšÞÞ>r·äRßÐHGgÕ55X­îظqNû:©àðÆoPQQAJJ 7nä?ø]]]¸¦×_TTDUUÕ-Ži0ø—ù~ò“Ÿðõ¯ÆÆF>ýéO“•5½R£³AUĘ‚ÕÅÚÕU"2šH ),#Æb ³Ž°M?ÃŒ?ÝŒ?ÍLÈi@ш(\"2†jkÄ‚A²W­¢ú¹çH--% ‡çÔy/I’™¢* Š,Ï.Ä\ôc‚ûÒlïYÃLF3Fƒ •ôÔt†¦ºp‹¢È†uëX½jISû[XP@A~>[7oB%î»÷žÄxþæãÄi¦¶¾Þ¸RSyÏ#£(Ê Oö¤ÕjY¿v kW¯B«ÕÎyñÉÈÌÈà£þâõ1$IbÝš5def‘–æBE.×ÕSŸ‡Éd" r÷;°Y­,_ºŸßÑh ;+kÎÇ2iuÌ––ÒÒÒ0™LÐ××G ˜°ÈÕÛ‹Å—¾ô%ªªªø_ÿëQSSûßýn²³³ÉÈÈÀn·_·˜¤Ñ·jYwmgØQEÿÉ*RTFï cì br0wûI¹Ü‡ÞFi&<¹6óíø²,DZ²–-‹·Øssi;r„H @ÞºuI¡!É-Aβeˆ@£ÕŠØÞ~³»3 ½^O?fƃÁ )Δ„oBÜ,9ž¾prA@7Á¢:²¶Âx—f[­òz"IÒMëßͬà,Šâ¤æq“ÉÄüyWª€ºFdb¶ˆJÊʺ¾Y.ÇA »»›sçÎñw÷wȲŒN§CEÞ|óM>þñ_÷‰¼‘¨ªJ[[øý~~ö³Ÿñ›ßü†ÔÔT*++ùÅ/~1«z±XŒ'NÐÑÑÁàà ‡fpp+V€  ¨ê(ó€* ¨¢õa‹O¶5±¨¨Hc_[‹{ó éçºÑcÒLô9é/uâ˰±|Š(`0[°fe%‡$·ÊUÿÞJ¨ªŠÉhÂëõÒÒÚ‚Ãî˜öÃ’ øü>DQÄb±Üì!%I2'Œ)8H’ÄŸÿüg~õ«_‰D¨ªªB–eÒÒÒxï{ßËOúSNœ8Á׿þõi›,nEÂá0ÿöoÿÆoû[:::X½z5_þò—1œ;wŽÖÖÖY1 ñÓŸþ”††\.O<ñ6›ÿøÇˆSÔd\ýŒ¢Š1ƒO¶•Ál+­«sb †ŽÆœuýdžîDóídÍ/c ÀAd¸DïÍžø$IÞèt:ì6;é®tUA–å ï‚  Ñh!u×-ãl’$7‰1¯hUU©¬¬ä#ùUUU¤¦¦&’¼ï}ï#''EQ ŒÞîø|>^|ñE/^Ì÷¿ÿ}Ö­[‡uÈYê½ï}/Š¢ÌÚFd±XøÙÏ~vÍ G§ÓqäÔ)˜…jnØ hD.~—‰¶Ùh"2–iÜ¿Xƒ–é+M¡{a:d­˜h#I’$c£ª*‚(Ps±†gŸ}»ÝŽ,Ë “À° Š"‡%K–°}ûö›^ç I’ëÁ˜‚ƒ¢(TUU±`ÁdYNDP¨ªŠÉdâÞ{ï˜Tò†x4ÅéÓ§ãé4oÉê˜V«•Ÿÿüç^ccÆpR™)ãÙÏ®ÇmeXuvú ìhvcm÷’q¦‹Šçª螟NçÒLüifT!)@$I2‚ 088ˆÑhäÒ¥K¤¥¥F‰F£ TU¥¿¿Ÿ‚‚öîÝË–-[ni_‚$Ifʸ:´‰²DN§.ºªªx½^B¡P¢üì­†N§£bµæ ‡ò8\/!B ®È·3oG‘q4}¬¥ÿy_¦…öåÙôV¤ÓII"É c8—ÃÛAðx<\¸pÿ÷'--P(„Édbppÿñ?þF£1aª uÔýVŠjHrë£ %òh4Šªª7¼ÎËu7¾éõz¶nÝ ÄëŠ'Õv×"Ë2/âZ¼Ëu®ù>RÑSžJOy*O˜´ón ö6Q¼«ž®Et,Ë"è0ŒÚ'I’믿ŸöS§P]®›Ý•)£( :‹Å‚N§Ã`0‡'ÍoÓ×ßC]S-±h4ž6½ÑNK0 £^ÇöS›U8ì°‰dd„ÅÈ4Æã¥4¾Ñs(Œ‘:~¸ï7:r²~Ý&;/`#GRQ^Ž×çãì¹s BUU%9YYì;p@0€ªªX,Ö¯YCCc#V«•’â¹Ë™ôÚ¹PÂ^/±Pè†æW¾<Ã6=-ksi[•£qÜí,ü8}%)´®ÍÅ›eMš1’\@‡ ¾m»ÝNyy9O=õÑh”p8ŒÉdBUUrrrHOO§··wÌ}[Û›1é͘fDAÀŠñæÅ>êºÈtÙ2/e¨ÐÕØD¢QöîÛO]}=ïï{‰«Fâõzyåµ×IOO'RXOvVoíÛÇŠåË9sö5µµ¼ÿ½ïÂw£PU•“§Osîüôz=Û·l!55€vïÝKÿU•¬^y}’Sµ´´ò×—^â½<’86Àé3g9sîZ­†m›7“––6‹£Lîn7/½ú*éܽcǘۼòêk´utàî顱± ‡ÃF£áOÏü…Ï|úSè´Z|>…H4Š^åÕ×w¡ÕiÙ<Ç  Þ.ÂÛI«¥`Ý:R oZ˜¤¨’H_‰“3XÈÉ/EÖK,úíÿ÷iRêûAQ“aœIæ°gfR´iÓM{œVUFƒÉdB–åDÊæá×ñ ºq5«Z­†`ç¯b´ú´iQhöꉆƒì\’Žf²JªJnn@€`08æ&§ÏœåRM ùyydf¤³gï>v¿µEQ±˜-ädg …‚Ü,r²³¹÷î»ESgÎ$>×ëõ¬Z±‚;6¬çðÑcøýþ9?v(âàáÃtvuáŒh_ç?¸ç®;Ñëôœ8uê†Î‰V§%/7—Îήq·ÉÏÏ£³³“ŽŽN"Ñ(V««ÕŠ(ˆ(Š2Jc¡ÕjY½j%•åå´µwÌi_ÇÕ8Lɤ 0"‘I’™¢B"ÃÍFú_ ÍDõ}å4n* ûXU¾HÈa ic}e)(bòÌ'™TnÍ<c!½½½œ={–ýèG¸\.B¡f³™¾ô¥/¡ÓéÆ Á4ŒÔuȼÅ#Çß©233“òÒÒDÚéªÊ Àj' JÜ®o  _‘e¼^/½!!|íÚý&kW¯¦° `Ô¶Æëõ±cû¶9J …Bœ¿pY–¹TSB¼þÇpÄ[?¯ïzƒ•ËWÌ©OÀtÏ¿Bb±©©©ädg¡Óêâõ)úúX³j)))”–ã°;èvwc·Ùq¦8±Y­x<2ÒÓçÌì3n¨ÌŒÉô¦“vº½½†††[23ÉÄ@̨¥y}˳È:ÑAù_kâˆÍô;Q…¤‘äÍf£¬¬Œ?þñ‰â}Ã>ÙÙÙ¤¥¥Ñ××7澃­Fá#wäðò±&îXMAºƒ~jOÖ±XŒêšZ››9{î^Ÿ×víâŽõë©­­e^UÕœ z½žG?ü!b²Ì“ø#«V®ÄÐÑÑAUe%oìÙC·ÛMÿ@?]dff\÷¹Æãõrîüy¨½|™’ââkÌwƒƒ,f3Z­A)/+£¹¹QQU•ööø8ººº0 h$‰7wïaÙÒ¥sê+2®©b®%½`08®M.ÉÍEUUPU„IlÌ3hh^—GDz!â¹BN[ éÏw ™¯’$¹ýPU£ÑHmm-f³™öµ5†+é Ο?Oæ8ÑQ[ ÁP€œT3Ÿ¼k‚’¤™²àñ*ŽׯÇh4Œ©áÈÏÍÅép$Þçåæâz¯ªêÐþë0(òÍ1-\0Ÿ®®nü19†ÕbA’$Ì&Û¶lAQB¡ðœk³AH˜?îÚ¾´4WÜ÷c(øüª*œ'@pBûõ@ŽÅ°Ym¬]³šhôÚc˲̼ªJdY¦° ¿ßO}c#[6oÂ`0P_ß@FF:YYY47·àî顳«‹m[¶›;·•goXTEII óæÍKš5Æàzçq˜ìØî 8ÿÇ?²äcÃ9Í‘Dç’Lr·±à÷çðäÙ¨ßVŒ7Ó’Ø.I’Éx»äqe™ªª*>ûÙÏ2000áœÃáÓÙS’$,æ©•Ð FÃ’Å‹&ÜÆf³a-1ò½F£añ¢…7{*™_UÅüªªk>7 lÚ¸á†ô!??/ñÚlŽk]*+*¨¼I9}œN'7¬÷{I’¨(/'7'^F[EV®XŽ^¯G’$Ea‘ºI’X³zŠ¢"Iâuq:ÖLf“KrýQdw]éË—cºÁ!i*6>Î'öõM+²C¢&- [ éXžEÁÞ&–ü×)ÜóÒhÜ\@Èn˜PxP¯úw¸MÆx¯Ž³ïÕû$…•·‡î‹QoBhàtŠŠŠIÕ¾Ã)ú“$™kÌfsâõH3ÕÕÕO¯gÒRÍÍN’$žpÄ×ÙIhp³Ëuõ" 1®|0Yv™«ˆç‚¨ÞYNëê\ w7²üñ´­Î¡uu.Q½”ØNPA”´(zO/‚ÖEˆ¢ó†ÑDd¤ÈOgDEu¨Z¨$ ë$¢F-Q³–¨QKÌ !fÒ¶é [õ(ZUP!QI4y•ßš@ÄçÃÓÖ†jù“ø$)$y§£™¨rÛ°ÔÑ‹²Š¹/€­Åƒ­Åƒ©'€ÎAï ³äW§Ñù#\z°’Æ-…SDÌ:ˆ¢‹ùÕLÅÌ rXE‰¨hQPcX½AÄŽ ŽÁº½¤z:È G­¾L+¡l3¾l þL 1‹Þ6ynWnuϧ™¦ ¾Y©‹“$¹žŒ©n¿ßÕjåᇦ§§‡‹/RRR‚^¯GQ<8¥D"Ξ=K4¥©©)Žy !jµh Îüö·¤”–â(,Ä`4òÿ±÷ÞÑqÜ÷¹÷gÊö`Ñ{# ìEl’¨nɲå(–ãÄ7vâøž¼É±“Ü8É=o’×o§Ü딓÷&qìÄvb'¶\ÉE%Q콃 DÇØ]”Å6lyÿ` ’AIûœr€ù•™Ùù}ç[žÇ–Ÿ?ï¢=ý€óØ$Ξ®®q¬CaÄ”BÜn Xjdz©„P¡„] @ÑÉA*ö÷’we„î]U$̺Y}ܘ¾33·AQ`rRû?OZR@€IDAT‡XL‹¦„Ã`6C¿€N'PV.2’qå\8š!<‘Q‡œÆœ$Õ¢l<ÊÈñ5¢‡kNñF'9ùi‡œ:di¶GBåÖù³Î• ÂË :½—ps;·m3‹eG8F§Óݱ/¡pˆ×íɲÈ⽂yã‚ ÐÓÓƒÉd¢±±‘šš$IB§Óñú믇Ԣ(Œ‹ÅˆF£Ë=ß,f@Ejvï¦bÛ6$I§#4:ŠÿÊ““ä55!™…Mާ±{‚ä^%§s 1©w˜(wàY_B¤ÐBÒ(£LUˆÌ\üú¶”áorSýVëþñ}[Ëñ¬/&­“2û h ‚É$¤Óà÷ƒÞCƒ‚;lVE°ÙÀn³ŠŠ´¿‰"héEùÚÿj>¨µ"":Ò›íŒ+ŽªôÄR|š!Rv¨OÒ€Ó 0n4"4ØPrôH‘Ø"1t“I-#’DŒ£›L"MådˆiAUµÐÊÔ™SEAœÊÓR™´AÒò3Œ2I³Ž”I&aÑ“°èIZµü EA˜íݬaq¿ ª*³…D2A"‘àNù]RÉTæ¸T:E`bŒT:•©¢2ÍÄ¢$’gÕ-÷”³x€¡ª*>¿Ÿ— I’ðxP•²Ò’ÌgÓQI’4½’D‚T:mªät1pËrLƒÁÀØØf³9“Ó0ÍǰPO£ÑÈî)ÁŽ‘‘‘l9æAÑÍÈÌMD"¸›šŒ’‰&t8;ÇÈ¿àÃî ’4é–Úé|¬†`©¤éfCa®âˆ9´¤ Wo€š×;):3L×ã5ø«sGa| ôz‚¼ñxü&Ò&EQ‡ÃY`±œ<3¡ŽòròŠËpö‡pïÄÙ9FÊ(3Ò˜Gß¶r"ùR²x[CaÞ¹ ¨trúÓm䯸¯¸r‡8[_Pa¢¢𛦠qv˜nþ}>Ì4,´ÐŠ!Çìbñ…± ‡1ŽÇ0ãi•´A"n3®u[_DܦG”%šûƒ8®Ž“ŒÑïrp¶°.wŽ:™Dr`5t‡×îÆ}§¹ Ä´‚¨¨I­òÄ8Ã8>‰it’œŽ1¤`}(šV åZ—X‰Zº­¤óŒ$Íò¬6çJ}о¹ï‡{yÞÍ<6PXXE(©£Ð¡£Óåro€¾±0ÛŒ·5EáZg'>¿ŸþþvíØNÓ |¯¼ú*;¶mãôÙ}<ùøcäçsñâ%‘0U••üèÕר,/ç…<¿Ü§6‹;ÀÕŽk  ‘H$¥¸¨Y'såêUô:+VÔ3> ‘ˆc6[ö²ªµwÞâ¦Ü–ª´´4C--‹·Ûßï_îsø¾’N3ÚÛKÁئœû UÑ\ìö¡0ç¼ä^EщŒÕæpþ¥Â…ÒÒucánòÓÏÃt&cÐÛ'b¯.&ö±|v^îâ×NždØRJ])½” [ÜÉf ¦‰o›'„m(„y4Š”H“2he›¡"c59„ ­ÄíÒ:IKÖœŠ€ÚìFÚ­`‰’ÑOm{/ÛÏt0xÂΉÜB®»(\¡En04¯Æô˜nu.fî“LA"  Á 1äÓOšq—AÀÖfˆŽ+X„4R ÁäµIrº¢”{B\“Ô!.»òiLè–¬s-Ø«ôˆF-Lb6jå°Ó&N3äæÏý‚L†CŒt\E5[î¹½f“‰k# ?<íem™D¥×¥©ÈÀóËnKã/Š"Ö­CUU~øÊžC=òÔé3xD!£˜ ¨ ©Tšêª*ôQ®vtÜõ<¦KRADUï`[Q•…oÏE^¤ªê,¨¥Üž+±U™1¶¥Þ¾55Õ8t˜T2EZI#ë´%Üép …9söÁ`x"AQa!»vìàì¹sÄb1ÚV;ïúzß9™LÎùªªTUiªe^¯—K—.QYY‰Ùl¦¢¢‚¾¾¾EÄŠ¢0ÑÛKtl sNÎ}yxO÷¡$q_ôSxf}8Áxµ‹Ën Tb›åY¸—7BˆÅÁã‘(+ƒ—ŽÐÉ ´Öê/ ö§×È?çãÚµŒÖæÌK_}c2¡.’Äê có„°{‚X|ĤB¦g2×Äx•‹¾måDóÌZnÁ”‹®·ñ¹’4UI$X`e¢ÀŠ´½óh”‚vÏ^é…N†‡s8ëÎg;ž1‘ªrÍ[bµiÿO{’´êM¥kçC–Áå‚@Ün˜˜€‚©|—¬år䨵ý„"q*_CÙj‚@Qb+‡¢äô«ä ;܃uo’‘+ceNF‹ìŒ9-Œ[%/ÇOžäÒå+lÙ´‘‰`ö‹—زi#Á`ˆ /ÎÚÞ¼i#¡Pˆ íÙ¼q#¡ðôöÂá0ç3Ûη·ÏÚÞ¸~ÝM,’¡PˆŸ¾ñ&Fƒ-›6òλû0LoïÛ‡Ao`˦M¼³ï]ôz=[7mæ}ûÐëtlݼ™½ûö¡[À¶,Ë<ñØnŒ3øuTUÅçó¡ª £Æyµ£ƒh4ÊÊæ&$I$'ÇENN¡`£ÑȡÇ©¯«£®¶fQïcY§»ùfUU-6644Äÿù?ÿ‡ÑÑQR©‹…x<ŽË墬¬ìŽ;Ë§Ì Y§£j×.òjk—ÜhPAUq „(>1HNç“9&×3ÚK¤Ý‹á>м CCÚbB}=8Ú[ṵ̀C ÌÁ©_n£èÌ0 ¯\f¢ÜA×£ÕDsfsø‹ŠŠ)Ã:ÆÑ?} ˆq?äæÀÄd)é†É{w܃NϪ*϶EùÁ‘~v­Ìç™5嘌 gÿ?~òÃ^/Ï>óôœ¹f²$¡×éÐédDQdpp‡ÝÁÐÐ0yS.ëD2I2•DQ”;¦$vØí<ûÌÓ¢ˆ^¯çÙ§ŸFDô=Ï>ýÔ-· =zú)MÚ`¸í¶nž¡Õ­­476f*üW¬Èl7¬¨Ÿ{»~îíõõè TEaE}Ýìí9έÅbá™'ŸÈŒóé™ÛOÌ·ýxfû©;Üž AˆÇä»Ýä¸\8.]¹Âøø8ÉdŠ‚ü|$I¢®¦†îž^JJŠ©¯«ãÔé3œ>{–m[ç§³¾SÌy·ªªJ^^¿õ[¿E:ž“Ê`0܇É'8xð Ï?Ÿ©Ýˆ…Æíïµ9‘&÷ê(¥G0DiÈãü'ZX3òØ÷šd7}|<½½0¥'Ca!LSÃÏ5_PeϺbün*÷öÐöµÓ l*etE.oW×8Žþ äXЏÝ@¸ÈŠgC Á2;q›aNOÂRÅÎE4OÄD‰‰;=Tãì£èøe/#——0’kã²×F@•¨,³Aó´ØÊoä¹`cáç_F™x©ƒñRÂVíú›G£¸ºÆ)î¥îd?Š,¨v2R—GQ„I‡Ñ Á€v G{µ‚£Q3ìví÷xL3(¼>Íðœª|ÉŸ פRšÇE”ÀdÖŒ!N3Dr\Ú±Z%L™Ö‘‚oì.füÞ‚Íæ$ ñÐ U¹eæX0è,æ…±fªÀµk×ðŒð½ïÿ€mm½IþÙl6“;òܺy3æôÙ³ ZW¶ÐÛÛǃ‡8vâׯ¿#® QgQ/õöÐëõ³õ¥Þ~PæžN§‘e«ÕJ^n.ãee”–”`4¹zí###ìÚ±ƒîî¼^×®ub0عc;‹‰[–cN«ˆ-ÚÚÚX¿~}Öëp1½ðB ŠÎ QxjEZ[„·%Ÿ„Eûr,&‹btzûÀdÔ›ü0ènmÍü»˜VÑE“„Jl¸:ÇÙø·GIe&*ôn«àÚµ„‹¬$M:Ò7;÷› 2c$ÅÁ”ðä»ùéÊ<*¶¤H&Ùqò*Ï¢øVЗ[L{ØÄD†‡µÐDNÈKLÀš9'¤ ÁbÅ6z·–£‹¥°{‚ä]¡úÍNVL¦YkÈe¬&‡¨ËDpâ“àÖ®«(h‹}" šQ S•/’¤}>³opÚo¾Ö™kÈ’Š ¾ÿŸ “Ó”fAž{ŠÝ}á$QðâÏ}ŒT2‰ª‚ÁpóWUYIEy9uµ5TV”“J¥ÐëõšÈ–ÕÂ/ê—ÐJö²Uï ˆ¢È–M›(,( ?ß(ˆ\½vªÊ Ìf3“““ì~äv;«W¯"Ž`2)-)Yt¦çû¦Ž)IÒ¬xMK‡é‡³Å¥ä˜÷E?Ñ|3מ¬e¼ÚEz*wE¹­”öB‘NC(—.ƒÝ¦ñ)˜ŒZ‚ã\‹E¦ŒPU1ǰ÷31©siÊ£ã™:lC!Êö£‹& ç[ˆ[ôË–‰?Ó£ŽhoÙý}Ú[uU45˜L:ÄZk[qô(>>È–ïœfe©ÞUÅ\49éî E´„E‡̦Ùçe)Ç?mH¤L2£µ9ŒÕæ ¦ôþI §Fq¼ãƒ#!FÝ.\É8Á²ŠVZpå Z‰ r¥¦]ƒ!-$Q\¬‘t ×ÏÓû߸sÌ ÜÍš­×énŠûÏ„ ³ NÇÌ´,ËÜJj ‹‚ `µZhmY™ù[~¾;³=SJ½´dqe´oDöîyAË_‡'HÙÁ~œ=Æk\Z8¢ÈŠ:ƒo!HpîßÿQ–YýÉOÞý‚¥j‹è•+ÚôªUÚbˆ0{Ѹn(€!Ç>ÄÕ=ŽÍŠs™(wpõéú)Âu~ˆ±jÞ•T½ÝÍÆ¿;Fßörú7—]7€–™EPÕIÿˆæ¶G´ðK^ S„S3æ›–EFks­ÉÁˆQtfˆÆ7;h”EVâ±p% 'ž‚DLsÝÛm³CK9Ÿ´¢|££Z&û°ßBØm!ÿù2Š ž ê/øØrt€t»ŽÑÆ<| y„ ¬˜Í½•;Oó¸D@O–¯QU©Fãõ|–,²Èâý¬áð@`Ê]ÉÝ=`§Ë)]½TìïÅ:ÆÛZÀÉ_]ˤËx½ÇHz=5>ÊÅïÿ®céŠ ÝÝZ<»² ¬nà^}X#8ruãì `‘°è™¨pл£‚`©„Y‡"ÎO$w¸ôá|-ùÔÿø*ù|tësè]SÂU“`D »œ­}£aþvïf.*Z%ÃDPû}pPËCPÒàtÁŠúi¢-‰¤;‡ «rÐO&qu“ÞGˉ!×£)_S>‘ F“@±I»rr´j‘dºº´y¨ªVA3Ó1WŽKYdñÞ@Öpx ( ž¢Æî¦ÛaÚ`Èí§b_/¦ÑI†ÖqéùFâ6ýmcþ:‹E U̬_^`ÇC>­”° _K˜3® òd ÛPgOgwÓØ$I³Žp‘•þÍeLT8ˆÛô³¸!àö¡A€ÑÚŽý÷õ”õÐüÝvFëséz¸Š¸Ý°è‹Ïè˜V‰ ¹à««¦<ÂÝ%0 @Z/ákvãoÌÃæ SrÔCÛž§!ßB߯R: sèõ‹(S•(.§V–y§}M÷GÄØ¸Ö@W—–ƒPQUÕšq2]11W‚¦ @Ҭû2ïÊ|ôÑ$Ξù|´|çyÛ*‰H$Âþç …8þ<Ï=÷ÜrÏùƒ¤ÓQõÈ#äÕ×ßVÆ:c0¼Ûƒ1c`S)ƒk‹Išä Þ ˆ¸ª«1ØlŒ^»†çÈ¢##4ÿÜÏášCN[ÂQèì„ [‚&[˜ü3Ø{'0FI4CÁÛZÀD…ƒ˜ÃHZ'fŽ…ÅMfÐÜÿ_hÄÕ­i_ž¦ëÑjÆj\™|Ž…´ZîBO¶àVT@I 8³É›cÅ¢§okžõÅävŒQv¸ŸÒCÔµ¸é[SB—ÃB( ]Z"eq‘–x ×Ù2U´|…™ó¨ªÒB.”/LããNÆ4ëð¶hžC8AÞ• Îy©ØßK¨Ð†wU£u¹$,:òr´EÕò!Ò)-™6'¯ ׿çbÃKp–³Èâý…™ —©T UUÑéî¯8š<ƒÇãÁn·g¨¥m6ÑhQ±Ûíx<žyÌf3ûØÇE‘o~ó›ÙrÌ»ÀÌDåÞ)ƒac)ƒëŠHšæa˜ “ËEÏÞ½ø/^¤bûvrëë±rõµ× MÊzªMIQ1LÄèÉ9ïç™n¥rŒ¤EG$ßrKCá¾Ä­±j_YCñÉ!VþÇÆjsè|¬†hŽiÞ1Ì4FÇ´EW¯‡ê°˜—Ö`˜o<ÊÌ0ÆP˜Ò£´}ë,õÅVú7”ÒYâ¤Ç+–g‘“£9Öª¼>- ï†Üܹ6—bܰéñ¬+fpmƉ8y—F(:9DåÛ=LT8ðµä¨t’Òkšå¹.íx§SóF ¤Ì(²ùFòÞÀøÄ]½¤¦{0™ Äܘ :v6.LS`æâq»}¦=½Ù²Ë÷>b±ÇOž¤¾®ŽH$Âù í¨@scùù:r”ÉÉITUÅjµ°iãFzûú°˜ÍTO1A/‚(¢Óé2NÏôSDžö(ÜEQˆD"‘«H$B,C"‘È- :fu.Øl¹I¶óÎ0Íòèê™ êínLc“š‡á. †é6m%%¬ù•Ï ( :“™èøoí¡tófܶ<,cXÃØƒè)Q`tD£ÀÎÍÕr o®yá‹°èÞYÉÀ–2,§Gpü̃Þ&O¶¡k±“(7#ËZÒcNŽ6ƒ~éK:4~Q£çîz¤ŠÞíØCž¢ù»íZ’hK>¾•ùLæ[æåûx¿A–db8Ø5Κr3—#ôMÄ&£<¾­Yo+rµ¢¾w^o½ó--+±YgË%Ÿ»pK—.³úÅVÚ/]b×Î(é4¯¿¹‡uu¸ÝnNž>M4Íï1”qâäIÒi…D"ÝfC–e‡†PUY–ÑëtÙˆ†+H&x½>r\®;î/'Ç…ÓéȬû‰Dy¾[T–eŠ‹‹‘eAÈŸâÁ·Ûu{Ý!ÆÆÆøýßÿ}œN'ëÖ­ã•W^! ñ?þÇÿ¸IPÈ1¤â]­¬r¸­ËÏ7·Î_%qc6üÌ·k)™FJ`Ó¤™­ÃaÌcQŒã1 iÖ“ŸWO鯷¨pÐ_œCŸÙ@Xñ N…ª P…åó(Ü)`¢ÔÎéÿ¶šÂ >ªöt¡;;ι¦2®¥,”•iÈ¢Á0sL-‚‘Q µ¨€Äsù´Â<~¤üw;¯É¡o})]%vú¼ŠªÍ+7W ¹L·±ÜsQt"ãÆ+èb)\ãÒ’*óm¤£#ò–˜Fó€Ùd¢s(Åþ+F‚1 ѱQ>¹½œ¶ê¼Û/Ë26«•ïÿðG †9Ù}ÃáÈTˆB‹ww÷N§q8˜ÍfVpäØ1îöΈÅbtvwcÐ(.*¤§·ý¬m=ÅEEw±Ý‡^¯Ëlët2ÕUU7± 122Jii ñx¿dövI ñÄ\ÛÅ$ |™í$>¿ÖvII1ÉdŸÏOIq¹¹³CG‰D‚ή.$I¦´¤„Þ¾ÞÛ}H’Dii ½½}H’Hiié¶ûúÄëÛ¢ RS]5‹¨KUU&cq&‚!ôz=£ccÄ Š‹ŠˆD"\¹z•ÉÉI&c1ªª0˜`×=PNO{´f´óVUÌ UL‡'fn/4T‘…†ãÇ“H$øÓ?ýSòóóihhà+_ù Ÿþô§DQ5‰+Tþ¬ƒœŽ±ŒÁ›áa˜É0ý#%ô‘$º©ÃÄ$&_ÓD ÓD](NZHeRV·ÿª"BÅ6bN#)½DjÊu Nµ9†«W ±¬æù™çRPœÏ¸¸ñó;Ý®>ouŒ¨¢ÈåÚBÎåä9æ‰}WÙ‘§£§®† hºã1ÝyO#–¯‚A­ò@’´„MYHaãJM3ý8ÅÇ<4¿ÜÎ ‹Ïæ2ÿz½Ž‚‚|ü##èäémÿÛøGFeyƶtó¶ÿúöˆQ©ª¬˜Õ· $“Irr\”£Óé¸rµƒ±ñ16®_Ë墮¶f*7q»Ý†Ãá`es3Ñ©¼‡Åzá—çkf:T‡3¡ŠémY–ï*TñA.Çìéé¡  ·[£mll$3>>Žª(Œvw\Hº[‹H¸t8/zÑ©òd )C FÑ'AŸHùFIûQ£1Y$¥—Pd]~.ÒŠJ¼N¿i’ÔÆ| õ•Ä”¿—4 ‚BaBEÒé°—•!J~|60:ilHyðõGnZÌn7¦œ¢££Dü~L99Xó󉃄††nZXu&ö’Ò©ÁQÄ^ZŠ ŠûûIÅã³AÀV\ŒÞj%44D,ÄZP€Ñé$22Bttô¦> 6¶âb’‘¡ÁAR:Xòè¹#OïÁ²"͉b‰ª·;©øý3„_ÅàÃuÄ‚}ý¤c1쥥èÌf‚ƒƒÄC¡›ú0çæbÎËcr|œ°Ï‡ÑáÀZXH"&48x]/zjÙhÄ^R‚ªªûûQUGY¢,3ÑßO2›Q ª¥˜˜je¬Ï˨'@Ý*7¥%9Äc:ü³Úl±‘·m=®c½Øþõ-VÊj_MïŠ\NÓ1d"b£¤Æ…]ò# 1l%¥ÈF$"ì%%Ú¹&61qÓ¼M.–ü|℆‡1X­ØJJHF£nš·¤×ã(-A 80€’Ja/-E2˜ ‚¢ŒÅ@UéÖËøêb¼ ¾ÿŸFƒ ½^å—v”ðãc=ìl)¡ºÐ„Á°°ü¯T*EOo/Ï ¹99sSO« Lé~˜Ífôš›9wþ• x<ô÷÷séòìv;æ;Ô$²Z­³Þ`wn¿Óímw´}#VÔ׳¢¾>ó{}]íõíÚëÛu Ú®™{»fnj³ÉÄŽme~ßþÐB¶·ÞÑö¶‡æW±œ˜˜Àfµ¢×éd™ºšjzú4TQ¦aÅ üþ,f ³…½ïîcUkë¢F æ5¦C:.ž˜[äååÝñ Nœ8Á>°ê˜ñx|– Œ^¯'•J‘N§I'“tíy‹ÔÅ\¡¬gusœ¨#öª —ÿ@Áà8¶æz •%ôuŒÐ¯Œ•R:EI‹×RJŶzÆ:;ézç0.s„êU5D½Aú÷ï'_ÓPUô6+òr‘ &οqš¤ä õÉ ˜MF:Þ=ÇD_ßuÕ"´õ­tÓ&Ì99z{8z”ÂÖV¬ùù„‡‡éÙ»wö›Œ¢`-.ÆZP@2fàðaDYÆœ—‡(ËxŽgrttV¢(R³{7z«ÿåËŒ^½JùCat:ïîfèÔ©Y}¨ŠBn]Žâb&†GÙÿ½sHÅ­l|2—Æê]ob,AàR.äÈ £íò(C›ÊyÇ{Š@$@ýO¢3›ñ··3ÖÙ9kL¨*Åk×bÉË#èñÐwày Ø ‰ŽŒÐ³wïlÏŒªbÎËÃâv£¤R =ŠšNcÊÉAo±0xêŸQI§UBQ=¡”‹ê-FV¬‰£íè"„}ý 9rÓ¹uTTàxòI®­°Ðµr’’ló…h;ÜþÚ)ÚÝiµu\›X  ²î;ùUF†Ïž%80@Íca°Z¹r…‘Ë—g÷¡ª´´h××ë¥gï^\UUØJJˆÓ»oßìJ)UÅètj×Wñ?N2¥î©§0ét Ÿ9Chpt©)ˆ‚&u-J (ª‚ªªšeÉT‰Õ´šàŒK„i²-E©ßQUÔ¹JaM.ª£ÆÇV¯R0%@ÐöŸËK4Z¹±Ìïsô1k ӿü}¢¨½O~cŸ7LAQ<šC>†ÂBA“ôžcÞª ýÝ5¦zO7†Ñ}[Ëð®-!e”µöï`Þ·:·7ÎS$-Œ¢(„#*‰@Q‘€¬pç‚(jßµÛÍ{®s« ‚ b Æ)<3„ûô*C« l*âZÄ„¬‡ð)XÍ*:v®•ùæ}÷ÔMó¾ázª3>e™¾}ûxÔëå¥_¼§ïÙBqàÀº»»Ù¼y3ÉéÒÈp8‹R&ãqôz=¥%¥ :FUUŽ=J[[Û‚=»‡`0Hccã’œ¯¡¡!ÆÆÆhnn^’öo‡cÇŽÑÜÜŒÅb¹ï}ûý~†††hmm]–¹Ÿ8q‚úúzìvMb6 a4š$‘H4ŠÉhD’$ÒSß'Y–I¥R(Š‚$Iw¥Œé÷ûñûý79’É$s'G*ŠBss3---ó6¬(Êq2Ȳ¼¨2Ýï5¬\¹’o~ó›´··³jÕ*Þzë-rssÉÏÏG½xQ–‘$ už‹, ⬀²  ÌC‚ Ưÿaž¶GF!†U­"F£x=>}åÌû¸©Ï›¸i ·íã†Ïgö1}:¼>M¥1‚ü|»u†ÀÖ\}Ný¨præS«Éí¥òÊN Ó÷P9¾–|Rzi~ˆ;8·3ç1ÝÞD‘TJ#Cª«ŸMe­ÞfÞ·:·g‡î•ôo.ÃÕ9NÉqG‡h®tÒ×VÌ5‡ƒhBäê5°[µrT«ej±_äyÏõ»™¶D¸m;Yd‘…ÛŒœ–™5òŒïÐR«ŸÎ[Uq§†A·Fkk+[·nåóŸÿ›!ñN¡"¾&7£õ¹ä]¡|_åúØTÊðê Æ´ ‹kº Z hN޶8‹ÂÒ óŽEÐ8:ž¬¥ûá*\ÝãžfljAÖXl)äªÃE,­ãÜE(Ê×Ê9-–ÙÆMYd‘…¼xy–YÜV«•Ç{l¹‡he~>45\W¶|Ð!^?ø}熵k5͆ÅZ€@‘E¼ÍùøòȽ6Fùþ>Ê÷3ÔVÄàºbbvCfßùÚˆD5yéxB!¨ªÔ”.…ûh0Ì7¾´AÂ߇E¦` w»Ÿò#ýÔ‡®(wÒU_€_vÒÑ'›„ÊRmìúıï…{0‹,²X"ƒªª7¹ßgr¦g1Z%Þý1á4—t0­+A”ü¶ˆ&°ÕÓ«¹ÑKJ´…l)ŧTIÄ¿"‘º\œ}”ècÝ?œÀß䯳¡„p¾%³ïÌÿÙR¯‡TJËÐÉËo0Ì5Gˆ9Œôm)c`c Vo„‚³^V¿Ý ª´UåÐUîfTpp­WÂh«I“ùž)‹}/sš>':E@~à¸H³È"‹¹°`Ãa¡ ¿(Šœ8q‚#GŽ Šb&OBEÎ;dzÏ>»Üs~à ( ááaâ‘ú%ÌÐ!{z¡e¥–›¶qõÅl3‘€Þ^M’Ùå‚ÂüûV™¦M¯t¨p`Szd€Uß8K¸ÈÊàú5.&E‘?ø½SâRF(*Ò\üË­}±Ðyª’H°ØF°ØF×#UØ=! Î{Ù°ÿ*‚¢â«p1TïæbÔA,!ÓÝ:I»ÇܤXóaús],…³w÷iî%çC5¼ß‘N§˜MN_/ƒ4MÄ#¢(à²Ü_•Ã,Þ{Åá°g¨¦E¥¤¤%ftllÖš›—›K2™$N/jEŠ|»où4[U("77÷¶ “Š¢°råJ¬V+¢(RTThRÝßúÖ·² —s@I¥>s†¢q74Üò’(É$ý‡SÐÚŠÙéd¤³“D(DÑêÕ·}`‡#ÔŒ§cq3ôöñù(^¿^ç‘#´´`r:絛pÚÛÁlÑòŒ–EÓ`:G XdãâóZ©ãÙaÊ~Ò‰^1Ð[šË¨3÷jùùZüïAò.ÜÑ<ÑT:Ç«œŒW9‘ilC!Üý4ì¦5–"X`¥³ KF'Ê‘‘ m²…nÍ5nöFLÿ¯&qôNßîÃÙ@1ÊôÚ’üÌ>È‹bñrŸ‚%Gï@7ž¡dQDQA@Źtc5øïU!.Àù8ìõ¢×ëçÔPT•¡)í“Ñ„^¯Ãf³1::ŠÉdB§Ó344D<§¤¸øbVU¯×G,£¸¨½þþRƒCCŒ•ÂÂBrsrî[ß©TŠÁ¡!ŒF#ùSD7âÊÕ«?q’+êééíexXã‚q:ì~äaÞØó¤Óir\.V¯jåÒå+¬^½j9Ö½BNÞ†$Nóµ¯}7Þxƒ¿ø‹¿ ®®î¶‹¿Á`Àçóqùòe>÷¹ÏeþþA.Ǽ$½žêG%ï6F€¨Ó! ô8@Ŷm 9B厷íCU »òòÀåXxåÁB¡æ¼ïEL;­—¯p2VáDN)˜G¢ä]¡ùÚ ë]Díúó]xÝ'luz¬H$5‘Ó æpœœ®qÜ—üØB$M2cµ9\øøJÂVÒ:‘œÊ¤Æ±ý>G8¢¨°’hZÛ¦£Ûåbß8}c!¶Ôëd4ŒñÕ¯ÿ +xaB½AÏ ?ü¯ÿbû¶‡H%S´_ºÄc<ÂO^gžzQˆræü9B¡¨ðs/¼€N÷`äÉ_¼t™ÃG"Kn·›'ì&N ¥B:æ•W_%7'«Õ‚Ùl¾¯†ƒgpW^û1v›O}òæÜ§ýâ%ÿB8¢UFtMylÜnMºZ±ã¤ËHÏŽ ú*ÃêÓ’ ë~Ò ¨ªœŒÖç¨p’˜Ã~¯" Š““Ž|¼Ín¬þ(î‹~ªÞîfÕ‰‹ÄF„HŠ@®…ómø«r鬘ÝýƒN&Óò„ –Fƒ «IOx2ÎU¿Ž`4N…=ÅÏm©ÀfÖßöø í¹ÚÑAyyžÁAÂá0ÖdµËËʈD"Ô×ס“eŠ xsÏ[iÏAðú|ì?xˆím]†ÌÅ@:f2Ãf³a1[0èõ$ñûÖ¿$Il{è!†‡½üø§?ã¡-›Y½jÕ}ë_Å)⦹Ÿ Š¢âõyI§dYÆh0ÐÑÑA$¥¹© A°ÛíØm6‚¡:žýPSSM}}Ý¢ŽU¾]6ÿ´ñàp84fÃ)Kèvšñ[¶laýúõÙðÄ@t F»Y¯gðôiºöìAÒëi}é%,nwFppX#Zµj¶ôÂRAŒv;› z<œúêWizáJÖ¬™å혾ó<ƒÐÙ ••PV:E!}‡ýŠ’„Þj¥wÿ~jvï¦ïàAJ7n¼«dM+blâ1†šjX·V‹ßÏ—¿I2,²,²Ñõp6o˜¼‹#TîíAI)°0V›C ÊIÄm!-‹³”#Td-QQ1ǰ‡qõŒãè@MséÙQÉÉ_]Ëd® !­bñEpöOP;8Ns`áRŠPFJ‰™>ÙBªÔB¨ÓˆXp{Yé÷:dYÏê꞉ðÊ1Û›òxv])ãÂbù‹™êª*<|~?áHä&ÃA§Óa0Ðët  ÑÑÑÉóÏ=Ëž·ßæ“/}œ´¢ðÓŸ½ÎÚ5k¨¯[Üå^ IN§“ήn‰$iE¹inK Ahin¦¹±‘ô” æýF:&=ƒ.z&DQ ‘HŸïÆ›‹Ãá ýÒ%FGGI&“`Ð먮ª¢§·’âbêëj9wþ§Ïœå¡­[í#ÏgˆSùšOšd2™QÆÅb±h­s”]Žñ£ýˆšš6mÚ„ÉdÂçó100p“¾ywQ–1»ÝÀxg'Õ<ÂXG¡áa,SŸŒiy Zýýýz£38èÌfTÀYYIa[J:={ü@0 ýýàtš5ZNÃÝ&ª@Ak+ÁÎýÛ¿ánn&§ºXx¥Çt~ÅȈæiðù4cfUëu¦å…¶Z’a ÌÁx™)U…y|×µqr®Qzd€p¡•ñ*¡·…”IžµHÏlï~àÆù *è# L£“X‡Ã8ú'°…‘i6=¡bÝW,±“°èPDa–·ê­vi!‰”‚Ka ƱyؽŠGÆÑõŒPq¥—c‰]bì6ÑÉ;šTåBIž £^Äb^ØY[SCmM ×:;é ° à¦}L&#N§€óÚY½ª•5kÚøá^¡³»«ÅBwo/Š¢ÐÓÛË“?¶äÅ ÅC[6óæž·¸tù2ׯ¿¯ÚÉd’CGŽÒÓÓƒN¯çчwÝ×¹ ³çíwðx8pèmÙ2ËxH§Ó‚ˆÕbÁår˜˜ ª²’Ò’L&#×:»ðúülß¶îž^|~?]Ý݈’È®;õ92§ÇA†††èèè`hh—Ë…Ífãøñã ÐÞÞŽÛíæ×~í׿ÐH&“ø|>ÊÊÊ2qšññqÆÆÆîë…x¯ànxŒý(’NG*##ÊEr"£c°b…–+p¿Œ¨Ü±CEcJ‡`Jiz®é4ôh×N§Æ¨x/ÌÓE‘’õë:uŠU¿ø‹¤S)Æ»»egEżºLibSW®h㪯ƒÖ–ë w‹éET•E"n a·…þM¥èbI¬ÞΞ9cŸDާHØôDÜBÅ6¢yfbN#q»´^º©Bán7/‚¢¢$0LÄ1bX|,Þ)ž&e’‰9ŒËì ­)"’o!iÒ‘–f 7žá™Ÿ)²Hª'nÕ3QlËG20°7HŽwøï€³“Ñ„ æiù‚¦Es¨®ªšWñ°ª²2Ÿßµc;²¬É.?ÿœV /Š"ÿã Ÿ'V$ñ®D– …¼ø±H§Ó÷Ý[-Ë2Ö­eMÛjŒ:Ýý­èp»óøø‹?§ÙsˆS‰¢È–Í›ÈÏwSXP€€À•Žª«*±˜ÍLÆb<²k'N‡ƒU­-„BaŒF#åe‹nÎÙš LLLpùòe._¾Lss3>ŸÎÎNz{{$‰J¥ey–×a:¹ä¹çžãg?û­­­±bÅ Z[[³$Ps@U"~?‰htÞ<€› H:ö¦½z5—ô#ôV+Ž©Æè(Æ¡¹éþÏGœºIÀå }`r¹È©ª"er iŒŠåå‹Ëü¨:³ƒÝŽÎdb´£ƒžwß%6>NÃóÏ“WWwÓ¢Ohɘ]]P\ uu/Á´‡f)x. eÒ1^éd¬Ò©-ž‰4†`Û`»'ˆû¢}8Óªžâv1§‘¤YGª'æ0’2ɤ 2Š^$­“P$MM•¦f§€˜VÓ BJEJ¦‘iäɆP}$.’ÄŒcÆAE§µ5™k"TbÓŒ„ I³ŽÔ”ñr+CaÁç`Æÿ‰D‚À¨E]ûQœ) w·mˆóVÌül:yf -‡ÊäB1sÌ÷‚ ,kh]–åY¢UsÏn³±fõêÌßŠŠ çÜ·¼¬liÇ:×E¡±±‘òòr†‡‡±Ùlðì³Ï’L&éîî&77£Ñ8§! ( ‰D‚G}4›¹¤S)<ÇS°v-ùw´X©€³¼œµŸù ¢,# Œ4„†–5p>ªØõG¨icŒZZXQ¿D ³(bžÊwUWcq»¹òê«H3šŸE,==PX¨yfÌæû¯!1³ì1šg&’gf¨µ@{ëH*ÈñºHÓø$Æ@ ãx ‹?‚«k1©¨Z²¢¨h‚"O)P**bZ“ÚV%A3.t"ª(4éˆ; „‹¬Œ4æ1é2‘°êI$R: eª.pæ—"CBCCô:„ºví}8ëYd‘Žb^ÿÅ´«¨ººšt:ÍîÝ»I¥R‚@mm휴ҙFe™¼¼<¬Vë;{!éõÔ<ú(î;42tSoŠª©FšÍ³™ — ²ÁÀdÒ@` µU£,^ªqéÌfš?ö1Q$Ó¹gEkÖପ ™Ôò>ü~-¡©I£‡¾Ÿí0˵¯Ièô$¬zÂÚõé1!­"(S?ªö3*ˆša¡ˆ"ª$ ˆÂœáŽ™Û÷‹üY\Ô?ý4¢ßÏtYdq·¸%sä´q ¬xÏ­ DQäСCôõõ‘J¥xþùçqÍÁn–Ålˆ:Ý=Ó5OËdK-ÿ"¨(Z)èȨ¶8×h¹ŠK;.A@Òëÿ¥K :DÔïG²ØWËÑÉZiêªÕZ2æ4–û\ÝvZ7üš1 .„1h޶¤ íþÏ"‹,ÞXtw€  ÐÒÒ™3g…BYÃá>`š ÁãÑ*–{,É$øGÁ; ×ËïT ¸m Žêtw«Œ'­˜m±”Éð`x²È"‹,Þ‹ûÕCUUÚÚÚ8vì6› §ÓI{{»ÆÃ=8˜-Ç\"¨h$E5µ×Ë— þQè¼UÕZhâ~‰RÁTƒ ôôê0UkäW¦)­‹F ^Ydñ~ÄLVÉt:ªª÷=%`Ñ{S…††ªªªeEQèîîfrr’‘‘ûO¨ñA€ {5á©qùŒ% Aè pçÝ}ÖøÝœм.ñ„F m±h„RÓÞŽ¬ÁÅr#§§¯“d2Á4ÈÉâ`(–‡Q¯ã¡÷O!‹÷âñ8'OŸ¦®¶–ÉÉIÎ_hGE¥©±wn.Ggr2†ªªX,6®_Gÿ€“ÑHeeŽ` Kb¦‚0Kqí™gž gË1çÀ½ÆœSi-4PR²|s˜ÖÃ0 ­ tò}”¾F3XÂa-§ÂnŸ’ _¢’Ê,RÎÅR¢o QÈqh,™ÑxŠ}—&¸6‘Äm3²¹Î‰t‹¼•T*Å«?ù A$Qdë–-TWUÎÚ'‰ðöÞwq¹œ(ŠBeEùù:r”µm«éîéáâ¥ËX¬vnÛŽ}©¹èç˜Ãñ“'¹zµƒ?û!G泉`˜ÐÔØÈêÖÖ;渹ü~?{ÞÙKiq1ÛÚ:ë³ö‹9¡ƒÑÈÎmÝ×0ûèè({ÞÙK¾ÛÍ®ÛçÜç=oÑ?0€×룫»;S€pöÜy>ûéO“H$™I&“¤R)ÞØóiEáá!Þ Ä1á ÂEò~ƒªªL$ãwÎË.¢½]GšŠäý^$E`|.]‚‚B›A¾OF@0ýZ•D: õõPR|Ã#YÜR©ѱ±Äõ’% E—Ã[cI §‡$zB&¢Ñ(»[ò¥©RÚyËT*Eÿ›7nàñÝ»)).ºiŸóííœoo§¬´ »ÍÎ;ïîãàáÄB!, ¹¹¹l{h+Á`ˆ³çÏÝ÷s ª*v›‘ÑQBáðìó#Ë456Ò¶jû$.þ›ÕJwoïM¹\.Úº…T2Éñ“§îû¹±Ûlt÷ôÜ0Üë÷B~¾›Á¡!<b±86› ›Í–)X0 ˜M&Œf³™–•+YÝÚÊÈè袎SVnãE‘ŽŽΟ?Ï3Ï<“-¯\¤“Iú$¯µ•‚¦¦;z€ÆV ²êþ/”Šý@ÐȓvÎRÐ7ƒ(-…ªª¬‡á½ö÷Ó³w/êúõË=œ%C2™$‘H`Ðèñ%¸<$6%…Žd4ÈómnZËlÄãqTU%‹ŸãE"™L"Ioìy‹ºÚÚºQ‰ÇãÄãqÒé4èu:Âá0õuµ\ºr™³çÎóÒÏ¿H:¦Àí&žH`4ÈËÍ%‘HÜÒ,B¦ýd2y˪º…¢¾®–‹—/e8¦û—%‰²Ò:®]ÓÈT5Ów<_”õÇåtÒÔØ0¥9ûçåæ’J¥Ðétä»I¥RÄãqb±Ø¢Í}>ØívšˆNF‰Åb‚€ ™{!‹‘N¥ƒX,RÉ$Ñh”ÊòrB¡W¯vœ$‘H099I^ní/±eó¦Û^ç™Hß p#„ù×o¨í~“É4§îD4åÿøÙ·oñÁŽ;nÙ¨(ŠØíö9YÍþå_þ…œœ†‡‡ùìg?»dཆ¼ö?H§©}öÙ;rË À¥ËÚÛõ4¡ÒýÀtÕDûEíÿ––ûW5‘Nkùãcq“ÅfSÖXx¯£{ÏvŽò‰_¼/ý8p€îîn6oÞL2™¼és‡Ã±(ª‘‚ Áaw ( iRiUSÒJ“^žõÝÅb †9Ÿ±XœD2$I˜M&A 5%Œ¤×ë3eôÓ9f©TŠT:Ñ`È´¡ªªfÈô,$P4³ýÅ´4×Z1Siú|èõúyÙ2o‡×6EQH+ º9 íÜ$Ñëõ”ðT:Á`XòP»ªªÃeñxN—1S©”ÆÝ#ˤUQÑëuH’”¹—UUEÅ̽0Yã­Æ1×þÉd’ŽÎd-IgþƒM&Ï>û,f³™ÕSÎY,2Ù`@„;ó6Ä!Ð*îÛPÑò ‚AMg¢¤déó¦å­ÇÐ×§…"ªªîM+‹"QØû9ÏAQ”)o@±ñ±›ž£jæ í–9nnaš·õF&/õ†í©Ï¦«®72CüíN”ÛñËv«9ÞØß-÷½t:ùî¼9©¤%Qœw=ÓédTUA“Ñ ˜Û½…/$Iš5®i#BQt:Ý,£b¦Ùs«êŠÅ»|» 1-¥=99yO¢###ÙrÌ[àn¾Óå—fóýYAS£Vr¹”^†dJó¦tuk†uk4í¬ÁÅ{**F£’’ü##Ùï}‚N–)).ÎV.2nk8L»Ø¢Ñ(ét:“|“ÅâáNyÒi„ꚥõ6S};¯½éWWišKvõU˜LÀÕ«Z…FK èu™²xãýœß ¢‚ª%ŽPï&û½?²FÃ"Bz/¨¶%‘HÜs¨"‹ù¡ª*ñPˆT"t›¬eƒÂ¢¥U™Ðòü~((Ð~–JmSI¸vMË£¨®Ö*%²!ÉÒŠB,|߇’$OÄŸ_' d¨;ÝÎbi¡( ²$/,TQSSÃæÍ›1›ÍYoà LÒóî»ä45QÐÜ|˯@* ]PW»´Þ†x¼^@Ъ–,L j\JiN&cÖÃðAŒ÷öÒõ曨6,÷pªªbµXYQ¿"{SßLNFI&ØmN&c3·'I&ã7oÇ'I&´í,–‚ `Ðno8(ŠByy9ÅÅÅË=æ÷-$ŽêG%¯±ñ–ÏVY–ÁåZÚ·ÿ  ²RS“\J¯Æ°†‡ ¶nÊË­–ø@A\UUÔ=õÂøƒýF.Â]½8 ‚€NÎʆß“DI+Ád ÒJ ½^O,%žþûÍÛ²,/:5u7C$QZX¨B„».ÅL¥RtttN§"''+ârш$Š·\4 ƒÚšë,‰‹: 4 g¯W 8Kgœ$“pµrr ®N+)…¬ÑðA„èL¦ÒpE£Ñˆ D"$Iºgb¨[ Ó‹ß¼Ÿk;e§÷›¹hÞ©qsc;wrüãæ˜¸q|ów㘭Vs†;Áb± ‡Éqå¡/и‹%ÓþÌí¥@"‘ ™Lκ>Ƚ^¿4"W3‘L&éèè âóùX¹rårÏýÄB¾ª©$x<ÐØ¸øý @( gÏBy…–œ¸TFÃØ¸F åp‚Û½t¹ïÜøZŒó 2w©ìbsøÌ×ÏÝàA½þÓ F4åøÉS¬[»ƒÁÀ¥ËWpçå‘——‹gpÃ}óBpèð:»»‘%‰¼¼\Þ¹3“ÀwòÔiL&M s;11Áå«WI¥ÒÔÕÖïv3 ²ÿàAñ›6n ¸¨hAã¸tù26›Ò’&‚A:»ºXÕÒ² „BEQ8{î<²N¦¥¹€ññqŽ;N2•dÝšµÎyl àÐÑ£LF'Ù¸a=¥%%„B!.]¹J2‘ ¦ºšÂº{zcËæM÷}áN§Ó$ ÍE?“ç ²,³äégÓÌ“?ÿó?ϪU«>Ð9¼üòËüîïþ.CCCwt¬€V¢XR ¦%(ÁŒ'4±ªª*3a©Œ†þ- b6CYñõ2Ë"úäg_øoþÞïñîÿûÿrñ‡?$HÜS›Ýo½Åkÿ×ÿ…ïÂ…YFI<äÔ׿Îþ?û3Æ»»ïºŠA@3‚ýýìûó?g¢¯ï}]1ËW®bµZÉò˜šLFη·LÐÓÓ‹eÊe60àáÊÕŽyÛQUÏЛ6¬ç©'góÆb¢¡áaöîÛGÿÀÀ¼Çï;x§ÃAeEû"‘Hpâä)\N'õõu;~B£$^ l6§NŸ!rêô$IB’$††‡¹xéò-=uæ ¦·¯/ó·‹—/SXXÀêÖU:|˜ÉÉÉ9=pè0¹®š›š8qê4Éd’‡c1›¨©©æàáÃD§®jª«eØë½Ÿ—<‹[ ›·~ŸFùÒ—¾Ä+¯¼Â~ô#ÆÆÆîèxMS–¿tMU4uK½J—Hš[IÃÈLÆ4Šì|÷ÒH=Èsn.W^}•d$‚d0ð“_ÿuü/"r½D÷ÆæÙ ˆøý\øÎwH„óö¹øòËìÿ³?Ô› ©T昙}‰·èKPÚ_~™Î·ß&ã9vŒøÄÄœc¼±Ý÷2E¥·¯ªÊŠÌß*+*0›L¼±gååeJc£Ñ€Åb¾e{Á`SgÎðöÞw LLd4Ú/^dõªUèõó‡… z=ƒCÃx=ˆSòÛ£££ÔTUSZ\L,>·8Ö|(-)¡¤¸˜Ÿ¼þJ:Íʦ&­ƒ«ÕrËc[W®dÇömèg„±7¬[GÛªU˜LFÖzž7ôx"ŽÛí¦¬´„ÑÑÑŒ6Çа—qÊë¡Óé(**¢§§—, d¥.ï$I⥗^"??Ÿ_|q–çe!<±˜–s°ØI‘É$ôöj “9K”©ªàóƒÏÍM÷WvûA…Ä'&H„B®^M*G”$DY&<:ÊÕW_e¼»›êGE”$úÀYYIõîÝ\úÁ˜£ù…ÐÛl\}íµÌ¾ãÝÝX‹Š°•”dd ‚CCœùÆ7HÇã$ÂaN|õ«8++©Üµ‹“ÿôOÔ?ý4¾övb¥›6Ñð ¥›6QûøãôìßÏàñãHz=éTŠ£ó7”oߎ³¢‚üæfŒ÷örù•WHF£¬üùŸgrlŒ³ßü&¥›6‘œœ$80ÀÚ_ùl……ó^÷Ùk¡ª “““Øl¶Y·XÌ û¼X-×ؼ¼¼[_wA`ÝÚ5Øm6&'c¼»ÿ?÷Ѱÿà¡)1#™Ñ±q¢Ñ(fó͈ÕjåÊÕôzN‡3Röz‰'∂xÇ^Ýæ¦&ŽŸ<ÉÖÍ›2íå¸\ä¸\·Ä÷^|‘‚U«0:ÿÿþ?*wî¤ïÀ¼çÎQ¹s'o¼¡y>d™7~çwxè‹_DoµÒýÖ[$''i}é%Nýó?›˜`ýÿï¼þ[¿…9/ß… „iüÈG8õµ¯a°ÛqVVrð/þ‚ò­[±Ïa8$£QTE!?°÷Åtrx"«€ÀÄCÃ^vnÛÆù í<´u ¢(jÒÇét&±o.ˆ‚¶H:NN>MZQÈÉqá÷Ð×?@0$ a6›‰Åb¤Òi¬ *àb÷#ãp8xõÇ?!‘Hb±X0 ¸Ýyô÷ܱ‚¥Á ÇjµfÂ-@FBÛ:5ßù Þ <544Ì™sçØ¸aý¬\‹x¼‹ã§NÒ?0@8Áa·óèûÐétx}>†††Ù¸a=~ÿç/\ ²vÍôz=kV¯æò•«t\ë ±±!cȨªÊàÐ0µµ5Ë}+d1y®2Ë{)¿œ£££¨rÌwÞy‡¿ú«¿BUU^|ñE¾ð…/Ì»¯¤ÓQ³{7•»wgÜÕ3‘LAA>ä.R˜BFFapV·- ‘T2.j9ÍM ¼×Ý‹ EQð_¼ˆµ¨wc#¾ó牎ŒñzIMNÒô 4>ÿúQ<ÇŽánj"‰Ðô‘Ðø‘0ÞÝMÄë%åÊÌ5€ÐÐÑ‘ò››‰øýDGG1ççsé?ÀZXªJdx˜ú§ž"âóözq77ÓýÖ[Ú½(ÄÆ::0åæ’N$ ³òçA3ŸÇƒAj}”Ñ+W0åæb-( ý?þ‹Ûm«·rçN*vì ÿ~„‰‰å¾,󢩡‘#ÇQ[]Åbaes3º)î€Ög¾@U••·}™ª«­¥¸¸%­Ü”GPS]…ªV^??å¨åe™ß««ª(.*BQ”L^EYi)Ï?÷,Š¢ÜÒÓ1Aà±G™õÌ/+-¥¤øÖo*MÔV× šq%Š"»~˜X,ŽŠŠ,I™ç’âbŠ ¯WXTWURP1*ÊË)((@I§1™L™üˆþTU¥¢¬Œ, Ü·ŸÏÇððð¦óCú?ü0Àmë¾A@o6c´ÙnZÀ4ÚçpXK\\Œ>‡hTÓ‚°.…$· ## “¡¡!k4Ì…þljøýNÿË¿àoogûüõúžƒçøqêž|’Õÿí¿qèý/ŠÖ¬Áœ—‡’Nc)( =OžÎlFôËm8äå岪¥…䔺åÌ„À™±ø…ê"XÌs'PÞxü\íÍõ<1›oy;Üè¥Ðª+n?‡ça2™2ÍÍí]oP„Y¹!™¹ s»qýúE™Íâî!üã?þ£úÌ3Ï`2™%ì Š"v»}Níóù—!''‡ááa>ûÙÏ.÷Üï+¢Ñ(ù—IWW¯¿þ:Û·o§¬¬Œ/~ñ‹:q‚ ÕO<1ç"îói%˜vÛ½/òñ’^U‹_Ù  …@ª*—(oâ}€D8L:‘@U”T ÙdÂ`³!Š"©xœD4ª‘‚éõăA$ƒÙL2%H`°Ù$IKxœÚW”eá0¢,£Ÿ‘È·ç÷~Kßÿ>ŸøéOÉ©©! !H’Öw2‰d4’ŽÇÑ[­Z¾M8Œ¤Ó¡7›ID"(é4› UQHD"¢ˆšN#È2›t"A2Ao±hã ‡AUÑ[­$"ÒÉ$z«iž¿ôìßÏ#ƒƒ¼ôâ‹÷åü8p€îîn6oÞL2™¼és‡ÃÑhD–eìvû}“ªÂèèÁ ù·­jÈbéF™œœÌÜY¸rå ò­Œ…i qZÜ*›Ïp÷$‰ªª*ìv;ëׯ'•Ja00 DB!Âs<¼’ €©*©{Æ€GËï*(X˜Ñp§aŒ‘Q›¡Ð½ôôÑK©Õ±ÔãÒO%}ÝHʤ’Á€iÆ›—qFv»ÎlÖ’g§p«}TE!‹Q¼nÖ‚˜eTdÚñ–hšÑÆÌ}IÂètÞt¬¤×gÄÙÔsã†í÷ :D2•b˦äçßs›^¯—×÷ì!/7“ÉÄàÐ.—w^CCÃèt:rss8uæ f“‰Æ††;j_QΜ;‡Ñ` é,rGŸ s*,¦×éxîÙ!KgÏŸG§ÓeJ6§qöÜyDQ¤ee3ãG'™L²níŠ …B\¾r•D2Amu5œ8yŠËW® É2N‡ƒÝ<Ì™sç¸Ú¡)ÝI²Ì‡?ô †9<s!‰pàà!"‘Ö¯£¬´EQ¸pñ"ª¢²ªµe î‚.äù,¨t:ÍO~òŠŠŠhll$ãr¹² ™w ƒÁÀ/þâ/ÎùÙd$Âd,6çgiESÂ4î}‘L&4Jé²Ò…QV«ŠBphK^Òm¾ÀGC_¬X±ôBUÉH„x0ˆõXòîÂ^/²ÙŒaŽúF,µá#ˆ"ÿ?ÿ²ÑH ¯{i©–›ðAUÕ9ßüT?y‚ÜœÌf3Gçé'žD’îþœŽ|÷ûßgtl ‹ÙL:ÖH¦.´³¶m5]ÝÝ´­^ʼn“§8tä( +êok8  YQ_ÀÉÓ§9|ä(uµµ·4V65R_WKgWCCÃÈ’Ä©3g8|ä(ÕUU³ ¿ßÏ;ïºŠ–•Í\¼x‰|·›ÜÜ\:ÌÓO=ÉC‡)/+¥ÔUÂÃGxê‰Çðxh[½š’’bDQD’$¨©®¦§§—¾þ~dY& qèÐabñ8Ö¯›—óô™³ *ÊË9~â$…´_¼È¡#G)*,Ì‹ q¾ªŠcÇŽñ'ò'|ùË_æ'?ù ?ûÙÏèïïŸ3‘Å=BæärÏ Ä&AZ ‡LU”›âÉNÕ(Z ·(‰W_{ɱ±[ÖÙOKpwuk9 –9ò&@I&Qî€ÕîVýúú¸öÆ÷Ü–vÒTíœ-‚GMºßy‡±«W…øHM§ï™MÒ`³a°ZIMNrñå—åZ¨%^”s¦¤R„‚ÁE×RCQFÇÆ©©®¦¼¼ŒH$J"±pÒ¥¹àt8X»¦µmmì~ô òó)+-Åjµðúž=”––`6›immaû¶­™¤Ãù022™³g9zì8ƒCC(ªÊª–vlÛ†Nwëc- ³™a¯—ë×Oy4²§™y±XŒs.°ªueÆ3°~ÝZÖ´­Îä>Lkx}~††5¶\I …Üo¿À;{ß%0Ðt'Ìf¬ ƒÃClX¿I’8zü8&³‰†õœ8uŠÄ<ߟÏG]M %ÅŤÒ)"‘(MìÚ±}Á^‹,Ž9yTU¥¥¥…§žzŠ]»v!Š"@€‹/PVV–õ<,"TE!3‰d’¦ˆ“†u”•¤ˆOª(·Y×A <4ÄÀ±c4<ûlfñè÷èާ1”+Ä£ 3R±±PˆX$‚>Cãš @Z8wAÆnN"©ÌÙ¾(Iô¼û.F»ÂÕ«ïéþD‘x8¬ýLÑÒÞ Òñ8?þ1Õ»wc°Ûï)$'±p˜x$B<G¹‡…UEF._&èñPµk×=y'ÐÆ456é^U¥óÍ7É­¯ÇU]=ç½qGç,$½FÈý‚  ’L¦áÞs»ÍF<Ç1#§Âj±244œáS0L‘.Ýî<4쥷¯Ÿ@`‚ÞÞ> òó5q"¼ û¸·¯ƒÞ@~¾{F¿³sT9J(Æjµ04ê~“ÉDÿÀ²$S8UŽÚÓÓ‹  3:6F"™D¯×sòÔi._½Ê†u먫­AEedl”þ),E#¨ÒéQÈ€æ{ò\° Ýȇt:Íúõëyùå—yâ‰'Ø»w/&“‰ÜÜÜ=`£Ñ(/¿ü2áp˜³gÏòÌ3Ï,÷œ88?þ1ݱƙƊ*"Çò˜Ôã‘,„_/`pppÖßÇcù8ÄÞcѵ ¤Ó¯]cü?þƒð¼YÛ* Õ„ua0 3¸g~5¼HOqƒôáÃ÷öv/ÄÆÇ‘GFú‡¸çó¯¤Óį\ÁÛß¼o'Rw7Ñîn<'OÞó<£~?±`Á+Wîy\édso/Þþg„fÿß “×®1vò$“99÷4ÏÄä$#—/ãÚ½ûžÇt? Š"&“ ‹Å‚Éh¢·¿oj1¿7¨êìÓ †ð ²sûv.´·óЖ-w·?Ý-+5Ž¿„Í›6Îè$óOñxœd*5«Ê¡§·—ŠòòG8ë™ï°Û‰F£t÷ôâÑ’:ÑgΞEÕ?0À#»v‘ïÎã•W_c2C–$f“‰ã'NfŒÆîžÊËJ3IˆnwE…TVVÇ1O­W +¨¬¨À2•@j³j‰ÅÕÕU x<3¼ ꃙõ‡‡oÊË—/³fÍéì줶¶–ÎÎNR©‘H„üüü‰©Fžzê)@Ë›Èz*nƇžy†‡wî˜ãZhÖó`.9Û»ig¾¶æØ AnûÖy§’½‹3¶÷v[òØ«-UÕ$Ë{(‘²µe%BEemÛšE)¼Q碫»›ò²2êëj9*+*(â¹±´µe%ïì}—3és¬lnÂl6súÌŽ;ÎÄÄ’$òðÎwEŽ•ÅÍþöoÿV}á…0³4Ù}>?øÁضmÃÃÃȲ̻ï¾K4¥±±‘¢¢"yä‘›r²å˜Yd‘ŃŽÅ(ÇŒD"(Š‚Õj]”2½t:¢ªïE"‘@–uˆ¢yI‹ÅâZ>… ‰v»mÁ}‡Ã‘ÇŠ™òÂ麙ÆO"‘@§ÓeÚG"åö ÇfÆ=u|4%‹¡¢ñ[Lï7MÅm2›§Ž‹D£¤R)lVkf½¸±_м։d«ÅŠ,Ïï)‹NµgµÚEH$J<CQÄqå”ÙrÌ›qåÊd‹Å2ç[ƒÃá ¿¿ŸC‡ñÄOpäÈ^yå‚Á /½ô‡ƒýû÷³k×®¬!‹,²øÀánXoI’˜¹,Î|;žN†´ZeàîúÕx!n>öFr¦û´0Æ<óy¼Ùlž“Œj.Òª¹H°æò˜ÍfBouc¿‹ù¶J¥YÜäù˜ÎTUÍ”`ž;wƒÁÀ“O>IWW—Vjsð «V­ÊZ`÷€d2Éž={xûí·±Z­|ô£}`˜5Ãá0{÷îåðáÃ|îsŸ£´´t¹‡”AGG?úÑ ¤¤„矞ºººå±XŒ7Þxƒ ( ›7oæ©§žb¾<¢å@?ÿüÏÿÌÇ?þqî`)ðúë¯óꫯÎzyùÌg>C[[ÛrmY0:::E•¿è†IY,æÍè™Vg³Ûí<þøãŒŽŽréÒ%vîÜI~~>¿ôK¿„,Ëï©Lè ?ýéOùó?ÿsvíÚÅðð0¿ó;¿Ã?üÃ?PQQ±¬ãŠÇãüÙŸý===?~œ~ô£ŒáÐÝÝÍoüÆoàv»illäÌ™3ìß¿Ÿ¯~õ«ÎàÂ_|ýë_ç;ßùNÆ ÷—ù—ø|>>÷¹Ï-÷i4—ò·¾õ-¾ò•¯°uëÖÂpx÷Ýw䡇Êï…SQNŸ9‹Íf¥~‘ŒÖa¯—7ÞÜCNNF£‘þv»â¢"&&&èîíeeSç/´c2iXqgêt±xœ£ÇŽáõùi\±‚•ÍMs¾ø=~œT2źµk(,(@QÎ_hGÖÉ4Oq@ŒsôØqÉkÛÚ(-)!˜àèñ)¨5k(,,àÄ©S\¹rI’p:<úð.Μ;GǵNPUdYæÙ=ƒ^§ã|{;¢ °²¹ùŽæ‰D8pèp†ª´¤„H$ÂÁÇ ‡#lX·ŽÒÒEV ücNÃAü~?étŸÏG$ÁårñÄO°gÏôz=999¤Óé,›ä]"ó£ýˆüãüú¯ÿ:‘H„Ï}îs¼ùæ›|æ3ŸYÖ±‰¢ÈsÏ=GII ÿøÇ¨PT,ãÙgŸåŸøv»¡¡!>ö±Ñ××·¬†ƒ¢(8NþüÏÿœ-[¶PPPÀÃáðáÃô÷÷ÓÜÜüÀüáp˜øÃó’£=¨8~â$‡Ž¥µ¥yQ ‡ñ@€ï¾ü}ÆÆÆ0[4(‹ÙÌÉÓ§Éq¹8uæ y¹¹œ>{–C‡Ð°¢þ¶†Ãðð0Á+êµñ?EQÙ¼qápEQæÔ¸Ð~‘ü<7®æ™§žäBûE9BuUUÆpho¿ˆÛí&/7—ƒ‡ðÜ3OÓ~é"y¹¹äææpàð!žyòIú<¬ZÕJIñu²§†+¨®¬¢§·—þt²œ™[yYYÆp…B:r„XL#€šÊòŒà÷ÐÔ¨¿§ÏœE§ÓѰ¢žcÇOPPPÀ™³çe™†+8vâùùîlrä"Až‹PCQš››ù£?ú£LÂÌ4·CI‰FD²ŠŠ™8}ú4‡âÙgŸ]î9?ˆÅbô÷÷ó«¿ú«€ö–ÕÔÔÄ¥K—–{hèt:6lØ@(zà ÃÆÆF2oJ§N¢¨¨ˆò›JÇî/DQ䥗^BUUz{{éééáüùóìÚµk¹OÁ`ï~÷»<ÿüóôõõ=0×5 râÄ :::H$ìܹ“‡~ø'íY½ªI’¦$¥ïN‡ƒ5m«cǶm˜LF CÃÃüäõ7pØí456’J¥%™±ññ[¶7::Ê™sçñûýØí6 ¸ÖÕ…^§ãL8̺µkæäÚ¸~z½ÿÈH¦âees:Ža¯÷ú~Ö£—.]šR Y¿v-z½ž‘ÑÑLd8¦ýâE®]ëdíš6v;V‹…¤^ϰ׈õëE‘æÆF z=ý™>Ž?Á` ¼¬œ'OñÄc» …Ü;Þ¾>œN………xý>6®[ÃaçÂÅ‹D#¼>ë×­ÅépÐ~ñ"‘hô® ‡l8þfˆó=@EA–åÌÚ ÌËË»+%¶ÆÆFZZZ¨·×å„¢(Äb±Yño£ÑHtÞïx<Îw¿û]¾óïðùÏ~ÙÃÓH§Ó|ùË_æsŸûccc<þøãË=$^{í5òòòرcÇóTU“ÉÄ•+WÐét¤ÓiþðÿÿüÏÿ\î¡ÝƒY·xâ‚ à°Û±Ù¬8ŽŒá´re3ÃÃ^V65!IƒaŠùñÖ†ŸgpˆîžéîîAQ"‘¥%%ÔÕÕ²wß~âó(–êõz<ƒƒ8xˆuk×`4§úÕÝ´_"çJGÇTŠ„^¯gphˆý²¶­ £ÑȪ–ÚV­bE}=ïî?Àä¤F¯ß?0€$I²§é>f.IÝ==\ëìâÜùóôö÷“H&ÖJ@‡èìêBI§QUåBûEDADQUTTFÇÆ8ß~Q+¿ cYUUÁqÉ{co}¿A¾SËþnßTŒF#¶p÷P I‹…à šÝP(„ÃáXî¡=ðƒüýßÿ=ýýýüþïÿ>M‹¥v˜œœD§Óñå/¯×ËßýÝßñõ¯?üÃ?\ÖqõööòýïŸO}êStuu‰D g —‚ ð¥/} ½^Ÿ)yüêW¿Ê~ô#>ñ‰O,X¢zÙ .®ðßPÀÛ¢uVuÀB Z[Vb2™ðøÙ²ie¥%ä“—›Ë™3g3áªx"A*™Ìä– sæì¹Y$NÓ=Ïœï…öv xúÉ'yå¿^% …9}æ,Ö­£¤¸NÆåra29yêé´æ­ÖÈžÊæx£¿Þ‡;/ª**‰'☌Fš±˜-ôôõ±mëVlV+’(QS]̀ǣ·©2ÏÚšj<³H¡î䚨D"!LÆ'ÁùA€œuÃ,Ìf3µµµ¼óÎ;lݺ•±±1N:Å‹÷IVø½ŠÉÉIþê¯þ QùÓ?ýSœs¨5.Eáïÿþï)++ãcûv»²²2Ο?¿ÜC£¿¿ŸÎÎNþôOÿ€Ë—/ó×ý×”––fÈÙ– D¯×óØc011qWÍû#GqüäIâñ8ªª²cÛC÷lè †›J§=Ó<ÇŽŸà؉LNN"°sûöyû­®ª¤²âzoes3ûö@Öɬ^Õš9σƒC³ Ž?Îàà‘H§ÓÁ#»vqúÌYŽ8A(FÞ¹£ÑÄ;{ß0›Íìyû<"‘‡GvíB¯×óöÞwI$ÔÖÔd ”d2EAÁu’©S§Ïpôøq&‚ADQâ‘];Y»¦ýÒ×?@eyy†ª´´„¢âëFMËÊfÞywJ:MsS&“‰–敼ó={ަ¦Æ9Ë?oQ).,»­6È Â7¾ñ õÑGÅd2Ͳ&o$pZ¨{3Kµpõ)V¯^½¬cûÿøþæoþ†¦¦&Òé4—/_æ·û·yá…–u\‰D"ãÙJ§Ó¼ôÒKüʯü /¼ð²?_~ùeþ×ÿú_4NÅﻺºøŸÿóòÄO,i¿÷J …4Á%A@’¤»"ºs1ö}Ôëõ‚@(žEåpÜY¿‘H„´¢`›AZ•N§I+ ú©~#Ój½S‡ƒH$B,G˜"€r8š6N$B:•ÂfÓ(Ÿ¯ ²,ÍÚ/•JaŸÚO›W½~ÉT8BlаIEœSÇF"É$6«õ–÷k$%•JfÆ2ßßî‘HŸ«ÕN^n^6ß)¨¹ÌT*…ÇãÉXÓz½ž²²¬ÕµØØ²e _ùÊW8xð 6›Ç{lÙÐÞr¦i_ë·~‹t:N§{ 2’ËËËù¾0«¢G’¤â-õ…^ 77—×^{’’>ûÙϲ~ýúåz½>s_©ªÊ¯ÿú¯ÓÖÖö@|Ÿ?üáSRR‰'$‰Ïþó¬Zµj¹‡u[,EØu."&`–‹Ýf³w^š«ÔõÆ~-ËMûY­Ö9ÃZÖö›ëعöÓæuÉ”Õ2ERuó˜R ;ÙÓ½@©ªJ8˜ UÌ‚|cŒNEü~?_ùÊWX½z5n·›Ó§Oó©O}Šòòò&±êýAhkk{àÈnôz=ŸúÔ§–{s¢¡¡áŽùEáßÿýßñx<|ö³ŸÅårÑÝÝÍ·¾õ-vïÞÍæÍ›ç=öôéÓüÛ¿ýk׮套^ºe?²,300À믿Îw¿û]Z[[—ûtÝAxþùç—{È²ÌæÍ›oy >H# áÎË{OðY¼ß‘ UÌ YœÃõ’N§I$¬Y³†;w‹Åî¸ürÑh”üà„B!Μ9“UÇÌâ¾CEB¡þçN[[7näþàˆF£·ä̘>æ{ßûO=õ/¼ðz½žh4ÊÐÐX­V‰›Í†ÝnçÅ_¤x*1lllŒññqdY¦  `NêÝ,Þ»8}æ,‹yQ¸¼^/¯¿¹WŽ‹5«W384ŒËå$/7—a¯¬C’$Ž?†’VX·v ùn÷‚ÛW•ó. 7èi¼ı'éêîBU59í=ý²,g šn0Ü/´·#"ÍM&&8vüÉd’µkÚ(,( sùêU’‰$55Õä»Ýœ:}†ËW®haž)1¬³çÎÓÑym*Ì!ó¡§ŸZpBc$åà4Ôºu””£ª*/]FQZVÞ¡Ô4TU% `µÚïêø÷+õY–3? M2<öØc|ô£¥©©)ë±ÈbYðÔSOQ\\Ì·¾õ-þøÿ¯×Ë_ýÕ_eø¹ðÊ+¯ÐÞÞ·?üaFFF˜˜˜Àçóñ‹¿ø‹üíßþ-Š¢ðÍo~“_ø…_àìÙ³|÷»ßåÊ•+ØívÞzë-^zé%~ñ‘矞/~ñ‹™6²xïcØëeÏÛoÓ×ßÏm|÷û? «»‡D<¢( zÎ_¸@0¤³³ £Ñȹ ÈÏs³¢¾žýÎ[R9=¾«×2¿Ÿ:}š½ûöÑÓÓ{˱46¬`÷ÃS[S cœ:s†½ûöÑÝÝ3kß‘‘Qö¼½—®în@#r¹\456pðÐab±Æ 7P^^ƃ‡ˆÅbôõ÷Ó²r%»}„M7 I+êëØýðÃÔÕÕ"M­3¡p˜7ö¼Å½öãY7âô™³H’D]]m†¹òìùóìÝ·kw}]¦C©Tò®Ûx?BfždA€öÆæñxøö·¿ÍÄĪª²iÓ&ž{î¹Û&œˆ¢˜‘gOe.‹,–<ÿüóüå_þ%­­­üÃ?üµµµóî?00Àßÿýßóᘪª*þäOþ„ññqÜn7<ñÄ|ûÛ߯jµòo|ƒ/|á 466ÒÞÞÎæÍ›E‘¿ýÛ¿Åëõòío›öövöïߟ-¹}Ÿ äB{;«Z[ERÛa·³zUëÔC˜§¤§‡†‡ycÏ[¬[»‹ÅÌÆõë0 øü~TeþšÌ±±1ÎN@9ìvòóݬlnBÖÉŒŒŒÜr,6«•„^ÏçgÓ† r&,3ìõeö‹Çãœ=Ž–•×™Hׯ]ƒÁ``tl e* .Kcãc(Š‚ªªZ²d8̥˗éêéfíê6œV«ƒÁ€×ëcãúuH’ıãÇÑét”–”püÄIlw&‰s&¼>/ׯÇáppñÒ%"Ñ(+V ×ééé½µ¡t+dCsCœ+£x###Äãq$Iâ?ÿó?9zô(8þæoþ†ááá»ÊTÍ"‹û UU1$ 6nÜÈš5kÁ³³³“+W®0<<œÙ÷ë_ÿ:‡-[¶J¥ŒšQý ¿ð (ŠÂÿñóéOšO|â 266FÓYË墷·—¿û»¿Ãh4ò¥/}iÙ«R²X8tˆD"‰¢( {‰Åb÷ÔÞtÝnÃåre\ôv› Ïà`æ¥Ë`0àñ rðÐaÖ­];¯+¿ß㡳«‹¾®uv¢( F£ñ&‚¥ùÐ×ßN§Ë”KjÇÎNf<|ôápA¯ÏG4:™1vö8ÈÚ¶ÕF'W;®qöüyt::Ž––•´¶´PWSËÞýû™œœ`ÀãAÅ µtWw]ÝÝœoo§·¯i¦ãS§Ïðï~7ãMPU•‘ÑQ.\hGDTEÁ`0 ×ëQ¹{® -T1‘%€º·TǬ­­Å`0N§Ùºu+ŸøÄ'ç§?ý)²,g†,Þ3øÞ÷¾ÇøC6mÚÄÁƒ ¬¬Œ .ðÅ/~‘P(ÄK/½ÄoþæorêÔ)þõ_ÿI’øÒ—¾D0Ìä5LãêÕ«Äb1w*æ;00@0dÅŠ‚ÀüÁ`2™xýõ×ùÿøþèþˆßøßXîS‘Å"Àjµ022JÿÀ‘H„ÀÄ…÷˜¿r#T(fÀ3Èö‡âB{;Û¶neØëå̹slÚ°¢¢ùÙRWµ´`6™ðùGغyÓŒN2ÿdH$H¥R³*“º{z©(/»q„³JöÍft\ëddd„ñÀ8‘H˜S§Ï°~íš çB?»y„|w¯¼úÑÉI zy¹¹˜LFN>MjÊcq#)T^^.E…TVVH$0O1íÖ×ÕRZZ‚ͪU·Ø¬V$I¢¦F#€ºnP©·#Ù¼Í5Q G‚Ùܤ /dñW…-[¶`·ÛùÔ§>…Õjåÿð)˜RMË"‹o½õögÆoüÆoPZZÊ'>ñ ^ýu>ó™ÏÐÒÒ·¿ým@+9›œœÌpi|ãß   €sçÎñÉO~’î©8îáÇù¿ÿïÿ›OúÓìÛ·¯}íklÙ²…ŽŽl6[¦¼pllŒ¯|å+tttðüóÏsðàÁ¬áð>Á4ã¥ËWƒÚä{Á Çl¾^ö×ÙÕIYi +êë9xøÃÃ^Ž;ư×K4Åår²kÇŽ[@UÍRÚ=~ò$ÇŽŸ ‰"";·oC–e<7@$“I ò¯“38uŠcÇ5(IÙ¹}{fÿήn‡)).æ¿^û1Ñh»ÝÎ#»v²zU+W®^åjG+ê뱘Íèt2oíÝK"‘ ¦º*S®™H$(œA µ¶­‡Ñ?0@yyYƹ±<´¥y%ïìÛ‡¢(4M‘Q9{–#ÇŽe™];¶ßqIy6T17ä¹(S§­=¿ßOg§fMN555lß¾Gy„¹²²ÈâA‰'øâ¿È‡?üa>ùÉOFY¹r%ßùÎwøØÇ>†ÃáÈäà€FHô³ŸýŒ/ùË4N©ÖÔÔ`µZéîîæÜ¹süöoÿ6?ü0¿ó;¿C]]ŸÿüçyóÍ7¹xñ"EEEðãÿ˜ÿý¿ÿ76l N#Š"O>ùärŸŽ,uµ5‹F;]S]MõŒ¶Ðé4‚¤MS‚R»y˜ÉX UUÑét·ôúÞÈÏÐP_OeE’$f>++-¥¤¸hÖ±ìÚ9k‘]QWGEyùMÇTV”S6%Yýð®LNNjã›J¢¯®ª¢°°0£ø)5ÕÕä瓜"…š^svíØ1«ßò²2ž}úÉÄ,ò¨Q\\Äsz†T2™ ëÔÖÔPRR¢J â]å¢L‡*¦=Yhžþù?ª®®žuRA@Q¢Ñ(×®]Ãl6ÓÚÚŠ(Š QQQAii)óƒá&†­3gÎðÃþ††B¡ëfX·Yd±PU•k×®Q[[Ë/ÿò/gÎ*++)(( ±±q–{VUUX·nýèG3dƒœœZ[[òòr>ó™Ï`µZ)))¡°°‚‚ÊÊÊØºu+k×®eåÊ•477#%%%üÚ¯ýO=õÔƒ¯¿ðA__@€²²²9½¦Ó¬‘¢(Þ²$pZ&z1pc[²,gž£¢("‰"z½‹ÙŒÅbÁd4Þ“á4¥µÙlÆd2Ínû†9ÌìûVÇÞxü¬ñÍØO§Óa˜b¿œ†^¯Çd4Î2nì7³ŸÉtÛи^¯Ç8ãœLe®1/‰DŸ£Ñ„ÕjË2G¢)¯ÎI9-LѨÎü}š©O–eE™7D1åôää$ÿøÿHUUU–r:‹,²XVÜ+åôRa||PUu^§»%‚2™LÙ2´,²Èâ}£ÇŽÓÕÓ(J¸órÙ±m;’toÉâ^Ÿ×ß܃Óé`m[v›Â‚Á ½}}sòÔiÒé4ëÖ®Á}õçÛÛÑÉ2 ó@¦þ–L&™œœäØ”øYuUÇOž"™L¸ÐÞΑcÇðz½¨ªÊpæØ R©‘H„aŸ—†úTUTJ¥‰F£Ë}Û¼o5²È"‹,î‚ °ª¥…–æfJKJxgï»ÜŠHo!E—Ó‰Ãa'7'ãÔÂÞºr%ƒƒƒë£,c0âÀ¡C¬›biœ ½ýýt\»Fo_W;:PU•ÃGN"ˆ">ŸO“¿ž-+›YÙÜDeEï¼»x<ž!vÚà kÛÚ0„B! ò󩮪dï»ûH$=~œp$Œ$IZ““¨€ÏïçÂÅKˆ‚€:exøGF¸p±]û›:ãoíí¢€¢ªtu÷ÐÓÛCû¥Kôôö’H$äJG}ýý\¾z5“72:ʹ)(EUQ•‘±QÎ]¸ðÿ·woÏMœiÇ¿­VËRëìÇç`ˆml /™fâ…`k'ÉnŠÉÅìÎÌÖNRS•«¤r“›Üq—»ü T%E%7lU¦R;©I<“8&ÀLl 0¶lŒ¬VæB–ðAÙ5 ϧÊýº­v»äîWo¿ÏïÅ¥(å$K±z÷Uœêr¹–Lv¬69RQ¦§§I&“Kz᪪255E}}ýZŸ³B¬Š®ûhhh@¡8gÀ²mV<½< ŠÕÁ`°œspãÆ ¾>{–íÛ«ÎØÚß_×™¼u‹Á…•G}^/©TŠ‹—.‘œ™!™LÒÒܼe•3$tŸ†õ x<gÎò,&''ùë×gض(Ø©µ¥…–æfÖsæÜß0M¯×‹c;\¸t‰[·n1L ðhMO4211Q¬Ððû‹mLL›?š[£©c¡Íãá'õõ466²áÉv £€Ïç%ÖÛKÀïçê÷×xn×. ¸l·[UyjÓFâñ8Þº: ¡POmÚD<ž Îs f‰{»gÇÁqΟ?Ï‘#GÈf³øý~^yå•r:ÞrŠ¢Ç9s¦ø\«4¬år¹¸víÝUVeBˆ…ÿýã§…›»»Ê#«QWç)'#–¢(Kò ¾þªïœËDxþ¹Ýw-íØ°'ÛÛËÛ;vpiô27''˓㉷¦¦ÊN.—‹O?û£ÀS›6¢ë:Ÿþé3≹\Žp8ÄÞ={ˆõõrbèϸ5þX ]×˯qelŒ‰xœÖ–ÇáÄП±‡¾ž¼^/[úúø|hÛqèíÙŒ×ë%Ö×Çç'Ú6Û~úôVþòå—ÄãqÚÚZËym­­K:N[b}?1„mÛôtwãóùˆõõ–Û6wwá÷K•ÊÃR±³ÄívsôèQÞ{ï=^xá‚Á Ùl–O>ù„7ß|“¬¨²(Õ=Ÿ>}š\.Ç®]»ÊϺ:D}}½”c !ÖÔjË1‹Á@9 7S^IDATlÛ&\¡ü¼¦ibÛöŠtÃùùùr6N&“YDx~Åòã,ßv‡L6‹iš„C!TU%“Í. vŠF£åŪLÓ\QªhY–e•_3“)íwçoU±-›Å,¬l3 ƒP(„V%Á±ø³Âápùg³Ù,…em¢TŽYzHuE•rL¸³:æ‘#Gxûí·yñÅùðÃyýõ×éïïçðáÃìÞ½›p8¼¢Ã¡i­­­;vŒ§ž‡ !Ä…¢(„r¾ÃÝb_?ƒÁ ÁàêR —gùvi”c±` @pQÄsI B¬L­ WîW±-pm•<Èï'V§jÇ!•J111A__ï¾û.‡btt”W_}•ëׯ3;;K$YÑq0 ƒááa¶lÙB4]ësB!ÄCRuì¦|ár¹ƒåáš{ ù˜¦Ihaˆkµ³…Bñè¨:âË嘜œddd„7ÞxƒŽŽöìÙñcÇhkk£¾¾¾b8†®ëìØ±¯×+)„Bˆ÷Ý*#‰djjŠwÞy‡“'OFyÿý÷¹ví$‰Tœ922ÂùóçQU• …H¥RRŽ)„BüÀ¹*å1¨ªÊG}Ä©S§Ø¿?ƒƒƒD£QlÛfppdzoß¾ŠëV(ŠÂèè([·nÅ4MfffgllLf¥ !„?`n˲V4:ŽC,c``€ææfÞzë-šššpÇqª@Y–E?§¼lq.—£««‹×^{\.G"‘XëóBY‡@ˆ¸5meÞ™eYìÛ·þþ~t]' Þ÷!¶mÓ¾:ÒÔÔ„mÛå¼óÎÎNR©óóóLMMUÍZ·‡12%7Q‰ËåB×uÚÛÛÑu½âuÈí¾¯P]!Kîj׆†€¾Á—^sùkÛ¶ßï§££ƒÉÉɵ>wñ+ 5w,EAÓ4y,&îÊçó‰Dð-KjBÜ[ÕnõÿÕ'6Çqä¢.îjz:ÉøÄDÍ¥¼ŠËÅúuëhkmy(‰~âÇ©‡/×"!ŒŒÇ‰GŠmÛܘ¼Ivn®æ zq™Ý›¬[÷~¿<²Bˆ‡H>މGŠ¢(è>EQÊ“qô Àç+®3 !„x¸dÄA~¿EQÈd2ä ƒh$Ru4>—Ë1wû6‘pUU±m›t&ƒ‘7G–N·,‹™ÙY<šF( “Í2Ÿ›'Ü÷üž»‘ŽƒBQÛ¶ùýþ€[Uñù|ôõöÒÝâ›o¿å>þ=¿ûíoinn*O²übø+F¯\Á£iüâågv6Åñ¡!lÛ¦­¥…]ÿYNÔ ìßûŸ'w{žúú(éôê'yJÇA!„¨Ëå"Öcrr’å»óøË_¢ë:š¦‘LÎ`/Œ6 üºN"‘À0 ²sYæææX¿náp¸¸’ô|®âqE! inX芨ªŠiY Ÿ!ÖÓC8Âq|>/Mâïß|[\÷DzQU•ñ‰8¶m×ç_>ïǽ.U!„¨…¢(ìØö /ÿÛKtuvrõûïñz½d³Y®Œ]åÒåËä Ó4™N&¹qó&ÿý›_ÓÕÙÉ…‹ …B$®_gvv–|>O`aÞC%w’q‹“MÓäø‰D"a¶o{Ã0p»ÝìÝó? ÐÖÚÊ™sçˆõöð_¿úO≩tzU™2ÇA!„¨išœ9{Žk†Á®ÁgikmŠ+°þSÿr·sŒ]½JÏænê£Q>ùã§Ø¶ÍÏvìÀSçá³ãŸsáÂEº:;Éÿæz{z–Dz,FNŸæâÅQnßÎ Q\ gÏý ííd2¶Äb$×yæ§Osiô2ß~÷O<Áæîn|>/§ÿú5ãñ8ímmUUW(|ð³wï^|>Ÿ¤í !„÷ÉqÒé4ù¼?à_²¨^n~¦¿ï×1 ƒT:·®Ž@ €¢@vî6ù|žúh”‘Ó§…íÛ–L^t‡T:M>ŸGQ”reÅÌì,¦i¢ª*‘p˜B¡€®ëd³YŒB¡¼Ÿã8åêH8ŒævSËÝ^Q®^½Š{µeB!ÄãHQ”%IÈ‹?|ë‹>Œûý:Žã ië×­+ïë8ðßépôÇb¨ª{EŃ¢(D+§ôZ¥6ǃã8ƒÁEÇ(î[*Ët*d><(·ªªåg2ßA!„¨Íò{èâíjß+m{½ÞšŽ³¸­Ú1ïÖö ççV…ññq´…!!„BˆJ’É$ÿ+`æ@;'ÁtEXtCommentCreated with GIMPW%tEXtdate:create2013-01-21T09:46:17+09:00 à 6%tEXtdate:modify2013-01-19T16:08:03+09:00ݾ$¾IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/evaldlg.png0000644000175000017500000007204413070106167016752 00000000000000‰PNG  IHDRÎ~æýbKGDÿÿÿ ½§“ IDATxÚìwXWÛ‡ïYb/±wcÅÞ{ÆÞ{/1y¿7½¨€‚ ¨1ƖĨØAlXboQ±w±W¬€Q¤³å|ì²l£)Í;¿ëJdgŸ}Î3çœ9sÎÌT¨æ`õJHHÀÍÍ >¡GAûöíéÖ­Û;¯Å$)å‹W£Â–ãG“‘œÝÓ‡pëñ#´ª$ZöEyg­_Í•„Ö6ÃtãÅ“[lÛw•äÌ£úÉ=@–¬,“„*) •J•ê³^ÖZ¢¸»»3gΓmãÇçÁD’$<==ñôœÀOfMõL÷w‡÷Ÿf‚÷O†Ï3ÝiúƒÅ”@üc<ÙÎЮ%;zÄÞÄcÁA¦~ÕNî²då´Z- å2ÇZL®\¹²¤ÐÒª”»* Uià “ö¸¨áо¿Üu€6]Ú°vÏž…³yÝFZÚ’ŠUêèöÄ)?R¢Æd“õžëävù—-…©^‹ŽŽÆÍÍ [[[lllpppÈ’B£%'ÃJŽŠC iièøa+]’¸‡‡˜åw‰Ÿ:•@t”sç/òìMUŠäÑ/¡$æNšÛŒ_LvRÖûÙùd½ÿrÈe‹V«KîIŸ›#x%)ÌÔú`"„ wîÜ,X°À°íÛo¿Íšèœc g¥8g‘¡NW¼tIœÊ´!~é2~»t—~™¡·èŒûO¿áõóÙô§¾òB)„É›¢dÉ’•yr<¸r I?“T(H€R‚¼A+Jlãâb­&:t`üøñ†Ùˆ$I<{ö, ÎFдN#,^†14®ÓDúÓáÓÇ·që^On]d¨ë\ÊÇ\e¢÷¯Ô(S˜¯3ø§,ñÊC§–Äì]ObÚÔ®UKî ²d½ƒòÛ«)ëRîVÃw©Lrå ,d}0éÚµ+]»vµ:Kx—µ®$AýŽ=Iy„,c3“FÍzШÀpÝôر:3Ýj˜ØTóô³¸äɉ,YïÁ5“Ôf ï*)O)ÓZ Ö·É ,KVNJNX‘%K–<˜È’%KLdÉ’õ/ÒËhŠØØX¹&dÉ’õN*œÇEåš%ëe |ûß“V€"üEDNVy†$³Û2ú»ÌøÎLQOïpëÎÈ¢X?›ŒÕçÛµKæûC:ô/,Oó7VËÏØÀ‘üÈÄ¡}ç‘$éê8­Å; r©Æ’…ƒŸò£ùspô–8½g3gGáL yK5¤÷§ ßK’DÈÕ˽p ›¸pïzÊÑ¿æ²ëB"5ä"eአéÖ¯ “(ãRëW2c–;+çMGY¨4:Gl¬Õ¡ù¿’$Yør)fÇÑ‹—±‰ eé¾Ù:'Ív1ÿ7pÙ/Üx À}úw†6;¾c#ÃcpÔ¾¡Pùf´(ÃooQ¾°3¯ÂîP¿çOÄß\ÏãH"^¦ÙP*Åžàw#›Ý>çÚñÝØÚ*Ñ„ŸæAžOÚ´ǃ¯ ½yŠƒ‘Ú<åËLl<Æw!æÉ5ÚtýšsÁu1Å>â»éþLpûHÒ+¦¸þN¥ªextë>_yy°àÇ)|ÜÈ…øØXZöNYgðšèN™ê•¹y=ï“ô¿§~¥Öœ»s!0-Kİ|ÅF³x:§úȆ®kñš4…2Õ*sëF^>9´}9_)‰x¤«›Fe³÷2ÑÍM\»vMlܰA>(²[ó|&þžà=W!ÄîÝ»S ´B<½sQÌ]±Å°é7ÏɆ¿Ý<‰Ð >âDœZ­Vˆè£bæ†P1ÛÕÝ`3iÂ,Ãß{ö챈á7ŸßR-O«Õ !„Øì9ID>¿žs‰ù3] ?›è3OÕyñ“ŸX+N\(„f6óÅ“uÓLbõZšy› Äã€iâdœZ­âMð^÷DÌŸåž#6ÓVݪ—Åš€ubͦ½&u¹ÀkÉg_>ó…B„ß¾ æ­ÜjR¿&mžŠ¯[‹g‰BÌ™2ÇÔnö£xŠ]s<ÄC{>S6mK¯)ˆuÓ]­Øè¾wws3ø »u^Ì_µÍè÷f6êP1{Ù6±pê/†ßLž>]œ=¾Oøl*!D GrßBˆ1uæ.1Ëu–q—W}ÝÅ©x½Í«#Âkõm!„Kfúˆ9> R-ËZÌ'÷oë×®w¿2ìs²®,,NÇëyDøøÝ1©EVÓˆÏÅÑËËÏ‹à‹çÅ•à‹âúÕˆÿöîÚ.Î>)Ö¯['._¾,<<<„âMäëœ]\Å:Þïgåf’·BnQÂ>Š«7 6š‰©_^cÏ}š8èLsnŽúòFúöjÆÈ/]ùaü`Z÷˜æôN¥R¥Z^ò(o£HAšÇa« EŠMIRtŠ•8¹h%š¸0pà n²ûz’™ ìy˜Û$V§‡»3mã#Øû07@’änãÃ=ØÄåŒýã#¬Û°‘¡0´KYf¬º˜Òf€q_±ºoÝ¿M1ÛWü¶f‹ÅYÔ¸]Œ} !èÒã3ŠØañl£Ò$^ Ÿ~çÉ´‘ý˜?.}Fÿ”{f1·úRkÀ(¸{[±‘ІQ¨voƒ¿ÛîPTÉï~[õ±šÙØç‡Ñ݉3ÊL¿uø5št`ÈÀn|7q&ÎŽJTú¾…6‘FÉ2±yÛfæû¸qû5ì ±§Q.ý«›óµÄöÁAöoñ¥Íç“PÇÄë+Ó²,“x€»“·QOúÊÊ•õ»ÿ¾ s$äo‰íƒý†º¹uÀ—šFeÝ2'_þ¼9:–8 £D?álÕ¦E‡þºwŸ¸/ ~“šø®ö'¿ƒWòÑJý- IR£vú˜•{Y¹p.ÿýƃOêN5£$‰íkýP98r6ø,þÔªÓŠjUJZ”Ð}²;3=gP¡FEb&ÓÙäÚçmˆ=V8s=&ž¯Z×DAíß²oÆ2 í_¬p¦„jkŒT‚"$S6q"7%¤'F6IÄJ%()æˆÆ®Çö/Ǿ`I$I¢k]ž\¿Ê‘à+œ½|–-[·¯dÈ n8‹¸_ÚÜ´Ô×ïT·…–çIJÕWjr2.CäáJàoô÷ñ£Aq{F?8Î\¿Ó|;´IÏn²á^~ÜÛåâøÊÙVmf¬8‡›ëwßɱzÅjnc®­:`ì(`“›O~šÈ¬©3)_½"Q!‡)ÐȃÁ ë=zãí±”ŠRœ®Ž% ‰Db£BÙ°GCë8.^»ÈÆÀíôëc½ŒãÙz<ŒJìäjlUË`ß:"4ÐôÓ7)'xŠøô›îÀ­½}–ÛŠû÷ïçè`j¼<³{bñ}Ô³W†Žò"!€¦û2vø>iP’:Óit¼üN"IplÕt:ÿ÷S„6}>m·ÁCéÝ«7uª×aР!T«RÒjy'Dˆ\LôœD¿¾ýxü,/_´pä±mÊYTÊÆÐNåYrä.’$qcÿoTê<ÔÌ&”N£Ú˜ÄÚvt§LÛ(Ãé4²5>þ§$8ºÊ›v£;ñÐF“#6mÇu¢`…’ôë×¾}{RµFeJV«ÁAƒ¨]­6½zö2ü&¾œÂIˆxR¿IÖßDŸš/s8t€Rr[kQ:?#.ê ›äë` 4ZALØ-~Ûs÷Ïú Q%YØì­ö½U”a»±5=S§PcÑLð˜H¿¾} ÈÇ— H¼¾µ§Ú­èýÅ'Ì 8­ôáÓIÓYºØ‡!C†Ð°vCúõéfevmÏ€öåx^À…~ýú1H_oŸ Âà!C([À†žã;ðóú³HÀá•3è0¾'Ñ¡7Y´?·q½³ô¬ôݷߊ1cÇrýÚ5>*R­Úfëí3IJ`å?TØ2쳑Ø{÷ì¡S§N¼ ¿ÏÚíc'ié:p,…u£j ïb4Å]èß¹)7Ïäô'”®Þ„6õ*ÿ2 ÿm°EEûžC)žßI’Ø»w/;v4‰ãäá“4iÝÄjyErKœ8t‚¦mšòäj0[bà¸o(ä ¤xV.õGCÇ põø.„<£hņ|Ò¤*gbcÜ2‹â3n#Ù1t¬®¬gpæf(¥k4¡Mݶ‰`ź=ØÙå¢×~8àMÛ45j_S_‰á!l?„¤¥ÛÀ1rÖ]¨ÝcÔæXñe¬SGNѸUcNü}‚¦m›±¬\ºdϱÃÉغŽgqló” ×ÖlY·µ”—„$ µjצ¦‹‹…*ò’ĵÓû9w3Œ²µšÑªvE¶,B­ÐÕMí:up©QâÎ_F¼àƵ«äÍ›7•¬á‡,Xˆ{÷RµZ5‘\]]Å!Crd0IMÖ:–Õ;0o‘ lm0ÉøÀ'Yü-+gÚüCæäCï;o3˜|Ó#ŸÈ‰,¹ïdàš‰Üô²dÉzW%$Ä˃‰,Y²Þ]Žò`"K–¬wW|\¬<˜È’%ëÝeŸË!ç‘Æ'«ö NÂâÆ¸™÷›Vy§™,ã­cýl²ª}3›€™fB\ºq¾C™Å`-Ž·éoãç-;r¦ëý]¤UG‘£ôèäç–/^ƒ [†9çÞ•`‚.\ÂÆÆŽðÐ&Lê×,õÝ€¤°¡ßè1äQÂÍÓû9¥.£]ƒÊ Ž2µ±±~KÎüVÕòô· /ÙÉù/ø¨B=:7wbY¾Øv ?ŠçsåÚCÂß2qâ  n˜ÇJ\†mÔ’=Ã>I.½ÍéO(S£)mëœÃ6R:íšœœgê+ôò%Ž^ ÆÆÆ–§aqüôÓØ ô‰ƒ›×ð ¶c†µ59@$Ibç†eté?€K‡wpñá ŠUlH§fÕ9ñ÷!î†>A«VѺß(Ô!9vñ2 [ž…Çóãct sKüÑ(ì:n$\=µ³7ŸPÖ¥¹þ9‰kxW’ÑÃÚ°mÝjÞ¨%$»ü íßÕÂOhðEŽ]2++)ßå›llé7zyl¬ø1³É­Ð÷јöŸ C›† !ì:'îÄÒ®UƒôIâêɽœ¹Fy—f´®÷1ëV,#Q¡D¡zMéš}iÕ°D–Û ¯ÁÕÕ5Gý<<~2üýÓ“¤/ã$¥]kgo‡é~3áÃöo'NâåQá¹æ„Bˆc+'‹‘VlÒHô»zájêåé·Eó¹'„âΡEbýÙXáá‘’¤8Ñsª‰ÏÉn3ôûgfóìˆI¬Ç^dÞfÒ´éB<=,¦ùŸB´r²8þBÏI9bsì™iý×Û•óWLÛ×Ü—^;×þ!ÎÝ 7Ô¯µD¿dZ»Hœxk–Ú¦Óõ ]¢s—¯…B< Z#|†!„¸yð±ñÌk1Ëõg«>wøÿ!Îß ×Å8ÕÕàÙuº¡ ¯€ÓB!ެ˜,Ž?âoÿEâÔ£”6ú¸‰pµþWQ÷…×Üf~¼­–å9é{ÃöïÝ}ÄÎ9“MýÌßmbó[ŠŸ¹³‹E3 !„x~댘ï¿[üá=ߢ ¬}Žp@ø¬?#„âðŠÉℾ 5‘ÄÏ¿ù¥{œf6ÑÏÓÓSäø2Ç4YÉ3†•>c9÷܉rÅ? ˆmý4MÇ&?»—1eh„€f#<8¼t·©"šSç;S-/ÙjÕŽ;ŒoY![Îýþ”ÑMäK¦ø[èÍ)Lm’J²{å“X-ßy›„âìZ„ûàÆ-FLæÐòÝ”ÕæŒÍ¾E[Ø·#›Yü«'W_¦ÌRvlÜaRÏÆ¾DBq–{å 'Ê+’¡Iüæ];xqa?kW/cÓ¾Hº¼¾MÐK;ÚÕÖùõÛu—1ÍË!„ rÛ/¸³k5Z‘ÄÁ=ÛÜuÌàÏ×{,—^:S¶hÊc›ÜãÐÆe—ß1\êÎþ-GºspÙ.¶ìÞųóûñ_íËæ'iÛ¥5þ[yFà¦Í´ïÑÞÔO\Q«eËUÈÐ÷r‹Ü´ïÝÙÄO‡nm,l6.™Åç?|F‚>ùñ©]~¾܉DµŽ .%=á×?W²iãzúZÌ·.=ÈÄþ @«‘nXºõë+t=™õjg˪#Ç“d<¨€5j¤«/“¿ÁO<ˆLŠ@HhbÙ{èOµvzʘl[ؘK’$þò[ͦÀM_ Æß ×n>¶(/¹QÆô©Éœ­$‰S»æ#å©CŒäh6¸­¢²>çÈÄFŠ!Lä6‰Õ™°LÛ8H1„ g#[œ#6‡lò:¼âø²hÔŠVªÍžå<¾v…5þþß&ps kÖþ`âË]vóÅý«áü4ÑÓêÒ3âæUVûù±qÿY”Õ¥{Ï >†KGÏèW‰¹«N3¾g;$¥î ѳ:ó·_B’$Žý5mžÚ ÿ|m;õ }•Dæ\FÁX7_ܾÆO“tÉŸ±emKÑ„'׿Ð%ëåV<Å®˜.†!ÃÇráÈ |\mLç/^âEt… Û™øIîæe=¦ë—ª(ö9‹]Ñ"&~òå·7±9tžûçRµó×älõûêR¶¢ImðYJùR…Ñ ‰“»tu´wíüüÖð RC¸p4Ú'{D8Ê|.ìØ²š v·ømÓµ,?¶•9=˜¤…Myl^·D/‘W7Ú»Ïú…Àuþ8—ü˜þƒ\h'†qÐÔQ‚˜£$–nƒÇˆQ)6ƒkX¤º@èõP† fzÍ˨<€¼õ{ÓÏé$ë7l€'ÏéôM}ÏÞb»þ@8´ ý&§\7pŠ5±é\Î4Ö¸rqù-s6¹%:•åd4q”àMñe?EñpQŽØ¨+t¢¨*”þýûëvZŸ‡7¬º wžÓ§wC½iŒ÷?·éÀQ<ÏGVÛ¥P• ¯’ÒfU ¤<¶-lt£´êÕUò¶' €³Ág ܲƒ>½úÑóÚ ÖoÜ_Òe| Š;éÛ¯|;âW¯D’j¦”Ÿ[7[P;ÅÅhCDzQœŠ‡Æ¼>‚ªü'T+RbPÚ±êçÕ|?ÅC¿¥3Ó§®$Ÿ³±ÓórrYî3f²i?¹‹WdÀàš,öðåûY>?žnâidÓH-^ÄErt37lm9}ñ4mov¢j• &þ"‰O»tÁèß¿?B:NéÓŸTHât<4ràÕÔå?1|Wªn7¢vnª¸ƒIzxPI’xpö;/]ÃQ¡¥˜KòR–OÚ·`Á/ =m6Åì `¢+wªUæöõP¼gºê*ÐÈÆüB«ñß±1)/ѶVÞÔo§2å×)”®Úˆ»·p¯TKj* ¡V}]ì"†&u›ðËy˜Ù&¥ó76³)öI}V˜ÄÚ‚3{2nã(bhZ¯9%Ú×cÕD7nWû˜Û7ÂñžÑ’Ó»ëæ˜Í®ÅYá·U<=F!¯•ºhTÃÈWýæ<8s’Á×qTh(Q³”Õ£¹*Ô¬Ìâå+±UÇQ»± S¿öÀcþTFëO÷ÎߣO¯® LõFܽ½že[QÛ NÛÊ7„Þfð¤9Ü?s‚]Á7tå×Ò-«ëW­ÅÂÅËpÐÆÐ´~ J¶«ÃêInܪò1wn=Å˧o¯Èâå+Qªc©Ó¸6½]œqõžKµ2…xþð&}ÿÏ›×g6ü4«ß‚û§O°ë²iY`O‡¶Íø}Þ"FOE¡Á&~|ã bã9‹l õõrÿÒ}“$)I÷–¾S¿Ç}’µê|Lþrhß žÉ¹±úhOfLrçf•JܽýŒéÞ­ð[8$ç|<p›®>Y~|çx¢Ÿ0¹/ û”œô•VRTÐþ Zvhi˜VÛ%ÿÎØ&ù{óD¿ô’°Œ·…Þ¼‰ö£Ò”Êï¨{¨$™Ä®»h.™$"¦fcríæ´1©'ýoÌ_±hmÿS» ”Z¢Ÿe›è|¤öZÇ'7n@±²”Ìç`ñÛôÚ7Ãû›A›ÔöõØc4oß<;kl“ZÿÌèwoóÙ\o“è—ãËœ´ð ií\Ë-SµIÞ––µ2ÒC–¨RÅø ‹ØSò¥tmR/ó´1z‡nz2¬x IDATûŸéþa%ke%ÿ[²jÕT›1”lÖÕ[jjÞ¾yºñX³IkÒÛ×Ì~Î ÉOÀÊ’%KLdÉ’%&²dÉú)Q¥•Y²d½»ìm(þWq†²dÉÊâeNξV.‹ð ¤=š~Ié——1ÄczdLùº£Œ}}ñ€µ«Y¸:Ð*Ô/:ù‡îtíùå¤lÃS®Žo,‘ŸVËJ;fK›1&XÐU+Öf z€¤È«¨œÊ°éé„DKö2²ú6~³'œ¹¾åwúzûÓ¨„=ãžœbaàU“8d‘ÒQ’± )¾µØ8=µzµÀ j ùùµ™Ÿ8õ[^¨^¼c8SËš$[WÍ£åH/ÊæE¾z–ÈOMŒEY‰ÙÜÆ :¸;6ô“Ï{óJ7ˆ†] ¤`ƒ¬ÏÁËÑD¿¬Äƒ\¤ –2¹©oÜìÆƒܶާ±lœ‹1°{[d<èÛãA K§ÈókêPOäLÁ‚êê6 šÜÆÆ1˜bAëPº ƒòSB’âLñ¢"†õ~›ˆML¤c¯/Ë šíCÅbùѼ~Âü[éÒ}$U*æfýŠe$(”(_QªVœ¥[\»ñ€ð§O™8aB†lö®&4¡#‡´I 4:„ýg_Сm#ž>¼Î΃§Q+œ?²çÎÊŸ…³!O‘Â8–©N¿ÖõAû†åKסQØ1dÜH’ûªQYÇþͽ°P´j­ú¤œ³"ÍY’$.ŸØÃùÛá”­Ñ”6õ+0¡RâkÊÔÎBLè?ŠõðLjÀI !<ÑŸ“tèÏ•s§ˆÑc¦Ã"îœ ×íó§Î1)ÏZ¢_2ÒÒjyúm/Ž®K‚txлG‹ugb„‡ÇÄ”$EÏ©"ú¤º6âéa1UÚ<¶ÚC}!2m3qÚt!‰éz„å±UStQ#gvÚ…§Ž½|þrªxЉFxÐþ¿ë™i$ú¥øÒšä¡Y3Wœ7B”zÿÒ‡¾ü¯®ýðý‹ø4‘ÄÏ¿[¢0==RDÓ³9è÷‡8õ0ÆÂ÷¼_–Ðwo뾌º.¦ýv0C~„â÷˜Ö]*¸Qã²Ìñ§æùz˜ÐûûÅŒ guõ¸rŠ8þT·]õ2DÌþÃ?Ëý¦Lžœó‰~¥T)¾(’JZ\X9cç_8Ræ£Â±3BJù€(š›ÂÇ%?î,¦ÌË´'IOLkº·kó®TËK¶Z½ó.ãZèð Z~ƃƒk)£I‰]J*ÉúCÓµÙ½*ˆÉzÔf³a“9¼bwæmгkõ1Ü6ÔÙ ŸÌá»LPœÙis`ñöîÛÈæ-[X:o*W"RêuçÆ&õlî `¹Ï8.¾t¢t‘ÂiNÞS|é zãÃ÷©k”-_¼TnÎ\¾ÍµóÇ)^­2϶ÿLL±ÊlÞÈì鳈“$´o®Ñ}ôdê×®iRÆöÞ výéÚlÙ³›ç°f9ûN I’Ýùý8º³B%ýïóäF¡Î˜€O°zÕJÂ"(/L±¥€EYB¨tøÓGõýçs¯fó¦ üæ¿ÙbÆ·Å÷o&ö«¯CŸŽpå ïÔ¯¯Ðk¬'õj»dÝX…"篙$ã#uxÐX«ýÈIK™üÕ&Nò 2é%ZIu {ŸòR¡ ÉëJÌñ‰Ön]ýå·šÀÍ_Æßßk7žX”gÀƒö­Åœ­çuxÐóPä­kо”bÕ¯nº6áfèO'ži)–§8Ù(qO‰Ë!›¼¯9±l#j•Š"åk±oå:_»‚ŸÿZ‚o³yËfÔÄW2Ôu)î_Ž`’ëT«Ëk¾tK8æ;ƒ^?M09äÿ¨8ánrûA(ó;³ùôk|¾L¯^½ùqò~™ñŠ<ÕÙ±e5•î±`ÃÃïo'@%;Ý ]À¾x=ºõèΠa£¹xô!gRåÓ¯°”J¥É‰j®ÛB~úºmüè0¨ßÎù…á#Fâíý‹É±‘Ü/î;dQÖ°düiU5¿³ÁÇ—r¥ ¢Ñ©Ý:¿{×®Á_ }&t‰)˜Ðg(ó¹°}ó**åºËo›®~˜×L´ÆhF'mš×3ŠçÕá$ÝfÎfóúœKT¤ÿ ·Mñ O®=aÈ¡6Éåä­×‹þŽ§Ø°iâÑ :}S¿go6A›**v ¿*m›OËÇr<š9I}„„òQÜ[˜9›ÜЩl'b¡©“QGH(ÿ)Šû䈦b'Š&=IÁƒê5´º /î<£w¯Þ†mj<¨iýÍSÄj»”ªîbá+¹/œ‰|ç`z]óÅí§Œu’„‡Û|R,·!CTHÊ”½âµºµu’äÂÓƒ ¨Ôg’ÅEÈÔl$I¢J~£ó­ÒžX›XnœØÆm[[Î^:Û!T­Rž úÐù«i(õ¿K˰ÑÍ@Ê—Ôõ·‚¹òYÖ][âÄ+«eä-ߊ¸5~Ø ¢cç.8ý¬aB+ª9 $ÄËCh*v0|W²N¢vlj|ˆ`¡y½&zíRêŒØ”w©Ä’å+Qªã¨Ó´6.u›âRWñþ¢îà^ä1”°Ü-‰Û@bÝzԬ钦ŸºÍjƒ&œ?}wb§ÔR¤ªn9Ø Zmn´yý–¸Ô¯Kɤ,þôΆLœM9ÇLvóÂ¥ÖÇ,_‘võëšÜª6j 3Ýܹõq%îÝyÎ4¯6ø-œÊ9/ÏÜa„›wÖÝ\ùPð Ç¥yû©¾2ÐÚÌÞ vóšJ¥Š)]š1'PiùOÏ&Õ;X©Ä“¦Yͤ…ÍHÌ™©‹Œ`B3›è·iÓ¦Ú¼}  4%KÈË ´x•ÊÆ_X==šÁ~‘F»¦µ=-Û´Úüml2Oš6¤ß™‰ùmê"£ÇÌ{ûК,Y²þ}’ssdÉ’•%ŠŽ~#&²dÉzw9;ç–Y²deäÁD–,Yâ`’ExP‘y,df˳–m™^¦ñ ïl“Z[Š fãZëqiÛˆ·ÚßÌÔ[Fð ™µÉl|ÿJ<è©=œÆ™r¯OŸÎ ßK’Dȵ+¿Œ"&”¥{žsxëömYÍÃ×KJD*PŽ¡ÝÛýä­:Ʌˇ8²s^)yù0˜½hV!Wª•l‚µRž¯øš)®¿óqõ²<º~—ÿóö$/°yů\¹«aŠ×H’„×D7ʹTãÚ•ûøÌtçÄÎ@.†ÇàD4yJ6 w§Fooó4'íò•nDÏŽ ô6U¹qõ!^3Ü8¾c#—žÅ刵:´†5÷U³D.Ž_º ož°üÀKmžf‘$‰#;Wòè• /^¦áÀé4­ I’X1o:vE*‚&‰H“¿Ö=éylw‡O?ÃÝóŽíØ@ð³xµo(X¦1Ý;ÔI2±ñþq •›Ô">&†–½‡QÆYà5Ƀr5ªpãê#¼f¸Zø©QÌŽãÁWQXu(Šƒ›f±iõJTöNüµj!ã½u¸ÍŸö¢ë>8–©JïõôäÄQ¿R[ÎÝ9 ›—x¸ýÉÇÕÊððæ=þ;݃Üf6i>H’¯Iž”­Q…[ן0Ý{"W¯DmïÈ_«~çsŸ´ªýoǃêq’ÆxÐß='pÉxÐYK·¤Š…ô˜¸ ãxP³òRú{í;·-*!~vŸ-„âºïdq2^osLx­{"æÏ0CL{w› Ä£µÓÄ©dªã›£Â{Ýc ¬gvÙL]yK¨"‰5k׉5›vgº@º<—a<¨y[NuKi«9“S2ƒ'MÔeÏF\?*öž¾%æMkþœ /ßÜf–ë,3”¦»¥©B¼>ëZõzó¬²ÓÑlqïyœ!}w×B‹}Y2ËGübŒMÇ&Ðc’xcÈŽSgì´êçä¾-býÚÕâÖ£H‹láËK'‹3&xÐÛB!üý"B^Äe9tÊ”)ï!¸óà%Þ°`e *Éñ¨^^òòÓØžXH¸û÷2ê—æ´Ïü‘{ãò’})m$ ¾cÐ&<¦s÷Ï(¨LyIþž;çÒvj†ÓÃ=HqfèÏG¹ßÝ&F°ïQnåJFv6Çñá^\fvÚ8<9ºõ:hC;—gƪ ©Ö¥)ÂS—{uçá=JØG±põætñ Æ3”;}©;xŒaµÓ£K#Æ|íΟ¥]ÿ@$ËŽEðIà h¥IÝj•…M©²EÙº} f¸só•Jy[àðp¿?p÷Ñ}=æT‡ìT¿¾Ž&w9¶üéÅÝ7ºýzöò1ëüX GîÛâKÛñ“ÐáAÓ³Q*“û ŽF¨ž[ØÜß¹˜ÿ}ºS¹zeJV­Î ¨Uµ=º÷`ð€.&¾lœž’aŒº|mµOª\ÁêALèMî¾c@a?x\צڔ—…h5*¾pŸGßž}è߯?ë5¡R¹<’¢jlÃ?iމMµªx“HDÞØEîÚ­éõEGf®=…Y9ƒvc;™øQ:?7Ù—j²3úe´·Y¨Q{ÐÆ’ ÿU„: ¤Ê,þÓ‡Áƒ›àAÓµvü4eýúö#,"_õëhbÓ·w7zµ,ÉÓ|ÕèÓ§êê¾Ã€Á 4ˆ2ùmèñù'Ì^w 8´b&Ç÷ :Rï“‹›(Ô°]–Ûÿt•ïZÝkÇŽ°Äƒ>½¯C#JºômÀInö]‚¦¤ ý:51ø3Æ|þµáO’Ðá]jÖ¢VMÝ« ¬ýN9EãV­–W8·Âðý“«ÁlýûÆ}E¡\)¼tß7$nû›Ó7B)]½­ëVôû'Ù2dÌpìÛoi³Úw-j…ƒG#póÜAÎÞ£tÆ´ªSˆgµo@ÎØÄG°rÃ>ìíìé1¨¯jÜɯå4ö•ÂúG°“´t0JçLºmߨômY³Vmb#¢iÒ¦ qOØñ7v’†öÝQ4Ÿ½¡MÎ=Cƒæ ¤8Vù®C«°gÐè¡„h²Mà ¹Ä©+±ÍSœÝu¯P¼qö çn†QÚ¥ ­jWLý$„Ýcî ì‚.ýGQØYbÿ¶õ„¿I$OÑ*:ܦˆa£ ±‰Itè9œâì eê)#6À£Ë—Ø~äÆþ—‚F}ÏØæìßÛy™HÑÊ5iæb‰½~æçn…SÖ¥ -kWdßÖu<}“DÞâUé¡ħ¦·Iô“ñ é•‰Œý'ÚüYïCß{›ÁDƃ¦W&2TÖ?Ôß?°¾'?+K–,y0‘%K–<˜È’%KLdÉ’%ë=LÞšÖv«‰~ï_‰~±Ï.d§HÙ™“6o×ÚiÕcª¿ÉLr[&Û4õ>À[÷ËŒøI;+õÿý8Õx³!ñïÀƒÆ±|±*l6~4f6÷®”Œë|Ëĉã é¾Ë7‚†¾£Æð kÍeðßP6I¯(^£/m›”L#)íòô6—ïàÒà —«K—–5õÒ›]‹â“v ¾’ãHÙ?Ô’-C?…£×NíÓ£?Ó¾¡ý™1?=*Rgsõä^ÎÞ £tõ&´kPD4Ë— QØf¿MºíšŒ1ñvù’ö$މǦÓK$ž=ºÁާPIN|>J‡×$É çÙÖJ ~õXE• à«GŠ*l$Š+EÛ¶­‘$‰€?0èó¯L›­ûD}ï2Ç.£°QšÀ„ ƒñõ]kâ§]»6FeeAú=¾¾«ÒŒG’ÔQ2G‡VÁ×w½EâÞm}[½º*¼ÿ8ôá'úeT’$ˆ½I—a“¨_§fºÓ¾·ÁƒÞÚ±Æ A*ꉦúxÐävªðqMÝÜÞ9 UJßÑ×Mpž7Ï4¦ÌރSDÒZ›LÅ"vFe˜"6–yãÒK'J)„1š4ÙeY@ ‘¡x¬aAMÑ¡–~Œ±  ýÓÇ‚.ÝBùJ.ºúÏ›Iõ/¸f’-xP!À© ;·ùá’÷¿\¶œ<¿#Tä­e‰ µ-i)•ñ ™ÇƒFܼÊ6î?kX.!Á\×yLü®]ÊR*w5ÎsáÆ«l;e•$8êëCÏ~ÔýÆ®$å (LÚȱ9'àBƸ-ÅíËáLtf@“&û¬–•^ÔÜOjñ˜÷0E‡Z‹' ªÎT· …¹“燯ZØ×L {ð Æ@£"5ºµn5PÓÂ÷»àA{ü§U†öOcŒx”ñ &J Z¨J †U©aÒ6þéM篦£´’BQ¼VW¢¶­§ž³U,è¹8ß:€5n‚â¥KèÚ¸|+â׬A’j¾/–;%Æ?P)•² ñXÅ‹êbH+Ë:ÓßÍÑ¡æñcAûg *IþœA—/§¢Lö¡\€Í<¨$Iø/œGRî|< ¹ÉØÉ3­ÎL’õ6xÐ:FoK0‡‡ñç¦2ô­ñ ÉŸ{ã±s b÷¬#¡n¶,ߌç<Ï”6¾›‘®>”´c‚ýašÚ×'ÑíaqbJJJ2ø7GlÞ?s’]Á×u1ÖÑÅhîçS·ŸÞ Aš^<`†mÐÔáü¹Ìjî§çw,hrhß žÉÉÕô)CyšW‡1M¨Wš..Yz|ÿ+ð æÒØO–áAS™=™ÞÉ@ƃ¾%4Õ²’·kµH …Å5°Œ .3ÚW2³í]ð¢iÅ”:4k0 iå;T¡ÈÙË&Ù‰͈Ÿ·Æƒ¦q&5ù×lÿd%ßý{ŸîIg‘n¬Y‡Í@ÈV÷Ë<æÌ–ÙÃÿ!èïæ…×¨þ,X0¾cç2ñ¿Q‰”§o“^^C©Tš 7â·‚S£é' Ø&Ì0‰Grв%jn“Þ~¹ÛÅ4æ‰3yvÀ—~Ô/fǨ‡'™ëw† ª±lµ?yl¹™TY_}›‚Ü 9B‘Æ>´O|„=°¥€2!ž5sÝñ¥7BˆlC‰ºOga¤¹_l¼Dû–í 1Tæaç…WS%cBuÉicBu¹> áרò¨0“:ØgÙ±ý¯Àƒâ\ ß%3ŒL¤x•Z4­QÉôNLèÖõ‹QKyHHÒP»NjT¯nQç2ÔŠd<èû©ìƃš÷¹=3'še"ãA?D™÷¹=³_rnŽ,Y²ÞýNŽR‰B¥eÉ’õ®ÒhÔrnެx"ë_¡Øè¸÷c0ÉÎŽ%wÚ÷Sòòúß%G'»÷c0I«ceË™U6³xÐôlþ—ýrz±ÌÃËÚ6JïßLÇ÷ÖFï^Ï91xÿxPS…-CÆÆÙÌÆ×ùäq ®“>ƒÄH–®Ø„¤°¡Ï¨1äÓãAý~ÿ•¡ÿ§{ZðÄÁ¿¹ŠF•D«þ£(ï¬H#)íòô6m'øÑK —«C—–µˆ »ÎÑëQtlß$•ßF³lÉZ4’-ƒ?“$P›%«4¢Cãj³Ñ¾aùÒÔ’=C>‰“$qåÄÎݧTÕF´o”Ã6é¶«þö«ˆ6ñnÀƒ* }Ǥ‰ãÒ?¸#Yºr3’‚>#ÆÏVÿˆ»ˆfÙÒuhv 7' ¶¬"F£Û| Ð â#ð]µÉFIȧõ«G,Xµ.ÝFQ¥¢³ëIB$ej÷§u£œ?¸ËO"(Z¾Ÿ¶¨iاmþKè1ä3Ãgÿ?æ1ä?ßè’è4Q,÷]FOxðEŽ]ºŒÂFIXh<' Å××_‡õT豞íÛ Š4çØþ„< G«VѪßHÊéû®xsýg_ðI»ÆVö+ÛÛúXƒïæÂ§”©Þ„¶ ª°nÅ2õû]¶ÎZ5,žeÇv\\RÎ'úyfzþ®ŽKé1á[#<èt=–ÓCŒ›‚åœi–•V¢ßås—S/O¿íyбôhˆBˆ{AKÄÚã/Å‹;çÄïˆùS礫§çSôgø!1m­µyb‡z–Q›Ìæ¤i^B„ý-¼ÖBq|§8šƒ6Aa,JßÁgƒMÛ×Ä×t ôfFð ž¿3üý«—ßZáêå#þšå.žªõ[ÞÜ^ów ÏIßì¿wóÑc==,0šª—÷Å/¬Õ%z^%–Ÿ¸/„âÖáÅbýÉH]Rßá¢k·4íÊyÓÄØq)ûäi„õœ¤Çz !Ävÿ?ÄÅSÌè¡Õ¿Š‹̨‡Éþš'&Ç8oÎR±hÆB]YVö+-1sã9!„A«<ıpÝ÷I÷Ä/‹Ò=N3›èç6ñ¡ ‡¯)”Ìtæg\xáHÉÂ…(b—ßšˆ¢Å°ÉT*boô[-ïÙÆÆí‡ÓöíÞ²;Õò’­üvÝalór!(ßb·wùñÔ6/ÿé׎$µ6ÕXK«ð˜I%Ùµú(“éP›M†NæÈÊݰÙE#Ì& ÅØµæ8n 4ê–£6–leïÞ lݶe ¦üµš,_ñº3ߊŸq)‰’… ‘ÉöG,ä&·ß"î#: è‚ÿšÍ„†>fÃú@:öhK±\… ¿uÎDî_Hl±Êlݺ…Ù^?+IhÞ\¥÷8j×Ô͸ö„0ªIY„|Üê3îìñGqƒSoœhS³˜®ÿ$=¡Õ07*NÉ…('ì ñ Çz.÷ùŒË‘N”(X¶B§c5Ô. g˜Ä4ܳ•M;ƒ ýrÃ’Y|þÝX’Ôfûå¼dþÒ5lݼ‰…k6YÌR¶.;Ä„¾õ@‹á“ø{ÙVÔ¯¯Ð÷³iÔ©Y-ëïæHö(4wïæìU_Œð R*xЉKpÿjn®Sx­ŠD-I;#g€¼”7Ãr?Œ6zÐ¥¶‚Yk.X½û—ßj6n"øšÔ¨¼äFݯs¶œÓA›vÎEä«M2ÓÕõøTŸìf@ž¾M*ÈÎ%NäœM^‡×œX¾‘¤ÄD •uáÀê <¾v…5þþ_&ps kü­àAõ¨ËQ“–àöÕp\ݼ¬ãAo\eµŸ÷ë0—‘ª—úö~Íþ ó)Si3ô¨má¢H Q\¹r¨ ÎÎvD$¼@#IÉcØ~.òÿÛ;ïð*Šî¶Ü›NIBB½J¯ ”"(Š *Š]áUñ‡õµR„PT,¯íµw±" ¨ø ˆ(]:ª H )·m™ß{s“›f¨*Þïóìs“ݳ³sfgÎΜ™9_fþ{4ÇàáI·óüS Qê´çëyÒ6â/ÏÙÎ-#;òÒÂÍH’ÄŠ…ÿA‰êÄËŸldì°‹²÷ãgK I%ZÏ*¨PßbÂø›™0ÉÒUV¼ýWþû!n,¬”Ÿ›ïº™—Œ`ðy&϶-?|C›KƾU§þzmáûçÞ¤q|$Ýä—ÅV-þt6WC,~G­×…ó> Uè>þû寧µ]Ûm ªp8Ϊ11#ÊS!ÖLÚÐK×9á©gXðåç„Å5gÔuª4@qIåchR?œ{ߺV’)¥ÍÙ™S%=hÃòô ]Gpmè/Ì7ý@#Æõ«U^+Òƒmî`eô ðgÜ͇"§½R³L‹¡(û^-WN‚Kš:YU }Â%(ø wóK‘÷½vVdÌV—«eU¢½©]ò~;ÂU#¯ò󣺬ã_¾quTùî¢Û¶çæ¶eô žœÅW_~NxÃf\S޶|ÚÎ:2=óLæ½z )“ÞdÊ“OY÷Æ6eÔèŽ$ä—£õô ÙB|éÅwÊñsˆuWîZǼùóñì?ÆÅ£cÙ±òsæÌaKê|ó=#†U^úﯫ¿®ax´ïïMÎr4£j¥ü”ÖÝ:Mûâúøsœ Aä¬[Dú&›¶od÷žýL¨ —~$Á—]F(ÕЃ¶ÔY[ ½Â%̼-˶”$v¾”Âoç§—™B¥Má™wÀBßîeô ½»÷­Ô{ÈØø ßnI%L1ËÑIÚèßï^}ù nŸò´¯!ëºî»oýê…ìN/$ç·mÜüØs5N;NßßU=oú¿§3é¹É$¶îFýÝû8Ðô":—‹– kzµyMîr¾EýI É=úÒp`W>˜0‰ýå¨67.ùc™ ‹»{i6KèÓ£/ñº0{âdÒ[· mïïLŸqÑY•Yl4ª’Ôétú•s¯ŽåÒêYJº“PY'©K“?œº·þ·Ñ¿ïù¼þÊ[Ü>õ)RHaÊ S¬´ßz—`³„>=û1¸Â¤§^¤MR¹Y{¹öþé\Ô§'o¼ú·Oy’X[!3§CÓru-}K:mZ7­¬—šÇ”‰3iß©%õ«¢½õ fMšÌÞ–-Ø—žKÊ´|üß—ÐÂë’›‘Æ-Ï8ýË02DÜòŸÿüåéAW/[EòÀ>g—tÏŒ˜F$Õ©zæ¢b^« Ç<-tœ5™èA©Ö‰ÒƒúÞ÷«I\CyWŸÏ5Ë×лïZÑ–þŸ³{4lDB½êßõÑzVÔõTi=+^;½jûEœ=èÙ^Sr²ô ÉûøÉœzÐÖÕÓƒVùŒ*è1ÿiô 5½íAò€ä?(ïêóÙ»ïZ×ÒÿÚüñ»þ#ZÏÚÔÓ¡-ÅÉèUÛÿOËé €ÓÐKÆ$€8u¸Ž “àÔQâ ì €NdY9·ŒIéjÃÀŽÔÎeüUëùß”TT*P!,ú²ï7ÖÚS}ªô åô g˜´ÚüqtªÝû®Í;?™z][kZ°lqméA9!½O¥iŸå©a‰5ßÍeëaáÛ™«/ë]vU’Ø¿#•5Û¶Caï.ÍãÇyϲxþ‡d)„HnDÝFÜ8üb 3¥ÿ°ûÙ´m™uoIÎøŒÇ¼´‰Õí9ªHZÕó,ZÅ|ž˜ø:mÚ7%cç^ÆMŸJ=,*„Ô4ƒ'f>ìKcíÒ9,þ9“©3bõ¢/Ùö»‹p ëÆÈKÏgúc“hÑé ÌfÛ²û×L{rÿ›ûKT‚p!G5åúË/ª$óÓ¢È)°q4s;ÝGM¥wó 2¶qñˆ‡Ø°e)ó>þÝÊÂÿË3çpaçH’ÄÊÿ}ÊÏ¿aÒÔû+ÉôJÌåý…³K¤åL}àöZåç½§Ûaj¤å ž¸ï&ï{(“¡p==—G¿§–ô 3&L£Yû¶ìޙɴñÓ¢É)PÉËø•ž×M¥W³àSnÙ!a!ðÈ!"=è‹Uî =¸{£øÏ{åéAŸ¨Dúì» }ô B1yZŠØ°z‰˜ýéá,·‹²ª]ï<ùJµÏ+½oޔǽt’¦¢@Lš¾H|÷õÛ"O÷Òƒz¯Û½J,ݘ.žóžó£õœù’ÈòQmšB¯Ó?Ë®…L–x¹Ífæ§ÓÊh)‹V‰™Ÿež5™”v O^†˜ýÙçbö—5Óƒ¾\=hήõâÅ÷O†ôí*éA¿]ø¶øÝ%Ä )/ø(;×û(;WŠY_dˆ×ËуNœú†Èø|¦ŸÌŒ÷øågƯ ¡çˆÿ|ðM9ÚYëy³_{F¤ÿ^â;‘»c…X²~¯x1å…je*ÒŒþQ~f}‘!^˜šâ»oÂãÏŠdf~œ.&§Lë½ô N¯ìš%_‰/>-öd­´{xÛ[“Ä=è ñäì=èAß0™‡ÆÝDÿQ£˜¿Íð“ Éù‰½+WÐ!Ù¢}ä±§9¼ôêöÁ¨Ñ7òáŸW*ße‚èî£í‹-c™Oï]KÞ¦óµ·œ6§ÅŸ@êøCzÐäWùÑ&öìÓ•w?ú„z¡AìÑêWyOm¢DtPeI’øî‹ÏÐBBÙœº™9s>§C§¾´mPéyÃ&NäÙé³hÒ¦Å?Ó Ï” éÁs§yÌ7—-¿n&-óp%zÐ$9P¼T›ÅrR%zÐJ2R‰¢za2·Ž·ö uíÙ¾ÆühÁÍøbÁ¼óÂ3Üûïé\ÚÀô“qÉñ ê7€ !@²èA¿Û’O¼ù=»Kthi…AXöåçä™pÁàk*”§dm*t椲0;†ÇWOêöxø55Õ÷žd¹¬ïQ\TDTtƒ?ט .³œrð¡J×>J݆Qäy,2ð ]I/  }.5©JŸH>Åe´‰Òñ*Ÿ=ôÚÑìݰ—Q£®«öy«—­¦÷€Þ<<ùQ¦?²•ÉCTrÎ=4ó5ß¹œ9´hÔÏí¥ù2QB3ø¶LûhOÜ܇ÌdИ~øïŠšeƦðë+½2:J؆ÜÚŸ¯aÒ½ùùý'¹xL KÎ’Ì ¥ðuîFŽ ¸ÑD6 ®kÓŽÌm¸bؾrȶ _Zjø\¹ù7°ŒûQ­ê÷’Ц]•iUü®úa}õ©tyĸK˜õéZ&\ß‹åï?Å%w¥p~4ôòö¬@ nÊÅÝœ•dŽgíàÝeû˜0öÊ2'¾äoè ó ©]‡œ-s‰îÙŸ;‡Þ滞›žËym›ûÉÄ\p1’$1ï½çéwóGXõ¥÷à‘5æçÒ»RøvÆR?Çé¥ã.áÉr2ƒÆ¦ðÃK+¼õ\P¢sUßxæ™m¸}HtÃÚt9ðšë|é4¼sÏ~¶ŽÇF_ÀïÏbÈ)d¦òÁOxìöáUê] ‡ÃÉõ7ÞŒ0Mt]§¤¤Ã00 ƒµëÖVÚ@ $·h1µó!äææJã&MÏÜ\Ž\xaof¿7›M[Rÿ=(@zZ-ZX±B<ÅG˜=g©[73vܽ„Ú­—:ÿÝ·I×ã¸îò |š+ªBb“D„ôëw}ø9[¶lçÿ ËQ—žžîKÛgAU•ÄÆ‰U>/,HâPö!›$’ºÙsærëƒR.Lžªª$6©Ø)¡Q‚W¿Ù¼e'ÿwßÿ¡„&§§óýòÕÔé0”>M#éW™~0û½Ù²m7wßs7jX#bZvh‹­´yßAÙûõOË]x˜¿üšÔ­[{÷½„Ú¬²J+÷Ω"­Šç'p0ë ßuEQHhÑ„îßø~ùjêw¼Œäfõ‰yï¼E–”È5—öDŽh\A&’%KR'HfËÖíH²LlLL¥|¬üa!«7lá˜Òœ†´«òW”Ñó·ñãÖ"òrv±mëV:u²B~Ö”Ÿ ×§{—v|:÷kvlÛÌÍÿº“ðzMˆ)'Ó»I}úöéÎG~ÁÖ­©Ü}ÿ8"’:b¦¯bÝ–T E(I1‘~S9jÝ&D¹ö²ø§ÕDuºœ^M#Y²dvKoYQˆ‰©Âép••Eë6mp»Ý蚆ËåÄÐut]'';‡ºuëp,¿€ °sçγ¿k¸*èAÿy8Ûô úÚ¿X~þGórY³z5ÆàÐÁƒäääЬYS–-[FŸäd~ùå%%’¶ï@€´ÖÏ$@—ñwÄŸQgþNù9!?gx8<ø ×^{BT¿¶F T» &Øl6¾[´ˆ_S¥y³fèšV¥œ\ã\Oð…oöÆ;“Ó¢Es„é ¦.UÕ3 -׉ø“2­œ±´ËG‡ à¯TQïå¯nH:vîÄ‚ó ÅMó LaÅÜ7M‚BBü‰Òª•͛³eÓg9ÈttdV­øé´û&„DÖ`õÊŸµã/†3õÎ8=ðE ‹‹C®¸Ð !!!‘;v•©Ü—Û4Í3:5@œ;0Mv‰@<“àô ª@œªœ–e™½{öPPÏ©D¯þú†K–Ú´mKhhh•c|§ÃIVV¢B·ïo=f–e’5&$8øo¹6"€¿ˆ1Ù³g7áü^½%äÅ÷‹¾¥Wr2†aT2¼û÷¥qAr_$ùÜitÂ4ùeíÚµïˆi ÀÉ“Âãlj‹¯ì`‘åJáÊ(<¢Nµ|%Á!!¸\Κ¾ó›^˜Ÿ^ÁÁNI§fLTUñ‹R‘•“‰"+”²»ãr:hÞ¬%6›ýœ-$I’5°Óù ¦i””[òR™Ñ•%™úõꟓâÛã!ÎÌPÔZ7h!œ¢ÏDQ*uç÷gì£sÇ®G7tt]C–e¢£–¾—¨¨Ä4ˆ­¡n TUÁ0Ìj£öO˜fÍ¡è„@QLÝ@Q+g¿” VUUt]G-/# *>¾FºÏr2³Ú¯´„—2Ò§°¨Äø$tCÇ0M&†i,ߢÕ4Œ“±h~[’erö§Ó Qsl’yb÷W¤úDIøÙD!I˜â ªþA=EÁ4M¿aawáðñý!0MS˜>t˜A½®fýÆuDEFûVœZÆÃ?ù‰O,bæ´Ë|é•oŽÛ·e|h3u.¹ŠÞyûmdYF7tdÅFÑÑ#yOLzœÝ‹çq¨ñ”½ßràÈöêI£†Yüx Š/fZ±)R)O£ßÐG=¬ vŤ¸î0Æ_OqÆVrÂÚѺYUùêÍw¸êα†ûÈ.v9’èÔ8Ìϸ˜¢¦‚?笡x4ÙÙYVÏĨvÒ}èe¹rÓ&B€Vt [D¤Ï 8ì¡aë®ý¶—:Iq57yI&ÿh.‘QQdŽ9H‘Ûƒ0%bãQ"ŠÍP"B”²t„@3`K85câr¹°Ùlhå6ô蚎Û(föÏ0Ü2H iú´ÉÓoÞÏÕßÍoi{iÕÒâlµÙl¼òÊ+ØíAØív‚ƒe¶oÛÀ›ofÓ¥Kºté’LÆÎul>lãÊVæmJÐGó¹ò¦+¸éæ›QTù;øzÕv.~=]Z7BÓ4Z¹Š´Å«P÷.ÅŒîGÜѯ‘{ÑÖ»à¿ÿ}™ÍÛ~!u{ú_|#ÿúW[TUáÏ÷¡¨*/}ºŠ'&wEÓ l"ÔÔ-(i.k,מŸSRè6eŠOÿÒ`ÉUù‡$É2Œågr¬‰aÖ²qYBUT\.¥lÄÂ×+(Kèhvº¤øz’$ðØcHˆTÑŠò±GÅcº I„Ä´`÷¶´8¯Bw×ø’ósö×!<äìßMx|KZÔ FG‰†T—cé{©ßª%ºnúò#Ir`¨@­!Wï0,‹8.I’Õ“‚ø¸æ´kÝ g>Ä%Æ`³+4l„-ÂM^^®O^×uîºë.’›Çq8¿ˆ¢üCtï5œ1cÆÐµkW ÷­cîúct¯—dzßå†Ay땘B + ªÈáÕov1ææëiß,]×­ˆò¿m§A|¡ç dŦ߹ð–;ùßÚ¥4iY„Îøñ÷Ò/ùÚwìÎêå³yí7xóµ—1ív²>M‡ÛîCÓ $IâãYß3å•WÉúòyTIÂÔuî½­=Ï|“ãÓ¥t(C !¦×7¢k:²$¡È ª¢`“Uì6¦apðPEÅE‘_é½Ï4Mê7L AL, b­#¦a º×çÇæ’•y€¬ŒÌ>L£f-uW™U«p@H2õí:B’ÐL…艧‡ËŠÀ4u’âBØD÷å'°Ö(€ÓbLUÁãñ {£*麎¦y@2Ç¢9~РeROBmPm*¦„„„àö¸ýî1 “E+Žrÿƒ÷pû #))Øá½¦!;r˜ñÙ6s ñpSŸLxþ}d ÃÀÐu~~æuî¿o.—Ã0|éÖ­ÍWÛJ¨S§&³yÛ& Ã…Ý&cš&{¶­aõºغñ+^5žAuŠr÷}ÜuE s×se¢×8ª*ùáÇ,³¦"•úY]EñÚyåôЭéÑêœ& kW…Êãq— M“˜ØÂÃ#Ð4¢ã=šGXXN‡Ã{Ÿï0Œ²C7À4Ð5+²=œ&ÍZÒ¸iS¢D!›:š¦“wä‡sr8”“íw¸N ]Ã.Q\bEɲ«*ÅNw¥ç‹Tt]Ó,=4-0%À©sYÁíöï:»=@&¬ž‰! $@7_™i˜kœê0ÇZ´TþÐ5 Y.ö¸5­íײã;…1ƒŸ§AXs4M«tŸÛ¥Ò/¹;;W¬`Èý#½çuõ9G‘ÃO6¤A fÞ5‚"—Ž0MºWᆲÜã`êx KÎ&9Éÿî96¸iÙw$Œ¹…i㮤HÄ!4[7ÅéÖyùÛnoŒ³D¥IäQöæÃ•£;òÆÿÒAÈ<7'Ù“neÄðጸe*úž ’aÿÿÞ ÓµÃýòV£ïÀ;,(íÄÇÅObB5BFFUmDÖ$48EQPe]7|÷ y9™deføŽŒŒ(²6…Ø,µIDAT5«bŠbßÞ4æä“eÉeÎó=ÛjôIÂ4Lò…L"aF“–‘m¥“I‰CÇ4Mœy™DÄÄø"i•Ûà”z&n·EQü°š¦Ý𠉱- 3‚XúÃâ²]¯´ÐMU$rÝ!¤Ìz‡ÃÉNb†7 Hè˜\N;/¾6oæÏç‡c.¾öâ‚$ÿ´†Ç_|‰œ Ëøqãn^þG–²ÄóÏ>Mÿ‘×#åІÞt/¿®Zн×ÕÈ ¦!]4‰ÞCþq’gÞûaðî•”þ*%£œV®Úë™*¿€¯Ô¨”öòlÁvB‚ƒÑ4ˆðÂ#"dM×üÊ+ºQsBƒý×ëš‡Ó „¦Më¡Ê Š¢X«m…Àé(Æ0jnôñ¡G ]D„ÚA ")1‘Ь51n<šNÎq… ‚ÂbiZþ2EVØN͘¨ª‚n~_¦   ê¨3øy?Ù;vøz2²¢Túšyt.ZR\â<© :Ü‚—ð *L!è×·fÑqâÚtç†6Ýýä·¹Ãú§Y o~ÜÎZuëÇãàŽÇ‘ž]DRtå'Uœ7®¼LÆ=pEå¡$À¬aq˜$Õ°9RC3ˆŠ·¦ÍËG¸×5Ýßpx\y\Õ–…æv£ÌK‹$XH¨²@7Á4tŠË —L“mZPXTìÖˆÒ©á¨$Iªn£Ÿ‚®ëe¬d’DtT4ò!.— °ºåk¡“›ÝN—N]þKì]f ‘•ã1Ø#AwUêA èÞ}PÍ´1Þ^‹ÇãbÇŽT_yõõ‹;ke¥"ЪqÏH¶`<%ÅøYV°|>…&œ’VQ0ô²Æ#€&›Ðô' !0ssÀ¬fG° ÕFA|\ÂßRçÀ¢µNȘTµ„<,,ŒÜ#G¨Y»ÝnMqÖ",|ç„iþ#ΩªŠÇã©Æ ߬iZ«U…i ÚíàõœÚ90Í?å\i9@­ŒÉ¶mÛ¸þúëýN6kÞœýûö‘…ÛéBVUk–"n×?뜮ëô<ÿߢ¹ŠÃ˜6çµã`N6’$#Ë (*®£.dYþÛžS™¶íÚcF Nkµ3&]ºt©rœŸÔ¨Q tªp2UuN–e“ýct €*Iu‹¦•(ÐààD(@œcR1zZpb,ëós~øáF(‰ÓŒâ¢"öìÝcío9G¡(2­Z·!,¬,öKQQ{Ïi½Š¢ÐºuB½zKÀïÇŠY¾i¿ ë…MUЭQuCªÚ«ƒ ´üÓÞÈRSSzù°s^×ï¿û–^½­@Û²,³sG*—^vîë½ø»E\л7†a *2ß®;ÀW÷C–$dYÂ4Å9÷«›&.XÃØË;à©°²¤¨Ù ¬#8íd™ˆ:u|!ÎÕCáh[’$"êÔ=çõ6M“°ððr±nYEs–`h.RwÃs–ÝìØsæ~KŠ‹(.,DµÙ«\ÇTõ ØNµ',jÞ¯sN©ê¯£ÄiÒ»BÌÛ¿ÔÇÂxʯ‹¯Èü~¬ˆv-âéÞÎZ&PþW’ezth‚0MßùšT’;•ßnç¹_Y–È:œnV¿î(à}ý›xåþ¨ !@–«|pùÝ̵ù=‘< Ó}zÓµk7TUeÖ¬YØíör×zѵkwßó¶¾ý*îOù †aEñ_ùórú]ØŸW>þŠ{n¸ÃYV™ÿñ+\}ó=,[¾‚ýûVÃP“ͧ¤wÅ{÷mÝÌÓRxrî|w°hãVïÝNÆ¡ fLœÊ²Ï?aÕ—Ÿ3ò¹7hÇ«ŸàÞšù¶#ß·™#u:phÃ/FÓÓÚõ]¸›¥ ¸°}]v»éÔ(ü”òj á×ÝW%™üãbêù5Y–ÙýÈ#D`í¬ß3q"mgÎdçÃSÇfÃ,)aÏäÉ´š>ÝÚLŠÄÞÿ¼Îº¸ºØLƒ¼CÁü´üFŒêÍê!¼ýÞµÜ{ï½¼ð àJcþº|Òv¤òèø[1¬]³œ­ÛvûœäŽº‰ü{ôeÖ;WUV¯ø™¾}û"ùeéW¤fçc #®»ŽÐ½ìu'ѱŠò ±£é¢Ê ¯AvÆäLÁ·ç¥–Ö?99™äädÿ“…Ûyq‘FçÎÖ8ýÑG-K?{%ïÿZŸÎ^Ÿ—¬ØøÆY̯%ÛØí ©©û™5+…Ÿ¾Mþ·°é¥é¬ìs)$¨x2—3óå\}3ônÌ»sVsË•ç×úû^Uœ—Õ»"šuêÂeÉÉÄ„©|üéNZGS·Iz\viEœB°yÝJV~w˜¿ä!k@‡ \xéU¼þåz&NèÆ7ë÷²çð§Ü5ö: SáƒO~D+†KßÊéÓé6y²_¼ž5zåŒK”¸5ê× ñùTüdƒ‚ÐCñx ã—¡C‰kÛóèQtEAªSÇ·J’$$»éÐ4 lö<7’TÚ×!88Øbi…«d!—]8d S3èÓw}úâøÁ}¬Ü²›‹.ЦkH’ÄÏŸ¼EäÀÛÐ ÁgoÌ iÀíŒhädšÔŸ§Ï ëäI~å#˧›°µJ¦ƒ`äZþî¡ÔæÐuÜÌ, ”ûÇÅý“çrÿèn~2V*ƒÇ_]ØK[ù®í[AÓ¤þÜxËíŒ3†Û®ï@Hƒ‹‘U•õGÒ¥¡5¢í8|,›ç¿‰Í¦òÖ‚_3¬=ö„ždd¯Cµ©µÎ³ÏùXÅè®¶iT<6nÜÄk?}Ám¼ÀÿIdãdä£s¬õÝ;öÃ"!I42Cé7jãï¹j¾šE‡[îF×M ]ç†>q|»1œµóh>èVœ. S×¹û¦¶ügQÎIçÑÒ[òSZ’  Ð\AV&­§O§$<i"Ž%¡U+ÌÜ\<š†+:š–“&aêå|Bàt¹p:]„× %,ÔŽËåBÓõ %.a:×»œÖíÑõÒ!§Î³&òØsos0s?KWn¦ÊHŠÊæc¹tŽ•QT…ü|µŠñÆ:–ˆ‹ÀÔu5/~w°’Î!ÁvR•ÃÉ »‚\ÊsÀéW††®×þ‡™úê”Içß÷§ðÄs)¸\N?Y5ypè@þ•ò¨ïš!`ù¦ÃÜretCC7t¾{u#îî‹ „äËìIw1fxg÷0=¯þÇÞó'ækccmóì%«@êu¢z—?º÷hO\V(ƒ»Ôá³/p`ß~yyL¼iË Àãvcº¡ãt81c¬¡G×Y°®˜+$op“ˆ68¸æ3n;΀6áa ëöÆ#)þeÁIçQ7ü# ¯6",MóøÉ††Çå¤õ¬YJOÇ´ÛqfgcÚlÊ̤մix\β2344Q—ý/$((§–Apý£ ПK{÷ox,Ó41 +}·ÛÃÑ_7Rb LÃÅsO?ÏùWÞÅëÿyŠ;ÆýM=kxùóõS'ü˜U CG6l¸ªª‡¯¤dýB=t§ËÚøYM\ 9111ÐòÏÄ0G˜x4MÓj}H‘m¸8¡€{ŸýžYϧ`s•»®ã)8ȔǦðèÜoyïá‡)š¦áq9¸øò¡»Ñuƒ‚̬4ÑAuàÖuÉ®YÕ0 Dl7îxôNºD[a#&š®ã2T@;<[•Rª0¼ÓNPoß¡|òÆk$ß4œQWÝŠ~ô}{wC ³!uM¿0.Š!Àp{h4pÝ­Çér¡ë2ÂE‘iѳ†Àäúë.ç²kFáñXÁ»5MCsà'—Gï¡þ;ÈY"/¿ÐÛ{ô—5€ÍcÆP¯n]œ¿ÿŽ.Ë8ÿº!!l¹{†,—É{4tS£}›vÜ6zºÇ MÏδmÕŠ—ÝÐpkœºÐ­{LdÞúî'"Ðp{wÝ:˜%ß.àõ×_åí…ßÐþ¢doýMÓu«.¸Ü2ùÙärŒVz÷qÜ„ûéàÑ4l²„§¬,ËÈMjg¬k‚kÿñaÐyÈm´~ã¸G/;/kW-櫘YIâ×qãPöíC/*ÂQRÂÁƒq8ìÚMê½÷Y³<¦i¤2MÖý²‚¾ZÍøñã¨/¬Åi¢y4<ÇŽàÁ†M‘øð¥i q+ÅNÂ49ºgm»÷åÆo&×tóÌãO0jÜÝèšÁþˆpÂl¦æá±;ndâÔgøhöÇ|ðî;¤î9†0–¾M‡‘—Uª›N—»ÚXY¦i°gÈQ‚®5ÒXTÛ£qóÀ„ûÈÌ-!>¢lÚ§ß%\ yp;¬©8§ÄÔ§&¢»,J’¢7mº]È%âp8œ;\¥ rç…íødÉv.On̓)â)ßöÑ™PXPHêÏ é4àJ<ú úƒü°'«·n­û%chn>úh.C®¸‚!a6\%N©ˆ#NóF\GÝz‘§W7ÿ—^øˆþ×ÜApt0Ò·OA¿Gytæ#Ï?îë=8NîŸr?†îaöÖž¨àð§ðŠËô–‡[§ ÐAldx%¬°á*,D’$l½{qÁK/±ýŽ;ñlÝŠ0MìAv?VÈúÝÛÒ¦s:´Õ˜ÿê‹4h}!ßö.®ØVxœMÐ Á³O¥ðÎk/"ÛÂ~ã}D†¨¾çÖë<’f;×óñG«hÏÀ'^ÂŽŽ¡Ã¿’[ñù²T†önÕ„‰ÿ›,.§ O eò@G¹U®’$a³)„«Õ:×¥I“&‰Ñ£G³sÇ è0§ªª²aýzºtëöÉ‘ÌÁ¼#$Å4À¨Â/É2Grsh‡qB JbÓ¦ôìÑ]×Q…M›6Ò¹K׳c³«pÚäöçª$FUy+/ 3¦9¡¸˜NôÉ[6o¤‡Wo›"óÖÿvqyÏ$b£Â½±sËÍtÈ2©÷Ü‹¡(4œð8î¢bl¡!JI!(<œóž{ål¡’dæV_ª+I’È8˜Ïò퇸óòö¸¼~XFÛóÎcÞüù¨+W® lô;3ãþ:[LFF¢éFu}T¢êÇ¢h~%Éh[òëîÿ™z»ÍâëW³×™PeÀð¡3 ÃÑš"SPä 62¬Ò³M]§ÕsÏâv»Ñœ B2ÍŸz»Ý†át"ÛlgiÅtÍu¡ºò‘% »MF¯fRÎÎÍÈçŸ~ ÝŸ¡¡âü‡Ã0*5‰s_oÓ«·ß¢5Y¢eb$«¶f L“µÛ³|¿2°yÇA"‚ƒùí “Ø˜ì?â¦nX(ÛöAU?ù“ù]÷k¦÷W˜&ë¶WþÿdåLÓdõ¶LÔ ­rÑš$IìÿÝ¢ëúÔáÇ“››KÓ¦MFà´Ø‰}éûˆ‰ñ-{6 Ó0,¯¸ªžçdY&++“F[KÄ%‰}ûöƒzõ.•ù³ÎÉ’LVV5òê ›ö¦Qb, ±‘8tHhXŸbÄÇÖÇeÈ$4ŒÄ¡A\L}J4ARÃèÚÉÅEŸXz±ernC&>öÔåJ<[—¡ð[æïtk‹n˜Øl6ö8@Tt?-YŽ:xðà@ë?ÍÐuî=zq`?n·YQ¬©3EF•Ç ŸSå/vÎãñУçù¾@Û†aЭ{w232p»Ý鼟’ÞšFž=}zë†Éˆ>-Ùº—ŽªÊ(²„ªÈØ…‚b×Y?gWòOó9‡GcTÿ6¸=:ªjã`N6²¬ !!¨%%%Öz&ªªÒ¼EËŒ¾eÍ[´øÇé¢2 [“Ð$ƒBbRcRwî*u¢nܸ‘1cÆ,Àªh½zŸ3S B ª6TUáxAN§“ {B›$"_xá…–@Ô¢7bãÐÁl„°ÖíX+ ­Y¡ø¤x‹êÂ4MÒÒÓ D] €ªCPP¦¤îÜEÝZí›–žNïÄÌúõë6lXÀ˜ð·jü¢Ûý•ТeKÖ®]Kpp0jBBiiilÚ´)ð"ø[#++‹ÄÄ_€' (*.ò”’üÖGH^Ú×àÓòl—ÓI„7.Imaš&'J5s2÷œIȲLݺuiÕªÿ”‚`C¿,ÿIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/fdialog.png0000644000175000017500000004174313070106167016743 00000000000000‰PNG  IHDRôô¬/ þbKGDùC» IDATxÚíwxTUúÇ?÷Þ©™$$„zèUzW±¡²®Š,èÚ{_W¬»öU׺¨X~ë®îŠ TT,kņÒ{PRH2í¶óûcÒ&u˜ó}žû$÷ιõœïyËyÏ{”¢ý… ‰#ªüGò$,[`ÛŠ“€‚ª*hª" ÝÔÒM>œ³’ù«·“·?(?H³§2d¤%1ªoGÎ>¡/n§Vÿ9Ò†N !˜þå2LTŽÑÍ!ûZ 0M“ïç¯Äë€I§ô—ºé~Z±…?_~&³|øÜ‘ÞØ\U"ª—Üo^û%! {XþûÑ÷1µ#íî»ïz@ÒéðÃ0sÎJNuíÒÝ¥v4,]»w¾XH(lÐ¥}+¹ß ößûß"l[™ž‚Û¥±¯XgÁŠŒÖMªÜMÉví³øËõçÒ³mÿûy5c†tÃçuËÓÜÔlËfÃÖ½,]·óNÊÊmE¼òöW̳öÕ|rZ6Îú ¯ŸUqÞÑ]áõ×ÿYízÙ¿¿‡kWžÉßôà‘S:bolÞU€¢ª¨ ´oZÍ!&l›õo\Ç-ï•v^B¿l=Ï_]¶Ë†ÍÅŒÿ9¥”Í*Ùçÿƒ—/醩qñØ›é½øìËV¬y÷Þ _Âe(t;ÿifÞ5 Z’Û‚‹nY,r‡Ó††q»]ØÂ¦cŒ>GŒìcÖC‹yfÖRÎjé©þ³YH˶£b¼”i™lúáî}x&g<ô:wÛ.ªLR›8ÿü:™%òéàgxû¸Šóm#n_Ë;‹8 8êö·yfðä-œE†³Â"ÑÃ:.·+®è,•ÐBf~½„‰§©FûàÎå|þù/åúëßÿ™S>ºœ„ÇümŸß;0jÀáLfÚ£­øÃW#(Þó#—=æ/ÏvE› Óo嬲N ’5¶¯Í=’UbÛ†Ãá@ÓªÇc[–…iš8NTU-×x_~ÿn™|bvúÆdCíúÔËßBÃ0Íj7‚kq%ªƒÅ«ÔŽÝ¼àsn›t}YÌ3³gri27ù òi×.)êØŽ¹·ºáA|Ú©ÌŠ–ÌC×ëÜ:wgÔñúœxlè²pOb²¡öb*O~‚ÉknçÎóÿÌ”_àÝ[®%$TzLžÊ§Ÿ~µ}üñ,:º4ÉÆƒÕ¼„૯¾¢W¯^¼õÖ[XUÆ“MÓä7Þ wïÞ|ûí·5ØÐíÍl,Ú6ÃL½ôîyã;6½s;[Ñ…«®ºŒÁSp84TE!¸g6¾ö㫼ˆ…eÚ T°o?ÿ˜Ùß.¤åÀq¼ùÍŠ>¸á ?ÖÊÛ8{B´Æ0ÿ‰ù\ùÎÁ©ËÙ.gþóá”åÇZ¤§ÅÛ‚C«wž0vP#·,Ó4è=<œ>¯qF[ÿXÄkò(Yû 3g®40ÃÂáÔ°„h_êc•8x<òòò¸öÚkB0yòd4MÃ4 ÞxãMn¸á<^¯7ʆ¾vâ±XV$®»ÑK~œz1+N{;§Bç©<¸øK^|üjž´{pÝ-7s\ïVlxó[ú\sq´TßðOL›ËÖ=Ex2²9åô³yî_·¤*¼ôà¯Æûyzk_~L&ôì-a^ªÁ,h¼ã m¹˜P~ìó…³ã^ñZ©—Û4t2Ó½èz¸šßÁ°%%ÅåæKÈ2Ê÷-lÝ_±/@X:º"˜?‡»šÅÊu-éñÝ­Lù¹¡p~zj/_3²TÍSxèšWxøß7 "¸í”Ul*LG·”ÔƒQ£Fò S¹ñÆ›¸îºë°,“‰'2}útn¾ùÜn7/¾øÇ‹ªó@PÇíqFÌÔFór·½‘·ÏV¾Û~ð8{uÅ›çógneêþN˜óvóà²ìh;¸Ý`®¹kÙ­Sã ÇØlüàz<—þµÚO9V&ÞƒôP+ª—L+çW¼CS¶À²->þnçœxT5õÍ4-&M:¿|?ùz^ž´±|cN1“¤–ZÜ*Œ¸!À“~ÿ5…Çv_tÇï¼ó¢¾³-ÿœõ+×O<!b,©—ÐcÎ?®Æã)GrÏso1ÿÑS¸=í†%G;Œœ¾îdûˆ ™KöüÈ1}Q¿j?'h5Q$ùÐZÕÊ »öU÷r ªiÌœ9£Ü)öíÙ÷0væãåN°“þ¾œ™SDí !¶Å–Ù÷3ûØw X¦É÷-dù/2ë:›‚sÖó­éÚï^¼ìY»æsÕô$©HB7*©áæ›o.'ó /T'sY]'yœaÓÀÇ6xË4Ù6ïU®þ´+_Ì;ùP¸°L‹âíó¸jÂý\;ãS:Ô  í+b]À¤WÒ‡©›uùFG;^î²À8㸾5VrÙV¶_í¯¨y_Ø‚]_ïaì™. ¨®v Ü÷7„8#TÄsW¿ÆÔw?àÅ«Ã<ÑÿH}Š¿gz%™Ôq:|ñÅœ~úéœ}öÙ5~c¸ôÌa‘DTñ,‰4$Û¶1Cû˜ñâ#¼0ßÃûs¦Ñ.NÞPÛ¶Kï)0ü;øðõ—xù³\î÷3Ní^³*?n|'^Z_Àó3ø¾…ë_&{üä¨c§úsWwBC„°m3’k$4@8.·¡ Û.ß·Ø–µ/J¯g ÁOk:ñgƒy"¢éç^€?PÈ›w]ˆïÏÿ¤ŸÇ¢ªŒºç?´<úÌ»ô Æd&K§X#ãÜsÏåÜsϪӚéx=.EiÌÀa˜ìÏÝÌŠ¥‹ùaî×Ì_ç甋oàÇ)Gs T®i,®&,øþKV­\É‚ß~c‡?…SÏ¿”o¾:W-¬Ïm·2çò/±fM¦¶‘«:%­°øò/ßrëÿ=Ví;ÄWÿ€Í¹(ªÂæ“yk\Ÿmè .¸°¢óY—Ã+l(ßß¾ÍÏ |eÎ~_ä<£O3/æ!"Z€ªpþ;ÏóàUç“~þ Ü1º%a]Çv*8ÜY¼üÎ üî¬[xëë—éá•“ò5l!xã“E\5a$–m6^`‰¥ïæªkî&µUGz53®}Œûº·:¨‡<ù¢˜ÊíØ’Gfßã¸çâ[h—ÛÜà¤VçqgÚhfl=“‰Ù-j”.sWÏ©•VE[?àùÔ?ók¦7Æs‘À’ˆ4ÍÝW\£„Ö\^Þÿ½˜®gÙ‚ÓŸ[±½n^{ád„(NGDãR 9õÁw9>ÛË›×\Â'&)§<„Ò»ÿžØÏûösóQ-%Ã1„x½Îr³)ÖÀ’#2c‰ÜÈ•ç<Ï㳞¥M†\¬p.·5…›>üç!—JeKî¾z<[vî+¦}fŠlÙÍ]R9yÿ|oNLKŽH]ÊáíÆ´·.dú»¸bl‡˜ÏÛõÃl&ý÷•âbFg,±iÓÒ'RÍÇílÜÀ’¦ oÆ(®Û°s:Œ½‚‡ñ™5M„úÙðùÏë8ý˜ž²U7cú­Ï—rÅÙCv#†~JBÍB–löæû±L«<-‘D3³¡m›$l‚Òx%‡ÐšFÙÀã‰ÃºDü– TUE)µµåþ‘½oY6N‡Æ§UXâˆ9°DæåN”YÀœ…9 î—MŠË&-Ù >ž·Žù+wÝ&·S“ûÍ`áš]tnÛ·Ëöë*ßÿ¶†³ª cÖè‹‘y¹Äf²¿>—‰§¦Mª‚[­Þ#‹RâWFMaë²Ü‘SΰUv ^šþ5ÿøÓRån*Pè×=‹Ÿ­åè!}"&¿–{¼•ˆ…( t‘åŽìr¶0ùyázNÞ=¶v$%t©ÝŠÊÌoV0wÑFŠü‘ðMMUñ¸#ý®Ó¡árD‚Ç­¡) 9» e¹#¸œ¢( ìÑŽsN: lKºÉ9ÆN4‡Vž9¢Š‰h½¬Ò1UQe¹#¸€mE’SH/w„i1Wž„DUÈAN Ih Ih Ih Ih Ih ‰¦ 9l•`¨œ0Q ”8HHBK4¦i²aÝ:vïÞE(:üDÜmÚ´£{Ïž1ç‚“8Œu&#ÅG2¯]½Š`0Hÿƒð%''ÄsùKJX¶t É>={÷‘%%´D¬Èݵƒc? oRRÌi[ã oR½ûôcÙ’E²‚$¡%UU«­Px¸át9 ²zšD ’HèzÍ‘x}¬i¸ÜYARBK4¨wUU„e£Ô’GÌ—ß´¾þÒU+«BQ”ÒT8’Ð "´-l”Tœ,˶íjö·ªFTùú¼ÔµyG²‹„$´DeIxKîX–EII 3gÎäã?fÙ²e ( ééé 4ˆñãÇsÎ9çàóù<ü¤(ª$´$´ÄªÜh±“Z×uÞÿ}î½÷^¶lÙRí÷‚‚6mÚÄ|ÀC=Äc=Æ„ pÔd«×ÐÉ. Ý$Úü $¡U[DdtM[Un½õV&Ož\#™«bÓ¦M\xá…ÜqÇå+TVU¹k¼¯T¹¥„nTÍABÛv­’²2 Ãà¶ÛnãÕW_mÐ=lÛfêԩضÍsÏ=‡ªªõKèÒó$š¸„.s°ÄºÅ EW´Dû;ª}FÖš®»Óˆz‡Ò5•-¡µ˜$´mÛ|ðÁ &såó§M›ÆÇ“„VT)¡ ½à×ù j$£Ž>&.¹{ÛNºöF»ÉV•œy›SÜ—Y‘eaüò32†¥o+o÷î[Á÷ ö1î´#û{Ö²¶8ƒÝ2™r ‡Ã84G½º¤¤„)S¦Ô½LÓäŽ;î`ܸqx½Þ:%´©¸\.É–¦Nè£F“ä«?¦XØ!¾þlI¾dþ’ÆÕ¶­Û ûùQCÓ}ûò8íô3ªs59¢+£:eà°B„MEM‚µk­‡¢T‘6±j•‰WUIII¡¸¸oVo:—ü†ÂTz¤» ¡õ0š£ž¡%!˜5kVL6s}ؼy3Ÿ|ò 'N¬[½7MXr¤ØÐõTP´e>žP”ÆWËB{WÚ8'ôÌÄ®ºêµÐù`Ƥ¤¶ ¸h©ª ³|y1ÃN‚@Ùª}ŠÊ€‘-ù9§„ÙI•TXÁþ i1x$¡ù?aWú%­ë06Î]'†Jk Ù¶]]+h$Úµ•À¶íjªò¢ìZe„®kZ–6te©PkïÜ˲ÍwÉÄÖwÊŸ° Ö®Öؾ%V(@ÀïÚJŠv£:Ò ’"Ì[ŠÝ¥É^`ØŒºž;½mö.¢reéy¬Úßž^™i‘u\£Z²ƒž –ÚT¦ØO_§XM[)/^Üh÷ŒºV-÷•%G¡‹ví ºOJ`ûYþëzDŠ[ÒíÆs¨ Á¾u¿âî;”Ô$•Q½ŒÞ…#¹ˆ U¼`]:µ=T£Äi?°Ëï.][H°cÉJzî‚GÓk,ŸÔ®3û–çáqT|*§Ó‰/¥ñ§7Æ" …ìÞ½»q:L!صkWLÏ% }„¨Ü"´ƒÅ9) íÚ¥´!˜Á},[°†vC¡SËdÂ~!~ûåç=ÈÈ*µ’«È±º2ºS"¨‘l%[ö’Ö³®HL¿7`1(Ѭ9.YufÐ'ù'¶†³h\Ï®´›ê#¬Ù´Ð\m±üËÐÜm T}yâ1Äîª*ápË:t䩜‰¤¦±iˆ ‘ÉÀ’#ˆÐi]G6ÿ;veC¯JÞŽu¬ß ÏÈ1´ËHÆ ø1«´ð‘G“C­6{ÝÚŽ‘]ÚáVÂvp”:®³v' ”‚–÷  ‚u0®E·alúiEø2æ(œV@­¤†[ƒê*:Ž@IIã“KUëí(E¡}ûö¬]»¶QÈܾ}{)¡›¡A¡ë°Á,ø~¹®0ž¬®Œ>q0É.•PÀ_ºhõ8Ôj‡35lƒ€aÖ *Úä­ÿ g÷a¤¹U‚Åv¥2QꉇVTGõKa¿·)>'Á½nçÄ!ªSU5¦|bƒnB 2$BËÀ’#ʆPµ Ô’wWè…Wµøµ’¹Ql<ˬfW Ûf_Î2ÖÛ2¬WD8Zoé0(Š!ŕޑÖ>'V0P'ý…UŒáȈê$âÕ¸%â+KXu+#ýYgÕ(Iû4M㬳Ί²©k»¯$ôFhwzz{7±tk>¡°A¼ã¨*UÄqVœ·‹• b·Ýš1#úáU ‚zôØt«6I¬/Ôcz1aéõß(Ù„·MÛ(ÇÛ/ßþ—÷5t½Þ™PŠ¢pöÙgÓ§OŸƒì< Àøñãë-kš– ,9 Ùg$Á¿âwô”°(ÈÛÃέ9¬]±”Å ~c{~˜.ƒŽcØ€ž8°º'¥[wö,ÙŽSSª©³±¨¼U‚½«÷Ò­G¢ÊŠIqðrëz¸ÔŽ®]R¸Ýn}ôÑšgLÅÚ9»Ý<òÈ#QHm÷•KŽ`B+ª›þÃ:ã;ÑâJj…’€Ž;5ƒ®ý†rôñ'2dÐQd$;у~Báš—\ÕÜèæXÍN#Zò}òqõÞ±jÓ¿ƒMΞtjáAÛQåâñê±ÚЊ¢0~üx¦L™r@©uN'wß}7§vZÌÒ\–¡„p$w$Ë£ ªqd´¢Ò©S'Úee’äR1BA‚?¡p¸ÞIíeû¯+©(ê/®ßIWVFX!Ö,ÍeèஸcT¹g,×:BÇ:¦ª*ýë_¹ùæ›q:1ÙÔŠ¢àv»¹ýöÛ¹÷Þ{dÛKú&4D† +îV4º®cšfƒf>)Z2G iÇÞ"qÀ’4œŸK»¡Ch™â"ÐIe(Š‚-ìzUîÊ’öé§Ÿæí·ß¦G8N4M‹"·¢(hš†Ëå¢OŸ>¼ûî»<þøã5JöZï+½ÜMGlÆÍ•N·§f£› oŒžÌÎ$9\ ‡ª)ǪrWí&L˜Àé§ŸÎÇÌ—_~É¢E‹Ø¼y3]ºtaذaŒ7Ž3Î8·Û}@ ,‘„>ü&ºyà§Û¦~H7–À’Z; ‡‰'Ö;sê€5IhIh‰Ð¥ãÐ5öOqN¸Pûõ…$´$´DÃ%aÝz×·鹤„–„–h0 ]GÕÔ„[NÖ0LXÒT´<ù ^¯=¬'ÜsÙ¶Õ,’4J -ѨhÕ:“­[rèܵ[¹WÙUÉ+-„5µÒ®´¨]¼Ê…‚¶oÛFvç.²‚š‚Ù&ׇN ÊPUÖ¯]ö­[q»]¨ŠJQij¥Èxr¤ÿUUµtý+‡Ã×r©©-ÈÌjC^½¢/! -‹Êäp¢9´ŠÙUJ…UµLŽˆ>¯r¶°±-Ó4dåH•[¢¡0MC’Gâ€!b’Ð’Ð’Ð’Ð’ÐMrØ*Á`×1ÛJâȆ¢(½fš$tÁ0 –.^Ìæ-› øýòƒ4&ãóùèœÝ™Aƒ£DòG)– B°à·ßðû‹sÜ ¤¶H“¥¡°°€¾ÿŽ©-2l˜´¡äälä¸N’dn†HKKgÔècÈÍÍ=¨ëHB'„Öuƒ¤$ŸüÍN— Ó2%¡3 MUeþëf UU°råQIèÄa4ªªbÛÒ¥Ñ| ­aÙ7EUz¹‰ÓªŠeYrت¹Ö¿ÂAÏ9?¬ZJ£ª=´š ù¯¦¡£²Šaý7 % "´]%ɵnÖ_Û¡‚@- 3kÞnY‹• ©Zdׄ –pÏð‡?þ‰_÷eÅ2 ­`JBÏ9÷¾¨ý±O-¯»iX!îùÃ}À2#ªD8¬£ë:ûwü›,Ý‹®Göu£ú‹Ø¦Yƒˆ¶…aU63j­ja›fÓr0išŠ£S¬ü»Õ±Õðá°,«ÎÍ4 üy ãý7ÓŸ¹Œ¿_ýíÁß·°L`•%–„eFå>;’M®ƒU¹uÒˆZ¿ÊvT… ˈÚW4gù2®ùûCä}3î‡ËàÇßäòû® ëè3Ý5€ ¾æÂï#çîJ»ÿot!çN½Žù½ïçîÓ²+Hnäü4‹ç_ŸEn|N…@PÇ“”Åi—ÝÄ„QØúÅ“üeÕHþyûI8Ô¦‘±RÕ4ˆa5.˲øýï_·ÊlÂܹßDóç~ϧß×­ Ûfíª0HÑPÔV¤;¶GÝ·¾õ¤5McöìÙ¤á38µçý›†fFŽ ›MïÝçγ¹vüpZõiÙ¢ÎßÝä:X ­NBç¼}·Ï¬Hîž¿bÓ&­/ßß”SÂÄë$·Ÿð4/Nü\qÆm˜)Ýùä³L6̸žÿq9ÐeÂcLÿsÿj÷ºè¶ÅQûÛ¾}˜gí«ù¤™?L½‘»väµç^£_FÅšÅzQŸ~Z¥„Îþý=\»òLø¦œÒ)á+SA~^ÉÉÉõ:ÅTU嫯¾ª]eÞ¿šcƾ]å:Û6c 6­ÏœpÂï8®O_n{éÙŠüfªÊçŸÓ»4èÝm‹`Évž½åRöûÏiUé ÙgßFêÓ3ö•iÜôàÜ=¬=N§£Z×g›~þûÅ>.9#»Iº¨¨ˆô–-ãGèâíËøèÃïË÷¿9ã.Æ~øxùþ˜Ç—ñÑ]¢ö#’ÚÇ d0ñ«‘öýÌåO†¹ç‰HØMïßÕ ”aOÆcäqÃíkygñQeö¯•+f¶dÙw÷á­b,¸R»pî…ÑÇFÝþ6Ï ¾€¼…³ÈpVœ ‡u\îÄK¯j–eКϕµ¦Ÿž¸Šß½øAU…Žävc™<¹Þ »øc>þ<ïŸÐ>¾˜Qñ×Í}‹»žÁ9ý‡{ëP]ê{Úpé½/0ñªe<>åj¦O?™WžùYN5ª#*Þù&Ï3ô°Ú¶m Èh5Ô¡eY˜¦‰Óé¬qFdîƒóBÆÍËÝ~ì߸hý¦\0…?ôÞÿÓMmA×IgæŒÕ¶îŠGÙ1÷vB7<ˆ¯ÊŠòsþ4•K^»³™kµI´dº^çÖ¹;£ŽŸÐçÄijŸ#°DØämúÛÍ£#³PS€üßöѾ½¯Ñc±Ÿu]' !ê¸e™èz˜ ¿|Ì çŽâá¯ýLýê.«Ì•¿PRë<øú<7±©šZåÕÞü§ÝÐó°iX_}õ½zõâ­·Þªb ›¦Éo¼AïÞ½ùöÛokѼ>°Ä§®ôè5$•œÞ/rZk/ÙñÈÚBüë¿ã£Y›"/iX8œ‘ž,$Ú"J-ÈùOÌçÊwª«Éï®òóZ†Å9gO¸œù̇S*K‹ôŒ•>èÀA°(‡[þð2ÿœ÷åA5Ì•ïmç쉞¨úÜ¿}ç_=;¦ówüú_ç’åRKY˜fdZh(o3ÿ›ýŸ~³ô§òŸoל}sƒ<ÁÇœ[]ú%<<=wï=|uëñxÈËËãÚk¯EÁäÉ“Ñ4 Ó4xã7¹á†ðx1Ðõ0%y›˜þÜ=œsÝ›\ùö§œß+5&R•_#¦`Ëb¦Þw%ÎïÀì©“Üøëï0"í,“·e%3þïi.™0Ïöveæg¯2*Ó“0d®ü^çž{.¯¾ú*guVÌçÄ]å®lC¬ßeCïØZÂ…‹“«ÙжYÈ'­/åîJ×¹èƒiüõ² ´¸pSŽÉ@×ul—ŠêjÍëÜʉgÜÄ;s^£g’ƒ>·Ýʜ˿Ě5™ª>°á×MåýÁñô½×³Ûvásªƒ:_§_qKµ¡–/ÿò-·þßcÕ¤y¢AA~~>>Ÿ¯µL*YÅEW½Èåw=Å-ÃÚÖ¨²zZãõ÷®å¢ón ÷7ÿŠƒBðëÜ/Y½j ~[À®`*ã&ý‘/¿8W *«‚m×°cûVÖ¯YÁ/?/¢(©3_ó$· ʱj½BˆÈ„”:Oø÷|Èõ·Í$dÚø²ºpüɿ㥙"Í©´ žH(..Žo`‰âpEÙÐõ¡,¶[QÝüëåˆTT]¥·ùŒ{d'uMáßW\Ȭ‚0I'?Fê>‰ÏžÉçíEôìß’¤VçqgÚhfl=“‰Ù-ªÙÒFͳ£Î®×v.Úúϧþ™_3£‡ 殞“°N1Ó4ë ,qûúòáû/ÖÛ“ÚžÈ;öÃíˆV¶`ç–}´î;†{.¾™¶)Îòï /lÛæ½·?ÄÓ¶½Žå±Ën¥…ëÀˆ¥( ^xa½ç%µ:WÞ<·J6ø‘‚Æ,IØ$fp#Wžó<Ïz–6î†GNYá\n;k 7}øOzxÚ·°oOÿ/&N,_·Y¢yÁï/aÎ×ßpö¹çÆOå>\px»1í­ ™þÃ.®Û¡áN¹f3鿯4 2—ŽY ©*–e£ªrrs„¢¨GvÆoÆ(®{`çv{šZ…jšL´ß¬!âX"qhmhaÙ Ý<ëÿP–H:DKdN±f¬st`‰$t"º4c‰$t3Vº%¡8Nô°Ç# Ýìˆ,Á@·Û- }¤ mûö,[¶„Aƒ†àr»¢$†a`—JnŸ¯b®²mÛ²ÜP.±bùrzöîspZ»\¬.±l¨Å‹±~íšòF iŽÒ@‡Ó‰ª(äååEœ(ªŠÃé”厀rn·›:2hèЃòtKB''š£J (ûSšÛK©ÊY9ŒU–k²åÛŠL<‘*÷Ó4ºR%š/äÚV’Ð’Ð’Ð’Ð’ÐMrØ*ÁP9¿T¢CQE‘•& -QLÓdúuìÞ½‹P(”¸DÜmÚ´£{Ïžµ—D#׌Kɼvõ*‚Á ý—œØ¹Äý%%,[º„dŸï ã%¤„>"‘»kÇÞ¤¤ƒžèox“’èݧË–,’' -Q ÃÄátV[¹0aÕ;lÛ’—@^îDª UmRé‡TEMxMBJh‰ÃHèHN©šOH ­(’Ве¤4Q“y^IhIh‰:lRa‹Ãªv ±-+Šy^ iC 45顪jdq9ˆi3u½üË,¢Ø´c>·êY©ÒbOA1¶Ø¢þsPékZ„ެ4ë–høò³OPJÙQB²¶÷•ÄšÝRUUµŠ¼Üõl¶ÙùË\Š-l›¢õ‹É Y`[ØVÕ­âšÂªþ»eY,\žmØE»Xµ|9[sK"(ëx¥´}H4•Û6 X°`mL²,›ÑÇ“p/˜’Ú‚â¢ý Ò9ó6-¦ ¹/=²"‹Üýø¿ÿÑ¢MVµ¢mû Ó©ܳ–µÅ ì–ÉÁDBªŠB¬+c +Ä&£ '§´À,)$g{³x1óõ0gtµ*ÎT† Ž,â¾~ñ‚H'PEÅK»°m¢ª¶¬¢¨°ý{§Ö®r£È”ÃM‰Ðª£%#F!)ÉSOë2ù`ÆÇ$ù|üþJC[°-Fôã†önEÑê–ˆk×ç°¿$±{ë™ÉÌ[ŠÝ¥É^`ØlØGPôÈ6X^d—wB~þf^ƒœb¢t±ºÚ7›`þj¶MZ¥8)ØµŠ½-"#ÅM¨ô™mÛÆ*µ-˶+Î ¯áçy?³ð·_YøÛo,Z¼øÜyh!0ùäìÑq8Ô:ŸEA[5= »w“Üy8BõKK!ðçí`Ãæ½´ï3œ™-ÀÖh¡uöìÀô Æ “Ô±-¹[CôééF/U M¿Õé²ôZïÙ2 vl]ËÆ’ No*™Yde¦£ª D©ûë è4ª%è¡jrǶíèeJj˜:èm›Í¾ÅyxÆd,•îN§_J2þâ’­` Qg/k[aÖoˆT›‹•+‹rü f€ˆ|㿟ƒYf( ÉÙèÙÊ (8“û0âÄÎ(v¤ìÊïwáKrâo­±3¨ÒZüÛ6Ò¶Ç1xœ F]U*Ç¡@B AÎÆzMÃÖõIŒˆ ‰îÝÁ¶m;)PÛsü¨Q$¹¡f-c™iÝRYYh1ØO7ìí[qö뎎hf­•ºTë]IÎh‹Cs` Éݹ•‹Ö#<-ÈjÛ–Ö­Ò(3ö,¥x0‚ÅUTÜ‹,À¬ÔºÕC¿£zE•Ó\m°üËÑÜmÀ´Q…'óX­¢¨Ñùš«}K›=k’~ÔHr¿_¢:é7biɂšÒk(Œ9a,F&Zá!ÃÂP+ˆßoF¤±ÆRÁ‘Åš~ÚeZlܙİ£RÑCÅõ:ñ$¡(B ü{–Sز?#Rœ„K‚Õìï[¶P¸¿ݰIiÕž>#ŽgÁ&?É.ðu^ݙޙ¢Uûq I&diôH+§ÂÂ,&/³%šjRŸ¢o:–¡ƒê¢u§ž´ëÚ;TÈŽ­[ØâM¡«/Bi¿ðàÑ XE-WTCGŒÂªš/[ˆèyËŠ†[”€ê*ÊÆê(TT=ÆvÖLË,d›Öaé©”#B1Ø_mE›ùy5vAÕDØá°Ž`ª–m`Š,ôõ9B{pöè‹Û¡S¸¿î9Ù†aÈÀ’#…ÐB ÿ.–¬ 2|l743HHTW›])ôíÚ¯Û¢€m#¶·Þ{hÎ,Žä@sA“6ƒ [‘ ûsVгË(¦…Þ@Gœ¡[ zhÛµod™3LØ80Qj•6¡`°~ĺ&"%u|Gº:ñZ%Õœ‡Ñæ%9E-ýöE(>˜óAa·Š°#e:8rX¼7›á#³°JŠÀ¶ªV«CQ‘%MŸÐevpÑî¬ÞPH¿ãFÓʧ,©¡7W423Òp¨á~@Š0ñWâ‘ nf½îK&¬ûøå…ma„+dK‡A‘%¸—V1†##ªSh˜—[CØBÔñB§ DD›4UêfÞÜ9èeæ¢Ü©/]ÓXz.®äVÌÿeºq¾µèÖͲ0Íbv‡˜¾ ’]:ùù%[RÒ~(mœjm&´T¹›"¡Ë"§l#@Þž\vîÜ3½#N8†T¯“?@]Õjš׋G­@Ø&{·®cG ™!²p&؈_«6I¬/Ôéç‚i¦FÉf¼m:—{û…ÌŸó#£ÇŽ‰ÐŠrЃ@Š¢püI'‡£ëÀ_ÈÎ …´ï6„ÎYí!ÉË Áüͬ_ºž6GÀúùìðƒå‡É蓉7œO°FÕA–4IBï_½ŒMÍ•Dz«,ŒîK²×…0u%þ7†„‚«„Ý»öQXO@‡Vz0¢W&NÕ&2ëUa‚”nÝYºd;ƒFg®¤ÆÆvÁ¾µ{é6t(¢Š­”’L /wQÑ~\.W½$©*•kú¿ª -„ÍŽ|/ý{ ”ì#\D‹¢=ÛÙº«„ìþÃéØ& ¿£'‹~YÏ€AØe´¤WEÚ5jWÁ`P–4EB§õÄpO.UY!/ä/9`iÒºEìÑTBg ]úv%5Ùƒª€©‡ êõKýO>µAÏ¥¹;ÐÍñ;ÖdTâðÑ'W﹦9Ξœ˜êA–”KËÑcÇÄ<{JUÕ˜#çjëdj;.¬"¬¬.øÜ&…E'´wùFKêGªÏIIa>¦–FŸî:+—-ÂÛù(’TA­*· ,i¢6´ l¤›vÏòbZ16rG:mÛh8 F(Ø I.—‹’â¢=[ûCYöëJÒFõ£rÜ[]ãÈ ±fi.CFÂE•g ”øc'´m£Ôq§( ÇwB5I^ÛñÈwLã¨lJ ¤\Oò¶îEwo <ŠNA^EíLiMÿaIKõa–Ôa"ÈŒ%MÞ)ÖX› hª;À!Fõ4&s@Kæ¨!íØ[$h››MÎÏ¥ÝÐ!´ô¹Ö3W7¡#%JŒÏœ»kgƒŽ &¿J¿d ©i´ÙÒýäíó×cdH§˜$t€æJ§ÛS³Ñcèx<™Ir¸0‚A¦y×X’h%’ÐMÂDo@8·mê}KEU–@¨M„Ô2cIâu²ò$Pe¨MKBƒLã+ -Q¡µ&5®[–¥TBªÜ5U†CÃ4 œNgâ[$B‡qºÜ²â$¡%jB«Ö­Ùºe3»v+‹¶L‹²±^—Û]‰Pv$WØa*gšÛ·m#»sgYq ¹X]"U†ª²~íZ¶oÛŠ¢(åA"‡†ª¨•æFSÍá(WÓu9ð&ùhÕ:‹={b[ÒŽ–„–¨Eív¢9JKDÙŸÈ?ªRáòˆrž†rBˆrI-!Un‰Z`š†$‰ÄCz¹%$$¡%$$$¡%$$$¡%$$$¡%$$¡%$$š.ä°U‚Á¶¬zWø¨e9 MC% -ÑhÐueK–°uÛÖ/ú'$ŸìNÙ <‡£ù4s)– BðÛ¯¿ ú9vÌñ¤¶H“å PXXÈó¾#5%•!ÆIZâÐcóæMwü‰’Ì€´´4FŽ:šÜÜÜfõÞ’Ð $¡uÝÀ›ä“£‘àt¹0-SZâ0Ø>(hªŠ2a@£5nU‰L mFN±Äaté‚ïñsi”””$ä«'''ljÐV3K‘ÔB ¶æ…Dƒ9­jX–—!+Ó4iÑ¢Eâ5@‡#zÏÆüž Ín®vÌ*·È% 3<ÆYET£•—8¸ïÙ ˆ‘Ð6?>pÿÚ¸P(T¾ùý~,ÉñFƒ¦Ê•(WãQ°liCWC¨p÷þÖŠv›oä»2ÜÖùyÞ/ÌØ°…Q)®ÝÔ2„tŸÏ[ëï–âÄåˆîo„e¢fDùWJ—ŒR-bئŽ.4ÉÉÉqqŠ%rlx¼ž­¨¨ˆô–-%¡Ëìæ­?¾ÆY·¼CÿcwrÉ%¿ø·ý‚ž9Œ;®¸¬üXpÏV>™ûs•¦óÞC“YÔãn¦ýq(G?UÃõ}ÜxçÞ[ª·Ýk\óQKç܃·ŠÕïJéÌ9Dyë[<;ô|ö8‹LWÅ Á@o’7qUD-âåÖ4 ‰FÐJó[¾VB›ÁM\úÜFîýýP.ýç»Q¿-}ü8Þ53êØ’ÇÖy£à¾Y=ð!žúCßZËlŸó'ŒëÿJRUyÎS¹äÕŸ«‘¹ÖŠÔ|x3Î ´õó¨cŸþúq‚;q49lÕx–y³ ,©×Ëm™{¹ä’?V9Úª+ÉÙÍgÜÃl¶2ñªÕ‰ÛÅ‘G¡a“îT@/™Öæ&§"†CÁ²Õh¦™¸“ÂáøDŠY¦)½ÜU¡9ZóÞ{ïÖ{¡ü%Ÿ£ë6.×Ï÷HÁ]ƒÚpþtž^¹—Ge5àj6RšTeh¥Zz¹Kåi~%6Û*½ÿîyzéA]ãè”bÖú«¯1æïâÃÿN~@§š‰)lÌÔ}ÿ–â”ÑQÇ‚`bZS±ìH,w<¶D&t¼ÞWÆrWëåbk¼ÿñÕºƒK›3îÌl¦­+¨v<¹Óżq±Áø«ÿÆ’…Q¶{IÞ>zoEµs ×½Bç3O:vÚÐÓ܆VIèÆ$´T¹«H ŸŸý nU©ÅõÁÊ_§ÿ/Çî´ªa<¸÷­·òý_b~4GCrØ5ÏóΠY<ûà­ì±]$9B!OR§]~c•bòÅßqëÿý­šLäF]ŸORR’T¹ ÅÅÅ2°¤*:Œ?Ž /º¯Ã…ÛãÆéPÁ¶1 Ó41,0Â8Ûá¥ËÛÅ|ãoV|]íXR« ü9ýXfäœÁ¤®éÕ¢¼:Œ<‹§GžU_ó 0ç^J»ƒŸ3½õÞ3Ñ$´išq ,iŽ„–%5 õˆ{™ý!Xz X:9BAs:ñ¸Üx’<šödÒ´7¹ú¼8~æ3´õ4¼a[¡\¸ésþ3ãµ&U•K„P%¡Ç'&3–Ôªz»<¤º<ñ oW^|óBÞùi—Ô¡Áçïúé &½1îÞ&–ŒE‰LŸ´,U•*wãZ•KÞŒ‘\vÒÛá¤ËèÐD+CÑâ;låó%^B‡C‹cg#d`‰ÄცªË.èÝÈ­ilÙœ“¨":>ßEz¹%"%–\§h™±Dâðº4c‰$t# Ih‰Ã§ÓI8¤ãq{( è®Ln¥Ž oY®úïÁ@Û- -qxЮCV¬XÆ€ƒp8"Cv†a` Bd¶2ضešåY–‹.§ë:+W,§gŸ¾ÍËÊ‹Õ%–Í·dñbÖ¯[‹¢ª8JsŒ9œ4U%//ˆ8ÏNgäM“åj(—’œL‡8dH³òtKB'šÊäp¢•JgDÙŸÈ?ªRpRvL–«¹œÛ²1MCªÜ‡¦i4»F(Ñx‹ÕIHHBKHHHBKHHHBKHHHBKHHBKHH4]Èa«CùôIÏ}pPEAUUIh‰ÃÓ4Ù°n{öä…ä9¸=²²ÚÒ­GŽæÓÌe¤X‚@ÁÚÕ+ …Âô8(*>Y¢áð—”°|é|>={÷‘ZâÐ#w×NŽ=þ$<^¯\ç áMJ¢WŸ~,[²HªÜ‡†aâp:±šYÚœ¸©Ÿ*Ør±:‰ÃVª*aù=U¦ ’8œ„ŽäÀНgV!2])Aþ*JÜ:1Ei~9Ť„N$Q)MATÚä{Óu$Ÿ/±þ&ùâö¾Í‘Ð1Kha…°5šä]m>aÇo :-½%…ù ÷×Yš” ZØÍË„‰QB ò×üÌ6¿mYXe›i"-¾Æµ¡m!â&±‘Ìié-ãö¾(J³sŠÅ$¡m£ˆ5¼¡¥+"@„MÞ¾†;t-¶Ê…mWt"b?Õd/ ÛF( jÕäoB` »Ôþ¢ÜSµb‘tac UUš ¡µ¸ååNd ¯À!Uîjä6»V.¥×¨ãÉn‘TºT'ö,áç­Ý阞F°x?–¨Ì!vmÎaïþª–©#Ü-éÓ·žÊ«B ›}9K؟܇îYÞ(’òv²y[.†ª¡)`Y6šæ¦UÇn´m)ܳžuÅéôïÖš¦ÆéH?'Q%tIqQÜ€r±ºhR²s;|ý•ä!P\„)À¶ŠY´¨˜!cúb†ŠÑ͈ZSת‰áümÖ‘a½[á(%pá–_ømM!cúµ,oƽ«ÙLFuÊÀa…›6›üMKYSäeРdø<”µ}Û,açv‡¦bZ6Þ¬^töÏgca z¤7­®EEûq{†–̨‘ƒhåÑ&@ | 6!ÃŽ:2lÂfÃn®û7¡et.'\Áº:e·=Õ¯î,6é‘‘Œˆ}RR»Îì[–‡ÇQñŠ.— _râNzPU[4?:n%U{¸q ³ÒP•ea ¢ö#ÇÖ…m°qñvúhV€=A‹öÉ #º‚¸ñ:ôŒ)j®¶X-hî {Ä G'ô¸¤¢¨Ñù§›‰„ާ“Qz¹«YÒ!ýòDçy`þ¼¨cf Ìè˜Él³gÝo˜]†Ó>ÕK8Pqˆ  ‚U:‡$%Œa7°©+nQª*)ú¿?q ­ªè¡0¶3>0Q%ôÞ=»ãò¾†a4»À’z ­àaø±'àVêndáü85…ú†ñ…°)غŒjFtoƒb0EÙØ5:1Ú·p³º0DOgC\¢ E·FKâwýæ&¡XR+ u—q§°|é.úöH®S2l[Æf½ ÃÊÆ%ÂôŠÞÒaPd ªØŠ{€IDAT¶<ª;+YNÏc{!¥ q#1*UŽšÅŽ ”J]@â{¹5„m!D|-UBïÙ/ZÚÐ5ˆè˜`ê»Ù[¬ãvkµ±™=²UoÃÐ>ÐDˆ’`8êƒg¶õ±a¿^í¡IÙ édðÓÒ  lÛ.Ý,L½„ÜÕŒ’’Ú¶QÑaÌŸó#(‰m¢*J\Y𛄖%5š¢&†e!,+ÂíJQ—•?UÉ®-¤tCS×pPþR–o ѦÍ^V.ÝU)´ì¨ƒP€ä®ÝØ»dÎÑmW =k‘ÝŸ¡-óÈY¿‚K ) –m£i2³{àtj†Uþp{Öì£ë°aˆJÃmŠ¢”ì#P\’•QT´—Ë·F˜¨zw¼o0”%UáiÛŠ…?}*@ÕÔrÕÖ¶íÒ¸iÀ¶P=i ꞊­×<´äÉÌ)¿KÂçQ¢È\ññhîtu|ÇN½55ć»R2è3¸ .·3Ò¯”O«zE7bøwãìÉI©ô`yG“Ð TUEQçBçRB7Lå–%UMãôÞŒåÁãÓ0±J'X(ª†¦j8Z©ª€°k·Y„ ¤áØ~à0–ÿ¶Š´‘ý¨i·m„µ¯Î(¬k—æ2tô(\„ñW!p ÄŸØ„¶m”8ÙùÍMBËŒ%u$ŒèÛeÂCX&¦eb4ªŠ¨h>ú iÇÞAÛ”†Û”áüÝ´6„–É.‚þ@Órh”–(Í,–;^&†@:ÅêýD‘ÙVÑ[cCs¥Ó&Õ‰ÓÑð!'Of6­’< M­*ãXRŸG‹´ô„ûO'cs#´ÌË BðýÜo0p§LõÖ0M“% pâɧH -q˜lh™¦Q!ÓøJFBkÍnÜ4î> é“8l•áÐ0 #nIóš› ‡qºÜ’Ї­Z·fë–ÍtîÚ­|,Ú2-ÊÆR]nw¥kc[vyä›,]Î4 ¶oÛFvçÎͪ I§X"U†ª²~íZ¶oÛµªÃ¡¡**E¥™=EA+M¬§ªš,W¥œx“|´jEž=±›ÑÒB’Ð §v;Ñ¥%¢ìOäU©pyD9Ïd¹jå„å’ZªÜ‡ ¦i4»F(Ñx^n Ih Ih Ih Ih ‰f‡ÿä¿‚~ÁµIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/graphc.jpg0000644000175000017500000001157113070106167016572 00000000000000ÿØÿàJFIFHHÿí €Photoshop 3.08BIMíHH8BIMó8BIM 8BIM' 8BIMõH/fflff/ff¡™š2Z5-8BIMøpÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿè8BIM@@8BIM €|€ºóÿØÿàJFIFHHÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„            ÿÀ|€"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?õT’I%)%W2ìÊ­Åû=l}/¸3)Ï$VZý¯ª>“ýIŠÒJRI$’”’I$¦˜ÈÍý®q¶Õö/³‹åÞ·«½ÌsvÇ¥èz_Êõ=EqRûgt{†4ä^®¤¥$’I)I$’JRJ¶¹v»'í,cËœÌrÂNê€d>ÍÁ»,õ}VìVRSÿÐõT’I%!Ì¥÷âÙUnÙalÖý}¯꟧ÒÙ`k¶©Ókn¥—6 lh{H2!Ãw*j¯O,k,Çkv}žÇ0¶{Ò°ÿ™cRSi$’IJI$,œšñi7ZkoÒ-iq»Èoæ3ó’S^ûb`nÐxߪº³±ò)ÈꞥgCD Ðèùàû¶¹®­ÿÛZ))I$’JR‹ÞÇ=ÆÐI'AITêA–P1\HûSÛL2Ó﹟ÉÝŽËRS< ß^%bÇn±Ã}‡_¤óê:7{¶µÎÚÅa$’SÿÑõT’I%)V£3‹`î¯vîáì!®k¿®Ë³þ-êÊ¡Ö2±°qëê7zc]^÷H"× OMâ¹v×:öÿ×=7¤¦úI$’”‡m5Ü,†8=°H÷£ôO¹$”Цª©êž•M hÇ4_oýHcUõJGí½Î4äþÕu%)$’IJU^ÓoPd´íÇap|é¾ÏdmþMmùêÒÎ虸½OÝWÓ~6cÉ¡û^Ïe  ôî {I]úž’’I%?ÿÒõT’I%)BÖz•>½=í-×Q¨TÒIH0­}صYcK,-‹{8{lç„uR”æÝ@'ôÀd1§ôW ÿ´Úì{Ò_üµm%)$’IM-ÃöÁos>Z?ýªê¥?å‚5×f4Ñþ*êJRI$’fßö|[-— ’÷{*`þ½ŽkQ)©´ÒÊY£khku'@6òP/"̺( ²n{[àßc7ŸÝsßý¿Où ÒJRI$’ŸÿÓõT’I%)$’IM\ÓéúY%Å­¥óf“,pôÝ1îÚÝͳû ÒE-¾‹(qs[kÇ9Ž-pe–7ÜÇþëÚ«ôÏÑâŒ7Zë¬ÃŠe„ºÇé[sÝüå¶ÓéÙmŸŸjJn!ßcëk\Æo—5® Ú]÷U$”æadœž .,,ÝŽ4äs_ô½¿é6ÆWbÓTÇü°Gý×õe\IJI%O«7ÖÂ~#m}æU•Û^ºÊ^ß¡eU6Ë·Á¤¦X$ÚnÊ.mΊcX­ƒc5þ[ý[¿ëªÒ…U²ª™S2¶†´s BšJRI$’ŸÿÔõT’I%)$’IJU­šr™v»-ЬâÿaþÑôë•«*S]õ>›æX \<ŠJf’©Ór2n ³2±N]Ns-`pp 9ͧ!®™“S[wüóÎT­¤¦”ŸÛ}›Ÿí«ª–¿¶"4û6¦—த¥*µ~cîÔUDÕX"%Æ ÖüŸæ[ÿ^QêyY8ô4aÒ22­{YUNvÁVç?k½˜ôï¿þg£üíŒVi©´ÔÊ›ôXòc¹þRJf’I$¥$’I)ÿÕõT’C³×ÜÓVÒ5Ü#ú°D¤¤‰*™äÓ鹯¶·xâ]¸9­ctö~“k·©Ùö÷VE^“^~‹‰s€×÷a©)°’ Žah¬v’IÍHÎí¯ÏWäRS ª­8À٣٠õ¯èKÏÑÚço©ß¿ÿb&>V>KK©x~Óµíüæ:7zv³éÕg»ù»=ê#í±¨¬™1«†¿5U×fEøí£ûÎïR±µ­Ý–Ý¿­{ÙôÿEo£ú?Q%$×öÇ>Í©ï;Õ‹²h£oªðÂùØÒ}Î nÛ[>þC6%Ý`õUxÇûPÄn ¾÷SÔ†ìÙîßUm©³ü'øEtô럑—{hÈÊÆÝ¶û«ÚæØÜ?oê»ý»Ý¾Û,§ôv¤¦Î3-.u÷¶?FW3±ŸšßÝõôíÛÿþ X@?m#AX2;¸é>ïÍHœÈ0+42îÍIIÒA/Im~~ãÿ‘Q¯íá‘g¤÷I’7ºC¾‹Sa%R‹²m6¹†·°<µ¿HmÚ^Ï£ïý&ÿzL=Wö‡½´~ÎôF¡Îõ…ûæìô¾Ïèÿ/ÔõSÿÖõT’I% ·׺ÇÔ¯]k}–þï­^Ûvÿm@¤’”’I$¥$’I)ª0X:‘ÏIÔú$kÙÛ÷s³þ‚´’I)I$’JRI$’˜WMu¹îh3c·8’N°¦âv·Ûô¦’I)ÿÙ8BIMÿÿÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„##""     ÿÀ’–"ÿÝ ÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?îI$”¤’AÄÊ«.ŸZ àÝÎl<:XçTÿcÿ¨’“$’I)I$’JRU¶Smµ³Ô²¶5„í-¶ïFAËþ‰wü[ÿê\’’±ÅÌkˆÚ\#˜ŸÍN£XŠÚ9ÐkòRIJI$’R’I$”¤oÉ®ƒP³wé¬7h.÷;vßSoóuû’R’I$”ÿÿÐîI$”¤ˆmÖÕÅ‚;‡ÿêZìFB°¹·Ô@–»s姪Ïüô’’¤’I)I$’JR_ôK¿âßÿRäd¿è—Å¿þ¥É)%sé¶u0'îRQ¯è7à?"’JRI$’”’I$¤/pvEuÄíÃüŸðUÿŸ¾Ïûm—o¶çök…`øìŸÿ‚ØŒ’”’I$§ÿÑîI$”¤ ïD¹ŸJ²?²w=¿Û­"AФ¥$…¸Tó¹Ì%¥Þ;NÆ»üÄT”¤’I%(è]™W¾«Zà×V澚Y{½_ø?KÑÙÿ^ÿüÚÔAËþ‰wü[ÿê\’’TI­¤ˆ04RQ¯è7à?"’JRI$’”™î cžíÐI>A:@s˜ßðŽ 3û¿Jßü %+;Ðax‡¸npþSÿHÿú¤T’IJI$’SÿÒîI$”¤’I%5+º–gÙ¼z¶1·ú}öÏÙl·þ…JÚûXú®#‡l.ðmžÏüý裤¥$’I)H9Ñ.ÿ‹ýK‘rÿ¢Ýÿÿú—$¤•ki#îRLϠ߀N’”’I$¥*º›óSüFƒc;µ÷Ðîÿ¬6Ïûu[@Æ >¥ÍÔÚâIògè+ÿÏi):I$’”’I$§ÿÓîI$”¤’I%1±›ës8Ü"|ï&¥î}MsÄ>=Àq¸{_ÿMM¨®û*“îý+AóöÜÖÿ×?Iÿ^IIÒI$”¤¿è—Å¿þ¥ÈÈ9qö[‡üÿê\’’V­ h‘IF±´À~E$”¤’I%#ÈsÛS¶jóíoõìScÆ5Ö€òN‹2É1PÞáÛs·WNïü%)$’IJI$’SÿÔîI$”¤’I%)Vξ¼Z†UŽÛ]Do0]ìym_F½Ïú~𲑂 èBJRH8ĆÜ Ôv|Z?šöêFIJYÙe•Xö¸±Žä“ìþßÚð%¢ƒ—ýïø·ÿÔ¹%$¨Em: J’A¿ù’R”mµ”Ôûl1]m.y‚a­ßíb’G¸6'Õ0îÐÏð¿úKþ¸’˜á¸[HÉ>Ñ ì#õ}Û¿àU„’IJI$’R’I$”ÿÿÕîI$”¤’I%)$’IHlý­´†XóËÿíÏüúŒ™ìkØXá-p‚<Š%¶=Že¬,²§üöæ²Yô¿GÄ”ØAËþ‰wü[ÿê\Œƒ—ýïø·ÿÔ¹%$®}6Ï0'îRQ¯ù¶Îš >JI)H4Íuæ@>ÊÁýÀœÿ¯?ÿôòî°>¼zØ^o$=ÀéWü‡µÎßÿÿ­h€$¥$’I)I$’JRI$’ŸÿÖîI3ÞÖ4¹ÜRRé!úôþøûÓ3&—7ppQ®œ‰)*H_i£xfá$=´;ïÉÎE Nð’’!\ÇH¶±63M³šO½ŸúI?¯Oï½!‘IŸxÐÂJe[ÛcØe®Ô!åÿD»þ-ÿõ.Ul;sm7Ã×o¢§c½Ÿ¦}ÿàmÙÿn¨fuLQMõ=ÛéÝǹ—=ŸñŸÌÿƒINfkiñò%e­…îàv“û¬UÆm Û[N÷4oGøK?›b1‹­}÷ú§tÖÂe!Íoè©ý¨ÿŽIMº˜á/óŽçù#ó*þÂ"Ȥ7Rõéýñ÷¤¤‰!ŒŠHx×TÃ&‚âÝÂZ'·»wþA%%I Ù4´ p2@Ó_¤v©zôþøûÒS4•AÔðŽ!̃CN×;Áû¾Ïé_ÖýI)ÿ×îI$”ÆÃ`oèƒK¼KGýØ…H¸XÿPs¬Ï·_̧ÝôÿJ:I)I$’JRI$’”©u*§ÛÙxi&9-Ûöÿ/Ò}ªêD"AЂ’‘Ð)¬;鉸Â"@ hI)I$’JRI$’‘\,ÝYdî:Ïs>‚*I$¦>{vm?v~÷ÑII$”ÿÿÐî^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/graphs.jpg0000644000175000017500000002142413070106167016610 00000000000000ÿØÿàJFIFHHÿí¢Photoshop 3.08BIMíHH8BIMó8BIM 8BIM' 8BIMõH/fflff/ff¡™š2Z5-8BIMøpÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿè8BIM@@8BIM 2€|€ºÿØÿàJFIFHHÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„            ÿÀ|€"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?õT+m{^ÖVÍîp.Ôí7o“¿}âr«Ò}üµ vÑKz¹:~…ºÿ/ÿ0KÕÉ‚}éü¿üÁ.̺Ÿ‡öz«}O¸3)Î$°±û_\s½IŠÑh‡h9UýìœQÚ÷—ù¾?Ü]A‡«“$z-Ó_§ÿ˜'õ2¿Ð·üÿüÁL´n:?½-¢F ½9Tå^ÇÐékZðIsé=ŽlþkØíìM–ÇKS,º øŽ®²c‡èßû¯uOÓél±­rOeÔ X[`iD8r¦&¨ÿPªà–¶«±Úß³Úæó¡‹Yß÷,T€Ñôì?©þiVÑh“ ãûÓílc;Ž£ïO¬[÷'€5ôõþ§ï¡[[S!úõ õŽ[Êc0ýGú„Ü€pü½?©û™Ú7p8L†è?Ô'×w#Âaºõ 8¾^§÷?—†ÇÑÿ¶·]ZÇ-çÃÍ-uÕ¿ru ==?©ÚJVѸh8?ÁA匯{ƒ@l’Lrž»†£ƒÛàªu¶Ìvã9À «P-;Ÿs?µŽËShüŸ„?Õ)–.¯ ¢Èu„o°ÿ)ÿ¤|O»k\ïbz€S"~‚Ž?¯”Žf¨ÿPOü©‘Çóqý|¥.÷$xkü_ßÉûª;?ÿÑõ+j®Ö†Ø%¡ÁÀI´ïgÊjhªœ– Z×’<`ÔÑþkU¤˜Ê¯Xö?òÔ„ªµÓðS!0ÍGÝåñUæÆf=¾Ó]ÌÝ»¸{ XZuüöXÍŸÔz°!ºÿ¬*c/ ™ùzcÝ^÷H"×7Ó~À]µÎ½¿õÏMQ‰‰… ]Šù¿Õ}{ fN£šZÈÔ}ßíH¸n:öþô· þ @a¯«¯ïÿ_ý¢¬r9ðÿjc0ýGÝåñO¸G=Ó~¿ë ™ 8~nŸ¿ýLŸë×w#õî˜L7Q÷y|Sî¹ì˜8CuÿXH˜ñ|ÝOéÿ_õÔ¾±ÈçÃÏâ–ºê>ïö¥¸G=ÿŠ[†º§ñCOWOßð—úÅ+]ÃQÁþj«šlΪG·¥Áý·Ù¹‘¶6¶¿üõkpÜ5ì‚Îè™ØKõ\K½l|Ë ¥û^ÏÑÖ]C[éÜöûë±ÿCóиÜè4ù»û_×S f¨û¼¾(Ê™Ïè(ãúùHå¯úÂFz¦GÐQÿW”Ÿ€ÇŽToü+ý<Ÿ×QÙÿÒõT˜Ê¯úüµ# ¼ÆUÔå© ZS tn§îòP¹¢Êm¬þx-ÔHÔFª`èÞ~ï$‰ÑÜóà¨qú>a·þ¢ÿh¿ª,;Ÿn;,°XX#‡ mŸôÂ6íF§îÿb«K™Nuô;ô­±¤ÿEw§ý¦×cÛþ’ÿå«S¨çîSqoêÿÝÿ´B·iÉçÃý‰‰ÑúŸ»É<éߟÄèþ~ï$Ì“ôüÃoû‰ÿ¬P^}ÝøðLÔýÞIçÝßÀèÞ~ï$Œ½_0ÜÿÓÇþ±Kîӓχš[¹ÔýßìJtïχšSÏ?rwÞ¡·ì—úÕR ÜŸ³ã¾Ñ%Á¤0©{‹YSFŸŸcšÕ:+e4ÕK$6°ÞN€mä¡^áff=!Λ®{Z¡¾ÆoþKžÿíújÀ:yðø¦Ê^¯˜/kýb”NŽÔýÞHê™ñÕå#“£¹û¼*3Õ2?â(ÿ«ÊR`•Î^ ô|Ÿ×’ŽÏÿÓôü»ÝŽûšÏP²=³H×kÿ5WÆÉ99XkôÃÛÏ3è¿Á¾æ}«È/­WÏЖÅL€Ñ¼ÿ¨HÏ)£yûü’#GsÏŠ¡Âx6w?濺¿«_7ôf¼’ç5´¸ L±Û«tÇ»kw6Ïì+1¯t<Š}VÐâö¶Ö1Å®ÁÍ–=§sû®@éôñ›ˆë,ºÌ?Ð>ËMŽ ô­¹îþrÛiôì¶ÏϵL"HØi#ß÷ÿº†Üiß”ÄhþÔ'ùñ)ˆþ~ÿ$Ì‘ªÏW ÌFÛeæU•¸¶Æ¹ívë*x¶U[l»þ¶ž"tÐl;ö—õTË mu™EÛ™s¿C«d1šÿ-þ­ßõÕd <ÿzjªeL®¦Æíh“ÀÚÑÝ8y=þ)’Œè>Óþ«úªQ;ŸõÊ™ÿ1G?×ÊG#Gs÷ù T#ªdÄQÏõò”˜Aã–ƒùO'õTvÿÔõT?¥U¤ûùjFAôªôŸcÿ-I³ü/þùK£}§ïòø¤FŽÐóãþÔâaº~>I‡ißÅPáÇoÜÿUþÉUF§ÚxñøùªöƒNUwmvË@ªÍD?¡³üïÐÿ×+VLÉÓ·ÅBêY}n¦Æ2Æ–¸Ob¥Œc®‡sú×ÿd†Q§Ñ<øÿµ1?Ú~ÿ/Š­Ó²2®Ç-̤S—S‹-`pp 8¶«Úáù™5ÝÿüÇÓ©Z3öþ>I¹`ª;Ðþ¤ÿÕ(G»ƒÇûS£}§ïòø©k»ŽÞ)„Ãtü|1Çsú×Çþ©J>‰çÇÏâ«U7åÙn×zTU`é.0n°:7ÛKëɺ–VV= t7#*Ûʪsö.­®~×{1êßü&ÏKùˬUPª¡SGµ€IÔÇw)IÁ£¨ýÏ ©S(÷ià÷øy¦A¡çÇãæ¥®áíì{ü §ŠŒÆÿ$ŒÃ¸çÅ!¶ôÔ$vþ*…ú>a·õÍqUÌÉÐqãñO¬Þ›Û¸ý?½?¶5Hþ¡¿õûˆkdÕhpÉÆkMÌÑ͘õ¯èKÏÑÚço©ß¿ÿb4ä²ÇRæ»iÚöÌ9®ÚéÚϧ]šÿ7g½Û›Êªì v:û±C1².;¬±o½ÐÐÏðßGoú_øD&A޲iòþäÿ¨¦Þ»»qâƒnE4 ýWµ…Ó±¥Þç ¶ÖÏ¥c¿’Ä!ûG× ý›ÒôD>]»ÖÜw;Òú>†Í¾ß[Ôßþzftüw[•”+ÉÌ£w¥{šÐkÞ·ìÃü©ôîõÏçl±\Bæ:íÃûøÿ¨¤¸ì¸—_x ±æ^éØÉö·÷}Gý;vÿÅÿ‚G×]Þ›Û›ÏñKÛ¯ÑD½Coêö—õ¾»†ƒƒßà¢&ƒŸŠnáôx?Á0Ûèóýé„ú¨ÍÿUýD¨Ì;A÷ù Óÿ*dÄQçùùHÇl;èÿ¨@¦?jdD1G×ÊRàùΠýŸ¿“ú¨;?ÿÖõTYi±–W¶ZÒ?´öþ¢2I)¥nE”C^êËkeÎ×AíüÖÿ)2ˆ1éíAÕC#ö~û=]ž®ÑêmþwdŽ}/ÓzjÓvícliB‡õ<=8kþãÿU§T1—$Åzˆüä£/¿úHé'Ž ÿ/ûåj‚2ü+ÿ¤˜·.ý¿ÖðVB^ÕkUÿ Ëþç‰Zµ}®½Õ7a±š8C ‘»úŽS ËüÞŸÖI¿cûcöíûVÁ¾9Ûù³ù¿÷õa#íßK¿û¨ÿÝp+T—á_ý$£/]+×úÈé#èðV¨#.AŠôþ²m¹z7¡ŸÎV@ûWÒÿôOýv­Z•[}áþžÏk‹]!ÃQ§ùªtÑkrmȰ·ôŒ®°ÖΛ ®Ý'÷½e*= ÷zS»éfgt7÷ÿ‘·èû‘ž¾¿ãKþëZ¿ÿÙ8BIMÿÿÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„##""     ÿÀ’–"ÿÝ ÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?î=á.:ÇaçíN‡óG¶­ÿªjJWªf=7O=¿òi½m'c£ŽÞ;}(ý!÷;ù]ü•_"¼œoV²ðÝîl9»L±þ›ý®gòS©ˆä4Ml'ÿ1³ê™MÓÏoüš^±çÓw‡oüšhý ÷;ƒù[ü”À{O¹ßHþ_ê¥J÷ ;õeê™M߇þM/Tëú7iðÿÉ¥ï¤î?×óSFŽ÷;ýGõP¤ûžŒWõŒéºOÃÿ&›ÖПMÚsÇþM"=í÷;ƒÿ}þJŒ{l÷;¿äþª<+NC®Ÿõ8ÙúÇOÑ»^8ÿÉ¥ëFí9ãÿ&¢F¬÷;ýGõR_îwúê¥I÷oÒ­ÿÕñ²õOú7kðÿÉ¥êŸônÓáÿ“J5ç¨þªQ©÷;ýGõP¤ñø~1W¬týµãüš^©˜ôÝ#áÿ“Q#F{ÈüŸÕN½Þçp?ïßÉF2uïýN5zÚ±Ðxã¿öÓú¦cÓtóÛÿ&«Û}t²€÷?ô¶6¶Ãw{î÷û=Œö#Çé¹ÜÊïä¥Jš|Ü+úõú¼þnéŽÉ*÷ÿYþ &²¿ÿÐîïþlÆš·þ©¨ˆwÿ7óoýSRR¡þ¡÷o7)V¨¹®²©Ü,rïwþ ]ŠÌ~è8•ʻÚêÈhÚâæ;ËÝê3ÿ=§ÿè-r7ßåËúSlCýAîÞmþR`´û‡Ò=¼ÿ¬ž?H4ÊÔÀ{NƒéÊ’«Só~—édþ£(~ï¤8ðÿÌ“CáÞá÷yY<{¸& ÿP‚â?½þ6OÝX‡ïo¸p{WùI¡ûl÷ý¼¿¬¤G½ºýõDmšÿ‘¤oóoûÙ?Í.Cåžá÷yY(|¿Ü>ï/ë'#Vh?Ô&_ ÿP—òÿœªþ÷ÍûÙ?̯‘îw—õ’‡É÷»ËúÉãVè?Ô%»Aþ¡Õýíÿ{'î1!ðÏpävòþ²p½ÞáÀíýoå&#Fh9‘8÷h8÷äP£æù¿{'ù¦³‹eÈ;Htú?à«ÿ?}ŸöÚ³õ¸p;y»ùJ½y{¶ˆkšÀ|v}?üÅ`Òò¹.èåù¶‡éO÷Z÷ÿYþ %ÿxÿõ¯à’caÿÑí­vÊÜéÛdÑý…D_}žËZ#Iê}'ÿ=ëà?ÎX´ïþhü[ÿTÔ”v[c}Cìì<<\«ä3õbö³ÜÇŽ?5þænµbê]Àî|\ ZÓQ’ ‚$þòÛú-Zé—/îÿÞ3ÚÍãÙØøxµ0cvŸgç:†µîsœÐæ—I×k¶7þ‚ ÚuwÒ=ÏŠ_jHté~ïõ¨Ëcw}ÞI¶6ìüž ỹw%46«¾óà—Ú’hÌÿ¼Qcw·ÙØø%GcvÙìñððR!»Û«¸=ÏòTa»lÕÝûŸ¾Õ¤ tŽÿÕÿ5ýÅË,ö~O¶6_ìüž Ùf®ûÏ‚PÙ~®ûÏ‚I¡Ú?7õÌÿq–ÆÈö~O¶6O³òx% ‘«¾óà”6N®ûÏ‚_jê¡¿õ?sûŒK öw ˆ­…îsa­ž8“Øf®äw>w¶e'ÞZÓ$ýs­ÿÀš’Ð#óWüß÷ã°}–¢æCw¼úŽÿªGØßPû;(€ßMš»‘Üø©C}C«¸Ï‹’ûP±¤?C÷ïŸ÷ÿYþ %ÿxÿõŸà’ceÿÒîïÒ£ÛVëý¦¢!ßüßÍ¿õMIKoo¨}ý‡‡‹”w·Óú}ü¿yO¨uÊå >Ÿ#Ÿûòþ‚Ö7®¿£—ù8Öeô3¨Ù@´z¬]³¸öw¿ÿ­YnÓïüãáâ‡y ¾«LH–x6ÂÖçïE´ê>‘ü©.7g_Þþ_Î/½»¾Ÿo$ÛÛ÷þO9;¹&“Ô¨A&ûÿ/ü1‰{w·ßØø%G{vÙïñððS$ïn£ƒÿ}M'mšŽÿ‘†õׯþ¢ÿh±{ežÿÉà–öËýÿ“ÁH“,Ô¨JL¿Qþ¡/åÿ9:÷ý/ýCþÑ[Û#ßù<ÞÙ>ÿÉàœ“-Ô¨H.Ô¨Av½úÿÜ´`^Øg¿¸ððU™}uÖÛAv+[½¿ºûC½?üÿ>«d˜f£‘ùƒ‹´¾ÛšA6ºIòfêÿž‘@»ß¯þ£ÿhÌ=¾›=ýÇ‡Š–öú‡ßØxx¹0'Óf£–þU9>¡Ôp?+’=VÆý:ô‡ýö/ûÇÿ¬ÿ’ÿ¼ú×ðI1²ÿÿÓîïþlé:·Oí5 "=#ßVè?¬Ô”vVÖú‡Ø8.QÚßOè|¿y< çÚî7-F§ô]Ïò¿®¤ÿÐZ§®ƒåËü¿š^ÊšùfÐ74‰Ï·Ü£G¾ç°É#pv×íS¼{]Áïæßåªõ²Û+‡ÄØÑ>.Ùk[ïÿIÿŸOS ý/åüÓkkw}Ç’m­‡{áà” ßEÜxÿæi C½®ûü¿®’Oþ_õ%Ë[½¾ÁÁðþJm­Ûg°wððL@Üßk¸=ÿ«ü´Ð6Ùíw~þ_×Eië ßÿQ²fZÙg°~ ¶¶_쇂b³Úï¿Ëúé@—û]÷ù]}Íÿ¨Ù3ÚÙÁøx%µ²}ƒððQ#Úï¿Ëúé@“íwßåýt—}ÿ÷ìQäKi7¸†·¤á±º«aØÖÖµ  8Úûëd:+‡¸O%Áì§óÿãQÀÝíw¿õ¿–’:Íÿ¨ÿÙ,ßMžÁÈðñRÚßPûÃÅÊMž×r;ùÿ]J¨}®àwówòÑ=QÑÐmú?ìš¿÷ÿYþ %ÿxÿõŸà’²ÿÿÔíÞÐö9§‡>õ@b:çHhhÓŸûKWý³à«Aý+=µoýSRQ[s}C©àv>.þJŽáéòyðþWõT·Pû›Àü®QÞ=?¤ÞïÉÿú TõË—ù8Ës}A©àö>-þJ«—‘^5?i±å¬©þÿiw±îôÝô­o ÷7ƒùZ›sK šA&GÍ.‹¯Ôu¥ÿqþ±–öîäñàò)·6©û‡õPñì†úd€j–sËFßIÿKóêDÞ!Þæÿ¨A$ﬔÚ(¹»Û©àö?ÉþJŽá¶ÍO~Þ_ÕR/Ûîoþú›xÛg¹½ÿ"+IßXïÿ¨¿Ú(¹²ÍOÝåýT· ~§îòþªrñ,÷7ýBmâ_îoú„•~1ù¿õûF[›#S÷ê¨YuUWe¶8µŒÎ0L5£sþ‹÷‰æÿ¨A½áÃÑ}SÖ!‘ú_ý%ÿ\Auë¼wÿ¸ÿhÆÙK25òÁaoè7{Ы!Ã{µ<Çù_ÉL\!žæèGäN7»ÜÞýù^£Xüßúý£áé³SÈíçýU-Íõ§Øø»ù*!ãÓg¹¼Ê¥¼z‡ÜÞårGªØŸ—Xíú?íŸ÷ÿYþ %ÿxÿõŸà’ceÿÕîïþlÇ‹Ꚉ‡óGIÕºi©(­ïõàwówòT}þŸŸåUKü!öv.Qÿô;ù~òþ‚Õ=~o—/OývËßê Áïæßä¦öô?ê§ÿ=‡‹S¢}Ÿœ|ÎÃÃÅɨèüÛC§õÙµ?ïþ³üKþñÿë<|’Ll¿ÿÖîïþhü[ÇõšˆªÛÇR$87v–šÿüÿZJ;%ÝúCô¸¼Ýü•ߣüî|?•ýU/ð‡ßØxx¹GüÓïåûÉÿú T“¯÷rÿ/çný ú\ÞmþJ`ïiú_HöóþªðƒßØøxµ0ú'ßùÇÃÅ$Ù³þýÏúÖ[½ßLJþbƒhv¶ÖllˆˆÜÓ·{?ôš7ç}>ÞI»;ßù<]gùpÿêÖ-µØö—cCüŸä¥»ÛgÒïÛËúª½”\ܶ_MðÝ®ßL7mŽ;?KꃳbweTÊîu¶…r]¼íéïúÿ­¤´Þµ®¿ú‹ý£`»V}/»Ëúª/µµ¶Ç;t©Óèýd7umcŽ:û@€#é:ÏæÐè¢æÙu—Þl.vêÙ ÛH-k}*ÿÒÿƤ­u¿ÞÿÔ_íÖ‡¿w¨îtà{¶Uô1v§é}Þ_ÕK¸÷þO»ŸäðIuŸÇú¿¹þÕ‰vŒú\ŽÞ_ÕNïwÒàvþ·òSïî<<¦ïaáü¤–‚l{ÿQµbú6}.Go?ê©ný!ú\ÞnþJˆþmžþãÃÅKü!÷ö.HõDIôùCþûF§ýãÿÖ‚IÞ?ýgŸ’I—ÿ×î.©€ÐH×âêÿòéœÖ¸mpy%0ý'¨uÇÅßÊQ÷ú|Ž|?•ýd¬ª¶·s);÷FÐðMˆTÖ÷µõ€ m³ù›¶þ‘ÿñvXlgú§×üâÒzƒQÁì|[ü¤Ã~Ó¨úG±ñþ²BŸÜr^…?¸>ä-^Þ§Sתÿ¤ÝÈãÀÿä“~’¨û‡õ’ô)ýÁ÷%èSûƒîJÓÁã/ñ”}MíÔp{äÿ)D‡í³Qß·—õ”½ p}ÈY±•îecé7t7q 'ô¯Ùÿ• ãßSöÿS!õ%š¸øY/ÒKõqðþ²j鬱¥Õ€è×Nê^…?¸>ä­^߉Þ÷þ§¶¹õ$j>ãáýd‡©'Q÷ë&ô)ýÁ÷%èSûƒîJÓÁã/ñ–>¤3QÈì|?¬œz›Ý¨àv?ÊþR^…?¸>ä½ p}ÉZ=½w;÷þ¯¿Óf£‘ÛÏúÊ_¤õ£Øø»ùH7TÖº½¬nÒèpÛ'þ¥þš7¡Oî¹PÇU©Ó‡¯î´ÿïÏÒþ +û³fѲ#l{c÷v¤šÈÿÿÐî^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/axisref.jpg0000644000175000017500000003406213070106167016767 00000000000000ÿØÿàJFIFHHÿíPPhotoshop 3.08BIMíHH8BIMó8BIM 8BIM' 8BIMõH/fflff/ff¡™š2Z5-8BIMøpÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿè8BIM@@8BIM ߀|€ºÃÿØÿàJFIFHHÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„            ÿÀ|€"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?ô:ôu\šn!ØÕãÕmUÖßÒn{ì¥Ûœ]îÞæ³Óú ×Û-ÿ¸—ÿàúUC¬·§Z\ó[Aa6–í÷ÁíöÿU]IM6õ<½­Ä¾kv×hÁ¬5ýí÷{^ߢ“úƒ™·v%ã{ƒ£§áo—ÒWIM_¶Ûÿq/ÿÀÿôª‹:ƒ¬is1/ 9Í:0jÒXï¥oï5\I%4ÝÔ×±‡ýÖHnŒüѸëêû´¥öËî%ÿøþ•V’IM:ú‹­`{1/-3‡oÑu¡Ý’=AÂÁ_Ù/ÞZ^2 ´û½]¿ž®._ëfg[¯%•ôË/ªªqŸ}aÞû)ÃÇ.v˽VÑUÙy¿f¢¿[õ?øF$§qýAìcžìKÃX œa‡@7ªC6—Á׊ÿôªçéê=o;©c]eôôÜΠEuٵǜAgª]k7âѓԙcY¯í­…”×üïT’š´l5ý’ýá¡äC" sG»ÕÛù‰YÔ]Uoµø—†1¥Î 0˜Oµ¶—9\I%5Ne ÇÙ/ÿÀÿôªž>So67cê}D1àN =§Øç·º:§ˆAηn‡Öð>›=¿÷ô”ÿÿÐô®©¿ìOôÈÜÍ„‚@;Ù·sZX眭ª]`tëZêýV’ÀjÓÞ7³ô¤-¯ßô}ë ëo]«?7#ë[Òhƶ¼Jé.W[ký|G[é^û7cRÊ[övþ¯fg­góI)ê’X]7öÝ]sì™™'#¬&Ýs…aŒ97ZÿæìÿGMxöWMà¨ôþÑö›ÿLµòNPgêÍcßq?ôGþf’“$¨á¿¨?ÔhsƒÏó„°ôZÊÞÝŠÆìÏôuÿžïý$’“$ƒ»3ýç»ÿI%»3ýç»ÿI$¤É îÌÿG_ùîÿÒJ¿PÍÈÂÀÉ͵ŒmxÕYsË\çÚÚë[^ÆzŸGèoIMOª9WæôsosÞì«r.a°Ë½;/¾Ìfý'ícqÝSk¯wèëö-•“õzœŒ^Óq«©¡”âÒÁêMúVÍm©¹•ÚïðŒmÖûÿÂØ´7f£¯ü÷é$”™$»+pÜÊÃgRIûl,­¿Xz‡IuuàŠ7}›#*ÃvçézXؘÕÓY¯sòóóqjþwý*JzESwÛ³wDn¯lxlo?ÚܹΟõ‡ë¿gªúñÅ–õO°¸½†»…l¨åäï§'5”Ýú+ý›ïÇô2½ +¾¯S¢ÄggCvËë$éî>›=úÛ~ÿôi)ÿÑôޝ´tëKœZÙfç6w½¾æm—nWUN«»ì/Úà×nf×8H{=Înænÿ=[IJI$’R’I$”¤’Y½g«]ÓÎ%8ØßkËθÓEn¦É ~CßuÁ—º¶6ª_ôi±%:K륮¯ê·RkD»"Ÿ²°Aw»$· Ö{·n½V£ëˆÉÄÅÍ£ÇãfßF-olz–?ÑÌsöîoÙð¬ýªÏQùV×o£OØÙöÅcëcç§böÎ¥‡YxªÖçÙôïðXoúI)ÛkZÖ†´ÖˆpN³2úÝx}ZŽ‘SšÌ¶³^%ÁöîØümg±Ì¯ôû½Oæ½oô-4”¥USݹìkœ" öÿšöïSI%0ôªÝ¿cwNíÐ'tz{§÷¶{lHûvt}õÌö>›4oòUÅS~Ý›$uq†ÆèuIOÿÒëßgTÊë9˜vú–RÿTs(ô›ök1.º¿u™6}®¯çŸê~•ž—꟣ÜûN_ýÄwùìÿÉ+I$¦›rs÷?~'·wèö½³¶ôåßOÔõ?°ùþݘ‡é ûžÏ£ùÛaßM[I%5~Ó—ÿqþ{?òJ,ÉÏÚ}LOvçF×¶6Éôþ“¾Ÿ§·òÕÄ’SMÙ9ûÙ·ì×Ô—²b=›=ß¿ô•^£Ó¨ê¡­Ïéîµ­e•Óm†\ËÇè­gó•·Ówü©WóvÚµ’IO9Òñ°2¨Ut Ã^u·lkÚ2q#×e[ý?æhý͟῞ý*]c#.Þ¿Ð1Ž8 m¹9oixÞ}wã׳iÙ·~¿z¹õ[þK³ÿuý½ËUò2ÿ<˜mskÇéý.Ûl±îÚÚo¨ntMŒc:m›ÞëSLßÕ/úÕq©5×Mm,ua·>º÷Õ™umÊwêöæz¾ƒò:eÞ…Þ¯Ùsë÷®„dæ@œGO{9ÿ9bt&zݨå¼=¤YmM,¹í©åmNõúu¢­¹tÔÚveÒ˨¾‹žõJ’šc'?Ô3ˆ}-¢=ìݺ]º}ÛvmØ•™=CÓ¥‰ú]§f÷·nèöïÚwmWIMc“—:b:?®Ïü’Žv‹òo²±W¬æÙ¬k ³áµ[I%?ÿÓô¾§kªÁ²Àó\míÕÀ5¯-Ñþí¿ÉKì÷bÿóÿرspºÈëY9×9Ÿau¬g¸ŠÈ·õ¶Ü3é3{¬ûU–ä2Ï}^¢ô¿IÑ084_â|›.ÛþrJj7§<—eÞàçKèÚ!£gÿxsÿ¶Ý=çnÜ«ÛÞé–÷gÝÊâI)©öû±ùÿìYýG/¦ôvWûO©\Ç\muBIqem~M§Ò¥¥‰ŒßÓ_ÿn{í[k+¬ý_£¬>oµÌoÙrqh>Óèï¹®vï{+Çô¾‡ówÚ’š™}S¤âÞ+»¨äÖjcm¾°Ë_¶»ç2ÛÜÊ]öj©Ùê_mžŸÙÿGö¯OÖ©k 3ö‹ÿÏÿbå›Ñ®·¯›œìŒ‡lê¹FÊ£,5ÍïµTêýzO£M”ÑnNOëY•åß]ÞšìÒSõkL°ú÷63sÆðÍËtTên1ë½~î¡’iéø´ba\ë­hk¥–åXmsƒvW³¨2¦{ÿ>ßø5©õ[þK³ÿuý½ÌTº>+zµ}qÙ¥ußÕ,ôŸ]…–²7 –5ô–º½·à{ðT”Ôú¿ÒòŽ^S€»Ýž•Ö¿kþ—ØïÁê/m™ÝBŸI¾¥ŒÎɾ¦zÞ•~Ÿ¡f5] ÀÐNMäøïÿb©õs ³¡bÛ‰]¢æ:Òúì5×]…»XØÊ} ­¹75Íéö7é­d”Ó9þ¡qË¿ah›¸ »s÷Fïwµ59î­Í¯.úÞA ~íÛI×mpÚíªêI)«öû±xþßûpK›‘•A±ö6§07ÔÔÌkÜ¡»š®*XBÁ™›ê9¯vöAkK@Öêû=ßÊÿ ’ŸÿÔôž®7tû[°Y%ƒÓwÑt½žÇHwµÿÕY¹_\:v]¸ÙuÝSqÜ*¿+h4¶÷TìÖa²\Ì›®¶†~‡ÒÆôí²ÊiþzêëK¨eç¿3'Ã[ðšÆ¹Â†ÙëÔwSèú—µÛ]vOé½ÇjE3 ™·YoýËõ1­ßc½öÞ’oªßò]Ÿø{¨íîZÔ·¾ï«˜ùV4µÙ¶de€`¹9åÕ»as𹋠ëOÕÊznMÙø·dÓn{ª±yh¿-ø5°=Ûêc2¯²Uùõ2·>­ ,ÎÓíõ*ͰcÔËò[fëZÆ‹ýK_ú_SùÏrJvR@û'úšû'úšRu“×~²atOLdWuϲ»ï ¡ÄUŒÏ_&ç¾ÇUS[[v3ùÏQöÝRÐn&+\Ú˜Ó †‰Sê§õg‡fopôÍqkMn¶Œ««sGæÞü:k»þôi)Ïg×lQeÿcËÙsiÈ-ØÖnî®Ï[&ì{ýO¶ÐÊññ-ÈͱÿÍâ­\-ÿlÎ/cXâö}ºFƆ½Çk=ÛUaõk™TäRûin=ïÉ«®–Ùhk.s(±e~¤[üßók̲ŸMù6+8Nkó3\Ðáï`;Æ¡ÁgæWØ’ŸÿÕô¥Óðj®üꨦŒË6¶ÌÁ[_Wó¶û^ö~Н¦ÿðKLàÓ êáeu©…q¿¦Òñne[\êœ×†u%õ›ý7Ó¹­¾Z¶z¶Õ]Õþ‰j€€Ré&Ìh|»¤H&'@’—I$Àƒ¨3ÛO-RÖW]µº«Z,®ÀZö8×4®kšï¤×.¥‹Œ~•õŸ¨YKwô«v3ªÜCêu£~6éÞêß[m~=ß™üÝ¿àí¿º$:žÃúÍ—™Kðqñò-ĦçØüÌŠ*õlm5Vçþ‹s/¯Õ·%ØØõ×è]mÞ·èRSÈ3üYe3ê-"ê¶ç·#y-Úlû¹®þe˜·/góŸ¥ôÿœ^Ò:^/Gé˜Ý3 »hÅ`cf$Ÿ¤ûá-°ºË?–¹Ôþ³}ŽŠ²³®Æë9ý•´ *ešš×·#3'ÓͧfK.¯&ê±oýjû¨éx^‡¡—rî¤LN§XIK¤˜$À’S¤¥$šDÄê5Žð‘ I€5$¤¥Õ,7fæ–¼ã^5®5±¯4ý£.ÇdÕ¾ï}=;n.Æ~­uù§ý^œ}œ\l\¬jrXok/clhu÷Hãwé¼ÓõŸØßc¶½²ooô»7ÏèÿœöÿæÈW’SQ½/¥Îiµ¦Ã¹ä_p“›ú_ÜcZ™Ý/ûwú®ÚC›7Ü`Ž?J®$’š¿³±ÿzïû~ïý*™/€µ†Ö‚KˆÜ5qÞ÷;ùÏvåm$”ÓwJÄsš÷z¥ÌŽ7Ý"F×mý/î¡æâ 1/»—ä_]nuT ›Zlx][ÝnÖzönZ9¿cû%ßnôþÇé»í´z~œ~—Öõ=žžÏ§½%9½#I±–Ô÷Õ}uÛ}meqõ+ôÍïÿ;Ô²»?œ¯ôjçì¼MâÏÒï´?׺CIswz¿Éj~—û7ì~ËôþÅÒôcgÒw©ôÂz»ýmߤõ·úŸ¤VÒSQý3ìsns \Ó}Ät þ•8é¸Àp@={¿ôª´’JiþËÄ«ê_ëÝ% —5»½_å9;ú^%Œuv^Ç‚×5×ÜAG5ÃÕVÒIM;pjeO}bû-¬dZ7ÍÜëvµbôî¸ávÌf¶¬öc;%ιöZ-ɦËéô½PïRŠéûÝ^ÿWÔöz¬tË.ù·öÌ/³ý—ígÿ'ìÙ¿ìñíû6ßð;7z{?3ÖôÿÃ$§ÿÙ8BIMÿÿÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„##""     ÿÀôú"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?ëzRÅéØÎ¿!Ð%¬NÂѻӡŸŸþ¾¢´×nhpà‰ûÖ\­®é9ŽÚ Æ=¡¦%Ãs}ígõö"Ýeíf-t¹¬uÎÚ\ö—Àmvä}ÙGú”ÜIUôºýÈ«þÙwþö%éuû‘Wý²ïýìIM¤•êhô½ZölÝ¿Ñtnž—ô´_K¨ÿÜŠ¿í—ïbJm$ªú]GþäUÿl»ÿ{«Mïµ®º¶ŠÜÓè»ÞÝ•]êKÿIo¥ÿZIMô•_K¨ÿÜŠ¿í—ïb^—Qÿ¹Û.ÿÞÄ”ÚIP u;*}ձĸm4»†¹Õ·éeþ~Ô_K¨ÿÜŠ¿í—ïbJm$¨ÜÞ§]6XË«{˜Òæ°RïqhÜÚý¹ž¦Úú‰h'"°H˜ô]ÿ½‰)¶’«éuû‘Wý²ïýìBÈNª]c-®Ç7† ]®¿ÉËIMô•_K¨ÿÜŠ¿í—ïb^—Qÿ¹Û.ÿÞÄ”ÚIPxêmº¶ «-~íÎô]íÚ=¿ö¯óÑ}.£ÿr*ÿ¶]ÿ½‰)´’«éuû‘Wý²ïýìB©›ßYº°Æ±®ô]sÍÍ}ÒÿÁz5ÿÛ©)¾’«éuû‘Wý²ïýìKÒê?÷"¯ûeßûØ’›I*ަëmaº¶¶²]è»ß-kÿîZ/¥ÔîE_öË¿÷±%6’U}.£ÿr*ÿ¶]ÿ½ˆtާc Ÿul!Ïl]ôX÷Ó]žì¿ðÕ³ÕIMä•_K¨ÿÜŠ¿í—ïb…ê,­ÏûEGh&=v¿îbJn¤‡E†Ê+±Úµ®1ĸnDIOÿÐî,ãh»Ò /õŽŽ%­G+w¹±]T³žYvƒaõµ±»Zr¿}ÌIMÔ’I%)$’IJI$’R’I$”¤’I%)$’IJI$’R’I$”ãuÞ´zpªª[»&÷5¬.eŽ©­'Þ÷ý™›í³ÙýŸÓ¢ô¾¡—•“—Eâ¸Äs+ÜÀáºÝ»ò}¶ºÏÐÿ¡QÌÄÉÈëxìýW¶Øç’ ]mƒÐ¦¯GvÿRŸç½u—]_X0>Û†ÛÎ]ϲ¼¿U­ õë~Ûßè1%&ÿ:ÜÇÒl&ËF5uƒ>…GÒûN{Ýê3ôŸÎàK{ËmĦۃE¶1®xdípÜïOrÂÌéuý^ÇéXÍõmsëmï5­¾Ó•ÿ£ëS¿ôé—F )I$’JRI$’”’I$¥ åïû-».Øè$?“½-Ûqmpit1ÞÖóÇò¶¤¥aÿD£þ-Ÿõ-FAÃþ‰Gü[?êZŒ’ŸÿÑî,ëUØo|ǬF€¼ëNWæT×½]UrÈs§é]ÿžr’Si$’IJI$’R’I$”¤’I%)$’IJI$’R’I$”¤’I%)d}eÌÈÄé6YŒKo{˜ÊÜØ–¹îoï-uÏýi›Š³í•1Ü[î÷lÿƒ³ÓINõ{½6îúP7|aI$’R’I$”¤’I%)$’IJAË{Y‹k0é€\xýÊ÷='L{¨ïÈ’˜áÿD£þ-Ÿõ-FAÃþ‰Gü[?êZŒ’ŸÿÒî<êë²ì6XÐöú®;\†”å~k•ÅK>¿Rì6îsLL°ív”å~rJC×z£º_O~K+uˆa .­®>Êß”ïðuoþ‹Yõõ¼¼,šÙ՜ёA¶«EN¥Í²¡êdbÛE–\ýþ’¿Ö°²3F%U4ÙËnt€ZʽßAßΡõ®›oPÉéàVÇQEÆÛÞèÜÖ´7m gçý«ÿEÖ’š6uî¥Óßv>óh6QCZæŒz>yG.Ïð–ÜzÿõWAˆë_‹Kî Úæ4¼·Fî#sý=ߘ¨uü,¬ì&bã€wÝ_¨âcÓ©§Ô²í¿á~‡óKU%,ç5¢\@¹U¬Î­º0o><h€t:ªöaÒýG°ùqþjJE–\÷z® lh8V~ÑGúFýáÖ÷oí#Cÿ˜¹XôjýÆýÁ%-öŠ?Ò7ï }¢ôûÂF¯ÜoÜôjýÆýÁ%-öŠ?Ò7ï }¢ôûÂF¯ÜoÜôjýÆýÁ%-öŠ?Ò7ï }¢ôûÂF¯ÜoÜôjýÆýÁ%-öŠ?Ò7ï }¢ôûÂF¯ÜoÜôjýÆýÁ%-öŠ?Ò7ï «mÈë}(†)¡ÖYe±5°–·ÐßgæYëR·½¿q¿pXd>Ï­M¤8 zq}CP×9ïô}ìýô”íý¢ôûÂ_h£ý#~ðŸÑ«÷÷½¿q¿pIK}¢ôûÂ_h£ý#~ðŸÑ«÷÷½¿q¿pIK}¢ôû ‰F¯ÜoÜøÐp’œüþ¯FÔã;#&òC)¬³~ƒvû={)ek?þt°¶Ë*ÀÊ¶š‹ƒ®c¯ôÎûýOÌBʯÿXîʲ¦º¾Ÿ‰ê¹ûï´O«MŸG~_¥‰_èÐYüßéE];©ÓЙ˜ì«†=Óf^a¬£k¿Mf5žÿ{êý7§þ%=FW_鏨tå9åã%¡Øõ4~–ÙüÚêþ×øE{%­³Ðö‚×0Ë\'¶ïs\¹î«‡‡»¤ââS-¾ÚÄ€w}—zÿÒ_úJ™_©êÿÂ.‡-»ñml–Ë«N×qûÉ)XÑ(ÿ‹gýKQpÿ¢QÿÏú–£$§ÿÓî,æ½×aµ5»Ö>à¿Àå¤Ü®ªYÆÁv©­sýS£‰`G+w½Œ»ÿ=¤¦êI$’”’I$¥$’I)I$’JRI$’”’I$¥$’I)I$’JRçºW§wÖ^¯e‚ªCÏò[·!ŸçãÔºõkÔ}O!ä~“-íÁ{S¾’I$¥$’I)I$’JRI$’”ƒ–ì[C]°ìt8cOå£ åï¶ì»c 8í~û[bJVôJ?âÙÿRÔd?è”ųþ¥¨É)ÿÔî,ç9—a¹¬6XûZZó9_é][ÕK:ÖUvÞa¾±óNWî$¦êI$’”’I$¥$’I)I$’JRI$’”’I$¥*ÕuŸm¾…YTÙq‘é¶Æ9þßsÿDÇïüÕ_¯ZúºFU¬±õ9Œ$:¸Ÿúã_ÿ¥?Ñ®g7œ‘ÓÙC]…¶áŠØÓa¶e1õÕV÷áú~¯óߤ²Ä”öhÇõþÏê³×Þ–áêmÿIèÿ9±I–×apcÚòõ᤮ú^›~…žåÎô¼,{z3³*È{¯Ìo©—–Ø¿oôŒ:l³ú/§·Ðÿƒÿ¬}S¥µôZž?ùö“ùÇsœÏÒ¿ü%›+INÕ¶6ªŸkôem.qçÚÑ½Ë êumgB©à־ǼžîÞêwÛTÖ´zÍ®§¤æXÐ m/€xú*= §UÑðØøÜ)aÓÌoIMámFÓH{M äo >ÖÙéý=ŠK˜ê-'«Y‘ÓÙVMô·nM/&‹JÇa3ÒϳôâÿÝoð94~ô×.ƒd7–äÇÚ-ƒ#|~“Þ’“¤’I)I$’JRI$’”ƒ–âÜ[KZ^v;Ú §ü#˜Äd·µ˜¶¹Æé:žßÉIJÃþ‰Gü[?êZŒƒ‡ýø¶Ôµ%?ÿÕésnÊ·>®ŸiÆ&§_eÁ­{öµÌǪš[{m«ùË?Mú?ø´,L›²„ëÈ7W‘uV9£k\úYŽû+oî?ÓV3q2¾×^v¦ocKÙisk}O,»ùÊ™së²›kÿEúE,N›Uxm£%¬Évç[cœÐZnµÏºûk©û½?}Ö$¦òJ·ìÞÿqiÿ¶ÙÿKöoNÿ¸´ÿÛlÿÈ$¤¾³~ÑèAݳ|ö‰ôÑ_Ù½;Ÿ²Óÿm³ÿ ŸöoNÿ¸´ÿÛlÿÈ$¦Êw6ÇÚÀ4¸0ÏrYVG·þßBý›Ó¿î-?öÛ?ò ¿fôïû‹Oý¶Ïü‚Jm$«~Íéß÷ŸûmŸù¿fôïû‹Oý¶Ïü‚JKE;¡cA—<ûê¿ïˆŠ¯ìÞÿqiÿ¶ÙÿOû7§ÜZí¶äRk­ÓeΊÚ^@æ7©4îhwˆ•[öoNÿ¸´ÿÛlÿÈ%û7§ÜZí¶äS<ÌK=JœA-’ÝZ}F{ªsôÚf6—õ/L›Ü©aqs¶Ì¯×~Ê*ÿŠô‘fôïû‹Oý¶Ïü‚Îë˜,èùf=M{iykƒ1ù®kRSvž—ÓëÆ»ªã/s­`s¶»Õmôýÿ¢õþY¢Š±ée´2ªšÆŽÍjÏé½?Ý;ÎÆ¨¸ÓY$ÖÂI,gò¿Ù½;þâÓÿm³ÿ ’œ®Yl§¢ÙI%¯È!¬#Å®®ë+wõée‹vŠ›MÒÉÙ[ZÆÎ¦67rç>²acEÕ_•[I k}£ÞêþбmÙÓk­Ï8µÀ\@­“ Ýû‰)çs:¶d[‹iÁ9O4š2éÝ]®qû¹84z¿¤±ÿà.ýøUÔTð,8Ä—>ªØâ÷~vóm_öçêË•é]+×®ú™éÖû6_‡˜Æ_ï ûClÃÍÙú/SÏ_ýŸÍ.›öoNÿ¸´ÿÛlÿÈ$¦ÒJ·ìÞÿqiÿ¶ÙÿKöoNÿ¸´ÿÛlÿÈ$¤µÜ×Ûm`j x;šÛ}¿ç¢*¿³zwýŧþÛgþA?ìÞÿqiÿ¶ÙÿIM”:nmÌ/h =šøÔ÷ã¿ÿ=!~Íéß÷ŸûmŸùß³zwýŧþÛgþA%6ò?£ÛýG~D/Ù½;þâÓÿm³ÿ ›öoNÿ¸´ÿÛlÿÈ$¤˜Ñ(ÿ‹gýKQ’€’SÿÖîI$”¤’I%)$’IJI$’R’I$”¤’I%)$’IJY½þEÍÿ‰äZK7¯ÿȹ¿ñ/ü‰)±ÒÿäÜOøŠÿê­*½/þMÄÿˆ¯þ¡ŠÒJyÞ¯é]õ“£ã¸’YëZZ$pÝøÏÿ·q–Ö~C±°¯ÈlS[ž7[,nÿ{YïØ²²ß­çA³ î}GîV:†i°eàµÞ…­kd9¾µÞ§é-f=íô÷¾¦Yo©ý/ý¤’š¥å>¼¼l“º·z¶áÒóöVäFÇßö;¿K_Òýø/ôk¦\ßCÎÄÊÎd€þ ÊÜ‹MN¢Ñ¶Æ1Ÿkÿêd×è[þÓô¬]"JRI$’”’I$¥$’I)I$’JRI$’Ÿÿ×îLÐçYP{«m–òÃµÄ ²-Û½¿ð•«6Xʘë,pc œç é9ÎT²^nv ˜ÏlYfæ<‚ö¹Ž£%û¶6Ê>›?áRO°7ý=ÿöë’ûÓßÿn¹[I%9ÿ`³íÏÝèlÿJéõ'üÿæÑ~Àßô÷ÿÛ®VÒIMO°7ý=ÿöëëÀ~û}KîÙ¼z_¥wÐÙVïý˜õÕô’SSì ÿOýºä¾Àßô÷ÿÛ®VÒIN~>žõï»Ô—LZޗÑÿ‚EûÓßÿn¹7U̳ìªëõ]SK¶—5ƒúû­ÿÕ–ƒX?/«;'¦S}öú™m}ù x¨íª¶î¥¾ž={ñèÊ}Ÿáìõ¿óÚJw/À£g£}Þ®×zsk£|~é-M¸hÝ}óþ•ܬܬ¾§oWÈÅÀ{GÙñšC_üׯk½È±µØúŸU¤®ŸðéºFVaêÙ8g$çcSSKïsZßO*vYˆÛ(mu}ÒÿÁÿ7þ %:Ÿ`oú{ÿí×,þ¹„Öt|Çz×¥æc‹NŸœÕ¶³zÿü‹›ÿÿÈ’˜tì»§â»Ö¸M5˜8 XÏ¢­}¿éïÿ·\Ÿ¥ÿɸŸñÿÔ1ZIO%Ó±ŽGÖN¢êïµÕѲ§¸Xw}æ÷»ô¿£Ê¢Åk®tü 2/¯#&Æ?Øêì>¥M×Ýs»ü¥êÕ]¤õ¿›Sú®]`ê9.hh¿.Â5Ö _ÕjËmŒêÔ2®‘y#)¯—×羛ìÙmôÛšJeUxÙ,γ+ǶÇ×’ÂæúÔ9·Óú,ÏÐ;ëz_ñž¯è–°À®ù¾ïGcv~•Ó¾nõÿð?³*ŸWkÄônÈźü–ZðÑ~A%ÏmMö¶ŸQ•?Ñ¥ö[RÚIMO°7ý=ÿöë’ûÓßÿn¹[I%9õàYêÛ¾û½9—é]ÆÖúŸø*/ØþžÿûuÊÚI)©öÿ§¿þÝr8Ø}kîß½ñ»èo³ìßGþëúJúI)©öÿ§¿þÝr…ØA”½Í¾ùkI¤w +È9aÇÐÇmvÇAÝ¿q%/Šç?§¸ËœÆ’|IkQPpÿ¢QÿÏú–£$§ÿÐÙúÇe® ÆuÛ†ZëouL6ns?¢b¿góuz߬dúŸàêOu¶tÎŽê«÷€Öí¶jn5õºÍÍ®ÿÑ¿ùÊGúUºæµí,p–¸Gˆ*†P¯಺ϧ]›[ÑFMlÚßø4”Þ¬ØX  5ýÃIs²÷²¯üö¤’I)I$’JRI$’”’I$¦‡YÁ»?§Ù‰SšÃihq|ÆÀæÙfÝŸŸíU3úNqΧ?¦ÞÊ®ªŸ³¹—4¹Žª]oÓ¯ôž¦ÿõÿI´’JyW`eÒ21žÁÖúœ[e…®k}êôq65ÿ̓ÿ é-Ž…“ƒökYEu²6 7’ãþÜ›2>¯YŸZ«~-˜}jŸ§…fÛ`Iu6{ÿ£*ÿЕÒ1í±{s^šF ƒîk’Rë7¯ÿȹ¿ñ/ü‹Ifõÿù7þ%ÿ‘%6:_ü›‰ÿ_ýCî{k¥ö9Á­cK‹Ž¡£vô—ÿ&âÄWÿPÄ»p§£æXFïн±ýqèÿèÄ”Òú£\t*l..uî²Ç“ûÅï«ÿE!ßõO ?§ÚüK™oÒç´mõ.Ä¿ô{ßþµ­.‰Q§£áÖ[±Í¥››ü¢7¿èÿ-_IMNš2Æ(ûc·d?ykts«g¢ÇØÏRµm$’R’I$”¤’I%)$’IJU³]’)¢Æ9»¸½îa~fÊ/Þ¬ å»n-®‚èc´h—p’•‡ýø¶Ôµú%ñlÿ©j2JÿÑî,ûYM¸–Xa¢×I»šr¿6½Êê«•ý#þ5ßùç)%$v^+iÙkk©ÚØ}1?õÿMM—Óe^­v5õj}Fæ@ú¤o±s½Sù¿Y0ñ]iôj­Ù.©ÍcëÐýŸml²·ú–Xÿç=æ¿í7é/°dž«•Ðip¯§d弤ÚOôŒJÿsí_¢ÿ‰ÿŒIOT3°ŽÈȨú¦+÷·Þggè}ߤ÷« êx6_oKé´‹sr6z¶: xÕ·ÒôÞÖþƒþµÖÔÂÊØÂw´ïw$¦I&sƒZIÇ`$ª6ç¿PÆíów?椦úK; ‡¹Ö:Girµöºÿuÿæ””$µ×û¯ÿ4¥öºÿuÿæ””¶~%y¸WbØmÍ-׳¿Á¿þ·géGÕ,·[Ó>Ëh-ÈÁy¦ÆŸ#ú/ý%ÿ[[k¯÷_þiXTVì/¬å´‰œÀ×¶zíÿE]Ÿ¤¿þ·ÿràÒSÒ,Þ¿ÿ"æÿÄ¿ò+k¯÷_þiTº½ƒ#¦ePÀZëjsAxØÀHÿ c¾‚Jmt¿ù7þ"¿ú†,ß­Öt+€vÓc˜ÎÞàç³{»þ ]Á½µacÔàâêêcIhÜÙkZÏcÿ=gõæ æaÐÖ‚Öä×m³Ûºº÷úÕW[ÿŸ{Ùgói)ܦ¿Jšê™ôÚ>;FÅ4µ×û¯ÿ4¥öºÿuÿæ””$µ×û¯ÿ4¥öºÿuÿæ””$µ×û¯ÿ4¥öºÿuÿæ””$µ×û¯ÿ4£ƒ RR;²(Çh}ö2¦Ïp`ŸÝÝbºOk‹]•K\4 ØÀGý5…ÔhvWÖj)}¥ÔãPr.k^ÝÍÆôjõ+óû?Ke¿ÍÚ{=Ž éÛìéUØÜÛÚz…Ïhk ®}uzþË,§ÑúK+IO¡Ý“CC¯µ•4˜î ÿ×sr¨ª‡‹A{¶ç?àšõÎçaââUˆæ~ÑêÏÆ´Òu­­ÿ œöÙ»ìÌgúõ¯sø]˜¶?Ô}4–¹ÂbaßGrJmaÿD£þ-Ÿõ-FAÃþ‰Gü[?êZŒ’ŸÿÒêó.ê-µ•aPË$>ÛžYScÚÚBËï}ÏÿŠôÕF^Þ Ì7dRÐæäY]µ:,`¶Šó(·gï³Õ¯ôH_+2¿NŒz.{mþvú×¾¶££Ô²¯ÖnÿKÿiÿý*ƒk¢Êp+ebÔ-p8š­jË÷=øöúŸ¥þsùÿÓ…IMöác³1ù­oë4VçIú ú Ùô«¬»³ÈÈÈ <’dV6VÖnþkþ¶]m­’œ^ïûr×>Å$”æ3 tæ^ûë±ö¿Ô³eÖ±¯y>§é*®ÖÖ´ÒI%)BÊj³é¶Ou4’R q…/sšI$’R’I$”¥ÏýmIJΜÜÚ4ÈéïÖ蓵§ô¿ú.ÿúÂè?Ö.ªÎ†M¸¯Éªàkt@¨n}<‡ûßú_ø¤”èàå3/œ¦}˜×ü7s=»ÿ›U:ÿü‹›ÿÿȼû£uÞ¥Mø˜[éâ›Ú –Øöú•¾×·ùKWëWXë¹y=ÏaĽ’Ï`ô¬öú{ÿàÿ›IOgÒÿäÌOøŠÿê²ú°}¿X:E!À5¾­¤DêÆ®{¤õ®¿Nʲ«)éÔ´´lo»oæoú‚2JRI$’”’I$¥$’I)¨þ™†ûrmsüÊý+Îç{«ÒØÏw轟è’=3 Ý?öq¬}“hg§¯Ñï§ôýMÿ¤õœõ´’S—g@éÏÈvLZÛÞÖ±Ö2ëXç5eLÞê­oæT®äUYò¢ÐêÅdmw¿FnïSvôu[7»i{ž^ XèÚ÷Ö8üæÑe{ÒSèÿ•ù®WU,óh·ÔÖ½þ«¡®qc™ÊÿÚïÿÏi)º’fÂÀlhkûµ§{Gýq̧ÿ=©$¥$’I)I$’JRI$’”’I$¥(]MWÔênh}v ¯cµ4’Sæ¹ÝÞ“×± N¹ú6sö~¯k¿Ò³ÿ¯þ¸º¯;í5¹ŒÔÄw¸þqªÂÚßþež•‹¦¶ª®nËZÐC€"}Ì>¥oþÃÔžÆXÂËÇs\%®ó\×$§êïIn'Cm}<¦—Ý#ý(þok¿ÑÒ¹¯ª} îê¶ä^ßÑ`XêÀ?Ó·ó}Ÿ«ÿ9ÿè¯AP®ªª´0=Åî÷{¬³ûi)šI$’”’I$¥$’I)I$’JRI$’”ƒ–qm vÇlt:7FŸºäe[5Ù—ú5±íØíÅÏ5‘§æµ”doILðÿ¢QÿÏú–£ áÿD£þ-Ÿõ-FIOÿÔî,ç¹—a¹¬u‡Õwµ»gùœ¯ôϪµW5ŸlêÕ`Zç fÐëÜÖ9Õ›¾¼j½KqÝUÞ;¿ÒÆ bdãâ»"Ç\6øs+úMüúÑià¦oãÿ‘IM´• ú®#)±õØ×ØÖ¸±ºûœ±ŸEM½S´sA#Q¯þE%1ë7bôÌŒŠÖYS ƒž ÛþeŸþÿ\¥¸¯é'«ºÐÜúÜ×–—½ßje£ô˜öú¶ÛúNË?KJèú•½;?ÌGåzl²79ŸJß³ÜÏÏTîgMfC³Íßj¶¦†bÐáú*ôÜz+gú?ð‰)?N·/ýK+4ב–À÷\Ãú?j²Ç–Ýe„}¯-ôþŽÏVÊ™w¯“eþ—ü ß\þUµ£…V;®MÎuW´N¯Zºð²>Û¹Þ¥_gô½jý:îõÒS¾×5íi–¸‘N¡U~L®gcCgÇhÚ¦’”’I$¥$’I)I$’JRI$’”’I$¥,~¥ÕìÆÍ¯‡c²ÇWê9ÙVXeÞTÑé¶ßRÿ¦¶Vm†¬§tӖ˘¶±[Üâ77ìù¿hô}*Iú?礧N²ó[Kãy»i–îw¦çƒRTúN=ؽ7óºÚ«k_¬êÐÝÿüÚ¸’”’I$¥$’I)I$’JRI$’”’I$¥,ÜN¬Ü¬Û©mne5TÛ[cÚXluÕúµÔÿÙÿAú+?ÂÅ­%œ1í=_"ÂÒ*³ºÃûoËuŒþÃ-­% £«ä¾Ìkm¡•àç?f=›É´Kl·ùTú~—ë¾—è}+¿Gê~•l.{2ÆôþŸe¨t×µöd5XÚeßd÷z–}«}~¯©]_gý"èRSÿÖî^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÜR^’J}Å%áÉ$§ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/fitdlg.png0000644000175000017500000011337013070106167016603 00000000000000‰PNG  IHDR®Gù¾¨ÐbKGDÿÿÿ ½§“ IDATxÚì½w˜Çÿÿêž°³»³9ç–%ì.9'‰( HdYHB²-ÇŸ}>ß}ïîùÚ??÷>ßÝÏ>ËgŸ“¬,’L @I –ÌæœÓÄî®ß³iØÙBÒ.[¯çiØ©®®™®Ou½ëSU]¥î BN|ò ÍÍͨªŠÝnG"‘H$ÃEQHII¡¦¦†‰& (ÊÿŽ­[¶“ÙL~~>999X,™ó‰D"4!())¡®®ŽM ³a4ÕדœœŒ×ëÅëõÊ\’H$É büøñܸqÝ00ë†Njj*·›yóæÊÜ‘H$É BÓt<ˆÕjEój¨^w=±±±2g$‰D2DÌ‹zò“2'$‰D24„K7P§LŸ sB"‘H$Cæõ¢†Þg4Ãè}¶¼Ðu„áÄ¥ ™Ÿ‰D"ùbeK€®k˜‹‹‹™8qRíÝÃÉ·rϳ?`̨ì>RÅÚeÉÝRð²íOÛÝ¡–PF„XÈ›0ñãFÈ–H$ÉGÓtÌÉÉÉO·:iu99ö4Ÿú€ãŸ5㨌`|f"Ó,#ÿíWI]¾† ïï@­©`ýßÿÌQ‰D"‘|±Â¥ë¨½u¶œü!Â0ˆ×¬Ì\¾–'Ÿx‚tSÿûÜVB®¾Cö¬‡Ø²e+[¶l¥ Ñ#sV"‘H$_†¡c¾yŒ«¼¬›-ÃÑ¥pN¦„: €#‡3u9sWb RyX¿~õuu\»R+sW"‘H$Ÿ Õd"1)«5¨3L×4ÌÑ  !**š1spüýwHž1Ôú @3 —¬ä“ÓùX‚ÔÎk_{íufÞÿ(YÙ12Ç%‰Dò¹Ðu«—/‘•=¶ÝÛ2¨(/Çܽ£ÐÑÖFrJ*N³o²…ËÑBMáIÄÈȪÊãIð7n¹,‘H$’;†ÉdÂl6wy`ªÊ¨¬Q˜…aôˆ,ôfZ »d%±ñhØY8¢×^=ÀäE«˜;wNgüîK$‰DòEáõz1¢§p)¦p6nXßÓ«z,³›XÍ ø·D"‘H$_šWC5tCæ„D"‘H†Â·Va K"‘H$’A'[¢Ÿ÷¸$‰D"l蚎hr†D"‘H$ƒg[¥oä»×­ÒÜÜ|WÜOxx8™#†Ï:wÒ~áádfÊ54%’!^)€vw WaAñ ‰Lš2õ®¸Ÿ’âbJŠ‹IKOe´° €øÄ;c¿’â"JJŠIKK—¿D2Tu ðhúÝ=9ÃápÔË"ÂC‘ø„\.×°)¤mŽ6’’îŒýââp»ÜòÉ—H†8ºæE½›=.UU¹›îOUúÛ?ínÂtí§ª ú0Ê;‰änåKU( oîÚC«öåÍbì.!DÃÓRÁ™‹UÏ ÖCAAïã½;ok5ç¯Ö|!yéi¨Áû%O@UUS¯ö»å¼STä;‹ÉÝàqé—|êÎoÿ.ßþæ½J°¶ð<-1cȰ9¸|½Âï\å‘CLÙ¸Ã;¯óðš,Î;Kvro}p–ÆúF"£# ŽÁ=c#(tD265â ó¸ òóÎñ|̪ÊîßeÑûæ$óâ‹/m1Ѩ <ϲe¹(ŠÂêǾF°ªt ±üæç/8Úν>J¬Uý ¦¨j¯WÑ¥S¼êfÕÄþ?}Ä‚þ_f$Øxýõ-DYTšt8|$ŸÅ ǃ¯Y‹í¦{úã/_'~T(ó–?@¸»”ý—óÐ’Yl}ñÔøD@Q`Õºõ4_½ÈáÓçü~‡ÙšÀÚÕ h*½LSHÎ’K\¸QˆÉdfæ¼…$F‡â¬+¢Øɘ>ìÜ›ýê‹ó¹Xêd·X¤Ç%‘ e„hºxɧîM»xåÕòö«4Ê+ø»ÿ G¼“Gös­%ˆ åbxº¦ùËUø·Wñÿ~c§ßÞƒš}¶ØpV=œÉóÏý…U›îŒûéÎ?3zóÓ˜”Ïw“n· ‹Å‚®‚àȶ—Ð’&Ä¢ xÕÍœ¤`6mÚÄŽß¼ÊÂGÇóò³„ÆûV#Ö#³BðÒK/ûe`᥉H™Kù¥óÄäå}áFs»ÝØlÁ7›’£;· %äÄü¥sÙndf¢/Þ† ëÙýÇí,xp [ŸÇ«`Fä‚ß>jÝï©øê'„'Ï¢òÊ%brÆ3%½Ž³5˜RÉž}?S2ìl}}AªBü˜ñl3¾[ã·Ï²ù©1<ÿê6ï)„ááõßÿ†Ù_û™1éœ~þy²žêÝÎ.×ÍöƒŠ«Ÿ²÷T9TV0gö”[Ê» ›M>ùÉÇÐ5út O nôrÆLžË×{Œu«¦` ›Ø•€ææÃwñó]Liylxh‘¯uk$77×ïHt…°~ÓÂ-*ŸU”1)=¼×ï}pq:¯õ‰å ÿùâçò¸„Ÿ0+,\ûKçM";ÝÆO~½‹ô¤°×9Ê?åšKgö_¥|ª¨EQÈÍÜsP*ËŒáñÇ'ï‰Ö7˜1cUUUüú׿æ»ßýn?ˆÂüUX8;Qi6þ÷ï÷’šàž*ÏqÃ¥3=g gŠÛP…ñãF×À”Â’¹£Y¿~99¾{OÍžLÃ¥™÷à*Ε´ÒRr†èÔl‚×^{W^þ#?úÇßòò‹ÏñãŸþŽ×^{óç/P~ìuÒ­¸Éc´²vóFönùPX¹0׎•£ë:/ÿ×+=~³Ét³ý-¶6¯½¿GÜk×®1kÖ,ª««Bð«_ýŠïÿû]ß­(È—í%’¡ÃáÄÜW„Ke°nÕ2.ž:Ê‹/¾‡§(ŸÏü€sŸàz…Îìyó‰>q†ÉY©}~Ù›×¾µÔ·UJPSß?Ìž±ˆ–=;`ÁZžüΟC¸L¸\®Îeñ…Ý·›—FkS#É6/eׯñÇËg¸RoæŸø4šæÅãÕÐ5ƒ§ÑÐÊo¼ÁÞ½oâiÿMÓÐõžÝ]ÇÞz“Z—FkK©v¨..á•‚?q­ÁÄO¿÷dŸß™7a:ãÇeó»×êØôÈþ°·Š{ü]'Ò3²I 5á:ñ2öy?fIšïÔÆp·œÂ˜Ìú9Í´í·±qu[Ÿ;Êšöž6±Ä¢º}ãpöô…´îÛ‰iþjökºFý홂ÇíFÓ´Î|HKKeíÚµÜwß}<üðCìÚµ›={vwË;/ÆMy' ƒ-/¿JHT( SßOJ°ù¶º/ª+ªIHömøsæÄ&͘t[éœ=s’I“§ài-ãB…•É£ãtýÅ“Ÿ2bÊ$lªB[åEJ”LÆ&÷â\>}Š±Ó¦ËšP2dP…Ĥ¤¾=®ûº€qSç³áá%Te0'9€ Óï㑇VÖï—}7Écº<53Zß°áÆPC?÷MªªŠ®i¾®±öAþ9Ë \ó6~&“F‡1mî=è­?øö“†A}u §ÏœåÞ5ëyì±Çxì±ÇÈÍÍéL׎!Ù NÊœ.U_ñ;»‡‚o}ëYžzê)Þÿ=öìÙMll¬ßù@c>s—­$ÂÐH7“‰£Ã™6wF›Á÷Ÿõ‰~cMgÏçžÕëØ¸q7n 777P±`L£‹Jεºë¡±í…ßcNICÑ9FOœÂ¾÷Oû]ñÙÛX07ÎÏ+zýÔ넪:žNÉ©=$Ïl—FáFWBzµŸé&ûÝœW7þÎw¾Í¦MsìØìÚµ³ß¼3„ÀÓ&xèÁyènK´À×|`×ÁÎÏ‘ÑQ·ýPº«‹9]ØB°cË~ÆŠðõ£ÆÄ±åa°}ßqÆø‰–àâõ‚ÎO^gï^TeM(’ô[rë*KØó×m¼°ó(?üñ·œpKSGàÅþBe$-쨰÷ymÅÉ=Œ^ìÛ*å…ß¼pÛ7§ë:(Š_‡"X¸z-ó§fή׶ðàægˆP=lß¶•ðI™¾üœýõOù?¿û3?zö›; 1 gkç>=Íù3Ù¾cãV-bÏë{¹vì𮎠öÙg¿Éž={ü*^Ã0Ð4 Õ¤ðL>º†S³PLìݶƒ‡žz†(³Æ;v1i"ÓW|ƒó¿ýüâ/ñ÷ßû.!ÎbÜÎV.œý” ç³s×.Æ­Zľmoqý£w©ÈÏgîªÍˆŠs¼ßÂâÅ‹êbß;!€‚ qA$’lt¯Ýë¦õzsf÷)ßà ÁÝÉοîàÃÒPžï³ó©=Œ^<§½«ðåÙϯñPø¿ÅîÝ»zä®ë¨jÿµ«á:¿üÍŸyëÀ~ôìC×u^üíK<ÿÜ_Ág§Þaÿþ}üÛm!øôÈaò/çsèÐ!pä­#¾¼m.âw|™½{vñÆwÑuŸ|çïØ·ïMþý[v…ÏXöçm#ÿãC¤Í\á7yæfïìÀ¼¹{;vÀ–Jn”‡ßÿéU&/[ƒr“‡uü“Ÿ«O¡V)ã­½{øÅ¾$kBÉ¢Ï&æÅüsT5¸Xxÿ*ìÁ–^ã=òȪan§‡¬‰³˜¿¸ç¬±‡¦Œæ—X4÷óæï=Õí ó²?_á™§|×=ùÝ'o_¸ ½GK[ÁÞ¿þ§3æ/äoÞ×~ÆÂ£«×€œ<²›Üy«Yº`*­õËØµç^}*…×/–0†ßüÛ=í•‚`ÖØ´ˆY_Êûbº®a6™Õbìݵ§®0cþ½ü°óž¬¬^³€SGv“;ÿQ–Ì›B[ƒïžt1•’ OÇþë½ÉÍ…1‹äQ1\¯ŒcíòLÆOCByåmõ¶„ó䣳})x#Bv³í³,š³–ÈÔ”ÿ‚wÚf6|cs¯ÚË&ž~ÒgçÇŸ}|@öëê'¾óÄ-幦i~]Ž\¾tž}ûö£( K#[ðÔ³ß"Ò¬rù|~@¯tôè Ô6ž¥òòIP&/\LþÕ*–.]êó½×ö²þ™oeVyî7[a DŽÎdÅŠ(yîU_ù¾©+\QTÖ>8—ÿùúûüŸ.ÃQ^ȱóWºÎ›‚Yºx>Š)±‘TÔ+Ô•7pâä%fL˸¼1ür÷nž~ÆÞYÞx —×Ë•¯±/|?csfqì¼Á׿±’D›‰ü_¿!kBÉÝ#\ãÆO`Ü=zt°ØÄ„^ã'æÌE¯ü¾‘»±–5_[}GnΤªÇ„V¬Zå×Ís3Sî}°ó\Hd<7­!5nZgëµ£lìä9½¦s§‚ÀSº…•«éóÚ© êü;4*ÇžØ@VNÏ1ŽñSüw´56ÓïsL²oÍ¿”YÑÝ~‚‰åùÿ†Õ­¦ºÑMbTPïð4Õ±ú±GûïêÕïÜö@/ ›ËŠË»É¿O`BM®„¡óÊó/³é{?àâgW»ÅØÄ8[x{“ÂÓk[\6ã‚Nv½{ÙRlÛö¦ßó“ƒRa»aªCƒ{?æÿ¼–×w½Í¦UKÚy9Í¥¨ø1+$‚0ØáÖH´™ 4¬QÖ„’»G¸¾HRâ8E%t§úAU†¦£*Ê]a,ú|yÐõC[ÂIìe¸g v6ÝIû ðä‹ϱ{ÏžÎÉ÷®¿ßýî/ŒBÑ•JTEA×*Ù»?%ךÕpóî;Ñ®Åm¬ ¸[ 9tøc–.žÕ™ö=Wòü_^%-!Œä¬ø€?ë…ß¼Ðg¯BHÊîOq³»JCcWÎJå‡GÈûáýL¶'òÉ¡¿’³p¶ˆFY?á\i+R}ž×Å·¯sÏÆ%í,AxÉqvîIÃÝ\Ãô¹ÈšP2´ê¿û»‹uëÖS^VFb|,YÙcîš›»võ )©iX­Ö»â~4MãúµkŒÏÉ…óNÚÏëÕ(¸qqãÇøšçŸû‹7¶D"ùòë+—əŃ1 EQ0‡†ÚïÚNJNáÂùϰZ­t¼Ãê[þGAQraº®1vÜøaS`“’R¸pþ[·–v¦§¹Š8YÃÓŸábM6É ¼öÚë8«Op1ÄÍèÙSÈÍË_aóæ1ìþ˜ÖÜ‘„*N>ÞµìUËI R¹q¤€Ü¯OáÌ®?3ú©§1+]Ë"uÇívÝ5ëJ$ÉpÁãñ`³Ùn]¸lñ)Tüò—ˆ¼©457PQQ‰0xCF2g€àÚg§9²}/î®îâ;ÔÔ´ñì××óá§•Ì–·õ4Æåtªb}{0mܸ¡ÝãRx'ê!rc‚){ÿeÒù¶™¹"ƒgëYÊÛ,þ÷røp!k' ÍY Àƒ‹2xíh›¤ðÒï^æ‰ooºIµ}Û6(ŠI–‰D"*Wû2m½žïSõÚZü„Ak›o žö¼N›5[ÊJ¾ùÀ¼5'xÿô›|úÙ>(¬å‘Ü(S8 —ߥ¸Ùï!ÍâÿµB˜Ú¥ε²0÷ðopü×^i%»}‡e»ªãî&6UéÁD&PÀ*2ÍX•uc¨¡¾¿Ì‘c\‰D2=.UÅ·áqZ3õAvTUEQTTUEUÍ ÚÇ­RÂxñùßžƒ£±Š­ÇÍL ·Ò±kl—ÚY™<{2†¡¡¨¾scÜ—:O—ß8ϾÚÆûz-ç.Éf÷'åç3Ëuk|ûO-´•`/ìZtµüä²—ÌàÅß¾ÔãtC—ïpI$ÉÃ0 L}ÔݽŽq]¼\Ú)4sNìÔ£‚Ë—˜>!‰Óæ2qšO4š*kxæéU~×ÛÓ»¶„8öò ˜¿j #—ŽÃ+À¢@c«™ÿçé®-ß#²—¢¾ð<Þ›±(0ÿñ®tG®x‚‘„—Už~Ò7^öäwžèyóº!…K"‘H†œpé˜Læ[®œœñää lÓˆĸa¡i;ÿΛ4Ÿ¼Ió;?Eu-ã1~ÂØ×®~l5Õn£zßÜÝÝXÇêÇí×Ý”/ K$ÉТ¿å"»ª%œÄ¨¾ãE%Ô_:íc\&“œU(‘H$C…ÏõòPÇd2õ93E"‘H$ƒaô²0üàõ¸îIÉÉ|üчø¶tÂ7T×ñ· œa¾@&ÃdØSC Ìåt2*+kx Whh(S¦LõuÝþñe” “a2L†É°A&„@Ó´á)\@Ÿ7/‘H$’¡‡œ+.‘H$)\‰D"‘Há’H$‰D —D"‘H¤pI$‰D"…K"‘H$)\‰D"‚˜eôÄÑÖFuu•ÜËK2è %1)‘ÛÉ2.¹K %!1I ×­RZRLzF&Š¢ÈÌ *š©©®&.>á¶ÓBÈ2.´4v–ñx)\·‚ÅbÁ$3B2èˆŒŠ¢¶¶æó—q«U–qÉà,ã‘‘ÔÕÕIëVQTUn@)”¨&ÓéÞSE–qÉ Äd2!„ñe — c5âbЭKÂèX<À¹Ž•‚¿Rá’Ý'’ÁÚ¨R ݸ ÉÌ” ÖBÞoïS¸t]çÓÓ§hiiö `ƬÙ=°Ý½åeV®ÛÄ–—~Ég¥ “F%qhϬ~æGLˆðRbÁ´Ì&¾ÿ?Žrï$ßN‘Žj›¿ÿTg¿øÅ¿’–ÖµCòº 0)ÐXz™¦ òߣ°ÎEC]#Q1‘Lž?õ%—˜ @ÙÑ×I_´²×ßž>‘ÒŠ Ss“PU£¬¬œØÔ‘xÜnÊŠJ0[Ì=.«fUAQÍÝÜkxcU#Éq>/2">…¦ªúaÇМTTVR[SMy{…ÙAc{#è'- †&‡\û-¿ª°+Þ¿Åj"Ún¦¡©ª:)q‘Ý(Âܽ±Ùþ !°Šž6ÞPÕDR\d»ý’iªªÇÒa?“C3ÑTÝ'¼=ŽU(C>Ž¡9|e¼ºŠòª¿wc]Cçç¤%é_sú+ãw°¦PY¿~‡_/¤¶¶šÆË—©ª*æòe0áá‘ì­ ­ 5Õx AKk35ÕÕ„Ú#–.ŸÚ;4Æe ¡ªàéYñ¸Ý¤d¤u/â~C\†lƒ›Ã½ÝìG‡ýnz¼7ÙX„2ôãÔ—Va±ƒmõ­GCu5^!hniÆÒ^Æ’–¤ÿ2.ô/ur†¯’7a2“6nÀá<Æ yë?Ehh(öÐ Àa˜Iˆ$*Ò†Þþ4Ý·l!~u VEAsº !&"»ªã6Á}ô ë·p+•ULÉM§¤¢†ÄبN÷4ÐS-LÝän¥›Ã#‚š<:Vº»%$á©qa±±© ±qqDÅùÞÁð:=ïcˆ¾Ò~ù+¹ýþÿLJÁV—³«›±«WAíì]&£‡ …w/ †§%8á­íŠcV³t³±§B"1¼5C>Žb(ãññ¾z]ÞÎ2n÷Ÿ–äó—ñ~k{Ã0z¸m½Mǽ|ò=>­¹Êò¼1!˜”«°uÛVFκCwb*~úˆÖÎÏ%)ÂJѨ+|p¶†Y@ŵ‹<ðèÞy³˜ù£.q-t.œÞ‹ÛÌ]’ÍîOÊY?3%`w€=²~@™ÒT[ALr&º¡a.Ú<‚ÆòR2²FtŠW÷û £¼¼ƒ0{e…%¤d¦õ²SZT‚+؆Çé!%3–:ç°ˆDIq !¡6̶`"ÃÂ{ºñ©ý¦%é§ah¨Ê­Oc/+, \Æ…ÐÐ^ʸxH”²û¹¼¤d¤ÑR碼¢U„Ùí„F†RVTŠ+8¨[ÇDiI Á!6¬ÁÁDôRVCRúMKÒ¿æ(ý¼ª¡üìg?+W®¤¼¬ŒÄøX²²Çty1ºNAÁ š›šüÇ”"";vœ¿—"4Þùè<÷NÍáCïÐÐê꜋œ<š »…¬ ¹T_>Íéü4Ý(VÖ>r'ò›˜5q¥ÇÏ‘:sç?:Θ¼D.9È‹³±í…çYõÄf,,—N¡.tss¢ç˜Í¦Îßn6›Ñ4­ó€Â×É9J– É ÃëõRS]ErJê€âw/× !(*( säH™¡’A‡Çã¡¶¦†äŸ£ríÊe2GfqààAŸ¨)Jß—Éd"+ktÀs7O…G1³hÎ$–fb[ IDAT®x°×4GŒŸÊˆñS{„Ïš @êÌ äΞ @^{eõc«©nt“Õs,+:s cã˜-Âï·wüÝ[W¡D2èºQnáä@e]qÉ`FU”/ûä/ðf,á$F>Ÿ|Ç+‰dÐ —|Yrwò~˸\ó%P¾É, jÄ(ã²”K†.òÅ™˜Ìf ®_ó-`¥tI™‚o¶‹ “a_U˜n褥§n¯M–q6(Ã]×IKÏÂu«¤¥g`2™Q”ö¶m×?¾w d˜ ûŠÂ„=Ç—o«Œ§Ë2.Æl—ÂÃ00 ̉,ãÉ DŽqI$‰dè WH¨†ú:™+‰D"ùÊÑ4-`·¡_WarJ ååeÔ]½"sL"‘H$_)&U%#sDßœœ"sK"‘H$ƒÈóò_€[ŽqI$‰dH!…K"‘H$R¸$‰D"‘Â%‘H$ }¼€,„è\l¶ûßœ=q– Ó'ÐZt{ÆDη2)ÝÎ… øì³ó´¶8±‡ù6ƒDQظa=Âððáá³ÌY2 œzçSÍ ùòÞ:{@Aéü^)•MkæHkI$‰¤á¿ÿë<ûÍ'0´fþüÊ!¾þäêÎÓõõõ|ôÞÇ4]àê¥DŒËÑ+Í,œ˜Ë£Ì$77C^ûÃ!6lXÚ®[>á{{Ç‹Ü(+`Ïù ¤¶~†99…—~vžWÍglY1ëÖ­¥lßÛ¤¬XBñÎc¤¯šÇνåÒR‰D"éC¸3kŽáÍw?è<Í£mò;}ôØ1®\#:m4ŠÉŠaXM•LÕ±7pŒKãÿûÃ9Ô¢"Ì[0Z«ž”Ǫ) xûTV§NÂH/ ‰¡4ØÓ™_O˜’ Üà³3ïpìÝw‰i­§æã|â<å4XfKKI$‰ècŒ+fôL꯾K[ìT¢-þÑ~ðAò²²¸.Âøú?ý S]üÛ?äv‹%ز}ç K ·G°eËVš®ž"¢4˜2ÝÉäöЧ/Y…éÓOÙ°a)ÇwüùíW;k‹H‰O"{tGOŸ&.ò*ÛŽ\Á=pæãý¼tþ³¶×SóI>qæʵiÔ×ÕQ/—£’H$’ი-RÓ2z®ŠŠrÆŒ‡ªªì~íyXûúµØw,ŸóÆ·ÇRX¿v žjÞìÖß»œªœ$Ì]Çž#—bNÄ{ñm¼ª‡­[·‘œ>á© 2m<µçORZVǬñT¦fÕÄ<>*8!{äî]ÊC‹î¡@‡k±óÍ2¢cbˆŽ‰‘†”H$’aÄÕ+—ûö¸„a ª*Âp“>z±VŒŸGü™Óþ×–­xm±8+®±eËVZK®`/ÝJ¹îdr”C{?$.Ø Á¾ä+J˸ÒÜ ÷@a‹WÓq»=X„ƒã[·à7f'Mq³sß»˜BÂØ²e+†×ˉ-[ùìF«KQI$Ép#Ð^ÝÊÏ~ö3±råJÊËÊHŒ%+{Ì—í "=¦ÛK$‰DríÊe2GfqààA Ã@Q”Á°‘¤‚Ô,‰D"‘ ¹r†D"‘H¤pI$‰DòEa¾ûnIH«ö‹"í,í.í.í.…ëËæb~>.— !dA¾µ2¬l³1nüx†®í/àr¹¥íoÃö!Á6ÆŽš¶Ï¿p·{èÛ½±¡´ŒŒ[—laPS]M|Bâ-š]AUFŽ%…ë+U…y î‘•Ñmðé©“C·½-ªÉ̼³¤!‡‘í ÃÀl±0}æÐ·{þùsLœ<õ¶òàRþyÆçN¸åkÏ=#=®AñÃÍf‚‚‚dMt˜ÌC»‡Ø"mÛ¨&“´û ¨»¾ŠŸ®ÁásÉZèv ±a íïO|ëË_>Hznç!nïZ]Ó†—p~áOT[CýÂÚ<ñ|ýÉE~aÇŽcÞ¼yþîiay¾þØü“—?mL{½Ó±Ï—¯ºy¿¯ŽÏöëM¶:ŒysüáB´?]ï ›8·RÁáÿÜÃöoÏ<±Ð//œº@î´Ü>l…ñÓ²ï˜í‘¶¿mÛßJí_Z\CjzÎêbDL!&_Zn— wÛ% Ä(ÆØ­†ŠÍfæÚµF$7ÓbI¤îbÖŒ(9Ž}Ÿ¸øx¿o««­eåâv»;ï\¹Âk¯l¥¢vžÖÚ¼ŸV“5-‘œ°ëüøA¡­!px\¶\ÂÐuâU3‹7¬ÅQ{7OU³î¾Ùüå7/°ù{OÑV}ƒýgŠY³ìÞÏ'\BÒò&aJJBt«ð&åù¶,©9¾ŠœUL ë*d;·¿Ìªµ›p”JYÍT²ÍÅ6c^^»â¶ÔðÊ®÷xâ Ÿú-™•Æ®ýGY³b>ïïÛEú¬%,X¹¿¼ø#ž|ŠOÊ䙓âüKçyú{>ƒýü¹?³rñL„0¸xå"›¿û÷€àçÏ=OfÝq¦mz–™ñÁ´U~ÈŸÞ¸ˆ½zxÄY¹xm5¥„Æ¥¡   !HÏ›ØÃö“'øl¿uëÖöV§àØ©P|ÉÍÍ%#ÒMYÍTÆXйÑôsór}­*‡ouÿW÷å‰MO‚Å3SÙõÖ1V/ŸÇÑ·ö>s! 0ù^~õu27=ÑÃö¢)tK×.³ùÛ?aðóß¼ÀŠE3†gÔ~Ì´Ç}yÔZþÞ‘Ohíðˆ³bátÚêJ MC@Åiè^ùÓ+<òô³†ÀjO#/ö3Þ;}“Gqÿ£s)(>@°°3õý|ò™£óÚÂ+78òö.>8vUßü¦|çAv~ô:éfžéžÜ´ CÓ•5žxaèüú/’óìfæÝÿ(¯lÙÊ_{¼§ÝYwUNîdyäEÁм\¹q§¾õ#:?ÿÍK¤UÀôMßdF\0Íeð®+|û‘1» yD7‹Mg¹ïv­¯û°ëÐuEQzx0×B˜œÌ=÷ú÷¦>t GÜÑ£Gó¿ÿõùÓ_^!ªõ:Äùz\tŠ‹Ã—“ƒ™|®µb²9râÉMû¥?’4ç‡\lô0.PÃ¥{ÞôuòÂ…|NœÏ§¢¢’ÝGÞãÊåË\ºt“~…s.°ÿ’ÅO´B\&j¼oìù˜øÐH\m¼š“bÂ0 4Í@¸£‰öž,ö4⩦°º€jâI³[Ú›î&šá4»Fqwþms*¥\uwú6§Â‰"ÁÌx_XpülŒÂãÃ&Îw¶pÅipËõü… œ8‘ŠŠ vu³½ª]áÜ…|Ö¯_ÏúõëyxY6Êì¼ÎÏ99ãùëžãćFàju µÛ^š×‹‚Hgs§í­öt⨦ ò:uj"©¡>Û«& ­ö€¶ï°¼˜:l¯¨Øœ½‡ûåQÂ,ôÂÃ&Îw¶pÕa°ÓròćäM™Ã­¿ã{ÿô;¶nÝÆÉCg°Ô]¤Í¨Á`³Z°X­â_AZL&æÝ{?ûÙ?“#*™6/’sN‚oD¡k:QžVnÖNE5aöµW°VšC\Ù~uì M­uìúëvžß¶]€¹ã™SLØœ‚OŠaF\Çs9QôIÀ´<ÁÁÁ~GDDD¯]~º®w?ùÉOæ_þå_øéOJpp0?ÿùÏýâ躎v‡Ç¸EáìÑ]8\..×6ùí¿èvéÙš¸RЂ¡ÃÀÐ šo\¦%؆æÕˆñ¶¨ 5añBŽîù´ßïW‹ŠŠz=™››C’ð ˆHÅhƒ¬ìÑ4•“ÕäèqÍ¢5syk×I6|íq¬¿LUUüZ{.=ØïºËfÿòðŠ~á6Ý×çš75¯×1.].¬ [çßA¸üÂãÌZôŽÖz3sܰ‰óÞ'%„º}Þ®1€Ú+/7—ÄvÛ‘Öeûâ ÇŒël¿ýö5ž9Škµ®N˲½ÒÍöNÍæ÷]ó–=ÀÁçßá¡ûçùY¸7ÛwŽ+AJ÷û î5<ÎÔ•G†Ö‚×7lâ¼w²„POÝ€-3fßË”Y“Y4>†óëׯgù”ÌYú ¡ªBqi9EÕqD×SVZêwm³Ç˾w÷q£âS”[™¾ôQöýô§$/_ŒÜº-`÷—Ǥv³»¯2¡gþ+Ÿ`6ó·ÿý¿±êѵ4ÔÜTæî¶iÅcŽëKr»:! š››üŽÚÚ¿8‡¯ñïí<~ò“ÿNssû·ËOúSš››ø›¿ù¡_Móâõzïè4™ÓÇöóïÿù.å m,9…uk×±hÖrÖ­]CˆIe„ ¬[³ {¢‡5x¶W«1ÄL“[Cs7a mâÔ‡§PT…z›ÉîjÀÚÄ‚U³xi÷Çaðñî—˜óè=Ã&΢ٙ\¨ølÂÎÁÞöÊnóÓ÷q½è#.&Á¢‚|tx7)ç1ùÞE\<øM¾DwÛ‡Øì†¯£Ãö¦›l¯š¬<ûßÀ¬ø—älQßûþ×9¶oÑÙyT\¾JLv!f•‚‚Ë\+(Àc‰çÁų}W[…EuäÝdw!$§ Ž}ù ÍÁ;û÷söü–?ð0Qá!LÊÉâ­7÷qñZ®Û@T|&¶æëýøa#g1wl2UU•DDDöŸêï0 ƒ†ú:¢¢czœ[°`³gÏêõÚÆÆÆ~í®i/^ ²¢‚‚×)¸q7®ÓP_Çèì1~âd6sîÔe&Í»¥š%=†¥%ŠfªŠ£ú8ï|tƒ‡×-Ç$ ޾¹óµ4yu¦ËãZþåÎrÐUÿ î<ÈâU ;g°Ô×ÕÍõë×;g Þ‘ý¸Œö (o­ÅââÀ;§¹Éœ^ã|pè-¦,¾à¡×®]eÆÌÙHnONgÔW¸ü‹ÐcÈÛàÜÙOIK¿õ%Ÿ ÃàÆõkdξåk/_¼Hö˜þëö ›- ]ºÏ(ìiS/&³¥óùTC¨Jïš y[9rìKv•ƒ¶šBΕº˜=y¬]ÿEíÇu«¢åµõ)Zs—ÞßW ²ºínޝödÅ܇hùl;wÉ}} K#ÞÁŽŸ@tˆ–ïù6  ˜MLæÐÀ¢Õn×¹K–}Î_>4L`ÜÆ3( Ú=¯[EÓ69#Ð{\ýÛÔâ×cô)Zf‹ÝO´Bã2™7À1Æ¡j{Yu}ÑU—´½4þ`³»r×áv†a ŒÛ¼ösŒq F†¬p9NÜn7&“ “É„¡ëï1˜ÌfÖK˜0 \Nç.´‡CÚþ6 ÃÀ9Dm¯( NçÝawC¿½ÉÂ0âö®UU ×``TV–oÅc!Ð4 ÕdBUUõ½3¤i¨&UQeX·0€ÑÙÙC¶À*ŠÂˆ‘#ùììD§í¥ïvÛ+ŠBæˆ|vöLç,¹î÷g´¿¯4TÂJJJnïZ“ù–¯UT…Q×”Âõ%ü•N0|u„„„ÜU{ I¤Ý%·†*³@"‘H$CV¸BBí4Ô×É\‘H$ÉWަi—«òë*LNI¡¼¼Œº«WdŽI$‰ä+ŤªddŽð BôãJNN‘¹%‘H$’AäyùϤ”c\‰D"RHá’H$‰.‰D"‘Hî á†.s\"‘H$ƒS¸šœÍ»¨¬©¡¶¶•®}xêëêº-½ß¡nO[­nßr)uõõÒJ‰D"é¤×•3 ¯ƒªê†ÎÏš°’–:°¥{…4;ÄÙ#pkî¦âÓ3QQÐÚª©wª¨Š‚¦i455bèM𕬤pj«Ñ ”Fʪ›ˆ‹ ¾®ŽˆØxLBzl‰D"…«7WÌBZf¦öí Ê*°™p¹ûÚšjŽfª±"„Àáp 56‚ªÚ5áqºq75`ÄĤ(ÄE…a1)X,6ÑßJó!†Ž·ÛNÓ¡Q‰˜Í` #uT8f‹µcLM÷NÞ8+º®‘–ƒ×ëEQMXL nWZL"‘H†»p!¾\FQA÷úÄO×ãîÇíîó‹ ]Ã-gJ$‰PEçØ“D"‘H$CÁã2ŒawÓBÈ‘2‰D"Ìšß%\ÃŒ¢Â¼ÒË”H$’AêY€! Ò22‘ y½=vÔ”H$ÉàÁíñÐØÐ …«“É„Åj•%C"‘H+ŠBSC:êðËE ‰D"äõ´ÐÛ®®-GºŽ;EC}Ý€â57:hm®Ç«‹€¿Ï·â†¸•‘¥B"‘H¹p¢wá꽫PhÔÖÔc2›º+.—‡ä”äÏ/\ $§¦át8üÂ[[ZhiéZÀ·¡®…øÄHªk¯“5* Íã ºÉKr|$W/^!6Ñ·fbxt •ÅG'c3)}бD"‘H/F·UœnM¸3q7-¤+ôVªë‚Fw¶6¢D˜Ýw¾¥ÑAXdMÕDDÆãm®Á‘€è¦¢Í-̪ðë¾³‡…Ûù9œÄŽÈÂðjhºFyU-£²²q»\DDF鋨ëDÅ%SYUEbB"Í M„GER.Y*$‰d#„@UM·!\h©­#:ðÉ—§Hg³¤ÒYÒÙ,V(D($i®nP,eð•f"Ÿbþú2bsËÁÛªÐêÜ8‡KÐw$‘Ðöe„……ò½‡x$Ž;tZjxd*?As}0LÅcwÜ£IgŠÄ#»}·¶Os–´z dV$î5îÞæ*"šb¢P V©íè‰ÝHV G+Ë`0Ü^DèŽmV„Å« $/\ $£ŒE-.<8_o°Œ³¹±In¢ÈúÒ+\½¶Fcs“~£ƒ­„%i46X]Yäù®Q­Öi‡5žÛÇulÛF |‡±h!%v(DF&“%žH‘Ëf‰†ll[ÐZß$ŸOãßrÔUhlúƒPcb"ËV¥u¸ƒ?¬µ @Dt—ÕÕM¦ )”†p2ËÆÚ K¯¼Ä+×®±±±A"nƒ†ž’D†á¿ÐX†©R‘l\¸cÙI› lkðÕ–övhû‚¬Þ0àªQ{Ç^e‹A¼övWeq†¼éÐ%,ÂRãëuâ£eø¾Ñ©7{8íÕ±èà>Õ«jÕ*ív›j¥B·ë©,ƒÁpï—ê÷ˆ¤gHÅIØŠ“ËMàw~@27F*“#6#†éó3dr9’ñqPšD"E&›!•ž §ß£öºÝÞb«ÓÆñ  LOOSžšf<HK]šÞÀÖ»­›››4›=,KÐS’°%öˆîõÐö0Ù»ˆ` çÎW¯ïS]_Ãõ.„ v„~à0ìñ$2pI•ÎqiníûÄÆ,úN@2¢iz75Z¾C˵ˆ[a ìð  ,ÉÍtÚ F§KÍvo0á§\'–×BGáÁV£y{Žë€÷n”åY_ità!-t!Íjµ1˜ð¬,“.äîl:N`ÇÈå'˜(ä†!ÞùBÄx‚|¡@<9RYƒáÞ;.+6†‡ïµé†3ô¶jTjU:îÖÐq(¥¨niRÑ“éëBܺøNÑm7É$ë[>•V…T"I:‘"•Çí´X]Ye}u…ÖA«Ú§Ž¯4ñd†\.G:'4‰´|5j‡o ŒÖ–×)ÓÚßBG“‡þÆ}ç¸2Ó—°$xë–—ÉO?H‡Õ•e²“eê•*ùÉl¡¨vzä Yº[ úhÆKe*+«D ƒI6¿×arº„vºÔ××(”Kž‡V‘HåÞÔ¨ù ¤@(ÍD©L¯Ý¢Ñt@ Ò¹,¨€Úz“âùÚíEoë¦jwì4™I +spS§¦¦¨V×Iyj[ ²^J¥B8–#³HÞG:^}ƒZµG8>Fr,¾«ÞìXæÐ² Ã!# ËÚ/TD·ÛÝ5§Õï÷öó€Ô7ÛL–ŠŒÇfq\xì1ª«är –¯Ï39û n·ÎÊZߎRTŠØjÔè{ K†°#IâÑ +×_!Ÿ`«Õ¤Ñéqn8žñ¼>~ ñŸ@)<Ëfj2ÏúÚ:N¿ËòÒH¦2ŒŠl¬®ÍgHg“T×+h­™¾ø2p €j‹âù"Úí<ùõ_ÿuýÁ~•åeJ… .=øÐ.¥HØÆõüá\“À²,´PÃX¥eÛÃù!%Z):ÍáD†Ü¿Q¯V)LOãíXÒШwÉd{.”Tn¶'É¥bx¾ºícþ•—™»pÑXˆÁ`8u,\{…Ùóö|/îé ö[o…l”?h·¥e¡ƒ`°þÃB(e…°Cn¿„°°,AÛ#@!‡l\×#‰A ‡oLóhü`ð]*DÆ,ËÆ¶íá»×qh·DÇ3Ø{ø…ÀíÒõm2‰(~°Ý¶_ýÁæ.\â¿|á £uGÊœá¸þÍ55Z8ú›&éõ°à±T)ÅȹíE¶PÄwo­t‹t69Jîê‘„c¤£òŽœÖ þÍdƒÁp:Q‡ì㺭蒷Ý.ßp& 4ÑÛï œw“/ ðýÝÒFÆnv”޳ÿª« ðwùŠñäþ~Á ÇIEå§uۡ»rÔÁ µÚw˜«ŽQî!žËX‡Á`8Ü›õj¿Ú¶ßIv}¥B”Rà B²GgdFfdFöÖ)¥PZçm×nfÎÍŽv† !R ……繃×FfdFv™Äó<#»«2‹s³æäŠ#9®v»}_ýàp8LyjÚÜyƒÁ`8£Èz½njÁ`0 gÇqÍ̘ý5ƒÁ`8CŽËTÁ`0橃Á`0œ$û¥ºÚoß­q\ƒÁ`81‡õì³ßCJ ­5ï2vt»^÷äëO—ã2§âN+¯†ì*ƾ gÁ¾”RØ¡0ozÓ›‚×qp]lmm1?ø©®NÄq]ŸŸÇus §’p$¹ٹ3{ý ó×ð\×ÜHÃ)ëMÒŠ™ÙYb±ídÝò†#ÓÐj5 …¹Õ>éŸNÄqyžËìœÙhg8,.^?Ó#-ß÷}N%ŽëÒ¨×w8®¬®,³²¼H(xè¡Ë9Ç%-ë¶€4~hϧ<Û‹m-c_†ÓŠ4÷ cGc1{ü õ:Zê–'tí鵜ñ¶Á`8¥Ï¦@ïþËd³!‡rçŽë #Öú#× N^9äâoýÚ]åÜFù÷Α›Ý»XÖ}ë¹nÃÁÝøw—Ê×ú–÷o¿|a¶gN±ãº‰„tkN³Ê¦#|ÅL¹ÀêêÓÓeü@Ñܨà(IÈÒh&›géú2ã©$Ý­6¥™é}Íçæfµ¹Q¡ãX(¬ð¹ôÞòl‚Å…E"±ý^Ÿ©ÙYÚ›»u– Çb8½>å¡N× gYgX'‡7ˆÁÝ+ë>gÄÒüuf/çÏ¿ÀD±@2“C¨€úÚ ã¥B#ݹ.àtšT·r!—>ø¾b¦œguuý›²É-¢d2q–¯¯0žJÐmw)MOѬ,Ë•‰ZâU;b4¼zQJíÅkà[/7Yé½€RŠ FËáU01eüv×f½ÃÜå˼ôüU‚^ƒTazt0X§ïpáüú®ÇÂÒ:cµç ¦]’q¨l¸ÄeoÇñ½)~Ùî´™:78ñsþúâ¨a½Uõš$Ë3¤ÂÛ`e½twë$nè8ËkSž¹¡³DÔkœ9‰\šV½†ëÄiÆb‘Qý­-­Pš.êl}ñHeFJ±gwk³ZA!ñmÛ¤ÓR©a}ª`pØc!X[YßÖµ,æ+›\¼x‰ù+W˜½|™«Ï_Åï6I‡6¥5ÇåüÜŽë±°T%ÔG6•ˆ *›.¥ü$k•uJÅ­zsoû2ŽËpjƒ)­ñ'\Ä‹M(ë8n@ Z(Æô&àÞ^¨p"Ÿbþú2bsËÁÛªÐêô[œá‰˜Â÷é!’kpLt8å5R‰EìЊ`ûd ö•·zšTxðƒ­pÝk¬¹¡cݤ­gN§·¹Šˆ¦˜(¨Uj;ÿ¦£JR–áÎ"yÝê2¡T‘òT™ ¿5¨ïfƒj¥B­:¸'Ýú©â•…ºˆH å»LL¤¸~} Qï¸¸Í [Þ@Ç ãºþ Øç{ô‚Éð ›Jay-§/‰„äÀ¾¢ÑÛ0 'Ú)ÜëaÇS8ž¢ïƒn@°Ç ­aµîì¸Bc¦JE²qAà:Œe'il6°-‰$ü’ÿ†ÅkŸ@DH¤’8½þ¡Klÿ%¬}åa©ño|¡öÑ2r ŽÖ>Z†‘œ}z³‡Ón°Q­‹†¨W+ÔªUÚí6ÕJ…n×9RY†£õ o¥Ùñ™HÅp]ÈXrL¥™šž¡1…_¯³åZ”†s†‰ôvÝ·‹r.‚ë8»tµh_¡¤@(ßïR*—Pn—ÆÚ:ùr‘À÷(— ›’’¹ó³(×!i·h6›DÒSŒ‡Àé;D¢q‚á鹑htרK)6œN|ß¿ { õáŽËŽ'Ñ® Â&“ôø<_!¤MzøÚw†K$‰ÝIy>‰ôá¡B!CŠ¥ÑëD:¹§`,™ay¹ït™‰=îO"•¼í² ‡¸ö–'3™í˜|ß!|“NLäðoJc¶C·×§P*ÒØÜ"“'O¢=!l2¹›m*4²©`XV<±}3=ϧYo13=…ç¸&Th8sH)½xHi³Ù`8R¨ðð)Üì/,ҙıøfóEüCòû2œVÚ€|;öy")ŸÌIÙrÝ…rÕ±‹Pƾ gÚqwŽëÄ—ïûøž‡5Lë¡”BkV;ddFvr2!J©3Ý8ø¾OàûHkpÆÑà·)ËÈŒìe­VsÏ»GvZ€R'ä¸ÎÍβQ«á>BˆÁ?)ÂÂó\#3²“)pî gVB0}î•J¥„ƒc#ä`­¡ïûFfd'$„# ʼncÍsJŒã …Ã''͸Ù`¸„Ãa&ËeS†S‰×Çü<&n0 †³âõŒã2 ÃÙó]'*¼ÃEƒá^!^ëÉ}^­öub« ¯ÏÏãÞ´YÓ`8M„#ÎÍÎÙë_˜¿†wÈ^/ƒá$†JJ+ffgµ²ðH™3îžç2{†Wn^Ý,.^?Ó#-ß÷}N%ŽëÒ¨×ïØqÙ–à=¯ÉŸŒã’–uòU ÷èù”g{ê×2öe8­Aó.„±¥ã8'qí鵜ñ¶Á`8¥Ïæþ)Ÿ´ÖƒdGH`///fÅû[‚ÖhvN¶i­|Û•’frö–ëáÿ7Üpßè¹Ù½‹eÝ·žëPÇ&„ØáàvÞ˽íá†)éáb—ö¶ÓÜϦîȾ †Sä¸öKùT«V¨TªJ33wé`ÇuáÂ…}ßtšUêŽÀ÷fÊEVWטž.ãŠæFGY„,…Öa²¹nw‹+WæyòMOâyÞ‘z´Í ]7@¢°Âc££åwɳ ‰Äc8Ý>åÙYÚ›w¢3ÎâÂÒÙÒÖÉá ®÷ʺÏñ¼°Èì¥ó¼ôü‹äŠy’™BÔ×V/Í"éÎ=p§Ó¤¶ ¹löÙàÏ•ó¬­V˜ž.ášf­‚ƒEH*4a²ÙN·ÅK?Xà‰7¾ßóiÔVˆeÊDmq@×Ŭ(4œN”Rû†â·G\‡?¿ÎqmÖ;Ì^¾ÌÕç¯âw¤‹Só´:ý>Î_ ïú,,U(—õn@!?e[xžG³Þ •Iè¸:-Êç.0}iÔ°Þ*z ’åRa‹Àm°¼ÞÆvÐq¬¬·±¼6åáùIgUg"—¦U¯ázŠX"ÅX,2ª¿µ¥JÓƒ, íõ¥#•e8)Åžî`³VAi‰hlÛ&•N“J ëS 5.6c!X[]ßÖµ,æ+›\¼x‰ù+W˜}ø2W_x¿ÛÚ”ZÓu]æææp†6•Ï94zšüĶmã{>™‰IÖ*딊¥ýíKÇe8­Á ½¯ãÊŠ$ÒY\7à°GøÀ˜ÂD>ÍÂõ%d4D½íà4«´:]ÂVÇõTßÃŽŽS.äð|ï¦À"‹Ü¡ ¶“—ÁþòVRáÌ §¡×8X'’F÷ˆWNocM’Ëç©Vj£àÆ ²£”e¸³Ha·ºL(Y¤¡øZµÂ+/ý€…kW/ç 7Cci¦JE2QIà:ŒçJ46›„,‰$$‡’K‚[N^M¤‡$)Åv¼S ¹¯<,5¾Þ‰i9PGko ÃÙ×i´z¸›ŒE«Å5jÕ*v›Zn×9RY†£õ o¥ÙñÉ¥b¸®GdxRg2•¦<=ÍäT)-’±§®´l<¥ e(—Ф£’Àé3ž+Qßl mJl*@b—MHí!¬ã©„9HÒpÆØqF¾PäÒC3wñÁã9.å÷Ùò%qK $¨ À ‡è©`˜®ÞCÚÔî9­V½¹Ï¥o–oI<5,Gú£ÏÜ*ÏÓ¬Vêh­iT–I³ê4++¤‹Y1…ߨÓv-J3ƒyÕdz»î[ŽÅT.‚ã8»tµàk”­ñû]J“E”› QY§0Y$ð=Ê¥ÂÀ¦¤dîüì(»ÌÍ6¥‡H4NàyûŠFwºT`:(†Ó‰ïûweᡎˎ'Ñž Â&“Í z™¾BH›ôðupSú¦D*9rT7ÿ½_(CÈùbiÇç÷’Œ%3 #/÷N"“Ûóþܨ¯Û)ËpÛ®¡£ÊŒþvúΜ˜ÈáÝd;t{}ò¥ú™ô8¡¡M‰]6:Ô¦šõ-f¦ËxŽ;›P¡á,u ¥¼+‹‡NdÒÃØ•át;®;0,­^ %,ҙıÃxÙ|ÿ<„ƾ §!Ä‘6{ÄuO.Þl4œÅ!×](W»eìËp¦×eŽë^à>žçaÛöhÓZ£5Ø!#3²““ )¯Ï0¾ïáû>–e¡µB©ÁÖ X¶mdFvb²­­±xül:®s³slnÔð}!BH¤),\Ï52#;1Y ÎáÌêB¦ÏÍR«TT€‰@H|ß32#;1Y$¡P˜8v>Ðq\¡PˆbiÒŒ› †{@8¦T.›Š0œÒHüñœ–ãôM0Ü`0 gƒ@)^œ¯Çe0 †³‚@GÒ'*¼ÃEƒáž™Æ«`=¹±/ëվ¼@ŒãZ˜¿†ïyƸ §’p8|¦hû2œV”RÌÌ΋ÅQ†>¡åðžÇ¹Ù9s §’ÅÅëgz¤åû¾±/éÄu]õú;. ¸~p2ŽKZÖ]ÉWe0Ü“çSží©_ËØ—á´"ê˜)Ÿ”Ò&å“Á°×¨åŒ· Ã)}6™òIÛÈ£±¾i˜¶ë½›ŒüÖ×û^ü-_»ßçvËõŽëÙSG¿JuŽÞêÞ½²î_Ïu$Çv£^o}F÷s‚Zߦîľ †Óä¸öKù$nù·Ÿçêwš‡ f•º#ðý€™r‘µÕ5¦§Ëø¢¹QÁQ!K¡u˜t2D­Ñ!l[´û3“Eôz´Í ]7@¢°Âc££åwɳ ‰Äc8Ý>åÙYÚ›w¢3ÎâÂÒÙÒÉ¥Øàúw¯¬û<œqË ‹Ì^:ÏKÏ¿H®˜ ™É!T@}m•ñÒ !‚‘îÜp:Mj[™Ëf þ\9ÏÚj…éé~ iÖ*8X„¤B&=nSkv‡6å33Y ^[!–)µ2mÓI1œN”R»Bñµ ‚áYtÒý=3Û¡+<:iì¸6ëf/_æêóWñ» ÒÅ)‚áY?~Ÿ ç/Ðw}–* iJ¥*hͯ‰„X_«’ʤt\Îåsƒóæ¯/Ö[åQ¯A²I)97{þðU…Zo®÷zï&#¿ñú0ÿ5%Í~ŸÙ-×;®gOý*Õ9z«{÷ʺ=בÛÞÏ»Þ× j}|›:Ê}4)Ÿ §Ùq7å’9ÃiV©;ߘ)Y[]czºŒ(še²Z‡‰Çlú®Gà´Ùh yhßW‡öh›ºn€Da…ÇFGËï’g,.,‰Çpº}ʳ³´7ïDgœÅ…¥³¥“K±Áõï^Y÷y8ã –™½tž—ž‘\1@2“C¨€úÚ*ã¥B#ݹ.àtšÔ¶2!—Í>x¾â\9ÏÚj…éé~ iÖ*8X„¤B&ؔﴩw—œ¡ººH,S&jïÓI1œN”Rw% ãÚ¬w˜½|™«Ï_Åï6H§†gýtú}.œ¿@ßõYXªP(¤¡Ù`Ó‰òšG¦p‡f½A*“>Ðqu:[”Ï Ž8™¿¾4jXo•G½Éò ©°Eà6X^oc»è8 VÖÛX^›òÌ…3­3‘KÓª×p=E,‘b,ÕßÚÒ ¥éA–„öúÒ‘Ê2Ž{ºƒÍZ¥%^ ±m›T:M*5¬O€Ö¸ØŒ…`mu}[ײ˜¯lrñâ%æ¯\aöáË\}áeünshS>hM×u™››Ã¹aSù44ëÔÝ].ã:™‰IÖ*딊¥ýíKÇe8­Á }W×%LäÓ,\_BFCÔÛN³J«Ó lEq\ÐAõ=ìp/ZÌ__BRZDbу;´µ}1ÁþòVRáÌ §¡×8X'’F÷ˆWNocM’Ëç©Vj;BH¾ï:G)Ëpg‘Ânu™P²HyªLÐvÚj6¨V*Ôªƒ{Ò©¯‘*–i¬,ìÐÕ@DZ(Ïe"ŸâúâVÔ¦Þvqš¶:=4¶Â¸C›’¾‡ áúбˆdaqy0ާ/ˆ„$–´ˆD£·;`4N´S¨Ž5m¡yùùgv\¡±4S¥"™¨$pÆs%›MB–Dl%Ž$‰T–d*ƒÛóˆ„m©Ä®Óoµ,)¶Ã‰JÈ}åa©ñõvHLËÈ:Z{ξN£ÕÃí´ØÜØ`,:X-ÖØ¨Q«Vé´ÛlÔjt»Î‘Ê2­Wx+ÍŽO.Ãu="cÉAx0•¦<=ÍäT)-’±§®´l<¥ e(—Ф£’Àé3ž+Qßl mJl*@‚dz`SN×%H¤öVˆñTb×éÇÆsN7Üù—ò}êÝî᳸Êï³åKâ–@ÈÁ±àV8DOƒ^¿ò¶Àïw‡£…"@X­zsŸKß6,ß’xjXŽôGŸ¹Už)¦Y­ÔË!+ˤ‹Ùuš•ÒÅ,ž%ð”F.Ò HΞN&Ç·¢ds9rù,™‰<ùBññù<ñxäHeîlÈ•Q©wÐZÑk7FrÏuñ\—~«J<;‰çz»t ¤=õ×§XÄì¡M)…Ó 6¥+$ðû½¡›†X”ezû2ŽËpZÝÖ1g( Q>©/6ÇlN+¯†Ìƾ ¯fû:ǵ0 ßóŒqN%ápøL/Ð0öe8­(¥˜™%;ÞÊ“Yïyœ›3wÑp*Y\¼~¦GZ¾ïû2œJ\×¥Q¯ŸMÇ%-ëXùª †{ú|ʳ=õkû2œV„@©3ºªÐ¤¤1œöQËo †Súl/åÓ¶ã:ÄHµÞ>\ïõÞŸ?ÌðoMIsP9;åzÇõì©£_¥:Gouï^Y÷¯ç:’c»Q¯·>£ûÙ‚ÖÇ·©£ÜG“òÉpš×qS>Á!¡B§Y¥î|?`¦\dmuéé2~ hnTp”EÈRh&›ñÐØX§ÛS”§'Ô£mnT躅-¿KžM°¸°H$Ãéö)ÏÎÒÞ¼q–ΖN.}Ä׿{eÝçጃX^XdöÒy^zþErÅ<ÉL¡êk«Œ—fŒt縀ÓiRÛ È„\6ûƒlðçÊyÖV+LO—ðM³VÁÁ"$š0ÙìЦªkô\ÍäÔ$Ú ±L™¨½ÿ5jL'Åp:QJÝ•P¼­Ö×÷}s³Þaöòe®>¿Û ]œ"žõÓé÷¹pþ}×ga©BÁt[uD$IØoœO½A*“>Ðqu:[”Ï Î7š¿¾4jXo•G½Éò ©°Eà6X^oc»è8 VÖÛX^›òÌ…3­3‘KÓª×p=E,‘b,ÕßÚÒ ¥éA–„öúÒ‘Ê2†bOw°Y« ´Ä 4¶m“J§I¥†õ©Ð›±¬­®oëZó•M.^¼Äü•+Ì>|™«/¼ŒßmmÊ­éº.sss87l*/è4ëMÖ›ÊLL²VY§T,ío_Ê8.Ãi fè»â¸¤,íVÓD>ÍÂõ%d4D½íà4«´:]ÂVÇõTßòµŽ"ŸMŽ RZDbу;´µ}1ÁþòVRáÌ §¡×8X'’F÷ˆWNocM’Ëç©Vj;BJ¾ï:G)Ëpg‘Ânu™P²HyªLÐvÚj6¨V*Ôªƒ{Ò©¯‘*–i¬,ìÐÕ@DZ(Ïe"ŸâúâVÔ¦Þvqš¶:=4¶Â¸C›’¾‡”ŠÍ®&ŸIÜd<§/ˆ„$–´ˆD£·;`4N´S¨îuʧÐXš©R‘LT¸ã¹Í&!K" F …`uq‘¨ ËKË4› ºÝ.‰TâЃ$¥ØŽw*!÷•‡¥Æ×Û!1-#êhí t8û:V·Óbscƒ±hx’­Q«Vé´ÛlÔjt»Î‘Ê2­Wx+ÍŽO.Ãu="Ó:“©4åéi&§ÊH)h9Œˆ=u¥eã)Mh,C¹T$•NŸñ\‰úfchSjdS’µ¥E"¶fyy™F£A·Û”¥=„b<•0IΨ¶ŠDÉKds$’)âñ1¢±ápgŸ³ç$žwpLÒï³åKâ–@ÈÁ±àV8DOƒ^¿ò¶ <{‰R©Dyzšt*K*•¢UoîséÛ†å[O Ë‘þè3·Ê3Å4«•:Zk•eÒÅì:ÍÊ ébÏxJ£i¤ gO'“Žã[Q²¹¹|v2Ê“/O0‘ÏGŽT–áΆ\©ñ•z­½vc$÷\Ïu鷪ij“x®·KWJªÑSx}ÚEÌÚ”RØá0Ý``S*p±B‚ò¹m›Ê¤3¤†§]+Ëôþöe—á´º­=g„#ry2™,‰D‚X,F4% ãº{û'[U«~‘ßë2Y.¡Ý.õÊ:…r‰Àó(—1v„àü…9œ¾3ê-&ÒI<ÏCHA$Ý5êRj»šš¢V]G#)OÏÐÛÚÚSnIAÖ­S­VÇr¤¢Éu&vëLMcKAÖ;{:^}ƒÍ¡ØɱíÍ{ÉLjûfÆ2‡–e8BÂÚ=2OLá7ê´]‹ÒÌ`^5™Þ®û–c1•‹à8Î.]-ø%Bkü~—Òdå&hTÖ)L |r©0°))™;?‹ãì¶)8D¢q‚öîu©ÀtP §ß÷ïÊC[rüO¢=„M&›ô2}…6éáëÀunñ ƒ K¤’‡† … ‘/nϳ%†½Ê[åcÉ ÃÈË}§“Èäö¼?7êëvÊ2Üö€kè¨2£¿¾³Ã'&rx7ÙÁÝ^Ÿ|©@£¾E&=NhhSb—M…öµ©ßÕ¬o13]ÆsÜ}™P¡á,u ¥ÜwñÐæFX|Œ­­-‡8·ÉœaìÊpº×ìŸS¸;EX¤3 ÇÛàœÍð÷‰ûû2œvÚ€ìº./_} ´æÂ•OÆq™ ’†³8äº åªc¡Œ}δãÚori²Œ aÛ6hMpÚF\~àãy¶m&£•f|;ddFvr2!ÅàõÆ÷=|ßDz,´V(5Ø:!˶ÌÈNL¶µÕ"ß™`÷f{K$¸ŽCôz=,ËÚÓùˆã:7;ÇæF ß÷B „DJÂÂõ\#3²“*8ÓGš!˜>7K­R!PBJ$! ð}ÏÈŒìÄd‘H„Bab.—R>_ÿó¯ö¥Aࣕ¦ïôyòÉ׳¾ºrðˆkl|œÍÍ 27M,ß lË¢P(šq³áôF Ïð¨+dÛKfAŽátrëª×Ç}l_Ý ðý`—l‡ãš,O±º²Â+¯¼lj×`0 'Š%%³ççv„¯\¹²;T8yÈòxƒÁ`0~˜ÜuI)yä‘GÌò#ƒÁ`0œ-Œã2 ÙbÏU…Zkæ¯]£ÝÞºÿ<¹´8wî‰drÏ÷[Í&‹‹‹;ÒVý0O$˜›;¿g>º³xߤeqnfÿú6î%J)æçﻶβlfÎ#‘Hìù~³Ù`iqñ͆v}ö^[-ç¯]£XšäuSo¸ïdß÷ù‹¯}•×<þÚ=ß¿víoç»›äN€¥ÅE–™9wnÏk+MNòºò^5õm0ÜKæç¯199ußÍí{žÇ7¾þ5^óøã{:óë ×yÛÛßuBíÜA× {{;ö}»Hömbñ±}ߘÓÈ ôþžïu;&'˯ªú6î%ÝN—Òää}÷»C¡Ð®À7ÐZ36>vbNë°ë{½%¥u泇ƒrÉô‘BìŸÙAZòLÞ7­Í‰½†“á¬ÚÌݰ¹ýìnÐĉS{}°Ï—´$*v±þ …›ØRà dïLÉÁži:îÚR.¿ÿ¹Ïóæ÷ÿ…Dø^ÕÚïí¨P­ð,K 5(¥‘R ¥D>Ò²QJ¡”Êï¼~¤û[1ø¾`ߣ±7¾ùMVÿèBP|ßû˜xÛÛöýž• ’ùä¶£Ö+ºéqÖl.\';;{oëÛ`¸—Žë›¹ÔFÞh;”VÈ›õ=„¤OÚ¥”òޝ}ÿ¼—bÏ¥ ÔàÈ­`x]JƒƒÿÍNçÞ^ß>ŽË’rW"ħ¿øy^ÙèÍ]àm‘çøÊz‚¯oLð/þû¥»ú"ÿñËßàþàøà?8îåàç~ü-ƒ›å;|óÏþ”—®¯0uéµ¼çmO` Pàûè=F}R ¶^ú.‰žÉkßú÷<ôΟàåÏÿ1…èðï|'Ÿ|­¾óõ?å•õ`ó®û o•—·’wôÀ-#®Öõ+ü§¯û,íe^Xxã“ÛsmŸøÄ'vÔùÕç¾Éw®,c[!Þú# ,ß~} ÷Úqíxþ4ß~æ+<÷üÂ.‡ò7ÿæß8ö÷¹®Ë?ý§ÿ”_ûµ_ÛeW¾ýæ{a:Ê¢³ð~íë¼óÂ;yâ‰'¸üðÃüÃ_ýŸ¸üž7ñµ?þoÿñ·ø ¯áoüÝ¢•Ïw¾÷O¼öq>÷»¿ƒŒÅ°c)~üýïÅݘg¡›ä‘ÙÜ‘û‹{·~ãŸÿýà›ùô¿û¤y7~ ù‹WÚüÿßyú†Î5àé?ž·½ç5<ñÄëxä‘ËT¯=G/u‰úKßåÊõ%lËæMïxÓ…ê+,tS·u}öÞ•ëaYöŽå¥õ-”oý%®Pägá'iýé _û½¯q1{…Ç.Ïòý×xê@‹A~êµÈ9´Öô6çùôþï~ï±úÜ—Ka~ãß}Ž_üëAOÿÑçx¥µó¨†ÞÄ»ù¥÷—i]}–ñK¯n‰×<Å'ÿïOò±¿þwmðþâ?Kü5ïGkÍç?ý¯É¼æ|ôíçQ~ŸÍMŸha–ïüÇÅëWïð‟Úñ½×êZkÜÖ<ã=ÀX¯ÃD. 9q‰ˆ€§>ö7¹úýexÍc\ºüŸý7ÿlôy8üÇ/~¿ýËòGßüKÞøŽ7îø® 9Ágÿè/øèSoÉ<Ï# ³ÿ}³v\ŸRŠgŸû©D’z£Î„ã ‚€µÕe6¾ú‚ àGßû¾åüÉï~™üÕwÒ÷äÃ?5@õ™&/iÍã?ÎD)ħ»ÉëŸHŒÔšBk=ªs|á?…¿ókÿ#ZûtA4zûõm0ÜK¼=læÉ7üOÞ²¾éýã²o{³tåEÊ=<Ú[ø §ºD¸tÛ\#œž9(¥j˜tv4 óûüŸ¿ó¼ã‰)>üó'òÎ'QßÒ|ü¶|ßÃq|ßÇq_!ˆ µæëðŸH<ñ~|ß§Qíó‹ÿç©\û.ŸüôWùÛ{ßþÜ'¹øK¿¼Ãîä>v§µFÝYzæ™gøê7¾ŠHÁO¼ë ”Þý3¸¾Æ¦ÆƒçÇȆ_ϳW_àú+›O¿¹Á‡~á£l99<§Íú¯ßçoýâ£üáW¿Ë¯üƒ_A}~ç_ý_¼ùçÿ³çnëúöu\{qy*Í˵>‘Ü•nÇqx<²ÌËÇÛÞñ‹”â‰×K¾ôÏÿ¦~ùp9¾]ôýËïòKý¯á÷_áóo¡|ñA>‘‘üÞ³›üôãYÞò?Ã[nù¾ßüâê°ÿ£ùÞ·¾ÁK¯, Xvˆ}ôç97%‚=Âf–eaIÁók+üÒ_I¢•bc}‹Ÿúkƒä©ÒŽ2Qè~è}ø­?YäôÜMí¨8rWäb.΋Ñ(áÄë/_e­æñèƒ6K¯¼Œ~ÛC|ê·þ=¯{Ã`dØ^~šÏuå£ÃÏ.þÉoqáý?»ïW¥gŸ`ñK¿·ÖŽ8z7im}äX’Õÿ÷_ãý·ç„)ñž{ý»ÿï'þ Õj•|>?pt~—/î ¼ûãÆÚø~óÿù>W×¹x÷ë×áýÇÿ;ÿðû$…¸ ZñÜÓ_æ…F´Õ9Z“ÉX<ýÜË<ùðcQëÎêÛ`¸—áÑÓÊ'4Ú%÷=—§ÿìËÔ­Ó çñ‡Ÿúo{[˜/µ’üäÅq*ñ5¦Ÿú™Ñçž}öY~ëSŸbú⣼õ ¯!²±ì?ýp–VÂæ_òIG«<¿ö¿uå·yý›ÿ Ìc‡ìQèMJ‰¶Ó::ðx¡¶Æ/M'ð< ð\—Zel~!-žzÏ9þýŸ-ó‰wO±Ã¸ÓI¿ñoä]oyÿÝO?Ê?ú·ßåÁ¿üŸ?ÿFœ…oó—ÿ/´Ÿþ"/¥.ð‰¿ú³„Ü?å-Ù—¨5Ÿã[•×ó–õÏrñ}?·s¤kEùÈ/üŸüôŸó«ûGoûúöãòÿvé‚þ:VöGŸßûô×øÐÏ¿@)~ïÓ¿Å3aÉëÞð<”áò¦Kø\û“?æÉý‚ÀÇJ^Âyi‰àÑä>±^Ÿ ð ;YàCy–¸9Nìó½ï=˳Ï>»ë³¯}íã<öØc„êŠ ðQJ!”Eø»tcSï¢õÙϼûçFÃÓƒŽ>×Jï(Ç÷\úý>:Üç…Þs¯û(:L|ëY”‚}ìc|éÓ׸ü@Œßÿ“—ù'ïÍðgWª¼ýR†?ûN‹Ÿ}wtt{]ŸÚ´wÈ• PÚ7ìqó}ÓZ³¶¶JyrŠþ7¾ÁäÅ‹ô_Ô6;5Åò·¾Eæãç¹ï?Ç;ßñ„Ô¿ÿ Þû¾ŸåùWI'Â|åéçX‹8¼öoeë¥øââ_2ñž7“’.½žK{õ üñr–¿ûÔ“¸ž?ªs€Ÿù¥¿ÇÕÿö Ÿú?â O}‚GÊc·]ßýÞÚÖÝJcùû$“sÃçZ³rýß|ú[´{>ýâ›ùå÷_=óÅJÞf|öý„?ÿMúÓ¯å»úq&‡ïÏ㿆}ìçXºú}>÷ÿý.ñó—yêõY †ó2”ø*[á‡y´ø(Jõñ!¾÷ì³\xë(àû>žçcY1ÖÆq}¢Ý¾Ï‹/<Ëg?ó;,´àüò>ÑÉwÐúÃß'xçÏlªö±»Áa;Û¹­Æ?¸úßøÌç–yèƒ÷v~â;~’µg6Y:Ë­ÅøÌâ:Ï|ûE6“~ì­¡Ÿ¯¯ÅϽwØÎÛíƒ" ýêm_ßþŽKJ\×Ý1TÜØ¬qªu>ü¡·ó_žÛ@¯tyê£oÆó\~ðÖ·^G|à#ááxhÚZËö˜t]>ÿɯ¾ÇÂó<ÖŸÿ¯L¾é­xž·ç…¾7è=XŠÙéÊ÷vÂ÷È#—yä‘Ë{‡<8xž‡ÖŠ Õ¥Ýë±­Á~¤Þ.±×PaJ«º½FÇ÷hnôøðSákÕ—Ù¨ç-zã°Áóþø³¿ÍoyŠäLŠ¥Oý&µÒ/ÇaËq³$ìQG±ëÚöÛü|ë}ó¼A^ùÁð~åWøÁ¿ü—L§R ?¸vþÇ?ŽÛh ‚×u‘R2þÐ[™ûîrî¡Ñ[kØï|Œg¢o¢táQxð">x‰«þ)žþÒïqmÓ¡Wû¯ˆ'øÿažÿð‡Gu~#L9wùuÌ\zˆù¯~Ÿ~õ#·]ßýv\·¶u7w7W®ñ©Ïü)çïÿò虵bI>ð? Àï|³²ËnáÇžB x×O¾¯|áó¼é}éÜù¾Oiî!><7ªùÇôD›õë¥4oþ‰Ÿæ5c!Ú_â?/µøØcpùáùÖŸ‰g¬q„çóÎÿðÿßÞ™GGqäyþ“™uJ*!•J·JF§Äe0·9}àcN»—vO»Ç3~cwï¼þcÇ=ã7½ûömOïÛ×ã™qÏk¼ÆÐ`icƶ1‰[º¯RUefÄþQ…@H%.alœŸ÷‰HEdÄ73îˆ_‘9;šït]gØð".ZÊ–7ÖRÝÑEºÓF8ÔŽÞ+ß×\ÎUofP²ŸùáïW¿O ô5Içi=ý # –`˜&‰.t@`FÃ7 ´],ç„-“%'÷n sâ\t]¿æø arôè±C…RFær.[pÁì`É¢óê¦?cóø¸pb;Šê&ÜÑEÀ¨$uòùè­µT¨äŽ!Õ (8vÜy¬Yý ¿)ŸnÙLLâ‰N¤ìy¯˜Sm=_~|þH!ðŽ›Èê7Ö‘’àB…0LËWÀây“¯Ò¿—4&Æcš&ª¢°rÑ|^[½_Ê ¤¡3jü}Œ(ðRµo3#ï¤GZû›;ÆI˜þ}IDAT“Qm.ÒV~€Ù ~ÂÆ?Âj'½ÞI£iPd=Œ{’惻(k>Á¤Âûšæ" ñð¢ùTWµ2íþlÚ{–'¦æ¢*:7nÀáÉ呹w#…Iâ æÏ‹´B”˜½ûËß[EE9ÉI^ÚÛÛI9’Ú_þ’S¯¾Šbh/¾H~Ašf£µµ…òòr†M£`ÿžh4S™9±=aÚáìü²™F!¥äž¹ oš4ãvþˆ¥þäeš+À– Ð5͵L~`RˆëÖÛÂâ–"%Rö,ë¤ìù`Õ0ÎÄTþúùg°#‘"ò&'z‰nJ”+ʃH£»ƒ/÷ìãì¹&ÆLœ‰G½tLŽMÕzûÑMÚêü¸S}´Ù–wÞ¦Ô© Å5eu•ÇøäóÜ=m6÷ŒieÉ ùøƒM|åJcÞ}Ó©OˆÃ4M¤‘aD)™³pÅë·³rÅ\j¿zŸa³ç_ŠGôàÔ~u¹,Žyþ,<ñn@áî2;&}Ú|ê¾j¡Z N•Æ—?T˜0u80œÏßû ×ıLš;Œ¾¬fé¤â\P\\‚Šéð±tZ RˆkŽŸªjŒ5ªïŠK×õÈj›Ë"žåJaÓ¦Íä&ßÅñSuüÕ …‚Á¡²Jœ]‚Í*BUŠ8;eû·È1S¢ª.–,^@ÁØ»){ww+|üô9x<ñÝáO~t1“û.Ø xæÉ<º‚!ì'6Mí¾w5Œʶ½G¸oòH2 øÙª‚žcÔ៰ñôOðú›s¦ÙóÄΡøÏÞÃk“5’‰SÆ0èPŸKdñ““ÒËóO/cÛ¶üéÄþîôØ©x†ÎÅöÆëtÝóO=ÿ½Ò~dï' Ÿ0¿Çót]Çî°s-ïíäÉr ‹ðù|¨ªJJJ ]¿ÿ=Š¢` A[[áp˜ŽÎNšš)ÈÏ ±h(™Ãó°©*¡V£ì6†Îz)t„LÈ1•sü({èL[äè~æåš?¼hÑUõ–Ö—ÅmD× T¥÷JÝ).ìÑ"Bö1=&™5ÌÓ˯&YCÆ2iº·WY¥iÏ=÷—½ü(š–Ï úT3§?DWj!©pW%N¦ƒeË—¢br(6˜ÖúÚ xtl>Ÿ~q”9GðäÏž@#>—/Ë%lgÇiOMK¸”ï¤D‰±L]J‰iŠq<|¸ WV&6{æÉìu$Á¦ÍÃÆ´±6²—üÿОÖoÂ]g©hw’œ2ÞZG×ø•,ÿ‹§z•sF¸óºâ ¼üòËòÑG¥¶¦†{ïÀ‘ÇQXxK÷c}KÍ)jëÈŠ.<¸’`Káø4í=*+=DQŒÃÍ—•1*†’ÁÔÛ¨ït’‘äìõñ44Ô‘ššÙ«rª(?Éðá#z…uå{ÛºõÏœ¿PGC}#†i …Ð4 ›ÃACC#ÕÕ5è†M³ñôÊ'yðÁo©æ7¢·…Å­äŽ)뤤¶¡‘¬T_ùî<áøÔùNJÉá²Ò>ó&ǧpÔÀåI#ÜFc—“ôAÎÞñk®#œÖoü Ã䣭[#ë%öâ Ó4pFJJÌÞ™#1 G½·X‹.o% Š–@Zbßa¦¤¤÷rïoÒòÊ÷VX8’öö6²³‘ÑEyqoDdqÆø±c@Fö=zÀÒKóÕÛÂâV9:þN)ë¼1ò]jùNö“ïä—sª-TOßa:¥]güúÛ€lšHõ‡yêÉÕ^Øí<Ö]é'~W¾·ÌŒ [¸ðÚm·)]?dób·¿âú¡–uýå;y[˹«Å¯ÏŠËOC}Þ/RL!°ÛlÝVîd7coØEÂá0Á®ˆiâÛ¿¦¦&õ7·;ކ†|>ß÷JkU¡ÅíÂGcC#ÉÉI˜‡¡l¶îEXwª›aèýV á°N°«+2nš¨š†¦iÝnµÛÅ-B×Uqùý~jª«©­­AUUEÅ0 ¤¨šrG»Ù4…EE11²ÚÚêÛ¿øørrrú\‰çÏÍ¥¦ºš³gÎ~oôWU­_½-,n%~.55Uœ;w.²™W^Zä¤*Êçfè:Šªb³ÙYX³:tØpΫé6 w±A¯jê·â¦i±ã³â’R’•m}Õ}öj\ ¹­qˆµ|Üzo×›ÈÎαd¸‚¸8÷m/çúâµ^‘…………Å÷ «â²°°°°°*. ‹[…Í’ÀÂ"‚‚3••tt´[bÄÀãIä®Áƒ»÷=YšYš}šY—…E *OŸ&3+›Ì¬,KŒT=Kuu~î%Ͳ³ÉÌ´4³4XÍjª«Éñûû¼o ZXD ddfZBôƒ/5•P(ÔS³ K3K³%Åç#żoõ¸,,.¶â¢£Ên”’Κêv例¢‚¤¡Cɘ6¸ÌÌï­‰!EQzœUµ«k&t޲2ÚFQU<£F_Xˆjûa?7¢Ù@`˜:Š¢ ©¶ïa^T®²…ŲâÒ"› Õ0ÿ#M“ÃøM;wâ2„T¿ŸÀÑ£|½y3Þ3¹jUë×RUEŠˆÝ<©¨(€)$šª`„Ã$v‡„@F+ÚÛR \féäâÆÑXq骬¤võjœ.T•–÷Þãü† d=ó ÷P]Ôc ‘ÂDQµï´fAØòïþWâ\ ÜSðãòg}ÿ*û~,êXC…Q4UC ÐÙ`e¯¾Jà³Ï  ¹¹™ MMÔ–—£´´ÐññÇ]½ºÇßWïÙByKu¿Í-ë© vlãŸGš&üÝ?ò¿~ù+šƒAvnû„};>¡%xé ½†Ó¥œi rè‹}¼ón1%ë7Pu¾€@ýiÊ*¨@éyˆªª15Ó[[©zåâU•`u5áòrÂååkkI°Ù¨úçÆìììÓïÞ7Þ@H1Ãvï$Pw’ÊsM½Îqºøiê\ؽ&Ò ŒhÒ/i¸mÛ¶?/§>ª/@[}5%ï¾Kqq1;ö•”|µ?BÞ¼fŇ_½Îàlù~/;¿Ûë~GC-KŠ)))fǾR„”˜†ÉþÝû£÷ϲ¿ìt$í§J9ÛŒé)úMÿ@|gVÅea«•£iZô»¿:jk©Y»–Î ¸ë¹ç˜öÊ+‘–ØU•ÖãÇ©zã .tûɸg&§v ¬ëÔ9ãðjp¼.DÔ=v2¹ãóùÝ?þ9ËáS•üûÿüÊkZ1õë?.%×ëd÷Î,[º„Ç{„ÅàDswÊ]ø¨˜)n:mº®c·_:Në}k&U¯½FœÃAð>û,íÁ ¡)?ûáPˆx»ª×_ïágïö^} ;wmåßÖ¼ÉÛo¿Ã‡ûö{ÏÎcÑ߆®cŠˆ»Ëççðžxm] ¡¨[°ã4~YaèÔUW²cÏ~Ö®]Ë;ﳡ¤˜ÿþ¯¿ï÷óÏ?ïñóâe„;Ù¸í0¹^']-§xåµxø±Å,Y²„9H /I²é£}7§Ù]ç›ÏrúÂz-Õg˜=ê‰÷»Z+ù¿k>äÁ…³xñbÒÕ:ÖlØŠaÚƳG(þó7Œ-ŒêàOŸÁŸìŒéO¢0x`óÖ/, ÍÖP¡…ŷŹ]»ˆw¹ƒ“;o]õõ|ýòËøRR¨ijBÍÏÇÝÐ@ÝîÝäE­÷7|QBPññMÈCËW¥0çáa¡T{>¿þ‡¿Ä 5ðÚÖ.~ñßV¢$g>}“‚—÷l±ªN–®ú1ÿöÿvòÂs°àþÁ¬Û^ÍOçú¢9|ÙïÄê ?Žèè@‘·ÝNú‹/¢hö@€æS§Àn'ØÞÞ#Üɳ"‡ÊÖæ9>z)s®8§ÎÔuûK(n,D† B­GI›÷Kæå& hNY´‚`k¶h¼¾|#ôGŽ”r¡±¢Ñc(œ÷$ ùfÇ{ø†-¡¿Ä4´hûb¬`÷º <ñ×/=;*-+oÞ8Îl_LºaÍnSH)°i„4)ÙýÈHGÅLbôàé=þ~Ï[ëYúó¿!ÎIÃð sùÓg‘žhÍñüç»øéŠTl«;íýùóæ£rÇ›ÀÄìvaU\WCÕTt=Œí& 4Ÿ<]U!'‡Žsç8ðÒK¤§§sºô3׬á›ßþJCÍ'O’kÑVx)hf8ŒaÓÀÃÔQ>\žlÖ¿»Ãr 4̺€—é÷?ÆÞoZY>DZ¨mF,kH%¼€i¸²fÒ¶i#æ¬e7•6)Rôœ¯éK3¡ëÏÃ@‘’ã¿ý-ã^{ i\µ G{;¨*Á¶¶Kñ¶´¥”èÉ'ŽaH–“P8L^^R¾Üúyqt¤ÝÃÊ ©”¼ÞÊŒLgwö„$¤iÐÑvŽCñLu…£aêÔï=‰i4øš“D¿7 ÓŒüRÒm•Ü4 ¤0X¿cq'ÚX>7¢ouL³ËÏ‹DÌFµ·ûuhv#„ô.þuË‹èF' '½@G°•°YK[@PßÏ>øR¯8UµI¦öHƒÄ¦ C§ª¶™{3Ò1 EÝÛXM{,ýÀlTúLÿ~g×}—…ÅMU ‡Ã1_+ž‚ê·|H°¬”}Ï?OzB§KK™ºz58NžÄ¡ëxóóÑu=Ò£2L‚ÁÈõ½VÍn„ö¿‰Ë`]°aßoh„ÈÏI"Ð¥1Ú?gR¯8Ý;5—w>=Ȳ…(Š‚ì@·w¢ã§ß‹½­‚m{º˜yOn´u§=†¿è÷+ý7Ô‹4 „0­ŠËÂ⪭|oxXüè³ëyÿ‹*–Mö“1îa’7½Ëº·ËpÙUTGÍ¿a†ILníSßkÕìF˜U´˜wvUPßRFB#cÜ<¼ïoàíwŽàr¨t´¶²pÑrMS7u.÷|ÂŽ/$“æãƒ/«Y:)'¦?)¦"ÑÛ6`‡OFf(VÅeaq5t=Œz•ÕLׂÃë%sÕ*B7ÒÕÖ†–šJé?ý½ª ûÙ³¸ÓÒñ.^Œ=)©ûYqÙ£BP~ôߘn ƒo>ÞŒ×;!3HU€Ã“ÆCS±qó'LŸ½¿o6ÞÖ ñ‰sQ×¾AׄŸ°ì™Ÿô*L£‹måžžšpÓiÓu»ã²…ºS³ìgVqpçNB¥¥4þâ‘bHQ(}áT·=9™ü•+ûô«jñL)r÷yO* #fÌëuO³ûx|ÉRTåRqåê½¹3zŸ.¤äáE?ÁçBÁ³Ïþ‡ÓMœËŽ‚¤!sPÖ®¥küJœšÂý —]¡±IÙžíŒÿHŸñ½Í®§ÍÍÊYÏçÇ6óIÙHöh4·‡ybúßE‡>½· *Ì¿¸ÏðV<³)%c¦Ì‰ö^‡À[ë"iWûö'L“²½;9þá;ÍüJÍzŽÌž=ûåaÆÑÞÞNnn®UzYü`ihhÀëóEöQÁ_RâÈÏãlc¡3gHw»ñ†ÃØÂašL“ŽéÓñ/~›Í†ªªHÀ>( xSS),*r†d¸?pú’Pìv-žÂÂQ¤ÄEÚœv— …a#òhì€x—Ö+>¡¶†Ý=‡z“éLaÒÜÔLJJÊU5Ó¥@2”Æ_c66aê:†a’’@F‰/ü ¯§Óí]ºE!#ËÛg@ÁãòôqOéε\ªÝÖý§Ó‰Í¦^º}…”(.7CsÓoZ³ë½„”¦Išg0þä»ùºb9ƒÆ3.÷~tý²SŽ•ÔFQ:"¦Nˆwj1â PÜñ õ§ßtzº53 ZZ.i&„¤¢¢)eä$g«¸²°ˆ^ªŠiš7mÕBJ‰¢iä­XAËŒ4•–r¡®%=OQI™Øl¶î9’@±%šHŸá9ÓpÀ€6>6>¶Í oãþ}{hÛ®ƒmcê¯i½ÿˬܰ—óÎ:d'èzƒ*­ªÁ:cïž¼‡²®Ê°L“}{÷Ôy9¶Þ6>6>6>¶Í +¦i°oïÚ¶kªª¶¦¿®iÈ Èö‰‰Ž²[«ZaëmßW[l|ì:aKĈ£Ñ=6>6>¶ÍâkÛqúü–# keÖ€Ûí®ú驳§²>!r9–ÈaNM´ Éá@*U¶a¹^ôþoFô6>µ‡…%däRUß²,dY¶ñid^a$‡£Ì=ûÏ>3â¿ÀzÕ·„Tú‹0¡`0H\\§ô¤Ø¢(•zo‘èÕ†[Ž®©ü¾9‡=š…\†©iüöÊÓ}ûC4sË…¥½‡xzÖ½·Oèmj*fˆÕSàÀíªüe¦ªjÅqFEµ¦ê¸ÜÎÃ! tKÁ¥H ,¹ëù)µ•Pˆš¡ªüüízκ´wÅõß0QEm‡0 PHŽO‰öV5ð¸ a/,¼ikxüÁgÙI{îf'%EÕºÍ6[rxÙ¨k:N—3캦úv‘jµ¡]¼«q2B‡@ P¡£Š“ ‰å¡‡'2õ©'#$„…n€Ë™÷’24G87³pÝ¥ªmѹ,}åV¾jû('uŽ/“Ãí¦ø«RËŸê',æÇkÜüò_Ì¿£{>CdÃìÛÈè:-Š $I8ÎZÑÛðûXxzf6ïNœ"UZí ]c‡ï6ý|a…©¼>GÙ‰Ôƒ)‘Õ>€!†2ÿ¯Ï |„¥‘¶c7þp%_ÿ¯ –®cèI|{÷Ýùáktô(X†ÊÆOÆó‘4ŠSTIqâ,…¥ôóæËK¸ãþùõ^cûg/ ^x/Ýj©ál|Š‹ßä¼³^dÙ¯ck] ÓÐÑ$Qù¸ aåï*P±Xjµ“ç²IïÒ•­Üu÷ÏÌyÿ¼ZµÙfK/ý¹~î¹à^Þ\þFXEiÞl澑Ü1ÿÇ-qκ׿6KgeeѪU+233kÌ5è¬1a’•öçŽ6ùcΩ¨þ“Ͻ‘'–RÍö®ÂØ-àã§7Æ0fq6¢ÆråÅSçàÆ ¼ºn ½c]…äõC†5h¦Åú¿pÍ/Gç_c²ã¯?éØ{4×¼Zä¸ÎýàýZÑ[pz”é{æpåÌÜÏffÊÜÿ’Âg?t-‚BvÑì˜Ûšr>ïn<žáÝ’‰äÍ„¥shÕ«‚Y\~EÙhÚ4MÖ®Ý@ÊÝ¡çix³wñò„{ÈðO—TÂñÒ £Ššm®Æ¹⌮ݹcÚ“Øb €Ïçãºë‡”¨k¹;×àm׋ÖI2ƒ¯ººÌ5111|8÷rrrèpDGN;í´ç›ƒ¯ú¨Ìu†a°víZöíÝSëvÔÈ ƒ´jÕ Ç“7 ™¡Hc„„e «AÒþ\DZ½š i¼™+Ð튦iÈ'ŠT³r„i°où&¼ºœËîyž[º»¹ûæI<ôÚôuƒ0ñ¦ïàÉÛf2y·¥®·älfæ‹qSD–%N1Š^±NTÍÄíR°Œ ;¾½ÏzÎdlÛØÚÁpEGsÏäÇ9Ê£T’…/g;·L,¶~ƒ©²gåCÌk5‘1š”(£àSycø- yï]œo l]á ¹æÚëÊ}á­Û¿¾Ü†Äãñ0ï£#Ÿ6Sì`Cú2†}ãá"_z¡mÂ2ñíþ‡ØåW<ŒèF}|^^Â"7sSFNáî¹ ˆ–K–áp¹¹öù¹ià}ôYô]›x3*s 5–¼°™üÊÅM=ej™7û]z^#c™èšÊ??}Äã/,fà#o0¤«b×Êĵ>ƒk¯©*Ÿ ûÖ.áç>Syï”V!·Ó•Û,04Ùå* â„@× .gÄ8³•³ &º)á*5yEX†PÊtûF¢ÑÑÑ,\ðy‘³Èå÷‰—±çÁy\“ì©4O!111…×[ºŽQ*ÿâÃ;²³³éÖ½GØ>B3Bc†‚Á ‰‰‰ŽŠ„(,eÕ+<þÎfö·Šäóã>ÉÄ—ö ª³c\ÀÙçÒ¤š1]’,“tl?Þøà&<²„&OO9;o~„Io=JRî¿çYNþ$ºË¼@ýÞÍÌ]#˜py»üÀYãÀ²™üš3’.²Dïó>eÓ²k©æâ7kÏ©4‘8fô#ü¶ùoÖTi¨Â¤1Ç£ë:N§K7ÙüÚ/ôšY1~ŠgœdÌ{yóüöW‡ª‹Çã)шßçã¼Þ²`ÁçDúvއÏ>ýˆ´Ï1ì‡A̽¾Ÿ]xó?û´ˆziÝGZŒšÍ3òœ"_Ö>¦ß1‚Žcgsv²MÓ¢ä&Í®˜ÎLþLn2‰9O¦u´+âp #e1³äYÝDA7LE)š¡%,ôà6\1=*ËÓ21u«¾fÆóÓ t»çÌ¥§zͽ0YeÐêôèZ³5˜›Í³ÃFpáÛïÓ;! „ENÚ.ÆÞø,ýßLZ8#{Ö °TR¶Îâ¦y}ùfâ‰Eá¬`ת§xpËÌ»á¨Ã" g©$aTÀf; Çß–`{ü~¾¾k³Òƒ%êr”ÇÅGó>®sµkeŒPê€é†`„*]åTrÐò¤»™Þ-À´ S˜0s–`ý«W²úšéÜÜ"º–¢ Or—bçdš´?iy¹â¢ÛèØ6‰{g¾ÇÉ-_×fû7góoþßB˜ø27âPzâÏú‡Iÿ»‡¶#Þ Éûc¹j†C÷³j½Jß^M‹C†y@âiçsãuãy룧éP 3ס 7‡·îžÎý/ÿ›>Í‹[ŽfÄð¡×6Å¡ ƒÀ¡ïˆi}Q©üLLÃÂþ´]|¿ø ¾ýåob»œÂüÛ9ðé-5j[MÝbËÂ}\|…;¬<*³ÙÃí/ÝÉðQ¯óÉ컑Ô~˜~^œMs‡Acã*°QrѤå0Ž]2ß„ˆÎ÷f5¿ÆWÿÁ´O‰|Ë˰ØýwóFå¥R’iɤÉw±òó3˼,K‚ÜÞ,ø|tQ½ zÙôêÕ¾3 #TðhÕªUágMºÅêØQ­2…! ¾R.c`‚­‹Ò¹bTT­—”×p›†NúÖ_™ñܧœ~õ`&Ür©ø˜ d—CÎphì_ñÏ<Ó"?RÓÉØ˜ÂQ—ÕL—ªÒz<>›û‹/êKëw¿Ë , 2öÎaȇ}yå†&¨¦(ŒÐ…HÛ‰:¹i ÙvâU8¼OKÆvZĂԸ²ETÄÔ šàSncbi¤¯…ÓÈ ¦òê©­##¬âtA Ååæôg^`CNƒœpÍã%’'$^ÊôÓÁmpþãŸpv—&pÁÜ 2S¾áÒ'’Y0³O±FSå» Ý)#ù¬åÏH9¢ð1µ +Þ¼‹-Îd|§d¬#¦3nÕb^{ê6¦)Çpë£è×1šŸ.£óð¡ÅÚƒ´>aú›¿°'ÍKL³#9÷âËxá¦Ñ˜~s_|¤Æz«š——÷Ãw îZ³Y’$6ëÃÓƒ¾äîÖ2¦Ó|Øâa>:ªÉaCޏÜ0ò6…'Öâ‰^Í–NvÆOÌ?v£Ü ‡£ȬSºóÅ矕jï-2Ó¶r•T•†s kìy<233 J×Ôó¬«Ým‹{“eʺ®‘uð+”>GãõzQ* |}9?èǧ(8B[A ˲ ¿—µE`&–i°cõ÷|øÁ|ú]ÝOH„g3ìÇÙ%S+.¼½Ç²èÞn tÃ"¹Ç\ý1ùŒP­óa³ª¢iy]|ªªbšnajZÈxV®7š†/à!׿F:Ú‰=øô­Oؙĕח+ ?/âœù+'X÷ò\yï'%ò-pöŠÿ&„Éq£2læZ.yø„Fõ€×>×$—uøTŸž ò윧yâæ×ñõ¾?äú×XñBCÓ „¡¡éÎ6:Ï=öb…ã$dIâãça 7§Q”§°T2w~AëóÆ”(ÇTUTUAÓ <úƒ©¡š‘ƒiX(­FòÚÝ Ï·:þ\&Í8‹Ìí¿òÚË÷0=«òºTÆÿÜ¢(aáiy<#8—vÉqEêrž±°õÖl^8÷µ÷‡OU6ƒL›³ÆÓå–«y8З×?éq»›[Å&¯”}¯È$Ÿ>ž•·Að㡘\þ|î%xh~DÙY©¥Þ£9¹ûYwE9X˜¨jJLQÅ?uMŰŒ’Ï´¦¢¢Üôµ¥¿®ëµã°BŸ7}^˜xÓ–1ñÉÏñ¦¬ÄëêÍØ±nt-‡¥Y^ÆMxˆŽß˧·¬! 'Ђ¼öüt6ïͤi§9ÿÖç!ý{Z¹yt‹«^Ù”?`4ounGt"IIÉù/Ôi1޼seºÆ(ñ{MéO!.—‡§Þz—c ý2üS'7Üö?F {•—çM$Æ!‘›±[ÿ”¹*É?;…iK;3r\¹e”¤“Ä·¹…¦‹ïÁ˜0«QuÕ >e»@-=Àö%SHñ(IQ.î¹-›‰_í`ÊEiÌc+CíX††føð÷Ç—ãËŽwñûýœÐëÄró1Tƒ¿_[Ë S“K• š?ªÑv7T…¬Èô¹¼o9Ýö2‰ú3ö©ž¬˜~O¶šÊñÑÎbé$œÑi]1í_]L„¥“±%c_ôòÆ]jµK¢ð~êYÁb…—\ÕÀí‰,¦DPùPˆhO+îHxŸÕÙWÒI?ÈKû®g~¼3¢¦ÚWnc±¶Ëºf]ïWÎÐË8@TËf¥êeÑKX%Æ™š†.(7}­é__]cµáÕ©H ±ÍNç¹§OæÏ'.'õžé\”(‘¶k&û¹Œçjm@›„ÓÄ [&Ò6е4ù> fY˜:»¿‰ iM +WîÎ}œxqÝ\·Pijñ#†c<2 _¢¢™|o ·¾ð-oÜÞŸÏŸÍÅ/ÎA*{?LË1†¶T\.®šü<Ïßs7þïi®>±%‡qÓÃÕ@~ÝÆÎV°cÌDî<"‹e—=ÁÇW&­Ïç£GÏãÊ0ªA_ó&ŽæòióÊ”aÁ:g'®‰PF¨,{fa™&ªÿ Ÿ½>6ÄñöçÏÐÂ)‡ýL‡’Þ²¬Â2ƒ9{X8çmæ.Ëaì¬8£c\µžÅJ©Z);¾áé-ñɈ¶êÜ}+¯üÑ;Nn9Óç‹í§V.F’‹ø–7ÐvÞÝÌJèÀóׯGÜ‹UÚ¨¾,–¼r7®»Ÿ#Ù)½³ò£sSÓIYþG÷Y¬^Rø~“.º]9šën;¯Šz,Õ€u3Xºx—XÁgqf¨àïHXhÑDáùT®•%L]pè‡ .UÇ£NúÎÜ8¬|ŸW(.è=¦ü†K×ó©Ó,œ’D”ÇÁçïž®ëX†Ž°¨–Y RXüõRVæh¨Ï¸¤º±3àÍä¥ñßòÂG/罈ÜÑœø¿|sóƒìøàUŽt;8\Äå´rÙ!æ÷‡£h¾~m<Ÿ:†óþm Ùß@j ~W ÑQ.r÷mâÍ·Óyðš¸róPÜNz–ëY膉$ºæ-÷QRíÚVàà”÷wyçBQÖPŒËãbæ¢ÇB »<ôyæ«jéÞ’ëZt~€ï(÷l@·úææ|ï:ï¥èTÀùåÁ;y#5€–’ÉCCyƒÀƒA¸ív|ŠŒ÷>î>ßU ŒP•ؾ #?^B›ÖÍp+BdîûˆÞ×xcæ<Ž>ûbfí‚ Ü0PeÝÒE¼óâBîsea>¾ÜŒ¸åadEA¨´èrùa0…´øÌXÀm·÷aÔÏpá­ðî©+¬7NOSFLy“-?ÍåñQw0ñÍ×iጌéáNW4½û -c…4¹eêìùúQ†üS.;áv1§ª?›Gþwžó'0kX¿|&U#uÓ³ÜùØ:EA ˜ý^ÄŽß»—ûx’øfí8¦[.½uãH*¸(ì95Š¢0xðધ<[)û²hÙýtÆ ¹“–…{<‰mŸU™ÍQqÍyò³WKœ‹ŠmÊ”OÞ¨Ó÷@ÝWQ±ÎšjòÝϱL¹§UDnÃQ™–`÷ñ“ûræŒ>¯ð¼©©üûÉ›¼þ÷²s|XîDÎzpmJ0š—»’%„AÖÁŸ¹õÞ7‘d #˜N«c¯¬þ;YT<ŽNJII·<ý%7]{þ / ““yÑWŸX"a0 ¹Y³rM,¾ biF(**Š„„„Ýf±±±Üzë­e6]‹ç`Ê:»™;wl£oÿS묌‚Fe÷®ôéwJ­—#„Fv@&!]aê²gÑþý^A%:ø(G£Ð»Œ¦aÓ9Q_}â‰R·õ2Rƒ$µð”ÛXU—ǃl×Ûæ°qÏîœÔ§¹H KåÀæÙܳ¤ŸÜÝý°´±^œ1ÓÀ°$œÕþ*Óß0t~Xò-µþ&*3T Å [j&’ä"¡Øâ®’âÄY2ž˜8<1qÛÅS±ï§-¡Ö{Êw‚$ÃÉ–F)FPgåô/ytÆM6øQk-HyãJ;E¡E ¸û|•cëmãcãcãcÛܸmtDÅ0èA¤ßÇÊW–®¦#T00º´8p Âs¡\o‹-¶Øb‹-¶ØRnRõ¡ØØØ­(JHÞ[$zµ6#dG·6>6>6>6#dÛØøõ›òx6>6>¶Í %@@L™2Ŷ1BõWUU¼÷Ö"ä+ë®±¸ø&uêÖ×°~£ÙÃLoÛæ†êÉÐ4 ·ÛmÛúkšÆGï¿—·«Tä£Öd«V­ê¼¯×K»ví"ŸHÕÛÆÇÆÇÆÇ¶¹¡$''‡:Ø6F¸þ2H$ÄGáóûë›éñx8p î—yeÏž=‡O¤êmãcãcãcÛÜPÏ®]»l#\Y–%ôhÇÁ=[A÷#a¦iÖùa?êx4ºÍÙÑ›m³Í–ü·l E)=í0M“m[ÿåÀ¾½øý~d¹ö¶/%¾”ßÿ&I’$qíÐaåçf¿$I:Cö¡ÃOoŸÃËȲTóöXäíÝf׉Zz¿Ùc„"Zÿ‚1BÈ[é¹s—c8êèÎüòÓœvÖÙÈ’L0À²,„˪à³`~¾ÃáÈK[îa•û;À‘GÅ׋¾¨ °Øµc{È΢(tèxd¹d«V­ê|X¯×KÇŽ9tèPÄEo‘¨·Ïa³x£Ëœ2ô _,ÏæŠ3Z”=§iy¾€?I IÊ f].Wa$ªë:»²,Žjæ9Lë„À4-„p8äz)1''‡.]º’’rØÖÝH·1ýˬ#TU¢¢¢QÁž`BvíØÁê?W±fÍêJÓš¦…Ûíæ„^½hÓ®GÉ•«k:FH C7 Ã)8NJi¡ô‹ Ë@7’’¤ä?´]Õq¸]”Ø,SÇÄS)ÊY†Žn ÜnW°>ÜúóÃÅ¥ªô6>ÿ-|jϪð úr?øQ¦ÿ–a¢8‚ª†ŒNú¾wyqí)\Ü?1/±äÀå”Ñ‚A2˜•‡XµEз[Â2É\ÿJ÷~´ŒfáÂ…ËÀŸ“Â[ÞÊ?Ýžá•[ºÕ &5­†®—éC–…¸]J©6RÛ¹›¯?ûš­Ùýyhì‰!·åJ©¶<”4PÕøi˜XÅfIK²ŒÃá(ÖÆ‡’&t}ê߯ê½?›þŽÆÞÀa±nÝzdr¹«eYúq>¸©KIZ/Ë7/ŒbÄŒHMùÎ諉K(ém|þ;øÔžá#„ =#‡ƒßÆ=ù ô€Ÿ÷§Íåšû‡Ð®×¹ô=2€(qù7 $Ù-Dzâ­þ¸<žøt!Yi¿qúXÁ·ï À øøñúÞÄÍ^Äɱ jÀϦçòÌŒœþÀ‹¼rn§ˆ` ƒ~?ÏÝw'ÿøõbmaÔ~ã@‹ üýÍmESÐËOç¡·3ü®[¹eHÏŠÛrScÿúE<úøl¼îXèèRsF>2‰sòÛòPÒTÍ6‚¹{ùðµ™|û×dI z½xŽ:‹çž¸‹”_ IDATGˆiÂÓ§~m ñý ú§§ǡԃbîœw…Ïçéibÿ¾=bïž]bÏîb÷ÎíbçŽmbǶŶ­[ÄÖ-ÿˆ-›7‰Í›6ˆ6þ-6þ½Nlùgcáß›6¬ÿ^'6¬_+þ^·F¬_»Z¬[ó§Xû×*±fõâ¯?«Wý&V¯úMde¤‹ç¼[f±#˲Ķ·ˆ‡Ç)w1$Ó4ŦM›D¿~ýD§NIJeËÄÃãÇ]×*\X)l±L‘up•8µë%â·þo†Hßö£¸èØ3ÄÆ\-¬r^¯vdG±W5J£‰½«gˆÞ7} tÓ*,'mÏw¢ÿ Ý*™OЗ->žt2õkÑ·CßZ[x*Ò%\\ÂIoãsøãS—x–ÅǾœ4qÞ 7ˆ‹ÏŸ*LÍ/Ö¾?\œ1q©ð©†è7å¼Ek‹Ù9qåm¿Ë™©ËEÏ›– !„0ü^±äòcÄÊl¿ÈÜ;_ ½| ¸ëÉ÷ÄRíM}.fW¢ùsÄïs'‹ó†>V¢í45¿X;ïAÑç†é"×°ªhË ‘¾ïwqzâ÷ü¶Ü2u‘ºå{qI³Å¦\-´4¥ÞQÁ`°ì»Iˆ]K¦Šy¿üSø›¡úÄòY7‰>w~ršpõ©OC{6ný T”#5 BššÊÍ7ßLjj*ãǧOŸ>GÕœ5féA6¿}/í¦½ÌÉ-¢ò©i…Äö}™þDsn}íŸ2QPù3%òúè5Ýd³Ñœæ’…®ëFÞl9IvÒ¢ëH&ľÄóDšßÇ;w<Ä„yá(æâêj.sÊŠvðƧÕZôé3<ÂÅ%œô6>‡?>u‰gùøHDEÇ2óñæ¤÷èMÆÜ:Mgì™Gb›fßÅ%—\Râ¸rð`öif•ºIÈĵ8ƒÏçÅñ7ÒÒ¥ „…š«Õ+#Tó:!z³øâ¥ÑLßt$_Î~„6ÝbÂ";c·=ºŽÏ^¿·e ë:ºa`•3¤ÔTýl™3†öϼÄIùm¹$;H:¢OOjƨ76‡”†RlCy3’d‡‡öçŒãêSŠX|ÅE·AÏ’ùõ«!§ WŸú´1iôú‹<Æ1,GHUÕJ-„óy‡¦…ÿ0š¦IVVVá i]×™`Åí£9èõ±ýûGXzú+\Ü<ªXV¾ôElíýÏïÝhúóÞ3—0ÓÛøæøÔ1žá#)nŽ8s2W­¿—‰7?ÌýOããûF¡É.º{…¯¿þºÄ±àóÏi[l|Œ¦ihšŽ°ô¼ïºŽaå]¦CS§œß%¯’²y×^9¹Þ ªyrSxeÌP~M¾™Ù¯F.6iÆÒýì^<åÆ üñî4ÆŒÇ=wßɽMã·=Ùeœ!]³øeîNî?µe§¥Eß»Ù>{IHiŠKxãg$¸gÈiÂÕ§ám ó†Ò_@Ú‚¼wo8NP—cºÖÊTH˲X±liÈÓôMÓbΜ9Ìš5‹9sæÐ¾}{~úé'¾üòKÎ8ã FŽYuŸs5Ç™–û£SªòJ2Θãðø¦£«è—ˆŠmÇK/½„ßçgÍâ5¼ôÒKå>Ñqmyþ¹£¹dÜ\š¯Öùlù ¥’8Hh}-O\Óxúó…„‹K˜ém|s|êÏ ñ¦epLßdöuKÛxè04‡É›ÒÈÞô=Ÿ~º%/ ÓMNݔҼ CËbç6™K.i’?Xz/ÊÕWÐ26š >GWü³äMxy#Óç¿\¯ŒPMê„eÙÿëT¾Ü‘ÀÑæ,F®øˆÓ/Á öÄ©HªÉŠVáîö&ʘgxáöæË õïï¸ïªKIýtÛŵBb¥?Š1eÚrgL<¾ibD•ià¾lC¨ãg„$kÇ,ÜýG†œ&‹ëÓÐ6–!±þ’ä"ªÙUÀ{á –öx<‚5œQË[ïÌæ#n ùY–Ù·oC‡eÖ¬YL:•¸¸8&Ož\áºAµÁ $²D“ |wA‚ȬÕ(HR\´èu톋üÂ2gÓæ&t^z/ã—wƯvä÷M˜uç)y¬jñĨ7y|öÈÂäþ˜ÍìUûÐ.*Šo¾YÄ¡]Ï3tÙ•|;ô¨’ƒ¥càЖåÌ|öþMºˆy_¾F¢CŽ˜:!;¢ètî ~87ÏaÌMÙÀ cofT懼yÃÑè,É„óÆMçÒMóãSÍ»ŸÉ³ooçì øí !·åMDfHiªÇ–üÙY¼|ïÇ<ýù]!§ WŸ†µ1ü÷gcÑ?ìYcÁ`¨¨¨Bç¢à·P¿WgÖ–¢È 2€G}”Aƒáóù>|8GqDÈzW‡’$IÙX”íG@–”\»Q`ë÷£Œ›‹óññì?.m¢ê~r_$Dô¦¦òÕÄ1ü_F ?(wÑéÒñŒ»¨­O‹O5ð‘⛟ËóO&³]Ë¡aè÷Ô¾ý ®Z9‘GÙ (¸’‡!{¿ecÓé\µƒ‘üÉìK†æ7B¡gàJt•"š ÒwÍåOmaÔýï0¹GráïȤH«’L\ËnÜñÜ{œxÚ ¸a&$ð@¾T”ÔM\Ûpn¿(r„dM¥¬rÛr È’’BJS\BeKTo_M†älÎNt‡œ&\}ÒÆrÙÑ¿ÚoØâìPƒQÙ÷空¢(J¡3ôÈ#àr¹>|xXúV‡rHpJ|?s5N*6­a¢å®F?½ö¢ a’¶†ûÞlÅâï°¿ç ®™¸„¥Ï^ˆRÇ-W$DôŠËÍ¥O¿È¥6ãa3B‡ >–©±cÑõý“hA±¬cÓ’·9ë>ƒÔ ¹tzs:v~ç¯{šU±«¹mÞBb”ÂÕ ¦m#ùˆ˜R΀ƒäŽ#Yønñ@Âϖů!ι‹®ÑÎÈ«’ŒÃÝŽDãßü—&´vK˜Å“, RMt9ªT[.§²:W§w\1û…î]ƒZHiÂet6ËÞËDZ£ùdè1a¥ WŸ†²±â÷gdè_#ž´4ËSÑ÷`--ÎXà M™2…~ýúѾ}û’•¿’Õ§«;kLqÊœ>¬3Ïý¸·D—Œe¨ì[6ƒ.#Ï)Uw¦„ðñÁÝ÷0êƒñ8­O¼‘'òö?éõ½ýfýhªfãcãÓ ŒPyøCpè»TÎKtƒ$átµäø´¯A 'ƒoƒW;‰Ø¸Î¯¯ÜõFL= þY4Fœùè²Re¯gö)2+X¤¢üþ«ëU†‹Ïë§}Zµq´ñ±× ÷¹® ÕçOžt™0üAñã%÷Í篟|‚ÈÉJ/ÜvŽ˜úÃ~bä5K…/s‡¸ìØ“ÄO©¹¢`Åœ@n¶¸­çÙBËÿ¡`¡_sT!„%LCÞÌ]âµqƒÅ qo‹€ëš.þúb©È …ªiBSU‘“¶C´ëwqë)ýÅ|"';Gœyì™…kÂeüKœÓórñë¾ü¶<èû7-—wØÐCKê5¾L1ï±!bس_ MÓJ!§ AŸ†´1”uø³þëÕ¨k¬8ãSÕ¸ êvÉŠB¯^'òÜ3Obš•¯Ÿát:9éä>•2BáQ’‰MìÆÇŸÝƒ÷ c†;ªHæ¾/çs”Çv¿¸«Ì2üîÆ<¼‡OïW¢ì˜&]yeŒÄ 3×ðÅèC̯û󉔋‹fzŸÿ,>µ‚g¥ø4ÓËÿµ¸™±mX”›«çÍ`âÈkhvã,<% @Ãr+DÅ·åµnç‚‹FñÉÒ·9Úm²ké$6^ñÎÒ]CT_ßò/¿ó#ç~†Ïö¨w¬ºuBƒ”=ß3ùÚH.7Ѧʜ2ô-ž:§u~O™“æñé“&†ãA¶t «)C^[Ä%-£ÉÍÉ-ªÓ’L“äîÌýpî†×‹‚.5çÞ…ŸÐ)¿-%Mq¶¡¼ñ'–ágÛw1êõ­\xÖ\†Ÿ[x.::š—_{Ù¬:#s5ÄÆP»3#A)=í(NE.ùækŒ –Øt5Ð㸠š'Ô1B‰‰‰…×ÄÆÆrË-·Î+Øtµ¢Ýç CŽs8+íÊ«k±wŸ?<ÅÆÇÆ§vñ˜¦Ÿ­eŽJ”Y>äaNýì)¼û¿ãwu§µv2ëækX˜ I—LåƒQÇ"L=ËßàÓÄku¤“gÝÆ´_æÐ*m!3èççûã~ùgÖßi§\ÍíÃ/£©C¶ëDˆ½û|dë_b÷ùê°A‰‰‰…¿UõÝãñTû¨È± ÷´wŸÿo1B6>6> E‰¡KÁÁióŸ ®ÍœŸâör{ñ+'íO»£på²9¿¼ì*rrO4g~¼€þ³çÚu¢ŽÅÞ}þðÐ?lG¨ºSàZjºû|¨©³gìY?6>6>‘‡Oq'È®õ/µ±3»mcÃëöST0>**ŠÄÄDÃúÞPRÝYcÕ‰‚"qöŒ=ëÇÆÇÆÇÆÇ¶9|¶¡º3ªlþÕ' ÖÊÌÌ$!!¡Êï -6#dGo6>6>6>¶ÍõÍ6Ø66~ý#j¡šêj3BvÄjãcãcãcÛ\Ÿlƒmcã׿ڎP¨ŽE}9 U‰ÍÙÑ›ms}³ ¶_ÿFµŽi‰:£þfùèØñˆœ5™zÛøØøØøØ67”dggsL—c8rÀ¶1õ·ò}ŽF³ŽÐ—_ü∠ê]Sqºê~-„ú*ÇÖÛÆÇÆÇÆÇ¶¹!E kšmc¤êoéXÛW¯k¬ø:BÝ^U}e!!êîÐT•;¯èY§eA¿»÷ªórl½m|l|l|l›öðåærß5'Ù6F°þÕf„j"Á`ääär!³Ãù6#dGo6>6>6>¶Í¶¶u¯¿¥ÃŽoÂc„„ÄÆÆÖèHNNFQ”a„ît\=DA~î½êÄŒÞ"SoÛæ†cr¸ÿÚ“m#Xÿ°!aYhºÎôçg”éËÿ$ýTì£\Q…á7ÝP‚ÒÛ_Æ1ª‰H’ÍÙ‘msŒ?±mlüú[:ò®o›5æp8sÿ}XùŽQÁ§˲p8yNS¹‡Uî不âNÐÁLožÓæH&ÓÊs‚Z$Æ–x ï»êxf.ÜT§«?c®ïËŸ¯¨ª©zÛøØøüð‘ª,í:Ñ0â÷å0aØi¼ðéÛÆHÔ_„9k¬¸ãSÛŽP#¤¶=¯„~©™^\ÔC.ã4UÜbÈ|¶Ö‚æÅ!›²£7ŸÆŒâ0²íœ,A»™]™V9ç$*p”XÅÚMY’ˆu@Ž.Û:QÐ êÍD›ŠtFȱûÛê¯#T'ê–b„õPXýç¬Y³ºrÈ´p»ÝœÐ«w]|)/|¹³D~º¦rÿÕ'ðâ‚5~ÐdIªpÍ#5àgÜ>¼0}¥á\¬é²H’BTõ)˜"<]ÂÞªÔ;‚$\ljå¾Úø6øÔw» ('vã·¿²Éo Pd ¸ÜÑtÑØe6Ž–Y–8¾{"-2Í¢!Õ›G…»b]¯JÀ,Y—8….G&ÐėÊ}z½1B5©²TÀ…•l;%¦U ‡C¡]s7qµ»ô*ò–J¼(…(ëH†’ÆïËáá›Ngú'UX/$Jæc‰ðÓ„ªOCØX›eÕ»þÕ#T׌P õ¹%¡Ì\ƒ{J¼÷î[ŒxR¹Óï-ËâàÁƒ,^¼˜+¯Äôg§òàÃñÂ;INˆ©ÕèD–%ÚvHà´vNÞÿ9µZQ$IÄ7‹£_+…Ü …ªX½[§ã1ÉDíMçïœ2O8±ñ1œÓÆdÁÆ@غü#úp±©ûjãóße„jŠÛ)Ô„£‚¹ü™cqT‡(¶ïp]Ÿ$ù˾*\Z.ÿ·Q+úÛåâ’£%æoP‘d‰Ö=š£oH%Õ(²DBÓ(z¶‹"eW6›2Œˆ` Y¢G—&$(R‰¶Óí"ZË峿|E¿ËÍZÄÒ»¥ƒ-{|ìÍÔ š¢B5&ÖC¯ŽQ8-ÈB°yG6û °%Mlƒ¢(tjK›89ÿo# òÛV/+ô4áéS¿6J’D\B½Úy- È’`×®väXy~FcÖßÒqî]R–’J13 Æ•rv*r‚¶lÙÂðáÃIMM¥sçΘ¦Yn~º¦òÀ5½˜ñù†jé¦(íHàËOŽ_!FjÐÏø¡}™þéº M8îèh–®8€¿˜Ï³kK&çœØ„­¿g=€Ã!sÒ1n¾ÿ=­î U—°¢·*ôŽ ›Úº¯6>‡>õÝ.(™3{%`i:ßþe’Ø2£e?Û,‹ìýY|³«¤ãâá´£¥Øóü +¢h⊗ËCÿc£Q³¬\“V¢]©F¨uÂ0mÌ,ál&5£w²Î×½E³}$‰„ä8ú5µøò¯ Œ*šB·ÓÉ]£ømu‡´¼Äžh7§—„÷÷Cd™¡¥)€/‡‰ÃÏ`Ú¼ÕeO|z–vêE[ËDÎ=ÚÅÂÔÒ„ªsC؈$ÅÙG:øî¯ ròO§ËÉI=“`Ã!¶DãÕ¿˜£Qf²Çã!à÷5ˆ3$Š¢j§)55•›o¾™ÔÔTÆOŸ>}*ÌÏáróì¼Õ%Ëñd‰NG&Ñ"˜Ëϻղº;\žh¦Îý£ü|òéóÉ$ ò)Q)ïœf,û×äìNî¢û#K´èДÜÍ™d[áëÎQ™Þ‘r„‹MmÝWŸÃŸ†h S°|«‰Û«ár»8µƒÄšt$‰&­¸àø¤Ç9=“ˆÉï2+~”W¶ª©,_›Îò~üù퇬Ô>µU'dE¦]ûzÄ,þ;¯U¬]w:8¥““o7åbRÔ¦–‡²D|ë&xÿÍ&U…¿¿o³ÐÖRšâyzbâxòý•eʲ„ 7#—mYzÑo– 35 wrlÈiÂÕ§>m”dhÝ9–uësÈ6‹òÑ4ƒ¿6úèuLT£Ö_B*Ç’$‰VmÚ²nÍ~?–e…|ˆ0Ò•î3-«Ð¹)m”#¢`KÐ*3 FW}ˆè¨F­¿ ;òö@u”v„ŽìtÛ¶þËï¿®  Ö ´yÓ¦ÂqAåu™¦Åœ9s˜5ksæÌ¡}ûöüôÓO|ùå—œqÆŒ9²|v©X&§›§?ü³Z³ Ô Ÿß]BTÌX¹ÜÑ<ùþïeÎë†É²Y8‰¤$Ë6f•¹Ö4ÿnÌä‚^MØýg'tá§?ÓJäŽ.áHEzG’„‹MmÜWŸÃŸ†h $dfYD{3Ødï—é£àŠñpdsGA/"ŸEV0²ÄÇ'#Ë2qÑpáñyƒ¥Ýq ¢g~S°ø¯4dY"1)†~í]¬X“Yo÷¨¦uB’$¢›ÄÓ>Ê$[Šá´&ÑHõ²%MÏ,.I´èàÆðZˆÙ,ßm‚ѱú—̶5‡Ø,*\ÐB¬)§ÿÌ4t %Iø«L#„·¨%:ž'f¯ÍFIÂå‰ÁÊòVœ¾TšPt.®O}ÚXØ=)À*óþ•d©QëCõ㤜ÝçE¡s—cèÜå˜zkP,Ë⛯¿*·ï®¨Xfß¾} :”Y³f1uêTâââ˜=`°„à z@GÕò!ÝhšäŠáÔNÖoMeWŽYø’ªl™ŽZ•Z®ª¦ó×zƒëÄ£îJòd\–Åïj{„e`F5GÕ²ŠÜ2!¡izÙôBÆ%LTÍ!M‘=’ÃÃïÿP¥ŠC¦C»$Øyí~=ä4¡é¬7Û×§sQ¯&¤®Ig¿ßÊŸEMŸö šßvYõ}$aÕÛ}¾®<¡òö)ÎT]ýõLš4 UUq»ÝÜtÓMUDE‡®©LyZ­ì]R:ïâ‡0å–3«}}Áaå÷aÖD—pŽPônèÃ2Û7¥óÝÚ4¾[›Æ÷ëÒYuШ5ljz_#í°ñ©?<+Â$âš5¥ƒC.œPÑ¿³‡=Ûñù¯)|³>f ú²èÙ« }ŽoÊúUè…k¦H.'Ñ*c•¾\¾ø+ƒÙf~·šDbóxd©^ð¨‹:aZAÉYøw®%ÊKKÞtê× ØgH4w”µ_V\Èz ¤4Å ø¼£l‘¹7 w—$Zzäüô2ÑÑút’ù~·RšÒlÃS£Î­åéÔ)™cdßlõ#çÛ!KRÈiBѧ!m,}Ï\.'=º6ãàß©xÍÈпQ*ÑÉÛ+G¦×‰½™1ý™‹%–3‚§ÓÁI'÷A7­2ù)½ñS×Gtê0§ÛÃøW¿¯ð|Uׇš&œt¡HUzGš”‡yët”gcMï«Ïá…O}µ Gsø=ÉӰؼ*~=[Ø“ÊéNEB²,4Íà»UÙ :9™EËRÉ´ >)‘Ä}i˜…}s.®¨8Ú·Š¥g»hvmOã‹Z½bR“:!IíöЧWŸ—/6 ×Ùù[pXü³v?Ûƒ.‡Œ°ŠÞAUãëUÙ èÖœãL !ŒÉêßSÈ2BOS î¨ÆÍü¶ì}•$â“’8³½“‡b9縢}/ Ó⇵‡!¤±BÐÇå bcÉ4NÚ$ÇÐ¥Mû·dí¡¢q›Zÿò6]m(±,‹Å_}EJ“SJü®Š,qçEíC´h f~µ;ïAt^†®òøˆS™4û÷:µE ú™zûÙ<òÎʈjÈ#UoŸHÆG’dÜ‚,Z÷jʾ?Òqy¢i©ÙôèÕ’£à?˜Æ×;t$âšÆÓY÷²Ö'8o@3–.;ˆ/Ò”$K´íÕsÝ>’»7#*ÝËÚÝ>‚®u!A_.Óg-ûÏÚ¨È]:'¢äÙzÀ_ï+˜×DY$gþÒ¸¡ñJünÔpê¸C‘Ê<˜.Ot½4õQŽ­·ÏIaÙu¢!©@M Ø6F¨þ²0h–µ¬qRd©FGé1BOÞzf=ô‹û™:꜈ß©zÛøØøü—ñ±L»N4äð{yöÎóm#Xhd]cûâщ@ F¢÷©zÛøØøØøØ6Ûl‰mcõ¡ÙŽª»}ot-ÈÔÛάóýuÔ€Ÿgî8'âöMŠT½m|l|l|l›êøs™v×ù¶¬£c„öÄô·!;z³ñ±ñ±ñ±m¶ÙÛÆza„Zå.oÜ *Öæ?]WyfÔYu¾ˆ˜ô3í®s#n1¸HÕÛÆÇÆÇÆÇ¶¹¡þ¹L¿çÛÆÖ¿Ñ1B¥gÕ¶“åóúˆ­óî=ŸßGlLl„9Í‘©·msCÚè÷û‰‰‰±mŒ@ý%aÐ:uêDJJJDU–HÕÛÆÇÆÇÆÇ¶¹¡$;;›nݺ±wï^ÛÆÔ_Ó4>z¿‘ –®Kñx<ìØ±£ÎË‰ŽŽfÛ¶m‡O¤êmãcãcãcÛÜPÏæÍ›m#\ÿÿŒ# 騱c—spïvöiqøøý~:uêd¿±l|l|l|l›C”œœºtébÛáúÛŒP-Šê÷òÉ“×srë +ÿï5;z³£[[þ³øØŒmc¤èo3Bµ$¦a0÷ñë9°m-_¾<šM+¿´£7;ºµñ±Åf„S±¡ÃCÿˆp„„e…~T°ñN]3B _º‹W}[¤³°øð‰Ø»y•½ÙÑ­OÕøT2·¦û.ˆ%ì:Qßlƒmcã׿Ñ;B–i²sÇv¶mý7¤c÷ÎåæS—ŒÐ<Ū¯ß)ÛxiÞ›xv4úÊbGô6>6> ‡º·ÜsºîgáÏË=§~|>?@€@ €ßçÅŸÿ½¸—¥l=8|ë„ºŽ¦Õß.´6#txèïhÌ!صs'®úƒõë×R”À4 <ž(zwmÚµÃáp–HS3FH kfA8%ÈÜn'k¾ŸËwï=Vᕾ¬C¼ûÐ@n›±”è¸Ä<çÎÐPu Y–$.—þQ1QåFŠ3µ AÝ"&¦f«~Ú½OÃà#„ èÍâ¡ë¦0}ÉtLMGq:ñÈè¤ï›Í̵¸¨o“üðÕE”[A ™rãµüšžÊo›a@„e’±v%ŽžhÍüùó± oÎ~Þ›|'[ºO契Ý"¢Nhj° ƒ%,!¹ˆŽ*Ù¾›ºJNÆ.¾Yð-Ûsú3aL¯Š[sË@ÓŒbœ„ÓåB‘¥°ÒÔ ["º^ìÝRPšìÀår¾ñBÕ§QÚú;{"„Åúõkÿð$<OYÆÈ²Ø¿?ß|ó ƒæùiS¹øÒ2Bá¯#$P½ûøðõ—ùȲ èÍÅÕáTî¾æþoÚ­Uæ¶w s¹’áO"KlžÿÌÛΑmšÓ´í ;¿ßÏÙÝÎfåΕåFVåûÿöÎ;<Šª ãïlÍ&¡÷ª4¤#H±¡(!‚„¤(MDº „"]º"€Š]DŽô^¡¤g“m³;3÷ûcSv³›°²ó{ž<ÏfæÎsÎÎμ÷̹3¼^‹=‹>Ç€…WûødžŒÞè90ŠÏ³‹c ±qIˆÝ?š)Óa1è1ozŒ AÅFo£Eõ¢_ìA·ý€%’GãèªPyy!|Ó$ÇG›± »V·„hÔã@Hc‰Ø†&¾2ô©¸vpæ/ÝŽ×G~‡ÅªŠc‚70Ôp\3ça‘7âñ•ãˆ)3çw}šÑV0¦àø¦ïökúˆ­ëgÛ¯$òˆþï˜6{#tj_(™f.}'LFÇÚ¹ØÆ6Ûëgì0}Ò=¬Y4‡o¦ÂÇK0¼Þˆ²ÞŘ¡!(é­tËóÑÍ}”ýŠÂp‘$)[tåÊ 8ñññx饗 Š¢Ó>r›b¢±Ç†wÓ¾X?ªVZFÇ„ý‹C°9l&T’Å¥~¢.ů³ûãÃßcÖWëðã•(«’ç:CeÒi±mþüOŠj^a4¢§ŒŧÐŇÁ¨ODßwGBPÛ¶ŹÈϱQè‹… µzÌÁæ1õìt¼„_]tá+Bûp'¾ø"þ¯uÁœ­[P:×ç›gL¨5ÞøjÙÊÌìA‹³,F˜º>v­èŸy °pñs° öþ±¾r.§“9’ÿ‡>ý7`îÞ h¨“Äß>ŒÁ£üá¨ã+r›"ª<É–˜ ©øuðûˆî¶‘a 2…Ù€kÆâÍÏ48ÑÕ-{<ÍG—ìñû Õ¬±ô7Ŧ~üø1 €¸¸8Œ?Mš4ÉvÛÜÖqr*´‹n­2ï1ê´I8}ò?¨$½[}]øûWìúi2® %Q‚ àyf³è¶MS ~žÚÇ+ŽÂ÷CZçéè øP|žU|8h4¾X^ Iõ^A|ô [(bÔë• f\Ù0AAAv=BBðÀ…sŠ”j‹Åwãz£´J& 0hM…ë˜` †”Dl_2‹®UöՓP.]Ð1 Ú„›~ ›—}¥`Ïóày3œÕ–‹¼×"Æ¢ò¬…hh-3àd ”¨Ô3¿)…a+®¹ÔY² ¹­Ÿ1 À/g©]ì3X •7š|áØ:·íñ4=Þ~f.\BÈb± 111C ™Íf„‡‡#&&ãÆC¿~ýrÜ>¯fñÖNú)ñí–—«ÙÈ¡méªõÁqö!>õ¿åðR]ÇØ±c1nÜL›wÈ̓}ÒnÜym:æõmD#zÊxP| q|8¹•Ú†!øâ(|30 ##çà·1Ã`âTx¹Ï"lß¾Ýîï×_6£¼MfÇh4ÂdâÁÞZ,m2Á,2ð&Ì5Š+ei™^݉ÞÏ(Dǃ1õ!–íƒã%ú`Õø @’ì²AQ»'@Þs,NE,À„‰1zÔŒ[€cw!0{5d1K8…/[•±Ï(¼Pªé縱ϥ6¶¶ Þ-ûºm§ùèÉö3f†1~{áB¢(aÆ øàƒpëÖ-ˆ¢ˆ`ÇŽhÓ¦ ú÷ïÿÄ>òbÖXÖg¥ãWªú„ÿîоJýÖè<|‘Ãò敌ôqG|÷ÝŠ¬jJŸºð2q©M^eKT>¾ú>ÚÕc0"ì;ì:tGölÁŒ c0o¿¶ÿØÅm{<ÍGO¶ŸãTДìjÍÂгÈår#Š˜âJ,×;7FQ7íñ4Y!±¿P!¹L†@XX‚ƒƒ¡×ë1`ÀTªTÉ¥>r?kÌŠ³gÉ*ôžò+JVÈY-¿Ùo*’bïáüM™‡´g ^ø7Š—©’–žËþùR>'ï²›á!šyìž2Û i''ª¾7cÞ)÷ܯ£øP|ò5>œEJvÀÜ©þ¸…:ˆ€æÓGa÷i†à“a˜6í2ÿPÈôûqÉo:kî`иÿ°æýÞé)%0KÔþ*û Š$ ñ~$†Ì¹A_®Â”ziY WBÆåÿy;Ogr2)Sƒg¯AãסK C"ü02Me6U£Hù^PÞî SÉÀP‚K†Äà࿆d.À¥6Y³ ¹Q%òœùq0f&~ˆ?Öo‚2mfC6Në…ÐØ™ø)´ª[öxšîî«ÀìOˆcýÃ6®[ò"I»uã:›ôÕÆc‚ °ˆˆV¥JV½zue×Þb±°I_a‹™9#55•å–ƒ‘sØWÕvçl¶k“uý¶¥#3m3ólŨvëg÷®Åbï]eŒ1fÔéX·ªÕ˜Q’ö­KIdU«vsj—^§gÍ*5cO‹$IL§Ó1‚âCñyvñÍv)¢›}#žè4œ¥$Ýa/uØš¶…=¼¹™5~˜uë°˜5l6– íø6Û÷ØÙ¯`dwte}/Æ[Ï‘Û÷amv,…wؗŘÊ.þ>]Ö› í1¡MNf¯V{Ëz^ÔjYHÍ—ï䜙œ”ÀjÕ´?gš´ÉlAÃÊì¸6Kl$ ‹½ˆUi´Ä¥6yå£.YËz֨ɒ-Yí—XrâCV³FˆÛöxšžn?Ïólíª¬K[eŸ\.GHHÂÃÃÑ¢E T¬X1Ëýv–o5BÍ߈:ÛB’YG^o˜Žúm?ry{…R…^ßü‚å­Ù£ /5ÅàEÿdd“2 è%VÝN²{Ò>“x$EE@]»;ÕxP Åçy«bÿŒCG5ÀqPªJã•ø ÉñX:l5–~Ó¾EjâÛ6Çp¡íT¼¨±©£‘pÿh¼˜ÃUoHÁÉ-³1|—ªgy¡çÖ‰YÜ`H: ­_kª§Âê»ÉöçLш¤»ÐÔë ÆŒëÓ´j9Zõ®‰…îÙ=¨Q´ðàÈÔî×Þ¥6yU?€‚ƒÙ"8|_‚™ä2—ìñd ‹ý…B)rhµZ˜ÍwöûgïD«F£Iç¡0™Ü›Šª)⇓7#:©ÌÙ _¿Ìž\­FÛ¹£±rÀtÜLÔÁd2Ád4 ñÑ5̶_-éàÑ÷óŸw(>Ÿüˆ(q8zµ2êy[ʼnÞМ†6)+'…¢Ø¸U¨ã­„Lå…–ã×¢øÆÏñwLJÆMt³ÙŒõ{Š¢k€Æ™‚h1#%1 «ÃbÁÅjر|HÆ-O>&D‹€s»#É`´ž MFhãïaÝ”qøxV¨õº Ñ Õ·±îÓi¸™”yÎŒ»³FlÁ´¥ KÕ¡SãNÖØª¼Q=d6¦ŒÃñè$˜L&z<ºySf°¸_u—ÚØò4õ3^j9†~ò2>™ý;RŒ¦4?MHMŽÃŽECñÊà±.ÙãÉ>û=¾FH.W a£ÆX8v¶KL—×J¥Mš4Í1#änyÜ=ø>_uï¶ûáW¬Ë7µZ¥ßÿ…'ÿÀŠˆ6Ô‚R¥Îr_[À}ðû×ë0¹(,Þ( €7{ãÃ;гJÑl¼æœ¿–£ ïç?Ç#zŠÅ'ïâÃ`–tØYúŒK[¢Ô¨ñÑÏó6¨7{ÿ€ÑÍü 7™ y) )ZË~ŒN|ŽV¢†JÂ݃Sq=h†ƒ¸aŒÁ˜‹¿¶Dà‡ˆCè8b&6w®WhŽ ÆÄ><„é}–A¦RC£`°ð2´ ùcÚ—M;g*XåClš&âëÏÂâ£' %ôX¶ Jy#5%r…<ý$‹bu°nC?L=KÔ¾P0YIŒø=Õ¼¬—CWÚØfr[?#Wûàµ/~ÆàU3Ñ?ô)ªŒ‰àMf¼Üq4"ûÖsÉžT3<ÖGWìñû¹„ø8VÐ' I’ðçž]ø¸W¨Óõ‚`q«¿¬ïKG§ÓÁ××7ßü˜ð¦ýÓ¯›8ï™W(NÔŒ1 øøøÐU‹âCñy&ñaE#nÅr¨æ/ÃÑÞ_£ÕæÐ=ú§L-Ъ¬? ÁZ†ïÎĺÁµÁD ¢®Äo~Ý1¨ªŸv‚Y‡Ö¢ŒÒz!Mþ¤5Ô‹ââ˜!ˆoù>ëûŠ+dtL/¤9Ùo6›¹~máByÉdB… r=kìyBz½žFôŠO!‹d‘ SÊè˜( ´ZíS½‡‹|,XûÓ… /yõdéçªñ øP| _|zŒý”"hDOñ¡øP|Èç|Ê6žo?e„ÑS|(>ò9Ÿ² ä£çÛO!‚FôŠŇ|ΧlùèùöSFˆ =ŇâCñ!Ÿó)Û@>z¾ý”"hDOñ¡øP|Èç|Ê6žo?e„ÑS|(>ò9Ÿ² ä£çÛO!‚FôŠŇ|ΧlùèùöSFˆ =ŇâCñ!Ÿó)Û@>z¾ý”"hDOñ¡øP|Èç|Ê6žo¡BL’\ÿc’Ó>(#D£7ŠÅÇ£ã“Ã[1o^ )1:&žu¶|ô|ûžî„$Šˆº{¢(ºÔ^©T¢R•ªË)#D£7ŠÅÇSãÃ1Aï_‡u‹ÛþIA×7J;¬3›Œƒ$2—6p™F“¡²x“ Q)@Í@ÍóyL0A 19Tªg3ƧŒÐóa¿G !Æ¢îÞÅéS'qáÂ9\6)Qàå¥Aý P®B(J»6é¡Ü¼}ÞÌ›FRLÁ8¼5™û¿ñ. š5k†óçÏC¥ñq.î3x‹™ŒÇ) RÉ­6gï£L®€JéükÍ&˜,||¼ólôFo§øP|žm|c0é’1±G8æï›Ñl\©„Áh„ $<ˆÀ’s-ñn³bi'4j9Ì&Âû|Œc ±8~ hYÏL‘xî_(ê·Di_olÙ²’`.å!ÖN†ëu¿Åâu<è˜`ÌIH’„?÷ìÂǽBNwnÝÄÚ5«ðÕ¤0xyy9ÝöáÇسg‚ƒƒ±`î·˜ôÍT!:¾¾¾nŠ ó¿Š«ÁF€ñøòQ< œˆK{9Øl0à㓽º¶e:FoºªåQ¼|¦Œm “ш¾ov„o­Ú$ ’hÙÈ£r‹.;¨ü¼ävýðz-ö,ú^Aìã“y":s²ûE‡âCñÉø0Æ—„Øýc°±Òt„½â‹ˆy›ÐcT*6z-ªµ?@‰¤ÀÑ8ºªEúUÉñÇÑf,ùÕ-!õ8ÒE"Ρ‰¯ Fƒ×nÂü¥ÛñúÈùØ¡š ¦Ô$ìZô†.¿‡ÑÇ2|Ò&œÁ£—: £.»‡¸—3 ÆßôÂ~Bß¡ñfëÆ(éë|ð(‰<¢ÿû¦ÍÞÚJf™ @ß “ѱvd.¶y² Æ”ûˆ\±ûÿ‹'càu:xUy³Â?Go¥‹mܳçÙúHnþ½ 3—ï‚Ù[%'B‹âýa_¡kÓòPpœGÛo6›¹~-Ç ú/.6†m\·†eE’$vëÆu6é«1Ì¢(²‹/²æÍ›³5j°#GްI_a‹Ù¡­Ñhdìi1R؉áìÍ^SX4/8¬×ét¬T©RÙnoÔéXhÕ*ìA–mõ:=kV©™Ý2OeÌéΚ~¾×6*̘šÄ6MéÁzÏÞí°Mny’Ý/:ŠOÞÇGbúÔxöv£>¬Ó[³˜hÖ³3ýX»¯ÿfz^`ͧgƒÁî/1IǺ:fÓ…À’b°ú}ÿ±ž3 :¶ïÃÚì_­%EÿÎútí¾ø6‚=rr®*ØcBbm<‹œÂz»“µ¬Öò‰ý F-;<ç]öîœÓ™×³žÝ8Ž5ýŽ¥ RÎHKˆ>ÆÚ4èÂNƬ‹D ‹½ñëÜ =»˜Â»ÖƆäädV®\9Çk“ÅÈ¢þœÍ6ÿsÍæ|®gGWõcM†îu¹»öò©Z¶ª}-¶î¡ÎA =¼ñ«ýÖÏm?cŒñ¦T¶vÕ Vh¦Ï[,$&&‚1–‘Ò GLL Ƈ~ýúå¸ýÓÍcàu±ltŽø÷Áê Á€(åx_Ü!MjˆÆØ±c1iÒ$D%ÝÃØ±c1nÜL›w(‡{Ù"xC,à]!m}ÒnÜym:æõm”/÷ó ŠÅçÙŇ“«Q©m‚/ŽÂ7Ã02r~3 &N…—û,ÂöíÛíþ~ýe3Ê«2o“F˜L<˜ÀÃh4Âh2Á,Z £Í5Š+ei·0Lxxu'z<£À}fÌ ]ò>Ü{mæ„6t©/Á¤Ç™%£PoÖ<WÈ2nËDížyϱ8±&NÄèQ#0:lŽÝM„Àì«>,f ‡#£ðe«2vËe /”jú9îDìs©MÖú×gTqdP)T.·qמgé£Yþˆ’£gû[NœLŸ’ÁÝúÕ£ígÌ cüv…`Öˆ¢„ 6`åÊ•X³f ªT©‚`ÇŽhß¾=ú÷ïÿÄ>žfÖÍxtbvÝ @M¬Å ã›Ñê½Pôîô*Ô {-é|¦O,\¸½gvžÁÂ… |1L&SF!Xrôe¬ž3=æ¬KëF¿2ÝþQÞǘfýP|(>Ï>>Œ‰°fÔh€è:Ëñni%*„¤ üJt×`Ë–›`ŒÁÌ P{)a8˜¹²`°N®ê Áœˆ¨› K+–~E¯î(í£Áo¿ý Þ¨ÇÕý?aü÷×0÷—Eî3Ç©P¼l7L võ,!%9 “wUÂÁ2Å/âÈw§áU5£faÞ ’`’€ØKû1ºgÄü¼A•3k¬Æá˜Aƒ±>ЬjJŸºð2ÌÀ<± 02c±;3ª˜hBÒí•дàrWl¶µçYû(`–ÔvÊ L4B°$z´ý§‚¦dWk ‡ÈårþlgýQêã®â»1}0(q=VRÛé(ÈýÙ3 FÝ= 4Œ H|p ×ÄfXµb+Z×ð{f£7gv <Ÿ1ºâ8œ\•‚{!ÖQ|(>ù&B÷'ÆOÝŠËW‹£ÆáQ˜|¼ ¦j8±ì–}Ö ‹™aæ°1r&à 靖曡‚Fƒ;·!.jzýÓ»zU·)–Þ†&Þ 1׎`ù‚y¸UâDn[ ?ų» W3 E³×6ŽB­ðáesÁµHÀþdà­±sñ^ÝâiÙë´Å·?ÞFûO·"ho›3,‡dV,›K C1–äR›¬Ù†'ÍHJß»>)ËFýŽo·¢ýgc¤IDAT|árwíy–>ªå@·ºJ|-ÃjdÌÖÍzDŸš ªªGÛoK¡Br™ !!!€°°0C¯×cÀ€¨T©’K}äÙs„8|kcØ‚õ¨×t!ðÉò<sð.RkÖ¬I;¹ñûø·qÞ,¢uŽÞD3ÝSÆc{‚!-ý¨BÕ÷ÆcÌ;åžûuŠO¾Æ‡“£Hɘ;Õ·Pñ¡Ð|ú(ì>Í|2 Ó¦=ÀAæ ™~?.ùÍCgÍ ÷Ö¼ß;=¥fI€Ú_•%‰" ñ~$†Ì¹A_®Â”zÖÛI‚+!ã îœâöÑhÄüÕüp¶‚Ý ᇑi"(ó­F‘ò½ ¼Ý@¦’¡— ‰ÁÁ É\€Kmlq5#dJMÄŽùýa¸íüÕ.·qמgé£ÂGƒöó¦ [Ï‘¨¿z>ZT) &Zur+Æ}w ¾B<Ú~; S±´ ,""‚U©R…U¯^EEEٵϩX:¯fe1§¦²z•:¸={&»g‡å’È’ãN³W_ŸÃ,’{}ѬšEñ)ñÍv)¢›}#žè4œ¥$Ýa/uØšvþ³°‡77³¦Ã³n³†ÍƲ¡ßfûljˆìî‘®¬ïÅxûb鬳qcc*»øûsÛmܵçYû(‰K¼ó7›úågì³¡ÃØè1£ÙÌ¥?³~zŸ…l¿ëñö§Ï+$ÅÒVÙ'—Ë‚ððp´hÑ+VÌr¿åKFHD‡ûú†¤ÓÐúµÍ¿Z NŸÚã¿[驯ƒj`(>ÏcÈûg:ú«ŽƒRU¯ÄïÀ`HŽÇÒa«±ô›Æð-Rß¶9† m§â ›'CK‚„ûDã­ÀªÊxC Nn™á»¼P]£,4Ç„ÅhÆáðÿaüèëTr ¨ž «ï&Û½„‰F$Ý€¦^Oë» FkC-G«Þ5±ðÀ=»äŠY‚ÚýÚ»ÔÆõl¯K¡5±Zß‘ãßt»+ö¤œLÿÊ­1yþ÷ø~ÉbÌ™5 Ÿui„%K,˜÷Vy·?3UP(äÐjµ0›yˆ¢€àà`̘1f3ŸñÇóÀ»Å¦«ÐhÐêÛ‰X÷é4ÜLÒYÏÏFâîŸÇ¬[0mièRuèÔ¸“5¶*oT™„)ãp<: &“ F£nÇ”Ù,îWÝ¥6¶d?kŒÁ¬O–yðÁøVìvý0çy—Û¸bOÁùh«µ%3’ãîaÅøh4ÿ'”VÊ ý_#$—+аQc,œ?û ïã T*ФIÓ<Í1&"þñߘÞgdJ54J³ h² 3;”u{ăÆGãÒrN¦‚å¡htæ ÜçßBEµÜ¥¾hDOŠOaˆƒYÒagéO0.m‰R£ÆG?ÏGØ ÞìýF7óƒÞd‚䥀¦hy,ûy0:}ð96X‰* wNÅõ â†1cJ,þÚ"¡ãˆ™ØÜ¹žg ñvÚŠ íƒ[8r`76ýò'š]‹ÁmʸlOAÛxø+6Ò‹›$¥ÓŒP… r5kÌôz}¡|çRaµ›âCñ)¼ñaE#nÅr¨æ/ÃÑÞ_£ÕæÐ=ú§L-Ъ¬? ÁZ†ïÎĺÁµÁD ¢®Äo~Ý1¨ªŸv‚Y‡Ö¢ŒÒz!Mþ¤5Ô‹ââ˜!ˆoù>ëû^Ƴwè˜È[´Z­‹³Æž_Í&6Ïœ SæèÔ%²Bcú+6 …Ê+ró®1÷3H…óKŒÞEñ¡øºøH 2¥ŒŽ ò‘|Ì…ýéBH†„§{²´ëÖZ ªñ øP| _|»‡;O–&=×~ÊÑ(ˆFôŠŇ|ΧlùèùöSF(\=¾ Þô„7½°eÁ`ý»íû Ûüüm®Fo¹íÃpÕöcÛ~pËGw¾×Â?ýS|Èç¼Í6žo?e„rÁƒg2>—«ÙÈ£FA®go›«£·Üöá ¸j»ÝwX£¡[ñɯï€Fÿò™²%äã³·ÿ…Ê=|ø0Oúzxã¬ÍEôU»u>>>¸ÿ~ùio[C—·³µ;·}x®ÚþÀ¦]Y|tç{-ÌñË-}ÜS|Èç‚ X±bϤö”|Ì_û_!$–/_ž§Y™\‰ÒUìRf±XðÃ?ˆÞ„˜¨ËÖ/?°|Š•p}Û4»Ÿ¦‚ÆUÛEQ“D”(W•ë¶„¯_€ËñÉÏï 0SÇ=Ň|.(xžÇ?þH>rû/ÊR¡P`øðáOÝOjR,R¬™¥R•ë@¡´¥‡R©Ä°aà ÄÇÇw΃Ib®2évß¿z"×}4®ú/—ËñÅŠÓ¹ŠO~~…™‚<î)>äsA¡V«1dÈò±Û¯á4cpvßzœÙG·/@Ì(^¦*v쉒2ï5–«ùj¶}\?µ'w®BÔ¥aHI€—O1Tx©)Zô%ªÖoít›cÛ~À¶%_:ö Ã!ãíÖ_=¾ “»¿ó ‚¾´Ïp=¸žyK& \uì_?—oEÂÃ[àdr”­Þ¯w…ÚMßÉÖnÛ>²ÞöËÊÓûqj×jÜ»r ©‰1Pª5(Uùe4}ïS¼Ú!䩾ƒë'÷âdZßúäx(½¼á눲ՠÑÛ¡¨Ù¸c®mÿwÛ÷ؾdD¶q~;r²ÁdHÅ/³>Á•ÿðõDIQ¥^KúÑAT¢„B`!5 ¦tÃó‡í–ÇF]Æî•í–9ñ›MFl™ÿÎÜlßoJ®߉kÇw⣱?9 9a»²>úzf–ãïÍóÖß½ðî^ø'Ûýgí#»Œ†ÉŠßæÄ¥¶Ú-ç Ü»| ÷.CÂÃ[èÐg²Ûñç :ü2§?.ùÃ~¹^ ^¯Eƒ¨úJ›\Ûn+O.fέÙÙ}ë¾ FÜ}ëì…òµ£ç7›Q, ,ýè‚ Hy‚Å‚õßãîÅ#¿’¨Û:_?Ü<û¢¯ž´B5í/¶’$!rF/\=¶P´DYÔ}=j~r/\?ضdj7ëo±,B'ç"ÛœŠ´³®MÔiõ!Š/ƒk'vãašÚñýÔm¥Ú+ç}8 ¢ `Ý×]qçüß¿ÀŠ¨Ñ¨|üqÿêqÜ:{p(ršuìRýMFߢˆõS>ÊèCíS u[}¿À Ð%Ç!6ê2¢.ýëwWmwdžyjÇC'EØ×NìFäÌPðz- ñÛ}ñþ°…PªÔô£#‚ !ä9ü»uI†ªðRSô¾-C¬tì†MßöÅù›8/”>±ce†ªÚ  zOݵÆú~“ö½'á‡/Ûâþ•à )¸qzê· ÎØÖbæû„"Û‹´mŠt V“wÐmÜjhŠøÚõœ€Åƒ› 6ê2 ) ¸õª6x=Û>²³áèï‹3DЫ{áÃ/–Ú]ÐÁÅÃ[ fÜ¿r /5Ïø/Íeª½‚¾3¶¡ˆ ]£N •—ã;c\-Rv¥]níÈÚ·¯_nœ½«¿À “+ðÞùhöþ§ôc#‚ðd‚ôl‡6͵ªC•zLÚ`—±á8Í;g><1k¡´`±à¯õÓJµ7º‘!‚@&“¡në Œÿã£oØíÿñíóDPÞI6ãIEÚ¶EºÅËVCÏo6eˆ +¨ÕäíŒÿ“b¢öñ¤B_ÛùVD—Ë²Õ¶Ëø¬KŽs+þ7βڪT£ç7‘â4¾Å W(ܶÝsk‡mß%+ÔÂÏÓzbïê¯0øú—ÂÀ¹ûHAPFÈ3¹vb ) €ot‡_ÉòmxcjÆç¬…Ò×Nì„.)Öº}»î(R¼”Ãö*¯ÍÌ>ÛcwKÅÙm¯3ÙîÛš-ÊܾaÇžBÉ*†T6ÂLžcÎn½Ùƨê+m‘{Ï¡MÒã»™—·~®ßiÿâ¥+»õý¹Z(ý¤vOc‡mß7Oÿ™ñ¹|í×ÐóëMTDABÈs¹yzÆç—[¼ïüB—ÃÓˆoØ\øj5q>++%>óŽÅJVÈ^è8ÉT×iÙÙíïÏÕ'E?©ÝÓØaÛw:¯´ï ‘?8¦ADÁC·ÆÒ…È­s™B¢ÖkÎÛäP¬üðæ™ë²)æµ½P–­Ö ˺³6B¦‘Û™ Û™PÙ=)9úšµX›ãd5F®ôa£'Ã!°ÒKyÿEˆ þ»ë£»vØöNjb droAx*t†N#½þ†“ÉÞÖ²2¹¥«Ö·ß>îAÆç¢%oðF=ûø•D骙BDÄܵÙ (ï¢Åí¶•$ ÷®Ëvß¶EºEÊ9©}#sêvíÆ3Öœú:Ä(Þê£wÑâø`øâã©T{ûˆ¿ËñׯÞÏð/»øg‡+¶»Ú.·vØö­ôòOÑH޽‡[gÿ¾5ax«ßTú‘Aò\Òkf˜$Áb技¯Øm\4çÅÊœ,3¹f1 ööµ[rçJXx Ñ[¡à8.c]rL$Ñ(^ÆñŰ'þ÷#ôi…ÇO*”öò)æÔ¿ô"gëþû:¬w¥Ø˜K‹‘JSõ^ïš/ßcDQ„\.wy›¼*”~;lû®Ñ°=Ú|<?|Ù’hÁ¡ÈÙ¨Pûµlo¹Axý§X (_#ýˆ‹ÿf·îö¹¿±ifhÆÿΊ•K”«žñùB–í£.þ5S¬BÅ×­º~a·ž7él2 F»u§v¯ÉxÚtvû¶½muw.üc/Âv­Æé=k­B«l54ìØ+Ç>²+6NªvrLnÚÔÒØ¢KŽËÈœ¹Cñ²UÓ„¨ˆKÿüî°>51&Û[syU(ý4vØö]¶Æ«¨Pû5t<'cÙ/³û#þÁMú¡Ax”J£N«.¸qjà·yŸáÎù¿áë_Ñ×Nâæ™ývmeê·ù·ÿ;غp(î^<ÿRuÿù=-[À!härøú•´Û¶ˆi› êi¬ŸÒ¥*×Áíÿ êÒ¿OÜwÖ"ݟƽ‹í>†_`ܽðnŸ;À:k¬ÛØŸœîºRlܰcOÜ8µ°fbgÔnú.JW­Žã{®ŸÁã;Ð!ô”¯ÕØ­ø×kŒ»inó·}qåèÿP¾:tI±ˆ¹{ Q—þEçÏ:ÔV¹j»«írk‡}±ºµÆ«yçAˆºxçnoHÁ†©cð¿¡òò¦A !Ï¢aÇÞ8»o¢.ý I´àÔî5Ù¶u–MhôV(Îú·ÿ;IfT)ÕÞõ=ê¶úÐaÛ"ÅK¡Ú«ípë¬5ËrùȯvPª½3n©e·oÛBkŸbÐkãö¯ÒA‰ëQñå¦ÙˆÇ'"g¥ÁÝqýÔ>œÝ·’(àòÑm¸|t›C»ò9<Õ9;^{Çú:‹[g@œ;éRÜ]µÝÕv¹µ#»¾»|¹nCÜýkˆ¹s¿7Ýǯ¡A„‡@·ÆÒ¡R‰Ofî@ëF¢X`ÈäJøú¢në |¶à@F´L®@)'3®ä úN߆7û…£T•ºP¨4P¨4¬øZÀÈŸ. AÛnÙî¿ÇÄõxí~ðõ/™\ ÿ2UÐ2h8F¬üEÊe»o»'R—,‘«/eø W¨à_º2š0_®:‡ZMÞrºï¬}äôZŒÆ¬DÈä¨Ùämøø•„L®€—JV¬o|Œ†/Fåz­rÿÐiÛÐið\”«Ù*M‘´‚åÒ¨úJ[´ë5Ñ¡HÜÛ]m—;rê[­ñAÈäPª­Y sEâèÖeôƒ#‚ð¸„ø8VÐFH’„?÷ìÂǽBé!‚ "ß1›Íˆ\¿–2BAA¼¸"‚ ‚„AA !‚ ‚ BAA$„‚ ‚ HAA"‚ ‚ !DAABˆ ‚ ‚„AA !‚ ‚ BAA$„‚ ‚ HAA"‚ ‚ !DAABˆ ‚ ‚„AA !‚ ‚ BAA$„‚ ‚ HAA"‚ ‚ !DAABˆ ‚ ‚„AA !‚ ‚ BAA$„‚ ‚ !DAABˆ ‚ ‚„AA !‚ ‚ BAA$„‚ ‚ HAA"‚ ‚ !DAABˆ ‚ ‚„AA !‚ ‚ BAA$„‚ ‚ HAA"‚ ‚xÆ(<ÉÆ}#AA< ÑáYBˆ1@—šB_ AAùŽÅb@·Æ‚ ‚xQxšA¢(B’$··“ÀÑ·IA<·Èé2çwËj8à8™' !žçqòä ܹ}£Ñ p¸¨/…BNGAñœ]é0oT2Q,² I =‚J¥ry__T«Võë×÷,!ÄÃÉ“' ×Ò³||‹¸¼­E1löV¼ÿv{P½5AñÓ½1Çøp˜[%5E‹ùáõ6m°yÓF+Rijj„ŒF#¼}|œ:”~ÐÙÞžI4Ÿ ‚x¾`Rš’Ñü&G!$³Ó¶ˆ¢Žã s7·7 £ç !€IÌ©JÑja6ó(XÊÉAÂ2Ú‘"ˆüC(Š?‘Ç×FÆp”r*„¸4 9œ«<ˆR¥J¡N:bÈVk(<ìÛ†”å–c Úä$œ>q%Q¢dI‡ÍÒ·‘ƒDJˆ òMíܾ»gû™ ˆ<¾ÐH¿f“Ê^eÍ™L&¬]»ÿ;‡ ë×ãå—_¶C¶í=ng«êÒ3A§Nƒ‰Ô©WßAõÙnÃ$F·Æ"_G¥é™WçŸ ‚Èë^ÆI¹!„Ôj5,X€Aƒ¡GH6EF¢víÚ…C™L&»ïÝ»wÀÔ¨Y f³Ùé6ÁêÉ"ÂÈ tdD> #/dû™ ˆ¼¾Ð²´g˨FÈ™LÆL&ÇGî¨Ô*L™†w;½‡uëÖaòäIëÌ<ï¹B(«ª+[¶âãqåâÔ®S×iBú 3Ib$•Dþü6Àl~gN>‘÷Bˆ~[îkÆbãâ0zô”(Q!=CìÚØ–ÑxÞ­±,éuoÔ­_—ΟÃëWQû¥:ÙnC5B‘'0Èrëï,›ÏAä±ÊrÑ&²ÑY„ÁhÄĉƒÕ?­BåŠíKo<ºFÈÉîííƒ:õÀb6;]ï¬^ ˆ¼E&“£u»wÀËö3AÏæºHd¨e‰‘B¡À'}û¢téÒ¨X©’ÃzÎIióþ³¢ñÒ@ã¥É±XZbtkŒ ‚x~à8ʹ$³h¹L†¦Mš8]—u™ !¾¾¾Ðëtðöñq«:>##$Áú0"‚ ‚x>¤˜DQpU¸ÚV¯ÓÁ××׳„LÆ¡FÍš8uú4^}õUxi4.o+ˆÖ£Dx«©ªž ‚x~D€õIÉ„=’$1d;«Ü©ÒëqáÂÔ¬Y Ü÷!Äq^yåUœ:uûöîÞ`p]݇*8sú8AÄs‡‚c8sê$"«b ‚`Á¦M‘.k ___ÔªUuëÕÅ£÷Á%ÄÇøÍ$I’ðçÞÝô„'¬/4”Ëå`…ñ3}ƒAdƒ(Šø?gdöËZ[xIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/adialog.png0000644000175000017500000007412713070106167016740 00000000000000‰PNG  IHDR1 ¢}gAMA± üasRGB®Îé cHRMz&€„ú€èu0ê`:˜pœºQ<bKGDùC» pHYsHHFÉk>wLIDATxÚíýW$Yz߉þŽ»‡‡–©e¥*­uËé™îž Ar¹$÷Òh4»|ãíîÝ—}  š-H>,hkà@³Ë»\î’Xˆ˜™Ö]]]ZËÔ:#3C+ç>xDTdUf©î®Ê¬òŸYUfžpqއûçç|ç;ÿOüÁü¬T*H)qqqqÙ(Š‚×ëEÓ=ªÕ*…Bîîn¼^ïË®›‹‹‹Ëc)—ËLLLÐÓÓ¦y<(ŠB"‘ ¢(ÊË®Ÿ‹‹‹Ëcx½^öïßOµZE3 ¯×K,etdÛv‡”...[!àêµëhš†4¡(Ä£Q¼^x<ŽmÛ/»Ž....›"ø}>ª¦e[hKËKD"Žcßu¸liÈÚ/¶m£…ƒ¡u†Kˆ\›o ‰k]\^8F,›«ÐÞá J¦e=ÓÁžÇxH)yæÝ$l¶—×£ôëßù…sqqÙHÀ²l´hÔ”!`f1Ã7–0¤úTM’µ¿…PžÜ›“`I‰ýë'E4úk–-‰ñðvà×lÞÞ×Fo{Ô푹¸<'ÛÉ$iÛhFµ‚!wgVÉ>B¡Ð3¨9(Ã1`O&jO{ü§q ²¹,oNã•%¬§˜a•R:]ȧ8þ“|…Ñ8ÎfÛ꺎®ë”Ë•§º¦’góO>ÙŸ)×Òiú£8B(LÓÄzæÞø³O=­V4Ý›Õýyëÿ<׺Q[ò¤ñDó½l:q&„B À46¯ûS×URë È ÎSumpíuÝK<‘@Óžöé|ùض¶–ÎÐÝÓ €¦Àh»J$TëõX6†i¡i*¦e¡©Oñ³¾ýóþ|ÆãZ–Ïë!çWÉ®è>ßSź5O÷xûÐ8†sXùÈéô++)ºº{ž:¯^ÇúKæÛªãÃí¯o`™&³3ÓDc1‘ÈSÕq£ã=u}ŸTçúññ!Ûh§o¯þO+ù4vï‰×½^wƒÙ™™§ª{ý­ç&u«_ËîÓL:ÍêÊ íÛ¢G&©±––dí„íî'ò3»”&ô‘+”‰†üdò¥M~–‰†|ùü»ý9»”¡5BS_^(¢ëúÅêÃÞ‡w Ä:§ÞºÏÚø¡M7d£ž¨¿ßO¹TÂëõ>òÀoôõ<|žæã6öŽú=WG÷zñùýx<ž¦óˆ ;¬ÝèÍoú¿€+ùMëþØúÇ8FáéεYÝÝ©»ÿ±uøî›ŽTžTŸ‡ïS!>Ÿ|>ÿB®Ù·li£Ù¶ÕhЦ*Ø5¿SÐï%ô ùQ…X$R‹‘Ò&ôô‚­èDC~¢!?ˆ}Oü  ùAJ¢!?¶”>ùµí„¢ jÇ÷!Îy¤DíT(+ØBA‰eYE-ML[AW¤”TL‰G(Ã0ðx}À²L Kàõ8oªj©ŠæÕÐ4•JµJ¾ ɈÞ®ÖoÞæ7b}¸ðð-m)íuCiY䲪VóC† øõu=šbɤR-£(*¡€T Õ¯"H†=Ô¯þ»s,YJlöðIlËZWÏj±H®X\÷ø(ª—h4„ªˆFû-KR,W0Œ ¡`M‘XÒÆ2$ª&0mPL=P÷Ã6µ¯h ë*ªª@“¿´ùÛ¶” (¢±ÿÓÔ³žáÓÆD>ÎHY¦EÕ¨â÷û»ïƒžº|lÝ­‡ê.miY¨ºŽi•±Ððª*RJL£D6WĶe£w%Õï#:÷øÃ÷èºk»þÅQ/ß½0çjÕûÍúšêXöJÕ “+’ˆ(–J|ñÅ”Ëe„˜¦É@ÿ î!¸÷åÏHÇúØÑÞB mEQˆÇã(ªÚ¸ñþ N§™œšb``€ññq:Ô¸Õb†‰¹ý}}Lß»Æäü*=ÀÎ=ðË4ËEÁ`oJíâ £dÙ6Jí¦Ÿ˜àÒÕÏX(‡ùÑѽ´¶¶òñ­4{ºÃtÅý\þâc®ß¥gä ^!XMÏ1µ¢ó?8M"âãÆõ[´¶w³’/03s“lE§¿sc‡GÐe‘éÅUZ-\»p<BÓݵÝʲZôuµ#j-¶k7oÃÈ Ai%Ãù?ÿFw¬ñ")æl’áAÞú`€ —¯“Z^ë+\»4×W¥"½|øÁhO(ܸÖ\¿d«^ú;9~xM˜Y\£§§Å.3v÷.Ëé<Š¢ÐÖÓOG‚™™YZ:zù<n –m¯3ÆcŸ^d¢¸Šò7¾Åôœ~íBËóå×7è‚ôZ‰û xƒ&½‡øá{{™šždñ^–d‡BÑfmbçv¢j “ã÷YZÎâÕUîÞ]¤³3F0 âiïàðèn”J–™Å4±H„ë·Ç8~ì >›c´·ÅYɤii|ýÁæþ½[LL.42gêÔ©“F;ÌjEÓçWçY+J:;;ÑTÑ8‡-%šª0;7ËåËWøÉO~í£X-å˜]N‹D¹rþ± Ïysé4Ër†?Š‚È¬°03Åt)Á-_ŽKþv¦—rz…ä÷Þ£§§›k׿fff¿ +™þÖ#$an\¼Ä­ûÓLέ‘²ýˆ|žx@ãüÕ9vöqçÞìP'^%ÃÂô2ïþÊ÷˜¸w‡3g®óÁCÜ;{Ÿÿ4mQ'OÚ6ҖضíÜ4B`6Éx7‡GÀ– @v©ÌêTÛ®réÆŠ™"±@]µs˜rÎ"ôpëênÝk®_x Â…kóìícöÞU¬`}²Â¹3ŸSRbìBÅëC #—âÊr–“G ¤íÜÒéÉØõZ„ícÏ®½ø[ÃPÛìvqi˜¬å—8séCmAZAF‡DZ{JË’LܸÊgŸ^&Ô3Àp›—">>ùøfÛ0Æ\™Ÿ‡ùå|>ÁJjžlЋ­2j 3uù*v¸]ä9óÓŸmI²¤—[Wn8y3·Ê•¥'ÔI2ÙÏmŒž6?ýËÝßï§P(P*–Š`ìÜÚ†vÐÚÕ…ßïGQ5&î^æîØ$'Ž&èÕI­Ì1—õrh¨•jµÊj:eÙˆF/W6×®\ADºÑì,©ùÞùỀÀ¯ë¤²_{Ƕ6×]ÁÊÂ] E–?ÿC±1Å8U&8°ÿ Š  Uª °8=ޭŰl?C ˜e®]¹‘n<2ÃâÌ2oð6÷îÜ䋯oñöÁNî;ÏwšÖh°QïútÀ }N¤””JÅõ“„šê ɪU“ÕLHÐq’wtv¢( ÙÔé’àS»±¥Í䛄;ù›ß]”™ŸŸç­w~Àà@'ÕªÁÒÒ–½~¦EUTâñ8£!m P3…I¥Zau~¹åEÞ>ò~#K ¨³”ZcdG‘!Zèï‰pþÆïŸu¾pãgY( B‚5?NWg‚R®‡…±«ôüÊiFÛâô¬}‚& É‚^E$H ÑX’@ÀKOOœ‹_ŽGé¦àédww! Orz‰ÅÔ2Ç÷£”Zdu5ÅkW˜_ZeçxQºÛƒ\¾=Çûdž^Xm8i7õĤm27;ÆÜùlãú2Q½«Z$ÔâchÇ(s×&‰usöë«|ó4!½@ww‚‹g›ë×MHžåµÅFý²K‹¬,§yçWßdu~œÙ…4–!9xè½\ûä<©ôɰ§áµ-Ëyà¼lÊ¥4÷®N¡EƒÔ_zKs*;í¤™aÇÞ]ô{ò©"Ò´Oñýïõ ­2¡h‚ ¦+¨QÈ[ ôFh‰DÐz{ „ðzTªÆ(…Ìç/\¤¥­Ÿ½ƒ;P³K,¬,srß1 Ë‹ š¾Kª-Ñõ ôsõãs­?@0!ª9Ë…À.¯ŽQôÒ²˜›ebr£”ç«_ü’ý§ßæˆ  âœ:ý&©¥„mc[&“7®ãíÛ‹m[ %3SSüò—¿$OÒÝÝA,ÅÎ/³´’âä¾ãä—PUMSŠBï@?×?½H*3B2T«;ÎK®^÷j)ÃÕ/¿æÐï°–SØyôm¼vž_\¼G$£˜ ²ct/ó·î²ºš!‘ÐAñѪuBf‰Å••ÆùƒÁíímdVS,ÞYÃÚCgk€+wæøþÑ!l)ôk/¯­Žãk Õ+.Uqâù5µÖ«½!’ÌÊüŸþôœxŸÖXйQ´(G ¡bQL§°mÐCQ,Ë¢R©pîü9J¥u·°Dâ÷ûyçíwP5 ÛL#Ôhí æ§/sæv…x ¢~ áòö?äÞ;üâ¯o1zà{‡Ú ÄÉÞ¼…<>Òofc¶¢ (*Åbû÷&˜*–Zeìåb«¼@²?ÏÍ[÷˜ZÎÒª¨ª¤TÈ1~ókî÷Ø”K)TÛ‡mÙ(ùiî,X ££Ý¬¥u”‚IÐYÓ$‰200@¹T$µ¼†¹£ =ÔMöîæál[bZ–ec†ã£Q†iÓÚÑKÇþa¤íÄêeSeÖf Ò©,r5Í|¦J^”¸=mo 2vûÞj-d¬¯ß¼…@02ÚÍjFC)Z=°T¬ X  †âôö„øìç_Ð×ÓMGwFAPL¯bZjÃ$Ó41MÓñÝ(Õd×pþ–Pãþ¾Oa™U–Æ–ñ”%Ë9,© hH3Ëù3רw`÷îMn "tÞ¶ Y­ÌÔ‚wB(¤\© (*ã.Ot²s ¥h“ÎäQŠ&¤ ?JGœk×oQ5-LÓ@xâO¬ÿÃ7½¢&ï¡ë!¢!•jµJ?m-Q®]¿ÁÈŽ=¼ûÆ)¢mmT«Õ†áK´u"€…é{ÌåoÅcUÃ0éìhg×è0K ó\<÷5ñÞAÚ¼jÑrêoÌÏÏqåòto€½{váõ†0 PJ¯aú5ãkcš¦i°–šCG' pyz•är†€AË.àóî!+YV–ŠìØ5а²Va%£“ÍWQë×Ï4˜˜çÓO?#N3ºï0ÕjO¨‹Ìå ÌCýضÄ2Mä6€B¬÷‰©ª!©&kÙ¢ãd—3Sw¹xåCGN°4sñîvú;ô öÛ4¸tñ±Î´Æ¼X¶×çå‡þpÃÛÒi³25N´giÛ¡P)¤¹{s},f,Ç8Y6º?ÂÑ“o¼~•³g¯±w¨[šØŠÖt£:½1Ó4QK±ÑZ»Ñg'ñᡵ-Ž/ÇëÍ1+–R)r9ȲšÎàñ)˜Å%æ3EÚdáöNÒVˆÑ½ÎÝZbâÆ"É“]/³¶‰Q»á|þí]òy.]_Ä4‡0Í –Ó4±mË2±l Ó4F̲ªÌÎŒ3w!W>@>cÕ{°†W“Î5´LTM#žh!‹38\¥dÚSËX{Ä¢»»—'ŽcY6 1ŒzÝ­õu7Ô=œèf×P.™£P\£P\Æ öà‘Ž!7 ƒJ¥L¹\$å’S&-sÝù#á=½½ ú1 ãÁ=j˜Žñ·,¤´ÛÛ²Ðd“3Rmò‰EC>Àâö­kÜ›\âðÉ7éîhaiú.gÎ|Iôï ù)å—8sæ…ª‡÷Þ9…°­ÆÍc±IО"˜½“[sU>üµT²+,.Ìó‹?£e`7»{"ŒOÞf9S$¦Ù\<²e’^[c`äÒ¶È,Ü¢uhYs„ TTáÌ8 !¶…HöÐÖÝIµ§=±ÀÕ;·F³2GÏÈ.vŒìfhd7+©5&nMp䣨†I0ägn,@Ъ ˜š[¥¯˜¶P¦\Âö@Å«²’-ãÑTVVùì³Ïɦ×Þ{۶ɦƈ÷ö:Ã[>2Û6( Ø8³J€¢:Ã_¨Šs3û|~bAð%Û1m/q½ÔZ¯j"Í2sË!ü–áÔov•¾¾aÚB­Ný4AY×XÉ–H†¢ìݵ“[Ï3 L¯ßG)³‚æ«à ‡3Hu®½?¥¢Ôf!kÓÛ‚Ö˜Ÿù—xoŸÖNq¶HK°—Åù¾šeÏé“Ä:Ú@‚‘_áÚ˜ÂJ¶Œªt]Egdh€óg® …Rö)êØÕ*÷nÞ`>›C¨^Žž:E[<„U»÷5O€=»v³4=ɽT–>ÕSë‘HŠù®Ý¸G±XFõú9|üÉXËr&!Ð=:VÝ—%Tº†'⧤;÷ˆ¢4]«mãˆr.…æ«âm®;²æ7­Õ]ñ€”òy¼1V‹oOÑ5´‹B¡€ešXF‰Ööº× -ŠDŸ®®®uç“R¢ê>¬B–T¦äÔ¿£ USkŸÛÜ¿{o¸þÎu¯V*E<8VÍÙ>¿–arv…âÚ%âÍâÕ=„^–g–5Ÿ›†ß¯ô[tt÷"*Riçüm­¨µ0#€bv…»+ìÝ=üàµlli‹Çb늣 !˜››Ç¶mÒé4âwÿ—ÿEŽŒŽ¢ëvì$‹¡j¥²A8è£Z´nyÅúˆ_Ñóòôv|}P¤hÄþÔÿ¶Í sËk´·µ¡kjSL‹$¿¶DQê´%â”+U2… ± Îµë7t4UmS!ê!‚͹›ƒ8›â&m,‘Žç$¶Yeq5K²¥¥vÐtƒ¬R–ÑpÇdš&Ùl–h4V»™ju{L°«s#Éu•‚oêÇÔÏ2«,¯fiiiÁ£>ˆ›sê ¶Yeeu…hK[-†Î9v.›CUÁàƒk¨<.ØU¬ ]hÇ”õÙMøŠ×ÅÎ5üÇ¢ñYó÷öpšë#*©§¬?õë܈ƒÚ膬œñh=÷·Ü`-FÓR®‡Ë-³Âòjn]ý…¨_û5¢-­O¾ö˜ÇÍ®ýÆÏ—”rÃó×U̬RæÑ{Ô²,v ¡ªO·~úe „àësç1M“‰‰q4»išR»Y«†Éj¶H$äm\¬æ‡©Ù€”ë?šŸ²>%^£²×ÿ­h:½]µ1º½®¡x+! ÔÊáÔGQœXû¡µvß ª‡ŽÖ–FìW3þp?‚)ë½.çÍjÓ< ôxž_ R¨ÚkõÛP­WQI¶¶;! —BÍ@ËæP϶Œò™ØìH¹y¤õlõßÈøäØ/•Šx}^tEâ÷€mU_ìOóÙ~ꪪ*˜¦Ikk+ÙlfËάÄ=:Šâ¬-ت„ÃaÄV5´¯pý·JÝ×VW·æ*ÕjÕÉÈV{ÆmÛB³›†aOø ÞpD4;3¶äÏæ.o0¢³«ëe_j—ïˆ|>Ojy©ñ·mËæž˜¬¥6žî­ýóáúº¸¸¼r4OÎÔq|bO”ìXß±|XFÆ5.../ Û¶×/˜R©D±Xlü­iápEU±Ëy×hëEH¹òi [¹\F×uªUÇãRº¸¸¸<#ÚfNf!ÓÓÓܺuÛ™M“&3³)þößù-ÚZãdÓ«üÅþ¯tí=‚b[T ¯®384ÄÐààc ™¢(üô§?åôéÓœ9óǧ··ÇÍyéââòÔH=±‡y„ºsçNvî܉¢(¤fïñ™gŒ@8¶ÅäÔ}:¼ÇÁN&§îóõ¹{üæßüuÂápm¡í£=«z/MÈæ²˜¦I.ŸÃ4Ú9·Åây——E³}’|ÉxȈÕÖV*<G¬M( ¹ÕE>ûüûß|W£˜]c9«ðÖ[‡ˆ‡|”2c$»ö00ÐeÙܽ{—{÷î#”¦ S[2<<Ìðð0RZõѬ@È*—ïÍЕl%P·Uˆ‹‹Ëw¢ˆ‡·–â}`ÄÛ²™Ÿ›uÖƒu÷àñxH§æøüãOXÍVÑ<ÎæˆÓoœ"àÓ°¬*÷oNÒ?ú¦“ºMJ’É$Z“:&8=»X,æünäAT= 8r/Åô ³×ñ©û(¦¿Ãq—m‰”ŽJͺlL²9sš€J¥ŒmÛŒŒîDÚ&wo^âÖ½Yv—cj‰3Ÿ}ŠxóMzZãhšJ©˜åö•‹¤ÕÞíu„ÿ€X,F<ß°RÚLݹ‹ê ‘HFҵfÆWè8Ȟᾗɸ¸¸¼¶ˆÚ(ñƵ«Ž°h­\òPúÇzBEQÈ ¬ä%o¼ó.-Ñ 9~Äbuq‘îÖBšLMÞ!+ƒüèÃS5‹‰6tì Y.1³˜å­wß!è®®nîM±kÿavºÎ}—GqÄ(EyȶÈsØJ ŒròØ!àÁ"Ñξa:j‚†•Ñ]GÙ鬺~ºx1)Ѽ>Þxç]„ª`šßÿþ{ 4UqcÎ\\\ž ä©7Ü`Èø‡‚_ŸµçTÓÆ©».ùá0—gF‚ò¬éê]\\\¶ RJ´Í’~º|7T«U,Ë|ýH—W­–Ù\Úö3 ¹¨ª¶~F²‰Gû.ßBÖÖÖ˜™žv ¸Ãg—׌P(„·– àY°,›–d’P(ôÐ'²ž<×åE±²’¢o`€D¢Åõº¼v¤– G£øýþ§ˆ`ue…|>×Ð[[‡t{b/  ãá]^G<Ò¶yV?¼ªª›æÃ”€VOÔ¹BQP6XÌ(åú”XJ-vc}ïBPËÅëü%Äæñc¯ Bž$}äâòªRO’ý,6 ‘v[>ƈݼy“C‡=º³PXº~…s σqlՀޮÝØÛÖÈ¡wýú zzº‰D"Îoùr†™ƒŽF©Pf-•¡«¿¯×‹ßïÇ2ªX(Ø–‰Ð<è5)Ûªb˜MU°QÑ5å•ñ EÙÔf[&ù|)ÁPmÝzI¥TÂãõm]}~—'àäËyöü–Î.‡r)4¯×»á‡B,œÿŠ« «’­ ÕË©"‰ù‡öµQµMtÍËٯϼKÐpÁª ‹w/pnÖ$RÉ3={Ÿ‰E8²»›C‡°{d‹çÏÒ6t€ó?ÿ+<-]üøÃ7P°ùò¯þšù5“÷ß;Ä•±eN;‚WSœØ²m¾IJ{cýÛàâÙϘ^. anëå“GðÔ6Í¤æøƒßÿßù{ÿÃ?¤½£õe7ÃÅ幨+³>KOÌ1|?7BÚc>”¡¡¡G*Û²‘‘þP¦Õþy‡Ä¢PΤ¸~å ÊN~Q„¢0uã”ܸ³”f°«½iS"?xüàË®¾‹Ë7C6õD6k”?‡OLQ¼µ^ƒ¦ùèLú³ áHØ9¸â¡¿6$j¶ Ž™J ˜$!Ö‡Ô»”ûÁ°Ä†"ˆ¶mŠ·q4Ù¦äØêýàù†“¦¹Ô|ÀÍôÈê†gÓ‡VÑð>&nSõxyÕØ(ƒ±‹ËëD=Äâi5û·`Ä\¾ 4M#N£ë:¶´UiD$×W;¸enÙ«V†˲0Œj#j!¸º7*Ê¥^Ÿoóçêe?د RJZÛÛY˜Ÿ'“N7‚^mËr¾´Ú?·ìÅ—)B4žºeO.Âñí>kY0À¶mJÅBã{x‹VlR¦àóùI´l®ü¢mç…í†WרÁzÿ^sÞÑôóYË6:ž[æ–m±²Z/ëYxÜÚIp{b/œG¿ ¹ÁïÏS†[æ–mý²g\üý4¸’...Û·'ö‚1 ÓMÎâò¢iÚs…X¨Š‚ú˜¥v®{A!H§ÓLOO9 !/»B../) ‡Ãx½ú31Û–$[“ƒ¡ ?wØ $•Z¦··ŸD"á1—׎Ôò‘h¿?ðL†lmu•|.G(Þðs׈½@‚H$B |ÙUqqyádÓ¤-ŸKcÿ™¥xê<­Æ¾PjËiÖÇÑØ·ñ<¶"¯[väâòª#ùö5öá1FLAêÖunÍ/ÇS; ¤j@{ç.öîJ64ö§ïOÓÒÞB ¨EéB¡’c~Í =¤Q*VɬdhïmE÷èx}>lÓÀFAÚBÕÐjÁŸÒ61-‰ªl4õÕ™@mû Ò¦X("‚u/bn…Å"½ýx<¯Îõpy½h,9ú5öáqFLQ˜;ûV &[k´J‰wFŒP(–PT…¯?ýšý'öÓÑãÈi„Baï]àËé*‘ržÙùqÆlŽìéáСCìâòůIöïãÒG¿À“ìâW~päÌ/þšùU“÷Þ=ÀÕ‰N9„þÊhìËFôzl®]øŠ{S‹$ý#œ<²¬ÌŽñéÙ« ï>ÜPqqÙŽ|Ûûu6E´m¢1ù*šæiˆÈCâQ…ûccܼy US¹pý"Y;G¢%ŽÏïç­SG¹x1Kg0BgÂd2%èORYž#˜ø>‹3w™Y“:ãëR‰ìÄ æW÷!ˉ|ž ñ¶^¸t…»³]ìHFXš_b`x`[ÇlËFÙ@c¿¼ºÄý{÷xû'ÿQ¹ÆúÓÏÙ18J{Øâç}Œ'ÖƒQI“Î%h‰†žãÌ../ŸfýúßÙL¯×‹ÏïǶm2™4Á`] ñ8}xLO¬\.sm|’tÕF–2¤ò:£–%©nÐÓ÷kŒŽîBØeVrãì<ö=ÞíGJX¸w™[û:ŠääC¾Raòþ$ïýÖ;Í4õןð«¿ò!‘€;ã² Ù@ce%E>—ehx”Õ•ËËËìܽOSšHž ±¿¡y“@ `2NØçÅj¥5ÑÅÈ@/þ@Ý@Q‹³S$Ã}äç)Ή"ñvŽ9‚‚D(*ÁH„X,F8èwÒ¾e!©;¢´mÚ{†e*fˆ¡žöưQÓ“ÈLŠX"Ρㇶýp²Ù±¿67ËW_|Á•[Îä‡R³± T ›ýÃÝ=ÄèþØ%‹ÌÊÚËn†‹ËsQר7 ƒjµŠaš´wt i®^¹ÄÂü<=½}hš‡jµêlcæ7ÐØ7-«¡çãhìO2›.ppÿI¼ ,ÏMpñæ$Çßü驜¿x™#÷jí$Zd‰/!LÅ­mx=:ɰ$UmÒØG娻oc¡²<·Ð¤±ŸBD“ò–æ—èêßÖÃÉfýÖþ|¿‡ÓÎÂ*_{àþ\Ѝ\CñUY^IÓŸPðf–×Êh6þpøÔÀÅååQï…5‡X¨ŠFoÿ+ËËBA"‘è:B!Ò~¼mÓf¥œcÍ¢oh„î®N ù¯[Ú€@Uç˵íš{βZ ­[æ–mÕ2˲0M£öx?½Æ~¥\F×›C.Öã½ ¤”´µµ1??Ïêê*JCÜÆ‘2oÖ$wËܲW©Ì‰rX¦EµRy}Ç£Ó’Ln®±ÿ²î× ¯×ËŽ;^v5\\^"b}ÐzsºˆM˶ðpòud;ǹ¹¸|sR»yÖà®(vqqÙÖ¸=±Œe™X–ýÍäâ²ÍPUõ¹B,EAUŸ#ØÕåÛEA&“azj Ó4_vu\\^8áHÝ£?6æk#¤„ÖÖÖM‘]#öI-/ÓÕÓC"Ñ⽺¼^Ajy‰h4ŠÏï¦]WWVÈå²Cn¢-A,#r5Á\^?r™4¹á*Ç¡iZÓÊ  >Ü΢6*¥ ¢6ðÐÁò2î’š'âj컼ÎHd=dÿ©CÙûϪ'æì,(”R̬åY[Yàòõ;ä³i._ºÊZ¦äl#`u%CÕ°(gW(Vªë„&,Ët"uM«¶ÝÂÚæ‹¸¿ hìK‰Q­¸†Íåµ ¾äèÙÿ=ÇÚIØÀìÂMÎÝS‰ßûšk…_é7þÎýüý¿ñ#<ÕE¾»À•û3 F0«Õ—]5—ïœtÂ2™4år©!–˜^[£R©¬ßÖ–¨êshìûü~Þ|ë(ž6…î¹d"aü¢—@4ÎÇÃìÔ–p÷Ú~ùñv Ä)MÍa›0ØÅ=ÝÎz'¥–wRÑtz†vpþÆÝ'}¤Wèì{×zoHópÒëòÖ[oSœÿÓצý.¯9hì//-Q,äeue…¥ÅŚƾgݮϜ<·¾lI/b!büÞ,A¿‡Ü•›ôõïàä©÷ñ¨*÷®þ5ʾ¿oˆ¹Ÿ}F|ßk†¬(=Êzé o+rí2±–£=}ä™g*¶3B€÷ßÿ]…–PÕµŠ"ˆF£$ ,K2¼û(]½ØÕ4áhœSý­DƒàáèþÝÜŸ™¡·-ÎÑÓGAzi;ØÉÎÞv¼ªàÈ©#ë¾z®ÓÒâjìo |>ƒCCëÊšeÅÝ2·ìu){V\ý-Ħ³0n™[ö–}¸û...Û·'ö‚±,ë•[jõ$ ôíÞö§mŸËËÁ5b/!Ùl–¹ÙÙšsàYªPÄìîî&o:\ÎårÌÍÍÖ¯ÆË®õ3µOA×ÚçòòpØ dyi‰îžÚÚ;žjûú%¹Å{/ ós¬®®‡7n‡µ¶÷ÒÖÖþ²«ûÌÌÏϱ¶ººiû\^.®{H)ñ‚XšÍXF™¥ñsE¡mÇquk~UB|þruõÉm÷ž¢í[ !~ŸŸ´\{ÙUqÙ„­ùd¼¢åA Ì“äñ‹­Oþ€P$Nè·~›P¼{ýÒ‹z@à–0ò‰’BÍj[£ÎÏØÂ-Þ~qØ ¤YOìqÛä×fY½ÿ)Ñ€†iÅã >²\É®T¨ [’ S]ÂIJ,Ei¨æ6ÿm†aYûÛâÖÍKܸ5á,Œ¯±´”âïý½¿K2ÙBµZ]gpUUA×½8EQ(æÖ¸pá<»0Ô–`zzš+W®pèÐ!.\¸ÀO~ò“ÆR¯Õ… nÏfèikãgÿ÷ÿMçŽ^<~?döÎMZú÷Ð×Ô¾Ú׿²EqØ Ä´,„PØtA«TH/~ŽQúK´`‹ÝtŒ¾YÛ¶ÙˆÁôô”;‰†BH,þìÏ~A_ÿápùùyJ¥RcûúßRJvïÞÍ®]»XMO3— °¯'Ê™OŽÒÒÉÂôÆ—ªüøpŒ±ËŸp/UæÇþ¿G¡\¬âÑ}t¶Ä8wá,í~ˆ.¤“TƶQŸà³3-«‘$Å1 {öe÷ž#õV!(óÿù£ÿJ¾hÑ*àîݻܼq£±Œ%·–ç×ÿæoODkÃiI¥TbòÞMnÜ kp/=ñRJJ¥‹‹‹”Ëejçi9{á*;öžB%±6~üã;=3!0Q.\üš¶>xÐ>ËFÕÜ‹­ŠkÄ^ õ…¯cSÎ] ·|ÅóоL<’Gˆà[wŒÕ¹q&—*üÊû ù°Ê«\ºÖ…ˆ:9 š†’RšÎߊùäSþÖßýû>°»® * ÅçävPͯr÷Ö,V1Ooo+©‰Iæ¸xñ"á‘!:úúI_˜$•ÊÓÝö }ÛÐ÷ÚైªF•jµòÐC!©ä>Ê_ÒÚjP©xIgA;eû1­Êƒc°,8zì(^MR©”™¸y ] kTÊ<@0p†cÅ%ŒªZjµ‚mƒ¢Vn¯Ñ3ÔKKËý‰V„4™[68¼[R5ªHiQªT0Œ*–m7†ƒBèÈ¢I5¿Š‘БRbš¶m=¡ícö;CZl“óçΓh ⵩T,g¨›É³v{œÂ ÊÞ}{ñëP©”©U|Á(C;÷plœO£Z)cÛŽ¯æž†a`Y&†i0~ý+ÆÖ|K]šFEx<ª¦`U„GG §}ñZû,s[é¾.¸Fì"ešX–Õ4œ”TóŸ"KF0 £i*^_o`œ|ŇižÖ;¿ƒ‰6ü¶M!›afâWnsâÍ÷PmCJöîÝ @¹˜ãâ—_Ht’ˆù0 '™ñÊÜ÷ÓïÅÚˆ…}ÈšDJÄo’*Wh3Mö ðÅù+D£Q‚ºB©d‡ÐÔ †jc+:–éÏ~ŠH|!¦õPÛkɃӫ)nݼIÎÔy÷{{± Ã<[6ãó³dã{xw×îF¢ tt ÒUïmÚfíºÚ¶Q©pÿú=;ßÂ4 ªÕ*3ã·˜X°84ÔÂ͵)òÓ´ˆÇ[qêeKŒJS“Xb}ûÜÙÉ­‹kÄ^ ¶eã¤d¯Kô*T g1sÿZAÚAÊÅ º7Ц)¨†]{xÖ?@åJ‰Ë/±ºš&MðæÛߣ-nJ° ™šãúÕØz„¼w Û†j©È¥«÷Øwh?‘€Ët ¤‚®]C\›c¸¯—î¡ý(_áËO>B(‚XKÇŽì#3?KÐ/‰ÅƒÎЭ&¢ˆÇ/õm$ë’>Ø•2×Ξ!e º{91ØWSø|v™¥t‘ƒG÷:†¤éx²vU„„C!TEi %gîÞÁŠôrd¤›µ”“ãôÊ­)9B{DåÚm/s +„>Ú»Ú1Œ*Òv†Ú+ó3’Xb}ûêÒI.[׈½@lÛÆ®MýK) èx¨ÍO¥œÇ4JEÔ e#•2𦬛‘S#;Ù âóêX—!$¾@˜Ã'ß"™ˆ¡°,Ǫº—So¾‰®kë÷‚öÞ$Î3·œ¦;atßa†v[HYó+É*“Ó‹Œî>ˆ_“Xµ¿¢ðض״ÕíæÌ5}§ßBUuŒW½ž¾@‚Ó§O£*ë1=¡÷Þ{ ÐhOÇÀ]ÃB––þûðñû¼¨ª‚‚ƒ»G˜˜œàÈá}>yË´pâ(*LÍ,1ºû>u}ûÅÕJت¸Fì"Û–RØI Å»øg¤²Ÿ XWãäò9L˦¨´a—Jøý^4M[wœD<Ö0 ‘H$G›ÜzÈ¥jÊ£FAJPu;JÕj2µÄlj-ah÷|þ fÍØÔ8¥|ÒpRiñu3³5ÉnÓÚØ§&OL&Ž83’õ€[¡©HœÌÑŽŸ)i´)Ù3ˆ¿¥Œ´mìFË }Ú½Ÿ?Ð0¦5qä×,¡ÍöÂ5b/¥µn?”GÏEÕû0«óT¬U ‚â òö¡yt”ZoàE *~e³¼ Ÿ7à ë%Mmzõý„‚/Š€×»qRðyý´Oº>±-Œ¶n¨×!„ãgqR¾4Ê>¯¼CÀ j]LJ¼°9þ'e£ VÛ¶^ÏcP6iûËBnZ¾þ“G†À.[mnn޼ìz¼C!–——Éår@-5ÞCÛ|“²—P.WH&“OlûÒò2Ù\nKÔûY¨T*$[[_v5\6AK&“î[æ ¥¤µµŸÏ‡QËø"„@J'Wgs¢„íVÖªëƒÁÇ&@­·½Z­:¯B  @'Z@ye[æñxÛ>——‹æóù¾ùQ\ž !œ ê¢éå#ë·kÙ“¶¯o;±ÌÃüÓ¦tßêeÏÓö—]ço³m./wvòó ß‹¡¡Äà>œ.¯(®{ضÍêê årå›ì)Q…X,F xÙÍwqùNpØ BÁââ•r…X<ñ‚N FµÊìÌ ;vàñx¾ù1]\¶®{ Eúw Ç_Ø9mÛæFá†a ëºëóqyåpØ Äñ…ɪ3__£éúÄ\^UžhÄÖ&o^¯'¥¬Çû<#uw³ºsÐÚçJ=¸Û®©xŠuû:çw´±Ž]Úª½Æ–f#VSvP4EäK&>]CU$FÕX·¦PÕ4<šF¹jàÑ4žVXa̲‹Ë+ÆcXµZåæ­[N€"`KIWG½}= sW?£˜ ¯¥ xCäñx;'„ X,²²²BKK’T*E__¯£U*r÷æzvŽâ×5æf¿fÁÛÇ‘–v†¦²«ËXž !äþØ8Ó&k£¯3ÁÊê*ÑD+^më©EydYËâÌ$‹Ë%ºzÛ™œ¹Ï©9zZ{Å\›à?ÿô3Zª¹ENð«„=0¾bðÆÉ£<⩌ÓvÍ0äâò4<Öˆ !ðh¨IÏŒßfiÍ  i›œ¿:ÎJeœD<ÊÔÔ‰–ZZZxçí· ›>8B–––øôÓOùÞ÷¾Ç/ùKþñ?þ`Ù6Šb¡è ã÷î’JÍ36v†Eo«]}8ý&IQáÌ×—8xò-®žý˜U §«Ó²‘(,OÝej!ÃñC»°Ló…‡4<Ë2×e<*dÒüÉŸ|L¢=Ìõ™ Wï\c(nsqj•T6Æßû•az&LŽvø)N}‰E™É”ͽûð©4TÎæSïÕÖÛ-„X—ŒÃÅåUâ±ÝÇÃþýû8zô({w ¡jÙ‡”°4uµ¥‡ßú{ŸŸüÚ üœ:ù¼ÿ>>ŸJ¥òÈ¿jµºNÑ´~úzïĶlVW×XÉdPüA"á8--qÉ$-‘0J.ÍìÝË(ñNºZBE z¼ôôï`tG7‡áÑQ¦§î’.Zœûâk+é-cÄj[ί¡ =qƒ™Éiй%­]ôõöÒÕÙ‰îQ™›gìîu®Ý¼Æõ{ÓDã]Ù3ÀÍËW(+ŽZªiòþÃàÿø˜å_ý«ÅÝ»w×'ªÝ*×ÀÅå[æ‰>1Gî·À_ý×ÿ‹Àà!zÛbHi³–·9°ÿa¿³˜FU5|Ñ$š¦R(ùå/I±Xj<;RB àç½÷Þ# !íB}^…Å…[ÜÏF9´os+9,Qe1íaxg;(š¦2{o‰ÑƒØ¶Í¾7ÞáöÍ›|þÑ_ißÁу»ñÇ’TK^ò«k  ¶ÌPJe=­)WX)–ñ‹+óèžÏæÜÛKܗƲ¼xE<þ0fÆormµÄèþCøüžF>ÉÎÎNþí¿ý·,//sæÌ|>ÉdKM Ú®ýÛ×ÀÅåÛæ‰ÃÉÜÚç¾>Å)¤YÍI„ü ïÚYsªÃýÛwñEÚhm bÛ6>ŸŸ?üð‘Gªª…Ô4d/ Q„‚´*ŒÝ£ûÀiÊåù‚ÂÐÀV3’ãG¹v}‚d['U 4áø‚T=À#'Ø]ÎòŸþŸÓßÕEoW EJ°-’ím[êáB`T+N² À®TékS5ÚhI$Ñ”9þä²Íjî¿õGi ûس³•=ñݤX!>´“ÑQ/+ó,¯‰‡œEÉ?øÁ÷©T*üîïþ.äüÿ_„B!*•2¦iá&NtyUÙÔˆ Sw¸zýƒ»ö³k¸—‰›—ùâ“ÏyïûïôéTÊ®_¹Êøô o¿û}tá¨c Á:%ÒõǬÌMrõö §xÊYVVR|ùÅçˆx?½‰0_~t†Ö‘Cܽz²'ÉüÔ$W/|M¼«‡žÞ÷Ó%zú³SS,­® `¢è^¿—jq Å_ÅsöÓ³ ï&ÑšØÆÌQG}0»›Íšä§:½P-ܧÒÒÎ{oí¢°z‘|¥Ìü\f5‚ ›9ÃF“påÜÞ݃žuòÒ?üá‡ìÙ³›xøànkks²ìÔf[ÛÚAÚ”«ýC£ôw%‘¶$ÞÚFÄçÁàñhXF™¢!8xø(­±§¶ !(¦s´ï¦¿³Õé™)íÝìÛ5L%Ÿc%SDË\¹9‡ß#ŠN[k+VUah´Ÿ»×nÓÞÓK@NRXEcïÞ=´µ„»uC ±{´G# o‰Ä§BRË˃A'èÔ¶±T % Ñðw! AºRåí·öQ¨äÉeJ${‡ˆ4òé5f3D;û9²7U4fë×=‹¡ëzCį“N¯‰DÑuýe_—çFÁòÒB*U˶I¥Rˆßþíß–ûöíÃëÕ ü!ؽo?²–q¦®=Þ| qGE5ŸË³U¦²’¨:µã;¿ EAUË0P<*³Óàk¡§­ž Ú‰µ²Œ ã${vñéŽ~ûèÕÛ|÷ÎÉ$‘š&¼SŽ“iGQ°m [Öbó¤¬åPlÊš-}ü'©¨>ÌøØ}zzz]M,—m‚ë×®¢A&W jܺuëñ>±'K•<_…‡ƒ/›õÙë‚yõ¡í¥“BBwïŽuòƾšÎŽáµš±å¢Ô…Ò¤G_שª·±64Tš~wŒóƒ6À6­§?aýØ®¼²Ë+̶\v$¥Ü–E8½-^pðis4—WmiĶ+Á`å¥eò¹|ÍÏî ×K¿õ2'9‡ªªîâo—W׈½ ¤”´¶µáõù0M³á|oÖ®ÿ.Ê!G"® Ë+‹kÄ^ Bb±Ø _A`o‘4i..ß®{Á¸‹±]\¾]\#ö‚ÙJ Ò·®ñw٠׈½@lÛ&½¶F¹\~ÙUùvxc\i|†ùeø|>¢±X#¦ÐÅ¥ŽkÄ^B–YK§ñûü/»:ß !P)—©TÊtvu?}ïH€@°0?GK²ŸÏÏÓ¯çKE,Ë¢µmk­‡uyù¸FìR(!oÛQA.—eanŽîžžgnGµZqV„BÏ´_6›afjêe7ße ⱈPª¦mû!‘ª¨ØÒÆ2Íg3bâÁŠ…‡W[< )Á–nЮˣ<… ?†JY+Ž -%B(ê ŽA'ú²·$¥ÛF4©Ö×e:ë/•u‹™hèoÏÞʦW²IÕuÛ#ŸÏÙ^_BVÿ½™u¹šhΡàâò0OÔ[K-°˜–ŒöE¸;>AÏàn‚…ÙÉYR+SÜÍÍÓ¡ÅÆ‰‘]…žn•lq™å±"ÉvAN S™Ksðô@ j*¹ô – ’]c)•Bõèttõˆ†(æÖ(ZÉXøÕyèÁ‘ˆÞfí)2LLNc¡Ñ;°ƒHÀ Àà OÃf®üzÎ…k×®±ÿ~|>ß#Û8ïA·'æò(›Žk„•<ç¾>‡'àÃë’Y^àê­ûMåΕI®]¸Äù«ç¹|ñ>¾ÈWçgX[«R*K&®]ãýçüô—˜¾~†/o\ä¿ýñäÏ^¢ËðÕÙ ”M8ûéW¤–V0Êy>ûè̮氫EΟýŠLÑÉ”ýª2˲Ûi(i–øôÓ™MåÈ.Oóñ§ŸSi²#2ñпõÛ4¶}¨§( ©TŠñ/þkkk|ëz瀶$•\¶öÄ`T‹|þ‹_°œ6 ÏŒ“]œÂBáúg¿$ràÔæ×Óè3K$ºZéoïcb²ø`Ö]Q˜™œ¢Ç§1YppçÚZ+”º[Y¿‚i§;â¬TÙ½{7½=xµ/8ûõ~ëWÓ¾Á•ûsìëŠq÷æ=N¾}bÛ¿‰%Ûkázfi™j:Ë>üu|²Èýç_’ZÎ ‰Æ"öúð?ŸÏQ,xÐß’‚¡ÇÊÿÔ{`gÏžebb‚T*Å_ÿõ_Ó××ÇÉ“'ñù|M9X—¶ÏťΦÃɪaèÛEgw†?={…}#{ˆZ‚}‘~Õ P‘¶ ¤v•JµDý®Vª¤Vòì?ºŸöŽ$aŸE1PæÚ\w‡ãܼû£Ç6Û¶±,›P¬—êµ+H±®nŸ›áäh}ƒ}¯DoLÙf>±BU",Ÿ@·T‹@°!…T7b«++ÌÍάógv÷ôâ÷û›´ÓDC¨Ñ¶m„€L&Ãïÿþï355Åüü<¿ÿû¿ÏÀÀ»wïÆëÕ¹DmëÙ'\^64bð"ÜŸ ¸2ÃÔ oï ”å–­½;˜œ¸ÉÔr…No•Ô4ÕD'B8C%WGe¼í1f >8ù=&¾ú˜BÅ"Ö§b‚Þ(©( Š¢[ÀÛÒH„ð Ì >¿öÎW#6h+'ö݈€G€V¥"Á+K* °m Ã0íI¶¶‘lm{äÕjuÝߦiaU'Ï€”ÄbQ~ï÷þWÆÇÇù§ÿôŸò{¿÷¿ÒÛÛ‹¢( `!ÕjË~v-5—WŸÇ:hŒr¯Ï]$’ÆkWX­˜Lk-ÎPBµˆ æ'¿ökîm rìP'UÓB×=ì`mq Ÿ?ˆG3ÈÛ6^M°º–¥«;ÈX¦ä<Ԙܾs‡KçÏrg|‘ãG‡Ê™ ‚=ݬ.¯rî‹sÛ>,¡Á6ZrmoE‹„ùò˯9ûå—Dã:ÉÖð:éë'9÷7ò‰ÙMavMA8pôèQü~CcÝ?7¼Âe6O¢îݺ‰éKrjO×/ʵûkì?õ.Hðj²3—ø(7F9›åðN/…©+Ì‚P"” …ão¼KKHcf|œCïüŸenašÞ݇?sôÈN¼uœ…åRÕyë{ïÓ Q.dŸÊpðÔ~|žþgªÜŠ8)Ö¶šŸwÞ~—ûc“˜¢wáUÀhú*ží{qÂjꆩyßÖÖVþå¿ü—¨ªº. Ô%Ñ7O>ãòz³é]!mÉàÎ}Œx4T;÷žfx—ÄëõbÙ6­É!þñßíkˆïy4 «¥BASU¢§Þ@óh(F¬]µY¹$­¶"àÀÞélÞÞ>ºûúSè¥\†¡½èLDP„¤³·ó™uå·"Ûm8 à ÅØ{ öH¹|Ž81'ÂDbËGXýúl'fÙö+q¸|û<öÕæÑ% i:Í/B!Ïúì9ZÓßšVKvQ3r뜻@ïÀ ¶½qìO$ÙEDQj3`l»ØªÍŠòª4xö81¨?[®Ë3ðÄ}j µ®cße#^Zÿ¼žŸrC¶aPèÓ jËn¶=âAØ³Ê Õ{cÏ’gÀ‘Û–®_ÌeC\'à Äï÷3;;C¡_ŠP–N϶5ËÅb|.‡G÷Ô’ôŠZ6x@`Z— ¹lUÕ( ˜¦é„Å P`ZÖ#e–mc‘Hôe….[׈½ ¤”´¶¶’Éd¨V«Ø–夦«ÿÃqüo‡2Etuwƒ '¼c°œäÇ•‚A”šqRUÕ1Xµí ÖXS™eYD#Q"Ñȶó)º|÷¸Fì¢( ‰DÂUv}\eW—ÍpØ Æ}]\¾]\#ö‚q{a[™ubS<½ò¬ƒûrz9¸FìbÛ6™L†JåÑØÕàóû1MÓ4x–<>Ÿ—hôŧãsqØ CÁòÒ«««x½¾†0 ËÖ"—Ë kÓŸ~¿•Ô*†aÒææxá¸Fì’Ïç!‹¿ìª¸lÂÔÔ$mmíƒÁgÚoyy™Å…ù—]ý×’§3bÏîpÙ!šæiˆþ¹l=TE­Ia?}`­e.){Ux¢“¶Q1ÐýŽ,q}ýŸ”ÒQ*­/ ÁQìB ëº£›cÿ6[Wר_ø)·åçA(ÛKOìuÄ–vcùÌKª^…ÕÛ'1ÉÄݤJ>Žîïãâå+ÄZ{èbñÊÇœ½=CJë¥Ï[ajü¾–Vü…íçÞlšÖ·éáÌWçØsìMÎü%Áx„h,ÀÏ®ŽñÃ÷ßfîþ ¦‚ÝÙ7„´ä³Lmi¶Æþkˆ3@xtq»òP/úá^šmÛ®›à%±éU*U˜œœÃöcT*ókLNÍSZ]`fjœªaðå—g¸sûõéר^>ý+nKš×C¬´LÏÈ•T•»+Ë :ÅèÈ01sŽ™{W0ƒmô´†±,Áèè(îǪ”+#££LŽß"S²¹pæéÕô+1u]Oxá²u±åúycÃ0øÿñ?òWõW!X\\äßü›Ãýû÷× u:ß­ûí¾ 6NªŠ$ 13çãä[ïá•UVñÇ„£qþ§ÿéÿM<¯:Ln¹Žý—¦‰B¼Þ =],ÍÍ¡é^° L©R̬@ñìceñ»â¤ÏÇ­[·YèhZ‘–c†©Þd´·“´\¢\*Q­”1 ‹®®Ù½ÂQ+Ðu¾žnÞûKk{hõW~=åÜç$Þ5 €;âØÒ4ëú7 yþÆoüûöí#™L’L&kD4>U^´Û‘ÇôÄêBt¥b…@(L$¢³»‡ ÏËìDŠÖönZcy¦Šq öâmïaqliKNœ:…ÙÞή¶N.^ÿ û:½XÞ=»;sìðŽ¿qŒXK ÅççøÑc„t˜›$o¥%æÃèîpò¾wˆ£±ï:ö·6bÃB8¾[)å:Vÿ̲,T7ÀKaó«.%ÝË‘£ÇÑTUÓÐuOcæ&Ù3L‡OGJƒXEÐ[© ý-m(ºUõñö΃!øðí¿…¦j$vM0oÿîk™½}ÝNlŽ-éèíAe,¡qäÈNTlºû»Y£·;îprë#„ïµQ€Í†‹ØIw8ùRxì«CQBÁ@ãïæ/ÉòÕ ‹—ˆ¤ôâG‚æy°MO€#è”Ð78ü@k½ùøª‡Á»ˆWJ_^5ýW“æáä³äpå³_Ïßÿ]—¶ë¡‚§Üã°‰Ww¢ºþ–wÙº4zËÏšÀÍÆôÒpñ/¿ÏÏüüår¹ñ ØÈš\³pË^v’b±„efÉf³Ž!ƒ†<·¬-­{¤ (ŠÄâîÂþ—kÄ^RJZÛÚX[[#—Ë>Ю¯ÍlÕãܲ—[‹F©T+Î$ŒPÂIT‚”Žî?• ÂáÑXÌõy¾\#öQ…d2ùJ¬>xU©´çÙÏ5`/׈½`Ü›}ëã~?Û ×ˆ½`Ü^Øóã—pØ DJI&¦R©¼ìªl/x½>"‘ˆûpy׈½ ê +©^¯wÛÆî •JÓ4èèìæYCkæ‰Æâø|¾gÚ/›ÍbÉÖV·Gæ²׈½@ò¹C##Äã‰mû !È岬,/34<üÌûK)éìì" =Ó~ÙL†™é©—Ý|—-ˆkÄ6á»X"$„ÀãÑ·½xž¦jHäsMRÔõëŸUÃ^âh}¹¸<ÌK3bõ¸œf¾-)“ºÚÌÕì*ŠŠ²±ºD¢(T«Åb…X,ä,'©Õ«ž ±½¢<ˆÀ¯?>æA{¥4öå³Ï´ !jÁ¢Î>ï«(ʦ÷€”¶»ÚÁeCkÄ<À!‹\˜šd°}”x@{¢ƒUQ>úècöìÙMëC~ !KËË,/-S?Œ¦yèG×uŒü*cSwè9ŽOyPEQžx^!KKKD£Q2™,‘H¯·–äDQ02Óã÷™šž%œìf×Î^g½çJ*E*•b~öã+oܪéô÷õâñhsiLÅG$èÃ6«,M/ïèD×5J…,[#lú`oýj¥Êäø8Rø£ ºÚ’¨ÎÚR‹ó¬dò„cI:Û[0Jyff籄FWwAŸçŸ#*• ÷îÝcdd]×ù\Êoï%çòj±©BpûömnÞº…¢(˜å4_¿ÃáÝGxãðvíÚýØ›JÁøÄ8ýýt¨*–e­{¸Ë¥kkkE€Uáêõ1~óoÿm>Òk«üõŸJ×ÈF¥D6›#™L²k÷nvïÚõÄóþìgÅ÷¾÷.Ÿ|ò o½õýýýئÁÜä]Ο½ÀJY2:ºƒ‰›¹qí2ÇN¿Ãè@7ç¯.!Í‚z€]:kkiÊ“ctÆ#È€—3gÏ1zð$ÑŸÌêòÿýßyûïÿCvõw`3œ½|Óo¾IØçÙÐݽU4ö——øÅOΉïÆÖº.ÏÞãgnÐßÛÁÍ«—Ùwò-fo_¢,‚ød‰{S¼ÿýwRMõïTQ”Gd†666–î4e¶RU•¥¥%þù?ÿçüÑý===Ü/¶ý0Üå»as=1)¤··Û¬pþó¿$Þ?È÷¾ÿ>=qŸ£Òº1iî-U*U.^ºŠaÚ´µµPjÇîïïg``EU˜¸y‰¼é%–ˆ`›Uîß¿ÇÉÿmöíèäþ½k|ùÕ-~øÃ¢ÖŒá“Îë<`š„J¥J±Pfhdmå"翞b`°áÎf¥ŠeK„/ÉÁÑ!:’^§Ã$KV’ÙûW0ü­ô´FÉÌý»ô:ÂøÝ1Fú:ˆ¶ö’ôÝàêø<{:¢ŒÝçÈéÃëo}iK>?Éd’h¼­V©ñ صÿ8wq7ê㣿øŠîX‰wóW È<ô_>by¹@4°þxB&&&˜ššZ—~o``€ÞÞÞõ=Ӧᤂr¹Ìµk×gii‰/¿ü’þþ~öíÛ‡®{iÌ~ 7ÆÎec;œÔui”8wñzK7ûÛLüþ^Ýõë7¸qã†Ó“ª!mÉž={Ø»wM%ôZœãÞí›ø" >D"èŶmEaæîu>ùò ?øõ¿Wä3y𵳸¿WC­¬n& %\¿~7n>rÞ½{÷°gÏUœ;¾iØc9 Õôš½@Z^%˜²Âîq|ºJ65ÉÏÆ¦ˆEœáŒŒ©I~¸ó swf=r  ZXe|µÈñcG9{æ Ëé‰ -=#|uq–#;Úiëh}$ú`«hì‡"aZ{:˜ŸçËó7øÑ‡ß'𰜣gèí t_:ƒNPB覂¬ä!¬õ¤êëU~þóŸó‡ø‡h5a@˲ø'ÿäŸðþÑ?¶&)EcBÀ¶m„¬­­ñ;¿ó;LOO1==Í¿þ×ÿš~÷w·æ†°‘R<ód€ËëÃc‡“k‹sœ»p™ÖÜ™äO.]¨ #l†††èëë}d?Go¤¯RT•áÑÝì XÈ“ZIaÉZÂ\i1y÷&—¯ÞB÷zH-¯Ð âE8~ü š¦bTòܼ=Ï®Sûk7¾¬·ï‘ó꺎”`•³H(ŠÊêÂ<ÅÔ"o¼ù.s^“tQãÀv(¬”«tõôaÛ6¡DÇŒÐÖò '–:ó1ŠUŸâLF,Í31>A0d~fš›ãstµŒ"¢Z$ôÓ3ÐóˆÁÚ*¢ˆ±DŒýäW‹ÛôgdVÓD­Ä6éªI`TÓx#qP ª€.+*àñ`Y&•J)‰¡¿ý·ÿ¿ñ¿þнà¡T*6¶0M£Z¥êq~£Ñÿþßÿãããü³öÏø÷ÿþ÷èííE×u*•rcßjµê1— ylO̶Žž"¢ îݺE.W@Sén]÷8J¯OÀ¶ml)Ñ}~º{ãcTK\ºpŽÕ¼Íéïÿ€Ræã¾@U»{@Ú,/NsåÂ%]»ØÝß]–麾¡ãש¯Áµ W':I&ƒ˜¦ÉøØ ÃbdïQ ˓ܟæèo±83E[[;ÆänÍplÿ0ÕRŽ™™å‚×16BM­‘”ÐÙée2W¡“û÷çùÞ}ìèâÜÕû”RÍMáïìbme±;ã>uøQ©-0"ª”ÓLͦ0ŠY„O¡R5¹ôÕ%íáÓk7Q¬ ÷n^áôGY»Æ×ç®’YBQ•D2‚UÎ5-ëFYUÕF/¬N=K|£éB4ökÞ×ëõ‰DØ»w/á°3cÛvcßz6¡WA¢ÜåÛç±>±–®N„dæfYKWÙ×9J̯>Uo¶mÞ8}š–––Æö²Ö 3-“hkŽöàõ¨@·Þ:Åjºäh5aS(æéÚÇð`åéâÂ-Ã@ó'xï{£èØ8pˆB±Äžƒ{èlpo,ÅÁ£ÇX¿Ä|ÖÄåÀá£L/.bJûlò¹5„ýÀ8Š©jtï>À_ß!;ØEÿþ#´µ´áõªtöôqØ RÌ2>¹Âã»Ðu–¶ä#•Þ*û…J>K¡lðÞ»§‰‡ü¤„Aç@',…Õ5vì=ÉèP?#1nߣ*‚¼óæaüä僙ëg ±hŽ«ïkÛ6­­­üöoÿ6º®o¨aä#éâ ~û·[îÛ·¯W'ð#„`÷¾ýëbrêñSÍ1SOuðM‡OE¡Ñ»ªo b‡„¢8²ÖÏ8„PDÝïR?®5? B ¤¤R.a¢à÷ykÙÎ ¶ š¦Òì?¶M³&‚ã÷ïà‰tÒ×sô¤êçTÒ‹SÌg-F‡P„sLùPûîß»ÇÀàÑhôÅ}Ãßù\މñ1ºvÚ?!Ó“´´¶Ÿz¸-„ ŸÏ“^]eÇàà–’»¼x„\¿vE2¹UÃàÖ­[Oìúð°àiÙüf“Ÿ…ùyÊår#Ôã[½LA¡'ŸË³ººŠeš.h,éڸ̪ªF¹\Â2­'î‹HÛ¦Z­ ‡_öWè²qØ ÂÑØogmu•|.礰kÒzÐxПµ xäxße@K2ÙÔ:Ç („xK±a$[ÛjR<õ¾6‰D‰Å] {—GqØ DUZÛÚ¶B”ŶÕõv٠׈½`žwÂÂÅÅec^~Ð’‹‹‹Ë7À5b...Û׈¹¸¸lk\#æââ²­q˜‹‹Ë¶Æ5b...Û׈¹¸¸lk\#æââ²­q˜‹‹Ë¶Æ5b...Ûš ˜»¶ÏÅÅe»ðÈÚÉúº>7=–‹‹ËÖðoFkþLóx¨V*¤RË¨Š›¨ÔÅÅeëPÏ9«û¼ëÊFÌÉ`¤Ç©V*®Š¦‹‹Ë–BQÚÛ;(‹ë”`š†“Nzù`0D0rµ›\\\¶Br¹Åbq]ù>±g×Nwqqqy!l`—×ïââ²Q\ß—‹‹ËvF›ššâÀ›nð:+ÝÞ©‹ËöA ‡Ã 3§ËKK¬­­!_CExÝ£ÓÕÝ×ëýæsqqùNÑZZZhν,€r¹ÌêÚ##£x<ž×ÊŒ `aaå¥%zûú^Ëž¨‹ËvBÛè!µL¯×K$}íb!±xŒÙ™üË®Š‹‹ËS°qʶšO¨9Ô¢9‰ª”²‘ÈUJ‰-¥Í®¤ú6Áæc<µó6ŸçÙvŠóK'µš‹‹ËÖgC#Öl j%T YR«Ø¨Ä-TsKdÊoí %ì«<¨T*äóyZZZ¶í2ç ë޹ÎÀ òˆ3]bÛÛàöõ‹,eN?„îyüò¨æóÔ¯ØzÛÄÞ?AÍ0»¸¸le¤m?&yn“QB°0;É'_žÃ:‡vï„é¯óïe/c¯Ÿ+_ÄTVÍf™žžfß¾}T¥Æàþ“j¡RÌs÷îî\»ŽŒ±ct7»Fv k*åìóË«XÐ0tš/Bwg+”²”—f îÀ.eÉ.ß'=ï§¼soróÔö›ñ;7Q£=ôµE¿uÛã3H ÖÚÇ‘½ƒÜ¿‡¶¾’ÿú ׈¹¸li¤„rÅØXŠGÚvcí¤c $Ū%AH‹¥Åe”–¼ýÖÌONqþÓ‹D=kTª%ŒJ™`ÀÏêÚø#¤J£RäìWgÈ”¡’÷1ÜÛO~yšK×oa•\–éÉq&Æ'˜˜˜`rr‚?ÿr’Õœ‰UÎSZ˜À¬VXÉH<(=Ýø£aàÁP·ùV§¹tkŽx4ÄÜýË|vé.{ãô©“ tµ!T>ª\8wC>è¥Y–ª¹ÉÑ]\¶6’µ¢ùxŸXcS)énK0<¸SÑI¯äXÂÀ¾w-sÀwéí?F8S$¿²ÄĠ?ùuÂ^/º×Ojê<þÖ^Žíéc*•'Ú;ÂÞø0yö>+Ù*­Ýý¼Û3ÐtzAéË%¬Úpt~n†ë¿ø9¥J]÷’ìÙɮݻœžÖø¦i®«¯¦iôöö2sý"í;ö 蜿pƒC‡OÑ×Ù†mÛDcζ}Ãܹõ)Ë«Eº~GèC¼žñq..Û ¢z6ñ‰á<ĆQuþ •J™l&ƒ¡x {ýŒ_¿L:&“M“L†I­æ¸}{Ã!R3Ó|òÑG$"]¼qúÆØ2#ûºH/-ã·æ„T,À®†©ÊþõFCÓ¬b™¦4@ÓÝEÐï#¢{4¤´)•JŒÝ§\.ó@cHâóùimkez¦Àþ Ã4(”MzT0Œj­—)‰¢± PN¯`F;j=1Ëu컸l$r󞘴m à ŒÕÙûŒÍMƒ{Þbd¨‹™¥ {ì#òrûò/›µèmßMKg''OŸ"¨zP„…÷0™NSY™ÃV{‹•…Y„2HbT«ëëB€i†©˜’Q‰8*6Ò6©Tœž—¦i¼ùæ››4tÅ oT1 ƒžIÎ^»CK[+º*¨V 4ަZ˜X˜¶cà¤Ë2])"—m€´71bNØ„ý ÄBr+³xÛ;Hª&ó«Œ-f¦—ØÓÚC:µÌl^¥¿3Èç_|Îr®ÀêÊ  jĉôíáúg_ÊUùÞûï33v‹×o2ºï(A`uòg¯Þ¤Ú°’4xvFõGX°4.üÙŸ£ ‰iY êì9x‚ÁÎ(†emØ8EQèéäÖtŠþÞ^ú÷céË3üì/†®)Bí;¶ŸRzÝW!`YN,ËFQÜô..['¼kSïµ]sîKé„´ôï#96‡ªØÙ ³­ƒÃ§Þ$µ¼D&Sa¨ož¡†z¹76ÆÌýû€`Çà;z9ùæ[X(|^ 2ÎÉÓo„°L“@²ƒc'£ë…Ît/AØèìÙsŠÞ¾¶UUA(ø~¬Zý6lž”tîØËä_³°’¡=âÄ›o“ϰl‰îõáQLnß›¤w`7¯À²,„ض…PÜõ“..[)ÙÜ'Ž!CJlÛ&Ö»“ï÷íjìéèŽAGgwío–M¬µ“í]M'‘˜¦‰G÷âlË â¤e!Å£‰êVͱÕã!O<úñ&½0p†“š7ÄáãG¨JGÚÁP¨±etô ‰·`Y¦äZ‹%s‡“..[)íÇÌNÊš‘¨G¸›&ö#Û4õ‚Dí?ÛĶÝN>nßïªÌ¶ ÂhjKóvŠJ<Þ€]JŠz}mwvÒÅe«£Ùå˜"vͱ¯(ʃeF-GzË*•ª+Çãâ²ÅBÐoœ²Íçóᘜ˜@Q”zÇÌég¡ÎwS&Ònü]ßðÁ²¡S&tvw¿ìïÈÅÅå ElÒSúûû ÒÚì$<ôðó]—=è ½è2EQPUÕ xuqÙj<$2Q)WšXmtÓËãñ¼ì*»¸¸¸µŽ†³ p:>¿ÿ8=°Ù™i<ºîöB\\\¶BŒj¯Ï×(SDÓpRJIGgÕj•R…»¸¸¸¼\»äñx˜›_¬•<쪪ª«+ïââ²¥ihâ¸ìݵ5...Û׈¹¸¼d\ÇÍ“yÜ5r•ÿ\¾5¤”¬®®Ig^ËTOD>HD“H8+E¤”Œ/dŸÏbZîR·ðh ƒQúÚ£<ƒ.]#æòí „ T*‘NgqÂs\;¶á¬™»O0Âçó‘Η¹7Ÿçà®tMýæçx)WMnÝŸ!õ ¬_cmÛ®sù±LŸÏG<žx|ˆNýuÚHýºä4ðûmt¯Û²@Õ°P•á®Úw­œ²Ñãm@Ù°¹;¹€aÕÅL ¥kÄ\¾Mji}~†æ¶aP¼ŸÒØf:'‘À?8ˆpEÓ64~Ïæï 퓎[ÏŽµYêÁÇ®üàÑŽèºíšª¨(Û–Øß‘,º‚ªQ&]H µ¢k>¤´Ùæ‘6l)ìiÚ¾a±oPw)%–-7½6®sùÖx4Õߺ1²YVþò/©Ü¼‰†\]£pîÞÝ»iùðC´pøÃc™&fÕÀðOÿ ‹Úy7ÛÞ,åPtBñ8kfkŠÆO>ú㸩!ÜÀ€Ö·q"Ïì¯*Šˆþõ’lisöÎ_pé,-¡>NŒü˜¶Xﺔ‰Íõ{Ôh7›ä¦vmºŸüÖz}õc[–½©{Â5b.ßu£±Ò0HýÅ_P¹pÁé©•JxCQ°ƒA*çϳ´ýÆo Ô&ß䙾r…‘ï˲m:uƒ‰õ&#*2c÷ïàKôÒÙo B ÓFU4Uaíî§„ú ü ²Ù4År…p¢xÀËÒò2 rÿþ}Nœ8ÑP9.eSŒÏ­222‚UXåò•«d eTÍÇžý‡ð“e!g³s°±Ñ“×$M%Å©4ßÅ<¥ ÓË·¹»ø9­-^–Wn3»²‹öXŸÓW‚J.ÍÕ«×XËŠJÿÐ.†º¹zþ CxuÉÛã íÚƒÇÈ16·ÂÈÈv1Í•«×H7í72ÐÍÚÒKyìÛ¸ýÏ-7³aîpÒå[ÄnÊßü&ŠBþþ}ògÏ¢—Ë?ø€òò2¹/¿Äÿæ›[Z¨üüçäÏž%xà¡‘’ìÊ_»Afa™±ÛŒ#ðy}ì>|ŒžX„ »šcvb‘݇)ær”-ˆ†C¨šMS9ûÅG í9ȾÑ!0 œ½6ÆÈÀÕìw¯^§tw%˜DS&ï]gï‹7GX[[ãÚµk$ ®^½ÊÉ“'±¥D± .œ¿ˆ¯mÕ*òó_þ_ûGíìxT•€7Èä™ E¢ô$£ë®EÝŠÆÐ[R5­G®Ù7A¥Ñ *EÎÞù3TOŽL>Wíf¸óPM~¤QàÓO~‰žäè±=T i¾üü#,õCîݼGÀ+˜[Z Ü6@@‡¯¾ª·½ÄÇŸüorˆ£ÇöPɯqæË±ÔL„˜øêB‘ݵÿ™ÛR».º¦°™ËÐ5b.ß*›Ý°…Û·1WVù<úýû$ý×ÉïÜI¸³“ìûoT––0C! wîEÚ6ÁHÇND©fæø´ÓÃÁãoôªx¼>@RÍ白{•/>þ%“+' œcEQùÉ?!âQèÙGkG媂եyÒ 3xF›_DóxÙàá¶> «óä Uvµ·Öä ,TUo¨š”+%¦fYM¯òîý¤§(ç+¼÷k‡ð)õÞ•Dˆ}½-\¼1Cß»1¬ü|ßÁµ «ÊJnX0‰ßâÆÔ3W‰„!“Õøþ¾öǰ¥PV—)d ¼ý£ø--ìÉf¸zñ.V1ÇçŸÅñ÷Äî¡^ŠËÓ¬¬­ðîß'½8I1[äíí¯í—`w6ÃÕ wØû›oÑÛ›àâÍYzßÙ¸ýÏxWáô±rêãd&s˜Ë·ÆƒTÍ¡ª”1²YÌBâG¡ìßOçÈüŸý‹Ÿ|‚VK“WZ\Ä´L°,ÒÙ<¹l«œg1ŸgzrŠœj“H¶ÐÖÖF6µH*—"ÓÑÃÉ»¨.ÞA­èø„…a8Žk/€P(V9wá2CGˆú|?~”u†p"ŠªÁ­±ûì>x˜_Ã0 ŒÊ R‰`š¶maÛS÷Îq~Ü$Q² é0[®¢Ø `R5ùóºoÍì!ý6¦µ³‘€¦ŽÝäwBÔRšHå›<ì[Zœ¹ý§|}ïéOdoï;œ½óǨž"k9IoìZ÷8Y½(ŠB©\EX `ÕfJT-ˆQ\Â4ªä«&A¿Û6XY+¢,B˜-Uö&ûY&ž@7ùw1­ÑGÚÿ¬÷”iiYë¦ Î-–/Û®sùö¨;Æ £ºÞlÛ(ñF¥†Aèý÷ ôö²ø_þ ={ð½õ…Ÿý T•p<†Q­‚m³0?ÏØø8šb0{³B§¶€Hú†CT«U‚m]œìè$ý_?%hU°½~öïÄ2ªÎ¬"Û2XY^äê•«xb]Œö·R©VAEHÌR…˜W°ûÈ)<ºNµRA’ùû÷‰uÀ4 ,Ë"½<ËÝ;)vu÷0—™¦X©‰ø(ØeîLÌ3Ø™À²L, ¼^†QÀ*†a4âú5±,k½§Ã4âùgô„PÈ–ùúîŸáó•˜IÆõ© |¤ÑΑ m¨Zõ|²‚pÄGQ>hƒmV¿}–þ}d*kì9ØÁ寿¤rð>ibIƒR½íVSÛ ãw.’ìß‹Q­bÅGÚÿ|íËÓ²7˜'ØŠî1—oú ›”6R®2ìÜɢ׋(ð‡B,üá²öÉ'$Þ{w7YÛFúýFG2¶ÍÐà ÃCC,×.q`ï(½Ýa,Ën$‰‘Ra 5MZìÚ½)| “;w®r| EUéݱ“Ñ¡~)±m'lBIñé™óh(¾`ÃÇS˜c&ëáý7zÉ­,±¼¸È§_^ gd/Cí~îMÜei%GW,ÎÑC¸xösîý©24ºŸÁ¾kswèÚ‰mÙD̲>c'åƒð8j=3ÛF*òù'ô„$èpzä79s÷ÿÀ`žpHl2Y·F? 5Ü…e[ ™Dà Å9zè—¾þ‚ñ`Ë(£ù“œÚÝ×3÷iíê§£§ÂÅ+—Ù·o˜ŠÏÃÒjŽÎh‚#‡pùÜŒœý<þ$'w÷bkó¶ÿùÚÒ(b“!¸t}b.ß"õ,QÒ–ë»þ–…¯¯ðï³øÈäÿö¿! ¤dþOþ¡ëÉ÷¾‡ÞÝ]Ë‚U7TØ?š$èÃ0×'Z¶,Ú÷!cÜšgý:ºvKö‡ñzœ´ºFHI$6ÀÛ'â Ǻªiø55ÑÉ?ì'è×ñ¶¶òóolj„ƒ£½LÞ¿GòÐ^ºwì$ÞÖM±REQTBá0éÔMÕ0Ð7åÝ头6x«ûümø6øÌã8¿›¤÷@(£é‘)ñEÂι, ÇC__σ4~B0°kÁÕ†i‚*ð‚xÁ¦«>~˜Ï³®NÎuµÎX³ºpíò›ˆJ)i ÷óáÿ'_ÜúoL,_d÷‡Ë,âñhhšöH"ÝD÷?hƒeÛè^X¶]›Lþ{ ®5µÝÄûÐ~BQ9²AûŸ§óêo­â†X¸|›8†|$=^ýÞ % üƒ@öÔ)Š·nc­¬ ´$ðŽÚ1H DUÕF¾ÓfäF!ðõÏx¶ò§ý|Óm„F[K¼Ö[ÜÀ¨†ãøx4/j=§ióðª9b_ûé*µéP­ÚD ~pàPªü |ž Šª Öbë©MçÚè´rƒß…Ro»Ä¶6®ìfí¤Û5ŸØ†VÌ5b.ߢ9sÔ7œª(„ÂaB‡#yµÞ¼‘”›Þ¬[†'õ˜6slÕÊí¦Ìõ*p ›Xûp³ŸXVû@SP@Óü|þuÛÖ{›R>ï9ä:Ýç ·{¨þÌçh.«l6ÔÖ4Å5b.ßRJ4MÅ´LR©šªb×Ö*¢ž„†‡Êp2Ì?q»W¥ LÓ@J‰ÇãA^Ýéyޛϡ©õMkã¯}™iK<ªÀ«k %Šª6b÷<ÂNº|‹èº—ÎÎ.2é4ÕšóZÚ¶ãïJ-œàõ.S…îîî†ß/ä×ÙÝ—`j)‡ *Ó’˜–¢ÔÚ¿×¹L× & útU¥T,4&H Ë5b.ß2‘H„h4úP醚¯m™|hÈÜÙ¤»5äü±ÑÊ×½¬æ¢°¥Ä¶­RR1Ü`W—o)7—LqÙ)%–å^³Ç¡ª¶0ªÕuqûОj}øo——B­G¦ª*…BMÓš&&ÌLh¶mcYË™4_}nKM¹¸¸¼Î8KÇTMÃ4ÍFV×ÖðûX¶fY‹‹‹tww;lÛ€T%]¾}ꪦ¯ßv[ŸZ¸ñ5¹¾ß„ìR$avv!m´D"ÁÌÌ ÛÆ—‘J¥0 ƒŽŽ÷&øŽ(‹äóyZ[[_‹k¼²²B àÇãqQضMµZAUUG¦éHÛyN<úƒ¤†a8g R­’ËåÈd25EG‰ÅbH)iI$PÝëm„ <‰jµJ¡P ?uûžgŸg9v±X$¿0"„“ |׎Nþÿ‘=Ä“Ö%tEXtdate:create2013-01-22T16:15:29+09:00w‡àx%tEXtdate:modify2013-01-21T17:35:17+09:00tXðÌIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/fwindow2.png0000644000175000017500000003077313070106167017076 00000000000000‰PNG  IHDR"pº}þbKGDùC» IDATxÚíw|TE÷ÿßsïö¡„^BïEå± (`E°ì(**(JQ¬<*vQ@°`ý)à×^@}•&Hï%!m“í÷Þùý±›M6”…äû|ïÇW Ù½sfæÌ™3gΙ9W>tPz}~ìÙ‰”M7("ú¿Ø"RRE ª–Q†A]ƒ¢(qhW¼úWÞVHOˆ*U[ü­mÔÕ~Ôdl-.‡—>ß@‡Î½h›ªqvÏæ1H)‹ýÑ#%†”—8] UªxÏî´nÓ®JevîØJ»ôŽun¶nù›Ž»Ö˜Îöm[hß¡séìÙµƒÖmÓãÖ¿ÜÜê×O‰ ­ì¬£4HmX+ã´sÇ6Ú¥w8áõJ)BÄ^¼ä$Þ8°/Í[´ª ,Š"ðë CÃÐ5t]/R2…?H0ÊQD h7 ‚Á@¥5gnný^• œìüÍ}un²³³ðûý€¬á$Í&Ø:Pcë*''›æ-[£i¡¸X{ž‚G\xåvçÑ µ!~ÿ‰Gáˉ®@×u\.@ >ò–•E •¿Ö,ËŠ¬´fÍ ƒUæ%Žj¿òŒ‰<& U\( Èëê¿îÇÃT.RþñhO¼è„ÇÊ€¸ð]Vk+ZE-ÉOxLãÉCâ&'qg²QõvIi”­ˆT‹… ãLJ•Kt‚”ømHÌàAƒ¢m¨JÕØOŠ À…[E\GLka§ÕŠ/ O )±ZBº,ëQ lýŠrh!¬ØT þÛfQheOøp›J´MJN~¨fã$!'{'?­9ÄÈsOC–[a»\Vð†Â¾Å‘ˆæ/(_Y”+’ü+d QÏ+(É©Â:‹×ír¨ø§ËCÇëõTJ«,'R†}K5‘- ª-È[o|Â5ã®FÕô’Ëhø¿*+"*¶ˆf¿ôëÖ­£W¯^e~Ÿ˜”D^N6'¢œ*iDºø !ñÞÒ .ìg¡a›–h`™Œˆ–‘A^œýV[lZ¶lÉÅC‡VÃѦð÷÷óé:褄`0ˆÍf# bµÙŽÍL#²…­©"2dÍ‘2"¨eбX,¼ôòk|´~#c{wåî ÷ƒ0ø`ÕFô®ÞšÇRQîjþŸÕ«ùë·øéH[&Ž<‹3NïϬopÿ­(ÈÏ/­Œdé>ZU?×ßòïÌ]q òÝe*2ÕjgÕrúÀdÙÆ¡Ì`ñ}$›^|‘Sî¸g‚OA¨ þõÃäì·|,½¡ ønÊ)œûÈËῪ¾:àãܦ^zùeTU¶7ÁàŒËo‚$U•¥ë,TDR’˜H¿éòûý­˜óæ»ÅÖÙWŒ¹¥rTr|_yõÕbüR¸úªÑ$%%Çl±lÝFZÇ!Ð5혵èþ ¶ì8Š"Šæíæ—žç¶oðõ»8kP‹ åNUUþýïç±Ú¬‘cÇΡðó7óٲˢEöyÀâÅ‹éÕ«+V¬Àår!„@AïÞ½±Z,Å´<ÕЄ‘ç…‚-¸—MÛÑ5kÍ;¤òŽaÙ˜<ù¡’7š´<¡]Àk¯¿ŽÅRÔņS1lD)²‡ƒŸ˜AÛón¦s„¾ßÀf³Q-–cšóÅWUt)q&ºðx«º9 ;7B1$ÅŽ*‹l"í±Z,„4 »ÓA0¤SZ ‰;\4lޗɳ§Ð/­3¿o÷ÐÑ›J§S†T¸š;lV|Á°[môiÖ€Mv.§[`=ãŸûwއ¹íàꉳø<¥V¿’ÖóÁß¾BM?Ê3Ï<ƒ@°|ù/,Yº„‚|wÌâe#ÄSNçœë$¨Kt]#*¦l„Bο2Ùt(ƒÖùÁ2'Za½YYÙ|üÑ»d® ñz(ìX—˶×^ç¶;î TŒ®j±qäïå¼½ø7¦MºoÈà¡,¢©…:y)×'& ‘¥Æ©$›¾ › ý}Ã1²vsUÇ|óWw®]É嬄EôÀĉÑgýö:™~•ÄD‰÷À2ÞYòUaïÁ´iV£®½‘äÈÔPU…œmÿP/½#RJô€ÕîBaþF‚V—'së£óyfÒÈQX õSÓ4&OžýÖ·ý[>Üæ¤C‰”:C.¾… Un[DRJ.¹ä’J[ÊÕUDF ‹gŸ^Ä)ýz³ø§g8xð.2ˆ2v ÅêäççǪ!M/˜}æþûîCzÙ-¤Û$—Ýù—\þÎétpæÝ>ã•禳lëa,~o‘Ðè^¤LŒ1Ë~sìc„˜ôÖJfÞv.·ßó<ÏÍW­­™–»‚9é´jÕ€?_¾š¦×¾I—¨2Õ¢2ù©ù<ûè­<úÐ4&?9…¶ÍšpÒðKñw_ÿ¶Œ¼d85nRCß•ÃØ¾«L™úO>1o@á¥WŸáªÅŽÃ¦°êÇ/YþŸ ´ìw.w7ù ©™óÖÛ$¤4媛Æqÿ¤G ÀMñ½ùkq%AÓ´h™ë£Ai¨¥whšÁCg¹yyêý<ùèôJó¤PÀt-¹ ýxðÍXtÿy,ª#O: 4MVžŽ¡GÛþÈèvK#òwHr]·fÑ =¸óo„´¾•rQjšV*ºjw*\Ö£?óV¯!áÓj%ÒЂAÖm?Ìá¦É÷øHIIÁj³!t…™kðÉO“ùûfdJ+v…šÓ½ ¹Š•›Óyß®ã heº ½´°;mÜ5d—®$׿3N?³DÁ¼vì¨ÙâÅ‹5j“'O¦qãÆ(Š‚ªªÜqÇ¥öÁU™t…B(ŠÂ=kYòÊDvoÍÂä®ôÚY@ßæö2 –)r8 ¬6[V~΢5îíA"êYÌñgñ¯ÆÍèÏdø„”×\=)Á“—+$«gãÜ'9ýÑÉl±ØxàÕT漬QV/C!-º²yòÜX1ÐB!T)J£i:º®á±FŸ°uíAn0 Xi:†!Ñ5=Ú§P~>VÅB  è‡Æm;b¬ÛÊ)çõfG£:‡#õr©ïý¦Ô†ë,ä»@4DpÙ\ÞÕœÜ}•…ŒàÔ‹Ñ‚A:ŸÜµë™ÈÌ<:óð‚%è麕)%i=N¦±®ÔaÌMãùë‹W8tãlÜ¾Â’Ê ×]…ܹ¹€,-cR"…ÀaLx:Ÿ¾ú‚À1e.\ÔÆˆ®VtÝ@óìgí%o1"³Ôv2¦­Ž‚ýû÷ŠÈATæ¬Vf?9“³nxßfM ãä'ihøË##¢xB¡B4-„Eø~5j„.Áîy/ºfJU‘” TBóä;_3ï×ÿaê”Y<öèHÃ`Þ¼yäæåa·;Ù°x/Ë/6»ƒ¾}z“q^/ºõlò=^:ŸÜ•ן}‚«ï¾?†ÏRJ¬6ß-x𛮉»À[¦¿PJ]׋ñIAxðØôy<òÉçü{âD|j*JÀÕêà¨}ß±ш#0` ˆóÖLDÍË´–}°ïkÃ9'õ p~ú$håÒ*n’†òóxïÿ}¡iÝël¦ÜšŽ^êÁµ…¹sfâ¢dD©ˆ^(Š1Ÿÿøf_5xS Ã0øù»ÿaÇž},xív|¡r¢ADÎVé^^ßÒ¸’&?ÏSßmOU|DRJÚy“+®ŽÞv éU‰FE/Õ`Ö×n¦Î˜ÉÎྩ“ðÚ’±:¤Ô÷àÞ°ŠÙn~Ýå¥ñ€4êWÈwÔüt÷{Ùv*n¿Æ.ÍNJ¢›7 WÂ~|o†ÇGmþ5Ž€”eF £gºfà°©¬]µŒŸýƒv§ ᢶè3’âãTZ.voÝÄo«~ãH^€[Ÿ|ŸÛ[®ÂeD›Vô>û4PyæêK …®=Z¯a1åòsvðþÇ?pÇ#£y¼t4•×§MäšGfàD–s¢¨ü=CšñüW{™>º-çvi.„üñý̰#_TÎê-äá» ÞF¦tä¡'Ò f<:†‡f¼Æô‡oaäȑѾ¿»äsÎ=wPÔ².lד˲ï`×£Œ¸öVD(8ædæ÷•ËÙ±ï0'_0š“;4 ûÀdÙÖâ[³Ÿ¾_ÂŽLxxÚ#|¦>y“˜ÆÔ§&#CAo.ïÍ›Cß!7" ò²åc ÿ¤[—N´MÑгªª2nÜ8Þxã 6oÞÌSO=ŸqãJ9«SRRÈÌ8‚×ëÅf³“››Sé­YƑä6l].;¿†bhèå§î§iZ3D¡E$œ‚Á!M/s»fS ¨W<^¶ŒgUdÝäú±×w`DËíÓi\ÏN À®Ûi—Þ!º5SRâHpá÷TÞY½{×Úwè]c»6 U‹Ô*ù™öïÛCû£‡÷,MÓ±9}~ ?nÛɹÚóý¶Í ïÙCQÉÚ¾[㎥ÆJ7táqG(¼ùúî¹÷F¼ž°å!ƒ{X—Ó”îŽØjéÇ)M¬¸w­AMë…Ôc£Ÿ9ÙY¤·ïHvvV¸BgÁ»ŸpÒigqR÷¶x|åÊÌš5kéׯoÌgþÜ@þ§`Ñü„ôŠ£‡î§IZ³"‹°9]¨ø|~* Ü$$$D#ŠBQQ1Њù¡„PAêe:š à -­)G¢Ÿ½ókcOIaÁ‚…Ñp½ðpãmwsk¶g÷NÚ¥wˆ¶ÇårâõÆòÍ®ŒXÛêÃ…?2úÚÁ¥¶t2”IV … øƒ±çžm;HiNã$þ@Å:@zûNx<•P06ÈbU ©>c×^RÛwD„<Çö½öÚkŒ3æ¸9« Ëø<þHÜ+j·”ïø‹š3:O…‘…@%"ágyfLÛ-õìèÅþNvª¥¨¢ªPïù <Õ9Žmˆÿ·šÎ—­r8¿äÊŠøÛ…Â*uÎNoMH qVÛö俇ÇÚ¨C™c(Š­¢ý«ÞÑ(Y[Ñ«1@wº ??€hØC ”-'ÅèéRaì˜ËÖFF)%}ûö‰iŸ”’n½ºaø=«!saž{Œìv{ìVE×0JÑÕ*®³Äü¸öÔFHàúë¯/Ób¬Š³ÚSÆbç×E©ytÅÕç”:žø†¤ZÀ(í[kÕ¾ ñù•ÓÅä®0ò^ÁbÕ7jÓ4FE爾ùæ&MšD«V­X¶lY)s÷³Ï>Ãjµ–W_U)ÒV×N”¿“®Å²Ëˆ+A׫w:)Î'o£ŠC ѶG?ŒêÒ.ë@ãÿÂqªïb”h-ôã„®æ1Kyް_ý•õë×Çœ•…ç"¿{÷î=o¡ªjŒÉ{̨™Gd*[¾•¦¨j¼â¡¨j "†û¤* FeyRnR#:…lWÒ@Qâqq3¼½S”ø´­Šj-ɪƫÏE<¬[W<B€¢*Õê§¥¼)Ѹqc tÌK¯…Ñ”%ËÿÆ[à®´PdÜIý&­«ÔèŒ}[iÔÜ‹Pê–"Ú·};ŽÖ|ÅÙ¿c»²•ªEËò…ìÙÂîl5.<…È©ØãÂ÷¼¬Ãl?*ÈÍÉ:áã–Ÿ‚"ã ‚aè4I+ ³˜¨¦r²=³(WWq`;²¼QU¬ä¸\z@Žh‚-% ÃѼ$eý.\Öþ¸‚Á]Ï«´‰*¬ùæ.è9”º¶1[³q -NUc:ýó--NUã ´/[Eó~m‘N­ÆmRT ›×þB§Þ=ãÂ÷C{³ihkŽL‰uÀCFõîø•³E°Y•:#?Z @FÐ)õâBï-_Óâ¤ËÔ-‹hÛš 4íÝi«Úí{ ‹aH쪆¢XPT¢÷gÔ2cåå#RÐ I‚MÅå°à è¸l ¾ 3òÛaSð  ‡ruT‹•ªìd„(U,sÂÌn«-.íR¬6 CÖØ擌K›Dx??¾ ½DÛtCrÓàæq“7¾=€½˜2‹­VäÇá(j¥âò•‘7‹ £Î¹J%Šj©žÜI°5ñúð׿b·¥òÓ›Âg¤™Òá¬1J©H9Ù,,®Ó¨— °bS§¥;04—hàR@h°v»‡m„Qd•–ßã:ê¨6â’r#6ÇSMéÄ£MBq£±ÂKÑ;¾Ž’c""|­ ù1¤Ä¨FÊ› ûfung ª'+†Ä"„Àjw’X¯½úžLÖÑL #|B2ú£i¨ª9ž_ø£GŸKt¹ØsÄ ×cÐ¥©íÿYL›6m£Y <·_4’_6e£GnªåÝ:¶H@’Ý ¢D²U/#©Ÿh!· òûdE€.e¹ÉØ:µrñÏ^oF§DV EÊíKù~ƒÞm“X·§ Ú)‰(YéIÞÔ‰UUØs؃_'†NÙm’4nा]!'ÏO†×¨p~!£ôÊë½j³Ò$Ap0'TéIYœžnÄJé2¶!ª7N Q„Bû¦N„€Í{=(Ñ;>’ôæ (ì?ìÁ'ÕJÇÆ6¤4ØzØÉ™œ2ºß¥c;`ðÏ!_ y”ôlÈú=a?Kë´lex(ÐE‘¼IY‹Q‘ eçúÉô…e¨pNW™Ç’¢Óä5UÖº.IrªHÀétráÐa\4t]ºõàÞû&Ò¢e+ttÈl銴gÌaЬq[w»Ù¸·€î]2Œè-|.¤œÚ£>AM– jzìß¡ðßZDy üAƒfÄÔˆ<×±¥+†Na9=R_”v‰YV?*ú1 ú¤'Óª¹3Æ:”U¤¡:¬ì8èaýn7ƒº%Òc–‰z {óq6J¦žbT¢®ò?·9­tj P¯ž­Rí–åЊ¿ƒ¸t[«q<¬£ûòÙš¤{eòðâÎN6îËgËá =’ÃùÎ i¶n•D›. CâHN$+Óæ½ù´îØ¥¸œÕèK<~ ÅY$C®ÆÅd¨šm’Ǻ}_5¥&Éñ„WD·ÛÍÒ¥K¹ð 9ÿüóY·nì’ò,")%ÍZÙÙwH »÷ç I«ˆYÑ6qaWT:4u±ý——ƒfÉ ŠE%˜[À B¯–NÜA‰?ßÇ!?´kìÄ40ìɶr¸tm âÓÂ6!¡Kót Íl!~Ù¢}š+ÂdØuÄWc‹HQ­¬ÝžGÓ&öpÂ1»bWÖYôú‹,½ÈJTxø0üwi:ÝÛ»XÿG&ª*غ=›.Ímd T`)Ñ­@Ypè«÷ø9¹s½J¤¸Å,"£˜<@öÑ#¬ß¸¹ÂíH£FèÞ½{¥-ÎâÍ) ˜Õ°¾¼~Ôˆ¡"¢4ºuI`Å/n·d!Xº1EôF÷õY÷KnTù"ÁbQøj“E M£[·úüµ"79Jp·ÏÖÜŽ!¡g×V­ÌGQþÎÄfŠX¨’Z ßwJw±áÏ£¨Š`ûŽl:5µ‘s$•ߪòX+1Zyغu+'Ôìììèg>ˆV)vòCEQ˜>}:ß|ó cÆŒ!55•C÷GŸ D¬’@·¤ )IEßù‘FøšBáçö…ð¤'ð÷^7RÂg¦°os6RÓé×½;~ËA× Ždy9’¾døÏ¯ŽZìúüéšòÃ{À¿:%†ØtÈKÛVšu¬ÛA6ïs£WpM¤x»*‡Pô¤m *–@GÓ*GÍœÉ ¬ÙZ€”Z8å8šf”V ¥_7° ÐuIȰ—ÿæ@¹-_Î3ˆ(M?v» )Ñt=æÙã±5ÓtU‰šIIÇ)–wšÕcѲ£"J)™b2lhè!#ª´ü¨‚!BÁ>ÿ£ëQ´Mó‹ð3A'›Ÿµ™úKI/@=aà „ˆ»CF>šnà„ ¼DRB‚¡ã „°¨Ýøu þ@ˆ¦ã†Ð«š+]VÃ"Ú³g#G]ÁìþÍ€gĬXGÝAì $&&²råJÈÊ•+c7‚3¹¬ß•/è«ÕæÂ ÍûkDO©†}7…+M(ö棛öæcU+¶æ’ÖÐÅð^–¬ËÇQá=±ådQ \! k=ÁÚ}œÞ­>†”(FÅNòj9ÑeQDEËãÒô*)"«ËAG€ÕûÑ4¦—>g"aSÔC'WH› Ãë-ûž^Ô×"EèU´-7 Yá3Q¡UüYÝ4hØ„›Äm„B:Š1ŠH‹l­«£„ê7L¢¾/Ÿ#"œîBØ#P\Éøòóéí¬óFr-eç{ Ex× ‚^NÁŸ‘,†ÙnAÄúIøA×–6,*›%ðW¶˸¶ÄzÈ€;lQêzÑù¾ïb³[¢Jò öðùÑA½z QÕsD»wïæÂ¡ÃXðΨ(ä1û§E©ÜöT–á¬6ê´³RRë1 ©`{®‹övƒýY>ò½ÛÿØOÿvÉxB’ú.ƒ•9:¢sCººØl* VçbˆðÖ³pÁ4 ½e*] BXm ï®ÍåÆa­™ÿå^6GòüõíVŸzà —SÚ'S0h˜$YþwdJ\¢«ÕEX†RÈ÷h¤&©,ß ËÕtVWAíÚµ‹ .º˜÷. Gî¥Þa Éʰ/Sã o@/qf¢’W¿ÜNËF.ôHÙò4g¾7ÈÊü 5S„/Ä/³ú?ûÂæTA¾ÇËïn@UÂÐùs·lTÃþ¦`Pã§m¹(ŠÀ¢„¤{ò ø-'œÚã¯ÝyØ, ?lÎç$Ú‡jQ0tŸ·å"×U¦¨B1oén¬¥è/U ß½¬,Lö.±ªJLx¼Ì6 X±ñ(ETå/1ƒŠW9E볊ü(GjKµí¸8«K†ï¡ÚŽñÌŒl>:æqT¾j¿lÉþLV¯Ï@‹è «Ö~%ù·vcfäæ¾Àª Þø|VKÑ>rnD.@²bK6’ð8)"öhB­]ñ°bcFÄ?Y(CÕ >*©ˆvîÜÉÐa—ðÁûïÒ£{÷b[bމv ©ÉVvÎ'#/@“zçúIKqp8ÇOŸvõÉt‡ST"D…9˜UU‰Z 2b¾…1žÔHÊH%¶LtbH¢·¥-ºÅéÖ¥Dè«Qç‚(F[”*W¼ÕYÔUU)Ñ¥ŠaYQÌßU¬ …+S9t„"P© ?%4‡”Ç$ÂV_l½ÇãaÉþ‹ÈÉþj_B‰då1òU\vŠdLD}S…uE­Q4VÅ婤ÿ»ø¨(½Â( µ‡° ŶK¥Ç6>Îj)Ù¶mC‡]ÂÇ.¢[·®åÞú•R²ípHÈ΢*"ú;§ è·EU‘W4WÅ„‚ÈÙ¥ºw Ñи´ËÐõ*mÍ*lO5·‹eIIUÇê˜Ñ¬2¶M}°™xÞ ´[ÕRuèºQ+òSêQÍÝ4µ|ލ¼vI iT#jV‘³ZJþÙº•¡çË%‹éÕ«gd>È€3!V¤IDATðErø ÀÔQŠ9Y ß‘Uú·Ž¢HüA_P¯’"ò‡ªVæDÁÒñõÉ™ ¨5QDa>…ÛSfî™*[mazñà{ñ>†Ê ÏyU²½B„#Zµ!?ZHÇ‚N<ŽV Ô#rRwæ@¡Üù‚ºV5+T ˆ\. ÀE+õýàAçðì3OE•Ì㣫öNñ9ùM¹yL—*•™™Æø*–9žüÞµëFn}¬6V»!,•xZI<$ £kþNó¹ÞæÜpEǸõó·U™üëÔøðý÷U9ô?µ]­Œ×KGÓ¸«äGjA„Å7z³¥qßèº3 ñ±e£Fµ¯–-U®"òx½d9DHÓ04 ÕbA×õèõŽ@ €×ë-RÓU­Zž˜2LJvmàÕ»NG³®_€ÕæÀæLÄb±Ñ¬c_FO^PÅþÅiûgFizüè…ôÚ»µ\[òР쪌[$Yï[nA«%_š^¾"BçvWx׬<&•Çðоû߇+5’ J xIHj€Í‘@Ðï!?ë &L˜¨,ñ&¨i?~÷ GŽ)ægPpº\\zÙ•ÖøÇ|³j•ZYy‘j »3 Õæ$ä÷ ÔkÜ’‘÷½AJ“6èZ0n}-Ïœ¥Œw¬W•o5åÇÛârìþ…ù^V¿Kˆ”¥^»S©r…V(q¶Žð:Þ2t\‘®i8x€nº%úÙ”)S¸è ªÔÉ_?™Í½Óÿ‡ßÖ]î3ã¯Ïìwg—ɘØA Ÿs4‡”†)åÖÝ#µë³6•‹$2øØì6”È{  ë²9°Ù]„ •ö=û³}í÷|:ë.p. š¶­°Ÿ{~ý˜“†È«óÓ$ÉÊ?; fN¿‘Y÷N µO?ò3pã}“p•¢/N¼—äî½ñdäšñIVá+(h{i’r.[Ð 7ϾðÍRY·1ŸYÏŽ¯}%¡ñÄÔ§i•ÞŠñô3ÆÏ"JJNæÈáÃ8öÒÑ)£¹~ óMSìZ‚ª¨1&Wxøá‡BРAJ¥~ÇßKQO¹†öoË}fólÅ2>úè#.¿ür¤¦±ðãO°!¹rôh0BÌs>ΔdÚžr1}› >þì5jˆªª 6,ºh½òæ\š5N!99 O?XDƒW^M3©ñÉ'Ÿ`µY±X,\yO„TÙ.¼Qçññs7°}õw|ôô *£ç/V'Ó»m‹)„ֹ醰ò9ÿ¬qp E$€ßÃ|HºDæ|ðÃAFjVíIºôó79óª‰ì}rÖ¥U%¥¤E¿+¹¦o¸]ZžÏmû¾FJÉÒqƒx`Qø¢î¾5Ï¢äà¼ûY®mm©ÑyÌRþyhìØ{ PÆMçú‰ :YÂ? òà‘™ßйyøªËÒ«ÿÅýïþE@þÖ—9š a={í*fàשWsåËhg2¾àßrÅÙÍ⣈òrsØ È¢¤h‘3J¹‰ÑÂùZ:w+º½sç.úôéÃ'Ÿ|·ß~ËêÕ«Ù¸a]¥>½ëPҡܼARJz E³©s¹üòð«h¾™q×L[ÀÉ×,bÉÔþœëͤE¤UaôåWT?¹˜Õ,Y<~w¾´0¸ûΧB0bìX yÛÛ9°ëUÆŽ[t ¢˜¹ms8Š ºŸ¤¸fÚ§¼õÀ¹ìÝ´ŠŸ¼†«û˜¤Ô´RJݚЛ+Ï€95ð9NÜBîzÙÅ•*÷þ&³­‘~4Žåð Yµ'éÐKÆÅÅêøý÷ßY´hQ…Ïõèуn¸á„[D…¿C>7¿07úݼ?¸"ÂWë›ñj‚ÛÛØ"oŸµâúýE VuÁ]휑qSp­~Ž‚ÇžÌãOÌäÌ÷ðÚš†‡Ó)àlwÁÜ\À^ëÊùÃMN^,”¡ÆÃQXZm*¥ˆÜn7ýN>¥Z‰Ñg ÑôôvL™2…nݺ±víÚ*yù+³2>£G²Ô àñ·~'¿ûÇa+lD imZ0çå×°8-tr§¶RðùüQEN´Ï/ÎcØìðëqSU4t¦¿ð:=Û5£¶ŸÏ‡Ãé@(J©ö5ëЇ<ßhÁ››ŸýŽ9ÃÊhá´Ë¸ê±INmk›Çy¯þĤñL:»R–E;‘¶e…@à# Rkx´-‡ËÆÈ[^¡g/w½óó_žOã7qÝèÑŒ;–´zi\>òœ{;Ýá÷¿zÇå$ÔO¬ü7c4®Ø‰þßÓè{AÍe(îÎjÕb¡G¯^,þâ3‚Å_|@rRr•i½el…ßÏ~o&ú9£F^°©òÖœùÔ«—ÀY—"%àý¿À‚ÁºCïÚ8…—ß|‡v­{qöáÃ^ZÉ+oÌ£i“fLº…„ä$æ¼ú6 ›¥ðéŒëRâp:xí­4oÚ•áT X¹vúç|òÜÍü½âs~úài†ßõb©ç®¿óúM^߯±$6僅 Ñ5뮿þ˜ªÝÑ~$ív}Á;ïüB—‘3èROÆe:íœÓøožõïСU .ÄétrÁùáÀKçó&³è­9­6nœ¿©ÂO/\Èü j=î;¼ á°óË+#˜¿`R$rßÕ—2omì‚tÝ]×vê½|ñî;¬Ô%Ã_ø—¥0CJ\/£õž/xçåt½l:ã!CYG3eÖÑL¹rùÏÒçóÊýûöȽ{vÉ];·Ëí[·Èƒû÷ʽ»wÊûöÈ}{vÉ=»¶Ë];¶Ê-o®ý\óŸUrãú¿d! Ã塸wo¼ñ†¬*^xáY1sæÌ2?÷¸sä·ïL—ù9™•¢3kÖ¬¸´gΜ9qíß/¿üR'iU/¾øb­Ôëóù*œUųÏ>['çÁ¢E‹ªU. É u¬Óå¢Y‹Ve~wÑ…ðøŒiU2³ÿ›Ï›”WR}†\3<ÒGTžVè(þ3þ|»É=&LœET oÝ× ¨r™sÎ9§N2ñüóÏ ÁƒÇ…Îé§Ÿ×þ¥§§×IZUÅÙgŸ]+õZ­Ö¸Ò2dHœ'tRµËÖŠûKJI—.]ª\¦GuŠñ™û·óåë±Øììÿµ9Îä$ÖoˆÍ‘HýÆ­h×k@•ú׳gϸ\¹èÒ¥KÜ J)iÚ´iÜÆ½iÓ¦µr€±¶äGFÇ“^¯^½êÜ!P)%éééÕnW­(¢ê4´.ú—^7ÿüþ%ÑÌ}‘T¢RBZÛ®Ü3çÏ*÷¯¦ýŒãÁ÷x·íƒüÄ»ÞÚäáñl—Õ†+9‹Õ½àÚ唋èyÎ(üž|,V›É &⩈fΜ‰ßïþ½fÍ\¦³»3›ÃE0¨ !½ßÙœ>â.S²L˜¨*tV‡4[ÆÝÌáCÉËÍ!7'›œì,ÚµmÃÀ³Ïú?Ï<ÕjGQ­¤4nÍ•“ ||;o*+>}Ñ”,&âeišÆ½÷N¨ð®Ùÿe8\‰(ªŸ;›îFp͌Ϙ?yßÎ{ iè u¯)a&LÔÔ"2qlØ hÁO:—ëŸ\ŠôóÝ;ÓYþás&ƒL˜¨©EdâØ¸òáwÂé@€ýsÃS_2÷¡‹ø~áãH$g]1Ñd” @}ð¦4MÃVÎÛ'J'F+fXí4lÜøÿ$“SÓHNM‹y^ƒ¦íhÚ¾7ë—}Ìž¿b±ÚhÝíTSÚL˜(†aŸÄh& ë©C¹fÚ§,zê:’¶0bÂDYG3%Àæ¿7Õ(1Z·½Ln–wÖ’4þ?wáׄ‰ÊBÓ´"‹Èœ&ÇkëÖÄd‚ Ç@¥£fæŠn„‰ã…cGͤ¤AJ “y»ÝFŸÞ½8ð̸ÜÀ7a„‰c[DR²mûvÒš·¤Q£†X,æ¼õ6Î<›zõê™Ü3aÂÄñ·ˆÖoØÀÝwOàhÆa²²²0 ƒñwÝÉÖ­[9é”SùeÙx<“‹&L˜8>‘ÕbaÚ´<õÔ“dddD?ƒ´k׎¶mÚðÓO?›4aÂÄñSD«…uë×3èœÒYí4MãüóÏãÛï¾79h„‰ã§ˆ úv{Ùé>;@Àä  &ŽŸ"òy}Lžü÷L(}ƒ<))‘‡y”¹oÏ19h„‰ãh ¸ëÎ;Yùë*^{ý 5lHbb"[·ncØ%#Y0.‡29h„‰š+¢ŠÞKïñxøùÇïÑušÐ²u[î¾gwÝy;={ö09š0a".ˆÞ5Ûò÷&úVp׬Aƒ4M'àõzÍ»f&L˜ˆ bîš yyîè…W&L˜ˆëÖÌd &jQ‹()9™#‡ãpØÑu=ö©ÈKâb£½ŽZUT““&L˜¨¹"31š &jY¹Ýî%F3a„‰ê"ê#2ñ&L˜¨uEt,˜g†L˜0qÜ·få"šm v»>}z3ð,31š &N”ET,1Z¯Þ}xíõ7wËm r¾™Í„ 'F­ß°{&Ü”’ñãÇG?ß·ogœ9‡ÃarЄ ÇOY-¦N›Îܹo—ùýþýÌÄh&L˜8¾ŠÈbµ°~ý Pna31š &ŽóÖìØQ231š &Ž«" 'F›Ä=÷ÜCy©BÌÄh&L˜8¾‘€»î¼ƒ%K–0cÆŒR_¿3ïm31š &Ž÷Ö,œmùÏ?räð¡èÆ:0çÍ×éÕ«§yÈÑ„ q™Í„ µ 31š &êþÖÌ„ &NÌÄh&L˜¨;ŠÌÄh&L˜¨eEd&F3aÂDmÁLŒf„‰º£ˆL˜0a¢N+¢¨“Ú„ &Ž*躎Q‣¦éÜ;án3‘ &ŽÿÖÌ„ &ê˜"2£f&L˜¨…­„“è?8åQ¶oÛÀÔiÓéܹC2¹g„‰£ˆ‚¡/ÌzEUÃþ"à ðãõša{&Lœ E$„ Ïí.u×Ì„ &âÓYm„ S™0aÂDtk–˜”d&F3aÂDí)")%-[µfßÞ=ìÏÏ Ô—¸ìZ*ˆ/‡4£™0a¢fŠHˆpöÅ-[U‹ÈÞÝ»LNš0a¢Ú0}D&L˜0‘ &L˜ŠÈ„ ¦"2a„ S™0aÂTD&L˜0a*"&LÔ:þ?,U/ C‚8LIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/fwindow.png0000644000175000017500000004231513070106167017007 00000000000000‰PNG  IHDRDì•0¹ðbKGDùC» IDATxÚíÝw|åðÏe'm¡eÊÞ{ï½Dq‚(‚‚âFT¿Ÿ‚'*?QQq2P‘Y( ”½¡¬ÝÉ]’»ûýÑAÓ&mÒ&mÚ~ÞšWKr÷Ü÷ž{îúÍsÏÝ çΞQADDDTI’„ù_} Ùl8e»öFÒ¥³PkˆˆˆˆÊ=Y–:¿ý{©Vj×í… ‡©I—ðì=ªšÕ‰¤ªP ú 5ëµÀis—™Sv–°J•¶Òªª"áÜÔ©[? •«ª Î ørÊ‹`«/ÆÃظ/•Š¢àÂùs¨]§cã¶ô™ÝnÇÏ ¿½ž)ŠŠ­ûÎâÆA}p8JµR$I XeŸ=suêÖØ2@‘eœ;{&àË)7;AÕãalÜ—ÊÒ·{'Î=ƒÚuêB’$ÆÆmé‡Ýžó»&ë{RÒE„XÌÜ"DDDTáè‚1¨¼§ÑQn –Q’Ë)/‚­¾cã¾T–ÖùúÏàkƒÁ·eÖ² wB„@UDîrZÙ%µœr³Y}1ÆÆ}©Ìý ÆuVù· èëK ò„H-rK(w²W_Œ‡±q_â:s{TŒúʽöt9*¿”Åúb<Œû{Ê{lÜ–ù2"Ÿ"Qæ—L&/_*4c+‹Ù'¿”íúb<36E4B°¯Àš¼oLž†ãh€WfÏ@§JÆr{ìQ.بÑtëdlë4÷7åþQfê2Ò¯íÛÏÎÀ)m#¼üÉ4t Òö›{9š¢$2ªªëe³Ùàp8ðß_òœ%êUËÈõ%-°Ë ìË¡”Ô²‚­¾Ê_<ª"!ñ䇸ãçãn?·I2¿¿·ÂÆfÍпǻA³/É’„¸×ÞÀ°·¾Âüé÷áã ü¶Îª"!ñć¸ù‡ò}¦HVľw>>›^¢ë,„6¼ÿ{ìkD žÕ½ÙÇõt›7~¸P¤§^Æ­·ÞæñuçÈQø-ÑZÆþæ¨2¬øzòÔ 8f9­6ì›6w¾5_¼~f=½1èêËÝ2‹}ÊLEDDDÀf³ù±×¬4¯2Sv-ýž±ûçþpÚíx½ï=˜±}™ÏËQÝ-G•‘’ø/îó®WeY,¡Xþûo%šÜ;í"–¾=‡‡ÍÃÔŽÕ\>ËÈÈ@£ÆMpéâ·ÿ.ÎvQ\Wu•‡xDQÄÝ#ï Â!žÅ”U¸õ{ L&~]¼(Ï2TŸË/±©2ÄÔm¸ÚÆïÛ;ᄂª2Ò.lÁÚ­— î­r8pü€„ÑUL0:k T½àUlÞ¬³š;9Ê3šu]UU‹\îŽ6› ·ß1¬ÀùŒ: fk†8¥>|µ.NYhdÖy½Î(l¡BUÐjX¹by‰üò&¶ôôt ¿sD儆†bÙÒ‚ÿ¨N;Ò¢WAV§ùÞÓáõú8‘z~+Öm+¸ýÊ’„SEŒªb‚Á‰Põ’Oí7õ¥Ê"Î휆ÇÞØãò¾Á`À¸1£ý“•¿®>ö”U¨uûYé‘€õÂÌðWù‚•k Âúuƒ 4#íš¶êW¢¼búY|<å1$õž™y’!*{L&V®XUµãêé9xxûp,Õªâ@âÁÏ1ãËãЀSQq*. Ïž¯£^‡wÞ}·ÂĦ*\ÝýÒÒ.â†!Ÿä?¸Ë <Œ‹Îúe_RÄÂn:§:6DD¿þ7¡w˶˜<ë½²pðô¸Îf³ë×­-àKèÜ2lšŒ~ M Ï£~‰(5- m»BÍÊzœº"¡×²*¨~ç»ø´çWùâqT1i]gКÑþUü4£c‰ÕZhh¨çºQ$_=‚;ïþµÀ2’kZ*"´"v9Šp§¢$BEØN„µì†ŽÕL~9¿¤*öBÛ¯ªÚa`E¿þ7¡Oëö˜ôÑ;¥^_‚Ö„ºÝ߯kòÔÃåK—&!Êî1JJJrûÓ›ž¤Òì!Re×bãкGæ·91uä6|ŠÉ/÷Q8ijЇ´ÊW†(ŠyÏ=…þ±Y¼h‘׋Sd'ýõ¦¾»ç}ûD¹]õðè•âl3Þ÷'pñ(v1oŽÇ»áÏápÚ ý6 á‘CðÎC[qºß;ømX}Øì Ì>€÷'6Füìa^/§<Äæd¬û`?æ¬ÚÛ«˜óýHO¹ˆæínöz¹ïKTª=cî+l÷q~ï?ØÔãüÔ·–×õ[Ð:Ûl"FÜuWVÜ9JZŽ¡¿Yò̯ ã\<’׌ÀŸF-Ìf~[²ÄoÇ·½ v1³žÂÀ~,ÒþVÐ: :3Z<ú ~Ðw~¿Nh»fï‚,¤¡Á‹óñËu\¦·Z˜ôân¿í÷Å=–8Å ìù|2ÌüÖµ,§ˆS›^Ç“ïï À`4Á¨×!=9 úg£yxÌf3,f3,a•д~'÷Çs§ A'@±K8¹âÔ¾óa˜4×{œ®Ä®@õnw¹~¡¯3¸ðö+[qvßFD÷~?ô©é—ö[œúòv™ì!Ê99qiç§x}þ!\ü+ƒ_Ä‚kÒØ4ÝðäÓ?áÆ7gbxÕ’¹›· ö” 0W¿Õm²³b¹ç._1#ß4Õëõ>½Ÿ|ü’šÞ‹OVýŠzuS«vc‰m»5Óïƒ;/AÇÖÔ xfØ«˜þç—¨iД`qàò±Ïpï/ýñ÷«r½oGžéx:n,–=Ô¬DÛmaõS]Q ž<€yK6Árùs<²}Ý^/Ü<­ÔëjɽuJ%6׃¡)WþÄ\ùì«bv7Ò BÚú_*ðŠŠä¸k¨ÙÇâ·u5›MX³zTÕ«§çàõ·`õ£Íó$©6ì™5 ï[‚ɵC¾Îªêĵ3+ñâî[±ýüC”·çòÌ:¼²ûflžZ#O¢gBÃïaÍÀ\‰¥-;ß¹»'¼ƒ'jÞnÒÓ2pïm³±âß¡*$ø«/ŽÂĨÌí®8í8¿öGׄÈëö« eo"{›ƒ¢¾¼Uì„Èd2¹ôúäþ·§Ÿ¥ÕC„‚²OA‹È®S0§½ï¼€—æ}ÕiÇþÏï@ôÈOñXÍËrÌ1çÿY‹†÷X`ŠS±EÏãÄÍïch„ ŠS‰Ï!ìå—=ϧªÈH{Ó«„Ò鸭¡v!“ÉH¹¼ SiŒ½Hˆ $hQ¹z/̵/ŒÇkÍÖb~µ7±´YåRizðäS*¦í½‚í«ªé)ãÇæ¯ã‰¼ãJ‚õ#Š6<8b´öN[‰á ,¸’Ö²ÔëJK/¶Ì¤CÄæÏÃþ›¾À‹MªAm4/ïX…¹¯ÝúÖxæÙ)èÛÈŒ³‹7¢éÃ÷ùw_*$Q°Ë">=ÕëÃM%ÚœTE…õt™µþ?~äYG)ã Þ}ø š÷[Vïf í2jw| «Wmßl©—ñþøGÑgîtð¶n4, ,¸xE~|Ô5hóxc|r0 ³;Vƒ¥Úð.ÿÈJˆdU‡˜k=Уñ‹N;æžiŠ?K¤ý^_!!!X½*ÿ·¦Y1éÆ'ýÓC”} ~vbä¤HUÕ€=å6wo†Ûe¨2R/¯‚®wkH’‡Ý¥é½q«l‡$ûT)JÎïEYU¶ãÄú7°µã4¼g,¸ Yqu š "NløŸìl†?™U©f<þßQ¯z®{I9ìÈÈš¶ÐXU'¬ÉqÐYZçL+¹™WqЏ°eÚßý©WëïM}Õ2 m»ϧ÷À‚%ú$ä‚ãQQcÈØðÈrHKÆ@–lØùöLüç•‹©8õ#K´þ÷õO0_úOì¼ ?ÜR/{’hlj߿ÄÌÕáU$D'â}{’v%âM/×¥8uUº±²Sù¾º»MÎçQoÂôÏn@Òñ­˜ûÑcx7­.ŒqçñŸÍ‘×ËðǾTàn&áøò)ÐŒþÏåx{ì «5‹Ç ù¦±Û$l: LÌ{Üñë:«Ó/à½GÇ".¡*úWŠU_Š,{\gÉ.CqÚ!Ù¥œŸiIWq{“Vp4mÙ/ØÐ¦¶ª"CN<…YÿÄ¢‰©ø#J ŠÍSÝXSÏáýÇÇaߥH ŒÐz5Ÿì°C´&#UÐãJÌ!©”I!J$Q‚,ËèÑ«WÞE!¤Å½Øýþ!Huƒžn}"syª‚”Œø«w{<îktXq|Õ ÐŒ|Þ÷ö[Bõ•Í&9pT­ïŸ„(»—(÷`é²9¨ZõêFü÷_‘‘¸©šxz¢ ²#'¥bâ¤)hxÇ ˜2¨V€»ý2¿‰%YƒñožÃ· -t~§"`ý¥ÆxËdz¿ŒY½ìËKó|/‚>¤ê†xèVö"VUv"íÔTj|O§Ììvß|*bê~;Ũ¨ ’ÒÂ`r¤B”…ÀÝA¯àx˜Œu09ì ìI¿åDÌ<9+*JõbOõ“ù…ņGï­ý<ަ¯ÂÈï,¸’Ö5:Ô¿å~xùƒÎØþñH¼Zc&:Yô¹¦+þ¾TÀN†”ËÛñÌ{I˜¿©E‘o5àM š¼Ç U†55Ë«?„¼óûiUé—wãõ‰ÓÐþù0¹ÞiLó äï¿AÿZEë‰ÏýpN÷±¹žv… AåÈÞ˜¿t6 ]’1懱lb+ȶtìzã®bÝvÀÛØÜnû‹±xkò ´n!ž©} SîÎo¿DŸH×S`3vìõ?ä:#Œ&=Tù_œy'¢`4a2a4šV) Ý{öÌÛG„*5ã2cÓ™L¸ýƒ· ª*dÉŠ£ß½gÇ}å[=¨2’.îÀs$ãË Í}o¿ª/÷ó; ¦n@zÓÞ’‹Ÿe÷ ð[QéÐÀRuf}Ü »ßº “>Å:\;÷)ÖߎOjZ"Q(Nvü>¯ÏÛ‡éËç¡aaßPTÖ”MØØì‘:Å ãŸOö ÿ+Ó øv áÀÏÏ!ýÉPI矤Eqˆ8ðÃÓpNþoV[¦ÿßß\j­EkСû+wâ±ïbf•÷1`ÆÜRm½ÕÖdÁ ?íÄ`Õ«g¿À„˜Û°ø®†Peg¢Ÿ(Õº*íØ Þµ8µyžý£>~ûs`I-I'þÅÄ߯Cßÿ†Ú†’<›ÙkóÑSoã¥9¿hõœ8úÏ÷˜:g'&Íý ½k[µæ,|Ç>Í Ð7ÒÐuT× ÑÉñxkzæqÌ.«8½ç*ÞJ©ÅiGòþkxª¤÷a§Gÿù¯}ƒ§gÿ€¾uBµ>þxvÜcÐ|7½j\?ý‚eK—æIþ¸š°wO¯…Ó½?Ñ•÷0­Êv\ˆ[‚Ï”Iø*ÌûS™ªâÄÕcÿ`Êcà¡‹Àöëk}¹íL$ìûrîþÏ÷Àá-ÅOˆ²O™å}/XUöíI‘UÙ’†;^3@QœHŽAó¾ô[T‰'ð÷ÚÕXºt="zŒÆ+ÿ‡ªzM!óª2®áóg>Æëó~óËeï•¡ÊœÜ0Ÿ¦ ÂööUÝöÉþúî-üta(¾y°¾_¾É«ª×ÎþW÷ÞŠå׆l…gMcñéÎv˜Ø¹Z©´:TŠzu¾sÃêaÖ•zy~qêG’$L}õU@U eÀÑÄx>:zŠñ·¹dÎdëË·ãâÔU©Çæa¿²[/â—Ùïàë¸P|·òcÔ,t_,f‘ªBL9_¿ú 6$áå¿aP£0¿_‚îyÙ øgõïøé×­¸õ•ïqs¤¹Ha=ÂV`M:Š/ß›øJCðÅâO¡Ë®S¡5º`ÖwÏà‰{…áׯÐ-ÂXÄuÎß64še­5ÝŠ)ãŸÃM߯Á?[aê+¯äôíýßLØ2«‡(ÚíM+‹·ïz(OUqí0¾|ÿ]Ä[aî/³sû5¨\³+>œÿž3úEóÐ%¼€ºQ†F°ž»TÄØUØm×°æûÙX™Ð _¼ÑÙë^?[ò),þjnJÅK_/ÆÀb·ßÀÖ—â°ÿÏñnâh¬¨†õ‡á¿¢ò2¨Z€õÎÞ­ 8T\\u·½˜ÕŠ]Âö7ŸÅÜ3©°T­>cæO¡šQëUL»ƒÿ<õºOúÃ{¼Ó.á·÷&aþѪøaÙù¾Q8ìv|ðÖTìŒÙ…‹öp õV?Û†xžš,IX=u _²B‰žoÄìEPYççÛX¨ Ò’âðȤ…xø?bRÛên’f *ÕìŽ¹ßØ0þž§ñùêy¨ª÷Ofƒ3G6@º$Âù ¿ÍH pTÉW÷á±I ðÐó31¹c¤›ºÑ¢rTw|ò…Ož„ÏW|†*žêFÐ@khźݧí#¦ÃÚU›³c;Φqýðåã_Ø ;™í7~?vÆìÂeG u?V>×#pí×õ¥ÈNœØµßû=.DÞŒ%ŸŒçõÞ2ôùsPuiöéô:|ù÷ûPU‚N³þ)R<Þ|Kôô˜>'ß~ï–% ¤J¼þÝOˆ4h‹]_Z­#FŒðXŽF«Ãà/bd«úùb4øáç_Q#ªžkPÝïõe ©†W}íò™Ñ÷V~°¶âÍös8€?Ö™ðÞÄÚ¿y£?êÇÝ¥í‚ΈöϽƒŸn­Ÿë›“ ?í×^˜ÂêªôbSaM?‹‰“¦¡RzhÙ¦=î˜0SVÍé=Qý¼/åüAQœ;}5ÚôÇK÷?ƒZaú\ߌÛv@c0à¶™sq›޽¯³€Ðˆøå»…”¯Axø~Qt‚=T9UçÅ£;T(ªÉ—¶ä{üÃð¿‘5¨ú>ñ[QA±iP¹j{,Zøq!u£EÕƒñÝí ­ C å´÷±« dg •ãáG£Au³Wí@–e$œ½†šmà•ûŸAM¿µßÀÖ—ìq|ÏUÜñÂ=»k]ËÚ¡UÕä„ï±uÐT¼¨E©&DÞÓ¡jݧðsݬ24FÔëù5~ÌS¦ 3¡ÕÄe~K:¼««Ò‰ Ì!u1þ—~;þº/åJ"†í÷v_û’·ëìÕQ­rõ€<³Î¢×`Á#M¡ª*,¡¡ø%ng‰üòçsõá…×%Ĉ…Kþëò40WîŒ;oòmuz=† \û T}i z ytL¾/‹×k£˜ÊÓ=ˆˆ¼!KNüóÆ"LŸÐ’•Áº¢2@€J¥qŸ°_O•ÃC¸Á‹üµÑO½CÙIQYT]Ö–S^”µ"­Ñ„‘ßýYbñs{ ¶ºªèû!×YelÜ–>.ÓO ‘»«ÌˆˆˆˆÊŸ"Q!øá¦xZ­Ö«,±,fŸüVP¶ë‹ñ06îK\gnŠQ_E~Ú½Éd‚ÕjÅäÉ“K,@&DÜ øÜ¹ÎlƒÜ–A•€^¯ÇÜ9s2/G;,5çòÔ¬¨AÍÿY®Ÿ¹ƒ`#!""¢Ò¦ ¦`TUEü¾8Ø¿/ å ‚€ÚuëtÙË©S¯öïÃÁø}lee¬¾cã¾Tvh4Ô®[û÷ÆáÐýŒÛ²|$DŠ*`OrM NÍ€”/ËNÌü߇¸ûÑÿlàtØ1óËY¸ëẜò"Øê‹ñ06îKe‡Ã.âýùs1â¡ç€:µ·¥‰‡8ñG披WU‡SÆãï­Äƒ£ï€Ut"Ãæ@jÒ%<{O眞›¬_<žóÇ)3YVÄñžFDDDT2 ‘zò:vš`‹M àv»ˆGnlÐe¨Pa³¥ãñ››|9åå¿`«/ÆÃظ/•ÿ2ÒSðÄmÍ·e‘ÿË–ÕC¤à…¹ëpã ¾4úRí!ú}•+•(VÀ˜¾Á{ŠÉ)«øaÓEn(¢ô §þ¼ÞC¤ÑèÕ¶.Ο> 8ÅÒí!R÷²K»©a@—¡ª€hÍÀø[š|9åålõÅx*flîȲŒU«VáÁDÓ¦MQ­Z5T¯^-[¶Äøñãñ×_•PÏ9=ž^i©xòöŒÛ²È/—¢ìÿØÑ#8î,D±”’"A{]’£KIéE/N"#B™QôZcû_Ä©( âââ0~üxÄÄÄxœO«Õ¢_¿~øüóÏѼyó€ÅçU,ü÷7Qzˆ´gÖâб“ׯ2ÓjµhÞ¢%š6kŽMþF¿Aƒ¡4EEªªPЇŸªªBQètºÌiݾ·ï@£FM°rÅr¨y¾evg÷tðþ‚8Eðs¬Ã¥ pØ%LÖ_¬9Ðú•l˜2²#>[y„­ Öã©x±©yz…Ö¯_Q£F!%%¥ÀùdYƆ 0`Àüúë¯èÝ»w@{‰xìÉÏšžŠÿŽéŽÙ¿dlÜ–Åë“Éî!ÊýÍhÝŸk0lÄÝD±Ä"±ö—¢k©Ù^‹Ý±;³½ðozz=ºvëŽ!CoÃ'+O¡:ŸüKD^ô=0 Š¢`ß¾}0`’““½? ¢¢¢°qãF4jÔ( =Dßm8Ï Eä÷"'ôgóô‹Üçó®åV·¯½9f³ÙÍ<*®]»†Õ«WcøðáøpæÛ2ô6 ÏùA‡]¤;[á³UÇ‹›ÑbB÷¦!0(*Z(ˆ?–‚ó65ß·´çFuœå‡Ý–£€¦u-8|&pÈ‹³ VÀ-=«aùæÄY^aõå×o‚€Ú Â1 ® 7^.µx´-Õ E½JZ@´: œV[ޤCRý)ÄŒnM,…¶Û¢ö·®¼Ù&Ž-û8!Š"y䟒¡ìcÐÅ‹ñÄO`íÚµ?6þT”¶ìK›Ì; â¦à‚¨æëUxéþ˜µô€›Æ˜-ftõ¢wí²rõJ¸µ¹?lº\¤2 Œ­¢òúüõ´ûÀìô¹že’§çÊS2tâÄ <ðÀHHH@à ˲Ûòtzæ®-Ã3¿Y**¢%CÉúvU%2íªèàP­V9Æ­'­P²»C-èÝÔYR «€ ¨¸r!ñ×d¯–‘ïtE½ÊèPU‡4±Sµ IDATQ†¬²YñCÌèÒÐ šy@3é®á¬¤ú¼ ã“°å`ræÁ,aaèlpàïø$l:„÷_û7ÔÕCU3X×váØwᅥã¯aÃþ$OQ¼[†KÝ «R½*9±j×lˆO–ÃÉ0Õ ‡AÈUo¢Œ]ñ×°aÿ5lØwÿÑ·½Åçåtïwõå×{Òˆˆ>ïpÙ¦¥Oþ—½1jrºßâT Ò‡v[Ô{ýµ®|Ù&%›Š .;i9þ|‰ƒ§ízß–½i“…MãÌÓn­i©˜2¢ÏËrºiÿ€€JÕ*£NjŽd(ùÚ¥¿b«(¯²R_AÛCTØÁæÔ©S=z4¾ýö[̘1‹3fÌ€ …ί7ñéò£°;œ>-W«`€âv>E BpùLÐ1sÑ>ËQ!óQ"y>×hÔnnÁÚ­×`ϵ‘.žMD•¾°¿ ­"‚ Éá„Ýy}"»Ã»eä]^¦ü»í,DÇõ²LC×~×çu8‘ûÎTjz*œÆHØ)>-ÏcOF!õåo…ÅZÒñ™=mZ‡àߘتÛxŠÂT@ä‡ïCFs>Yz°ØuUœöãv¥ª¯{aJ뛢7ëQœ¶â¿¶, }›l½Tä6éi€=O»5‡VÂGKö»Ú—rf³ ½«:°2ÞáñÄeQb+ÉcIp5[Ç¿P5—Ï´F ÞýyO‰Ö— :a.é„H’$ôêÝ1;¶xŽ\²;<þÁx௾ú*n¿ýv¤§§cܸqhذ¡çåæ*Ïa—ðÒ}ñÁ¯¾`WT@„ÆýÁRŒP\>“D+^{ ;Þóp`ò4hYP¦!ªµ©šç´”!@UU8e`Kl2w‰„5EBB’ˆ³‰6¤;U¯–‘wyõô bí®;¸ÓnEºž3¯ ¨aAë(3 P!Ðh4yº@½ïÖÏ· ©¯@õzе¤ãÑh4hZÆ3—pZRü¬`ƒÆí>¥h {ÜßJzÛ§ýø#6UUs.?vìXÑ®Ye”Ö)³’n»îÚrÝÆ5¡;} Ç2ìEn“ž¦Q pº|fËHÅ´GûãŸvçI²5>•£7èй¥«£s®ŽS ¨9ÓùZ¦§Ø*NB¤Bòð·SU3“ËÜŸ•J}åVSRÉPç®Ý]»õÄŽí[=fDíóZ­Ö%)2 xôÑG½]WèôF¼¿ø|=æª*pÎ) ºVÀå<‰‡ 5@ë´¹”i0Zðî/û<.'×£áò½ï”¿ã®xP®ªH¿–Šß·¦ÂdÖ#ªª½ºD íô%l=ï,tÞÆ‘ýST­_ýCDüqð Ò™—å¬åá ¾·Âê+p QéÇ#hÔ¬W ­ädüîa†H’$têÒ `4 ì!ÊŒÍýShó&EÓ§OG·nÝP¿~}¯ËsØE¼0²•ÏOÂUTgÎ8еªÆ56°T©Œ”ÓV—÷E1/Žj[èóuó¾#CÅ1ÐÊ$xùdk;ŽŸKÆß;/¢Y«ª^-ÃuyÀi‡€zz×é4zB…Ì÷4ݱ,>iÎÌÏaø¼|x±Žwþ(ÃÛcc°ìK¾´eoÚ¤¢ çèT%ÿ4æˆJH9ëZ¾5#Sïï’ÿø¦¨^—£¨ ’/'bqÌ%¬Ýs9çõ÷Þ+H’X»'ÿÄ_ó©Ì‚b«(ÿ••ú*‘„H’$tìÜ532°3¦ð«/< vÒh4°Ùl9IѸqã0{öì|ó[­VhµZ·åiõF¼·(ÞçWŠ¢âÚ©D„´©ŽHƒó¾ÁdBÿ–:üyÊî2½ÁhÁÛ?ïõ\ž*àšªE˜g™ œØ›Œ.#`Ê»F«‡!×7ÄPË|ÙáÕ2´#×Î}ì ýÛ…AP¯÷5k†t%»À¦ ×9Ÿ7nV ‰ŠÆ«åyó*¬¾òBéÆ#6©ŽÖÚtü~0# õ£È*®IDhkïÚmQ^~­+ø·Ž}M«ÕbÈ!8p`‘{‡n¼ñƀ܃Þ}©°¶œ÷˜ã©Möm®ÅŸ§ìPd×Î^AH«jˆ4d `²˜Ð§¹ëò´[“¥¦}ã¦ý^Ž^«Á]ƒ¢¼n—þŠ­¢¼ÊJ}ü”™$IèЩKN2´+fTUñb§WÝœ—× CÇN˜1í5—›.º£×ëÑ­{·å9¦ŽéŒwí÷y}ìv K·%c@‡šè*+Pè1[Ï#)OW $Z1í¡ž˜ñSœûnDYAÌÁtÜÜ-×l ìv6HË<–’‚¥G+aH·HØD*h!#vÿµÌ.GA@µjaèÓD—uɽƒNÅÚmW\ÖÕÓ2TÐ BÎcS’/%bSH5ÜÕ³&R¬NÈ p2öêQ9c–¢c“0´{$’SP\:‡ªÖF˜ æÜTËã:y9Ö£ ú È©µà1DŒ'ó¸ÕqK#N\pk—J×Û¨¬bmì%—a›Å‰G’$ü¾=ý½h·E§ãº*l›:¶œ[Løøã‹ô莚5kâ£> èxŒ`Û—¼i˹9žÚ¤Fubgô…œ6)Jv¬Ü™Š¾í#aU(P¡…ì2Íõq'ix÷ÉÁxóÛùâ+¬ƒN…‚ǺͻSÁ'ËsC•Á^öw}iT'j¤lÆ¡c'ý7¨Újµæ$C‹q»‹ö€Ä@>¯Äáðê˜.Š$Zñú+ìókÊz}1žŠ›‚Ìgpå}  n:_ó Ž?«Í† «‡Æç_|ºÏ߯œÁ½<öä{Ù2ÒðÖ#½·e±Ÿeæ—¢Œôt—d(û4YþWá=DçB{•‹ì“ß Êv}1ÆÆ}‰ëÌíQ1zˆj¦nñOQÞž¡=±;‹U^ /­sØ%¼9®KÀ/á“lV¼õp÷ {©eY¯/ÆÃظ/•—-= 3íÍØ¸-‹}Ù}±zˆ2ÒÓsP[,ìÜ Nç¡wÈ»¢3!=ÙCÄoŒ‡ß€¹rÙù· Dzˆ¢Ò¶¯‡Èjµº\M³}dYöêU!€ÿÉ;f<Ô- Ë À!ÚðΣ=¾œòò_°ÕãalÜ—ÊÎ’5 ï=Þ‡±q[í¿\†/R‘h³¡E«6EJ¤Œvlß궇hͪ=vSd""" 8»ÝŽŸ~[¼ûi‹Ø¥¥Õ±ëˆˆˆ‚K‘"£Ñˆ#‡z¼Sµ7cˆˆˆˆˆ‚Ÿká£Ô«°qÑG¬""¢rDÇ*ðždMÇ·S‡ãÂñ8èMô¼ã V Q9À"/ÉN'~œ~.Ï|ŠôʹÏâà¶•¬"""&DÇï³'âèε9ÿVU?͸çïdå1!*ÿþþáì\óM¾÷v¾}õN\»p’•DDDÄ„¨üÚý×Xÿí›?ÏHNÄ‚W†Áš–ÄÊ"""*O ‘Àzß³K>_ètWÎÁ÷¯Ý‡]b¥•—„Èh2ÁjͨÐséÔ,|sÙáÕô§ã·â×™ðKDDDå!!µjE!.66«µ€›,úó(A”H¤^½€¯Ü)#ŧùömük¾|™­Šˆˆ¨Œq{" zëfˆ¢X":¦ô‡4eßk(%ñœËûµ›uF‘].ïÕlÔ—N*9ïmþõcDÔ¬Ï{•å„HUU\<Ÿ€~ƒC#hÜ>ÜÕÝO_Ýáéᮥ)f²…GÖÇo-Å;£ê¹¼ß°]_t¿ýqü>ëi—÷WÎ}áÕë eÏÛØÂˆˆˆÊ·]2¢$Ál¶T¸ÊÈ{¯!0…Fà¡·—#,¢†Ûyºßú(úz!ORÉ{•ù„¨"rw¯!­Î€ûßüÕë6/pÞž†vG¹¼Ç{1!*s´:}¾÷Fþç+4lÛ»ÐyAÀÝω†íúº¼o0…@vÚY¹DDDLˆÊ†þ£žÇ½S€Î` }tÚ éõü:½c__ŒêõZê¶ìŽ Ÿn.´w‰ˆˆˆJŸvŸKÛ~w!¼F]ܶýîyÎçùÍaáxpúïØ¸ø#Ü2~&ô#+•ˆˆˆ QÙS·E7ÔmÑ­ÈóGÔ¬ag±"‰ˆˆÊž2#""¢ ¯Ø=D²,»Ü‡H„BïC 7`$"""òKB$IZ·mïÓsÊ2ÚuèƒÁ€Ñ[‚¾·(-é2R¯žD6h Þ4±]<¹ª"«gÂeûúkµZLúß® ÝDDT¢ìdH«ÕÂh4bOìN—Óe¢(¡K·îeÝzôÆöm›K=)’e»×-DìÚïpáÄ>ÈN;ªÔj„NCÆ zÝæ9ÓÕnæùtÙ‘ë³ú+œŽßkêU˜B*£nËîè;r µëëvžèåó°|Î$ÀßÀÀû^tùüÐö5øîÕ;]n~#¦|îòy‘ë§jªÕn‚¿Î@ü¦e¸zþ8QMÚ£ß=Ï¡E÷›=Æ»ŒÂNÝõv®ùgF#íÚ%èfD6h…î·=ŽŽ7ÜW¬mp$f-b²ÊÎH¾½É‚Ððˆj܇ŽC³.CŠû¶å_`ÅœÉë¹8qƒhMÃâ÷ÂÁm+¡5pïԟаmoiˆˆÊsBdµZÑ¡cgX,ÄîÜEQòMc4°wO,DIB·î=ѽgDoÝTjI‘5- ?¼yNîÝäòþåÓðÇüW\Þs×`møí£ñØ»a‘k¹©WqxûjÞ¾#ÿóµÛ„¡°ÁÚ…}~îÈõ^‹>Ì÷ù©}›qjßfËÏ[†§Ñš†%<†øÍË\Þ—¬œ93¢qõüqÜðÀ«>׿dMÇâ÷Á-¿»¾Ÿ‘)#WŽ¢Q‡þEŽ=3i)|ÐsQãðÕsGñýëw#ñìa@æ]0æõE¨\-ŠG"¢òœI’„v:Áh4b÷®˜œg’yb4°}ÛtéÖ=zõÅŽè-%¾²N‡ _¿§ög.;$¼:Úôsh8ŽíþçŸ&DÍ\ÿè*Š‚Ÿß‹CÑ«•ªF¡M¿0Z*áHÌZ$Ù X>g2Zô¸æÐÊyž‚ã6˜;÷ç`‹@ë>ÃV¥ïøç³ªU_¼€6}G@o4¼ 7É‚ìtâû×îÂɽá5ê¡iç^gmÇñÝÿþýù}ô¸c‚OãsdYÆÂ7Gæ”a ©Œ6}†#¼F]¤''âòé8¿-_½{»ûzìä×8λ¬}xÇøùq2R]†>ˆÛŸž½ÁÈ# QyOˆd9sEÞ1C®O/Ër‰÷m[6''ªÛ²;œ±<'iòàøåݱ÷Ÿ_¸P½cÕüœd¨Qûþ¸Úo0šCƒïŸŠySàìÁ¬©8ºkÚõ¿;g^‡]ÂåBã4˜;÷`^hÞífÜóßo`  ó2fOè†Ë§Àšzgí@£öý<–á)†­Kgç$C‡ŒÅðIs]þ°ÿøÖ}Ø¿é7ÈN;ÎŒFËž·ùPÿss’Z;àÁ·—#,¢†Ë4¶ôL!ùæõv0³7Ó5޼e‡†WÆŸfbí7¯P¡ÑêpÛ“¡ÇíóÈBDTÆ)#‘$ mÛuÈ3´ÛûÁ«FƒÑ[7Ãn·£gï~%Ü;dÇ¿¿|™L¸wê.=8‚  ç×o˜w@µÓáÀß §ôF F½ô]N2múŽÈù÷•sG]–ñÄ^(²PÇMïFaƒ¹sæ­Õc^ÿ%'­N‡æÝ†æü;éÒé|Ë(l@pî: ¯QwNþ,_/GãNƒr~OONô©þ7üô^f¬z#Ƽþs¾$Ì¡•¡Õé|ŽÝ—u,j¹Ë®^·9~œ>k¿y €ŠÐˆH<öÁ:&CDD­‡¨¬9¼c ¬©WíŽBxõ:ù=[ZÎïyTÞ±éI—3ç4 aU"óÍo0‡æú—ë)D×ûâ¸;ëqÙ™½G×çï4dŒÛ«ß´:C®M[`îNÉ宣F ùò™|Ó$]¯Ó¬‹Ûå§$žÍù=<²žÏËÈ]G±k¿CìÚï ¬ÓˆHã±çüÞº÷>o?oï<]Øtʼn#wÙÙ: ¾#žT·g ""ßU˜Gwœ?w=¡hÞÕý4 j>lÏõÏ< úÍý3ªqû<ŸíΕÐtö¹g#÷•Sžî¼|îpæ nAи½¡dae䮣 ¨Q¿¥_ë¿ÀdÄ‹õ÷u}#wÙÙÒ®]‚F«ã‘„ˆ¨Œ+ò‘Üep´àý¨å¬q4:¶DW4{|Ž Ñº=Ý•;¡Ðhõ¨Ù¨ëü‰ 9¿WªšÿÔˆdËÀɸÌÁÈ!áÕQ³Ñõ„Dv:qéTæ`ÜJÕjÃR©ŠË¼Š¢àÌÁhËÎ=˜·RµÚn¯ìºrîèõK¾[tÉw…›»ÁùêèJæ:Z*UÁ°gfXŸz£–°¯ë?åòÙœõóTÿžx»·Ó5ŽÜeëM!©TÉ—Ïàøî¿±nÁ¸éái<šU´„Èh4bßÞ=hÕº-:t쌽{b½šO’ìèÑ«/ ¶nÞXè¥úþ”=¦FU8ìR¾Á‡wü‰”ÄsÜjr]ç­0ZB]>Y=É è|Ó8¹’ÄäK§¡È@•Z óŶcå—ÈÈ \Ø€jSHe·ë—=:sùæûÜ›AÉBVÌahÛﮀlUU ˲OW'úk@uqâÈ]vÓNƒÑô ˜7eÙž‰º-ºz<KDDÁ¯X§Ìr÷sïT«Ó4ûO!öo\âòÙ‰¸øåq9ÿv7¨¹jí&9¿ïË3ÿéøh¬[ðffÂ>wMrMÅô\= 6—Ïvþ± çîÕž–ûtÚåÓprßf×dlÍ7Øõç·™ WTct2¶À2< JξKwò¥Ó8–k¬Mnéɉ9=i¾¨Õ(+!•¿yi¾ÏÓ®]òxÊÎ_ª‹Gî²£švDÝ]që„÷sÞ[<ó\I8Æ# QEê!2{‰öî‰E»бsל;UëÜ\2-Ë2DQD÷ž}`±˜±m˦í€Ö}îÄÑëK>“{7"4¢&ÎŽÁ±Ø¿\¦u׻ЮÿHœØ³°lÖS8µ ""ëáòéCØ¿yiVï€Ï~ŽÐðê.ó†EÔÌõ‡u¾9 ‘ ZãÄžp:~[¡ËÎ;˜÷ëÿÞ‚öƒF#¼F]œÚ·'âþÍLPuÜóŸ¯ÝðõfPr§!cptçZÀ‚Wî@‹î· f£¶É—Ï"áH,.žÜ‡ƽŽ:Í»øTÿmûßSY‰Ü¢wÄÁ­+Q­N¤']Æ¥Sñ8¿ wLœ•oì•·±{;]QãpÔž9¬çOàôþ­Ø»a$k*~˜6fm„Ádá‘…ˆ¨¢$DÙIўݻСcg´nÛÞóÌDtéÖ`±X½µä“¡Ì?ö÷c÷ºïq:~Ù,ð8­»Þ…Î7ÃÞãÄž Pdg¾+°ôF F<÷ÚôžoÞ°*‘hÜqŽïÎìu9°å÷œGFè–œSmž–{@vHåjÈH¹’oùsî}e!êµêî!Yȇå¼Ú…#;×a÷º…Pd'l]Ž[—ç›®Nw‰ö¤ëÍ™É8¾û(²qÿüìU½{»·Ó5Oeß9ås\8‡Ä³‡qéä~,ýäIŒzq,DDeL±¯2Ë~t‡V«…ÓéDËÖmѪM;´nÛmÚu@—n= Õja±X°}ÛæÒËüôz<ôÎ*ôù,*ר VЈhÓwÆüOÎ@iV‡H7Whiu:<8c9n|ø-D6lÁ ÁŒõZ¢ÏÝ“ñì×ûÐ~À=—ï+ Ñõæ‡ VˆZ Ñ{Ä3˜<*U«íqÙ.w¸®^Ï~Ÿ³Z5 ç°'1å«84ïv“Ûeç-£ ÇmŒ|a>î{õ'4ë6!áÕ¡Ñê` Gõz-Ð~àh {f6´íS¤ú7}9nðj7ëƒ9,k`sM4ê0ƒÆ¾’o0¹/±{;]Qâ(¨l£9÷½úôÆÌ^¡¸¿ÆÖeŸñÈBDTÆW¯$ºt×(Š‚u®Á°wCEˆ¢ Š¢döø( ?UU…Í&¢K·îù¦˜íÛ²zŒ—Þ£ì4jÔkV­Àè±ã¸Uˆˆˆ(àìv;~^ø-;éß3Œßç1é!""" FV1!""""bBDDDDÄ„ˆˆˆˆˆ Q^ë…ˆˆˆ*zBd4™`µf°vˆˆˆ¨b&D‚  V­(ÄÅÆÂfµº½„Þÿ/@á¥ùDDDTJÜÞ‡HˆÞº¢(–H ‡ÄC£á&""" ‚„HUU\<Ÿ€~ƒC#h|ºSuöÃ]=÷~§j"""¢’æ¶KF”$˜Í|b7Uà„ˆˆˆˆˆ """""&DDDDDLˆˆˆˆˆ* ¿ ”e9ßeõ¼¿Uˆ„H–eØl6téÖÃå}£Á€˜ÑY‰Ÿ’FDDDå4!²Z­èعkfºÌ"N'@²ÛÑ®C' ìˆÞÂÞ"""" :ÅÎN²“!N‡ÐÐP8¤¥¥å›În·£[Þe™µNDDDå'!²Z­èбs‰PÞ¤¨{Ï>LŠˆˆˆ¨|$D’$¡]‡N0™L…&By“¢½ú²æ‰ˆˆ¨ì'DÙ½Š:?jIDAT<Ùc†Š:?Q™Lˆ$IBÛv|îÊf·Ûѳw?Ö>•Ý„ˆˆˆˆˆ """""&DÐjµ®ß€ÑW:–µODDDe7!2Ø·wDQDXX˜Ïó lݼ‘µODDDe7!ÊVÔ^"öQ¹HˆŒF#öÃá@XXœN§W‰‘Åbƶ-›XóDDDTö¢ì¤hÏî]p8Ðëõ…&F‹Ñ[7³Ö‰ˆˆ¨ü$DÙIÑî]1Ðjµ.‰QnZ­‹Û·1"""¢à£óG!F£ñûâ`³‰èÒ­{¾Ïb¶oƒªªPU…5NDDDå3!ºžüp0~_Vòãú"""" V¼1#1!b"""""&DDDDDLˆòX/DDDTÑ"£É«5ƒµCDDD3!µjE!.66«Õí%ôþ /Í'""¢Râö>D*@ôÖÍE±D9t  ‡4Q$Dªªââùô4AQ´AQ”ÌžEâ᧪ªP:®€ž ÅãM5j‚5«Vp‹Q‰sÛ%#JÌf k‡ˆˆˆ*nBDDDDÄ„ˆˆˆˆˆ """""&DDDDDLˆˆˆˆˆ˜U ºâÌì”åœ6fߘQ¯nÌÈ»RQ™Oˆ$IB«Ömsþ­Õjs~—e¹À÷ vDoaíQÙNˆr³X,ˆÝ¹Š¢@–e´mß`4±{W TU…(IèÖ½§K²DDDD Š}Þ*;é)t:ƒÛ·±WˆˆˆˆÊYB¤Õj]N‰JÈœG§Ó²æ‰ˆˆ(hù”™ÑhÄáƒñ9O»÷jƒ»wípyÊ=Qiã¥^DDDÄ„ˆU@DDDLˆˆˆˆˆ˜1!""""bBDDDDT‘éüU,Ë9wª¾N…œý¼3U…F#°Æ‰ˆˆ¨|&D’$¡cç®9ÿξY£Ó)£C§.2ï[´}ÛfÖ8•Ï„Èh4"~_EN§+ði÷DDDDÁ†cˆˆˆˆˆ «€ˆˆˆ˜1!""""bBDDDDÄ„ˆˆˆˆˆ Q¼}"Uø„Èh2ÁjÍ`íQÅLˆA@­¨ÚˆÛ½6«µ€›,úó(ªÊ­ADDD¥Bç.!jܤ)Ž;Šè­›!Šb‰rè@<4i"""¢ Hˆ€Ìg‘5kÞÍš·(±@EÁú?×p‹Q‰c— 1!b"""""&DDDDDLˆˆˆˆˆ˜1!""""bBDDDDÄ„ˆˆˆˆˆ """""&DDDDDLˆˆˆˆˆ˜1!""""bBDDDDÄ„ˆˆˆˆˆ """""&DDDDDLˆˆˆˆˆ˜1!""""bBDDDDÄ„ˆˆˆˆˆ """""&DDDDDÃÿ¶“r™á'~~IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/focus.jpg0000644000175000017500000000762213070106167016447 00000000000000ÿØÿàJFIFHHÿí Photoshop 3.08BIMíHH8BIMó8BIM 8BIM' 8BIMô5-8BIM÷ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿè8BIM@@8BIM 3€D€fÿØÿàJFIFHHÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛ„            ÿÀD€"ÿÝÿÄ?   3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷5!1AQaq"2‘¡±B#ÁRÑð3$bár‚’CScs4ñ%¢²ƒ&5ÂÒD“T£dEU6teâò³„ÃÓuãóF”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö'7GWgw‡—§·ÇÿÚ ?õD•/K­ÿܬ_ý‡³ÿ{T_G\peã4‚ ý™ç@un¹ŸôRS}%KÒë÷+ÿaìÿÞÔ½.·ÿr±öÏýíIMÔ–f^YÉ¡Ô;3ŧsqìm!ÿ÷3ù(¾—Z?ö«ÿaìÿÞÄ”ÞIRôºßýÊÅÿØ{?÷µEôuÇ6—ŒÓ¦¿fyàùæ$¦úJ£ÖÿîV/þÃYÿ½©ý.·ÿr±öÏýíIMÔ•OZ µbë§ô{?÷µ­cãUŽ31Þ)ckv;ËŽÑ·s¿\úI)ÒIRôºßýÊÅÿØ{?÷µ1§­‘¦V(>?f³ÿ{RSy%A´õÀÐ^3ˆ]ög‰>:f)z]oþåbÿì=ŸûÚ’ŸÿÐõD’I%)$’INÖnŸÒ2YNGWm™4PKiéì2Ûî°EcìíÚëòµÞ¿Ó«ô–Ùþ’»?W0rúGÇÄÌy}µî€\^XÇ=Ï£Úïu¿f¥Ì£ÕüÿMVúˉõ^Ó‘õ‚æcš‹ÛcòlÆ‚à=PÇSuç1¿æ-.™‹…‰ƒU$œXßQu´óênõ¯}¶¿vÿô‰)´’I$¥$’I)I!ädÑ‹Cò2lm4T7YkÈkZç=Îú(x=G¨ÓöŒ в©-6Rðöî·s ÷{’Sa$’IJI$’SÿÑõD’I%)$’INÖ¯ª=?ëN=ÙöÝS1Þla ´HÙîõkµ[鱘M¯!Çeb¬BêÈsEcÑÝéOô?1˜ËEsYÅ_±(¾ö}—©Ñ{_ÒÙPç(9ßgǨ4?s2šßÖ›ÿqý_Q%;ŹޕmÔ-i›é8‡Ý®¿_u?Ú²Õ8ÉÆÖz°Êöáß¼ë}M¯oò=Ì}_ê8];¥Ù›mY9]G+%ÿµ[EºÖe}+(¶ºê3†í¯w³Ñôÿ}gýiêdõ›,Ƨ.çôF±ØŸg¢Ë˜ì¢êó2+ºÚc(wÙ^½Þ§ëwƒIOg[:ˆªÆÙ‘S®?Í=´¹­oõë9uŸöíJ[s"˜º¹l}£ôGßÇó_¦ýöýu…Ö~´»¨búY8F¸¥Žpie®o­UöÚ×=¿cØïÖßÿiÿõU;ú—[Ç·©³ª_“Nn=YyÐ^÷°áÓ}¹#_]™Vµÿ£e5]êý›ý3Ø’î¯Óoê}?7ëZqó+ôšÆ4Öö‡{lw®ç^Ç»oÐý]CêÏÕ¼/«]8ôì-¶“k­Ýqit¸5¤~•·o³÷Pñ3©êdf]]Ì'e¶ã42Á_ó7WÝíý6;÷ú?CÔ[#ºJ]$’IJI$’SÿÒõD’I%)$’IJYØý7ó‹—s¾Ù~!°ãä9Î0^\×¹¬ÜkõßÑzŸMe}yú¡Ö¬Llj²ÆDZÖ–—Ì·fßkë[X3œ|F[]v߇S*®òѸmh­Î­Î—×½%3§§aQ™~u5†d匇‚aûÚÜúçÓõßo©³ÔRÅÃÅÃc«Æ`­¶Xû\$™}Ž6Zò\]ôÞä†P?ÒÆþ“þ;OÒý/ÏLz~ eL8Õc™¡»‘Þ‘·ô_ØIMÍÏyquLn=6zÅþ³le5²¯Q¶+§Þ2ML9 hÞ5¶Fý¾åÓ°VR1ª\w[Xcv½ß½k6í±ß×IH+éôtÎö^•ŽÆµ†YI$‚\íö½ï±ÛÞý\ýïz¼_^èÝ[¤_ÓÚʪ±ôºœkaÞŒˆš¾ŽÍ±þ Vú™õjß«]!Ý:Ü‘–ç\û½PÒߤÝ»\ë?q%;É$’JRI$’ŸÿÓõD—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ê”—ÊÉ$§ÿÙ8BIMÿþ'File written by Adobe Photoshop¨ 4.0ÿîAdobed€ÿÛC     ÿÀ DÿÝÿÄ¢  3!1AQa"q2‘¡±B#$RÁb34r‚ÑC%’Sðáñcs5¢²ƒ&D“TdE£t6ÒUâeò³„ÃÓuãóF'”¤…´•ÄÔäô¥µÅÕåõVfv†–¦¶ÆÖæö7GWgw‡—§·Ç×ç÷ÿÚ?ïÒI$’I$’I$’I%ÿÐí=>­ÿr1ÿí‡ÿïr‹©êäÊÇn ÏÙÞtVëùê^ŸVÿ¹ÿöÃÿ÷¹/O«ÜŒûaÿû܃“‰Õ2)u.Ê¡¡Ä͡ॶÜïä¢ú}TÿÚŒûaÿûÜŸÓêß÷#þØþ÷(ºž®D ¬v5û;ÏýVrK«ÜŒûaÿûÜŸÓêß÷#þØþ÷!dbu\Š,¡ÙT0ZÒÒæÐðá#næ~¼‹éõoû‘ÿl?ÿ{’ôú·ýÈÇÿ¶ÿ½Ê.§«¹¤7+¤ðáŽóçg)z}[þäcÿÛÿÞä½>­ÿr1ÿí‡ÿïrÿÑïÒI%‘×°úmíªî¤,¾ª‰mXl2.µþÚÛövm}ù ÛúÒzu~’Û?Ò+'¦S’âë»Bíå.sèÆõüïÙ©s(õô’I$’I$—ÿÒïÒI%“×1º †‹ºÍ¨×¹´=÷¾\«±ÔÝGæ«Øø¸ØµÕ‡'7VKÝd‡ŸWw­{í±û·þú°’I åeâáÔo˵”RËÙ?GÜå,|Š2©møÖ6ê_ô,ak íö½¨‰$’ÿÓïÒI%“×þ®áõú©§.Ë+m./i¨´HÛîõYj?OkÛŠÖQ{_CX+Å&²ÑXô7_ú_Ö>‡ø6c#–æzlhº¿Q§ô®ô‰»]_hÝOý¹r—éÅÄ›è‘ ¯aÞûλÕÚÿêz 3½ß^¿^œô²?wÐûNýßËõÔâÿU®7Ñ͇qwï6ïWmÔôVWéêø/ÀÌ´¬µŽš‡¤æ1§øS˜ÛlþÅJßJéÔô®ŸNsê ×> Žç:ßvƱ¿ž­¤’KÿÔïÒI$—?×…²jºæ}Ÿ¨Uhvk»í;ö|zšÝû™”Öþ²Ïô¢FÍÅÂÀ~Së¿#;"÷þÑRëmfGÒ²‹k¥›ëÇ¡¿£Åÿé*}2ÌŽ¦û(«"Çt¦°ãú5>Ö;$š³2kºÜvØÚ?Tex~ÿÒ~³oø5¡•ׯnN5Ƨ×Õ[ðít~ƒyk-ûSý·nßú§¾Ÿ['õETõ>§U%ØlªšVkrmeâßNßN«ß‡Uõ^ÿ[Þü¼š}_Oý¦¶Û}X˜Y=®õ_[ëu$º·XC¶l{ØÇú?×b¾8N’I/ÿÕïÒI$•0q-û6M®ûUØåþ…î$Áqs^æ×½ÕúŸà½Dj°±)Ê».¦l¿ 4\àL?g¶·>½Þ—©·ü&ÏQKŽe kÞë©2û©k÷;wÓ{•ZúI®«if;C.à—£Ìôžçú”zw?Õ«Ðôý+IZWô.“‘O£n8s¸ç5ÂËNü‡‹˜öÝúgÿ9úDo@bÓ‡K5¹¬ÙÀe`}:ÿ”Åhp’I$¿ÿÖïÒI%ƒõ«êå¿X(Ǧ¼è=Ï$´ºdlü×1jctú*§¶1–]‹[keÅ£pÚÑ[Sï¯z ÃÄÐ(¬ ÿžö7ôŸñþßÓ}/ð‰Žml4V[Iš[±±Yýê[·ô_ØR¸âÇÜ*`¶Á¶Ë6ÎoîXøÜö¨}ƒÑÿg«Ðp«cv~ø«nÍË?ëÕúúÖ ¨ae.,Œ’ÍÏ iÝéï,ÿ¦¬ô>šî•Ò±ú{ì:€àlÜçÛôeß¾¯¤’Kÿ×ïÒI$’I$’I$’I%ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/fdup.png0000644000175000017500000005113213070106167016265 00000000000000‰PNG  IHDR"Ý ÎbKGDùC» IDATxÚìw|Åù‡ŸÙ½ªbÉU–Ü;¶l¹÷nÀ˜€M ½„n Ƙ ý‡é$@èBIè`ŠÁã‚{ï½Êê]×vw~ÜéÔNcËhžOˆuw;³3³³ß}ç™wÅýû¤&ºÍ†B¡Pk-^Œ-&&š¹Ë·“Ÿ_LÓ(I»V± %ÂÿJ)ƒ)Ê|Oèû’Ï.—YË ^¯§ÓUëÂÖ'ͱàh•«¡åS‚Ïç ^[ÙpÚêx×ãø^/.—ë˜×ã÷*—¦ vn߆ͦk,Ûí¥gž´hnÒ¯wRPpÊüg!+}WòÙ²,¢cbµ<¹Æ¡ƒILJªC5:HëĤuŽV¹Z>%ìß»‡n'õÄçõ6˜¶:Þõ¨“i‚#‡‘Ðú(]}{èÖãØ×ã÷*—®i|ÿýØDø«ß&±R–ZJ5+Ñ4´,„µLc!„V§4Ç‚£U®†–Oé]@®mC½†G³uÂ8º×CZ’†fÕ·\¡1¶ª„Âf·×˜IÀïÃãñ”fYÛB”ÚÕ¡Äu;Ç1S¢£T®†–OÙŽ"R~Õ”Mâ7g/ˆŠŠÂ[\Té±zTëQ±Üš ]h`ù1eÕߣóà;~÷Aµí[ÏrI¼î…Èf·Ó¥K&OžŒÛíÆãñTRs»ÝÎúuëøòË/Gkõ"‰†Ë¦°ðú*?=¤(—F¢UY>þ@½:”ÃáÄï÷ë]\Œ;* OqqÕO³ åªÿUþýó ÖÑÝÚÇŠìöôk@€_w0º{†¬RŒªÊ/::†E;×3ªk E…Øt_wç3¸cl­Ë¶dñ.ÆïßoÔxt» ?v»^jÈ AþÆŸyvÎ*†»œa½ãª¯‡ÐX²mc{ö&`J w/#«ý:ØÌû‡ÓáÀfw”=yëù÷ìUh-2eL爂Z¶Î¿î.`ÜIMxæÙ—p8‚|Ë´8oÚ´À¬ùÑ ËÞÁkPÑ@(ë&šÆÁ­;IêÞ¹Vb/!*·oÞ†<ûãFŒ¿Œ¡Éqõ.—œ®(lºI•Seçž{.O?ý4×_=¯½öZÄc:tè€Íf Vº.O›_©ìñšo~Ý–Øuó¹åÉ«).ôT›FÈ,}ô9öÒ*Øl…>n¿íf¤”ÄÄ”o¿ß_É%¥DÓm¤nYÌ—›ó¸ùÜÓ0$\wíu¼õöÛ\sõÕ¼õöÛÔº.õ3áM>K~]Æö5_ðsz'nšØ–ÝûŠøï†²%0eÊ èôÌU\[]×yþÅ—ùeç¶÷À ¾Ù¼;›o×ewñxºuéXcÙ„°ñõ·¯²es¼~ „ oJ #Gލt¢¢<÷à]œ6sm­¼üá6-|LÁ®Uí" £RyËÖCJILl «öíà”þC±K‹‚CkHïr2]to¹>R©üy?ÿü3«W¯ Uþ¼·ß¼iꈒ œrÖÒ:/üeÿüÏ<6:žqCY½µ0ø`ïI’nâ3d,"MÓxtÖ,Ž 0ê6Ëß’iÓ/@hv¢£˜¦ÅÖ/? êÚé׺-16”!Bב†²îtþü-¼üÑÏujßڔ놛.4~šý ›v{œ'µž³¿âŠ+hÚ´iøósÏ=W«§f5£ÊðñFÁÞ~æ%¼'ÅªÜ ôZ¶’ѽz‡×U¤‘Ä1óæ›Ê[rr=³)%º®óä“O⌊A˜~4»½Pã/Ó/ w0ÝfGóæòæ«oÛy·œ7 Ÿ<«Ëœåp¹\¡{ÈB×4̈cýÒrmþe1ÝN=· °äÇ 3 m¢±pÃzNé׿)X´u ’ûá7eÛ¶\y~ZIâá%ü\èÇï-dÕ×¢ÿå]ú5Ëb‚ãcLÍ”J=¿ä&¶<;Y™ÖžÁß.~Íé„mý|üÂÉŠ…™¤·*âž‹o#½U:±ûÞAvž^mÙìŽZ7ÀŒ[®CZ&B+掻_fĈá!»]àŠŠbÝü/ùlÞFfÜù±ºáìÎÍÓ{–¹éžoðM³i iR\¹/–©‡®ë<þø,Ú¾ž¨½iø IÁöŸI[£¡Hÿþý«íC‡eèСH =bCLL{L V÷@IyÖºsö•}‘¦Å//¸}ÚÍü냛@¬Ge-Ó4™9óæ{‘¯Þ|†¡Ó/|ø³7ðÏËú#û1–¯ÀévÓ»e[¢u‰¦Á²%{i[ü æ)×ЃŒ_Ó|ÀØbzpóô^åÚ·hÇ|Û|ƒc«oßêÊeY^œN;§5ÓBÂ÷Äc³j"M *â{ï½W+'t­‡eŽ·5éJ“¦çrÛÔKøþíýœÚ7…¢ŠÃ+QóÐeå¿¿`ÔU÷ ¥…aÜxã¤Ï{•¬ w²÷ýGèqõHi`yÒøÏçs˜q í9œYÀß®€7`–)ŸVâi 6¦|:o-—Lì|rWQ®¾ðÄóÐ#6•Q—߉4<µõö•ÉÇ$jöõD7{:»fd”zäS±ùaÌÿ>ÉdÒ`yªš| ÖÃ0 fÜ4ƒÂ¯þÅM\F¡ÏâÐgùdžs#}ufñ‘jûG —ƒÇî~ž;žy£È[ã½!iøñ›€`RóD^yåe4Q-{ð%ÔòŠt6.Àê4–DéE¶¸Ütc4ÝÎ?çäqö¤Ix,³ÝvüœQçžÃ“¬çÖ¿ô"u£ƒæ"´¯€ï>Éä´ûÁòVß¾5•káÂ…¬[·€ ‹×2pÂàê…Ȳ,fΜÉÏ?ÿŒÇã [ãÆ«à› à­åÔ!Àãñ i:ÖýÄ7çã|·ˆï¾9H‹Q¹tˆ×#¤¡4Z¥‹ì¶{ygƒàù ¼x¼¥B±eM!ý­Á7ü"e^¯@Zνè2œšBcÅ/sË•]–%ðçc^Cjäîü‘ÂáÝ)k=W,—× Céì* o-gJ*æÓï¢køà…7Y#<œuóux‹=õʧbyŠ q8ØN¼Y¶Ìý/¾œBþ«màœ¡^®aÀ0‚màõ‚× Y.e8s6çÑ'çS<›&þ꯳Q±!gùöåßñ¿ŸVsÒØÉø½^L`ÅŠ¬_¿ÎÏ[–Ñd¿Ÿa1`@’““/1I§ã‘m8?y Ù¾ãÀˆatÐÆN§Á2¯äÌ‚Èí[—rõíÛ—¾}û"€¿µE“«"MÓøä“O:th-}Ðu³ˆJ¦t ?붬cô(E}ÿNMMLKÖxa³ãÖ ¾ýò –mIcÖ£wRì-½.·›ŸE,c£ÚÑ£Mÿ„æB¼xË ½Ê–Ýa¤‚;O‘‰ÄåŽâ½çîdØ…w°ŒjËåÐóY&èìØB¦<•Ô}½‡”’€O#?ÊA\twq1f=\G‘Êãu>¶}Ã._3Fÿ©#q'’w0›Óœ9V¤'š þ/ôýùÓOáúñWqß—o`|4›t9Q›eò¸¾¬ ìfÒ§³ÉžN›â«í2dÊG5‹BÓmØu‹_~ù…f=ò:lN ‹ŠJ-èŠ~EMÃátqd×jî{áîyê1|†·jl… •’h—o>ý7ÍúõÂSP|ÎWÛ?4Òv.çÃÿ­ãæû!Zðà]÷qÏÓ y=UZ¨%âçÐ5„¦±÷jâš6£eË–4on§…Ö¬–~ÖòõpÚ%ï¾ö­R&rÇßNcõ‚/™½Tpæ°“1bcÇŽ™ÏvàÆég’_À0 L3híŒê×)lØão/0¸å{ØOUÒ¾©;Wñ—>ãž'­uûVW.+ä@§ð01Írñjšeeeáv»3fLÍíS‡uDeÿõ{ pu>•#{29µ¯À0e­Ä.ÓjÞYµ…IgLáÔ)Qø=Å¥N~4æÏùœ«¯¾šâjfÑ,ˤi³¦¥N6ÝÆÛ¯}ÃÃÞˆßë§ÿ¼ðÜsL8&Í£U.“(I¿bÁn¼ò,4K²lþ/´1¨N+´JÛÆd”}?ÆÄ[0,_½D(Ry†NJûØ5Œ.qÙ<úÆË K´óìÖ9Ü7ò&¼•ÆþåÀ²wbøi]ikyX’?Ÿ}6»\…œ3ål~|ð\ž;¤Sà‡ÍMŠ]ƒ¿ëÖ.cÃÆx=~νìVšGiûQ³æÍ1M³Üo[Ö¬fñªÕ´lŸÌߟ›Eq±§ê¶–•…,mýjþ·z3“ΜBRœ 3Ây+õòYêæ¯wLÅë+Ƌ΃ÞÂüï0jÜ*Ï\ ÓÆ%ðÔw‡øÇ gsáÿ¡ùxrŠ8x$½V3ϲŒ?V ˜ÿóbξòV\‡ß0è=úlh7¯^Å’ÕkiÙ>™gþñÅžªÛ·.å"àgÿš•ü°é 3¯½ˆ—^|Q˜—-þp-={t§[s‹á½“Ðu;3§žzŠU«VññÇ“žž^ÉYÝ¡CvîØbV5³Á"òù¼ØlöJìê°€]·Õ*MÉŒ@É¿Õg·ÛóERÊ Z‡žNº®!-Y˜Ô­\µ­Ÿf³óÚ›¯pÓ5×á3e½ó‰Ü.6ìšI@Ú±‹~S¢ÙXÊË&2ÒÓèÒ­ùy¹\ø/vu¹œ1I„Û×i³ã38íN| hj6'ÒôW[6)%‡M¿Ï_íMìp8ðûýåü‹ºÍ††YóbÁŠõ¨‹ —íÕõµÚ\‰DË’ÄÄÆ"C3‰BÓ(*(€ê‘™‘Nç.ÝÈùÊ"/Ì)ßï¥ n¥°*N´H BC׆aV©Ô­}ëR®à,Zp8/4Á;o¿SµEäv»BðÁTš!‹dÔwÖ¬î  d½-¯ª¨4¥o•ú˜LÓ:êåªM>†ßÇ´ënÀãóÕkEnuå‘Ò è‡ôS"VH@*MË–qBJ)i7áÚú}È2³_>#Ø~%"`¾Z•­dÝVMøýþJå3ˈCm,‰ú.¬ÍÖ¥ªó••ê\2³VXPPÕü|õmWS}#ô{˪â^%ÍXñ·:µoÊU6o-´¶¬J!Z¼x1I¡½`Ÿ|ò Qn1””’nݺ…¿“’ð¾³Úúˆj{|}Ó ŽV¹"åã™Ñu¹yŽz;UØShø¼µºaÜ5¬P­”}àsêñ{–«Ê•Õ¦a0wîÜH•à0¥Œº…œ‰‡ì!;;«¶¥¦u›6>pM×j&±MÕ%ͱ¹G§\ -Ÿ°CXçðþ½df¦7œ¶:Þõ¨c['µáðÁ£Sg]×9|`™™ Jˆê[.M„¦Um@­vßè~IKÄioS;Ô5-ßMë¶ýj¯ššÆ¢»iݦ_ƒºG«\ -Ÿ°C÷À^ZË$$­L[ïzԭ΂Å+÷’p´®Çþ½´¶Ú IlP÷AýË¥¡±[éüÅoÜr( ,³v‡Ú„ƒôC;iU‡pºn#ãÐ.ZµnXa@ŽV¹Z>%½âÈþí$µïDÀïÿÝÚ*±©“VqŽ£sã©9>ÒòüÕÖÃ’¥~“ßÑB×töíÜH|Ë£ ävm]K«6*ùÖ~ïXš&ÐÄïÐO„†@` &#»ºÈËÝFf±ÁZÿáÐT§ ·féߣ…þÖ„ºaY?*É¡C¬ÛiZH)¨ËpRˆàV¥64>jåjhù”\|Ë’G5¿H×=1ÞIŸ1Gíš IjŽ¿ÊzHiaenftJR­'#~ CÏîd•¼†Ÿ78tÌý\‹7¦"[$W1qòúIpß+6Ë’ŒØí[·Ðoàprs²±, 3´èÉ0MLÃÄfÓ1M3¸4ܲ°¬àߦi`Ái8)%Qz€xq„#Yåž„‰Í£É³· î-–‰¬r_^K¤ëA[MDHš¬ýmPÃñ¦%Ñ#È~uéD-ê¹,K>_}ò‘RRrw2×.ŸŠm[ÓSÝ’5çWrþš.@¤²IŽvhŽHç(­‡išø<ÅôèÙEíøqù.Ü–‰¦éAÑ Ý%ý·6ý¤ê¶’µ F €e÷hÆ,óŸR=+‚YH+¸ZX’M5–o…)ãÆ" ®Î|ò™tr.“'İñ€'ØU,Y¥iœÐÂM §Àžbû³Q>eIº¶b÷aO­«Üµm[÷E¼iLK2 {Öí,¨SºŠåª –%éÒ.–8'¬Ý]Xï|[Dc—¸ÜvŽÎ'Ã+ķlÛû8¨±¬–Yu~v—)ýâødQ[ͲfE(›<ÊF‰Œ0ì*[à„KdaoHA÷RÛOJÉ€nqˆ‹ÖY¾-M5ö“ª-¢j£ÕKJD‰óZÓ ˜ÁÝv5½S>Ž5I=¥%iegÍÞÒ Ð„À0-†ôhBÚÎÂjó‘RÒ,ÊÆš½ùèH†vŽegº{5ÖŒDbVea Mu¶¥yÃ^Q„§¦Eí×…ÕF(ª²ºJêaU±ÆJÁ7Ëž!«h;– }óaœÒÿúˆe([_NΦ-«üý!D¡{·y›XìÊ!Ý`wÒ¿5©Fõý¤6Q} åt:)..ªüT FTbˆÕ|÷öƒ\qÃxŠ ¸èêé|5gi™!‰ Y_VDË$ L0-€OHŒ€I@Ó0L3œf÷¾|âÝ›öæ£i‚I.VîÌÅáv08ц¿I4×d°i8í¦ÇË‘<öæãrhÁÕ­R2´K 7fï&ɲ0&wçá³tÆõr³lGq¥tå8hÖ¥ý÷).ç·J—ãXáaus^J M›Ç’™Z´ªÉDzÀÔ,ôPê€~©‰j­ #`F¼V“ûü êGÀ0h5ù%1Ìò×]"Ñ5믿·Û]õðÏ0xñÅkÕ.¦)+•×0,°JâUÙ0 :wèŠeYç"ŠÕ¿ßz‹¯¹žU«V±bùb~úßzNýó9\Õ!xõ³#L;/èœ^¾b9‡ÂÐÚrþYƒX¶tC‡À»g«2»1bP+„ü¼x9cGipBdY’€i‘蔬,6qØ4L16±†¿\ûÖC‡ê.D11ÑŒw2=x?ýú¦„o Ï& @Üw IÑ>f^u¿ª\@mצÛ&£²WÛ2-|2¸[@—ÃD×5,Ó §±‚^G¤”øý& Í$û‚V×îl?û³éÛµ =r)4Cw•´0M0 ®š.Ø„$/»ë¦B0 c ÙÅ&S n¬®Ül‚„€aâõÕm¶À0%†i„Óiº ¿?Pç|„ÃN'§ŸÅ©>l¢ú|, <¦Äãó‡qÅÞN{ÕÛü`û†YeO2-+¸E ËFÓ$¦)+\w‰Ïï¯2ø^},"˲*õ-Ó²ðøüÐÕPÁIýÕ’¿cZ&[,eH‹¾X¦ÉºÝ+ñú=8ìNÎzsø¾¹øò)Ì¿…¯¾x—^xi7ÀÆwV°iÙR~úö{ÈhÉûü‡óf¼Ë­ áãw÷°ø“·ˆ{u¸./ÎË¢]ü:Äà`ì¦!mM>œ½šK&÷oP•eYƒK" “ÓhV€€a–kߺéVõ‚ƪE(†ñN¡Il,cÇŒ&///ìù.kš—_;ƒŽ»Ð¹k7’}D"xLè©qø  ‰„@ÀÄ–¡#´#¬LKJLÀg˜Ø4·È`ýÞiŽ‘ÍzTÊÕÐò©44ûí¹i¡íBóÚ“V\åDêÃLO…s”¯‡)©äV¿xÜ=Á°|dä/Â0 út:‹‹ÆÞVáñ-Èܽ–¥©«˜6ãÞ{ï½à,™ˆç¢þP¼ã;6µ¼Œ€s„@¦ÎÇÿYÇÒuÑ\FWvÆ5 fåÛNóøIœsÁ8„ ûæi¾?`2©N‹¤´8k&ËÝãG»ŸØj¡QcÆáv¹ùáûoÉÍÍ­²ó[U—2¢ÕÙŒ³êiúýî^¼£T®†–O8»£˜_ÃÆÝiEìN+ú/Sù©ûª¬0òX³s ¦ së³"Øê&?m*dÖÝçñλáñ[˜VpÊxóÚm|=ùsËC¼ð¿¸æ‚KÉÈÕ; ¾ÉÁáÞŒÑݘ½h"w7©»æpë­_‡TÚÎyM²v[&ýO¾©ÁMÿËû¥’)ùû‰¬iúÞf·3zìxvîÜÉ_ヒG{¼Ü¦×!C‡gÍL)×»–YËWNë6šÆpRÏæµšÖ#ͱàh•«¡åSB³‚hRzµÀðû~{[i:Í‹cèq®aÙz˜¦Áþ-®ˆþ°©§?ÂÔÓ©æù¬qÑäàÔûU×ÝPåq3f$—û|RŸX’–ýO§oZNgò™§WJw$ý ýZ5á÷ß=V7›ºèг9š®Õ~"„Ʋ‘•™!¶lÜÀ€!CÉÎÊ Gr›5ëQìGøu¹‘„È4M~ƒa#G¡Pœ†Áüùó9õÔSUcÔ’ü‘ñãÇc³}Gzµ¯2 ƒ;ï¼#¸ÅÃ0Ðu=â…B¡øÍÖ²j…B¡„H¡P4zÂC³’7W(‰Ã‡“žž®¢ IHH8vBÔ*¡5K-Äf³#¥ 4.ÃWtVËð.zYí«VІLRRRø%Š`¥§¥2rÌ8òrsêÍïWB¤8Á|*ìPƒj¯°•¼£>Ñ,SÍž)N,Vîõ2ûùŸB‹Õ!„ }?c…)ë /6¨# £tMãðöåÇÆ"R(ÁšªÕ ‘M×yê©§±ÛíU®¬V(NÐG(|ÝgŠM3ïJ×€UîÅ "ô^{¾‚)±B¯çÖOTÇ”üýÕºz!²Ùéå\ˆ IDATxý7yüñÇñ–‰²øÓO?a·Û”)þQ݄ȴ$)]£Y¾9ŸÁ]âÈ* —¼VÚor¨Ðb|J<6¿à`—Œ\A !1ñÑ,O+Â& !ÞIjŽžíc¦Äë °'ËMƒÖñfû±52oz­†f÷ÜsO¹Ï>Ÿâ¢Õ“'¶ÕÕ"’’¤fN4SpÞÈÖ¤D‡BÒ:£]¬Ý–EËV.¶ì. }Ó(2òlN ¯Ä«Uëh9ÅH)ÑtÉú½DÇ8éßÆÍšCŤ{ GK;;2ïÊúý·à*‘¢‘ÌêgÊòq Ó‡Ç6—=<ܲéÁaXnžÎÉ4,»Ns?µÃ"ÚË”´´i¬ñ£™ ‚¡‡=E~‰ö`L¦b/±-bñ>ì Å*:û/”)%‰×¨ób\ÔL•ˆž_̪lIG{€ …î3ñ üV‹¶ø‰Ž¥c×h~NÏ£K§8r<^|Åšz‡ $`šøü¤¿eáõù1u Ãfâõú±l c–¦i¿»I¤„HÑH-¢z8«%tLˆ&;£€Ý¹’ÞIN„×ÂmI†öˆ#ã`î&Í›ÄÓ©u…~¦ oÅî,“ n6¤aÈÒó–¼Ò´,„©CéJŒdiÑp‚ƒ°¨õ"‡ÃAq‘êÌŠ›ú Íö¤Ò´iR䓞VÄØ¾­hí|¿ô †¤­Ôðxü¬N‡½»réÓ>ŽŽ-|±4‡]'.`â5$6!iï¤gÛXN{rÐ…Ä´$Å 4êþÖÔßÍ$:ÞBš ˆ²rÚõSUOVœøBT«ãpº—f1š¹u¬NÅâctmæ`gŽ>mÝ8,‹“£Øw$íi6†ôhʖݹ¬ÊôÓ£¥v óÄÇØBз{sv¥áG2rÑ '>»<ÎBäõxH=|#`„öš•nïðx<å¦ôŠNˆ¬úÝì‡2ƒáPs ‚k È/ô“ºi×í ß~~X¹3€œ"Ò\6²Š¼lÜ—_nاë‚8·ƒT_ùµI ah¦O!Bòó ªŒÐ¨PœÈ˜õšÕÅÚªŸ¿$P|®Ç@×zp7p¬ŒÚDÚ1œ¾W‘ˆ ¡éMõüšÛIüî"MÓRm¼Q4ãí{&–¦ú|­„¨©ãØQ«„–.Z„ÍfSÑxZ5Ñ9õÔAª!jÉœ9sŽ¥§a䘱å£%ñˆ ›Í10šaT`4…Bq4„¨úÀhAÇt¤Àh– Œ¦h¬H ¡‘BÉ—Ò¿%R „ üï€ýåìJG—Ì”ÿN†N]UN'ê- E´§Œ×V–ìX_N4„,ý„ðóÜ+Ÿ „ #-¸I\ú³)´ª¡‹Ö!„à“÷"---üŸ!{-ƒ¼ìGÏsh9»•‡|åËUE™e~9†­-@ll,¦iâõzðz}ªG*%B^yée4·‹(‡“?|ÎîSÏFbÒ»OŠ3¶Û*™õß~Á· 7òèðÄý÷rí}°õÝÑmê-äoZÉ[s—b 9»0}Ꟙ5ëV,ÚÈe£\|²×ÍœŸÿƒ”’‘£Çrñ•áÏž'õ™½¤5K!9e ]Ç0<6‘Õ‡Û0¸“Ï?z‰!gÞÀ—Ï=I‹nø<ìH3™u÷µ|ñúc ¹òo´±Ëˆ ”¶E$%ÑÑÑ<÷ü?IjÛžv:qö9ç±aãÆ­® ÅïIQ’‹S3·“£Ù~Æ…XÀû_Ò¿?FL¼˜œ¥ß3òOçÒ=ÞÏß_|›{y”wßü€ò4ì@“äAÜzó f̘Áô©BJÉ}÷ÝÏ×ÞÉ;«¶rÖ¸±Œ9’ÑcÆÒÍ•‰è=¸ÍšÆߢ mcñüá2Yk8"Ñ®‰†×gã’‹/âŠ+¯Â, .š¯˲p9uþûá 4‹íÊOŸü‡¯n¡o϶|ýõlbŠ7±!²ÚÆ„rñ³/­ì΄ @\þÈO\×'ž^ɽéÞ½;Ý»w'ÆôÁê–Àßo;‡^“'ãŒÉæòvç²vÍVl±æ<û —^:4dµùøâ«/ø¿ûî!yä°ðŽä´8}DBðàCsé%—pݵב‘I~~ýûõãçsùóùÑ¢E Õ+Oq1Å¡ÿàÌñäK¯¥§ ’ÚÇ‘.‹HÝ¿#{W“;„>MÀæ ŠÊgŸ}@b‚«ôv³2xü‘'蔳‹¢þwòÀƒ³zårV­\Æ’p-ñðÏïÓ˱ùÏyýõ7xûë,û¶°ÙC|؆ppîÙçòÀ¬'ØñËÊð9bͼOˆ\.¯¿þýëݕ̹¼¼|n˜v=³}LõFE£Ä,³œ%:ÊúÅ B`8º°øß¯³nû2Î<8í:Ü€ÝÊ£t‰ …Møëý÷ЦÏšY~˜y9ýöÃ!M.5iæ“ܳ1E…ŒtÓožAʱ HéCJß~ŒOò°±$·2#•l£4’ja\ô h•˜¡>_$c ŸÏ‡ÓéT=RÑèÈݽ’9zSÚĸiÒ¤ Mš4aò)V­^´HV¬^È;_ýÄåSoc@G7ßx/0¤Ïҳν–wßx•—_~™7Þù¡ï%Ãï§ØŸËÞ,?–¥Ñ¦cg~7›C~zt…ýûÙ¾yëöekRTœÇê݇è?ý6~|ñ.»ê,>ýüK¾üì3žyòÞI"1ºá Q•³f†aЫWO/^Br¯^å~Óu‹-æÁîS½RѨRòô=oVû{ç+/§s™Ï)/ ×ÉS ¶X®¼nZ¥´ÓÿvE¹ÏeG#inKßúgx9‘dÌÈSÈÍËš1¦w, àñgÿ‰Ûíà—%K˜HQQº®óØc³øúË/((P¯R(¿—ËUóÊj!YÙÙÜvë-á¿ß¯ZO¡P5³fji¢B¡8îB¤£)Šã… Œ¦P„(Ú½ÍnÇÕ¶-BˆJŸgžÊÞ+tm€-2„ñkÌãD˜ýúÍB¤£)3…Û·³÷‘G@×'žÀòxØýðà ]}”¨víÂÂòÑU7bŒÆWŸ®føð~tèæÂçóazÇp嵸þúëyíµ×x÷«ÿÒ2s ¯½“Ö÷=÷Ü«8v…9™œ}ó}tmA+Ø»–Ô˜dºµ°#<9¼õþ§]§ÝIƒ9ud /cÜÈ¡\‹HFS4j„ PTDRß¾l»å„®ÓºW/¯[WÉV1¤Aaa!‰Ó)ÈÏÏ'à÷ÜøZ²˜àÒqü䛯¡U‡h=0 )ÜrËL~÷=Z«‰t)µv^úx ÷ÜÝd7Üù*¯¼ø`ÐP8˜Àж’f¯âÒÉþPV‘ Œ¦P1ݺÑí©§8¸r%ÍÛµ£iëÖXµŠ“þùO\mÛV"Æî(Ñ11zߟŒ0ä²µÍé]c8°MxX–±g W\r+w§²lá< A!<øß§è}Å|7ëÜûâƒá× µjÛ¸; cçÞE¸¡YÍBT&0ZLLLФT(N`ª _# _a!ž¬,<99ø ±ÌÊïï;uÒ…ØívNÔƒì­_°Ó§ßLŒ|'Y™xˆÐ¹Ò¶#/®X:ŸÙKöñÞGÿá¦k¯bÆWqÃu×#€¯–sfë`Êím©èO ù©Òl¸kRçÀhç_x± Œ¦8ÁGa¢RÿÍß¼™\@tT‡¶n%uëV¢Ýn–M™BÑÞ½åŽ-..âúë¯g@·$¢m~.™zeÈþ ÒÆ¡“Uò ‚¼Íßó㑦H)<|<íãóyã7yþqÐÐiÙ48”‹ð9.;³+o.ÜQ@ÒÕˆ„(màà¡tìÔ9Ük×®ã’K/gçÎJŒ+IüÅŤîÜÉÐÏ?gÀûïsxË^o¥a& ^}ñ%¢OÇ%G2šJÂo\uV Oÿk9B@ÎÁ <õ}&—kÎÇŸq„K¯¸š™·]ÎßßüWë>œ{I_^_’”’æ#.§éޝyùõ7yûí·yãÝoÃé[$¥ýáÚßVÍcƒz˜[o½•»îº«ÒÏç]p1û÷î"==]õbÅ O\ÏžŒøßÿÐÜmÚ „`ä·ß¢9DuèPîØøþ}˜Öÿ<²×­â­õpU÷M¦u˶È&Ôª{jôìÙ“åË—Wé 6t¨ê„ …â÷¢î¿—©S§FTú”>}èׯ¯jA…Bñû ÀàAƒxàþ{BðôÓO—ŠPJ _}ù™ ¢P(Ž ¶š­%ÑxèafÜ4Ñ£GÑ7%EFSü!8|ø°šù­)%III$$$g!BFSü±IJJ"))I5DC𩥉 …⸠‘ Œ¦P(Ž*0šB¡h8B¤£)Šã.D*0šBQ;ªÚÊQ›0²@Äp¯ÕýÖ¨„H¡PÔ^„þù/Ò£•Ë iŸSøïúl.=’äQ,[¶!?|µŒ)Âç `Z3fÜÀ¯K1lø(Þ|éì1±4o›Ì™'øÃ†‚­ ¡Q¡¨Büq,K‡±§sûgsã72ùŠÛ¹âÒñôlÝ”+§žCN¡‡#èÎèšÒ‡?]p6‹?y w—‘Šì\qÅ• ï,xòÍ¥¡`[ˆ[5ÒÃá@×4 ÓÀ¦ÛÂC6˲Ò$//_õLE£³ˆþú׿ò¶ó=~Xô1±¾82¿¸Š˜Nص3ÀUz.E“'Ñéì[I²Ïáªë&²ôƒ¿óyÞî:ó/üš™Áí­‚Ã®@ ¸¯y§Aäì[  ûõó1P Q‰ò?øÐüóλ\?õ:,ø™mÛ·3õºkùaÎöíÛÏÎí[ÈÍÍU½SѨ,¢}[WóÓÏsÐFæƒ;¦’³HÒtÔõüç»çÑòt4Mçó—žDß½+þ²ØBo|ÄeG~¥Ã,]$üG [‹(ÔèwÞqW]y%Û¶oç¾{ÿÆ}÷þ•ö»¨^©h”ì-r3qÜDö9wñÎ[o’¶a>ñ›‡l~ÆF˜,°ü&BhR‘q ’Úp–>Ðÿˆ¡`ë-DRJ~ð ÓÄëñ”û-//=»¶“““£z¥¢Ñ ÍÆìÉæ~ÁÕ½Wq.Y 43•¾{­ÀâÝwÖqÁDä$,Ë‚Ø$VoÌ€?Á®&±á¼Ö®^¿þG^æa®žvOø5‹ÄP°õ·ˆ„Àç÷‡§î+üH~~~£›bT(„¼øÂó Ÿr1¹i xýõ×67Ö–×i‘<¨ö‚û/IÅ}ön঱=™ýËDÎ{veëÖmX¦Á ÝÉ”)Shfe3ð ö7 Í Eenš|A"½/àä“k—fpÇ^ %-ûN¤_zí[Maò”)•ŽKË8Dÿ–M8Ö¡`7µz¯™;ÊŽUëv»—¸µ E#0§hߪê° Ç!õ !D6»{ï½)%·Ì¼™;ﺛÅK–¨N¥P(ŽÝÐÌ0 îýÛ_Ñu½Ò…B¡86C3…B¡8VB¤£)Šã.Dš¦!-µ‹^¡¨-‘öƒ©×°×°¨C§Î,ÿuIð•¡€háÀh–…дòÑ, IIhÕøŠ?¦ÐT ËQöo!–n Ïð>áq…‚_|ŽŒ2îW)-F?Ÿ~½Ë«['ԨÀ¸\.ú\l\¿VõZÅ!S§N套^Ân·‡¿[ôÓ‡ì>l¢é ¿YȨ£°L?cο†ÎÑ’ oº%²À¢`Ï|¹;þr:¯<þ7bÛ%ƒ4vòE´µíåíùÛ¹ñÂ3¯E$„¨buÍXjH§8Á‡T‘,‘Ë/¿œÑ£G‡E¨„”Ö=Y¿kN›€Àëõ¢¹ºÑ9F°dÉV¯^ÌKÓ‚/´LÓdæÌ™<òÊ×Ü×møüQÜpÙ¥erîNï¢ÙlòŸI²£‘ ‘B¡, ÁŠ+˜5k<ð–e1uêÔJǽñÃ|œN'ÞÂ|r}>ü>ÂÜÆêUM1b#úö…èhö<÷­nyÃ+‰s®£Yú>À3ÎË«¯¿ABǾœ3qc®¾œGžžGòUÛ«é{…¢ŒE4xð`&MšÄèÑ£yöÙgË[OR"%Ü~ûítmi'ªm/ÆëÇM3foÒ`0†Ðÿ½ü6ž€A1°gî;ÌÝV @¡ö³vë;ŠiS¯ctÇ^útmÈzJ Ê·µÑµ½"…¢ŒE$¥ä†n`öìÙ´jÕª¼ÏT0SyýQ¼z'W]x3o¿‘Ó†žÂéÓï ù;¦}·a¡ãƒ~¡~g\ÍŠÙ¯ G „@ÁþÃÁèM[$R•Ìß»_Ò¸F×öjh¦PD£SN9%Âì•DØ™0¢3ïÏûß'Ÿbú¼Ì^ôèaM>ŸN1=¸òìÖ|þò üºh+OÞLyíŸ&b+†B ÈÝ·–UËó°ñÜ3-8{ïÅyÜrÇ]¯Ý³23~óÜûæ5v¼êÅŠ‚@ Àüùó™8qb½ÒçÕ¤Ü.(XÀ^åt02£ÅGÿ@‹8øqî¼p†aðìÃ3™»©“‡%C›¾Ÿ3g&Lø]6¼?ñØ,e)u¥¬•XQAì>Wü¤\ráéH)™8éôrb†œ<¼d¥QãBùˆŠc<ô«(På?7Î`ƒJˆ …"…B¡PB¤P(”)Ç›êvÌ×j7}™cÔöïú¡fÍ!‡R‘“ "ølH'ݺö(¿ž(ÒÛ…`Ëê¤Û›Ò£¶êÜ[fšˆ¸éü·îÆE@ ‘BÑ9’z˜ý’›Ïï%7'—¶mÛ±uÛfNêÑ«œèÚ·™¬<£ô+›Nêª=ñHéÁóÏ?_)ÿñãÇ“’’€é)ÂrEcðÞÿÍâ@t ÷Ý|£Ç‚ïßbãNOX@â’ñ— ë˜ò÷¬%-6ïîUüº~3Â28ã‚+HŒw²`ÑRÆ®,"…¢!0¦I à휇 à°ÙË QHÊ Ù Ég™ó˜zÖH²³³yøá‡Ë¥¹ûî»ÃBôÕãÏðçÿ{€˜fn¢£]áݸI×0®¢àyR_ÁþÍ›hß« xù“¥Üsw?žøÇÏÜóØÝL»å!^}î!†¶×øàë\6ePƒ[,©„H¡á÷°,ÌŸ7ŸøøxºvïBzjf¥cÛvL¦m™¾¦ƒzuŠZ P)®ëá¿×´íÄŸCO:%…Ã]O`É’¥á"v‡€?˜Ïˆ#8p`¹Q¡,Jç¹—ßãÂïàÀ7OÑçÊàÖ­ŒÐ´Ši€»ýPv~õOƒ•E¤P4X‹(àGhóæÎ£MÛ¶´nÙšÃb5z˜Ù«Ée|>˜’ß;æä…%,ú¤ÑÌ}ò#ºÝuq0„Ȉ¼ñÄL»çÜ É÷_ÎÞÙ|·'†¯Ÿº3d™ ¾þµ˜›&"?Ÿ}ñE¹Yô™RšAZÛRB¤PMh¸£Ü4kF»víØ²m31ѱ5øfŠ™qïxñ•§j<‡‚Í_}îArwŸËÁï>#ú¬Ë8´ÁC‡”¾L8 vñÌ—Û¹ã/§sÉæOŸƒ´,Æ]øZæmçíùÛ¹ñÂ3•E¤PüщdmXÒÂ0 ü~R³!½ˆ3±ë} ôŸ6µdÜz+.j7Ÿ;¯dý’¯¸ãöéz0ó°`¿—]¹NoæÄ4]C iÛ€G^ùšûïº-hAËe—]Všw«îô.šÍ&ÿ™$;×5QÎj…°,38tÒìˆaàIvºe,¡U4t:cr‰‚!4æ®tã^ùGœ­øèWxëí7y÷“ sÀ¤¡ƒ)ðV¢‰`ŽfAø»5«å£>âý÷ßÇ ‰ã˜«/ç‹çç5ºöWB¤P–%Ñmv\Þ§OJ+²wí#¯Ç%tI>FBãŽa¹îx¡›ôî|2};N¡u÷é|=gÉSÎG;½ñ$9 H÷ì ÐŠ U2t —\r —_~9zp“@”o«š)Sˆ, o1®øX¼ÑíÙ׎¦Gcde•é¤ábÛÚ\ùš1 ‰—o¾xŸE˨ӯcùòåìò¬þåGÖlÚDúû9Œ;m2Ư‹“’Œ]PºAֲʌCÿç]‰/iœ"…¢1"4­›Ö‘ÇI¸;dРVDE¹Y´hA™ƒiè£ûqf¯M8·oÍÆ/bøfÅlQ66‰ÛåâÖ'_eÐ oð—‡ocþß–]H.à°b(b€&-|ùå—AgõŸÿL3à½çqËw5¾öÏÊÌøÍo@Ù¼q£ÆŽW½YqB`óæÍcâĉáïü~?+W¯ÄÂoØ@J:tìDÇÃ3I™µA‘Þèþ©Ìz"Jä|ôñ´ˆƒçÎ+W¦gžÉÜM…œ<,¹ÁÅ•ž3g&LÀf;ú¶ËÍR‘Bàp81lDMÏíò «‹È︆ë¸äÂÓ‘R2qÒéå„ !8yxU¡òÿØ(gµBq,‡ ªìçÆ¹[ ‘B¡PB¤P(Jˆ …"…B¡PB¤PÔ)«ùIþΧ–‘ÏSÕ÷'jú^¡¨ Bpäð>2³ *þ@ïÞÉÕŠHÅ™2)ehAuùï—.]ÊðáÃ#¦O;’JBëD6®[‡ÃíFJIÇ=ÈJM#)1A ‘BÑ8 "I뤴N*ÿý¯ËVV)>E9ÙD7-ÿ^´@QöèX$`ù‹ÑQ¥7e™Eƒ%y!HݵgÒI¡¡ŒîÝ»—E«XÁ޽étëвÁ-†TC3…â¨D‘oraÓ"›ºG ËïÆß±v Òwˆy&(>¸¯ÜïiiilÚ¸‰©åΗáõÐÌ]y(%ØbZ‘W~BвˆŠ£a%ùsq:ãß‹ r9x(Ó´°â:лmt¹ãócl8šuCß¼âÚ‘F±e~OHH ¹w2ÅùYlÞ´ [| º·IÀî+Ù&"ÈÌHc×. Ó¥KÇ`BωۆJˆŠz ÏJ,Ã[Èò5»1|`é0ÃE“‚o‚Ýx¨ˆ²«¥¥” ìÚ )¡S¯ŽìÛ±™ÎÝzUÊ *¶½’›‡¿×±Ây5kÞ’.]º”KgaWB¤P4¦áÙm[(°$º=ŠÃ–'w™8ÖÈC;izð ¹ùE$µï /R*VVIx ì|‡½’X…ÇfBgÌ÷÷IDATàŠ*VB¤P4&‹¨]ž¥"@Õ¾£-\•ÓcѤEIígÓ† 1¯Þ‰MÙ›šCÇÖñ¤ L)«ndÜE˶É'là}%D E=,¢²"P±.=Bz1nª°ò‡«y[Zx<Ïݼ5n·uÓ¬"…âÄ?bÜºÝÑ'tíÔô½B¡PB¤P(Jˆ ÅqGùˆšÃ‡“žž®¢ IHøý÷°)!R4j’’’HJJR ¡†f …B ‘B¡P(!R(JˆŠFΉÙð‚rV+¥ð”ÝZ!„à?sŸ"®I\É7%Gжi }º–FL,ybÙ·¹–ý·,¦i†Ó481÷‚)!R(Ž2‘„ ¹Ã(„ÐR²mÿJâ¢Z’Ô²S0"c‹ee `÷mtn׃#kWҺߠð¯ééédgg#¥¤U‹h²ó¤ÞMÛ¤N´lÛ™X—FÚ‘TZƹٶˉ-ª)ZØÉ1chmktb¥†f лËÿ·wæÑQUyÿÜ÷ª’JRaËŽ)HÈF@¶ B«¸;â8§Ç»mµ[»{hN«3£ÝêÌØ-££c«sŽÓ2£àqœc÷q¥âQAŒÈ&Ùˆ ’P©ìImï½;TR©llIS÷óO^ªÞ»©Üz÷û~¿û»¿ß]LqNmÝMäåç´3yb*Źe$Oʈ”1Ìî&š ªkj8ìöP]]Mee%B&bà7 LÓÄd Þ®.–žžnÇÖ`Ÿ˜7‰Â‚0 ??ŸW*ZÜd¿®ˆJ‹IYD åªõ¹T_Tn$Îi£ÓëA±±¿þsìz )“/t~},]*”ßð’VX~Ï{¼‘Òâùà`åQÚZºHŸ6Ÿ»•{-È[ ×ê£(wG½»â”E¤PD›«¶§v ÇÚ¾Áï÷cZ&R‚alÚõžŽ¦Açw·‡¬ ?}ò11&·î¡ººšGÚT¾>XG]Ý×ħLö·Ê½Ž¨ˆè‰Ó1܇•E¤PD#sò–1'o¶ÿžxg,–°ÈL*àŠù ú5"\hÖ¬Y€…4$3s’ð'$R芧ËÛ#. ½q?‰q=ئÍ$cê òò/ à Y>‘å^‡é…%b£®ÿ•E¤PD`Z¡ùÃ`I+ÂjbÀ’1ìøl;9%E}¯„†QË¡8\±TwXt6µâí‚Bôå¤ ö~Yή_ДƒDewÕJó\¡Á§ ?ݦ0½`ßTîUõˆŠhc ûþ@_ö½Á Á¦]–}? `ÙE¥S\R‚]J„€ªÝåä]¸ˆ ,äÐWŸÓé³Â–‘SOúy¼‡rÍŠhdNÞ2n¸ø.Ú;Z1M˲ÈLÊç¦å÷41Ñ<%Ó0"#ªHÍ‹C„,¡âù‹i¬ÝEK—CÚÃ’kÉB7c—%D E4cIË4 Á²ïGšHìBeå‘ì´#„ת.œ½€î†¯C@ìÁ°ÛÕkyÃÇ~1 hA{ôe^©\3…"‚îîN,ˉ”½#dß÷ÍÿìÝ‹®ëHÃC«Àh ÕºNOO'%%eP®X¿M/,@—v‚}Öм9³Ù_³Ì»pnh~ / 11JˆŠhEJÉÊ“fßKfÏž}Zíö_/%ä•–pààQrs\`s_?èÜ#ê).š©\3…"Z«ìûÑÛ‰QnŽkÄð¼”’¬Ü™j‘B¡ønÄîD¢'T…B¡85kQ ‘B¡8¿,"Gl¬ê…BqÎhGe+jœbbb°Å:ª' !øïwC×lH)™_tÅ9 ѪoWؾÿú‘–ôÔÊâù6›MYD EõíûÈ/È'Ñ1…ŠƒåÄHÁsÏ=GLL ÁöMló.å’ŒÐ*++cΜ9ƒ„d¤ãmÛ>eÉ’¥¼ø»ÿÀ1q“§°âŠ26ºK–.!$KQ$D=Ý=Ä'Ä«;PÅÙ€Xø^êŽ×”è"ìsúöaX½z5þ&;»—q×5¹ƒÜ;!U;>bŸÇÉß\½(ܾ‚-¯¯eÊå·`yÜö‹U´ÖífÍï_ãÁßBYv ëß*çÖFÕnZ¬CMV+¢Ý#¼¿ýUÖox)%Á@€€¿—ݵ[xå½Ç©9²sĺD‰ûØ>~û›5ÔyzCž…4ìýˆ-GbY’ÑÉšÿúcØØé9Nqr¨­ Jn2m.mu8\ 8x¤<ê¶Òt]ey(•\CͱϘš™FÐâîh$+7 OW#YóFž¾’’%×òÿô _nü!†§–7çîï_Læì+¸}y<órØâJlÓFœ1#²øGߪÍçóª»PõLp&ñÓOóÍÁC` 4iÇÓÔÃ}+_8ù䱄¿Zy=›ªÚøç{V†K¦äÌç›ó÷>#;F\gø8@ôlv»]Ý… ™šË×>Á o¯&%qݹîÔ"X"¬G\±tѰkâÓóxê—SßL˜~}ßÞrÖ­[GWkwÜuøõä wô QÈ5SQ3…BJɬeÜqÍææ]rR²%.d~¬m¨œ(ëL!ø»KfñΖ*DûRó¦SSSƒeüîñûY±â&›-,¸òçQ·ù|^j-‘BÞµc^Áe§$6g)¥§§t$—^ÎÜãÇq¥qýŠÃNini$-9‘è Þ+×L¡âeÅ ø¾6]©©£ž’–<5*û]EÍ Ź"5S(çkfš&Á`@õ¨bÜcfäºÅÉÇ·aà÷û0 }LÛÕ5c5@0õËíË´Qߦb\`Ò^?2C1¤Ï¤… Žy…K˜1FQ3!4¶oÿ äÈ;…^ÛåÌIJ,õ*Îý 2Mb{Û¸fØSðÒÛ kv@2¿p9%¹ Q+yÂô‹hÛ€¬¡øÆúz¶lþM;½Uß8Rw”âÒ9ÆPCÅB Mhcãšiº†f Ê/òT åó}…mÊ º{ýjœMw»2BGF0ð7¶ŒøÞ±Žjò ò˜—Då7åÃ…HŽoùW¿ª%fP™³p/œÌÖ7×Qrã˜H/Ͼø'î¹ëû47u’–>–?‘8GáJp:ÉÌt¡é§ïšµwv²tÙ2ü~?šÚz)ô?jlùäclvÛØ-h´,‰i˜!õl¨'Öá ))9lÖY–TåFΦiM XR’éšFCýQÒÓ3TÇŒ2Ð#oÅÁÙ÷½9^Eê„lLÑms—ŠH/Äi€ŸåË/ã/o¼‘¬¬,fΜÞ²{L£f@€˜ØXO ññ á÷‚_@E*κ¦4B{¶û&ACõ÷èsDÂl/.¹†'_¿ƒ©™i¸;ë9Þ~”éùÓiõ gß÷[MÏ¿´×M«Hè©âý} ,œÞ7†ô|豑:!‡M|ƒw¶îç§÷.ã­·Þf²y€ª^È6»ÂsÏî/xmÝZvì¬á¡§ŸàâU·ò/O~DÉýËÇ™ÐĹŒB~`;wb ²³³ü˜fÈ8³ !÷+ô”)™=Ë4ÿK)1LÓT“Õgï)o1³ x½^f«þuÁBrÏOt&q÷ЧxúŸ01ÉMwÐÒØÁC«†'¾®,»þ v¿—¬¢Ëðþ‚%ßËc{ùa®üùmZÿ.=éñ´é~Zššèm¯Ã¸¢xøÄt†Û+=Ÿ•·ÞÎ-?’<þØ:úõ­ R‰óï–Ÿg÷§‰iš¸\.Ö¯{%"½“ RJþ@¨ƒû¦ãt]ˆ0tM#Ö®«Qð`ÓôA?C-"sý™šË]ñ/¼½šÔÄ$þÛuá'zÿL4!XX¦AVQ)9©•lݹ‹{õë>?Y œù|üòó<øÔ LL.æáÕ¡yÝÙnOBŽ|ùÒË–†fï™—ŽÏyHq‘` 0œ”$:߃‰aX–…m,*4Z–…ÓÏÿ÷¿áɧ™Â/œx­ý Öhüzxœ¬îò·:>Ç1 Ë2‰Óýƒص÷M"-e*ˆ‹uR×RÁªßpõ¼só•÷†î_ÙC¹m2Ó§LBOæÃ;ˆKŸÌò¥3y÷õ üàæëÀôóùŽÍìÚËmwßϱ=›X»ö%~pÇ8H¤˜¤¹&ðæ›o’˜ZÀWMà•ÿÜÌ/~ùÀ¸»+šŽ£³ÍsF“Õ†aðêúW­Ñ’€®i””–bš¢Åí–pæáB)%úΦ+Æ'íí¤¦gÐÑÞ†Ïç%-}jèØë%-ã #Ú‰=§áiÃ0Øþy9×]w]øµ×7>ƒMy¾´tæò¦ÍePìlÈz¢îÎ!"¯‘¼þƇ$O‚7}2ÈuYóÐÏØTÝÃ¥ Ç]©Ø ÞcñâÅØô±¶²›6oÆömD¨ÿibY–Z¬xáõöðûéîîÂCÇ]]˜–IÀï;ýã!íØlç6ÑÚaeuÈâ9ù 7þ°q0ØcøïB %Üü×W!¥äò+®&X—.ŸûwHKž••Õý•MAgWGrãä([™Œñ ¹3iîl.Òo Ïáç±Ûí´¸ÝØcb°L“·›˜˜LÓÄÝÜ~ýtûÛll¨?§ýcš&­m­çlžåÄ‚5>§/Z[=TWUôå†}ëN$h­žl6]cíµää—’Ÿb±xVF¤ß…” >–R"­þc+q‹ë ÕŸ*ž7IÉ)gýšñжú<ãëó˜–‰±i§mÉ M1Oíl‹×w¹X )¯³ºÀåbé÷.A!jnj$-} îÒÖmÛ°éšÀgÚ–iX¡¸~¤èŒ$Drà÷þ/2Æ4ƒ§ôA4M£««‹gÂ)?4¡ÑÝ}zל*g³mõyÆßç±, —ËECCÃpdÐx>ø›Ž5âÊÊ&Œà¥œX,NÖöh"äñ´0eJÒ ÿõä³)b˜rªç775âš–QMC5m>ŸoLæ‚;;;HMKÇï÷£k¡Èáÿš”ìã·7õIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/fdialog3.png0000644000175000017500000004507213070106167017025 00000000000000‰PNG  IHDRõó^èPxbKGDÿÿÿ ½§“ IDATxÚìw|Åùÿß»{ýÔ‹-˽÷n\À6`ŠC(L($”$ÔÐ @5H …žüB¾ô^M  ãÞm¹È]n’,éú–ùýqj§z’uöIšÏëµ/évgëÌgž2Ï<£ìÛ[$Ün7ª$´„DÇ‚M~‚ä„i ,KB~ @AU4U‘¤nE Þýj-‹Ö,(?H§§3dgx˜<¬'gŸ0 §]kº|yÙ!) ’B^ùl*Ó'G³É~W Ãà›EkqÛà‚SFJIݾH Ölç–ËϤOW/^g´W¶DTW•¨&w®ß¾‰5a(/½÷M³mH»ýößß#©”<°¼ýÕZfLA~¦³Ò®†•wñÚ§K …uúvÏ‘¿;Áï7þ· Ëäf¦âth¬ˆ°dÍNšÐ_ªßíÍAvÕÃïóÇkÎeP7ÿ[¸žiãúãu;åÇél*·i±yÇVìä¼SƳvg9Ͼú9\7³ÉóTùé’Ï)bÓ*Õ/!X_¸—Ã.?L'„MSé×3‡ÒJg©ªªè¦ÙüyòÓ%4-Ú×*ŠÂ93Æ ª BH…ª3®©\ù“©˜B ,aXÍžÓA$µÀÐu"ºŽÕÚ¾MS+I,èÑ5]¶ìN Œ‚Riž%ˆÔ¡°‘T/©XËÝ×\ÊÅ¿ü=‹‹Ûÿ¸®MÕPDÔþÖçË;dC …B’­qÀ²O¿9Ÿh’‚a&„ÔÓ&?’0A³–¨¦i6»-¹õv~|ϳ¼ð×_ðØ5_Ç>­¡cTŠoaèº^½…Ãá˜ßÕå,=5'¡’š¨M½{Y#ʉE$‰{K&†AFF†dlœN¯Ë‰¢( W»l±M:4Ÿ’”¡6˸\-õÔFÕçwï¿€ çü›»ÆæØ¿€¿Ý×ìÙׇ™¢¢Ú²É°íªÕî æ=~5‹†ÜÅí§õfç‡rÏûÛ«þá\N9ãäêß}Ï»»~ÜŸ>Â×Mâ?7ÏÀGX^›“ÚíkUEaöÉcü^ÁCßræOî‹“D‚yó¾i‡P…«/˜† (`Y õÅOƒzˆsgÿ·ÁÆ6þ÷”:?-“Hp/ÿ¸é öO¹Ÿ¿V:zÐÀЛWõóÎQ9õGçpÜÀÁ\ÿx±óËûù›õkæœÖ€^³þÈs³jÎ;¶ßq<÷Üê]¯÷ïવgrÏyà”^GØ;ÛŠJQTUî]Òt’¹2¦ñùçŸ7O舌œá­r´™†WD›0MM«W¯ŠÚp8cÕ³Hç_œ6u0ŒÓéÀ=ãð±´ŒÔÂâýû–óØû+™•åªØ8DV·Éq^ÊÂ0 ¶~ûwÞÿ6gÜ÷·NÍ)ãÉ; /Œ££Yñ.Ž}ŒW§×œoéÅ\{óF^[~O«>ää›_å±±Q¼ô}²í5VJ$Áát$´í•’ZÁÛsWpþ©ãZÝE¡Bì)£Z|žòò]÷ráCãjÀH tœ;BXlzõIò/ºž­¦ìûî%ò¦ý¢éÇ4QUUQ:9-ËB×ul6šV¿Ã3MÃ0°Ûí¨ªZ­ù>óæ·ÜpÉ Äån‘M]^ô.O¨—sVº†nõn 7âHÓD[˜•ví¶%ŸpÓÓ¹ï³ ûèm.­Cè– dI ùùž˜}»çÝLèÚ{ñj­k0Š–Â}×D¸qÞž˜ý' =ñØÔU¡¡4nSÇIÎPñ§xófµHs Vìâ¯×œÏ¯iЦ©ó£ÉwGç Û«<¾³iLë’%ØññýzjóõkšDÂaÖ~þ¿¼ìŒ¾å%n©4[ê7•«»¾Ã†€Ž¢(ô¹xï¿°%ƆðmïÞô{*0¾«É{Oþ³Ï>‡_Ý|7/´€’`¸’àO5w¹\sÕUWñÒK/U»ŠÐ×\s ¥¥¥ÔÎq * W?Dôÿ6 >ùîñŸ±æôsgŸ4èó8÷.ÿŒ'ú5X¹ú†ë™>$‡Í/|ÉÐ++Ý7¿ÃÃOÏcÇþr\Ù½9åô³ùûoÀ£*_±“=dw\|-9žh30+3­Äs?OÖ)̲҃­(œóÄ_B`V{޾.­áóU'§N[Ÿd"~"iÑÛÖª½K^àÊm¼œâh5©;.¸à|ìvŸ~ú)§Ÿ~:gŸ}vƒßC.=sBÔ)™¨à!BXX–…:È[O>À‹\¼ùÕÓä;´„|˲*ï)Ðý»y÷¹§xæã½ÜõúÇœ: aµ~æY½xjS)ÿÛêûÚô ½Ïº$fß©c~ļõ_&œÔU³[vJ“ß2tLK(ÞÆ×s?åÝ·?%mÒ…¼ö¿ÿ’cW[D!"NI]EdËŒ¶S¯à³åÍmƒø¿?Óä5$©£8÷Üs9÷Üs›ýP·Ë¢(m|"Ðuƒ²½ÛX³r9ßΛˢ?§üìZ¾»íXZCç†ÆêÂ’o>cÝÚµ,Y¼˜ÝþTN½ðR¾ø|*Ž&të¡7ÝÈW—†ùþ%4ækiRâ “Ïþø%7þ¿ë}‡Äê!°moi4pCXÌ™¿³¦mıX|÷ üs[®¬žwüÉ<üê5亴V‘F7©zpŸ¼ÿ-‹-b[‰ÊI?½Ž®^Ù!5}§Ó!ƒOâhBðüœeüjö$LËhÛà3²_]y;i9=2b4g\õ sX|É%ÇUn÷öbr‡M玟Ý@~Z|s‹=9çqkÆÞÚq&ç÷NG¡þ$‚O—RoŸËåå;Þái·ðCnl åyë¿JxEFƒO¢±ß{V4Þø…cî‚‘„­Ái#2ã&µ©—NéËe¿¿€¾]ÝÒq:l ,¢òÍâ Ìjdˆ³Ú/#ó~'™ e înçŸ>…¼4§Z¿gPo¸¡0wY®ã”Ó-•}‚§^™Ë?{†T¿Û†èÊ‚e9vÜÐ:ÙCjR+Qƒ Q #Ëuìr–0X¸t'3 ù6$%uªàŠÊÛ_¬aÞ²-”û£ó¥4UÅåŒöÁv›†Ãm .§†¦(’å:p9EQ=0ŸsfŒË”¤n—Î2›ͦUç{Žªe"VG«µOUÔ¤*',¢(Iû|í­€eZ†.½ß톡ÇUIå0MT-þY–eUçâ’hC ?Äá"P^ÌÖó(\ñ¦Â0t¼é]p§e",ÍîÂáò¬(FU5Ü©YøÀÒÃd÷D¯áÇ’Ý}€ü’ÔÉOZ6«¿zm«¿iñ¹v—‡Ë™+?bBê>‡ !™y}[u®" ].Á#I-‘\¶´U?™,sœžèL3EÕPµ¨‚¨j6Òóú Ùò#Jõ["™ i6²óû7Jè´ì|&u yýF!èa?¦¡£ªþCHïÒK~DIj‰dCv•¹Ê•ºº9A_)ë~@!Éë7J~,©~w^;Õ²¬¤Úšš×ÓcÞŒ. ÓCŠ6¯à£§nbóÒÏeåJIÝù`› Ø·¯()ÖqV§ËE^^> j0·œ¦ihZMsJïÒ“Ô¬nìÚð¦æàÎ |ñü=Ê‹uâ…²¢%©;„Þ\°‘`0ÈqÓŽÇ›’’Ïå÷ùXµr[60hHýYBŠfÃéI£¢¤(ú–Å´ ÏÆ…sXöYt…TË4(Ý»•ùoü•@y1“g]++\ªß{‹v3rôÜOÒ¨Þn‡!C‡SRRÒà3»S2ÈêÖ?Æ–ÎÈíÁ䳯ãØÙ7Õì¶,Êìdñ‡Ïòå‹÷ËTMRRwž¾VUÕz+#mØvBÁ@£Ç½™59Ö%عf2ö”ŸãNÍäëWĈDÍ _é>Võ*ÁŠN¹ü~®YíRRw\D"á¸{?â¶¾®ãpº4R³ºÕ”„ù¢Ëð¦åä3|ê¹ÌüÕ#xÒjÒJÊ‹)Xôs¿žŠ’½²â¥¤îÀ=­ª"L ¥‘¼dޔĦ öû*ܯ(JeZúû²{ BQU„e¢`D‚5Ïœ‘Ë cfâô¤òÕ‹÷Qº7ºð`È_ƶ•ó˜óøuœrÙäö"€”Ô“Ô–°¢0ØšƒišèºN8ŽÙt]K¥oì¾Í-ûâò¦×‚¢Í˱jÝÏ•’AŸQÓ9õWÓmÀØÍ$äg÷Æ%|ôÔMìX»P6IꎇÚó[Ó4)++ãùçŸç'?ù C‡%//nݺ1lØ0.¼ðB^zé%ÊËË[e¯+ŠÚ$©S³ºáñfâô¤‘™×»+¥^7ät§ÐsÈDN¾ô~úQK]²Û>ÿÏløþCÙ§ýÈ$ É!ß|õÇM;»£á˜è”Ô´ìðo¾ù&wÞy'Û·ooòýúõãÁdöìÙØ°Ý}åØú¾ûf'œtJ£×Þ²ì 2»õ#5»‘`Þô†(4 ;6òܧY;ÿ­)£ÙHÏíɤ³®aì©?— ¢ÙD“;vl§{Ï^:ËœNgÌï@ ÀÍ7ßÌwÜAYYY³×/--åwÞ¡¬¬ŒO<±±Ã‘†—œ·,‹í…[éÛ¿ñ¹ÏYÝúáNÍDÓl8\Þ&L oz9=£©6ölZZÙ©Y„üeìß¾–°¿œÞ#Ž“ ¢C«ßdLS­r6 ÑðV º®sÓM7ñôÓO·è–eñøãsË-·ÔW©¹¯Ry^›©‰ªJNL8ãWL»à6”ª,(BP~p7+¾x‘¢-+%KAê–*$ å[Ö4[º<«Ãh sÓGÌ;ˆèê“G–Ô–Í:Ê,ËâwÞá_ÿúW«îcYO?ý4|ðAì'hdST%!õ›Ñ¥£Oú)§\þ`ŒtŸtæ5dµržvgF\CZK~XÔ¢†2ùØÄ¨Lûvî¡ßà1 ‡°‘pu Z¼u9¥)ÃØ5º$íwŸ}Lö1'1,ÇÝà=‚×ðÍ’ƒÌ<íÄèïýÙX‘Íèþ¹(Ê‘©”H8ŒM³5«™ø|>n»í¶Ãº—aüîw¿cæÌ™¸Ýî&5"#¢ãp$fîsjVC¦œ‰Ó“Æçÿ¹Q3.bøôópzÓ$KAꉓ§àñ6ñ#¬s?^†Ç›BÀïk[ÍÛ ±SwPöý·ˆR¤i+xÓsè?î$ºô~oz.ÞôÉÐD‘ˆƒ¤‚òí‹p …¢´½Š:°†´‘Çp \¬º+o‹ï¼õ)©iéT”W:Ь«WW0á”q8‰¨Z-PQ5)‹……>&ööÔNjKÙæ¥¤DhѬZG2úM`˼¥pò¨µ–Q¢²aFÇ©jªeYõÔæÖ¢êZU¤nL?h,ø¤-áNÉÀåM¯?/["1޲¦‚ïõàVms1¶o.V¤m§ Kgãú£»ga†üþ˜ÍW¾Õ–µ”ò`ñJ¬¾ÃIqkÃFÌõœ™ÃÉ;°ŒÚÝ”)f]YwçfD×iÍ6õÑYuÈ¢vS[0÷›ÄTJœŽ²åË—·Ù=c®Õ˜£LQê3©ÝyH!R—í¦¾ŸJ`èe¬þaƒ§Œ!Õ)E¬¶s² ÁÁ‚pOšG%¤×/c…‹°¥ôQ£–—”Ò«WDB Jžî£‡²jù¾ÊµŒ»W¬eÈØ¾¸´Hƒå=ù}8¸º—­æ“Ùív¼©) iÔÍID!ûöík›NSŠŠŠâz®#Aj‰#¤~ˆÐn–¦2¾_:Jec0‚Yµdùã£WV a¿?†‹¿oYØß¤:N6ßîušý˜Ò+ 4H8ßöd аj’ߘŒIu¡ŽcVíÙ MYÀŽpWº7Q”1š©i^BÁ†Í ÍÑ Ó¿ Í™•ªü¤KÈ(›ªª„ÃaLóȨ¶t ‡§Öu=ªAHtRgô›HÆ¢¯)êzyn•âÝlÚ`è¤iäg§`üuZù¤c‹ËÉÖ˜ýîLËgRß|œJ¸Æ.ŽQÍ#lÜcǤb†k&ø… —Á&X—Þ[¬£?ã¦Àn 4jPj8E¨v ¦óø|mO0Um¶³P…îÝ»³qãÆ6!t÷îÝ¥¤îŒ¤…~Ʋä›eìu„quíǔǒâP ü• g·ÆÉÖ8ìi™`ét£µÑ¢xÓbì&áT VXµ^Ì@i&~ZQŒžJ™{8©^;A_¤i‡6Ĉ×QU5®äcÇŽmRŒ7.R#IÝÑljUKgô˜,|Î~Œ5·jð%t›Ø|¦QÏΖÅÁÂU»1ap"«šgÙtÊãTqdö¤‹×Ž 4ٳݖÓQ$ª+JÔQ&„hp«"þ¬Y³ÚÄ©¤i³fÍŠ±±»¯$u$5€3s CÜ[Y¹£„PX'ÑñV5 +êL«(.bíÒ쳺0mâpܪN0;v“çaÓ¡H\/(Ìz3€îÛŠ;¯[Œ3îû/¿MÈûê‘HƒÉýêªÂgŸ}6C‡=lÕ{Ô¨QœuÖYÍ–5 3aÁ'G™Ô¹C'\óþD>“ÒâýìÙQÈÆ5+Y¾d1»JÂô3 £aW üÁúŽÔþØ¿bvM©§ÚÆ£þÖy¬?@ÿÙˆ:+QzàýŽD•vuã¢;þô§?58Ó*îÚéäˆéD»oc™O$:©ÕÉÈ }ð‡íh %¶‚/Á™–M¿áã9öø7fÙ)v"A?¡pÃ˽jÎô·­g+=yz³w¬[Æðïf«}½Ò]DÂVL¹D¼z¼6µ¢(œuÖYÜvÛmÍJöýv;·ß~;§vZÜR=ÑÁ'G‘Ô¶”žtu)¨jY­¨ôêÕ‹ü®¹x*z(H0à'7;Ñ¢ûèñìúa-uƒJýÍ;îªÊ3Ć•{?¶ÂèuîϵZCêxÇÊTUåî»ïæúë¯Çn·Çec+Š‚Óéäæ›oæÎ;ïl‘­/mêNjˆ)éf­j"‘†a´hÆ”¢¥0b\>ÊE«%j¸d/ùãÇ‘•ê ˆ‘JQ%šÎ¨õ»¶Ä}ôÑGyõÕW8p v»MÓb®( š¦áp8:t(¯¿þ:=ôPƒ¾ÑûJïw»@‡O<¨92ÉsÚ°k£å Ò•ÛÍr¤šs¼êwÝŽ`öìÙœ~úé|ðÁ|öÙg,[¶ŒmÛ¶зo_&L˜ÀÌ™39ãŒ3ê%Zˆ[ý–¤–¤N ƒˆÑúÓ-#rD7žà“F;!—‹óÏ?¿ÙW­Ö $©%©%Z)©›X.Ñ«Z4~}!I-I-Ñ:‰Ø´¤.Ú³û(=—”Ô’Ô­‚‰ jjÒ­3¥ë† >išžüÉ·ÛM$Iºç²,ä\g)©%ZŽœ.¹ìØ^HŸ~ý«½ÍŽZÞj!¬˜i™µWÁHT¹P0À®;éÝG&LzóM&óOÂJQU6mÜÀÎ;p:¨ŠJyeš¦èxs´/VUµr½-›Í–ÐriiéävÍcààÁ1¤—¤–ˆW…²ÙÑlZͬ,¥ÆRŠY’GÄîKT9KXX¦…aè²r¤ú-ц. $Ñ*HG™„„$µ„„„$µ„„„$µ„„„$µ„„„$µ„DǃÒJR4–A¢ãCQ”ÃÊ+I„0 ƒÍìÛWD(’¤³pº\äåå3`РVåQ–”zãúuƒAFŽƒ7%E~”N¿ÏǪ•+Hñz4¤u韥¤NBì-ÚÍÔãgàöxäüåN·ÇáÃYµb™T¿;tÝÀf·cʉS W+§¹¶Òû„hIŠ`‰Xÿ‡™ŠYJê¤$u4mP<«‰Ht@I}˜i£$©“²RÕhÞoù)$©Û+©…Yrbm*a‰¤PÁ…í\UEVÑ‘#µ8ŒUdm­«hRk©KÔfXié&ª½¡q7“}%:yÙráµÚ6µ%ÄQ—ÔV¤Œ‚µñ[.úN†C“•sdX}äeÅ?¬ù½pSy3½€ÉúEk@!fc˲ÐÛÙz(‚ªŠÊ}¢In5,´*ש¶b6[Vˆ-Õ“¤Ö¦•ÔÍl–i6»Õ?ÏŠJà¦6Óäкµt:ž‰ã³}u‡{ßø7a™Ñ5Ïkï¯|¶Ã¹n{Ø”Ã̯Ÿ¤VLÆêvbøƒÕÇÝvج¶ «wD71¬D6—ÛIÁò ôÜ—¹_/ Û½½S9ÈÒ–%Ú1ulV )‹·.§4e»ºcˆ,ÞÃÖE芆¦€iZhš“Ü^è–-Ü¿‘ÙŒîŸÛnTü¨ÖÓ|G$„`É‹š5m&M™«…JØWjÖ& TXä{<˜z)ª¥ãpÛ t„,]¼¨YrÂÄÉ­Ó,“½‹ñwÇÀtGÍóìYÇ5ž]3cÚXG3é”à Ž‹Ô]+Y»§¦DÊ}lÿf>¢REðûM¾-³UKDwþ(Fôô‚0YùýJ°¥0iz¾­ Ø%zÑßéÀ›?œic»×“Ìß/-Áë¶áF×É \O¡èÇä^ÙØÌaÃ%[V²¾ÌÍØ1“ÈNqQÅËð±gW›¦b˜î®CèãûžÍ‡Ò˜él•Z^^†Ó劫b™4¹‘¨3©`ÞW…x¼^ü>_í#`)¨Z“- WwXøõ—dySè=j8‚šxô 'ãõ¦4Ûéþ9WL#ĶµË‰dcT—LTÝO¸rFW^lÛ6óÃâô8˜.®Í>aì9 Ó½–hO¤¤¦%–Ôz°œIS„ËÕÖ÷}µ”¼ÇT§¯»¦”ãGfU“zîšR\v•#†8X^’‡Mìcþ‹A£³°+þÝk˜_¶±žjv Æ"¥Ê¨cõê &œ2'• ÜéþBVÙ™1c^»E0¨¥I¨dçy¢6¥Y’Ño[æ-…“§@íT¸I:l¤ªj‹ž­6akkW7. kØ$”: õ7Ž IDAT‹ùjÎ\ò{Ú°ÙÔ& .+bÖ1LëîÅ4 Â`ì}ým´Œo¥‰ä/ÞIAAyCÇ3¬G6Š"TkEUEu’ßoÝû‡(\½’•EÙ ÒGÌRÊ3¼‹íÅôéîE7Ž|D^ÕdœÆ&f4w<ê¯:Ž2U#PY‰aË lÕê·Ðƒ=H RýzMö’îÜä~ͪù0`Êtö}¿˜.9“ðöÉô±Ýë‘záâbªü¬Áâ•X}‡“âÖúj4…âÕ›é1þTRœŸ/Ô`ƒÖkçìSl ꣳêÅèԚϵ`î7L=õ„¤$µ°,D«õG(bCYÇÎBúêI}aêD̦‰æÛÂÑEà øðW“C4è÷hê]škü¡²}lÝ\€™Ò‹ÇM#Óë@ùY¥T „ƒÞ#&ÓïÇE8ª¡€øví"·O_œ6…ˆ~äý)ìgÍêU 4„üîÝcˆ+„`÷®]lÞ´‘‘£F““Û úÄCZÑJKIW eK¯ŒR{†(ˆh˜¾ƒì, 2¬ê^ b¸«%uiA)½&gA$Óoí)7—Šˆ_Rxòûppi1®é¹+‹ÝnÇ›š’…ãÔJtD¡•ç›z€uK·1jêt\Z_¨u Ä¿7H^–¥W×§ÜÆŠÕûã:?\ZÌ1§þ‡Û„3¤dû‹Ë°§uaÏA³NjEú}4ÛoÍ“ID·êt[wÛ7"=\qtêOÓÐ#Ö­Yò»÷ˆS Áî];Y·fueŽu­ ï÷ u•w¹ÊQVû7¢Îïªsôƒ¬ß°Ÿß…·t)kzÑõTŠ×–1¾šÝ†Ý‚õ‹71lâ @0È^FÀŠNC;0“êBÆVN'n›B(/¬9ºaúW¡9ó ’Ô“N<.)£1E¥µZ–fó²%džJ×4A_ë:,aR™îµ£ûÕ2ÄæîË1“‡àvÛ›U©×~ú)Ù™øÊJtßn¶l/&6Ðrºæ3jâœ6•«pØ5Ê…Zø¾‘ç©oÏjè?ÝÂ::•›™™Åð‘£X»zëÖ¬ [~wöìÞUMèá#G‘™™Õ¨£ôˆz鯡Ò1.÷±óÛùÑa—JGÙ [t #:eLµç2t¨ÓÝ…ð‚edNÑAèUºŠ ~„%PýPŒ½¼éj•²dE1ãòú¢bâ.\ë0ÏC£¥ã¸Š†ST€jjtó€Ï—|¤VU"¡0–½%+0ÍÛ׬Äv—æ!XVJHoEãÿ¾U(ùýq(:%¡p]L(Ø ÙL?»µ|Y:¡pô|KM!¿_>Ù4EAX&‘H€²Šb†ÃáVk…F°˜ÕÛTŽ™šƒé/#6ŽZfçä2xè06®_ÇÚÕ«(>x½E{PU•ÁC‡‘•Óè»êº~d‚OŽ9îD\ZôFûæ-%ï„cªI=wm)SGfUÛZs×–ÖHÕ¢UìÍ=ŽLÓ@+Wîã”i£˜ØÏ¦ïdÞ7iÃØôýJ¬½ôž0K#äJÔížî`ý¡m-s'XØí`K4ø¤e$4"elY·‰´~ãžgcåwß1ŒôŒÌH)·šŒ<¡;"èkEŸ`QV¸–ìÁpXÁZj©§"úÊkÀa¹„jìT#XÂúÕ;xÌ$Ò½‡JŒ£^]óº°qýºBwéš×Œ¦vxÁ'-²©«†'ªeÆeu”…„éÒ˃¥€¢zHárõ¤ÂWƺ…9y:;VD“¾š5ŽqŒÎJCø@–M§Üõ2kä@Ö.\Í ©CJÕ\׫(Ì t[vL'‘¼Þo a™Ñ|õË"XZÄæm%ô1‘žy™èþRŒìËæUëPF %5Nb aa„Jظj+ÝÇL¦KšJÙÁH‹LaY²UïÎän9„ËKctBÇh ¾ú_áj2ºöÆéIkÂÑfQ¶o;ÛŠ‚ôŸp =sSð•”&MÀQKŠ‹ÉÎÉ!·K×f‡*…ÃR¿ãnѵ£¶jÛÔVe„OÌïZ(©ðá²Uªäh¥D,رfÚ  䤺1-“¬QS°m]J±¯£ò¥sòöï.dýÊ”è^Æ;‰Þ9)JJ‰XÉå(éÒ5!Ɠۥk¼XâƒOêÚÔŸ?Ʀ¶©…ˆ°ÏÕ‡áZMDZ÷‰cYýÝ7¨ÝÇ2¬{&VЇP@Q]ŒžØïç¯büÔQ¸U•ÔþX¹bc¦t­@¨BFŸQLÈ*fkÁj¶MQ0- Ms‘Ûg v»†®›ÕáÀúô?Qg}*Oj $ó~———áp8š¬XÓð³nÝvòûcp\ìVˆ²âRb(¤y8²W0lüz×+/9HÀ_Ayy9ÓFv~O¦ ïIŠSÅWZ\èÓ8B¡P˜`ÀGyY9¦ê¢[ï î–…Ý Sr(—j][³B°æ«WX÷Í›øK÷3ÿ•?á+ÙËø_‰ÓmP°ñ–°P²rº0ròHR=.̰ŸÒâŠ1³- &>øE±©£~'µšÔQ•Q©¶©¿\WZÙßhŒÝ»ˆÔL:9C&Ó='•Â_±;b¢åŒ¶”3Òd¿i§·j‚³ým_³GïBv:…#-›acóp8QµZu› ©qBþÝlµbFº‹H-ñØ“§'åÌ#UU4!bøjó2rôh23½}eøtVé NFvecIEpgæÑ}ÀRÜNTÅ" RRn–BöïÝÍå%5«=Çët ƒ` ¿Þ2›°k^7„l^ü)K?ùT”U[÷Í› :wÚ@†ŽêKF†°,=¦¼ÄGGJú­öÖwOq'T)Xáø%š×©UÆ‚+¨*X–@ó¸1AÅŽ¦–ÀîöbWAè!‚• S±9±‹S L«ogÄäá´fŽ0C¬]´†~“'“›¢âD’ºB…|ùùgLœ|lã㘭ò¨kÕa½µáòxÀ4Ð#‘fU톒’аL CG×uGó-ݹ–Ož¹…’¢ÍXfÔò¶»¼œø‹è3ê\)éTFFwè¹æáPˆukW3uú ‰U¿[Bh zrG4©Re¬r¬ £²Vô Ÿº ¶ #L¤Z#Haĸ|” º¥)-®ÌpÉ^òÇ#+ÕA°z¼5Ù½ßÑॠ=ÂlØôûëºåmò|Å» øâ¹?P²wk5¡EåØŸÜJÏáÇáô¦Uš¢Ã'Ðñ3ŸhŽLòœ6ìšÕHè`ãpåöÁcs ‚íFE;œà“öé>¾yé~ŠwmŒ &™xö ôw ž´l:ÔN“ÎHDZ9ôX»¡´ R«*µý»´h+Š¢`èa4›´œhöú³äôŸy/Ýþ•‘šh²Ñ§\Êà)³ðfté|+•Ì'‰V¿Û¿¤Þ½ñ¾{íA@!­K/FŸr)æͮç?øæ•ؽþ{ôP0hò,†Ÿpi¹=:m8bÁ'GŠÔZ»–N–eQºg3z8êÃ(ݳ Oz}zÁ›aÛŠ/jìò^#§3öGW™×·׿Ì&Úá`Ó4 ÝÀn··SíQAµ9jHnX¦ÓQ-ûäß,x`EIõ¾.}G1áÌëÈê> ª‚vÒÜçáp»Ã!IÝ‘Ó%—Û éÛ¯?šMìء֪§³–*k%U9‡»&xBÕl ¨D"QßFÁÂ÷XõÅKøËj¦p¦wéÍijo"«û@ S€iWïÛVå =®;éݧ¯$uÇñ‘( 4„M7°zåŠjiÀ±Ùl¨ŠJyyYõ9šfKªr{wmQÇ wPrqhÇJ¶/|…PYMp‰Í•JöÈ3Ù]ä@`M»|ß¶*ç°;ÈíšGÿƒb:IêvaY :œá#GÕ9Põ§’èŠZëHªrsw~Çöª_ˆ)S§bw¸xÿó¿©Ø_ÓÜæpqÆU0dÒq§f&Ý{éreZ†.%uGƒaè‡U±GOzõÿNO*;7,aýÂ8°scup Àñ?½ƒ^#¦¡Ø]„š›¤-!I-qô©5DúXôÁS}¥˜zMLþ±³obÈä3ñfäÊ&I-‘ì0õZi‰„ ¼xOÌ2Bãf^Ƙ“/!-'¿Ž3IDk’ÔÉ¥nRñZ„î1d"ƒ§œ‰°L6-ùŒ¯ #¤hór쮎}Þt)½%©%’USFƒå¥–©()â£'~S¹ HI4½û0fìX4[et”¦Ñw̉øJ÷‘™×EÓÈÎïOväô‚¦i(š wJ†¬ìDTK¼éŒ$Ž „,Y¼¿¿‚iÓO -=¹þ¡C¥|ûÍפ§¥3n„êýòb>Y¸]×c–œm\RG×1“hW¤¶ˆD"qoɆæÖnô­ £V£Ž„Ãèº^o«*",Ý8üÆ­i*VœŽ2Ë4xñÇǰƯ#,‹•¹‚×ö•7\7z‡ÚÐë†ÂœsÃB"!ÁÕïp͵7ò̇[š}'EU¥úÝÞlêHù"νøÏq©~á°Áçÿû¤ÝaÌ{üj ¹‹ÛOë À´þÃýã“ë•=ïápj¦‹Ÿ>Â×Mâ?7ÏÀ¦¶~ì5º†V|çá"+?‹õ^;¦ä/ÿ·“CK/eFÙ!22bǹ©#xûÕ‡°L“{.:Ÿ¡Øa(!`ùúCœ·£æ¼Íÿ¸ÅßÝÇÿ=<¾IsAªßíŒÔŽ´)|8çƒ8ÄFÌ.£Zõ ¦aT‡6I6ÓD©³pœ°Ìúów;¿¼Ÿ¿Y¿fN%¡4Gÿú׳žÓûÇwpÕÚ3¹ïËAÜwrÏÖu&BPR\LJJJ³Ž2!LvÌýÝ®¹a™Xÿgv^úßÜ5†ÔÔT‚Á`ƒ×Bá€~#sæ_Gê n8õmŸs^M½˜Mk:]oyy9™YY’MѦ6B…ØSF¶Ø±cè!^úãÝ„éìÚ\]›ßx_Moÿ‚ך6ÓÄŠÓ›léÅ\{óF^»ñ˜ƒÉ7¿JÁ­×QRg±õH8~³DÕ4Ì8ÔYËÐùËÍ_òèe0 g¯~Ÿ'n¯mQG5·Á±¤¦ˆeòò;k㲩;kŽîOêPÉÿðäÙ×$ØËß~s¿WƒOcrÆôû«=ºÁíoðÔ®Š˜{>}©Ù{ýó¹7YVPD$A×&;»çÝLèÚ{ñj-W¡-…»~­só×Eµ¤ÉI#OŽïü8ƒO„0Ùùí<¿«‚1^] îçÓãþÉ8o͔Ǻ6s•@`qpÃ=Ìš5«r;‡s~ú ‚!]æ¶¢¥>àÑÏ5߈dðIûS¿ãÅŽ>bÐåO4/$,Ó4Ù<ÿMþ××\pÏ9mHcqÎWwy— »ê±Ó÷â3˜óÂn½sLu‰ŠmÝš½çønðÑ¿ïãO[÷“Ó{'œ|*?ž1ž›†ªihµlàE/â—¯õjP«Ðu½ íöØÏØëìKYô‹Epò¹ÕûÒ3âŒãŽ3ø$ØÏ]F3v†Ÿ›®[ÁëKîéHfÏž]›yŒ¼áiœ‘¨¤ »Ÿ·Þ;¡Zí¾ëôÿ ùgxx÷@€ r<÷(ÜöQ¤–Á'’ÔÂ2x⟅üaAŸ†mfÓˆ6T+ÄŸ½É /¿ÏçÙ,zåY<Í8•&Þ0”»V—ðßI]IÉ¿†ðûÿ‚jR ¾?4•éÍ<ßñg\Èñg\@qá*>ÿôc®»ø/Ø{æÌ3gqÚ cªŸã£íažÊª?ØŒìçæßþ6¶Ëqtãï½=fŸ+ûtBÛo¢¤Ö4ø îo©4ãx²L÷n?ŸéO¿Ï[#B³¥òì'oë¬ñ+hšÆœ9s½F©=V-RmNºœxÏ}¹‡Ù³2¸çµ¼w{zê· >éx¤Û>½•ï'?ÂSéΜ[>^ÿïs,Yº‚}e£gœËŸ{› _×,¡r&þ’µwl…I]Q4/¿?fwõ1Ý·¯OžÄ­-xÜì¾£¸ðêQ\x5”.çwßቜÞÜ:*êì)4sq7ð\š£+ÿóŸqH.¹æ¶ÖÛDªJ8¤áÉK‚`ùþ/û^Þêæàz  ‘–«‡*%wÔ«]õ»~«³;CT·L•*G"ØÒŠï±gXv`ùþz¸ù1~Ó0¤÷»#‘Ú2 J·|ÄÏîØÅ› Ïj¤'·‘5x*wüôr<-¿¥+óToM-‹Ôš¦ñî»ï4è¤Üüü÷\~Ë}œôú¬˜N²lßR~÷ó{øùïRø›“xwç ÎÉ÷°óëýû{“Ï#ÕïvJêe÷ÜÄc…¥¸2{rÜ 'ñ×ׯ!×Õú µ/Œàf>þà[/ZÈ–ýpÒÅ×óê•#â:×él™$zÓ|uùg˜ï_£rÆ%i…ÉÜûçqý³ª×)ŧ JJJðz½‡Eê†öW9,Ÿ™Û—ÿ<à¬>nA¼÷,<¿†[þû:Óº¹ñÿçQÎ>ïŒÿ~^88×]Z£ÏSQQ!ƒOÚ+©'<ð¯´áÍOC°Ì2ÂÞÞ\öû èׄØ6nXߢòžœó¸5c oí8“ó{§WÛÖóÖÕ¬6Q¾ãžHý- sݵÔi/ÖÌm‘£Ì0 4Mk–ÔN§³AR7´ß|çÿ®ñ- ß½‹/Чñò»×“¢)žì©¼ôH!¿8ï4ßüb“Œ >I.Èăj[øå9ÿà¡÷ÿFž3>mÄ ïå¦Y·qý»ÿa€»•î Kðê+/1ûüó›Íí•,ðû}|5÷ Î>÷\Ùp’r>uc*Œ»?O¿üS>ú¶(îsоýˆ ^z¶Õ„Žv³ ©*¦iUÆi'ÿ¦(ª >i¯êwgƒ;{2Wœù']A¶PŸ4­]%ó:1%©%©%š´©…iŬ™Üêž"½ß’ÔM!|Ò~r”ÉàIj‰æH]™ù¤=y”…$µ$µDã°Ûí„C\NUൠÞÔŠGºœ‚` €Ëé”'I-Ñò{ô`ÍšUŒ5›-:œÍ…&P·fõ˲0 £špGº\$aíšÕ :LV\²XCrœ:9mÔË—³©`#ŠªbSU@Áf·¡©*ÅÅÅ@Ô¡f³G“"¨švTÊ¥¦¤Ð£GOF'=à’ÔMªP6;Z¥”®Š0­Êè­*5á1Y¾B9!¢1ù†¡ËJ“ê·DS0 ]E¢Ue’Ô’Ô’Ô’Ô’ÔrH+IaU.$3ŠEAUUTU•¤–8zˆD"¬Z±‚;wðûå9 x¼^z÷êÍè±c±Ù:Gs—eI!‹ø`ÐÏÔiÇ“–ž!?ÊaàСC|7ÿkÒRÓ7a‚´©%޶mÛÊôãO”„nddd0iò±ìÝ»·Ó¼³$uJêHDÇíñÊÑF°;¦!I-q”ì¡8—²•hA#ïdKíJGYò±:®¥lK’óÕ=ž‘ºs-µÛ RÖÒqñ4nUÃ4”£Ì4©˜81ù^ZÓH]±"1ß³“-µÛbõÛì%`I‡ybÕEUæüjË難*Ûi ImñÝ=çñß- …BÕ›ßïÇ”+Ûi‹ÔïСUܹ8‡üm×ñu•2nEX8ÿ{ÞڼɩŽÝÜÔÄ"^¯»Ñã¦bÇa‹í{„iѨ! T¦ÇVl6¶Êí,#BDh¸ìZû#ue6Q‰6”Ô¦´©ëËh#ÌÛ·ýŽ{ßù“2]UŒfû—÷pQ×KZLh#âëgoæâ—±·èûú–»á«'~ÃÒawrÛÌÞ1Dߺàž|ñCJpá±A0¤ãôtaæÏ®eö”žìœû÷¬ϳ7ŒCk_>¥27˜DÛ}OKJêºÓÙðÎïyuÀý¼å†P(@Ä¿–«þ°›×þ÷ûê}BÜnw³„þø±_óIÚ¯éç^ÙÐÙþÅ˰lWõ±HÅ6>úðT’º÷~Ï•kÏæÞ¹y`fŸvC!¥%%¤¤¤$ÆQ–ı䉊s///ïTKíÆAj‹ßý›Y7¼ÆÈ©{øùÏkŽøw~O$w¿»â²ê}Áý;˜3oaáû.aÙÀÛyúã9ö¯ Ü1rënÝÌKcÃúÊ þÍ•ïe³ò«;p×ñ8RûpÎE±û&Ýø2!O|Ÿ\GÍ Á@·Ç¼ê¢õ~7·”­Dœ’º“-µÛ,©àV.ýûîüñx.ýÏë1ÇV>4Ñ¿;fߊ{›^Q.xðÖ¾¿þ¤ñ<Ñ»¾ú-ú5wã©£6õ»Çùù¿Ö#t£•©y¹çjƒ›¾ÚÍK3{Vï?iÄÉ,Øú]r6À˜àIê6é$;YðI³ô°¹ðùÛ2<µmV`ðäžÇý?i:ñû÷üÀ/ÏíUoÿëÜ4 ½E÷ë}îåüðH¬Íž•“Äb%ñÁ'Ô+ø$.™gS¢vnía¬P(DÄTêí ‡ß#~¼#ÌY®zûw[Ùõ¤wspgŸAhÇ'1û>üáƒ$wìh sìt¾ùÙ¢ÓŸÄíý6üü翨³7êìóîããûï¡¶™¹¸Õúäík+æn‘iW[@7¹æ¶v§.†CA”Dx÷’¸q‡Ã¡„\×4 éýnš­ o¼ñz³åJV|B$báp´~®H*~¬Ôˆ ÇeòèÚ<0¦k ®f µ]UЦ&pÑùNèýîlKí¶ù,­Ì‘Ó¸ãÑ•‡ucS+Øè¯¿:Å´¿ü–w¯û %õLNaa4 úëþT¤N‰Ù “›ÔšŠY¹>u"¶d&u¢ÞWÆ~7ØÛÅ×Åÿãó‚ÃKÁ3óÌÞ<]PZoJ¯ŸñüÏtÎúõŸY±ûPŒ-ï+ÞÌ{o¬©wΡ‚gésæ©1ûNz’ÛÔ*B IÝ–¤–êwÒÃë§,Ä©*¸#¢ªÝÚwŸcäEÏÄïÈj`¼xÈ7òÍŸa¼w ¶:†å„+ÿÁkcÞço÷ÞÈ~ËǦ é¸<]9íòëê4ƒOïùšÿߟëIÂdnØ¥%%x<©~·***dðICèqÖt~zñŸmœ.'v› –…®ë†n „ÆÞmO]ž÷|±fn½}žœÙÜ’9•· Ïà‚~™(€¿V¾Ì'sßßOnðz~¿¯× ¾ÃS¿ca®»Ù{&›¤6 #1Á'Ô2ø¤t™x'½ f$„?¬œP¡ Ùí¸N\W›è<ý¿>ïŽû1º¹4 ÷¹E{vc†örÏo>áÅ·þÝ®*¤vð‰jBH­t:R#3Ÿ4©†;\¤9\‰0w?ž|á§¼¶ ˆËfô hÏî_´àS.xþi¸ÛYr%:õÒ4-TUHR· ©U™ù$YàΞÄe3Zwn—Ñ£VŠ¢%xHË„qïš–@YÈà‰£ UU¦•ûWU1?û4YEub¾'Šô~Ke/Ló ×IDAT¡¥jX–)—ÜiC£Zf>‘8Êšh4ó‰$u*’ÔGv»p(‚Ëé¢*¼6Á•&‚Âe¹úǃ.§S’Zâè!¿GÖ¬YŨQc°Ù¢cÕº®cUz®=ÞšÕ;,ËÂ4Œê-ËÅ–‹D"¬]³šAC‡ukC.—œ6àŠåËÙT°EU±Uæ,³ÙmhªJqq1u¨Ùìöèÿš&Ë5P.5%…=z2zܸNã—¤NVÊfG«”Òˆª?ÑT¥&(¥jŸ,×p9!–iaºT¿%Ž. CïT Q¢í È“¤–¤–¤–¤–¤–èxCZIŠê©—2þûð ((Š‚ªª’ÔG†a°¹ €ýû÷…ä9 8].ºvíFÿ±Ù:Gs—eI!ׯ% 3rô˜˜xf‰–Ãïó±zå ¼^/ƒ† •’Zâè`oѦ?—ÛÝ©&÷'n‡ÁC‡³jÅ2©~K=èºÍnÇìD)xªŽª`Éò$Žj¥¨ªtµå÷TT™ÎHâh“:šS+±[…è4§$ù«( ëÈ¥så(“’:ÕE¥2Qe³oë-‰àñz“ë¯Ç›°÷íl¤n±¤fKs¡Iî%ÐTVâÆ¨32³8TZ’t핉 !©…ÕyÌ™JjAɆ…ìôëX¦‰YµÒl[›Ú"a’+ ‘™•°÷EQ:•£¬E’ÚÒËÙPêÂZI©0£‚DX,eÂÌÓÈÔâ[ûAXVM' ¢öTCö£°,„¢ ÖM('–°*í1ªm3EQkj–PPU¥’ZK\Þï$–Ô‰ QRýnˆÂ¢híJO>žÞéžÊeB!° w  gfÁŠ2LÑ¡Cm+ä@YUÓˆ œY ÖWíÕ(…ÅÁ”¥ e@Ww ÑÅ{ضs/ºª¡)`ššæ$§gºeEË÷o¢ "“‘ý»ÐÞxíħû$«¤öU”'Ì)(È«ÏD|{Ö°Û;œÉŠr –YÁ²eŒ›6 #TAĈª8M­Ö.Ù =™0$[%‰mÿžÅ1mxVuSXÏ6ú2¹W663Dذ@X”l]Ɇr7cÆL$Û뢪ý[†=»"Ø4ôpwLÿ"¶Jg`fûJ[^^†ÓåJXCLVIU>` @Jjš$um;:X\ÈâU»HË ³lá¬J§ƒ(Árf±aå÷X•„6B&N›Ñ¨¤qå ¤»Í–N0=Ç™;‚ÈŠ¥xÆwÁ2Àаf­ŸcN#ª:éþBV98iÆ8Üv‹P0@ÿC%;σ¢*Pi>¥÷Ï–yKá¤)PKý2M3a ¨Ílêi%«¤®(/Kã1±šO»#µ0ý¬ØâgP^&CŽ?«V2¼Ck?#cä)`5ûVŽÇë%à÷5~M#„^§ãPTbwBÈ xp%VŸaxÝA_Í„†âÕ[è9~&^§Àç 5¨Qèµ/¬ØØGgU™ÅèÔšj]øÅ|¦Î<1i\UŒËVóª‡oJòN”PUKt>›:aÁ' õtQòêF­a,ÓÄÄüŽîkYc–Ζå»6*Ì0ûƒ&ÝS\èzlEqâ¶)DZ0æ¨9ºa¶£9kÔí‰'›Ôã–Š¢Ææ·î$’:‘ŽGéýnвýÿöÎþ'Š#ŒãŸÙÙ½[7å­‡¶Bh­´("•Ä&}3é_ÝÛµ©m­&(Hy«PáØ½½Ýñ‡;àî<¶,¹ù&›»l&›Ù™ùÎ3Ï3ß}†_ïü5û}.Üý±æžò¦L蘕¿î¡Þ¿Æ¹öSÞf9H¦]\ ~Ý‘a|Èá.$Y]˪E¿·µ•^R[¥b@ì$3Ój©WW–yß0 ›J|r`R \®Ýøœ¬Ø k 8Rð¶­~­cÖç²` 39”G„JoWJ5 lœëÈòÇ¿EFœÃ„=416ú)bËâ“äžßl–ZñɾLÄó½ýËdÛ˜™^ä£áÖ}-ôúüCž•ò\í'£¼Òn£wÚ!JS/ìâÑFn|€QGÞ²Ž¥î®Ú$´»UÓ@ú£ßGhŒ#­–zey))—ÚøÔ{˜êA•–YÝ,‘ÍʽÍÊÓûÌ•ò\½x©‹ü ¦Ñ{úZxúªôFåì\?ãçCnO?eÉã¸rE¨R¥…7Å aa–\_èÝIãîw?ƒH¯"Å"Ñ ˜f³ÔF|²§kª£Ee~W)4«›«°øœ¶÷&±¥ hðœâÚ43sEòùUM/UIÐFÇ.#€ÖÁ ¬>˜Ç™ÊÔIÔ:ú?æjçKfŸüÆl¤‘BÅ1Rºôôã8’0Œv*·òç? NL «¶â„äZ[ð6 ©ì”Wd2™ÄbZ-õòÒb"ïëû¾Ÿ4‚Û×ÍýÛ·°4XÒÚYæÆq\ÑYq„åžæòP;q©ñ¶“Ûu…›ßähqE ¡w;ÀCfßeÐþ¿K½t5ГgÚº¸x%O&ë”ç–Ïr5aiw* ·˜uFø²Ý¥äïxê«ÏR„À²,´Öû¶n,õá–ßF|ÒÈU>ó!“×]Ü ¨PU>Ê–DZÛ–¿U€Žðý½}­< o1’çÆ&˜¹÷;§?½D£ïDâ(¤èí}*¤ŽŠ<ž^âêÔu2lÕ‘Ø+l¥›ÔqŒHÈïo6Km2Ÿì'‹Šø~yí½mDt¤P‘B…érQÈ.Ÿeµ ék;¼¬-svbœÎÖ þ–w²ñ‰h2íwRî†ÆÊÔL寴j¯£†Ìœ!ßîàØ‡¯¦ÛÓOwÎ%ô|NZw&->Y_{IÇé3©ûM2ðØL¤6y¿S­5·¾ÿ–OÆÆ±“Bî( ”âÁý_øâë›ÆR£OmrÉ)LŠ`ƒc&µlª}Õÿ%FaeÇÚ)¶D…ab‰øšÍ ‚'“5¤68>t÷ö2÷üƒvöª#±½×šÉf«mLÅ; 9S®¶œR!/æçéhšñceiìËâÉãǼ˜Ÿ«9†Õ¶%–°Ø¨dB +Éú,Kšruåp*×Bwï; Œ7É1F†Ô©]‚;H»">ÑÛ?å?–Ø …ÔÔL¹7Êi­w,¶Y~+” ›j LôÛÀÀÚÀÀÀÚÀÀÀÚÀÀà¿á5 LˆIŽîIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/tutorial/alegend.jpg0000644000175000017500000000712513070106167016725 00000000000000ÿØÿþK****JPEG Compressor Copyright (C) 1991-1992 Potapov WORKS, STOIK Ltd.****ÿàJFIFÿÛC     ÿÛC   ÿÀ&©"ÿÄ ÿĵ}!1AQa"q2‘¡#B±ÁRÑð$3br‚ %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyzƒ„…†‡ˆ‰Š’“”•–—˜™š¢£¤¥¦§¨©ª²³´µ¶·¸¹ºÂÃÄÅÆÇÈÉÊÒÓÔÕÖרÙÚáâãäåæçèéêñòóôõö÷øùúÿÄ ÿĵw!1AQaq"2B‘¡±Á #3RðbrÑ $4á%ñ&'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz‚ƒ„…†‡ˆ‰Š’“”•–—˜™š¢£¤¥¦§¨©ª²³´µ¶·¸¹ºÂÃÄÅÆÇÈÉÊÒÓÔÕÖרÙÚâãäåæçèéêòóôõö÷øùúÿÚ ?ýý¡|SªxàÄ¿h—_bÖ´ êz…×–²y3Åk$‘¾×[  á‚++þß‹¿è»|@ÿÀòªÚÇþMcã'ý‰šÏþÍ^«@Uÿ oÅßô]¾ à‡¿ùUGü)¿Ñvøÿ€>ÿåUz­å_ð¦ü]ÿEÛâþø{ÿ•T›ñwýoˆøáïþUU¯Úöð¯ìËð¾ûÇ^/k‡Óm¦†Ú;;»»–G #$‘°]òÝ‘ÈÜí5èN­c¯éVzž™yo¨é·°¥Í­å¤«,3Äê$GRC+)0$Aæ¿ð¦ü]ÿEÛâþø{ÿ•T›ñwýoˆøáïþUWªÑ@Uÿ oÅßô]¾ à‡¿ùUGü)¿Ñvøÿ€>ÿåUz­x§Ä¿Úk@ð¼öz^‹wöji>Yot˵Ӯ}RÞÒî {Í‹o=ÌQÉrLQÊîo.ôÄ2ª€k›ñwýoˆøáïþUQÿ oÅßô]¾ à‡¿ùU]§ñ—ÂZ?ŒÓÃZ…ÂjFhmd4ë™,m®% a·žõc6ðO'™Èe‘d> ª|è÷dë¿´wÃïx›XÐ/u«í-háÖ¶—yq§I¯fŽ&ŽÖªây™"ÂMóþæ]€áMø»þ‹·Äüð÷ÿ*¨ÿ…7âïú.ß?ðÃßüª®ƒÁ?|%ñU—OÐõ ‰î&êÝîtë›Xu pʦâÊY£D¼€‹3[´‘4'v%Œ±àŸŒ¾ø‡ªË§èz…Ä÷un÷:uͬ:…¸eSqe,Ñ¢^@ Å™­ÚHÀš»ÆXŸÿ…7âïú.ß?ðÃßüª£þß‹¿è»|@ÿÀòªªYøûǶÔüß²^ýžX<Ï.W‰þIU\aãqÊŒã# ƒ]]|«ÿ¸ÿ“øgÿq?ý:]×ÕTå_µüšÇÆOû5Ÿý!š½+VÓ!Ö´«Í>áî#·»…à‘í.d¶™U”©),l¯`ðèÁ”à‚¸¯ÚÂÚ§Ž~|KðÞ‰köÝkXðΧ§ØÚù‹<¶²GnrrÌX€3ɾø×ÿ1ð_ìíâ«_ üBøsñÃúÕÕ’jÚùZUÎèä_t:ƒ¨ËE Á9ùz`Œ€{_ü3O„è/ñÿ?ˆù:øfŸÿÐ_âþÿòu|«ÿ«ø!ÿB·ÄüXÿòeðú¿‚ô+|@ÿÁuÿ&PAûPÁ4®ÿh=WO‹LøËâxNÖÙ¼9­Üê"…ïU¥ì=ÝþQŒrˆðNÎkÒ¾~Å|1øq§xcÅ_|aã ½70ZjwŠ5ÍÔ"„ÛC©4CËE1„]Ü©fñ_ø}_Áú¾ àºÇÿ“(ÿ‡Õüÿ¡[âþ ¬ù2€>ªÿ†iðýþ áÇñÿ'V¯…¾xsÁúõ®¯a©xÂâîÛvÈõ_ë:…¹Ü¥Nø..䉸cÊppF|ÿ«ø!ÿB·ÄüXÿòeðú¿‚ô+|@ÿÁuÿ&PßõòSM«h_~ü!>ñE÷‹<-©ø:ÃUžÓE¸m6(,5M<Ëz—¬¢ d„8X™¦Eb‹ÊŸÉó_ø}_Áú¾ àºÇÿ“(ÿ‡Õüÿ¡[âþ ¬ù2€;_|+ñ)Ñ|wðÒóÄ¿ ÇŠu=vK] CÒì@¹±ÔïngËj²isUܸ˜K/ž¯¾DR†¶ö¿ü'®_|)ý¯í-ômBâï\ûwöTZ»>¡»ÂÚt ä(—3Fñ™Ë£/PEx¯ü>¯à‡ý ß?ð]cÿÉ”ÃêþЭñÿÖ?ü™@ÿûG|3×>(xªMHƒËþ×øgã5”qgouvúJ@³HªÛwl‘€Áb±H@;MjÜë—¾ |:};ÃÞ Ñ?áÖ§Ö5³â*k€¶™}d¶±JëåÝÊe¼Ý¾Ù¥ƒd1˜o€Mó_ü>¯à‡ý ß?ð]cÿÉ”ÃêþЭñÿÖ?ü™@Õÿ„ßÅZ±¥|.Ô>üm–÷N¸ñ§6“¶(,áûm¼Ú¼iö}F)-TÃHò°‘íÜÅ[³ÛzWÆ&ûÇž½°Ð¬î/5-Ä.¦ö’ÄÖæìY_Ùj2Eo$¡#‘ž(ÌhûÄ^iØò&É |—ÿ«ø!ÿB·ÄüXÿòeðú¿‚ô+|@ÿÁuÿ&P¯øûĺ·Åo˨x;ÀÆ·oeðçÅVéã\iÚn¥¨Ï.”ÐéòÅx!r®!;‹ªFêÎF1Ì#ÊÓ-[žjv7¯à‡ý ß?ð]cÿÉ”ÃêþЭñÿÖ?ü™@OþȺƒMû6ü9Ó.4ÝcHÔ´/éº>¡g­éZtÑ]Cg Ê¡.#Bê1! €Ç0ÁjÿäÖ<-ÿc¯þßQÿ«ø!ÿB·ÄüXÿòe|¿ÿ ÿ‚…ü:ý¬þ è¾ð†‹â;R²ñ¬’ëv¶ÑBbKk˜Šƒćvéã`z÷¯üãþLOáŸýÄÿôéw_UWÊ¿ðKù1?†÷ÿÓ¥Ý}U@x§Æ¿ØÏàïíâ«_|Bðü$Õ­’iðÝiÞ[m^I6Ã2)ÃK!Éùºà {]ò¯ü:ãöbÿ¢gÿ•ýSÿ’hÿ‡\~Ì_ôLÿò¿ªòM}UE|«ÿ¸ý˜¿è™ÿåTÿäš?á׳ý?ü¯êŸü“_UQ@*ÿî?f/ú&ù_Õ?ù&øuÇìÅÿDÏÿ+ú§ÿ$×ÕTPÊ¿ðëÙ‹þ‰ŸþWõOþI£þqû1Ñ3ÿÊþ©ÿÉ5õUò¯ü:ãöbÿ¢gÿ•ýSÿ’hÿ‡\~Ì_ôLÿò¿ªòM}UE|«ÿ¸ý˜¿è™ÿåTÿäš?á׳ý?ü¯êŸü“_UQ@*ÿî?f/ú&ù_Õ?ù&øuÇìÅÿDÏÿ+ú§ÿ$×ÕTPÊ¿ðëÙ‹þ‰ŸþWõOþI£þqû1Ñ3ÿÊþ©ÿÉ5õUò¯ü:ãöbÿ¢gÿ•ýSÿ’hÿ‡\~Ì_ôLÿò¿ªòM}UErŸ ~øcà·4Ïø7LþÆðÞ™æý’ËíÏåù’¼¯óÊÌç/#žXã8 ê袀?ÿÙngraph-gtk-6.08.00/doc/html/ja/tutorial/Makefile.am0000644000175000017500000000044413070106167016655 00000000000000htmltutorialdir = $(docdir)/html/ja/tutorial dist_htmltutorial_DATA = adialog.png alegend.jpg awindow.png \ axisref.jpg evaldlg.png fdialog.png fdialog2.png fdialog3.png \ fdup.png filedlg.png fitdlg.png focus.jpg fwindow.png \ fwindow2.png graphc.jpg graphf.jpg graphs.jpg window.png ngraph-gtk-6.08.00/doc/html/ja/tutorial/Makefile.in0000644000175000017500000003773013367273152016706 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc/html/ja/tutorial ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_htmltutorial_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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)$(htmltutorialdir)" DATA = $(dist_htmltutorial_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ htmltutorialdir = $(docdir)/html/ja/tutorial dist_htmltutorial_DATA = adialog.png alegend.jpg awindow.png \ axisref.jpg evaldlg.png fdialog.png fdialog2.png fdialog3.png \ fdup.png filedlg.png fitdlg.png focus.jpg fwindow.png \ fwindow2.png graphc.jpg graphf.jpg graphs.jpg window.png 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) --gnu doc/html/ja/tutorial/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/html/ja/tutorial/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_htmltutorialDATA: $(dist_htmltutorial_DATA) @$(NORMAL_INSTALL) @list='$(dist_htmltutorial_DATA)'; test -n "$(htmltutorialdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmltutorialdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmltutorialdir)" || 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)$(htmltutorialdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmltutorialdir)" || exit $$?; \ done uninstall-dist_htmltutorialDATA: @$(NORMAL_UNINSTALL) @list='$(dist_htmltutorial_DATA)'; test -n "$(htmltutorialdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmltutorialdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)$(htmltutorialdir)"; 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_htmltutorialDATA 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_htmltutorialDATA .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_htmltutorialDATA 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_htmltutorialDATA .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: ngraph-gtk-6.08.00/doc/html/ja/tutorial.html0000644000175000017500000013467013251136374015524 00000000000000 Tutorial  

ãƒãƒ¥ãƒ¼ãƒˆãƒªã‚¢ãƒ«


外観

  1. èµ·å‹•ç”»é¢

    Ngraph ã‚’èµ·å‹•ã™ã‚‹ã¨ä¸‹å›³ã®ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ãŒé–‹ã‹ã‚Œã¾ã™ã€‚

    ã“ã“ã§ã¯ã€ç°¡å˜ã«ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã®èª¬æ˜Žã‚’ã—ã¾ã™ã€‚

      コントロールボタン(上部)
      通常ã®ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã‚¢ãƒ—リケーションã¨åŒæ§˜ã«ã€ãƒ•ァイルã®ã‚ªãƒ¼ãƒ—ン ãªã©é »ç¹ã«ä½¿ã†ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚³ãƒžãƒ³ãƒ‰ãŒãƒœã‚¿ãƒ³ã«å‰²ã‚Šå½“ã¦ã‚‰ã‚Œã¦ã„ã¾ã™ã€‚
      コントロールボタン(左サイド)
      マウスã«ã‚ˆã‚‹æ“作モードを指定ã™ã‚‹ãƒˆã‚°ãƒ«ãƒœã‚¿ãƒ³åˆ—ã§ã™ã€‚グラフィッ クスオブジェクトã®é¸æŠžãƒ¢ãƒ¼ãƒ‰ã€ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ç¨®é¡žåˆ¥ã®ä½œæˆãƒ¢ãƒ¼ãƒ‰ã€ プロットã•れãŸãƒ‡ãƒ¼ã‚¿ã®è©•価モードã€ç”»é¢ã®æ‹¡å¤§ç¸®å°ãƒ¢ãƒ¼ãƒ‰ãªã©ã‚’ 切り替ãˆã¾ã™ã€‚
      サイドãƒãƒ¼

      グラフã®å³ã«è¡¨ç¤ºã•れã€ä¸Šéƒ¨ã«ãƒ‡ãƒ¼ã‚¿ã‚„軸ãªã©ã‚’一覧表示ã™ã‚‹ タブã€ä¸‹éƒ¨ã«ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ä½ç½®ã‚„ãƒ•ã‚£ãƒƒãƒ†ã‚£ãƒ³ã‚°ã®æƒ…報を表示㙠る場所ãŒã‚りã¾ã™ã€‚タブã®é †ç•ªãƒ»ä½ç½®ã¯ãƒ‰ãƒ©ãƒƒã‚°ï¼†ãƒ‰ãƒ­ãƒƒãƒ—ã§è‡ªç”± ã«å¤‰æ›´ã§ãã¾ã™ã€‚

      Data タブ

      é–‹ã‹ã‚ŒãŸãƒ‡ãƒ¼ã‚¿ãƒ•ァイルãŒä¸€è¦§è¡¨ç¤ºã•れã¾ã™ã€‚ã¾ãŸã€ãƒ— ロットã®ç‚ºã®å„種パラメターも一覧表示ã•れã¾ã™ã€‚ã“ã®ãƒªã‚¹ トをダブルクリックã™ã‚‹ã¨ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ã〠å„種設定を変更ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

      Axis タブ

      座標軸ã®åå‰ã¨ã€ã‚¹ã‚±ãƒ¼ãƒ«ã®æ•°å€¤ãªã©ã®å„種パラメター ãŒä¸€è¦§è¡¨ç¤ºã•れã¾ã™ã€‚ã“ã®ãƒªã‚¹ãƒˆã‚’ダブルクリックã™ã‚‹ã¨è»¸ ダイアログボックスãŒé–‹ãã€å„種設定を変更ã™ã‚‹äº‹ãŒã§ãã¾ ã™ã€‚

      Merge タブ

      åˆæˆãƒ•ァイルã¨å„種パラメターãŒä¸€è¦§è¡¨ç¤ºã•れã¾ã™ã€‚ã“ ã®ãƒªã‚¹ãƒˆã‚’ダブルクリックã™ã‚‹ã¨åˆæˆãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒ é–‹ãã€å„種設定を変更ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

      Path, Rectangle, Arc, Mark, Text タブ

      å„レジェンドを一覧表示ã—ã¾ã™ã€‚ã“ã®ãƒªã‚¹ãƒˆã‚’ダブルク リックã™ã‚‹ã¨å„レジェンドã®ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ãã€å„ 種設定を変更ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

      Coordinate 表示

      グラフã®ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ã®ä½ç½®ãŒè¡¨ç¤ºã•れã¾ã™ã€‚ ã¾ãŸã€åº§æ¨™è»¸ãŒæœ‰ã‚‹å ´åˆã«ã¯ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ã®ä½ç½®ã«å¯¾å¿œã™ る軸ã®åº§æ¨™ã‚‚表示ã•れã¾ã™ã€‚

      Information 表示

      フィットã®çµæžœç­‰ãŒè¡¨ç¤ºã•れã¾ã™ã€‚

    [表示]-[シングルウィンドウモード] ([View]-[single window mode]) ã® ãƒã‚§ãƒƒã‚¯ã‚’外ã™ã“ã¨ã§ã€å·¦å´ã®ã‚¿ãƒ–を独立ã—ãŸã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã«åˆ†é›¢ã™ã‚‹ã“㨠もã§ãã¾ã™ã€‚ã“ã®å ´åˆã€ãƒ‡ãƒ¼ã‚¿ä¸€è¦§ã‚’表示ã™ã‚‹ "Data Window"ã€è»¸ã®ä¸€è¦§ を表示ã™ã‚‹ "Axis Window"ã€ã‚°ãƒ©ãƒ•上ã®ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ä½ç½®ãŒè¡¨ç¤ºã•れる "Coordinate Window"ã€ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã‚’一覧表示ã™ã‚‹ "Legend Window"ã€åˆæˆ ファイルを一覧表示ã™ã‚‹ "Merge Window"ã€ãƒ•ィットã®çµæžœç­‰ã‚’表示ã™ã‚‹ "Information Window" ã®å„ウィンドウを開ã事ãŒã§ãã¾ã™ã€‚ã¾ãŸã€å„ウィ ンドウ上ã§ãƒžã‚¦ã‚¹ã®å³ãƒœã‚¿ãƒ³ã‚’クリックã™ã‚‹ã¨ã€ãれãžã‚Œã®ã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ ç•°ãªã‚‹ãƒãƒƒãƒ—アップメニューを出ã™äº‹ãŒã§ãã€å„種æ“作ãŒè¡Œãˆã‚‹ã‚ˆã†ã«ãªã£ ã¦ã„ã¾ã™ã€‚


グラフ作æˆã®æ¦‚ç•¥

  1. データファイルを用æ„ã™ã‚‹

    Ngraphã¯ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã‹ã‚‰ãƒ‡ãƒ¼ã‚¿ã‚’読ã¿è¾¼ã¿ã‚°ãƒ©ãƒ•を作æˆã—ã¾ã™ã€‚ 従ã£ã¦ã€ã¾ãšãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを用æ„ã—ãªã‘れã°ãªã‚Šã¾ã›ã‚“。 エディターã€è¨ˆç®—プログラムã€ã‚ã‚‹ã„ã¯æ¸¬å®šè£…置コントロールソフトãªã©ã‹ã‚‰ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを作æˆã—ã¾ã™ã€‚

  2. グラフã®ç¨®é¡žã‚’決ã‚ã‚‹

    グラフã«ã™ã‚‹ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを用æ„ã—ãŸã‚‰Ngraphã‚’èµ·å‹•ã—ã¾ã™ã€‚次ã«ä½œæˆ ã—ãŸã„グラフã®ç¨®é¡žã‚’決ã‚ã¾ã™ã€‚ Ngraphã§ã¯ä»¥ä¸‹ã®3ã¤ã«åˆ†é¡žã•れã¦ã„ã¾ã™ã€‚

    フレームグラフ(Frame graph)
    4ã¤ã®è»¸ã§å›²ã¾ã‚ŒãŸã‚°ãƒ©ãƒ•
    方眼グラフ(Section graph)
    4ã¤ã®è»¸ã§å›²ã¾ã‚Œã€æ–¹çœ¼ç·šã®å…¥ã£ãŸã‚°ãƒ©ãƒ•
    交差グラフ(Cross graph)
    X-Y2軸ã®ã‚°ãƒ©ãƒ•

    åˆæœŸçŠ¶æ…‹ã§ã¯ãƒ•レームグラフãŒä¸€ã¤ä½œæˆã•れã¦ã„ã¾ã™ã€‚ フレームグラフã®ï¼”ã¤ã®è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã¯ã¾ã è¨­å®šã•れã¦ã„ã¾ã›ã‚“ã®ã§ã€è»¸ã®åŸºç·šã‚’ç¤ºã™æž ã ã‘ãŒè¡¨ç¤ºã•れã¦ã„ã¾ã™ã€‚ ã“れã§è‰¯ã‘ã‚Œã°æ¬¡ã«é€²ã¿ã¾ã™ã€‚ ä»–ã®ç¨®é¡žã®ã‚°ãƒ©ãƒ•を作æˆã™ã‚‹ã«ã¯ã€[グラフ]-[æ–°è¦ä½œæˆ]([Graph]-[New graph])メニューã§ä½œæˆã™ã‚‹ã‚°ãƒ©ãƒ•ã®ç¨®é¡žã‚’指定ã—ã¾ã™ã€‚

  3. データファイルを開ã

    次ã«ã€æº–å‚™ã—ã¦ã‚るデータファイルを開ãã¾ã™ã€‚ データファイルを開ãã«ã¯æ§˜ã€…ãªæ–¹æ³•ãŒæœ‰ã‚Šã¾ã™ãŒã€ å–り敢ãˆãš[データ]-[追加]メニューをé¸ã³ã€ ãƒ•ã‚¡ã‚¤ãƒ«é¸æŠžã®ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã§ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを開ã„ã¦ãã ã•ã„。

    ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã‚’é–‹ãæ–¹æ³•ã¯ä»–ã«ã‚‚用æ„ã•れã¦ã„ã¾ã™ã€‚

    1. 下図ã®ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’押ã™ã€‚

      file open control button

    2. Data タブ上ã§ãƒžã‚¦ã‚¹å³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒãƒƒãƒ—アップメニューを出ã—ã€"追加(A)" メニューをé¸ã¶ã€‚
    3. ファイルマãƒãƒ¼ã‚¸ãƒ£ãƒ¼ç­‰ã‹ã‚‰ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルをé¸ã³ã€ã‚°ãƒ©ãƒ•ã¾ãŸã¯ Data タブ上ã«ãƒ‰ãƒ©ãƒƒã‚°&ドロップã™ã‚‹ã€‚

    ã„ãšã‚Œã®æ–¹æ³•ã§ã‚‚〠データファイルを指定ã™ã‚‹ã¨æ¬¡ã„ã§ãƒ—ロット方法ãªã©ã‚’指定ã™ã‚‹ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ãã¾ã™ãŒã€ å–り敢ãˆãš OK ã§é–‰ã˜ã¦ãã ã•ã„。

  4. æç”»ã™ã‚‹

    Ngraphã§ã¯ãƒ•ァイルを開ã„ã¦ã‚‚自動的ã«ã¯æç”»ã—ãªã„よã†ã«ãªã£ã¦ã„ã¾ã™ã€‚ グラフをæç”»ã™ã‚‹ã«ã¯ä¸‹å›³ã®ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãã ã•ã„。

    æç”»ã™ã‚‹æ–¹æ³•ã¯ä»–ã«ã‚‚用æ„ã•れã¦ã„ã¾ã™ã€‚

    1. [表示]-[æç”»]([View]-[Draw])ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’é¸æŠžã™ã‚‹ã€‚
    2. グラフ上ã§ã‚¯ãƒªãƒƒã‚¯ã—ã¦ã‚¹ãƒšãƒ¼ã‚¹ã‚­ãƒ¼ã‚’押ã™ã€‚

    ã“ã®æ§˜ã«ã—ã¦æç”»ã™ã‚‹ã¨è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã¯å°‘ã—余白をã¨ã‚‹ã‚ˆã†ã«è‡ªå‹•çš„ã«è¨­å®šã•れã€ã‚°ãƒ©ãƒ•ãŒæç”»ã•れã¾ã™ã€‚


軸ã®ã‚¹ã‚±ãƒ¼ãƒ«

  1. スケールを変ãˆã‚‹

    特ã«ã‚¹ã‚±ãƒ¼ãƒ« (座標軸ã®ä¸Šé™ãƒ»ä¸‹é™)を設定ã›ãšã«æç”»ã—ãŸå ´åˆã«ã¯ã‚ªãƒ¼ãƒˆã‚¹ã‚±ãƒ¼ãƒ«ã§å€¤ãŒæ±ºã‚られã¾ã™ã€‚ ã¾ãŸ Axis タブã«ã¯è»¸ãŒä¸€è¦§è¡¨ç¤ºã•れã¦ã„ã¾ã™ã€‚ フレームグラフã®å ´åˆã«ã¯è»¸ã¯ï¼”ã¤ã‚りã€ãれãžã‚Œ "fX1", "fY1", "fU1", "fR1" ã¨åå‰ãŒä»˜ã„ã¦ã„ã¾ã™ã€‚ ã“れらã®è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’変更ã™ã‚‹ã«ã¯ã€ä¸‹å›³ã®æ§˜ã« Axis タブã®ä¸€è¦§ã‹ã‚‰å¤‰æ›´ã—ãŸã„軸をé¸ã‚“ã§ãƒ€ãƒ–ルクリックã—ã¦ãã ã•ã„。

    è»¸ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’é–‹ãæ–¹æ³•ã¯ä»–ã«ã‚‚用æ„ã•れã¦ã„ã¾ã™ã€‚

    1. [軸]-[設定] ([Axis]-[Update]) メニューã§ãƒ—変更ã—ãŸã„軸をé¸ã¶ã€‚
    2. 下図ボタンã®ã„ãšã‚Œã‹ä¸€æ–¹ (ã©ã¡ã‚‰ã§ã‚‚良ã„ã§ã™)を押ã—ã¦ã‚°ãƒ©ãƒ•ã‚£ãƒƒã‚¯ã‚¹ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆé¸æŠžãƒ¢ãƒ¼ãƒ‰ (ã‚ã‚‹ã„ã¯è»¸ã®ã¿ã®é¸æŠžãƒ¢ãƒ¼ãƒ‰)ã«ã—ã¦ã‚°ãƒ©ãƒ•上ã§è»¸ã‚’ダブルクリックã—〠次ã„ã§å‡ºã¦ãるダイアログボックスã§å¤‰æ›´ã—ãŸã„軸ã®ãƒœã‚¿ãƒ³ã‚’押ã™ã€‚

    ã“ã®æ§˜ã«ã™ã‚‹ã¨ä¸‹å›³ã®è»¸ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ã‹ã‚Œã¾ã™ã€‚ ã“ã“ã§ã€ã€Œæœ€å°å€¤ã€ã€Œæœ€å¤§å€¤ã€ã€Œå¢—分ã€ã«è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã®æœ€å°ï¼Œæœ€å¤§ï¼Œå¢—分を指定ã—ã¦ãã ã•ã„。 目盛数字ã¯å¢—分ã«å¯¾ã—ã¦ä»˜ã‘られã¾ã™ã€‚ 「分割数ã€ã¯ã€Œå¢—分ã€ã‚’ã•らã«ä½•等分ã—ã¦ç›®ç››ç·šã‚’引ãã‹ã‚’決ã‚ã¾ã™ã€‚ ã“ã®å€¤ãŒ0ã®æ™‚ã¯è‡ªå‹•çš„ã«åˆ†å‰²æ•°ãŒæ±ºã‚られã¾ã™ã€‚ 「スケール法ã€ã§ã¯é€šå¸¸ã®ç·šå½¢è»¸ï¼ˆlinear)ã€ãƒ­ã‚°(log)ã€é€†æ•°(inverse)ã€MJD ã®ä¸­ã‹ã‚‰ï¼‘ã¤ã‚’é¸ã¶äº‹ãŒã§ãã¾ã™ã€‚ 「ファイルã€ãƒœã‚¿ãƒ³ã‚’押ã™ã¨ã‚¹ã‚±ãƒ¼ãƒ«ã‚’é–‹ã„ãŸãƒ‡ãƒ¼ã‚¿ãƒ•ァイル中ã‹ã‚‰æŒ‡å®šã—ãŸãƒ•ァイルã§ã‚ªãƒ¼ãƒˆã‚¹ã‚±ãƒ¼ãƒ«ã‚’行ã£ã¦æ±ºã‚る事ãŒã§ãã¾ã™ã€‚ 「クリアã€ã¯ã‚¹ã‚±ãƒ¼ãƒ«ã®è¨­å®šã‚’未設定状態ã«ã—ã¾ã™ã€‚

    ã•らã«è»¸ã«é–¢ã™ã‚‹ç´°ã‹ã„設定ãŒã§ãるよã†ã«ã€Œè»¸åŸºç·šã€ã€Œç›®ç››ç·šã€ã€Œç›®ç››æ•°å­—ã€ã€Œãƒ•ォントã€ã€Œä½ç½®ã€ã®ãƒœã‚¿ãƒ³ãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚ 「軸基線ã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦è»¸ã®åŸºç·šã®å¤ªã•ã€è‰²ãªã©ã®è¨­å®šã‚’行ã„ã¾ã™ã€‚ 軸ã®ç«¯ã«çŸ¢å°ã‚’ã¤ã‘ãŸã‚Šã™ã‚‹ã“ã¨ã‚‚ã§ãã¾ã™ã€‚ 「目盛線ã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦è»¸ã®"ゲージ"ã®é•·ã•ã€å¤ªã•ã€è‰²ãªã©ã®è¨­å®šã‚’行ã„ã¾ã™ã€‚ ã¾ãŸã€ç›®ç››ç·šã‚’グラフã®å†…å´ã«æãã‹å¤–å´ã«æãã‹ã‚’決ã‚ãŸã‚Š(「ä½ç½®ã€)ã€è»¸ã‚’全部æã‹ãšã«ä¸€éƒ¨ã ã‘ã«ã—ãŸã‚Š(「範囲最å°å€¤ã€ã€ã€Œç¯„囲最大値ã€)ã§ãã¾ã™ã€‚ 「目盛数字ã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ã€ãã®"ゲージ" ã«æŒ¯ã‚‹ç›®ç››æ•°å­—ã«é–¢ã™ã‚‹è¨­å®šã‚’行ã„ã¾ã™ã€‚ 目盛数字を振り始ã‚るスケールã®ä½ç½®ã‚’変ãˆãŸã‚Šï¼ˆã€Œé–‹å§‹ç‚¹ã€ã€0ã§è‡ªå‹•設定)〠間隔を変ãˆãŸã‚Š(「間隔ã€ã€0ã§è‡ªå‹•設定)〠個数を変ãˆãŸã‚Š(「個数ã€ã€-1ã§è‡ªå‹•設定)ã§ãã¾ã™ã€‚ 「フォントã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ç›®ç››æ•°å­—ã®ãƒ•ォントã®è¨­å®šã‚’行ã„ã¾ã™ã€‚

  2. スケールをクリアã™ã‚‹

    å‰ç¯€ã§èª¬æ˜Žã—ãŸã‚ˆã†ã«ã€è»¸ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œã‚¯ãƒªã‚¢ã€ãƒœã‚¿ãƒ³ã§ã€ 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«è¨­å®šã‚’未設定状態ã«ã§ãã¾ã™ãŒã€ 複数ã®è»¸ã‚’クリアã—ãŸã„よã†ãªå ´åˆã«ã¯[軸]-[スケールクリア]メニューã§ã‚¯ãƒªã‚¢ã—ãŸã„軸を複数指定ã—ã€ä¸€æ‹¬ã—ã¦ã‚¯ãƒªã‚¢ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚ ã‚ã‚‹ã„ã¯ä¸‹å›³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ã‚‚åŒã˜ã‚ˆã†ã«è¤‡æ•°ã®è»¸ã‚’クリアã§ãã¾ã™ã€‚

  3. 一部を拡大ã™ã‚‹

    å‰ç¯€ã®ã‚ˆã†ã«è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã¯æ•°å€¤ã‚’入力ã—ã¦å¤‰æ›´ã—ã¾ã™ãŒã€ã‚°ãƒ©ãƒ•ã®ä¸€éƒ¨ã‚’拡大ã—ã¦æç”»ã—ãŸã„時ãªã©ã¯ã‚°ãƒ©ãƒ•ィカルã«å¤‰æ›´ã™ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚ ãれã«ã¯ä¸‹å›³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒˆãƒªãƒŸãƒ³ã‚°ãƒ¢ãƒ¼ãƒ‰ã«ã—ã¦ã‚°ãƒ©ãƒ•上ã§è»¸ã®ç¯„å›²ã‚’ãƒžã‚¦ã‚¹ã§æŒ‡å®šã—ã¾ã™ã€‚

  4. スケールã®å€¤ã‚’å…ƒã«æˆ»ã™

    軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã®è¨­å®šã¯ã€å„軸10個ã¾ã§å±¥æ­´ãŒè¨˜æ†¶ã•れã¦ã„ã¾ã™ã€‚ 従ã£ã¦å‰ç¯€ã®ã‚ˆã†ã«ä¸€éƒ¨ã‚’拡大æç”»ã—ãŸå¾Œã«ã€å…ƒã®ã‚¹ã‚±ãƒ¼ãƒ«ã®è¨­å®šã«ç°¡å˜ã«æˆ»ã™äº‹ãŒã§ãã¾ã™ã€‚ ãれã«ã¯ä¸‹å›³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦è¨­å®šã‚’戻ã—ãŸã„軸を指定ã—ã¦ãã ã•ã„。


プロット方法

  1. プロット方法を変ãˆã‚‹

    デフォルトã®çŠ¶æ…‹ã§ã¯ã€é»’ã„点ã§ãƒ‡ãƒ¼ã‚¿ç‚¹ãŒãƒ—ロットã•れã¾ã™ã€‚ã¾ãŸã€Data タブã«ã¯é–‹ã„ãŸãƒ‡ãƒ¼ã‚¿ãƒ•ァイルãŒä¸€è¦§è¡¨ç¤ºã•れã¦ã„ã¾ã™ã€‚ プロット方法を変ãˆã‚‹ç‚ºã«ã€Data タブã®ä¸€è¦§è¡¨ç¤ºã‚’ダブルクリックã—ã¦ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’é–‹ã„ã¦ãã ã•ã„。

    データダイアログボックスã¯ãã®ä»–ã«æ¬¡ã®æ–¹æ³•ã§é–‹ãã“ã¨ãŒã§ãã¾ã™ã€‚

    1. [データ]-[設定] ([Data]-[Update]) メニューã§ãƒ—ロットã—ãŸã„データファイルをé¸ã¶
    2. 下図ボタンを押ã—ã¦ãƒ‡ãƒ¼ã‚¿é¸æŠžãƒ¢ãƒ¼ãƒ‰ã«ã—ã¦ã‚°ãƒ©ãƒ•上ã§ãƒ‡ãƒ¼ã‚¿ã‚’クリックã™ã‚‹

    3. Data タブ上ã§ãƒžã‚¦ã‚¹å³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒãƒƒãƒ—アップメニューを出ã—ã€"プロパティ(P)" メニューをé¸ã¶

    ã“ã®æ§˜ã«ã™ã‚‹ã¨ä¸‹å·¦å›³ã«ç¤ºã™ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒç¾ã‚Œã¾ã™ã€‚

    例ãˆã°ãƒ—ロット方法を変更ã—ã¦ãƒ‡ãƒ¼ã‚¿ã‚’曲線ã§çµã¶ã‚ˆã†ã«ã™ã‚‹ã«ã¯ä¸Šå³å›³ã«ã®æ§˜ã«ãƒ—ロットタイプを "曲線" ã«ã—ã¾ã™ã€‚ ãã®å¾Œã€ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’ OK ã§é–‰ã˜ã€ã‚‚ã†ä¸€åº¦æç”»ã—ã¦ãã  ã•ã„。

    データダイアログボックスã§ã¯ã€ãã®ä»–ã«ãƒ‰ãƒƒãƒˆã®å¤§ãã•ã€å¹…ã€è‰²ãªã©ã®è¨­å®šãŒè¡Œãˆã¾ã™ã€‚ ã¾ãŸãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®å…ˆé ­ã«ä½•ã®ãƒ‡ãƒ¼ã‚¿ã§ã‚ã‚‹ã‹ã®æ³¨é‡ˆã‚’ã¤ã‘ã¦ãŠã事ãŒå¤šã„ã¨æ€ã„ã¾ã™ãŒã€ ãã®éƒ¨åˆ†ã‚’読ã¿é£›ã°ã™ã®ã«ã¯ã€Œèª­è¾¼ã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ã€Œå…ˆé ­ã‚¹ã‚­ãƒƒãƒ—行ã€ã‚’設定ã—ã¾ã™ã€‚

  2. 曲線+点ã§ãƒ—ロットã™ã‚‹

    データを曲線ã¨ç‚¹ã®ä¸¡æ–¹ã§ãƒ—ロットã™ã‚‹ã‚ˆã†ã«ã™ã‚‹ã«ã¯ã€ åŒã˜ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを二度開ãã€ç‰‡æ–¹ã‚’曲線ã§ã€ã‚‚ã†ç‰‡æ–¹ã‚’点ã§ãƒ—ロットã™ã‚‹ã‚ˆã†ã«è¨­å®šã—ã¾ã™ã€‚ åŒã˜ãƒ‡ãƒ¼ã‚¿2度開ãã®ã‚‚基本的ã«ã¯å‰ç¯€ã§ç¤ºã—ãŸæ–¹æ³•ã§ã€ 二回開ã‘ã°è‰¯ã„ã®ã§ã™ãŒã€ã™ã§ã«é–‹ã„ã¦æœ‰ã‚‹ãƒ•ァイルをもã†ä¸€åº¦é–‹ãã«ã¯ä¸‹å›³ã«ç¤ºã—ãŸã‚ˆã†ã« Data タブ上ã§ãƒžã‚¦ã‚¹å³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒãƒƒãƒ—アップメニューを出㗠"複製(D)" メニューをé¸ã³è¤‡è£½ã‚’生æˆã™ã‚‹ã®ãŒã‚ˆã‚Šç°¡å˜ã§ã™ã€‚ Data タブã§INSキーを押ã™äº‹ã§ã‚‚åŒæ§˜ã®æ“作ãŒè¡Œãˆã¾ã™ã€‚ 下左図㯠Data タブã§ãƒãƒƒãƒ—アップメニューを出ã—ãŸçŠ¶æ…‹ã§ã™ã€‚ "複製(D)"メニューをé¸ã¶äº‹ã§ä¸‹å³å›³ã®ã‚ˆã†ã« Data タブã«ã¯åŒã˜ãƒ•ァイルãŒ2ã¤ãƒªã‚¹ãƒˆã•れるよã†ã«ãªã‚Šã¾ã™ã€‚

    ã“ã®ã‚ˆã†ã«ã—ã¦2度開ã„ãŸãƒ•ァイルã®ãƒ—ロットã®è¨­å®šã‚’〠片方ã®ãƒ—ロットを "マーク" ã«ã€ã‚‚ã†ç‰‡æ–¹ã‚’ "曲線" ã«ã™ã‚‹äº‹ã§ã€ ãƒ‡ãƒ¼ã‚¿ã¯æ›²ç·šã¨ç‚¹ã®ä¸¡æ–¹ã§ãƒ—ロットã•れるよã†ã«ãªã‚Šã¾ã™ã€‚

  3. データ点ã®è©•価・マスク・移動

    プロットã—ãŸãƒ‡ãƒ¼ã‚¿ã®å€¤ã¯ã‚°ãƒ©ãƒ•ã®åº§æ¨™å€¤ã‹ã‚‰èª­ã¿å–る時ã«ã€ グラフ上ã§ãƒžã‚¦ã‚¹å³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒãƒƒãƒ—アップメニューを出ã—〠"クロスゲージ(G)" ã‚’é¸ã¶ã¨ã€ãƒžã‚¦ã‚¹ã‚«ãƒ¼ã‚½ãƒ«ã«ç¸¦æ¨ªã®ã‚¯ãƒ­ã‚¹ã‚²ãƒ¼ã‚¸ãŒç¾ã‚Œã¾ã™ã®ã§ã€åº§æ¨™å€¤ã‚’読ã¿å–ã‚‹ã®ã«ä¾¿åˆ©ã§ã™ã€‚ ã¾ãŸã€ã‚‚ã£ã¨ç›´æŽ¥çš„ã«æ•°å€¤ã‚’知りãŸã„ã¨ãã«ã¯ã€ 下図ã®ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ã€Œè©•価モードã€ã«ã—ã¦ã‹ã‚‰ã‚°ãƒ©ãƒ•上ã§ãƒ‡ãƒ¼ã‚¿ã‚’クリックã—ã¾ã™ã€‚

    ã™ã‚‹ã¨ãƒžã‚¦ã‚¹ãƒã‚¤ãƒ³ã‚¿ãƒ¼ã«è¿‘ã„データã®ä¸€è¦§ãŒãƒªã‚¹ãƒˆã‚¢ãƒƒãƒ—ã•れã¾ã™ã€‚

    ã“ã“ã§ãƒªã‚¹ãƒˆã‚¢ãƒƒãƒ—ã•れãŸé …ç›®ã®ã€Œ#ã€ã¯ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®ç•ªå·ã€ 「行ã€ã¯ãã®ãƒ•ァイル中ã®è¡Œæ•°ã€ã€Œï¼¸ã€ï¼¹ã€ãŒåº§æ¨™å€¤ã‚’示ã—ã¦ã—ã¾ã™ã€‚ リストボックスã®ä¸­ã®é …ç›®ã‚’é¸æŠžã—「Maskã€ãƒœã‚¿ãƒ³ã‚’押ã™äº‹ã§ã€ãƒ‡ãƒ¼ã‚¿ã®ä¸€éƒ¨ã ã‘ã‚’æã‹ãªãã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚ ã¾ãŸã€ã€ŒMoveã€ãƒœã‚¿ãƒ³ã‚’押ã™ã¨ã€ãƒ‡ãƒ¼ã‚¿ã‚’移動ã•ã›ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚ ã“れらマスクã€ç§»å‹•ã®è§£é™¤ã¯ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œãƒžã‚¹ã‚¯ã€ã€Œç§»å‹•ã€ã§è¡Œã„ã¾ã™ã€‚


グラフを飾りã¥ã‘ã‚‹

  1. Legend を入れる

    図ã«ãƒ†ã‚­ã‚¹ãƒˆã€çŸ¢å°ãªã©ã‚’入れるã«ã¯ã€ 下図ã®ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’押ã—ã¦Legend ã®ç¨®é¡žã‚’é¸ã³ã€ãƒžã‚¦ã‚¹ã§ä½ç½®ã‚’決ã‚ã¾ã™ã€‚ Legend ã®ä½œæˆãŒçµ‚ã‚ã‚‹ã¨ãƒžã‚¦ã‚¹ã¯é¸æŠžãƒ¢ãƒ¼ãƒ‰ã«æˆ»ã‚Šã¾ã™ã€‚ 複数㮠Legend を作æˆã—ãŸã„ã¨ã㯠SHIFT キーを押ã—ãªãŒã‚‰ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’クリックã—ã¦ãã ã•ã„。 ã¾ãŸ Legend ã®ä½ç½®æŒ‡å®šæ™‚ã« CTL キーを押ã—ãªãŒã‚‰ãƒžã‚¦ã‚¹ã‚’æ“作ã™ã‚‹ã¨ã€è§’åº¦ã‚„ç¸¦æ¨ªã®æ¯”を制é™ã§ãã¾ã™ã€‚

    直線・曲線を作æˆã—ã¾ã™ã€‚
    矩形を作æˆã—ã¾ã™ã€‚
    円・楕円を作æˆã—ã¾ã™ã€‚
    ãƒ‡ãƒ¼ã‚¿ãƒ—ãƒ­ãƒƒãƒˆå½¢å¼ "マーク" ã«å¯¾å¿œã™ã‚‹ãƒžãƒ¼ã‚¯ã‚’作æˆã—ã¾ã™ã€‚
    テキストを作æˆã—ã¾ã™ã€‚
    ガウス関数, ローレンツ関数, 放物線, 正弦曲線を作æˆã—ã¾ã™ã€‚
    作æˆã—ãŸæ›²ç·šã¯ãŸã ã¡ã«ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰-曲線ã«å±•é–‹ã•れるã®ã§, 一度作æˆã™ã‚‹ã¨é–¢æ•°ã¨ã—ã¦ã®å¤‰æ›´ã¯ã§ãã¾ã›ã‚“。

    文字列をグラフ上ã«ãƒ‰ãƒ©ãƒƒã‚°&ドロップã™ã‚‹ã“ã¨ã§ã‚‚テキストを作æˆã§ãã¾ã™ã€‚

  2. グラフ上ã§ã®ç§»å‹•ã€è¨­å®šå¤‰æ›´

    マウスã«ã‚ˆã£ã¦ Legendã€Axis ãªã©ã®è¨­å®šã®å¤‰æ›´ã€ç§»å‹•ã€æ‹¡å¤§ç¸®å°ãªã©ã‚’行ã†äº‹ã‚‚ã§ãã¾ã™ã€‚ Ngraph ã«ã¯ã€ãã®ç‚ºã®ãƒžã‚¦ã‚¹ãƒã‚¤ãƒ³ã‚¿ãƒ¼ã®ãƒ¢ãƒ¼ãƒ‰ãŒï¼”種類ã‚ã‚‹ã®ã§æ³¨æ„ãŒå¿…è¦ã§ã™(下図)。

    ã“ã“ã§ã€"legend+axis" ã®ãƒã‚¤ãƒ³ã‚¿ãƒ¼ãƒ¢ãƒ¼ãƒ‰ã§ã¯ã€ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã¨è»¸ã‚’é¸æŠžã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚ "legend" ã®ãƒã‚¤ãƒ³ã‚¿ãƒ¼ãƒ¢ãƒ¼ãƒ‰ã§ã¯ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã®ã¿ãŒé¸æŠžå¯¾è±¡ã«ãªã‚Šã¾ã™ã€‚ 軸ã¨ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ãŒè¾¼ã¿åˆã£ã¦ã„ã¦è»¸ã‚’é¸æŠžã—ãŸãç„¡ã„よã†ãªå ´åˆã«ä½¿ã£ã¦ãã ã•ã„。 "axis" ã®ãƒã‚¤ãƒ³ã‚¿ãƒ¼ãƒ¢ãƒ¼ãƒ‰ã§ã¯é€†ã«è»¸ã®ã¿ãŒé¸æŠžå¯¾è±¡ã«ãªã‚Šã¾ã™ã€‚ "data" ã®ãƒã‚¤ãƒ³ã‚¿ãƒ¼ãƒ¢ãƒ¼ãƒ‰ã§ã¯ãƒ—ロットã—ãŸãƒ‡ãƒ¼ã‚¿ãŒé¸æŠžå¯¾è±¡ã«ãªã‚Šã€ãƒ—ロットã—ãŸç‚¹ã«å¯¾å¿œã™ã‚‹ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®è¨­å®šã‚’行ã†äº‹ãŒã§ãã¾ã™ã€‚

    é¸æŠžã—ãŸã„グラフィックスオブジェクトã«åˆã£ãŸã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒ¢ãƒ¼ãƒ‰ã‚’決ã‚〠マウスã§ç›®çš„ã®ã‚°ãƒ©ãƒ•ィックスをクリックã™ã‚‹ã¨ãƒ•ォーカスã•れã¦ã„る事を示ã™ç‚¹ç·šæž ãŒè¡¨ç¤ºã•れã¾ã™(下図)。 SHIFT キーを押ã—ãªãŒã‚‰ã‚¯ãƒªãƒƒã‚¯ã™ã‚‹ã¨è¤‡æ•°ã®ã‚ªãƒ–ã‚¸ã‚§ã‚¯ãƒˆã‚’è¤‡æ•°é¸æŠžã§ãã¾ã™ã€‚

    マウスã®ãƒ‰ãƒ©ãƒƒã‚°ã§ç§»å‹•ã€æ‹¡å¤§ãƒ»ç¸®å°ãŒã§ãã¾ã™ã€‚ 移動ã®éš›ã« CTL キーを押ã—ãªãŒã‚‰ãƒ‰ãƒ©ãƒƒã‚°ã™ã‚‹ã¨ã€æ°´å¹³åž‚ç›´æ–¹å‘ã«ã—ã‹å‹•ãã¾ã›ã‚“ã®ã§ã€ä½ç½®åˆã‚ã›ã‚’ã™ã‚‹ã®ã«ä¾¿åˆ©ã§ã™ã€‚ ã¾ãŸã€ç§»å‹•ã®éš›ã¯ã‚°ãƒªãƒƒãƒ‰ãŒåйã„ã¦ã„ã¾ã™ã€‚ã“ã®ã‚°ãƒªãƒƒãƒ‰ã‚’解除ã™ã‚‹ã«ã¯ SHIFT キーを押ã—ãªãŒã‚‰ãƒ‰ãƒ©ãƒƒã‚°ã—ã¦ãã ã•ã„。 ダブルクリックã§ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ãå„種設定ã®å¤‰æ›´ãŒè¡Œãˆã¾ã™ã€‚

  3. レジェンドã®è¤‡è£½

    åŒã˜æ§˜ãªãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã‚’沢山作æˆã—ãªã‘れã°ãªã‚‰ãªã„時ã®ç‚ºã«ã€ï¼‘ã¤ä½œæˆã—ã¦ãれã®è¤‡è£½ã‚’生æˆã™ã‚‹æ©Ÿèƒ½ãŒã‚りã¾ã™ã€‚ ãれã«ã¯å‰ç¯€ã§èª¬æ˜Žã—ãŸæ–¹æ³•ã§ã€è¤‡è£½ã‚’作æˆã—ãŸã„レジェンドãŒãƒ•ォーカス(é¸æŠž)ã•れãŸçŠ¶æ…‹(点線枠ã§å›²ã¾ã‚ŒãŸçŠ¶æ…‹)ã«ã—ã¾ã™ã€‚ ã‚‚ã—ã€è¤‡æ•°ã®ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã®è¤‡è£½ã‚’作りãŸã„ã®ã§ã‚れã°ã€ãれら複数ã®ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã‚’マウスã§å›²ã‚€ã‚ˆã†ã«ã—ã¦ãƒ•ォーカスã•れãŸçŠ¶æ…‹ã«ã—ã¦ãã ã•ã„。 ã“ã“ã§ INS キーを押ã™ã¨(ã‚ã‚‹ã„ã¯ãƒãƒƒãƒ—アップメニューを出ã—㦠"複製(D)" ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’é¸æŠžã™ã‚‹)〠フォーカスã•れã¦ã„るレジェンドã®è¤‡è£½ãŒç”Ÿæˆã•れã¾ã™ã€‚ 複製ã¯åŒã˜ä½ç½®ã«ç”Ÿæˆã•れã¾ã™ã®ã§ã€é‡ãªã£ã¦ï¼‘ã¤ã—ã‹è¦‹ãˆã¾ã›ã‚“。 ã§ã™ãŒã€è¤‡è£½å¾Œã¯è¤‡è£½ã•れãŸãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã®ã¿ãŒãƒ•ォーカスã•れã¦ã„ã¾ã™ã®ã§ã€ãã®ã¾ã¾ãƒ‰ãƒ©ãƒƒã‚°ã™ã‚Œã°è¤‡è£½ã•れãŸã‚‚ã®ã ã‘ãŒç§»å‹•ã—ã¾ã™ã€‚

  4. legend.nsc を使ã†

    Ngraph ã«ã¯ã‚¢ãƒ‰ã‚¤ãƒ³ã¨å‘¼ã°ã‚Œã‚‹å‰¯ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã‚’ä½¿ã†æ©Ÿèƒ½ãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚ ãã®ä¸€ã¤ã«ãƒ‡ãƒ¼ã‚¿ã®å‡¡ä¾‹ã‚’自動生æˆã™ã‚‹ LGEND ãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚ [アドイン] ([Addin]) メニューã®ä¸­ã‹ã‚‰ [Legend...] ã‚’é¸ã³å®Ÿè¡Œã™ã‚‹ã¨ã€ç¾åœ¨é–‹ã‹ã‚Œã¦ã„るデータファイルã®å‡¡ä¾‹ãŒè‡ªå‹•生æˆã•れã¾ã™ã€‚ 下図㯠LEGEND アドインã«ã‚ˆã‚‹å‡¡ä¾‹ã®ä½œæˆä¾‹ã§ã™ã€‚

  5. è¾¼ã¿åˆã£ã¦ã„るレジェンドã®é¸æŠžæ–¹æ³•

    "Path タブ"ã€"Rectangle タブ"ã€"Arc タブ"ã€"Mark タブ"ã€"Text タブ" ã«ã¯ ãれãžã‚Œã®ã‚ªãƒ–ジェクトã®ä¸€è¦§ãŒè¡¨ç¤ºã•れã¦ã„ã¾ã™ã€‚ "File タブ" ã‚„"Axis タブ" ã¨åŒæ§˜ã«ä¸€è¦§ã‚’ダブルクリックã™ã‚‹ã¨ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ã〠å„種設定を行ã†äº‹ãŒã§ãã¾ã™ã€‚ ã¾ãŸã€ä¸€è¦§ã®ä¸­ã‹ã‚‰é©å½“㪠legendã‚’é¸ã³ã‚¹ãƒšãƒ¼ã‚¹ã‚’押㙠(ã‚ã‚‹ã„ã¯ãƒãƒƒãƒ—アップメニューを出ã—㦠"フォーカス(F)" メニューをé¸ã¶)ã¨ã€ グラフã§å¯¾å¿œã™ã‚‹ã‚°ãƒ©ãƒ•ィックスオブジェクトãŒãƒ•ォーカスã•れã¾ã™ã€‚ 作æˆã—ãŸlegendãŒé‡ãªã‚Šã‚ã£ã¦ã—ã¾ã„ã€ç›®çš„ã® legend ã ã‘をマウスã§é¸æŠžã™ã‚‹ã®ãŒå›°é›£ãªæ™‚ã«ã“ã®æ©Ÿèƒ½ã‚’使ã†ã¨ä¾¿åˆ©ã§ã™ã€‚


グラフã®å°åˆ·ãƒ»ä¿å­˜ãƒ»èª­è¾¼ã€ãƒ•ァイルã¸ã®å‡ºåŠ›

  1. グラフã®å°åˆ·

    å°åˆ·ã¯[グラフ]-[å°åˆ·]メニューã§è¡Œã„ã¾ã™ã€‚

  2. グラフã®ä¿å­˜

    グラフã®ä¿å­˜ã¯[グラフ]-[ä¿å­˜]メニューã§è¡Œã„ã¾ã™ã€‚ ã“ã®ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’é¸æŠžã™ã‚‹ã¨ä¿å­˜ã™ã‚‹ãƒ•ァイルåã‚’èžã„ã¦ããŸå¾Œã€å„種セーブオプション指定ã®ç‚ºã®ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ãã¾ã™ã€‚ ã“ã“ã§ OK を押ã›ã°ã€Ngraph ã®ä¿å­˜å½¢å¼ã§ NGP ã®æ‹¡å¼µå­ã‚’æŒã¤ãƒ•ァイルãŒä½œæˆã•れã¾ã™ã€‚ 一方ã€Ngraphã¯äºˆã‚用æ„ã—ã¦ã‚るデータファイルを読ã¿è¾¼ã‚“ã§ã‚°ãƒ©ãƒ•ã«ã—ã¦ã„ã¾ã™ã€‚ 従ã£ã¦ã€ã‚°ãƒ©ãƒ•を完全ã«ä¿å­˜ã™ã‚‹ã«ã¯ã‚°ãƒ©ãƒ•ã®çŠ¶æ…‹ã‚’ä¿å­˜ã—㟠NGP ファイルã ã‘ã§ãªãã€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルもä¿å­˜ã—ã¦ãŠãå¿…è¦ãŒã‚る事ã«ãªã‚Šã¾ã™ã€‚ ã¨ã“ã‚ãŒã€ã“ã®ã‚ˆã†ã« NGP ファイルã¨ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを別々ã«ä¿å­˜ã—ã¦ãŠãã¨ã€ フォルダ構æˆã®ç•°ãªã‚‹ã‚³ãƒ³ãƒ”ュータã«ã‚³ãƒ”ーã—ãŸæ™‚ã«æ­£å¸¸ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルãŒèª­ã¿è¾¼ã‚ãªããªã£ã¦ã—ã¾ã„ã¾ã™ã€‚ ã“れを回é¿ã™ã‚‹ç‚ºã«å¹¾ã¤ã‹ã®ã‚»ãƒ¼ãƒ–オプションãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚

    パス情報
    セーブã™ã‚‹æ™‚ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®ãƒ‘ス情報をã©ã†ã™ã‚‹ã‹ã‚’指定ã—ã¾ã™ã€‚ unchange ã§ã¯ä½•ã®å¤‰æ›´ã‚‚ã—ã¾ã›ã‚“。 full ã«ã™ã‚‹ã¨ãƒ‡ãƒ¼ã‚¿ãƒ‘スをフルパスã§ã‚»ãƒ¼ãƒ–ã—ã¾ã™ã€‚ relative ã¯ã‚«ãƒ¬ãƒ³ãƒˆãƒ•ォルダã‹ã‚‰ã®ç›¸å¯¾ãƒ‘スã§ã‚»ãƒ¼ãƒ–ã—ã¾ã™ã€‚ base ã¯ãƒ‘スåã‚’ã¤ã‘ãšãƒ•ァイルåã ã‘ã§ã‚»ãƒ¼ãƒ–ã—ã¾ã™ã€‚
    データファイルをå«ã‚ã‚‹
    ã“ã®ã‚ªãƒ—ションをãƒã‚§ãƒƒã‚¯ã™ã‚‹ã¨ã€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®å†…容も NGP ファイルã«åŸ‹ã‚è¾¼ã¾ã‚Œã¾ã™ã€‚ ã—ãŸãŒã£ã¦ã€ã‚°ãƒ©ãƒ•ã®ä¿å­˜ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã¯ã‚‚ã¯ã‚„ä¸è¦ã¨ãªã‚Šã¾ã™ã€‚ 埋ã‚è¾¼ã¾ã‚ŒãŸãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã¯NGPファイルã®èª­ã¿è¾¼ã¿æ™‚ã«å±•é–‹ã•れã¾ã™ã€‚
    åˆæˆã‚¿ãƒ•ァイルをå«ã‚ã‚‹
    ä¸Šè¨˜åŒæ§˜ã«åˆæˆãƒ•ァイル(GRAファイル)ã‚’NGPファイルã«åŸ‹ã‚è¾¼ã¿ã¾ã™ã€‚
  3. グラフã®èª­è¾¼

    セーブã—ã¦ã‚ã‚‹NGPファイル(*.ngp)を読ã¿è¾¼ã‚€ã«ã¯[グラフ]-[é–‹ã]メニューã§è¡Œã„ã¾ã™ã€‚ ファイルマãƒãƒ¼ã‚¸ãƒ£ãƒ¼ç­‰ã‹ã‚‰NGPファイルをé¸ã³ã€ グラフ上ã«ãƒ‰ãƒ©ãƒƒã‚°&ドロップã—ã¦ã‚‚グラフを読ã¿è¾¼ã‚€ã“ã¨ãŒå‡ºæ¥ã¾ã™ã€‚ ã“ã®ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’é¸æŠžã™ã‚‹ã¨èª­ã¿è¾¼ã‚€ãƒ•ァイルåã‚’èžã„ã¦ããŸå¾Œã€ å„種読ã¿è¾¼ã¿ã‚ªãƒ—ション指定ã®ç‚ºã®ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ãŒé–‹ãã¾ã™ã€‚ å„ã‚ªãƒ—ã‚·ãƒ§ãƒ³ã®æ„味ã¯ä»¥ä¸‹ã®é€šã‚Šã§ã™ã€‚

    データファイル展開
    データファイルãŒåŸ‹ã‚è¾¼ã¾ã‚Œã¦ã„ã‚‹ NGP ファイルを読ã¿ã“ã‚€ã¨ãã€åŸ‹ã‚è¾¼ã¾ã‚Œã¦ã„るデータファイルを展開ã™ã‚‹ã‹ã©ã†ã‹ã‚’指定ã—ã¾ã™ã€‚ 展開ã™ã‚‹ãƒ•ォルダã¯ã€Œå±•開ファルダã€ã§æŒ‡å®šã§ãã¾ã™ã€‚デフォルトã§ã¯ã‚«ãƒ¬ãƒ³ãƒˆãƒ•ォルダ(.\)ã«ãªã£ã¦ã„ã¾ã™ã€‚
    パス情報
    データファイルã®ãƒ‘ã‚¹æƒ…å ±ã®æ‰±ã„ã‚’é¸æŠžã—ã¾ã™ã€‚ 「フルパスã€ã¯ãƒ•ãƒ«ãƒ‘ã‚¹ã§æŒ‡å®šã•れã¦ã„ãªã„データファイルã«ã¤ã„ã¦ã€ カレントフォルダã‹ã‚‰æŽ¨æ¸¬ã•れるフルパスã«å¤‰æ›ã—ã¾ã™ã€‚ 「ファイルåã®ã¿ã€ã®å ´åˆã€ãƒ‘ス情報ã¯ç„¡è¦–ã•れ〠データファイルã¯ã‚«ãƒ¬ãƒ³ãƒˆãƒ•ォルダã«ã‚ã‚‹ã‚‚ã®ã¨ã¿ãªã•れã¾ã™ã€‚ フォルダ構æˆãŒå¤‰ã‚ã£ã¦ã—ã¾ã„ã€ã‹ã¤ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルãŒã‚«ãƒ¬ãƒ³ãƒˆãƒ•ã‚©ãƒ«ãƒ€ã«æœ‰ã‚‹å ´åˆã«ã¯ã“ã®ã‚ªãƒ—ションをãƒã‚§ãƒƒã‚¯ã—ã¦ãã ã•ã„。
  4. ç”»åƒãƒ•ァイルã¸ã®ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆ

    [グラフ]-[ç”»åƒã«ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆ]ã§å‡ºåŠ›ãƒ•ã‚¡ã‚¤ãƒ«å½¢å¼ã‚’指定ã—ã¦ãƒ•ァイルã«å‡ºåŠ›ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

  5. GRAファイルã¸ã®å‡ºåŠ›

    GRAファイルã¨ã¯ã€ç›´ç·šã€å††ãªã©ã®ã‚°ãƒ©ãƒ•ィックス命令を記述ã—ãŸNgraph独自ã®ãƒ•ァイル形å¼ã§ã™ã€‚ グラフã®åˆæˆã«ä½¿ã†äº‹ãŒã§ãã¾ã™ã€‚ GRAファイルã®ä½œæˆã¯[グラフ]-[ç”»åƒã«ã‚¨ã‚¯ã‚¹ãƒãƒ¼ãƒˆ]-[GRA ファイル]ã§è¡Œã„ã¾ã™ã€‚ ãã®ã‚ˆã†ã«ã—ã¦å‡ºåŠ›ã—ãŸGRAファイルを[åˆæˆ]-[é–‹ã]ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã§æŒ‡å®šã™ã‚‹ã‹ã€ ファイルマãƒãƒ¼ã‚¸ãƒ£ãƒ¼ç­‰ã‹ã‚‰GRAファイルをé¸ã³ã€ グラフã¾ãŸã¯Merge タブ上ã«ãƒ‰ãƒ©ãƒƒã‚°&ドロップ事ã§å–り込む事ãŒã§ãã¾ã™ã€‚


フィッティング

  1. 通常ã®ãƒ•ィット

    データã®ãƒ•ィッティングをã™ã‚‹ã«ã¯ä¸‹å›³ã®æ§˜ã«ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã§ãƒ—ロット形å¼ã‚’ fit ã«ã—ã¾ã™ã€‚

    ãã®å¾Œã€ã€Œä½œæˆã€ãƒœã‚¿ãƒ³ã‚’押ã™ã¨ä¸‹å›³ã®ãƒ•ィットダイアログボックスãŒé–‹ãã¾ã™ã®ã§ã€ãã“ã§ãƒ•ã‚£ãƒƒãƒ†ã‚£ãƒ³ã‚°ã®æ–¹æ³•を指定ã—ã¾ã™ã€‚

    フィットダイアログボックスã®ã€Œç¨®é¡žã€ã«ã¯ "多項å¼", "ã¹ã関数", "指数関数", "対数" ã‹ã‚‰é¸æŠžã—ã¾ã™ã€‚ "ユーザ定義" ã‚’é¸ã¶ã¨ãƒ¦ãƒ¼ã‚¶æŒ‡å®šã®é–¢æ•°ã§ãƒ•ィットã§ãã¾ã™ãŒã€ãã‚Œã¯æ¬¡ç¯€ã§èª¬æ˜Žã—ã¾ã™ã€‚ ã¾ãŸ "多項å¼" (多項å¼ãƒ•ィット)ã®å ´åˆã«ã¯ã€Œå¤šé …弿¬¡å…ƒã€ã‚‚指定ã—ã¦ãã ã•ã„。 ãã®å¾Œã€æç”»ã™ã‚‹ã¨ãƒ•ィッティングãŒè¡Œã‚れã¾ã™ã€‚ ãƒ•ã‚£ãƒƒãƒˆçµæžœã¯ç·šã¨ã—ã¦ã‚°ãƒ©ãƒ•ã«è¡¨ç¤ºã•れã¾ã™ã€‚ã¾ãŸã‚µã‚¤ãƒ‰ãƒãƒ¼å³ä¸‹ã«ã‚‚情報ãŒè¡¨ç¤ºã•れã¾ã™ã€‚ ã‚ã‚‹ã„ã¯ãƒ•ィットダイアログボックスã®ã€Œçµæžœè¡¨ç¤ºã€ãƒœã‚¿ãƒ³ã§ã‚‚ãƒ•ã‚£ãƒƒãƒˆçµæžœãŒæ•°å€¤ã§è¡¨ç¤ºã•れã¾ã™ã€‚

    ãƒ•ã‚£ãƒƒãƒˆçµæžœã®è¡¨ç¤ºã§<DY^2>ã¯ãƒ‡ãƒ¼ã‚¿ãŒ (Xi, Yi)ã€ãƒ•ィットã—ãŸé–¢æ•°ãŒ Y=f(X) ã®ã¨ã〠<DY^2>=<ΔY^2>=<[Yi-f(Xi)]^2>=(1/N)Σ[Yi-f(Xi)]^2 ã®æ„味ã§ã™ã€‚ã¾ãŸ "|r| or |R|" ã¯ç›¸é–¢ä¿‚æ•°ã®çµ¶å¯¾å€¤ã§ã™ã€‚

  2. ä»»æ„関数ã«ã‚ˆã‚‹ãƒ•ィット

    ä»»æ„関数ã§ãƒ•ィットã™ã‚‹å ´åˆã«ã¯ã€ãƒ•ィットダイアログボックスã®ã€Œç¨®é¡žã€ã§ "ユーザ定義" ã‚’é¸ã³ã¾ã™ã€‚ フィット関数を「フィットå¼ã€ã«æŒ‡å®šã—ã¾ã™ã€‚

    例ã¨ã—ã¦

          Y=a*(X+b)^2
          
    ã®ãƒ•ィットã®å ´åˆã‚’説明ã—ã¾ã™ã€‚ フィッティングパラメター㯠a 㨠b ã§ã™ã€‚ フィッティングパラメターã¯ã€Œãƒ•ィットå¼ã€ã®ä¸­ã§ã¯ %00 ã‹ã‚‰ %09 ã§æŒ‡å®šã—ã¾ã™ã€‚ ã¤ã¾ã‚Šãƒ•ã‚£ãƒƒãƒ†ãƒ³ã‚°ãƒ‘ãƒ©ãƒ¡ã‚¿ãƒ¼ã¯æœ€å¤§ 10 個ã¾ã§ã«åˆ¶é™ã•れã¦ã„ã¾ã™ã€‚ 上ã®ä¾‹ã§ã¯ã€Œãƒ•ィットå¼ã€ã«
          %00*(X+%01)^2
          
    ã¨å…¥åŠ›ã—ã¦ãã ã•ã„. ä»»æ„関数ã®ãƒ•ィットã§ã¯ä¸€æ°—ã«ãƒ‘ラメターã®å€¤ã‚’決ã‚ã‚‹ã®ã§ã¯ãªãã€ãƒ‘ラメターã®å€¤ã‚’変ãˆãªãŒã‚‰èª¤å·®ãŒæœ€å°ã«ãªã‚‹ç‚¹ã‚’探ã—ã¦è¡Œãã¾ã™ã€‚ æŽ¢ã—æ–¹ã¯ãƒ‘ラメターã®åˆæœŸå€¤ã‚’決ã‚ã€ãã®æ™‚ã®ãƒ‘ラメター空間ã§ã®èª¤å·®ã®å‹¾é…ã‹ã‚‰æ–°ãŸãªãƒ‘ラメターã®å€¤ã‚’決ã‚ã‚‹ã¨è¨€ã†å‹•作を パラメターã®å€¤ãŒå¤‰ã‚らãªããªã‚‹ã¾ã§(åŽæŸã™ã‚‹ã¾ã§)繰り返ã—ã¾ã™ã€‚ 「%00:〜%09:ã€ã€ŒåŽæŸ(%)ã€ã€Œå¾®åˆ†å¼æŒ‡å®šã€ã€ŒdF/d(%00):〜dF/d(%09):ã€ã§ã“ã®ç¹°ã‚Šè¿”ã—動作を制御ã—ã¾ã™ã€‚ パラメター空間ã§ã®èª¤å·®ã®å‹¾é…を求ã‚ã‚‹ã«ã¯ãƒ•ィット関数をå„パラメターã§å微分ã—ãŸå¼ãŒå¿…è¦ã§ã™ã€‚ ã€Œå¾®åˆ†å¼æŒ‡å®šã€ã‚’ãƒã‚§ãƒƒã‚¯ã—ã€ã“れら微分å¼ã‚’「dF/d(%00):〜dF/d(%09):ã€ã«å…¥åŠ›ã—ã¦ãã ã•ã„。 上ã®ä¾‹ã®å ´åˆ %00*(X+%01)^2 ã‚’ %00, %01 ã§å微分ã—ãŸå¼ã‚’入力ã—ã¾ã™ã€‚ 具体的ã«ã¯
          dF/d(%00): (X+%01)^2
          dF/d(%01): %00*2*(X+%01)
          
    ã¨ã—ã¦ãã ã•ã„。 ã€Œå¾®åˆ†å¼æŒ‡å®šã€ã‚’ãƒã‚§ãƒƒã‚¯ã—ãªã‘れã°ã€å¾®åˆ†å¼ã®è¿‘ä¼¼å€¤ã‚’æ•°å€¤çš„ã«æ±‚ã‚ã¾ã™ãŒã€æ˜Žç¤ºçš„ã«å¾®åˆ†å¼ã‚’指定ã—ãŸæ–¹ãŒåŽæŸã¯é€Ÿããªã‚Šã¾ã™ã€‚ ã¾ãŸã€ãƒ•ィットパラメターã®åˆæœŸå€¤ã‚’「%00:〜%09:ã€ã§æŒ‡å®šã—ã¦ãã ã•ã„。 パラメターã®å€¤ãŒå¤‰ã‚らãªããªã£ãŸæ™‚ã‚’åŽæŸã—ãŸã¨åˆ¤æ–­ã—ã¦ã„ã¾ã™ãŒã€å…¨ã変化ã—ãªããªã‚‹äº‹ã¯ã‚りã¾ã›ã‚“。 変化ã—ãªããªã£ãŸã¨è¦‹ãªã™åŸºæº–ã‚’ã€ŒåŽæŸ(%):ã€ã§æŒ‡å®šã—ã¾ã™ã€‚ デフォルトã§ã¯ 1% ã§ã™ã®ã§ãƒ•ã‚£ãƒƒãƒˆçµæžœã®æœ‰åŠ¹æ¡æ•°ã¯ï¼’æ¡ã§ã™ã€‚ ã“れらã®ã‚ªãƒ—ションを指定ã—ãŸã‚‰ã€ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã‚’é–‰ã˜ã¦æç”»ã™ã‚Œã°ãƒ•ィットãŒè¡Œã‚れã¾ã™ã€‚ ã¾ãŸã€æ™‚ã¨ã—ã¦
          singular matrix ã‚ã‚‹ã„㯠too small number of data
          
    ã®ã‚¨ãƒ©ãƒ¼ãŒå‡ºãŸã‚Šã€åŽæŸã›ãšã«ãƒ•ィット処ç†ãŒã„ã¤ã¾ã§ã‚‚ç¶šã„ã¦ã—ã¾ã†äº‹ ãŒã‚りã¾ã™(æç”»é€²è¡Œçжæ³ã‚’示ã™ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ã®ã€Œåœæ­¢ã€ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ä¸­æ–­ã—ã¦ãã ã•ã„)。 ã“ã®ã‚ˆã†ãªå ´åˆã«ã¯ãƒ•ィットパラメターã®åˆæœŸå€¤ã‚’変ãˆã¦å†åº¦æŒ‘戦ã—ã¦ã¿ã¦ãã ã•ã„。 フィット関数ã«ã‚ˆã£ã¦ã¯åˆæœŸå€¤ã‚’ã‹ãªã‚Šæ…Žé‡ã«é¸ã°ãªã„ã¨åŽæŸã—ã¦ãれ㾠ã›ã‚“。

    ãªãŠãƒ•ィッティングã®ãƒ¦ãƒ¼ã‚¶å®šç¾©é–¢æ•°ã§ã¯ä¸‹è¨˜ã®å®šæ•°ã€é–¢æ•°ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“。

    • F(), G(), H()
    • CIOLOR(), ALPHA()
    • OBJ_COLOR(), OBJ_ALPHA()
    • RGB(), RGB2()
    • HSB(), HSB2()
    • MARKSIZE(), MARKTYPE()
    • NUM
    • MINX, MAXX
    • MINY, MAXY
    • SUMX, SUMY
    • SUMXX, SUMYY, SUMXY
    • AVX, AVY
    • SGX, SGY
    • FIRST
    • MASK, MOVE
    • COLX, COLY
    • AXISX, AXISY
    • HSKIP, RSTEP, FLINE
    • FILE_OBJ, PATH_OBJ, RECT_OBJ, ARC_OBJ, MARK_OBJ, TEXT_OBJ
    • %D, %N


æ•°å¼å¤‰æ›æ©Ÿèƒ½ã‚’使ã†

  1. データを数å¼ã§å¤‰æ›ã—ã¦ãƒ—ロットã™ã‚‹

    Ngraph ã§ã¯ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®ãƒ‡ãƒ¼ã‚¿ã‚’ãã®ã¾ã¾ã‚°ãƒ©ãƒ•ã«ã™ã‚‹ã ã‘ã§ã¯ãªãã€ãƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸæ•°å¼ã§å¤‰æ›ã—ã¦ã‹ã‚‰ã‚°ãƒ©ãƒ•ã«ã™ã‚‹æ©Ÿèƒ½ã‚’æŒã£ã¦ã„ã¾ã™ã€‚ 変æ›ã™ã‚‹ç‚ºã®å¼ã¯ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã§ã€Œå¤‰æ›æ•°å¼ã€ã‚¿ãƒ–を表示ã—ã€ã€Œå¤‰æ›æ•°å¼:ã€ã«å…¥åŠ›ã—ã¾ã™ã€‚ å¤‰æ›æ•°å¼ã¯å„データファイルã§ç‹¬ç«‹ã—ã¦ã„ã¾ã™ã€‚ 下図ã®ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ã€è¤‡æ•°ã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイルã®å¤‰æ›æ•°å¼ã‚’一括ã—ã¦å…¥åŠ›ã™ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚

    例ãˆã°ã€ç¸¦è»¸ãƒ‡ãƒ¼ã‚¿ã‚’二乗ã—ãŸã‚‚ã®ã‚’グラフã«ã—ãŸã„時ã«ã¯ã€Œ(Y)カラム数å¼å¤‰æ›ã€ã«

          Y^2 (ã‚ã‚‹ã„ã¯åŒã˜äº‹ã§ã™ãŒ SQR(Y))
          
    ã¨å…¥åŠ›ã—ã¦ãã ã•ã„。もã—データダイアログボックスã®ã€Œ(Y)カラムã€ãŒ 2 ã¨ãªã£ã¦ã„ã‚‹å ´åˆã«ã¯
          %2^2 (ã‚ã‚‹ã„ã¯åŒã˜äº‹ã§ã™ãŒ SQR(%2))
          
    ã§ã‚‚åŒã˜çµæžœã‚’å¾—ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚%2 ã®æ„味㯠"データファイルã®2カラム目ã®ãƒ‡ãƒ¼ã‚¿"ã§ã™ã€‚ ã“ã®ã‚ˆã†ã« %1〜%999 ã§ç‰¹å®šã®ã‚«ãƒ©ãƒ ã‚’å–り出ã™äº‹ãŒã§ãã¾ã™ã€‚ 一方ã€Xã¯ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œ(X)カラムã€ã«æŒ‡å®šã—ãŸã‚«ãƒ©ãƒ ã®ãƒ‡ãƒ¼ã‚¿ã§ã‚り〠Yã¯ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œ(Y)カラムã€ã«æŒ‡å®šã—ãŸã‚«ãƒ©ãƒ ã®ãƒ‡ãƒ¼ã‚¿ã§ã™ã€‚ ã§ã™ã‹ã‚‰ã€ã€Œ(Y)カラムã€ã‚’ 3 ã«ã™ã‚‹ã¨ã€ä»Šåº¦ã¯ "Y" 㨠"%3" ãŒåŒã˜å€¤ã‚’示ã™ã‚ˆã†ã«ãªã‚Šã¾ã™ã€‚ ã¾ãŸé…列 COL を使ã£ã¦ç‰¹å®šã®ã‚«ãƒ©ãƒ ã‚’å–り出ã™ã“ã¨ã‚‚ã§ãã¾ã™ã€‚ COL[1] ãŒ1カラム目ã®ãƒ‡ãƒ¼ã‚¿ã«ãªã‚Šã¾ã™ã€‚

    縦軸データをカラム 1 ã¨ã‚«ãƒ©ãƒ 2 ã®å’Œã‚’プロットã—ãŸã„時ã«ã¯å¤‰æ›æ•°å¼ã«

          %1+%2
          
    ã¨å…¥åŠ›ã—ã¦ãã ã•ã„。ã“ã®ã‚ˆã†ã«ã‚«ãƒ©ãƒ é–“ã®æ¼”ç®—ãŒã§ãã¾ã™ã€‚ ã¾ãŸã€0番目(Data タブã®ãƒªã‚¹ãƒˆã®å…ˆé ­ã®æ•°å­—)ã®ãƒ‡ãƒ¼ã‚¿ã®ã‚«ãƒ©ãƒ  1 ã¨ã€1 番目ã®ãƒ‡ãƒ¼ã‚¿ã®ã‚«ãƒ©ãƒ 2 ã®å’Œã‚’プロットã—ãŸã„時ã«ã¯å¤‰æ›æ•°å¼ã«
          %F0001+%F0102
          
    ã¨å…¥åŠ›ã—ã¦ãã ã•ã„。ã“ã®ã‚ˆã†ã«ãƒ•ã‚¡ã‚¤ãƒ«é–“ã®æ¼”ç®—ã‚‚ã§ãã¾ã™ã€‚

    æ•°å¼å¤‰æ›ã§ã¯å››å‰‡æ¼”ç®—ã€æ‹¬å¼§ã®ã»ã‹å¤šãã®é–¢æ•°ãŒä½¿ç”¨ã§ãã¾ã™ã€‚


複数ã®ã‚°ãƒ©ãƒ•

  1. 複数ã®ã‚°ãƒ©ãƒ•ã®ä½œã‚Šæ–¹

    • グラフを新ãŸã«ä½œæˆã™ã‚‹

      一枚ã®ç´™ã«è¤‡æ•°ã®ã‚°ãƒ©ãƒ•を作æˆã—ãŸã„å ´åˆã«ã¯ã€ [軸]-[追加作æˆ]メニューã®ä¸­ã‹ã‚‰ä½œæˆã—ãŸã„グラフã®ç¨®é¡žã‚’指定ã—ã¾ã™ã€‚ ã‚ã‚‹ã„ã¯ä¸‹å›³ã®ã‚³ãƒ³ãƒˆãƒ­ãƒ¼ãƒ«ãƒœã‚¿ãƒ³

      を押ã—ã¦ã€ã‚°ãƒ©ãƒ•(軸)ã®ä½œæˆãƒ¢ãƒ¼ãƒ‰ã«ã—㦠グラフ上ã§ãƒžã‚¦ã‚¹ã‚’使ã£ã¦ä½ç½®ã‚’指定ã—作æˆã™ã‚‹äº‹ã‚‚ã§ãã¾ã™ã€‚

    • ã™ã§ã«ä½œæˆã—ã¦ã‚るグラフを複製ã™ã‚‹

      æ—¢ã«ä¸€ã¤ã®ã‚°ãƒ©ãƒ•ãŒä½œæˆã—ã¦ã‚りã€ãれã¨åŒã˜æ§˜ãªã‚°ãƒ©ãƒ•ã‚’æ–°ãŸã«è¿½åŠ ã™ã‚‹ã®ã«ã¯ã€ ãã®æ—¢ã«ä½œæˆã—ã¦ã‚るグラフを複製ã—ã¦ã—ã¾ã†ã®ãŒã€ã‚ˆã‚Šç°¡å˜ã§ç¾å®Ÿçš„ã§ã™ã€‚ ãれã«ã¯ã€ä¸‹å›³ãƒœã‚¿ãƒ³ã‚’押ã—ã¦ãƒžã‚¦ã‚¹ã‚’ãƒã‚¤ãƒ³ã‚¿ãƒ¼(é¸æŠž)モードã«ã—ã¾ã™ã€‚ ã“ã®ãƒ¢ãƒ¼ãƒ‰ã§ã¯è»¸ã¨ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ãŒé¸æŠžå¯¾è±¡ã«ãªã‚Šã¾ã™(legendも一緒ã«è¤‡è£½ã™ã‚‹äº‹ã‚’考ãˆã¦ã„ã¾ã™)。

      次ã„ã§ã€ã‚°ãƒ©ãƒ•上ã§è¤‡è£½ãƒ¼ã—ãŸã„グラフ全体を囲むよã†ã«ãƒžã‚¦ã‚¹ã§ç¯„囲を指定ã—ã¾ã™ã€‚ ã™ã‚‹ã¨ã€ãƒžã‚¦ã‚¹ã®ç¯„囲ã«å…¥ã£ã¦ã„るグラフã¨ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ãŒå…¨ã¦é¸æŠžã•れã€ç‚¹ç·šæž ã§å›²ã¾ã‚Œã¾ã™ã€‚ ã“ã®çŠ¶æ…‹ã§ INS キーを押ã™(ã‚ã‚‹ã„ã¯ãƒãƒƒãƒ—アップメニューを出ã—㦠"複製(D)" ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’é¸æŠžã™ã‚‹)ã¨ã€ é¸æŠžã•れã¦ã„るグラフã¨ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ãŒè¤‡è£½ã•れã¾ã™ã€‚ ã“ã®æ™‚ã€ãƒ•ォーカス(é¸æŠž)ã•れã¦ã„ã‚‹ã®ã¯æ–°ãŸã«è¤‡è£½ã•れãŸã‚°ãƒ©ãƒ•ã¨ãƒ¬ã‚¸ã‚§ãƒ³ãƒ‰ã ã‘ã§ã€è¤‡è£½å…ƒã¯é¸æŠžã•れã¦ã„ã¾ã›ã‚“。 ã“ã®çŠ¶æ…‹ã§ãƒžã‚¦ã‚¹ã§ãƒ‰ãƒ©ãƒƒã‚°ã—ã¦ä½ç½®ã‚’ãšã‚‰ã—ã¦ãã ã•ã„。 通常ã€è¤‡æ•°ã®ã‚°ãƒ©ãƒ•を作æˆã™ã‚‹å ´åˆã«ã¯ç¸¦ã€ã‚ã‚‹ã„ã¯æ¨ªã«ä½ç½®ã‚’æƒãˆãŸã„å ´åˆãŒå¤šã„ã§ã™ãŒã€ マウスã§ä½ç½®ã‚’ãšã‚‰ã™æ™‚ã« CTRL キーを押ã—ãªãŒã‚‰ãƒ‰ãƒ©ãƒƒã‚°ã™ã‚Œã°æ°´å¹³ãƒ»åž‚ç›´æ–¹å‘ã«ã—ã‹ç§»å‹•ã—ã¾ã›ã‚“ã®ã§ã€ç°¡å˜ã«æƒãˆã‚‹äº‹ãŒã§ãã¾ã™ã€‚

  2. append.nscを使ã†

    NGP ファイルã¨ã—ã¦ä¿å­˜ã•れã¦ã„る別ã®ã‚°ãƒ©ãƒ•ã‚’ã€ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã¨åŒã˜ãƒšãƒ¼ã‚¸ã«å–り込むã®ã¯ã‚‚ã£ã¨ç°¡å˜ã§ã™ã€‚ Ngraph ã«ã¯ã‚¢ãƒ‰ã‚¤ãƒ³ã¨å‘¼ã°ã‚Œã‚‹å‰¯ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã‚’ä½¿ã†æ©Ÿèƒ½ãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚ ãã®ä¸€ã¤ã«NGPファイルã«ä¿å­˜ã•れã¦ã„るグラフをç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã«è¿½åŠ ã™ã‚‹ APPEND ãŒç”¨æ„ã•れã¦ã„ã¾ã™ã€‚ [アドイン] ([Addin]) メニューã®ä¸­ã‹ã‚‰ [Append...] ã‚’é¸ã³å®Ÿè¡Œã—NGPファイルåを指定ã™ã‚‹ã ã‘ã§ã€ç¾åœ¨ã®ã‚°ãƒ©ãƒ•ã«è¿½åŠ ã™ã‚‹äº‹ãŒã§ãã¾ã™ã€‚

  3. 軸ã®åç§°

    フレームグラフや方眼グラフã¯4ã¤ã®è»¸(X軸ã€Y軸ã€U軸ã€R軸)ã‹ã‚‰æ§‹æˆã•れã¾ã™ã€‚ ã¾ãŸäº¤å·®ã‚°ãƒ©ãƒ•ã¯2ã¤ã®è»¸(X軸ã€Y軸)ã‹ã‚‰æ§‹æˆã•れã¾ã™ã€‚ ã“れらã®è»¸ã«ã¯è¤‡æ•°ã®ã‚°ãƒ©ãƒ•を作æˆã—ã¦ã‚‚一æ„ã«ãªã‚‹ã‚ˆã†ã«åå‰ãŒè‡ªå‹•çš„ã«ä»˜ã‘られã¾ã™ã€‚ 軸ã®åå‰ã¯ä»¥ä¸‹ã®å½¢å¼ã‚’ã—ã¦ã„ã¾ã™ã€‚

    グラフã®ç¨®é¡žè»¸ã‚°ãƒ©ãƒ•ã®ç•ªå·
    f: フレームグラフ
    s: 方眼グラフ
    c: 交差グラフ
    X
    Y
    U
    R
    グラフã®ç¨®é¡žæ¯Žã« 1 ã‹ã‚‰æŒ¯ã‚‰ã‚Œã¾ã™

    例ãˆã°ã€æœ€åˆã«ä½œæˆã—ãŸãƒ•レームグラフã®è»¸ã®åå‰ã¯ fX1, fY1, fU1, fR1 ã¨ãªã‚Šã€äºŒç•ªç›®ä½œæˆã—ãŸãƒ•レームグラフã®è»¸ã®åå‰ã¯ fX2, fY2, fU2, fR2 ã§ã™ã€‚

    Axis タブ㮠"name" ã®éƒ¨åˆ†ã«ã¯ã€ã“ã®åå‰ãŒä¸€è¦§è¡¨ç¤ºã•れã¾ã™ã€‚ ã¾ãŸã“れã¨ã¯åˆ¥ã«ä»–ã®ã‚°ãƒ©ãƒ•ィックオブジェクトã¨åŒæ§˜ã«0ã‹ã‚‰ã®é€šã—番å·ãŒä»˜ã„ã¦ã„ã¾ã™ã€‚ Axis タブ㮠"#" ã®éƒ¨åˆ†ã«è¡¨ç¤ºã•れã¦ã„ã‚‹æ•°å­—ãŒã“ã®ç•ªå·ã§ã™ã€‚

  4. プロットã™ã‚‹è»¸ã®æŒ‡å®š

    データをプロットã™ã‚‹è»¸ã¯ãƒ‡ãƒ¼ã‚¿ãƒ€ã‚¤ã‚¢ãƒ­ã‚°ãƒœãƒƒã‚¯ã‚¹ã®ã€Œè»¸ã€ã«è»¸ã®é€šã—番å·ã‚’指定ã—ã¾ã™ã€‚ ãŸã ã—ã€åˆ†ã‹ã‚Šã‚„ã™ã„様ã«ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ã®ãƒªã‚¹ãƒˆã«ã¯å‰ç¯€ã§èª¬æ˜Žã—ãŸè»¸ã®åå‰ãŒä¸€è¦§è¡¨ç¤ºã•れるよã†ã«ãªã£ã¦ã„ã¾ã™ã€‚

  5. 軸ã®é€£æº

    Ngraph ã®åº§æ¨™è»¸ã¯è»¸ã®é–“ã§é€£æºã™ã‚‹ç‚ºã®æ©Ÿèƒ½ã‚’2ã¤ã‚‚ãŸã›ã¦ã‚りã¾ã™ã€‚

    Reference パラメタ

    åº§æ¨™è»¸ã®æœ€å¤§ãƒ»æœ€å°å€¤ãŒè¨­å®šã•れã¦ã„ãªã„時ã€Reference パラメタã«ä»–ã®åº§æ¨™è»¸ç•ªå·ãŒæŒ‡å®šã•れã¦ã„れã°ã€ ãã®è»¸ã‹ã‚‰æœ€å¤§ãƒ»æœ€å°å€¤ã‚’自動的ã«èª­ã¿å–りã¾ã™ã€‚主ã«ãƒ•レームグラフ㮠U軸, R軸ã®ç‚ºã«ä½¿ã‚れã¾ã™ã€‚

    Adjust パラメタ

    ä»–ã®è»¸ç•ªå·ãŒæŒ‡å®šã•れã¦ã„ã‚‹å ´åˆã«ã¯ã€ ãã®è»¸ã¨Adjust position ã§äº¤å·®ã™ã‚‹ã‚ˆã†ã«è‡ªåˆ†è‡ªèº«ã‚’平行移動ã•ã›ã¾ã™ã€‚ 主ã«äº¤å·®ã‚°ãƒ©ãƒ•ã®è»¸ã«å¯¾ã—ã¦ä½¿ã‚れã¾ã™ã€‚

    ã“れらã¯ã€Œå‚照軸ã€ã€ã€Œä½ç½®ãƒœã‚¿ãƒ³ã€-「交差軸ã€ã§ãれãžã‚ŒæŒ‡å®šã§ãã¾ã™ã€‚

    軸ã«ã¯å‰ã§èª¬æ˜Žã—ãŸæ§˜ã«ã€0ã‹ã‚‰ã®é€šã—番å·ãŒä»˜ã‘られã¦ã„ã¾ã™ã€‚ ã•らã«ã€(ä»–ã®ã‚°ãƒ©ãƒ•ィックオブジェクトã¨åŒæ§˜ã«)実行時ã«ä¸€æ„ã«æ±ºã¾ã‚‹ç•ªå·ã‚‚付ã„ã¦ã„ã¾ã™(^ã§å§‹ã¾ã‚‹æ•°å­—ã¨ã—ã¦æŒ‡å®šã—ã¾ã™)。 Axis ã‚¿ãƒ–ã®æœ€å¾Œã®"^#" ã®éƒ¨åˆ†ã«è¡¨ç¤ºã•れã¦ã„ã‚‹æ•°å­—ãŒã“ã®ç•ªå·ã§ã™ã€‚ 上記「å‚照軸ã€ã‚„「ä½ç½®ãƒœã‚¿ãƒ³ã€-「交差軸ã€ã®ã‚³ãƒ³ãƒœãƒœãƒƒã‚¯ã‚¹ãƒªã‚¹ãƒˆã‹ã‚‰è»¸ã®åå‰ã‚’é¸ã‚“ã å ´åˆã«å®Ÿéš›ã«å…¥åŠ›ã•れるã®ã¯ã€ ã“ã®ã€Œå®Ÿè¡Œæ™‚ã«ä¸€æ„ã«æ±ºã¾ã‚‹ç•ªå·ã€ã«ãªã‚Šã¾ã™ã€‚ 「通ã—番å·ã€ã§æŒ‡å®šã—ã¦ã‚ã‚‹ã¨ã€è»¸ãŒå‰Šé™¤ã•れãŸã‚ˆã†ãªå ´åˆã«ç•ªå·ãŒå¤‰ã‚ã£ã¦ã—ã¾ã„ã€ çµæžœã¨ã—ã¦å‚照関係ãŒå£Šã‚Œã¦ã—ã¾ã„ä¸ä¾¿ãªã®ã§ã€ ã“ã®ã‚ˆã†ã«ã€Œå®Ÿè¡Œæ™‚ã«ä¸€æ„ã«æ±ºã¾ã‚‹ç•ªå·ã€ã§æŒ‡å®šã™ã‚‹ã‚ˆã†ã«ãªã£ã¦ã„ã‚‹ã®ã§ã™ã€‚

    複数ã®ã‚°ãƒ©ãƒ•ã§ X 軸を共通ã«ã—ãŸã„å ´åˆã€ ä¸‹å›³ã®æ§˜ã« Reference パラメタを設定ã™ã‚‹ã¨ fX2 軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’変ãˆã‚‹ã ã‘ã§ fU2, fX1, fU1 ã®è»¸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚’æƒãˆã‚‹äº‹ãŒã§ãã¾ã™ã€‚


ngraph-gtk-6.08.00/doc/html/ja/dialogs/0000755000175000017500000000000013375640233014463 500000000000000ngraph-gtk-6.08.00/doc/html/ja/dialogs/dataload.png0000644000175000017500000011605713070106167016667 00000000000000‰PNG  IHDR$_~þ×ïsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœ IDATxÚìgxTE€ß»-›ž„=Té5tŽT)ÒQ@¥IQ"M)"E@) H/Ò¤ˆ`]é-@B!$›íûýØd“%›?™÷yòÀΙ;s¦™9wFºÿ¾@ ‚WˆLˆ@ Á«F‘œœ,¤ àÕ*$ÎÎÎB @ ^­B"D ø·"I‹™LF¢Fϕ둜»xëÿ6OË£d?î. »|Z,”K ¼æ}¾0jü›‹Å‚Å^zˆNoA¥R#“«ËåX,›Òòo&5&“ ³IÁ ÃY-Q±L€(d@ HíóÃÂÂ,™ÍÒ=zÄõë×_+”,Y’€€”J%ƒ™L†Ùl~íeóOË]’$Ìf8w% ¥ÊWw|||ìVNþ_VÒ§9::MR}Êø"—½Þmïuos™Õ}±j&xmWHÒf£?~Lbb"jµ¥Rù5u4;M? d…ÉdÂ`0 ÕjqrrÂßߥRùŸ•Í«’svån2[8~æJ•+ž^yð÷÷G’$»òøZ!IŸîÈÈHâãbÐë©[£(ðß©_¢Íe_™å_ x­’ÔF‹ÅbA¡PüßÎF_Æ Öh4¢×ëñööF­V¿Ö²É©s"‡¬ä~ën<Ÿèps÷ÄÛÛ___ ©}ü³¯I?H½ŒëeÆ—>ÍF£‘'OžKbB<þ~jJ÷{íê×ëÞæž—àµVHnÞ¼‰Z­ÆÛÛ??¿ÿËÙè‹ÌÖÒç5**ŠØØX4 AAAܺuë?'›Ë Ifrý3ŠÒ¥Ë T*Q(˜Ífd2Y¦Ñ¿Y!IŸÏÔ|F /^¤AÍüÿ™ú%Ú\öeUþ_÷>Eðúa;‡$99ƒÁ€‹‹‹­Ó·ÎF%»ö_žÙ§æÓh4"“ÉÉd˜L&ÂÃó%±Jòrån4šl3e³Ùlû“ÉdÏ^V}Ùñ¥·‹Éd¶™ðëØö^F›û¯æ?""ÑA^/…$õ’‹/’?~är9†ððð,g£ÿ–ÙõË|dz3X¹\Ž»»;/^¤\¹r¯D694ÿ ³ªœ–gfr‡(ÒŸ““ªÈåòçÆ}}ÇJbv'ØÃé_5k6™L¶'=îîîÿxýú»ÛÝÿS›û»dñ¼•œ¬ò_¤H1B ^/…$õ?111+V,G³ÑTÁ¹X¦<h_Õ3W6õ¬‰¿ ³Ùl[òÍÍ 6'3u³IÇï§Ò f‘çžÍoÒÅq蜉¦5|lnñ·å— /y6dgb_ÈšÕ.l—¿«W“¯¤žòœu°‡CoQ¶Z1ò*LÄšexË¥\É:U~/ºrjàg6›Q(¬ÕU.—sivWfœzh 3rÙ>*¸ªl¿/¬úŠ«U;SÏÇ-ût1Çù~—žÁ½êÛÜÖý°#i]‡ÞCp“ežwíãý\¶Ô¡Š¿K–ùÒÜ?Ì%ç`ªçQÛf¿©u>½|rºô²Ë¿³ÝýSmÎbI³Ñˆ»ÉS_ ¹É³+ ´fPa•EBd<Oò(^Ž ž'ßÌò/¼¶ ëÙèúð|Lê—‹«~Ã¥^£¿-±Fm³V]á³õ³ô§‹À ³?弟ß!%G?â†Ê îò,g°9‘Q«aÕ¶s4kXåsÆs­>‚-¿éh×° ­süö§3DÕxƒÞ ÔªS,ƒbøà³v93©o>6ì½N‡¦¥7q=?kMYµ…?gô—]È眳ÁfÿÞ‹¨ª—Aùç&ŸòfáðJ¨¤“ñ‹È]¡PØ}šú¼ü°,Ñ›Ò è˜öùlÛïð¸dâŒaš[Ú £¾XŠ—B†ÌÕ…?¾ÃxÖ3ûýF)ejÄl,z–.þšfïŽÀWíxD2ëï1æ½Oé²ù,jµšK3Ú0írKÖ­þ0£gO=Óz å§_V’G.ÙlaRó’úÿܶ½—ɾա8µ©NCoÅKk_G›³˜M<|Ë­ˆ(Î\¸Çù3“§4§ J˜ÅÔNP£g}Lî $$J÷#U·|pùWb4Ä'j‰OæÞÃXîyópçh(¥>hÅØ¢ž8ËÓ fåÈJ‡ýLNò`1&ðñ´ƒ¹Ê¿¸gLðÚ)$ég!™ÍF'NØÈMmæcþjMXP'—”EÒ“ãts!ËwÙ‡^>ª%VfTÚ–r3ã¯5;ˆnJ-kÇ+%&o(ÈÌ¡¥±˜ÄÅ>娑3L˜v“ɳ»P5oI>­xŽ)¿Ä³°sÞLg°ecQТ~»÷G]8ÎÚG¥˜úq%?Æfc9>z¦£òrqFaNb×ápôšhŒ:ûCn’¿fqŽ®#¨i]Šr!ê\(Þ¥*!Œç:P<€¼ ³1™_OÆÐ¢zI¢/ßLœ}ìEݪN„\ÔRÑí.˜ ›²Ýî½S'w!@)qé¯ÛÄ3Y…•³öPP¸^iòÉã8zÖHÓÚ³”ñS¹nÿU“æ” {§ðHç‚.þ •µRB­ÎžÜáìÓu›ß¶¯JWÂßD˜Æz°T‚ÙŒöÉC"%ë–ŠÚëMœÒ%ÌÉ«6+6® ±pAûÙoÜnÎ'hæñž'còy>ÙÁü㕳]o+ŸIxž„½F‘LV]Õ/“!Žá_|nü>%+ñE¯Ö²ÐK$&2®Ä=‰`óá:,hé0Žë{Ob‘ä,š³;MT{ññˆFM'¸—ýÉ“¹.ûÌú£éó¬ŠçWÃWP¡vAž L†§,[°‹_î¹±rAs|å!?n"²Y ûZÓjÔE³üL¤-mtfîí:Ãíe¿Ú{Mhï­D)Ñ`&YgIŽw:;¤çÿhî뾸gLðZoÙ8š,üöƒLW/..[Ï\ yÒöÒrr'VLkâ0Ì”që@¦°Íz¢´¸û©¹ºi›ŠÖb|Uë~{ÿ9žT}ƒê)›¹f¹ÜÖQ9LuO˜~4É‹P(¬~åÈ”î” J;¦»VõÜ´œ~K æÛ¾Tè\‡{Cð°SO ¦tNÏÎ`ËFApå¢XL:æÍý6ƒ›àvâ5‹\Ù‹°ðSì1äGvî0;¼j0­}a[Lxô$£Vf#ž$pfÕvNFhó4’¹s.S©~YÌ×OpôÌ„»Lµ/úÑÃGë½.®=¹¸÷,³‰H…‘¤d¸w:Ž‚óyot 7:ï1K&ÔÁ_­D!ÁÅs„ë—§Ù¯?áv@ª²‹B•&óÌdìæW¸½üiä½ö ãO›S©GuN,~„\¡@¡°Ê/;rw¼œ¦âÖW­ùô{iÊÖŽsîÝæn¢€‚]†P0ùwïXŸ»hkf\1(Ñ‘gç´QGÏâ䣿¯ßîCïŒ3Þ¨ã0ø¤’[ö•i•GÚ{%1ÿÏHæÖ*àУú%—y2 [ÌW Íz¾YpM[ù(ò”eØ»e3øÝ2q%7ë×tØvL†8¦ï‰eÀÇ­)™ª|Xô|2}7rES Ù+){G21µüyù 1F wn<äO9a¿&ªxu&—dðg{éÕHÅš›¬˜TEÊj¤BîËÈ~ 0­uóðêR‡ÆÖƒØ.³¶÷“±˜Ì¨¾ÝÃy™‰˜$Wv/íüï©ûÁë¢dêI‘ùÂÿá+ß÷r0hÈ ðópÜAKiƒ¡.á]ÆgýÒžx5rzíE¨ZÛÚaì8k…ÒT·K¦…ý—biú†w†x£¯ÇèYžrÎò,·„$™’NrN=²^J×B´t3°ü††IeÝr,Äck·qÒXŠ`üùDwµ£r§º¬ûdiÉ”ö…¬™Ò“A=ê’ó.hè×6/&Æã&ObpÏZtúã#ûÔgø±Ë|Ø«>ÛÏÝ@—º p¥kë*œÙ³Ÿ%«@ô).»EŦUi]×A?&øq^ æs#^‡³gó¥É«G¿&™¯0Ídq@E†¼ãçðyf26é%> ö`ÚÊÛôPÖ&뤨?9ªQóCI%'ž‰+;rO5Š|Ö8²Â¤=ì0¥­¢È¥'ìðÊG¯LtÙ9$©S7¬·¹kÝ›jîi3àK¯ÐeîlüxRŸ2ÄseéòÖûÌ.-Rê_ö-jú3滋Hµ3ä-S½K¦¤z…B™>?õÓ’ò”by§YÖOCÒ–Fèøü‡òݹp'ª:-x»BZÌåó Û¥éþÁük4²sËNÙ‡é^^Ù;’‰Ê%/ŸmAô•üqôjB×¼Öժț·Yµöwnå)Ë»åžr.ÖDù3r¯eéÙÈ›#‹~ÁµeªºH|:ûhZÿ`´PX!Çb1 I2›{®ò_.÷ù6$‚×N!I¿OùlƒyžBö˯¨ý«RßC‘¡ÑƒôÜïïSŸ¿ÛÒ‡¹'ãW(Èü1])ê¦@y £:?EœäϤGÆâ=Y÷ÃA¦±†u«3¢O5 ªe܈1âù¦ó3Ê‘„!ñ6 V'a1yò$šS—¢(^½ã+ºÛ”'ï’Î$ïŠF’Š8L£#ÙXÌžšò0÷ËjüõÓV—1ã³ü¬=òSD8÷Ý Ñ­±·Uñò.ÄÜé­x䚦˜ Éܸ>ñ!ÃÇÞ¤È ëÒð/1º>’$1äÝÚüzã ›B¢PûR¦v#>mT{¿ÿŠoùr(œ¼è3¨WÜÀÅ>m¹½!=Ÿš@¡žîvi7jòÕÒSÖYܽ'Äz{è*G¦pe怼h6ÜB’Š:,·Ìdl1³w9Þò aþÁ8µöÁlˆcÞ¥Dz΢Ê17r¨üå路®ÐÅïEáT”¡#&Óó­J|³ý,ác›±õ™\^ËŠ[‘$ ¹Â‡‰Sðõ៉O§\.ý`0¥ü‚‹Â™)Þ¤Ó»ýy;d3Þò´U‚­—nϤéùõÝ%Г.,C^ž—OI’xxòWFrå»Ñµñ”Khc#9õ8í?ìF-ϬȣÎeþ9óg<ù3ñáY>ÝËÔÙɯJË£Ù”ÌÂà ¼?ÇÏ.Ì¿¥ì%IâÀê¼?NÚIÉ/ۣݴ…97èÞ¡%ï:ݦÇ×רoä” dJ7†|Po…„„Drtç¯h¸o0ã|ý!J'ûø£M*+eÈ,z,RÚ—Nÿtþ… ‰àµÞ²‘ËåvVÞ©ÛŽ>G3j3aÇcš~Þ¹Ü~"—ËRâËd}I.·=j×™E) ¿D¹¼ÖÙëÚ+ä¯×Ü.™\H(Õ^ôØ‘¦õ.òåâ#LXŸ5ƒ sÏ`ÆÙßÉ>ŒÈœÈëãŽL¦ L¹btëHù@û½^W%&}¼íâ®ô2ÉT625]Þk~%øavQ–ý‰PE z4ÈCuâÂÕÊS+ A)á“cÏÑ~èä+äŠ\åËÈq-(ê¥`X>o†LéˆÅ¬§Eß•ìû¡?Aõ`Ï” är9&}ÑÑX¹é—~½…wò¬Üd]–¹”`jÓB9þ+ÓOGqþ¡…¥¥Ü‘§[º–{±ôKkJŽŽ^Êæ·Û0¯–gÊ’x2JÍ nšPR±Ü3•±$!—ËéÞ;>ßÿm;yòw îeéâ¯Fj!·KK®än±0§y1vœPÆÄ8Ê-ÙɨÑ"— \»‰“’knóXgF¡ૹ‹2ÔÇôõðÄòެ¹_™=ƒ*!—Ë)öö:,+L¯_³iþ§¸¦¤9ŸJÎ¥hCÆü#eZߌ1:䪂9ΧL&#õÔÛ¿–~Ó |3¢ ³Æî¡x×Î|œ'ËÆ­O¸ÏØo.àŒŒÐó T¨m¿²ãQ KfW¢˜½R¾{qå›RÇS•«²—Ú½MdÈïÜÊÐ9¯É1/·ìµ1×øY_–š®çÉ×ÅñŸlbòìÖlÉãIô•¿ðÕm>û¬# q7O2c¿•¹rÈ•N¸»©QKj75Ö2)åà58§13ÒU‰”dD&WÛÒ“ãü»—}¡ü ¯µB’ºL]¸,&ôz­õÿžÞðÓAJlIi¥ Å ùñäâqnTbHi?¢¯`}x †´Ê‹§JAãáõ™3x+Åߤ€sæ³h9 ÉäiiS¸ÓÇ_ÁÂc‰|Û,〗™ŒÁGšÍð\´” 1&’6GR±O3 EJÀΰïEä®OŒgܾÇ4Ïã̱ޅY©*FŸ>µÑÅíFî\•Â:IrJ•'¥JTB¦PØÕU™d­‡¿Íz‹¡+¯2ý×ópNµ'qcÜæmô¨×ŒöøòÛª”õpâøõûüKH²Lë;@Ò•8TÞrW¿ ÿü=ÔÓWÓgð%Ê´nǤ·ògÙ°uOï1zÔ6Üš¶dQ}=Ç­CkèÆÈÆiÇ‘[,‚üì}Íã0&lM`Ìw%ìÚ^ÎÊÞLâæH*öiúòËÞdäûé¿< |sü5ñuÒövçØîC|¹én%«Ò BœôÑŒ˜ÉÈYípQZÓì[ªÃ,”’„“·þ®r&m„\.Çtƒde>j%¹Üٖߜ翙Õ07—ù^;…$3’Ì´t³1‘¹Ÿ¯ao”‹æ×Ïôœ “1‘u;O;|öÄdÿ…Gj‡h±X0“˜÷ùvò·hMu—çÏd R»æ §#tààÄôŸÖ9B¡ÃÉÃÏ.ßé÷ú3“19†mÛNñóá(ZwoËÔ¨s|uä!ã‡5¡xü%®eøäÞ¼Uä™O•%9yÔ IJ•½‚nmª¥ÉèÒopåÏfõ)isTÊÉÝiR«0ƒ—í£Ñ¨J4/ïÉ;S烪4-a]æuró'¿ÜH’2>ƒý#,&wïDrû±;Í•æû‡Ilü6nrX¸â½zWÃS!e)cky¸1¦º'3WüIl¬Š 5³>¹7grþ©*·¶~‰w¹±܇´/ÍWg©òuÌýï8gÆ2s6m[WgÎÞŸiYÔ>­*Ïz¬>¸‹Ÿï”³¹•·—ýŸVµ¯ïÚëØ·Í^ª¼Ù¨:ÇÞ£øðÊvyÈNýJ«.N ü¬±/åÔ­G,Å3=tïéÝ[Œù|'IÕ±²OidÀãttúm&¼h{gú³Ntñw:zÍG¾KUm/;eÿiuOf-?Ml¬Šµ¼‘eaß’›6§‰:Áʰ«‚;ÓRÂTîЈë[Ö²î^V,ĵ›yg\,Õµ·(г Í|Óò›O³ñ®€H­ ÅÁ¿¸“¢$”®Z„¨ÍÇñ«\?¥LŸ )½sÿ 5=3(u9É¿°!¼v Iú}Êô ?õ”HÛi‘¡ûCY´ö8Ѿ%X²°5¥\76…R†Å¬ãÂÕŽ¢Ù‚\©ÈpðPÒ£p¦ÎØÎüµÙدteÇœ23Éì`´òoåá›PöIû’A!„5_Y-…ž>•@ÑnP(¶#µSg©YÉÆ,)‰TdùÒ·ðQH@1 çÝE¯KPc¤Ö ¾¼SÖ#Ó÷*•2$ä(UN”/mM·IÍ'3žðÉœA\™þ=?œôçË^oà”®o7ËTô|·[~ü™.2wžDù°¿ŒJÉú9èü‰p~³5#ŽÐw¡ +†WÇ5E ‘·ïsõ~ áw£9gàʪ ´\j¦H‰T¯V‹&u›ÓÈe#6ÞgY76ì?EßþµQʳ±”VžUúó¸ï^ ÔíL~g•­N¤–]úƒ·r&w«½†\.C&ÁÖ¯GsV­àáÍXdr3íœJÿ™÷™Ú ¥”2‰¸óç¸éy’»ze<•(%?O{‡‰+¯0{_8Ñ Û2às#»Èxœ?7W” 9fƒ­6­6½.„“e?¡Ž‡EÚ"iÒ`b‚JžÜò%Ÿ×9fÏ8gW¶N^ÍiÞ¬:&Ý-V<Ô2·e ëQç‹,[õË~EOÉØ™éÙ=C.ʲ^…3¬\n_û+ó·_§Z›f|Û§’Miñ¯T‹µc tùòg´úÎÌêRÜn‹àÖ©ÓL^ð;…zô``µ<9k_éʾjº²Ï§V¾Ä²·Ê«@]æN7ã¤T “@žr€ÙïôfEŠE˜kíJ8ïݬW7Æ5·_I*ß·-sÌÖ÷¬ú-ž¿Mkµ‘»÷£‰7&3÷P,]A©T¢‹L@åR–·œæÿEë¾°!ˆ-›”#ŒS/²²Í­]G®e]Œ‘i5½mKÄÏž™lär_Ft÷%æQ\½Ã'¯sèd$õ[Ô¢ŠëS¶¬]MÛ¾T)H‰¢y)š?eÊ⣈NУÔé uiÚ¬çÊé‹,\~ß.=håëB‹™}™÷åZZ}tŽžm«ÐºYü2™+U«výW®Éiø˜6CÖóýøÚ|?k—<«²y`%äæ’ÌŸ¸œ#îñÕ—í©ì&çæÏY•èLÉ¢þÔ÷-Þ  lQ»2÷U;:¿¿ÃÜpÏ_ï”N53jÕ¶rq÷«ÊøÞÉø4+jsS(\)èƒJ!³•cöåŽí/µJJ@™ÚoRÕ] š T¬¢ÿ×Gùrë)XÏÄ)9¸æ‰#²×‡·?ÝŠ›B”„{̼'y+È£õù}ìü-„ðkgˆVgÀh2#“É‘«T¨\éå¦D&Ÿ·™\mcvÝfÕÛÖA½Ò”_ùmJæíáö¦~8×_J£Gy3´£!Žm!‰Œ˜:ˆöå2®L¨Ù5Ãuü”äl÷åÊ«˜ð‡–!£ûÑ­jæv)Ù){7ß*Œë¥Á·yQ[›{±²V&2*z§Õ)Ý‘ëáWn°sß 6ÿeâãIh÷Œ IwY¾é:1qI<‰IàÚSÚ‰kؓǃb…}¹»fqeêÒèöM~p%l{4y*{ÙâÏiþÓn)Î]þw”$› IDAT‚× éþýû€}ûöѹsgœœœ.[,FÌ <þ&{+‹YÏíd9Å\3YÃú=·èÞ®Z¦~6™Çá}XØÐ;Ûïß»šC+±{r…´%x“ ³ÙŒN§cãÆec6%3vìüñ½Ú‹Êå S£j šÖ.ޝíü á×Â9}éo<"â± ¿j« FöšÉáX=ëtcÛ˜¢Lì;‡+þEèÕ³mŸéLÿúý8+wE2ez;<å°fÂ"–Ýw¢U³ éR™…ó§¢x|d3;¼j1»oÚ4“–%³öÒaT;ü•Ùïìâo_fʲó´ý¨ ò;½Œs#÷yßíJ‘» ™ÌºB"—[t£6 ™³+ék‹ÁÊ /×>ÙÛµ¦±ñâªd}”Ï݇×hY®“Ïœ¥–‡’&“õÏlÎÌÆ>ð­LÛÞßMâý«<ò*AëóßûO•}fm.=ã{Ì Ú‘´÷VñëzoÔе]Mº¶(·ƒÙ˜ÀO{nàïãN^? ø{ã—rº´6î2Æò…íÑÝÇ”ÝÀÇ¡£ZÛ;òOæ¿yóæb„¼^ IXX˜àÈ‘#téÒ''§,óþíèâÃè2è(KV½K«öÓžëÿÔÖéÕg##–½Oµg:d£ÑˆN§cÆ ™Ê&öæ#ôy}ñwÏÌŒz UŠ‚£7#Seïö“NƒÌÉ…ŒÝ®þU2έÜç.þ%EîJešBòoàáIìF¿ÒYL1Íeub7†× H7ðXÿ Ðé,lذµþ¿h{ÿTÙgÕæRÑë ÈUJ¬öãÌH¼ÐõtÙh:ÿdþëׯ/F(ÁkE¦6$ÿ¯8yñý¨û~¨ãì® Ïõwó?뙡cûÏ3“wñ€+UºOUÙïNåN™]{/ýëdübr—˱)$ÿ 4›ÄûÙðç[åcF<ã–ºýd6ÛoCþ?´½¶ì³–‰ÊIiWï_ø®\éß•aC"xíûŽRöŸØ¿Ì[¥]²é׫xMúeÖ?¥;%ò¿"›W!ã“»UÉÎÍìKšIúÿçzÂü’ã{V)Q*A¯ÿÿk{ÿ\Ùÿ;eòOå_ x­àßFê—Úÿգđ@¢§ÚüxøŽ†@ ‚”ž ­—ˆÚÙôhZFHF Á?ÂOû¯Øì¥l[6%‹äáÔH!@ ÿ%‹¤}dSH (ã ,,¤#àáÞ½ÀϪ¤¿/A«Õ é@ øÇHÕCìlHÔjµŒ@ ‚Œ 6$©\¾|AHG ÁßJÙ²åí~+²ãI àeáhñá ‰°%@ðw’ªkdiC"lI@ ü¤ê©zˆ¸4A Á+G($@ ^9†Dà½ûö !¼-š·B‚,6$‚lQ¹RjÕªõÚË!44”R¥Jå(̵k×D‚ç𬠉BˆD ÈšüùógÛÀ …D J†@ ¼z…DØ^:vìø\?›7oÎà–¾dц {ýäKµ!Yóà êwëCa'ùk+Ø+›sènÆB­Ö±¬¨iÿ!Ò·€„„ ÄâÅ‹qwwwFØAּͣõ|»Ã›Q4`úSñk×=S…ÄxŠáŸ®Èàî–o îÑßóPornÔ× (ª~±]¥“>äP÷/[ÒûoìÔʬÌña½ ã›{üõµ ú.µswùa½Ã𪨲—Ÿ&òçÍÁçsÉv:’îåOçêÔõâs‘¸»ÊIHÔe;ˆÉd¢_¿~„„„Я_?Ö­[‡\.²‚$W£ýů—°ýÉ8F}=ÿruºwï‘Á]éR¥®;“Ì:Þï÷ß,ÿg™€¯ÒÚÑkc÷°dõ5‡qûTêBÏ™* ×Ù~F¿˜B’‹ÑbÉôy Åæ­]U ^T!ɹ ‰™9ûïcª¸±c÷[^ ü4u¿;¥ €2¹ ÆšòË OWîéìWB\ärËÏÉÓ·Ð'žDò¨‹Üh@x—«†Ò Ck­&ž¨¨¨Œ+5²dÕ:û>ÓÔú4ÉÏÃq·ƒÄÍ›7¹~í ±>Ö±pŽÕ½^ .k ™>/Ô|›ÕÆ­›Z­–„ÛÜwÞ=3¢®Z­–2ãçò}ïH/÷ãSzq¯Õ\j¨-Öøßãî½h‡e“ðä>wî@«Õ"¹7dfÝÙôžÊÖÑUE ·Y:³çþ<ËÕÇ:òç}~˜ômdâĉLœ81ÓçŽÊR ™y¹¶!‰Ø6˜ Ê:LiÛÐæ¶eÓ‚*U¡œ«Òæ&ÉTvñìÑ—¯*QÊÙº(“p=ÃÛYõæ ¶‰NmËÓ¡E^<@Ô±è§`eMkz teÚ´®ÒòC»½\í<*Czwÿ¼Šëܹs‡ð°KÄßüƒ.ýƒ(^¼8AAA”-ín&þn žóð×׃X^~ šp}õ 5ëJý¶ž¹„)“’3cšó™Æß)£›ÅÈè~“¨XN§nßa²@éÊñf6’gmH²ƒ°!‚ìõ“¹²!1éîÐoÜ^z¯9NÇ*¾6÷ cFS³MZxgÝ 7˜:ŸÉ…­JƹiÍ™–: º×`ذ6>9ºç¤Eÿ_^ŽçÛU¥3<»þ*ú¼…¨Ó"˜žE†Ð½ÃÛlùu/ùT÷ú“c¶S£ù,Ž_8ŠoG§­fcXþílÜt¢> P©2Ö®ãQY,ÍAR0ï@(rgÆi9›>ÚÅÔ©÷²ÌÓ‡cÇã£y|&ß>TuSæªUžõéâ­aÖ™(–ÔÉ@̹ÅLÿ1Œ¦SÛCõú¶‹“èà_GŽ’d½£†Aí OŸÚÛB$'&ðTno°)IrÜÝ]m¿cîr9É €Û1:(ž²l»—aÃ.Úü%„=Á÷½¬Ó²uÌò7ýš&^Nž½ÿ…ýž~cO[¢µ|”Ï5«ᜧ\>ebH$óêOÂò°GâGPÏÝÄž-[òºúÙ4{¿ gtœ8ÉÞVCÿô$ŽDñՉЙæÇlŒæË¾}1•éËøJ>vÏäN…é9t ߩˈr,Ú•Œ'Qº*h]”™*¿¨ñ@ ø¿ × É“¿&‘ìZ—*™^ZÌZf,Ù°Ýp‘I¨ó´ã ËhvÄ$ã½èe‡ A†HŽÙÁ{ï³…¿‰gwûøânb@·Il<‘ãZ#vþð”&½: Ñ¬cö{5¬Ê€ªK¿ùÚ^ÁˆoGrôgX‰ôœ|™QLî1€ÀÞ ©›‰­…ÙðˆIÝZ³õ~ ~>ø)Me%¿S7×…RÆÝ‰cWŸBëÜlüåxœ¼J‹þ’;v,«W¯¶ýîÝ»·8‡D ^†B’›»lLÚ>ýhõ>Û†A«Åhõ&,ƒ-¬1é<Ë¿žÀÀ>¥t6nÈ0.þ±“¡‘<¾ÙfÊlZ¿ˆŸ—ÀÌÕáLø¸3‡çƒ÷æðA)7´Z-fc,›¾™Â¬öÜkËF½>åî{³e~ ­‡¾CBüwÌØÀq‚ª‘Çüˆ£QO©áž¹AgâÝcŒö1× d×Çõ2ÊÁ¢çÍK˜39QùÞdÕŽ™“emcb²X0ê´hµ7ÞŒÅlÈðžRÝ qu(ÚÁiÛQz³,F‡e£7e|väàCŠ}ds‹<>•‘ ¯ðîÂ4ñÛ 9!}7n7nÜ 44”Zµj1nÜ8q‰@ ä‚;‡Ä¬å̾µÌœòNí¿by§’¶GÎÎj´±{9x$µÌÂí£óPyÔÆÛÅ}B(ßÁµ‡z*T¦ÁÐi4mÖœr…¼ˆ<»é£—Ñ`êjÞ(S”Àòn÷|¥ÿ†…ƒ›¢zÍ¿F1aÍÞ©™q ¢xË1윥aY‚O–ûöí|Ôì7SßϱŸÈcSh:àWºžÃ‚^Q:XJ [Ó¡ó"é6pŸöo…Jz¾Àå’dgCbL:ÇÁÐXòøä!üT42¹*Cº‹µˆfÆDâåýñWZ›óÈW˜"±~óèž·E Øž™twX©cnó¢¨ÕVLE2ññq˜UN¾!U‘‹{ă‡qÏõ÷ì9$+W®´Ýeãæææ0Œ±@ dͳ6$Òýû÷-aaaæòå ”-[Þaà³ÚòáAÁ{oU±_ HcʸYÜxƒÁ,Ã=Oµßþ„þÍ Çÿ £R… Ô²´Qüéí5Ô뺯~ZI³ 4­)ú8ïuúŠáÛ×Qó%}¢zë§eܪß&]>·˜’¸™¤"È#ó³?,f-O-NxÊ¥l¿wD²øn>Ág­—°icwÓ±Û×$&&¢³8ÓfüŒk˜!ÜÚî5Ùßu+ÛÎq^o®ïÊ»¿væèŠŽ¹–WDÄ-jÕªõŸªü¹¹í744”R¥Jåè=×®]£páb¢·‚LHÕ5îÝ‹ (((ç =&IÅ˼J,^oÆSõß½sEŸ¬AR»8\qÉ mÌaZ5_À!¨W¦x¶Ã]¿ôíë~ÀøC»^H™ ‰PHàŸTHraCbµyY8ÿéívI:mÎOu fåŒÓì»Í¥KW³ìñåh:w%UfaÇðe#»8²y®B)d/Ùê's}—àŸ£pãQ¼—Ã0ùª d¨ÝK%õvßìzR«hC@5/ïà5A/?B!dJhh¨V›@ üÍ InÎ!ü÷ñ÷§¼¾¢ AöúIaC"à•ñ¬ ‰LˆD Á«F($@ ^9†D Á?ް!@ðÊ6$@ þu…D Á+Gزwß^!„ EóB@†D-*WªðŸ»í77äö¶_ц kÄ]6AÉŸ?û§Ö>xð@L rPH¡dÁ«WH„ ‰@5éÛHvmH ²×Oþ-6$^Å“æ]ièåôÚ öʦꛀ±Pk†u,+jÚˆôm !!Aƒ±xñbÜÝ݆6$@5/dCrþ‹÷ø,ô‘í÷¤õ;¨æ¦´ý>±øk.TkçP!Ñ>9ÉÜ­zƾ_׿¶lÉbŒ–4?=Þˆ»\ú¿ìÔʬÌña½ ã›{üõµ ú.µswùa½Ã𪨒۹i"qÞLp>;wƒÑŒRaÿÅvÒÝ£üé\º¾b Ì6=±ñF¼½\²Äd2ѯ_?BBBèׯëÖ­C.— Y Á ’#…¤ìðy¬ùД¦ÝÈÂ1b‘í÷͘dâfŽcD:%e¬9x+dH —÷añ{²*%:ΪXô|³à[š¿û>îòŒIÒÆîaÉêkÓäS© =d4:üqP/vD;^j/Úù+fv.š#A%ÄÅb´X2}ÞB±y+Ï®nKpŠ›1é2ïu™LµÙ‡¸½ö;æG]U ^T!É® Iò“Mtè¹ÔÎÍ¿æx¶ikû½ÿد„7jA›W››L¯GkÔeùvÛ2º6éè|{™Ö"~ @ÿ4„oÀùØDòygœák5ñDEEep×<8È’Ugètìû Ï*uê·Öè0ÓÅÜr¼Çß½^ .k ™>/Ô|›ÕÆ­›Z­–„ÛÜwÞ=3¢®Z­–2ãçò}ïHŸ¦ãSzq¯Õ\j¨-hµZŽMëÂÌ_Ü™±t5¸|6„écÑ9f)kF×FroÈ̺³é==”­£«Šš q7FP¾Ù6nBp!nÝy~˜ômdâĉLœ81ÓçŽÊR ™y9¶!Qx‡;Úڹɕ.Üúí®'[þ$³}\,1*5Œg<]ÒâRÔaý–y$)Š:Ýö„þñ.å´søî®L›Ö5ƒûíörµó(‡é-׸å²)”ø»1xÌÃ__byùq,hÀõÕ+xÔ¬+õ\Øzæ¦LVHÎŒiÎg?| äµ:XŒŒî7‰Ê£Ö3¦cEVõoGdߥ|RÛ?[é1j.3rË}–ž®ŠZm]mZ½;‚Rm§mÒVe0qª—/ÀCŸz6?Á£'<œû£C)®P9Â+h:Q÷æ àÄÐ?X› …äY’ì lH {ýdÎmH$%7gvgØÑ´O gíú ýý;D$Xí" wíGáäÇDDXŸ»ä­’!Ï’­ñ|ÆíñïçqòqâÌÁ‡ð®{¶’£‹ÿ//ÇóíªÒvîfCç.Þ{nx¹Ò‹ 劒³ÍgqüÂQ|+è8:m 4 ÀòogãÖ õ…J•©°v¢èÌbéd¥`ÞPä. ÏŒÓr6}´‹©S³NׇcÇã£y|&ß>TM·õUH­à×ý0ô/2ÅÌÆ­pcJ¤ ¯ò¬Oo ³ÎD±¤N>bÎ-fúat˜0Ú*Ñ$'ñ­»@ ü ÉQß\qòZö›ÌiƒºÍf¼ðpì_&¿ÃbJbÝÏÛlîÅÛt¦¦{ÚàøÓw×éñM/Ö ]ïÎÏVZ¶Ž™@þ¦_ÓäZmÜ!FŒøÖ~Å!)’ȧ®ÈçfssòjÀÞ­SpÎÓŽF.Ÿ21$’yõ'ay؈#ñ#¨çnbOŒ–-y³6x4éî²ù‰†yå½íFÍú[OÓoRÈëOíÃÆ^ZÍÊcÁŒx¿dŠ<­šÆ¥ÅWh0ÔÎïðïF°¿Ë—·:ÁÀÞ§[Ûz¸90~«¦Ã]…$ñÞa¶l9AùQS…B’K8m¿Mš4‚Ü($99‡ä¯‰]ñÇCÛïI«Ç3aòú¿Û&ƒ_‹)å«~¥Mëf˜M \¸p€ó¿l¡l•¦T,bÕb´1ûYŸÐòC8§¯Î¢ócéWÒ+ËDGý’‰‡4¬y3CZeîíØ³§ÛÕïÞæƒß†°ççFöÊKJØû1y×U 5j±fù6J8Yxrs —ªJF´™Ø¢\üv0Î…Þ§¡³½Ü ‰WþvOn$›Χ@™ïMºu³{wÏÖ]iH·n SéÐàÜC ž\íâs)Ùƒ]»ß`ÅÒïY:ö=æÍ(Å»CÆ2¤Su»8Ý*z¡Yq­¶6y¯âÒ%²,WAÖôîÝ;Û~oÞ¼)d-Ùà…Î! žµcé~ëâ~CáT˜O>C§–MX²óWnéÊÆ® ù²¼Žå«ö§ÄÀôé3˜qä✜RÜ-,úðsÊ \ƒ·«'³>¯KëþŸÑ=tÞrÇ_ŠèbO2`ÄZ\$%‡CܦÄs3­»‘ˆwyÿLóUaðV6KÖí‘ õÊ2{3…:ÌÍÒÀ¨¹À¥i¿~…?“.œAíz¢m9…Ö;Æ£pR;ŒÇI%C’)3<»«3áVÄ+ƒ»ºX0£f3|Â]6-™Éäɽ¹·•ƒ+Úüxuä»#l^"/^̶ßtF³`ê6l@£F ¨W½ßôf̨Þ`Öq.,o… ̓;<Ò˜)}˜;ç‹,ã;¾üVÞƒïXí@Š´[LGŸ³t¾˜$SFRmÌIú4ë{×yÞò9Û>y‹‰?Ÿnº×žŠ"¨U÷‘HJ»Ÿú§'™p$Š WÌ4ˆÙÍ—}ûb*Ó—ñ•|ìžÉ ÓsèÖïˆDÎÏU PÉÐEé2_Ör-H× YÕ·!‹‡Ø+_Q:dªü¢¦ àÿŠÙè¿ë0-¼Õ„¼W›òôîQ ]ÜoÈÕ¥í´IæBP±R˜3Ñz~Ñ‹Á«o2s÷>ü•)_ÜÈœ·~)ÝÞìEË÷½8²¢‡ÍÜC èö!‰'²s\kdÀΞҤW4šuÌ~¯†Ã4?:ò»ãTªê—­<šQLî1€ÀÞ ©›‰Í…ÙðˆIÝZ³õ~ ~>ø)Å’hüNÝ\Jw'Ž]} ­ÓÜÎïXg³ÞN÷õŒY@‹ljOüåxœ¼J‹šý7qüøq®]K;§T©R ÁÁ‹*$9±!1Z,´Z´ZЛ-˜õ:´Z-W7/À»ìûhµZ f fƒ­VËGßdú‘?)ïj]¸|=ûâÌXf|K«oðÕæ¯i ´ŸS–o_†{%Ðjµ˜±lúf ³~ØOp¯ ,õ6úÿî{³e~ ­‡¾CBüwÌØÀ^9»î¾£Í”øY hµ†,…‘x÷ã‡}̵ÂÙõq½Œr°èùcóæÌ_NT¾7Yµc&ÅdYÛ˜˜,Œ:-Z­2£‚§7c12¼§T·BÜ_Šv°u;ʤÈ¢oæq|ÎŒÙJå q÷ÏPæOú“Â-¾F—.ü‘ƒ)öQ-ÎÈãS¹ð ï.\A/±ð¢Ô¬Y­VKDDAAAôíÛ—¸¸8Û|©íIØAÖ¼ ‰B’ؾh9)xþ™RÉ…}Kù`Þcæj†Z­F%—wùáÞW¹kPð†·jÉÀÏ3?bÒa|µ=„è%ýùpº‰No«x’ßWr£upÖjµuç9[v Õ¸Çæ_£˜°æïÔ̸Q¼åvÎÒ°,ÁÇ.Ý»?ïÉðuçè0ì;fv}㹂‰<6…¦~¥Ûè9,èÕØöimzÂÖôcè¼Hº œÃ§ý[¡ÊÆnŒ\’ìlHŒIç8KŸ<„ŸŠF&Wew±vÑ̘H¼¼?þJ¨‹òíî}Ì?™çŽeÂ'(\}x³óhf|ÖuÊ×6&ÝVEê˜Û¼(jµuuGE2ññq˜UN®áœó¡x±¼9 #IuëÖE©TÒ§O’““yø0ÍÐ;µ= Y AÖ¼Ð]6¥kÔ¦Š›êÔA)ÛÌßœbÚÚ4ô³FXb@[,_LcدÞt¾™(?Í×;vЪ˜;|µ…–—ްë÷ÓD\»@\BZ“ÙŒL&C®T¡vr¦»«•¼:ÛoÊ2MA¦0ã·Úï´ç‡¾ßQ»°[¶ò•·æH¶„Œ%ÈC™©Ÿâ=–ÚÝ Ï¸oǨ¿Ï7³¿&11Å™¶ãKf,$¯|^ùsÆì¹Ëʶ…­Š*#f}ÇÀ¨IFá’ñ°®ð­ŸàR{:õ=Ó¶šò5œÃþ†¢â;¢Âø­„æ"œB¡ ~ýúFîÞ½‹%‹+@Í­s T IDAT ßýû÷-aaaæòå ”-[Þ¡gC²™³‹Í„Á‚ÃÕ}²Ií’cicÓªù~ Ù@~Õó/o3ioÓ¾îŒ?´‹š/ἑˆˆ[ÔªUëµ/¿ÐÐPüüü²í?Ož<\»vÂ…‹‰Ê/™ªkÜ»gÝþ†Ú É0iµð1u8ÆÐJ>6÷[?`äÞn„nè”å{㯯eÐw ¬3€¸ËçÓèú ¨P…@•ÜÎMyˆóæ`‚ó¹<7Iwò§suêúŠAå?EOl¼o/—l1™Lôë×úõëǺuëËåB–@ð‚äJ! »qo·ï£ SƎج»C«öÃ2¸Ç^~À“S#y\÷K¿abÞ‡Þ³!XŒLYp‘hãªVý×€fÙ5óìÝuxWÀáßj61,¸[‘bEŠVŠk‹[q×Bq /ýp§@qw VÜ¡x  ±õýþHH²DH€’@ÏûìØ¶ÿÍ_ÌÚóìö¸×:t(ÇŽàØ±c :”qãÆI£ !Äû$ïšC²rþl\b»V[ƒc.Ãf¢O+onš3òûêSŸ?_´¤SC=öüÄI½ÇÎ$…JÁýMí踿¼]ý »ûèÖ¶îÍçЧ¬'z½ž|C§² ží‹^ÿĨ<ª9•¯t6ôz=AÏáR„É£kÄ¨ç… EŠŠL(;‰–ã|ØØ¿˜%Ÿ‘€[}(Xu+W¡Tf'Ô<Þ?”ñgTüÑu£G?Šw» ЧZÉÓ0¥jE1M¢^£Öµ<ÝCùõ/?æ}íÀË s·ü6õ~G™”Z9š>E yÖ]!’¡¿7[ôw¨ß¤gƒ–S˜ºf#Ù#z®=Å—çR=­†ï:õaÿÑݤtö a“4›p†f]c,K夯zö=Wã=û™ÝΑ1£}ÿ+KYt¼}:䯣PpeÎ5ÒUèóõsîÜ9»iNéò'ZÒë·%SÓkÖ5ˆH‚dÆ“ì7Z’ÿ½{÷&¸l•*U¤Á„â]’„ç¤eîÜùnQ3ã×Ñ'C ŒAÇ©Ñd=ÛW#Ìjµÿ ªtÄ5¥Ž”˜ x¼‘²ÞC±©uÖ†6ç*P,ë†ø2ñk ;fô`ÔÞT,Û0‹ß:7¡éÉ èÚ–üi»sLÁ×èU¿9·Â,”òR£ñªD³fö[÷pÇV]«H³fÃ'˜ èMpáI(® í^“ÑjEÿb =z°[Fö¦s™×.wT¯Na7B^B¯/@šÊK¸r…xÚH$VÓ nÝyù¿Æ)#Ù39¿Ó²Z¶l™à²ÿý·B‘ï•Câå医JÅÑѹï Âf D¡ÌÄÉéc™´ï8¾ÄU¥«³n±þüe¼tjHߟc•qHéÁð2ù)2²7é xü×N:ÔžK@®¦ÌP–‚˲b_~f û‰fU1ëäi¾qú‡Îuš£¯1ŠZ›‡¢vÐź}Z% ¥&Ƽ‡ .YÝì¦k•Jœ½~äÈ¡®ñ6–[6,†’ð ~<ƒ/¿ŒzR+}ùÍü½Ëû–•˜‘Z_ŸOrÌ!DüÞÌ!y§gZ+ŒžÆ¼yó™9%üVH“ÙËXÐ1®Þ£X»öÆÔvÃ=o ;Gݺ=±1­6ß ðöD†Ír¥¨îރױeVö¯Mé*ß³ú„^Wqrû6ª¸ëP9d¡yy¬ÚŠDok:­ƒŸáËàg@©•ÁÚ>E)³ #(((òçæ¹•"„ÉÙ;å÷˜4‚AŽjl总ÏC[®‹‹Œç÷‰—±{®]ßs/IÝ2exÏCž–<=>“ܳ×ËÊ ³’Á vSwï"†hC梇(—3sDM•›”}ç˜/…ǯ¿‚Z‰¯x5·¼r”|’”¨ÿ…1dÌÒ¥K#ÿoÙ²¥ŒC"„" Iì8$F›Rý~¦£C(îî娹óå=™4¿_×oK¦š3¨ì®²[ÎÒÇÁ4J¡ä´Í†Â¡y¬]ØöO _ÞŸEwP±iKZ·lÌÒ]Mk¬Û`±Ù0ôèõ1Ÿ˜1­Ø¬¦õò4ËŒïRôÝrE½«læ·Þç?¼ï Ù»æŒ,÷ôÄhúμFë™ ©â&]òÿÑÏ‘!C†pëÖ-|||(]º4C† ‘qH„â¼G‰•æ•¿æÒ£0œ{vâqîÜä̬…NÇÍ£«Üw)ßu„ߦA4êyŠÎm[P£dn¬¦Ðxå§Az7Î*hX°ù©Ó¹BºŸ8~°)V,e`½J¤©Ð˜:P&—GŒ-P)v9$æ ìóñÇÃÓƒ{§_ Ticl{ö:?Œ@U{ÒFŒ›’Ò+ YýSÇ{ŸßbxÀ’§¦VˆNþD–0°j$Gà3à˜&+9²§y{¹7Æ!Y´hQäwÙ¸¸¸ÄZGŽ!„ˆß{ŒC¢dúâ 8¥O‡£*<—Ãp€5–±ª}E&ûf¢ßôÝ4-å…µG#þ˜;•9cQqÓ/8iÒ±bÇŸvKK5ê»l´nÙiÚu;õ`Û™Œï>š?vLEû–”³Ñ—ß&M&88ƒÍ‘ÚCsÇ|ÁnÕ^d8ƒv?cX( šDÖÕ¿Ô8$V˜ zôz•Ýt¯Òß³nwªTh†Ò¥7‚Éáøö8Èp’æývSeò^,=ÑŸƒÑëM P³zÿþ7v0½›•cYí.ŒÒ‰lÎjLÁ×èU¿9·Â,”òR£ñªD³fö˸c«®U¤Y³ŠáLô&¸ð$׆Îvm`´Z }º˜š5·`³xé÷Œ"U[0cÍ&¾vSÙ•u)ìFèÂKèõeHSy W®ðÎíšÜ„<]‚&Cxc†ø­$E¶Zr !„ˆÓÏ!y¥4ºXëž›9žç’üXâÍêtcåöˆç–ˆÕäÇðÝQUú™iÕ³#Ï5"·ÃÙ5;=~]C½z«é×4ÝÇ—`ט,t®Ó}QÔÚ<uÛä U¢PjbÌ{h°à’ÕÍnºV©ÄÁ½*cÇÖçîù#lY½Ç&7JæOî,\·l.X >»±\ŒAg¨Ûd¦ ‹„ùe¦fÍå/üì5kÎÆ%CoÖ.ð–3O!„ý%ûC缫ççÐfþuFl?AÓìZT*óý·]ñÙ?çX© º³m{rÁ¡:û§µ"Ý©tSVôÆ×â†ÊAIóó¨Ü¤,}6ÿœèíM§UòÜÏcºJ›ž"EŠQ¤H1ê4­I‹rµ©ÚÒÂñ]í{vü (µŸßS'ÚÅÙ¼y3G[fáô ,,”Š£- ±xöz~ÿÂ…B%gBˆw–à€Ä|šùKNÄ9?ÖÁÅ|Ó¦ÅÊ \OÓœ)èè»E%«­V°™íÊjÓ}Oï/f2·Ûpzœ‚:"v:¼ï Ù»æŒ,ûôÄhúμFë™ ©âö‰ßƱ™Xñ*5#ÝXàD?7ùš!„qûà9$:¯º,XP7ÎNíÝ•ÜnÎèt:Ì¡×iÐf4%ºÍaf·øó Ü´7 HY˜ÑÿNµ2_D^Øãß8$Ñ{2 »sÈöùøãáéÁ½Ó/Pª´1–‘½N'BÇ#PÕž´šðWSze!«êe[ÏêÁ¦¶KYðw(½ x`1<`ÉSS«eC§ ¢FKXµŸ|^IØË-„x´F˜‚/ðй^Âö—Bˆÿ¬žCÒ{ꬨn§¼l^s€´…3½µ^Æj¿° ZâÖ¥qÊÇÐ!C½f£/¿MšLpp0›#µ‡æŽÙ@nÕ^d8ƒvˆíæB‚‘w¥rÈJëÖYßZnü¡3(tNÑ.¨5Ù¶³æ[ëÕŸ9ß«õáqõµ”Ë—#AÛtóÊzMzÁ¤ýß}¶‹BéHæ,¯ÿÑ’)›VÎ !„& ùPã$Ó+(¼1†I‚8•bÑø3ìºõ‚+W®'¨Ê³«‹ñžºˆÂZëçÓ~B!Ä{úèã|n²TîG›D”÷*Ú‰rÜ !„všC¢”¦B!DR“$Dœ|||¤„B|œ€ä³Î!ï,mÚôÒB!Þ›ä!„"Ù’!„B$;!„"ÉI‰B!>:É!B!D’“!„B$;!„"ÉI‰ˆÕÎ];¥„B¼·êÕªÇ:=Î…B!9$"R‘/ Qºtii!„ïÌÇÇ'Þï²Q(’C"„BˆäC!„B$9É!B!Ä¿æóÿ.«GýȘ1c¢«ZŒOX¸d m;tD%ÇŠBñ¯‰/‡¢Æ!Q'f¡6Ë+:àòéJU ¿SÔ*®NÿžÑÁY5¤px`ŠÁf‹µ®B©ÃQw¸` þ‹ ¾çê­{8$òÆ“E—ñã¡e»Ž¨P7ôé~.ZKQÊËÉnzÈÃ#œs,AÙT’ü!„<ÞÁky*dtŽvЙAq ÙŒ ÐFÎzpï!™³f’†BˆÏ@¢sØ-:thGùŠ•P)Þ^¾dþRv‰)è~¯Œ‘ÿhü ÝoûƒÍ‚É *"ð1ã^x!>ë*¾÷ |~j;ûî¾²H °~íê¯#eNojóŒ*k|LÏCh±õ 7´¥×®¼lÿcJ]ýöaóÞ™¤Vÿ·ÓqNOiL»å/Ywl'yí«ãêñãz Ù@.ÇØ9‹á!-+ôàÇ“—ì÷ߥöTœÐŽË+ÊqoKmšßœÈÑ~¨T²·Ÿ^–³X!>‡€$19$&}x0ñëo³HKDb½J¿ {˜8¢'1–e´X±YŒ‘ÓÊ®;Ä9 èѾùþ%gOàö²&tÜkŠ,·qå2‚ÌÖ7.`÷Xøû¼·]”ê4ÿ¾~x±æW~½V€º¥SÛ•iݺ ߺa7íé¡õÜø*+ß|õ ýĨ<ª9•¯t6ôz=AÏóà¡z½EŠŠL(;‰–ã|ØØ¿Øú@*ÞsEÏMí–‹¹±®}äô {+øvìºlºI.G5××ÓoÔ ¬ìhWÿpÿÚ$×ÀôrÖ !Ä'ä_É!Q™Ã»Ët:žü9„iJ3¹Çw¨#‚C#ûq- )uo*·9~ü&gnð|#‡¬âñc_þyÊ®}»0¨ÃPª="׫]äÿ/^`¶` þ‹žÐ¦e-À™öí;ðâ9æ°Û,Yy˜æmÚâ ¥ÚYW«RªX[~þ¹è[íÔóü¬ÒFÖ5‡^¥ï_æŸ)†N§ íj …*²L©þøWª¾ý}È¡Sÿg8…Ê•ÙñEîÆ ØW“_+§Çf ¦[ÕÞä鲎ѕÃ ß½ÓÙ|¦2 ¢º!i¾ä><,c¹¶úRµc*ŽyA“è·s„B${ÿJIt™jtÀ«wG¾iîÂ9#ÉÎ)zþùœ¹§jÆŒ‚ü·0sÑytÏBQ:¹S¸L j¤OOú °™ƒPªÓE–·­‘iû /g áÌæ/Éܪ?¤º0ÝÛДõ‡dÄ1ÖíYÔ›Jj¶T-B¯¿ýãþ„ßk¿¯B%G¨“0¥jE1Mœõ´®åiìʯù1ïk/^^˜Ã¸å·©÷ó8ʤÔþg:§´5Ù÷{ Š4­G»Çx>á[ö¤lÊíñá£ôùîˈ5wÑûo§C‡G8¤,ÅÌÉíxrègLi:Qúu[ÙŒT­V+< ¹HÁ6 Øœò5ñU“ÚÌñ¬Í¦UÝìÖýüÌ$Ï»Á÷“fò«ƒ¼!Ä'æµS6ÍÛCé}iTñ;êä{IÚ&s(•"æØ%CoÖ®€ cªÑ÷Umš6(a7?Ô7¥&MT@b° Ž%×@¡rf\ÛÜü8h?,­9}Å”Ëük¬Û™­éO hxŽï¢M·YBØ»r3»çHºÕ- /áÊœk¤«Ðã­mñmÉÔôšu "’àGÙ°á$ûþO$ÙÍaú–T¯ß•Ð3l¼='exZÊÜßP¹ÐZöÝËC½zõP;„ߊ9?ñ"é«޶£µìÞ½«É¯,mÙ»{ æÐk¤Ë?Ý»çÆºÞW÷v³|ùŠŽš&‰B|ŠÉ»äôzô9$%[Œå×kÕè¶é5j9Ç;†Iô«%‹Ò ü.úã’-}dÝ#*Gk¬ËÊÚj4ÖÍY~µ, ³§$ðæb–Õšw¥äáÙŒk7o†o&¯[ÌÜ›%ˆµl‹u[.ýJ§Âé8»{ gߘW­acÜTJ,¸du³ÛŽ7sHܲ¹`1<øÏPÓµ»hñwÏ”ä^¹ƒ5ù<ÞZïV˜çÌQûÏt†ºM†a ºH˜_fjÖ\Ž1ðÁÏP³æìð·Þr– !Ä' Ñ9$ …"Q+°Ÿ²tü`&nxÊŒ©œÑ™ª\©[¿ ]0«ë71+)@ïçGhh W÷]Áfª 63‹nðÍÔ QQÓS=ºÜq_Ü3ÕÄÃÞÔ«þ Ž^­8Ù,W¬ål6×®]už‹JÉ…+— ‰åÖP« TN«ä¹Ÿá­mað3 ÔÊÓ{~êÉZ¿Pž-„ ïE‡ˆÛ'ƒfÌ%GãÊdpPñìiT­MQœÍ›7s´uaNßÀÂB©8Ú²‹g¯ç÷/Cï”C¢püŠž£WQ¦B>À>×C›Ñ›å+¼Ád@o²¯Ÿ²p/öûôŠüßtž–Þ©è»EõÀÄ–Crxß²wÍ9íé‰ÑôyÖ3RÅíó½³­K þLÓ—#¾À#W^^ß qP(H‘#_¼qËÆ)³zÿ< îïy%˦£X§œ<˜q FE{ì×fbūԌt ïaYàD¿xÚòñ>4}žžl£Ž‡£œÙB‘Lü«9$Þ_—JÐF¸e›ÀÁ5c÷òÊ6zþ8cµQ̬““£Cz°Þä‚:ð B<Ø”=ºˆq=.îýƒ­ûö±cë,YJÑ}Æ^š• B#u³Áì­Z“ÙSf2¹w †kÓR³Õ$¦ô)cVó ^Râæ¤ÀhƒC¼yÙët"tü0UíI« \R¦ÉD¶¬Qù.Ö<50µZ6tºðöÑF``V­ÃgWòûŸÛ™62ÖyÙræ"£CÌ[+*ÿJÙôßQ0OYj5íIɲÉÒ 7!ý{ñÄØ¯ˆž”°—[ñh0_à¡s½Èñnbc5òâÅ ôV›œýB‘Œü«ãl;x”Ê·÷B(UqßY5i aaÏ:ä¬T’¬¡÷ªÉüN ÈmÈy‡§¹aHϰ%{ñ.š5æ‹ò,LŸ± è9ô ;×­FY¥p¬ë {¶’’¦`S*@™† oé½Ð¹Ugx‘á ÚñEµ³«Ý¶´‹*soãœÊŒ£¼kÔã½^§°§âç}€™B.³?ÐȲ*±çÎl8ùW¬Ó5Î…Øvá¾Ý4G:L.Ù›NﱩIöð¶w¯Á©Öˆ:ùøkïðx·'cõÿq¡ºœøBñ©RøúúÚîÞ½‹—WF®^½DþüãúJhhNNŸòh™VÂB‚±9¸à”€ïŸÑ¿>>ÒB!>N@òúÞB¡HP‰øoH›VFžBñþâË!Q(’C"„Bˆ¤#9$B!„Hv$ B!D’Kô8$B!„ïKÆ!B!D’“!„B$;!„"ÉI‰B!>:É!B!D’“!„B$;‘‰B¡Öˆƒ-eW/]㬞š¬ÒxB!D¢ÇÉ/‡Äf„Í[â#“ÙŠFýî<»V.á±Áë¼´_7 fnWB|7ñí;Ø´i6®ª·¯ïÆbªT—b{»ÒzK^v/€Nú¡„B;$‡dÏž‰Z©·wõ·–¹¸y:ãïàÚµ[YÔ¤ÏU‚¦íûÓ¥^áÈ2VKËÆdÞ†#<{e!kÞ”©ÞQ]½V·*·¾ɪ±¥c,ßv›µÚSbôjÆ–I+†àËÌ^|™ž]ê÷'K¶å£së<ØTZt:ý·Eù>›Hëì” ×êå ÂO¡!«ÅÔÙXŠN+³ºC^9ò„Bˆht:Q9$êw]P¥JÞ€ ›íõoüþsìØnÞ¼FîÜùâ\Öòþuµù>-‡Œâ§‰Åq ºÍÁý›˜Ð¿.Ÿofn‡‚Õ” ›S0yÑJgvàÊé#Œê×™&¯±fp9¾¯¦£öÌÁ:@ •}ËÃøç̢⩨ӡ3a/þdþʺvíÎËkX}¼*]»ÖÜžŸ¥ÿmxReóä´[Öé½»xnнwÅhµqòÏu¬IåH¶ñÒœãÿа^E9ú„Bˆ8¨ß½ª}0b³Ùb$ ữ7Ã7œ§Ï†³t-ìñºŸ_–#/²{1†v“qPÂï[î’§Ë&j|™€¯«5c}Þ4<ñ,@Ž–#QM©ÏÈ3ϘT2­ÝzNº@úŠÓÈ U½åeÙ¿b*ã&®¢D— lìXçgç±Ý¿-+gàÔÞÜ5ÅZÝlƒÇ§.r-[Šˆ)×Pë r¤ !„ñ$ïšCb0#à@Ä(ˆž×2çý¼üh—Ç)F™b]–°³‹›QÈ Sqm×N‚šgÌ1Q§ýšLXÐë- ÊGÿ|̱ýÆ6Që~¹…OC<°¨Ý: جèõzôF XMèõz®œzJß»©˜3%†W·ù±ídrŽ©Y·Ýˆqq¶Ë©U—õõ)`7]ÆvB!b^ß{­Vï­šèÁJ\Ë´Y‚YãJþ6•´Î¾sû²¿ñ/T¬ÿ:v Yír¸¼qk¦ÎèêüÒp ×,í)â¬àê‚ù8¥iLûlžá/þź܊Åôæ°èÖ­ ¦K„<õ£[÷m8º× {4Ø,Œú¡ þå~bB­Ѷû·þ~cûJ-™¼½X(c¹!„ñø`9$oÞš‰-yÛm‹á!f« âž Z§G¡vìÛW„ù³ç0p¦OÈK»^ÃèÝ´ddÏ‚Ã(ถ1«ï°¾]°™µþÅÇþL¥(I§N™0äÄy:uêLÈ“9œ—‰Nj¡Òza ¸ÌÏÚpÄ¡{¦µÂlFíÞ\Æ “ôïÿA·¯ñ»Ê!7z½ƒÁ‚ÍfB¯ÃçàCÚLßBýÒYÁÄ´¶m)ÖÊ.НÃh³a5¢MwâÇL:F®»É²&ÙåB!bg‰B¡HT‰Z­Žµw$®'mâZfÏÁeÙÜ"ÿ;S—®eÓÛÍ»ºªMçÄwÙØÞŒ$äÑß,õæ1°vA¦¶©ÄàÙ+ð9ƒk§ö1òO4¶‰"õº“Z­Äb|ÌܙӨ]£3ëwæîã{Úº’n?Ÿ#Û·y³¥ñˆ ü½º/ÝÓ"s,k¶2{ã}J·Š½Ãbôe|û*Œ;êÊâ­³É-y|õ,{¶þÁÜiãYîÂűM)R´<ý'ü+_ºèª»œ¦Õ”ãXÂn²hå<š_!„ˆ¯£ã}*Ç÷TMx¯KB–¢¤Ã”Í/7™‰Ë–ÒyÆ0B,Z2æú’³¶Ðºjøã³*mzflÝÅô¡#Yôk_=xŽÚÙ“Jú3þ§˜#Á¦)5†,ÚídÒ)ÖµúîÂaKAÎJ#P9½i.cÆÍàyÖzü¹o9œì›éúŒQÌ t'oÞ¼Tø+Ý ¢pþlh£½Þ1üFÕ ­øáRjRd퉛J!„".ŠÛ·oÛüüüH™Ò;wn‘={®x+9r0Q+É’% ™3gKXa«=ZtÊø/àæP=j§w´vdõ¯ð½î%ÂGn z4ž¦ý²±mu#õjCPÙéÚ  ïGÞØÁ°_7Qwø$¾Éì"G›B‘±Æ«Wþ¤N~VøúúÚ)X /Q9xÈQ!„B|d¯cgÏž9sfà=nÙ$·#±$B!’yìC!„IîÇ!B!„xWì»l„B!ÞUø8$|ˆqH„B!>ŒÈ€DîB!ÄÇ=ö!„B|t’C"„Bˆ$§Óé ’!„B$#!„"ÉI‰B!>:É!B!D’‹3‡DûB!ÄÇ=ö!„B$9É!B!ÄG'9$B!„Hr:Žàà@‡D!„ɇ$B!„Hr’C"„Bˆ.Î…B!9$B!„ø(t:!!¯$‡D!„ɇ$B!„Hr’C"„BˆNÆ!B!D’“!„B$;!„"ÉEæ( É!B!ÄG¡×ëQ(1sHüýý%‡D!„…N§#44HrH„B‘|H@"„Bˆ$'ã!„⣋sÉ!B!ÄÇg‰B¡ÖB!ÄG=ö!„B$9É!B!ÄGgI@@€ä!„â£Ðét„…K‰B!’–ä!„"Y‘!„B|tqæJ‰B!> N‡^"ße#„BˆäC!„B$9É!B!ÄGgÉ«W¯"sGîÞ»þAWj³%¦t<ÛYþ½Ê !„âߢÓé0B#sHÔoÈŸ¿ ´’B!>*É!B!D’‹5‡D!„âcˆ7‡D!„âß=‡DnÙ!„"ÉI@"„Bˆ$™C¢P($‡D!„B¡ˆ™C$9$B!„øhŒÆ0É!B!Dò!‰B!’œŒC"„Bˆ$#9$B!„HRÑsH"¿ËF¡ˆý‹çöìÙ)-ö‰òö®. „"ÙŠ{¨sa³ÙlØl6Àñ7vÿ‹¤ózß¼ÞG‘FBñÉHP‰^¯ 8ì‡%$Ÿ $úoÉ B‘ÜÅÈ! Ž3‡ÄÁÁ!–Þû`D’¤FÞì­’œ !„əɤOxIl»Øn×H@’ôIl !„ÉU¢sHÂ+Á›×9…¬V H’QX"ûA!Ä')A9$ƒØòEÞL¤|V“ËWm§yËVÉz´¶'7 J‘t.êd¶eЉä!„Hîbä„„„Ä›Cb»ÆÆí¥=é·ándòåÈßú…·çðóoW#ë¦ÌÖ™1½ó¿uƒLúgL:•Z·G„‰ÕÀ…‹÷(RäËó•1ŸŸO™Þ“ÉëøþAIسC\²~ÅWécδ™0¡AóÆÝ´GǹèX”Òžoî/ûÞ*É!B‘œbæ$VÖF£YXËŒÕjÅf³¡Ná €ÁÿçŸç—žùñ¿:)‡žÇ¨ûêö!\ñ·›f6<`ëæ?Q¿qv/P™ò9RÄXΓ Ç9zá2×oÞBá–™¼y¿ fÍopR*Þ¹qL¯NÓªõ@.^8cÞÓ#|7­"¦T;Ød|ï€Äj|BÿFÑtÝv»é—·ÏaÊòÝ\¿ñ7Áf5^9‹Ò°U/:Ô.€JʳvëdR©eô!„Ÿ¾wº¢êýwP»ÉäðÏä=$CVo&ÃÃP\ó• lÙ"ü£X‡Âë<ð7’Ù] À?‡gñËÊtÔ÷No·ÜæÍ[pûÆu»i¾;ÿàE»v‰ÍÄê_û1"†5KòÇ6¦Œ(ÌÁS™¾x3“f£dZLj‹¾/ÍZôŽ÷õ4™½”úžoëM°’²QMž†"Å7ôþÊé½ÿô„Ž<©9™²n‘ÓVmƸmøaÀú-ŠcÐŽÞÆä¡M¹üb ÓÛ|.UÆ—ÿ§g}¿¢r !„øô’wÉ!Q:•gÕª¯bä89*ظæ>éÚ¸c6›0[¬ØlŒ¡ù®òüuj‹ —L èÛ·Ì[7ðè…Ì·š1›Mш‰i­¿åtîl]Ö¶³lq*|Û$üg~{z6ÁícÐ(À†3-[¶ˆsù Fåi˜³YÞSc1‡ÿŽXŸEÿ”=Ö²zõ:®¾teÎÎõsÑFmÏ;2‡Ý ïF_¦È¹¬'‡†0vÓEº,;@‡î%=ù> rX0zß2BV :õåžwonwÞEV’C"„âSôž9$ž/ëIç•·#ËŸ¸š®¯~ç׿]XS1jµ 'OoMf@_-:÷*¨ÕšðKlÔuÊÄù­víEœ™ªÐX†W«OÕ|ž‘uíè˺JpxYs” CNã’¹jäüÊæñ窯v®¿J ¸ñí·ßŹŽc‡£Ti"ë[TáFA÷αjÕ Ön:„ç—U¨ßm2³«•"¥êÃÜ"yvvfÏ(îÕÓ²|ÜAÜóõ£ó—ib”ÿºçRvíñ( Ôw å·KüV*íë¾#É!BñÉø 9$¹ZÏa{sKd‰R­å¯ßï1ø÷äÒ…÷6xäÍ’Ygñ7B¯‚Å#ë¦)Ý–î¥ÁTkKMV¬æ—Tö®Çú=ðˆÈ‹Pi\qw-FŽhë]9éÕ¦îÀ!"OÄïèÒVŽºõ£PêhQÄ“±;žÀWißéµÙ¬jtš@­ºõ˜µy,_¤w‰£œžÃGN&jÙùÊ”#Fɵßo¦lçhË f­_(yø:Žš1óbªOÅ€ùסTZ9ª…B|ÒÞ9 ¹¹°#?®ï!±Ù ÄÔu|ÿ,˜?'våÏ7{X\‹²pvÌÛ3 ­ –ep·fX#î€xx¦"•&®^ kŸ‡27{ÊÈ)VÝ¥àû rÊœ):øÎ¢Pj9¶g=ª·äÆÚÌ þs¢–=ôÏÝTqÓqíiî Ý¢^™Á³Õ†{Q/˽¨¡ oäHBñi$ï:IöÖóØÝÊ>‡$$EªŽë̶Üý^#—ôa‰öËXs.î.bÓ¦ÔôïdÂ1äÀ~8D‹GRdnË.yÂK F›’‚á9VÓs–¼LÇN/ÝòŸxŽGq·åyØ«ÅY6<‡DÍbÂü¶ÊJOöîÝ—èF7›MÜ՛ѥÕD®×ªôD©Pxõ%æ/\´m:,†;Ë!„Ÿž÷‡dEÝŠÌ V¡S(°šƒq.:õã‹ñý”I,óþ™à¶ë) ?LgÓ÷UŒÌѰëeY|Ô¥~A­Ö`µ…ϯè]Ѻ&tné¢êªS‘Q wL ò9©¹¿m$îÞCpÑj#Ë[¾Ì¾H‰¡™b]gŒÞˆ5‡$!ußG:­Š«þV»×ö‡Ž#CÝ,w¬uL6ìÆ$±ø›Pi3DÛVÉ!BñéHtIlßcc ¦þ¢ýôHïÌ“£íhµÆ€Æ¥(KÇV¤~Ãî0Ÿ§Ñ´­q‰yq·Zü³ß?Õ(Îö[Í—¹ªxÇsË:ôdÜê³,¨çÌÏÎÒaó´¨í´¼bù°ü“®ƒò‡ßú0ŸeáŠSq.Ï×h¦„]¯‡lf‚­6\Þc<“·É“BËÉ›¯ F´×Ö·4›‡Lf¾Ou:–ö²+}Ý@Zÿþ„­ÛGŽ=xýZ·Ü1‚>^!ħ&9$ö;›Í>òÈßúûz<’`ez<_-ç©(íÿib¤d^œÓ‰W™Z±®£‘f ~¤ÿ¨^‘ëŠoúêG²ÿÇÞ”ŸB‰n‹©Ê€ûW8zü[Wüë)¿aÁ²^‘˰šžqåÊ•8—b±Ù­SëR”4h;èªåON«ÁD€¿?/ýý ð÷§ß´¹dqP½WÃh–™'KÏBϨQl37ÞÇš1µÓ·øvHÍ’Ep3=æØ±ƒÌþß6Šv˜O*µ"r[Oü‡ì]óĺ„BˆO* IH‰^3‡Äb³qtÖD‚œ5„>¹˜ ¸w‚éãaÇ7úLßHÅ”3yò ¼—f¡þwßѨ¾7nj%/þZB§…wè½a.28ó»ñŒþ¹=ÃÆËÓ­•¬3£6}‘F£DåZŠÉ+wqû™‰œéœ1™L<Ü?å>.Tk3†_k•ÇQ©Àd ÏÍPºTbòäJq6Àœ!Ȥ¶E–+L`Ýþ³Ü¹~…0£µÖggg\Sg CÖÜ8Z͘"žzWi*µ tÂx‡6"u´¡æ£—S¨älf®]I¯¹c5kIŸ£ Ý'®àûoòEn§Õøˆ%ÏŒüR&&“)Æ÷ Å·?…Bˆäâu¢ðõõµ<þ—˜É”{öì¤bÅJ1>}/®ö;Ž –»°¡uËÊœ.ÍHÛ¨CºÕÇ5ZÈ•}+˜±ð*S—ÁQ©`ÏȆûr#êD=Ðk³söØqnÝ{Ä ÿBõ&,V+(”88f¦wfŸÝNX×®2,fvÍL±°0 |Ä9º»´£óºìœ>ÆÊ›ûçÔ©“x{W—#]!D²HªT©T¨ðÝÅÎf³a Ūա&*¿ÄdB"!É V@¾ƒÅà”†õ°`×"ÒiÞÃ}~¨Ö‹~[ÖP<…6–€ÄÆéÓ§% BñÉ$ NjJl ÿ_å CùF²«ÊEÀü…¨<ˆÿ2­Û×ü>æ1¾Aù×;°²U&ͧ˜‹Æ.HŒ¾„BˆOI‚rHÂs"’D­ÖÈ à닟B$R¾#Ï’h4<óW¢êµ,KŒÀ1úoÉ!B‘Ü%jµZMTOˆêOãòdGòðº÷*jŠŒC"„"9{ÏqHˆ5‘€$9$Ñ÷BñéHP@rôèai)!„Bük·oß¶Aø-µÚAZD!„…ÙlÀÙÙH`‰B!ć=‡DB!D’“€D!„I.Aã!„BübŒC¢T*yõêÕ¿¾â¸IMÌô䲌ÄÌÿXËxײb !„‰‘)S&¨‰ü.!„Bˆ¤"9$B!„Hrv9$B!„I¼Î!B!„H*rËF!„!„BH‰B!’> ‘!„B$5¹e#„Bˆ$§–&H:[¶l‘FøD|÷Ýw²e Ù‡â_Ú‡ 9$I®J•*@øp쯇dëoñq¼ÙþÇŽ#¾óDö¡ìC‘|ö¡Õj¬ýoÙ‡I³­Vkäß§NŠwJIsttŒqÂÄv2‰ÿF½íã;OdÊ>ÉcZ­Ö?6› ‹Åbwqo*ŠïC¹e“ÌNºØ"zy#Lú7BÙ‡²e&ï}[0=(yý[|ü}˜Ð¶—€$tq½ ÊIôñ÷IlË>”}(’ï>LH0"ûðã²Z­(  E‚z§$‡$‰½nÿ7ßô$¢Oâ›ûIö¡ìC‘<÷¡^¯3 |}ËFöãÇõæíš·íCÉ!Ib¯ï{&öÞµÕŒ€”îh”ŠdùÚ,_nÜÕ?ošOö01÷®%ÿ@ö¡Hº}¨Óé°X,v½"¯ÿ~}a”’¤ H$‡ä3v}ÏVN< Å5{E•Í·<ÍBƒÃptq$!aŽïùC²•&»«6Æ<³á>gλòuÉÌøêc­|ÿ:w_™´]_,càsÈüléñrIØ¡lzåË3MZ28~:‡þÍy}qè‰Ý4‡”eY4· ½Z·à™Ñb7/C•QLl›3òÿuË—Q¤á÷äÔ©¢½Ó›yhP)ú´X‚´8“ÆU{ÏÂÓƒ\´–¤¤W,o26&4hÞ8Bã‚S1Êxê>«sòÔèžh:’¹Ü’lôϲíd*|Wà_Y¾ìï„FR&¬ Íè+ìÙ.[‹S"c¢ÖòȇKŽE)åéðI4› Œö ~t’“~)hÛ»;üŽsìn@jY1†…àÿÜ߇÷¹uã:ÏŸå¤Ï1½bWrÛºU<±ÄŽØ°X¢ÂŸ®:oÚÎS½…à‡‡X·nëÖ®bÅÊÕlÞy…ù2‹/cÅÊUáóÖ­ÃíƒfЭ \ynÁÉÉ)òç¯Ó§Pè#ÿwtÔpòäIÜÝ=Þè% aß–ãX]pR+£}ª2³iÅr¶_ñyÀkLÚr Å'täÝ»BXéÞÌš5‹Y³f1å—Fœ¿t€ËçÎ2~ÆÌÈyÝ¿xÅÕÁvõ›0žóÁF»ž«ûÿ Yã‘Y¢u¥ú­¡qÃÔ®U‹ªU*ñUÑBÿª4Õjö5ൟлéHŒŽöyië,Z6®ÍW…¿¤PÂTªÓ–y^Šœ¯r e`“<7^ŸV5¦[ølñý ˺¿m ž}šèz¯î¯`Ü”} .¿{ÛG´“kUbнWq–•ýývý9“6ÍêQö«’”(UF-Ú³xÏõå.OìH“vkíßÏLÏݺM;M%0Ú{¬Õø[ŽÑî Y—JÊЖC?™¶—’$VŽs’IDAT–Ø{׆—7Ù´ç%u!·»;¶šµ8´y C¾¡Lž´v½ãcöí;OHh!¡a(5ޤH‘g'xôðŽîÈ›#©=Ò“&uJ|¿Àjò㎔Λ‹§7®rçøNûc0é1L&Ó{ÓÈ;=6› ÇŒE©Uú4ûŽ<¢uÕ²4Ê•žLî/7a5]ê‹“B…ß¡™¬ô¯FŸú9#ƒ™Û·naÌVι¿Æ»¤Ž¡fŽ:H…j5°½|†Å6«ƒ’*uj^<{Êëyrb;ÁÙ*Q"Wz^ܾ‰)ââúô/Ì*T®’¡t9î½0D;â3P!ÃY¶\5ñmN0ÇÑ ŸœòÌV÷7þB—㺈@,lù1™LØ€~ݺòºŸ#ì±/¶ fL&“}i2a2…÷ =>ðí·b’÷æž{J¯ÂžáÁšS)ZwL‡»;žžž¸¨þ¦]ÝÞTыɄåí:9¦kL¤”³2r}«‡þÀ¸møaÀOôSÇ »9¼ÉƒsáÙj¦·Éʵ"ãËM£íÄÓ¬ïWôßûú‘÷ajïôü3á멸ó÷ßܼyÏÚô¨Ÿ%ƇƒçÿèI•Î)Îe]ºt…Áý+³¯í&öøUïÊšÌ6ÀúÆþÛÐsðR»9ü*€ ½!κI±¿?+‹ú6bÎq=-fø×…q1¿àìþ5ü2ø{öÂ’áu£^Çó'ø> Äb ?«lÖ¦ýØ„Ͼ`Ñš.¸`‹œwê×Î<©>ŽR.êˆi _—ƽ"c¿žEçiçXÝûË~}“’OLbî]>¸È®ø¢Z+¾+š¿ûwP8¸Q¡^moÝÊæÇ¹¨P®©Ã/OjuZrøŠœy²“.m:R:i±„=dùŒ…”¨ÕžFåsc1„ò*$ “IF£ÁzSfôJ5î9sS²Hz2§ö$¥³Z­GGúGÜy @ª\eø¾x:Ò»šX¿a+§màÊ+oÞAZC0®>Á±àuvl¹€Á1³¹ Ö„ßP+X ¯xñÌß@cÄ›úûìë‹Ù6kÔ§{Fƒ °š_pèVµûGôƒR&âÄý“IW¡¡r\Y›,švmž®ÄWø­\KéV„øâ}#Lùj¥‚lMDz¼]žð7Þ€=”­½Fƒ˜¿d)"®XW¦Ögp°&ú-*&rZ–êh¹¥ÆV+éŸ2ZW®& 5«†_<-¦èUµyú,£Ÿw–˜ARØ5úm|ÌlŸÂ‘Ë}|`c7]¤çÚãt.ôº7+¹‹•'ŸÂ—aVam?%”è=˜{eûò°÷!²¿å¶Ñû$ÿæ>ܹn·<àÁƒÜÿû £I‡äÈ‘Ùs/—óûž¯åÛ®söð°8·§Ö ÿ‘5ïDÚù‰¦A©ùsä×vóü9‚ÝŽíh_-“}/ZÍÂÝë¹ÿà!†oÛƒxiÉËê#ÑEË93Úl¸ê´h4á]þJµ&Æö&åþþTrHnïˬC÷é¼b?ó»GLu£jËŸ(˜ÉDÞ£ù¥Vy~þ*uxð¯ˆ8/U*°™ø½o36<ÎÇ¢õSÈ㬎Öî7´é1Ó/ûë*Ò­÷« äA÷]dsP}Ôë›ä|†,zþßÞ™‡7U­kü—±é<—–eèHË<”IdAfQ&DÅéÀá(pT x@AA¼ˆ€€^D‘ñ€(2HK)P(´¥¥mÚ¦Išìdçþ‘6MÚ´çî÷yòôéÎvÖ»†o­ï]kýyäW~Ï(Ä/º á²\v|›ŠÁ\Õ¸‚›·!@YÎ_­§Ië$Ú·o‰ŸBC\‹Fz+)-ȦÀlâàæ/)KΘ®ÍÑ^Î"¿ÄÕZ5桉èˆÍRb¯<‘1øûø¡’YЕ±Š6l¢ˆhsmØÖ’Ëd–@êñÜ;j4‰‰‰Èeçùf›ÃFŽAãçGñÉ­ìÍoIï$EºªYXÉñøú,˜+–໯×a-/§¶aÜ{ѧ "4dŸ)wqG.63®k3̧|رõíûùRèTV u#Ôf~*ö§·ÌŒù+žýâyFm«2âc{Ð"!G]5K¼rEÿ«§7qùÆ:F++K~ÿ×ùjb·Aò-AO{¿ªÁë“; iõ’ÓàT…”g×ð“Óú: £ƒ ,>r…å)‘wlÛÌ9‘Ž9¢):1®é“Ló ë·m!J]{ǯ  Åoc_ÁK¢PFfF:™¹ÞôëÛÊî®á/òC\©‘\éÌy}‘oL¯h 뙿h²²ÈºpCùA¦=w˜¦MiCL«Îh2ðs“q.ÆˆÝ ?ÅÕý—ßuãã%‡Nü›“P…¨>óx8r›^ÝÂËßN­±²òõ¼q|’ÃG›Þq1F®~K胴õU]w^ꀆXz´€w»4¸½]6Òp{C´êøæ«o JìÄÔgÆpþø Cf«‘C‡ŽÒ£GGØFzsOR»v§‚A[Œ`³RRª³V…¿rRÍsý“i/‘_RsuÀ\lÆ+Òky•¡b1”aq;n‘ž‘oŸ™y7¦EŒ/ Y|w2ÑZ‚¹\ͱcW0™¬ÄÅÈ±é½ ôUº$!`Fï0LÉÂùó˜ðØø &l€M,gÞü….y-¯é@dV-F'QŠöø¯¨:“¨ât—¦”nþñipYï¿Y”†=;óâE¶ÁrÛ׃؉ï²aZBµÊQNãän¬œû¢ãÑÉ%Ãy©ôÆ–ž7.ËGgšñ\ÊæÌš‰:2žö]0ìîªüO®ï'ðí—C«µ_¢ÍF°òêþ ‰ïºì÷R¶–“8¾vwTŸ.á¬Ùö%àjü¸x ‹¶ëø|çZZùÕ\™Jû8ˆ”é7œ×ÀŽ¡ÌYunwƒDÒxW÷]{1tÔÚ%`ÒæakC`H¢)›ýŽ2lØ0òò*Åo6ô:I=»à¥Q£œ4‹äÿzŽ ¤±„ªËH»RævõÁ¨5£já…Åh¸ªÚj.£ @‹Òv‰s¥a$%ø6B; ¤g#-Öc¬ÚȘщè ôg6pøŠˆM¬Ò8XDûo6dq¶Bë!Ú쟬sç0ÛlØlU.›JÝÄ•2 Þ)Aºâª÷´YÙŸVLôОˆ¦+¾m •§±9CÅÝÞ—•U¸¦´Kx…$ ”k]*®ÎÓõqxã›h¡,?•“™:§qÎÀ—k×Ñ¿_/ûjVx6«Í¥|+ë…³†¤.cä›×&0ïë Ú¦ÜC‘,œá“{aÊ=Éǯ<ȦQ+øèI{Gøçe#A£ü«x4žÇ"ÚJö¯·~! m0úOR„î7g ð‡¢|øô»4ð+$--S§ÒÈ8[Ê®ÿü„!ëMˉ4ð&;a0o¼Ð•f ƒÙ1wï5ù¡ˆBínSñ¯<òÒNú¾ý=X@îÂäñmü7oœ5$BÙIó3>ÚNHµ´Íe'«B —ÙŸ‹€hœâcöÊ\??Èc|ß ‹1ÛnØ%:t5~{R â–óè >r¢ yŸ3ï§$¢dWøì»3¼ñ@Bx©yFGú;Ò½ž¼ÛcøüVkÊ-ß$ Ɇzù®U6.œIÅP1“7ä± Eèt:rs«¶„*¼4¨Eù9ùÈ•®[ÁJt|"0k‹ŽHQ…h8ꪘõ¥Ø|üñ’Õœñ¨TMèÙ+?ñ{Vm$2Â¡ÐøqxÓ2Š2”Vk>=€OÊ’tvcB&¯Ò8(€â?¶²ö¬ cEgi6®þ‹Á`7šœÜC•ÕŠ&Ô Ñdt¤U^p˜A¤ü"‡ö 5Y‰TqêûÝ4šÚ‰‹¥U†w ›¥…º=*Uy­áí¢!‘É•˜²w°vm†ÃÈ8¸s'¢(òÅڵȀÈÏ1L!s)ßÊÙª³†ÄÙP©šÉŠl\0ž[´üãÓŒwžI%%Ѿ•H—ÁÏc¹\F–É‚Oÿ*åPÈdè2 ¨:ªê7@5ñÅjÊr«Yø+ ’›Å¡Õt‰õë¾'+ëÎ_àܹ3då£8¿Š_ú·#.¶ ãîA\\<µ Mì\í™ @æ†qÌL!>&‚Ò³_0{»‘ϤÔY¢PÀÂI³÷™ÃÛý›¸Ý–¯Rʹ#£+^G½œ‡[…ÕÀõ¿£öëèëª!±òÞôg¸Ðêï¨T*ñ}'hHä>‘Ëdh• hï~¢øˆ¹2•}R —Ò;žÏ7.%ðØ š1…uÉÛßÊuËx–ÉŠO´ŸC?r=yøE{c5e9Òñ„A"iHþ‹ Ï=Àw{œ·Ú­ãåË—»ÌPöNïPµËʈ£ÓUÊ0œ+Ãd­½qy)0æü‡õGÊ™<>‚Ÿ¿ØH³%V%ºMÓ&¸RhB´¸Î’ô%%Œ3`™ŒÜmKÙIPQÍø@H·Þ jæ©"ƒO?\I¯ј+]6fV~ø‰K<_…œR½ѧªƒ9·/U@#.þy³ÉÿL™‡ùC݇0Šœf5Vdò©î˜:Ún&ïµ³s¿~Þƒ\³³ëçðö»ïá%¯tÙÔ?½‚?^ã©Í]Y· ?¢PÄ“!¬øßÏè)òÇîmX£;Ó1Ö>ù4‚Ux•Kf‘X‚Hµ‚‚+U.?¹"ˆ¡!önØ µp›Ÿ`ÃåŒ S …:êÎm”29{Žž%.6ŽA]úOˆù]î{¼!Kßx¦Î¨a]Û“ÿáQ ™?×l¥çÜOèàW{]Ôeþ¬é/p\ÝŸ§¾G!všó«E÷‘ï~KTŸWÝ~·wå46Úóó¼ÁßuV?†‡z³kÇo09Þm˜‡ ñ|Äå™: q>Jè6“÷ÆäÙG§q׎µ$ûWéÔ@­ °ÀtÃy™ ÍÈU·¿«L:‡äOdoÆ=ü4³gÏföìÙ¼øìÇÿ•ŸI ÷rogF$GPtøòÕµÓ®ôQpå§Ý´Ò…†a¾4öV’-ã{§ÁnZ³šU~À·YJüQ 3X¨î[¾l‰nÕ”Po5 …¢Bu‘ Q+•ögÊšï¢RPžkDV±»Dò9TXNòÄÉ<2ñ!&NšÄ¤I“˜ôðÚù{±÷ûB‚œÒ1–£ðŽ›åŽª‚îË_ÉGEùÚiaƒŸJî8kÂaΚsøÛS›é=Ìî‚‘«ÂX¼~="m<Ö§›žeÝÂ) ™i?+AŸ³¥&Ö¡ÒOðS£K×¹¤ùäK)¥¾Åй5Þ!í«éÚw‚Ëy%i%x'ܱmR¡nÈï,â¹rÿ€Þ´lEpÔŒE[¸Úz˜OØh W62=ËÆÆº g5ñËú70t…-b݆×¼Ê`f—.ÞKî.Ýæÿ”Í“Ï'W[‘(gí¼qÌüÔÄgkþæÁJ|×ÉÏwE›ö&ï/¬ñ]ÎÎWX›¯gà+µ·×³>atã|fNzÝål x?º Ý çUš^ŠWPüm_Ž’†ÄÃ0nýÖÕÿ„‹¤WEs¾#ôôôzå¥iÜ“–![Xõá7´NŒ#ªA0þx©ªz,yd iو³iDõhËþuKÙÓZ‰Í"`0”Ñ­ï@‡ÒX"`Ñg`´cwØhžÔ–n#Gãe2b³ÁWKó±ÎL‹AØD½] "–sÑda¤¯}ŽŽ²ŠAÓVñ1”•Õª! Nô§øÏLä!ÚûAÕ€‘Mü):›Æåòª¸é]A;¼õàñ9öCÃ.^ÐtwCDkM­Œ»ËÔ®¦?¨/‡×ƒJ ÉþO^ååo¡ýÃsØðÄPǪ” È+(´¸Ñô Ó°ããC<1Û®51æýÆÜ'žE?b)SÛ¸„5—æ !–ƒ³G%{œîż­>ä-^FÏg× ZD åCMÈYý+Â̪N.jðfíÇ;S‘õÔK îÒž !›ýûáý¿£ý´•Ú¬‚›ý?_¦ÙŒØzk®žâPæÝ™ñ2´z:û©ë°f¢IR\à÷bI;(œMÆ3?®gõÿnçç=¿cjÁÔ…k™~ok¸ŠÆDƒñÊF–|Ø€&!~ˆ‚m‘m±Á{$³g&b ,~äè=›A Gù‹À¡YÃ8êÛ‡5Û^¡™ÒæøÎ|_‡îÜnΠ›uIôÀ7yzÇ–=:ãós¸¿{’ýl]ëY´ü;î>Ÿ¿w u¸Œì¯áìBR1ëãóÛ€)L|9‰M¯ ÕØ&\^{qFâuçppwÍ»åGç_+‡’†ÄÃP«ÕµÞ,Zù)l-hXó½ü•éhýïbÞÊ9ôïÚe=(ƒ›Ïá­Ø÷çN•”aA£ñÁÇׇðP5J¥Ãåìú³añx”N«-m»5ã¼ÿhÞŸ3¶Æö`Oð}­*•Ê·ûVÞ6ëlœÜ¤õ2&/ÙDÒæå,ýr)Þº„IîCLl<“­er¿D×ÉaD4M!sÒæ©ýÚ°âƒ'˜: ËÿÓƒ§R"ˆ0 ÃÛ‹(°L𨠛¥´ªñ*•E4¦I‹x” %rlzfsGN–pßäÉtŽñ#éôŸœHÍ`ßOÛÐ ˜ÍÇÒµ\¡@!W¢T)è6t$‘¢ž¼<É£Ai)Ao©š<˜…œBr²³­;F.«©rUºFdcšœ^Þ"]ﻟÈf Ñå`­ÞéÈ‚1b4ÍøP–#çtê^” {ÑÁ_Ev® Q´ÕÉÉ_Áát„6›=ÐŽãè…ýJïNíˆúí"óþµ™(riç"¦®:N¹Eη"\ò l9•èÊ/‡R±†$Ò¯{û€ckü<9ÿX·‹1GãR¡‘ÐÑÓ"¡9þ ×ëÃÕ}ù{òkÌÝ~‘•÷¹Ε4ô)>úˆ&ÊQ;7çøç7ÏÅ»ë|Rü”7eð$‡£¦Í S%¿jø®OÏ @áþZö¨¾óXÞ·òåÜñT;MœÁ Z¾EMÄ0¶~5¬b†^•ð…ë5ž{ŠïkåÐ1r«/Hl?ìI>ö$6Ñ„EæåÐÐTÏ·Õ¬÷ùÂÍó¤ÉlÚ4ÙGp/%½Áü³Yvo£ëÊë· ðîüºù«nù‘×Ê¡dÜÆIe# ¿«1a(ë/ù-¥uT+Å—)ä :ƒÌ)¬‹>‹´ÓÕv˜ h ÕÆ.†ŽBóÆ>\›;þÊÁì¯è“_ÙÀj¹Ú%€Ä»—X•‹‰ï³kbÍÙˆÃ|mКA÷·®õûêFI|ÛÎÄCá‡-YÀg÷Ï&§ßj¢Üé’dj¼ÜĵšÎóâÒ"ntÓ:HOrØtì$šÖÃ=Ù÷!"o¢á¯Æ­æûz8¬Ë(¹¥76ËÔ(±ñWd7dÑˬó2¹÷|Dd-å^[^VÓæ,+⟛û{¤ž]k¹K£rï¼3yîcIn6%7ãSù %@zj•K!‚PÄ¥²¢zÇÎ;›n$€BIůŠ8w®–ôä è›RÌYU“'L Urr½ò<š§¡Sc/.¤wÜsµ†TŸó®Æáõwn äN¾øÛr¿®¬zí(;3µ,Õ»Þñv}ù<}ßZI[ì¦èGnKÿ à ¾¯…C“ÉT«›íNæPЕ NðKV)oí{Mqw¬~–{-§­¢ÖsKn…QâüWÒÜÆ¨î»®í, îáÛ°Af+Þ*Nœ8Q¯8šEQš•‰9î¶å»+ûkÑüâ0ªç ÆãŽ¿¦xÓoñÊ£ÄáÇ÷µr¨P(jðç,hõ¤~âFÑm:>|Íq§xð½ÝµICr›£®NPB=Öhty^Cx‹±€|‰C ‡ÿUÉdÑH¨›“ʶUƒP2H<Œ«5©Ayn`ºV1ġġÏqXýxxçPâϳÖ¶ZRà ‘4$ž…Ùl¾êÙRCºõ¨zÙ×ÕN$%%xžC‹ÅrÓÎ’pc:CÒÜÆØ·oŸTwêj'‡‡<Ïá¡C‡¤ºÃ9”eggKf£ $H Á£î²‘ A‚ $x’†D‚ $HàyƒDÒH A‚ < Ée#A‚ $H  $H A‚IC"A‚ $Hð8þï¢ØÖÀIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axisfont.png0000644000175000017500000010531613070106167016745 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu\ËÀÏîÞ¦ABÊTLììnE±ž…ØÝÝú³»ã©`áCì‹”–î›»¿?ör¹\î½\q¾Ÿ÷ñqgÎΞ3³{vöÌì (?\.·¢u@ ˆ*^Ñ DU9V(g­@T)PŒ@ ÊFE+€@ Ê À¢(Çsó…¿$¿ýYÑJ•z.vNf:<©SÂ0Œ¢¨ŠUé‡Áâãã+Zñ³Ðnˆ¢àuh¢@H±Xœ`AQís+-´†‰„”E"—ƒÕ«m^ÑJý,=Uáá””ôåË—ŠÓªœqrr277g2™"‘p'IR–[Œ­òÂßac™P¨ ÃHÞ~La²´xZ:FFF²>låïúÉTMKKËÏË óêÖ6&ðÊî”J6LaiµðqG}ÿþ=77—Ãá0™ÌJþ¸+²A­†‰D$ñù|6›mffÆd2ÿ ci«°ðwب ^Ï4%+DBRO^~c²´ôô ÍÌÌ0 “UQ%¯ZC™¶ÉÉÉY™éBAnË&5*¸‰Õœ«dÈç…(ŠÊÈÈ (ŠÁ`üY;5È? Åb±P(400àp8UÆØ*o ü6– ¥›õ=U ­£g```ll\ÇŽù5–r´Â¾|£œ¬ÿ€imÃ"Euì˜Wn‡åæd™™pjÙ›TÎ&VuM ÈkDD‡Ã100011ù#w>áe†¤¤¤dddäçç;88DFFþÆjÒ›û£ „¿ÃFM(Sµd…„¼N©U«6“Éd0žmío=ˆ¨pïS&hmI’Äq\,‹D¢>´ijQ±M¬æ\J¯I™°tkAAH$âñx8ŽcÆ`0d.þäá9™b±ÇqÇ%Ittt•1¶Ê‡eBi…ˆÅºO’äõÀÏtVEkZ6è y×öŽ7ï}¥{jš¸bQÚ111fff´€të‡,,,‚ÈÏÏŽŽ¦-)wÊôL.k±ê,ô“ >¸¸¸üRc5é…•WiUÀÀR ¬U)©FÏßv–’"›“ÞÖÝ2ð¿‚ þ Î;EQ‰ÇñOŠæ)éèè”Wÿð«ê@¥×¤­­-+2–žžnggGËÑüŠÇ¬_¾íM’¤ú2eÃÇ8ŽÓOBÙ³]ÁØÜ„Øw"Óæ6lùó“²$&º„’òß<‰Ôs«Qƒ-Íå'= åtl¬_R¥¬¨„|sójÜ¢Zå'|`tmb\ªt½©iÍ üaRßE‡›Yº›1ù™é]Tú¡RÚ¨W¢ÅIR|;8Ö³¥­¬e?}ü^Íɤ¤¤<”¸àVH¼g+ /z o“’BŸ$ùß‹d B~âÄ/B”÷lî¼·UšËÿFµh`ÆSux~üƒP®{cCÝ逖̂_~§sU51)ÊIÎçVÓ+Ã4ürw¬ ¬ di&{ÜÑ6”éq—úîãk¦“³Êê+wY _I3B–"–P ¹ë» -é+ˤ®!{ÊßxªŒM‹ (0íX»˜!÷Žÿ›;©ç`b£~4!Ôr.œÒœ›pé¡qÏ6 b)\sì•넞ŒŠj?þUDHš[ž’J+i]I~À@qAÚ»HªuíÍ8*}•{5¤ý0½Ow‚÷|3Þ2ÉMKN¶| ¤H1à ¹‹®ÂmäÊæ&„®»Á]â]íÜí/};×Zàcøüîu8ÔöãOf­(ÿ8)‰¨ çÌÍОë2UßOš´8”V! ƒž…Ö´žáó÷™Ÿ)VÖÅãé±J»¹¿Ý\ò®ÚØînгXAÆÓ n…†ÆÍ=gà…W'tMù¾)¬¸ðÜQO¸bؔ׃Á IòéÛtÙ\:U÷iä‡[Rݶ”Nwý|æßýÐxà %ð{îÜ*ÀY8HDb!Np Œ"ÅBœÇÁ"”þZ¿&òò¥6„ú&Q´V€ìqÇ`0€ ~vÔ¥‡™ èÚ:tqÖRH|sóãóžv]™J\štæC^D:Ô¯aÂÀŽ­¸1¶ÇS–‚)ÎÛºùy×ù}˜L‚”þ½réIBz>U­ºq]·:ã<­€äQ;×?Ý´¤µ!“ Ÿ„ò"EcqìÀ¹ç›Ÿ.þ|LÀÏ^ -˜8à ¦ütЏÖ<Ì€ôÉÇ·ïã2Å 2SüVE@õ6íæ¶Õ€ìØÜÌðǵÜUž}^0¤¹é£¥göIØz<õ[b~>§Ç–F%­ûzþΦ÷y€a8—Ƕ²2íÐÁÕÕ”Yf ‚$ɼøÐõGòÝ]ôJÖy쇳™çË=<þwñ…¼€ [”ò!ôÀ9mHˆ?zAR­n½þ.¼Ÿ4NùúüíÑûߢâ2óIܸš©GG·~M+…®õú»ò@×Â.éÓµ7‚^XNä‹T“:õtÙ‚œˆœëªËV¸±2Ãcž' e?IQ Lœt@K¿ýt|Ë‹/=MgÛhºW]pðô<à °rÊ¡šsûõ7¶MNB€÷V³«ëÊÕ¹rǵh‰ÎªMµï;óÖ¬õh‡‰AÛ}þ1“Ú÷øêÊ–ì™/o–[-±_3ÉŽ"ÅYYÙO¾Z²"jѦÁîÚD ÇÙ,œ£ã°ð·’u~tæÿ"Ylù~Ç•À°qÞmu‹n)Ó§¯‚ì\œMxã:68 ×¶ÐæpX?i \?py÷³¬žƒZŽs6çäg<qàè͈ü>þ]L*‰¤¸àγtÏÆNiañ’×)ú-²ƒ?ðëiÇ)šºìЬÀåKš3±´§o}3î\ôÇèçY7%=O&–òæsTmÓöÎúJ[ÜzE‘’dÓŒ!Î+€¸™V:,îh Èù:eË÷½‹Z˜q˜  뎪ò»Ì÷1[0•-ÎÕk8ÚìÁš¯Ï.s§¯,Àhy5"CÖce°Ø%+âΓdÛ5Žªt“ǹÏÊëN.Í[ÈR(2Ïå1óu3‹ÉQâk!Ÿ{4«)Ÿ–òd‘Èx|}mÅ×Í’°t;öÖÏÛú:ys3KhPGçÍ'éCHiG½Ô2nÌ•dœ¸ö®° ýê}âZ4ýèvó9=y@‘Qñýz7–;×Ù5XãzÍ0(ª•ؤ,kK#SÒ8S§èÖkìømÂÁÿÝÏiÚ×X“&(CôW”÷m_Œ`ñl£b©yìpLÃÁm»›² 7áÅŽÛ†sGÛƒ¥äuL“P€@Kuß7í㱞« Wz×Vcá/cDžFt‹gfc[(ÉÔ²î¢-:ø5IíR­KxiíÓÓñkF ßuPcÉÔñã< Ë sõ‘íhéÆËˆ.y`o¿žý ¤WOvâ1[Íä™9n?ró‡ù«»93nˆ ´žÚóSi× >øÊŠXåÖÉ(œ4'R`lÄüiòS_ôÿºdº°@ØPÿÃ0B,.CAêÇ+Ü<››ÔÖlù¼çGn}«9°· “Ùø3ž?¥gӼЫJ©ß·÷ñÂ÷ÔŠµ‘–ÄZƒ»7xùo@ SH{ú8²^§†Ý[jO8ž[ÝÏÔªšv–0“«ç`UMÚ Ôw´uǹ÷çZ•È/©†KßþÓkÖpgq•V"IÏ9NL¾¶2¨Ö¢Öú ‡«©¬úm” ¹‚è+iyk]Œ1 Ëü2ªçðY–8'S8È¥ ŽñL'ܺ¾N4pÚ\îð„ß0¢ãö6²‚1  ŽOk¶×±çd¿åž¬éôûÞ›¶š/S …ñïß>—Å5sv¬&}kñlj6wϬyuxý1WÍÀX¶ørfÊdjÛ®›mû-ÛÊFZí):ÿ Ê£“.@Jço¾-f»$ÿ^>³cHèùâeNÓ^ SyëIõÇ™Žlây’4»&‹b¬´1t›¶JÁ¶€A¦ ;4×)æ‹ãÜX]êR›ök Áo9v-ÙÉ(JòôM,”†ƒ«1Š’è1péÙKTqĵT£ºe‰#§5 ^5?C~3Ÿ`;}ñÿÉs}ÇàÂwI‰(0‹’µ÷ùMRÃ]ê2yÞøÜw4„^¾¯P×Ü„l°–¬`` å|ŠøNI$™AwŸ ª;Ìi¤+(ƒ†aϸñ•MòîEÊáiû#åt–’<ËÁ]Ý úvÄíd ØÜj.’€k9µ¯¶3€£×¾ ïá„ÿ„)¼ž!²÷°V?LZá6’üï›6Ýþ¢UsÇÄZ½ž¾Û²ÒãÄ¡ÀKDh²“ÜHÅ\u2B³ jÊJ¶j×b,´ñi_xjŠ=¾÷âø­Ø}Z oa`6¶0«d‹S¤ˆ©m¿nPõŽ\}ßxx]PìŠRU!Ò0ìͧ†),d>ô}½ã–0ÅQ8ŒyúÑÛCËÆÎVûLïù‹ýgÛj1?&åë*Ö ã§Ÿíw[ö³ÆÐ »}]è¿ çïa](Šr«­ýös¾Ì…&>t+S ã†a˜07fÌ’{'Œ¡¼ðÇ‚»·«I›N0y³Çu8~*¸]ÿfYÿw+]ÌÏ ÚÚZEè¦}›7äªBþ~ÏŠ È7i¥G§¨j%1Vùæ)éRÞ>ÚúV´e·ƒ|bvl蔃ß|d†ås"ùÚÖ­>–ñ>µ¦^ôëw=3l٬ŧ— Ï›OhE¹õmdÏš‚¬7P"ÎS _³è‚$Ý}žAÿmÑÈ©.¨ 6âãÚÍÛÍig÷ðŽ±« ƒ­?rBÿOÇÏ~Ù3êl°ìBCr¬‡ë¨yArÅê]Ú+}¥‰†Úi¿}òYþÕ´ug]+Ùâ ¨Á'úwº;éÆšΓ­˜€L¦Ô ù.P¸…€ß8¦¯¤ö”y Ìå_wcƒwy¯~».ðþO­ÂÛM‘œÈ3¼½Þ±zßÞ6‰QÜsá.SÀºå˜£{&HŒ‚¨Æ"BÓDòva®´p§ –m‘‹ûC¸@iã:¶~3ªÕ(,j˜³Öº+éÄHy’mP»‘â)0º¬ ýÓ³Ñò9‰dW¢È^% ³ÍŒu1Œ¨í\cÈH+×êE+UM £È±Ò]nŠ¢h ÙAvܬ™—µ;uÙÙZ4|Á)¾hȌһZÇÜq†\€^˜u1 ޹è1Êý¦&3Ÿ¿œýbÖ¨}j0z´áéÅóÿB­óãê000gbŸ³‹Mï cÛL¦aïa=l%G¦^¹ÅèCg‰sHœ¡C[$‘H0 £ïJë6¼=‘O¦ÆaL]=ÝY£ Ͷ½W_—›_fui<€—yìß`ƒ ãm‹P—vÿF6;²´9ˆ²–íz¼dj¸wäôΓm³[[°¥ÑŒÈƒg6ík)JY´ïÛõµ r³cßÓsÆ&~ýê^'çã ZÐÝPë\:Cß$vu]ty=áJ£Oÿ²È`0F° ׳)Yí¹/>‹ éÀER š6ìbôdØŒD&€"ÅÁÀ©ÛÏîÃq”˜l¹zÌ\+-ú¢ÿqں̧A±Œ.¦ôµ¡m\ùôúàíµ/hª0×øÎ·ÖœâÙY›¤~xe^RMãŒ/ÏNE;NîjªÇbt˜ÖzÓ¤Kºöí-¹Ò×gR,ŒŒMS85À>Ťð‹wW› SÒâ@Ð6™Æ5· }7nï¡+ÍeƒWšTˆ³=ëS´Dv )Š_1¤á¥Ø:§®eËÅ)Ç–ym¼¿ìü“ŽÕõ* î€D˜òèüº9 7›wžyvÓ £ƒa ¢øt+†…-ÔÑe?ù’Sd†(T€¼™,ƒº´E¡B•MŒa=p¿¿Å¤Cv†9Û?3öðô]®Ódc…SHE Œ¡]­MñoUG'âD‘½%‚©eíÕ·©ÒT5AQµ”Œ±Ê»ÞìØÈ¹‹¯å5jwxd-à ƒ—ŸÈç\Ô­zÉÚ9¿)À¤i' Õ31 Sÿ5)ÊÞø,Ë{—œ·¦D÷]Þûw·á`<Æ‹T~ü{‹ÂÊ4®ÁÈ£è÷>€ü[×Df‘lIc…¹‘Ã’ +C$¥‡Gó¾gKTé™µïøƒà\¼cCâäåg¤8÷nð'#½ Mã½ÇíÒ«ÉÈu Xð×<ÓA\`éØ[nfvìÖ:ä±§ëü GœÀ—x›ÏxÁ“…†¬£¡?æ£ë->F€†², ”ApŒ;¶¨UÒ¢¨ãá…c8ÓkBËÔÐ |^Ûsëí¾œZßîè(óWëœè:p£³vÀÔS6×äg éeskǃ¡5‡»è@á; EŠødÑg…ÙHv^˜:›ÙL:p»ÝÌúÝêþïÚÃæctrâ[ÛÌ‚ç1³„Ð>ÎàM÷é pê'÷ÞuÚ¶»¾’Ø¥’Ç0YÝ:õèÛåîî9Ç‹Xj…|•¦A§VmX¿>ŲçÉûGëhépkêÕïÎ']r1ä¿/¿ÞÜsøò™€»„uÆoy2¡g£’Ê«Áu”câÿ`Ž’`wIžÜ³ŸæF8Ô²%>F‰Õ7± kG~öÝq#È;—.Ùo§r£)‚Á35Ö•9׋y*¥·žL…!wUM $Æ*Óž~Zb”àê©€­W¾4êÑy×Èúô»­Yýf'犮:ÃX7Ð^îDÔ­ÿ>exþ SÍ÷%´…*êˆ"…ÛýOAãŽÝŒ¥q€×[Ž…rìõp*œÓçÚÍpÛÕ$æÈê@вOœy~&vúÈu â>ÅìÙŸhÕ²'«pÒï‹ç95†XÒ=>ºjdóÎäåðŒÜœqHæG½çWssÖ-­oL&“ g2™Lý‰0cîª.½Û]ê¤sÿYHDT3•à¶ìÑ|ZÏÈ]çµÙ,&&¹•%žmÄ} @0Y£íMÃò!öÂEÝ®½¬y,̶]ï¦7wN9ÆÝ1Ú•ÀŠY HaNè—$*77?ìõ‡Co²{LÊ,£ô¿ ˆÄJfeP€a †üdi&Ç0‚Éd2 ÃL&Sö¡ƒ.‘~¢~ÊÀúMz{dç²C‰Ã;vvµ´Ö…ˆ˜ä‹'Sµ­–˜j1™xEÚ('Lâ¬á£Z\<~¦ßIÔT£€:zL (R¸Õÿ,·½gÓ˜ ï¼CÓ«™ÍBÿÆDFÉÇ'Š^Q™ÓWtíæ{]ÍÝÑ ‹J¤Ç0øz¸Û?ë†N::wB…>O>'¯öøº¿×웹©SGëËnÐe¾N×m¸âø&ÏVn*^A$L€’–Ùöž™·dR:L6câ ]­†­­‘ÒOˆ$‚ÈC‰üÍ]l  (øò­”&f8†I›†aìÚ«—€"˜ Oq=7GmÅ9ïÒšg± ~äékqòééÙUÔÄJBi“ê&Pc¥Ÿ 4†‰ÅY—ƒs§/ŸÐ»øG,–MÛ›&8‘Ç•Å>(J¼fá¾;鯛¶ô6g—òM^Iß/#?íËc‘ÓÑ™dq!W7Ã^ý¾ 8ríjÙÊ=ÿàí4²± ÃÙúk·Ù»+àô±›+s\­–Ú,ò®M—@ 3N¥‹W45 ß&ä'Ä)ËÖ2ïØÒ"ÓŸþ›g×±¥ä&%ä$tvW\ ¤&ï<ŒQ€[ã8ŽsŒöï™$Œý¶¦ ý7@rZ è ÷µÓfàa¦ƒEµú¬7`î±jô͇öåÔ=ëkSO†ÌÙë¼WÎ<´:Ôο®Ž¼uÀ5Ö7áF¬Ú€1Ù,s+óÅ+'tu‘Î/ÑÜ@ZÇ¡ íYÿ J¦"d ~œG 3_ÉÎŒ. R_‡q’üôä×a’ðIvtÂkœ-$³#ÞpÍ«›CÎÏ^3½5~´íÚ˹§oç§vm«†­ÚÌéë&CZ¡6¾Îç˜;YY²0×jØÀ!üË·Ÿm,“{L>½aóýë.‡ê5¼0¾>A:mõ?ØgzÜúU½Ý´å&N‰órD=&$)LÅ·%[Ü*+¼Ó2®½{Dè’ÂBÍÕWà8D'Q²7W§Ñמäè©qöC7.®ûM¨¹¥Q[ IDATµßÝ¢hþu÷½‡»«9H [§žÿ² %-ãõ]ÚhòÜQGúÚ@ýew®«(!ê¼·õ¾v†l (p²ÆÂã(5MŒáq5øv–ô¸r&(ýãW‚g»ëØCZfذ¶ 0€w/Ãó9. Æ+;wÄ· °qs¨ÁÆ•4D¶–Ò&SÓ2Š+ýp="¸º6'VZŽ».)–@ õl=±e]CµW*:æn¶û`¦û ß’-ËÓ¯3»Ö!9;ÚALš>p€¸@Äà{¼Ä>¼É­ß½…žtv ‘}¿!o¬ ǰÂD“in×íúVé7AÊ€Oè¬Ü´°ý§’älÓÔaÿ©ÿäS,ÛtžÑZŸàšìÛíHû!MZ5mW¯®0îÖyÌAþ›ÇR„)Zçê;ü¢¯Ê+«L¯º}»Ë[š”,êÈÔá -,&ž»ñ @¿Iäs7’LjA̹1``eþñã¹Nv&¯BϾ‚ÿT·Öû)i\Û·Ýß¾-PìâQÅÚx ƒ­•5—8¶hçxv×ÎMnL­ËéwÏSbÎ^à×ïpÉ»> +Çk¯»eÅcrc;üô·ž£†aÚ­ôÙ„²/CK¶ø±2. a…Žƒ–˜AQ=dÏ5)yÖâ°ŒÜÛ8”&¥ê`‡ñÿ(?v葚y¥ô jd®r¾|lâç)«¿o9ˆÉ ‰b’)’5MLàÎÑÕ6Àо 5hÖLþ šÉ dµ‘$PûÍ«çä@%â„*U7 éžWAAAd³Ùª¢Ë• AVøÀ öe®º¾$´#ÏM?àÛH«¨IÄb±@ 8{ö¬*c)‰XHìŸ{B(E$á,¦ÚU¤È¬ëÚ{…±ç—&þ€¿Ž0PMóÑüX#þ $‚|œÍ+®®,’¯Š_  ˜l®ê‹Jõ¾y÷õ²Ù“ *âm¿›ÄÀ%7«Oõ©¥ä Zšô7›æ™ÖR:¬"‘€¹>D ÔÙ³gý&t/ÙÄ)æ‹.[£›TÀ19LÕšâÂ4„úû®uëÖtŠ’k凭ç°füƒDÁš ëUÉÜÛÖ¹ÃüáòƃÜì UÆbCI¦<`²K_¡†FfÝ«‹ÔˆeF<ý?` šæ£ù±Füì’ktiøôÅ8\%+?É£a‹CéŽ0™`ª‹¥åQFZÿoÝ>KÓò–¨—Y©…M/üÛDûžM €ã¨hb gp5¾KÙM/KЬ!Ô7’«|£òcÚ Í@€j/DŸ)ò/M•ÙXÚ:õèÛ7ýÓ Tß|4®eB“‡Ò˜LÀqHË£þÔ) ˜L *¢‰KmõM ãxñG š@Ïcüõk[ÿþt+¤1Öã%Ö E DYÞÖäc¬Ã:Õ®P}âÏæDÀGÚ£JCN¶†Ï¿&W¨Jñgãd+ý*RêX-™YÕ«+ù¼@ `òkðùJåE „æÐµ(ƪtŸE@híQËgû?@È@Ž@ Ê™Š±Šr_Mšy`ïž]rv(G4бædfˆ•­ò§¥o¨z=k)Ñ×Ö¾¶Ù§¡ÊM€ É F^Q(6UÃZ5 Í•L·éºóÞön ‰‰£švo®+]M+44tÖô–ã6l›Ñ[“E¢jPŠc½ø2TR¢Çúr®Çü|ÅíÎàóÞÕ—íÚËk·¹G­V{ÍÞ+ÓèúŠV2±˜‹ nsÇíbýsš#D%åGb¬WC¾Û¬´()/$)‰P ŸîØÕï¦ýÇj®²DŠ,˜¹ìœùjY Ÿ/J|æAX/w»Ÿ2@ *šœÇ*Ä^N+ØÒ ‡ÃÉü2µÃ Y–8'K8Ô£Ži™ º9N¬Öp`5¹Ãcÿõ #ZŸô´+Zã˜Ã€ã3úìqò˜1}N÷Æ–?k@TJb¬ÿý÷Pö·——WddLÉÃB÷NæÙŒ÷4à€¾ãÆÇ¥[™ÛæÀ ¼Í©;ëkèa˜òƒ 3dÄÌmAŠ+ÇcŒËïí]2ÓoH«}¦¬\2©£«ýÑ£GÆ<øm(8LEèååEÿ¡Ô«ŠóßÛõ¾×éƒÒ߃ÍfÀ—ÓÿìŽn±¾fÐM&‹ÍV¾º7)Jñ0o¿pc‹’¹ÛrâêS=zžž9kùØ%në2M¢2S²¨$ÆöYéÁ¤8m­÷hqM¯™µ´ä©q!'†®ü°îúeðë¤c•‘õ`Æø™ïYn­$(.Àç‹dg7që}øV«‰>ŸÏW¥@TBh'¦2ƪ4ØJŠ’– ïu)ÞñÌÝZi?—§]é·þRòŠÓ—=l àÁb+.¦]Ü3kñÁjÇž_?ÃŒW"JÀa?©ån‰@ íÄ4šÇ @ ƒÎì\·iïw‹Ž§ïl®#ção/¹’âtæþ>6@ñݾÞ:qðʵ€ûÏ…Žã7^ú§{Ýò4@ *+¥;Öðã£ÇoI2~Óœ1]¾¶²ê¶íR7€ðÿùι—ú)c”vÑžˆ\,4MÛuÙÁEÍÁ~ÒQIQcU’ZöÛù /[—ÀHÊ™®æÝgÍrHñ–6Ö#d‡·ñßÞ@,à‹Uk ÁíçÌžVƒE 4e±r¸¥Éqroéôƒêpœ|}ôX¨ÈÇXѲQÎ ÇŠ@ åLé1V@”ÊÌcE „Ê8ñë¹|årE«ð[éÝ«wE«€@üBc­¸Õ¯Û¬Y³ŠÖâg ©Y³f©bŸ?£•UcE”'JVØ‘'!!Ð5†¨Š +âWAûÍRA×¢êb¬ˆ_…ìø›ùáy¬äç›ÃÒËSÄŸW±Xìëë+‹¹Å©hˆ_NÙb¬q×6Ìí={ˆÝ×Ã#Ngþ7ç¢þú®†Ê^ë(É{Ÿ;w¨£¹*¢ÜW“fØ»g—ÒÜ‚ä辶MÌUÞ–yqÁo¹ ›¡wLR ÆØJ¾¡ÄŒ¡|%r Å4,A"‘øøøûøøœ:uŠ ù\cET=~<Æš÷ùეŽþ£9dªÈºº^û>ÁT*²yТ«F-© ©‚ÖÛ¶mß²aÕÄ‘½Y1g‡xz¥ó¹&ž›Û~µþåžãÏ'+b_£¾Ó¸'Ü|þøâNwöƒ¾Í{Ä $u¬A×ñbÏ…/£þÝ?ûÝÁ:̹V²5b–PPˆ¿¿x!þþþrüÒJ@ *¥^-Ôëmžþ» 9:Q<»{wi'—à|òØXAþññ¹cÖ¾ØxÕUGº6k·¹G­V{ÍÞ+ÓèúŠV2ɘ‹ nsÇíb­^q~Øäsqû^¸ÊR¦¹«+½lvãv=¿6p[4¢õ4ç~‹"Ý'Fø…ØsþÆA¹û³6²\æžZ6 v¿ö›¸¯ŒÊÞ]Ëàøˆ…P}ÚÍeCLú_¿h×yÄó…ßë°äKP#¦a („Š@€&1ÖÁÓçv“H÷ˆ<1wWÖˆùkÑ?qœ+/,ÈÝ0oÆÉGÑÆõö6ÓÃå³»úÝ´±ÿXÍU–H‘3—3_í#w^Pâ3Âz¹ÛÉ+ðhµÈh˜3CÂçK@H’@‰å 'jñÿ…§óù|`7é§Ÿ·&$n{3sH¿oéȞ󖹿ù«*½/„6É/úIJR€ $¹+Þ¥Ö=è#Ë2sßPybÁØ;ƒíe‰jÄn0Ó¤ÍA1VDÕ£l1VצÍ™O#uk›qµîñ8 ×æÍ›Ä‡œ*¨?À[Ô1|qqÓŒE»tÛøluí[VÉ Zµ†«ÉýŒý×/Œh}ÒÓ®h+lŽÏè³ÇÉcÆô9Ý[ÒÉá>›·&+…ã€1d?3ÂN_Iã·è@§ôt7¶?’ÓÎÄ߃¯\yZΪ¶IDcXfHa‚¾>Ú]Ö;ê rîdˆHç†FE‚„v+=öË s‹‚œ`UbÏpMJ€ÀÀ@õ:vìØPŒQ)ó<ÖÇóg.Ì™|¬‡,%pçÖCÚøÃ=ƒ@Rðuõ” ÇŸQS×]šÐÍ5lÛ¥(È 13Àc[Saäc\~|oï’™~CZè3eå’IvZŒIùC ‹¸dI2)ÌKŽøøƒ³ç¬-­¥NÛ°‘aþ¾íÀºÛ™ˆnšØWÕH}}qø qM»Þ~µO‡Àò…ßÀž[l\ޑ˸ÿ%[>…T-¦&KáÔ¥nZQ6cˆ?Ò+)N]p?¡ÿµÖò‰CvmÝÙdè–ÐNÓœ 1†N¾a·ëÁ“´5rÓ¤(ÅÀ8¼ý”|þH°-'®>Õ£ç陳–]⸾M4_³,¹Ãmsój8Á®çÞaì¢f  dY¼ê< ?R5ª*Û' Yx¾ïüÝWf÷gc nmˆ*ȋŠ$:Ž:ò)jÄ\CMJ ¾¼BAXÄß@é1Ö[Fgi·_Íçó…’"|>Xõ¶p7aí¸;K1Ð÷_:@Ìç‹@ ¦(R¨*ˆ–õ`Æø™ïYn­¤°‡Ÿ/’ÝÄ­÷á[­$ú|>ߘ‰Ïæóõi1!I²´5ZîÀ¢r² p¦é_ÂûwqáGøÇŸ~îRKO–ÈÒ®kÀÄß¿J;i"Eæý›Q`ßÒDþX5b,mkMJМ¿¶U˜2ÄX™ã…úœyÆãp€EàΦùmÄõ¿•»¤q±>›a¸’«D˜tqϬÅ«u{~ý 3^‰î-‡Yüì–àªË~)PcU´íkÛÀåï á%μëûð ¦zÅ'ðc¬--̧,:ýWÒ q·æ$‰ðã=¬5Ó°9æÍ›wôèQúo///4Qå)Ã1bXɬ3£Zßp|o·R>%ˆ:çå{·oàž?ouúää„ß³Ð5),ÀY¥¿d¨S“¥ùB×ff¥,ÛŠ@üAÈY˜óyÍšU‡y)þ´súŠ$ÙO¶n˃»&N÷ñ]X䊫µ^²~lÑ~-ÉÞSM›˜Ýœ"1Éd•žü–Û°¹zÓT%` öψiX‚D"ñññ öññ9uêAò¹(ÆŠ¨züTŒ²h¥¾2õÙÍ»QÙ²ŸAܸzY~ûA]‡N]€ð[˜¨ý†ÿ ±Aæ½Nƒþãp8ao^ z¦C|=2|~œ@¦D˜0yØÒ×p8lR’ylÍœ½}Ï–ØÖª×ÜÓwÙ?€Ò-0ÿjàú¨¬ ŽŸ±:(4ZËÊÅ£×äkG(­ 5b–@³páBz7ààà… ®^½Z>ÅXU²ÅXÏ=œ#)ÚAZÌ€£ÿ;$¿‘5NèŒôÑçׯ «Û¿EÑÙcÆøÆDEÈ~&Þ?ó¹©íX êìâq¸@J2\éÄéÇÒwlAr 4-:ËÓå^ =w¶ÖgÀãeƒ×^ÕÙxøZ3kvèóGËfN”}øÌ¼V\ÏÍm7ŽZÿòƼÆeª”ªMvÔ±]Ç7ðÛÿòF×¼OÞ}¼;€þýµ=4Ó°Ù ¿¿¿¿¿Étâo tÇš’œœ)–s_ž¸˜8Ú«;gÌßÔäDqAø‘“AÃG{³qÀEovÆn#çÍk ª´gI‹ä~:ŽÚ|v”ð3þmìq›Nb!TŸvsÙP“þׯÚuñ|á÷Æ:, Å4,…PÐ$Æ:zò4 $yϯºW<~p5-:=æŠ×KŸ¹3¦Ë¥íÚ® CûbÇú³¢2Kž¬Á¤³Ëê·kÃѦ……$ùiÏSÒ;³Fö|>ßÚÞa@×NtŠ03o)¤…­ sfHø| Xrˆ·oå ·eb ³V Ív“~úykBâ¶73€ô÷û6œŠì9o™»Î_º+%É]ñ.µîAYŠ™û†êÌ nÄÞl¯‰Øífš” 9(ÆŠ¨züXŒ•³ÆÛiÜ⇣Žö¥Ÿßæ6oƒ‚p­þó`È›¾…)”$/ðä·všºtRïFMjf±p¼Öø}F9%‘ÒhÃáË×pÑ=V}ŠðŸÍÛN“nÆž÷®jÛ÷åø±¾Cz¶Ò–âôt7¶?’ÓÎÄ߃¯\yZΪ¶k\Oœ!" Ã/€Ú­ôØ/ƒR@Î-ªx†kRªW†ÞmÅXUœÇZkÜZªÑ 3á9èe~:x$•s»C)ŸÙ@¿6MÍÇm¿qÅš§ò\ßní¼ ÖÊDz³ñSb­Vžìf#/ó!)ß`ˆ¡ì§a]Ÿ»wÝöíÚ½oÞè­kkùLó÷\Ž5ld˜¿ï#@{°îv&¢›æVVAHáw°ç—wä2îÉÖPLÃÀËËK½2êˆ*@+ƒçrfccíZ=bC»ÅWkbR’œ³ço(õ61o¼‹qȵóò{zô¨OR®ÞykÀ:épÓ‹Ùí6•8{4_³,¿ãY6˜¶rÿ¤ù±ç÷®]ºhð»Ôˇ'Õ“fUçIø‘š›Vµapk@TA±ùı‰Ž£Ž†b ®¡&%À‡Ô+chh¨^¨”m«I»…+:vïíÑŽg>ìa+IRœýþý{…C´ üõ»·YÅ]°{×&!$IR$äóù!ÇÏãma59¾Z3ŸÏŠIJ"±3ñïñÙ|¾¾¢N„Iç}ñÞ=‰?&€NËN(À™¦(GÃÒ®kÀÄß¿J;=:…"óþÍ(°oi¢¡KÛZ“45 ¢êñãóX%‚øˆl £X)ÏNÞÿ2¦KÝâù–+V¬T8ä¿‹gzÏY<ЄW²4ŽãL‡Ãa³pËΛoË÷XYl‡Ãbà!±ºê²ŸEÍi}wõ^g/›BmUWN ÙjåÍa¸ @žŒµ¥…ù”E¡¿´uânÍIáÇ{Xk*¦a rZ—K±µy*>Ûo¾ñv#‚Ã!0ŽB¶á‚3O(ÊÚµîˆÇ¼ôg-Xró~Šk+áGÍÞš±ñ^_ç/ý@=úD5b–@#‘H¢££K¦£+¢êñÛÖcŹZºê²YÜ2Ý^ö§6¾¹ó-w‰G=U2/®.ê²ódSÕ±?DÅ‚b¬ˆ¿?ìkz³ÖÓFŒˆˆV#3ñw)ƒ(ÉÇÕ ôéÓç÷h‚@T hÏ+Dy¢¡ßD×¢êö¼ªŒ„„„”.TéÑpVt!ªhÏ«J‡]E«€@ Ê ´Ì>@”3(ÆŠ@ 励"D9ó#k BCcE ˆrÅX¢@1V(gÐ<ÖJÇå+—+Z…ßJï^½+Zâ‚k¥À­~ÝfÍšU´?KHHHÍš5KÓðë,âÏÅXå‰l§U$$$ºÆUcEü*h¿Y*èCT=PŒñ«@Ë­"PÉç±~<¿{çæu[/„UÈÙÅyi©/×ù_‹ª³ÿ¡på‹Å¾¾¾b±˜[œŠÖøå”sŒõÔìÙ\¿Å½«i)¤KøÑï?‹ê×s¤ŠóCw˜2ešúÒ–9ÿo]“g³¼ùÝ€(÷Õ¤™öîÙ¥T8ñã{‘]k¶t×–½»vô3Á\~(É{Ÿ;w¨£*ÿüØîß¼¶Ä¬x¾Þî¦RwPüà=Õ´‰y‘w‰I¦ÜÞ3yqÁo¹ ›UÒW]J,ÀìŸÓ°‰DâããìããsêÔ)‚(Ö(ÆŠ¨z”-ÆÊÏøwïQÅa\£ú‡·Q¦å½YsëÎ¥5›8ÅCfü.ïñ©a¯OÒ?ósÂ÷îÝ3{ö\úgNf†˜R²‹jWöå=§>Dóú´¦U*È Vž;3iTÒÑà-öRŸ¾w÷ÎVc§Úr˜Êë dó EWZxì0bàJmÔºøåšãG.`™°0‰0aò°¥#®?àpؤ$óØš9{/>úž-±­U¯¹§ï²:¥'Z0`þÕÀ&*vúúu8;;—Ll°êæ±^6ðèØø«ƒB£µ¬\°v„RýÔˆiXÍÂ… ƒƒƒ 88xáÂ…«W¯–ÏE1VDÕ£l1VJ’Ÿ‘‘.Ÿ’°÷èëá/(H~Ü¿ˆÆì=èŸ žýšÿm©Å+ýÃZ5 Í•L·éºój–Ú£õJ-¡¬„ž™?ö$uòÞV#*l¼yÔ)ôÙÿ0“%>]î•Ðsgk}6<^6xíU‡¯5³f‡>´læ„AÙ‡ÏÌkÅ5ñÜÜvã¨õ/oÌk\îj«gÅŠÅLˆ?=nnÀ²¦Æu¬A×ñ üö¿¼Ñ5ïS wï m…-ް IDATÔˆiX‚ìÈßßßßß¿d:ñ7Pº×ã÷[²¤Øòÿëu#¬ÿt1 ?jòþ¯ vá1€’äŒîKÁM”¸ø2TR¢Çúr®Çü|}mãR¼*)N{ô¾ Ȩ̀îÅH÷{%^ÝÏä\#·fõ åy||/v^uÕaª·QÞ«ŠóÃ&Ÿ‹Û÷•þyàZT͉WºÔ·€C.Ô2M4r§³ø-ŠtŸáb_¢çþKQØeiÓɵ}Ïö3×€ã#Bõi7— 0éýJ ]çÏ~o¬Sl×E5b–€B¨ü@ŒUýpUXæÖ}¶ b'þÆê¾ep7úgNÜ&¦a߸˜Ï€@(Š”"ˆJ=ÑÕï6+-äeø|Pâ3Âz¹­·/Êý²}û6HÌŠŽïÙΖú21öîàâ˜qý…n5¥ÞVºaÞŒ“¢ëím¦‡«R@© V‹Œ†93$|¾,9ÄÇÛ·r†Û21†Y +f»I?ý¼5!qÛ›™@úû}NEöœ·Ì]ç÷í›<{c¸É‡ v@IrW¼K­{ÐG–k澡:óÄ‚±wÛËÕˆÝ`¦I šƒb¬ˆªÇOÍc½ì·Ü¢Ó¦.fÅ:’Ïþ³émõ[Á8…cG_ÎYv]#+ŠÏ"Ãe?I6Žá 5'’b/§liP­˜ ‡ ÇgôÙãä1cúœî-€ÃivéÒXÓÂ9iû‰-öú$ßÞ±Ös—ªË ^½¸¸iÆ¢]ºm|6Œº¿ö-KÍÙ•Ú~à³yÛi²£fì™qoશ}_Žë;¤g+m¹¾-ôt7¶?’ÓÎÄ߃¯\yZΪ¶¿/°HÎ~¸þÜ»ôPž '8CD:74’ec„v+=öË s‹jÄžáš”ê5ëØ±# +¢*òãóX“.ó¿—úeWùÄìÈÝ^["ö^´*ôª¤$}Ùé¸9j«*G"ˆ%8jNºw2Ïf¼§A‰Ûc\~|oï’™~CZè3eå’IvZJLˆR0œaQèU%_WO™pü5uÝ¥ Ý\öýWVàCR¾Á¢‚a]Ÿ»wÝöíÚ½oÞè­kkùLó÷Ü´(·‘aþ¾íÀºÛ™ˆnjNXþ$ûÏ4 "Ë"…ßÀž[l\ޑ˸ÿ%[>E˜†%€———zÝ"""47øC)ƒcd<5é(c޹ݠ‡£,]×nÂÕ€QNfEÁµÏ‡Æ¥¶\×N¿hRÇÐcܘü¢¢RÃYÜZªN$Î?n×û^§*Í%Ø–WŸêÑóôÌYËÇ.q \ßF‰ªÙ™¼º²1kŒ¡“oØízðdíRìUe#Dó%<ËbDžeƒi+÷Oš{~ïÚ¥‹¿K½|xR=iVuž„©þ\¿Ž5ާퟗͿ(2kâÖûð­V }™Lï5Û…† úg|Ð%]ûr‡ëû/PðS),yvõ63ñïñÙ|¾¾¢Æ„Iç}ñÞ=‰?&€NËN(À™¦IÌß·÷[ö¾¥ e),íºLüý«4°“7(2ïߌû–&òªci[kR‚æ +¢êQækæ×{ã†LÌëàmq_àúÿ :Ž$Ú0º‰bÑi!>ýçôÙØÖDWÕé…ÙÏ–?Nîr¹EÉ‘¢¤%Ã{]ŠweÑAè¿’Nˆ»5'I„ïa]ìH5b– ǼyóŽ=Jÿíåå…æ±"ª„zøðá &ìÞ½[[[»üME *1Xxx8ÄÇÇ›½xñÔËË+,ìGÖ!ΉH4j뤣òRà§>Xq>Ï\·’®“"ù9[—PçS%‚o'Ï>1b˜*qÞÇU{ßLž2È@íç¤)OO^ýÖÜg€­¥œÕúÞ€ã{»{ÿçó¼b/¶Qç¼|ïö ÜS†Eò““~ÏBפ°g•>|¤FLM–æ ]›™•²l+ñ!󜩩ɖ––PŽë±rjõ(u ƒSÝsƒÊuW8¥ßî'__žXq·UóÝJ-ƪ÷?¥ )cЮuG<æ¥÷8k!¿¶Kñê’ð£foÍØx¯/‡óû>ÐM¼ªz1 KPб"ªh=Ö„cØöÔÆ7w¾å.ñ¨§JæÅÕE]vžlZ"øø—€B¨ ÇZVÌZO0""ZÌÄߥL%„^ÑJ ô—WDÕíy…(O4ô›èCT=ОW•‘ŠV¡ÐpVt!ª(ÆZé°±±+]@ü!Tê=¯âOÅX¢@1V(gʰV@ Ê r¬QΠ+@”(ÆŠ@ å šÇZé¸UÑ*Te:uò¬hȱV蛟¢(Š¢dÿ—ý]ÑÚýaP…Pÿý÷¨¢ÕAüu keÏçÓTî_ٟȱ–ùÊD—4â7€b¬•6›]¼»ZäU‘c-+ò5 è’FüPŒµ2RÒ«Êÿ¬hí*’—/Ÿ@Æ5?DVcyÕ!* äX+ò~À$‘cðòòúð!¬Œ¡zCT(ÆZY AUù˜ŠÖ®â‹EeÇä+º¤¿c­Œ°Ùl9_*u­da—µ¢µ«x uûT*£¨Ñ%ø TºµD¹/F{ûªÊÍO¾÷$1_Íáy±þK­Ê]‘˜¬h~ŠÌ{÷ôaȇ˜?Õâ‡(=Æš“™!VÖcÒÒ7,¹‹µÑ×Ö¾¶Ù§¡¹z1‰(åÑ£ åY„©ýŒ¸þÞ.:í^¼‚À¦ëµ8y³úO¿¸ÃDí®×¤$ëøºù¯§d“Ö5]Ü;Žú{÷×4·ÆüI7P¶2¸÷Þ¨/*î ˆ¨(nœˆ{^÷Þ{ï…{ïÊp!Ú¦IîZJ‚Š<ßÏû¹·MO’“‡z¿ž&~#Ûv§rp®ÏayËÀù]€¡â§ôïtó·uýñ«Z_»°{‡PÉ9cÐÂîmŠšx˦ÝÊóËU¿ÐòíêÉP»ö†i÷(}þâ•Ϥæ‡- ôèÂÍz–HÈÌûeÝŸ÷ß׎+ìDŒD"IüñõgrýÀù”XI¶^Ò|™Û¢{Ç}f{°:-sÆzwÁÀåçÄþëö7.#xÿôþÒ™^nqk·M²/ìžf'9ögŒ,‘ÍC>ñ»ôI~íÁc.‡ÎuHª 3V¤ãr—±ò†ÊtÆúdZ»é)%3GW¡Û—¨Þ®uÉ´åÝýöTª±ÈmÚÔ~IVgü[(š…›qQoÔÈ6iÏEüÌûyÊ[ïc‘ÿ{ÜP$ ÃáéUm×NÍ×í}f…Ú{FúÜ«$*ªó2g¬»Ï‡Wu¨Cƒ* Ã4kWn¯­Õ73ûÜGÊiå§ôÇ ¯¾‹Ì;› …ZÙ2{à+W®ØºuKVm† îéé•þ 3VT r—±òa&gïÿ¬0P£Û4Õîé{íXàT¯?“:eʼÃoùÜ íêøÝ•u¿ß_B–ÜPœóP"0nÙ×4e铟ìÓß/6øøxßMiÒCe£Çývõ™þKMlÓª²R)Þß¿ÐÏcð°1ó׉£Ò2Ì—+ý×^ŠŒwiÅß‘c=w\V¬žzËo∾}xϘ–¨vYµùrk÷8÷ž½ú{ú.yùóÏÙßË•þk/~M ½à;bYp<o]²põ[x°ÂíÅHYâ#?¿és×VM<<<»uë¦ö¥nݺyxxjkGý¼„’”4â诔~µM î£GÆõÿy¼Œ¹Ø»uÆõ[v\©hoZ«G ó?§ _/z¿æ¶ p*q«Ì¶ ]'žyô'E}³áU«¶v-‹z¦äƒÒ‡Zš”|µîû8éëcÇŽ§ÊóptºcüâõZÇž#¶Ÿ¾“Dgø£á;igï/Ó Óè>-^\6À÷2»üëµóÇ®w²¬vh^áôjïñG¿0ÔhW²Ù %Kg9×€ù37P™có,ÚDœóíî¹E¯šË‚9ãÊqß îä&¥»»ùéûÔÁ“¾ˆjµ±Ò€ïw.^¸e›9ÚW4ä‰Ê»¸´sj]S[5!bÞ¼ùŽŽŽ*ËçÍ›O9¥þˆ¼Ìc}½~¼žÍˆÖz ‘HDe\»–öÏl÷ø¶;ž-vž^PΈ xj·#{0hò%çÀ+”TB¥/”HH x®ßºÀ×˵Åî®cçÌ]Á€÷":Ÿ·b;2š–Äœž8ñºbkûoÜ4¬*ûX\×$eÛ+‰Ä,œv¾y£Ñ±èŽÌ«¸Ú€“§jìØ²mûìÑë«þ7ÖglÏ´¹BÛ!+ì,›•@õj‘mú­“ËÛÍ0¿­¿|¶‰±J<<7mû=y÷2´ìÛ«d²m½ZeË•í7Í¥0)“Ç…e7ÈY•2‹Ï܆¤“GÍ:[ò‘9}+@•9öÔÃf“Ö½>8±»»è›¾½Öžêmk r9I1 ÃPr9iÑÀ®î#î“ÒÍš9À_¬*[X¸pÑ„ ã?~Ì>mÔ¨ÑÂ…‹hš¦iÅìÌXQAû«y¬ò”Wþ÷ºûmÚë|<0nsxó€j·Î«]—&Îþo·ÍÌ•í+d8µñÀÀ¸âÄ¥{ô80Ùgþ„ů´ŠRâò&Š 8ëQ·oŽS»q“ bJ^tÓ4µóXy6&Îm8Æ'âĶ•‹ »èÚÀ3¯bññÂÆÓ¯¿}ûFI¿²$‡ J6XÐÌ\ÌnÓ²–‰üÕ¼²+7óìßýYÞ={÷oQÃ’~ìïÑcÛÒ¢ñÿ®nk–¹ä÷í)e|{Õ¤ûiÜÄÓÌ÷Ÿx“ê²»£S\û×¶P— ‚Ëv†Ë!8Ú …•·#ó׬YëææöéÓÇ*Uª®Y³V,6Ì´f¬¨@åýZ´‡f€¡)¹<­ÂÀ0r¹\–ðhüˆ õzЫ “$!8|s‚Q4c©mCsJ®X}¼çk=º:q¾¿ß8}l„Ó†Cm@ew@1 ÃÐìŠfh•½äY®¶“~a0`å`ÆŠ @®3ÖàÝÃ&®üî:zùÔáU¾mU¹ûº“Ý‚wŒ˜z1ù×Ǹ!fbÅLãŒêÎß:»CM^6ç©YÌc­ØmtÊâYñÜá–|Y—+«fò,PÒðߥ+ÚU‰ €Ôøø8Z ,BášP(PNXy<›ÇN­»pßê™s#bxf­zxÌóiËãÀ³Þ·tÂø…S[Òå«6˜²s·¥×Àë ä@K}£266Vb/íDT߬t¹²%x<.ÏÌnPç‹«wùo]>'(9höþJ•dÕÆaòž&þk6ÏÝ´Ø×¼lå¦Î¾›GÔb˜*»±µ~Ú}³Ò6eK(¿ú7rµ•¬º½ PÑ¥œ±‘‘‘\¦L¹  ›nnnŸ?‡©¬ÀÐ’FhœíŸðò¤ÐWo£dešÔ´É¦™Z”4t÷þ[C†¸e~i߀&—ûÚÞµ\ö[9ÐÈ¥>··õÊí®uÄåË2|n¥Dž’ÊÓW34ršŸËoñ’É©|½¼µ!SI¾^!|=áÙ³§nnn¯^½Ö|åê=|øïy…ò•bäüú5¬råÊ aÆJpDê?æW—¯oW>oÝâ Ë¢~Ýžk—li7)ªý¡¶•²Zýã›ëžËb–]ë’·½ëÕ 3\=¡Ú \ñ¸Dn/|ÅÓå¸JVmx"^!^g+W»V®$BOç¯Çªo¿}ñ㋟bÞ¼yŸU“ow¸¬Ø^W@ëVÏsI*•Þð*k¹ÏX7eб·4úG©ÉX ‚ÐÙë±–sš<4ÛÖ FO, ¾ä#>Ÿ¯O•OWñÌËÍÍ 8œ\„lцÝ{K£’H$"ïy¥£TFÕÂîNá{þüEÖR¹Ï B V]‘ÕHŠg¬y’V6,*:Ÿ±$)û“¯*Ýö rù¹ •2â[¼ç•.ºÿ^awៅoiTò~­”Op¢%Bÿ’ê&Q!¤ 0cE!-ÀŒ!„´,w÷¼B!”+8°"„–aÆŠBZ€+Bif¬!”p`E!-ÃŒ!„´3V„Ò2ÌXB(áÀŠBZ†뿉–ÿþò«Zµªš4¦dÑ»öžwê®Uë*†J9{ý™s›f¢Œ§”ôç·8ÃÒ–0Jò9*¥TY³´…’ïÁòRUJëXoQ‘ƒë¿/åÛ™^½ƒ?}Ф±L½lÙR÷Qc…Yÿ“òýÚKÚÞÞ:»‘%9âö3½ÆÍKèèû'ôè˜éÓ_Ôzò º>{ošý‹íû ?W·‡§”¿Z=i|ð”›ÿkÃ>ý°ÛÛ;ÁÿÊÒÆj·œ¹8:^ ”ðz¬ºëòå 9¶ùû‹·þzxîê—ÅSJGàÚUvéÐÐ<­,ʣ׌ÿÎÜ€óx^‹‚ÙU®Õ¨ï°qöåÅÀ%ûôžtêÊÚ’¼|‰˜þ¦84;inPûamû8 Xux{ñƒ…=Ö‹f—„…†ÒÌx÷Ø}è—phû™‹#•3 C±ó»H×`ƪӄB¡òMÓJ7jM»«`æŸQ&2Jñ49*ôü*¡ZƒöæzŠ…\»¢uã¶Î<«Ë]›z†Äfî@#Ï“ íÚ:ë¥5޼»’,1¸i CöU‡C|EŠ”1`]΄]"9÷5M]ù&aS3kmCUŠ#K¸ëês°víj{æx¿xù¡nÝZ×ðÖÁIý}k{øïÞaÿýÁ`‚óçˆd Æï &Ê–jpå @ÜûvÝ×ry„ÝŒ½‹K)o\¥8BAÜ‚)Ò5˜±ê4•¿sU^Éj­V=ú(?}á¿Ý¤¶õ—·6ýÖ:en\¡ÿô©ÐûYŦ©ä+ûÖ­ÝvÓÅcîøîuêNMé͆wV­&*¯.—~}öìPÒ˜ïŸ/ì]-©ÚiYÛ2ŠW;5)é¹îäÏh’‡âŒšø­9ß͹<%¨^»ÓÑ£'Øåå£u{âÒƒŒíyxÒ 8~IÁÆ ;:v-ó\æzÞÛcòÃæJ±iæâ(Ë×R ]†«ÎQ› *j¸‘sç¿öÙyêbO×7)wkêçüSîÕÊŽç0jÍÙ“6™¿þ–bêj¦¼D{zΜ»´<)âK8·\+ß©ã,ùƳFf)ÿ{ þC¡¿”§âpCîlõ»A1t2ÃHüü¦€Ð¸åLŸÝ3"Û¹{_9èö§©4îêÜ'»×ŽòO[÷aåÞÄJ™ôËna‹ýÃW?;>©¡¢}æâ(Ë×R ]†«Î‘Je3Ä q"Û&ûŸQüÇM»’mïX—r`9lèêë;Ç*}Ú •xô¸êÇë/¢“‡W7¾ul¿òBç½L¸œ‰\X’£Ø£Œ¦ ,‡<8€ÝÖ—Çg&éxzÌþMÃj³ ¸"yê§|zå­8õš4ý!¥Ä{èÈå¦M’$´‰I‰DÒmö!;9Oúb/™ôæÄ0N«žmM›mÜUË"q2ФD"¡dÑ~#¶t 8/{4Цd-ç¬YÞ¢ÿ‚ŠG½ÛW`·¬RåŒ5¿Kt f¬:ÏçeuF¦8)ËægÄÐ’Õ77˜~ÚÌ@ÏÎg_Ãö“9mp««h@Ë“‚ƒ?©¬%ærÞ|ø ÕËpºê,ŠøÜÒîëø?{TÉXm[ô ¼£ïÖÕ¢q»ÓV‹'¹Â²ùô.Ê[qš73¯×jù«{˼|–54¾Ð}‡Ã] g½~ýêõë×oß~J&"Î?hÚÁQ ‰ZÕ}À_È—ÍÔçy%Ï eß>#8\Ø´ÎÞMC[ éÎ㟟ک"¨G9cÍïR ]ƒ«NS8ÔŽY¯LnžØá4aL/÷¹Ô`[ÛÊFK.éÔ¾·³/`pÚ¼¯Äœ9óTÖ»qh_×É~}Kª™ÿok(¼û>:g¹Ï°wñn%ÅÓø·ñB“êjîå­81Ï6‰Ëôc—lä-yÙþæ÷…Wž~©Q£É˜nîV°´ÏÔ›VtUYkËØN‡£j®s·eËídâßÔ¨–7åºoÚ3%dðŒÉãÚs‰ì‹“¯¥@º VÄ0Œú3²ìV*5|íÔ¡;>Ô>qÅ» £Çvv¸×£S燓:ôì?ô‹ïâéC-¹žúSÛ­|Ô¶G0¹¶b‰\þøñ#&).æå­cknE÷ ðQ¼z÷Zte¹Ý‹ÆòRœýóžÔŸ2Í ¸¢ ~uŒT>»°ûêïwêkâÜ­w½%£2ö½¨WK»OOœuz~_OÄßx¾SŠ˜K€ºâ(ËçR Ý…«Î!I9MÓ ”!D†(ÔýŒÂ.ýo⬵¿m\vZhN“ÍG­Ù!žî½ãȧɢŠÝO3œ8§ݭ{çf+ç­´<&Ajd¢OHh†”J%5_*Ñfhòüyá‰ý-øà˜—²Ð»2mÚB oh]ë/›. IDAT¡Æ‚í»6¶d»DI#¶~“.mfžOï¢<‡¡ß ËùÕ$'‡³¯:¬lbVùÏ^FAÆy¬R 4iÝf”50R8.‡‡ÃJ&¡ÀÊ,-WU)•*WÖ¬`Jt f¬:íþý»9¶Éü3*Y^l;xñbžŠ+Œ8 [~Ûx€¨F§=×êߌ2Ô˸brÔ±V­–38ΖÆ"¾šUdÕev}ÿÙ×nïZÍÚw%뎅œ˜©ï°ÈÉÂ(ÇCÈ›<G´ùì©û£Z9] —v‰D¢ò¦J/ë …¡Py-¡€J3[@Àå\A沫§Ö¨­gF¥½”ߥ@ºF9c%"## $$¤ti›  ›nnnŸ?‡r‹·ß娿/¿ÒššœÄÅúY«]òûFÇvköÜ9Ô¶RVmàã›ëÝ›ô»v¶‰‘@{Ý˸‹¿(%M¾òõ²DËeG ôk†&%RF 'PS"µÅ)€R Ý¡9##Ã+Uª˜±ê ­ššàèäpV%2k½?ðù¥ð¤ÐlšÅ¾ÙÚaݾ|Jþ¦8\¡ÆýãðT†P_¤—E[µÅ)€R ]†+Òˆ±Ýè>9½7ô* t/–ïŸÌÅ)¶¥(ÎÔd¬A`ÆŠBy&‰‚À{^!„P¾À!„´ 3V„ҜNJBZ¦<£„Ò2XBHË0cE!-ÀŒ!„´ 3V„ÊG8°"„–aÆŠBZ€«Î¹|Yõî~ºÃÅ¥}aw¡"ïy¥‹Øñ+ãG×É×ô®×Z¡|ã“  Û¹k„þ 8°êL÷q*̵à÷‹Ð?3V]Áþ ·rRŒk?º)í—|? ¤ÌXu‘P(ÌêtµàÏXÙÿgoÛ‡ï„4¡&c%Mî„òA€òJ@Ó…0°æåb ÅŒUGÙØ”.”ý~þZ(ûEè_‚«®J¥*éjpðgÅçHÓ‡ªU«Èå$¡|ÆŠï„4‘ÇŒ•¡n> omW«@:Yì…B¥€•@`k[­À:ðêÕàñø œíbÆŠ&òx­€Ðcã'xl eÿ‹øú;«–)߯ÝNQ]ÊdƯäˆÛA¿ðl!ô¯Ñt`¥¤á“æ?¨Y!Ò×wª¯ïÔ©“‡;:Úߌ—ªi)‹òè5C¦ÇU,yyjÕ€žíëרn[­ZËNƒÖ‘¶oQ²OïI?åôßBéM3Ö#^$]Wî÷sdŸžœÚ^Ö`S!“¹ñýyÿ}í¸ÂN”öÒþéý 8u¦÷‚ú‰_nÝ<èÓýyô‘Õî5 ÃÖKš/s[tï¸OÃü:¾¢#sÆ*“É ²r9™þ¿˜±"”k¹ÎXï¯:ï&½tÿîÝ;úãÒ¬k‚+(ö)ß F‹&ÖlKyÊ[ïc‘ÿ{ÜP$â@äU/ÿ“/&{:®®T°µkS‹9ãú>bt ö>³Bí=#}îU÷ù j3Ö‚ì›®bÆŠPÞäæZŒüDÀ(ßýŸyÒKçÙe/ÏŸ¬Õ¦óõ‹ç@–x/(ØëÉ•>ìKßï/!K n(fÿq–Y—ÌjNOUÓ4›tð¤Íö·ìkš²ôÉÏMͬà÷‹ ‹ö÷˜¹ÈÁ¨@DŽҢVZ{÷•ɾ3þýÛù² çÞ¹PaÆB7K}ˆ å4úOû7ÞYµšÈ>f¨¤}?Rj i™i«¾ŒÐ©IIÏuï ™5$}½qìØƒÚ“çãÀŠ*ºrÌX çm^ K¼ÌŸ8UÎ0r©T"á€DJ3 ©xéEtŠqoö©<5XN3&µÅÙ‡tâº&)Û^I$`á´óÍ›Ì}(0cE¨HËuÆÊ‘ (iX›6­Ù§‰1^¿ö[*Ž0l«X%BJ‰Ë›°Oi~9.A$†HDöÙ…t&Ä”4ƒ<ÌX*Òòr=V®¨Ü•+§2/OŠZç·¡¤â©•€óëgÚ,×´›¹ÞÍC×``e•µHøéy€ô§”#(•»#@!–6Uƒ‹°úú™ÿ³¨Ý³qÕä1$$Tsµ‰ÜuO2¾ û’e‡U“nô]>´MØ„iìšÈ"ƒî\[·ådÑ[ å2‰àÖÕèŠã*³ÿ~¾÷ÚwCÖns6)v~bÆŠP‘–댕ϩƕELY¶¦–¥©PÈ#ØõJNÊSS“¿<:dTa°H»NY<+ž;Ü’Ÿv.EßaQKã´Oi¬[/¿ÜZ‡X$1Ê îÀ¨íB(·4ýðªl‹®£ZhÔ²çÚ%[ÚMŠj¨”€›áŽPå̇’|ñ\³ìZ ûðoË<œ1 óêÕ›»làŸV„þN>\Uß~ûâÇ?ÅøwµË¾aÐái.+¶×Иâ€T*U>Q}òäIÁ÷áÉ“'†*·ÛŸBšÈ÷{^•sš<`hHhŽ-'þåžþ!|>_9055OZÐgŽŠÓUöNÌXÒD^æ±¢ü¦4Œ*†U’+÷!”¹¸Ð5**£j¡ôï-‰ÐßÀ{^é vÖªÒ©baÍ ¥ýbÆŠ¦ò=cEyÀãñ…+‡Û‚Ý-¾Òf¬º((èVaw!¤8°ê—ö…Ý„Ö`ÆŠBZ &c%3V„Ê3‘HD;¢ât+„Ò2XBHË0cE!-Ày¬!¤e"‘(>0cE¡|+Bif¬!¤˜±"„–aÆŠBùV„Ò2ÌXBH 0cE!-S“±x/„ú;Š3V„Ò2ÌXBH 0cE!-‰D 8!„ò¬!¤e˜±"„`ÆŠBZ†+Bå#XBHË0cE!-ÀŒ!„´ 3V„ÊGx„ÒÅ@Š+Bif¬!¤e"‘(13V„Ê8°"„–aÆŠBZ€+Bif¬!”p`E!-KËX ‚ÀŒ!„òL"‘+BiH$JJŠÇŒ!„ò¬!¤e8!„´ç±"„–aÆŠBùV„Ò2ÌXBH Ôd¬A`ÆŠBy&‰’“0cE¡|+Bif¬!¤8!„´ 3V„ÊG8°"„–aÆŠBZ€+Bi™šŒ• ˆBíByŠ3V„Ò2ÌXBH Ôd¬±±±˜±"„Pž‰D¢””DœÇŠBùV„Ò2ÌXBH 0cE!-S“±â+¤.!„п3V„Ò25óXBåM†Œ5)) §¯"„Ðß I ÎcE¡|+Bif¬!¤5˜±"„6©f¬AjB¨ÈS ¤˜±"„–aÆŠBZ“!cMNNÆŒ!„þFR’T͵”]¾|¡ûósqi_Ø]@œ,VH†aFñÿŠÇÕÃ"‰IÀÝ.ìî „ Tv«D"aP¥ÿU<Ä5Ê¥Ãü¡b"çŒU(f<]ý3ªâÀš=åºÞF ¡â!çŒTC€ 9¬ÙSÔ …P1”ÝÀ Ê#AMãÀª!¬BÅTv«T*U U•?“ÉÕnhòçžýç¹ .”/$$GL4¬h%Îá·ˆVÊ+f¬e¬Jc)¼Ëcò±/ì[ofñÁf®~Ë66ª0Æß«FV;#%?V¬X1pÈp^~ެ4÷âehýúõ”~98ã¶¡“üùÿ¼«ëåzlMýqómgg¥—a)C’Àç+} 8ùëÝ—z šš+×ðÏ©=f¬e¬*Ê÷™¿­³œ¦i†ax†Æ }ö<ºÑB±oW-¿ùK¹qBðÍëobOåÒp8sêOi02­åÔ²’¡òZÑ/î½xýþã'ÂĦzõš;:êsrq2áÑà!S_¾xª¼ðûíø.+[“%Î_N”åv`¥eÑ>çõ?|N±äõ¹ Ë÷\zÿ!$Iγ®Ü ÷`Ï]kW”2c ï¡3%òõWB¨(Ðt ‘ÄžïÚ/€\˜qàTéˆcÛÆÍ›×ÿFì„›á±2S|»µná>«ž.¥[4è¿àïO#/‰VK1°2T⥓7='zwlräì½åsêÞ8¿bÕŽSËÖ-jb©´,Òõ?/µ}ë·~WOó¬N i£>ÎÛW†Ž^vú¬Â£%#£;67²Oø¹.:>pÊŒÉ è%~¾}ël _ÿ×1W ­)*ἸåêQ+ŸÜ ·{Aýc4ÍX9ú-÷ï·SÎXõõˆã솚Ê夜¢†’¥DtqøäáU (F\¶—··CV;zqþ´\.'råNªŽ8³»Ä۽ùU§~­:õkõ¿áƒæ\?çÏ'€7·ÿ2ogó\¿ï©¹œ rJì6)É÷ËÇ8pøíoã Ž6 Òö¥1yêïã‘+¯WeWŒ¾9cÁÉ—cw_QËÌÔh\‰ ŸuwÊÀùÔíêâ<æby!3V„ЧÜf¬ü_»=Æì f_jp`\–¥!⃭Ëòx\}s³øOS¼"Sgæµ:t×/û|êYïb2ï»D³ÛõlkkÎ6þzÞûð·Æ·vrˆøäGb›¶ìr§Ñ›Nìo6ëÙ¤;K“NºdÞÔñ³9\>Ûžâò 1ôÙþý{¼i^ϹçøÀõíì¸yùóüÇÓ5róŒÓÎs÷,ºaj;yL= å6Í¡)×ì"i å¿\z½|ÝŒÇ.ßØÔ¸a¥ô-ï[v¿ÝŠóB?ƒ>[:¥Gô_}óç£ÁÎRÃN2´´Ãè%»÷XwjAÍRâL¯JnÝ~ãFlZXð9ï¶|°h>&}ŤC?Sªl–©m†¸}£Sþ÷ì5í-B蟔‹õã¶‘£öÃ@ã‡üH:0î„R¡qƒmë3üíO~nÞýÔw¼+M˜™—(ÁÏ|òHú•²±¢ûäúþ/µ7ü˜Œ*&>ˆ×¼“GpçòQnŸx1ò¸Ù³g渿—œMDï¾§šö6Ië¢4RN3¦ ̲_Ñ´Yʶ­4ï0Bèß“‹y¬‡lº4øOÆšl8±í¢1g«úÌîP^ož´SPO%ÇŒû²ýäÉ’>£IZNÀÜ©“…é㪡ûŒ±Õ€¡âe §¶är’&íümuÁZ¤ØNÔý_fL²‰Gš"ÙrJ@0)Ϫ5ÇüÊ•«šÔE.'¿Hä"K>»ešcÎ!ˆø·¿å5³YK`%¤¤Ÿår3V„Ч\ÏcÝÛ½õÆ$®ˆ hy’Aƒ•G7°|Ùn—™IîGkIn¹Ç]uµ5›u*|Üñ¢¤ýBO3|híÒÎ0ýdRdb•Ö˜W¢Œ>“„­>/ìì\S—b€mCË"×Ç7ö+«²Ye€JÆšMã\±pßÆÒŠNv1Ý>q‡çZU¥É€bB+Kr¥Ó;€+BÅ‹¦× Pþ²•,9©çökKD |¾¸Á®­{öžPKþ¼ÏÊ3õÅF4šŠõ¿ù“;ïéäõôZ9»¨‹`dmóEžnîa0sÉÓ§V¦íJØ3kÄ7+×i5Ì€LzºmïÃÌëFÊäO8|`äI4#ÎÍì׬T3<ø˜Ò;éÝôÔŒÀÿÝk?²©µ¢ÍûÃS‡l‰>sv;}5þ}‚À„yÿüBúûž „Š–ì3V&P> KûVk§”yžgP¢ilÊãÙË £Ê>`îµQ^-×$7¿£k a\Ø› »wÎìÝúÞÈqónOvšüñæÍ›Ìë&SŒb³q >¸O[Ø®F)‘€/KIŒ‹ý;yåÆrBn®JSËÕ&z×SðHû:™M—•^w\WŒî9~jÇ&õMȨ;wn¬ßz¶Áˆÿ•àlÜøVq\5•ºåj§¡@ö×cͱR ´. Ñ€Ÿý@zÕâ…ç?›LZu¼µQH`à4—]åzvéÒ§§‹ ódçèmŸ½Žm,]Ú`‹lëü™Ã`ÖT_ksc¡@À%€¦äR™t¨÷4 >‡kl¸ïb𲲕I’×Ví¹'n7Ôiç–z‚$IàˆÛ¶É|fL)ËcØ6¢½›—¾öôóû7©29O g```\²téòUõh9IÒ¹*E›ÿR–,ŽJéS2ý,{Ðü=uš¬_{hŸçFÿ¹ T¥Úöp´e÷N˾îü![èP‚$I•«ÖbÆŠP1ÁލDdd$üúõK,Îð±ÌåËZ·n£|Úµ£ÝË‘s:›ŠIù c]-ûLš1¾§qzlúæêÞ5ÛÞ®Øí¯Ç!.Ïí}§Þ’9ÝÒ¦T1tÒÓ;w?…~‰K‘MÁêÙxMt-ЃΥÃÜ®÷Ú±¾cYÕh©Œ×#ÃÆ\ï~a]ÈxýÚ‡à­Y*’’âK”(Ù¬­Z9*gdj -ñ -x•'’<Ãl>&¢ÿ{kKcƒz÷ܼùâv+AÇBIöóœ|ú`#Cd¼ Ø£Gp`E¨8P ¬^è†á E¥³¸b^¶"‘ÛK ê I³-þ¯®G$.îÕ2û–×÷Mv^ö¿†b¾r×¹F¨xÊ.c%I’hš¥{^D10Ì›Œè Ðûñ“[ (JñT1Âf¬9Ïcåñxéç^\¥S0ü°[ìi~ڜNJPqÛy¬*sZq`Í‘rÝBÅKvkPЭëBý3ˆàà`HNNæñ„…Ý„*Âär©dŸ±"„Òœ"c-òSMBH×àÀŠBZ–Ý|¨¶h˜±UzzzL&Š7}a÷®¨ükWûÆÆ¢©Ð°htF ÃP¥_Іa‚ȾhUj‡†b~‘ãácÑThrø´:Šdou„òû'«68°UÙ Åöí®ò@m,š2MŠ–Í¨Z<‹FÓ4AAdsÂŽkQÅþà”…â|ÁRþ§®öEË,Ç¢I$’Ì¿ŠØ( xÖM9€,ІkQÅ&_*ç\y>xqhOJû¾M¹]‘"¿ß¾ó®Nó–f¼ÂŸº§Ä³ ƒwyxúyôS?)'õûÑ9ÿI”qçnŒ®ÜÀâá|%Ÿâòu’7Žž~ý÷ÛQ_^†$3þŽÐ©òfÀy˜SÜ~ôMͱgÞ`ò×{÷c¤yÝOáÀZ¬};ºÃoÛGÅSyê{¯]{E&|I̱ѓöC‘2yÚ{5âA°c777ÙÓ{1zPÒð)ëƒW;jruæü+Q*§dÑ^ýçÊô8ðrᶬv 5mÖ‚#wB-¹z)SûMý%׉Ó>ùéÞé¼\ý=ììòO¿kÒ2!lï¢åW³oséìé(ÛL Uswåò²^YçÖ·«]ÝzujÕmÓÍ}Ó‰Wìr*/ëɉµC]{4·kÒØ¾UŸÿ†ï¸ü^ùÕ×#û ;¤xJ“¿æéÓôŠx*íhÙ·©n ”=› rE)~n~|ø˜±UZ‰ [Îì5«ÿŒ¸)†¡IùÇ]3õëÏhªÇIŠ }ø8‘$I9Å0Œœ$I Ʋvƒ:âO þk=’$ON&iãßÜÔ¦æ¦ ÝÕÙu £­©bãü‡Eu°7à$™ò3êgrýåþí!DF„…<]<²Ë‡¾WùZò9\ãÖ‹[¬txttrƒ¿©‰V2Ö’.¥¾-yÕƒû9$äãDZæ]'ö,§´ ú×7I +ýÌõê¯ÓUwÿ€‰¸Dvý$å ÍV5+~S¦úßp,i"LJˆK”H37V./ð¸èløÀ)Ó½ýëë%~¹}ël oß?¬Z#ûòxÆJo÷î³á®ÄmªïìfuÅò˜§×.ôpåöŒ³»§uãWtdtO"²›¸´ ŸÏçó8>ŸÏãÁãóùÀ!.÷yÛúŠ ùü;&.xRåʵ¶|Ç¢ÁˆcKã» ìüqÞŸu@žúnòñ¨õ÷ê²ër9ÀUtttLßó°ñ#÷ï4ä?¯Z×7õ€Æ^¾¡Í½#¼nVqó\“¿ÉXÏÚó)<<<<<,äM|È~#*UªT¡RÅJ¶U ØC`¥þ:Ôiàû§·feÞxçi[ËWpŸ1½bÉs›)–‡Ÿ˜sIoØðveKø<‚¡“¿¼ÎúMU?°w®ˆ“6$ËÆX$àóù¯ÜÈTÞ¨ëSœ|éqèî˜:fP¶jÖ¶Dä¬ëûéá‹…œìÊ[ÀkÄ9ïu7ÃÆì½6²û;ؤ­ÛôÚeÉ^óvn9Ó®$p ¸\.0äo×cQ¶Û.¯fÀK?öÓNF­ºQ‹Ëåj¸Áúã'‡9O Ÿp±‚0ïï.M2VœnU¬=Ñy×¥ßÇ®žšÇ¸v¸°#ñê£>Y®Á,<êyµâåužSö|7åþèÓÖYñZu·ŽÇgº&Z]›×Ôòǃåd‰ Äü¬6¤_ªÑ†¥.Îg?HìÚÄP 0jÞÛ$%ðéÏuVÚ=F E½ú ³(ãжñ€òcÝúô?t@Í?B‘iGˆ[&¥g 9@“I_>}ø­çìTƒ}µVwŸ‹Uª½µj¨hÏЩ¾ ŽY- )чæ,¾–"¹?bÒýråË—/W®\ ;ѧ»×l(FU1 æf™Ô©”wÛÜ«f5¦¤ªièVY±Ä¯yýlÏw çJ†CãÌ"L÷\\jkÀe<›7lq"¨W =‚ËMîí 6ðfÓ{Ëc³ß{I{W†9¿ëKb“:æÐÁ®Ääï¡þå»Ï›§xìhÌ?#mm¾€f?ˆûúáý‡RÜ”q£c¿|Šˆ¡Ë•7xûê÷Õg·­øi£°i͔ͮ6yyên³Ž¥€k`Y¹~KçåÅqk'®²»yÙƒm“yÂq}µÓûþ|圡i†1åe((——¡’üH±ý¯y¦VV/Üò²*áTŒ¤ú@5‰„c“’»Ïíø3°^t_|!qçÕ½52þz~·õƒ…ÃÈÜn°]#sßÍ¡ÀVÌX‹(­d¬rš =º`Â#±bÉÛDY99IR4ªd¬”\Þ'ÐÃÉmýí££¢~F|ù J31_ÃC“„ÀáV*CËI^K5ée¨H)†R a-A$~M$mÀ¨žiò¶·$©<.åŽV2Vhk­¿ýÌUKqÌ»wïÞ¿÷)$áú½+)áK;¸ßªn[½¼…^dµŽK&ÛW(eziFçÕ6‹Ì&Õ}]8EÖ 1IDAT¾-{8dÊU§eçAN’=‡¡~<ÖSd¬dÒ›Q}üÇm¹`¦´YÒ+ß¼$A“$MÐr2½ñ‹i›¢½Û+—Wž*§“º†Ù‡¶Y•· 3Vyj$Í0¦uÙ¨4C÷êÓ'CI¹>‡ Hù¾sö•:ÖÄÏg‚—ô­¦Üòí÷T㞆ì4Ü ×3MÙùž¢rÕaµ0cý—i%cåq ‡¾£:ý‰ÿ6<ºÍåñùD–«q™>&¿çxÈ Ü“ö±~H²<2`á]>C»­ë'@¸T®oc¨H¹ ®JP(KxL3Œq#v¹‘% Wi“+yÎXå’ˆƒûÏ…‡‡……†}þþ=Žºù†Ký*•khÓ£J•ª"_Tyƃ[3àˑޖ«ZÎ"!dÏ´ ©;î:¨í3MþZèæÅqô]æb£ræÉçlyàùÆdïuƒk”Pn I~"7J+ûŸŒ•Z=Ò#¬Æt>Ÿ¯\^.§ — ?¥ðeWº¬Ê[+G¿,‡ b_Äs¨ž9Æ=åðŒ ù<àÀÓ«ºóè*ãÚs?P÷ÂÀ&Š–áRJ¿´˜ X5Ü ˆKëQÒpv­¿„+Ê™,þ{däŸ,/…ÎqP&lõ¸_MÛå,]¿ÿÎèA½šÖk±fì]ßlìäR鹤•€ûëg“¿ÝÞK\÷²†ìSé/)W`çù+çÖó*•«´oâR¥JU3ÙÊN£K­Zâ¡¶m û?þ÷ îëݧZÌØÖP]Žœøå†×ÈÉ/.—f;AûÜE«f©¯Vž¶vœ¯²ðö¦G™Ž×fw„ŒååpMº˜‰n¹ ®•TV!à§ï¾0Ë›Žàˆ»›ë]¿ô†VUyé꣫!Ч£¦UôyÐtÂê÷=‡¨uio]ôo¯X ¸1¿¤¹Ý 4FÆá\ ‚óX‹»”ÈÏ•ÄðôktéP7sã/dž¶tt¸ÅTia$?=y÷v%'üªëèTú°\M,Hü˜Í~>˜q£”óÜúéSü»x¡iµlVÉ?\A© +O7¬kÛV¶¬M­;§þ>™Õoý½S~‡9‡Öö«¬ò*%û}ãÐÒ¶]ÆÅغ8âoœÅÄ+dé9ÂŒÿ )YÔœ+‘c½ÿÔŸa${g˜°]ºc÷Tö.•òŽâðûmÀÆ»ÑÊÛywÐÇÞibþf!–WÙPoûØwK׿ŒQ^uuÖÞÉífuÏܾ¹×¶ÞeLp[˜þÞª*æ'~úsìn0áC‚ÐDuðÍ?˜±U©©©*Y¡òc 7"§ëÖn“ýâO ä$×ÜÑo2dÎXmº¬Ÿß—˜–ä%>qŸwÿ¿½‹H’d(’ìî¿ýœs§ÿVÖÙ9Þl]m¢v=$'¤½•)ä©/^¼ÈPÒÑ‘¡9}ϼ±ëÎÅ]Éàkß*Œ«œ}P˜ å @Ö«&E#ôìÌèowc“íÄê¾ãË-]‡ö$.¥ŽÙ^ðåC»Î^¸vë‰Ì¤Òð…{Gv¨ Yd¯<³r©?.ÿŸ¥™˜&“cÇÆÆÅ’z=§M¨ÎÐ)CúB«ií¸iexàÕí¹ãîs³*ðv¡Jy­;.÷º5`Åðöáã§tlÒÀ„Œ¼sçÆú­gŒØdÌP$IeU^ ‹¦’Ÿ(RéÜf¬PºÝÒ‰—ú¬Ö/ÕÛ·k³:byÌÓ뇯;S«ûœéÌÓ¯s ŠœïµuÍã¶îÿͬsÌ¿ÔègómïSz\uÍ7÷o~¯0ºŠV¾ƒ«IÑ0c-ª“5 7ÂåÀáñx<`ä¯?„šë}“ÑÕø<wûö=C“ð'¿¹"—–|qx¢V%àôxAŸÕî&dRjjœœæòù½R+öúuõ<.ÐÌ€KØt–²dþoÆÍ‚Ï}Ë2VÆoW®|Kpø¦%,,­+.ØìÓÑ¡ºâ\’Fìú! p*Ëî+˜Œ³Ú7¶æEël®w>†t0QóEèi©ê7ÙÀ8Ã. yb kÍÞäëbo›õçù¦}&½~ú>>INƒH¤¯o _Ò\ÀãñR¾] "]Ž䥟êÖkZ!Ô°÷zß~Ê“±TÊ #–iÜbõŠ}¼6.L¦øe*״ꈛsÚ<°¬Ê«IÑx<žò­Øk;)FØìŽS=îÐåÇêœX·jߪ#_¥ýr•«]¼w¨suE ‘Ei›2&‘>WL\{ã†1Ãçì^w¯ùx‹ÒmÝR–-þ%w-™vì9o–}ÝóC¶°¥µb›Z‘]Ñ´¸T² 4»3 {f@À,ÏÑ?“M*·èa*¤iúÚÆ€ÛQ12B¯Û¢ŠŠó&½qûUÛ6ï÷w?úIh\ÉшGÓ´MËÇzp€¡iF`ä4½®ÿŒ ›:•€š>›ÏødÚ½RGCOÌгŸã æåùœB“ß+š­×ˆq_øœ¬:c?qœWõªqÖN³×9±»¡sLªÛÿ7®}¦…4M‹,º:ØMyêœi£*åeÕé2~{—ñ@K% `GaE³*¯&ESUåÊÕ¯p ºÝÙm,CKå„M•7UÃkýžŒKÌê =vl(ÛL`ÔfJ%s.G®íPFà †ž«gç×ÔŸç+Ó¤h8°UY¹z»×ud;WÈ0 qøìEåûí:¬üœ¸ÆõØÇaY!0µ}÷?òÍІPì»Ûò¹;ºN‹rÞåÒ NöÝxñäŒÏªß ϵÿ›÷}žVµE+ßÏ­|ÖêZ9¹Zåéa-R”×Z1£%ÂŒ}£¤¡Y•Wâ©[ÿf`Ut•—§*v^ IDATxœìwTÔJÀo²,,½ ˆJ;н£((úEEÅŠ½?»‚;vÅ‚ŠŠOQüTìÅ¢‚¢"V°€ ½C¶%ùþ¬ ,¸( ¼—ßáp6wnfîN’»3w&3Hll,00000(ð?mCýý,L>Âüÿýjd``¨ ‰‰‰¿sþ€ÉG®øºW•5u¦þ# LL“Ay~7¦ùÓVAÒ7–‘‰ ò;…ü% º;ØÞZ&‰~ùͤ¹±«*mbZš¿Eúùß”Écd’ð[!æ½z賫 pT{ÈÏÎb©kb(B9ù¨¦†â‡.5üjnÓ¾™D”uëèUÕén]jÊÒš€$Ÿ z>عŸ JŸÁ»—~·{^–wçB_µ±Þ€oщ… ¯v¥[ìk)¯³Ý7dÀ˜žV•w¥Q»‚f‘œ¢ó(’c¸oyç¹+ΑlV‘ˆ"¸º]¶Ï2€¼o/Ö]TÝ4ÝxðÌ‹Aû‡/Xt~Â:—*ÔˆéÇ=wŒo)¨JavÂÒ¨¥6»„”"¥€²åŒ-LK|Ï3l­Îª¬ýÿH…Ñðný=¿‹y(]S$Áíx÷êzÇîÝž ­@B^ýMWu€¬7»&n©÷?ß ,¾~ hÛËãÁƒNªd“†–G_ÇupËæ_˜|çÙ©s=¾B›ò¿ÞÎïÐ]O¥Š¾cU2¥……ùµ¨%¦‚ìØ™\ ßG®(«CIsœ›·î~úéüÖº2áÇãM]yw]Û²ú×Ôâ ywÈÙaã7ÏåSèC6ÏÐÕm†–ð5/I¤$GνVP{ì²"R’õë×—U+ÛÂJyù%ʬÕðFïÂ=³îm—ô6‹°oÙ=ŒøÔadw+(átÄùŸÏÝÍ*•¿FC+§j²Caf¾À¾×\K ¤xÚ‚Ý ’–ï½z0­öúÁ¶GRú3ß Ñ÷˜óOò‡@æ»°4½f-0T”ûG°fŠ<&)Íß¼1lÀÊa2ɇ'Q~ÁŸ?}Ë.$Q½zŽ}Ûï¤,®dûÆ{»½zɾÔO[š—/_.%8p`úUŽg«/ûžìd 0õóÅÏŒ'¸´3¬ IvGS@ù.ÝÛO¿e¯ÉRš¾a_Дô9hAb‚ÖäƒÛÚë€$ÿùÀ1ÁŸt)ø&CRÈÜÙ8ýY`>èËý^7³î@JØ’D³I\<-°Õï è.'ĉÓ.+^¬¾(ºÏíó“åXXÁÜ¿æÜ|x@ù–Ee/JÀ´1çÒñâ#Ä~Á¾ð3 HJ^§ÇŸÙô•4@FFtBúÓù)Ý7ͱJÚz:vÑÈŽ{4_.ÑÔe£ó»wi^6èÜÕ6´~©Ú˜qû ,žŽaƒÆÆL™ÔÎL­*fOžT@奢lÍǶËK„!£·|œ½p&Azød´U×þ&ÜÞ Æî%RšíçµÐçÜý”¢aS›®NS7Îq€ o'6Žãe3õòòjÖ¬ŸÏçóù(Šâ8žŸŸïáááééYJ3p÷¨R9ˆ)Š qœ FõŽ>ïäÖĸ÷ß¿KŠ*—xG© ÀÓÔmnÂQaaFv~‰úÍL ¼›Ük£ÝÌI*õù» ŸY@8P(ŽãÔ…[¯h<-Ÿ"E8Ž“„0äi¢MÃoO?%}øE¥}sâfxJsÕ8 ÅÓ=ey._ì¤ÏA úìõÔ6]š¢bú Ýeó®ƒö™ð´€Žv»oG…êsXíIj“Ot—¿›žzáà6ïiî#q)"&©Ä§}_ò€”¤ÅÂq(Â××—Î$ÿë÷¢«#Í8wþ¾K?çO—‚(¿]¯Ooêôù×´‚("·G·n²r\¾nÊcÀ£•#¿ ÜÕQ…Äq<7ù[|BZéï"°ÛÞ}óȵaW–)h—•å.Ší¸)†"‚þµj毙ó§»7óàñ#\às'=“à´a™¯v¯<ô¡H9_ünɬ[œÿR˜¹»¡åÖ3½f5ÑJ2kT¯R“caýföi´aŽ‹)jÀÑÿ­1S§5?ŸwùöÇå+Uix׺P¤(=9áö™]CíN~x£›vµWØØÚŠJþlȃ²Tå/ÇÍî?­ãêÿÍjxúƒ~Û$¯íÖ!Ä¥.fÝK¡«†¬¿,Øæw¡£)/&"lÝÂ)ƒÒ,ëZÁí¤ ¦éááѤI]]] EAQ4..ŽÅbyyy•joÒ-,IA¼·Ñ€RZŽ4åþóÑEq kºˆG§Ã.sT 8˜k¿¸ó€¢$ñÉâÀýn<0¬Ùì±%, ò:õ¥K{y ¹(ÂQÃt4¹@H(@:UG³È‰ä²‘†a$Aá"BP_óÝÝWE¦×±°ndÅ.Øù:`ÂCÀÆ¥cÒ‚‡.#L8(TØÒ¤½{ôèA’¤T*E„$I[[ÛgÏž—÷K.å",~ë·÷–’O±ï†òT~!ÍF·Ü‡® °hîåºp‘s¾ÑíÍ=dò/K¯ñ§Ïp2ÃLFÕG׬z”yÌÑÔuq˃ÛyËO¡¹ßòõ\uÕøÀE®¦Ž¾¾‘œ.N_¿¨åÅËâ"™< ÃH ;//O£iÃÈ#{)Jœ(V­Ïå—Ÿ,Æîöo‰g\4ñå­ Õfj¤…1sý¢Ûa¸,Aܺ]–¯ùd3'qy„…J¹](š_»(–ºÉÂL‘B¢q{£î¬i£YÍ;ŒÐÃ(|ÉF# ã™ý,ìUëëZ@AxˆÑÀ!Z¼Â4ñãwšÃ†9@èò9Ïs) ðC—·ôè³6&úÐúží…¡A®OÅ)jæˆs¾°û]¾²µÁâ™´oßžÖì?pP\³æÛN'ö]ؼº+ܧM¯8gxêÓyCÇÝN,4Ø1®ëq^z®Tu“«Ã& H“~AkŠšÒ5v/ù]ùÒdî5çŽÖ`dlÙÁÆ$I§T^í•nyzxxXYYZZZ²X,EY,‚ 4ÐÖÖ¶²²*Õm§=ÊV³iRþSA£–Æôg ­ì§o eÊMÝ÷¬r–ÿÛ2Ç’ÅÓá)jÚH ¿í¯UJ®j cÙ@ϲž‰–ào÷–°pJ§àÒB3½¢¯‡²øÃúµ²`e~·l ¼}üµ§aßIÕçU¾n+=CM]^ŽŠF#CM:X™ñ>’ÐhÚ´¸Û~៯õÛ{Ì"Zr:º¬'m-‡oÒWUr,—¯‡²”ºÉb‚hÙ²%(êÉ@ži¸Hu©µævy§ç¢2 Eþ½âL ‡€òÖö7}¼æ8;¬lÒÎ4UBÀ§ÓŸuÚ;ÊN4jÚªU«V­Z™Öß¹{&ìÝ¿6Ôi¡µ™*­†r gÍšÕ’ó¥ý,@Èÿ]ÏS51Ìhyp¢Q_ ‹zª±|ý¿,,,èøuò£½ í?FHÂÕè9R«`CDZÅj¿|Q ’Î ™³'GJPW3pmj£ â܇‰ì¦ÝÕô9j6ŽŽŽŽŽŽ&•‡"…wî†þT­y^†œrCZï9OQ/äÒn9´‡\jÂõy¯Ø=Îö)ª‡V˦>Ë¥ØüfWoróÍomŽ›ËNѶéjß³²èé”áêg^ºñjøšöðµðܼX8nú+­¡Wöktä­»Ï9Ì>/a‰}^Aw£´‡ßô:ÿ¸1¢÷ÄÚÍS¦Zþê¬7s×èfT±Ú¯]¾aÿÞÒ]ÿŠõ?Ðû3Ú¤—&ÌÇ[|ô}½Œ“Ö²œ¢Œ‘ ‰ºý´û²£í9ÚÆD-x {·¬SçÑ©9ãÁªH³âÚÈŒ9˜ŽÛ 7£«µB€Ň<üP^¶ÖÝídÁJ[OÄùá¾ %‰bâÚ1ß*lHyœº%έ™{iá‘E7¯kmÿxæô)nÎ=J è+¬=1M Ãèö¹µuÑ4kk눈’$Ùì"(;«T,”ä}Q-P1ŽK 0OÊâJi)E‘"!Ž—°)ú^¶^µ²6d¼yæóJ¼v£aé€)I‘banFâò=¯ ±4Ñ÷ê,}n~j¶PŸµ:zäì¾Æb‚ŽtPÖ°u»i “Bi7±çQö±çoD³K¸ü<»PÿEx®ÑP–,ÿw™RµN}Hˆ³ ÔL)YªT˜þðe.ýÙ°eƒ& *õ¹xl Žë–­yp§ï?ù{Qö¡T}þ8K$ ËÊI ¤B!޳ ñ÷ (,Qž57î9hª€¢˜fV̉‹v¬k?l¾‚>»(ûñð97v‡H…8=²†j ]5„r9ä~Ù%5=جè ÒW'û{˘=R¼ðÓLû†‚œO L2ìí-8y®‘ìê€Yó^Gtþ|f¾A7W èÏØðrý ðU~·­Ï,èö¿ø†ž:2k£’ 5‡óe‡b‚¢(©Â W³Ñ*ð}‰ã+®–_»(ÈÄmAêëÜþê5W§É6ZA½åRñ“Ño³º_õØéÀFÙYB1)Ê È€OB"ÿÒ¹ ž+-H €ˆ|1)â8Žgµï¹œBUá—Û=šv,ÚñÌoã¾¥…˜4aüô=¾Ýºv2ÊàÒ™—­ QÖÍ%K)qarRìƒG1Mlë¨E+Ts…žþÀËëpyÙÎøÇv öîš!(Zô+Ž"€"(}ˆ"@¢_ª¦î%~c·ààf¾ûú,»Í«±û<Ïy#ÚË VX{ C\.—ÇãQTéà.I’2¡ì¬R-¬ä70æFjEùl¸ê|ZÙeÑ`‘¦ãüpšüû¡Oâµ³ ±’cÙ’üä~T€õQlÓ¾D÷œ‹"(WE]ÛbëÒ†@ù® nœÙY43‹Ëã¤qYÊÃ0ŒgåæfÞÈx’ Õ¡Ià@Õ­èmö(*ÌçMþëTØÙD +nd¥H)¾‘€6•ä¢(…)(Ö¤èk Å…ÑR êùg[k‹6Ú<Ð0â’’Bú” Zšt|Cv "BRÜ×.{¤<6ZVŽ"ÀVQÁ0 °F/_¾TX¢BJÅ4³¢† ßà´ù¶«™vYeR’ê1bË~õ>'ó Â;f5ågP|¹é«£ièd¤ø[³Ö®ocÞÒ©<¾jbñÕ‘â )‘»wGF»©7xüîÝ»ÕxtB÷ëWç-¹ûþñgêzg¬¸‘/"ÔiËŒ//¦ ZÔQüOc¾¿vQhÆl83ÈâÑ篅Ní´x€5ßé$˜{Ð;ïð¡­±¬g¤ÂE¥ÂØÈH!¤KÑ«ç‘G’—*çGFFÀ\Êåª`†™¸FEöå©k¯mkÕp§—åÇ9Ä‹SsÀ ½ p?¡Aó´…ÿ‹µ[ìºQX, SSS”ÅkÛÝqöºÎí¬~<5Õ]!˜©Û½{ng.ñ–ú”)Eíñà›Ç¹Ó ö·’‹·by?¾TMÝK€Yt^º­óÂ5ñû6®X1:&ûÊÉy6Ôž‚¾sAAAA¼~ýºyóæðôéS©T*•JóóóK)Ë{ Š"N¤4uýá• $*:Ežº ä¹¡'ª4êØ¤¤Çç%¯Xuƒß­ç‘N’/â¢3º•lµ|÷¾¡KãÓ_)R"?»¢ AÌUÓ.[¥xò䉭­­Â{ñÓ§O O¡!ĉ²èŒñoÝÁ á+çÏ?÷L2k×ÍE•ö˜„8ãÞYŸy¾FÓ.í\¬É.×g¾½´y çõ~a6j¥¯o«•OV¤¿\bë|ÆÚCãŠba_/é°¸õœuâ±ÐÉwÜÐnõ÷Xm¿i¢³­ð4[4à๼1Üâò›©sCßæÀ ŸÁœ˜žVÓŸªýòE¡ÈÂE3Î ?6¦›NÆÄáqÙb+Œå á¨Äž<œ=zS•V·ŸgÔ[¨<-³‚ùÑÜÍ#\Òúxí9~ÖÂn=Çgͨ[ºjÅá6åkª¿B*…Tø…§iîÜ–²IŽº.*óžM ÜK/.Öì7¾Añø¸asM!@«+¬½Ò1MOOO///©T* ŒŒèØ0AIIIYYY‰‰‰#FŒE1Í7#×ßÌr_>˜+~ø'бÔ"& [š!¥Š Dy×®<;š9kù@JD'’„èÎÕˆãwZôl·bP}ZªRßb«{Á<ß«ùù=9ÔƒâHŽ£ )Èܺ;Önt§ÁwÇ]Ñ9°U+uaq¤HRì4¨Å­³W&¢XV†ÀÏp§HéQ﫜öí;|5ëºÑ­1ÝÒ­ßE-íÞ7ܱ¨å¨iÓÙÍ6ïÄö³ß´íj©k¤ I™·®>OçëÏP!èü#¢òë9MC+/¦iooüìÙ3kkkÙÏ8EQ$IÆÇÇ€™™”Ó¤¤¹ááá¥äyIÇ4Ë–U1RŠú迼ýÕ[j¶Cî­²ÑS‘/ôãSG/]½)Ò²˜î}nÆ€:0]:Ÿ‚xÿí«6ý=ÉûÒœNšò™_DY¯gŽùŸË–­/L³Ýe½`áçNJ\B:qɬSë†tD R=³VÅqœ" ÖÊâåð~›ý ìüÖñt3Äz´Y¢_>·h˜ ¤øÇK—.ÉŠfq zõh !7“Í3¯`Î,üÆEJrtÁÀ(£1‡ÚiàBéTŸSðú¼§ëÎ{n=x¹ÈÉa‚öyŸYÚl„b’"Ų€¾D(ÄqJ¡8+¦ ¨º(ÉÙ4|DP”D(šÚ¬ixRÆë#£·ëbÐwÜÖåPgOŽÿò¡,DAm@9ÞꮈsïÝ$òpøÍ\‡¶¡?¿÷¿£a9Sa7ŸÇFËÆ4«û^"ÄI»wl Ûò`Åb·6-ëÇ?´Íã™™ÓYà^aí) ­_¿ÞÃãY³fb±èJ‰D ´Ç”D£[XyI/×]N›¾ÐÅ¡>$iß÷œŒ”P kÖdº™†|÷[˜7kùvCóµk{Ûèÿ˜œ!Ásï¾MY0ÜÁªÄ´m³vwIÉ ¸m'éàq¤^ܸÿ¥ÕÀ>óºÔƒ.V1áχÄYµÊÍ$–,2‚ÙÚ4HLHûô íh˜9mã½Í³[>òA£é¡±ÍQÒâÈŽ 3½3<Ù5ç£õ;·ÂÏ?¹­´‹ÏGLuný$Ê/ø£÷õ¸†-Ú·åØ˜V %¹WrˆEmué€l-Í^¾|ùÝ»wôÀ9úòå ß‹ %ÝŽc'Ô÷Z=¹”|ÿjs]u ã),«:ÚYÝŒ‘.;rÃ;YÙT-Þ‡, ›þkûwm^AS‰”¦ëê˜jÕçHpxKõR©ôÕá²Ò÷mÚqÒÿz×ùǶ¹tç'Û6>Õ¦ÑÌŒøBù«Ó£OßѯŸs-Þtí7áÂñY;¦ÍˆÒ›ºy ‹pZ;²OÏÁQ‡ÿ·¯£×bÈŒ/\öT êõÌêi½÷ö~/+š§ÑÓɱ!úz4E´·¿9=S²~å¢P’3úíyÕøÚOL… ‘ÿ×,Ïc¯<ÎÞd©7à쥔þýz÷pÝÏF­ÂEó’vãqÙâ§s&Ý籤ø'<7fÌ#HMÎ7æª`&&7µhå\O+ A8**Ã.\;·¤ßö¼‘÷Ö[Jó@0¾úÆË·è»"ªÏŽ.ek£Q–¾BOT½ñ8[XqÎ*ÚZܺ€8÷Ù²c±#‚zÊ›*L{ zZ‚˜79ÕR1Íj¿—0sßà;ÞKV÷^²ìk[M·ÏÈ¥ÛVÆXHµWî»çe_£,ë1åIÅI}¹è$ã)ùPOOÁ…ŒxžÖ¶Þ¯Í6 _õϵáƒ×5S½{5¦^{+k½}C©0m’çmÅé>Êqº­.ì HáÚum:®Ÿ%†R2"Bn Zx¸XѽrŠŸò w˜Ô]—Àõ­§w°¦ƒ t©)”[Òâo®®xÑØoŽâùRe);Ó­‚{±šu:~‡¼_Vf “®Ûµ8±êæéžFçvi8ÈÕÖìÇïŸ$?ªs÷ …І3œLàਮ;? †ºº/›5T•E=»ó!ùÒ´iGV¸ÒUMIs·Íôµgg=. ü]ÚÜ}ᤳâ¢ibOºŒºéúÔßEÉïRÉ‹B]ذªÉܕ֪EÍü¬7{ºLz¼÷ô^fE÷ )Mß½øàTïåŠ$Þ?xCçƒ[Ê}çþÂ)¯×^9ÒõGèɳ•ùõ øIÎ º %âVôv‘ß`\hÐ" %É$ÛþIS¦6 Ú+¤r<ò°÷Ȳ§Ä¨Qaê‰aãþÁ …$gÄáós‹gÖü½$-ÀÙª%üUyµWÑ‚¯^½*%)[w5¼º)–lvùóK@ˆ…(·Ô¢ ù q^ÂÌU/6l ÷³°!É™¿øÎ¤ ƒe«~(SÊÔg†À ¥\Œ§ÜÒ5R<ƒ…é”TU¼0ãno»]g#Ï·oX_¡Â׸‡NíÜW‡Ýì¤þ“V•<¿yQD$ðªn  ^ˆ¨ð• Šþ´6àUHP$.A0®r¿Û5s/sKOÿ‘§ðSyµÇ¬§Y‚ÌwÑšo8W±ÚÑŶ·…õ‡X0;…Ô()wß6çf¡¡05+Æ/ `Àôöz5lÕŸ¢âÚ€ÿ^…T ºöV;Ú–§äQ^íUÍÊíÌf=M†ÿU¿ž&ÿ˜ÕúØ Õâõ4Âì{ÎÀð߃’dçJËÛªˆ¡b*ýb CÝ%é]Ä[WOž8õÆÈoUÔ¹³‚eZyžÙß߀ìÝ­NüxAUÂBïÖ„¹µÆi– àLàÏ•ʠʯÊý˪iÿ¨œOž]]îtéÞÝÖ„ÿå[‰¤R/³|¿0mȲ¶: -ˆy÷éËæãÿ˜ñŠf5"ÈvKA&¦YŠÖ6-;uêô§­`¨c„‡‡øðÞK‡¢(zŲ*@^9,,¬šžJ®á¢WO=XD­ ?—PâuuÙB4;.±yÀ^€à8^˜вÔwé ï)ÿË~ƒ‰i20T †Qe W¾PÒiÊ4«í©,Ê–ÇBË[RŸ¬>øE7ìZ/z JÅÓì¦Æ8Šb˜)G UC)_ISÖþ”?ý=ÈuÓNµ˜ë‡ · IDAT#[ƒ2ûe2krçœïŒ‘޶]zOüÛûsôÏšøgaœ&CÕP¶uù ¾ò;ÍÔ'—rtLm,“dDd|ßÿ°Ð`Æú£§÷{&8tŸ‘OüqçþÇ`bš Uý(É;A™Uæty×YÝO¥ˆ ËÛdÉ{öùú’߈Ürîá‹cM­èõ‡´–8{æç¼Èo{Z–ÞRá?BE1ÍÔð«¹MûZhüX~M”uëèUÕén]jĶZ)þ¾Ûç̼ym‹˜òàBvK§Æš?VFf^Ù^íïI=«Ý>†? †aeÛ˜JÆ4¡¤·­î‘†òbšßOü“˜¿Ã£}‰-tL­lMå”°FÝ4x±¯ °¦ðŸ¤Üî9%Í™2aö¥O9òÂøK{ßóJé%ÅÅ_ ô^9סS³q¾¯"=¸q5èôÉã>»·,œ5i€}×–­GÆ‹ù“ “ïñÜÇ•ö%ÐûäÛªœÂÀPM< Ïþ“Q×¾‹×=ø.;$¥™0fÌyz½Wmoé/¾¦†Mýn·{q“ok½_9¾ëYã¹bm} 0µU+ä~ã»ÜŒÜZ Jâ’hê:¶”8ìÀªñ‡“¼önêÕÉÒßøxLÅuì¼[üGûæ 8¦IIfêõQjr,¬ÀÌÞ!6ÌÂq1E 8ú¿5fE;|>ï:ó-½ƒ{ÿ?'("÷ú¥û6æú Áߨ¨«H„ùù•v>¶h«3÷¿Ð{§}Z­ÞŒ‰˜ßÆWé”'Â/ø«°`Ôž#ôVpÉ6Jô&´ .™aì7nI¦ZÓ›öØËf:p5zŽÔ*Ø‘v´›d¼Ø»îX¬ËÚ-]+³vÿob=mÛ&–­mñòΔ(ñC€kG¶lEŠÚ¡êæ#BüB› Ù"êk—ÝÚ¼Ù†ž¹¹­QQK3ö”ƒ[tÙÎðçY°`AJJÊ… Ê& <øï¿ÿ®y“~”Ãÿ¹Ò€rqQ·Ÿv_v´=Gû`À˜¨/ bï–uêE£@9ãÁ @EÛéÐ!§˜íŽÁø;ä£ÈC·pdn µÖU§NñëwN¯§z¬oû„â è=1†v?FŸYtcðºÖögNŸâæÜCPrK¿:ëÍÜõº@~ü½ÀÀðVË6Ô¤ÓÔnÓÇàþýûô!!ühdÖKvjjjrúWÃz¯ ìÌÕÙu|p„çW÷^³L£¨Ò²ß}ë³áσ Ȇ rrrîÞ-±¼E¯^½Ö¯_ L£­N¢ ¦‰gµï¹œBUá—Û=šv,ÚñÌoã¾¥…˜4aüô=¾Ýºv2ÊàŸK®?Q@Ù=G{ù.ÔËÕsÝU9éßó…KfFrYßÓð¢ÍÊ£’ 5‡óe…ò»7óÝÐgáØm^ÝçyÎÑ^f‰šVïKï ú}üéÝŒjxb©¿SWïoyE”(Q—.?f\©Mytc&¦Ô·žN²TÐB{Ç­zjÌÚòêòÁÝ 8°èÔù~Žöf©åîèÂP×)/¦¹yóæ3fDD÷Ûµk·yófú}!ùÓk2¦Éð;(ˆib&®Q‘}yêÚkÛZ5ÜéeùñcñâÔÃ0hï†ÜOhÐXYYùøøe¶‰®Ù˜&Ãï ¸{þzñï~§šH ž»/”—–øùìÖ‹ÚƒCŒõ²~×@IsçM9»ðî¬Ùça𦠣lå¡3{T?.š•';ôÍÃ9“‹ûÝF\VzªHjõÝ–ì·}±gÌ{D Ei"·^5}óŸ"-ŒiÜâ¯"J ”ÈÜܼ”æ¥è÷Íøì—3º­|¹€$/bÄ´„Èa¹© ±þkÎê GX|dÇåÇ<»èÉxÌÿ ÀÏÏoéÒ¥›6mRè1êŠæíçõjOËÁ¬`~4wó—´>^{ŽŸµ°[ÏñYg3ê–® €¬^_»{ÿ¥Í@Xju@´=èEÀ©>mã÷Xjª,^Ñ/g3unèÛ(D~qá°f¿ñ ŠÇÇ ›ke{“çÄäð´šVã·¯6¿Ùû÷ïå%×ç¶›ýN‡D{…_Ú +·ù:›Í€ké&+µ€§3 QÁÔÜ=cG¥¶_¾åüõÆm<9'¶ÛþuEO Ü>Î u…¯œËRutt|}}Ë;Wþõ¡Ÿ´ÿþŸê0T-Ó§O—}V·”æOcš•Ž7nÜ,ôÉ——/SRs¤’"Ïb±‚D„¢H’ (@PA)ŠDQ„¢àrQ#cAË6†¶- ¿~­¬u—œœù+¢ ¦)&7µhå\O+ A8**Ã.\;·¤ßö¼‘÷Ö[Jó@0¾úÆË·è»"ªÏŽ.­() †|ý0Ês-Ï• C“­šb¨ âBO‡Z ™Qàå‘ËžjÀA3÷ ¾ã½dÕqï%˾¦±ÕtûŒ\ºmå`Œ…!úz4E´·¿9†q€‹àÙÙÙW¥FÃ=”4éÓÛˆû×ýŽ~]nF_5æ±&µ>±rö䞘µËà~;´wuv@„ñ-¬luh§ Ãn=<5«³WÆØ¨­ ³r’ @ány<³{‡÷íõ4ª¹¯ÀPSp¹Ü²-MY²âsK5Nz“ëëëWÎ8”ï{âYÒgö(·ö»5ÕÐà!(ÂBY@%!)AI‚à ,6 á ( E¤… ÀBX„T’“#zúæ¤ÿ«˜˜´¡ƒ­Qê¿2Z•““#EtÏÙ* ÏÞ¹,/éìäîÐehaÜŠ^Ã.·,ŽÑÖ+·I¶A©sノîzYt`ÓÎÞUœ4lËž>š<­þ^¶ž ®$œt6·Þ’¾K¤8[µÄò9p¿ÛÖžEŒêõÚõ ÄÚÒ5Á׿3ÃY]»÷pYuîBŸ–²bç±k#G/ >{òÊ­;ÇNë€Y\¼/nwçYá=G~X`ëpÆ´Í4`q}<%9ŒÇüwRž»,ÕOÿé¹Ê”U©¦‡Ã9qæSòW¾³{3›¶æ™an†X*•¢,”.( IRJIP‚›… ,EŠŠ$AQM:™»ð¸ü¢/\›àÚL"©u DÔHbbbyi¼Qá+Ù—,,Äù|¥.¤0ãno»]g#ÏsËÝiD*üäÔÎ}uØÍN58+Þ¿/¿ÝEäKP©Î´¸°ÅT™ø z»‹>}ú”ç1+å4Ÿmµ£my*A{Ûpˆ?;a aUz “ËW­Kj?B¡Ê„2•l<–Òüém¯¦¦¦¼a11"®¥.[/K³¨ŒÇQá"\A颢(A@@PE€"Y(›J¥B‰P,&$ªÍW±Ô|™e×ÇåÖh³æOñ“˜f Рï’É“ËoäÀü Òj<nZ–F¥‚”iòù•x£1›Pa™bš|vJ&®!àI¥h¡X,–MR¡€¢(Š (èÑ{E (J‘…P(ŠòØ,‰”‹¤™Bmvº–—‡ ÈdJéObš ¿@yáËêˆiVÊij4Òáj¨ÔS'UUùl6e£lÊF¸²Õt)H‚¢HŠR´ÇDa±$AEI Q A8_…k¢Q€ ˜ØÒ@EE¥R–ü;`œ&CÕ hHYWHUfwPQ©ËZ³ÙìZbIMÂìTšððð?mC$$$¤ª²úéSÉãñ*VÇ¢IrPMš*Ÿ§Âå²Y(›…"‚"$E‘RФ[š , GX,”¤(@EQŠ¢¤É‘p8 Êb£h„'æóù•²¤îòçcšµ–Æÿ\‰¡ 5|çTª}g¢&Íâ ÔÔxª|ŒÇa±Y(ŸË&e³‹¦‘$E$IAP€ Àf¡(аXAPB¡(*•JÅR’+%8AEÅÒàfa˜Ê¤¥ÉÄ4ê6•³îٮ鵈xu•š ›ÍA9,EQzm:Š¢(’"Y % ( (AØ,„…¢( !QAP”…r9(— %¥"%Y,ž™ØÈ@ÇSùŒžËÃ8M†º‡ü ¾?¥qãÆ/¢ßd&Çê7oްÙÀf!$…uÏ( ’DŠERŠ›…²Pzž&Jwã X$‚J$\.šüå‹!;·o_—júvµ&¦ÉÀP÷¨”ӀѮÃüOþóáÑ ‘i½ ´µõHŠDÑ¢î9”” Š’$  а„…¢IÒo!€¤&%'Å'd&~ÑUåëV=߬–ÂÄ4ê6´¿«ãÆŽ¹råÊ÷ï 1£#K6•dCöå-&OQŠ¢<OSS³Y3'§~¿`s†‰i20ÔmV¬XQó…ŠÅâ¼¼¼„„„ÇÕ|鵇ŠÞ=g````(Ód```¨LL³gÿ´ 5ŠëˆaÚ†:Ó,Ak›–òKÃÕQÂÃÕ™k]j3e`œæ¿“zõ~²!]RRRÍXÂÀð/ƒ‰iþ;QÒ'2WŸ¡²01Í'JzCæê×-~Ú`¨Vè¶HESdSÃ¯Ææ”X¸]”ukÿɰ²š„(þȉûeå  L©T:yòd©TŠ•äOÛÈÀP')7¦IIs¦L˜ÝýôÓù­ueÂøK{cWN/£,Åc7í¸æ>¶!þ6tø,…;tj´~Ñz¥…Éw^:×SvùÒü¯÷Ÿó;t×û÷¬§BIEû·ÖÔR2‚ ÜÝÝÃÂÂÜÝÝOŸ>Íb•»/ƒ2(ŽifÆ|ˈ\ú½ËÚÉõ?o<ñfÞ°v—Ú®kêpP€¿»uIþwÌéä5V´¾Q”Çq Ô׬Y£°$Œ¢Ë"ÄIÓ,q»|Àù¯‹üi;Ét®YpM}üÆ¿[È$Aû«Îñ_%™;`fPðn=v¥ß«m$=ôŸ¶`ヘ/ª¦ÍÍ>¼yLÅ_éüìýߎýýBžžžaaaæéé¹qãFùT&¦ÉÀ <ôó¢(¦II–Ltz/1=õÜõú¬®¡æÞË0Œ‹ ƒ®oh N«| tž£‚aPÒU«×¢IÁ—M›6qT[z.:¤·]º„ÏróÕ;­úsè÷ïC:i¾sàmܲá U¡—[!E«¯~ç$ï\~¾È"óã·­üZkׯ·Ï~×Ä1Á+ÛWc•T?¹ŸýÛôŸÖæoßgWû¼ žè<±7h†l.wëÁøË '×åH_K‹ßV2™7\¹råÊ•+ËÊi˜N:ƒòÐÏ‹¢î9ÂÙis>kŸ?ݽú]Çg¾]hñåñΜ¢68ç »?P„߉ËWý…²r¬-5Vn½ç¹xè縸€¨n‘ò¸¶Íq‚¤?K c¦$øE·3—‰Òus|óç› /Ñ'™ÛÞ@ôôTjá(}>ä%ìI#Ð¥õ íâUq6ScGX¨ÔáiR'Çx‚ɼkkGè¹\ nÔwL„gj;‚E ñ´Û½Ç^u?nEGÓÊæÀxC†jBqÇNÐÀ9hOßEcý¶þ3f뺢Eü ¼^ÌáÍeÊKÝepw6Öp˜s_™0"졌,))“'?Ú(Ñ›ÐNÀLwhw ÞÕ£qtRÜ‘+º¶Óg5ø|¡%±‡n©O·ÆØÀÕè9R«`CD”ñbï¼yóBsëҞˑïõ*½åZw™Ä £· ‡ð¸š @Yš3³çý)gç4ãIŠ›™•Ê¡:(wžæ“»,Üß‚àïóxæc1E=ݵqUqs&7ö+i)ÄqH‰Ó1M¡ˆ¢ÇGŒû6üÇ {Çánú¤ÇIx¶+Æ ÛtY¡Ó{×s¿x_Üü.~m¶£‘M\ƒµ>þøä•pøJ‚ùìþ2eǺóvDám5 =öN`àÓ¦¯´åÔ™&•(/,KB6³Õ‘I–Z7 Þ³iàj^JùszÝàˆÛØÈÜ_È!88¸bcìíí‰i20T†rcšxúù–’,9ö]ó®ê+|?ÚqبP cFœ}ð„£Cïiú†‰ ÆC6¦ÂCVÆÝkõ­›–Êóõíàæ#Àû\g¬‘¬P›ùýñ >’[šP/ÏgHït4©ßrJáêYÈuMÉ—2…¾.–V4hnÔI·Ð'Ãú@c— ‰umÝhRœ æX‰ñkKŒò!·”æ×Kó'ž!n~Ú‚¡EþJcÇŽ­Ø˜¸¸8`zñ •¡Ü˜&¦;äydOžºöÚ¶V ·¯µüø1‡x|48 Ú»¡w⌬Óž‰µ›?taÙ5K£½WéìÚ_[%ç}àÅo]Çõ6¢ˆ‚Ý>\G €OB)ßäÇL#Ùß&܃;£Ò½Ä;UëM³ÂØ€ýÕ]}ž÷“”Íènž–c?­ÓŒø&|Bø©êk¢¦`cMà3^bˆ,AD,ò’ÂÔ½ÇYô¾“FéEJæJ¼ĸK†_Cñ Êëżûj )xî¾ 4:xP^Zâç³[/jFP 90ÖËvø]ÿ¥~ìé‚,Õ8_¥â}õeeÙÌk“>uï2cÜ.=Z§Áä^™Î»r2®3•7/õeWâ‡áîÎ.†sV—õ´àÛ%ÉôäÀúòZ–î{.ØçÉ)²p°óÈžkì´´”ÌAžeË–8q‚þ§oî³ÐüzÉeÜ£e÷6Ù’’Ô–tAíÜyz‰­h'+ͤ㠴 Ë;A·ÆÚ´D¥ÉbmiÓ'`yÊ\-ך}’lµ 5Or¨ç4ï×SüúkեׄúÚ²²åx‡å–;¦;f¿¼=s܉6Sü:«s`õþ‘œAWÎLÕhÜ©¯Üºn”4Zôèm¯Ç¯8ydÞÐÃÃããÇááá:uòðð`æiÖiJíá#ÛÛ§TRm“‡……Íž=›þüüùó?nÏ/ËéçEÁ”#©è[‹VNÚEÎhй«z>®>Y#ÎÌ®Ÿ—JÇ+è¦YøºERÀÄØ Tÿ9¼wï^ÿ›IY¯ÏíÝ»wß~?Y’é€ißö¥H~Œn°xfsë êõ™ûÃ\–ÚÒ¦Ú—Ê{LBôõÐwѬ>Æô!)ÎËÌÌ‘?¾d@ÍthXÈ.•ð}Ýš˜¿³ù„v ¥“ò322² œƒ VVVêůBUƒ<²ÌÕÔÔüüüìììüüüÔÔÔ˜wÏë:”uB2hРeË–EFFFFF?~ÜÌÌ,77·¶Ù©¤*Þ#ȳ•ùõ øIÎ º %âVôv‘ß`\hÐ" %É$Ûök¢ì»Íí®}Œò€ëv-öœíª÷㙤ˆ<ÏÕ¾ñ_¢èC—67G_8élV^¹ ‰=é2ê¦ëSÿê2ÿþ}Í,BLŠq”û[n«‚”_„X5†Úƒ±±qÙg¸6êììسgO™pÊ”)pèС?fÖ/ EÞ‰-OI‚㨠ÆR¼©g)'0Œ[ôIã–< ÇqYÓF˜yßÉqŸèéîM•}bß¿¾íÜmºÇKÊôC«–øøøÿÔÊíõë— e¨…XXXÔ!§™œœÜ¶mÛ£GöíÛW^ž——×¢E‹C‡•’×r¤È[V´žf¥zp?t%Ÿfìx~OÌBù03£}úö4ÐPÞžÿ8Ìzš ‚ ÜÜÜ&Ož\Ö3 ‚C‡M™2%::Z (=[®6C?/̾%¨±îyµžð“+ííí™îy£-B¼fÍš‡Þ¼y³¼Õë\']Ö=¯Ã‹_0Tý–$Ãáþýû¾¾¾‘‘‘¬ßºmÛ¶-Zו{•¢(úf Ò„‡‡ÿiª%wšd®>CuæææfhhXŽ@ X·nÝÞ½{ëŠÓ„âç…éž30ÔêJ÷¼gÏž3fÌ>|xÅj¹¹¹¦¦¦ êêê5cØoòó=‚j¥&·×N¢¢¢>þýöí[5YUUÈ~±˜yš UÃ¥K—ÜÜÜ*{†aÇ?yòäÒ¥K«Ãª*„™§©€€3uc ¯ªp1ìO›ÀP jùa„wïÞU‡UUHÑAÚŒÚEk›–ÿŽwÏ•\娌a¨B©µaMzdù<&нTv›U 0NóßÉO›$?Ýy¡RÜ¿_~ÑÌÊ2~üøãÇ×f§ùcÁ&¦ù¯DIŸÈ\}†ªâÞ½{¿ã4ÝÜÜZ¶l¹cÇŽÚ< ²ü=‚ê>Ìzš 5̽{÷V­Zõ˧›˜˜´oß>((ÈÕÕµ ­ªZ˜yšÿfä÷’J¥“'O–J¥XIþ´ •æ_Д1`À€T‘EÕH•:MJzõFt)ÙÂ^½$ä)T¯…Éw%)Úw¬ò¿Þ&üýr Jœ•­ØfJ*R(W^M08 IDATÉ‚pww qww'B™S*Ëo4iš5kSæT Õ2O3|ç¨ù—´[uÙ­S¼u¢874àÃÇCÉ_f­Eªon©©Ü®Còâ¤é–¸]Æqä¥×˜¿ï&ZO>ì3²Q Ñ×N…$uêæmCKŒdÍ03(x·û´¦¿Å„_¿zþÈ¡cŸ`Rjl‰­Æ“úO[°ñAÌUÓæƒfÞEŸZ2í4vÀDÀ‘ ßlßÂÕ®·iÁ¼¢œó“¤Í¶?õÿ«²¶†®qÿ>ä ƒ‘&@Ö÷,¶àÁö­¼‰Çäŧ‹+ õñÔÃx,¬þà}ö»&îˆ ^Ù¾²Åý&Ùç·è{½goûŽõùŸâK$å~öoÓZ›¿}Ÿ]í_ð.x¢óÄÞ ²y`©*PS2™7\¹råÊ•+ËÊi˜N:C•ð›MHII¡?ÔBèçEÁ”#ÇpÅŠeå‘»lÊœ¼¾ Vc=¾h¬W„ïÃk­ä<¦TøiêákCcÜŒÕhÉ“¹]—kWzûCiaÌ´€¿è–2‰zý%Z)î[?d/±Ò” ½7EuY=?xV„LÒvñª8›©±‹#,Tjtf•¦ÅÆ´oÛÙ<™zª¤Ó<9ÆLæ][; @ÏåJPp£¾c"¹õ\—˜H%Ê|å9¦Ûˆå§4¬Wö6äË¥>“G¤s¬[ñ¸ÑÓ÷Sz+ѧV†äG%zÚÉ»ãBtí`³3KoÊ$y_÷]ÍÕôj¯*"W£çH­‚ iôaÆ‹½óæÍ ÍWÖ€JƒðØŠ"‘ïõ*½åZw™Ä £· ‡ð¸š ¤š’900Ô$UФ©ÍaMÙzšÅ4Åȶ/Ï~ë7ñxʾ§A$”y~ç•û=&zgm~!’Ï*tûÈzËÜt¶³›»ÕgšccaÖ­ YܧºlÇ)RrïÑO­lÖ­§}¶+Æ ÛtYæb‚’äZΜÖÍãYFÿ¦|6/;fØm5_ü D8Ž“E!TǺóvDám5 =öN`àÓ¦¯´åü™V˜(/,KB6³Õ‘I–Z7 Þ³iàj®ŒšÈ1V™ 88¸bcèY˜˜&Ãïsùòåaêæ}Ü.]ºVv¤ã'ó4ã¯ÌrùÇð†ÿrm6Z˜|×ÍuûÄ}wú›jÓ©Rüƒ×´)ÇžP v^™=°åëíÊ“e•ñbó¤Ãñ»Bîn èÞr³ËÜ¿bfû ÿ´ÙÌeq–‡‡ÇOMÜò¸ºÊû\g¬‘,s. ‚¥m6~´þÆUg¯Ì°&D_<Ã’ç…õ䡟€‡a¯ÈiuÒ-ô‰Å°þÐØåB¢ËïÔØïBŠSÀ+±?Ÿ%Æù«¤š’9Àرc+6&..˜^<Ão“››râĉ*ÉmàÀ3fÌÈÍÍ­k—Ó¤1q\íè×ÇÎ9ï‘¡óí'5YvaE3Y*ÊV/Ðp;bž¥@AZÍÆo>5ap4¼$ÔÜrÄðÙ“pÁ•˜î´‹[ïÅ‹JúI(å›ðKÊ(˜±ºCÏÅ«Éñ——Ht†O6QËO,îá›ð á'% ªnØXøŒ—˜÷“ "–%ÕØ˜¶29€o1î².R š—/_¶³³«*W'Ö$.w² ÊÖ]sæÞAHvC‰Q÷NhU"•c¸uûB…PŽk'}Ù¡F“n­êñ[L:ÜRõWdŒ¸,Qª‚9‰&[µðG> yÞ/;¬ž£ð\QšˆÅ­- ÃpÕZjqÐèç2 E\ÏÂõ»ê)©¦d 5F```UõÍijí®AJÎÓäÎ;t%¹_Б¹…]9åO¯IHŠ)ÌŠ$²×r¼§?ööß-~-‚f©Æyø*ï[ä…ÅE‘bÇÔ×Û{.Ý—žÂ¿×SÇq¡P%cš©/³¸µ%r‡pwv1œ³â¸¬§ßn,I– 'ÖWVMÉäX¶l™¬ë4vìXfž&CRµ}sšÚÜCWòÝslëå£}Úººíê~iY—ò”xT>¦)£àÛÓµs§^—ô»ï¿HóW'™·soäuè%¶¢}Èe!Ê¥Ëê¶næwÛ%fƒü¨«¡Â’1ͧ!ÉV ZÓÊÉ¡žÓ¼_Oñ 该òk–ü>ýmYÙr¼ÃrËÓ³_Þž9îD›)~Õ¹°zHÿHΠ+g¦V¬VA’<2oèááññãGzÑ-fž&CRµ}sšÚÜCWöÝsžf§s'ŽèkUÙnlŸÛ¶«[NÛ.oÔú×rLL+ø¶/EBÒ‡*õ˜MüT5tÛºtñ:¯"oŽr´ÍÍ͹ÅE¢¯‡¾‹fõ1¦Iq^ff¦ˆ¬¹¨¦ßÀ¼‘¾¼DÍthXÈ.•ð}Ýš˜¿³ù„v ¥“ò322² ªVAR‰¢‹QSSóóó³³³óóóSSScÞ=¯ÓÔ¶}Ï«¼oNSk{è4U³r{jØñÀÏÝfº•˜ƒ™x{ßÓÑ}¬5Ë;Kyü]ÚÜ}ᤳÙÏUåˆ=é2ê¦ëSÿJ ™¿ÿ¾fVô#Å8Êý¹Ûª@­‚$å!VF¡ö`ll\{Æ‚ªo÷ÝÚ¹¯o¯§)h3|b›Ò2í®»VQÔlÀ® ûgÅõ:ݽ©²ùû×·§oJÛr§Oí Û)ã1+VS2‡Š©•ÃP'¨Ž¾9M­í¡×¥õ41cÇó{bn¤Ê·‹3£}úö4ШVÃj-Ìzš ÕMPP³³s5eN÷Ðk›Ó¤ŸfcµÔX÷¼Z OHøÉ‹•öööL÷¼ÎQ{6V#ÂÀÀ ::ÚÈȨ:ò¯…=ôÝó?m Cµ@¿%ÉÀPM„‡‡›™™U“Ç„ZÙC§(ªh7J&ªUŠððð?mB äN“ÌÕgø5®_¿îèèX­E 4èêÕ«µÇi³ï9C£ötÏmmmwíÚÕµk×ê+âÛ·o­[·NIIAÑÚ²+ÝÒ¬-Ö000ü”Z2Oóû÷ï_¿~­î迉‰‰¾¾~TTTµ–ò 0N“áÿíg\ÔX‡O’©ô¢¢¢VÄ®€•ª«b[».kyÁÞֆ⪸¢bG±­{飼¢‚½7Š  ˆ(HŸšäý†a„™Qîó_rssÏI†œ{óÏ-eãÒ¥KnnnA”žõÇðòòŠˆˆ¨l+j¢Ö|šQœsçÎõìÙS†<==W­Zåïï¯[ê€4Mâ'CFUvg#yòòòjÖ¬™’’¢¯¯_zîJFÖ彞#? Z˜PùäÑ××oݺõµk×4`K}PÐD e@äÑY³RÖ=G ¿<.\ ј9OOÏR×nÑ?ÓØs®m4Š··â‚é„ 4ÓÙHž–-[¦¥¥}üø±V­Z3Z¥¬Teaâ­ Š¢´íÝ"9QQQÚvQ6´¾î¹Æ:ÉÀqÜÓÓ3""bÔ¨Q3ª¤i*Ai¸¤(Ji$ýyÑömFü|\¾|¹[·n6êáá¡ ²&ê§Y"ùùùL@‘.¿R ‘¿ôë#ÊDTTÔÂ… 5lÔÝÝÝßߟ¦i­ˆBš¦rx<S”6-µí]îÞ½ NNNêŸ"«©ýúõyóæ ØÙÙiØ®©©itttóæÍKÏ]™¨»FP¤x|¬ðWã |||ÊzŠlñÓ¡ÝîÚµk]»vÕŠiË—/kÅtqPÐD j¥­ éîî®õ I—¯Ÿfö›ìúù¸NLµRI07D¡iFQEæ|êáêÂ-ZÑP¢/©™†5kYøëƒK9 ]ë±e)¢¬'"k í[O•mZœ“+Ò74,SU&‘HÊ’½HKišõÑŠ Éàææ6räH‘HÄårµâC)š&Mæ’¸K.<¾¹z='nçÌ=ÙWV–a}ÇïÅIÏ]|ѳ{³2”Ÿzå)åìRSO!=7áÚc½ö«WÊòå|>¿¸šIQÔ‡ãþŽi|÷ZC&RL;=íéÂaK‡ß:ÙUVMfϘ:ÏeûÕIÍ =ÏÏ>·)ÌÍg ª•#ö›pô­óÔý;ǶRßa6›]z&9äë¤i"ÔD[‚&ƒ‰‰I“&MîÞ½Û¥K­8ÀPЦùxùçsâ²Ä²”GÇæþk¶ ¿àaš¤ÌÝo­2cñ†¯R ÞŸZvìAj©§âäñÞþ"~A0R”àââ²!%~ÞÔÞSÒ¤šë5I‘™3—ÜöÕnh·‘Q‰¹p?xðè¨â9¿½øôöÀä4—@¿zo7…ÇÓ’?~ʧ¤_¿óµ˜óYñû§Ÿ–ì<»>qóèÐÈRVøATM´øùX‹‚&ƒ»»û¥K—´è€Œƒfó¿6wg_ëÙ®Ûá9LÊÀ÷oM ]nÁ.›s`Ψ½ôá‹«±pˆ‰Ö¿½ßòR•¢öÓûmq5-hÓ”8!!!CBߢÇF·øaK–Éáî¿´³×ÎX·wªíïÞ{禮ž¶ºzÄì);ÉGKæü¯§ï†Ìƒ½M™u7…zµyɬY³fÍšµ`哼´ý³¾³çsžüy‚Ï×G ZÖoU˜s}ÏCÛ¦œÚ;øtœÆ®(- š ^^^W®\Ñ¢¥ôÓüúYP­†å¼—7®lmŠ}Ïc´`Aó‹±im i2ëÑ“x…³ìZ¶2!ãéíýó|—? ½|ªK*HÀcæöõƒÿœ;µûWÃð §ËO8±à¢ž¯_÷Ú ¼{(ië{™{¤@R‘@ `@ÓÉsß:ûÅN¾iË«àÁ Å5ͤˆå£·¾ >êœ`Ð~ÌŠ‘©ËB ¿p黎³.å5¤hZ*ƒ÷-êóûšÇ׃7~qÕ„­ßYïçôšÚeß¾2C²SÒ£ÏNž°Øqzؼ.Õ%‰q‹'wëýù¿!oú­XèW“[JÅ”³nݺ;v””g̘1Ó¦Mc¶‘¦‰(Z4œœœž?ž™™ibb¢-JÔ4ÅY‘]»Œïý׊•Szœ(èŠÿ_Ÿ'><4T’,()6zéã×=Í uFQFô?S'†]}gÑjoºfò™Û _t«Y³˜šøü‚ü4•?÷Ÿc5×Oeüùxk´ú¨ŽÕ Wï”X\>“Ï÷j:iMlÎÎNVþ4ôŸ]o,^Ñшóƒ÷EAÓeÝ2óH3‡ûÍŽŽyåèè€úWöO:ºlä…aÛÛ¤=ðÅ0–LX4­×ûàŠ‡^Óχþ·.dý#ÿéM>É€œ,1E榧§Nð-ª€4?ùøöàÌþf#|V8³oŸá_cÎör=;dì¤q#{š³J Œé™3g¦§§Ÿ:uªx†¾}ûΜ9SVO"MQV´+h2p¹Ü:\½zµÿþÚò¡Ä±çc×Ë»üÇŒ›âûåú¶1²tqö §Ó6=îlÃ6gÏž•?kfK{ùÝûGWNñ5ró ùßÕ ÇJÌ›9þ.¯è&ý7-šÕåˆgÁ˜ü˜ q–®ÓT_@o—êCžC'+ÈMŒ:zôNó¹K»ò°Ó¬M £õ‡‡?ê7dÙì‚Ùkž˜8ñpœ„Í$…ñÞZõð;z=èÉ‘°/R¾Bßîïíþ¿_=²éÄ·=ÌK›$ð   ììì«W¯Ê§»¹¹i}(¢BÐV?M­ š W®\ÑbÐdPþ,Ösyöš]ØKÛÂ$Zê;ÍrÐVw³‘Q,È—P…?¡L ” ^/ç·ë=c]ødoÇØ57JuBôíö){l¹ÍþþhÇ|˜0Sy˜·3ÏÛà6½%÷.ÕNù ÞÝܹ ’¤É<š2o(\ãŽóþÚáŸâí7ûêþ? ³ ÓÏ8»ÿM\83tLT×í¹Ëþó8~|Šòryö‡ÃoY€íÿü”æiâ6l«Û0u%ˆ5kÖøùùÝ¿ŸIi׮ݚ5k49½â—äâÅ‹šYßB5ƒ Ò–uºÔuÏ1ãÖ£Ûj^§ôÙú¡Ù™­me)‹\ŽÍ—å—…]„€¦$œ,“îgoL´5` ‘„¢)‘ 팒|™×{ ¸Î îh&Ë/r«ãòg)hš€[ð¤‚ø WåŠkš-\R…}øvôø—\!ib\K"‘ô]x°½”-‰>,É{qöXÖ¹Ÿ—éoW#œ¸Æ¦KÜÚµ^ü—ÅÛTõê÷gîJ-òÙgà’•Œ¸À·àJ$’ž"JI ù—#Ηê°|?M‚ BBB|||âããíííCBB‚Pèȉ4MD™‰D/^ Õ¶#àèèøíÛ·„„­8 îØsJúíÀ² ‹"ŒOÜØÖа°K`ðÝhyQsfK{Ïçó€_wmHáBH\6ŽáÜ’¬ä¼½<îIO8¿ÝÞâ§'×)´—ˆÉÂäÏRÐ4Ë’°¸µ+\•+ÞOÓÅÅ´e×uOn,›­mnxaÀ.§kaì‹áGžÇÅÅÅ=þ">Küï®S·N›Í~·Ú'Äu[RøtÚ‚øG×<ÎÝ»™7qÕŒZ†Lù[Çþù‰$ä;W¦¥¥­ºr§ƒqaA’sßÉuª:}0ò˜ššîÚµËßßùò妦¦Åó#MQ&®]»æàà`aa¡mGÃ0æ }ôèÑZq@­±çï¯ïàÒ~ywÏ彎†eëD­Rœ~eß?.n£¿8øœ9¿Ò„UDtkjÄÉz‘%Ÿ"¼K¹OÉYqY\Ó&èRI¤?ÙfP« ?õVÓD1Ko|޽ú䃙m[?ÿå‡öt4¬9uãªÅ½kð )6ÓÒÎø¦=ªez)€qC‡æß1c)‘9z|½¢È>‘•ssómÛ¶™››—»„n¢múܹsº3Yu·nÝ.\¸ ]”kšYÏoî?}ö¿ÿ.DÄþ˜³î o…~/ùi{|&œ‘OyûM䪞ÉWçöþ{òô…Ë÷Ŧö“ׇOé£dæ’æ£ê%ÿ{üèƒϵîêøxwÎ2énZJnD¤ØÏhÊl§Þœ?nU¬_Ø¡¦?:L¨øp ƒÿÒš¿9î›×:T¡È8¡9;jræÌ™3gΔžO#xyy͘1ƒ$IÍ+õ²Õ(•kš™ŸÂO?Íê3nÙÆªs J¤˜‰b·öõ­!Ÿ²ëÅc±P (>ŠÅ5M\ò4ß$pûÜn.MX˜rY­šÇè¼ ÙCÍÄ1WNm^ì“Ï1þ÷n JÌd'EI[?‰Ö~—Aós¾¥§§çäç x? „B¡ü ,%Í~É­Д+$Ðb±Ø=xU{3{±¸`¬”DB-ev)q ײqW}ü:€T"î±ñpÿšÆhˆ^0­`ð%Äæˆí%b±¸ÈO¾aúÄýE;QÒLYQ:ydȨ¤i"J#&&š5+ÛèÊÃÊÊÊÆÆæÎ;;v,=wE£JÓ´q¾è®òl~ÓnÝšÊ'´¹É·4)>—GíŽ#|­Ê[±ï»zoßRœãóû.i½8àÊ×}ýœ¶>GKói–ž|Pys|ž~§•^–ÆÌnýß6Þø­”2Õ„Ãáig²Ì6Ÿ>vw‚§Gd’AÍAX·1ËO°Øl6‹©÷~íÝg€„AíZ€Ôé5`¸uÁI;îFá8¡POöåÛB¿ˆú!Í~ëîJuªÓ2U¹òWHÓD”ƹsçz÷®¬Ž)å£{÷îÿý÷ŸV‚&ó¼48uaúUw×#OXsƒ‚Tø®gÛ1‹n]t®è^™ááá^^^t1(Š’ ói6POS —Ïd¦„)—ÏÁ”b\>¿˜ºL "ÕAíÑ£G>>>qqep)QwïÞÕ­ ¡5kÖÔ°Å:,\¸ÐËK‡D¦›7oN:õÑ£G¶[øz®aÃêÃ3w;¾þÉ…¹®Š_{b.,êùïá ˜ J#&MÓ8‡'×W§Ø\ž¬'2Æå±åz%ËbàñxÊz-cÌòê8¬–Oß3Ë·4¤¥¥ÅÆÆjwb¡â8;;'$$|úôÉÊÊJ“véRûiêÆí' üæMñC¾•¦Ç …BøIbÖƒ–J¥êŸ¢p-ºüë#´Îùóç»uë¦Ý),‹C„››Û¥K—þüóO ›Fk)‡Ëå2MK…Ïè íŊÈôHÓDT»víš8q¢¶½PBŸ>}Ž=ªù ‰Ö=WŽ,V*¤ëfc³¬ ×óŸM®{þäÉ“÷ïß÷ë×O3æÊ„··÷„ ²³³ŒŒJÏ]Ñ 5‚)®iþbPßÑöFè4¡¡¡cÇŽe±t±]eddäêê®I£hÝ󉌌Զ šýú¥|ýúõÔ©S¯^½Ò¶#%2pàÀ£G>\“F™çEw»!¬­­i¼ž/]ºôíÛ·*¦µÖ:ÙÙÙµk×NJJÒØº¬Ëz=G ~41¥RéÖ­['Mš¤[åF+oè (h"ˆ"œ|øÉ“'µÕ8¨XôôôNœ8áääÔ¬Y3wwÕ«—µ4MZšù0ÁÍIW–Š×|>_^͇cgg§1^¾| l6ŠÆn¤i"*–¨¨(f¢ ­¬!^IØØØ>|ø÷ß?zôh…K´jišï7~û‡ï$$¥—”3?õÊí”|ÅTZ")Ú>ËM¸vý‹°|#Uœ |Ý‘EÌŸ÷ãOItîÜùèÑ£¬¤Þͪ‚&)J˜¼ðŽƒmòÌ™3gΜù×Ô‘\Ú\Í)É)Nïí/âj"OO®ÐÓ½q}Ûz6õÛ{ Yì)“Nðó¦öž’&E Ô ZãöíÛ¿jÄdèÚµ+7#""*ªLZ~š‡' öÝpl‘³{r†§¨ÍvgUü”Û †~ôqâÚ?û÷Åg|Í nÍÏ}{íjxð´^SNnöuC×5ƒ‡.¾uvn›Šº˜Š¥¸¦)‹5é£f"MQIÐ4=yòäÍ›7ÿª“¡k×®'Ož2dˆ¯¯ïüùó+ä3W)šæíõ,Œ¤×lâܺu òS/ÌàlÜH1»lý¦]œ­˜œÒü¸©G“ÃbÚòùlø1eá‰g³ÏEOmaõœ<‰³¯ìÃ'…pqè0/ð]‹)ÉóØñtñÛ½RMS“0j&Ò4•DXXüþûïÚv¤Ò騱ãLJ víÚµüøÇ®’ÇžÓÒãËÆÌÜO‘97.œcÒžž=ÙÌ£÷åóç@œsûÚëq73‡Ro/“TÕÖÍìn{ѼÙßß#fæ¿]Ì8Æ]‡šæ-}ðeg'+HúÏ®7¯èh¤ÑØ„@ütüàºç Ó¦M‹=pà€f†ikKKˈˆˆ   6mÚ:t¨B>y)Ñ4)iÆÍg¦Ç"–âìë¾Óшû{`0³4ÇQ>̆8K×îÌ6MæìùœW»O×b¥ù…z»TòœÙÎMŒ:zôh¼@úãƒ@ ”"‰–,YÒªU«Ö­[ÇÆÆ¶mÛVÛi‚ ,XÖ¯_¿ù4¤z>MÃ¥»–‰³ïÊ—Rš–…B ´XvèIJ¾É =fW*ˆ—R´Is=ÕœA Ó¼mϰðÜûæ €ÎhvHÓDü2¤¥¥ÅÆÆÆÅÅ­_¿ÞÁÁáñãÇ•:4[—ñôôd> ÍŸ?ßÙÙÙÑÑ‘Ç㕵R4MBÂ%… ²ÖlNºèë±Ç€"3Á°»ìÄDiPߌ٥Øõ'æ‚ IDAT Ëy#⻨àLë¢DÝ馉ø‘H$>|ˆýúõ«W¯^¼x 7 íÖ­›¶}Ô2]»v=}úôÎ;wíÚõúõë ´nݺZµj––– 4°··¯[·.óÜ•Déói¼º×¯Ÿ/žž—²aö†ê²]+ñ5­ Î2í_yð øØ+œ%¡ýý]ôEDpj–~•BŽ9sæøûûË§äææ¾yóæÍ›7ÉÉÉÖÖÖvvvvvvtpp°°°Ð–«º‰‹‹‹‹‹ …ÂèèèÇgff¾yóæÂ… ÷ÐÀÀ ¤BT¿Æôõõ‹§êÛû‡­Í™¿rÛÜ¿þ§O`M87_dAŸ‚£Óæw:6mÉúëÞS:[ËN‰Û7¹ÿ†ä·ŽY°pÈŠËâš6)Ç5#USSS…++«=z¨ÓJBÈÃãñÚµk×®];ùDYk=>>^(TƒCÓtJJ ¨è§)ˆhZTâÑœ‡»C×ùO!h4Ü&9ì–`jAÓ²FÏ ³¯þ¾bxçwÓçõvic"þxãúÕ­'ÛN3”ˆ€È‹)õ§Ù2…¾8%äùè­»»™”Yb¨ ¦‰ÐYæÌ™Eç:’ÿ˜ŽÒ+$ÝÞÞ¾¤ü¥hš¢!Nš¼ÞÑÒ”Ëaá4E’R© ?÷í½ÃF¶# ø|°ë?!oI@6kl vÁ·ø)›.tp[±,ìÀ„ y$§vƒ–óþýï¿ `'E ;?‹B{Øòùà`‚ÌÌLšÃÓÍŽËå*ÌϦá \¦i2Èæ Ñ‘ûƒÐ:%õ:Bé•^ЦIpjFí =ûômFZŠP$&IŠŒ 6‡Ë×Ówè1cLÏ~LNži%­çÏ8›´¯_ᇹÖf0(‘8<¼H£÷GgèuZÙÕ¸àëJM·ën%y¡è¢@%/Ì¢Ô™²ORšt@¨@•¦iÓ¥ïÄ.j•2pëª-®S’{ž°æ«„s^¹¥ÂwƒÓCnUúºqåFiÐ|ùò%­©…Õ+ óÆkÀ.P‡ šOSÏyÿªç_}YÔ½µêŒNt ÝÝ‚Mê¬B' åÛz=Ò¼éééFFF Áiš„¶©à5‚êzÍñðMN.5ç_b¯Òàp8òM< …n›C¡¥‰4MB» uÏ•#ªŠ¯­¦-O4i@¨-¬¦¥SÛN!­¤ˆH$Rø $¿­IOì¢_ Ð.hÝså°X,ºd4é -×I¦‰@h¤i*'22RÛ. ÝÍ"x{{kÛ¡Ó M@ Ô‚‰–X²=+Á€º!D@A@ ÊÒ4¢  ~šQÐë9@”4„& ¥]6¦ò@š&¨\>ß?î¿8ôÞëz5vñµrÞï?uc iš %–b¦ä-c,.¡Ž@hœ„#¿ùÌu¿6ò°g~üµÉ>“‡±ª^Ø]Û~•ŸŸ:âëÉQ{ÿèæR¿®m}ÛÆ¦ÞHÈ•J½sd¸‡Kýzõœ<¦ÑÄ¢„nptÂRºæ¸ÃþêV3nâÜûྶ’+Ѷ_åÍŠ!çÃ÷?çñ]G¾üðžm¸·|º K““pÄuÈ ©Ç_‘O⎬·oV¿À ÚöÐ4™·:6ÝÁ„,¥z›Å5YTÐ¥Ÿx "Ò4+†ËóCÙ '†LPÛ#`}Í½Ž½W¼N[fkr`\mù¿]S{´ðܹ£_‡áãïN|Ö\_£+#šG”u#SJÙ6âÉż­;æF²à·Úôì@šfÅÐoïmgðù³F‰%y@pù<µþy†Ãú‘²û\§CPMÖÉU×3Žõ¯«-o ‘› ö&òq¦Ÿu'AüóFôz^A`,K½‚ˆIIR—ü9UßÒ=°¾±8÷^¦”jØÂ´0#¡ïlÌùrç«–E 4‹ß„¤|b²ˆ2¨o %*4+˜ô賃;t>#v9¹Ý€À(ñW¨Ç+²|}‘ó6GK"šƒ­ßÔ„…¿xöM–BSù—3…ÕªiÑ«išÉͰùVœë1yéöñ=9)$Xx›™+0*¬ŸD¤~6ºóˆªÀ¶ÕíxÎfvS®þ&ÅBº˜ÿ¼ÿÿHÓ¬0®H´5â¾»½‘,‘ÏkmÂÂã_ ù došÊÊÕëhî<¢*Ð3$pM§I¬n4Ê=+.jöÔcÍ}B;U7*ýL]½žW ©×ÇìøzøÚAùˆ €±ƒÚ[Ä.Û'KH¹˜&Åæt«¥im oí}þôRÞƒí=[œ¿¥ñ°¥áA?÷¢29s{ÚÃ7M¼ú73-5'MåoÛqÜÏ÷YÊK‘¶n],X?kÕÌöµÛœy^Öò‰zÖή-Ìò’ÃÝ;Mª5zyAM;a–þàÐs?ùÿ QV(‰gó´íE€½yóFÅašÌ;îŸÉ!ÁÍôXÑ¡cg ?й¤ÌOt[R?ôøH{…ôÌø™ƒÿöºxÈ 2_l·ÖêÀÆNû¼Œ»2 Ãos.]j§Oµjì¸åal;C%£ Ÿ#ŸQNNV¥¼Ìæ%Ý|ÂoÓ±šv~•¡=»§KGúÔìºj×]8hBÄGÀpNõšµëÖ«×¾ÇC»|Ñ&’Ù}æ\¼±E+ÍÕSW¯©8Êo3ò`øÈ_¦¦E ª2ª–ð%ÅÉ“f_ï±å6Ó_†cì|8¸›Ç`¿ÞOY± úÐд(òÚýÛ7#àùºaëüÔ£6ôïÜ1W">wîIHI¿9~{ˆ÷À¤ÿÎÓ´àÒË:Ý»³ŽïhN“9];¶a÷FDÚp ¸³`xr¿-®¦\~Iþ’ßîßµ}hZü9)ñÝ«{>nÛ;ÿ±oç?Vl‚oÑc£ÛÊaK^^Ю‚oR"&ñ  *hžœ5äC'»XÉRêÜ4qoKï‘KτͫÉ!ÃõÆúù¸qÙæ”Üìø´1knéZOóñó3ekñÑÒŒŒ ýµïlYGSâ÷y\kVî·LÑË3oì|B¶´¤Ÿì3úÙ¥Ó‹˜Â¥ùqã%…Å8Ê xõ]]]¿ïùN›p¯·ë >£›Ýß;ÚÌ^ø¶ÅØ7³ØñÐzî¢R(±Ÿæƒ­cgœÃÝ™% ä'$»çhÊð®]^m=¸¾} >1ã¯I’ìÌå$·fȺ†3—÷¬ƒ&FÑÒlB!IÓb@`ÞþÛï4¦î;îaÀ>ŸOò ãðù|iÞÓ™Ž6ýý|è°ÆçöœŽø7dö”ýüC%,éŽ×|Ïz9÷?Ytl"s)þß—Vn3d»LÑa÷Ñ4}~oŠØµ…1ôï`1qË;¾G=¦Ý:qâN«ùÁî¨G$âbóæÍÚv¡Ê1~üxÙ¶’×XRš~ï1l¿z¥îLJ BR"xá;~Åú; Þî™·û-v{wT£ýÑõy, D9t×;»@ìêk,Ûé]@œ•K)¶ï~£VýV®ÞñÝÁI–]F°ø636œ~²¨û½%û_/P^N&ÙöÚ‰ù$0a¦úb8m ËI@ óvæy›âÜÀ¦÷±äÞå¸?„®cll¬m iذéÍ{ž=ûü99K*Š¢hš&‚$) Ãhš h ÀÇ0œ¦)Çh·²6tleÙº™eB‚ªþÞ ¾õp×ùj}GnÐsû§ÿN}žrîéÝ·Ô­ ¥¾Jõj驾qÎ=’¦ëê3»zµôHá»Rï‚jPMŽÐò-XXXT¶'ê‚ëmÛó(å=k؈v.šs1#phЦ%$)%i IÒlœ`Ç “Ò4†¤T’•%º{óù¾½Ñqq_~ïÛ§uk„¥bÐ,uèƒM·ü%Ëö%1×/<‹ÝfïÞÝ·nÝ‘?#x.N­i2; ¨¦IŠY666iw7½¬óG@ó_oÚ×mÞÈú,±Ð}ͬÙ]‡˜:þmNŠeeWgãŸ?f •jqM/lÇ0b”EÁPî¬dζøña­¥Öä¿|íŠÐ¿³ïøõê.£Nn$Ëp#"Å~FSf;õæüq«býÂõ0-sIÿ»U§vEè,:1e\œˆc_e¤'K¿Ñy|.›ÇÁ8l†Ð4Ð4†a†`€aŽáгh©Tš'”ÅbR‚áfz<ûjŸ}síÌåpt´ÓK A“Ý<¶nÙêv£"Ãþ”ä> {`cm!øGN­¦PhJ¸pá‚m²p¦È‡×oáF†é÷¾àì‚¥p–©sW׸ǷŸ=fw·{޺듻'­7áIµ‘7ƒ¤ç⡞NÝîo?¾ÑɘS»×¸¼Ÿ%£k°qàÕ¨ceüléÒgÎ6«niem»fÿü>›Èºƒ’¢„?‰B= >%Q✌Œ %×½^mTÔäU§vEè,zz¥hýš!“äµù&z¬ÏcC®TŠç‹ÅbI>0/‹4Ð4M“4MEÑ4 8Žaà8NS4Ñ8ŽsY„DJŠEÒŒ<¡õÕŠŸý6Ã0‘ Š£\ÓÌŠxlÄäÕÿó`‰…bºÚ‡£ïe ÄôˆY{;ó¨"gQ" c¹¸¸ìI¿½ô’ÉðdûªC‰éùì·©öLÊŽ‘?ô8òÚâ>zý$òÍóU“sÚϺä?P*H?;ì,–N¼#6lØðiÌóŒÔ78‹,£h¼ @Ó@RFÒEÓ8,'p¦' Î440  Ã%OýðÁ’•íå5@ËV uûiVeTÔrU§vEè,:4`ø{÷í}û‚¡Uíšuëš™U§h Ç 4ÐR’"iZBQ€a`ޱ0ŒÀq’¢˜>Ë`i)©)‰IɪéëùøŒÐö5•‚®Üz]CÅ?eÕ©]: •t„?}þ8{öì§OIqñ1‹Ê 4]ÐKšiR‡¦iǹ\®‰‰IÓº6={þVéîþ0HÓTŽêš¼ ֮͠æóø÷ßW¶'šD,çää$%%ݽ{[Û¾(iš¥SjM^ÕjW„fPçyTs&$D%^Ï•£š\÷kWQœŠ\÷@ ~y¦‰@ eišQt¨ã@è>(h"D@š&@”¤i"D@¯çQPÐD ˆ2€4M(HÓD ˆ2€^Ï¢   ‰@ e@=M“&$}®ecC¨QbfÜåh¡}çÖ6?ì@èjÍr$ξU¯ñ '’,Ø¥·LÏõn¹Äbõíná@è2Ÿ&%•R²í¯3½WµJ¥ò9 Vû PH *)óÿæ)éÐö¥ƒJµ®âíí­"ÿÓ…ƒ&D| g›Ù7k7tì$—z†¥*·¹Y1ž'|Õ,ÿG \F›[ÔmæòÇ„qÎÖúeµ‹@TJZš”ô[Oïaò)4™÷®I3GVљȞ=o@`)QCÛû<26*qE0QvVûÃ÷9ר8·5D@@@³fÍôõõõôô‚ÈÏÏÏÍÍ}öìYIqóAt³!Êy·|׿qVßÛæmk«¶ÅD–.]ºP%•J)Šºw兀/w'tù ×áí=hJœ‘–pqÿšƒ7DÛÝò2+}IËrš{ØçåýÙ¥þã†|îv96hiFÚÇ«ÇÖíÂvÜýÏÝ ­oŒÐ>Ê4Mš(ÛËÿ¼sÔ¬Ô“'W? B1eXköƒ+ÃK²±ÓµÕM±ð§ëºdÉ’† ׯ_Çq Ã0 {ÿþ½ƒƒC@@Àüùó‹Ÿâ`_Ù|K;Ûêõ¸õŒêË¿|ù2´oß^ $IQEQÍš5‹‰‰ ÷ððPz–˜¤qvõ 4rpîè~»y‹µû^vòm¨úÒÊmަ¥eúສ\WÃ&NÝßµm¾|[¬Ë”&ê›F * åý4Ûµk'Ûþöz[ÏA>EŒÍçó¥ùé_²Äò‡øÕk˜°p6‡ÇJúÏ®7¯èXrËThРAÍš5mmm™ˆÉ¬dgg 4X²d‰Š÷tZÀ.Ïç)_&H…¶†aLp!IÒÑÑ1::úòåËJÛecî|QR*¦À¨ž©ê¾·?bÃÊб÷Ç®«ˆ¡º\âS.Žú#tÒ5Máç© #88X>±Ý¸i®ÆŠïJNŒö újWKÙÍzóÚñâÓí Låóä&F=z§ùÜ¥:4ÀÌÌÌÞÞž —õë×€—/_’$imm••ÑÑÑŽŽŽbKþíUY˜¿5zùòeI¶HQÒãÇi©èkêÛó{Ö y‡t/Eøs»®Bhé½ÓËf¯žÐàÇýA ~œÒƒæç+Ÿõj7—_Òv߆Ÿ‰Åƒ&Ôt]±É‰Ù>Ü©iD± 6½%÷.··ÅÐÐi]25jôäÉ’$¹Ü ×JŠ,̆Š…gnQ’Ü„w D½® &[ªÑÃ¡ÜæÊJ¹ 姆yz†Ó”(ýóç¶=Gï<¥«ú„Ð Jï§y'âSó…Û&t²’¥ ©F‰e' ÅÐ@ S4Y˜.¦ „ò'Ô4)Š’H$²õxD"‘T*‹ Tˆ’.J(”€H(Ð¥¿ž@~~¾Bd‘mÈ(nKLÒú–~'N  ÉwÂ'ñ:5éÈα¥4Ëm®¬šf¹ qM=/îûîÉÍðC»>äòšÖB“$ t…R$*iþ‹ÕIy»œjñù²·i*MBÕ52äóÙ̾LÓäqð¼ä[áá©Lú³<1Áåñù|yMó'B$A’dll¬ƒƒÜ¿Ÿyìóóó™<%]T™4M`±X²€‚aI’L:£–dKAÓlÚeèº1;ûþ»Ž?í`%™+“¦ù#†nmgçÎÎê;¤]GG§¨o¨}pÈÄÃcö­|˜<ÍÁLõ¥!•ò±ç g¦u[þiå–MÞŽæLÊ×Ç¡oy’™™…ñ-&­[ëbZøù8%j¨G@÷ç·þT($nõ_K&ç „\£Úó6¯sÔ¯!›š¦ø0J&bVTg#yŠ7d"KeØÒ¤9 _Q©”8aG>Eëájµ’hi~®mhÀ®PÇtˆèèh…”’žö^¾;J*äì¶1kËÚÚZE9êÌÃR!æ4f¨LæˆÊC­YŽÁ€º¿!D@k!DøIg¹D 퀂&@”¤i"D@š&@”ôzŽ@ eM(HÓD ˆ2€4M(èõ@ ÊÀO9ó¡@ñ‰” _øÝ´RQºZ*Ò4¿Ì*ê4M3«ߨjÈß[·n)}Ò™›ÆLuÊÌvJË¡iuæ&0÷ïßWzÓ¦‰øEàóùt1dQ@ÛÞi…ð§ôIçóùTQhš&IR;ª4Mc¦ú¦¡×sÄ/‚ÒXYÅM¥^>¥ Ù Ô¤·:‚üÿOIyPÐDü"¨ˆ˜UöùWØ(ŽŠˆY5oEQ†É¯–Z¤i"~˜ÿdù(Y•[L ò±Oé“. ‹W3ÌëyÕ¼oòïæPÂMCš&â‘ç˜U¹ÑE«¥O:ÇcV eî³ÁŽª©iÊ‚¦Š›†úi"ª÷ÿ™ŸY©&„iQÇÃc¼Áç¨{ŸŠ5sh‰¤hüÏKºu;]øãæ*ZRî +H»ñ Uɵ/0ïã»é¢òÚ)'(h"ªlIüðò,Š•pnͩǟÕÉ™°Ùš+ªó\:ž"&`u/7ÿÙÅ3âOÓ‡Šù…gÌÙ>ƒz·kÞÂÑ¡¹[ŸÑ[OÅ0é?Îà9_¥:Ô*|t*tÔÐ~ÛµoëÔeàÿÛñRþhìJ¿ÁcŽÈv)É×F2nmYp ”8uŽOüµ«(àåÏ÷™¯áËGš&âAM³ºgÍÔà˜”~Ä»·o_¿~õͼ÷”þ6reP_S…Õ,õŠ7w–û•ÑKV•fÒÓ DIDATNéI¨\¤U"¥(‰D¢"ÏüÙs–D¹V7áæfgæEÅ3ß[2&å·•Nú8sèÐüáËÎ%Ÿ=oÆ’–üœ÷7®Ÿ[=wг´C!£šÆ]—wZ7zåƒã3[7¤qM“ ›1póm¡Ïœ¹ ;47¦?¾zxéÜa—oì^Ø·À¯Ÿ’?e‘$ 4•·nìàÿÒš†ž`4“xÅøOÝ—9°H’,µ@¶i× ǯ{rhz‹²{«¤i"ª*4ÍÿŽì‹OLLLLLx—õöÖ`_[[Ûz¶õmÛë³Ù…KO ¾é9üåãë ŠÞËGÝF+GÌ’SýT`Yzâ©E—øcþ×­¶,…ÍÂh*ïýËè„Ĥ¤¤D† ²Ñ¡ý¼ïkb‹iÚ˜Ça³Ù8ÎbËûRÁ‹™'S6ÝiΤ§DÎ:=õÈíñŽfP»Aëαä‘©ÿ-çâÐvúÜg$M¿VŸG(¸­aM3éüŒ×Æï¿ê×ÄL¼|æ5«-ùmú?K{uþ»]uÀ1À‚Z²}ÆÐ)ÃŽ¯i¨Ïú~í¯üO§„D9¡f-'ÍLð˜“8ùb=®âå—u4MÔåñë“óJlQËÅ«í°º|9rþ´GÉÆ3홫DÔ.”$÷}ü«÷ŸøîM˜£}g]´oøÜ²µ,?M æ° ö€üOG-LHLLLHÈÞõýë®Mݺumllš´ãÅß¾Zg˜,b€˜¢De,íÞIµá­ "éÎÀ+fMf˜¸LÛ{ äu`’¿úñ—.–å¼AÄŽ5÷LÍùà °r]ø§å¥ÿœþ;ürÉÔÑ…Ãv>·Ù~b­,bÀ—ë¥æCZè³Õ/cäÒ×8?äé×uíkTÚ•MįÏèÅ‹eÛ®ÆìÓéÂqVúß(FÙÏLýðê嫚Dþĩ㾽OJ§lêê?ɸòä†%» š6íÝA®Øäˆ9qD‡]®5€Ð¯aײ³G¿º™¡SBÚ]‹˜ÊäÉK>庩aøÂ!Ì4™CÑ´)«Ä—ü¸­/ktšð=sî¡´üÆt,–«È鿵«6sËKÐjФÉì3éÂFÕ¨®í«ï= 0hF¬½üBÎî+û›ie¿ØñÊÂů¬vkc>wÛkÐXÐDš&â×@Í~š^Vzag¯Ô0HñâÅË—/âßfGÞ¹œŸ¸â·Ñ×5nTׂŸÜ°GðL§z5M/ôZ_g™9PeßE™÷Gξâ¾ê?J$8ßeÔp€´‡|™¦)É;pÉÄíÌä çÆàlóê%‘P%•|ÏüÌë§Õ3ºÇ¦ L~7d¥‚RŠ6in¨Z$5jaš·ó¹DÒA!]“š¦TLÑ´iscFš,➣1uúCŽDª‡c ùŸw/¼ìh…}ÙuöMð †ò9Ÿ÷7dJP³@0naš¿û%Iº”Éa¥ MQ…(IÓ” “<Ÿ˜˜ð!áÝ»7‰Ÿ3‰Û¢<[ÚÛ5æÖÏÞ¾ÃæÙÜ»ï ›üܦEöÛ}þ»n»(Ž ”äëRŸé¸ëÜUžuZŒl€3g=Ý$°ñÏ&Õä3óq Ú0ä4Mr½ßÔ„&óØlv¢HªWÇÉ@ൠˉÏg·Q↠£:ú¤(±¸«šÔ4q½Ú8†}{–E´Rlñe>þ†³Œ Ù,À1`ñì>büls÷‰£5¿0¼‰‰,g¢ˆÔ³6`M5 k>)JdÎúA¦‰@`øõ§oííì»·÷´·o`&^×s\Íà©JóVsj•öïS€æ±{Ït ØÙÚ@I¨Êy5Ýof4Ç3bõp•Ò¡íÜÃ{(Eí2f]¸•ë? ‰7¶ú§{\]Ø,9Ä×/}qÂÄÛŒwãØ5j«pŠ„öwó¢¯"‚c¥Ò—Jà úšó#/=„Q ]y®o9R¶Ë1r¶×cóäõÃïNãëpisCs¨‡Hÿ**k¢t1ÎÖœ4úi"~qNÍÍk—ÿ5qLo¯.ëY™Zõdœ.éÍS¯Ú€ü/ÇÀeÑ‘ÐÁv GIqFÔ‘^ÞÓ=tl‰q hßĹEŸ0Rœ²èrò„Í 3ÓÂý ‡MíÚ;‡ùXÔЀ“ó*G–aÂl—Œç+·Üþ$_΋óœÜGÈú'f½ÈâšyÏÕ £f8}{±bStº|bÊ•ûÓòº-è[<Çé;ÔN›ì”Cü Ø9ñ…×®fÙ¯²¹&еò@š&âA (šòÛ²l¿•zû[^;Ž’RkG"áQf¾£>dZÚ›ˆ#{Î]¸zý‘ØÄöK÷ûýÖJÐ:Yf6‚/Ç×ü[£Ž™%Éû–ñí[æ7 ¿¿ÿäF4•¿zä èâß݈`4J àÞô>Oõ]÷ž_PE3‰‡ÖIÙs_2¹ XõX3ýú°µÿëž8ivö­L$É·nEmÚq¶•ïVcš”HH¸u5µÞD;ÝSþ@ òœ@ PÐ4d*pY5M°î¶bÊ¥¡c fÌíÝÁÑ@šþ8òÈògú.š×Æüû<• {÷gOß±á¡×è?þv<±¤4\'uÿcjb#õ €»×>×g_!ã>Õ¹iHÓDü"p8ºdäsö2çÿ—.q1QÒ‰ú×Ð;“!ie\ä¹0d½úfè°pë\O§Æ%÷0­?wåL£›±_fåJ)àñôôôõª›sX,V~ê•›Ïc«‡³¾7Q[8×û`8`ÓÜÁò’êô“üOícÁ.h¦ú®:Ö¶ÓúµMß²4dײkþWÈ1‚¾P¤(iOšx¥{m«ˆÚFz¯\žc±äg6bæø‘EOUשbÔšާ6†9¶ò£׳±k0jùþQd9xÖuj™`Ø÷þRͶlÿ¿E{7Þé8ÉÅÂÚË'Õò¯Ò¡Õ ®½ô)ñÇ}i⥭deV*n–œ\žQe„NÞ­[·’"¦ÂóÿþÐî÷¸ÕÒWZÔ§Ëž7êã^ÂQÍpx¤ëÕ{¶ö¬­x€ #aàýÑ‘¾Wú]ÞÒG!¯ü¸sçŽÒå.ÜÜÜä#¦|c³-Í"Ö)‘ã²ËÇŽùu‹ê·#ô·Zjøá„ß„ÈÞç7ô*¯§E­ÈñøñcåË]Tˆ%Bë”.‹?ÿuûÔ-ùõÓÒ}¨e¹^N+>kwõöOñØcÅ)ª‰bnQßHчY!KÏw/îpI m…< -MuÎR ŒÃ*×]ìµüï½ÿþä¶Ý²Øµ/%Ì ÍX|ʳ¢~/u®išˆ_¦Ë![¨žƒ8m[òôÊûoËï¢:gäî+·¶àaJ;rÊ_¾Ò']$)T3 ^à¨!D@š&@”¤i"D@¯çQPÐD ˆ2€4M(ÿ¹cjÏV?ß`IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/lgndpath.png0000644000175000017500000021677113362603467016734 00000000000000‰PNG  IHDR°go`!szTXtRaw profile type exifxÚÍ›Yv7“„ß±Š^æa9Ïéôòû Ô½)Ñúe·Z²IªX…rˆŒHàšý?ÿ}Ìñ§kML¥æ–³åOl±ùÎÕ>úýêl¼_ïŸa­]ýrÝäòú…ç#ßÿ5V~ ¶¹Îο®Ïç»ë\OŸjûõ‹ñõý5¯¯¼®¿^kƒ{^`_›þ(ø×›ãk ϲlnµ|^Â|Ý^¿¿fà£/1ŸSv%ò5z[Jnü\½»-MÔÏ×P¯þ·yßꙓßÁË׬¦jèºÆWþíu¥ñs ‰¯ZÞoyc ?··]ÿçw37ï©¿\þÅ¥?ýäê? ÿáis ú¾%üä¡üñýÛë.ý¸n^¼ßï?¿9ç×OþëõsÜW+¼½¦ÿÏYõœý¬®ÇÌ’ókQï%ºg5d­ûTæoáÿd«Œ­¿¿•”˜ÄÑ"ȧkÎã²ã¢[®;æq¿O7™bôÛ¾{?}pÓp±âŒæçuwÔ_w|ÁÍ çû0 ‡ÀUÿ1w_Ûî릫¼x¹jˆÇ`ŽGþOÍŸÜtŽÊ9Ù׻ǿ^™Æ,ä9çŒu܆GÜy5]¿ÿþüG~ x0]3WØíи$÷#¸ÂutàÆÄ÷'ð\Y¯03HLÆ<`³ Éeg‹÷¦8‡!+êL݇ènq)ùÅ$} !ã²€wóLq÷VŸüs ¼™—M(ø†DÄY1&â§ÄJ õRL)åTRM-õ²2,ç’…¨½„K*¹”RK+ÝÔPcM5×Rkmµ7߈›ùØjk­w^Ú¹ótç†Þ‡aÄ‘FeÔÑFŸÞÌ0ãL3Ï2ël³/¿Â"W^eÕÕVßnJ;î´ó.»î¶û!ÔN8ñ¤“O9õ4sú‡×^nýåïßðš{yÍ_OéÆòá5®–ò N’|†Ç|t8¼È.ïå3[]Œ^ž“ÏlódEòL2É9ËÉcx0nçÓq¾ûá¹dBþwüfp„ÿ7A]k„<³Å±žˆ?³Ôçyq ág5%žÊŠð8Ñ—'« @–) ÍMæÐC•ò¿ƒl3Ö›r ˆzÉC8Q±¶rwL ròî%†“+· o¡‘Q÷ZDSÕÈ‹<Ùcn×GiÍk^äVÓw³®À<)SÃcd=pqŒAPÍ s¡YYž¼a pªôMVÎ eÙ‰é7Œl|ÀWq0‹ŒVžy‚¹Ç^…+$!sΈÀÈ„rû=l†zJ L¨Ô€f¤#jMO"!ï¼)<×Þá`°’ëqÿØmœÉt5¼vžÀdâY@mm½"€fõÑaî'96œŸ:Eñ ïPÙg_Kº~_ÀõŠ×øHÏ¡Fz%5~[×çíÓX7iÇÇh’áŸ'üuq»jn7*‰ñåC©e½"ãY±1z ÑëhÑîàž’Ã0§ÎP-ÔÑ5âߪ8ᓸHe³x0ÊÊ5ÒAx*êº&_¨,ð¬IxÙ¾±pGÿPÆÁ0¤Ìm š’šä‹ˆ‹í…QCk j²¿ùþN\Ê=dzÒQ<µrì]¶9+Yò¿ÏkØR¯jÊ›áIwcUb5Ši”‚ލðJVŽW½}ŠMÙOtÊÂø0?âóJÊI£rzŒªwÕ¡@‰gßè?0~Þ p`AÉØHçÛ‹81^´Aw¡C²¢‚ºËh©™»«ïœÛœ€@dvdh`¶_D¦Ê+Ù”ÉÙŽ²Ö ¶®Y8ׄ#k¶`A6A2F–!Ì••/pÁÈê t6¨7ÅBaÃÛš5E'(×xGÕœ´¦è‰âSBØQ>Ñä:2© ±È<Õ¨bÚºÛK ÷ªohsgš%”ƒ‡gWÀqN%@[ºðh‡ :ÂO–àBÍ¢`t!ñÏpøDŒn¢›cpû%•Ÿ½m†‹È À7^KªÃP·¾Éס’(˜7¢C{&oºÈ' º¾ÁìÑöÙúÝÖ$6E¥9ª ´‘'ˆÃå<´{@®ñÀ,TAˆ.÷ˆ) åŠèÖ >Lè0ÌZ‰)ÂÂbçléhob·˜R„ëdŒ¡H5©V&ÔàŤÐnÇÖ©i´9Ž(¿ýe (ŒðêUXÁ §Ì`ö€7»×¿.ýäŸ5Ál"‘DUà)0[X¦[p‹·'Q7(AŽ]rÕD5G2ñÖXL+‹BRÞ£ þ.~úÅ{?Faó›QbÏQ H°1arGïÜkŽÝEü€“C³å„òö:)  o¥eèÀu’[¹'#¨VàÜ·A´Gps¤“é!6÷ ïÔe+åÈØü®•bU0n³Àm~«Ú´©¿ü@†®ÎÛd?›‹Z’öÇ“2Hú2.ÃÃE€’ÚÏn¯’û’(^ghb°m jc#ÒH­­¹´{µ(ûÀ·Zàš]ìzÒ”N¢þ8Db« –©¡AËUHßTì³ÕPX˜ó¨ÖN¥[)L‚ÒIÇ£ìaPEí ´È°»¡¶Üž „Ö$Êà9ÒÒyTÊ«)¿QƸ¼I†/ᤥXìÄ0jƒÛ8«ôMö«x{ZàH¤ÝN[À_s‚Ä\M >×HX¢¿ xË¥V’à0Rô<\w ÔjT³Tòñ ˜½QsjwZ¿q¦6—NLÊƈPl wÊØjá Ïþ™ƒ¼±žå¶Q9âžðG¯©;”©ð`USoÅÙ¡g5@î•"©g ÊrŒ"Ø‹c¸§‰ó¼zR)kQ^O'¨ÿ¥Ó(©Ù‡ÄÛÎØììNÅÜ)qíáÏF®CAáõÝ}!`Zjû…º_¾ƒ2ŒäKˆ7OŒZ(°êSL»ÕÒÑk8Î׆ºíYµÍYÌ *D¡SÄ:<•¿ò€«C vá¢ä§#(  úsê¶IaH­©†ºÆµ¡…aZ\À7òPQãE'½zÇD:N”Àär{4à¡¢'Ëÿ!öâ‘X€—‘8±’~&¯ý¤aǼY$C;qv’&À)b # Hû©Ó§…·WWsbÞ&½½šà–¦s(çC-¼|Îio I‹¨A^MÚÛàïD‡ë`D"gê×$Üü‘?!¿WsCx/¿Ã=fk @ ÂÅäµ C]¨/U¯su9‚ ÊXI"ã/xµ¦¬½¸ëÄ©ø`M@CÆÄ¢¨Nh–Á‡Ó–.AÒ„ N1lŽ0]ª¸U3ê_pÚ-µEAƉ~]Ù‚›Mâvu€ j”î½ ÝMsÅC.ßDA "Õ•;€¦ûµI€¼At<_‹Vhç_ÝD6®’Hî! ‚¢¾(†ø£Njwůý•6 ú^ùõN¯Œð1ß+"©‹ÛLüš+·a(é~–ìC~ø7ß0OÞ¿(‡¿{zTµSXÆVà8@—ÔN‹zHÙ×áŒѾ®¸Ö¨à,n#{Â|®ç2bMÄ5F À¯2Øø¯ˆ9 ~ºu 'IÆÂÆÜ4»ÐÚÔÛÔª¡&é'Ë€>àHõ9n©Ë­<šSµùTÅ®a6JÎÜ K5×dˆ›SçÀÄâ ’vödæ}Q݃\z¦$‚M»B$f÷†Õ”hψ7'kNÐÿ‘P™iÂ~B] _®9ub…ʪ¶Ó‰ ä`öԦëóø<ìɶí€Þd9 ÖæåÑŽ6á*x¡mÜ_Q®:¯]n†ô: ¤–¨úÛ—½¡°j(䓇'ÕŠU\Æu eZÅB—kn‚|ÐÕØÛÀÇ Ž%ŠÔÂ?îñ_PÃr¼£¿Y„·¯:‚ Y·XVƒkaJ²+g„Ò Y…â¨íŒ\QKê)¡S[/j/eŒÁöS¢˜Gs|íÚÉ©`¨?Ú¼ŒÏ‰Z%®`P`2d˜r~3Úy·©H²P"€¾²)€j¯(Ï \Gægmò65qC˜é^ÕLßFr iûãö¨Ü¢²NÈ@)_F¾ýU¶{º6ê[6[æø¶h~mþ³> ùµød“ƒ‹;[ôéQ©¾Ð:³E%ݿЬE UjOGÔ ë~‚ïR¦À×—\÷4PÆz«ð‘m#&w—e³E,PBöj[,ÝSBj‹•8–ºèêØBË"Y c•[ akÏP çtê²\§ ¸ŽÀ´&[!—öN xK˜=êéd=©#EY_:"qZ'^hÚ›cX|2v™O 7„·"G®= 2*¹¢Ç/xQ'Å«H…&‚ˆÏEˆ§Ã(èéÍ2YgeFîGÖæ¼}ÂYãdǶŸpT€iŒ°R†Ô$€!g±@kúiе"þåèÞ)ƒ7ê'óÊo ÈLÚ{˜á®]ÕÓL›u„ek?6¦Èå*îu¬«b‡AûƒøT;œMGš¨—³'ôW)央`ž”Z³²àÇ*òM†tát’æéy3´‚“ˆP ¹£3¢E]oˆhA¡¡ m“»ódÓþÍpè¼)ãñ_? êËpð¾Ôs¼¼˜D¸hl–a…¾ïã2‹©[ñ‡¢óyàVÁÙNçiòøò3Cu¨°mÓÑLnûvSeóÎRÊ‚ÕF*4“'ÂÐÑ:Âû“Úþ=7ÂÇQÛˆ¬¢^æ¥Êõªc³Ú÷U çkÓé´~¡¦@nÇÖQ½µj?Æü>‡ qöÙA mÅ1x‘C!Dá tYƇdçvcj×{—±Ú" )?olHçëèn#¨Ÿas·9ßsP[ Réð6Ähá5~« ´ijMS†D! `!A»"a{PËé™O:ê ŒRMÃ¥2ŒP£¯£i™¥lH<*.íÝhxmeœ¬Ód%pyF8ÐSÕ¶"dV‹ Ô˪ ¨m b@‚$BôRRýî¯Q*j@ÙRÀ@”çÑ–z%×$Z§oîu 6ª62KýÛƒh óo ¢1Ì¿1ˆÆ0o/ã_h6g¨@¯{väV8bïþxH‰g0 p]‡¦žNŽQÍãÕ±ðƒº–°L´~Óáðœ ú^îf9ñpÛô1AÅŸj¿˜Êû¥÷•]§r>¯µ¼3D#ºŸ†jÖýÑ0°“ѵ…­3ð‡˜)ÄóiæÕ« jux²ŒmÛ»W»ÚÝKd¤öŸ“TêÑ:’¥„ðëjõvÔWï!ÍG³ß…€‹$-H)&¬lýõ>ó§7þÅ}PÒ?i Ä^Jn¯­i bÔÅ jfö9^_<Ü\¦^DÃŽ¸ïµ` …¥žDµ4îv)Éé•ò,„€tiUmB¾«+ÚÎü•vÛÆk‰=;ë)¤.—#߯ùYÚb¤ð@‰s’@©4n‘‘muªJÞ‰Hy(4fЙ)ø£V¢†ƒÙHoRñ`\I[Ö‹jÀ³3=å’>M‚ÜD(Ã1o/àm¤0Ä¡)P’® »Î»_®3æóOnæÕøÁ=KÿG¼Ÿ7w€(Õ]‘Ùm"êYêù Ý1¸ªsbª?TöÉ|+ŽK™7Í4Å?½DjŸ¬ÒÑ¥‹ïKÒ‚¬éAÒÎÝ>»ç¸pl ªS¢ŽFzyÒ·\ðBV˜£N”(?à€ÂD`ášu'Ú¤Åç J$*›öqtŒIU°…<™¤OS * zƒ¸ sG–ã=U¥º§ôÁÊ¢Ï#Í—Øû8ò>BÉ%o¿SÑ>Êßú…ùû|ÿ óþMŒ_÷`ÕB}=Èщ¡»÷¹$‰>Õ#œ–zb%£ÎÐ*Ò t§HY}f@Ÿz€R ªS›ðarÒM*„x€HQ9é8^ëjtI’»Ïªýì¶“”Þj:htb€¹¶ð!u'ŸÔC„«:>gäú4šÛéc–m,}.·ÃÄÙ„ñ>cAš™Ú`ØÀHÝA}¾'¨âÂÔæ¸·E^ÜÞ¼SÓò M¨ÏÛI6U¤ 8 7f*&·{Ú ÞØÔ<„œÛtà_:Ý9ÔïŸÂv ŠvXµEôñrýŸ<õÍCæ=õÍCæ=õÍCæÓS^ŸJÔ§=§ZhKêMh£Ž‘À P—8”ç¼}xšƒªÚþÒ§WI>÷›[þìS×÷ýÇ¿ûÝü§àr`•ôȵˆ^ÄÀ~>iCCPICC profile8­TMHa~vÖÌ~ЩˆŠ-$HÜZw´µÊÌLÊ]É"ZfgöwÆevW݈èè!:DÐM:u ¬.A<A×ÀS§Ž2H‚íù~rU” šá÷y¿÷}¿ï þMÞv‹u!ÀõJþHÿ¹Ðøµë¡­±ͤ6„-»X辌MŸ‹þ>,r=[x1xüñò¶˜_?>1¿˜ÝNªhvâv»à—ˆÇ‰g§K¿·ØYË!þ.||!¡O*Ü)pFá‹ûñ‘^âÄ»2 çN*|[`;ë»Ä÷ˆ[×a~ã¹È︞ÀˆO¸©’[Hón¾lëšE·;SÞØ¨ÈCÚ¾¤^Ä1ÄYnì›—¾qd‘C!àciJy¤(+mšÚ””…-„ xDÓü†`P¡Gæ)Q'¼‹DBg“çèãQs {¹~Ši3ªtK{ªÕå›@ÓRµú³ã °å{=Dý[F_Õâs€Ó´5x5ÝÑFŽnxy«¦sžsŸ¹}Ë·VvÙ0Í¿Éj?øÅçIƒ«¤¤#wƒ ÿaöIߌqrCœeIî'gW”äì’ŽkR¹åàv““x#8+Îy\Ëw´ý!ùvò9òÃä ¢pò¯Úþ‹¼ÍÖ©¼s€¹ ‘§™OKœ” žd¾Ìb”ÈÑGû)Áª®já$¿&¢¬¢“Ø”ëvQŠE©3©"›$ÙŒHK¿ßäš|-%Y×н¨¹L›%ç]–÷Úß´þZd†®ŒrBQ¹¢zk>¾ì,ÁÙDä»Y›è¤sŸŠô1eO1úFÖ¬¥þMÞJ.Sv¾>×j¿Š^3Fnò~FWù%ùç+ËSÙ:äz"cdž^í%º÷=ü‰! QB‹n¼bKGD¾¾¾µ­@› pHYs.#.#x¥?vtIMEâ  - ¸üÎñtEXtCommentCreated with GIMPW IDATxÚìÝuxgÚÇñï̑䜸'B‚S\‹©SêT¶Þ.õn•–ºÛ²¥Þm·þ¶ÔK–ÅÝ]!B„¸?3óþ‘ „(i‘û³W¯kÉñgì7÷<Ï3 ˜ä &ô{ðÁo·Ûí Š¢˜EA!„Bˆ¿ša†¡¹Ýî]=öØk“&MZ ä~HÚgee=кuëá~¿]×Ñu]ZN!„BümTUEUUÌf3ÙÙÙ3ÓÓÓ_¶(ÀЬ¬¬Ç‡{½^i)!„Bq̱Z­äææÎLOOÊtÿý÷;vì ^¯Wú !„Bˆc’¦iDFF¦UUUmR*++w˜L¦4i!„Bq,S¯×›¥¸\.¦iVi!„Bq¬3™L³a–ÆÔuìì,ŠŠ ‘¾±'«ÕJll))i¨ª* "„h>¿Î?­ã‡Å;)®tIƒœDZ…ÙÓ?•[Ï9‹¹ñãŒäÉ!Ë!†aXͺ®7Ú÷5;;‹êêjúôéÍf“Ö<‰¸\.6lXGvviiéÒ BˆñÆOëønYçžv*‘¡rœ9™”U¹ønÎ*îÛ É!âprˆ®ëŠRSSc4öâÅ‹н{O4M“)µN2{¦¬X³fýû”B´ˆÓ&L¥oŸ>ìªVpûä8s2 ´¨$†,]ºŒYÏŸ‡äq¸9Ä|°{½^YiNR{–¹\²B´¤âJyÕàöiÒ'—OcW•Úd×É!’CšÊ!æ¦Þ@Ód§r²’e/„øK‚ŒWÂÉÉÊÙŒe/Ç"É!G`…Bˆ–dH!Ž@“Ö0d×"„¢¬f„äq´¬BÑ¢Eš@q´¬œù!NZº†³ú'ï²mЂܫ[Ž3BÖqôÈ,õBÑ×ì'=âLnù¦ˆC5ñoçóÇã™;q7<üRòÃýŒ<ýžQ%ÕÆÆÊÉòŸáGóyÑÆ7Ð}Nü~}¿¿kh^G#?qþ<ûpV;ñMû*°:9¿½ÎGÕ£y袘ŽéæÑÈüõ}EœÏý¢3íëh>Åbª}®áÓÁl6¢cPµöÞ_•ÄåWö'f¿247N—ňÕTûN†kß0ÐóþÁˆD‹¬ÕB4—#?ü6 jy¨, ¯á'ëû§¸ùµÁyÌÈ»xbl**.§mõ7|6wI.¥0»”ТŸø÷™hTìØ€Ûk°ùûyp¶˜H?÷nnèÚô¾À[Īé¿2k]z0 pöYýH¶`µÜ:Åè•ë)Û¼”šJAA*.‡‚)¶7‘z` س^ùðn›‚×>†à”èºõÂgÇTª+"‰í6 í$M{ÇlV+dÁK°C{.Ÿß÷ãÞæî>*YÓ?ayüŒM*g[u8í“Ãð.y‡ K;óÄmƒ7Šøã½˜S¬ïݧDõÿ·ŽHDÕËXôö¼¶¨{÷kxú®!Ä™šŸ ̓ÛåÅo $Èf9 ·œHyÁüwlÐFu«·—â‚Z0|æþòÿWÙ‡ËÏëG²ýHŠÍ:¥›ç³<éL.ïw˜¯,ù‰w¬`ø›9=\Á¿ánzÓÌ}¯_C§&R»–?¿»ƒaO#ÞäG«k3ÇöY|òÉTfo,A 0á÷@XÆ&»„;_,bgr\ƒÃÐñÎÄš|&ï^ÉÇ_0«òä ¯ÇnØ]8’O_˜ÎúÑ£ëR‡NÑÜŸX’<–7“üÛÌ(&Sm?x¥.K (f¢Z§Ò¦Õ"¾ÌëÀé×0åé×ùÝ>ŽŸ:“X¿—¤G_ÂüâCL|4›ï¾‚1–&²‚ßë!ùêwùøº Lè8‹71û‹·yý¡õä?úcS-`œ8y¡å¬o /^3‰ù“ÙŠ5ÀŠ>w!ïþw !Ö°hïB‎´jä„@/ú…GÊæâ·o¡w³ªÞ*‘]Æ0áís¹rÎǼòö3ŒŸ9˜Û&ÜÀ Võ²ÆŽyŸóyÕ5Œì¿_5À¨ýŸ·œìµ;Y¿~=k×®g}V%ö”.ôêÝ‘xóRÖëZƒ€[§¼geÝÿßÑ2§óC^?îbÇí¯K¯z!Ó>üÇ™ÏóêihŽbv;lq­0üþÚ>U?m/Kä?²à¼v “*¬ÍÚE­}—ë'üNܵoñ¯š¹üò[!æ@ÕF­†m‹æ³ 0ün\^+þ·ì °¶×pçé‹™ðX¶~Ë›¼$º(Ý­ádÅ'O±â€O<ÄÌ¿•³rÐÃGqÃõýhe©=Xv¾ô&Λ~ŸÌ›É²Ûû3ô¹5ü ;HÇUÀ˜«Ïƾr,󰧈ï­qòÓ´|¬ç`âàŸ¹nG,&Õ¨ë'«£ÏÁÄû7%1õÛ|~,=¹;B»ë‡†–r·^¼ _me búqëµ§¢i”þ†Ú PûoÃï&ëןÙÆîG'Sjµ‘´„7[X×ï^Á¤†a«ZÆ;6“yïc\Ù1°ñ¬€ (þ*vï.Â(¦x]÷É–Û¹ó£YœúðhZ©'N^hù.ÖÁ<ñóÙØÌ(µµs¼K^bÌ30áÝ»éc®íÑ^»P½8*ø‹£1mik]LÎnÞ‰ ¾šòr²ÉÎÉegö.”îWð~ ú{h^U^…È~×2iÀ9,œ¶‰ˆèýÊ»ZËWUÒu\Ç}‡ÝMqÖ&Ö¬[Ë‚n¶Ï~†‡âÛÒ½g/N½b ÷ôéD’ÍÀ³ûwÃàSÛ`ÚÿB˜®c ¢ªÍß2—,ÅÓÿ6ÚÚ¾joÑrîHã¼û’ñÖxê}Šæ÷7ÛþàÞ Mùˆù«ª:,TF= q$”z_|5CbÔŨX>…wç”ï÷Ü0ÞxÃ?ì©»±ÅŸk!_VÚñ+Á ¾í9®é²o7ë_ùwüwmÓìêd똻w¡s`ý½u];£LßÁÖ]C3L'DsŸ¨µEÅÍ™¥ü<ÏÃ7Ã4|L_UÄ5i“i°S­k÷:<¦Søà®öÌýqSŠtètìžú²xòü{‘ÍëEîFæ˜ó®ŸôµîW,fÊï6Æ=| qz =bŠÉ*tá÷­á½‰3Hú׿8#ÞŒ5*…d×ZÖÍ ¾¿æÃ]ã'þŒsh÷Í\VVŒâôHå„É -_5<ÔT”PSï½t5ˆPÏ. ‹J( lú座ŠÂ¼l²s¶QÄNMz˜ÕET©Q´NK!=5ŽªÍËðœrÊ~UÐ=»GŸ«Šr%ˆg Àïrá¯÷$׺™Ì*ïÃ-=¬µ!ºj!/ßý&Kˆ§c×®„™I»òU>¼>¼¼^/^wÅN'ë?ùŒÕ2>ÅÀد‡½á×ðaÆlnXumXթܵGX* ör¶e–ÑæôÖèú¾÷òçç’ÒŽÔ`ú¡‡a§M»0>ËÌÆ?´‹Lò+Ä‘ÐKYøñ$6šJ–=µê|²ŠÌDEšP*ƒ8eèÔß¿bqY (*Kÿ7‘µõ7DŸï!¶c£²‚J]ÁAÃîi&""ÃPŒ***uà °'hBS£#iS]ΫÕFcMI»¢¢H5ûȪ{<(­;oŽLaÝÏùü/WC¡ÛzÕð“ú·xk\ªRw6æËcMEQj¯àB]ÅÕ¨;]«ŸÌDÛÊÉ*‹åôn^-†ä4ÅWL„ÉF«äTÒ“T ݇/¤u7^_ãY¡ös¨{£A±ËO›ðBvi{úQžyÁü·ì¡‚B 56SíÐ!°‰¥^ÈO/>Åo®$ÒÒR‰I !;ö2^¹s(‰v¿ß¿j!ÏÏ^O‡ö‡¸žføq;ý ÿæÏá§/çc;ûYzY t”°þÜþÆpžI AõÕ0ûÙÙ|„“²’ÒzÕ]âùïòÊìp®üÏ0Â4/ûß±×p9p™ìØ›:ÆèEÌ|ã²Î‹{z–SZf':¼á 4¯¿½Ö¦F|Ô[Qâ"qdWà6 XJ°BÁQ)–‘·ßÉY‰jƒm«dî[¼ðsqƒ¿Uüñn˜´¢®ÂVÁÒ/¾Äl5£ª¡´<€Œ`£|³g2ð:®ïHÖ_°¬ ·Ñ »ÒXÕÄßP0™œ±Äl6~ü'ÐíáOÔ £ÅˆÅU‰Ã°7ú §›" ¶ù0œ` Ѿ‘åóyjZ)î§`‘‰.mŠAùú_øüózí\òtèÜœ—‡tåúv⦾áë;X¶½nÃ6ªÈõìfóäÇY±§ƒª)‘Óo¹šAag…&if¬V/þ+/´xV÷¹pº½{qù¼^¼ÕÕ —°yÅ ÂÃt|>ßÞÿÔ„^ ïY•ÆMú’ë?>¿Ê™»™=§_M)E5àfÛ—ÿÇòöqm”q8§«†ƒ SÞ⛪ÓxòüÖ蚯îÉ„Ýî¥bw1~¼º±ßAͪ÷yäô~ð%ÆF{qùl'­ª”ŠðpBëq{÷Ôõª±5;ØZL×6f t4ÍŒ £A»›lvLN'NÝÀ8ä ¦ƒª¢è:Z£Õh!Ä¡wZE̘ü3=âÔ?QVí9†³»—²Ùd£|ÕfÊ[bLë|;?—Ms¦±©Þ³Ýë·¡œß…íÛJÉ)]@æ5]èjkì#ìØUÓ…Ÿú=f œ5. lØO ©´NÔ ¬€³×À°¸¼4¯;M©k¼¹™|67oý–ËÞÜ»}L'y!âØ­ÀÖØ5§³^”2Üøz¿÷TE÷¼ÄØS™tþö½é²û;¼W]Å Cê¶-ï?:“Äó®âô¸º³ÅJD¨rЬ°ÿFÕàÝÃm#È^¿=ÿ¼ÐÂX?k?¸›§g»0X °X°Z­X5*µ2vMû™â+«•«‹5€ðÀNõ7qe»qìY&ñÉDçe‘£õ§½RÁš¯^çõÅiÜõR?‚tÍ.Jè嬞2™Ïäò®£³ê­7a°Žæ¯ˆ:àðBh‹yì•HÚ&T»µFƒdQV6îij‰S6‹ÍfmB_®V@ !<ØIŽC£þý%L‰)$W/d[±NǸCŸŽ;ª¨!!ؤú*Ä‘Qã8óž8/ÙÔp{9™Ç§6¬²%$U“Ç6=*™¶ÐAÛ3®cxRK¿ýžezÝng.ÏÝ;ìùçÄk ¯jd<ñVØ´+‡|Ò÷löF 9¹e¦N$ÅH¥¹3Áj•œ°pZWïfkdÔ~?¹ÃDRµÁ.o½)ý53~Í'ê yï’¸ì;JzœÜq蘥Ъ×®º aß2ò/b×?4íwûÐ {T2Ë&ó‰õR&ŒH$\µ“EÉO“YÕ÷nÆ÷ F÷ùÐôƳB“‘§"‡ÕIœ¯žPy¡…+°fúÞû óU÷޼3 ÷‘7®yâ_æÑ–}£ò н5T:}ïÒbRH®œNnµN»0;ÑÏåé+“¬WânVzÕ(ß:—¯?ý’ßKÚqãKr~¼‡š&:¥™,ø|¾}J4%‚Ö1U®ƒ”|õ|–-É!cX{=£K½mjà+˜É;_åÑï¶ûˆÑ 4¢II1±0§­Gâ¾Õ2ºÃÒ?ã‡_71òêN4ÝQÂC^N1II˜¤+Ä‘Ñ ™öÒ¿˜Öèñj¿-Ð_H~‘NX—Xì¹™¨qI$Tl"¼Ëé ÑÿÔ mûu¡jÙJŠQ0 3®¸—+Úüó:Óû”@~_>›ß6]Â-u#¹´üYüºÎ‡)µ=O¤y`OЕV¦1¯8óÛýÈW«zš‹Iü¥8·-âô;î r{›´½EºÚöðºùlj±—]Ã[»ßàºeý JŠ8iåËX¬©Osëìz3‹Š|­èxÀØ—z ®ëÞð/|<‹µ‘££.æó©9$ÜÏ“W»+Ò9epkþ7ù=æ<}3Â8XV`ßUâ†}`½lŸù9Ý/¤g`ý18Ç^0·ôöTQP¹ÿŸu‚B4¶íΣ¤ô0F¿™h·‹y„YIéÓÅ[‰»‰®š»œ‚œlÙ¸–åK–°"G¡ý×ñÖ‹£IÑ+› ¯ ŸÏîE«É97™Ô=}Q ?^ßžŸRW†ßw:ÅöŸ?æ»Ýýø×àHد.løªØ¾ì'>útUCfb+š§v@FÇÞ)úy=Åç&»g­Ô£9ëæKùã×yÞ~7ŸÛ¸@ðQ]X†Kèžçz¶°jS}.ŒF‘ø*ÄáåVK›!œ{vÕÁÏ(Ú…9¨q›4¡ïÎ&Ûe")%–ƒCŒy+>»—»Šwáí|.­äÑe«I9íL—üšÏÿÃg=ŸåÊöÁªDrÚegó+¾á³‡ï¡ìÜ!¤› Y jöGÇfÁìG×k ÞÒ2ÿÎÌ«·ÜÅ?dñòvÿIY–8v×Ú)Î,ö ‚ƒƒP©»Y'‹¢¢ £+f,†Ž®ë¸\n0›P ½® ª'б­Áö¯žåµ­½™8éTÝçà “IÃïVH¿âŸô¼ý=¾ÝÒ‘´ 8HVÐ1[¶O™ÈÕ?ˆ‹j—•Ä£¹còôµ×P³w¼Î‰‘þ’;q5rÞApˆ—Ó…n‡µ3Nî}éÿ7hLР{ùbd(Ñá>· —«”Ýîæÿ.-°w½ÿ·•ì"¯Ì‰¦˜0›-X¬…„fÓq”W×N£DÒõœñ¼r{oÚ(Työ}ŽÛ«oéLd›NôìÅ]Ae¥«A¥G£—_“À¿>ŸÉF“°g¶ OÞ˜áÜûÚ¹<à­ ¤Â‹%$‚¨`Š¢rÜŽ5|1µ”³îN¸ß‹_‰‡UI‰êy.çu oÆþH!´s *`êp!Ý]Aëöż „Ñwìùœn²rÁ5a|zùã|à2P’éÖ)ŽØwñÊD•ÇN¢{|S£ˆ-$þ'¯ º–šÒ2ª ;QQ¡œ€!OØÔ)Ë)æ±÷‹±Zˆ ·ÃOù·.Öøõ« üº&¯ˆë'Ô[æ1=ˆ Àðãóù ÷{&<<•Ò'±’mËX÷Ö8þúòçsŒ9ÐŽYwáöê` %6ÚŽæ3°˜½”•ãÆBpD(&ŸÍdÃnTQ\Y{C"¿Ûƒ€UÕjê»ñ¨A„›ðºu‚,¸KËØ3ÔÆ„ÅïÄ]WE=XVPTªª š®ØÇ¼…òBKi*‡4`ÓÓÛÊÖõ—3a Á_RˆÃˆµ9¿·%šØ`UÕ¾£v™iûöm`…-`£2zKCœÄJ3—7`墨&C«WRP”ýªÆŠŠª(€^ïÆ &‹ü>ö¯u)ŠŠ¢Öޝiºø|Y¡óBKi*‡¢ Ü䯧ã¬(ÇhÃêך7B׈]©¡²Jn;(„8¾ºìµÄñ™C Moäû°‚7:ŧ߫ü÷6ë'AV8ÁòÂßÔVb³ÀïÓg+Â/çBˆã2 ÈqFÈúñ—d…,/bYq„B´]®ô É!âhX9óBÑ’ä8#dý-`åÌX!D ©° É!âèXÙ±!„hÉ€"Ç!ë‡8ŠÖjµâ÷û1™LÒJ'!MócµHC!ZL«0¿Åd‘Æ8éæ#&܆äq$9ä 666žììDGÇ(Aædâv{())"%¥4†¢ÅŒéŸÆ¿oÁ™ŒjµKƒœDt¯oY—jäq$9ä 6%%•’’bÖ­[…Óé”Ö<‰ØíA´mÛŽ””Ti !D‹¹åœÎøªŠøî¹ì.¯–9‰ÄF†péðîÜrNg$‡ˆ#É!½—B!„Ç"Uš@!„BH€B!„¢…˜5M“VB!„ÇO€u¹\Ò B!„âø °ÕÕ•Ò B!„âø °¿üò£´‚B!„8n(……2–B!„8nÈ,B!„B¬B!„`…B!„+„B!$À !„BÑ‚Ì{þÏʕ˥5„ØOÏž½ü[¶!„âï?.››:X q2;XX•íD!„ø{ËÒ…@!„BW$À !„B °B!„B´³4âïfùù»(++Åçó”m`±XˆŒŒ"!!EQd¥B °BˆcY~þ.<}ûÀf³”màr¹Ø°aùù»HLL’•B!Žz€5\lõYIg1º}¯è¸*+Ñì[¤±…+++¥G^¸Ý.œNÇIÙªªÒ¶m;V¯^)V!þl€ÕªóÉ*r¢7°•Ìûé+Vœ’Bš)²á ”`ÚĬz!?>õ—OfdþgÌÈö7ýaŠÎç\ÅÈdÓž¢jÍW¼»¢5ÿ¸z1{þ¬ûp»½x5´a5Õûjέ|û¿9„^p £%5 q<ðù|hš†®ë'mìùí'k !„8ŠÖ fÑ»Üõ~iÉá ŸliCÀæoykó~/±tåš'.§[ý'+&“ÚÑѦÛ~y¥­.áòžæ~2 ßiW32Y¬Äí«çj»~å…7·pêcÖ…W 'çù?ªQƒB°›5œ¨ƒ¹è›K IDATÚ+9#=ÅÞ–Ó‡Ìå¾ç?"ú¹ëé,}É„8hš&m m „G#ÀÖ=©Ý<ùÄhÂrã??ZwóiÄ®û˜{ŠâžϦµ¾‰/^^Bòø«^½%;ز+‡§Ò¬-ÇTµ%·aPX­ãb'›·ø(óùðçne“SA ïA׈º‰ôb¦¿û úyÏpfÂ¾Š¬»ÆIÂ%/ñÆåi˜ÝUÀÒ/_ååG_ÁüꃌŠR îv7u¼›7¾È›×uÄ*ËY!„â„qÓhé”­›Ç¢ ¡ Îr *ñ m`ÁÆ*Lveïs+7üƧŸ}ËÂ]U¬úñ#>þb*?­1è4h ½ZžÑ‡¡CzÑ&4”6½1$ÝÃòy[(¯»‚èÏœÆ79=¹è´Ø¾¤R¯×­j‹§ÿ?Æ36j-3–T``£Ûg6ë;æV²”…8†!ÿ²¿Bˆ£`õRÌß‚îõà4ÛÒÕ«Ùá-¡ Ø¿÷m[ ½™çîA‚zôPî¼¾?á¶HR3ÚÒ:ÌŒ=:•vé­‰´Z‰LΠmëˆz•R?Ûæ/ÂÝûTº6ã»)QÄDÃádÏWScú3(q=sVTïýþõü÷Öxä—Ýè²ì…B!ŽK‡ìB°g`góü—N»¨/xuz7 Ûó„S2ü~t³Óá¼È³‰žü”š~§¾ðf÷»‡Fì¹Z±ßTuª—šJ^£ñmTµdi‘éêš]5Ü”î*¦F?ðùeó¾àíµÝˆM4^/|*j0­#±ÕýMÛ9•_¬äºW®§«t¯ƒ*§­?¾ÃÛUãèfÇ (¦@BB¯Í…BüV§¤¤œ°wóàNæMÿ•µ±Ú9_—긾$í^ÀÏ¿¨ »b­Uþâ^c¹ã J#‡pÉð™,/ !5¤‰«ÚÀªÝ­éBX°‹\GcaW%nèxž½<õ”š*jpˆTQÄ_H§`ã2Vevdí+<ÙNŸöчˆ´’żþäW„Üú<×µ·®ÜÕ,ʬ¤©è§ï^IJ¤ xõ‚^˜ üLød¾ƒ àÀ©êŒÊLºí]Vùj‹ÏåF·Ø0×nDÁÃî烛»cþ;§«Ówòû»²ø€«9Ž¢`qóáë«´‰bïÃM^DG¥œ¢R-ßÌÂvþ³t«^η+Bém|ÁåÐ*ÒŽªÚˆä;{ø[ WEaç1ùå‹H•Ë6BqœX£š‚'±}c1KÉË+dOïQ½ÄîƒÂ¼<\ûÍ(é`Âv çê„grí#>WUUn§ ‹ÝŽR´’ŸW™0ú++°DD àòj,©­M,Ê.D|„—û=äæ”Öš}õ! ¯Ófµa3ËÑH´D¸ª`Íš\ì>¿ý”}@Àrl%«Í-|ùðP쇊+7|Ë‹/}OÅÀñT[˾÷ËYÁŒ94Ý«»šêü©|<½†ð è|Wí6ÑÈTuJØpýtxÝÇæñùÝ÷°þ¬·yztØ~Ýy”£>]]³+°j®{ån®Û„ ͇O30ôb¾»ÿŸÌöÿ>'jß7UÍXUÕë¾aâë+ð[ñÈݽö!ó’îgH¸Kï[ùøé –‹wõ‘Õ0.ºBq¼XÏ66ì §íe‘„v>‡›:ï{È·h3wÇqñõ—“ÞH))ãÂ’¡çó%´y%©9¿ðÔS‹éýôãœ_ͬÌ@Î7€e<Çšž·óÈU=‰RkŸJ¯Lþm »/I&îH²¦gË7…ÓëÂø}Ø¿Ž7oz𼯤 ⥬8úùµ`¿gvâª7ᬨý×0?ëß»•GÊhîEwÙÜ)ïðÎô*z\û4NÝ{T¢ÞÀ³ñ&¾å¼tÕ+lÌìÉÈ!w2±Wíº¿gªº›'Äá¶P7]ݽß1÷‚Œ ÿsUØæâòRµáG¾XleÄØ”}ò/&üRA€UEQL°ý&Î~¯î=ý´Î7ñÁÄá„*`ív1ã’æóu»Aį›ÂK™ý¹ûÖdL³Á¿þîºmjƒ¶0jòð™A¬B?Öµn1«L§pSÀF–.õ4¸$çÏ,Esê¬[¾Œ’úÇ-ÅJl‡®¤†( Ü%+¿àùÉó‰¼êÎŽU!ÏÓÛqõ“wò᳓¹ÿÕxîöĘœÁ©ÿ÷ÓvœÉµ‡;äÄ lÁ¯,ÅËm¤çšø‹U,šòåƒoc€© ‡NPƒd¨Q^ZMXt‡Šzº#e¿}Çgß-¤¼ÍÙÜúï‹”p„_«˜b"ýÇŽáÌuï6Y;UÝ?›7UÝAÔNW÷9sVT3bDhíïò¯ç¿w¾BîÙÏòÄY1-r¢¨—¬gÚ,;=ÏëÙj&êœgøöž^ûèäM¹,³ìý†Á·]ÆŒû_eÂ<ÎÀ»¿âŠ`NÁøönÐí÷ê}î™)«¶BGVÇáò“0tIÛgóÉâŠýæN ä”ËýµáË”PúEw!5¤^pôå0{V>½ïyŽ Œï¹ë–•xÝ%T‡_H˜ jDw®}âA‚_ý‰e…8;Q[w®¼üWîý`£ž8—$sígž6ñ N;Ô»f%¹›‘wNbý£§¹;w}úµ,uÑ‘Š’ïòÖÚÜ0)…å¯Ý¹í9ý¼±\0²±€–OV®NRïÄFû¿Þr²Ö¯dÁ¼9ÌZ”‰H™¯/¾’þbœ”wÇ6²íi\Soc8Ì©êž`Þtu‡5–ª¢¨& t*gÿ›«×8k‰¯*-mDíMjÿ‚'r8ç¶ÿŒ÷ÃäÖsì|öÛ{¬*²`¸JÈÎÊj‚ý%. öÜdáÀ¯ñõwSùøÿ>kò«^vÉÅ\vÉE²‰!Ä_`U¢‡ÜÁ §š1›OáÉÓäàÉÀkoÇÔ–ô¾÷Õ.æÉÇÏÀå[D ‘uÇTÅÞŽK&ÜÝàó[v ·l~‚—?IãékºÐ¬q"þ|~›ü1»Ïº›[:ÈM|-ø•—ÞÉaàÝO14*eÂkÄÏþ‰¯¿}ë¿HbøØK¹´[6+ŠRÒ)¸^ÐÒ)Yø!ÿùf9ÛvcÄt ïàáüëÕ‡èXøW?ëü“ßÌÍÚÅ«¡ûxÚ×ßÚõ¦§ª;Œü˜®N!äÔñ¼zs×ývhß?È-ëöýÛµqüºˆeK4,iŸrß]NJwï&Ñ=Žó:—³mÓfô² Ì\â¡Óèž$ZÚ1vx[6öôê+/'$$„7Þ~§ÑÇo¼îZ.»ä"jjjd#Bˆ¿&ÀÖ>lþSå™@;wßï-ƒˆŒ jæq)œ~7?G»R7&šu¤5Bé=þFDc‘å+þ"jÜiÜýâ©´Š¯»Œn‰¢Ë¨«é2â"v.þ™Ï¿x…ñ;1Ÿr#ƒcÕ08áFŒÈ-ÒI Ù·Áù B°.œÅ× ¬ {¤û~ƒÆššªîð­éê§kP[R5À0p®ý†—'Í8 0»v …³·kŽiKŸá© ¶š÷&ídø+34ÿkžŸQFHç°ØÞÄòÅóˆî{5·÷*bÊï05ùþÑáÀaj555œ?æ\€Bì×]˸‹/¢ººZ6!„økì± ‰huô,ÁDGÉ‚1%ØøFÖS5ˆÔS/æv{™O­cÀåÉÙ/e¦öá´ÔøNž,¾}õ3rºÿ“:î¾Ô¦¦ª;<ÿtu ©{nÆ~V§tn«òëíZEQþáû”ŽéEˆº› ¬OylCwnTÌšÝN2gÇ ÝÐ)gæÿ½GÄŒ5ÌþÿéþƶÃq`ˆÝ^kj$¼ !ÄÉ`…8®ù(XôÏLžGäOðŽM·_ñ >›ôß;Gð胃övÕÙ`ÆTup4§«;ì l½×h•ylÞªз¸ºÄ±·kx‹ÈË5‘nÓ00P¢¢1ï*#ôƱ\XðLëÃ#£ødû†Íã«¢óyë儸MNUVSSÍùcÎÁãñ0îâ ©®®’Õ_!$À qñ;È];Ÿi?~Ï/- ºáin•B‹ÆWÝMÉŽ5Ì›õ?ÌØŒ¹ï¼0ñ,Ú5Úyü(LUÇÀtu QÝÏá|Kå%¥ÜÐAIÆe­S ¨kÃQDÏ ÀÚo¥†Ç]žEaÞ>{á'¯}™Áßó‰ÍèñW±{ ¦¯9qím‡ìÁTSS³w°–tB °Bô¼|úË*rr³Øºm'éô~ÏÞ>”N‘-¸©¹ÖðÑÓ0c{.ej]ú æÊ§ï`h»ð&6ð?;Uíéêt½ùÝtÀ¨ÙÌŒo¿#ÊlÅb ð Þüe|÷cƒÎìAtÎNv%w$A©TП;ï¨dÒSÿ£æì§y~@Žu~tUňÍý7¬æöOÂzï]ŒÍ8tˆ­¬¬” A!$À q¿¾ðsO¹›ÇǤüéÛÈ®\¹œŒŒvÍÿÚžrrËiÓ>®y·ä5¼8«]hæU?.W…»Ü„&GJê¤Úe"8,ÝoÂ६´ kHv­’ §ö—,’ÌÌ­²/BˆC—¥+ÄI} {SÕA‹LWwX72°ÅÐ6ÕÀ[YÁa]´÷¹q˜BInŽßåÅ窱{Õ^Õz]ZOU)YS„â˜Ò¬»råri)qÂ:é«]‡;U´Ètu†qSzùݸüæÃ¼¸ò;!„8¶,À™gž#­õ(**$66Nâ/2mÚOÒLjêÀ !„+„7]—+„B¬â8"X!„`…ÇY€•þ§B!$À !Ž«+X!„`…Ç ‹Å‚ßïÇd2Ôí i~,«¬B!Vq¬‹ŒŒ&??èèXNÊ6p»=””Ÿ$+„BH€Bëâãã)))fíÚ•¸\®“² l6;©©iÄÇÇË !„-` G!™y•èÁñd$†R{ÐMqV¥>qmZ.1ù¨ð”f“Uâ%$!ƒÄ}·Lò—ç’¹ÛMp|:I¡r·vqüQU•nݺӭ[wi !„‡>nüÙ7PlVj¶,böïóÙT];Ã_°Š3ç³²HÁ&áõèmø X9o.s7³o¼¶‡ì•³™³0“*“"$„B °‡~‡Hº îI,¬Z™ƒG¯`ý²-T‡´cpß$¤SLa Õ¹9”íI°î<2ó¼¤t =H¬B!$À6ïM"º0¤g,ÞíËY¼t)kŠítØ—Ö’^òÒŠ"##*sØYQ[ívåî ÏDF‡Ör² „B °‡ó6‘]Ò=²’MërQ3úÓ7I¦‚9ú"ÒÓ‰Q*ÈΩÄÀEöö|´ð¶tˆ“¾B!„{XôÊ<ò*Uìv ®Â\v{¥q[$†´¡]œJiN.UŽl¶ĵoG”ŒÝB!„ØÃI¯å¬¿’"{'FŸÑƒXçæ-ÍÃ#íÛ 6ˆ´¶‰˜K²Ù¸a;¦$:f„ ½_…B!¶ù镲µóYQd¦M¯®ÄEu¤_§j¶,`I®DØ–`KΠµy7ëÖÖ´@i!„Bœ<þtÇI­t-³WíÆˆéKïº$×­7m¶Íbó‚e¤ž?ˆd]tt$’ob{Ní:$ÈÝ(ÄqÏ0 òówQVVŠÏç“X,V"##IHHDQä:“â(XSTw.¸v¿ÉÇÓyåõÒº-Å[Hîn?¦Víé-_Åñ/?^¯—îÝ{aµÊPQ·«ózÉÌÜJ~~>‰‰‰Ò Bˆ½$ýw ;6²Ãe&©CaR”'€²²222ÚIx X­V22ÚRVV*!„{\ÓËÙ´!`*SmÒâ„àóy%¼Šƒ„Ø|>™ÖFÑtŸ<¤¾£ˆ ŒD¦ÚB!„Xq,±âZ‡H;!„â¤%]„B!„X!„B!ZJ³»JkýE¤­…B!ŽB€“Öú ÔÔÔ, qÜ1ð{ÜèfVÓþi8ÊJñÚ[®”±«"„Ø ¦/hÕæ;±'Äj:Âoäwãô™°Ù,r©åHx+ÈË-Áš@ëVvLÒ"BqÌãÚ1Æá¨‘F8.󫃭saqžVûO]GÓ´ºÿì\>5>|Ž v,›ÉÌu»qëM¼§µ‹6Pà1šøP»×-bIVþFug-æ‡ù;pMuOÑF®Êñçûè>ÜnÚÞ)eÓ’•l¯ÖOžå©íféï Érú(Y3‹?¶90þÊÏ×utÙª„â d!Žz˜­fó¬é¬.Ûy tMƒòøfÏ'6Íc†>Œ³º…S¸êViûÕššÙÓÉÜï4ÓÛQ=â0a!<>ÇüY̨ìÏÐ.vÊsŠë«‚·Ä‰î.eçöí*µSƒcI‹ bÏ×Ы2Y°´„ÖÃ:T÷9zñZ~ž]M·ó†‘X¢HOÍá÷ùkу¸cdú6£f n£²©¤§†ÒþÔþ¤ï»ã‡¿b;KÜMR£&›Ü°®Œ=% 5Eãç»ÑÚ¦aŒòuü2cÓ!?·óÈÓéqøwÑ;™?}-ƒÎ¦o«=u_òóYéN¦G—"­r!„X!Ä‘Ç(œÙ+X°­G¥†oýl¦o¤Ã  ¹,pobãŒß(i7–!)û_ˆöã©®€¸AœšfC9Ôge-aNÕ¾ðeîÀ°Ñ!¬\YD¹;žÊÒ2ªêÓj|àwRQV†eO€%’ÔXj?Çp²cåFô#ÈiúbŒ5¶ ½¢§³tCkÎî}L\NW¬´NÏ æ IT+ÛÂâÍÕ´Q”mè©Èeë¶ò¦+œ†OÕ:Vlñ`+Ú‰%nèÞ߬„¶aÀðx´&¿ {¨rØë’«p³g¯Ã•6„3¢¶²5"ÓÒ…|¿i-é=úÒ§CöF›VžÍ–špÚµ“¼B¬¢Ñ…52•N0£j;K6:©ÈZÊö¢=AS£¦Rûq>³²êBBFŸî$ÛjßÈ^YBi]”€H¢Í(u Õp’UBjB"½ÕÞ'>¡OÌÞç»¶Í&{g<Ýû´'¸‘,¥—mcce<}qè¨e!¶c[¦o&»ã ÚMo 9=â YÐÉæ‹±¶FzPÃå”ÚŸ³RñÞZ.³?ŸKQ©“¶m3")d_™‚ˆŒ:º¿ÅWÎöU‹Y¼ÕMBŸ³Õ>b¿³JP|†iG׬5,Zú_nNgÈè´i°puJ3—³ÂÝ—v­ÃdóBH€Bd# ‰&1ÀÇ®Ü嘓ûå\Î6s{µ‹@Qœì\VBERºÄšÀ(bíÜ]Tù›Jt»^XMx *©¨i"Àß‘>ᡨ€¯ºŒÌ%KÈÌèÏ.±uÝšK§,'B/b›¹P‚I YGv‡6iuo³›ÓSÕnÃÚ6'ÿj+Õ+Jâès^–#y ·ƒ-Œä.]èP¿’jøñkÍ?¹QL&LM4Šá­ gËzV­ÏÂÙ‰çv'5¬‰ú¶b%²MÎNnËέe„Úö{s½œì\±]cdç.„{ü3pWì¦ÂÝH8PTlá1„48ªPSQ?0œp[s/–j¸*«ðÛ±ªâ9Ç %¥>‚b"°)‡$we%¾À0Bšþ½š³ŒRw Ñ‘öfŒ,<6ÛÚ_²‰Uù¡´í^ƶMÔøZÅD£5”XTÜ¡ÑÄĘ@w ìª{•JH\*!á=IhÆçì¹›5¦#G…°tîBfêýée/!߱︿¼½Æ`Ãjw]‚ÚÏ‹LëLj¨‹’7áé‘Íɩ؈ŠdCI9zZ\Ýët|7¿q̬–Zåff/."¦ßÚY¤ö—Sn¤ç~¯÷gÍáã?²4w5’^cÏ£×þý`ýNÊŠòÈÚ±ÌìRô@3. #Fö"¥¹»s8©ÂüÞ›ÙæJ¤뀿­ý׬]Ç’eËš|N¯ž=èÕ£‡…`›Î¯å|;¾'wÌð4r¼œ;¥Œ)€k S&ÞÁcŸ,¥Â†¥¦#í îxùî{½ƒuÞË­Ma­;³['~ÄmLzý!F%˜ã9ÇYv͟Σ—^Á ËzñNÎ4nˆÙwv¬zŸ ¾Ê·³7S†Ãg¡Íéw2ùíGßH+ºVðôÐ!u@±5De %Ü j›ÎD×µUõ¦B6†§Ñ«{'B¯ËƒÉ¸ïuºŽ®+¨‡YœVM*F½P&l!!ÇÄš©;²Y0}›ªBèzjGÚM×¨ÞÆš,3é£é~ ¨˜Ì‡j4²‚\Qm‰µì ÿ!ñ´í‘Ê©1Q„ì[‚ZõQY )X9—Uî4FÝb%¼ !Ž–“wX½€Ï~õö'¸8V=ŸÅ‹òèwÃ=ŒL¬+_¨!tºünÆÅ/gÁÚF.êY|2é{î~“Õ ÅžÁ%“^dì®7˜ü»£yÏ9Žhë^äÌó>$î¹9üöè"XƒZõÏÜxí£m¨€5n÷?| Asa¾£a(­šý07~Õ…Çþջ龊Çl[ûÉ[±€LKÒ#ÌĤ&c-ΣÈc ûÜ8].œ.7>ÍÀïqÖþÛé©7‚]%¸UkRSRHMI!%2ÃERJ ©)É$† F‘\÷xjJ )­ö» ‚7?ÎeÛž _ró*KN"Dñ¹?Ïf}Y½“ ÅJ€ÕÇ{x—þ½/ŠÕzÌùzŠ7ü?{÷Eµÿqü=[’ÝôFB:%@Zè½H•&MQ¯ŠŠ¢Ü ¢(¿«^Ä Šˆzå^Å V W¤ ÒDzMè%Þv³eæ÷i@€D’ð}=Ožv§í9;3Ÿ=sæ ¿üôgêt¦{/Žý²‚ß“­W?v«3“½¿í '´5qA×ø)-§Ø™P@h£ú%nž3ø…X"¼Vᬤm«X¯§EÏ7´õµtˆíЮ„W!„ØÊdÙø:¯ìÌ´G£ÏµJéêÒ¢EûWÿÊ™bçyëÁ•¬=K«èrNfù[ذ7’>}–lóìέ¬lù펊LS“ ÎД'~^Ï4µú| IDATû££®ê¦!ÅÕ„‹¢P|D#-kSÇÿLçwf3,ð _Åj[Öb{2 [ÞshknéK°+%ïá·õX÷Û6Žæ99›°™uë7°nc^ÅÊWÅi·áPoPXÕBÊÞÕ|¿|?Zl?†t"2¶'ƒ;zr|Í ¶$Y*üùœ‰ü±|%;l¹¥KÜ®¡ÿVt†k6‘èGû¨ªîV¡R˜vˆË–°â°‘ýûÑ&ÐX­-[4§M«Vþ„¢òξ7#5™¯_ÿ ÿñë¹åÂS[MÜòÂÇ ü©Š,i;²šÏ×DsqǧN]BvdHƒpê¸éB °µ^kÞŸOþˆOèWüzv*‹êÉ3ùOðÕ¾Ïiç¯ 9úóÜ5º7§¾ùƒw{{•ŒE®f\±b)ÒÀ³äÓ~¬V+:“ — Lc¬Å¥­ån楻¦rüÎÏùt /  &~Éß§`ôWïÓ½‚÷ÿÔì²V0¸¸bÔåsdË6ŽæZÉV½uUÀ™ÎŽåë8aŠ ¶Û­4 * Ì~xÜÇ’ov¢j Ó»âÓ =!.€šÃÉÓ* Û4Á—³ì:yš|½ náñ5¹b6™ v3ãææŽ»»&-‰ Kp<«1-ýt`¬KËfGY±ó0 oi‚×ùë‚Ú0òÎÒé)…Ýû ¨ß1ªdÑêêÒqĨ¿þÀÇÐ;Úbºìðl:<£º3Ø7ïR‰RïEd³öDzúâçmÆpµSq`-TÑ{MÇÀ|Í×v8UL¾„†:.1ÝE.õ:1*¤;nnÆ›øæ!„¸I¬–¾„y?x1fYWÌÅ^WO|Íœ%Ñüóðã´óÿóLâFÃa3™½n Ã>[˽o+qg³>8Œ%‰S‰N(^”6’N%(<—à‚+NS[ÛO´ì-¼6b$ "Þdå›ý8W¬Eüòâ“üOÇý_?ˤ¯ÏM›¿çEG¿gúÇ êð0/‰-Q.Õ¾¬3áqt× >:ÑÏsACq§qÁ€ŠÍ¿ENpñÀÛ €¸Cim0”ÛÊoŠcЈ¸Kä3_Zô틦((„Ъë•F‘ £Ó î¢WpkЖvëØ´Û—^­Ëﺠæqä÷Ý4êH»€jòmU\0U¨)]§9OëRÜ ¿Ž§i‚hÚ1¨R>ŠÎ7šž·TdnxÈÓ „â|ÅME%yñ'¬ŠÃÝq%Ûâ4{6 Ëœ ôzªóÜØNk9yÖsÃy¶§SôqÖüzªäsÕ 7ñËf#í:Çb¬È4µ°¤ÉËxªß0„¿ÉÊù÷ÒÐxñ7Sƒ/0kÒ`šEEETTCêÕ1£3P/*ŠAçžèT³ÊZgÎßùãâéO€§K™ÝÍÅÍ __|Ü«þáµbAN¹Šy †²ýƒÃÚö¦g/t—¼ÛÉ•6½¸¥‰r±Z!„Ø¿<¿&ñãÂ-4>ŒÆ¥ÎÄú†ƒó3¦|CÂ…[µí¤®›Á³ó- º½&ìl}¾5A_eÐ7âÞ }84kswåž Mö$–?;•¯½`B¯ŠMS«häïþ/wv€Í½æóëÇwÑÐ¥dЋºõQ&L˜PìïqîïŠ1¤÷=þ8õŽD'eý×Q ˜ÜL—¾Œ®sÁÍÍE.[ !„¨6nª RêéX´µ1Ãßm\¶%Iß”§MÑ„'é6 ï°:ó’I¥)wÎXÊÃüQ°—Éÿ¡÷~Ìé0®O/ûâš•†Öü~æýðÜ*:Mmbc匧øîhÚÌþÏ,ö–KOÞ=²š á×…¤¬…BqŽ’šš¢ìر֭ۖ;ÑŽÛ0`ðÍt ÓIJÍÁa 4Ä› ¨cÏ%%)»g0aþ—¸“¹Óœ9“JPP]ùfþe °lÙO—ýÞ—~ïrû‰¸v;vl£K—îR¢\7®—ýNQâ,·”Cç@xƒ€«›ÉèEp=¯ëŸFHY !„âòYMŠ@!„BH€B!„B¬¢¶2]°ÙlR¢ ›­£„B¬¢zñóóçÈ‘CØlER¢Dx=rä~~RBˆä&.!Ä Brr2»víÄn—–XqŽ‹‹?¿‚ƒC¤0„`…Õ‹¢(„††*…!„⊤ B!„+„B!„X!„B!$À !„B °B!„BH€½ Ž|ÒÏdaÑ.?™³0“´ÌBÔòÞÔlägemq^ÅŠXr²È³©×9Mm*kkNyEWþ¼—­)k!„BÔÖëH^É?o©OPä]|qö2 Ö²—{„1üC‹çK_OîO“À Ƶ¡YX¡mïbæÚ3— Vìýt<Ý#nKý:Á4ñ«’W9Mí)ë‚ó÷!q„zºáAïb‡NgUŠzuõQCËZUUvïÞÉ’%ßñÍ7_TèoÉ’ïÙ½{ª*[!„¸’Z2¬FöÖ9üíÎYdvlGýêeCÐæâÝZÝÆ–†1~ÓPîZBßPWPó8ðùc ½},»þǃaº2ë=ûÝ£ z&™G'°ºk †Â#,š8”;‡+¬ùí9â\*2Mm*k”³xÝ6›5Ÿt¢Q€Gêz^3’; cÏÿ¤d1^ª>¨±e½wï =ú<=½*4O^^.¿ü²’}ûöТEœ™„BˆË¨-°Î½¯3`è§Ô}m+þÕ?Ý¥CPîÚçxxQ3¦=Ñ–O×V“Ù²9‘=IŸP×ó¥ãIì˜ÉŒÞÆÆ=޲‹S³`ö„LžË3]1Š[£f¿Î°¤÷x{UAŦ©Ue­Pgà3¼òp/š˜Ñ.u»óôs£p_ÿ3 *X5¸¬Ož‰žcþ˜X¼õöìlýíNõ\öhy7ãb&óÞÂ.̃ B!$ÀÞP©‹'1éÛødc|•üò‚WÝuæ‡Ù?³ø›¸ßFªï@"ý\)/hÖB¬˜q3•~WÁd6£Z-U`àZ‹Kßyr>ÏÎÍaÔÇ÷©«x}Ôä².ÝúºaÓf:wì€N§+1Íœ¿Çâï¨Ð2÷HÚ÷Œ¼DbÎ`Åúqïñ$=ü+¹õP@Ë~ýéw™VI-ßÈ–¯NV~9æocùf·½ð—¹ bç÷·࿦’QÓqd‹OµfüÔ ‹}¤,'8r&”.½¢ñÖŸûN}êÓeHýbsši9b ÞO}ÏúÑôñ‘VX!„¨®nŠq`ÕÄ/ùû”ŒþàEº{^êL™Êâ‡zòèæ.|´ï(¿/ÿ™ßN°vª/‹F÷fòêܲÂÕŒ+V,EZ™ÀlµZÑ™L¸T`cmþé»™—îšÊñ;ßgæ@_”ŠÖG /kMS/ü}ôégL}îyfÌš…Óé@ÓTTÕÉœwÿ]"¼Þ{÷˜ký†“¹ác>=Ë}wµÄí²¦â¬1ƒ_ØHXü ;ê aHãr~kky¤gØññõ.v spxÃf¬m;Ó¢x‹±)„pßTöîϸìPmºÀŽt ÝǺíyh!„¨®n‚Ø"~yñIþ§ãþ¯ŸeÒ×ç^Íßs„¢£ß3ý‰ãux˜éV2gI4ÿ<ü8í.´`¹ÑpØLf¯[°ÏÖòFïÛ(~NÔ‡¢$q*Ñ †'Þ¤Sg Á%¸àŠÓèkkxÍÞÂk#F² âMV¾ÙsÅZ±úxiLl‰r©ie­ªçâφM›ùdþ~^¾PxjÒDÞzçßüïçŸ/Lÿ·»ÇðØ#ã˜7oîU¯Ë‘´œY ö¡Yôö¿ÂoRû^¿ÿQ~lÞ’Ö­ZѦUsš»WA¹hä>À‘ {ƒ ‚Ñ¿!ÍÂ=Î_íÐÈßû9o­0sÇ+}/ôI/ùÁOqä´™ˆá¬šE|BõúE•<¸špǸ®<3ë9žO¼Q»Ò¼®¹ì/x/{±(þÎÞq7Ë%*!„[?bƒ/0«…£ÄÉ5;ÅŒîtõ¢¢r{6  eO¬z½Õ©¢Nkùv#žž&tžíé}œ¥¿žbZ\ƒ‹'ÃÂMü²ÙH»;c1zú^yšZXêÎäe<=ì~Žy‹•óñêêC©áeýg‚n]:sÛàA,ùiéù»‚={÷’˜”|aÚ»GßÉøqcµZ¯>(gnå½—?'³Ç3¼ÞÃÿÊ—TŒ­yð¹[1íÝÉŽµŸòýgQ‚›Ñ¥[wzöèHËÐÊ ³NޝšÇ¬u9 °:¼{<Á»c›aÔŒuÌžµ‰°‡^áöúå¦lg[Q46)ö¾šNZ–™:~¦RÝ~|ÛŽcΛYüÍÌœð n­†òȸ‘´«c(±¾îÌÀ¢§ô"B °7†ž¨[eBÉÓ>‰Ê÷ÌLíÆ}?N„pfDÌLfLù†ös‡ØI]7ƒgç[ô~7LØÙò|knY~[v¾Hœ¡÷NèÃ[ÿ7‰¹·|Îcq^èìI,v*_{=ÀÏý½@ïqåijüÝïsÿÈH¾}>¿¾Òºúk¨ìl®Áe­iç.T;*ÿ7åIŒFã…îÅÃëðÛnãñGÇaµZ®z޳¿3wúl~N©ËÈÎQ [ЉÀ&íéÖ¬=ƒîgA þØÈÚuKxmÑÐ…wàÞÉ“\O݇–cçðÅØk›[ç×±Óc¬T~ V3øõ‡ßpvœHû}s8zôåΤàÞ™{Ÿê̘œÃ¬øèm^y6‹çf?BÛbËÐô :)oÔ®;¶ÉYC!þ"­[·½™lEsnSžZü5Ež¤kØ$¼Ãê`ÌK&•¦Ü9c)o óGÁ^¦Õ(ôÞù!ýÆõ‰àeŸ@\³ÒКßϼ^¢“[E§©Ml¬œñß-@›ÙŸà™ÅÞréÉ»GV3!üZº^׬².~—Åbáɉ(ÑçuØmC˜2yâ5´¼jä'üĬ™_‘Òz>Ð{ÞjS²Ï¯Îo § .? „Þ»ÿþ(Ç}•e;ÿFÛn—’Ÿ[€ÎÃ7åê¦B!*Ï• j]€ÕGOekÞÔ+†¡°Ç×÷x©yCúñ¯ïöò\a:I©98L„†xNÇH§7c}£ø‰Ö—N“²÷﹤$¥c÷ &Ì¿TߺŠLSkÊÚ•_å£~uuá´l}Ôì².= Åbaò?.†ØÛâ©I±X®²åՙ;ÿË› 1j³†7ÁSéJ˜ûÛ<ûÚ Ø§Lc\Ÿkú¼ÏÚõ¨Þ_:G&;¿}‡7Ÿ¥Ãä—\ê“ꂨ®góÉTÔN—/½'>N’-48ßå ˆÓ§Ò ©^«o®BˆšNZ`Ë‹Sn„7¸ÊÁ,^×óºþiD­(k§Ó¢è¡XÐÂÂ&MxŒæM›Òû–žX,…Å“÷…n—X"Ù «Y0ïs~-Œã¾f1$Úë|@3Úk"3 ï2õ`ÊtƵñ®¼Ð®‘šJÒåZ° s°VÙmû*–ô£ìØ´ŽeKW³–Üý«ŒlZÞgt¥y›hÞ^±›´QoþRYÿcþÝ»ëoDÁΙ-?±&)”ÞM<.ö—-:ȶƒ>´|s Ñ"„`…&“™””BBB1Jîb‡ƒ>½zb·ÛK¼çp8HIIÁl.ÿ²¹mÿ§L~y7 †Oä?ÃÛd,»+uÿ;¯:çðô¯ôæK ­„¦wÁÝt’…ÏOaá?x=:VÚpù»1络>uŠÓ9š¶¥Ûè˜Ü­ ~—Ñ]éÕ"9@I€B\½“'sÇ£Ñë Th½Þ@Ïž½ùöÛ¯¯)ÀZ/áõ¹k8«¨ÓcS†7Æ­²âj?=?…]}ßá_½¼/bÕÓü4ûÖ¦«%^V<ÛñÐc!¬}óG—jVÑtcÂä[‰8¦Òòð¿Å§‰º£±%>Œ8Hݾ†¿[èQߥœ¤]D¡Õª]zƒ+n¦ò¸FîîEÌÛν÷u"P_ê]‡•«Š‹ÙŒ‹þÜÜZá!¾ûh^#î§o¨Qv!*ž^IÛµý9 ø—zËnî¤ûè[hXN‚Q3÷³é¸?=Gô#t¶-ÛÈžÐ!´ ¦X °Bˆ«“–B\\\Ñ4­Âóhš†««+Ká&Ìbë×_qºÅŒlj>ÿZë¿ÙBãɳ˜’Æ¢ç?a}¯r«R,{®gîÖ¬^fÙº`úŽ˜[u‚\~ÒAâS­hyÛXqØ—Ø~Gض½tìÓáKtàù0©’rø8ãîXÃùL»ŒŸ$‘k7q,ÁIË碃ûùSØoø×ÒT T.ôÖ×ò±æ§Ý¸ ëGì…r–U3_eG·ÿcdòjÞ]Aðëch\*Ã:öÌgÂì ”WŽr ìèb䣷\ê\çLZÎ̹ tž6²XxÕÈ?ú Ÿ}úkö¥£º°ix7Îs¯ÞIŒ[#úw_Ï”ŸðÚƒ´ò& !*päÖ²uÇ|iÓÔ…?RK½k³ãÐq¹TµZ±yÖÅÇàŸ§ƒ¤")U °Bˆk¦ªêÕÊ+x‰ü¾b ¶F_|M1`6ÙÉÌ´¢úf’is%°ÔÞ®¸GÒ¾GOò.± ûñ•¼¿,•nú’-ÙñëXº9 gvs&¨W°´lú%¼O$M]еhªdŽgŸv.jéX <ÿV>‰ qw=ÿßÄlœ„–i}±aÄXüz .€ö½ê1îçt~s<·o}žw¾ëÄœÑõKà ­æã—þ”¤þñ-ÿ~ÿ'NGgܸþeÂ+êYVÎ[Œ:ô„\lz-:¼ˆgŸ_†iÈxæ<Ó–p8 H9‘…›@Á£åÝŒ‹™Ì{ »0wl .²qùcž-…­›’ê4zyëø£ôûv—KîKºÀ†4ضÕ[ó !•C¹‘t ’ÖW °Bˆk?0_EëëU㬓œÌ¦chñëÚîtùÛ™÷2s¼ˆ»ãaº–jTÜ#iß3ò Í`Åúqïñ$=ü•¡4¬÷x¦õ-{/ÿ#‡.Oÿ‹1‘úŠtŒ&̦s'Õ¥ØMŠ“+æóÖiÔ—¹”¯ÙmØ\J¹¼ÛßÏ£;f³ë˜?1•h%øŠ7Gæ>~˜÷_¾9Èàßà¹N!˜Ê›îÈ2ŸjÍø©AÅnIá§“×ëy^»»n¾®w'¸¡{±¹Í´1ï§¾gýˆhúøH+¬—>HZ9ýû&R‚;34Ì„ý`y¿¬mØìYlûy1™Ù…ØT|BÓ¾cKÂÝu`¤í€Þ$K$›hú¶ ÃG’ŽX!ÄõXµJ–k;rˆîõ¹§NÉV}`{ÆNmJV_¯«iûSÉÜð1ŸŽeì„–ÃYɳ‡~\Ìžð64];‡§wœ$ß³ ƒËÀ†æËô…ÕãÚÆÎw!0ÂõBu#¨A#Ÿ_¡Ó± ÝöÒÖŽS§/{àR¼é2~:]ðæ²=†Õ|­üŒw¾Ú‹wŸûxkb'ÂL—Œ¹Þ°kÛGhQl5u ëD0`bì%ʧx‹PGº†~źíyôîí%7» Qþ’¿³él=†„à¢hØË™J1Õ¡^¤'á±M©çë‚fÍ aÓjVÿj`èÀæøê@1zÞÄ›p)T °Bˆë§ªUÑëàÈÞƒ8ßCT™FP'‡>šgNŽà“ç{SÑÆ?GÒrf}p€Ø‡fÑÛ¿üKojòr>üé4ù®&;áÑÿ ¢pÓ<^žù¡³FâŸ|‚ã§I÷jð![.µ"ެÿ–/÷\ܘ†m[áçDóvÞÿß7ÿsÙÇ)ÒBJ}$'ý5¥@ Ëé Ìÿ÷Çüx°¿† 1nýŒ§WþÍèhCZuȈ>ÑøþY–jñ YÔëUâ`é<}‚ÓQ4 ¬À¥I/{±(þÎÞqrТ¼½³à·fÓð䊕{ IDAT–._æžG]zÔ)ö‚ÉŸ˜öÍ8ºø's›âë#Ý$À !*÷]]œÇù}G.ÑC›ã^&ÔéiЮ5Þ?ofkN/úU Áª™[yïåÏÉìñ ¯÷ð/ÿI'êYV}¸x¿ž<3ýqzÖÕS˜²—ß õ¸¦-åŸn$¤^}D„ѺÔgVÌ̓mJzÔ$öZ2 ½ýUÆ6=÷žcû»ÜýA™_h:ÝÕ·bÚÏðû¢÷yﻃ(Qí¹ýá6´ŒiDýº¾x™ ØóÓ8¶s Ÿ2'Nåñ­Î Û£¦“–e¦ŽŸ©Ä:í ·€ Žê # À—ÂX4ð”&X!ÊüØNÚ¹•“Š?¦cÛØtìü~–™‹3÷Û·ä`Œ¦mCŸrIŠÙ7ÅF‘MJR¬¢ låw!pÝ̦ŒF mëSn¨34îHWذ=—¾½/?Ì•ãìïÌ>›ŸSê2²sÔ%‚–Jú¯óøèH4^Ÿ@wó!¾ó}¾Ù££i÷Ž´ˆÜÙþo2c ßeó§‘ñëž[t´Ø`ävrRÏâ89‰Í&ïøË.WQ*P&ßòÒ7n<ðÌ@êoIUÏìbÓ™}ë):†»•Ù6ƒwM{ÞÃóžÙ<4c)›ï‰£¯—8q8ôèKµnÍf ……X*ø›DoЃê,;øºPðª×ŠN~Z‰ãDQ¡ \ñðòÆÝd¼äñKÍË&Gs'ÈM~J€BTA€­ìXûWÿFFìt¹Ä¥~ éÔÆÌô-»(èÕƒòGrÒÈOø‰Y3¿"¥õx^쿉w_~ýÔçx ¥w©°§Ã¿ÃÝLk@ŒW<=3‹}-Çñæuµ³eö>ÎÌFÃï²'+ßÎñjœ ÂcË™óÎÿHS<è2öjjÀèæ…n_9sºšpµçPt©ßZ›/å¨×D‚Š…N]Xžxpd°sÉüôûaRòì=ƒhÜ~wnI€LõÑÖ’™«—:O¼=,œ.(¹B}X¡ù¿s(M¥eÈ•/Yæç óðDίB”G‡WX4MK— 8ÅnK0Mbÿ|†5í$©º ÂýÍèp¦°{ó~òCÚQß]v0 °Bˆj`µÜßù߆":<Ö¿Kf(#MZ5Eÿï]ì³õ £k©·Ùìûñ¿¼¹ð£¦1kx<•®„¹¿Í³¯½€}Ê4Ƶ)yÙNñˆ¤©‡FþÚYæ:”wÇv"ôü°Q&/ 8¯|ºrõÀ×ÕÊéµñêg'iõØS4ÿò=²Ý}ðó=ß… ¼ùüP÷‘’®B™à¨‘»ís>ÞÁo·À\fî"ö|ü3Ž´å¡»¥I€ë™x–~:‹×x7†ã<“ÂCAö£ÓQ/\Ïæ“©¨".”ƒ.¸#Ýë/dÙÿö3è‘æW¸‘«ˆÓ§Ò ©Ž<Î@ˆë£ZSÙµq=¿é1¹héð©×‚þ£ü*VQœNŠ¢çÜS£*B¹L·'§–ÿÈïž½x½½ûe»˜šÆkû’í‡tlf¸0vÂjÌûœ_ ã¸ï…Y ‰ö:Ð „öšÈLûL}ã˜2qmJ·Ä*çþ¬yä;àÜ ŒâÆÍeî•£7ÖäßùæƒOX‘Ýœ±/¾DŸÐT>ÿ²%âÓ„˜:Ÿ²iK*#F„p±‘U%wÿB¦¿µ•°f0°¼qÕŽÍ¢Q¿;èÓòüh¡ax'®ãÉÄ4œ…ù|»`t™L» #a¹Ò¼M4o¯ØMÚ¨ê^H°¡ yh(ë¦ÍæEÏ LÑš`“ØÉMNG«Œ÷ŸÓdÛAÚŒ Fn/‚ ÿÜco娒¯¹EtdXx{ìE¬p1»áª—ä*VQ%L&3)))„„„b0Tl·s8¤¤¤`6›ËyókË Õ·Ñä ÍzŠGsZ7ÈeéÎS8›5@ØöÊä—wÓ`øDþ3¼ AƲ‡† îçUçž~ãu‚Þ|‰á¡%ã—G‡áŒ\ö*Ï>qŠ›R?Ð7WšÝŠ¥ Œ³é¸ÆæÎ6¥ûÞÚIܲ‰ŒÖyo`úÌtΤ¥“St®‹«¦i(Š‚ÓfÃat)ù s}=kÆOï¿ÄË–áôj€kQ:‡·¯aéoDÝû/¦ö ¦ÜQiutêÓœo?ÆÌä^´nˆ—‹ƒø-ÇQm?òÔøÃ4»‡j]¬%GÁ»Ó­tþâ3–ÀQëÎ}¯½èþǣßZq÷6á(ÈÇæÑƒÿ{ïq:˜Ï…õÌËÙÔ—Y ô²#Q)ÙV‡Ñä.W4$À !ªZxxññ±Z­èõ 2N§“'ŽVÎà ¸oö(Ò›®Üª§  ï”·éît!عČfμûñòÐ_öð|ËD^HƳ¼~žæhî~í?tß» §H:œD¾MEgtÁÕ䆷o="üË;ĸ5â &¨é¬þò-¾=Z„âÝ–;Ãl˜y7¯mÕPT€¾Ï\lõ<÷aì7…9ÞKù~õo,Úš‡ÃèMHTGŸÝ—Náî—)Á}§òߨm¬Û²Ÿƒ"ßƺ=éÚ€æm&ѪžWÙƒ¢9Ž{Æ,ç©O–Ñwú íg“<ùÆþ‘ŸEf¾ƒ»7¾ž®¶AËßÁü…iô™ÔŸPi~B °BÔ$QQ9|8={vaµZ*4Ùl&44œ¨¨FåO`4áZ±æ Ü‚q/‘åÜñò¨È¼F‚F^&»Þ²á-+r´iÀ¨é3púèK„ëÞ“^§wñé¦~E'»U1âb(/õ™ë0’¿wy 5¡Ç«~†Ôïpóè¨Óë1‹ŸÎ¬õyùþf¥n†S0zøTº<ɬx{>i'óX´«ìB!VˆšÅÓÓ“&MbˆŒ¬Óé¬Ð>¾‚ªÓé$''›ö³|ùRZ´ˆ#,,\ M¬B!Ä_OÓ4öîÝE^^wÝõ7ŒF#‡›Í†ªž{:¡N§ÃÃÓλҮ]–.ý‘ŒŒtZ´ˆCQäÉ\7isB!Dµ±gÏ.ôz·Ý6MÓ°Z­8Ž áÎu-p8X­V4McèБ öìÙ%x“X!D­¡iÉÉIdff`·ÛÿÒu.øùù pöãÊÛiÄÏÏ_¶óêUZöª^bâiòòr2d86› MÓ®8ªªØl6ºvíÁ’%ß“˜˜HXX˜¦X!„¨’““°ÙlÄŵÁÅÅå/]·ÍfãÈ‘C$''EEE´oß ³Ù\­ÊÈb±°ÿ^’““jÌvV‡z •¬ ©ªÊîÝ;¹ýöÑØíö …×â?^ív;}ûÞÊwß-$$$Dnì’+„5Cff&qq­ÿòàââBTT#víÚ h´jÕ«ÕBaaAµ*#NG£FÙµk@ ÙN¥ZÔ«ت•˜xš¨¨F † ?±°tˆ5ԯ߀¤¤DÂÃ#¤Pk1ùy"„¨5ìvÛ 9ÃŽ+v» »ÝŽÓé,Ñg¯ºPUUU±Ûí5h;«G½ŠªuêÔIBCÃq8hšvM‡ƒ°°OKÖrÒ+„UàZZnĶՔíÕÏûKwñѱY +eyO £[·WÕu <žžžœ9“ÊŽÛ¤’n½^OXX8þþ`…âZÍž=»J—?yòd)d©×›ÒG?l¤^«~xøUÊò\ô?£×®;Àžë‚à 88D*é°Ùl$&&J€BˆšèzO²¢&PÐ*ñ»x®Õýzo¾r:Uù^ß$À !nZN§“øøxâããIII!77///‚ƒƒ‰ŽŽ&::½^/…%õ*JyhX7>úáŠ,•s`¯A¡X­ŒÆë‹&EE ))ÉRI7€^o 4´êŸŠ&VqS:xð «V­"++«Ì{ddd°oß>|}}éÛ·/111Wµ|i­õ*.7¨ãµ¨´å­_ÿ+ùù9xxx\×rrssðóó§uë¶RIµ˜ŒB „¸©hšÆÊ•+Y¸pa¹!§´¬¬,.\ȪU«ä²¤Ô«¨B;v§óúF!8vì8AR `…5‰zr¿ï=þpTøÔOîî…¼ùñfÒœçþoËÏ&×r™8 ÉÎ.À¦VxˆÅïÎcU’½F”ϪU«Ø¼yóUÏ·iÓ&V¯^}Uª:ÿÕ´í¬.õ*ªNdd=RS“IK;{ßM8{6””$ÂÃëIÖrÒ…@ˆÊiÿ!këÌ]ˆZÁ]¯Ñà Œnnªü-qÚ±_ŸžÎ¤åÌœ›@çi# Ô±á퇘•:œ·ßº›FeŽVv}øSWÔgêWSééÖˆþÝ×3eÆg¼ö ­<ªïã6[ÓŸû”¸T£&-ç³_ÒШþ–w3.f2ï-ìÂܱ1¸TÃúq:¬Zµêº—³bÅ 5jtÅ€¤lí¬WQuE!*ª¹¹Ù8°ŸØØføøø¢ª—X¯×‘•un³Ù¨¨(E‘•+„¨À¡·úXÿŠqü­ïò•©£š»VΪu.¸{záuþ¯æÙ±™}ðò«Ø1Üzx ß `ðm¬ãÈ2ŸjÍø©A¥úhб9)ß.fW·Ghýgc†–ËÆ¯~¢¨u[BvŸÞLËñ~ê{Öˆ¦Oõ;yÄÇÇW¨oä•dgg“@ll¬Ø›°^EÕ2™L4mÚ‚;·€èèX||¼q:ËoÐéôäääp‹ÅB«Vm0™LR7é+Ä_Ér/?Û‚ÿm#èPI—Ú·(úÜ1Š»GâîÑw0¤™ºðNŒýçk£¸{ôí m€^¯/ö«ÕÁá ›±¶íL‹rŽ÷®ÑÃS+ –%ògû‡ýè¾LhÅßE /ÓºÛ‘®¡ûX·=ïâÈŽ}|ðøC<ÿs7úa¥ñññÕrYBêµ6ù࣯{zoooZ¶lEaaññÈÎÎ)·e\¯×“——CBB,²Ø{y§p$Ã^Á!ÁŒþ iîAÙ¬r&å,æºuK´¾8íN00\è>E|BõúE]â@àC÷»ðã´¯ÙØûIº{fðËç¿â3ü5Ú¸¯äÃ2?‡}iÜØ‹EñÇpöŽ;¿L…9ÙäYoü#A“““ÿÒeU´e󋯿aæ-•²]û÷cÈ W5OMÙÎêR¯â¯áëëKË–­Ù½{Çù–ئç[bÂknî¹ðš““CË–­ñóó“‚»‰H€¢’î]ÄÌ׎ÒçÕWù[£óÝ,'ùùíW™w²5O¿2œ†ÆÑ’ã«æ1k]N¬ïOðîØfew`5‹ø„ »FRº½Âf³ƒÑ… «VÓIË2SÇÏÄ¥Ú‚õù[›ÉÌûþ-ãÖ²0½Ïô Dw²üí ð¥pg <@Ãß^‡W~¹'??¿Ò–•——WyËÊ/ ©’‚“Åj­²ò«®ÛY]ëU\?Ÿb!v?11M/´°æäärèПᵕ„W °BˆëåÖê>&õžÂ ³Ðâû©wz¼÷¸à¹W羚®ÌnØbì¾{ýëÖrw³íx(­ó)5¬+Š« “r18;z.ÏŠ­G ÇÊ\žÝZ@Ô˜7ibä’Ýô=¨N. À¥¸âRûžG^‘DnDßRE¹úõÖ”í¬.õ*n\ˆ=xð11çú('$Ä“›+áU¬¢ςÿ z/ÿc Ž<#q#ŸfîíqÔ©Ò=N%ù×UììΣ¡¥C²F^^&O÷‹ÁV牷‡…Ó—ïª ìÅØÛòùÉæÜ×É›Ëâós ÐyxâV s€§§'•¶¬ÊR/"‚6­[UʲêÖ ®²ò«®ÛY]ëUTnˆmÑ¢»víàСƒ¨ªJ^^¾„W °BˆJgŠæž'î`÷Ó‹1}‡ ¨úKèjÆz>ü.““úR&¿r6­¿hßb6ˆzáz6ŸLEíq™í35d/\q Š8}*úá»)àÄVhÅébÆl¸±‚ƒƒ+-è„T U¹¢-ŒÃ‡ÞÆ]wÞQ)Ûe±X(,,¼ªyjÊvV—z7ƹ>±çBlrJ  ’ð*VQŒõ‡1ñÎm<ñõglè0™î~Uà´ü,xíc»MæÉÖîeZIµ‚ì:f üÖâÃe¹Ò¼M4o¯ØMÚ¨ê^ïædÛAÚŒ ¾¸Ç^æŽ{™#ÞeöˆàÚ6::š}ûöUʲš4iRiÛUPOAA~µÿ>W×í¬®õ**ŸŸŸ­[·eïç_Hx`…¨ÊÝ«þ°ñŒÙ:•¹l éÓÝñ¯‚§ìã£gg²1ü!^ǹѹTN-|†|w“«¬ÙúâÅ–ÅÇËRðît+¿øŒeÇð@Ôõ427.gkP_f5¨žÁÇÄÄàççGffæu-Ç××·BAGUÕñ-­)ÛY]êU\Þ¸ÇVéô>>>Lœðx•®ã¯šçf^‡X!ª}†dÄßï#mXœTÉÈËŠ[nû#›7áâýa:Ân{žy]sȳáÐ\ ǯô³ÌqÜ3f9O}²Œ¾Ó‡f0ÑëÙ¯éu™uê£îáÃEÅâkþæ/L£Ï¤þ”è~kˆcÒçßV‹ªÐétôéÓ‡… ^×rú÷ï_¡§5Ƀ jg½ !ªÉ¾/E DgØð[™0®;aÆ*ZâFÖÅÃëùÛäEp4Œ¢qT9áõü! N¯Çx,d ³ì#ÿZ²Œ#™oÏ'màÜíZ­ë"&&†Î;_óü]ºt©p+¦iÕú¯¦mgu©W!D59·Jq“S|è0þ5gXÑkÀÕŽ  yÑöÑWèíï±|Ü>}ú°iÓ¦«9½{÷®x±H l­¬W!„X!Du¡3á[çŸnô À¿åuE¡oß¾„‡‡³jÕª+öôóó£_¿~WÝB§i5£oiMÙÎêR¯B °BqÃDGGÓ¸qcâãã‰'%%…ÜÜ\¼¼¼&::šèèhtº«ïm%-°µ³^…`…â†ÒétÄÆÆ[éËVÕš kÊvV—zBH€BˆZKZ`…B¬B\“É“'ß `(}`kc½ !$À !D­%-°B!V!®ÈhtÁf³áâârCÖo³áâbDÓÀápTÛñNF£  Õí¤ZÔ«B¬BT:??Ž9DTT#\\þÚ‡*ØlE9r?¿4 ’“ Âdª^w°Z‹HO?CppPs¶³:Ôkm'!]ÜH6›]¬âæBrr2»víÄn·ýå'?¿‚ƒCÐ4ôô³ìÙ³‹ÅR­ÊÈlv£^½úÔˆíT¥ZÔ«¢ú+„¨5E!44”ÐÐо-[ÆÑ²e\µ/³š²Õ¡^…Õ‡Œâ,„B!$À !„B!V!„B¤¬¢–;{6´´3IaˆZÏh4âççOHH(Š¢H °BQëÕj¥sçn˜L&)ñ—X¶ì'úôéCÖm±XØ¿/ÉÉI„††Ie °BQÓ¤¥¥Ñ¹sW ¯â/—‘‘~CÖ«ÓéhÔ¨1»ví+$À !DMTTd•ð*n*ªª`·Û¥0„X!„BTœ¦i7lÝN§S*@Ôz2 B!„¨Q¤V!„¨d7²Vˆ›´À !„BˆEZ`…BˆJ&-°BT-i¢JÙ((p”ÿNâVoO¤°ç¹+M"'Ë*`9Ìšo×pØR¡‰Éɱ•ûŽ5~9Ÿ/;HžT‘BTi¢ 9ŽÏÓ¯å0îßãh骭€œ* ?Ì彜ÑÄ4pÇ (3^ž&ôöLŽìKàèéSœ8šÀž½É|€þ¡*EE ÈÏË%;;‹ô³i¤$ŸæLäý|<µîÅ"oîîEÌÛν÷u"Pñu‡¥«Î„‡«þâÔ…‡øî£ux¸Ÿ¾¡Æ›¬–T,YgÉ)*™0ÕäE<ÿR­flHÉßúŠ«7u|ÍZì»ß ÷gyc÷»ÜbÕ’ÅÙœ"4l}ëþqvZùR(FOüýÝåà[ËÉJ!$À Q3Q&©éNâ¿Y…ë­Óiš»•ÅÛ¼i§~ÉcŸœ"ÐÏ ¸àÃw<7õ;°f’ê=œ÷æÜId^<¿ü¼‘ä´=ôÅK3'R´vKÖ)¸¸špsÍdçÊà ¿·ö¤nHáÁ~˜‹­Þ™´œ™sè¹½!SöQÇ­ØçvæqÆRHüÐÎ| /L Ïr¦ù]õ¡Z ÇOÛøýÕ0[I—ô%¼µ,þêó´yú!ž(˜ äuõ|-?™užbÛ¶Ñ\/»‰BH€¢±í]ÄÔ9`3¶çéx²õýøµî3tóCÜý¼÷lÓ¾ñ îøæÜ¿u~yôÙùü ¦ç×§'YãC‹f+ƒ hÎB²Îœ$ëÌIîö¡i÷ÎDy( žeå¼Å¨C_a@Èù”ä<ÆÂÙóIìðóÇÄâ­×°gŸ`ëo'pª -ïf\ÌdÞ[Ø…¹ccp¹©jÌ•¾oíㇻ=/æÚÓÿ¦wìbFnZÍ„ð‹-°y_ #ìãsÿ¶®{…¾üD‘ëm|6ÏŸe‚/.bD¸ô~ƒíßÁ£ØZŠßI—eÿ¸H ¬`…¨q\š aXð:~ŒêFƒÃ_óD|k{8Ãoà8¸˜çŸ]Mñ85÷$v%âÜ¿sN°óÐN%Y°ÅóûV•ÓÙNL6ª…Ø5•¢‚ŸûÌE‰ì¶¤‘2¦?¸ &N7FŽl‰‡¦îÿà ¿äß­GÓâétû}ï¼Ý—oÀ¾é5†ôù¸d=ŸÝ‡M×Tv °B °BTCú?2‚µÿú/S·ѸoLÿŽûz‚!¼÷?ЪD §}÷þ¹îü‰/}?«Wîâô¡ rŠÖ²Ô³?]±ëðùGCª™hœ©§8‘~u‘Ñ óT‡7lÆÚöZ‚ª)„pßTöîÏàŽÐ:—¼{SØ‘®¡_±n{½{{¡8öñÁÄ9œô*ÓÖ¾;?oºLø7ïuÝÉÉü‹¡CK[ÌÄíëèñÄ4F*Åòn$­âÂq04fü;OóuÿÇè÷cmÆ´A3yi bGóâŒþ%ZÚmkþIÿ¯d÷B °BT×+¢/~ÇïIŒîÅ×k>eÛZQgΤ•°Žœ¢ # èâéÿkÎOìàÐ)7ÚÜÑï_p¦îþÑÍì»ùx{&þ½F04R‡eë‡ük ã´VxjYÄ'dQ¯_TÉÛЄ;Æuå™YÏñ|âíŒØ•æuÍeèΗƽX gï¸óËpP˜“Mžµ6?žÒûÙƒì;zqÄ-+…µ€”„}ìK»` CèXlNcÓ±Œk=ƒé xkr3æOaùI´Â³œÀ]£n'??_ K °BT£o-: £mÛÝ,øÏiºÌx–NI?2ç·\|cP0ÒPcë–Mø¶ã­ÒXôÂ{üд9Å*$ü²Ž3f7¼ÚßJË߱ܠÐ`Èf ôC±oâÕ{¾¤îøéŒm¤#ÿ×W¹ï×?×íÄáУח¿]ná¹÷©ÎŒÉ9ÌŠÞæ}íéñ IDAT•g³xnö#´-6ê€Þ ÕÉ…¶HÅ¿Z(l~÷KÌ(öŠúÿìÝwte߯ñïîf“Ý^I!$B¤#Mx¤ˆ€¢`o ¯ØÀޱaÅÎcCŠ EŠ>(Ø%Té‚ = !=[gß?B = A®Ï99vgfgSöš{î™Éx‹E§Ðgø¨ƒ.â*_Ï€šMøÏeµèÙó'Fܱ†¾³¿¦ÏºWø¿Ï³‰íX ³ÉFjsƒo¦}IÌEOñj·Í¼tñ`Þ8ÿ^è`צRcO ¶¨¨ˆ¾}.8,ÄÞzÓ ®¹ò UTX‘Êe­Ká‡cñõ9— ÓnBw}ÍKkqk»Öä–²aö$ÒãÏÅ _'}BÍô%Ì ¼’Wøã˛͗³Ch×–ÚÎá²ëýùüëí,œô ý¿pSà*Áï™ÁübŸ×‰%õ<Ì&ÀLhP)ÅÆ1çÏZ^wÝÆ¦ÛžcæÒþ´:?ðÀiA1æ `Ï’VB_ö8ú¤áç!o\nƒ9u¹ÿÐüÐÿ®ÿšAuSÈ}àŒ¡]ˆ0o'jó« œß‰ûneÁŽ"–}ú“ëuÁ ‹ÏŸ~Œ”ÏfñAÈ£Ìn«ð*+.><Äî ¯EE ¯" °"§ƒ‘CÆV¨»÷JæˆPLÛ ˆÜ—FÛ¦ñàÌf\Ü9ŠI·¢½í>Û֛ѣºk6ØþóLÖ4êÅ}Q_²´ÄBB‡K\¯×ïë‚ê]˜a_3ä ®HÙÛÔj¶•]TdŽ%¹–…[vb´K:ö)K0aA^2K=ø`o—'[sˆO©ÅÇxq•8ðúÛ±ûU¿N¦èAü/ÐÁ/º×ó^ߎ<¾Ì‚µÙ~6˜Ô#=ßÁÁÚÕ>š†—Uσé¯lê¼þíÖ¼D·w»sÛuIŒZÜ›KkLä¹µw‘þë’uØê`tw!(**¤oŸ‹q:ËŽ¦®¹òr TL‘#УdE*ãÇ«(“¦Xâíe›˜92†ÈÜ,vå,âí¾%ôú›¸  æ.¼ù*Òr–0oS >ÌÄuº‘á7´%tßÖéÝÈ7c^çå×öþ½ñ-kÝ{ømÒ[^{s&k½4iÙ€¬¥ËÉ*ßkl#}ÚOü¹Û½·ÿ¦›] gðóöΩt ¿¬s ‹×„ѲE܃g%càá¯waœËαeOõéÊ“%CùzéO<ðöyšï¶8_Î{þfƒ¹.©ÁeÕ²$Ô&nǶlýw_3†È'_áÚ83Xj3è•Çh½mÓ—èB.9Fˆ-âÚ«®àÚ«Ôm@äXÔ+R ¼[6²½V}jû•`ªÑ‘;†ðßÇþK~·‡yªK æÕ†ÅŒ­ö%Ü×ÿOîõ<5Εiçp.^Ö—E$…at¾õN:훸{)ïÜÿ5QWáŠýMy&^²Úî"Ú2™{2(uß&nÃoÏ^¹} 9~aSD¾)‘ þo(WÔÞU}äΛŢØî¼\çìj"ôlaùÜøß÷õVÜösG\J8ïó9$½0„!-ëwñ ú_u Ý;6¥vˆî•KX× -¬e­d¦°«xë­†^x9§ñ¿þÉXæzñZül<ŒŸCç+úúÕTh‚®åª¾ ãä÷òóóU@X‘ÓÏב[¯L$È4oï+,N7µox†«ÛmãÍYì,‘v+Ñf 1ÝïedÉ{üåÀ—X.ØxÙð팙Wtpëg¬¬O_æ©ý/XH»ò î» ³½7\7‹ûÇͤûÈKHôÌQ´¿éIÚtS”·‡B¯ÈÈü˃ñ-aâYtÖƒ„òçfüš1ìã/«qÒXÏë½ZòžÖôì7–]K§¤r}TýâéöèW¬´€Ïß{ìÅ}aòGú}Ôª{/?ÜpÓä½ûãWâ䜧~æ¡ËÖpG­8fçQÒæ5jYüHºéc¾*¸‹ › ñ)ÀVï}€d R©L;wîð,Y²˜-Zq %KÓ³çŪ–T;3gÎ8æzè{}m?×.V-ϧf‹4¢ö7jxJK)q›°b=bGÅ«øË“L‹”à:¾<~3’Ïoæ™ :Þ<™ÌzáÒ›ÜË“}jW›ÇÈVtßåõx0ûùU°Î><?¿r­Ô¥›˜ûsÉ=Î+;`Ø»œ]Eù8,G„ [gÕ~%55í_‡õë×}¿tþþV-<ù׸\îú½U ¬Heò¥qëØC^4ãg¯AÈ1/D7Q£VZžô¡iç EÚn–Wh#“…Ðê¶géÄÙøfñ;‘]¡éàð `O¡cï”Ö³P8QAÚ ÎFj©\ °"Õ•ÙFx´­bÃZƒˆŠTÉDN]€5TX‘ª`Õ+¢+""R…†¬ˆ¬ˆˆH¢XX‘*`ÕVDVDD¤JXµÀŠ(ÀŠˆœ„€‡›Í¦bÈY`½^V«¿‚Tkºµ¶ˆT[11±¬Zµ‡£TÅÓ`ÿ¿ÒR™™Û‰ˆÐ}ñ¤zS ¬ˆT[ÑÑÑdgg3þ<œN‡ "§…ËådöìŸÿ•϶ÛINN!..N B`EDªrˆŽŽV!ä´jÛ¶ƒŠ R‰Ô…@DDDD`EDDDD`EDDDD`EDDDDVDDDDDVDDDDDVDDDDª ÝVDªµìì,²²vát:U ©ölÄÄÄ£bˆ¬ˆHU ¯‡ƒöíÏÇf³© g¬¬]ÄÄÄžµóàp8XµjÙÙÙz€‡TkêB "Õ8ÌdѸñ¹ ¯rÖ°Ùl4nÜ„¬¬]*†(ÀŠˆTEN§CáUÎÂkÇét¨¢+""""¢+""""¢+"""" °""""" °""""§‡Óé⫯¾¢gÏÞ*F5¡ûÀŠT*ÅÅfjÔ8|Ssm[œ]1´k‘H éð1}ÎBr]þ„èHSDä$lܸ‰>úˆ?þ„Ý»w« °"RžMÓxpT>ƒßLS0\Åä»ða°vúÞujàL~vB‚mXÊâ+Ås_çæô¶L|²!Ž•|öæ7¬÷í“üiÔ÷n.o°o“öQ°|2ïÿQ‹´#ÆWB~1Ô <°Ñ ˜ì!ˆÈîâ|JÍ5ömdêØÙ„ôH÷«¦…—Òü<öP‚ýOìPË[’Ën‡¨ˆÀ#¤ütåìfsæÌaüø‰Ì˜1¯×«¢(ÀŠHÅö ¹ìÌñò×ç?pÑHÎ)XĔš´6>åöq[‰‰°þ„1•džOG.;CûòökW“b20|>¼>`àõ~5iöŸ H:Ú~Ød&:æÀ¼wû,^³–ö#.'ÆÞM_ñЃÓ÷ƒÇéZÖÜëY9Žÿ{ü{l—=Ïû7Õ/Ûørù~ÔíüÜæM^êSÒyàù Dº™æA&-W)§˜•ãï玓Xá°áç0ˆëz'£ßz„îñ–ã^úÏtîĨÀQ¬ûån’̧hºrÖÊÎÎæÓO?cܸñlݺUQ€‘åZ9™á¯ýŽËÚ†ïfÑ»cù¥æCœ~Íòö£±—Þ=ï%®ü|ᅢ«Ÿþ…"Àb®¾l Á]ᦋxï›­)Ãú5¾žçÛîMF6ß¿?ãÒgé¹÷ß’˜F½€Ÿø{«—Müƒë7c‰«Iᆠäõ‰2Þ­¬Ï§þ á˜1Ôôz7¼—·¿èÀ˜›â¯E+øÈžz½Êä¶)kù©c ~%ë™<ôR®îkâç9ÑÌÿØáwÁS·ðæZ4?•Ó­ºíí§ùãÌo´ªUÀ²eË™0a“&}ŽÓéTA`Eädù7¾„ËâfóUêùÔù{÷üÕ‚ÛoMÂoxÖLáñG¢|[’Q°·)iÿÿ­-ïdÜù¿qGz[ÞùÏ"†-gîV6ÖèÄwžÇgKìøöyFlÏßl=ëg2ek † =pZÖ¯ RŠøiãnŒ&±˜q²ñï,êõèEáWëÙè…(3»6²ÁU‡+jïÛ5ØiÚ¯¡÷O#½_º…©VcžNü½‹y¨cLÙº˜ÊU£_dVÃ[xý‡{×»ÆQÃoÁ¯qëäÆŒ¸'”G~=UÓ•³IQQS¦LeìØ±¬Zõ§ rRÇ"‘Ê`‰çâÿëGèìwþöÒºùóÑÈ©l1À¯Öù ÔŸ›Ëý üOrÅŽ&Mf,ËÁeJÏ]€£U{Î-ÿUSõӢɨ°€7ƒu[£iТõl›Y·ÝÀµy#™µÒ¨Pn'Ó–Ž «˜ýG!¾ý³Š÷ǿÍÂÐÒ> ÓÃB殬M·îu:#¸µs°pÎê²õìHñuÏ ò-íßÍe1æS6]9;¬_¿ž‘#ŸâÜs›qÏ=÷*¼žÅÔ+RYWRwzÕÊG¡ÃÒ7„I?gñ.?|Î|víÊ:èt¼'ßy E@t8çóÚKóy§‡•ýà{økí’/L=dã¶T¿.æß7²ÍhCJþ&6”ֿЄd “søeC ¾d;¶”Ú‹èò¹ÂNZZ“ÿÚˆ·k³½ÓõP’ŸG¡CGœ¼™[Ùf$Ò«Ö¡}Rm$%G‘¹e^ZþãËaÆýwðk·ÿ2¿g$EcNÑt¥Zs¹\Ìœ9“ñã'’žžŽÏçSQDû‘SÏGÉŸ3xÆ\þáÁ’<•Çî+&''‹øÒËéÕ €u®ÆÈý“Ÿ~sÒèÂ$XRé}~*ÁGd>yöf\|IÓ#¿oò±³ØGR@Y{ìDGØ8ôd¿_Ý4jg-cS‰Z›Ö“‘T:~v Sc·~3Þ.Ilܸ‡:Ô>dÇ`&**œ’¥»)õA° °4¤ÿ‹oà ‰Öiœ³q w”àÀN íе̄ÍnÇp”âÙ.vNưßû0n^7ÂLE§dºÿL· Þ´2û£m}ýlë»sçN>ÿü Þÿ233µá‰¬Hå2a OâÜv—ѪÕr>úož”vÛ¿âµ9„7ŠÂ„•øº>-œOxË븭y“Ÿ|›éç4aÀ‘&éÝÈÿ^KgKÃÖÔ ‚’-Kø½$™N #1ù²Y9·n¯Œ¦-/Ë.Ö6‡¥R?ü¬ßê¡Þ†ÍÔ¨Óƒ“™àºÉxo$Ûë·ÅÓ Õ~ظ? Þ§oMDÄÇkQŸ­kx€”:÷Ñ©‡³ÍÆ¡7^3¶}Ê]¬æšÏÞ¥Sð©›®T³ƒ#ŸôôtÆŸÈ7ß|ƒÇ£N#¢+rÚXkÆRøáX|}Î%È´›Ð]_óÒšFÜÚ.‡5¹¥l˜=‰ôøs1Èã×IŸP3} 3¯ä•þ°ø(5GÓèŸbbÛ—±:£÷ÜÓ «{!£}¶w˜`BƒJÉ(>BÏTK êóõæ¬ßCr§D,€¯N=jo_Éú&6Q‡Ž±‡·©c >âäìc‰K$Þ´­Û¼UþgÄÅö­ÙÄÖŠ?¸+N~|ê>þgiÆÀI2lÒÞõjÅzœ¦1òžMÄžw+O÷:ÑéþsgB«æ¡óp6Þ…   €iÓ¦óÎ;ï²víZmd¢+ò¯0rÈØ uƒöæÊˆPLÛ ˆÜ—FÛ¦ñàÌf\Ü9ŠI·¢½í>Û֛ѣºkwùéx2Xðûv°Dƒ‘É·ÏßÇpì ÀùwÝõ1&ŠÙå$ÀKr- ¶ìÄh—tÈé}ê¥Õ"cíVo©I½:e½pMÁuH ÁŸsLd&· îa ÁIÆÖâSj•kýòâ*qàõ·c÷S'‚³NpÚ5ØÄ7¿leD³:Ö³’ùü¸ÀJë«a¼ŽBŠÜV‚ƒ­Ôé÷$/Ÿ[¾5ÍGÞ;æŒ(’SS‰‹­©‚Ó•êcß-°&Oþ’’’D*L¿<"•ÀW”ÉS,ñö²MÌCdn»rñö ßzýM\as Þ|i9K˜·©` N ~RXÙѥŠQ͹¶[=,æš\xϳŒ~ñY¾(‘àVƒxéÅçýÜ´Øß)0€&-µt9YÆá›{DZ*¶?³À•L½}WjY©ŸœKú«‰LK=¼•Õ¹†ÅkÂhÙ"îÀó’1ƒðð×»t‚³‘¥7ÞÙu/c̲‚²uÀ½YgRÈ îì¸Yôx bÛ?Ç …Ô‹nãÎ;ï,÷w;%`?ŸwÜÁ-]kc®Ðt¥ªs:]|õÕWôìÙ›.]º2aÂD…WQ€9x·ld{­ºì»ª©FGîÁ´ÇþKFçx K fÃÀ°˜±Õ¾„ûúGðý¨ç™¼®KÃ+yê¦VÔ0%ÐuÐ-\zN0fJÉ\½”ÅK–²*³÷îõü±d ‹—l$wŠ4Úî"ÚçüÈ̇÷ó«Fâòk§’²¿¥ÕŸ:õÉÛí%5­æ!;¹óf±(¶;ÖÑSäÀOGÂ2ý>ïvK">5Ú5ÏaðÒóyúÓ´ <Ó¦+g‚71räS4nÜ„Aƒnæ·ß~SQ䤩 H%ðÅuäÖ+ 2ÍÛûŠ‹ÓMížáêvÛxsà@;‹p¤ÝJ´ÙBL÷{Yò?d9ð¥rÄ®¦>'YÿbUÜ’ ƒ¬ùs5;É+7+{3n¸n÷›I÷‘—X~+·wà±/:â.{žo/;ÂG-aâYtÖƒ„òÉÖ¯Ã>þR úlf §Ý½_°ò®vlÏÁGb¤½Ü•v/ý㥣‡ÕÄ;~¦ðŽnõWú¾†Áœ9s?~"3fÌÀëÕ­÷DVäŒeiLûÀÕŠÖ£¦ÍLx«+è@ÃÞiL‰Û„=(«ÀNÚeCI;ð+Ž­é•<’QvJßÒ€kFŒÄZ;…˜Cï!ä+ä’ÿdã¿ÿ9ñf¢»ÜÎíäåRxf`c‚Næâ+O&ß½>‘¬^÷r{ƒ-T9ÊÊB\rHÕ™®œÙÙÙ|úégŒ7ž­[·ª ¢+R¥øÇÒ¸uì!/šñ³× Ä~œ3ª>m¢öåÙ$¤¥y@S0‰ ¹/‘)Œó†Œ"m·‹8™ë ¡ÕmÏÒ52HΈH…ì»(kÒ¤Ïq:*ˆ(ÀŠÈ 2Û¶üøÖ ¢"UF9¶¢¢"¦L™ÊرcõhWQ€‘3×úõëùä“O™0a"yyy*ˆ(ÀŠˆˆÈ™Çår1sæLÆŸHzz:>ŸOEX9óìܹ“Ï?ÿ‚÷ßÿ€ÌÌÌ*ý]""¢´@ÏÈul‡¬ˆˆˆü3>ŸôôtÆŸÈ7ß|ƒÇãQQ䌡+"""û0mÚtÞyç]Ö®]«‚ˆ¬ˆÈé`Ãáp`³ÙT 9k8¥'µÎï»ÖäÉ_êÑ®rÆÓ£dE¤ÚЉ‰eÕª8¥*†œ5áuÕªÄÄĪR­©VDª­èèh²³³™?N§C‘jÏf³KTTô Û¬YSš5ÍÈ‘Oª (ÀŠˆüÛ!6::Z…©  èOÿþ7ê".9c© ˆˆˆÆd2ѹsgÆËŠË1â âããU9#¨VDDDŽ©fÍš z7C†ÜVåd››£zr¹Ü'4¼Z`EDD¤Büýý¹ôÒK™6m ¿ý¶€¡Cï&,,L…‘ÓNVDDDNXjj*#F<ÁŠËxõÕÑ4n|ŽŠ" °"""ræ bÀ€þ¤§ÏæçŸbÀ€þ¨0¢+"""g¾fÍšòê«£÷_ô•””¤¢ˆ¬ˆˆˆœù¢££:ôn–,YÌ´iS¸ôÒK±X,*Œœ2º ˆTkÙÙYdeíÂétªRí؈‰‰!::挘³ÙLçÎéܹ3›6mfâĉ|üñ'ìÞ½[ K`EDŽ^íÛŸRφ—ª'+k׿þÕs«V­ ;;ûŒ{€GJJ2#F<ÁðáÙ5«ìV\³gÏÖJ+'wp¤ˆHõ 3Y4n|®Â«œ5l67!+k×;nŵÀÀ@-ïQÞóüù9#ÆÌ!Ç8msCÁò/xåÃdyËþï*Ê£ ÔsôQ<%äåãò¯dSÞ|Ÿ¶»µ`Ïž"rví¡Ôw´¼”æï¡Ðu"+YEÆ9™éÊÙhß­¸ö]ô•””¤¢œt ‘J r{}˜Ÿ¶aTpS¬wñ\ÓäÄîYêÍYÈ[OM&øŽç¹©¾õw v¬þ¥ë²â7ŽÔ6a‰¨KëúQœª'”{·Ïâ…1ki?ârb,Næ¾~ /ïìËë¯^O½Ãö8–}pÿKaøgÃùO`=ztJçç'5êfšé‚5»f~ÏW_Ï ¿·äÝ­3¹%¦üò(fåøû¹cÄ$V8lø9 âºÞÉè·¡{üÑÖ¨ŠŒs2Óèèh†½›»îº“9sæ0~üDf̘×ëUq`E¤¢¢ëѼiÔñ¬w ?LœÿNdêùNåÅ—¦“×áž®g= y,_žA ÛÎw3¶°Kv¬cSÛùâ±Îœ’gàÙ|ÿþŒKŸ¥ç!Aûå&ü܃§.Œ:è´±}~ÌÂGÊÞWL5½žÁ ïåí/:0榆økUúWÀò½Fÿ«_&·mkR–‡½Ÿ=õ6z?”ÉmSÖòSÇüJÖ3yè¥\Ý×ÄÏs£™?'1ÎÉL·úéÖ³7?ÎüF«âI0›ÍtîÜ™Î;³iÓf&NœÈÇÂîÝ»UX96)çÑ+åøA¡hÑ›|fkÍUM*ÖËW²•Ù“ÞåÝï h>è»0û*³ùa}#ú¿ý8½"í-äaÕwðøž¬§è{ÖÏdÊÖ {Hß$?ê´mÂŽ/§°ìüÿ£…}ß)`Þg3p¶hEü’òÃÛiÚ¯¡÷O#½_º…©ötó®|‘ž—~J“WgóYÓ/¹`Ư‡¬\›øhôtâï]ÌCcÊZðS¹jô‹Ìjx ¯ÿpãz×8ñqzî:ñéŠCJJ2#F<ÁC=È”)SùðÃq*Ju9PQ DþE¥køtÂB"ûôã¼ãœ.7Š·ñÛÔ7öñá–†ÜñÊË<ØãÈá_ &Í`Ïù}hg) ø°f`/{vÊ©‰‡þž»G«öœ{„^ .㺔E|4sÛþþºî _óéÚæôï„å™0Ç´¥cÂ*fÿQÈþ®—žU¼wÇ-<þmêYÙMçpÏ·é¼{M*¶#­ E ™»²6ݺ×=¸ûIp'.jç`áœÕxNfœ“™®HØl6®¿þ:~ú飺ì¦T‘JæÎæÏ ^ê7¨yðçÙů滠Ëyñ²ÚGÜ}®=lZµ„ysfóó‚õ¡6rÝmxô±h{Ô¦Sƒœyïóß ¸etm¿y;ogÔ§Ç¥—ѯ[Sbo&›2 [%” > 3V³~·_…¾˜ kd]× Âdì᯵{H¾0õ(;•0:]ß“¯FLb^×ûè¼›?þ…°¾£hYã{>8ìÐ:œ´´&ÿµo×f{§é¡$?B‡ú³U6K˹êï{3·²ÍH¤W­Cû¤ÚHJŽ"sË6¼´>h]¨È8®“˜®ˆ(ÀŠH%(Y9™Fm ÛsÏÑ¿ÞÞn¥[øöõçxK |¶/u­‡ÐùãyuÊbþÞœ/¦mο€{Þx„†;'0๒c~ž±c/½»•÷>MçÈLÃß$î×|9õnþ<‘ .»š«›ná]ÉtjT®Ö˦ÞçåÙù °fB;ßÛ75ÆÏÈ!kèÛQ[t-I½èßò^ÞŸ¶Ž¦Í~勜Î<Ô=ó–#O;**œ’¥»)õA° °4¤ÿ‹oà ‰Ö©£™ÏQ‚;‡5Ïš°ÙíŽR\pÐ…ƒÇyÓý§öõ7=žÊìz´y8ôuõ‰Q€9m›`X×xrôGœûÒ@’3¾ã½·?á÷=yì¹ëin>,¼Å7¡ë5¸½A]‚l¦žˆ•5»pï‹í‰Ž ) “ÖHw@ã®W°yá7|öùkÜ6±¿&·r~¬ù ÝÁ¹7½Æ'7Ì·ôâñX°ó"ñ@Z\Õ—ÈÆðè¢bR¯{…úVŽÚÀâgÃ{à”±)€=ýŒ` °€ƒRç¾£‹ý1‡ÃÙf;¬ouEÆñ?‰éŠˆ¬ˆTʯ} Z ¼›¾Žà™»â)´ÒìòsE3¢²Ú’[Ó%ùd?ÏFlÜ:¢škÜþJî ÌcýÓ+iwÝÄœª¦Ls0¡A¥d»wª9¦ 7]±†·4a@»c÷¿-*(ÆL ®á:ãXâ‰7mgë6/D•_‰]lßšMl­øÃnÍV‘qüãŠOxºÿԙЪyè<è.©f2k IDAT"øÙQ DN[n¸çJ ‹ixÓS?.°Òº}#¬€×QH~¡£l˜ŠŒSÁ銈(ÀŠœ&Ö”ËzumÖLšÀÜÜÓÂ<Åd,ùŽ÷FÞÍ×V|ó3<Õ¯§ö¡‹4iÙ€¬¥ËÉ:_͹†ÅkÂhÙ"îÀNʳ’1ƒðð×»t‚›¥7ÞÙu/c̲‚²åáÞάG‡3)dwöÜ,z¼±íŸc…§‚ãThº""êB rZ7·”ˆpÝ¢áŒyo.ç<؉ÈJ:„4¶Íãão—²5cëþÞLž­.ç]pÏÝÕ™F•±Ù›mwí?™ÀÌ=”úO>ÃGî¼Y,ŠíÎËuôä¥3µí#áÆ™žó î–Ä3a1ìÉÂ×d ïOšv';ÎÉLWD`E¤’·¸Úô»kY3¡ÔË Ÿ1'Ѽ…‹ðãõ õó# (žs/hÃeƒë“–Še÷%µ7ã†ëfqÿ¸™ty ‰~6º<:‰.ÇÍ’zL._‹–0ñ‹,º ëAÂAט5cØÇ_j:Í, †³¨pøVÆpÚÝû+ï*`ÇöÜÁq$FÚË­ÒVÚ½ô7Ž—Ndœ Sͩ靖¬È™·ÑÕºˆ;Ÿd˜HéÉ8sÍó¸úºÓýÍÌDw¹ÛÿÉË¥ðÌÀÆhhödòÝëÉêu/·7ÐÊRXCˆK9õãœÌtEDVDä„™Â8oÈ(Òv;°øà„óå ¡ÕmÏÒ52H눈ˆ¬ˆœ&fáѶ“×DT¤J(""Çù©Q DDDDDVDDDDDVDDDDDVDDDD`EDDDD`EDNX@€ ‡Ã¡BÈYÅá(Åf³©¢+"RÅÄIJjÕ ŽRCΚðºjÕ bbbU ©ÖtX©¶¢££ÉÎÎfþüy8j‰•êÏf³KTT´Š! °""U9ÄFGëÇ\D¤:QQ€Q€Q€XXX©‚tX©¶|>™™ÛÉÍÝÛíVANÕj%""’øøL&“ "" °""•-3s;N§“6mÚa·ÛUTZZÊŸ®$3s; ‰*ˆˆ(ÀŠˆT¶ÜÜÝ4oÞ‡£”’’bä™ÍfêÕKcÙ²% °"¢+"r:¸Ýn¼^/†a¨'a_ÝÔýBD`EDN#¯×«"¨~"RÍè.""""R¥¨VDª5ŸÏ§"ˆˆT3j‘*E-°"R­©VD¤úQ ¬È¿ÉëÂåq’1w:?lt©gNì%oé׌ÿy#ÎÍAqÉ‘/zråläÏŒ|*z?_é2·ï`O©¸ˆÈ¡Ô+R‰Œ¢ÝäBt•ßcä`é{÷16d(F­`Ü¥$¿t-õ¬§1¦y<~~XNað+X>™÷ÿ¨ÅÚs„ ®bòB‚m˜KÖ1uìlBú ¤{Bå|ñ“ju­eꇟò½î-aóÇ·íGÏé¹T®5“¸ï?î}=õúîYéï3b]o&>Ôã=RÁ›µÿ>÷KÜ6J­M¹ë‘[hcÑ%"¢+Réñ•?¾Âí®Å^“ÚÉ)Ô©“B½fçsaÓü°Ñ´oBú€ùOÜÍu¡#ù8½Ovàt<´Ó›³·žšLðÏsSý}áÑËÖoðQ~n¸¬µkœØIïöY¼0f-íG\Αó–Aî£ô]ÞxíjRëÑ£S:¨É×G`­:øÿø.w|;• ®¹™A=q„=…{Ófå$Ñ£uþF6ß¿?ãÒgé_ÑÖBAM¯gpÃ{yû‹Œ¹©aÙ´N¡k5ÈYð>/Í€Þ#úÒ&®lixwÿÎ{Ÿ®'öŠá\™XÈ®¬ÀD@P¡v3î5SyüÍŸ,yø¾\¦<ü?ò®}.-LDíýø=ÆßüaJ¦e«úX÷Øð?ðùð•}K§¾Ç[ÿË¡ù¯ó@—pœyê|…w’^cø¨á¬¾ä6îêw.‘jŒX©Ôk '1-œÄ´ft:BÈmÓüŸ¦ò“§ÝRËg©\þZ°’í®£0sX=Ú7O  ¢a®d+³'½Ë»ßÐ|Ð3û÷]ýè~Ð%ìX¿–5%G`Æ®eüXÚ‹sš&sœÄhoã÷ï¦ñé´ùì©Ó›;^¹’Ž Çˆ½æ¤tÈsmº1ïÇM$DòÞ-,ü#FWìkMôð÷Ü8ZýçÚN"äÇ´¥cÂgÌþ£®]CÊZ¡=«xoèkdô~Ž‘½b*ýÔ¹¯h!~°ŽàZ!Ä6‚Iw6)ÛAzVóö §pÜ;Žûšïm­6r˜zÿÒ­eaÛç £ÇíWñÝÃ/óat¿è7û „‡Ï÷°5ß|äeáÉ]ÏÂù–²š™‚©Ý¸.‘Esxó¥ï ¼âwOâ­Ç3þ‹Üd²wáÃŒ°Îâ—ÞÁúÒt3i;X9uŒÂ6¬ø™ß§mbË®Rl±µIkw÷ <Èri̳n!‹ÜMRÿ‹˜Ì‰\0`0eúî£Iÿê̵‡M«–0oÎl~^°#ÔF®» >vm+x½”ÉžHÇK{½tÅ,~ÜÓœÁ­ƒÊ¦±‡¿Öî!ùÂÔ“Û©˜ÃIK aò_ñvm¶wJòó(tü³G™V¸6¸ÃÇwe˄ۙµ†yó ÊZ8Lv¹Ü8×,dnɾWÄ–BàÛ;}îÈŽtKøœï[ŒàÆŽ¿³rÔRïfuY'XL–dÚGî$ýç̲.~ÉôLK!2¼;ÏNº o Eòj½] _˜,Vjµä£+Üã2òËi_1ñ“OùU¯½êJ®½ê m¤"¢+"‡d²ÈÖ Þš€·$›Í6°ÑOHù¦D_ ¿ ™íT|ªAÎüñ¼:e1oÎÆÓ€6ç_À=oÏs±G›{7%ùE¸ ¥…. ¥¸¼&LÇ* ÛIžÛ3ÀÂQR.n¸Žàà`Þ~çÝ#¾ëMƒ¸öª+(**ÒF*" °"rt–Àhê6‰¦î!¯—¬þœñKjsÅk Žpñ’Â_G3䃸$‹)­]ï° ß„®×tàöuI>°‰{vž‚/â+fåG¯óy~G¹²~¹yöâñX°üƒN™? ^<û^0ÿÏg¹Â}`}x½^'±]îä…AõÊZ`=kywð38n}š¡M÷u!ØÍWßÌÜ}ÓK¦U—èÔz¯Mtsí«Ã ýiéc†rպݩ Ù/±7ïI‚|>+ÇßÃÈÙn‚mG/¢×Q„_çá|pk“£î¼‹ŠŠèÛç€ÃBì­7 âš+¯ °°P¥ˆ(ÀŠÈ‰óìø•Ñ¯Ì&úúQô8b'VÁ†2®Ã‘O)»{þ3Ý–Üš.É•0ÃÞ\þøøEF}çÏåOÞDëò·¼2TJFññoÓïq{Àl>줢‚bÌAÁþ›Ý:}òò–5¤§gîí±‹í'®Usù5ß¼?ÈoÌ;°TÌa1”.|‡Ìf)ØüòñÌ‹Éþƒ¸)þ9– áí›´³-û ·|ë)·\MXý-Ôìó“îl|”³‡o à±Rëq[¹‹‹±ûÂkQ‘«ˆ(ÀŠÈ s’ùÛd^3‹’ äÙ^ GßÍ~XrÚd1sz²ž‡Ü¿~á³qŸ0sgú?yW6°üÙæX’kYX°e'F»¤cœò÷²cG„†j:¸&[sˆO©…µÜ°®^;v¿“ïDpB·Ñòî c› oéü¿o<3–†çb]÷ ߯=P“¹‘¾½}`Ý;Ù²ÑAX`"(2˜l¦$̶üüª‰Çæ_ÖUÀç£löö¤x ÈÞµó(õ3(ðìÖw´~²åŠ éÛçbœÎ²g‰]sååhóX©(ÇîͬX¼€_~ø‘ù»b¹ðæç¸ù?IØÎÀ¹õ”æ²cËFÖ¬ZÆoóæñÛfHë~-/?Ú!GŠW4iـ׿[NÖUIÔÜ;ˆg×:þò$Ð0¡ ŠÖÃsJhx}“²~®ûóë¯ £ååq›g%c?Ãæ~o2º_ÜiékìXÅ’ÜF\;ú .Ž8Æ'»ùêá[˜·ïÿ®Ýì,©I£½í²„E`ß“GQHYHõz½Nã4=¶¨¨hÿÅZê6 " °"R¡Ðº#ýCÞû~d曈­ß‚ö eL—¦$ØÓ~êYÅ»w¾ÈùG9-ïqPZ§Þ©=¿<ǵ£á Œ"9­Í:ßÊèÇ[“q¬[˜mwí?™ÀÌ=”Z¶kqoKçõ—g‘é±lóRT@½wò@ò÷Šõ‘;o‹b»órSgSÃ0*8¤“•ßÿÊŽ&WÑŒ\vï>ÖDs)qû°˜Mø ï¶MdÄ$G>àƒQÄ›”> W|Å;ï…4º7k#^ê`ÆÞuÅðù(üëG>û"ü¨a=÷¯B|u|†QáÖ÷üü|mŠ"¢+"e"(6–ÿi@¯ø$ê¤$i?vD¿s¸uÌxn9Æ)p“ÉŒ¹‚“4'Ѽ…‹ðã$Ÿm‡0vÂ0"Âñ;‘> öfÜpÝ,î7“î#/!Ñì-oáýOP\GÃDÈHB¬OÔW´„‰_dÑmXÊ¿f ûøË¼*Ú…ÀW´‚_7Óû¡vÔ0¼G¸ðÊËßSžå¥ø›ä스÷e§ó#[rõµ„›~ÀuÏ>ëeÉ¿ÇQ‡s›&JÝk3˜»foW€½]LÖ„„†åŽ}÷­@X9©\¿×?ùñÍæS×ËÕ’Ò“¬À§ÚɱŸÌ'˜‰îr;·ÿ5’—?Já™ 2f+5¢©q¤Q<™|÷úD²zÝËí *e)Tü>°yèÃóq»Kqñégê_ý4o_îÄá[DAŽ\ò]>LaitŠöP\xÃôe’“m"éòçx×/`›å S_»V´)õb5í °fRû>ÉËÖjEµuÕÙ© ½Ü50+ÀŠˆ¬ˆÈ©Êìaœ7di»XÊ®g:Nº ¡ÕmÏÒ52k%ÍR…¬·„¢3ÆQ¡ÛÅâ‡-|…»ÉÛ×™ÕSJ‘ð§N]n‡ ¯Ï‡ÉbÅßç ¸è)šý°û›ñx|–58†Ü8~ˆ`‹$ÎæÁé1´®‰ˆ¬ˆÈ)c¶]ÁKÓ¬ADEVîìø|{>ïq†õ3;z”––Üã∃{]¸é£àu—r¼gŽyݼZÃDD`E¤z;¡Ûh‰ˆˆ¬ˆÈ¿Í0`ED`EDªµÀŠTŒËåVDVDä̰ºàIDDVD¤JXµÀŠˆ(ÀŠˆTV«ǃÅbQ1N’×ëÁjõW!DDVDätˆˆˆ"3sQQ±Øl*È r8œääì"..QÅX‘Ó!..ŽœœlV¬XBiù´J…Øí$'§§bˆˆ¬ˆÈé`6›iÚ´M›6S1DDªÓþ]%XXX©bt—ˆˆˆTY†a°pá<Ú¶í€Ù¬¶¹³–²ˆˆˆœrïý°ÒÇ3 ƒ æ’˜˜DÍšq,X0Ã0θù<›Æû§ã*ÀŠˆˆHµµ/¼&$$Ò¬Y Z·nKBB"s禟pˆ•ªG]D¤Úòù|dfn'7w7n·ûŒŸ_«ÕJDD$ññ ˜L&-@‘clÛ‹-$>>-Zãr¹hÙ² Ì¥]»ŽêN +"RõdfnÇétÒ¦M;ìvû?¿¥¥¥üùçJ23·“ Ç·Š-¼þöÛbbbiÙ²Íþð àt:b`EDª¶ÜÜÝ4oÞ‡£”’’â3~~Íf3õꥱlÙX‘ã„×V­¯åCl‹­ñùb«3-Q©¶Ün7^¯·Êô‡3 Ã0ªDw‘cû˜?.5kÆ5¼îãr¹hÙ²5ññ ,\8_}b`EDª¯×‹Ïç«2^¯W Mä–-[BÍš5iÑ¢Õ1ÃëÁ!¶ ÑÑÑ,[ö‡ Xͨ ˆœUâãθyÊÌÜ®#ÕÎà›o:eãmÙ²—ËE«VçU(¼–±çמ3¦³uëf’’’+u>5Þ?·¢Ô+"ÕÚ¡-œšG‘ªÅ0 V®\F—.Ýq»Ý'|VÃårÑ­ÛE,_¾T] ªX9cmÙ²…úõa±X0 ㄬaX,ê×oHFÆTVDä̧X‘ª-3s+ññ x<ž“î[îñxˆOdÛ¶m*¨¬ˆTŒAöŠ_øem:y%"rböìÙCPPð?¾@288˜¼¼\´šÐE\"•ÌW´”^}›?]CÑ9A˜Ê?F5îDÛ$ÛÑÆ¤`ùdÞÿ£7hGŒåw=Šþv;þ–²©úJÖ1uìlBú ¤{‚UŇ*Ñ¢©VW©ŠÞýfc§ÏÃUZR©ŸóÐÅ øùYþñvb±øQZZÊ’%‹µð*‘Åb!1±‘‘Q °"U7=³ô£±ÌiK÷ÈBvì,,{9w5?¤ï Ùƒí9/ ŽôÐPïöY¼0f-íG\^.¼ú(Úð#ÆOåçU9~¸>Bëõå±ç®¦a`=ztJçç'5êfšéq¤"R9ÆNŸGró Šˆ­ÔÏ1[¾Åãñbµþ³“Æ“ÉD\\¼^%r¹\lÛ¶MV¤êò°ý§7xy^M½x½ãËR¨±g)ï=ù ÝÂŽ^1²ùþý)—>KÏøM¯Î¿'óèã3±]2„×jE­ 3x‹Ù±yfAM¯gpÃ{yû‹Œ¹©!þgû1„Z`E*‰Ê_w SNg)Vë?‹,‡??™ª.`E*…›m?½ÁcoýÆ{,ÿu3ö…Ð=ÛØ^àO´÷#¹û£½M \p÷£\U·,¬zÖÏdÊÖ { £º±ƒL¡°Ë㌺¾1û^·Ô ®nrŸm§i¿^„Þ?ô~ èvv·Â*ÀŠTŽ[.;Ÿ±ÓÄYZ¹iN=/’üü|jÔúGÓÉÏ߃ŸŸ;vdjáU"‹Å„„Z °"U‘kåx}5^›?-®}˜ÛZìÝÔ|ÅÌ}ë õzœ{:—µ¾zÖòñŸ“ãØb<ü=wŽVÿǹåºÇ;’¾>‰žC¯GaŽiKDŽϘýG!]»†ìýœU¼7ô52z?ÇÈ^1º‚SDþ‘Á½Ïepïs+ýsÖ®]ÃÆˆÅl¶œÔ4¼^ƒM›6P¯^ii ´ðªý†‰Tÿ—òô+Ò#ÆŒ=2Z‰‰{ÿ∰™¯Yîµh‚Êo‰ÆþZ»‡äú©az36“”J½˜ l¶æpÒÒBØð×F<˜ÔCI~…޳ëQ¥º–HÕ–””LNÎ.vîÜuÄíåxàc×®äääP«Vm´šP ¬He°ÆWŠ ð:Š)*Ú×盛W ÅE{{§z¸}°¿]ÁÈ!kèÛAýcÝ¥¥x£¬P3QQá”,ÝM©‚M€¥!ý_|OH´Ž\E¤Ê°ÛíÔ­›ÆòåK  22²‚{&Ìf»wg³|ùRSÓ°Ûí*¨¬ˆŸ›?>¼ŸÛ>)ÿZlÁm_¦(ßÊ…ûß÷âñX°r¦Ìj·ãWRBiè,~0¼xöïˈˆ?û®¾UX‘ª/%¥.ùùù¬^½ŠÔÔ´½Ý Ìø|eO‡-Û†L&&˜LeïíܹƒuëÖJJJRVD*ÆJ›ÛÿËcŽq嫱“…Óý·]ÔLhP)Å?öÀ’˜DBÑo¬Ë2hü6Ô¢‚bÌAÁl±9sШQcÖ¬ù“å˗РA#BBB Áßß“iï]^ ·ÛMaaEE…¬^½Š°°p48‡€€RVDNsMÚœθY H¸¡ æX’kYX°e'F»¤ý§ûÍqmé”ò3ÿ÷'½ÿ¯Éq.är’±5‡ø”ZˆÎ^\%¼þvì~gO'µÀŠTÁÁÁ4jÔ˜ŒŒ-,_¾„ÈÈhjÖŒÃjµâóø|`6›q»ÝìØ±ƒÜÜêÔI¥V­$‚‚‚TÀêöÓ©ˆTžŠ5~ú(Y7—K2÷^p@“– ÈZºœ¬ò°æ.¹åRÍSŸþÁŽýw-pS¹ƒüòÃ:×°xM-[ÄØÈ=+3x½K´‘*)((ˆ:uRiÓ¦=aaalß¾eË–°pá|~ûm>Ë–-!3saaa´iÓŽ:uê*¼VSj©4V¬~Y›×“Ý$‰ {~~˜M> —ˉÓQJáî|7k5ê_BÜÞ‡„¶»ˆöŸL`æÆž J=°™Ú\˨§Âx¹íK5BmxŠ‹puæá·ïà<{Y Î7‹E±Ýy¹Žå¬_ †ahEª‘€€¢££ !..Ç×[vøo±Xðó³b³¨Ë€¬ˆœs -ÿÓŒŸ§âÿ¦—âpºñ>|”]``±ú`ÃN|Z†^uÎÓýöfÜpÝ,î7“î#/!qÿ–j"¸~/î{©'wí!·Èƒ_Pƒö·´úŠ–0ñ‹,º ëABùs,~Íöñ—gÝbP‘êdR`E¤6¯º}á>傊a࣬ŸÖqÒ/Ñ]nçö¿FòòG)<3°1AõG0a Š öÐ3cžL¾{}"Y½îåöÚ±+ÀŠˆ(ÀŠÈ?d2›©ðMLaœ7di»X|T¬C­/„V·=K×È ôÄoXX9ýÌ6£mÞDT¤Êvp844"" °""U)ÀªVDDVD¤ 1 ŸæQDDVD¤êP ¬ˆˆ¬ˆH °÷/-..:ãæqãÆ ZP"†—LJÙÏ?ó‘®\5ð¸=ø,V¬æ£]Ùzìa|^7nÂÕzÕŠ¬ˆÈé °·nnذ^E9ÓrkéV.üyxM&<a»Ñ·uMÊÇâa÷ß‹˜÷ÇFr &Àø†´kß”ÄÀ}·%<Î0>;–ý¯k ðóóâ =‡ º4&ÖjŸƒ ³ÿÇŠà èÓ2 =FVDä_cµZñxŸïŒÿ+-u™¹ˆÝ MÎ> ×þÁjÑ­sCbìe±Äd±l+;Åï+âïU[©Ñ¸=McmX“_uÏkCrñVm÷Thïž\ ‚ã¨i7ÙN͸ òvïÁ0 økñÎmNŠ] ª µÀŠHµGNN6+V,¡´´ôŒŸ_»=ääâââ´ðä,ɯ%lݲ›ðz‰ð³{g>%^ 5"" ·û•XO6;skÐ6øàV7k,µb¼ü±3£fÁq‡!Ö‹Û…{ï[n—‹Õ‚sËR–•¦ÐµA¨Zõ`EDþ}f³™¦M›Ñ´i3CäŒ °ùäæYð[É×Ó³ð ÇæÍgçÎÂw¦{ó8¬ÅESƒ¤‡¶ŽZ ¶QRXŒ·ØšÖ¡¶g¬Œ Qp«6$w°°ê÷Ä6¿”šJD °""""Çe8q8ìÈöç¢K.%> ,€ºsV0kV: ¢úq~˜ÜS# IDAT /^,øù~zßÏâ‡Ïðbx?ŒÏ¿6z™X½f ‹ü©Õé"òç1ÿ½j²nÙ*v;­„ÕªGýøê {¦7P¨"""ò¯ðy1LþÿßÞ}ÇWuß÷»ïÕÕºÚBHH!ÄŒ1Ø;^q³›&MÓ:MšÑ4M›6ÓÙNš¦Iók“f;Ëqœ;v°'Æl„˜B ’ÐÞwßs~H€Ä2ïçã¡Çî8çÜï÷}?ç{¾‡ 3¦Ÿ ¯ÎÌ)Ì(29ÚЂe·c'A"qæxÉñDÃfÃ6š×ŽäqL›»ˆÍ¡2«‹šýOÏ þ©gÙJ&;=Ρþĺ£Q4:³¬ˆˆˆÈ™ìnÜ.'ýŒxâõº‰GcàKÂG¾Ó#¥É@߇m¯)AGí6ŽfÌ`ºã(õñbfÏ›Liù,æ—;9TßDBkGVDDDä F€¬ô-ÇûqË+Fwwor†#“œÔ~ššFVEã­4¶ÚÉÊIÇ>š× Ÿ|=÷TV—à‹G‰;ݸ—lj‹‘P VVDDDäÌë£dòxv¾Â¶–ð`ˆµbtØÀ–æ4*Ê2±ÛR(›’GÏŽWÙÝ ¨æG7o″Œª'Œæ5ÃÂñ±í5ôU35`ÃHM'u •Ö V„Ö–^|ii85¢Ö5Mq‰ˆˆÈÕJ°x',dEp/>ý0µ673BÜ“ËÔe˨J¬³%•ÞÀ-‘u¼ðä¯Ùêòb‹† ½Œ%+f‘íœÎ…_3ÈìÜɦ#éÌ|s>.€”IÌ«<ÊÚՠΣß(á†ù™ªð)ÀŠˆˆˆœ+Ã:É®\Ê[*bƒa6>Ÿsä(†‹ì©7qß”Á0–ÓK’{hœØ‹y `˘É=ïù¾¼Y·ñö© Dø’ÜØU}U€¹ ›ŸßyÁ×$]Ž×œím®$’uç±³¹¨ DDDDDVDDDDDVDDDDDVDDDD`EDDDD`EDDDD £%rYlݺY ""¢+26Ìš5[ ""r© ˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆÈ £%r™™¦Imm ‡…B£z×루¨˜ªªiØlú])""¢+rÕÖî àmo{ÉÉ)£zO__/Ï<³†;w0mÚŒ3_H°Û±Ÿñ„E°õGºd'àk­£§+JRb?Ü`gùmU¤Ú†DDäüTê¹Ì±téÍØíFõg·;Xºôf>t–)Æ©{è“üÍ~ÁKGCX'îdû#_åCŸú!xä[üÃ'¾ËŸêû1϶P‰6v½º“¦èéù×:5½×I´¿“öŽŽ³üuÒ}è >ÿ±ï³.dÿÃ?åñ£‰aËd×?gõ®×°Œ½5¿å›?ZOkbðÿÑþn:»ºNûë¦7š]ü×xº1¦XDä§ ¬Èe q¹ÜXÖèc—eY¸ÝnB¡àYwÓò·Š­þÿû™éÿúÇ©¬‚Ÿ=ô$rnãÃ߸›Y ޽üK¾ýÀ‡yjæ=¼çm+˜•ãæd13¼‹ß~óif}ÿ‹Ü™iѵëI~úË'xi×qìi”ÌYÅßþÝ=LO;ÿoZ+¤«µöÞ QËŽ/-‡‚œTÜç|[Œí?ÿ4ßÙt*šÁn:úcX†‹ýwMù#n¸ûßãÇk¹÷ƒ3pXÔ½ø8¯²ŠÛ+“.j$Ÿâkÿ½…Ÿ½—l;@„—ÿóý|c«‹$—mÄoøìÛ>ÍwÞ= ‡¯Œ[–¼È?}õ§d~寙éW)XDDVä:bšæE¿ç\×ìØÀïž7X´êãü÷öýúS|rs>SSÝDêÿăþýàO÷á2üLÕðýO¬gå×àÞ|Ûé ”£k¾Å¿þ¬™ñ~¾öá ¤„°æÇßçs_vðí/ßEÑÉ£‚E¨µŽšš]ÔîÞËÞºz4v6|¤¤xp$Âôö1“‹˜»â>Þ÷ÖÅŒ÷œ¾ôNæÞÿ}~q?@‚ÖW~È~TGõÛÞÊ]K¦Spc–ÿ}-.&T~žo[)ƒá€(Ѹ<î‹lü6ÖüàÌ;¿ÄÊüá.ìL¸÷Ë|÷ÎÒÀÀ?ý| âã|ï·‹øï÷UàÒ¦,"¢+r½¸˜êëóX ÇøðOq÷ßßÏ[ßò~ö./®¡a|Çÿðžã|üÿþžê¡=Ú ‡ˆ¥,Ù÷k¾ü«oyà+Ü9áD<ËàŸˆpøþŸðÇ«ø‡':Ò&høóùam:•S*Xñ®7S:q…™~N1ÍH'6­áç?þO>^ß÷>»Šñç8ª˜íÏòíïìbÆç¾Îû'ŸJº¶Ây¬*üw`D#ƬËÁÅÔBãõOòÈ‘YÜÿ©œ×ÐGÊËô{n#õòâ=“ySšª°"" °"×M€5/ßNš=—÷}~+Ö?Æs l}/ñ¥ü–ýñ¡Dûéìµøú¶q"zþÅüÓ·þŠiÃ÷p«•5u3ùo¿Ì›'Œ¬-É3™7é{<º· sFÑPðs0ùÝßà‡çY6›;@Ùâ·ñ™bŸúèoøåÆ¥|jáÙO÷›Ç8ÂxVNðŒò“'ˆÇí8Cãìy=áÙË4Ïkko[ö|üжôqóÍ)(Šˆ(ÀŠ\Lór_åaÜ‚{XöÔ7ù÷5wð/ßú&ëžäÀ¸å,ø5üNœ>x/¬y™ÈüÛ˜—íÁ{úÞh£5ð¾47õÌPfxHO÷ÐÛÓ‡ÉÅ_ÝéÈ¿‰Sâgµ‡ˆ/œ:t`1鬯¡9e •Ùn쪨r~5/µ³hyæà<¬G7m¡§|SϨv&H˜vö‹iø.öîëbŠҳÜúÕ²~}Ë©Ïo8É­˜ÉÄÔaó¶¥S^žÂÃ{’¸y†’""× B ò:°,ë5ý[‚öõÿÃgdþ’Rû~ÃþrfZ~ÃæÀ›œNºµƒ|åGlí?Û[Nª–, û¬{½…O`³Ù_Û6¼dfúè6b€ÙÂsÿû-~¿/Žþ¹¼ïýÓ9øò«ºããš4­ÿ)ßüåθ|Í21-›ý"j f;­]^²ž³TNM¶òü‹/ú{éUêºÌ3‹™™éÛ:YÚ–ED®E*.ˆ¼.Ö¼ŒS sxÍwùü/ÚYöÏÿHå®ïð51ï£ï#mý£<ÜXÇ€}N#‰Ê·}š‹Ž/|ñ§¤|å½Ì~%½=ò²sœ7{hn’Qxm¿j­]]!RóNMßl^Ï‹M•Ü5Ã7ô˜¬?Ä:¾Ì¿|é?ÈüÚ?sKnsÞ~/øøoùó]UÜ=â¢3c0Çž'×7ð»¯>„ãŸä®b'ºØígÿ½ž³è=üË9/âÖT;˜ âgynëÖÍÚÀED®€Y³f+ÀŠ\Ù{KwæÇ¼õóâÖbái¼óó÷³,¿žŸ­®£{Ò üõç0ÙÄÔw~ŠOdlÇ7|Þ™üõÅøÇŸ=ºYÝÛØx0@å_e¾¦›h^Ë“µÉÌ~óÄ¡ƒJœúgž£­úÝÌK™=L¼ûüãÑOðõï?ÃÌÏÞBvöRî[ô{¾ûä>nÿ늓ýx1\xÜ1Z"‰sª,ú6=Êï÷§ò±Ü¡çmɤúC¸´ý½ØüÉøŒ‹; ŠˆÈåq¡b¬Èµ`m,zûͼ´úq~sr~’ß¼¼µ;Ž0¡¤œÜÃëyôðÐSö|æÞq3ÅÃïÊeKeüäÔs,l›õ»ÆßÊýeÛ…Àbàгü÷×¢eîGø×©ƒ‡Yý›xt­Á›þmÖÈ `¤0ûö%¤ò6u¯`UÀÃô[–âúü3l{gs=§>wvÀdSK&ùgk«¿†ŸüxãÞò ÕÞïÉaB¡õ Ç1Œ}¤"=ÒN~q!NmÊ""×$õy$qLÓÂ4ÍQþY$‰óLÑÀ°;° û³Û l6ûˆÇmvcÔ;v¢g?O}÷ßùÊú\ÞûáUŒÅ‘^Zö°áÙßñ½>Ê{>ñ-s>Æ7>²€€m(Ôî«¥qê=ÜUzößÈñ Q›çÐÓö 7°¼¬—¦–a•SÃϤÉù4¬_ϱÄéáu/¿þÊ·x)÷/ùÈʼaŸ×MUõdZ·ÕÐúZ‹°‘=lÞ“Fõ¬< ED®QªÀŠ\f—ææfòó p8F·‹Åãqš››ñz½gs<‹ï?â!³ÝɆǘ±òNîÌMÔJp¼æ¶6öÓÓ~œ#v³mW+¾é«øÄ7þ‚…yç©7Æ·ó½~ƒ§ÛÄc O:%åL›ñf>ó7‹¨Ê~Ñ”¿ú|§úÄ‚vòüÄžÌj¦%?¾ƒ?ýöYËþ™'ºØ ¹÷ß>}Æïëñ+î¤ú‰ÿæ3_ qß²Éd{btÚÊÓO¼Äñâ·óÀ?­ À>2è§.¸•…ý”'®ä½¥{ˆ³è\÷s–ó`‰]³ˆˆ¬Èõ¡°p<{÷î!c·.% >ȸqEgvìØN8Õ{¼^/…”––%Ä­à‡V\–ݽâ®QñZÞjxÈΡcØÝ.ĉÆ$çŒgÊô©”¤9Á™ÁÄ Gxúå’nžIîUÂ5ÞÚL»7‹j_˜Ç#¤ß0ŸÙZ˳û}Ì_8‘dä}׋ìî‰b ·?Æi×":ÐGØæcÏÚ§ÙszüÍŸË] uðQ€‘k$mspënÌÉ7S:¬’šˆÆI©\ÎmUiØ3Ú˱]Yÿüf+0Þ ®œ©Tg®aã®BVÍÌÄ~E³—¨ÝErn KK(ÎIÆihóQ€‘kŽÙ¹ŸÝ=yÌYœÄùòšÍ•ÂøéÓh9òGÚŒgœäT”á^³—†ŠÅ”x®à‚GŽRwÌFѲ,ìÆ1 J_g;­. úÂ$âÐÙÞÆÐJ@úÉXïqìÞΖýAòÜÉã4ÜϾWg}<•âòÉT”‘å³kCQ€yƒ³,, 0®õùšt9F<¿šœQ,l؆u†5’ (J®¥¡9BI±{h²­lyòUzËofiYÒëÐ &{vr$–Ä\ÿP¸4üN™Ne²AâXˆý½ÉL™^EšÍ¤9zö“ï stË:¶j¡½ßN ¨œ…·O¥8Ý @Qå<Š*«8~];wðdÍ&Ò§,fùœ<Ú²ED`EÞ°L;ç¿vÊ"ÜÛMÌ“F²Ë ÚÛFg05ªØ}éd§¸.m¾ÎííaÒ&.<<‰âø®ZlEÜ0¼C­á%#Óîö.ÌâÜ¡é˜Ä"a"qëui^kà[vw {è'þ”ûŸ{œý€é'uðÌ㇇x.Rʆ}±0ᄤ¼Igð» èiäPÏésq‘U:”Ì£4F"„bàqjÓ¾5;jÙ°iÓy_S=k&Õ3gª±DDVäJ³bQâ†×ùÎ<[ýXÿSîä†Bƒ®[Y×å ÜEó¹mföˆàyÑó-1vàó:ÎtûmâÙ6V6l˜/“¸yœ?>´ãä»L+“÷­¤2ión*¢ïØ^uÅÏRñö’W^J¶Û¢kûc<Ú6…›–•âÒVýº†X…WQ€¹ª,úººIøK9÷ð¨ý ‡hñç3Ão\Åùºp»âôDÏ~ªß‘”NVv6²ÈI³è~r{Ês™‘>rÑHÃåºB;ÙSgAü û‡…íôéwp÷Ìtl@dÿÓüª¡„·ÎL°«#“™%½<÷ËÝæaÒuh+Ûû&2c|ò©*±ÕIÝÖƒ˜ã&’íÖ–|¥B¬Â«ˆ(ÀŠ\õüÚDZc½¤Ï>gÕÎì=ÀÆÚ^òªç“f\ÍùúIK18ÚÓU˜zÞÓý†¯I…µ¬¯kaê¼¼a’8½=A’ÓR† £e’ˆÅ±ìN¶«sÚÝŠöp¼©‹ºš#¤äM<Û'™QÌÔ©9§ºa$Ó²­SÛð ±ñx|0À*¼Šˆ¬ÈÕ£sïVvä1g‚ÿÌ@h†é<²-Ûë ÎgùxïUž¯ƒìü,‚õ- T¦rþb°ƒÜ‰p>w€#ÓóN ™•h§±ÍC^Űùš­lZý"Ý·qK…ÿÊ Æ`v²û¹õìëèc ”À› ¡lJsö±s_€3;4X„Žlæé>ϰ ìm&dhC¾"ªg)¸Šˆ¬ÈÕe…hذ–õn&-^À„Ó²©5p€µÔ‘p(žz#KÊ2qW¾žqW[Ãþ®RfÎ?-PÌÄ”5ì?ÔGqÅà©÷Бzš’JX‘n»ºío$‘?y9ÞdÒR’pÚN|þ<ò:صÛÀf opwf)3«2Fl«ÊÂã³°°ˆÅv6mÝ"" °"oH†‡¬‰ÓY6-ŸlßÈÈcø ¨š•Ž'-“œÌܶkh¾Î\¦O=ÀŸ·ígâM“H± &Š—¼…â3æ•LåŠ{©<ñÿh35»(ž_JòðhËeþ=q…ÛßMZ^úȰ™8ÂK½ÌË$êš@åɾvòf­ä6’IO~H4iÞôGþðt?qÓÂp$1nvºˆˆ¬È5ÁâˇïlÏ$åR^~­Î×ÀW2›9/ðJM:ËffîŠ{³ú 5 ”ÍgNæUˆxöfÜäÃãsà›u+lIgVJíãY|ß}Äâ lNÎa‹éLJ?óæ\ØÈ›s79G[³ˆˆ¬ˆ\ã<Œ›}3™¡86‹QÞÉËM~õ2J|®«sŠÝH"»0iðß¾Î5h—ÍáÄíÐDD`EäÇpàñ]ÄáÁæÂçS³‰ˆÈ•¡ëDDDDDVDDDDDVDDDDDVDDDD`EDDDD`EäzâtºˆF£jµh4‚Ë¥!ÒD®£'çÉ'Wk‰ÈdP__Gii.—[ " ¯õõu™j ØSfÍš­–‘+&??Ÿ¦¦&¶oßF,¦J¬œŸËå$È$//_!¢+"ru†AAAj 9ƒúÀŠˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆÈ¤q`EäšcYMMtvv‹Å®ùåu:]òó 0 C+PDäZ °cíKåÚþÂsdŒê Oí® q½ijj$2cF5.—ëš_Þh4J}}MMMºù‚ˆÈµ`›š‰D"Ì»¯×«Ö»¡Pˆ]»jijj¤ `ÜêË\AC.Ugg'3fÌ3Û»Ë墴´ŒíÛ·i»¹Ölgg3gV‡Ôz—Àf³QVVÎöí[/`ÇÚ—¹‚†\ªX,:æ¶w—ËM,ÕʹÖl,#‘H`š¦ZîhÃÑt ‹_æ """rMX€D"¡V»LÔ–"£·fÍškn™V¬X¡#"2¬ˆÈÕrÇw\3˲zõj­‘±`-ËR«‰ˆˆˆÈU£ˆˆˆˆÈ˜¢ ¬ÈëÎ"ØÒ@«#—¢ }VDDä Ø×ý«¾ï ëwĘ´`ç¨[ÁcÔÔ†(œSvÎ×È•\iq¢Q›Ë…CéìLÑfjÖo¤5k*‘l×°k×=žq©çÞ #-»ÙÒ”ÂôéãH:}[7ãDãv‡û‰çbìÙÚ€kÊ &&kç‘7¦‹þ†³,ëÿÂyáq^8=Ës Ú_ùÿñØ>"癆Ùö*ÿ÷ŸO°7þZæoÒSó0ÿñ“õ´ÄÏ|.ÒßMWóôyëøý÷þgκܯýïŠ1û8´¥–cÀêdë~ÉóG€Iç¾lo“vq¼+„ ÄÖñûüUAý+ÏðÔš§‡þžáźn,k€Ãëã7ÿŽß=€¾óŒ°n®á…M ô™ ‰‰Å9kkÄÚ¨}ùUêzÆêˆ 1šk¶qÔ]H/J?}ýýô¶bûæíì9wƒ™½õ¬ÛØNViþˆðí:ÈÆçžà7?Ê£=Æo~û<½‹vpf0q‚ÁÞ—k8®‘ÂDDä ê*T`m®åÇ_:ˆñ¹rC¶hÍÏùôÏk‰bl;BÄÖÎW?ùÒàËÓxïßÅŒaKja`Ù]¸GTûâlûŸûùÌS] öâ·òïcÂPH4­á›?8ÈÒÞFž=ΈX”ØÏCŸüw~oÞÆ×þë=L6OÃWÁ›Wlàcþ‚ŒþŠIc¬Ôhsböìbó¾B ª†7[3»jšð¾©šÈ‘çyòh)ï\^Š ÒÓÁ´+F÷ñvì“–R•‘ yÛ ‹9 ÑÏÁWÖ°¾¯Œ•oGÛKOóÄs V,-'`?-Œõìå¹u­¯¨ÂoHpø¥‡Y»?„iwâ4L6Y…eL›YIQÊPã;³(ŸxÇ×nÆ¿jùcj8\“¾ƒx娟ËçQ>TµBÇÙòü!¼¥ó™;þÈ rpënÌÉ7S:¬’ïÜͳk÷ã(ŸÍÊEù¤¸ 0cô÷„NV¿]9S©Î\ÃÆ]…¬š™‰]Ç9¹Þì¥W LxógùZâÓ|âË?Âû¹÷QjçÕ|ñ_o%ÏadžIÂ4I4<Ê¿~µƒ°eaYßöþæ[/3`Æ ‡-¾üžõC%d;E÷~†w;Œû÷øÉßLÂÄ^x€;rbz?f;Oÿè÷}“[ÒcDN+êÅë6°!y)7Ƕ°®îíTT8‡}ðöŠ÷ð‘éâÁ‡÷òí÷LflÝZÀÄʶ¼¸—æŠò“?úìäHjw¥Û¡õü?<¼,rÓ°³7‹ÒÜ>¶­y‘½Ž©Ü²¼’L'dÞ´ã¥gøÓ],¾i6’‡¢“5@݆ÌÊULJ±œw<%eúÜSÀ†E<ØÎá]›yùñ&zV.gZúàæéΛłœÇX·}wÏÍ#c¿%è=¸‘µvø©{ùiêN<ê¥7b#ɪå™'k‡~!y(žw•éƒícvîgwOs'êr`õ±ën¢ÅKxÓ´lœÃ~œøÓ#ö±œŠ2ÜköÒP±˜t""¢{‰³´ˆÃäÝý9¾”¹Ã–a`s'¤vª4Ñ“ŒÓÖCÔ1ã¯ùÁOÞG|ÏÏøÐw|è¿ÞËTGŒõßþ[~qò”vOw×`€Y'Ë‚Dý;6.ñŽŸ~J:ÆÞõ›ðßðYî‹}Ï®ÛÇ»'WŽ©V$NÙ½wø‡Õ¬»³œ¥©c« kϞ¼Ê㸧–Ûò0§º”$‚£XwÝûvÑ–äfàé°9ð¤4±ù¹¦a/qcfÝêÚ–ÝÆœ\fûnj»Æ±p™ÿÌ ˜l'1pø²(¸¼·DIDAT³‚ã1þôj=%·NÆo ²¼ªÉxVïäPUeÞ1_[kxvk–ÃNnÕbæäذ£Ùð<ÇÊndAÑPX³ƒšçvŒŸx·Iç‘cÄó«É~æ¡¿‘é”ÍËÂyùI%×ÒС¤Ø=4ÙV¶<ù*½å7³´,I“‰ˆÈõ`/‹XФxÑ|ÌH˜ ?ø(ÿöO\ x/-‰é§ÞeØq9 lVœHR:é.'.»×i`ÆÉ/d˲ÎÒŸ2Aý†Dæˆ2+qæó±:^Ùìgñg3(H,À÷…WÙýîJf¸F.wÜ?›‹~ÊËÛú¸qiÊ  ^Zͳ‡b°ÉÂJ$°žû%ìM$îYNÑ…&j`Ë>;U7V‘l¦ëÑÕë8›ÿ\OÊâE”û lÞTRb-tºí€Iû¡#ÄÆ- wT[›¬ŠÉdì>ÌÑàd*’†™¿ˆâÔm<¦¬ìÚ/)Ú3'±ì–ñ~ùz¼)¤œ¬­|””§òËúâ7NS·2³ Ò§ßÎSS†­žûõ>ÌѬW› #Lo<ÀÔ|à#×$Bxl’3rÈM?®ŠÈ°hm (Ëu_LÛN†§–®>““W/>²²<Ô´v’(Ë¿öûuÚ’HõÇ0+%=±Ä1€™ˆƆVÌ`_lǰ;vàóŽÜºñ8¦ÓwÁêëPƒáõzˆ‡Á3 ¶,¦/_‰éö©ú*""×W€½d˜ “xçNžÚÜÅä[f’˜-/ñ¿ßÚ‹û,‹8qåyÇôçM:;; =•TÛàÿ »ýÅꢣÓGfÚÙ¢O„ë·’¼à3äš`‘Çü…>þýÕÝ„fÌdäk‹ÔŒ Ý„-†Nq™K¨ý0{ë¼§ŒÙA¯Å`ؼw>sçdñÈ–Z’;hhê†aEèJôÑþòS4žX F:Sn˜G‰7HЉ/ÉqQ›¥ÃaQ)4ðù|D›ˆÃº0)AÓ¶§y¼vøc.è}žÇ÷zM4lgâ©_˜¦1âG€ÝaÇ‹m†¶ÛÀ²†]ÔhÇ›œ¬£žˆˆ\öR+°FÆ,î{ï¬ú_°q[6««¶ÀTVÞ½˜LÛÈÐùÒÿ|—Ý1LëÄð1Žk%—ƒÝ²°¬(Ñ88¶ 8ØçNv¬Èš$ìœeøªð.^ÙÞÕËž}݃Ë(†'^eGhsGœ±6ÁfÃ0MgíªpGØX„pØvaP”‹Y¥ÎÜñäôï"š?“êÂù«™ÍO uÒ ÊRNLÙIŠÛ˜¦Ýf\ÌB:p9Ó™¦…9¦ZÜNÁœU,žë¬~ŽímÄð }^Ã…Û§':rÅ©i¤Dé°ÈM¾p{F#Q —kL%y]ì%KDè‹`†ã#¿œ“ò™\9ed³ÃÉ-ÃÃÙHÝþ8%ïÈÃXV„P<¾ ô‹4’Ió92àôáoC;7²)ê"÷é_ð“™Á0ñÄ[X¿#Äܹ#k°½Ø’“ñ޹ó°IS¨ž–z*À&Óµk÷ELÂËÄ™œ…÷è‹l¶Ïäæ²t¼6'É™©D÷¼HcÑM,7TK·Üx\qº"&£vØ uÒMeRêÈ×G"Qln÷(O¡¥Õâ§ ÀÃöúc¤L+$Ùð“–bp´§«ðÔº2üã(JßÅþ}­”Íι@;Äéí ’œ–2¬Zm’ˆÅ±ìN6u"‘ë(À^®Á÷GVG!Ѻ‘ßü¸×§XA´X¸‡ úoÙÆÆ¶IÜ9É1ØoÓ꣫׆ßç:9åS}`‡ê°–…edRTdç•#-$f ‹R!j^ÝFò_âûï/Ö qvþ¿÷óÏëkèŸ=oØrE8v¤q¥ã+Àcju›tî~Ž?~>B¯å#o4¿=ŽïäéÍ{iô”Ri?ƶÚ.ü7ù1èJXr'¤ðê˯rèŽ)öF 4ƒÃÝ}X¤¢ïeœö}ûéΛB¡gäã=]¤RÇP÷ãTè¿€XÇQêšÓ)™6¸[fçg¬oa 2õT7#™òY“8üü«¼àžÃüŠ|üŽÁõé bùýxN¼6ÑNc›‡¼Ša#?˜­lZý"Ý·qK…_ý`EDäú °—+Hõ?No_µ‡ÃTL¼•¼³™PìôÑl¾£ŠÜÉ'úl†ÙñÌs´N7sýC)8ÚÆñŽtrRß™ééëÃÄBë¼v*fWÒòÄNÚî( çD‚¨å•šdß•EO{û°ùäÏGÒ6²}`.‹N¤ˆÈ>¶íIgν™'îCl¤”ÌæÆòaáÅjdýêÀÀ[r÷ºpg»‰“-5ŸŠì<ægùéÜðM¹s¹'ÇÁ©»A¸ f³¸p5/n9Jþ …¸qS˜ÃÀ¾&ú§§s¾3ßf¤›£»7±®Îì['⑞[8Ú⥠j,ü`Ãn3èî"˜ŠËaÇn· ^Øe&H$Äãq¢¡.hÁ™Qv²}<ã&2®¶†ý]¥Ì6¶œ#³Š7ÝäaËÖM¬ÞÇåv`Æ¢$\X¼jã†öèБzš’JX‘®ÛÉŠˆˆ,¦y©=#{ñ'|㡣̻«ˆußx€¶•·ssõ¦f¦á÷ºpØG”aIDÂÄM“øá'xè'+¿PAÃÚÇ©ù0šÖ±Å(å£ù¦eÒüä7ùÈÚ¡÷Ç£D Š1MpÏZÉ’ŸþgÞÄÛK€EÍ«l÷/àÞqq‰‘Ô?—…¾X·½—ù “1°èzu-›òVò­üæ¼»©Ã“LZÚ°.±ì ö‰5\I¤8- ,âñ8ØlƒÃ´5‹á 0.Ï¢sçÓ¼Ô’Ï’Û‹/p³L,lC¹(¨žMÞ6³½%Ÿy9v¼E“(Úº‰=“™›yª~j·tm_Í/ö¹q'±“:®”ù+gRrÚÅvÁCû8š\Æc(IäMÈåÐÞ—Y½7F<žàÔ6»‡ÝÃí%90‰y•Ù§Î 8s™>õÞ¶Ÿ‰7M"eØÇve”±`yó¢!‚Q›Ëƒ×e?µN£ÍÔì x~éÈ ¶\æßó:ꉈÈõ`/y­£Oò_÷që¿ÁÛJ}Äo}•ßÿ~-ÿ¿ßÓÜÞC_0BÜ4¯Å:™t&ñÞoþ7DŒ»ý~Þ^{w·q°®‹þx€[þáT; öùs˜ùÞóï(¼‘Á†ïðžG|8NÜÈ€rÞñWù|ìWϲäŸWo‡ä¥Ÿá©;´·tsÚ53XæDîÿÕjì½ÍtMÌ~óÇnûäM¤Å£ÄÇðŠ·ºjxô±ítca¹Ë™â6Àleã#¢vÀRªªÏr·1þÜ),?Žüþ-üîá= `sQz¢S°{>â1+ÔIsè´I ˜TüÝ·ùjûqL k´ßòV ?öÜíÐÛc,ÞËÈîòŽ¼Ê°ápŒl›Ã‰ÛáƒéÓg¨åôe."""rUèvé""""¢+""""òzq¨ D.ÝÖ­›Õ""" °"cìY³Õ"""Wºˆˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆ§õÕ…("¦ýDDDäê2Žo¶Ô """"2V¨ ˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆˆ(ÀŠˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆˆ¬ˆˆˆˆŒAŽs=aYMMtvv‹ÅÔR2*N§‹@ @~~†a¨ADDDä²;ç F)--Çår©¥dT¢Ñ(õõu¸\n Ô """rÙ³ Agg§Â«\4—ËEiij ¹²6‹*¼Êk ±nb±¨BDDD®l€Q€Q€XX‘ë1ÀÆ{i:ÜLO| ·z¼£{¶±yÇÚ#–¶B‘‹àx“͵Ø×e‹Ì*æW’c5±å…]´xÊð0~ö"¦¤Ÿ?S[‘F¶¼pˆ’·ä’ê¸6ïôèaÀð“곟åÙ( ëŸc_ÚL*}Çxemn­"ý2}”ps Ž¥Q]]„ÿô¦4ãDc6§ljçbmÔn8€»jå©ví"""r½XV…Iìá#ÉDûimŒqã òì½Ô½RKgØ~m|ŠÍ‰‘“L„éIDéûócì;-oÙóf³jnÁÊ µshÿšÛé³ìx“3È-*£rb.IŽ3CfÇáƒ^¸:jKΧ¼0•S‹’àø¶'yÉyo—sf‰Û죭'ò…Ø“iÛWC— é—!;š={yn]+Å+ªF„×hG›6ÕRß2€e70ãàάbùm3ÈvfQ>ñ ¯ÝŒÕ<ò5ô¯ˆˆˆ\×6ÜÆ‘cmôÈ]D¼éLv‡9RÈ)G¡ÑN³Ó $ºr  ,ÏM¸·òofi©ï‚³ Ö¿ÈšžðiÆèØû k75a/(¥´8Ÿè¦ýxf/¤ÄÖÊáºxdW‹Þ´€‰)Ãd‚`w;m½ç °Ñ®FŽùœL`/”xÓ˜PØÏË/l¢ÍÓNcj·\ŽÂ§5@݆ÌÊULJ9•^ãí5üé©=8*rç²BÒ\˜Qúº‚œ(`»óf± ç1ÖmŸÀÝss^ï_5""""×p€5lØ.\#r ÝnÑרH_ „L` …GkØÜ;‹‰yÙ€ÓëÆìï¥/qž0iOÆïubô 0NÇŽgøÓ'3n½‡©YnŒh=ͯúÉ*Ìe¼/ñ¥å”n~†gžÙŒïŽyä9O¼×KáŒÅž?1Ò[û¿ØF±“9}9ËÛi(eúøt.GÑÓlßMm×8.ós²7‚ÕËž 5DJW°ª:—“Ïæ"9cø\äUMƳz'‡ªr(ójÇ‘ë5Àº³Ÿ¤¹oX{)á¬Ý¢ô¦’ À20slëó´÷v“>+62˪™â3i߈Æ;YaÚŽ´ae#Û{¢„XÀÔ²ÉÌIœyð´¿ÙÎæÇÖК1âÊ}«ï(;k[˜2¹bØ£Q¯œöaÝ8m镼é†RüÆàóј{Ø”¬^Ž·DȪ œάXœ„ÃqÁÓìÃ[º”{NÀ;ú«»ÈŸsïœóZæ–À4 ì¶‘IÕæp`‹Æˆv 옦ö ¹~¬A |K& V–·Ý€X'û^®¡wÙJäÛ騱‘=ÆdV–ùGT(CÍtx$;F.vnÕbfç ¨ï°ê©·+NG$Á‰Z¢ÕŒ#Ý™”åºÎÙmØÓÊð—ïsÛœÜWªŒi¸ñ¸âtEL†ß›Â– -Ò@[¿E~Ê…?\$Åæv_Ö /"""2Æl„úçá•>§V‚`(ƒEo[Τì™,_ÐÇãÏý™X¹Ÿ¦}0íÖ™dX¢ GµB¨‹»JX9-chmxüiÎ5xªá!7Ç϶†FÂ%ÅxˆÓ¶w?ÝùUL8½ÿ@°ÚqÆßs™N›8œvâÑ8Wì[F 4ƒÃÝ}X¤Ÿü`¤Œ§8c{wgÊ‚¼ Ó8=]¤RÕ}@DDD®ç;è æÜÅ-e.Hæ™_îzÜFò„ÙÌ<´š—vtà°’Ó©Õ]ÏÞÎ|Ý6‘æçŸå©Øn¬Í"ÛTT’ý‡¼¸ËÃ4ïaÖí3˜|Ë„iÅ{³ñùW8ž³»ò‡O7FWãÚC盇E¨#|–j#5=øöÃÈgB’튬ƜÂö5Ñ?=ä“ 6•ÊyS9øçXã^Ä’i…C•ìáÞ Vrò©ªu¢…£-^ ªR0´_ˆˆˆÈõ`!ÒÛNk«ÌÂÒvp/Û·ïæ¸£„Þ”CÏ®ÍüáÑcL™5“iÅÜFŒÆ]û-¤$£€²Û<ìXÿ >ÈÆIk9J“;ŸÇÛåÄa³aCý>ÃWÆ’›‚<ÿòZžŠ§R²à&ª³'ÃÚÖ§^dG{œô²¬š[<òÂ.+FwÓaõ\è“¥S˜å?ãn[Þ’™T7¬eíÃáòùp#ÃÚrfqû Å\ŽA«¼E“(Úº‰=“™›yꇀ#{·ÝêeÆu<\Çív`F#ÄÝ¥,»wECM<´£ÉeÜ‘aÓ^!"""×4ãøñ泞éÞºu3‹-¹ÄɇÙûçß²)˜E†w(Ù3) ´°ý¨‡òªéT•dà1+Jç¡lÝqçÌ;X’uˆ§;HѪ[˜r²¤híiæpC#ÇÛ»èéë§?!7#›ùo¹…)ìÌ¡³¹ Ò²x_¯æñP?½ÁqÓä¬ý \Éd¦y±]¦ù Ô­å±ú\VÞZ9r¨°!‰h`ÄÄæòâsÛOUZ#Çxññ͸o¸ƒyÙ—§=Ö­{‘Y³fk‘±`ô6¦ß?üá·jµ,,Ã8Ç©j ‹Áçâ±6§ÕG+Dú5lwÍåÖ9y¸GµŠzÙûü³̽‘•ËV’W€‘×ËëÜ…ÀNJþDRÎˆÍÆyúYžzÎáÔõðÇKÑÂUdcØ-]gV7…óo£,É­‹·DDDDV®Ã7é"V«ÝMR’šMDDDÆXXXQ€¹ÖétFÕBrÑ¢Ñ.—†@‘+` êëëˆF#j%¹¨ðZ__G ©Æ‘×Å9ïÄeYMMMtvv‹©+£ãr9 2ÉËËÇ0 5ˆˆˆˆ\¹+""""r-ÒE\""""¢+""""¢+""""¢+"""" °"""""¯£ÿnê2u¤eIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axisgage.png0000644000175000017500000013436613070106167016711 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu\ÛÀÏÔ݈ Š`£‚øìÀîg=»»»»»žŠÝ­è±0Aº{{g~̲,ì‹'êï~?|tgî™{Ï™{çÌ3gf°ððp@ DùAòùüŠÖ@ ~+ðŠV@ ~7cE ˆr†‰D­@üV +@”3dE+€(0 †apÏJCÂ’ÞEV´Rÿ–õj8Z”#Ã0†a*V%¢8°¸¸¸ŠÖQΰN‡aàí§‰”ápx8Á!‚aÖçþB°:+ Z!•É$|Ö ¶uE+…@”Ææ±9ÿ'&&†……UœVåL5¬­­)Š’Éd€ã8MÓªÒßÀØ"bFÓð>$…âè ô ÌÌÌTsØ_q¢§R>--M˜—#“æÕ¯mNà¿óˆÕ…ßoTÿriwª1©œ±æÏq˜äääÜÜ\GQÔO>Ç)°¡D  …L&‹Å\.×ÊÊŠ¢¨_ÈXÖÆ²¨ ™çß(Žž‘±©••†a*“6K…ÕY¥RRRVfºT’ëåQ à×èDÑq<³ür£ºÔ‘üsZTB[š «—„†ÉÈÈ`†$É_}Ž£B}²#—Ë¥R©‰‰ ÇûmŒÕj`dLVrªDßÀÈÄÄÄÜܼŽõ%†q²Ã¾15ª`ê¿•Yƒ#eu¨+w‚ss²¬,xµª[üXV~¿QýËYTœÂ*ÇÁãñLLL,,,~‰9ŽŽgx•!)))B¡ÐÑÑ122ò—0V—«¦oSjÕªMQI’ZU¿íQáñ_ÂêOÓ4Žãr¹\&“µô´ù%:QGÊ4cýåFu©#ùç´¨„¶´*¬V汊D"™L&pÇ0Œ$I•K†_ù¬Ê ¹\Žã8Žã …"**ê·1V«r¹‚=ÛÓ4}ý~([TÑšþ[Øp[ç6N7~a§¿M'–•ïÕ?9¿œEZŽŽŽ¶²²b”y¬AAA666A…¨¨(Ö’r7 Lçä²V[ò‰…ìa``T¯^½ÿÔX]fšåU›¦)ªôäV+ßMÄ¿T&ñÞ‰OÝÚV7%ŠÍ]LÈ¢ž:ýÍ\§U "MÒ¬»êõïÙìß´ËÂ0ŒB¡ÀqÜïyA‹Á=b5Õ`ü§3&]ZùÁ£º¼Æs õü×}· Åm¨UáªU«²¥Ê¬ÀôôtVŽå¿˜ã¨¦ñå;.iš.¹NÕ½EÇÙÉŽjBWÄØÜø˜2˦ö\õͳ³†&„–úß=4r©V«,’ âµkd¬©RÖ×x¡µu%~Á^• ï‘=ÌK5Ýo%ôˆ¦l(¦é§¯“€ š¦e9o_¾K)®S×Vµõ8Å•JN}Q·Ó2Ï—ç—¯ öø{ß}¼À:F‘¹tö¤F»ÞެW`NÜ£]w¢— )Ôg'ß fš¹Z Û)•‡RÛÍÂ8¿OüÆLy쌼ܭü“ÙÒâ:ñ»IýnU¹±%ÎL—˜iô8MËïøÇtòªªêÙÏ!É•jXhJ2K.ºש¹£Žƒ^ÇÃD÷Qýï)õ+—zt·ˆ–å$ ù•ŒÊ†_îŽU«Â* 4SÍqXÊ4ÇIýò–°o_WPºh9!ÉŠÿB[Õ3!Tkä †Tߢ´Ä/‹ú„j²£>Ί36-.úžÈ²]íB†<ŸµÚGý|©‰L”söæ§nêSÅOºô8|ï¨þO‘‹SÖ ™?¶…ÖÒRíú>‹"o<Þšê²c˜2£9ôì­Ðhc?-s¿½wo‹p ™\Š|ch¹HŠ x80´„1^7Í£VQð®Õ‡$I BœýõÒãÌ"Vuô®«Wdå»›!¯º9tÖ67)‚.“ù€×‘Ž «Y؉•2ÆtlYtEËó¶myÕy~OŠ"h…äÖå€KÏãÓ…L%[óú.uÆv²ZÀìÚðbóÒ¦ÁNvÔ'}Eűƒç^@NŒ0]zB€NÝÝl( p’RO§ˆõó[û8ÒEŠwá*ÅD¢Ì”i«#À¶eë¹­Œ ;&73üYF­Æýl¥¾¯DšZþ³ìì~׈€ÓVƒ\,ä¹vÜÚ×LÓº/çïnþ˜†ó\;;˶m-©R $‚õDoCrÙ58ŽÆ3í»aëlÍ}¾«µu(A²{ƒåäѳV0¡TƒÆÙïîÇ&£­9DŽŸ0¬fJ’$0Ò%cGÈ«ìy2èÎLççÕvO"IïÃOçÛ±[F_j7=„PUþbe¯¤®'Z˜ë³‹gç¶\{-bà¼-3›6áç„>õ;·y~ëOiO¶ŽvÓ·îµ¶åªIÛ^ŸÝ„v©­ÿîsž\.×Ò‰AÓt^ܧ Ç„ëiÚm5Óg¾Ú òèÅ×ê’lYJЧƒçôL >îøE%ç}œ`hãøùÚ;Iw,'òuªE†\IN„ç;r‹X™áѯ’¤ªEZ–ÿ¼ŒR›âƒžµ]Óê¼âz¼FǶӚœär’žÏÛŸ½sQ‡²j‚ÈÍɵn|=^ ^ž%þõ›P“Z­«  ÄÖ‘ÈÞ‡$RÚŽ}­#Yió»Û—Ñ"öœz+ ·éô‚ '‚¦å@hÕA”’SorïæÔ—s×Wj¶ÆË(;îÑtßšÛ¦ÙÈòâ-þ¤¾U1‡ah$°¶±ìئNm ²ä.P¹Ó‚w¨æ8ÀÊq9X®H¦®¥85ú‚_zÏÞ…ö¬Br1E6ÍÙ”Wü\ Lì>æ?Ã¥¦ ¥’Ëãq‹¼;q5­qû&fzðæÄõc/8³§÷j`A„‡Åî=øx¡´ÓF[¯Æœï—_ÏÚÙ×’u1 –r¬a,S·† ¤HâC$uk€ž\snï>&ʾɉ¿7r›ÕÁ5õÕö½jçµ(…Áê͵Ÿí?ûުŠՌž¬”vÅ>»º*š£š¾©[‡åвÕ×Nt`hyVVöóÇo–®üºhsÿÆúDɪp©­¯ò­e€‘€H”Ç•â@é»÷èÚÐôéúcrçí^±ÝÛÍ:ê`EgÙÝ»Ïý¸nã—æ÷v´b+¸3¾í;JyÚ—fGí•ËEfŸÞöÜ…]Lx8jõ¥WÎ}SŸnØVkж&µøþNñ¨Ã<k0u]T³ÁQ“C«òHxœ£ÒQsÄâ8Îåà<Ç…\4m:>óh$‡«~Évå~ðØ‘­ .t,_¼yâP¯®‰7ªcsp}}CËEw_¦wjT#-8@ñ6ÅØËë$n ´lÊò+ª W,󱦰´ïO|3ïPpGöîT?%½À­¤¼ ýZÛ²M]cv±HgÊõžž¾ëí9 ¡žrJpIbjÇ+㨆ŋÎEˆ ÷v‡þr(²2õMXl-džù³ô¸ø¬G.¾éÜrn/§B¸œ€"ÂÚí’Tš7¢P£ÕôùFe³ÇqYÞ·§b¯ ñU9í‹Ò2Èø¦œq M­•¿I {vøA…‹Rrƒý¾"åÒŒì”Ü…[‚…0¾ºæEÎ’Ù­›\‹¡å™ÙÏž.Z±l£›eI ¸SU¥ª9ŽêòcZgÊð:ê;âââ#-<Õç5òùQšNl¹v¢ðnåÖØ0͹Ø))ÍèSIâ8FEš“KR×ü“³l—5Ipée–C÷>­j˜@#O“ºU “ mÙ¢ú}›ÅNºŸÐg°…Cþ‰…ìhkp#Kž› )_}ÈäèÙ5vÊxª·dt•סQyMjyqó–îš=ÒU] ƒË›¯ªf¬Œ< R…-n5r¡XÄûýq•OO±'1 0ìŸ׃ó¯6dÂ,Ò]ifë ʰ¶£ò’§‰{Í£œy–ëÕÙ¬dUñªy k›¹oÖÜç²¼œÆ…ßbAH„B€¼øcgü§÷èÚÐuþʬÞsô^½™w¬¨‚k%=û~Ç7>ýcìÞu7ÏïZoæÜÐa×¹Uòg¬—;Í U §<_$3×P_9î-»nRwu¾WUâ1ùÖíÉùƒÐ°]ã¼mo“¶4© ®u Þ}Vz(ÍNÄqœ$0Àð"] ,Å#Õfå R-¥1 y–šZ˜¿½VËëæŽœå¿y{_ ð\¡TÏÎ(èö†V$I(+Rž'‚Ø×™vmÛ.ig"Éù2ykò¾Eͬx‰ƒ‰Sýq‹}ôöcFôV¬Øç¹°ò[»é­ïòÆìÈ"I cåË4ªwî£9Ó :xf‹D ¹‹¾Ý~yßÎÁÝPÙ5­v­\åÙœC~“…úûFØ©ÄâŸ>~ÊqññPN¨i‚ÍÚ´Œd®IS·¢Þ¼¬á8õ$Pϼ_‘qêÚ‡ü:Œm!êÔµ(vÁ¬vÓ9ÝÀÐ_ã2MëÑH­-ßµ8c»Ï0)Ð6&1«Je3Ó¢0Nzœ¾?tôQŽg/s]Ž»2DeyßöGK–Ì6+´–¡O‰vëߪ‹%rã_ï¼c:w„-—cº„äzÅÏ}ÓBžËœëñ•v%-ëdÆ^Ú¬ì«æKRzU¼õe‡¾—ÖÑ/Õºø·‘UFusú’‘"vî×H1eSÜØNÉ1q­k›Â!²*»²¢47ì1­[oåXÌN¸ûç¶¢f ¬œ¶Ž‹¶%hþïcg¢Ç°€SºM°TÎXãü¯¬ŒÑnŠü¤9…”s3ªT±|ØkgÕ½Jóž=Ò ØÙÊ*Tí®‚\øŠcØrÔŸÓ â襫ßl1 ã4v‘8›>$ _سÏwìX¶£>>zÖdÆ9WŽù‰ =ƒ&Gcïö/ßd 40'" ••‡ìÿhÙ|¾2[E‘}.9·Ö°ö¡ÀB‹<­æî šÚÀÛÜRï¢S_÷÷Vs½T$uS[”‰“1 #är‘D©!W‚\:5µ¨?¨ÉŠy¯ŽÝþVÓ§ëU'õúwq ¼uï~ WH{õéYdƒön]¼ôǟ̵fiWI?KšÉ7r´«dÂÊ;UmŒóÍ9¼:A¬©F½^}¦×¬Ö˜£œÚhö8-St›ÓöÔ¤k«žÔZÔÂ¸ÈæeÕ¤Fòø…mG­V+5¼šµ5ÿbj£Ï #ßp2Äb¬kaAæÞ§ŒöuMÔWiÉZÿ2Y$—¤-¹œ†YR”~Õõ³íb¾eÛÙ+ÛehÙy¿¯[Ö0$h…äüÍ÷êÛÒ áC!Õ.àÓùÂuþõg=¬ØCO©9N9q‰W‰R.ˆ±²ã•o³·Èð½wð‰¥[Û¦…|qì³{$v—¼k³~-Þÿ=ÏÄÁ˽à¼Ä0Šïb 4íÍI ZJ3`DâÊÖ5Ž¢ˆk©fõ©V›êé¿Â¿ÿ‚¸~]vmREPx µª#X}5¯g¨ºÍª2­¨±ïŸÇ¥ 3äá7… ·Pó…ÿSçúÎþùWJ Y&`6š{/ô]¢[_ïú”àÂ㡽FÀ§ë¯öç뚟 6Êš‹X(d9Ÿ#’…"3#ãɃW[Ç9î†*â Tnaï>ç}ÇŒä'7yf>âÔ“óW?I{Tw…×»–,YaÞsy›—k'mñ˜ÕS~äÈýñc}ÄigZ¶Oã<\ÜîÏÇk56Z¾÷ÃÞ5gLD2˜0²ËŸÛ/¶lÕ®rªò,’(4î§<7+¤Qrš1qµPµ+Ë}~óîö·mû~n0u3øˆaÞ Ã¸ÔÖ*TY§9b1 ˜7º²YÝ…*92õ@¤Z¿($I¤ rÿÎ.u'âN’†a¿R=Žk9µ¯¶6€ã×Âw­A‹“7o¾¦Wsç_µº¿ø°uUÇS‡ï_">%É1ÅTÌÙ ãS¶ImSUÍv­›€–£Úä7Íвg_Ÿ¼Ó¬góÁͬ¬Æäiö8CË(ýêëûÙN8võc£Áõ{¦)µÓK=„€–eß˒ͯ&À0,;öÞðUßTEr‘D¾ìïÞ8ðMœO­VÞÒ1®V³QþÞ€ÄWÂpû .†úbsq—ïIÛê#ú4n]Ó 8»hY^Hx’ª9ž‰Y53²¬ù¾©‡ñÃ0LšýçÒ‡§þÉž¥yáOøwi]“m“ ³Ç¶=yÚ¿uŸ&&Y!Go§ËÅ©¯¯–úâÙ«©›€(Naõã=+:ø^¶Ü£¹»¦8…µÄXÕIÍ^Iyÿ϶÷²­{ÕWfÇ|š|èÛ¨%Ã8ùaùœH±~º #o:øJcÊúáÍ)d’Tœä[spÖ4•V2aâêË9K:}I—µá«š0©ÞðøFkß+oμ~ü´¹O¯á­+«ª5©ÁÝHðªElÔ4êzÔ¬þ%鋸Z;7Å×IQìÅ;ÒÏ"¹øqÎ)…:%CylK¦ýÈ]Œó³NÞ/KÍP^«ššè˳C{M{Hã$.½4ã½½S]î–«éëÆz›H˜¿öòÀÉ]›¸ØWÊâ²j±L’¾ãx£Æ'dVöcû»[ÜP*ÝÀ5ÂDùk@’yu邯šû?$Sl¥Ú'ŒtÍú^kpMø>=-èA=,û3`Äžê[Òòþ»gÜåŸËÞbÆ7ððŸ³ÍÍí×ntøò9›~zúq˜»Âž|µuL9²ãø‹0€h±\PYŸmˆàÚá–’‰¹*/¸âOþÿ<€g·/x¹tq7ä€ÀVO! g7y*,¡U+´žK I¤}ˆæ:Is>¯9Ÿñ1µæ(£¨·6~iêÕ¤ÙçÀ…ç­Ç7gÎÞþ6¬[Mœg^»ië9­íbß5w®Gr‡ïóù¤oаn_}ý¥àð) §Ê`ƒN`§!ëº.^Ýצè.-=Î0 Ü:uíòðЊ oÎ/õÀ‰BFé>ª5U ¿~—gåÖÂ#Ûv¾;”óÇ󛎟 Å<œ[‰Ë®ÕYnìì½_[LÂQ» ‡a¾gÇàÓG¬YuâšW£éÃÜíx¸¶‘üeå®hÕ†UÚuYÛŬLÉr¿® ÄŒ³Þ|0 ã:6àÞ;%žç$€¼ø¯<£:z…ãÁwî}¨×£‰^öןª¬S«SÛ‚¢k›.~îÜÄ]+®#d¹_wÏcdòÔÔ´WŸRª7j²°V¢ÂÚc¬ª{[†©ßê’æÄÍÛþ‘xÀ‡œúM B<}ƒ¶Ã}úV/Hx˜[mŒ1AjÕ]Ú§<=ë’ùL‹ã)~e¶  '‚`®»[µ%A±2šoÅUoBÏÒfÄh›¡Csn_ñß~øRhvÿõ½”Ï?èYQ iûâ•™ÚÅ !:O–ФiŸ¿Ò€aCËŒ‚ZAË4A´4gý~öTÁå)’Oûç÷%C‹Di¯WíK`çï3fõ¬lZç®j”τݶãZÚǦçÒñ—ßIÀ¼–3ð<ÉÐ!óþ­øªÃ[4ÆŠX‡c 0sß·Ê0`¾…„.]æqoŸõ]u50(\¢êMÇnõ¦^í4w{Î}_9޳Û2 ¹gÇ©Ý-—wîðœCá -•ÓEb例؊sHh™¤õ•ðU5•Ye¡ ½vvºU…èõ”ùýoõ¦ÇDŸ_rÛt† °C½¶¸ ½zd › W‰C|J“å+iÑÍLðÏÅûÄкlUúÖc7ï }êéåw=ÈÓ%ÇŽµ±ž#7(\Rl'â8ŽcÒœÈ͇´Ü¯ ËSXÊ:Qì<è9¶Ï€èÞRŸéàÒБ·y]bÿ™C[UÐòÚG÷Þž4/®Õˆ!A(¤™iiñGÎǺiÒÌùÈù€ œV´¯òäùÝ5¯S>$0ûk„ò’ë†_Ñ—0}N“ tÐÿÌ¥='¿ÑMŽ-k ²¬å»Ÿ-â Ùm±}v ®ò´yÈ÷g¯ê€Ñ²”Eû¿]ßTK”›ãçÿШ.FPøõ«ûjÔ=¹ ; -b+oۉC}çÞoÇ_ {öÑÑÀºÕ9Ÿ£loF të9Hs·G®ÿë³*ÝŠ4ùkãšäçÞbÃ-nu‰<Õlrø–ëK<žv88êÑÁÆ6×[›_Çø*%Ÿ¼Oµ™eŽðÍ{UŽìïÛ7©ÛÚµû‡×í¼Ž³uY£Q÷¬¸Ê¸pCîó°Õ¶¶»2mÖáׯ4.Hþe9"†QÝhÊ Éä˜Ôgmü!-¡I’$ Œà˜6j`¯icîëPy¾ ͸zºy›=4#"ZÎ$ÎíðÝã$ŒœöZ;z~}ÀC‹Ô ç_­N¬ižöòt”ӤΖF²íÔ›'^2¬Þ¦2_i -—FƤiZ@`Ÿ£SÄ…§«M ’$1-=›°I™×Ü>ðÃØ}7®²Vݼ*Ó¨.t˜È…ûÖ_¥«ºN­e¨®GüÇ·ÓN¦.Ý:ÛtW¿¹§FNlÄ’µ7CH§³ÓܨŽKAâóÊ®AÃ];k$Ò|íva8k—æá¯«EÖÕ•ŸüPÞúsèhš³#”$«À‹¹5&™Ñ_)J`¤~¥–…Æy•€«¥j*LéUÚËSëÅ)¬BKŒUÝõfÇDÎ]r-Ͻõ‘aµp€£ $ýWœŠ}ýa«¹÷Ïo¾gáÙÞ†S¬ÓÄ0L•‰¦Z–½éeÖÈÝjÞš‘]ÜyWØÓ’‡8 È×ÑÈN2ä飯®6ù;Ó¼ É¿ý!Œ–p -T©^©PÄXinäÅàDÈÊIdéáQb€älsEqzfFÝÒÏ?oçFü}ù%-Ï}àÿÙÑÞ À¨š›eÜÈqǽ»{ ëZÇ„Äü¿äYöãÇ ºäN(ÕîÂa'^¬_l:ä¾t¤õŒ×Uh¸ˆu,ìÃ|ì~‹‹–à„©ª¨T¿ÄºWÀ0až–Ùœü»}d¤—R„K̯°qΠߤå}ÙÝÉpèß•9TéqºÙ!ÛÁËõ-N`à<Ü)áàSÈXÀ¾×ÅÙ~žÔø6{kצM«š0_>¿;½qr’qó VÊhÝó±Õ§ºµª!_åZ;QÁ3o×LËC_OÞ ÏÿáÔÐñ^©Ÿ.ˆ­Împøvïô¸ÖLJ[¿ÙpðTgŸMuõïMÙuŸÉŸ¼PíšØO+–ö]ïS]­!æöÑ3‡¾šž?\*-ó¸¸}ÄÐÒ‹OC£v˜+q€·[O|â;Ü×±F~NŸó¦Û¯&RÃl€–eŸ:ðêlÌôa®õLb?Gï=`çÕ“ŸôûúUNµ•Ù»kTygêÆòf.uqHý(®äR×ôô¾a@PE†SE‘ìÿ iÆÜÕ~õz´¾ÔÞàÑË4PÈ0¨4×o IDATd©¼ÓêÕµéÔn‘»Ï%ès9¦¸%ŸmÆ @PœÕ-ƒ…sá¢açîU¬jëž7wM>Áß9™À Y$´4çSX"“›+ ~tø]v×)) t²Ã¾&0cP$7·k±Osç Ós›ÀÖª|}ñ9]&üøJ?>*K”øJ–!Îúü,0˲>ùæWvknÃD×vlÔÕŠÿ‚„—^\šå¾5sĽ•y¢`‡³üú›ù]½ì°Á˦j™yK'¦Ã$+e¤·çUÓöËWÜ6qËø\0®ïÑܳǪa’Èà â-ÞUI¾Û‰ì¿$‰2m' 0Œ$ÕÂ)Ç0‚¢(’À0œ¤(Jõ0‰¦qÎàáÍ.ž<ÛûoƒÔT³{uŒ( Zºm±/¿M'Ïè'#w OmTB6 Qøš=ŽN\¢RÓWvþcôe uïtõŒ"à^À®¿Ÿ§™;íÛÙ¥¦^ÁÑÿòÖý,Ëý{ûÔ2$€` ™ðöo¿'1RCóaS‡ðÒž=F“$ägò—Å®B”É"ŠÀ1L©'iîܽ»„!(Qü ÜÈÅI¿hλrÏs¸„8ò̵XõõéY—S`¯V…µvY k‰±²g Ãäò¬Ëþ¹ÓWŒïQø!–Êž­NL•œÊã«b #_»pÿÝtóÍ[{XsK9£iú~´°g²Çgº«âBÎ.¦Ñ‚†›F»òÔ|uåæ…‡î¤Ñ,H ç¯Ûþç¾Ý÷Μ¸¹*!—äëyµo¹hdm¶Zšq:]¾ÒÓ„½šPOˆ+b,WϺ—5D¦¿¸•çÐÎË rãsïµô@.’2“vÁÀ«à8ŽóÌìé™(IǪ– û )-ŒvÐ'q…4ÓѦR[cÎ; 0 ï¸zÄÍ]‡÷çÔ÷m’#Ò€á5{ýÈU3¯ùä°¸¾ºuÀ77¶àG¬Þ€Q\޵õ’Uã;×Sæ—”f à8D%2ª‹’cbï¼ÒïÎÍ¿·ƒS(GÙ¥RáóãG.Ø5«xüH @­zðàø‘`ÙÔæå™ã/\Ú[>:yÀ»¶§½™ÓéÇÀÞiÄÇ¡I·)¼‹#&wêyºrà 88×vÝíw4iƒc 0ëµÌ}ÒÜ_õ*817ì³Ø·Ïb`¤b†Sä)“¯çGñ[ìomʆU°ðXFk'²ò8¢´—}ÆkI·eKÝò@¤¥™oò3£D2IêÛ`^b‚Dœžô6Xž£ÈŽŠ‹ ¢¤tvDü[!Ϻ†]e†ãzn®ŽáaßBBÉ–•“ºN:s`aÓë/2r»0®!Aר¶øPÏé±V÷pÑWKœ’çåÈxFjö¸]_=x§g^{ÏOKý¤ùšë:ªÙÍ#oœ™ýwnïÞÝ&ö¬UäbÒ¶ycÍ"¯ž[ ͈öP*%xr†^¥9KÚ·®oEáŶ8ŽA~ö~)veë©ÛU°—Êh†`XÄUÿ;Yr0"àÊÙ'é!_AÕÝ'³2ƒµ2!1À>† yõŒÓ¦}Ä·'`ïâX‹kUXk—• °ŠÇÊžT§¾¡ý߇GhÝ•Ní:/-´‚Ø©Å_^õM‹ ­êˆµË…m…˜é2ct 1qÙµî® ÈÙÙÊÂdâtŸ‰r‘Œä:½Ä<¾ÉoØ¥™‘2φBTÏo¨«Ç1,%IQÖ\ߦ|ÆA!Ié;ã9[”›|àt¢ú†-=œ~ª¾¦rË3Z|‹ý{FÊóµGsÏÖ êKco˜díäNA˜,Þ2†! ¬¨uΣ_]ì+Í@Àq°·Â2† ƒJî'Ÿ=Ò^Õd¿/ªßœJŸPl«Å°âM"ÆÓ#1¨Ú~@½ï¾ì((æ¤j w#Lì¬CBÎ…Ôp°xóé@ÛªvUøÄ‰E»Æq;wð¸1¥¾g>¼J‰ö½ nØöÒȆ f¬§¿þ¶€"ÔîJ‹ÓßwáG†é77æÚ`Òìñ2õúö;ßWù»¬£Ú±ë€»%_ÂWëØa–S¶ŒoäfYp)mçÕe»WI[±ðô*ÍÝ^sªiשbj(«EŽà>>\.FQ@PLè¥"I¸¿ô¦í”¹LK ýgóñÜSó/B °6Æ¢‰„ñõõ6¾Ë± ‰ç ÷ž*’_2ŒX$a(.¿øA¥cC‰^¨®(t±ë;,bh¹XFð¹:¤±ŒâQÅGhÊYá-”/£Ñcýùá9˜ç— Y;~Cq2·wh;°ºñ –½Qœ±Aj Ò”W{°F•uon,*A,3âE‰b–†XZc¦÷sý[¿ç²´¼¥sJ–4w¶J›ž¿ÆÂKÎf$’‚ËÏ6b ®æKÈt<ûb<¾–çèÕѱǡôNÿ¹a]ìú‹0œäë|”ryºw墰–«zãçÇÒµ¥€O‰q”ÆõKŒŸÙXÖº’1®îY¢@Q€ã–Çü>ÿ2 PH¥?}'– ]zJïôŸn‡”j×ÏfÑ¿TXÅÏrÕ€(_Øœ–âÛ~m~W»¿ ÊëI¿o¥Š"¢d·ªê1ÖAíkW¨>ñksê^ëQ•¡€UM_}I*q@”DªÊD¥c­LeÙÚjy¼@ : `êï ‹µ¼”@ ºÃzÔ‚«Ö¯Ö BwXZn_G KéŽ5;üœïÃõ5éïÿ¾üŸ©„@ ¿6¥ÇX/L_{®ù"{½Jì"ߺ¦ßŒuzØà–*‡zõ ,úâªâKnÏÖ{ÞœÎZÞåŠ@ ¿:ÅX%™þ›#¸­«Þ_ùç\6Îz”™{CßDÓ¶a7‡l½ÝÒû>0níV )Ž|,í³fT Hÿ<Ö¶a}3žLüê“iÓFÖºwöÕX æ"ˆß•By¬ZahñÊþ\gŸÝ>¬æç=Ý&D Ú¾¡ñ‚îÝ·ÜZݾò©d;&Z³P¥V [´hOöÎ9?rÐĶ™áÏÞØnÀ»À¿ú_š„@ ?%9V…(4Ëiìá¡5Åé××õX5¡`DÛák<’‰‰ ÍÏ1LS$&&ð,¬Õ^‡—þ9YJÇe˜/ÁÁÙ919 i|pp0É©ôß›ƒ@ OI1Vš1ÏÍ{1zÔ …$öÅ&z²À¼Á´Àžm/T1§0Øþ¹þ…gª€TA3 é³;¯¥‹Òcób®ØòŒ/Ëû"ÎÈܲåƒÀ¢_šfä”0‹@ ~Wt‰±Z/™>.:]"N¿õ.ÚdøðÆàä\ûôytèÜ=¸ÖÁå‡ËnË!pŒàt[·³À“÷\ mføØ¶ãÚ8Ð^NY…‘\cE ¿+Zb¬OŸ>Vý:thddtέe "ê·1–‰?–<:sü؛ВëÍÍÉ¡F(£iInvvvN®œ¡EÙÙÙVðjXûãÇ—«9Qa°SµX4Æ:tèPö‡JH! …2 1¡0O¡ÃG’‡ö홣 Ó¿¥1Æ÷ފѲ´Ü„·½{Å)óN ª\Õ@üÒhNµÄXƒƒ æ¤9S¹Ó áþ÷ßþùg›ø;—%b±‚™Dœø12×À8\$Ǥʰ)cýûòu…4¡­G»Õ¾Wšrr¾-oÿ§Õµkcàõ¬ª«z+ñ«Ãz¶bc¬ê1PóšžF7÷o”ĈҸkÖP®ÍLôø——ê»w±¤Â®ñz{3„ü+ǹ´i]kZKCr ÀHeÇQŒ@ü–°ž­ôW¬Œ§gìØjxW\,K4©oU¥J•*Å4ÆÈ(”ÇŠ@ ~GÊcU®©2æŸk§Ì—ª3rãÝ‘Zêu›í1ÃásŠ}c= Ÿãò(ô®Bñ»¡kŒµŒðK—Â)^ÉR8‡î[!ˆß4yD ˆr¦Ä+@ t£Ì1V@”LÙc¬ÿgÜ»w»¢Uø·´oß©¢U@ þAŽU;¬cb†aÕÿªß­˜|˜§Oÿ©huˆÿkPŒU;b±˜u jÿª~þŒŽ ©Š:øÑ kép¹ÜÂÓÕ¯ús:Vumu"ñÃA1ÖÒÑôªê‹ÿuë¯ÀÍ­‘´ú9ý>ñr¬Å‚a î£0 húÇÍX‡\Æ~ÒÙ4ñÿбjG"‘ ªªßú1:Èå²²ˆcêŽu"ñƒùž«B•U©zþ»{¸\®š/UºV:Ê __áõ\í¹Di5}?$I•q‹]QŒøÁ|OŒ5d÷¤IÑ moÆ.¾YÐi!¬º¹ÊMSò∞Çr.´$WŒ ÎÐÂ<1G_@#35¯ž_§./Lzønܸ’ P-ŒLUðQmÈ‹ùç-¿‘—ùÏâ/fÿ5ºß{®ïP@ ÿgèú®€Ãg£;N©§Z¤e©ŒÖ*™ñ5ÂsË_ßó‹1|Ÿ ¾¾ç÷­°É4œîë{þÄ)á1ê iü”Þ ¤ü‚y߇«ÛöêäR§Víš5[t¼çÒ{¥¢¼¼Y}¦§Èµ7úƒ‘‹BÂĤ·éÏâåÄO…N1VI–ßõ\³ó¬gÏ‚Ø5a)b1={&e¹&5ëVÓg˸>að!ŒûÇ›ÔçO!ŽÈˆêÓÇQdc®^ÿóåCb;oñà1ìÊÓóû­¹=h΢«\9_ÿy|}ã¬oâ}wŒrÆ Z­óÚ8tMÀ¥YZ¦ÉåŽfŒõñâi§“óØR…40júø1E¶XÙ°¤Iyé€b¬Ä/D™c¬‘GvTžªÏ„îÙs4C5¸¿gÏ}vÁªñ¢Ì‘‡}‰h}à\kµm÷éÉÝxjUÁ•þ·oÑÕjÈ…Á3.ÆííÆãQ÷`ÚÊ+ï§_|3¡)T«íÑÆ™ŠŸóè$3~+ÇÏZÕxjܬ€êÿý·^4c¬uzô,”²¿7ÎMí?m`«"[Q‚šeŒ [ÕÖ­[:XœÌ¨QN:- ÅXˆ £l1V¹0dìŽ`ÌNŸkÜþÄñV‘ÁÑuÙ"F‘wðì½¾ýºЊìö«oËÈS¯fòº_=y p‹×n4 °¤çëdæÃÜô•žèà⻦uçç{U%M¦ž~2Ujåµð1®LÙ׬¤¿ß³ædxÏEkšr¾c/”O/kšfF!K[9C²fbwýÑî”)SSSS®\¹¢YÔ½{÷)S¦þD™(=Æzoþ¸tc¥ÿgÞïØ³G¢L¡\̸¾~é"Õ 'M7lØdof2aź¥SÝ Ü,œkkhh¤úë¾h͆ ›  >í ±nÙÝ–Qäþ,´íÚB£}L}áO‹»BØß¹±~/^É¿ÃìCüƒÅâ*ŒW Ö/_Ѻuë"ë[·n½|ù ôn…@ *Rb¬’¬G3ïÁú5ÎKvJÅb1ð[7ÈÖ&¬kh)!·øæ}™D¬ ÝüW²ó¸-£”ô¯±£ÇoÞí¬G%p(Ç+ÎcÕ×§vìØ9tèÐ/_œœjìØ±S_ß@c cE *Œ²ÄX1ªO «„'+ª¬–9ã@ xô$±ÎæªÅmÊ1rmßÞI}Í£à×ê‹Ö<5EÂþÆ “îfü'Ã`eW`1pûöÐ͹ IŠçØ”¢óFÌ•Ó/RçýFWË.¨åîÙØˆûZ××78pààÂ…óW®\­Í«"ˆŸ…2óʨf'QƵ$­%I”L­kZœ$A™V*Œ^¨¹ÚÜìÏ٪ʼns›¥}\¹ïE’º £È©=ÿžœÅ5®UVË…ÏW7ôwcÊÁ=Õþ˧­JÆÌÌlÏž}fff¥ÐÝòXe `¤ìzL¯cŸaÉÙB½3`‹ÉÅâB·`¤±LÁÅsïîÛ÷T½(8µe±Xé˜j¨w<@>ûG*èµf…¶ÆÃ^ÿÕ¼Ú8òI‡îã„kgZQÊ™ìøí×›]ݶöèÉ)»—å‚a}·F]g/=€PH¾K’léXÇãDYY™4‡û_Ĺ\Žz„•Ô¯qåá]œoŸ»íSšJLÎÀž9SÎJýqÊb÷Ž•å¥I–Á_‰£+ñƒùÎ÷±rŒLLè‚yI»1êT\-íçËÇ÷BNINçÑÊ‘<ãNK\–̽s¤›½ª¨~·)w›ŒLÌP¼ÂЍK³M×´0Ræ9Ujµù^+ÝÕ/Eï[1 Îdž±nÓk°‹H%6xð`õ­0œ_Ž/î+SUEF ˆNŽÕºÙÁ'—IŸ¨®ƒðí×8ޱÛ^;×ì8=¾“¯MGŒQ¼Â š ñשÓ6>ìª[ÅÿMÇÊb\Ç­i‰ž«ÂkyµŽ@ ¾]ßÇŠc2±X·G×q\ª{€OÐøÈÚ×w¾¤­ìæQ²àÓssÛo9Ò€Cÿ˜è¡D"ŠþàUÙc¬ª +ñ£ù¹¾yeßvæ€Q¥JNþï•QAQ”ÊŸªMЬpèС€ãeÈÙ`Ã0` PŒøá o^•"^õÇ4úîÝûïØªÈ·dDE«vŠó¤?qS©ÚϪñúæ•vd2iA|UíuP®·§Ê•Bª¢ND ~0?WŒõçäùó¢ïXùµ@ˆ@ü`PŒµÚ·ïTÑ* ˆ_˜2¿+@ %ƒb¬Q +@”3ê1V @ ˆr9V(gPŒ@ ÊcE ˆrå±–Âå+—+ZñSÓ£{J‘cÕ‚KÃúMš4©h-ÄOJ@@)Of¢+@”M?‰b¬ñ¯Ðô“(@ þC*Þ±f_÷û˜¡¾æ“ïßOÓP8@üªècíÛ³«ÓòáUx—.ž)®v…äÛ˜¿–¬Üs°Rñm½=oÉÕa§;ñUkNm^I¸´s×Ó",JòûÈxzXóµ”i#/Öÿ=ß­©Yù7¹#¹ÿF UTÑ÷ñ#ÛBüZ”cÅù|>P±j>{ãö;v©ÿmÛ8'<Ÿ_†t«3‡öŽ0tŽî›+„Y„À¨ÈÊìèm9F== 8àÓON3 Äܾ¸yÈ@V€ä|rûÅŠ¡ñÝvµ0æ€$5>Ð{²q5=à ºR߮̋É3¥¼–Ñ|‹N[Zm¾!ðƼFº«ZTɯ'\;sv ðFç¼Ï÷GöÙŒ­+ú!îÄPQE•{—{[ˆß,..ÂÃÃmmíŸ>}Ž:?cï·k§»Ë…Ÿj:ÿq'(¼‘ÒÖµÍÔû¯{XºÂ¿7©ÅZjãƒÍÊo_oY2?>'âêä^Ý<€kÔréÜÎl‘\ìéÚkÿënú¼œÒjFöbã×c[_z5ÝÑXUáÚÂ…SN[ëaÇ%@šõ¤Aã×ßTçéz‰ŽŽTÏcÝíe¿þ÷ãYS{âøû=ÔÇ1PˆÃ«£R&ü`¨u«©ªEŽËE˜ËŒÑ©^+"iŸ:­>]©ÅŠJüHàòx<®òŽY·Æ–SDòZWy²ÿ•+/ÎYÝJ·t]IކŒ®ëf¦Zƒú͸OR u]Ä$ÂQQ…Aÿꑾ£ÜF?8uîùUÏïÛЮ^ËÀ˜§#`ßוêƒñÿ€æÍžîï xöGóóióbÓ•9vÒlÿÖ=}\\.T„ìqB`lÄ5̿Ў¹½‚4ê¨~a¥¬Šk¿cr]Ÿi›?[¢ô+«ƒlv 1^—UH¬y›ö$™ÔE¿‚ï¡% M˜ªK22Z`9 ¿ÅÊE'Ã/Œ©¥D-ôOœð°)ÄiÚÔÝT¸?  TùãlÄ%]Zš Õù…²œøä£°lÅPQE1Šœnã|›®µl-hèÞ‘~b5xõÇ+\yÆ«7_Xá¯bý6ð¥)¸FµœL¾§-@ Ô(5ìH˜˜˜êáøãES#¹£ÈÂ0»'ëo|ðÌ´^C#Zòæý— ï‚€Bôyô¢€–+îk­ËiÈZØôÇÖ/ó¦:óM:¯;ÞÜúñ"2êÈDŸj«ÖG‰‚ÊE²¬³À³ã•ô˜“17HÍúŒ¬¬—_ôóÔ[BYš¥Ú!ùµà«H¡¾2F¢0p2ÐQŒä›¢¢ )¥_Éo-ôy ¼7¦ c®½ƒ.rqô‘#GØ•áÙæÌ‰d> ¦u§,ö=] „:å±JÆkÑºé• ¤9Ï:÷¿Ö}ójÛz­×[püÏ:_N)þ«&!‹åpyꨫ¾—½­ÙJäù1V1&À«-rµØ0ãô8ßС¦ äC+¤‰Œab±˜f ¾{#3i¶ôü}¹Js OŽË‹•÷©¤4 ŒT,›5_j,j½;"5gË·YKÅb±X"6ÆÊ(gÙñ"œ²ÔšŸ[*ýú&þñM8(S:ïV†¨º—…Žbý*¨¨BŠhé FIl|`¤JÒÙ›))P Çãðxq,Eo]—êl¥ÀÆXóÉáe Žÿ IDATšÔÓ)…U-+M ÆÙÚÌúâCª±·ç$Êðe]«è*†Š*¨ˆoÞ›‡coùõÚäÓÊ«v=jP2ß§âÿ MÁSËcÕõ‘Öf V.ž7käÀ6ì"Á©¼óè€GRmÖüQ© ƒªíä½½+«'Ti\•ÛtïèbS\+Ó–­¶1ÔÀÈÂkÙÜ‚h¨óЪñ·_iݪт± ~Û*uXkEi7çÙÃÇ‘uØßIÏ–øøô¹“Y†Ùkçýë·wœ48&ñÙõ݆ws¤©!–öêܥ߾RÅPQ…\»‹“œéßsõþK "ErøÛ)m<†l+šX¦/¡PQjŒ•ܶÙÇX¡Þ¸15j8VQʇ==3oÆá®æ¦\™Ñu¬ÿø‘C¼=k`j›}\?ëh*)P„”… —ÐZµ:RáÇ+–k¬ zweÀÌùŽ|Ҷ󘼋“dÃYïɳ²«š§ôà««g¦YöWfžb¤©ƒƒ'ßÇ*$ß%J¶´©¬´Gš“‘‘.¡‹züзëíÿ(kä´]Í·OàØÔj7b뱽٢ܴ´4®°T1TTQE­W?•hyÚ¥ƒ;OßWœð]ÆÇ \kê«sgbDƦž÷ ï:Å5²»×ìÔÅç&Æ4ñ>½|a­2žºXR8œÞâaß“ûþ(Ûe××sCG?èuoI¯û.BRR¼Ö]ÓRÎ)ý5%ˆ¡¢Š*’æI9zežW~_[ˆßž€€+«‚+o•çLMMª\¹2èþäU> ¡PAÉ“pC»Òg¡:@ËÄRàðHZ(¦üRƽ8ݯsÇ'ý}›×Ö5g0ìÓ£^c>¼áY–‹µ"O^!„:¥>yUÖO³`W^úáøÅ:œûy¦­Nozw÷[nDD”Žõg|:ä½ëï2yUø—übß¼²j1µhâk‰˜Ôõ×¥ @h}ó @ ÊLÉy¬è›WÚ)õ+ŒâÿM?ÉÓý]ÿŸ¨‡¥¢¬Tü7¯â7ÅX¢@1V(gÔc¬(€@ å r¬QΠ+@”(ÆŠ@ å Êc-…ËW.W´ ⧦G÷’^˜‡«\ÖGo·B ÅQê“™(ÆŠ@ e½+@ Ê™’߀ҭ¢œù+#ÏÈH/ùóR™Á×ý>f¨¯ùäû÷Ó4Ž@ ¿*ºÆXûöìªÀ´|…Þ¥‹gŠ«]’õؽéØÇï‚Í‹ù~*Üž·äê°Ó >!pjóJÂ¥»žaQ’ßGÆÓÃZ×o åÅú¿ç»55+Ÿà#—`$÷߈¡¢Š*ú>~d[ˆ_‹’c¬8ûl(cÕ$"<|öÆí;vìRÿÛ¶qNxx¤Vy%\pK(§Ûò¦´¯ºlÞìÙ³g²2%Á›–²¿—®¦¦ðôÙƒ–±€Çã…néíÝqÚ¥ø"RXbÏ?:y{wÌ$('0’-4?‡ä”¤¤š;1þŸÝ<ꘙT®å1rÎ º˜}]‚*ª¨¢ïãG¶…øÑô¼ü+ŸÏ/CºÕ™Cû Ï;:ç_*—½-Ǩ§§|úÉi’˜Û÷7È ü‚ï¾X14¾Û®Æ\¤Æ§zO6®¦TWêÛ•y1y梔×2€oÑiK«MÃ7Þ˜×èû•üzµó8×iotÎû|dÏ‘mÁøÑº®º‹¡¢Š**÷/÷¶¿%º~¥µŽSµ¦š¾¢§eÛwŸÿöAµæÒÞß$ Õ¢Büu×þ+N˜" ¾ŒMrí&ŒS~ŠýÞ¤k©6{°‹[–Ìω¸z'¹W7àµ\:·3[${ºöÚÿú£›>/§´š‘½ØøõØÖ—^Mw4VU>Å£¶pᔇÓÖúGØq f=iÐxÆõ·ÕyºžEŠ|¥u·—ýò´Á‰!«ØÅDÿqÎm^lº2ÇÎ@šíߺ§ïƒ‹Ë…Š‚=NŒ¸†Ú.´ƒŽEº¯8¹`ì›Üî®ú”z‘(ýÊê ›]CŒ×eÚ¤y›ö$™ÔE¿‚L­ D¡ÉSuIFF ,ô·X¹èdø…1µ’¨…þ‰6e˜Ð"j˜º› ÷‡´€*œø£d£ AK“ :¿PF„Ÿ|–­£*ª¨"F‘ÓmœoÓõ¯ö­ Ý;ÒO¬¯þøb… #Ïxõæ +üU¬ ß¾4åר–“É÷´„¥† S=¼hj$—`Yf÷dýâž™ÖkhD`@KÞ¼ÿrá]P-eyoç½JÙ·×Sþ¦òÄ1ûŸý=A½”oÒyÝñæÖ‡Ù*àñC}™è3@mÕú(±BP¹H–cxv\¸’s2ææ©YŸ‘•õòâÿÇÞ™ÇCÕýqü{g½öÙ[µ÷´JI ¥•J¥hѪ„J BZ¤)•J=-Z¥¢ýi‘zJë“6ZÐbÍ:f¿¿?†13CB¿Îûåõ*ƒ‚zQù‚åû[[X/:jºeB7ñ›ÎНo>‡ÍæŸÅb èÙÏXƒBNçôuž¨1šTRö—"«ü9G ‚Ãb±42ʆìNË-}aäÈb±Xl=V¢¼gQôµŒDÕªß4åžêTÒË'yÐ^MXBJ㔚·”3Œ¦Üíj’]ÎC˜6gn§Ê{ÿù¼ P•{GDD‹¢c!a3´+NœzœK†Œÿw4À8V†=Úè¿>äoÀH8ŽyíÃÌ?ñüþ‚°”À}®ÕùwÏœ k¼];&á8®¨Òzω Çë'y-F§`$2N§bÇq_3ÊÉüšEÙC•^ò]Ù$ 0š°ò`kƒŽÎQ e(¬ªže½/¦«ÿ%×V±Qiå`´03«ˆ 2V|ç’ÖŒn-oÚÕD»4Çã$ì©Â_C+°4ïúWÿv ú5ñ‡Q=càbãXå}¥ÕÌwÿ*ïYNC…›dšþ®CSÖ:Í¢ ©[å)‚_pn×¢Ù{SƒN\ì¥TÞS`tžwhÙ¥5\|w§3%û¶"¼ÖlÐSUVTTTTTTki¾fe¥ÚÃ¥íׄG5eì;ïÛ?Ûum6j×ò~×ý›ß:Ì*ï,gÝptœp¥ ½W»ÈMŒï;l}¥d|¿ñÈçè¾sT¥@ ƒÝ¨I{e†¡]M²‹Louֽ׉Éö"Ï}+ãg§>õÚßyû Eýš@ˆé± ¦Y™½Ìd*ÍŸ™Ñ©S‡ÖåñïîXµ4jô•9±KGÏK\0ËyÄ€N@ZÜî%ëw~ wÛxæ²C7uñŠZ˜{ã”ö"7ŸÑ‰™ÏþÙ€U= ‡ùríÚ jg÷ß³Ø)Ë|:(P ìæ–®õÏâÎfO\»UÛÒò„®¨í´aYžÖäò‘§¥Eûöíi9–ÏN?ð:T¿üz8Å?~ä³Ò'0¨‚r«ñ‰· gy…Ú±¦×eØÌ°Ã[ÊÇá–äååÑ™2ÃЮ¦Ú5dÃÍýê^Á Ö/™¡Õ®«Õ¸­—ö–ø~oF•Û”ú ¥¦¦À—/_45µ?~èââ’’Rå©z~æwE]mœŒ»ðöÀÇWôþ°ãk+OŸuúë xyçöï:~$f +xý÷úªÏâ êäš;nÖƒ,åå9ñõn‡å¹þ§e˜Ž8ä7¹ÆC ¥E%ÀÉ7'Ý;²n·]O¹Ì¹áp}´é¾%ÈÊúZãD×N‰&{š)ahWSíâ”rhJuîWÖï\ˆÿ{’’’´µõD›¢Ì™››¥¯¯ò¿yUŸÉäSyY$ÕV5ÌÈRw\h8EÀd dèž•ÿíΣ‰1ƒºÊ;fðÝ«[ãÌçúݼ4 .7ko^!„82ß¼ªëÒ,dEE2@«†j‰*4~IŠrüíÇ[XßúìjzIZÚ'9ëÿñêÀˆðcuʪñ“üfk^i[xJ|•ŠzwW·_Õ¨´æ@Ô´æU}¹ #ø“©ž'qùç ø3·¥¢® Å¢A+@4ÈcE ˆFšÇÝ-B ˆÿ#ª$V—¦j@üßPÅc•˜%@ u¢V@ õC˜QÑp+h`PbE ˆ¦†q¬¨ÈcE ˆ¦á=ÖUÃm÷e–ÈJðâ¯ý×€§F ˆæƒŒIXX?â÷FKŽÁÒèí8m°žD!§èî©ÔÔ}ï˜åÉZ˰ƒ,±´U9IaSW^Ðè?d—p¥kHˆ;ßÃv´>¼i¸YNÄåÍíÔê|)Ñ<á±²˜…999â%̯7öNžpŸDä³]ëiê:ë=Ëç•æ–~ãwÞp}]õ:SNÌ=&8t9D‰ÇaU,غjé’ ÆC4ôâÂEÌ2‹þs×…@ M€\+®?yݺ*kü›ðfâ2‰`>ëãÒ#©þ7žOÖ+_%ðѲ!- «×yÿèÊÙ!Éá×/µT/焺’ŽÓ(F¢Ó‘á‹@ ~Gê3+»ðÖ†”Â݇»T-æïusÊ£tî¡XY[ÌÝ,˘vUŽýñrãÒÅÑ·?¶ìspˆ¶bÕ€C€r- »"ÄïEÝrÙ¹•«õ¬·cT¹O¿»mÊÎ'Z>ÎzãÙFÄ¿Ö+ èó TD1Ïn³1·ŒÛl™Ñ©zµ¿X@ꔚ Yø½¨â±>~üP´C¸L¶xhÖÝ þ7™Ñ‰CÅÝØüÿÂfïû{É®µJïa3{µuÜçm­Æ„иlø¬Ô-K<Ž' ןœ3¼ûëÝw GÂÏå?%S54\‹Ë#›- à?[¾÷ë•(/4çhΈfÍ«h‚«>‹ìÿÎ[rL£þ“ôÝdtGQ¹N¯™ë¹:tj =VÞìÜÅyÚr2å³O†â8dMvËQÝ;(S€NÁ0MÂBåæ$Ó” Å|ø,QÂÊÿw†­‹Êä°ö%ÃÇd2OMê)ÜE¢jOP©ÚÙ¼‡®"Åbï_~+‰ª³!ÄKz³žo‹Õµ –(¼³{Æ)bÌ Q56 @ š-²^¼¿9oŠ[‰•œï(@Ü¡¢aÎöLæñ-3ûKD ø?Ö9 ¿«=ãúrcù[Àç|ñ¿šéq§·¨„°ŽøMؽë«@BÆ+øÍ¶æ•€÷ãôŽ M‡®™8¯Þ¿ÌÃb€J/—³ÛóG-žT\¸gûüÁ¢Š˜_“7­ò¼Áwp.Á©uÞ6÷X >sËô±„¥­&,äÄ÷áO•­þNXÓ†Äc‰Fº"D3FÞ5¯8E™g®æ¬>rgÒ€*ïYŽX·‰¹¿XCymÇÒ廹ú^[2¥¶·­„Hx¬Ìoïñ†ÇWedføYeòÞÕN¨¯Š@ ~#dx¬"hªÆ±ÿœ®qWû b›Ý»wØr!ѪCæ¹5'ÏÔj+ÚTÔpåüñ€q[âÆÉ¬@ š1u{A 6ô¬HÎP Z¦ÎóLäœÑL‘æ±"BNjðX1 «î±"BNpÇ0 ­y…@ ¿”X¢Ak®$4uÄ/AI±!MÎAƒ,%JäÇúÒ§wOSS4jø#))éÝ»wÖÖÀ ‚ Dÿ}–^QqïÞÝêyRÞq¬ñFÕ¬ZçÄ*O$ ÄŠ@ þÄ{•¡ò“ÌcåM¬ÈcE ,VYE&QŠÿ¯T €¨)O"@ü‰Ðé¸X_µ<£ yz¬ <–D" ¦<)î±Ê;Ü*çáå´B®x »àÚ¾ã÷å<üÿç[XX˜ô˜¬;çÞpÄKXùC÷ÿó ›…@ šr%V‚_¸pž×¥Eâ…#μ«ºH5Áûö!åæå3aAKG[öžsðeòƒ»×âãbމ ߺÊkÞø‘CŒM3Ø|ñƒ˜Y7|cŠ—pyñÍÒŒ»÷r›…;Ác}^µj•”‚W0ÅqÖé÷…â…ŸNm9úÝ ²=Öü”/ùO|²Lgµþ´ùï÷ñÆ—G™¬åªiPIˆ nÉ7…ÑçWô$øÅ~+×Ðõt¯]¾uò´Q×Öqëüž8ƒÁøxr?á¹ÙoN×¶mô.‹UÞùås¾¹;ø:I`±X~á±-~Qîe Útîab=sõ<+àbËÆ{œ¾ªIiì×Þí[¾öÎ7Ѧ€—ÎÎÎâ1zV!3:@î³ÏÙ‰ó¾ Ù±¼kfС·þ3Ìczë{pZhQIózõnQ¦â„+7÷kä«@ BØlvuƒUôTJÖјø“«ŸóX ®ï¼1ïy‡îO¼âe™Ô>ÄÇ©$lLtÜš6ªÂg'º¥W©ÂÄœ$øEîêÓ)+ñÐgÕ–@ð9¢èíÓk_S„‡Ì^âÝ‚B€ûëçd ¦£÷Æm» ²õàEÓÖôWî-ó˜Îvv‹ÑÛÌl§œé¢õMÃD¸«¯×ê&ni^I†xcSncbcSÞÇä1ߨOpŒŒíU»¨%ü„ÑŽü³«÷€ÿÞYž2(í„¥°øô«$Yø™ý#2¶ñZŽ@ d²mÛÖ}û"kÛëê:ÛÓSÆ’}5";O)·³íáÐÙÑaW÷‡m¼íãc vÇD=ÖsSÜßp™¯Nž¼À+{OÊNž<¡¬;ºâáÍ/sàk1›u!æN€IÛ"Éd=ájN7R¦ ëiS®^»ÎÝ…Š Ïk%Z –¦fá¨ÎÜ”œ³×LòŸGMµ_ëgê(oõ±ˆÉRxž¢e6_tºù;ܯNÛl2"ÉuÖLÇ‘fÊU—x±î§±|çs–‘:ä}¸yö죮î~}iUs58-úZ¸}û¶p“Ïz¯Ûf¨h”••µÅâ]J´ :5¦±ýð¸G~Ÿ iËšUjåø Þ|‚.¿´½B5z¬·oÿ#9x°¥¿Ÿ/¾æ^Ãy¬eyçû^! á$Ö4×{–ݪE}8´y¯6“ ®3œ슲6´MnËŠ£;bX~áØ…;/ì÷¦‘°”­~K©¹Ù¥¬u+_ÒÈßòÊ&Ñ…†,¼Ë.Ó˜ª#:^¿ù7oôÜqÐÞîm]\=ý½&W®¬­3@“™†ãà£ý©´JŸó×rd¤ù–Ìâò ‚ÛÌÌL´WIwîý„…ÀÌ9ѺË'1‡ O°íe©¶hÓ‹¸½'4K¹`?z”÷±³#†k“­ÖHíF Õ¨ÍcݺuÛ‚ó=z$ 366Þ²e+F¯VAy¬ ãîß³ «¶6ïÞ6Äß05µÿ0úV´ìçD¸õA·SΊÓ,ó²¥^EŠõ]¦{c¼·q@Ÿu{"»¶ˆ³é“z`¡žÒËž¢Næ'_Q_AütŠú}=×ï[ä“qzoÈšÕ“_äž?¸¨Wù.E>ëC~‰ ‚ó¥{¢A<æÕ–¦ÏŸ×ðJ±åä´Tk\McU‡–†{7wyý¦€ow|è t%Ä¿Óïžµ ú­­ï”Õh•D¢YãøŽ;]\\Þ¿×±c§;vþä{R²=Ößqa¶Ñ]8¥Ï¬L|tyLIî—Og¶Æ1Æ`$lÿÌ>xb¿hùÂSž –ÄÂèµgu )D ZÊRç±TRAf1g¶ãU*©„E™Y±üª”›Ã®¡MJ­&/ÙÕž:-ÂݲsØ$šœ k5 <æ«Î=ÆT)"x@° %"/¼|Û]‘òÜmÐÚqq=¸Å&Í¿•ñxbQvFê‘51ŽY uð1qN>*Ñ QVVÙ·o¿ŸŸÏºu”•U~²6ÙëÕ§yZn8 È ¥ÞOþ£F8l¤ïÞ¯?feÓª¿æÞR#sÙ,.üx·îóÀuVŠÁæ’{*ì5Ç.œv°Ì ‰ðÔWžÂP™vï¿\Ö°r—ò¿KѪVS[ãåÏÐU˜e,–0å¼üAS3lÌy (ŠÝß¾}+^ïaìþFC@štaƒ&µrP-…B€Ër üÕ€®1ª}é¼g´.NÙý}6ïÜ×½ÍhÌÅ–*R×G ¿”ŠRe+TØ®jjj;w†Ç«~lÅ , ñú³ãXcóXkô1ŒBÇöèöSðyÛ\†óNCU% °Žãw::`ÖVµ#>tºDn¢ã4&@ù Z›Ì|YÊ€œ&{µÇ:Î]o× Œ¦· ‰zޝ4>çkÔÞ]‰»ù¯pîÛ³uú“û[‚žµ¹C¡¢1oguôè%¬6ë~€{Ø+×È£¶Œ_ûF“0c ¹ºËÝ5VãiÚ•+ƒ{õ½~ÛæY¶=+“+Á9šÍÜ®¥€y÷éù —™²e cÞá6t2´ŸmµÓÐf¹òåg Ê®DS@§Ó$V¹_8ð§;³Kûž#ÔñÇ0êXì9ßÑÛL¼ê׺ 8›`Ô€S—|F®z0h“©v' *^Xef¼ï½z<ÄÏsüæá3K[ Šóy‚’ÝÜÒµþYÜÚT™¦·óâ•í~knZº2=—¢¤1t¢÷FŸáÍH?ð:T_¸)àÿø‘ÏÈ3 ÷ç x_?¼~t;þ`Ôþ`våå%}:yÖž{]¢ýÝçXú*t™0n„É€þ“ím1VzNFöÂÄ ¯Þ=¶hàº<—§›Ûý(üÎ 0Ú¶[Z p»=,ÒR÷—·@T£¶¬ZÄ*‰•Œ·;N¼ÄdÄÌa¦öÌvNôz¸™ª»áìe‚¢-qlú…Cá)ùå=Áé¨ðŠ]ëìtœ1< OÀÊøŒƒcÚ™¦»dÓž%iú»ïü+ ¢¬Š@4 Rº«2Ó¥üY°ÔÔTøúõ«††ÖãÇ]\\RRÞVã²ÊHt93€‡— IDAT²2–‚‚\7é¬ü;öc#¢nÕ­x=©:|Ö§Iíˆ?k¬òk_€¬¬¯âK³üb «ÔéÆÃ,%)(¡›}¢Y!\šÅÔÔ ªLÀZeL«tÄsñ“'Éâk^‰2g^^¶žžÈ?kÈŒëؚٜr5›hÛ½¶˜ÇVÛ…ÔRUþ4¹ÎiŠJ¿¢%âç¡R©¢|*Ñ]•³ÇŠa@üì\¿m Ogç´ORbÜ«1âO N&€ 9c›>±"DãP[&•Ï<-’ëáZó @ü!p¹œŸYóJü(´æUÝHJJjê& ˆ_ƒ ö¯»¹{¬ÍŠ6mÚ7uÄ/¡1ÿu7öb'ñòX¢@+@40â+²¢A‰@ ä±"DPƒÇŠaòX¢Þà8ŽaÇZ×®%4ujÅÚzxS7@ÈJ¬’óWÕioj}Åø—">OĽ{wóÔâg@«$,«ÚÄu˜´±aoÉþ½ Í4ŽUt:]b–Fñ¹Æ³%Óšýáß ÑÌAsH£zV•*Üo‰Äñ[€k HLg‹a 4Ab€&ñÄO‚ë‰e³xá±Ã„›ç– ˜´ÖR«yýœ¬±áÃtÊwõt᳋oŸY?…âÔnƆø:¦]Ø3§n0:lÈŽy;_]ZeÜÐ×Xª{¬4­1 tW‘ÇŠ@ü^ÔÙc}>Óÿ&Óv¸yó”e_]yZ&ܤ*u4@WÉc¦¸ŸÊŒ|ÜC¸ùå†WÀÙgKÎ>YØ«èöÔÒ}¯b»n¥“ ¯×ê&ni^I†8ø…@ þO•ÎÞùÍóVOðJ¯Æ Ë^ÄÇþ5tÔ­+ñÀ)Nº—ê•|}¢pWÖƒ®æt#eao öû_mÑݧ"«–c¶ää?€ ?ÓÔ,Õ™›’söšé@þóˆà£©ö«ƒª6j'@ «€›{÷¹ÊÁ3þÓG‡¬]»^X¸þ^|»eNZ Pæn·˜+:äixŠ–Ù|á&Á/9–Íì2ÕDº9hÝOcùÎç,#uÈûpóìÙG]ÝýúÒ |¡rƒNñÓû#½ç‘Œ¦· ‰zޝ4îêä¸oŃq!óF|÷Z=f`?'óîÝa{.»E(+ cßÎêèÑKXyÖý÷°W®‘GmMæ'"@Ôƒ:c%ãíÈœôÅë6ÿ¥­N§S0á`)‚ÏãòÊÊJ?>ŠQmç"ìÍØÍ-]ëŸÅ¡M¾LEš³íB¿A[7‰^°Ó¿”O3èØ{yxÜ ›ò øìôßÙ¡Cõ…›NñùlASN”WmŠë&œµJ~G ¿ ò%VšîÕ¨í—_|ÈÏýÆfsø|™L¦Ðè ŠÝm½fŒ+ŒÄÃú¬ŒÏ88¦èð>öKÙ/›4œTå)Ù§sË[¨•w u-·]³l˜ û q  +Qc3Äs´4¶™.í½SBt”Ý–µûÆz~´<ªK«îɲūæ³>ylÉÝoݬÜC«õéÓgÂ’Fh—ËþWb¡­fõ[B üÚùXq=›[S®fóm»K||aµ]øñA-Uæt Fï'&''7~’““ÕÔÝUä±"Í™_¾æ•¶…§3€sÚ'™‘n¿âô?‡„  ®®Q±Ù¨·äU}d ¿hêIÄÒ¨x’m¯S¼%â7­y% —Ëf2@•ƒ„+ 6v†zö‡/D3­y% …RÑY$KtWxAT®û‡/D3ç—{¬¿5b™TbLk“$VQ3Äoƒ¼“°ü9Ü»w§©›€@ ~K*'aA«8ƒY6ujåOþ^ˆæòX¢÷X›Ñò¨ñÿJ¬ÑÀ @ ä±"Dƒ½{ššš6u+þ8’’’:wî,3ìíÛ·Ž8‘›„Ÿ‘"š+ÑìÐÓ“±úׯ_§%ˆ?œ‘"J¬ˆfÊ›ˆfBƒHy¬ˆfH‡ÒAâDüjê-ÅßÕÕ511ÑÕÕõøñãdrõµ~¥ñ.Òoûó¼wi™, p6”( qn´3vC¾K«—8‘‚ó£§Î‘ ¤è­¤({kþ«ÌÔ£ó³ÍÖ»uúó/ÄÙôék9dÁáþ=okë¡–¦]G¬{^ý@2Ukݺõ5þX«× ²oïÛ4Ú¼·…]¨är¾zŒ÷å(;Ùs½(¾ëί•Û^ˆ—œŸ9z¢$¼Ô{Â’ž@æ"¤óõî‘1ý»©«©ëwé?kÅ™¿Ð³î ÆéÜÊû©:Õàçç—˜˜‰‰‰~~~ummþ“ÛoÕ99M­þ3ÆT«züȾäò…x||ö‘Å«±ZyÄ Ï×:š%€¤ØPd¾JÚ·ÉÛ¤£~ç~k¥„IÑ[£IQ–ÇJp½fؤrõ÷ý3â´§Íí¶ë°X\ayÒ¯uù²ÕŸb§z¾a³X, øCBøœ/œ’ÏþT¥¿–ºq±•Ï募2àø…Ö<Ž„€‹>­µšz{À@³^ºøç¯< ÿâAs¦]hœ` "¯ß¹¾€i…“0{uÌ…ljF ÛÑòöòK7&¥tßÕSÑ 1ßâœtÎÛ¨N¿„8Eôµ›ß×k_ò%»Ò7×gÙϲƭѵŧÇ-›}V“ÊûW±êœ5ˆtèïïïïï_½\ˆL•# òž\<’¯\}Wð¶íÕ7p\úÕÆûží•øø'é<‡àÖú1rŠ“ÅbggfdæH`*–HŠ?OÁû%=lâ-­†™´Vü^k˜½ýj)Öi+~:ØfÔº”—ûBRM÷Xâ$ŒJÂÜŸQË{»œÂÏd[:Žã `;y%Ègérq·Î-Ö†Þ÷õvÌøø1úÁ3}Zyðl³>|* Ç%ûáx瀗id ž®váE¼ oÏå“V˜µÂqЉ·ÿ'Ï/ÞI†8üPOŽ:ûçå '€–.Æ^ooãüÈ/ÛX…V=¸,çš•Ëþ€Ûi«MZÕµqcK 2=V Ó0qÞ¸¶Õw©**ïå8ÅISgnd•± ó¾ç³Èje¡§³×îÚgÑW™\ÃRrŠh$`”êDRüy‚s2·Q0x¸øÞ±Ú«½ýj)â8^X(÷\ÊmÆÆl³ö™½þàÔ°·……vÇccã„?»=º‹‚1²Šýhs ÞÎa¬µ¨0ù~¢ˆ‚Únˆ0ZM’ÈzÂÕœn¤L {s5zBtšpWÚá˽çÎo­r,æsyIÔue½¹(@S³pTgnJÎîÊáí½ô~Gæ%#„ü’u/r{¹ŠJ´M¶Pù¾—2jæ.´tÖš³¸;[Ñ]­S Eöƒ˜={vWÿa Ê[ES6v_ê·uçþ¸›ÿ{ö䯵¿•ò“ÛöïYcVWœR@Rl0:EÖRRôÖÈR”ëïçóÌ–Eö£ªGšùÌã1$ïÙºA¥¼×Y”–j=vÒôï“ÿ}_±iêèb@¯ÛãˆW¯u/m.´Òs;>½àX\Æ_a]ÓÚ‡Ÿ„…p4þK÷q¢à‘Zz†¿3](ÉüçìÙ‡=–­¨ZCo Qvqâ® »QåKŒ¬:³xh‚⤴`kÕ£†ëׯKo̰aÃäl¶Ö@§Emª——ÛG€Q,LEåT¥¾‘nóÝOÝ‹r’ó"$Ä)$ÅF@ŠÞØÃSSŠ2:Ãf”Ct,£2ŸŽ?ÖŠBWøXVåÙc›¯Ò±JÚbf'XM?àûÖTMÒ:—³ãu¡Pkû*i䎎“àuÖ£C[G»V `¯\à6ekD/ep _…G¿·Ð¾½š"N!ñÙŸ¾—éé3h@Ò¨¶5•ÍOõ>îus©”6Ègm+ )6 RôFQhQÛ.‰Jê-źy¬)¾ã¦_üœÒg V^±êÓU_߀ûàd\j FRÀöÏ IœpÀSÂýøQüMø¡³ó|Ï#ô[ô˜äáá¹Ø}®Ì3J C#±sØ¢MŒ¤àÝCãÕÞW/÷¾î0³ü®ßm¨Þë=Ïßxm0z¾ø±ì6‰&ãÍ_DmД{ªSI/ŸT %¥ñ?Ê´Ì[Ї¥lñûÆÃÏ{422222ê7Àü¬Í˜Ž‘³†Ÿ‡DÕ²°la1¸—®Ü®Ÿ…Å` K›3ºÅœK7·ÜYáë¶Õ;´ŒL-,kPHÿ:hüÌ{å—Éèÿ|ÁmÈÁV6öumbWzÑ›*Ýuã%ýòžïÝó_Þô±åOŸ;/–ÿ_øÁ—ùcgw,L)¤3ºÔõŒˆr0Z˜™Î‹ÕD™ +¾sIkF·êèºóÜ™#ÁlX“üÖ¬_·\ÎÄYµj•~«V­ú™æ÷]vÜ4sç8¯9¶ó8…_Û»r²b…ÍJoѶäË9Q¬ ÝÓ¸¥\ƒÅ©.ÎÚ@Rl ¤è­q¥({ë™\–Ÿ–L<6ǵ{ׇß~¤ìwV™¼ESÀ%€Ð²Ùlz`ðä5´ËíÉÄÇE±Ø¯ ‚üʸ>&`päéÍíÔ2âÝ-óï-àæö6¶—b-U·±:Oiý%:‰µ¨2c*wñ •Ú¾Q6µQÄ„‘4ù꼨‡DûÝ-(âÇÞ¹ñ­ýÂÂ’¬k—îz=cWÔ0º“»ÈMþ=gØút ]0¼àùµ…Ó£ûÎ=(|äè`÷˜:öâÉyjMmÄ&Z#x…Ðc°Õ°–ŠÒkG¤C__ß÷ïß'%%™ššúúúÖc«€Çf±Xù)‰÷îùœ8¿c‘Sn·Áô•Å¥iz Ud=Ë×ÓÙÞ¸kkC•‚2ž:Ë'G à±R/]ª|‡…LÓ¶Ô%")‚T½ýj)ÖÁcå³¾uißsŒ.ã9†Qèt‡ÎùŽÞ^äx5 “[$® tæ’¯ÃÈ5φn2Õnß®5» ÃÈÂJhöéܱC-ð‚7Y…zJðK0)N“ªvë¶mµÅÚÏÜè_Hž­]1rðNn­TÎöõ ×uQS_¡¬ Öxvúá,v¨m;§ Ê 4:ò¹äG¹ÕøÄ[…³¼ÂíXHÓë2lfØá-åþxI^^YÃ1©S§Nª’ÌÄ|®~²5»·;÷ÈE[ñÛ½³Ê¦öüvNÚ8ß8µÜïEGè° nõžðòA\µí1Òm¢feC ~ñšõQïÞü+û÷'Æ1§×&ÇSÃ)¤˜<ãêÄ»Qµ>(«ÎçÏÐìÂ5"à”‘hu¾S–³ùgnÓ¦}m{Sÿž4!<׸ÿþýû›š[þÕZ]|/ûÇû˜COßä=¿YEÒ¹"˜E…L6W³e}ì6yĉ¤ØøHÑ[ƒKQ”9³³¿µnÝäŸÕçÆ#®ºæÖÜÿwh/‰ª#úLgX<¼e&üluþž%®H«*cûñÓå<©‡]!ûm—|3¨«äðÉÚx÷ê–ç–¼-7k}ùQ'~2«6H Òéàô÷³©µê™®ÞÑÙkƒ³W;1EUYSzÔŽLq")6 Rôö«¥u˜#ñÙ,®|•’°ŠJ0°%«#‘°:ßS49¸ññ•÷y¯^½‘óˆì”CÖ¡{Ñh¨àoAÍÇZó*¿YâDRü½hÈùX¡Ù¯yÕÆjÙ̺Äëö/× 1ˆæp!)_wùʼn¤ø{Qo)â8^T„Ö¼B4'äcø¥4ˆQb•$))©©›ð'òöí[ÙAHŠMBƒH­yUmmônL³æÏ'’b3çÿÄcE ˆæŒ¸Ç*û•V@Ô ”X¢A+@4ÈcE ˆy¬ñ )O¬&k™.@HE”H‘ÇZ…„+ MÝ„4†Ûoê&4HŠÍœêRDk­ôéÝÍÕÖøÈ?WÛŸ#N$Å&ág¤ˆãxq1š+ÑœÐÓ“ñ¢‘Ì%Þˆ¡A¤ˆ+¢Y€ò&¢™Ð RD+¢YÐ@ó±"?K£ÎÇšóðrQkC5ª¨„]p-:^iΔ‘|vÆÑÓŸ¦O$×E Pu¡¡ââbáBC**’k¾ÿ9+¢©¨·ëì±üÂ…ó¼ÌÝ_Ü[CT˜q1âLšïœjÁ¼²Ô-;¦OÄç|™2꣮ £'·¬e- ‡Ñª-§ ̬›/&&ºò® Qšq÷©‚±¹&úwØ0<6F¡7B |>ßÕÕ511ÑÕÕõøñãd2¹Ngyé·ýy^»´L–8K®žâ<Ühgì0†|—V/q")606£Sd •¢·F¢ìò_e¦Ÿm¶Þ­Ó×И ΦO_Ë! ðïy[[µ4í:bÝóê’©ZëÖ­¯ñÇZ½‘}½ó÷¬ÑݺtéÚ½çH§¥‰é¥•WÈùê1Þ—£@>ìd7Îõ¢øQwÖx­ÜVeqÍó3GOXtƒ„—zOX’ÃÈù‹@ÔÆ×»GÆô瑩¦®ß¥ÿ¬GdþBϺ`0§s+ï§êTƒŸŸŸp ÷ÄÄD??¿º¶6ÿÉí·jƒœœ¦VÿcªU=~d_rHH²ðóÏ>²j^ÜEqÀóµN£&GI‹¤ØPd\Û7Τ›ºj F þ¶³o~(®1LŠÞMŠå+†a5{¬×k†M*Wß?#N{ÚÜn»n‹Åv‘'ýZ« C>ÅNõ|Ãf±X@ð7†„ð9_8%Ÿý©J-uãb?*ŸË?eÀñ ­y §1{­é¬å6Ú)æ$ŸŒ ™=fjü¿uhdxäœiÚ'ƒÈëw®/`Zá$ @À^s!›šèv´¼½üÒI)ÝwµÇTtCÌ·¸'ó6ªÓo!NÑÇ#}íæ÷õÚ—|É®ôÍõYö³¬€q+¤ÖuñÒã–Í>«IåýÇ#ˆ:Õ 2¶üýýýýý«— ‘é±rDÞ“‹Gò%+€àmÛ«nà¸ô«÷!=Û+ññOÒyÁ'¬õ%bä'‹Å*ÎÎÌÈÌ‘8 ¦b‰¤øó¦EösðêµñòÁ Jßïï]á0pôŸoЫt$¥èíWK‘Åba&§ÇЇŸ¶µ.åå¾T“Ä=–8 £’°wçgÔòÞ.§ð3Ù–Žã8ØÇN^ òEº\Ü­s‹µ¡÷}½3>~Œ~ðLŸV<Û¬ŸJÃqÉ~ø?›öÓº¸ïY9Zwïßéd‘{³¹Á”xÌ”¥g¿D>6ÂqjGÇYü-^ÑùüÅÊP’¹7‡Ö_‹ý(¶X0©¥"}ÞžË'­0k…ãoÿO&ž_¼“ q4ø¡žuöÏËAN-'\Œ½ÞÞÆù‘_¶± ­zpYÎ5+—ý·ÓV›´ªk âÆ–dz¬4¦5`â¼qm«ïRUTþä'M¹‘UÆ*ÌûžÏ"k¨•…žÎ^¸kŸE_åê÷ùr‹h$`”êDRüynyo¥ýµòx;@×ñ[;ìki²þcQD—*ëœKÑÛ¯–"Žã%%…òz¬ÊmÆÆl{8tvtØÕýaoûøX€]Äñ€6å=Ö禸W,O‰‘UìG›¯/qk½6tŸ°0ù~â§Š,\PË Ñð}·ûˆý=ðò@ØçÉzÂÕœn¤L {sµ• Ñi‹}z@Úá˽WÎÿöæXÌçI »@ZÔue½¹(@S³pTgnJÎÙk¦ ùÏ#‚¦Ú¯¨ZCR@T‡à—¬{‘Û󀫨DÛd‹õoßKW'Kš•¯p¡¥³ÖܘÅÝé++º«uª¡¡È~³ç{ =ÖЈHE4ec÷¥~:Ú:Ú::jŠTné“Á& Ûö­1«‚Üâ”’âÏ3îÌ«þÌÊM?*¾Rôve¢vcJQ®¿ŸÏo<2[Ùªujæ3Ǽgë•ò^gQZt¨õØIÓg¼Oþ÷}Ŧ©£‹D×½Œ¢]aý ¸ß7ÎY¢¨=tu;5xñZgpå2— ­ô\ãN€O/8—ñWXWã´vÁá'aa ÿÒÁ}œ(x䀖žá¯ÁLJ2ÿ9{öaek‘šå„]œøƒ+ènTùÄ#+R£'ßÉjZ<³xh‚⤴`kÕ£†ëׯKoŒüK¼i tZäЦzy¹}ÅÂÔXTNUêéf0ßýÔ½(§šk”[œR@RüY0ŠžRùG端ƒ«²ÞˆÍâ!RôÆžÚ˜R”1Ž••gníGéËÑé¦E×þÊ>;žî Ú±¬Œ æºÎ Ýcnf¢“Gg±X `A°Ø‚à³Xl‚àˆ‹ÑlÕV³ê)ÿ=k`?²¶å¿JXêᓦ1äPl0™Ëfqáù7¦Ú%Q«ÚÍVv.*9ß·ñßÙ<îù.*š­§1¼“ó—u¼ŒÍ/ ³n) VîÅ`F½d±€–ÕáW¯$/!' ªü!ì¨@¹õ®H"òó…%³Nò¯|ؤ@ÂA}jpqq‘Þ˜´´4¨ý»ã–=;mÒ¼×ZvWžDªT½É¢·FbƱâz“­èª-‚Í»·Ýh˜šZ¼J[} IDATÈvò~´ìçD¸›Ñ¦[Ίó,—LôÂ`N§aÇéFNݵñoSÇáêxáûÓq™fÓ†èüÒÝ‘±NSÆ×Øâ»Q>n›âìÜ7vE«øe°ùÊm¢VÑ;.ѧŒ|SÈÝ«¨;§;C 檫v¿,Z‡í£3lFéTþc´Sæ³ÓÑàÇúAQè ˪<{Ì`óU:VI[Ìì«é¼cßšªIZçrÖr¼î"jm_%ÜÁÑq¼Îz”chëh× ì• Ü¦lè¥LNá«ðè·óÚ·WSÄ)$>ûÓ÷2=} HšÒ¶¦²ù©Þǽn.­­òˆ³6ˆë;Mñ;íà»|½šs#Eo…µí’¨¤ÞR¬›Çšâ;.Ì6º §ôÙ‚•‰.)ÉýòéÌÖ8ÆŒ¤€íŸÒgbÂO‰küQüMø¡³ó|CFú¥¤Ä“<<ú ¸9»#ck<Ñ­­Îî§Ø;/&é *^®C#åæ°E›IÁ»‡ÆÆ½¯^r_w˜¹JXè6TÏsÏó7´×£w‹ËÎa“hhµËzBSî©N%½|’íÕ„%„ 4þG™¡yKñ°”-~ßxøy¯‘çË àgmª`ððþiyjøyHT- - ÃãÛõ³°è;gtó<—¾pŸkΣã3ïh59ÐÂb°ÐfÍ4~Í´ç†Ñy~`äô/þ#u¬­~9Å)$ÅŸ'>`ô´Ã¬£ߎè¢Vc€ÅÒ”[7Ž…ÈN¬7Ÿåéz©aݺÔûmÃûÜ‘!áû§ßDÝîßkÆ ¥j®ÿ\GŸÆ~zçæŒÑC($~YVv™Û{t~M'¬»ëÊ;žx¾O5ש« ýþ›"UYb¼¤_Þ¼½{y3v•?}î¼`Xþ¸ðƒÔü±ªüÛ(L)¤3ºÈ¼FDÍ`´03Å«À„õ‚̄ß¹¤££[‹GutÝynXåˆBBÀg?e’ßš!êêrÖ ÎªU«¢££…Ÿ]\\‚ƒƒëÝü¾ËŽ›Ž2çõ ýΗeáצ™UŽU ·h[òå‡*ê{*h÷4®¹šº‰³6’¯×WLÞ}5õ΀j7F•HÑ[ãJQÖ\÷L.ËO K&›ãÚ½ëÃo?Rö;«LÞ¢)à@hÙl6=0xòÚåöd âã¢Xì×Á?~å\08òôævjñÎn–Æù÷ps{ÛW·'|½ŽêZ{düŸ!V¨¨Ûß¼‡zç)­¿D'±UfLå.¤RÛ7ʦ6ŠåÃoi:óÕyQ‰ö»[PÄ+¿sã[û…„%YÖ.ÝõzÆ®¨a t;&/v‘›ü{ΰõéº`xÁók §G÷{PøÈ%ÐÁî1uìÅ“óÔ:›ÚˆM´Fð  Ç`«a-¥× ŽH‡¾¾¾ïß¿OJJ255õõõ­Ç8VÍb±ò3RïÝó9q~Ç"§Ünƒ;è+‹KÓôª:Èz–¯§³½q×Ö †*#j ¿89•zéRå;,dš¶å €¤øÓxÌØ×jlà×›—ω*µ²°é§!’"HÕÛ¯–b +†a5z¬|Ö·.í{ŽÑe<Ç0 îpâÂ9ßÑÛ‹¯t`r‹@ÂT‚Î\òu¹æÙÐM¦ÚíÛµf¤aYX Ã>;v¨^ð&«0ãâ¡CO ~ VÝž(ÑjEyyjçË*…zCB‡ë¶;Ÿ¹Ñ¿<[»bÌàÜZ©œíë)V¾¬‹z˜ú e±Æ³Óg±CmÛá8 hPVXX  Ñ‘Ï%?Ê­Æ'Þ*œå>hÇBš^—a3Ão)÷ÇKòòòèÌŽÁH:uR¥dÖ ŽøàÁƒ _ÐVV–5%å»ðJ?½{ó,»,óÒúq'Þ)³¶©ÒÆ?úŸAn ì¬LÇM=z´µI7 xè¥+'vGœ]ú™ÉIéÝ»5Ö,¿8UuÛè1Þ†…½…ÑÕ·6FRüy~è¶%?:ø¨Ja«áQ6ý4Ä¥(Eo¿ZŠ8Ž—–•gÔ/_¾À—/_44´îÝ»íââòáÃçê'[3°{»s\´¿Ý;«ljÏÿhçtA¡óSK@ÀýNPt„~»àV¿á /„ÀUÛ¾#Ý&jV6”à¯YõîÍ¿2âspmrÌÁ15Œ¡‘BÚ‰É3®N¼Uóƒ²ùüùš]¸Fœ2M®Óõ¨AþÙ…Û´i_ÛÞÔ¿'MÏ5îß¿ÿþ¦æ–µ®2nœýã}Ì¡ƒ§orŽžß¬"é\Ì¢B&›«Ù²>v›<âDRl|¤è­Á¥(ÊœyyÙúúú ÿ|¬>7‘pEÐ5wè°æþ¿kD{ITÑg:Ãâá-3ág«ó÷,qEZUÛŸ.çIE8ì Ùo»äëð˜A]åÊûîÕ-Ï-y[nÖúò%¢NüdVm¤ÓÁéïgSkÕ3]½£³×g¯wbŠª yg÷©†Lq")6 Rôö«¥u˜#ñÙ,®|•’°ŠJ0°%«#‘°:ßS49¸ññ•÷y¯^½‘ Ù)‡¬Cö¢ ÐPÁß‚šµæ)T~-²Ä‰¤ø{Ѩó±69m¬–ͬK¼nßùr½ƒh§’‚ðu—ßQœHŠ¿õ–¢¸ÇЦ„@4 äcø¥4ˆQb•$))©©›ð'òöí[ÙAHŠMBƒH­yUmmônL³æÏ'’b3çÿÄcE ˆæŒ¸ÇZ>ŠÃd­ ƒ@ ©ˆ©ì5¯Q'ÇŠ@  @ ë?ÇŠ@ õÇq&³¸ŠÇŠ@ ˆ†%Vh`ÇZ…„+ MÝ„4†Ûoê&4HŠÍœêRDk­ôéÝÍÕÖøÈ?WÛŸ#N$Å&ág¤(î±–¿ÒŠÆ±"š==/É\â h~FŠ¢DŠæ @4 PÞD4DŠÈcE4 h>VâgiÈùX ¤{¬9/u±6T£ŠJØ×¢ã•æL(Égg=ýiúÔAò^Qu¡¡ââbáBC**’k¾ÿ9+¢©¨·q/++©Ã|¬¿páÅNõ|Ãf±X@ð7†„ð9_8%Ÿý©J-uãb?*ŸË?wÀñ ­y _íOݰí yÿŽß_ý»uÙ’ ™*×vMî}äœiÚ'ƒÈëw®/`Zá$ @À^s!›šèv´¼½üÒI)ÝwµÇTtCÌ·¸'ó6’ç7‚¨‘¢GúÚÍïëµ/ù’]é›ë³ìgYãVH­ëâ¥Ç-›}V“ÊûGuªA¤CÿêåBdz¬‘÷äâ‘|ÉÅŠ xÛöê‡8.ýjã}HÏöJ|ü“tžCð‰k}‰9ÅÉb±Š³332s$΂©X")þ<± ºŸ¦ì?zÙzp·Ì'w}]\,35ßžš!&Eo¿ZŠ5x¬………µx¬xøé`›QëR^î I5IÜc‰“0* Kpw~F-ïír ?“mé8Žƒ€}ìä• ŸQ¤ËÅÝ:·Xzß×Û1ããÇèÏôiåÁ³Íúð©4—ì‡ u^;kŒCgh™Ù|ÂÂuŽO3eéÙ/‘pœÚÑq‹Wt>±2”dîÍ¡õ×b?Š-Lj©EŸ·çòI+ÌZá8ÅÄÛÿ“‰çï$C ~¨'GýÀÀór@Ë c¯··q~ä—m¬RýXYÎ5+—ý·ÓV›´ªk âÆ–dz¬4¦5`â¼qm«ïRUTÞËqŠ“¦ÎÜÈ*cæ}Ïg‘5ÔÊBOg¯ ܵϢ¯²äÊØr‹h$`”êDRüyôlgïp›4ñ/u`˜ŽØiÖÙ~-À ‰0)zûÕRÄqœÅ*•×cUn36fÛ᳣îîÛxÛÇÇì"Ž´)ï±~<7ŽbyJŒ¬b?Ú|}x‰ÃX뵡û„…É÷?Udá‚ZnˆzÛºôÛüú0›¦b,üœõ „«9ÝH™ öæj+¢Óûô€´Ã—5z¯œÿíͱ˜Ï“v€´¨ëÊzs;)P€¦fá¨ÎÜ”œ³×LòŸGMµ_‹Å&þ‡¸ÍVm5«žòßó±ö#klÍù­ë/|ÌÌ.Qžæ¹ldaKžcªMPµªÝìae碒ó};ÿÍãžï¢¢Ùz3À;9Y'ÁËØü²0ë–¢`å^ fÔKk hY~õJòRp²ÀP¡ÊÂŽ ”[ïŠ$"?_X2ë$ÿʇM $ŒÔ§éIKKƒÚ¿;nÉ“UG ïE^NzÌÞÉÁ1"¦¯ÙÔC©J¢$óø5å)ºOV†&[.èÞ¢¶å'G ‚Wc#‘„SA>ÇÞ}üZ¤æ¶f½ó_’_–½5‚ëà±âz“­èª-‚Í»·Ýh˜šZÈvò~´ìçD¸›Ñ¦[Ίó,—LôÂ`N§aÇéFNݵñoSÇáêxáûÓq™fÓ†èüÒÝ‘±NSÆ×Øâ%Ç.(úœ4ßÕîúÇÄc‹ ƒÍWn˵ŠÞq‰>í`ä›’@î^EÝ9ÝJÀp0W]µûeÑ:la3J‡!ªÑN™ÏNGƒëE¡+|,«òì1ƒÍWéX%m1³¬¦ðŽ}kª&iËYÈñº‹P¨µ}•4rGÇIð:ëQŽ¡­£]+°W.p›²5¢—2 8…¯Â£ßÎ[hß^M§øìOßËôô4 iTHÛšÊæ§z÷º¹´¶È#ÎÚ8—Z‚‘°ý3CÒ'ð”p§~~èì<ßÃÃsÆý=&yxx.vŸ+óŒªmŒ‚{¸íN!th$v[´#)x÷Ðxµ÷Õ˽¯;Ì,¿ëwª÷zÏó7^Œž/^;‡M¢¡Õ.ë M¹§:•ôòIå°PBPÿ£L˼¥xXÊ¿o<ü¼×H#####£~,ÀÏÚ|€é9køyHT- ‹Áƒ{iàÊíúYX ¶°´Ù9£[̹ts‹Á¾n[½CËÈÔÂb°…ù¯ƒÆÏ¼W~™ŒÎó#ïÿs.ò¤›ÌI§5C“í×|¹t­ Ê/_ŠÞMŠBd'Ö›Ïòt»©aݺôü+šÉûÁ·RñmÓ 1ŒºÝ¿IQC©šë?×ѧƒñP¸9cô!ƒ§­}þù‚Û!ƒ­l쫟BÀ͉ ßôI|èªB/zS¥»n¼¤_Þó½{þË›>¶üésçÃòÿ ?ø2ììŽâ‘…)…tF™×ˆ¨Œf¦óbõQAfŠï\Қѭţ:ºîňÚ÷€©hL(¿žTzCvËçû«çýþjìïûœ ÑŸcšâòÇÆe6c{ýÖhëÔÞO¯Ml;i?ûÈeÅ`—¿¹ÎlÐľ§ÂDk • -»::ÕÐQA¹×ïëëûæÍ›{÷îÙÛÛûúú–c+MIòóóÓ>¾¼ù[èéí3F¦4ëÚ°¶HñXžéìú½|çŒÔÎÚÊÐPŸÀ£ÊÔ8¥4M忽páë;,žY·Î-5Åoƒêäξ§>ÿoõX‡öÖÙ±ÖŽ[jÔlJW>(4EPÛÞ¾wSÌÏÏÇ0¬ˆÇš••¥Òc•å'5­oÓßÂð)†|þàг§|]·e »º¼¡˜Ì¢õV¸à;¸ïÊ'=6Ú›Õ¯g%Éx‡a6ÃbO2dDÎüx>(èF–€)Û‚ºû®ŸÛ¼|Íš9žiyOdÒÆÉóÈÊÙBê˜"ö[–É™`V8f §Yê´£GàÓÔ(Àh¡H¨PyIüÏ’­½ê <àA^ffÍã#ŸKsD–CîDdzyïè¼}:¯VS§q6øã9©©©|±Šc0¼qãÆú^jEîß¿Ÿ}A[$R5¥ægGS¹±¯£Ÿ$çýwaíÀÐ×Y: œœûêÕY|£áªiS]íwuuuîÐŒÀ@°õ•ÐÀ¡[,'&Çu_¿~¦"nY§¾EZ†11ò£ù]{;·CMñáðjŸx¹|΢Ùî=SÄ_¿†]ßÉW~cMQM{ûÞMQ H$böp,!!>þl``yÓÓÓóýû¸â'[éмީGžf:I‘'EöƒdV¸Œ<+¬3:üØ\ ÉO aÎú’Œˆ¶½/?¿¿®ö²ÝÙwš›é׊2²ì•k÷½Ž~X’‚y9b¡HùëÃ#Û_¶¿¿Š14jx:bìU·ÛûT?(SI\Ü{4»°JhiÎÓhàt9"h>»p:õKÚû6døÐ)íìììììì;ukae¤¸W’þ&,hÿñëÒC§7é);WŒ8+S,!Mk”b·•»q¢¦¨EÄY¹:úº¥SÓÞ´Þå™333ÍÌÌ 4Ÿõ·ðG¸@,: h¸òîÕò½8×\¾Ì7ìò ¢`à®ãéÈn^Ñfåkœ¨)jM²*¨moß»)BæcÅp™$ŸÔ,(ŽÁp(‡Ãq¬ÌÃ÷t:ì÷ûûÊ›Ô/¢K/ É/ƒœ·îoÅ£ÑPÁ*–æcU5…Ê÷¦´Æ‰šbÕB›ó±–ä±Vê8úŒ+Ky Û)½ƒ¨°Ó©}Ý¥*6NÔ«ånŠŠ+šQ)ÐüU⻢•¦ˆ«2÷îÝ«è*TGbbbJ/TÍ@M±BÐJSDß¼*‚™z7¦RS}'jŠ•<ÖìììJî±"DeF H¥yšÎ€@ ˆ2+@he588¸Bëƒ@ U’=ÖRgxE „J=Ö"íT΀@ ˆ2¿hwõkVE‰U=ŠºúŒQ=(Ýce ˆ€«zäú ¡ˆjˆºÄ Š™À¦QbÕ¤QMQç±J$%SUñ™L™NC“_¹8ÊsL…¼›ô:[¯¾¹¨”»ˆVÁ+òXˆj‚F«B.eÞÏö9ùM°­Wî]ÒÜ8óíÎ¥Û_²…õëM]ãݬ¤“‘ùÉ[·nõ;øž™•–e<}Û¦MkÅŽúÞÖs¤žüáàíßTXæÜš—|ó9mgg.,²•!Iàr^Îýïî3¡­½‰¢†_»öÈcE ªy¬JÔu[½¯EÓ4Ã0„žHÒÿy’ÔvÝìfé/·m¹™¢X8ëí͈éòUJçÏž&’‘Q Ç. ôJzz7òé¿Ñ¯ß`†VM›6wq鮃—a2ëј± Ÿ=RÜøùv¦k@7ÒôÒµliY+-Mšï±jı‹ò-ÿ^ܹåÐÕè˜w9aÑÐvè˜9û·Ž@ìë±8켿éw½u ˆª€¦‰&?ýRÿáþ¬åÊ€oèÙÚÅÖí:ujó ;7âÓ¥VF<øtkÇºÃæƒkÉ#Œ5úmL´|5áòñÔñ-䉕‘e‡nôÙýêÒþø…{[V´ºqië¶ ³›w¬oo&Zšà>Ú[e݆6)©KHë»9í÷Àôº{Ûéhx±rm˜”äâßÉÏ®†.q_!Þc¯ÏZ[aöûÛ·.ø/ñoêÑmãš LüºlŸðä„mYÏ‚@ ~24õXq.GŽØ)z¬:BìÔÑ8óqFER2šadRñGWGÇÃ@&cD–CæÍs(éÄ‘O/ýASE0dÀؾO<p8d\<äÔµïð®}‡wýcÂìQ+".®ábÀ€®§çèâqö¬\ò9/Ÿ¢8@É(`cÊò?_;zìešÁÎË'~ñ Î¥1T^̼S Ù“nú®=ólÚÁˆ‰-ŒÀdd³v dñ«ÃŠ=Vóph1e^¬³÷Û©Wêò9ÈcE ª'eõX¹)gO=ü–ÝÕvSèô¬½߉Žv³$ŽŽ‰qæÿóx#'‚à€I‹>u,Ÿ,»ìUjñs›Ú¬]ÞkpOk¶ð—æûÔîÖÁQ|ËÌ}$²êÉnwœ²ûô‘ŽËþ™»ÉÎ À°o_×â¡N­]Žs¸ly‡€ìØŽ ;sÓ¤µÓàþ½:èsÊóçyrÔÿ(¶ýÜCëoYûLm]S±LÇÙÁ—¡À¬ Œ»6ož¹½ƒ ¨n”Çcm4vçÅQ2ÖcÅ Þã½±‹÷†4pÀØzõQéR˜Ó²-[¸¦½×L{ ûý/˜¤€¦Ò¸aLàÀáüÚ 0òáÍ÷{m½ÄÇ1øùÞ̱À@ÀpÁè6&k/%™†•dhIŸ)ú ´ãìÚæµDÅöæßºý Ô ÖkrñW{cjvšZx`NØqSŽÅʱ€{·5]ðG4tд¶⧤ ‰õõ¾I“CÞÃ@»­ÇF&çœÞ4ý´B¾í¾À"ûc¼/{F-žáN“Æ&¦¦ÜâGYXŠxW}}v%âȇ–;¿&&ý†zÙ25¯$†óî\;Á)á‰Ce,_¾´Ô KN_u2¼úœg4Ô° Š’ŠfŒlÕhdk,ÞÐUó #ˆŸ2Œc­?v÷Õ1_=Ö\½Y=×O½Ðxþò>–ðïž¹x­•|ÌŒ8ްMIDATûÏœ©1 IS$¬\èÃ/Ì«zV^¾Óš#Ë”2xK>PI“)ÒÌ/[äqï§·5Tc2´Œd P2 cd$URiÜ䯿Â5Ñ…¢Èù”ÀŒËF¦qÃ2_¦QÍ ÔÅ3çË$ï)ŠD+Q=)ó8ÖÝvåpFS9º¶'ü~¹eóAç¥9^'Zäßšz³-¼ëuÊyô´F‡uÁ¥.tsî¥WØ™š&LáÁ{³Ö!â.¬4röñxlZšø6³ÝK¥°Š`J«šÂeœÇy™NË+éj,¸}úáÞX©É€|@«,äðjVy¬DõBÓ¹_¶’ææ Þ}V-ݤÈñcŽÊ€+² ^ÛmðЙ-¨'nçÛˆŠd4Z–¾æzÂΪ(ŸÐÖ:]œUY0©¥ÉúШ=ƒt—nˆšx6 à첬CË&~2w_ÔÌÈœ¨}!‹› ¥ÚÉWp.0T͈Ê2úµ$šèñ¼Î‚>…•œgÖ×ÿ{½'Ù[ÈËD[8voÒù AìðÕÌè,ž!›y¿Þ¾½&¢j¡ÞceŠŠ°‚·ZsðZ&Y‡þSûôDj*æ³g;§dYŽ96Iê>dòüUsØ€*ß…í½iåõÉÞ]þ—ÛnFPS~F܋Ȼw·ü­ß}ÏÁ9ì!4™üâÅ‹âÇæÊyXžÈ¶&¼­ëÕ¬–€Ç•г3ÒÓÓÒÓ3ÒÓ}vÕásÊ$M w«¤à(˜]ð:™•k€÷÷­Sú&ÌXèÒ¾!™xçÎÀ?/ØNüÔÀØ <¸ñ©þô&Jº•é¤â'@ý|¬E|€>Í‚@Trr2MMMA}bíÚµ»¢@æ‰iž€€ã•Ê& =5‰èŸàÛÚ’ôÈ¡ƒ÷칲ߜWʵÈ$q½æøœ;ÚVE§{ôèJ¬Du@žX5œè†áð¸Âã,ŽˆPk beZ°Â3ì¸wÍóˆÙ~Cº¨/qØÇi󿊸Š^4šç¨ž¨óXI’dMÓ ðÍ+ «F äýÄ¡Cÿ~\jɱ2™L¾*ϰ€VD¥åܹs]…ÊŽ«««Ò$Z© ÑÊAqÑy¬U'''øúÕB Õ Eîܹ£²a#Ñ”Ð\4š¦ÙÂò…ê,šü3€>T)òX«*B¡)†¼ÑWtí*¥ßv• ‰¦„†¢ÑEaF&“ÉóKuƒa ÃÔ‹†¬€ªŠÊÔPÍû¥^>M M.ŸV…\ÀYÛJ‚bû)© J¬U5 ¢Ú6w¥•ehŠh"šš¬Z=E£iÃ0 ÃÔtØ‘ÇZUapŠI¡:w"XÕU6l$ZqJ-??¿ø­ˆµª§nŠ>” òX«*¬ó¥Ôç*w?âiØ!qïaöú¼²(#?ß¾óʦSc¢â‡î)fL5v¡¶Dû9(U4@ “ÉäUvM.ÕÓc•'V5¢Uü/¢¹wzßK1÷wo»–‘·7n¸Ÿ#/ðñŠ—³×]vù¯%s§“Én|<{Î’9KTÊÉû|ãARéå~¼s7µ²|ÀâáêÙÞd|×Sä'ß8qîßo£Z^†$‹Þ#*•¼E`Èr'æ¼äÛ>©¸öâsÿ»w?URÞó””X«5ŸN-Ù÷Z¾JåE{‡ ¹ù©'§Ì FFJ©‚¶úñA$ßÅÍÓÓSu/Uˆ€L¿ ðíÖ“' ×®þ+Q)¸Lšä=b¥TˆÀ³uc{²ôê;rìäEËÖ¿óN^’#/¾0…ªÝ.ùæÞ¹òÌþwaËé¨Ïš”ÌŠ Y¿%\}™«Î%Jeà߯ǢX_÷P”—åùùžÃúÛµjmÓ¢U^»O?g·W*yYŸþ}œû NvíÛuèê6zBеhŽÿnš4||˜|•&SVu1ek¦¬àhé§…žk¯]M@Ž@¼Äsɾ|ä±VU´bvY:dÙߌ‰Ge C“Ôëà¥:m|í…xNzìÿ³I’¤d ÃP$IÍ0f-mmDC›B’$Ï,ŸßcM'#«æ»gºx² u±6’°f|bŸMtq’$Å_¿ä¶Ù²¦70drÂǸwQ~“\ƒ†íÚ¶ØŒ‹s ºùuðÚôè„í·h¢µ†s­Ož'â¼÷îõë˜t“þ³×QˆA§|Ê75×)üùó‹ç;†{­Ù4«/SWO’bhVÕ’X²`ášÝkòs²2²ó%Å +Ê ¡K<Ö_ˆ÷XðÛ¼5m„Ùnߺà¿xØÓäÐmãš©—÷‡{¬ôþyn;ïæ{.\¼¼c+•uýèºÅ#ÿºí{`ùÀ‚j¤$%$eÊd2`èÜ€ÉÃ/%7ßtšvãÃS“z¯ï "d2Y©¹FÝÖvÜ15àŸPïÖe¯­ Çú3£»Ð¤ñ¬±ýòiœƒa8—ÈØÍÚèÊår¹€s¹\‚ƒaÁårÇ0A¼ßXßÃÏå> šµöq£¿®÷äxMÛ‰'7fºzô{½jïüA6@å½ò9•x¯{,BP¿{÷î…g?cÒß#úŽíÝ"b÷Phç½8¶Ó¼Þ7ë 8åÖä[<ÖKa‡ÞÄÇÇÇÇǽ{‘ùîÎð‰ 4¨× ~ëFºì%°ä¥„õõˆŽºµ¬xð~‹þ¬Ût“—ïo#²kœ^ÙQ¾=þôŠ«ÂñzYÊ·p Œ¡s?D?‹‹ÿøñc¼‰ù$trlÆîm1pþ•FM^šÿ*/ÏÐy‹×ž4ß0 ÄIa+ü"ââãããâÄù÷'ν_§nݺuêÔif'xs÷ºÕHyV)"N‰N’¼ûV†7[P˜U p˜sð/(XáòÊùsË£¦ “`Ý—1¿zrõ™¥ç&(l¦-¹ïe½'·Ê³*|y´2ÑZ—«y@ž¾Ã@ñ¶')í;ە%Öj CËšÎ^·šZ7­[S˜ÐÄeƒO‡zµŒ®úöÛnµÞhRÕómIÆÃ± Â7_Š$p¡Ã8€ä¿…r•Ìy1ÙmÍô½—‚Hsžã\“M’4 @Sdaá§‹v'ùÏë­(/•KÑŒa+=õ¦mIòþH•ÊK ƨ•k•©ž}&6›¤tpŒf@üùÀò¿l,°/AçßnÖD±äËÏyƒõ؃ÖFâÑ2™C™*¬ä±þÌhÅc%p¬¦Ã°É}¿Ú;Ýæ\.V¢Çjð‹›aÚꘇ¸ÿ¡‚Çúïr©„Mëîr1àéÙý8â%”Ž•žÜäà€a%£Pšõ7Í0õôÙíúVº2I¼R™2Qn•ÊÿxôÈÅøø¸¸Ø¸÷ï߯ÎàÄî¹áܦQÖ#{ jÔ¨±€Ç4ô}pË>9óeÆujf½;´èr^Ð]•u¦É”užÞx÷Å›­”zž\cå€'»Ö’CwŒifªX ?÷1OÔ¶@ö¯«lû¤ÙqÍ~ãr¹Šòrð_8–ýFÌm«Nº’äý‘+®c‰cXúÓLŽ­rÏ1#*' ô¸àÂÆNl3xº³÷t¯ÐV—=šÊKÆKd:µE¬Áªa@ÕÊ$ñìQßòX¥#ÍüœðÕËÓ¥&eÌZÈùÐvQ°“$ðÈ)£\¼í[wþßN ì8ͧV¡/iÎã¤|)eðà§Û!Æñ²ÔcW%)Ï¢ÜòM`ø­'ï5lÔ»½s£F¥}§ÔÚ¶a¶Ê²¦l“ÿxÐê߃g;ûîûU•œýá†÷$Ÿg<çkþj@»ÅGƒie/õyÀ9‹î«•6ÞÞ=ñãr}¹ •çº n¿ î ”!àž¾"å-ÃEM„Wÿ†q•v…?JÕ5+_åéÛ7Ò!À~ævûsÆOlq5¤•^ÁÛ+fCß±yÃ<>Ü}Ê.YaZn"âeÇd«9oÖûȉ¾7j9­lS˜˜2_eòš¨9äûÁáÕÚ¹Õoîôñý{vµ®gadÑ//íLIwÓ¡â/ÇÀaEØïÃ*í•IÓn„mìé:=ÕÚ=ôøƒ^1 -\ÄùE eÒÄ%L›÷U†ÉY>ræ~IÐÁ…ì.%y§-pH{¹i×Ý$Å8¯ŽÎïà8J>~³åUdܼé¯6>KUܘ¾,$9·×²ÅËwòÞ7Ô2y¦çÚì¶ÕXÄÍ~óõÚ5 ˜“Å7TN¾ßä±VUòòò”¼BÅe ƒP4cÑÍsÙ!ó\¨Œ"9&Ý—ø@qÕÊ5põ0’gTƒÈ~ìµêþèõ$I22’¸fÿE§¾£lÌèÖîV‰ÁÉ™MYF•÷úÊ•+ŒL’œ”ûúÑñs÷LÚ¹ðs•;ƒw®ª7½¡z£P Š @É«&¢aB;cúÓÝô\;‘ªw|9µm8q3Ä6º\{{o¯…_¸|ýÖc©aƒ ëB&õi%x¯„q¼/'¶üafe,¢ÉÜô´ôôŒtR8xÑ̦ -ö; º.ê­Ï)à÷€'ºÝ^\V`ØJòZ¸lñ¾5rë„Þñ3¸´·5$îܹøçyÛ‰» IÊJ’WCÑ”ü¹+]Vj÷Ú8ëªÛïã‡çÍ[Ü¿£ˆJŠóÛq¾ÅÀ¿µ5)œçä>×ûÏÿýÝÓkôR›“k@³áVŸB¢èéM5÷o~®7¥‘VÞÁÕD4ä±VUx<S2áààAÀPÿÆÄ?Ié&\‚ ˆÛ·ïéÆ?NãxQà|á„ÀÔ¼œ›1Ÿç¶ÝËÌÉËË h—ËÖÚ²¤ÿœS’™u9˜•Ëxñ†ÕiŒgM.:f¿˜¼ x‰á\#Óšfõ×î™ïâÐTÞW“I>'K79Z²ç*LQ‹YeÃÖ\´~&ÂK©¤ƒ¡Š`°™ÎÙ4ÒÖ È)ôˆ˜t½Ëw/vî`]òó|£ú‹7ùèGþ™CÑ èèèêÔ0á!þI:÷÷ »º­íëÅê \<\q0–’¼0qóñv·o=ê½k]®ŒûKÃVs·÷t*V’¼šˆF„âŒVìÜNò «î:U÷å¤ÍéÛo;¾é? ®S§aãq~!㜚ÊKjÖ¶úÅà NJ‰ZîÚ9uŠƒ;îušáP³vOOñf¿ʽFÁµ—–þw(Yº®‹…<¦VP'šOƒø‘¨Iš7w†a{4,›3åKv®aÃ΃Œø4M_ßµévbªX__Þ` ÷Þ¶ß‘gí7ÂëľAƒîúMÓºVƒ®„CÓ Oßñ·Vk|/ÜÝךÏßs~~±Ó+T4ö´¯°Ã Qî>…&÷ÍE2qú.^Re:Ìš®ÏQž5ÎÂqùGö4t©NuïÑÓ{ÛHÓ´ æ€³G(†è·.¬_± Jò²Ø¸ÎØï:hI>ðØ,,¯aIòj"šRV•ËU¦[¸¶¦0¡%Æg]`ÅPͼÝbl3îäÉql1ž~6V\Kø½Ï/Œ;·Rh·Ä^[î +¢‰h(±VUJÊejî­–ßÏá3 €»pE1ø’àcŠ«0òôu†/d—q¾%˜–‹¿Ÿµi¸c©…¯Ïéá·£µ§øX×r#Çú“¡hVÚ¯ŒXtž>Rƒb&-ÆLúæs)]~©k¥MsXyG>{VjÉ’äÕD4‡£¨˜üÉ•výʲRÓ~Ò0€aiRØK«§Vj*h>ÖŸ • ¢¢+UÙA¢•ÅñðÕ|Rpö», öÖ‚<ÖªJIM¼Ú¶{M%M MDS|{UžJª­bPÔG*© òX«*R©Tñ¬´\ѵ«”._eÃF¢)¡‰hE•$Ú­leAé‘ÇúSYÑU¨Ô¨lØH4õ¨íÁƒ?¾&U•¢a åù @ J=¼B -ƒñIDATxœíy\ ûÿÇßsöÓF» ¡"²uÃUYŠB]ºQQ¶ìdO²%û–¥p/ ¥K¥o„«„lÅ•µD”¡ÒªsNg›ùý15NçL‹õÜß5Ï?zœùÌ{Þóþ¼ûÌçó:sf>$77((”ƒËå*;ŠŸš² øÙ¡š …’aeÇ@ñSCiA %C ÄJ†j‚J†Ò‚J†Ò‚Jæ ÄFFFÔßÏúK! RTTô5Ç}¥‡Ÿ *cr ÔoÄÊåkµ`³×´¤¶à‘g0³ÑîvÆ-wûñUâ™ÌÞ]Ú%RÑÛ#QÿøNu%µV$G'µŸ2Á¼%Î%ü'©OÕ¬š•T ›9sz Ãn T/(Ç×ÄÍ’}À4Ç'7Æ€TX0Åwµì^›­f¨›çÛnb_ß1¤Ù0$‚:óú%H……ŽN“å ãÿÚšMlòß_~ˆZÛª%5×î«ü:H—Óì¹~ZrÛ‰‰‰ÍãââB|V¸¦QÙ¯8%ïkÕ4yYÏ߈óEftjËχE<“s¨c9Ág¹N?ä9:¦”Ê“ðKñrö§Ã‡À³½ÁE5¢ª'‚•þþ÷`Î ki¯b£wà–7æ{gòÄ„Ãgæ&pÚ­4hém$n6m¥XŽ¡Â—oè3N%«YUIPbS**ší²bròMxvÐ{îùn—Wй<¿Q ’nÔcÐÉØÏÉ}Á!C†`õ€Üç[·n=~üØÌÌ 7ÎÍÍ•õÀ{·ß~òô‹Çè”=Zm?[ðàÆ¶›’TœöuDÄXÀ«,))‘=¯(%ìH†{Æ¢$íÊ-‰TÂêìx%&n‡ùã÷ á?™<7fÍš5¸M›ž–øyU{öµí â½Ï:wÇÔÖÖ˜b1‚pzôè[¾bÓ_Ô 6ˆªx8-1á0,ö]ª™?xL­ä5×9ê±»skë¾Ñ·þÑÒ` ©ðµ“Ë4ÀD€‰¨ÑÉýTˆ=*. 'â|Î[×~ª}Ú7.{úsP@ð±ômÁk-@êö»mõXë\@ÒŒQhA6›¢(FaC%wM¥]—HÕT¸`Ôw­¿Çæìµݽ?ØÎkëV/ÙÓvêõt¼¿l«̈ µb¨tµÈ ÏïYž’ Rá[LR‘’’‚ÛØvïgÆe£’r0±°¨~ÕšÁ5¶´´ •Bãr¹gO?¢sS*„šjª¸ÿÒKçÛ/޳?æõH[OO»¡qõõõ59t¶¶Ž¾¾6=]} ÀéŸ+5È#º}—CGGçS¢h‹ÃÅ=KøOüb‹"2ûr¹L`3©Ë­íÊ —½­¼kÊa(fŒB~ Ù¦ ½ œ±\6G˜N†Fèê»–ö=oÇÆ¶5vzaÕ•à¬ÊCuýt:éÇ·H[ €E;¦…&åkkh€TX‰ Ü,óHhûÙ~FÇæÏ¿–}ÿ^‡Þ¿tÑKòºµ¸…ËòEu΋s®d1‡º/0T‰àùÙBƒîpór•ð}䡪Äü§¡¡¡ožU½:ª§R-EícÓÀyú¬N¦©©)Tçßr[åÜŸ}ò¡fggG„š¶N|~Ÿ¶Y¬;¥/™Øeµ²óÐämº[zd bÆ(È› iÏ'·‰#{M£’òàìòe#Û{Í|B[m¶Ý鿪‡6ééã–¬4±{˜Œ¢”%°Õ­ò@Ïf̯5Oë÷˜îÝÝà „Q7Z”°èÀÀnÕû¢üÕ§v7Y{z;÷¤¸,""½, ï½À¨½ 4ƒ4„A§3èÀ`0è t¾‹Î 3hBTYÊ[æ¾Á9$Ŝ˾Y´h@^µÈ±þsæ¾'mì’ÖFÙèÎÝ“  €ê Ñ‚µµµ¤*P¶ GÉ*›’»«*˜G«#2>µwºwœ·ø°ï S¦ÎîI„`ÝCT¯¼å·vW!*"”`&!6Õzkò=l€Ò‚ hA‹¥¨ uˆÛjÁØ ëmlCT:ì³dv¹U`>æÓM¥A+,¿3m~” ¼zë½­kg¢œk”z }{õBcÕ ¸Üç“ÒÝtêÜŠª®Y =J°yC°ÕÕᯫÕßJ/88ØÄg:¥¿f{·Ø¡þþž;¦2³nI¥R c @g2™,&‚ЙL&AhL&“ɤÂb±Xt:Ž ’ë½GœÁ\Ú±#Ìßäâ¶Q**œ>ýÓ=œ*ñ z-X(”ªuÒ"¢’Õ‚ ÙIM*,Ä7©^PŽæb¹¯&rÆD6K36ìy!:~zœWw¼S«ÀÀ¸üÿy›…µe·=í½Ô½ö¥»Õ qÎã'löìE쥳乎X4û³®•V´&vEþuêï ž:5$¼¬h½_×s|‡ß, Ù]bt»cÝM–XWûM¯«˜0nÈߪ}úô¸6¬hhÚ÷ë£atýÌèò¬°óŒ±©‘+G›G ^pнÛöü®Ý/%%¤û¹ŸvÀ7{õÞ¢¨¿WiÖÝð3`Ñ?”4èªe– é,C¹ŒQà4Ó¿Ëã×4†ÖL?ÚÉã°½Œª#Xàcâºsx‡â›•9—§¸Íøè”¼n )ºzÐ>/foÿÆ¢´óž>¸ ÿ,á?š¹4Ø¿rÑ¥ŠZqÍC^ɻٳSÀnÅ 1õÂ7ö³ÿmjw¿ó­uêÎ=ñú8á«°¸Ü^^<¬hÛÝŒ ‘xÎÕ†ê5s–ŒÚv okèô^{ýÆ¥Õhá¶Ê@ckÏa`¯Ž¥6ÛØÜܼâAŽÔ² ÀBƒuóiŒ&¿êI[³›lÆ«éO‰ …¤° -X[~1³Vû°R•cä9S;ýFq _ «<²vÓád›Ék­'@½·ObXÙ°ÙnÕU‡öϵé¡*½I0,/ã6“[wµH…(q¢î#Çj‰¤5Eïn<µ?~0è01ÀP@ Qé(,Jß?:Ádîž~cŒïXÛK³&ž9¼í½§Õ†ÿéÔ®ûùÄá³’/íÓ«ïq(€P °Qx“p í³·=WŒb¡@ ¸¸`ìƒCW‚Œ5̽Œ‹"n üêzz9-x5ém§…&ø&¥å Ñ‚L&Sqð•ëå´ ×hÌ­œ$] p¹coŸ‹ˆª³bÿ.]*ÍÓºÁo!f#“jù|Ô!ÜrX4B 2ÄyÁ2=qÕë÷|6‹wñhܲ³ÍÀÎÏ£\süމ„—­&3ÊuÞ©-g3Vz{•Ø0]‡Aã½97ýgóR½¸\ngÃQ/¹®fsý{ÞÏ»Û-$>ÑÊÚkÕÅ›{Ç±ÑØ\.—CO?2mÙÅeÑ×ÕU¸\6½òNvN&?¦”北ÁårMÇÎám¬fÌÔgÒ@C¿½IGC¸o¨èýòIÜÿJJ¥Í;dÕ¬òŒŽß¬MVý/€ˆñÍo¯Û9·-Þô¼r‚jn^Þóœ§åÚc¹É.æ!ýðN¨c ¢èüENΪ€áצoYäBorj& 1™M­±nåÊ-ƒŒU™ÂêJ>ÐÓ7Î~ï²Û^W ߌ^1~㹂‰«WXÿÂý˜-5qÇ*ÏìʸÐiL§va³öfñ·RϼWPøúõëBœr©ùÉAļ" Sm¼!KO.ÚŸno¾½º|}Â#¿˜´Ù=µÀ S/›.Øë5)‘Â)[Ø4°ô[‘?Àï¥ßµNzc> ¯/,½öjö‰+3ºi€ºÃÄ #‘Ó¢õÁ¿ \-7C&_ìWdqz§Yýl¢AÎò„·{R»¶Üa¯¹K_9,ËŸ›Ô‘ýƒªÿ%MðmfŽH¯­Í°¾žæxÿ>!æÂI¸Mg¨Ü!D×°i€Škò_ää¿ã: ­›f¯»ë²$³.Ùm>u6*Øßfë à¿‹Y·åjAaaaA¿ö¶ïâÛÆ:t066îÖó"íJ{OÙyaD¨Ñ8Jîìëxý¢V×5 º¬Õmy}û«ÃfadJÝÔKÀÒàÖš¿ó~i˜M›/HÎ7$|×MsÿúæR‡ýZŸ6ÉñÁgV'Ê® …Æ®õ<’m|8>¤‹ê§ÿiéݽí ½U™-wÈÒ°qmÅßóðÃî_õ¿[Íð%ZpÒêOkÙµbƜцƒu³ÿT<ÏÉ1¤óç,˜Y‘ÿâM9ÚÞX-;«,ùŸTýúÙûÔ:;õ ôYQòò,ºÍ¡ºb±eétìik7ÊK­rÿâо)æá6¼·g‡…™ýï˜q†Ö ¦†IÅb @%bbÎãƒÏôlgà…Zs²„oîÙ_ÎFŽa}t–x"î+?EûÔ‚˜´úlY­¹GoBà î§ùw´T:P °¤S¶\¬ŽH>Þ…K“µž£k= /i¡Cp´Òüó™´|5ß] €³¡jø¥[íÔÊžfgg?Í~ž[}3#•W¸y¤wj×®Ý:ê«uµc¥u'C­¤#B:îh«B>œ°òŽoà•a!)*,&0µ‡ÌžPr÷¡Å³æ{nYp,ÅHƉèã :SÛX• 4ƒYoüpé·{–;ç ´&èâ…A±Å´ûé5-.uûj ç2™Cåʤ”ˆJQ Ó²ÒÁuž,Z–šèÙ‚Z„¦JChð‹¯¿ÜËÉŠL*Ü>¾Á÷¶œb¦›6î¡…@çMþÑtúàÏ ˜”Â7§þºPXXPðªàåËÜÂâJzþÁËŽ–f¦v£ÍÌ:ÓÐ0¸s-òã<çg·íd¨UµôÿhZ?RŸ¨øCÇ|Ä.`›½A§~$:±sƒÕ¹„Uw˜j}ÃÜ;uî«n+à•PÂ5¬«9Õ†Ž UO« wS—¸Š‘Ф6¿é<|oèlC‚”?(W µ<£œÆh¥Z/EÜÎGOïnõèÀˆ¹>'z\ôêöi"î¡”kÀý\‡\C®TXð]jEÆçkA„výaž™©Ùˆ_ÍÌ:k‰vÿ6ËpÏV?R[þ¿”üù WVäÙG¬ÔHúžù©‹f,}Ìr¼´Ó«éyÿúœ:ŽÊk¾Ì݉öÁr…7þð=9_Yë mXô¥u÷ºhôÖ.Zœq×ÀÃDî1ÌúÓ ?鬦.†BSsÕæ^M΀)åv]¾[¦Úf2±ÉÒ°6Sa€õü½^·Nóíž|¢—zÝ÷B}½ìƒðs ËD4æÓÁŸ¯Agï¶OÿrQõAy°H<‡´õ0[»òKŠÅž}OXÉÈ>TTqóì‘UëÛOŽÚ¸@•(Þ-K0 «%¤T,•õðvÝ¥¢9ÉÝp@*®9¾zöÎKÈ_É‹éR‰X ¦j¬´§âauMÊwIÿ3Ûî;̰þÔȞŮ˜|øÝ¹óøíÀ²'U¬Ö¦ŠzñGjAðYôk|à¶Ð޲_žÞ^Yw¢„7î  .ép-ˆ¶^phܧù“6œY£NGÀTy'§JêhØr‡Pù´šÝÊTQ2~_¥Ùl6Ö8„S{Zü ûUdJS&Ó´7£0[½Tô¹É'#/¤¤Þµ6™¹5fÖoÝ«ƒºQ§Úÿ ;ÞÖX[ ñ*ÊËË+*Ä\·À…]1)›¯ tÕWÇiËÆ=Vz29¨«FÝ{O4ÞzôsiÝ¢&cÖ¦»ï˜5êߊ‘ý­Z‹ŠnÞ¼²ïЫYáÜ:‰™q­Ød~w9½(«†¡YCLÓ-ûŒŒÜ¿¡åt¹Ëïò¸}3¨ñ½?†ß¶­‰ëÿÚ.¢üºN4:HdÅ¥TX°twYp¢iÀ²Õ'ͱd‹ÜÕÿõM€AþD9oZ9~U‘Ý!…º“8” BËÖÅý&BG¶îŸ§W¢ûÿûô¥ŠÎࣛŸ\~+ØäjÛ´åõ˜eÃBÂmM’¹VE.k ÅÎO¹éâhÙþ±þIjo›ûfS¢Ýv°O“ëw|ruÿr-øxp_×fö€ -XÏb:Ù²ËÐâ÷e3&;+1iºý}øýîÝ–Où¦¡¶¤úM=“CÚþ¾UpÿId øÉŸ0ÇA^A•±jAYYÍ­Íþ3 W}Ò¼‰D¢Æ’ös"×`>O 2 ¬q¾_ÐÿZ°†Oì’¿A£‘féçÌŽlÝ?O ~ÖJt8iiiÍQ4„Zú†BÉPó R(j~A %C½GL¡d¨&H¡d(-H¡d(-H¡dþzÇ‚ú*iz,IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/lgndmark.png0000644000175000017500000006015413070106167016711 00000000000000‰PNG  IHDRI/GE¤¸sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìe@[ÇŸÙ^º%TÀî@E1Q,/öU°Û+Šb^±;±®q lñEQÄnTPº¶gæý°¸.µ,ÊÆ…óû;§æÌ™yfÎΙó`±±±€@ ê46›­ê: ˆÚ‡¢ê …€l¨›Ð¸\®ªë€@ j¤·ˆº MüïÕ«Wª­G]¥cÇŽ’ߨ‘ÊA|ÕÑÊm#j‘ŠÆŒ¡h$WÝO½„·"(ת¨‘J@|™ýÔÛHx+‚r­Š¡Ä—C ê&ȶˆº‰bõö•«×k½LufÄðaåBê³Þ®og_~45XµXš““S¹eèííÛvïÞ½Ö‹U2QQQÍš5«6YLLLÅ6¬Ïz»nœýZ'**êË—/...@VA²KN|ÿþýª®:Zeyå177— 55U95AÔ*µjñù3ÊH†l[.é"j—JMZ‹ùm[Æ·G¥ª]WÅÅ‹¥7ålœŠÉê³ÞFÈ€Ãန•‚Ü+A’²ª«oË…tãÍš5kß¾}ÚÚÚ2’U‚!†ÍfW|\ËÙ'‡²7…ª®:õÃhÚZÌÊc¨ô*3UU»%à8îååîåå…ã¸NåH‡Ee^Ã'<ˆÈâÕÊÔ/Á××WFR”?öÏ _Ë4Ë÷óA§>ÕæR¦J½M5´¼ßþiÞ£ÝzÞí¢Ã’à.¹,Wgäšaµ®µ,fÜdÿöõ«Ï™|s“2Q¦Nûþ^øõâÖÙþϘ–—¬Z¼J¼GÉŽªÝ$ÇP1¼ÒMyäF'ç¼X–ÖcÍ4«oN|\8ºË5çΫz†t À"GG§±‡žºé׎ċ|0ÍÍo_;r¹KK«++}_[_O/îôArÉÖÕ3}7²`ÉNpAê¬a>®…q¹çŸÜ¸ü`ÈÃÌB¢Q󶃼VÏv–·`Øœ+a;iŠíÄ}9´tmDšd“åÀĉ¥Ó˜÷_¹i²-d¿IÈŒœ‘ÖwçÒÉkŽÅLîùo{‹:`F»v ,LÖp¿ýbsg…ÖYqˆ¯„rz[Ü'—'»t×ýWôöÀUÝîvžçuàÍõ¥ÀÓ@9†ÿ†­ÖÑ`üÆAUNqê÷±ûqšÏiݯ¬m÷÷™ÙýŽßÈðèpb“O³Üc¸"Q¿YB¹êÉ©“k¬·I¡çСåéWcnÍíùÈ&È—Íf`˜ëÙ[ë鈓ğw›Íb³Ùì“—/’¢Bë›útj–ñðèw=#\@Ÿ^ßN‰g™±t™!V{¥<àl¦ˇ†èì:ÚÊùþiDÀ‚¹ãJN†ôb[¹îqÚá¹-:,À^žcüe²Ÿ‡>çOß9µié¡ãÅšÚVîîn’1ûç}•³i²-/—Î…Ö×âÇžÜúNÓ}⻩ǵGÛmtʼn¿žê?ö­Bë«X” ·eaT­—wv³Ÿ:ãܨ-ÝžÛýjJð³®:¥†óf÷Úc±îk{êÔ†©“ÂJÅ+Fao¢¿%T’÷é`¶¨ÿ”n&¾òªŠZžú›%ÔÂÉFßwuSïk^=Û¹ês·—‡zˆƒ¯Mv{N/}Š ¾Ó†àü„ˆÇñ$É!IAxx8/ͨcÇÒQ÷‚ó4VëvJÏ1 Ã@ĉžy6)ø}[qàþËßZ,¸9´ƒ-8µeƒTÃÒ‰%—®Œk?#vés[–bÇDµ¬» Xú¤q>»¹{<¸O«{]ó¨øÆ8ywû®>ÏoZúÑ1îlqð÷þQ ªø7?/Ž6B¡•U6AAAû÷ï¯*vúôéýõW ¬æ\²M^Ü4¬ß²?xz… Gí^ÕÿçŽâÄûçÏGµó]_;¶]tVÚ4,ák¡$„$¸ïK„MÛèÒŸ›WR¶ý‹%”%,,Lv=+Îû“íFnWv=é1)xïƒc›×†¯\Ù†9¿Öºô¹ýíâ號„%Μ¹"â~! î™3g´Ìg{²ƒ7¼Ë€Ô">7äìI Æí:¢IÅ ýñ¡ñ”.Ú¥ï­Ù´ÐÐÿ g4§câý:I¦Ú1tûŒÕ/Yÿ<먣Ôú]ûÍgnÙHmЩS§ÒmR¤àç&ÀÍ#›±Ò§ºŽGxð£V#÷x}qïÿ6mr€QçnoiRzjbO;Ox_‹µS=‹/ÎÈÈ ©åêêºhÑ¢šXýø¶…K`û€6÷²ˆ3ËûI§1pR¼´¹BÇl1š¤ò˼þIáãíjȈªÝ`Ò¤I²ë¿:¾ý4ôIï}mp}g'>™óD@’ÏvlX©]jW…± „Ëå»ßŽý>íÁÞ¸m;›‚Ez>&fŸÚÞTïö¨~I§šjü3¼w|A —MÀËÑ gIö8wïÂPíûEΘî5Ö¥§µÌKÃA]n{Íí¬Ù±wÏŸÖrQ@'zmŽØtàðàÁñ&ÎûjfÝO² ZZZ ¤Ò?¿ÙÍy†áŽã®Ïý *hµ¯néûÅüÏß¡y-ÖNÙTª·W¯^ŸŸ.²oß¾«W¯‰ÊÈÌßÕÛb^ïöxG6b¿hþ©gf×ÂaÕœŸfÌ2¯yŒéN çUõû%hØ”©FµóÒÄ­WS½Í;Զ›7AeQ¸c'EômÝSgÅ¡øÓÛ›qD0qÜØyN rîß(ËäGFbÛY ž±óö1&‹Þ´|¾&-;£˜»jÉ;55›;ž%ç“Á5œd&Ù£E×ÙuÝ·kÏaß©;[Ìð^µdüÏÉÞfÝ8{cÙì!ÐÌ=$¥ü ‡ÚáäОAÉE¥¤H~=$±šfÓ‡ÎNÖY«æ³*‹ÂqêÜ®îÜÀwל5*€›Ë°%§/ ädY¾{õ¢R½M£Ñ¶mÛ6}úôgÏž‰“ÙÛÛoÛ¶É,?*ü»z ¾œrŒœzæåB«‡{,švªß¡ J½[ŠxñE"²‘¤•ˆC0Œe¯ÍLý/âeVõû%õRÆÑ±F¾zч©c°¦sÓÆ[ר}ýZ€?9V ì'PîÆ™5Ïò>Û÷¯QÞ@Æã•ßûúQ.-[fvgØ"û kix¹wë„ÝÇXhth!é„ÄóDe; š ;yo:ºpEâÙ=V,ý6ëú©…íÅQ 5p^¼¢wâG’×â"ÎgãîoßVòBLÃxL\ì–®¡¯­±ÍÍÍ?}ÎÇí½•¦^€[_,ZeÌ:ãì7v…ì1Ëÿl6{Ïž=ãÇÿòåKÓ¦M÷ìÙÃbý☟¬a\2}äJ“A[ü{4вtÿ×»k¨ŸÛ•äâ_ÛÓ/BŠöEç6™8•)+ªvKÂ×××ⲇgåäÃÒac¯|aÉ+¯Å·tlaii)Š:{9¶£°±ý“Ö}ïsïäb €.œþ¯÷²öàºñJЪ4-Ýèyã¼1©èؤQƒ>Á¥³t¶ÍT~&¿âiZV|ö™Öìᮟ½0~ŸÊ¨æ{˜ßAĉ¶)K³ÖÎ@òm*ÍÀÛÙŽÃÎÇ€°è¹ÇÌ«Cº¶¶¶¶Fû7¦£j`ÛF.øò²3l1ÚÚÚÁÁÁŽŽŽÁÁÁç>Ê,½}zÎȧ‚f·‡Š£šM=âq¡»÷ðyì6 Q2¯ž¿ã£çãÎzŠKðlÛ¡?.Ù虲ïÚ ­&çù8}½$¾dDMZõwSÑcÿu7~¹i$ãçç÷õëר¨¨îÝ»ûùùýþøö­—Ù æ1E$Ia÷¶*þë±jøPËa뇎[ þ›¾uE›)wu© ïóªï=ÖÐà ¨í4þús¡$ ç†õLÚzл¡P˜¥{±Ó¢?|—ÉXúÎÿÝÕcº'Z³Jß3ë5Õ&ËárÅæ‘ù6¡k«¸W'4V111e|A—yŸ J¿¨«ëè?Ÿ14 n>Ïn LÃaMJf¼aìš4.Ó~yà¥[Í:úÓOlí4üº±6õ?lÚ\.·ÒÉäâß:::{÷î¡PX1o¹iç5ÖÛÙ¯veÎ:q¬™žÖ0öÚ‹;ߌ^»âا£ó:30n~~>É`ÕîiA~zjZ™N57ëáBoMïY#¶¹Íæ$¾º½/ðÀÃj£ØÚº:BÖï” ô1‹ç“kiiÉHViHÅñílÞz ý§Fg±ç·kõžC~ôÒÿsŸ®4ó8ÐûD§‰›ôήüìíšàí,6#)gã´Io‹…™ÉáûÎýÄ @³©;7 ³€.^MÖ|Ë^ÑpAÊá½;îx¶ÆïÏÎí}ñhÓÊ7M†ïÑøQŸgáéMw›þÈfЇéÁg‡è׿][l´bþ·{ž×Ã×q·o/èÝ®³Ëß[7{:·ýiߤàT&g‡ ;[Ò¡í“lÎÇ áz3Ž[3©ÐÄãDÿ]6—jÝÜ4‘öß4pƒAVì¼åFÂk¬·:΋ˆ˜W>±SØýÒÁó~;"úÕôˆª'þŸUó+Æ…x‡b4)Èu`ñÜß,¡*´µµO:%OÊjñ“[ضjÀz #.ܸà3xkžÇýÕVùE™8`€Ñ×]¹½tØÀ%{oëÑ 9È]Š’„/ø®ú®O•ºxÅtSM(ʆ4Šå°™%~BÏt •a±ÿÎÝ Ÿ•‡Ö/ZœEÓ20fÙ–€!â¢p~ÂÁ4þîâMBP”››Ë'äš UHQjü§çn=üzÜ~ÂIõÜÿ¨ù‰€yÓúø±›»»îÖÕ~Œ›3ÆKlÓ´“›¡Ø¶aôÿžžë°.gÒëÍó ÒqÀcl 2§W×Ùœö1«åz*†]£µd$«Ò¶-,,ddKII‘½{E Ãöä4Ëß/¡v¡±ÿ{÷štˆÃP/ç£8q+ú¾lÑn2Péf›¯ß!h ÊåM¼rtLJÜÒö½àÜá?¢Fî ÇdéY×Éñõ¤SnÖ@e˜ûl;ä *áÒ4ËÜé¿_¬á¸¹n騛‚îÚçÆ´žEíÙ«·ûÊ !ÚJ·“Ö¼¿$ìßS×ÿw÷Ø“‰#ض·^<ÎÛËmnTŸ±œ/‹;9Ÿ³ì8¨ ‹½ÏúÒ°¡êWä|nËcÛ˜Øÿö§OŸZ´hQ›u€ÄÄÄ:°ªNTT”••UµÉË%+ת2YÈåRXl9õ#—Ë•Sñr ´çä£3æ?¦sUç}ssœåw÷j×ÚžƒTîì“xPµkÔƒpJ(lÍÿh¯»*Äk*õêÕKZiƒÜ+F’òÅ‹åæMI.3ôý¶\ˆ¿ý’¸}ùûí5¾ü‰Ùƒ.íŠÍÀýúV¹ÞÛûÐU.‡Î÷i ð±bŒZãW¾ MEÔDÖÛ¿¹î Z/í·øå)¥*Ç´ÏâÉ“ej¨Š/8J RîÅònÛQQå¿—ü/RnüøMª’Öµ¨·»^š<2µ.ÖKCȉ@ ¨¨´AnÛ–N‰ÖKS õ|½´ºÑkS=ª­¢ÞF(y6ÔO”Ó2ê·"¨ Ôb}ò: ÒÛåƒô¶2¨çz¡Ôu}rQ ÛF ê&Èÿvm‚üo#Ôä[^ÿmÄ 4¾]ÿí_àì¹óª®‚Rã1ZÕU(²m¹@¦û Ô·^›*S#Ðø¶\ ÿÛõ9{mêsrÑøv @þ·ë3röÚÔçäªëø6)ÈËçT#äV½ìÁÉñé+)ªdMßj£¤Qÿm„:ÕU×±ª´íCžCû:Ï-ÂËXÌÿ–¹÷î?)U k:9:êPà’nvÍ:¯-A N¬œÑÊÂHÇ@×мÉ‹‚Ò?‹Kºsȵ[K}=S{ç©÷â‹Ê— ©O·o©¯«oÑÜÞÓç$!_TEá2£nÄ”Y­–Ÿ÷¿}§*Yìç'9ñ b8Bq°¥‰DÓ¦M‰D첨ºŽ•P¥Þv_·p¯ƒ×˜M•:^Ìÿ<õÔ“I‡"ôqA­ß§ò¿þÕfà­>ýºYiÄ'–‰º2ÇaÞÚáS7ôn™üê¡ß¤I}’bÎO€‚¸ƒG.ê·hãÍ`wÍôLJ·ùŒtpùp·!³Ìò`…ßNv2³ã¢C/o )ùæéæÙôÂ7¹ÈŽ’Fqþ·€Ä ¦N™×ãXÄüv†’À¸‹;ÏÅùN®žŸ½aëíq£íqAʸ‰•;v¹û˜‡qéÕÆÍKtëf&ïÅW’ôè5»sO£ÿ’ÿzRÄÇhå½ê(¢q¯-22ÒËËëÌ™3Tj™ËL}žÞÕèm6{À…À¡}¼½îLy=ÜL“Ä‹ü&o³±}Ýà&Ѝží†¬ä­4 žÎtº¬m›;OÝ9Ûctk}Ðë>xïÁÍÜÖL€ð%[­—Y3 Å¨-]lwûû[á¾æúÒ%œšè Þ\3ÀØýú•°&'>÷Ïì¢ÍU¶5ã ç}Rö³¿²zm\Ü&wÛåä%c»]îÝz¹PψFðuvQQ*{Ä…»«JûPøL £±Ùl`YVZ #s=6¸ eæè•“ÿ÷èôD—‹ì¹7O—¤¹ï?ÿšŽ×–¥í$!Ç>¦¹øßuÂ¥#|n?ÜoBS?½VÔ‡'g.Þý]Ó²µóˆy‡7M”]éKóºzžŒ9›æþßqJ(×kÛ°aƒt¬ú<½«ß¶ùcß’;úü±vHÄÆ—Acˆ:En/õ„^ûn\1fUUé2bf©Í¤‡iLRq®£í¥´9g@9ÝMâÅëÞe·=â% iÐ-¨!ý¿I·G7¨*êcÊ:ûS¤pÁøþ1BËÓ¯F^šÛó¾MÐp=}s}£R½ñçݦE‹‹V®Z‹ó“ÅßW®\I×lë¿tÔÈþ}³Ëz.ßtãnóf0>Åm_}¦™}Mà:á¢`ù™+iôä-K/•V/^Ý.¸%ÛÄ|O¿ÍãÖ¿ °WF ürö¹$$^óžzɈ.ú ú±°IíöÚÔjÆ·g?Òn蘭&ïö~ò¿ýÊ”^Ú QŽómi¾<‰ŒÏJwÿÒæSœw¶—†b4ó+a‚T¿‘^Zæƒ7ÛéIgäEæ ‰V~vw1ª–£.óeDPlUQPÖ¶å£ï»º©÷€5¯ží\õ¹ÛËC¥÷¬k“Ýžÿp£#(øNû ñà×6¬N¡4·Ó Ø|ßé¨oqqg_G7d”&þ³sk.^úÆ@ĉžy6)ø}[°v÷­¿7¥ø/Km(JٛΰoÀv:“3ÎDŠ’veá”eÝL óÒ•qígÄ.}nËRëérö¹Äp³îôŸtx僸Ý,kZ‚úFÕêÜuåöüaƒ{¯Œ—ö8ü®áu®às¹\&)áëF[ÓD\®4‡ôÔ]rýàÇYËÛ@ô«†í—NOûxüäg·Ù- zo¨–ùTkr¹B`t­W¼öQÒþ¦ûvÿÆâ]ý×9(ë>.2ºcû\¤¨`NŸ‰&Óÿߊ¹ìÇC»F%ȃú<Æåß¶î;àxïIT{÷ò»ùÀ  îÉb‘­/GÇÞþéC3l×ܱþF.ßwe©;³Â:õ4v øÆ-ÓqMâãÚvÚ4¶AUQå Qÿm1Ÿ¼ìåÜSÛ(øÂÔÏ>oöêðÎÍ:¥¯v ¾&Sš²Øl6 ›ÍÄ0›ÅÄ0*›Íïéùýíëï?Šr?ÙVO‹Í¦À׃ŸÍú-–ìqÑ@‹I×/²×v€o$·ÛÓÁ1ÖfÓŽöâŽpævªÝ¢?$‰Gö0™³?žíÔD™‘—.EuôßÔ__2ºcPÁ2/Îïªá·a…¿P‚œ½6õy¼ÿ'ç“ëÚtÛq}µQãùwòÿ Ç€[+]&çz3¸yå«ç3´ÚêÓ)ï_å@“Ò$Qr+kÓÓ˜¡eUU”r‡›}©m7o‚Ê¢pGŽ¾Û·uO¥»¢Oo=dÈÀÄqcç8áÔ¿·e–N¥Ù“o\4·mZ.ðåÕëv®ð>k0ág§å‚Áœ ûß•¬oA¾=Ÿ-¼ÛÁȲÙÔ’åsß–¬lI¼¹”Ã=4â碴†ö†%{£ú€õð )ÃAݿϕpõ/Ïsøíø@6#‰_)AÎ^›º¡îïB AƱ±ÜŸNsI:æ3foæÍ·×«2lŒ±½‡é»G$É¡>éBÊj+YQUP»þ·ÙF#_½xñéÓG#ö¤­k<Æ®ßùÉѰˆÇljšPîÆ™†m9wñR¥sÞ­:ý---íóýO½JKKKMŽ]ê³ZÏi4Ô$Ö¶^Ômõl»¦ù̦lËpx/ZÐÓŒ¬—;™úƒKyíÔh¨óâó芌î˜t'3´ÿŸG–„„v×-?Ä%g ZêóÄ–¦úùä8Ÿ"ËýùWšómD—öíñ ÉØµv²C×Eߟþ=e…~Ë™½u™°`ò!Ë«RïÝ ‘Ê¢iÙk`gÃU#‡¼ ¸~n 9Ðv²ór»m³忽3çϧ‹Õ£Œ(içûåâ!ÛkN’œœ'žE=¿1,75õûÅm—´c¹âš£nœÍãrà\.Ÿ$E©Y $‰ Òn¬çl½Äî?9{vB˜µsoˆx/ÆtJFr—ûó®·¸Á¦]/Ÿ ¢›ü¹Dœff_³;Ÿ½a~l8t—tÝ R¸º‰úÈŠÈèŽI'ûäŸ&b]^4ôriþznc7|úøBíöÚÔ§¹äÕÛ8MÛÆÆÆD[C:‚œoÛ¤‘MÉ&•aqñý£• —-;0›#bêÛñ¿íËŲ:Ϭõù‘UÏË”`9èèÀΆÅ999ÌÒñ1-ËQ‘áž‹ö8îœÃ0oî4eûñ QÕF•©•‚üoD¼Í³ôi@Ã0-3—Fœe±:AÆf Ø´ÿøÔV}û×v÷?S#- ÖÛ³Æø7ë¶’ñõa¸çÈþ4 çfdpçõdН]ñ^Úé2ŸÄñ¥÷Øk™ýÒ)G’¹ÓÛ•¦Yäœ7äÀ Zî¨-­¥Sò¿± Úªç㨌±½‡éüGÀýoq€¸ÏuªlŸËÎkWˆÓÏ©Š$ÁquëῺ¯¾¾œ%Hãëë{âÄ ñïI“&ý‡Ç·ÅPé¦åäÆÚú‡”[®ž®ÓbýÑ+ë8…%:eœ¿…=UU9AžJo¶÷¼îI¸Fù #ªRjÑÿ6ÂóYÜõFì§Ø¼¶­^ärbv×ýs%ƒ Ön{{îä¾JóìÊ?hfäƒsÑpãÉk¸Õw…Óé[{lõ®ºÿùØ÷þÆN„0³‘³¸ìvS§|ËÚJöfÔq9¥¤Ç'mG7ÃÒ#Õiü—ðpiwÊ¢LGôáT»Å­Ä¿ÓùÏ ú0=øì}õš¬&£Ï%éµé6ë>PêMRTmz÷w2Ö]‚4röÚÔ_ñ¿­çÛPΰÖ+§a×."~r ÛvC XâûЈ 7.ø ÞšçqµU~Q&`ôuWn/6pÉãÞÛz4hhÑ€Ÿ-]Â×ï6dåJÍK¸°{wI”H¢,‡Í, ðËz6ø1TNeZ/°Òþ·óIŒªµ¬¥AÁ2i?¸8?á`÷€Ò €åææò‰ÚtCW+ÈèsI÷ÚÊ€Qš6mªócȰv{mêF•z[ì—»RÔüv¥öý¶éñëÿò¹\I y<.ëè4ér÷9qk†Œ¿fÞf—ËÐ[sþIÓçåsù$)ÿ$•Åf³YìŽ^ó;þs/¬¾`᥯G‡ÿìdN {5­l5\.D¹” ‰;»ˆíðwW.Ôï¾ñöí4‚2©ªÏU®×&£j¿}ûVžªBF¯M}Ú}¿]í{íã·Kƒ†A“cÚl|ýn£T¶FR% |ÕŸÍfÀ°ÐgƒYŒ²CúãÆO—ìeü¡-Gû.Íu»dßX^§‹ qoÍÛé.ÞÅ‚ßïsÕJ¯M},è?9¾­*í›ÎÖ¨>Q)8Ôv; IDATTC²T¶µB´†ÆÏ+ŒeØïâÎסߋå—Q¹ï =x®»:MAS9êó@®Èÿ¶\¨ájXrbÚgñ䚤7h3m¾‚ªòŸEÎ^›ºüo×&h½´:‰œ¦«>'émePÏ×K«W½6õ9¹Ho# ò¿­ZÔ}>9ø5ÐúäŠém„òAz[Ôs½P êº>9¨ m#u¤· ÒÛåƒô¶2@z¡|Ðø6B±\»vM {qq©rAòz²m„Y!ÛóZ•HrÿþýÚ¬nÝémÅRÏõ6—Ë!HÙ¤ä÷¯•Y®„úÖ¤ò€ô¶2¨çz›ÅbI?¨Ë=º­Ìr%Ô·&•¤· G†aÿæs[ú¢Rm#‹ÄŒ7n\+ÆÄÄüέ¡þ€ô¶bAz~O]WD(JXßšTÞVõ\o³ÙlIo¼ÒàòåË!!!¯_¿NNN€† vìØÑÕÕÕÕÕ•Á¨di':Žô¶lÞF¨˜ .,[¶¬œ3­˜˜˜˜˜˜3gÎØÚÚnܸqÔ¨JFÈšOŽP8Ž/Y²dôèÑ2¼äÅÆÆº»»/Y²ÇñªÒ d€ô¶bAz*ÓÛ>>>[¶l‘§„   Ã%!HoW ÒÛÊ@UzûØÜù¾ëÿ°¨Ü÷'ýƒ¹¼ ''› oVþáàà0õTùŽ1ÎÿÞ¿g‡4!TvÉ‚áó3E¿8KT@àããSÓ\ÞÞÞB¡ð÷÷^¯@ïÒT‰ˆ;pÈôªbt›{fýÈ_(6zÿr£/1X¼I×´ÝrzW Òs0>Åm_}&ð²Rr©Zá׎Ißæ.-I(1æf>l“!{úm·þEX€ý/ÔGšøø{öŽ‹‹»|ùòèÑ£sïõ ¤·‹l½Mâz•>ÄHQaÀ¼Å¬¾ú¿pRpÞ·û¾,?x¸µ H¢hÒ„™\^ £€ˆûiÆÙ¤ÏíJ=Šá¤¶ÅB½ôÙÞ§ýe«')dÓ†×ÝýæÝûë9ŸËåTh5Ï7®ûôóÙ°*ú2©’ŠzûÊ•+5="IF±m#½]-Ho+ƒêô6ÛÙÙ¹b®ðUÎEæ£øõaS°Š±²9:k {ÔYÎ}Å›E F J]ð&GnOéi¬#ÞdP1œÏ^çf=ke„ß%Yö„é=ê©× €Éf³™T`³ŽÕŸ»õCÑQG3Èy³{í±X÷5=ezª¨·_¾|YÓ#óüy©›u¤·«o«$.ûò>ò<žyøÙ:±a“ïî½GՖкw?S:åÉÁ¿´ÑWwâNÃaA’Í÷»¢Mû.”Î(*µñžžÕÙÿCɨ֚4ˆð?nÖg½¥¼î`ŽQ®··wµ…¬Ò3÷Ș Øà‡×¬˜TIÞÿ¤ø=i)Iö>k0Á@:#)Â5LÆ7Y³ìxìõÙÍqþ÷¥i #Hòs¹]Ú–ìèÖÃ/¤ ÿƒF(¤·‹<ãÛ†½—9vé3"ÿì¾ËOmê}Ö»¯‰TJ}ù<ï`îyåöئ:˜$ï§CS²zlp`’¯\Ó˜"Ùà$Ið¹\®×ò.Îþ%SŽ'†,Œš`H-I€DoÅ„%â~­ÑuRQo›™™É_‚sssñ¤·«éme ßøvÿ/Üך4ÀÙñ\ûG÷MÿõwÑíÿ,¿8)tÎÞÔ gC¥=i7dRß`’j0¨Fa°Ùl—-ú‹»g‹Šv¾ï¶:ˆÍfã,:HémÀ „4¦e®“Šz»sçÎ_¾|ù…Cëܹ³øÒÛÕ‚Æ·ÕŒ¦ë{ò®»µVê»7ÂÚøbŠ—ýøóGí¿ZN·Òa|*¨˜žBo°Ù¹áñådhnlYi™ÑLý–•FÉψ#~-£dî BNm« U{ãÕ£š/vÚX·çj‰¹sÄ­ï¤ÆKÎ{÷1+ÕnJã”Ï*ÍÕuÕìÔ{ÛÌo6¥W~U<¼“j7­•øwú#WW×›y¼šÖÍÕÕÕÆÆ¦¦¹lmmù¦PoAz[±Ôl>9³ý©£ ïѬ~ç\„.÷Xt³ÐgÇõɽ­+–cääY°:¡p¬ ˜aC+ º8EwÔzïtcŽ¥Cß"­&MšüR½ó“¤ñ·õ4ÇrŠòrrrŠ8.KV7£¢Þf05ýºkË–-t:]üéíjAz[Ôt>¹U¯E“oNóf…®qj®M¯¢>®ë:­ñ»›}Êͺ®=wC*öÏE?_ȳ­½>ô’lÆ^\®é¸y ©®x³Éà=W_™Jç“9ÒÛÛ;((HFFi–.]:|øÏ—òHoW ß®›h7Ü\f‚Ñ‚ö÷Ÿ2ô’}c+9ËLˆ{8gSÎŽÈzI/“&¾qãF Ã6oÞ\m K—.]¿~½tˆ¸4qÉ5­O½Ùv½ƒeØïâÎסߋSRRäÌ’ûþÐЃçº×pš TX“T•J tppX²dIlll¥ymmm·nÝZѵ)µ²bMëS¯@z[±¨ç÷Ûº]g{Ô¤2lÛ Ó~©ò<O†ººº2äÊ•+W®\yùòeRRXZZvêÔiĈ#FŒ¨tM%@h}r™ ½­ êùzi £Òç¶t‚Ñ£G×è/*•Šô¶lÐø6BáTÕ'W·2ë$Ho#ˆ´~þü™,Ëï—Y»µ­c ½­XÔSo+ @ y­ Rf‰aØïÛ¶x³¾5©< ½­ ê¹Þ¦ÑhdÕüZ™åJ¨oM*h|¡pdöïØ6“dÛ®ê*Ô_ÞV,õYo;99)a/õªIåémePÏõ6B% ñm¢.ƒl¨› ½­Xê³ÞF¨ ¤·•ÒÛåƒô6Q—A¶@ÔMÞV,õYo_¹z]ÕUP*#†SuJAz[Ôg½Ý¡}ÛîÝ»«º¿KTTT³fͪM£>'Í'G äBâÒ¤*RSS•S“l¨õ4ÝjAz[±Ôg½]gó¬©ÏÉEz[¨Jo‹Š³ó>Þšâ±Áµ±röX‡‘>kEEE³fÍÚ·oŸ¶¶¶Œdªo«)Þ|çã’Í[·¦ péÝ}/#þ_¯Á‡ &­y)ƒ# ä¤ß}œÊ‘N&қŠ"²jìHõ|‘Ÿr“"þ/DIƒã¸——Wxx¸——ŽË?S$k×jEÒC®ÝZêëè˜Ú;O½_¹÷ßÔ‡'‡Û·Ô×Õ·hnïés’/ª"þþþ‘‘‘éïï_{Ç¡ÞV,rêmIâ<.—Ë”„ðy\.MTiâèWL>!úçn¦Ï·$?33S:AIJØÍ£M?<=‚Q1œWºËÇc“]vtc\.÷ÑÊ‘_ÓÞÒÍ’ý‡yºyö½ðM.²£¤‘œµ€€€€€€Šá•nª¤·•l½Mˆ²ïÝ©"ïõ³ÈtÍÒp€÷OsY4¶QÇí ¤³<:¾dÒº‡Þ´ÿñ@f[Žß´i¼tšÃƒÛ}òðÑÐÒ„ˆ8Ñ Î§¿ïÂfÓ øú÷ nºukfv]Û7L5ì-Žê±|u|ûù)ËŸÛ²Ô} %|ÉFëegÖÌh1jKÛCÆÝþþV¸¯¹¾t²Sý¡á›kÆ»_¿ÖdàÄçþ™]´2¢¤KÓ4ÔÇ‚Ðø¶êÁ¹ß·oß)Eá‰ýÛ™ ¹ýê`¹û!ÈvnǦ…)”U®üI“&É®@\\¨S!½­ äߦa•ÅÇrŠ^Ð5ÛiþHIÐŒùÆÃï¼Xh§M&‚Q˜•–ÃÏ}ê5ï”FLïáÚT:*‘k51ÎŶuX¶ÅÁ{uâÙ=V¬ýÔÂöâ(ý&Z8?ñ¿r=„íš;ÖÿÂÈåû®,ugbåciìð[f¼*‰kÛiÓØUE•+¤Úyiâ¶RŸCz[¿ë0ß\Kü;+2DÏnš$ŠB7ݼջŠ|?áå<×w¼öø]QîÅý\œK8—7Œk'‰5cP³3+Â¥iYMðÙgËÿâ±k6,|,ägñ©ŒjfP« ·VºL8Î;õ4fpsÝJ0´ÚêÓ)ï_å@“Ò$Qr+kÓÓ˜¡eUU”’j¯`Ðø¶ZФ»c xÑÚ•¯-ïZ£ìù1wÇö_ÐoeȪáú­ÇÝ>íâë²àÐI‚V:Œ‚O’Í7!‡¿ó~°™¶ÖÀ$o¡ ¢ ˜ú-ãh”Dj˜Ï˜½™7ß^¯Ê°0Æö¦ïV‘$‡ú¤ )«]¬dEU¯¯¯Å|}}ké8ÒÛŠ¥fC $þÏr—çÖ>n¯]UJ¾ÖÛ„(ïܶ•ëÿ¯ûŸÇ}Gó¹\Ðnÿçµ=9g¹Ú;§4oÉ]`¸ uç¶-‘+–NèØÖ*ñÕã-~/­‡nû1á·S›,´ï"ãñêù;>z8î¬Çú½–¨}L>d9bUê½›!Rš–½v6\5rÈ úˆëçfÀƒm';/·Û6kPþÛ;sþ<Ñqz°ƒCv”4’ÖöóóûúõkTTT÷îÝýüüÐøv½Fþùäüœ7kιœÚáê _ͪǖËémAáûó·²Öœ‹×½¡t2»a~·yœEFâ”¶#g—¬ó+¤Íh@§ÛæPØÝ Ÿ•ǃ||²hZFÆ.Ûàʦb€óŽfðw±a³ÀÀ¸ùùù$ƒ¥†—GžY#êó#«ž— ´tt`gÃ✜féø˜–å¨ÈðÏE{wÎa˜7wš²ýxШj£¤‘>öàà`ñ|r---ÉT‹¸&XJJ ¼zõªcÇŽª®R]£\«ÊndQq´ÿΗK—N0 ÉJ™‘ÇÏsœ3¡IM+sÒ½ãíñ!§Ü¬Ëì´„KÓ,sEÆžrw{̳“î5-¿"111jµ6!àR•›ŸŒ(ù×f'™\fHo« 4­V—O’mØ`ÒãÏ_0l} èÛÊù)e?A)gØ"^üœM9;ö ÿ…òÕŸª¬WvÔ¤·‹I2îÿ=¿“µjP§ª’<¿âç¼ûx{:Ž.iÐ÷ÛˆJP«õÒ ô™0-%EFš¿”V›ÿâo¿d ž—¦>„Æ·¹PÏ)¥Õ‚l¡@¢¢¢T]…Z &&FÕUøÞV,j¤·•Ž•U•“@ê$êsr‘ÞVj¥·õ´^Q—A¶@ÔMÞV,õYo#TÒÛÊém„òAz¨Ë ÛF ê&Ho+–ú¬·«]BP…üG§šÉ ÒÛÊ žëm +ƒ ”ê½Dz×÷ï߯Û'Í'G(ƒJ­ZüCUÕPæ~U²m„©Ô¤UbcõѶ‘ÞV(õYo‡Ã)»UÛ˜d¿uûD ½­ ê¹Þf³Ù×*é“CÙ[LÝ>Ho#”©©©Jö›””¤’ýªdÛ¥’––¦äç¶¥¥¥rv¤n ½­Xä×Û$^øàURŸ.­_)å!>^éΰ@ hÙRyŽ Þ¿B¡¤Ä6Ôõ«éme ¿ÞŽ?;uÁ&£ÿ…,obTmkKÃJSrÒï¾!º;˜—uÓK …@§K9Ä*NxðJ£k/cUú (§·€ÁPª?P:.ù[ßô6šsªàü„y+£ZÛ¤x{{{{{ÿµ`r‡Î÷ *ñà… Rf¹,ãKyŸ|²Í}hÿMl[7éê4fç…7âp*»dÁðù™"¥NA¨Ho«gçỸñ÷ñæ…yŽÂn'ûé2+¦Œ Ÿâ¶¿¯~iÔñ…ÃV„|÷\õw€c¢Ø{wBÖ-ö6ëæ‘YmÙ&CöôÛýüG6,jÅý*Jõ¶2+ VÚHo×e¢*ªÑÛ¤èâ/ï“q$^üäÞqØ›ë!mœ†G„ÝAÑã_G?ôG%GnOéi¬#Þ<¾ò®a›ÞÝ,¤‹tò qìÇîŽÕŸ»õCÑQG3Èy³{í±X÷5=+¸³SHo«4¾­zQúî¬ÙgÍöíÛÅþ7mVošÒ@ò¾Líéõ3ýû]Ѧ}Š“xщŒ’Ö^}*”ZÆÁüpã9;>‚£'Þ?>ªïz¥Ù6B… wiª„B7Ùvn{Jtu¥¼Oãtw¿ç'‰ÒÀÞ@vC{Ã’ähñoëáRRRÄw DémÅ"Þpù8ï›ÄÅgQ6—6¨Ç. /íÞ’\_¹"¦1E¼IúT Ë{Ém©-£–ˆûUU'ém•€ô¶2g|›*dRY>¼Y1ª$u×Ò]’\ ™Ô÷ØMöH#vøÅGì©­Ëå’ èÆ „4¦¥ªN.ÒÛ*o«˜fe˜Ø- ÞÖÅ󡜀V:Œ‚O’< ýsÞ¯ÛQÆw_ô©y­»” kD0õ•7 ¡> ÛVÈ*{ªBÎûã»·³¨´›Ò8åÆ3IT#÷Ã~nmÇ÷òÞy2òõçOÂönòqñ éè¾Ðä‡ï‡wRí¦•ÎcMäïêêz3§È#A¨ Ho+yô6NšQ‰Óü×µn ÏdÐ(b¥Mà¸HÄå”|{qA§ñ— FNž%« ÇšÐKMwràÅvÝ·:êµÍ¯g4´k·d÷åÉ[‰w„ó“¤ñ·õ4orŠòrrrŠ8.KIßip¹Ür_kóù•L¶S½]®uûjGz[È5ŸœÝäþ©Ý×ßÄååeeñ8N€Q©T:ƒÉÖÐl7Ì{úP76› l¶ëºNküîfŸr³–äv·üÒ¸å@ðyÀ`QÊ €Å^\®é¸y ©®x³Éà=×ú!Ê‚Á`H¹ ?¤¯Ò Ñhâ¿å¾¯ÛW;ßV#¬{»Îé-WÊÑ‚ö÷Ÿ2ô’£ìT3 ³ÜG!"^üœM9;"‡×V%²,âÏŸ?“ÊZ Q¼—rëC(a¿ê²íÿ,Ã~w¾ý^ì×·š7dïCW =x®»J§©”³í—/_*¿999õѶ‘ÞV(ŠX/M·ëlØØjSNSõiåñx¤Ô2iúúú*±1éñm­—†¨êùziÒz[­Ö9­Û'o#”A¥†­êJÕ ÞF(ª–FSùs»>€ô¶b©çë“ é7äå~+³&åö[·OÒÛÊ žëíG©º •S·OßF(±£?„ª@ïÒˆº ÒÛŠ¥žëm„J@z[Ôs½P h|¨Ë ÛF ê&Ho+¤·Êéme€ô6Bù ñm„b¹v횪«P%õaìÙ6BˆMˆ¬ å¬Í Az×÷ïßWæ®UÒÛŠ¥žëmÉzi€æ“+¤·•A=×Û,KúA]îÑ­Ìš”ÛoÝ>Ho#Ž ÃVÉs[úGÙ6B±T4c•Øv¥5©Û ½­XÞ)c¶²²RI5âããùCÔ.õ\oWô–––VÕb, ÂÒÒ²~úC}ru†¿Hè×­ª+¢pììì”¶¯˜˜¥íKÝ@óÉÕ…ofÍœuøû’rd¥&¢Ê{œô»S9åCI¡°lââ„YÈ+XémÅ"§ÞÆùIs¢Z¶j·hÑ" E9/Þ$~þº·.³\ÊÔ‡§Wl>ô$&EDÓ²kßßwêVš¥…Rg ó™p-ŒË-õôîê®MÇC?}Š-ÂiævÇx-žåÖXÞ‚as®„í4¦)öæŽüo«¤·•œzûŸ G¸õ÷ñæ…yޏÃÉA¦zå’}?1tÚª^³Îí®™ùìľÕÓFxF¾ 1gPàÑj¯´‘œÍJs_8lEÈwÏU¯rì¢Q{ïNȺ¥£¢ n™Õ–måºÇi‡ç¶è°ûZ>ಠÿÛ*émuáñΉËÃð­{!,, 8é¡‹Cé{öpÅ›tÍV½»›‰SFìa´XppÙ4€¦.ë:4>ÙÔykBQžˆ=ólRðû¶â”Éwæ/?ÿzéw Ú€¹m‡^-È„¥¡Gø3v0)Ðyéʸö3b—>·e¡k n‚ΫJ!E7xyŸüJàECoˆÃÞ\iã4<ìæ =~ðeqôCqÔÐ㑤ú’ž â^fúã Bã)]´K½dð½mØfÅÃ.ÅÑçb”v׺}Æê—¬žuÔÑ rÞì^{,Ö}M`O•úCÔ"Ho+Ùz›f=x­óϵUc­ß°aƒ8põƒM|WO4a@~ìì³Ò¹t1àr…@3þž8_£A__3—Ë}¹#ºã¬R}‹ŸÈ(i9©›ìs:¨«ÑÂm¯¹õ ;öîùóÏZ. èD¯ÍÎ*ÒÛ*émePÞf[í<¿KP @‘DÑ0ŒÎb‰7yL*`ŒŠ§&çÝõ™Sÿúj<àÂýmFZ ˆÉàN2§q¾‰Ò¨‡¹ìsjÖ݈³7–ÍÍÜCRÜóX+ém•€ô¶ó¾uêÔIü»(›KÔs7Ïíå?8ä3íï+Ãþ úgÞpFiây"†âß†à ¢  “‰Œj4ÔÀyñµ{ õÙ¶Z@e5Šˆ¸Y1¼$u×Ò]ÆÒ!w7›q–àγþv:Òáf jv&_ü›BÓiÄ?s&•Ÿ%"$þãvÀÏâSæµuuémÅ"Ïø¶€Ë )”J†šµ.Ø»¾hÙ†½KæMÖ bÖ{Î<ýèbz¹¢ì´èßer–>¨gú8\X²n˳{þ´ÞOgÙŸv÷ñ°væÛ<†®­BÏ;ÒÛ*éme Ïø6UÈRTUû Š^ÿ³Ïß¾³©«ÿ:m1Ä'ïÅ£{R 4,º÷moÐūɺƒoÙ+ºˆ› ö{<ìoÏiKV¹9vÑç'ßp'h÷Õ®óO[i—ÎuyžÞtqñ~ÓùÏ ú0=øì}V-¶Ôñ"½­|ÞV¨¬ÆAâÌU›Úšê34 †Ià¸HÄåÇ==§c3™ &VÔ×§6½.“Ý¢ÿξí ,‡Í, ðËz6 ‹Ÿÿ”Y»nÚ÷Ü|Ìk›_ ΰlÚaùÁ[S—ÎWÇù Óø»Xˆ7 AQnn.Ÿ¨åï7*ºÝVÕW–⠈룒 (dÛª‡Ê0¿j÷õ7q¹™©<¾Ç 0*•Jg0Ùš­‡,öê&NyénxU…°ô‡¬ëä¿øzÒ)7kI`'÷¥Ü—ÁçƒEÁ¤Ó;¿XÃqsÝÒ§¨y¿ýjÿÐȲ€Òm›”ZJIÉߟ©¤·‹œóÉMì=eÍþ$ä9;Ãv¬ß7hn\¿3â)¨eáIçÇyßfmÌ ¼;@Ñ'Ç㕳j>ŸÿáÃ%Û˜Ø 8 õÒµˆ2¿ßf[ º´+:4÷ëÛLvÊ÷¡«\ïÓ@Wq•Ã`0¤ŸÛ/_¾Tô+òòåKƒr݇º}µ#½]1í³x2Àä””jSÎW|e BŸÜÄĤܫ5åPQÔm#ˆ´E©Õ:§õ¤·K=_/M,tÉž$Ö…a˜ªl[¼Y·OÒÛÊ ž¯—F£ÑȪQfMÃ'¼çIDATÞF j†­|Û®wc`ª®¢.^å€"©:uÉHKåp8âí‚ÏïJº4nÑ€R"û‘አ‰µlÞ(&>zäP»¯ŸŸ‹þæäÔÓT“^|õZX¥ukáìÒŒýÓ­••eLÌ—[$³e£·Qá¸À¬›]ƒ‚ÕȶӞÜ*±hßÔ"ÿ{<||põI\A›>ÎÃ[7Ó"ò¿|~}ãîÕBbt¯f:Tv£~–¯¯}¹6§‰ÊF¨ rèm0á6ÞÚòg¯›Ébß½Q ÕU[Ä),,8N Ο>7u²‡'EÉ0pøc”u^¡°Ò]ƧŽÔ20dç—$^ÞºfÐnš×@#xÿþMSûž}Ìš´´{ríæ«)î¸"‚$)­Zµ51)ßí¿åÝÔ\+?5ODàB‘8P(’8ç[Ì瘘˜lÓeòäæ$^QÀ—¿QQ¢¡ ÛÑòóy‚⤇¿f:LYæÚB/7=5¿˜4³í:²$ã^Rœq—.©9\½¶²Î_`ØOàfÿl7é–D ”\z»èõõ—òÄQ¦ýFt|ŠÈgLìd"*Jbj±ùÙ·OŸ¥ÐXMš6oó%NËĦ…ž^Ü?‡Ï&•TR²I¯ž íš31*ŸN' ãÂb8f ç×äÅÆ| iµ"ñ"nq¡®móg§c}»ÒKH ÛÙÙjkk–+Š…Æ`1t:F`8 J2âÞ?{ðéK"»Aãv½Üºwm¯Ç “ã¾q’N§Ëß(Åé¯ ¶ö¦ì”XNÿô4‰eâäÖÒ0;!6‡‡|½V'ô¶ÖÖ2 ÓHz£fŒˆ»…z½¸o#Ô¹ô¶A»Á“zš˜ê0H’Ĩ´/מ9ºýÙJ‹LH± G¸õô}­ ¼4,ÚvÖdi·üÝȘI¢dæó}|5)ªkœÎ'‹x8||–b3|¾ƒ›”W’\ iÓ€–†Q[˜0Ÿ½šu¥¥rDDQQQ¹Zá’õ€$ñ ‡®ÙØÙyÌòhfeˆs‹ òÒãŠJpR+JNN«þH-jR°ì7¹Zœ1ÐJ“ž”ÄKÞó4f5Ö*IL qÈOáj4Ѥ0I¡°rÝN’@’€ …Ba©Þ¦`dôç¯U¼ÏbzxŒkÖ̦ÚIýú%O„3 ™¢¢"¡PH’L ø©\ažPXµÝ²©„( £Ñ…B!ÒÛu@.½ýþ߯ø*$! ›:ìcÚ²ÿ÷'øÆÒó¾þï+áöW :™#­i3?f±­õõYYÙthѦ-ÆçНwº†UC3~F6€®M… HH¡ñŸ°;šÒñx‚B§S¼ømϪƒ!ÎͯJ*c`Pét:”êm ÉÔÕqqqÕ7 …ªM£–ˆH N Û²©iÏ>ÑÆXÑ…eû ’~& )]ŒÂ¢ÓéHo#ÔÊûä妑ãaÛˆ0ó¿|fÞÈŒù=ÍpXoËÓÁ·Œ -œ'·3 ¤Äý|sF’¼È„"%46{¤8¤e›6%i?zÉd1§T¸¶7b‡<þ>Ø(çÁ“ôÎSÚàE™I ¢Þ,ÖjíÞX‡“”EÒßFW"•‹ñŸ½n £¼šŒrÉÀ€NÍLãb¦¥†Û¡‹ElÄGY3¬¤î9Ÿï_SìñÇP~Ê6R$=¿V*ƒ@üÕ|+òóD¡&'$¤sD|c’$É#Y,λtÐj¡EËKIäHYZÆ«Û|­¶ó‡èì=|«G6âÀâ¢ÂŠÃ¿MúõL¹{28›gÒÉ­w#”7¿&&ÅE¿Ëa4ò˜:Š&ÊËàŠpœ“K§SËå’+­*Fo Aýg®Z0„* x<.ŸÇçñ¸]ûÒ¡ÕlRšQKüߨݬÉB´mûwË ½sâH›nÝ,Œ™xqjJâË·qæ]ǵ±µŠO‘’ÈÑïcNâ<²þùpG¨'•ëm'=“\D’Iwo ùE…ù@#y¹‰CïËgu2ɱzýÜž-[ëFMí¬˜Œ›}ûm~7¯i&V¢ÁÙOž?ºçÏœ>£P(I¢Ví5(Pô<‘edÞÄ„]œ—û,:Õ¢ëà‰ŽÝtˆ¢ø¯)œŠEŸ~-­ê—«äý &t .„ Ø;—+ÊË).á‹0É`éë±Y,«† ’¿×hâ ³a áÓ¶—@P(±íÜ¿‘]ҳןï=‹mýŽ#¦ éÑ¢$#žÃxч|X;C^Öw@èûm„P¹Þf0Òm*†é5²iNò‰–tm£ã‡ÏRš;ÌñìgÆ&ÒSR:ß>/þá£dóEù…Iß¿5é;a˜nzlŒ®y“¡¶ææåææäæqB‚ IÀè ý¦V–ÙéiBøüìïñ_H·àÞÛÚ\ /ÈIýš_D…*~Z“ÅIIÅå*iÓ¹« ÎãaT*ÍÖºlŽ:  £`@8Að9@¡Pkòä¦j4îfòââgº#‹*ékP 9²7Ñ× ²Ø, |nFR\N!J¥Ä>¡™÷ê¢ÃHNéT*ÒÛu `×®]0`@½-êÙ6×ÌNË$Iâ®iS;anzjfþãÒgë60f'Æ%@êXØis’Rò~LÃ(šZÚLƒN£JF¡HBž!kTIµàü”ëW¿NötÊ+ªøn£ÀÏÉã$^xãBxwϹFE1 ùÒíöôéS´^BUT¯· ‚Œ’ÿ5lj£ø˜O$^¦—Ë)ÈþVPú» ùkA™âðâÂüò]õ†Â0س žnrõøÙ)=†u¶ê;ÌÞ’•ô%©âk BUT®·ÁOÖ2u ÃJ/Y¼b¦ºݸ©W°ÀkR6¯š£m ḋOâßå ém„ª¨\oÓh´ò¯Êëåã/ÉÌ Pj°´C¹†Bz¡*䫯¶ý h ñÿöÎ< †õãÏœ9kû¾œÑ‚²„r-%[e˾ Ù…DâÊ.dIÙ/¹"dÙrK¡k)®ër³í*rNef~œ:Ngë8§7óù«3óÌ3ïûí}gÞgÞ™÷ù>ß·SSS¹$$$ ’ý­Ë@BBÒðùÀHHš&dŽ^’¦ Ù·IHš&dþm’¦ o“4MÈ19 IÓ„ìÛ$$M2Þ&!iš¨o'&&6lQš²x’¢Õ )šÈý”X¥5Œ•{”ûιè² IÒÒÒäÚ¢I¡ºh¸"¹D4jq¿$?[¸sçŽ\ú6Èk£?ò—*~QCŠ&‰Š¢áu!Ã0ò‚¨D4âm.—KÔ®©&>*ÿ§&ŒdõåjKŠ&K½¢q8Qß±AƒœðMƒzEÓh~›ÉdJÝvT¼7UÄUÔøäjKŠ&…*¢1 Ùû6Žã_ ùÁÀqœB¡ˆ/ @´†“Ënù1y‚¨bCЦ¶h?æ˜\tQ#A®òùÍo?:wç_1AiZZZ¹ðGü“(B£x[*m¨Ý»«çáç Eýcßö2çÁ]Xºé‘[«ÆÎö´Ò^›9#~Ê•ý=àúêÅgßÕdìîÝZ^št䙥ËêÄ rfªÊn>ÆêjQOèÁ)¼ý7˹‡1Cõ’ËEòö¢J®5'Zfø¢Þ+Cì 4,ŒªËn^É4éÕNC?òå% Ñ$î(Êå­W4Ñ‚ùÒén0¬;„GhêÝâªÊÒÿ!œ»˜K×]Ö!·èîcVçnFš¶.1âûvMI<Þ–J&FªèämÂѨ7®çæµE„B£"œÅq'¢æcŸl¨Úå‹"B&JÍÅ™·Y}LX|Ð¥Óh4Œ—¿,:gû•sû½FnºÑ}¥[Ò9ƳÄo½ïoWi4Úßáþ!iÅÍIJ™••U—ãÆ¸Ödÿcêò—[þÛÕm&TÆ2’V•\krEcaÙ÷®”Ñ‚M¿öìy—¢ZúŽp2¯×²¢øä–í½GtRbsíRb{ÏÁl:9¤ßÛÝ ›ZêIHÊ+Úòøâžˆ#IÏžåTbTK;gŸ) gèõÉ[¯hL&Ã0É©/¢veNµÇävï>•ò2;¯ ÕµiÕÊkRˆ¿§½x™ëžyœŠñýÄï6Ìø‡é½'H¥Î/Y6e£Ï©óhÍúÊÒ´ªWM^}òüf [—qßV"Ú·“»¯õ~yp§vEäWÇVi;­ê¥ÇVçgÜ%kÏîÜÕ©-çOp°Ò€ ˦ó<6ö5³Ý³àBˆß¥¬ IãŒðéo†ls3`ï}ñ[ŽÓÊ•+W, Õ¿‡ µdÓÌ¡Cg…•0`šxní3-òá¿^a°ø¿’ëYo ²ï¤%ŽÞ¾->¯î~ìݮܳþÉ õsŸ•ˆ5Dä¾bÉÏϸBà~úÀ‘òHÊ Ç—úŒ[zÔaø¬C É—ŽïØÏ|g¨÷¼˜à;“Y0ræÆ‹NcƒO\¾‘ü[쬶±¡&®>'¶à½Sô¦&« s¶ÏwµŒ½.*PÔ± 3" dÐW}†*™&î{æÌÙù¨1+©é³4Íѳ™ë?„“ǯY'ø3í§À̓•ò"z—µï& À£Øùa™vÉ×ÝÀÈqêÙ-åC}d…X<Ò„UOž-úåΗa'•iíææVûËÎôûã¼üÇÏk›=:-}Ý3èUÐ ¦tî±Æáê™c/óóóóóórž|ÌI5ÅÖÖÖÚÖÆÖÁ†.iVõîlŸgÞ\%ëaÐ’Í[GL]þóèF k]ÅÛóÖ\cM›> ¹¤1W¾xü /¿   _D9fòØZfm~>Ah+NÈ"%oqê’°„GA§o8€¥MG—6DÁªä£¼)›”o/¯˜‚ËÁ»oä»>³­(•®‡_h»ÿñ- [çå¶²kÝá!ˆ öŽ/²?t6²•VMV=_’P¼#ÍAu‡ç†äz,~=7ÉšÑHÕÿöñöÃUÃü^q.åS‰ñƒ’ª"b?&Ý%Äp@ Ä‚вpã ùÎä^µººk~èñC´ll±·6~Ï­÷Ñô÷ÕÝÌŠÿˆïÀѱIfó¦™vÜî>0xÕƒºêÐV·Q܈Ì7;»×?¦U„&ñvÁ£§U¦Íº¹;yO9u¼ïñóg-è5w Éb£ºžðaëg^(ƒ¸àsnö‹ÜV¿¾5í¬×‚‹ÖvO-:Š!ðª¥ëÏY„OÜ’øu7òóó òó¹Õw§/¼Ó¢e‹V-¬Ú8Ó_ü‘fåƒbBAírì|˜8&p\(J„.%ï5)†‹¦;èJšý4÷à•¹`Jämäxû@ä=Ã6‹§µÑM ‰0ëµb¢ùµ„°„eç§Na‚ø5ãfYí?³ÕމˆíKîíùt`RD[Tqˆjw®ÏÝñ 4²›ú­KÌ#ÞF·ŸôÔ$;ñ–=;#( F£¢‚PEAP*ÝÓV÷AÑg£"㸤­Ú(° §³[Búh‚¢ïþ`Ŧ¡È‹˜çæ½æŠCA”‚Jeó¶ìéKIÇ ª]µÀ««IȯÙ4·fjk¢I¼=cýz±Y_}ú¥OÂÙ–ÚµpQõ¡$÷ù³çl”» $°âõË‚÷x‹–ÚYËSÞ²¨MujÖq¤™Ä “eQ]{¶ !ÀÔg·vêÝTK»çïèz39HdÃ)JèmŸxb„8_*UâaÊ¢Óh(€B¥II')/}>ý–ë0©·¢dé"ÉÛ˜ñ6}J,¯¶÷ë"ޓŏw7=vùŠÎeVG®oŸ±%éóá”ãíuë ^zaî:KäAE‡0°‹qèÁÔ… £J¼ýíÇä{.|þ}ñϬJ¾Rû ;‚{MØw÷B@qyIá€jœøPR\ÄcB³oŽ"UReè#ýS ºNgA>—T#€‘³÷Às€>Õ§!ÄÖŽ¹’ÆÖyÿ4++ëiÖ‹ìOé÷Ó8ùLJsphkm®Uä0tkh¶QÒÒÛZFXÈä0ÁûpoÊÏ)žÛ’EO­z½gú”eÛ*ŸÌöÞ0?6Ù\‰€û¥³é2©‘+ÿ Ù[¼cÉ`Iy1~¡'Œœ”Wê{ã—àaÔYNQ :àçs98¡MA€[zxMrG6òöðå×>m$-Ÿ–VŒ1øZ‡F ¹±ÏÜd-ÿ ¾‹¾mÖcìL¯/¡àÞŒ›Êíµ,F”¯yòDÆåˆ¶äp„…ÃnÑ ëvù%ryB»žQ ¿ò>Fz͵j<ÿOKXýZíŠhÆ+n ²ZǞݮÿhïÀ¹“u¸êÛöË”dcY²¾Ö!‹ÍÂxREÿE¾}¼-Ä ~Eq^Þ—‘ÕgŒÀ„¦(Þ B{šÝqQLo^ô©;3' éõ“kÔ.8¹·Ç¬El:EdlJCß–pÄáŸl¼ …©G„2É‚)ÚÎ)­FéæR6_…Úñ6&Þø3ÛÖÎÖst?»VvFü]Ãç±·®Ÿ'>P²T]:•F?Ú>:|¾çÒýŽ -óçÜ!KÓÝ/oòÊì ‘¼Ð)$.§Hyx•hÑ{uìµñvú¯3ãñ×–y ‚ºòj1bÞ:s]0ÆJúDˆ'ºÉÛ¸ñ6k¸1+-)›d+µã÷ÌwÚæ“E13N]¯» ®s¶O¸«˜·B‚ nݺ£k`ŸñžÂ Ô:$ ê@bðBÚØ“µ¹Ÿ !Õ4*nŰñŸçv×Fö€©Üðu¥|_3¦Í,ôžDF>A(4C3sKë ¿† v±§Ô~Š„ñ •ò"úX¨w…Õý©,eˆ13±”ÛUGþ b„™Ö¹R®£uwŘõ^»Ýê襞ݨ()†nóŸ·„è¤?ÉÌúøYˆ“©¥¥­ejH!‚[võ&ß3>bœøpÇÖ¯tÇüêä|ùîJJ^dê–3N®;·?¸g£5³ë¼#~’G[åòª"šd—&êÎÕ{/Í?òl‡„=;Žo;³¹GÑja×zʦcS<ìÅÞè¦l«fzâŸ(«Ý¾½Ó×Þ™î2ÏÅÌÒc"w˦Ržií¥µ^‡8¿ðH?¼§Yƒ|Ü¢JGS?XrrrŸ>}ÄÞ%ÏôU}ûáªa‘m¶ÅùÚà>C½ÞUrõ[:=¥MA6øû¤¿yÏGXÃÖ êbG½z–F_ i¦/_H³z±ÅwÆo/zÖ篞0½ (1F=3Í#uô¡_7Wxz ^ÇO Hquœ—ÒUD²úR_%Zî飯]Fõm¦ òx“râi›aýìmÊ‹óx@gPêÜ É«Šhnnnâ»ä…à«Zš\œ'D´¯¿•ž5èÆÈ_w”™ÏSà0÷ܬyiÃ.îôR·¤uÏ"Qý‡ÊŠÆÛt:]öÎóµñ¶Óê³±(E4þò5É]«ŽÆKû%\',Q8jYÓ:-?™¹¼Žd43r[Ø‘a+ÊñtrT^ŒG.†î®¿ÞVÒFUס1è lô( Ê`ªl @7èyhãß)ù•?VnYñôˆgÔ.:4MZŒT3­×FmѾÄò†pUnyóôbEòª"šxLNÈ<-ÿV¢Ñ \¢Ãž¤TnñîW¯qr\°û–½Nšµ.IT©{ƒõíïDqYL]Æ©p=0°Ÿ8ý«.òøÚ¾ýÝŠ¦:"yÇýýw½–ŠäU±oK*&5,פüš`Ú}ÆX€±™™ªOiТªR}æ·ù|¾Xqø'ý°+ÝHµQ¹Ú’¢I¡Šh’ÏÉ%›õ+š ?¿M¥R ÅhPÔÿ*RÕW:’¢I¢Šh‚ˆ–“œ×_½Èß©¦Òñ6ÙLnìGACѳ¨ßªÔ]£¾ššªÉá?&¤hjpûöío]„ÿêÏo“|Ïù·IHš&ß~½4’²o“4MÈüÛ$$M2Þ&!išcr’¦Éÿ4—åâ«ú±IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/datafit.png0000644000175000017500000023203013070106167016520 00000000000000‰PNG  IHDRf5óT¡„sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìÝe`ÇÛðgÏïâ®IB‚„E‚[ÜJ Å¡”Rª”R£} ”*¥ZÜ¥8HñÜ-„·»ËéÞÞÚûáÂåâò‚<¿/¹›™ÝÛìÜî³3G$&&B!„*#’Ëåµ]„Bè% ¨í „B/ì2B¡*‘$YÛu@!„^ËD!„ªoÌ"„BURõ.“3r¼å•òþL3[f¡l5ey‘w6Qmþ_k‡B½0ˆòÆe&:r%='_™ŸŸ—”pÿ~£:ƒ~ÚùU$lêñƃÕ'¾ªëXbªàxXÛ9Ço^õ— 'µjêµéÌ·!.Ïü „BÏE¹±L{]®žú6hœ°iÍ+®~#Ø^\xI*&@$“—^ðÑ_Ë\Ïv¶7©Ò2çyÉ¥Âg[}„Bèy•™Êï~¶ç”åõ#ýð‡/nJ…ÐuéÊÉÞv@ªòs&B öp/ºŽüý¯‡]Wö€ôC+g»„•XíÍÄd!ñ,>B!ô¬e$ótVfEs°jH´ëʽCÝåA\™:dn‚Š£i¹—¯“ÎÑø¤$²,¡ÏÜÒú£ÓIe¢/Ú†f}{tÒ±˜¹¦ÿ;±´µu­"QÙ=4B!ôâ+w\¦þêû}Ãì²4”háüób¸x-ïþ­³½~ïÚ‚Û|pºsJ³ö_=Yœ_:î;àL¦Çç®Uú^ŠpO<ÂñB!ô4X»E‘m’å…%R…£££L@ÈÖÇv¸x-ý½ƒ˜+Ð DŽ@íæ}´®S„×2…÷Ø ÿ‘ Kœë5iÒÄvÙ™™Ö !„B/8Û˼b±Ì¤¤$ëk»Ðw>©“‹»“ô—?#IÒ¤>¬—†ÉiʨÏ%„ö–Å[icyA‘¤@*$I(–Ë9·dÊ”ÂGj}ºÎýdp@‰­ „B/>KW,–iûúÞò5ëÔi E;6§ˆЪW÷œ•¿ûtûL.—›¹D¡¬~Ñ"œ¤r¹u,¦T(°¯ÛyÈ`Ë[‡z>8Ÿ-B¡—‘¥ÿ*wÔG³¿®gyøµ{k·_Vް£%'å³çmNštª-h¦KìzT¼ ;¿¶½zµyªÕF!„jGÙ]&­;ÿÓoGóóòss³o)Irä€Þþ C‚};[ÕæýÞ·ºçž°ò¡G¿ç\]„B¨¶‹eZ_s¼ÂÍ¿Mã7¼}}ë,©ãébdþ¡~cµ;·NÔúæ¯Í7Á¥ý·Ó-ÎQ@‘$ÉÞ˜¥XŽg)ü=N„B/;K_V8ûOll¬õ!ÚŠpýö‰Á`PØÙ=YK›(^"—àï‹!„zYÙöÕœÁ®ÂîÏÎήXY± ŸöA!ôÊÀK@„B¨JÊŽe"„BȪ’q™!„²°ôxc!„ªì2B¡*ÁX&B!T Œe"„BURɳ¨´ýû÷×v^Jýû÷¯í*¼Ê^„f‰‡½&°Ë¬Ë©/ Çqµ]»…ín9yòdmWçÕ÷ü›%bôzÂXfõ$i9M€ÍYÃúº¶k÷¢(±O°]=kÏ¿Yâ!F¯ŒeÖ„L&³ýþ^â}m×îEQbŸ`»zÖž³ÄCŒ^7ˬ‰ NL¯j—yþüyˆˆˆ¨ú"Ö]ñªî“ÍÿØ,;QQQÕÚb‰½°Ë¬¶Ò§¡W»Ë€˜˜˜„„„j-òjïÐÿØ,gΜ‰‡¡Ja,³z,»Èöddýj_ÛU{¶hš®VyÛó)¶«gí©4K<ÄU Öb™w·ý›ª£ëöŸ;¢ÉsØÜÓ%—ËKßû²¦ÔV­8:wí†ãß~[Xa±Ô' ‚:5³+¼µ M@õ±TöŽ­e-ûu¬'cX©¿ŸGy…ÍúK›wÞ)3+fü„ò:»kgNKÂÛ·¶n½ë1yT§òºÄ‚»û¶\šùVËòº³:%1ËX^Ýä¾õ¥¶)´þQïïïPIŸd.xœ%ö«k÷tÃ%LL dœýD›?´ ü‹¿¾jáþ¼>\CúîM{Áö†G7o˜IuZJždÂì‰N|á°Bž3Þ¾“d-Oì‡ïê,€k«~Ië=i€á/œ;99ååæ–ÙÙÙ “ÜÎ;|P£»«öÞo58Tn)¦~w•éѸp$^Êwyc¨—‡}v®¾ÌÚšµ™É „åôÌî¡¡"‚b «À±ºƒ[ÿk1~ºTȤßq0I !T88:»¸ø5kZ×ÕRR 6Ývì­·z—óïU=z ™š¥IH.ЀË[}½XÇ #ô¿ª<–yí§¯%.>_ΜjyKë³ØFߟþ»oé’w¶>a=³é¿ìhФah›wŒeDGêöþmo¯ööo:Y6wnÁèôþ¿´spûì³Ï,(ÕÁYŸìý|ÙŠ:’ÂÒÙ©Û—Œþ:îÀ§µ|MTfÐ(ãØæ½ J”ì1~R¬â¥áxàÚ6¼ToÜÔÝZÿÓ×b–ytü·o6{ ‰òµæ¾ùæ› w‹®º2þÝ¥œÚ¡®ÜÚ~ñù¼kÌ“¯/õö”Ÿ~ú©µ0!´hêTq(ëºx>3áÒñ3×ÛŽš2 9˜H³)}ÍÏë»Mx/ÔÛ>=%ÍÌñÀ±ºôŒL¡¹› kÚ¤ž@äÒ¤Á£3gòàŽ† ÌN¼š¦70\ý°p½^Ï0LVÊ#’+ÙoÒ<$_½,7kå %¹2^þ¾@3æÛǶØËÇ6ó–s¬þ‚Ö,º·ç÷Úü¤Û#Â/¬{«…7Z„ž-zöuuw’”÷™Ìš<’d-¯ÓÏìÔõ ÷sѤ§´Z#Û`ì°pžgujenö£Ó{Ö_«Ö;*ÂN €øW †6•²Õ¹Í_ºYRºœígô¾^޾ŽBÁ¹A]—» Ù¯c™U J±LÆ”üîÚ‡_Ÿ½ó¦Ÿ½%åÂìŽó\ƒJ—<»îØ…—W9ÔÆ³ðþê¡;ØRW™—ævÿÐèéQÇ»pýÆ;³wd¬¹ÕZa'îÛ·°Ög$@ÇèÞMmîPu˜÷Urów3æ] ’ÕæS¾e r22ò‹‚F<¹gï‘¶ã§T78£<}öd˜Ù‚«â2 ¯œ8€÷ ¦;æ:Ôm ‹„CÝ1óçw,o=§ný»\(¶Vàø±£¦'ýÏh€g=j-LíÛ´nQqÅ,«úñÇW®\Y^™)S¦¼ÿþû…[©Z ‹ãô{7l(PÔï1°û郇NzËBÕ{·P´Ó½¡³^•+”Êž,,ïÝ»¯Bp'áQÒ¸7ÇIJ›²þÒ »Îž­ºv—H… !Mˆ;áÑIÎSŒXœ—–ªâ ÄÕš€ TÉéJgà Ɍ4صq3g#IÉui2lÝ·½ñœiÆóû„.­&oiõŠÌèÑ}½À³»Wÿ%­àéBëLì“•‘Mý„Äò¡9:/öž~ØÇÍŦ^"“ È£q£ú*5éãëߨÙÚg­]¾fÿÉz“ú²<ÔíÔùÀÊ’NÓ€d*>"¶J7K±«ßÄ¡îþv ‡OÞ7ð@*m–—.]ºqãFyeÂÃÃ[·nmy±LôZ©J,“]>yd¾84\Qô϶åTN= l Qª›ßÌž¹æx²gË =¼‹â‘"‰¤ôÚ÷ÇåþT´xö¹ÿ£=Þj]YŒ$N]G»¾»”·º“(¯/ûfmâ°¯wt,÷›þsSô‡ß*úÆMë/ïÙ{$ F—˜¬)õ?þ€L=Mo]ý‡´p2<ìþ{¥B@¸7ŸÑÌÅ¥IïÁ2ŸK³G}vOUz%îáß}ÝkhÏP'`M)[wÅùÖ«oÍåè|¢AƒbqÓ¦M†ŽªWYçÌ™“››»gÏžÒYƒ š3gN5?.öQ½ÇÖmÚPÄ™‚<]ÿþkÝ}³^1ͽåMI±ÅJóŒFKò<ÇótAAAÏbŸà ?ã“ë9™Ø;ˆôf†çÛF÷rpv)q‡óÑ–Ÿ{wÜÃÝÄpÖuI€w‹~#¼ù gÓ×ñ9gNôóœ^ìîïç¤%(°oÝ7È…Ræ@Vzzñj•Ièïïúô³œ]Ë0‰*»èŽçŠ¢ ß}{ÿ½ÿ€Vþ¡Ñ,”Ö “QGóÄ}†2çÒéëªF]#­Qí*#xs~bRnž­Öƒi­Zµâ8îÖ­[ef1B­VçååU³2½"*ê2O-ñÓ%Ï<û·é>÷ç¿gõ 5©ïVKoù=tqÇ’w?YæØ}ò/“Ž{µ’±Tê¶|ãïÍ\­)·~»ãÝí½*Öu@{™¿Ü…N> O=¹cG|ø§ß½]f Œ)‰Ê<ÅEç8ž3:}¾ÒuèìeßbÛ¶m°¸ë9?®.Œer¦ÐÆÍWlÚâ')\§gû‰ïµzÀòÍ4­ìÜmàÞ§ÝĈ\Z=Ù8ÃØ^¯pÊlíGŸ|h6å=L1…yÝO1†Ö³€ªœV ‚øöÛoµZíñãÇmÓ»wïþí·ßDMBpöžŽªÜŒ‡·®]:ϸ7ûö8Ñ­­®É4²·„axW/oi9QC†¼w.Íl.ìÿ ˜¢[±Ø_qä¿,Çn*Š5kRîÞM¯×g°”'©R÷™+S“g¸ ‚hݺ5EQ<°MoÒ¤ÉðáõZ-ö—èuVn,SuóǘÉKé_סEÐoΈ¾:ýç¡– þAL›HX2ñûÙ37^„Ù‹wNëÓôxŽª8¤qó×iŠºS»Ëyk±k™FçŠK™L4P&’ëÑí›»VÝ Éöàµ!1±dŸƒª €#µ„’:ŒMdˆ3çY#µ˜¿çHä“'-mc™•MDîGÓÅžà`ˆÌå®~úÎhަÀÑÉÉI\ý-ŠK ý{d}¾öŽA¯7êTù”"°A@÷.G^ïÐo×¼YmG÷û"à» “ºø”\¿-Û@×¢E‹f̘qéÒ%ËÛÖ­[/Z´ˆã8ÛÀ«èz|ïfjVfZjºÐµ^«¶ƒG´ ytjËöøœ€×»—/Q&SÊãÔ ~oEúK,ýc¢8Ž$I“™;t3:Ô`,üN°õ‡ï Ì&’dy–Jù÷ß+A˜UùF;Wg©€ÚŠò ânDÝÊ«’°~¯aa^™—§S)i]If8¯àènõ•é)$Í@¯ƒ}üü…ÀŸœù^#›}qå_ñ]ß?ÔÚϦgh2µ´<Â1hHÒf–çyx¦XxA˜ h™ U@±B©éfºHáB’:ýf}àà%Ϭ&™rNͲð[ÏUª´-жm[³Ùœ’’by8vìXƒÁžžn=¬ËD¯•Jb™>-'-Ú•>y Ø±Þä/ßm£4úDO{'ÒÎÎ!iùŒ®ã&w÷êÁ…놼¿÷Xfÿa¡§NpÌqn:hD¸]¹wÈm?ŽX,^¾|ùرc|8''ÇÇÇg„ 4Mggg‹DEÿ’ËD¯•Jb™±×¨vEou ÷Uˆ»ýe/{/ùñƒ*nŒcò¿7žk2éËâ#|$Âü\ª¼¥J ò(¡Ä·òrµÍðH/¶kWy¹ XüåSøìOÞùŽeŒÀ¹»êªG»ï­o»FE;>‰ÝI G4š5güù°åµæ¾Zë匸p¨FˆX{¡€|óµ?Ï2 S­Û~kÖ¬ùä“O¾ÿþûÒýeÕ¹6îà)w0¦\ߺ÷zB¦©q‹PEƭĤG?YþƒsÛÎÐãÞíÄQZõ“‡nŒ#GçüùÓâ\Þ}XWBæ6蓚0Ož.]÷Í‘Í-\ž3åå™4,Çr­Uç“ D8‹ö_3¯O”Å’·ŠÙÚß— 9>éx’kË·zŠ®Ùr{ú€`¦Œ½Ãš‰‡H ,ÿ¨½P Ò3¼kE;WÿèAº¸Êx#+8D-Of)‰¢¢¢.\¸0zôh‚ 222ðçíªÒ¿%Ǩ¿uÊçí3óÚÔ`ýÙÐ^;Ó‚wŸWâ†&Ž’³÷40°JëÑÜÑH]× ÏÔö-[èâ7f³O§sôã­[·€CƒÈ¾mj2Þ±^˰UàYÝ’ï®Gý²¤DŽUõ_F®à«Ëoo©èí..9nUæÖÞ'M ƒN£½¾òîVo7g¡2/¯ÎÌχ:]GEôÈùü÷ö¢«ýÁnnn«V­ªÁG+!u4•ïÔnÎØ¦NR¡ºy½­kÿJ¬W?;ÙÐ;f\gA^ŽÌú›Û·Ç)Mâ °æ:µ«ïëjLþÛTpô?N™ŸÜOÎ71-ÊéùyŽVçfækB¢BÎíß/y¯?M²§O\nÝå ¹€à9*vûaðê8º…©ÊÉN½xJ)œÔÅßìãpzÝîëÎ}›•qÕ·®Ëܺ ¾Ä€ž#×n=<|Ô {ÀS*ÌÌ"‰zÒÒ‹[Pª”Ž%;4PO&ÌWó@噄 oà«ðŒÑ3&“Ézôè!ÒÓÓ±¿Dª2.Ó˜qù»Þ=JFÝ8£Ê YP4WF,“7ŸÞþÇ’WåúöØrä‡@M’Å*¡cëf¬‰#gÛ&–Ëd8hÓk4 H<|8¼;„G·pªùöxvÛ£¯¼y¼¹s‰XÔõe“5þãwL10éïgMÓ4”1ÕÃê…ßfIì©|ŠpR…µìPÇEÌšô Û„Û¾yà÷çýµâ«r§’€jÚ³ÝEP…@—À£Y¸Ü…׫guùj©£$ßì3ýÝ.>ŽâÜôLÍOÔ ïäÝ."ÌAÌô:Uv†qújöà¡=ÌÎí¾a‚1äiŒFHJÔ¹tóá#I’†ô³Ç.ç7ëݯ´¢o·¥›¥õuÍb™¶‰=*^ÝCŒÐË®Jã2ÿýqöœ_w™ºà̇cË›ñÇ¢ÌX惵¦ÿ3n毟Më+)ké !3 ?ÓŠ¦zÙ\ñ^ŽŠb±L–z¼:‡ZÖ'P.—€„ x‰ì9Q$I‰ˆÑ_kו8}<-”êæâO?<˜Ýl˶÷$¢b×çù—þž¾:ùÃk‚êØo€?,˜ _~ö¹¯›³L"À± E™':ßK,øbÕ߬É$”É.p~I³è¨.A´.óôž?ÿø}SD·®îÝŸyëJ m˜ª´ŠsK(ß­øñcÐi•Ùé×33S=Pò.á-ûŽîò†”3æç©¸¢¢<,؉5¨³Mf€.3ùþñS×C¢ÆÕóñT‰Z6}|tûšM­»F¶mRG.ìkñ7Í //¯¦Q{7¬ïã&ŒÙL™ô=Gõ^¿zãáT…Ä¥£³k¦>÷Ì]u‹asÃ…÷ΞÝs$Nܤ÷äþ¡”._(“9ù¶Ó—Ù~hOzF»Ñ½Ú ` ª·¯Ç]¸å×nøÈpwR•#—Ë)¹Ð¬‹¿t­©QO«ŸHêÚË:™Ü£ik:þ”Q.' ptv(H?|$ã ;{GŸAã¶ «ÇS†|--—Ë9¶à¦ÒÂ5ÈårFÌQfÚÙÇ߅Қʿu^ºYZIåbg')‚Jà³;Ľª4ÇlXXÃ_ÿý**Ô¹ÒÕy¶3ɳ^‰Äà˜u×Þ”:•ß×Ê\ú,|cþÜi×µ&*<Ç>=®DÉG;æ*:-éúd¾ßî^i¥ž¾òNL–3ÈÓÝ!±Áãþ6ÂED”Xùå}ûz~¹u˜Ÿ‚㸆}'oé5úJ\ÜÔô|UÑDQ,G„RûB°,øpÄQ«Ò$&Ó 7ò¯ÿÜgæ¿£z~¸îHë:vI±+?\²}ì‚÷*®µ>ín©´°)ïÚêW=½}ýüëDô{«Y°Ÿƒ± ×`*U–'MfË«k»×]6yGŸêMj• Ø·Žþàà¿—tÍ83týþ£¹ºÛÃ04MkÔJš.œËGdWìèþ§Î' ‹éı::5®~sO½2ùȱ+u;ÝŒ*}áU—KPë‰<Ï&9ú¸9ä©t׎í¾ÏøDŽ›ÑØÇ¬Wj)ƒº¼‘{÷Þ­ûÍIíôÍs ’wõ9¹ó޹¿°Ú´þÚÄw†-Y¼´â*Íž5aË_û»Ï˜ÕÜ…ÎQ–;í{ ÿ{³Ø®žµZo–xˆÑ+c™Õ†OÒ£6K„ž›êíC!„^[ËD!„*±L„B¨J,ý#Þ˜E!„ª»L„B¨J0–‰BUc™!„P•à¸ÌjÛºmGmW!„Ð37jäð2ӱˬ†Í›µk×®¶kBèŠ// c™!„P1¥{CŒe"„Be(Ýâ¸L„B¨j§Ëä9£Ž)õ›D¥Vëj£:!„På*‰e3n_MV’FÒ¨×h 4še^^NnNFÚã|:lÿÑ_ÜE5éts/½ßc¶èÖ¹%¶‰d‘;ïÝÜk›xlË®ÆCùI„EUÊ<´ãlãñ#ê[6çÄ ."§ª7– ig¯É[ut—Õ ò!„^m5Œervwüs\agïàà`/§ûcÝ/Ë–{zzzúøÔñ‘ Û™G7mºœ˜••™•••kš²a×èºeÖ&~Ñùú£Ö—Ø/!(–ÈÓŸ~õÙ¡±£åÒ¢.S›»û÷µŠiãYSXsÆ´á_L8zvó¸þ»äïÚ0Àšurþ»û'.ý(Üš²klïµvs·/¤?øñ‘3+ú"©ùÔÄ.Épp*B¡ÊUË|#²§öÑï-ºeyËsFàù}ûöY 4›ÿà ûÒ÷|ÓNþíÜðÆD2·þœÿ}Ø»&[²8F9sæ1<…ÎãOe»”Y×¾Çg§NM‘4dŧ;†º’$I<Œýï„H,–Éd¼ÖDˆ‚ÃZzŠH’Ì8±Ðì>®©ˆ!IìúttúðÀÊ»Óç5€;îskþÑ”¬»ë6Ü<£ÜYþ¯½ï¤º@“$ ’¶ÃõßœM[ÑÁT7V|¿)yÐü…í%Og×"„z9Õ0–©£n\JêydKàÌ™'ÏLY¸p¡%ëèÈžghA‰EÌÙ÷þvÏ­“8=ßTÇÍ$]Þô´‹_8ñžs‘«‘Û9ËíàÊîåž}§Ö‘€’:^^^ÖµÑA®r¹\.ï¿úïþ–Ĭ³cÎæ™:©»åíÕ÷}ºÏµ®N´_Ì]òoÚÀöƒéῷ蔸è—Ýò¹-`Ë‘Ìà9#¬…‡tðœ¹"YY˜Ü¸þ‰o9QœŠB¯·šÄ2- ÙÍšµ€7s¬fÖ¬Y–tU®¡M1žÕoùáãEÿÜoæq2‰Ò`×›½>ÒØ6Ô¨ýä…ÁHZõ­Õ9?ùhZÏß,)ñWm>âvnÅȲ7bPtR”HdM¬Ä©èBðVéú¦«õmãÙ½;WÜ4|׈¿±#Ÿþ¯…{I†yïÜ0|ј»þ’\50ÀZØ­›aù€PwÀÎŒ€B•§òçEë|¼gÏž={öìÚ¾B tÙóÄû~Åž†=ñõåiOÅû´…Á·ëÒ_þÚráNâѵ SHöÌЮ³¾ß¬cy±}óÿûuoW—¢¡S×® Ž|øõéì27-” Y’¥òL¶‰æ|³ØYl}›lbþEݪCÝ9þâçkùy¶óÖP.’¹ èì(úáBNÞ•_¥.½zÛl]á¯`MÉ•î„B*—if„ú»ÈÈ¥¼™c”‘‘‘–,“FF›-‹ð9s]òþãŦìY?ÝšaIWH.Pž1g7tùüãß2u¤Â^=ë<òÓ?ŒýŠ")à‹Õðè’r'7ñ—3 ‚Ⱦ¬tl"·ó rÒ5$éd]jn˜ë¢ß®\2ßi0þCK±iÝ|fÿzñºô®ßßl×¯É bOœY!„­Å2yÆ1dÉÙÓ…ïSr³7†üóÏ?¶E$r¹€Ö]7 ½‚œì-£ióÍ„zn–Üý 7µY°Ý#´îнQEËÈ$A›M\{"†K„J D±:8ØeîÿÜØîs»¢ëÈ£'r'ù[‹…;IÏ'Q¶Kuþ¤ÍGoý½’WMþ+Ø’>§§ºÏŸëEª¡K›Ú–¤êd®Ípf]„B¶jËdŒwÇŒ™g}Ëó&àé1cÆØ–ùaÇžP¹Hlß*Â!§ÇàÎÉ÷¶_,|V}gÅGg$gÿô¯¤j„È»œgT=:ù,:4k]kkJîù%ëŒa׃\¬)áoÕÏXy>ifMqo9O`èpÏ¡Ó`·ÂÏìXÿ}Wú¯x>xcñ›ÉgŽeÏmby}vþ´nOY³µ N „B¨ åw™œ)!E¸hÑ"kK¥ö8Ã6Øäsã&B¼éüÉ-kbÃVŽjî “òè€Á¿ÎßyÆ_RÉD°ú—_ÁÕCAžmÓê ˆ‡x^bÞ?ôÇøÙëßYë$*šu¨N¿i†ŸåÐo{‰ ã²BiÝÙÛ[Ͷ–!„öŸ4výÁõ›å€¥¯Ì¢–Eù~\³N¥RQ\©™oB!¨ –ÉRé‹/.QºG÷Î¥¿üíwo±ÀmØ„‘|atSÖjÎO{{‡(ʸ#l²‰eZ*‘‘xâÊE#Ixk~±ò².¿ý½Õ¡H€ÊËøpÛѾ‹—é¶ ¼÷ÏÃÕŠ…{urñÓg|ÿâ)I[çÈÛÛVÂZ]Ú}äHÉ€Bè5T^,“ÈÈÈ€ØØØ˜˜˜ÌÌÌçQž1’ŒBñÔîš”Ç{tûeûåÚÔ¨¼4Ç,²*ñÃg!„^+•Ï1‹B!ÀX&B!T)Œe"„BUbéñÆ,B!T%Øe"„BU‚±L„B¨ËD!„ªc™!„P5`—‰BU Æ2B¡J`,!„ªŒe"„BÕ€]&B!T%ËD!„*±L„B¨Jð÷2_8[·í¨í* 0jäðç¼ElüèQqãÇ.óÒ¢y3WW×Ú®zÝ©Tªç¿QlüèEPiãÇX&B¨$< ×Vyc™¡²á©½¶Êkü8.!„ª†W¡ËäXm¾R_Ûµ@!ôŠ«<–[éZ"##K'Ò®\.ðîæ‰‡v_Ñ™K°¯Ó¾oû:Ö”ݛntï-ËÙv éÖ£‰K™[§ÔÇ·p˜>±³ÙÌ”WCÆð8—÷óµ/÷q'Z›ž-ò®£xŸ‡âyž ˆÿ¥fÕVVÍ<Ïm•éʼnebãy³jæ…müÕˆeöéÓ‡çyŽãø²œ«vhܯg;{V§ÔP ðòV=tˆí3´c¨òr'| hTéÏßÓäêh¡LâçíØ.Ô¾ÌÚUP ³j+«fžç¶*PÝXæÕ}[nëœGŽî%U*é¿g3ÅCÆ pÖän6þ—7«f^ðÆoIÎ;’““ÃÃÃu:]ér< *¯¿€””ggg//¯ ånMùÜ8v¼n‡6R–ci±Ÿ‹ðá•Ûö †Œî&cMiéÁD2×F}nÇ÷m¡`Ù/tìÝGyïè¡WîÝ»÷0%Ë䨼}ÔHq¥* ùàòµ¬üüìÔÔ´ô'H¯†AN"ŽH;±õwßA 쥊°ðf¡¡¡uÌ—¯¥DÑ¢I£ÐÐÐÐÐÐA-\2ÿ;¤ªî'-»S­Pêî¢O8{îVhDKð<»iWž´ÑÌQ¥@™è2j^‚R©´=Z´Q¿ÿœRîïÒ½…{}áƒ{ÊG´$È]\b© ŠaVmeÕÌóÜVH’tww¯Ö"ŽWÎÆ¥É7ñ–ZRLùW·ÄÞn2xr‡.&’¬ô ÿ+“U3/rã·í«ôí¯Ä•™mYÞE›…Ø!`ôÔiA.®šø}7nüçßSÉy”“TXpóÐÊßýuùŸWô´µ°Ä>`ÔÔé¡®.²'_T)mŠÒ¥Ettt‡&ÎB‘°‚ ‰MfΘ1ÝÆ0_…Xwð¶¶Wdc‘Éà_·®¯¯¯¯¯¯—6nRÇÏ’àKêt^í;åÛÎÉjxo6 ÃƦ;oˆdÆïJ0ÊÇN"Jc,÷Žq’¯«y¹c†öö³«]÷VvÊ”¼|¦ä¯ fÕVVUdÝÌͤ‹~vÛzÖDòºÃ¢BÒNnÌäxÎ|ôŸsN¡F4÷ t¶úÕÄÆÿòfUÅËÛø«4.Ód2Y;HÛÎÒúº‚eÈÇ5JµRÚiüÔî”6néßÄgïu!úÄÒo' ©Ô0Ö+02í±6-1‘âáöë9©3§Ì~¬ÉÌ" ¦ûs‚¤P¸9³æÎ…›…cNYs.Céþùg§VWX—°6M ¿íêŸbáM]$Ù)ZÇ“¤h}aI]AÅYw½W#)u4OÔ]¤§+ü*Pžˆ~Ým>r89¸µüþ?—²Ã‡Í ±ƒÌ”Ç›r¯Åß)nßÙ_ZQßoÅwK˹„Û[Sd®®rB-—òU¥X¤¯³j%Ër€4yÚ›ZŠw°—6uq—–¼“DPœÍ­‡šJÛÆðÕ –)­×¥­_úÞMñÓF´|¿ó1ëõî›´>7[­ÇÆÿúd½Â¿±L‰DRæ]YK€³ÌeyNëv2 kÖD*$ÔWcw=à¦|J/ܵ=ÝdbòæPH*“Éhý­ÛI@DXXØÅ“ÿ5n×A§T‰\ÂÂ…œJk \ÂB2.Mn0.Üžb8à”i‰i^}#ý ¤I3±XÌ[ÿÉ>y(«EtWá ã†Ê!¨·€3R™µŠB¦ð¢^*“ lzÇFuGþËöᦢØjíå'{0txÔãõû·P2£cã£[{U9–íš©Œ„„ôÀþÜyÒ¦“.G›(žwv*:Å ð* 6 ¥‚bœ‡³j% |EºÌüƒ·ÈúõÛy ?Ö;•Õ7Ò×±Â{:5;”ðlÎ5—ÙvÀ€¤•[÷Þ—¥_Wvò‰·ˆÍU2r¹ÿë“õ 7þjÌ1[^gi{•YrŽÎÍË Ùk7#"Z€chë.AvíµÇ¹Â.]š›Íì•ôd‘€xžÉÍË‹ˆk×îDD´€Ž½ûjNK"àÌf€æ;Sf€ÜQ&ÌÓvÒBYÈ6 ´t‰M‹/ÉËdBÚò¨P®Ž±kçÀR¦ª|R…Ÿœº’!¶÷†šu™.¡Q>'~hà'kËÕSázœÿ0ÜÝÓE¢É!©ª¬ˆãÀ¡ø—rG‘màªZ ³j)‹îø-½G#¿vbpm¦àUÏ<¤ú†HyžUj ïÒëX´T¾˜Hâ$®Q5^$‰ç ~ÍWí>éß)&:ÐI››c¹%‹ÿõÉzåMºÌ•¹ˆ@äí 0_»‘èäì¦ÜÔDN 7ä±´ )ñÁHç3¬ :EFF;Ú‹®]»ãäädYÃÃø3‚èÁþRÑí½ÛÕm;Ì')¶xÞl4h Jþ°ý"«fX‰›Œ3—âR&±ƒ˜cò QÍ¿¼d_ÞÅ»6qÔìØ|fZ¿PÛ,†ÌϬòí.B(}ñŽÛÀØNPÅb„P€Yµ’Å™z¤¹êSy… ‘â 2× !Rže“Ò Çëà3t&‘$öŽáþ59”ð‚QÔ ¸Ò)˜Ö© Elü¯KÖ+ßø«ˤ(ªt³Äã?e.kÐé€çŠå ¡X"JÄ D‰„f!À˜L$ÀÑ@ðÀñÀñÀðÀ¦üƒžáAnÇÑ'ä8ÚD’f0±2‰ùØo¿s4Sú»†°Ž˜àÌ&’d@& 4:†±#-o-hSáµ)e*v§H_@„#Q³qi”úîŽsi-G~0°î£oï:˜èÓÑ·†u D)A¨5,( [Ïó4çè"¬b1HˆYµ’Ås&hàà(, á‘åxµmêfIIV¹FîAEa¾Ûª°Õ\ÇerláWXƒJK–ñ¿Y%Øø_Þ¬W¸ñW#–)‹K_\–¸Ê,sYŽ5AR!áÔ¼MˆD¥¢ÎÜ·mÛZ£¥Œñ'‘L&gyà¹Â=" @@€ˆ $Rihh'žÓq  b™\.©_»Ùž‘ª,££—›ˆ¸uñlp«ŽR ŽìÚÝØGÎSf¹œ_™(7›Õ—Ë¡¨Ë,/–©Ñ˜Ev>Db9«;´÷œ]p¿-= J~Xû€-67ž9ÅOT³oCD+WÁÅzð)œÀÌS™x¢“—°ÊÅ0«v²„{!¡V % Ý ϱ4Qi3¨Y5ž‰Ï1˱…·s¬ÿ×5‚ÿeÍz…5昭âÍØÒŒYIÀÓgXÞ²Išx™D`ÈÙýÃO¿œÓ êÛŒè0d&ð§“4–·áCGwi×¶e‹ÍÛmøñÿ¶Þ0Ö v´νxðÒõ,£N÷÷ÊWÓTyywÅn»™“Ÿ¯Ui«Ý’k.¼’÷jî\pë!®ÒÈ×ÇÉ:·v~õĶmÛšª±fÿf®J{_§1±y9úÿ®ë]ë¸{ˆ¸q9ç¿«ºJ‹aV­da×z’”«9·R $&#ué|æ™G%ƒîÕ:âd½ø°ñ¿>Y¯|ã'222 666&&&33³t‰ýû÷Wº–ºuë–œý‡ç.‰½’ÓmH·ûËê…ú…Ö±B¡ÜÉŽÍË7‹íDM®Þbþþù#±Ws#‡G&:Èz7lÞ¬±˜5‹¤`Žå8޳SÈ)Š’zû¹ ³&aõÚ#gÍïæÉÞÜ÷çþ¼>ôHº¾cÓ9Ÿù3:ªŒÚý¯Ñß­Ëcz¸|Õ©O¾|ר4ZkGnnÚq}Ò‡ù9Öñ$[ðç²õC>ÿº ]OV¯×4f]Ü~än“!3„(ò² ‡ 1†GÛwŸso9°W{Í£#»NåDM›HiMå<4˜Pâ')þÜ]mN-”‰|¼:4*œóâJ|f®À¾w[ÇŠ‹aV­eñ|J²òæc£žâe ±·cDHÉùJ ùFpU”ˆÈÔ¬O—J¥ ©Ù²§_¿~g§™s››Tº'W™ºlü¯SÖ+×ømûG"11âââbbb’’’Ê\ËÇ+ÝRppp±÷7[m)<}ÝeªŒ4}97¬RSSËü•]žã Aå-¤‚b˜U[YË „Õþï®Ù¶ž•JPóå Q@_MfºÍxkÀÆÿf½2ß¶¬ü*³æxÂÙËͤRšL®JÄB¡@@@„åÉ!žç´*ÍóNî”ZibxB&WH$b‘P@AÖÒZ•Šæ9‘£§ hó´ÄÎÎ|Nž‘«“¢@£åxˆN PkÀ6­¿6ñaK/-¯²³gMØò×þî3f5w¡sl®G«è§Ÿ~ª wΜ9UYIé/Ú=5¸Ê¬ ýcãG/‘J¯2Ÿåw|An~ákž3õ¦ {"MÞ“ÂÀ›Hƒ©¢GöF[Tš£ rò,Ë1ªma"cT¾‘¼þ°ÞùùïÏñòñ-o¥AýÍ<¥¹Úò T`Μ9¾¾å®žòׄ^$·lüè•ñ"þÖUUëΩ]@ë`‰@Æ *øïmë'ÍËέq}ð¼€^gØþÑë Jã2_$‰¿CPU¼â§„Ê÷Æe¢çF¥RÕvªS6~ô"x sÌ¢ç£ÆOö#ô²ÃÆ^ /Ü•!„ЋéuŠe"„B5‚±L„B¨JJÆ2ׯ__{•A!„^t…³ÿT< !„z›c!„Baü!„ª d‚BU v™!„P•ˆp,&B!TËD!„ªoÌ"„BU‚]&B!T%ËD!„ªäéÄ2ãÝM{4ãÇ´³¼Õ=>¸ÿvø˜¾þ£\³!vâ[#k¼fíÃmwécMQ^ßxÂ=¬ƒçÿZi„B¨: 'ÌûsÖ4ïôàêBËÛ´##­šqegWÆp;0lòãäxK:K=Þ¶+®*+ìˆ Pg¿} ¬wðÓU‡um#ÃíÅî­[lÎp¾½{Ð÷‡ºõí§ðÎÒßš(Dšûq7ÉK¦4Õõø´:-ÂÝdŒñÎùÛnÛxÀýßçîIÒÖp?!„zí•;ÇìéïMÞ¨Üxþ¿ÖŽà9òƒníN9‰ß·@Lã˜ü­Ûšu—ü™÷Ù}Õ·þý÷¶šÖ¥¦¨\ƒëÚóœ)áazhHÌݸ³«“´ÄVX*=4¬çÃw ž3}Ñ·cê¨ÍkÇ7¼¿bð;‰ïÇ.i;¿g÷áþï¢ü6n´÷Úu1 ­åo|Ûçí×ǵ€3c;¬|kÛ†Hÿ‚đӻ_>6 .½×㛿í{·ñÿ¸ËB½žÊeF¹kð­fMüóú€ ‹GTºmýÊQ!±-Æš!55•6*9VŸššê?ê÷ØOËÙØ'7fccc­å•WwŸ4wìß$qÒÌ?€çMÀ3S§NµäNÿý¯À›ûÎÙwîÊèô!36M gTû–Þºdv3¹Â¾÷ä%m# z,üÌ])*(({x;‹‰„PªO{œK³Ù&–ÌNKN6kÓ ,Ÿœœ,”øJ„„@,Åq¨!„j¦ì³@í¿ßókD›IS· ]qi̲«o­¹ØÖQR¢˜PR端¾2æ¬Ùù_ÒW_}eIt¬?h º xLŸ6ζ|ÖÉ˵õûe»n¿wËLžÕŸ:=ùã?€ŸF È¢XÉþe+ë4î*ùÈ o¿ÀQig¯I¦3+<[}zµ_—mu=%Xœp·ÅÑ¿9[×ñ¯e»òùiú´½«–ÆËiýC“Z»té-;ÏqcŸÒ.C!ôz*·Ë¹gô®Eýº2Âä¬õºìË•ÿ¦&ÃÁ;S&š9 öíã…‰o¿ý¶ç¸ß¾ïf[R rmÒ¤ Ïh6iÒœE‚â\¾þ`ú#¥É¤:t9Ùõ­·" $zÍqöìèìÃÿXÓÕ÷ïk]™Q¬üÁã'YsF«†í~>|¼‹“D›2¯Í(ïӧ߀ó3:”÷IB¡J•ËdÍS†|áÙkéü^ö°µÿgƒ÷v½4Ðß¾X9ÔÇŒÆbiSg½k/$Îß;òæÔÙuuK/|Urý&徨¨ –³QQQ©2µ/^Æ1¨­Ã¾_¾¦ÒŒùÒÏ>;%x££BXØC¦íúéÓ3É\ö?ù¯p»¿›È5þ ‹SÉ'•B¡ÿE±9fm_ož9ä‚9äÈâ¾–ÄIÜÙZZæ**yAh2Ñ<ÏX¯× £H‘íêÔkÐÀYC8O[r-±LPD]ºØJQ(àÖ“X&­¿º;Ý­E 7ZÏž¿gߢE(l_wÉË ~ÿçï¬éÕùßµû¦zÛYb™I‡Þ›wØià –Í™ÌB¹´ðsYc™Osÿ!„z XúŽbã2­¯ó¯þ¶.Q:}ýÚgë5œü›]¿^þÍçkï­žÕÊvEwï$4éĺøÒï¾–cHüséB'©Y{ˆÖXfæßOMu,¯ZÚ„lAŒL.—‹Á- (M¢@ädy-±wc„Äý”|ÚS&$xCAÖ¡œ¬Ñv ¹\. T·6®wñîéthÙÒC…ë èªüþûï ë®Z‚ã2BU[±L+÷–³NŸžUrÈØ“‘¥ oÿhêîǪ°YS":vTèÔÉòÖ“xðjQy·£Þ›ÔÊqùŒ ’‡ †¬¼ïÖy:ÈRàaf¿Ý ÆwÑ“ /Û;‡DMå©°dIüƒ‚ê•·fÁ%ñãòòB¡ÊNËóTŠ1 …¢XOM„B.Ž6™A"—û;m2™í½_ž1š…\Xñv9ÚDñ¹¤ü5›I3!­`Ó!„P ¶ýc¹±Ì#¢ôz’¤Ÿ¼£H¦âuPEe‹¯ÊƩʊUºi„B¨¤Šb™!„²²ôx—!„ªì2B¡*yú±ÌWÀÞ}j» ÏÕÀýj» /lÈ Ãkc™åjѼY»víj»ÏI||<÷ªÀV¬^ÆRi±„„l Pñ¸L„B¯<_ßJ~Ò§ã.»L„zMaX]ËDxÜQ°U¼ªx”±1À‹ËTßÞíØ=ÜÅšrkËFuÔ°Îî²ç_™×Óó>î<£Rk]\]‰ò‹`«¨uÏ­UäžÙvÖ9zH˜K¥%yθêï]S&³¦Ä=ؽ‹g©Š@Ud{”u:ÝôéÓÿøã‡ Š=fí™mG¼Æ /6¯ê-kÔ}Ƕ“*sO_IÙ“ÁqtÎÊ¿wOž6­’¹âj¤zã2{õèU–Q*XŠ¥RFŽ™af+(sìãÏW<ÒÚ¦lZüõQƒ¹ÌÂÆìÿÎeËÌ*“þñ©Óy¦ª—¯ÏPÿc±?«ZjÖ*(Íé°°°<š«  ¶Š*«ºx¦`B̬®ÿüVÿ/OTP8íà«/ä–NW'Ìî2øpá뻿 ž°ƒgõ ¿ý‘çŒýZDÄëÌÀ™Þž“T΄^UlO·1Ô–ÿý°²,;qâÄ'NLœ8‘e+:cWÑþ*(oY2Ï÷¿^+‘xyÙ’C*SÊ®¯úŽüÎÈñe SÚ7ß|ÃTtj)£aT« TµË|ð áÓŸ—ýQܲŸ?}ðàaKñŒþìÙ³F¶ì<«_tW=§‡ÏïÌœþÄ¿jÓõ¯?°¼ž»à?kaÖœ1½ÿ'”\׿Ѿ}ûI“J¬¥Rztìо}û,š¡Ü0{À»¹ïÂ*È<³a@›Æ.N.~¡mÞþxCy«« Ø‹™UÃÝñDÍZE¥°UÔnV w‡ÔC³ãn1MíDÐø­)Ùë'þy[m[€g41O|s"3yógÖ·&Ý”)S8V£Tžî¦œúøˆÚ9qgÔÔÎAB*÷žmÊøeÜÒ­¢}ûö:v4bÜ{/Ørª¨}>­Æð,q­š5mb£iØÖ¼šñÒæÏŸqqqóçÏ*õîÓ§OïÞ½{öìÙ£GîÝ»wëÖ­k×®póæÍŠ× KŒÿ÷‰»F&íLìC×Aµñë÷ÿ?{gÅöð3ÛC7Š”bb‚¢¢bw+vûT, ìnÁÆînAúlŸ¤’"%¹³9óûcqYv—eAŒ÷ó~?~Þ›[çž™9;‡¹çÞ;·%¿å‚Øûe¸tý\¹$›w1ôC¡T ¬a|8àÝ¥Ï&¨¦ T#–yrïnmz…±4J\ ”ªV"øº˜[H×Е«P˜¼µP·K†X0p ¤€ä§ßùgÛˆ¡’ L¼¾Tþß+F¤÷ñwæAe¥çÑ4Â7®*(ëö?^šŸRbHä¼()%6´;ípß`O[}¼0wϧQÛ}D$Ø8‡EÏvkç>?âÍ ºš²5ܯã¶ÇñŽ»ÀÖ¥¾ÅIMãÎ;ÀÖë´ÞÏFRSÄs)ãØ['g‹ŽéZ-ÑÏž¸'ïÛPO*pÏö7VÍ õ‚ã8›–®Nn9;cé3[N §Ÿãæso¯ `<8èF¨M·1Ïü²*þy«¢Úo[$Ñü{êXÅå=þ)üòÑ3ï#?°_SÆ×2ØVsf –#«øO[ÅåÅãR­FßèZŸñíö6upæ…VC¦ï¼yl©$ E± ¦N”{dçþÌ’¢„œÔ÷{×þ£¡]oîØ)SëhkHzsèÆÂqœ2Š‹‹u›Ô~dE 2š– ~ >ÝI¶õ84ÎŽÈ»Öo›{7VYéj11%VÁÀíºwï.ÕpÁì§}; 6³Õ?§F@mÃ…_IcèŽïÙU1>W³;.+AÍ»\3c`³Ù²ž’$IYª\2^?::ˆ/7;ô9;mä-Œ$) NEÞŠŸ¿|­•`4ÀfÒôìÆ¯_ï•ð0îÎ&GÒ‹œa°†•y@ul z±Ìƒ‡¸4kl_‘ÆÍ\Ú«XùâÎ;ñÆ^(é,³m#­Vyï‘Íäåß›’ÊÐdˆ¸±[ýo@ðÅó]‡/¸tnûСCûu3¸|½ü3›YowÒfJsD\ÚšþVß•æ§ì .Ò[×¶‚WfézŒÐ/Ýð,G’Ì{½gîܹ‘EÊ£bŠPâ’u1¹k&JsL·™3ÅË‚ÓÔ¬ö;©y*CM«àq¹¥2”~€»Ÿre3¹Ü²X²Š_^¤æEPÊ“½ãç3N\YÁ¨0ô€Í½t³KÑ•Î㣳¸€Ñµü–-t\ºa×®]>îulFúíÚµký’æ-YfÌw 4fY³f90b?µöüJH±fƒaCê. ۭͨ¥­­­™f¢†I_[[[& Ì*äÐ4owÜ¿Gf¸ïßÅøncøÑðóžrô:+úËšÝñŸ¢ò7 +"—_I#šŽŽŽŽŽÎ…¹[;¯Û§ÃÀ†7³svwwww÷Ï(¹>²—»»{û6ö]–¾Ô6lÙwHW³Èñ:+cà”èz=†öin ©¬Â0äl@UüU%â%õ0Ku];·Àžk·p "âög”ì`)W­Ý²£zMÜWD_ãb"É9?u ¦Ï!7.ðhøÂ9}àAÈmÉ@Ÿˆˆh*mþvwlNs+èV"j¾`Jޣ߻ÒA’¨Éc¿u=6ÐäCY}ÛÏônu $õá¥KÑ-–lpÕQQ„_õUH6mc(ÍÁèZnºìs`xuªñ½Û"u®€"ÕµŠÑ‹–È¥† =y•ÍËn½bßPņÈ*~y‘:W@ ”ðüÚ ¾ÇãmíÌŸ©X®ëºo|ì‚án=Âß>°á0ˆœ‹CÆŸ"##=b¡÷e6Ì9}ÅS¡Qéëc§Çè Ú3¤ñ#×îð_4û0ãdª.Øîus"ÒÛÛJë+Z…"¦nc)êÖá¤Âö-áûŒáG“ÿ2“©Ñ%äÌîsçÎF}µißwÎŶZÌšY—¬}@hh¨êÞ===k¬9U9$©*pøùñÚ€Ôv¯=’&­K€w9j3/¸5ýpúÞJ+íäK&”yL¨ÛyæB~σgDJ¦,Ñ™&F.vß’ª CÖTPe,ÓôÈ‘#‡uýgÛÕEÚ‚¢¨Î/‡^YÉ—Ÿ0®¡§ËÑ¡„’/b~º¶‚¡Û̓C!Ë0ñÿ«é°™–Dm"ÿæê˜º{Fëm.â<E‰ ‚ \:z3iÀ/À.=IUz•ÉÕª!M Ä) 0íÃW/:üîÊ{1?eÑãÏ3´&ˆ·À'‚,ûËL«¥~é¡7ÑLºžJL¬ìd•@ ² AÅ\ÛáŒðø"5«ýÎEª¨¨¶UÈòâpb›µÉËfDåxµÖªð²Šß¡HBu­B,üò÷srßí`«Œ—)<‘ˆ?sÎŽmûhÓ>ž[u:~dø›óïêRB¢´$‡pÞ·ÏÞû°[µ¯§@Ñ—Œ)é]ˤÀªYïu‡µÿxaž©Ûp!˜ÌØrþÍú~Ñ+%l_Ÿ_êu%µ¾Ÿ¡ «J$:ô¦t +üX@ØkÁ÷Ã&7:·8cgxéþù;/-)I>¸|‚K‹÷Éñgé5ºãr½½½U÷ž””5½<d§Ü±Eɱ¼¼‰9mÖŒXÛ5àâ¥3°eît=:-ýKi±ßœ œÁMO$›ò% ?D„¥ñª˜ßËàXwr³Ãà‹(JÆ0dm@)êÆ2q\KŸA{´jÁ'6b˜Å“ë6Ý‹4lÞJ—Éþ*>èß83\òŠùaêŠ'7=*;þËÄq8LÙ†íè¾7uÕ{=ÜlàŽ žVa#i¥lœÃÂ0:Žã4€gQZ4ÉûD<†5–ª”ÊkÙH“,:†Ñ˜8ŽÿµÚÙcÑ&öœó)Á+…†CgØ•d0@µ}-1?µfÃñ ¼1|$*Ü•4¾XÛN[Íj Üà·-’Pƒ+S-«EXòrÉóÜcÇ;ŠÞ˜ÿ5ýøË˳+ˆEVñI¨ö•Á­nžhÔ½@AÂc–ŽÛð>½$…‘×\©£ƒkè™ÐEÏçÍóÿÖÒD#eç¼oo;½vCÅX¦ˆHËûò< àùóãwû š^Ÿ£ãÝC‚çú†Å=ùH…´7Ç¿­ÕS´ Àr§#(z!¦(ý†eÕ¾Ç~4­V_ÿ{–n‹¦’ÑEóíWÞ2m4íuα†5±.9áUîþ#¹&5»2,Ki,SÖkÊIæåÞ4bóÈmCWæÄfgY¦—ÒMšÞHƒqÿÍã”Ñ“'ÕÑÈxðiK6[ÒðCèÝð‚²˜Î»w)çÎÍ5™…q¯ùM;:”Çrô»õìæ †!Ë5l z{ÌvÞ¸g™¥¶ (¢C¯+#m¼Ùkµæú볚}8:r(nK­29Wÿ—Swdø`k¥BM6´5Y;÷‚©€1´4|&_Ç©ƒ›A!yá~y~]=7[É#óî[õÿrÚ—V\¼íM»U[”öËÏáÓYUl¥X,-}&ííË<°)‹ÎRdiÈW¢«±šÕXZ–¿mF«á«.jZ…,—ÌÒí´ÅE›I®=gÓÂeú™NûG5//FVñ}§UHˆ ŒÖkä+M¦s5\4ʯŒŽÛåË""¢d›`tŽk{'JT´¬¢(Œ®ekk›g=~¥c“Üûßö\9©±6ëµoÙ"çú-טˬm¯Ì*dùv ÃèÓ,u$Éï1† Ǥ~ “ò$mî¡Ë‰ÿ;‡Õº&Öõ35Wá/+‹e2µÞ2ÙáÂ1m«Ë7&¯8•ÁåƒO‚àr¹@ðËÿ±%`Ä·ãÁmzìØ3ÑT3fc×™Ù‹w¶•®Ú0Ô´u§ÿü½ÉoÁ‚‹—‘$|³9ý`ÌÆ˜uÇ&H«é7i¾úÜ2;/ôð÷Û¸^Õwd>%%JHúôE6¿©«ðßBÅú4¦éÖîæ'–<øEsk ¥2 c ÙúMTtª Œµ«C˜o'éw|³„´Õ},Õ­öÕðš|CM«òpÛˆ¥Á¢ƒ{izøêú'~}ž|©XSdÿ!«añ“©?ÍÙå.Íù·D¨iUÑ“Â#½C¿qÿîµQ£g`t'''šÌì!:Ël@?÷»A©½–Ž4hàY¾çª úy[¯¹5“ÀØi™'peV!¥0ñá¨ù¡æ^›¿Íù.cøÁðócC“‹¥I1ïãýžµ‹q ïx%,Y²¤Þ7–,YRYµj!u–Šþ²2—Ig[Íëe-9ÆMݶ.p€¿ïÞ Š)$‡ß zôæ«bC‘ð²Tä¦Ã–×ATñæ“äXµa¨ij­ËTûÅ+§³¹iÉ÷#^¾"ÀÐÿè0Ç>Þ–½÷vÕ§IºN•#âñ <– @3ðêdP^/$IqyÔjΪµEßö=`±œW.²—Öl4Ê*ãX1§,”+S)”¶X<)³ÃrËÞGtE|B<ž*F­ÂïfÚÌm ©üåïÕ³ýßO8x¢»žº[¯õ ܲÂa\÷¥v;§{¼¹?sìÉÖS޵×aÀª=Ÿ3û]˜ªºÚo[ô*oŠû®õ­(qÁý+|÷ů9Ëž^àd[õ¿q<·ë˜þ)¯}ÖúM¶üzAVñßµ q š í¶|¨qùã%ô+ÏÆ¢ÂÓH>†q/^,I‰ùéÇÏF@;wWËR,šà;ëìÚÎ4Ó/i6/iA‰K× Ä¸®{ÜvÏøÕ­ã$Ë–­BÄýpóæMJÌÏÎLOþðäüõ(#ç1ç·÷‘êóÆðCy´sáà½éÛx¹9BöÛ>££îû[CMï¸,Ò+°lÙ²„„„èèh—eË–ÕʺL@ ™æ#u“†É¹L¥’y<‘4üLŒ]°¤µóò£ëñ3,µÐþxõÝ´×|¹†á›§ë8,µ!Aù"Š—U roŒêï÷> C.–)kJQ3–Ium“FhΘ’aoßЊ@ÃqüÃã³ fï?gYöUß~3ÿ™=yl/{ÙYåo6Ì;’ÃР3Mlô4qšòýDÙLÎÆ9,!7vÓ¦M åÉ›bCF/^n‡3lÎ(]·¬ˆ1Õ”I3«úDÙ¨4n=aëâbÓQpœ ”¶iƒ ´5qœI1?åèþžž pœ,Œ((( XõGçµ,E…NðÙë0“eÖÈsü®ÛIŠJòòòØÜ*«ý¶E’üê*ªg‰×wÿµÚ?‰Þtû­Ð!Í*l%jÙñ¯È›æS'ùöë•õoôf‰• «øoZɼvlׯíŸlLJŸ˜Ä Þø{fUÏ„HÇûÔ3Ü‹o•iÅ“Þ_J\ŒMÒéóÇQ4í¼gùt–æ75ðŽ]»%¼}öî%ÓËö½kñ×NÌÚ9mÆ+ãñ‘›ÇÐŽ֌èêÑÿÕá+{uYŠVa¦÷nÛ¶wi`\§n½†;άìçÞD:ÂöýÆðCé¶öö9í¹»6Îñ‘@j›¶vùfƒƒšÞqYdÏñرc’=fµ´äg-×ìRDFFVYG©d‡! ?ÓØÇ™, l¼¤˜àå ht¶´áç÷Çöl9þÁ¡Ûc%™šŒ¼{ÁO_Ð0~Iì½S¸a/I¾¼a˜Z6¨o&)’³ªbêíí­4œ›úY³^œŽ¿ ¬I‡ã«Û$mΰZ¼vÛ¨öf¤(÷žíÇCÄ×B6kÈøÅìè³'§pù”y˾ú6«L‰w;ºÏÊÞ² ¥‰ëÉmëÇ(­ãÚw€ä O n}wÔµÓ¬*“¦”ÄÓƒGÞþÏ©Áê7‰‹‹SúýXR@ÐXU›ŽŠj¿a‘šŸ™•£ZVñõÝñe·ëŽ4¨dûlR˜‘©ÕѪ쇊¬â—ÕÌ* ãµz~¬ÏÂ9ÞÝ5h)ÊõñYQTXÄPvî³ÖͨxõH¾…uó“'JR”(¡ßÑOƒàøøÁ§Sr¸Z§Ç×÷·€ƒ#]w}Ô4|â’Yƒ4éÔ‹ñY7§7œvdùp&i^´}沑»wI¶J¨–UÔ¢1üPHA)ÆÒTúòQ³;®þ'¦k`  Æ~xààà ˜Yœ¶ÙiþáÉlÚØfÑ?qŽÚÌ¿—ÏÍœ³1Þ»û¥úÈC—¶4€w{õÞÙoĨy¾Ó¬¾íBPšqËgñÉÌü!‰é™wŸ±nâ·••†jõU»ÌŠˆ¹\1S”EÓ±¬•­âI!O,ƒäòHÊÝ»^^X—NþŸ_m[¿Òy9R’"z9M\u×¥:K¬~ÉïáWQ³‡cEUü¿Qc«QÀPñ…šŠp¹„††Z¯/""ŽVLª˜Š¡¾UüÉÆð£]fÍ¡„\¦3€Ïå254*»Ó”¸¤4åöìTRèÒdýcµ¿—‰a bCm®Xâ"ÀÔé]Ãå̶g·ãr%Ë¦Ô ûݱî{N´dŠ“%V¿'ßqUüÿQã‹#¿·r0Lý^4„ÕÒGm«øÃá·ý^&P¶¤Ãøªz§3€W 唆š6ð»|/³ZXwó\ú¸ãŒy?J—ÿ~ÿû®d?‚?Ä*þpc|½D’ÝþëÆ ‹¢a¨iÕ[—‰@ ˆÿ3¾g?¼?ä2•#ÙMYBÊÿ‡1ÄÅÅýjþcT;–ù'`i©îD’ÿÐ}Wd)Èþ@þ“±L@ ~>Õû^&@ 8Èe"¡å±Ì“'OþZUø=‘øÊ²ÝÌÌ~Óß ñË)ÛýG6@ ¢2P,@ µ` 7@¨­ÅD BÐÀ,@ j\&@ jb™@¨Še"¡h`@ µø­]&)üràÀqUÕ>½¼ÿºD$MÆ]»óôÓÔ @ "XbbâÏì/ó}Œ°AS+6]’ÜÐshw:÷ÁÂk®çç;ÈU–¼lÜrhl|"[¥g¿ë×cmÚðÈc€"yup¢Í½0ÌîÇœ@ þPÊö˜ýi¬u´Ï:ÿt¯­ž$icaî7Ö6ÒÕÿßyóBbB±Äwcò¥•Eü lݱ“•K0léÕ¥¡|~¸À{ý H’¢aâø„O Ú‰Åb:½Ì%·Þxf³£ÉO:7@ü_ÃPQ–râr|\¦×”™ö¸ªVÕ¥áŸÝ3ß]?¼C“Ž%>Øáw¬îˆ^æÒÒI“&Ž•&ÓnžÍžÙBâ2ëzlÛ¢ùLHQ’"± }Ȉùëׯ—VÆh,'ä/QK¨r~¼Üôs¤IŠâ^¾ÜvÂôtCŠrþ€T¾økô£ÐOšeùïbØëfk¦kXXaÚÖcV¯ö¨LNØË›;d’Á·nb²L=Q!Pä7¤¥4†Ž“cËh‹@ „"ªÖeš ž·qpyRXòìòåດ€ ªœ‘#°$nÇŽð¹X 8±o«làTDÁ…½8Æ­W¶¶wÐhè5nôhbïÅïó…·Ú¼¾û î¶‚ ļg/Eš˜[HKIQ.XYYÉ6 t2²>‡^]…£±Lnö醎+ÓR“¤EŠä=‹¬²a³Žë0Ë&ðTˆe’¼z ž|Lµ`Upi‚¼¯1P¢¼ÖNž¡Ï^20 ³ô õ˜’:"^Ò±Sa2ȼŒTƒzÖ ÊÄo¿D IDATÿL4nhö>¹´‰t3¾§6G’ñgRæKBCC¥YÞÞÞJ?Ÿ)"âélk™‰8@Šò,XPeŸôÔç(æ‹…ÙQ%ÿ ˆ±¾ìügí¢q¤ÀÐØØ„)?e–ÁiÐÛöì¼ýoŠKй…yÙ|M{;ëîÝçxÛ?kâzvÃ’Ž½\çÛÜøËÓÌÌÌNžÝ4µuvŽ0œ0½[=(y'â¾;wãÓ€MÜ»¬•¦×bÈhÈÌ”ž@ ê#ûÆU!–™””¤¢YÞ¿ ¼ÝwîI;hÛ^¾]"$-üŠnƒ±Š_ø?3n¿… RÈ€Žž]u¾­2aëiKêy÷×m–dþ›Wh}Ó•$1 #sŠÚ¶1Š t‘êSC B×SaYÙã³§O‹¿­ß–I‰Ó/_¾ :¶Ýû¹ÔdýFOÉ%.Þºþuƒûä6¹%Eù+C3²é«bV;ir Gÿþг¸ù°õkKJJ‹ ^ì~JǼ®1#'û‹õ¼u£^Í{ôHYxEÍ@§‰£“uýúÖ¦šäÄ9Z ÛÔaRÄIÏQ žÙ6µæz"ñJ]æ©sçP—ü¼×kæÎ¼žÙêfð¹—Çìèý£÷%ø=:ßÀJûª8`á¼á°à¯¹æÆú‹A±HÈçóg­^_‡IÛpú¬˜àÑqΓ™i­ºw󰥇ݱkÇ1×îM^¾~rþBê«'hÛ<@Ôb™?çÛ™"ŠØ¿¿o„>%$¡lQÔÅË^ë® 2aQ¿ÇäKÝF<ˆˆû˜š“WÀå•rÅ$F£³ñúº">!øppð ©,oÐô'ë»N¹íÖ½Çâ³ám-5ïî÷ÙtÎ{Í<ôAP@|'WR¶.344´²µ%?²ºW!…<.°´˜4JHaL¬ê&@¨‰¬üÝÖøWûcd4&G«ìùK@ü@~ëïe"ñûð b™@ü·¨b]&@  U¬ËDÈqþÂ¥_­@ ~Ç Qš\¦º´jéàââò«µ@ Ä%::º²"ËD ¢ŠÞÅ2P‚¢7”ä E&@¨Åïî2O=’ÂÉÏ’¿Z@üÑü‚X¦°äÅÔ9GT§rà†5BÏN÷¦ºÞèá…ÅœŠ.žøþ†tv®[éxriZä+ÜÑÕˆó:WWLiÐåö"?rÉúòóª(c°• &Îú1 *§43ä9éÞÑ\S’¬•³JðµP¤¯§QÝÞÕ¡V4”+*þúf‡.&¸ÒäOÓ H¾c3ÐÆUÄïDe±LŽãÒA[¼""Pƒ,zaDD¤š•ÍXôl³ÙÄSÄ×&žúTQN¾Ï• ¯‰ãxܦ±]øWÌÐÔ.ê[Ìd—Æ8Ž+Œk¼²®SKÛ&Ʀýž–Íé?`Ö‘8ٜ̈S}Û6Ñ×կרíßSå/Ë”àäÊ©MëéèšÙ õÙöYPVH„N|>‡ ?àÕZÌOóî8›¯A¯³H>´e¡³]={ǵ²M”ž…lïêP+*-¢k”Nê8ñË·Ñ ¹äOÐ*íþ¡þÎMôu ô ê´í>),¹X®ÄO@ñá/9VµÈdH»VoK…ŠùÖ½Fì­˜/*ÎchÖXŧ÷BrX’zrõâY#¼ÁaõX//\þžjÝsZkŸC/‚{–~0`BÐ ßÜnÌlÿ×eÆáÓ·»vl’þ2b™··GºQÜ¥q¥™§ZzGM<+9»ÒéšÅ³‡³kQsx¼°oÚ°ÓÝ 8µr óšw ñèâél©‘œZÞKeg!í]UkEÃÊŠ4Lû÷ZÝgù“6µ¹äÖª0)Ðq OgŸM· ÖÌúûðNßíû¼Ky`ÎV÷ ñóQå2ƒÞÅ‹)¹¯Lóùrõ+‹éãÝ;»^|6ÕN·0%O×ÊðÕæ)–ìaŽúì5ªS]U£vOî†|àÊ{h!@Fô›XmxÏÄù’|7vÚù´co¤5霞žžŠb­Lj95qÑ3[N­-B%¾†d†“[10£¿êiÝø'wV-1?}lŸƒ'ž=fÉ ²ãæso¯ `<8èF¨M·1Ïü²´YfÝ'Ì6¤™>è¹ôØØÁ~ÀZ€qšfcŽ ˆðZ˜£ñ%>(jm%*ÔaiÌè)—ÓZÕÖYèÙnÌIßÁÀàéìȳ2.SéYÈö®µ¢¡Š"ç•›ã­GÆ­L´Ç —”ròPjëÉnzœZÔ*|ávV³ÅçÖüÐxÐv'ÛCÆÎë?ío¤¯æÅA ?ŸjÇ2¯Ee[o6“«I‰‹·ï˶×Ûœ•Ÿq¡U§íÑ1áZ¹V!<|`¿ÿf-—¾Îzðx Dg¼о¬)ë6+v÷dúËu6£ý6—S2#|ÀhL3†ˆ D S@‰”ëÏj7D¯dmdÚu ÿÍMg’ûû­k¯Sóð!®MРŤ!ƒ–Å'Ùz,8:®{ó÷Ûé–‹¥Ä%ëbrŽL”æ˜:o3gžYœvox§~Óœdd¦E|fët€ÒϧDÕõw1-šìî7æð½Y’ ŸÂ®>x#>•Û¼ƒkß©>=mu$ù9/¯¬Ü}ñ}ÜSû&ƒg®âh*É/Œ¿³ÐooLj‘M³–c}×t·Ó€Ï– M¦¹è°jë,c+ýKDéYÈöþñÊšÍaÂí»×hÒ0H8³b׋º»wL—V¿†w‡˜ªPž­×uœAéòè/;×¹¤”ÏO#I¾¸vï~ÿ+±m¹å]â\ÿû@ü"jËT„E˹’KŒv4“Íd3Š·Žï¬;ûââ®8ŽÔæ©™·úy¡M÷õuô‰€ÆaSwòùc­ ËpXp|Nß.£܋ɓÊá0…)IM˲ò2ËQ¤¨IBà‡º{—+FÇHAö¿2¤|¥¤¥;˜¼;,9eG]½z5˜Už¬²×Ž£ßÍK›µýâ³[ûŽæ2f·2L¼0åÉÆµÍd«ñ‹£¾ ɦmÊ«1º–›.;ûqŽ4'þIÔ[W¶ÌÕg/wSÐ.Ь;úÉÙÕ š¸Yv!õ—)×g4뻸ĠÕÒ óìÙ±#\ºFäñ ãþâ†3 õZ.ß±¼¥~Ñì.†¤P¢~nÞ3NœÜ= Ì™ºAD¼ÞcÖ­o­Ÿ…"JÏB¶wËÞc?^ÛÓ{C4¹÷ºÌð¯?|°Üîï×°Jå»›¾Ø#-•K*¥v®Æ0Ó,ûcƒd.8QˬÇV;%ã7âç£øð—Wo¬òíÞÖ3{É¢ ÞOè›ÇãÕ]ê.Í\0ÅÞ78™îázíü½Fºì’F»†²}aŒ÷.ó™5Èåä`Ÿ-ëf7ÐbŠŸøøì€¢ø÷¹¦¶6º,«Î9‡’MÁò#®o?£ dsˆüÓ§‡K“vcOœžÑHrlØÖ°t_,@°ê{9£oµNZûXøéÙ¾þË^Øl8åÂ{à¼Añ¢Çå.\ ç4ìºyÇ|3d@¼BtÊg„ÇI“—Ö,=ÿ1³HwÆêõcš•Ÿ‘Çî“ÒcŠ$úM<íävÉ×zyôhVç’7pä~‡¥Î,v€.Î]zÔót3`Uö?aÖ³bÁ`Wû†zö ý‡Ì,õ*ƒk8ñÛC¼ö΢2dÏB®w:ÛêÂýM \úž•ðfØxë¿®.hkL ó’s%˜æ6šß©a•ʵ7*Ýñ ‡\’}}ö2A’ù‘'&_½øÇ€lÝF-ìujñºå¾º:zØÔMzÞ}¨-?ÿ@ü^TÃeŠJcÆÄ ºv\’|Ø¿qýñgØÚ úl•©ÙxÖ›»4€èUç¬ÈI£³Ígo»ÔÀÙ9sWók±«[¿[HH7éÔüˆÏÑË}­€å3 cJ·:hVP5™'Ò0¯Õ¬;ýéå3e4Ì5ļdõÏTtízž¸Ú(qÑ”6¾ï=ͽ™´/é…¡[ÖDE, 0ƒ 1M~ЪӠ]±Å×z™j\Þe75Ä£Y³æk;íö „½]XZúLÚÛ—y`S¦'E–†|%¸Ë Ñmàì´Ú¨þìûóºêÉ/à#E`Èßw‚怳<ŸÆÐ€,úl¼‘4"ôÐñã“;Ú7™tìîŽ!PMÏþÂûAgQ%Š½ë™™ŠxQãz:V+Š‹ý$E­ÂûYÍ4diYªVž÷…Gg›K{‘&™Z-÷ïß/É<uƒÜ¼kœ©’…¤ßsÝBVö}‚wúi\FºÕ½’â‡ò]±L6£pݨޗRìÎ^^¡õ-ÓÀ²ÿ¢áš8޳é4KÉjM6³xý˜–ãt5Õ-Ïå°dûÒÔ6·ÓÓ’mÅ¢at‡Ã¤>'Æ„‡çÙÑÿÝÎÍB&Çñ­ŽL6Žã-tÙ%Iüò&t 0FeúóŠ9••ª‰ÒËúùáªÅY‡ÛÀW®ˆmƆ>)ÊÀX»:Ô‰Y~DZ?ýŽo–¶º%)ør|ÓŠDB$-¢( ˜Ê^5p£ÚtZàÃ,iNáûˆ8è² ßÖÖY(½&*ë½$ýZ×ÙÁ»¢ž4x³yè>I‘ÆøV~-j®aUÊİ Ê'—É%Uó=×-3Ôwø¾ìÛo‚¿D ~Cþ’ãª6Ì£ág¶uwìp[ärõñÙfšÕÈ-N‰˜Ö£S”õìk+º©S?#öÅ÷l[âKéëUƒ7k?gý¡·y&Žk{i=±5JDÄ>¹´_?#ø55‰¸Ÿi7¹lT3+Ò¯ÿþ·¿*yÓª.‚â烦¾¹{¼lJd›~– ‚ŠÅâÇGÂô”dö Ü¢—Ð}éñ÷iYê;ædë)ÇÚë°(]Ý¿·£ÇÌ«÷¢³ ÞÜÕk¹~“iu•ìCcÞXä4¡ïÊ=ç?¼ »èîÖgóÝ ÓøÆ‚6Aã†î¹V$(|p.`èØ›­}nÔcÑù¼Úu]}àzžrùeÆ¢@›i¶©×£jë,ª{Åd{'Ey“<¦Xͺ:¹Y³s·ýîúv=“¬<8úªV><8£Ñìò¥JrI|§VsƲè7*3ìö5î=Ï«ÎåD ?›*\`ü‰1·}33`Ù´^¬êÄZ²"WvœpwÔÿ½ã<ÕÜÇöß+÷è7iÒ¤›ßvŸæ-Z5³‘ö¸ùæÞŽÎ£†¾1Ö±™§ÇÀÀ¢÷´Ò˾'˜2iÀ1µ´±4P*VÌO üÌßÓµ,˜G Šóóóùd-ÌçßÞ×{Ê­héÚs¿³yYXn¶mÚéÈ•’L-‹AQá…|öºÌd™5ò¿ëĶA@gÕ»ò6råÜÅsFtËåŠØ:Æm{M½·kieרÅïîöœå[go]DX7oÛ{Cè–ÞÐ~åý£š>Ëô\¬mh=Ð÷ØÎùnÀÖs9Ü~åο¶.ÏàÔ¹7Âg€Õ ŸÒ…s? fÔeѾÿ,dÁM¬ؘ¨¾b²½ÿ³szr~V»€Qëù—¦‡¯š¶~ÐÍsùN U‰yý3yÇ{Z(MJé¸=ôä÷^øN­¾Öµ¦?;²êY™^G»9Ö|3ñ£Á **ÊÛÛ;))I®˜"yE[·ª‰|i×#톌hZ¾ ›—&•²lu˜Š•Åü”Sç"Æ]-E þ½½tãõAkwt±Ò’äœÕ>tØù£}«L:?jüýÁ ¨VwФ¦¦Ê}bº0>W·¡‘\5~±€­­äõ‹4–òÑ]nQ©†Žº®ò¸"ŽÂ¦À/á³µ”¼¡ ŠKYÚ„ên4!ôÆ0I²¶ÎBMäzW‡ÚÒP±(îH÷>·¼ã¯Ršü9Z!ˆßèèhKËrÏ"뱌Œ  õööÎÌÌüe:V^^X—NþŸ_m[¿R¯™’ÑËi⪨».ß±q„¸¸89—ù…ȽëÔjSHb¨Å¯Ø›í×ö.‹ˆHpµ¶%6Ú]—­˜D ,ÑÑÑöööÒ¤¬¬µ=ä~>ÃÎW^ÝùT"ñúJÉ{¨Wà…ï÷—ÿOàFÝï}v3¹xZã_°pþ×ö.KaÜçB¤R.‰@ Šü‡ß22ÿ7o™Pª·ÌŸÿ½L@ ~g*[—É]qXÙêC„„èèè_­@ ~8ŠÞP’óŽeþddßÓñ¢æšI@ þtP,@ ˆ*@±L@ ÔBâÑÀ,@ j\&@ jb™@TŠe"¡h]fõ8áÒ¯V@üA 6äW«€¹LuiÕÒí1‹@ ~h¯±ßËD ˆßô@þ­@±Lø}Aäß ´.@ þ\Š„TÙAòçOü²ãÒŒ/)ÅâÚíèNXl–Jœ'¦KÃý[$¦€û%/¥PÝ®I1÷ê½·dmª©ê¹L’Ï%DÕ’KŠ <\ñƒùšð|ʪD¥¥y<2þÂÃK_D~1—„÷gÂŽg ”6¡Äü5xÄÝŸ!];n\yúš+N{tî–g§yö“!@â•þÏŠd;ÌɯÔï‚’£—þQæ‚Ëá¤ÅT.A 7'ãU‘º®Z­XfΛI^ó:½x0JM¡ &Ò×®Ûàí­ª ñ%ü éì\·lðS8«X…L#( œ¥i‘¯pGW#ŽúË „B`2e«#ªP‚¯…"}=*j‰øƒŠ~~‘š7¨ T!ù"ŒÍÀ”” ßC•±ÌuëÖU)ÄÏÏO1SÈÍ[½ûý˜ýãïÞ=nêÖ¤Ä<"rÏ­ü™ý³¿šj‹”výòÑ›Æ|ŠGPÇ¥aîòЋ­ô1gU©ƒ>ƒ–YÂíØÖ­ýãkËn›¯é¬/[JÅç…ñÅ$)ä}Nÿœœ–ŸõäMzÇt“¯» €’ÏÏRùå­„Åp÷a,Mæ§§ceÞ¦N™>¤¨tˆH/ß>AO¸úÀÿ])`MO_«Ž‘vã–véHj ÈÒëlYîª'ï€* ¹&4Ç¥#æ¸æ¸qãøL‡MŒùñÀÂ1òŒ½]HJê^Ù½k« Ûü%ÞZ‘]»¯He³èù>CV‚¾&ŽãÙ¡û†{¹uiÑjò¦ ÙþãON]q%]r¬©'\4Ô·˜É–WR™@ qwŒÜ»uÓfM5õè3þPpœš¢”¢xÓc£mYèlWÏÞq­Š qªoÛ&úºúõµà{ŠDE?«HͤBÒîêïÜD_Ç@Ï NÛî“Â’‹kÜ ¡ˆ:%WW׎;zxxtéÒÅÓÓ³[·n^^^={öìÕ«WïÞ½ !!A®ƒ*Ú¸!ÌnhïNZ8›I£³8lFçà, cr8ÿ”Šï†-Ù~oÉö{ Pþd3Å>w˜à"yÂêZmcunoT)‹#+<9þËË÷òÿÄõáMÚãéÖ®ö®ÚEQ¯sqÇ9ìÇÏS?Oå“ðêUZÔ›¯l:íSÈà §^=I(Ò®g1oÁsë½r>—288Žã¥ñ±ÇnÎøR,ù÷9úy6ýœ],Íyôüj)Õ$ñÆ£¼v]\ µp§•…‚º3Fu˜6¢m7'KCÿÄÁà…‡^I”×3m¸°EÉúbÕÿ²«§êŽQâÈÈHUöêkÑkb÷ȉç—­ó0“äÌ=¼+sËÆõÌ…‚òW`RÄ Yy –±ô8zŨŒ:é³)QÁÐ9Ón¼ašÖ٥ߡé='×Ñ€¢Ä³SoÚE5*SפçÞÎ[Gnxº¢­Re¥%És{/¿öiªõ+Üœ4ŠÃî_[7·÷›œÛG¦;T)J æ5ïâÑÅÓÙR#9µÒjEOµî9­µÏ¡Á=K?„N0¡ è…o~t‘š7¨Æw¹0)Ðq OgŸM· ÖÌúûðNßíû¼Ky`Φװ3¢úÐh4 äÿ•€a†UúÂDcâMõáD›:ÿÊ$vNLÜßÂô¨÷4®¸ná{B³ÁÆ)-ÂvÞâNèaÇ.Ü=Â(ȉËM6e@>ƒ%©@%§å€ ==—«&6½¼vt/ ‹Vm»yâÀC:Æ&3¯ì¼ž'<+mÈÏÛY¼|§QùY³tÚ4“¶m:Ü+kÁÊÛ ÷›mû·Í˜–Þ˜9³Š`%–‘‘¡¡¡ÞÞÞ™™™ I~= ›WŸÒàÝXYžï£Æ~‰žìµ©ß«½@XüܶŬĤ'Ò1OQqbLBÑ7Ó sóÆ©0ÝÆ ¾yh7¶e“¾ÇÞ~pÒf¹—í×'|ÅÀà˜k“ÛKî\êe)dŽs?÷APm¦T‚ ð¡}KŸûÿ>³åÈ{zY~v»qWÇÌii(­±yࢿ-^ógÓT‰ªŒ¸¸¸ ë2)¾Ø žÎnÕç¶WvâF¥­ö¹Z­ÉõïzI2+jšM·ó²²´Y¨è‡©yƒª r!×ÚÿõytZôrIRXòFÇØyÜ«Ìýô+‘…@Tƒèèè*?k¿lÙ2Ö­[7xøð!†a;v€ÈÈHŠ¢‚ƒƒ‡ æàà ØöÕé«ÇñëÚ‘)­÷ç€Ó`ÿ‚“yù5ÖT.ëUÆ2I>ðø$PB‚ 4N)øwAt€ÜØ@m«)"^ù¼ ì—ËNÊsmgÉJ¼cÇIQÖÓȺ¢H’áëFcš1D!â Y¤¸0»´TŸNËà‹8IÄÙYƒn8ׄ!"d§±Ú Ñ+Y™v C¹S’{ß1hºxн†ì9Î>6#ù¡ *ÿÍMg’ûû­k¯Sõ¸|»JgK‰KÖÅä:™(Í1uÞfÎ<³,8íîSTôãŠî o úÅ…ì]s((>½Ä¦™óü «ÛÖ©$ÒY¹þWbÛrË“¤8TÎE@ ª‡:ë2eß&=<<¤Çbqù|E9ʼn" F¬b½L-Òà”‹Ü{Q"¢ÞÜ:19‰âvãñÁˆB{KG(* iÛÞ+ã©ß²ë;6ö4cb)Hû•­€atÍFœÂ'¡ÄÁ·Xf©@P·[gŸ:yňÀ0º†µ•ñðÆýñú¶Cꃨ…ÛZ1 ”˜7eeȶÕté4:[G³Io'ûoPž~£&Òˆ) ä´¸uŠúx-¥ÐΊíì8»n~&¬ëUr¥ÕY—IÒ€ƒãÀ¦ÆÄqp§^xòå¯â1fZñGÞÚM\$ۄâk™Í8}º?ˆˆë†ÝOŸ>-)ºàÖ4„ÑVNüP·ó|IçxuÖÃV½;½aÁÅ|æG³¬;¾çLV„zZ+*=°ƒÉÌɸg}¹|Y”¸øl6·Ù¤®JJE‰²£®^ní·¹K­.„¯/ü IDATâG}’MÛ”¿ébt-7]ö‹Ç9|¯DTôãŠ`x÷%ùâÄ6“ÃFÎ]|h©õåƒ[=›u|‘m§:H¡Æ0ûö ™ËNÔ2ë±ÕN¯zBˆÊQý“ ‰}øð¡¬¿Œˆˆ Ñh$I*•#,ÍZðÊ€ 6ó}R·è8Í6v…Ïãì…ÆÍGï_•æ‰èÚõ´4€sRi~«ÖÍËÎR"Aþ†ÀófxjÑ0Høwpçðœ!¶¹ t4@Xš³ÿì+(ÍÌ/ÔÓ5Ó Ók'˜Á™8n+¯=EfeäI8}ø~Z–8À§áËø¹*víìqNù«­˜Fœ ù2µcRÌSS}}esvR źt¤'΢c€1ä®α aÀ/-Ë7¶ÇywKT\s¼f{Ìú,r:çæÈ³…œØe-W*æ|úô ļ Jr 9¢ Sxß~& F—½qÆÚ{ãàâUÖ¿±ö;tÛ‰÷¸ÛNòvX×›Çw^ Šä4è¸rÝÌ:̲¿ƒ Û–î‹è"ׯ¬@1?MDRm @%²¢¬ú^Îè[« ¤ à‚[v8#<¾ýÐ"¨J\ÜwÚÅö[žNm-»“MGoxûtm+R˜—œ+©ÆÔ0·±PþG±¹¯®Ž6õ_“žw_j«œq‡@Ô:—©˜O’$E)õ(ÉüÔ`H[·htÎô‘í½J´äüá]róAÎíqzjxÆú;±š&ec¹4ºÆ\ßî&æÅŸS¸Y§––’RÖ#`éУ¹»›Hr˜š–»ü, zå™›½»ntÒRÌc”žOä¹ÙrÊ b~þ¸×)C.Eµóê°¶©Ñ×÷w"ãL/ŸòröPhÆç†2.³4çíƒhÍ©ýË’{=”µLfö+û:CHr ˃zJò²H 4Mʪq ¤@Õ£C‚Z.“â—_úúÃö­qÜÜÖnC3MùæÜìSsçˆ_=EQ”«[§6mZ`¹Ù„ìÉ<‘†yùP˜¶çÞ“ž@‰‹}:¯Zqù~ÞÍé‹h9¾Úâ.©©a®!æ%+j(+ƪKÇ°ÂØBhc¢â¤*U‹0ðÆð‘¨ðçB_¬m§ÍÀ PÑ+‚Ê!òƒ’‘^ˆßÐe?µ<1™vë5¬mU’¹»eËÍ’L3÷›Iw»ª#!t÷¬~—.ÝcÑ`6r—ˆŸŽd²ì+&¸¹¹=|øPú–)‡¾ó\;8z«,™+¢œe¿R@ÖsuÉ}Óvt¥mïÖ®ç(M–ä‰8öU;3Ü„ø´pKÇòa:Û`óêÑf¬I3Ž5³•ÌïK»¾EùÛŽ†Â$¦ÄÛÙÝ¥I§6ÖZßV™°´Ê_XRU»"ä½}aØ@£²`œ HLcTýW²ªX&‘‹ÆôŽ~þŽnâñ­”½Í§™×ª§K”«é{L˜ÖbÑt»£ ¦»ÎмàëibÔïÜêá Ç÷'jaÒúÆLÚ—ôB‚ЕÓ&tÕrú!WmÞ÷¤þÈS­­ìëÏw }ŒXí$©P˜AИ&ŠCórúr¹C ‘Ÿ[%¤@:Y©2QµKËAŸI{û2lÊΔ"KC¾ \YZ–¨èÇ©¸)¤à Œž<¥aùHì4Ç t¬V—-bÃhUO| YÙgô Þé§q=É[2ñýT÷éôèÑ#Lÿ‹ÅR—©TŽˆ¢„<—AÆð°©$_DQ‘×ÂŽ%ëù/°«Ç¢ s¾„üÄ‘³)ªhÄ ©ÀDBÌÒU¾ˆS@Rb[Š}ÎÌKËÓh7ÜòäÁè\GMœ¼ü~À€ÆÚtL‚ ¤ë2y²4çͦÿJ…dH ˜e?U’äï}]\@‹zÙ»›=GMeSJ51çÐ^,"š•5TŒe–|ù¼üxªqó¶Ö ™ÞùyL -×¼Šu™táËVî#Ú÷Ócš{ç;Jb™8ŽãFøÓ/týÖá0¹Å+&&­ði´oV¯ý ÍoŽÀf¾ïöå°Ç°Å|¯IÃ- ¤5[è²K’ørÍ‹^lüê0¼1ŽãOÌ©£ƒã¸–¾!)*’Öá's ×ÍÈ œ¿Ü=?vó¡gù²u’¯,rê4Jº³2Q•QÙuTÆÚÕ¡NÌò#ÒŒô;¾YBÚê>–¨èÇUn4ˆCÃ^áÍ:Ãõq³¶’è8ñ :­ŠwÆÌPßáû²o¿ BþñƒPç¡D§Óétzdd¤$~ > éÀ¬Ò¶ cr8üÏoÅz³#^>å1q}ë]~NŸî?.°n’~!Q,[Ÿ…ñö<ÒlêÒ¿žŽ4ó5Wll©#[­$·øõ»ô {ï®=·äæ¾[‰©%XÝ&n4r7ÜýÊ¢ó‚£þÅq i`lŽã8‡EÓ6m·mI_é¿Fšì²ÏÔû¹&ÍýÇšmÚò(*EÖ„Êд‹nnLA¹òtŒ–¾þýúýç°Èø“çMÙ.²m¼yzSi÷±\Ënu+»ÎÒËXé–N‡Wqï.nÖͱKê¶_?#øÙî„%¯ÇÍ{wyOÙnA=ë%¿["GŸ~¬g?HZ-â~¦Ý䦊ÚÊ ´|xÙ‡-£ÜœŠzõáý“Ð}›}û,¹Özð\“oC²¢²"ýú÷ïû+OQr X5°gïa%Ç=·èet_zü}ZÖßA§úŽ9ÙzÊ1ɼ\TôC‹*ƒÎ¶¸úW‹óÃl¼ö™g'¾šÓ¹íÿ˜êÞå9ãYô•vûš ÷žçUWñ=H–`J¼£$~)ù¯X,®,–)E,(Þ¹?ÑÝ»©i}£å†Îîm÷åIôŠPᪿÚne}uïÍÈó‹Ûܼ³ÝŠÃ8÷à¨wÏÉí"Þ >`…e îØíežÞØ%{/OèLI׆`ŒÁ¾û»ô½¿~ÃÖqƒGÅÜ4cÑ-zO+]±ì‹p‚é·ÐíÞQ3¼ÏÞ1c•õØtþ!·¨!Í[øÛ4r÷?^æ2Åü”ÀÏü=]•LVH›¾ûvÛŽ[6;>qç²R1Ë¢a«¥!“z4W*ŠçççóÉš¬ÀM¬ØTš–äåå±Ë¦YkY Š /œà³×-`&ˬ‘çø]'¶ BE?¡HÅ ê´!찾ϪÓ×ÏgR¿q—þۃ淕( ùZךþìȪgªYxíæhÄÏ"88¸Æmé ÜÙýgc {}RÌõ¿”>cqßl \;ÍO»ÍbÒ $óßõ—zõöXéaÅÁ€dj~ùœ“œ(à‰ ×ÀžÎš܄ӌ¾N•tÇÖµXÚ)àbÂÜ™e3[Þ콺>™`âF–ß&КæuËã²sûÞ?MtõîãeÌ€úÎ-··m›‘ò¥8¿˜Çˆ…" Ã0¶†¾$(ÊÒ´žfíÿ¼du;mh8ÔëÀPU—"3:‚ÓÄ­µFÕ›®c‰‰‰åíí””¤´RÞÛ¿.sÈØù¡í_[—N É;ÖES6MLÁš NŠÄ@/Sƒ"Å1-³!¸P ¦—+ITC AIæü ïV®é:}Þ9Õ5/lï½xEÄØ=šV2ì*ëUîþSJ,Âèê/J¡¸\BC£Ò½°yya]:ù_|~µ«êy â%÷rš¸*ê®K%Ãnê ¬R”RäwÿA ˆ†:»ÿ T“ûò‰~³^fU<ç‹RcCˆúÃì+õVvÿQ¿ûêøKÀTøKàv¾ðêΧ’q Õš=Q”ð WàNN*pY§&ªE½½³Jµ(@ü×1lÚº—Õt,›S[fµ·2¨Eêx̧veƒæ“g«'p\FF•Òª…@ „j}/@ ?ô@þ­PcYDE¢££µ âO=+ðší1ûÇ‚Bññ‡Sõ2@ €b™@T Še"¡ÿˆfP ä2P ËD ¢ P,@ µ@±L@ ªr™@¨…’Xæ›A¿N@ j“~}{KrrrÔo¥©©)û=®Jc™­Z: Íáñ@\\œ¬›sppP³aRR’¢¬tY4{@ ÿi”ÎiMNN®²¡ÒüJ]&š=‹@ „,Ê×e\&@ þÓHœZMý# Çq©w”#‰@ ˆÿ:R&ëédáóù¡¡¡|>¿²ærþñ?ËDóx¿é¼;De ß)â—#û;Uýú'‹}ššš*M~øðAKK«Y³f²ïšŠþQù³È_"⿎ŠÙ9ÎÎÎ400ÍÌÏÏÏÌÌ”k.{üŸ‰e"¿ô£@ ~d§ª_ÿ233e¤:ügb™Ä/ý(ˆßŸú;¥!ÂT½Š…+N("S‘bMJ$¨¬KEÕGœÿ9½ˆ/þ.”àk·ÚDÊ'%ÿ™E*®¡@@VÚªF¨Rƒä‹ªžòö3ñŸ=]­&¼Üw¹Bå×JQ7ëÁß™åüGü0KR=ÎáU¡´zp•©÷‘«T½Jo®P÷¹Q+ÝÕì±P]J3C¥—J“?Ys¹ÞÕ¡V4”+*þú ›¨,ùH=𬧫Vs9ÿ¨îºÌ”[Ûûutlß°Ñè•—dóßôö=(›“}q”g{›ú6Íœ=g¯¾HªWT}ÈS«¦40ÔkäÚÍÚP¯y×qÁ‰EŠ•š*cÌIizlô¡- íêÙ;®U¿UfÄ©¾m›èëê×kÔv‚ï)Ù³ø‹*»†@ ®lžÒ´~=}£–®^+ÎÆÂw£B´û‡ú;7Ñ×1Ð3¨Ó¶û¤°äâïïî{(NÝ4hðxÉñë•CÛ+ð²D(×äö´±‘Eʽ‚¬4 2¦÷YÌÇéð#˜t¼tNßÙÙ¢ïú™~¼²®SKÛ&Ʀýž–Íé?`Ö‘8ÙœJo.%8¹rjÓzF:º†f6C}¶}þöG :qðù.|«] ÝUnÒŠÝ)%l–÷¨©çT^•2Äü4ùô_¢¹lïêP+*-¢k”Nêø?öÎ;.jä à/Û—âRTPQ±cÁ‚"–OÄ.XPä,XNÅ^O,§žœÏ vQ± ¢ˆÊ ‚X)KG:a—ÝÍïÀ¶±”îg¾?’™7óæ%™·“äe&.YU׋ÉRë¼ÌZ«×g^&&,˜²ÜkÁµð)z©ãFN=6Ïzž¾%^s½ÕñáÍöâÂ%©7GN[o¾p_й‘e‰/~wù}¢€umƒbQ=ˆñ¿ìz5øÝ˜~&‚¢´«Ìž9xÌûÔ0#fðÇ“%Ü+‹Ö=Ü1°%įê1&hĨіFj_S@ÉZEI>}Æ»õYyêíÝñ¥ŸÍŸ4h=Ùk÷sŠÃ÷غx NÝyþK/½ÏÏšeÅcEíuh_¿Ó­ØŒÂDï~+­Wî¹wÖQ=óå?y8 ¶‹M~Ü–©ìÏ’(•ZΊËe¦e—ööòO,Ðø(á.PÈKÝ:.T “ÙQ¼Ü2#ÍÎË’%*+ÉP¡cjŽ<8lïŒaëûÕñ8U‚ òÇ.Ø»âIÒÜ6ßúvydå¯K 4 0îìÌëf1Ï»‹K*8¹K/»AûÇ÷žÍðni‘Ï7:;Hkw}niº…s˜+?¢äÒÖþþí"žº7Jsòº´tsòöº,7;‡_¢Ìñ ]cŸ:ÍwŒ«I,·®Œ©b¡<‘šþÄsc·Ûm~õfÏ`HÖű̷oß*£äíÛ·ZZZ2\.—Ëåž?Ã0|;$$„[“„h/*]/9ËårÿèÈìÎårS’"¬ ÍoþF,¹Ó¢•¦Ñbq2Êo:BaÆ}S,R†”€[«ÂÄÉ’ÂXú1UȺžºÝÜîT&Ê ŠËPEŸ.4Ó4\¡d­}õ8V‰EIæ fhváÏ)’ KÛ2i¿ċӱgDz´lJåšÜžm‘OÌQ`ÆåqF--6ˆEE9¯`nTºÒ­)…´_( öÉ8*]ß¾9±ƒf;Åå_1âøKe´%Ç?Ц³n}þÆU½c&}¼È`è=KLV~lj~š—ršÊÐÇ{ÈÁNZÃ/BQ´¤ Þ¶]¯§™…JžÜÐ+ˆ¨>• ÷l©L|ûá~'*‚hy–šßXÍ)øYh®å¾Öa°C² ›ÄrbëÊÐ(*dÜf2õß}/ÆEÉ:!í§Äœðððòòr Ã0 +**ÊÈÈøòåË·oß““S’“SRRR“SR¿~MJˆOŒ‰‰ÁkÇG¥b™ª†HXX$@6_ÄÔbÀ¥¥ŽÝœï«IÄ¥bóÌ×Íç´ê·Ã€&Úõ€«@yX±BÞS)™i1²Ã_Š“%©ABµâ0TÉ [{ ¡•ÿž‘•i„ICjoˆX –ü“Ûs‡‹Xªo¹¿-]¸ñnêO(Rp +JbÒx‚ѽ´Å9m¬Ê ÞÈ­ìWqAGg9Œë?ÀjÚü5o2eÄ]2^¿H'„¨›ñëͯ­‹DÂ\øñ1Íw·þvur´›6×±»u®ŸÝ“°Û¶­2Ú2_î®h5¯¿&Tï˜ ÎˆÚ¥ž•Ÿ¬«ŸR¨š"Aa¡P™¼JóÎ̵íqÂo ÁUŸÜþÝæ˜Ww¤ÔçÌC 4ÃwuX¯Aúë·ÛäôOc5'¯KK7…_î»Nµ³´>sÁòàøB<óÃþ5«¶Vžßl^¹Ã?9?ÚÓ —_&M_迪_f<Û\¡ç6¨£I,'¶žts‡Û’Í¥¢JËâ/nY²ê¸ÄSц[¨Øx¦–Í\ÒÍáY¸H"ÙP9±Ì/_OœºýÛÊ›nëBVZísðFø­‡aÑÑ1•GÁ Þ±L¦–µµ²îØ­¨ûg.æÑ\{è$ù¯<¯»y½Ukb1~ÉëÈÔ¢º#TõAFNx®”¤<½~ýz¼¬·äárãf¬ ~yÃ{×(«ÍÓ¶ùÛë(xT-Z7û¬ÅºóFu{XW£¯8,¿BÔ½¯.a/4¬8ÌìМŸP¤à¨ÑÕ»ë1¨£óÅ9¹¯ïÀë">|½æÒwú~õ¿ž:¶©35j´ùðZO}-f 4õʃˆŸ¾ÑÁEÃ`ÜŸe=TQ_|çÙ¯8­nfãá>…É »âQ*â¥Gøœ^ã*¡ývçÚù3»†:‡vC¦Øt¹´uöä3•a¿wÆŒ±oô¥”å5[7úeN’ÿ‘_<ÃÍ}0j±WÇ鎔šJna­Æ;Ó»7F,•HÖ™±ÌKWÖl¹~óZ^>MLôƒÃ¢³9…Œö±Ù¢ÇOB+*øâêõ\cvÿÕ¿·xžÞi´ö¨¿yÁCûƒ|¿ ¡7Ní»}ï%Ëx؆­®út*Z”m¡‚X·“ŸWZ”#O„¢¨žOB‚ŒFÐÂxJÀ­Bëñ+Þð3¹c×Û·r”‚ò™a+o´úàÞ]A™Zk‰øÙ`®1èvfÓž|)ú E’‹B?³´Ãìɧ|ïÕ:þ•ßÊet)b˜°ØÞíÚà}Þ‹ÌÀ¢Ÿ­(T¶çû×;{c‚üˆÈx\AR¹Põö ˜³ÎÚJ™‘å7{Ú¢Ozãƒ#½5©J#zï?ïc^ž/Äм7·qy“YÞg\«¿â¹ïàÄÍWÄÊk‹J/Óšª&.¬RÇ íÒSÑ(:êì§óì_w¯o=/‡ *lé)|þvÜžWýž°ºØì=ø»ƒªL»¾cÃ¥/IéEœÅÛw9™WÏ=qø‚*š“±9!?3¢˜ï8ti-Ó.^S–È®’úàö·ÏÖÚ,0 ½ît(\L Š[¦ëR5~üXË%Z§2Û_}¸Çd½ï¬øèió:,ó[= •¨"/þkåe]­­q;õZX«ñ-·,=ø`œÌd@Æ2ÃÂÞ\¾“¦¡Ñ_Ÿ¢£¦Ã¢¶G“£©Áj¡Ù¹8ëÛ‹—¯†Y •©\Ùy™ìnNøNLX¼ÒzÞ֛˸o:­vúܶ»Îù£ß³}ÃhÚætbÝl¾H³“ަ¶¾xú!#™î¸ ‡Z+–°É*,Uc±@C¡®ÆÔ`3ôº™}KŠûgdÔVºzט}°ÅYîc£Ç¾}âµÉœkCÌ̺nê=åìFWï®E£|ŠÎ‡ö-ð˜¨ìQAyGË–tõ¶òDu? 䥌Ûpy꣯óê€Z›>ž_EÌÞ±»¯tù®÷É”"ïí2D ®ÅÐè©M§¼ÌcNÕ^”å£&C[14Œ~6Q-‡Âš¹îèÌu•©Â„mBÁa‰ò²`öB×.Õ7n4V{ kX?~Ϻ Ú{h®~•Wc|Åfmµ›}¾Ü÷uÜ83N-†©LTêõº¯Í‹ÝQ>e1 ¥X[57[ÆŒ79&/‡GeH7WWWÛ ëü'è«Ýø+¬ó¢ ææ=vŽ<<ÖŽŽRàVJ8&–^Û[vtX°ÊF‹©êæjÅnw@âŒG§Î[8Ü´Û‚³Á§H—¡0ñ„džLjv–Œi¯?ÆréÖµ ôåa¬V†, -Úo).Þ„‹J;úYXë/IyV9•Y=DI$ëôÛ91‘™³tíÓ.§ ´¨´\G…ЩÀ¤Ó™t*FALǰ—›bdÔVz|¬Û÷2³ÂönÏqúË¡#– º  ±µDù}×@½ØÝÕ³vÒC¶g Û¶ŠDu§¢,¦H jÝš`$…ÝžIûþö»Ìò/VR×srÒS«S+2j!ŒCCZÇl>-ÎH»ï‘YAÙngô3Š"äef=?øýb›a^XTvËÉ, Å6·®bÄЮæ:*֦،ôGÓeß‹l’ñX:ãäê›\qNÜ•$%ë>Øtoýo¦ÄÅÚº·`~*”P¢:Ç,üPÈÔî¦ä¾È#ãé¶u™.ÞÓ;@~™€Ù’ 45m‘à;€¢“+âgÛ³%=Å0è /NêÝ\=vM¿çèM}c#½C;?+”¿¼€=9ŒÂ÷’çñ‡Y.ÑzIš¿ûÝCa¯L¢÷N=†G)´*¨”êÃ] k3¾ ¦€©ÓC,•HÖéXf·Ørh7¡PH§RY ƒIcÒéL:A§ÑiT:¡Óé†Fí @V,“"¯•‹{ IDAT%é—w‹r_9¯ŒñýÓOšŽ1H<˜[RòìÜ3Ng{<Ój÷NÖI‡mb“ŸúÎp»ÒcæÁ4bÑ·Çëìííoe(zu›hKkì$C ï)ËŸ¾+ 4ï²ç¬sÙ¥Óvô€mã™v²º4Æßø0­½ãºi9µÆ{ïÓÊüÛvù©™/}ì.ôq=;¸ãçÉG´}ÔÀÓ<£â3K²¿úpžÿ”¿ëìT 2Ûù-ëueú$Ooÿ T˜µÜz€“Wíq~f,Ÿ{ªÝÄYé!÷ü <ø7¯ng\ äuN^…ÆI'Óà%óþºô8¿(+äÂ:—à2qy¾L ³bÉ÷÷ûó§bˆ”×f6«=70ŒX^uމ¢è“àtã¹&øv]ý‡_üïäEÑÁç*_•ì;Ñ(þD`±Pz:D«ëLÅ'ßñ£ÃG,ñ{žYX¼tÂfínnÃ9ro1Ò\:¯àÙØ6ÛOÜÊ«U”ñ ÀQ‡¸O_·N)·ÂšÄr‰ÖE‚¼#\Û/õ[hn~ùÞ¦`›‹_eGh¡bãŸÜåš¹÷·%‘¬µtH¾ˆÃaR„N£ª³ètÿG£R4 J¡R=ƒÖò>:­Ô¼Lœ5ýÚïý$N& ›daÀÐÖ44árìWqþûûûFö3cS)CS{—}© òD>Ž&&&Gb”œï…¢h>÷Å’ÉÃ5©*Sƒ‚ z]­¶{‰‹– èiaå).™—|ªK—.[>ɲùzãXbùZk¥…ci®F¥hµëæ¸ähéÏ-’w ‹ó¢]íF¶ÓfQèšÝÚ^‰$ÉÒï¶Í1nÍ¡P­;õšµú|™”ÂÏ·¯.(‘È”gÆó®]¤åþBJkƒPJaÈ~|ýŠä#*"jrÂrüR>C½ÎÈõ2£755­¥&(Ǩ,вA͵‡® Õ£ÉyØ#G›cŸàYþ¾“*—RRc&ø:Î žþÆÇQ‰]©DÚO ¿ärºH¾²À+æ35eœz'·¬¨T­…ºL‘*šS~q)C³vä9ek8ÿQÀ4c<ùƒ-—h]ËBiQÜi[»;Î_nÍ’™¬~Š¢(>¢áÉœœœ ®\¿³>%³ ° ¥RéIYùêL6°Õ˜Z &ÊP£q8ô{§ŽMš4IMM jŽuˆeJ»%ÈtKP0(Öc¼”Beé¶ûñã%(è¯?¡H>yã%Ôc¼¬¯? „¦üxÉ/|Þm‹ÜñR¾¶)'÷'muçò+_>T‘c Ê¿.Ù›çuÔ^®yÊ!ý# 2dAáÉUf¼lÄæ”§~ã%̾x-‘¬¨Ây™ ä}/“Ëå6¢6’&¡ù|/³Ã:¾Ï&ÅŽ¹ª1š Q€Í&·Ÿµu1ºËÖÊOÖƒZý¨÷’šuž—IBBBBBòŸ•±j:BA(€ âPõÍMéñ‘F‰mU`|C ojHHHjôS’惬·s ‚ ‚ øë  ¸AˆÕ‰Û?(–Ùpį<‘4ÍÍ)š!¤Ÿ’49Šc™‚PðAAAðñß@ª§üÅ2IHHHHHšõÿ6 Ë$!!!!ùÿDV,³¤fü*K¼ÁüoÇ2IHHHHH”GñªéJV'nÿgb™$$$$$$uBö`‰a€a˜‚˜¥<ÈX& ÉOrñM2–IBBBBòÿ‰âX&†ÕØÆ0 °C'Ë$!!!!ùYøyc™·›Ú’Ÿ‰ö¿4µ ÍÒOIš¢ŸÊ,1ü†Ã0ÿ­Ü Ào7åðŸ‰eö¶è)ýñ/’FxxxssŠfé§$M‹~Š¿üƒoŠÓU2Ì‘€Œe’ü¢8–Y‰Ô)Î c™$$$$$? Ò±L¬ú™¬8Y½Q%ňՉÛÿ™X& I“C: Ió§ÖïebrµóŸ‰e’49¤S4jõS¬r)Ù§Ê)(ŠC˜ŠŸü¢BiÝ¢dT Ã&_¾½…vµ^Êo¨&ü ÙðäU!E*ÕÙV½”'Düû®NUÊscs+DJj+Ë|ü2½LœT…c–$? Í)¯ÕìzP&ËÚ¤2™ÖÊ=¡Ê;~izг´Re€F²PBTœôèq¶ÊŸRHìl£ì`üü‚2¹Rù­+ƒ*5ñˆFé”"¥ÇG ›Í&†0åÍbI¾s`âð~ƒ»˜ÍÞz˜}ÒÙÃ7˜“~mÖèÁÆÍ-G»o¿Fü Hÿáó÷6ÛþÝŽÚ¯´ÍrÀø¶.ênز…G×ÀxêÊý|Ù?7€ñ}6:õîb¨¥¥ÛkÐè­×?UÛóÜÇ~@7m޶¡Ù€ù>5L%EªÕÙV)NÙ3Ùq¾ýnëÔÁRD–THT¹ç6çE‘ìa€¨ „|îovëxl*¨Ò1©ìÒåöîÙ‚Æ<–I7ÿiÑ©[+ý‰k|‰ù‘^“–žŽ#æÈ=¡ò_ðÈÅñJNLòR‡»óÔ¨?ÎB9"ªZé‚á.Y„«"™K²ÔyÖ¢ËÊOÜÙFÙ‘´á§ö­±ìlhÚo'±J³=ÔÒ­ˆG4âH'žORµÄˆ3O$b™ã#EÞþ ÊJ2¦,÷šp äÉùßß}ËÃó³bÏ»Þêè=«½¸dÎß‘Ó~ç_þï…½nï}ÖLÜ|e~\7tòÒûJz°1L€Ö ó– ^vušï–2ç·Q,”'RÓŸxnìg»Í¯ðbò –¦,7;'§DûÅ;Û(;R¿ªÇ˜ù÷bË-Ôˆ­4çCç+Õ!åßiŠß ’ —Ëår¹çÏŸÇ0 ß áÖ$!Ú‹J×KNãr¹Ü?:r{‡s¹Ü”¤kCóÛŸ¿Kî´h¥i´XœŒò›ŽPq߸\.7- ×pÛ©³F7n !ˆÐ+ˆH'îÙR™Òœ“xŠJ¡ßNÏçdáúêq:¬ç'=šƒP˜¡Ù…¤HÕ"e¸=Û. #Ÿ˜£º¶”DÚ/ûd•®‡oßœØA³‡âò/qü¥2Ú’ãhÓY·>ãªÞ1“>^d0ôž%&+µÏ\.WÊO‰ä¥œ¦2ô‹ËPEvÒ~ùŠ¢%ñ¶íz=ͬq²œPŽÿp¿A4ÆÁÁ©~*[cééñQ©X&SËÚZ YwìVÔý3óh®=t’üWž×ݼު5±¿äu@djQÝ¡ªú #'µØ«ãtG‰¸TÃ-¬ÕxÇaúo÷ÆÈ6L´šÎ½øü…ÓzÃòEž ý¡ßµ;)xõow®?³k¨óqh7dŠM—K[gO>'½³x¨¥i·ZÚZ™±LyVª®.1>*;/sÿÕ¿·xžÞi´ö¨¿yÁCûƒ|¿ ¡7Ní»}ï%Ëx؆­®út*Z”m¡‚X·“ŸGÌá ExÈDœ£gã“ £ÑZ¹¾cÃ¥/IéEœÅÛw9™ëHx^Àÿ·fE…½·ïÃÖ´ü‹{\'ô´ú7íM[~6˜°kDª;³iO¾‰H‘*E˜°ØÞíÚà}Þ‹ÌÀ¢Ÿ­(T¶çû×;{c‚üˆÈx¼pR¹Põö ˜³ÎÚõi yý–ÎØü¸ÿ†;žN] oŸ½wŸ÷±/Ïbh^€›[ˆ¸¼É,ï3®¦âd侃7_+W¬-*½Lkªš¸°J4,´KOE£è`¨»ŸŠ*òâ¿VŽÊtµ¶ÆíÔÏ>ñu÷ðÚøÖØórØ òÇ–žÂçoÇÝ8áyÕï «‹ÍÞƒ¿0¨ÊœPyŽ?âp¢¸eº.•?©Tfû«÷˜ ²÷=m^‡e~«´jt k5¾åà–¥ßŒ“6XÈÏŒ(æ;dÚEË´‹×”%²jVèƒÛß>[k³À0ôºÓ¡Pp1•ØY@˜u¨åÑ<5Z˼L|Y|K2hY½–ž”—Éî6á„ïÀ„Å+­çm½ù°ìû¦Ój§Ïm{±káœ?ú=Û7Œ¦mé@'ÖÍæ‹4;és˜T ‚Ðjð•aã½g _ý>ÍÁüÖ‡„àõôÔ²„öOCÖ2Ð_~ôÑ}?ýE—ƒ§t€$´Æó³TžP³³&­CŠT'B¿&¢­ MSW^wæ E©wÞÁÎÞ‚òä³gÏâ™ E<ìŠO6›:Ý—oSŸó¼N‹æeò…ÛMÙìÊ@gð}‹—gPuƒßÞ¼r—­TÄÛó¨ÿž6â‡`е¥ð„ÆÕ¥jÇÔ6ÖòRêç­%é‡-,öâÛÃn'Ûp:?ï70a‘k_Ý^çÞpZrHýêÝO6Ï¿²ï»££hl¹çZœ¬ÕñqâQº‘º8©Õ}ÑÝ ~¶–½Ô wX«ÂÂZ{£z{u/ÓZ*³í•å63,{¼˜3î|×±½ ek=ØÛº*Ò¤ßWGðæ“Ìm¬C­$ÍäPãÔ{p‘¾Ë”¦nó2àÁd¹;æÄk“9¿ 1³X¸qhZР«w×¢Q>EçW[ *{TPÞʲeýv@I8&–^Û¹¡;HÎÎÔ’©a4ƒ!~"0&¶då½ÌchôÔ¦SÞGæL- ÊGõ†¶"E*‰øY0{¡«[½¯^96 èÇ«pÒS›½÷¾½k©YýÚ‚&*uj¿ðy±;ʧl kkàò²eÌBS‘còrxT†A­ÅdÒ¢ý–â*¾&ŠWÛ ëü'è«EýÖyÑÊæýÜwŽL ðåO¨ÇÇ1dR˳jL-Õ2Дgµ2dQUXX«ñåYåTf 5»Ý‰/ΚÓ7µ]u]f ƒpŸCxÜ)½³ ÙyÊ£™jiäc™Ä¹$5‚š•Û@œdRÏX¦˜¬°½Ûsœþrè…e†.hl-QE>Bß5P/vwõ$›ôíÙÄÃVn©"~Ö¹=[1 C€.õ#Óoóð¢Ä£%âÙ²ÿf.ÚfLk@‡†´ŽÙ|Z\2í¾Gfe»)R©ˆÝr2‹‚D±Í­«1´«ù€Ž’gN‚ú™ñ£`éŒcP«oªCƒqW’”¬û`Ó½õ¿™skëÞ‚Qø©PB‰ê³ðC!S»›’û"…V•RíœO·­ËtñžÞ òËÌ–L ©i‹ßkå§'‡Qø¾úX•¤ùÛ¸ß=öÊ$zïÔc1ª°°ÖÞXSÀÔé¡àé÷½é ol¤wèqçg…uXšCbgº#u¤™jiÃdÏË$ÞJV”•‚ë;/§(÷•óÊß?ð¤éƒÄ3¹%%ÏÎ=ãt¶Ç3­voàdtØv!&1ùy ï ·+=fìA«1 S2óíñ:{{û[ŠÞ´&Ú†ÀïøÑá#–ø=Ï,,ˆ^:a³v7·á&lsÿË´“xÉvãOŽlñvÐŒ±ßòŠ3â/ñFØõÔÄö0Þ{ŸVæß¶Î}LÍ|ècït¡ëÙÁ-¤H¥"*³ß²^W¦OòôöÏ@…Ù QË­8yÅÈë‡bêgFã"¯sò*4N:™/™÷×¥ÇùEY!Ö¹—‰Ëó…È™ˆ\òýýþüéƒ"åµ™ÍjÏ ¬1WRuމ¢è“àtã¹&øv]ýT&üâ'/Š>Wù¢c߉Fñ'‹…ÂÐÓ!Z]g*>׊_š¾nRn…áÛ"AÞ‚®í—ú-47¿|oS°‡Íů²#v ±P±žÜåš¹÷”Ù.¯àÙØ6ÛOÜÊ«U”ñ À¡ì²;Û(;R'šÉ¡Æ«ÔÚ!«×1¨±¬AõØÙÐy™8kúµßúIœLþ6É€¡­i6hÂ娝âü÷÷÷ìgƦR8†¦ö.ûR¥ô_†JòùöõÏ%™õ3£±Pž9tÀ¸»ø¶ŸmÿáóŸŠ+Ä›d1d«ôÎ6ÖŽà¼Þ8–ø‹*“fr¨Q%æešu[üïÇ´›!ï/Üý×ç^Ôžó¡‡.½:téÕ‰[ï.?M¼ù2)ð]ÊÓätyó2‘„„ svvNLL€””###ég³Å‰yš&º™ü’ †¤U”SèJ-¡$qqq2?][VTªÖB]:_LP&¢ªÉЉø(…!ûA4)R©ˆ_Êg¨×ùz¶~m5œððpSSÓZ a‚rŒÊ¢(Ô\;pèê°P=šœ‡=r´ù8ö žåï;©=žTc&ø:Î žþÆÇQÉò ßOÅ~Éåt‘Œ¡òŠùLM=AÁ UÒñOÙÎ0͸֒n¡´(î´­Ýç/·f)6€_\ÊÐTâ7M ‰m¬©_ëÊ ŠC-á§(Šâ#žÌÉÉ™çâã{cCrf~)ÊC*7§˜EgKÅÑÒd0(L5ª†6íÙ¹S“&MRSSƒšãc¾—)í– Ó-@Â- e¿ý\.WžH”/¡É[ûPAG!E*Õc¼¬w[?„ÆRú ~áÓðn[䎗òµM9¹ÿÄHwî?CTæ˜É‰Ï—ìÍó ³—k^½þ‰™?‘ ð„*éø³/÷êí’úë£vLer6–…"?gkÎ?j¿þ¨ßx R;ÛX;R¿Ö•AE‡šˆÌ·s`‚/³úMñ벊—2 È(aJóùu !!!!!©hm+ (S¸]‡Xf“ÞÔ&Ôé§$ͱL 0™O^¥&eBÆ2Žø•'’¦¢¹9E3„ôS’&§ÖXf­H¯=+†Œe’(Ë$!!!!ùÿDF,³¶i`Dù;–IBBBBB¢<ŠWMW²:qû?Ë$!!!!!©2KAA@I¢ð6”Œe’ü\È…Ò*ÈX& Éÿ'2çeJß\VæVA©“±L’ŸéX&Rù¶ç@å6±:qû?Ë ¸ØÔ&üìL´ÿ¥©Mhî~JÒäýTv,³–´"þ3±ÌÞ=Tˆ„D¥„‡‡77§h†~JÒ´(ã§ÄÛÊÊ»Nüm ñ¶üºd,“„„„„äÿÙ±LñˆÔHJ”d,“„„„„ägAæ¼Ìª›K¤êβjÎIU©Z3ï?Ë$!irH§ !iþ4pYDñƒYyòF“„DÒ)HHš?µù)òŪŠ ™E‰!LÅ_C…Ò뻋’QtILÀ—Û¦ˆ/¨õ«Ø &à‘¢æ&REJ0~~AYÛh\å ÿ¾«S•òÜØÜ ‘’ÚÊ2¿L¯ÞkU8fIò³ÐœòÚ¬VšfyšHþïh„‘®ê½AÄãgÍç´a^¦ÄøHa³ÙĦ¼ù’ï˜8¼ßà.f³·^'æGŸtöðM æd†_›5z°qGcsËÑîÛ¯¸O}œlw016é:Úqùóä’F9(~ËjiiÝÈ•=̧?÷±ÐM›£mh6`¾‡ˆ5‘ò(P’ö!üÔ¾5– Mûí¬—nRœ²g²ã<|ûÝÖ©ƒ¥ˆ,©¨rÏm΋"ÙãQùÜßìÖñØTP¥cRÙ¥Ëíݳõ;oÕ4çÓDòxD#Žtuª.1>*ËÄ„S–{-¸>E/uÜÈ©ÇæYÏÓW€¢Äk®·:>¼Ù^\¸$õæÈiëÍî :7²,ñÅï.¿O°®m°€âä‹ÖÎÛ‡.\aÿµì/Ÿòt¶þøõ•6 j]wƒHÊÕ üZÒ±Y_8+Jòé3Þ­ÏÊSoïŽ/ýühþ¤ù£@ëÉ^;RÔ„"åQ ¤ ~U1A#F¶4RûšRßÞSG”e–ó„âòE™iÙ¥½½<Ç ´>J¸ òRw§Ž UÃd6AÔ/·ÌH³ó²d‰ÊJ2T蘚#Û;cGXàú~u\æ©W¬¤¹ñÅwžýŠÓêf6îS˜Ü€±+^¥"^z$Ïé5®Êóî´[oĤ*£íýá­GŽÅ·Uí˜`?¸U´×G|»~~JBÒ„ÈŒe"Ä?².éÄ£f=c™°ÿêß[6Áä¼  âg€ »F¬´3›öäK)j*&,¶w»6x_„÷"3°èg+ ÕŸíùþõÎÞ¢Š¼ø¯¹xaºZÛÖL¹J ‰×?1aéŒÍûo¸ãéÔúöÑ{×øy ðò|!†æ¸¹…ˆË›Ìò>ãZýì(rßÁ‰›¯ˆ•+Ö•^¦5UM\X¥Ž Ú¥§¢Qt0ÔËOIH~<µÇ2+Ö`„!S¼Âof*;/“ÝmÂ ß € ‹WZÏÛzóaÙ÷M§ÕNŸÛöb×Â9ô{¶oMÛÒN¬›ÍivÒç<;å±pWÀ/«\^fϨìû£æœ^7ˆÃTPŒÆî Ih{ÐTžP³³&­CŠšD„~LDZA›¦>¦àùyBQêw°³wIúa ‹½x¦Á°ÛŸnÈ=}ÐDÈ{ãÍ Êä ·9š²Ù,<§³ ø¾ÅË3¨ˆºÁooäÅ2E¼=Úøïi#~€©X[ O¨a\íPªvLmc !/…œJò¢áݵ1ט}°ÅYîc£Ç¾}âµÉœkCÌ̺nê=åìFWï®E£|ŠÎ‡ö-ð˜¨ìQAyGË–xòñÞ™‹®ðN>|3ªs‹†ìÏÇý›2¬[+'ܪÌÀ&›¡±Û¾¿-.ÆÐè©M§¼Ìƒª§L˜¨4(5ÚŠ¡aDŠšD$â¿€Ù ]»T?áp£±Ú@‹ö[Š‹7áY…JE*ä)Qº§ü 0Q ¨Sës ˜»£|ÊbÀO±¶6 jn¶ŒYª*rL^Ê0¨Ç~‘4ä¬1+ùÍ/€Ê©™ 5/SB•²ó2q²ÂönÏqúË¡#– º  ±µDù}×@½ØÝ¾âòé!Û³ˆ‡m[È|¶ÝåtîÕg—8^@g—Ãþ7}vWá¹k+LÛ´}×kk”C‡†´ŽÙ|Zœ‘vß#³‚²ÝΈ5•ˆÝr2‹‚D±Í­«1´«ù€Ž@¡UA¥ Šô73X:ãäê›\qNÜ•$%ë>Øtoýo5^ðS¬­{ Fá§B %ªsÌÂ…LínJî IsCV,³j°„êeÙñR5ï0¥ÇGм–P)Šr_9¯ŒñýÓOšŽ1H<˜[RòìÜ3Ng{<Ój÷NÖI‡mb“ŸúÎp»ÒcæÁ4Š¢k—\031åñ]Á¯ÒQýöx½½ý­Œ|éFk®ÚP ÇtÐ"£G@á£F ÛÆÿ2í$^r¼÷>­Ì¿m7œû˜šù2ÐÇÞéB׳ƒ[0HQS‰¨Ìv~Ëz]™>ÉÓÛ?f'D-·àä#³*Ðß$È뜼 “N¦ÁKæýuéq~QVÈ…u.Áeâò|!˜@fÅ’ïï÷çOÄ)¯ÍlV{n`ØqLEŸ§Ï5Á·ëê§$$MB­Rrî¥âUekR‡5fON_5÷ò}cŽžìãñÏ0‡)ý-› ûûÂt6› l“ÉAåî›Î8œÙÈhÝyøLÏ£;&ãÃr‰¾-æê_5 GýmkiÀ@Ђ‚ŒÁªç3h„Ò¥K—´Êá¿$//YùF¢F»ÉaO ç¯Öá{™Òn 2Ý$ÜÒÐÐPÞâË©?¸¤¨©DJŽ—Š•4/Ké'<ü§áݶÈ/åk›rrÿ‰‘îÜ ~† *¨Ì1“Ÿ/Ù›çf/×<’fâ·s”¬NÜþAßËÄïe@C$$ª£‘û*c`ð‘zéTtqĽ¸œÙ8 4AcfÇžµ=rÞ‚.$=”ä¿Zۼ̆@~/“„DYšStã±PÅM°û-^¥â&HHTb?Å0¬jEÈúPçy™$$$$$$ÿ Pó2«ÇKâ+>€ô,éñ±±Ì&'<<¼©M !!©ÒOIš²b™u¸Ål²XfÿòDBÒT47§h†~JÒäÔˬ¼¡„ŸÌ¬þ’I•T&d,“„„„„„D)ÈX& Éÿ'Ò±L*•*¿¸ìêÄíÿR,“„„„„„Dy¤c™Ba>ÿŽe’Ô éÛ?A„"¡H(ET † D": a Éù3Ë$!!!!ùy P(˜£Ñh4šÇ0è4 `F‘£R‘»&Ë$!!!!ùÿD:–I£Ca!O€‰A9¿BX!Ä0 hBQ_ I§ „HVV>’±L’ŸéX¦¾!çåóCº”WQÆÐD4 3D¡¨BˆQHú·oZZZðŸŽeÜljH~v&ÚÿÒÔ&4wH?%irˆ~*}û׫—þ%ß”IÕjÝ‚_!*,æ©«Ðù|ƒÁª‰˜”âŒÔÎíÚÈTþŸ‰eö¶èI~Tˆ¤ onNÑ !ý”¤i©ÕO‡ìð)îmÀÙê i-Ô´ÔhF¢ P(…J¥ÒÓ¿}ÖQguëÖ­´´Tº:Ë$!!!!ùÿD:–ih¨ï8ÑìÖݔ̈,¬sËïmØ4 (”2!PË¿1`• µŠ8ÉX& ÉÏ‚ÌïeöèÞɬ³Ñ݇Ñ>|/øÆâSt€¢.Òæ èÞAO¯›Duâö&–IBÒäNABÒüQæ{™L&Óq¢åÔI …B¥R) B¡Pä/-+æ?Ë$!irH§ !iþ¨ÔO)(ŠC˜²¾.V *”þlŠ(H—Ä|yM Ê+êeªD~™^½×ªpÌ’äg¡9åµýc)Mz–VýFF™¬½N*“¹×Ð$ZW†F±PBTœôèq6*/I"xD#Žtuª.1>RØl61„)óÉ/$ß90qx¿Á]Ìfo½NÌ>éìá›@ÌÉ ¿6kô`ãŽÆæ–£Ý·_«þ À*®î]5ؼs{“º÷qÙx$K΄’¤><õ«e7í:Z:­Ø.ùZ,«”Èg›«‰®–ÙÐ1tµzØÌ½›P$–¥?÷±ÐM›£mh6`¾‡ÑR¤R‘ò(P’ö!üÔ¾5– Mûí¬—nRœ²g²ã<|ûÝÖ©ƒ¥ˆ,‘¼p¼ç6çE‘ìñŒ¨ „|îovëxl*¨Ò1©ìÒåöîÙ‚9i#"ä¥:wç©Q éæ#-:uk¥?q/±L¤×¤¥§ãˆ9õè?"€G.ŽWrÊ€PšØº24Š…2ETµÒÃ]Ä?žI Ä#q¤«Su‰ñQî²@(²’Œ)˽&yr>Á÷÷cßòðü¬Øó®·:zÏj/.™óÅwä´ßù×…ÿ{a¯Û{Ÿ57߯E·Vñ8ý~å o?ÆÜ8ùGY°—‹/ª4æ&z÷sXÁóÛ½ˆ„—~G-™OÛ¥IÝGÆxŽ_v"îXð»¬ÄYéŸ}Æ» Ænzû-=èÔÚ˜ÓKFyÜÁk‘"•Š”G’‚øU=ÆÌ¿[ni¤VWµõFùîZΊËe¦e—öÞX“6À'–/)ø²;uœ­V«6EŸnœ‘fçeÉ©Ô1AsäÁaq3v„)¿×¨*c½¡kìS§ùŽÑaa‚ü± öN=÷êÓ§{ñ§;’^‚(Œ;;óº™ÿÒîâ*õè?¥é>¦£Ý¢â#>]ÚÚßúoéÖ•1µQ,”'RÓŸxnìg»Í¯ðbI¨é§®ár¹ðèÑ#ggçôôtˆ‹‹355­aAî Ó~»¾&EÑ8;´Û½õ÷¯O0òÓç·âq`_Mº¸ä™ û¾Où¾Of¿þ½£ßO_zkУî‹3þuº™.Êxá4ÐécJÒ[% ‹‹#Î÷ºå`º,cvjøfsÁòàøB<3ãÙæ =7|Ä¢P5E‚ÂB¡2y•{}f®m~ÄѨ~ý§4ÃwuX¯Aúë·ÛäôtëI7w¸-Ù\*ªü±‰¿¸eɪãOEn¡bã™Z6suJ7‡W4‰$ ´Ib™L-kk-dݱ[Q÷Ï\Ì£¹öÐIò_y^wóz«ÖÄbü’ב©Eõ}BUÄaä„çŠsÿ}rÿÎß›Í<]¶õråTIÊÓëׯÇËz[A.Í@½ò’JÄOßèà¢a0îÏÎZ¥\nÒý°qÐŒµÁ¯"oxïeµyÚ6{6¯8,¿BÔ½¯.ÁT +3;4‡©T_¯¹ô¾_½Ç¯§ŽmêLm>\æ©W¬¤¹ñÅwžýŠÓêf6îS˜Ü€±+j<(ñÒ# |N¯q•Pžp§Ýz#&Umïh=r,¾­jÇûÁ­¢½>âÛõðÓä[‹ÍíוèôÞà¹Ê”ùaÆ ›çyåÀ}¸®Ëˆ%…Z›n¶Ð.re¶&( L´šÎ½øü…ÓzÃòEžøË}ïþŒ1cëdi«,=p-âα3¹4÷Þº W]OéíÞim@lº~ýG½ÍìW—¶›t³2²Yü h)žIlÝè—9IþG~ñ 4÷Á¨Å^§;JÄ·na­Æ;Ó»7F,•H’ˆiôX¦²ó2÷_ý{‹çé‘Fkú›<´?È÷ zãÔ¾Û÷^²Œ‡mØêªO§¢EéÐ*ˆuÛ1©¡ñyâœ{wÜúššU¬9gõZ»ö,<_ÏÆ'!AF£Êå7{Ú¢Ozãƒ#½5©’×-Œ§Ü*´¿ÒéM?“;ví±}+G€ˆŸ &ìÁüÎlÚ“/E¤H¥"LXlïvmð¾ïEf`ÑÏVª?Ûóýë½Eyñ_+Äéjm[3å*&B^ÿÄ„¥36?î¿áާSèÛgDï]ãç},ÀËó…šàæ".o2ËûŒkõ³£È}'n¾"V®X[Tz™ÖT5qa•:&hXh—žŠFÑÁPw?ÅDèDßþ›B®{ô€ #Æ™·>Õ’Š€¨Üaæñž_\×FYŽg8z˜Ó¤mÙoX™Å|Ç¡ƒL»h™vñš²¤RU·L×¥jü@˜gŸøº{xm|kìy9lPùcKOáó·ãnœð¼ê÷„ÕÅfïÁß T°VËG¾@L[§2Û_}¸Çd½ï¬øèió:,ó[= •D×5n§Þ@ k5¾åà–¥ßŒ“™üÉA•˜—Yo”—Éî6á„ïÀ„Å+­çm½ù°ìû¦Ój§Ïm{±káœ?ú=Û7Œ¦mé@'ÖÍæ‹4;éˆs<®ßõ(úöïf—9£$ý{cEC¬txéŒM76XëÈ”õ˜%òð›]Ÿÿ¼>×Ú¼<#òUózôöq½#»+$¡5žŸ¥ò„š5ilR¤:ú=0hmšú¸òÒ6z옯Mæü6ÄÌbáÆ¡iA€®Þ]‹Fù/.Œ‰Ê”·²l)¡¤E‡~»/¯ËÿóiaÝâ"D‚¶ÚM;wáuÜIÙ㥗2nÃå©7ç[›SÔÚôñ¼øªoÞÓÙ;¢=µé”÷‘ySKƒòQ½¡­H‘JE"~Ì^èêVÅFï«WŽ €í·Wñ%h´%2Nv“‚‰J@]ê!‡2äÅî(Ÿ²WS¬­ ƒÊË–1‡OEŽÉËáQP/D‚Ð¥I¾–/ªÈ€–ôê| ­dò…`·; ñÅYszâÂᦶ«*gÎ2©åY2&‰®¶AÖùOÐW‹ú+¬ó¢•#Ìû¹ï™à ؤ[×2Дgµ2dQêº ·°Vã˳ʩÌêà·D’DŒœXfísùÅÕëË“¶w{ŽÓ_ °LÀÐe­%ªÈ@è»êÅ‡”²=[€xضUd_öÚ“T^Á0èõ}ƒ#ý‘ÇôcÙ÷¢Ç™qä•©(‹)ˆZ·&ì …ÝžIûþö; ŒCCZÇl>-–¤Ý÷Ȭ l·3"E*±[NfQ(¶¹u#†v5Ð?=´*¨D‘þfKgƒ‚\}SŒ»’¤dÝ›î­ÿ­Æ ~еuoÁ(üT(¡DuŽYø¡©]};X'Ø-'iR)ÞO3Å9…ŸçUˆØº“4¨” aÕ1Åì°³•íØ²ÒUõ{ŽÞtÐ76Ò;ô¸ó³Bôä0 ßKîuÆÓmë2]¼§w€ü2³%hjÚ"ÁwhÄþ#ÑzIš¿ûÝCa¯L¢÷N=†Gkv݆[X›ñ1Lb©D’DLÓÌËÄ)Ê}å¼2Æ÷O¾ü÷Ô9·û¬ 0dPyÏÆ´Ù~âV^…¨¢Œ‡P *ôuë”r+Œ¨œ_üïäEÑÁç*ß)í;Ñ(þD`±Pz:D«ëL<³±ú±u‘ oÁ×öKýš›_¾·)ØÃæâWÙÁÑZ¨Øø'w¹fî=ÅmI$r —Ëår¹çÏŸÇ0 ß áÊbM¿öûC?‰“É_Ã&Y0´5ÍM¸ûUœÿþþ¾‘ýÌØT ÇÐÔÞe_ª¸üç'¿M©Ë¦C³å Éî?ÃE>Ž&&&Gbd¶+¶Šx †˜wí"Å(÷(Š.ÐÓÂÊ/–Ï}±dòpM*…ÊÔ  ˆ^W«mç^Š•¤…ci®F¥hµëæ¸äh)A?)R¡¨ôû…msŒ[s(TFëN½f­>_†ÊE~œ×ÇŠO·J‘ç8iɷϳÖQ£ÑÔt-Ǻ½Œø³‹Ù@\t×uX¯!{eÖz~`и oê¤-1ö¡ùMìX*tÌ”¯/µéŒ‹“êí§hiþ…mÎíõ4„Ö±çàe‡žWæ—øî˜×±5‡B§pZÏÛy± ²”\ótéjÔ’Êd19—ç~ç^¡3[-¬>ÿ[,;Î'‹óc§õkËÔát·ú5[=¨7Jÿ!¶þd‡]¾³²K*ͽµl”…•{¾´ÞưPž¨$ÿ£ƒy;£@fò'GÚO‰9áááoß¾ŒŒ|õ.&&&66öãÇqqqñññ ‰‰_ $&&ÆÄÄൈã#’aaaÎÎΉ‰‰’’bdd$}[œ˜§i¢+‘É/©`hÐA QE9….{¥ ´¸Œ­Yç[2E–çdæP5õt[0¥¥">JaȾa'E*ñKù u¥.ù(ùa(µ”&(Ǩ,вñ†µ‡® Õ“Šö)ÖæãØ'x–¿ï¤ÊuTç˜ ¾Ž3ƒ§¿ñqTbW*‘ç§åe–šŒ— y%<¦† ¯ä—24Õ‰9§lç? ˜fŒ' ¿ärºHÆbyÅ|¦¬µ2Þ$ZW†Æ²PZwÚÖîŽó—[³d&r$üEQ|DÓ999 ãìw\ÇÀßÞÞ^¡w¤(¨¨Ø{ïX±DEÅh4vý%v½5±÷Þ;±wEÄÞEÞËÕm¿?Îã£Î÷“O¼yóvÞ0ofwÞÎ.†a<Œ§Ï« ÷üXˆX¦¶[€N·€¼ÜŠ0_ ÙT®ªs¾€|| e•j–žóeþJ*_ÿùR™~;¨Öü<ç˼µùn[óyÁ¤heö㔥䘔<|üÊä ›|ò¬^aÐ9_€Îù4æKzhKØÿFEå¼S{6³”DÿÑ8»>”T 5²(Ù§á wîë¯ó¡A¹íË,&®®®yeq·¹DŧdM¯ü[$Í­y|ñCâP×<Ÿ}Ó“|óñ¹9ÿÝçIÐ%luQ[u¾ºûñùð̱55ßXòß]ô—û¹ÔÊT¨ód_f1‰ŽŽ.AmD¹Pq¾—Y­ÓŒÑ%¡'ÇœV§(Aì;Îû³ž]…¥çÄ?ó>D@)û)_}B–©m@©8£@ E@–ß› Ž¡hÏ|õ©Q}ѶXÕ,‚‚‚Êccs IDAT» ¢Ÿ"*ù¿i@Ïâê¿Ë(–Y|T X&@ ~LP,@ ½øyc™çΔw?;½|z”w*:ÈO厺Ÿþ¼±Ìúžu‹üñ/¢øU4§¨€ ?E”/¥í§(–‰@ ˆËD B/~ÞX&Qî §@ *>è³D…9Qñ)U?åÉd2õfþ+¿2šÕJc"d”¶$K)K°–ùÀRŠbŠ¡¬òÊ*ey®"CÉC?yQ¨"ò¤7I$£§6iÜ1RÕai8fVÄ»‰r=…ˆŠ‰jFSŸé U\c~ä‰Åbõf^+¿ÖöjÝÈ»†ûÐ'ÔÓ_nó›q0T=%.èøÞÎNÎ^&-<®s ˜ÑÉÉÉé|r±2æÞŸ&µÌMÍ+»7ñŸq@÷`“¯Ê*¯¬¢Q–ç*&™‘+úõÉý~±`€·ϲH"Ç¿Ÿ¡{>S×´2z\Ï™ 1¥é˜¸X2ÙgRUîm‰@ÕŒ¦>Óª¸Æü¨W,“¥Ó|'oøõx¯MT×¶6l7ÒÖ2ÂŽ9ët픣J8+êTÛ³¸¹¹åªAÒI·FKÃ??çc°§E­‹³.Ÿèî@+cF´9åF@CcB%¹»»çªß 9ÜaBðôýO_xÿ±¾Q¶Œ<évË&#½ðtY线øÔ×J_{>|ø ¾ßks ÇEÉCãÞ/åãÇ:w:z'.¡±±@½T>b(«¼²ôùs_=€]½¿“™¨˜J}Î¥'AAA~‘©­×éiä—çðð÷æ#ž y8)ùˆsCfcËù8¨’¾õ¬å³çuHcc¢´S™~ÛÍsêµ÷]Ey^[k á§D£í§ê3Zdd¤@ À0Œ‡ñx8Îãa<Çq÷ ÃT¥X–•H$–––{~Ô+–ÉÃ:=ƒf AÉÍpxBÿZk÷©»%KKÖ¾Iö˜9T•bÝh‘=ŸYz5:[€ÊøÓg¬õðÝcÜ…ûíþ2ùÅ¿S¦LÉkUJ–ÎZò*©î¢Qª[¯5UzÎQzŠ¡¬òÊâ?\Ú4¤oׯMZôÿãQÜ·˜œŠØàû1 ZuXœs•/În3¬ÏþK7ÿG,ž‹=+B—w®¢¶¸ËIë‘ (}ǘ¶l.Yö8‘;,¬Ÿ"åNùÄ2…fíÚ™a37Ÿ}~y÷¡dþ˜:ŸÏLÝg9oVËJêbʬà4Šqó4W¥`¸a3SAbPwxaVïâ>§çµ6×’yûĉŸt=­ Ef`*ÉÔnh©v"£–¦Â„»‰zŠ¡¬òÊ€ðã£ZcX§÷ŽÍs«ãÏ;x´.ðO_äs•Žô™²ËнãŒI¾Âès]¦w¡ê,!®¶×ÿ¼­Ô¶ ÷»´|¼­_nxÇý.¬Ÿ"åNùÄ2`ͱó—íZôÌáÏMg<Ò®ù¬Sž¾ÔâäŽUç/>9·š½`Œ-Ë2b  êe« ñ»Ÿ’e2Ù׫ 'ž¡Îdr-¥<[ЦãÐP'Í F™.b\=±º˜ëc†žb(«¼²X:ÓgìqïU·ÿæž:3wm‡.{¼¸>K¥>~ö‰þ,§™çOYˆ@hê^ݼ(ç‚’&¯þÉÒ’Áón4ž}aÙ°аA›úK»|—ÆÉ+iV–|nìØ›*y—!Ûwù¶vôlÕº^󎪔ç¯íyŒÔl€J¸TŒ<Í%;^ÊdÞPx?E Ê… ±/S\«ûփ݀¥3§¶¹àÔ5éÕIswìÚû×ý¥£‡/itgU+¾¹Ä¡^6AÉ»Z@VÐà©G'zÔÂÖXЍ(Ó>ðÅ5à³,×q”‚6®n¬§_l²Ê%K–&£Ì.ÍpƒÇ¥'ÓLÔ…°¸>%سg—š¡`HóÀ¢öäËò§„’&¯î*Kº§¤ÿêï&g_ø¹ÀÁ§œ¼Ç íÇ=Ê+–É(V\·;³ÂŽé¥-RA9[|»ò-eÇ4w6¢‘hC*â;¢b½cöêü¾ØämÄç·» ?ÞÜݽæœÛ}÷êV„am3>ïýËTp4á„YFz=MîäeõaÓÌxZtqΠ‹ÙjXÖ¯Û±ýµË‡ [iQ]s‚÷úY28›æœHr)UæÒÂZO1‘Ê*—,F CG©ñm…c,_ä„‘ç–-[¸¤ý瘕ëGØf‹°Ê"œ«€nTr°LâX’Ú$¿Y$÷ÍW+š¿6;ž” cûi)9¦"Q ì‹`Q(ñwÌê»/“#>påÂÄa÷u€t)%°_lÆ©±´©Í›åUò17&PØŒÎU\†®Ø¿w˼æÎýúLŸ9wöÄ¢Ø Ö7¯ôjÞ.UÂ×Ë3âHÞžúŠ¡¬rÊ[õñ°çbv9´iQÓ£‰äOѪQVˆ,º xرGIª”G?ëYöêÜ‹³ÆåzÀ/mµMéïÓ5””žc¦¿Mš×ÒÓ¢¢Qâ±L^^¢2-2’úM}upu_îЭ“}Øî€¤¬¬;{ï˜V÷á[.Ÿm¿­ï_û_…EÜ 88xìÑ:¿¬«Ã§ø•=¼ÔiÒ\4nÒ¸žL&ûrc¦ÏÙØTí“æõ¤S·í«Ìâ6vž½÷]T܃€>Ãö7³ÇÛDõíÖcà¶ÅPV¹dᪧ'Ö;:¨Ï²ígbetBèóÉíš ÛðªÀ¾[´j”,yuNi´m˜Û•ñ#ÿ>|#5#þæþ™£®HUòJš–ÒY0+åõšÔAÍŒþÚ܇8F–cÊd²[WbœG¸p¿‹à§DÙSª²ï˜Ý6hÚˆ#—M¸Ã3v¶êëÛØk³³{«û‰ÅB»ô»tN>iîî¾»ç*Uoý˲M‹úiOË,M»¸¸Xr¥˜,--ˆô¿ 0ªÚ/ðVºÿÔM-7ŽØ»w¹~ßš~\VVrr²PZ Ê*¯¬¶Ënî4Ÿú×òqK§°qªÙ¾÷Ú€éžßÖk·ƒÚ¦Ì"Ÿ«dɧv\tz.o†þë˜6jå{ñÄÄÃNrò&öŽÎ©6:ˆŸ[Xÿ¯ ÚYùhsíû»dÉœ þo¶D¶c•žcÒŠˆÝñŠ»¹ˆÅ(’Ÿ"eO©öO,44ýüü 22ÒÁÁAû¬™aÉÆ.–‰Ê,R`D€ )ç"íô"“×iF)ã n |ÄPVye)%Ja¡ï‹v®â£×« XJÎâ"ž¾AÍ?›¶ø_à]~‹=yh;пÁ•!göÉ~ïAé9fèÁþ¿\ôè@=å½ÊQÞhø©L&ãf4î011±P¯2000€Üóc!¾—©í– Ó-@Ã-+W®œ—…Ü뇊ŒžCd>b(«¼²Š0_ù\eÆéý 2ývP­ùyΗykóݶfkÛIÑÝOWàPjŽvoüÊä >yV¨ð|¯ßËäîeËàDDéQÂ}UÐôÊ¿EÒiÐìКÇ?$u5-fòqÌ„7{:ÿ»Ï“ ‘‡"¾/da_&¨8NQ­ÓŒÑ¥| q£ß§•ò)ˆÒ bíËD â»@VÒû2 Ë,w‚‚‚Ê» ¢Ÿ"*yÆ21Õ?Ëb, ˜æ³åË,>ªGžˆò¢¢9Eù)¢ÜÑ#–‰ lÎÀ¦cÂÔŠe"â§‚ýv ƪ§äŠe"âÇD;–ɲ€°Ù{»T'˲˜ê6“eY–eá{e"¡?Ú±LŠ" ‚ÀrßP²€a¹ßcÀMßq,@ ˆB¡}ûÇÝ>°€Av,“‹dª=þò¬\. …Ú Q,@ ? |> gºT¿±Ì™0¹UY’$uO™(–‰@ ˆíX¦‘‘Qrr²P$ ðì$ ÃTKµE%%%„P,@ ?Ú±L'''š¦SRR0`EBQö ' ,À²J¥299™Çã™[XȤ’ï8–yî|@yWñ³Ó˧GyW¡¢ƒüQî¨û©ÎÛ?†a3y™†††††<O"—gI² …¥¥%·sS›ï&–Yß³.ú¨¢ ªhNQA~Š(_ ôSš¦qwqqqqqÉ_÷µ/ P,@ ?&:ß1^`Aggg@±L@ü<|¯ßËD ~S ô½L¢B€œ¨øÊO Ž{÷Z¶l©s¦6<™L¦ÂÌÿëb2Zû!"&BFiK²”Rï: –RS e•WVÑ(ËsJúøÉ‹B‘'½I"=µIãn<ˆ‘ªKÃ1³"îÜM”ë)Œ@TLT3šúL§‚¦é7nDGGß»wÓõ!íù‘'‹ÕC˜y­üF\XÛ«u#ïîCœPO¹ÍoÆÁPõ”¸ ãC:x;;9{xu˜´ð¸ÚÀ´oÙÜ[æ-Ú¾¾sï€O“Zæ¦æ•Ý›øÏ8 {°ÉW e•WVÑ(Ës“ÌÈýúä~¿X0À[‹gY¤F‘‹c‡ßÏÐ=Ÿ©kZ=®çL…‡ÒtL\,™ì3)*÷¶D ŠŽjFSŸé8X–½{÷nbb"DGG?|øPgqùQ¯X&K§ùNÞðëñ _›¨®mlÙn¤­d„sÖéÚ)G•pVÔ©¶gyŒ^uio[iØý飦÷¢DÇgwJú6$üËâí{„9ïÇð"‡2>hÐmlƒ©;žþ×MrÝ¿{0»µ²§þb(«¼²Jü/^âçÊ ý»«\A«ä3â¾&HêoXÖM]À”2µ»@Zµ<ªë]Vç)ÔµÀƒùƒ¿öÜà%b¤Y±¥è˜Æm×µZ9xQ`À¬F…h#¢¼Ñ3–©: 122òððÈy ­n°èèh¸~ýºŸŸ_LL |øðÁÍÍ-W ’Nº5Zþù9ƒ=-j]œuùDwZ3¢ÅÈ)7*ÉÝÝ=W¥ø†Íá‚§7èúÂûõIüN÷&k¿D¼Ç¡(|øðA}¿×掋’‡Æ½_ÊÆŽuîtôN\Bccz©|ÄPVyeéóç¾6z»z'3Q1ÿ”úœKO‚‚‚4ü"R?þZ¯ÓÓÈ/ÏàáïÍG<òpR>òç†ÌÆ–òq,P%}ëYËgÏëÆÆDi;¦2ý¶›çÔkﻊò¼¶Ö@ÃOˆ2FÛOÕg´ÈÈȺuëª6™ØÛÛ[XX¨ §¤¤pó ³³sXX˜¥¥%äžõŠeòp#†NÏ HP2B3žÐ¿ÖÚ}ênÉÒ’µo’=fU¥X7ZdÏg–^EêS¡iKóeò‹§L™’ת”6,µäURÝE£T)¶^kªôœÿ¢ôCYå•Å~¸´iHß®›´èÿÇ£¸o19±Á÷c´ê°8ç*3^œÝ8fXÿžý—nþ.X<{V„.ï\Emq–“Ö#PúŽ)0m3Ø\²ìq"wXX?E Êüc™111orÃÍ‹êŋ˚µkg†ÍÜ|öùå݇’ùcêX|>3uŸå¼Y-+©‹)³‚Ó(ÆÍÓ\•‚á†ÍL‰AIö2Ž/®yãäŽßwiؼ½ÿÔ5Ÿ%Ù SY‘·Oœ8ñI×Ó :Qd¦’L톖j'2ji*L¸›¨§Ê*¯,?>ªá 5†uzïØ<·:þ¼ƒGëÿôE>W™ññàHŸ)» Ý;Θä+Œ>×eJ®¸£ˆy¦FHL®«yò¹ Ug9q}´½þçm¥¶]¸ß¥í˜àãmýrÃ;îwaý(wò‰eêY¼(±LXslãüe»=søsÓ´k>ë”§/µ8¹cÕù‹Dέf/cKಌ¨¤zÙªBüî§d™L”$‰Ý|+mù¨y›ÇI"¬™Þ©åû »ÿâ˜MÇ¡¡:NšŒ2\Ĺ®Œ«‹ù·>fè)†²Ê+‹¥3}Æ÷^õxûoîàÙ¨3s×vè²×Á‹ë³TêãgŸ8áÏršyþô‘…„¦îÕÍ‹r.(iòêŸ,-<ïFãÙ– « ´©¿´ÛÈwiœ¼’feÉçÆŽ½©’w²}÷˜okGÏV­ë5ï¨JyþÚžÇHͨ„KÕ1ÀÈÓ\²ã¥Læ …õS¢\¨û2ŵºo=ØX:sj»‘ N]“^4w—Á®½Ý_:zø’FwVµâ›{@ êe”Œ±«…X,n<çॱ&îÜ¥®óòn¸yÍ •ló´.t¥Å5à³,×êW”‚6®n¬§_l²Ê%K–&£Ì.Íp#ûa“dš‰ºð×§ä{öìáC3ìÑ b>XÔž¼`xQþ”PÒäå~²¤KqJú¯þnbqv𵟠|ÊÉ pÌÐ~Ü£¼b™ŒbÅu»3+ìø˜^Ú"´‘³Å·+ßRvLsg#Z‰6¤"¾#Jµ»ú³Wç÷Å&èh#>¿5Øeøñæîî5ç´Øî»Vµ" k›ñyï_¦‚£ 'Ì2Òëir'/+Z;z¨MޏÀ¾…©0ôq2~ÊÕ5'x¯Ÿ%ƒ³iΉ$—Re.-¬õ9 ¬rÉb”Á0tô˜ßV8ÆòEŽ@ynÙ²…KÚxŽY¹~„­a¶«,¹ èF%Ëdw[VX’ß,’ûÎæ«Í_›OJбý´”S‘¨ÀöE° ¨h?óôéS} >}úÔÌÌL{~Ôw_&G|àÊ…‰ÃþîëéRJ`)¾ØŒ!S0biS›7˪äcn.L °«€25äND–*‹VDÜNS84¶„"€ Ö7¯ôjÞ.UÂ×Ë3âHÞžúŠ¡¬rÊ[õñ°çbv9´iQÓ£‰äOѪQVˆ,º xرGIª”G?ëYöêÜ‹³ÆåzÀ/mµMéïÓ5””žc¦¿Mš×ÒÓ¢¢¡ËlÒ¤IKuš7÷jÚ´Aýúu<<ÜÜjº¸¸Vs¬V¥JU;»Ê +–ÉËëL2-2’úM}upu_îЭ“}Øî€¤¬¬;{ï˜V÷á[.Ÿm¿­ï_û_…EÜ 88xìÑ:¿¬«Ã§d2Ù­çùµë²ëÜͰØä°7÷gí-µh½ÄÕP&“}¹1ÓÇÇçllªöIózÒ©ÛöUfq;ÏÞû.*îAÀŸaûŒÙãm"€¿úvë1p[b(«\²paÕÓëÔgÙö3±2:!ôùävM†mxU`×/Z5J–¼:§‚4Ú6ÌíÊø‘¾‘šsÿÌQW¤*y%ÍKé,˜•òzMê fFmîC£ËÆ1e2Ù­+1Î#\¸ßEðS¢ì)Õ©×¾LŽõ½¼m×]ì’½¶C)¾Léëû_D¦³{«;þiežý‚¾”ׇ&ÍÝýðùGA¥ê­»ŒÚ´hˆjZ¾¶qöÖ‹÷_¼ g ­ëyõZ³i®«!bnNô×ó©g®ô±Ìs Z{¿Wò‹ÝþS·ÜüN`ïÞÁgü¾5þ܉þ׺i pPÐÕ©ù‹¡¬rËbd'VOýkëÙ/‰2§ší{OÛ±x€Æ*dĵhÕÕQ˜ë¡ž¢U£¤È_&K¥ïúk†cw3À´Q+ßu‹]F ;yëÆix±pðì·Ý/ª]*ühÿeÖv¶¯¬¿6yêE·s}|jKd›XzŽI+"ê¹µù÷å‡6¦(ªŸ"eIû2ëׯ¯þ:Y†a(Š"•J’$•$MÑ$MQEÓ4-“Iµ÷eb¡¡¡èççÇ}Q322ÒÁÁA{m63,ÙØEsU™E ŒЂ!å¶p )Q¾hø©L&ãf4î011±PS¦äž ñ½Lm·n y¹%ðƒ¼í-4z‘ùˆ¡¬òÊ*Â|Yäs•_¤÷Å 2ývP­ùyΗykóݶfkÛIÑÝOWàPjŽIÉÃǯLÞè“gõˆ ÞßËÄ0ØìcL£`™~/ÓÕÕ5¯,î6¨ø”phDÐôÊ¿EÒiÐìКÇ?$u5-fòqÌÇçætþwŸ'A£%âûB¦ß¾Ìßÿ]õˆ>Lj#—.]Ê]¦²˜î7Í–Ñ÷2¹ˆ)ñ]Sq¶'Vë4ctIèÉß1§•Ä)ˆ2FO?ý矢££ÏŸ?ÏvíÚuÙ²å,°,p“¦îõ¢Â}/@ ˆïYÞï˜ÅqüÈ‘#M›6€ÆïÚ¹ÇqŒe1îK&, ºÞ1[ˆXf¹TÞU@ €üQqÈ?–i``pîÜ9??¿mÛ¶‰ÄB’¤Y Xî[ÓX¹Æ2‹ê‘'¢¼¨hNQA~Š(wôŒerX[[_¸ T*IR À›óüO_Í,£X&@ Õ<ɌΠeêŽeú³@|èõt†aÀ 14b™ª¾§X&@ ú£×¾LX6g9Ãòe–økÅønÀxª=%,‹åÌž:…uÇ2?|øP*UC ¢üxþü¹ž’†††Ú‰:b™è™7@ü0¨¦9këÂ}FWßX&@ šû2÷ïß_~•A ¢¢“ý½L{{ûò® @ ”\ßËD ‘?|¿D BоL@ ôM™@è}œ@ }@±L@ ô-Ì"¡hÊD B/tÄ2¯_¿^.Uù!éСC2ßWƒÿx~F!~N¾»Î\öüc‡¶iºc™={öV ÔEM¿[ÔÛêöíÛz†Š+rƒÿxAQBüœTðÎ\öücG¦éþøè2ŒaîG)×ùûF½ÅŠ\°B5øgÃ(ÄÏIEîÌeÏ9&phšî)S§IhˆÑ‡¢5TEnðÏ"@S&¢0TðÎ\öücGUÒ½/S*•ªÖGBUCé¹íµâ7øgÞ(ÄÏÉwљ˞rLàÈÇ4ݱL±X¬}PÑî +,ê@ÏUþ Þà?žEP$£?'¿3—=?ä˜À‘¿i¥¾É„e¤¯_¿.¯Ø.™•,QV”Àrñy{âÐtEy×¢è$= ¸’Q¨"dÖÛw_RJ©>Ä÷BÒ£+á¤zŠ"ýΡÓáåUŸ’½?t"Xu˜uõÄ•`¨”‡N—_½ò#ÏÇÔI}}õzH:7ëÚ´ìÚÜJ¤H}v÷I2—+0mк‰e^eY*388¸E«Öé©¥8ð±¬"!!ÝÖÖF=1íý(A56ñ•c“6¦<¬°:)Id"kog”»‰X†žº22#:°­,Ö«%õäÕÒQ³ƒâ¹ŸwðDC#‚K´}Û†=Z› Õ…åÉO6œSÎð÷æ÷ìØAæ\² 5Ú×a¸,þö+¦iS;Ý׆’¨À— ½-E%eŽŠ“³¾œwÎ5yçÒ£Ÿ5²¬Nš7ÜU»HÈæYßOº½§€§Øµ-")†à»",=£ˆÌzöû´;¶oÖÎbéŒIãÿôÞysB½o#­<ùü?;Û éë¬!œôtÅÔõoó:‹ÇëgÔÍ5\ç?p”’û™OVoû¥î0ýãáýêÛÙžQÆ­Xµyؾ\:­ˆ<}>8o5ßhÞ«¯½ç~ëcÞ4ݱL.Qu*võîYϦ’‰x"1šŸåÜ·sUIìÍŸD6–üè¸l=Ê´¯QÉßî„h*"""âb¢U‰B˪U̹ꔒ–B K'§*VˆIŽ–GÜ;v ·\Α¡pë×HùÉÐÊ"+^Î&RMKnž¬Õ×Or É@Òç—OßE¤¤¦‘ ÏÐ̦zíu]¬€Ùó÷öoÉäèW_gÐs•_£Á]_¹sÅ-Yˆ™°éÓwpbŸSdi«æM7ÌžAg,YfÎçQ,¼ÝýûxÅ?ëõ©LF±,°ä–­;Ûýâ'âçb”±Sþ5èDI’¯Wþºð]ë“û†åàgÌðçñ€ÕV9SNñ-J±9Jq²žYúùàéWüæ¦޽½lÛ‹$òGî0íí‹OÒì êóç£lF(Næá„¡·R¤$i¢R®1̸Æ36·r¨ÕdÀÈì  ÔÆ¥’`”J%-MK•R ©JF™KÉ“èØØX0¶°Âå)ïÞ½SWÅÒ’c'þ4h€Æ)jvîañó´‹GXVªìPÕ¡AÇ}½³/5 kZÁ±LRzâtznó>ýŒ¤”ȶFÝZV¥–å e´ÂD„@fÌËàwfuÝMsĉ† ÇÇÆ¨ÎòJÒØÕ£²€[2eYÅû [ϰZîÕ>}éÛÝíӻǧC";thQÉ uþ‚îm°5;÷tã€Ñ|pvvúðᣪU j;½ ¾C+í½ªŒ…š*Ä mô£ëR×ÎÍj9¤} '€}wçüðô:m:÷òp3bÒ>†<ÿïÆE æÛÊÍ„ \Û9¼¾ ½Ý ŠýÖâE^å—$ëîûíJÓÖkî¸~ý¸ßWÝúÒ©g¿J†Ü¡©PHð€°j´#`—oÛá ª]^ÖµÊøI“@™¸eëÎP\sîPU-×s}[k# Sc£c3 "— a×uM›Mc7¾97£avS–DÜ"åñߪã«‹ÃpLdåáíÝX%e ɸª1çìŽÌZñùQºA³‡gv?ÔÔOÖmÚ¤–¶E–ûÿ`¼jÇ)¯ªÂ·O—ý9mDÖöC3¼KÄ(ÄωFgîß¾Õ[©æÄ]Ö_]ßE;ÊJáYxšà€†3KÎÛûYu×Ý>§Æ¶{ÔlcË+–½KJ!M Ÿ=û 'ØtÝÎi•€c´,*$Ä*X:$$„“‰VП¯~ Ñ YÑrÿæ¾ÀR©‰ÑwÎnÓûÚ?7Nµ1–ø˜@“‰GŽ]Qd¼¤å‰§NJ}såÊ›T*+*5åŸqã YFÎIãÆ€©ûµ6õ\°À3W[)¾;yeÁ‚yKî$iÃ+º³Œ2!:êKèÓÕ¿÷9ØbÐŽçT"ðšVðr"_èä;°º}%sUŠP$¾y1ÃØË„–K¥rše†Ê=ÈKN3&¬S·¾µ•¹†žÛgO ì*›f%¤çž YZþþÝ»wïå¢Þ¿ú»™‰‘$J 1_2TòÍY>Ó<‰Œ ÍfEÞ~ð)¡¹ÿ¬Þ‰ñ¼ª{óþÒøëQa¶^ÍâSåÖ '>)ôN¥–@ ÑÀªÏ¹sÙœÀ80ø|ûâ'™ #KJˆÇ @hÚL˜³î(4kxðøêLG;•yÚMx™Ev1ϵà@ÉÞO=½9¨vþu¨?yæç“Ã'ßqiÞ¤™“ËÙ´úUÉzó×퀇ó»%Õ\¹sv£|„5,ÚQcì‰ÎõœÀ»ã€£çlâ,²çæÒ0 ñrúé+*ç.Su;òlNÏy2SmaZ3¾k¯½·Gº˜dD¥˜Tµxù÷¤=3Öw¬ Ÿí‹k? e¥¼§ŒXwtq÷^k^=X³)©ýý1õlË1HŸÞyB»cǺk¢” ‘‘ÀRTdd$—žHҹĴFœ°õððÏ–m»Dy5Üx(¬Í„ZPÒîÃ2ò°°0RšÈPáááö½VŸ]b}cÄ/û~=»¿%}W¯Ù¤³gϪäS^ÜW6ëâ>é]\q`©±cÇr¹£Votz{)بUwsvñEN-[¶Ì9ñû¯Ou1xB­[ÛúÖ4="p/óÍùõGS¹£Jíz5V¾¿J «oMfFá"‘<ñòá#<\äìäâüác˜ÈÊÙÝÄ,ìàö£Qmeb›V-ªTw¶( #üæ{‰Ý”ñÝM”©¡^ój3tfVzª±Kûàƒwé¶MA<ÂÅÙÉØØPC• „|µ•I|سÀëï?FŠmêµêÓ¬©§™€ýöYZ˜%YÆ>f ê4´E‡ÊàU`„ȦCïšI¡Ér®ÏQ&µ: måhh@b©±¸ Š›@y=͸5¦TÿÑ/Œ[9zò½X`Yvù¹ËdtTD¦ªúލ*MŒˆ0°ÉuÙeR½«‰Úa½7BKá³[ñàg¬.–¼Ž´Ò@ëÖSI‹þfÒµÏ7yW*®9úvýßïSk4Å€GˆÓ§4oŒR*cD†"°¤m[ÍÎsõðŸÒ·=ð|³rÚÚTõ,#‡Nÿ,¬Ó"1~íúMrd ã$Û¨¤%nâç„/àZz^ NrZ^MC’¥37ü6˜ðÏHyJ€wu÷ž]·ª£ \~:þ{¶¬7jÙ§%äL™,u6(¼w³\áI£ªÝ¯ î4ù¿—Ö¯YûpæÔZñ‰RÈLV0TZ\\ðp±õ· ÛÀ¦³¿s •1[w]ô÷÷çÒo]€N¬þÜò–ll Å[0ÔÒ1»\YšT*••{n ì ðn}ÿ?“f,iÀѨƥ½[ˆæ‹\ù¬lð„YrŠKL{ÿßÿ–^3º•JXâqëÇ_÷[Û²ç#?ßîÞF¹û*¦QˆŸí œjˆ`Ñg’e+k«÷a†LZ;vàuã_¯ŒmB’$nܹ•Áœ÷¢W{Í`ãºßJ×܈¹’¢8d.àJQ$ÀîÚg“Kû‰“&wm`¯RõìÚãÓ6Ô`L6õ{ÔsÀÊY÷¸ô*F§~ÿý½ö--´5ÊXÛ·ïZVÉPÉ}ûöÍÑdæI°yùÍËÒÙ‡,ýìÒú“é&‹FTS ”ä˜;–I10sÚd%ÃÜw+[~ܸ§ÖVÌkò ER4oâêêÊÒ™,†»ºº€1ŽÑ™-@’Ø¥jˆF¾,{iï§”u, eš^û2“ž]øïuöó®ví{×ÎT†ý;¤s; ƒ*¾½L#¾H³WÉé©Tæã‡á-›x°ŒÌ-,’¿„Ó©,K3tJ:`”QƒjZgÆDâý!ÃÎ׆’¤qJ -„Ò¯qSB©û€a€a€ Fó1 _4g*ЊŒôôèÏ¡r’Ÿà/ZñàA¯ çfÛiIËÓ$”assJ*%‚¡2–5u5¡²’5à jÙ‹o¾ØÔ"’âGþž.øeÂ.kÑÁ¹‹—ï=²§º<ËdîÜsu€o/††?À« §k5ïÙÌœyòµv¼¦¿#ï —Œv3Sü/³d­2çO§]Ö-d;C ¢=”@töÌMƒ>»Ú?™­ ¢žGæÌ_%òÌתNÉkÓ¦÷ëÓñi«Ÿ%º©DáàÌÝ@_^?}ÅMrý¥S ÔoӰȦþ¨+WîÚºcï‚ñ›×¹ùOš5iÀ· i1Büœ¸¡ðõ¶b‡ÑÝlŒTEÒC®N™0?E.·û_+Uçœ<²ú‚_…mšÚ{®†¥QVäÒ°¡»qvg¦ >`Ä©;—v.ž5sD×½~_4o¬üb³öóX\ÃÆÞkSÃK´êZçÓ§§jWREå+/_ÎþMIßÕi4ø²ê87Ú£,ñˆ¯ïU–V$'&4è3¨‡åôý·oÝÚ~ä¸!Ž=ùŸÿ­)þ¨b,‰ÝÃx|‚+R®øú>`X*Õ××bÓÍøD¶Aè´ ÃpÍ'6Ìã&M¢¸týMÓkk„eý£ÚØÙ™fŸ2Í”J ¼fßÝ·žDÝ:Èw777ˆúúm%V™þæÓGã^Œâ2àÔáCò¬LnâšÖkÞ›ÌIÀȉ¥YFúZn8ÁÙXÄiÈŠ‘8òD…Ø9ÊÃØa_t.Œòp£!Cý\œ T’ð%<¦…–BZ& 7âa˜,FFW¦ó)E,•Ä#D:–£ Kƒå's|Ržv›/¬:eÊ”A=»o:sá˜᧬[ì¡Ø¹ç*ðp³… Àª;9·¼ì–߸Þ)Æ…Kçx÷òŸÙÿîfs<»¿((±½^ýÛ ²%×Ü R4 ¬ž:¥ÌÚÖÞ]½x3M,#¿z5š¿wÊ^ÀnÊ »¸nÈšÏcÛØÝøôòyFN¬zïÁkÝVne¿¼}ú vý"¦m‘½çÄE›ÆÍøzzǺ%ù½N:¶ã÷º%nÁAIßþ¾íÏÁìGö”éw­]{ø6gýæ[nT“t}ä(F€[ãêðxÅIŸUÚp¡ýoKöuïqbƬåã×»¼Âçîí–"Só…-ë7Z6Ã&ì3kmÿdñŸ{âr3–¯km"¤¤ïºõž’KK«ìÔ©“ÆY6Ÿ¿ä*µ}GhÖ~áÂ^Ÿ_ßÿUnäéœ+¬S‚î#M8èÝz¹•‹ _à8sÓz·Jõjzx˜àX’˜0q­éáj–a¤ùü -:;6“e²6éuìØ1XØÞKCFŸQN™ù„fY“ªÜ¡þ¦é5e¾9qà™‚‡cÀ2J¢R‡¾m*¹µkÿâÀ5iÃÁDê§«Ÿ˜>Ójòédõ"ɯâÅU››šñ 5ëÔÅ2n2# l­ñI 㧤d ›vOäÔšO…+i`謧)r‡¾–´4MŸªÈ/ÈRª²óÇçeH(Æ€ ºˆñØGïyƒ ÷=:Âꮕ’Ñϰb„z²¢“w€RH`@e¥×þwûŸS‡£xaÎ罌“Q<Ârõê¿t– Þ3a_LÍ+£ÝÀÑgCß]­MßqzíC€J<)Q¯g”I \`W°œ~8™¯ ç‚å=X®,î{ßJÈ?eV9·cšIÎþQeFÐÀù·W;b±cÀm€Kö}e¯¨$ôÍCû#ÄÙQÏyë=+ñð¼,âV0e“"tÄöéðûµÒ0 `¨ä•c~cÜýfåì˜dȨ(ÛîWÏ÷ó0ͽ„jãƒ2ãñ‚ûI+ï×Ñ©¶Š—ïkíbh3ø¸bð†¶;”Y'ÎþôôN›ÿ‚îfŽ_3½Jö|¶í·á_å ˜_ìvøða•’ð€e¿í‰,±6–†õ[5»¯‡*Ë\ˆƒ®ÑØÕ«W¿^½ú=vÙ¶wúξßT¹%è>V¾— 4‘nÚ;ÌÝλ¥›5e2ŽAbtfÌòY“ Jú@ûAEžP(di& A×ëxôåâîÂ0Ü¿jvêoZž±Lõ›S…Ré1ffo aê§=;Ù9Ú¡_M:7¯rxÏ%+e„[‡¡u-x‘!iä·‰òû_2eøåÐn¹V:1_éìb2=CN’Ô±Ÿyð¥£iüí ¸ú#<¨ôI²¬òýý‹Y†µú9™d}ŽUH¢_¿Ó®d&ŰªX&Űr†Õ–+,¦+ëìåov¡ÿÝOm‡}SžòñÞå×Y}ûtñ0$Êq±-°J¥RY´U~õ—ffÎ8}±ƒ™0hlÇý¬Í€þµ²Rîá¢ê4IR,ËREó«UuV¤ª»0,0yy¥ÿôß:m I2¼é{7¾é6¦çoFW¶ W#Áƒ÷©d§ìΑO,3ùmºÀÌ•$IõŠÙ"–e•ÃÒ$§0ü‚ٷª¬ïN.I=£Òæ#–ný{juS`âF/17¼dX–¦Æ-_­Ò¹ m«Ë'Ú«–¿’d4,zsñ IûÁ9»Q-ÜŒ•+I+ £?'Ú9{i‘LX:Â÷|ŒË¾€Iœ¿nÚjáš"i –¥(mÿb¨¤Å~+^ÝXŒ©r)’‚\}[C’Ì—×i6#Å €À¸£Uúâ7S(Œ]Üj¹d\ÌøM’$ÉSÓ쇀žX1þßпOÍ×õ×¥GwLê?êϘqËg µàó€¡HF×hð-æ‡;®?0Ù»ÇÊeÁ>4°âJvL0'h©‚âÆ.Åï×_ xØÓÁ·úû®b$‰ÝüdMv}T±LyÊÅ^½ž0 •Ú«W/ˆKS4ÊËÌÏ.Èø8zöm»vó=„Ù ®¿iºc™@}Õ p<#:22NF)Hñù|‹¤¯ãÁ¨–©(-:RÉÃUïZ‰vSi\wR7“Í»¯5ož}%“J(µ{@>ŸÕÛ·ˆ»qà@’ܦaŸvΦ1/Þ‰Œ {û*YPmàh_‚JM$ÇS¦¦¦„æ•`8x|>Ÿep¼²¶9_Y@òpœ&•r¹L!WÈå²¦í»˜ð ·Áض–Éã7Ÿù^Ž| n½’/_;°§Ž—Wekk!ùôågû¦¿4¨éI±ÿUjÞ¦2K+ù|¾zCÏU~çàAŽÆçóùüÐK;ÍkýÆçóq Ãp>ŸÏŸ>¤çŠûÏêýðèÍt6ìïÕµîšÓ뻨-§ð-šì Øzüku®Áë qŒÝ÷‚?={¡Ç€RDÞ¹sG%Ï#lÚ¶ªïÄ»L¬ÍçóÙÜa›¢YIJ,Ç€Ç籩û–Íþçªtû»D»a<¼í”½’uwè1hÚÜéCÛX[óçaçªÍðp¾zІE´2v÷¶ÍA›Ïž>¸~‡ÈçA뿪Öm ‘S¤˜F!~N´;3Ë(îß²fý®D»¶ÿ[YËX÷òŽaŽkôجȠ9“§†8޽4³£úÅÇ!g`TçhœÄßÚð> ¯,Þñ1³cΰÀ `<µCEjÈ¿‹ç~n°)àh#ã/ 6«»õâ¹uSÇun~Ä„‰Cûµ±à k4À0žJ¹Ëˆiµwl™¾ê»ë¸´ÄÇ‚À¹ºszjÖö0Ʊ$߸º»‡‹Y†‘@vëñy€a¸‘u÷‡Úik½Q.´í¢ŸïܹÃÒŠ„˜¯Ÿ?<:~þe“!‡Öõãó³§ýM+øã_\É/7.]'%ééiÀEjtà•›ai"ïž#š;P—/Û,1®îääæVMÄÃdq¯¯¾Ló=Ú¦*Ó#9(øþe8qä(¦Tðp†Ë04C×iâeÈÃ0aå6=Gf¶N6bIâ—¯áßňj6ëî×¢©1“ñ9žaXžÀ±}Ç:Uì5÷<Ý>}Ò–ÀY†a€ïÓµ]B–"5E"•“Ÿ ÅæÆæb±È±jÕ̘¨Bíý0¨æAß‘Œf˜ìw ¹{uvªñ9øYÈÍGJ–gl^©Uï‘]½kJ#”4ÃЙo$tOO+Er¤z|[ÿ3j:$À©¿W>à±á@SÏo¿.~Õå–܇XS_¾1xEò]„<†–Ÿ\7}éáð¥'®¥ìœ0v Õ§7ÄV²264àã<–"år…B!—+ž=pò÷2Øu)]¾$Nñ‹ Áu;ÓµkCT5˜4oÝ¢6­øº7^±ª•­ÆSE·ˆevuïMÚüï7câ-ËË2 ÓmÊÏfǧÏÛó¥_K—œ­Q Ëõ^†¥3ƒ_|©TÉ"FÉØ£ñ5Zu‹0¾íÚSg7-\¾oí¬¹QÉ|C‹Ö}'/þ£=W¤øF!~N´;ó§C£ÇoLøëŠ©#: 0Èë É,pü[nüÃ='Þôº|ÕàÖŸׇi¨¢•Ñ"»ZL÷X–ñÙzr€½å%^¯œ7-gÅë,¥;Ã0 ÃP©;W->xâV^.´%x””átbüJÓÿ9ÓýÆþÕÿÌßµÎ*àîÉ*B\{4p¨bª^ëÆž{dÓ›¤‰µ-J|Lxÿî#–þÃ06çÓ«–.&bâ%a[Ö,2™ÏjrY 17WŒ0ÉKyƧXvP¶m»*™¼Y»ö `„¹•u%»jK¶MïêíÆËiíB™¦×”ɘVsq㓠ƽ‘±åÞGxîÞãG¶³3qÑÑ : ñL ¿wÿ«m³º™iqaaNm‡vu1 ý`dçÔmx=2#%5%%9%U¦$†e#æ.övIq±$ 4%¥“¾„§c ’±¨Õ¡_KG{#:=):.-Sõ§c©ôÈÈtJ:7jbCËät¶mB«*NUM˜ø|Œ‡ÃÐ Í0 #—Ð,S¨8xÙŸz·±ª;cyµÎýšØ˜à"±¥B–œ!€ŒO÷ùö­_c”%Ò™ F#/O¼¼øØÙñ›Ÿ,Ø{´¥¥eYgÿn̪UÓo˜öœ°A„ xÄ£äå'v®fKvzx9ðyä§·éY ’¢h†ÇÃq‚ ÄÄ8˲BÓö³ë-wåëÖîU öÛ/ü¡£2çæŠ½þò6&´+V4‹² ³ì„{§XWÇ1ÈÑ–c×Ä÷ð_î8G…*ÿ{Ù¼´Œt÷Ö¿XhTCÃ"a;qÉú‰”TÎ7©*Å7 ñs¢Ý—m¹ãKó ÿd×a@u ëÆߘæbL¨÷tB\cÆŸÿÓHåö{ÎâdY–ÙUâ~WíÞwpN„Bt“«†›9š¸®<9ßËÙTUmP;“[»a;Û ýò.µ²€§s48–»Z†•¹pá(1áÔ¼I‘©µºnTm×iÔÔKŒxe?Î#Kü|õä˜æuúŽªùB]¡»CçÔGŸQNÝÎB™†…††j$]¿~½U«Vª¶fY–¡)K÷:†‰Ñ©$Ͳ,-•Ù×t'“b¢â’鵦Öv¶âÏ#`ͪºK"¢Rrv1b¸‘±±H( ø|ã.+XF›¤OC— ´"æòÅðáÃÛ&ehÇùx<øv%ÆÒ—ÏÜõ1¡¹MÆ»ðPëOž<éС€÷‰ƒ®'å2žP„åè!Y ŠñîJ ©¾ývl¿¼»kÓ†:ž<<;´Ë´éç42ÎÞåY|‹€¡”$‹óyßú*C*”,!è~(š!$B¢àG¦UUÊCЊˆb…ø9ÑÙ™‹6g¥\† ÅÜCrŒ\F Ū÷ÙªgiÁÈdŠ|N  8JiLPoF™L¦YO–”)xbzŒ © 1B˜ÔÓ®"˜Vp,“aÇ3>J§i&ÇÔÏÞ³4 <\`Td¥|É Çq€Ì˜ÐLü[&È$™2­Íê Ü j§YŸEvç·,Ï_r`FŽízzUýøÇq _*Â*?Ã0¸¡‘ºž’m&«V{–¿½#{õê•N´÷:­ÛÙÔ,»æ%b˲<žWÓ8nÏÆùçê´hYŸyÉÜ=öGñBüœhw沟2ņß6}↹^l£ž¥n”﫾  8JiLPÇÈHÛ \õ©G =í*‚iyn2Ñ4,÷kûYºŒ:J9"ªTÓXIM=2Y‘ߎL¨úþcþ2¢³'Sg^Øx”w®YÍaz½ ¶ ÊÞ¢AùºG‰…ø9)ËÎ\Æä?p|¿cBÖ4ÝSf^_Êþ‘:Š>(3â »v\´®P‘üdzÊca ñýRÁ;sÙóCŽ š¦{_¦úæBõòÊ¶Š‰FCé¹c©"7øgÕ(ÄÏIïÌeÏ9&phšîXæýû÷Ë r?z®òG þãY(–‰È—ï«3—=?ä˜À¡m].UA âû¢/=G âgFw,@ „ºc™@ 4@ ³@èš2Ð ËD B/P,@ ½@ ³@èEž¯eG eÏ… Ê» ž={j¤ F+ÔhE@»ÑÅ2ˆŠ÷‰>í7pV¨Wq–%ê-¨sÈâMõâïò“#…‚kîÇ£Gòi4ÔÓTèÓÓP,¨XˆÅbV‹¼¾ñ3 1ùé²Äb1“–eišVÍ?,ËbV`£¡ž¦Ž>= Å2ˆŠ…Æø¥šlÞ㸪¡œœœ†©^½:MÓ5kÖdÆÃÃeÙŸíÿuêÔasúêiE ¯FC¯eG *.\èÞ½;ç´:ǯò®`9À欕1 sïÞ=a†øÒ?IDAT¹®]»róå§OŸTCÿÏ|ÃÄ0Œ§§ç‹/hš~üø±ÎFC=Mƒ{ X&QÑà\R}äR jå]µrC}×9dÉår–eß½{§ú(#›³0ûs¶†aOŸ>¥(Š;ÔÙh¨§iS`OC±L¢bÁ…å4.ù‹|ÃôòøAi—ÍL…-H“ñ÷ß×mÑÊ‚_þáõa]ç%‰hšvvvV¿Ëä‚y?g,ðzõê=þ<ŸF+ÙžöcP`O+g@ %NÐÙÝï¤<ܶáZšî­Zy52K%uÅ¿£ÿî÷õ¹ÓÆæpôC:—ºò”¹S†ÌÕ½A;8¶à*ITàƒdy1mÑŸÐÐÐ|rŸ,ÿc]hz©V@žxïìÅwÅ×#K¸÷8N«yY’Ì=‘I¾=LVä¥äÅ‹ůIaIº¨Euw-] ˸wq )ø‰;µwîîªCJ2uÿ!‘!O>=vÚ!`iRIeß~EßvóõóóS> Jc@+"ÿÜú÷éSf7æ-¾£¡œVÆN´P)æÀ«e#:qtîþˈßfÎ_z20L%‰‹¥3ÎH¢Êè>ÏÕÕ5Ÿ\‚ }x±(nD^ÚxáE‚>’™‘GWo¼•¿ÌõKc• lè×u^D†¶£Œ›á·”k^Ž·—¶ý:Ô·eÓ¦M6í:à·Þré¸H:×on^Íëéé©OK–ǧþÒ·{㺞u=½|úí¼’ëâÕ²}†Q2dÒü_|úú¯J§³MPïZ*,ãÞÅb™DÅ¢D"L­æõ›?hNÚèc4Ë2$õqÿ<ƒúsš‰yY©_=É$I’¢Y–¥H’†emë4¨küêo±“$ynæ(y»%-Ìjo›ØÍhÝýG»Õ4W)^2*¦ëj/CI’ÒĘDIýuKºK&DGE„=[1¦ç^ï[7̲%x¸i›-×û¯~|ê ŠÓ&%Ë´î`¿ö}|o"<<<ôÓÇT‹ã{;¨é`’ãå–¶ÚÊß½{?N·ÛÃÿZ>¾+ŽåWOšfXšÎïkÑܹ5mkc*f¤g))máG«ÆÅvYîeÄç²N,¾êrÔ i3¦,ôg}¹ïÒ†ùCß$XëW“0o³´ù¦q럪9;r±L•ò2‰e2;'õþ÷|䬹‹ZÖ7¦’ž\?²xzÿ«·æZÜ“&ÆDE§r½Že²Öú÷þ/ÎãÀ™‰ M24äîZ*,©Þ¥Še"ß%a²¬1iDy ÃÃ1ŒGðå¢&“Võ$‚àóxAðq ÃøAÃp>?|÷fç!+„ñr拉O«_¿Ù‰àólŒ>½*½çíü£O] dïÿw&fsP=®,ξȹmÛ¶9g5aÌ“AÝG ›êqk[h–yá÷·¿L<ø»‡XtµÀÓ‘l7á¯Å½Û-ò²œ†,¹m¼ï‰˜Ú‡þ­iÈϱ=W×ÒGa‰ô.u ìiè…yÄȳ9=ö_M9}ã<0|vp×+²Õ{3o<öͳ»ìÄ—)7œ¯mšòçÁxs<Á·SUž»_·3ógVº¹¨™mBð:ÒjH#"/Eö¶¬êØaÒ‚àLŸ¦ÆI‹þfÒµÏ7yW*Yµ ÕëcÞ|TÚTñjßhàÈ1¿vðÌÉJ)‘EgH_¯`f yÀ’ˆÐ_âEmÛÔärkõœzÁ¥ÆûJßîfXF6å¹JKü@wjéÚ»Q‘‘‘QQRù£ñ3‚Ý CÞq¨š/€dÁ—gD,ññFÊr§avóî_vÛ¼æÔœù2›¦výÙ &Þ½M¥^$­oj«¡êÅ‹eù϶•A5çæLoÙØwXâowùäü3‹®þ¦–ÌÝoÛÛjÔæKÐèZú(,ËÞŦLâ„eh÷‰Žù}‹íÍmQ?ßñëàbüèKšE”ùÁ+«jâ,À” [ž½ßÏJŒá¸¤p°€·ÛBl[þžÿÙ­½³ì¥ýŸ3›Öµ€®M¬þ·5JPsuuýôé“FâðùóU¿[›Rd¿V2ÌI`¸ç9Òã#>~üh‡K§þ1)ísèצª£áû·)—‚nØÙÓ›Y­îÍÔÔÆÜ˜÷o¶½µà¶Îõš·õùÅ(mëôM®Œçd$1ºn¯qrowU)–ÉbXÖ<ï‡ßïú`ã=&GXr"Qêö‹·–T®ÕáÎ,gíøZS¦§§çóçÏó:QÉÂÒg“å5‡7ÒÎêÐÌzß…ýߦÌË+‡.þ/óÈý“µs]x©w-ý–Yïâ@±L¢bQ"&Ša¿œZ:ñ±‘*å]¦Ò‘"Iš`´c™4Eù®ÜÞoó½S¿Å$F}N1lò×È/YBàá.UŠdàMœÌ¬Ÿ1WhX–Vr`B†e~Í$kš€‰§¹d÷;’l^ä6)‘X&t°3ØùŽ­aʇ!!!!¡á™Wï^”F­õùí¾›››£8ºF—eS›T³3¿¾ ïf‡%V<ÝIeú“1soµ[qžÇÐ4ß°ÙˆÁ‰OŪX&™õnÒЕ¿m½`©¦D™õŽGXØà,­ {f ¿š»3nåÿÛ;ï¸(Î4Ž?Sv—¥¸‹A)"¨ ˆ'¢TcA vÅ‚%¢&èÙ!Lî îЈ5&jŠå‚%jì)rHŒñc kC¥„²m&ì:Ãì2‡›óýþÁ‡™y÷}ßyøñÎÎû{Ÿ™ÅÜ{V#g¥Û©©Qh(ZÞ]fÜ•õ°®Nü¯V[çÊÚÂ^¦¦F¡¥i¹—G `å%×+x©TYà˜–‚ª¢]1g½°ç»Näo˜Ò…]’--Bs¨‹ ò2ˆ?Íâ0‘8Ö¶Oèìí™=_e^#H‘3èeÊ'ÊKcó3ð ûõK^Tiǯ½)Â@lå¿{ûP(5æNVºÛb¡ªÈ¢hZÖ±•n+' ­RÁ)óF4ÚËÔÖ>:|ø‡G …B¡((xððy9ñÛ·Wƒ¼\\ºNê7ÊÕÕULâŽÑWÏE@áñ™Kó]m* ®—¦ÿåu|ØÒX!4‡ºØ /xGQ•?{üøõ`5Õà ˆyH‰ßåIƒ•ÛÞ˜3mø’Þ=Þßò$oœ»ÌA¬‘íÄDñ ƒ¹€:Š®%cÞÞJ·©,VbûFŸˆpx¼L »qçW×!~ƒ\]]­U[CÚǯžÇûqÿ/¾ý  {ÞSÑ_÷´à…/¼=Å]Ñ Ô¸ÉFÏ‚OÔ¾wöîÖÓvý?çì¼±kî zè™OƒÀVL”ë˲­Ínœ¸ ¡9QÓ zÕ¼²D…‹x¦%[ÒËÄ«ñ6ÒÏdÀÇîœCçÒ‹-ì?b6%­úº™“¸tûô´yÓfx^Iéùê9li ¯°ÅÔ¥åe"ÿŸT?ÎÏaQ¢ÖiÞuÔ0¯ú… ŽýµßÀ>WéÎï·+R—íûîî ‰a$®¸0eÎí«±×ÝR\™_i¤ÝŠ_¯sÙa𪞯Öq”ç•K¬¹ßÿ‚úy™¸ØaÓ¿bΞ1bp_÷vr»aµe' ]F¤6!5ÅÇ fÿ—:qŽRª²kG7Žœ°¸¤Khâ¿Ë ¦›¨˜Æ%uÇWJõtÍÅ'‹<™=4U{hõÌ¥û”ßì^j†càf)ª¼ÿ:¼KÊòvÝ*bדŸòé€ááL>bE~…DîV¿-œ—ùÑòÀÒ{k6ç”°w>>¿"éYÕ°WI&lúGí›äü|öäT¼ÒGZ+l1ué@^&aZÔÔÔpì%öï+ÑP´ý€éK§½¾„”§~§Õ¨‰÷®\õ½L§QÛcCÕbë6dåíð/n…%¯S«Õ4€V­»zÏéÁ#º'ÎïSœž$e¨èÇh-šš_Ξ=Kk•ÏŸ>.ü%3%5í=¿)‰q£êÆÅ¢Žó\ë›RaG ÛrEýüóÏJ¥’=ÁÈ i`M=˨¨õ³äy‚ &jïI(r+•Ý,DÀdÈ?¸²ÿô¹Ë׳U²Ná±I³‚»ïsøÄ6Î5Å'¶ì±kßÚ’VW½,+++{©–ŽšçNSÕ Ó _ÔP¹Xÿ&K€¬OBs-úïý>ÆE‚ëvväT”œMÍÓ›|톯_xsúæ¹cý-rX@™êiZÚ•¯öœñžµ­5®ïí+Ï:ÎéÌéMÓYYY >c¶éJc°ÿ`ý’ Mac«¢cÆöõ²Ò–ܾðÝêÍÿî>.v¥µî¯_×ù&"÷lKšúI÷Ôu㡞´„TMV!JC^&aZˆÅbÚ0+!p p’$I 5wó å2i‘Šr‘$I^»–f%—+n—fb’$Ç'ÍlìÚ@êü(ñÄÍárõï55/5!‰¥“WŽ^|\¹ ЂÀœ†Ïªþgl)=½­s[G;Ù½„„{.²¶ikkßiÍΨá}º0÷WZåÃ¤çªøAíum5ŽÁÆï0‘$EQnnnyyyºòÌÛ"ë^Kˆa­¥?×ú[IxÛÝVú}q­gÝ ª9–_fé±bKä ÿ.¤ÑÙØVN‘kYÞ¼—_^¥¡Ab&577·iM`VóâÂuUPòºP ÓWáà\h9.!j¼+¥ÝÓ«×Çk¦´Ñ¯Ô%f®Iöî½}ˡÑ;ãª5bÏEñÉSƒôÙ/”êÑþ窵ýì™j|||²²²Œ­Y”Æ&bÛ©žG7mØ·ñpÜCnÑ¡³[Ć”‚=˜æ¶ŽœZ3J åÞ{w/‹IÜzkÀâ¾¶i ©°éêb#Dièå_„ ‘ššlhþ„ñì˜ñ]6 s & ú¢²JÞÁ÷ÀÞ ‹ ›píI‰ “ŽY—¸Ä¯ $÷z¶û|´£hkj±Ó/q“ÃÞ—È:ž:XNàÀdcÀ¡™/NLúšµ¶ÈGf~|!äÇcÞ<zØHKKã}UPP3Þ1£ïJ–Â#û û„ hg|]<”ç>r £-CJDðåÝ[‡9rP*%ˆØ)žPx,bî¥Ñ§·Œä”e-;;›7hÍ¢4^hm­77{ù0$-C6]]uZiHi€–ÿ ¦†¡!ì¾û{}ž²‡Ð4 €9u–]ùʤ#ìM˜zâ"-‘ê~Ç%í%@{®8˜¹¢N €i{Ì—«öŽ^þdpÒïîÆ»qçöɨM¥kOmÜ] Óo}t!òðð¸{÷.]ïì’Î>t6<ñh;0Ô¶QÓ’ÍÈȸÏöMüìiÐ.î#0‘¸nß´ÊßVl-ýâÄú¦iÚ××7##ÃHCÍ¢4~p Ù¨(2Ò²çœ;_…ZeaÓÕÅFˆÒ—‰@˜ºC`¥ˆ ùOæ‚8¥Q ¼U Hм„[öÚ¹:çBAYƒ™ò¥yûÅÝà k¢ÕÄ>}Þ!Kgaæää¨ÕêúqkJÓ-٪׎U?]VTÄOd¼ä¹¤ÅAqÛz˜¼‰›éééÆƒÖïEMÓݺu»sçÍZûSßáûSжwD(@hffƒ%à ì§i: ==]·Ù —i:JÓIkjn®ÂMW!JCI&„ÉÁ;нíN™4ºÅ>¹¹¹^^^Ey{{Ó4íëë ~~~ïàOݬ¬ñ/ Hio Zþƒ@˜ÌJC¼í¾اŸ™™É»’%00EŒ sî4MçääY3…âÆÐ Òy™„©Á<%ê¥Ê½³°NŸwÈÒh4†‚Ö²58'Î4¤4B”†¼L´¸~ýúÛî‚IÃ;d1¦‚Þ !¥åe"ÑxÐò@ ¼L@ ¼L@ &fºd"!äe"!ˆ?o8º`­IêüIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axis.png0000644000175000017500000012517013070106167016056 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu\ÛÀÏÄ&Ý €AXØbc= •÷ìŽ÷ìîîŽgww‹ v ¨(‚tmïÌïY†eY–ß³î÷ãwoÍ9÷îœ9sî;ØçÏŸ@ )¾· ñKoâWV¨`H±Xü½e@ ˆ_ cE ˆ †dþÃ0 hšÆqNp ‚ iš±¹?#ŒðJ¥’RÊär©€Õ¯eý½…B ¿>»Ž•¦±7ïS8\=¡ž™™ëÃþÔþ«EZZš(/G.Ë«WËœÀ i”””þýd¬œ­­­9Ž\.Ç)Šbsá÷бLüzòÓi¤!°º©Ty¬JŠ~ü"–ÃÕ326µ²²Â0,߇ýé=VV‘äää¬Ìt™4·i£j4MÓ_¿~ÍÍÍåóùçÇtÏ™qÒ-•R©”Ë剄ÇãYYYq8Vå_Aø=t, çd)äÿé:¤ÄQþ15Òq¬¢«çª kا䯩R}#ssóÚÕ9Ÿâh';,<–v¶ÇÔ?ÿ\Õ%¿ÿôKFFFnN–•¿¦ƒEFFMÓ$IþÔK®P(d2™‰‰ ŸÏ§iú×P~Ëį×!?FÅ \P€1¬N<¬Y³‡Ã!I²CK‡kß]ôŠ‚Q„¢(_§K·>Êåòž•ø|¾‰‰‰……Åìž—Æ›c…OIIÉÈȉDŽŽŽ‘‘‘?…‚ð{èXÊä±þtRâ(ÿ˜é8–VÙªu¬ …’¹>PuéÖG…Bã¿Î³L¤æÊOÀ\Uär¹P(ÄqÃ0’$ÙëülkXÉ™!Ãq\©TFGGÿ2 Âï¡c™(G‡üàüti8&&ÆÊÊŠ)P°Ž•ýÐÒ«ò­ ‚ ~„ Ý·CÓ´R©Äqܧ±]àã&ÑÀÀ€ ‘HÍ [ÅŽVi¼°ŠjuÉq'ÂÀÀ $$¤N:?‘‚%6ø]t,NHrþgGù;¤¢†[G;ÿoÊ­Bqµ \µjU&—dË1ÁWŠ¢‚ž'AêSrºIÜüˆÓã&•Ê*t¹‘|½F7ih%dSä ŠCxÙ¢„ÀP—‡)Ÿ¹˜ÀƒgI¬κç lznbÜ[¹eã*<õce'e)- M-Còúq¤‘kµjq-ê¬K®~"iUP!N{)-®ACkG~±§"w!ÂÂg€Ñ‡ÁÛcÍ×uÕS+[1 Ò”pRíüÝuæ—ÍM ]yY0?ÀæäõðíjΚ{yàÌεùô¦Cÿ^ê§~9)Š\œsüJh×võ8ÅŸÔ¥q(W‡ènðÛQHRVî?sDs­¹%êU>"/ß[Ÿêºi°jYúÇãWwÇê>Z.áÛo\ã\”r… 'FS ± òq ))m¼bR£ ˜¥`¯‚ ôê}®JLœ•®^:/áÒþÃÏû==¯žH+3þË^à]™$ËpÑÁâéÃ=ìa'$¥Ù"À‹6ûdqä.››ëÀ£%¾/-ÙÜÈŽÿþùÿøÿ•{fß´ÖúÖ=–·X2nÃóãÿx3µ^†åà8®P(@Í=g'pl÷Ég'JW|<(å@‡nn•88à$G}9E|`àò{™.V¾ß|ýn~ÇR ±83eÒÒ°mÑjzK#ÈŽËÍüü0£¦W[Ù‰gâ~-,8¾SÉ3"àɤ¥ ˆø Û¯ïm–ßHÞ†uÏ|gvçpˆO§n¬}—† „<;;ËÖ­ëÖµä%¤·¬z²v~sSÁ¸ä꟦‚AQT^Bèªý"¯:FEû<.$ÆjªßLµ‹Ç¾3ÏÕ H³å)!¡»Oê˜@bÂÓJ›zõ{Õ~£‚LʧgoÜŠÏQ¸¹eû6®==ÍëÖïUW†•ª'}¸øZÚ Ë‰|žjQ»¾!Oš!Æu y'Væç˜gÉ2ö+%Ï€O£q5+§gmר_܈;·o=©±![8'ùñŒÙ›ç´+k‡äæˆÚîz|Vž!ñùË&5[9AgÌš–Êß¼OÒXlTœ^&ÍìV¥ìC Wå6ž\°Â‰ (Ze§äÔßs¨9çÓÉ‹{mš,kj”pwò‰&U’ç% ˜ª^«˜S04ZW²lïS»–©{Xsªe¯×ZúŒm囜1w zÖág>ôœ£Qþëã _å°å¯v[ § ÌúíÚ6²¨ª%"¥i½âï­â·ÿœŠÙðØ•ùºÿR„ãÈmëׯvCÕ°N2kÆdÕŸ¸"ºÉÀèñ«òIhXÛàõÕвî9à8@»8W€iâ{©…‹³è)6‹€Ø\…âì“tAðÌ&û×ÇvwX2~oé={™¨Æ&'ñfÀ«ÝËêˆKSK6_ŒV,][ëáÎão¬šåó9´œÒ}Œ•*àÿðÂ’.{+ñúà…4¯¶Þfz€åг•ËÇV§)EVVöã{/ç/Žš³¶¯—>Áç;O«ÿfᥬͽ-™+"¨­©.¢ à8Îãâ|ÇÙc\‹öê©û"¹<õÛ™ó·ÂF´4,Ë'/ïW¯ãbA⵫à\\¿’>ŸÏýFàÒîsÛžfuíÓt„‹5_”ñìmÄîW"DÝçv´øAt¤âOÓ;x8§…%(_¥7uã‡HêëÇ%Ÿ°°ÀÏX´ÀÏšƒ¥=ys0Ö¼ 몓=;ÔKI/0+)¯?FÕ²ôq1Ö:â™ ½ £7:zök §ºðHqiRjŸÏ/k‡Ìs2B¢% Wɽ͞ÑÕ5S_†Ç×tlï¥'$fmú÷ÌKßÓ{8éuà äÏ k ©—ÔfÆÐB­¦/00*óËóbƒ$•ˆˆ¨L•¨"J¹±\æ+ÏÐÔÑZõ™Ä°‡{oGppqJNRXðìg¤B–‘’;{]­”&P—\Cà,¹ÝŠñ5iJ‘™‘ýðþ‹9‹#¬ös³Ô%0kNµø˜¬Çª4ûúš÷kÿ­S(•Vl›sÃûï­½«@vIJåj/]Ð 8|ÇâC7rôˆbï­RÏ‘›l ¯ê8;yçÖ%y€ sÖ«ÒÑ!¿$×°ÍÆy^%¯ó® /ÃrØFX÷œ½W²Œùr9K‘ûE&V&={›ÉÕ³órÊxüQoÞ0ûç£ó¼k6ååÍßýO@Cua0 έ½Àz¬´"ÀFÃÅž3·eÀìàðˆ7;*P…Ä€À°›.…åßmÈEY¤;ÁÔRHS—=ÈY°Åš$ 0 8†µU·<Þî5Þ ÛuìanS_3¨×»Iü¸[_z ´ãàåd\ò¢ â8N`ZîÇ#É‚,š™œ’Q|Ë-LÃ^«….¹¯ÝØÛ"ÿ¦ý[L~ukËïCæ ¨Îü¾ª:WuÂsV¿ QvnËÃ~)ÀsE2=;£k/iJ™,åX‘Š<1Ä?Ï´kÝz^iΧñë¿î˜ÓÄŠÏ!1 p0qª7²±ÏO¿ËˆY;â#·¡VË×¼:±Ð‹ùe‘$€1åËÔ!›·/êi†ì>¶N*,ÚE±×žÞ²«în¨:³ZõïRÙþá´=ãEú;†Ú±Åƒîq]ý©jŠ  hkZ~É<“ÆnšÖ¼¬á8}ÿ…ž¹‡@™qøâÛü6Œm!úðÅhæ‹Y­ÆÓº ¦¢2<&ýá¡v¬ËOsGt›bR m\R–}e3Ó"0Î1(8õ<œbGíÙw7dz‡¹Y €åãZKŸñì44—gN´n³»•q!7æüàkRŸ ?1v-V´I`Ñ­uÛ®lšß¿w·hojP«iKFJeEÓ&U0¥h¨ûýÎw–Íf²‰c¶Î½ÛwF›®ÁïÕ¥~ákkO«éÛC°Æ¶àZKÿÍGQqQ§ÄW‘övuú”‘"©ÛÇC9aMˆÉ5ièb›Â%²*» ³¢‹VücRמ&ªßbö—m(|ë$´rZ?2aðº™Ë:î?3¢_h>¡ëK•C—|~qœªµ´÷Fuë4C<ù‹æ”2ÌÍT2GϾ£¾|Ï'ÑüÚúº»—E”úü‘¯Š¦ËÄ27µ¯rÉW Ã…B¬qêûó!®[Ôà½hƳý×bkøýaAb¬Žß¢à©ýQFUç[U züq¨ü:2%qR¯oç†/®Þ¼åÜÒž…>Œ¬ßÖ­sSýQ‡rm'YÚÙègÉ2FŽv6&Lyc§ª^¸àî´½K¿HŠŠQ§G¯É5ªyqZ;(¹²ë´Ö‡Ç]\r¿æœæš eê’Ôâ ¾ÙÓlV+ÎMï³5ÿdZ‰kšV¬:ôÞbDÃÂ雡m]LÔ“´þ’µ†ʤ‘Bš6ï\fÉáèW]ù]\l¶]ÕqiJ~*0ª} gC€RJO]y£^—RŠîˆ8m…ž*Üæè¿|ô°bO=•ä8ljG²ñš¬·é5 …iEÚüY£Š;<ˬ+Ú @.zƒs,+q5Õ“ç<™¾5nÍ´^ï“DÆ}ÌØt“ºã.Þh´oûšguߺªÎà «Æø5csMÝÌE»ÞaXGš¦Ù8äÛkææBeÁÞ< KHe(>_ÑÌL¾]/üŸ:—6_ηæJy&`•Ø¢l™¯“Üzw¬Çž¾wùc¡zéÙÎü{®ÜÄl¨¤j9âbªY=‚º(å9"¾ÒJefFÆýÛϤ¶ŽÓÜ Ù-k —^ÈÀë²óÈê¤B b†aBsókÕÍ‹Š'îŠT“Y)M&…•ûúº@ôõˆëɆq6u”7/æÔºÐÊ \ ØÅÿiJv)CîÐÞ^÷Ëwב’|]»öz¸^Í£kv{òvý’ö‡÷Þ:K„&+0ååT¬®AFh¶I-S¶e»VM†@‹?}òMSò‡wžºפ{³M¬¬†çgqš’sôVö±³ÿÂ;õ„@¡_T™:D£(yöÍ,ùÌjB òãoYËf)ÄRÅ‚#=q˜Ô=¼T5¥c\­ãñ1M%=»ŽWYåjX /†Ðg¶œ8dë0´—W«ÅéEÉóÞNfÇ71«fF–U£à½×2õ0`†ÉrcþšçðK ,ïóîƒÁ[Õ`ŽIp„ÿŒh}èhp«^Þ&Yï÷]KWH2R__ËÊàÙ£±›(N`õó=+&ìf¶¢Q3#&¥8µÄXÙ¼ú5„oÃÅê£"Í5n‡ãܽéÚ¹+WߦãÜ»] ÌÜí[ñŽK £Á³ |T0x%"ϾÏÕoŠ©†(· íS{ †a1…°²¾ú!ôl½Æ,>9bFô¹s–ÍmšzÛ•û/´ÕSJ?«ë¥>`ì˜.j8|Jþ$©ÖÆMyýy2†TæºìƒX!¹‚sóû„¦R2DLM· h×Ù8U@Òñ;å©* nj¢¯ÈþØcÒ 'qÙÙ)oª8¹ðÖ]H_1¢£‰”€™ËÏõßÅÛµŠMãSºÂÈGP `Ҝϛ$ÐJYâ—,ªʈ¾îœ7ÄÄY ¾œ†aU5±¨‚l‚V+V¨@ÚÛ¡“,çòƒ‰ïRküiýêíê½OM›z7ùðbö)ëQÍèã×bw­!Í*¿‚JEŽ‚ãBö¸rqÒígÌçJîÎõ„Ä #Î7¯Õ¸Õ´Vvñ÷n˜×­CòŒêõáЉÁ]£NË zè£û:.c'ÿKº4œ»´w%͉.-#NÓJ Ü:té|gÏ¢U/OÍo„…”*S‡hîó¥|+·æ†$Ù¶9±Iå?žZsàäG¬ÑìþÓmx4àZu‘çÆÿ³=ªù¸A\µi8 Ãðm›Ýw{Ù’ƒ›zLìnÇǵý’?-ÞÃV´oÓyyg³2i$ÏZþ›5ÒzíiÀ0ŒgèXŸwsO´d†“ò£øFµ5¦g®ß|[ço½ì¨Û¡öˆ×ìк ëâš3|½Ýõ°âBžµé@-W¤¦¦= Mqððž]ßÓ)°–+AÌ•!ä³Ã0vªK’þ`D‡ÎýöèžÛµ§—Xron•;``ßeNÿA¥Y׎¤Pç½*D «Ftºî˜MëíL 8Ž´µó9ºÏ­Å} ³á¡iò¢‡ úL=â {?t»?1^µ Ž"]Jpí˜B>K5Õ•…üÛƒ/1_ñ¯2±,íCF8ДBI+i ””BIa€AÉrVî¼tHžòëÑÀ°ü±¤)±8íù’_~ÊßÝ+›Ö>½¥GO°mÌVÛ‘-ªÄ§çR‰ç^KÀ¼f] àq²aõÌ[W«iî…ÄË)ÕÇ@hæ¾cI]À€Ž}ÿqþÊc÷zú­ì¢zÀCÏŠ£”e1 ²ã¨]AÇqL–¹v–zxžÒ‚ TÇ¥•›&yŽhÇ7 ºµÐ§Û¹6pä¯]‘ÔwªK!¥¨µoûµq3Z H„ðÄxF8¹±r¢F¾üŠŒçïâàùÓOj8ºp¿¯Ž-‡"B)ËLKKü÷TbèH“&uÿ=õp¡Ó¢¶ö÷ßXö<åízg ‚P¹á—57aú&ï_]ÿÍãê·¦Í[¸XÑÕD >znÛÛc//î2ÎŽ°eÊÔ!êb($_ç\øÚv^×ü¦‚ˆ¼såHr•ö1<ŸÏ…"Ð4M)ò6,¼Š7l>ËÃXÝtá€qøÆþ#{¶m²tÛý9*U¥¨^S·cÜA›¹/¥F¸AÕISljÃMÀp¦À½•çÓ‰iò8Û¤–»¦eÀ˜F0qú‡Ý'¢Õs¾ˆ)_ö÷ íÔœgenˆaD-—jýÛÕµ-X'0K¡+Žã4M»8p?D+™%Yá—GúõÎm³îüüþ8ÀùCÙíû7‘Hî¬üS˲µDzòÝQMW4«”(e1‹nÄŒ{Ô˜‰…c€ËÏi¹â vêÑZ}.jò‡ç°Áòwç6vS…¯újS×@BªðXÞûL®I=FçšU‰°H93yÇ*ËdQå:ЇQ©ñÇÐÈðï!¦$ÎÓwðïQçʽY=z 3^ &IHóóüè³ÛÅRÞû4yÖ­çOèwöÛc±ñŸæ•xªË~äž{<{8FÉSæìŒ½´¦¦87;.0øŽ‘ FpðKv8»šÕ„qC­9ØÇì‚©WMÅ0'Iõzugu|5êü#²{/¦€"‡ÂIF ¥R‰aXq ’$IÁ5õ¨_¥hÏç>ÿ¨ T;4E7ôtëhöxÀ”/€¦4AâtȦ;qœÄ€VPM—ý5ÝNùÑ—_AR¿½!çÉý8²£%³*^ß¼Á¢É À=ž?ÑôÝt\>l¦½>à´°º½EjÈã(ëck˜g„?=í4Î×ÒˆK¶žØ|íØ³†>•ªÀ7¥EÆ¥iZH`bR$…ÝÕÆI’˜–‚Y°É1¯±±ÿÛ;.÷_bÍN^•µCØÃQ ÑŽ•¨ª 'Ö4T—#ñÝ«I‡R範­Ùƒ«Oî©‘1où•÷¤ÓñInœÂ†KIâ?yeW¿Á–ÍÎI”@»^ÎèUÔ°–V# ëÒPðõ  šú«ÞÞ4gÓG’t€'osÇ™kȯ*J`¤¾M‹ÂϪ<Œþ‚ú˜£gïßÃSëÅ ÌRceÆqüS ”"õزqËvm°éÀ¬ÌHXxM½¸#³ý°–yy—¶Œ÷Uk‡º°¤í¦çëÏú•RB+sWõõ‚6ºš,):¦þƒnÇlwª~¸u‡8}ÙÓÜ@)‹Ý±aþÃ5wfÏݰ¾Cì‹Ûkg=®ÚåÛoÇ;Lt%>D+Ù-Xe™®‘åFž K€¬ ¹Tžþ9Zð5Û\Yœ¨™1Q;çâm܈#çžRŠÜÛÁ«˜Us³Ly c·Fƒ»Ô6!±àOy–}À5p¨$½þ‘Ó¦SsÑàƒOVÎ5tŸ`=å¹]ˆî($ŸÇH¡I¡Ã1ó1#—#Å S6K#åZ°WËâd!øæmšÔ,ªQÔ¡›Ÿó?c8ÇTÓÔÐÓaË“«ªÇÞ<:;¡Õ!Ö/Wí>ìë·ÆEÿæ„-·0»Öä[ì_åÚæÀá5Ö1€ü§\hJ.¡ ¦8¾›Žt¾óÂ1hã]eìîë­¦6èÔÀtßÅ{‡7lë,ž¾U%B‘ÇÉ’ÑÀeœMR8ùÏÖ‡~|çm»þ-;kYh©eÄ1Œí[ç.=:ÞÞ6íP!ËÚ!@)r×Í;x-ÅlˆæxA¢øÔ+;îåþ½ cSΣ¢ÂPrñã{O—ìyaéî¾cLSÃ’îEqRX©8½X½4(‡F öN’ìÛ)ŠŽfw2]¹«z±/š"H¡¥¹¡úÔ™^ÈVj˜•Acέ8µÄXYéì°¨/´2/üäå„yÇ?÷il¯ÞbUßÅ—6dîÎ6b×ÕÒ”x¶ŸËÅ/.»oµ×+©ã‹G”rê¾¼û…m£8ù—·æ5¢ ÿÚµp„@­ ªþ15oþØtgÅÁ9û­wÞ®ÿgâþCfF'“ú–­û-Y1¯sQUJ#÷~‘¬ëX•$¦ÁÉŽ¥Ùug콆a|¡™« É’¨wWcÐÓ‹Å€àp8`8‡ÃáÌÿJYÆô¥uþhu¶­Áݧi ”c`c©šimÚ¥ñÄ®‘[O~Ñçq9˜òZ–â3Á+‚Ãê`&‚¸Óg }»Ù ¹XÕVx^Ù2þ `óкu;™n¼Ä¬z¶Ä€’儆'й¹¢°W!{_gw™ÐŸ]ÕüüYNµ~•—–{­ 2Iä -+½iÀ0’T_,Í!q #8I`Nr8öA ’i‘¹¢¿IÁj­{Ž}³˽_¶iW·²½!DÄ$Ÿ9|+Ußn¾¥‡ƒOÕ S8wà&gïyÄ 5Õìfm#4%Û0÷„À§ƒgÌý€Í½=ô4#¨…Ÿ1a):âàDÁ-*gòbßNÃÎaX¾AZùèæ£-G§™;íØÜ¹†Úšøôê­,ËÛ{Õ4$€  ©ùèÕ‘À÷÷_ÄÉ ÍO<´©öÕcIBþJþ²èUˆ2iÄ!p SÉIš×íÖMJqâÜÈÕI_Ëí2Ar8\!‰öϑܞ=»Ží^“[øܶÙû›D^8¹ð‘,#FÔWÈa…â_3ôl¦ÍkÛªž/öÉ+Ç õ~ zeë©ëUÐKeÔÃ0,âBðõ,pþøýô÷ŸaÕ­ï1e·î{& IDAT hiBb€¼}ñYį3Kë³J±÷# Š«c5®U`­C¦C`–Êã8AŽC+ìKMÓPúçŒ]ú.mÑŠ ÿþÝ»½ýSºß¯Ì+øs¹…¬ªB>~Ù×M/úp8€a T‚­9õ…fŸß`ââ×OǰüD’ñ®ÞéÒ†ºL–RšÒ{Êc&+7-l×Ñ$õŠ-<w-tªÜ¢Ý”æÆ„Àbç¶?ÕõºQ3ÏVõëÉâ¯õ›bíäNA˜Ì]7œ&  „Ƶÿ©ycñ£œÍ-M î°g†Ûq÷®tnb¤šm`b=:äp…¶­Î­oT´©ý¶|&I¦°Böåäåƪ%Ÿ¼œ `QbN^Ž;ë÷ïO¾p®nñ2ôÄKh=ÆÖÞè›d¨ëÓr—OK •R x…ußWÇ“­«ÚÙ ˆƒs¶ìNàù¶ktyB=!N¿}–sâ´¤Aë³ ¸LY2Rå5;!‡P›•–¤¿é04"0 ÓofÌ#´=ÀTtÄ)S§wŸS½ËÙ!Ž]úÝèDê¾…¯Ö¾ÝßNÙr‘›eÁ­´]ÓΛêªÅÀ׳™2¬mQ?´¨^‡‹i¡¬8€ó õM09›hâíí Ö&‡$ØÞŽŽH’ê|€WXßÙ‘ *D`Õ;¯Žž}îççÇãa|ìþÄ—[ó¯ØN˜îaZ\ÖÈí71ÿþE©¥ärJé'NLÕ™ÇãÓÓJ…Œ&xd©/)¥F.•ã\ŽÎ]TH³>ûz°cÿß?ë(öììèAƒONÞ=Ì]íæN¡PH¥Ò'NøùùiUðÿG9´.éyu¥,íÑQ)áßqˇj'𤋮*øÐeª¢ˆcW’f¼ßdzÐsV¶m¦^\™½;Ç€M¡)ÉœAm/%;XѦȤSé½(knÝ@6¥~ãê}wÌé/ÀѲVñs zçUBB‚¹¹ÕóçOüýýËÁŒ¸|Τ}WSíê‚@ ~/XË™šš\¹re(MŒµ”¸ôì[QR"ÄOGic¬(Ȱ"D£e+z0@ ÊJÙÖ±"¢DÔc¬heè/˹óç¾·Ä„ž°"]ƶm;èÈE†õ—ŵA=ooïï-ñCðèÑ£ððpÆÒ4MÓ4û?ûYw t>tPÐÝ…QŒ@ü.H$Æ€ªýe?–`X ×Òb'QŒ@üŽðx¼ÂîjU-¥ÇÊšà¢vÅXÄïHQ«ªþµÄºt€ +øÀ0P7ŒU*à ¥ŒÀcÍ|õ-åÝÜŘM ;}<³U·Æ¦("@ *©TªTUŸ’*©6¦nX+&ÆÚÕ·=…kyL‹Á•KgŠD)ò׬{T*~Ë«à…KΜnçVpг›W’ͺûhC”|ç-ååe#,®5 òâ¼x45G6úû@+¤ÉûÞR *x<žš-U™V*ße-EÕ*&ÆúùSøÖó×íx…ì#%õýc‚.)”y‹”ÅJL+óÖ|È\×ÒfƤñyJŠI|’!±]:}<¡yås}˜t¥,qBÏYƒ.À›Eý'ÞI¨9üßmýª«7¨”Fwö"¡è£7îXsœŸ÷w¯Énm¶@Ûnå^¯žXm,0œòîÅ7dpfœgÀÁ»?ée®ºN'>88rʲû¡ÑzvuÚw·{Å 4ˆß‡2ÄXíÙaPøä ©œÒWWв¡‘Fbv̆£îž\ð룠hPJã®Ý|±vP•|¶ð“Eþ‰]·47æ€451л¿z)Õo·ºP±çgÄ噋SžË)E‡u-× Yõâò Ò‹úK"Ï}ú)bÓé Õùª«#†ß’Å{qê_gÌ9ŠEþ5?;ê`Cß‘ 'ízqÙ7ïí€î­ÁøîŠ.ÿWˆ‡2ÄX­m*öûhE†Öò1g§ïŽó[4¾¡B"™Tš'óõî8öÊÃ.V…îâƒV_µð\&‘H껺À¦Ås¿äDa8ïüùsÀ5j6{Š»êåWâ÷ãNÆorb¾Ê(Ê Òxãäq«C“Ç;Øëµ«^5š>öÞ?Ï¥‰„& öèi‘-F½u¯¿ü;pÿHs‚pÒh¨oÛ¢½P¾,qÊÍÖþ»çÝ‹˜ãeÇ&4l'^YØÀ¢×¥ó·ª·ôlöWnÅ(ƒ@”‹¢1Ö/ž‡††W¾vmWW×üoÿ‡ë¦m;)m1ˆm[[-yûí¨?Çðù|Å.§'¨¶¢O•±cöö¾4µ@ŽŒ›ÿÜŠ·í#$©ÈMÿFNÓùÖ¹3wé?iæQóBÏêÆNx¸^n>ØÛ\õÚ.ŽSRÁ¼®öÝÿçXo&1'nÛõ\“;ÞF-x|>ŸGŸßÆÏD¼>4{GH³mÙ¡ÏÝç,klø{äÒ´'|c­ö±|Y@+²Æ´d9üÄxÞtv1Š2wñÛÔz{þd‹Yy­¶åžu9îF_‡bZB þ ŠÆX==½p{÷î]ÑÂîîî~~~©©iÉÉ_óÓ*(ƪ”Döè£+Š ›6­€uÇÏVç“ ‡ïLÌÝØÕN£˜Ç´Æ [/|â?×Ó’I99vf̹8|ïþÀIc:@à«ú8JI8@m¶zè¶÷Ö-Æ«7(Ï“»Lø+¥é¼0Q÷ÚB‚æ´i¾ÐÔ8t'O‹‰[ÞCȧÜYpz¼Ï5aŸˆemÊf$Í ÎS.nfl Fè73⽸ŸȰ"~00 kØÐ]*•†‡‡«§»¸¸ôîÝ;++Kͪ– +Á¯²oßþ@?Ÿ'kÎO³3e·ê~âö™…¢ü‰&À ¡±ϯj*îÚ"Ò¨};cMsNðªlïâ7iÍ܇+@œ~~iH¥-ƒŒWd*Ö̧­i&çL`’$2égª^’–SBË~}-Ï9ôùôðšJiôìà¤1wÓ´æ«eLÝME;ßø€}§ãJî—_ÔG©9 ëîæm›²îäŒÜÈs¼ë‡E†1 °òeÅ\˜p\y=r¥Ç肟P²¯à (äæ: È»áÙ€@üxà8îåå-“É¢££™‡äåå%$$–¯Í’c¬ƒa³Çæ´2ÛÛËfo|lR»ž!-}ý6âèãçu%9€Rþ×ìGMç^QFóc¬Lv~ `MÕ!“Ç:aŸÅ»=LüE)eR©œ¦•‰„¢áÁ›ú8€Bt V˜‰‚g³_e´T"‘ þÇ£ëü…"ÿ½qçgÈL»÷7#ò¾È€±aÉWˆ?ýæ{ ¸.8÷p¬Q}æâd»ætàE«š#_§v³,GÖ.»—­ïùûüGo#ÍÕT¤ D‰•ê‰qR¥“ ßëX½¼¼Åbqrr²Í!C¤RiTT4E©¹ cåbXËÅÕ§ÇÙ;×YÓy©Þâ#]  ëäa¦Ï”<=itšMßë}œ“ÆÆXùŒ?Ëo°ÐÝrÙ¬ SÏà÷ô0{„á—Çã`Áçóq <›67çà ËÂÎ’¬0•¹DHVl\ŒËçó«û®0žÞø@ª"gkˆÇì|>_É#A-Æ %'xv¿ù|Ëjõ- ¾<Û–Füð‡)àfYެ°¸Ù_üs“:åoMHÀì¶M× lŸ<^=º€¤iÆPwÜn³îû\—ï^2ÿÆv¶˜q­:³gÏÐ1ûÞ~õ a²®•O1‘Y$ò¼¯¯Ý®eÀ{ø!:k–Ç9VËÚÚΚ·+õ«Þ½v¶ZÛÌ Ëâ×,IÅ_izèƒLû6ÕUn£Ru3SÒÂÛ¢|YNí6mS°ØŽ¦Dtï×gö‚V&&€q×7±?gôZÂäÆ_›–$Çu±ÿÏ”E ´¢uû6—Ëå5oÞðè襒ÒV»´¿–Ö°6™µx4//.âFðë—@p+oÞ×Ï­s€}çílôØb­Ço/\OSa¥ní+AqLZ°4K‘¯°é‚鵨¬ºþU÷>ƒ©u‹Öò˜5âKã™ö÷Yq´/Bxç‹ãÕaî34oÑÂØœ¾–p³Jö•9Œ¨¸Q“-z¹ª–¸* ªU«FÉT1V¥4nO’te3U$73==-W$‘ü^vÚ-ºrÔ`âúe¦õûDX5lÚ+èÍR}+wV!0ÜÙÙÙ0™³¾]Ïà»Y“¶4Û8†[©f›¡ë÷¯îùߪ‹@hA"ÑceSt×ÕðpuÇX±„„øüù³­m•  {þþþ‘‘… vZÜa%kÁ¬-½Û°õÁÙ®‘kì¦Î[Ù׈R¤Ú¾îàuåñóK…xÁù–òäØáà±*×ëìßÉ¥8YÃ6vš”²èÜÄØ†>‡–- µŒw§nŒ+z¤¿ç;'þíZE·þDë;äFï{»;&&Rë(YÆÕ+bËŸ¥J&ƹ‚2VB *æ -[ú箖自W|úô‰ú«YXËãèè¥ ˜ÙÙ°ŸyÆÍŸ=hÂQ$ûÚ1Tœ4ó»Øo¬f- Ͼ=KÖ¶æ¨ÓçË'ë½xì+”p«ØcóŠÝí''v8ѬVi—C†‡Þ¸:mõô0e8W¯b³t YUÄ„V«ZvÃZñû±B! ¹ø¿Üàfj –âä›¶<ºæõØÜˆˆèR¶Ÿº§ã–#ž(º‡@ mt­é®–Ò°–nŸë`?Ö2aÔhdï²H(pðck„@ þ3är9c™ª¬¡Ä°RÙKµ°,zç@I’ù®'¡á®–°2~®ê zç@ZǪ±¦µ”†•­XȰþÊ9h*GGyÀ$\àñùüb<֬ȵ9F=šYrûõWP4(¥q7n¿Z7xS€8°í?\2,¹Û–6ÖF@g$eúAÖpýw«7ua^¼ÈRœòçòù<‚oÛe}«#6…^žáQœ¿ òÜ·¡Ÿ"6¾Pϼ¹0Œ(1kñâÅêä&1ýæBOsݵ²£6ôÙpÒ®—}ó>Ü èÐŒï®@/!G|gx<Þ·ÇX™’¶Žµ²½iaûHÉ34ʜݾ)Vªd¿*%Q°{Ó!±‰$ÏnÌÈžÌç§ë®Y6^ žÞM`ݼ™‰9οté"ðŒZÌŸnÔTˆÂÆŒßù¼.ÛŽ¡ÝTãäë?gNv4fׯ~í={ÂIÏÙ”†“æDzŽ˜ôÈÿ[¯-“æá¤ÑPß¶DY²ºwï®þuç¸ZÃNô´ÖÓ]ëРÙ`;ñÊÂþ½.¿U½Ý g³¿z ÷#~,ž={úöí›ârëÔ©ëææ^ŽfK{¶iÛN/—ZÎÎ5ÔÿÕtñÚ¶uƒz1‰H$å±ÿr²càfLªz¢H$Uθ9ñz©G*Daë¶\€k§OøôžrxÿÊž={unmzæâk¶åäÇ+äæƒÝô9lŠRDÌíjjöM6%'nÛÕãyîzê"qšû™ˆV¾Ha¾¦¿Ùö÷ßSfËJßG¿Ò´'|cŸ¢FPw–:ÉÁÿ¬ùlqvy+ݵheîâ·©õþɦXy­¶å(g]Ž+¯ìÄÿ wwºuë“åîï?ÈÊʲÍ–cUJ¢úùOÕÝÄÆ«`ÅÕøD÷ÑÔ³âo 9|Ž'I®3iE!LJ9ÄÑѳÁˆK)e¹™{öÝõgІÛW.ê(ÄŸ®É ójK˜e“‘ìWEÉsDŽ#§´žû*½c-! wç°n2G(&°K«Îú¶îfÿlz#q3€´È;gÎ<«5nvC.UæÞú™I™È¶¾zxÓÑ£G‚£n».];ÝQŸ£;K júÀL¿mÏ#t7(Í ÎS.nflMŒÐofÄ{q?ú:üw #EÐc­W¯D"ýô)\½¤‹‹KïÞ½322òÓ*0ÆÊwÞ¿ÿ` ŸÏ“5ç§ÙȲƒ[u?qûÌB‘²À*á„ÐØˆgh¬WÔyùt4Ú}ñžÈY#½>QÅéçW†UÞ2ÈdE—Çã`Áçóq Z¶ëhÁÅ@šy÷BÍ þUl6ÀšýÊÅqZI˜Øù÷µX±øTüéá5•Òè’ÇÜiÁÃ# ìæ›kOsÑÎ>¿8u?QÈÈÿ.¤>JÍIXw7oÛ”u'gäFî˜à]?,2üˆéÈb«'O:•i:Þ¥Ä ÙWpú98 È»áÙÿ™²„VŠ‹±z{{Ëå²èèh¦˜ƒƒÃ€òòò¾|I"IuÃUa1VÂÄÄTÇïÍ™É#he†ÙÝ_9wõ퇦uPÒ—o>~R¿HMyÞ«ÏRvl÷T¼¬•çÏÙ–öUx½¹¹D"‘HP8Æšò.ƒkäð›ï M}iߦºÊmTJ¢nfJZx[èÎbšº^ÏrÐ Ka©ĸë›XŸ³z-a²â¯MK’ㇺØÿ¿uD t“o -b…ü°+Ž7¥iøü9B¡PhÔÍߘ{å XÇÊۦs–ŽæåÅEÜxüö%ŸÏ~õ­ûû»uißy{÷ª…OZ™ynÛìi{¢¿ìa¦¯j³ÞÀKûDmõÿòiÊâYÃí…*—Gb8Qc²pi–"ÿ*aÔ|ÁŒZ¬0nƒ«­Øû†?]å4qq0.“ÛdîȤÆ3í;ï«b %„Â1Öç÷’&Ôg '?œ7n}èŸ;µ7þ½Ǻ·îï^[â×ìÛØ¡™;|}·vÒ±yûm®º³hÙ¬›ñU+}ƒ¾;Wέ7¤ýL§u£:d¾¹9fð†ÃÿmlˆÖZ!¾3<W3ªù€ $©9g¤Qñc¬ÔÀÖMÞÅ‹ôFsvv´W•:6cÊÞ.c¦§œŸÒeDð¨€A=1€ˆ‹['/ÙIÔ^~úJÚ&ê Yx¿}Òjìè™]‚ã_.Å F&z·hÑÂ"Gy}¾ßÔ™ŽÒÖwxÞ¢¹Éò!VøVvUóT˪„Vý—NM³ì«ÚÔ#M«W¯ÎÍr(¥±{’¤ë|*«ô‘ådd¤K©òÆN~ZÚ-ºrÔ`âúe¦õûDX5lÚ+èÍR&œ­# D)'•«õç\úõízßÍ ˜´¥ÙÆ1ÜJ5Û ]¿uÏÿX_¢(ÅYÕÒ–I]ðùÌ„¿' ¿R»ckÂn|UDDD—²ùŒÐ=¾[Ž6³¨8ÄO ‡Ãaí©†»ZJÀ¦1¨À½~¬šOÔ\øª—?Gÿ¿dA ?+e °`”²ìOfX¢ÜgIK7%¥*UCŒÞy…@ ~ärÙ·¼óJ½zçÕïË£G¾·ÄÄãÇvFüR1VDé©R¥ú÷øø/Ïô¾ ¨`PŒ@ *cE ˆ F=ÆŠBQÁ Ê@  б"D€b¬QÁ u¬¿çΟûÞ" ?zŠtÕ· , 2¬¿,® êiÝø aöce¬aáM­ŠÝ@@õ}[‚‚è.Œb¬âwA"‘Ù <[²Ú+@ x<žÆ¬êoÐ]Wc›A´W@h ÅJcX5>èVñ¡±Y5†E•ʰ@éwÅ.UŒ•VŠó$}=•Ž}eëâÊ|þpç‘e3OSzÐ@üèH¥Ò¢›±²nlIµ1uÃZ1Ö”×£:üÓýÅ®@+³g nqúéGc…èýàI#–½éd Y…VfŽ1ÜÆÕu…äÛÍÃf <5«…VaEÉwÞR^^6B6%/îÁ+GSsêý¿ Ë8íïm¤RŒäýÇò ÿ<¯è;°©|—µ TÓc-›§™}ûÄ©+½-vZuüø±=+ÇS¦msïœ?{)D£düµ)Bµ…$ÔôWÒáá»Ã2Š6¨”%Nè9K& |W€o¯•€óóþî59EA•I6D вóF¸T67452«TÝoÒê/²‚N|p°k£Ú&F&•k6 ˜v°˜®§ÜëÕqQ£N]·ÿHxâ§¢l1Ö”—ÛמtÐcôßÍaÿâÙ-&Ï1Ž¥ß^º9¡{ç:l1¥,qÒÌí7Ý#€käypqÛNƒFw~|ÈšC¨7ød‘b×-Íy Ëüo‹ëZ®²êÅå߬ BÅù1Ç"wºÒ¶Eíø—fùû·Œ7ÿxrdGlè;²á¤]/.ûæ}¸Ð= 5ß]ÑE£yîÛÐO›N_¨ÎW "†€@ ŠPBŒU!z7zâynXÞ—/þþ'úúÈ0‚äp8€Fr8A‘8Ð õZçgö¶õÛçaÂ&Úø®úópÓ.9²yŠ5Wu6*ÄïÇŒßäÄ“*hšV2ŸkžÙbÔûQ÷ªñÑ©[1TjÿׯÑ}z×1cïŽ[w6©Ñ}À84h6ØN¼²°?€E¯KçoUo7èÙ쯅"Òœ œ4êÛ â'¥hŒõŋ硡š7Ü,µk»¸ººæ«¸+EV2dhVä†Ð½‡ id–ºV*är9Ð@+är9NÉ`$[ëéŽasopŽ=ž§/à¨uâ‘séºwë½óØfO+!$<\/7ìmnÀà‘†L;|~?ñúÐìMl ýͶe‡>wŸ³¬±¡öà ¢D<ºT÷ÿã|á6Z™»ømj½=²YV^«m9‡g]Ž»Ñ×A½iÚ¾±²ªˆŸ—¢1VOO/ÇÞ½{W´°»»»ŸŸ_jjZrò×ü´ÒÆXKङOëÓCœ.>>­£ÎlçÙ;;;€Çí„8-ßÞÓò“ˇÍ:îæà¸{Úø¢­yoò?Í¿M—kÏ®Wã“¡ÛÞ[·ÐRŒ¡“§ÅÄ- äÆž9ó¤îÔEȰ~#áƒ#S’ÞžYuH´üæzægÈ)73¶ Fè73⽸Ÿ… kúËDްõÕÛŽ=­pkÜuéÚéŽúÍc ?†5lè.•JÃÃÃÕÓ]\\z÷î••¥fUË@Ùb¬F¾íªF^½ õ{ Œ¼ ÐÛ ”Š´g¯°mWoTIx+Q(ÄGOX½fûN€È#sEa»nÕ8ö®Ÿ€$‘I?ÓâŽeên*ÚùÀì;èTíšœ\8óHxTb¶ÑèKÕ1Jö…s#ì?ùÓËësú»è5¶ë®ÃëÝtmµ\~àmä¯û—šp¨õt?Ù÷„+‡Zå+käŽ×¢¡m;ï¹™”ù!Ìqhï CKŸVXQ9¢X©œQ– IRòíÛw’”Èÿ)…ä‚–cåu¾}ª3- %@Òtܧ÷ῲ¿O&)R$ ”èÁå#»¼¶ý¨=þü–© |ž›V5̈¾÷F ®I(6nØkRºÛê©£dS hW«iª/« Eîû%ÚÐÙ 3m‘–œ˜˜& 11P"LNõÓ¯CVØ/?¦o¼€äjWi߯ ïå²o4M‡…ñ'/ØÑuëlNµ†}&yÜ4L¶aZBBW {Ý×íÊQ-{ïuó—ŒùDi·î2<䥻&~s…Ê¡0«¼¤àm•®pU<+‹ Ôtõ t³ï(çÀâre[ñ?ÌßxaüÜ-ûÇY¨3Š[ç××ß^¦Äô„ÅÖ&:ŠMñL®hµfEPœß šÐtƾK32W}9ç¢Þi]o#mÙ¢Yß-7û|Ô¨líFîûÏ»RÒÕµ5”Ö´œ|>h2%Î`pÔË7Ýy¨¸Ø±wÿÅ@‰Ó ŽTTîp8låD@Öåj¡×¡J—«*žuù­ÇO¥ð[5ÐÚšÉËœBE§Þä§'Ë×2X›6o+ µ¡Û=öZ:D[èÚ({ÈäÇð ûM ›n+ßR‰T"wT•SŠªùWË·„ʲ<£jñë_˜•­¦®TÂÉYÂ*Ε O¿ÇQÏ7~¤}ùòM^˜¾¯ßŽ€x/BH¥¨òåjkÑæ¹.ϼÒio7"çNÕꌛŒÞB©šD"‘ÅEÙUy $ˆ"ÅK…´,>ó !„€Åbe]z2•.W‹Xe×¹™ øÌ+„ȾD¥•žvUäÀ*ß°X+²°°°ÒîBeHHÈݳ£Òϱ¢¿ÄظZiw¡2Dµ¿˜cE¡¿®äϼB!T( ¬!¤b˜cE!À+B©æXBè/ÂÀŠB*†9Ö ëÞ½àÒîBÉuíÚ£XõËõÁ槸'•.̱VVcVžwò•vïrPœj($ä^ Þ„åè`óóç'•"œ+ É5ÓD5ŠýTI#eù`ó£’“€Ê ¬™âÂDEœrâŸúó˜RŽ6?X+ ̱VdBa†Â’Ù‘Fþß²„–=·¢òžì²Påê`óó§'•"̱V\./¿§¨—ÉXCÓ4Í`äýÐöB•·ƒÍÏTŠp+BýEX+££K–œIÏ].}{ñê“|‘„oÛ¶µ¸gü¾óèW†r)-‘ä¼jLÿy?,¡ü|Ô¥¥7n¿-îFyŸ åì$ "ÃkE&åñuqÚ+«7;­ I‰R}~äö)v ïî–-f¤†ïÞí;sæL¤=]ìr8¿Õì;ß¾_- Ä¿Ç­uì¼¼ñð«¾Þ7?|ü’F²Mê´f3oÊ€&@³S–[z윇Kö×(ø¡íÅ=Ø´äd MÉÈ«©ëèrŠÿäîG;§¸^ÕoÙÉC?³·pëڕƽ¬ªr[‡÷‹÷<¾º¦¶Ò&ЧâÍÆéËîÆ(Up?v¦žªO*E˜c­,¸\nî´ã{wŠ`¯œ4NV‡¥^{µïúúj,`1 ‹¹ŠÉÙ"¡fÒ©Sç<÷ò`ïæ@xã8°><\7ë—µg7MÙªcÎcÖ]þ1n±Ó"óÖj©÷î^ötÿ6éø–IM4­<ºíœµ=ü´c묖²{Y¢kŽƒjÕó­@ù/Ôè»ù²§e±Z~wzÕ‚SÄþ+xlyájgç5ÁV¦êla*_LùI“S<Ò¤_ ­6®²R¬PK“§©£â“€JŽc­¼¤Âo~_ïði¤Æ R§N™KÃúB7drÍÆŒ1“½–¤=9rö·íkHz»w#_ßßcïÏFo½ÛDV-:xéÚó¯æÜ›ÑLLj5ïTŸŽ\yûˆh¢;—-ç,ùÖsÁ×¹·kq™*?ÒãaÏ¥4¥ôåÕ ×ÿ­ÈÐqêƒsW¿çÞªJ;ëžµ´K[1{ó³Í—N4ÑÌ:E4­‘ÿ£Þ•N0¹µºwïž»æ_= ¨´``­\Ž:Lâðߥƒ,Ö¤ýôfëi V¼·ˆ¼}O¤íkIÚ[‡i;»/;ÝX¿yI Æ¶Ê @×ÜÖkä˜U3™Ï=x 2ãG»óP]×óø­æÆ*8¶œX+ר€kãk¹™%Ž~ÿþ½Ò&ñO®¾¾Àèé?"ó0“Â=—/>òͰ¹O7#5¥Ê4ù~E¡t* ðWO*-˜c­È”ÒŽO-ÜôÜäÌõމD–vür4¸jWy>””Ò4Ð ‹‚ÁÊŠ‹’˜L½Œä—ö#¦ ¬\ö þOVçÍž÷U:M“½¦©ôq‚c:äÞ\‘Eƒe¾ád[}•çX!ç-@‰£Î'd¬k I’–ÎÀåË€$ýÕúío]–ŒNû~ù®:í±’uøùÅÎk÷iu¿f,ÓëµTé(h*¢i-’$MÓ@KI¥ Ч¤M‰£Ÿ?*¯À«R¯ž‰šÊO*E˜c­,ÓŽüßé;¿î¸zÂL“++¡¤IÎÄ8\k¢TÍ‘c%¤ÑLníÜÙC‚Lcp°XL£Î;‡0³>ü-Ôa(«OfÄ’­ßÖ(÷æŠ Ûöf±z€js¬¹Ç±¾Ù³LÍtŠ¥¡¦âVч«o翟5~U£é,Œµ¤Â/žŽöÇžÒ³ÖjÙäÏ#‚PN¡ŠÓ>3ئê\  ˜,YIÚ‹¥¾1ž û)ž `2aÒµ¥KCå-ÔµÃgr}•ŸTŠ0ÇZiך~úò„zF<Š¢d%ŸÍKìäÖM‡+¯ÃÓí3ÙV _Åe«ÕÏÝT|è/ Óálͦn+›*–’jÕ2ÿN38Æ ‚HyŸ- è•Zu5©è[I©HAø¼=áìP*—’ñ –þ[_7bПé-€`j ô,OÚÕÖÌ÷·CÌÈÑl“«Xº}ÚÜo–AÎS!£n<ùúõéy¶öÏNúg0°V"õLÔäÒ£oÍß½êFÅ \=ËY ¿ûïö~Ðm¼$w;!£ªO¬‘»Ü˜ÃLˆË^3˜ºõy÷ÎÜQµ•ªIh`g]äŠãELNÕM1Pd⦙³¤ &,i®¯´Jóž­Ñ«…ƒýa"óê’Á6^é6§à_o½lÒ}•RaÈ»³´õ ç~óTêßœô/a޵"ËúQæÈ9€0áÑäáKû{œk£Æ I2ÏmÅ©OÝBõ>ÒB©Bâ«}Þ_>ݪäÞ°ž&ûÁû$Ò"3FLY`~ÁÅsWHŸ©æÙQãéåSöÇœ¿°O6r3ñ-Ÿ£S‡”¥*³2¤P¹ò>X©8výÔÑ—¢kï??—"I*çVww0±˜EJ åU2RЦi©âÁRâ·[QvWË i(Iú‘U³½‰ÃW°()I)Ÿ )T~§Z…'•¢f;sG»Y~ô”¿%€æckþ:ô’µ ™l±Öà- ÂÆxÍ3g‰u‡Vº’èÐÐàû®´ž¶Û8k@è“»±µg7f±˜Jý,QŽ5×ÁR¢{§|½¶î«ÚãàÅur}G²síSV€w+ß¡NLA yšxÛ'z,d¤!+!x²lÄk^þW]j±ó<L0òÛ‹ O*E< ̱V|¹£êu×qK®§8l83®‹©üÛg% ÏOÌš¿!ÎÔÂÛTB¡RFÜåþS×w›ìá5½UžÛV³°x¸ÿ©ÂμÈvݱV¶o=`¿k€äT¯ÛÜÞóø¸Þd›S¢Ÿ‡~‹×w3¡sRÕÁ~>:cþŽßÃ'»/˜hÁ!”ç¸útÄyŒ×ýýò˜í”Îl\¶$ˆ½qOÜûèú‘ò’f̾j Ûºx‘}¶”N§Jõšÿéä¹ÕžTF``­ÈrÇšŽ“&[Ø­ž&«€_]õÿŒŒ[}hZ?¥`Ä3´>{²“i]Ýü¶åèô^ÚÜÝõÆÏÖ¦òÂæfï0(‘8\ AêÛWµ+:j±UPrl­‘;n çh3!φ«÷îíÕeI—šïÔ õÐq†Ù„ÔŒ ¤xý×ëŸÕüNE“…¾ùÌ^¨Ú“€Ê̱Vd"‘rÌIJs«u¯´DRÐØR–ng—ÉÒ<2‚UÍ4óKÊX¯w=8bùÏûL8Jƒç™L*f1¥¢ïK¶%¬:×;+S™3 \Âq¬9–¦™ê@*Ïþ’…mÐÅ àÃÝÖÃlZ^-7ù©èß±m~uÝ?«Ú“€JŽc­,ØlvVˆÉc‚ý¿±G5ƒ®{ׄE ÖëVpÍ G‹M»Ûéd¾Ùd]" iJô&ü÷[0ù©xþüE~u’ßù«ö$ R„ãX+¥@óW÷eÔÉnÀ¨ü£‰Ü”œ‹*éÚ¿<Ø‚ÉNEtÿK'•. ¬Y~Á¥L&ò2;U⎕«ƒÍÏŸžTF`޵"“HÄåç1P9:Y‚7a¹:ØüüéI@¥s¬•Ńa¥Ý…*Á›°ül~ð7±|Ák¥`aaUx¥Š¢R,*ûð™W!¤b˜cE!À+B©˜bŽS!¤bXBHÅ0ÇŠB*€9V„R1ÇZ)^+í.¨PEåÖŠL•rÎó”ï=õe„â*!!÷J»;•æX+2¡P˜ë–ùw£—MŠ}Æw#*/0ÇZYp¹\¥iIfR.£UiÆ?|7¢òs¬•Eî¨úç~~úô1´iÓ®è›È;VfC?B…ÂÀZÁ)MœL@QÿôŠÕÆÆæÍ›·Åܨì^P#T˜c­ÈD"QîùIå—±ÿ¬$YÐ#¶r!+¾QyQas¬¿ÞÍø¯q-ÍÒîHYÁårs?½”ʺdýgÝ`±ØÅÜ"»»å÷݈*›¿5W@t஀à6XRðnáïÅÇ~|=±p–Çëü6ÄÞ~#P,‘äÜ<=ò^H<^!„þTá9VaÒUßC” ZŽß½šRáíM¾Žƪ¨g×.žkf9°:‡¹ÁªsœÏ•µt×,]ŸGúùptSÍÂ/ˆ¤âèùÜ&\ Jš|xýß3÷~§HͶèd5mõl `ðÒ w¸ps{V…BáÕº‰ŽAÑõ'ùx0S,§D?† ›!¢h¿ó—Ù̬ÂÈC¦ Ýzª‰¼ö˜¼äN4 ¶É5Lk´¶5´Sí~•u…çX…~\\œb‰ ú–ïÁ§ÃïïQ,¤¥ü?RÖ´ÔVURlÙB÷v= t¹©ü¤A†PÈ͹^oÙKšó&=Lº¶}éÓT1¤G~Ks·±É Áý×mlùAòÁê ?­½Úóh¡PxÍHKZëwŸêð÷í³ÐuKgŽHÜ}xQ'B«‡G—M6ëÂÎ.j£’C(u¹s¬é¿£ê![6ˆ‡lQüëñý¢ëÏ4}a ¡„$‰Ì y©$#222Q(&IdÄEÇ ZnZmES’¸èŸß¿<Û0kðáŽÃ·o^jÌ.èOæXQeP¼+¯úè5kF+–|íýG¥j¿BKˆv6;rîLÍ`ˆÿî‰%襘¦õ4Ôx<‹ \®Òî1¡éU:.Þw"¦ÍéLJà۩Ş߆Λ×TV§j-‡ ¤àíÂ3Q»Ÿ´áñØpèÊ÷³Ïjߌ«Õi׬zŒAWÙ*óE®ßÌí£…ÕáU„ñ¹s¬l¡ýŸ½nÜ\ßu²?øn{Ýaɬ;K^°˜,+óŠ•`±dÿ•%I™ ‚É­Ý­[¬&Íœòtüÿ&OZØôÆÎatC¶¹··×¾}{ó«3eÊT{ûYK˜cEåÏcñƒÜßòwl˜£”&·8w]â1ÖL øŸ·®:Pó+`qÍJÖK1 šÌ|¯ƒ®º,^ÙÂï¸W ]ní–­eGÕï«s“¶m«º<§>g² (‰P(!iš‰d­IR_,öör´`OÛt¡Ý÷ŒÀ‰VçÐ’„ÄÇ=²Ü{ãn}óeŒ@g¸†¼?êõÇ]¾Òdÿî=»—Mò^ßÀvó/r5[è ö¿ ;€Qïƒáá…œ“²,wŽUBÑ”DÌÒýßÐ*Ü>²­G‰#W?ˆz¡•DòH)If –’$Ð$)K’J)@ª”0ep›0"-:•l¤_77qw_7wîœ'OžÈÛ¶më¢(Š’ÐÀ+*—J8ŽU”ôh†C€:Áûe>Pþé(ƒêƒVœ™ÚÊD^|ûWýuµs´Ã«õèÑÓ¢wQ÷”£ÙAÖ‚BŽUºuÌìMVÊ[®žðÛüäí÷lQ¯ÙÄ£° ¹[‹I5Ítûëmî¸ÞÜÞ%ò”¯ÇªU6o“ÏùÍi![¥[KS*úQ1R{yæX ‚Éf³§.n;xÕfÆÔ½QWÖJôÿgkª›C@Á9V¦Ò TqêSЦµkj0XUq•¦&{Û¶í666Ÿ>}¬W¯þ¶mÛ55µrm9VTþ”d«0ñÑľ6Z£½ƒÏ¬8·¸¿ëÒWM IDATñWòUêÕ{¯rñƒÆÑËÛýI_n>_µ÷¥Â»;mOÒƒN­¹£äàS¬?g²Åë«n7s˜ =&-:ŸãS­ ‡!ŠåÞ KÃt´Ãöƒ“„úÌÍÁQIVñTí¹RGøÈ/:íìŽðÖ‹f”¸Ø{Á´ý/wpÌ—¦¦Öž={»té²gÏÞ¼¢*Bå^‘kò§ÛûÚ¤ör=î4@·ñè‹Ï» qô{”gåƒó–[¹›r™%î“TåzãçœÅ-å%4%<ì<|æ>¡€“#30k‰nŸuÕX N Yÿ‘X3Кَ qs71û#d#-nÊûùâ« û¿ Iù¢qcm†ü>$þ[>W7çWsƒm´ªgµckŠW_Õ;ï?$dÆg0âäû£Lù:ÓõNÕ^+Za(±"_ƒBÒ²•S…äX)2éÔÖÕšOpÙë8T,€V ›3[Ì•ÊߵŮ»BkÔ¥M“·¼©y9¨O‰Sc´T°iâ`ºÇrK BÖIÓæZ=×ì}äÚªš R($ éív÷§ÂC¡Ýeuî¯r6°¡BA_TgÑ`y#]‚/¬æ1h0¦FÔ¡0áœz ÇìØêý`sȲ…c[6­ùá7¨¦b+¤ ƒ¥®¦XòåØhÛ#îí/h¸{yx­gÏÞ9æ_ɳ ™„…–fÐLµ?üY>þÌÆÆæõë7EßD±“=Äg^¡²O9££#k×® ªµî ˜<2ïáѬ1dšm5Ô«õ[‘½8t»Ç^K‡h«Õ2†JQU*üj¿)aÓí¡Ã¥Cyb+…¨ZøìV ¡¢)°ŠÕŒb‡*§*Í|¬êæ~ëŸ\ÿ”°fPûüª„œ\jáåׂCU˜3 ‰  <ðªø9Vù³*è»UDv>Ö‚Õìí8 `Ò—oÔ™WÀºrˆÍfËã©Òå꿉­666À`#£ ëAMPqߨâÁg^U:ÅK¨Î‹/K°•Òãd*w0°VdùEÒ²ÄÌì]î!B…¨49ÖJI"gçWF³B1¿Pú·rôߨ¼¨¤9ÖJèÁƒ°ÒîŸÂw#*/0ÇZ)àP„JK…}¸B•̱"„ `Ž!„T¬$ó±"„*" ¬!¤b˜cE!À+B©XãXñáÃϹóçJ» ÿÔÿÿ¯´»€*;y Å*¬V-›wìØ±´{ñ§ÂÂÂ4hPhµ>üƒÎ TD˜cEe]µj…<47::ð}‹JæXQy"‹›…Â÷-*]8W*Oäª*/þÖ8Öß¡'χ'¥&M öí?¢Xòðæ8’ú;ýBåš’$§M›F’¤ZN¥ÝG„r(FŽ•–òçÌ]3kÓº&ê¬7»f¹óÇ,éš_»—w¨ÕȲŽò;>ùó’ñ«ú\:lÉ|æn­zл‹Çï±£­Çöàpéj; jƬIÛB_hiqr7›üšîÐÞ¤_¤ôŸ¡/ÕÚt2Àφåƒ$CÌVËãÇ­D*•N™2%44tÊ”)Ge2s]èo9?»ÓÜS¬½þW,º7þùìž“MŸ†NÚ*U“¨ruuuuuÍ]ŽPYSÔÀzaù¸o5ÆëZU^Rkè¶í†M÷8廤*‡ C}Ê”ÉQ¾{bÒS>ÿþ¾eåuÍjsÇMžªËÊu-IJJR¯gúhïVš–|OçVc¥'óE®|®=nóÎñu…‰çGؽ¼xÂÕ„ÃRðvîÉŸ»Ÿ4“7ÀäÕîÖ­{ÖÒ”¹Ó ·;®é½}£ õ—óY_„ÕááteT5Ë©[gÑTt;öÛ¹»sƒ!n¶JÕ0…ŠÊ"åXŸì›µô*óÐ…¤H¨ø„ø©ûŽÅLeÕ÷ãöƒ^íŒÕ˜öógIRùn$õnë¸íõܬL,M­F´4EÖ²P,J" tmm'Ý÷s8Ój:Dï|röJ»qvS­õ†»EÕØÞ zu“Ä”jVÕ«W—Š„R€è{ë$ãš°¤B¡Ä4©ØU†Aómë,,í—ßë×^‹ÜöÃtÓׇýÜÖÑ_ïÞt4bÐ²Õæy¥nQ©h7ØNñEä½®vç·†9VTºŠ“c¥%'×Os:ü±Mº‡V,ÎÝ–Nçí6ï–L0üÚãëµx¬ŒøS¶vþ ˆŠ‰z°bÎ%.ÌÚw¼—OÖ²”ÛÇã‘‚—˦Îy­;ôœ×¨–WýO^òÙî´à(ïD”„EøÄëe–ú$ưSCyg>ïý`ÒÃ^¾Èa0€`)¥ÕL»O¤é«G¢ÅÝZhÀ s#û=¼žf@þ=þaË%î=0WÆ||÷ëUð™þ‚õÞ¹+ܼy³àúôé˜cE¥­9V)™ðø9ásõFͨ§?„$™ñaÖüMž»vk1ˆpñÿJï¹ÙàØëZ<P¢4ºû®]Ýà­÷è­õ×ì²® II“²•Zfò´´~ãèÎ_OÌ7î:–©VcþæÓ/Öx¼âÐ'O· ªÏÓ ‘uœ³o¹yóK 7F¿àÞr4Û0 "-&Zè·Õì~Ð jô?þ¥±ÎúGN®^ðñktŠÎ¬Uk'4ÍãGlccSp _¾|ù;]C¨„ ™„…É6Ùp f÷ºÉŸoq´;îÓG¶–wÔ•kÈ‚3`L§=ž?[Ö¦†Ü¯æ_Ï\èç©|%B‰"c£Ã6o{zøšÁ@›Í›7¡a½sLû/¼úòQ}¾•¡¼þ7¡T½z!¹6qê#)Mk×ÈŠ þŸºTQ”³€J‘Ó•;Nü/ŽÚô\øçëË”*zç&aQ‘= K±æ x¶'L§®½¼BB¤€×š™]ŸÓvÿ~¿°°9öÄä™·oMKSVæÌ±J%,SÓqw}4·¸Y½„—»ö¿í»d|m¶DÔsƒƒSßñºM (‰P(‘µcÈfüŽJ ue‹¹s¬yÓ ˜زò”è ÛSoå‚Nó-—VÖš˜ì`¡Ë-A øƒF¥«„ãX%©žý±ðVoy…/‰Výõ)Ñ´évmÆË–h*ÕÿøƒoïÑRi›6mÕÕ²s¬À«5lˆÖèµÎývLÑÙÔçàúÞnS‡µ2¶QëšlaªZ,ƒËãd]I7Óæ>Šcå¹kç\ÝÂÝÜP+ó8?¥rõšbê­l¢Ä±‡6ïè2ßµ®ZæÇ&š&€ÿ–Ë–-;tèìµ ŽcEeJIƱ’‚OŽ#¦iu[1ÞTS^œ,ª][S©&Að\\2JE‘þÇÁÔ8qâ”r£sÚÒy#{0LbÖyÖÂhiúšQ£yÃÖuz¿a ƒÖ™M“5˜4³1‹Þÿ³‡[I3>Þ ¥¢Ø¨Èˆ÷aÇÎ…šO<¾e¸¼ÂýÛ1uç7–½Ž½¿b®wø”Ýþ–ºøëW&Ð@žñÙát6v››m§R¿=\;ÉE¯±]wåËUù‡*''§OŸ>………uìØÑÉÉ Ç±¢2«•Ý¿ppûFïïu&^ó I¹ãÐÓÕªdD¿Hç*§·hZèæ¶:ó5•*/rŸÐÒJ|Ç`g~‘Å`êµïÚãíó¯^°-ê¼ël9þøž™ÛæÎ{ahskå&Õ{u·A}¶¶×áüg==ÝÍ5VbkÌfÏØÔDçÕ† ¯GÏÐȤZ¿åº4’ßµ#ýØ÷KäÕ«zæAˆS“’E”Â- ¨T19ÕO¿Ya¿tþ˜¾ñ’«]¥}ÿ7¼—ç¾`UL¡úùùÍœ9ÓÇÇGSSù/:BeGá9Ö”Ïg®==zÖ†£z³%" møãýÓ7S2Äô˜ºðèõ)A°äó+SdÒµ›d^ð:™!aXΩ++90Ír×ÍCl]©3éw¾¼ÛbŸÚ~á%ÇaR‘P ê»/p¹¡^å-`ñ…Ͼýk@}‡=”F¬Ð“¯'ÕÌW·çR²}é™»_¼˜ÇÑ¡RÄÖnä¾ÿ¼;€ %]][£(›hiiùûûç¹ ²¨t)æX‰¨¨(øö훉Iõ;666ß•6 iÈ}çT~‚ uõ"}K+ÍHd¨éçl˜*`Â-ab°µå6ÿÐ]Õ)¸åáAÿë2ÝùöåÚ•÷v€ïß#*ÕjÖ¬ýúƒPnòÈùëW”™™1ÇZô¨ EŒªÀTË=h± 9Sxú=Žz¾¸ñ#íË—o·œ¾¯ßŽ€ÊU+Ì¥¢r§œÝGoÜÍ~Bªé5™2ë¯÷ý#²­ Ð'k`5Be>ó •uEŒ›ø¾E¥ ŸyUY„……•vT ˆO`Å÷-*]øÌ«J¿ÌA¨´àû!¤b˜cE!È#ÇJæXB¨Äx<A²ˆŠ©„R1 ¬!¤b˜cE!Àq¬!¤b<ÏÇq¬ݹóçJ» e”†º*/,,¬Tت0°VX­Z6¯³[©\XXØÇeѦiš¦åÿ—¿.¸: rïŸô•3˜cE•‘P(”P…ÿÊ_>ºâ¶øû‚d0ÇŠ*;.—›ór5;ªñŠU‚ñ÷É`ŽUv¹£ªâb¡Û*½@H VTI(F‚Š*R`€"f P¥UÜ«ôüÙ[í­{Wå2UÕƒä·ïŠ; ji X˜øñ¤VÙsR9‘H¤”TUüJª°­ ÅÀŠ9V$SòëGÿ)î{Õ‡àI—îô7D‹™ã±-ü¯n6öd¯5Œ'lùhºw¸R#&]<ö.m._L}uäpJã‘æÕë\7‘ïßá?u¥m±·_QææU•Ë¥GÞ{®Ö®‹!f¾P¾¸\®B,Í ­TÖ%kÈÞ s¬H&+AþX+þçãã=£÷3b3€Ö¦âo÷¸uŸg“ì0'~ÿ͵»âÛ1ý×Þvq&ÝW´—&t0_7äê\x·}Ä*Ù3¨iÒm;ðßEÅŠw»ñ `¢åf¼|³RqôüaN.ÀK·±ö·£€ ÚúUj6í4vú´Õ4€ÁK_4ÜáÂÍíUXxÁ‹úwä´ð«Tøe©óNŠ–~ ¼,1ií»`ÚV±H˜‘!HOgÆ'ͱ°°õØ7ÛºavÓ,-==}N†0ØÚlén·[ÍíNhkk@ÆËdíQÚ£U«VÿýXذU«ÿ€Å¿è°ü|I̯YúSÅVoâ±fš¬å‡n6уvtÓå€(>:^Ô-ÀwÐdÒ蘒³['Z^ñ¹{±§W­Š•WOÛO//k§Ês†BES”kõ>Ú§1Ù={õeÃ×ù ÷ï:v°†ž®Ž®ž—™úåÊ­DNö¶b)-Mçóùé©" ÙqBwot:Çì{e°ö¸IÓLªh=}“š"Ð- 'á>ïLºÏË{M>¾´áD²öúõäeý;T±ßñ:W€´ŸÁgÎyèG:¯qu¶bÏ™F<2ãæ¿PžòÇÊd27oöš¤®ÁãñXš:õþƒ#G Yãñ<ÏØ¬ÖÁ©#fï]££¦†l–¸qRÅ¿"@]ß°úçº<î%žNŸ9sFœ:·?ÉÖn’ö7_OYåêæ~vß8 “kÚ¡CÇ:Ÿ0hB×Aƒ¦÷ÌÎÞ_Âäšbþ å©€q¬ººz{öìsv^¾f»®®^> `Ž)+FŽ•«Ûëîãû:꬟A:ƒí×Ä>¾~dÉà ŸF+wßÔT´l˜Õc“±ý,.ój/«¯m¶|ïŠ3ïÔútª§ýãíc)ÀÔÃÇí7v*$ÞKf·rÜÒÝH Dɇ¾~l†Pñö-à-¿š(¿ž4ÒâÞŸòXÅT«¿ëÔâV½W»?¹¼]Y!ÿ-Ÿ«Û0ÚAŽ™rOje``àãã[àÖE¿ùUF…¡×Qg@È1¯A½û{žzÒv¬ûÛ~_ŽXw˜b¾ø†¯cΛ¯¨ÕÓE¦À¬QcÏÅgLµ3žW>‹‚ÝZ7zö é_…$09¦mÛ¶mÛ¶mcSMõje¯kçw@3³èkó[«m6yQSý£sW‘Yoõû·cêNn,{{Åȑï'ãG6$§x¹J).òOéB¡ÜŠ:WÀ€µ¾Ó?>¿ :ØßõŽfÓ~Küouª­MŠ„¤Bµwþ³¯ ›†šë …Â!UÔNÞìo]cþø:“—ìw¹4¿Ýüƒ=¯uŸ0ëàÍã€aÖ³§|þé{&µ]Ïž õçã”.-[®–ÒÁÒ|A£¬?†½&¥»­þ‘:ڈ͆AµÕ5»:ÜsÖ)»#^Ï¢ç6Ñ—Š"÷ýmèl™õHKNLLH…ø¡ €P˜GŽU^Rð¶JW¸˜cE2%™+`íð­œfÍZ´6ï±ëŠg½*yÔ¡¥©÷>˜sஞº´éñߥÞÐúM¦.ë˜ðâpÕ<ãs¶ÿ 9\5Fæu.—M,®l§¤šFµFëïœÿŸl•4ã£Õˆ=™CSM®hµfEPœß šÐÖ5àBνóêN½ysªìõ—s.êÖõ6Ò–-šõÝr³oIϪˆ8¶r" ërµÐëP¥ËU̱"™bäX妸Oc©\‡`jùß cp2ÃYK×+g€£ÝuçÚ®²Bõªý÷¯Í±UÝ ÇNR™ÃK5«;Þ9Ÿ½Š©V?ðÒFùâÐí{-¢­NtmT§€n| ²ß”°éöÀ¢ªœòŒªÅ¬˜ @y+ê$,ŒÂ¢jfµ¬¨Zt“WÄûNyú=Žz¾¸ñ#íË—oTK ß×oG@¼åO!Œ*_®1°â<×(·ìIXÊ×3¯tÚÛ(¬‡juÆM.ÛGJD"‘ÅEŠ¢@!ÁJEŠ— iY|§¡LøÌ+TÙ±X,ù=J—«E¬²ëÜÌü}A2</5Ÿy…*1…Hª4¦µˆU¾!ByÀÀZ‘………•vʨ»¥ÝT‘•³+*:cãj¥Ý…2Jµg_ æXBHÅs¬øT(„R1 ¬!¤b™9V‚ 0ÇŠB%& ‚À+B© ÇKKãcŽ!„þ ¬!¤b8ŽµÂºvýZiw៲²´*í. J DZV ­Z6ïØ±ci÷âO………5hРÐj>|À÷-*]Š9V¼¥•uÕªr£Tttô¿é BE„•u7Q¹ƒ9VTÖÉߢÃ÷-*]yäX ‚ÀkQHRß=z•РC'CVá*2bß'qkUÓåþƒŽU`ò¯ 55uæÌ™>>>ZZZJÕð}‹JÇKOO)á8Öô_> œÿd÷’´'“&Oû“¢wÇüI %E{7{éôa³¥vè¢IGï/¸Ž ööƒAÁuÒ#ï…Ä—ûË1š•`•"©T:eÊ”   )S¦H¥RÕu !+v`•¤½ùþ'»”JâîÝËc6LaÒÕ-[¼•þùßÉ#¿v{“ïu‰Ê~¯®]<%–À«Î‹¾ò ¨ùù삃¿›ß¼~µÁO[¯Âÿºìz™ÐcÕÐ*HÅÑó‡9‰Õ²ŸùES‚!æ­Çü¤XÁK_4Ü!ޤ Ýã¿EµmÞ´‰‚¦ÍÚäY/úÞáAíëéèUoØ~ò’ÃTÑVåæìì ¡¡¡ÎÎΪ;„T¬Ø9V¡ˆ¢iɟ䳄BIž{ øqqqŠ%‚è[¾Ÿ¿¿G±–òwþHYÓR[U9µe ÜÛõ4Ðå¦ò“RBaÞŸÜãŸìætwñ‰kš í '·O†ñ¹ËЙ‘²×©iâ÷ÓûÜR¨P£ÿÞ.-ä‹VOøiíÕžGË%î™óÛt.k«{Æ(ùv„V.›lÖ…]”wä*’´W៾l;}¡vÖà "§B¦|=ÜÚÚ®õ‚=O/[§¿¿9yÈäÞ ä1°àUŠäoQWWWWW×Üå2˜cE¥«ãX%©Öz^RÜXÄÿ â'¯_íËú{ÿ<6ä•ãU½fÍhÅ’ƒ¯½á¨TóWˆão ±ÃÎfGÎÍÕ †øïžXìΈiZOCÇã°‚Áåæ™ª ?¿iòrÿÙû®Û45^µžÇoZ8j|ß ·ïXÓÆX]^“)è÷Ü~nU«Ü<]Ú­„!oŸ¼]x&j÷“6<[^çª[P›U‡#þ·÷—x®Yö#o͹~3·ZV‡WVrˆRC,IÖ?cׂ3ügeõX€*Ã/¿Y»ï„ÇοÛiq X¥Ø‚b޵˜cE¥K1ÇZÈo)ÁT71©*_Ä\Þ(Ðq¦ IDATqáO·®¬­¡SÂ.ÐÒ³÷¿ éT§€*"~û[þ΃ snHnq îºÄc¬™ð?o]u þæ5VÀâš•¬/b4™ù¦D„qo|6®ÞwOÜF¹Ï¾ÿ¾!Ó2zLWs‹ñ³—/Z“alumí<®Á΂bxH '¶ÑÌŽªâ”ÐMŸSõmsÊpÝÊ»s ¯âèt©'Øð4ηsUH|é³Îÿó—uJï)ߢ„‡<Ý^GUZš¶æU|ó}Sä%Ææ›þcqºy}„q~«nŒ.èPÙWH`e©7µ³kšµD­²Øe±¸éãìì¦ÊëД0(8´Ð=5éÚÓ˜-_ôþ¹Ö[ë[.tX2 ]õ<ëŸ]êRͳOίԿž›wIØõÙÔa²àßÓ÷ªYZXô-qghi*EÓz,"Ïj™8¦Ï(£áŽA÷&êI„bš€Ù]Z7?yoFU PW×>ø”Ç®p½" PîóΤû<Å’»×hÖœÓZ“äl;Ä9RÔÏ”›¸úw¨b¿ãt® i?ƒÏœyØÌÑ­kâ³h¶zï«G¶=úlÓiûæ¥uþN€(54IB5ic /!˜š]u¸OïÆ‰¬>ç· rÖ›7oÜ“>}ú¨â€R™bäX_øÙ]R}¡KD¿€9V©8féÒÅ…îÉõ­>º<åX Ö±ÛW÷­]¶`L×Ãf­t²«¥‘#ÄÇÞsw½-8ÚKqGü'†/žp[*ʾºŠ}–¨UOóO:#N}ÎdP¡PBÒ4%ÉZ“¤¾Xìíåhíw1(ƒ-%ãbåÙ_’QZ*Ÿ/>?…U³³Ç® ±HÖ 1Eý~°ÑÎN7÷N“_ÿ¦ÍÅòÞ¾Œè ×Èî<-v=ü¥Ý†ÁB¡P­–}#îá¥ç>ï\S¾¹f ]Áþ×Ba'0ê}0< T‹ñañ©Q^Aé> ½N.K‹ðu™Ü±ÅÛˆZÌì¿R”ø7ÔQËq][Oô1¥€UJ;²±±)¸'_¾|̱¢ÒV’¹"®{LÛ›~üÞ"µèÙÁÎQ‡WëÑ£§ÅØ? :µçm8>dÈ1ÇEns×·»¹±»|½(éÑ ‡u‚öË|`=y9eP}Њ3S[™ÈK‚oÿª¿®öŸtF÷”£ÙAÖ‚BŽUºuÌìMVòx<¦Á»!ì7‰O—¼;éºBøØsåV]µÌ? Cã¿Näñaös³KL޼·‘"©¦™®|1ñµû«trIʳk×Ð¥¦Öaï}¼Qä›ëÖÒ”Š~”Lb«UçîÏÑiÑDþó<|Ѹ¡Ý‹¸#mŒäuXjàkFŽ!‘"©V=-–š~~«”vTèW²÷pÙ93¨rÊ#ÇJy É›> ìûæu. ±:+Y¥]1í8úh°E”4ûúN˜øÈÖÒFk´÷±!iVÃú §Vj.[¥^½÷ …/·DüàƒqôµöFð^n>_µ÷:¥Â»;mOÒƒî®lVAAw òùwÓV5`j›†­Ž]®uàBü´±r·©ñ_çÚå.˜ã{@#>.{üæe—Ëÿµyxýrær•F‚·'ü­o¢!+ʼnœ2ôàUžQ­ çžÉý¯‡ïãý8P¬ÍæzlÆëg P;3OSéW“2êt©ÂѬ‘ߪx©’<’L¸2cPç@©ÿ­“}L5þFW,y&1ùÓí‰}mR{¹w ÛxôÅŽç]†8ú=ÊsÃó–[¹+f!‹K*Žr½ñsÎâ–òšv>sŸÐ?ÀI‘ýÇ&öî¦¾ãÆ¾ò ÿçUÏI×íPtÉöÞH‹›ò>óc¯$ý¹{xâèÝ»÷îÝŸùoÿ‘FûÜËëóßò¹º ói¬ˆÃoF¤Ê¥Â¯ÉB³Ž9Ã"ÁñîlòÊ%û;¿Ÿ×–ü’0V ¬QЪ|,[¶¬z–eË–©ò`R©Br¬„®Ií¡î›GwgT?Åe¦Å‹þÆ8VŠL:µuõ†æ\ö: … ÕÂæÌ–ÄóF¥òwm±ë®XýÒ¦É[ÞÔ¼Ô§Ä=¡¥‚MÓ=–[jd>és­žkö>rmUM)f†ÑwØÚûNÜXŸA …$EƒD$dTíäwÑoΈ©½G8°ÛµfÖXN1EIR£eY?%Qibš•cm0¦FÔ¡0áœzðq¿ ¨7Ÿcª¦x8g7>³vYtÚ-}îÞŠ©=»®¬Bì·…ÛßÙnß/Ë—Š;^‹†ïøéy`«U×¶ðûõæã2 -}ZU€•C­Ÿ°_:>¬wopmnk¹¼ž×L«ä—³'j=ÝOö[«ÉߢNNNŸ>} ëØ±£““ŽcEeJ9Ö¤¤¤¼s¬¼ÖK&e¾ šÒqÁGà âôzOý£|V^ãXÅ)?O߈s9|wT‡Ÿvëô[zqƒ`oª¼>M ]&X^Š­¿ûâV3í’_D b.…Vç·NâeeKÛt®ó]k´¯ËXÅk՟זœ}ÆÆ ö=´"¢’ªUÕN$¥\Çãñªuò <·pèHwÿ±çdûç01÷VMx™Ç—õ’”xëìkíÁv‚õ®|æTc6ãÌ©¹Í:-µç¤þ0·Z‡fˆÈXÞÜ@*úq0VäeY‹Çã2øüdŠ“÷¨Û£¯Û•£ZöÞëæ/ó‰Ò2nÝexÈKwM&i ÜÌût5M‡…ñ'/ØÑuëlNµ†}&yÜ4¬ÐUŠDZúùùÉæ ÐÔÔTª†9VTºx<ž@š9ûJTTDGGëëW ¹ccc‘÷«â¤ï¿þJNc´ìÜF›™N¶0RÑ·ÃGïÚÚòUo>_8­g=Ä ø#œJ€–¦†DÐ]ëiK3>µng–!Ñ1mqóæYý¬½ÓÒ‚™=jõõzÛ-œE{šän*÷ª€±GŸðT3we%_޶½1âÞþ<âN~¾ø7]Sât‚£Qè‚g08yõ/`UÑ'º®Y³v¡Õúä‘311N6}p1nãáèÕh®—oþ«è˜\3[[³?i¡î bÄ—?D0µºÖ`ªÕ{ùæ“T$`rÕsVÈq/@³¥öæÓTîUC·{ìµtˆ¶:ѵQACâ?†ÙoJØt[ù^Ï2‚Á)Òç†üBgÁ«*p>ÖâbHTx~ÔÍýÖ?¹þ)!<ü}µ~¿=`áåׂCUÎ ÎÇŠÊ…âäXÑ_V³·ã¤ÂêTmm7¯°:˜lF«Èî¼Â÷-*]Š9Ö"ŒcE¨T᫨¼Ò²2UúÂÂÂJ» *ðáÇÒîBŃ9Ö ËØ¸ ݦõàû•®ÿ³ËÖ·²ÊÚµf®YÐ8¿I„¿½¼¼ÆÙNeýÍÈJI“_¾úÖªUKůÇîiõ&_ìî´À³¡Z±ckÆï;¯©öíMÔr”Ò °Ù ·§ÿ¼ÿJ­uGÅs˜}i9V„*ƒ"åX•˜pÛ?€¤(Цi––ˆ’ž¿ˆië>¿qÒÛ-›ïÄ+VNù|'(Ч{ÿQÝûê¾{êüñ+ƒ®¬a@ƒ†Í„ÜíìYå›!$I&RdmJ…±gN;vòm¢ŽÏµÓm49™û*22ãóQÞAõeÆÜqZ{þÕ¬ÃAÓšê€ÁØÆíêH¸Ý:,çÆa@S»…ß,|žyÝŒËÄ+B•Sqs¬ìøÃóg|–­j»ñØì”½¾hïaÊb1Õ ôùŸ</äðôú°Xl0hÚïê¦/–غ¾KȽoÃækWXíÛÈ@VùçÕ…'µ»{x<—AðÓkÖè++ïmç{îhg×çÛèöï?0wSg×®`0Ù²úR& R¿=?zôȉów Zö:Çs§¥¹6³$Ï?ÛFŒk«“yë¿.X¯‘ãÌ–FŠu:Ï?t 2“,ýîCu[_ó·šæXªlJ’c­gëse¼T–ce°8O÷~[¶÷H=ô¹Üñ,I öÍÚÊ*uœ<·#Hl;$¡€"{[ 9¤Ïb“­£§Ó¦NVË›Xz]å2ˆ ‰0î™@ ¼ ­ Ö^öÆEì$M‰úÙy øßÖ6©¦™k­ð…6Ò¨SW#6ãÝÞF]ffm˜v"NÐp\ç\us¤€­Ú.ÞýÌ‹Ú[„P…TŒÀúqÿôG>MC;¯“c§Û8ûœB®Nëý;s|ö'8q{?[6g %Ð704dç¾x”žˆ쪭-[:úµ™Ov`Ò®«•ú_ôN Nhàif>ßxÑdòŠ.…6â|îF]Þ»Ø ½áº™]E‘­×Z¿à õZë öè^ô#„*žbŒc­më{cbvŽ5]k^ßu3/×_´¢Ÿ)¼ÙãpÓR)™üÕïüù*‹ì$)€UK¹YqU«Æd§Y €–òÅ4£HRBIâ&š\«Ê“·ý ^¿­néQ€’JdH) @ÐR ™_m†ÁÍ›·Šr^HRòUHòŒÙ²–)†ƒ øoÉ&:lÅ1áJE$)Á+B•S±Ç±ù_]iLAPdšFkïÓëیݼ鰅KÚäÓM…wg†1·Üê!ËuÊ}<𲊹;‹Å¦h6ô°°Ôʺ˜äéšdVfþÇ ÑHõýò*= 'MGV‡GíüÌoçlªÔ¬"@)ÇZ@åb1á0ß&QòNÔçÝ;ÊS_©š„ù€Vi’„É©žÕ̱"T¹u®Å›­ÄéiCýnÏ«¦2eâq)°5[ZÛcèð¹MÉ#¼/µÒÌÑ(iÒšÛQqÌÕϵTèÞÇ"¯TLof°îس=C4\<žM»à¹wiŠ¿ë´_&c–6ÖIÚ³ýGåÞ6JL¶“/0Ø@“i­YœÑ¯ùi Åyø1úeuraÇ Nž»Ã¬¦w¬*¯óþäÛ½1—. _å¿OáèÊ"oö¤?ï B¨|)8ÇJçŠa™wµ¦1ª¤ø?ÃŽIÑ4)ƳW>v)¦ON6cÑj{YƒyÞ kµqÕí ºmKo7çÀ Cnò÷ðû¡—Žì{¯ÝsÏa{Ù&”äwxxxîmÓ¥´¼YŽfk#6L^ênٸà R““’“’’“’½wÕä2‹ujšŽ©sèÌϼ¬Æ@ï¡c¼ìúGÍYbÝ¡•®$:44xç¾Ë­§í6d²< þU{v¥óV¬"„*€‚çcÍ‘c•ÒtÈŽ©lAL™üíÁ–õîW#t¶œí¡ýÅÓs©Å¡šC1ÔB—ÅHxzÐnÄ‚3»ªWר+Þçæ2\—,«j Ãåp˜PRR$MZ¸ÔˆÍ`ê˜{\ÿü[R×DC"‘DÞÞâ¦i9i͆ÝÔ„D"†f/OÏ^¹ÀÇi±)‹–ÕàÙãqòö³ˆ÷áb’ÅQÓÐÐЩR½ºY}5Š”H¨b£^ë£#ªd]ewóoÞaçöö»ÖHNµ:Íæn<2¶g#ÙÞ)ñσ¿Åî %‰Ò¬µ˜cE¨’ET"** âãã55s|-x­G^Š—],Û¿š¾r€€æèšùÌc<ÂÁiÎP¬´iø­#Ûö¿õ:¼FA®ÚÒcåàÌ!U4•ö,ôþ§oÿoïÌ¢(ß8þ̵Ër#Š`‚'*f fŠx‚¦()*’¤xdÞäIâ•h(yÐ/Q³œ;?n7 ” XRRJ¬DC@H¬>è8Ž#¤&¸èvaNê5±ª>Z°"±îõ}سé…á#ûê¯yöÇùÞ_÷®9%ö¢Ñs®ˆ†‰>•¦i>1°, ¢w^aXJ¶=¦Œuíz¥5'0 #ì ÇŠ@4*_ÇJ’dÙÜ‹MÁÐÍnCà§ù¥;h+Ѩê:V5­(±VŠX7ѰЗX/\8_cí@ ˆ7ìÑ£GPTTD’ÒÚn @ÔcÔj¥™™è÷Xa8‚ÇZï—š"D]%V02úÖ±"¢J”[ÇŠãxAAÁë„ÓXW$ÞÕsȈüï +=¤´â h 8::J¥Rž€@ cÕw—Çè­‘!M)œ°ú ¼Ï¦ ˆ¤C󻾎&FñX›ôo–µöNæâŸÇ{2ð+ws’a˜JR6¬îµù³Mî î\õÖjy¬o2F± mÛÍž0¤$“Å Ã)²Ä¤ûìu¾EQ$€SE†‘EŽaIþ³#ªu@¸”¢níš½úºóé3(·ë:%vÝ ß€!¾ü~ÁWPß›ÿKfÔe7þ³¤IkOOϲ3Oš9õÚØÁÆw:»m¼’Ú{^zð­Mˆjkò:ëïö>”ËåryÚã¿_<¾8fJ›6mZµiÝÆÅÙŒïOñóƒîß8¿¬bð!‹hÙ!"hÉc ›^ÙK(—^qR6iò‡ŽB Eb[”rÿvš<==]ΓËtسÒ/MÉ*޳2‘P…à$%nT7óìÂÕGnÏ9pé3×FàØîݾ.XƲ³?±“Ã¥¸>ykØcM?6oóiŸÅœ™Ú‘¿[üâGzPðª5Cú.íÞp 0‚ €£¿Ÿç›é²óІöfdYߓɌ<׉ v™9?Í{‘|Ö‰VÒê.CHæd•]sïk9=ÐoìcG$Z¾„&6>ÿµ’]&Å¥_¦ÔÒ7?èË/…mO+êHNÉ4³²–¿‘Ÿ•š|?¹¡˜1gZ^ÊÃô¶EK³»wrãÿL°§J³°ÍÛC{‰ÂfœZô7Ñk—g3 Ìš¶íÒ×{DKóüogGvÿãÔ¾NQÆaϨöq?¾úÉ9DzgCê4ÄòrÌË}Ù —ñ½+Ô*÷ñÚ•—‡c ~Í)é Å‘ðìÑdϱ^%ÖSëƒÂîŽéXþò|ï‡d;©U øa7Ûí Æ+òXë)FñXÕ,—zhõ¬$s¡än¡ª…š¦–75ÃxT©ÁZA뛌QÁ=;÷ù߈‰ê5}~³2_Ò^B<VÉâÁ¬„ #‚-ø]ås%!q¨vG^ ?ó±s[ç=ú;;·k¤Ú4xZ³Èµs´ÖmìÞ5û»›níùµÏ’ïjó‘ SÎO[ÒÿÔú½ à½ýѬ¦—zgSœƒç*„mSq>g–û@yyqÂÚ·‘IÂÁ?À¿ÆGh¨²Óצ¼e`¸ùp[ÙÙ“×`b;CñI9fö„]‰eOgSzÎú&àÊÜIS:Œq³(ýõJS ‘ó\YÕ€ÊNÕœ ‚Ö±6tÉ7EäÐ ¦}¹U¬œ;±¯§Çyι¥D7ϾÇ|Å0—ÇûOÛÊ”¥åöæ’ÂäB=ç-øç”%çšy¯ìR–˜^Ü{!µi¯ç#ÿ„¤Ù–áŸÏ˜4tÀû.­l†çÑu…1m\7û¤ß·“ÆÏ ÚËÕ\sãìðÍG; _ñE7۲眀à3PÁ?üïÚ€ ñK]cÃF@Ç1NY17Ø WþxÚjš³Q~ƒkˆhÈc­¯H$N7!p p’$IàÔ%§Z[ɲTl{Š$I2!á²…µµüz.a"!ÉRç 'MÛ7€¸™ $~ßYÓ/‹‹óÕ,AQY³1¡Cçþ¢œÕËŒÀœ|&)Ö®Êåí(L›6··º»iÓ] §lÛ5uh½zûÂ\Q¦Gg«"¼ùsU®¼Å¬u`.Ú[Ùï9´‡µ–ÀGMMÍ¥»Z•;…™œgÑiù¶þî.ºïçØ´‰˜oyá¯÷_¼T³`bbjjfÚÄVB’¤"+þÝÿàú²lªÛ¹g«T‹QQ!cÄ‹±4ä€)_|¯Ï7ܼuMC5oëöyäÁ@ïÒu`ºä5D4’$ÅO´âŸí$dX}ýÔ1qC¬ëáÍ‘?FŒøW‰›¶hÛnbxÌDïB »·œš[cXÙZ1ów¶nùlòŠ=›/÷žéa÷Ö€@Å×áÏÕþMJû^y@VõïÞlÕš¾BL£ O4#žQ“èI†wŽãg,,›;íYa‘uÛ>#l¤,ËžÙ‘™£Âdþj-Ì#¸²Ê#wzIœî‡ :ôPjÕÆÓ’dYÖÌiÄ©Ø8p,ËI,½¾p [r<}Û`Gx{Áö£ *œ^ÔÐÔÃKdî+<ÌÉjÏ) ¹®.ÚÈ)3R(\WcÜgϰ$4Ÿçàµ|³¶R§zàø+²,kb7ì×ýÃÄ!†¬90¤BP yy\}gîô ¬²$|Z¨K^CDÓȪ‚\Uº„kÐuØôÝæs¬RIyXªcpÔÞò%\'ÆÆNä«I,û-t]»âTÆ·ƒš0-n¥¬{hO ªÚ cˆh(±ÖWte‡* w·ewRŽã°Ÿ;!ý³xÆ>ÃIeü6.u”÷NÈOI!åê`¹‡mX¹kèâLïèþ]]õ7ãÖõ£ "s×ø:ã¾Ú‰U«h-ǶÔý¯®½—¿}µþ6"‚¼’ò-&‘–o£LÕ%¯¢iÍ­¯“X…¦’ÕRqHøÒ=~KŸôûÞ¾Bß+d”i!ßæ~y¸¿±þ^†ôy¬õ~u!TxqSÕ†;Fà¬ÚÐG $¿Ó@ps÷ía7ãSòþüóOý5sïíõŠØÖÙ«¶ÁÊ#%™ðš¢Õ yÃG¾¯¿æÙçé‘·RÑ”J¥Æ¥ K.ÿ¤¥ûÖ•wÎÉ "ÆxUZùdôÜ~á›;›׺VA@ë†Ø.¬³oqè3cœÕl;}2õµÏ¥ÑýJ=Ö:+šáðòŽ»}»Òšºä5D4‚ ÄŠ w®ŒëWV»žSGŒNJ2¤rQO­1TÐóXß4´&ˆÚnT]‰VUÄëáøCÁyø÷²€ÞK òXë+º†xƒ÷†$J$š†ˆ&þõªJ¬bPÞGÒUy¬õ•J%þkl×vëjîkØH4 M­Vë­fÐè8òXß(.\¸PÛM¨ÓhØH4ýh-11±æ[RÐ*–‘Q·P Bèæ@ä±"„‘A+@d „‘A‰@ Œ òXÂÈü+gy:ãðIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/pageord.png0000644000175000017500000006766213070106167016546 00000000000000‰PNG  IHDRùMM^sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu@oÇŸ[otƒ`‚¢RЉbc¢`ÁOìF,1°»»Q±;1 ¤Sšõm÷ûã`ŒmÀ`‰}þÚ½÷Þ{Ï»÷Ùí{ï=÷>Èïß¿A…Šz‰N§ÿkT¨¨ÿÚ*ª •¯«¨/Ølö¿¶A…Šê@¥×UÔTFE}Aåë*ê *½®¢¾ Òë*ê * £¢¾Pª¯£¬o'φ‰6óãn½•B4óèñ`¥œûorSJK*”Æß×ò£Çü·[Xfµ¼ŸOXÂZ6xHiñ0ìôÓöÃc"_­Ä7¸»Ÿö2¨;ÊúÖÖvÖ¯Oðr7þòõ×òœ©ëpS 1ܧïξÇZQ@×À˾Ýè¶¬Š”®|úÖ#2±Ð’´ÇŸ„;›”£µ˜ />ÐmºéÓä1¦¾ÁL=¸b¯Å¶5}Ê­ùçòœ©¯úzö\ëpàðxsÀLA„׉~ú¢ ê°oüˆ[ë†ËiÀ™ é‹V»4P“ÞÅ/x?Ýëб£e({ô1¾)ò"Êu€Rõ:F##‰N§£Ìì,&ŸÉ`v~~>Êf"€åç瀖¾!YÈùùóg‰§Î\ûï¿  Ú’it:‰JDÚå1ý„—à Æü/\@ì¥I^og\ßd‡W6ÔTÇ{"à%ͽrbè :úq¥ë¬û‰€( 6iÚÔ~ûØžÍ O Í_2ÌçÞó†$•0“„ÃÿòäCb¬ó³³ù˜äµÙxÐÆáO7öÞÜŒèt¼1ãƒÕ‰£kÚjQð:_o<ézØ%úT>ÉÍ\þ·Í/ø°öÖ½[[wá J€°sŸ?!ÓÅG/ ;¿qÓ‰;QßcØ$M‹V­\fÌlYX»<qn!štî.7ïÊN?}útÖ§›7?e¡ñY™ÇWÄ?}üøñ°ìÒÍÞZVV%ìãÆŸ ,÷+"Y—ÿôüí4æŸ ±Œn?¯_O«ñ“LŠ*„ùOqÀQ‡ œŒ¤ –Ý¡íÃ0Œ—–óãÍ*ÞGz¸Ÿ9¶Æ„L¤ÚÛ{ó¸uáüíä95„„„ÈY³æ0dÈe55Ú¾ãg&_º¼‰óÁÅ SÝ¢M«ûL;Ø®ÿÆ{7ÜšhÀèWÂݘ½gƒœ'úzÀWˆ½‡ Ä7Éj[ÏînÍá{ˆ>€`÷¤Þ[ž°g®]¿½­?ýõãKg ºí²áæ¶qP®È8&äüþý›ÏJ ò~ÿþm6j÷ý-† ÷\‡žuÿR/”ùżÝÔû÷ï‹êgF\}Âë6¤íï)³÷†qC=<<ð½3÷1¼ñJ½÷p+]ésÀïcÛ‚mÜÝÆ{5€÷{·¤ ßEƒ(ëëŒó Ç?·U&Òš9::mM?ëÍPG×a“Ú½==l–¬Œî0ý÷’w´ò¿GÜu0Y…eKÖjBܤ'OžÈs?ÿuÀ†?cnî7NV¦Ÿ_P4»¬ôq€›_~ ¤®ëïö^ÌÒmf¤² Œ›®9ûÂfçzÛ ¼@6Z¿Îîñï|G rA913öÿ\yât{5`‚|7WO v—`Éѽ2echô¢[Ÿæ[逿à©V ¹ö“û¸ôÙØÕÊs™óëúK—.e§Ÿ¾ø féÒ¥Àf³É OlÄf³…)Sƈ{ßž|G³¸WèNNÇOŸEÍŸ?v{ŒŽË-À®í:`jÞ¿¸LÈãð… äp„\›+Ä4[´µj¢‰·–J! \6›M€¤Çkyúî–$”ÍF€'ÀCÅOMÐk`s?Ç9>ÓuÖ Å~´vÁš º—ûUâ°ÙlÜ@Ì«DŸål¤J‘°Gžç!(¤¯¯/Úd¥Ü9q5Ž¦Ý /¤¨ÓÊhäêËô&àx¹Ï:ÛÏ<7pݬÁý¦/OtÜcŸY+Ò§¿89Î é±51_¢7(À©ic(ÃvïÜ/ÏOØBÖsiŠðÙ쿇zöá—æâ-HŒþŽÕÏuÛøOoÁ7^¯çš)&!<š e;€z]s¦Mæ 1€§³Ÿî={¶š¡ûî Ž@%$F! :uê„¡y€:uêzd…F§ 2 ?®×ÉÒh*N% ‰·.œÒ(Ô‚q<{*¯üëÐw“Þ ERˆ ’7î3 ÃnŸNæ9vЀ‘] gˆ¡;5•Ù)ih4šø…\âÒ.g#UŠ„=r=¡Ûx{Ûm—÷8<À·Ý« ÞÞÓÊ>NÀ¿ü—½×¦N:½ÿƒË&ÏX4èGî³Ã“EÕxyϽofì‹pÃe´gÈÓqB Ftlëóìcg 2¨1èðúÐôM͇ S ï$?i8d‹x/6Nx ÝÓr Ï’eÃìÍðrñÑÇÐÜ+9–S»Kwß¹‡Ññ+'éôøf û¿0~‰ãæ½tÐÕÀïrè½{gnÜT# oçŒ õ9´¼¡3iÇ”Àx‰£8™7úö} ¢Y}ûö€ä,Žƒtëˆd¥ÏúÝ­ ÎéžíEí~NaëN­|DPÔmˆ’ŸÄ†zvzÌ}_ÊŸp(ìiéŽ^s|]âC…xÀó†úOúþêT~åÏ{g1šÌ¬[<•ÑÔqâͧÇ¿‹]q1þž©ó]öÑ-¼_$Ñ ¥7€Æ`¨©^¶ò¢÷ŽÙòûøóFEŽ.D³V%ù½n#yb„tçý³½~Þs\ºœå½iíQ‰óß0L«IádÃŒ!àÄ”}ˆÒn]£|TÑ·×Ý“wõÍB$iF¹•Qf¤ç®H—«'$ÊÆÝf‹)‚ˈŠïpïTrÔ4Ÿ}÷é¤VFÅWâï‡'göØÚG›*]™H5›·åâðg½æL\ÞñùGñÑ'R$óm&ØJø7ì/‘¤ƒ;:”é2ô:¢6ìö›‘Z¬söÃcšêñ s§M!!ž—´bÞdu Ÿù°Öø.._(D9l¯ðê(~c'Ä0‡Í…|^9#‘I ¡z½óÁK‡Š®ëA}¬ãŠôº™–˜ËfkỤõ:Äß=‚ DOC2^ž›Ä& åòÁkJ(uü/ªƒ²¾=D;·—Ù‚Ãäé 9¦Þ*¸¯ËÛ5LðàÀbۯnFàçp ä—q¬Í t÷´žèÓJ­´jBANðæùëî¨{°ÝPÈ“®%Ä€Ëf³ÉQIcíbƒ™‰÷=w$¬{ÖM¢}‡'ê—A§gõHh³Ùì’£Oe@¿ý){R‰“Þx‘®f2MÔf S¯Ó›ª+­P¯ãE³æ{«‘׿^ßûoÖ‚ÆšùI['­"Jð"½Îͺ=tè{\à :’³¹=Jêõ$jj¢%¡×?,ŸåÎ ã'JMcö-ÒëVZÔ×ÑÜ2ôzîï'“—=6°±«Aá­-÷W>M·½üA>t:]\½0S_î¸Còq·w¯”—[Wìéúæ¶µÌÞ-uÝbµ/ØÃBžÓ±ÓžD ííË|.ÆLxù‰aí W,$*ª×ó£oÍ›åû‘äpéåõÚàP‰@ —v¬Ÿêçæ|)¡ùÕþ겦Ààϳ …‹VýÔp8õð€m)ÏkPét:"½‹ó÷•ÇÐE£>íc¤%± ×ëb¶™áOL$FßkeÏàÙkö|sYlm :6á¶÷‰4æ„ î¢je8€¼ss­Û´Õ$!)4’¦E«¶-tré:èzC¿|v’>¡AÿT¼%¼Å™¥Eåµj‹];¸ê¿gþëfógõÒÛ9šåª3sL ‰•gÓ¤CoaiñUÀþu÷î]LÀMKŠþvæò3Ï«û\EžßOn¾°­œ’†@DÞ=±ub'”ý}ý–‹öìIß`Íš5@¤šù.ñ,« !'5=G´E¤èè޽€—â=fÕø«wE{1!ÛµGoµé§O¸ÿTˆt–›ÏÕ»Ûõ+ûPŒnܸոí‡=z“@¹•ÈÏãÉ®ŠñŸÝµnÓþtÓ~Wží²T“ô‡Üo/‚®ß¼sçnd"âî³ãÜÔAÔ’F¥‡ûŒ_Žá ‹G R#  Õ$àÒá®xùûGç/XßlñåE½L@n$F¿ñðƒ¾!}6ºôc¯ZçÖËZSð÷õ“¾›.u» ŸpÄ)Ãdûú·¯?¹¤¸[ký—“HH)ø½+ÐO‹ÊË{P삉÷0¤·û‹‡‹ÚÄ_~½gÇbèÞ}ð™_® ùú«§OxüLgÿ  "€®Õ GÓw޽743”Îk°óEpO¼þÛuSRœ·wS«?¬‰bÑH{·bîû‘búné¹sòÖ×}dÿ“” IÍÒç¿ÂÏO'ØÏþ4f†Nß©Ò5žtŸ¼%Í}ö.¿ƒ)RsÀɺò9ä¼mG‡ô4¤JÞh€n«Y;vH—©ð·Ÿ’·|߃)½›T¨£@œ}ôI§ó× <íÇEÔšµj3gßÙƒ‹ï ËvÙñëgO½—Ýfð>ÑÞNvv booo²ÒÞzÏéuö#gNl.ÝÎÏC?Îñ9l6;/•i>h•HèuìÓ7-xò’s—Bv4%¢l6Ú¨¯×½Ózãæ¬|=ü²•hŽþaþ•_dž6€–KŽÝ["Ù8WÌþèóÞt‡@{Š@½NÔ¶?sj£ ¹6šH]»v->W®àŸ_81|ûÚ•\ËŠ+àRþüaþ}’Xбû”Ìh}ëÖiH~N‡aó. ›‡ 8(†Og°åv$))I¦â°X,£ä|ÆgqB>‡Zé7gB>‡‡Ph$ð„@¯ˆ¡é‚D&À¢ÛjNæ£>Ž;/„_±kÚÊ$.úù`ÛÉ/ïuÑ”¡e2xð`éÙF¼„u¯c×E&ÆÅe0Œ›™ß(2üœx#ÏÆv?>=øx¯V ÚÐj×ÉA1v}ãu’Nt;ä‰_דŸL²ªÅûÇ‹EòòÂ:vžræíÇ”™N›)K(ÞìêÒ6ÜÞë` b?ÅçÏŸ+1F æ#}SŠŒ¿ PNLÙ —^—tt@ÈŒ"õO ÓÊŽ-¯@‘øE $C)DŽ4½Þ—w}¸îo2ëóáÁ‡‚åwti0óìùk¸W5wvi@f´¹_b^ZòŸ>=›§iÆ~ŸTzlÂ׃ߺÏ/ùud£Z£™ÕÉM|û§Hàök(&Úé/:ðä}\'¾Ÿ£Ô”¼Ÿï”íòÞ›þCŒ{-œ(G5ÝvSç)v" xß¾}€÷×.ÚtÔFÜ„•+WJTë¼`¹³ØÓ–lÔ‚A4%i”ú}~Ke븉ÝÐc¼Õgcì·¸€N«Em¨çüï$Þ¸¸;Öº¬#?z)Ö§Z>úåPP¶Ô÷÷MKêu†¿¿?†ak^òù(EˆZ½zõ¯kÅ¢pÏý5 /À˜}#“¬Iæóùì\IAù(V¨Ñ`…z=†ƒÒ É"±žýu}$õNuõ*쩟ßz€?xµèDdcʉÁë+¢×Uˆ¨ïï›J̯ã€L&‘I’–“S‰‰Ô¯¤\2‰L.|ÀJæj:5Q§@> ¥ë3Hd‚W @ˆøçTâ—lèÀûkCÕÌ:F<* 5hÅŠºz1sÅ8ãB¹(Ìæ) ðú_W!“Z aª”²Ã`ø¬¯½{÷¯_ÎrÛüºÿœIïüów6Ú ”1ÐRö#ð™Ÿ6~Ëý–OóâèY¿îNl ·½ðÙ{nT.U§%9ºÄ£\• ¾ûº´£G?<ú(Ÿ@Ú|xœ_{}“Ρ÷ö‰×¿¶x“BÄÝNÀMô¹’à÷¤¾ù•ÉJ#b&0ÃÃÃàot>ÅlYŽoœ|2ónÑgÖ£½·¹–¸ûNž×öÚš•ùôH{œÖln+qGWùº‚Ôw½ÎápDn$°Ï®Ÿ»åzÆ–+wöÍvù|Ѐ·ŸÔTW# B”Ïár¹-:rÏz6aJgudï´qààc/ŒØ±ÿ›>ÿž£¾žŽð™¨—´cÇàæ$ƒÏãñÀ°·kýº$¦«™pþ!ßvŒÆç‰?Ì4îçÓøØâƒŸÓµÕrO¤q×;èñx<¬âñë*dRßõ:…B)¾¤“é_ø;nœïeBÇ6œíÿ5ìiøçø¤ø?¹y._ Ä„@$“iTú ‚&þ)èxêÀh –œŸz+±³ü¨1Ìã©7iÞíĉ­ùiûÆ»úD"zý|­6†ßÛ×kñ­ ¶(éëoÞ¼©WÏ’”‹J¯ËöòªðuŠv×cë#ÅçGFÊX&DDNÔé¾[Û¨“ÅÕ‹J¯+N}×ë¸ ÆŠÞ¤y‚ Uá[zöÓF‚2êh´ç)VGÂÑëùx)B}×ë$ +m€J¯+&""¢úíP:øËÝåR†£×_¯èœcÝA‘vÙz]NG©±È?Ø?®RKþµ}D¦ÈÖël6ÛÔ´òo<ü[ð™%yt­ÄóÿZœz½V ‚”æ²õz­…¸ñµº ŠSŸ»_š¨–ùTQ_PùºŠúB©z½úMQ¸ñµº ŠSŸ»_š¨ôzݤ>w¿êu”ý#ìõûm…ŠÊSÍ#X%¾þhŽÇøéçʯ§XSy±þ}ûRÊYTHP'G°Jô:ëozOÆú8ÕÓ”J¯C-A©V½î|þ®sùµJÀÊã34ÉJiJ¥×¡– ‚(A¯¼xÐ{ê˜>FÌ[u, ÀŸË«gÌ^Á,Êý÷+Èö‚ýB€¯[/Xù/ÌýywšëÎ{Ž›âuïWnQcسSë<\‡7mÝŽ ]Y»=€·+¼W]ŽÍýùÀg’óÒoÙP²)xaÓØáý{rõÛv­¬XA²¨ç#(¯¯Gì›ÔsæÁf]Ý|§ôO¹âÛ}Ò5häüߟ«{œ×…ûohŸY;›ŽEH¾åBH<†ë>†ç4ëä©Ý#:‚×ôu(ðnC¿a>¡O_<ÚösЮÜn;£î8@lÈ…Û_“<&üdX5Sñ¦¢ŽŒî9uFÛAK&Ђ»Ly¡ô¯££Ayõz·Eú˜öo©6ÚŒ$Rßß`Þeè™ñ¿>¹y6™{e‘øQ^ê»|Þ¨n]Z¶ÐnÙbçèÙ…å»Þ;ý¸`P#è`Ç6j1# uÕ% áö”©7¾Lé /a&Ȳèn· ¯Íl ޽†v[b3äKfiÆË#X=̵b ¿÷‚Ä«}çÝÚñòµù§®ûd¿FiÔÞiù¶3_"=Ûïñ4— )¯ß0œg³kaf=äØÃÁK;—k]o8•€œz™!*ùv²by‘d"îIÂ"þ•+—K¥»Y‡GP~äÒëDZ}2ñÑçnž="CNm^þr“ycBΔ^ÓϹ2ÕÒrÄíåÍzö ðk|³â¤Üœ§Ãú¯íâ9{Îä¡‹‹( (Dˆzð4%ƒ׍¡ŽœÁÕ7µŽ½8²áÅ™–£<]·l_7{t§7gW¿Å’Y³Bóë, de6Uз”ŽÈùã×Å7k×*ˆBzHið씿ËüÿL}„Í-6=xØ`ŒãÕ ¶õÙ™1ÆÃ®êú^œù8`F ËÝjfÍÌÕÔ€ªÝmö˜–+·ÏݼԓD3™½÷ys: úoÞÖÎÅ÷ñD—)Ñ‘/ðÖÜ~áeg ÑļYQQSà´!4P8qƒ×ÐÕ^Úö½'<¿³hÔ‰ +¤×e®çXÓÖÙÿíUN¯×®TÒ@Æú0:uÒÕ•‘Õ‘ÇR*•ð—Ϥh~NŒ…Q{¯ð¤ùÍ ÓD]Ùr^Òº„7.¥7 †²1"]–²ÄÉÊÊ»PnKeçà3?Ÿ a»»ÙÊ´!35WÏDFºÍª@d˜œ¹jû*HiP±õa*÷5€èk P¹öîIÛ¼ LŠ =–n¹¨¥¼m!$zµÜÞðòÞîØÿ×ÝÍ0Þ¡½û²róòòòòr³“ãcc“-³-7n8Še«ûs~Í–ç©¢M§Õ[G蕚„A:!žtú»ª ^ ÿ ~H1ýzÐoK ýöY\h5²ê´ï4ɬ¿•¦Bz½Œü¦|T˜Ïç Í Œ2Œ«©«]ñ_l»=è@Û¦:jO~¤Ñ¦Ç ÂÀŸE‹t¼™Îš²%¬—2ß-`ÌÅ›|>ÿ÷‰ÙKî·¸ä%$åù¸.¹ps³tú;qAU9½®\ªz¤fůvžpøÒ„*j\q½Î禜 åå}BÙ¬ .th©•Œ eåpY,!–ùî~laKËá®Vj…A úí{n D³.IJÑjë„ÎL²ÃÑ@„ùé‰É†d2™l2pK¯½3v}‘N§¸^W:U:‚ RšÔ÷5îd#`ÇÅÅ¡¬¡€gnj–‘‘…ïá1fÖß n¡32î_QÖwÈ|Ÿ-%³ÀÊŽò¾œ´/LFÎŽ^KÿtóŠñzÚL*½ ÅQùº ˆ´&~~~Ì”£×_üõõ]?âNâ»(„®¥­£A»á²2Qq2ïˆäÔûñ0Î\zoú›m|ýñÔe\ò)šÝFi³¶Fdì­ß)ÁªˆRõzvvvõ[£”®×QT¸aã¶Å‹¼€@¡@ Huò–Ю¯…T†@€èsÌ=}ãÏíåò»Iß FønØušHè£ @(Úìg£¿dÿW¾m‰žÊéõÚ;‚ R³ôz•¢”ùu/7:*‘›÷~ŠÛ# #B´´´€d‚iË6–ZÔ¸_´D²,Eޏ™àzmØÏk›·Gå-m/9/ù#­;Æ@t ‰ˆ+{[]ö‘ßdrŸ-Ö<½^“Qéõ ÀJ?ÕÕq«qsÕÜgÏæ6 Ô[û¢7nÜ€?l4ûÞ­\)çG.´–qlÖ×-OÐŽÛ ɾ=‡{m˜÷`£dH,¥7(Õ¦ ”óGÙRP«ß­®:ún¡ïÞ_Ü7†HkÚ¦: Í××××××Zƒ2Èk±¯¯ïäî2$5&È[9óìÀMëˆ4¸¥/¿˜àÌ2··šCžuÕÇË—X7zè‚ij[÷Ìì#º¶[¨S^Eeóû:´„^ÏüšKѶoVܼ õ«öŽ ‚(G¯g¾òÛc”M‰èä¿Q_Q‹ÖÆ•} §t*¤×KäK* ‰H„@"‘À²í…à°¼{§fÇ/N2fÄßX¤¦‰ï'iÏÒé§#›ßö§ g 5õ;äç²óÕô6G¯nkJA„bhµv»}e‡ÞçS.ƒ–ðB¡PhÒÏ“•|$•‹â›T€ IDATÈ: š42À?óÙñ'Ò¸S{ K"qiW„º7‚ò#ß½)†ú¯\ 9_SyûýsõÀÓ׿)­ÖßÚÊtt¡Px5`á¤ÜvCvJx˜Hèˆšé ºÎÞéíÖ•P”ÍTõfއn†‚ ¢^'3Z;;·€©.åöpv¶€¼¸÷yq¾­Z­ä3 °^Ö;!Ê_ü©P­¿µ|Dùñë‘fÚvó›»#ñM”ýÃqÈJ·¦¢ú©o#XêZH"c  åp1 ­fÄa&çZHu•Ú>‚ RšT,~!Ѫv©e ÒëPËGPATï›Ö/ês÷ë`~S**„Ê×UÔJÕ릦¦ÕoRÀï¶Uz½öŽ ‚”æ*½^7©ÏÝW­#ƒZ—ÏÃÃ#99ù_[Q[©×¾ÿÚÕÄ?X½ª‘~½k×®ÑÑÑUoÑ? V ‚¨æ×ëõ¹û5l~C¯†|,¿šŠK-Ay}=7++SÜJ½§ödÍ K7eð‹C_»p>ž+€åÖ-§þÊ©L£*ÊD5‚òêõ-›~,Úo>2èKÐÈ òãñ¹£c÷¾œ0‹@š9yòa§á¨DVvVªPrtU< ÔòTEõú³ÄtÔ»Æa3lf±t€›ûøÔ…ßÒí˜ôpun©%^òøà¬‘~ag#_tÒ*‘‘‚+Ä4””½[¥×¡– ‚(:¿N¦R¥WÕ¿ü4­Å¡æ àÆ‹/냓úüâ» ‚ó“Éø&'óƒïäÿößûedwu`5‰Ê\ 4‰ª€…*D5‚•7NÀ‰=Îôì¤ ÃÿvïÞ½{÷î­ë&ÉmvïÞ½vžÃ»xØ}a,^ùÕ™Õš÷xIs>:§tS˜ Wˆazu:¨ºRßF°òóë·z0Ì×+ñOÁ/ˆ¾¾= ܹûÌ>¡C (+j™û¸C/°å‡Ÿ-véø)ð‘tS¼‚ODŠa#©„ö¼Ü77$œ]?ª"=Réu€Z>‚ ¢äùu~Á‡Q›"Æ=¸,Q.à§ÈÖÏ#Œ?xÍÇ$-¦þÈ7¿–¶Ò”ì8ÙO©]¥Š«þÝqkÙ–”f¼J¯—]¡& ‚(3FÈÏX6|„ ÝœM¶»˜ñŸÉÎöëV?F o\”û®(»Áð€`³Á{% C7 ;‰¹þØY­—„zBýÁ ûº—ìݯKP\뇟×H'œ ÝÙÐÅŠüÂMÀ÷º·ü‡­¨²Ìíí{yös=ƒP#níëõv+¢×1nèñM+¶§4üàãQ+©l´±¡kç>'??+ãÞ¥40AßÀ0h˃â—#ŸyؾÕòäÛnKµRÿ4Ë@~½^ëâÀÉÉIžjµzD z=êà·5)S];Uê·úeïÔn~–~jU‘î1S®Þã{ybš¨Ä¶wóZž7O©ôõ Bz_擞1æŸ#nÒ“'OYϱ¶Œ ‚(A¯·švùÏš6Ivš<`ksͲ1êê9׸8s¹º™û‡—îâÆy5V~›”L/¯Qëô*kMêº:‚rR_GtíÒEœš©s91î5}a/ùÏYåÈtñjË8 J´§NŽ üÔëøu`±X kåõšãë8•X½Š-ª¹¨â×K­,}9¯QJþÌoZ¨añ뵇 S§ðPUµúþ¾©LX©÷‡hyOv€MÖ q•~úÍ/x¿Ð÷¤x‰ºÉÌ)Ÿ_b~³Ÿþ’ý_ù¶zøfåôº<Õê$Êž_ÇxyùuMM9ç,ão\ˆ²п™&¹@ –€(¢×ûw áðVàäå Õ5šZÝú-g’45 Í&’õ_>¿ &6™Á‡w¶Ô¨ƒ©™L¤ë;sÆ /z·°ß!™L&À4¶îü³2™$2™L.ñk`«Ë>ò›LîƒoV^'H•œ5* š¾!ƒ™™ÅjD¤Pi(Y¯ß_ÚobЯîK®Ÿg[~m€Øs›¶w¶ìïÕæâ”žšù]\^C‹>~óNô,i–½UóË盪g}Ÿ9`®Ýëûž•­ºÚ^Ö™>¹µ€›8{ùéÅ=MxéÀÎ8?pà]¼'#ÅbLaåX.Jo ïý"Ôrþ(©O²Ñ5·jmÌȉûü51Ožú4£F s™Y‰LÃV 9q_bÿV©yUAež%å|?>ý?øÉáØc¶Þ“çšù¿ó`èÖ]ü‹þ“˜•8oµ‚ñ xÝ´Êú „Y{@ÎÏ=‘:ø$Ý`Ì"6õ4U6¦¹ò&†æþå)&å׫,$†IKCäkÄwZötåšËGY"ƒÿB ›J=p¨ùTX¯³RtpÛû²›…Ù x§±} ¶\Y9ª½Dµ¹ƦñŠçãØII‰ÞNN Àtuþ7ì0I#ôîUåu¤„ñP]+3&óÓ£K;*ðù|Å0LˆKmLÈÝz,dö$:!jôo…ù^OÏ×Þ÷¶õ¬©¹I?0°³nNž\øB~ÞÏt­Q…zÝBò**›ß¯„—¦×3¿æR´- ÏX28Gq½N¤è´kß4ýçû6÷ó·øm:£¿üI/¨Ö¢M[²X@$‘J¥Qšwè Àínк]LðñÓgyŒ©f”£×3".OœàÓÉïòúf`ØeÆ“kZÃ]‡„?óÚ¿ÙËLì·þîå˱‡ÏvÑ,œ¡c¥Ÿõ\œ¾g¿¨‚TÕP…ô:…BÁ¤@Y± nv_~•B"‘ˆB ‘H€2¿ÚµÖkš‰€@À¼yŸ#í}›‘;y8ÙôÊ…½PÖŸˆ[¹`Ôã>É“·Më`D"Àj|㔓I K\H$H$¼q™Ïm‹JÄç(¨×ÉmÚ˜çÇ}ŽÎä/7éÃg´e{ ­„щ\añONCK+íû·£7˜ôód­_›Êg(¾°A»iÓ¦d(ñ^ˆ€›x"»©‡QáÙÅP¤§‘jdÚ¸‰©&Ÿ™É!j™™¯p”‘œBÖ0°¶3HMHHHÎýǰ òòŠV±C<„Ø‘Ïfñ1@4‹F:¿bS±§ú‘Ë×Qö÷Þ™{ûöð3ÒJ†|Õ[ž zbãöóYžCE¾~À{Ö5 Hôæûw-qÒDN§³æ›ªGÍáªôžT W³uÜÜÇš3–sïo%ò- ³¹.Ž;ƒOå ºÍæ®ñÂ0Œ¬n³0ð•e3jÑÛ7yÎ ™w3ðøÅ>Í40 ÓhÞÿä Ýéãw¾×ÕVƒBÕêãk¸â^âÁ Eg§é»†„¸âfˆ ã®/§wpÐ cÊ‹1FŒŽ¶VÜ¿‰ŸÞýÒ42¥”|c°b¾þIÓ5iÜМò—_t"S‹Xa…¿â³`L!&pt£æÚé•6æ_üþ-¹²YTTTëÖ­%ôznB¾VC ùÛµmÚÈóø{ 27;Ô}~tô—#ÝíÖ·=º¨¡‹eG§»‘³›”óþK¥a±XxÊ­ùàÁƒ=zˆ»`<‘ÊúVO¨YúKÉÜì—£]º{l ½uiuÂ__›0`ÁÂçl4ŠЊ|=<<\ž÷Mñ¦Š’¨D´"›6]R¢¾ä 0I·MszØÛï:ml3¿Œç´³·Íþø6‘SCÃ?e:€¼zwtkŽP† ÚûðWâ%|AgëNê䂤çDŠ1Ø®ó{àªp"'¦ùüªstP@¯ …B #¸ŽêÐËš`è÷8¾þë£d¶ôjr"r¢N÷ÛvÄ^»Øx‰ëz¥õ:îèÖ6¶²ßÅ„ïÂKÄŠ‘ H^~~¾#Rµ1ŒùÒèí›hbD:+ñsMutPÖüzJjêÞ·_z–\´’ŸÖÖfªx ʉæc<åÄií@³©·#qÏè=ÔgV¢U‡˜£+G—¡ÃÌ1eVÐní>¥ŠÎ *ågø›´D¢¦½m«%:0üº†h˜°PvB˜Yš £Þ&U¥UE…'C¨ †šZ‰Ygž@r‚–•~ªÕ“‘õ‹«—vó›f àåFäaB³0¥àæ™»Žcû«ýë•]K{©J=¾B(ý(‚> ˆäsPÅPˆæÈjtŸ¢Ç°Ò€@Ò `B6>]£g¬—“–)¨_’\TI<Ì÷½wõ­ýò“Nÿ7ý_³±oP'nV„{7Ôeó¢äm#‡û‡ÝZµÂoZ°KL ºòg+4¿ÎãñDn$îR5ÊסÚß7U3ÕãçÇ©ÆmZê"NÜ×Y£u‡¶HFt¥¡e»¦ï#ÿ4kÖòkz«f|Kâ(-fëÌÉ'K.Ç*DK¼Õr¢^Šjo`ÞïÕ» u{oo¯M&c¶\[3 sÇvïÒÿ5Kݱ**¨×_¼xQ6TŠÇÃ4jÙÊDÂ?K>ë@t CZúÇ<>;ë}x40ôÌ:4oÄKÿý9&LbÛNÖ´ˆ‚l–¬›·ŽÒâa†Í˜cS20eE>~ö¥x“ùǨãÂÅæ…Ó·˜udç•‘›o.Þ€¨¶,è¾Þ†U‡%=µÒÁBªod$%æ $ôººŽ¶šØ&—ÏÍ,˜égDG&d`‚¸¯ÑÆM¹ñÕf³R@ð„ÖâDDDtêÔ Ad(i‹Ee0¤æ„,§æÄc†wá_òÏÀ»ÿçŒè1"‘(ÈÐØD"Q ¨¹S+¢iÓ¦2 bz½‡&ÔGÕúëPz÷Ksè:ãè Z¦¾QŸ»¯ZFE}Gåë*ê ¥êuSSÓê·F)àwÛ*½nm]jÔMݦ4PéõºI}î¾J¯«¨ï¨|]E}¡¾¯¿^W©ÏÝWͯ×/ês÷‡Éùþ3·i¯£d»*ÊþñîSA—ÎJ›^ QVSÕF¥cxêäVy}ýõœQÓ8ûâß ªRkÊ&/Ö¿oÿ·¹Ê\$¨ÖåÁ«t;uuå§¾ëuÑú0 Š_¯+ü3½ÎÊã3JÏc_TH¯Óh´’ï›– Š-• {ªýõêAQòüú;{Çhk×ÝmÒâ·©,±=سSë<\‡7mÝŽ ]Y»=-û·+¼W_ËþtuùüÉÎ#Æ,Ûq'æcï/l;¼ÏA®~Û®UE$^Ž^s™ªÄŽ×™”ŸÊøzÌ…ÉÖc¶¨µ~xßòæÄN–=Åõ¿ÛÐo˜Oh‡ÁÓ¶ý´+·ÛΨ;Neráä±Ànû¡a×Ñ}[œ]9ÁåØ|WÔ‘Ñ=§îÑh;(`ÉZBp—)Uò‘¸?‰—ÔdZ¨ ulå¤ÂzäqÁaÓ»CÓ[@›þÂgFÖ}~³¦#îzïpôã‚A ƒۨŌ,ÔUa–q¤= ½û½· LŸ]tßñ &·ÄùCÝí¶áõ¡™mÀ±×ÐnKl†|É,Í0 ãÉ—„_ãå9¼z÷uÅõzÍAQš^ggÝŒf£Úw–»>,üOÈB>šŽÐšAz“—sRb•‚ eƇz%®0²ÖEßF;ëVÝèÚLtj+Os8Xþ7¥Äü¦1g½"ÜOm±‘§©²)7ŽÌn>Wïnσ§\êÕŠSa_§ë»Ð¾è–3z7ÀK„¼”‚þ9åõ†óìav Ó Z›²£g£r)õDzé„ù§^fô/ZñÛɘŠZ[Cx»nJŠóöîÚT`&'&%ÿ^ù¬´„hú}·ôÜ9yëñ9±Àí«ìCpD](¼W ž|>b€ øåÀ½¼}ÁˆYë¾å°eîfç}ö¾œè7©¾)À@ºMT€`øgËY‹þyý,àHÖAÑ õ«öŽ ‚”æòêuõFææ\uü³ãºGGt¼ÖÏ \0Ѱië>÷Þ\ØßÕó¶v.¾ º4H‰Ž|ùƒ·æö /;ƒ2ÑhbÞÌ´xÁšnc‹f†øg§ ¡Â‰¼†®öÒ¶ï=áùE£F•ÛU%êuÉŽòsr*^Ó¦Ó÷Þµåâ-¼Üé¾áŽö$ëOî#½ÏÜØÝZ*Ó]ÆË]|ý v:…¯Ÿ„(‘8‰DD¼¬×k”6kgdŽ(žRôz-A)ÍJ]3CWW·ÜFyLE­Øœ £ö^áIó›.sudËyIëÞ¸”vˆ\`(#Òe/¹)ƒ¬¬,9×Ì =Õ«ð (âùóçòÄÃÔöTÒ@¡ É>¨\ {÷$‚-ÄI‘wކ¥[º¶,ëy@HÕö5IC¤5h.†¸£¿?·ÊÅÿÃë{,è$â{Ö¯gÖ„!s"Ò9â-|KeëtªXÄ•®µ.+é‡Rì/›ú0‚"”C¤˜~ =è·%Ð~û,®´šYuÚwš¥ÂFV %ί‹ôºôü‚ˆ9›_¬ºt¡ƒ:ATaˆïi>6ÙÝ©ÿ$ÿMó†^Wb8(Í,ª#Òëâ­‰ô:¾I6¦¡œѦrç×Ë †Œ ‚TS<Œaç ‡/M¨Ü±ÊB¹z]Z[ãuìÞ aJ®Qìp¦•Õ–é+&=µìÚ¶ ЀJü’-5¢£AâfäK´ÉKaÈf¢Ba6ŸHi ÚTîüzÙÔ„TÕû¦²‘#ç±ÒŽŽc5bQèµ=úôÀ7[ªSòä‹öš9™ä'ÉDK ߸š Ñ¤·h37*—ªS¨D?¿c\{©ªdtµ…—s”yÿá Ó ‰1ù¼ÜHj˜î½ûPÊÔŸæNÞæ…ÑZ–ã'Ÿ ǼÛà»,þ l~Üu„‡ïß©íš7ÈOüsí`ÀÉDʪ#}D?³°ÇiÍæ¶’ÐTòÿUȤT½>tèÐê·F)ìß¿ä¬GäF(7íðáâ]†è5Ó;r$Lâ¨ö]µˆòþ%öö`­_—Ät5À×ò&49u'hó òY(¤Ö´µíÎ+ºë“y<¹‰'Ò¸ëôðM¬²ñëÙÙÙå׫‹T“^¯ T:_‰ÔøüùóJ¿Ž2ôúùZmx˜*Ê€GÔlµâàù ÌLIW72¦–üÕÄß  wè®Sh¿„¸ªþøõZ‡J¯ËFZ¬WE ûЭ«â7,Kæ J#ºÆF¤Dʉ]²++pc™íüëo«v£ÒëÅTÝ{Ií®ÇÖG>ŠÏ_7¢[Ù5Ÿ/î»õ°:{ECåëJ¡¾¿o*Ê—$‘$Aåú–žý´Ñ£?|(·¦gÉÕÐ%]~½^£ůN” ×õlºżû–ÅUܤ*sÙWH¯“H¤2´G•ÙX$ìQD¯§=¹ÐÚÑÆH Rø÷BKA ñ냼.ÿOäëÆ]Û«•x "àg<|üz iD‘Ì4ó÷ýÝÇ1ù@7r:¾®çÔiþù5 _`Ž^s|]Y÷Êg–,H:&òõø;×ÂòJ\¹HTS—áÝ äøáD*q¸I¯±Ã[k@AÂ¥îãC?:®]eAöUܾŽP†êÑïµ¶ëÕ€œoot&ÍžýêmOTåPp_'Q(tæcGXœ>w¦ÛgDϘsWÿ ©fË¶Ï ?1·&8:<~üø_›P]¹'Ò˜n¯'€žÓßõ~ÛÛè£[üDŒDçâ¾Îçp™Ù‘»Ž|^0Ï•qåè6s'·â¢ œèÙ×õZr»v9:ȯ×5¥s>ë:M™Ãˆ|ø9;91" öüÑ=1¹Ò‡?ºxžªÝÛÕYãìÙ³ZÍZ êøêìÙÇ@Õi³xÓZý°mþ¡U˜BM~½îääTufT•Öë9¿w0:§_Zë›ßÅ¥³ASó:-çú¶Ñ“>|äÌ9ì¿WöžÊ™?~æ·AÏÌŸ?8ï½FOHé¿õ¤[s¥t§*PT¯÷Y4(|»W°¾¯…Ñåý~€c…ÎíݧOüùܶy^è´ÝCóåõ×ÉjCNTë9‚¬î_ñ>ã¸%dvʬ/ ÓV¯ê×*Ô"Æ»rËêõgìçm½5kPFø¾›Ùƒ<û6Q–ÁJDA½Ž4dEo~™¦?¬DiÇÀ}§Åâ:Â|fîK.(­‰¦muyý÷:®€@1^81vË3ymW¡„¿ÔÚîÐ0åx‰ÒãûÛ‰efîáÁš&š¥5ñý]†ÿ×}[j ¸ñ“&ljµ½–e‡•Ë׉Ô9_¢FŽŸ ÝJ_[}»»/ÿm:@dàâõ±yx!ûO7!"@ÕvZ¾°'¬O¢é¯Y³†ÌhÁÐ×_³º77ïÅù¸„¨1sË.í÷‡w¼L«Ân©( ʉӷ·>¼c[fDÊß¼ ­[Ñ´û˜t>xi«ÂW:NôµûŽ €ý÷Òô7¼”âááÁ+øT’êñߺîà¹-514ÇßÅ9³§ÿæ ÿiŸ*Œ\z¢L&D„Ÿ_Àd2y,>XÌ‚‚ 9¯(]7Ÿùv¢E¦ IDAT988•¢nÛ¡•Upp0ÝÀ­õ´Ôàà§~YÃbÞšµ6¼û“Ö]'1H(KòN_)Th~½®"¡×ISS P!E[[SS“ªN’º^¢PŠfç9sqs½üðrΜ9É{Þ¯j8gÎ0"Å„—óÙÇÃý uôó}žü|>Y£&®}§^òÓ®\¹:Œh÷íá•+1àè\<¦åNZ5× dUþò%nØ^ÀIøò勺Y/õë·?=†_¼ixö£Cž»®£4óç6žž8îi¶fëe¯Òëâ›DJéS§À‹G^ÛŽœ:µ \Û ¿n]]´Md6×°°²™YAÒ+ÝÂÎÎ.7FŸHkdkÝ*äèŽù®G Fø¿\?‰Ìþêdíºðåû¡5î{VÎú0VÍ4uÚ8úûÌ‹ÿ;9!6£ðÍp}´Ä"E£‘€[¼ íl ƒWM»‘ÙcõÚçSUáè*Ê&ì[ίg®û;<˜ÙÍÔšX´lPøZt ¥Ä"7ç‰ÖªxÃ޺¨ ús+šslOLÃbÙ!J×Ú]´‰´ÏÁ)ïcÛß{ᵊ ÄÃtží›ûåÀ·o!>§íÖoš´£d•˜G÷ͱN&—'J´@ Möß0¤yÖ²©k¹Uµh«J¯C)ñ0÷—Ïе[ecý_ð‡ã\×mR+±·õ7±-á®K±ÝN›K´ à%®Ÿâvâ³Ñ¹Ç‡šÑjhà ¢óëMzO[Ö‹ºj|(|;ï»ú]Ó¿G»å›ðJ¾Kæ;ÿvÇÈÁË–økÄñwËÞn3§×I~8{âž©çÏJD¥×AV÷¿_Y=ëçh¸ØÌ={¸?+{jÈ›é£J†Ï{ž½1Þ‘x×ç± ýb{„o®ì]¹zGFS—»/-5ñ®G!½Ž5çÏìqÂßë-~'Š ÞÇ8ü:¸uGB¾xͼ\.Œ™ÖãâÊ)ø"ܘ€™“Ç€Ö]­ßZyúNDͨ_ÑìÅþ!>§nöÁïDRÏ–š×ÚûoÝÔ¼Äz:ºtؽúæ¬ãOð_BÔÔ×e@ÄgŽ‹/׃TcþʤԵ&Nœ(^H „Ü—p’º™UÀÊð\EKÈ“;P=œ8qBεê*x÷¤„K 8"­D@?/‡«¦%smQ7‹H-)¥š †a2@^½.áè€ä—&Dþ¡£CEôúƒªÞ%#g ´^—pt kj—&Dj¯£ƒê}ÓÒ¨uyðTï›–‹ÒÖ_¯{Èôò¿^£âék/õÝ×eºxò­šfOí¥T½~ãÆê·F)àwÛrί³X,•Ù´¦ù–Èùã×MMM«Ø¨JiPßõzÙë9V±¥ò"þÛSéõrQ­£¢¾Sßõº™ñ²yñë¨4D’vãFž’S$ž ¥Pßׇ‘Xýøœ)Wþ²E^.äædPõõJ8(ÃÀ5äüô ™$ä¥Ìw sñ&ŸÏÿ¼qŠÏÓd@d=cÓF uêë:Ò¡01¢”çãºäÂÍÍâyðÄxUºþzÝ@5¿^jeq½¾èÆÃ…bz=öÚx×½NÏî{*hRXàÌÔ!; Ô@ò—e½kÃ`LÈKOJˆýý~ó¬gº9¼ÇϘL$› ÜÒkïŒ]_Äóà©ôz…Pt~]ˆf=yö±ì:Ö=µjL2ËjDxmçâS¿ 6l\ÔBMÆ÷‰²£¼/'í k+*!ÑšvïÞ½hkâ¬)ácO;§Íャ £×Ò?ݼb¼ž6“zÒ©•õ~åõu^þÛÁƒGtéÒßÄ„Ì×o"E›‚°°·Ór;kV<™N͆uûò«^.MK«ðrç·´'Y;dŽÌaèì—w´*éÖ‘¾vVœ/I˜T¾$m›Ñvçį¬Níô Ÿþ’ý_ù¶…oQ(Q¯×ŠT•^/µrYù’HU³ë‰;{îŸÜºb”Sk—™>Þ«þ¾?·júöÏîµÖ¤Àðåç„·‰#½ïì$–^æG[wŒ(ù‘ˆT&²¶-AXQ¼ÜÀV—}ä7™Üß«ÒëB5¿^y­Ÿ§ßGµœâ8£Š_>gó˵—NØêPEG®<¿Ì‘åî4`ûÕ÷¢Ãc¹(½A9žÇË`˜fÃÂÈD†)åü©Š¾ÔgTóëòBÓï°îôC·¨|3*Èê6ïÞJFåºy»-ÓWx<}^˜ϘBü›QÎ[ä©Ïƒ„8©¡¾ÉýË%RLª¢õ™Šéummí¢XÉÍDEõºÌ`ü3Šb&×Ömš«g!Õ!ÊL}ÚÆÙëV«¶Ç~µÄ÷Z¨S^Eeóûú®´^Ïûórªï“Þþ–TÀË3¿æR´-ð϶ÔëµbD9z=55Uf9&ÈÓÕo¬˜…J£Òù’¤!@$R…ÿýt[ XT´Þ„ÕøÆ)'?’¶Ç7‰¸ž>}Š ¸éɉ~¼½pã•žÝø m.$Rá$ã»§iæsÛâçÅJÆç(¨×kÅ*ˆrâ×i4ÙÏ®1´¶®ôR†£ …B!†Â/m˜ôód­_›ÊgH&ÅÀÌXóËÖ­_!ëè›4Y{pá@‡–üDnâ‰4î¦F©>0eÄ¢Õ½”Ÿú®×Kór ]£È)¨Z}|­WÜKÄóàµ]|(d±,;Š>Æ]_Nïà AÆjpŒqm¤¾ÇÃàùMAl[Ü·ôßw¯·lQ^!mô?î²4¡×±öÖe× }mñÎÌÕ7úˆŸTÜ×Uñ0åR5óëBÎìy>ZZ44!P)õ™v¥©´^—ñ^‘¡®ŒÇˆ ýÇ×}”ÌŽŒŒ,»fNÔé~ÛŽØk/q]WòüzAQT¯j-Z´*¥µÖ¥ýÌú›ƒj/Ût±TޤZLGWúY fŽ‘£švk÷)J?7Ôé”y}¢ÕýÓ§OÒåsVoTª=ÕMi¯ Õ}¬¬_`]Aù©ïz]”ßd½uZ¥vʉ„=*½^.ªxÙ¼xñ¢ŠÍQ2ªx˜rQ­#|!$õUì—ŠúB©z=;;[º¼V Zjù*ˆJ¯×/ês÷Uñë*ê;*_WQ_(U¯KgÛ©-¨ô:ÔòTªÒë('îÊ©kX‹án½jJô³J¯C-A©*½þhæ†ÎfY$. ËS4PÅ?¡þŒ`EŸ% Åi©5Ö—‰ü?¼æ$NÖ­½Ç¿K£×qÌÄÞõt}äšGýÁŠéõ‚äÝ]Ƽúð4˜„Àß>Ý&±¿¿ÛýôæmµáGÚ0È€ ˜YYY%I¸»çhÄÄoAUÔiTzjù*ˆ’Þ7}ôöÃSþéµ_nÁ´ôX8¼8X•nàè*~È‘!_Æ,RÌøŠ¡ÒëPËGPA”×|J?ü3BÔØ¾¨ÃÐÙ›ßm.­>7÷áê/9Gη© µÕDHHÈ¿6¡Â(ÃSÇF°BTÀ×…ü¬5ß²;›‰JšOÜ«µÞaíç¥ËÛéÉ<äÒßvöÓ¦ÊÜ[¨uyðiªNŽ üT@¯gDøgQZ1,.'RÌöŽ3ŸêskùméFRù/}ÀºúÅY¹—KåÖ‡:¿^{GPA” ×Oû>6vØ!1IÙnþŒÌN¾ßXcÛ”LPÏÍz3nÚI5 Ý}øÇf¸Ô«_UI…ô:F¿K\Ú«ØR¹°G‘øõÚ2‚ ¢èüzFøÚ?yvöl×Àmø^Œ/äd¾Ós¬Æ„Ýa·Ö\šßoÙY¯~ÕÊpôšƒÈTEzZWGP~äÒ똳tòñfãŽ:ÊÒmó&šÛºþÛ‹oæüx0ÑeZ~ßU÷†BÏåvwsf2/îšÚY™†+q/Qз”ˆâÆÔ픹ô:7ûÁW®Á©€n2›°˜4WÿÍÓ<SDzƒ6ù®:x§Û”µW¸ã†]f>8’×}’ “yêèü>UÒ )ã¡‚ïeŠ;7&¶þº<`‚|6¢Î ¦£r“Þ§jÙJ­Ô®â¾^9½^»FPAÒë4=ççoû’é²ÿhºC^_‚ðò~…¤¬>ÿjœC‰gl ûù„îÈ;ð{çÐDÓÄñ¹\½ˆ‚ 6,XQ ˆXQéÊ‹¨(vDÅ^°€"ìˆ(VÁ†½£€¢4iJ)iwï‡@)RL~Ÿ’ËÞÞìÎäò¿ÍîN©‚H-Ñ÷_ŸbiÉ$ðQwH_¿zëà­-³öÓÜ£|MYo{/Þ˜m{d&ßË “ 7çW±qz½myPDD_')Ô5êĺ§‘ ï<»Æ·@;ö y¥V@JÊ׃—#µÈµÂ£fNžÁ½9]ú=ïµ÷¯<4aR3ƒ“†ÿp¿§y=ÆþOÆu·}_ûyHsÔÁ¤å¸Ûmu¼r>ìt^— €å”»÷8c¶++oJ)÷´õ¼rgg*<Ñ+òE¬×V×AXÐ 9®HÃþp•yºÉuϳ-—Â+™L¤àíyÏÓ‡°íwãÕ˜ßçÚmRs ‘®]Ëss&î¡$Ô‚ìBºEðAsœI+ÌϼéˤkÜ£,-ÝÎlϨsüÞr¦Â“ :â>¯^õŽšJÄZápF1ÎÞf‘QþiýÑ”=—à *#ÆšÞŒ}rîÐÕÕ¶ÎçÏÇÄÜ߆Xí¶Hõ?ùÉÛ©GÕ猊$÷ˆþ{°j`b@ ©éééÀFÆcŸxéûˆÙºÐgáÊT“e_Ew•B¡)ôºX!Yo*°0¯^?p(€ÉoèãàÁì¦5O„ã Û­<’MšöQÌ‘Äz ¨tçàààXÓç¾á+5娿Ÿ˜Ïˆ¸siS³fb ¥(*H+H£pÏÏiýå¯r6€£½ý7Œœ±á‡ìÔc'f*+É£ŒŠÄ}WòY'~έP¶Uæ¼\eÑ-/¯g8£,3-“ =Âs傤¯2P¥üD2Àèæh¹x P¯kj¶Õ¹ùYYYÐX½.+++… 6z|“"àÌ߀h>ðõ:÷L¥W_Œúîã·ÐøgÿÑé~^YNó;>jó&&NWéo(µôV&hG-t@ȳvZn]•öè{%Cº=‰3Ë©l— ìpfÚë[+N½µàÌa—>¬$uiFåwΔIœ Ó®¶ëA½Î­×‰ŒÚæÇº¯³Ž´;Ôsß´]²›Î¹öúzvÎÿè‹(Q@QÓ&îþtÈYÍ’ÝÔ¢w«gm$åíô3Õ)Ï»9å绫ɑHU¿œ¥Ð„"&g–S½NÒ6ÍgVˆÃɃ¤ùA¬X%wdèõ!Ñëüá3 à™ß¶õ"Æ(P€>‹‘MlCúo;å÷iíƒìs)h PKâgŽ_¤¿ää;ÉÓx*ñŒ\~tæ®Ë½djºWOŽü4¹&´$#©!Öd‚/I,‘RÖƒÚÛÃ7yóÅ quî@Çq¾vË|rYÆ·{Oß½Ãqœ@ÒØwÂz˜ÕmKÿñêΘc½$É8í¼<Ѥ @ÿÙ·m¬gªöuó«ÁY²cçìÓ¯p÷êE80i™¯^½€²â‚O®>Êæ³œ}ÊÓØ¼nKô9]ë""îû¯³ò%U¬3],Í>e•Ë,œ—Þ]§['ŒF£¥<½¼e}Èx×åù7ÖN]ødîL[³AÝYcï4:À 3‰¦CÞ=¹{ýÜñÈ/”5{÷¤DŽ2Žš4m¢Éhcƒ®Ð~ŒS¹÷ά25PUM5éØ b!SäÔ»öÜv"râ uõGpÕÛH•µ=wéRÀ¥£而ªù:Ÿ-1¹¬lx}=ßðhUÆÍ-”¡[F(SàoçKúi¥zýˆ³‹ì¶³ªs“7?\FE³[0†?º7„Èø5]^“€ã8‚*[Íß`5¿êDPè¼-:¥H£goÚtÓc× ]‡X¬bCõ“ý¶OY›mzÚ| A&½{ucµ᎛ã8ïè­Vô¸…§%cVúruøÕGG[ÐÎHâyNE¤¥Ië\%A’–Ç»ªËÖ‹d¥áAÞîg”Ö ¯8ñŒ™ßñArm ¿ikð ð¥×ÉCŒU¡1bÕýÂäxãæãþeL„ä:¦jR5Q¶Ç‘È ÿdIuŸU/Ë—Ä•$A¿[ªC\­˜Lfeä{8Ìæ(ÃèÓëm˃""’^Gɽ½½y‹áŒ’¥Ž.¿'h4 FÅWÇ}I»"® cmÁSbiaCP#ªâ¢AzH$â‚ÝÑi½Þ¶<(""éu•777ç=µjh‰–ãÛ-ÜK…áØ¬‰û³‹ÍG±Þ–¤n"«9õmö[BÞzb]ô1Ç؃ÂÓ0½NÅAªz¢ká‡C6ÇsÏÙËZ~†c·ïÄÖ[C?S‹ŽdÂcÇ Ï:½IÇ>žrì¶öôÀÓ$ÄÆÖoó¿Ä¿çAáiÀøzÚegó ŽO¯nW%ʲïšÝìvúÕøêÍF0z››[½×ó›4:?p¶/—>Äu©ÎŽ1 VœÊØžøŸ á6^]kjjÚ$WlND_o+‘&_מä;ù°aÿ±¥1aöóÛõñŠñžRóŸ6*¥•žž.”-*ñïÜzkÔ¬$H8hókÌ‘ñÊÒuœ$<’ý¡{PDš`|@Ró½ýVÚʰŸNРeaÁnmMoÍšn*M´õÉübÙèÚ$‰˜{°a«w¢Ò¶«/»ÉÿxûšÖOn¿X qq8g¢ø/ìØúg6x> ‚*úÇ]¢3Á|Óȸm£E¹öç›sçoÒÝto£YSδ–ì¿m܃"Ò”óa¤•GD]Ûx“$Ò>ÅWŽqŽ(Ùòbñ¸î¢ÔËD¯C÷ ˆ4ñ|˜Æ«\D3hŒûò'Þ}É¢U#¡‘ˆ¡[l>Œ¢îdÅ–º¶„¦ ÍyPÜç¯ÿ«ˆsó%ó×Å qnþßÊo*AB[AëÄz½¨¨¨ù­i„×ëÑÑÑßœ&FÈ9Îiö szÕÜŸîpË´ßDM˜E9Ô!ÓgýÊzpõ°ëÔ{c"F+K‘4Æï°À?¯©ôz[ñ ˆˆ4¾ŽÑ¾ý)èS”¤Ò¯oWøñö3U½óˆ Ü»ºO·œtóaLG2ZwÍÔ’¯„âø-À™—§XëcaS¡Ø}©Ëä²tZÕž[Hƒ—ìªgå—£»:úÞ/õz©},¨ôu‰Ø]8ÉvÜg¯«¬ú£"Ñ="+ðioö‰(©CŸ>¬,ýF˜Xdèúmôâ^ÐÙšTãeß—=è&]O ‰øx°„ŠõÊ¢˜%KjöاÿÉÍ-‘ë¤Y%a¥”Lboí7__vs%ò¥üŠeÙ©Ê1¾ÏÁá+Öu´8`®Äw©"~l¾Ù>½ñžžë¦ Ѫ5"ózEð‚ˆèk8“ˆÛ¿ Pá\óÒZàøÎKiËcºÝ X¾úlž2úÓÚ¼æ?|}'Ë+íKÕï{ ëðóù^z;GÖY|@P-)BVqU†²‚ñ ¥r¿7¿š(7˜øx°„Òë2ííããíÙo?íçpoeü-³:ê¤%{øZŒ–ü¯„„ ‰_Šß%¿®0rîoZ]~%a"ÿ*â7Ö¹/š6ô´µ»ïö¥Ý ñÐX½Nc0ôŸ>çØ­7›2èt:Àèt:ƒ‰ã8ƒ¥×1g2˜&Ý䟥ä+g(ߨ¡/GÄq|¥ÉÐáá±VªE˧Žme:þáHRûᮜù’pœYõg¾¹½?¼DÁ˹ »€ù v«¢V…¦Ðëm˃"Ò”ãë%Ÿ+ý§ÂuIÍ8™žöýû÷Ô”¯_Òr‹Ðo§××i¬µ¾¾W7Q Ÿ;¸ž–â˜ÔAS{ð½*¥µÔïÒT«sK—oþ߆÷›Ô×Ìã§×I$ãên7²P½—ôçRš‘DB^½Ž‰³üWŒt8ñìúÂ삼2*†—æÿúÉ”„Ò§“’ó*TìÔ8ó%Uü:om…3©¿~7+ üº±–Û0µÁ*'RH¤±ðÆ×[¹E¤)çÜyþ³G Ϻq„pÿõW½=&Yêëë«ÒvrÒ:濚o •ÏìG;ÈÏ8=Ÿý)5ŸŠ’³}n½üóDÃæÃd¿›ä8Ý7F[ªžÇs²âHU,'þ7m¸BÍpF/ ݽnëÑÛÆs·_Ú8‹õ¤Ó~˜[ô‰ß#\¦—•…œ\>V”ư‡†èZN…@Çð²¬OoÞdAu¬çÓ™LÈ=&Œ£òêõïáÎ#¯g—à:ë(È·«g.ôqµ5Ã0ޤŨ¹ÊD[€":räøÄ"ºyUøÖÒëhçýg–MܵóùäUÚ± |*!+éÐét®É9"·i‘&Ðë‘ël}?ÝãÄ>[]!®ˆZµ£\É+çì)FEJhdŽ×…x£Z? Ì=£öÿ>RªÀSIc!_Ž"HG³yktØáµáf%ʪ÷Z€¢‚ D"tvÌg&¬ÜžXþnÁŽçÿ»¸‡H$"(‘hµûL”ɸ9‡ž]: ;çœ~Gôè[Õ; U(ww^ÑûøaÝ«îeÉâ—òº/éÍÚžs~Ž(z½­xPDš@¯;L;çz¸‹°™q—z¤kÕOV0¼óìßÂ=fìØËñ–$Û{ë–MÂÛÖh¸f}àUÇ0úÇÄ”¦ †a?•SRÊ|žO #ÕI8TAE ¿á¾;ñ‘!!IDAT‚8〓LYa 10Çm·'dÝ÷ðR7CYÑ0Ÿ]î½=—êОD²š–¶–"çrÛ½ ®,8¿¤· “ú#8º{d®yi"6öŸô ð4 Ö•ûØ7¤êîÿ›ßèý P©.sçÎnìÙ ç vÀY ~aóŠ…¿~—)é[©Jã8~ÿ¨ßãìB™âݽº ^%u,üƒLIÚÉ»ìçD|‘Rèn¢HÂq\®ó´{—§±òŠI)Ž]g°cãݬHôºq¿^— á߃¿^— áßC¢a$ˆ ’X— .HôºqA¢×%ˆ  #A\ĺqA¢×%ˆ ½.A\h âB ¯ÕˆŒŒlYZ?¼ J$V/|Wá´¼^gmx»гõ¬ølf8{àÉ“'|Äê4öÂðæÙ¡5ÃêÖ‹/^ðí´–×ë 硵emN„Ù†µm<'8Ž3™L¶ËÅ Ç©»ÓZ~½)ßó[T½ÍÇøÁîÀæ´¶•À?‚Ê´¢Xç t±u× ^êtñì4 ÃA¤ŽŸµ–×ë\‹ Z{‰§ÏXp†,_UVVòÞXF<ûSÀ€€Nkz÷Ž.η("A’´´4“ÉdßÎY/XþO½ÎŽõ::­mŒ¯¿Ø¶l××â¿z‰ÊŸq‘ ¢×S‘÷<‡ç¦‚Ó鵿¶e™Oâ *E¿\ÓƒÓý]©øùèe.Ÿ¶óVXöãé³*Ïá¿KÛˆuýëÓÈÆ¬O¿¹÷꛺°ÁÑûf†ãêuÛûSJS=¼é·ÖæýÏ f÷BGûŒØïâû2båÞ 5»^ÇNyXޝtò\»y¸£àÍý‹;×:D?ZzóÔ*3òs²rJ˜L&àXÙþù¶·ö>uq¡ଃ/v»åXx•#2™Ìz+$)Þ1<ÀmÿÛ îýn-Ú¼^¿vökFFFFFú·O%ßžØÎëÞ½{×îݺ÷Ô•e' €Šü° ŽIoòÉX2qÍÉ.ú¾.ë×Ù•ª]Ý:œ}<ãê–(Êœ¹ã:±ˆŽ•¥&}HÏÈÌÌÌ`QÈÔ¿ºUšPõ-¡á¸¢4™D"D§ À¨H\y%;ð©ëxvìê×>, ‹wëËÊ$Ú©ÇÀ‘=‘¬M±ç±¹>Rì¾6ÍØ#ÓO"öfÖë™·<¤»…ÞwíÅJ˨dî´î¿NôñîÛvN¹ÑP  (ŠN?áa9»ç©ˆ½z²Äê¶'¯¹–} ®Š¢BVØñÊtSÏŒ%w»Ö—¥L„Ñë-?æXÙ“iíµŒÌ;tYèdmvëš™O¿H+[Bñ*¶IŠýOê×äÔŠéØ^¬OûL]uWWï³zM* «X»ã²ú.W(Ï Û⛞‘‘‘ž^^ùlÞŠg»téÒ¹sç^†Ò_ãïk;°h8È¡UWö ­1*½VWzFËÏDWoEÔ䉨Íɽϕõ=«ã² “ÍÿSº¼íÚÆHÎíà±K›‚>w>qy;Ðà×K†ª]?Y’𒌦*–x—¿H‡¿Ö²Z´êXwñòb¿6Q$]+¨\ ![}c=lç¦%'%wDË-[P”ú5³ëÜEöóǘ·ÔIU_ åÞ“‡sT›uÏó:<ؤ# ²tú4µê"W|héÃ÷–±Ê”e]5 Ô‹Mê0bauá?~–÷œÅ›ž¨Öéã Û­<’-ë8ó÷õ‚J}G>RÊdˆÚ™[çjbýžŸ‹ÏÒÓ1¡½jg[O<™ÜÞȵ¡Ž¤ºöøh¶XozÌ5dN݈é W˜˜˜””øõÛïØ§Ñå»Ç»<Ôï©ß¥=%KÏr×Ê¡];*G­Ÿè¯í­ ߈µø…ó꘱{nƒN PŒf;ü|EaëuúŸOó­·/:qG…£ÚŸ’ª‚Ñé€1èՅ߯9šãça‘[¡4]žuQ‘ÆÀp%ùºú)—}¦Ó‡soN½Î¨ÈÂp\Ù@‘%»k™×W»–VJgÈ ‡ò¼Ó›£ûj ¿‚o¤ì²Ñã,ù9¯Bqš<«!+Å~Êå§“˜L£Ì—¶­×•™ÏßÊÈHOOKÿþ=%#¯M;gÖ_Wç?‡1Vºº=¤É$iõÏ®€Ôp‡%Ÿ;÷èÜþ÷·³kîTÇq‰i=§“;Ádí3m®û3‰ˆXg½;²ƒ>#à½Úq¨,{M–Ä*À¡×™þ®ËÒ{­#‘HT†Œ¶<«JÐB¤ôk9i3Ø(hË2©¼¦6§^'Èt" HÑût÷ýµøM¨(OªJæJ¤ô8q@ñýa‹E. î8öRb—Ì 2e4åXb]È @N“¤f°Î‘6®×ÂÃwßtut-†˜éêöP¡íŸ° ã]Ëø–m7tÀÏcï Î\±>h Ÿ+Msw]ùlvÏϱîÝ;¯½‚qëòû#5L¶q|tt^ny³%ÔÎÂN@•&©H? öÜYé8°Sçý½Dìƒ䦪Rb£^Áì\ż,Uwf¿%+ Ó•!°%þŽÏ–Ï™×'*Ô :S_2ZOmh…ÔÔ|ú­õޝ£äއ÷ù¬X4g²ù¨ž]5”5&V^ôó,ÓnFù¯p0ÚvÈV‡ëS&­0.l·ù¤E=í/„oW0úˆ­ú%AªvÇ0iÙ[¢³zÔÆ+C7;,9E >ãÉz~Õ“#—&—² ,\mTøÙ÷H|g=‰W ;“=®\’X"¥\K ´³=†%îüPÀy0;fSèϲq›¦ò–7všÑéç§¥Ì*‡ô#•~­i»þNþ-¥Äý}ø{´ ½Î%Ö9_³‹!C,7¾¨ÌPŽÌ§T³/šþº¸¼¯, Ø:1å^XÈÍ;÷¾¦)uŸ»3Ôu|o ã‰*+~Eì=ÖA[E£—Ñ)ÓÖ,ÑDZr?gµÆBeéo à¹û”w²&gnmêJÄY{Úkg‡¼ /©rž†å^÷‡ûæZd,^m9d€=ëÉ“¸À“7Ì;ªˆ3ét&<¹ŸÛu‘—¦çì =+**¸„û §¡z4Çí^e}hŽm…ÇÚÉÃûÊ1 ÞĆùÜè3u˺Aªì$ÝlDr?yð•¹Ë¬}/o·€^¶Ú¹¡o°EúÂWÏäu] Û$“„é´–×ëœFyá,9Q•r»€n¤Ä?Eí´2× ék5Gž˜\$ßgóѵfC{ APî¶Öw¥Âã„7I%HKËÈÈʨ©’‰DbynÌcºY¸Ÿ#±ú¡ß°®iò3×ÚrŽHj[Î)ßµ­wbea€y{Âðßwî‚û‘eL’–ŽÁŠáN¦Uƒ¡LjfÈOšïØNDb-%‰×žÄ_z‰œsY³üØA_W;ùƒÎÞ{¹ïÕ€ç„ûþ d:ëô˜í:ÛTŸ]Bº½¦¶–‚T˜Êýwä°ÛÜ-gž/6j¯iîT¾Ç'Ÿa¯VÕöú+Äh?Îþ¤í©Á®³I¨£ÓZxÿõÈÈÈqãÆ t.·¥^8j}Êw Þ˜1c8óÖÞˆûz­«cT"%|2n6á®ãâ¬N¯%d…i—]ÆN¾upbc-­}Þ¼yà ^“\IE9¯ÛºØ:uü­>Ö^½Q¿àMÈ”½[ƒ'¯É6 Ñ ×ÖûYª¶mLjÚª…;oYð,èg« ×}]˜³„!Õ‹}6ž±Þ˜3æ„:OÛy+dRÓ×*ôºjÖTþ¦í-¯×YCÅÀ³Ò´ ÜÖìä†ßþ.&µÈgú¨ºKÆžóë{´Ÿ4Âwž³ù|D¥R¹î œ¿ÿD…¡G¶~ŒËøík;¶ÞÂQ!ËÇøô“AyÇà Îñ¸Òôú?°OcÄ"‡ê-é*à8Wóù:EQÎc?˜6­öm(í‡¹ÚØ¼|)La—&½4W¨´Þùë|½¥jÕpþu"æëZX°àAßö–×ë‚\%¶þæ Ï9€í]±í1¨-€•iy½N£Ñø*N±õWóù:ˆÁ`ê´æ5¶µÀÕðVª×?~ܲ´rø:èùóçÍoI¢5ޝKÐl´ŠgS š–×ë$4-¯×%Hh$F‚¸ ‰u â‚D¯KþÌÊ}40¼ÜIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/grid.png0000644000175000017500000012113213070106167016031 00000000000000‰PNG  IHDR»c+f2 sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìw\IÇŸMOèED,(bCÅŠŠ;Øð°gïg;OåÎrvìbïÞéyöÞEÅ‚(*Ä‚ÒiÒ²Ù$»ûþ±B!ÒáïùdgŸ™y²åÉÌogg°ÏŸ?@ ô€# +Ú¨°*Ú¨2 ˆ‰@ úÂÁq¼¢}@ ˆªÒ1B_P¯@ ô¥ˆˆ™vþìóTÄÔáI ªÌ\B ÊZ™}÷IXE{¨z¡cÆ=:¸/»ŽgSõÄSã¼3ÿ{ð»aû†@”Ñg¦LÝbqåÄ,f“Å6ªmg^±.!ª…蘴rÙòUž˜BZ'µ€q ÿª'à—  ˆ* IÄ.ð iÞÜeÉ’%@)RCBc¼ýàn¯hוNÁÉËÅÅ3žâN..µ€“yi–o |NÃåËÄ‹¸\Q3¿õSËÏY¢489ká½ïšo/fóì,7E‡ÿP¸DèC!X5ß<>–"ÍŽÌËŸ|ä›tuo~+Øêà–nÁ·$êk4iÎm1U‹ÇÛG/ ývC@@H“nλÉݵ g6¹M»ºÚT´ˆÊK¡:æ'ÿ«u×iö<âkΈI}•Þ“ƒ}Æp9Ç6mÚÄ8™Î.mŒcüÑpND•&/mš¾ðD¥^»Ì¤½¾q¹iwOÿ+—@.~òèóìç·½+ÔKD¥¦Ðñ˜< ž]9Ÿš&¿uVJb˜©ÏŒ' yp¡€ÀBj&¢ª@)Rž†[œ½½vH·•;vì`—¸ø;¬Þ4¾¦2"&užÈC—4B¹½r¦KÂ0f̘„„hí1¨iè³0IO¯>ŠS7C€È~pà@ö«lBzâ0&Hgìmmm9Rîž#š¨.]­«¶œÚ*ÏÒ§(tU#ÔQ]Zõ$æ‹êš‹ {…ÅHrdïB_“¹F´‚  J¹œÀä*{U^¢¢(0Ài_Õ@Ê¢[·nÍ|§âì¾w²0 ÈL0ꥲGW5‚AýÒʧcFFFª¾·˜¿L!–'+(JŽ Dö+7À‰k|c·‰½ÏžÜ“9|Ì8ã˜m·0ÙÕ3"ˆ¶°®qqÊq‚-¨sëÖí¼’ÄÝKv›¨J@W5BæÂȧcª¾·N„†@æ7‚ ¾|ú”ðIZOtLD%Gû‚ÔHa+ø, í¼Ù!þËïèÂß'°±2ôQa.¤‚ß’dóíÛµk×®]»fö¢ZM™ï … EB ª´¼°= iØ¿;· P¸DBÁA#ròôt€‰{Îf»yz6qìóìØÅNN˔Һ{ë­@»}¹:‹@”¶ KþeÚòõÎÖf|‡…a@S$©TâRIäÓSÆãØí$¢Ò’OÇÔÖ€E)&]¦àØ6^xq³‹Ä?õö7‰¨Th_Z)fþÿø]’ðEFÈ)Цc±X\_ 5ê9ë—~ÑUÐF—Ž©¢ùäóWhž€ËaƒÅOýÕö l+Gý)RÇÇ^Ã{•—Cˆês!!Mb \¼A ˆÊšQ@ ô¥¨Zè¡c"ÅA/¨Zè£c"Å@/³¢8yêLE»€( D¥)Œ0 K«N\¹r¥¢](”*}Ö*iÄlÕÒÙÕÕµ¢½@”2ÁÁÁÌ CE±~”ºq```y8]e)Éq.]ªÓYC:&¢¼Áqœ¹y@í^R}×WÃRÕòÿöª.Éq.]Š÷|—©)ž‰óÆK¥76úüóTs—©Ë†?úý7oÌØíÇ‹]>¢ÜÐÖ1ýüü8P˜ýĉûí7Õf©è˜$7cip“¦-æÎ ´2íù«¸ƒÏ^v5ákZʦ÷ÿã—+8žß\Þ±þß›ïߓۆmFLœ7ÝËäXÆœþ3.l¯Á©ª½öq–Ë˵û¥P(TŸÿ':¦pã¥íÚMúíòðÍžßûj¡.5M´ËJ¼{Ãió©æ!ÑI9ãg{(Ž Z5Ë9õìÙ3MÄÍèÜ­‡q4À}¦ü´W;Wþì½rCgcžž¾²y¶n]pkñTã±[æ÷û¶éF”jÆ6˜½éÏÌk«.Ä(&¢fU@[ÇôññIMM½p¡€ÕÊ<þ|LíÌ–ŠŽylÎXÅÐ}7|s§É<;Ëìø__kSmËG+&&Ù×Ç&w׿¿õÿëBÌ„å¾ËÝÚŠÄŸïÞ¾°Úç§ð¬ëOwÚÞÕsÛ„-áKÛé{,Êm“ÇÓ÷Ž+óÿEÇÌ5²ê}n}÷?‡ÉL³í~Ú¹¼‡ma–ÏžˆŠOI•_9–Epå©| ×ÞÌiÉôßm´êÒ˜Žõ¹ù71uŸm|–E¶œúÙçZ«ºRôym0l»Ë²†w¿QçWzê0kí1¨iè³0IO¯>ŠS7C€È~pà@ö«lBzâ0&HWYÖxöëÀp±VïÅu_nþó^<ÐÊ4¿¹«ÖíYtiìüŠ®é:m^7öÂÑä4š—U6›íçç7eÊ”&¥]»v~~~lv©.ºC+Ï­8ÿ¿O)~xó“öêê…æ=\¿rñãûóÂgv%=^«¨1¾­—ÙÜ·Ðߢù_ßÃe.nœ †Ü«gÒm¤YΚgßþq³bu§•œ¢Çc¾Þ;æÙ°OÍèé“v?:<¥ÀRä4D½|F~Kˆ×OŸS4­Ä (™D"‘Q ÏÉÉQJ¨âéñþËÒy©Bò~ÁÄEóMÛnðéwféøw9Šb‹¨( Éf³·mÛ6f̘OŸ>5lØpÛ¶ml6›QÁÔ)‰ŽI)¾Ýi|ìÊò‘}׬]»–I\qÿZý…+F[  óó¯÷§ËUY^l ¯é6=×aRr$9§É˜º/ã¾í-Ûòoc ©Ÿïœ9ÒdîÒÖÜ è‡"³tÑk0žj×ÇdÜbŒ ³©”F+)Ú²“­îËØÆÕRºû³Pè¼/|õÖ÷°”:HÇ,]ŠÖ1Iù×)C–Yõݼ¤SMïÓóOXìu©Û³Av†êfDÆ­CO^@f.#"ÃÃ3Â3keê=|½±sYhÞ¡ÇX‚Ëû÷µX²xÉŠ²®Qlt¿ælaa¡ã¹¹zx-‰¤,ºuëÖÌwq*ÎîÛy' ŠÌ£¼UÓ¢dJ‘]®>ÎâÙ°1,+< Z[é(Yd'"eQ: U]óø ï§ §û;rÿ%[Î:þó¹– ýÖùé~ µñl¾}»v Hß ‘6m×ÎŒÁ…›ôhÉ´Mo§:éaV¢‘k9ñï^Äçmblˆyó24³Ìƒ5¢$h‡ËCgayKå­¶ îƒ×µÓsvøì¨¡Ú´á±SSr/'Çlˆ¥ðÞ‰;0Fs¸‚ÕÀLâÁæú€QÕ)TÇL{µwÿÎä{¬(¹*ù£ŸZÿûŽà½Ó\òÊÀ긻×€O_vÎnçîÞÄqO²c;9-SJsèn­·b°Û1åKÅiiib©”ê«Z4ŸCV‡·ý«72™L]ÁÔø®;¯†eñÆcÊq€f± 5id7g÷ñŸkw/˜5NÄÆr¾IÁ{ç6*§ýÑñì‚Õ›o÷úµs^L|bÞˆ½ wŽ1Ã0S^gðLT©阥K:¦ë܇çjäÖö¼ó Ð'æ|.‹ÅåçŠ>"ÃZM7<¹1„Ù¥Ä?ºÜÇìªßo×Ã~¥÷;¾CSøÔ©%z§Q>ðx<í¦¥ž-GÖhñÆc²| •…©irñËc{wù.ü• ÐvbýÕû_ ÿjËìryhñãþ¾z'.XîåÖÖŒˆ¼{ÓÎËíg·7Ê9!ä^’ã¼VLá¥Õ*HÇ,]ŠÐ1kÕª¥#óׯ_µǽDçž#»?žÜÈÛÅ6zpÛ¯xŽ"ª:ÂåFÌâÁÔcÉ¿L[¾ÞÙÚŒÏã°0 hŠ$•J\*‰|zÊØa3¦©vÿi9K'+&|Ÿ|‹5}Çõv]7¬=txâ–Å9$¯¶c«EûoLê—ûr:IÄîO$vöʽw(¹8== *¦ß£¡CÅMO©~–+ÄR¤ÐˆY`LÔ Æ”Å?)šì²šQX¬,¿ˆÉ³ <ºóê«Èô”!'IŠŒÍfsy|¡È ™Ç¼‰ž^Œ¥ÀÌcuë%ó®Æõª£ÊÞÚÛ笷P„ xV¾qÀÑgæ‰Ü6v3Ém7غo{à^l7KŠö-ç€E«I(壋*ÚQ& ½¸,¨¤:&Q<ŽÉгgÏŠv¡PªèA:&¢‚tLDÁ\H•bÑ;¨ ˆ‰@ ú‚tLDµ阈2阈jÒ1eÒ1âǨÔ3#ò]@J®¬Ké×&©6¥ß¢ý_H€"e—ïF”]½¢ŠR¹tLÿ#yÚu7ãÀµ7¬‡6>¼ñ®ór7Rüé+Õ¨®)cFé§oÇìßBŸ2•²oë¿[<­+³I)pÖ÷Å£‰ì¸C³ÝÛäNÏõ-:üؽ&]š°I"ãàÙÐ^®µ¿g‘Ü{ž¬O]Îmë×à`EÛ!Ê ¤c"Ê}uÌÅ‹Y–¯¯¯FŠ45ò÷-¡NúüÖÁ8/1-r®_¨“g¯¹Mµ Qʾ óç.äcÐc`­Ùg¨žuX|!•²bôÂvÆR&—œ¿>ah‡¢%€œ$_¿Ob~‘‘ðàœi§%½j&çbG(’2"› hdršTÐ`29 †Æ"–—”¯PJqýA”G7Í ›ò„ŒóˆŠ阈2âÞ+ïܹ3›ÍÆ0Œùd}Ã0 î^½úæÍgggõ,"K‡É-Þ®ü÷zÏÚ Y@ÓÊ=g Ìr- \@”ÿcco]w‘ÙäLGháPGâ’üP5®î½,ÔWxúQJ—/ž|‘ãÉJ¹ôÆýÙ1Ñbd¤Lœ-y±t+‡¦IJ)]ºÕÆ.ØFd9ýgKõr(…øúƒèé?w,%¿DÕ@¯ˆÉGÕ§z¸Ô‘ËÅÛ£ë«ë¶¼üoQk àÝ¥²ùk–µ/°ÛJ*²ÖûgLœÙ§!Ÿ4%_¼ùvCënú¸'ù&3¬!ˆ¸x÷|¶¶2€˜»oÓZ9µ6Óüuƒ~ëá³á£ßò”RŸ”©$¤4­ˆOÊ´ríºc¬(ùÕuŸÛÎ;Ø‘²´!¿ßÙ±ÌK•1+*2TiÛ¹væša@ƒ€Z±ý³wÈäžv±‘oµ»Ö­€%ÅçS‡?vêicpúà¶¿Œ¯'(Yheö½ç±îš—JiˆÒE/“ ޽{÷€»wïÒ4Ý¥Kxðàî9ï&Ìîøbùß{v¿6øö×”¾“×¢ÀJnì¿ÁiÛ¹·CnóSšöŠcTßš’1ƸŒT_z…)T5’˜±Ë^Ø8o#=†;µ€sמ‹Ôn"à€\& n¾JêÚÈÀÈ×§Žãœ_¶ ²#î¼Îþe` ¦4–‰}Žã‰ twPÿE__½>ƒó[™f¿‰f­žÑ„¦¡ïÒ‡y4€3;o%ˆs¨§¯Î›´«i¦ÿ¡G”å©c†îÚxÁº»»)kçºÕs=¼­Íò̘›×^÷9ˆÿý‘ª,ýÊ_ö²ÙùQ­ØÉJU¸,LôÉŒz})5dV/ÕóÀX“tû°)d‡ÿ·%VöAG®n|.?ÙkPscͲ¾“ñùÃò]OÒkÔÛ<«…†ªšöþÉôÝ_úxu]н¶žO£ã2XÒlõ!¥‡N>fc’!»þlˆ¥ÄSò®§¼z²"™WXi9 9ÐM¿Š•ƒÂb¥n)“Å22dˆvzÈ­›j[lsss’øâì9Àݽ›¶ñ;w^ÆÄYró]°¤,ºuëÖÌwq*ÎîÛy' ŠÌ£^*³(™Rd'RÏh`3ãÆ±´2òÉÅ)cz_ùíÒÑ-™½";)‹Òý£ú —ŽyíÚµ" ÒÈË·qܲÈQ3k¹q¡G9uu\ß¿–½¥C ÄŒ8ö]Ú¯êS—«áù'èÚ7õ]ÑÜNÈÒÚe0Ö«Ñóæ¿¾u]º¨v5t°`X‡Ì&‘©P阆öu½ºü¶| ȸtÌJ€þ:&Aê}pï:ò8AS²/^°‹¢ ǹy/’ c/Z´HÛøÎ;2Ç•ySŽlA[·.hKw/Ùm¢ò§—•Ÿ…ã¹S"h蘶-=×Ù;|×Z|Âa&%ë+ÎâZ¡ë³$è«cúúú¾yó¦Èâ4òöŸü·ã«&jf¯ãXðXÍ|U4˜çUèÞ†…uå…Bï~šMZ˜¾dètµÍ;Æ øù[Ü´C—® à±ÀiР½Àâ$&04sôî­ÓQ>è¯cr¹\í¦e‘:&°>`l+«.*|¡P(Ìë‹P\3~½üüü˜Í{7o8vï]‹Ï¦iðôô4‰„jïÀ±|–…E·‚…Å_Gvˆÿò;ºð÷Il¬… ÿI$¡®cÆU÷6)"›Åi J!>‰æÎHg/ ? cjJ+í˜XÉÑ —€±߯|›]h‡\?De£°X©O¯ |ÆÍ¿LÇrñ/nsÿº´XàY IDATòÆÉf"Žký:7ïôd?wëú—ÇŒ¹$Р‘…–V¥Böïέ+L€ãë}ÝæÝ˜$@K2R_žÛr/aÄÖ3ª½o'4œ×´¨…(4> ñŠv¸Ô?/Æ1=z´jSý&33ÈÖ.¡ÕYÆ>¿±ÿ>ÿD›µ{4ä³(EßÌí΅վ˗µÞ¹}ÒÜùLèÇŒ=f ê±ä_¦-_ïlmÆçqX4E’J%.•D>=eì0ޱ¬ÝZÎÒÅÉŠ 5¹,Ô´¯) ˜??Ã0žÈ¨Vƒæ[Îy»ÖaÜ ‰Øý‰ÄÎ^µJvÀ•m~L¢„è¯cÞ»w¯¥ê³@ÒËS¶„æäHk4íÝSâx®ŽyçÈaaÇÃ;³¼š5ŒÂ€]³y;>…ã8Ƕõ²ýWÇ9e Ï+ÊÌÿ¿ë¯£S¾È9EÑ4`,‹Ëã D¢F=gýÒo`n½‚îK[Áoç?ý3ÐùüãïS¨ó‘'ç ;ú¶ç‘è/ hD5DOsÀ€ÅPç¿'ö~ÿ¦»Pí•°†CvÜ/àÉ9LØ~JõýúûÏ ‚àòó YkÒsÌŠüY{ sìú0êÀæºû¤{oWO×pºØÈ‡óü2¶y«««ˆbð:&Qý(†:ÿ¶HÄ.ÚJ pYBîç¶¿¼#ùúõ«³ô°žûO¹£pY: ˆ‰@TU¬»ÍW”yóɳËÁ•ÿމ¨V u~eÒ1մ΢Œ@ë•#Ä"&@è Ò1Õ ¤c"ʈJ­cžÛ­\¶|d†'¦‡ÖI-`Ü¿ê 8ÀeGP¦«xSmœq2ïôc,ÁÛ°–¬BT„B¡v3GÏgåÿÞC:¦J¢—.tQês• sô&ŸÝ.£Þ<æŠO;&%óÃIGŸL8’.c¹¸¸@bfÀSÜÉÅ¥6p2/Íò €Ïi¸|ù‚x—+jæ·~j =–Ä<Õm¯®#($oÂ?Eî8w¹¾ ×% +ÎÄ…DµD;8Vl³œ+- ˜ó®g7xv›ÿËåÑ/ÚФø÷‘jÚºÜÝ6¿!«æ›ÇÇR¤Ù‘ÙbùÓ€€|“®î-Ão[ÜÒ-0ø–dàO} ’&͹]ˆ‰§ÞïÑÞÛpâ¡;kú« ñ#Çd¼G/&«4›6mÚ»woa{§L™òûï¿—§?Õkkë ©7..®Bê-#t阶üæžèøÇÐåÝo­|¹eø}E«;kûjkŸü¯Ö]{¤Ùóˆ¯9#&õUzOöÃåÛ´i#àd:»´1Žðg2¦¿Þ»îXÔà%«;þȤÐJYäèNãÆ\{¾ÌmÂAû&åΞM¤=˜º£pYµÐÖ1gÍš•˜˜xéÒ%mãAƒÍœ9S¡È[…é˜z¢}œcccõ׋K…úõë3çN÷Y«è5söÑÿ®´ð¿ÇæÍþKüCë𠇇Á³+çãâSÓä·ÎJI 3ò9€ñ„B!®@ ðXLáÊ” óçƒ]–¬ï¡·–A“Ù>=»Û®˜ÑÆ–ºðp¬K{ßzO÷°€ôЮ¨Çc;Nœ8£lÝqà¿?r‹wDåC:æºuëÄbñÝ»wÕ-ÝÝÝ׬YÃfçûO,E3=üuZÆ yïBCm[šrJgèM± Yuí Xм<Ñ8ÎÀãñÞ¾}Û¬Y³røär¹À|ê>kU½Æcr šÛ?¶íèÍ-gŸïdZ˜YkAMCŸ…IzzõQœº Döƒ²_eÒ‡1AºÊ²ÎÀ³_þ˜£Ÿïù·ÿG`ñl>:ÓÛå癟±ÔàTñ×-÷röÌÛrf¡$jß_\[¼‹Š8®þ´ Q%`³Ù~~~S¦L aRÚµkççç§.K—”ç?Ôtnn‚= zؽµ«%žù)"±aóƪ+H‰8qö†pEÑ4ÝaèȆÍ›(óýõkA¢ £: %‹oj\pŒPH¢“i;;#]ÿñòÌØDn­:¥3tºÜÂe³fÍ>~üX*>W*Š> 5;Mø»ËÏÍtØÄ†½Âb$9²w¡¯s×ZA„‚¥\N`….Z¯Ž.ÞÀòºð|ÓwÃï°Ù´ZqññL“MÍÀnó¹À+5¦½úv¬uÿ½#ŠP(ܵkרQ£"""wíÚ%”æDG q—ŽÝL‘2ß•RÂVh`À& 6ìiXÄ»”l°±¯k \P0}Hš’eˆfM¨Ý—=¿oÏÌR@d1«3PdæÍÀ8+ëÚ·nßV(IšÊùš5dæ,{ŽfÌ¥Hñµ“wZÎg+¿Ü=s-20ŒÍ-¬l›µnkgÊW~ëÔíñãûiPÊ-\ªÚ˜ÕŒ¢Çc’J™ Ç ¯-æ/SˆåÉ Š’c‘ýÊÅ pâߨmâDï³'÷d3Î8fÛÁ-Å/0žFg‰-Ìmw¬êµP‹l¾]7AÄão€"f%FÇxL@°ÿþ%K–¬^½Z ¨Ë—*J¨cZö2ÙÚΊÏšzºyõ;‹”Ë(–°f÷þ.65Í8yâb •kk‚¤@)SPÊ´ÇAr¤2’ÓÅb“2N潦ñþÖY…c¿™£»Ð„Œxunû³úc;ØÛ&FGK©|A7þáÙì}ZÔ2ËŠÿ’“ÓΓG;Ó”2G’þ.äιÿ>ô7ҖÖ]ûà3/2jÆ'DÔ>Îr¹¼<Û˜oß¾€ÿ/H Ða•DÆ­¡áù ˆ/Ÿ>å|’ÖS¦c–.DzøÃLûžõr]•EßΔuu­Qê!J>Ÿ¯=M½º|ûM:M+¾~zMÈi€„÷ï­›~‰—r%ê6gJc‚ @ÿˆ2pinÆKOR@2-29%WP4ߌo$¢e›_·¹€¸õëa¤TÒ€'?{ð*½q·žöüy‘ŽYBôˆ˜,žƒƒƒ9·àLj‘“§§|LÜs6ÛÍÓ³ˆcŸgÇ.vrZ¦”æÐÝ[oØí{J.NOO'¨ÒßÐ{ÕõF¿m];瑟(£š.½½^cˆûTnt„ËšQ¸X•c=ûõ21%|MŽùü‘Óspg^vbJ†Yó.#\M \ ÀÂÚ†Ñ2i&¥Ì8yúFn6æÉM@ðãÇ”RÉTÿàÁš¦û aÊ¿$ ™6èènÿáÇI¥2¸¾iMÍ!ÃÚó(%MãßNn;)43á'¥H %䛡CoŒÊ‘ÿ!”"#öK|zZŽ4'ýóë§JËFC›YPâfoC;‘ÿDãaé)ÏŠy÷.¾®‡ŸÆôVB:f Ñç½rÿÂ÷æB((JA062ǶñêÀ‹ƒ˜]$þ©ß°¿™]f®ëüýuÔõÃxúlõôJžƒñ P¤¬Èd2ºBçÇ”d|<øo€ƒƒ½vá±Q‘¦Ì°%Àóð`cc™‘‘¥f‚ñx\¹<÷a¦©™ ‰¾}ýÚų»¹A6M+iZ™˜˜9$EtvJR–’"2d4©ZÎø“­v0RædḠä$­”¾¾|ù“œefd±Ìêõî×ׄ̉Ï0±™]ƒ/{Ï™á™8¯vÿYómík Sc3pe¡ÿ1HÇ,]ŠÐ1kÕªUXί_¿j'6Ÿ|þ ÍpY l°ø©¿Ú>¡óÀm¥àrá°xE!*<O»i©¯\ݲxã1IŒ±:uT(4eÁ¤è(KÛZÆYߘ¶›P¸4uïÞêׯ§íLddäŒy @Á8’Lœ&³|}7$ r™òó®iЦ¦eÀoÉèû &)¥€¦äB!<6Æ3é:gŽ«BIM§Ç…ûgûÛŽ?jeÉ´Ó”|šLcñ „B€ÌHHÈ._Xx3阥K:faQ§ F‚ ª#…ÅÊbDÌ ŒgÚwùRiòLQæííM„†ñÖ­[-jÔÈIITï³Ø¦ üF~zÎb³i’¤ˆ¬À ÷ÌTf†lVºDI›ç«Œ"%ß¾åmzºXžxúÔÂmpšDJ)Éb™`XI< ³„ …@á²|=À DŽf Ã0nƒׯ_g"fôçOus0ptt,pŒ$ÇIJú¦•ÜÊÃwÁÿIëÍy,ÌŠÏNHıºüÂLO–fÅ34Ißdl‘5КÏë¤c–´Î¢¼!¢0SÏ6¦Ê²x:&)#0‡-#´«Ã€Çñ¼v#Ö¶‘Í£'1ý¦Œ±á±·­^Ùmôx'âÖí×›tî–““£nKJJ*•j;OÊ??}äÞ±Mfz–iã̰(puÀqä$M)Ò£££“% O‰‹x#iîÕhãäg±YwJ)Åq<'þÑíç©Îýú×çëjñ ³tAëü *‡CŽî¼tþ¹‡K cò]];deK˜"=Q ">Wñ €Æ0à …@Ñ™ð94ôE¤Ä°÷@o[~NZšœš¹Âò—=_n~tߥ}×– ˜¡$¯&‹Ì>v%À£ØlVn”¦(ŠV*äé_Ãùf­ÍLÍq\^£Y[Eð}©¨…g€ÈØÔ0óý¹ ï( Ø\¾‰¥õ ±^šZI3R„B!Ef¾É!‡´² ¥™B¡PÉ¥¹ÂÔÆÎŒÈ–þ¬\cÜ+p¹ÜÆ—¿Ž©Þ¥(ðŒT *û:?ÁÁ…êDTiîÝ»WÑ.Ð@çää0ß³¾_zœ(W( j6¬Åg«Ú‡qao„]~ïÔ\Ä"·­Z‘NÓ˜Q͆B•<›NǵýöéM†¥© ;G,¶Ñ˜!I¹X,É‘*(š c±Ølo߬{—–í(28‚†ÝlφËØIƒu×!“Œ-̾OóJÓ©Td¤¥à„2ÃosëônaÀÍH&À¨nŸ‰NfF\±¦²šÿjýÑ4]žmÌ>€–Sg²\©¤³Q£Fí¢L¨ g–-°ÿõ× ê)& ûŒw6µ0âaF+ ù÷†[ó>C L-0™8YJŒ˜>Ó̲ŸÃZ‘BÓ@) Ž™};k@Þ3wS{G ¾PÈã°0,ßü4MÓ4Iái©¹}Ò&ž=_9ÍôÞ²a³oçÌwã1îùk{Zž¥}IÊ2R4ŸZiR`Äär¹>|`±XïÞ½+ëOÆŠT«Ë¤c"ªzÏIÄÄH(õ.-ŽKÒ °Ãñø¼ïq_0 Ó¼íq\¬•G¢—³Öý{Ø~TfNŸV§¾ƒ»º½ÙÍjp“¿$ã?2^]cÜë‹°šKZZš±±15жJ€tLD5¤j­ó#lÐÁŠÏp t˜uªoœ–œ |Áýq¯VVVú{-]4Ú˜•ùŒè ²ë˜Äÿ$!Î)›’ÕãÔŽ{-;Oʳ޲ ÔÖ+G •ÃeE;UµA:&¢ZÖùQQ’q¯¥‹F½UôŒ Q ©Z:f™R’q¯¥ ]Ô(Ú*Ò1ˆêL%÷ZÍ@¨† 0 ¢]¨ž Q­@:&¢Œ@:&¢‚tLDÁ\H•wtQF什”–,-H"ýÚÃ$Õ¦ô[´ÿ P¤ìò݈²«@T]*‘Žyíà}þŽ=͹pió›ŸÿÝt¿ÝÚTvDÙ¸>³(9²Ôc7bÆxµÑ§L%ž¼êÀ›³{1›”BÊ⊘ï YÒáKYžnÖ̦øëûãw¹}ZÒŠœ¿Ï¾èîø=‹øö]ïc¨håêhU*KJ#ˆÊJÑ:æêÕ«‹,eÉ’%)×ød­™ßQ¨ÖŠ}~:àh÷¯ù],´"‹’HÛÿ,zíж8®€¶½­þøW¼°§U¶—¥=_´?¾¾cId'¾þzhߦúüYßÁ0 ð«W¯~úôÉÙÙY=ËÀ m/Í÷÷½ÝlóàšLŠøëÛA)f°3iWqë±÷lÍ]ˆ#0=²u“:ç°Õ—;Çä\®jÀ&y*ãë[/Jõ5<ýHܣNj'_äx:©†ÄfÇD?Š‘‘2q¶$lÍ^M“´_³÷>Œ]0°i­Ycò-yD)Ä·‚¾ÌÓEå Ò1eÄŒÇd‚£êS=\–…gXkí˜z¿þëÿ°ëH73.M)¶myQ³m×ÉÍ XÂŒTd­÷Ϙ8³OC> hJ¾xóí†ÖÝôñMòMfXCqñîù:mÿle1wߦµrjm¦ùÓýÖÃgÃG¿å(¥8>)SIHiZŸ”iåÚuÇXQò«ë>·w,°#eiC~¿³c™—*cVTd¨Ò¶síÌ5€%µbû-fïÉ=íb#ßjw­‹:B ª9z=ùaBdïÞ½{öìÉÄÊ.]º¸¹¹Î×­ì:vÕ»ssIûK×CI«u žÒêú¾›<׃šÙ4iX³IÚõÌ“¹ÆŽõøE÷p qä¨e—²IÚ¤Ž2ôô{&ñâõ¡ õ%Ié»ï3€#´ò[ÖX£ÉÃ;ŒT˯9yx‡AŽ"0°rðlo WøSo'õZRÃÃν̡9ob¸£½Z䂱ø£½Zöj͉NHUPÉÏß\üPÀ*¢š¡×xLõ¶d·nÝTß™%FuäõœÔõÞ⛋.p#ý3Fÿ1X$—i½¿÷èÐgÑ–•ª"b-[´Wmâ2€Rm29†a¹›ÛÖ<|Ç›ôßZÑéW‚Óš´B˜\ÃWâ8³ü©€>¿÷â1›Ú#û·èä×ÂUé˜$ Ûþ~ ¤ fūܽ+¶' MÎfÌRìJ.“cÇÆRDSrÌÆRBÈe8AR”B†ô²ÊÒ1eÄè˜L300P=\>|øÅbQ¥+¯P¸zZ“qÛÃ=<½ê›jïÏIz³ò†ø¯Õëçv¢)Rv8X:a­P˜;ƒ¿ROǤsd,ž©jsLo³a„A+Û¿®caˆ{¥ä[74É•JÙ$€µ}“÷™ã¶o¿СÕÌŸ[Ú 0šRĥȲo«7]5óö|¿bá@!†½;xã©Wñ<<ýåšsS ŸËb)BLžóÅgC*MS2Ÿ 7 5‡j%òÙ,W€ô²ÊÒ1eÄé˜,Výwõ·ë ÃÜ©)@xK7ó÷X;o]Ù¤®Iž±YMÜÚ°U)|Ã:Cûæ Ì$ÄY\¾…j³n¿›0Ômda§"l\»júÏ5>Ö£kû~‡ž®:^cÛOâ± CÌlDl®É¤Ýë™sƒìk°!“Ç6°±hhË— %ù†uýu )¹÷œ‹~‹À®…Guÿ|Qø'?ê Lpss Tµ1‹M]µG4ÒÔXßk’YëíÕ x†õ~öÈÛŒº–ndß>oË å àÐÉÇl R2äqןí±”xŠz¯<åÕ“É…Füœ„è¦_Å¢*£WļvíZ±+`±E{Wyë¶iÕ§Ù¶¡öu„ºÂ¨†A½n›<¸Z±×¼QëMÚÙ”÷˜4¬½vzÀ‘»÷¿ÉÚöT¥4ml+À0hœûz,++(*ÏÞ¸žãˆžf…ùsóÞM®#ˆêBÑ:æ’%K>}úTdAy‡Î>^˜å™í?k¤`Æ5­ ×.sáYNíJ®,hg P’Û»S]íßõË│¹}hãp>Ï‚¶lÕ*wÔ§u÷ž›ÅcÚL¶ãÑXH/« QFü€Ž©ñθ>\=0±Øž•?%-w7%阈2¢²Ï‰@ • 1B_Ð:?ˆjÒ1eZçQ A:&¢Œ@:&@ü(b"„¾äé˜GŽ©XWˆ’£¡Z¢«QZ0—öõëW°µµ­hˆR !!oáOtU#JæÒʘ(¤c"„¾pÐh5Э†@ z‚zå¡/(b"„¾ @ ô阡/¨WŽ@ ú‚"&@èKéè˜ ûy88=ÉΰhSš¼ð¡o¯¦%¯@ Ê™BuLYúµ]‡>h$Z¶1Ö½–F¢<ûÁÙÏ‘ÿâßbcÓ˜ëL Yn7h£÷ æn{-9¹ÍÛkÏ·ðdÇc¯qoŸrðÖÖú&Åÿ5Q–ºú.MJÓÓÓÕS$qþ»þy96ü¨†eØŽUúwÁ˜ÕÏ<¼Þˆ«žNP´a! R¨Tè«cY+ßfìþGcíorÏÄa©G'–R•~40©ë)u3"ãíºùsÿ»]£åÁŽ&˜Fr¸rÇI%M“„ E •}ÇcžŸµ¢VßmýmLÕï¯ÿiGhͥ㭼»xÎÛú÷,O'YúË™‚°VÂïÍÆ3gÿ¹ÓØ}ò¶Iw}CùÕѤ˜¢i#‘Çæ`›/@ãCD¥%·W J3fŒú´¬xwÙÂÛÒóoû«'¦½Z?foô¶{÷×5rm²Þû×Þ¯gíµ¦Ž÷vcJrÕ5ìZÈJsQ¡-S(gt­WN)Ó®™Ö¶÷Ó¡+nlþ…1²rvûÀŒË+½'m»«nœ²p¸ûE¢¯ÿá¹……Kmh2ÇwØèµrˆe^ }ükÏmïë_~|Ú …KQù(80)¥Ÿ]IZqòñÏ®ùÞð©Ýûÿ-ÙûÄFª”›~sæn¿ÑuêÒ FöžOH“¯Ý•÷½±3O¦låæðÙøçC+~²ÐðLQÁ>þ AAAcÆŒ)†h˜pwß»áEZ¦»ÛqêˆzÅq@ *õð¨KÇÔÏßô³¬ã>é·-@ *ºtL@hƒ"&@èK¾ñ˜èn(¢Çc"‚!wØxE»QaœïHÇDT[z£R£™©;¯†%º)ª¶¶¶º ˜ÉÛ´Ïûÿ»Ž‰¨Æè—z¶1Õ¿ ª³Yþ((b"ª'ÚÁQψY`^Dµ¡„2KÑ:æ·§7³z8˜ä-gFdÞ9rC4yd•54H¼})¶y¯Ö"=í£ÎÿÖÅ«}¼Ö{vä¹3am'¶ŠV¾·’\ÈtöldÊS¥ÈÒ¯î9o8wR·Òð‘æJÖP0™ö¦>ÙÕ#f‘7˜þ7IÄ=3vTgý¢ÔQïn‹ÅâéÓ§ïÙ³ÇÈÈHì˜:&­Ìš=m^—!¿[«ãO�t¶º1­Lˆúøîý»W!nß°žpbfÓÌ´ŒŒŒŒÌŒô䨈ˆ>|I«}õÉQ{¾æj…(2³•¦&š>H“î¼¢\;Úæ2…’⪭ß+‰½*jߥFIÇ”ü=sê— ï˜ˆ™öüÊõ÷™\‘ÓˆŸÚ2ß)eÚ)Óxè'GIŽôôzýøéæŒw×2›8Øþò°æÇ=.œœ;e=­Ì9lB+‹ÛÖP•sfÓшusKè4¢ „B¡v\•RdvýuL}o ˆ¸Í»ü§MêEÊã6³À‡î?>ʪÿl½oÝ”ÖýRFÐJãðKËL$INœ81((hâĉ'Nœ`³ó…¦âè˜iaq©!¿'wY7Û1aã‰Ï Fv¸ØµÙ"…©%‡ð{—. '½³¼%Má‹,çÛÕº~éÖék7Û7«s~ÑüZhfföù¿}ôÂëæ4­_¯¶¨éà><»sëÚÑ#Çc`ôÇçåûUò¯Óü9îÖ# ”™‡VÏß}ö~rY¯IËΞS×ÎîlaΜ³ýîµâ”à¥OšØŸ$ñ䯙p˜ËÞ>~œ¢a"0á«"fì…ÉY-WÍø²¦Ý˜ÔàÃSíæþê?w!ȳƒgʯÿ›;KSê«Ø” ©‰Ý·û4Ž_yøãÒqO·¬5GnnÅeLmÑÙñ"oÿçÛßyDE ÿ ¢‘‘Í­¹nݺË´4/ ésƒüíÝûœpæõÿªv.™}ÅxâfŸª”s£ú6˜wzµ¼î—2 ááÓæ­}cP»YŸA³®] …›Qmœq2ïc Þ†½(¬º%K–@PPÐ’%KÖ®]«“…GLZ1gTŠÚÇC‡œŸÙ9ÐaÓ|üúšº¹§Qg¼&‡`l£ÃçÏÐÊì:—ï»6«“üðŸCsSZ)ÃI:ëÍÓË1/™,S}þ´Èž²¢–tö¾Ó©K—Öv¢˜xM/‚—Žúêµ·»-ýÉ÷‚ñŽã7:ÙóÞ>X:gŠWæ–vZyìrßøóšçKµ— Ò—ÌÅB×´“‹çdºêjíõ—ïžÑ¼ÂŒI"î×9A~¯Ž¶˜˜ÜÉ©ÏÊN'NLßð" ꤅ºÿu®¹€–OÐæ¢Î•¨‘'Ç5»í¸g) ¿òh«ƒ SÚ§£=F¾.¶ãˆ âGn •Ë–¯"‰8¹$fÙ²e\ç%>? éÑ=UAª¹þÚ'­(¦ç bÓ“»rÃj5@ÀL/K‹N\JäÆoö9Ÿë/)YÞâP¡•mÉï—R';ú?i.s¼¸æ‘ó!`‚ׄ`zo½æë:Ì’7áŸ"wœ»\_ÛZİz´ªîöÒ¥K—.]ª®]:æ–Ó«z÷_ûäÑæ5ïÛmwÁq\NÓ—Ç ù¾ô£<+†ÝG†ã8IÄ=¦))MËýýýeIÆÍšY26é|6×±q3ÕDë2ÎÎ×ÒäY/x²˜ÁË¥Ágã”ê>(ñ÷SOÆí{ÖIÜu1ºÑ¯çÝj@›îCN_1M´hÉìj:ka¤ë”·³9 ïõëäĔݷߛ—2.4bæÆí`Æ ÏO¹ årðÊ FUØ?ºW¨ÑÙK'œ'Oiß³QûùÆg®(sÄÄänS9Êœí£ÜÞs©ï¿À-Ûÿòx½Ï;·È“ݘ¢Îz÷þ~‰ŒHΠây(mÓÏÏïÀ…ÙOœ8ñ·ßò&#ÔSÇÔÿŠ8täòÊEž,vºCÑÊ­wæÍòˆŽŒü7øy­ïÆ“:·É”äàZ=M=o«þ£•«æm‹Lmg’øI¼6Vij¿¤«!€ìØ-ßHÖÜÆ8Ž—ü~)uŽŽ^v¿]_ù3@ ï«—ê÷ýlIJ[#žžf„ø‹c2Þ£—çp±âè˜B§á—w†vštt÷ýÃ;6=Y¶Ì‡aþ9·ªNî_hô¹¡ÓÞ „B¡ ÿtîÜ%%ASø¹sç mthí›THËñkçO 8ðóŽ¿- µ;¹•òÙ, ËçO|Ÿ²ÆøÎ5r««/äܼó€3³%cÜóT‰‚Baï‘f3ýÞŠÿq³€´W;Wþì½rCgãBÛ‰ù¡>6ý{HÝĽyI¡ý~õ^#an3|D×NR’€¬è5Ë^7àeyaþŒOýÇzZ;¬®c49;;ñk’à{ûàî Çdî»%ÆÃïzÔtÈž#/Ï­\xkýú>ðÓ)ÿÍõsÛ˜Ÿ÷ù%L?7ú¡­cúøø¤¦¦^¸pAÛxðàÁóçÏǰ¼?r=uLýo XÛdäPwßݲŸ‡{®Ú¶)öÍ‹ç ß•ÙJŠ/ …ÚÚœ^7ˆÐnD“E·ŽýcYKøxÌß²õâY ³]L;» ¼?r×°Öôæ†P ÷K)C“’ÕoRÿž¨J©Ùa“÷Øâkq·F8èiF¤=˜º—Ö?@1Çc¾¼Òeá?í¸æûNŽ~9ï5<Û¹a•qîIÍúôæžû÷{†ûõ x ÚºwŸˆ…=ü%›sf·“Ù5O×/¾[§ÛîÝ.Ž uÔ¥MØŽpëîyÿüóÿ^psðªV=ŸÌ˜>寮FùÛª;Ö˜±í¸Ù€äKà™3Á-®Ñó PâQ–;îZ·&õYBjêáÕ«o[ºŒÇ¦Í ÿÇÞYDñ|üíõ (¨ˆba`·¢b Š¢¢ØÝŠ(v+ˆ-æWüÚb *ŠbÖ×¢”é¼ÞÝßçDZ„?çó×íì›Ù¹¹}ïfÞÄ+šeÇÒÐ2[ð‚ÖV‹uóÞÙ«KÜ77Õ‘¥wjûÃaÄOJm©PþKÿ›—»²ô¼þ±{¹&ÂvopÕ*jÆœ/±`Y™vAT önÝš››ûða‰(U}ûöݲe‹¢¹¬D)NS§F½|U|Ù}üäú*æE•QJA0q¾~Öµ€37â­6ïÝh“×yX° Nû'Z,¶— WG_jQ~H¶„ha­'OÁèê=´Øÿ=I‹©Z,ëu2“gsçßýçÏŸ ‰•Zw¾ÕcUcu&”$00Pueúõë§ân¹SákÕyAçÐ#G?èÓ²»æŠýÏyÓãK`âøqóžégÓ«~º|ŠØîÃ'ðœ>Î;N¯€÷—LWcd¤\ç¿fÑ“ÓNªkZ†ðî]ù¥^›éÁÁíï?xx™óž-Íf.[¿ÜéǽŽz…‡>Ø€Ùð+IÕX©­­ ùR‚¥­¥­­­ÉcÀ“;þñÅÖ‚b2NîÙ âr ìz¶fÑzœ}Ïß¼+ÑÇ~úSËÙCã÷x×¶uo­y;ßû½ _(ûaC—Ÿó4°ŸYšV%ÛQiètº‡‡ÇŒ3^¼x!K騱£‡‡G©IRŠT^AJèÕ¸qikúßÍ[ŽvÔëPJAš/Ä¿rä}áÖfä»Ë’mõë7V¸zÞ»Âu͉·¾™‚c#LåÂÕÑ—‡§€9·ÄaÁeEæQËËÈOò *<¼Ôó²kÁ×£k§viýékä¹R]+gggP‰êà=åû1Õ…<íÌÖÔÙÖݪÁÖÕæÑ1yÄSï»y`Ø~, à~„N£ôÕbzͼH{¶ñ[Ïå´îK †,h½'[oÜçÝL×϶}üî#sÕNöi' ‚r§çD8A’%Ü4Q)Û€¦˜BÓk>wýÁ™Ë¯ݵqÕè×ÉWNÎ+êÙÑ 9RATÕ–§ÒÙfóæÍ€GÜ74o^/ˆ›àüéaÀ'™Aö7A‡ASïé#œ¡Ø£éÓwV†?ÂÍ4þèÓ½«ü—)ˆù.ûg䌉îÏÑÒsml`~t—åç/9xð¡;9P·« àN¤I‹ï³ÏDغ[‹ÂÕå­Ç¤Óé^^^ÎÎÎQQQ^^^t:]"‘”ÊNÉY)!D„@ "I©@("Iü¿ëŽu=P—“éë—ÔeB#/<äí7b¸my_ªBaÎ2aÙó,qăgäR$$¯7MÆÎ§q›h{ÙÚý{sH¹puô¥Æap›À7A‰1h‚װР.ÖvÃõÐyZ­[ÈþBêí¹úȯŽå¬·éÿZ*ÊW¸çG6ú®ŠóíB›ÝƒÎ5Ã0À?ÍY8B”›ôíÒ.CŒÆ¥Ÿ±ÓzLйe<:FJóVÍ÷]þpÑü0f·ŸY“tóø²|êH-;±@4Ãé‹–/bNWãªð •uÓÔcÓÃs1%Y¸Sܼ›á6ŽG–p—‡ÊÒ°\ ƒ]¿š»€¿ÏN{5fuϰ­vfN­;jS‹ KvðpbkÏæ>uXEæ~w'k‡ÑMiË[º|Áâ¡àpUló;¶=^\æ»9=6Ùùµä¿tœ”ðjt^ZB´Ï†Kzc0:ó¹ºóÄÿ®¯Aæ²Q±SGGçôéÓ«V­Ú¾}»ŽŽŽÒìý˜ÔËecC ÉÂ0:‹†5Ÿ¾pecí¸›/CC'®\iMHÒyûUOA¸«[ëo>!ùb1Ý]–¾¸¿ñœc_¾±"LíŽ*æ­}©)XêV:LZøëL(vî“DálywêbÆ­l#]¯·'24JZLŠ”çÇTµ ëþëLãZÀÖ±5+ô guutèý ’³Rc cÚÔ†ÆÓW§cµ9®çîáº\ÀèêõØí~Í—ßÂ…ßîçt)asquu5)ÆÕÕ•bMË·˜¤ärº`@Ѫ l¾U‹WYüónNZ“ÖgÑÀÌþPÏxO‡õ—¤$è4q?¹gbî­3&999999úο½dšìóº» «%£õ”†IþE.'\œtpïž}§_òô5)öá³3]ÿk8|µü}|z?Ùbz ÙçÔà5vvv·³…•zÜíÅÎÚm·v4îqÛoÅ™×™jV[[2ÞˆËÝÁ¸Øì‡CªÉl;Ó´géšêZøðÑ-nn?oñâyÃ3£2Gì½¶»¹)>›ÆjXÔŒËÛZ=ËàŸ^<\{æ?fl:4rR´¹æ(k.+¥ÝA•Q ±C_”åóöÆßÛú»ziCÛvÞ¡¡¡ÁoVök**ˆ ýv«i…/>Ó»ØëõN4.Ñ•| “4œcRb„[}}©Y{ïÔNÝg»úô§„ÔÐ[>Ã'ži7ãTWM¬9x¨ãÑ Å{.Ù¾Û±›² "–´èÛn[Úb Šqss“_×¥K777*êY®Æ6mÔª/— !I‰P8ÀçÊõ5v^Y#\ SÒâpÀB©Û…kF [ÔiGC3„Y!ü„èK\eK oÏ—2o…K]5ÈHÊ×Ó-g§¦cbV_K±úý¦ºoˆËgȤèzÞô÷Z»Ù{Ë¢¥ñ 5½¾K·¹ö‘É㢄£)"ÏK~~vfff>Ÿ/àPµCŸ.®r¾”súÓ40è¸x™9|Ü`aȧu¬œ|||ÀÊ~l+vöËð%§7&ði}»Ó½àÍåSRÚ¬Ò¥ƒÖn–Ãýi“#7ŸÚ7 .ŒoÕÄÚ^£ï==7¯ëæLç7»fç¦â€Æòz6·g§9ûy÷6¢X[„j„B¡¢³ÔgÕyIjçcVVAôt59"¹#RLÿñÔeçF$fÅ_ôô|D¡ŠÇAÅ "ÃpN} ß¶³ÄèK,u¼t–H„?VW__jõú£B‚r§.>Øcß\–±e¿){ÿÙ=Jv« 33“ͯPlÀ¦Ûç5íݶpå¸(B£N»îÁï¶–íã+·O:%ÛW®®®^J¬öÍç}«_ÀãÕ¤/Y˜ùЦץW¾ò­e‘ ¿éà²>$ KeV“•zpNçVqõkv_Ǥ‚sÄüBW ÙÄŸÌböïß¿réØÐ´biˆ‹yZ}}ùC©¾Å¬ø|L&—ê™(P³æ8z}¯î{s7¶À­O¹^êð»ë‡x_¬ÔÏ_–*›K¨Ð\‹§Våò•¥<[YY‹IåY•Q:¯ø5£sye_¸*¨\Ad]*d…«¾¾ü¹üôó19Zæ88FG«™þ»VñK‹Års FÃ0êSvùû¿W2¡^Onã ³¾ÈÎ+RlÏŠóƒø‹`0eý˜Uëc"¥¨e¨Þ)ÅùAüE¨0—T,&õ³‡ÿ*ÂÂÂ~uj€ˆˆˆêdÿ«-fíxe úÕU¨mP™0ùøü˜? SSªs‹ˆ?‹šýeÿ*¥@¨ù1‚*ï+G „"Èb"Uþ^?&@Pù1‚*ȉ@ •YL ÊßëǼqóÖ¯®â§ Æ+á¹êPÜT‡¨õüí~̶m¬jÁéUˆRÈN{“Ѧt‹d…±(…=zôW)… .\¼ü««ðe¬ãèR)h_9¢6£ÔVVá$„ŒÚÑà~>fy·ÅDÔB”ʪ]„¨e«Pž÷ïõc"j1|>”Eø¡nå’H)jÆ+—ÎÇDüE¨ˆWNÅb*ÚV¤µ ŠU‰W.#-Ì?:W¢˜"ʾwølçÿé┽{÷ª–ùþäZDŽX1E˜uËóø£ŸX-ÄïuÁEñ'Î<þÕ ¡®R©túôéR©”[Ù+°˜¤4wÆ”ù7¿–ˆ"óÀåv)¹ä˜·.ïv_hۥŤcï_†>¹ëãüÙíÛ¹lÞ´¡ýº[µ/ÂU=Œ+ÙÍO}šÌWL‘HKLwÄ=~’^á–¥Â8ÕAßIiθ1S¯D•h™ØË»Ï~®É¥-ˆßª RAôvO?Àʼnvåðo¿lÆ"(+ˆj~†¾Ô ¤TDMNœ£ü[S,Çq—   WišPåÇÌú˜˜ùjUJ·ÓM¿m;óiÑè~¶í׋µõ˜4€Å=z€¤ …;äìm·Ö$ž¿r©;ÛØ8àV Ïµëš›ÞXçú ¸:ÚÚ1ç¼Éåf­lØÀ„Kˆ•öˆ“Ÿž[»ëسˆ$)CÝ¢ë¶õÝL‹âˆáâäÙCWNð 0ÏñÙ¾ÚûÚÓ´<¢¥U×.æô1–½pèÜû ʉ„N…Èc+6=I‘_Ò,˜8q¢¢Œ±Íº“@ÆÛ¸´™)}ö­h–¸ñt„ûäî—Ú˜,ë2i3[·I^"Ï!àÕ®ö€øÈÞäR~LÙ¨œJvÅÁ»ŠAu‘É‹ÅñÊIÍ 6(-SK–}"9b?ü:oÖµãC乞nXz[sò¶Å­ä)7¦Øù¨-ðY'©¾¾ü ’ŸúÌZºíÉÇXµú-mGÌ?¾c¢Òú%~ »ãï{ÂûôW˜–½­ %ÈX³f,æOHHÈš5k¶m+QTåý˜¤dåÔ!’úç^½3¯{°ùnW.—…avîlm )ùzÙ~úG—Ëàú\¿JJóÌn÷¶núýéÉXmC}\L¹Ÿß$}”e™¹b•^Éß)?öÌéë{Îv¿xp¸ZÚ‹3‡7L15äý5c‚7¸¤Œ’]›þZk0K=‡¢‚|±eoÛ¹câÐ0B´þ² 3uïjߢúâ;ž}n}ª­®©qõõ¥ÆÉûæÓnð¬v‹ýç?¸ðKàTû©6 ´£tè㜨%­ÜémÓ¯³)ïk|UJ›Bwwwww÷²é2*çc¾¹£Wÿ¯_ì[ÿ¥óǺɒý&Û¿d™_•ª9•§ª½4ØßØÿ¬›ó©COïÚ´n]_zâò&³¢¿ÐoWGÏú )üpþü © ’$çÏŸW7ž3•{jÛû HÎ ®]ðá0`üþjôÒsÈ?!Ö ÆÀ³@Ö H Ý&1˜Ò¡ø_׌˸{÷žd¦%“U¯Ÿ|)*K«÷8­/ÓOö0€Ì·6Žvظ³;å Ì–³öl§×±¶¶.º&Å@Š\Ü>±sVÔÕ4w :Übäá3o®nt½·c‡-Œº°§QQ3úœí„pŠOFü?Xºté÷ï߯]»Vö–ÝâÅ‹«P&uŒ®é`×s½WÁhûÊ_†<ýV<äÊ–*ߌDQA¸ú£zj-÷?³d]ˆ9qKßÚm^ògŸ ±ã4€hï{ê&³-¹ ¨ }©YH¼`óû «.ò”:w×cþëæŸpo¬y QŒ­ÔfU¢„êQÁzÌçwŸušYœ_ IDAT[v¸Î;|aâ³¹ÏÄ$ùÂkÛºb›GXpûzyõý¼oDàîvϽ\25”˜svoí€Q}Ü·O«Ëûwx¯¯¹…®’1‘É÷-ðêôq5b ‚ÿ¼>Öé1[^«y‡ÝuÜÞ¦oÈÌ.ã†uW/i|vÒ_äùFÐ^2¢\¾ü¢ùbwk&ÕÿÝvýû<~\4•‰ £ŒÌúÊ/@]]½Ž‚üKÿ›—»²ô¼þ±{¹&ÂvopÕ*ò÷ç|‰KŠOFÔ6lJ¥Š‰ý˜@]A!ù1…"’Ä£³óç°SêÇL0$$»IQAfÛ»\?#XÑN]káÙ¨MLƒ‡|ÓÝàø­óùƒåÂÕÔ—šE”’-!ZXëÉS0ºz-öOÒš½£^B`` ê¢ª¯\ákÕyAçÐ㜟ôiÙ]sí±¯ç<ñ¥0qü¸ùGÏ ´µinXœ‹ð¼ $ðÜA3÷œ^ɦcw¬^ ÆÈø^ X¿ü=‹žœ!pâpTt‰3ßßš5mI”Aÿ+<õÕYñ] çl$ÏbÒiNpp§Ãûw¶og³™ËÖ/wú±m˨‹>ÿP4—;š:\KrPÝ,JðÒ}wb~Ñ)RÔ­[7ù]5£¡wç?ý‚©ål‚Ρñû ¼kÛº·Ö¼ïýŽ^Ð/”€ý°¡ËÏùØÏ,M«Ò5@ÔJý˜ ÃÓÓsÆŒ/^¼‰uìØÑÓÓ“Í.=¯MÅY9!h4.—a .‡aô̇·M-›—*óÃýÀ–Žvå}© ¤Í’Á‚kG¢ˆÍÈw¾™Òë™ZÍ௟IljN¼½™%<æ`Áå­å¨¾¾Ô „8 ̹tÅD .#(2¯ÆKpvvV]TLL TÁÉÕùúUo¶¦îÆöMzl´ˆŠÊÅŸ Ì€:'ÐÄY¦/»ÝgɨeÀ÷Ðu±}Üh¾«Vݺ¸ã6€v;½O7×»Þ«eÜÓ MÔ½»6SqÂãc+§o¹1tÉîçg÷¿ ¥¼zt'êvu¡܉4iñ}ö™[·qkKû ¿.—{ðàA''§ÈÈÈ&Mš.éÁè<ÌsäêÎÿ»¾™Ëß S§N­ZµjûöíTR)ÔD‘¬ü¢El–Sæ.m¬w3ìI踥K­ IÚ¾CJܬ@YA0×µµÞæƒÞI>5ž¶F–¸ ¿ñœƒo?³>›Ž8ª˜·:úRã°Ô­t˜´ð×™P<@…w²æÝ þo%PD•óÎuæ³¥$Iãö2-XòŠX?|Hý¡›YÇþ1´…é±¶Õ”Zt±Pýe}l·­ýyB1½5m½x—$àâÐî ÞËê©­Ä;ð=x«Ëñ´sÁWÛj2KݵPg>}Ÿ&`(»|ó´Ö€‰fœ¢Ž·v |@öF¦½Ëfi5®Ú.`¯E©ÓJî,ì0ÿ‹Aëvs«>óÇr(ƒ·_fÔs×¶ÞÐF…3ß²ö;Oë¸z§ï¦íÖ0ÏxX¿e QÎßâÿ€@ Pº©\öYSSóСC ‘HÊæ-µý\ÅE]Aý˜“F¬hÜÞUtœm ¤¥ ¦wyÌ ”>Žº‚@›Eí2fØOdNò2 7˜Þ7ËÞë(3sئúŠÙ«£/5ÆÚۭ'Àa‹,!ñîÊT íì0Ê¡ç+_‚««ë™3gdŸk`=æµ áVçÆäp´nÎ'cwºèL:l¡¥Mö:c=q‡ö…ucŒ¬6žÚËá2ùòB¶Ow~W €´4¾ÈuÞgšNÛ·ché/°aÉ9“Á+³_?THä™téÓF·ƒK£ÍÞï¸k;.N:~hßS¯Ý&µoÓ öUðŽuo ?È+®ó‹ Ô&KÛÊžž¼fÖî3N]¬CuÌ%3…2î˜ïrCïML@ÀÂ^­ÛÛâ±kª­Õ«IŠÏ¦ñ½ ¹!Øò¶VÏ2øŸvמù›ÏØì7°Býöމ d6,‹,ÕyK­ÜT±“º‚00nÈãË\îG cÜyþîôÙÔÿ|ÀÁÆÚq7&…º>ÚnMHÒXØ–}E‘Q¯óZZa·/=Mte)œf+t¥ÍŸƒÅ9sÅ·±šúRã öÞén5Ùvµ…çì9ïîÏt¦ÝŒS]5Y°~äàWÌ·.άr ŠÈM¡››[TTTXXX—.]ÜÜܪ»S*JlÖ¸õ]ÎsqÅÿÊÊAÙŽ6˜æä§á€ÆÜ|#`ÅÐËC{yv«cɲx¾±0.rŒëú1pkʨä¥kgÔ•mQÈÏ”¥V°çšÒßœÝñ¦ÄÓMlöõi£[è¬Bw·ï’©u˜4:ËäÈý»W®;¶uñÒ¸t†º~ÿ±«ö¸ËV».ŠóNèo"»$ÄùYYY"¢2§u‘Ò䯟_>¾sêäñ÷Ð- Üß„MŸz$ØòŒûüé½Ý¸–vƒ:wê8ÖÞÆ·jbm¯'³˜0úÞÓsóºnÎt~³«avn*`, gs{všó¸Ÿwo£JÔQC¨0—•:QX…Xe¤žIQÎGÅ¢þ=~@“ó99;îÊa$Q¨ôAD–Ng›-4Õ¸Ô~¡\£«¯j®»[w•¢¹¬}©iÔë ʺø`}sYÆ–ý¦ìýg÷(Ù­‚ÌÌLvé ‘\Ãæ )–P"£‚)¬®®N±žåZL§á¥~Š)]‡¸ØvÅYÛwôu“Ö“€Î4Úuë>Á¨S*oü“^²Š.Úô„‹Ç½ŠoÞ¹¿¿v‰©Iß%V{(ÂѼÙzÍÒ[ gíÍ€Î2^éyl%€´PÀP+ñðíòR^]½µŠþOŒûz=é[îwVÊű-ç†Ñ»÷ìå°îʵþVò·««óÆWNË/½uïÁéó†GpßyUâ<…žöóÂzãG.µ¶½X¿Ý, ³L=yA0‘¹ü5”g+)ö1©XÌê(ˆ ¦†¦–W«óìeH\ùŽ>ê "cAÈç%ÅÆø¿S2¥úúò3Ðk3õFÐTB, ±Jh÷îÇÏË [­¹F¹„òÐÐÐ8{öl¥*‰EGG@HHˆ³³³lZ½€ÆáRtÊ ‚š=K˜õxÈÀƒ>ÁçYôòdpá7û³ÝÜìT™õ·ñññŠgJ“x>Ð5*5†ó i\54îþ­E­èÙ³§¢(ÛArÉW¯^Uç§2 ‚ 8—Ë*úÄá²J檂úȤgóŠ—ñá~õõå…ú즦?ü‡Šæ±âó1+õÖøa‚\“¾û?ÞýŽ»õ)÷{†ß]?ìØåÞuªµþ£WzÚ”ÅS«Î?E?f5Ï`¯ð•®¤‚”ýTŢв+HRRÅ,YáǪ¯/.Õ<ówÙUª‚º½—N˜¬ò…X ââ¯D©¹üÕ•ú)È„:º­¦ÿÍú";¯HªG€ÅD *Ky.Ëôc"þPªNÅùAÔBÄbqY&P¶˜Š’H)ä„…•kùóP'RçG µã @”%88¸¦ŠúÛ”¢<¨L˜Ônþ?æO½µôË"~¿×±õñ;ƒü˜Q1ȉ@ T¡¯@ 2ÅD ª ?&@T òc"Uþöõ˜.^þÕU@üÔx5y,î°aÃj°4ÄŸÎßk1Û¶±ª§W!J!;íMfæHeTêDáGý?*ý'ð·õ0Æ:ŽVšŽü˜ˆZˆ<Π}å5DíèaP?í+GüEp8ÅNe©n¦ê¼¥$‘RÔ2Œ+ˆ ) ÏûŸ‰@Tæ’bSñ¢6Qa¼rÕ ‹‰¨”5Ž-¦Ò¼ˆZC5Ý,û1ÓŸßͳ´1×bÊSD9ÎÜáM÷Ç;5T@ˆSöº¸hÑ"2ߟ\˱ÒTûG°a֭þꋧõþéõC¨Dö&—ò`Êú›T²+ZÌ Œº‚à¢Ä³Wb'9u§þE5Žâp;??_KRC£tК*ú1Iiî‚YK{ž±¤®¦<1ñ’÷õoî J7—&øôùÓÛÁ÷ïÖz~^‹œÌììììœì¬ï_##¿|ùŸYÿÖ³³¦ìrœI…‡Y6Ÿúà-Ñ¥«1Ož"‘L…¾q_ó:õ4¨É5%Raœ««« ‹IJsÆ™jãéÖÁ@ž{y÷ÙÈí‹k°ˆ*ÁårËŽÇ)Æ’„’¦Vµ“ª‚€H”°ç`À¬iýqqâ¨1ó”8Úûœ“!Oé-ê ¢šŸ¡/5)a vÅr„Hб•Æ%¤XŽã...!!!...çÏŸ§ÓK˜¦ªø13Ã2^,ùÞsû‚&É»ÎG/×ùz¯–«%Úú À’ž=AšŸÌqåÁú6$!X½|=»žÉí÷.ùßíÔÒÌwõ²$WGG'Úç(éz`ûÂÖç)ÿ~’‹;WzùøÅeó¹ÚuzÙMݺ~Ž<þ2.Nš=lÕä{Á@HsNm^vèÊãï¹xÃæmº™¹m-й… ‡/xzÄQõMŸ‘ÇVlz’"¿$¤Y0qâDEc›u;&7€Œ·qi!3Súì[Ñ,qãé÷ÉÝ/µ1Y(Ö5dÒf¶n ’¼DžCÀ«]í«\Äïu)•‘ά³}ûv¥eêë–1dÔä„À«Üy·}†Ëó=Z³ÀOÓeÏŠÖò”«NƒN«-½´Y\}}ù$?õ™µtÛ“±jõ[ÚŽ˜|ÇD¥õK¸lþZÏÇâ$Læ‡n?ìÙ·‘F¥J±fÍYÌŸ5kÖlÛ¶J%Ë·˜¤d¡“M„¤þ¹×#}çud¾{9Ø»½µAÑßé×ËöÓ?`tÓ¾—IižÙÍÇ]Zš}z2R]W€” 8™ûþùÍØ¢õ3W¬Ò+ù;Ý^1påM†×‘‹½»5My÷lóœÙÓõžŸ'»æî”d¤‚ÝGm¹¦¹ÿÜn¦ìðçOÜΰÏñ¹æÞ“k8ø`ß]ã·¾ tïHå;+%ãåÝ—¢û¦5)úöxš†©ƒƒ½\ âȼ“¯3wLn ¤ØeXûO3¿¯ã.Lny¿Éawpô Þk^Ÿ/ê¬Í¸wU® âO 2 ¤tÝúM¸(A\»nÝ:¦šÕš£FÚôÉàŠEîð`YÆŠQT£~Ì;7 ‰a@ˆVŸ¿‘ÂLܳ·¨¾xÁæ­O5çW__jœ¼o>íÏj·øØþƒ ¿NµŸjÚA;JoÈñn?rqßÅÛoŸrPK =î¹rd×aâÔcÓ)– n»»»»»»—MW*?¦ç¥M†n{¼gëç!ûÚ 1IÞtñ¢8t¸87–n+¸(!äù7’à“¤8 @˜ªÙ²¥¾L&‹Mg6iÖR¿¸‹+ J†vÖí6v£ÓÐMµ³–]7moßkÚ.À¤‚Ï3/$}i!«ØÁëßšÎñíkiíûŒ¼ä§¢×Fv«Å|ט.3>Ì6ç”;ê¯u³Îõ ¥ü/ö.ÞÞ‡åwµn©”}ÂX>´é´òE莟zÄ\è-K¾â`VÜ2¢ìƈ*WQ]Êú1=<<Ž;Vž¼‹‹‹¢†¢“º‚!:uææÆÕChô,s3ÞÆ½–Îü-&柰W&ÅÂÓº·Ï)(”NRTᥛ–zÅd,¨§‰ûSYí E/ÿ‰ÏcÀ€¼8Ïtœ¶¸µ¦@ ¨}©YÎN\õÝÞ8ÀÀáÖÀF&¾\“ÖA£DPõ å{X-Wß8 Ù¨=3è¼å[ÞaKŠ%P\.V?&×Òñæ×ݦ=ôøôþÝÏÖ­ë˰a'¯n2+ú ývuô¬Ï.—+D]½zC*ˆ$ ÁÕ«WÕçLM=µí}$ç‹þ¾9 ¿ÿ„žzéAGg»é.3_g°4;Ëj’â!5˜ÒÝ èq¸Œ»ž0æµab²ê ‘{¹Üãtæy|È?ÙÃ2ߨt:ÚaãÎî”cØ[ÎÚ³^ÇÚÚºèš)þq pûÄÎ]XQTÓÜ1èTp‹‘‡Ï¼¹ºÑõÞŽ¶0êbÀžFE}Ìès¶Â)>Qó”õc®X±"##ãÚµke…íìì–-[†a?þÈ)ú1©+4Œ®5ntß-‡„ã‡lò:*+öý¯’‹;•yR‚Íår¹¥-&EáÖÛSkõ½sI+×µ€ˆô­Ýæ'/ø÷zê¤Íàó™‡ê&³[ëªCMèKÍBâ›ßgXp‘§Ôé¼»ó_7ÿ„{cÍ%í®~ìÈÿqIà@V¦ŠTq=æ›û/zºžìÈÔ=za⛥ïàå›4‹~ÔܨxhÀÑâí=ä£ÇÀÀ'¼½GŽòhØÓ aØÂˇ,uü‡t‰ß²w¶±ÚéDxyŠyõ<.#íCÈ­—ùë|·ÈÃ÷¬ÛçÇ?ÿ²ËïÚmjÛïÙÜÙ3&Ø÷Ò(ÙWÞÕ`®×'èañ._kíº•ú Û®?€ÇË.qa”‘Y_ù%¨««×Qéb³ñrW–ž×?v/×Ä@Øî ®ZE-“ó%,)>ñÿð­[·æææ>|øP1½oß¾[¶lQ4—•‚¢‚(ÅiêÔ¨—Ï£Š/»Ÿ\¿üyQ* ²p€‰óõs°® œ¹ou°y§èF›¼ÎÂMpÚ?Ñbñ/S5õ¥få‡dKˆÖzòŒ®ÞC‹ýß“t(eï0†±ZÑGBœì6ÒEÝxÐ. mQþ=Š%ª®Lã• 2|­:/#èš`äè}Zv×\±ÿã9cz|)L?nþÑ3ýlzÕO—OÛ}øžÓÇyGÀé•ð~ã’éjŒŒÔëü×,zrºÀ©üzÜØµùJL|j¾†Ë*·1–:²Äðî]¹Œ^›éÁÁíï?xx™óž-Íf.[¿ÜéǽŽz…‡>Ø€Ùð+Iá²ø é¾;1¿è‚)êÖ­›ü®šÑŒÐ»s€Ÿ~ÁÔr6AçÐøýÞµmÝ[kÞÎ÷~G/èJÀ~ØÐåç| ìg–¦Ué ~&t:ÝÃÃcÆŒ/^¼¥tìØÑÃãÔ$)E*¯ %Hô¿jܸ´5ýïæ- G;¥òT¤ùÂAü+GÞnmF¾»œ!yÐV¿~Ói…«ç½+\לxë›)86ÂT.\}}©Aq˜sKü\FPd^yY2ÞøNpœùÙppÀko :Ƨ\‚³³³êÊÄÄĨ¸[¾SmPÈÓÎlMmÝ­l]m“G<õ¾›†íÇÒîGè4J_}!¦×ìÁ 1€´g¿õ\N»á¾Ä `È‚Öp²õÆ}ÞÍtýlÛÇï>2×XídŸv¡P P>y5ûô¥Ùyq¯7ÍžÑÕïCð¿ó J eÐkEÓk>wýÁ™Ë¯ݵqÕè×ÉWNÎ+š ¤r¤‚¨ê,Oè,Ÿ—ò¿hty÷NÉô Ï`lLtŽ–žkcó£»,?ÉÁƒÝÉ€º]]hw"MZ|Ÿ}&ÂÖmÜÚ*v]Õ£¼õ˜t:ÝËËËÙÙ9**ÊÂÂÂËË‹N§K$’RÙ)ù1+¥ „€D$)E$‰ÿ·sݱΣêrr#}ý’ºLècDâ…‡¼ýF ·Uú4* Â0œeÂ:²çYâ:‰ÏÈ¥>HH^ÿnšŒOã6Ñö²µû÷æráêëK Âà6€o‚cЮaQz™¤ŒÀýóÆ­¹2rõá+ØXåJ¨pÏlô]?æÛ…6»k†a€š³:8c§õ˜ sËxtŒ”æ­šï»üá¢ù7`Ìn?³&éæñeùÔ‘,Zvbh†Ó-_Äœ®ÆUívåZvÛyq•EÛUÏÅ {k±ê±éṘ’,\‹)nÞÍpÇ#K¸ËCeiX®„Á®_µ]ÀRþǦ­JþÉ’R Eææ¥= 7Ã#ZðïæôØdç× @’ÿÒqVP«Ñyi Ñ>.éÁè<ÌsäêÎÿ»¾™Ë_…Šõ˜:::§OŸ^µjÕöíÛutt”f§èǤ® @Ðh\.ÃI†ÑY4¬ùô…+kÇÝ|:qåJkB’vÈÛ¯z Â]ÝZóñèÉ‹éî²ôÅýçûòajwT±ðêèKÃR·ÒaÒÂ_gBñLIÞɘw7(+|gݰ ÿÏ>d©Uµ¨PžSÕ‚¬û¯3[h[ÇÖ¬Ð7œÕÕÑ¡÷ƒHÎþI1ŒyhSO_Ž@vÔæ¸ž»‡ër£«wÖc·ó¸ñè¦ï•+W\êò†£k×®Ý{)WJA óŠoÏtY4o6@Vøþcï2ígY(JVG_jŒµ·[Ý÷kOÈï®L•Ð6 3-%˜¸rì¡´Ûïn)šËJ• ÇÕÕÕ¤WWWŠ5-ßb’’Ëé‚E«‚°ùV-^eñÏ»9iM:XŸE3ûC=ã=Ö_’’ ÓÄýäžAй·Î˜äääääätê;ÿö’i²Ïëî&”~à·N6|Å­ —iy¹_?<\9v«vÓÉ]5YÐzJÃ$ÿ"—.N:¸wÏÀ¾Ó/ù?úšûðÆÙ™®ÿ5¾Zþ>>½Ÿl1½…ìsjð;;»ÛÙBŠ­ YìrC/äö˵æÏZ·vúÁ'Zñ-R|6?Ô°¨e–·µz–Á?½x¸öÌÌØthäxÆæÛÖ+|¤hkò/¢¬¹¬”vUFA€Æy|Q–ÏÿÙo;èwîNhhè¥ mØy‡††?¾©ä!”D†~»Õ´ÂŸé]ìõŠz'š —èJ>…IÎ1)1>­¦¾Ô8ƒ½wj§î³]}úSBjè-ŸáÏ´›qJö5×<Ôñ¨LláäcõG8%?¼}M{¯2U— ˆ 777Ùùu]ºtqss( ¢žåú1qalÓF­úrÉ’”…|®\_cç•52ÀÕ0%-L ”º]¸±fÔ°%Avt14‰@(ÂOˆ±ÄU¶ñöÌq)óV¸Ô•Íoe$åëé–X£«}äþµ=붺N•%ÀYêzmlœþÝ0_(€~¿©…îâòÆ2iºž7ý½ÖnöÞ²hi|CM¯¯ÃÒm®}duÆE GSDžÝue—üüìÌÌÌ|>_À¡l´Hiò×Ï/ß9uòø{èîo¦O=lyÆ}þôÞn\K»A;uko‹ ã[5±¶×ã†Àè{OÏÍëº9ÓùÍ®†Ù¹©8`€±<‚žÍíÙiÎã~Þ½¨VQs…BEf©Ïªó’ÔÎǬ¬‚èéj rD$)•(&ȈŽxê²s#³â/zz>¢PÙã¨+ˆ Ã9õ5|ÛÎV(‡¾ÄRÇKg‰D(ûkk@_jõú£B‚r§.>Øcß\–±e¿){ÿÙ=Jv« 33“]´¤(Û¨ýå‰õ/Kä­?ðä€öz*JPDq¸}êÔ)Ù¾ruuõRbåù1±¤¤$ tvvVê]Ó®‰ù·Sêð’Ÿ\Ñè6 YÛwôu^ƒIÁ7–!I%ue»IižYã^ñ±o>ï[åù!Ki»ŒÞ¹¿¿¶ò-Ÿ‚|>W£ôÞX‡vN×ÎÚ›)&J  µüè³ãƾðqPZ²R"""OH½èh97ŒÞ½g/‡I³œú[)¥H{ö¬Â¨ÔD”ó°eŸÛQovÀ>­ ›?ÖàÇkLâùkÖ‹/ÞWê R!Õ×—Ÿ!ÐXÕò®ª(ú‰ÂŠbŠæ±b‹)5HGÝ IDATð1Žòáeáó<^Mú’…™múx]zå+ßQ©ðë.ëCºTf5Y©7€Äó®Q)û&æÒ¸jÈ&þVÈ,fÿþýË3—•²˜ÏŸ?¯ÐbVFAp¾çqY€ ø8‡Ç*™« ê#WŽ ËuØ•".æiõõå¥ú³âó1™\ªg¢@ÍšKàèõ½ºïÍÝØ·>åz©Ãï®â}±R?Y0ºòu *`ñÔ*Bü ʳ••µ˜TžU¡óŠ Ò¹¼²]€*¨\Ad]*d…«¾¾ü¹üôó19Zæ88FG«™þ»VñK‹Års FÃ0êSvùû¿W2¡^Onã ³¾ÈÎ+RlÏŠóƒø‹`0eý˜Uëc"¥¨e¨Þ)ÅùAüE¨0—T,&õ³‡ÿ*ÂÂÂ~uj€ˆˆˆêdÿ«-fíxe úÕU¨mP™0ùøü˜? SSªs‹ˆ?‹šýeÿ*¥@¨ù1‚*ï+G „"Èb"U~ø1Ïœ9ók«‚@ ¿-%ö•ÿêú ÄïK‰]’žKŒ@ äÇD ª0Ðr3 ­ÁD Š Q9@PYL  òc"U@ ¨¢ä´7??¿ÿ=j+F‰A ÊÏÇ”é¹ÒÓX+ {ÿ—£ØV=úÕÕA 5‰r?¦@ ŸA­xr5:˜ºBHjѮğˆr?&‡ÃQìTVêÐÿ¿%¨Å(•«0—ÈbªFÞ>¨¡ˆÚG¹q~ÊGd1)‚Z ¨­”ëÇ„2LY³² þ§Ïßš·hU¿²•GR%fk«1ÿ¯ õ-&òc"µ å~L.—«8Ïzø%Wf { ê¦Ïe¿~ò*S&ÌÒj׫£^y ÄÂW¯^õêÓ77;ë'} IQZZn:†Š‰9Ÿ'°é¡f{kÑ*m±¥…ñ餱‘zÉn8I@S,L’—”ƬcÂý!†ü˜Dm…Rô]­f½ìÛé¨3€Æá’i‰_…iß ²­_˜ò00’[×€“š.” ‹³â2„ò¼¸4âââÒ¿§ÊÙú¦¦:lÅG¦%%|OÏÌÊަžž¾y#Sfel.J¹u+hÞ¼9Š}ºÂxq ‡ŽìÄ„H CA¦ˆ¨D™À ø…¶=™Çó¥¤Ç¼~ñ!6++GLbjÚu-[µoca4¦ä±_ˆÓØ^$Zv…@Ôv*¶˜RaÌ…+%âzw³¥ž'áZ´j¦YÈ$Iº—ž'Ä59t(ˆÿ/ô“¶•¥V±8ÝÚºÃ÷”d>Ÿ/»Îýò¾°CÃfuh…bHRô9,èMÖܲAÄ×#‡XD}zyñã·~ýº×UcÜô TZ·f¶ÃšréòKSÓú‘ÅW$»yƒwaA¸Ø¨³“GÃ*e1SžÝ)4б‰INìWøôøæ³˜ÜV½m‡·lªNäD~yãÿàf1ºgSM:·Aßúoü>Kí,Rä½D j5ü˜`<ÂÞɬþq7›Ã}àŸ«ÞICÊÏË+8NHr/Ÿ»8m²£'¥ÉÒí:f”YvžDé#¿¦~ Q×ÕãäJ€$þ»s%E·õt—úþ¶IÇî½5·xsÍïöë)Ö)A’´-¬ KüÝðeÖ5VÏIΖ¸D*K”H$$Îÿñ%"""CÈ6y²¥.Äs¿çЍ7 !Íz‘?dQkFv|ŽP\ð44*­ë”UvÍ´³R“s H£ÆF~˜cСCr¦@Ûªmúå+¬Ž?ÚM±%D퀒3ÿÍ-/ßlÙ­º}Gt~’Úhm(ÍO`«sEç.МFM,›FDƨš7ÓÖŽù÷ø…„B%%öì^Ï¢‘£‹˜L"/&0‚o´hÞpMqvtĆz Ïäi5îmüâl(Ö§³¦…Ec µREq0ÀX6‹ÉÄ g@á÷˜ð?GÆsë4lÝÓ¾K§6Ú,21æŸ ™L&õF)H}Cð¬:Öå&EK™Læçç Ã~öÍõ2â¢3…8!Òn1`B/3 ž„•—B24e=y§Ý‹…‹ÑzL¢öBÉ©Ûzswúš,’$1:#ÒïEûI-ÔɸT)W¯ÇˆamV3/ž‰U{5ŽFóAc˜úl:…Ûvì[°ÒU@£óØXÃT™/ÄàÓ‹$óá ôYÂè„ìÂÄ\5ó:„¤0ŒÞÌý"\bÔ‰‘Ì—ùùù¥j…(‚IßvÌÏÜÂÂq¶cSS=\P›“_ˆ“²»ÒÄÄ”Š¿©I=5–ñ6K½-†g ’$Ä_øÒ:=[âÂô"sYÆÏˆÿZ|ÑЈóäÁwƒ¡ì$¾”J“"ˆ?J3ëímÿð¢™n#»¹Âˆxßȧ¼x®ƒÉ«7z„f\l‘§RZ˜•)Í~þ>²GÇ–$ÁmÌØ¯8@6Iâ8.È ¾ð¥c›èå'Å“±ŸrëŽÖ—æçÈ aë°ù‰ì~Z@Ía}£ÛbÀEy¹¹Iߢ…’1$!|òä)­¢Ù¤>§háÂÌ)¯«¶´°H"Ÿ I-sMI~¦ŠŒÜºчDŽ^sеE "”Öcj´àÜ£~}–ìn¶º0=ì~¬É`+]H|t>„a©­Åù–“#/A˜õ>*BcX?nrJ\=÷/?/WÖ%dk¶êÜVHR„´Pc&$Å’Âp!ovCõÂø‰€œ$¯‘MJ$Êý¡$ $ ¸D"‘ù1iùñKT9³/lGÇñM›šWØ"ÉQ‘ÙRœ¥Ç–æçK$’dc&HHê%’ò­!—NHÓ1S"‘ ?&Q[¡äÇ ¿t浈FÇ€$Ä̺ýFö®ÛÜÆ&Ü'P`=Ž™u/а_ÒŒIf*ú Ó>¥sM{èèpÒ3˜Ð¬•&Ȭ“gZÏHô=CÀÔ Ãw±TBcãŸqö¨ËÄ¿4&“Fàï²…¦mõpANy.H  :“É„"?&0Tú+cbb*n]ƒAË+”’<“É`6æÒS^|fŒ5eJJtQ ä}VLLÒhZÃd2‘¨­(•—ÚNŽ‹%V3W ×eçDžò~aÜÀˆ›¢7´Wýs§îˆãšÙNn­KKŠù1ÏC’¸|>íntÆHYJóV­ ¿§“É~‘C°>÷Zhì ýÌÇÏRÛOi…ç§$)þøôvzK‡†šü„tBœúî£dþcÜa4RX™õC*ÐeÒÓRXÝ"sضƒIôÿàô™¦ Ö8óË£[o Ç áÐ0e éܺ@J÷ã×HeÄïC'qüè,Ñhy‰qq©|©HLÃØ$I I‡ÿ>Ô›©3²“âù öëû둺ՂÁš‡ŽßéÖ­•,± ?¯ìrÅF}»'=ð9•!4´¶ïÕ@3éí§¨ø„˜ï3Y §bH³¿ ¤8ÎÏÈÈb2é¥òJHŒ†UcÖáÑàÈù›&, NÇ%b¡P Š„BA'›šŒÊmøÑo®™óá½³™G€Fc›ÎiwïŸ9Ѫsg6^œÿß»ãNã[56ýú5^JBR<_§·1‰ I…ãK*õPñû£Ü) w”KI2áÁ‰(?7/¤0+þéÝGßr8;÷h@ܽuñ`¡zc³M,LÙ4LðýcÀ»œÎ.Ó M¥ƒ2ž½ ¾—Ï_‘£ÑhIÒí;òhÐët4‘£oÜÈ[ð=&.úÅÇN³Nƒ&öè¬IäJã$ÐLz÷mnZO§T%]»bȤáb±XBÀིÒìÌ‚B‘c0Ø,޶6—Ã1­W/71¶RË×ÙõšIž?æs]ÄâË>—2—ȉ@Ô&”û1 Fééò¿²ë„¦eÐh•8¸TC!?&Q› ¶ºèoµ˜U€D«‹ˆÚ‹r‹ô®@üþ`ÑÑÑ¿ºñg Ü‰@ ˆ²ü_ƒ,"Ä ²˜Aåë1QäÇD ª Q9@PYL  òc"Uó÷ÂÏÏïWWáw§ìz¨Ñ*5ZPzT#¥è»ˆÿ'²ßIéŽ~ÙQRŠ-ðèÑ#¥2¨ÑJA½ÑdÍ%ãÿZÝßÅC!ÂÂÂ”Ê ‹ù;¢TíÿÚÓ=(žƒMŠF”„$IÇÑߌŠFC~Ìß>ŸOGX’ÿxTÞþZŒâ×WúÆ¢F+K…VXX(³ŒòÞ%(ô³þϵýM¨°Ñó·ƒÃá”ê"Qì/ÔVäæO¦ÒJßXÔh¥ Òhl6»l“ ˆ‡ÿeA£Ñdm(§ÑШüw¤¬žÿÍÊÊ„Š j´*7Úß9*—ýU$‰aåFRDë1k9ï. ËW!#.ùþèÑ£,éߨ9Dy ?æo‡ì)嫬kéùÍÓšý&4ã1BŽìM³Üž«¼g·`ô¬þ¦ê2Ä{3¦_™rÇ» <\·üj_–ÞkáÖ1M´ òÔ‚…g¾u]ç·EÉ AÚ“p¢CǺ¸t Cßs­»è±©×\)Š]!¥o,•F{¹uéã1k—5Ö®feT L{r神ýÕ,Gyó’ 0™ ½ÕÍ[a£ …²~ ÙÌOu;椄À˜UëŽ Ò‚?’Öíë”þîe ä'= ç¶í¤[Ý·K޼YTäÇü#àr¹eq•öM¿îã‘ÒÍw^s:†Ñ˜ L³üìy9Kð<¿E[G<œè˜T‚Ó˜L&$¿ åÎßæ¨Ï=¾hvŽ‹Édâ¢øÕGcöÞñõb¿ýqçµýŒ ÇÅ)+&lvºv—Éd¾ß:yÙ£dŒ©oTÏÔÔ´½íX‡næ2IކØm¬Ûµ»žúŒjfM¡Ò7–J£qñèçwÒ˜K *ûô87FNvíêT(™|a§WË1vmTÈÜó÷kÙ°1‹¾ghßô×·7Ð,% Ø¼²”ð[w øò%&g5¶vœ²x¦]+¨¨y+l4‡ƒã¸â¢"²8úa•Gåÿ]?pà⃨è8]£‘…Åçe“û[Êï~Ø5cÓ—~OŒ‘]’Œ-Ógät=zp¡„8uõ”mŽoÐéô dò„î“Ö]¸±£šo—¹ÅTÑhhT^;±Ù0&êäšÂâÉ_ÿuWkçÞS“-Æ¿xõµ¬¼qÛŽíš¾ëÙ¦špsõ4Q¿m} ÍžXtsÙÿOÙŠÂ/¶NKêÙC› ¢ÌäôÂvk×®]³zÉÈ]ô©Ûg 6scªŽ~ÿݽb\ö¼ùé_˜FMR~JOˆ{ðÏѽžWâJÞÇ3RøJ3~úøÉu‚Í?¼&<¢kV¬ü—?/§P™ÓC±yàÜ*DZ«|š˜yêz ÿ¹ÃûÖÙç:fÞ‰ð›5/qb‘ýŒm·Ú^rþöãÀk§gÚšŸv?q¯\B”™’”’'ûL…{g½›f¼Éc¾Ì\ÀË]³Síì¦Å¦R Gßf[÷˜9ûÞý?¿$šù©h6š;yhaœ¸(np³ÃüƒUg‰<º¿¡ÓvÀ»Ó 6¾løÐt­¦^Ý™5ÌÑöÓÆãËí­@*ø¼øjÒ¡°O§a=Н&Ï™öjìÉãæ5:êm®úÖ}á×…qè5ÿ=)p÷ò¿Qñññññq1rc‚GN177ohÞȼY#–¢˜ ãêÇ/¯Ÿ¸—-aЊãõ›ìšê¶rT®îõ Ýäéñ××ßãºL³­¯(Lù‘áÿÅÅ'$$ÄËÈÂ-/ü»C+N‹IR^îÄB©æMZ±ñú»…—Bg[é€Q£Ö]›’ î>¢)ÛÙ´_ß¼rn/9ð8vö¿g4×~\[˜ˆ-Þ¸iHµKvíIɉ%c®$YžººÇ‚Wd…¤‚ˆד½5£^`ë¹Ëbû-ÿ67 !ûÿôõ‘ó·£Fü˜oÜGœ¹Ÿíûà&I0Èqƒ»N焎”„D"‘â$IJ% $‰KÅ[.Çοkzwÿ×s©:ô´ÑúÉKk:a ïÚ±¹÷×u2LÙ#Ñ׊ ²¼8$‰Ë>Ë`´Þ¿Õfà÷ìAÕY·ÓHmþ®—)û:W<ª-êø1Þ}ÔëdÓnÌÔSÇ9»qµ.«¨G£XmºFÈÙ] reÓ€ÄFGƦrûö)ÒÞ¦CÝjØøsÝÖò,$!XµÙ·îÿÚ;Ó€&®5 “Éd!,d1A\p­ ¸ €uß•ºï[ÄVª·*µTQTÜQq7Ä—¢XTjôª• W‹²H\@Y"É$™û#0ÙU¨óü"“oÎysÎÉœ÷œ™„ÌÂq\RûÃækùùùÏòó%U·æ.ÿ᥃ƒ½ƒ½s7ÎãßSì}Q…¯ùÑ{<¥Çq%€RŽSËjò\—dîºb®« 5ì ¿C—üPà¸ôÈû‘}̃a·ÍWÎq6UmÍQaÝoÍ4›+qÁqß› J…]7éP¦ýþ3[œx_|;·ðíÈc©ŽÐIˆ zŽ2“„߇õ4¼u‘0>f“¤A|L”.K¢NOw"¬éÓA1 X, ÃØ(‚ l•SÆB”Íñimr·°Â¢Ð2:a‹«%–õéÖ7.u\3>‚¢•½C‘Ç‘lúù‘ÊAÉ—*š÷™B 'žUy¸ `Xf²±¾vkRsÞ† dØ3ίeò…Í5”*cêMqî£ÿ=¡’eþ¥9={­th)È|X’tï†-V}ñbÝiŒ5åŒ +2ÙG}0xf¢¶]ûÛÒøÍ®%á=®'.UÅTÆ ˆp¹pr4V“„P”+ ŠÏÁ0”ÀbcjÒQå%1/%®Óû«Å¨¡KÞécв %U.S»“þ#‰W/«ãñ'Qt°@®nŸšPq4éD“Z—ù?¶ñX Ê@3! întè ê.‚zCÇÇdfåÿXrYrǘ|™Y.k¥7~rx@¿Éûn_TTR\ð JI¼).*”òÁ\Z d¿3÷5×jŽqA*Šß€E7 ÉÁGžõªOC0D$ˆ¼”"2~•™™™•ù8»,õNJeþO_NOqumçhcTè:bKPïV"‹„Uƒ·µÜL—jHßÜžõm’϶DÕÊ5×´ÿü™/Ò‘1xyÆÂ‰?.9’hCI‚K²PÌRÄQO‹—ßÜ[þÍPª¼ Y\IXt³Ð_©Æ ¯BV¬$‹.ZŠ*ì,TžË­TñÑu‰DÈË£ñ9›}©‘YâwÂñº&´èb.9ò ¯fäß3bþc±î=aþ°÷ÛÞ´ëúãlÇ KÖeüaÑOTGžTÊ ~ ¾!À1é¹Çr¥r¾èóYùA˜¶0ªÎü/#yUŽÁ© iÁé“ñùùyy¹yOŸfç‹ß 9û’|º´qj?ÉsT›6mQL‚n_ €œØÉþ™v­DeO¢ã%GnöКS‰¿Z?Éñ Ð\Ï©ïïZ/·kj[3êAéÛÛ˜qwÍbî˜í—Ûî;¨-/‹c‹"ÈÛ¬·Ð¹™ž}ByIP®ˆ… %÷J4‹Zr§„Å6ÔØ¸l~Û#g·›=Ø;ØoÆñŽ—§´{¿Ù+Oªà7ç×5!_ÄWHÕñþF³ÑÑ >¦\IÈJ‹òòÞÏ­*„BŽã ]>¦Çå.|4»ÓŠÈþÒˆÓÌŸ<8°ß[w©½½¬qXª`+ }Y\IÚjš>&$G!kº-Ou¼R\…rlÔbê„Á>¦—_ûOvk§Ö>ã:µq²íµX´eÃbò©¥vï,ޏ‹ãí=×gÕ~7.h–¹"÷Zà¢U9^ñ'Ê5ÞÅå„J^è©d©e¸·õ‚mÿµÕ²×ø˜©æÇ*_ùÎÇñÚò †[ðnœ¹Š·W?äÆL]ò~\“?Ê’Ÿ’®˜ÞZíßÒ_ lf¨¼H%Ó^­¸ôøzûä[sæº^ŠêT37·æ°^¿xWãZÒJ’—RfCõ: †ñ1›$ âc²Yˆ¤(;#ãy¤T®@Ù_ÐaÄ*M3ÿü<¯¸¢·D›u–‚ç¿?ãæ?CØR2Ýßìj¤Ÿj· '-û³ìiꢵ×EÞÁ_˜W_cV>.ãš»ê7ãôc¸‰µÜ¾‰ “•|W²–-׺Vmj;ñÝ+ ›Ý7øŒ‡ÆÎ;…¬äFÜÁ à£¶gŸÚ´¬™¶µiŒ 'kŠ©g(ÚpµÐ?©[µìªˆÙ0cs“dÂeƒ†¼~߸Ÿ_µ52}øB÷÷׳Y§WNxžpå˜j¢.y?¦ ³Wôú%hsÄífI,Júþä ÉøýcUv¤ÊÇTýÝ/àÐø´AËfmü5v Š€³1'íI%i\ÒI••s…Κv§0>f“¤¡ž%!òšó-uåçÂ)à™Z¤%ØqÌþSp޹5»òþœà[3c¶oÙ}ÉsÐŒ]¢—º@Ç©EGîBÀûÝEòªìÄÄDB)}QX˜óèvÌù›–=§œCÜJ·òw5  *¨ßºbhŠÆ1u·PŠÓÊe=k¯9¨@y-;³óTâµn/ɾrêð…øÄ”»2aë›N/ÖAW1x6ŽU/Ïn9X+e•¥%%%¥¥8üêe®„B²eæD°z„%ŒO[>ê¾±×É+ëÛò«{¢š¼ö£v¦NÜ2wHÁÒUÃ{uÊ SS¯îG!}vX,ÝìikظµŸóZoÑXÃ-yÄ’ÆÚ/xG[ý,–¸9Öº‡™¯í×F¬òéåÊF@O1LZ|hœš‘žù¶B®ÏÈH`deÎ"Bòâòu™Oìæ¯ÈwëíøÔdüž _ëý³‚Ôä@f‡žéê±cÛ‰ãþ»¨T`vNÂc§{·Ó//Ѩ%Q{znØ=?3ÃÎvŒÛ~bÛ™MR–‘ƒSÛYÏòv!³q¬Döv¦äK”ß~ßÞEs×Ý‘ê¾ØÝº¹÷4IèF±Ôתæ ëƒ •²‚c/d!}¬äÑ!t:’]ÿ314‰‰‰žžžägFýüê4bÞû~d˜ó¶è)­”¾#†½*—˜µìuh«€…ü8Ó7õùk¹áðÒîÍ jXqÄå@;cPHóå˜ýãÐ)ó~ù‹kêxîòI¡êö5Ê,õÌïäq‡÷ m¡óôrbç,J}y·–›ÓiB­~ZZš···Z@DˉÊq;ÀNÚxžt2Ëyä@ï~tÊ«”JÃeÕº˜Ò%/ÑúöíK^„R‡×:µ4­J©ábu¿ì;»`ȵ1v ÖØ)¥#aîÏ §Œ¼¸c˜¡%­}JõïÝ»§)0>f#„Ãáh^%ÕÕÇìºö씋¢…úÖ÷Q±jÁSã®\¾Ê¦D9WŸJ_]+†êÙ|läš_óéꦿî^ ÚU?´>6“Ú7¿ÖK_´Ö“fª/%P°4Õð]£ )osNm+52ª©æê’—ŽóPvh±IDAThl6›úLÌ|d=‚ò´¸4±éßÑÖŠ½ÚÖ®»Ö„ iÞê=¥ÁqƒdJ®BU}UBÆÇlèéùô[3‚q9 oþHåòhÇp„}ÿôgR~ùÇõG–fóÙz°»1VŸ~¨Öù?c°hRÞÑú#¯Ç¬Ô%/ÑÈY9¡±bþ©DãÝ#‚3Rž•‡NøÁàÄè¯Ð½]ë׺¨Ð©;3b6:tuûFÕù­Ü}Ec”ºL›[§ÁXu1­hôQÉûÕŸ~0R—¼4GLªbjóú”¿>Xõš7`Bz:àY ZT:Õgöc6:d2ÙŽÒô?ÛßPëùZ[,#štD£®•S‹ÏV45˜ý˜M6›MèæS—î V}]–#:¢!¢úYê>Dò›æ£ùÓ£ÖT³i §ç¶¿áv}.ÔS´YÔÆº3#f£#99ùS¡éÁˆf7oÞüÔEhz0û1èÂø˜ ta~ç‡.̈ÉÀÀÀ@f?&]“.̬œ.ÿ} 4no#óIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axisbase.png0000644000175000017500000013552513070106167016716 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu|ÔÈÀßDÖêuÅ ÅÝÝ—ããÐÃýp;ä°Ãõ(îR(Å­xK¡¥îÞîv%+Éïl·Ûí¶´üðË÷çd“Éä½y“—É›É zÿþ=ppppp|:¡Pøµeààààø¡À¾¶?œcåàààøÄr¹ükËÀÁÁÁñCÁÅX9888>1Ä×à+€†a0 Ë—)Ã#Ò^†Fm¡þ/jרìíig&ÒZ!Ä0Ì׉ƒã¿ JJJúÚ2|iX¿Ã0ð<,…R2<žÃy8Ž3 ÃúÜïV`FCk”*% ÚUí¿¶P€Øq¬mœÔÔÔˆˆˆ¯'Õ'ÆÛÛÛÞÞž$I•J!š†—á$ÏDdbfcc£kÃ~wm=äYYY2©D¥”Öªj‹c? 5 ŒˆaMÓº£?†ŽåâÇ+ïN£âŽEwßi[¬8&===??_ $ù7â u(UBF£R© ŸÏ·³³#IRC3ŸÆ“< Kk;;;„NýoVY£°ë„OKKËËÍVRùMVøn¬ÉÚ±¼Füklé”±>³|wòA+›•r­âë- 0 “““Ã0 Aßu#NýZ­V*•VVVÑ yé™”©™…•••­­mµÊddãå‚"âoW¤¿ýíÿÕ—öö㔜œœ|Iž]A ?Œ5Q ü5¶,üxòÝiT’À… tŽ5**J XYYU¨Pá»hÄ•ñ ¯S$###''G&“=xžQ¥JU’$ ‚èØÒãJpÔW·Óÿ+¾ç€_ÿ>õ ’1šÜÅ3'6Øú|TB—tsëÕ¸?†y³(Òß0MêÚ‰JÑZ–&lÔÀZÀ>-àΓTÕtMòOeÍÌW±ïíœÙ‘ŠÜlÊÌÊÓÖ%È‹I–ÙÛ; ÷¨d©¡D熶Æò3„­¥ÈY܈Ÿ[G ܰFÑ´ú꽄ŽMÝu•ímxºƒw…â)õaÔò+’:6ó,c¥/ãmò DÿZŸä¶-=Ÿ²kD«$i2¡ƒE9†árÇjT`…’éq¬ºF\YÈ|þwkW½4Gði¡ò’#i»V¸nZÃzõ[ž•É«PË ×5èôëAì`¿ÚÖO^ç£^¿~ˆß&e*ÿÞ"³€þS–»  |~ÁÅü;ø÷ß@†„z9¶íBgïdYú“A}@åAÿ®ä9oⳟýšÕxã˜j™».ÆïÓäJW÷Õ*++˜2¨/¨ó.ÌÒºcZ™8{ä¬þ'Ÿ ‚°UÝæÇÂH3›JÕ÷þ{}73 å²Á“þ¹°ÏGAètamÔšjyÖ«hª¤"5÷°÷”x+2â„sQZ¶x{íÞßñ¶ó5ÑKËÐÊU‡žÕß½ŸMa)%=‹zåÛWd¤V7›‹0B¯Ò•nÄ/ £¨ m~rØš‹ÂÅ£Ž_èݾʼ…‡ÌíZMÀl>üpÆŠþú“â¨ä’c—º·¯E–|?/b|D”žáÿZ‘±æ@øÜ±Íý ^§QôÅ[3}7׎Ú~wìò.h°n€‘Gxðß×®È1•Z‰áB1´Z®ÄD šb,WOmø ÖQ8W€®Gà8®Çœ¾•kp‚¹»g§ê&;_\ Ò½rgc/ÊÒ˜íY§RZv2gL·Iy hµtÓ†'çö"IœÖP—Ï<8ý09[Æ88ÛÖò­6¶£ Ð"fëÚGë7·&q¶A§ß ÂqœuFÏÃó«ãÛÒ$מËkÖñuôôÂÅ“#W®™”*$I“Úü1¼†;7 à÷F¶µ?noÊf›ûþ§®ãüÏ]™T(+£\4¶Q”ÚuûíÁW§×|XiÛD‚ÀtÚ{w®››$îtÛiá8[ìðhYï´n‡šÛš€:;1GÝg×–ž ¡²3c‚–ïytÃí×-­„¦ö½WµX>qSȱ™ÙŸ½‘`¦V«Á˜5iš–&…­= kTâx™'„ÆÙMï?W/R±ÿTˆ~J¬Ê Û}ÜÀ ’“žÔ8Ԫݷ†Ä ù¹ïïçTi4ÀYðD>пâ?ŽíÔð-px4u¨2AÝûÙ7»'òÉ˃7ãcse4fëP±C[ß>~¶4â—бfí¾5E`îX9õíùT$‰ɬP­¶9Ÿ’DÉ1aMs¾Á•û>îIšR÷“VåÀDZ˜ž—3±wñ÷/È×Ö¿–zwh3Õß\—X’öpÎNñ–íË[ ù¹ÚØí&4”âåY’Cž½³ªÒÊC¥Þ¶ ¥zžJ»÷‹ëe`êÜnå71\~ï?­p„NÓjÀÊ ÏÔ˜Ôg¤-yüü^‡&+›Zˆ“nN ðÙ4ÕQ%M¼0Lÿ,£#„›[ˆì+vh]­j¢tèÜiá\ºF°éø<”/WéK©ÈŒ;œÝks§"%«¡Ne¨¦Ö´”Ü(ÛÜûÝ×ÇE€«dJŠà |ƒ/ËjÔ®± <;táÀ#ÞÌi½kWÀßG$þ½ûÖ|eÇuýïYµ_.¹·¥_EÖ‡B±!Çà[Õôyx>V!ìöÉt©$&WªºwûæžE›¦µ^?±_¿²íý'¥¶%Ou‰u¬úú¹ÕÅ‚«Fà_ä0â­=º¹GÙ¯ž®^Ù,psKv÷Õñm^¸¥8o§M®–¿šy"nÓC_]8ϹzºÐ¸Y«^!uíwžŒn9º:Ôž²:¶ÉØIïÜÔ­föâ­¶î·&†a|&0óœ?¡0s§ïæñõ[åg¯¿;ª¥yáK@ÅGÏnW®Q½5¨æ†ñ0SGS€ ½|ËùXÙŠõUïï<öÒ®ùH€DÐò÷^ì´†K¼nyO—¹¾ùàÂî3ÛçuÐtlu{,çÉ«¨Ý/EÉz-ìT¡t#~1iµüÚãìŽ ¼³Þ$hžgX6­Ç¿ª¨mš´jò’³º —þÑßžDY^Š·m_øGôéX+#»Ð­d¼xSµbëê–Å åËsÕ&w\ëä7°Ž‰¶†P•š)å-… ŽG)ŠTxÇúm÷üZÙ`g泈Ä*žu ZéIÉy›÷zÖ¹ÅìÞ^¥„:05 ]¦êE9ÌY䢕L…få6±JW! pÄ£b´Í¾$­‚ü¨xm Œoníi¯Ý&º¿÷F‰É3$©oîÍB¨•9âŒüùB H¨/¹Ày*—Õ“ª0´:7G|ÿöÓË¢þX׿^ÅÒ.t§ºLu8ÝëϺÚäÕô âÔÂ}QÍýtm+–Œ·7³4phÃùCE‹U`î½vjÍ R2Jš1%I‚À0„ã—SS™+ïHþØjO8œ~œW¹Gß–Þ6ÐÀϪº»yº¹3{¨V¿&‰¯§ôâBbPð`at: Z¬pãT¥—ª=}—&3ª½jè¸àé#x„ J#ÿÖ©"¯^s?ó(€KÅ¥´ýÊ`;­Gë5Ñ0‰Û€ƒëîvû÷êK'¶® œ>»=´ßzu¶kA‹õLÇï´‰3.PÙŽ«cjØHgaE3vNÚ;–gÞ¶§¥tÓó´ àÙ‰.eqkbFàfPžÚ£AbhPªh%€Tìè_ÁúÍó“`·¤zþ¨÷ÖÿÕ¯BÁKû‚…-GÍ¿õrg’Ó‘Én¡;›/¼)xRÉòˆúZ;˜/íùõ­÷ÓG,5¸2[¿-ܽݽ0ɺ硚®íø¨4#~1iÀòeJ‹Ð+ÏZ“F‘v„Z*‡Ä\—6mµµ¢$‘“6¦ïXÐÄN@p ¬¼jTâçůsâ6"ã‚#ZÔi¼êÏçK±NŽ bÓ—«@¶lS¼¥ºûèJT¼ˆâ¯<¾îR¹¾¹¶îµÔÍÉõþ¬=Á“d¦;Fºè’%ß½u—çÛ¿¡¶AMã8Ï­¸^8ßÊ¿ž¡7/¯F†ÅÞ~jbÛ@¨Éùçü«‚<,!öŸó±ì›ªþ³º‹€¡c’rLíÙ@ïZ«NòÆöøÝªPÚ„Ô¹gPÁ€" Yñ4¯oÞoüûñº<ÛC'{…NŠC/v.ùÓLÛ “DÅ‚§6çð¯+6›«Ëh¨¸×/Ÿ0EvZäõ#+(¯>ËÛvžtô³›ýw(òwߪ¦/ßÉJ«É2CzŽ{^|¿R®ÔïqS)ÒB¸Z-Wƒ<3ül¨oGÿ µ7^:çÉ+ñ>ý{V Δ";¯ã’†o»²Ó£qcº@óÉÝ'TÔ*˜tïì²mÎæ;q ÆÂÍ¿À«j©Ó»çáÞÚíRŒøtdSb„ÉO]ë>½xÝ».d= »]»]½®MMÇÎwžZÑÅÁ4O™+´ðtq°bÓ[z¹7„7gí]‘¢(.FÞ}§ùTjÄ- Ušî³Úü3ñüòÛU4·48½\BFn¤àp™ó/†ÙÅ»©ÿ~gÛHkG­F½öpx…±u‹&dÃrÚU·ÒßU\/(áö/—Fj*kÑ™,T‘$MÝ×ÌtIˆ»¸i¯ËЪÁ1Zx›ã´†:qé¥þ¹´F$#Û>;Q4Ï_G·6AÆ.”#½øø“Te.Œ±²Ž†mo뜉~ÒÀÝ·+ÖkãoVÄ'Þ¼I¹œîT•õkÉ÷^ ¬*7­_ø\bÍ£ ð!†V‘¦k8O8pîuƒ!µD8@‘û±\bP´J˜§š[I„'ŽX¯;¤–Sê?þíƒÐªæ?+´]:–•|Ø›UꓘÛZ_óBy`Nm 8ìì1²o£V>f%éE«¤áïÓt—XÙT²!ʫѽ½WrMBH™7zqÐ?»G³@¥ôýîC÷º¶òa¯‰“¢™cÛ>r¯U߯Vyáû¯d«98ajjRø:è×Û¿ž/I`ý†T^Ü›@±ºa3 vOI‰±ê;âVÉxygÓKÕÆížú;Å a“öÄÿ¼h8¯ ,/‰V˜ºŠôÓ0jÅŸ»ƒàCL^3¢‰€ŠÊÄ¡=cUÓI¥’¥®8#Y4È+2[mÑZ¨»„•GƒëìÎ>;¾ûÂÁ#¶ýû6ÑÊI—­•·P~1 !wuµ}D¯"äìž„7!(>_¦xýúµF«>£V*4*J…)Ù´2~þì߀~.Q¤¬œô²ÀÓ1ê,iòšY³°™…;/¸Ú ºÓžgf³®™­Ûªu•#ߊé»Gnå€m½Ÿ1€Û1ΞãÏDwßsˆS¨EN¦z†ûéÇNes}0mt£k¿ÝÜ>¦>›@äl¢¡Þëëb  q:…? (’ ëUœÐÜK)y»òPrÎëLŸŸ-bŸ¿Z·÷±uÓÆMÞ>Â~|3æØ•øáÝ}¨¼w½§Ñ)OÿþÒÍ«:ùìÕc;YQ Ì]ufФn}ÝòølæúæÓ¨%j,} +ŒJžzãI»íXß»–/‹?·Ž˜À¶ª«Y­\o]³­Yƒà[ß÷íá€ÐáÝcî)¡r؉ë³R¿MÛGT¯»pE?GÃŽ.0¨ÏÃhB^»u Ú³tí³‹bx¥ÊU —{ášÀ®^ss,œÛlÖ¶Oüyðø;Ôpþ Ù|0£º¨ògþÓ|âPž^7BÛ¾yÈ‘ý7V.?t¾iƒiÃë»°âzQ’Èe[ãt'º¶íºª«M¹4RåǬzŠæ³_B|sÏÚüÀ=±Š9^"&Ç,ª™_ |U£gcqÌ0וcªtlSxèüŸ§Þvn\ß•dU~ÌæƒRF¥ÎÌÌz–áÑ ñüÚf¨TÇXu}[!ý®.¥$iÎ_¯…€=x%©å_Øž˜šµÑ¿ŸGá »Oó+±Äq\/[‹Ó;´ç²Œ|¦ɤЉÍ!@Žã8³{õ¥D÷8Ž'ªh¡_ÿ&Gþâ8l˜äÊÙ{í=ýNüÓšÞÚïLìH2¸A§¦¾²¡ï)VÙ37aez$ŒÀÜÊuñ‚*vœoÑy̯ÃOŸÜ;lÚPó÷;,Âqyï;| @stV£˜†óÎü»ˆQÆÍš±xݦ}peY‹µo«سΙ¯•ðÝü¦[:^öA ‘‡LžtïòYvB܉EW¬"L„öôÞà;ìܾEìX1–¥Òi‡!À ~⇮¾qÈÎÅøøËlu6…ó\XCßSÅÔ·&†!¥$zýžüâÅ!ÕTÀqí…Í–#©~cÛ Ìð-L™ö¾u<ëW§þ4}XK­®ºÿï+ç$µ9Çq‘uµ“[+‘&Âí¶9ká–˜O'ŸyA€m•šàašyåÜë—“ÝG4o„ô͇ø‚üxîS` uNÈëyÙÐÇÓ׌W#~>[ŽŠã¸F™›••¼ïDrصh«&5÷x˜Èki;×Û¯­ Éx•Âìô1Ãqm3üb°á$Lo³Tƒ*›¾|øNÿÕ´y‹êæ82¨Ï¬ËÂ0 ûua»¿]\R}¢ tiÊU úb¨é Î¥·[Ô]W£p :èÒ¿ins\ã‚ù¤@`$¾Ï0 ­–nZr«Û|^Ký»Ã1D ,‡ëÓ®YèŠí·t<4Þ­¸^BëzG7Õc·5ÂÌܧþîP Y¿ƒ«›¬9›Ï2€Œ‡b«ªõõ=°å†aHžývw@¬þ‘9ÝYWŠÖL­!0¾­9BxÕê•w©é\°*I`…Ž•mr3 æРq Ä‰3¦Ÿ1m×iksÕyGª¿·Ñº-3{¯ßõôJiÌ©<8T ŒûͲŒ|Žˆ°«ß޽4ˆímxtêÄe¨rbl5=‰Þ‰‹ËÙØ6IZ÷ÜÍ]s`òÙ+DÿŸÙCj f¬F!ÄvÞé”­îÁ{«‘g=ò$òÒå”22âm.À+‰ Åvƒ`0œ p\×~iýÊ©7sø]Û ÷í\Ç(“/_8Vµzu€Š]ËïõnT«×¸¹¿ŽjC`·_f:ΰEBÛÞ®²_"D;ûõKë¾jÕÎÕ;¯æmü£ÁÏö|í˜jæü‡v8B¨hWLÒ»\Œ¨¢Û# ÏåYÕb¬âŽ¿‰V(¨oMG8ϺAm·âÅžòNk;vš©ëW¯“ÍÃÁ¿§C«œÀ˜ÐÍ;1Œ@À¨é¦+GÏv1a+}ôž€=~½=ѪŒ;ã/üYEž/N¾dQá$váÜïê‡ç5a›õEÌG˜v0'ÝN :Ud놩m¥ÓêÀ¨a±‚ަñsé¸ê—¹®¦€1¢Ê®2CÆØ×ùÍÇ6'âñ‘X¯‰+Zðˆ6Sš¯ÿí´¹Gk'¡Ö‚´ZepiŽÞÆe(Š6Wýq‚ A}Æ1€³6I[Ÿ¿½»ãâ åöººWÞ)¼MÔ²kÎÑîu§T1×—#ùõó©‡3oŠþÜ£+s$‰Q‹V] '¼ŽM­Gu\ƒ‚Î+—Úu¶nñN¥…ÆõB«WñÛ¿¬!Ô­®0ý%ÐvýUî`-ÙüŽ <àÑ«|òk“âˆ0uhQô[•û±)^¨oqI×a½ýŒ~ P’À:ŒÄXõ]¯8!zö¢óÒú­ö ¯‚ìŸGý´ô™¢ÿ‚.ÎÅKÿÄúÀ ~íy%:M„n$šQh•øÏÇy£¶éykFujç™­`×öà)"Bâ((ø4üî3‹Fu Ó¶’@ʰï}²8Šo^A§‘nJ²‘ ÂÊõj %ÿRˆ¬N½†•ÀLp˨êý¸¡Ój[}ã'—«×€Vj½½¶LZŒ˜1{äÕu[ Fy:C¶ÈF€ÆÕ¬ó,K¹­£ù°x8¸ö<Òdó%¦ŒÀÔᕲû.Ì* ª©è§Oî0ù9é¯nÚœÐgCahåáD)¾8ŽÀÛXMq ¤¸À¶m“*Å•Š9ø^g&Œ6¾ifØI…¨åñµ•ãÌOjup„ý³µ»ÿéÜÿÏꦓ·^G¤n¬É½HiÅBà™y8RWß‘m»4— ?ôhÍBë¡ÿ`‹GÙÿ"Òž Ì7|˜Û•-Áÿ„ù ©aï4 ­RÐ…]4âçÒ‘)h¼fm»ý¶ûj«éuºÔ±Þþ–ÿ˜ºí¼EÀ7µsÄÕR2OÉ[ñ1B4íç6—~ôªý –]- ´4(`›lÙzwëÝéÆöY‡‹(XÞZ¿aÑ¡+6[75Ç wÊO¼´ãVþŒ?ù[“Š @«äo=^¾çiÅúõwLhjþ/#DŽ%é ÓˀЈÅÌÕK!¾‘¡îdÒãÙš]•K\h 'DmÍõ»ÎL°"žÊ¨À: úÜJØHŒU'½ö©ÂPçŽn:Q¿[ûmÃë°AC»:ÿ­ê¿â˜BÙoM½ 1WöÝc}bo òC#K*#†Vn^x´íb«N„<ßx(Lèµ{Gï‚1}5»Xÿu.•î ´JüωOŽ%L^·–—UâÛ¸¿w¥¸4íÎ+ôòDRi Alƒ ¾BÓ)ëå‚bRܲv·µ "}Ý9qÛn=|@÷@÷[½SÕR ÓÖy¢kN’@’žÇï_Šˆ'$Cµ5@#'0v 1,s·´…iqU=t³>C€Ðóô£Ó3êo̸¬²Tž¢DòxK.<›ÛÙwÁãök›:º÷œ.]ü[6L´#10u¨d'º0oæ„OdáèYw݉È^þÚ’×PÑ{S:¹0 x¹àñŒ‚¬5Ù¿*µ‘Q Dúƒ¥IC'I’ÀÂ’$qA’$I°9²¯QŒæJžz¦ð9NòFzT|#ƒ„“§Ì;÷pñ{«ž~—¶N:$Ü2²&ŽŠ˜*µéóÛË[—ìMÒ¶}M'WsˆŠK;õÏõLS—ÅMH+‹?—Žz‰iŒ7dD“S‡õù×,3Ó&°š‰€¡•›[wô‹»=j‹hŒfÁ Òèvƒ! ÀðÂWTrÚ²Î]~9¸9YæZ­_ Àh>ØúïÃ,[¯[ºú˜Þ}É/_Ï«¸óï¾UÌ À™"*G?xþopøí§ JsÛáS†lj|ôMP0’¿8½¾..TÓ×:NTçÏ_ê ô|µS³F²=W³è„ñ-Wÿ5zǶÀ£‡.-OÉ'„&MÛµX0ª*›­Ì9’­^ægžMèˆCa`Ħ2úm| @ÀžŽ“BÇ;ï]ÌRËÃÚuù“=$K:¼iÝ3}áÛµï¸iÝbý=®½6,èY y¹õØŽ8 0 wŸÜ¾éEÔ¤Ž½Ž8Õ™€a€ñW_yAŽ‘Mï?êOœ}1æ@o¨³äÚÍ%%f̉Ÿ…Íw¶²æÃ@t2CÓ §`¡5uÚɳ÷od(’\¬¬Wðq­Ì}!Ε«¨Ìço©)”";íùÍ{‰F›üÅ*iqTò ¹ÐÎËÙ$žŽm,y/ „uX1òÒÖ½;%µ~±’Èe4 'g®µ|úÞ•a•Ö2Ó7{éaÓGÕopç¯óOg½*AÕª.õšµ˜ÕÛW;†ôFü¼:>— ì½]œxÃLêÕõ|þŽhá”ÖmâÑ]óýw­9fQïä¸:8í½iáž^Ó×®èékª7pJ-•¨¤¤T·"´µt‘ õƒw&¶U· [¬,¼|}ñèÌóûôéþ[¯*/“ÎÍzh}îø’Êœ8ÙO"R'¤KÏ1q˜µ¨]«Zv$Vâm‹±ýÅT3¢—ØD_¯ÂR*§F@(êܽ«yj°Àáì±ÛÙᑸÈ}Û!í[æàÁ-­àÕÓ÷2AyãŒI; Ü|=+ñ1£5Y)ëÐÎÇzõêÕ~ýúñùüRZÝ¥üÒ²i-ëB«Ÿœ³7w¾¥e‘qsj¹Šy¼Ä^9øëƒ:—þÐÎ5¥Ñhhš¦(jãßûõëÇçcnv(%‡a`‹…QË)š/à}ú hTr)˜”¥„™—[7^v<ôv}ûÒF'¤¼ëT£×OŸ56ç# 8Û¢˜†¢èãÇO×¥¸5s¢ÎŒÜìxfcÃ⹘¼õý´QKÝ„@å…Îßú¶,Jµ™Ð³cÁD«‡®vß4m€5™öü•IíZšÄ+ýç„ êŸY×hµ„ÁÍØ[£æ`4àü¢ET’?n´Æ~&-غ;‰ß¹}Éýk‰0æÕ“ŒôÛ'ÏY6^7ªë­bÇš+½¦÷°Ó{c“fÜi52˜ÆB¦—NL®P‚ùK,c”·@F-¡‰Ò_áÕ²ì7Ñb•ТžG™dЇVf½=¨Gýâ‡Ê¨Wy5J{öÏÀ]õööο-Q•%ôèш§[¯å5:ù9”úÝ _ËÆ¦ø'¸C‡ìNíšW·oßîß¿?ŸÏ7ºþÖ òÞ÷gÇö%——F™5tøñi»©¯÷î£V«)ŠÚ°ýBÿþýù|D’€ãPþçÈg'åúâKΓ®Rš³_l8˜?pJÁ šF ¨T@QL@@ÀÔñ]¿°5U” ã‘¥Nó¤¥,æc)ň_²Æj(ÆWÉ/F!§’/,ù¡ª+Î=—•ž×“Ó¿~#RÊ¢×GhÄÐj… òËÔŒ£*R`lÆÏÏ#póæÚÉhŒÄX¿}øž»¦'§P«Æ¯-)MÐ_íÛÌ¢¯<èÞÀ0„ã@’PÑeI“oëo­^dI—žÆ§Ù´,éTý=ö–(!ƒÑ½š}ak’üOÁÃRó±|Ȉ_NGœ_|Ž®2¾Ÿ!ÐÈwôúè äÙÅ¥§ÌzôHY(‹^¡Â¡‘Pj 2ÊZ-?‰ÀFb¬úQŒoŸŠu[ôè_jEü¹ØTð†I†A–”øAþfæ3j5(•ß¼5Ëb>–RøMëX.Øù –~ßW|P¯oM£ÿS`ßÊ[ÆòQò¸¯ï˜R)Žï mŒõppü“rpppp”Ζ® cÜ®êW•‡ƒƒƒãûæŸÀpÖ£jCÞîÖO"ÓJ=…ƒƒƒƒ£4¼Ý­Ù ­cu"óœ|^ÍÁÁÁÁQFã*€þ\ …‘Iy98888ÊëQ c¬FW­áàààà(;¬GýôßnrpppüÇ)“cÍ ;sú™á“YïÞ¤©Œ™¼qxïkYáÒZTnàÁc¯¦Ìxt)*¯È¿Tnà®#÷Ë"ÇDÐÕà4•ækKÁñi(SŒ5ñþ¾=×NÕLôwžóSÞÞ INF–Ó:¾qMíf=½ì´_æ&¬ßV·/ƒdŒF<~ìTÿA¿Ö*\• úôÖ1³†r_ŽÿTÞ­1¿M<ûä¹…àߤj⸘èèˆÐ{wo?±Ürh.).r³f¬EßЇ­ÿ5ÊceÔK—­€¼ðätåµR:c.»Š=€à ôÏzpìøC‘&V>ÑçTÁ¬Uš,íY·nÇÀsèÎíÃ< ;,1+dFf“å“jdo>—4µÃóí})-mH0¯[7På§»½<¿öç-Žo€¸CÛøæM“ŸÜK.vˆg^·…Ÿvêû¨#ƒ;-zæXÉÃÓË»jv‹Æ4µÎÛÒ°ý‰Š¶ÚUW•¹Γ/žkdžoŽ/C‘q¬ÆA˜¯¯/¤ä=QTñõu"ïü´¹· *[®\6;QD¢ê«—ýžÃv˜P¿j#~±×¶psßm5ºA`àèœÕï#:Dª÷ßïyvjË;•WO€nÎþá¦]¯<æT¿_ß|Z•98¾Etíßï\ªû;v”¡Á·îûµh%*˜ßÞÜÅNçXiJêÜé@ЦÂIÅqH`ÞêþýíìÏ{#ý?0± Ç¡ô¹°Š¡ަË$Ñâ|Õã  w|‹f-j‡_TqûšæwJºöì J?ãëXõÙ7¼ÏÙ‚Iá4ÊD€E#ró‰í».{²ey„ß½mþìî‹cú=-˜âK™‡wørp|ã¼Ù=ò‰i×ëH*Á»Z³%[wy ÿ£óxü| ÆxÑmé¾êÏ"“¤F¶S šðpÚ`!¨\¯^ýx‘[³n]³X` ÎÕ3h˾¡µ1Ö¼˜iÝ'« Òv­ºßiôµç·¯[8sfsÍtؼ®«¶ÅwnØ´Š]ËñƒÃhVï |h‹†Rh4JŠR uñ´”ŠQËÓ —áS4ºÛDI3´š»k¾&eÇJ"ôôâ™Ä¤¬låµS2 KGˆ$BŸ/ðaç…»Y°„ZƒPãâù¿½ó¬Éô]Mmûö÷C/ömYo¦jQ•„<ùÜèZŽ›¼¬ÌUÇHs$‘H€VJ@*KTzË&a<[ à“(õþ¢þý W¨¾r¤\w›ð0„Ü]ó51c½{·p]ÒaÆEGÇ€o‡nÕ^„„J[wo«>ø(ñ}û$/Å”<à ähO`Ô©i즂az®Ø0¨‚ÖeçÅÎî?S’ššÂþ¬`ç Ì>Ó°Å,`ŠþC‚[Vkl6Û›ý«ÿ¶–©àçCÇoÙÛºUsçLs¨\ÙíàÁƒŸ±$88>ºûˆ¥ø-6»O—Ç¥ÞJܱ½™ ðÞä›5¼¼ƒÝvnówÑ«ñ9m¹»æ c`hÃ8ΰaÃØ ]¢ø°—(N*S„¿|U0j•QS¥f@­T*‘¶Nh”‰3fÌ:DL%­˜÷œÐFKiM¶4yëäé!lvÙîƒn6=ïßmÎ7·^Ù´ºûê…ïßçi¼)€ õa7£¼3fˆn9©çÔèè8TßF]›Á-¶=ø‘þÑ„+£:-Î@˜û½»›ÿÇç;Ü]ó%)nh#1Ö7oÞéך²@¯LSÑ´ ˜8/šYYA]á™71¢÷éãçö:Ô,v뾿 €ý®]{4Gô{_ï×Sû&2ʤÙóþZ»v5\Y=h]Dåý[g;óq`T …êÅì[ÚíñfYö“q³Ü=Ý%'%9þ̦³¦&`v\U§×™­ã(…Â@$Žï‹âÏ’ë3½}ɣή:®ê1jûݽ?®ÐG©†.B¥Jޱrw͆-öc¬º *7ðØó0ÈËTPÊøÈH)@¤ÌMYRŒ5ûíÍ?W/ Êåwm#:¸­J»|ùbõêUìÚøS!}ZuíýËo¿ýÒˆÀî¾Îvš^@ÈÄ®³›ln”ùêý3»¬ß¹{DÕŽëy›ÕqÃÎÆDø¥Ë†ƒãSS<âYR ôÙ¶!ç±æýœ°Û› [éxæ^EfIæ“H{õСpÝžíq6Æúïδ¹MXŒ„ßÉ”‹±~Øbÿð8VœçR¿¾ Ròo†È«Õ¯ïf‚GFk¨Ø1#—ÖþeÎÍWß­Ô{{í2¢-†íš;üÖÚm/„£:™©øÃF€Æ×¬ö,[ù÷0‹!9óppí¾¹é>¿AËMÍí[–…?98¾sè»æLÚünýÍ[B ¥ß?'–ôêÝmøËy ·Â ƒ´R&‘ˆ‹Ÿo’{ýyí×on7×/(6‡qJs¬„¨J§NU 2mçiqÓNª€$á™8~a:KÔ2)Ó¡ÑVDî8ßýèý±ùÑqàííŠÀØm`b#’Áaôü&"i‰U*×êd%€®ÿž==¯Û¦œ~׿»æJÒ5€‘‹Ž_œ×»Ëœ‡ÍÖ4¶û¼eÀÁñ5a"îŸß³sý…7ÖëÎ^ï`¯¤hé3àâ5‡qƒÇ79xà¸9 ~i ¦®~]úõ™6Ú[w²®óªÇü•=¾¼ì%`$ÆZ<$D©¦ pC©‡*K®tciï{ ÚËÊ‹:¾á¯"KµjÙlÆ?õ÷8wš3«³3€ÃîÓG” …šaÔ¥P`¾m†÷ëž³¬çˆ‹Õ) «…ÿžf nPÇwMñ ¬¿Gs ÇÏ;ÛszÃW!®³i¸ãbЩ­K‹ØýVþSçùC)1Vޝˆ~Œ%%%Àû÷ïÝîÞ½e0h€…Ñ((š' ?ýƒ*¹ ˆ¸—}Ž’â7”Ñ[L"ט ?vÚF%“3"ïÃ)9>:³&&ÆyzzB—¿F¸àCsî|$¤PôYòåàø~øx¯ ˆq÷з7Ñ5Ç'¦L1Vަô+ÇCYDZrppüÿ”}+ÇwMYDZrppp”D`à•¯-ÂÿK»v?SΜcåààøHXÇÄ0 Ã0ºÿuÛ_[:#00wïÞù|âb¬Ÿ—8ƪP(Xª÷W·ù-:V("ê'6ÄWˆ±æ'F?U9¶¨T$ç¼äl•µ±Q¬!w­Vñàk©d ×_ˆ:ùÛO™û>Nêèâ$*Þ ’%\zNöhboRCå>Uvô×~Ç%ÏŠ»oÛÖׄÖPWî&tnáùÿ(ÈÁQ?pŒ•Ïçm®zÕoÓ±êK ŸÚ_!Æšóþí¹¥c½½óZþÄ>mÈâéƒ/>÷ªééÁ×¢ÄQG¯U,îXZ¹nçÝZ¿öéï^˜sÚÓÐàÔúÅ?ïS)Ò_ë«$ù]Àm²­¯ £–î?ûJçXi•$èIjY”ªÝгBÁ‚‰Š¼Ä÷´} «ÒÊSž•Á«XÛŒ[A“㡸WÕÿù¹¯þôé¨W¯ÁSêÐIõ¹Å+«c]ºtñÓ,XP, Cï;õò“¤Ùê°}2tì^Ï¡„¸o¯½“ ÙrÍ›Mƒ \F-—ç¦O^NÍZÍlaâÄü¼¨û9>ú8H>ÿÔ¸âÝeÇv«ùÜ›¼ T ™À·Ãú>†î˜¦(1E‹å4£QæŠå•€ÉËÀÄLˆÑÊØ¤ì¢'¨¯Þ‹éÐÌpùnO T ØãÒ >ì4»Dž¼¶1T aBßÅ¥bëÖ5kT #U[þ¼»vAsKîS3Ž„@ßG!4ýåZ¬Ã† -_B¶rÄX›4iŠaB¨ø_„Е+—#"Â]]+=‰qw²€ì|üÒÔÝÉÔÙ‘.¥@r¾Z}ân*ÃyVcúx€­_£Õ~›Ÿô×¶‹…Öïç§ÝŸ¶×fõtŸB zãÖs‰j“Ù oì¿ôܶ~O…BE3G·n«ý¼/åiÐ_I”B¡ 5ÔÍlj**CCÉ/Þ “$&>N 4T¾XúlÉ‚ £–/ÙýÇ·©#4Ò­ÈšÛ´Jzõ^¬ÁN†-ÂN¦×n\S)*in¾Xí2w¸3CkÄ’ügÞ,Y5e~çº&8ð*Ž÷yþÇ餕]mËg%Žï™8ÆJQ”APU¿wèËÈ V«Ê“é;Öo"ÆŠað‚¿B˜Î«êÒ?×.5ëºX#MW+4Ù¯#¤¤ÈÁÏ+çY´éŒ!Ž/£“¤ <ñäk'N\Kÿ,ÐÕÝ7´Xiu>Bö™Ï˜Öxòê¸ÄˆÒìwŒq 1ôðÀ­È‚³T2 ^›/hµ:=[¦QR £IÏ–UhÜ|ýPaúëkóƒj¬Ÿì¨¡²Î ^?·».gqLÌ Cc§¼u€aÔô†ý÷٣݇·tJˆ 85u€†ÊÞüX:{•ƒ@€ÃpÒ¼ª§›¸Q]¯wÓÿ=÷Bé߯ jöh:ï^V>NŸaâŽo“2ÆX5ò÷±y‹Æðù|=_ªu­tA“õËÈ@Fb‰¥R(ë7cÅ0ÃP‡ (è&B¨eËpûöR 1íu¼Ó vÑyY”OÏ:ôÜ¿S‡·ÂžE-‡,.®l_S(H,~b§±íºZh‹L’v{ênà•– KýmÇ»)óZ;“4¼—øn÷sm‹5ùñµõIa:²OEÞÛà0ñÈ>ÚˆŒ¨B¥Ž L‚ž­½õsÎzvFfîg' #–M¨ŒêÅ»àŸºÖ€ã[.g©iòyèykÖ±fG>Ó˜W©RÂ2 C+d]{%EŽmLÔ‡£å³|¾§û‡ã ¾mâĸù7ÿjÂþ|6¯ã|X~iy½â)Oìu@‚ó1 ©|&‘Cˤ ž©ˆF­`|ÎX­Ÿ^–ôŠnÔÈ¡Ä9¤ wž 4µýd^†¡¥mÚôÜzñR•ñ>ùïáÚ½z~¦)H¾ÊåX §­[·Òíÿà£)ìIdJ¶ÍŠÄÐê˜è\•,mѪS]Z=y0ã·¶B ½û7øYGÿÖŸ®Þž®fDv&z »c"Ëêkgù°r'½ùsÇÕÇ;Ío«õ¤æöï¹×;ôꙪÒV3EÎ…5‹èü"FX¯]û§›Õ„¥«O©gnn!âça|gss Ý¿ V®]û'Û¶=ܾEû’®›óæèÉLy¾ÚÅ»øUx½U»þk~bð©S'ßËK¼UK!áüR¡÷ Ö«@^ÔöëÃ0¾óÊãç>“W„Ð’%K š}ЪU«%K–ê\ú2”#ÆÊFR‚ƒoÄTè7n°#+hÚxŒU£æy¸X@¶4!\iîábBHg•B¡P± ^!mŒ•V坨öسe­?Šž„‰€V“`n¢­WÕýü4J=”ÅP”Ñ7%š¤ú-è)eWgËÐ,iÌÍ aãFæjŠÆ¢FÃAçÀœnîlô‚¢ÔÀ¨uÚÙˆD¤áH`)t°åI‚• b¬ áð÷âNÅËO¨£õb¬.M2î$+Úi¡JšÖ(s^…'02w&\Úb@ ÝuŸ½–:¶7ýaF2r|Òc¬TÞÍé°feÍE[” …„­ˆT+Ÿ¦¬®c á—…¶}q½=?¸¯æÏ“ˆ¤«gï5Ù±|~~…‡Žý:4dÈ„ú¿Õ”®·Ž\<&÷ÜÔÏZA3 `¡hÌô®¯»¸/Áu‚·(61“ËuQT8~á%Ž #O•vX„©åÙUÔÅX3ß¼Ú]âK4EŽ5ÓÆXýj*Î=’‘5ØIL­Í­SR÷œL@$´µ·ž0©W O3öDZ%¹œ§™âk-(axÇGé1V¿íÛëÖ…é€xìþ_Wœ³3Z°×²®&ÚúýjÄã ø€á&ã¦wL7Þº›¡¨\¯ðM¡ªƒ!ðÑŽ¯R䉯æfææÙ§e‰/ìñ×olóD®?»?Þö<~}3ðìÕvS¯uOyr_àÓ¸Žˆóª ²os»”Û…;<UÊýý4@s¸y;µÚz÷’NåYÔm׮ȗÖ7ß„èÿ´ça™T‘SÌ7ÞhnT…ñ*#ŒF¶`r@“ùgM1¤Qe_?y&4>‹‘&0jùÏÍ|±|ʹF‡¶ýSS³]»vÏŸ?wÙ²ƼꢬŽuÁ‚Åá}çæ–3Zo"´öÝ6³ðƳÜ4ÛŸÝ6s¨=kLùr¾°F`SÅÀ¾áÎ 3ǵ]¥#§÷©wÖ¾µƒü¢º3N ý´›ní;mŒWòýž£z4× O·ü¹ñ¹åw3ët7õP)¢¬ï¹ñ5qQ¥RÒppXøt”ç,LSýi éûR©ÓÕ­KJ‰“ÖE¢–fX‘gvU3þý·bèZ¦ëæ½Éã[Vù(‘µÈ3/'òýº¸ÀŠÝ$ÍÆ´¨îÿ48çÝÜþ“žÎš9¹ž³6FaCbÉÊÂî Z™Ïp¦‚aÇ+ ­"9]K/áÝC¡>ÓÝ|;7;âï/p%­ulð¤Þa lÔio“ÕþFî›âO|T×=›a1ö›ˆ±rpp|VxVVtaʪíýªþ§9‘¯_Êx¥9AÖžBXv\ä»höå„}ÝÝ ÖÜCgJH{z¦Èes m‡­CËõ-?,°¡WÕcÊþ w/œ›Ùvêæ]†áYTó,h.ZV}åR£[Ã5Ö>mük 0ôÑS¤–ë4?œcåàøúØ7Ù}û !âeH|%äOTÖÐÞ[Vïî0-¹c@³ª%ævsʺ¬uAÝÊ(­Ž’+Ȥi·Ÿš&4àb¬ß-_}Í+·6ÓG–šÀ¡î¸I•3I’:ªß\ý2­ÂaƆ•cð"+BÀ0¸+Ç·ŒWý2}ñâå‡Ã`-™ÏçX988>’’<é—i±~ZÑ>{çcåàø¬üÀk^©TÊÂøªÞtðÿõG}NŠˆÊÅX98¾W¾zŒõóñðჯ-Âÿcåààø¶h×®ã×áÛå¿âXÏœ-id4Çѧl¶pî†þ;1Vß:µ7nüµ¥àøæxðàADDD³f-Á08È”=V¨ë«yôèAY"ª?ä-ÆÁÅX98Š  Æ`t¸wÛ`˜QY"ªÜ-öCÂÅX98ŠP|p»þ'še9÷ nÄñÃ9V(îUËþ‘.çX9tüWb¬¥`tí&·ýÐÙXF‰‹±þGø˜kÆ£Kâ*í<, ——¡r^6ùe ÿg—÷óC+SþÚvlÊ”ÒÖÈM»}:·VËÂ…°Ù¶Ÿ2:ºåg—ã3S|í&†fWÊ,S;´ð4.ÆúŸ¥Ü1VF“7aìÔ¦ûïOªc£Û™paûɨy¿I§N‰‰þ*äþ öÃ«š›“›“›››ó>"""">ÛùTð~~áT’²´ Wt£F"Ý•š&‰Â‰¤ wž 4µýŒuQ­ˆ›3gN)Ž•Qçì?ªÍùˆy *èvÆ_w8bÕÔÏ'Ç7ÌmcÏ=ËžøÃŽ5;,1+dFz“å¿z'oˆšÚ¿áùö¾‹”–6$˜Ñ®¨òS„]Ž^ž_›¡å‹æ.å;9^9xøÌùÕÜÎ.šÂ---£þÝÅÌØ´tB5÷JÎ"½µ¤4ÊäÉ}æ ½ ´&÷ЪY;NÝIkÜ«ÔöïøË’ íHgôvîú– Ä'[ƒ/b×Ì¥·St?iu6 :T?c›E«Gx@拸ô{cSZý5³jâ’ýïŽhPÇi²Òº"‰Œ­]TâDQß«!kë*ñ88¾}~Œ!Œ<ðññù`²wïÞ•+ÛÅXÕÔíß«œvw:1¥ý-÷eã ÍtÞyl¾«9›$öìà)o)…B@þµÿìy?yxTñÞœìÊøš¢(«±îÜé{èP`Eímmç;8HŠ@Hcý‹ùÍJ©ôªUMcUÔºóÙ°ùA»nÞåý`Ý:S°Ù W4cýrq†ý+öìÙËüÂÏ„°ðìÙ3Š:‹g3Ol›©yöåÐÓ8¦í ©iO·ñ4f÷U, ˆµÆ)·ï„óæw¡b¢~‡‹7ü¡©˜LUcùĤ¨Y¯¼‚ã­Ö{ P. %U‰.‹wx“µúö-ž\ ¸%‡×ølÇŠæ³Êí§E{¬?1 è忞.··m3€IgoíhW4c?mþ¿·Õ¢âè¸òׯ_aåɈãÇ_±BVœñw!¾k¯Aäš¾¾ûbàêÀ~Tµ£çæ¾Z 1vlU¢‹js’¡®6ÚßtÜž±‘Ìí{÷3IXäܧ`²»“Ú͉&ß=|çk+˜Ì)ÚO<6à½ö’ÌåVÞ™ºÕÈâÙâ… fXV$—Ú³qLMÿ÷0Pò¿ß¿páYÕ›ªíX›õ1ðàÁÑ¡€ýYGo˜øµ$Ú¿¸9ÜóÜšúî^¸}€(_•¢Oà÷‡¯ðGû±#†mÚ´977'""B²|èСžž›0¬ZŠ"$â»vÈËË[²dI@@€’’ҟجDceg]dæFé{êÌ{&] ×íyyÈsÏêB,Yh»ÀïÀ FÚ™ôⳄ>§ „‚ßæs½Îïwä ‰w[V/aR2æ³]WÄÐÈ?3 'sŠö=ýƒ¥2YAܳӬk×õ t™»Ë»ó{ûÉâ‘(öRe}Ëf€æÃOÄÆJµªœ3È÷{^ÑÁ‚3pà@q­‚ÎÂ'7퀕~¦u—%B2NbuÓ¼—©Ê2Ÿ7WžÑ(à€Õ¸±N§/Œ5Bï—JµG‚¨w*ÒX·nõ¶··‹Ž.Š ôë×oëV/¡P( %ήõóÿ·™å¯y‡u3ÚIî´ÿÏŽÐaªôrO)L»ÿ–èo¨Í(·VDÁ÷È׌¾Ô†.!äð1zõvÀ–Ç—GШ•X¶¶¶‘‘‘¶¶¶!!!dr©}pkRcÅ[L‰ŠNWnæ5H¿Íöíããs¯Î>ÉÍ~3I’õº¥¯½”hºrŠ#ötãwÓu¤0W§–f®7ö$a½· ìÚìÊÈÞI»ÙµP8bÚSH/Ú¬<™#Pl£Zª»vF«½Ö'Ÿ?¸ÍÃÃ&î÷¥cËz‰ªTÛ* 8I5(NY_{,^Àg}PÖ4~ýºœSszB¼®¢îÒA³ýÁí]Þø-x¼ÿÆoÐ`K¸ñ©¥~Ú’ æ®3Ö£iÌ_JEëX)ÊÞ½ûlll>þÔ±c§½{÷)*–;‘©µàíãøfK<Æ´.[ÅÔjUöË~Çݱ^ ûË«ß:ÝÛG ÜTûYÖWïãx‘Û%„¬‰),9<»dGmB…ç:e]Í®·)}}ý²…}¶^?9^’ï²_ï÷àÝ7U©›áXï¿aí¤?ä öýçüx8þÇdr~*dY ¸'Ýlwž»÷1¥°cÏ>Vîõ˜Òµ¢qº¹¹EFF@dd¤›››———dm k¬q®v™uà¼Zâùâºe~FÊ×w\QµÄH ìðÜm½§Ü< Ü5vçn.Yã6]ÐΡUâVY§’~ÏãΟz›JÊgSæï®M#e¤sÊöHQh5}å¾vœøÿØÃ²‡¢BN:‡D«$x''|Vlç–¥Š>œöí¥÷¾üö£>“òzéàM®ôà彘¶8"9zJî¯äø“¡êS12ó›¸ÎÈ:æ’òªEE¥C‡»¹­Û¼yk^µÆÈzyýtN9]lß;°la{k—Ô!kNµ¶¸~íjô7þ”í6ÒU=Ûd“jéo"1™MÿoC\²g1û°ø•¡9ÊÏtÇœí1×\ ʘ¯I6oÞ,y˜Ÿrf‘óÏþ“Øo¢ã0GïëÇ&+ü|rØoíÄãÞ}»«+±Ô=éÊêù4¨üwüòÖmáøŒ~k^¶=qâ¦q77AÓæ67¶9SÒ‚ø®ÝÝÝÝÝݽly5¨Ü±Þ{•©ã¨tU³ÖN±´­“­2Æló?ü¿ö£|¨»Ý{͹«®@Æà÷g¯¤AÛÆ4c¬ÀÈ †Í€ãýïm àÌãä]Gt€D/úÍéªDò!ÆuôæòQ•‘6zÅ¿ºZݔ؀èï '.‡®Z3B&…©/µ*íÆ ûêBÒ°¨Ë[5¨%¿Þ ®¿ÈÐuWºúØv‹^ÑöÚÌüe¸ÎçÂÎ}ܨA;ûZ^ÕT"#¿úSnúq­ººz@ÀA™gË•U R4 '͟Цl9½x.ÂÍ‹š5×›]ÈÎÉü™Å&««úœIõظ÷ IqL‚ÏŠ³?÷=0º‡¤…KëÃûzœLv°ïk®}eqyÇõ‰FKkr½MY¬¬¬$=úÛw]:I["œvк;‡xÚt´Ã Ã!M£-_rº¨‰¦ßnsxÄõF­Ê5.ÃB~jð²+_/~n¦†€É„µ_‡­¤+S¥,Hj¬5EåëXÿÍ`»)`1Áçpmõ»>û‘wØZiº¯†GÑ|ävã#C¦{ÐŽ¬±Â[­Þã³Ù„Ȉ÷’¹ï xñ«€»zá[:Xûl4×€Î3Z§E±—u÷‡ÿž]Ow>vY5óŸî­“_FíÞøRoÔNñ`ÞýÑήƒÈlÚÓM«ö½Ÿ³ïèÕj*")âö>{Û0õ— ·n­ҫ߸-;·Ï3ïYâ\ nð/ÖîæŒHÌ©wϧ¬8_KÕE'ôèdh7-høÞö#×(^ßfýG ¢þàpذwS©³ª­±r…DZÔ™ý©Še«|vïcˆ|+¥Çbû5Í›kiii)3©¼‚W#M[ôô¢ð8l^QãÔG^<õYú›]%ææEùÆç™èýè¥î»þî‚C£KLÓ '©xG}ßk¬ Yo}C-]<”ª®”´È5;â5ß=*:œðo¬!«¤V(ȉ•Ã?ÇÎÔºùÂÐåútç .„ ¯œ½•Úzˆ¼ªˆ²^U~jRc°ti×ÓRGõ5†Qèô‰g._t·;wêí X¼\!p†’ç¿×\'Žñx5ÌÇX«!`8޳’?O]»a*ÜX4õ‡£Û<-à²(´fR»ñ‹YÞî9äùZTàm÷_¿µÛÍ#ØÏe}REA}Ø'ïuãp2NÒ‰4ŽŸy[§ sr~ iôêK®?5ñý‹7Ž=üÞz{­%<ïÀã.Aîö L]]&OmÔßpº•9ÆNêÑ©¯•ºÈ±Â”ÛN/°9Óæåö¶Ù9?€FÛñÔΤÿÒ#Muª9D½B£Ñ¤ç«r? %ÍV[c¥‘0­ÿ[>Q¯l• “!þ¥>¤DÀq£CKu;]y|t¦¸0þðGmSÉ.â÷ù(êÙi(e»Yc呎YJ>SniÔÜáP">´ ðE†…=ûgíVÓÚZi+tþß±œï¶£´P(®ã¦ºN´Ul1z{GUQɿˇÝdNKð2an…&+¶ðþefóAFÏ»¬?zíÕ7–~¿¡ûw n© e <<\ö GŒ5«±’ñ¶Á7.J–ž;ÂØŠõe£ÅÌË-zØ™ª³õÂu‚¢%unÒåãþqYE=Ãù£þÅU·ì®JÇUGmè½ÁùFò1K= ÓtVúX ÀgR˜¥&ç_/®að2Q)úÕ1ÝyÇTöÀ+áìôîvQäA&C&o8Ѭ§x¢9ÀÆ3z–SxhðÕÛw‡4·žÀèp#úä¹&VË¢Lg°>­êk~¶UŸÅ@¦µÜÿ𹊼êߊtÜJ«V:cýC€—½jÝqÈ|›•ñýü¡Ì e\[¯]½J}aó“ƒ#Ôf·|¹rïÛQö=š‰ ßýd©Íh&1>îÆ“ ýwMµ®Îúô“ë®'´j+®oÖ¯+ð=À0h=æl˜ê½¹øéxþ·fìòrbY//üoÚ¢÷Í-ný(Ö¾]^9ï¬àV¢ƒ„²gTnáÑonÖG'že`ðmJö)ï…czŽþþ¼£ÔÇhcc#ÛrBB‚üïQ„¼Âʺ»/H8tMèàñ乇¸–DÕ¿ÆÈʯþ{]ì¶øK›‘fâ¾m‡ÍW¦Ž mA+ù •òªößLß{ã䪫”¿ž¬R  E#³âõîß[CÃ@k…øÍ Z‹B"æ•JPé“WÕaåÎÇŠ‘%2N%H˜¼+L™FǼ£o}ÎÜliXQ“ÇçœÍüŽõ¢ kð kŒ\åð.)}h4p¹\IÇZüß*ïyÕÑX• û¨Ñ™­zv€Ö]œÎ'ØîŸ“ºhýž–“]ûögð¹l>d¼Ù8iËôgMp½9Î{¦Ï}Kî ¶©A%ýJÉe³‹î¦Ã\¯)´ìuãJQoêYq¡Ç¾9ÏÐ*ŠŒç¦’¨Íë }A~JàÁ¤Ü@éŒ76Œûß vð³£»”,óuûÁÇ/9Ž)~ôMnfƒüºÏ¢.ËcŒ5è¡”4ñ £×À÷?É„yÕÍæ ¨uô†¯ž 07ᫌ6ËeÔ! •JyÒ⬄TK+ þLc%QŠÂFkÏ;pºKLÒÔÕþwþ7°$ ®¬Ý®àÇ5}”Ø_àzý$WcõP¦?Oäˆìð ^ú¼Ï²¹îÒIMÜÀÙX?hÇ›¹{LE‡ìÏytµîuð­¼z—BskëÒKRÃ×NßÿëvüÃþ¥g¦m÷^‘'>$„¬ V3¦¹y USƒÒTdú­’;ß?_0¦hÉÁý7£Pg¤6T€‹‹KPPèµMí®cE =ÝõË'žµúóåV"²’b>xàqé†ß¢É™Ý‡vk§.Y«¬»ÖLÅ`ä|w§9“ »·QSU¦`âE‰=lÚ¤}«{@BÐ`þ³ºc)g´Ð¡û…ë2ùÕ)$xrïG‡ÝDUiO6Øïе 6¯îz› !¸®w¾ëÍ^ U¼bΡVã7¦Þ».ÉQhe2²ŸñH‰ûu‚Ÿ=† ¡É€-¢©ã¯ž]$Ó‚z+‹ƒC•ÛÏØâc§GÏ öœý\Ðõíxéð ø®ÝÕÕõóçÏQQQÆÆÆ®®®µ»ŽhôHÎ:%^Ë•úSÇ*ä|ýôáùOVR˜û¨àO¹Ìö#ÌÌFRµ×‹hã¹Ôvø ã ÓÆgfÔ‚è¾WoÙäãàÿÅIáÓ§7bkº 6¹§ñæhQIgîòŒl¶H=É©géÑöˆÝÁ¸ìu=Õœ¤#?9~ÃZ„›—ÅÖüæ]¬ôP~˶Óí;I•gë´!¿8²ñE©ÂV£ŽŽìWêç0R§N”‹ŸËÏÌ̤³*µ€‘B_=^c½x¬¡oz!­s?‹‹/üË*¼’ê±cÇD¹ËY÷&?X||<¤¤¤hhhEG?³±±‰‹«ZJ׿‚´4¹2ƒ!š Ÿ>}ªAkƒ›Š_—ýB•ûKƘ 㫳äQ4b!ISÔX{ÿÓó¯yJ¤bäJ¤ƒ@ *¢©8ÖFC‹•ì¨XirIQÛ õ/CN¿‰.bÃi¬M„¦¨±6ä|ü]ĆÒX›ÕÑXÓŸ]ÏíbÖ^¥dCÎï;A7Ì ÕRÀI>ÿuö¬Á54ZD)$Sœååå‰Rœ))Õî~÷DYP@Xr9VBc·ÈqÐñ'Ëÿ)I’˜|5àßWé¼µüÂxß½7gÏ,à¦ÌøßŠr Nôš®Y”Hœ•vïÐÈH‡Yn˲$?zÉ0¤Ñ@ó >£ÈµKÏZ¶¶¶‘‘‘¶¶¶!!!dògïA ª Ë r5+.%ë¿uiFçµþºýTœý$ƒëc6ñTÔ©$€Õ#F/ÿctÐ¥µ=Eí9.AØl6Êë×o(·WuFQ/îû‰®3ÿ½yxúèËŒ¡â6‘[ÖÜT¶Ùdß]\reá¤û£®¼Õ“Vœ¿æ§AiXO7¤>:¹x•×ÃØ¯ ­º›·?¼ÍZöø.Ø÷Ÿwòãáø“5Õ°àææ&Jéææ&µRñHcmàÈ®Ñ\Ïu‘åg¾îñ'Sn9šFµÛæ„ãTftÅCOYÔäË…)Kãè8ŽÁß´y«›Ìc}۾݇ªÐÃy¥Õt ³Lž@²ûÍnõP,’žlY6Þ„¶ÊÇá4?_ Yá$ @ÈÙtázõçv§Ð¢ v>ÿÐ#°—ª®Î®¡{í½æbPÉV‡ä~9ÙÇbqÇ£äiv IDATC1×, >„ϳš7T#¶U¸³lÒ•Õó/hPùïøÅiçå´ þ!twwwww/[.©x ¤±6pä ×h®Œº÷üÖ‘c7¿ŠÞ·åSÿÈýEŠêµ…Sb¨EÓ)nÎ7²9‚“§¯y®K"çtî ¼ÉïóJ«o‰‰AO_µ¤5ž?°w¡ hp>+ÎþÜ÷ÀèÐzâ·c`jÁr]EÈO=ð‹fМóâl:kš&ò¾ïKVh@Çõ‰FK£Úã e¹X°µè:\÷œ  9ùjXx»‘Ö/Ü~(•“ì²0ýÎp›Ã$¬7jUU ÕØ‰@È 6ò±V~7­¨7>t§ÙºùA[ŽÍÚåý@ThvEôoÿ }qcŒ¬d5no;q¼™¸0æI¤˜ß|¡¸<íé6žÆì¾ŠT`¨[ R¡ß JU%œ¸®þÏÂÅ­•N‡~+*9®Øba'h*&SÕX>1颪¬×NN«žärÿäƒøAþæ7==mÅ%ZF¾ºTëµärósìL­›/ ]®OçOW«dÑøp’OœzTߣh¢0$àóù ,àóùŒÒTÕ¦\ëX_Ü~nì°¯‡Pápèœç‹"yBⅿϦâ™TnBÑÃf³AÈ‚`i¬‘Ò:i–õ‡çOĦ 'Íl|6›€—þqÍ.w·ÀTgÉåSì•àäå¤nÛÛõJÔó <Ŷu€׿·[:ZÜØ¬Ÿúš½¯Ù}Õ 3ñÞ… /ºÚ»õ¡ ¡>àäEfó„ú}K"{Yq° =æa:L—ÞãßåÃn2§%x™0·ÂÃÃeF”\©x y4VNNÜö=w¦M2pSgÏ[]® »ŽˆåøÂ´ûo‰þ†Ú²¾ðß#_3úPoX²—GШåì=%#f+g8÷Ï-ÈפÆZ˜yÉpÈZ! '±ÿgûØ´ÛeÏ£‰Ç·ÔbñÀvŽõ’}GÍF ÓËÐÄq„`N§aÇéFμ£U§.RÝdžßí6Ù>ý*TŸ¥-î®çòÑ…—ã…[;o²ø7 ZêvŸÏÚ¼â³pcáë«ÙìýVĵûk°p|t´:—`Ué‡V‹¹¿ =£ÔeèÈ D|Ê•jùíòÊyg·}$ŒVÇ‚ìÁ$$$Rñòh¬[ô­ÁÞjëV/(umœB7Õ~–‡õÕû8^ä,!kâ€A KÎÏî(nO¨ð\§¬»¾O³!„y îI7Ûçî}L)ìØ³Ï„•{=¦tÕȈÙÊÎýs "d„kRce¨OxòØ„®ÜÌk~›mîíããsÏ‚"r@³ßL@D¢N§ôµçM—Op,û3ë·é¸ñÔQjxÎçóW¾üßPBP°?0lÊdKøÊ0[–üä*µ^Þ’vh頻¼½L`Œ¤¼j׋_›1ºêÈ‘{3u™v¢ìÁ×FWøRX*F—Ì(u,µ¼”õëæðÙGœÂ>«HÿxÊiäÚ‘û—Qòå|Û´ÉSFÈ·S±|¶É&ÕÒßDµä¯(ý¿ qtÊžmÄìÃâ¯!Cs”ŸéŽ9ÛcB˜÷øŒ~k^¶=qâ¦q77AÓæ67¶9SFÌVÎpîŸ[3 \%*þĹNØeÔ€[ðj‰sä‹ë–ù)_ÿÝqEÕ#1°Ãs·õžr󈃔WÍÎû!zÑÙzñŠöªI×¢"ŸN[±¢—¾?0LT¥M#e¤sħ`$†Suoyï;Ìu.ÖÂáÀë´÷ºãöKÚç¤sH´JIÔ4ÅžjTÒÛÿ2¡Š¨„ÜÈ.l?HS²Yœ¯Û>~ÉqLñºj!¸™ òcè>{r^ ˆFÈ„|Å\ZÞ×ãd²ë„}_síÛ(‹ËH˜7?5xÙ•¯¿?7SÃÀdÂÚ¯ÃVÒ•© 3f+g8÷Ï-ÔÆ\¤rõöËÌæKq>A&ºN/…îcGëNô¦ï?ÜÒÒ‡âãÒ}a„ ™Çaó@Rc?Å¥]gnâƒ{³ÇšRH‚Â_éì%¦èBÔE{EÚãwìZâ¾z.ëi°_˜iíÛ\Ô¦­iÖÔ½G(Yc6´’XúÛlšJû†¢$b´]µ—¯?“·ˆ ¾ß\û“G Wjc÷޶{/ŽÈBÖ«ÓÜ<†ª©ÉiA—   Ñk´ŽµÁR‰Æ*ä`$ÅÑ# 7ï˱07ñÜ™Àf³ €§î7£MW²yB.GT ©¼xê³ô)6»hJËÍ‹òÏ 2ÑûÑKÝwý݇F—§NR-ðŽú¾×X²Þú†$Zºx•·X¥öxåì­ÔÖCäU‹Æ¥LqÌöˆTÌö”ëµä[S´*ªº-uøs òSÃëXÃ2Ù-T£1ŒBÇízt{Ç~Û¹PÕzo{e °Ž“öî?o‡ÊÉu“É~ïÎiœ‡aä°‡/à¶ù–a'®îj¯štmÚ‚§komê#ä¥wé1FÔEßÙm·};÷÷ÖÒÐ…T`úIiФª¢z§ÕÍø=_@‡ãm5(³âèiWôÙI{²Á~W¬m`°¹j½ ‹>î=瘯ëè·dÔï×wìfõYxl€2 6N´ˆ¦Ž¿zv‘Jgã‘xüè1døM¦l ’ˆ]]]?þellìêêŠÖ±6X*ÑXËD&pŸ>{Î×7/¿70ͦ²ŽS þðGmSI ñû|õì4”²ÝǬ±òHÇ,[ÑKÄzK£æ‡ñ¡m€ÿ+2,ìÙ?k·šÖíŸÇû—™Í=?ì²þèµWßXúý†zìß5¸¥‚Œ˜-gT¼<áÜ?·r„kRcp¾wi×s´ cO‡]t·;{Êm·Ö¿ó~ ŒºáÜ5׉c\žö1ÖjÙB‹ó;NÒBÂÙcšá¿?üÈN¾pàÀ3B/®ÒµXX°É=7G«xI,™®·´•Ò…>öŸ…ª.j»Ôœ$½ª€“tä'ÇoXKÑ¡›—ŲßK­¢ØjRdDÎÞÄÜ\á›±õ†YÔåô‰µjÆÚ¨TcG&~¦'„€K¦Í]ÔV%ùFä£V‹ý#äeì¼$:KƒJú•’Ëfiea®×ZöŽºq¥ÈšzgV\è±oÎ3´Š²å¦’¨Íë÷ïÁXƒJ™Qâ0Úx |ÿ“LÚÜ~ÅliŠ­å çʈËiA~jTc-¦Jš]IÛÊLá-FžÙwû?!᫜ƳcXø‡ ÖT®¼icåcýë_cµ·ÙÐÑÐù`áäÑ’ 0íW¡Ãè(QÈÕC™þ<‘#zÍ+xéó>ËæZ¸K'5±=gcý oæî1²?çÑÕº×ïßC¿õCrçûç Æ(’1‚ûoF¡ÎHmY1[9ùnAÙá*i¬õ¿rXËÄÁºƒŠüíÕôm—öoº‹"+­cýË ÑïÝ>%zyñÁó‹þ–0ìø•ˆˆÁë{éYîˆxp÷v‰׿MêÍ¢× A€ùÏêŽj’ö:tO¹³.³øÙñ'÷~t˜×Mô:íɆ©S'ßú]׳×V‡*ÇÏØôîkfÞÏKMŸ º¯>ª?÷˜¯;—üóÉÕ“–Ö%1[U'ZŒvPd¼z$),ÆÕÕU”QSÕ·ÜP’˜ äD D4&ªò=s—gd³EêQ=K¶GìÆe¯ë©Þ@¼I!ôÕã5Ö‹Çú¦Ò:÷³¸øÂ¿5 2c¶r„«gA’Ú7¡=¯¢¢¢ê{5€œ wëEü‘+W€8‹1— H8Î`0½çÙõ „%«¿7]× Ö\Ž?8¦µsðÅr¬amÂ._•9·šaäiHŠÚ¨m½r¥üÔ6f§ÿÞÛIðYB2“\ê§@FÌV΀p5,T„Œ€p­h¬;zzíê{ˆ&Š<¹p|ÄóûCqœ£Ã"GâL©ïÔi¶â³¦í÷9aî’5.tpWY Ý?ÅF¬Ù½ãÞD‘ÙFaV°Ó… Ç'§Oüs ²©Ñ|¬¢. 3‹W\’å8&³Ä5àÍLCv¼º”/;ä›{d´ÿéþe$E„µ‘9VâïCËÄÁº²6jú¶Këb,=¢ŒV2¨F`£ i¬D½€ö¼jàÈé7‘ÆŠ@4 ñžWM* Œ4VQë €° êÿhd ¨]ÆÚDhŠë;7ë{bf6ª¾‡€¨E±ÆŠ¤‰j¬"ÿEAâÿ‹_×åHˆbˆÇѦÇM qšD#¦ 9VöªõìXë¾_D½SiNeDã  i¬¢wZìÑ@ì×êÞ»IôK@ãýÀ"$¯o\œ\+{/MKc:^Ñtµîg¬¢ÿ …Bh¼8Bº¾MŠ&§±†¤ Å0 ëÁ±ÒˆFLÓr¬’´nݲ^úMLüZ/ý"ˆ:£ i¬GJ]OÇ‘êf :uäóy˜äŒµ±~àèú6)ª¬±‚Ü1I¦†Ýëf|5N—X  Ñh]»v®³¼}  $µ]¤Á5nªw}Ï;<Âzž:¥jÏFòrsTJg’FÔ%UÖX¿^Xf¿Sãê™å¢CY¹•n³r[²Òî½é0K•<P%·‘(H~ô’a0H¹DÓåwÜ)·›*{VŽ•ò Û½{L›#åX³ã6/ÚøJʰÝ'&&>úÜÞd 6óæä¡Wvß ìZþQgÈëXœ¤•›žéwÿÇÅe-y™Ñ¯’ŽD¿¢B—nÉM]1ÉÕúê}qɛ˻½ßxÿþsž€Ò¢£ÁôùNK­z /pš¼òrø>Í*þ,#šZ댳 Ç%%Ù±¾¼|“V´•GH¼z™M']­[¿nÍ@¥ãÒ={8Þ–Ãúœ¸>”;ròñˆ›{™šÌW«6Î;?P›)«'D"¯ÆzÞq&ÛrWˆÛPÑaØÚQÜ>ûÓ‰²ŸzZ·ð3Ä‹ªBÖMóºömÖÚõ«¶ôaæ}yøàʧ ¯~œß3OS2Ý6Èׯ+ê¢SßÚz”ÕX¹\nô+†Ïçÿi¬MÙ×—¤fpèê)·¥©y¬Ì€•ËÞiön©¹BâÒ‰£ŠdŒÏN|úšˆŽ¾CÀ©ªÊ¤aÀTQS¡*b@QUU‡'$„\›Íæ —þ¢ê‘*h¬Oýçz>úì¦>y …¿n»ß£ùù D‡T…nƒûëˆZòYq«.¤F÷Åq*¤ÜuÜözå…ÿìz‰îMÚv5Öœâq[¼ƒN#'÷¯F)NQíñZ_ŸP®ÆZÛJ"RW‘ÆÚÔ}}Ó£_¨÷3Ø}îD“±v3¶Ó L»uØp¤“±zh’²‹2€å‹æ³¹¼÷.+®“rù…ß–-[Š«Ž˜JÂH4:ŽãTF¦áè/ª‘Oc%ø—¶/r ùLðó#oß•½¹Ö}ØØˆ[7€›õ8Þ1&|Ѝ*íé6žÆì¾Š"߇Ýo7Ó_WìU‹¸òì}(’Zi*&SÕX>1éê@Öë¯àx«õ^e÷þF !Óê¹õçŸÝ³\•\¾ öŽÜnË6SÑë«×bᄇ«œ5xo£þ;½fÍZE-ÕmOÝ!•8V!?ûÉ[ÕÓW7O7ß¼}ûQ¡GäͶ®[m´˜ð;~ÑðÅ%ícÞk)Šn‚üÓ¿XÝæ˜”±Z*d9¦¿¦ƒÿ{¨ùßï_¸ð¬ÇêMȱ"šeçõKÎӧޝóøØ4H¹}`S²*d󅇶mnF!‘ÕzwQ(úž¶ï؉•’Î>¤{Wnn6FbvêÔxý‡6Gk¢RUÉóÐnÞS JäT>Að96›lŽ xâª×?X*“D‡üÂx¾Pí¡([ñQì¥Ê:ú–Í͇Ÿˆ-;†ši¬ˆzAòúFG?¿¶±±‰‹û$]ÏÓW_å0ÙlvaŸ¡Ý&/<ðÉRÏ-ÀËñô 5±ÝO‰ BÁï-6ÞCÖœc³Ù\¡Èx›ù+µÃŸ=ÊW~”æ ¸l6»[·Î(V]Rt5«¤±’¸4çÛ°a¦¢Ã¼L6eڨÄà7¦4R|J2G ØFUt(¤ê‘1,/ÉR|TÛ* 8Iu  !Q/H]_q‚«ÄÄoÅU-:¼y‰·ìÍM-lå0yíìßCí¾MÛ´¸¾< µåžAšJ¢S2_ž}ÝÅþòÔN$*ÖvžÍˆˆ{£G[PcÞø›+è3zc'MœFNLü†2iբ߰êäc%ãzáá—Ë–ç§ú»hеi¤ŒtŽè5‰¬6^ñ ôÌê uñ‚VN:‡DkQ¥·@üÕ$&~“<~š:ÊÊÇoóòx*º õŽnVJ}µ¥[øªFè³1M½÷Š ÕøøOE)²,†éŒ›´ôÆ[`»ÈHÔæº4r¹½ êùcñ“©P¶”ÙaÍAŸ<¿£NËç2ÉXW%ú“¹0¶¨v™óÀ‹N^þÇÚ *qq!ÓRïÞ;#Z¾š—CWíògïø‹ _¿¨°ë*Ëfô‰¬… ’ëÙCãΘFð—{܃YêKú`‡gȯ¢µ®„0ÜÜ\ŵ ÚsŽí ˆúF®u¬\— ¸Iܼÿ‚ì^½d&›g´N Šb/ë(ªÒ½{åý©;çûfï<ƨ¯*7åqä=ÿÃa}QâsÙ|€‡w´³ë 2žötÓª}ïçì;:BµæïŽ‘ÆŠ¨dïyUzqÅå”-áÓ3¿‰¶1a›ÍN{˜€-€7×/ÿè:CM⠚Ѿ£‹_óò_þÓFPP°ìîuC•÷¼¢’:“¹Ék|÷v×R£Ó)˜(¬Oø<~aaÁ—¡Êmg+à8´¿˜åížCž¯E-úSXºûª±éŽí'CVl*Ðt;þ³ÆÿÊœ‘E œ¤i?ó¶8NæäüÒèµ!;Òh´R»¢P©ÔïEk)©i¬Ù{^ù-ݦ=rç¤Öj;Æ´›qˆÌúvúÐ>ÿ›Yë?©›¼ná"3³gÍ[°`îøfð;øôI;BN2„†ž•²?n¦µzš±Î©²ÆJ¦éÜ>ºûú›Ä¬ŒW €‘Éd Î`0õÍçŒ_dZuÔ†Þœo$³ÔŸÞÛjÕi«U ä°†“J­µúzq s€—‰JQIÇtçÓšx‹åCHõ°wQî0M™ž¦}Ì—™ ¸)ïXí÷;vXj:ˆjµ6<|¦*™ åwñÙÓ°ÃO=¦ÌBnJÊ÷Ògcóç/(S\ôgUßÈ«±¶l¹h°\-'îÛvØ|eê¨ÐÅ"z$ºÔ·€ýÅÁ7Ó÷Þ89Çð‡”ugA¼}iKdäXÅŒq> -…Ÿ Þ‹¦(JäßÀ(FM²¶‹‹ky6 ŽZÈÇÊ4:æ}ësæfKCÙ Ÿs6ó;Ö‹&¬UˆÃáHNTcbbê S)bbb”¤¶ÛB¢XãF¶Æ* øèïáï¤ðÜóJoøê¹s¾VÚrùöT¨Tª¤ ¦¦^|X×3GñtÃÆÚØ‘­±" 8ŽcÖäö¼’p£’1¬z¸%— h|4ÅС”W­—1`(Å;ÑxiB{^‰V­JLëkmHô‹4ÖÆOÕ4Ö¿–Gî×÷þ”ÁƒMÿäô*¯cmP(ñ]¸¤P÷R†‰€‰ºm¬8BDÓÑXÍÌFA)¥«Ôw­¾GW’7¯?úÃëR\€ÇÖ÷ˆFŽTèâ¯p¬µ1¼¦âXE¿¥¢ö(–\º]ߣ+‡Zt¬MGcE ê…&¢±›](¶(èÇúæÍ+èÙ󟪜Dˆw…5íh¢+Q/4•NÇË<áH…Â:›±ÚØØ¼{WÅ“‚ H¤ÈÚ!©±6ÅåVQ« ÇŠ@4…ñ ? ê{ˆši¬Dí"§Æ»gÙªäµ7}E‡¯6Xz€ÇEÞe[†-šv*ŸLÃ@È-`c &•D…¬Bš“ „€ÏÚ,Ù¾0íþ[¢¿¡6£¢||Íè;@ýOв)E"€P?Ê|òžË—;3Ê–_}œçæ}xÒhòŒ Î36â纑cE ꟄÝJ-WP ßìÞ}¼¸¬m¸±{÷ Ñ–Ñz_».@ð?}NxN27r µÝ÷”—S\òéÓÇö;“1à³âìÏ}Œî!®"Sµ{ôè CGŒúܧ÷ö ý>Žë–&8FµÇkÌ'p~‡Ï™³—F¥e&Ué£þ*¬×Á€A&9ø»;Û­šøjAˆ÷<©Ì÷5Å®]~GŽ®¨ÖÖv¾ƒƒcmô+i¬DíR©ÆÊ/ü°po,¦K#ðÁ‡¾¼OjÛ­½¨Š?oâä±*dŒÍf ùÙHžKð3¯ý¦½xâ@é.\6y)‘±ÔG^<õYú›-®P_¢wr&åq|›Íºá$Õï¨ï{µ ëm oH¢¥‹§‘R¶ˆ—ÒXÉÊcn^·à±>6™½ïÎ6t2p³ÿ‹þÙaçÙ·37ܹÅD „Ÿ_>]¤±ÚÙÙýú•våÊ•² ÆgggW,Å"ø;©Tc½á¼"[•ÊÀh8޳³#,§;=Š}­M%@aFØÎ-›mþ7'‹fv:;wîÚç½y¬ƒ³ffèΣñ¼‚¯$z+5µfbkCW8R.ò†ñ‡?j›:ˆ»£‘H€•è¶ÙqgÂ2Ù¦S;ˆJ,š;Jć¶þ¯È°°gÿ¬ÝjZoP®Æš|Á‹ÑÉ©ƒB‘¬¯vÏŠ8eâ}þ2‰Z¤Z`€‘ÈԪˣå 6²yó–üüüˆˆÉÚ¡C‡nÞ¼…D’Œ’ÕŠÆŠ–[!õ çwøêpÒ®õ½D‡¸Úèþ <Ÿ·Y¢ÃÜ„[ Íi äR÷Ë烎ÿà YéwžèN™åyîÔæ Ű®y_÷“¥Ö·™ä¹œßá7º»¯[µhöxãñ®Ìv™èˆªšõkÆJy/zÝzÌÙ„„¯6òBµ9°7ÎÄeXÙr±W­%H$²¯A‰jl``àãã[Ú«ÖHcE êºÊý=ºÃjqÉb£æ.ûÞÃQMH½’¤a¸¸¢s ~œ÷ñ¹+Y’œË"qø•-`¶,µÊ #+jkëÈô^Fî7îÛAM\ÅÔe ؉ú~J“þbËmnç‡=Õ«~ªèaÓ?Çñ={öÚØØ|þü©cÇN{öì­³Ûq¤±"µK¥ëXC•Ÿ‘ ¸¢rÝ)zÙkϳنpçÁÏÎÛt¤Ú@p9lWHSî5thɪ±Ñ<›Í.š”iPI¿RrÙlUÑ!W(¤)ö›3gn¹#ÉM-$Q›ÿÉ×_Jc%„,×åg¸üKð¹üì{ÃÞ%eI/_jµiY5óµ×Ê«†'\‡Wu R–qpww÷ôôÄq¼Ì*W¤±"'ò¬c¥SÉ€ÑDåÍ»[°»çwiÀ¯“iœ‹½uðÒ‘z 0§ÓHd­/ IDATšf«V­$«TÈ$*Ûï¡LžÈ©Hc•‚ý9®ÖýO¾þRkÁÏ+©øÀPËvT 6ͰʼpHÎI1³?­Ÿ¹òÕÚ5+úê*ˆNÔ ’ HbyTÈMu_yÕd—]5Tײ§hii<Xñh+Ñ`¨Ÿf›Å¹_ö`Ö*xZ‰Df’ î:ôD²0è=$â&=lÚ¤}«{HŸ\Oîýè°¢›èuÚ“ ö»bmƒÍU«àk¤2µ&^ ·"0BÀNú÷«êËs6 ÏuqóÉcšY5!ÇëÀ0 üvPÌ2ç!P˜öÂuÉ ÖÄ=‹zWC@¨*¥m5r¬DCáý‘ÝW2Ù B‚3»}3bnSúølÕÎ_éÔ¬øÉ¨˜ˆ;ùÌñ^žåYyyç-´4¬ƒ¢k±°`“{oŽ•¸V«6­ÔÊ;œ¤#?9~ÃZŠ…ܼìì,ްªîFrIFÑt­»äZ;{›vd<>ù¶ójÝžæN÷7HÂ[Šv'š¾}^Ȭe–o ÔùiRùÌç]Þ_TUuªp–Ôhk¤±"µ‹<¹8<\`**qKîd•Lç-hÃã°Ù|@||“K•Ý&÷2ÒÅh€›®ëk.ÇÓ:­¯JÏü‹áUå<É¡ÒXˆ¿y4V=ÓcP˜ rW9 ÞŠ~Kc2å\)9m¿Ï s—¬q¡ƒ»¶¯¨Í§Øˆ5»³wÜ›ˆãUx ,4µÔtµä5AÊC&ÌRñ¹Š-zŽžÐóOzA&Wa5•Ôti¬D£#Ó™&Ÿ’gVay)ÞÌ4dÇ«ÛIù _+j“{d´ÿéþÊäU¡ÜýXJkmÍR¥Ž$GX³Ã@Žhäh™8XËl ¦o»´&:’p£åìU=ÈÂÆÆªåXkc㤱"µKÓÙóŠÇã‰\”P( µx¿÷Ú%&æ¿jœ%¡#ø{h:{^Q(”âY YjºZgR@M®‹ÆŠ@ žTjMkCv¬âÑÖ$ȱ"ˆšáñã‡õ=„†ÒXˆÚ¥‰h¬ƒ›Ö÷þ¤±" MGcmâ |¬Q‹ ÇŠ@ 5 ÒXˆÚ¥‰h¬ˆr4V ÃÆŠ@ÔHcm"à8ŽaÒX¢V@Ž@ j¤±"µKÑXoÞºYßC¨SF™’*AëXˆº£‰h¬½ÿéill\ߣøS¢¢¢:wî\i³?VtYQ®¦E‹²¤¦¦Vj9V(A¿Y)HcE j—&¢±6Ä.Q6]V¤±"uAÑX b—yyyK–, PRR’j†4Vâ/àS Ûî×™åV57Z½ÁZz+ÀmÖ£úî ¡J/÷VÚ½7B##ywÇ*H~ô’a0Hã/ðø¼B.•Qùö\ŸƒQÊÿpdTI"lmm###mmmCBBª´M!ZÇŠ@4²þ{ðQeðÌ™³Êþ³4n^¶ý˜>ämÛbD¯³¿¼úÂæ‹«ÜÔ“\¹ ò‰™l¯JžõÐÃÑyçÉ’KsÇM^v—„8M^™ÎÖÂ;«!nІEú-5”›©¨·h7ÕÑ÷·üѦ>:iiØMME­eÃykO å«*‹››[dd$DFFº¹¹Ui°HcE j95V®ÈüïêÉ,ŲU^;w—=EwêªÔ‘NÇ[˜ßºqã¿$þD¯3ÌZŠªžzZ·ð3Ä ÕÁä-{·üf ÇI€³>ôò/jòÆ¥Á¢–„ À;*N_;LIgÛ _¯¨‹N}ÿìíÖavìÏS_7Òíû\mlL¿k|<7GªYî—“},÷q<sÍ¢àCø<«yÃA5bÛ8ÙU’ˆ]¢»»»»»{ÙrHcE ê95V kÞÊ¢ mÊV)3¢»Pn^Ô¬¹ÞìBvNæÏ,6Y]¥Ðïü/û™ôQ$c¢Æ|Vܪ )Ñ}qœÚqê<¯cP–`¹®"ä?˜N3lÎy–'œ¦É€Üo»3¤µ[á8ÅÈÉý«‘CŠST{¼!*„-ÌçïY:mJw5P5½?p`g«Ms¤š[»®ÃuÏ™š“¯†…·iýÂí—MF•¤IUHcE þ~= =𳜫_@ “„MÑÀ~•›¶–¶–¶¶ “Ê+øoˆ‘]C?±W€´§Ûx³û*R€¡n5HÅùfPÂòu½ áÄuõœÿøp:ôÛ4»®p4\±ÅÂN ÐTL¦ª±|bÒÔ€¬×^ÁñVë½(W.hÖãH&?úAW(Õ†äo~“Ñóˆ­¸DËÈW—zÊõZò­)ZUÝž.­_ÿ9ȱ" …æf.›¨W¶¼èF0Љq‰{¡*ô \ª»ØþÜã£3Å…±﵇,Ú oa{å ¬ë§¯$wßÕÕ ¡­—ÿY°ÛÁ7R:ØO7Ó_ÓÁÿ= Ô€üï÷/\xÖcõ¦âXE|z™˜þóÍý ÛƒYÞwvIÕrò"³yBý¾ê⌬8X…ó03*¾¢*(íXÃÃÃeaĈ•Ži¬Dí"[cååÿç²12ßd¦'…L—^Ö#f¶‡O…R3¡üï!wgèüçìcºD¿™¨ðõ–Êdqmç(¼x4&˵ñîB&ïR%ÖÿcmpŠÉZÝIø6,«p—™¦¸±b/UÖÑ·löh>üDllùã¯GÎy®;ýéKj®ÊR-ÖÝ›IÕ ¹¿ =£Tø¾#ƒñ)WF•”ÙcHHH¤±"õ‹l•Fî0uê4xŸö"½½ùT‹V ä8/Y:cG@/Epsbýƒ>.²³j§ÂÄ)$çëÏÂ-Ui@ÒÀHØÏÄ;…8Þ[%2˜Ì(¶QwA︲%íXà‡ü¼ƒLúª  :q²Ëþ·¹›±CtÕ‘cµUŃQm«(à$5dàzý+@NÂÓUÓ&v¿ËE²–Âè _ ’…ÉRG% £YEUR]Túä•ÈgÊÖX‹–[a¢Î!Q››˜ 11ÒKWlÛÏÄdˆ‰éȽsº…^Ld2¤3#uçú=Íû›˜ Q§ ë½ç¤¹EçÒT;/ÞøäþÅÀ³Kŵi$N:G|ˆ‘N=Ôcƾ=ø¾ÃÜ¢»þ¥ÃZ¼?ðúÑ÷ºãK†“Î!Ñ*yR¾! ÒÞh÷U”‡žw~s$ËiŠ=Õ¨¤·ÿ•,&„7² ›Ò”QUƒ;R´ŽhpôYbü}ïÇæ‹OÎô¿sÐy:³Xf¥7k“Ÿr‘K”4fhõ4Ð, dwU¢ç~(u{k°²_æëƒÞeÎßJTÒyɈ¬wþÇÞfŸßQ²eN\]µK-½©?AÈM;îí_X²V— 0 JM1Ú®ÚoÖ|¿¹ö'ä1®µ¬ª pqqiYŒ‹‹KEÍÊi¬Dí"ÿ:V!ŸÃf³³’ã"?^wæÒže33º éÐRQ²=McÅ0åÁfó\¬­ º¶VUU¦`@‰ƒé<£uJP{Y‰ÇT첂T`þAÑx$™¢i/Vã}F´Ûߌ"iüáÝíì:ˆJÒžnZµïýœ}GG¨Ö¿2@ÿB€¿ëÅ´½›æ èß5ïë³-s׫u[}*y˜ªÝøÅ,o÷ò|-jñý(Þii+¥ }$úÅWwQÛ¥¶V‘Q2'éDÇϼ-ŽÓ€…99¿…4zCpdZËß>Þàà¼bÆÈ Ÿ®¬i8fÑí]ëD¿'ù™™™t–¨¥b«I‘9óýï±£µè2b“*­’Drë±cÇD¹¥—ÁÉÖX±””øò勎ŽîãÇlll¿ÕÀ'@4yÊ~¡ÊýŠÅŸš6Ù?ÃÀÐÐÐÐÐxi÷Öj’µœìÏ¡Ç¿Ç ¾´]‰,uëK°rsXž†f)¡ðôÌþw¦‡³,gå– ÎLŸs{Ê££åøyøö-±n]³r ˜Ê •6r I´ò—ú˨’?ѵž^;ñ¡ø²þøñ½mÛ¶€Ö±"õN‡™§^ͪð›HWëhí¸ÕÚ±ÜJŒ©¬Z6ÏÊÄ}Û›¯L:¸«¼Kß?ÅF8øfúÞ“~¾³"W€Š\§ìªši¬Dí"ŸÆÊ/Sò0ŽyGßúœûAÎ3~Å7ó;Ö‹&D_”ø ¨—|¬zÃWÏ­J{>‹—WÞªI Êh%Ñ“W(W@È‹A{^5ÊÉ€@ ˆš%aA ˆšAìH‘ÆŠ@Ô.MDcE ¨;ÆÚD@+@Ô"ȱ"D ƒ4V¢vi"ëÍ[7ë{uÊ(óQR%HcE êŽ&¢±öþ§gݤ ¬UäOˆr „¼´hQÉ#d•î6ȱ"„$òøÍJA+Q»4µÑ€ò±"rj¬éÏ®çv1k¯B—p~ß º¡°`Æ©–Nrðù¯³g ®ñ¡" ôžWyyy¢=¯”””¤š!hè‚»EŽƒŽ?Yþº¸0ùjÀ¿ ® Ê4æÆûî½9{Ö`7eÆÿV”kp¢ÐtÍ¢M[Xi÷ÞŒtÊîáR>É^2 i4Ð Áç`zX¶¶¶‘‘‘¶¶¶!!!d2Yþ.cE ꙬØï™ÑN¿nYÚ)Õ/4Áqªá•‘½7pUÕ©€“™ðò0Æœ¹áÖKêD2µùæÍ[ʵ©®VäÜÔ“\­¯Þ?1Óâ"cé¥#cÅmz8^Wšë½²§¸äÒÜqÁ '7ðœ&¯¼¾O“Ò°Ö¹§>:¹x•×ÃØ¯ ­º›·?¼ÍZöø.Ø÷Ÿwòãáø“5Õ°àææ&ÚM 22ÒÍÍÍËËKþ¡"¨]*ÑX žãœ‘ñ¼–‡î>ï0òA›ÍKØlž°<ëÖZYÔäkØ,‡6› „À{Û67…›ÿmãFwªB÷Uö–6Vc³xIûB.·æsÙ|€§žÖß-ü qBu0yËÞ-¿YÃq 䬽ü‹š¼qipÑ@ÞQqúûÚaJ:ÛùÚxE]tê[;IuÈýr²Åâ>އb®Y|Ÿg5o8¨Fl«p÷ä+«ç_Рòßñ ¢JÄ.ÑÝÝÝÝݽl¹¹4V ÃÆŠ@Ô•i¬¸ÿy¯‘c7ǽ=´-Þ(ò€)N¨$즽õ+jÑtŠ›ólNÇq„œÓgoy®Kºž×­s³M~O\¦&ùôôUKZQãù{ ¨4§Ÿ·êBJ`t_§vœ:Oàë”%X®«ùß¦Ó ›s^„å §i2 ÷Ûî iíÀV8N1rrÿjäâÕo(7µÁÖn ëpÝs&€æä«aáíFZ¿pûe D+Û¸0ýÎp›Ã$¬7jUU ’« ʽ¬†¡\Dƒ@Qo|èN³u󃶛µËû¨Ð" $,ìŠèßþúâÆYÉjÜ Þvâx3qaÌ“H1¿ùBqyÚÓm<Ù}©ÀP·¤B¿” ªJ8q]ýŸ…‹[+ýVTr4\±ÅÂN ÐTL¦ª±|bÒEUY¯œœV=ÉåÖâ§ B¿ùMFOO[q‰–‘¯.Uàz-¹œÆü;Sëæ C—ëÓyÅÓÕ*YøsÊÏÑ”y}÷ÅÀÕý¨jGÏÍ}µ"bìØªT`ÉMH†ž;möœÏ1Ï?OµÑ¥…YbÞk)Ù}Õnx Û+g`]/8}%¹û®® m½üÏ‚ÝF¾‘ÒÁ~‚¸ñ˜þšþïa ä¿á³«7 P.gzXpò"³yBý¾%‘=Œ¬8X…ó0¦·—jüïòa7™Ó¼Ì@˜[ ááá²#ÏnƒHcE jÙ+;ëÊ 37‚LÇØSgÞ3éj¨¸nÏËCž{Vò`ÉBÛ~ 4ÒΤ³Ùlr€ Ø.AØlA¯„j´j£QÚþóKaºVcàõ–Êdqwmç(¼x4&˵ñîB&ïR%ÖÿcmpŠÉZÝIø6,«p—™¦¸±b/UÖÑ·löh>üDllùï¥nr@{F©¸|G%âS®TËo—WÎ;+¸•èà a„°:llld&!!Ð:V¢~‘­±â-¦DE§+7ó¤ßfûÆöññ9‚WgŸä€f¿™$€GÉzÝÒ×^J4]9Åb€a8†ad§c9~Ÿ÷)ã©£ÔðœÏç¯|ø¿¡ÿoï>šÈ¶8€Ÿ™T @(RtÅ^° ²6ìر7,¨¸öŠÛÚ ¶·bo(öÞËbï®®eU°RQéd’™÷a †BÀԜ߇÷’ÉÍÍäl8ÿ¹™82ŠÌÍ'øô€X©BTQ¬|8Aµ)åø;6GdÌ£6™:ލ-6qÏ!ÏÒ[âv]ÄÊW)¤1ßI7àš8Àû¬<ŸÑÅJæÕò,/•$œ÷²mú‰H7KõÕT:Î:|óŠí™ÿ³¦¦â:V„¾/»¯iZ@–ùx̬[ÎvÍHŒ‹:|JÜ• Mˆ­Ã–5ès~Ûdµ_OJNg/Ô‡l>ÁÞäÀ'?K•w!H“éum–nzþŒzYuX»qlÛ²“7>‰à¿üÅ;Du~ég)Éÿ^~x•/r±â‘Ï%AeKv CgžKΪҢŒê°+ƒâåÂãþçl  È«Åj“_îÝ>¬Ë ú‚¡Rvùq’£¿%Ä^N™ÓŸó÷î‘ØyÙú­ƒªtXÎ[;§ÞÐp3Žú¯Òìû{ÕFAðæúå¡Þî\R‘õ)!k¬ûMÀ׃2gsÁíˆ4øºtMi˜4jÓF:ièŸ9—×ãù¥ûú¼/ÝWS?õEª@\Ó@O¹ÈþšægoƒÞ9ëvÿ;?ó#EîñvRUmøÿŽy¦+¯2´¤{Ÿ~AóÝ­¬tœAU@@@hh({Ù×××±"ô)të‘Äì 3â!ÃÈ¥²áµïÅ'¿Ø:ؼÿJ[šb€±k·Âm[ëþóùÛfôàpîÔöléK†Qì»pþê:·õæÃ+*YÆž<öÁÔSsêÓTbýF=؇¨áãz'{ü׎)ª9‰Ìl!rkgJ°cø£­äÛï1•C¬¹ª;v=<¾ò¸ªì–OwLýóåÐ?·{ŠK-è´yù—¡í¯¶zL‡”'—Æ u¹ƒý0m^ÏNóº>0ʲ†[;•sþ1òT¨ÛÚóŒ©öT)[b``àëׯïÜ¹ãææXœu¬€+B†¡=cUdÇ׬ìÒÕQü„ ¸AÏý'z¯Më{qnU •F)41ÿãÈ™Àžç?n»Ü;r%'iÊ[‚à°“ð "êØÞÖ”ˆO©±§wîü‡Qdä,K¯Üm´déœTÎoö¹KbAX}ly󣮓UöA8­¦Õ«™"•½’Æìú$]ݾ’PÈ>d¥¦¦Ð|A)6Qù^·®¤úù¯o¹n¿lMÏakv­ìÅÞ”‘””$h¸AV¯^Ý"÷ûcZfP¥ºŽuÇŽì¹D"‘Ú0ÌXú~q„•öœ;¦º¥iÇažn=$ïçup²l]_àð=Ëpí5ÎÀ™[X˜X45¹1£øÅæ6˜;ë\쎮”Ç]~:.ï ½Žý­Ö`¢ŽÍ0m¶¤•eÎÑœc›U—Úó ê‘M}¿WühYÉϳ†åµ{Çó'Ožè2CAÌÍÍ÷ìÙSŒ]ÅÆŠÐwá÷ð¤Ð[ô¨:ÿöýùÊ[Ižƒò²@ÜêÞ•æìeã7ÛMùyؽ†(/÷üsÙÖöS>t8ØÒY}½gA^=¿2yeÒÊË~[´téØ :C¡0cEȰt=+A*¤Ù”ns’Dî$ RõéH’øú¦Mw,ýûÂë¤çÏ#tÜá„;½Vï¨Ç§³àùXú”úo^Uð˜6¬(ã]GO,|ÔO‹=£•ì7¯tÊX B}1B!]¾±Ze#ÅŒ!¤wîÜ)í]ЃÈÈÈoŸ3V„ ËH~óÊÞþ{ùšVÉÀŒ¡ÒTê+*B¡0- ð|¬!dØXBHÏ0cEȰŒ$cE˜±"Tr0c5˜±"„acE!=ÃŒ!ÃÂŒÕH`ÆŠPÉÁŒÕH`ÆŠB”ÓXñ$,!ô¾ž„3V„ 3V#+B%3V#! ÓÓ1cE!ÃÀÆŠBz†+B†…«‘ÀŒ¡’ƒ«‘ÀŒ!„ +BéYNÆJf¬f¬F";;› ÌX* ˜± ¡P˜‘‘Š+B6V„Ò3\ÇŠaaÆj$p+B%3V#+B6V„Ò3ÌX2,ÌX„†Œ• ÌX2ÌX„P(ÌÌLÃŒ!„ +Béf¬f¬F×±"Tr0c5˜±"„acE!=ÃŒ!ÃÂŒÕH`ÆŠPÉÁŒÕHhÈX ‚(Õ]B¡ž²‘bÆŠBz†+B†…«‘б&''cÆŠ!`Æj$„B¡D’ŽëXBÈ °±"„žaÆŠaaÆj$0cE¨ä`Æj$4d¬¸Ž!„¾®cE!CÁŒ!ÃÂŒÕHhÈXSRR0cEÈ0c5B¡0++×±"„Aà‡W!¤ÊFŠ+B†…«‘ᦦ¦bÆŠ!`Æj$„Bavv&f¬!dØXBHÏ0cEȰ0c5˜±"Tr0c5˜±"„acE!=ËÉX ‚ÀŒ!CÀŒÕHdgg‘'cMKKÃŒ!CÀŒÕH…B©T‚+B6V„Ò3\ÇŠaaÆj$4¬cÅŒ!ÁŒÕH`ÆŠB„!„ô 3V„ 3V#¡!cMOOÇŒ!CÀŒÕH…B™, 3V„2l¬!¤gêkhhh©îB?µDÿÄ~Vª+ V•+W(å]Cè§óî]´ò2þ‰ýÄÞ½‹NKK¶³³®Ú ¥´Kü3˜±"„žiXÇŠB¨xò¬cÍÈÈÀµu!ô-(*×±"„A`cE!=ÃŒ!„ô3V„Ò'õŒ• ˆRÝ„úá))f¬!¤g˜±"„ÞäÉX3331cE¡o‘‘!e;*· —./ÁýùÉyyu(í]@•œ+䶆a†Qþ¿òrIíá‰ÉÀܼy£´w!T¢´e¬ÙÙÙlUù_åEl¬…P-æ×‰Â3V@÷põkWÅÆªjÝã!ãPxÆ ê!@ž«vÊú`¡2BÚ+¨v‚šÆÆª#¬BFJ[Æ*•JÕBUÕÏdŠô04õyϾ³ƒ|‡”Ê2ã_¥›Wvò.¢W„jcÅŒ!#¡SƪÒK™7¡“¦}Ï6Øúó·Õ¶N}³aöºì`‹Jcú×*èÁ¨ì„Õ«WúוV¤Y¥ËFÆw n!°W÷ù,93pFà´E®&éïn\?Ôÿߤk‡ÕÚz.mµnÔšÇG¦¹õQB?]3VÒ´Õ¾}U3VSâØh‡aVr9%WÐ £Ib½=>¼ #*ßkêÔf=ðÍ'ç6Ór¹œ`¨5C;?¨>âôî~rv÷NÏÖûµîܯõæß& šwåìB ˜ùúÎ?Ï–ùAŸ²²årÈr`çTdºtôàþý‡^|±Üpþȯ"~ÎcéLž9õXÜš+ÕÙ;Æ_ \tâéØÝWFÔ±›µUQÄ,…î³)¬IDATß-¸€OBÑS£¼üߌ¹PQÀÁŒ!ãTÔŒ•—¸{Ò˜½oØ›®Ø?.mëò·¢mÊs¹SëÔ×Á3¦ò…Vž\.lêtìnZþñÌ¡s^&ål[—EsÛ÷lçlÃþïÜÔC]ß=H@©™DNíØí£7ß×|Î?SV4¶wîìªc‹æ’;^Áá@zÔ?ûö…)ô<ä„\ëÖ=Å’uÏR×5µÌX26ÅÉX« Ýpv‚ÍXI.ÿáÖ¨€­aÕ„°v^°ký£dL®Ûlçæ7Á ¨.ÿ ¥h å_<¼z¹tÅšK‡gieùk•Ü™÷®¼Û~õ9IÀç›ïì=r‚n`³è\<4¶×q'ZÚqô².Ý{¬?¹¨vYQ¾[³¯ß¸Wè$ÎÍZÚñÈ—[#íZŒÉ½cÆÁÏ’š›ç›'îÐÐvÆæhªëÞ"„~JEh¬¯¶ö­>4 !ãøŠqÇU,]·‡äù·?Áÿ¼e÷£€ñ>4`mckËËð¨8˜(ÙXÙ‚½reßûº¾6&‹ªæé÷RußI‚äߺt„SÀ'^Œ·cyøwË”]üúj9fÊû'N”™>š¢åÌŸ9MÛWÍüÇÖF‘*cȺË)šJÜõÅá¼£P9χ»‰Ö ÅZâQ€VPì¹B@0 J^ÐhÒæ¯¿Âu©‹\N½Ï– íyìÌ4iCDê‹/òÚ–ZîÅw(¤ïär 3V„ŒS‘×±†uo³1ƒ#$ZžaæºæÈÒ_¬Z¹Ûkv†ß‘:Ù×ÇÜᬠoÃfJ¯v>)Ót1—Ë£´ñjož{0);ä æÚþ‡wálÊ>3ßÊ+PÄç³chY\È›ÔFAåÕ¦UE¨e¬Z‰Ÿó"™VµðÆñ[\ŸêjÃ(” Zɇ_.w0cEȸèz®Õ/[É23zî¸<±¬YüÍáC(€'r ]Ô¦gï uäû¬9Ý@”§£ÑŠä…—ã>sþx4m}S€Öž^š¢Y×fÉþG[z˜Í^öhÄÉ59®HÛ3gÄGŸYµ¬€Êx´=ì~þûÆÉä”WH0ò šeõkAj˜óï½JƒŽ¹;9Õíd`ðæ;Fº9*ÇDš9tküé3;Ùå«©i|1Ûy¿¾!}ûž „~,Ú3V&P=ËùVkYÖ&mÏ?`ë–ü;Õ~ötÃè´òC”ùô5ýÉì„¿ ÛaÅüË£ü[ý/³Ñø]m)ÑÏoÞ¾u:l[„…û–ݓٻÐTÂóçÏóß7SÁ(§å‹\íxà7kqûZe…|žL’ž’œü%99%9yÚšœ"•¦ŽS|è#˜”óu2'ï5þ·|Vî7~f§& ÄÔ‡[·®†l;ã:b³-—`wàÞÕ•ÇÕP«[‘!ôÐ~>Ö<«‚an®_‘nƓĿ§DÝ]»tñ¹wâ)kµ±x<Ë+´BOoï>=½Ä\2éá®ÑÛßùÝX®œÙVÙ¶³€93m,|>‡Z!—ʤæβã‘˦Á{/¼I ª:˜Q{yíž;¢öÃ.ïÒÊ„$(ŠRÔ68¸mþ'°!pFy.ÃŽ†mYvèò£wϳdr.ßÄÌÌ̲L¹r«›ÐrŠ¢‹T»¶ƒ%Ë–~ô)“{”=hÁ—&!Ü;yãB‰œ_¶JÝ +¸;³NËþÛ• [ÜÌ–¢(µ³ÖbÆŠ‘`;*‰‰‰"Qže.]:ߦM[Õîí?9¯‹•€á‹+nëcßgJàøž–¹±éóð°ÿm±z÷B’¸4¿÷­úËæuËYRÅÐnÝ~õ_RrŠ$›RÐ4¤ÀÄÉ¢O‰>é":4ÜãJ¯!Ê«ß@K¥Àä Þ>æJ÷óë½!ïùkïß¿‡?Í‚1ÈÈHµµµíµukwÕ €Ê’Ð|!r‚Wy:Å5×ò1ýü¶¶4ùfïž[¶\ØáÀ/ä¹(¤ÑÛOžvê@Cs>ä= ؃°±"d ”UÇ]Ã0Tù8‹#âj ‰¢žZð;Ä7ߺðÙ•Øô¥½Ziyeï4Ï•›ñT³h<Ï5BÆI[ÆJQÛhš•ß¼"#j6MFôèý÷ÃBGP(Ê«Ê ˜±"d4 _ÇÊårs½8*‡`øa·.ØÃüœ+¸Ž!cPÔu¬jkZ±±Jµn!㢭±Þ¼y½Äö!„~Ä›7o 33“Ë”öÎ „ÐL.—š™™öŒ!„î”ë¿Ô!„¾7ØXBHÏ´­cE!T$yÖ±’$™––ö-Ó©­+R½ªå&=ÞÑp ½I;\q…‘(_¾¼@ å¹Bé f¬!¤g_3V„Bz‘“±"„ÒŒBHϰ±"„žaÆŠBz†+BéF!¤gÚÎÇŠ¾[§N*í]øÞy{{«mÁ¢ ‹V ù‹˜±þ¸<==áë¯j¸`lT+pëÖ-/l,šÝ‹FÓ4;XyÁ˜‹¦üÀû÷ïk,f¬?*&勾´÷®¨ýµk|acÑÔèX4:/†a …²¿†a‚Ð^4Œ~T[ƒ‘Gúô±hjtyú´&Ê–äÞ~'T_?ÁÆú£ÒÒ Œöå®vAã,š*]Ц¥«gÑhš&‚ -옱þ¨ØÿpªMÁ˜"Xªê_ØX´ü -Zvvvþ·"6 0κ©æP@Ñ0cýQ±É—Ú1W±#žÜ#éÐ×Í‚_Ô;*¨O7n½tiÑÊš[úK÷T;¦–¸P_Eû9Z4¡P¨P(”ªì¶¹gƪl¬ZŠVú ¨Ý9¾ý…Dw7­½”’ 7–/»“¡{ÁÏËï6{ù¯ )£síLe7¾ 49hòÀ Í‹r²>]½_ø?‰2coÝNú^~Àâþ‚IË^§ô!²®9õï·Ï£¹¼ Eå}ø®Ê›C»1g%ÜxðQÃsÏ?aæwî&I‹û8ńը}<²3hû+åUyV„h˜PÌËN::zJ0 J&Ïy­ÆÞ»)èÔÇ××WöèN’  iÌŒ7«‡Ï^ð׵ɲxÿþóe&$<]<´«}çCGÍš³èð­·Ê‘ÉÌ~3åßÅáz}çTqÎþ}fÕñGŸt™¶dU¸ö1Ïœú S@p—¶³¢4üº‡jyYÏN¯÷íÛµq½ú.uêµíæ·éø3vûwU^ÖÃãóéÑ¢q“FM[÷üÛÎKª·þ»bd¿á•Wi*qÁÐ>ýG¯NUä<Zöq¦ï"Õç®eBŽPäTÂO3Ö•^âÂV³{Íé˜2 ahJþ*t¶iƒ@72#9êþßéEÉ ÃÈ)Ššaì뺺ˆî=„M(Š:1kxvÛ…-¬œjošÐÉoKèþNÎVÊÉï-þ¡ãЦf$EQ’Ï>g6Xµ°0TB\lôÛGKGzïlÖwãÚ{ɱl³´å¿ŽLsý–šè%c-ãUöã²gzpÞ½}ûêUd²M׉=+¨ÌA'~̶u0Í?ù³gϦ{„û-\1±3‡Ð¶Ÿ”œ Ùª$hÆÌ…WÝˈi)éÙÒüƒUË ûƒ.93pÆïS60Iãú™à€¾Oö¯VK{yK~äßý;ì_çʦÞÐÈ? ªÅÔXÿk•…œb×ä[2Ös÷¼Ž‰‰‰‰‰~û<õí­~#ªT©R©Jå*ÎÕÌØ§ÀÊJ<Øy`Ä£ësòOÞeÖ¶Š5WøþÞ?½ÌñùÍ•ÛcŽÏ»h2ü·öå•[x\‚¡3ßG<މa}QÔÜ6_Hæ´dÃX ù< ¹<Õ}€|åýpeÆ¢O'¼=ÆÅÊWÿµ•37çÊ>ú·¥R[yK8c=;uýµè1a—GÖb߃Åí|¯[žêè¿`q—V³—’‚ÃáCmêsôƒóŽ#«j˜qsŸ{ä¬Ö^­Ãáptœ°ÁøiÑž3c&\¨$(þ«KI—Œ—[µG]B/~9~h.ãÓñ@ÖŠéáúxfñ¡¨Éá•/­Ÿ<‹”ÙýÒ¬]£Çúöéðì G¾†?B¡U'HY)¥çH ©Œ÷¯#ßÇ›xzÔbo­Ó}ú…j5^8üªÏÐY‹Ž:, ’øƒó–^‰Ž‰‰‰Ž–dß1ån…Š+V¨P¡VcáëÛ—(»*Èq LêÔÊ»}~¸u­¹]5G³É»ÿ‚œ K½¼JÛVݳª93· æptŸ;ÄáâÑ'fŸúMe3}hî€í/*l=ºZÙUàóƒur›þõÍxºOÈ·hÖÝR²öqâš&ö{fy`c5j ­¨9a÷ߪÊ-A-h=Þ%<«˜ßJ±ŽµÚsa¹³‡˜Üâ×–Çoö²5!8œÌÞžàdÏ7EØ·«ýÑË4õa˜s¡ïÓ›¸Ø@ÇÆ¶Ó6F@)ýåûýñ‡ò²»%ïDRöhG³Ü 4ûiDÊǨȈȲɸI£“ß¿ŽM¢+T4{ñìKø?7x9]تv׿*ÓÆ]šùœÓ|§{Yà˜ÙWmÐʳGEQÊŸ×6¾vi;&3î¸{HS{¿~åœQ¤Ó cÅ-0PP-/£ÈØŸ qÜ"ߨ»àkc½ì·ô|ú®ð°Zyßž_n‹´k6²¨¶oh°å”XcÅŒõ¥—ŒUN3QGMx Rny‘.« §(͆€j«B.ï<ÉÃ7䯑Q>Ǿÿ E3IÿÅDe€äTù…–S4üû1KÜË\™ *h`…ZPHê‘þ_:ålõ­2·¿ (Õ¾T4zÉX £éŽÓáö¢¤—/_FD¼|ý6íÊ¿$1Ë;ú]¯é\³¢I\N˦5­TÖêb`—uNKl€¦4}¾-M¹?tF¸ÇÊs §(Ò¤Ù° ›(3V*ãù¨> Çm=o­2‰,ãɳ)CÐEÓ´œÊüdÖ¦øà©TË+ÏŠ’ÓŒ¸ž¹öж ò–dÆ*ÏŠ£ƪž%•æÙ=KúDT:%7% šɧ]sÿrq$>ï<ýfYߪ#_|ʲìiÎΠã„`YßJ²+B¡hV¤Ö3ÖŸ™^2V.IØ5ë;ªó×øoÃ.G˜±ZþÒGüeAä}2xOÎÇúo3åq+ßæÀ7o¼-dÄHå¦NæÊdCApÔ‚BYÚß4ÃXV²`·[8™)¤1jcФØ«<;öÀ¾³11ÑÑQÑïÞ½‰ù”‰ÚrÕ«Aµªu´íQ­Zu!Ÿ'¬xïz ¼?<`‹ Õ+Ø¥½Ý3ë|ÖÎÛÍ4î3M%.öõ'ÝVz9©yò¸[^x¼qÕ{ýZ¶ª²3òE sÊþ5cU¬9)ºÖï<Oµ¼òA¤¿–ðj+]Aå-ÉŒ•4-ODò“TŽ«ú‘cÊ£d’kiÎãIפú®#k-Ÿlè0Îo½ók‰•#c¤ Ór"6`ÕqB•3QHcØ{}#ÌXQád©Ÿââ¾fyºÐ¦L8›pÞ7œê) Ùwkô Nþnõ[þo„…4;­ln.éÀç$~.dñàÇaÁñ+oÎ^•&J9|Çb?‘oB׿­VµZ‡&^ÕªU·–­é<ºìÚe“4޵mêš°ù1@½wŸl¸ýWM9rúû«þ#§=å{] ¨u4 8J«g©ÏÖœrt_ ¶ñƦG˜N—çv‚¼å%9bokáÃ×À§ŠÚ](x¹_šåÍE¢î6&W.þ ê«Ýþ ÉÌa¨ò*ß­š)Ü&¬xwòðu.†Õ3ÏùöŠ=Ÿ“”(-ê„Ò$É+¹×±;I\äcI”¸¦µ¼;ÖË?øýÑa­Ü›]gªµ´àÇœš¶{ÿ[¶—Œ ÷½Q‘Û–kˆøé‘éZ7íÝÍWËzÎoÛ˜R_¦ ¬jh¹‹ápøe7¬^:eÜð®íZ;Wr´rì’õåDAï0¦¶½%Ÿ@³yÿìWUíV…ìËÕƒËÛyKröÙx¡e ¯å^$yÿ ²óþŠ;õký&;lî€ ;¤;wÏd?àR+ïØ;¼X±ñv¼êNBïSr^Ê äY¯.\¸À(¤ ñqQ¯>uǦ‘Ï®¥ÞÊdðÖ啯UÕj¡Z(8cÕ¥h„IckúãíäÌÆ"Mßñå”sáD?L‘¸˜ñ@™í½¹t0ôÌùË×ÊÄU~[6²cm( {åZWÈú|dÕf{'kMe&INNI¦LzΚP“¡%ÁCûBëY,89e¸çßí±™ûî³s*qv£Zy;­ò¿>`õobÆÏèÔÄULÅݺu5dÛi×›,E) *¯ŽESËO”©tQ3V(×~ùÄ‹}þÞ/kj@׿."yÒ£+—®?]§û¼ßÚäžç”9ÏÛÿþnç7x¶ËÑ…= V?§aèq5uŸî^ûTit5½|W—¢aÆú£âóùLÁtœ„C@r¹\.0ò#£Ä–&et —ËåÞ¸qÇ\,Žyø…#äs¹9ÉÉÚ:”€Sã§óû¬óSYY)ršÃãñMÊ® ê:ù˜tBs3áÔi¸dÙ‚/Œ¯Sû_,_¬Yó‚ yV¶vöŽ•m™Þ©YM屚Bš [áQž}¬b`òFÌ_غ­‹É¹$ª™Xà§½éÉ/”«ež‡0çF&›×™»)À«©sÁŸçXUX1Íâæ¿"R3ä4…¦¦f¦elø\.Wò1ü&åu8x 7÷P·¾[¥(óÞ!ýTc©•F¬<ܨåºÕ{÷ûo\œ©àýRµÞ”µ‡}=sÖT^]ŠÆårUÏhÅžÛIÙaµ=OÍ8ÃVu9¾~íÞµ‡Wü'%M+T­>liØ0ÏšÊB»rN¿ˆ "w­˜¨îÆ c~›·{ýã›Ù•kç+Y¹4QîS&ç¹>!-ûoO‚lq+Gåœz¡­hz|T’´4Ý_î ÃÐ0gòèÏé™âª-{X hš¾¼qÅI2¤ےÊÊã&wp‡µ;<øNKûûy-°¬ânÁ¥iÚ̩ǥ£=H`hšá[xü^oaàùØMË@íé[NOÏ÷ð*;u<Фé¼f"n±)ty_ѽh½FŒ{Ï# Ú™¦ÇYpÔÏçè1w½û0t¡Iu‡Áã:äÛHӴЮÛÉÝT§è²ø`—|“ª•—åâ=~‡÷x ¥ÙÀg»°r *¯.ESëªÊré-\k·±»ºeh©œ°)°êTµüCöäÝbí2ìèÑaì0¾EÛ.Ëæ]Šû³ã/:N}j¾Iã 7s^±wX•.EÃÆú£*¨;éå^oÎáÃ0Ä¡3T' =¤z¿ÌLØË¤ ¼˜ºûäC(»Ûªù;»Îúàêåê¢}7ž<<=}í—Åg;|Ëë¾ØUcÑ*öó­Xð?u<|Šõa=R–בŸ7£%ø‚¼û¦FT^‹¦±·~KcUî*·XUì²töî>³ãÛnuÈ÷ÜóO¨Füùåã^úúï¥ËsÇŒõGÅ®.„|?ÜT´—;Á!i¹®§âpÙõ˜:"EM·,|þ>ùŸþÑ>òËË=+6ÕÅXYªO_Ë’LøÆ¢}”å]Ú«µö‘WöNÕRÞB‹&•JÕÞŠ@·æb8\‹¦ç?»“¶¢ŸG¡ƒ/†Nn»t}}SNþµ®Å¦,`Æú“Q ¿Û_ql9n€Ãlê ùÍ¥öô ÍX¿Û¢éŽ-O YPyu)‡ÃQ­˜ò“+ýæ•Eeç6²/@ßtì§×‡V{©àùX6DiïÔ÷‹VTªëáü¤à,öwY@ë[ f¬?ª‚^âFûº×¥QbÑÔèR4Õo¯*[‰ÑV òæHÁŒõG%“ÉTÿ«].í½+jO_ã ‹¦F—¢Éåò‚ŠV²;û½P{☱þTnÞ¼YÚ»ð]ÓøÂÆ¢i§±h÷îÝ+ù=ùh,Wœ_¡@!Tüð !„ô 3V„Ò3ÌXBHÏ0 @!=ÃÆŠBz†+BéÙÿfé î° oIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/datamove.png0000644000175000017500000010613213070106167016707 00000000000000‰PNG  IHDR$_~þ×ïsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœ IDATxÚìÝwxÕ×Àñïììnz$„^~4)Ò›t°aAA„lHQT@¥(R¤HU@)R,"‚ˆAª(‘Þ;BHÛ>ï›l²)F ä|ž‡G³;íÞ¹sçÌÌÙ;Êùóç5„B!î"TB!î6}bb¢Ô‚B!în@âåå%µ „Bˆ»H!î5Š¢ i:ޏ \fÿ÷]YkV+G¥ aøyëÝʯi’Þ' Ùq/I­Bˆ{1 Ñ4 Mƒ}‘1[4ŒFOtªUUÑ4Í´DÉÛo·ÛqØ-X­f¼<jV —/ ïqìØ1-³ˆüÒ¥K9r¤PUH¥J•Ç`0`µZÐét8ŽB_7RïRÎüªEQp8`ÿÁ«Œ>xûøâv礠ßEH]–k×®‘‹ÕO*¡èéD!¾C’rE¢qåÊâââðôôÄ`0è+’ä++Ûn·Û±Z­˜L&<<< Ã`0Ü·us·êù~¬÷¬”¿°´¯¼8æì{Î`0úLXXŠ¢¸ÕÕýp‡$uy._¾LÌëXÌq4®WE‚QX’äƒ$::MÓÐëõ÷ÝIv®Vl6‹…   <== uÝd·³S…¥Þ¥}e¯NNœáJ”_¿‚‚‚ E¯×»NÒ÷CU¤.‹Íf#**Šèèhâbc+âI• Eå % o@rüøq<== ¢H‘"÷ÅIv®ÖR—õêÕ«DGG“@… 8qâÄ}W7÷Ê’û¡Þ³RþÂÒ¾òâ˜Û¾ï*•+WÁ`0 ×ëq8ètºû.0K.Orùl6V«•л[S9C‰BÅ5Ibb"V«ooo×ï¼"QÜ:™ûùÊ>¹œ6› N‡N§Ãn·sêÔ©,ÕÜ%¹;õžúD˜ö®BnO¬yµ¼¼,gaØ÷6›ÝuçÈáp¸þét÷ßXŽ©ó‡t:žžž®>YˆB$CràÀ"""PU•„„N:•oW$¹¹º¾W°ÉŸªªøùùqàÀªU«vWê&;e»Óux§ög^Õ{NˆÌ¶7»Ë»]¹ïµöu§»Üsp•Ôc$%$ªª¦ßO %UhÔîÄ”oLù ¬†˜ žI˸q<K©Ê5¨ùr¬ØívW0–šŒ% ]@’ü?ׯ_§\¹r9º"9³û(û£­Øƒ‹óD€”Éã ÜÉ«äÛà9¹ZÉÎÕšÃnæÝi^¿ÌmÇæ·›o°q¿6…¸>‹9y‘«AE©¨f¡îì¬Ûv†¶J»•ïÐÁ+«T„5{'›MÛOPµn9ŠêíD;t©JŽê:¹þr{•˜Ý«ää“à©]'ˆù_ijz«¹j©‚ÛYiÇyUμ:ÞÉã.·ÇœÁ`p}¯×;»*UU±YnræèGþŶMkÙõ¯…ë~¥¬§kÜNú|‘f£Ò"Ø 0P£öC$7ãÓÛÖðÏÅ‹\¿~•ëQ8}ì?Ž=NDÇ™Ì~·=[†váäÔ] *™q_fº²žÿ´ÆÔóÎQ½$œßD¤Wê{ºî%ïûñÙHÒFä·º"Iké©bŒ|¡(üŽwÓ–wlcm¦«|²à ï½Üì–Ó™c.pÔFµ ÛŸŒ¯]⨱5üÔ,_­Ü®nl¦ü°Ÿ¶-ªb¸ÍùÜd9Íw¿›y¼EÉäÓ3íáêCÿ£y= —KÄ]ˆä“5^Œì]Œe¿¡s›Ê¼?b Ýß{„ªžS¿ÙÁ1](敽ný/0Ö«‚aßf>ÜÄ´µ0*¹«ã;QïÇØÌ¬# ®ïú¼ÙŽÊž)óžøã0Ç«T¢¡·1ݺ-±Wùv—ƒ‡¹>ûé·ƒØSm®Š·.÷mìN´¯;eÝÂíxx5èÀÍ?Vòƒõ¿mÜÁ¸?NÓ:ØY¿Þq‰·©„•®Æ‰å3©>ik>€·!eÝTOW`äi*þÞ„G¥ÝÃU©RDÃ[cú§1qd3‚ j¦W+Õ‚• _nÏ`#ÌÌøz{†ÛøR¯¦ø'6½ ŠÎµü›çö°_Wœýqؘ÷ÝTj\‰¢÷ÎÚ?¢—ýÄßæÇ…¸“»‰*R•šþ˜c“¨ó¢º¿G¶ßžª×q]Q)Ó¢5MÿZΘÍø¸uP–ê¸t›V mâŸ.÷Áa½ÉÀ7bÖ4Fx‚PUÉU½«ªJ¥Ç›1ÊšÒq{™¾è€ëïsq6bÚÃôTAJïõîaàÔïëùŒ– mWÌ9æ…]àÙYúó·®N€A—å66ãLI& ¬’®ç¶œÙ=9YâNóý72üοL:üÏ'ÃãÎfŽbþ¾³|Ò½)†[DÑ·Û÷i—m·Ääxß«ªê:Y§f~ÌÞv €÷¡Þ#R1Ô»é$Ÿ½Ú‘e‡Kðó_‹)jPùmd]Îõ\Iû¢~Îc-ñ_>ùy£kùg¬œ˜þ.‡ŒÎu6³˜îa¾è°Ü¼Î6Å@HH°kž¿>z’Ë~M³P_ç2¯Ÿ#ZõãÏ)ÃÑu[‘îx;ýۜõtzôzßð'×üc^Ÿ²›oßnèvÇ*9±$‡D€$õ•YFW$#†/ç¸)óŽ1¢nk¦6.·¿ój4>j]†þ{Ë?7¾'=BŒÙÚXÍຽ™¿¿^ŵmhâìx•¸Db¬%ÿFe4‡Ñ7ùsó†tœ't¡NÑJ¼Ss?£VÇ0홢™^­dX7šžöͪ¸­ÿê¿;X|éF¿U‹K;þd¥­¯¦é¨½½Ð;âY³é–„kØÌVÖo;NDýòlùòÚ4¡l)o®îßNеP/Çp/NQ½‚Öȯ;¯Ó¾^%®ýw°³÷J Mêx°í€‰š¾gÁaåÍQ?º­wô‡]7(Dþ}’h[&w¡Ð8¸÷4›üõ”nZ™bê ¶ìµÑ¦QÉ[ÖñMÕƒ}?îÃØº]ºNùÜ® \2{c޹„Þ艧AÁÓ3çõnŠ9Ìëã÷»­#¤Jcº¥ÚÛŽœå\ÝŠ´ NicAÞ^ðô,ÉÇwäÁ«™ñ,ëùÑý©úXαôçœW<(ç©f¹]¹nϰ]榜vë |üÛm‹Jµø¸‡óê\±(Ä%ZÓ߉‹:ÍÊM×é<µC†Ë8òËN4EeúÄŸSÏ@ÞØ’²ºœïû;s¼ï3ˆ®±ý¯¿ÇšÕα¿³-ÀƒC³ûs±Æ0&5ù‹.žàå.þÌÜ_ŸU+š§ôož0rô瘭ÎhQ÷†G§`/EÇ?ýjQïè5V o<ÂNÕJTL»÷nM hþáí§™²ãA÷@¯ÄH®<ÇŒcѼVÁ=xŸ1q½û›»_œÔ0žS»sêÔñÌøŽ”äˆBýÈ&ã+˜6ã¥Lï^˜»”IfoüƒSž§êUªG_~Ô:ÃyF½¿$éjÁ¹úØ«&üŠxrhÅ:V”mȰ:ÎøÉõû‰ªó?ê;§s¨ª«óÎðdjŽbì–X>œŽ^ïœVU@gð£J…”!™Ö«È™~ó˜ÿ{,õŸ ¥Æ39÷ú.>Ý’IWÅi¯V2®= ,‹f73yÒ<úZk|ÿú“ðúåhð` ÇNíb­5ÝþM¬ |ˆž(íÚ».EÅb3™ÁaãRT,{üÈÎËV½y™Iÿ£V³ª8ŽüÅ–=ÿãÔŸÿQ÷ã><¢ÇóÝ>%8ðË^4‡Ëfazñ‰pn÷ J¶jÅ­ƒ0ÇåÉW˜5¼1ažô ØšSæŒ÷§Cƒ+G¢8ž|"FoL©óÌêØ·H}üoü¢Ë6^,î~b^´ò µž¯Ç__\BÕëÑëõ—Óz÷ ®ÌŒQ•܃U½sã¤Ùy2‹whXbÍ\W'ßxRÚ> ?hM|x k{L¦³Î´U¡eí,³ò£è2m—9-§ª àå®3¿cè°ðùÔ $Ôöw­[\•7{UM7íw#¾âx³ún£Ýzƒ±k£yù­G¨”|hÞû3ª¾ z½î®ìû Û§åß-ÿ Í~“7MÄ­þšKF•>3öÒÇÏ´n¼¼«:S—?ÈÒÕSPS…HŠûÁþ<÷qÕJùqé¦ýgCا‡=_fÏßÇèÌ~8í›]ô 2š6ÿ J·Ükw` ¨N5/õ–„Š*».Yœ·Ë}JÑÁ×ʼ£ Œ¬ê›íJüsñì´=À[0ìŸ8Z=羌ŸnÂ’·W1‚Œz¢”³#7Ðïù&$^ÿ› ÿ&Ðç±¢<="_5ž×º7äé­Ô³þüþ=šñãþ£˜]'_ž{¤6{Ö®gC¥Úpm‘ž f›:<ÒÄ—~ßÄQâ­¢”,æKŒå^(Y,¥¾žïÓ:ó;LS.óExM^¶H†ßgVÇv‹Â« üùè«“ô^ÕU×ñW÷±%Á“ù• ü•fY9®wEåÌÒÕŒ9çúhðGÏc‹ºÉ…gÑ¢&æx.\NºÚ´¤Gˆ_‰ ø¥i×þ¹‚Á_åÀÞ8hœ­6–™œ–SѨW£T¦ßïZ´Œøà˜÷ô­OhÖø3Ì>m惷C2<.~šöÆÆíy²FÊrâ¯î@ï_…r©îŽdeß¿8¬Jªeänß''ĦNŒ5øÔbâÔ%\Ýñ"¿m€¶ÃæÐ;)ùôÂþŸ˜1vGÂ{ñj£“친@éÒ \»/u©È¯ƒžÂÿÅA4ðUxùå!®uܰi”3êѱ ¤üüúàì)Úô=·‹5°Å[©úæ\k6ˆÃ‰Ý¨ìí¼“»cÔlšN&H=êVždíë‡1tæ”F%Ò•YˆB¤~N™|0$?ªI>02;@Ö›¬±ò^Yïté­æ’Öåé_‰úž™z0÷k6E›¶ˆÝ ¨ë­±%ÖÎÔ`cšíÐønú2¾)QžŸn@Ëü\K=þS!5깯WIÙ¢äÏcNÿÇú›6jàú¬EUoƬŠFWÍßmXçÔëN_7¿-YÅ”=ÞLü¤&{WþÈáÐ|¨²q×).3¡+§`ô‹`üØN x{ £½ŸfD»ÐTuîÜ>ÿŠ|1®<ƒúÏáü_[!´²s< Eá·½§9c±ž´ 6Ó&N\ÇŸ˜Ö¿2ÿõ“?nÇ¢/7ð½Ée›‚}MJu?¢#oT%Ø­N4»™Sã28è)ò 7þHÈtßeVÇöDŸªIô›[8jªLŤܽ P¤zsuÑv¸9«w¨Òóqæk©7!‘_}|÷ÉäqŸî*Š„æ°²ú÷îÏK5¬BMï”äÑÕ«¯óØkÕY=m/Jû6Y.ÿ­Û{ÎË™ü_‹†[rñÍ3û¹1“›¹~®š™õs7S´N+ù¥¿þøgí:æócÞ”ÒnÛþ·Ó„=ÔÒí³¬ìûcæ¼Û÷¤éGRþÓè_ 1¨Ìzú ª¬Zéó6ŒÜBßþ‹éﳚ/-塨¶ª ª±8ïŒÿ„Ф «„ ûؽó"gÍ6¼÷lEïå¾¾+V;T4ûM]Êc“ƒ—|6}P§ÙxéÍÓE†2zÑaõ­†Ã|œQžç¥õÍÑ´È ÷KpPæü‹¢tÈðgå’C" ]@’ú9eÚÎàvɱտâV‡fþú4ˆ³§ºÝøÉß÷ê¤7Pk”dÊÐç(ë«'áò.lž”ñPÓlŽ/¦vgÉüßûñ×üÔ¤{Ö¥¤§Ž£×m<ì•&8R°ÆdêÂx4«¨¨k슼Jùz VÓÏ<Uò"qÍ5¥L†Û˜QÝh+7íÁLS—¿­bÁ?:ƽÁâͱŸ>Åy¿Rtmä ¼‚J1ilG.ù¤k"GÇ`‰»È€wS¦ß3Γâ†Xi†¢(¼Þ«¿½ÀE«æ Hôž¡TiÔ’wZ–äÜ¿Z½z@zö{šCß,ã@ÏÇ8¹lʹ=–RÝýܶÝfºÈ§³w9¯bÏED Þ‡ñ/%aÙ ¥l†û-³:ÖìàTNÛ˜òÛ ¦?‚ÃzƒÉ‘qtŸP¸–a=æ¤ÞÎÿQÿĺ>8¼SîṎ•2ºÏÏ’µÇèÐü4?À¡?Q¡Z%jù8Û¯%æ8kâýøá†±ÍæÛ³Íx®”g–Ê»öžÓr*ŠÂÅ¿2p£3‡4"@U0EŸfÐè<Ñ¿+ nD~uÿ¦ì·2ù‹ é¶/îâ^Þù.šÑž!˜r'ÄaOdÚ¦XúN,â6Ͻ²ï.,f¾éûÏ¡Ä[Õy£ÃÃLüå[6…•åê_Óyö•ÕŒÿ+ÅŒ*×ÿÇðE±èUçuª‡/~þx( žþøy¥îç쎵2ÜÏbbQÔ@×zO›lx÷M³M à &z¿×„LJ¿ƒöÒÏœ[û:Öà¼PŸø Z†åñ.áƒÝ|,]“ÿ–Q¨Ù¨ªê–åž|+;£ßÆÛLW¾ê m>x Uu¿…«ª:”¤åerEU]ßWxü¦+ΫԊ՜ïoøwñA"š¶s[†NÕ Ï@^xå)Ú4=À˜/63|a_÷+Í9«¯0÷y@çAÑ?t:=Uª•£kÏT/á~¢ñ 3`·Ä¸^f–ºN2­']^l šÓE*2BYæ½»ˆíúŠ<ß<˜ ÀÕ¿"Y”®[†áå¨|õ½Ÿ'ÞØJ±R>¨ÆP½ßž²zÞ,Ä룞BsXhßû+ÖÍÿ?*4…µg.`5èQU»å×®]ૈüõA«óÕ çMqwEF·)Åæ¿2v÷Uþ¹¨1û?ÔT?V*0{ŒsK¶ ™ÍÊ'erCç­m‡-C—·¶¦’gúýži+ ªªÒí…ôœ³ëÌå`õ«J—0O®%çE¨nÛ’£z×4j¼ò,+Rm—%îªÁŸ¾Ï5æÕ·¿æ£1Ý97{%??Ü!åì,Y{UUQU÷u>²šù÷nêR–¿è³M”¬3>F#ïô,EŸñ¿ñÈôGÝÆrÉ´ü¤¿»‘ëö•tìEÔkNÓõ‹éó‘•ÏVá“w×Rþ¹gèß ø–·%ö<ï~þ/^èØþO,5¹_Ýû¯Ë¬ µ(âÔœúy-7ª·¡q€1Gû^yüI.oû«ož)êAâõ<Ü÷+“_DÓ÷¡½5‡m>eVÌpʇ†óû¼þ¼ÿùøÖy‡5ÇË|¾ýw3ü§cx%弩5‚÷Wœ"DxòÙ¤‰¨ªŠ)ú{â=êêa Áq>ȵ=ÅŒ*‘׬”ß9 [‰v3 \Žùã‰û|/u†ÍJjsº¤þKu›×vÝŒj,™iù…(ÔIò-cMÓ\EêŸ!º® l ÌúdŽ2µPÙ?]f½>)pÈ,ÉOtjJR«¦©n%áÿI`ØÜâ®ä9{Ò-×äùJÖ¬Åôi•¸äðB¯W7(¾éžôªê >¥èѹÞ-ŸÏÚbèô~®rÛíö¤W ;²P7znÎ',aã5^èV¯¤Ž7îüQæmŒæZ5ݶË/´Ë¿zÏø½<ñ~<‚uŒü|¡%C=mhv,“óÿ‚`ÑoT~¥• Þ”+U„¨;8^‹×+áÚá¿Xzª"¯w,J€QO«͘øÚ÷ø—˜â^™_E«€¢SS¶MïGÏ0=ÓþŒcFÛô'¼ÌêœË(^¿-Óg³ìºø•—©Ù³-z½>©Mà–Ø˜›zŸ=hìz ØLTò$¯v«^…ƒçnâiàäµ¢ì: ^Þ|ðFëtíQQ@QAÞ¾5?±"ª(Kž G¯W(Óò1:­žÅkÓ÷2o@}ט$™–?)©5Ó>7íKïÏ€^ÄsìBz¾I•Ggd§ˆ[Øæ›ç2ø|Ût`z3+Ýß_‚ÉÚ•A­RÆ^Ñ4 EÜOú WŽ1üûX†Î¬èvìeoß;ˆ[y™š=Ûäù¾¿y~,kuÝØÑ¢ ï:½žF¯NäÔ†Ì?Ö–ö^$rr:<ó4‰_Céw7Ò¹TJþÔ±i“YxØyÇæR¼ý·³8™”T[£u[®Ìø˜ðŸ8÷¥åªGEWy«ú{°ãH¬{ù•”ò£/ÅÇmË0|䢮ø²±Syôz«üz½Þ­NãÞÀT#Óò Qè’ÌrH2‹Ò¶8&}ð5¿\ aú”f™Žsa·Å±ä§Ý~ewÿ…Gr‡¨i[<“?ø‘ˆöP/ £lêôÞ$wͼõì>m† ~˜ú§…I8mÆÃ¿ˆ[¹S?×ͬnl‰×ùá‡]|»é*t{ŒÑW÷óéæ‹ {³5åc"yeq4>|NeÒü$TQ ö„„øäº×ÓõѺ)uù;;Nû°ïº?ŸôLy Q C§úѺai^›»Ž–ƒkÑ®zßü´‰Æ/Õ¡MEçm^ß0"Tñ†˜tùÑìVΞ¹ÌÉ+~´íW™9ã6×êI|U˜öå.z¼P—½rË:vî_†Ö `ü—ûˆŽ6²¬þ­GîÍi½›-¼ñYZøéÙýñ¾Uýyª]1,q'Q=‹¸µKE1P6"dØ^ÿ\ü=ﯽλzR$ù„©èymôã¼öÚJ^çÉŠ÷jÞ¶¥>æU9Sš‹¯¼×“è·f³ëÄ%¬ZùLÝ»yöC?ø‰øº-ùªgetÀü÷Í<7z ¦. ïTµÎÔc˜cÎòƵ´Ô‹:{YÙ÷ïÔ à“y»‰Ž6²¼aº[ä·d¯Nœ{οÔ{Ì^a%íÖýïõ­,KúÔ£]o¼æ÷Aº‘ÑÏÕt›®ú°¯™mw–wf›RO^ΓÞfN\z„ž/µ‹;vƒoÇ”y{UäâÜ­ðNLËTwÄ.>ô ¥û™0íGÚñÛ9ÊxÐU¶´å—Qè’ÔÏ)Sw†É£DºF‹Ôìl_¿é‹wp-´"³¦=Â> zƒÍaæßC2AŸn€³øK§=îGŽF4byŸÊéNޤ+“ÌF«Þ)˜ÏW]ÂÐ3%k]¯€‚.éÖiæÎî]±”íZÜu•ëÔ+ÕøÕC1pÙX’y³;¢W€r”.º†gቆýzólUÿL×k0èPP1=¨^Ù¹Ývó5ÞÅÛûqpìæï cLÿᑪowèŒtïÕ˜ï¾ù–.:?¢®†°¾Š?ÅùsÐ)#–áõp{êŸÞLïiÞ|9 >Izùäy¿Î©³×Ø}ÃÊÁËè0ÛA™ŠÅ©W·!­›´£¥÷d.?ÏÜ.¾,[¿‹Þÿ׃z‹:VRögíÿkÀ•Þ¿P¼É3Dx]m"yߥx+§õ®ôzƒUç¼R6 œüs'åa0œŸ« ÃßÿŠæâI¿¹¸[â@[²—ŽM"Ýö Z¥ùɪ!°,_L}†®„ºÊ–YùÖü¹÷”ûÝ'½/MêËU9ÝïèxwüStÿ¿¥¼ñmYæö(îÎå‹eÊG¨ûh[fô¬å ZÂj5dñP+]Æ|‹Éò Ÿt)ïöˆàÄ®Ý|8õJ=ÿ<¯Ô ÎÞñ•jß×Iµï‹yòpß'å¨z ×»—¨zp®Zlj]«Xöõ$¾ÙbaøâÃ<ÛÐýJÖ››™>}QW/sõò"¯%ص?†—¦b媜Û“è‡> ã¡Uüv´(Gæ¤H‹Ò$w7ežLüÈ׸Îë®`÷XYÊ$ø¹¦ (ù2ãÞ½J‘î-]Ÿ½B)Wþ¼>Jçòq§ è3X~òÕVfï{(Þ´ óÖqÍQÏu¥ëHÉ›>éžÓºuä–h–\·ñQý ×nÚ1!2«U e`·P®_ºÊÖCgغów^¦Yû†Ôö¹Éw‹òتPjW-AŲE)L•j%Ñ+\‹µ`0›!ùÊÚaáàîL›·‰Ð.ÏÓ1Ô›öã{3yÌb:¾ºŸîÕæ‘¶UÓ+èt>Ô©]cGÎpð°JóWxôõ¥ÌÖˆ9Ÿü@d@V¾R ÕQ‰)#æÑyà9>óúªÿö7ÄyQ©lÍzu¢o…pª– qÛ§ïú8Ïô]Fÿc¾øE4%(©άŽK˜<]ûůH†½HHÛ²®ÏôzÊ”Á¨×¹öcnê]Ї#/ IDATQ`õâßÙoÔqé¼ …6ÿÉÀ¯ã=«‚szEÇ£W9ás‘óV¼ è°óÂïùtÍ5>˜ø*×W.gÐ\GÖq%Ô?/zU‡ÃfÇl±a6[1Yϳ§TCêù¨™–?Üï*3¾ÞäÐø”£Y½â¹*gZže˜5²›õEÓ6ë ~ØÇÀÑýx¢Zú;SÅë·àëfÅ{¹å»l˜º€á[M¼>¤]ëdž—’•}ïZ›÷{$Ú®¬ë˜ËݾÇõOɰOpþ;±¸3?¢×KØ2éIB2¸;að©@`±ŠT®Ý‚bÅKQ²TY‚¿ÒK¼ºŒöcYµf(‰?¾É‚» ¸5ã×$¹š½Cžäú¯3tÍI<é èjú•Ò¬§ë€anû{…ßÿ|Åí³“+úàÕl6-ƒ=’^ò³_Qh)çÏŸ×Ö­[Ç3Ï<ƒ‡‡G†·5ÍF¬CÿÊ·ÒN&ª”óÉ|Ëu–®=A·Çëf:ÍŠ¡“ÙÔ¾'ÓZeyݧ~YHÿíµøùÃ)œìvf³™åË—gX7{"ï¾û ûNGañ äÁê¥y¨NEÚ4*O¨küS‡O±;ò Ž^âô¦}ú>:Ôc<›¢-”lÜ•†–eDï‰ +Cîmy,Í åï?vð՚ˌû8*|=|:sÏ{бíC¼Þ¥Þ:v]åÊæ•¬ lÈ„Þ)ï Ñì&f}ò ?N˜!ë]ÌÉÿ5÷{µ3Í#¾P$íº7mÚ”«íÌëå !DNû±l$’C’?~Y'Wæ¹Ñ¾]û\/#u»¾Õ 9ùÿïÖ|«ï²²y½œ'm2y·:gv"¿IN·3¯—'„9éÇnSH‰¸ë"""²<í… ò|ý é ÛÝYÈÏ:¯¶3¯—'„ÙíDzC‘ïîD‘^^^™Þ¸[.2 r³y½KÝæ²*/Ú¤´k!„È?w%‡Än:ÎÂåGy±GöÏGîÇX©:E :Ù{…Dê6K¿~ýøâ‹/ðóóËpž¼Ì!¹•˜#ßò꬛,ü´1ÿáX‚5Ãé«ע¸Q•)„·ésó5‡Äÿ/&¯Jܼr–cÇò÷Îmlùs?Où’GÊû»M3·o7"¾ÛIßpЬ´ïÐ)Ãut]ð==Ã|Òœ<Óof,‹'¾Ìÿös,Á’ñÉ£FmJ¤9y$\ÞÈ?Ž4(æ}˲şÝÂ>¯z4 •DßÛRôøù¨ÄÆ™³ÌÚíôéÓ‡m۶ѧO–,Y‚ªÞÙ}r4žöö¢5î ½ŸûˆǬÂjµrlñ>?s3Ãe´7•gB½òl›2ºÍ™¼qçVñt¯Ï©ùêlÆúE&íófÕwÓ¥= !rÝeG®’ ¿"Ö®aKø›ù,_}õ¥3hñ _v­Ï)ÏRÔ¬^êÕkÐýÍG¨VÔû6¥qpüÄ%öìÞê´tjÄ5«{!mñÿñb—©;a#'ÏdÊéŒO'Ρk‘”uÛ-xó©÷é±zûGwãýÈÖ¬^Ú;ݼ:Ïx†<=U¦QD/wq2R¤tUê5hBûŽm‰`-O÷œ—åy‡ ƶmÛØ¶mÆ cìØ±wüMÚ\Š›Ç×Ó÷ùé5“÷Û•AÓ4ꌞʂ|>3Êù0–{šmÐgø‹ti»‘z~F{¿8šÿ'øè©J”¬-ï…Oßfný^¼4óV¼UÇÜ82Ÿ·–ï¡ûÌ iØBˆ\÷cÙ Hr“Cb2™X4å3ªö~ƒ¯VäÜ–9¬IlÃ; L܈µ0á§eÔ÷3¦#0™lLøà}®[íücÆkÔPzªtú>šfaáÂùnëÙg¥ºÙ„É䌟bOþÆk½Ôý 6 Ád2QeØ$æÜf[“íÕƒs'ñ§†Éd"öÊ9Ξ»ša¹¿Œo2Ænçû!u¤Å¥á[üfˆýûör芙ˆ¢Y¿C0bÄFŒ‘é÷í¿œÊtš÷º£æ E¼Ý¹ ^zŠ+=§3¨aÑ{¦ž› ]Âã¿6äµ§±cÅ[ì™ú"?_fÁo»#·ãÜ”%c:Ðfh/Ötý‹Ža^höXÞí5‰âÇònóbÒ°…yÖçæKI÷—úòû|V·xŽ~uŠòÕsè2s0Ëø3S£‡'žžÆ çmÝñìbÿø…ÖíièIyE!88ÄmZo‚ÞÃÓ¹]š!}Fòàॠ}ª& þïq.÷žÍÛ²´Í¶„ÿôÝyfﮃ§§ó*Ð¨Ó¢Ï´Ü †ŒàTƒœ²òžòäÔâ.Ìãé®3±kPùÕj<œ…sxÚ’,Dïd‰¢2yÃVt^*ç~Á§{ô,í÷ cÆœ»åò^~{(!ùt×LQ}½ì3š5íÇë+gLÝÝô™õ7ݧo¤®¿1ÛË+÷ôT®hÀ°îciûë(ö~þ"Ûì²nÜ£Ò¨…y"ßrH¬q»˜¿dÑE=Ø3á æ<δ“ ¼¼~)K":°dÒ86¥ÉݨØû-žó¦Aó–lñP‰hÔ‚‡Ã}ÀaT7nì6ϩ驖¡è™¼a;ª·ž ‡1n·ÊŠW×0zô­OýßFˆ^Çå㱆ö¤ŽoÖoIšÑ%(Oö\eVcçÕãõý_0ö›ct>–F98!Ü74+ö¶ÉæèÁtã?úXFËÉ¿PÌg?áá6·ùb-åëõx­Wyçü6VMÉ›j¼EÎGòwº€¦,ÙŽÇFô !à&ÅÇàÆ¡X­Ö-¯çŒ/ø¾q^˜ÄÙ‡¸â7‚q`µÊðñBˆ¼éDzCŸ‹5c·Ûñ¯Ò•eóÙç;ðÖ°Û±ÙT4¼áF•ó&°ï‘Wx®¸/FÖ¸=|³|?¬\X¶½Ÿá?Žæ01lØûn«:wÃLêë6Õ[-á ÿ÷æRÚÌØB©À}”(á¾yÑ‘ ùêÏ ì[É9⨀QQÐ=R-¿ƒ9…_¾šI«ßàùÎG6à ôíëÞÉž»–È£I9$vó)ú=ÞS‡Q<²jXJnIFŠÎf;¾eÝ>¿] @`Y_ìæ3òžŸ<þ sW"8Ü;éäQšîoÌ¢Õ³M¸jx¶·9ܨ#êª9Û󙯚Ñ#¤…ÝÓÝZlòD]Ìf3 6[†y6»†¦eü]ndv›3õvÚÌè÷ìG„¶úˆµдŽÌ{m9ÏêÆªëéá“­å%g3;Çî±[,X­Fyd#„ÈÓ~,;rù“eƒŸÇúd_”›™Ó£%úLàÖ¿ãáWï¶s]4žšÃY9àžhÏ¥9+éÙ <»Ï&Röíê”Üã‰ñjqÊ—/ϵ»‰­S?U¡Õ³Mr¼ÅUü<øóÐMx$›W§ÿÅàXYZ]Û±c‡výýÀ¸ýÝ)F£1Ã÷¹hš†¢€NUÑëÓªª ñw¹=3z—Lêí\þfOöXà—‰Oa0èÐ4_™Ç3?5aä Ãh¼a ÁI¿øÉÊò\åµ;“»Uƒ½^/‰"Oû±l$9Î!Ѭ,ùà9¦oÀÏïU§ÕOg˜½jÃÞZÃÞƒ[kú±k9MÃa1»-×tu ½¦äµÕM(á˲ñ7øüÈ:—?ͧç4‡±X8ìL&;G½ÌOcV3±RkvMÃf6a2¥ÿÅŒÙâ@sXӕ宥8¿p;¦×Rns[l¦c¬Y³Úýd £EÓêlþí"å^­àZÞå£4í ½¦}Ië@yŒ“Sõë×Çd2qúôi*T¨@ïÞ½¹qã†ë|Éí3/sH2 FR¿ýÖápþÒÄÿ/›vÞ ((˜ÓF.å»;qe‘ú@Nþ;jï ¾:j ïœ/(iÔ¥L‹·çc_¯O>ïo¦ö­•¥å¹ýSô”-[–ÀT#¶ !D^ôcù–Cb¾±ÅûËòݪ1&nAQTü‹Öcòü2<^{­ªîZNÚ[Âz>ö*¼¼€žœ‰®:åÃcÛòÔÿQ³ÿ—T ðá„§Ê;ص#šoÎÇÑ:ÌßmÛTEqË!±Åïç·íчsj×5tª1]YÊ=þ ãF£þaIïÏñ/VšˆÀÃLž|ØmZ€æ´oS»ù .›™Ô®¬k\#‰ÄÄÜÀ‘ª\…åÆ%.\¼‘­yE¡I“& zöìIbb"/^t}ŸÜ>ó2‡äV‰¦¦9R=Ò¸ÀôÉS‰‹Ç¬yÒéòy~ávDp­WX·îå ßÎëÜŒïV5sMŸÝ€D§/ÊÚµk#¿:r‡D‘gýX¾åx¶ä×_Z¢(`N5°æÅÍ#¸\áMÞ(ëŸùmïj ±¦SnÍGíKó¾èÖ ï÷©@±‡{òÐúåÌœ³‹ÐGЭˆÏ-·Éf9Ïç>#..³æÅcÃ*¥¯€Àö|ðà ]{–¯+ @÷¾fý{™/÷Ô÷oãÝh,ÍR~Þ[¬ÅDÖ·F˜Ú‰E#y#óéõzš5k†ÍfãìÙ³wü¤h2™Ò¼“ÿÿƒµ¿ƒÑÓ•'¢ómÉ·Ë[ºÍŸ×9$iæ¬lçíž×æõò„"'ýX¶Î¹YyÒÐx6ã¯?œƒ™o5ƒo¸•Õꇭ4÷pMê` ´ö;lÛùjÊÈ—^¡2}Næ#GŽûc7ŠgÊr=ƒ:²æ—Ž·Ýî'§gn»\h¿Œ¦UÊßrÚ#‘¿3`Â5&l”,ï$»ÝΩS§òe]is)R?÷ôòñÍ÷sfÁ­¶óV~^/O!rÚe+ ÉÍ»lRÓ))óSq½³Æ¹èÀbâvKõLÙ¹øTt`6e¤Pï|5n7ëŽ^#2òÐ-'½òß|ÚLúŠšF‡Œ7’ÆÊ•+ïø:îDIêƒ'£“ò½xçÕv”r ! ¾|‡¤ +Ýj0/faºbµ_ÉÑc‘¹?þø#ËÓvîÜ9ÏÚdò2n— ~¯Ü!Éévæõò„"'ýX¾ŽC"DN$w‹ÅbÉ4‡ân$­7§Û™×ËBˆœöcÙ!I>Ú¾}»T¸;r7lݺµ@ÔS^ogA)·¢pʳqkaa2ÊknäUIÏž=¥2…"œ8qú–ý·äˆBKÚµB䟛ÕT™B!î6 H„Bq×I‰(4¤] !Dþ÷¹’C"DÒ®…"ÿû\É!B!D!‰B!î:É!É'¿¬ûE*!Ú·kŸëeH»Bˆü#9$÷¨kÕ aÆR9°}ûö<}—Bˆ;OrH„BQàH@"„Bˆ»NrHDWï²B‘¿ý¶äˆûŠä!DÁì·%‡D!„FŽ’øs?Òöá¼ýÃÉôßÿ‘Ö·`ÈÊãRÃB!„¸­稡íx»Ålú¿Ûǯ£®ŸÍ‘È{ϽO´ßŒèX\žÛ‹%žä›±þƒgX}>^jW!„Y’«’oßìÂ.k%~ú¸£kž^œÍÓß5áÝgPû×)ëu\Þ1šAÓÒkÚ—´”Ûæ"û$‡D! f¿}ÇsH®í›Á7'Œ¼4w|R}ãɈ¥“øçù1|øõAfõ«ƒ‘Dbbnà0zÈs|‘#’C"„³ßÎj‰>§+ y°?ë×÷Ïð;¯ÐV¬Y×Êõw±YßBvŽB!2–〤|ù2YšîøñSRËB!„¸u@’Ó’ÈÈCYZ<·yArH„¢`öÛù:‰wšä!DÁì·óm!„BˆÜÒKäŸíÛ·K%!„$yñ.q{aaR ¹ 9$BQ0ûmÉ!" i×B‘ÿ}®ä!„¢À€D!„wäˆBCÚµBäŸ+9$B¤!íZ!ò¿Ï•!„B!„⮓’|ò˺_¤r¡}»ö¹^†´k!„È?’Crz°V 6l(‘Û·o—wÙ!D#9$B!„(p$ B!Ä]'9$¢@wÙ!DÁì·%‡DÜW$‡D! f¿-9$B!„(0r|õòã´{ôMâìZºï6 –¶{sÑb—B!Ämå8‡¤óÈ7˜Õò%^˜Ø…ů×q}stý—ìäù rX1™¬RË"×$‡D! f¿}ÇsH<‹µbñÇh÷îKüÖc'Â}Ð챌è;…Làƒ¶eeoˆ<#9$BQ0ûí|É!)÷Ô4Þªë˰îc°i°{Jw¶Új³äÓ'\Ó\ßÿC† âÏ›Ù;B!„ÈP®“Z_šû%E/}Ë ŸO¦÷ÌC¼³xaÕõ}ܹM|÷ÝJŽ%Ú¤¶…B‘¡ÜC¢+ϬI]iõÊdª¿¼.¥<Ýæ/Új‘‘d¹B¤"9$BQ0ûí|‡¤d³—€¯iÖ­¶<§w„ä!DÁì·e!„B!„â®Ë“wÙØÍflf&“Þí»Ë;F3hÚAzMû’ÖrË\äŒä!DÁì·ó5‡Ä®úR®\9Šøz¥›×H"117p=ä¾È1É!Bˆ‚Ùog5‡DŸ+U á¬_¿1Ã˜Èú²c„B‘¹$åË—¹í4ÇŸ’B!Äí’œæDFºí4òÌ^äÉ!Bˆ‚Ùoçk‰wšä!DÁì·e!„Bz©‚ü³}ûv©!„"£€$/Æ!·!• ’C"„³ß–!Òv-„ùßçJ‰B! H„Bq×I‰(4¤] !Dþ÷¹’C"DÒ®…"ÿû\É!B!D!‰B!î:É!É'[¶l*TåmÚ´Å=·MÒ®…"ÿû\É!¹µiÓMÓÐ4 Ð’þ·¿ šäò$—aëÖ-÷d’v-„ùßçf5‡D†Ž¿K'ï”`äþ H êö !„¸û$ ¹‹wR$©ÿ–€D!D¡ H$‡$ÿ˜L‰©‚ÜNàiÿ[ÀB@4ížmCÒ®…"ÿûÜlç(Š"9$w˜‡‡'îwFR‡ÃQ`ï$%š¦¡Ói÷l’v-„ùßçÞ*‡DQ‡¤ °%DòûŽn;ÃO‚Õ!&„¢À’€ä.K¼¼O¾Þáw7Êð1;n»Œ}#ž¦ï·'r¶þ+°óRb–§?÷'ۯɣ!„yKrHò‘Ùl&mþˆ]³±gúK ¶ÌfÌóµ°%f”•\ÙöjH}4 Õ£CÞê‘n¹v‡†æ°a³YS>t˜¹|õ†Ûtª1ˆÐ cÊ$–K ~~Ï.ýÑm^Í‘H¶ðéó%³º–s[†f¸É{Ïeéã Ñ'dz iZ%‡D! 7‡äæááAÚCxSü4ƒ'ÚöáÓŠëXå+ÜÅä ƒ¡isžJš×–ÉÛ£~ãÝ!½]ËÛ±åÌ8eâÚßëXn(@p´ˆØM‡ŽïP¢xQgÐbºŠ¥Ø$~_ÔÌ5ÿ_cûs©ãg4 ñuÛΫ{?äp¢'êìÏQ{LGIõoX{Æ7›Aÿi‘¬\;u¨â–#9$BQ¸É8$q§iÂâ¯?Å^±ÜÞŸæÍ›»ß]‰Q€mnŸ­ûéGbl®ŸÃª¿Ì™3‰Dí\Źĺ´è ï*üüó".üÞ›çç¦ÌkK<Äàï/ðùæÿ¥ÛžŸFÿ΃ïÍáܨç˜u:–WJû¹}_ëµw8Õò-N¾¾‘²ªì@!„¹&É="°j{4MÃXþ£]»6nßkPÊí³>™ÀÖ-˜ßã5ÞiÁß#·ò©×탄+;'a éÆƒ¾·Ï-±;øüD,ó[UäÒ¡|6f¯Ìjï6Ñ¿1O&0i_Ÿ7“'„"÷‰ä䟴9${ËW¬!ùqGùOPÕnÃàU™U«¾J7¿¢(îy"I.E[ð 7b³Y1ÅXQ 6» 4Í5½Í®¡iv×ßæ¢H£¾é–wxîx|Jö¥š'”Üš+ÝGq*¡%%ŒîùÏmê„ðî¬Hluƒ‘!„™õ¹’CrJ›Cb·)=z€½«VP§ñ£ÔðÕc³œg̘1.£þ€÷è侎%Ú¨àç‰^o@‹³aðD¯êAQÐëw@ôª‚¢¨®¿\1üL¨ëoçm ã–¢Þø§Ñë „VLe|´ás+í¶ÎÐ:!$|y ½þáä™%‡D!D–c É!¹‡èÔ@FŽhŒþ}×ç<üp«tÓ¯>}}†¸$š#‘Õ×Í|âÜ¡ÖX+†@Ãm×}ÊdÃ+ÂËí³èÿ>áßxo]ÛÉêÕÎ;"õKù²tò\xl•„} IDAT´Û´^ް›OÉNB‘'$ ¹• ’ZþõÔ“æ³Ä¨ï0ûµ¢xRrit¼ @ãm×fT¹eqûì—Ñëð)^‹ÝÖ¥|ò ¿céåwy.ÌÛõ±%ÊŒj,&;K!DÞ$’C’RêÕý6š¦áÐÀa³b³Û±&üGÛ¶­ÓÍw%v6›-%H™¹”ðæï»>;”h#Ü `³ÛAÃõyJ‰óvŠÆÖÆTXãÿaÂÁhžýö{Vt[ï‡m²à“<=¾‰ë³ëÿÅ` (ÍfKõb=gÙîÕ6$íZ!ò¿Ï•’{‡‡1Í{lœ'ï¿Éq: Ÿ/àÒ»Õ ¯ÏÚŸ§¥›ÿÇw^'ÞLj^ï¼â0ŸgĪs ÝPËõÙ¡x+øÑ«:Žxþùg?Q§ãPkºÝJsiá~ôoUwnÃòqà]ƒ·A¯¸¯·ÏkUùiÌGÜdÁIƒ¡íÞ|™r¯VE¯W3,“ä!Dá&9$÷°´'nÍabñ˜WùôÇ«LøîWÎÎèdzÏl¥S‡†Ìÿzþ~>T»ÍŠÙdÂ\¥6¦_²½{_ø*Ìèß½Kcõ_¦Ï‰$T9Ã^³/ãýhñËE¦Nýósàò6áˆ6½H?†+–®1èXþ»zÏ@ïºÓ‘¢DÇ÷(³`óF3¸Z0ó9^±0®Yxú2Ø— !„¸›$ ¹‹ Š ÿš™ðÝ7´(æ Cëÿv°y÷¿œ9Šã7ob2Û°;(ŠÕ`ÀÓË®^zìæs­ÉWÓ;£Ó.sqgâlôo.¡z‹âM™ ™7ïS®íŸÌ§¿ºc@+†ÖÈ_Ï1£cIÞýz¹kÓÒyTà»~t}jÕ¼ê@C?ƒ#B!ò„rìØ1 àÂ… „„åĉ£”+WQj&mÙ²‰† »ôÓæ^ä÷ ݽgŸ™ËÌŸçÑ©aÝ,ͳóÏïéÑqƒ~XL?cºòhšÆÞ½{hÚ´Å=UÿÉíº\¹ÒÒ…"_úÝÓ™ÆÉŸ_»v…ˆˆçÉ!É?ƒÁ-q¿³ÿw¼Bš2÷£H~¿À¾}giž¿¡Í„ÙÔ HõÓã¤íVÐ4åžmCÒ®…"ÿû\É!¹ÇeŒÜ E½Â³Ù˜>°Jwúdð¹3‘ý*„"g$ Éç äVÁGÁÍÃH®<!„9 Hd’ücµZRå‹@ÚñHRÿ·à$îå‘qH„¢p“qHîa;vl/4e•!„(Ü$‡äÕ¦M{©!„":©!„BÜm’C" i×B‘ÿ}®ä‘†´k!„Èÿ>7«9$òÈF!„w$B!„¸ë$‡DÒ®…"ÿûÜlç(Š"9$â¾&íZ!ò¿Ï½U‰¢(¹‡dýú_ UÅÊ8"B!Ä“«Ñ’OÒéßXË]i\n¤}ñÝÖ­[¤¥!„w2 ÉM‰ÉdÊä],éßmRƒ’Ôÿ•üƒ‚Oö¡B䟛/ãxxxdpwÄ=)ÈwHRT’PðÉ>Bˆüïsóå]6™#i?+ˆIFÿ/„Bˆ;#×/×SH{ÎVp8 n@’ŠH0"„BäW@’›³ÙLFù"ÉÈÕ£‡°•*O¸QÍ}xàHàÂÅhB‹Eü?{÷U•>pü{§¥÷B é½*E,6ŠÝµ®¢®eÝ]õgY]Ŷ‹}í(‚ ‚«"éZ !…´I›zçÞûûcB ZBðý©C!„hø6·ÁrHj×díÙB@«óˆ²@þöMx:õ%Õä$mÝz|ΧU¸­rù²ßñýžó˜0*€ŒµËÙãòU>ß¼ç:F`ß¶šU;ŠkuWöOÆwŒÎ Ÿ3“#‘„úuþ¨eÙä[âI :úõ5{x$ÿ é“:Bˆ†osí^6Ž´-¬Ùã#°¢ÃKˆagå΄¶L"Ø·—¥+vV¼ZCWâéÐ:€òÜ,{`øðáØ rhÙ‚è@3†Vʪ-ÅŒšv‘~d[yÝ=$†æ`ÅâŸ0‚±š(Øð-óçÁüù_ðå—óY´x +×ýÆa‡Z¹ŒÉ¢²fÉO˜d}!„¢ÑœöÓp«A(Üø=1QU=!…;Vc‰Âä84µ”ÃynZµˆö?©((JU€‘Ò™æ!Ed‰ kƒE‡ýk¾Co9œAm›3rt6-ø»G«µíÜ ÿÃÑv$ý;5GÑ 4—·‘ÊÔ©S™2ùÆF¼)‹ï¿^Bæïù0µbXó"–ìѱ(r@!„á´ç(!]8¯‰²ˆ8ôŠ«m<4£×¸hŽC{5ÀJH°MÓÁÐÁðáó© 1²Ö¬%,u!”³î×ïø97’ëÿ<¥8WX;.¦òõܹt|!šG ûì,ßSÎØ?÷Àb?H±Ç‹¦(æZ5coºkP$=‡M"?ý6æÒ¤2J}]º“?Á}®£(ω䜛¤…¢áÛÜFË!É]9‡Üìnºf†·_bîÃûËs(WM!ÙböwÌ(&Ìfÿo ‹3 cðãîRÜÞ‰Í ?aé7Af7óß~U­ê‰>?•´Õ‹Ñ.›B÷03å¹›0‚ºÒ?)˜ƒ;UÿúL  `:^¯˜Æë›eIñ¡8óÜX,­H XÍåÑ ²ùðèµ/[–üƒ¦OêP!¾Í=áyHª›œ Ã0ˆþ'¸0M7*¯ ž÷ìㄵM!fß–ßYƒBJ¤Ÿâ<+WÞz3=ð>{öI:Üó(½Bm(&Î^±´ë‚š¹‡Ÿ¶Ú i=ÅW„S7޵sä¥ÿÂK†Æ£[ùTëf¬Yz˜ [É(WåHB!ΰ걇åLl dó7|®ãðê€?8(tªDhõ›×£ÇÈÞ¼þéÜse/Š|v6o,À­ûtJJKÙ»?‹RŸŠ…H%¼>Š>‚E¡–—ÕX—¯üg^ýÏfÜ.n—“øV¹øš[m!k·§*Rkˆgç!‚âRA!„¢AöM‡àÖ½¸°GxE@â·ú³±™tŸ(`èÇÌ!±´ÁZö N§—E‹r82íH±j°yÑv«.|˜m‰Œ¾0¯ê£Ø§cÃWVŒÏç(4ÝÀÔ‰ z½7[ùgh2©Éfö§¥Qæ®R‚Lèj>&kW|>’Crî‘:Bˆ†os-‡ÄlÝ]F~n9EΪ9Eœºj€éwsH@±X‰±*n7‘ ÑìJ?Äо]˜û¯§é4í&ô•Kh=t‘†îàÀÁ|BÌ&ÊË5 › ‹Å €Ù¤ ˜#hÙ<]ïLó”¶,|÷#Þ.,åÊ)X,Õ.2ò˜L(¦ , ’Crî‘:Bˆ†osì^6µoªjq.‡rÍ8½zÕÝru0[bhÛ6è˜ë´o|‡™ qQL2c_5—Ÿ6ÇÓ'5 §®ã5À“¹w?6qõðŽ„<Ñ63¹.”øÚW2ºŠÓé`àÅ}øtÞjö˜ºÑN«êòy07ÃW+ÈB!Ä™uŠ9$5OÜGNÞ¡†pÉ 0Š«Íººd÷VÌ X[1°o(Å%.üù%Õ ªçM\ÙÙEHb46ï^>\›M×k®#&ºj«‡e÷œy,MObx›` 65Œ ÛÒ1÷m%Fû ` í@ïØßX?w ý§ô!¿¢''ÓAäðdtÍUç{B!Ä HN%‡Äí®C¢jþßÞâ\2;)*.Å`!_Õˆ3 4Uå@Æv²²l”g»À¤€áCUU40ÌàÌgÿžö}?RFsqs »öãÒCA×­ô½ /ßnH#±W.' y*ꆸBnBUKý!H@áQÁ€†ªV%ª¶Ø…}kÒùÍt jº^Æv§Î%ÝcpÞªJɹHêP!¾Ím›ÍZ«'ÁlRPPÀdÆbµ°~õ2ܪ[TKú†à6›ÉÚþ9N:]–Ff³Ù›( ˜L>6ÃGÑ­]_ó ïm.ÂÉy¡VÜ&3‘í˜0.аèP¬….Ìæ6ôÛȼ]6YͨÄ÷Å•‰mðzK0›«nðgŽèÄe—¦}b Åj »7/Åš8˜~á62i˜Í¦Z½#’ÐôI !D÷¹ –CRýÄmqý/ãÒæqàÉÀ0`ìe蚊ÕlÆç)#KÕè;úš·O!ÌfA1tì™ù†A‡qWöŠušÂ(?¸¥ónÕžvÑ蚇4Ÿ†a€æ.bGZQUÏÇ~ìZ0‡ð.à•×߯×{˜|íe¬Þäb؃ÑÊQêÓz_2d#„Bœi§% 92lã"L¸³÷±­òù´;k-›¹gw­Ç“™Â´ ë•a€¡ùç qÚÖCÇß“-‰ –²/ 7N™Jçó»Õë}l+ ¡«@2vfÔ F$…D!„h€€äÈØ¢('œC¢ªjeë•AÊ‘¹’Ö<£kÚ)½!kl Á/¡ƒ_ÝX¯e:EÃŽÍ;j[ÕKþAÓ'u(„ ßæ/‡DQ”Ó“CRs¾óQ= w•ŠV~˜BÀd:Ù›éñ¡VÙˆ¦KêP!¾Ím„yH¨3iš—Íýž„Bq&R@²zõJ)A!„Bœz@r²ó 2üUP’ u(„âÄÛÜ™‡Dˆ¦DŽk!„hø6·¾9$&)2!„B46 H„BÑèNé^6B4%r\ !D÷¹’C"ÄQä¸Bˆ†os%‡D!„MFe@¢(Š”†B!LõØã¤sHV­Z.%yø£Ís*$‡D!¾Ím’Q£.¨ã65§‘§ÇÑw"^½z•äEœ)+!„hø6÷x9$%%§é^6u#œé€DÊU!Ĺæ”o®w¬€¤úÿB!„â¸É©ÌCâv»ªÔ8Qý[œ–P]7N¨®„”•B4F›Û 9$Ôì© Lt]—’3”†ÉdœP] )+!„hŒ6·¾9$2É Ø½c;n],!„ât³4ÄFìÛ¾cƒÚ‹Ñ=bífm^…Ú¦­ÃmØ·-cÍr T,ƒˆuýÂa¯îLõ’8r<½Ãl5Ö±uãÚô„¥¼Wi&é9Î:·Ó&…kÍXÏç̤ÀH$!¤~E®–e“o‰')È"G©Bˆs? 9•ÇñòGª'`ª.'.K,­âÌìËqðNî\·‰v}ÏÇVçäm^— §Ë…ËíÂírár¹p»Ýxõpú÷M (ÄÌòo¾'슑DtȘÞñ$‡Ûp.äÃe±Lœ:–B-–`“‰ôÏß`w‹V4+Í"Ë«UßQññxJ pämaýotj^3ðÙµƒö©ÝHô9pVô¦š“‹"õÒ)*.ÊÕŠÀÇðñ¿ù_bí2š ;FÔX®¸X½d-“.ˆVÙ+£ptB«äEÔŸ”•B4|›{Â9$Š¢œDIÕsHtÍÁÆßv‚¡áÓ´Š<pváR~bñwör/𮡨:3t@Âq×oèÖ®É 5º„~ËçŠ~ÉhhÞ,–.ý ‡ÓÃéÆd $,,œ`8”y˜ ¨æ¤¶kAbt"­Z6#+»ˆèö¹ÄüËÖÛ™{Ó·¬K wËþ÷ÍjÆB»AÔ’¡…äi½9´k“Lx ™¢ÜLr«ö,öÛCIIððÖë¯qðP)­SzÒ¯O"ŽWÞáß›Zž7šèæ¡ÐéÓ·‰ ñìßüC/O˜³„‚í›ëU&ÎÜ_ЃºÐ7!ˆƒ;«º­4o6K¼\= -ZZß}ÅmÂȫ6Dd¶%“bó²´4œA&7I¨Bq®$§?‡ÄKV–ƒ’=kY´!ƒøØç—ÑMGs—PXè¨s]e¿°|·‰ ·M¥GD.øˆ…߬aìE}‰0Q¨”¸µê¡ùþýôØeWy"÷ŒîùûÈ,¨¹ÿ†fg_zÿ 'Ó*ÑF—Þýh–`á­w×3íš (±çl‚Ë®¿…HŸ¬6ìùÙø|þ )33Ÿa 9é{((PñÎç¹̨>½r[^·FœºÏ‡Ï§‘¿¥ˆàV£Q|ù”z½•¯+Ú²kX/zFZÙÖ£%¥K¾Ä˜x¾ƒ¥5ö½E|?/=Ì£!½Ì‡äœ<)+!„hø6·æ!©™CR}’ö1öÖ‡Ú6’M³^`‰“‹ÅZk=‡Ó~âÇùŒ¹þfz&˜Ù·;“øÎ0Ô÷=‹—¬ç¢‹b1›°Xê¾J9s‘Ý®&!ÐÁÎb­Ö64ÝGII9&5ƒ O][¥³`Y&àE÷:øtÖ§8œÊ|ßÌþ Ãã"²ûpúÄÙ°X¬†’‚ÃøPøæ½s¸ÀÃ…) ‰c¹û†8 W2s–‹ûï @Pd»‹n¢Ä©Ò1µÜYµ_†Æ/{JI?ÝS€݇Ónì fx oµŽ„ <;œŠÅUŽäœ<)+!„hø6÷ø9$œ¹ð_=â0Lœ×2Š»Ò(·(8Òwc²v©õZÝ{˜å¿f1|êm iÊÁÝ*†&’ºbˆi9 ç}ICèÒ&¾Î핪uˆÇSXH]ƒf[ý¦æYÌ«#hÙº9]2„äX;Ï¿ºŠ[o» ‡ÃÍ{Ï=ͤ›o%Bu¡àÎË"»4Ÿ9³¿Æƒƒn£®¡gó(r¾z• ¤8B­.r½mÐÊg£„Œ!ÿ`!¡Uôš”ø4bÐåU=KEë)Puz˜2ùyE…n„p+{–¬ éÆž(®êI±„ZÐ}˜¬@¹áB!ÎIg$ Q ýZ†ðï×Þ¡cBû·Û!Ì!@Í!“­WN¸Ž®£ÉÚ»‡V=¤PHî2‚«wóõ’%dææâíjm/Èbµ¿-\;v¤9È-ô ûTÖø9?ú‡›¬ŠÁ /¼€ÇãC3ðÑ+/¢z½\qÅL–(ÆO¼‘Þ½Ryþ¯Óºe<¥¹Ù—å$``0>—Ÿf¥k„™ù[| QQ«½…`³‰òrº­jX'ý§XÚ“¹m ·ÛD…Åã9°ÍAÉ(.¨êÝqi˜”p“MŽV!„çn@rj÷²9òºÚs´|mM>ò Ü´‹,䇜ö†ŽÏç«c/|lß¹]ÕëÜŽ9¢-“®‰ã€Ñ‘vͽ¤(¨ñ|tçŠ~ù’ü>cë^ÿ‘“»æRê;m"-I øðv浚!·ÜF+Kïþë]b:÷cøÐ>Ęع3 ¤íØŽªûsHœ¥¶—xˆHÆç(ÁçóÑ®¾Z8‡17]HaµË€#­& r]ëﺚÏ/Eοó®J2㨖³ð•çYµ¤ˆ)=t *ÊÂYàÆÔ C÷¢ª*ÕsvN¤®„”•B4F›Û@9$¶£òGŽžÍLó$ƒ¯?Ê¥û ÍÐ=%X,æcta€éXÏùOí´ pQ^æ®µŽˆv#è´ÿ+Þyo祦Ø,šˆ°pŽš-¯ŽÏ™ŽÃÛœo?™Ë!GFŒ%9@!7½aãG°ç/¼öüzC§¸ÀÊméGîk§€æÞC®/€)Ia¨s°XÌ„6ëO˜y|ø]:µâHhß)œ_·¥céÛK™†}ç°6cR«pìûv‘[- iÓ%Š-æ2v2ÅÙþž¤¼,'QÓ1t‹¹VYK^DýIY !D÷¹õÍ!9¥{Ù?1(Ï?À¢O¿ÀÚy ¶‹ /ËQk™ùñ¹KÈ-öÔ±]3=G^ÁÅýÛQ¸#ß.ZÀ_þ„I9²?:Y;fñÏ*ç·/åõO¶áÔc¹tüº$šÙ¿m3YEØ>"[ôdT¿v´Œ¯EÁ0 ¼N>ŸÕÃð°æÛ_‰HCœU#×ã«ÜNÃ/ 2-ó~üOÅÍCZ‡j_+$Ã0HË4Hêy9fÃI®ËWã}„¶íGD¸…Õå˜1Ð}¥ìpê ìƒ'ßUgy !„ç‚Ê¥ÎiÙO> ѼùüïÇßHé7–KÇ DÍ?H¡W;ƒoE!¢Y{.Ÿ6ˆˆ@·ââÌlÛ‘‰¡•±ak!#§ÞÀ ödlßĦíi¬_¾„ÒrªOÃ0üW™ÍþŸ€ƒ { ÁZ9»–/dy¾³-–x¥ ¯5‘ë¯ë‡Çž‰Z}nSC.¹”½ûºµoΞ}‡0l-é·y», ²ô½hÉí“)/8„~tPaŠdüø ¤4 ¦ÌkfצµXÓ'ÜFÆ!¯#B!Î)ÕcÓ0 5‚‘Ê%‚ñ&Ò¥k+ ³ö“SXÖ o® '“Àd±RXlªÈ) bìåcéÜ6Œ;wSê ¤}a Ž‹$0À†ÕlF1)þ;Å™_×ÑuìýÅ$޼œÛÛu¤Mx0ŠîdÐÅF9{Ú«Mé~„•¶í±;Jq«þ|––û°kÁ¦ çÕ7?¬×û¸æªq¬ÚäbèõƒÑÊ2°{ÔZA߉ԕ²BˆÆhs$‡ÄjµÖB޾©žaxر-ÍÿåßdjØ’Ð5¼­Úv5ÒvîÃÐýû¢»KÉÎ,­WϋɤP–¾‡­Š vHzÚPL˜êìXò’å­Ü¶)¨9,gP"7N™Jçó»Õë-ì,g@›@2vf`2™*ËVQÀ0”ª+!e%„Ñæ/‡¤¬ì ÌCR;9û†ŒSœzÝ0ô“¯˜f©„¹|„˜Ø´©~ÓÎw‰3‘VÐU†G ȈBˆsÍ)$¿|H¾CMÞÒœ£nŸwÂ%^9®”«Bˆs* 9•UõV» =Iõßât¨]Î’QRVBÑðmnƒäüüóORâLò"¤¬„âlnsO8‡äD/û5ê")m!„Bœ´ê±‡IŠC!„í”rH„hJä¸Bˆ†os$‡Dˆ¦DŽk!„hø6÷x9$åå%§ç^6B!„§ƒ$B!„ht’C"þ0ä¸Bˆ†osO8‡DQÉ!ç49®…¢áÛÜãå8¥’C"„Bˆ³‡$B!„ht’C"þ0ä¸Bˆ†ose!Ž"ǵB4|›+9$B!„h2$ B!D£«Ì!QErHÄ9MŽk!„hø6÷x9$Š¢ÔÎ!±Ûí’C"Îir\ !D÷¹ÇË!q:Ë$‡D!„g H„BÑèdñ‡!ǵB4|›{ÂóH‰8×Éq-„ ßæžp‰¢(RzB!„h0ÕcÉ!B!D£“ñ‡!ǵB4|›{Â9$ÅÅÅ’C"Îir\ !D÷¹ÇË!q¹Ê%‡D!„KrH„BqV‘ñ‡!ǵB4|›{Â9$%%%’C"Îir\ !D÷¹ÇË!q»•9$)2ñG’}X A!ÎBˆ?Œ»6ð2†q¼gëH7~çùz='„À€DrHÄAÛ¶)RBÑN8‡¤´´´rœ'ýÀ®Óº3Çÿ–yßSý¦)ßJ…Bˆ³A`` óØ9$;w•RB!Dƒ’yH„BÑèêÌ!B!„hÇÍ!B!„8ÓªçÈB!$B!„ht•9$Š¢H‰B!Œ¢(µsHÊÊÊ$‡D!„ ÆëuI‰B!Î!„¢ÑÉ<$B!„h4’C"„BˆFU=‡¤ò^6ŠR÷ç¾ÿþ[)±&jÔ¨‹¤„BœµªÇ–9±†a€Qñ75þçHݩիWI¡!„h2ê•Câv»+Žš¿ýA‰$gOPRý·ä !„8ÛÕÊ!)//?fI@@@½#5ƒ H?9º·Jr‚„BœÍTÕ]ÿ’ºNvu ×H@ÒøI] !„g«Î!ñ/GŸçt]’³(,‘zBÑ$Õ+‡ÄãñPW¾Èщ”§•Øjü IDATBWóùä³ÅL™výY=[›#g7eamIµœe{¦Ô H$‡D!ÄÙ®V‰Ãá8nIÍჽÝ˃óÓ+ƒ”îO¾Ëß΋¦dïüýµ•ˆ·¹ƒ§§wþÝRÝy¼üòËL¾á,‘èZ1›· GKÿü1V…]ˆoÓÛ œ>ƒÔ SJ\y+ت÷¥oBPí' +Ö£FÓ‡Ö²%¨'bŽ®¯š½U’C"„âlV^î©Cr¢ZOzŠ÷ÆùÐuÃ0°„Eà±ÿƦœÞ<{ogì;^奵–-Ý»‚eÛí5óy2XôõWXŽ:Gu¹¡íÂj­'góZVoÞÆ®Ý{P"[’šzcÇŽ ؤœtᨥ¸þ†‡Ù²yc­ç¯*aü+ÃQc—ð}™÷”Ý›Ã_&ÿ×Ì]\ãñm‹ßà¥O¾cWÚ>Ê}Û÷dâõ÷që¥]0:ylò£ÌY4ƒX‹Ìþ/„¢é;©3ªÛ¾„K¯žáÿN^ÑCðØì¯IÎtÑ©ƒ÷ WùVø—ɰ{ie wåLžý4 £’j¬wÊ”©ìMÛU㱬o¿ ðæ.5C+cö¿ä­M Çöã‹o~â¥'Îgù’—yõƒ¯yqæ?é×,¨â¤ŸÅµS§÷ý\ýúGLˆù½ÞðI#yÆ+(a#˜Þ7ø” Ãó·‘3vƒ#*›ý·kùç7L~è1|¦'AeûYµòfüí¶~Ϋ7žG`ìHžúzeóì)G±Bˆ¦œL‰)x(Ÿ}Ö·VIp—Ÿ$áÆ(|>Ÿ¦c^g&ã/œÌ¯ë— i¡-®äþî®Þ¼„·u>ŸZ¨¼rÃ%lèp+‹>¾Šóñ#vÉÕþŸ·oáÞ)O°lñÓX0aÚ´©Ç\ÿ;OþÃ.7>ŸÙßS£ùü¿+¶§¹óýü9Ìž=—E¼ñíf£;ÅT.{hÉÌÍíÃʧ`R(ql ´åèÊç/¼ý-¾úlÿøí~^èÛ ˆä’KÆs_>ó8&³µryÍìï4*;ðŸ}6‹9 VÓ}$îžÁëcún>=C$yÿ/f2½#ªzZ>ùçr¢:=ÈÝãk½~нñ-Õ.ŠÆ„H'¯m-áµþÍŽôI‰Bˆ&ã´ä¤Üð‹§h•9$&‹_ß=À£ïÎ"%ÐßÛÝé)>œ¹»îëÚ»rÙø7qÏPÇý›TÝWÄ…£®`Þ÷ˈ®È‹0[#ˆŠèE»jÛýôÅŸóò*òDòWï§Ù…UC?Š)©=bxfIômvRïÍÐ=\|ûóŒ»ü f~ý ç%…ãunV®ZwBëî4pñV;ßM#~ðÕÖUΜ|'©“cÉÚy1õŽå¡·wAÿfrT !„hÒN: ÙýÞmüi–¿‡Ä0 ÏËs¹.¯œ¯^¸‹¯Žîa‰èÉ{¯×žQlù¼óñF½ûZôŠè˜Xb­Çê…ИSàäͶá•,û,®oÔÝ ªgt½×Õ3ç{iÀ09’…B4í€ädç!i{Ã[|w}ÍGØŸýÏ;ø¦Ã_xüâl{ç~>´u¯3ç¢8ý},ˆã/·«èÏ?ùðƒT‹GÂZÞÄcwvôZ ^ÃD×އ®ðaQß&ÖXöÏD÷ެWž‡èšZùZ‰‚¡©ø~oaS ?ü°ô„ ÝçSIwûlf­Ü®nŠÁ¤(”ì(Âw^D½ÖcK@óì¯X‡ä!„hzNy’Y—çÍr3Š‚î+'¤ç+Ì{®×½ô"ú;å7Í£‹{%wüdæÕ¥Ã+s4jô²|°™¸þÏb±XÑ ÿóÃG!¬Z×D`dBÕ²–XšÛ`¿ªÐ)ØÂÁož$jÔc„Úl•¯×½Y¼¾·„>kQç6kõ†@9$õYöT$ØÌì°ë5ÞÛøè@V}µ˵ê\F5¨1'‰fW1Û’«í«ä!„h:N8‡¤®ûØxåLxÿGþœBÎ꛹þs khO>zf8&ÞCß&&½²ˆ¡µOîºfçé³È7ÿœM÷ŠÜÎa#GgÈnëÃ?goä+Bøûó¹õëWªöS+å“ÜJnµ<ÒÙ?ô¡–oä½Yë¹¾,¯>5z=¬`ø(× BOa>“ßÓ1ÌÆºÝ¥pqµ÷öÀ¾~loÿt· H¬ñú]sæ†wsXôÍ•s”ì*ÅÙ¡V0"ÓÇ !„hjê™CRódg†æ‘£îú{d>’rS1¥Ÿð± °gc_+%sË·SÚâzæÞæåÚ+ÿÄ_þï¾Êmoú‹^x’ÿ4¡ÿvÐçî¸46€âƒÛY½v ‹fý—]á#xçãû*ס«ylß¾ý˜ëshFmÚB{o…›y–1“´Yñ:Ë(¶Û)²Û)¶Ûyð•7i`>¥‚ïrmKr>Ú÷VÍbÛrü+L_s-/ß~ Yw?ÌØ~=ˆT³Y³f9¯ÿ÷zÞú6±¥r_×-Ï¥í]ë¬!„¢I$õÉ!q»kçh†Áê™/PbÅ™³ðQ|àg^}îY–ìäþW¿dxø>fÌx„QµbÂøñLš0ŠH‹‰Â_?äö÷ö3}þ›$'‡ð®÷¿<õ÷[øÇÃ’A€Í†Y]óáñz¸ñGˆ·š0GôgƧÿcožJû„TU%óÇWùä§PÆÜø4ÿ7” “‚ªús3L¡0cÆÇ,€7{ˆ£òõȬwžgîÙ¿k;.¯‹-ˆ"â’InÝ Ý‡ZquÐÉŠ¿`*ÎçŸ#Û9‰¸j=BSžú„ný^ç?s>å¾7ŸÆé³‘Ô®+÷¼0‹ëFtªÜOÝ{ˆó¼<;0UUkÝgèxõ)„Bœ-ŽÄ!JVV–PPP@hhídÊï¿ÿ–áÃ/¨õíûƒ1}ÙrÛŒ‹  l‘­yãÎki6é~»{Õò@¶/Å¿ßÛÁË?MIáû''²¦ûó}‘/¾M¯Pk ±z !„MI½rHü9 I¢º^y!!!@=sH„B!N·ê9$2ˆB!$B!„htõš‡D!„âL¨5‰Éd¢´´ôŒoøX—¤žÈãgË:Näù†ZÇɾötÔ¡Bq"Z´hA@€ÿ‚šÊ{Ù!„B4É!B!D£«‘C"„BÑ(É‘!„BˆÆ"C6B!„€D!„BrH„BÑø‰ä!„¢±ÉB!EŠ ñ,\¸P ¡‰?~¼Ô¡Ô¡:g¨ArHÝÈ‘#ÿtìG¦d?Öߢa]þkÖ¬áxŸ©C©CqöÔ¡®ë•ËVÿ[ê°qêP×õʿׯ_Ü:”’FTëSׇI4|CX½ì÷9‘:”:gGêº^ëÇ0 4M«qr W‡Š¢Ô»eÈæ,ûÐÕÑKCØø ¡Ô¡Ô¡ÔáÙ]‡u#Õƒ’#¿EÃ×a}Ë^’³èCw¬FP>D _'uý-u(u(ÎÞ:¬O0"uذt]GQE©Wï”ä4²#åt£'ýÙ(]OR‡R‡âì¬C·Û}Ì€òÈÔcÃ:z¸æ÷êPrHÙ‘qϻֵrìÅ£¢±š”³ò½iž,ÒÒ­tNo² ቌ]KþÔ¡h¼: DÓ´½"Gþ>rb”’Æ H$‡ä¶ëûEüœç$¢íp& nËéü˜9Ë]…QŸ0'kÓ Ð\­¥÷‘éQhQý±:xÊ‹)ÑBˆ°Öݳpx9[ô~ôK¬£‘1TT¬X:™kØÜ‹1çÔgrýS÷²ìš'y8%²ÑöÁ·œoÖÅråø.gdýRßõ¤TtÅzÚ&úrå­b›Þ›> A'´-Ç¡ŸØÔ“þ1M¢Ødb´&¨üÐ:Öå‡qÓô{HÎ_Ëšôâz,¥ãu9°ä“•y=i»Ø²i#ë~ZÃÊÕÛk¼ò›¹Ÿ‘£+1дªð',"• sØ­Qž¹‚¹sç2wÎgÌút6_{Å·>ø˜YŸ~ænî\ôj_4Ëölf{FpppåϯÖ£UþdeݺuDEEÕKä`éµèA¡[LÕ¾UùX0ëo·×>à­*+®AiBG~Ùí¸LgæÌ™Ìœ9“—žÄ¦­élûm#Ïýû?•ÏÝs^);2Êk,ÿÚóϱ©Ü[£çê`æ\{Õ“”iÕºRó?窉Wré¸qŒy}{v£wߌû@¯æÍaú5Oâ ªY˜[ÍdÚU—Ò÷üîtër>\vo}µµòys“‡¯~˜ß¹õmÕªîá§…Y§e]¿y‰¯6>áåJÎâŸ/-­÷ë¿ûf!ÙíŒqðÈÒc¾Vêû÷ýúÕ¸ñÚ+Ü·}úcÒÔ[øàû]µ^·í…Û¸úæ95Û3µ€§n˜Ä5·¿LIµ6V÷æòð´gj•{}¶etò·ik2e/9$ìDÇ®=E»YðýNúMº“QQcDZâë…,wŒ``Çf5z54o6K—nÂátàpº0Yƒ #$eæ•Lj»ÄE'NVv!ºšO)A HMápÚö¯]Ɔür<ª¯GÅëU JŤQI†AP󞌰¥«qÃèÁLJI¢ETÿ|~6wýõ‚3ù+þçö1Ü?¡}e0³wÏ À§„tĨ~:}¬]±œac.Æ(ÊC3ÀÐ=,_¾šØ¸8 ós¤Dr~^Ly› è“’DáÞݨ'Wçá5ú̘7ï yÀzªñÉ KÞÈÂ*—´ß1záϦüŸnpðËg¹sm`E V FgTUżû.Žôs¸²³0†ùPUµf©ª¨ª¿W({Ùkܲ¸/ŽÊàÍßsßù1þ`-¸?7ÜGtT111„š÷qóåÓ¹à‰ÐTí¨ýZ÷ôÍd_üýCL•Û›ý·Éüó› &?ôWxºAeé¬Zù 3½ŠÍy³yõÆÎ˜#†óÜW¸é… Ì{°ç™û’ÚÀu7*‰Üç·’}…™ýûö±{wö˜Kùó„Vµ¾争M>溶nÝΣ¹¥7=Í ¾s=GeUŸèGÕÿ±ýí¡‡yzùâ"(/-¦Ìí9æ²QßM'‡Dçý&ñÆZ7Ó~”ÇO¨¯?~γ^Ç«ãÃÇ/¯z9då” iþO•¡;xåOW³$ï<ÞÿüNB1*Ÿ[ÿ¯;ȹèŸôµTC¿å9LÐgú£ü™ÓWÐöw†N5 9“uøíÜYìÉÈ ##ƒƒû¶S²o WßÚŽvíÚЮm;:¥„Uà*˜Ã%“w±qå?޹?ãù/­S_à¦ÇþÊ5eq|õä Ïg|õßÝÌ-cZÔ쥱(ºƒô][8˜‘If¦ß222(ÒR™=ëI«åœy ƒˆ@V«¿Ëßd±ÖÚ߯¬ï¦’C’¹øf®8ȳ~ä¶ÎQF2zÚ_éÚBåâéOñ측ü½oœ?øW*>—f3*ï>p-ó³;ñþ¼—èb©Vîi<² ›W—wñ¿ö$¶Õãî98òa2îùmÌ z~“’sæ¶³mãz~ÝSHhrW┾[¸§·êÃÕ¶+á7ÿû|-ÏëFÏž5’Ò®9AJ ²(ðzøù«O)O½œIýÛbÏÍ ¯¤f´êÊ)"0¾7†¯Äð$´",8«â£¬Ä…¦ºŽnÔü`k%¹¤—ÀŽ-[¹øÊ‰¤¦¦bRðåâ`.›0‰ÀÐPŠ·ͪ¼N ëf¥¨¬ê[XÉ–ÿ1wx+ºU`ÑÜÙhn7Ç:;s6 w¥W| Y{Ý5†#6{¹®¼»‚ùîëCôBaµ²2ÛšÓÑæå‡â0†)^¼M Yqß'påâªà¡Cûa´ëØ‘®šXõ-1ÿ æQ¿¿¾©3çç, ñ柮&oÔ3|>µk/É[÷jìdz†V¼Þ{r)Ѫvrª2ð¾ù¡Zÿ-|0#ÌØ˜ÏÌ Mö³™½5 o|sŽîÃu­ïdÚ¤k˜³x‰¶c7üQc¡øE<ú?0®–“¾'ôœ F^عòu].ÿ ÿKéÈŽ„^5«Gwñè3óIxþ¶ŠÏžxn32È8x§ûgn½ÿgZµnMëV­hÕ¹/{ÖòcËëj#þ€BÍ¿?~)õ}|ÿ}iQ©W ª$Žxœë¾cþS øûÂ[jõ¬Ì}ü:ÞÛÑŠwç¿\#Èßð¾˜kèb=émÙÂry„“W7ðJ¿fg÷œîÏnºVÆ—Ÿ/$2µ·Ü;‰[¶¢:Ëñj.Ö­ÛÄàÁƒ+_Û¼×0.è–Ͳi$ÇEã´£%¥eþ“Uáz¶—%sÿ¨n(öCä•Ôîð{ HCsW*>g9¾:Ï[E¤íÉó3 jA»V!$¹2X´ý0ºV‚×mcóæ|<”V& G!–Itß«¸kX,žŠ€äÙ'gÊŸî Dõ`†îæñ'ž­±í‚ME„¶ƒ¢ÙqUKJ±oY5¼/çGXÙݯ5¥_}‰~խ먱|›Ä@V.=Lܸ²œ¾³þ8h?õ¾¸µãQ‡›çà­ÇþRùÐö—.ç¡ÒSëzž÷äÕ¼»· ÷ÜË£ÓïÁ–ОýFsÙðªíok͆ÜYíX(gvž“NSë»R­G.î˃oî‚&|‚ºéÿþ¯Æÿ#"¬,(ts{bH2=’®Wœ{€´]i$™ÜuïíØÓ÷Y¨Óªu;¶±ô·U$X«‚™¨ó.eÐQÛÌúþa¶›ñÁˆ$€ÒŒö=†2òŠÖ„ÿ‡?¿Ú—ßß[ùzGÖWŒx½# ?Ôç· Ý0ˆ²üþxÔ÷ñâ÷R¾.t“:ùØÃQ#úÅññâOšÉ÷3nâ¹oËøpé,:‡Öî™Úùß4âÞvÊÛÓ;†GßÙ g{@"9$ë÷Ç®å:öèˆÇ~£y+"¢#Ñ=Y¬Y»‰Ë.»ŒÃ‡$¿8ʬtÒ€@vU¥ZÎ"yë÷ÙíjblåìÌ/¯³÷Áe÷bm€ÏåüÝqhÍ[NA‹qˆý¥±tëÄôÃæv"´Í¼3/‚ISq8}8ö~Á†|C¯Êqðéþ÷ì)È`_E®‡nø2öïÇkFÕÍ‘¼‰ürA#QËŠ«öÓÐX³³˜äñCÐ=ù¨!݉1íä«=V†ùjô„Xãðì=…Ççî¡ûÀ (Râ¸üÆ¡xr¶óß\Ãü+ßäÝ;ý á¶\‘W†UÕ£ë>Ý òü°zç/„wÂñÞTuЙ9Q4BŽN æýEKiZÈÎ;Ùµk'{ö•²ì§pfü‹‹oZIj§TZÇ‘Õq,Ï?ØŸ6IQ|÷Ø8^kùObÐQÕc+xŠ×sÃCK¹ðÅ%àSQSÐ@nœ\ñÿ%ˆê9$jùvþ4éiîz÷[¢Z··|+&k qŠÿqÐ}jµe7óÈ[9Ìxà¢F«ï¦Câseù»ó#*ó>j½÷nè P¦ú6)è8Èã?t#QÉçƒE{yþªŽµ–ÛqØEÄ„°ÊõžÌ¶"ºGáüpš6°AÏo’CÒÄÔkìÚjppïœßä9.4µ€²²2rrª. 5bÓ=äeça²Ô¼¬¤ÌGpÇx¼öâÊŽZªcäÀ®CX›Eàu”b‡ ÔþÆcµ¶dÈÐTBõ%¼óm ñ!€‚90” óÿC±YÁ¢YùøýµG·20¡˜ªrÌ@ño_3kŸ«¢±ôó>zŸÓ險 É!)Ó4cÐ=®Êu¹ 6P êô0e²nUvFr„•]KVÐü–>d–V6A6 _f[O¬V÷1³%‡D1Yðd}ǬY{*ƒŒŸ—.E×u>™5 H|?—™•å{äÛjõ’êJÕ7YyONæÉvþöþwL®þMª[7zvÖé7ö´{VhRÈðønVU¦æ˜…²=N¬½­õ;Aµ AódÔ™³p:’3U‡šçsf/!#ã dÿþ½d.Æ|à–êAJû®\wÁ¤¤t Ðf%°ýc¬[ùé_\Ç=;ZÑ¡U<¥û>á‘o]|°vàqËBW xvÚtL#åÅQ-ë¼,ßjQSåz6½ù êÄ™\ß9¶ö Üñ+¶ÐÞ•¯­™C¢ñÚm÷r°ó_±Z­VßM!‡ÄÜ“¢`ß\‚¹gÝ=Åí˜,„Yý_ L X‚:ðá¼W‰ØüÝu³Ïÿ–Ék^2žáÑN­Ì9™m„&¡y2*×Ó‰äœC9kY´²úe€þèxæÌ™5¾¡$¼œa1¶=#•®EÁ¹¿-R;ö‡+ÀŒ+û'æltsãäx~üdm®¹™öV½Îuº“üBº¯æ·$GI W?ú8QŠBÎâWY@dQíåe*цqQ› <xÿí·:z Þ#C6^Þzû½Ë…˜M”:|èÁU ÌþÕéXÛ“¹m ^YÂâñ¤oà7Ûb)ªö­FC1…ƒbm2Ç@L{x­‡¿îç<~ ‡&=˾9òâ+¯`:2dSÿõüö4wÕŸÙOŽBW‹X»=š7¿ù€Á :¿­XŒ–Ü—Þíý'²à¤qhêSòê´4“`3S_5äg2G2>:U_¬€kÛÕ¹=Õ Æžf[bÓýP*&VnÚGJû.ê7Š””D{_á’Û“xõù{»hlÿžä½½ 8ŸmÍÇÞ£Wè±Å²ôåL¿íA¶ØFñýŒÉÔw*Ä>~ÎGzÝ9"[_YH∧ê|nÕ[·2ÏËú>îaÊå1A,ûC¯Yº¡„jç_Œ…®eöOñ;×xk4ñ¦ºÖ›Í?dqççÕ#áfÖã×qÏû>øøáÊ$X©ïã»ñþØwþ‹×·Öz.{é?˜•ç`Ì?Žýy<ý=&¶ÈãžiÏÔ˜¨C¨•²=e§¼­Ò´R";œõå(9$ÌårÕ9n}ôÿªšIZE¢îÍ«\GZZZ½¶Øb¢ðÎÛ_r^j ‰Í¢ˆ 'ÀZÕb™"m „3®Ss ÷í$qpwÖÌ~•y­šh³`øTœÎr\8¦r|ÒU¢âsìÁ¥Eá0hÛ­;&L$ÀãÂ0àóWgðß2/í®ˆÄÐþ\ÝM¦ÇÇ„Žì2Ê+NšFų¼ü˜9$Q©aoKÇÔ·9ªªbߺ¬Í˜Ð2Œ¢};ÉuW€[w‰dó†yØÆNFÍöO–yÐAäð$t­v®L]7Sû½üƒúÖáÉ8’C²æ½§øû¿ÐóúGùâŽñ•½Rªªbª¨B_9$#bùî¿ë¸ã®‰ëð/ŒÅbÁ"ÚwCݰWèmX Uö‚ä^W`6\ú,–ª^¢¨Ž‰H[ÅêòR­nT_);œ:—öˆÅk?TãµG>DGç ïsRŸ:<•†ÐlRPLfRÎkÍßç,exûpö}ð"ó ¨¦pm<™éØ­!de;Q"-5ÞÓ”—ná³kþÌe[û£fW–AßÌG÷âè"·D âÊÖ1jÂ4†öjËa üúì[ÜpïLê’Ô–coÆùüSÓˆ¯ÐÞúâôò/:›éo>‹C³Ò¼ýùÜÿêLYµ¼æÉä£Ül±òNÒ^¶ÿTÁáå]7çJÌØÆ§Û@³ÓŒÙ=¸y–/=¹ðäÝÌaì—ABO W½œK‰IéñøäWr±¨¾Ó²ÇZwqÐÚqq¾tòOZv.i~~Ó4aÑ™üðMfûzç‰Ó÷'º}¯—Þ¡jèËè‰OfnåóÌ­¸4;NC˜;†Æ»Þé¯âKßG%æpâDŽ»ŒÙ’Ê›‰°û´Ï»¯ºÊ~ÜCø¼¤DšäGsÖø´r÷ö¿ÜÕD}“ÁãXgc9ÅW¼Þ(p4q§ºÉkìŠ cu:SÆGPñO)Z&=EJT$aæö˜'-÷½i·*˜¶øy¢&Z¨.¿ÞåZGƒ­¬Íô‹­ Œ‹{E1pçvÛ+oÄ/J¡èûã ß´” ª]6f¯ä·‹Í¤nZ€ÖXI½}9˜õEG˜ôî·SÌ]ÎaIXDVBgýñÙ‡8›ÝýiÄí¾ŽAÚŠ~÷vJ¦ÎœÇTx|æ‡{ølÅ[T.9F¬¯¸$ƒ™0e[í¥¼ñq ûN¥õ[©§†“Öm`RË1Ö‰éÇe„¾f õ¾ 9%š±Ù`ƈ‹¾¨.=o'_¬ÙÉÍÔ£ÄøiwuµÚËxû@ ï\ªËÿ,Ôv—éxwÞS<_ÆX{ÓFm\@K öæ^€¿‹®Ò1ÒÒRÆš KW]+!€-µíwÛRÃõë~ΧŒÅ:ÿ.×L£ÉY¿žéIIAÕy©jsLJQV\êÎÓ“!³ÿAOÞ禢x¬Å”ÉÙ{‰3%wÈ[õLÐåÎ~õ:Öý‡™9ÌÐ/ñ#ƒRÃ=ôEC»Ýîw™m(kh´$óÉžBΕױ5¤²¿{•Ô¼ƒÌŒPýî[2N‰ç§Ä b¼×®ýí… øfxÜtF:Z±„›(,, ªÌìɱԕ—p_¯åûjûPâþOÆ>KuùrHå¶ ðÌ£h8ôôUCUU»éçЪgüDo‰NÙÂZ`íùó!—ݤãuû²‰!äê… æhꫨáxç½ÛÜ ÑðÂ`0è7"֤ö‚qÅ!Ñ™žŒF J¿)Ô`:ÑP4ôÓÐ{{xÏPôÓWC³%݉!чÃÑãÞbHoDÞmÈNDCÑPÐ_C§ÓÙo{ ½ÓЉ!ÄäççK# Ù‰h( úkXPP 4Ä54Øl6qAAÐÉe#‚ ‚îH ‰ ‚ ú;$C"‚ ‚ÞÈ’ ‚ â‚ ‚ H ‰ ‚ ºó›fko%9ÅIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/lgndarc.png0000644000175000017500000021002713362604320016516 00000000000000‰PNG  IHDRÕ\6 X{ÉzTXtRaw profile type exifxÚ­›ivÜ:’…ÿc½ÌÃr0žÓ;èå÷wÁL ~z.W½²lIf2Iq‡Òìÿûßcþ‡?ÕFkb*5·œ-b‹Íw~©öùÓïwÇyú~ÿ¬dýëè·ã&Í× žCŸáy¡æ×Å6Ç9Ãù×ñùütãéË…Ú~½0¾¿Ð_òõuƒ×ñ×mmpÏ ì릿.üëÎñùÿxËæVË×G˜¯óÏëõ; ü3úCñ9eW"ߣ·¥äÆïÕÛX˜·¥úùºÔë‚¿þß¼OõŒÉïà‚å{ÖÃ5tã;ÿ÷:Òø=ñSßës!¢å-üÞÞóúû?¿¹yýòo!ýøÍý%쯑6wBß§„_"”?~þxÜ¥Ïãæu÷ýý×;çüúÍ?~¦[ßžù5ý;gÕsöót=f9¿êýˆ÷7Κ­û®ÌWá_²U“­¯ÆW¥$&y´H²Á×tÍyBv\tËuwܾ?§› 1úí ?½Ÿ>¸i8X Fóó†;êË_ó"ø>LÒ!pÔŒÅÝÛ¶{»é*7^®²Çq1Ç[þÑ—ù““ÎQA9§¹\éÎãòª4F¡È9g¬ã4"âÎkRÓà÷ׯ×@ÓæÊv;tÂ?’ûL®p81ñó)`WÖëL#H Æ"`³ Éeg‹÷¦8ÇDVÔºÑÂâRò‹AúB&8T÷æ=ÅÝS}òÏa€@¤M(ĆB$X1&ò§ÄJõRL)åTRM-õ²*,ç’…¨½„K*¹”RK+ÝÔPcM5×Rkmµ7߈›õØjk­wnÚ¹rçÝz~„Gy”QG}z3ÃŒ3Í<ˬ³Í¾ü ‹:^y•UW[}»M*í¸ÓλìºÛî‡T;áÄ“N>åÔÓÌéQ{…õ/_ÿFÔÜ+jþFJ'–¨q´”÷%œà$)fDÌGGÀ‹"à‚ñ^1³ÕÅè9ÅÌ6OU$Ï “‚³œ"Fãv>÷»ÏÈ%ò'n†@øÿFäŒB÷‘ûkÜ~ŠÚê—èÂÊP“jÕwÉÃÏ ê[†[·¯ÇöZûƒ¸Å2Ô³E;z´95Wæ8c¦ru§6W{^sK£3­¡žBíPjvŽ]ïxó!0£•prrÌÑë“'‚Óì"þ~ï4ªŸ5ºÀ©°M/iˆÑÇŒ<ãÍs¸ÎšfÝnäf6¡Üì‰YeŠG<t;3/ÇCÑ+”=¹xªgµ6v£Öb¡Í×Úc.2M=äº}hÙ?@¿˜šCŒì˜„»2}-{¤[Ï$d¬*õ0šµf\ó«æRç)kµ}’ïk¬ÙgÔ„¹Kó{,V®6”â ¿ÌvH¦àlî8·©‹Y^Û¶ˆÚjar’ Ó;Î!×6¬üq~ý»sÌŸœôÃ9©úJäXÚ~õi*£¥Ú;ÀŽ(ÐÏŠµâB@g8,¤e_3¸Ü,Ô‰€¡ìWÝ)V?N§P­q¾'&‹4Yâh"Ðö‚ I ‡èÌÝË>[ù8æ¶‘TíŠúÞ‘“¬É…8 ÃÒ-Åó9ø<¢§0)ÅUÝ ¼o÷™yù>5µ}gÀ{ÏÝd@¥e0ÊçÓ7?ÏF ŒÛÙ.–Ÿ'^ØŽ*rFLlC ²ç÷í{ ÏkR²úþ¼LÞc¾S%yñä{#;Y™‰)ã@O™“½¥X×DQucD‡ ˆ;Ô=)Ðr\ϼa´X2²@×ó²9‘¨pÕ|¨ØL`ˆ w ÍCÒ{µÌ ¸îôÒÒc·Ñ2×?í¸rÇkêIVMƒ‚!&Íŵ} ›Oª›³¨¯ÂS×<ÍYJ@UMÜÜuÀ.‘G…²Ø}ÇØHî8I˜ÊÝ-™“ÈÝËVÞH078­ÿ7F]˜Þ”ÆL»÷Ý òäÊ=a† ޾wÐløBZBôl; À ÇcZLFÕÛZ"[[Ó>žx®Ón¬À¾À’‘mqPä)Ù’4õÄ›)%é¼0¥3ÀÙÎÌ“):Óf3…!qùžêú±ó¤Y3rí´ŽÈ “)ÝÔÝ A¶‚{ 0J‘ÌæŠ{Tp `k…›´y…yY;ÏÓ58Ú8 ñ€Á‰9Ïyì=/Üb—V*’;Ü:³È Ži¡ÉN>0Üa)FÄhÐl©k ÅÉ»mz=ô}dòøõÐAs ¹Ô)Êì>ŸZäV9D,£ËP‡k«Ž[wÓèÝ=Ç墄Xc`±åa€ÜÁ‰}îµ{®!Ï)* UBÚÅÎáâVé'mnm|&¸ÔêåÀq­Þ<Ђ°w$kbËrH»ÓØyJ2óŽ…Â©gÏaF½I†µ"û ÿD‡. 7VPÕúúëñ–´¹ïù~YóqÝŽn€£-Œ ¥׋½AC#ÊÖÝC~ñæN“è˜!Àc~Ô%Ìf6u nÇœ}Ÿ+ÛöòŠÇÈ=Ø }QRÌ®„Š‹x1HÐ’‹ ±H˜F‚Y*}ElIKOý7=•&µŒ® ¡ _R÷g2%/d[[–‘‡c´&¸r±S¸ 12´VÀy47ÁaxÑ;0›¢H.yÇÚš£÷p^ƒ!Kî÷“ÝßGnÔ5ƒÑ!6“y¶ðšô%îí²y5!ãaU„ XŸ ⣢ª`!¢ Z1dª?4R ˜ ?U IC€é²XW]pµnq€hònARo.p ñÇÀZ2p ¨ÿ2¡W‡uöªØM¯œ&v¯6Ä,y|ÆŒÎÕÕ‡ƒ›c3”Ò² Õò9?iÖ=ìПºóãr°ý:¸à0ÁRó£»H¾y‰AÖpÓ\ó„$åÃCö[£ùÒÔÆ€¶›f i{( [F¶¯›)töš)X‡FäÁå;[ºX‰e±àžé;i)Û&)^dªäˆaË`„“'<©@ CôcN©S¥TÓjaÚžˆ= 5†+;†óT+9¸„%Æß»÷Ö€9ÂN(c µœœæFìbËšPHbP‰¹Š¨.>.eƹ—Š­2™ ]ý¹8s´E£Ä Vâ•.¹ýBy »]ìܰ/P›WÞ+K›öÍœàÝ…¡Qµ`­=½d²’’ÿå¹È€wßG ‡4\KԀɀþB—ô’Dô.íË(6.‚ÿé ¬9AÍ’‰Ó@,ÖŒ‡É w#V¼þË@7ªÑ©; "<1[ LÛIÛô Y­ûØ·ŽªkÁ>á•.ªî2ÊÔCà›²ó—$üš—ÊŸ'3©ø¨ÓÍ/þ”Éïóÿöòæçëÿty´6] ÄÌKEéA‹Ôài u,P*Øž X“@:µoHbØÏJ,Q€cŸÅ£d%˨(ßÈ©0Ûf7<"NTÍ…¥FD¹B´á•|¾ÔÄÕÚ-¾…E`&wÇ)=¨Ú8ê:Ët²,„hÀ‹\Êø)œŒ¦•ÙݰNIµ=Õž’êÍØßS]=§Q¬Y³8(½ÎEˆíJ8bôHô }Ž (}æDKdFñmˆù#:x0ˆ ƽ4¤¡6VÍ|ÍXHLÍ`Qaæ¥dl<Ð@…Ý0ìÛN“ü©•9‚A–Ç3öÝ R7æ®ê*"”yahNÐ •,ògZ(ê›Ëað(Èn¦Ü]Þ¸ëËÌbµ(K45‡ŽÕÌ‚ãXS?I–D•9S5g3?PÌÜ ½±á»4Ñ„‡Dèvh14/à –2!¡&F7lêKn‚z‚ŽéF¬Á8ZágRˆ!SÅô5¦Ÿ7 Épî$ZÛýÊŸ‰+E¼ðä¸Zç€L­`4ê“MŒPÏ ü÷i© ¨§S5G ‚L’‚é @ ‘&¡“³£{dØ$vê«éCTi‘8…˜öc²&ŸDú3GˆEÜ”©àª(‚dñÞP£ÚÜÅ1è¾dA%û0(ü,ë]¾x½×=’>Wa (žg}"Í ÷Ì' y-šyÙ h¿j¿…ºqÕ8’X1&¨“Ȥºy7€àÄÐ_(rQ‘J‰ÁÀSÊmYE :IûQ$›ô“´!7ï’ÄA§ƒ÷eÝ Øö6WP5âŠ?ˆ®ï?UÍáÝy àÐþ†Ak‰Ÿ¬Vý¹jêò3Åþ‚Ùh§b¹½ &~!²°+·0 èBõñ¡g’9tÉ®»ûy€I#ÖRÀÙK•yܯV!´×´ìÅî:•7®’€Ãø”by¬º*çY/ÜüµŸ?Í·õ;ú…J€áôã‰4éãF=} ð9Gj†m©-Y̹£¨ö*ª MÞ½Úa/ç¥`[¯Ê¦”¨-„Ìà LñmòÝw…1BAªH‘oˆimЮE4æ¼¢|¥ýŽV¼s4NUgÕ³F´wa5 ìuŠyÖN0¤·¡‰öÖZ5J¬™¶,½QÕQì&%‡bØâU‘Áœ˜³ÄµÊÐN•=Ki¶3 ´–,›šQÏŠß ÖÆÊ o V‹·µ ¾]eʈ"Em™ÀH ìVWOEêµ錜ê8@ÀçÓÆ¬¤«œ`Ö]ãÓš ¨2SÉßvS–É*íÑÔŠ”wÁŽéâÝV#§Sb\bžS‹hhoîö!-T¹Ä}d-¦Á“àNÛ60ĵ]KyYŸ5 ïŸÛC-yŽË]—²WÓf'!½MdÖ^[€¦ƒŽ"`ò©³/7%ÇIú›É„úÇDþÔÒÁ|hûª‡gGâ0Ÿ®>j¯‡š{ÚÞ1¶D©zƒî6Â.•(CÂp$„ÏBŽ1mUýu"†ƒZ£Ú¢†ñЦ % ò‚LWÿ_˜ÚSu·f°ÚƒA"6*ïnEC.XHÛvo­´ZµmÎiùz#ÿaE¼¢–\˜bêXØJ𳜮z˜ø.‹… 5ÆÐ^Ëù„¼¢ŸƒÚMcœqÅÆz„CPw[‹[c,L:Z&ïÛ. Y ÍøŽ%±êé¢N´;¨ ß(\úíVŒŒ.¤cTÁ^Ð\ ¾zûA–'ûhQœø ìµ]`Õõk¶ã%Å]xõŒ¡#œä劆[ý‰jدÖz¦©ßwmNƒÐ†Î£ ÔÖÂô¬DÞ•òòün;©àÜßsÁÜ_|U®ºK¢>ÕtZŠ&7îÅŸ ÍA-PUÜ\´U‰> þ4ã/Økï’0 `BV—Ö–ZâÚ º}Y½Õú.b&ßeâ™Õ`ëÚó`5® *˜ôQx©ÏÜû"Úvá´».4Ïä[ñR|TfPl¤p2 Ìnú )Im<¡ÓÅÀOé!ÉÒæï*â³ìµÚ ƒ'm¶_¾4€lXå®­@ï%ÙÓ¿[tæW ¬­Zµßðî‘׊UÅ#ìãš¶ä¨^ºZèZ’î¨]³µ³R¢sQ´Z­`výM0q‹Œ%µݶá÷µ¼žÅBš0µ—Žfa=Ðоw†û"•µÅ°®ê0‡ªÝÜK&ÐÇ6àkhî®E5´…¯QÛĵýÕìxûC9ËSÀ¡HêFƒcPêVu0›­^Bm«OÝX"÷M‘uwsWV0Ú@RUüeoÚxÝn›”Ì¿º˜F¦¹M„±¶Bƒ%òp[».Ƴi6-in•‡ï^Ÿtõûš?˜äŸß#YHÿø± ýGx-vªë~:TõA2½š!º¥}îehL]7<ðU’ÕÞB j¯jº©GÊ“ÊR•gsÕ/×ëª;-†®¦}›œÚ¸ó Ô>m˜÷Cëkvx( Ž…q¨¨«˜€¶-{͸Ûk]¹’ G­EÿÞ.s´w3É¥‡l"Ò´÷ð¶±ôú´AÑUŠ—”RC:GGæò•Ÿ#•[“T2ÚTðz˜ÆƒU)¨«˜xòuÚ—³‚v÷?0Ôs”ßVÔ¬Zʃô–MÑÐëöÉ»<DtWVÜþ8Èc!ø T2kǯ7Ü‘ªh¨Ñùê¡mÉ>õ²ˆÕԾч^uVÆó)…gGÙ^îóÿæøvžØþ:²×yŸÿÿÝåÌ—ÿèræëðþÉåÌ_Ÿö·—Óþ8´Åó)É„[iCCPICC profile8­TMHa~vÖÌ~ЩˆŠ-$HÜZw´µÊÌLÊ]É"ZfgöwÆevW݈èè!:DÐM:u ¬.A<A×ÀS§Ž2H‚íù~rU” šá÷y¿÷}¿ï þMÞv‹u!ÀõJþHÿ¹Ðøµë¡­±ͤ6„-»X辌MŸ‹þ>,r=[x1xüñò¶˜_?>1¿˜ÝNªhvâv»à—ˆÇ‰g§K¿·ØYË!þ.||!¡O*Ü)pFá‹ûñ‘^âÄ»2 çN*|[`;ë»Ä÷ˆ[×a~ã¹È︞ÀˆO¸©’[Hón¾lëšE·;SÞØ¨ÈCÚ¾¤^Ä1ÄYnì›—¾qd‘C!àciJy¤(+mšÚ””…-„ xDÓü†`P¡Gæ)Q'¼‹DBg“çèãQs {¹~Ši3ªtK{ªÕå›@ÓRµú³ã °å{=Dý[F_Õâs€Ó´5x5ÝÑFŽnxy«¦sžsŸ¹}Ë·VvÙ0Í¿Éj?øÅçIƒ«¤¤#wƒ ÿaöIߌqrCœeIî'gW”äì’ŽkR¹åàv““x#8+Îy\Ëw´ý!ùvò9òÃä ¢pò¯Úþ‹¼ÍÖ©¼s€¹ ‘§™OKœ” žd¾Ìb”ÈÑGû)Áª®já$¿&¢¬¢“Ø”ëvQŠE©3©"›$ÙŒHK¿ßäš|-%Y×н¨¹L›%ç]–÷Úß´þZd†®ŒrBQ¹¢zk>¾ì,ÁÙDä»Y›è¤sŸŠô1eO1úFÖ¬¥þMÞJ.Sv¾>×j¿Š^3Fnò~FWù%ùç+ËSÙ:äz"cdž^í%º÷=ü‰! QB‹n¼bKGD¾¾¾µ­@› pHYs.#.#x¥?vtIMEâ  4´.¾atEXtCommentCreated with GIMPW IDATxÚìÝw|ÕÞÇñÏlËnzBH¡wP:E©¢ˆØõ ¶Ëc½6&‚ô˵7»bA¤ Ò1tHRHÙ”­3óü‘^€€”üÞ÷ÅË›ÍÌd÷œ™3ßsöÌŒD& fìØ±ÝÇ÷˜¯¯o”¢(FEQB!„B€®ë躮:ÎäÉ“'¿:oÞ¼@àU€F@ËÇiРA_¯×‹¦ihš&%'„B!D)ƒƒÁ€Éd">>~yÓ¦Mç{àÊÇO®_¿~_·Û-%%„B!DX,—7mÚtªñÙgŸ½}ذa¸Ýn™ë!„B!D©ªJhhhc»Ý§dgg2¥X„B!„83Š¢àv»+‡Ã¥ªªEŠD!„Bˆ3g4]&]×Í•ýRÓ4âã“’r™k]»X,êÖ­GÆ1 R BˆZÃãÕxý§ü°áiÙ)Z$<ÈÆÐxäºö˜M•Ÿû$I6:Y6ÒuÝbÒ4­Ò¹Ôññ‡ÉÉÉ¡kרl6)ÍZÄáp°{÷NâãÓ¸qS)!D­ñúO;ùnS ×_Ý“Ð@9÷Õ&vß­Ú ÀÃ.G²‘8“l¤iš¢äææê•­¼aÃ::t脪ªr{½Z¦èV1Û·o¥G^R BˆZã걋èÖµ+É9 Nœûj«Ù@ý@7±bæ H6gšL'[ÙívËNSKÕ¹|µ%„¨mÒ²$å€Ó£JaÔ2J²ÝpÊi?’$*™NµU•F¥¶’ºBÔÚpå–ÀT[åW¡îåü(Ùè¬BµBQÛèRBˆ³pÊP­ëÒ´!„¨e¡ZN}B²‘8סZ!„¨u¡IŠ@q®CµôÆ„BÔºP-ç>!û‡8סZ!Ĺ¡:ìd;¼UU,øùã#Ï_ºð¡©Ö|P/šWC1YP”Š¥ {hŠc™¡¨hn'ºÁVîuQ£iòóܘüü°HµŸ]¨>?½1„_^ãÜ£Þ0ñÌk÷Ðæ= õè2þ;ÿWM»H£·ð¬“wp¼ˆ•§£úñº ¨ÙPÆN½…V¾­:àOžœû u¦ÝC?9™ Q-)6š_5”‘…í‘óËm$5ú ní]8È ’°öV«Bkš·‹÷ž}Žvça°dÌgÅo?ñå×ñ¼Çé]G†”$S—ûlÙ’{ÂÆ3Sžghs ̸ù{ÃoÌxw m®Â׬ú>8•»ŽïæÑ½ ¡âI\Fp‡»øîæ`Þú:…ßí2 ¢Z1ø£¤,æÓߺpùP#f£‚Ù¬€s?÷7aÏ oóËLÞ|%Œë n;G3]æê.Žï=ŒíÚ總¹—­Mg£× ÞTÖ¼9ƒ™×óÊÂüýâ3LœçbâúãsºüâbÃ+0k•ÕdžMqã1†Ñ¬ó•ÜtëPºGZ šÅ”a.ÈHµ®zp»Ý¸Ün\n9^ ú‰ÃìŒ Å×ãÂårü^ ¡m¯6T>0£áÊscô³V±' ãߤ5þ Þåñ_¾çÊ›G2bPkB* ´ž#òë‰ôë…¥ü9Р  Ê¢¨44G:ÿÞÉö»Ø¾óoÝÇ2ëÖ†eFÝuƒ“b¬è;¬ÉŒÁh¤ë'¿²\Kç׋Pnù/C<¸ ‡´\¾aÒ Ëðþ4ïÎìI#Š–Kâž$Ttt̓±õH¿üQæ~µ‡—F¶ªð9„Õ#T·ru)Ñ3³ï§d6íǨQ½ [+’¿¯B¨ö²wá<>úÛK³›§3çÿºnÌa÷çÏ3ú½ÅÌ}/–ÎÏöÀWJýÌÏY55+ê™8œ¡¼=«?¹›Óµ,Ÿ˜ýl ès5ó§ÿÉã³S8S¯Ì7ªº®á9¾KÌ`æßÊG_cE¶^‹÷êúÙ¸â¦~|2k» (LB)«âϘa¼£àÝoB1A×ÑQP”Â|£ƒ¢˜¨Ó MÂ×óeR+Þ{Œ…Ó^ãWßÛ™=u0u½n¢'ÍÁ4û9ÆOJâ¡§î"6Â|Šü¢ãu»ˆ9Ÿîk†ü´8V~ñ¯=·‹£“žcX#3è5'ÜÿPíù“Ù÷Ìc­KÁh²`ñ±`Á…Çyœùïl'Àâƒ>>¬¾í¨ÛšðJ:)ZÊÏL|.ž[Þz˜.UúvÀ@h»¡Œ}ëzþµê#^zëE\Þ›GÇ>Àáeç‡Zó9ŸÛï¡_§Èr#zÁÿÜ™Äï8®]»Ø±c»gãÛ°»´&Ò´‘]šZ&t—n”‹vÖò?WF=°Œ’ºóD_œÞÂD­gÉß“7x&¯ÜÕ5/Ô|[½pt¯MÝå¥ùMÃýϬ»¡WÉhµ5šw¿­H@ îÏ÷w'Ü\pRm{Û(nXö(¯YΦÇzp¥MŠªæ„¦ÈqŒ¡#‡à»%™1›\x _vçæóÓ’£XnŒe|ïÅÜw¨.FCÁ9M×5Ô´UèÁW°`T4‹¾=Ê'4Ù?ª%µáµ±çâ@š†©C;ÚZK·ê¹¬?ʲCìKV¹²™Q ëL˶†~.ÅÆàf'X¼ÆE…-ë–mMáž^õir@爡°œ;qÛóþ-Yýc2 S4¹å`µåaÃËóßõ.ttT·mÆ¿YeLrÿ¼1ÄžnßÏÚÀÂ_mÜ>áVêi 鑯á㼞í¼;þ7¢Ÿ|’A‘&,uãØÁ.Ýç¤ù¥Òí«œ¹^"]G‹oV³%«?C•“aÎÿHµî"7+ÜRÛÒ ~º’9ž’Î ë©W×\vŽ'ÅŸ°Ÿް~Þ~ËIÁn¨CƒÆ iÚ¨ö=›pµ¿¥ÜhqQóèqØÉTüè8(¯Ã·ÔBŽËY‘Ù•‡;Z ‚½ýæ>õIëË.#ÈÏDã½Â÷7· ·ÛÛ™AZ~>»>þŒmÍnâÁ†:z¹+6t¯Š&SÙÑé²#ÕÙÉGÈ jD”o&ûdÐd`4­d[Þ£‰$´ ‘¿ítÕ¡ûÒ¤EŸˆÇ{e;¹µ‹Õ.­å²~þxžü²ðtáIg\Û?áÙg*<‰hdðž~SÙYdk –àÊNA4„¢ÛÉÊÖ Õg\M545ÂBi’“É;9†J?cnzÉuêÐÈäápáïýwà~ Ù¹ø(ï%ªÈÜ«÷7ÝK£»ßäÍÛ£1(…=D÷j&ß¼E)øö G¦õÂ.dé\b !Ì–Éጺ ¼\Ç­FÓXAñ¤b´Óˆ¦Ñt̓'àrÚjNÜžÊóKÁß¡pûz™AA¯5’&ÁÇINQÑ‹æåÖ€ cº(-”_ úrò4°žb(W;ÎO³§ò‹#šÆQ?€øºwðÒãWRßWÁëõâµÿÁÌ•»hÕò4ßqê^œùåNTÞ~úr-¶!ÓélÖÑ4P‚zðØë}y1:ƒ'—•ÓWò!ùd¤Ÿ(5 ®‘¶v>/­ æ_ÿ»Š Õ]áŠ~Ý‘‡Ãè‹ï©ÎgZ Ë_‘Ã7¾ÉÓ29‘áKXpÙT·¯o8NßmÓ ªJ^|Nüe¨ZˆjÆKNj"ñÙ%¯Ø""°a'!Á^üšÓqú“¶®zñê FcÅ; ™LFÀ‹W•?«SV ý\f_+fG6yºo¥ŸQÏw’K(þ6z>èiÙ†Ð̵L]rg«ö˜åÚ×êMÑÉÜõ3ŸP*H$’¤AÛª¬p÷ÿ_F½ÿ _ÿuˆM ÝN¢+•=/?Ï_EžõøðH®ª<¿œ’jÂbq“å­Yæ¼TkùNwñ…Š·wNhéìùë/‚ƒ4<Oñ?CTgú¶ -°J·Ïû’û/¯‡ì婬\•ƒ'÷)¹:àdÿ—Ÿ²¹åÍÜ[GG?“.´žÇî…oòýj^¸±šê)ì´ñõu“•š†Ž·¦—ëeéän]ÀÄ·Ðe܆…¹qx+–“j?AVp0…*êÅ-u©QëÜCì;ÃeMLèh¨ª #z™r7Ú|1æç“¯éè§ÝÁ40P4 µÒQ{!ÄÅ=á3`üG<{Ê C\¬˜|þ8ͦl¾øt\ù¼P2} ü\:6|å¶zçd¨¦ð`ÀëãÅäÖÑÍ÷ ÕíÆ—ª–FÒê|ݸo<ò-w¼qgË&•Ú¾Tפ l¨.'ùù¥âîÄ«—ºáBÑèqÑ*zÑ6 ¹ð¶ìB»ÔïpÁ} +Û»ƒ“–Sÿ† ¬WسR,„*'Í/åª2¿ÑòÈsÚðó-]ž—~†9Ï#Õ^v¼ÿÓV:0ùXð1›±X,øXT²Õ ’—,&-Ä‚ÙbÁÇbÁlñ!ØÚ¦ô!N^F*yEuCXÒaÔ´T²ØþÕk¼¶¡1OÌ鎟æªúý_µL¶-|™ÿþfåÎY÷ÑÖàÆ­•SµTÏ©bÛ¡Øñ&¿Jó(§Zi¸M9³þêN€ÓÖ¯dGT7îS@ Ø?Ÿ„<J‰ë7$&çö§i´®wú!‚<{†€ä\*DÍf$ÒqÉ Õ iQó ç’˜nlCt=V<ëpR©y‚‚i“ʾÐ:å>rºÅèd·^Rªƒß–¥ÎM7ñî­ïsÇw6”¦õ=«ÚöÜ ï<”ãJêÈ»žä~¨úÞïô ê¾ubðÙô2[ncì5õ 6؈ˆ©CúO/³µÛS<ØÙÍãAÕ*Ï/§ŒaY ʉfp¤¡Fe˜óÕg©khã©f¨¬IkÌ-~ä«­ Œª‹ÑxO¿=ÿó²#N-Ì,(·“Ï¥P÷Ž{x3õuîÛÔ¿èZ{1|u©ÖÑ8¼h¬,õm˜žGŠ'œÖ®ï*•K Ǫ»`ÖG+Ø:€¡† |¾(¨gÂ𸒠âj¥}ï¼÷ò»¬šö±Á œ,¿Pò Ù9Õn.ÿ„7ÑÉZú:³K?ØÎw»²S8–]þe ¿•ý©I¤Ÿ8ƒ+Tg&Çް÷ïlþóOþJPh9è>Þœ=€†Zö)5ˆ¬Iêúm$\C£¢yDº·§è£~]QÒÅãàâø.µ;Oö…rãçºÇÎÁM?ñá'¿aï3ñ]-¨®‚‹‰ZwiKÊâ]¤]_ŸºE{¥ƵÝÆïc^c¦ï(ºþrêYÀCÎñ ôˆº-ëÚËÖ¸ºÞ†"‘ZˆK~ÄI9U㨄rõCøô¯oølÂÓd\߇¦ÆãlX²„m®PúÝu$SŸå™«¦~0߬²sÍðbþ»<ÿÓ²0 XÂòðƒŒmâ`ÆÇŽ wÑ-?——¿51펙þO½†Àp¹ zõc ~ß™4¸nI.ñüÅ«¯ ¨ÏÓ|ÐÇ€üJÖ¶4ìÆð޽Ý&ˆmóža÷åòXs8JvKÛ‘<ûÓ?ßJ»; œ$¿T–Ér“Ù²ôæ/å¾¹±øêî’‹_k@†9e¨Ö´ót¯îK@سsQ5ÿ3ø)”˜7›3ð¶CËÏ;åÒykçñÀë[Pma4lÙŽÎgÔ€4³9ɶŸÀ^…~Õ-ô[>—Ñ,!¼Ž?&TTUÅëqãÈËÃ:ˆçÞNs eðÇ;3x}K·>ÿ Ý,žâÀ¯é ¥/aÒ‹ðØš3`ĉÛî,Þ¡|: ¦Ï‡ïòÛ¡¾ÜÑÄTÜ£óDÝÄܹÁ¼þÊ»<¹È‰-Ð5/·ÿ<=ç>:Y öôÌ +Ø9˜yQ*š\ $Ä¥CKá»qðÞA>#ÎLŠ1€¿S·Ž¾—ÿ›¹“ŒÌysK?ŽCCÁ§Nnxö)»*Dn«y¶Õ¡ÕÜ{\äÆçñ¯Ãxüæ'Xÿ:9??#)‡N0õ³£¬Ë-¾ – 3&g0šVpžrŸÈàùïL¼òðLùá0szkåðMõÝ? nwhöõÃßß…xqù`V (hhŠ ³®¡i‡LF º†V8\¬øGѺ¹ÎÁ¯¦óê¾.ŒŸ×ƒË‰æñàňѨâu*4½ëÿèôØ»|»·5w·ð9I~Ñ0™.ÏÈÅþXqã°P¿ãþóò]tóÍ%·øš´š‘a.È+é á`‘ï@Óõ3jøcº\MS—·ÂÃV*ãwÅh¾èHX°ÝãÂåtàpœ ÕYõÏ¥Z/ç‰ßñhz2Iù¨Š“ÉŒÙbÅ/ ˆ ›F^fn½`äè²ëä¥ÇºÐDÉÂî*ù;JÝîŒ|¸-¡MÚЩu$fgÙÙŽ2·'RiÁ÷DñäçËé3fQEw™qÙqGôeô«×3ÆEz–s@uü5²R2qê çmç‹E'¸öÙ¾{ÝxBT –€pêGúb­¤ÅSü‰nsm ù¸\n´èfDw¿•ØÓ>¸ÅLýÞÿÇKWÜKî‰ ìº/uêâ##ÔÿlÜG¯ÙQ1#!É Ò°XÍÔ±‚3ÏK¦§ügVYúÕn––¬JJáþy)²TÏwVø/¿gì„E$¡¡bŸ‚îÞËû£§òcºšè[nÇVzz†êÆé4Þá&&õïHÓƒïóŸ©¿‘ާO®TÐu—Þš{GßÉÁ€‚齕ç ½ÆýÈ O&™v^£/¡a!XÔ>X0XlX4'.ƒAþFÜN ?3Î]Nf´úaöæã,m>Y~Q F E×Q5µâ5 ç)Ü/§ÊFi¤ZÇ‘‘\!ûÇÊ/5,Üæî²ã!„¨]4ù–VH6ç:TKoL!Dm#ç>!û‡8¡ZzëB!jYh’‘H!ÙHœûP- ‹BˆÚšäÜ'dÿç0T[,¼^/F£QJ©RU/‹„¢V ²‘çu£ÍRµ10«"‚OþÔ%ÉF’N•NªëÖ$>þaau±Z%\Õ&N§‹ôô6l"…!„¨U†öhÌû¿îŃÁâ+R‹hî|Ü ÜÑ¿%’ÄÙd£“†ê† ‘žžÆÎ[ÉÏÏ—Ò¬E|}ýhÞ¼ 6’ÂBÔ*_×=…ï~_MjfŽH-R74€ÛúvàáëÚ"ÙHœM6:écÊ…B!„Uc"B!„BBµB!„•IUU)!„B!þI¨v8R B!„Bü“P““-¥ „B!Ä? Õ?ÿü£”‚B!„ÿ€rüø1¹¥žB!„ÿ€ÜýC!„B ÕB!„BH¨B!„BBµB!„ª…B!„gÍTô¶lÙ,¥!Ä% S§.e~–cW!„¸øçeÓ©NÖBˆêådZŽ]!„ââž—eú‡B!„ÿ„j!„B!$T !„Bqq™ªûÔt…ã4Öt‘ç•5^¨Ÿ‰ÞÍl\ßÊ€AÑ¥@.¢´´TRSSp¹\R¢Æóñ±Axx„†51Tÿ¸G#.Å#5U‹4òËåHž­~÷ `fhkEvˆ‹¨N'={öÆjµJÔ©©)DDÔ­µïÁét²k×ÒÒÒ—Bˆšª×pðÜHZGÚ¤ÆäÄVãßÃî£fþ|ŒÕ¼ mí+;ÄEÛRéÙó Ô¢Ö°Z­´kמ?þX'¡Zˆšª‹¦|H µEÛ(›Luª\.§jQ ƒµ —Ë)!ÄY …B!„P-„B!„„j!„B!.i&)‚šgÈËûªõû[üx ©$!„BÔ(2R-„B!„„j!ÄùàÉ:J|ºƒòŸQ39x‰vÚ-èdmùžË!NBQÓzú‡î!7;Å/?sÙ‡P¨Îì3VŒRŽÕ˜‚ÍÇ^‡úO–©ÈâcÄxšuª²Œ8´D~š÷+ÓËF_% +<ÅÊÿ.b¹»öÂzóèSƒˆ1x9ðí4fzá½QmK5nv|1…—ŒOò§î•»÷òÕüYbí…'>„’ÄHTìM ií‡r’0nßþóÿjÀÝ#c‰0–ý;7›<üö7—Y_ÏßÇ·ï­"pø=ô¯o–}àœRqdÛñÚ‚°Îá:g³]!„¸$Cu6k_~‚|æíÑ= *:ƒ©‰|=a +Ú?Ï«#[H¨®ŽŒfºw gd{?êt0ê¤%f³à÷lÌÑ«¾Lµ çá42jh&…ŒÄ,æÿ~‚­yg²Œ8¿¡:Ÿcûã7dwµ1æì%Ì|?»ÇÊ¡½*—Ox€î~‹{ÿþ‚I‹“§Qøý•Jzj¡-BËg×.Vn0sŸ–˜ñ’¶}[-WÒ¿B@v²ç‹·Yj¹š»5§è6ž£ëølÑ1zv¸™“=+RM^ʬ7öÒsòMå5àÝLJOãmÿ}ó~Ú–jÁßæ 쳚gf~HØŒûéè/O£üçòØùÁh™¼N+&§Fä52ïµçèeüëœÍv…¢z;õЀ!Œ~÷ §Þ¦Où"®è \+?曌^O7QYøõAnyë·¼›Ä·.ž¹>”æÆª.SQP³žïe毥‡¹sþ!ÀçŽÆ^JcÕ—©éú B¿ÁC.v²&3q»vDZkw»§SüH-—¤½qÅ¿û;1‹‚/t²þüç§Lç“NŽ­z›IS¦1}ÑTtrÿZÉŸþ½¸ª¹ 0 &oà7qÐSö羚{‹?h ¸ûF®èØN;pyŒ—ík6ô†Eç’’šJJjYŽR£éZËæƒvÃ(W®¼ûÖ±ÞÖ“Þ>›Xµ×Sî· þ—ßÅŸHë IDAT¨Öñú—{pKCðé¤}û CÆìcЧ{IK9FÚ±uL¬³ÛnœÁ6÷Ù®s6Û==»ÝŽÝn¯õµV=Ú!$TWÊÔ`ÿ¤°ôÃ_HÒ€ü|úù^ÚÞ}e$¨ZR|üÚZá·•©¬ÎÐÐÍåbÙïi¬³qm¥JËTܰ™«;ú“±5•¯ŽªxÝëaÍš4ÖûsCŒ¡jˈ Æd¶b³ú`³ú`µ˜Jxň¥ðu›Õ«ÙX8r¬àÛ¸;×ök‚¯'ŠîCÓ=0™]Éyèz&kÙB½k®¦iaǬ^ÿ»¢/áýi…s¬½¤®‹çæ­$ÍhgýÛ/0fü$ƌˣãÞe‹@îúL?‰1ãÇóèƒ1gMNñ¼mï%|“Љ›¯®[Iãä!ní&|{ÞÌ-±V6¬Š«$8Û¸|øµ­øŽÕYºìÿ¨Ov˜ç}OÔSo0æŠÌ€âÛŒ[çÍfXòë¼ükÞÙ­s6Û=] ÎÉaÚ¬YLyq:YYYRwBˆêªÁ‡6·Ž¤Wêw|°î}Ìê°›¹ÿÊr_ {wñÎ#0ñçÔ*\À$Îk¨ö3apsøD¹Páv²;Ý@Ó Æ*,Saç0[iæe[‚§l»üuÌ@«( Æ*,#à¾PŒÕoJ‹æÍ þ5Á§x'ñ¥n“æ%¿«X\ß–ˆVt®g"ß·5}úv¦Y‚¯9=+¿â‡6‚s7ðùGïñò¼™ŒŸð+ÓòÙòÍÄy@Ïýƒ·ßúá×<Ë»óßâƒùoñÁ›c\7”«Ÿ~­àçùoñÁÛ³Ѻô 4/û×®ÇÙ¥'—UötpO«6ÚˆíCÓ]±m^ËÎJF5 =¸¢þ.VýUÖÏwûtLj‘<1ú™SŽ”Úív=š;FŒ¼4vŸÜ ¬ÝÙ~ý›–âЇA±N6¬ù»â±\•uÎf»§ Ô3g’˜˜ÄÑcǘ:c¦k!ÄÅȪRHóïÌÈ5ãá“9ì2qÝ”ADWH\^ò³³ÈqÊi›îÒÈÁD¨/”|ß(F‚m þVJ–1@™bð3SGñ°©Â|k´•Ð@¦*,£"7H¿@;VÍg;J¾uhÚ¥#¡>uiß5ˆÃ?~ÁáÂ×µ¬Ã¸ô¨¢ŸÈÜGZ“¾43ºÙr<‹°VùlXyœð®­ðÏÍÀJ£vÍévM="ÃÝü>k6_¬Æ”kbyâµÎYø32سÇPœ´2<^܉û‰+¾ -›ãy¥ö-“={3i4 Y¥û‡{÷:þôëÆ”Œzzئ³z§‹Î}Ê¥êZ´ä«=‡P¯éP¸­óÛ>ED„“’šÊ´™³˜0v õ´™³HMM£nDÄ%±û¨GHÒ¢¹¶Aùi8Vb…q4> •®eêª*ë¸Ïb»§ê¨L›9‹Ä¤$DG˜”ÄôÙs*­!„¸è¡ ÔéÞ›vïÌcC½;¸ªi%WÖö+xÃå>};Kåç±15Œºøó믹dè áÍB¡ &éhUX¦|,VL t\•ä·WC1*˜«°Œð9‡Ÿ·ªó[²ø¼•ùÉÞCù×Ïç{¨Ø¶ÑáÖgx²Á.–lHÄ¥¸Ù¾2ß–mi `¦}ß+h¼÷5îz§hÊeÛ–CD·{˜-ž}G‚hrãUŒБÌ|•Š“*tzßû½›¡`$ @AWUò÷ÿÎÂ/ ¯„ÔóHÊÉÃûûW|º¹(ä{HMÕ/Õé¤fÚµVr£‹ík6ãßm èÕÍÆókvâèÜ[¹ö*,,„ü­'pè œÿöiêäÉÅ£¥S^œÎÄqc .~…S“’ˆŠŒdâsã.vÄ™¾Öòµ¡`µÙМÜåŽåª¬ã:‹íV¨Ë•ëscžÅ`0œ´.äq_ëÛ!$TŸŠ‡ýßËÎF½è”º”ÏÿÄØ+‚ÊžøB£¢¤D«ÅÙÐÃâå©´¸¾¯Ýéà¯ã^”+ÍŒv¥hD;4ôª,S~³ªŽK%ZŒ ºªã­Â22J}i*·“£ýÄJµ;7u çØ†ïØd»š¡*L‡Ðs·²n—ƒð]p[­¹¯ Ľÿ,c—«„”­A-?‹ì¦÷ñáÔNů9nÂzßÏ”‘Í Fª½{™ÿÈœ#žã±Ë ××2øqâÃl(^KÅë5b¬ìbVçNVoÖ‰¹Óɾ={ –oˆþë¶9ºk+×Ç7ASK¦œçö)0 € cǺ©3f2qÜX FcñkE:8(è’Øm>8q¸Šz&%(§Ó‰ÁjÅ|ëXÎb»•ê“”keõp>ƒµBœQ¨ÖŽ.åÅ C§=ÎÀ3xø£/ÙÑùß\n“¬®¼™væ|šGÃH lo?Áëé&n¹32 æ;kUX¦Ì~ç%C7ᯀC/3ÂT'ÀDV®ožá´Ë„ŸãÏZF`Ê¿‡¢Q¢‹ÿÞt4ÿ&\Ñ·SW°QíÄÕW7&.ágâ‚»pÍ•1X+$£:4íw?ƒbþæÕWÄÛw—ùÀ>B¯Í¶+Õph¤ü0žQ–þ“N²²]èÆ¶mË+è|«I¤¸Üxì`‹V8V¬çXzš!€ ‰yg=ço_ËF—…ˆåòNÉ^Ž7•U[ó‰íé[fù\{ÿ|/àµÔL3¦x:ÂôÙsЧ&\jÓŒ‘ÑD)É$$©VúTá&9!º ¢*ÜNµ*ëX"óÎx»åMœ2…ÔÔ´J˵|=Lž6—çν ǽ´=BH¨>Í99ƒ•~CJÏÇÞÄ‚_ûºx<ï|ß—ïh\j*î|'ªÅ†Í$@ªU%>)—øÂ-õ‚‰µåóéQ½ÊËŒlF|·Žîv—i¦k´ %ÍS2’m²Ò!Rgß*7^·vÚe¢:IÕ\À€øóyë 2RÈõÿ–9sLäË!Õø1³öûÓæ–±Œ(©ýÛñ¯·C;áG3ëz6îÙÊ޼˨r>U“‰OVЛøyI©×[¶Á´w‹÷½àáX†FHq¨®K£FÖÇG‹)5M#Ÿ­k¶â7p<ÿ»·E©6ÇË®wåù5[ÉíEÉ͈\$&¤Õ¸A©Ï Ó>2a\ÉH)P<5á’›ßÐØV‡Yü{“;4)©ü?øm½™®·µÁLÁƒÀr=f¬ª²N@H•¶{*EsÓOÖQ dÂØ1Lza*)©©Ò !.ÃéF¹ò¶.äÃM¸óöŽø)€©1ÃGô"{Ñ,I)5¢äÝÉ£F2ûG5 XLDÏYTâ±AäoÉ`ƒ«ªË(´èÙOo ¥±Ðݬ؞OýÎ\n(Y{†s¥;›㵪-#.h¿¹éÐg™=áfZ[Ãé÷Ÿ™;óFu"ªßcÌž9…û;Û*f=›õ}ÆÁîñX³Müoþ&²ªXuZò6¶d¶ä¦gže⸱'ÿ7æ7,=&éCûέHݺÔÒ+w«¶úÛ¤Ü(€‰V±]ðݶ–Í¥/xtű9.˜Î"K¸ Ø>MiÐ ú’›òQ†±9w?Ú}sŸàmö‚ró$³tüXÞË£'v¢nÏéìðVq*m÷Ô>ÿèC^š;甕ÀÀ@^š;‡Ï?úPš!Ä:㞊ç _¿¿¿ëgÐ?ÜP¾ü;ÝÆ-çãÖÓ{t/‚åvÕÕï|̤Cˆðªäë 6m9ÊÔ¿\ÅóL«²Ly'âR˜j‹à?Ûp»Ë‹ÇÇ'²yåÇìñV}q9øùå·Øs+/·1C©ÚÕuÕíÆk¶`QÜùq¯ÆuàÉ9ýéfˆÀµH†ü+ù|áߥzã:y{Ò)¹.ÕÉŽŸWp¬õpz„œnDØ‹× F£©øÙA±ƒèùé‡,94˜{›™Ü­kØâךUl®L-zÐÝ6U›s¸òª@t2Ö-ecÝþ̽ˆO*š‚Pî.Õ1—úw/àûôÿcT¿¦Gà“™ŠÞþæ?•Xß³]çl¶+„—z¨67cä« ©pWUC8C¦|F™k‹Mx⓯¥D« ïñt};ƒ _#VE#;OÅ©é2:{ÖfØšÒ¯©ìÙrŒ‡·õ7bt{Iw–¿SHU–©ÙªÏ|Fü„-ìô¹–I÷§ž¡0¼6hG#ëfÝά:ЦÖ õ ·ém&|cäŽþM÷ èÀ°¼ìx ÐT4M-³}U/©Y=w¿lPèÿÔ•„*Ò{>›Àì5ùX R†0øÞR÷y°uà_w.eôûKè?åz¢M þ½ÇðuQíxdÁg¥þþ>ú2•~O ¤¾áâ¶O5âvnJ±O}ÉÎÇìKNÇIt[©N•™Ø9ûqÎ9“uª¸Œ¸ÄÛ!$T‹šDÓÈÎÕÈþ§Ëœd½ »öÏ—çéÈn­Sf¢›ðµcìèÒ¿4Òôú'y  ïçôòxÐ3–¹ÆzëaL™]¦uÍeÖi4ðQÆlJ§Æe¦‹¸Žw¤SF(Pü{ðä«mP¬'mršß8ŽÙý¸<:æÀ0ÂËÜMÄ@øÕóðž)Ìý¸1ÓîiG•Üê=Ê//DêµOñp+ÙÎ%s ‘Ïý:g³]!„P-„¸€)ˆ z‘UX΀É\6€*þ hê_~9…ÀÆè\É|굦{½’Ÿ-§¡5Ú‚³bޱL÷‡fÐâ„£U¾BR¤Ëƒ/rMÿÓ^è&„BH¨BÔ|+!áÖ3ìGøVGŠN!„„jqŽ,~¼…‚B!Ä$×…!„B!¡Z!„B ÕB!„BH¨B!„BBu5êg"ÔÏÄ-Q+ìNvêg¢Ž¿\G|1ùøXq:R¢Vq:X­V)!ÎBµ?k÷ifc÷q3>FFž<ãº6hä—Ë‘¼ìZûBýLÔñ3Ñ.Jî¶|1EDÔe×®´k׫Õ&"jE Þµku¥0„¨‰¡úºVÀÌê¨k‹#yþµú=( ´‹23¤¥jÕÃÝ«—ððpÒÒÒøãu¸\2b-j>«ÕJDD]ÂÂÂ¥0„¨‰¡Ú è m­0´µ¯Ô–¨e$PW‡`.C!D2«B!„ª…B!„P-„B!„„j!„B!$T !„B!$T !„B!¡Z!„BˆKÓ%ñä´´TRSSp¹\Rc¢Æóñ±Axx„†´=BHÛ#„„êswRs:ôìÙ«Õ*5V ¤¦¦\ôÇä^Ì÷àt:Ùµkiiiòài{„´=Òöq‰¨öÓ?RSSi×î29©‰ZÃjµÒ®]{RSS¤0¤íBÚ!$TŸ.—SNj¢žÜl¸\N)i{„¶G ÕB!„BH¨B!„BH¨B!„BBµB!„ª…B!„P-„gE'kË÷,X~ytŠBˆšî”Q9Ø]F‚|+.¨»ÉÍv øág–‚¼h¼¹¤Ÿðà‚M9E]ægpÂi%,Ô·’ž”†3;5ˆŸªö³TÙv¼¶ ,†°Œ8?42w.cñÎLô*ö¯CÚäÚöÁºO¾ÙB¦Vøÿö ¿»7õ‹ªPóoÏ"ãD*G““‰?¼Ÿ¿÷æÓáá§¹!ºT=»÷òÕüYbí…'>„’ÝÓHTìM ií‡r’0nßþóÿjÀÝ#c‰0–ý;7›<üö7—Y_ÏßÇ·ï­"pø=ô¯_»%Wv*Y­BÝ+_B"±T8TdÛÝX±™”st,K!„¨]NÙŠéÉ‹ÿÀ3¼·ÛUá„}bÅ\î}|Ûº”âÅÊÓG—ñ\߯ÔmxŸ¦¢1íÊÄÜø.IZÉËy[ðØõ¨àKHt áAa´¹a ¿ÓNñWóØùÁCôiFd‹64¤ýð©üzT=ÃeÄù¥“¹s) WÆáöà.ú—³Ÿ_¿ú=9¥^s;9´ú+ïÌBŸ:4n֌͚ÑÌ?…u«öž²Œ‰#îbø-·1dØ-Ü8âžœþ6Ÿþ¸ˆ/¾ÛKÀUèR:Œ9ÙóÅÛ,µ\Í]ƒÚS¿> ê×§žr„?¬åCád}@5y)³ÞØK«AÝÊjÀ»Ÿ¾;žüˆ¿½å£osöQøvæ‡lÍ­Íí’›ÕzÑ®]»2ÿZ6®OTÛ'Yî.UÖÇW2û®nÔ®Cæ1„Ôá²±«ñü£cYÚ!„„ê LM‡ñ`%-)ÆÈßÁ§ŸÇÑò®¨H)^„À”µñ ïu/«£»ÒØÈ)Opë_x€W÷*¶‘,À¡óXq8“¼œìG¾çΜ׸í÷ËÖw©uÒ¾}!cö1èÓ½¤¥#íØ:&ÖYÈm7Î`›»ªËÔ|ý¡ßà!ý}öáž{Fpá¿ûnëA´)Š+n»»øµû﹋¾ Kv"%¨9½û`ðÀ ìÖ°àÍEž£÷½ò&ŽéKh㛘=ÿþ÷Ì bÌa´íqÑ~Jq§;}Ý[ÌøAcÀÝ7rEÇtêØËc¼l_s€°¡0,:—”ÔTRRÓÈr”ÚÙ´4–Íÿí†Q Žª¸c{÷­c½­'½}6±j¯§Üoü/¿‹Q­ÿâõ/÷வ탅þ¯î'-=ôôtÒÓÓ8øã“t ŠáÆYÏruÑ0uÞ:&λڽ|{ ‹¬Œlò3ãøâßm ¿™<›cùâµv»»Ý^ëÏÕ¥íBBuVÚß>’Øãßñþš¬Â¯½\ô1«B‡3êšp™”}¨;g3ø†¨7c¿LêC¨áäáÛ¾rÿþª“Ÿì‚¹\ ¿v /þûjZ†Ù0–z}xv­ø­þ™µy•lN;ÌÇó¾'ê©7sEf@ñmÆ­óf3,ùu^þ5¯jˈjÎCö±ŽÄÇ<º®¡+>……ìk*eV ¨¨Å¹ØKêú·xnÞJÒŒvÖ¿ýcÆObÌø±<:î]¶¨ä®_À¤ñ“3~<>øsÖäOSðXÂ7 ¸ù꺕´-âÖn·çÍÜkeê¸J‚³Ë‡_KЊïX%ߢNæÚç2ì]"fü§÷µÄ§°ãsxÁx^×áó÷¢{Ý‚¤­XëÒºiXAýžÍ±|‘Ú{NÓfÍbÊ‹ÓÉÊÊ’jBTÇP J`7);>ûšNÐÒV°`±‡kïBLé$ï.Þyä&þœŠ&åz~™ÚòäÏ«yûöfXOñEžù+cú™ž¯ÌcXDÕº?Š‹¢ T¶ÝÜ ¬ÝÙ~ý›Rf 1 ƒblXó7Þª,#5XÍ{mGøzÊÓ<3ý%æ-Š'¸a8¾º†f0Vh0£^<Þ‚«çþÁÛoý-*€ðkžåÝùoñÁü·øàÍ1 ®ÊÕO¿Vðóü·øàíYŒh]új /û×®ÇÙ¥'—UötpO«6ÚˆíCÓ]±m^ËÎJF5 =¸¢þ.VýUÖÏwûtLj‘<1ú™SŽ”Úív=š;FŒ¼`úÄÊñ\{ã'DÏYÆ'÷¶( Ô€v”%ßýE»»ïár5™í«—±dÙZvw””ÙÙË¡°çä0mæL“8zìSgÌ”`-„¨ž¡ D\s/·®ä½ãXÿÙ—$õ¸‡Û[”¿ÔÅK~v9N™w¾[_Ç­ƒ8åÄ=ŸF?ÂÊ~¯3{pª6IÇKÜoËIëԇd­£ $iÑ4jPþky+1Â8Ÿ„» ËÈráè.;©©©…S-RII·ãÂ=½Ôk©id•¾lBÏ#ׯ€'çðúKóxmò0š©nàÃWžbpËfô›²ŠzÕŽwõ"·v»i3 uƒèhDGsôØ1¦Ïž#SA„œ©j)®ÃîÀoÏ¿ÀKþóRGü” I³_Á(SBªA”âø7OðĦ¡¼¿®ÁŠFnÖRã?büÙܺànVR‰º3'6|+ +Xm64§W–qCɈÙ9PÕùƒ¿-Y|ÞJüdï¡üëçó=TÚMÚµ±c¿-ûbü8}yØsµÂ>º™€]UÉßÿ; ¿ð+êI9yxÿŠO7mÄCjªFxñI'5ÓFx¨µ’N ‹ík6ãßmBá¾Ùˆ^Ýl<¿f'ŽÎ]°• !ë :(ç¿}š:yrñhé”§3qÜX‚ƒƒ ‚_áԄĤ$¢"#™øÜ¸ R÷Šî™þ?†äeÿÇÜ7f ç­àÛQ-1{Nž™Îê?YüÇ6®¬SP*¹[fr]ÿñLç]¼}æÇò…l#Ê—ëscžÅ`0œ´.äq/mªOÉÒò:®oú#_5JŸÐJÆ=B£¢¤D«-é3{æonÿümúT1†Û×3õޱ¾í>¸6¤Ò‘mÅdžN®¢¤RâN'«K–‘;0^8æÎ£X0·P+ÃÍêwóyÑþ“E¦'‰fŽf•Ìíîâ…ËsÈõ «Ø™VB ²s,³ì¤ §ÓMXïû™2²yÁWüÞ½ÌdÎÏñØe…ÍŽ–ÁfCI·¯×ˆ±² o;Y½Y'æN'ûöì-X:¼!ú¯kØæèB¬­\ßdM-™FpžÛ§À€&Œ[è¦Î˜ÉÄqc1ůêà   ªÃ{pçÃ= ÏSïßH‡ñÿeňw¨zQ•†ŸX¨ü;=ÎØ_fäwëñŽ>ócùBµ¥§|”/×Êêá|k!„8ãP &,&“Ù„Üï£:sñÛ Oó£±÷,Ï ^ÍÝq×Áï˜òäaêvÿ7SïlS<ŸQÏÚÀŒá7ñqÌYößÔ9I#£‰R’IHR!ÌT&”%'¤Q·A–ȼÓ.c<ÇŸ¸:ŒÀ”E£D—âè–™N–_Gî|âü—Ìâ¥,ùi鸃[Rœ¿4²6¼Çôã]è\Oc˱t4¢ Fu'YÙ.tcÛ¶å´j).7ž;Ø¢nDÏ!1§ÔôCAþó*ÎzÎß¾–. Ë?äâW½øxSYµ5ŸØžeç+åÚó0øà{«À€&Œô™£§ÓgÏ 1©`j„±c ¼Hµj$êÊ«h•³„#Y:„†êH`òãÁf"ê…’—…V…ãÝx‘Úˆ‰S¦ššVi¹–¯‡ÉÓ¦ñòܹ丗¶G Õ爊;߉j±a3É‹Y¥M†?ÏÜ˼eF€²ŽÙ0$†Ñ¨Y3"ë–k ‘³JýÊr¯XΣ ʯc þÝ ø>ýÿÕ/†iÁød¦¢·¿‡ùßO%Ö·ªËˆ‹ÏEò®m$:-˜•v×1ÝÑGóàp+X-é$§@HXkSÓÝ»‚÷ß8Lü¾d%ºyï³Ëhãd{N Ý|¾dù_ytéidÇÏ+8Öz8=BN]½x½`4M)SŠDÏO?dÉ¡ÁÜÛÌTÐùÛº†-~Ýx¡YÅæÊÔ¢ÝmÓYµ9‡+¯ DA'cÝR6ÖíÏÜ&Æ‹VºESŠÂÝ…æIü™qÃG0Ü@X JV–•ö·Oçû—†¬”uøðëÌÞ IDAT7ø6ùAFÝØ„ÿúÔ!Ày‚Üð¾<±ð+žn[PÖg~,K!„¨ÅSÇÓ¶lÙL§N]ªÝܲe3ƒ_'5UÝxìKNÇIt[å#UY¦©©)DDÔ½¨¯:¼‡%K~ªpLVvœV~ìj$ýð"ÓŽ^Ë«v®øuºžË¦Ï^cÑ>†Ñ/š¾#îÿöî;:ªjoãøwZ2“Lz#$ ”P¤7©RPDŠõ‚Нz±£ˆ¢Ü«Ø+ˆØhb! —„"5’:“içýƒ–„$$ßg-–ËÉÙgÎì=³ç9{öÙ‡áZ”œ_xþ‘ÿ°Õ ècv¯›öÇñXÇ,¶ô¢vD$õÔ%ĨÁºóCÆ}Áã±ÛøÉýAþ¯ýQf>öÆI³y,N_nNþòyfüU„‹ÚDFš–ÞÓçòHŒöüqgþö“åµ—úv•§ýJÁVæL^„ÇÄ7y8Ƶf÷=Ùiéd[\ð Å÷R‹ÚÛ 8™šÉÅŸÐ`Ïò§^\Ëg¹ûˆ[ùs_]û!Ä¥¿+Î}^d¤Z\'Á‘ž×¿¨$j¼À/y:mä¶áS¹­¼?ùôäµo{`·Zq¨]Ði ³V«¦qÙ&núóãT¨”žÄ©T¨æÉ¹°{è/ñÄZê |–ÝM[tžþxhKw@×ñŒO~‰™‹¢xõÁ&%æJ_-Õs’Ñgãc\å- 6àVß+m§5a¬øÏ²ôBˆFBµ¢¼hFçrö65ÚKõ*Õ™©çþ ¸\aºƒÆà…¿á2sŒUÞ´7úYf4 8½ÜâI˱¯ÑÍÏ(à !„P-„¨õø诮ŒÎˆ¿ŸTBˆ*úê’*B!„BBµB!„ª…B!„P-„B!„„j!„B!Ä-ª]]õ˜Ífi)Q£˜Í&ôz½T„ô=BHß#„„êŠDRR"f³IZKÔ˜/µ¤¤Ä*¿«ZM'}¾Gq5ªý:Õdff’°âb5·>½^O``þþRÒ÷!}ª+öË- @>äBé{„BTOr¡¢B!„ª…B!„P-„B!„„j!„B!$T !„B!$T !„B!¡Z!„Bˆ›ÔM±Nuff')..–·^‹ç éª“7…B ÕBˆ«c2áâ⊢(N—ùà£Yøù<ÚM|6P“0g,oü‘ÚÝ7­¢B~1¹û¡ÜQו[=zuZÇ”7à?ýašUòÆB!¡Zquç°¢(Ì÷¾ùvé¥7ÒøÝ4Ÿ_>]ÁÞb'‚ºÚƒ¸ÃñÕxÓ¾+Ñn{Y¸Å“Ö]»}ªˆÕ_Ò¤sWn7ÚIüër/$“_æ/Åqçkô97­`.("dÈ[¼?, à0¥³yñ»Ìü÷l´ï>K?5ƸáŒi8‰÷·gÞ¨†¸ÈÛB!„„j!ÄÕ(;J½>a#íÚ´.u¢¢(Ì~ï}–.ûÞ‰”~’¿îD¹]ü/3êëHaÕ~fWûûèªÆ‘ús?I óôQò2uü÷•#¸Y38jÉeÙŒ×ØÒb0½.󴶃+Yz¬9ã¦]´|‘Š Ç¡6ÓfäXîÚú4¿þ}šî}|Qa nP¼&/cÝ º{ËhµB ÕBˆ« ÕFª?Y°ˆO.¢Ï=yæ©I¨ÕjEaÎ{óXúýç·9|`»ôNUZ<ükr™ÕAìE¸©/„W•wCºõñ&5áviÛ0¸c\NoâäÞÃÄ÷ìC«° Té—ŒÔX¿sËGiêÌ¢@*?ý °°_T€:° B¿bíÖ|ºuóDbµBˆª›“¹: nzt%¿?+¹E¨Ü=qוþz²›óɳêðôУ‘º®:v¹y\<<1h/!lœÊ²âèƒÁ©”aÇ”›‡Íà…‡‹ú:¶7ŠÃqf¤z}ÂF>]¸€«~TLž8wÞ}ŸV¬8¿ýýÇ1þÑ1ÌŸ?ï2Ã)6}õ‡\¯ðäÁõhç~æ¥r¡IswN¬Ì%¼åí´m'SñМ"*¾ÍŒþ i@*@Q@Qƒvä¼/‡ÈžÑNu^Jánvr%¢·ÿ…Qmµõë{²$ùönñ2² „âF„j3ÞÃôµf\=¸*f Ì.„Ävâžûï£k¤•’Ëú9ùÌm<Ln‡×¹@f?ηÏ?Ãï±/2÷úª«"KŸø“·Ÿzš9?&Q¨ÓQlÒPoÂ÷l}£%×>°¥ý¿ïΛÿkÁÇV2:ðr©º]ŸMæ±i_“hÖ£5;îö8³Þû?zœŸßêÌ6âF;7ý£cûv è×—^~6X¯&q×.RRÓÎo;|轌ófóåÖÊVP0ÝævÚ”œþ¡ò£n¤ƒÃ‡s(9‹[•BQÜT ‰Kø:)‚~£CP¥g{k¨;àq­ÿ•ŸVìÂþO2…n­pSŽSdäðÕ—;Â\˜–ÌŽÝ<]ä¥îáÏeßñ¿ð¡¼Ý¼ä°¶жgaRÀC†ª…BT~¨†â¢b‡Ìà½a‘h{Áq6.~w¦ÍÃåÝItôò§û¨A¬zê ¾ÙÛ‚1\Y.biv{¦ ®'U… ¼Ð{߯¼Æw¦u Šù$É©š®pzólî¿w&Ùmn#jÛ•.dSÈün,}ŸIcìÒ}üÖ!mÑA–L¸“{ªøý¯ç‰wqf›[¿ú»÷î À¯+—W£P}¦}ívÏNy Nw~îtÉ@=pÀ;³ù 7‰±™1ÛdåHáÙq`óþú LnMÎ?i =såHý?ŸîNøY÷óÍGö"}k)§2„Óºí6VL›‡þ…ñtòkA&ÇaS7æÞ‘]‰Ò6;6›M¹çfòüÉâìuXZܼƒ¨×ûYæukL@™žN£Õ€Ã~¹‰-B!Dņê²4Æp:Ü?’ë_gÃÛêІ÷å‘;~ç…«é3}aæD¾øjG¾C Y¶ª 88üÉs¼¯<ÆïŸŽ£ÅÙA:•>ˆ†u/leß5ƒÞw~Iì;kù*î[nÿùÏ+ìö0‹f}OȤ-<Ó!ð̯nÑ ™5ƒU G3gÍ“|Úûä•·éë.MT%¡úÂ…Š&“‰§&<Pê¢Ä»ôgʤ W¡>ûvÈÉ&[Esß¶e¶ã_cºSDz†#$à^¯>¦e¿Öi<õ©~ã)V}w¶ Kœ1‹ŒìBN¤¤œ}П¶=¢YÿâO%ªÜ›ôàÎ& Òxìufú†Ú/£‰ã…媩Õy,¯Ÿ¸œ‚¼BÔF3£ßB!DU„ê’Euçç¸ÒhÈ´bŸmhÏ})‹Xç7³;û–¾:ߖćfs¼ïë¼Ô'™e[Y™:•˶ÒdäÇÄÙSÙ¹n7if7›¶ q-Ã…ŸÍµyrÅ:îiæ…#Ù‰ýlbý®º¿[·thñèÄmÍLûk¶Ž®¼MßÛdk‡êsÁzÒ¿.ëýú2yâ§ocn9z˜T¿H»§qKç±hyµ±¡*m]F<÷(Kç}Å’ñô3—~nî+f/`›µÄƒö>žØÆév{L¦¢%T¥V )L“¶$áÒèQŒÇÿá€Ý‚?ç0×ÑpXr8|<•bw ófãz»G™ž'Ž‡ßšÅÃ%ÏO-çéq tœö wú_*.»Û"†9«w’1¤6µ®%UïeË^oZ –{!„72T;Hÿý}žÝ­ÇQœÇ‰”Œñ}™üÊ`â %·Sã׺#M>œÅ¦Z÷Ñ¥n9c@š†Ü?ã]lžòeV™¬YœÊ9ź¿=Yž°ƒÎ~gj»`Ûôë1‚)-’ø¸Ÿ×U/%¦˜‹0cÀM_¶¤ ½Á€Ãl¢Ø‰m,€k¾Üs󗯤2ç7_êÊ>^Us¬õzééé„„„¢Õ–þØÛl6ºwí‚Õj-õ7›ÍFzz:ƒáâ^!k=?lÔÓyL_|¶Ïø–Œ|q,M\þàÿ¾=HæÚ¬ûÇƒæ· dÚ¨¦lŸÁ’mçvœGÚñ3 –zådav˜9uôÿä•yÿ¨ô„ã©UáÕöÚ}±€•‡zóPôÕžž)doXÅæ ̬#Í !„¸¡¡ZOloFt¯…£(ƒí?.d{bÊ^ùƒ•ßÇ®Èö4ÏXÅW w0µC™à¦rÅ7$Dj½²ÙmØU>ÜõÜ ç5€±ù¦œÃË6bíwÇU_@ªr5àŠSqÙ%Ìf3j½'¶‘ŸÜo¼ððÚ$'ïÅl6£Ñ8&ív;GŽ",,⢿™Oœ„¶Ã¹§s{|»ôÁ‘ö3/LÃ+Å6Ôþ]2`4º*ä­}‡ñc߯d¯ÖñTRÈ’÷¿cyW †Ã¶Eï±í¢žª.÷>?žNÞ*0Ä3bØ*&º’/õ'L  §ësßÐõJ‘º` gÐ}b/BåÌ^!Ä Õ ¨CãÆ‘hhDÓ:v=±ˆe}šñ@Ý Åi«øp¹Š¯N ×ÁéŒ_¸˜Ä”Í7„Þ_£'ž~eǃuÖò¥hïi¬pÕ¡ZFˆ*•c)vð/ùÖ±z,“ ð\‚ ¯¸MEV‡6ÊCu[ý#:º>ì#1qÇ•Wõ8Ë`0Ntt½‹þæÖx¯4.qêÒ×ô+{†gçI|Þ¹ÌÃÞ˜0³Ãu¼5]Ç3>ù%f.ŠâÕ›àÔõж4VÏYHFŸIŒq•~B!ÄÕ¥¾ÎüÚsW»¯˜µb'Cžh@ÉæÏK9Ùî ÕqÁ=b$–?LJßwgÎ}Q%žÄŽ¥ÈŒÝÅ€A+ÃD•תM¹­i6Ÿnø{ǘ !VÉeïî4‚£#Ôvs>VzÔ­hs˜åcZ| SxŠøu£ŽÛîm„ÎÃçÊÛH Ýp4hЈˆ(ìvç®iÐh4èõzÜÝ«áj-*oZ›Ný,3œšË¤xÒrìktó3Ê{P!D…»†d«'®gg «ÙpZ ·Í‚Ä: Ú w bÐýíÉýá3Vž,q¡“móÆ<À³?žÄ!u_‰­ÊÝãú‘öö8^ÿ+ãÌZ¼J>{?ŸÄËk1úÁ–N† +›_hNP»×I´šzŒ|¼;ûgNdÞŽ¼3mhMeÕsSùÚó!ïåéÜ6âÆgP• £Ñˆ¿¿?AAANýó÷÷Çh4¢RUÓuçÔz|¼18Û‹éŒøK BQ}B5h£»Ò3tËÿ8Ãúß~º÷þ#épnw*ŒÍïå¾øbáFN+RÑ78B0hß½P‹¥ëàA¸0í^ËfØ×Kxª±öšß.¡#?áû§ô|н6!Ñõ‰¨Õ˜1Û;2ÿûWhëæì6B!„·Xú:q"]ضm Í›·¬v¸mÛz÷î'-u­lœLÍÀäâOh°gÅÒYóHO=…Õ#˜0?CùggÎlSŽŒŒ“UiµU‡cX¹òç‹>“å}N«ëgW!„¸Õ•ü–å‚ouZ#AƊ߯ΓàHÏëßF!„â W !„B!¡Z!„B ÕB!„BH¨B!„BBµB!„BBµB!„UE–Ô¢p8ìÚµ“£Gc2™œ*c0¸EllSÔj9ÿB!nêPíêªÇl6£×륵Da6›*ô=¿kW"EE… :çÖÏÏÏã×_!))‘¦Mã¥Q„BˆË¨öÃOA$%%b6›¤µD ÔII‰zGÇ£GÓ¥K74-………NýÓh´:–Æ‘#‡+íµ:²“X¾ìoR7W92Ö1oæì³]M)…¼‹yû“dØK?n3RPl/½uÑ~–ÎÏšT«|(„â&PíGªÈÌÌ$!aÅÅfi1qËÓëõáïPaû4™ŠpqqEQ§Ë|ðÑÇ,üü 9äòáò?¿“v¹P¬¦Ç¸G¸=ðâsxåÔV–~yÏ~­ sòßqj#´–μU-ºŒ¾ŸŽþ;~`ùg ¿'»ÒøøQ\/Úµ ­1P?=ªÚSWñæ¼}´›6˜@ÍÙv9´Š¹s¾dà •™Bµ nëǘÇúPß­½:­cÊ ðŸþ0ÍŒ*ùp!„„êëÖÒZB\‡Ã¹á`EQ˜;ï?|óíÒ+gV÷ZuîBþ%®õð/|°ò5 ³}sQ#úÐðr3dÌÉüøùNŽÝøWh¤fÏö$Š `þ+Û/~Íù9hnŸÆÂñM/t°ŽL~™¿ǯÑ;äl¢¶bñ¬…¤´~ž…Ãá¥Q°ž>Âæ¿Ž`wœ çÆ¸áŒi8‰÷·gÞ¨†¸ÈÛX!$T !ªVÙQêõ iצu©‹Eaö{ï³tÙ÷NíSåA«.—HñY¬^÷³_²jü‰ëÙ‹ž—½U tlúêhÅ×cÁVmÔ3àÅwy$¦ljåïwâ¿úÒñ×vp%K5gÜÔ  sîLG8x2”ö]cðÒœ Ñ:ï(Ú÷*QÒ@Ü >xM^ƺA1t÷–Ñj!„¨®ä’~!jL¨vœÿ÷ñg ˜úü ¼1s&v» EqàpØ™=÷½Rzäða×øl²×ÂgñÀ}q¸]öÀØí7K-ZØ·ô¶Eö§ýrÆ$”|NeYñöñ*ѹÚ8°~#æ–íhZrd]B¸Ï víÎâ²³gÛÐ!4‰µ[óQäm,„Õ–ŒT QC8g"Ùú„|ºp+Vý¨˜Ô¯ïÉ’äCØ»ÅK§-„ª…UéÜôŽíÛ1 __~üyùÙ`½šÄ]»HIM;¿íð¡÷2nÌ#˜ÍWq°#{3ï¿ú9ÙŸaFg¿+ÿ¦kÎÃÏß~×v¶ýùË>ÌDÜ„ö;Ñ¥sâB+*`Û9¼f>3׿:ªÕxu~’¹£š Yk™53°Ñ¯qwTù]§eïßl)Žáá%þî8EFŽßÒ.‚ Ÿ–c˜ýÖF–~ó=o>þ)nÍîäÑ1ƒ¹-@[ê8üý}(Úž…I™"„ª…UªÏL2°Û<;å)t:Ýù©%õÀxlì˜kZÆÒ–ù7ó^šÅŠôZ ní\Té lЊŽMZÑ÷>°¦³çøsíL_òÔá­9iý"¯7Zki:j6_Œº¶ÒjßÖŒz©!‘Aå‡|G|ÿö6hUj®·›Mƒ¦ÜB*ÜÂÛ1rr;†å`õÇsxí¹žŸõ(-KìC£Õ€ÃNy+ømÛ¶EÞÜBqƒ4oÞRBµª/ŒÏšL&žšð@©9Ôw èÏ”I®a„Z¡`ßÏÌ|ó+Ò›ãå^ Ì}õE4SŸç¡8¯«ºxCãLl—»‰ír7ãò±}ÓaÜü«Áå*a‘†KüÑÊñ•ïóÉžºŒx§Eé9äj¼Œ&Ž^~õW=ú<1–Ãc_gåöûiÙñÂ^ ò Q=pS]]/„¢â\iCBµ50TŸ Ö“þu!Xè×—É'8}óóì§Iúῼ½øµ‡LcæÀx¨:æ>‡ç¦¿ˆuÊ4ƴ𾦫¢µµ¹­Gíê]±¶l¶û.o-ͤõ¤Wè\敪ƒˆ ×°ñè mk_¾4xí¤™l(pvºH1Ç"$*¼…¢Úº)Buff')..–·Nþò¦3âï'U&„7M/U „B!„„j!„B!$T !*–ܺZ!„P-„B!Ä­ª›…¢‚|ò ÌXËÜ`ÍnÎ''·[¹-œÎ¥Ð*]ÕìEÙddQþýñì˜rsÈ·8®fN”¹–ý !„BÜr¡Ú̆wî§ÿÝ#9~cÇbð½2öåOøíˆ PR—óÜè)|¼»ì-Ädý>“‡&|“"5]•L[yµs8µ~DJ©|[È®ÏÆÑ)Ÿàúˆ &vÐ+¬I»Ü’kΔ¹–ý !„Bܲ¡ЋР2ƒÅ ?áËE_²ìÓW¶yÓæ±>WA[÷.Æöp°ráÊÒ­(‘/¾ÚKƒá#hë©’š®2…l|y4s÷•m…ÌïÆÒ÷™ýÜñÅ>2O¦“™¾ü¾æÞÓÙa)o_Δ¹–ýÞzº÷îK÷Þ}åí'„BH¨.ŸÆN‡ûGÒU³• {l€žØ¡ÐöÄ2>ýë4gƤmüóÃ"ÖúbL·™¸]eòþ|žG–4aÚ“-Kß@Âq˜E³¾'dÒ<žéˆP¹E3dÖ îJ}Ÿ9k /Þ3e®e¿B!„5-T_ Ew6¥©<[ñÐðº$~ù-»ÌàÈüO–[éóp_jkJ±%ñác£yaE2ËöDêœ5L·‚vïÎâ®À2M]°‰õ»"èÞ£.%›NÜÑÖ̦¿ö\ 1ží`óAÖ|½‘ ®Ô€¡: 9{6Ĉ…“»þdíÞ<¨ðŽé@צA¸HUC5èêиq$Ñ´ŽCO,bYŸf„?ßþe†ŸÔþy|ÒÔ>ûí©ì᧥lj¾§'ÜJŸH‚[gŸïítŽr)'ýSd¶á¸Ìª£*­+núòúT…¼K˜¿5œ‘´%°ÌK±™)4;p1pÑœ)­íç»×â9èAz„Êé­W‘¨ÉرžÝ¹*ð+ó'««&‚NCo§n9©Ê‘½›„Ã~tÔ“@N±eåCûÓÒ_†¬kd¨.õ…âמ»Ú}Ŭ;òD WUÚŽ¥ÈŒÝÅ€A~ÿ¨´&­3èEf6µ•úò=n@}ÜŸÈèh‚ƒÜQy´¢mÌa–ÿqŒiñu.œ]%ðëF·ÝÛgnîS`Õáá¡GíL§ö+ªžÉT„‹‹+Šâü:òŠ¢àêêŠÉTt… sØüõWoúƒŸí%”\Ö}³‰ú“f2-$ƒ%/|ʺ®ÿÇÞªyxóþó;i—»’YLqpûù‹o R÷’|Â|fõ¡ü-¬>àC£žÙ²µlUãÞˆ˜À³×QDúø÷}žá´gsöJÞø4•<«žCûìÄ=?šÖîg¿V÷|ÿ—Ÿ ÐÁù+R”üýüþóN\îêI£ó/$“5o¾Î¶ŽÏ28í7æ.Ê"xÆ0Ê^fbK\Èã³ÖSX^Ø É-´¢nø0¿1€à2]¦=uoÎÛG»iƒKj…‚~eÁgßñ{Ò)®Z¬Å ^õòüë÷ÒЭ½:­cÊ ðŸþ0ÍŒ2ü!„=–ô-¬=äC‹Æ.üïD™¿Z¬Ø4:\.kÌf,µðÖxáëa#µXjUB5zâzvÆ0m5F6§»÷Utʶ]Ìó*GÍeÖ `™W])4Dß1–ÇKŸ'“¢ZÆ›':òÀcas0òñî¼óìDæÝþ9ãã=Q[SYõÜT¾ö|ˆ½<+›_hÎí«îcÓö—‰×Ö»rщýŠêÂá¸úuxœ áöþ^½ K½G.<¦ÒbÐ[ÉÎ6ãðÉ&ÛâJ`™HåA«Î]È¿ÄSXÿÂ+OÐQSzDøtòZ–oÌAÁF澜 jBà†Õ\ü;šðî4t)1òë çx2IÊ™dªdÂLàÙ?²o/îg/p¤œÆNèE£TtèJþ–«ö§U×HÎûœvoãîÍ/ðîwm™=4ªT§«möŸ,z¤ì«äÄÿ¾å½~æxÌ@ÆŒéuQ Æ‘É/ó—â¸ó5z‡\¢.>°„ç^X‰¾ÿ8f?Ó’p£ì…¤ÉÁM  Â7œ1 'ñþâöÌÕùqù>Ï’Îæ„T‚Úö!2-ÿ+ûw›«‹Ë%?KêÀºÔÙ²žß6 öçEÐ1H„ês…¢»Ò3t2Ëÿ8A׎oNjBG~Â÷§eL÷Ú¼êˆkNJìƒÌÿþÚº]k™kÙ¯¨²/ ¥rîvêÈ9ÊÑ‚`Ú„–œ“àNûûïáàüW™ëIü=СÌH©Ê=‚V]".±Ó,V¯û÷ÎOÑÙOUê}ÖmÓºrz-¯þ+—öOÿ›aÎO4Òêôôgz2‡K‰ ‹T\ô®Άj»NsÑ4 ÅjÁ¢rÁ¥ToªÂ«ÕƒŒÝ6‹‡|yäɩĨ‚¯ØáÚ²“ø~þùæ@ ý~‹çÛ† /o»ƒ+Yz¬9㦕¸*Ÿ?ZJ~ט>¼ ç?jw‚뺗(m nP¼&/cÝ ˜«¢Æu’fŽÿ@zp;î ÓcÝ[ÞÙ¾‹5‡-+–’}º‹ÃïÐú´jG¸»´´ìÝ”C)œ&†ÍÂðÖJÕÖÀP­§ësßÐõ¢lÊ™_1¤ìã*Oz½´˜^—|¶x&~þ­Ôzè°Ç~'ÿ±²íåCÛI‹ÙõDé©§°zæg(q’¤£í[0¿u5eœÜæWçR—Õ•³b¼åà~ޏG1" t«k[1jjcr uøx^Í©ƒìõŸðÙFŒz<ŽòÏͬìÿa)‰á-hüçlžÞv”ô}h}ê.3·ZƒWh]ê×;;ýC¿ÿÂê4*7‚êÔ£þÙ'´Û¶ ÞZ6T[±«5w¦*/Ú{‰öxqÙèŽöÿ²€w¿Ú…W÷xgB[Âô—ŒÞX¿sËGiZbljM¬;X›Þq¥sWu`:„~ÅÚ­ùtëæ)×ÀQ~IÑ‘¿IȬMçþ!¸¨¬ål¥ÒáAx£ÆDú¸ ˜³Ø—ð¿ý¡åÎ>±ø¨A¥ó"¼áR©59T‹AçIp¤gÅ—¹–ýŠÊᨌ‘jwíÅ^Ñ ÛÙÿùÓᇽEøÖ­‹nóžþå¿(:#~¡uiÖ¡ƒºÇàs®.9$ïË!²gt©Ü~üÇÑÔ tâôUíCýúž,I>„½[¼|QÞ§³ð6Ÿ¦îíí ¾ÌÅ@ꀆt(ñ€Þ†­šðÏÒƒÍkŒ·üž/¡ZqëiTÆôûaþÞ–G̱¯U†:·5ÇkÅF6çv¥§©Ú‘½™÷_ýœìÎÏ0£³_ù¿x82YóÑb’}»ðÌKÑ¥–†¢ô]üU¤Á5c9ÿ÷ðB"£¨S;”ÚÍ˼f•ø!SxªE™îБÊ.S6¡w¿Î¨ÆgþfÛ:—á^tf‚¢V_ýh¯õ$/ù€÷¿Û‹*ºw?Ò‚¸†õˆªåƒ§A‹µ ƒCÛçóO§ñÔ?Syw\³3Kx9N‘‘c ÀW_ê9­&67'WSQãïïCÑö,LeW¿BvR·oæ¨Êý¡-$:û9ËÎÞw„­›r1ÆÐ²®w¹}’ÊàŽ›ÊB±EjRBµ¢†„ꊟþaûg# Yõ¸³¥w¹AS[¿ ­¯±~k=º]~É;[æßÌ{i+Òk1¸]ô%ŸƒSÌçãƒ1<>ãq:ö³ìíø&QMãNmh‘ÈÉ^oóFßËLARÈúc6Ï/ù§Ä ¬äžÈÄvt"õZêßóo&”÷ËJåD|Ë+߸ñÐ3}ˆ<;âì8¹ƒ„“ ûÎdÚ„»]tlZ¯wÁ §ýÆr6Žˆ§‡§ °c³iДù@g0 -*Âääy’F«‡ýâV!ž‘Íhë«”ê'Š‹4PèŠÑÓ w½î’ý—#ÿ4¹Š;AnrÆ*¡ZQCBuET[ØýÛ_d5º‡ö—˜¦¶>m[xiÓ »v¦üUÝ öýÌÌ7¿"½ù8^î•ÀÜW_D3õyŠó*@Õøµδºþ4ôLæãgf’7†·?lK¨«•M³~ä“ìÓ(ø^ö Ô§Ýh^·¢ Pth³ßý‰ •‘ö£^dtc-:7OÔIå”tÕãjÍ¥øRç'J. K—óç‚JauX/ž|°e±ýÇ/øùï¤ç[ÑyQ¿Uoî퇿ôµ# Qþ$;OO¨=ð2š8^Xú 5aµ -ø›ýâB®üssA^!j£ò/DyÔx†ÅиL¿TÈ1vš‚iÐèÜÍ_ÌG9¡"ÜÏ€Fö¢tvnÜMAÈmD¹ËLBµBBõµì/ïo~Z_Lëñíñ½d®ÓÑ Yc4ïí ÉÒ™6eïYo?MÒÿåíҨ=d36ÀCÕ0÷9<7ýE¬S¦1¦EéŸ\UÆ þü•®w2wT[BÏ.!§7z¢Å~å¯PW#>®fŽÿù1¯/8J³ñ“‰ýò}N»{ãësvúGyå|ýñw$‘~Ê…Y…¼-ŸóɶÚÜ;§i9ëú“øÉó¼q°%£‡¥¿óÉd–6“éÌà­;ƒ±ŸLç¤ÖŸ só2ÕAD†kØxô޶µÏ׃:¸ ¢³ò§Ýô}4ö +süØ)B¢ÂeÝx!®“Ã|‚Öñk±½‹Bq±ïȦôjdj ÕBˆÂn·¡Ri8s÷?g¨.3eÄαU?ð·GWf´r¿ì´}ãxY¾dëmšhÏ—?½ï7Íÿœ?ŠâyàÅ™ôñ<µ„vÀ›Ú¹L}ëE˜òcZ”±VùgΧÀgÕ?fó®|:€9ío¾ùðSVŸŽeÔ˯Ð=ôŸéDx7 aÀg$l:Á A%ïê o÷b^zg3a½AŸòÖ¥uärðŸêõ¼‡îqgWá Ã+e-O¥d`/*àÛEk¡ý$n;¿*ž+±-b˜³z'CjSë|ª¥ÿè;Y;m/{<΄AÍ Ö«+yi§PjãunÛâ½lÙëM‹Á²$ªÎSáÞèjTú1·Úm¸+¼Öbf¸ÜpÕHš–P-„¨1ôzééé„„„¢Õ:רl6ÒÓÓ1ʹ—ªíþ•E³{Ðà ß*c,Íëä±|û1ìMê ,»?cÒ«;©3pÿØ‚ ÝÅÝUP§'xÝ>›§ßšAÐÛ¯00´t$4¶Èà•¯óÜ“ÇèÜ®1QÞ¸¹ªQ¬fL…ùdežÂ5~(÷¶(;—ÛJʦ²šOàý>Ñh²Oq2ã¹Åg¦L+Š‚J¥Ân±`Ó¹Pò>/h"ésW~þà^5 ¤k\‹Oq`ëï,ÿ+‹è‘ÿfjÏ`Ê]5[íOÛî±|ûÙ4ÞLëJó:xºØHÞt‡å&;@a“¼8ºy‰/^mï Ý Xy¨7E_h;}Ì}LÙ›?zŸ±ßšq÷Òc+,Àbì̳ï?FkÙˆì «ØÔƒ™u4òA¢Bò¶Þ]~ù‘P-„¨‰ÂÃk“œ¼³ÙŒFã\¸²Ûí9rˆ°°rnТ­Ç³þC±FåÑOµ?=¦Ì¡“1è|Øti8”ÙóÄÓ¨¹l—|ûfÔNã¼yƆOÿvmaÛ¾c¤H¥Àâ@­sÁUO$µýÊëö\ˆô$“§øíËwøöŸbT^-¹7ÌÆú7‡3}³‚Ê¡àßã™ £Ãg^ =§0Ûk9Ë~û‹%›ó±é¼‰nÃc³zÐ6Üý2õ¡&¸ÇTþ½…µ›v³÷û)°€®Vº‡Ö!¶ÅDšEz^ÜQâ1l“?]I—ú¦½¸=ôá©·z󯂲 lhݽðñp= JÁ6.ΠûÄ^„Ê0µBÔœPíêªÇl6£×륵Da6›*ý=]Ÿö‘˜¸³ÙäTƒÁ@hh8ÑÑõÊß@§ÇÕ©=©p÷ƽT¾tÇÓèLYÁu#.ØÝ ëLxœ3=`†¼ôvoM©Àßmâ º•ÜnêW´µZq¨t¸hËK¢zÂZæ‰Öƒ¯¡%4xFµ¦Të«(£& ëxÆ'¿ÄÌEQ¼ú`“2|ªÐ} *[Ÿ¶4VÏYHFŸIŒq•šBÔ¤PDRR"MšÄ¢×¤ÅDÔII‰UêóxxxРAC""¢°ÛíN•Ñh4èõzÜÝÝo‘ÚÖáU+Ø©«ÕU³ªò¦õ¸éÔÏ2£QÀ©…²OZŽ}n~Fù™Z!jZ¨ 33“„„ ›¥ÅÄ-O¯×„¿@åf2• £ÑˆÑh”J¿Y©õø\Å/:#þ~RmBQ#Cõ¹` ­%„B!ª%¹LE!„Bˆë$«!„B8Éáp’rŒÔÔTrr²(*:s¡·Á`À××ÐÐ0ÂÂÂQ«eÜRBµB!„¸HJÊq·S¯^:v쌷·Ïùðl·ÛÉÍ=Íž=»Yµj9M›Æ.•&¡Z!„BÀ™@íÚµƒüü|î»ï~t:6› ‹Å‚Ãqæ.³jµ£Ñƒví:pÛm­Y¾ü²²NÑ´i<*•Üa±&ß&„B!.#1q–¡( f³›Ív>PÙi!6› ³ÙŒ¢(Üyç`´Z-‰‰;¤k©BˆJ¤( ii©dggaµZoèsët.øúú PeÇqåãÔáëë'Çy í*# •/%å8ùùyôï?‹Å‚¢(W,ãp8°X,tèЙ\FJJ aaaR™ª…B\«´´T, ññ-pqq¹¡Ïm±X8xp?iii€Bqq1­ZµÅ`¨^7Ò2™LìÞ½‹´´T€›æ8«C»†††Ê‡¬9vîÜÎÝwÅjµ:¨KžP[­Vzô¸ƒï¾[LHHˆ\¼(¡Z!ĵÊÎÎ&>¾ù ^...DG×cÇŽí€B³f-0›MV«:R«ÕÔ«WŸ;¶Ü$Ç©ªí*¡ºr¥¤':ºZ­Öé;Ï– Ö:ލ¨:¤¦¦^[*õ&§LBQ‰¬VK•¯ ̫ՂÕjÅn·—šZ]8V«õ&:ÎêÑ®¢r;v”ÐÐpl6Š¢\Ó?›ÍFXXmRRŽK…Þâd¤Z!jˆki«Šc»YŽST?,ßÁÇßoÀb*ªý=Õ7ŒŽ;_Õ´òxxxpòä ¶mÛ"T4 aaáøùùK¨Bˆ[ɬY³*uÿ“&M’J–v­‘>þ~‘Ízbô ªý¹hV Ñh¯;TŸ™>b#88D© X,RRR$T !„¨× ä8ÅÍ@…RïÅ3¿N\ï†v»CÞ×5€„j!„¨Fìv;ÉÉÉ$''“žžN^^žžžCLL F*KÚU”1ú®Ž|üý¯›*æ"×®}C1›Mèt×—Š‹MhµZÒÓÓ¤‘ª€F£%4´òïn)¡Z!ª‰½{÷²fÍrrr.ú[VVYYY$%%áããC=hذáUí_FªoÍvŒéÛ”1}›VØþÖ­ûƒ‚‚\ŒFãuí'//__?š7o)t “Õ?„¢„È_~ù…Å‹—¼ÊÊÉÉañâŬY³F~R–v•Èß?C‡c·_ßê‡&00H*TBµB\ÇÑ%<ñÀûüÏæt!oçbÞþd#ö3ÿo)8Mžé2;°qút!”¢ý,;Ÿ5©Ö›¢~Ö¬YÃÆ¯º\BB¿ýöÛU…¼êüïf;ÎêÒ®¢òDDDrâD™×øÞ„ÌÌ ÒÓS ” ½ÅÉô!nY 9›¿`Þo)8œìêõ{œ¡±úŠ?»ëU¬;lO]Å›óöÑnÚ`5ŬŸ3š™'2çáÔ»¨ç2³ã£'™º:Š©_M¥‹[=zuZÇ”7à?ýaš«ï­œ÷îÝ{MÁëœ 6FLLŒ¼å¥]Esss#**š;·âêÚ_§×PW«Õääd³sç6êÖ­››A*TBµâfåPfqþWÕö£¬Y¸—.¢ öðãâÒÎ,+¹û8e.fÅDZ¥L¾U¶bèMñ:÷¸#“_æ/ÅqçkôÑ”9Ìå,ø½/÷ô/õ3›#u ~Í@!êì#*ŒqÃÓpï/nϼQ q©†íc·ÛY³fÍuïgõêÕÔ«Wɜê[³]EåQ©TDG×#/ï4{öì¦Q£&x{ûàp\~½rFMNΙ2ƒÑÑѨT*©P ÕBˆ›ôë·¨Öô‰ºb„¡`ó\¾Ò߯X׊yjµ îžxžýÞqä[±¼ñ÷ôijÄ÷ŠùÀï,ÛïO¿BµíàJ–kθ©Aeæ§i©Ó&–ôo—²£ã£4?7è£ä±á«Ÿ)nÞ’m%·77¨^“—±nP ݽ«ßZrr²Ssm¯äôéÓìÛ·FI¨®í**—^¯§qã¦lß¾•ää=ÄÄ4ÂÛÛ »½üá µZCnn.ûöíÁd2ѬY ôz½Td sª…¨éL{ùrÁ&ü ¢uM“P¹EÓýž! :„áCï¡oÔám:ôÜcC>ônîláF£)qvoãÀú˜[¶£i9ßA®1w1,j3‹V¦pnœÈúÏ|¹¯÷÷­æ¢Qð6tMbíÖü +×Ú’øð±Ñ¼°"ƒª¾vrrrµÜ—v½•|øñ'×½½——qqÍ(**$9y§Oç–û ‚F£!??—}û’ÉÏÏ£iÓx¼¼¼®û˜nT™šüAFª…¨ ¬™ìþÇNƒ˜Z¥?ô¶“ü:g«ƒ™qWD‰¿)äßÃÁ,«“·QP¡ó«K“p#Çr'Ó31ÔªUj”ÀnµƒV‹öüÔ’÷åÙ3ú“7†÷æ‡i_³¡ÛStòÈâ×ÏÿÀ{àtZ¸ÿÂG øP¿¾'K’aïvŸ6ŠrO“o®úÛM§¥¥ÝÐ}9;üÅ×ß°>aS…WŸ^=éß·÷U•¹Y޳º´«¸1|||ˆ‹kÎÎÛÎŽX7>;bm?¨óòÎêÜÜ\ââšãëë+WƒH¨¢(Úµ„7§ÿC÷×_çþzg§x˜Ž²bÎëÌ?Úœ§_H]]©¸Ëá5ó™¹6×ÉP­Æ«ó“ÌÕäâNÅ‘Cò¾,Â;DPv\Çb±‚Î…óOí8EFŽ_=—3×ÔîÃý-&1Ù~ââÿdñ©Î<Ó#õÑòËß߇¢íY˜ðPš†Ü?ã]lžUþS]AAA…í+??¿âöUPHj…9“Ù\iõW]³º¶«¸~ÞÞÞ%‚õn6l|~$:77ýûÏêf¨%T !nEnÍ`b·)¼8kMßzÈã«ùðý/øŸ{ož}8-|Ôu MGÍæ‹Q×ÿÜJÞN¶¥Ùxï2!VÁl2£rÕ£W]ó6›†Ë_—åFó!ñ›2ç6=ìmè¸äTV;çãS¹âr˵±3AUÅ\e•êêŸ÷f9ÎêÒ®¢ê‚õÞ½{hØðÌœ÷}û’ÉË“@-¡ZqkS¹ÓüÁ1ðéi¼ú¯MØòuÄ~šywÇP©½€ƒ´?Ö°;¢cCËw…üüBôî¶Ú/£‰ã…—Ÿí¬ìʨ»÷òùÑXhëÅåbGA^!j£nÕ0›xxx••Uaûª(‘µkÓ¢y³ ÙW­ZÁ•VÕõ8«k»ŠŠ ÖM›6cÇŽmìß¿‡ÃA~~j ÕBˆAÈ'ïaçÓK1Œz—÷®üéެu|ô]6'v'ä¢L]DfF¾1>%Bu‘á6=£míËŸŽèþyñŠGPÌñc§‰ ¿0Å;–"3vmÕN ®°ðâÄ軳#±ïÀ}÷ÞS!Çe2™(**ºª27ËqV—vUãÌë3Á:-=>½ûJ –P-„¨)tQw1áÞ-<ùõÖ·žD'ßÊ •JÁMÿ„”Ž“xª¹ûE£ÉJávÒ~GÉ¥ó\‰mÜÕ;ÉR›Z×{xÅ{Ù²×›ƒƒ/<‡móƼʑAs™5(¸JçUÇÄÄ””T!ûjРA…Waa……Õþý\]³º¶«¨x¾¾¾4oÞ’]Ÿ!ZH¨¢¦}ä£îǰÍS™÷áz?Ý ¿JH•Ja?÷&ÂGóú¨xάÔçàØâgø×w'Ñ»êÀ|š"¿¾¼Wrí<^mï Ý Xy¨7E_O¥½a›ƒz0³Nõ¼yFÆ ñõõ%;;ûºöããããTør87Å»ôf9ÎêÒ®âòÆ<<ªR·÷ööfÂãUêsܨ25ù9$T !®áSÁ ' c%˜ìTÊjõ*·:Ü>êyÇ6àÂ5j¼Àü¹ä›Š±)®ø‡‡ã[ö~3†xF [ÅäOWÒã¥þ„iôt}îkº^æ95Ñ#øhI‰H]°…‹3è>±¥¦skã™øù·Õ¢)Ôj5Ý»wgñâÅ×µŸ^½z9u×=¹ùË­Ù®BˆjòÙ—*¢æêð;x|L'Ât•ô*7êÆ• Ôg;½'!áÔ©MýèrõÙn) ëxƇüÎÌEI\K¾²¥±zÎB2ú<ÉÈ×jÝ 6¤]»v×\¾}ûöNf*ŠR­ÿÝlÇY]ÚUQM¾[¥ „Õ³€vÉ IDATŽÊ›Öã¦S?ËŒF®våÅ“–c_£›ŸÝMðr»wï@BBÂU¯nݺ9_-2R}K¶«BBµB\šZO€þÚÊêŒøûÝDç*=zô <<œ5kÖ\q.®¯¯/={ö¼ê‘LE¹9æ*ß,ÇY]ÚU!¡Z!D 111Ô¯_Ÿääd’““IOO'//OOO‚ƒƒ‰‰‰!&&µúêgïÉHõ­Ù®B ÕB!ÊP«Õ4jÔˆFUø¾Ž›#¬Þ,ÇY]ÚU!¡Z!Ä $#ÕB!¡Z!n“&Mª¢°*sªoÅvBH¨BqCêŒT !„„j!„¸ ét.X,\\\ªäù-–b\\t( Øl¶j{3»Ý†Nç(7ÉqR-ÚU!¡Z!j__?ÜOtt=\\nìh,–bܯ¯?Šii)øû¡×W¯â˜ÍÅœ:u’àà0àæ9ÎêЮ·:9qUÉb±J¨Bˆê"$$„´´4vìØŽÕj¹áÄ×ןààEáÔ©L·a2™ªU nDFF pS§J¥ªí*„¨>$T !D%R©T„††ZåÇO\\|µ¯³›å8«C» !ªYe^!„B ÕB!„BH¨B!„â¦&sª…âËÌÌ #ã$ÅÅÅRâ–§Óéðõõ#$$•J%"þŸ½ûoªüß8þNÒ‘–è¤-£@)C,A"à·,EQÀ¨(âEqÂWEd9PdèJÙˆì½K¡ÐAénÒ$'¿?Ê(P°L¡½_×Õë‚ä¬|ÎÈ}ž<ç…j¹8Úf³Ñ¢ÅõX­VD.‹yóæÒ¾}ÇÿdÞyyylÚ´ÄÄDEUÐÊ…j¹pÉÉÉ´hÑJZ.»Ã‡Sÿ“ùšÍfªWeíÚÕ Õ¢P-""‡ÝnS –RÅ0 ‡Š! Õ"""rus»ÝÿÙ¼].—V€”xºû‡ˆˆˆˆÈRKµˆˆH)ð_¶T‹”j©¹@j©)ÔR-ri©¥Z¤ÔÉ''ÇYô;ûWóÇ?ûÉ-Æwï¿ ¢/ðK o ¾_À޼b LFF~‘ïØ¶ÎçËy[ÈÒ*¹hÔR-RÊ8÷Ìfè¨ úÜŸz^`äç‘“ƒmsÆ3.ãnjU-ƒ 0yøàoÅâHcçÆmìJØÇÞ]ÛX¿!‘°Î}ée`·ç‘›“CvV&ééGHMIæ`bI•ûðŰ6”)Ã3×Í`Â?y wsÂ,'^wæåb3[ñó¶œ:w;³&.$ {:Dy–²µdw$… ûÉ©×HœÁK}~¢K\MúEžÜ&bò$´œÏñ–Ǻ1´ë™Â˜uq£yGHɰãÆÉÊ÷áÉ”4oPŽÀäéOpp}!”p:ÑQ¨‘‹’ÓÒ8”êbë·¿á}óH®É\ÉÌU41¾æ±Iû ò¼(Ë,†›¶4vcÜûwQ9k+¿ÿ¼„Ääõl ¾“×Þ„ý¯ ü¸Ð„—·_ï4Öüºƒðn½étó ”Œ¤bD>…fï:0Ÿ·Æo£Åˆ;Žê¼Ýóù胯YrÈ„ÉFŽ9˜Mn¡ÿã‰õ­NÇÖq<;z !£¤_)z¼±qI=ªñì†pB} }nWIy¹l½½ŸY …¥Ü’êŽa×oå>Èž„|V¼9Ÿþ¿Ò2õGÞ›FGã% ÝL¥HLøÆÛt¹ámÜÙ‰ì }†U«^¦®E»‰ˆˆBµˆœUþ† {ÿoò=›2ôIV~:‘?Ë?ÇõeÁ£~Æ½Øæ¤ìX2†žßüÛÔ‚G_¼Ž_advªÏßZ\[çXØs³ÅnW.G’â9’Ï–ue¹¦u büL`¤ðë„™·¿A§È£É͵›ïÆNeÿuÙzom-né{Y¹h/.À„_½ûè_ë)Æ}×’ñýjáUªÖ˜7ÞÛÈœûüOdí„iW{&w,ýƒO´Tg}Õ• _üÛ¶ð :ô‹Ýû6¦LfÞCøºÚ º‡ƒW»1ü3û^ü ÍÅ>ó.B_×þQ¨¥ZD¡ZD.¯:·Ò5b!?Ä\OÕÓ²µ!=\ EàÜ2“—^üƒÂ •Ff<S¥‚gìeÍö$öÈ#ß¾•+ Ò]X5¢¹8Üöœ,23¾hòÄVð 5œ;ç1s_C ?q!GÞ^v&EѲmM-!Ú³lZÞZ¥ÐRøP¯{gŸ™M\÷š´/[JZ«M~Ôëvó?ïJûI…>³}?ëò’9xïMÌñ.–\¾ÜqG=üL`mý$OVûšÞ͵äúøðƒºx} Ž¥£¸µý'¯ç”䛯Ñ¢P-" Õ"R,–Hny¤;½ü ÖۉípÓF΢÷ àQñzúômpRK°cÝ4^XxôË8uüº–„í‡É°ÿÅOþiYq;kw}ì°‘FŽÛ‰ëÐ>öf]åštõ7Nv,^†­ñ#\[øéÜÖH*–;ĆM‡ézÆ«¦ÍaÍhõ ÿÉ¢]»LÎ|6è}º¼ÉÈÎa%ïŠkS -~̸VkˆÏ>„ÜÉ3ôÏBÚ Áa¦B¼2 êWÄÀ#–ezÇǸé‡?Ø•]Þâµ{Á£öݼ:ºãI¿Hä/xŽßh÷Q¨‘âïð•:йÚ,¦f@·¦/˜Ìª$Üö ’’’O ÕÎ ûñ;|XªuaèóuùjÈj¶ïó¥QÏNûФòÏòäõàXÇÿ¤ܶ;·W6“·òs^Þtþîø»°uÛ¢oŠ9ù€ãQƒžý[ñÜ;ÃyiîìÜŠºå}NÈærÄÆ0cën\íꆓ܌t²l%ùÑÇÞ8R¶°q׉;µ¸$ÇÈáà¶lL>ª=ªEҬИž×ô£ÃÑŒ ›Æ{O…0zê³Ì÷›BüÞ½>·q$ç öËÒá\Zª¿ŸýS¿úú¬ÃÜsgOî¹³‡ +¢P-Rª¾NÉÝ4— s³ü'–èY :‡ÔÔd"óî sÍL¶oÚŒ‘¶‰?VØ©}SC¢,1t¹>†c=z+Yoàí{ˆy³×ЃÄeßòÙ6OpgïÌ$áÇÉ$ù˜p¥ïÇ|lÄT’ødåäÎ&Ê5îÏûc–1óÛ9¼5p¾ nç‘þwÐ$´ð¡ÉLHH9r×&Ï þ&ÀR‹^oˆ3 ´ßÔMNr<{÷:N¼’•†Ím#mÿ^öfœ¨¦§ÿ±`ì&sÑ<;î;æÎwàQw4·4Ï`ÿþ½TÏFÿ橬Z¼ãà"¦ý˜CËo&Æ£ ýïjLI{‰œÐûþ{ñ÷÷gÜ'ŸùþÃýúrÏ=ÈÎÎV±DªEJžå*qmó®4n¼ŽiÿK åèi~àÞ_”I¹Ú!˜ð$²š›•Ë—R®Ñ½<Ú ™¯ŒcÎ5uy¨¶‰m¿/$ÉÇ—€¦7Soó,æ{˜¨z볌î„ɱ”7ïÿšòFÒ¯º™ì?ߤ÷ŸÇæíÂé´`±½\¾[ðÀ3-¸7c¿Lü€7^<Âð±Ð¸ÐÝ>,0\o³5yYâÏuï{Ñ…^1>fåÔ™Ü6lÔI*®§wùºÜе":ýÁˆÇ·Ðmáܶý]ù6…ðV1›¬Ä40øiö÷„Ýü*ïµß˘[úóáõ7òVKí*%ùÔúZª³³³évÛ­§ë‡ûõåîž=ÈÊÊRQEªEJÏòád}1÷m×âg:L`ÒŒÙR›‡›§²%-] §y-éü5ý+ÊÇ­fžoOÞ­é…;}!ß/  yXc½†®÷yñíX>}(½¾p™Ÿ‹ÇëýùÓn—KÌu˜M€ÙŸ@¿<rŒ³.Ÿ%°:Ÿx”=¾É¼5½h|½ï‰/øÌÌ~þø–’ÖTwÊ$n‹ÀoöSÞ0œä; Uóå™S3µwþ·óGúV«BÚ³C0µ%È|€½ïÑgikÞî¶e³Yûõ«Ì¨Þƒd¾}m8U¾™Ïç/²°™µœ,'çô`},Pgg+P‹(T‹”VF* û ÚÑû©™ƒ1íÏ$¢7jïŸÍÐyõ¹¥MÓw4¦…õO¾Ùß…±£Ún68°`[jwæéïY“k!ªå­ô¯Þ’ûŽuiv­füàð2=ªm’6[ .œ3‡]ѲøCÍ+½»†ÅŸ²~.óœ¸áhw; ûR‰¬R‘€q‘ŸkÃååƒGÉëb íËÿeô=ùEÇN>ëÖŠ—ÖZð¬?‚¿f÷'¦¨gâ8ضÙM½rÕ³D„aÚšBÕž¥ù–1´ÿ´Þ[‰Q«ºp{™©¼¹í âþêM´îQ]òOÖÎãîÙÙYt»íìö‚3¼»{ÞAVV¦Š)R=¦\¤´|¡f'rÐN¤OÁno#8-™¤Ô•Œ{ëgïëÇAf0‡qÓƒw›ºš%{rqc&¢õ »¿ÇŽ®Ýü4þÞyÿè߇?³Íq„Ó?>ñÚGóØæð¦n£š$¯YGráÆjc?q³ÿ`ÓaÇÑþÀ’–ÏeÁ(®©áw¢ÿµ} «¶”¥QÈ,çÆ÷ïÍó?&a”‚ug‹ŸÏ«·µã•ÜAü¸æ^õ~‹›n{_âm§¯ç#;Øe®FŒAµ,Q•‰8Oü¾ÿãÉ»ÇüÊ»ÜaKeú¾;œ&ûç3g]¦.V”³ëlî¹³÷Ü©."g£–j‘R¿›kPÙ#S™V<> “ÿ ÿíŸçÕ¶a˜73ÖÊ·òt¯M<3j4e^FÏØk¸; b¶¬²´yx ­Mܱ†Ožù‘»Ðãx“§ o› ü,6¿™_MaÞîNô9vرâqdï>6žT²ø“M†©7>2ˆ•Åg7iKæ³2¼ïT-]M©ÎÌxÖ-þÿûn*“~ÜGÍG?dñˆÛ©ê ×}»ˆJo `@£DÜÒ—^wÞJ‡Võ¨àcÃj¶×lFmÏ‚ÖDSÙ;ùøãTÝô(©}fó½¢±,vá²xà[g0_¼±ˆ6=ºøÃ,žm€®W,¹ ãüOA322T@…jpG´âážð3-9úŠ‹ÝAåû_ç®æûù¨OVÙ³±Å>L¨ÙBX‡§™û¿%ÛpÇú [.výü!ã—dŸÜJn%ùëwxõø b{¾ÌÓ7aö©Ïý÷Îç™Ióè0òV*xæZô{…}d§!Ëe%88¯B¿Ÿ¹³W3õ»dÚîHTáßÕ<ê3øËïKpúÙÉñÖ‘&têÞ‡ikï¡u¥B}ž="iÿâl컌o?ûŒiC;ótÙ¡ü÷4«ÝÉ;Ï×¢œiÆÑ½ðȵsÍ« x®ë¯Áüœtr›¾OE‹•ú}É™O0eon…ê’} ÐÃ_D.)Ó¡CÝ«W¯¢aÃÆªˆÈ¬¨ý´¸¯—ŸÄÆu”oKÈñÆ_g^¹>~¾xÙ1ÌMNÂF¶:£iXÅÿÜ×;ãGòާ~ÿ6g"óßz‹¸ºOñÊm•KÌ#ÊW¯^E§N·üëp.§³‡G1ëìÆé4ðð(ÔšŸ·‡Å ’‰îx]ÁIÌÑõœŸA¦Í‚PÞêXjÌ›7—˜˜ØÿtvîÜ~Î9ÃËËS+Oþ3ùùŽsú¾UKµHiãN&á§¼hÆÃ§ g½„‰2ëÒè¼OáËrÝ€QĶa9qâYrb}ƒvÁ~”ƯU‹Ç¹žM'jŸ*´êRå´õìåWŽ?í¥‘ZªE.-…j¹|ÌVÊ…Z‹7¬§!Á*™ÈŠՆР¢P-"""ªÕR-¢P-"""Ä0ªEªEDD䂨¥ZD¡ZDDD.8T«OµˆBµˆˆˆ\`¨VKµˆBµˆH áímÅf³aµZU )5¡Úårâé饕 %šný/"r………³qãzl¶<C.{¨þ/þòòl$& (H÷È”’M-Õ""—Qhh())),]º»Ý¦‚Èe‘ŸogáÂÿɼ}||‰Ž®BDD„V„(T‹ˆÈÅ Ö¡¡¡*„\VÍšµTD.!uÿQ¨Q¨Q¨Q¨…j…j‘«”îS-"r™¥¤$“œœ„ÝnW1¤Äóö¶Fhh˜Š! Õ""rñµÍf£E‹ë±Z­*H)œœDXXx©]›ÍÆÆëIIIÑC¤DS÷‘Ën’©SçZj)5¬V+uêÔ%99IÅ…j¹8ìv›µ”Â`íƒÝnS!D¡ZDDDDDªEDDDDªEDDDDªEDDDDªEDDDäb°Ûóùá‡èÔ©‹ŠQBè>Õ"¥N>99fÊ”9}÷Ïß¿šEIa4oX_ÓécºíY¤å{QÎß[gä""ça÷î=L›6/¿üŠÃ‡« Õ"rµrî™ÍÐQôÿ¸?õ¼ÀÈÏ!#'7ÛæŒg\ÆÝÔªZ`òð!Àߊ¥ R“³øŒkÆÔWÚ`ÛÀ7ýÄN×™æäEínOrGÍc‡7™ëf0៊<л9aî\2r L ï‰‘a#3Ó†É'ï±Ý‘“Až¹ þîÝÌš¸€î}èå©•)gà"/#§O þ^çvúçÊMã°ÍJHo'Žç?])Ý Ã`Ñ¢ELž<•¹sçâr¹T…j¹zêiJu±õÛßð¾y$×d®dæª@š_óؤ}„ù^”eÇÍ[‡»1îý»¨b20Ün\n7`àrå©ÃT:ÓwƒÉLh؉àá:0Ÿ·Æo£Åˆ;³€kÏ<7tÝ>‰ŽÍâÎ “xä¥_±vÍ„~5 Pî4~õ š~Ę۪ӱuÏŽžBȨiàgÒz•BrØ0ù1õ6+6ƒˆvûñ tˆ´üûèyÿðz›ÖŒòÅö?Ÿ¤’ù"MWJ­””¾þú&MšÌ¾}ûT…j) ò7Ì`Øû“ïÙ”¡Oú³òÓ‰üYþ9®/ õû0îÅ6øÞ±d =¿=úï¿?ä®×þ$Û °Š»ºŽÇ¿Ý |Xo%Ÿý´¢rµGûÝìh*1RøuÂLŒÛß ÓÑb©Kuï?رÏEǺ€Á¡{±D”'k×.Ò„˜×>v&”£Æýå0c¯Þ}ô¯õã¾kÉø~µðÒªܤÌz”.Ï%òèÌmüÑ* ÜÌt;wu3±`Ñpê{=/{õ!>Úf‚sº%Cû£ý~Ÿ÷“6µbX»vS¦Laúôo±Ûí*ˆBµˆ”$^un¥kÄB~ˆ¹žª;¦3dkC{¸‹À¹e&/½ø…ÛÜŒÌx¦JÇÿïÙh “®_ÁãqÍøä†• ^ ö´}ì.Óš^ljgüy4#dÛÎ󘹯!†…ŸøIÝ£*5«dóÇîÃuÃ1cg÷ŽdªwìLÖ;Ùí‚3I»Ù•_••®|¨×½3ÏÌ&®{MÚ—UkµÆ¦CäS«x®UXÁ¶ìÃcßf~­‡øà·!LêRæŒ<ó¯á<<£#†òÂ_kºRšdgg3sæ,&NœÈÆ›TRHÂDJ K$·<ÒÀ…Ÿ0lÜjbÛ{1mä,â ð¨x=}úöâÁB}nˆ.ÞY·ÉŒÅb9ù卵ëdÇâeØ·àÚÂOç6P#6”„]ñ8\ lßJ͆µ©nÝËöù{w“X1–êÞ…\aÍhµ‘…ÿdá>>›|öøC¼ôs2†Öv)L4ËY¼¡2í;T;éäÿÖÜÜÜÆòE› ¶³¢"õ‘ß6àgZ|8–®aæ‹6])vîÜÉÈ‘¯ríµõ2ä)êRL-Õ"¥i‡¯ÔÎÕf1-p0º0}ÁdV%yà¶g””|RW g†ýD`=ïЪԴ/åý1KOy§ µë”-!ƶn;BôM1§p,TªQ óß»Ùo4¥JÆvåU¦GT4YÑ©ü¹+w´ »öáÓ™ÐÂYÇ\ŽØØflÝ«]ý£Óu’›‘N–M•F®Ä}ì7*йâ©}œ­TŠ!1~?.šœþ¥çNeî3óWûÿ±´S0Ùã/Òt¥DËÏÏgÞ¼yLž<•¸¸8Ün·Š":ˆ”nr7ÍeÂÜÅ,ÿlj%zßÎ!55™È¼;è\3“í›6c¤mâvjßÔ(K ]®ÁÿŒ“Ì Ý§>·ÜZ¯è÷Mn帩äJòBƒ¬œÚQãZ,•“ײ'×MÅ=;I¨Tª>dÅ„3iç^\m+±{÷ªÞXù”ƒ•™rä®9LžüM€¥½Þþg@¨~‚+[¸->øZOÝÊLX}|0lyäÞ§ì‡ffðß·1iI{Êš ²/Êt/LûbÞ·øRöo>Ó2œúziëc}èÐ!¾ýö;&LøœÄÄDíx¢P-Rú˜ð,W‰k›w¥qãuLû_-G¿Hó?ðþ¢LÊÕÁ„'‘Õܬ\¾”rîåÑÉÌxes®©Kï¢&éÚÍÿ½G|­&TõƒÜøÕüMëZÁ˜Ü)lXœEûwÇÒ«¢ §Ó‚¥ˆ›$˜ËÆP£Üÿ±sŸ“ê»öR¦jGLfü«Eã\µ›'ìÜIÍŸÓƵxXÀpøéÝäMPd¤Vuiݽ}ðÆFžýØYÖ‰àl³Ù0[­œzFcÿ×<ñìfîþæSZû_¼éJ ;as»‰‹‹còä©üôÓO8êð# Õ"¥šgùp²¾˜ˆû¶kñ3&0éGÆl©ÍÃÍSÙ’–Ç®…Ó‰‹¼ƒtþšþåãV3Ï·'ïÖô‚Ug˜¨9”æ÷?A¯*&öÿ›ncÈÆx:–3jå7G‡ñ'Ð/„œ"z:[*Q³Z?î=ÄÎ]©D·®€pW­NåØyÐĪÒ*üô¶çìÌÌ~þE>¤FJKD"MØ·ß!…¿Úò9°/…ðŠ‘'÷‰ÆÎï¯>ÍÿYêÓgú‹ ž~t»Z¿û®ÙŒ²‡ðëæµÎç:Ý w%´þžº ¥ñî™™™Ìž=‡O>ù”mÛ¶i'…j9ÊH%aTó;šuƒ1íÏ$¢7jïŸÍÐyõ¹¥MÓw4¦…õO¾Ùß…±£ÚnGáé8Xö÷°„‚‘ÈÏ£Ÿf™äg$ÓþO<ñ%&rH²ù`'º¢…eñ‡0šW:¥k†Õc+’°m›ãËS½jA¯n“Ubç²i‘‰Äè†T;-µØIØ—Jd•Š…Z ]äçÚpyùàã¡ ¥ŽSš×ÜÃOîcDýª'¶³Ü¥ü¾Ì“&wÕÆpÙ²ÈvxâïïIÕî¯ðε…[ݤôÁœBtL áe0sºRr»ÞŒß“››«‚H±é›G¤”pg'rÐN¤OÁno#8-™¤Ô•Œ{ëgïëÇAf0‡qÓƒw›ºš%{rq&ÿ(jT*[pn1CHîi_‹¹<7 yƒ±o¿Áó7WÀ¿q_Ƽ=š±o>@ÃãL½©Û¨&ÉkÖ‘lœ~ ŠÁº~Ëò£©~ìjDKjD§÷ûf‚ccNo¶oaÕ–²4jqâ æÜÀøþ½yþÇ$Ýý£4²TçíÙþÎ`ƯÍ,ؘÿâ0¦ôe`ÇÀÁÊ—ÞâMÖ;-ÄÜü(,ô÷8}ZGáy=½œ‡ÚUÆ\¬éÊÕÎnÏç‡~ S§.´mÛŽ)S¦*P‹BµˆÍ¿›«qìvϦ2­x|@³‡ÿ„6ÏòlÛ0̆a1c­|+O÷ â×Q£™±=K­ž¼Ú¯1eLQ´ëû·_ã™<7¯aÕê5lLÌÅqx'ÿ¬^ͪջI;žlM6¿™©¿3o÷é}=*ÇR5'•ŒÊ1T9Þ"íEÕêH?ì"&¶ü)*7iKæ³2¼7UÕÓìäÄ×YÔ_0çi+Ÿ¶¯DdL,•Ë_Cÿ5×3aÎk4÷½Ò¦+W‚Ý»÷0rä«Ô©S—¾}dÅŠ*Šœ7uÿ)%Ü­x¸güLK޾bÁbwPùþ×¹«ù~>êÓ‡Uöll±j¶Öá)Fæ~ÆoÉ6ܱ¾ÙuÙm'y÷V6¦þ¸ÉßΖM›Á8Dzá;ÛùÔçþ{çó̤yty+ y|Z2ü»–§™ˆ®£ù¹k³Ì^ÍÔï’i?¸#Q…Ó¶G}ù½Vtif*Gó§¾cÙ<ŠÃ?‚ Á>…NÊf¶1gÐ_@Öãç:Ý’¯$õ¥6 ƒE‹1yòTæÎ‹Ë¥ÛpŠBµˆœϰ:´òÓghuÊ[Í”k܃^D0ø“:ä:Løøùâið!¶ë bO$ ¬õzòBTPAw KMî1ÏÊU;õ~bî,n½!¯HËñ°Úö1Û:’w¦Uáõ>uð;Ÿ ‰üòÁT’;?Åc5½µRå {ÑWÏtå²HIIá믿aÒ¤ÉìÛ·O…j¹@^áÔi~Ê‹f<|Êàó/Œ4 9–±Ë[¥èMþT¨yÊ=ÊLe¹nÀ(bÛ°¸ó Õî?úí‚ýtq˜ˆ˱ §Oÿ»Ý®‚ˆBµˆ”f+åB­ç?¾§!Á*£ˆœ]vv63gÎbâĉzl¸(T‹ˆˆˆœ‹;wòÕW_3eÊTÒÓÓUQ¨)Žüü|æÍ›ÇäÉS‰‹‹Ãív«(¢ÞZ™m IDATP-"""R‡âÛo¿c„ÏILL¼ª?KPPˆVè¹T¨‘’ÇívÇäÉSùé§Ÿp:*Š\1ªEDD䊖™™ÉìÙsøä“OÙ¶m› " Õ""¥··›Í†ÕjU1¤Ô°ÙòÎk›?v;¼3¾×cÃ劧ǔ‹ˆ\Faaálܸ›-OÅR¨7n\OXX¸Š!%šZªED.£ÐÐPRRRXºt v»M‘ÏjµNHHè9[¿~=ê×ËÈ‘¯¨û‡(T‹ˆÈéÁ:44T…)¦€€z÷îE¯^èBE¹b©û‡ˆˆˆ\L&mÚ´aÒ¤‰¬_¿–#^&22R…‘+‚ZªEDDäªS¾|y z’½êþ’––ªzÊÏwœÓðj©‘«–——·ß~;³gÏdÅŠe ô$eË–Uaä²S¨‘!&&†#^fýúµ¼÷ÞXêÔ¹FE…j‘óáççGïÞ½ˆ‹[È‚лw/¼½½UQ¨9õë×ã½÷Æ¿°±R¥J*Š(T‹ˆˆˆœÐÐP z’Õ«W1{öLn¿ýv,‹ #îþ!"r™¥¤$“œœ„ÝnW1¤Äóö¶FhhرӕÒèØmùŽ]ØX©R%¥нaDJOÔåÈʯÿÇ~Š <¨~Ë@î®{n÷Tv¥.çãWgàÿøhúÕð<å]ƒƒ›ÿfÍÎZ¬_áEQm8– j4©‚å"}j×ù¼5~-FÜA˜ÀÎââCÝøà½û¨~ÚQÐÆÚχ0ì—* ûf7øV§cë8ž=…QÒÀO%ý§y:ñW^¾ë>Þú»Ÿî›ÇCa…×G&?Ãã#¦³ÞfÅÃfÑn c?~‘gÚ¢Š3ÎùLWBCC4èIžxb ‹-bòä©Ì;—Ë¥â(T‹ÈÕÌ;´: ê…ü{¨vÅóÛÔ…xÝp.S7ÈØ4‹·ÇÌ!½å^«îYÄ é¬[—€¯Ã‡_æÆŸúsngOÕÇønx.ʳ̌~0ãö7ètJøqÅÿÄ”yõ¦“~²3ÌgÊïɸ©rô~õ§÷]KÆ÷«…—6¥ÿä¤0}åûôºëÒš5¡Êjã´÷Sf=J—çytæ6þh†GîNf º»º™X°h8õ½8qÎgº%OûN]ø}ÞOÚσÙl¦M›6´iÓ†={ö2uêT¾üò+>¬â(T‹ÈÕÇ„o•ëè\åßÃKöÊøÆÚ„;ë¯? ;w §ʧ¿fÒ ïë ¿)Ÿ"tƒ ùmgmz{‰ÎÁ§ö>s²ñóÇyéˆ7žé;wÎc澆 ~J_7ª6«ËÁïg²öúGhèsìƒd²ä›¹Ø6&ruáá}¨×½3ÏÌ&®{MÚ—UkõåæÚð6nÿšºï-ä›zßsãÜ¿NÙ¸ö0mì"ŸZÅs­Â ~éðáαo3¿ÖC|ðÛ&u)sîãtJ:÷銜E•*ÑŒñ2Ï=7”™3gñÅ“T”’rò¤ˆÈIò¶ðõ”åßÖëþ¥«ƒ‘³Ÿ³>bð#ÏñE|-÷†v,:PãÎdÙô¹¹þ6š[2É9­¹ÜÅ‘ÃYrq"«“‹—akÜ‚k‹èÁâ]³+÷VYÉ´yû÷ÿvìú‘¯·5 W—JXNYsX3ZEmdá?YïÊëÜÈg?ÄK?'£^¶—˜Ç5 ù9ŽOïŽÁZÔ’½œÅ*Ó¾Cµ“»ù·æææ6–/ÚŒó|Æ9ŸéŠƒÕjå¾ûîå?~S1JÊaJ%)…)lÚå¢FÍò'œIüþÁX~ñ»ƒ·»V.òáÎ?ž«Y²h! –íÄ´’æhÊ‹Ãï§Ù›˜ R—LàëkòÐØÊ¬úè1Æ%Ô ãí]éÞ¾áÞ€+‘= G /n²6³ó°w±>˜ ÏàjÔ©è‡É8ÂÖmGˆ¾)æ º²´¾¯?Œ˜Î’vOÓÚÿ0¿ù'e»¢Q™_ùü´&ˆrÄÆ0cën\íꦓ܌t²lêy©YjÝÂgyß•¸ýF:W<µ³•JÑ!$ÆïÇE““¶…⌓Ó…j)%r7Ìà­Q»hÿæ›ôª~´‹G^c>ÝG˧^£Mp¦añ×\¾Ÿõ~[»ÞÅ]õâù')šÖµý µT»ØóÛÞY˜QÌPm&°Í>êW#•ä#>„YÏØòm©Ô™^žbÂìíÔ«ÿߥ¶á¹a˜ã‹žvHH9r×&Ï þ&ÀR‹^oˆ3 T?ûýÇܶ\løà{Z3¶ «†-|8éâØâŒc?é^¨cý—ÿÍ¥ìß|¦e8õuõ±Q¨)Õ|ôfp»gyeì4®Ó‡è„_ølÜWü]¦Ãß¼Få̧J¿Èº´»»%Õ¬F”ÿ‰C‡óP1¢nù¶<õv B# ®g0u:ô¦N»ì]þß|û>NÍÅ£îÃ\n>éum¿÷ùªßù|JN§ËYoÎàKÃ;»üìx^\™C̽ïRÓ3vå°xXÀpø¹ßäMPd¤6¨+€ÉÛoläÙñÎØl6ÌVëi}õ‹3Ž×yLWDªE¤Ô$24ìó$݆Žàõ'—ãÌò¤þCߣ>¡g8*X£›Ð6ú|çg%<¢ˆŽÍæ2D·èɾéì|mÍq°‹Õäkö'Ð/„œ³÷v6‡µ¥_-|_—ÞÍÏÞŸ;;3³Ÿ?¾ºNñŠc‰¨@¤éûö» ¤ðFœÏ})„WŒ<í6ÅÇ+"眧{¡®„ÖßS—Awÿ)Æ×ŽJ RJYkrÿžTÈÊ¡V¿Wyùî3êKÇÁÁe6zA÷ áZñGts8Ñ-ì?ô/zsë`^ØŽ gMGvö¥]±Pˤ‹üÜòœºLñ?çß”æ5÷°àÏ}'¯ïÜ¥ü¾Ì“&-jã ¸lYddÙ †)Î8Åœ®ˆˆBµH)æY¥+ƒîªÌ–éSXœvƒ¡3‡„Õ¿ðÙÈ'ðþz¢|W»Wåâ>Ð×›ºj’¼fÉã£Ù·°jKY5Œ8qàtn`|ÿÞ<ÿc’îþñ_³TçíÙþÎ`ƯÍ,XŽÌqÓú2°cà`åK oñ&ëŧXÓQ÷‘R¨Òu÷®ÆøÏsÍÐÖ_¢Smcÿ¾üy ûö°}Ç^Ò­Õ¸îÆ¼ùDj]ŠC‘‰Àæ7Óâ«)ÌÛ݉¾127iKæ³2¼ïTÕô®Lf¢ø‚9©Ð¿}%^/†÷‘dÜuû0aÎk4÷=ßqÎgº"¢P-"¥ð(P™îOô&yä¹8ç߯Lþ•hÐ0ŸrÿÖÏØÃo¿H®½±)]û× ¶B ^—ºo²O}î¿w>ÏLšG‡‘·RÁÀJÛ§Óö,£Ybîçó…"uöj¦~—LûÁ‰:é:Êú þò{mC—™¥æ0Vf +bc,Gó§¾cÙ<ŠÃ?‚ Á>…6iOšÙm̹ŒSÌaJ8õ¥Q¨‘â*ÞÌÀþçpªtâÙ¡ÿ>œ¹üuÜuïåþdfBÛ>Æc[Gòδ*¼Þ§~çä‰üòÁT’;?Åc5½µ±\ <ˆˆ¸øãœÏtED¡ZD¤D0•庣ˆ=lÃâ†s~\£;€Æ¾A»`?]&"" Õ"RŠ™­” µžß¸ž~„«„""ò/_5*ˆˆˆˆˆBµˆˆˆˆˆBµˆˆˆˆˆBµˆˆˆˆˆBµˆˆˆˆˆ(T‹ˆ\¼½­Øl6BJ›-«ÕªBˆBµˆˆ\aaálܸ›-OÅR¨7n\OXX¸Š!%šîS-"r…††’’’ÂÒ¥K°ÛÕb-%ŸÕj%,,œPCªEDäâëÐP ‘’DÝ?DDDDDªEDDDDªEDDDDªEDDDDªEDDDDD¡ZDDDDD¡ZDDDDä*¥ûT‹ˆ\Fn·›ÄĤ¥Æáp¨ çÈÓÓ“  `"#£0™L*ˆˆ(T‹ˆ”F‰‰°Ûí4mÚäååå±iÓUA…j‘Ò(-í0 4ÂfË#77G9Gf³™êÕcY»vµBµˆ(T‹ˆ”V‡—Ë…a*Æy8V7u…j‘RÎår©ªŸˆ”0ºû‡ˆˆˆˆÈRKµˆÈeæv»U‘F-Õ"""""H-Õ""—™ZªEDJµT‹ÈÉ\ùä;í$,žÃo»óU+'Š“¾æG&/ØýœF³‘“[ô…}ù©»Ù”AqïCâÎ;BâƒÉÓIˆÈ©ÔR-RÊÙ‡I%€P?ON5Ÿ=ÍÄ€A YϤóˆsÕ=/ctt:1<<°\Ä0š¹nþ©È½›VÄ„ü2ìü­˜s·3kâBº÷¡CÔ¥ùàçÕR¿Y_|Í/>ÍqÄ—-ô†™ÈfÝéTÓ—¢ž/˜¿e:OâÁScï£úIŸÝ 9n#¶waês-ù·Çи’—ó¿7?cµÃJžg=žxá!Z„Y´C‰ˆ(T‹”ÊHÍÁßßå±/¶a*WžÊÑU¨Zµ Õë_ÏMõÂðÀJ½n·øÜç,}ùIî É—qy¥]—ãЮÔå|üê üM¿Ç­‹}s?dZFSîïÚœÊeÎí6×ù¼5~-FÜAÑÐ í·Qôý¥.¾U|«Ó±uÏŽžBȨiàw%< ÛÆ¶ï'ò«OG¼­:ž®‚PîH\ÈÔYiÙ¨ÇéëÇÈ 9ÕÆº9K¾m ¶üÂì\L«V³ÇUp²‘›D~ÆoŒûhÍÑ“ •nìM÷:…ºAúæ9Œ}ï'l7`òCUØùù q4 CÒ³v ~òQ¨)mÌDu}“Ù7!q_<»÷ìa×®=lØs-7Õ +¢|ž|ÜÅfK0mžÿˆÞÖ˨ 26Íâí1sHo9„×Njwã[±*^¿Êã?ÏâÆ»¤o§ÚqôrìYÆüÔJtl…€‘¯fbÜþ"‹Ûªj¯Þ}ô¯õã¾kÉø~µ ¦u[KµAê² Œ™ ]Ft£iDÁÚpþ›Ï¾ÞIxaô¬ERr&`ÂÛ/ˆ@3Ž-³xé£Uä[ZñüÓiÌ|þÿH¿g(mš9:û#Æþ1EÓ¨q <†êraàvã.˜ kf}ÆÇÿ—JƒðlÛrØÓÔèó.ŸTzŸa£†±ùÖGy¢ûµ«ÑZDªE¤ÔEkk9*Ä–£Bl}Z¼Ã›v ãYüá¼ö1…ó][—mà@þ™C¡¹luZ4ˆÂ»¸3w §ʧ¿fÒ ïë ¿)Óɇ©z·óìØöôX4ƒÏ&¿ÂC¿¶aðKhV¸ÔÅ®?§ñeF?:6‰À¹s3÷5dÀ°ðslMõ¡^÷Î>3›¸î5i_öâžV?T»HY9‘‘Æ‘âLÜ/ò—ÀAfj:”-OÙ…óÜŸnÀEnZ:1ýíð¬Ûž‘ ™Y£ þ¿Oá÷{ùøº*”µTÇb*ëÒ~fšëÚÜÐêx÷W¾|—“Œí0õó,§%O|ô*7…ç“•eÇ ¸²r)Ûúi&ÖXÀ¯¿Ï“+›rïC÷Ð16ekQ¨‘’/‹~dzr4U+W Ìï ‡çþøæWOt§ÃIoärpç6¶ä ¤µüž×™kêEö/)ÖÈÙÏß¿ÌæëÙK9Rµ ¿Û“VQg‰âæ2TiÓ‡7›¶gÉï{ˆ :e®x–ÿ“NíÇZ]ìX¼ [ãG¸Öz'aÍhõ ÿÉ¢]»€‚ÖzçF>ô> ]Þddç°KÞíÁ½œ/>ߎżÌôu ÚÎÍŒëû*¶§&ñtƒ£­úF*³žéMœgÁ €ÛY–ŽÝÉ/Ï¿ÃË”¥ÃÍ+þyÏ_ïd_†¸IOÈÆ™¶“åK-53ùS¹N5‚³ñј_ñíñ/9¦óñðþL.b•›L"nzžžóùpÌ'xŽy–eMÚÏDD¡ZDJ6#+•]ëð÷ì=Ä'åa ¯Lló;yºÏuJˆÎíËYé¨Ç€§\¨g®À½ûsã¦ïX6–¸Îó°gãj–,ZÈ‚e;1­¤9šòâðûiVÌkM>huk…Ó^Ï[?Ÿß4 ¿‚laë¶#Dßs~:s9bc˜±u7®võNÃInF:Y¶ {Lv±[ªý[3lr;â§<ÊÈä-,Y’YÐl$’”ïÀ¾e9‹s­¸lâ³Ü€ûèô8‚[Ñ>ê[~m8‚Zý͆QkXî˜Íª1Y¢i|ˆ¸‰Ý=<¢é[…àrxczW¼\¹df彎G»ƒœ¾60Y<)ã׈i=ädçoœ>ä÷³`êW_Ÿõ£ÞsgOî¹³‡vRQ¨‘+Ÿ9¸ }†5¡àÊMaï®]ì¶EP¸ÉÕÍòŸAËg©o½s5H]:™÷f®bÇÞÜa5izý ùðjšBï7s/|νÌùrÖ#hvìÂB#•ä#>„oŸp3!!åÈ]s˜<7ø›K-z½ý!΀ÐËsqžá‡ƒœ|ÙÛÿbVŽoA¸u瑘™ƒsáòŽ_Hé 5É ìèÿ\ñòù÷¿±x£™Àü¼è‰ åi;r4o†Ÿiéäfd“oä“—•O–=|— ÓÙ è°“îp`÷¶p†äMïûïÅßߟqŸ|Zäû÷ëË=wö ;;[;©ˆ(T‹ÈÕÅâJµº¡T;åõÜÍß2yuez¼_³ˆ ôÜdý5–Ÿ¯ÇQd¸Í!¯rõÓ©_d]ÚÝÝ’ÇjV#ÊÿÄaÇyè"|w¦}À·­x¡gBËìÂé´`¹€N¾ .œÇ^0yyá‹\ì>Õn\.6›ð¶y«oõ‚–jç6>íÿ:¶‡_cP½cÝ?óÃó²øØôËFÓ¸íý´n²ˆ÷§:¸ç½aþ1…¸ñƒ¸sûaŠjk÷¨Ð…—†u"Ê n·“ “‡0r¡뙋è²eãÑfŸ?\÷Œ_(ÙÙÙt»íV€Ó‚õÃýúrwÏdeei§…j)œÿbì» ½o‹ìm¿õ &µ,º;€cÅôš{úëÖè&´¾ ìJãŸ/ßfÔ/^ÜñJ?š¾ýÙŸ@¿<rþýÑ&N‡ÌæÓ.²ËÎÌÁìçïÙMØm#=ÃŽaÙB\\âÑ®-I°ÙÉ߸˜¿2ÌÇO.v§ŸX+æ²aä-ÿ„ÄúU°zdà\ú13¼úÒ/òMVû `\¿Z'}ä-~—‡~vZ¯&<½,”¿íU¦¬s†/ 'ë?îÍð<Ïý5 'çô`},Pgg+P‹ˆBµˆ”vWÌàƒñóɽq(otŽ:óÁÁìçz˜,f.Oþt’¶õO¾™ôóU¥×+OÓ³¦ÏÉó6‡]ѲøCÍ+¥»†‹ƒ“!°¦“k’°/•È*ñ,4l~® ——>çßäœn©ç:HÂ~®¼ø-ãØxf,µ®ÅsûŸüºíDM¥»ö©v"~·²MÝ€ ¿`þ³—Ü0[½ñöð8©&N«WA7·›‚Å;zâäÌ$%éÐêgé<:¬ûLý® ¤dgÑí¶[°Û ž ywÏ;ÈÊÊÔî'" Õ"r53°ÞËúUËøó·ßYšÎM¾Éƒ7TÂz.­3/ƒñ»Ù²q-+–,aÅ^ˆípï¼ØšEE>oê6ªÉ¿¬#ùÎJ”?:ˆ3i;[QÔŠ*ƒƒì?ñÝ¢\jÝW· ßôñL½…U[ÊÒ莈Ò¹ñý_go÷Û=â²ô«6nduZmîû2·eŽÆa~xþ!–ûþaå–§öч/ZÊás$쀂àìr¹N ÁÆezòxvvöñ ÕåCDªEäª Òã¾à³_·“@b†‰ð iqã Æ·­G”Ï¿´3;7òéÀ·ù-ã ]*œ6òªV¿øAìÏ7¹gìJ\¾!DÇÖ¦~›‡ûRbƒÎvËÍo¦ÅWS˜·»}c wŽýq|ðÎ|>ø[]dg{S½ã@žíXø^ÖnÒ–ÌgexÞ©zñï¼lF1‡´³á׿8X÷Nê“ÆáÃg›h¹7³ ·aàÚ¿‡„°JD¸¡L‘f;¹†›¬õ?ðÉg'îJÞ‹ª†qt[1Ün²¶þÎ7ß•;ã DÚÖ,ÜU݆Qì_)222´+ŠˆBµˆ\ÍLø…ÇÒ膚tެDÕ*ö9‡öVkxxüd:K÷“ÉŒ¹˜“4ùW¢AÃ|ÊýK+Ól§ &¨œ/çҿħ>÷ß;Ÿg&Í£ÃÈ[©à>bÂW½ÉÉL'Óf¢Lp0ž'OÔ½š©ß%Ó~pG¢ ú þòû ^ ÅíþáÎ^Ï_›éò\sÊ®"..t±cæ|¸,/³Ô¤`º<à]Ð#¸wÝD9ÓÌ!7óÆ.VÿïW<ƒªrm½¨“‚²c[‹·íÆq´û€É³ gx¨‹íØ}±‹ÑýCD¤DÃ:tÐ °zõ*6l¬Šˆ\ÁŠÚO‹ûZ©åNgÅø‘|ãû ¯÷©ƒß¿…rg"óßz‹¸ºOñÊm•/ú#ÊW¯^ELLlñ6ûàçcÂáÈÃ^äS,MX<=ÁiÇækP~¶42òÝ`±RÆÓINÖ$¹‰*‹·Én._ü­–“Z–ÝŽ<2ò\xZN¼êÌM'Ë3ŒŠAÞgl…¶§à £ Á¾—÷YŠ;wn×6^ xyyªòŸÉÏwœÓ÷­ZªE¤„7”庣ˆ=lÃRpÍÞ¿„ð?úí‚ý¸T_çžPÑ•Kv® ã ­Ànœ‹Vopg&ýXçhgÙNÀ«U«™pØòq¹Ý˜,žx¹mädŸ2E³>^fœÎóòô# Y™ö3ç~k0V'v§¡mMDJ5…j)ùÌVÊ…óòKO?B‚/íâ¸ÝÅ n׿ ë68kžuÙÉË+4¸3Ÿ"wå“Jÿ—#{v¤ËaÃ¥-LDD¡ZDär;§[ꉈˆBµˆˆœÎ0ªEDªED䂨¥Z¤xN½PLD¡ZDD …j]Ô'"¢P-""ªÕR-"¢P-""çÍÓÓ§Ó‰ÅbQ1ΓËåÄÓÓK……j‘Ò*((„ÄÄý„„„cµz« çÈf³“ššDDDCDªEDJ«ˆˆRSSX¿~5y…o -ÅâããKtt"""T Q¨)­Ìf3õêÕ§^½ú*†ˆHI:¾«""""" Õ""""" Õ""""" Õ"""""¥˜.T¹ˆ Ã`ùò%4kÖ³Ym˜¥Ö²ˆˆˆ” ŸMüâ’gË–-¦B…J”/Á²e‹1 ãŠ[ÎÒ4Þ…Ž«P-"""r ÔQQ¨_¿!Mš4#*ª‹Çs°–«ºˆˆ\Fn·›ÄĤ¥Æáp\ñËëééIPP0‘‘Q˜L&­@‘³ìÛ+W.'22І ›ŸŸ@£FMX¶l1Í›·RW…j¹`·ÛiÚ´9>>>Wüòæåå±iÓ¥Gƒ‹œ)P¯X±Œ°°p5jz&??ŸFšÅòåKÕÇZ¡ZDD.”ËåÂív_5.—K+M¤k×®¦|ùò4lØø¬úä`Ý”ÐÐPÖ®ýG,aL‡t¬^½Š† «""W°¢öÓâ¾&WÎ:¬_¿áI¯EFF]qË™˜xà´ð mJ䄸ø½<˜H§N·œó/9^^^Ì;‡ *R©R´ŠYB¾ƒÕR-"r™Ú¬e¹º†Á† kiÛ¶‡ãœýÉÏϧ}û›Y·nº” Õ""""ç >>ž5jc±X0 ãœCµaX,jÔ¨EBB¼ ªP-""çC-Õ"W·ÄÄ}DFFát:ƒ@ IDATÏûZ§ÓIddöï߯‚*T‹ÈÕË eýŸü¹-ýð("rnŽ9‚ŸŸÿ_ìïïOzzš ZBè>Õ"¥;{ ÓÞǦÚw“}¦BçÙ!uZÓ¬’õLc’¹nþ©È½›f9å]§›—^–‚©ºs·3kâBº÷¡C”§ŠWE˯Z§åjôéOk™8g ùy¹—t>ÏÝ…‡‡å‚÷‹Åƒ¼¼ó9爌N=÷_ùÁVÚ¼¬}è 4¸3÷ÛãÉš?䵽̼{‰÷=ÉKw—qKÒø®V+T‹¼9>~× üÏSé õ¼©¯S¼0…ŽŽâã}oèy::Úp8Ô××i彉ìv99¹ Õ"ru„+Á—²Ÿ˜ÇÅœ|‰OÍøú[=¼òƒ¯²mÕ¿ñOKýýUêè!~ýÕßÓÜ{&XE9üÊzç}’Cڭ͆×x©:Û?;e0P_„-ý:®Ïù-/îìbùò„×ÙËöûÔ¬þ&¬JבÓ"ò†|bõ >±zÆ›þ:‡àèÑ#ddd`³Ù¯è9b1“cÇŽPRRJii™VÞ5@ÃDÆ WÙüÇw¿È­é6¼)9äN˜0pË"à1p'g¹/ ßЭƒÙÆÁCmL*¶'«9N¯˜’ôlJlÉ”–&päàQ/z%ØÑNWïøº ¶N©'2¶ååÐÜ|š††Óü¾\ê§O7ÐÜÜLnn¾ô¡JµÈxáL'/+„Äz{èî>ÓǤτh8HO÷@·s¬—ˆgë/f3m^ÒžaýÖ‘Pˆh\*q#êæ°‘ššLpW ! ü`ŸÌß~û¢ iÚÑ1Ãëõ2qb)»p»Ý¤¤¤ŒpÔÀf3hii¢¢¢œââR¼^¯T¡ZDƦ;vŸzlè}>¨ýŸúÓà<ÝNVž#µc?çWN§×‹#$4ÂB¦Ýa3Fôìß7ìñwÔ»zªEƾ‰ttt°ÿ^Š‹KZAlX–Iÿ•Çû¿C†a``ýÓꩪª"11‘ÂÂ" ¤BµˆŒ]NÜûc¾²äuŽ87xí©­ØÒêÇ6?‰¾5=Ã/cŸGN÷VªMff_ºÖÜÝÙƒÍçae[Ddôr»ÝL™2öQQQNYÙðùp¹ÆÀÙ•L“H$BWW'ÝÝ]ìß¿—¤¤dÊʦâv»5 Õ"rM³e²`a2?_¿…œ/!Ç–AA®-'0åmÕ°e]ÇÒÂÇY·v«?9ý+öQs²™ìÂ\ã|Œp°—˜Ë‹×1~@T©¹6øý~¦L™FMÍ **ÊIII#33 §Ó‰e™XØl6"‘õõõ´¶6STTLnn>ŸOx­ýéÔˆŒ/#+[«^á™òºƒ ÝLŸ[Fã® ‡«m9¬ùøÄmú_ÿÍNêÏž-$Bg]=Cçí;ÀŽIÌ“5¸á‰Vò£O|„/=}Z—K‘1ÉçóQTTÌ‚‹IJJ¢¶ö»w—óÚk¯²uë«ìÞ]N]Ý)’’’X°`EE¨¯QªT‹Œ+Nœ“ÆãÕ4MÏÃçuãv8°f4J8ÜG_oˆ®–£<»~/ñ“Ö5p—ÄE·±ø±_²îèíü}ñà¦ÃSöúzÿýÓò©?öŸè!ÚÓMØw#_úá?°ÐÛÒ[7¯g[Æ .²ûµ`š¦–Qäâv»IKK#!!¬¬ D£b±þ’„ÝnÇápâñ¸Õî¡P-"× [:sošÅ¦§â“O…èí‹3-,ú¢±;]¸Ý¼¾d²Kïà³ï:تáŇ?¸žû~¾Ž¬aÂÙ­‡Ò*¾ðÛùLw­ÝQñ‰$ûÝg+ÒVw9>ÞÈ-Ÿ»•œ¡¿9fñ¹_ÿqÜ­µˆ\»áZÁY¡ZDÆÉW~âÿÊÿwÇðdšXô÷ý]"‘“¶ì^î=øÿªÿn¾a½$N_€ŒsÕŒÖñì=JãªÏso™þØ(T‹ˆ(T‹È5ȰÙñÉ8Œ$Þó¥-½Ø-FÖ m%0ïSß`yЧ†[¡ZDD¡ZD°yHNóŒ|~§Ô ÛðÀjjEDªEDäVUªEDªEDä 1MKË("¢P-""o„*Õ"" Õ""ò†ëð~åžžîQ·ŒGÑŠ0£„£6‡‡íBGg›D#Q,»§íbGo¿þB²×Ѫ£M4´Æ“sxuÒ™AnzŒ 혙—œ‡ öH˜ÈÀ¤H8ŠÝi§ïÄ.v‡ Y^–¨ê§Bµˆˆ\ˆÍfcæÌYÌœ9Kƒ!2*Cu­ív\I•<ýT#Žäd<±‚$M»‘³³pötÓCF ;Çù­»ËŒaÆ.=åÊgÉ*ƒýNp´ÛEîÒÛÈéØÌ3®)¬Êì¢j÷^Zúœ$å–0);^½Õ£œ~U9Êa. fÍ<¨œ©S˜•oRsâ4–ÝŽ±ØùçsÆ¢6¶‘Ì8ü˜±` 7.™ÏÔ´6*ötS83…êõÏq0ä'=9ʱÿÂæš0:{¼BµˆˆˆÈØ`wãv9ñxìçE&¯×M4¸xâÒÕsnÌ5ééîÅã‹Ã6‚y†‹ÑR¹‹š”YÌtÔP-dÞÂ2ŠKçp]©“cÕuÄ´vªEDDDÆ#@Zr§ºv™&+B{{¯?ÑJFb7uõ=ëÇÑFjí¤e$cɉÉ%©Øm ”LÉ¢cÏkìo‰ô‡f³‡šÛ9â,azŽF2ÏÀ~jwùs™°a$&“ØÓHcЫÆÓÄ%%áÔÙõF5¨("""2˜ªñ,fep3/ýõTÚÜ8Ì>¢žL¦-[Æôäþzd|ñ ÜÚ·™×ýŽr—[8É%,]9‡tGÿó\zž~fë^¶ŸLföÙ¸&±pj ›Ö>E•'B·QÄ ×¥ªªP-"""2–rµ“ô©7ñîÉ‚Á^b6qqÎágß0\¤O»™÷L‰ÐìÅrz‰wœÇúræl)³¹ûƒÃ—5g˜ÖCOØA\¼»ªÔ Õ""""c’ÍIœÏyÉyâ¯Æ<z˜+¿K«aÌ|\4""""" Õ""""" Õ""""" Õ""""" Õ"""""¢P-""""ò6Ñ)õD®Qåå;4""" Õ"r¥æÌ™§Ay ©ýCDDDDD¡ZDDDDD¡ZDDDDD¡ZDDDDD¡ZDDDDDªEDDDDÞ.:¥žÈ8`š&••œ8qŒP(4¢Çx½qäç2}ú l6틈ˆ(T‹Œs••{{xÿû?ŒßŸ0¢Çtuu²qãöîÝÃŒ³ÎŸ!#f·c?o‚E°ñ'Û¤æpŽµÑŠÐÑ&>v˜?mµ³bÕt }†DDäõ©ü$2œ8qŒ›nZŽÝî §§gD7»ÝÁM7-çøñcxÆ(U}‘ÿóõ_órMëìÝ­ì~â?ùÇûÊSO|ÏÜ÷þRÝy¡…Š5±ïµ½Ô…ÏÍäÖàó½IÂÝ­4·´\àÖJû±?óÀ?ý˜Í}Aÿá—Êõaº¿ýy¦Vÿ™G[Ç‘ŒU|ú;ïdNJŒS¯ü†ï?øiÖϾ›¼%s2Üœ-úöîãñïþ•9?þîLµhÛ·Ž_þæÏ¼¼¯{EóWóÉOÝÍ̤×ß÷·¢AÚ›hî ¶ìÄ%e“‘ˆû¢‹°ûW_æ‘íƒAÕ ¶ÓÒÁ2\,úÜ#Ü5åO<¹õ=ÜsK„Ÿ©ä]÷Π`õPõÒ3¼ÆjÞ15þ²ÖA¬v=ßúÑ!í]¤Ûúxå¿>ÎwÊ]Ä»lÃj髾Ì#3 G\ ·.}‰þÏ_’úÐǘíSÉ\DD¡ZDÞV¦i^öc.ÂÍ–­üñƒ%«?ÏÖôqèw÷óÅÙLKtÓWýþôií_r.ÃGA¨‚ß·…Û¿õ ïʶ›Š©Ùð=þõÑ&f¿÷ã|ëÓ$„ްáç?æß¿éàûß¼‹ü³[*‹Pcû¨ÜƒUÕ©m¥×ˆ#!Áƒ#ÖKggÓŸÏ‚•ïá£ï»ž<ϹKïdÁ=?æ×÷Äh|õ§|ýgUÌ}ÿû¸kéL nÌÒOÑuÚEÁÔø¾•Ð¨Ž€Ëã¾ÌÁobÃOžÀ¼óÜž=´aÆNÁ»¾É>Xp6ßÌñ‰ÉŸç‡/áGŒKe…jyû\N•ú’1fнç'|úÏëyç?ÜÃûÞý~Ø‹k ÝóùÈÃQ>ÿ?ÿÀÜ­ŒÙ"ròqß¡ßñÍßöñîâ΂3‘1…Ý×Çñ{~ÁŸö®æ3³Î4fÇ8ñìOùie2S§Lfå‡ï xb¹©>Î{;VŽlßÀ¯~þ_|¾ºƒï}m5yÙÒ™ÍÏñýGö1ëß¿ÍÇËÓ·-w!«sûÿ?0l#ý¡ÚåàrjÆÑêu0ƒ•[žæùž¶®—ùÆgçpt`†p7­ßþÄ.ÎÄaÃw=ÿü½¿cÆÐ­ŽÕȆÇÚ)ûä7¹£`x ÖðÏfá¤òäÁ:ÌYùaÔAÙß|‡Ÿ¾Î²ÙÜJ®?_-ŒãþÏýžßl»‰û_¸UÃl8ÁIò¸½À3Âw#µãp\N4Žrø•-ôÎû$3ç·¼¸³‹åËP¬Q¨‘·‰i^íÃÿUÉ–-§ß¿á$sòl&&ym[2¥¥ üáàQbËgiÃ-"2 éì"ã„eYWt»¸Í[þ/_ûmë–;ô{þë70“’ðy6^2ÉÖ~òÐÏ(ï¾Ðé÷œL_ºˆô n‰,Ìh ›Í~eoØð’šGO×3u˜§yþ¿¿ÇÿŠb†oýøLŽþÏÃü¶êÌù»Mê¶ü’ïþfç¢i™˜–Í~µb³™Æ6/iÏ*Ì&='Êyᥗo/¿FU›yÞ¦:55™`S !KŸe‘ÑH‘qªÍ«øl½ßðøu3Ëþå LÝ÷_x¬Ž…Ÿû(I[žäµUôØ'á4â™úþ/ó•è¿óõÿø% ý=³†žÁžEiÉEÚÌêä®lïß꣭-DbÖàó›õ[x©n*wÍŠ¸ÏFÚÿÈ×[¾É—¾ñÿú­áÖÌxæà]<õùÇyö®é¼sØ•F¶~}üñ?ÃñÁ/rW¡ƒ3-#vû…ëK>—.z â¡rØÁŒ½À´òòú€‹ˆ¼æÌ™§P-¢P}Kœfµ Þ÷À?r[¡‹–Þ|è{X–]Í£k«hŸt»w>e€x¦}è~îKÙMÜÐçðÎæcâË»pœ´Úw±íh€©—zE¡:V¿‰u•~æÝ1q`C¥zãó4Íýú‡Æxßy_¨¹oÿx#³¿v+éé7ñž%ÿËÖâ›|¶/Ã…Çát_ì"›O‹®íOò¿‡ù§Ìé6?‰¾5=ol§¦»³›ÏOœqyy¹:.UÀP¨Q¨¾|¶–|`9/¯}†ßŸÝƬã÷¯bÓž“•’y| O˜dÏfÁšå½º¢-‘¼²Ä‹,l;~ûûònãž’Ëmÿ°è9ö?úöcœ^ðYþuZÿV÷vžÜdpËWæ ÷FóÞ±”ä/¾Êöö•¬x˜yëM¸ØÈ®Mfgð}§L¶ŸnÁ$û¼°ouWð‹Ÿog»f®÷Ìc2(ȵ³åD梼+ì¹ë£æd3Ù…¹8õQ•ÔS-2NÄbQLÓÂ4ÍÞ,b±Øë<£aw`r³Û l6û°ûmvcÄ›XÇaÖÿàßxhK&ÿéÕLÁc}4ž8ÀÖçþÈü¹ï1NÏÿ'¾óÙElAûP%µÓîæ®â ×¢=AÂ6'ÎÉö‚XQÒIÝé!fÃǤ²lNlÙ©عú ¿{è{¼œù·|öö¬!ï×Íô¹e4ñJ‹Õ}Øq ‰¹s²´Ñ¥T©</õõõdgçàpŒìkF©¯¯Çëõ^xg×ß™7ì.³ÙÉÖ§{˜uûÜ™:’ø£¡âEÊk»éhnàä‘ýìÚ×HÜÌÕÜ÷÷²8ëuê²ÑÝüðÞïð׿^z#1 O29E¥Ì˜u_ý?K˜ž1ôÀ@ßÜOðÈÜ3 ÚÊ ?ýRç23ßO´ayü9Ëþ…EgZCl¹¼ë+_>¯‘·òNæþùG|õ!Þ³¬ŒtO„ÖcåüõÏ/ÓPøüç•䨇ï|$.ºÅý’uGoçï‹/w³kѺy=Û2Vðp‘]f…jy»äææqðàz{{±ÛGÌb±Çe„üó¦™-øêg~Á¾ 5gƒ#ÿða~qÞÖf2äˬN± ŒmÇ*¨8êÄŸ”JÉÒñÎOO§8Õs銬½Œ÷}õ›¬1¼Ä'$’äw3âÈi¸)šYJÕ«[X»­ 3>‹Éû|éæRü—8±‡-å&îÿŽŸ§ÿ´‘—ŸÚIGÄIBæD|â[¬º.ß…Ü;‹p=÷ý|+XÀ‡e_þ=Ë.©»ËyôñFnùÜ­ä¨L-"2j õô7_ë`‘ÑíBßÓ‘|w;;;9|ø§NÕÐÛÑky½^rrr))™DBB‚ÿ²ÚÙú£ømÜÇxðï¦áÉYù¢u¬ÿÖ·xiúçù÷;òu‰r‘Qü7X•j‘qÀï÷3iÒdòó /Ñ'=Èn·ãñxˆ×^ F ïyˆÒ–^ìŒè²ˆVó>õ –§øt€¢ˆÈ(§P-2òœaàóùðù|Œ·“ÍCrÚe\«Üé#5EÃ&"2&6ñ…j…j¹ºtÙj…j…j…jQ¨y«è<Õ"2¦X–E]]-­­-D"‘Q¿¼N§‹@ @vv†ahŠˆ(T‹ˆ¼ýêêj ‡ÃÌš5—kô_¸;S]]E]]999Z""×(µˆÈ˜ÒÚÚJqqé˜Ô.—‹ââZ[[´òDDªEDF‡H$ª^ù+Ug¦„:éì³oU²q]eÿ†‡Â…705¹?@›­‡Ùß‘ÅüëãÛE¬.—ï'\¸”[f¤ã‡|%'êû(*t\.§VžˆˆBµˆÈè¤P]]E8Ü7fuuu@ªVžˆÈ5L=Õ"2¦dggSWWÇîÝ»ˆDFÅÚår¤’••­•'"¢P-"2:†ANN999 iBH½ IDAT5Ôþ!""""¢P-""""¢P-""""2¦©§ZäU^¾Cƒ ""¢P-"WjΜy‘·Ú?DDDDDªEDDDDªEDDDDÆ´a=Õ:°IdlÒwWDDäíe44Ô[‘+§ö…j…j…j…jQ¨Q¨£›`Yuuµ´¶¶‰D4R2"N§‹@ @vv†ah@DDDd\¸èÅ_jkO‡)..Ååri¤dDÂá0ÕÕU¸\nrrr4 """2.\´ý£µµUZ.›Ë墸¸„ÖÖ †ˆˆˆ(TG"aj¹Â`í& k DDDD¡ZDDDDDªEDDDDªEDDDDªEDDDDªEDDDDäÚ ÕÑNêŽ×Óãí¢æÀ.vì9BsŸ¥O¡ˆˆˆÈçx“Ó#õ•[9Ôf‰ñ&_7• «Ž/î£éÌ$ÃCÞ¼%LI~ýœoõÕ²óÅc½;“DÇè¼b_´§ƒÃGbœýSÜØò<‡’f35î¯n rÃmÓI¾Jo¥·¾‚­§’˜;7ß¹CiF G,lN'Ž3Ó"MTn=‚{ú|JíúFˆˆˆˆŒ¾PmàKË!7~H¨6∷ánkûH¹qYöNª^­¤µ×ÈOm[϶úØð§ŒõÒ ÓõìÓ:'Ú³æ±zAÎyoÊ 5sìðNÔ7ÓÞÓKIJãõ§™_ÂÔ‰™Ä;ξ-ÇÒ¼tÙæÏ¦47‘ÁE‰Ñ°k/;oæ} 3Îÿ)À좩#™ÒE¹äØý4ª Í„ä«gÍŽƒ<¿¹‘•ӇêpKÛ·WR}ºËn`FÁ:«f‘îL£tâQžÙ´ßê…dëÔä""""£,T÷6qòTÝòi}ÞdÊÜ!BŽ2r'k4Sï4±öŽ„”d¹éíl…ìåÜTwÉ— V¿Ä†ŽÞsîÐrðU6m¯ÃžSLqa6áí‡ñÌ[L‘­‘ãU/òľ–ܲˆ‰ CSmŒ`{3M¯ª-ÂmµœŠs2qX¨¾T O¢ ·›W^ÜN“§™ÚÄÉÜz5 ÄVU[+0§®fRÂ`¢Ž6Wð—õpL^ÌËrIr`†éj r¦ÐïΚ⌧ټ»€w.Èx³÷´DDDDª/‹aÃîtá–M ìv‹®ÚZºE¤Úk0¨öÔT°£s³Ò§×ÙÝIWìu®ÝÏëÄèzg”–=ùË'³n»›iinŒp5õ¯ùHËÍ$/.‹¼âRŠwldãÆÄ­YH–óÌc½äκžÜ×O±tVþ™'.wPì¤Î\ÁŠæZê{Š™™—ÌÕ(›Íû©l›Àâe>Îv’XØZA_ñJVÏÍäìÛ³¹ð§ }U'YÓËð¬Ý˱é”xõÅ=¡ÚF^vú®!íöxz÷°iwˆâ›‹ˆ7ËÀ —Så/ÐÜÙNòœDlØH-™Ë”8“æÃǨ=s@ŸÕKÓÉ&¬ô ¤{Ï”Zs˜VRÆ|àl»…Ù¶Ÿ—÷D™zû ¦§ô¿M³«“.‡¿{àq†—ìy72»q-ÛMaÍ4?oj—v4HK} ÇOœäxMÝ™7’—Ÿ|5"5ÍÇN™°ˆÌ!kÔê:Á‘¦dÊnÈ ÔÛÿñåS˜¸‹£§z))ñè›!"""2jB5½íÔ5F†¼bÞ ñ^¿’é9ÕR[2S—ÞLj·‰Ã»€Œôx ) Iié”y|¬žWþðæŒY:axßDÆÙt¸Šžü…g5@´½î„4’†6: L,Neç±zz§ù¹jEZË"ÒÓFksM465ÑØÔ‰éO'7/Ÿ9Ë1!Í7,ìöµ7Ð4Ùù@ lq²’Ü`il (IÖ†b¶µÑáN%-~» Fii*[‰•d£CEDDDFM¨¶ŸQH‰èÙ?<$ôU²éÅì|áü è(¼‘g$ §ÝS‡·t2Y#M¼V¦¦^Ò&iyÀ¤µ¹g`2çfL·/goÞ«Rª¶è9°ž_ráON%--•¬Ò¹Ì\šIšÏy‘j¸IËá×xþH߈_Å=q)wÏÏÂfé:‰;çˆK3!æŠÃ9¢÷dG¸®‡((T‹ˆˆˆŒžPmÒq¢’]µ‘³ÕWÙÍÜ›–ð¾;r¨ê0)Ïßß²a6³ãé 4¦§ ;c†ÕUÃÞÊÓL)›<äÞ0Ç·o„¶Ú“4‡^ï5,B-½Î6““ˆî>NMO6ñ¶·d5fäfÐs¨Žî™ÉøÏ¦êD¦.œÆÑg_dƒ{ KgäTücôv±üþÁê~ì45§½äLOÀÐ÷BDDDd´…jèël¦±Ñf½ Òtô »wï§ÁQÄ ·dбoO=yŠ)sf3£0€ÛˆP»ï¡üÅ¥äP²ÊÞ-¯òäŒp”¤Ó5Ô¹ˆó¸q»œ8l6 c 0âJXzs^ÙÄúh"E‹nfnšãl€,_ÿ{š£$—,bõ‚Âá/ZÚëŽs¬ãRï,™Ü4ßyWMôÍfî‰MlúÃc¸ââp]$WÛ2æðŽ ¹'°óæO"¿|;ZÊX:¸sâHŸÃªÛ¼lݺ™?TFq»˜á>¢îb–½k ùCû8Ûƒi¤xš=•üÀiv×x(>“éE)x À Ózl/å{Žãœ½†¥iÇXÿôQòWßÊ”³¥W‹pG=ÇOÔÒÐÜFGW7ÝÁ>"ÑQ0Ò¹îÝ·2å’ÍÑ}´Ö·ARï›Õì` uÓì#jš\°Äå'5É‹í*½^OÕ&ž®ÎäöÛ¦?mà€X8H°ÏÄæòç¶V¤ûNñÒ3;pß°†…éWg<6o~‰9sæé&""" ÕoÖÓô1zˆî™Òëõ„‡‡ãîîŽZ­Æd2ýzÿYä:I<ù‚ŸÖ Y¶öÙ²eG©T¢P(0Èd²Ÿj ”5Rv½^N§ãÚµk”-šµZ»»;I’$ùi¼G_ÃCb­Ç€€‚‚‚ %S¦LÜ¿ÿ?¡÷„Èÿ#È™ØuáGÕIBuŸü?{Ÿ"øù°ìC¢×,³£Ñhù‘É~®½Ó¬×­e2™e¦¢Óéppp°ifï‘£ó^’OŸ%êõzd22™ ƒÁÀǤwëA ú ús•ÄÊ/1åeÿcè$>ù=zD²dÉD!ø¹ ë}H¬ÿiÈåòvľÛgsâù{ )kѦFÎÿô,ß`0X:kœ‘Ë儆†òðáÃïÊ{dý ßìêc½%Ñ=Sr¹ggg®]»F®\¹¬÷O5 âzÞÍïCr'–œßƒW+±½FßZ'_Jª7ñÉŸ.]:1B ~.ƒÄúÈ`*£ÑˆBa>%—ËcD»GgÖ¹ÂÌ[’ ƒ¡¬»î‹=¬.ä ÍbÊŒeñ¦Óøïㆩ$’9|0ÏÐg‡¸n_ŒÂjËì$²#±6J>Æ{d4h9|îe‹¦ûàÞüí\6P©ˆ§åØÛ/pOJ&7y:<{Ž?¦r‰´—6À­›þ$Ï’WùÇu°‡NÞ'G¡ $U2Êp—|Y_>Æ»—gêc½v‘Ëó÷y›3-yä º·µîâ2ö>4FºÞã{¾Ä’3±Ë=ïçŸ^S'&ST À_?Þ%ó"“<¡š@c;̺xï÷§+ŠÄÑÁ‡ô—üÁOm( ›×í"Rè»7èãéŒ+©Ö°tí%ž84¡ÄlLRX§OŠ·Áß2°ío¸€Z­æúŸµ|è±ùz¹ ÷$ÉI•© [w%oj'p gLó¬Ü¾¹d‰Ÿ‰”?òÿã=ÒkBù{óe*—Ëòã¹&üj©S.µ¥sœ³ò<ErRÖ]’‚â%3Ä0 ‚Ÿ_gâ{F´KÎÚÝw¨W)C†ï ÅàšäP›˜¹âýÆ5&¹ýÇ 6ûv_îpv”0ò¬;³zåÃ.´oŸsטŒ\îòO*˰À—ܵKBgy¼ž©¸ôî»ùóî„ZεïY…lê¨kï¾oö,w°‹qïð÷¬9k¤å/Q.ñmÿÞÄ`UÇ+ÿ’‡xT—Pù?WίéñÚ³ì$ªZ…)çÿHü­ËÞd4ðây÷pþêS®<22rTRÛIèýô4EZ”Áà¬@B"[Æ$È"ÔøüÆSn¾åm°†·oÃxú"ˆÇÏß‘´p Æ6JÀÑ•»xÚ±í]쾩üÁOgXËF.—[d뎰S¥,Ü 3“4UWðOí_pôr3–O‡PºòŒxoÜaÿ3º¦pù¨‡5(äÃ).N©_­å”ñr2¯ŸòZ[‰…s[AC ß¬ÃouV2ëÐyJx×çϲcéþ×9Öô/n3{Œ lË{$¡cò⓱XEZæ,?ë3þÞ¦4.†^!IfÉÿÝÓó\–¥¤­·F}(‹6Þ KÉ,$UÚvV.)2ðòÖ6.iëÁÎñ*Iòº¨Ð¾÷%LfOnÕG=ÑK!ãµ$']¹Š”>½ŽqG21¶¢»­xúþšv–êƒë¡Tʹ»~/S¯†¶R–r‰±ÎoÔ½£ÏØhM&F¯‹—\Âè`bö¤ÓLQ¥zÞ†ð·‰Zö2™‰6óÊÕ…°ä®Wšñ­R’ÊQ &›G-5ï®>b¿AˉËþôД’Þ;M¡žI=x|ô$Y¯Î ô®ØË£fåÈÊX_¿ýùLú÷ôóï'É/¾3&øé ’„|ËfÅi?›Ù£5—†fd¨»Å!¢SWØfËÖ%±^Ó·V^›×ˆß=y…Kj/®Nû•e¹Æ3©RZî­˜…_Ŷ”ôvL0ú°+ô_ÿˆ¿Nå·9.S¦ g®• t…:øIÍ_+îP¢G^òöšÀÃ’-xØã6éÔ±;±zL ª–Én“.àê)V½ÌÊèÞùxyêô¹è­£rs°Ga aÇ¡‡„‡¢×êØwÜ—E3rtñ=2U*Eú4\>‰{Ö|ÈýÞrðÎèMR…„QÆÞ3¯©Z8 7ž.ø»Qª Šã×4äuzF=Gm±¹ïè‘ñVJ\¿ô€ }:ÄÄÍ 8ä¢ mél$—¿áè=•J¤Ž*óå[ ,V‰âžær‘‚Ãx'WqqËEì*V‰a==»Ÿ—Z´o_¢°S£VJ¨ÕY÷2£¶¿eV£¤qz¦bÓ»æímºO¸lsÏì%ùÕª,ŽßyÂÓB™©â5Ëuw°G)Zš±c«ÓãíÌIÑ„>…iÑ (ºÐ§ü³óÏ$Աπc“ßÿµ!VÏÝçÈiн¡×Ø?Xï=³äclËÌæg —ÓÅôĽzĆC¯©7³Z¬yÜÙ}“$göÔQµ½û”'½JöéeæL¢–=Àøé­˜Ôk1yJd"“«ƒî gî`ûS'–̬‚—\âøŠõøU®J/ó³êµ,:ïgy¶çZ#OwœçA„áY¨mEêº+QJ × ÓA’ãî¢útù~zÝßüÔK6q&²SÅ™pï)?Òý™9æòŠLMŠ”ic½ÆÎÊû¢y½†ò5|ø÷â T Àò¹#q,Ý’’¶S¶¼M­âYcäpj:¯Näs²‹éGîD%Ǽ3?KE꺅ð×E?¦Oë5±{ËŸ“AËôi‡©Õ­"N§Oà]4Åò»qïáYvéR »|ˆ­nES7J¼|õ½F F=/_½çüß[8ã§£Ö;?¦M½A¾290Þ9ÍÑó9yxâ…ƶ§¹§#æo 9¦våÚî ˜Œü´J’)ô„„ÁÓsoH]¡>ÝѾ¿KéþÌV’dj% ®]~ÄCmì¦Ñþw^ñÀ;R‡A(좼Rzí+Æ}ÏÈÙÞ("UN©°WFÕb…k*¦úT$ÄÛÍò<Íó­“(‹'..ù‘dqzî>UN¹Ì•ŽÍJÆYMÆpfÌÜOh˽9èÙ&GŒ´‡/Á·LÑXŸÑ {Ãø]Atì]“,‘Ƈ)œþãw"WTB¡}7eoÔk¸xã¯õ&ß}ÁE9÷¶" caFæö£ÛàÝ´,oÇr_oHƒ"©{Ñ·}YtzsÝß0v-nKRÁżÛk©ý, “ÁˆÝœ]\‘xâÈÎù¾‰üÁOmD ED‹kÛ¨}È–À&äòŠ–>þë"I’„½gSÊ8taìÉL,3zäæÄ»á”p6°/(ŒÉœ,ù˜›XÑ«8ó2צ{ïÑT-”Æ’åÍùWIZz°í³Dük}ìÍÍ%l ¥Tý –ãU‹&càÿ®!•HCâĪ͜Ñg¥· †^ ¦BS'›óù–buÿ­ §£êšŸW®t¥sóR„½¾Äþ«¡´¯”†Ãßâ$¡[‹â4<öœ¾­ËÐëÄ º´,ÖËwÑZ_GšÖ,Àù]ûØŸ¥žåú‰ûä­Tš¥œè¼"˜T½“’:¹oÃß`ÔÉ£–]𷝧,—þòc®w^º7IëùÀ›§Ð»æ&—½­÷À.ѵ˜ c–< Ý°–e‹€‹ U³4‹’ÓÑòR:¦¡š“ŽEwC‘Ã)áµV’óøŸíŒ»l9ôǘæè_½ãy¨ÙIQ./)´!<˜Û‡Çü.‘sªL8cûºvà”.r®]†* –?>>UNI¦¤pž4qž?»r-!YYÔ0e¼ùèB3ÿ‘Ÿþž±4C‰m³¶aW²*õóDåp …Kv2XyGRöm‡f·Ê#ñËÞ¨f×ᛘŒZ.…9q‹¥Œf½šÑÌA ¦¬´¼½’Ň’0w|ËÒhd½1<:Hç•:²&µ# Ä€bíq®*àêÝPv-lM`eß…7¡™ã[j÷<úyò‡%rÝ~dƒ$¶uJ[ nnÌo…}š¾Ttÿ<×b—vÙ½û.²ÒåYú÷i2»ª yü':‡’d´6£“”üsô2‹GýÎÀæÙYSw0>Ãû“ÎQÉÍ—¡¸5‰Ù醿ÝÁ¸‘/0†ãÿü&ÇO^"[•QL,e|xô"tÁU$©Z¬¯êE'‘nãHãèßÕ[ùë¼S'æå†-ÜöÊÃX79Î>ÄïžY ;çL_ƒ^ýw0Ú¡!ëxE3Þ$T.™™ûgFúvYÀ³ÓÇÀ+›yïIâß xnÀ;âô¦NÝÃǬÌê’:§¯0}lV.ÞÏ&ùuüô†¯r;týîÙ=lä1´<|K¹+H’ß‘7‡Cã,{ßm¯ðÌSØö¼†0#™ä%¨çQîj²‘9"vã²k$É]7YP¬F^¹ŒÛ„,—‹ÍþÖu0¦Þ!{ë:,5Y?B{‰kuO& @’Ü1ul?xÛrÂ-sZ”wçÈìí8V+@A‰“ZîûVo"­BŽÉ¤C’d–ãŸ$®O—_Ä~:ƒÄz2.ÏH¬o’„^ çÿ.PsõÆXïuÐÖ÷ÊÚñ+$s§’µh.Î_JêºKbõ¼ÈÕiùmܪ×ZÂàýè>ºÛ'Tæ‘FCJ§×Hr¼“§D’«ÉS¼:톖#&ÛÙ¯C*G Ú{1äÞ9ZŸ3u¼3x0m\!.­ÜÊßWdü98«Ž¼Àðè!ÏœÓЬ‚;’$¡vOôñÕyéeuaÜõ}Kxð z ò%]g³kxûþ÷ôéWI’èÞ¦{ï>ç…Îd1Hj/²—(Ï€ò©yzx/^¹s¡P¹ÑºsCn­X˵ֵy°ö8ádàúÉ÷¤iálóìzÍ &Í?kžÅ=}E»;©åÈŽL蘔е÷‘¤ô±–ÛÝ×z\±æ…’0ÀÞ=5ÜŽó׿o˜]Ó£î Ó¯Óbr* 0V=ºg±'lG ’”.Áz¸¹t3£®¼·ï3¬ -;OÓêYb™V‡³z×=ª•ÍŠ #¾Í.ÿ['n‘)Wò9*" W_v„8³9kqîèç³æIš¦Q'Hþè^¸è|ªœ’$ñâÌ^úpäýJà*—Ð=¢ïèSÔíÒŒâ®ñ÷$àòQþº¬cúܘ;¿¸À€AŒžÜˆvQž£!ŒY‡ÞóÛÔ$6×|/e/Iû—=Â]!±bÄ6²Œ«‹fýF¦úªøµ^5Ú¨Ð|Êmò¿ÕsV2¥Ý/…»BBB",0€+7Cy¦3bçJ•mþù•2d¦pLR”±úµå1$‚ŸzÉF.—ÛDyGº²£¿ŽfÔû3¥C} Ù{0¨€7ò³Qs-—ÇîÖ6/¹Ë­ÎÛ6¼ðwG}ÔñgŠØä!“Ë,Ï ¦T–®Ísƒ'r¹œävr®êl¯‘Àι,¿w¯"ô¯µÈíR[>Üe­“8u#SÓ¸my0x”$3K'§gÑ •œTd¦yY2§¯³H[(7Ž3)âú° ËÔíqŒäi‘ÛyÑwHUÒ»)è™Üî£`2†SµÝö,í@¦Ò°ëñstJr¹CøŸ³dýs®ï½{ÉÜ,Yov Ë23ºRŽœÚËøs\yab~VgäV®k¹k&æ3?ÉÑ~óÙP¿Ó‹»F”mÊÐÅøê*’Eó-“§:#öÉT1tŒd.ï_[¥¢õ‚cP»~g£sÎAãdjB#ã"ä6Ïâ˜L‰!üíÇéÝd"O§&¬·®3Á‘+]ø­iIºö_Θq-x:;©F¿ VïòE.—#—;òÇoæ%«ÿ]ºÃ;YTþ+§"cíz8ÚÙ1 uÚOø—š³kÙìå§üÄônXó©rÊd2R.Ké}«h?FÇŒ>Ù™8h›6¢K1xëtøûg šq{dœ¼òž<%l½‡.) 1or>2xÚ5wîâMîJ”tµû¤²—êÔÇïøatNÙi”TEØëÄ-{ÍëÛ¬ ÏAQÇ+$oœ„¡ý×3rrM6z¸xó'=`ðàx+d¼ñ=ßûô¸Ø)K —\©ÂÙIZ’P;©qVE•Ÿ$ÁåP#}•H!zdrµåy>Z~çŸ%¿@ðS$‘îQ“Édi֯ܙgõÏÓ¬ ›žä`õá ¨b ’S(dèßð÷¢é±ÞÔ_g@¦PÄ`gÔ¿d\óF¤n³†2¶þw…<–×~)ˆœ_äpQqêÎ{›órIdñ¾* ró vîy,r óë ïñëFÁ/¼™è³š*ZýšûˆŽ'øÙ]b@¾¼6Ïàì•uKò£¹@Ý!!dò1bƼR{2zÖ0טÿàê+ÿ%[§jdS:!M^];Åï|tÏ–„ÀÛ§ùçafºWOŠ«‚ ½Ê0µÛ&\2þBJû¸gÑòãÐòl gZ'S0ëD0s*Ç𼕷ßÙ–\&æmQ_Fën×É^³#j¤ˆ·>kß=¥ß›qªTÙet´²®}+Dí½b2™È”ÄvÐõ¿Ç°Mïø¿Ì–ÀÍ/{#ÁüÈÛºRâ—½AÏ‚ñ‡)Ö±5̸JŠ"å™rŒ´îΜØy€qëï┥ eó¤CHŸ©~ôX‡ˆ€f¯¬%éi2ï_£”$Tî.$s”3²Gyär9º»„)½ñT+ G.··ÈûñòW6æ~¢üÁOgX¯SZ¯ÙÊåÑ:U“–#«Ç1yÒ$RÖfÕÁeäpŒÇ]¬Ëù³Çb=lˆ½Á?ÚÏ ŽM¸•n{†Öþhar·ÉÌ‹…Ç`@Á¾öÔ¿OÉØ+¿ÜÖ±$¶º‰ê¨õa¯Ù¼ù,kPó×ÚŒ¸Ì¤#/Ú³"ß^§Óª zlEtÑ^ •äx¨!4$R÷ šÕ*d9ýêúAN=räâk&¶ŽZ†H¥”!“;S±xZº-ÜCù?òQ%·++¶¢äï©”ÙìmR9%#…\OˆòmŒøƒØ0tNr˜µø,-[ÂU!‘ÉAÁ¹GZˆãå™Â‰…]™°ø"AAv¬-êï}CiQ¹$±ÑiBô® §Ç”ö”sVpnìÖÈ]hP%9áÁ«“ؼ~)IJÒ§ð±îËrbÕ&†ìzÍ É­I9`H º®C·nhõ§šõƒóÄ+¿õšXrFU·&¨÷|ÎމΔ1ÎM÷Þ=¹Ï@Ÿm„*Ï’ÖÙK‡hi:z%¡šÆ «‘ÊrOë½N´oŸÐ£ß.ªômCÁXv¸MHÙ(ìÊÄEç ²c]q÷oiâ•}hÀiö“yœqMþzå¹³q«Ÿ¦cñüÎÜ^·&C‚(¬¹OÊ©ìÕOù®;Ǻ'ü4ÿ^âqD™g+˜Ž€ §H’¿ŒÙ@мBRº²ük‹ºÆ0ê>F~C"øé ëuJë†/—›gr¹ÙywI ºNzίݖ1°sÃx8÷4o—š‘#{Åz~þðndp³Ãzß¡—G{Q±í~ü73ÛÖŒµ³5D¤WÆa¥«û!#ºñšî$‹x•Î)yzÒ¥óŒóƒö>‹_h˜V- …y+j“If™¥ÆÔ<ª3—”øÙ¥fÑüx*$ i“î eŸy¨ÑS¼s;šäˆ{8¥R†„¥ŠÜÙREìwïDÖ²CªØz’r·«ÍT£ù>÷˜ƒkïúÔTëyò,·ú0¦¢é¬t(•J´~ï±sÈüÁ²KþÏ­û"†D –ldX~¬ûÂ,m·q¶µWŇ_ƒuðjÀèÑqŸï4fVŒcÉKfËʼndv{•s^†šL\;,;xÖgd¡î Üñ€¿ë›;Ü|£ö²ýÏû`}{ìȨ̈¼‡*b– ¶t‘Û;G~äËÜQzÑçW/^¿ àØ­Ç;s‡gü(Sµ8ß±qÕ2joõ¢@ŽTdNŸ”ô)<Èž+ž ‰À÷á(µZˆœYùyqsª{9PuB;¦[Eõ®—iQ»5+g'™BB&s¤`Lܻ󘛷å”MåO­îÿ°`h LÜÌuׂl蔹1  _D½>O™4®.ùäø®ù—¿ƒíÉ’>eÚÔà·LÞäHïicd™T‡F¿­¥Ë='œS”Æ=¢SMYº¡‹öh,lñ&Ø{¹‘J£¶¸þ“dh«0<+§·S(I—Ê;…Ì2k6†±úµž1EÝ-ž…èûNÄ¥wI‚í«rÙNÆËg$®9AŸåÁŒž—Éœ^’ñæn÷_ðL'#“ƒ6ÿ½‰I;ñ™Ú•×ÖÑw¡‰Z¿Èð÷rÄÙ^‰B.è7  ×£ÕêÐèžq>Mq ;Êã”ßÛ9€9ËÙ4Ž(S8ågɵk:æ(ÃEÒKCzÝ6¦ÏèÎÔÍÓ3•²h9–÷Ò²2ÄÞ&ÞeÿÌ¿vLC÷~íiV0„”½“W†´ Å«JzKlDâ–½Œ¼N s,ZÔ–ëoÞeÛžÓl¸d ÷ˆŽÔ‰¦]È­¿Ãë7!¼zýžÛïth†/g—‡ ÒzñdùÞd/Eù¾~äȽ-xäw³äÿ±òG}¥øÓä~jƒÄ<#1#r¹ù'êÃUö$ù¢âLÎMì2Ñ©k¦x“üú÷BoE@½#òþð¾oO^ܦÇxfžo‚Ri–Õ`0ÿHRÔ5ëY›ÑÆ A+¸øèáj7òçNK‘bEéÜ'#^û7´hS“‡·ÒeÒ9 IDATrîúc®Ý¸ËáC*fMJ‡\ºÏàPP8©K6C.ƒáfq3Y:ZöúÚ©\îF¿‘]¨tøKvܧIõÜÈå°|Øl>SQ½rvỗƒÌÄ•³ÿ›ûÓ¾¾4eÁÍèUÊÛªc0ÿèt ÕšX»v-½;×D¥RÅŒ ò}IxR/’9Ú§AõávN¸™]Â:#ƒ6™ÊX¾O |Ù–öí=w>ʼ¿ÛP½î˜OÊãì¦.´l½Ž> £P´P¯×£ÕjY»vmDŒ©wV‡\¥´‰ Ñ™øàÇ ¿¶üŸ+ç÷Æ÷Pö‘„kuÈí”ær1aDⳆò4¯)™2eÄ%ø¹<$¶1$r9ƒä¿JÊÊ#ø-i½ ô¦O´c‘KVF#k\³4÷ŒÞŸWvV¯Ú%¼;•«â²1¿¸~U®™XðÇ3½ÐraǰOÊãïi* n£C6{…ä1fÉÑQªb)¿’§ûcäÿ\9¿7¾‡²·8LmêÀg# l:_S~C"øé ’è±R Âc¥‹ðp,£XÛ"i²4þŒëÝ2¥}\ãB4·ý÷¨÷„Êÿ_—S”ý·“_ ø© ’È×ßÅkð1u"àËa‰!Yqè±Ð†@ ‚¯J‹ræˆÚÄ4¯”]hF ÁWaå¾›–x)Ë’M–tœ½ë'´#à«%]ÔÞGƒ$¥ò-©R¥Ú@ðUxúôDìrfó-F#´#à«i‡ØÄ¨Õj¡@ _1$‘ܸqUhG Á%GŽÜ6+’H  ±ˆÍùk ‰ˆ%@ð%‰´5â!±$@ ¾$‘¶F¤">š à›# @ ßCò…9zôPÂOHéÒ儾cvïÙ-” øéptø:á íÿD É7 R¥ª˜L&L&`Šø?6 þ›D–kdY;vT´¡ïœüùòP¼xq¡ÁOÃÉ“'¹sçN¢GŸÓÿE!QˆbúºƒVTá ƒäG-[@ øYÆ£Äìÿ„Aò fÐÖÀúo0Hà¿4%ªA"bH¾<M˜UacSpÑ ¾.W®\ Ož|ŸÓÄ 0a4šD?ÑxôéýŸˆ!ù¨Têh–hTE0ÂCòiÕª×®ÝøÜy&“ ™Ì$Ú@ øÉÆ£OëÿÄ>$Áœ€Ó;ñ}«‹q\ûf VŸ JDŒá/˜>}z‚ÓûÙÄí7á1g‚¯·3má!¡P þsÉÍõs™=m"m¸ñÃÊ…ÕË90—׫³{yð.¶Áé KÖ5üÃdxK׎½Ùñà]ŒsO¶ÏeÃU,éyqÿvn`ú¨¾Ô*—ß–\åü©£ìÛµµ«—3öõîHƒå)\¼%O´†Ù„úàÔ‹ÐÇuzcŒc!OŽrìÕÙJ¯yÄ AƒV6ú74kÜŽõw߯8÷pÝdVÜ^3 >-†dxZ¤Ÿ³š¶)>¶‡eïÛT®#AÉGÉÉÒ‰E8Ó¯š‹-ÇÃüqÕT”"ÞöÌ#äéq.Û¤„ç×é ´Z-q­×YE²hö4Ò•¨II½üª{Gï)6gs{Øœ{¼s>[ô¥¥^'jyBžÏÒ“Dô€®/CòúÆ3^_Œ_±´KóI+oнAavÖ,Æh+žJð+‚.øöÕ–±y@L†÷ 8UŠäìÛy€ÅkÖS0{¶Ê“777¬Yˆ©×$†þ–tiSboÒ¡ÑDéÄþ‚îõ‡ðë†Ýh4Œ†·¬š<”Å[áÿÎHÚ¬¹)V©-Ã:V0)ÒþhГõ;¦á¥øoÌ{î,èÏè#/l=$ú×´lÙ2Fú|˜Ð&“ybpéþÇ;ò¢ü úgʨ¥·Þ¦kó¥¤g¸I•2 #yó‚îÝSîáܤB¢á ¾:;}Éþï‹Ä„¿;ÊFßû, àñã@Ëñ¤³à&—â½öä´& ÛêIÉ*³ðTÈxÿ&}<ëWÕU›ùßêkœãª´}6µkYF ª@ÐÍg^J@ñátÌúŠÿm}B·ú…ØY»$cu®x(dÀêÕ}È ÔU—²©¿øŠsœ–¹Bù¹¾ ›µ×D!1éÒ±6wõ©Xz¢{z—ãd† ôS«QÊ$j/ÛÆÈ´.–ä66¢Ë UÄs¨Y´v &Ã;²î>AéüYð;¾”G.IðŒ˜„M¼»}‘}Ï£<úô‹¨GpbìoøÕ™MEoWŽùÔeêVg¦,ÙNñ4*®Ÿ=ʨ?zÒ:t k•FªÓËÏ ãÌëìTø?Q^ÝÍYíïÌèÅÊèÆÑ9 Ö³I{ûÝX|!Ðl˜Âi_«7tiÙv¿ÿ´Éž,s‘¶É¶cLÏèj¹öîŠ 4»,ÚœàÛ×x”1$Ûÿ}‘}H®Ï‡{rÆõîj9¦ y!Û$Ž.®÷ukóû*«ü…gDÇ×¼t®‡Æ=[M[}6[k•©mT?=ºÏkϦ¬WJ† e}½ÞN÷›>k©UQƒ»w²_˜Vnm&ÿ¦¥K–òÔU¾·±Hµo°ç@f:5ª#½Ü.¥epܱ.÷ô)™w ;TãDºQt‹4Úæ­aHgËu¶´¤×mÑÿÓHJf®Gåšc¸tncïåøœ–Ó;~oÄy+6üí#äU"¼ÚÇ?ý“1“)œ#G£yáEþü),éßmR#/ù½¬&(’y2¡½A÷uO™.Ê ]¸íY»l¡Z¾Œ”¬ÒŒ Ù’ò³˜%MÞø_¬ ¾½O’QýߨaÀ)m1*WŽò\èCoQ¯a{æÏŸk“Îu»#ÿ¬dÇòC³ÈWtgNL ÿÒøþSÎ’v}à œ´‹òvjƒ|QÔUZð}1uê,˜ÿÁtíÛw W¯Þ_fbø¹4è¶ô.Ãÿ½LÓŽ–ãgÿ(Gê8¯;±b &œcöþ­ävŽšn<CÖÙùUꆓ—«U‡ÕYJ2%¿üRÁr.$b¶W¸lyr8ØŠú=t–)òPÜÛl‘?_Êè¿n  ½Œ„=›7o¶I[eà(Ê»©,ƒÓ¤#¨Óp"W.Ìcâ½Bü;­¨%ížî-¹h=8½{Œ¼¢hp aúôi,Z´ð›6ʸË:¬zš_:,cúÞ…Lÿó0ƒ›¾êsWãcí!ÙÔŒî·"&¡×Y³f+ú°»˜Œa¬YóNÉ;ÑÚáo&]}Àó÷Z4[ײJm8›LC„wÓïÔt^­)èÕNÓ¨ìÝ·]‡l(¥Èç«@f«çµs-Cc÷P&ž`^Éä¼¾<—ñ+îQoØxJ¸Ø}WeŸ­Óþ”'£`Á‚V¿p0…Ûv.šÈ$)ʓ⒱ —#gý¹,»¸Qƒö2a‚Ù"l°fS2DõY÷VU¡ÅUÑÖß½{÷Áßߟ-[6Ç™¦N:ôìÙë‹=ÃgƘßéWYÈ"ÓÛ\·úÈKJ­H#/mÐu&ê˪£ñÊ;⮲ßoëIÒŽMa“þùÑñè<›“Sa@£± ÄÓhõæ{j4hdÑŒU¸…ðçɧÌ,îmî,¯ÎgòêûÔ4ŠbΉ×YÆ·f·dÖ_TèÐÇ Ó¾cÐ4ÚrõÊ>¹<ˆÒNQF†:Ee–Œ=C­®+ùsã fN>DŸ>¥0šLTœº€©£<$·w ÿ]ýgÆIüØDê¦k×®øûû±mÛ¶8ÓÖªU‹®]»ZéóëÄœÝ{†â½f‘Ûèȵm8Óñ8:£‰³³'2ڪξó}Œ)“Öüöå™2¥<·æÔçàq{ÆLšŠ½LâdÇ“;þÍäÌnìmZ‰gƒÇÒÖÛÕ *ðà](šgÉÅÙ7HZ²“Lftgo‹I«v’öíÚÒ¸FIœbYž­TÈ“þ3/£)è@àýlÜx–ì݇RÀÎø]Õ•¨>|ØjÂu—äi±9àääD²èe³ã8F­£„'ý]—³CpròH¹F¿¹õ²‰6'ø6Ä7ùøŒàÍ›7>|(ÆueË–cøp }´3ßI ÉÑ©™{))ƒ[&å×Juè9ñt®– MÐv¼Us6cÔVÔ¹Sé;l.eÛ3¹ÍA&\¶Kð½ Ú'l czä6×Ü[xïr½bÍÇ 2!*µu,^ÚÅ’ÒkÁ}ÔåÓ™%ÿãlÙrš|ÆQ.câ[³[¿l ¹Ûu#³\Br…}ûbFè?ÖêÉ.Wƈs¸qô"%z΢ڃ›»q£ëd’Äå¥s™n58½¿ÿ2*!NâÇÅZ7cÆŒ%88˜ƒÆHW¾|yÆŒ‹L=àøËÆ„n¦HÙejdš´?VŽ%\µø>K'Í#YÄ2gû6-隇DKÉ’%mÒ9&ÿ»ÍKÔ¡ÿ&[gŒr5²ÐŠTÝ]…¼å\é6ñ ÛæýƒWˆ¹lêÕªI¿U©Vµ"iý]E£|>C2eÊT:wîÈÙ³g-×.\˜É“§`g§Š#×oCòúÊd:,xÄäÝû©•Ö™"Ù'Ó¼W ®ÜžAƒISo.ƈ!ì.ã{tfÅ='n¢sÜܘqì£îw}^wÒv¢ª»­ ×^†âÞÌãÓfD…<ø€45Öà[ãÛU¥c*U*ã¸ÿîM¶Våë픩2£\…,¬í–&{QgF-¸Å¼ÑÓñ3[°]:þF‡)s([¦$)EKL 2™œ‰'Ó¥K§râÄɱ#_{Ϻœ8V•‹ãKå$Ý„ád¼w·†Ó,;h~8I¡_‘ï''KÀÖß/Gº½‘¿S£x\v²-Cø#ù¿4èW˜Q@þ1ÿc~v¶UÎÏãi‹èšÂ‘Eåò`í»x¨1à2æÛk) Ðkìº ~Âúy9¬)W^mfI·¼QiR9`ÐÜÿÏ”}ËǰvPêCoá’¤8—/Ç…ê¤)¾÷*¡võdP¦$dœ7‰l7oñÆpŒ9»Þ˜ ³í‘»î¤$§_g–Ý®ÂfÃDs|g¨Õjf̘I«V­¸{÷™3gaÆŒ™_e³ÇO6Hܲ·dÌÒÖÔJkè²Õúƒ3d¢e‹Þt sbã…RQ…3¡5Ø~¼;™œ>þ–úЫtœs•:ÿ,Šq.®Î2!|oeœžìÖÆ£&ö—ÄÎÙÉ• “vô@2øÞçᫎ˜gw^ù!Ž<ô&Ó«al~PšÎ5»‰ð?Ð(ãâÆºL¯²Œl@xÈ%:<ÎÙµ ~õŒ‡¦°Í­6’Ìia[&äoÄîE½ÌÎTÃ;úw]G¯Ýé³jÞˆ÷[¦®ÜèÛ’:Jož¾'¼Ccö*ek´•EÕo;¯´qw"Ž©iÚg´÷h1·;t;b9§ Ð"³KñÝ—·>ô:Ys׎eâ§“–Œ3ÆzÝÖ«·Éé àr—ÒŒ®»Ü€îýYšt:È“sxçÿ„{ËG²Ö³1’ÜiZ}kÉùÍCE[|·899³`ÁB†̘1ãprú:Úψ!q¥V^Û´vi “ÃÛY©™d’éÑh"ךÜ>²3uL«7a2†ð^F} ÚµEŸµdsŒ‘ÞK)ÃÿÙ;4·ׯC¼{†L™ô‹w$Þ÷¾½N‡Þ`Bჲec¾õóbçFŒM È5Ÿ¦Ì­0—,&о½HÏa§9¸®*ï^ðxëv:W™–vfjžÚ¬›ù;C÷€‹nÔj5sçÎeøðáŒ5 µZGÎ׉!Ù{1¤]ÔèM&äöeHÒ‹ÆáÔ¬–Šúª˜³0%µ'*˜8(¿tE®Ó¢ÑAÐ1<*1† æçÔêääq0¡¹Š­ϼ¾~9žN˜K¯ˆ}„d*É"CF';Ž]{…¦bTÔĵËp©Ðœ4ê(o‘[fg ”0Æ2Ø\ ÂÎ5ãwÿm…CNnߎù*Ú®ž…é~Ë£ìNn‡W´Wñ s¿²óì+R 7ÇɨÎü¢>¬gÎócú¿/ö-£!ˆ1­êp»-û•Dõí=T I ‰Q÷’-ê°éYfÖü;ÇXâ@r»¨8s_ûI1$š»ïQ¹çúâ³ÞøÖì$@¡T¢KŸsëÖ­×LȢŻDòîHØ{V"u˜wìGÒ N ¦/fö¢ÌÔ™¡dÒ \t:˜W;;Ñã∯I–Ì›yóæ' ‡/¿É–@ #S¸qN’P¨Ôt̓k¡FMý·–3Éè∄Dæs(½¢(í¦¸²|pC¼sú0¢ µ]( YžmRç¶\ˆoE;¬'·"^OÍÜfc«›ß’+Ø:=_F=Ðü¦‰!ü9‹çÍâø¬³ Ð’yÒðøÂ &ºDú3°·’ýÜa?2÷Ìk¹§ß ºO¿Nûù+¨â¦þÎê€m±wVwÚoñä¢ïöô,KÞBµ;uíªä±ÝâÚÎ ÿPþJjÏñµ_þ<œzÊɵqëø7iUf½fh²Œ 33R¹¿;'´D!ìÁWF¥²‹6}ÞÆh±åõM¿eúì,ÃZTa›¶ Ûöø 1òa Ã9òÏ4j—,Çn}1þÙ»,Æk»ƒ¤U:žï>ûI·9qà™ÚEíëw‡Æ²çMâÎæ¢XtO €ƒwsö(Š››[ŒŸz ¡¬›ÊfpÚ¨¡¼‡Ú2Cï#—‚ÂØ8îw\šN$EÄÀ’ºúdŠ?KÛI›1ˆï÷}!b6ÈÄÆ }J¶ y¨fCUsÕ¼æµàAXÞ) oÞûc@I‰Ïº¤95ŽA§üäŽd±·m?¡OîÒ ß0FŒň£¨é¡¦DÏÁ–¿›§{Ïëˆ-áSUÿgÿÃOgþ[n—‚™Û÷к°œ%ûR¹Ly: ™JšFýX?¾ªÕ3?fÑK-~I5ÉOPÐk´Æï°2šô<÷½Ê–Å©[* þ fÏÕ¤TÉi÷¿clP”¹¿•#yÖt0šå÷ 3^ó˜ÜY RÏ3jr×hïQ’M­Î”ÀVìì—ž ·/#ÊÆŽ©O‘áÈ º~!šŽàëWó#ŸûóY“‚Ïnߌ¾ôŸ³›Ò퇰¯O³îÌšî­hK§é~4ë4•ªcO–©ªÿNÈèáøéÚ,š;URx!C†X¯ì,§}•ÎÒw%VO›ÈA»ø­¸{3&±(Ñ©7%Ô/É’.•ÜUœÈ¿Ú’ÕlÙ˜9oê±e@*ÞûcDIÁàåëѼ!>gŠ3¦hRÑ"ã(£Älà‰\ž»6Å8^¬Z[*¯GèƒTÿu+)r·2§W&gÜÆ˜ÉbÍïñ֥̾ñ:ê@žÒ°~1³­ÒÔ; n*ÔnUñÉïÃÀ]OXR;m„Q’œ>ÿG@†Â!f×ÃMýq(1ž2®QÞ¹ä妲¯Ü÷YÖ4ÍEדrJ•)KCŸõlª”Ç&ΣD«QœkÞýkW°}ï¿,]”–õûLì:w8F~eêuãd¹f„ÞéKÁ*kH] S„îR2çÈŒÊä¢Ù ¾;ƒ$údùcòû\¤{÷={†—W2îß¿K† ™œÁ‹C ¸²1å2Ükl§W±õq Ú7JS@£†÷&•å-v$mÊp Ñ æÕH“àû?X׊ßþ­ÏþÿÕý¢…ôè!J”(M\1$5‹ J2¨æVÊT¾ŠÍlwB•’¤[±Ÿ&Iìñ;µÇ"Õ1<œHãßwaŸº1›—t1[:LФˆ¥k[®^½B«V­¸xñÒg4pÛr=wî,¥K¹QW§ C¦²ÿ¤² Ó`oÿñK%š×G¨Wg.‹ÿ]Ar»¿edÐ<¤IÅn ص‘ÂÎßßr¡ŸßsŠ/n[ކ÷ wþ¬`ÓðÐdöŽb)FðÝqòäIîܹCñâ%-ãOÔïØ=÷ 5H¬ “ Î'¨ÿ‹´5^½ò#eJ³cà³cHÒWíNúOPNê²íèçY5óÞL“9ù»Ê ^×ZKéì?˜þÎõƒôÿ+ˆ)ê£VùÎÒÎN§Eºùè)”öj¤O´.ûm?hœR”ŒxK ó`öl;Ö‹ÙX¼ù§¿ÊÛ áKÆ%}NÞŸz­:Eeþ™rƒ½þzFTÉùÁôç¶£úìÕ”NâòŸ©’üóß$°spIð]£T*mŒØ¼#Ÿâ!‘$0™¤êg¾È·l¾5jr¬žr‰½ƒñõ}øÁôA×Qmö*Š~¥­«ãsÙ©Õðî.…JMôó >­Œ§|Ü‚HV¦-– hc]Dµ¾û~ïS—jlŒy‰Dƒ?Šb#;Ë„àž³ýWí,m üó-RAâѪU«D3H„a(þ“¯¸Çœ¢^Öøì ÖÏû– !èt:KAÆh•"Òº#Ù·àüù ‰ØÈ£~‹6$¾Ïñ(Ü*^¢Ç5~ü-f>ß|A$à§gó–ÍB ŸAÝ:u…‰Ž0HÁOGþ|y(^¼øO¯‡“'O’5kÖºæöíÛ¢ ¾ŒA"bH¾,Gú.žCì‡"b#EŠ Nûüùs1F Cò ¨T©*@,ß°á³?ûÑ¿&|ìØQQ¦ ^#ãcý‰ 11$߈Ø?¨÷e ’ÄÎW üxX{É‚o‰Ø‡ä+#±ýÄö‘½ÄþüXœÞ‰ï[]ŒãÚ7ûX°úDœ×´Oø{åQ¡@ ööö6?z½žß~û ½^㜵G] HlD ÉW@£ ‹ø4½Éê·Éb¬XÿN$F£I”édÜÞѹcoJÌ?@—<ž6çîošÍúhGYkßÞ`ÒŒ}4iPCøsZ·û#Þ{Õ¾ˆ†^QP˜ß!®šŠRÄûÓ¥§Ç¹l_žÂÝoS¦z-’Bõ]äk0hß¾=ǧ}ûö¬^½¹\KŸ&úAbŒ"†ä«£R©m£å~2™I”éÂëëO <×W%ÇÒ#×kfn}FïÆEØV9?>ánx*%`µj.øö5þa×м–ë%’$7×UjÆïý<½]Q+ÌNTCøsº7IËí‡XÓ®›ì»°yQM›ôGFöf§s[þì“Çæøæ¶µXáØ‹å>:†4ÌÖý³H¢ÎÙçG—Ó©ïxŽ\ˆcê\T©Ó…Z&Øm½±{QÚ-¿ÍÂ{/l ÇÏÉwèС?~€ãÇ3tèPÆYOD"H D ÉwÀ—4FjÖ¬Éõë7…’¸i´Ž¾mªpWŸŠ¥'ê²¥w9Žf˜@ïˆÓµþÞÂÈ´.–ä66¢Ë ËT™ÑcÆa BxÈ#F…Ò17ûÔ£iõJê 1n7fã²X §G·âyíÙ”qS‘¬¼’±ÓÆ¡1Ö@-“Ì ŒZ†¯Ý†ŸòöYkåÑ aÂÉ䞟û$É™Vn m&gÇ Â?uq¾{°œÕ;Q ÷Îï¨NÈ­ý´«×Ž ¸qpB­^ÿxÛtØè…R ½•wõSòµö’>œáÇÇy^ ø’ˆiÊ7 >cbóæÍ¤OŸž²eËòðáCì|Z€D IDATíí¹rå ©S§F«Õ2pà@ªU«¯Q"ø‘”Ì\?£þ5—ÎÍbÌ¢¬ø£„åôŽßQ³f5ËOÇi×­ŒËWí k–4ÈändÍäÂÊðèþ}æ¬Û–-Û,?I^=%Ì`´\®½A÷uOÕ%7iê·Á }Îüç!–4ÁÏÿ‡¿]a’†_`M@¨åøû§³0Èø£p ôÆýe]ðÕèêâ\Ñr(¤êÅÎQ¿’1‰yJ7dû–_9=«%g߇Ç{mXÀ>*´ZˆÏ®eh¦ÏÎ7¶8‘ø~‚/…ˆ!ù hµZ¬ãGâ2& DòäÉ©_¿>>>>ôèцŠ5ÂÇLJ4iÒ°oß¾8ó¹|ù*Ñß°eú4ÖdUXþç ªuø›IÛæ2yÌ>ú÷/ƒÎh¢ÊÌ¥ Nå!y´µ}îhÍånÔ"Éœ¨V¹cf½¥z•2Œšê‹F£Áœ:|…d¹6Hg$\«A£1ןçGÇ£ólNN…Æ€äX.Ùµø&¿÷7)7mÇ#Ï´y“•«îP§c6óñûpJÞŽ4’Fª"4p áÏ“O™YÜ€×Wç3yõ}jE1g»ßÙefÌ•WäYÔÞæx²b“I¥\ÉOØÛ4cì×êßÒµ\K’þ¾–9U ´j㟓ïÇ"úAbÖ#CòQ©TXÇD7"ªW¯Nƒ È“'½zõÂÇLJ‘#GÆû;W®\ìÞ½›­[·R»ví8cH"Q¦?·Ž^ ä (îäÉòM¹Õ÷J™Ä¥%³˜êÀøÎ÷R&•¹ÜHjUd ‰ÊKÒ´u^¹ÈC«{”hÒŠ .ލտÝ{ oã]®—Mê^1íwmD=ܼô²~×3rOÏK ß Lž½uϬÝûœLÝÚ\[»XRz-¸º|:³Æÿ8[¶œ&߀q”û ê©öýq‚tFr´ J–äN”vUqþHÄa8lèñ »šà;¾ß%J¾û÷ïOð³W¬XQô'‚DCÄ|D÷hÔ¯_Ÿ¼yó~Љþ»jÕªìÙ³GÄü„n¦HÙejdšÆ´8TŽÅ:çK'üPókÀíÛ´¤ó¬ÅüR¾ ©^¹Ä›ç³Ý›Hž!3Éc9wqÇN25¬ Àµ—¡¸7ó°9Ÿ­kUÂ6ÍçZèh²š®°1PÇ®¼^¤ÊÒŽPŸž\ J6ãe¶¼cN­Ô6×zò tþMàÒÔXƒoŸ§,áþd´ùöJf{+õºG[ûÐn=÷'b/“0'ßV­Z%øÙ}}}Ec|1þsɵýûP+GV'e¼ét! ø?{ç^E•þñÏÜž^I%$z¯ÒÒ{QTEEŶë"¶]ÛêO×®kÅuYl `CéÒBS@šHï=¹ýÎüþ¸!ÉMÜ`€óyž<7wî9gΜ™9çw¾ç=J$HWoþ’T²4áDyº¿‰j¾¦iŒ1rîsüøñ?~¼‰àJÂ#h»wGïÈ q݈yñIbOŸ¦Ø±—O·:šVýoBlM §cNÁý3Dª§Ìc¯>Ã'ƒç0!À@qÂj¾KÊ-#ÃQå¼óþ:®¯0HΚxFºj|ÚÜO¤îÞ<”ÇÓ¶7ñ ¿“öð˜Bœïü¶?‡g¥·Ñûcœ¿ëÓ´gkO椫·ÓõèÀSm1qªÅOŸZÛ9?1úÖøËº“ öÓ»­\¸¸H­BC"hÖ{ãrÒȶv%&ró¬ë0æQd“ëNç(góšmt»nj‡•ä]ß³-¥ŒÀãÕɯŽô%|»ö'ì Lš5O• ‡£œ-ßnæÆ9×Öz¹XêÓ¬]»–°°0|ðÁF#ç>GEjjªÐ\áúÛtÞûcÁ~?ÏÎo&S˜™AÊÚ×Yç=Ie@ùà6þÙ{&kß^Œ¥BC‚¢`¶XQY¹)(Š«¢Ðþ†Û¸«­©ëw±cÿL7²-wÞ_[yÍkU䤗`6ûW«ÄÒn¼òî!~µ§Ý-W¦¿ãÚ0þòÎ~× râkµ®½’ *mÈU{Mê¼{ Uqä·|hWÕ)r9ë MÄÆµª•çøË“i7°öÁÉT­Sìì˜Ç«­Ù»{õE—ÛXD"pçuÔd ‰b/ä‹Õë/˜Î;²S†urKåsŽìAQÔlþï'جVgø/?#§Œ#H[5a(mûL&3¤K$%é¨,F¬:O2¥Í° 䔸F¹,:±žR»7vcmbc1geb7tflÌ!~<%3»‡'Ž&Ä-«OCÒ¾}ûJkc‘sŸË—/çŸÿü§Ð\ÁìF¢ï‹Ì“Çä½Ï‡ º0á_:Þ|ª 6‡äUqo×ÐÜ7ÿ):\ó8ºÓ»øeÑl&jT8LÙä˜`b¼pRå5ÓÃWϾ$K­khè#X~×Ç|,pÛ;±UéïGáŒ÷ùŸ¶€ÿìV+Ÿ9¡}@÷«÷š”t¼64ŒûŸøf?WÕoýô(Y6+§¶©•¥ÃÂ7ùfL©k,™1s.7<þwF4ªÜš,[¶ŒO?ý´òûüùóEA³á> ‰Ê›¡C¯%8دnƒE6³nÕ—Mx°™yåMª¸b/bá†ß°€nlv(>þh%­ÂƒÐäaUd[N”2ó‘îhÊò0VXº€ñø–­d§uq5HöïͦõèÑœý>¶ªIB !÷ӯР½G¡ºË9Oƈ#ÜbŒüýïgõêÕBCr%£ØX“gæïA¨ðPÜÝ£+¿Iø÷|ünyƒÖ:§v Í´7‰[1›žóâ¿ÍF­Ò³eÃÿg`’o~ÙÀ†ñO3ê“ïx-ÖŸ”nàÎ=òó3}‘m¹tîQ%êè1?†Œ÷Ã#=\ªÜû¯¨ÊGð‡OÓ«l|c Ðþ1{iÏÇÞµe÷–LÚ/íZù={÷SÜ÷Ú1¾¿’ñþWÇ@7éý—x²çÆ?ÖWïž@Ñá,¹õSú.ZÁ_çL£§gMâ€v:ßq~3®SÍ>±Øy~®͘Vž .·&Õ½äË—/'!!øøxÌòåËEÁ%£ÑqH$•–¨¨(‚‚ZÕùWvt+&ŸnÜ9©#*ÙÑäŠÛ¸MÇ)LèÛ_Oo¼½}Ñ9N¢öìN´o•x¯Ãj6cWì f³Š>£oá«Ó(<ó,3ü@x·›*ÎuO®úEãWyî-’sß­Š‚Ê`p4}ngIŸsÞM T]3†<Ö þúíiÞ›ìêö_øã>Öq}Mþl'“ëØ~æ«Gðô®ÑË•¿ zžï¾»ú®Ó Þ·³nëíÈV*]íþå_öžÿ¡PíÃáÇ/ºÜ áããÃÊ•+/Ðï‹þDÐt܇¤$qëNx3gò`ô’„­<™Ÿ~<@Ï w2¬µÙ)éè dG»ví@’¤—=zÁ"ü ÷ðóÁR¦ßu}!5ÅŽÁ`@QLì?UƵ÷µÇ^^\Yçb£ïŽþ8ÌÖÊm:• IVÐô¥›çÖ–˜ãÉVH|†‘AK{á0m®Ü¯Þ`@]1–ûµöÄr8^2MºÌæþ¡D…ÈK6âh€ARŸ†ä‰'ž`ùòån1JžyæŒF£Ð\<¹å*ƒ'j bFÝàÜØí9â÷?çšÐíúÕ0†}ÛFb08]÷×íbœÁ]·äœº\37¼óÿ¿Œ‚©_2¬Kãfq:¶•¿¾^È+[fUÖA@£Œ†?³\ÑŸÜ}¹-‰OÛaÄÿ’/€£cØôÅ ¹‰ÙÃÛR’“Q©áP©½¹uÁ"¢Û„]TùyRn˜7Œ>Q^d§fb¯ÿó¯Ç5†!z Rª^ÍÛetAzæºÞ{JôÁ[¾#詜Ø÷ ®L ÷"ûDÝ­Åž‹J«œeÚʲI*k|›ód,^¼Øm’7ÞxChH®´žÌ©Æ³ZŒ µ‡'êzRzzºf†À|öÊ!6¤”‘˜x¶Q{/<öß^Å@_aŒ´$„FDÐRh²A"©<<õf¼6~Îÿ>=HXŸéÌŸØkAùå5Ö«Pì$'§]ô>üõFÒÓLX+Œ?ÿZÂè%× 2åc¬öîÙK-QTæ@ñ‘ë1 FbØüv+ždíË&rôlË(±×íé°H*?$É}ñHÎyH^ýõÊpðM5JÖ¬YÃÖ­[EA³:üæ5!@·…Ü#š±Åqnu߆p.R«@Ð,‰»âtŒ›IIá礖”a/È %·Ì­=W#»9“×l$vô­ Ó“‘޹Úk_­šÌL#Jˆ³Ùéõ°Ê2 (V,V5ƒÛx¿v%F-‹„bÌLÆl©2žªkHJ³¨=BQdK£ß›Ö§!ùÛßþæ6ÉÑ£G…†D \412D"p˸ޜkÙ ™6‰5+ײ">Œ)Ýýq·f¾ðìa6o'pÐ\®Ñ‘²ìtZ=†jÁX#{ú³ÿèY4C;`°:Ò:• $ƒèaýØøéF{ÜHŒRmj ú*Hu INš‘À­QdƒÁ@yÚv6ìϥפé´Ó7ÌkRŸ†ä¹çž#**ªÉÆÈk¯½Æ©S§˜1c†Ð $>>^4pòäÉ‹Î#ú;hÖµlÔ†p¦NBqD[ÂýMd¸ÏŠNüe ›N[ˆ›rã®i‡­0‹Â:B$û´ïƒu×6Œ†n€S[¢ñòÅ_ª ·¬õêÆÈÁÚŽï…½<ß©K‘<ð÷r™-$;Š9\æ`Fï@lŹ(²³ÅŠoh(^¥ ›eS“êaÞ7oÞL·nÝšd”äæærÿý÷ ‰@Ð@¢£Û‰FZn_¨Å#¬Þ:™R£Í­åFõêü©é¨¥ 'ƒb£½îÒǶƒÕÇŒ ‡!C¦qCP(öŠ@B{÷ÄÇRF~©¹ÂHéÎM· ÆSvp.UñÉ-h£ÆÐÇ[KN¾Óøñn3†yƒ ÷ÑQXÚ¸c©¹ÚïO?ýÄ„ eŒ9rÄ%(šÐà²4Hše-³™rw×Ô¦¨¤¼ò PŠ>”ß×}‰fáÞzó½FínÁ¼ëÙ¸×Ȩ…× —gQh¬¦D7§‘Pp1Íq®=¯Pj®Îûí·ßòóÏ?3~üø‹6F¾üòËZå:ô;Õ5+n9§@ ¸‘fÕ4?vÐé¹`í ˜6¦”$M0÷Ýs/mÚF7jo'J¸&ʃ¼Ô¢&µ‰^¯«ÔsTלûœ6mßÿ=ÇgôèÑ ÒŒäååÕòŒœûŒ‰i벿–}N@p5Ò¬’–„Wd_ü$ O­Š¤¤äF•Ñ7\GzrF“ëRÝ8¨ËCRý3%%…åË—³zõj–.]ʳÏ>Ë3Ï<Ão¼Áš5k8rä .š‘šŸGŽ­e@Ð’Q]Ég7Qb•ÿôzÔ4Hê3F¦L™Âúõëùç?ÿ‰N§#55•ž={b2™ˆ‰‰aëÖ­œ9s¦r6M}åcD —Í£!¸àŒCB¥p>cŸ¿ývÐÅçT -š)==]8}ú4­[Gsüøºví!ZÊMlÜøǨ0 œBSW†û½®eÃû;v‚8@ hœ³5ÒÒ’iß¾=pkHZ*u#Í$xc#ÔÍÚukE#4ÓgˆF¸a\"#ä|Ƈûõ猄ŽD ¨ƒ>½{xÕ·CAA:uº¨<‰ì*4È ’æÇf³VÆ©úTª+4ƒAâºqNA]DDD48mFF†èOnã2Cry²gÏŸ¿f†8§ .Ž=Úà´ç¼J¢?¸s\ºâã´„˜T \)T÷¨ îF%š@ Ô‡l3aÌŠg{B‘hŒ«›ÍƦM›°Ùj¯GVÝ£.¸¡!.3Êósqøá«®zž8|è7Ú÷藺ϊÂÙ”b¢ƒ.˜ôäÏ_PÖ} ÅñkIo;— {•ÖÉ^žB„y¹:ZeYA¥’\¹Òtr4¡Dz§l]çC‘$¤‹Ê¢ IR“ÓÔ•gëÖ­dffϵ×^[§¾MŒw 4$ÁeÎÁÍ?bºîNÆ{¨°)ç ’ƒt5oSö è£Ó÷}Í®OºôšŠb¶a7'rðH~iõ݆‘{à 7ß2˜XÌéé”9dG[~ÜM¹‹0Ø0ÚLßÂÁ?R1Zeü‚C‰lÛ‡áýÚ:;v}Ï-·ŒE%&~`Ì+eßɲJìÈj ?Oúö$̳~£ÒXPÆžÅä”ÚPtD†ù2¸³·‹1Ó4õ±wï^2338sæ AAAtïÞ½–Q"Æ;à @ÜŠ{!9¶ª¥|üýј˱ŸgÆVÞñ­¬?s–ÜBtDjZ.vÙ†ÙbC¯S»¤µŸäà±¹{>Á^dfä¢8œegìZGYÇÉ h׊’ô Òv®%>AÇÔ›Ó£µ7ÙɧXûùZ~®crß4ž±Œ‰ÞϺ#Ff÷ðÄq•%6c ß($¼]£{y¡5›9u¦m»²™::/U]yÊøa_>킘2À{™‰]òØ€Šñ=œæ| 4ˆY³f¹L‰.((¨œ]#4$‚æD$Áe€"›HIÍ Ä¡`OJ A.£Èî4H ùÔ ´…Èú"Cj¿ëO;º•÷d0åŽÅôl¥&35‡ÏÎ ¿Ö› ëÓò‡'Èé3‘ PÎ$ç8wȶ<6œ(eæ#ÝÑ”åat(N(¤Õ°% éBNf>Zß(®Ÿ7 Mt‚­ùdä› 0„ÜO¿B3ôŶ«ú|f/AåëÇ°Ž¾Î Þ^ô÷×’°1ƒ£&½Ôµò$*DñðetGoç†@/Fõ7ñ;\òÚ·!X#5(Í…ÈÈȨ4@j"4$‚f5H„†D hùÈÖöï߇Z­¢Ô*#ïÝÎv앯gà×m[l6<ÂFÒ&TC¹É€ÃœÇþ[9‘VŒgÄ ñ&õt2eöê OšI+¯úæ°¦²1ËÈ´Û°fa6Uõ ei;‘=zÐ;XOêÉ̲‚—FEZÂIÊ{9È/¶T¤ôC•žÅ^ŽEV€:ê,lÌ×3ÌQ†EQ0çfÿ‰"bÆ¡S_5ç³MÿÖ;jJ•qYË EæH‰L@/o—í†À@<¤2æ8¡º`š±îyc„ÀבЗ†h®ŸÓ‘ˆð~zéÊn¾“4Î×3ŠÇŸø;·ßs/^ `7àÈ·’yr/›·ÿŠ>ºÓ'³%à ÙV„]£Ãpž±éø¶Ýø´›ÌÐ=Ùg%—>!óH!Þí& 9J‘uz Àà Y½v#ÿ·2^ݺӵC:•Ø¡" @ÇHO¶nÎ&l†/Ù&VK:§OgÐaêõXK1ÉWÏ»Ouu˜ƒC¿æ¢1xЯïˆl3cQüý\“Pª•((p ·²^0 u$¿üòKƒë_šºhL¤V Y ¡!i~Ìfs=k×Ô^sFÐr’êŸæ=Ònøü}õ8²,˜-JÏþ. Šl®V/ ‡ô&H*'éT>YÁbWœ1/dkõ·›3ÙðÍÏè:ãžQ^¼ñΛ˜Iï(?—tz•DY™»Þ„Ù\Ó`1c,ƒ€˜!ÌÅê½ë 2—”\çþÊ‹mH’/ ]õýLú©lv¤) ‹kM¤×ùãǨ4:ô’Da±ªM V…t›Œo€•F}Á4îìÓw]GBCr ÑëõuxG\a´|IuÃñϼG 1±hK (UéÐë,lÛ›Cû]‘meµêUPP†T¡áÐk$$$•ƒÁõ1Ú\x–MkÆ3‚n…T–Ïõ3‡³jÍ#f3´SHeÚ0½†£™&4­ *^å$Bß¶'~šªÐì£ÅŽgp$†Òt§w¥ØŠÚ+üªïgŒylOv0vD8ÁÚ†D‘è¨bß©2¨ÜjÊ-À¬H U70ÍùÙ³gËj¾:ubРAµ¯A1FÜÑ— ÉŸ? ÕõºF$Íöm[1bT“½#5ÿÿ3±™Ì Èÿe5Ùþ½™ß;˜òìô‹?6Ùĉ}ÛÙ}(‘ÈÞ£¹kÎXÔÆBÒòËÑwå†)þ÷ÝWXm³ÙÝiH´êáGñѳ¨†v@v”qð×ý¤Èfø .·ò¥$+½Û³ðë|ƒK@®´ä2GD¢8¬NIÚv6ìϥפé´Ó_=ÝÑþC¥x†`Ì3’Rã7§~*È&OåÉè¾>´îÈ¡í¹lúCÀO¬Å&ö.#0*˜VÓy’æ| 8³ÙLrr2íÛ·çöÛo§¨¨HÄ!\„Ar‰$j½¿—$g˜ma4/K–,áèÑãM5+[Ô9r˜sؽy§ËC˜·h¶’ÍŽ‹.G¶r<±ŒÑ7/eTÏpL%…¤ç—VþîÙ‡&X8¥#4ÀƒìB>íû`ݵ £¡`E¥öfìœ[8±/Çöo!³ •Ö“v=GpÃìÞØËò+ —b—9˜Ñ;[qn…AdÅl±âŠWiåWIÄ4«Aƒª¨”Ãu,ä¢%ÂO‡ÝæÀZ-¬­ÆàÅÄ »—°þLjƒ†ð¨ †vñº¨4çï§$âââÐjµÜzë­˜L¦ÊÈ­ÕŸd‚f1H„†¤ù±X,Ô¥©)–4v{SqIµ ’?û‘m6ì½¹kþ Î$ec½€Á¤ ê@Ï€€’@¦Î™MÛvd¦œ¡¨¼v;éÂzÓÏÏ›¥¤"_$ƒBdVw0ÜÃ\!¤•ˆíÇà‰³ðPkðòñ@‘í”哘U€ ŸÜ„&b}¼µ¤g”cv(hBâ˜sK8ÑÞ:rs-˜òUq=Ž‹¼`š~ƒ#jmÓûy3r°7Ь ©êöx4$Íy†áÇc·ÛIMMkÙšfÕØÌf$½$¡ÈV,6† ¸a§±µ#@ï*êrX’8’¨£w×Ö—}£ëõz\_×T'²,»ÍCR˜ZHªÑâåC¯Özqµ»t²Z·xHZ‚†ÄYHFŵÅW)'-£•¾*ÖG½YÚö¥•‡%åæõWÈHÍÔ õè ,ÅT;înF±ú‹/ñY<“©Êˆ()( ò%”ŠéÂ:ƒÅ^Äöß,Œ¿+Å”]«Çpî”Ø IK´ºªm‚ó›È 04cŒTö¿gÏž­ÿZ;º±æÔlùìçÜÁ5^ÌÅÛXù‹Ä!×ìHQ,ü¼~#m®»›A¶jéJ~ãâQŒð5PTR·5n+?K®I„w½˜"#£¢æ=i+I%KN”ç•÷¶j_®é££(Úy‚Qäºï)&9ËBt˜0rZŠl%¯Àzq©”"7È4†h¦ŽÉç´â÷ï>wÁô·]Gì„Ùô ד›Z NÞeŠÐšõÁÑÝz†G`ÌsF]Eû1ØJ-”¤ç‘ëáOl  ]ÍxEöÅO’xtéý”X/üªe€Þ—òìì«*ëå@c"µ Íb4ECbÎûÝ¿W=íäÙdJÖ~N–Õ„É’‹ÃœÏWæSZæ\Û"¨÷0zêA‘ÙðÝ*Ц,ÂÑU¯ò‡n$Cz8½$.en°®rðÍûíVe…é‰YκeᥤÝ8ú¶mEaRf‡Â‰ß²/©˜ÃÇ3¥G'¼•"þ8È›WSh¹ž¸¾ ŠäÚÖûXw¤Œ©4\ªÝÔ§!±[l˜,5R5O޵¬£geÎ!¯¤ÊšøyK2ç©°Ox7ÇÆÐ/ÖŽÞQ@±ÝF÷~aŒh‹º¶ûÖ/ȇÜ?ŽW.ÐViùlM–™:{ íCN%·ÈÌîCÉdu áš¶¤ËàB¿Ò4$-s Žif6S.Z¬ÅÑ#C\ÿ·tîÔØì9dD1sR4û×¥áߣ]5Œ¥¿’½Í›¾ýºa±Ø9óã7äû´"Ü×N¡Uf¬Q|¹z7öò|—Á= Ä×^€V%qjå{¼ŠGÅà0£êlGR{a08WÝvªŒ™ôA_ž‡]«Ç–¾‘=§svÇcLëèGq~e&/ÚvÁSÒ‰Œ»–üb+­ åçO×à5ô,—`ÕÑú4$ZmCûúl º¨õÀ×{ÈíÚ•ÈhŠNTM œ4.–¶;ãQÇ»á³?naµ­­½-œÎ,G.t ÑhñóÓByÆ:¬ci>6IFS·n ël›OX;ãFh8“ j-±ÝZÓ:Ê·;SÙ,µgb{WInijÉêºG´AÀ9 ɯ¿àèÑ#Lß½{úõë_mK ÓšLAxu¸Äi(âú¸·kHÔº¶ôíÝŽÜ|+ÇÕ­:v¦½Œ‚ü“Hê@ºwmONž‘b­Š<ƒÚÈèü:0sl6+Wìaê­×s`óQzôp†%î4osu•IþÁø,»jp+ÏØìÙ‡ÞÁz²“„CÛ“ðÇ´N¦§Qh9ç_±Ðs* F„ãe°SPœ‡Z߆.z ó ŒÖÚ°)`ÎùÝG è8t$­õ—nÕQÙ^LffQå@ç°•³9߯´Ù~X ]ãJ¨T) §ê,'>É„÷h=HFd»óØOœ.Äq÷…$ièÚΧ–‡Ãa5sà`6's­x÷`d¬7) g0U›’©÷Õ3gBÔ±‰±¤s:Ãùœ¬( »Ž•à׉`ßrOK oß~ç5Jú÷ïÏœ9sÈËË';;GôW ÑÑíD#- •; Qd+ååFì È XMFŒ&;Š"£(6ÊËXd¥–¸5+1…¨¸9ô kEâþ5˜|œ¢ÉômX·z5«W¯aõê5ü´?»¥Ê“‘÷[>Þm{!9J1ËÎPØÇvúuÅa)¬fŒT½˜ ²HÉÈ«|’ð$us³ ¬¥g9yòì~uz .‰‡sñ aˆ¿–ìÜÚnQW/‹óO¶[9m‘é㵚ȱ¸ÌŠÑ&k™_g‘îáj䤿³vS*¹Z_¦ôôF­óÂaΦÔVûµŽ¢RP²²ÈÊ©rÄ—gf‘¯òâ¦ax´ÀØ*’$Ñ·o_:vìXçïݺuãú믧¸¸X#@p i’†Äb•±[ÎpðP™Ùf í2ªc‡Ð–PTV€ÃfçàÁÃdd•‘mu   ÛÌ”ýÁª/w€JtêÞMŠÆ?BÇú}&ÄÁ78 _‹‘ÿ~öƒgΡk—N¤Y¼PÌf3Y¥6<ûa+-Âl6#Ûó‘ßX_¬Eù˜Í– {v‚u˜§¡÷특Ќ.rw-¢}„'Y§ò0ÛÝ¡¡qHŒyìÍ–™}{'lÅ©Zæ]È?‰Æ3A>Z’“ÍØ+êÞ¿{ QmÚP—}e*H$!Íñ±Q¤;B®ÙÂÁÃ9œ*€þCz0mH[Ò¶lÆa³¢(Žz5öÒ<ε¶l3³áPÑqƒñRJ9Rhl1ÑUjÖ¿_¿þX,’““+·ÅÆÆróÍ7SZZFrrJ5͈лq¯†D§B¶åtÆŒÙâÀ*CQÊYtŠ«Ù ²BÒ™ Lf;F‡ŒV¥B¥5àåß·õ¤]‡ÖüðÜÍ» Ô4JíIœMɧ,;ßÖ½8kŠ$äì*å·#®ý@ (sÈ‚õ(vƒÁ€¢¡’$L&”h Ã…=ö@=Š=•Þ»j]k.II€F‡ÁH‡Än1²í`)ZI"'ÇLšTޠزÝÌŽ$+'F¶äQ†«&$3#³Î|I{²ñnÝ FŠ5­‡!€ÛoëM‡9égH-±WxÔ¬‹";Ø»'),’Ûµ¢$õ4jMËÓT'.n8fó²³³ gÁ‚X­VÒÓ3P«k^BC"†¤É¯ltÞ¹þúYÌœ9“hƒŠž“gpÝŒ™LÛg7fÏ¾Ž™3gÒÇ[çò¤ž»å?¼µé(%£1™•kà…Î3mÆQN•HH* Ò/³µ$†Ûnž„¯3ü±—ZÂQæ@©ðH’ò÷@UÏ4Öš3 íF’ÊIúó§®:¬&6nË@Ó†Gæõà·w°7ûÂaÀÅÁ¯û2}ƒ¹±«Ei é™ òÙ](1nl8Öbçk I¥ap¯ Z©Ê8ýG¹Å ÷ØÊËÙ¼í,©’/ ¯ïƒTšMZ©­Åß †Q£FÓ¡Cî¼óN@"%%Y–EO!—·hHd{)¹¹ù˜e°ËPVO^ÅaG‘äææSêP°WE&gñë—ÏnØÿÀÒ‰víÛp*OÃŒ¡mPqÓ´(Tž!„ëͤe:~Öi0g‘ªMeí7¨5åé?°#»ö@˜w|#ÿïk—ø–<3jÏ0Åñ§žKi9¶¦c àÐé4LŽ‹äÄþ$~Í’Ïã‘°³ow2 F=7ÞØ•9Ÿ,“ýÂû+)cãÞBÚôëN?éYÕ)vÒÓs±40N„"ÛIKÉã›m™˜ZqÇmq„ªJIL»|f/ètz†$Iœ=›ŒÃ!Œ@ øS›ª!QçÚEAVì ‹Ã¹šœbÇl6cS”J ‰Ùd哃ñþz2dYA$µX¶|¦ÓHÂ<œ‹À>7ºå9Þ_oãÚΑHøuö¡èèSYW}ô(vZÏÆÿ¼GæÀÁD·Bï(#=#™ƒ¿Ÿ"bàMt‰åôéì œ=[FÀˆpd{9f³™òŒÝl;˜O÷1‰vóª£UíYåò—e; 'óøíL9a±‘,šÑuI'S Pyh˜<(œuñ‰ØzEÓ?¬ºÝ¨™ZÄÁ„bÌon¾5ŽÎ^VNd¸Dº­e< “ž\Èž?J‰êÖ–[GDQœzŠkýž ‡¬ Txbìö*c§8»”?2ÊHË5ãÐêé3´3‡Æ`+Î#!1«ÁÍ¥¤zýëúíôé¤óx¢Î­ÊìlÉ‹¹G@pþ±ÑmkéÞûHÅâ Ø"“»j§Vl¶"l¦ Þû ³Åޱ܆?*­½¶Œ ÿùéùR’PIݯ»‘#[ßç°½ 'uÁ˜—Œ‚ IÒ0læ ìýîK·¿Á> éÒÛ¾_0{wÇPRUŸ>#gѱó1výz‚­vb•Uø†3òº;7°æÂl4z*G1ÇÊÌ茽$ƒÁ€]#cµÙ ŠŽ&ÈÍ«ŽêõºZ3c6+IÙFL̘îÁ”çg’”UT©ÿÐz2}`)>mh^JJ®sZmÑÙ ¶'ØéÖ½#3FuÄ`+åÌétl*šzü]Y ¹Ä'•`Ñy0`T?¦ô 4;…´{½1HÔ* $•K:ƒÊ†Í+€‰ÛпK(‡…Ü´3ä›à<õøS-oMã§r×ÈùçhÙÉLËbÈM·ì£Ã^ÞQQL¥ʃX°hQá^Ø-Në@’<ÈÏÌ@ªÐ|t7’#_|‰®Æj£æÒ"2K$$—ÁR±±i¯‰qw B1å»èJìÆ>žN:]TžÆDvd4ECâLœÂ©j‹‹ëÁ2OŸYv”çömÎàdÉùJ eÜð0N+Þ|ûîó ®îÜi‰5>á:ÒOg`v4ÿ ãŒC‚‹1RW\’‹Á~±é‹³hŒêÁ^”Í•°¾çù4$ 5fª%BC"¸RˆˆˆhpÚŒŒ qý ÜF½I’.ZCògch;¤jðj£ç¸ÈHέÃ%•¡Õj]ŒšÑÄÓwó±dÉTªÆ [ÎIE‘.«{D h¨‘qQ}¯¸þîà $IrßZ6ú“¯©ˆ’˨¾u#‚æãСÃn)ÇiŒˆö\yT÷’ &Ñ—Æ9Ÿñ!<$-þ VF×çIp¥Q}¦%@ii)wß}7ï¾û.>>>¢—Î i²†DpAl6k5½Ô\Ϧú§ ¥$®çí²¾G¶œdÜ讵~zrúTÚ¾ó·Ez7ÏÓxö6Ž(¹&Ì£QùËÓvqØ£C‚.“WŠ•Âb;þžõ'±[4ú‹+¶yS®Ãá`áÂ…ìÚµ‹… òÙgŸ¡Vמ2/Æ;pkAÃØ³'^4ÂÆå|Ä¿zO|ÄÐñoT-hŒµd_'&ñ)—””üÊí!±ñW7}l‡5ƒûnþ;ó¾ß†Á çð37ñÀ–t:/ZÁ»sÛÕNo9Ë”I 0Ë ŸmØB˜Vâgcùõñí¦·hÕÞTv,žõ?|ÍGïBwsú…Zi2vü—Å¿ÀöcgñŠêÎøé÷ñá‹óÎ>»!ySî9üqvíÚÀ®]»xüñÇyá…®¨ë_ÐòúÑ+FCÒÒ;v‚hAÓss"“gÜ}Át¡ïá?¯?Fı/cÑ*…U[^w1F޽û<º€pžpIå6[y&ŽÎÿÇŽ§4ùö>3ŸŒio3ÜßùÔnÉË @íÅö—ŸGžûa­3eÝ2R˃1å "Ì­&ðêˆWXð¿òò-ò\%ø¿þ0‰ò?6qûÌÛ?[_œZg¹ ÉÓ˜r«{ÉŸ|òIž|òÉzša—*m=¶¼Þß{ OÜû ecBëM³{å߸ãż½é[zøhk7‡Ppä}^þ,‰iËþÁ :ÝKФ?â(ãÙßóèùÑB—í¡ƒ^¦µö,ÿ!• 7Æ^tžŸ¯½èr‹#„†D ¸L±* «&é(:ñ1÷}žË;;Öàïéú´{àëñðïà{íB^^°•ëjÝß;þ5‡w…ðؼn;¥/ý›»'vÆ\ø3?ØÛ ƒZB‘Ílݶë¢êÚmØHBµ*Nx’°¸ì[§Ra7IôyøNòâž!IžCWOçP¾õùÏþ áÎEõ}•¸rÚ ø Ãȧ&gëÖí¥÷£Ï3¢…÷_–Ò]Údºõ rµcÔÞ óÓóëö\¨a84$eÂé‹.`Ó¦M ®û˜1cÄ!pBC"\Ƥþ¸”›¾ãÛ%@­Â˜½¹sþ[_û™‘ÁUƈÔÀ ÷ßÍÊ} K_ú†»'÷àø;k•WðûËÜñA2/ÿ´‰©Ñ>\Óåen~`2¿Ÿ|ƒëμD›™¯â[!h•í…,[öèEÕ÷?ïd¼¿£YFæÖöØd ûåÙWI:^ÆýO|³Ÿ«ÜœöÓ£dÙT¬œÚ¦qySn –-[ƧŸ~Zù}þüù"‰ ùz2¡!¹´lÜøS‹®Ÿˆ“ry"©}x櫘w3s_Äê¿ ir™Æôý<÷È6XƳñ³ûÝfŒô˜CÆÇûá‘õ¦°ü.2‡4×-‘Y«ÓzÒ"ÊŸy’lÛ‚JcÃELyUÌÏЛxþ‘|Bn\exii×®ºjö‰Ã’ÂGY^YåÙ±–RXX€EnYK0x„ÄÛ.¤Övï¨ëصµ˜Û|›ao,AÑ™1·½Æ^¾®2MY~>ùzãEåiHšZu¬¡ Y±bEåZ6ÞÞÞâF\º­Ó§O+à6…””@»vD˸‰;¶1l؈zÖ®©½FÊ¥0JÎ}îÛ·‡aÃFˆ“t•»wߦ aáõ1µ~ËÜö'#ç0¢ƒ_³íÿ‹ÃÙrýJޛܦIåœùj>wnžÅ¦ÏhtÙÙ <¸EœÙjB¥óp{ž†¤‰§S§Nµï“'O!n(A“8gkäçç἞„†äR<ÉêõuxG\‘Ké!©n‰s}õuíí,©ç·¶î£m3ïÿ†w^â?ã—Q0õK†ui\€®SǶò×× yeË, Ýq^.ÖihžÆ”ÛPD¿!pçu$4$—úŒ‘šÛ.•w¤æÿÁ%é|GðÙ+‡ØRFbâÙF•Qxì#&¾½Š¾:Ñ nBhD-a\"$ jÚ’²|é ’ SD#‚?Ðá0¯ ùº-äÑŒnåÜê¾ á\¤V Y ‡¤ù±X,Ô¥9gˆd™ ñs>ñåîÛKy§>Äø]ü`ú†ïHè4’ÑÞ [@¥¯iÕ2HĹ®ncdˆ~Cà.û8$¶²,ºÿ=V|üÁyÓ³·ð»<ˆAáž,³è×1‹øvéÖÅ<ÄGޝ‘ÊÕ##Þ ®VâããE#à©^,¢ß¸·jHJ‹ ±ŸÇýïå貘;pØrÙ±cûùÓX3XzÝræ}¿ €ÃÏÜÄ[ÒëLû¯ï7ÑÙPÎ_f?Ä·›Þ¢•FuIOÈÙ/ß¿óÃDêÕXŠ6±³ÔÎú6¾*Ë;Ö‡ò3eŒÿû ¬™ñ0ßÞ8Œi 0Ê‚«‰èèv¢‚F“ ’›‡]Ã1£­þ›~ÒÛly³þ¯ìeh¼Ý~P{Ÿ™OÆ´·îï|eaÉË ÏØ×_¨]—¶5^xuÄ+,ø¿_ùaÙ€Kz>ü4‘¡¯Žvz86}ŠƒiCú×™ö—ý¿á­rZxË\›ìò»)+“Œ¼åÌží4@”>½ïVª½ùò‹OÅÕ.‚–k4EC²jׯ8êñ|b*O™<ë-ËaÍàÞqSøñ6´ó¥$­ßÖüþúý|ÒíQþ5Æô(aÕÈ=‡¸PŠºÙÎ[G»é÷}•Æ[;;T¦±Ê2j}4C† ­ÁfÅlƒ®÷“ϳÏ>ä’O’ÔØí6„†D -÷jHΓnãþ|ڽعβG)¯ÜyŽßcq×Lë6í%öÙAD_;»ŸýÔe¬|ÿu¼GÏe̹r ZP¬ÿ-™CjÇ2Hßý¶à[\µ²¥sÍ ÍyË`ܯ+ὡá~—Vžfæ/Ôv¹!Ô­!Qøèþ×ðÔj)8ø_E²cD4‰»$PëÐëÏs$ˆíÝŸUidK8öG§Ú¾²%…'ÞÚÁsß\½õ…†D :55$Í"˜pXRY“g䆵~“m¹¼0,ßyßç sV&p:#=óyrW6áßFÉüíÅÙÈú3sCjj >¾o#çÞÏ÷û]µ!ÇÞ=AصãêôÈÅǯ¾Âç%–½ò=ïÝÀ›6‹Ë~bü•’³ÙLL¯h,f3;ÿñ9QS_rIwNCbS‚¸ý©Œ›ðË{;ŸèÆÏ#ÑlGßJå’Ç*Ëx…-dÆ»j*ÕÒ©C ØM n×UÔÖhXzïÛ ìåÇ€6`&?|9 M…FÄ!+h}"hß>Öű۫D¬ù6™>Ý»ÒÕKKyÖ.ÔÚVØí6º?23·¼È¯XHn{'ó# ú@ ´êÕH’Ôä8$²=Ÿ—îYŒÜåvžº&’sÒP¥4›ÌÈly~ž*‰=* •V_c?®û´–ìã»òø¿½\׬0h]êØþÚy|ñË$Òþ¨Í€‚ IDATôj"ujŽ»CC4$ÛPë£Ü®«¨KC2lÁ'C«ÑàëYuŒj•DÞ¯ï±lYÕ+¯°aKyxZËlŠŠoµ ìé¨ ÝÐh´´[ÂPõ îZ¡ã­ Ñh´5ý3BC"‚?ƒÁ€$Iî_ËF¶eñôÜ)|“Þ/6?Jõy*­Æòâ}cØäò÷›ï¢õü·ˆk€˜T¥ "ªâHºøèÙýG L¹øc(>^ŒÞ¿³Ûý|‹êÕ‡WëALœX+Á«åÿ¦¼uè|‡àYpŠ$k¹Ná;­ÂûREA2´#Üàl” «77kž*\Œ"àjeãÆŸD#4±c'ˆF¸¦$Š•í_¼ÍKÿzœˆ1|¾áUºz6¾Ø²”² »wkøw,…‡YrÝBSžæž¬w¸mþóüøÙßøçóòÁ”ßh§W ƒD ¨1¨Ö^ü’Z«b_͸ö ;wî y ’¦jH?»Åoå0gá‹ÿ¾dX—Ø ÖçÔ±­<ðr>/o™Ú¬7tÍU~IG|ü^FΧXØ6‘÷~È`Á€²+B!”eqØóHII©ÌãÑšà:޽øôg<òÖ¾ÆS×ßÁ;ÖqψÖâ&\¹É•ª!i) 6¢E×OœëË‹Žw½Â¨ûngÖ°I<µú3f¶ñ`Ò³Ÿ²ÿ©¹õ…'Àaå¡€ÎËñÕO±h•Ì'?¾ˆ—ÝŠÙ‡á/ÅñóÂxeéT2ËÏ?æ‘6éU®1(•×™Ã\FJJ2¹åFÌf5ÿÏÞy‡WQ´}øÞÓÓHBBï½÷Þ»€  +ˆ½+ˆ×‚HW,ØQ)‚Xé½Az¯PB ýäÔÝïCNrR @HNüžûºr%™™yö™ßÎ(!™Øö#ß̯5Éײ¼–†dËçOSo?½ø ËŒfHß¾ ýìGî{~Cs2âé»9î*˗˺3û¥žli>‰æ;Æòá¡+¸ìQXcŽó曋¼ùh:áK^*ì“·Ô˜ ypw[@“r¥˜>õ9>×—äw¿ç•^µoø^EC"øóø#A(dÄ^L%²D Þÿi-ͧ~@“ŠE±˜®®Uc)ÏØ1­Ùí¤}•4w;þ=’m:U5!LŸ½7bÓ/oòÄÄL]1Ÿ&Žá}ßþ…*µÇ3øÍ7¸/¹$ ÇøîÖ}ú÷·Xð4Oõ,ï­þ{4ßüÓ‹%]¿àÖÌžŽÇlñö3-_{—S-‡ýÚfªXòÏi›“†äìŠq<÷ÃI&þÖ‘˜˜"Ú>Í1±Œÿv>ƒ¦=Çè_òükËp×C}†‘fŒ¢O¿Iìßö)ß\îÂê§cT¾`fš×ãäkô~¹3gÞ™c¾.ïYÀ‹Ï¢Á°é¼ÛÍSž%Z<ΟÓÃxä‰Gسõi>ù¥ÍúÜ¿y^Íã”)“ùþûï®ÿñÇŸ`èÐaBDC"ä=9®C¢("„Å‘°–ퟧ×Kÿ\oz¿ð¿,qÖ¿û2oÇ<ÃÆŸîÕzŒñãÇf‰sfÿ^Þß¼Ÿá¾Š=n/†¿ÄOkOR¬Ñ4:•Ìrn½{G°ªzMö•ò]ÓBS­¼þþ\J}ôœ7ìâ–‰8#¡IðõÅ”¦Ðö ·òÁŽK|ݦWvÉø_ŽqÏ;ãi}›>Ç϶œ“¶pßð_©S§?½;œ½ûŽP¯^}0K¦?ïߥÎsïðÍ— ‰ù'ëîáÁeïäçñ[é9üo>Yð1“§låµ—jëÑÑ$]¶£º¸xñ¢§ßÕY(^,ôªÍ?|ÆGÓÿ¡hõ”³þÃ÷ßÿã“~¯‡àò¾ôO>ÇSƒï¤è Lu½üòPbc/ñ×_å§OŸ>¼üòPyè„|!£í!A(˜B;ð÷·¯óÌ Ãè±ÿË¿xÔw MÜÀË cøds_Ï»zpæÍû3K:#Zfu÷ÿóûÇ ç Štxœ†¬fâîœó^÷Úe ;»t8ûôíù¥KoØþ/R²ÃK¹¾¿^-Š1têA¸j$Ÿ]Ãï¿o¥Þ«£óÕ 1…4ãÍÉÑ«c9ܶ34lÞ3fyW(rž'úcöüOÌ!=«vÐî•O©­+ÂÔ9ƒù·Ï@&ŽHßÿ¥lð¼ô’G|liÉOß½‚Ûv”{:ÝO©O2kÕhvÍý‘KNW–´õUùßWopÏêY|öõÄ=Ø“¢7Ћ+ŠÂûï&11‘Õ«Wg9Þ©S'Þ´¼  ‚hH¡P²ù@f-(ÇÌc•|ŸQÍÉϧxŸ)´ H×k8l©ž}‘2zBT §Í†ÍnÛ1>zåefíÐx~ì¯<Ù£¿X¦:rÝØã·òð«Ëè:in»4éÊîóVBûeIÇm·{¼v6[º÷$¸AÖöb³µ x—éìßÏmírÒÛð#W»ÑÜ)hšQ£F^5VZñÚK_0<º?Ͼ±œðÕØ®üMç;ßG5˜Q<ÌÓkÚSµ™‰ ‹;0sÆ39æÃår‚¡"Ó箤Hé ÊrÍøÕÚõçÓvý—K½î½fÖŒ7ž_|þI÷À4mÚ”qãÆ{>yV3¦)áö A(ÄX*tâù ¾a¾ÓŸéÑ XðCg,tz´aÞåT_OJª;,ý†ªÄ^¬7 7¾HÕ`Ïk¶Ù  èL¹êTç%Fz}çw˜Ò£ß©ÏØÝW Ë’Nv€°JÁ¸íQùÚ÷ä¤!iÑ®lN‚´+üñ×ÚµkO²M%,´ƒ‘ïÏ¡­Ë€~ϸRO°òï”ö÷pGñ¾¬ZÑsh8c:7¥ÉØ×)~üj±òìùà~¼’%Æ|D»"ž2)Z> €;»uÆ~ CÑ™X±|ɽyfZ‡$8ØÈgŸ}ÎàÁƒ9zôÕªUç³Ï>'88$‡DC"܆þ,¯÷²¡`PÝqüúáKŒ]Âì•S)ŸIäøÞš¼—霌S6:cIÆMvS×N:±’—{™Ý欚ò™ü%M:b/Ùsï­¸dGg*íåÚ´i0Í»~ÊöÕcAÑS'`÷OkÁŠo+³äÏY<°ŸýpèÐ1RˆâïM͹£•g >òáÃ|ÞákÊޤúÎ1¶¬ìÀ¢-ëI~ö†–Iÿšæ»çã¬M…LûwÅÄÄ0aé†l§ªœÉÛi×mXžÜgppß~ûo¿ý?ÆŒw cDò1H¡rjÃ,Þ1†£!­ønÑ·Ô 6æËuÝŽ+¬ûý+^ù=¥º>Å܇–Í7ÀµBÌl:”½3 ¨6Ï—?ÅM¾BÌ„ ˜ÃjúEÙ^Ùõ=Aeû{ÿlü¶}÷°áâHVï:E­šMy²× J(Sôö]|:1ý‹™³ûã)ñ¸g`(Ú“ÈĶN@‘êu¨_%Ì7ܳNÃ@` 9K¸Ã·ž‰ˆˆ¾üòky ÿ0HDCr{Y¿~Íê~ü}]•ÿ2‰‡73wÑRV®\ξs:î{i_î†Y—õ™M½4‹g_[”Õ‰·Óúª†$[O…KËVCrlùl¦/\Äʵ;p„UáÉñ¿òôu6[VñeÊýÓfl/T4æÍ[JöuÙ=ë3t†P:X|ó¼nåy*?_ÕvqËh†~!Ÿÿ@×°Û3=~}ß5HfŒÝIý—ßÄéòÜ—¦/ëuBødnEæ¼ÝË{~ÜMsãr¥ßÿÌ )qU Ü™Â<¹·Ë…Ë•õ³^—Ë}õ·ë†îõFãûäÇgCNÙKÈûgP4$ùH·n=¼¶ï²ñ¾[û™—ºß°a½´$!e5Ë[éóüG|}g{Š]c c±<÷\å,áÓ†=…ÑbɱsÒ„™Ž_¤£¿I÷Öu0\ç#ŒÊ}žÁ:á]ôOáØË–åÓùèý=XMá<üÎ ª…¥{]ìQL¿hgr÷JX,ži ©$$Ä£šÌ·­Í™Í¦¬[*¸“8P‘w›„§=¤AÏM¦}Ѻ2|bkÐ+(ŠƒÁSª#š€RµéÈô=}¿šËý¥K°Xý“ßgDOÖ¾dµõzïùi(À×ÿÎÜl Yu'xótCož7?§~@4$B^"’Ü}Et…à ‘­Çýƒ­ßç¯Ö¹‹«·T¦}û¬IÝ¿–c 5çx^d³ûy´xÅ,áe»ãÛî7ÐÑ„õ`d£‘¼¹ø ÓînÀg?þæ¶¢é³l uê× l=žö–Â/Õñc–wÌ?ƒÛÛ¾uÁ|úÛl¶¾Ø'Öž%¨t?4MÃR¢!2ïÊmÀhÔyÃci~øýï¦a)UÒû¹;ûñ@™tCì‡-«Ñrx¶z ~œ†ÙLù¬ûÙ¸ùÐ ?·òüÊXB~!Ix2ï,꯺$ÿ=Š–-ÍãÅ[ âéVys­{?ŸÈwÝ_á\9”6éQôYįnÛI†~t™VÝU ÏeÆ)MÓhöÉbvÚ­hFKŽm?´ÚǬ˜›ý`?âï5èÍfï±;f/¥³9S†øhé:ôæ¬é¯Ý´s@@;ŸÖaó¦>fÂm5HÒænE ÉmÂfKÍ`|@æ9ë[í0nc—MÚª*sÇ Ø’iþaéÑËŒ¹»y¶Q6Ì}“n“§ÑÀ¤æ{Û²_]Å÷ÌðŒê àvq3ê ÁèÑŒx{Z#ºLie‰s£Ñˆêr‘Ó—¿F£±4$ø%Òy36ÚPE4$ù‰Ùl!»õ<½êçož¼ét2w,Ü8º¼Ê£À£ÇOåç¥Ê›Ñhô1Bròdfì1~t7¿“rZ9( hš"ý€gˆ†ÄO(_¾Œ_çïĉSRIÂÿ²3Fþ ìÚµ;OÒñ#ÒN„Û‹$HTÔY¿ôT®\Q*Gøa„\ËøÝ„·$2‰ðá6$yµ‰æNdý¿giß´¶”j&rÚ3Ãápгgw¿Êëß{Ö®ðì}!{Xÿ]œNG!Õv„Aâ[>ÒyÁm[‡ääܧþq$ g§ÏëôE(W¶èM´'ñ‰.ÂB²=l½¸Š=jKZ– Ìö\'FŒ™äü)gÖóo@3ÚFæÿÜgv{f˜L&¿k i{^¤ï}!ëÿM¶lÙ,…p“H? äe;ÊS ‰ÛÅ+£·R§nCFŒxÕy™vEñý?{épu2rþÈ?¬^±ˆY3~å4±gãÿ²^ËqŽ—û½Å …k|Â÷Ìÿ„ ?.æàÁ£$¹ ”®ÖŒûŸxçîià1Ž,)¼Öÿæ¯øœb´AøLÚb…‚ øy22ÏþŽ{§2{æ¯Ì¼ús_97 Ÿš–kc$áäHº<0Œ•‡m4.c¼­£sîî©´KO÷—×úÒÿµ©Ý÷y~^¸¥s¾ã‘.%™òZ_žùv¯Ç+ÖƒÉ2äÃRë‚ ‚àgܲ†dÛ×Oóî*c?t²t©gKlkÌ Þ\¦çƒ½aÆÀš´nV2ÇtÌ%‡³}Ãô ìz+œueɇ+õ /Î=Ëçªy[ó:#ßÅ‹³7ñL½´é¡f¢7MÁù­"Ó·ÉþyôJŠÖùC›eݺ¼Óësé”amH‹¥+ÃS™²?‘¯Û”àÊî/ÿË1îyg|¶Û}ç¢!A„L£~^iHTW›ö†1sáîï>†?œä=6jã*½5ŽÁ%<¢ÓøcOÓå™[Ïüþ/R²CºhVs'33ÆJí!ís8#ëæT½ZcèÔƒpÕ I>»†ßßJ½WGß6ƒDA„kãÕ(Šrc'‹ñÁÏ“¨’ƒø¾ V›¤µã¶ŸÁ¥jm‘ë4Š6-Š5ú ÷ÿò½~åøñS^ãIA„ü!£íqˇÝÛvŠÖ­[xÃ’bSÑ÷éÈW:Ï…TWZH‡\§kwk eÕ·¹0ÓyÃU-½¢¿;[­\¥­/nÁ•z4_µ¢!A_ò|ÄÞR+æç'ùÜTÞþ²t®ÓÍICRƤg_BÆü•¤ODkÿ؈eHlÓrjø®I’àDo.—¯ZÑ‚ ‚/‹…„„t I-È¡”ãOñª¯óõM5ù¬î›_ù°Vˆ™ÄC‰>a/¼Ù†+ûÇ3uù,ñÌJ“¹äJß73á@æ°šÒAÁȃDÓœ×ã´îã—¯>õx?n’zƒ+rnÉvŸ° ÷|Íw×cò£ñÅ 6ï:ÌÁm+ùfÒÿèÿî_4ºçEŸ…Ð6­:OÕÇÒ—·¿¸i$ögi¼LE‚ BAqË7¥Ð;¢x~ÔxjÃl2¢»*RÑT7n—‹ÔÔNïøŠâ´Ù¸žù¢„•¡B¹Ð,ùˆìü()£ß'*é~ŠÓŒAãæP¯Å'L™õ#Ï~ö.)n#eª4`Øäy êZÛ›ŽÛ~†ï/Øù MDúÜUrŸ´ßiOØ-hØA¸ÍÉ­jH ‚ÐæÏ0°ÿÐ ÷XÝ[šV$£÷!$¤H–uIü‰t >F‰hHüƒ6mÚ¢ÓéP%Çߊ¢°dÉbŽ9Hùò•®™Þ‰¥›ÑÐñÙ¤ôÉR½¹O=Ù‚r&Ï nw¸AS}Ú€ÝvñqÊ®æx¼DýVŒ©[’€–FoÚû_NLƒVÔÔ9±Ù<×]>{%?ïJ⎻sÿ}‘XR“Øuð4³~YÄÑ+ÝÚ1LÅy¶Æ¿Œú#šñ½#¥ñ‚Ÿ£†DQ”›Ó×Åh4úD}=þë…HË—¢€¦)Ò6üÎcx¤ÿÖ¡(:c$#ת7Õ™Èçkyä™.T1yÄâšê`Ôg«1š;`1{Òršô è|Ór³¤Ÿ|ÙNp„™£ ײ |^© @ÔÚƒ\iP†a&Nx5‡6hæ¾²žaÏ*·ý ŸmKáÍ ¥°Xv!IªFhy7»~?ì=¶`Ù¿üëôxEôF£>ÛŸGS)Õ.Ô'Ý+Gwâ.R“š–ô.kþœ(Š”m’ÁI§~ïîL}¥wQDc`iº¹øåDª4Að×~MŠ ŒkÙ Hýá'Ý{ƒèHüÐC’Ñ Ò¹s':u꘩Í]Ÿ«Öñó‰`Fô+ã~n}4ÅVËMëöɇ9¸ML6¾=œJd­fhqØeu£i.¶$»ézmÙšêLfM¢“®å}Œ“Ëâ(Z»|úUU'Ë\oZ:×eÖºZÇ—ÄIã?¥PjH N§#ƒ^ã$óo?3¥²äWÚ†±råJºtéâ¶zõš«mJÍòlgÄsˆ÷ÅñÊë] uÛ±¹¯ªï6%3ðÍ_½H6kr<:cŸ°{ÚᇗpT*Á»OÝAY“¸sp™#‰T\« X¾sd-êÓu"Gâ\µH¿·#·Áe•\·IK9#¶—°ÙDG"þ@Þ¯C"\—-[6ÿgîEÚ†¿xHô^ IÖc:TUų9bÎõf)ßÞ®Kù0_¯Å©•kH¬ÙšVEƒ|Ó-Z‘{ºº|Ò²9R0š#|ªõìÅxÅã|­VǾïïS”hÞöšíÇm¿Ìä•Wh?´K–x1.ÀAÞpÕŽNkŒ‚¥FîÚd‘’&T§UÚ° øÑx’˜˜Çë9Ó­[)á6$c¤S§NYŽuèОU«VûxHr"³1’zù .IæÙ÷Ëe‰k ªÈÀî¾a§–Å\¶™o â;ìLᛃ©¼0.gÏ„ê¶1ýËU¨ekñhŬC„ÝîßLû`ÿn> ™ô&i¸4|Ö$q$ºQ AÒxÁ_û5)A(Œ‰‚’aà_»vk×®óþ¯i*ªzcӀޤ ¼7qíëI½€ëw ÎÔ¾9d¥å=ůah¤òç«)Þ¡= rHSu[ù~Ê|Vņòö‹M²í”*H‰vø„õï[ŠÄ³;˜w(%Kü“7ðè{K‰Ï°™gÊY¦ 0i<‚ৈ†D !iÚž5kÖfÐ!©¬\¹Uõh~<Ó6äê™>{à(_ÏÙCÉîéSIÝøªÓÊÏŸ­ÂU©6õlã§^¾È7Ó7U¬ö(–5ަ²gÛAf/9D|XÞÞœRš=[I¹VA\Z[·tGXý–Ü×(™Ù_üÉùî i]-’`—•=G¢™·ê5»tÀâ´nÏ;» IDAT“&EÙ¹7…ÒwKÿ&~‚hHá?€^ïYwijNŒ’A3’Q$­ey¶³có¬%|²ÓÁ Gï¢Wí"×½vü‰#Œýf;qÅ*0þÙF²êX®ÞÎËßž¡Û]mÞ¾,ÙDáìºåL^dåŽ;Úòpç ÞOt³£l‹zØæoÅj¬KÑ «­öô.ê×ÙÅŒu'˜²b'6UO±R‘<üD/zÕÈ`@%±8ÁÍÐFE½ë˜‚P°ˆ†Dþ,^¼8ÏÒjÐ¥6ô-Kù€Ü Ô‘TìØšqÝ+åhD„WkÄøÑM({4Ë´ëÌ·mõçⲦÀò<^q_ü›ÌÛMC|ŽUoÞQÍ‚æÆS6y:¿}–­h(ƈ ø+^ƒD‘°¡PðÎ;ïqäÈÁŸýJqäW¡§-÷í–¶Ì·ÿøš#‚ ÂmG4$ù€Ýn'³^¤Jÿ^¤éÈ‘£¤-EžÑ ‘¶!‚ ä¢!)Ìf3¾Ó5ž>*ê,ªªú‡¤råŠ Æ«ÿùæYÚ† ‚X,’“¼’<ÛØAÓìD»$%|ƒ¨ª‹:uj*uëÖöƒß‚ ‚ÿä™A’px)ËVìÆn³’OBB<‰I7éÞ×Ü\ËaàL9Źdg窨ٜëL<ëËï* nݺìÛ·Ïo~ ‚ BA'ÕÈò ÑD”(Ëš5+Iµ9Ñ´T.^L¤ÇàG)™K³'%ú ›vìå|\šb"¬XyšµmMéc†k¥°rÞêô‚Þí Å©{b'Û÷ŸâJ\! €¥Ÿ¡d¿4×Ù±«©±sùò· ŠG8|,åî–S×KÕÐÔ¶-YŽ1¨}"H=içÜ?±Uì†âŠ#ÞšŠ¦:8`uQ¢]mܶKœOÈš¶íÜ)â2ü_®„… +/v§™3).’.Ÿàðá TìÑ}ÊRnÃ\ŽhHA!ÓøœwëXèÖ·'áaqhš 7W®Ä{` \¤ÄÅ“èÖ°'8ÑT7ŠbÌUÚ®KÇX¶dñ•»rx ‹ö$Ó¿_/,W¯™tÑŠ> šjÏ7=„hHAÁ›Í†¢(Y5$qqq7µ‰[1¡)( &“é†Ë)þÙ¸;Úµ%>.‘Ì,kÖ¤HµN˜/gýáxÖ-1…”¡\ñÊÔcû¾SÚTÃâð|c©Û›Ö—ÿ`ùOßS¿u;*”(ÙÄÙ³§Ø¶ó8eZ=LÚ•8sæn bÎZ)Ú±,šªzæ¯Î®cÙöK4¸³•Í·Çk"AAðÅb±`µ&呆P aèÜ ÌX°œ@—½AGÚ‹‚ŠÛ­ár9‰?sX#ÂÂB¹—˜ÕR *‚þÒ.–,vãÎd­„VéErA¸ª6±q VKÀ‘–êw¸—*Õ÷³qÇ–n]ƒCÕQ¤h):õ{’;ZTÃw·ª;ÝÉnú6,Š3Á³ïަ:°Ù)Q‚ ¤Ûó•g0Ïh¤‡û·†$«%‚ ·ƒ[6Htú`îïÝ+7‰ VRS\¨W/EQÐ MfÊ×íD‡†ÍQIÙ¦Ówàƒ”.[½’ýu\ÖX¬ö*´-¹žß¸éŽÏj«A¥êp÷m1¡3Y0ëÀé°såâyR<ÆKÂáUËu¥Q°‘˜Ë½Ipù® ªI©qI·«˜}ö´Á]Ó4?Ô(×̳ ‚ Ü”cÇŽià™² áĉ£T®\í†2¡ˆÅ„^¯CQ%ƒw@ÓPU—Ë…51Û-x!\¶3,øëCïAB²;§ÛBA#ãU4W æ® Íã/Ð22…£Q‰ùRÀëׯ¡uëvdÖT«V…#GŽù„û 5jTçðá#Y4/ÿü³ví:ÊS#‚ Üi¶†ÕšDxx¸ÇCr«’tKÁAr²ãúñŒf,·²r»¥wwMâ„!’ùÓÆæú´G´¥j4/@ì™ø|ÕB˜LÆ,ž†;vømCÙ±c¡¡aÙzGDC"‚ ä9jHE)47T¦1¡ŠÂ/¿D¢#÷[÷63!åâERÕüõFd7U‘!Ìÿ¦D²N×È” ‚·d´= …õ&\©ñÜ褋۞H|îiÓ3™zÕhdη ‚ Ü.nz/!÷8N¯Á¡ªªw°Oè¿fôêHÛAòŠ÷²‰¿5 ‰³Õg0î ÑgëñOƒ$Í£“"mCAÈ , ©©É…[CRØð5>ÈÖñ_ƒ$cžA!ïøOhH 6¬“BA„k ’ÛÌmÝi‚ B^Ž'Y4$ ¢!A!_°X,Øl)^ ‰ì5/‚ B#‰ ‚ ŽhHAAÈwrÔ$&&zµ#'OÊÓ‹ÞØ£×øüX»Áø·WA„Û…ÅbÁn·f]‡$ÚµëI) ‚ ‚¯ˆ†DA„'[ ‰ ‚ B~pM ‰ ‚ Âí&£†D¦lAA(pÄ A¡ÀñjHE ‰ ‚ ù†¢(Y5$III¢!A!ßp8REC"‚ ‚ÿ ‰ ‚ ެC"‚ B!AA ”Œï^6Š’ýÆsË—/‘+¤tëÖC AAð[2Ú†Ø4MCÓ4@»ú7>ÿ GZݤÕdž ë¥PA„BC®4$6›Íkpøþö%bøQ’ñ·h‚A'‹†$999G ‰ÙlÎÆ;âkŒˆARðÆHfo•h‚AÆé´å^C’Ý`—Ýt$od÷· ‚ ø+7¬!ñœ™Ç9EUƒÄÌ©A¡P’+ ‰Ýn';½Hf!å­ :/ñˬE<<ø¿^­-åü’B*S2Øàg9S²$¢!Aü,’”””kjH|§k4Žýô2¯þ~Òk¤4õo×)J±/yçÓÞs‹Tz–1Ãj_7CN[ “'Oæ¡!O`(@‹Dudz{Ï)5j˜åØÉ_ßb}H\»¾¡õ°IÔ ¸u£$5f-{Õæ4/õ æÄ‰c¦Ù´”³›ØИV™ëË×[%AÁŸIN¶gÕÜ(Œæ‡Þ.TUEÓ4 !¡Øãþe×ù¦Œ{¹6q>áãµ±YÎM<¶–Õûã|Â\ö(ÎÿC¦8¼nÚW É’Îùݛذ{‡ŽE +OÍšu¸óÎNê”›.gâvò{vïÌrìâúîšÒgäb–'9nÙ Qçyí¡÷¹î"Ÿð}‹¾äã_–qèðq’]JUmLÿG†òäÝuÐ[¬¼õÐæ,œD¤AVÿA ?75¢Úâs÷}“<ïäW=$oÍžO™3VBk5£mÛF\P¦ÃZÏ9Qqʇ›¸°n*ãf–äÞn¥}Ò}øáA;|È',zÉo\~¼®A¢¹“˜ýÁ«|½K¡ÿ-øíïÍ|ü^Ö,žÌ'?Î磩ãiQ"àê Íƒ†]ó~îûâ'7A¥È€®L›4%¤ÚÞráoŸøçïœDÛ0³7löÛ0þï(zý-^Û˜€¤¬_÷7“Þ¾Ÿ}—å“Gë`‰ìÊ„öŸòô”]Ì{µ±´bA¡ð$7£!ѶgÖ¬æY4$ üzš’†ãr9q¹U4ÍÃz†»º<ÄŽm+p»5‚ËõcøðÖ×Íà†Ý‹ùFuár9¯Z#N¦ éÅöêO²ðçû ~?ÿØ•½îóü|ó/?ü«Á¨€FƒÊ1ýoG½ÍÅT.—Þã©q»<¿¯^Ïm»Èòßç0{ö\\ åË%óhlJÏÏMâJ=Ìð?¢™²ºº7­ókßbì_{xîçÕñ;>8̯Ëa0è Œ(JÂÑI¼>Ü„%¼+ƒÑ3ÄÖíIßÀrìzc<c&#ëed÷{¹£V„÷ܳ‹‡3÷B3Öýü0fBBÊv‚Ëßá=Þ噯ùsVÞý÷>l^£W¯»r¼ÆcG¢Ó½ç»õ§QÒ©™5ksþZKDîÜûÂ$¾èÞ’"ú¼™"‰Ùù®ˆ‡hšîiùeüÂk½Ê³ ‹g‰ßæåŸXB†Ï£ŠvàÞ0+ŸîMàÓ–%Ò|G¢!A y¢!©6äK=ìöjHt;¾;ňïfPÍâñ6­5šéSw瀡õšzÏ-Þê1^lÎÞŸñ“S@u]¡K·{˜·|5E¯ê"ôÆPÂC›P%Ãug~´…î“c¾ª¹´á%º¤Oý(: ƒE0vñyh^â¦îMSíô|f"½ûÞÃÔùc©S:8‡x6Ö­ßzCi×jÝŽâF¿;Lñ¶ÏfH+™9—¬Ô|¨MgfÕÅôhÉëß‚–%¤U ‚ …š›6HŽüðOÏðxH4 šMžËƒ1Éüùáóü™ÙÃÚ˜¾È:=£˜.ñíÏ;ñ¨Wg@ŠFDiÌÉ áfN¬•¯*ñ†¬žu’z_úÈEª†´5ᦠEљظ|úëhc5W<#G¾sCi¿ýç2º†Y8x1•ðþaéwfÆ¥j„7.šë´ÂÅúÃa ƒ´dA¡p$7»Iå!_³ì_ IJÈKÜ1þYþ®þ#{–`ß·¯0ÝÔ0[ÍEüÉiüõW1^{Ɖzõø¨7^ÅœÁ )ÿo=WÃc¸ph:ê™=ÕËô+%YRÊâ“þ¹-±m–+‡¨n§7®GC¢ ¹¸®w².‚+VÞp¡»\NNÚ\XJ½×Uuè…„WpÕ ÍU:¦’fÜöWÓ ‰ ‚Pø¸åuHfôíÈWÉz,Š‚êJ&¨ñæMhƒÄÏÝÞ!ù±yÔµ­ãÙÍz>YÙÑ«Ñðñ²ü¸›b-Ça0Q5ÏñŽÝº’Á5a +™~®!’²&8áT¨hàôߣïöÁ&“7¾êˆæ‹c 4{»\¶×Ìâ l5$¹9÷V(iÒs Nõ¹·»ŠZXÿçF TÏö§†Ïš$î8'zS™ y ‰ ‚Px¸a IvûØ8R’¹wÚ*^*Äù óȯnŒÁùilGîíÿ"u]»0e!‚³îª;Ž1«¢¹¤Ÿ¯Î¦áUmg‡®Ý®1eOÕ‹`üì|{OïLÜÉ“ó§¤çÓÈ/ï>É…’ðfmÏÔ‡3y'?ÌØ–czÑÍ|¼FÐ\$«Á·°žÉõ¨bbë‘Dè™áÞ†·bþ[“øfsžjUÊ'þ¡¹o0ä»ó,üûGïÚ# ‡1…UÏbŒÈòñ‚ Ba#—ßÁNÓ4ÏÊ#™výM[$YWšˆÄ_ø—HZÅC£xIæž/Ÿ!±Ü#Ì}ÊÁýžæµ÷‡z¯u­eè{|8ŠUO£ýg)4{áGîŽ4z?6mdáŒï9T¤ßþ<Ô›†êŒaÿþý9¦—âÖ|®i nLq#<öæ8º×.ÅdÄaM">.Ž+qqÄÇÅñꔯ¨`ÖßRÁ×} <çÚ /§¯b[þ®) Ûø“ŸéEô opg‹F„9ϱqã¾øþo?ù ‘Å›×­k.PùùÙÖ ‚ *ƒ$7›-«†Ä­il˜ú!IAF¬çO.âOmá“ ãX|"ŒW>ùƒŽEŽ3iÒ›tû©÷ÞuîíF˜AÇåÓyæ‡ ûý+Ê” â;Ç÷Œ~ç Þ}c¥"B1›LèPÝ.ì;“âFúЖLš¹”c1Nª– ÂétrfÕ'ü²9˜îŽáƒÞí Ð)8m†.¸3“&uα¾|ëuÊ4o|°0ãÛ‰Ì]µ“‡ö“êpa0Dh±2”©XÕ…óê×A7Kñ΃°NœÀ9ëŠeð=<úê·ø‚ÏçÌdèWc°ºL”®R?œÁƒjyó©:Î2=ÆÁ¸Ö‘8Î,û ]«>AÁ_H³C”èèh 66–àà¬bÊå˗бcç,oß?voΞ§Þ£w¸Ð0…UäËç Ä€Wxë…{ Í Ù¿rŸýp€É?!@§°|T66œÈ{}Ò?èÕÔdvnÜÄÑSg¹տĭª è0”gØKüç*aîã]XÝïG¾¸³\öT;vLÞOœ3rò·Çyvu_–Lõ¬±’¹~¶mÛJ·n=¤¥ ‚ ~Krr‘‘‘¹7H:tèä3Øiš†3ÕŠj²` ]_âJrbÉTd{Üúßû-ß.FISîËÃm?ÍC݇òê‚_ibÊÆ ÑØ¾}»$‚ B¡1Hr-jM¶zþ×›-è2‰]õÁ†\êÒuÿŸ1…µá»1{Y}&‰ ýÚçú¼Õ3_¥ëGßÐ$Øèc$f¬#AA(LäJCâÑ(\‰ªªwLüRÞ$-ž¤?ÐÿŸ7tÞÀívg13þ ‰ ‚àïÜÐ:$ƒtOˆ>ÓÛ¸|Ùá¤y¯ÒCdAÁŸ¹ÅuHÈÖƒÄ ’Œõ#‚ …‡\$6¬“’Aá¶¡;vLÏ”Á`–A!_p¹ì¹Ô‚ ‚ ä55$²ˆ ‚ Ž$‚ ‚ 8¹Z‡DAáveNGbbâm¿pNŸ¤ÞH¸¿¤q#Çó+››u(‚ 7B¹rå0›=Ôx÷²AA((DC"‚ Bã£!AA(ƒ$MC"‚ ‚PPÈ” ‚ b‚ ‚ ˆ†DA„‚7HDC"‚ BA#S6‚ ‚ 8)‚‚cÁ‚R…„»îºKêPêP:nS‚hH œ®]»žåØÓ–dÏéo!È\þ7näZωԡԡà?u¨ªª÷ÜŒKLªªêý{Û¶m׬CÑ0Y˜ì&!ÿ;ÂŒe­çDêPêPð:TU5˦i¸ÝnŸÁQÈ¿:T%×u(S6~öÐegÑKGXð¡Ô¡Ô¡Ô¡×avÆHF£$í·ÿu˜Û²ƒÄºœ:Ayˆò¿N²û[êPêPðß:Ì1"u˜¿¨ªŠ¢((Š’+ï”hH ˜´òÏÜé‰Eï†bæz’:”:ü³m6[ŽeÚ”Ôcþ’yºæzu(’&mÞóFç®Uw2qñvŠ„ŨSüòÞÜöhŸ4R»fñBÛÞÈܵ褅‚«C‹Å‚ÛíöñФý60І¤à Ñü‡9´|![b¬„VîÈ€¶•ÉËÇÌšœJ@p¹1s¢w­Å^©•CMY޹ì§ùgW(mZ”'.Á–íùɧq2Ñ™«|Õ©W/ËÂ9®”(.i¥)œ»¦ìLŒ&ÆX‚2…§éùz8ï­=ïf.Ò–i_=ÇÐ!ƒˆq¸}Ž•éú>>VÕûÿÜ_~¦Qÿ©jÑgèé]œ±+”Ë– öäxÜA5fïY¸¸†=j Z”ʦ“Ñœ81bÌÔRÎldw`ZGXþSÏä¶Ñ/³úþQ¼Q-¬Àò`‹YÃß[#éwWÝÛ’¾Ôwn-)'ªb̳…¾RcÖ³OmJ³’7t­”³›ÙИ–æBQl²0Z!$ùìV¶^ á±a/RæÒ&6žŒÏÅY*ŽÔâb/}æ4GbÏ®lݼ‘uöûÄü{î,λs2G4Üîtó'$Ôº¿qÑæ&ùÌZæÎËÜ9³˜1s6ó—œBqíãÇfÆÌYžcsç¢fxÑL:º›ý±n½?;¶oC±xÿ0²uëVÂËfò¥°rÁ&Ô€` º oU.þšñ ‹öÇemðF'klD)D-?éÔ~R[ cêÔ©L:•Ç `×Þ“ìûw'>ûÜ{ìÅ:‰ˆJö9ÿӉؕìðñ\>ó E’;ƒ+õÒ¯ ìß»{÷掮iÞ¸>M›·¢ûó5xÝŽó »ŽßÂÜ»p*ƒÞMó ©_·û<Æ×îõ×Xyã¾7ˆuý·ÞVΣl^'iþûcþÜyñ†ÏK<=ƒñ¯Ìuüe/àÜUƒvRïμy*1ǸRß×gÇŸŸóè÷жy šµìÀ€AOðãòCYâíûð)î{|ŽoæŒeôÜÿÌd2ô±ªão ›¥Üss-½ÅÊÛƒß.4e/’æFç®íWŽð×òƒ´ðÕÃÃÑîìÍÚù X“Ò‰Ö5Jøx5ÜŽs¬\¹‹k )ÖTtÆBBB „³gb/CÍ*å(V´4Å‹!úÜeTç%  UÍj\<|€›V³ýR2v§ ‡Ý‰Ãá$ t7t+¦i”mLïVÛY¹þ,CîhË€j¥)~…ñgóüÿ†¨è¹´ösfÆuç•{«z™cG¢.U#¨zºµ°pÙê`ÓÚ5tèÞíJ n 4ÕΚ5ˆ,VŒË1I+‘ó[‘\©3ͪ•æò±#8¯®Ö‹¹ìÒ£ß}€2­Úqê²=C‹/C‡2;YpÀI¯ªàÊÁ ïOú—ªqúq<·ÉrÕ‹­6N§ xõ…çIós¤ž‹FëàÂétú‘N'N§Ç+tnõ§<±¨>u‹â«/2´A„ÇX lɧŠQ4<œˆˆ‚õÇy¼ï0:¿7·Ó‰;S¾¶Žyœs=?¤eÎ{½Ùo?Äø¿£xèõÿ1|L#’N²~ÝßL1Ý1³ùäÑÚèC;2¡Ýûp;ó^m|û^Ró¹‹u+Í…‰{9wžÇsäÈaâ"îæ¥{+dy9ˆ½`#²d`ŽiíÝ»Ÿ¯uaåccøð¥^ès9+ëti€š©þsæí×ß`ÌšN 3“œO’Ížã¹Qß…GC¢2mø¾Üdcð#Ù¦Á®Ëì\õ+ãF<ÈŠõo1}dßôûˆ=OôùÜnÏS¥©)Lyú>ÇÔaگόæ=¶íƒg9ßc<-ƒ WÃr-cxGƶ™Ê³Sþeö°†ù>¾‰†¤q#s× Q{Xºz7uº?Â]Ëpéô sî¹›u 2ÿ\5:´kB±ÏðdÉ/þ IDAT0” zÝæT­Q™’%JR$Є;õ ¿|öÍz?Á€öÕqÛ­$¦¤âtÚ08¬'1ÖŬ¸°é „W­N‹F¥)_,‚"AfL& æ€ÛYNœµY­56-IéP'ó~_Èv BIäÇù‹)aO&êÀyêbñ‚ÝØªQ¯R0£g À SPí‰\މ#:Áqµ‚„¸8’££qi ©éo÷F£ P]—Y{4…»_iŠ)é›çöÆQ¼,­ïhƃŸcð€û™³è/J™rîø-áwBüGØÕw1ë@u&sòèaNž k—ÚÞxuû¾ÆÒj58P²‰oõ¨©Œû;%'>uõY˜Ã{Vs:*Ѝӧ±Ú¶ðä+[¨P±"+T BíæXŽnbUù}ŒAÁúëÏ_J}_›ï?ÞJxÍ72é”ê4’GJ.ã÷Ññ΂'²xVæŽ|Tà»ß'û#—¶Š+â~oúZ¦"­éjå“]±LiQ¿§ld¸÷oTwüº€°šÍxâåœÚ³§5‡;•­[wѶm[oܲM:йþ9V¯=L™bE±ÆÅãÔÜ$$&y«ËÛØŸT†WºÕG‰;KLBVï€#Þ¹dn[º¡â²&ãÊvܺÂá£1ž7³€rT©@éÔ(êNÀa3±{÷%ìv7Õ*èÐR 2ø$E›äù‘د$ãÞÉÃO?KÓŽhª‘ïó¹vì®+WìŽâŽ#5ƒ(%nÏ6ŒEšÓ ÔÈ‘IüóÔOÂ…Ÿó+•²°nåEŠõ6muù};¨:h ¿=Y#Sã°Q®A+¾~ë5oÐþûòzâ­¹žçºïŽUâ•ÖÇ1ìEL%«Ó¸Åôé˜~ýý_¢D»ç2´…dfÇX©5¨mNïJYBz6äÕ¯A! {ÿ}Ÿÿ;…ùë²gJù”iš\/þÂ):Li½•ç_~†¸“G9sY¥BÅ ì½ÂÊ×SÒ˜n̄׹›6™®½ü öëÛðc§Ò;¨Uµ§ë= Žÿœ—>iÎÚå/{ã§DÿI§/j°`æ]™žß$TM#Üpýù ©ïkÙï‰Ì¿l£æC9OGujQŒŸÍ| ’å“cÂ’$¦¯œAíଞ©ƒß¦xë§nùZÝ›F0âÛ#àï‰hH –ëÏ]›¹«ßÃÔhT{ÜE´²-†jfã¦]ôéÓ‡‹ÓÄo)IFê·kÙb"Îé$ƒf‘˜m'«¦d^JÎÖûçÀXÅŒ+ÕzÝyh·#™ØØ8 ÚYN$FR¿F Ѭ;íÊÆêÞÍ·óBп&)V)Ç~cû%MM×8¸TÏ=Ûc£8~Uë¡jžŸ¨'phš–>e“¦›¸”ì" uΤøô|jn6Œ§Ì]íPí—p5$Bw?éàòñ„‹™±<‹¹h œ ©9ºŠ3×ÓÍÕá­kH4ÕErÌöŸLÊ0ÎY™9c6ݺ¶÷x³ŠÕ@sk>å›Ö.2jH®eŒü1æaFÎ=JÃÖ¹¢£ï£í±ŸßÏ÷ïÞÏïý¾â»ç<á¾ ©„õ I¯ÇÔS¸T°!¹Ö/iNÊp:ÛÜž¢êðŽRL[¸’Á—9xð ‡äèñDVo^5êz>¶ŽšµjR±xÑ5îdâ«-©T:œeoõæÓòã‰@ÅéÌyZÁ¿!¯¯¤ËG‹ÁåÄ èZóèCWŸñȨ!q&ïçécxþ»%Í”¶#y/:cÅO¸ ¨.g†swóæ×ç™4¼GÕwaиR£=†]ƒP¯î#˽×EýëIN:UëÅéŒ\QŸRÊ%~\xŒ‰kd9ïÀÅTBï ñ¦{3×mŽuú!ÜîÖù:¾‰†¤‘«¹k£Æéc°^}“·žOÅí¼@RRçϧª7[0©vbÎÅ 3ø~ –ä"°Fqqñ^ G–äT1µpêÐYŒ%Bq¤$¢†`V²¾ñåi×¾&Áêb¾]JÉâA€‚ÞÌöß?'^¯`pùyÚ&[÷¦~’ǘPté=ÿï|f×H½ÚYº€y?MÃeµzŒ¦ ÓCi’$·K„ÕžêMË»X§J#ݶ®%Îî¦L¨‘C‹×Rö‰fœIL7lBMh®Xô¦Æ¶;BÑ(:öèe̘qÔkdlY¹UUùeÆ  dÛWè£W|Ê7ím5£†$£¡’þ&«2oÔCŒú+Ž·§-㡌oRõëÓ¸¶J‹;‡ã~q=B”ÝE`ùôzÔ•E¯($µbljÌÝU>·=*[ÍB^$·«Ýö³Ì™½˜¨¨Óœ>uš'Žu1ý©oYÓ­ÕªÖãÁÎ÷P­Zu,&#–ªo±uÝ[œüíA^õ2§kÿ£ÑX`õ]4$ºÀrè…¸Ý ègïˆß‡ÎJˆÑóR SÀPéó>!t÷—ôxþ1f7XÂCµ}?²» ,ìÕÜ̵‚Ëà¶GyÓ)ƒD4$ÿ!RÎobẌŸz¬ã©S§ú¼¡”îÚ—&ψ·Ó5(XO$ãsçüp™õ¤žÛÌœ6}¨8«~™G¥û§ªQÍ6MMµré²Õåû–”’À}#F®(œ_ô +‹–$ìJÖó­INжê@Jد^`Ú7_ÓþÿÚ;óø¨Š»ûu§ÓIš$$!7I‡ 7 7F1€\"HáZp@G' £àʲ(‚¢€ê¸0¸˜uÆqQ\X`ˆ€ $Ò 9º“¾^ï;p5™­ïçÓŸ|ÒïÕ«×õ{u¼ª_U ÖR>dcaÓæ«…óR))4Úu•ÌåÃé¨õ-É8{‹ÙŸ ÌéÇùI3”òª¼ÕØQ(õ P7™g y÷¼×Ý©}êÒ§Éœ´‚K©‹yûÝ÷ðP–Ù4üz7ZÎü=±ìx}²5þáÏÆ¿~€`™Ÿ~…=¬½Â™.4»õ 2-2áZÁ7­òSª|í¯åÐ΃0¥ƒËø¬ª­Qa¾iF¥ iº™R¡äûS—ˆ`dßaDDDâoy—'ž e훿©7h@lr7Ÿb8»í .ù˜žÞu?‹EéX4÷·œÖ ã›ÕÏÐÐ¥{/þŒ­²kÈ™w¿$dè.Ú4‡]ŽQ|·t€Ð»ÞÇÀ›'›{²ï HŽtyξ㼂gTûN£#B'AÜÞ{æ( gÍ¡ëÞíÄøT®éÔB£ÂpÓ|×q™ ”ꇨL¬CÒDÐfêôHII!%%…—N¨ø¿ü“Ô+Š@×íÌ ˜ òŽÿ™\MݲK:¿~{î } 𢕧D–Õ¯;X v÷¶­lÙü_^“ðA…Âd£æØò ³LXç¶4÷Ô R©Ê\çŠF’œßIµï×_­¢ôz вÙ%²5—c†Rb“™‘8…Ĥ$’’’Hš>“î>ú›ß*×1JQyƒÃÖ¤žkÑeÖ¿<žóFð_U¦Ö[ù©•kMT4g-ÙünþuÁ(Õ¬NÝÈ€`ÿ2t(»^bÇŠ™$,p®•`ÌÞ…¤ ¯péwôÖPt¾¨Ú5Ÿ¥yçV±ñ‡ëµî!í³—‰ŸVm=„‚´<ü:6Ù<©Ò„òÁ;+yqÞ,Æ L§v!ø…$P’÷9·ëÓLÄôëNú-KeÝäp—çÙ-yH}‹á£çaè4…;—Óì6s€XªñJW×ÍfÙ·Y<ÿRL‰R¶/Ê‚?šùdÛï*L°BïúI~)–ü´·ØpÚPëXö¾×ØžkdÄkuç׋>fb«\$ý[µµ"½Õ],ºë¸ ÏâáùЧ£ð¸™’’—ãÖ5ÿ°Z38_fX”-¹×8þ|ƒâÒ¶H'ÿÏÙ²ùÏt‰Š ¤…Í|ôx¨+K,¥¯z:µÄp)Ý8²c-»Ú´D«‘pج˜LÅÄŨŸ,)°b3^¤Äî‡sÀAûènÄŸˆ‡¹‡>[»šŠ,tç‹C6:½ r)fã½4³‹(.«4eSqq¿(nMGÙ§%V«•ü3G@Ý‚ñ­}È»”ÆÒÊ ¸mW_þ~|šQÏ`Ív.–qÕˆïPd{m¯Œ«ÍÔnç?h¨†wB¹‡äÈÇoðêûŸÓcúbv>7º¢WÊjµ¢,“ÐæÂC24@ËÞŽñ\ŠÓkR’s‚%Ï-Ä8n-³ÑW;×Rxœ£¦pŽ.zµâYÞŸ8ˆ¥_èÈY½Ž ·!Û¬È@§)­ÉÞú¿XTr!£Ö°èû©¼3{$׿¿Â¨¾=ðµfqäÈ6|ôzÌÙD3‡«Õ©Í‘ïnÐn^xƒ=Á]*<ûà/ßà‡|#}¼5õ´fˆV]åÇ[&¢ËfPTm2þòM*[ÿú5ß}ÿ#ßÌ^±¹wÛxL$ÿ6”üº‹5›[ÐÚßÙj$?/Ÿü[ùX=Ç“² ‡lbõŒ§`p #õªŠô—c‹ÆrÊk(Û¾zv’£â˜;ô¾ ] »UõݯuHÂF¼Å {'±nÖdJ^Z̘þÑεAö§²rý_èúä2~ß«yÅ‘ó6ª!©YôÑûœ>“ÄW£Ù½|'·æÆö“Èó¢î8.€£sh÷lÄ_:¿± ‰›Ñh4uî,Zþ1\8ÇuKõI¶;+ÖC‡‘››[½ÛKB§WrÓ÷ñI„g^ääÉ“üý¸IAò´AØËfªèµ¨uQ`Å`SàÔ•Ä©‘Ý"??‹¬ÀÃÓ‹ðvíÉ˾ÆåÓGøþ´¾½`Ö¯‰ìÇå_Òч„q--’Âì²LÄ€!ô D%ßàÂM-jIÂpúm$Q^×Q"ÕtûÛ³¸x¹ʈBéôÃH’„hõøAJ¼ç"¬\Ì„°žãP9J0ØHRe/‘_Ç~4;ˆÃÅ͈R—bµrÎ$3¦{–üÌjç–g¢š¾úòIC4¼›‚P¥T PªˆèÒ–WS÷1$\Ï¥OÞf×M#V¥­Fœ‘N¾Ú‹¬l _©Úoš¶f6ÿùô Œ=Ó›æö~βÑÿñYl}±?5“\òëÏ„¶K6>‰A=Û“#Á+61ã7ëYøtå”ÔÖ£fazó òIUiÐÎy{'½¾Ç;Ÿî`ÑÆíjZ†ÇðâÚ$=VÞnÎ`k®…Uñ­j¥ÿ½*Ý¥aBsOþf°ÒÏWWïyã[èø"ÏJfµïËG:O¾OW–nZ̰ØNH ì ôk¿˜U¿ÕsøìI~.(Æ&ƒV«Cç¥#°¹I’0ÝØÇaë0v®~©JoK·¸v\ñ™È†Å“kMv‡ÞÕP’¤Z»û–ï6[µqrŸúËH^³›è=ëYûéZv®ÊĬÔÑ&<’ä•ÛI~,ªúËaP­[ú¢¨âÍÓx?ÂÆžcö²m¬ÿŸÌïDØð$Lo¯ä¦m éÞ¸¸dK&ʵ°bPHµø4ÂCÒhH!h1)u¨kJZz÷îKAA6[õaI­¥™^Cþ-×ûÇø‡udBô|4PR ?_p.y­ JRb;¶ÂÊÌ+Iøµ¢u‡H$•„VcK1'ÿQÀÉÉôiãMô…³œ9w‘Ãß~E‘É„Åb«èºVªT¨”’ZEÜèñËFrrLÄL˜d+Àh«|?>jz•ƒ ÙYY€ƒ.½F¡T”™Ô¥º5±AGÙ•¦d§LìcnŠ1/{ÍBGá˸qißBGq¶’ ç!…¢§š¬ëfdÙQ¯&÷Bû)gÍ{MeÎ-½ý{w'äDKÿ} Y&sßJfo9M©MIª jñ5ë4›oþ;–ÇÎa÷â±þ8+‡Œ\ëç)ùÃŽýL:u‚LC Í'N§CÇöø¨ªo®ÑÇóû˜å,ù:ƒMOT_œ+zô|þ8z>ÈfJÑTTnUÃ_Ù³ÏØeôó–îK%áN 'Ì™GºZyÛóc_˜‡^åz[öø¥¬/¿9W:ÕÍÈÄyŒ¬ã˜,ËhƒÆòÅgcËÞÐ+/œ°"•¨õ½»ôn¬†®#zƒÄcŸç?Æ>C6cSxTxhjÆÛyÑþäâ{ÿèdvïN®£Ñ?Ê+Ño²ì›,Ö=ÞòŽâºúåëxöùq>ê¾Adc5 ’‡¸ARž‰»v§M@z©á–ÙVXÏ`çÖÍÜ”*5E&E•s•ØŒ×H»PcFÅD¾ÁT£îÒ1zbí[éÈøå FYGDÌâü}ðДyBª¼iUü6Y&7£˜ŽCŸÄ¿õËÕî5 0¬«éÈê0†ÆGÑ2Ô¥RAþMç”·r: ‰ãÜç©xÍÆ»ë>lPºLOÇÁ“¥<:³?²1›"{<ÜËÊì^„1¯íd«RSíú¨!LªŒ¿Câö'Ö~©h¾¶èÂÈ1]ê<^³QÙ­‘Pïùc×¼Î'cRÈ~l+!®|I .ÂÚÍWxym+¾yß HwjØvrm0<?…àû8Œp¯yÐz߉†õ5JèŽÍ îEt +_eÛ¤W¹þè‡בîuÅe7_eñº<þuÏ0·àžG¡aÓÓ»±ªTªZúU5´ºÓ?q·ÅÍå)à©ãÇv¦ïÛUž’‡œú AAúhŠr04â|[ÉMr…†¡á? …Â-¾Aýš”ç­†4EƒÄÍÜ.Óˆ 徊©±f:¡¡ÐPà> k._µú¹WúzKj5H„‡Ä½X,–Û®} 2ÒƒÏD5Ó¾¾|"4 ܯ¡Íf»ok îNêÉCÌáÇE"4êË'BC¡¡Àý;vL$P×P‘••%š@ ÜŠØËF Û@ îo‰@ w#†l@ ˆ‰@ ð@ p;ÿ ‹3 Áø±QIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/data.png0000644000175000017500000007557113070106167016034 00000000000000‰PNG  IHDR$ŸÉaÂïsRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœ IDATxÚìuxGÀçwq!¸»C¢Åµ@pwww‡ân>¬@‹» îNq÷ $D/çß’\r¹$—Ð"û{ž{’ÝÙ™}çÝ™wgÞ™=~üØ„€€€€€€€ÀˆT¥R RøO " ©Z­¤ ðß$‚‰€€€€€€Àn"øÑØ»w¯ /Š··· “I”`|lÚ¼U‚€€´hÞ4Ù•¢ÉdŠ÷g4! $Hl½9qâ„ “vÈFð!ù ø©haÊ”)#B@ œ?žäÔ_jµ:ª’Œ]qÆ<HL£ìÑÍïQ'“"Á‡D@@à›%9õ—R©Œóåií‹T@ ©½öêæ÷¨“I‘0d# ðÃ7"ñUü‚A"”^€Øÿ :™4ÙÉWHãÆ¿©ünß¾](4oÚ(±Õ0$G—L¼l¾{’°W'¸ñ)?å ¥Þ¯”àP5~ïQ)˜ŒF F*9é¼ÜlÆK®‰µŠ>æ×éw×hꈤÿîz˜FÝ{þZÿ7í:tHÖJœw·oäcµF”wU|®½>$ñéä‹Ã>È©HjEÒ¥ñá8û.»Óä×¢„<ÝÏ¿üüúK¶¯J6_—‰IÏþC÷¨S«PÊ$g¥ó~˜Fì¥LhÏd‘XƒÊzçPøÛ£Ü0–¡lz‡Ó}q’k¥¨à¥LqQ8eËMzÑ> ùâb—È3’'‡wï=ZFÿ„÷ƒH—&r©‰D‚\&E§×Ž«süïbrê/•Jo·xÌó_¦®3pèèjVËŸì¤&OšIçáƒI'—$xíêæåùÛ«-Z¶£q%ë÷~¼vC¶?:þiò*Æô èÑbFÍ¿uÞ%[o¦ I8ÿ:Í{æÌ™C»Î]‘ÙhKoMïÎØ ǮÛJq'YÔñµ?q»d}ª¤’Åmp?^aÁn-Ã;•~Ö+ÐÅ(¿–»â,Åo ¼;ÁMc)J¥S%ð‘{–ŠSÖSi³ÃÝŒO'uaÿÐnäoL=~ŒÔÜbø¸u6ÓùmÖ‹gÝ6t› /¤e=³ìvŸÁ™fk©'“%l$%R.)!›D Ù„ZlœÆÓݹ(ùïèÙÙ-¼ÓƒRÕ–’*†¿×ŠÔ®OF¹„©UJñ~åaægwM0½]csWRÍmO•¹æsúpüƒÙ{÷:E-ß õ¥§÷:>ÀñÍèuäµÕ´>I>UýëõãÐ饤Nᯎ|}Æ1@¾Ö}/}ñÆÀ!mfLσwý¶BË(ð¯âûö#o>¡7˜@$A©Tàèè€Á$A$®ÅÉAD"ùWòòé:£1^ƒÄÑÍ=Eêº ¿w`ô>JTš‡gŒºãðþ½¬^›ôr sêVÁÑ.¦gu‰7½ú6mfÈèa‰ºo«ÀÊåÌë×”…y*³bír+-e›­éDV×5DË\̽T×¹î÷33å'àΜçY´S_Š»÷ƒx±t9ûÿA!ßíÓ—¡}ûö¶ëtq´ Õþ{™|õŽ~C©ácί߫Ox®êE5–ñmÞC-w¥M¹ 9ágõž³vî'O2e“(ƒ¤i©Ÿ¸¦‹7² =#Žfàø…¿É¬0+¡Aó‚Nåª#±:Ž1p~\k|.¥²»¹K0ÂßÿðŸùß츋¸dSJP9Õfq•Y´šzŸq%˜FÄ1Syº·qaî´ýB‹*dƒByúê~ï?!•ÊpP)ptvÁ qÀ –®­AT,BªPòÂï#Ù3ý;C®­Ë—æNxüu]æZó9<¿Vò˜­ãéµ þ:4ÛÂ3l8ÓÏÖ ½\Bxð'¨ë"£p«†2F2÷·LæTžžt+âiqíÕÃ'H_©<‡Ï¦mŸþìÙr>Ž1xzÍçÆ¹Ï¸mûÈð2×ü?S¾|1ÞˆVÃqsØË@-™Ýå¼9±ˆIëÓÒ¤Fz‹øíÚµãÑý{–Æèß[ùЭ•rº þ°ú­–[„§)=†ž FkŽò¼z¦uŒÑðš\áZ”åûþ iåöŒÊt©¿f¤GŸ>hƒÏ²hñrî«udUZ7H.M훺ó(ïf®û5ýxíûÉêµÊTÕ™]qç\g÷ðâ_TõáèÑ´=áå953ýiEÑå>d;»Ž¥÷­ÆIS¶?EŠ˜ÿ7êÞ3¾ý$DÊ\ìÙ-_ïªUX·ö/d1 D…»î I‚rù .Í‚©ÕãÚJ JÇäÉ&Q>$[/ÿƒ!ž’«#k3*\…Z­F|ŽmûžÇ›NšRÞTÍáçü¹õ£è:ý*‹|v‘[ªG­Ö[„kŒ&dºÔj#z“ ƒ&"Þ1(ƒî=+Ftå÷S/qÍÛ£&µQŒA÷ŽÉ-ëñªÌhöw('¾^}î›^±ìr®¨0­Á„D‘…råÊYë‡D­ƒ}Gò¤L7n÷=C¥ä‡hPRkH™<×…–UÀ.ö¿ŠT&Céà„ƒ£; 'Š ×‚Æ 3"1±‰XBh„ÿ€`¼<âö¤´ɦóWÐÇè!‰Éq¯vB§Ó¡ ¹È®/âMÛëçÚTÎæçüÅMè=÷:s÷m"t:KãGc2¡0éÑéÄ£^ç0øö5/_½æþ¹£™˜?o>^Y иn%œÓHù½cÊžØ@žCÓc‡õ¡÷á ÔpW€<-ÞmÆI[âXM›â~\9(EìØøœ´<Ðétèõ&0Є½¢V…üs턹5špÊÔ„¡CË%(ÿÓ7þf©Áü|R—ÚlÚTÅ"\,sàù©ƒ<Žl‚ FÂß½ÁÏhÂS¸”FlС‹ìT;fõ†é„fö²x®Ð>\û¤¦ª“ÄJ/Ó}nÍÂS¹£âŒf9Ç•½™‚½†ð¬röö![d#þE|H$YÙ°¨¿ö?Åá?ºò¬ÂdävæÂ¼cø7šÎ¨l–ïÄÛ3c˜uÓŸAõÓc2ª™ß¹1·rVÄøâS¦L‰¾ÉÄô©S,|zruKÏ‚î ÊE¢ÈBéÒ¥ãfÞh@g4$K6‰ó!±qÍá È5/ŸyL(ÔŸ‡­û!¼¿°‡»ÔÝÓ&úå ¸É¤þ½Y}ì)©‹­¥vV«qµ&ðttD¥’"‰(”VÇ ïüEó–“H]o8—®·ãÀ˜FÔ®7€5õfu‡V¼-3†Ã“[Åé6x}v.z¯Žüâ]Àr‰DR›c*U Zº÷aîíV•OÀÇ‹˜´æ1M&Îäyòz#2”¤‰w9repâå3üµù1 6SÉz´ªY’´ÎFݽºgè7¤“§ÌŽ7ÍܛӤÊOxJø}ý;­Œ å¨P‡%Š’ÍKÆ‹»økÃ!B &RýÜŠv•Ò"w*Å A^èÂï -¬@¢‰ˆÐàéîŠFê‰\!G/¡G"!‹‘HDfC$Ò Ñê| ‘rûá}šÖ,ŽL*‰õþ¥¬‰\.ׇäðådŸ–™L†Áô.ÞºÎÿònî•QcS³èº.ð3‡fý©ç¤*²Œª¬ÃèLà¦P “Ib© Y¬q~CÄ#*×mM¶Ü¹Q={NúZqv†= ‡±ãþj¶ÁÔêµèÑó/άïçÏuÔðr²ø*Ž‹Œ;úÓcÓ¨3%çm¥oÐr¦=qb{ÕLÈdRyðéá,† T t¯•G¯Bµiä‰CÚ2ú^@ü5E¦2ñׯÔ**2®Œ—ó»2èÌ›¨k¦í>ˆî­¯C´diÖ,š^¿6§ëZG6žùêâë^çï¢ðTðÏéÈÚ¹Ç-¯³ Ñ¥jCI÷h_%‰@'ý()yV¢‰[8 n~bqÙ´q [{uÓšNf¬8¿z]¤õRŽ}ÅEµ ‰Þõáï{–¾ÁOyIÍ:ªy‡&k¶ÉB©—)Q¢D´1ẋâÅKÓ¥&]*‹çO."QürI®l’5í× yÉæá,.l6$T^-˜1£…ùÅ ½Êèé7™9¹#!O·SaÛ¦m‹žÎzië,úX„K•®,èrŒ)׬ßÃdÁh2á!KxàÖ5O]ú.¯Šwé ´±M›ŸiTÖ›ÚÃÖ°³_ÕxãÞúýi+ˆkôiü¸vÍ2sió’7†Ók½²^ô^p" ’З'غõTwSРÔ+ªõÜ£ŠR{âJæü\“?žµ¤s64ŸŽ¢p¯eŒú=æÖí{h^”ú¥.1Z¦\—p môP‘D¦àÊòçŒY½1jˆÇ3ÿÖ/»J FÄ "Ñ ]ê²Ptõ–°AgŒ6øH…ÊõÙ}üž‘^­b™+®%Èã¹ [ÃCŒûŠ>²ÓÅ‹xl7Ä’»@6L†06oÞ&GFüì]ïnZñ˜–s[±iÐRh÷Cíβû¤)ß+É:ñkÉT Yz"Ý/‡‘“‡ŸÑjö*œÏäi—¬#m┌1|e¶KR/]v³ü;¹=š “ ’’*Uª¨ËDˆH啊˜æ½k,§èøäbоãöíÛ–m•WNr¦Q&[6É2Hn-î…CÖÞÔñˆ;ËDv“ûn0eø ZÔBÁþÛ©å¥B¯~ÈäÝXsÑÄàù{éë]˜ÛsOÇ{]øm$2/2ÆãA® ¹Jïù¾,[±ÔïÒŸ¿Hî1Ü(þ¸›Žé›¶Ñæ—,¶Ÿå6q{hÔ»éÙó¸Å¹\íÿd]¯¼ÑVyIO–ÜÌO–zÛð­—|5T¸–`]‡vœ ˆÀ/kE&þZ¶öbÃï­€3¨ßÜáöË0 Åý¸téI!GölœasP:.•ÀmíϬxð‰®y,§’ß}«Æ½¹{’u£¸á+•¾˜Þ…¿_KÑ Óqvu&¨GK^Öª‰øÔ(®9EðîøAö8Æí©(®Q|rKyéƒ,6ïÓ™LìÛ»×röÞ½øÔÍ躙lÊEýq'ýú¶|¯[-eE—ÜÉ–ÝëèÃoÓqáMêoZju<(,Ä‘ĕ˳‡CÃé,ïšµZQ''È­ûN÷&‡“µZFgÄdÔXM'äíIäNÅ£Â,}H ÌjÖ‘'ÆF…û?¼È¶­[X»~ïµîžÌê]YVžÁçìyœ"¿ ©õ(¼ÄyÐL8¦íʉ=ãJŒëÄ©•èÕHé5]‚_-Œ2F‚#ùŬ,2—R¤—KX}Ä×òåÚûjZú’»”&•LÂÊ“o,Î?9äuóD?wÈks–§MõܤöòÄÅ9E:¡5H¾‘­P'gVž¼zÇÇðptbDQæˆ#˜ @)ãî,CñŽŒŽRŠäËcó=L*‰]‡D~—^ËnQwÍB«>êwˆ¥nü³hxObqçüèt:ŒF¡nÕÙv¤;Ù¤fß £Ù÷ÂZ:aÏ!s*féCbd^Ç^<Ë7"*üÕÁÕ¤*Ù#ê8"ü Eú¨ã}ÇRzµZÿëP®¡Fã–®gQáÌ|î¹<·»æøz³³nöŽËðé+oNý©9¥;ûò ç·Úæ:èö²¬–ÿdõYŸ¬b×N/†÷ÒaŒ ;x1—ÐpÉÒ™±}¢?ì Ž_‹OŒ44A§‘Ê3Ò»woÚ4¬Ï­;y>®;›Ìâ·ZV¬>yoGÆŒÀœûŠ’™‰ÅÝÆ‘§ó2¤F1F”¦IÇaÔ?ö;î’èŒ<УL-³xŽ„|Hdi•è#žF]ó%|H$®Í¸t¤:g¿üÒ‹ßz6åu…Jì™3’Ç2{ëVzuÉâ•ÃiÛsk—¶£uÇéLݳ!RþÄ®ë-zûNž:ÇAƒâ¾ŸnQÏŸ\ÓvãÐvq æ×Ù+»Ö!1ê?0­k7Œº0¹tF¬ÙóÁ"w®IÙ cÙ+’E[bª¬Ì[0ÂR21"±Âê¸Òå{I_cVTXL’ã [²MÔ€‹3› ÃÜ–•Xp5œúíº±dm áŸ3ãSÉ¿ ¥ Ud÷hF…„[A"‹<$Ƈ@¤CªÈDJ¯éb2jc÷ÜAd5"–˜{44IX&A$63©˜¤ÔbìršdË–-G8~ÕŸq!JüÔ\hMR„,Y²ðæí{Ò9ëñ 3a‰0‰Ì•–ËÍ·Žr:©(ðs ë‹a}éuH ºÌìÝcÞöŒ.žÆj]§{ÿ™SUJ ¦˜u,S¦[KÅ"I¬ŽÁß[ô7é*OŠ ‹éCrzY'vQ‡c¿y#‹œÒ¹såcê­ú)êz‘î5Reލc™{)æG¶9Ú×:DïYAéXë&åo’‹ÐÝÇ‘ÉÌ=ëTfi¨•X„QŠc‰…ìžU‚¶ çòW¥Ñ„uÙE!ÍIºŸ“°èTe«Ïòhõ ¼ÊNG&“aÄ^¥f-\b G)ÜÒYÄU»"ëÈD  ¢à¢å Ô™ÄÈ­§/ñR)xôî5ïu"äi˜=kBœ{‹EÑ2»¸º7kßäçP÷Èdr6üFk*ÐvÄvÌé†cäÇhz…„Û‹´ò!0êÈÓG]ó¥|H|z4æù’Í€ˆk£ûroîA>UdWj(T¨R‰’‚ò!–¸S¨`>@„L&Ãd¥R•:V=˜ttíÚÕjö;“D¯\ò!IŽl’ed]òrë‚rp=s´ƒ…ïÞ{¸´^µƒãƒq¦u<Úò•W‹èÒ°0ÿyŒœxs¦m7™§±ÈœŠ³~zeê5èM!Ãuš-:@1§¸åc4òÛQ_Þ‹ãÊð-‹t·«\£†Í!›ˆÐFî>D w%çºVæOIZ·,‚&è$en ÙŠÄ*rfË1Òp‹Í‘Y°î)Söì!,ò™Å F¬_LÛêñîéʱåægÎã$çüƒ¨“Äzÿ^ ÷< nrWøµ¦“×44wU°Èá‘Å›ÎóF\Œâm4oÞœ¡OhÙº;Ú ·´hu?ZF'Nž‘F©,­©s½ª±à^vöœÛB^‡è<8¤+å4•TŠt̆ï~û|"Nñ#W×QÇoÏŒ¡AƒüøåƼMúOLÜûœÒCÆÑ¢z1RG Uí„j±æÿO˜Âä1u,ã KÓªE‘K)R£cJGmFí[‚ôFŠ–)ˆ£TI¡òÞ ‘‘HµfBÄ{ r§ŸñR9“· ‡Ðº $™LF|¹p}B)c0˜ÐùQ>‡‘® KQ¬Hþ/jŒÄþj³ø5œÚ¼€†kpX_’uûWO%±zí«S¿3þ²”ÉrÅŸž…¡w[y£>ŒÙšAåÑÔõPXEÖç²²ñðjr)£ó°sÈäl;}ði|n½A¯~ÎÊ-Ï)Þ%g<÷7¹Øâœ6Ø½ËÆÐyÝkºÏ¨c™ÇÏÿG:ô| gÀ3ä"×Â\pðÅhå^7u#(cvL*Eú]Ùqñ•myÇ.‹úóÿO÷,Ã=7sŸ³g¢ó_¹ªŠóúüF|>¹<çœ böŽÝÔÏìdq™sqÖì[JûžÕ¢Îl¿ÃW,ób½æ9>>>¿c'oF]sþø;²·Ï›¢«ûÆé©3„³/<Y# É ¿¶¦¡ó6\ ™glÚ´‰TN9ذn)r×Jl\¿Êj:ÚàçÌìQ›ñ‡ ü¹y4 aúæ­d}½™*5Û³áàBô–ÆP|rѩő‹·ÃtÉ–M¢}H¯kGçùïhÙ}6úÔB.Š»^Àƒ?‡ÑpÆú,ÜJ‘µZ—ð×¾’ð7;ñ‰¨ÎŽÙM-Î,›‡ÎÍX:¦%*±õ<DDˆ^_Áí“X¾zNìZW»HŸ.Ùü?pëÅ;*çIM®¥“¼"kr|H"""¬6†7t¦÷štšÂ€vÕ‹LhµÚ¸= ÆÒjÞ9ºÏ\G‰Ñê5q†w &0é,® »Ÿ“š*l˜ÒÈâ|RYyâÔˆÚ GçÁ¨ÿÄ¡S:d'"ü ÿ4˜AïC;•á@V›ùy¶™˯ðáÝ ®]ˆKÎ2Œ^¾‡ÙTQñ &8½h!Ž2Âß<ÄžÀ§ç˜7m ?qgÈÂÝTv}̬Yè¼:+Mê×£Yãê¸IÅ|¸²†®+Ÿ0h×22dtd•f%¿êÀ¨!ÃHïé†B.G*ƒ^V«¡ÓБ¤–‰1š`ÛÜ\RHxû$“VÃ…‹è7÷-Óö•A«Õb0AÀõÛÜ–_ã•VB‰­&”ó‡1mÓS&mÀ)[.\è!6hž³dÕÒ¤ÏL¾BÅ(”Ý+Î5Ö*ÃÍî¨9{Rî–Å=š“¶ù`ÆömlѽÇg þ¸Ë‚õSP‰E߈3?Íbbƒ1ÚŽP®ž9Ë£ç¯ùø‰pµƒÑ„H$Fî™Áý[0µJIO¥Ëº« IDAThä0Ìã!ƒG\bü̙ԊœnýîÌzÍ<ŽNáJ‘½˜Ôµ`dn‹¶˜¾ŒšYÍeá÷,Ï^ç¥ß;‚‚CÑèôè FÄb ™ ¥\ÅÈ)qtnÝÒ± ÇšüÉÒ:™%ýg[;ÒíXCŽü¯žÕ‰ .àííb:iÐúS¤T7n\Þʉ¥{¨ØÝ›f%bË¥ëL·‘:1fò~~¶-®-Ù0¿Í3z6FšŠµhÞ®5S›ËÓñ”¢%›rëæU }zpá>פôî½èé`ò¾Äõ«§…K@ÀVµœ€!ò£$…0ûDs’&R">ûÉ$©BiöW‰Õ@ýE w+Ǫi79ö2„›7oÚ¼öÓ½µTŸ³‚N²8Ã)îCC'?#ŸÓ—+•vßK™È¸I‘KJÈFšÒkg|븖êEs7þ§ÊÙ†®À×$C×ìs¸~U(Gƒä¼{ŸÇ·?Wü±+O‘HôC$?*ž¥ºÑ0 6¯sÎÝŠŽ±®³ÖàÚ£›_£N&V.)!iJ¯! ðo‘œúK*•&rfŒ€@Òz6ìÕÍïQ'“"© J_çÏŸ„ ðV”‚A"]úÓ~¿ƒ$ÑÓ~Uúï±×1O@@À~Ž?.A@ÐɯÑãÇ…OÿÁ‡D@@@@@@à?G,ˆ@@@@@@@@0H~x„uHþ{ƒDð!ø¯†lƒD@@@@@@@ ʇäÞ½{‚4¾JòåËgq,ÔWßßûmáCR¬X1A2_×®]³º÷…P_ |_ï·°t¼€€À7Ë›7oR<Í ‚ˆ‡€€€¨ÿ_¾|iw:ŽŽŽxzzZœ »(\¸°]ñž2iúJÆþÃ”ï ˜·õoÔ.<{2¥¼þå(~DY‰wñéÓ§IJ#{öìi}þkáC"¬I" ð5b­nR©T|úôÉvåùa}»ÎåÖë0ZÔh•hƒd×¹¼k7RÎæë¥Ê”«Ÿ_¾ÈÝ\m€ø fΜ÷Ã4’oOO¥ÖØë,\2š÷'ÆS¯BÞÝ[þ/$I“µQû–‡ÏÅäÍZxS0-Á‡D@ Ù´yëwù\ŽÊå>ÞÞÞ_$]“QKƒ"Ñ2IñÞk 4í;f©Rþ#­ë†] ƒÅ]0üàCšårÅXe —^ôçV˜ŽB޲¯.¯!¯¦S¡¶Š÷§ ÷ ’´¡ù·hѼéñœ?-L™2e¾«g:þ<>Œ2L&S¼?£Ñ˜x#!VÜ'N|±gpHÝ„º©aã½ÓI'“`Òc¸ %'âãINDsx î “áñ.V^Ñý[¡Š±âÓÓ};xYêW*Å–0êÞ±ê÷%< ó U·Ê?Lý W?bñÇtøçr@,ó⯠î©Ð°yë!j5m{dáݾUµúÓ_°Y¶d½uÓ&j7kŽ£XuìݬJ1¼?³—½W¡W°qãF¼J×¥Z6稸g6.e÷…‡¤)T¾E!â‡E£ÑpúôiÊ—/B¡H¼A"øüx ½Sž)­ù@–òÏŒ’ðDþM§cX³p ÏþžF¹bGyþd#NÛ] cÇ¥æÐ¿áLG|}&à’gEd¼³Q:×vË:_ŸY,þUÇáš*V¯Ž1dcÒÓ~æ1æÝyCû´Ž¨›f£ïLTæ{ì$±õ®šL&N:…¿¿?¾¾¾\¸pR¥JÙLKð!H2Ÿ ‹Ä#öôÄþÿkÂ÷/R'7< w¢«ûú…2+›«í/w‰ÙçF,’ &l?£:ð 2×Êäs0WÇny{kÝËRaоgÇâždVH(Øg5¦{ò»_(#39ÛŒ›£Í|‡UçiD;LºF…K,‡/!kmè k´Mëhn\Sy³r©÷YW\¼x1ÎÚ$÷ïßÇÉɉ‚ &ø¾ ‰@¢†_£Ä–±’é}©, /™˜[†/Ó(K]ЫÇøàùaôJî\‘Ô‰ôòèž§ÂN2î†êŒ+s,ÄÌŸ” Ü‘KϤ\«.Åe ‰d˜LuF|`çÎñÆmРC† A$Y5H¾ÖuH¾®ù‹S%¿Ð ¥X¯Wåjâüoꃘ”,Y…BAXX8Ï_øáëBHxnŽF”"dऔãìâŒA¯Çh0®Kþ:$ªÔ5Ø>£.UF4#Â-˜Œ1¡jü fIòÓ¶m´Ú¬Ÿ4–ömÚÒ2r•Â×Gö±ôDô>zððx–¡6#عkÊúµèÚÒS¯¾Ï_ïÕì¬hžú¥ ¼ÍÑЬüšÉòK$ôå ¶n=O‘‘SlƒÄ|||}mµjÕRö%H¢Þ}æÜ¶<}ýžÚ½¬2n‰º_rõDr–@‘±vtIœ(ïªàê)øF ’xmZ‘ˆ©S§ıcÇâ„W©R…)S¦Ä1F¾/®]¿Í±S¹qõ#þ zGéÍ‹™<¤qVà¡Ð‘= Ù³e‘õN»>’s6[H±ñ¹8æodÇÄÄš4Ϲn ª[´ˆ!Ì€Ì1z¯ âŸòx<û–¤]긳A^í‡C¦>s2{E?Ù<‰«ÓRõÂä1êÃ,õ¶á[OP {h×.ñÃOž—ï㜭ƒ§¢ˆëç#k§ cëɇ䮨”™£ÛZÌÄ0BX;w!i»¦†[Ì mdzëiÚΧ}i&§ÜSþÙmÅ‹[³iE¬§.²bÕyBCœçôB忀J!&­‹¹áõpqEéä„ÄQΓ€·ø½¹@ñŸŠXÍX­V[Œã$æwa~KnrQ3œž]–$:ÞÓ¿G㔡3ÎzMÔ¹ 2·ÄÝûÐØ}dª3•°ÅS¯Sbdèã¬íVÐ@q„¶Ën$:Ö~Ñ|ž_ž˜ßç.¸äÈ>¹z§5ÁÓë—¹ù8„ÐÿpñÊmL&=jŒ„††amXa¡á€1ÅôDªÊÀ3uÜÅ´^i 8çrþfÊ]­V£Ñh,~Z­6ê'‘HX°`¹rå2\¹r±`Á$ :ÎæO¯×'¨'ÖÂ?ŸKˆM}š±ó}Z:öíIqÕzt˜ž¨gÞµp.wLrœœœÌ?GU²Ã>ãë3Îã'óç…w‘-‹†öE+rѽæL¦¬d'U,úaê•ÅÞÅYí—‰¡“'PÞñ5+ô »9³ö©é7¡/!›†Rgæ­¨°°·R­H.zŸÂÑ@Eš¶âÙÂVš¶òiWšÉ(÷/ñì¶âÅ ‹ýnÞz GE*šw.Aݪ™©RÀÚÇ¡8fqOðÞï/ÌfÄU);V—B¥²üÂQûocK€’ 5³£ŠZñOŸ)\¾·[_äggÿ>)5gݽ+?z Š-oŸˆG<½20cb.TŠ=(Üj0p`s6ïXI`—ÞtqyÆâ?g¦X~åN…q—‰¹uí#dwñ„q PMŽ_¼¾©2LhwwwÖ¬YÈ#˜>}:îîî¶ëƒÁ‡Dvƒy×"8pº ž21…sNeÎfon„ h[Û¿×hÚw Í¬ÌØ³7 À õ£u›Mô©“‘sŸëÀk¸ÔìÀ{ã Q2ÿFúº"ÄÐgÉ÷=Ü¥ >Lj3a<ù0€4r1¥ ®eè’<œ ^@Y9“\¤ýñTËíFñ­mÉQu ÛÙC ¡ã‚SÈ[ÇAe+ží^ëi&”O»ÒLF¹‰g·/fX@€eoò­ï˜6«Z¹‰à0-‘ƒDRóŒJ!G)—¢‰‘ÉÄdÍ›‡§}(P ò|H Z_º5OêZsS. Є-C6á=º!»+]¦~Æø=Ç/ÌjÆ~Ci.Ö´\œêÃ?¸´r±yßÀ»ûhÙöwjL;5$caÙÍ^„{þ¾?¸É÷~ø½~Å£Gxüè2ƒ?=ºüÉÕÍ]ë 9r$ýõ—ÅpδiӾȽìÑ;MàaV_¸À§·j"4O¸sçp‡O4_^@"9óË¥¥ßØ? É”¨Ó¯ç­NÌ:ïÌßLY'vÿOOÏDͺ‰mÌ|¹¡€pÚu½œ·XŽâ„ùwz#édLú`  'z{ÃŽóFÛy MBúE$r—2,û_ôŽâú𻈥Î(Äß¿ïÑÂÀ¡3H¹ÊªH¬Àˆ'‰½úûÔ<ÈbîMtÉÚu@>ªõäVIqÊÐ6`}¬4Šg‹øÒ´•Ï„ˆ/Íä”{rž]t†í¿"SíÆü9äd+^vžX„Å&ƳvÈù¿ÆÐfÉC&ï\Œ§TÌ‹m«Ù{â¾/3õA …ËxÅ;FvdõÊþÚ—BƒV³¼¹¥ Qÿ‘2y³ÓhÝ#>Üüõ[0bòœ¿‹Ô3 : `óßQ_ø©WÌ»¾=3† ðw`„`UØÑuÿù7zôhÊ”1¿LeÊ”aôèÑ_l¸Ë½“(2S²dIJ–,IÁÌŽ8d(uœS™°žzR{ùLÜÞ.¤æ¨5Ü}õ–sûÖR¯í_ë¶:Á¯ª¯‰øŒ‘äüì]á5I½T.eéÓ=Úèê꡸è“`£ô¹§ãÐŒ¾”)Yš´éó2çà«d‡…¼XK»méØ÷[9ëFЩ­,]4Ÿ®uûÑzÚ. ß·ï¥[M&ö±95«î%&QØQ†^ý‘DEæHŸ ‰2+*±ˆjÛ ÚÏÞ|&—”,÷Ä<{¨ßïtêÔ‰ßýB/v˜•“X&1ƒ‰X‚Vo#`4×"‘“1rE@Sü›j&z’7–²ü¾”®+þGj£–˜—_7‹+­g0è÷ó,íQÌ"Þ§ÇKh9ù4¿­?Lý´RÔj5ïï¤ÿʱhŒ&ÒlÃðtò8÷¾¸x,£þØN Gaú,=D§J™¬äÏå —ìæEúôéIãélu»çÕÃÆà–]…Z­&<$?ŽZiBT©³’#{êDuÝ[Èuõ꨽lœœœâ5b’ƒ½z‡( UªdàÑËÅl .I•È9—!¯.üb4yóŽG†©Rq拌 )•ߔЧL9{<ˆNS~aoäéóR­ã|þœÝø›Òˆˆˆ8{ØX;NŠ;Þ—^‡äÔŠ¡ŒÙ©`ù¶V‰º>@o$°p/.L]FÀÍUä¬\›f~7ȤØ&71ªîPzí¸…G“›fJ–{bdæœy4»ww&mfçDÅ3`û½‰@*c™KĈÄ&Äbó_‰X„D"A,#Æ<;ïóÌ;»×!ÉXf §O´ÞPeªÃÑSÖg=¨ æÌÕ~dŒáÃñóøÍ<äϫٲXßÓ¦@ÅœtË·•6µKX]sä3…jTO°JõŽ^}3û¯‹9ý«`„Ĥ𘜷#ž³³3ëÖ­K’“TìÕ»˜(dbÄ2ET^ôNd(0“ Y|!T©·,êš”ÒÏ¢Ø}¼F­±üÛldäryŠötXöù’ë[Г©WÒðçöidS%n”Ú÷/R's%ìQ¸]ÝG°Ð/”YÙ\í ëvº+{<p)‹‘wïÞ®Gò‘Ry˜gf¬ÓquÀñœ"Jðsµ×Ô´˜=ñý²{ä¯ô>™‘Sÿ¬#od¯ƒD™£îF>wåù¨3’-N[ñœÜ»³zuó8qÜÒ9ÙO§tÉK3%Ë=12“9¦F‰Ž'Á2,ö»h41šŒ˜Œ&ŒFb‘¹äó„&ŸßwËÞ»}H2dȸÙ×7®À­8”J½Èfc¢×Ï=è Ø ?<ÉÑ»Ïäî°Ý¦è!çŒÃ¹p –>ªòpêÈÜ/öߪ1bÍ€°fŒ$× ùR¼=5‹ ‡\ض{©½£³‘ÊòËÖK&æV„Áî0ß=opò_K•*kͽN^ íJÃÛ+8º*·Ÿ9S¬Hú¨Æ¡e*)ËŸS³ø÷o¼Ú?˜.[Ýùçî2ÒÇØ±WæP±IÏPÅœdèB¯£GLÛÃ$¶âIä™)\8sŠæS¢°/Mmðƒ/÷/!3–aqê6±£ÁhîõNo@"Ž1aØdÂd4`4‰1áÄŸD$¶*|ƒÿbtJèHªD)_Š$ñ9¹~u‰QÃÄñ;iµü@ŒÐÄ#c+.½{E)ÍK–¿ çéí«´í4wbÜãb¿Ÿ”å/N.DðË©T®~€·oO¡‹0‚8ô)‚^?€ÖÕt*¾GžX4òyzzgpfÞÅ÷¬­š÷æáœ¡OœëâôØÏÞ|ÚKħí)^î‰yvkN­¶ãY†Å1"¤"BCµ˜D`2‰ÐèÀdBo4 F4:R™£QD``r¹uº$íe#ðcóywßÄðy¥VA§¾}´Z­…1Û¨‰Dv$‰­{ìñ! }û—B´hg ¥[ŒóEÆÎ¡w¦ø»g®•™SË•:uZѽ~ no\@ú.«©êªì ‹—Ì#èUh%eš ¢ã/œÞµ†·Åú2*³Ëw¯[A/gp<(ÍàÔˆq¾ôÿ¶21‡+}t¤HëLR#³þ¦ÓꛉJ×ÞxöæÓ¾T¹'ôìf§Ö=Ô»V“_\=/fXç––ÛadÊîÎÁý7(V!­‘Pµ†Puô,‰TŽF§G¦—"ÖKð}|///‹wØÎ½l~dìY^Щo©Tš¨™3Éé!ù>$2EE.,缇gÂ:Ùcó 2ÿµ’KOƒñ»‰fuË';,&y{.f®*[䑘iGîPvÝŸ\}äϯݳ¡E-Ä?€nÉUuÙ½»lœó©#WãÎX{:g×mc×™Ç XžÆÕ2ƹvòÆm8§u´8—˜x¶ˆfBù´'Í”(w{žÝšSkBñb†Å~+–ÏÊî]wðûKvOŒ"á:<œÍ‰X"A$‘ •ÊÐF„ ýø–Âùr[¼×ŸÿŠ|}}M×®]‹Ú®] šBHyòäùaôäó4èï…óçÏóðáC*W®œâIÌaŸ«W¯âííïõÖê¦ÏçÞ¼y“âÏ] @áň‡˜ £½|ù­VÇác§°¾ IDAT÷¸x1”¹ ² ®¨<¤s7$i]89;á 6 Ô¾#󬨰°0<==-Þo© ^¡AH¹ü{äøñãBá XÅÉÉ‘ZÕ R´p'O?á廄†*ùd2¯Öì!×"—„'k*ÒxäÀÕÅ9ùëÄOæÌ™…çJ_z/÷®:::+»#yr¥E,#‹‘H$ˆDâÈc‘Í´o†ä¬C" ðeßE0™WH#æD˜aŠ:Ž/-»ö²ø–Ð…=eéüUÜ~ö4yËÒ£_›DMÛô™73AÑ{IUÙ3¼]²Âb²aæBËu¥[9ó ÉÉÙ†þ[ÇdbÉoð¹|çl¥wŦÌÝÖÂéÓdaíÜ…¤í:˜‹‰ÙŽg;?ÖÓ´OûÒLN¹§ü³ÛжfÓšx2óŸÈƒÈµI‹X¨²¾Ï–NËè&¸åR€^CúRTrŒ.ý7$*ê®…s¹c’ãäädþ9ª’ö_Ÿt?™?/¼‹Ì§ýÛÐ,ö.Îj¿L <òŽ'¨Y¡TXÌmïC6 ¥ÎÌ[Qaaoÿ¤Z‘\ô?…£–fÚŠg [iÚʧ]i&£Ü¿Ä³ÛŠ3Ì:¢ØV‰ùÈ&Sâ-ÑãÇM÷îÝ#_¾|B%& ðUa­nú|ÎÖ.ì¦ÍõaØèA(Å"Œº÷”*דÎØÜñ·@4ËàA“|i–*®Aao€AëGÕÌÅùù'ΕÙÁÙÁ…П§ïðÌ[<±ƒÖg÷B¼ þ˜à6ôß:ÚàsxdlÌ“¾¤‘‹1h^á鑇¿ß|¢¬‹œ¦<Èqü)Ós»x(9ª¾ Àw ¡¾ËÙu¿ë[—¢ðùçÌȽˆ­x¶ˆ/Í„òi_šö—û—xv[ñb†Å\¬Òßß¹\nö‰ÌûÕ$‡Äd2†ƒƒƒÅû-ø|õص‰cÆ-u¬W?A$qD&J¸‘§7’N&Á¤Æ q±ØOËÞ0€£Ã¼ÑvÞB“~œ‹<—œmè¿uŒÆAšÈa4‘XNzõ‹mï]²öF‡j=¹URœ2t£MX+Í„âÙ"¾4må3!âK39åžœg·¶R«­xÙybö%}H„!ïšW³eãZ&ô™FÝ %¢¯5phF_Ê”,MÚôy™sðU²ÃB^¬¥Ý¶tìû­œu#(·¡ÿVPºÕdÒØh›S³Zà^b…eq¶½—(³¢‹x ÖÛLÓÞxöæ3¹¤d¹'æÙÍ+µvâw¿ÐDÅ‹/)àC"8µ |×è ðGÞ¬î‰Û'$@o$°p/.L]FÀÍUä¬\›f~7ȤØ&71ªîPzí¸…‡Ôúw`JnCÿ-²ojs:­Rqø†ÙOÁ µÜöÀU*æÖ`3[ñ‚ž¦JãƒqâÔÚ~Œ)Y]íÊgrÓLÉrOŒÌ¬­Ôj+ž¸aq‰éCm|ö!%Ò(Ö!øêIÎ:$i*4¡G0öð£q•æ,}4Áqß7¾HÌ•°GáNtuÁB¿Pfesµ+¬Ûé®ìñÀ¥,FÞ½{G@¸þÿíwxÕ×€ßÙ–M#•’Ћ€”(AT:ˆ`C@TªMá' Ò‚‚ E,€”ÐD@@@º‚$ éɶùþØ´Ín6›ÙÜ÷1îœ9wî̽3÷̽gÎÁ”Ë­¸ ‚­¹nŠ2 }Icã¸Î Ý]=ÇWR;sÖA­·M{bªê¿G;Óó LxxO;ÿÅõô q¯Ì¢lwW®™Ö;ŒÂ\ÖSc+s|ß)[²qHA‰C‰‰1å_Î_õ¢N-ë§µ*](Ô¬½šL‹:NŽfAò´}³-­UñWºY±,jÓ5|n® M›¤ßºJœf ÏŸ\ÌŽ¥!Ež†¾$ñߣ°6€ã§Ú|’­õ²M{oLþ*êz9_&q¦§ÖU",¬R‘ÖSí¡¬LCâÙ"o÷â¸fZleŽí)s•F&÷’œi’HÜׇD Ü×·Ñàh2,™GK2û <à<ûnFÂnJù‡r*Õºînθ¢ë©ô õV,{j]$§NÊþ[ݳuÞYO产2ÓÐ÷$-«ž™iè”~fG,i ᾲ‹£Ö夽¸qp¾å‡GF©žÒz*¥8ÚÝ•s7$ì%""‚½ —ôòÊŠáC"îK¼CúÓ«æz^}wÏ5ðãèÎܪó B¼êyøµæ‹N~téò ƒŸmÌɈل§­Ÿ T–?Å•†¾$pe;ÒÉÕ‹¹¶7Ÿ¿–OªûÙ¤½ß6c+ýÂO¸T®R=¥õTBqµ{AçnujÝD·£yÜ/Ð%½Ü²aý†[qH7Ù¸iËý;¨{Ý™·ôvíÚå+S‡Äúf›Á®-9}%žrÕêѵsË¿²©[·.XÒÙº| ‡.%R»i+z<Ó*g:Y©,÷÷÷~Îx†Ñ¬ŠOöøæÌ4ôë4¡O¯NÄW6i1‡‰<g·½Ìc­yÔ׺Ìpf»5íýC?Ï‹íì“Ù¹ßæOÚ}Ò[ž3ò–éJ= [fQ´»’s7¦œ`ç¾ë”kÙÚî+!gzY²>ûdo+ê8$RTT” ŽS|?è¬ùv­¸nÒ«çK÷ý9ž={–Ç{ì¾;¯pîÜ9ºvíšýÉïÏb±¸\n^Ý]»veÃŽžMYÛ®]»Väç]·n]qã ù—c˜]¹rÅ-ƒ$((ÈæþK6NhðhØ}9Ð(œjÕ*Ü[ÆÙ³gÅ…»Opfˆdý¿Ò²Áý‰TÈY>a\&44Ôå}£££Å»O‘ÜFˆÃB$Áƒd• qHÅidˆ>UòIMMµ3$ŠÂ°È­WP?q'‰@ (:Šò¾qHw´#Š>UòñôôÌwVDÉ’#㦠~¢$I^¶.]DjƒîtoXà¾ÛgMeoBNUg5>Û×-YnVOŸLrË ji‘âNú’ŽlN`ÞÇÙþÇ|«6cÔÔ÷yÄ/+p]NÚûšO¾Äôñ}lœ„es+fΡÜÀQt° &æ\Ïy}—鼞ÊÊt§Ý‹þÜéåÈ–­YV¤Ï–ÜÿŠ8$‚BužÜ&“‰b2™ìd÷Š!ÿ×zÖ¾åPvëÌ)®-¢anœÎGó±éD¬Kûÿ0g&§d>>>Ö?oO·eYDmIÿ ŸòÍÁ˜Ì‘Eyúû¹]]‘ÑŸN¤•÷.:>ñV¶,wÚû¤5£é2ý¯lYÊõoh÷ÈC 0™ñ6e:Ós†³2ÕSQ™n´{qœ»3½Ü²|Ì£ÌÝû4ìŽúùt,ûž͈†Áâ y§°d`’<첎Úö%ñ &ü½\.Öl6Ó¿öíÛGÿþý‰ˆˆ@­¾÷Þènü¾”ʼn5éÞØ¾Ï­ï×øo1¶¢o1¿þú Šð0Þà½q?óòe9îj¿1˜yiøHz{™ ÀlˆæÕÞkÖ¥Bv¶_CÒQJu|¯?Š—J¢i†Ô'É<¢À4ô%Câ~ÞÛ›ÂÅ[oSV§¢Y½ŒžW‹ý‰³iQJǤٿóÚÎÚÕô§ÑÚ>To; Æ|—9CÁ³÷ {µ™]¹ÎôœÏ:8.³ z**Óv/Žsw¦—[–û+›¢Æe’ð7_àÛè*¬Ûð…]Êå½Âô#Þ,Û°€]þƒÒÅ_·°³v?>œ`¢Ñ­cûít‡²)¿ s>ɱdK­[vaÀ[è]V<øÿÛ¶˜áÎb÷É˵¾Ôiú ŸÍŸE›j9ƒïÕSøéÇõ|½h—À S].ÿƒ>`ß¾}ìÛ·>ø€©SíõÝ]oTÔïd3ŸN¶Öåöé«\3Ìe|¬uš¾÷»ã¨¢·îk´€)=´´â±Ëݹ¾÷Ymèȇ$kɦÐ6Zžežâô!98sÆç?§}ÊT— ’“…­Ù”ˆY]ÊÆ W*Ø1¦+†þßÑ=iD¶AâNúo,Z’9ze3#‰J*,Hø¨%LigmÒÞ—ª2”´¸‡9—f¢¦§Ÿòƒè]Vå)³ =gäW¦³zD~eºÓî!a/ßoýŠO¿Èã™KNÎôªqÑFvOøô›õ‹ö¡ß¼7Ø<¦iööÛg3$âú-?D5?çÉ„t’„Z§wzœ÷W~Ç0“ãiôòeýņ̃$]™Kt|ÏUÀSó`¯D%\\DãFÒfägl ïŽ÷õý,™5–ZtåäåTðPsûü;ÔïðOµmGóJ^\ºâzçøè£øè£  Ü]ºQÖï,4mjÝ÷Zò.ޤեiÓŠÖ9ãÆ|´ € ñi>ûë^Z´^õ˜9mp‘µ’ë{¯R’}HR£73~[i~øåQ.O/ÄÌšÁÌ/Ó†3úçH.\³0.|£:UtK–ty}×…púß–œÇ´g-ND±ÍB·ÓЗôþ™ôaÎï=3zÐxaÞZÒãlÓÞ«õUðTIœ-À°0¥)ÓSZOw)ÊvwåÜEju¦W [YQ.Ççõ!q¹uôO²nzžz·7›úüI·odsï¼<ŠÏ~ÉÄ6öŸ„fÜÞÆð19ÁÅ¢®'óߢñ Ú’3ƒáU¦_~Ú*ûwhš„*8±‹ßü„єַ˜£¿@Wï=">É\ï{øE¾hRƒÅ¥›3ùŸDæ×À¿ÆTn^‰F‚ßGìeõ×;Ï}`)èw ¢ì‰ý¬º‘JâÅD’ ¿³}ûY<üž¤Í£§øõ@–ÌzŠ]~%¹Û‹tò¾Î€·¶©A¢äú–4>ÿüs,XPà~ƒ âwÞ¹ó”Í|9l&=g}ŸºpÏ…8“…ø°!œ²¸K©ÑúizD£¢‡Z™L'óþ3£²þ/óyFeú’È–)=é·Ô“_YŸ[fƒ}Ú{?Šk³Órœé%ü;ž6/þl§Óéûߘ\ÅOQ=Ý-³(ÛÝ•kæ[i<7ö§\%_—ôÌØË"åþ)ëÍI–]HR(s±zùŒþ®!c{Lâé=Ÿqäó^ì65bß—Ï;Ü_­+O«V9ÆÆæÈíTiû­2×W..eþo1Ùò%óæ’nÉÿMKãÊ€/8ô‡øþ‡«Ôû¤­ÓúÇûŠIË.Ðý“é<^JwßÞØÏ}Ц©yæ ÌVÇÎì«+y”˜ 4…íw—ÝÂC_|KýCˆNy¡OéöÚ>& Ô¢ñ¬I«V­ˆöÔß´­Jýl+Ú~R‚®¯RFELL 6lÈ¿/>÷#G޼+õ»²y,»ü{*KbºSÊmâ ðuDÔµ(4>Ö‡p`X?¼ÇœèdfTõS$9MAos¨²…˜˜âRM˜’b¹—Ap 5×MQ¦¡/il×™¡»+°çøJjgÎ:¨õ¶iïÁB¬ÑBU½ó;Ë™žOÀ`ÂÃ{Ú¿@„ø(®§Oˆ{ee»»rÍ´Þatè沞š¼²|¬Ù~íÆøÂÆ!ycáb¾oö=¦ð×Ü¿»y~&i&Gu¬J÷îU³®øäCzwïN÷Lƒ$ê·MÌÿM}Ü3§O“šA"[ÒÙ´y*êOÑ;iN;Çòi¬iæOZZ†Û§Ù•\™l}Un]ØÁÚµ‡¨3ò#iïã7ICh®S·¢ÿB|B;3ã!ÅÅnß¾Ýå}³r“Õzc¡ú`aïšœŠá¦aßÄZe?Ò2$ Ö~"ƒ1=4]`É®ëÓO\Ä™ÉÇÌíÛ·Ù¹s§^ëÖ­ùøã1™ìéNøÄ캉WÜú÷ßlíñ1ÜÖLäí ùff'š$OÛ7ÛÒZ¥›Ë¢6]Ãçæ Ú´Y@ú­«ÄiòüÉÅìXRäièKÿý8Šk8~z¡MVZ­—mÚ{còŸ˜PQ×Ëù2‰3=µ®aa•Š´žjeeÏy»Ç5Ób+s|ßɶ3#YC‘’$“ß×7îÇ!ñlDÄ¢×hÒgŽXÇ GB\›JÊø—Óif:•óÇSkmL­QFç[*û¸Ÿ57_ýø3øyWSúW´³ÒþÙ2¯ŠÃx,Øš%ñßo¦3&¼ζY«Õ}QݬÁäÖŸëéÝs0—yš_Ž.rËk¿oß¾.ï{ñâE×û”+²ßé$hÒíEêý“ÓÉx©£‘ï·ÅÓCCFÒAV®LçXR©Ö ÓǪìº>ˆýÄé¥wâC¢Ñh˜5kƒ âСCÙ:M›6eÖ¬Yxx8Ît{'|HšÌü†rý>1õ%>Â7¯=äôX » ¬ð ‡bþ£®—sÆ]Oe~¨·bÙSë"9•ë¿hÀ;•—9ª>‰W¦ÐºýO\¿¾O•”†¾Cé`vÄ’ÆàþK¾í¢Í ؤ½_Ѷ<7ηü0»ýìf ê)­§RÒo_äíîʹ;rju®g+Ë{/ʲÕÜU¹fK² Y–lVlÝ÷…ö!ÉMÙ–€¯yâ•z.ëDmÿŸ ƒ)£Í¹0Æd#º@—ô›ð#•žïpÊhÁÔc4›úEö¤ûšGx}éV÷¯ýÀ$Ûÿ7Œ—?XÇ ïÏgã˜îx¸é$W˜H­ÅáoRØ~wù¯cHÿ&“’~š£Çs­;ËF2220Ê`2È ÂêpÓ`™;w.¯¾ú*çΣfÍšÌ;½¾d¨~­ù¢“]º¼Âàgs2b6¡Âiëç(•åOq¥¡/ $\™ÆÎ„t2Fõ¢C®íÍç¯å“ê~6iï·ÍØJ¿ð.•«TOi=•P\í^й;rj-H/·lX¿a6å™LF´Z­Ã… I²O¬—ßìæYæ–-é|ñÑï4ùd²ÍöÄÓ‰xU,øÝ?gÔjÖý¨ý”ÏÍuDÄzp°u.çFIËû«>!¬Õ+üÑãwšøjyÐøiBWz“ÎÊßÏÒ¹¶ßwþÍÞŸŒ”dàúYÍ:Jù—ç³6áá×–aÃzòí·ó‰mJýÃì%Ó(Ç××—ððpÞ{ï=>ûì3|}}ï¹:Ví9žwõå]Ú÷ÍoQiù]J¤ë‡kèñL+·e¹©ýs™é™µœ­bê¶S´ÈLCßyð\V÷êô@D­Ôy>ÃÆ-ì¶—)c*<ýûVZÓÞ¿½ê/¶«`·ï§ëð-g»<3ò–YP=•”Yí®äÜ9µ¤—[æh¶3Ëü°Ú$™>$2H2vN­²,“žžîpöTQ.s†52œ«1Í|‰MMÙýDÍ1¢ÿŒÃ§§Îéqoÿý¯öþm?ÞÊÃjiyœþ˜6ÿÚoróÄœŒ¹Æµ¨«\¸p‘‹/ 1Ýdp¿%ì[þú58DoK¯y7øõšùyË1ÆÇòå˳÷íÛ·Xâ(éw·w°xïÖþ•JšáÇߎs3ØP ‰À¾ å±Éú]ªT)æÍ›€ÑhÌÿÅAþ›;‘ËÆ·Ú£„¹º³JÏÓ¯ã颔åÂïáØ„´RyÒµï›t}Ðf×Ê6¦CçûÔn×÷Úå/oÔº­"=gä-Ó•z¶Ì¢hw%çîȩս,YTT”­¡±>‹³mÉvŽ$·SkÖ}o4ñðð(š\6f•uÓèõêXþý]`ò®?(ïëÍåuáœ~„†Ì|~þ6­ž¨è° ÙœÄöåÓ1qß çË>umäS,-ë5áJR0…®=|­X™‡jÕ¦v­Ú¼ød7Æ~¢ãå§_fÖ©î¼ß¸4×÷~À›ŸŸdPøž¸×gßz}1ŸHôo[ÉûýƒwÅ'èÐ8HñÀ”Åøñã9þ<à±ÇcüøñŇDI¿ÓÊ5hÑÂz D§íæhj-ZXÎ|ý€¤ÃÓÓZ½O½¹}H”~âò[¬NçÐÄl¿yã—܉\6 ŒÈ<÷¢±±±xè=ñÈ R$Éf)Çd2qëÖ-´ZMYnù ÒQ½zuµÎ'—nŸ›ÃË“÷1eÝzUµN%œÝÆ[#?$Ã"ö:«Ù/'˜=–w|G\УŒ ßÅ 6•í«  â›á$”¥|ùò” öuèÇ»züÇÔ °1†$âââȰÜß)ÏãCª þãk&þa/«Øi©AâY¦ Õ«•)tG çÿþïÿ˜?>>>>Åb.ö;Wmºt±ú½6Ÿu‰­èÒÅêw’tù0‰—ÇS»öL©)È­ñ%2¨sÞW‹ºŸ¸z}ïU\1F,‹âòAÉ¥jÕª˜ÍfâââÑ{è³§IddÉú?ƒØØXT*¤¥¦Ø?»•T@­-Çž={ ÜÏ¿æöþ?*äòῚs#nò_œDÕÊŽsÚÔhQ•5ÖÒûéÆNs°Ô|êÉëðè ~ÙÿÚf6{ÚÜÿdûG µØ8 à8¾¾¾¬\¹òŽ—«ýÎy!zÊ×ÎÁŸ^ȱÚÓÎÒ¦ÛÂbë'J¯oI0H”Dj‰@pQ©R%, 7oÞ$I•„··7Þ^Þ¨T*RÒÓINI&##///‚‚‚p|ß»ìCR£F+uႽÃK;¿4>”+“ÿñ|ê½FOÀ˜ž†Q´u‰Æ]¿ ¥ý.{F¨× ÖXrü”4A#ع>o½*ñ˦ɇ$ÒÓÓí|GÜ5,òê—ÉÁåK8šœó•F_AýºlÔÏšÊÞ„œ,ªÏj|0¶¯[²Ü¬ž>™ä–ÔÒ:sæNú’ŽlN`ÞÇÙþÇ|«6cÔÔ÷y$;p]NÚûšO¾Äôñ}lœ>es+fΡÜÀQt° &æ\Ïy}—鼞ÊÊt§Ý‹þÜéåÈæ‡Ï·Ñ2›Í¨ÕjªW¯NõêÕ]n÷‹/*÷!ÉëÈ"Æ…+¸ëCâ~¿óD¤Zt¼>$ùÅ$qg†¤¸|H~[½œ[Ýú–J­sÍ'è‡93‰é;’f¾ºLCÆÓmYvŸÞ>’þÐðÓnVƒ$3 ý­W&ðÉÍ9ñmžSqñ§·ˆþ5·k#–…aΧ½8µf,Ÿˆáúqë gM{_s‡³vpºhå§1õH¹þ ÝÚåÐ¥D†tf3(;Ós†³2ÕSQ™n´{qœ»3½Ü2G÷â¥K— ÕæÕªU³¹¯Ýó!’ÁžE&0¢yµ÷†u©í×4ô%Câ~ÞÛ›ÂÅ[oSV§¢Y½ŒžW‹ý‰³iQJg“ö¾ÑÚ>To; Æ|—9CÁ³÷ {µ™]¹ÎôœÏ:8.³ z**Óv/Žsw¦—[WlýA$adœRŸÈ½ìCg’)­U!›S°¨¼qu|1YѪ‘M‰˜Õ¥l|Ù”ÊvŒéŠ¡ÿwtO‘m¸“†¾ä÷­$FŽžFÙÌH¢’Ê >j SÚY›´÷¥ª %-îaÎef®õ)?ˆÞåaUž2 ÒsF~e:«gAäW¦;íîι;ŠÔêL¯mdʼn¢8$!“³gÏZGô©ûà-Ö`(0Ia ’¼zÅåCk4³oéT¾Ø{„+·dLZÄk-˹4CòË´áŒþ9’ ×,Œ ߯¨NÝ’%]^Aßu!œþ·%ç$?.Ê4ô%½G&}˜ó{ÏŒ^4žD˜·–ô8Û´÷j}FEµ2™NæýgF3dý_j»(ÓЗD¶LéI¿¥žüzl8fƒ}Ú{?Šk³Órœé%ü;ž6/þl§Óéûߘ\ÅOQ=Ý-³(ÛÝ•kæ(R«3=3¶²‚îU³ÙÌŽ;¸yó&‘‘‘´oß>ßáC"Ãõ9·ßvnGíeÍ âWóyº—šÅª›©Œ*ïÖ‡p`X?¼ÇœèdfTõS$9MAos¨²…˜˜âRM˜’b¹—Apf>¯¢LC_ÒØ8®3CwW`Ïñ•ÔΜuPë󦽷k´PUï|Ør¦ç0˜ððžv:þ!>Šëéâ^™EÙî®\3G‘Zé©É+ËY–Ù³g7oÞ´ÞGQQ©îg“ö~ÛŒ­ô ?áR¹Jõ”ÖS ÅÕî»#§Ö‚ôrˆõæôøÑÑÑv†GA÷uÖ¿RTT” pôèQ6l(ž|àžÂѳ)kÛµk× x³5¹ù{þºšLÕúèøDÃ×ÁëÖ­ –t¶._¡K‰ÔnÚŠÏ´ÊÑS*Ë=Àý½Ÿ3ža4«â“ý¾93 }Å:MèÓ«Óñ•MZÌa"Ûǵ(óXkÍL9rf»5íýC?Ï‹íì}šŽìÜoó'í¾ )HÏyËt¥ž…-³(Ú]ɹSN°sßuʵlm÷•3½,Ù ƒ²·]¹r…°°0EÑ.^¼HPPÍý- @pÿ$ ¨[·®¸èA>äŒVÔ‰ð!÷þ›´Â8$ øïEwË>$ Ä 4‰@ (Þ{ñÈ‘#….ãÈ‘#øûû‹8$@ І¦M›ÚGcµX0šL ŒF#£“ɈÙdÂd6c6[HKK±+K$à¾æÌÖ•¬ø%’tŸ¼6ja'ÚÛ>k*{2r”žÕø`l_·d¹Y=}2É-Z³ýâ^ú’ŽlN`ÞÇÙþÇ|«6cÔÔ÷yÄ/ëK¨œ´÷5Ÿ|‰éãûØ8 Ëæ$VÌœC¹£l2Þ¤ç¼>ŽËt^OeeºÓîEîÎôrdËÖ,+¶¾ |HÁ=R’[GóæW3îƒAÄý1—á¯ÆîM ÔûaÎLbúŽÌþDX£÷t[–EÔö‘ôŸ°€†Ÿv³$n¤¡¿˜ÛµËB‡0çÓ^œZ3–ŽOÄpýø|À6íýÚÁ}è¢}”ŸÆÔ åú7tk7–C—Ò}˜Í ìLÏÎÊtVOEeºÑîÅqîÎôrË\¹ï,€]4)óÏzò6÷°ð!%¥>$k&¬¤ß‚-t¬ä‹¥éçü=ói&* ÉÚ ƒ™—†¤G°g‘É̆h^í½†a]*dgûu' }IǸŸ÷ö¦pñÖÛ”Õ©hVo£çÕbâlZ”ÒÙ¤½o´¶ÕÛN‚1ßeÎdðÆì=è^µKîLÏù¬ƒã2 ª§¢2Ýh÷â8wgz¹e¹¿²)ªûÚe’Í›7‹§a ¥k×®â"XÌWˆ¸]šÈÌ$b*M S¦MsI7Æd!D«F6%bV—B#¹/Ø1¦+†þßÑ=iD¶AâNú’ŽÅ’ÄÈÑÓ(›ITRy`AÂG-aJ;k“ö¾T•¡¤Å=̹Ì̵>åÑ»<¬ÊSfAzÎȯLgõ,ˆüÊt§ÝÝ9wG‘ZéU㢬pdM‹XrÍ‹€„ãstɇ$k`Ëv<ïŸÅbOÀ»HÞöصk—¸(‚CòÔÞ¸°u ‹Ìù½gF/O"Ì[KzœmÚ{µ¾ ž*‰³¦4ezJëé.EÙ»£H­Îô*a+sÆ!C˜?ß~ëõ×ß`òäÉÙfˆ,9Îiã’IZZZö@—wðËý[pw ’¼m!|‚÷ J|HÌéÿ’‘ɇ¿÷fò¸¸ºg }züÎ/?M뀷Ð8“…ø°!œ²¸K©ÑúizD£¢‡Z™L'óþ3£²þ/5Ž] ‹2 }IdË”žô[êɯdž[ÛÏ`›öÀO£âšÁyrDgz ÿŽ§Í‹?Ûétúþ7&WñSTOwË,ÊvwåšùVÏÆý)WÉ×%=3¶2g÷Ýÿþ÷?¢¢¢Ø´iSö¶Î;3eÊTddäl“D²)«P>$z½Þn6ÄÑ,‰àÞ™!qÖžAIC‰‰JãÅÇ—ã{¢SQã•Oh±ôqVßHc@9/§Ç‹º…ÆÇú ëÇÀ€÷˜ÌŒª~Šdƒ"²)èmU¶C\ª SR,·â2Îüê§(ÓЗ46ŽëÌÐÝØs|%µ3gÔú¼iï-Ä-TÕ;Ÿåp¦ç0˜ððžv:þ!>Šëéâ^™EÙî®\3­w:„¹¬§ÆVæl\Q«ÕDDDЦM~ÿýwš4iÂ×K–¢V«1›ŒHYvBž1ªPqH\1F„AroÌäýàAEã]IíEmÎŒDM/ ShZKb©ê„øÜ{1åò$‡Dp¿ 4Éð_âå~ïr½ç#Z· ÏŽãy¢€Ï4=üZóE'?ºty…ÁÏ6ædÄlB„ÓÖÏP*ËŸâJC_H¸2 édŒêE‡\Û›Ï_Ë'ÕýlÒÞo›±•~á'\*W©žÒz*¡¸Ú½ swäÔZ^nYÿ—û»:"å²@T ™sâHŽ}H Ìö»yófºtéb·Ts~Ù0Þ^ûOöØàÓ¥L¨HÂù¹¼ÿå霋^u(Sß­S`ÕÉR¿ñË?}»h‘XÌ·9vü_6|ÔNv)b{JµÃxôw{ºo”¤Åìâ„¥ÍB¼µÉFŒhÑæ™ÝJùoǽÑ"HŸïlUdd¤øìWp_àn¶ßèÿñó¡s=ô(]Û7/ð…§nݺ`Igëò%º”Hí¦­èñL«=¥²ÜÜßû9ãF³*>Ùoà/±†fÌa"Ûǵ(óXkõµ.d¥½èñçy±]-»}ìÜoó'í¾ )HÏyËt¥ž…-³(Ú]ɹSN°sßuʵlm÷•3½,Ù ƒ²·]¹r… Ø…Ž·X,˜Ì&Œ#Fƒ ƒÑˆÙdÄ”:ÞLZZª]¶_ʼn)5„4Söv¯>j‰˜Cx~j¦½S‡¸S³˜±ó-ö~û¤M™‰çw±ãd¼Í6SÆe>œ¸€IS¦Ú}»P¿-OÕ°·¯ÛÇžc'ùûÌ9¤€J<üp=žéÒ/7‚ ¥ÇÿJƒ–£ùûôq;Ùþ7‡Pû«¯0Í/U'ѧŒ—[7£Ùp¡_áÕ ?ÓÊ?§AÿÚ2—ËáÌ™‹$™5„ÔhDÏ7F2ø9kÔ¼ô[Ûhßk ~žEp.}a„Aâ>uëÖ] ȇÜÑœ$&ƒ£Ñ„ÑhÄd6a2™0›L˜-ÒRSì E¯øéñ[éôüt»í­ÛBù+©øÕiB«V ¹&…ÃÎ̊Ǩ`*½¶ë+&­*G÷¡6ú}ûöåü™¿m¶Em]Ë­Aõm ÙœÈê©£˜÷§DÏgš³vË~¾œô(;·ÎdæÒ|¹`ÍËyfúQôxy„ÓóyyÑ*º´ngÁ¯W{¾ž>U©6ŒjæåvÚ2€kÏ̲1FV¿×“É[.Ó{܇Œý¬!žIÿ°{×f>׃¿b×ñUÿºèƒÛóù“³éÿÅŸlÛHÜ!@ ¸§°:©æD‹—‘rœHê(ò!‘<Ÿ`ݺ¦v>$^z‰õÿR®_ Õ"2É ›ÉHùNOôâøÑ]ÖÙ‹ŒOÅîŒݲÀ“Š<¶•f#Fc¦g¼ldfŸÎª9˜ŸW÷‚Û?²li{žz¦—õoA?†¾ü‘¿LA+,{óÚk¯å[þ¢ ïs=%c)kГÑê–u7ƒwGz hVk]¯*]ÿi^ðªÈ±wû0þïüãâ?2…O:¿H§ºÁÙºÿý8’o¯7eDô*‰„”CøTî˜-o?t1ëW5çƒ?ßef³²€?ݺuË÷ë?ýµV›­oÖZ'’.eõÊ•DlØEpƒöt1‹E£”ºh\n1¸7MrfZVLÞI`1 kXÆnÿVï¬bG®p»Ú §èîŸÊì·™Û¢œA"âî7ò‹CR}¼(su÷ó½X©R¥"-S±WfÍþ‹øµ¯9ÛPQit^ô/„GPSo}cª3™U Ÿ!ñÎ#³uË´èÏÛ-ÀØm«Öóc,O´~–;÷”7@¥õ#Я15rwåôtžó+úÌH‹7#/Q®]ùœi"•ž×ñÉÑЬ¬¢s“-´ðÝ^x…[§R¯¼O>û¥³{ÏÁB•ýpË'(«Uqjáʶ’S–9™57Ry¸ÏãN&ÀléÜ4˜wœLƒD ‚’Šbƒäìâô[~>ûwÓ9ëé“Ìúφ°>Ͼþ YþD û!VwƒËŽðÁ[¯bÉ\ &X›ß,„™oo¦²¸ZŽ?ÉŽUÿ¶ÈÖð(õP)&(¾(’JÇ¡(È7ÖbŠgüøñ…*{â;hï¯çôõ4z䜙á*&‹L`£@—Ë lHê’³ÀS¢'  d$JãTë·˜oØú¤ø¼EÇɃÙRk,?mM(uráÛ„ë8ô¹ˆ¿¸”6”fì#–Lù‡£Þ±ùì·Tåþ|8¬væ,B²ŠúV‹ñ&Kãʲ=DoSþÕ·jà’Ÿ‡,ƒÙ˜ã£bõ!‘°˜Œ˜.P V”ÄÎh4r)Ý„¾Œ6û¸)•$qûd,ƺ®}×®-§Ç”~)» áC"¸_Éχ$55U\àâååUl÷·B™å]g^’½JÂbJÆ»Ñ6ÎhLŸ93YþÔxRü@ýŒÝ Þ¯æ«=­³}4rs>ü¥[|†V«Å‚UÞ¦c'Jåúî×Ã?$GWLE¸d’¨ã¥áò–‰vø_]®™†(æž¿MÓ ÓΦpèC⊮;„z¨9oÎun¥é¨'rÃ>´½3o”±‰Ib‰7¢Ö…f—!|H÷+ùùܺu‹úõë+*3:ê17n°që1ì»ÌíØtÌf *•*3¤„Z-Qº¬­ž¬B‡6õ)[6X4†àŽ"Ë2éé餧§c2™Ðh4øù !ª¨Ì¨¨¬Ïå­c…„”™W²¾¥KþE&.6–   b»¿]Z²q”¿ÆœL÷•»y;Ô›èÈ7èaÍ&¨õiĪÏZÓí¹¡Ô7ÿI¯~rÿÞbŽçãQÜP}Ìá±ßÑ0ÓèjÝ¡ƒ“%x³~Ÿ®>Bø >Œ›z„Á[çä4œ9‘åãûq-äÆ×µ.}“°dÅ¡üÆ`²5PTZM$™e|ÕÅ™¨–Žg“ Kζ!cZ°ñ½,Øß™7[„Øìÿ÷·£é½ð¿üº<;öHÂß xÔ²1FŠ*r®@PRÖ—.]*”^µjÕHHJæûMG9yÌÀ°aÏS§^t: *• “lA’%RS28vä"K¿þ›·~ç•Í )-.¼àŽöqOOO<<<°X,ÄÆÆ{ëŠû¾F£vë~+. \/û/ïy®7ó$Uy‚’VpT¦E\¹ŒK汯‘PáuÖÿŸ‘Ïä½OGÚ+?:ÏœÄöoñØ—)4±œgƒ<ˆÿ÷${öícóŠ%ü]ª5KW¿“]†Épƒ“'Oæ[^ŠÉö˜ZïF”ÕÂk£?¥SÝòèuZ ©IÄÇÅO||cç,¦²^íÖ…¯÷je¢¿9Œ<2'ŠmÅnsµ·'_ èÌ#ÆòÌcð7D±oïNþ·x /!H-e×õÀΪ ¯í0ñ¡@ pÎå+·9v4ƒ6ÝêP1€¨ÛÉX,fT*’,$c‘-„>\Ž6Ýê³çç¿9Zó*¥ƒüÑê´â î’$!IRæÌL``±±±ÄÅÅQ¡Be¿:sü’ræI¬s ’,[“àenÌú-QüãŠK>$ééév9lL²Läìi$ùhIþñ—ö3kêd¶^ àÝ9iíw3ÆÐ:¼ ÝŸíFÛã¯Qqëð2.¹È;?,¤|o–f,áã÷ûðþ»c òÇC§C£³É„ÁA¿Ñã(£U¡*ÕœYk~åBŒ‰!Þ ®lÿ’åû|èÜïS>ïú$ž*0¬‰ƒTÞm˜9³M¾`î¸ÑTT[²÷"¾žÎw¿åÒß'I5˜Ðè<ñöñƯtyB«ÖDo1b0˜ÝºðeÚô%uê¢RzP:׌PŸOWÖl.sÖ¬bø¼I¤št”¯QŸ·¾ˆàÕ6g×Ó’q•e1Lm„Á`p˜`Oøî”Ä!‘e™Ã‡Ó¤I‡òí;þÆèï¾´7±‰)h4Ö¥µJ…ÙlF£Ö`¶X0˜Lx–óB.Ä_ÇãhÔ ‰r¢QwÅ8ñðð €ëׯ+îûê<3$20qÂ&L˜ˆ*ÓX‘Éûmgñ+…ò!Ñétv3$jI¢b“æ´ðZÐÙ/”!½zR®ç(~û"~j ¨Ì´em9µ}%³¿ÞËë½:£VIßú#'Dг²õk™:ݳæ™W9²wçÿ½Ê­øÛ¤¦H7ÊH’ }©„ès½‘¨½¨•Ë0¬ûú¾}]Ù…1}¦Ý¶Ò :2´AÇbíX^Axÿ‘Ϙ¸ã: ºT´‘5|nËž– 2Ðᡲ_:ºòãD<›O¤U€§ÃY,gí)”4òó!ɳÙLdd$—/_¦[·nCÌÿ+¡-ç‡Áh&15oO=zIj´ÖðÖ©é˜ešRüw=ޏøtBÄ—ö‚»ˆ^¯G§Ó)îûMÞ>™%K–píÚuæÍ›^ï‘Ë$‘l ’âW åCâhɦ÷æÝ¼¬õ@CζƿìFã›ã`™E¶¯²°mNYí'®¥=*ۥɛF­:ШUþu¸ßèöÅÇ,{vÑí¾!ÄQJkI‡ÎÁ¹›3.3fN“ìh73"–l:éééüöÛoܼy€   ‡åT­ïñIhÕ*2LLæ4¬~sµ‘a">9 ŸR:’oëHË0b±d†Á–@–­ìÜ¿%ddîÓìx’ècÅ~‰ekÿ‘$Ùê`-e.¥é€Š5Ò©Ò¾¯Õ8úüq /¾xÕ«# Ì<šä`¶¤xPdX,T:ëÊ=kâ£qq0”1hêü[²tê ~»’Ä”çwYoÏ·£iÿÅbûh…A"äaïÞ½ÙdgTô'È_…¯·µFF­B§Vƒ d‹„¤’0™ÍHZ_O-¡þfnZððÖgÞcrÖ9oÙ¿åû÷ '/wä"ËÖ{æ¿9=*ë_O½§â¾¯³óÊ17>ÌСCX¿~ #I² ª;pÖ.ùdù(d#y@k…E/UBP³A¼¼TÈ|o`šsd4ÔžAI£0>$?þ8ûöíãêÕ«ÅR‹,c±˜E£îŽ!(eõC‹â¾Ÿ*¬i³¦,[¶,s9{þ@*Æq¥P>$Æñ—6â­üÞé«Â‡DpS½^O›6m8|ø0§OŸÎ·ÌjeeôÞžøúxá¥×¡Ó¨Q©T¨$0[¬/Zf‹Q‹J¥Æ‚ OÕm¼ôRæË@Þ™^)Ϩ!ž‰¥HöHž¾æ(( «}_—iä5ižþyV¬Xátì¸'}H„Arï$â³_ óq-I4mÚ__ß|÷)ë#aööÆÇÇO ^:-*µµZ•=ûh0š0˜Ì¨4Z,²_RðÖI™3Å Ü=ƒ$%%EqßG•™/.צ·Þz‹™3g¢R©îÚY»dìܹSô@PâŒôÚµkëPÞ°VNǘñóöÄÃÃêC¢VYc>XT ©$´Z:“ŒVcÆdHÃKO].ƒ„|aß@ý@ô^û~”kéÄh4`2™÷}G|ùå—wý¬ ô!i×®¸J(‡Dp?÷eWû·£¯ ªÂÙ¡óÂÃC…V+jTXP2‹„ÊdB–MH‰Ñ”/ëƒZ­Âb¶ˆ Á™ ±~Ä•¶ Lf )ÉI+îû÷Ú¸R(@ ¸›6‰+T(J£š8x<’ÒÕkQ¹ZU4ZuvDL$HNH"úò¿Ü¼|ê!e Ì™‘óÌŒäþ-ß©%®Í6”Ä*gZ%–̹ÉêPš’‚¿¿?UªT¹gîÅ¢*S#:«@ (É9rD‘Îc=Fƒ˹“‡9¿w»Ígô`ýÁßߟ:U«Q¶läì/d'ž\rBÁ=gHÉ2˜LFdYF£ÑP¦LªW¯À÷ý{a‚ÒÌ܇ÀÏÏ/ßÛ¹ÉI/!ÜL&ñññÙ}×ݾÏ$®Ä!‚»I~>$¥K‹Ì»Áݾ‹ªL’3gOº\@þ_–æY7•óÙNAÛÀŠ£ukWžWŽŸS’‹Ï'ñlîäý-EEE‰…N@ w•¸@ î6á7"à®$"öˆ@ ‚»X²@p×ùV"ÎlžoKpIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axispos.png0000644000175000017500000010232113070106167016571 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu@YÀÏÄKº‘–0QA±±];1XW]×µv-µkíüÄ@Q×εamÄÀƒi¥ëõÌ÷Ç<x<Š…÷÷‡òî=sçœ{gÎ9s‹‹‹@Ô$ÇûÚ: DÿÚ D]9V¨eH@ðµu@ ˆ:б"D-C~mB†MÓ8Ž•ˆ_Åd>}‘ðµ•*G3gûŽf:|¹Å0Œ¦iùß©©©_O1P ã§hG§‹Ä4›ÍÅ 6A4M3>÷kÁ( “É(™X"ñ¸X³Ææd0f«²¯€ŒŒŒ˜˜˜/ªìç¤Aƒæææ,K"‘ŽãE)r뀱uÞ@ø1l¬u¯B*X„aEÁÓWXl-¾–Ž‘‘‘â¶‚¿úò(4ÉÎÎ.).”ˆ‹]ãJÞ^þÄZÚ9Ðïß¿/**âr¹,ë[èÔPöÔ­VC™L&‘H„B!‡Ã133c±Xß‘±ŒuØ@ø1lÔ ¯g†ï®BªmåÊÉ(úîÃw,¶–ž¾¡™™†a ¿…'V…2™™™ùy9bQQ»Vv ½ÊB4MçææÒ4M’ä7Õ9| Ê‹T*‹Å\.·Î[ç „ÃÆQ÷*D¥E Éùï³DÚ:zÆÆÆMìY±É´“5óŽn`ó•ÿUÖäæýôÜÜÜ¢Â|3ncGS¹E ÇÏår LLL¾ÎA öð C>|ø››[RRâèè˜ð]«ÉÓÜwm ü6jBžX¿» ©¶•+[ùøC£FY,I’¾>—®ÇS=£ EQ=;9 #‘H^¼x1~D{&W>ŽU H$>Ÿã8†a$I*ú¨ýŽPX!•JqÇq\&“½}û¶Î[ç „ÃÆñò£Ò"©TÆ<†Su.ü “õµ5-Ô¾p5¸\.(¦ÈDZ¾xñ‚ ˆ’’’·oß2mSëMR£>¹¦ÅVU¦¢cÁqœ /^8;;Vc5y «­Òê€ÕøUl¬JI5z~±³|á ©­æVSNe‹>(FÙûxX†ßN"‚9V&ŒM-¨gcªý‰ú| 4MËd2Ç;µµ¾~WþÞ¯PX>+''ÇÞÞž1ŒástŠ“Ú½.)ŠR_¦âk)ŽãLÇ¢è +[”–üLbÚÖ–£|xAF¾ÌD×€PQþ“» z-ê×çȳ$%7¢¹]ZéWV)?1­Äܼ¯¬V%%a/Èž­«5©75-¢¹MÖ³·qf–f,a^ŽHÇ@‡ *}ŠðMÚ¨W©Å)Jz9"Ù×ËNѲ¯_½¯×À¤²¤2´Tp)2Õ·½£†½†·É¨åsÕÊm«¾œÊ±X,&ývT&ÁÈ$OY²øè ù{÷ó¥þ†5¡­*—yqjcE™¸H„óù$NÓ%%B¶ŠèÆ{BÖ+Ë ß‡½¤Û¹™ñ«2¡$õz4Ï£•!—y¬€[2*WuÙ…¯eZEÑ9hBÖ³W Û®M«Ô¦Öå§ÅRf΄"E*£I¥ë[Ë6qÕ!‹²ñU›š&0íÒ¸œ!W\,ú­ï0Ve5"Ã_9¹5jZ:B¸¨ íÔ ã¾,*ˆÑ”xåþG.“û6â*SÅGf·ÄWQi•­«ÌG(d?KUU ®ƒ¹#·Ê[‘.H>oÒi¤Þë+ÿ{g¼á·ZJ²µc MI'•.º¯n#¿T¶(-zõyÞÂñõŽ]ŽЭQ@ÐùQó{7áÒ›Üýsùåî¤2Aá‘ Ñ}»¹²ª¾Ÿ4iqøØ«ú³"~X½ïÕü‰Þ*s«µK½E$I2ÃÈÚ43|ð<˜Üc§;‡¶bœ/°h‰HÅOeŠßŵÚ=ÃJ7z•ÇÚúÿÛ3¤A#Vürtogqþ•Ý7+E‰S掛3äÄ#.—½²Ïüëï#8&õ¬Û3¥™µ6艗Žüýà¹C#IR¡›òX7P^+@Ñ9$ A OÝÈ« ¨®c¦ZŸ\xõ ¯}O– ×SM^O"£›×7!±ýKOäþÒçwSvJZ¼qýƒžób±J&ºx:òÔÝ´œºž•±k‹&}­€âÓ[ÿ¾·n¡·!‹`:墊ÆâØ®c 0¹$Gúf¿ˆ ¾ýZZ°p 0ÀIKɺ”ë×WÞÈ€ìÕ–Ë×p…bAÞ‡ËãÀªCǹ>zP\”w'·‘ÇP+ñÑ‚ámMo-:,ãèpoÆr K¸nÝ7 6ªl]ìñ+랆á<>ÇÚÚ´sgSV $Š¢ŠS£ÿÞWâá¬W¹Î“_$™ý1d¾Rç±÷d”²€¨@òáEô®cÚ–zBVϵ٠gþ'ȤÄ>xzí]bJ^ …×3íÞ¥ÅÀ6Æß„.͹ð@×Â>ãõ¿ODý°Â„¨,“&Ít9¢ÂxÎsÑåTp«yqI2ÅŠŸ”$nÝ«<ÎQËܺ­·ªoн󌶺 áÂÌ»ó‚ ¶,èVÓ )*HUÝn<-®/ÏõèA£Ž|P{ÛÒ"ÉÓW,U÷¾Ê+Y™óûÙªµˆ Æy=~UĤà8.Ê¿x¥Øì–äùÓûLbB®H ¯Ÿ?•_NCç&õåµG`peÖ€lB’”ÂûÙÿ_žLø:/ù­ÿh}åa˜SW ÷–Èì³ßÛX¤9)9¢®»¶ûL˜™xõèÒ ýn¹þ°­ù€•–MÝud¶'sÔ£—…8ŽK¥R¨c¥ÎJ»+H”+B˜•tâzÎO›{”«Y™èäÉ CnÕÏ5bÛ¾ˆY-Zs I‰XDr¸\N'ûÏf{tõ4Ò€GûÏí»Çž=s@3".&å»nŠ}× ±ârÌiötñ¹ü-ƒM™¶¥AÔ•Œ¥›6°€¢´W"“¦ t@Kšºùp ¼+’JOÝËáÇh¦Ÿ+8úúîòXöûž†s2_U…iaã7šíZáªT;Ô²-ÿ¾•é,_×øNð‘§fÞã¸\>³~šb&·+åÎÙeIlEÏ©lV$(9¬üÍž¦¤ùùwox¿+ôB|ÉOA=L¾)©àÊýßV ²_¦ÈÐ÷jɉx!l¦ ”dÚâ3Š—,bβï=Ýÿθ[Ù 9Ð×õCN™[ùðäMbcÓNMõU¶xžTëö¡+=Ú o®%÷"\”‘UÌårkZ!A ŽÅ Ë=I1X¸wÙý«}…ĬG1)›—>¥§¦åo9ù¨g‡¹œÔ„:p) J?ÝT ¢]¢zóÆ•;i}mžŽž:‹´h¬­ð­‰‡—i[Ì'¶oÞVšïh§·o>Íü0i³jÙdg %qq±žÛÿóT*'dlîªó ÍÊ‚³q±/ë;6!0 žÍ>ž´ñnÙ•ƒ³,š:»@ÛöûÅ·¶Þx ¦íïÍšM_õ¶Ý¨·¿¿±ã’àÖDçÉkyãVŒ±‚Rç x}`6™6¶‰²y'ƒBâ½Û(ûxøðúZ¶ ö¯ÿwùjåê6ø{†KÅÊÖ1Ek³X$‰ãAT8T”µâV᢭æ$IÀ©ûùöýù40€Vm šÚé¾×µb²\·K™ž>h”5 ‡ÒžéX*kš”~>_Z”.È2<ËckY{8åÞ}£õ×›¨7o‹=yqŠ¿=ÞMY ƒÓëÎ*žXii!@½ /òÿ48ÕòÐ4[Ãnm>÷²ôõHR’OºËͬ`ÁÒmì(Ÿ0çéÞðù„‡ïyõ4ª©8Ž“^A=y.I–eш%”˜Â€äšú¶51|ùø˜-nZ4þψu››”¾´Š™Ã·Þy?váø‘öÌ©g×ÀÎ /\óø…¬wWöMØH^T"Ö²Ö{qéMÉ2E,3RZ,€”¨<ëÎÿêb *Œý}Ãû Ú™qY$N®“FTœæ¨àynÒ¬Êçéµgv}åÚÇG{0WIb#_£ Ù²í—ÊOš/v^/âW®¢w—î‡[Û»ëÊ_;ŽècisgÎîë¿—hïg­K»}ã6»ÅÖòGBŠ  ri*®dŽAÛ–½¹z‹(¼ªTð|úÖg˜µG¿WpH×·/ìš6’·§¬0ôèùþC†2!oJV°o÷åB(iæ…Î\ïi ^V–¯Á",’âwÁI¢¿f•K¥©ý!I-‡ùô6å@QZԖˆsÇÙÉVñ:¦I(@  Uõ³oö«»R=gžü®­ÇÆã&I|˜W¾™­]©$K˦‡¶dwlÉÂ&Õ=L{œ`ãß×)6÷ƒÐeh+Ù´µ©} ’màÖÔê›(p²lÁÏx[ùÀþ3ú47FAú•Ÿ7V4“oæ´aRê˜õ/æ¯è±ïpÒÄá¶à=­ïSù]jÄ™¥Éª­SP:ÊO&¦Á؈õ2”dEõŸô¸rºX n©ôS"|a!• ¤ ÈzuæE ß¶&®#=—Ì{°ïÒ»†Cú›˜ÂÆO1ðø¾D=Û¶¥^UNóý €oÁFF'µ†õv{x1,¼d?ˆ¾“ЬkËÞ^Ú“YÍ0µ®§/Îãé9Z×3`äõìž6üò’Oþò³¹¸³®â3«Â´ŠÆ<½ó25«$Ww¡„à”;}ùÿ”9·å|Dé›’L’˜EåÚ{ó$£åà®,þ‰çß Ñç—êZ”Vò’+XÈ$…¯ãßÓ2Y^nîÍÿˆ¬ç¸ë*j` †aÆ7nuf²{‘2}g‚’Î2Q&É·Ö³¼½9SÃ0¯ž³,ìßÂÆg;@è¿1£ú4À?Á@šŸË•8t·Qÿå«ÛH ߯[w9F«á–_õ»÷lòî÷„Ÿ"¢3¥˜ì|梓]`ÐØPQ²uÇv¿@ÿN¥§¦)É«Q.%·û©ý¨vff¿”fUnqš’°´Vµš²ïìóV£\ùs›\£W¨JR–/™_ŸaXAJØØeïYRHºèŸ8ð \.oÍ$ê×oÈ|kgŠÊxð_ nûw Ý2}1 €>¹õè+‡qƒ<:6Ô©Ê.JRü*.Sq:®Q}#R½EŠSlqúÀ¶“ó³Îì¼}åðŸF”e›Øíù¸ 2ÇšQ¢?´ÜS£8ÿüòE锸è}Ú«ˆÈ'º/^ímÅd¶4.ÙùÃzÐ4­ˆ€Ê«²1•[åÃÓ[ŸJ6lwTN,HŽþ}÷;ÿ¿Æ°KÃò… Bm¾² -®ÝuªcÚê±íY8HDY8É3gã€)i%)ÉX~ºð¯N±9R½N<Å) š‡®1?zæÑ±]çBä5¶£¥¢Xƒ<Áùl ³«`cec i놱™±Âú]ZÊ.Gebˆ)'/‹_ ¤Â/p¶@.LSrKäUOÓ]Çwë­_:* ãêïÁ’¬\yEhK Þ ˜q•ÂI\|jÖS[§¦œõgsVMìa ¢`þÊÓ#~ïãÙ¶^>‡Q£‚u`¢Â¸Í¡©´Lœ–žO˜ÙNænÂ*ë=47P‘ Ò‹•“È~–ÄÓu¾^±?-÷yVC½·Ÿ­ÙsßÐ˳Ýë‡ÇÍ'·§\z7¦oCQþÇ(“JiÐoXvÁHÿ=Èeþ¶poàÊ'¾q®qã¶çt´N¹qÅØÅ™äè™<èõ£/ÆôM<!ûèÈB›Q:jº‡ßf†MÝ‚–¶¨ø¡KE‹Ó´ Ã0'ß>½¯î^ò÷£ã [ãD9£jT!Nwî ׬¥·. zV]Žn–??_zì Ö:pÄÜzp•¶HŠRfÿ/Ñ{êh¶Òg8 Ãðí›GÚûߊeûÿõj5sŒ»5Wu%Ç.Ýš¤8ЦK4´¨YCþ³W¯kàÖ–Mág¬Ô´Ÿ=ÌÿÚþÛeéçZÍR¡9†a”¤ذæ‚rrJè'¥KJù–ÚJ¡k^Ï#¸®ž=Çú´p4TË·Ò’‰â”ucþVcU|ŒÃ0LùÛœ¸0uÞ¦ç<À#Ÿº¶-sê\mÎc‡ v($pûaQý_ô ‚P*VïÔy÷¬ÉÈgJ˜ÆâY2%``8A½kÕ…»A¤H(žGùZ¦ã&Xøù^:±iÏ©7ÃV0“g™±dâ|f) …™ªÅ =é=þ^,g¿N¤Ãš’Êh ”Œ’Ê( 0‚ (qáê`¦« _ËÞºþ²´“¤) ;jÙŽtæù}ÖŸ?Y69±µ>K‹·}Ê6«IlSrЍ´ÓOD`Üȸ›©kŸ~1Ín¬·PÁ:¾‘ûŽe.€ýîÕ›…«ß8duŸšˆã8މ Öí.ª\í1Å2‚Ÿ—–m9”Ñfb7®ѯƒ6Ý­EsGîºUÃþðóqàSÒÆ{ÿwiê¼ÔãFÁÿ1ŽŽAÑ; ѰTinÔódˆºÛº¡c ö×µÑgÜh‚ dâ¼ìì´ãiÑW Ú¹„¿8ßiIW››w¯¬ˆúð,n¨CòÇðó×+.+õ:[2Â^ûéÝ7O•½;4Õ%°Ê-òOOø¯A]ÿûíüʨ¦S­Y€B¦F¢¬†Tø~ÁÙ÷]ÿê[ZA W/ü“i;Ï&é:‡Ååª2Ò4MI‹7.¾ˆ»y´ÒW¾{qÀX\}¿I»¶±|ûÍ¡û'ÛV¶‹gØòðFwPuûWkÑ‹8†a4Íèc•qSîÀqdƒ¼™‡ ÂnÝJk´¾²g € ÇØz]º•ûbtãe$®¸걉èl‰²Âl¿ü:·rm€4GD°­…_ĉ +(s¬ÌKMÓŒ„bІ¨ åÏ?Nkwí±Õ[2*àP2|Vgù]­cî4K)@/.N<™ûõHRµßÔdäsÌÑ3÷®Ì©qÀ˜¯ ÷N¿ŽOlBb`ÎÂÞ” –3Ñz˰ÿÈ>v²}ÓÎ\"‡øËí/¤pR‡±H&“aÆ|m¬ll‹Qˆ*+`éêéþ9Ö$b8Ú~œ/Üx˜ß£Õ`~Þþ‹$Ii¼é¯!ô©íÞQžûµIþâmwNëW÷Þšd²i¶·GÞí'ì>º»ÍÀ(ɇÁïέm$(*H¾qU¯)F°ðsgw4hz  óZÁ:—Šan{W—€'Ÿ‰$TSI’$ Œ`¶jf[¹Ú‹¢ÞH ù‡š¢ÝÚ´ìatwä¬t @SRš qúÅæ£Á8Nb@K)¯?ϵÖb.ú7Ôî®Ëºw3™ìaÊ\ÚÆÍ—Ìlãý6ग़¾š+'Ì·ÑœæÛÛ˜d½¸›hÞü·†Æ¹1÷½ušÚÓTMvžî½î·Sº,yòÀ7%'$gW85ŸÀ^'}–\mK$‰©hq ˜!¨,㆛F<›¸ãüˆeæŠW5­²ÛDZ²cõYÊÎmz#]e=Òž?žq ká†ÑØÚÝŠ:¯@aJü_+/¼"ŽÌhÉ*ç@@FâPúñʺYó­[dP<Õva8cWåÛ¿Z‹š:°_¿•1 ÿôgÔt€0wj6j é¡™ÂÍ*~:‚$ #ئ––6Ê麎eö6ÑåÜ),SÃT€âWylWFáFvÄËI•ãXƒ™ùdŠì‚䄹ý[ìÞ1dL#`o€hØ’ƒ%Â! zYU>Ùñua&mºZ°«tš†)æN¨„’¬½Ÿ?~›’·¦%'ƒOo„Û;p1G>•$‚vòüW·éy¸Y”šo\Ÿ PLËcÏP’$âèš(,R,HQÁXqQÂÉ—Ÿ+IrâÞ Þ˪Ò3/)1øÀõˆ"¼KKâŸÓ÷)iѯmôê·4M?)´G¿Öcú41 ±ˆØbÓ¡<`ë8Xˆ.¿auéå]2fÿ½ÕA†£â Ǜϊâ+Bìc`¦'2õ–š$‰²W T@p»´kTÙ¢Äaq¥c8Ëo²WVô !ßçØßöï¦v kþèï]{YÛT;lÚÖpŒ¥ó)Žñ³½´åúÁ膣œu ô†¦$BªìÇW³‘.}xaétñ´ým×åŽ4ïÕÜpï¿7ÚþâÖµ8Úf„´˜•/¦¹ðq’?Ó¿s…Sß½ú¬ÛŸÞú*{ªhq SÔmƒ>zü·}ÎrÖ´B€’­ÿkÿ¥F[7zãe‰‚ã¡vÜ(úsш¶†¬ÈÊÊPÁÝ÷—í~hêî¾cŠ—n53'ùUÙ °«ÕZ›¬ú‹7×hÄ Y"Š.HXŒOvä©öƒ8¡…ݵ£\L2¸.J1 —±Né»nÃÑùÊÜý/Åaz ‚Ààõ[™Ba1VE{È{ZtöPØÆ31î}ºmÓœy·5kîùÏ\ÉåG„âÁ«‡8(ˆ¾´÷ðîDÃã{œYÕ<®Üêò"(ñæ CЪK/cù@àñ†ýÑ<§];º7(ÓçÒËpÓÙ Ö+ $G>8’þçú«›“źÆc¦ç¥zôE’P:7¡&v•£Z‹œ¬±Ätš p  €AÜžÅg³JÀ€Ç7dÝ?Cjw^·Zþæ>aörC–ü;Í“gü+W©Òþeøµ—`ß¡·#´ëÿGñÂßr`ª ízõíìŒTÎy’‰ö¤ ×÷°#I ip²&bÞÑŒÂ*b¬LÏÀ€a˜Tš:¢hæ’ÉýËOb±l㳺è`1O¾¡iéÊÀà+9Æë6ô7çTÓ£aU·*ÉŽ¹#iú‡»".äÒÂ0‰ß|í7®’¯¶lïQ²ûr6ÕÊ„ÄpŽþªM?ïØvxÿ…eéE$OË«k‡ã3%PâÜC9Ò¥m ˜· å!~Œåh™wñ2€„œ{‹í»x™@QFZaFXç‘ÿIbzêÖŒÜÇqœk´sûЄ qò{p´3™˜À˜¿2³?€Þ¨ öÚ$.ç9ZÔë¬Ï~‚†áÝ—»°uOp¡ëÑ …‚ 0œ`Í^=~Ù{VDÛ¹ê([þ>W«Þœ¿ºvt5cáUÞ¶8޵u›¶ IDATAé|„jì*ÐR¶«¬–ª±pÞfÐJãàêÑe³¥züÑP©L’…FqOï Ôú%~Û ´H¾Ñ€EîSçžOÜ7Àš/¾r® ùÄãþ<ïàŽ† iHH£)ªbà¸Ì±2ƒ¢‹àéÚþ³gœÊrºô\X.áëý«—«a¡U Ñ1oqbc¹ 3½gMè]IŒ¯ßdv£+K# ·øAü6sÈoR„ä•ë_’o\à5ïÝNOŒgb7Š):ÊÆ*Àq +M$Y,sû^ç6Êç8ÈDϺËde¿Üy(CùÀmwº­œbÙ¡Û,o}‚g¼Ý0÷×­Û·éØÌUœriø¼æNîA„AÐú_hB‡À*Zç2aÔÉ UÖXM d±ùVOoh]¹¨}Ó¶Æ‘$#,§;ÿ@¿uýÌcç3LAÒ±óI``mþêÕ±W ìME}§XÙè}’ .|vvòZ&‚Sþ"úº6èlgmÃ#ö/غ+•Ó³[ëóÓ\ù8ýìÁ‡¤£'„Í;Ÿßœ€Î¬e“´W_²æ³¥á>œ§¾ã®S†aÚíõ9„ª L•[|%çÁCþÈ qì3üJ/Rý+|ýîÝþt*ðôZš–íÙlíÕ{“—º£¸ZõfMèZù9´²]«(¡:‹ÇÁÖ KÏ¥i0 l»œ}àÍâóˆÆÕk7òØ|5/å±o×.O¿?Ýt7¯r€rú›ßW¼ßüp(‹2Xc‰é¿Ê÷¼ºyóæ!C8NUÁÚo Q~ÜÉ·vìk^uØA&Î=æØÌ]Ü•Þ}¤R©H$:zôhUÆÒ2©˜&8ŸÖC¨D"’àl–ÚUä(¬ëÙ©±§~ý?a šæcø¸FüÈD%8‡_^]E$_=´P ¢Y^Õ•†-ß^£«G»ÔX´~û¹!C†p8‹UDk™ôð…¬¦ù72¨J çÉúТáÓK#2Èd ‘€HD=ztøOîLºŠë·GÏqç©×ÓE+'ÿ]•ÌÕMÝ:Ï¥ÜZ 4z£*c1‚¬¸0A-ÁâT¿B ƒÂºGç¨Ë‹¿÷~>>Â@5ÍÇðqø9 8•×èÒ°÷Ÿ<óè•ѰÅáÛktõhbWua,˜êbÙÅ´‘Ö—øw®6¡ê܆ígfÏPN1×Ç’?ÐLHDEŒU9.óícêÖaÀµ¢¥åWŒoÙXÆ:õè;´ùÞ Tß| ߯5B“‡ï°Ñ«µ«:‹€Å‡ìbàý7«ˆ–JA\¶œ@Ö @ ˆ/ 34«êñ™ß””ÇX\§Z@ 3ÊÇ”c¬#»jò‘ @ ª9öŠñ¨òP@;ñ™jA „:ØÉgEÊ«%+ßÊJÅôj@hHJJ€ (¯ ªX”@ šÃxÔ²«Ê]k¡9ŒG­µÇÁ ‘c• ââ3*n]‹@ •hcÞôÛ¬ä9—ÖÈ÷‘}òWßE°èÔ"; Ÿ™8ô`ÁÆ€ 1Ÿ…Ó´ DÀÖâ@ËDàtì`5³¡âû¥1Öƒ'ÞùrS´D¤Jù¢¤Dýó­už.í¾Ôaí±á9¯~î½Äïâ?Þ¢¼k-:îD‘\Q‡)7ŽU ¢¼ÿÎ?¶FEÉwòy“-Á›¨(¹×°±³}Ù¾µç¦ú=a%)ÉÉÜiCNqe‚¸ÜäwC†èÒ²|f @Ôm°ÔÔTˆ‹‹«jëËí}GŸsç˜îÏS÷ª0óX°fJ# ¥1±ñ²‚GÿÄYspŒY¹•œj²¸@|_¤¤$9::Bµ1V©àõ/›£1+6Ím¿3Ø#ñÕ»úMä;²Ð²â½Ç¯Ô[À„B!%Íýßÿ¶+KK³ÏçqzŸÚ÷¿òeÎ[²ByVQÑ(Æzqî´\}cs¹\aîµ¾Ãþ¼ýÔœE€ ë̺eKýF âʽd½uë6lY¹´÷ô¹&ÙG×퉓¿Å9Öe;ßuœ6×KWÅæºQ7Pc½}û†âo??¿WvÿŽoø»Ù¼ \ƒm´¦¯~ž³ÎÍ â/óL†j•ö<º·å¯³µ>„¹Ó>duÿÁ#˲þ™0ì©ÿ,ƱÚÛÛ†††~>ÛâKâçç—¤øYñ㕟ŸóGBBG¯Ã¢m.Îð‡"w’‡é¼-¯` ¤ýûθõ¤ªNSœ~|õêÿ”S’ Ä¥Ûö@BB’âDñ]Sù1QEŒõåË7ŠìÞ­õ2"d@‹™\«Á¶¹sŽ …­ ìFFÃUõ*Dfi Å"¡HL±u›uì訜u#:J" …Då³ Ä÷ã «Œ±V¶rX`l&ÑÔ¹§0/(ŸØ` ï÷gŠNµ¨Çå–{æÅcs¸6N°M¬­­•³ôœÅá¢q¬¢NÂ87MDZ*Ã3ê7Ô?GDщ›0ãÑŽ<Õ‡ã/Û¹óŽrb6p\ÐÊâ@SÇúj÷Ƴ… ‡Ãák²^!µÛ­^½ŠÉýy柆¤Ük>¼VÄï·b±ªRžG„=‡ú^ªòÈQPc­6Id@‹¯­#.ÛßXÇgü%‰H(”â@ýæÉÖº=x‰fVt…@ ê5‹±Úú„ÜlKòy„&[b]ŽzÎæóÑ?øÑ¨YŒ#8|žÆEóùÕ !D=\"D-S}Œ@ ÕR³+@ ªåãDZ"àô™Ó_[…/Jÿ~ý¿¶ Äwr¬5¦EsWOOϯ­Å§Ù°aÃjÅÞ¼A3ˆƒb¬?.êÒÒÒ]„f + ÔoV ºM@1V@i׊@ j4ŽõÇ…§„T*0a‚T*å•çkëˆ@|— ëWF"³xU®œ –ÐlV5ûƒÑRFrjš¥ŒL&ó÷÷ˆˆð÷÷?tèA”[ê]„&Ô ÆZœræ'¿õÍYÝ¿~Ybê™~£×·˜²ûï_Në:-]8uÕ® 9Å|ƒz‡þºqÕÌzl\‘»?Ðݱ«oRN®nýgn^4XÅR i·öOšµâfô[-kçîý¦îZ5× «2¸bÅ å\cE 4A9ÆZM(@˪_`ÓóFÜ/3)4U²`x@.ßgùäU?ž3SÚNÝþtaÈ…ô¼7Nl[å3²lw‡½ÃÝg/X¾ïRZZôæ9]ƒ'ö8÷¾¤B ‰ûÝzN’ú>|›vqçìg»§tžóoµYÊJ Š+%((H Äç«¢SýÇ«ös÷ óømÜæ{'faQFË6:xn~uo¨uXtÿyÓ¯C;€¾gmÁíþ´`,¥øíß·§Rîw5à€wÿ9o;Íäè²*”p`t XM¿°x€É sgÂí»~ø¾•[M–r („Š@|&4‰±¡«ºvú롞KÜýßã‘›¯º°)F,çyðšC }ç-öÐAK¬Ö€Vý&µRú™|+£ÛŽùûÉÜ•:õ1^•¡²W¥eEKŸe¹îöW¤˜y¬±b 8Ÿ|y°YUYW†}ÌKб"šPãq¬\랇—^ì±`œD¿À²ÿÆ¿º—Å[¥ï#Μ¹×|Îr‰«91w#>d<»~òï%+Ã60‰¯g›zyÜß5oÁžóO’Jšºw\´mC{K-åE…¹ªiK#E Fh·×ã<¼ùAäWU”w¬áááêÕëÒ¥  +¡3ŽÕaàúæKš\ÿ@ꡜnÓëH|¯Z×ðGáØâùÿÄ$¦èýºhÙhgC&ñVž8çÍŸÓ%}ƒ„™“¹WþÒ˵}TÊýJûÙPâ÷àÀ+÷ùÞ‰G^‹)P“UáìÕî@ÿ±–!?4š:Ö';Æ<£øš%N›²;bߤϪÓCÀ…ùñwg à|::îò<0c%q¶×¯Îfc`6mkø¥“fÅ__6µŸä5€DL¹´d‘LÇI‡äV•UáìÕμBAXâãÐhkAü‘‘ëîŒÞyc’U¤OyCÛmâôEÕ¬Óè9xl<·È¸þïay3»ês<9GÉálÅ·AŒÝϘ»íN6Œ/;„­íjÀŸ?Ê{=&…¦Š/æ ¼LØÚ6Ue}œz(ÆŠ@hBÍb¬2qÚ,¿&ÝVt°°90ýÔ ¥#Ã;Gö.õCh%Î ]·ÕkZb·ZšÆ€há¾ CÁÏ[‹d½´ €ŸÈÔëf^®Œ½¡ùï vàeLBÊ¥9ü@uYU0oÞ¼ÐPù`/???4Žøj0ŽŽLú@Ò0tíæg³É¡Cí°yƒgæH)ȼó×!ƒ.硇š@ƒôäö­|¦œ¼™‘Ÿûôòo½4™ÔAÖ=wtÔ}è9|É‹·Ù…é±Ûõ¹/k¼³Ÿ-,г÷ÐL!=ƒWëglê>ïËäŒ;çö÷êöKH[]¶ú,eƒU˜…===Ð8Vâ©Æ±f?ÞËúe×.NéÇŒðÏ:¸y;%.ÌÍÍQôçV´.A°-O<¿=¦iÆ´áÝê›×kÕmBZó‰W®­bÞþ1\ëè“Û]e×{·®oÞÀsçkÇS®0õ_”+Ÿ) m=0âÚFnäÖöÎÜàÕÇX-z­™zÌ;`ä’ç>Ý<ò¶´ù…%¾ŒLÎóà5‡úÎ[ìQþŽE0ô?ݺ¤ì'%ËZm-+Zú,Ëu·¿"ËÌcë`Àùä+ÉjÄ.6Ó¤ÍA1VBj<Žõ×=!ç[÷û%Øüù®7sÎݳÕÑbÒ¥ï#Μ¹×|Îr†S FZÈ« (qZÀm‹;é«É^É•PM[••Ah·×ã<¼ù”Ü¢¨0¢*1‘oœ&%@xx¸zõ™ÝQŒЄc%ùM÷ní5~C³)‡ýè+Òmz‰ïõ™”¬Sd=>9jèÄW¦=/? Ö!05Y%â÷àÀ+¿vâ‘×b ”S¨ªÅÔdUÐÊÏÏO½ÚñññšX‡@ * éSñ!^Cœ?«6u’ðÍ¿ <>`þö3³q°j²H^cHȔŒE2'å5b$ÏP“@ƒ™W(‹@|šŽc•‰D  …B4Y«\ü«Ï¨}Â÷Þôh¤§I[ÛÕ€…?” öòDš*¾˜+pð2Q>V[ÛF“4ÅXMø˜µdHEÜ4'-|ΰmï¯ÄÝl£Wq”~•Y{C;óßì†A˘„”Ks2$ø>6šŠiX‚óæÍ eþöóóCãXˆ ÖÖ È¼ó×Ô ÑþÁºë£{OÓÆî´î·0íê…SJ‰ZÖÞÝÜÔdõ ^ä:¶û|§õ“}óž†MêöKH[]6,Ð3ŠÕïÜ‘‰ FLM–2Š—•€€€ØØØÈÈHOOÏ€€4|øD4v¬8ËÞÞÞ€U.FH‰ sssD]ûzÕ rëÙv/|P.ÑÚwO7w#5YÚÖ#®åŸ±µý¦)l‹F]ÆmØ·f #P”Í‘ÒR#¦&KåjHHÈäÉ“·oß®­­]kö#?*X\\¤¦¦›EEÝóóó{ù­m¬ŽÌÌ´/³Ð5%àìê?©S“¥ùB×ffÕ,ÛŠ@üà(súk«ðEé߯ÿ×VøÎ@ŽµÆ´hîúe– ü¬h¾làP¨c ë‹…E5 ­2» ¢ëÐcEh°K+ºM@1VZøl q¬?.<%¤Ré„ ¤R)¯<_[Gâ»DÓkìîE[Ÿg«,´ÍôùÃ+.ø´Î¿_óµG;éWÜö™Ayý9ݦµ¹êû¶8%â)¯e[£:ôJ‹só¥úüš$a¤ê ÔPLÃd2™¿¿DD„¿¿ÿ¡C‡‚PÎE1VB>&ÆZüüvœáäE½TìMÏ7³®|H_wrÆÆèž+Ú@n⓼zÎõ¹ò°ƒLœ6uä¢Ñç®s¹œ§KFDw9wx¼ò±´ž$`ðü³á[LÈïþ:%:òâù“»ƒ÷&ÀÏïãV¨”99µÍøýovÅ¥2–·EÚ­ý“f­¸ýVËÚ¹{¿©»VVYjÄ4,!00ÙM """00pÅŠrz¢+¡ cÍy|áŸ|ÊéonW9Ñaô¼´³Úô¼pþ\T’tðß'—úZ1Y÷–ø¥õÝê­ÏQVZrjn…cy&¾ë}ÖŽýûáùy­4Wï$/v¦K·‹>»xØðÞ©–y÷ï?Ÿ4fI_Hiù.â‰ûÝzNr›±óáùžÅ¯ÃÇÿ4¾3è_[Õ§ÂjÄ4,Añ²T9@|5p¬&­þÜß®r:ǘ?Ä…‘#Ç­ „ùÙ9BÂHO°úpÚ¢…›wx»iriÉË©ÇR‚£\ÔŸËmÆ‚_ãgD:p¿ãÏkúŽ+>¤¬#1¸÷ûíT9VÁ‡°Î~»þº¿ÀÃZ‘x`t XM¿°x€É sgÂí»~ø¾•[ùX5b–€B¨ÄgBÓ«˜¢3#oKÓ®œµzãã[I—ISg›šš™™™éòY’â'Ý|fX¸® %"¡D.œvk…ÄhdSR&Ê@LQ@KUœ‘Óz ~ñÊȔ͞æó ¸¶îÊ£±\t9÷DšÄX…±…ç:àsòß|ªK¡â'M•ôÿiøÐÀE cohgþû‚Ý0h“›riN†?Чüb5b– Ä¼yóBCC™¿ýüüÐ8Vâ#ø¤µrÞEß¼qcÑé‹ë'ÊvîØÄÞH9W×jNW½VÝ~úsì ÖÎvúº$F` ?»´=à²áV2abXØÅOœmÖ¹C3¸s5ÝqZ&1óÎ_S7Dûè®_nr½†žÝ”V죥ùàÒ¡s>ô ^ä:¶û|§õ“}óž†MêöKH[]6,Ð3ŠÕïÜ‘‰êÅÔd)£xY ˆŒŒôôô @ãXˆO¤zÇJI‹ßƼ¾ŸQòîLC—®]»±Ìç‡\³[ü«g/ÏþCûôéÓÕ£ ‰àœ5ç.Þ¶=tõôyqI%Àq­˜˜gŠÒ¬zþR¼$(S2ÖŒ…×̺žþËÕ«_*8z:wh&½Û!ZßÉR®ƒ¸077GDѵmþ‚gjç`oZe6†7hÐ@·tš™¶õÀˆkùãglm¿i Û¢Q—qö­ÈdeggsJªS“UN+¥jHHÈäÉ“·oß®­­bD¨X\\¤¦¦›EEÝóóó{ù²ÜÚÆ ‡GÎvkéîîîÞ¦­wSk}å\QnÜÉ¡§nHvY®C`åʺ¤°@ ’+§ë}uðªfÇ*H<æ7á¿áÿû×®ÏÌLû2 ]Sbήþó‘15Yš/tmfVͲ­ÄŽÂsfeeZZZ‚&1Ö&c=[åƒ-·žó¸?Wû³Š\®Š»zè¶ÕûºÏËés´}cÕãÕc¢¯ÍÞ˜»öê.÷»šPÛhâUÕ‹iX‚zPŒЄÆX±ZžTÊ5ô9´öÉ•wEññoU äFïî±õŸ6•b‚ˆÚÅRˆÏÄ×™‰oæ=}tÕ¹Mýýrºü¸0+Z©™y…@ j ÚóêÇEC¿‰®BОWŸJddä×V¡ÐpVt= š€ö¼ú$lm+n—€@ Ê|÷Kô#Ä·б"D-€b¬QË(ÇXQ(@ jäX¢–A1V¨PŒ@ j4Žõ“8}ætõBˆO¦¿oqm3Bc­1-š»~™eë$š/Wø”A >(ÆŠøÒXXT³À+³Ë!ºß(ÆŠøšT»;,ºß(ÆúYÈÍ=þì¿ ¯bò(ŠvrÐëäm7tP33Óº¼ÙIÒ»¼c'Ÿ…_K|CQàÒPÏÇËfð@×&ªÜŠ­‹¨óÔܱR¤ä +[;BÙ¼è°gB'ï–v5>Ëw…LF­ÙxkÃî—Æ[uêÔËk˜> X\Rþ®›ñ˶œ0ØnÁ¼ÎN]ëÃd2jåšCãmÝZwé?dØ ]ІØwÅn&nxqLã¥AÝø|Vå•÷Ú*,,döÚÒÑÑù‚º#Ÿ—ÇXÅ…w;u{ãÉKcVõ“ nÍ_k¼ôòFs52‚ÌëÏé6­Í«ÙD¤8%â)¯e[£oîõP*¥ü=q3Ñxá†ßz·f”@A H)ðllì×Ã8ìIË;n=uèhè0O…—ùLÐRFr>EL} 25aÊ©kñ†[÷LòjLf@~ È(hd¥;л٣×Õ#^Žøçä?#TúÖÒBdþþþþþþ‡"ˆr5б"¾/>)ÆŠ‹ÙÄ IDATÀár¹ª+%“QŠãó{­jÅb•{XÃRq¤Lœ6uä¢Ñç®s¹œ§KFL¿š Î2®gmkk×ÊwäöŽŒ$­' <ÿløòÛš-¶ríõ[I&ÇvùiA|:äƒ$2(4²"Ìé¸t-kî‚K×ôùú¤ÝÚ?iÖŠ›Ñoµ¬»÷›ºkÕh•õ¥FL“Önºõ_œþ±=ôx“ ù%Àe`“ ` Íéµt-6gÁÅÍkûV¥j`` ³‹ADDD``àŠ+”sQŒñ}Qƒ+%Ëýi€Ÿr MÀ¸ý*lÉúÏɳZ–~sŒ÷ÏtuJ·«"´â†v>¢$&.ÌwßÒÆŒùyo‰_Zß­Þúe¥e•¸oý»/M‰3SÞ%ÆÞ_æß-¤ýÈÿ-4g<ßõ>kÇþýðü¼VŸ`{-ó6)wchâÆ“h ¢“Š…0ЊEr˜Â0è;¨Ýþµ»Çù¥7w­÷Yõ)HÜïÖs’ÛŒÏ÷,~>þ§ñAÿÚªŠ]˜&%äå ×»æ7. âÒH|ÝNDÂû|À0À1èÖ·íu[§MÉv´7R>\ñ’T9øÞ©Æ±â¸ÎÒ¥Ë?K2wý#ãôé•%y¥ŽVÇjîëUîhµÛÇõvéßÒ’—S¥G¹(r ®½·w‡Ò_þS¹?ÈwÄàIηv· <~ŸéÀýVâ•ÇN¿°soãlC¼x8òÇÀÄ¡ ¤LÌÂ3rmzèñçv¬F‚Õô ‹G˜ :w&ܾÛèï[é°5Ó¤„#'ž6níãÂŽ~4 |ôo l _k½y€Øc†®w‡F­XØ]ùìÊ1V¢NR}ŒÕÉ©âï<\Lòœ”Sˆ…BId4- …2ANVXY€klªGàR(±ˆ9EÚ­£‘MI™P(1E-U>;näºyE×îÓçßüУµ8­ê¯ŒLÙìi9σ×Jè;o±‡ÎWÛÏõ¿;©í»´zù2ó@,…Ü"Ðåà¸<æ(£€$ÇÀ¢¾]ä£ÛÕ•÷Iв¢¥Ï²\wû+RÌ<ÖX±œO¾2ÌA±ËƒÍ4)áêT/ï.oR!% œm¡;¥ÑQ>Æu‚à+›$õn?ºûqæ +âûâb¬yÅ2aþ¶m[”ÓÜý§zëÉ¿rpX†±¸\nü©©½Wg;XÊ Ïuþ÷ÁvGœÍaN·ë¹ÏtÅéØ8YáìÖÆÐôŃibïfºÐ×ÃtúÎnG;¾8sæ^ó9Ë}¾^0îi\‰ç ›/Á@z¸Á¥G• 4 Ùà`\àØÈ)‡“\ôy´E…¹ªi˲÷nŒÐn¯Çyxó(¹E5b"ß8MJˆI)éî£3Ìå^õì]Q77¶HQoÄÝ8ºÂâc– l'¥’Õáááê av9D1VÄ÷ÅÇcͼöžgåJeGÞ¾YkÄd…cU¦ž÷ês[3ïÒü¿J/2J †ª?#[»%aEéh`ènXü  Øô:ß«Fê×>›] ÂRr¡“+ÝÅs««ÎÐ4XšÀÌ~ ÅÈêÉ#Åš}DjÀ.N)æbðy]£Ššjg^¡ ,â{§ãX¥‚7'mm¬¥$@½—ÈŒ¨²À¨"Æ*–P…ï–?z<*Q"‘P(Tޱ³ð÷©B¡>#S9Æ Éá!FŒ1e1éiœeúíDß|<ëÝL˰¶qÈ+Á—_.[êÕ€dÃÙ(ñÞ¤!Î" /ãCsg£j üØÚ®,üù£l°×cRhªøb®ÀÁËDC1¶¶&%´ocy*:ݦ‘^v!.6IMÐP,`±È" õÙÀ" 7-³•«ñÇ™óí´2¡ c½ù÷½ÖK|Lt)Ò’§2ÀékqKÇ–*b¬l.-L‰•2é:½‡·6Óãr¹Ê1V]Îý‘šk~üÍI ®[v]îa,bÆr œ¿èÛ€næ?iØÂž"1ðõ7Ï•ºÙ’pû8ä!a`€cÚ<ˆŒ>Ëéójƒ±7´3ÿ}Án$È‘riN†?ÐÇFS1ÍJÔÃág#\<œ(’ h. 88zú¥'ÐâÒq·_û-t®Jßyóæ…††2ûùù¡q¬ˆïš‰±¦ÜØ2éPþæÛ”…9a,­æFªFìëØw6¾çœöjÊtñ³KÛóþ(n%Ć…]¡e¢ÌÔä„ב‡Oß6ösdã …À«éŽÓš0gÞùkê†hÿàÝõ¿Úèd§;ÀËàÁ³·v s‹AFá›ïÒcDbEïJê8|xñ$É«ÑúcŸÝ4§gðê ×±Ýç;­Ÿì›÷4lʘP·_BÚê²`သQ¬~çŽLT/¦&K™wP'ÓÈg±-Û5Ê.Š é¨DIN Í×b8†ZðúEŠg¶³“~%/I±±±‘‘‘žžžh+¢ÎP½c¥eÅ—ö®œ½úäôý×;r éøÆéls3Ã×'èØþ¦ò(Ó6¿ÍiSöóñá1,-}mì|ŽÀˆ#wÄV=)^”)kÆÂ€kfm®÷lõêgÎ6065·pX2¿·Wã²iZ¢w»3Dë;Y2?)qannŽˆydúzÌÿ¹‰ÿÒÇ/Ÿ’m½ì¥2¬HLÇ#CL‹ ’ŽzL¥&¬\ü%æ5h[Œ¸–?~ÆÖö›¦°-u·aßšLVQvv6§¤Z15YÊÌ×dìâ‡o^p<ÚÕˆ¡D‚í}‰cflˆñX ÍçÏÒŠãbCV¨°Z9„¬ ­]——ªAühTcM¹074sÉ?a¾Mu˜,–5–þðqd>ð[¯ÙÐ_Y^c­p,õÑù'ÿoï>šÖÚ8€?éfOÜ[q  (*÷ºîŠ×=·ˆÜ¢àëÞ‚¸õº*†{‹e(ʆÒ6mò~(”RJ)XDàù}¸·MONNŽå!ü›&ñYYí–ݧÔÐÊnÀë´¤9,¸ðywïÐ`îÞ‹sÇ'’ëêë©yZö«Zq)éêFök.^T2à?ŒËaî[j³Î?âôá°më4j`¬£Å&øBòsDò£HûÚ¬å«ìôuþЗL¬]ιP¢,'ÏG@›î>T§™ê—dx\æe-VìûpñxbëöµëÖ4ärX@€ˆ¤bbS¯†D×Ö_cg¨WÈåôôôŽ9¢ô%ÌXQÙ"Ÿ±±±±ðùóçjÕjßuvvþò%Ja>Ek3ˆüåGKø™¶®ŽºW$ÝéÕýGBN¶·¬«ºåÇ·Aÿ8Lr¿}¹µ~©}@**ê‹Ò;Ä$NÞþþèCFª@Öuµ‡u1¯WUûOñzþ)ýäíïo¢³ÒDMƒ›nhÁÜÉÌÁÊHi{õï P³¦ª ¡¿‡¬r~ûU¯^=P3cU³ªÁÔÖÕ)€xÆŽy¿¸©ºeòÛý=·-õªªBõÊ<·áµJ{šM}=›úE»âf©¨Ü+ý/Ý›u˜Sà•ä5™0­ÄÇ‚þé­T~ó ¡² ïy…þ45ë&¾QÙ¢äÚ5Ï=nü½½Ã€¦øK\¦éº_óP+ËôWþi‡ÚW•_xuÖØÔ#¡s«)Þ-Šÿãö+ÊÞÞBÕ]¤2cî?ײs0Ť¬ár¹rµ4»´R9‡¬jt»f¬¨xJ0cM ?u80(ƒÖ G/ÙôÍŒÍ$ÝçM‹>çë P­çøA €{z­€Ôw±?D{½¼XÉMíB¨¤ž±º] s€¤7Ǿ4›ÞÏ hJà¿f©é^ ä×b™·kUëé7‘´¶‚DD•*Ud½1¹5l+1¥ _ŸúÉOÿššN> Ôçê·kÝèÃÍƾ«Bftëí¤ócöâ;+ÝÇ€8ëÝÌSß¶×—Þ)÷@÷ßV ñù0µ¦¾lyãi ¿tœúnêÝÚ9!/*ßòg¬>>[Ø_Pûñã]fÍš•ó 3V¤ÅÉX³îŽ·ÖnÕÕœWyª³&íñuC€[ÿÆò-¿Þ¾z5)»XÓT:ÐÔ… çe¯j™ôoÛª–ôñ÷;׬ hö$rC¦óôâAC—Mb³µ::vNÔf'·íÐI?ˆ{Ò-Ɔú¦cÛ˜æÞiY”â‘q¼w³øó•Ö®}äz¨ì%Ïi¨Q–ÏÛ´Ýí, éåεG>X¶¶í_|÷lô;òg¬óæÍOLL<¯ìûÇýû÷wuKò`ÆŠ~W‘3Ö¸G§L_i1~ïš¹Q¦ý°•—ªíâÚ÷Ýû » bå¼K;/öêœÓF’õùÜ…»7zÔóÃÿNDÆþü%º|,M`¨b ow¾3ï8K~ÉÇ=^º5gØê²“Ý{ýà#ìY›{|Ú»u¥9ÛßA; ÈøvçìÙ‡Íæyba­8‚ðôôJKK ’_îèè¸j•gÞªŠ†^X“^mî<Öo¬ç±±¦—¯ O¯–MjYïvÔ¦[Ç«ŽpYel~æ:´$½e«Ù«ÑŠ`2€b’-lú {òœCØtïÛøÅ“7™û9‰O>aÚýƒÓ_¦ ³Nú¼dÙ*o¾óFçvA‹VøG´ö F–‹špý—\‰öP[öºqKcþžw Fk19¨lc2™7zO:ùñãÇÒ%vvv6lb00 B%«ðŒU»ÁäCçÆX×Ö“ˆ µõÛ×ÿæhKÃø;3­‚­ ´™ÏßîÏԖƦì0šœÑÞ®‰ÿ½©µõAJ(4ýõåÉ—ŒLÁë'Ï( Å!ƒ¦…™™Bšñù| hJ:ž˜[‰![Ò[Ï™â¹ñ÷Nb@«ºÇÖoô\-Û³2Oœõ ó² ¢ óX™LææÍ[\\Æúô©~ýú›7oa±˜b1™wmÌX‘9cµ·ÔàÕÙyfM—>£Íýæl˜{nÚác-€|‘Ô—3sïeµ{péØÅ—8z­G n"}Üv¡'']ôý h›Võr¯Çã^â8͘1äô¹É㦌×Ü}Ä[:žªæ›ÔܱÝò¼¦S­Å³Û7²û­Ü˜ÿîÌé”U£Íu²—¤’LnuÌË*ç±íÝ»ßÝ}‰—×CC£:ÀŒý®âŸÇªS½ßÁ™þ}Î0wX3î’Ò6™ßG{»Ì˜, @’õÑgW›ëäì—¹béÿ…)~_@ê,èKxx*@xjaA›¶ÔㆾOƒ>dæó5o“œ/ß\Ü ÷çdQ›&û×<½µ“ôijx*×°Q‘ö•]J/¿"{ÕÄÄdçÎÝ*×Vÿ˯®…•–dÞ:¾Ícó›Þ'Eóì84t®›[ÿÖµåÛdDÞõÏt‡•— Îþ˜K|Õwï“)S¦*ôÆäToÙ’€øŒ 'Y[¶¬z¼‡m½™s­¸a^3ˆð[ÚÖóêç9ú˜4§éÙKÅÁ&,„ÞŽ¯7;ût…¡Ëgú¼°çHwC<)¯äW‹ö•V…ú}…g¬´„ÿùõó{·¯_¾x1Õ¢Ãüƒ=››R3ÆžÙ¾Þk¼“‡Qm‡ö:õéïØ„Lܵ״Žó8×øš ]]”þ(Ahhˆ¬CËÀÚª0j9:Ö€ÏßvŸM·stl éß§E/³¶^Eò3¡»ýv‚†t<¦Çgz®ŠN^™Í8(j5rµD(ÈÓ¬ûÒZ{çl¿ ©‰D³ÿ»pC;“ìÔ##%))1ƒ/`]-§%«l‰êuŽp1cEÅS´ŒõØ¿=Ÿ3»ÍÞz©»]ÝœÅUÇ,Ü:ÊmåÃÀk—¯^~œn0ŒÇãñÚ¸ÓÐÆ|»ÛôW"YŽ­>${Êѵ²oÕTö”Ë&WºQ±–NËuwÏÿ#}I’õ±Ç½Ò—xæ}—Ûx-úy°_M¯³×”ìÏêÆÍÛÒ‡ç–i·]Û¥röGgµºùÞìVŒ‰Be‡Ã.èpµÐãP…ÃUÌXQñ-c¾ûÚP†¾Ò+®0XFmzŽhÓs„lICs˜î½]ýÑÔsü•}z©nÕyws¿LL­—6Êžܶ~_÷¹q=N¶·¬ ûø6hΦÄM·ûª?TÖ)­ªE/¬ Í(¼°Lý=ë`òÔüÞ)ϸÓ1ï7¢3"""U4K~»¿çö£­ñ»‰\U<\U³°âu®‘•±{^´š2¤°jÕåòwïÒ8’$¥u‘¢( X B­z)Ëâ;Þó •7,Kö…ÃU5 «ô87û ¾ÿQñà=¯Py#WIÎiU³°ÊVDH°°GXXXiå|¯´‡€P®2–±þ Ì̪ÞýAšýÁ÷?*%+A˜±"„P±ñx<‚ ¤ï …B†…!„4 3V„Ò<!„4Lþ"NyœdfWǘ«¤Ã¬Ï‘©uÍuмè÷Èþé ==}êÔ©;wîÔÓÓSh†+Bêø­ŒU"øºnÝša.ÙJoƒ•ã¡ÏL÷¸ñ÷öšâ»þW×ýšï€Zù[¾Û1sf”{ÐÖvÒ§Ï–öp‡ÕWV·Èßòìø‡Ó™\P C[›Í )~¦€£«ÍZ, ^8½^¾=ÿÇíW”½½…vAƒÌŒ¹ÿ\ËÎÁ´ÜZ,$XJ~™)H$&L ™0a±cǘ̽B埆3Ö”ðS‡c€2hptñ’MßÌØLArÐ}¾Ñ´ès¾¾ÕzŽÔÀ@¶ÊQÝåÞ´•"…" ”vžü5¢µÈ’êz/½º{ÕÝxrDݤwÿöñt¾r´ƒ0%ÈÆq¯|c‰(nö ¥c.Ý€—ž#çÜŽ‚É1®l^³ÝH— -jè0x™óϽps[%Vy;Ÿ7î¾ÿ·µ÷ÞFêToÚ½ÿÌ}ëǨØCww÷ qww_»ví'BåRáëúîöÇør (hÝ4Ï™::fクÍ1SÏÄÄLÜ—¯¤É_+×l[±|¹ÇÒÜÆº ±lÂÔ;—2LÂLSCCßH—|ü)À›ÐÐì»gs6©­+},¦áÒôÑÏ8L~lt,oæà3<‰ "ù[äàÁú´$ hSù‘?X5æ[¯-­x´@ HOøöKàphÛ@Z"LLˆ¹uê#zœÜyóR;ãNë69¯ ûo¾’ä²+í«¿m¯)¶®{Ÿ^î•ùþ¦Ë—.`´^ñ¶µ²züË¥0cEHEËX—ß}±’^ö°ž= 9ДààÊù•‡{ö±4”oÌkØ£3ÿqŒH"}*jõë×—5`rk¶¬g"{úåཪsté;wÊYV§6Üܹó¦ô‰™ý²MÓMüá¸÷”£Ü¶öŒÀݰÞ,÷/ýè診õ2 óÃÝÎÆîyÒ‚Çc‡Á`rª¶hÑRÚ¬[Ͼ_lm|NÆv™ÓÄ~¾G¤ýœØùauyåç‰#cܡڜ+«FT|éüÍ:ÝÆ%{UˤKk éc1ÿÝäÿ…Õu¹†]ýý:} ªÓ¤^öŠ’Ì}'‡ ëoÈ$€’¤íÝ»G~+´ø×…^ÿ Gòüýà±n““øñ`=i:¶….[é¾L¦:ì»_2€cÐa¨ÃÓŸ»ÛY@ÒËk|°lmÛ2{÷lZ’áõê—Õþ ²%fö›ª±–^޹1¼n) ¡rOVHÕ:L‹{ptÊô•ã÷®˜{ìi?lå¥j{‡¸ö}÷~îƒX9•¹ób¯Î9m$YŸÏ]¸»q£·Òn—LI2dIš)7»˜ÿíKs6É—6¬ð9¬¿´%ƒe¼q£÷¶u^}æ,ª”xróÏdfƒ[M_?7«uœ½È!§¾Ýùμ㬂v'9üø™_Y×>íݺҜíï d|»söìÃfó<Ëna¦‡$“T“¹LÝöܧ÷~BÞÂzóæMÕ]999•È*ï ÏX“Þlí<6`”ÇáѦWº ºwʽW;jí•K~fc§¬;?ܱ·™6-IwèÐUºMQÁ`ƒ·ha­°Õ àtZм@ذ¶Ùòm"@ZŽvÚäÚ§ñë­Mà绫Z¦ƒ™¤P@æ®uÊï`³ ³X±×χ´Û½Ú½ÿÜ—NLódôô–œìs¶^Æó ëÈvDDQ”îîq4™ù#."øA¸eW×u­Œ¤ t›ò¼Ú@å.‡ß¾U2 e%J€ºZy>Ù¯¯Å ú˜¦ÐÒÙÙYuWP–§¡?©hk•–nG¯Lµ­«'U7ðè~bäý±ân-¹’eýÄ¡†6ÓùFèH¦¶ôÈ—÷ôé šœl׬鉇3ë@AxN+wÚÚÂ< 8Ò-NkSyñž/¼Õ ñú7ÓÖÓFBÁáò¸Fæ÷s>>wå_ŠI'‡py²ö1B‰n-CÙSƒA0õ«U«Æ`rmÛu›º¼M‹zF²u këJ„Ñå&IdiYÀ×,‰ü¡D¯¾â ªoÞ¼QÝ•±±1`ÆŠzŠz+Ó¶®09U·^ӥϿ9fžžv8D›I@NUÍõåìì L#û{gæ»'1G¯õ¨ÁMöàfñr ꎬâö@º÷½ñæZ ˆc`Ûµk}ù%AáO䟚s¿~ ón×~Ê”©J{þ28åçÆ«]+#6ãõ³D¨“ý[¦2¯&gÕu¨TºC¨â(ÚGá:Õûœéßgà s‡53ì”ÿ f~ íì2c²P(IÖGŸ]An®“³_æŠ êÜ a¬d¤·)$ü.ü¯‰qA-™lc ù%zŒ<§iZêqCß§Aµv*5<•kØH­¦eÁñig>kÙ~¼ZºàÛµ…ßIÆ‘¾5 ZãÁƒ>|>nذ¡½½ýŸ'BåW®@KøwNíôÜüº‡‹KÌ…UÏš=«]-ù6Qw\†Íjã~v΀ìÏ÷É7|÷>7n¼¬|ÿBR´Hº„Ðé>xlB?‹ŠÚL˜Ž¨Fˆ‚‹ô½+Bê(ZÆJK2?½zv'ðÊ…’™›Q IDATsçSªtZp¿·M%jáô“¾^ë'÷ñ4®Ó±CÇNû tjF¦?ì;`NçEGÆ[ ß¼y-]]” ”Hö,C[ëì’Çe3à| Ø}1QÆøo÷¶_Oo³tÛmÝê+móïÜùÆ,@¼½/Ò¸ÖSÙn}|rÿ#Ôvè\O‹U§ÿþ:Tæ¿flè[Ô¬•\IiV(Fþ!ÜÒ½6Çd¥¦¦Pn™u« JuqÝÞ~ëtN•FNã}o¤¢=Al6{ìØ±YYYñññÒåÒ÷F™ž „þ˜¢e¬Ç'wõ|Îtpì6Ó÷bw»ìóu,“án[†ÎöxxíòÕË¡IðõZ ¸ÓÐÆ|»ÛôW"YŽ›ËŸ…Êѵ’Öì%FFTîa‘‘Ó$ù—r§Ø~zý’ÏQõMv^«Nõ´€gØc¹ÍòEWcö« VKüÏÐ>ò¿Úm×v0È>š³è´9°“ŠîË k—óA.”(‹ÁQë[,«C‡b±8&&†¦é’Bå[á…uøîkCúJ¯¸Â`µé9¢Mϲ% mÌ`º÷v57oÞnß½s,m-¦:g®_{òŠ£­­æ·ún[¿¯ûܸ'Û[Ø÷Ç·As6%nº­ø]ÏrCͪ*%‘H"##Kl,U êd¬ùÓI5ŒA5»g0Dêç}Úö×=¹þ)ñíÛ÷5I?ÔuËÁæ cD¥0cEH}åžW5»Ì¯²…픿žUܽ{Wuƒ@9z? T¢ðžW §n"„4NÝ‹° yaaa¥= »Š҈܋°à=¯ŠÊ̬ü|MKø~@H%cE¡?F>c-o·$A¡R‡…!„4 3V„ÒÌXBHÃ0cE¡„…!„4 3V„ÒÌXBHÃ0cE¡„…!„4 3V„Ò%+A˜±"„P±ñx<‚ 0cE¡…!„4 3V„Ò<!„4ŒÇ㥦ây¬!T2°°"„†aÆŠB€+Bif¬!T‚°°"„†aÆŠB€+Bi˜’Œ• ˆRB•y²BŠ+Bif¬!¤˜±"„†ñx¼´4<!„JV„Ò0ÌXBH0cE! ÃŒ!„JV„Ò0ÌXBH0cE! ÃŒ!„J^„!„4CVH1cE! ÀŒ!„4ŒÇ㥧cÆŠB% +Bif¬!¤˜±"„†aÆŠB% +BiXvÆJf¬!Tl€ ÌXBHcx<^FF*f¬!T"°°"„†áy¬!¤x+Bif¬!T‚°°"„†aÆŠB $c%3V„*6—™™†+B•,¬!¤a˜±"„ày¬!¤a˜±"„P ŠB†+Bif¬!¤aJ2V‚ JuH!TæÉ )f¬!¤a˜±"„(ÉX“““1cE¡bãñx|~:žÇŠB% +Bif¬!¤˜±"„†)ÉXñf¬!T"°°"„†áy¬!¤JÎcÅŒ!„~f¬!T‚°°"„†aÆŠB $cMOOÇŒ!„ŠÇã‰DY˜±"„P‰ÀŠB¦˜±úùù•êxB¨L*0cuvv.å¡!„PÙ$Ÿ±²ä_øò%ª”†„Båf¬!¤aJÎcE!T÷&Æ©Ÿw.Û.m¬_{ª—kã‚6F ¶lÙ2jÜ¿¬’¬¬”$åå«Hkù…_O,½¯×EübO[WïFZE®­Y w_S­Z™kåYJ“$°Ùr_ÎüúJ˶‰üæÚcÆŠPE Vƪ ÖÏ}ÄEÑ4ÍÒ3aòóñ-×Ìnœî»ùî/ùÆiŸï½M–= £àÒ…s,¹bdÔ´K‡ºzòkÅ¿ ~ùæýÇO„aFšôêå¨Í(ÂE È´ÇcÇ-|õò™üÂ÷Sûút"M¯¦‹ŠZX)QüüQ«†Ÿº"[òæÊÎÍGn¼ÿ‘!fYÔ³„ž£k+m5wVæñúIñ½¼ ¹Ò§ÇÝG¬½=jÁÒy«mµÒ¿Ü¿wÙÛ}ø›Ä¾ã›ðLÖuØ:ÙçÅ™y¶EÝ B¨œQ7cehw8v¬•|ƪ­Eüw"Ê|¼‘XLŠ%MKDü˜¾]F=}t $Z·ú 7·¶m8øåÕ=”X,&hÒg\ïÇ &^ò)Wü9uì=¬cïa÷ü;{ôŠ +^lhÐqv“¿Ÿ½+Ýd Äb&ˆ%bö)ü<{òøñSáI;¯i¡ËÉÞ–ÚÄYÜþ‹õ j ]1þîÒÕç_MóšØÔLF6¶«+‰ö¼åÏåÉa@Ó)n‘]]?O½^‹ËÄŒ¡Š©¨+û—ÿì©G?K_j¹ñøô´}"tOtªÎb1µMŒS?y/pãðŒœX,6˜4íùvõ Çy¼KÌ¿mS«ÕË»ìfi"müíªÛ©ïv÷üGsDjæcÝݤ˻LÙ}îX;çs7¶20ìÝ»oþ®þ[½œÁdKÛK˜,H|~ìXÀÉówM¬ÎðÞÑÝ^ŸYœ?ÏžýOl2ª¥AöqwŒ,çMµ®,ߦÝl¿kV°Œ;4äo}ºÕÞ 0cE¨¢)NÆZÜÎ+£%ÒŒ•Áâ<ݹx_@}Œ-=o–,‚9ÍZJWnã2³ }þçGR@‰“ºtp&0ȘÅ&ÛÀÈ EÝœžnzÐ}ËU.ƒ€ŸÁ_̺dƒ7ÆÆdõÕxhe¦æ iJØsÊú>ÿ Ø~au“*ºù^Ü»ÿ°ÐN,Û¶¯Ìf¼Û÷¡²ÃÔœ3Nþä7Õ._Û<p–¦ ö¼{uG‹*—ŠPX?˜49à3Ð4Øm952!ãÜÆéçäp lìÈó·?Áù¹×ÿÙâ#(ÀØÄÔ”ÿàQròW}é“ c_›íÌ-LúõôÒ¦ª?H‚Á <Ã,à/Zœ²|ù²B;q?wÃÉ÷îG–Ñ`Ãì! cÅmdk¬zE#[cþÕ0B¨ü)Ây¬uÆí¾167cÍÔ›ÕmíÔË æ/ïYÞì{˜c­c¦|=xþ|¥ùSHJLÀÊ…ó¸9uU¯†ËÒi €–¤ŠhF3.ˆÅ$Eþ:œd~Í‚'ë'îÁ/ã–†*âQ€’Òb‰€ %¤¸ Ö “›7o©3/b1ùU æ™±¥=S A¤†'‰›¨X‹cΕ¿ˆÅ$f¬ULE>5àŸN»2˜<‚ Ä:¶>gÖµ¹y“×e.gš îM cúÞê$Í:e>zYÉ~ ‹Å¦h6têÚ]/ç`’ghžÝ˜eZ_HÂR›uy¥Q×¥ºŽ´ %ŠÝñ9ÕνºB·ò…ŒUEã"1ç0Ó)Ù ûóîŸ ah ÐŒ¤AvB«$™drªæ 3V„*u¯ ÿe+QfÆÀƒ·gUщž0ö„غ¶~«; <³©øÅŸK6ºy*%Iöºû“¹êÙ¼ãÖÚº*‹`R3“µÇŸí ³lý³‰|²·.I;â1ñ»ùˆE€Ìxv àQþucEb;ÙhqEëåìׂ4Ôã<ü˜=séÖæÂRï=a=&µ±µyjá¸}ñ—.’ž¾šú>c(­¼¹¿~$¡²EuÆJçòaÙßjÍ`T1I;òLÛ$ÇÑPY¾ž½Ú9%­úØS“D#Mž¿jŽ´C¥ß…í±qåíÉ®þ—i7ãP?SnJÔÛàÐKûßë;îõŸ#]…"Þ¾}›ÝL -ë–£k[™ .‹Öto\…Ça‹øé)ÉÉIÉÉ)ÉÉó|vÕä2‹45MGÔˆ÷{³³¿NV£¯kȈ-SzÇÎXØ«µ!rgÇþ˶÷˜²éÞù^gzC…y+ÒFBå€êë±æÉX%4¼}cº›ÿ@œùÀwÝš«_ çúþ×I?ÂÛ{QW¿šûö2°«!‹‘øôð”_\ÏîªZUgŸh¿ç²Àcáb .‡Ã$€’ˆ…"áx·E•Ù ¦½÷ÑëŸÈzæ:$IÆÜö=¦Û}¼×†>´I’ÀÐíìíÝ9ÿì\º :‹–¶àì]êö³/ïßf‰Ä,Ž–ŽŽŽA¥ªUk5ТÄ$Iij*wÃ_¿.Ž?¤RÎQöhÏ#V­wl;ytÎ./¾˜S¥n³™F:ZJ·N‰¾N­ikJ’¤ÂUk1cE¨‚VT"66~ýú¥«›çc™ÀÀk:u–?ì:Ô½Õ«I+úñhŽa­ÓF˜ ™»tÆ@ƒœØôí­€ÿßâï¥Å W±^¿¢ö)U4•ñ,$ôSä·Ää¾€”P ®V ×Y#þèNÑ© ]‚ÚÑ«ºâ ”PnÞÀáëé Sƒþ¹¶½/ä½~í£GñÖ,U©¦¦¦ º°vìè(ŸY|ŠÃcAvð*N'Yz*>&¢ÊÁ½µ…ÉÁƒîÝ{ý 9§}‘£FuŸ3ï≖zÈ{°ÇcaE¨"V5/t 4M3¹<†ÜÇYL]–Ê‘(ê¥ÿBÃvû¼^Ť¯ÔAuË £óœ6íi¡Ë–Ï¢ñ:×ULª2V’$¥…¢(»çAT ‚aÒzâ`€ÁOžÚr€D"‘=•UXÀŒ¡ £ðóXY,VαSî ?ìV‡ô0?û žÇŠPEPÔóXÎiÅÂZ(ùyCU,ª kpð½?6„*7ˆÏŸ?@ff&‹Å-íÁ „P& utt@uÆŠBH}²ŒµÌŸjŠB,¬!¤aªÎcE!T$yÎce0iii¿ÓÂyEòOU¼¤ÁKna¡/©†g\!TAT¯^Ëå‚ìZ!„43V„Ò°ÜŒ!„Fdg¬!„4£„Ò0,¬!¤a˜±"„†aÆŠB†QBi˜ªë±¢¿ÖÅ‹K{»¾}û*,ÁI+NZ1äŸ4ÀŒµìrrr‚Ü»*yPÑÈÏ@HHˆÒ76Nšõ'¢(icÙƒŠzôHé¤aÆZViiiÑùÈÞô¥=ºR ðÓ®ô“¦@ÍI£ò¢iZ"‘ÈêKECÓ4Aª' £€²Jii¨àÇ…î>NšuvŸRF6r´ ù÷OAm°°–U* D…}»+ˆ’ÿQWúÆÆI˯ÐIùI£€Š9oò90i˜±–UÒäKᘫØÇ/Oá÷ÚFŸSÔ%äû!ï¬:³JÿÔ=ùŠ©".ÔÔ¤•…NÇ“H$²Uéiq©˜«¬°ª˜´Òÿa@¥(ìÜp¾ìö LÀý ëoDgÈÄ\wéê*}|Ó}î”Ç?¤J~ö›=Ç}Î(wå'ådý¸ó0¾ð?‰2cBBÿ–X<òœ½þSJ‰nBpçÌÅ7¿ßòé¥I2ïjzó Éb欄û¿+Ù÷üf~ {(,îvŠ k…öýÌ!÷eOÅYï]ýx†lAâÙ)s€–"qö{5æa0·×gggѳ°D-$Âè;>o9{ÆðÖ2Ï›q KDñ®ÃWŠ´ðj͸nRÝ{7y‘ÇêÓ!²–L-þÂa ‰ÿŠÃ6ù)ìbq®þuyó¹g?Ôi™°vó-Õmn\¾'’€wŸÎ‹"•ÜÝC~z¥^_Úî<´_«æÖVM›wîï²ûÜkéò¿jz¥žžÛ6~ćV­íì;óï¡À÷ò¯¾Ù8iØ„“²§ùËsÜáS¶¤J²w}_è¼Z~ßUtÈäñÝÝÿðîcÆZVi$.ì°lÇð¥)OHhš"Åý–iÛ,m£ÅÈHŽ|ô$$I±„¦i1I’@Ñ´Y3[+݇OÁf§…I’çMtör0ªÑd÷Ì^.£­üŽ÷²4’uþÐkB\Ïö: ’$ù?ã~fÚlöê4™ñlݤ¾‡ÚÝ廨ŒÍ`tZ×ÞÇeãã3ólgN4’±VêZåûú×q˜_"">~ülÒoÖÀšr}P¿¾ L͵ówþúõÛÅó»ÜrñÚ8«7“P5NRLPÒY-ˆû‚…^w+r3ÒRÒÂüå§Ž»Z{9zÔ‚%n^6Zé_ïß»ì½xèË„ã¾ã«žÞ?ž±R݆ì 8/\¼¼]s]qâ³Û'Ö,yóþÒÃËÿÉƯøØøT‰D4•é3yØÕ„&OLÓZºðц©ñ=ÖÚë²$I¡²:­n·}ªÏóã®ÖE­˜±–g‰ MÌ×GG1˜Á`³¼V³6ôe³Ùl€Áf³YL‚ Xl6Ád±¾ØQgÔ:.›ýòЬÕOëß¼ÝÍbT¶xvCjßQ}>®Ú7€ˆ³ÞÍû/nGXséºL°xus¶­ÍJlÏòÀÂZ¡Ñ”¤ÑLÿÎõdKÜlTïNuõE¦Ç¹¾ÁR‡IÌqhÑþ\ð S-‚ÉÌì5*ÀÛÝïÍÚOS½õJö#húªß×ôÖV&г•é¼]ï¡”~ò]V­’=v4`ŸOL±ÐÉY@I?Hùùáý‡*LþôÙS’¿~ŠI¤jÖÒ tëù}svv6jÒ¯\·± ß2Ûr¬L³z6œÔÒMÙ6Ë·ÕÝÀÙÒ6™±çw4¼x4÷+ç´$¢i#V‚üôÒ’Œã |Ë1ùZåY½t§WŠ–¤]H4¥$‘pl]ÉÿÊQ€ÜÂèí²îZúá[óþz~·ÿCå¶“ŠÚa÷–&‹÷~„?VX1c-£4’±Š):òÌê™ueKÂÓE5Å$)¡¤! BÆ*‹‡xÏîâ¼ãþ™Éq?c¾þÈ¢èÄoÑ‘\`0ëV£Ä$o¾gÒ“%ƒ hZ¢ܦ ‚Hÿ–NZꀾµQæp’”¯KE£‘ŒºYh¼tËL7ñÝ»wïß¿û‘v“½¡§Ë½F–jUÖŠmØký<ûÚUŒn,í³µÆZ HeŸo S[p«Ë¦« &I†VÛñ£žhÉ2V2ãíä!^Ó÷]3–ëD”ñšÁ6©DP$IQ”˜ÌiürÑîxo·òÓ+ΊS´as=Õ¡mAÓû'3VqV,EÓFÍ ¤QižáYPç#ÓI±6ƒ hàÿ8¼ü¦•ñóÐ¥Ïë‡6”oþ#Ë` ž´5;k#þá÷IÛ" X)ÌXË3d¬,Q¹íÐɽsã¿ï3Yl6Q`ÆjPmˆa’ç‡G ï#ÙëGdŠc7® eÀÑkµÇLˆеkèÉ’A&‚©ŠÒžP4mP[_º\¿†ŽD­Ð¦HбŠ1'Ž]‰ŽŽŠŠŒúòåsôfäÞ;]mê×k6²ó€úõð8l^½¥ï-€¯§GÎ ¯Ù få´ˆ#‹®e m«tÌùk³+Ãqñ¦®5Ž<Ù,B:½ðb×jrðö±Må2Ÿrt[fO{nÆ*Ù:ivTã%l6[~z™ŒjL‚HÿÄg·T5uMïŸÌXÚÕ‘ü2•i«xä˜ò,™Á2Ðc³€AK«Áá3¾/wö˜îr¼ùµQ e-£…íªºÒ€UÍ@·ª–D-]ë7aÆŠ 'Jý››åñ©B‹2a©ÅüÚr‘Ÿ“pDZ)£{¹¶±nÿ¿°£Ý´yUrrIsó×ÏBNü~?€ ˜.Õõ¤O…¿„LŽE±wä·Œ{/"ê׫ߣu×úõ‹|zO©â»~¶Ò¶¦ö¶ {^4ã¡ýÒ-”åÈé_ï¸Nš÷ŠÓ5Ð{”ÊÀnñ ?J1K}ísÑÂÑSaáýÝÏнn/ïy§—Á4ìkÌ»ú.Œ¨«° I;gó¥9½9†î?&ZA7žÀø /Ýzœ¨c>Nö”£ß¦¾6 ÚÌÜ:êÁœ ›Þh®—ýí33ñ—°¨ E öŸ‹Að<ÖŠŽûá…œDR,íÆ}{6ÏßøëÙñÛÞ£ë·×çD_œçù݆¯åÆÝòHÈìîñOþö®WO˜é¼:=ç½Õ@—þ)wßÕì0íC×P±ø–ÌX˪¬¬,…¬Pþ±šˆ)Ú¢“óÜѹÕ!õâq‰˜dš8ºÏƒük¾;<‡’£J¬ô§.«Œ XK’$ !ɼ^qê=ÆÇêð {°Q#Îï93û­,¡@œõñúõë´D˜ùññé‹a&v#¯ë+KCn¯=½žê Pù€‚3Vu&ÐjeL}MÎl¥«ì;¾ÌªV̨§)|+6Ȳ½Ï'ý._»}ï©È°î¿k&õld¯,ãšY?ÏlÞcVÃX—"3““’“S’I­‹f6¢)¾÷¸¡ÐqQ}fö´Dh}Q Ù,‹uÿ~˜ž¡aôÓ$&Ãbe'_ ÏÔ¼\œ1Ÿ3d«‹!™‘••"¦˜l6G«Ê–÷~sþÎl§Ã$jôšÀ_ï™D;Wf3@Û¬š¹A¸O8Á`™V6³¨³zïü^mÉŽÕ$Â¿ÑÆ.Õ¥Û*:oĬô­þ¤õ1ѺšHôíê¹4IDAT¶5TòEh¦}!‰´5ȳ =Ö‡d½¦Ëw/îjoYðçùFuoœ§üæÙûÔ 1<ž¶¶Žv%‹Åâ¿Lv=í=Š•s¨kݦv¤Þà‹‡ÉŸŒ¥0½0qÓi»ö[·=îºkM¦„]­^ó¹¾§²Ï+hzÕ™4‹%E+éµdVÕ~*Ç¿ù¬Õ¹í¾G}Ooü&dh׬×`üº€ñNd-x•«Ö¨fH9çŠé6Ûµsê¿+ü·‡9Ìh[¹j7gþ¦u¿Ä#*eï{áR¢oGDk:XÈúÔU“¦ÁÍ ?IEPÿíNÓÒ# <æLù™žiX¯ý#.EQ·wm¼—("´ú¯­#;Ž s÷ð=Ø…Sãýºá.g>q ê:ê³(ŠÒ©1 ðìÐEsô»,iîµôZÌîÞÕ Éü½—æçÛ¼Ü@#Ï-Õ²_ÑV—Uìc u~¯¨?iƒ&NÿÊf4ûYÓõ™ŠW³è²|{éf¨B“êc¦÷È·¢(^åþNô—ï¢Ïš“}òuª0½RV}gì;(¡8Ò*,aAӫΤ)TUÙtéW¸ÛþÓ÷ŸFSB1Á•¦Àò]5vÝq$ïc«ñgÏŽ—6ãèw^`µ~E`ì¶žÕÔì0êâJ­VîmôØÅ°öxqž6€lÛý7¯<ÔoQœ“_W[+ÕÃxùôÒ|ߤ5WzüÎû¾Ø…Ué¤Õæ\«à?uÍ»Œ0/ÖÂ$›^ NÞŒ–àpóŽM"Œ,hzÕœ4¥µõw «l¨¬bÍbŸuËü‡,‹ï¼Ï<ß¾çïP"ŒZ¼-iÕ¹®šú÷Rgß1c-«¤gB¾7ííN0”XÝK 1YÒó1ÕÄеßëõâÖ×äçÏŸ«n™ôîH—»­yD±V)ùÝWqJ&üæ¤ýdÓ»nPGÕ-ƒŽº©˜ÞB'M(*ü*õŠKÉaéÛïZùúNtÚÆa] m|ÃoNçuÛ­µ™ùÏu-6Ù$f¬åŒ|\ø×ÞeÄ¢ýô‘j43i:vÒooKa÷ ÍXÿÚISŸtzG¾zUhË‚¦WIc2™ò3&ûäJ³yeQUn3i(ÀÐÇÕiì¢ÑM+¼Uðz¬åÒQÚƒúÛᤕüùðü¢àRÒû²€Ê_-˜±–U½Å+ìû^B‰“¦@I“ÿöª¬”T؃¼9RAm0c-«D"‘ü?°ÂãÒ])PØ}¥olœ4êLšX,.hÒþì`ÿ ;Žk¹\ÚCø«)}c㤩¦tÒ>|øçGR†(4"6¶8w¡@!Tüð !„4 3V„Ò0ÌXBHÃ0 @! ÊB†+BiØÿPo êkIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/merge.png0000644000175000017500000004062513070106167016212 00000000000000‰PNG  IHDR=×çQšsBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœíu@ÛÇÏl/Ý¥‚"&¶b €ÝÝÖSìzö³ýù|vwb+‚(v ¢ t7lïÌüþX\–-v)Y½Ÿ`fî½sæìœ™{æÎÜ/ B§ ±Ùì_mÐʯ6@h Š[B÷ ñx¼_mДß"ºMòçõë׿Ö¡ Íš5iÜJ—DµEz-ÎoQ¢‹@T$qZœß¢D¨þHâ!ºŠ[B÷@ùmÙ¹zíú¯6ñ›Ó¯oo¹5(¿-/MÝ·mÛöW[øm WŒJ”ß"º Š[B÷@ù-B'a³Ù«xŒ:–߯=x“Û°C«_mQ^ò yÉé9l“$œ õØ [K¥%«A~KŠoÜþPƪxáÜþS}Éæü„Ë+ã¦?Mæªi§0îᣠ~ÙlЄÜ/_¾Ï©Ø_Eæ©/ÃËx—!$*p§ÕÖ U{!ÅUåÕlú…¤gåÙZ[X™ÛÙX89ØZ˜ç¨;oQ·99ÙÊ’e±5l‹ï¼Õ»2ÅÅN¿qåR¢€u^­¾«;-®, Æï·ŽõòòòòòêØ¦Q½zMßqJ„..Lòë³HÀ¦ÀÛC=x](¢²9þ}g§‹+ëôz6sðÀÉáÛàйêË\50$¿rÏÎjb†â^’ïÛª¾©±iz­&,<.û»ªÞD´hܰ 5¯l³¥$¥f½üø=3—“‘•—•ÇåpžÄIJ!Wˆã¸æí¨ËoµjÉ)Öqè±+xW­Ì<·lÜ1ñÉà-ú"ïg“ fûojíenÂÌÏÉÎãpy<†ÒºöLYxßævÈÅšL*à‚x?ïÞ0ïߺWlÞÓåÃûìhÃ"x<^~jb:§éŽu=eÛ±!vÞÚqãðÕa×[he•‘÷åâüÕYûOMѰ<Îÿ±<~àW vÙªWk†ªêr{Éÿq¼YÏiÍæìu£'çËý &xƒIÈÆ>ê7‰ ßG~‹Ùuñš#‹*ièe³Ssrò ¿'¤%§çÒht=6SßЧêáWB\L£`4&+.9˱–|X–üöfäWœ”¿·¾˜çµ€kÅf³…ùOÎ^ý¡h¢uÛþ] e×<9º`ÌÚ—ûßle¥'»^@’fzl6ƒ†aT&KÑ\”¾wÞ˜­!±&nà õõØt .J]1thr‡UÁ³ÛÉ–s#ýÏ'þВͦƒŠÑØ®½zõR4¯ÝâUßÝg'-~áÌ¢)ný…póEzFô¤û;®½ôÞ¯q­¸ ÿzk¶Kµ­^QT¬ªªËíåÄè¥P3àæê–ƒ¯_½ïØuô‹¥é- j6 žPhÆã{vÑ6X%?PÙŽèFÈ+ÎÒ3ÐÓ7e‚Ñ(J¡R0*…ZÈ'2²ó-ÍŒd+–%¿¥1L‚Â2œÆ8.Hü¨Àƒëν*mAý~éèß2®·ÜÛFO®}! •äDëѼÝ3£Á¯ßÏ©ó«ËÔˆø·3»yE6^xg۹©O׋,Ç·4,Ý­ ãNÃM9ë^dH³Þîx’/,µ¢*Ö/ÀK\Ýò¾Ý\>wJï¾Cl8Ã!T%ä£cëÆ íÛwÄ”uÛ7´u°n>ìaÒí¿WžýÁϹ9yòä™óÊUˆ Z?Õo~·Dv°wyÔÎÞ’ÿ«G,›³êblÞ×û 'ô^ô).ü5{MP‚´ú—=s–u€#–ÍY}9.çÝå¥{ð Ü~EiBT3 êÖž‘{´lÕaØ„©Å¹\Þ×ÛS†öiÓÆsÄ$ÿ;ßòTUWÜ ¬}ŸÙxõDé¢u›-5éø’ $^¨j²ž³L¼4Z%?R—ÀÛóûæLöõî>`öªCÙ YŸ/075f™ÔbZ‹1V!_\ÀrE…\QW”ÏåsEi¹ü”Ú½ð/"±F½eížKá‚ø³™ÜáÍ€mé»qãÆ7®]6”¤×Û¸qãÒ©­Þ&Âúƒƒ$…#ÎoölÙ'‚ÕmÇ$W%^Á ’4£cªöeìÚ{Ö¡'ÖN² 3Fo¼>·æÛ}ðþ».ÿ=‚¦PéîH›ÎÝeׂä×2|‘y^Õ×ÃòÝŽO’ÿ ãCÏŸ?ÿMÙS. ¹³kfÓþÿ“.rÓÏzõÛ"°jîÛËýÚÆÉ½þQþ(îņ®ýÞuï5uÁ–NîÌk¿ãó-£º½›ÑX® èÛ³¥lùô§;ÛŒÞá8ÀßU¯¸›ÀË<©öšÚ?û{ŠÕcƒÎÝŒLï3ê«^ó¾5õàÕ¥37ÞgK[H{xå\P¬äÿØ sGýÝ~Ì^¨ÕnH—º§VŒt(JÎì²™ñýÜÄæ¾[ôõßÿ¿¥.Ô7> =‹NŠûuðúL?zl×€¦à?u˜TR]é^ GD4hn.]ĨŒ™é2aª6@öëdº^Ã['wéÝÖ©aË¡SÖD*I•þ@J]úú<ýö9¶¶xR·”K‹;L¸"×Ô÷?LXÙy…əܘäüÏq¹ï¿ç¼‰É~“ó::çù—¬Ð÷é>f¾‹-H(d?zñYÑE´¿}¿sšžÃT/6)[˜—õêRл¥þn¾=ç»M?åi…Ù6øÏ8þ›.LëÙðÓ·$!k_XðŠJ·0Ç…<ˆIð%DoæìIÞ½¨Û§ ›Çã r¿ìY³òH¤õš£'}=j)µóM2×d¨žt“'yYW§M{ -à4ò¿CSŠ.ýïx<°êr\2t™Ÿ?ß`Ó`Þ–Ä1ók/óÎò¯1ýlõÀ9ò|¿WaAcB”õí{¦¤<]¯¦c-ý¿w¾ò8øvnO{poų®;-[<ÔÌÑ£ƒ›1ížSÏž%2ó¼¯gÛ÷Yç&ba×Z²ëßý½~øÖ`颡²ê 7'M¾öq’»…&Ç’öèîµØ/^¦,¨ñèüèí`bñ5·lfxAßiç<6½øoj=poÑxd=j݇çkšâÂÔÂÁíÛºÖ5q­»cÈ •G¡¸ Nì7N6-äk>!LWµ 2Ã3 ’¶…pöÎÛv>°ðû¾eÚ6ùôýë)Cj‰»òˆFQtiýaóÏy×èæj -š&Öjý7ÀÀF:Öyøä™)Ó0•G  ¤XŒ“$ $`ƒjiiÎf—切ñ[1çý´½]>&WRL͡ҭ¿ý»Š:dë©ym€ Y ,ûÞ{àbH&‚Q˜òµ2^2 [KVÊä·ø¶Á~q WKÖ§ ?sæô‘£WÓ„b¦™ÅŽyCw”4éñ«7wÇ pG3é.TLßÎ/âÙl¥bêh€ â+j¼Ú¨ŽŸ»Á¢;OÒçû€Y½½’ ófâKŸ 0y—»ûFÉJ»Ž×bîtqÓ£…}/¬á§Äb&SÞõàg‡vm¿Ûtfp`wûþÂk¶Á[MÕ›GNÕ0hÀÆã?IЀus3qDñµ¿Ìfð²¯ÇðÄ&·– .êÜeáDBÐ[XӔʬyÆ¿Ëð6žŒ0n”îMk¨> å{ùÁ+Ñ«Là†.†4¶™ªMÐtÕ•§3›40€šÿ\ ²®7ímÆÉæ%ž ©ùä\Ê2«kýæâêc/“²²cļïrF2™LWçÚ1 iY\®ˆ¢‡`@’€$ ÀbPL é4~ZM}Z·SUù­¦ÏfqæêÑc‰“V6•? ¸‰ŸèÝš/ ¼Š¥—ºÍæ­óÕ7øfÓe».›åV†ìu†ì÷|}_rëðN;^qû™²çxÆø9MÞ=™#[RÌ®[¿«ô©™-ƒš™®é „ C@eØiXX,¨”ÜÌ¢½cfñ `ä°¼ `éÏT˜{âï«}º›P‹÷íäé[½—Ü6 *Û¼ogfl±~ñ˜Pÿ×ÌXÒõ™ïù#×*¦ r95Öü@( ™ó¡d Uf3aŒš<¥.[Úø4«(Mí³þjÌðûû™ìéZÒá;[‡(mDé^L锯³ÀÑX²Hœ[9<§ö– {U›€eUGöå*³f'cÖ×§P2nÕü@r.Ý0´ñ?ïjÿµ`¬o×úø£Û6*Úïàà’šnk(Nâ$†‘$‰04ÐÇ3œ Ø Z6`2™Šu•¢QÜ¢Ô%ƒº_Hp¹üd±bB²ûS> £kž+ãÂÄÀ[‰óž7•®! þ‘…ý×ÜÀnD,gS0˜¶u÷X‹ætJÖ§0À(r‡D%J 50b<ùœý4Ú{^dÓ´¾ÆÆ–‚ˆóþQ¾`˜—ÚR­„{Rž=×ë=£_«Zé…õMÚîén­ª¦uëOëâø¢‰o§Y_ßügôóì¹>çÊê+ëµµ¶“ÂK(JõqAüÊG) Þðr›Á¶Ä¢,~Ãn8Í«èZISr)ÅÇkÝØgéVŸYÓOÙ4ópE_Oc%ç®Ò½log3{ÙAü·d1ñöÂTåD{À*7²#çÚû8 yàü÷rùžm-å×ðæ?]uýÇŽïSl ãÕ1É•Z‘æÍÜC‡³0 ô%Ëå‹ÅÉ­\LÕw§Óµ{RMáñx’3O)ܼ;G6tmÞÕé;("¹íßîl\N]7ÞAyuÇã D„$¿-j²0kÕàޤײúE;“äÓi>Û#ÎuÀŠv™8ë‰<ÏÇIR,×&Ÿ'¿h±ÞH‡¤ëaÒ­Bœ…*RBî$;Žs’ü¼¨oß¾WRrÔØ¯ ‰—ø`ØÙ^¯”þªŸï?Lùô!.Gla¢Oð’3E:={=~έÄœçOReËÝ{·uî%oÿK’E1÷óÚœ‰ÝLXrͪª.¥ýÚ±—þºù:*òñµ…Ã}¸öÚ% e0ƒÊ¬uiV“3¾Öýw9…‡§G¿ñ÷j5zÇ{ä>ì޺˪¯d‰W€Qv ªâQ¨ÚKÏÿ6™¤îì¶øÈ§„Ô§×÷}¬Ù”ÃF õ›n[0°E»ý×Br ¢ÂçôæYtÛÛÔVìÙ{Ø>Iãª~ 9¨¬Útêƒkó„œÇ÷Nõ–$ÉB%…étz7#,—E§à8)ÌKîàDLкY“új‚Vñ”“üSJ~ûõÈ8¿-i£gì\2­C¡/ôå`@µçüÔÜÌP±®¹ü–“ôHÜãöÞ‰ìŸýž–cF^5Jr§•ƒÅ¢ òBÓeW’D°YlI#ΧsÖ.ɧMµ¦SÀÈÎÁ1ÇJéႸCi‚Ý=Øl00^nn.ÉP2z¬!÷ù^—ïXn`ïä$0nb×rvRž[vÛ¼µÑ Å!÷13¤Ä¼‹®¹ùÄ¿•e ïMííú4rmßÛ׿uû)öNŽ } 0¬ÝßÔièšÝo;Ít7ÿq> ù†ŠÍÊU7¬íäXC_¶@ã%WÿŠ3£g[FÍ&ý§8*úgÊ¢ßN®0ËÌÁÙ±¨ëXN3:¯{pÀtÎÊõ~ÏgUÇÍ»ÿ?×ç¹Ó¤ý _×Ûfm^4žÆ²±ç± ›¦X]Õ^ j É›0gO‡3võ|Æo?ºeP©›º®¹yÚ0`ûzÿ…ÿ†ÖÍÚ~òn¤\˜••Åäªÿä¼DeØ=:¶|PÀØ —†›îÛùv¾œÁ›Qð³µ­“‘ù!.­³«•‹S*µôÑ(Uù-–””¯_¿V:+Iðó ¦±Šô…›r÷™ ­WmuA éaGÏÿè0c”c©V*%ëÓ¸Öà öo$»’&™ð×ç¸D£Ÿ¶ÜìÎÈË'8(k£˜èƒGÜñ8>¸lÆÈU¶ïæqþwgëÆþ/“\аË]g'­Kx>H}E)3\-ÿøÎZ‹Ô¤RÐÖ !GÈÐWòVœ°€Ã0ÔW\¯f/²ßB…¡ü²«vcè+=³Ëð E£¢ŽððpWש¤qZJ~‹QXƪѳíê¥Áî­ÚÑ®ôbª0¯·ïý3ª[ÞÔ¸¸a4™ Ê}[þí<;©×¥VuìAq1glÌÚÖ·ìÖT¦€$_„¾æ9ubSˆ¤÷w†§7œ¯d”[)‚Ü{¯ÿåA[3”-¨ ZMö¢*2KÛ¤r§eø*£¦/žÒ[ó_ž$«ST¿ä`ËùUáááöö%nBÒ8-¥ŸŒPC™ûÉ„&¨é'Wƒ‹6Ð’êõMŒÎ^‘_Û"‚æ—*;r¹Qá(F%O·æ—B €æOF t·„îò[B—@ù-¡{ üÐUPÜ"ºÊoËΟ¦«¨ÅЍzP~[^~ý[Å—`•…Îê€vóK!~cììJ™m+99¹j,AhŠ[ KÝå·Mzt†Tt2¿ÍÿJsöÔS6 ¢ÌÈþô~~~{÷î54”Ÿ~H'Îß­Ço£N<óy¥Ù#‰ŠKÎhýàQÌû,¼¨mS¿\·œh(âZ~XÇ'Nœ2qâD­dUŒqËÏŠ‹‰ãTž)r¼Þ0¸í…‘yÅŠ[¯.þg¶| ïeºˆ€WÖ_x¡|¶QY$º¸íŸp4ý@ÄZÉ\þ$Á~ð¤Ô]4ôô²1î|ÿÈ¢‰Óf{}Ìx´¿ø´æ?ž~5ý¯Kˆš5ä)³˜p+à=Íó\—š’Å»"m:hxt}=,gìøl¡H7¼IàºöFʧü­lT‰¸¾z”¾NštÖ¤¸ÿ¾zc|||Ê{<ˆ E»ü–Ê´tp(! [+ñÖÜg­¯\`J¥ðÒê·q̶›EepaʼyóJ5hÕíÐn&,›6Ã.Ü©uì«cqû¤hçDë»<Ø„*S¹Ï†Î¾Ýmgˆ˜_$D-§‹+Ï€€ÏãQJ\¶*V·œ¨qÕ¤˜†-À˜1cÔ(¿­Td~+Á©ïš'»ôλ|pÐÜÞÓ,¾¼ªÝâÍlÇwïÞin»¶w@íâÅ‹‹Nlzç„›©\U…¥/6ê³rO/'éS*9]\ 8‹L›]R¡buqË íªE\5)¦^V–Rß—’ø¤šxæ§â¿¿¥Ð,V fâÙr>bßîñM*¤YBœsbÍð…· ÏÝý×AEÐÄÜíÙñ6¥û=ãe-Û2¨‚_§‹[‹D\"qµjo©a1 [@è"üý-F3<<ØÁ ùý[‘rPíøñèä`ÖB™Çîo¬ìñ.Ì >±ÆÃkBFÃ1×nn6))AÖÀˆ‘÷9OÃ}U¬.nyÁÛÛÙ¼_vPºB"⺪½¦Å4lA†ÀÀÀ? ¬ÈÃAT(*ó[çÞ&»&1*OóüÚµB¹&<}º””ؤ­8ûoŸc¬m~~~?sËûüôìÛwïÞýD1wÓ¡ñݘRÎÂo·Oºvã^ÈK©³ß– Ó{7ñx"Ù2õF:$ãù»È®T•߆ÜIv p’ì%íéªÙ;>MØwTQvµÊèùߦåÇu[ì²Í¯{î»{3Æ‹¸®Øó%½ßõ³SÕS³I–b-ß%K¾}ûÞ¶mÛ%K– ñÛjH)ù-.Ì:tèPÉ*6u-ž:$ÿªcÇž½Ù49CÏ‹'æß£7*sF”Ï}pû3w ÿ¶Ã}<­TôM™_sŒÝ×_ݳ}CBŸòº¸HCk'''#½ùm…ëâ–5"®²J­e“•Eö>,y?ÙÀ@^Áå·Õôo*O·Êt½Ôˆ¸jXLÍ&Í¿›×¤¢RÑTÿö7@—tqU IЪ/¦a ]áøþV¯íÉ-/nFeH”~•’þñp·ÝGÝéøoëµ ïouüþ¶lÔîºp²ÚìÓçV‘-ÕÉ7@j¼/õŸ!:š_ QzQç@q[.~ýÛ¨¨¨_mB;þ€ü¶ÒøÓôoÑRøƒò[â·é!º Š[B÷@ù-¡K üÐ=P~‹@è*(nÝå·eéß"ª”ß–¤‹¨zÐûɈ"þ­ÎâÂR÷@ù-}«KhßF? §º·¬óKåsþme€ôou­Ço§V…z9U¦[ÍÅoéß"Ð4nÅÜŸùôþæUwÅ­Xý[› oW í2p¿\*›S=Åoéß"T .¿}°hæñ´"¡jB˜ @Ÿ4r¸\}›‰»×·¯þú·mXÇËOMŒOÈ?RÃÎ[;n¬nâ·€ôoÊ(=¿m2l4“+ÑÇ‚g«ggŒ[<©£\º~6›]ýõoÙl:0¨†Ñ©†â·€ôoÊ(}ü¶¦G'‰%!Î œÂß¹`h[C墒ý[Åõ!+»åÛ -‹þ­_ß¹›6ÏîÛ/`™ì¦‡‹g,L›ñòLÑm¿É¥a®nìäõoívÝü5Ô¿•Šßê` Yow¯9=xõ¦_%¢ RaÛƒrêµ'—ÜH¸+£‚©¦Ø!Öš´€ÐE4º½$ÜZÀ«³@UÐÊ¢»ú·ÕJüþ-B-¥ßâL¿y!b›,_߇r› jÌÚµ¶Xå úëß q’$ÅJ«W+ñ[@ú·h:~{oåÄ´fûg4—,Ž1|îǚЀ®_O¶Võ׿U•ßB5¿¤‹PFï'Ç]_:å ýÞÛ™Ò6€†mÛu0a*–èß²ÆtñlyÊ}ê¡ Ô¿=µ~úÊÛ†—«Ó¿6zæF§ ú·™šéßV+ñ[¶u4–¬‘¨×:©Ò¿U(Æ0°×¤„.¢nü6òÂÚn³¯ž9¦ùSVÝÕ¿­^â·€ôoêP™ßâü¿eAóŽÞåª'·IÀãñ˜jð«¯þ­'żo×®]“ 2¬½<Cõ¿¤‹PFiù-»áƒ—a4}ÚÇþëßgJW‹IØéïwâ§œ,…nuüÈ6¹¦«­þ­‘ƒiÔ–-ÅÓó3;õêÞºŠßÒ¿E(CSýÛœ÷áo³T¾¾K¡²=;¶©$+MôoË ~ HÿQåh¡kÚ¸­’7*t‡Rõo«¹ø- ý[„À÷·¥éßþáâ·€¾¿Õ)þ ù¥Ôëßþáâ·€ôou 4¿¢ô£Îâ¶\ ý[Ä/áÈo+ ¤‹¨zþ üøm@ú@„®‚âÐ=P~‹@è(¿E t”ß"º Š[B÷@ùmÙAú·ˆªå·åéß"ªô~2¢¤«s ¸E °Ô=P~‹@ßßêeÌoÅ…™9ŸlM¶¾J´Q… ý[¢Œã·ç&öØŸß5aÕÀKi*eˉz¹Z Õ_´V9¤0'Wù¡•_½éßþ9¨‹[~öàŒZõtÙ½7÷¶Ò+Û.I‚Û¶©Ç‘TŽÒ­R¹Z\”⡌¾7 z‹Ö*%12|ÿ¦m\j¸¶X#·©üêµHÿöOC]~Ëã䦧§Ë®á$Ý¿y¨îÇç1*†ó˘î&îLÌÊõÖWž/IåjBÖ’%Kd7 sžù/:\k¨ Ç«¶¢µJÉý6·Q×[¼}ÚØë}/±©üêµHÿöBò+”>«,z49Ýöhðr÷òìøíïÑ¡£>WÜ$æFº×ï{øÃEåKB”>­}‡µ¦¼¼0O2Ÿ²0/ÔÕ}νϿL´V‹yXI˜4 žÏnÚçf÷ôèõÒ-ÿkï°:kTêç¿%‹©aÓ»žy˜šÞÒ¡f“lÛålÍêCHãT‹üV÷`ÍÇÜ…³Ýʹï‹WÎõVºI\í±éýîå×;wÜ_: ºT´V²˜õvw@@À“|a9Í«0¦Ò™Ù‹ÔkWËIÔâKn$¨ÙT±- t-îTæ-¶ë¾½«Œ¢—’¶?õ ļ/ÇÒy—=m@˜ó1¸°vZÅóâ«’«:é·ìNÆßwo¹°K\ÝDkµ¥üêµHÿöÏDÓñÛÔ‡ktÝ$ IDATïqN¿ô–-¦•¤­äÿØKKõjNs£Šy<ñ—«ü[y„n‘J]ËÉÕJ(ˆ»Ü/ðºç¢KC˜r›ª›h­¶”_½éßþih1~+È~>qÖ =Œ–Ú®’¶päŸ÷­×o“ì«éÌSC.6ñ;wjb=ÉV9¹ZÀñ³‡,3hÿ×ñé-{šÕM´V[ʯ^‹ôoÿ44¿åg=Þi„áÈ]á×W_œÓ-ð”v* /ãÂé,æºÎ?߆Åè‹O®~þ÷ˆE"z¶ ª „\-ùߤA/ÈfOW*ÜUÝDkµ¥X½ö'‰Z«ö–j6Ul ]¤”¸Í Þidž×ŠË+ûš6qçÔÂË}ü÷?+ÛÎÞoÙmZV~ÔûÐ{7NþwÕâyÓŽÑñŒi“ŽJ ÈÉÕ~80~ý#Þ¦ Cªäª«h­¶”_½éßþ‘¨Ìo qÎÙm+Ö¸Ûvìò£C<º Ú“ÕÕop~ÞþÿÍè¤ùnq¶W‹‰…€U]ûéÛÖ´wv©[·®k¯>³ãú[ÖmA3 Y¹Ú¼èÓVÛ÷ZHÿríC‰ÖÚxùR1¨–¢µÚR6õZ¤ûÇRJ~+ÌÿpþVÆê³a#ÚÖ”]ïÒ{É>w_…–ÙNãûç›ZרQÃÆÂP®Ó{jé*Óf¶l6MV®6ñåS»Úu òÜ–Hù¶véiŦUOÑZõ°­j;9ZÉ®)›z-Ò¿ýcÑTÿ¶ŠÑD®VBÙDk+ŠÕ¿-›zmù[@ï]èZèßV1¥ÊÕJ¨þ¢µÚR~õZ¤ûçPý¾¿-M®V­­@Ð÷·:Dõ_J½\­$Z[ ý[Í/…(½Æ¨s ¸-HÿñK¨~ù­î€ôoUOõÍo„*>¡« ¸E t”ß"º„|~û%êc©uHRq̻Ƥ²•*× ­)ñ~2Ð!P~‹@è4”Ö": Û":ê'#ºŠ[B÷@ù-¡{ üÐ=”|ÇTõvü®ôé#/~‡@”åßßJÎ6R¡3’³¿Y_…††þjs¿'Êó['9ó@æD”þ_Õ6êrŽB•òü–ÅbÉÞ`ån¹Uo¥!ç(ôøQ(ï'« Z·ê‘ú9 Qy¨œ_J1DQÜjò¢²Q™ß‚Bf+¹÷j»’à~úü£~ƒ¿äC>Qa¶i¢O¯Ò×Kdãå·ˆÊ@y~Ëf³e{ÈÙïïÜÿ’'9­:ôhgÁä¼~ô²H ‘aÜ̳•¹b#!ÿåË—ž½òr²+é€$ééyÖÖ%¤wr??L`Ô&3ž:´êdLÑúº!æÄgv¶%»$$AE¶1Q~R:ݺ»¸Êo•Fó°»yhfni@ ‹M¦'~ç§§qu«ÅIypÿ+ÛÆ’•šÁ—æ$Äeò¥uqqÄÅÅe¤¥JW2-ìíM™²»à¤'%¤edeçËÈÜÜÂÉÑž®M¤á‚”ë×CfΜ.{ãÄ  nÅLLøjhiÅËZtœô´áqz4!WL@FÌ눱ÙÙ¹BÓ7±©×¨…»‹%P袇Aa#}=I4@†¨*J[1?æÌ…³·0È _IJriäfñ•C'Iª>›šÏÇXT(Œõô“IãzÆ?‹S›7o™–’ÌåéÇå}yÏiYÇÍšÂ@’‚Ïá!oÒ±úõjG}ØËåÛ§g#øø´·Ñ§^ º¯Ô6·n}\ÙÅÒ¸ööµ¢¢¾þ\"™õk¿ Á…¶mlézL«¸Myv‹ãÔµUݹ±ßàÓÃkÏbòuêÖ·¡«‘ûõË›Á×ò‰!]¨ìÚ^µÞ}÷¯G£¬Q%hß‚]¿#j÷„™,vð<ƒÖ†bn~~¡˜ÀqB”wþÔÙIㆠqRL 3¡ƒròEJwù=õK˜™9«0—#’xuëBŠY“É»ZÀ‡oë¶jßÉÖ±¾Ë›ËA7_Üœ'&H’Ò Ac++ù®xèÕKt;ƒÜä1‹Ä’•"‘ˆÄ¹?¢¾DEEeò™}Æ«g¦GâyiyCTBˆ³Dô hBˉÏå ?ý–î1~Q7“ìÔäÜBÒÖ¹õ@NÚƒ„Ë–-“³x&›fœ¿Àh5Š—Yì7YO"‹FùmÁ›ë;.åH6Ùxõk)üü(—1º¹•¸ iÀdÞ9u†Bc9Ö­çõ5ÆÀÊÉÍÄ$æä3 %-[ul_ÓÅÑ’‰Qt:‘s?Šk0³¯‘0':ê#Í ‰ð ó;ÙEœxŠunMç@wqq64Ô—kŠ…Æ`1t:F`8 8i1"~þ϶®Ó¤ã€¶­ÝMdbÌ.AÒétÍR˜ú†ÐkÜʆ-¦Ó韟'°¬|Ô7ÏŒ‹Îâã„À¤A×Qž†z"F~ I¯íÊxœoâÉÀ…hüQùh”ßš5é1¦½•ƒ$IŒJûÑaÀØd\ª˜mÞ¡_‘‰)£³¥€^Æ-ôY†õ{ ¥[X2©@pÖoÜ9{a >€BÕcbuRd€OIN}g[0øÑ 9œÄ<}'kBÄ £ºY1#>ˆl[Ó’¹b¢  @Î*\v":’Ä×ïrrqæ7ÌÕÞçæå¤ÆppR²Uœ˜˜Rú‘Ö¨©OÁ2ßfÔî†á9<‚$ á®ØºcCœŸQ´E`ÜÌøï?êØ²§Yöf&qÅš¸(ÅmöÛ›7>= ¶õîß éëcþóI ]¯æ~Fq±E¬˜“%Îyþþk‡V I‚ &¦¦Y±ßq€’Äqœ— @|áŠ}ëš$Å“±Ÿòl†Xˆ r%0M™ÜÄB¦1h F]½dà‚ü¼¼¤Ñ|Q‰ÇD$Áôè1¥´g]G7ÆùY…b=1§H¢€ Ic'#QA–šŠl–àc"˼¾†Ö"åA£ñ[Ã]Çt¨UË”!ÙšcÀÏ¿[£çàÆfz:ŒVÏĘõ#7WÚ?ûý·(Ã>>ìä”l¸xê$7?Or{d5jÓÔ HR€4Ч'$ð…"ξž_N|ŠH„@nOÏQŸÂ$E"åy2II.‰DEù-##¿|Sñlˆ9lØWW§R=’üíkŽg˜3Å"‘ˆ$™†ñ’y"k¾H¤:&ÙTBœÑè"‘å·ˆÊF£üöùc¯*$!¤Ûø ìdSßÛûÃñû¼æÃé9ßî~#Ìu£“Y²9dú§ ¶}SSVF&Ü5Æ<ɹL׳¯i+HËÐ ©&‹(4~ü3V6tü;A¡Ó)^ø.‡oßÔçåªJM1 0 ¨t:Šò[ ©ÍccbbJw …jH£äsĤ…N§ÐÙÔ”ˆÏ4_{º¨Äíš AzÿÆ„$…bŒQXt:å·ˆÊFy?Yîµd\(j~8“oÕ|€gm£¤·Ÿ¾Å'ÄD¾ÏbÔ6iMœ“Æã8733›N§ÊÕ‘+2£[ëQàßÓ×j0D* ù|ž€/àóy­½»Ñ´{YÊ¢¾QîÇÔ6d> †ÎÞmÒoß;v°Q›65,-™xarRü«w1v­G4r¶ÿþ=^LBR<×´“‰óI™1´Ú)¡9Êó[>Ÿ/ûf²˜$‚o‰yù¹@#ùÙño‡þÈeµé9¦Cmâöõ³{8ÎµëºØ3)/-òλÜ6'[Ù‹{d>{ñäœ?}<ŒB¡`@$Aˆ´h¥GÁ€jݾÇh–…£»0-&.:"2…åÖºÇèmŒˆ‚ïß’„8 ”¼êÛ×4•32ôò+: …"zvõÌæ‰s² 91F£1,K6‹e_³f^b¬V/]0kº‰ž?ä²' …ù’5Î-¼k»$D¼ùò "LHR M­;ôß³'í;W $ñ‚¼ws~F¬P(ôý-¢’Qžß2 ÙÛ-ÃLj;Õ£‰D}º¡ÅÑg(õQ?Kþ— Z”ß"*åù-F“¤üGÞFpNz6…¢Åg÷rŽBù-¢2ÐlèOÛ2@¢q D声›¶6+ãI¥ˆô~[d‰Vù­œD\Ú¦f¯¼„O|5‡F9€ /´Çȧt:ýÓÛ·‡<6¤`ðå£×& ¤ª?{¶löï5Ì͸ )1íñ號n]^eHÅ€—qv¬ß9>_Àçss³3y|Í´Ë«°²¾Ã…)Z;òòmi›®ïÙ|ìΗ/18ÍÖ¹ù°ñs¦öo,Cáß%—oo³ •å×” HMt•”:G?¿•NŸk©íÞãnl}c;²3ëRKæ$ŸÙ´£áÐþîjÊܽÔ°KO;õŸÞ^»¯l¨m$W ¢¼ZªÓX,Žã²Ã?äÏËÜO~ue÷î³ÁߢãxTCG—^cæëROºõãæ)k¾øœ=8T²Hˆ2ÿžìÉòØ·ÇߘJB˜ºxüúag¯R‹æïV× ]¿|ìŠ3W7–í¤RD·jœ¦‘ަ¶Ä]Y?#œž PtÕ_0k¦Ä¼ä$褼bê£]“o¸oë–¸ÿCö\ws`w˜ägcjffanaH‹Ûk–÷ÚErî‰X7)¥÷¶&E¼S‹†ý}=nTಅš± ~< Ú8ôCօݰ,ºlñÜ1ñŸ7W6¯Œ×Ûî5R×}ÊÂŒŽ‰ùõ9Û|ÀœÁ2ÛñÌ…­žbÅO‘Ÿx?˜´~Ûœ>ZMã®”¥-ÜÖÕŽAåæçrÄJÂC·¼*q0`ÐÿÂyã.YÝÁÝ@œù*øÌÚÀÁO–_U¤V%ÈJIJ)R¢ Îöi¾·Ó¹0K´ðb³_jM팙š4Ȳð^ß~ÏôïÎÍmZeY)q[gØÚã]€Ÿ{¯}ß`ÉÊ}GŽIn¡‘Ûª˜L¹F— £¯ â>5רèt¡2ìºzÛ.J èPwîñ¹íd«ˆyŸç\Lú_xÑÕ!9ä¯ÕWÞùŸ{êר l›x¸’ ËïŒßÀ¤@SÿE?Úû÷èÈRÞ¯$nŸ?ù->>>>>.æc^̓㜜ê89:¹92d‹ñ2/vöåõ£åŠ-ôøë@­º›',Y8(ÏìʪvÒõñWVÞeOœÔ­–la’(øúáU\|BBB¼„l¼Þ™“«X?ç’¤¾êèׯ*’psî~'L©/¦1ôØ †°ÇœÕkzuXÖªd7‡œ;ôBR½ÃÿqÑ+Š1/ê¯+É;BÝ4o°ÉŒù±> ~̸SGE~WáT|~+&ȘsÞ( <§Ž"‘¨Nݺc‡ ’¬ágÄR}Ä2ª¶$.‰DE^óÝ~ä5oIüß©CÓ¼WŸô­'·)9ì‘ùðFÌ¢*V›ºÍ›äf([¬åŒC·f`€‹D8`ìÖM¸›_¤ìlSz‡SŽòä· ï>ó,k¶ön6t” ÃGžºzцQtu—5•jØr· ™ D…±Ñ_cSÙ^‹Î!×^×ë8¶i"­B¼Ek/Ù¬/‰¸©Öl~ŸÏå?›4'Ü¡¶ƒƒ½ƒ½ksÆ×°PûaT\,ú9´‹D"€‹*Ï«Uœßøç¹©ë‚‰®F’A V—޶¾{eõ•ÅW'A‰ã¢ +‡údÿßù-Î,LZ>õù‘Ù°F,Šd& Rõ[÷3æîx•öOk­O*E~M~K£`Σw\˜ìZ¼Šà;¸{ì_²@²¹µÿ_ù4U[ŒJ§«¹•Ô¿¸rø¡ǹí~,ÿk.æn³Ö]ûu*jÿëÁ(ëŽ3$ÕI¼ð\×mŒ§ÚÖ W+‹ùû£éjª)£”òä·“×®•ël̸‘/žf«/=@ɃýÜÔØ¨/QvTnÀüY9?¾%dµõ?}È~óØæ§¡U“V2{L¼3ï­ÝÑ.t XÆvu›yvXÛ w÷ì­Ý÷—”á$]鼯^ÐéþRMC/ HÒ’Í Ó© MÞÿèÕªÌoIÕаD—çëá¯Öí¦JZаAèÞÂ<ðP ÕÃÊ&ùme r¾¾úÉËW/N:#ùÿS<§ôÊ% .®ò]z>Ú­žyÕfÐd¿nÍ­¯¬ð¿û¥dó§Tži³"©>\˜(&H³æfê[4knÆMŠÒú*Žvú÷o…^;wlãÊEc‡õmÛÜ '!?n}·aS÷ž¹]ÇZ/Û­ÏæÿÎG„‡Lr×ê³ÙFACT‚ ÷ùø…Á]Ö/—<ÝeyN7¼k§¶Î5ŠÓcQÁÇiCÿž}d»µL#"îg*ÝÜŽ¡ MZðÖÓMÐM¯.L%HÒ¬©SMÜMQ6ç§,#7íèÊûvXÆÑ›?äJ~Nã™45ѶA³¦¦Üäª;üJÉo 0öÎѣ߀|LàÄ‘£G1›ösû•^›¤^ÄÅU¾Ë/g/=tg¤´R¿~cWQëžüéY,V fÛ]( *†å}Îw 5­ëÕÐóå­J$ž=}3>>..6îû÷èø´\ꃻ4uqn0¼S?—ºT ŒŸ? €FÌúTÓÑÎ,?æÄü›Ü#O[)m“e®> 븩³­š]¿Ý½J8h÷¨ºÆ²+yÏé-ÍÜ9aFlýÅ ^U„Ê´£`Xö›lES³_fShÆú?Ó{»î‘‹Ûßíí>cìÉF·GÖ/–‹àl[¶¶ ²íظ ®RŽJ•’ß’„بá´þâÂê‘ ƒÖ.,]¿ù&àÓv’$Tæ·ùv]ÀµV'–û¢Ì°¦»¯îogM¼xDضhæltËn¸hM,GàÄ¢ZÒ©©œŸ­é÷6c=>ÿ@4Ø^Î* Ò!GNŸÊ°–O¡5 Ìù-.?|íäìÔe—³‹³™pW¿™v[ÖÎ,6OÆ“îiû^‰Dõß½Ú~Ñ™ Ù>@aìÃù~‹>0¼on*VØ*“„¤–ûü Š\ o¶Ùx®¬”æ·OöO¹@t¿»¸‹H$ª@¯Vm~Ëîgνóã$·áÞ‹L}ë±’• aÔÆ‘‰A«éÛG<›;q’Û­ãM~ö–­”¬tÞÏlV£€›! Ð­esà2óËò[ŒB£Ó颂ïÿ­žs•ßçÖÎAÍ.,¥Óé’kµ¨€¤¼šFR¤‹¸0yiÀµN»fÒét Ûn=¿Ä9S;w²î5†µþ¨ë»†¤^£±œ] XT ê2"¢yÒê3þò¸¶hëÁ½§yß…>Ÿ]0j_Ê»Ç$#lœ¯ùLS7õÙšRÊžßÒkÿ»c£´˜0¿//{>Géó\#›¡¼ÌYtú„«Ï·SÈdpaöã+Wµñšpfc€…²ç·tF‚Xz€tù’×>HšÜ\R€€QñskÇn¾ƒ 4dÒ*Ò«U™ßÀ„ym.nÞÙ}zcséÊäàå§Ó¹ƒÿ(IS%ù­äÿŽs Žè0~à +%㮌ˆŽ4¡Õ¤Aà|+`š¸*¦Áe \ã·å|3þùÑ¿·_i1aÉÕýÔ6z[°o~9{I'ॾX8e&wÐn¿fÅ>qÞ<ã¹¼úk›µ½ÛU7 S7ïî8ï´¤ÙF£’¼‚¹E#öývÍ2tˤ‰þ‹z·in"LzòäÁ®ý×›O;(’æ8ËMóc‘ {åRUFC§1Œ<̈´ˆaë’OD$PYµÝiqï8¢&ú%^͉¾{æpÐÍû¡¯„&NS7žÖ«¡*3XÖuø·´s07 „œœìììœ{ð’7çn7:/écÎ’–˜Óï­÷黫겋·Šòª&NS Zi¸ªyAWö=ÿñ¿7h×ÄaüKú·kl€g½ >·n÷õFV-k]ôD +jœÊšdÏKïq£—»_]7wH=þ›Ý@ó âašãôze0XÙ³HU•q«xþiÀ$Y§žý²s÷;9ÅÙr1“#¢Q1’ÿ#‡®—À62bëÄ“¾3z¾kiާ}I·ë1ñh@Ù]Ð ZrXØ©ÏðŽÍÓ¨ðjÍÿÆùï ð­+)c×mwÝš4áH«¢“›°é|³v;·:9kÏN¯éÜdîŽ c|êKÊã‚„Ãi‚Íl´º f‚];ÒÛœ”Æme üžßßJïR·qï0±àS–~ƒûuiãFÃ@†µnšoðäã‹Oy…bX,==}=KS I’ÜôÛ„].lö•VoܶÎwÃÁÿ Æ¢SQ^ÕÄi²áJ–ì0—í}©qÿ\lteÏŽSÛÎoLPôœëŽßpr¼O=ik K;ûšFÒE*»Á¿{ý&­<ºó‰ÇL+[ŸÑÜMÒÃ,^6Km&K®koU!BhhÊõî߿ߩS'iMÙVJÛ7Ëûn®½åÔ„º’ż/¡7_%0Ì›êÞ0æøÌ)‡>ðÅ”^Î,nW<ÒÅK|ñYlæêíÑPúb@ÉCÁ£Þ½JÊâ™ÛÕrr­cP²Ìù‰>!ƒÿ¯g-ùZ„@ fÉÂ?.Lô é{Ö2ð²‡áãã#W@+§Åž;þÃc`çšú Œ”àÓŸ]ûz©ØZ5TˆW5qZ‡¤7dÙ /õL+’ˆ1&]û[àÅ©=Ø¿³»Â˜–Šc/MÚ÷úÎ^eµ´ä^dÿÍ›7ŠN5ù-ƒÁP¼ch’ß6[qñ…AýùʘYïQ?ßo¯;noè8%U j4î9 ±Úc¡ÖoÞ¶¾Šm¶­>Öwiz·c¶Œ’É UOîuA\¸;gÝÍžeÈC䮂Jý¦¹Óœ†“Ð!CÍ®£´\®h*Ä«š8F£É~s[Óƒ`T–’ IDATxœìe@MÇŸë[º[PQ±1P,PPlÅV l;Ä»»» °‹î½ÚÛ÷ÞÇqÜ’Çþ>(;3;3·»÷ÜÌŸ™‡òýûw !!!)tAªº$$$5jUw€„„¤CZ’²CGQ´ªû@BBRS!u’²C'þ{÷î]Õöƒ¤\°µµÿMÞS’ …xØèRÇ$5—â&ƒ¼§$„øa+ÔAHADº‰ä=%©8ˆ§«P!@ê&’÷”¤â ž.òm. IÙ!- IÙQ)äú[UÝ…Jeà€~R)ÕGpR7ûì3½[å4|"ŒÙ¿}]ºÌ\nvB´Ð¤¹.­°{N§Qćhzò7¦a+Mš¬³Id£‚:H›Ö-ííí«ºÿJxx¸M‰Å¢¢¢Šß2åuŸ›(žÈËûyéQ¦T¢v½F}[h)†a¿$WÎC%à¤}¿e‚#¢Ï ò6n}ÓÏo‚Є÷Ö¥ç—Ãgàfu [µm>ÓÕ ¨š”Ýë_îðwԥɨD&ÄÍ•m³Iª333Åÿ½F¡Pˆ©¡P( åÖ­[Ÿ>}jÙ²¥ÔY¸PÇ‘LAÓâ.>Jí»ÍE™F Ò^ôùOfÖðµcÇê3ËðA~‡áÚ¶õ׈C:[gÎÜîuÿZ“ˆsÁ©íÛªÓàã¹ £/™ ç li@‹‰N8päáâ|—ÃÌYÚuµx·üJÊ®aÆeè@m†´ Õ‘r1%B ñ¿’æCÁY,­†3F7”L¹îÿ+¦s[e[ÅqËpŸ_w©äu«. ñRt^ ÆÏÞœé1Û¥!‹ ¸ç³ù>¢ú1núúç¹Ë·‡W_åÔë7°s=hmÛ8ÐB=UÓ”Èj2¨}‚G¿°`â`)P)äß:th•´{ùòeÉC%ïEñb¥ÒAcáìì =Âq¼k×®ðôéSÇ•ì ¿ ñpgÑt¶TI‡ ¼û!¹›v‘.q-uéŸ.€€ÃAQLqsŹsགྷ³µqXþ®YßDÈ!º“úßKV£zÀ% ”ocršÑ)M£¿Y@ÑwTãŽÌ\l£VÚ>ÔNTPQ$ïEnnîŒ3öîÝ«©©© ˜ÌÅ÷”˜¼;::ŠÓ%‡!%>O޾5jÓ­‹†T: cÀícw/™×ud×µ¡¨Î¢P‹WK¥ÍF&Žco"J‚Õof¡O£üwÿÑ©_š{6Z# Q‡ãÓŒíºˆëOx˜¥ßÂN|è>ËîÕ†—S7¦¹¹4ïÓÁB­èh£GµM÷ Öú%¶N¤R2 ø˜Ì¡µ‚,ÉR4ŽñK›% †a¡¡¡gÏž¥ÑÊóe1yyüøq÷îÝʼnϞ=¡P¨L i/ö|âoØZON>uÛ&·‹gžnºp»c›Ù£[[°KÖ)qŒ³ãø³‹ÍX=¢Un¤ï¬åþLþš!ÆÙÿ,Â:=q±ï™˜V7–øP»^³†WnºrüÞ™ËzƒtÛÕ´0· N¨Sbë$bäZ¼ø«}GÚÎ?µuháó‘÷ûjŸmçß6¼A¥t¯j0´u=ahËzÆtAAlÔ‹CÛ÷~HBKÌ’D¿EϹÓFµ¨kÌIùõ&ìÚæCp%²Šãëë ¡¡¡¾¾¾ëÖ­+ígyðàøowwwI……>ŠŸ" ųðó’WìÿÌÚ‹ˆì&íue–¡24FŒwíÖ!jËÑ—kÎîŸdQbµTºúÉÍ£K, ÞrÛê¦uµ Ÿáز›vi§^hgøB¶>Cò$Dßh̸ž#‡åÞ¿ófÿ©ÛÑ9Wõ©$l}º—#.iffvâÄ ¥zR›zŠäê 4ƒÞË÷MY8l°ÃÃvZLÀ…èâ!K3´†¬îg®Â¢‰ºYß=+g¼¿|È'ð)ª×Ìuèä•Ûý§ŒY”Ê*È’¬AͤçÞ€¹Ñ—·Ìô}Ūc»hå‚M¿ðP¸â,IÄ—×ÏÏÏÏϯxºÌCyÜÝؘ݉©ò8Ž÷èÑC2¥K—.„&"¯ ^^ªÿÚGlûN»Û æm¹–—ç<Ù^¯HO|º¶•åŠåFiBŠ¢(W ,^­/‹bÌ åÐôßknåN_e(Y¹ 2RóÑ:ÅÇ>ôn½;q2VÞ~ˆ: ’rÒøK|zLLŒøÒ‘&•¸D%ë Î+/~hçé±ÿíÅ€—G¥ë_x°JK­,¯Üj ­§ºñ[{ü@ܳýQ‰®—vŒ6Qߟ« K²§%!í²ÏñGYO}ýÚœØ°Äæ´[*—%Õ%5)åuâGC*—F£‰Ç Ää¥K—.Êô$7!> ðÚÊ~Ç*Àιø´­Á|¡ëüž&…•cÌ¢§#ꀳèBzç™ôþÞY˜HQôåÃËIZ³1ÜiúÐözê’éÔé‘)q7¾½ŒÔ´mbú÷m‹i=6åYAƒý°4$?r弫q—¨d„BÓXmGÇö“§º¹ãëÑ»ÞM<úªƒ–è§صæØw·Õ´TÊ „®šüµpâ ª–2Y‰È˜úÚ?6ß§d~9&pšØÑÈûI¦¼¬rýÊB¼»}þü91â …?&¦0&{, Ä8÷®…ºÿ«•Sçµn6ÄQצÅÎÜ黃P®‹Oß’ç)¸÷9úTbAÙÞå@ìÇÈ­ÇÞ˜ê;¦™ºTVÃZ©÷ÿÀ` ò.Ýz÷ázâÔ¡MšÔÓJŠI:y:Ŭ]wñøäýǼ:Hµt” ¤"FΗ7ôs\:œ£“c1t×J§BO§¼¸Ç/†·ò^«bp,ý¯Ã…®?iÅ4ýõ„¼²þÂPk¦I§ÄFN§q!‘ÏoÔB›ñÚL^–T$Å ™ôìÙ³LŸ­Ä;±ùÀq\l>äé /û)ó‡»4*òòŸ•Ýö‰¼«(CæY’Ð#×êÓG4—J¿|>Ì)‹NzâÖ¦7¼‰Sl!àÛµ@Ï…e`Mõh*]céŠ!§N¾¸~åÙŽÔiï`7g˜Hæòs®eb‹ZI¿T"QLÉþ æý7¶ökñ(Uxv™£d£^'‰P3ªª‰h7pXê;×2ó•÷Œ­hÑ_HYº$r‹(# \¬µ…š‚,©¦Kœ~Іòþ 2ïQPPâVd¨µÎÏIf…†­ÛL•H ÕǶ•Ñ.Ídü§»hÀ+ãԸ[£ ýÌ-ªìçj<©.l Kó±#LuØÈNÃ0®€Æ¢€Ø$!ì ˦C WEçòDY„àý®ŸpW“ó¼N½9;³ÒzYµØò\6±Ëó3;ü.<åãÊfÆSV‘w† jAŠqsåe©Y©¤Äé·äD´xzñÃâ%>}ú¤¸™'* ‚¸õ©ŒÙbÕHñÄ£ÏÌ.·V¼È³ïgH—ÐS‹~,ŒŸ½óÁÚÆB:¤–Œ²:d;å¶1tòÙ·s-ŸÙvž7å”ãÁ±+£UJ;÷5ÞÎÌu³'¾ŽÏW>‹@Àù‘+Àë6Ô‚$Q …Ý^“•ø_–€“"/Ë kÅ}¹_ó¢’05ë¬÷H}‘Â߻⤼2g–wì4½w Ò|”Eã%L²Â¨÷fßÎÆnžëï3øz÷×-Ty®¨o;Ùw€Î’ñó¿æK{|)È*ì̘5¡7<=J$´›¢K®OQµZÎØÎÛÛ[ì’àîî^ÐofÛ ïAeFTZoT E:È™YC^òl‚7ö%²l&qÉ~áO»'»ôèÔ?a«¼¶ž´ÿ¸‹»²{]‘ÌZÔ7%ì„A›‰hʧ·ßrd¹¯ h$óõ€W[Ž?°hý¤„½7ßhÔ·õ\Ò3:(0²@ 8Kñ½ðññ‰ŽŽ···÷ññ)›?ˆÌ’$$eF)$íÝÎãßY3N³Ñ85—w|¶fù±/G<í˜4++ g²UlAFF²Ð¦÷¸¢t¤¾Þüö[Ž‚,DS[‹/²¤hê³¹ Õθu°?=î]ðÞûŸ•˜%‰ä%=zô(±.FCCzè÷/: I™QJ1°õ|úÔSúLÞ‹Þ#š9nêXì´šÏâY3ʵÁlÉܘ»~ ïRèL\À“*© K&ššš§NR¦$ Iå#ׂ˜››+8-!!¡:£j(°Jš’jŽ\äûwi¿cITu^-µOGUQîûƒ¨êý"©JçBRùëq@ø¤ÖräÜù‹UÝ…jŠºZy¾Üèß¿¿TJ)üAHª„rqZWyTccír'<<üÛ·oÄ×—E‰›¿H~üø±âªfAÂÃ¥WÊ×D¢¢¢ªº $5™¶ƒøCùKlE¥öIµ´´¬ê.T*¤B"‚‚âû/i ”· ’%å=f¤¢‚Ô*„Dl6[jÜ¡üÈBlnˆùŽ<¹ÔAHHT™âÆ¢´ceZ!—Õ^Rƒ¾gYàÃͼ·÷T ¯j B^Ò¶mÛ—ùóôjTVÇNÆ­­‡W`·T•ÒAH”×Ap,{òDÏÎÇžzµ*\syÇùï ’…q,éç·/Q_"Þ„?|b2þØ´&YYYY™Ù™™)?¿Gûö->ÃâJÈa Váþ@èŸÂŽM G¿|A/ü¹Êþ±s0¨ÀUN¬··÷ܹsåÀY£†Orºùͧ¡8ñ×ÅÀSßÖÏ«¸nUÄ—A”ÜCŠŽAH¤¡¤’Ÿöj~j×õ Zdl½ö{ѨŽ×º5_Æ×1 S¼]\@›ˆ ¼ôpekË]½|ËÂüöõ‡‚îvhnueÙÂW8¢««ûýäaÜ{ׯùÍê׫£&±õÆK˜>lÅ„{Ï„%dõ_¸çÒ“?ÙX½¦­úN[çå Ã_ßf-Úq2ú”Ó¨åÕ5U†´ µ cï Ýz­~÷jÇʯßìL$ßœ0øõßMÌyÙ¿è®7öiØ/Àq^HH'ÉÀÖV´WnöE:»y+[Ñ›BAAäôsñG#D{í»ö³ÉœÛ}Û4€.®cn45NÔù€Ù-^ÓzÚ÷ů°Ëí!Ô°êèì,5 ¾vó8p`¯8Wû–úÑ`ž|¼«u‡%¯Â6,þÜ%æ\w"ù’›S8S4ãfÆÐ–W¿ªûöí“—;uêÔùóç—¡Z•ÒA®ß¸UÕ]¨Tè'•¢¤B7î}~s¨“û‘mÁÖ­^¶¬Çûì9ég%ƒüº:Æ3Šƒ¢('óÝ©S·h4.DO:¥a:Å9¹)"’r¹œKgޱi0bË^*ƒ$„øó Æ5§ PTlÚçÛA9îVDT9ºqgKe³Ã0¼5Ïã÷u6€ŒûÖŸþ1È׿SY7în<}ózšqÛ¶c€ã<Ày…‡·oÜDP´¬G„}ÞlÈÞï/¯ö¾·aƒ =¼¹¾h òýŒË؈²u¤ZP\ñôôLJJº~ýzñœ={6Ÿ_(«×RD5ÜœÃÃÃmllJ,õ/ëb¾ c‰ò¯ƒBV_ìÄÔß~|ÐkßX\å­-ºY_AMÞÏS¦²~ýúÜÜÜGI–ttt\»v­T@UR©Ù˜™™).ð/‘д+-;.ÒØTtȰ‡=š;h-ÞyfËAýŒ=Êsÿ‰žNÝꤊƒ'ן,bY=Ü7[ŸVÏŸ¢NOKÎC½=ß1i‰©è˜¿E#’P½±…Áëô[OyþÜvïÎÝ{ºoh2máÊEc M¼~{ýü=‘N`5àR€2&'û:þþý çÎíܹ³8WÝtjØÝYPzβñ !M-èÙû®K«îÚ³7~º¹ÿœA>÷ï·èÌ•>½{Z¥HGá¨éÐh´-[¶L:õÕ«WDJûöí·lÙò/ñ˜I R©ÐPiˆÁwoº³´ôVÛ5ª·euÃèèlìÅ‘Ù`Ü~,àaŒiãÔ…ç¿÷˜?t!àOØŠ_=|¨W–.5½ßo^ûu¶kª­[óØ]Çæ˜kèÔD¼TëG V4x…ºEÛ…ŽÌ]wn÷ºåK‡}L½ujnk"KÍB ãü(Ç6.è¹øÕ‹ à«–¡ýÇ2äP5Ñ1ß{±µõ½ZïßÔøË×,ìùž;Y`ÒɃ pç›y³?3ND¹øŒZ^r¬ð‚ »wï3fÌ·oß5j´{÷n6ûŸÞ©«”¢2Tôþ o¸ns>ÖÇ Ò_Lšþ:¨_Fbâ¯Ë[¯hö¡PÙø¾q«Û ½}`&Eq,ÇkÊy¯;“\—çõ³é•ZÿÍé fÅçðÆ ¾Í æÐ'ò¸(JCõÏïl-öëM3êµÅ2?jìÎéè´"-;¥2ŒÊåÁDÚ´(:†Á€s­­­¥JÞˆˆj¦Fÿ8³ËšA7[ðs_˜ÿfXNJü÷“«.è§ÐÔ([‡,ë8îí5ßšk>øƒ°Ùìøúúúûû³ÙlIùCL-ÕATÉ{‘››K쓪©©© ˜Ìy7÷éÇÌ:KŒéІiÿºK¿kŽ•Úkþ㓛õØÈÜ·¦Íè{&jñeE|·Ínfº Ô4 ºjwû'8gzÙÅí9µ´ŽÐXjl:Zi³^ÄpÅÍ}¸zH§Ï„ºß¶X¶Ö¥œæŠãÔr£sÙz-ËåÁ£«5“ZÐ|gN;ϯúBªcøµŒB¯:·_§YøéK¿_ýüi˜;ÝG§´_¶ñÊ[_Ɖ-mÜ2”Rmj,«ør1&&&‡’w®¤ó”¤ƒÔz¯vœ—™U ;GÀý׺å× då†yxx„„„xxxÈ‹e[únñ/¦¢Î¢·°Ï–ÍÞdœõ£=~w& ¬ïé·ÕmåºüŽlî#yöÚ©ãÇŒ3f̘£ nÏŸLü½ân<‘Ûjb½„ Ñã%ìÞ¶¹·ã” A$üztýÔ4ï·õ,/ŸÝOl8¥ñwòsßAƒÝÎä@Y¡Kðhß<ëú¡·_/·~ÑÊ®ÿ±‡Ÿ©³pÞ©”‚~F¢+°¨MËiÇæ ЙvÜŠE€ú#N8ý\ë¼ø¤ ìÁ|«æC”÷=“kANêÛÃev.V¤Š{Kݺ9¹'òÊéQ®R~G†ܸ¨cCs»5RY‰ÏNhßTW[×¼qûIKNÊÜåŠgKi²Gà jP¦r1¾¾¾Ä~e¡¡¡¾¾¾¥øxòp7iЪ¯žhö;ðRáž‘{2Gœ÷´ÌÊMÁ€†ÿõ`«ð5‹ÂþPh‘B±,?öÛpï•õ‡ˉ¿Ýëå¦ „P§ßôüß»ÿð…@cšï»ÿpbúÁµóºupðXh5réÍ@W¢*Œ{ ‰;»—h;^!/7##ƒûñ·$ÆD\?²qC£éçò‚#‚ÌY´Iûž_]Òaï”î¦6f-YsòJ0'®E£¶ƒõE?­Ãî=3Þâº9Ýýö¢z™ÙÉP€ÂÜò¢þSï™O’·YmQlJD\¸Ä†äê nþs÷tò¹aÄ¥y"¬oG'Ÿzá~ð©.V–ø¦ÕЬèù-œïtwêÙÑRíG\‘¬œŸ'm]§ÛÎ;ø6È5ÿëƒIƒ'9NȆ"½ÅÝ\8ùŠCðŸ@Ö%VPƒ2•ƒÄ½ðóóóóó+ž.óPA¢é&Ço]ࢨÇùŠRl{º_³˜³ÚuÌM³cQÐY}ñ&N×M§1Ѽ÷Û¥ƒ»>gˆªiÑÎìßò·Ò!þ›uXÀîá׿^‰>2€Ø«E×kí/AJWCx¢+1çæ!:01¢ ]ûõÁÁ²?”’œÙ|V8Í¡k7·—®öj)étr_ýfÌ¢Nݺ÷ðØY£qCwÞ<‘<·ëàÙáÝG|[ÐÖå|Ûé@cšïyúJÈ0-[gª‡ƒWÊþ b×õwïÞÙÚÚJ•‹¹0£û‡»_¾`ªŽc¹v¶QÖ…îv+‡ÏW1DEE)ë‚sÀ¢Sà¥W›þ·{§|/Œ·ÇÁjuúØä/ÄarèôúÎçž$§´Óy:¡©÷[66ûIÌòŽuĦ4”Ž›­ †+‡ÒøƒH“º‰ÄáƒÜÝÝe¾Ü᣶äŠE jjJ œôGN=¶_xsÅœ)÷¡€ó£o;•¡Áöeõƒb·Çr¦Y*é‚WOEÔ•¼5b—Ã^½zÉ›˜”hA$Ïzùò¥ä>©âÇIü°)ÒA¬‡ï]Ô^cÉð5^Ž|"h{y›h•Aú‡]sçÎ}žScCPX2ŸËóÿ”ÖruaxD㎠Ì'H4ÏÇÙ³º3šzÁ«‹/ëN(¨¡ÄÊ+¢¬ù%Ͱõ/ïèzÿWž¹|r¢ö=pþ_ÌGq(¥4ÀTS5ó!¦ø´¥$éC6%6T‚?ÈÌã'®¶ê;r‹Ñ§=_|ƒß™0D¿*yq/^ oå½Ö¡\‚*‡›šÉ6k[¸àBÓè¢Ízû4FZÀe/Ç»j#bÖõaNikàöþ®¸r1ÁFŒêZ×7’LѨ344${Ò¼Ý]vÌbš5î9qÛñÀ¡2ΤP5j¤õw›Ï¼ôôtVA‰5(Y¹äU=zô(±.FCCCA1™)¤BR”N¡1Lž>}*•hæ¸ý©cEô­²ié{µøLZ¿õ¤ë!“„<”Ê”ûÅ£Ð4%WŽ>y©d ÊT.‰¦¦æ©S§”)IBRùȵ æææò²¾çW”ü†—­†¯œ„¤: WùNø{È‚œTW4½? É¿@îRÝ!Öã*€ðI%u’*ô©îTs§u1ªfATÃÅHj»-™œ;±ª»P©Œ1¬ª» •Ú'ÕÒR®k–JRËuÚÜ£úÜDRQYH¤&¢dpêsI„„¤Q¡Á=*Ò‚T1ÕgzRTJ!)•’úònNc'km†8…›õðĵ)£¤ÅŒûûÔ¥_ãÇ8”wI”îQ}¾¡¤¢²(¯ƒà‚l¯é ºž}5ßDÝ~_8pí§ŸW±Â\nüæÝÁÓ'÷Âx¿‡Ÿ-³éaÎŒ1m[üðƒÐ¾“™ô²òÈ‹}òN­CWÃjºJp)tE›Â”W DpÐÐP³gÏJ£¬>ßP2^Lm'="þÛñɺ®÷j”¸éì ¸Ö­yÓN‡³OæwíÚµS›N+??‘Æ0^/—¿á#0^ÂŒþK¹í°›³ë¸’§?öõZ°±HÊËcúôŸú€†äÏà•"Pú¢NkE IDAT (Uh¤Êƒ{T4¤RûÀùsÆ8Eñëœy7äÊl‡ÇÖ‹`ЙÛkëŠÆ#?.žI¬X¹ãÆóò~­X±‚¡ÞÒwñÐ!N=ÒøEvZÛô°ñßeÊá~cïë¡Ë2íÉX½ÑŸ#ìϦR„Üeg¯'1~o^|EÔ,Ï?4²ÕѦˆ‘ÙnÇM£×¾yà×¾2®€r(šCLñ åÜ£z¢R:Èõ·ªº •ÊÀý¤R”ÔA¶^XãÜoÝ‹ç›×~iºÃEQŽßpøêo|^ö/š EQrž¸±zY_*-ÃÚJmõ¶‡ <]ÆÄ#æ0ÙÁ.+/¥³@€~™v.~ÿë†(Šõ'X³`{Lš—…äýޙ̴3â¾>—1Ü€œØ­©u^+-E›yzÇØOýÏó¹5»ìqäË—Sã|ÁbîíÕ£ Ýn]PßyÜkß"¡9Ä ©÷Ü­x³¼cÒÖ äô¤ú|CUV©m.Fe^ƒ4qc׻ΓOíyrlgà‹+™Jÿ#—×X‰Æ ?/›þ… ©šö¨aŽ{8£Gô]³}?QÕ§·oÿ:rB‚  ~‡nNt0ÔÄbdWíe÷Î$,YÑ¢N´õñLô:}-y¼WSør⑆ùŒVz€ Σtgoù/÷HSHÿ°kͱïn«7VU0QhŽÃR¡9NûÅß)Í[2ÈÒ¿RÕ  ÕçJúƒTw”t1úÞßÕÕûH{†ÞþsãÞ/ø¯wm\£%Rû²£ã ‘ÜsÇLšýúeôßC‡Ñê°D‡ˆ‘&=æŠKÎq6w¿vV´€×ãZînÚá{ý5ÛÏ‚×8ô»á¼ÁâÂ:ÎÚþº˜B5'RbÜIdÆQ¾†܃´ Õ‘ u1BÓ®´ì¸PHcSÑ!Ãöhî µxgä™-õ 0nô(Ïý'z:u«“ª%óôßA—ÍH[—·7n51"’P½±zâô¦sú\Ú÷)müãÅ4þÃ6ul&ç/›ý1ESá‡+éèÁ… ôÛëçï‰p«—”ûG/ʇæ¤Üƒ{TOTJQ*võ>¡Ï:²´t×9´¬»v™õ÷˜á³wsÀÈn$à~”nýÔeçbºÍpCr„(ÊÅqÊáâ8öv㊃‡õÖcg»r3Á~lSËßsàæÀ. X†Tqst£éæÌ}›_ü^ÁߢfêQø¸Z¯ÎZôÏb×P·±tzugãâÂT#¶®&Ï¡‚¨’) b€(Y(Ü£š\(•‚qãŽÿéáÞ­2ûG¢¤‹Q™usœûœiB¡öyæ²çr³~^ØdäF¡"´CS7¶rf¡B*AX ågP(4&•ÒtÊœ% tbo¼ ·dI[!?eÏ›D,ZD6E¢9dY+ÿCߣø_Nñ#Òçõ2›yðëOf”å ý’£dóé¬:Õd¶¯ j‡d±Ï¾rc€„]*ßàÕäÊ@©tú}ýÖÛîÝTÖ•çef tudt¸BýˆÊÅŨÌÜ—n¶PXº.Vùó#˜F¸¥öòßyüBƒŒ=kZ¾g A“Ž(;qÐâFV@ôã£ût¢S0ôÏtj§§,âkCÐL‹ùüK6 ,<«ãâvi÷ìÂÓ'ïMXšx:g¸îc´Çï®Ã¤€Õà=]㶺­¼ À¨¬Ð'ç‰ó‚^¼:0zž¹vaU›ºƒ„……=Rx¯[M¬—ôJ²5ÛeÔüW_höƒõE?¡Zõæëñ?‡óëÍ4/2ªzv?±á”fÄßÉÏ} t;“S>¹L¸ب“¼ÃeÙ±ÏñÉa·NWšcå×~#ö€¶½³$={ÄÉAq ’ ñññ!^&Šƒ{ˆ©ì¯4òuóX‡ñ~órc}||ê-–Ì8ªoït~‘gÞÿrŸ‹òÂüFý#[¨Û¶jëšÌüžbW¢¥g¯ýaÄù{žý[w¾hdóýõAÓtK× £V‡Þò¶«ðÏ*AVôüÎwº;õìh©ö#®H–2^@Å}‡”¬¡|]ŒÊ¦ƒ`œ_6õ[8"x(Žó9ç“—®ùÚž1$ØÛ()% Êøœ»î;´ÿüìôõ´Ð,.Ž ˆJxB<êø¾­z¬ì¨ßqç·n} Â|q='åû­ŠÍeÄÿ8ͬ£y¥Í ‰>Ðæ7ÖÝ®;ŸÏ!Œ¿?‰»ÕA(V›™žžž[P€²Ë?X´’(Í!Ü£Ec€”opêcG”ÓA„Ü“gî¬[1àüͼæMôý6…®\62öÇÏsï#-˜¢ 4Þ®9ÆdŽ‚‚È9ŽF´C†Í¨ÉØz¯£Øü:š¿/…ÙÁ˜ûêj.>ÚH r~mKŨ>]-„ÞyÙª­½–½nÀ®¼C: Ö¥þÞB§ÀK¯çgŠZ½€dú)YCùº•QAš\ :…Â`³é6pJ¿ÎC±˜å}‡]3o5A@êm¹ý@H7¡S¨\…"zT˜T KWÏÀ10˜µ¨3ޱ pn<È¿íjŸ‡i§[‰\öeAÑ~޽óqlє©wÙäl"’ ê÷Ùý¬2× b‘šC*¸‡© j‡‚à5O¡Ð´Üu]¹=oØ`g¿Mû‰ÄסÏ~þ5±™³ä°u|Éí4€ íª½(èHÌü­ æð-ƒ¶>³¿œ<÷k´WSø~àž†ùŒÆ˜ÚÝG鿝}Z©®D–ÌO^¢Lß!%kf\¾.FÿȊж˜uuhäÿ8—Ê0"X:Ý>†‰æ:ß~éÄVcI܆Oÿ=là¾^ }¯´¯§ì–q±1ÏfmHßZ¥ïoåS¡q?j:¥ûÙWyW¢½€dú)Y·÷÷jåbÄ@”¼hjýhˆZq9WM­ðÂÖw¼¼ãýÝ_yÊÇʈ8Ø÷Àyû*r«rªÏô¤ È×AŠ9|¿zÎЪžÔ›¨ðKW,ÜúÀûÄájâJêMëUpéÐëôå6xÄÅ4þíÆVîùËæ¿J_ÜXøéJ:ºÛÅP\X£µnþÁ(Ú Œz$"ÕTÉeUì$ÏwHÉÊÝŨÚÝaæˆÒ4Š4;¥†‘þ%ƒ{TŸë£¤R耰Y -zGÀ‰N#]õØÙQ¯ývïdŠcù;ö\u7⸘F}=q%l›EÌÃ{¿äûóöª›Mo¡§àÖUkñÎ9¨ûYº½š†¼×­¯qãªÃ4Oß!%k #zò²¤*QÒňŒ£(9¢¬>7±Ôëb2r“ˆ?Oœµ Nìð§a£,h+ä§ìØs•È2eÒÒR¸âS(TÄ»•¾ÿîÿ>ò?7˜,z éÕËlæî_˜_,î—¬Ÿ›Ê¥1KX R9(ð#úè)×w(ü†2505,Ë×ň„ îQå(eAj‘+‘|/ †vò}‡”«¡–¸Uʬ`&©h­‹y|E?ã¸àRHÜëíÛãÈ•­Ö:qA£§¼\¼ºŸÚ¤å@âÄÆc¬ކ¢s Mƒz“ùÔ|§/š{«‰*g˜ÌÔå ZÔ£K6œX®5‘ò'l•×öÏ“öwÑ©GU×ýZNpYÖpëŒÞYïÏÿ× HËÞYâ‰ÅÙ@øªÀÊ!®ooŸ¦¨…Y’ˆ/ŽOtttxx¸ØÅHf1y)ä¢'’Š@Ùu1 ¬­¸Y1’Ž?.Ÿ>¬ÏÎúò';öæáÃïpa¾øÄCfæûûäЧ‹]‰›9–šìæI®’ðnª¨·LSBºÇ¸±Gþpw¹Z#˜4++ g²+gÖ‡Õµ®o$™¢¤”喇‘‚Ê×ňÔAHª„²ïÂÐÔÒÖF´;ÎXØÇ âÙº®þm}ÜŠ—t%ò ýâU´†áA†MùyqZ—MݵE¿ÃfŽÛŸ:–ªSÿDKß«ÅgÒÊxIùI¹)¨¡]ŒHHªœ,Hmv%ªP?"v1"©U”¼?¥0‹éBŠÄ‰jö§_ߎJýNxt(AÊG]voÍÀȉº$»? É¿Qû¤Öu^2¥4å»™óÿ½U•CI#R!©È}R«;Õy_LITÍ‚.Fµ‡›7oVuäÒ¿¿Ü°2*†Jí“ji©¬‚«:1XÃqÇq™T’M‡††ªê'PÙx1$µMA/†P(¬* "nWU/8©ƒ¨2 ‡ä7¹JzR™íV9¤!©Á(0•oA¤þ¨%¨”BRÛtâsIš ±5©üÎHš-U½à¤¢²ÔBDrôall\%݈‡¢†LU/8©ƒ¨,III•¬¤Ö©#{ÃíZiAj5¸ 'äM¬cÇUÝ‘ò¤Q#ùAÃË›¯_¿VZ[Õ•ÒA®ß¸UÕ]¨Tè'•RZäçũӶêß<ëIRišu,ôd–Dÿ„|vìhZtpŽóùÀ`H,¶Ìþ±s0¨¤½]Šë <¯rš&àóùâI¤ÆÏÜÚ´nI„üªÑ„‡‡+³ûVTTÔ?®‹Á¸±‹^µhaKDÃòÓ^½‹=ñßWÇbÁb¼„éÃVL¸÷œˆ ®nõ?t+òst.F7oÔ~Ìô¥^n­tø‹. ~¶Ïˆ®l8ÄAJ&³R7|g0âI„¤º`fV®±%nŬ ç¦Þ><£%bäºÛqÓèµoøµÿ÷’TH R)¡˜°ã–=À¶ìŦ)H¾»à.c÷n”8d¨7ëfoJ”DN?4¢%qøû¾×²‹ï}šÓš|cÖ M×&xì⻇¹Ó¶³¨`·xELëißWjB’ªB¥t•¡b÷Á±ë3¼Ï~ r‰v™ÿxçF³}ƒoÞ^î‹çß½ÞÜw#²BüyãšÓ(*€ÝKïê5[:ÕFM²N;¯S¼(B.гÃ0¼5Ïã÷u6€ŒûÖŸþ1È׿øv°ÿ©ƒT eÔA„ü?_2}zñe$å‹ä½ÈÍÍ%öIÕÔ”+S6DÈOy©éþº!ÝWïܹ“Hôµ ¶öœh¬™ß&;x0ŧDøj글8ıÜ3)Í'÷Rü´ él4kߤg=¤„^¹në»Á©¤R©$uRÈ]'~Íš59±ÚÄŒèœÉ•—[ü0,QVÐó¢äÅ>yšÊQ¾o–‘ô;‡‹ÉÌÃr? ’Å”¬Ã0 “Ý™ÒBem=¿­…–¢¸Y’D$¡zíD/h0n¼@ˆëµ—ý¾FŒ~{ýüß‘ÄßV.%$$¶‰DõPdAf;ué ƒÓèj/™Ö¡k/é=ÆúÛÑÞgüxÿƒ#ga¼„ý—r|X1ÜÙí„Ô¹_vŒë9p+Ðü9¼RJ4W‚ðäÊ©Öú:œëêë´è5!è{aTÊÄg'´oª«­kÞ¸ý¤%'åõOA1%k ðõõ%ö+ %Þ˜”#çgÛ¿\HC7öv þv"YìG f!úþS™¦4 %;2[qÍjjçGùö–¤z¢HÙpý€q²2rùÅÏdhéé°h©-F.Jè>ÿyï;A·ßü ÛtaMo "+ÌoÔïþÛ;²…(Šæ$ÿŽ‹O“:7;åwlœ9Š¢ ÙcK× £V‡Þò¶+·ÏªŸÖºzîCÏp¶³äü>ï?vt'çˆøPK-ççI[×é¶ó¾ rÍÿú`ÒàIN ²Az/Å”¬A|YüüüüüüЧËÅAýó;E‰8{ìúì'§ï¢Ã,¤Îâã v ÉN@© £JÐH¤J(òýÚ—M‚ŽÍu$3?½`ùÝ¿:¬>qÈË 6:E9ÙéIé(Ý@§ ð|J@ÀÞcÝÚjÒE•  rÎÅ„£í„L(t©FÙtª8Ì‹¿C¡Ðºh3q,ÏÿSZËÕâ,㎠Ì'(^òtÅ”¬¡òÀå^L~AÄñ]ÛØ4 ´šX/!è•8«®Û!ŸÁ-7ŽéºpÇÉÐ÷_?¿x°gÃ’þÞWmÝæŠ½ÈžÝOl8¥ñwòsßAƒÝάZU‹¤¢(ùç]Ý¢C ö+nIÕjÝÁL½ðBï޹Ѓˆ¡Ñö˜§…ÇŒó¯OŽ'FìŒ4é1W²Œ'µ­itQ‘u@'ÃYÛ?CSÈ‹{|ñbx+ïµðRPKÛNÙO¶·rÎÈÜOwÖ¯Ü5båÕz'+8“/lÖ¶ðG›BÓè¢Ízû4FZ‹¹¹¡òŠq{W¦‘†þ}+f»•7}冖&º,&J¡.Ä0-È‹yy^ËzñÒ­N¿éù~>ø“þF#¤ÎØy»}·ëŽóØê“1ë4j³ìÀÉ}D‹k0nì$î®^¢Š—›‘‘ÁVÈ:7©mA ê¶ç :PU T!Štnö“ 7â :v4qjäõ‘Poàˆâ_é¼øÓw5Ƙ½Y´ñUÏ"Ýþ}bÎðB'†s3‚/.ꛑŒ3â2­uó~DÑN`Ôë$…¦¢g˜Zõ‡]¿–íè:oÜ«ë¼ä„Þ‹÷lœçB^ X#EÞe7Dè!ßr$SS²pwwWÜɘ˜ø×}Ruƒl¹ýñgJb‡Ë q(T*•Ád±ÕÔlzzŽí3@t»‡_˜{%úÈ€Âmh›öõ<Ùׄ\0ÙTŠd1çæ!:0E1€tí×ËëÿÂáp$Íp¹J½ä*/Ù…ÇãI™0RàÄ_Ú°C¸tŽÜ•&϶­ÿè8¼—1÷WR™….hFjß7}ã`ßæ^º˜(ÇÅ4êë‰[aÒ(j¦Sž=+óÃJ§á7 »¤[_ãÆUò”òÝÎɽ¾nº>Á±9'éÿü‰-Ú\}òúb=¤ üD‹¼Rçb𠋏iÐå£#zÊÔJø¤JND‹§?”y õÞ¨—âvDŒ9¸ùHѝ˜3¥œ¤ëp~,Ø’¹#Ôˆ‚\Ñ0™L©1ƒÁøúõ+1¨„Ðh4©nÔ¤„Y S«ã”)S¾îš¿&üdzÝ!k†Z¡‡7‹£¤öëï;þ}0uÏ8ìáùñµpµ)“––Rºßn*—Æ,a…Hù‚qãú,;;üÁIŒ@ÍÔvíéÍÍÆ®þøzmK]5â]:Ôi@¸0ÿN&jí`(YSCn1¦†¥25TCØúŽ—w¼¿û+ϧGSÅ%#î®ì{à¼}Ï4ÅàEyûömå´+Izzºžžž”©=(õš#ëóËœ^»ÿÄ~Ý;|Ul®T¶^ýÜß—y¸“8°.bÒªƒDfZÌç_²a`):—™ÍÒ-á‘-_øŸrB‰*bÅ¢}›æ¶Î&^˃[‘óûî’d>õTÿ¢!&S² ¼½½Oœy͸»»¯[·®Ü>j)1é¾`À„„„Kz•X¢ü² FFFR¯fª¤•Önu@‘Âáb ä£(ÊÃð_—†‰ÜŠr¢…½¹(Š pÀ8(в€a0·—–}—±KMÚ¾™•®Ž‚¾‹i<Æ*áh(:§!qÈÃpÀRrB\"1$8±þ\kâðOØ*¯íŸ'í?î¢S{O°uz6×80lN·½K;¶±¡£é·{KÉŸ{®¸Øè×r‚˲†[gôÎúxÖø¶SË=Vq}Ãxëü4ÅÅdI"¾>>>ÑÑÑáááööö>>>åè¢p8(¶Oj•|¥ÚUÕ N ´¢• “F©ÓÚ²>âÝÜ°Ï ©é©¿8AþžˆìzðèôŽ]§ú|û•Ï*M=.ö‹¸¶CfæûûäЧ’¾–™UýL#©Fµ-­ë™‰7öÈî.WkbFͤ YYY8“]±3L ýÈ«»¾^>ûÙÐÕp^¾Ac‡GC—t4:CCC²'ÍÛÝeÇ,¦Yãž·Jœ——žžÎ½HRPLA–$’Ÿñèѣĺ Åd¦¨Òæ/2a±XÄ £Ê_Ê:ˆ":î ½]4eáäî ¹,³ö;L kËÔ}Q€û"Àós² 8EÜ Øº®þm}ÜŠ?5Ø Z¯8+U'4ñ<~W´]ü¼¸@­Ë¦îÚ¢ßg3ÇíO•ü€ÿ[¯mà©»›0Njr*MÓH¿èúýÖ“®‡LòP*³È#øä¥2ÅgÉDSSóÔ©Seú(ª¼-Q+R{g1 òtîyûP¶ËÙ¥VKQ×ÒQ×’N¶?p_¯„¾WÚ×+!>2“ØyqÓêUóz¶4”;qÃx‰3ú-{óŠR>ú›÷Hz·¤-7ƒm(™súͺþ`‡!üq-RQAJ¥ƒ¸ººßYCÌãÇ£££[¶l)uVІÀ:“=ÜÁ¡jþwyÝ„EûšŒ_œþ$è@ÇÑî;Öxu vñYº`X·Æ’˜ÃÔê'Ù =„ŒÂ!÷×—Oþûòóç¯?éYB¶^›vcG;«Q)Rí¶v_rgìœÓ›—ŽîþíÊ+[ö-ÿÔU‡â•3ØŠ¶y¾Ê#iÈ~S€Ì¤4´ýÞÀ"+këhè ÚÝsû¤­‘üÚË®…ä/¤?HmGù?5ïý¬Ý¹Öäöpï˜VGïî‹zžñéÀÑ(çÃêÎ_»·¹vb@@@gûcfL‡ª[IV E§` ò//\r24ì}6U¯½]}K ëæêÂì÷W–Ûºþ`6]Úˆ•ÝcœÏ³þCq-}f³Ëé!©Ž=ë)ùa‘ÓÏÅ(4ˆ4¶µÌA–Ýâ1­§}_\Ù¡Îj(ä5ª½HY ¥6ø¢0&¬9Ý¥ë¤æ:Ûò¾ý*>USSCY4 ƒ­¦¦ÀùŽêMßµÛŒI^eÄ„AРS1.,ý¶ê âÖO[ݽS‹"#Ž™s7¹´½-2has©Æ#Öκæ¼r¹]cÐÙSzÓ6(ðLêìHSå믵:ˆJQ*"Ø (ÜgTf fã¾î˜êÝjEýø¸?ÑÉÚÖÆÙiA^Jìì'ï±îíŒ8f¹(ÊŠ>ÿÃMÿqÔm»ÑíõŽ'R€Ø ×xÍâé\ŽTƒ½lެ~„β–j— Q÷ÏF/l¦Q!6=ZHàs8(Zläo·Gw™!®ãÆK®ÃDŒmlLE3 Þ æn}ÚéȨˆä/¤¢‚”J‘ ¶"‰8ØŠ¬„—W÷ ÖºáeiÚÈ¢Sïóg?<Ó|ú0dØt÷üG'<îAcìEëŒíô³.|Øåu°Ã‚»DU¡†µ®âŽi›« ¸?ÄeB¤Ë„ÑnÁ ÕŠÂh?85 5É-eä}˾[g6›ðêÑšNòªJyã;ùbç\¡”ϤB%&&’  Š[RRQ)äé Dœ])¸\nqùCJI-þTèužòuo _–ÈíjÅÝô›3&µ¥½:´ñ0 ë7o®«Ö¨ïo%‘'æ 4z"xñjùiÿ½{tåô‰Ûÿ Yvf¢ EQ ·øÑ°COQ4Ÿð~¤êrf/ß“êc©5~ë¸Ý&GÌ{Õ¡€>ƒú+'Õ :0^‚礋]÷L'Új¨Áxö)u½’®HLÊÇL¦vÉ\™°ÖB”jŸTƒQâ ]™'ÖiѺmÈD`¼øc'oµmÛVœKcšÈ<ë×Ó½#׆Î=÷B*WÑÕaÔïÔ,š–Y—ÇïëÑX4„IûBkµØ¿»Õ·#£–ÿv;æ;„çÇ sD A¤õÒ}‡µÐ½‘q5Bnøä½Ú ’ÂçÌ}d¡ƒhÃývõý|D–·#™4 PèòžùW!É´!¿ò ÷!åRâ)?éþÃTKFE|™wïÞmåÔË”! Ó ü§;t?qbÀ /{#©:éê-îìE~@ê *K©tâk^Tļ÷•‘wÿ` ÒkêÄdDìðbwcíÊìXƒÔAHj)&ÝLPX@¯ÅÙ."$r —0“”RQ)Èx1$•©ƒ¨,µ*n.IU!©ƒ³’²CZ’²Cê *E ÕA”Ù´µª·Ylm†ÔAT–š«ƒôïßäo8P™=‘lúñãÇÕÿÒU>¤?Iu¤ ›•Tt7*³Ý iAHª v*!-Hu†ÔATŠªƒ@AAÈÙ±µJ¾Éâv«ÿ¥«|HDe©¹:‚ ŇU2‹¢†¬ú_ºÊ‡ÔAHª;&&&UÒn|||É…H$ -I5%))©’Ç uêÔ©œ†T RQ)J«ƒà87>9×ÒÔ Â{VD%§<¯iÓ¦-Z´¨„‰nðù|A€ü^È‚ÔAT–Òê ™‘w„ªMÓ™ËPY:Z²Kòó~þÁ-,¤b¾áB!P%7ãeÅ&1Ì­ÔK=¶•ÒA€ÉdVšùhÑ¢Åׯ_€Á`©ƒ”©ƒ±¬»ãLêÜ»Ÿ/Àpa~BböÙž–ÅÖ ±Ü sÛŒŸÁ¢ ¸É__<{š–ÁÃ)šzæÍí:whbTïÞùû'ö)ô¶ TšùAHJ iAj/‘w®šðmóùðþâÖWÖ:Zš¥''s…E¤‡ß¯ä6î߯B/?5>Ÿ}ü5˶§kÿ¦ Õß¾¾ >—Á×§•>]½aŸz/.¾Ëc§%ügù¢òÇ $¥…ÔAT åuÄw·þÀúºi~}žšÃäÿ|øÖÏÿñMXz—Æ0°0S'J é·þË´°1579+Ÿ“ûðÑçä.“½4ÒÎNOËÅXu›wަÜû©ÞÎ!-›«Ó¦CêÉó˜ý$N6¯´=—ÒA*s B( ¤¢ ¤¢²(¥ƒàÂ/¡7îÊ\Çåá‰_¢M5Küù‹Ëpc¦u™3Õ˜ËÅ ççk\ÝÖÖ€‘LEäųXÄØe€^nZr>OH¥3¨¦í‡LÕ4Ô` xY8Ò¨ûþý WMT€úçõÓMº÷´dIÅrî9©ƒÔÈýAj58ŽÆýAÆNH¥i1|¨››››[„n7døà‡º¹ p6*¢«-ŠÌò*Uú5E˜ÏÃq\Èý”Ï׳m*äçäò$¼Q¸¹iÒ²ˆî†jñ“´˜4àeÿúüù3ª¦É¢–Z!uꩃÔ:(Tu·>H:àŽ ³²²€+ÄB@s²ò1œ“ÃÇ…˜¸|J®@Ý^ãrÇr„8®i­‰¡M¨™#Ü· àbÚ†-je`¤ËÌþƒ*·ö/¤Rý!u•By$/3]ˆe¬0à¡ü¯»6> …88XÍçg¥ñ1†K—‹¢|gP)4åÓ PrÀX4!?•BûÛ.Ÿ›¡TÏI¤F@ê *‹òþ •E¥é.Z4ÃD“*†cÀÍ~|5D(Lâ,m:5#£è³„€4V£Ç½úBoÚ¡ ü$ÄA‚ €4ëavé3Þß[¤^k·f]40X,*ø¼œŒÔ| ’ñéÓÊÙV“‘YÀ@:bÓwr+]}-F.ÊwSe2™’ƒ `0•9ùòå Ðét¼è¾$ä÷¢8äºËFú,aÒ© …"á¬ã8ŽcB4=MôóÛ´oÏ÷'.Pf»¿Ð„W›^ .¿ 2ï„¡}gvÀyÙb×xŒ“™¢è寸Í"ÇqƒñåË¡P ú/±Ÿ³Ô.Geº®µ Ò‚Ôj0.š§„“©çÖ'훹¾Õ_qÉécº5è?¢¥++%§T=‘² oß¾-ÕéåBzzºžžiAJ©ƒ¨·O*Õ°y.ñš™Í+!öBKÆýŒ-mý—ØUWW·J¾É’þ 8¹OªHDe©Ø}Rq”GcUÐc"©ƒT«½ÚÉïEqH’êˆLóQÕ")R!©ÈÛµÊÇ $Š!u•¢æÆ‹áñx’oa¤þ®ÌžHµ[ý/]åCê *KÍóüùóªî‚lªÿ¥«|H’êv›¤&B*©$$$e‡ÔATŠš«ƒÔ HDe©¹:I ‚ÔAj'Nœ¨ê.¨,¤QqÜÝÝ«º $ª ©ƒ¨Åu˜˜˜ªê ‰j#­ƒ|úOª„„#ÿûHþARÒ;ŠßS‚¢.Zâ› Eo+y‹IAŒÿw÷ö ½7•Ž;`ï %vc¬1&јhb5¶DcЉÆÞѨØŠ]1ÆÒáèõ€ãêÞî¼Îã8à@_Ùß§»ÝÿÍÎ<·;;óÌìÏÆÙÙ’§}IAvf~aq‰øfÖÖ6îÎdC®yZ‘{æÌ•ùó?Ò¾çK„Ê6cxY™‰¦¶v²bÓ€CK¢#oµ;Õˆ£”ª(Lù/öizII©aÆ>íºt𲜤®FÞœ8¾b‡¹Yšõ× *yÊáˆÛÚ[ºmRNñí¼ÚùÚ$JH„cQ.§ÍøTïߊ³ð÷1¯ ':w›#•JÕßËž?–tuóµÇ%JRÄß¾ò óóqMH}6j°WRܽ#ÏÒBC{8s€¡+NGFéÍ›oÿ¡ÞBóÕÙ¹UBBbÕ7Äós}tû ­t t$p¬A5Hîó~­[”¦§@ÜÕÓwRÊÚõî?¬­· SšøüÁÙèÓåÌØžÞf„Àµo«‘ñª>ë~°43 ðAÀiøÈ‰.­^ôSx|AôÙ2“n¦*iyy…Š¡i†*;vðÈÌ©áJ©ĵ 7ÚETNé=djÞó›&VÖüŠR ˆ¹>"תý¬ýlàÉ“‡­zôvt÷ózðwä¹ÿ¦é,S1ámÚøÛÙév”bN œLJsD*†¦TêE!Zš–ðQ(°wkßsä{Ý:XpQVJš”A$I.JEÞÆÈ?ÀA¬"I2þn&ß.t¤ŸuQFr±œ`múMêåbjDqËséêͽ]nÑ‹K+Ùù ,Í ƒ|«ö§ô°s0ã"„0‚“<òƒ6&(#O%°>”²°äö±uaè 0jáßŘoê7picË#€‘¬ýaëÂÏ—ã8aÄÃÜòH,§ .6ÛcØB®<9S$É*3ö°g( `ákÇ‹}B9vãäHUŒX,ÖÉ­y=0 D¯ý3ÒÃË+|n¸·³5-«(奈%4RïUeeåÖ_Ò-q¬èa‰‰kŒÉ„ås©Ê¾g[Z^XY}T‚I‹„©U_Üù×¢óm‡ð²¥*C$eay70¨)yxîì“Ê‘ÇmÊä ‰×)ºÊ;$ZŽn–‘^ét¨$%Å*ÑÝljÁm# KËâôT@„MÓ²æ¹T5¾µµ8[ˆÒãÊÆÚ¨Ä¥êDx–“§™Óòâ •Q…JRˆ3™{˜Qââ:~(pà+žfñ­ý Ì- Ë»AóALÛô›ܪ•%W½Wd"/¼ýOz‹Acü­ +æÐMŽ…9?­´T“‚¼äqR‚éÐPANn ?x@Z^¦n2ðÌÚv´„4@c23S®¤$OäFsÝL$Â\Š¢ 4[fänŒóEé÷S„€¦(ŠªôAp ={žT‹›É ßÛÛ£^Er’E*škÍS‰ÅE!ÄÃ0L–#£ìåU{í U!Æ!)Šb}–æƒA>È“£{ÿSàˆQ’¡£z;ø…„<Ù%ë<%]JbF.ñ%Q±¶×PW(p¶´ä‘àÛÎSÈÔWiäÜÒQ‘_¤ M ÈWª(œ#Þá»;t*ƒ“$ÎÐDrçŽÖ´¬´6 ÃÀ I*}àÔéw´üN˜rðr‰ á$Iž"76ž3Þ™¤ª5aš6 ¦D8nŽá|’$Y„¥ù ¿£ó8 ­¤üç,fÅ+MÜõG¬“«#/=×zH¯Vw·UføöŸÚÞ ÏNyá›"$¿™!–â’‹F©·øµk'ÉÏ­êW  i¥¡ÐÁFð÷­ô6ÅWïäu™ÖŽ0)Ÿ]?WaÒvŒ›™4³Qæ=z¦Ç¨ _ôS0 @ò†Œ×ÖIäÊ0‡Êê¡c×É×ÎÞ(œã¬U;?9ó°"|Ü`>Ž€¢XN©´Ÿ'z%™aay›©çɺ7S/ÏÊÈÈ“ªJã!„äˆÏ—>Î_Ž([(Õºžóÿ»¨0ñ_8Èì×ç»wo§ÞX!.¯9]½oìè}»ŠävGör5Ë~—$ÌLyö¸˜ë>s4G%Ê—©hZZTTB’„Îo)„áXeV1ÒÞ‡ßnÁ¥p‚ )¥\.SÈr¹¬[È3NÃ&¤Úø™•>M#]P9SÏÀ‚ ÿìÝÙ.0°…­-®ÈÉÞ”âÔíývžÎ©©B‚l¡Ô²·¢åHëqÄ”…¥)¢ß‘ËåÚOĨÊŒ>O)Äeå¥ÀAòáõ 1i¥üÀAS‚]™ gŽü"1ñtqmíåÌÃ1Yþ³‹Jg̲sV ,ºsïÆy8vè0(dŽã0 bU›.F8„}“ù6Nîv‚Šü”ŒäØg¹|ßn'š1âÔ¤l%oÑ»¯ŸsKKLÆüaGâ´R©¤Ô¯W‰L%*®(T‡Ããò-l-|¾sË–eYé šNÆkéKݽ*ÌP*ËÕ[<»„¸zeÆ>x~9ö¦ᦖöÁç êî+ÉO•*”ˆ?•ÐCÚ[Ë Ó•J%°ïai6è÷A¸\®v„À0 W¥`üHS›=;ã>Aó¦÷u0yÙÙúMì J½~#Ë©»•¸´<3=ͽϤ!^æyÉ æNîƒ?è@•—ˆJJŠKD2%Å0Fr-[;·*ÊË¥(Eé©e˜‚blÛ†éåâdB—ç$•ŠÀ uËUdfVèdÒ£K7;Z.Ç‚ÀÀØÞÅ\`ÖÉ̈Ëá`8 C34Ã0ŒB 8N4¤B¹Úý{ü9Ì'4í&Âʵÿè;K#‚/àc TÈò3SŠËåA”%ßá8õìjÆÍÊ¥ ‚`}–惞us###êù *ÊÂÓǸ(·TÅ „h©Ì¡µU’—S ¢«.0™µ½­@˜’Å2káe*ÍÌUMÅpcS—KrÍx*b”yùu¾YhEö™ÓIS§‡ŠÄ5Ç_0^<ƒèò³WÞ›>?ÈFœQª­ÛÝ»wÙ÷¤²¼ÛÔïƒ0 ^šš$¢i¦êÖššèjýiYQZYå粬¤²jÉÑ奺Mˆ·œëÔ¯GY*iwzÏÚº#Çtqî3$ ?31³¦}ÄÂòn£ßQ*•/ª­ Ã°Ê ƒ®ù£w Ò¶µ‘L¹hÆ”"y=¥õ”ð4^ýY§ú`}–wý>‡ÃÑŽi–·VZRP€ã xA‘ŽP¬ÂòncØhns­AbGsYšúk+W®¼æ|°°°4E°äää7–¦ »n. Kãy­/1gaayÇ`k–Æ£> ‹!°> Kãa{1,,,‡­AXXX냰°°4ž·Ý‰ŒŒ|ÓYxÛ©ùV´zaEkz_UaÐjou¾õ>¡£~t¸¹¡­@LLŒÞV4 ÑB-—š×šÝ·퇼nß¾­7¦ Ô  ïJhÎO¯ø”#+š6ŠÆT!DÓ4[íÖ!ZðA¤R)ªzc«¦0†œ ï0ÚÅ×û²¢Õ¤^Ñ$‰º¦Ð´>@ë>üšsû–P¯ho»|>_çjàýä]ES¨Oq½ÿ +š†ˆÆãñj¶A†yñb­fÃ08Ž«bP‹hM©SsKóü_AŸ †Ä°¢5Z´æÙ‹QW! «õMåÍn>È££ûo—+ñCšÊ‰‰)Q5Ç3‰…¥6š€¢³ˆ/4ªkz÷ôn³ÐI¾Fœ›¿ÿTÐyPéMec? s6Qd]š=+bÚù?ހ˫>=^T¹Šx¯EkƵ6€Ä] í}î´*ò{=cZ²‚kO˜®õt %Y· :¿gÍ3<çzѾU²ò1èíÞšO®Žûj©§ÅKf¦ä×Îß³9¸ÍK¦£_^DQ@’ZwǺå­W4õ2Iº 6Òô+h¸!ŠÁÈÆÝ®e7ž¡Î]ìuË^3Aiö'‚ŽÝ¬^öìÒ iƒT椉ú :‹øêtï L¤ðä¾Í¹ÝOÌ÷#0 '9˜*åÓý‡6´„.\ü½ì÷Í LEÑê…r!çÞ-Á‚µá6‚‹ç–šrI’¤Â/¶§ütþăG®»øU¨“vâ´2÷³IßMüûI’×L]“€‘6Ž-»ô?¦{åŠß|SåŠñ+þ¾ð£ ç¥ZÚUƒ!+ëM@'ß=_@.±mèÑ3În~à8qD'ûz#E9‡×oi;nD‡:b.l6ȉKlÒ·pÛÉu®f:Úòª·<9󈽟?OÓGÏÎáÓ>ž3¢Ô'o½¢ñù|š¦µqQÕÛÅÝ‹¹rÛ¶#ÑIÉ2ÂÔÝËkð”¥SÃ|4{Ÿn˜ýíóÐ#;Ç©¿2TÑ÷³æ>ãmÿe‘9£ÌûbÚÚð#§ˆÊ•“êJ4’¯ü`ÕáS?¼äÙ¥ASƒÔ!ZséÅ„|3.é¯/%U+T¤XiÜieO3žJ.Œý7µf¼SÇ€N~’ÿ ó\g38ýÅLEèÚ>v¿ì\|z餳q"íàØ53s‡ülÁEqN¡¤ÓW_}õåKFõ{φ“·nöСsVçQ4ðmÂ6öJ™±éÁÿ½Àà8 EÞå¸ÂÌäÛ1÷lÿéLjŒêûé¢\©ÞÆ=‹[>)dáæHúU8*_~öùs© ¤å¥}Dmyàà²ðñËöùŸ³ëdÔÙƒ¿Mîk¿uù¸ù;ŸÁ[&/³sñÈÙkÏt»äй«QïžÓßc÷ò÷'¯:¡‰PçfçV®‹ˆÉOŽ¿Pàôíæêêîm˜›7p}wsž! òmBÖöHùhë£×YȦ᤾ùhÑÑ[sý­Àѽ}7Ê\µO1móòjÈ<·dÛÕô¹.ÏöS/Øj:iy›Ê¯þvpðWÕ›~ˆÚ¹d\D¶Ï®ã›¼Œ*¯J•,᳓9[b| O°ý¼¥é¡Ÿ¦Í»èÆ{MÅo.>ȃ•Ã÷þ#:}14aàEÙ†ÝeoR1 EQ*!¤¢( „h•òûcé .8_øyáòƒy–DÁØ~¡šÔ¼' 8ñÕø2ÛVu³Ë¹¹‰²žÐŽêßÒ D«?«!mÛÿ¼&dÀ’•7EL¸˜ Û( é†{¹[ëïÔÆËø ™âe¶-»…t7}öô ž:îÀ­¼ãig›0 ƒÒŠå<ª"=91=OзOåÙì=xñ7Ïx‡öšŸ F¶ì»k¦Q%Í‹øvÃU¡P˜)Jåwf~|ÛÅÕÅ{Z^ê ,IDATÅÙÅÙ»37ñfŒs8A«¨ªEx”ø MQÀ¨(í<€Ž¼;¾Ž¶ôýd¦¯©vX×yŸ‡MQ4Ô!ïköAvlºkéýé o3õP¨»ž_N¶¿trõÉ/NM¢i*âë Å9ÿql£'ÓÄçÝÝBY…·ããê-†$Hwn.Ýr?S·ÆŸ]Xä0> ÷™â©ÙòeŽA’€à$Ir Ã8êž6Ža‡æaz?»Â*ÛzÿžÆXÜ£sðÉ£mAHÆõg'’Àw&Ø÷œ§é¢8`¡ùªÆ±ÇD„.Ì”w÷7€Á6KÿL&ƒ[6Z“—ñAf}÷&¬9÷l¹êCG㪠Œºc[š—žð<Á‰.^º@”–”Y̸¸Ç=)‰~pݬ¼¹Ùµi§uĬ‹ŸÄqºï s!1à›;µîÔ«ß(W“Òm ·\‹Z¤Ž‘dŸì³Ý'òв*D‹„l\’$pœCêH§-/¢+ŽJ}§ô҉ѡ6y_§‚èòȹϤ.ÿBCH ís‡bà`—šµþbÅžèƒmM«5w%ÚwŸ£NÁÀ`@ëå¥ANðÒâƒ4—^ ¤ŸX³ð_Í×8±Ò½Îø÷·,éùþïwNÏÍ)ÉË*3¨4/'[ÁŒôiE`—'³ ·¬ûÐ\“ކUäÉÀÀª³•tG@ï—*Ï«` “ñÎó1N&Åñqqqñq‰Éå7þ‘×öŸãëëçfo”í;tãò÷ܬ..ð£ëMõ¡ƒ¢ôî´Ï£Ã~ŒRŒðÌzÍž Ppï/M %~úá¸ï×J„’ƤµW7YJüpéo9[>¤-/­ÌR1Ȫ³UÝ…z䥕y BVõdÕ¢ƒs*] ciþž¯£Ú;a…{Î¥m÷ÖŽŒÏ—YŒ±hh‚V-¥»‚kFþ?hF5ˆÝ{cg~ÑEÿ-öZÝñF£,J¾~z6íOQoI‘¨²Ö®¾NbÀ5 ØùëHW¨Nõ´ã”âi„ÌZU¦ÜÂH%OktA^Z‘uäÐ9¡0##=#55Y˜_J¤ýÖÑ˳̈́Þý¼Z˜¹,¿{u9¤E¼¿ ®¥»“UyÊþ¥ç¤»oèM“¡Š¾™°ë½|}Ç:ýpÛ7ÊÑÛ&µ6×Þ¨(»Kšt©™Í­Óç¥û}ÕåŹ†•Å—A›:ôåÕ@ðœp +yPR3«%ÿ–àsã*ˆ#h½ûøOæ~0ïƒí.Lô{1¸ž¡ Ž‚†&(pÐ SüÿHsñAT RŠr22^´E+hD«(Š®ÍQQ”ÊG@$·ÿdg/Åö#·g¿?`iÏ®Ý7ÿ ‡{oÎ'N\\lK…yM·¼¦YWöa>ůÞ.É—\{˜Ñh„¦TWÿKöðôÝ×ÓËÓJùóðùN¿›¯ù¡v®,ºtÈß~Ÿ¢üí9ÕcÙþ<¨™çŠô«Kç.{ 9·nœªÆ^J…Ôò@‡¥ûw2¸N 6G:ôZU){•rãÏÙÌ€K_„QU]^ã!VüëÇ.Scœu„@31¤6y_¯"n-ˆ¹xžâ¡³ãŸ{EÆö¨½ ×,ЇAÀG?½gÉŒ™¾ç÷µ¯êËØqñâY•ëaP‚ -Tऽ¶WÒhX䓿$?}Z¤Ù"Rч·:P^Óžžr2§ y}mmœ{vÉcþ > 1—eÅLY`~yç<õ‚Ÿ)76YV‡RžzcîªkN¡«»ZV¶A$‰åºfÛ™v#¿ùª[¥€U&Nð—îþåß©“Wv8µf´à’·ï!¶°á @ìÕ|÷|‘ášhŸEµÅ4¤æ•Јªi±Hõ4!ÝÂ\£d¼0„º~ý¶©……0¶çáU "skKˆ\ò19vëÆRQ9&R1€ql7ïÿrØâˆŠyÆæÔºtÍ·ùʉv$<Û–fO7mzŠá¤¥½£Û÷.äƒW=J+2wå+6ôvh\=†-îm°høk~d¾4ÀDƒh„щ|©¿[µy¢|ˆ+6n³jû²°@_udôÕçë—šÜxz/®¬BÅŸoddldk‰#„¤®)Ã"6Œ×üÜÿ=·TÓ1¿.çã/ž…Õ‘›¾þX§î[tp‘XjîÚiß_›qìû©á7r‹•˜`Øw»u±€}ƒ{äo¿°´¥ Ð ¡ŠtN\?qÖßI<3·SY¨§kµêͽ2zׯƒZÕzx-Ò"f̽2âÂ/z®1íâÇÆÆ†††ê4H´ô£ûÒ‚Fõii úÈ>ï=¬o-{_µÊË(ÀåáÕn¶µÉkˆhÁÁÁšFŠvuÓ 3M/ˆQ¨0ÙðfÁñ9¯Žüsë€#Óµ$˜~bÎü˜ag¶nlN«E«ø<¨)4 „ËåÖ¼‹6Ôé´êøn‚Gqî’ö®•û"t‚'¼ŒxµÍA¹q:¬8|oEµí^æÈWïöeAÿ½aüëÎÆ£ûg–o­97èeº©:w½ÿ á¢yL˜ªkÍiѲߤÆÏZyEhäuäV·b#£ê‘´"½6y Ãáh¿ä¾Ò #øzz‰0ô‡¯ö]•²Ã¡zÙõ&H+2Vü*Z}²ß+é¨Q_`SõAê¸ ÿw1’Ç…ºÚÛÚ<¾Á±\‹»Ö>ŽŠŸ‡ÃAµó¦s÷Ð)~m]zV4m  Ã0õkAµçAhjÞמå7Ωòîø ìÅðêFs› /)ÚëÌêÛƒ!eo5È•+WÞtš¬hàÖ­[o: M·}> ËÛLðAXXXÞZšË{RYXXþ°5 KãióAXXXÞZX„……¥ñ°½–Æó??Õq>´ŒcIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/axisnum.png0000644000175000017500000017225013070106167016577 00000000000000‰PNG  IHDRȱiî±´sBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìu\OÀ߯%Ý!H‹…Š¢ØŠÝ‰ØØÝ]ØÝÝÝ-&¨ØØ¨ Òp\ïîï=Žƒ;Jñ§è~?|ôvvvæ½÷ffßÎî"áááÀÀÀÀÀP~à<ïwËÀÀÀÀðWþnþ6˜Ž•¡œÁE"Ñï–ᯂ‰±2000”3øï€áG@(ŠBQT ”~K~÷1òw õ¿R»¦}G3¾Â…¡(ê÷ŠÄ ‰ÿÝ200”º¡(x’(‘Rl6ÅØ†QE÷¹+´‚A„T&“ð¸Híjæ¿[(†Â ô:ÖBÃ]RRRXXØï“ªœ©R¥Š¹¹9‹Å’Éd€¢(I’ʽ²½‚ ¦#‚ $ ï>§°ØZ|-###åö¯Ÿ»)5MKKææÈ¤¹µªch…wá gÆê6©lÅŒ5oü§¾ÿ.¸\.‹ÅúÃÇÿ|Š• ™L&‹9Ž™™‹Åª@ÊÒ:þÅ ÂêHÔ³à[KOßÐÌÌ A¥Ö Žå­ RÙäää¬Ìt©DдÀŸÛè%¶òŸiÆÅÔ¥.°êÞüPEQEá8þ׌ÿªc»\.—J¥\.÷¯Qö¯WŠÐ126ë{ªD[GÏÀÀÀØØ¸º=ëk,åd„ÅPU*#ª¿ÿ¾Uµ{ø"1##C“ef­ê`RA½Â™qQçgPv¬\.×ÀÀÀÄĤBŒÿ¥œ±*IIIÉÈÈ …ŽŽŽ‘‘‘BÙÒÌæ*´‚ð£:>}“Rµj5‹…ãx‡–·#~»³ýŸÐÊ’$Ù©•“_@¨L&ûøñc wË?¶ÑKlå?ÓŒ‹©K£ÀÊÌŠu¬"‘H&“ñù|EÁq\Ù%CE¾á¨ÔB.—£(Š¢(AQQQ²½‚P„Žr9AÏhH’ô ¥wýnIÿWèøã{_€ž+Óè8?`Æ¿GGG›™™ÑëX?~ühii‰a˜P(ŒŠŠ¢5)wJ9Çü±b‹XH’DQÃ0?Ö¬Yó—*[šYXy•ö(Xbê:¤(—`·lX)àq4†a?)O’ÿ±ûn­ôDIÁbcW¼pOM‘Âsg.xõ¬Lyûè~åF- ÕrªBÊνÚgàØrìø)Š"EÑV­Ÿ).:utt~Q£—WsSί6ãV¡¨5 lkkKïU,‚KOO···§óÑüŠñ_9/ߎ•$ÉâËTÞ[DQ”Û•“BÊ bßËLÛpTÏNÊ"Lt 0 å¿}©çjgÇQì’ “„pÛÔ×W)ë[‚ÐÜÜ‚—VeÂ$ÿx§Æ%*HŸ·bZ¤ô þ0©ï£ÂÍ*54c‰3Ó%:º(ég„Ò‘¾]@’äãWÉ€aI’²œ7/Þ¦UˆaÝ–Õ´ØEí•$ž:ü¼F‡¥î/Î/[ó©ÁÉ=‹µQE f…mœ»«Ò޵»wn0¨ßèÍÆ_|êÊ'}æz¯¾cÆcU&ÈÄ1»¶-÷òžÄ*ºÄßý?QMêšñ‹)„ñ!¼†õ ¹ô ½LRž´rot%%ºX¹”Sz3&e9ÉBž…^–á—{ǪQ`%ù’)ÇZ‡2ÿ©ï?¿ÁlÚÖ(Á,ÊIVÂWÒ¬¦¦L‘®Ò÷‰Ò’¾²Mjé`ʱ]ÕΊR6->Ú_dÚ¦ZEî¿)˜Ø­ŸŽçyðÙ©nÕy‹´Ù —wkaY(EJW{í2®[£ü³ÿ:âiš«'_ÃIS×NPP.J{))ª@]sGn‘®HeÇ^0i5PïË Ý1Æ›'ºj©ä-)R(®btÅëˆã8½"ǽ¶áË™€¢hn؆ùóâ[µ¬ª^iDàÕJ'B7é*S6­[ šAœš•üpãÆ5v5¨¯7·¯Wö˜9¼…°œûÅ?kø\üÉy7;¹òÄFƺⴓBÌÜÝX·ÐYKuùaT–rS. €;7ΨvÚÚ¸šÐ¿IiÜÜas¼.¼ær¹!«»ÎŒ©9òìJOgeæìoS†N‰¸xÕô¤+N>áwÈCpWêN{øÏ¸ð#§¬=òyþ˜æ÷–hÉ?æ§‘×lNuÝ6D±€7ôÌÍ}P}_ Cxàî;·D(B&—¢C(R.’¢|. )¡ô×LkPŽ+ÉW€rüÇq0 g»ô ³Ðº¶ŽkhJ|{ãóËnöXÅÛ4¥™Ì?}éXÇÎGŽ­¸1ºëdÓÂS Rž»eÓËNó{²XIHn^~zéYBº²°2®åZ}Lk ùÔŽuÏ7.inÈÂè±]uBTXYÙî%äÄ Óå¡Ç$\èнž%  g©.§ˆ \ý ÒEÄçí·ï£JÁD¢Ì”i«"Àª…ÇÜ–z+È ’Qµa_+éÙ—¢þM-=³—àèað|Ú*‹…ܺí7÷1R×îëù;?ä‚ <>ÇÚÚ´ukSV™Ä0’$sãCÖ6¬©§~Îc?F›Íôš¯2x¾øJ5ƒ$[–ò1dÿ9mHˆ?z°¨UÛ³&ÿ'¤S¾¾|wô~Ì·¸L!‰[˜¶oãÚÛݸD1 £;—7Ÿt Š¢†p û¬Û<[]Çæ¡NŸšã‡·ÍZµÏ &éxg‚c£Qæl¬QƒöÓµ3Äqœ”§\½ñ¤W‡I÷¯)|éк-ûV@xƒË@d÷éâ–_Å•`+eù¶Ou»5V®ÛG½‡O‰Îñqràá¯î5;Ô· 7Ÿ¯è•ÜõXscm§Ç¥I-ï¬èÒ«ãgw=Å(…Éqq18Žk›÷ZÝbå¤-¯ÎÌnDïzý)EQ¹\®±Ñ9"¹&wãiqY%u¹ ¯^‡TõpàC±nKIdï>'±4ù¾FKVeÚüî6e7c¸ùTÐxzþ 'Œ$å€i”A”’SsrïaƬ¯ç®´hâÛT/;þþô³Î[¦YÊrã. Q=ª×Ãtõøæ–¦í[U¯f‚o“Êî4ÿ]Êñè|6"ÉT¥§F_Lï¹­c3KH.¦È¦¹r‹žï”‰G‚f¸:[s1™P*Á9\.§P†·Ç®¦5lÛÈH ^ó;òœ={z¯Ú&XxXÜîý|¤Ö{Yq¹UæÔ~·Ì/k{SÚý@eɱš²T*–"Iø,1©QE´äñÛNÇ@Œ@.¿ô<ƒa£éÞµÀ±C‡ýVN>è<··§¢mrü‡o1Ûï[Kåì+·_‹"tVm¬ödï™wf͇q¹,ZÎè9ÁL¡WÜ“«+£ÙÊK Uí(›pX=Ñž"åYYÙϼ^²âÛÂýjceTPå°Q®Ž£ÏWõs~tæáH6GõræJÀ§1Ã[êæ_˜>ýоf ­_Ýe£Ú–Ú\.û'¿ý—w½ÈêÖ·é˜æ\aÆË÷ûÞˆö\ÔѤx•¸VÓVö­e€’€H”Ë‘¢ÀÒvëѵŽáãµGä.[›Æuo3ëpÐS3ºë§d™©|'ÛWVS”4&—cçdfJÂo„Úöß¿q ³8ýìñ¯Îœ^kÆV †®cgÌq/ªæàd¿y¿å¢÷³ÏGoy–ß(|ãm&Ìæ{ïâRuª=uMT“AQ“Cm¹8Ô­®óö‹¢ÃRoôE ÏEˆIµ2ÀÒ­Íñö…S_‡ÅUu¬ÃWÔŸµíÐÅ×ZÌíå¤) ¦•³ ïîY! Yr¦ÄbÞ°•ÚiótôÊlƲܘÇbþYK,â›bÚ/$e ˆˆQÌÀ8º†ŽæŠß8‚<9x7‚…ŠRr’>ù¼ÄåÒŒìϦ!„§*y!³dÖk&W¥HyfFö“‡Á WD,]ïUÏ´8ó»Se¡Êñ_yùÀ6¬>ehuÕqqÑ¡ˆæîªc>¤|¹ŸFÀ±M׎<­\Ý*릹Ù E#%)m ÇQÁ°BÕÉ%©¾r–î0Çq .½È²ïîÙ²ŠÔw7¨a«û]׊ÞU«O“¸I‰žƒ¬Y(ä ,ôØ®®¬itâõ,¹ Q*"’^¾ÏdkY7tÊxªµxTåW¡Q¹ª6åä.Ù5{x]Ua.o¼ªœ±Rò‹B/\Ôr¸OPXÄ»½ñ•NM±ÁÀäÑ6¿OyW2aî¦P³vK·š£bîÓÈÍùè}§Ÿšv2*«‚(ŠâZH<Å^\e6G‘ •‘RœkÚ¡±‰á§7ÀlY ÁðYA·ö1É»hÿ“ßìxò}è’áíiûÖ³­bë„æ¬ó‘èÒ–ƒ§£’B½jnâê&nÕu”åæ4,°ùA0L"ä&94½G×:u篘ÑyÕ®Ãþ5gÞ6Ë›P£,Ëá£g>=à}­ÞLHô}wåŠÛà9Ã{Vê·*ÖzW=;ûJâPž‰§½ââݰNç¸ñÍŽVs#ÓÕÅpüpq½Î-¸ŠëÖ”g eÆcëhç_–IŸC{÷6î>ûÂÀõ½«:œ­Û¦‡~î–7É›U€×Ÿr”»Ô}ûÎÑê3ÍûOo’ðÕÍ æÖ‹k{7]…$ºVªüdÎÀÉBí=ì•Ù?xÌvõj ˆ¨ê¥i°dŽAãz…{s(»G= Ö2®Ï#2N\{ŸW†¾D¸EoUk<§(ò[|Fýi=ê«Ôuvõö˜î3 ò¥Mʪ\ÉC4Œ²tò]¯¾S̸‡ïç¸÷2.M–!ú+ËÙ-Y<Û¨@*E;]¯_Ë.¦$¼Ú~Ûpî0{ÀÙ.9K h=÷MûüL®çR“§0z 6-ë`D_ÚðÍllór²´*wÔ–ø*\R]»DíÞDVÑÍékFŠØ¥o}bʆø10œmP·†U ËvªäÊψR?°Ç´n½ ¶˜xgä–ÂjòÍœ6²éã|ߎGNGéoͧt›`ª˜ÐÅ]Y«Y;%y‹æ)ÆF¬PF˜úªÇØ7êéR‘´žÊ¦LüAL.ÉA”úùÊG×Mj l´|ÞË#·bœ½z˜àˆRÇŸQðü‘oz6ózUuzõ8Þ JÔÉõš6=k£7µ,æ=¹¯!°½¥Y¨Ê¹ð%[·Åˆ‘Ó âð¥«1V‚°uºÊ†Iü´ouصçì˜1^¤0xÉèA!úNnÔøÆÎ#WNì]8ü¾/^†Ëö¿AšZ¥=6r¯ª,Ù¶Ÿï4ðŒï”W5EäÜ?½nï¡;“6é^ þ´¼]Ÿ÷~0m6_y,@9\ýûfµê¿¤óëv!õt9ô^ežîfswD[€k5íw¡Â¢b©¸¦å Ÿ…V£ô5æ/D•¦[5´T¶5EÉ×ÿl2¦nÁŒ”HFÛªI-Y£û—Ɍ咴ŗÓSKÛvílëØ˜lkE½);ø­}‹*ºIHÎßx§z,Iï Ymž†œ/Xæø‘­´"]O!9Êrâ`/“¤¥8?ÆJ%=ß.Ô4þûšÖkÝX§@_÷Äÿ¾ÄúRÇjt¿–ôŽk`ßÔ-\¢(âùÛX( GcŠ”’èᨢvµ{ˆ×RjÕW&™ê´<¨ß‚ø¾]êtmT™_ÐZV篺šÖÔU®FPªVXY€wO>ŧ 3äá7„§@õÿSÅoûõ ¼+%B– ˆ¥úÙ }›T¯OÇZ,þ…×C{ €¿—{ód$dƒ¥¢äBÚ„,çKÄwŠ 232Þ})±rœã¦«ÌPA¾qý+U»P‡¦î‹T‘™$ãüJý:¹@ÔíˆÛÉ:‚°x5 ÿk9Õ®zÀÑkaƒºVABAŠ”úeÈÚW.þKQ:*΂¼ý’ûwi¾?¼Á5ò§Ÿ¿êaÚã5–Û½»cñâåÆ=—µz±zÒ¦³zÊ 7Æ áV¯Õmç /èsCÍšŽÀxvãÖßÿàÛèõ«›f‹É.o®EÛÍ·.¦®­ìY¦¯»öØšWx*ó9I¨ß·Àd…"EPuèEÏ3•gŽZwÿŒ‚Ðΰž±pßéHQ”2¥pa eÙþY²ùv|A²ãü‡®ŒQî’‹$ò¥'{£À3p9±JqKGßι~^áôònj³ÎU7ßB€º¸ãìq+‡až =œuètuK&e¹ŸÃ“•Õq ŒìŒg£ôftðV¦ÂA© zä’{'ö¤/ž¤¹áûuñp¦ëÄXüÙcZ?äáÙÈ ëóá[érq†kk«, qïÕ¸+J`UÏŠþäŸ-oÐLN)J` 1VU{Uo•”w¶¼“mÞ娚˜2ù@̈ÅCØy Ÿ)Ö®ÌWÍCÉÅö߃’˜²vh3 2I*ŠóÌÙ(­šR*™0iÕåœÅœ¾¦ËõZñ”U8Ô9ºÞüì•×çöû=eìåÙt¨G%e±Ux¢ëib[HGue Fg‡¯É_Åvmê·_%#HDqoK¿ˆäâQ¶H‘™"S2„ô!RŠj;¼]ý¼UI÷&ï•¥f(lÝÐ@[žÚkÚ=ÅQé¥ïlœjp6]M_3¦£„€ù«/˜Üµ‘«E–bVRH;INø¶£ñ!MHÌÂÌlÆôs3QY¶Sz• û 9ÒÞGót¤9_|%d|Hu¡õæýúƒ/ ›6jò%Øç¼ù¸fÔ™[1Cº9K²~\ABž#§@ß9ß`d¢¤»/3èß–nUjñ±ÒèXÛ™ÿ>L¤Ô@’yuÉ‚oê:~Λ)u¤¤¾kŸ7õÝÇ1àyõ4!NlP[géȧÃv}hWË””÷Û9{È .Ú-}ƒ )þžðpûæ‡o_1ì2vû楀hõÚÜ¿ÙÝëIóo#O×5SŒDÖÅ  Uý1Q0¢¦éK¿ã/U[÷¢¡Ñb9¿’¶Jc嵞y|ïfýæÝ<Ï™§Úp|+-B®ª{1^H’p¿;\³zÍuqгjsv›bþx~ÃÑs¡HŸs-8 ê€L7{÷·æ“³U:zAÐ]Û:|×wå±kMëOâfÍE5Yò×;¢•VnÓeuňRJ3– ¾­FŒ5ßxáè:ÖæøˆÏsâ@nÂ7®^u­‚ñàÛþïköh¤•ýínHeßÑU;´ÎßumÃÅ/¹i)ò« ,|Ûv4—’ÉSSÓ^†¤8ÔoäS[)V`Í1Vå½-ATouIsâçmýÀôéûœZóGW®¶Në¡^}ò <ØÖÇ0L¥X½K{FÓ¿Kó€)N`ñ*Ñ%  (†aµÍ8Û†ÅÉHžGµ -SËa£,½½sn] ÚzðRhv¿µ½Ï?h™±iý⥚š•E 1ú;ú]*’¦}ùF‚` )'(‚’ 剂a)ÍY»—*¨¹Ä÷SŸòÚ’"E¢´W+÷$Òó÷³zV2¬~a‡K‹·kÂN«±-lâÒdÂå·0®ê‚¦WëÞB›jçZÇ‘»qMR¿™Þ-ø¤¼ÚáÝ·&Í‹o1l†aüŸPáè¡bd˜sžüòŒWbàÕ‹¯ œ]uØ¥Ññc¸D©#†"Ç¡qÓ6ê:朕£(},EÈÝÛOínº¬S»glJ‘R9ÉbáÈÛiÍ7£lR&ñ¸¾ÒÙ€­çàX5å™oxåñsÜj¥¾ö=ÒkÎÐZzl¼ÃÖUK›wÖ¯µÉš§˜‘”,ìËûBUkcèÇOïD§«-Ã0 6’&Smq…Zæ=ÍjÙnßÝ”Z€<]‚±­éò1\R|£«Ö(_xõ{ÛÅÝòŠÂ0 òÞ“É6ó*GrX\®†u¾E‘òÜ-Ën¢u›/¨¯¯ê½(† ,®¾÷ØÞm›}\µëá£–ÇÆÙ¨[2ϰÞé-n ÉýKiƨŽí´ÕÁŸî`` ­µWÒ±9:ò,Û š›jπЅ ¢ô/ûÏF©îI‘”6¯Éõå˜ë"V­†]ÿ!Ö.Vù«¢V’ßÒô”›¢(:‡r‰ƒ$;nÖÌËÚm;îh.´à”XÖFk…Wë˜;ÍPy¤4÷ÛÅ,8VSÇ5÷›¥y@ ìl˜™[[ºjúŽÊó‹çoBÕócªã˜³ÐìÁr:¶ÍböØÕ–82åÊ-Ük½KžC¢¸­A‚Ð7ïÔ•uÔ ’©qKWOwÖPC ãh;x÷ªyãApVÇú}ø™Çná8¸ñÖÅ^Ô¥]ÇcÈFG–6YÖ²O–Lé÷ŽœÞm²uvsKŽbØn;»Eq(9ÙÔwä\k-Úè\A\»½.ëùÃX¼£)mÚÆu–O¯ý7£y7ÓJÔ±†ûKAëˆa‹_»[Ïê:F®ÿE¹Ü 7¿Þ÷û³ŽbÝM÷ov‰<Ñdrø&¿Å ž²ß?âþþ†–~Æ~ÎŒãvÝ{ð,ÓaÏÄžMíöìŸÙjå”õÌ@˨Ae–(‡Cb8›6j¼Ò’•; Uýðì¾nó6õ1)¼Nªërž…åä·8‚ *7k»Ùë¬Ùøµ<D™˜û9“mP‹>!Um±O‘²b=ßMäÂ=k¯’¶u§V-°ð6áÛiÇS—lŒl8 <ç…ȉ‹X¼úÆgÜéÌ´z¬‚£wóʺvÛ«$‘<G4Z2½UÝýKkÆÒµ.ïû;@q/Ô¾½aζPw€çïU&’_‘Cpm‹ŸUy•ˆª,¿S˜¥UÙ»—»ÆŠX *‰è¸­0–í3Ù±‘Ó¦^ÔóØ1¤ª®ËáMoï;±üzœú©€óýMÜÛZ²‹ì4•~5Bʲ7¼È:P¥·¦d÷žžM¾uI .àÈÇs¢óW¹~ü:‰Ì¿r1¶ã Êð¸0ZÂÑ5Q*UèC™.F]ü”õ=:C&ÉLúþ%ìËͬKÍTÉŒþ¶våáÃ1dkìäåǯß úrüò‹ã—_$èÙÕ3Í>öè–ËŸ2ä}Í5µå[ÇÁRò9”eÕ¹¹íÓX|a{CÐ%ÃÍQ._.¤ Šæ{Z|´ÅòGÎR*˜¿ö“kܦIUõ?[N~£ (Ë{\SD&ó[žÜ2|uW-n½Ž'· ŸeÖc¼Nn>—d!,¥H?£ào›ŒˆÀ!4o. )“ù·8JÔñk,…aùë´)J"̨ÿÉêñN|ä‚…±«Z´îÒh[lUWS ˆœ•½[òúìi/ÛÓ}ʦ\âG*pê”xóq‘»öüÓû_¨¦=»ç0ÂÃP C¿D%6:rÁ¦ÅGü’ 7,jŽæ'ŠÎ¼0xýûIK46Ô¼”‰ž<è7ëJ†]í=«Ûé÷Ì Šóé@£%åþe5c%:•ÄÙ¡)rŠ” Î¥#ì‹üІóMuMŒt”Z#׆¼Î½”‹òȱ*-[‘’\=å¿åJ˜[×v;‡Ô¡¯mÍê4:9WæµêŒXÚg­—ƒJEԭç|3<°&«¤•Ç…çêÊ"Hé¶E§ ~›ÎÆŠguP€7›…ðœöïi_EKq”KgíW“XC¬€”eŸ8ÿô器éCêÖr2ˆû½{_¢uÓnì¼E¿¯^æØõ¯DÏøè‘G¹îLUY.ßȵ ÉâoÄ®5ô@K+ŒÅba€ ,‹…ÓÿÒŒ¹«köð¸ÔVçþ‹4 dX˜*î´6íÚxj·Èçµ9lBÜÊ’Ï6â½ÀXìa¦Ÿ„{á¢n§î•ùlÄÖ£‡û“ñ¶sÁÚŽ)Í K á§7¾Íî:e«Œ Òÿâ8 È4u0 Ž«.–fá(‚`, ÇÅY,–òA \ÅØú)íZ÷žøîÈŽeµiçR©².DD'_<ªm½ÄT‹ÅBK££“5ò-‘Â0A€…ƒ0ic›æ{Ôu¦ á@«HH¾½ ŽÎø’.~~©•%J~) Ëg}yŒGŠeY!AÁ¹ú•ê5³æ`À2jܺcèÛÀÁìvNïš·n{öèÜ­cú¿5žpõ0Œèºª_Vï¾x²^þ²kRö=K¢o …HI Ë«º¶=fæ.™˜“ÌX(h[ØÙf¨ædY{žœ×mæAžä‘Å›:Úâ8P8Yca1T1ñÔÿ鎓ÏÒŒölï⬕ï} /nd™îÝíYUŒ*`‘Oßœ üü08Vªk®GÁu*¹·<6Ur"—§2A¯öÙ{'ÝxãææœF4¤èåV´°'²*Ggº)‡WÃh~ £êrUúêJÍ ÜN#ë›àÊÑ_³uäžþ§ÝX™(ÀyZMÛ¶X8¼])Í8•._án@_M¨.ˆ+¤,G˼MSsˆL~3×¾MS3$%ä$ù·xW.’R“vB(@+£(Šröíê™$ý޶¦@H1„þ œ–zƒFÙkã(!Ít´´h­Ï~‹‚ íW »±ãàÞœZgG䈄$ (Æš½vøÊ™}CìÕÒQÕxÆú&¼ˆU;#‡mnm¾xå¸N5ëKJ¯ EA”öÂsœ†åV¢li½¼‡óHiæ›°ìÌ(‘L’úæ7)Q"NO~ó‰Ï!²£Þ ü()™‘ðVÄ3s²2‡œŸQ¼gw«ÿhëµà¹§oç·Z5ëzÍZÌéåJg(IG@QˆJ¢”Ó œm`ã²"ðöuw·s e+ÌV*|vôÐë&5‚ ¨Zî=tL[¾8}ô€k[ÓûÇt¬ænÃãíë[ek¤nÏS‚6Ò¨×þŸ"7{ ›­ \<œ`Æ Ï~Ô7±²®:¹¥îmඈ±heÄÓøì>ߨ×R·Is¯;ÒËê,»sU-O퉗ü'*~;?‚×|¯‡!( "(’„b=òúéÙ'½{w›Ø³j¡‹I«f=Ž4ˆ¼znÙSiF´°Ÿ¥ôk>ú=CËbÎâ¶µÌXh‘n‹ÒQa5ÝÔ-Ù:[K5(©¤¬fŒ q5èv–ô0¸ræaúç¯ßvç±tž[à ïƒÃ…Üš Æj’>"æaظ:ÚqPk|\µ•äw¬ôà "xº6'Óx*ÚtZR Сùø¦µ ‹­–s× [ <Ôeƨ.jÙøúÕgW½³âiÎö–€a§{M‹dxÁwaÄ>¸Á«Ó¥‰ž"O‡B”Ïo¨*«E$/g±Ìí;ûmQ<ã@HRúÌxFï¤}Úw*IõÀîŽûN¸ «Ô¢ÝŒæúÏdﮀ€b¼nÐÌÝ£v-iÜ­þó>š;¹a†a‹6¦0 )¬Ë¨AGyÆÊª ‹Í·r𸼹zQG¦ìÇq:³\šxîúývÉç®'˜T…ès×£ÁÀÚüóçsŸªØ›¼9ûZO°ª¬÷S Ò¸´j¹¯UK  `œ‚FT’Ž€¢`c†$fPnÇŸÜ×|º&~Uþf[ô?x¬‘gV1'ƒÆóL”+qv® ?ö¯cëÏ=r¼ÐQl;ŸØ´ù"A6ÅÑåý –GöïoäÒó¡›y ëÊcC'û~ßÜ—Å‚+cä["UL£;ví§3^ü%¼]ûv³œ²e<½z¦ù—ÒÖM»lmZ¼8\-‹£ÚªÏCÕ-ùDQJ•ÑŒ1@¹ºÚH~°Î Q#Õ+hŽay·”£"’$Å^FókWqİrX‰â›W>ôòòâp8C×’¬p¯qöj^ôù"¤iƒ‡œ›¾”›Êµ\.—H$gÏž-JYŠK)Œós#„FdÊfóh ¥vz¬(&ÛËKã@Á_Ç(XLóÑÓˆ›vùyyyq8‹E„—* ‰KnXMQÕ øléo7ôŸšwUN@ “DB={vÚ¸.” —Æ’ÀŒ)R.–aoç…šÕiÞ¼><Ü=çüð›[e†Ÿœ½¾ÍÜ-€{§þ®I†Ÿd`³!B Ÿ{°é´ãÞ¶Î…ý/~sïÒXW׊Gtî1®¨½fîã,íQ¦þnŠëX Qh–Ó˜ƒÞÎât¿5{¬œP¬õPßuð¤¤Ä&‹æè¦II‰\s}•·Å¥†ù.%c…2aì×OŸ²sbsi§OŸp¶Å¯W‡á_äbp¡6c žÛ~¾P_=sèßËö­ÊÚ±¢,óùó¨§Sòì…§ Ú(¾—›®gmøvø. ¶µ³€°£“ÚõknÎ/Su âb¬$e,È}>jÄsB÷ü==Ü `\{ZpÏÖ—t*³Xþ¥Ö…'ëìô@J!}²oûµtQz\nìÕ}›žðd¹_Å™›6½ç›ôëC’”\Â,˜eø¸úô»ÍJKuc“’!ý#Ä4pWO}¼¦W¶y÷«ãëˆÅbqºŸ{û/tªŠ­8$n> öîX§Ý°K}ÄbPò3Ÿº7´ÿ1¥þ|Jc5_<}ltºDœ~óm´ÁС ÀÉ¥Ú©ó0ðÀ¹ –Zp­ë]6‡>–¡Æî¶f{7€‡î¾v_«Ìð1­Ç¶Ù·¯¼˜²Á9LŒ‰áWCHb/§‰6×µàr¹™aSZ÷¨Ü%ÏÉ’hßE´Ì†<ð{?0¨ÄÒj4ó0Ë{W²”eÜ6óóÁI§Sv>º Ïç×ÒÓƒï³*8ks›eÔ4’ÙÍtˆ;’‹Ö†\.ÀeÀñ=wWi?cúœ.õ+•³Ú b¬?PþöööŽŒŒÎ¹¹tAD­V†Ñ2Q⃒û§yZ|¹‚œ’¢„2’”²³³srŠegg#Hþ«aíímŽ=Z®ê0üµÐ¦¨ÜT·RõCBöLâÛŒí`À}§ Ožtú¡Ñ-ö¿B[œº³ÎNApRþ}Þ¼9% °ìöãöú\ˆ½1eÀó«ç`¨09°¿×º!›o{çÎdêˆ*>·"±æMλá¬ÇÄl“ñë;òT¼ Á/?¹·gÉÌiý›è9yå’‰m\_ø (dŠ…c¬ÞÞÞôe&B" e@"Ba©¾ïëݧgA¦Ç¤QëÆõÞŒ²4Aâ›Þ½£,ãåN ,\YC1hìtÔ­T¹ðغŸ> ØFp€°ÓvE5Yçüð‹ÍáÐï ·xþüUé…©ÔnQÛcÛ÷Í9³«çœNcªÎ:7·}eÕ UÇ^8° ª»3<_y¦rÏM… Á8•ÆûžêÚíôÌYËG/q X‡3¾PÑQ·R 1ÖOŸòç¤9U©ÃÀ¡öAouGŽl•pû²D,&(IÄI":úá"9’±¢c¬'/ûÒÄÖ Ú¬:{¥±.;'fYÛ‘f×®€W³Ú)c¬ªµ00zH´(û!åik†“;{Ϭª¥zTÜÓV~\ëw¦µý¡+Ö¬ý~øØîíšœvºÃ׫Цr³ciÎKŸ‡)«:+óˆÅ2¥.&®=Ýj–@è‹ÅbÆþè–-2ƪ5vv×»±w½$V”Æñõ}ʪÛÄ@‹‡!ÀâpSÏî^IX7\kcD‡è+—˾´aYuZ+S]r0@pEE™+àn3­ˆ”%-ÔýR¼Ó™» ´¸Š«1Rž~tå´u—’Wœ¾ÜÞÆ E0öÏ!wÞá;™š<þòãt,êsˆ¤Ãð‹¡¤OoêÖ¤å-yÃÓwŽVçç›\üí%WRªœ¹¥g €ŸþŠ ‚é,?·OëõÎþëŸhÌ ˆy<©GÛ§6ÎÌkû³•1TLŠëòPLÛÜÜ$Ù:®Gÿfik‹P$446[×GHAfÒõ¤„>yëXÓß> cÖÆCûÊ&ß+yåtlš¼|ù2HIU10üáLJݜÜìÆ9#;zÚʺóÖKšs;7õKÆPí2|¹S#}÷“§ßeUQß•üdYÛ1wúÏÚ°ypkæGÿ,b¬ùa#ĦC&'®=jÖ¡CG:9rHûˈ·ˆ @¸ZúŽ-‡vÕAÅb±” qm³Ê•+W.\‹ŠG1ëXÊŽºÍJ©Ô{G`/Ž.†’"Í˼ˬYŽ 2þÒúzØÏ¡N­á=4 ¦[{©{ÓtX„DLÜE sfÏfìÿo¥ 1VEJåÑ®!\®b½Tõáëï ×Pn½ù×Pl»ÈqšìßWŠp¸,f g(¥ˆ±ryPÜ* ›j˜c–7ÜZE 0jÔÿ ÃïA5ÆZºè'‚óK6[@Y%7Êæ1÷­þz˜É#C9SlŒ•áÏ Ä+Ão§Ì1V†ßK)×±20üFÊcýð÷¿õ»E(mÛvøÝ"0üÍT,wÐÈïõ¦c͇n Š¢(ŠRþ¯üý{e£ò ?~ô{…aøø“ÝA#”01Ö|Äb1m1*ÿ*þ~KR•í_k#&Æúÿ󇻃F~¯01VÍp8œ‚ãs¾ývKR þ½6bb¬ÿ?²;hä·ûcÕŒº©n–cEÁÁ/ ^½úe’­Ð†_Êÿæ©è>¬c-‚Þ¤~àíí]ÖCþäK0†¿’ÿÇŠ2ø í#LŒ5‰DR(ФÒfåßZr¹†‹ ¢j4ÿZ11ÖÿŸÿÙ4R±|äGb¬„(<*ËÂÁ¼¨§ ÿ8’€"IR¹‘þ6w¬a«].ÕáxYß±”/Ö¿aü1VŠ<|iÄðÊ”çì[63Á5_Æ];z Nß¡ÖLãÞüb ÁÃFŽ¢LÉ"(=¬ˆ÷¶–]ŒÿÝAðíñÇl놵mJW)"Š@FøIe'sv g*š”ö}¬ª|Þ9i䪷ÊÍ× :tZ¬1çÅa=»{zzyyzvïÐ¥g///Ï>ž:uéáååéÕ§G7ÏŸ&ß{–(,Q€ÜØGSó$åÆÌ «_¦ü^J!‰•ùéÞåË—è¿ëß~XŒåÿt“·k–ølûRÔÞo.œ9±w×VßeóG ölѰÁÈU÷é]·§ ;T²ËWhJ{óêà™èö§j*7I™DZă3¾E¸ šo­ónEûëÎöwHÿ<²Ërï'›K2ï»zìSÍLH¦ô^0Ø/Þ-0õ^|í±6÷ͱzfÄü>ã¿ùß>…rsgyN¿°ý·ä”ü`\Îf¿§v†²@¹Ož ‹øF›Ž}×èGí2àûÓùñ•‡»ë°E©r1Óú:ìB™o^÷#( 2 òÅë> šwì2iÜè&m;°H}~?¥é¡{›©W$Í~;bî½…þ˯wÅÓ‰|c³ÎmìÊ*hr–B6úTýÅn"Ëþ# ¯¶O|Lwœ©¢Ü«]¹ŠŽbމ¥Åg‰QcK‡ÐSG\6Ù\Ë^ë_z­]©b¬’¬@?ÑSã¬'O>Ò)a)b1||òDJor œkØ).åøMôš ãc⹓

ì˜Ónþðž…#JË°ì‘ €¼øÑæÍ›Ø_Tž#FN:-o‹‰±—QçgìŽé¿zº›œä›Ãa¡)š·šðªGÞíR† ݪv¯ì (Y‚TË—æ !Ú?Ò~ঃÅéWúŒ}wíì¢ÊºZ,æ-Xôy²Ð`ÐÂqÕ„IÎ^ï³jñbº(—K¦zÎî²ßÞäÂì»wä¢0Š’Ý½`J"}woö®:µMa×®ÕÖ*`$eCÝYp^•öí5<µY^n¢1ÆÊÂmˉ´VÏ£[“‹N[5®]eÙ’Å LJõÖŸ2·‹!AÐ÷S{ºGd2wæØW˜<%Ûôõ³³ÅÈP±|¤lëXåÂÏc¶}B¬µ9úmmù)Ú¾†âR"r÷ŸñïÓ·»>†IdïÛ·WõXJžz5“Ûýêñ}Ë\´z½†$?[#3ROå;„X:àÈúíîC&Ÿ÷Üîi_H¶^s/áÚà”=M, ýÝ.ßãá=ú6ÖÕpÝT.Xº52'IŠ¢iòò©Â…{<›êrÊ·Š)S¦¦¦¦\¹rE}W÷îݧL™Z¾ÕýÝ\Üv'|ÄXÕŒm±Ú«òÄ‘»zøÍ¤SP–ùرãï›xÉm$ly}ù–»÷Ľ,º-O°Ý[ËÁÁ"]Á3îêàÿ!ÛAуoøjá‡Ï٠ܨZþí¹ÛÝæ¦ãüj7nŽ8Ýçæ]îú›é™AÄ©¡O »×?´ý®JÀ·É¨Éî:eCÝYŠâW» I䤦¦ª§ H•Ø Â"¾,òZ-¬i­•”%emö}Cð»Ô7/ïuØÓ¾!uøòH½h÷Ö«JScEô‘’£þóǦë+ú_qf@ûž=’d gø­]²PÙÔ(n¸nÝ#ƒ Ë×,™ZOWWÏÉB9VººzÊ¿î }×­Û ƒ!²ë³y‹vªuQ¤€£ßìØœ&w|‘-U¦³»É‡Ÿéß‚¸À‹/„}·¡ùxpš¼ŽO¹÷ª€ ȲeË=<< ¥{xx,[¶Aм›ÌPB¶7A0º›u¡ôúsöêÛ½ìùwzS.|7k@³o.­ì…¢ºg®í`¿Ý{øÂ”8öuïGH Š3n¤è΄)§¼¼»k;×HQ>¿ÕŠ‚•l=ãkR±týÙ m;öîü  ®6 d¹ïNA»>ã7Õ¯‰ùÞaQb¹>"ïØw $žùÒjðà„Œ,‹šœEœvmòäûJ‘ìûíÞ3BñÝ—rqî #(J3NŸ.ÜÇÀ­ž-.r¥UË J˜øáùó¤h1Á~p€¢÷&Ë7”K2eE­X>R†+—Óf鮺ua& l:}|#Óy{#¹­ ívœ±ûøB± 6‡Ëa£¹I—7o~ º+6GÖ‡ÃUæ•Ú¶úÊM6Š"No.8µþz“±óïõ]äÌWÆX@ßN›Äü¢è‰Æ ’L>kà<=à.­[øLbVØ®Í7c—ÌnúcÕ©FfµµYÛ¶m÷ööþú5ÌɩʶmÛµµuÔŽ`b¬E¦¢/—?o¹<€NWÆX¹\j [[:ïŽõ™ê¤OˆbÓ¿ïÜ|Ì߸«÷ÎÛÑë²Û»é[©óˆ¢®¸Wâ*VYr´®\óW­Ë fëf:Àár *wÜÑküUïïml|æÖš½êñ´ë×\#§´Ýc:¢MÒ‡CKÅaaªð£2Š¡ÁY´,Æ«Qï9cF^¨­š.I‘ lËd.?d9_æò¦z¬ñ]¿Âؽ];Õ½IZç6ß,·º´µuöíÛïã3ÅŠUš,†¡8.O™jÞïVO[{q~µen¦¾3ÏM½2 0m{{‡”çÛÃ*YP·Zê›íûB:.ꬃ!·ÌYÐbA­%•TÖ®“Ò¤Ùs–Ñ—ÞLyqökÛj-ó—TÓ6¹û€&Âï~Óo‘×[´„Õ´eßö]Ç,m´S³Äe£gQç—ºIV̲NÖª§‹¾ç¨~(Ñ°Æø9}Ò€…ÛÈÄL—³nÍ<døçrjà¨Pž…âºêåCò‘2ß7Ôsî ÊX”,Û` ß%I.Õ0,*'Æ2´°°PMÑA tÕt8O¾dC͇×y¸÷™z£Ökf}ÊâèW-«Ì?IdèØßwãžñ-^ÍZÿ?Ôhdd´kמÿ¡¢¿ýj5}|æ±k¿~?¹>`l‹n]šõ[2§ãŽÁ=šXïÚ¿¼Õò¡Ý\€£çbÃçp⤰UwËpölŃ-×úä¥Ërc c*Q —ÆÈ%.“w+{C»^㊸¬bï,…ø¥n¢WyÉíËE¬ PÙ Û}øxx&$åÊð §¿±¨ÞÔ=eß.³&3@. CÙ¥|j+ŸŠâ#¥[Ç*#€’ÒéˆV{Ï!ß³…"2z#bÜß ‘‹ÅââPR‰XFpPÁ={«îJv5™D,VXžsÿÊñGŸŠ'*fµR’¤(™jí3,÷k; pKeâû‰öéÍägËglÿV¸zQ6ÒŒ…€®…]Žq¯M÷㳮Ϻ,T„¥$1G’%›ÚÛq¹l`ƒ(++“dsÊ+˜Âá° …”욹п1"N ®wªÐ”¶Uk/ÕMuÊt`!Á˜kQgàÃÚY‡Sq>бLluù\Tã-có¦­Ú„|ò–ÕÖás«î#Ïì·mÒä·ÆCî.€‘|½;µóz»ëäÖzl‚â²äÙ³«µ²CÐ^ “3­¶îKØš\!©¥•¿’‰@8ªâa€°8œŒ ‹…ÌHÆæªH^1ÔÅ6ÃDók=ÊÉMÔÝ¢(C Û†?ªž?#I`†¡´U˯öLKKMMMù”!ñ¾njéàè½uafÝñm¿> Œ4 ?þ͸‰Uñ^P±|äßÇÊÖ30 óƒ6£U¨ªüõÃ;a±oXà6héÈ®~‡Å®‹çÞŒ=ÔÍjÍ?vQ-§Ë¨½·òÖiD]šÍoìÛ\OaÄ-7ú·,½ø%£nFJP¾N§Lª¦šÿû‹éÃ6s”w! º–¡(Ì[Ô³ŠIÜ}6,çkîUaÿPQÚ=ú {´ª'£ÞÜÿ¾}Bnã¹s½Xf8ÿè­©‹¬óÖQ!¸¾··â¥*‘§CΨ–ŠàZ¥x1‘4çÑŒÉGsÅÐay~²Lb¨;Ëå"ê*/7)€gâµp¡†•0'y?V¼³P¶µ¶ie‡šnfV•*™èk€8í¶çÁ‰£ÃÅ·WŸ<ú —Œ©R¼=W\Aâãã <<ÜÊÊæñãÞÞÞ‘‘Ñ…2Q„D$Åù¼Rb¡Íç—ò©`qz`§öÛŽmVÍ¡øœa!÷{4ísïºû¯yÀßÿVË–­4v¬åþ’Ç·oßx{{¿ÿ¡ô‡¨ öâÅóçc‚ê6Y”•–B”Žò vºdÑkº)¡PÂçžþ…B>Ÿ_D~1Ÿ¯¸” …¯ñåVe£TÎR^nR”;r±X†s9ô!Å"›Ë)b0ËËTÚ÷>U,QÚd\\´££#”þ}¬("‹K÷Ü.ŠJKÝà7<´úÕí¯i!!E¾&‡æû§Ãm7ªÍ&]èD"‘Àÿø…Ÿ²Ç”/ugb¬?w>”åpÕPŠ¢EÉ€¢Hþ.%%ExNÅ(³”£›á(Žš-ga$!×üj&JÌ BÅò‘?ë›W6­g+E6‹ºc'ÿbIX,–Ò€ MWË·oõöö-ÃË~h( &ÆúÝäsTDa¾yU¿.@óöí»8 Aàˆ1üsüjwÐHE÷¦cͧ(Óù3Âá )þIþ þlwÐÈä#Ì7¯ò‘ɤ*Ÿ%ÏÙ+ÿý­ê_k#æ›Wÿ?¶;hä7ûÈŸcýsxöìéï¡´ükmÄÄXÿ*;h„‰±þü; ˜J„q‡Ÿäú Ãÿce¨01V†?&ÆÊPÁ`b¬ >ª1V&ÀÀÀÀPÎ0+C9ÃÄX*LŒ•áχ‰±2T0˜+ß³ŽU—¯õ~Ë¿“Ý{ünþ\þ5wøŠ÷ ¦cUàZ§V£F~·?ËÓ§OKÌú?ÃPqù;Üá×ñôi ¥11Ö¿ KË>Ï™­•™+ßFQ6ÉÄXÿNè~³D*V+31V†?¢l’‰±þ(/A~¿`+%¿âÿ¤PZxlz‰ÇҸЯIå/Ï?O¹\>jÔ(¹\Î+Èï–ñÿàØáƒÑâwKÁðRrŒ5t×LßçÉÊM¶n“½[ÇÎ54E–oµ–‹W q¤KsžÎ›µ§ý³ºÊ½âŒÛ:¬ðü¶^\?ž±Ôs¤éËû ‹É#Jü@¹70/®kÈ zÇ«×Øè¯½T¤ä甘 ˆ#F1âÔ©SVà[+FYÊ«0ùÜ^?ý©#Ú€ïÊåúí{™6™ x–ÏÕm‹‘:i‡¥…?¯4uõ&[®â¤•Æðà°=%?c•D}4Xuh°ˆ3ouÌår?¿:tÿ‰6ŠÀ—VÄI•GI“ïs :¨yaŸmuÚüœØk¢årPR–úîÝ[ÕDG×êFŠN„&L¸t°_ —Ëy·|ÀÔ{ñ€ ¸¶®¡cM7¯Új¥'[ÐgþÕ€í&Åöã‘„GÇÆÎð}¥e]³}÷Iû× .FCŸ    òñññõõUÝ[±b”¥Œ±¾ß~ðzꂹ»X\®z66^eð`oÕß‘%$$H %£FLØz`E ’Ÿ‹! fx>Ÿ;];9Hµ„/;†Ît½~nÊ_l{ …(‡kô••žñ€”§Ô¢gMOÛŽ(>ZPDî±ç³B#äèÑ#(®;h@Obˡșw]IyÚ€®í†] ìeWdß*¼Ù°!M5¥ÆÔí‹›Ó¿Ÿ/÷Nè¶£¹>$© é²NÇwu¤izjLÀéÍÞ/í|ØÆ€Ë3鰩冡낯ϫ_í* ÙߎÕí4¶î´}Á×;å~ Þsxkп¿¦k¡lÊKE‹-Z´H=ýï…ÜìO¸^óñ¹r N¯Zò˜£èàPŒ¿l© ¸I Ó”Xqþü”o¥e«m÷ìE„4÷5¢ÛœîU \èä}´ºáÅÆgªX’‘o«í1”•Ru¬¶½—îZÄ×[÷yN'nÙ{@EàóÖ>‹$tš<))é[@¢q+4!úå±Ë’Az¦½[þÊdÂ}gÿ6ÏVž#ë?9iÍÁ4VÄ1ìxöìR»äÂO“ÎÅí}å¢LÁØ–..t/ïÖ²U§çµjî8ÕfTU¨;madÃñÓž:pÿž»sÇû€ÕÔ˘xú] °o7ø¥Ï÷ú:¾ ÿ„PÕ‰¾<ù«É².ÍèÍsgNÙ¹Ô®©Å¢74ÿ,=š0pƒyg9aOe£¯iõxĸóžÝ\zv0¾yóFÊ“kR߀Cîf ÉðŠç¯´=†²RrŒUJ’1—–{Χ7ë×k$‹ë4pŸ=a,’G6•ŠÅbÎäÉSfœ;4nò”f’£§àáƒ{÷—]¬ÔnÚù3§rr2³²P{éë¡óo\_Ù–>6'æä–£ŠŠ²?I³¿ùø,PVm?`Ê{]úwÂ#_™ÑÀ8!´T%SŠú{ç×DÒÆñgÓzéÅÞ;Š=+нbÁ^NO=+–×Þ»b÷ÎÞ±‹]Ä^Q”&½×„$»Ùöþ‘Aˆ*à~?~îvgž)»<;™ýÍì MJPж´`«Bø-úKׄ&noe Ùï÷n8ã=™{Ñ6¨A“ù+Þe68à§±rß`Ç=¶ðJÂÍÁ®ß‘aÓXI,aÌÂëÃÜïÑÈL²hÞßM:w묡±ª“àÝÆ­¿ƒ!¼_Ûk ŽaÁÓo:qâX¥Á›ôûg˜Ò^Ûñ€&Š?#¤F`•ó=†ù¯+År¼öÈX«„DÕPZZê_ÿ[©<6²sHÜÔc–˜§LEÊ#oË,¶Ùg½z+²õ}râpr¶5²>À LLÍ­ªOß¶kùŸ³>/ëÚP y9÷ƒTÿß̺ЬuÇÂr?m[r¿ËÔ1uT•‰ÚÿÙÚs†ºn<‹T¤…‡‡‰e¥Å\?¶ «ÑsSWWõêçín9c_Œ ƒé!OÍ]åY©„EM0IHNÕmj¦AØúmø/d@ц588¸ô¬:uêUNcÍÇ­þž±²u…B¡$\¡(Ô:„m` \"Nˆ!ô )gqù|>ͽ5gN¸ÒR•eîÇWQ’ã% ˆÊ@á¨mª˜ï1”HùÌcÅrn¯ZuË~õ"ÑÙ£IÞÇÇ‘&›Ù»¯Ú¦ùX‹c÷ЬG³2¤š·¶˜3uŸXœ_,«ó—CÌ ^ЀoÔªOŸ?´K¼wtU¸ÆiXªÌdˆ©¦š´técŠÈOøÏvl?î+náSdÚÌT¶7 #8ô8ÝCÇ ­ PŠtp‘Pª 9w#ÄÅ,}}}¡T¢££Ë·n^<Å »×*Î¥ôD†Æ+¼[Ï‘r TƒŸlžÅ³Ð›`Ù¬µäèŽõª¤lD 4ë{üø,eгéž9k;–sËßÿy‘ì4И¦QÅ|á;еaš÷ß³§ʃCŽOÞ³»Õ‹9Ö»/ßÓ×Â4̾}%rhL_ŒïvÜ‘…7iÒÛÞÞVm“”à{çÝL$)‹‹· #Šl±‹’"Û"꡾õ¤ÀÀ4óìÒԱݯL=whBCe¬ÈND¢1:^]Ň#¬ _äE&f&`¤Aõâ#aaaP*¦¦¦¥TFî>}¥>žÐ´VÍÀG3íô³ÃÇþ1Éý影ŌÍÜüŒÙäquH,aÂüCóEÙõ5Ä%æXØ^½^£ú8qøÈ„ÅVi¬}—-«Û©ß‘þÍWÉÓTÜÓŠ€hfÈA¿pv¡uýi#¦'úù´ÍKϵ¬îÈg];¹¿í€qz¿~îüÎõ­•ä_ßÿ,Ó”º„«™sj¤˜ÅqS‡ ‘¾I½Ê¥$–ÂÛâaýç¢Ð_¥n'^Ÿ›Š³ŽörøZŠ'Ož¨W±ªY³¦»»»flåº3º¯ùzª×ÆÝÜ€ à±ÕNBSèš=ç§O"b!‚jýëÒ nÊh“}/êΘAå%òøyÎÕI“>(3Éû”a4\¥±j;ž¦œª d ¬j¾ÇP¥k¬ºNc6«Ó qãÆáÓ=GuhܸqM+°ZíÆׯc¦iV¿S?Yü™MŸøkµ›éÝ3Iëk–b¼ß9uÿÉx¸6vè’Gi¬g۷΂° jÁÇQ½¦§ã”*g_§äëE„-‹ñâù‹Ïî_Û¶xÜŒ)Þ þVÇ>¾“â6¦Žò8íñ’ûßÈ­Ü=ˆî{×§nóZðÏÇ„ÔÇ—x8Üdü¡Ö†_knÙ²¥££#¸¹¹3F½êUžÐJÊ¿,˜Ø~ÉríÙ|¤üó…õ-›9KöôúæÐ´/Û‡x^€÷¾xhƯ¹Ð‰»(·Þ¸í«¨[Ûñʤêù÷¢«ÆJ*ÒŽ®š|Þ¸hB…Ný)“g— SÕTjYʃQ}u^y½Oo§V®CÍxr OíÙ³›:IZ:¤àXš4n_äÌÛ} ^ëm?¶£æ6éå¿BVõ\s:УíÐyÁ}À®ûxéòÅiø(å•ÀÊÞJt{þüÛ‚ð„Õ\ë­;vϧ¥£ª¶XüTlsG•¶K)$99ÙUD´­tèÛ÷ ¹›7æ¯m·MáU«Õiô–7ô+ÅA6mÚp¹Ü‘#GÊåò””exÕœèJ¡/o_»l=¿Ïú#½Un€°¹òì +7,úËÃ-<ÃÖ"¢„è;ósŠ¢As÷¶®èÜÅ«žƒqÚ«‹K§´_~ØÍÕÙâÏñ£†N[!Û¶cjg(ÉñœìMŠÎ7³sv0WWIßcøVtÕXQ¹8–êxæÐ(Eqó?¦MâšFŸ>ét8J°´V¦:ÿ÷ËÑ»WxY£(jT·*ÿ$ÙlݺCÛß¾´B¥±†ìµºËÇŒ¢¨Yçšì{÷Q´­y;ÿVϤäËL8úkþ]¸ô¼D†¢,x.hs.Eíéá5fî Ò+Zó/gf Ý—µàSÊ÷UAA%\Z¥Ã¬Ñ˜À»c(…œÅÓ©qäp8íÚµ#"!!¦‹<Û•ëV”©±>ßÔÆ=à sùvm¤ŽâYNíßaó‘ý8Å20uþsÙLEÛhÖÊ} ê¹ XªÞ@Ƨƒ]&­üç\'CEùŽí™0tóÃA-›ð´ï¤VéN£wž­ ¬ª¾ÇPŒÒ5V$)) ¢¢¢ìì=ºïëë§iM)ä _ Û·Ï4)EØz:ׯ(„¯óGÕhö½î^Û†œn[»´)ñîöi3ÞÿΕ–_MÖ&..¦ ,™jaQÆp–©©éçÏŸ]~N•þ#Ú>Y¢—­ ^Éßóé@ž‚2â}Õut<ø^ß«€TÇáǪù©}211ÎÍÍ t‘X<¡î"ü·´ªð ­*L=Ol|s3>?::¶³œºí<^Ù=ûÇQ55ÖÿЪ@)­*èìxÀøC•ìsf«v3F”ecR×oòϨKåþýû¥øøøüœšT%tq<øí}A ³çUUCÇv³rý•™=¯*ÌžWºRæÎ‹•w`­\efÏ«ŸOÕx~ÌžW:QYs~ÌãðaÖ9g```(g•¡Àh¬ Fce¨d0+CÅç{Ö `````Цae```(g•¡Àh¬ Fce¨d0+CŇ™ÇZ/þê*üTúôîó««ÀPqù݇ï ô'ˆiXU4nÔ  ,çZ³fÍ2Ítü:‹á·¥j<?Ž2?Kc4Öª†z§€¯‘œœ •í¯Ìh¬  f­€ß e»Y&•ë¯Ìh¬  f­€ß‹ª¹Ü*C¥‚™ÇZÕj@ĸqã‚åW×ñGA“bY¸ ‰%<•|Í8ýñÕ1®‚åÞ=r6úÖá·¡lõÓΙ+BSÕ§|Ã6vMž9fDº‚TÚ´[º~| Ø8qÔë|pø6¾NŠÃѹ%–ÚwÓ>oSUGZžvï=ݲ…uáÓŽWc'ibÈ[aÓÖfÌ«_F |R†I’~~~!!!~~~'Nœ`³‹,±_¹4J5Ök‹|¶)þº¶¶“ò4dÅè%Ƀƒw ×¶¤Èœ “þêpèÞø:…;楜ݲ»ã€ž¶ÚöÚ^Z ÆK7þ«ÆªˆÿˆwÜðÏÀrïtôH ||óúðƒgl€È‡/HTm¼þåý›þ»OÕ$ ôÈsË– %ade$`#@*’§ û߈Ë÷>EæY3wÏù‡ébÒ©VÃÖ]Ç-›Òh#|ဗ‚wXè¶ïV&áÖ¾i‹6ߋùuZô\°¹£‹Á׌ýýýCBB $$ÄßßõêÕš±•K£ÔEc½¹la°IPhW.’´ýÀ§mãgݶ¿v4‘zi܆ˆC[æ Ü'ûcJúãé¹ÖMª‘°çFzù•íÏÒÏ+ËL_°à¡ÒlѺM&xé°ó‡»uûµ:>wáÆK#ÊAcýrzÉ„{B È€úÊÀ™“Ç+=Hž- kÖ6¹½ÒÑg¾È†•{£a«yµjØ)£(27>»íÛÇ«ÔÆO—û&{ïlgÌ€Ç˯½d°ñPP+þ‡ç—Íž4H|èÔü¶B‹®›=7ŽZÿòÊüæßuªyÑ{›õý«ã_k®ꯗúxÿæ¹}[÷ ‹»mÇ/ÒU¿‚,^¼xñâÅÚáU’g‡ø­Y~á’J‘ùúØÌCÛ¨Õ·_XQ£úÍ·˜zJݪ…ÎðíC¹ íyajÛ'MvìܵŸ½ ¤)éÂ÷ë§šf$b©Ò(½´½¹í¢Eªû‰f_ž6÷Ââûì vm³¶ê¸Ùs3㥠JtjX«Ú|zT @s®5÷º¡ N;“¸÷…ª¥Þô¥æäÀn\ÀÃkȹZ–)fîʨ&-ŠqŸýW¨«à÷m»û÷F^½y'–M¨Ýocs·}î+¿ˆjÙæ¾ K¨_ƒ½›·;jÛÕ«å§Ú´ }uqÿͳÓ{øióåb vžYÑÙ{ÃÛ§›Ö%wy²·¢HH}ûdrŠÈMMM®¨ž²ÍT{)Ââvìø‡²DiòGhÞ¾CQ¡C2^Ê ¦lUAQŸvõ:¡ÚxÒÙ¹#Š¢®nºwVä&²Ú(”©(rbwŸÎoöÒ€…¢(¦`éqÞxy©4/ ¦&¨óO~¸7V—C¢( ¶vøë’áN\€cåaª(à·èg,]š¸½•5d¿ß»áDŒ÷üeî¿Ñv˜}Î}h!+<¥ÈL ¿j^UJceÕ¸rë_€ü?;®ÿcé%.Ž‘lçµ'Ú¶öMØ3±m^DÜìS»ÜÝgÎaצÛÑ•÷»O8¿ñЄWb¦xˆ£££ åPó ­PÔ ´¼TU:F†¢(K£ e¼ôwâ¿j¬<«ÖĽçFÕš$)Õƒ|èâe‡({¬aõyçS}ßã?IмÄ×RÄ0åöfï«ë¹|•A¬ßê‡7Vz)_¿öZ²§±Yä‚©ë¦rtt*–‚¤)‹(æ¥JH>ø hç”ñÒ߇r›Çuh—… öªìÐŒû•ÁÇ{83ãð6.¬;jÞýÀÙ·LîíeûùÊy£.½·ƒí{º è³çƒ##Þ@XªÌdˆ©:¡i¿Û·ïݰwþè­kkùÍXü×àBíÖ´™©lo8@Gpèq*º‡î¯jd¾>?|ЄpËî7^í5`Ÿàëë[zòèè*8£èæºÁóÎFTŠøIñâÏÌ‹×ë{àŸQ¦ÆlBöqÃù gžkÞ~>°…ôõÞ_Zuj©÷xþ¹Ø+u†{ùbmWÀ¾ûƒ–—–㥠J¾mÓ®ËÖ[·î(ÿmîb÷U³ns3žœ‘ňÿ›‘»×mb)ªßwø¨‘…s_bQRd[DÙ6™±r_èË{þ÷.ÑoÄÀ~}ú÷t#ÇqÞðö 4ïòäõÛ·^ÆÂI«g𵍗¥È¸ÖàñÉÇ›OÌ}ô®ÆÌ™³Õ™k{i)0^Ê D'•Â(Šb *éæ_^o z¬iI6­0EE“…«C ž HJÐ$–Я݂Æ¶Ò ´áü¿Þ<:M)ÔE˜sYéIb-þ2 l‹>“7ØI#ÆLEÇÞR†‰“å,®eåRËkKz ÿ=úôs·ZFÿ1«Êu'K×XYFÞÁ·z@êšÆQÅrÞÌèÿ7‡£?iÙúN6"YêŸ1'l„´:É‹™=÷ö=lIÓâ”Ó›ö8^Û:j¼™•8#ü l½žžæaOnûgÇ…O‚%»v}>¹©uËë}útîÜ¥}cW K¨åÒ¬“1ÿ*L?y_XuaÓˆ£¬^¡µLÑG#Â?<½žƒí6àAQ/-,…cêââÂ+:pÈx)ƒšoÐXÍÛœ÷àë ¿óù°qä苟Q‚Ýuµ™¦ÆŠ¢` ´J{Õn^C†í:åRD w_UÏ aÎ¥¨==Àdò²-“Ê p žœ™-t_Ö‚O)š¸¯ *¡ªU›àç¯Ê6*ŠÁÑ£GKŒª\·N—µ0IÓxê»í]n1­íѽû¨à]õÙ´ï8ìÉ•ãgNo8lÒ²¶- ö‡.FQ”¤iEYú–÷ÚÙxïá9†² 6²ú{ÚŒgŽ=Ù¢„–—° ûõ¥AŒ—þV”®±"IIIegçøèÑ}__ߘ˜8MkJ!W°­i=%¢É8"‘ê—Æe(K$d—bfßëîµýhÈéj¼¯š‘è—>mÆûß¹ÒÒðN´Ž‹‹©K¦ë¾ƒ€££ËO¨ÏGÛ'KôRZ!CY"!'*9ß­ZÙ=t…\ÆŠØ4)¡Ù¥ÌQ{iÛÚ®_³‰øp÷'xéO£j<?ŽÐÐPÍ'H퓉‰qnnn ‹Àâ u—ˆx"Qá •5ME`êybã››ñùK½~ÍæÅ¥EÝv¯þúøM´Ô@xJÓ¥UžPå«Û ô^ƒÚK££c¿f“óá㥠j~ýGÍVífŒñu—€É?«2UåŠV¥ üòŠá›Pzi)˜Ôõc¼”A ³çUUCÇv³rý•™=¯*ÌžWºRæÎ‹•w`­\efÏ«ŸOÕx~ÌžW:QYs~ÌãðaV;g```(g•¡Àh¬ Fce¨d0+CÅGSce¤†r†iXÊFce¨0+CŇÑX*ŒÆÊPñaæ±–ÀÅÀ‹¿º ?•>½ûüê*0T\~·Çá;(ý bV5¨Ëù辺ÕO¨ Cå¥j<?Ž2?Kc4ÖªFµjÕJ7HNN†ÊöWf4V†Š³VÀï…²Ý,“ÊõWf4V†Š³VÀïÅï»+C…A×y¬©&Ȉ²í€¦dÓ y|?ƒ ¾­j ß…P‚ ÆG„°(¿ºŽ”g'=•(J·¡Éüýþý¦lO>‘@ai8óü.覱Ò䔩~]Oîϸð°Ä\&&n¹Ÿ¦m³ùwK›µë¶ Ü}h‡ž3/_k®GM˜¼x>òλ™Fª$[þhz‘oiÀF°ìD«Ù×ö5Èûœ¯€tœ‚ð÷o³D ´®ßÀQOiÏ2°qrR5‘…ÛÉÉIyºb柆u”¶#‹ ŸpëŒü§÷÷‰ÇžWK¥íÿ€°¸æ6öŽŽNÍ»ØVõ,0þ_Ñ(õí†ó®£Þs΃ qÜ¢~ ^q܇­g("ëìÅ'»÷K¸y¦äÁ]:s.\jmz…&%^;ª3høÌåËW)Og °êÔ¥V{> ¾þY†ËŸ !ùÙ»pge¶á¦ ×ò¶À¥]»ög~ÓÆ?ëßu耉õ¿½ÿW.ÊÖXßl%'šc(ÆÆišŒñ$$ÅóSHB@sŒ¦qEŒGýøÐÌóÇCò®®66qlw“þË“vÔ´µµÎGͺÚÚÚ’J$?\› «Ë!Q”E‘riß½«··;åD¯Í>΀*HZU%~‹~ÆÒ5¡‰Û[Y@öû½NÄxÏ_æ^’t[AøåøËƼëq¿…!OÀc jowËûbœ€H |Úhî*ÏJ%þh‚ƒƒK7Pî6Xõ4VŸMà©çÏŸÓNžEP¾@„ƒÀ?3&\á!ùqI¼‰|###ex÷éóàܦÕ.f5Öãé …‡”G­Ù¦ÎЦ0à ª+OX¶ÖMÈšGF§h°xömrOçiWXÛÿá3³o?’¦¯KV´khŒÿW$þ“Æšz‡ËäÛžóTÑxÏ^Þ$ž&IºÝ³çA—¡;Wx¨bØ‚š¼×¬ìñåôt«¶CÙB‡é›Î½YÙóù’Ñ—Ë©N//%¸ú~–*3bªYM¢Pgô¡!'›N³ëéٻȖï¦ÍLe{Ã:€CSÑ=¾í^T"(<+2&SyÌÙ¹Øëé˜Ð××·tƒèèèÿT³ Mˆß¿§.'éb!}æ-éj"ø0öŽÁèc4£^ì\ßfï@ ‘2Gœ6:txaxz`ÐÍ0£ ’æ°PHžþý÷6D…gZ¸9qÙ<ë6ÔÏßp àbuÐömxúMÙ’Ÿ"‡†¿“ÿWvÊhXíºî8úE:4•ùæÕCørfؼÌÂ! KHKÝ´)ôå‘ëf½|7mÚˆ^÷]CZÜ JŸuíí³:°±¹Ú>%E¶ÅAáÌ;¶þ’ÇÄ™Wû-®É׌Ù‰H4æ»®´’‘Ÿ¼½Q£µÊãjí.Eßè¬c°°°Ò LMËx˜+/\Q­Õ«×j‡¸z¡Xˆ…£³«…(ߘ£û÷ÎÖ˜aš ÆÞp‚oxáÜ YÆÉ!ãNK[§¶ËÒ¥‹‹Üwj˜¥ˆoÜ90°3ÜôjòÏŸ{Ž÷pŠÈææµ “­©'*ò¸•äÿÅQHž‘4mè úYý}ü¿²S¦ÆÊe†Ó4Y ±*cY,6°„&0 #•+‰sìí2žïް6§~õ¬·»~ì2w¸ Ç:¬›¹°Ëpãz Í(EUê¾9—•ž$FQcå©‚¢ ´Z@ Ú˜ÑrèÜñ¾Çëj¬âd9‹kY¹ôÁïÃÐq±Dâ¯*×=üq+…cK×m¼°µÉ˜iÕxlØ<¸‡ý¢µ,ôPeö?uª~â¹½§c¿V·Ú£¦t3«’‚¦)V"š`/øß™ˆ#ƒŠl}ªíÿÅ4VH>„ ì‘–\eøïãÿŸr˜ÇÊEµÆ*(2oÜ8?§E#=ù|>A¸Îý| ¯ôï¶sôû€×ü±|l¿ÆæÀµlâÈE%Â4_À+x¹¯oȃijLª| É¤ÃýÎ7²U ©±¢‘¾I½Ê¥~/,Λ±øäÉõ*V5kÖtww׌­\÷PGV‰×Å(¦±&}úfÌÎÂX5øŽ.®NHø,ÿ³¡g°0`³L]¬ µ—¼¬›§®ÕÛµ¦„Õž.ÍЭByÂâñù\*öSXDbµ¾k{o·^1ü !Yý¿ÝŽ7á°´ý¿˜Æšý`â¢{¶W¹›«&*üNþ_Ñ)ïµX¼«W‚ ó2s‚|X„=nÞŸÇ×ôdY§%º¾jh4)]1h° ßêÖŸÖõšip~Ã=6õ}’>‡Ùõ‹¡ÊŠ»ðØšËm§ÇVöøNŠÛô:Êã´ÇK¦mùà·÷¨—1ãg%вeKEãââÜÜÜÆŒ“››«\Ÿ¥ Oh%ñÌ[·nj‡ç‘Å¿%}xìP4P³¹­z­>{·s÷3©ÓÛ”¬e£9×¶n}ªž*V4Ñ8MþøêCLLtTÔã 黕ƒ/ÀÝ6mÝa²—×Ò®ú Fnz|vªÅ¡ã{&ùO€’üŸ”GÞºu“&±´¤„˜O¡'/>2wyjkµãÿ•…okX±¼£G,HÈ£T°Yl“m=?¾~òî ·³k¸‡×ðSû&mŸöçsßÛK°©?Vûvoçý<àø¶F<»îã¥Ë§á£¬¸,XÙ;åiæ,²ê~ôïN_”)OI,þ@*¶¹£ª¥’œœlŒ*>.QåZ:¹ºX–i† H›6m¸\îÈ‘#åryJŠj´º Ot¥ɧNÔÏTiXMì&mÚÙݤ°=b±7ݸ•œƒã$žKPR<¾QÇqãZhç|má ͬ?m_¶;ϤV­Zæ®›V¯AÃ:Îê÷³g·ui?rØ{ §éÆl´ýßÚèݺuïÏÄÜÒºšëÚC z¶©­~maü¿¡ÓZj•+ª3uê¤b±ÒÔ}Ó7¨´ÑÆyíŽ×ïåã{k±·ˆM¿¹¾u†¤Å¬Ë³û‘J‚hæÞKü¿—["8ŠR ð\Ðæ\ŠÚÓÃjÌÜw\«ôê#¶]¡ ürf¶Ð}Y ¾JG3q_Tr…«6 ü/”±Ên§]»vA$$$Ðt‘'°rÝ4Ö `×ðêa±~åxíäÛæÏrbÊ—#ÿ½ M)uvOÍÇô¬jÏ!š±˜‚"јçϵš[€$aY¨¥BëÍ'[kÄRXa.ˆAë³'Ö/^¸b{O•½–ÿÍ,ž¿B£ŒÿW(J×X‘¤¤$ˆŽŽ¶µuxô辯¯oLL\±¤\F D\ d(%jÍF¦qŠˆ„ åÙ,¡iQ¤JYC ;×ÝkûÑÓmk»–~îöi3ÞÿΕ–†?d:t\\LX2=44Ô¢tSSÓÏŸ?;:º”nVAÐöɯyi¹@â‹Ë/Ö‚Ò&Ç8"a Cˆ„\F D¼š\¨8þ_Œªñ8ü8BCC5Ÿ µO&%Å»ºº‚ŽR[(bpD%¾D"\u8[¨=•§´©ç‰onÆçGGÇ–^‡œºí<þs¼ªjS…5Öÿ›Ë×DXü’=€#,c±Òaü¿ªòë?:¶j7c„f&uý&ÿðºTîß¿_ºÏÏ© ƒ.0þ_%aö¼ªjèØnV®¿2³çCEƒÙóJWÊÜy±R ã¬•ë¯Ììyõó©ÃÙóJ'*Ë`ÃO€yþ#Ìjä å £±2T•¡âÃh¬ • Fce¨ø”¦±>|øÔˆ¡ Q¤a-sd†2)¢±~ü¨ÓL†_£±2T4ÊÐXµ!åQ±y6®ÖºîÂÀð£a4V†ŠÆ7Ïc ß5mZœÿÝmªÍ­^-ìê+¯®lªmy~´Ï¿6Ÿ–²D".‹¦dR”§/âM tÍKgKØ9ƒ¡Bq1ð⯮ÂO¥Oï>囡N ëÁSq^' 7ï¥pLÅWV’ó%ºå‘öoWx­p]zˆkvøØžË}¯o‡åÞmÜa_ùÔšáGÒ¸Qƒ*°ºUhhhÍš5Ë4ÓñcÅo¢„y¬ÅÀòî]Î7 5Ï{üXµK]DŠBØãÇ å)ߤf]g}å1AÃå)Ã_ñز¤ø$Á´þç$“Û¿¿!MŠ6g¤1†rq$]¨V­ZéÊm5ÊžMc9´ËÀv†>ý9 àŸ‚0gPí_oå¾hÃs ‰ˆÈèûÎtÐH»w„ñµV…K«ÅÇǹV¯ÉþÞõ+”0+ƒ.(ÛÍ2)wú•…OØþ±×çw>rØ3æcœK]7eMJ÷Ÿº5`Poå>)Þ·o¯fZšÈ¼”+è}éh±÷ÿÅk60-+ÃçW­>\ÆZ·LÌ6V5¾hn°—OŸTœTæ\^·tWÇtýúŽf&S–¯]:£©¡¡‘ˆŸÇâÛ©ÿõ^´zýúL«Êð£‘DßyýEgsJV°sTvÄÇùƒjÅðój@ĸqã‚åG”[Dc}ñ¢pJ__ßס»gß‚u«ë/Ù¡@Q„š‹ðÕ/SÖ62€ŒðkBóþlCñÂìÎ>TßïONÒÀ=+ý{(Œ:5yÄ‹áSšñô NšÌ'^ :âëë«=útQìÉÿæ-!æÞ9hSbì—‡·^&¥eegfe¤ÆDD|ŽübßkÃñE@à„ÁÑ{‚ý ¿£ž)·÷?àöÔÎú;Ò~ò´{ïé–-¬Kk¤‰!o…M[›ýîÊ I’~~~!!!~~~'Nœ`³‹l´óÃ5VõÇW11qF–þФ Ì„§ŒÜÊrþÞÁA;Ⱥ‘hÞrr1m„Çðy,iêÅ-[Š,eŸ ÁìíÇ|åÅ  Ê`]Ö Àób>Å«¶b?þ!»æ|ÓÈÈu¬¾cmgCÕû•H’&%X6Nµ#OüÛxgàžÆnz\Õ«AØ^ª͹¶çpñfݬÑÀá틊„l;pgvŸ‘å$þ^ºXß«—-½®«GFÀÕõÎFÅ HEò´aÿqùž@ ÚN†¦d}[·Ñ›têèÈêj3Ú_8`Á¥àœ*¶”Õ¬A9Y¸E&„½ù5kÿ ñ÷÷_½zµfìÏÐX ·iC¸ýÛY¥<(Œrêœ;ë@;¸û µÎ&§¯•Á3jÒ¹suÍ»_”\ Cyòhþ€yyÍ™Ôi{ÖDe¾yj¶ùÞÑNv@È—©|:V†GnYÆg@»5£­ô@ž•!ÂÇÜÌhR–““­YP~â­=‡_ù¯f MæÄKÖ¶,{[rY0k溶Ýlyl¹87Ÿ,avãÓå¾ÉÞ;ÛnÒ•ñjÉG)Ÿ³m-=r¿ZnZtÝì¹qÔú—Wæ7/¯ºUðüw"£·Ÿ»ä"Põ=¤„ÝÕoä‹/^¼x±vøâÛº6ªÙUž³8 ßhé‡R± uµ·TÁæšÚØy3`U±L† ‡~µ¿ŽñÒêÒøTÁ1Gè¶zåJ 'àÐ&³ýû˜ „õzܵ#³)Lö„M¤çYzw „æý–.í§™Û?½¯|ì_|£ê´Pÿ46¸¹h¸ÐÌçèÞ‘ßq-Më}4‚}œv&qï‹úš7ýß‘„…}vÄŠ§9ªMþZã>9ú¯PWAÕYØ“ænÝëT$–&7-¸×zÖŠAú ŽÙµòHõµK:Gàô}ú‚.®@QŠ i Êe’üp5n6¬.‡DQÕP›Bº!J|¸cJC³ ‹nÛ׭КߢŸ±tMhâöVÖý~ï†1Þó—¹Tâ=_±¬§ãŽåÕšüŒy¬Åä>— ï˱=AY(˜òàž™/ïpô=¶mÛª´;óoS @Þ?~¨õ]½¼¤’#^<Œç6Ý„Uç—“á' ‹ÆÊç±òS&N<¢\œ*sàñÕIø<–YÓÁv¹ú—ŸÑØ)ˆïØÿ)cÅU]OÄã*Ôã Ÿø×òj7u³*¢x~¹0ùÖöÕÄÁ\ îâa‘U÷= ûÎ4…Þ½RæeÖmÛÁŠËš”P4m­/ðØañùÅ*µÿ³µç ÍÀ¨ëô§¹›ä,î1Ç爷=¿°Ùñv·œ±/FÐÁ ˆôÀÀ§æ®ò¬Ìs³_%sE\;¶ýĉã!±DÓÖÞ«6ÍsÓç3 .=ŸN:ÁϟǪ†gdbB6ê&Æk ¨,W–È÷oe¼Ò~H-<Ý~M÷œ¡ŠchïùrR€YrØ“'éq(!zù”-(tßtœjÍcÓ¤añA‹ÔûËß‘|Ù]30÷ó‰þ îÏ>÷ˆ[MÎÛ\ÚET2ŠÈ™?n™õ_vã‘—±pÙ6×ÜVë9Â%¯þÚ™¼c^ϰT™É"hÅÒ#Ñ-· “Úóêò,¸ÄÇYoÚÌT¶7 #8ô8ݣ̺Tt2C3%I›ïJfm>3??fÏ¢1­~Œ‰8^l6g™ƒäÑÑÑ?¢ze7¬Öû\䈄lW²»þâO$bÄT†_E’D ¡Z!l¾ÈÐÐ BCC¡úQ¤žHðåú\*OÂb…ÇržšzX„poÞmÒ«°_ÁÓ·ô^rnduÈÍ[ÉÕWÛ)Žgóôi‘ÁÛÒÁrCyú-´‚É;ã¾Ô] ±()²-ìžd‡­x#%æf†^¼È€ÖŽGÖ€zôDv"ѽŸÆÿ»øxªQCÕ0ÝÆs÷‚¬jM|“q¬i‘ñÃ2¿¼úóX‹¨a!8ª9[µX,ó7Cy££Æ*Žó÷ô,A„BÓÅÕ54Vý“æõÏl#3CþƵóQEs®Kùõ„„B–Ÿ‰°õ4‹@³Ÿï=N¯ÿºëÞÒÞC{HòŽ/ê¯Z–ˆeæ1·Oa}0ñƒ3¨À†ÿE¶{¾þ‚µ§JäUk¬öŽ9Cv¿µ Š¢æ\Vz’E•ö ¯èÙ6½¤JoVSöñô¡¸yC ¾&'ËY\˪´À‚ÀÒ¹¡FÊæÛy "g@Óñ 4V†_ŽŽ«¡ãª‡7¾"hh¬á{È€)Á9w2–Ë€Æ=ÓX·Ÿ/0*Š-pVÛçFÞ™0d²ôÅAKú².ÿ#ï4b†ŸØ0Z»S ‡',±êºÚÍèû/&I+n'OÐBY‚ \úÌŠák®!ç.1q ¾!ÿY ¦4À¥¯×…gû^ ž_£°×<¯UÝÃßÞæ©æ,h`FbñR±Ím•Q”B’““Q4Tfº,¿zÂ`Æ–ÕÓ牤 ¬š´éÿÅÀ L IDATèí*홿šê¡C‡&M𠝝ÿ£«§“ÆÊP.<|xïWWá§Ò¶­gye¥£Æ*4¸hQ Ë3?œ:ìQÆJµÈÌιNSkÛUv–&z€f]ó%>qd´äúÊC§ÂÀ¤ÕÒq.(Нþ©ëGK,ήۂ¥EÇô2ÙËÛ”Ãú/OˤgàÉž ±G×gº€+’©ÀsAC˜s)jO‡yG/”PCÄ)ðÒeø—3³…îËZð)¥‰ûª  (ñ¢*=ælé1(…áéé²°“ÁÑ£GKŒb4ÖÊMçÎ]€¦iš¦ÕÿWÿêÚýWèèG–£#颱ºyyÜ•+–Ð[¬sý‰OÈWvgýŠ %°õ¹{ÃXVž NÔí7ø;S~ƒv­û×k~v¯Ómk—6a'âÃÝ9[s6Þé+TâÏJÅ+‡½ø~Ù]á!Uj~mÃúbÕnƈ²lLêúMþu© (W´*å—W壱þTPT^Ð’‚ºÒüoÅ!$ä!xx´ý–D4@S åêHºh¬ ÚèØnþ(AFcý ðù¾ªªE¥(ªböX§L™öñÑ4M³X4”«#颱2”/¡¡¡¿º 倎;°–—ÆŠ £±200”Œ££Ë¯®BåFWÅž&rr¤º}ÕúÝÐ$†a®Ûös¡ÊÊÓõ&Ð@eVòiÞ U]5ÖÌW×ï‰=†u¶Æp ÒC·‚Go+m˨›—Âq„N‡ÃB‚`s8M‚‰w’e»„ÇçnGäVkêÝ¥þW¿KË|r;¶†G3Ó2úíùé)„™µqÁláo^VoØ„‡ŸëFHã3¡šµ^iÝv\’”α²-§u1 ÓXÕc>@áò+ÓFøÔ!ä²2s£ì꣔qýêH¥eñM¿¦ˆæÈ£±2üV|Ï<ÖÏâš#8X¡ é(pŠظÙ$f`Å,IIžóè¿{› ¯n¿j9dBsóüä£;¯¹Ïë¦F¬ÜôÈÕÅ6)9«x²ßß‹¦ûMzgÿéX'ßZ%OœÁSSó=ªUÓC³%lV¡æÃƒ[y}Çw‚‚øôîm“.ÝØ±æÇ&™çêãúCÆ›p9¡lãðó‡s›øx×/\CAÈ…ÐáÃ;³Ê£/ÍçóK×XIZnիdž$Ë*‘¢I¨^½ú·+¡ºÂá_à², /ŒÑX~+¾y+‰ÆF*DóìàÓ›X1A@¶œ È´¸xqz®8Bs ã‰rŸÎI¥rq¶„zÏ À°l©8kï†ÉiZŸÇ+^(. <ÿ°V׉-œíͼ“Ž]<"íܯ©“YQ+•æg$G»ï© ÇÌ̘ÈIÇUí¯¡‘‘\"ÖlŒ“Cókôhîb!NR-,&K}‰sد^[·éšš§ê©qD®Ÿ¾—õ¯/*³¥ûhŠLÍ’«Ç®(B±ñ™)YrõÏ€±©@PpÉ4E\ IQ Ûþ¹/—«ºoÚØñu¸9 ?ÖœÏøDÜÝ'ÏÕËffÔ‡;A€¾}û.LAdçäØwë[ÛÚÚ€"X\î£ý;Ø}G4q9”§a¥¦¦Ñ4¨YÚçkWïY{ ÒÎI’žÌ²¬7h€^ÐùÓÉn-<=°Y ?=rò%Á =v–œè••”œ”‡smìjÕv.që-š (JN¤%%HS’1‚egg žy3\â3»'?SVÐ^F>øbÓÑWz{ÿ#ÂÇ _­š·Î8|†ã1–Ì+•™Ä%7§ÚY©>^¦)>Ä $š¤TIgŸzDÁ~”4-Æ&i¥L»÷ÌûþÝa˜€ 8þÄÁÙ%3îK¹ÿ¼|ù",ìý×bëÕ«ß´i³r.’¡2S¶ÆJYW_d€±1‹kÑÙ«‡6³1WFÑ”"ôå§ÆMë Y!MÏÍ¿|ù’Í.£)Y””U/ìÅ}™LsÑöWx~äûÏÃR„æ5l9·ƒ.Šåª–˾~#®8òÄ¿Ÿj7hX¿Ž+Ÿ[«×÷æMn¯^”ÔµííËÇÞå鹺¸ÚâîžJÈéÝ®Ž)àÒ° WÞ8ã8½uU‡Íæp9l¶Œ¢o^ bS[`âèh#•ÊóQÂúÌù ŸÅ(E©Hz’ƒ nîH|ݼ׸ƒ^F¡Ú`Yƒ‡ÝÊâ·%ó1šF3ß>ÏumÙ¦Ú·¯µ¡­±â δQ$’| °¬ÕûߎЊJ”IVïºcáà Œþ˜KP@S8;˜þIár¨feôùs(ß¾…ŠÀ‰òkX•kƒ hšþð!LÛ Y³fLOÏHIIa4V†ß™oÓX£ƒï`6ŸÃà°©ð{ož6‰“@È>Þºú¨^×|©Œ¢¡È¸s—®á¯Ÿ×óì¤/{}÷I&‰IŽ©‘H¨àp•ÅToÿ‡‹€™)Çž5¨Þ|äô!¹Ÿžåb(pE"•¢Çbë·îÒ½~컇>z6çJåB’’˜˜¡ #ÎiàÑóÏÍõ\*—ׯk½mÏÏ6“x2œÏk8`PK{ÓÇÛVg?ÔBHÑ4MQk-9y²‰“MS8IÒ)ïsô]º"¤„âñ•W›ñö9ϨUc#^Œ‡›øìzðdAFá£[ÃVt÷všuÃ49©À’¢¢’«÷`¢È¿q‰ m¡8 4MÆÅ%‰K•–‰ñ ÊŽ'­º!Ð@«öŽ'(œTCAsÆæpËqF¬ZcmÚ´)Ž+"""4cëÖ­;`À€¼¼¼ŒŒÌKFceøMù•D¿Üù‚ôð±~@GàZwó aàä4`¹1½F6f±ù£Ò4õêÙÓjžhâû·QnÃútoÔœ# R/Oý“ÐÒÓR*–S4pÌú ïZω扜k¸rŠjƒ4sŒì»ªcb$Ê–ÊIš’ç'ÇadÝa®k–ŸŸ§ìkÛÔP¯(OV \!ŸÎÎÊ–”‚¤ò•+IECjrªº+—‘ëµ6"Õ#ï4ù(,ÇΧ ç"&­,Øï/~Fº™^`/´ o“øÆæ —ºöýóo+{KAfœäg~‡L‘Øë ÐôÕ{á™ÊVöê½™J›ÛÂ%Y™ÎÕÍË{3\aµlé®P(bcc•!®®®Ã† “J¥IIeì~ÁÀð»QFÃÊæ;¶ëæP×0ø&¡ÚJ¨q5½‡·Szu×OGÉüÈ<=»Ž™_l„^d`ÈF—|¸/ZFæÉÉÆ"=T¦ìèñôYI‰‰G,YDؾ#F`2IªLžuýÔœ{{ýü´ä YáÖF€¥ yª (’u~IÑ1<}”¢YE[í<‚â™ñI´@É|”†S]¨¸§òò0ÒÖ÷ñÚ=ó‰)U)\.Md°¸<9àùi1ù¥ß¹o€¦ñÎ>—H¤@Ó;÷D.ÉW^…ºOŒ ˆH Ð×t°0ÓÓã!´±BšŽ ð<–háh –æÆúú|bleeÙ™å¾à&‹Åöðh+—ËÓÒÒlllF¥P(’*Þ'c ¿˜²5VGs$=¥ihŠ¢¢†²G/ù†íÑ\4:^jæcIHs5“Ð@Ó@ã ŠÍ·«[Ï×hX#2’9,À1Õ”J¥ƒæø×(ºÚ‰~Y±ö˜½}µÈÈ HɃ‹x û¸½¿ˆ"ËЂ¥ÑiJ%':ói±EUí AE©ÀR£Ã¢³rL›™°YÙ(ªîòYH~>AðåÊ$ŸîFq íâÃÞa(F€¾ûü«ƒ ªj>¥y8‚ ÿQÚ+Ycv›æ®2™H…øäõ˜VÍ\ÕóXO½Š$H ©áhhnfX™(üf¢‹g£¬pûMMê5!¸˜À‰òhXµç±¶k×þÍ›×C† €˜˜/$IjD2+ÃïË7ÏcÍ'a+wZg[U'd¤¼Þ<^ÞG)1¦ºž#×L‚‚Âá±޾‘H"-|ð8 \¾@À.ÒLjDù™)šz%‰‰h.—£ÌM:{MèÙôâÛ (Isù|G)@RŸîž“FíL¹®@ ê€+U6ß´‹wGKK>W!ËcóêÆÛšÏ K‘sì’ ðÔgÙhÓ©£ûÙðÔ-þÅ +^ËÛN$&hÈËS°õlJ¼9ß„¶ÆÊa´h _ÝÑ,6.H€‹£EF|œ²*[:ÚóX•ÆJåää*³’¦fÞÉæŒ©c‹HãûèÕÎÂLse8‡SëàiÏcåp¸íÚy" ÚÅ0k(ª)…àáõ[Õ²âPÙËTkIür!÷˧×ú®,¾u’2Ciü§õX9ÂuQ$KHæ¾½†®vFj›!,.KñéÁÃhœ(lCeÀuøJ¶4¥ZI U´·%°lÞÏÞˆ-Ë’Ó@Òи,%)þãëÐxÌ²ÏØÞ.k ¦"NäýdkÈKOÏW`$ÂpU­€E}£¼°X–GuÈyÿ¸6>ö’¤„¬‚™µš˜½ 9Çö ™($Æå›zÚÒ¤¤‰n>Ïhؽ· ÿ›ïžö‚ÀâÕq楦¦ççK€ÄU1©Tª¼ s^~JrÑQ2:16ëq¸¤m·¦."ü³•Y—Z¹×ïÄ׫c^Ï^ôcžÄ"_RL‘/ª0ÎÜÙÆÝ׆¯õø~xQüë³Znmlù ÏŠþ3 nÓ‚¬¯þ.¾€FÕñ·÷–>3Ù5³)¯¨!š—EY×3ù6ß»þï#¾·{\Ùd5 Þ±mêþY3E`ÕР¸_zò¬”ž¥v*M¾áÏ“ò$Àƒ K9_bX<׫WóÄ(4já.(ð•¸ðBI ÍLØdQ••ù)+“gëd¢ÑÓ¹uì_®Õ4¤éâ/z$–—ŒP@#€$>¿’&ªY˳oÇ6¦<-9WÓØ®SÛ÷ׯ­|ƒò¹@(†S4mé1t`CSe)n!÷d‚ºŠq”]³>lÓüšË¨F;ã°Ûrù 'òÞæ“}™ây@S SZYéI²¥ßË—/-ÓfÑ¢²mÔ<þ÷–ȧC#Ãâ ‡Ì}÷<¼KhX ‚D¥YçîeòrEÅ_®¾2éëi¬Ô (\¼u˳F=»—Òª€)‡•AÐÚtlzfù—åîHÒÍŸt›ç£û%ez·f°‡ò´uW›9§Ð…]lI¾cã£õ‹Úkükyîæžû 3jkæÆâ–Š¡:­€á$M“lO`ÈS·žÖµÜ«ñ|D°ø``h ËÊ$i NKŠÊež–Rr©öö®´U®4lßÁ†*ò*¥Hýçè íʸµð°rÈlÔ¢I¯aVŽÖ"R,ΈÌoßxö]û³±Ô#F._( „"#îK–ò\[wKêìG²mÞ­µs5ivª¼HYú}ú t±å'gF„sªy6Öç&%KQ’æX¶8ÜÆQŸ—‘¡di_Öjƒ¢%¬ T¸v£—’‘ɩߤ–{#':?ös¸U¿.àžëÑ2E2ÏÜÊXœ˜šóMû8þ ßDh^ü"Õã ‹ÅBDû¿‚\¿~-""ÜÁÁùkᲜ$ÜÐɈ @ïÛö¸S_›õm›ç^lÊŠA]a楴ÔfDRš$!9Gbà< …êǬ…‡›"Ÿ{ñ¡¼Gûâ”ô[áÖ=Ú;Ðâ̤=»dÖi6£!_]ùÏóˆbUŒ¦ß‡~2Ög[4u6f'ß Ém×ÔFõáü­ô†­j±pÅeÙo'®(ž¼çõéoRøšs#”ÖöAÊS6ß°_ïê6v|˜TóÍÿ.$­îi®6Ö,Bš›Ÿ–%-~«y–“j¾.–оCcå;{ªemiåØ<-úú-)P4 =Þ¹†&—>M]ž›‹P4ŒöïVÃ%7% -ò¶k4ejmíÊ8Ô®÷öÎ: Ší‹ãgfkè”PJ±PÀ@ DA ìõ‰Ý b‹b÷3±ž`'bc!vc!HI/³13¿?–eÙ]@ù êýüñÞÌsï=»Îî|çÞ{ˆ¼l!›G°*;%1€Ã#iE¢ŒŒ, g±Y8-&üš¡iºxÛÙÆžnÇÕòó^·n“ ?ýÆ ½õDà1¶-S!–ö$Îüú€ÃUر ¸\ŽüpµhI ‹¥9¨‹±,«ô`Qßʤ§ƒ…™ý=5þkv>Àb?‘Ñ9€áõ4IZHÊ–ÿ jGn¸Z%+Žc8ŽýÇ0\Uˬ[ñ) (*™V=©kçÚjý܈Å×ÕÖù9kªŽLïÞ}›–›’‘—ü-+?åÛ‚ºµL´ÍLtj몕xÍ â†!ä²ç<îã;Ïœµñh3½£Eîç˜è<ó.vÚðáí·/ù¿Í 音$÷V‹Ã’4N ¾o~?w¥)Aà@óX,®áƹò[­ :ÍâDÑ­I‹r¶ÜÌî×Ñš‹C oŽlhÞžàa`çÝò›T†wŸZ¼t\Œ]úë’«… @cÅT.0ÇpˆÒã†ì²Zgs8_?Ç—ÿaÃáÄRlÿéSBéB2/¿œ-CS"Z l²{§ŒŒÖ¤ñ-j[ªhÄÚS½¹)/-á{ùûUꢨ*X‡ü—/_ÑJÞ餉MWÑ•û=-÷ç•q¸BÆÒSy.T gá8æááׯGbæêÚnݺ­ú³ÐbþÚµÑ\ÿÑùºlÓ9frmæY‹ue¤Æ´ø,‘¶¦]Sv WG¬ ènÀ.×ãð—ä°é½Z˜riQ^ðö§–C ï·>ƒÛ–6~µëdˆ‘Ího¹½2à{ìJ»aCB&–a,#yÙG.ö¥+\Çö]mL$§üŒ'l­ºV¼B#ŽzÍŽâC æ4ÐPÜ…"äj!¤Hiù5Ö üÄ**±)³ÿKuµšë`˜:ÿøñ‹ ³æ¦ÜÄ/•3^&Œ*È%µ¢ÿ-ø¥L˜0~(°Vm–ÉðTrìæÖAZ^–OLÄÞˆsû»ša`¶ŠÇš»ù,LîáaUBEõè$=n¡Îº‘Kõ)» &È[÷ߊâSB~п×Å‚t2‹´ãOâ·)—¡!›.ä4l1Ö^º5„0!¥Ä@ÃXú¶ê9Ñ –ž|ºœ©ß¨I9¿ ¯¯ß:øQsýÒZÒ’¤Û‰5š–ÈÞºžÚ†‹™Ð@£B]ÈÖB”æ¯ÏyE~«¼™þe#‰$¿pš¦AF`Űj—óêñã'?PKF8®Êy¬×®]ëØ±£ô42ò0 ­¬îýs×Öžo- I0²³[N3›Î Gwr¯£xË–zìó>ê‚ω™_3RD[—vL¯k{ž° 9æsj×öõ ²éw©ê]Û[àlµÜïÉ!{o¿d[´ÊÏ*`ˆøI›Ä?%+GKÛDÇYjsêðÏ~$Iyó}¦X£•ÌïT@C—þ,4€X@’$ÅO}»äBæôÙt(DЧiÁî»yýçªÉÖ"Ì9äÇ4Iwr]i±Â¯Z¶BÂìÇŠ¨ØlvÑÀŽ%7\­nõ‡ŒÄ OªHceIÄÕ’…8MÓÒù£ru…yñ»£ó&ôª¥Y,™×nå¸V;sgDj÷Q­k-Ê»õ9%-79-;ñ[η,O{÷¬I sÓžöõ,LõÔÕÂÞF¿ ó;‹«goc–—ÏâèÚ50޾ù<`Ç[›Øp„ßg,»ÒaŸÖZl‚¨³zNx°ühx·Å͵€¦HNÁ‰$¬]^‰O‘*fÔ5¤ÎÓ<–DÉ•ÿØ<‚ 8„EÓà[ Ýâ§ÒÏ×nä4lí¬_b˜©mÂ¥E|I;r](ÓXåj!$üÔÊoÝQ‡Ç^õêÝX‹…Y©±_& ¡y±=%柹#×H¦¢À(Ìý¶hÕßvjò/¦ò¿ ¹º’ãÒ](C¶¢4½Æú i×εª]ø¥T‰Æ*ÑxoܸY¤öÒ×®]“侑èÚuL³vÝ™µUÁõ´iþÓL~#ùPÅc3ŠG’¤@@1ŒHR—ó¸q%QmÎŒVú”P"zf$e|JÍMNɉÉÅž¸4<”ªi^£±MÃ& ì[§Ÿþ²È]í|Ô+¯®u98˜;k¤ÝN"Ý Ç‰¤€Zð:ö›œ_|š‘h¬Ò’¯¯cw}aâáæ]›Uúƒv±8yG½–sÓšrµÆŠøc‰ˆˆøe}uìÜ4‰#¿€âä©Ï=ÆxKâ#Îâèhràý‹¤f^®Z×”[^ã0ÆËAIãÓžùZ=àZ˜‹ÂZÂü¸µk×x¢ÅR¹T„eçR:Úeÿ+ˆÅ¢2mdÀdß\!ñ;òS+.ä Å•¦¨âÁÒqÙ]WµäpJÌ=ÀXliMJ˜4iÈâaçoïùÒÁS¯'†s MÍ--­Zzéß®®Ä’Ñù÷›öê–ìßX¾àñx%4Vš ZÄ0õ&9Uxpmž> œ:Ë’ÇÎf³Ù%¶ÛÀ4ë=;{òÂ1z,ßMeßw÷qá=6øàööæšWØ¥6~çÄö,˜|kÅÙl`³9l%õÛ‡§·"/?r<Ü»:³ÌOª¬#å«ÎHcEüŽT`+Meöêí#[ÂÐy0²·Üððɳ,,ùÖp—ÑO´µ¸…¥,:‘1æf·8ÒÊXrz©OR­.º<¤'¥ó[l]݃¡…)_ã?Å>X>ªsH»!!ÿ.2á°Ôjx®w];bõñ;y IDATãðy-â³W30¬I“¦4ͤdßxLÖ··¯ œì s×Ý€O™¤pÕÂD56GÝfiàI ÏÒǘs"­`´‰‚ŒC¶OµŸqxÚ°×æ‹†õê5}ë¡A“WŸ0`ºææ¹¶%,W{¶ KãËÐàêX")‡†±Ï­ Ó çËòn#o9:·nRS-¾rÿÞˆù/o<¥:µQ<ó*ȰÕÔËñH‡øS)#°â¸Ö²eË¥§ü”Ý#f~;}zciKµ¢@«e6÷ñõaÊÜãj§èXÌ=éØ×ì¤WYD—öEg£&ýó ¯çà~~¶·÷ €æÓ|t7-Úšøc¦ßâF1ޤæç~ÊÍ=¾y3–§ÝºÝ»jlXÖ&êQdžg÷Žê)SýoJ+t`9ïðçÑÓ-Îyv?¡y›ÆxmÕØÝWk—””¨ÛzLðˆÔ O ¿øÐö ³. •Pg]Œš™¯‡~²ßÝš<´ F߀. J¤±Ó¶˜uÿ–? ƒçK«H`ݰaýž=»•]5jôÔ©Ó*Ð\UÀO‰Úx‘3o¸£laRäò9Û=¾¬8°>žÛuU³'F(NlUªýë/h''Su6ù ·Ÿªµlkˆé¿ ek¬õêßY¸­VO¶DŠdwF¨0ÉUð==G(k@é°p1´P é"évÈ`Hc6%ÉÏS:‰9n`¿9ÈÝcêü[i]µ¸Às죛¿2úëfgøþrçšÐ=æ-q’«=¥5Ö×"¬í²y—œßwDGñð)¦ æ°‰:-Z´H$ØÙöÍZhÅDÊJ–¦^½âûïJpëväXø•»`Úổݜü‡ƒfmܨÞÀ¯bbmma,ó{G…4ò›¿msã´Ç€ËIŸdz”ÏÈUÍæ-*gY1Svy·xçD¯2†€H @Ñ ]ýTb3a„ÔÔ”sçΕ6èÞ½û„ Ššªµ<»1T4ó˜P,z¸Ñw’`ïjqÁÛ•k@êíW¸¡A@€?° ³¹3G–¨BÓ´HXì!M¦¤eI¯âýú…w,%LžÔÛð‰‹Rc†.ØÁMcÌÁ½CëJ«ˆ°¬™}¦_oø;ë`< 4V ÃÊ¥±fåSdö¶m[dËZŒšä¢S˜ö‡Ç‘$ù!âNMêœa]«PÀÍŽ‹µ=÷p{]=68—'éâÃîw&®SU'17o?œa"þKº4Ñ€NFSw}$:X€85êÌ™ûMç¬pý}ä6y•6ÃO'$e|^=•O¦Ãfã,6›ÃÀÙ6› €ËJ–TŽ}µÿÜ”>½½·œZik® Àuš³æT×´àk³V}“×ÖM;pvØÙê¥4ÖäǦL2¶yI¯âêÔoÁ1ó}ÃæŽ[ºqª·ÜFõ,“sFR›eË–çååEFFÊ^íСòeËq\6¯Iåh¬nnî WµIˆŠºÿ©~}ùç7°èz$®k…ܯ¦4éìÕðÙ“˜üö]Ýħ¯?Aî݃s_å N†b¼LYãGý§ìŠ´x‡’27ëSô%·)†ÎgÁ’%‹€§ÝfÎÔ]³’zŽ›¹p‰N3_mî:6tð‚½C . YÁü7_¢ÀÐKûº3ËÏÛWsĸõ—»{«zD-8Î ^3~¼ßÇ%%-[¶ ^S2ªV" 6a(ÿú‹[³þ€Ír÷³š‘ˉ£©Æ 8KÇÍ­£ô’ ¸-=½pêD–˜þþ%OÈúöåKAÚ½“ d«Žý€£ny¾^Ü÷ßBãÒRœ^pÕañÁÿž[>çL²*Nÿ÷'ê`2ûGzù­éÂ}S\L¥%ÇÿÝbÊýÁÇ“Ï$¥^«ŒYVÂÜÃh[¾¨Q7S§È?Ö]µ%áõK,>Ÿ/x÷âUÑü`F, Å ˆ…B!V¬¨$] œx0翈ÃÖ þáZ·IRyòTdÛ¶móHZWÇ ú,>ÒZ̆ÇÄü÷—Î$a.½:ëz¶ã÷žÑ´¶-4ÒZØë¿^—†Øè&ßXÁ·»ÕÒHïwæZo–zåÄ>‚ 6mÚìããû¾^½ú›6mþ5ïô1 еI¢jÙ±5õéZ¨`–¶nã®@ˆø/]\ÚHËš°’ž.߸nösÜí;}[­'óo® ”~‡)÷V‰ ‡;hÿ…9Qk>ä†un|Ü0hÑ­IûºI/qu\úëñƒ§íhcª¨1Dõ¢óXÅïV'ämµÑ1 SE”],ŒJ5V¡ˆÎ¿V˜‘üI®€H’”ÕX 9xjbIêJlJk¬p5ÃXÃ8’òœ¤œcôûÎa,­±ÚO™Oå S(†³Ô5ÍügÔ‹/ó´Û î}æÔÞ쾃kÅï8´U¢En\r¡×¿-yŒB•³ISµv]·E_Y«÷ü½Ž—þµ?qèí›×¯ß¼y÷6.ûr>ªe§–]ÅZ,°5'Äbà5Ví÷÷0T÷ßqgœµý—‹i.ˆÅòË *ª±J!bûöíK–,!¢T •6U ÈJPb+¥íK1 -dáX¡ò/ˆëuíÓH$â¨7ŠˆøOÎy¹¿~h±H’ÌÏblŠ$E´ÄF ¤ºP~}ºõµQ?Ùº1Û–jXø5bS¦³;§ ðÿÝÁŒW—Ý[ÌÞüœtÐSæ<¢jùÁy¬·VÏÑq\êZ£øñDÌNÖPWƒ(ÒÔ¥+—ƒ‹s¿ÆÆŠ%åZÝ9ë!«±Úió|¨ÐX³ãnù-¸QË}…“aáÌy26—§gûûÎa”ÓXÉÌkÇžÆ0 d¥‘a|ll@lž™P™Æš$¤¬tegú«šµú²Yl0i9U0©×½Œ…·^&Ø4tü§ûpclð€î›ƒ½JWÔ±ì±cܱ¾Ãf;/ç¨j@ô«cc“;v*¯Q9+‡Ã)-¯Êí&W—¡²ž½ø$9NṘwoÒxÀÓ®×Ð }ÏutíÝ\›C ¾.[¶D®SçY‹zè?{ňèi勹úÁÀ%ò¸8†s%ÇïS †˜;ÃB?:mL„i“€Æ¼ÐÅ×Sö*ÎhÒÊ¿3Ž <•‡ˆª„ ˆìì îÇúõæ¿ÐìÍwJ$2'¿_áh45Pô¦R«N‡¾^s×QѦUÒÞ‡0³Xc¢ b¯\¹ÌP‚”Ä„o£ÃNß1t~dc_©ÁÝëÉu§4’§Ü]8iC̨‡á7lÖÌ ´x•UëQ{æÈY~­›ÔÓÑVg„dNVzRRR½&Ž\ Ž­|Údš¿d\ÆâYαÕÞtÂúÄ"oIÝÌwІæß8öï²Í¯=FŽL8·ÊÃçÁäI»¶´ªü¯ŠŠ)¡e6r¯UnÌH ¾=Zø®ïs®9s,`€ný1¬ë.[¶_?#½cl]w÷¹¬ÏÌ™øØÏ_Xš&CpÚP D9"®žÒ?BrRØ÷WËžå‹ç¤GŸ>@kK­ƒÁÛ¡W°ÔàÔÁþTʬ •qßÊÙÁ'§¼ÑQŸ€/Ç7žHæšë¿=yDËr¢ÂZF­&ÎiU|ú4ìÐ{ކ®&þ½À€Wø 7óú'i`Šh„1ÂØÜDçEpð çê™Ô´^2¿[[›âeZ‚ø=ßëÝ s¹ÓÂÜÌÌïú÷Zß^â%5‹¨çî^—a˜Øo{Ïå:uîly_Ÿå&,sv^)æó™žv,I¸l»0lÞîõ¡ÁSħ‹šÁ0LMK÷å«¶j‚X5Ë€¦Zb*^Ò‘ÇêumômJ ‹Åà Å{õìÖõË·g›´›µ÷¢§½!=yäÉmÁ«ÆõX¦W»M›¶íÚ{ywh$ë=ÏÀÌÂ\¿ –\P@ª·ðð³P+4 \ç7Ùg?ìèjõ§ï:7]Þ?Ùä城ÍTsZâÈ+”«ôœVHæGþF’+I*Ø+€S C‰E"ˆiŽIƒçÿ+|f§È¸~#J.€×ˆi^#¦Cåfe‰€­¦¡¥ÆÅ@LñÖ>ðpzw¿[‰¦½E"ÛÀV(‘¨ðUŒ˜b±ÙŒ´Sz¬~Árj×aLÐa·fV ‰´¼Ç-í>fæã×._¹ÞÃKTB µ³ñ¿1 •­±–ÇFŠì?§± …B(~2€’ßsu¡”Æ*EÌ0Œ€$I‘ˆÿ²]»Ö²—rSøÝ$IÐÇ›štX$éâe¾È„¥TcµÖäÞy•Nv2Qþó1ߟ ŸUOWÚò׿»—Fõ][¸½CÚËL®Žõot·ÿmTLc­ÛkC´7£ŽOí©Ùjò–V K×Ý·8!ÿøÓtƺŠìl Þï1ï{÷£íl¬U;ý>&röÆÌµ×{Äo³ 4\.Gvô$=®?$äÅf±pÐ6›V\…¥Qÿ̱¥¥Zbé•nßiã…Ç‚ક^ñoÐpýµãŧý6žèƒ+Þq…ÅÒwòèçäѯâŸO¶‘ Ì(QþœÆÊ–L´*=\UÑ~qu £y<9ƒ¸k»näᜠûÒ6­Q³õë%Ö’˜6&_GCR…$øŸJ¼ëH<xÇyëhlM¼zõÒâó¥«ÃðÚ«ö>'æ:Àçå Þt®­ Gæ_dÜ4»3‹å³ïHÔ¶G7SêMiòû¾`øã©°Æ*UUƒ±Ô5,aWkèÚg—ãóââ>«¶ÌŒÙÓeëáVÚ¿qTå3×çr±JxœK”+®‰ÿ?³T¨iÙ8X)]ËFUiyyR¼;®™I¬ M\:&èDÚæ wâ7úzw¿Õ£[ÛÝ!t´48l%’RÐØ‘ Û5rB-lÓ¨¾X»EíYÏ7lYûôˆÔZ¯K@Ђ¯ëÖ­Af<ý@d¥°°k"'Ÿåœ’ZöX\{Ï„¯3çÛÈé`ˆjNÕO66v™ªtgôÿ÷åÿŽÌ^é;ëßø¡ÀZ)éinß¾õ3ÕÍ\ÜeO1œ›ô\°ù‰Nf°æd—˜¨ë÷ŸIø›M DbŠÆq›ÃáñÔ}48”0þCŽCØÞ8“˜tòK®hÊâÃÆ\ˆkÔiàzøðHºjYxá¢B×sa³…s#BzX.:QÚ–ZÃK— Ö|>5[½u‹Îï=°ø{@9¯~)"‘H­–&ÜZ0õ¿Ô|Ia|ß¼È /yÛØ±…©¹ê6›×Oó®ó·¶/þu0T^[÷·Ȥ¾âhÖëXO )ã÷—ú$õØê¢Ëch½ e/ 2£§ÌÙc1ÐÔjx®w];bõãðy-ËÛ4¢”7°â,ÝÑ-ôçŽÚÜ7b®¤äèŒ}fW–Žªâü×#û/n±æ:|:üïÆ/9r^ëv *ÊÛþlÍ€IÏíwn_ÔHI2ŸÜ¬L±¢Í5tõ¹E·%JSé¨IÓfr±›$G=z!gF “¦ôñvþ<_:xêõDÀX\}#Ëú-ûŽr°ÐÀ‰üY}§WÛ¿ðI·úͺóYÃÜÖÃ{ÒîUÃz©Â¬œ-HˆŠŠ€¨¨¨€€€   JÿD§8ªþ@‚†Ê}÷âá—øø/_¾Äljÿò¹ÛåˆãGV8@±Ôš^ ß(We‚WiÛ ú õˆ%Ç^ÞM.²!ô:ùúF.Œ¥#9`k¼\;ë\†TWÀ¦à¼¢{Uݰ÷Ê@ÓŠ~~ó_O:öuç#;ÀpÂÍ­£ô-J›Üq²ã”½c “Á4Ÿ¶à£Óø¸iÑÖz•]i”­±Rä÷ôl!Ô=É|õí‡>q0Aö­Õoò×Y}ùòX„¡r?]›è;Soèöém H’´ X¯hYÜEý±kÝ&ùönçµðxh/ ùgIÜÎñ5_A†z ë<‹Z•v»Z-åò_ŠÉwòL®Ê½%þz­w$’$sS¿¦“m÷méÍP‚ŒÔ„kÇ6ò<ºýêù6ú®«Ú®ñ Š>5KI#çÓÁæ^~ͧízî•ÿöªo/ߎ ¹ª{ùÍÊÙ‚ôž ,].¡J4V@(MÎZ2ù+&M+W—ÿíè’U‘ñññññ_øäÝ‘“îXXYYZZZÖw`¿½o1„€PÆ144”ë‘abI’lÐihÛ¤¨ü‡õUH’$)ÒlžU“&MK;_׳g?!%9f(~xøÅî½ûêýÍfñ,¤–+ççˆiÕßÎÖ^¶d>$Ý i̦H’’³ ÒëZNýÛÆˆ$?à9öÑÍ_ýu³³‰êöª©˜ÆštwŰEO%Ǭ”¡½¢Œõ¸dê7¶v`¿’r³Ž[/l ŒxÖ¨EÍf†ÍíÓdÿhïß³[«ð#=¥ÀиÁ’7·;XéEú€˜ÿânrmk-8õ8†*5Öx<×c>¿F±Ÿ§´Û…0,›m›Ö•º@7l`-[EÌ=ãdâÎGÁ.޳¸µ å¶Î]ºlÞlÃÑÄŽS;Í üì45qVµû hX˜M½°d0@¾çÏ\­ÓyØÃ€Ô–ZÜrš•³YUU2•Ëå(dSaËÕÅôÌ´ìèÙ¿¶fÖ† ëœîÞœ!)Ïÿz¢Ý¿6Çûˆx,ÀðÒýâl!)?¸ðÌgIybߊKH4Ö¼ä­cÆ„IÊm&®Ÿßʈgì 9Q¢!†€ïßiÏ xózmÀÆøT‰ÀºtÁüs7Ñà{ÂR—¸ña÷;ש¥] ›¸"2cѹótK$©ïád4u×G¢ƒ•¯QN*¦±ÖtÛrË­ðøé‚N³AWƒ[^ïî°cdè‘Þµ€O3…D0ö†«Ñ,uvÒõ€•XÇ'„/]úUa›ãçhåßnï2¡ëä•Aã»u›8_öêíÀ)©~Q›Ë-íbø½´Ú«ê”(b¨Swãzµ¶–P¢ä¥Ë·@‹JÅ£E‹`bÀ"C6žro•Èp¸ƒ&G¡%ÆÒ°ÕàÜü˜\—þzüàÇi;Ú˜À÷çÛƒ}èµ ¨µvU¦&f¨¼e/Òí÷Œ’–;­1ãüçžpy uyÌ.õ3.O Õ…òªêã<ã|Rîr_Œé½hê¡ÛÆœ Ç5œO¶,¶Ÿÿ8›[8öT3è={¶“äXÃBòÊ” ÒŠ”ð[ÈöÐF.¦!‡cþé_ORHÒ c§»÷íÀˆß¥‹Ô `å‚ù­¼ûz¨½ ?ÓÐË[Vìzõ¯7H_ηÜ/'ú^h?÷̺r—ô[èów¾pD%Q®1מÑ]ž Qø¤@f†;¸­¹rÿªä}K-æ¿=%Ì}Ûm ݧffÅ–™1Bî:MSXÆÕi¾k¶ßÄiž1iW¶”š sîL9Ÿº1º§2g(A‰tþ;¹úÌÞI^›ê{̘>§[ËZ€³tºuëN‹3>}ÉRÖ”že}6¦‰c³ýIûÉÊ,3_‡H/pík!9íÚªÆÔ­o )ä}½qòä}»™K«6° r£2Etci ÆÒl§Ã{|+ d¢ 3ç‡ò´W¯^UíL§N~öóü( _Z©¬ y²q°ÿNŸR1H5j& ›ýJÎc %Ê|ñà£>‹gigg/k‰³ 'L˜$9þþúÊÜÉ»[ÿwÓ8·–ý;Œ\×H Â^÷²yô‰¹²qýíÁÑýþÕ{~w½TøfhþÎUó¿>S?é_<ë3I©×*ñTA &ôñ×h=s—¯]i·ÕÍÔ)òc…>)B5…+†a*æ±62ìXy•<ÒW@1 %$IRD-$ùjû&í:>†t¡b#Ê{3µ÷ÐØÊÉ”Í1u4¨¸‘„ˆˆÐ7®ƒ¹ˆ¤Lû‡ž3?ü¡vqŒhÛ¸FÞœÕe"Ú«mÕ,ƸªÉŠÂ"ÀØa×#ö,Ÿ7mP»ƒ=Æ/ò÷«­Á¶µµË_2Âïcÿžõ€¡ÉÃa† î-©õætXããQ³Í´$ Úód¾N_ i›Bšd]HbDù)Iqwî½¶qŸ¶ÒQ¯0;|]þÞ—$ÙŒ:î‰Qü½ýJha*X—œ…^Où>§œfål|||T;U¤± …Bi`-üOñk¬RB±äj“™¡{h\Ö’PÀÐ¥ëÒ…+#úÿéãǸ¸qã>D~'s‡ù$·õöw§óSvNœxFZeÈ¢UÍ49ýéáþ]!§n×u褟ƒˆ5>¦¾#7ôÓ=øk£í»Æ+¡ä÷ÛÖßzGH’ÀˆX|(س³ßœºç{>ÆrðÔÄ’”þU`öúõÌ49½q¸@ÑgÏI*À9FhûOB’$†a˜Çj;Ñ;«ÓÚ\ö` ÃX\‚ 88àÁÅÖû4òTIJðyœ÷P²Ë’ng¤ª“ÇpŽ\!aÙa‚eñéé}÷'69·×à)~þó_NÚùªgØÞíÐЩ39øH¯^a3g-´²åÕÕí@Èc1Œ ??FÀHŽ@H3²N&(M+]é)Ç1–¶™™Îâ5oÓyÜBg‡ºÅcdÝÚš” ¾Z-Wg«ÙÀ§‚/+”V=­rš±ÕôËÓ”cå•䦪•Ífƒ’áª2U ‹3@ÿJ^ñXbÑ·ƒÈÕJÑ’Iչ׌úíìlm63;qAïÁ½[º,ìëÕÁ\í¶ýû7—V±ÖÑ Óοîež‘ÏÈQÁIïXšHúm9#¬›·Óž÷uo<Ø";yVõxBïÉ݃§6/œ'€†+e IDATpx<‚ ‹®ÇÖÜê8½¿Ýí¡ôÀN›÷à£@úAböÞM_Ú]O§„´*…ŒÍåéÙV«ûùw„ ˆ¼¼ì ÌcÕ2oÍݼòEÆÐ’åI‘3c´¶Ò–œ²x–C'ïè8 íô³ *êMeY=yùe­°k[-”DUZœ±Â×—²ñ hj Ð̆ÞpO¤ŠŸàx:®'z-Ê<þxâÄÂç¯ã÷. d*špñô4Ùàj9ùùSØ‹ M€sËX/ÿ‹ájÚëqð—O2 Nál†ÎÈ,°n[£œf\M‹ò´Pí)œhU:ª–)¨™X“iG×íªii E ó332¾gf ÕNoTh!Îyôè¡\­¼¢wJ<ÝŽobž±0€°)íÍ»­Ðe ŸµF..íKT3õ8½Î;@ÔÕ%ÀÐü7£¢Ÿæ†Ní3°çÐy»·/i¤/™MLv÷Ij:ñÒê> =·è¶jåõ‹| ¾·°ó±JÚûfÚ@ö‡ÃW\·è:O#6úJl‰ZNnîZ, î^O®;¥‘–?FùÞkcœ9Îæ#SäŠ÷,Žì¼RVnÃ:hûN|¾:wÞ²X-çÝvÙ*y}D‹¾-ÔíTb½#׿¨~›€³ Ì‹>GÃÞ¥é͵k×0†Ê)<€f®nêÅßF‹w÷mt+—ÃÙ¯³yº ËeúËÀ¸Ú˜L^°úNhÿzqÎ7~¨»EyÍÊÙ‚ óæÍ;p pçããS=æ±ÊGUiy™ûah[¬›£uë僘¬\1¡¡®¡n¤_8läh: ñ©¹ÐßW®Ö®eµ‹nZ´8c¯¿ïægõÏ]î*À8ž.v¢ìo/^¿¾™Ìÿ°oj›àDS{'W÷¡lõ†Î^^3ÑÇÛ¹U—aãfÍmÎcìÿ—eÕ–‹AâÅÃ7³yºš‚|šáÈì*Ð+ø¸Y†ºÄW3¯ò—¦ˆFsð´»7M,­àUhð+y¶·uÓRcS‚ø=ßëÝj•ñí *By÷ pÚá„ó%%4ÖégÏ‹¹º¥í)† H’,"Bš¡E²Æ9ï¢]¸tíÚ•WIø€É+wø¸ópE½3Â;'v¬Û¸'ÍÔmÿÙUup1IŠe¯«˜ÇzwÇɳ!C0ŧvÜ÷œ^ø®¶Á ‹ÄÑäIJBºXn+Í­kÉu&Ô•\M¹·tÆ–7#¶ìí¤[ÅOR^;ƒíGx̯·~œgÖó+†hþOˆä•Ú¢Þ^8ÞçŒUm¦â’,Ò{Æßß?666::ÚÙÙÙßß¿:ÌcU½TDu]è4x\é÷n…öjæÌPPwØÌùůB†z„ñÜž 4b R1hêéb ; ïwTÔ¶íàmÚ¶qnªÃÁ‹ºÓž¼ñ´çÍÃ[OejQ"’qj¶,œN+zñü»>éì>¸WöU„F"÷×ùM`öÙ;ºZ˜õßx®¿²+&Iñ§c3Õœ–8òÈLj Q±y¬KçÍ’ÎLþþ,-Úµ`ÁÉoßòâO®_ôHSRÎâ¬\Q5yCÊ ¿usF{q:ÎceD™Y¹µ»ô *tžgx<`@ñºiœk\PÀ×ÔÕç`PÇÛ¿20›5Ú˜ƒ€¶©¥Uf …ª%ˆßŸ"XïQ› ¸À…‚ìì,šË«r‰JÓ¼OTd¶ï´­í6MàÖlØiä†ýk Ÿó222xü2ÍT\’EvkHHˆd¯MMM9³_¯±º»{¾ÿæZ«Dþ9tn,a*»\ͪÓÎ+JfIØ=~¬Ò¥mö¾;<ä ­»/: ¿bC¶ï÷˜÷½ûÑv6ª¦Ê½‰œ½1síõÞ’›ñ3TLcmîèDÒEÏSNÎ^E²68®X±0qÓšµyyyF­G@}ÙKÆ­—œi]¶»ÖCöDæé°”>ÈqÔmüýå …9Ñ£G˯ °k\38x¥\áì}G[iq ]Ï…ÍÎHéa öóžVÒÝçS³Õ[¹­Á5u]wŵìOñk0hê{&Ò—àܳmÖܼ_3Õ—¢¥¥uèСŸt»)ç>ÿ?XD…¡þ¿Fú®¡kŸ]ŽÏ‹‹û¬Â,3fO—­‡[UéLÁ?’²k×^Šõr¬¼ù# w ô¼Â/zUØ/0œÐQiÀâYa%WÈÕq9qÂ¥BõÞ²j·Çô$OUäßÇDN]“±æz9Æ UG9c¢ ³r¶€¨Î»LV–^ãQã…/ÿŸýX1¥V)WÔBV>º›óV™Iêë}îëCšpÿjAêOÝøh¬†¡œW`ÙqæH•¦Íý”.Ïúkìh¥ÉÊ+”ó ñWAD~~Êy…øAªpÅ*ñ[€ë/%::ºª]¨Þ½{WÕ. Õ”óê×al\½ký¿A+â¯âGs^!UÒXÕYµ:æA ˆßX¢’A+â7i¬ˆêÒX¿HcETh¬X™[ª!B%Ò@Š4V¨dÆúë¸xébU»ðKñô𬬦Ɗ¨þ(ÐX333‘Æúÿ¦YS{ggç²íª7ÑÑÑ 4(ÓìÝ»wh¯Ä_A|~.Ú+ñƒÔ¬YƲ2³ "6(°"* Š›„jÆŠ¨0h?V¢4•§±Ò‚¤DqMs¥yYàá½¹žƒÜŒªlGú´´4…åÎ64ÐûÅÎüÈæ¼ÊÍÍ•ä¼ÒÒÒ’3C+â¯Bƪj+#ÎÎÎ)ÈÏÏççef¤§¥¥¥}ûúéÓ§qï_½|'Ôn°ûâÉVº…k°n­(ïÑ?“w„ìÝ¥à-prjÙ¾ƒ›Ü´2†Ê‰zD¾}y^ΜŸrýíädª®ºÇü„ÛOÕZ¶5¬®¿mF˜™-ÖÓ-ãS0bÆVü§â’,E5***jÔ¨Q¡¡¡,–êÄäÄŽ4–­±ÒtÞ0÷Ž)5mmm=ý†¼Ë7ü¹tR»Žµ•I‰A_òõu«ÏÇË–ÜÍä­š?[ü“#tÜV,ì!9~¶fÀ¤çö;·/j¤£8YnV¦X&5¼ ]}iÆVJ”¦:éq“¦Íäb7%HŽzôBÎŒ&Méã?ìü x¾tðÔë‰MüölPWj7¿ßøOW.…âDþ¬¾ÓÏ^ÝRƒ]½&‰Ž?¹gç¾0:õC2³¤ÛýfÝŠù¬anëá=i÷ªax9.•& @’M *** (HiÄ_E94VÛwéšôŒ"?]¾xÛ»KG`¾ÿ,B‡ð¬Úvïž'5fß ¿\ïŸ>½JtÉ3“vQìZ·I¾½Ûy-<ÚËBþY·s|Í•.·ðرγÈa‘· €C GNÉÀ*&ßAÈ3¹*÷– ûêµÞ‘`H’ÌMýš&0º°p`O×kN:…c7~^ò—„’$1-×Um×øEŸšå  Ó*"+vº]ç׎œ,Ô?Æ+5Ëùt°¹—_ói»‡{忽êÛË·#èF®ê®ú’,Ò{&00000°t¹¤±"þ*h¬YYYÊ4Ö¬¸%}FG1âô¤T^­šZÀˆ¡úôé¹I_…F5 ØxëÝg–[ëQDZC€ü¤Ý Ö¼å?Å0µsçÎJ[ó \Õ¡H7HO)04n°äÀMÇ­ÁVúDѨVÌq7¹¶‹µœzC•±>žë1Ÿ_£ØO‚SÚíB–ͶMòy°è† ¬e«ˆù¯gœLÜùÈ 8ÀÅqãgXÍ›õÏŽûgfKFm—P˜ÌiVàg§©‰³¢­‰ê2³B·nPÚ×ul îO¾sXy`=4,̦^X2 Fßóg®Öé<ìa@jK-®ŠK²-Èj¬*@+⯂ ˆ‚‚¼òÎcÕµ^ Yq“ÝÆ´Œ¼>Œ$Ø4éyö¸Údžœ_Y»Dvêë‚='ÌÐ̾wý‘íîuC†)¾âç󎿼“.„Ù7Û»Lè:yeÐønÝ&Ηmávà”€T¿¨€Íå–v1ü^ZíUuJ1Ô©»q½Z§­¦DÉK—o€-Z*ûh‹ÀÄ€E†l<åÞ*‘ápMNq ¤pðþ5[Z Ÿ|¼ï–¾uäêru\úëñƒ§íhc ߟo:ô¡×‚ ÖU˜¢ã•ùÏÉPyË^¤Ûï%-1vZcÆùÏ?<áR?ce—.Tš@”¦¬—WŒø[J䤓4•óí[2%L ¿}K€\šæ§§|Sã@ cSpx÷N»ÑSóŸ?ÿ]¶±OQ£¢c®Nûð]³ý&NóŒI»²­85ª0çΔó©£{*ó˜$œHço°“{¡Ïì䵩¾ÇŒésºµ¬8K§[·î´8ãÓ—,eMéYÖÑgcš81Ûߘ´/‘€•¡óxºžç´é¹`ȃÎ7KEÌ®­jLÝúÚ˜@Þ×'OÞ·›¹´*k9äFeŠèÆÒŒ¥ÙN‡÷øVšÀóƒ²KP2°^½zUu/(Û âï¤øå•j•"?úúNZ˜ÄO}áë{-Îòõ Yiä¼ ¾\¬=|¢6Á¡€$…GݶcÇ+8“Ï H’,|ä7qìzÎüð‡ÚÅ=2¢mãfyopVc”‰h¯¶MT³ãª&ë°0vØõˆ=ËçMÔî`ñ‹üýjk°mmírã—ŒðûØ¿g}`hòpØ…!ƒ{Kj½9ÖøxÔl3- H€çÉ|¾Ò6…4M‹sI’¬3h{ÿí'ŽÜt뿉1 Pì˜f]þÞ—$ÙŒ:ÿöª!´0¬ÕJ¼¾¯§ÆŽ|Ÿ£â’\#>>>ª{‰‹‹¤±"þ2h¬ÙÙÙŠ5V¢Ñ…  ¥€  ¥IáWûØ]Çå¤ 0. ¸,ÿÕµkù²—b{!Û>aÙa‚e±Áé}÷'69·×à)ž¸#濜´óUϰ½%䀆NÉÁGzõ ›9k餕-¯®nB‹aùùùÀ0Fr BšaË8“  4­t¥§\Ç0¶äÔ?tMx¿ù×6P—j¬ [[“Äÿ^b[Í>P²… J«ž[M_Ù%¹FÊ\y%¹©ÆŠø« ‚$ó˽W#)¡ˆF,(¡€@P"¡@ `qy¥ç¢r4ìÝÝKŽXÏUÖ MeY=yùe­°k[-”DUZœ±Â×—²ñ hj Ð̆ÞpO¤t¥%<׉½€ež ûu6O·¡J_ªwC“É ö@ßå’‚¯ç|ᇺ[¨º¤„yóæ8p@rìããƒæ±"ÊžÇJ˜-¾|¹ø”"ãš´ì}ùò5(‰´–Dceéž;9QΦ笶2âiλèc.]»våU>`òÊ>î<\‘vÆïœØ±nãž4S·ýgWÕÁÅ$).ÙµÒy¬wwƒ:Þ~ü•Ù¬ÑÆ´M-kç–”ƒ½Í Ÿuš/)¤ñûSë=j¸PEsyÕAûS3²²®c$[’—‘‘ÁãKŽ5ÍûDEfûNÛÚnÓn͆FnØ¿¦O™—J´/35$$D²W€¦¦¦œÒXÓX3ݽ™œ'[2p@¿›7oÈ–hšZH+ÔilW—Põ¼nÌe€që%gZ—í®õ=уy:,¥ pÔmüýå …9Ñ£G˯ °k\38x¥\áì}G[iq ]Ï…ÍÎHéa öóž,Ցݘ‹¦å~>5[½uKÑJ\S×uW\Ëþ,¿û€SÑ%KÖܼ/{jÐÔ÷L¤/-,À¹òSýU\Rˆ––Ö¡C‡~Ê]â£ìÀÚ`Âüeiñâ£\uõJ\BᄎJÏjÄ+¹B®ŽË‰.ê¨÷–U»=¦'ymgSÆ|ø÷1‘S×d¬¹.¿Öó÷BEè,gTE  )ÔX1 «´ýXq\ø›ê_êN!+]ŠÍˆ‰y«Ú0õõ>÷õ!M¸ôß©ô¡ýXˆÒ$‰aX 5''å¼ËŽ3G–m¦Íý&—mõÇ"ÙÑJ’•WHcEüU!ðQÎ+Ä‚V¬"ªAõ—]¶QµçÝ»wUíQ­A9¯~ÆÆ¿Ù2­Ÿi¬ˆ¿ óX‘ÆŠ¨Î Qý‘ÕX«Wfø@@ *¤±"~ÆŠ¨þ(ÐXsss‘ÆŠ¨¶ Qý!B(,@+@ü_@@ *yUºo1Q}STÑ]Ѝ†Èj¬Xbb"¤¦¦jkëÕ©cYFU¢*øøñ‹ôÝ¥ˆêÉÇ_rr2ŒŒ@nI«ìí‹@TOÐ]Ѝþ @ *óXñc”˜Çš——‡&"ÄÏ ‘h+@ü_@@ *¤±"D¥4V¨Lä5V êÔøí‘R¤±"D%ƒ4V¨4Jh¬ùùùHcE ˆŸ!/O ‰¨JÓ__¹rñúó‡ãîîYÕ. ˆ_‡ÒÀ Eá€a†a¤ÿ—ÿ*K˜"˜;wnWµ;â—¢Jc%IR@eþ+=Dµ d¿:¤_# ek¬<¯äpµ8ª¢ÀªÙï P‚&âï läE€: ¬ª‘~?è‹B þBTVÀ0 4k9Aßñ—¢Jcr¢ªì;™ uC‹Ò…^ê3¼J$ä'¿ÏÕªc¢YÆ_‘J“ ¬HcE þÊ¥±ÊÄRæÃ)3O~’ئ‹w4ÖÏþ°}Á¦×cíÚã–Mk¤¬3™º~ýú!#F³ÿŸ‘•¦²ž¿øÜ¬YSÙÂOGüoku?ÛÙzÚÚ†jŽ­©7_ÒŽŽ&j%J‘8™eÀù_ï¾Pkîl ûí‘ÆŠ@ü ”Kc•êßÒ½ÝÄ4M3 ÃÖÒAæÓgÉ-VLi”ùzãº›é²Æ9nFÆdJOÅ‚x8ö4[&éÙvt±Ö’­•üüîç¯Þ¾Åt-6lìåÕA¯À&¢œ‡ÃGÌyñü‰laÊíìî\E†Wr… ¬´0yÖ%]–¼º°}Ý¡ËoßÅå‰Ù¦u›÷>uL[`|ÿ!óŽž_køýÓ@ ~ÊhÈ̈ÖH$WüÃÎÖJàëØ´lÛ¶Ù7l?܈ÏZèqàÛ­­+›ôv¯)maèÐaÞ½•ž&^<ž1ÊVX*7,xæŽgX_¯VÇã×-jr#býÆ}g×l je¬´0qаi }°í@oeCBZ»_§µ0­ÓÕËùa¥<\õO²×Ú¶º<ÉiXÀ  ðø!³ýg.o®–ûñö­ðµ_eÙ8²1aØi¥Ë¦±ž˜Ù¼¢½ ˆ?Œòj¬¸ºKh¨£¬Æª®†:òÅd¤žX,S4ÃPB~B÷ŽC?¸Åhš÷™1£µ²Žï<ØI‹Åb#Ú0¢ëÃúcÎYîëÔ¾ë€ö]´ß9zÊÐE‘–q0`@ÃÇgXévv-H) Åbˆ)1HڤȔ+'†…{ý]gûŚܾʸàÝŒS‰"ëK*&ßô_~æÅøƒ‘clõÀ`p£–ÖTüÒkùC–rq°õ›ñÙ}Ú‡q—¬x,¤±"'ÕX9é§Œ;üAr©Åê° 9»ƒã4¸š³Ù,uýìØµ³gp ½Nl6 l»ôT76gDà›ŒÒ}Ú/_èÑ»³ÄøkÄŒcßZÞ:8”‡cÙù5-:KÊ;úí8Ú&ðéôՎƺ]»v/ÝÔ©å qGbO±ØûùihèGÏÜ4hÚ©÷ĵÛ<œ´Y?òxžúd³Ø`H Âqî¡ z63Ç55’µi3åÀE(+Øúí{ëò7½ÌÞäd HcE þ6~Dc­7bû…¡”DcÅÙÜÇ»?ÏÛý_=‚ú6K÷o}’)„©v-$ÆFξ“œAÔmó ´ø{G÷^'®Dê³q`qtôt¬‹Z>¼æžÇúŽ@ÚÆ  '†53X‘ ŽÆåt’¡]üVuëÙkëÙåkj–ºJÞº}¿ÌFlZ·3âàov¿3j;®¨bÞÑ4~Ã!mJÙ–€=[ÎÞùœÊë-ø#©@`}¿÷Ÿ±ÿ}†–ë NÍ;½zÂižNó½ÛJ<ûcÜ´]ŸÌ›8ˆèrJ©£éüëhKN"C?Ùm/LÚuµrïg—ßI çF]9ÁRòÆ‹g-\¸ ÌFN_î¤K¼I)Ðë«[è¢ QL3zÍõUWÔk®Ïßû }ùF ˜ÇZgÄŽËË5Ö|­ÉƒÆ…ןµ°‹9¼Ú5}?·©œŽ™õ)äÌ™³üD´X‹çÌäÅU- _ÿñ €¡²… nDZXD‹Ò÷7¹hJHÛIº—®ßBW…<ÊДHb ¦ÄC‰Äʬqƒ«W¯•ç{‹EŸH1aÌ‘´Lã8†e¿þ.n¬£¢ׄG >ŠÅ"¤±"'žÇú_O×óX†Ñâ<æN¬t¼nÍA÷y¾'lÉ[ã¢Y¯¹J´N)ï÷=¯á´‚ÍæÐ \Ý=´Š“„®I¡1ÛÐŒ E˜:ûKøb=wM.WbC ·}Èn`.׬,€œÆªÂ¸B˜pY¯3i©“Ýõ‰Û§£ØƒêË™‰Nh¥2E,n­"ÆŠ@ü]”w¯ÙÅVÂü¼Þ!×'×ÔH¾3jø 8šÍ,wíÝw’­øY¿ ç›i–ˆh4•¹ìzbkÉ“™aMÕÚwrW$À?vAaOvõÒX°êɘ³ {§rŽùf2hn#}å=Ùû߃Òu…â–ÒœŒ8f4+2ûU ´¸÷ßç@—"'g8Ÿõ_»3ÚógS©ÍÛcsFìN>¾O2}5ûmWWy‹ÿ ý¼'â÷BµÆÊ”da…«Zóðš9‡ž‚¡sfF²ñìÅv¿óáÇþê3vÖ’©’®…õ\½øúØi.›ó[NÜ××õ%æÎݨóÿíy«Ýa×Á©’*´(5&&¦tÝ|Š‘6ËÕlnÄß¹+<Õ$¸!?7+3ó{ffVfæÌ ÿZòXújlY$xS —“Ytß0-jÐz¿®ÿkïÌš8Ú0þî•nTð>°ZE7ü¯MŸ……-îÙd¸§§×ð¾æ$žssÏÔÏý£·4jd´]¶cÕÒI°lQ€­¥™P 0`¹T&0o±5…fNaûO?Í¢[ÚÑ4v>|ßUãþ‚ÖzôáMÓ€÷ ëS¾›Ú‘_À jÛšßÏßzþè~‘LN DFFFfõ5jÚZÄÊiš­”4Ö}ÆIÖ„dH¼ê—β¿YµÏ±[ÄÆCûçl ’È [|>34j¬‹vVöbO–,ØÙЦi•]k‘ÇŠ@ÔøŒŠ¥§§@vv¶±q™Û2gÏžúúë>ÊÓ®Ýý»Þ²ÂÀ˜7Ý<Í»×ÜÀÃÍJmÓû±Q¿ì|°~oÇήßqÍŠ!%Kª8öÝ­ø+OR^ääåKŠi†eÃ…"{ÿYÞµÓ•ä÷‰®FìŽp·S}ƒ•JA ,k8$žøÝ…¡§6yBÙýk¯_O@fA êïÞ½±²²í‰õ«¯\”=ºH H(1^å4i¢å6û <[[šwyäðmÛNï²TÐFšêÓÎü˜ƒ]LPv°ÄÄD”Xˆº€"±ê¸Ñ5pTˆ&ßçIDATG p¥ÛY„1©Õ@Ä*»µ` D`Þc{н i!#zk¯yaÿ|·Ÿ~ý˜Rö¢Ñ>×DÝD›ÇJÓ4ŸX–¥g^aXJ–Ý&yãf…5Ç0 £x©È°€ÿLQ“I^”-¯ÓŠ~r5¦*»¿§žXwôÖ+]j¾Múq]¬ö:gNÄdÈóè³8EÍÓ=”åå¹w|“ï¨Á];ttlߡϿ­Gïñå5J^ž›G7NðÖ³k·/¾ò7i÷ÙGÊïþ:eôÄCŠ—,½j¼×˜©ëß0%]`e™‹|W+÷]K@Â@²ÄwÉGî>òXk+z± {/±lL`þäƒ Ç±´üqäRÃNÝEø»¼”ë7 hš–3ÇÉiš–ã|ÞÙÑ8á&tÚl+¢iúØâ‰Å}‚zZضu¦»ß7Ž‘Ü,Á‚&f u2Âiš–¼Îx]Øi]Ðàè¬ô´Ôg·B¦xîvµ%< …f_‡ôÚàšxd~çÑD/ký¾ 3×ÜËF<öìñã¤<ËÁ³†7QŠÁfg[Ù–~ïÞý€®±~A¡³˜¶vÒr€åUÕÄ’…‹‚.ºÔ7¾{›_P,-_YY^8°ÄçÇbŸ…ßÏ ê$*HŽ»t",`Ô¬áÚi—÷£{¬ì®y^›¯û. XÞ£ƒ±<çÖùƒÁcÏÅîY>´¤Ù/Ó_¾a8¶p÷£ÿÊúl×ÁiÆÀñ…××~÷rÀNÆ$Ã0¤,¾^ÝcÓwþ9àß±ò­UòX?eôbZ¶ž5Þ£8ƒÅ Ã)²Ø ë¬µžEQ$€SE†‘EŽaI>ßÑÜ'DHQwvÏZ}³Õ¹óý(·î<9zíOÇ?l_0ÌäEçÿ‘qµÿYÒ ¹‹‹Ké™'ΘrcÌ ñãüÛ_Ø:¾ôHé9/ÍÿïæD•5ùõ¯CûžˆÅb±8õÙý7ÏâGOnÑ¢E³Í[8´2â»ÀS”}hÏ£[—–•î±xGÓ¶¡~ß)¨teE¹øèŠ3¢‰“úÛ)J(ãØÂäGwSÅiiibž\¦í¨•xIJ–qœ™€¢(')å6@9y3.,\}ìîìCW¾s¬v­¿è퀥/»ð;)Dˆk“÷#{¬i'çmú;õ»¨óSÚñ×`ó~¾ßnGô_ìÑ{i×ú€c€½}žwt†Ã®#ëÚ‘¥}OZ|,#üb{‚ t ØiÆüT·Eâ™§› «>ºèâ±¢åVuš[‘gr£cÿ–伞( Ý]›è¥ñ\ðï)sb›ŸÝ4gá¾WD–W?7Å{m}ÝÿXê]`sþ‡î ²ÖÑV>)M vÙ¼¶¯Û¬å ƒ»™¦=GšKÂn½Þäl£ß>êHƽ$™ucç~_Žm:Í×kÌ¡“Çlj¾„îÿ“”]&Ä¥ß%?IJ~)rsmÇ¿Û~è‚Ó­Ú<°ùBQŸc‹VGÛ¬™’—‡V„\H‹Å©©’âk“ç^kÒ´iÓ&Mš´ëjðäÊyû±Š¬ 2Œ Nм;WÆÖk·°4«–àh²=z½"«ÀëÄŸå–c:Qº˜:5“„ßÎÞЭÁÖ³2 ÄZ§áX¦í̽}[*J–ôì¤u¾‹¹µ0¹ž’_/ÍbßéµF0§ç½Ž^a%¢p¤Ø[Àý­ôš¦ýìõ¼9î¯Èä‚nŽ–0°«Õü- š¾ù~?ü 8v1£ŽåOµ5*-`ù»ù™)I’’é³§æ%?IËa›45zp/7öŸ8ª$ [|6¸‡RØô³‹î=v»4¨AËN½Ý†55Îß8+¼ëßggóu ÓºD´‰Ùÿþ'çSÀrœ©ÑPP–—cÞÈ’8ŒëY®V™W¯¼<óöÏœâ¶>j —nõ÷žÜð>±ž ó 9U°'6ª]ÙËóÃIÖÎS*°Ë€má£%Vä±ÖRôâ±ÊY.åÈꙉƊ’²&ršfXÞTñX¹Ü+l¶«oDÜ‘o3^§%¿(b¹œâ”wBÀ‰Y9Í¿™Eæ#LÎ ÃÇ1*F!&lcXÁ‹ÚÁL;Zî|@ÓÊy©rèÅc€~¶†»ŽÇ60Îyøðá£GŸ<{{áê9‰xí@¿KmÚ6µ¥·q_3ß©YC‹3?Ûÿh ,­îþ¶4ÿúø…±®?ýršÀEÎ|²nˆ+ýîþ·^AÓ·Ÿª§DöîNYÖÇXšfYVN—V¾³xë˰y”å•¥ÈY색vÓV“¼Óc•¥³gÑÁŒ·JË4ÏÑŒ=–R@Ë qŒå@òjÏòs޶ØëÝÇŸ®ÕF¹æƒWEfÃMø:³Ž’=ƹR V òX?eôâ±’8fí<êÛAïí¿Í‰qIQ˜FÕ¬±—yëxؾ’ÛúÏ åé¡ÁW( &]wḎTnho¢p 0ŒP1 eoo°gÖÌ”/7µ7b¤b•:•¢Ê«¼8íào'ÅâÔÔ”ÔçÏŸŠ_å)Û.öíÔªåçcû kÕªµ€2h˜p)’ù Ië&ÖoŸí[|ªh÷gµmféì`_Ü%à§¾ö*3OŠÄxyàö–ÕôÈMÿkg¥\¡¸ð¦À¸K‰ìï=Væç)³SÛ}OQ”²¼Þ˜À°‚'ª‹6é4Éû1=VÜÐǰ¼;oˆÎª3Çü[y8ifB‘€c@ŠZï9nvgó€é~:œòig®¨)–2†ŒyƒUÇ€`ÜHÄHÅü§>ä±"*FöæUzú{/OÂV˜”1‘Üeq¤›4â·ø©ß¸ûwïØë—ÍÑcÚü†¥¾¤€È~]ÁâÁ̸( #üìLø—Òl)!°­rG> ¿tûY«–­tëÛªUëz² ƒ¦6 _3[m]+§ÎY¿ÞèðïÞ?{îüB\|ÑÊü»‚¾gÃ|´.€/F²ª^ê½ 1¶.«T ã¶N>¹Ÿ_îeåÅ sÏzq‡ÿï*¡9 JO_ò–‚áÆC-EÎÜ€ ­UÞŠMÌ1²¯x)0íÞÊ„î3ö¹6gâäög¢:˜”üz¥€ÈÉ–V6 4G†SÏAëXë:’ô¤ÛJäÐ †í<v(_99zBoçK\«^¦qÌü½žñyÃH\ë=u Sš–Û ’ ´œ÷íóË“/6t[Ù©41½yøFhÑFËGþ;AÃÍëCæNŸ8¸ßWÍl-l=ŠriºÂZ”¼> Î+mÝRå]F–{ñÐÚ~žÓs¼2Ó°ðŠYé!.,û-dd+Î¥O›÷^Ž+ŽZ>væ.éø\*òN[èœû tË•—Êq\àäúbýf5ʫ̄yNy×FÜÍQ.̈]•UØÙÐòõ{úïi—5ÓwuAéØjmL”÷Xí=#V¢õÉ‚›~?\õ#MÓCÓCƒvt4nƒãžNààmŸyžY2”äEOŸ>Í1Ò¬—é)Ç\µüÒ{Oˆ§ÂŒ?ŸÙlzKíF¡”Í«.¢a¢®õØÌ+y…]ÕýÆ—häH¤ÞÌ—8Q ðöžž=yâÔùK7eæ-&GMøhð^ÉzMŠ^Y÷kûzÆ,]˜—›——ŸG‹†/žÙ–c%aãGÁW‹˜%²$ø¹mä²÷ä²f$ǪÈkë¾ÎÿÒØõ“ˆg,tïÖÙœN¿±ãxçÉ[Í8†¦Mòê(šŠ¢p¥+ë±@£þkgñÚ8qtѼ€Á=å9·. Ùt¼ýÐßw±,Ýç>å¿ã—ýüÆ-uŒíFÛgFÝb§·Õ= \ûûU³©­ôò\]DCkmE pšÑ1c€“$I'ÿ7)ÅÜL”)cÛP$I’qqWMÌÍÅ7s I–8_8i`eSbf,xýìgN¿+*Ê—³E D ×G-<çéÌFfï>Q²fU.çkMá`Ø ±Ùƒ `8eaeÝÀ¶ùêm ÜÛ*æjŒ4-2KêjÇŸ« pe-fµ[wÑ<,EåÐÎæj~Ãþ™Kw6+s 2)Ϥýò­}4ßϰh:ßôò¿·½y'gÁÀÀÐÐȰ¾¥€$IIfìeºïá0²tªÛ±{³“‘£•c©È “:üe¯Ÿ×ï?à¿%¸¡·ì07ü°¯[É:0Mòê"I’Ê;Zñ{;)2¬¶~ª‡˜°.Úñè¦ðýá‡C_HqÃ&-[O‰šàÖVQÃÀº‘}cs +]+füù–ÍßMZ±wÓÕž3œ­õó•ü’-÷®_Ò÷в²û²dÁ½m1õ‚6ÑôxÄÇDK‚Ð}¸s?3``Ùœ©¯ Í[öf!dYöü–иŒ&òcsÅ<‚+­< |—«ÀþQÈ¿#O„f-\LI–e쇆DzœÀÔõûA§Ò¶²€Ïl;¾ Ü镚r4Pä´ÂÙ˜¬òœB—ëŠî¢˜<=™Â55ÆiÖtSBu×8[×å›\ùÓ°:ÕÆMP®eYë!¢Â#øG¹ *òò8zÎØå9Xi1ø,¬h¡&yuM%«*äªÔ%\…ÎC¦í2c¥rLÈ»ÀÊ¡ÚùGì+[RÏqBtô¾šÀ´ÏBÇ5+ΦoØXÇ€©1+E]—t7¡ªÜ`et %ÖÚŠ¦ìP©áÞaÙá]„ã8ì÷§•ƒ/‰ü]ù%Œ=zžŠøc\h'îó€ßÊÔÁç²nåîÁ‹3Ü"ûvvÔÞŒ;7/Ï >9àCÆ}•«ZÑšŽömªù_]Wo›*ý#¬GòÚ Êz´˜@X¶mŒ4E“¼:Ц6·~HbU4•¬’Š!K÷z-}Ùg»M¹¾—ÈHS6æþp´¯¾þ^ºôy¬µ~u!”{pSå†;Fà¬\×-†’_©#¸±Ó¶ Û±Éyÿüóöš¹÷¹†níh€UÙ`åQî¾–%™ð¢Õ ò†ŒøJ{Í ûçi‘·BѤR©Ê¥tK.ÿ¤©Ó–•÷.Šß†Žv­°ò™È9}B6u4$ʯu­2 y¬ŸÊva}ʈm¯écu¨fÙþS>ø\*ݯÐc­±¢é/ïØ»w+¬©I^]D#BY1Å+ýú••źû”Q£u©ì§×S« ´맆ÚQݪé Ñ*‹òzø:¾)8ÿ\ÐziAkmEÓ¯³ã^—D‰DSAÑ”½ªH%uV1(ë#iªƒ<ÖÚŠL&Sþ«Wwëª•î«ØH4tM.—kíã6¶¦ Òqä±~R\¾|¹º›P£Q;°‘hÚQ+ZBBÂÇoI-B­hXzzUžB@ M ›W¡gÇŠ@ zy¬¡g€@ z%VÐ3ÈcE =ó=¤b”ñ‘Õ¼IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/datamask.png0000644000175000017500000010310413070106167016670 00000000000000‰PNG  IHDR$`‹Òb—sRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœ IDATxÚìwxTÅ׀߻÷îfÓ; !ôŽô"½÷ª€ÒQøP±"`C¤(?°€”¦"ˆJ/R¥†^C é$Ùl¿ß›l²IB %ó>Ù[æÎœ9wæÌ™sg¤K—.©@ ÜG4B@ „A" Ð£¤§§ )@ ¸¿‰§§§‚@ ‚ûk÷I’PUFCªÁLÔ‰>S(Ê_£j*” Ã×Kq‘‰ªŠx{ Pµ…â+àþ$ªª¢ª°ÿÈLfNFÖ!Ë2ªª:–G…Ì2Ùl6ì63‹ O½DÊáB!‚ÂÚž:uJu7"¹zõ*'Nœ(T©P¡áááhµZ, »Ý^èe#ä~oÊ)Iv;ˆŠE«óÆËÛ—àà`ÏÉ£è1È^¾øøx i)XÌiT¯‚¬)<í‘;"A¡õdÒT®]»Fjj*z½­VûPÒ2_êüäÝf³a±X0xxx†V«}des¿äü(Ê=?åwWN›]eçÞ huÞø†$I.åT=$ÙËCrRfS*M/ <¼ï\~ßw:!jƒ$ó%JLLDUUE)£4w£5«ÕŠÙl&00½^_¨es«r¼9¹ß¨œg.&s-΄¯?„„„ ( ™}Ù£ªVÙËgµZ‰‹‹#11‘Ô”dÂBõT*úH¿s7Ó} P$§OŸF¯×Hhhè#1J»•‘{ö²ÆÆÆ’˜˜ˆÁ` \¹rœ9s摓̓â!y䞟ò»+çŽý±TªT­V‹¢(Øív4M¡0r3˘Yf«ÕŠÅbáðáÃ4¯ñоsù}n¤û…½M>œë¤§§c±Xðòòr6†ŽQšäò‚=Ê cf9­V+FƒÍfãܹsù’ð’ܹgïrŽ ï´S¹[éݨœV«Íé ²ÛíÎMáX·0{œF£qzõöèF:qþüyÂÂÂD!(\Iæ:$‡&""Y–1 œ;w®ÀFiw2º¾#ØÌÎ@–e|}}9|ø0U«V½/²¹•²ÝkÞ«ú¼[r¿]Â]~o5½›•Û]9!–ìëe$²,?ò£dUU±ÙlÎÎ8;¾¾¾öÎÝ«6èfzs#Ý/Uª”è¡…Ë Éü#!!2eÊÜÖ(íž“H´` *Æ“uüoë¥Í\ƒá^ŽÂ2]¾·3Z»•¬ÝfbÓž+4¯_ê¦kóÛLIüsÀFÛǃǒÏ^!6°åä|ÈÎÆÚmhר¤KùŽE]£h…Püå[k`7î8C•ºe(¢ØH´k”¥Û’u¦üît”|«žƒÌŽåÜî3$?V’^òéFöÎïfa~ôØ]93ív;Šâx-eYÎõ•ѽdùû/ãùÚ't ÷¹áuÆkë8ª6¦v˜×m=Çpi#G<P/HïôdÊ/»ìò[÷ªšt:†ëa!”ð‘óÛa´ƒÇóSb’±û¤Üvçfï; ­AÜö(í§sEùðÙ"ž¿¯¦-ïYf­ÆX>™Ũ›Ýð:SòeNÚèxó)=þ*'u¡T÷•o8Z»ÙXæÿz€v-ª ½In4ŸgÅO´(îl¿Z¸—ØÇ£y ’BÃÆer©—ðÉjO>T”%ž {ÛJ¼?f5ýGu¡Š^åËwòÖÄ^õ¼5#oÝŸ‡ÑÕ«Œvÿf>ÚÈŒa5ÑIw&ã{!÷Ó¿næÛç¹Áo´§’>ëÞ3›Žsºrzér=ÛœËÏ»í h•åÿýï(lÙ Žv­ªà¥¹sËo9EqùÌ9óü­é¦Äߘ·èhžç‚ªà馑yž³¤íá‹u«Y0á[ôz÷_yØÍѼûü;ôZ¾½^Ï‘É]µñå-cj¯ò¹¯7¡O÷˜ì*³~ßG˜V3žy…«¾'H–œq3™åÍüÛ]Ý«vW.'ræ|,{Esð¼Æµ§¸NšËøyÿòxÿfØ|$$*• E“¡Ã—F•` 9ÕHrr:ÑW¹pù:Eê5âã§²Ù²p Ñ/ve°ŸîŽÛ—;Ñ  Ð$Ù÷²q7JKMIÇzƒÑacåË·&rÙ£ µnó“µü¸bU“…QWoøYœÝšÆçÓwÓiTw´Z™“ËþbÚ¡´ŒgÈøù{Q„ö­ªP9TÁî¥2óÓ™öa3‚´²ÛÑZ^²‘°0uîŽ<2aà«vä™ÇžkŠ_†aUd4Îô¯Gï倦χ{a·ønÅQ*4®@­kcåQ†«Ç~ç?Ó€DêÙ=Ä…V¡†Ÿ¦”Ó¤k<©æçqË»'†($™R-ÚÐôߥLÜ\ŽÛæKÆ%Û¶æÝ&~¹æùí–ë ÿøLªÊø1O"Kw$wY–©ðD3ÆY²F–Útf.<ìüj%å÷½ÌÌf¤ ÐØ!w-ç6¬ã´äÝöEë€ØT쪟þ8Lã6Õð×jò­c_](Îôá•séq~Ë)˲³cΔŸÍx‚^½ž¹i©÷ߌíãÐ')ëÉ ¹®I»´Šù ÷Ðw×oy¦q|þìhù¨‹¬ÆÁ«"ÎýŽ žYïÛ¿zÓõš…8¼(Ö„he_¶þš~ËréÛù_ßàRZƸ QPŸðLnþ1¯}¾‡ŸßnèâaÊ luW÷ʇïüJœ¿éWb©Ö½)“ž-F¤·T•_çlC_©8×g½ÍÄö×1¥3¼%:c:›†à"A\زƒŠ/tâ½ÒþxÊY³²E›g;s3ÝÏÕfYSxsÂß·¥ûbŸ1A¡3H²BÜÒÆ|°”ÓF÷®ãˆºmø²q$^#Š´¸ôz÷Ð ÜgÊ@ën)³«ÖéÊuÇ?¬$¾A[{;Œ†Ôt’-Å™òz%T»•¤Äëlß¼—&œæ£©½¨S¤ïÔ8À¸UÉÌxºˆÛÑZž²Q:4«ìòüØC;Ytµ"ã߬ÉÕÛYn­Ê+9ª/O{«7žÃlˆÇj²°nÛi"ê—eËÜS”kÛ„Ò%¼ˆ=°ƒÀŠ5‘c’9„— §ˆ"a·¦ó×®:Ô«@üÑK€}×hRǃm‡Ôð¹v oŒsí|ÆÔ‹p­Ä‘ÿÎ’huã…B%jßy6ú)”lZ‰¢r[öYiÛ¨ø e|]ö`ÿoûѵiŸ«SŠÞ½ž«&/LÉWQtzôZ ½þöånL>ÎkS¸<#¸rcúe«‹m'.]·<탲t,ÐË­z}q>þ¸¯\ÅW½^Ï—þ=ë;<†h~úã0—$Êèå|ëØµ[žz™ßræ©ïÚF¼3Ù½nMbƒImU4ëy!ýyoLÿ\×.챂c=?È3›ñ$#¿;ÆÈoWPÅËñŽ©¶ë¼0ðiT¾ËÒôƒ¼½ì<Ÿï¬åjG~ˆÿµ>|u*‘W˹¯_MÛÍãïbóHWã¼Æ°)œkÜŸs¯§”>ï¹wíѤϞàÓas©Þ¨åül–ëÌùr5«¢}øþËö„ÈÛ~\FL»´qÔ“ÕÏw{cœé_6Ù‰^½—³†gÝçÛðd ­V‹t“$™@?Û×ý-·¯ûbŸ1A¡ž²Ék”0ã«Üz/Ïù‰é&/ü‚²æ“YƒìÆÜ mò¼gÜû‹3FKŽÇ§Äñ ÕslÙZ–•nÈè:ŽüìºÄÕyŒz“¹vYv6Tyv¦¦8&mIᣙá(ŠãZYÖ—Êå²–¤nX¯<†~Ǽ )ÔïBõ§ýÚz®<ÕŸâSÎÑZÞ²QhP«4ªÍÄgÓ7ÑõÕ6øü»ðúehP+€Sçv³ÆæÀFV<΄'Kfu¸—‚Õh»•«q)ìÿ»b,t½ÃôiG©Ù¬ öÿ²eïcœÛ~”ºæ™`;ŽýN¼‹ûsøÏ}¨v1&-aŠ•´tˆÞ“DñÖ­Û&SÊI^ÿìß~И0½E‚ÃÎsΔw}ÚU¸v"޳á™y"Š.KæîdìZ¿¤?Ycåùb®óÂåרùL=þýú*²¢ (ùÝ®Ü}‚*ñÕ¸ ®·¢%ú¿Sœ59ó4»Š9ÅD‚ì}zøDâ©ÍÒÅ?’icÛàÌ€Ñx€‰–yè™»ò#iÜêe~Ê™§×Pö¡qÓ¶nÏo›ØÔðgøuØM¦0¯¯åQ‰Lû¾jžç—¼Ù}·y¦ió¬)Á‹cÑ  b6ïHìΰ„¼DMׄ5]æ.¥y{ìZðÙliüu)¬ªãÃæÏÔùµáÉ€4>ßÃô†ÅòÌW^uo·Ù4€«Ê…“WØï%sjÕFbËÖã£j1¼:êO´ÔñÃépæ~X%éÈ!ŒÜ‹Õ¡ûË?^B@¯Æ´ös,Âwô‹%t»”Žj³£ûj 56Ò¼ùcÖÓ÷E÷‚Bm¸½Hqïøße rH@^­)á¡~yÞ£“²:CSÊIz½»“Ÿfõ' ´•=‹CFŽcå¿xW¯D=—lª¬;’HÛÇs¥µ«5ªzÊ7œ’4ZÊ{Èì¾jv¸†½KÐÑÇÂw' |XÅç–…¸}ѯì²VäM}0•Ö}\Ó¨õT¿½’1tdÜ“% ™ÖŸ¡Ï4!=á?Ö20¸[ž“ŒœÆ«ýòÔÖˌ،aÛòò€füvà$&gçëMŸ.µÙ»fë+Ô†øÝÙ~†mëÐ¥‰CL%òÍ"/êC²9 Oÿr/š%¯g·qïaú<†¯ÃkðZïÐ<Ï»“±Í,ñJ?&|–ATqÊ:-v?[ zæUÐòoŽ´n[î’Ì…ŸV1ñpªóÐÈ Ï`»ÎeƒÃ‰hQƒS—3ÄžæÜ{¤øF–Ã7‡nļ†ÖOæð¾ThtK:æŽü”33¨6gpmæßf—Xž¤c3¶ø*Ó6NÃS¾ñÄÜêQÃo3‡–¹GÜ{¿†éû‹óëæö.Ï=¿x E;~år,jÖ!Š4åš?Àšf¡Ê¯ßlÇÓûQ)Ã˲sÜ,š~F |Ò¥Œ™t¨Æ»ßFj™Kî°[SY³) Õnâ?ƒ´íLjÕjè;¬/}½´ VdÀñ…ÌÝÊדš9§F3õÆv~CZ¨XDGlš eÉ6)pè¤5sÒX8böQ½éëL·7¶Ü’î??:ËK—»Ÿ-éwY÷‚GÙ É>O™ÙdºF3w „ÝruÉF•öÊÕHÝè> ãYz¿ Ô×ÿ×QÞ¯ÑuÆBöP×KeKŠ/ƒt9ò¡²bæ~Œ,ËóO5 eE_gª§#¸z=×çJY9Ê<ž|þ(ë®[y¼©¿óX‹*^L\™ˆ¦ªŸË²ÖÙŸ[6*/^Éç{½˜öI ö-ÿã!Õù8@æŸÝçˆ9eDSFBçÁ”IööjÆ{=Řö!ÙdîÈŸ‡_y¾ž\–/ÏæÒ¿[!¤’cíIâï}ç¹`¶ž‘«ñÓ¦­å„wEf¼\‰'þ=Èg·gáÜõü"!Æ*a[‡TÍ—Ä#× ¬ä"ÕfâÜ•Ô<:E…ÐZÞ$m2¸­;w2¶¥Û)ß³‰olᤱå3b7ö-8LhµæhóìpnOîPyàÌS³g!¿¼½ ÷v3ý¡‰E’QíVm8î<^¢aejxe'¯Z•@·W«±jÆ>¤mó]þëûÍË™ÓÉ~üÒšç´$‚ŸçL @Ö³–A}ÆÒoÚš…ÜøK—˜Ío1~CóvuÏu.åìÿxáó|ñ×FŠydu²v[<“—\àͪ¹\uÕ@@ïà<¦Žìx†â©Ðw¿ð8 ‡TÅn:͸í—xa]sTõHžy ª‚aö!$©cžŸÇæU÷:¯"Œ}½ñQëÙºšhCŸ"MÌé³Ì_´‰3AUx®êu$Ú(&çHÊW¡Ë@6Ï\…wÇÚÔñ’xgê–¬öÁªRR‘QU ’¤qÏîŸ2åÐýª·¯û"†DPè ’ìó”îFgîÚS«þBV‡f~J®—¤›~Ÿyþ¹ŽÁLß•„\½8Ÿ¿Û‡Ò> †˜ÝXõ”ÊÖP:®×ðõ—ýY<ïo&}ü¿7©Çðu)®×p2ÁŠ+ÏÆ‘„%õ,_.HCµX‰‹‹g÷‘XÊÖkÈè¾Nã)°‚'é«ã‘¤Ryæ1/Ù¨v ×mALŸX—ÿ®dþA “GE°hólçÏqÉ·}[: ¯ÀLŸÔ‰«ÞYÆÝ’ÎÉÓɘS¯0ì½Ó”êp ¯ZŸÂð·š!I¯=׈¿N^æŠEu$Š>„ÊZòNËâDoú‹jUQ<8ô)Žý¸„ûqvÉ6Ì”áÈŽJô÷uÉ»Õx…OgívŒâ¢ãH $Ò[F£x3åÅ"–œA’JçYoîd¬ÚÀ3°*¶ñùßIÌìŒÝ’ÄgGRé?5ˆÏSŽ·#w€¨y¿2î`Šóøðšñù‚½ôéT!ËÙÌâ5§èؼ"*vN_p¸üm?F¹ª¨éíÐ_sòiV§ùòkņœ°Îâç‹ÍèSBŸ¯òßLßo·œ’$Ñn*­~¬Ç“}SXðU?>èÚ‡ #ÿfDû27žªIÜÆÐ×¾ÅKÒ²aÓjuqwò+3’%k_¦\ŽÏwOÍëEBãohžÃ£rÞhÅ«˜OŽ|‚„£34ª O|ðê ½æ5,Ax6Ò´ËjžeôŠôÆf:•«Üù‘Éúç T$~üðw*L|ã²L;íA¿îyÎã,Ïüï8µ’­ìÖ€FëÃk/4!P‘Hå`”K;ž'® õpM?Þ¦RK«A£šQ¥,cµ u_Ä õ”,Ë.QÞ™®ì¼>G³¯ñÁÊk´Û Yv…Ȳ)#=7þ$Yvž/÷ÄÓÌÌxñËW-À¡EQD4mï’†FÖZ}Ͼԓ¶M3ñëÍ|° ‚†–$ÚbÇ3ÌÃõ ÐxP$ØF¡rÕ2ôIµH׎Æ;L‹Íœìܸ+»LÜÊF£§×ó-Aµq>´<ó¦–æ»÷²C)Ï3̓(Äþ{„¥@ɺÕh^†r÷§'àÉ×·R´„7².„ïw t€ÂEym\OT»™ƒ¾gí¼ÿ£\SXsá2­‚,ËØÌIÄÇ_æûe—9ò×Wãûe§°Æ«<ãÛ–`óο˜´'–ƒWTfUôEÎæº–ýË1k¢#'[ÞšÅò]ù¬¡†K<­a.§-m¨ Ï]ïne,IȲL¿g#8{+tëNÌ®MX|«Ð+L!Þñ|Y#»äå¶ä®ªT©7˲åËœzYëÇ>yåí˜0±?ѳ–óG«Ž¼UÆÆâ5§‘eYöfäÇ”Õ7ÿàº&+ý…ÿÛHÙnÝñÖéxg` Où›.3»º¬åâ¶üäöâܱ~e¼{²ΨEñT—nMçRmÈr¦>÷ø _lcÂ^ìÐß¾óXÐ=•n=nÜĘÞu\®«XÌ×åwZôo ›y‘q[s¿×Eu2Gâ-yÔ½cA¯Èöß0² 󮤑úÅ>êŒþ6CæŸ0g{ç¬ &d]ñ[–‰1á8?›«Pßû E{…2úíe|4µ +‚ü‰ú?=˨Q= W4$ÞÅäuVüt ²²d­¾>zô’„ÞG¯GVýI0Øá­EJ³¢‘õÎüäW÷¥'z³Í¡ûOñ =áöt_ (ÔI¦{TUUçK‘ý“;ç€ÓjàÛOVb/U›a•ürE–+†ƒ» ? ÐÈYA­ª*»>fC4Ó=§˜3x À–Ë’y_ñ5™9£Wíž(ŠD¸Vâøu× WY#¡õ.Á€îõn8?mM±£Q|å¶ÙlÛÂÛó!…V­Ãùdìbþ‰÷àÙ~EðÌhxR/ä»y§f —|ù†Ôdé÷µÐ§íãÉ÷Ó(¤áÃ/ÖR<˜ñ3Ö‚jÃl6:þð„…S饎TÒzQ¦D(q‡wr6¼&¯U %þø¿üt®<¯u*‚¿N¡õ°fL{õüʶ¢˜§ûϤe@ÒÈYyS|¦0c{*_µËCáNÆàH£XývøÏœÅ’iËc¨1°Š¢dè.}w"÷Y#¾c½Mq|a0Ré­¼Ò¯6Š QÑI뵜O&ΦAëéÅØ×ÛäÒGIIvyûWÿβ¸",H”jÙΫ¾åÕ™ûønX}çš$nËŸÔêÖ€¿#ý”PÞZp„6¥Øvxªü¤Û5n’O¬æ¥^O“Úf:¿}Ø ðÛ×i߯1Fã?|28ï XcüžïòO~E“ Üs_Uü<Øy"ŵìRVÝ£”àãv¥øàÃω»æÃ?Ë¢(gÝ+Šâò>§E%¡ ¬~k2±Y™=i ^_"âñ–ü/m+%}ÙþÇ?L\vŸ uh^½æx†O‹aÄ'Oà•ÐR±1o¨Žõk´’„G aÞ2½ÞY–±¤$]N°^‹Á`F–=åÍ¿îÛIÍÐ}Y–o[÷‚Bg¸‹!qg¥Û­©LûÆ3óófn×¹°YSYüûž<ÏÅÙ\¿ðÈlÀUUÅnMã³±¿Ñ¡ õò±Ê¦Fñ""ãïr^ {Λ qÍöi]^Λðð u)wöymw²±¦'ð믻ùyc,]úuc|ì>Ý|…Ño´¡lò^Z”Ȱž¥s©Ÿ„J2Az0¤eÊ^¡o׺Y2:²ç½ÙŸàÇ'³¦!"µ4²/m–äÕ9ki9²&í«ùóãïiüBÚ–w¸y=|ˆ­¤i“sDæ…j³pñB g¯ùÒnh%fOÞHjëøÈ0cîn<[Eº¡Œõáûõü™2w?‰‰:–Ô¿ñʽ·+wSº™×ÿ7˜¾ {>žÍϲ=ÛÅœzYꢗ’¤¥tDvÈS_·/ú…÷×$ðÞÔ„fv’«ãŸàÕW—óìd=ËFÕ¸©Žeï@﬜y¿U’ìÏG¿üJ·úmé?¥?¿Û*ǻǒO_aÒì_h4èK¼ÿ¢³¼¡ Fòû·I´Ò‚´´UÌ|½“ëTÔú/xgä{”±‰×›ç½xZµçÊseÎVx§ŽÛú¬;æ-®<þ%ºýA˜öÆÁ¶;ÿަì°Z.å½YÝbÿe=•Y]Ý— ÷ÔêÞ’+±8ºsg åøÒåô~?‘zÆ3ëß‹v!Yùé¥{XzÑ@ŒÑ†ò÷\ȨóJuJ»|'¡µ›Í‡¤Í Ïî¿SÏŸO¾ÛãÔýìحꄈ!:ƒ$û@^²±KZbtÅùnVg‚ (CÉ"«0ü[ôXi8t½«ø¹}®V«ABF«ó Z%G¾m¦xÞžÇÛÓ†5i6óv…1qÀcxd3*ìýŸkÌŠ¦—Æ—¸Ø`ÖUöC+j7óù˜%x¶ê@ýó›4˹Ãêá!И³—8v)sãÙ“d!jþ:βSª|1êÕmH›&íiéõ×^bN/–¬ÛÍ ÿk„V¾Œ¥¬ú¬ý ¸6èOŠ5yšOS'2ëN›mh»r׊¢E«U5 QÏ?»}þe¡ÕjÇeÇW¼ÿ=cçౌ/$®ØÏ–TPï£S“Æ·{’Ö9>ÙÔ”æë/Ÿæ×k!β¹+¿Ý’Äö}ç\½OŠMê½r:¼7²¬!§COÚœŸ}ÄßÊcä| ÌéÇXºúc>EïF%réZ©NXõys®û»Ü»fdÞX™Ä{ßàùVåÜêj©'G’öá«$ðšÓØð)ZšR_gzþÅ_dò{±„öoé<¦ó ¡LÙŠxzàæ;ºæÓ‰ORËGæôÏ3?Õ“ ¥Ãhö\g†” §Jé`—:}ÿÓ'xzÈ^>åƒoDS3Uw2Ž4êõâZ‡ÑϦÜ®´ó˜¢xS*2¢qÖãÈ]’`Õ¢ Ði¸zÉ’ÄÁÍÛþC*ã¿-ç¸^Òt2–3ÞW¸dÑPÎK‹¿Îÿ…OWÇ3vÚ+$,_ʈ9*][i¸⯧EÖ`·Ú0™­˜LŒ–KÛ)…} IDATì-ÑzÞ²Ûò‡ûÆòÕ]ï24«Wìʉóßvkkôýò8®hªÝ[oøÂWì5ƒOsköÊV}Ø™J~7^¨Ð+¸Õ}wWŸe~²Ô÷¿æ¸®ï°Ñ.¿}оĆí/¹;»l0žÍfÑ2È#Ã3Šv;7©{ 5³¦~¥lK®Ÿ‹:Éïkÿeù6ÞüðEž¨ê곤]ä»e'HHJ#.!…ã×-ÇüÀš ?Ê” áâ«IªÜ„–gO³é¼7§~‹'¨V€3ýüè¾OHmÞ` ¤}él»ßžî …Ú É‘ä5eS®k_þê¬à—x+¯ÀÇx÷÷矱SîF¶F+æÏoKo÷Ð{eĶn=^Ux»Ò_LؑŒŽV«Úþ,¼I~/núÏš]hìŸÕ gÎçfßS$§lì¶tÞ{ïGöŸÃ¬ Vµ’<Þ >C‡—%ÄÃq_ÿçºpîø9ö¹Àá£'ٴуŸ–BÖÀ”×¾`c¢™âû"k`ÌÿÍ *¬†½@·ŒÆT–x룗i»i'߯>CïNÕeøáƒ™Ì¹äA§v³úêxiTîŽåü’åk¶æ—A™{Ðø2âã—ðùäOŠ{i‘e‰æ ¦ùMdâR‘ÅÓº3nÎA~PÓYfw2^ãþ½]ã|Bë±âÛzwEî™Q…je›çÕ*‹¢aøOѼ?y0ÍBžŽrO?†:ûoFýëIçþ½ðQd@Côaã¿LÛH1ˆö§Oóמ‹\¸Ãõ4&‹ «]E#iµ2z­–^ÞÙ¹+ÿŠ!wC¿ƈ,;þåÜ4î^\¹;Áù¼¶ßü9Ìiø,±Ý7S7üövŸ»xå8¯OºÆ—{{£Õ:Êh³9þI7­ûì:({þ¯% Zj ÏõYùF%óÑH^Áø…†P¾RiŠ„úQ,,Ð #̘t”ÞïZøajSŒ[Ö²äËàW†±Ï½eÝïÙ§ù]Ñ} °!:uJؼy3½zõÂÃÃÃm0êÀ)ù½†náÛùÏÑéÉ 7½~÷//3`àR†ÏBÝÆÕjÅd2±dÉ·²I<}s‘Â|oOfV³ E—aà˜íhtùkŒl&/òØŸ(ß ¹[Ld­Ë´žE妛tùóSÎé_¯Ê(§„V›e<¨\Yÿ!D¾ÁàJ·uÂÓYÚ—aM³uÆŽ ˜L*K–,áÍ¡]nØ™MdÖ±R.*v$î¨+ÏÇ«Sºß¬Y3ÑC —‡Ä] Éʇ9f¼ÄÆ+&ö­þà¦×'þ—Ö£úçjÞ 9×h-'eÃï¬tÙ>!Ôå¿9•=Ü-ˆ%=p2¾r×zäŽ#ÒJžŽå¿œ²ŒÓ y)ÖîC†ÜÁý!µßdxŽc™SUv»ëÔìÚ#‹Ü¡1’ÏW§ u_Ä AâÚ(h‰ùË"µ›Ó+Ÿ×”­Ï`wíS—º˜Û½=?ŠrÏoùó_N‡1R˜½õ™20›y$êþNuB (Ô‰@ ¸?d~‘.– 2 +Î’7^Ò@P ôoáX¦À%†ä™¶•…d@  ×E9㥜S6J±ûdŒŽ@ ‚¡B©¬-JœI1m2‘‘%…t@ ÑÑçP‡A’}¿£Ñ(¤# ÀÈ´C\bHôz½Œ@ ‚#W I&GÒ@pO©R¥šËo%? @ Ü-òr~äC"bIgΜB‚û@™2åó<žikÜ0†DÄ’E„çO  –£G¹µ)2»!eÖ­ûSA  €¶m;ÜÒõ :ºví €ªªnÿÙņ*@or¶¡7n¼å4D IñçZ12¿:´ïpÇid×ë"™ àö ’üØ"†ä>Q«fu6lXèå°cÇ*V¬xK÷?~ü®èdf72Br¾P@ ¸=ƒäf6…ˆ!Üw"""ò}íåË—ïúó C®ÈÝ %‚[7Lna œ{adÜ žžžn½"bÊF î̹mƒDÄn—ž={ÞôšåË—ç:–]çòËÝÐI¡×@PpÜ—›ñ4 –žäù·xxéÈtªªÕˆÚ+$d×9€””†Ê×_¯¯ož÷ÜÍ’‘|âg^ùö: >LrÔAN,y^^­&Åt²¨L@ ¸I›[ 1$æ´CLýle.ƒäúµ‹œ:}’ÿvmcËöôœ8—.eý\®™3¤+v1$ÜT :vÎó}çÿÂÀ0ïÇ"†~“¢i/’tô§ æ¼;굉ÌÑybþá ½ Šzݰli·°ß³MBD ïM‘|½eRRMù7fm6̶mÛ ­S„ï›M¯oFÒ½”ßH óУ×ëò¼·M§.lvR6ýIp›´ ÐSÖÏI’ v¹ÖK#¡xèùR­¼5øCjü‰w{Ö`þÿ=AÌ Y¼Ý(,_y¶Ž2bÅ%fí©ƒ^¯@§Ñ€¤¸-wƒ·Æp®Á0.½µƒ²zñaRvR/ÇS}¿Á¦B¥WªÒ*}xÎ’üpOcH$™ÏÖoEã)ý÷>Ý«ðÓÐ?™81ú†é½øö» ¯™@ ܰͽç1$–ÔÝÌ[¼ŸÄ"ìú5³[…3ã¬×ýÄâˆN,ž>™9b7Êz“§Â¼hм%[Ú|—Uçߌ^>ÙË·‹pàk&ýxŠîL¢‘Ÿ®ðjœjÁöe9ÏŒIG2l -?û“¢Þ·ºÜ—|ì'~ØYWŸ+ë¸ßjÅ¢J¢Õîg ‰ªb³Ùð«Ü—¥Oó¿/v1ìÍa`³aµ92T$¼(á:™ãßNe——èṠKê^~\z€(ƒ…ËK øzÞê T»‘Ñ£ßwyTt’‰®Ù~Ë^ VCÿ÷ÆO´ýj %öéš½Ä# ø~{†©à¸GrtG¾Ž"¼ùë·\ÜÎõC63 2 ’Ôè¬Xñ/ÕFŽ/ÜÉm°~ýú|_Û¦M›»þü¼bHÌ)GödNm4)@`dg•s½ïÂXv²-ƒµ•(n ’‚!ÑV§Y#f»Š%U‡¼ Ž 8ü0?fXUúõíG„Nfýâ/‰i׃¾ÕC#Ô”ž‹¯ä$,ZGŽy œ<ûì³ù¾öôéÓwMÆîÒ°™ÎóBûÞ¤wüˆÎ+Lj ‚»@ÆüðõLb-6RNïÂ’îÃŒ_P¦Ï‡$Ú$Júy#:IB£óÈ–~ FŒp ~ÿ ­Ÿg"S6£í† ìê!‰O§kF ‰ÍtŽ¡OôÇØq]VŽÎŠ-ɇNƒ¤Ñæ:wÑdçT€Ëñ›Å”öÁfº öù¹ >|8ß×Ý’NÞwiÈ%èÿú7´êՈ᠂»B®C2éëÙØLé]¿5’ìCßw¦Óº¼¿#¾DÁÍV“0_߯y«?_÷èGÈâi_Ö—µk×rhÒæ=>™aÆ)|tú%æ¬GP¸WFçQ’þ¯KëÞM¾òƒ[Îs¸NC\¬é–ï3ÅšÐè"„†=¤§§çr-6y².&“ » v«‹%÷‚hV›Šªæ}N  3wc°;üdDeÉÈg°ô‚´l3³´dý੼Óf¾õnz÷É…S®ñˇ]¥ã“¸:{9”eÏÅtJ¿]â{õèb‹Q¶lYâwí!¥N|e‰Ö½›ÜvŽ+ûz°ýØuèrk÷%MÆ# ’к»ÌÎ;9~ü¸ówÅŠS÷ N—ç>6ªª"I ‘e%÷«!ËyŸ‚ÂnÜé^`·C¢ZX<¶3N7àQÕhýûf­Ãè7W³/j aM?v¦cVUìf“KºÆØ-<÷y¯®j‚¤K¦$ñʼnkt/{žO£U…é0[ìØmfŒF#»Æ½ÈïW1­B 3 ›ªb51s1c2ÛQí–\e©Ø·—ìÀøjù,OÝŽÕxŠÕ«W¹v@º0Z4­À濯Pæ•rÎôbvŽgÄŒ(ž›1—6bçv©_¿>F£‘óçÏS®\9 DRR’s¾Lý¼›1$ì»þÚív‡W$íw%Äùíq É:'òlWócSܵSÒ(ÍŠ• Hß‚$Éø©ÇgóJñDí…t[YÍ™NΫá0»½BÅç3°œ#е\§wùèÔÞêùÔxy.ü½9£—I:¼“Ý;ùñR*mÂü\ò&K’K ‰5íïH$(8ˆs»ãÑȺ\e)óÄK&!Yþ?Â2öÏñ+Z’ˆ€ã|öÙq—k=ü›Ó¡m=l¦ Ì11½}içº*:ÒINNž­\…sÒU._Iº¥{$I¢I“&hµZHzz:W®\qžÏÔÏ»Cr#ƒDUAUíÎÊjºÌÌϾ$-5 “ª§ó;eÅNÀ@ƒ¤ÀbH<Zòן-‘$0e[XóÊæ1Ä”{ƒ×Kû¹wËxUeä˜4ížåšÛ7‰æCÖÓïåÏyp}жÈãë–òÍìÝ„tF¿PïæÉj¾ÄSÿGjj*&Õ“n£+ä@@ÆÖË»k.ò}·’TõëF¹O÷Ü/oãÕhÍü³>ï-ÚbëZ%ÌΙ…òúmܧ( Íš5ÃjµrñâÅ{ÞáFoHö¿Ç®Ù:½3NDãÓ’Ÿ—¶t¹_ÄÁ’ÛáŽ&Ã3–öÀ# ÿnr,fV¬õWüÜÀu©¬Ö¿n¥¹‡ë>6Ù€Úï°m×;ÈY+_z†teæì®nŸ?yÓ$}VºúÀN¬þ³ÓMóÝcÆæ´ÎåKhZ¹ì ¯=qdæÆ3õŸ®BÛî!6›sçÎȳrÆdŸ÷ôôö¹ãÀ,@ ’Û0Hîd/›ìh¤¬ûŠÊ8÷¬qX.0¹YªzÀx+ƒOI&ã­¯êÕ€ï'ïaíÉxŽ9vÃK¯GÛéßSCgëä`ùòå÷ü÷"†$ûË“s4aˆÁÝ¡@×!y˜)Ùz$Ïç㺢µ_º­i{6mÚ”ïk»wï~×t23›E‚ ÃD nûC"Ü.™FÆýÂl6çŠÉë·@ òoÜiû) ’dÇŽBà²îÈý`ëÖ­¢àã®ÅnLX˜XåõN¸[1$‚àÌ™ó7l¿E ‰ Ð"ôZ  ¾ÍÍo ‰FˆL ÁýF$@ î;"†DPhz-߿РB¯ àÛ\C"à¡A$@ î;"†¤€Ø²ec¡*oÓ¦-¸< ½‚‚osE ÉHÛ¶€ìKëf.YŽËï‡ ×¥×U¶nÝò@êÐk@ (ø6Wìeó€wÞYÆÈ£c<¬ùÁýG$÷Ñ“Ý Éþ[$@ (t‰ˆ!)8ŒÆôlÆ.xÎÿ2“»]}`uHèµ@ |›+bH@<<ô¸zF² »Ýþo{ïÈ»F£>°:$ôZ  ¾Íë<X GذóàM¯³Ó0XìB`@ xhÉ}&=fŸü°'ÏsW6ÊwÞ4ýcžbÈÏgnïù×6±ëjz¾¯O‹ÞÎŽx1õ!‚»‹ˆ!)@L&9ãGlª•½3_`¤yŸ©‰5ý8S?_ÀµmG‘ƒƒ™0a²G$o½9 Wº6»Šj·bµZ²ÚMÄÄ&¹\'ë Ôe]b¾ÊÈgÆÑû§ß\îUíé h×ïÁsù¶o—4TíuF=ó.?ý:…`%Óž•ÈÐ*bH p#bH`<<<ÈC¢ oÊüß¿âÉvƒù´ü:†W¾ÌòßvóÙԑд9=3ðö¸¿yï­AÎôvnلɧâŒÄÿ·–¥ÚP‚ªw¤EÄ:vz‡ÈbEF‹1sÑélXØÌyÿ¿“^æj§ÿÑ,ØÇ%Ÿ±û>âxºyÖÈf"e;çÖ);âåGX>²vvSÅ%FÄAáF¬Cò0VZhýð)¶ò¡p4ŠÍ›7wõ®$KÀ6—ckÿd«„‹©X”.\H'n×J¢ÓëÒ¢;h½*óÇ ¸¼aÏÌɺך~Œ‘¿\æ‹ÍåÊÏïã7PkÔl¢ÇõáÛó)¼TÒ×å|ÍWßá\Ë79ûÚ?”öE àŽÉB@•¨ªŠ°ŽÒ¾}[—óªÝ”p96ö“ilЂy^åæü÷áV>õ¼¹‘pm×t,Áý¨å£u9nNÙÉgR˜×º6ŽÎû̆¹lJÕ ýb>Wß«JHx}Öü1#×ý¿½óiÞ:Åá ±›.1fe4ﮯéÞ8ŒLã G"‚Û3HÄ:$‡ÅbÎ/9×#ÉþÿÃg¸–G¬C"…±ÉÌÎ; MYE ‰@ nD ÉJÛ¶„@ pƒFˆ@ ÁýFÄ B¯ àÛ\C"ä@èµ@ |››ß1e#à¾# @ ÷C"(4½‚‚osE ‰@¡×@Pðmî=_‡dݺ? •`Å:"@ Ü;îha´ÌN:÷޵Ü÷MãßmݺEhŠ@ ÷Ò ¹“£Ñèf/–Ü{›<ŒFIöÿEüÁèC@ (ø6·@bH<<<òðޏ#³‡$»A%â~D AÁ·¹²—;c$ç±‡Ñ Éëo@ ÷†;Þ\O’ gŸ-I`·?¼I†)"Œ@  Ê ¹““ÉD^ñ"™†HìÉcXK”%\'ß¹y`7pùJ"!E#ðÐH÷X,R.ƒDÄ<üˆ:‚‚os ,†ÄuºFåÒɃx”|Œ@bü‡©òãTÒ8þï.¬jPÒOç¼?åÜ_¬;ù=ÚàÂöœL·:ÏGÖnJÅ@oeËÑ|K¶¢gƒbXÝ8/¬†‹Ä©E ÷ΟóÇ’r™X¥ž9¯wõðˆøƒ‡Q‡@Pðmî}ÛË&íøA¶´¢ÏðbhƒBðVÙ…O‰¼¬§ø{STÆÕ6ìR*”ò õê%ôµÒ¢E tqWð(Qœ ½Œj»Î–ƒI´}v(çþápjÞՖƦ?v zúâ­Õ·ûOV¬XÆŠËøå—¬úc ›ÿÝOLšÅyF±°mÍ4b}@ îw½.Ù¸2ñûÖ˜å ‰?º¥HSš Åf¹NÌ5#%‹9NJ’”e`ø—¯B¤wÔ¢4 F±Ã™ma/Ñ‚Æe"iÓ®ÿýö ‰&[®g_ݽ–´2mhP9É®bKOèVbÀ€ô¦]Û7§ˆæëV®!Îæð|Èž%i™Àš“vI(„@ ÷ƒ»C"yWå±ÒRüC±g|mc"Œ:]aK‹&Él´x{)ØlvPí Z±Z-dš—¶mÇ·R[¼Iåß½±ój_o†”ttß²tnnaåÒ¥ToҚʑØ­‰l<™J§×k¡$ž'ÉdÆfW‘dJFúrêl"ZÏj7𨳳ù/Æ‹n)\·ªøW­IìŠåxÕëGÂ5"†äÑDÔ¡@ |›{ßbH®n^ÂÑsFÎL>ŠÝ&ìiœ´[1ԫ?ÅÙᘑ4Ȳã$EÑ"vTþ9q†/UæÀï?ò÷Q#ž²‘³>ÅbÉòŠÕ¨Äñ­`{¢?5}eR¯þ‡êY^œ²8ÒÓH€„ªÚ1›Ó4f3è$HIÓQÄÃ5#ŠR’ò[ù'5ˆÆ:+&{îÏ–EüÁèC@ (ø6·@Ö!É UU iñ"#ZÅfWß/Ÿ8ß2å >}ð&)H”Бlµ’tMKÏ!ƒ©UÔ«ª°xâGTxí=êøè4 u*¢”­ŠåâIvJÄ»T{$k»ê.s\;»‡“&›AâªóT©0=ÛþŽ¡GG-R-B“@ (@”{‘hòÕÌ;k'ÍlÆA¼Á‚¿-ëzÔjS—¯­çµžuH°&r`_F»Œ}@ IDATJ’ÕNòõëœ:s‰ëV$…é"˜­$¤Yñjˆ%5Å%-kêN>Ÿqcº cº"%«Ð±Ïš)\:aʲÔÂô˜¢¢ñ ­  ` ’»Cb³ƒW©:´®å—a8غx>:„Ýj$PíncH´¥Ñ¦üˆÁ`fÕª+d.;’dQ9°ê7NXÒ±ª ëŠÒ®µ³ÅJ’Õ†G°kJV«Ã °ÙUdÏÊôèQ‹ËgNphÏN >ŨTLæÌñ㤳¦€$O vK,m5¬V+"†äÑCÔ¡@ |›{ßbHd Ø)Ä^M%Áµ¦ˆÁ®bQAsÓ-ÁZ‰˜²OÑ#(Žcg£iöxU–~2ÊϾy ¥šµ%@Ñ ÚÓ8w>oYCjª U§AQ´È Iö§Dd0v{"Ë—á÷9 ˜ž-Ë£(Ù>22«h4þHOEAÄýÊzj•8±d9Ÿ Ei/T ¤’/»ŸE~¼8$«yæ@ëSº!ûÙµt ú×#6Ësåb-Ša·¥çY&@ ÷Ð ¹“£1w ‰Åæøßœt•‹1’®£óPˆµØUUl ç.áÒ%©—ÓA#jÅb±`SUC,gNÆqzÝR(ßŽŽ‘ Ž!ݨv»–Ç[=Ο»S´NÎǤâY ËîM¤{Âb¹î0A<¼ñ ôlX,Yª¥Uåô¶³ì×´"Ür »=…#;kcŒ9ƒÅ"bHED AÁ·¹C¢Óisyd„„E«°këŒ+ºÀ<îëQ–¹td?W ¦ÿoï¾Ã£ªÒŽï´ô^Hè½I—Þ‘*‚(‚ A°­u±®ºêϲºˆ‚Š}mˆ"ˆ‚(Ø¢€"=ô@BH¯3™vïï ÉL e&÷ó<<ÀÌÜ2çœ9÷sÞ9':LhZz½Þ›( èth'-†Ž¤K«Þœü~.îÈFïÎ%ÁFŠuzüÃ[1q\!‘Á³,èõ-è³¥ûL 0ê±kÛk$×Ä·ÀfËC¯/»ÁŸ>¬®Hëø(ríyرcü@ú„šH:îD¯×U‘üƒúOêP!¼ßçz-‡Äý­i1}'peã°&¡i0vÂDÚ¶oQ¯Ça- Åî¤÷¨+hܺ !&Ц’“œ¦i´w 1þS²O]…Ç£tÍ-#[Ó*ÒÕie¿Ã‰¦³8›½û³ËF>õaßòÅ„N¿Œ¹o}T£÷0å† lØnaÈŒ8 “ïP˽/™²B!ηsœš¶q:ŠSsgéóû*l›|ð@…Çž¬ý{AUKÃÍéZ+¤èøAv¯þ|t¦† ïŸÏa¿̸i*»v©ÑûØDßfþ$%$UF$…D!„ðB@r69$v»½ttDUÕÒ åԅܵHk-¯èNçY½!ct‹l4þúk[¶é {wì­l¹ÿ-ùõŸÔ¡Bx¿ÏõJ‰çzúr# ¾û•гð$Y€Nw¦73>5âC…²õ—Ô¡Bx¿ÏõÁ:$TŒÔÏŸÍ–OB!„8ŸÎ* Ù°á7)A!„Bœ}@r¦9$ƒ ½¨ Jò¤…BÔ¾ÏõJ‰õ‰´k!„ð~Ÿ[Ó™B!|M!„BøÜY­C"D}"íZ!¼ßçJ‰åH»Bï÷¹’C"„BˆzC!„BøÜç¬_¿VJ¯¸ØÖƒ9’C"„ÞïskC¢(J­sHFŽPÉ=l<—‘çFù;oذ^ò"jAÊJ!¼ßçV—C¢(ʹ¹—MåÁˆ$ç; ‘rBq¡9ë›ëU¸ÿ_H@"„BTœÍ:$ÅÅ·à eù¿Å9 IÐPU­Vu%¤¬„Â}®WÖ!ñóóÇsd¤,0QUUFHÎSP¢i:V«ºRVBá‹>WÖ!9ìÝC±*–Bq®¼qœÝ?±Õ~)£ºGùì¦ìX½Eš‡šÈÙ½†G аc@´åONÚT×cvñ#ÆÓ3Ää±]Û¶Ò¢Ï …¹Xò“IL3Wz¬¨mˆ2zÆzs2™ZYͤ©cÉrF¨Ó‘øåÛhÒŒù)¤Øœî‡""6k^&Eé;Ùò·?Z‡z>ûöÒº}âE˜KFS4§™u+§ý•7á¯X(´—>šƒ¿þc§Q oæ±U±°aÕ&&_Õg騌Bù„VÉ‹¨9)+!„ð~Ÿë¥?ÜsHTgÛþN͉Ãé,É#â“,Êï¬üI#§Ð†Su¢˜:2¸_\µû×Ô"6mL¢}d¿üÁÕ}áÔÀiKaõê¿)2Qd.Fgô'$$” @8ž|’€ˆÆ´oÕ„øÈxš5m@Jj6‘­ûs…þwÖlÉaÊ@•w?XI³¦‘4Žò'ç·|𗉆ÁÐÇÐÔhÂd4¢wjìßÀ5j®-› ×F´^‡)dSojMnž½ôœW&î'¨AC"²Ža+qIûs5æ–#йY‡a0¸ óÉÍä8 è÷¢õà!Ͳ–EŠÁ­Úx7?%긢µ‡V¹çæH^DÍIY !„÷ûÜšæœóùMƒàPôzƒ½Á@Qq2JcÚvÃj×Pt:ôþhÜÐÎñT³ÇhÇáí¿±7'€{a ¢ ˆš@ßæ´j¬ç@r:c­:ô¤mûVÄÇÇhÂaNâ³7?¢×·1yH[Ö"ò ,—È„·èǵ=Ñ0 ÅËÿ˜FAn>kÞ~›ä@BÚ\Îí£cÉLßÍ'Kwqéeá€JAA!þþ®à+?;“Fx¨kJFµçšZPz ³ªì6‚¡:²Yw°ˆ+è1÷8…βçŽü‘DƒA7aùí#6éÆÓ ²ŒêÖ“Œ%K ê3¼L‹´n!„¬s(º@.íÙ‡˜èPT§Š9û'Ì:"#M$ЊNíC9‘c-™âQÉË·{lŸºý6'úѳi?~¿ñãÑjÀåD4¥{piÙ®éEñ§U‹F„úëÉ>‘Lšµ˜-ß}IA›+™Ô·%Y)‰¤åT~·ç¤p$'˜6qVÞ}ëuŽϧy›ôéOÑÜ÷yãXÀ@ÓKFÙ8˜¬£*½z÷!>.–#;þfðåã 1瑹gGÊÄ|âOÔ€NôŽ àXBÙ°•Ӗʶ<×õk‰s?}›ÂCHw›"Ò›ÑÆdcu~(tÅX%¡V!Ä…œû))EäÜÄw[“ˆöãdFa]TœÅydeUº¯‚¤?Y{@ÇÄ;¦Ò=—ÊŠï72vLo´ãd95òŠî¡™®ó´æüžÂxîÕ 2“œéyþš3‡Ã‰™®7؈fñ&:õìCƒ8ï~°…i×_F^N::˜póm„;¬`4‘“‘ŠÃá š’““qhNM#-ñ ™™v¬Y_óÒl=v‡Zz,[±“ T‡‡ÃIÆÎl›Bqdo³•¾.{çŒ!—Ò#ÜÈîîMÉ_õ Ú¤é8Žå{œ{“X?þX}’«GAbÉ!9sRVBáý>×'9$îë¬Ûz˜±·?Âà–ál_8›UVPtz c…ýœÜÿ;¿nË`ôÍ·Ò#NÏáÉÄv¼ŒÁŽŸY¹j cÆôÇ ×a0Tþ+åŒI„w¹Ž8ÿ"rŽáTä墳'‘dmHçf‰,_“ ØPmE|¾ðsŠÌV ß/úÍj!¼ÛPzŘ0Œhšƒ¼Ì“8PøþÃ78™iexÿø±Ü;½-æ¬ß˜¿Ðƒ÷Œ <€¢UGžÙIP»Hì…æ²óÒœüy0ŸF㇢Z3Q"{¥;Àòà °`s Š ÀšpœÀ¸ö,…HÉ™“²Bï÷¹>Ë!ׯGŠ4—4àè¾ýŠ 3vªðZÕv’µ¥0tê j̱GK¦&vÉ ÝZV,ý†îýÑ©El¥ÇËηÐ6kV•MjèM éÛ¿ !Ö•|¼!Œ¦Í3æŠA4ŠÎáåyë¹ýŽ[(**æÃ—žgò­·f· jPœžBj~‹}‹.8 ]F^OƤ-›G@ÂNØZà,\„4šŒcY™³dÔ$ÏáÄ/ÊgQaÙÈRö2í*ÝuÉü±.¬b'q¡F®ZGÃ=8š[6’b6 :2ÑýBiáB!.Hç% Q}šñÆëïÓ..€#{rÀôþA€ç”ÎÔ€k&ÞHçv‘¤:B‘Ó=¤PhÔiׯàÛU«H>1Ëûµªp¼ƒË‘Bœ¡Îªƒ$g'²¬¨;[>ù’_³\ÓMFEcöìÙX­œz?>û v› Mƒ«¯žˆÎÁøI3èyi{^þ×£4oKþ‰cN1ã×?‡¥‡ÓHç0=_ït0(ÈŽÝí-êu:PMeÓ:‰¿ÅÒ˜äÝ;±»‚¨X¬G·²#`(a¹™e£;':%Eg’Ö*„â HÎî^6§^Wq ’'ÐRç #³˜VáYü’ÖMSq8•œ…ƒ= Píj¥Çчµdòõ1ÕÚѪ±ýG3=žìEöŸßÑklåû?uqwº¦”zO›DSâ<¹‡¯—m`ÐmwÐÌPÀÿý€¨Ž}:¸Q~zöãg€ý{÷`W]9$æü"öäY kˆ£(‡ÃA«¾-X¶b1£oN–ÛÏ€Ã:2OX ÚõÞU{f[éz÷t®m¨§È-/fÅÜ—Y¿*››º«d–”…9³]@4Õ†ÝnÇ=g§6u%¤¬„Â}®—rHLåòGÊ/Œ¦§qCo?=A·é P­y ú*†0@WÕs®K;­ü,WØGX«at8²Œ÷?üŽKÚ·!¾A$a!¡ø•[-›ŠÃœH‘­1?|¶„ãEô6–F~ '³2~Gþäõ—7réˆÑtˆñ/=–zê¾v 8‹rÂáÇM C°KÃ`ÐÜ /Ý£–òÉO‰LÐŒS¡Ul‡PþÚˆ¡w Nr¶‚±“›…’sx'Ü’"عu)Ac§›êIJO11´šjÅ`ÐW(kÉ‹¨9)+!„ð~Ÿë•{ÙTŒhfå»Ï¿ÂØq4Ã[…‘žRTa›Úüqçq"×ZÉqõôq5—÷mEÖ‘müðÝr¾úæwtÊ©óQIIøƒ•ØéÚ:Ÿ·>ÛYæÊñ£é¯çÈî¤df“Sä ¼IFöiEÓ°4MÃf¶àpX±k iV6þðamFctrÂê(=C/#„…ØP† Õ‘Ï^³JÿnQX3,•–·Bq!8«’ê§-ƒý›6}ÆråèþØ3Ž‘esžÇ·¢Ö 5WM@˜¿Bq1ÄÄèÙ½7ÍYÀÖ]YŒ˜:­ÃHÚ³í{ö³eí*ò ‹°;œhšëW@z½ëß±L޽‚@g!ûÖ®`m†½)šX¥›1ž›oìƒ5'»ûÚ º0]q%‡Ž(tiݘƒ‡£™šÒ;f+K÷`Ôè=fZ7¢0ó8jù BÎøñiÓ ›ž}Û7aˆH¯PIÇmŒ!„¸p’³_‡`¤4ÇA cüÄItêÜŒ¬”#¤exå e¦%“ è F²ru%9%Œ½j,[†p4áùZwÂÀ˜püýLõzâºSÌ©eðUUUI=’Küˆ«¸³U;Z„¢¨f\>œ 9x,ÇmI÷SŒ´låONQ>ÅvW>KÓþ½Ø·|1!Ó†2ïOjô>®¿vë·[|ó@œIäX킾ÚÔ•²B_ô¹^É!1AHù›êi𕽻÷»¾üëtÞ- Õ‰Íêt;®“ý ‡ÑT×¹¨Åù¤&ç×häE§S(H<È.Eš+;$qÿQPtè*»ß6RSl¥ÇÖ4fxÿBŽÄ3㦩tìÚ¥Fo!!7”~-üIJHB§Ó•–­¢€¦)µª+!e%„¾ès½¾IÅ`¤îM+hg¹ôº¦©g^1 Úbqê§cûöš-;ß)FÇþ’€®4¯Ö%^º®”«Bˆ * 9›»Ýæv(¿‰ûßâ\¨XÎ’QsRVBáý>×+9$üñ»”¸I^„”•BÔå>÷¼çŒ9FJ[!„ç„NŠ@!„¾vV9$BÔ'Ò®…Âû}n­sHE©u‰õ‰´k!„ð~Ÿ[]‰¢(çæ^6B!„ç‚$B!„ð9É! i×Báý>×+ëQŸH»Bï÷¹5]‡D¦l„Bás!„Âç$‡D\4¤] !„÷û\É!¢i×Báý>WrH„BQoH@"„BŸ“qÑv-„Þïs%‡Dˆr¤] !„÷ûÜZç(Š"¥'„B¯q=$‡D!„>'9$â¢!íZ!¼ßçJ‰åH»Bï÷¹²‰B!ê H„Bás’C".Ò®…Âû}®äQŽ´k!„ð~Ÿ+9$B!„¨7$ B!„Ï•æ(Š"9$â‚&íZ!¼ßçV—C¢(Šäˆ‹´k!„ð~Ÿ+9$B!„¨7$ B!„ÏÉ:$â¢!íZ!¼ßçÊ:$B”#íZ!¼ßçJ‰B!ê H„Bás’C".Ò®…Âû}®äQŽ´k!„ð~Ÿ+9$B!„¨7JEQ¤4„Bá5䈋†´k!„ð~Ÿ+9$B”#íZ!¼ßçV—C’—'9$B!„¨C$ B!„ÏI‰¸hH»Bï÷¹’C"D9Ò®…Âû}®ä!„¢Þ€D!„>'9$â¢!íZ!¼ßçÖ:‡DQÉ!4i×Báý>·º’ü|ErH„BQwH@"„BŸ“qÑv-„Þïse!Ê‘v-„Þïs«Ï!‘uH„BQ‡H@"„BŸ“qÑv-„Þïs%‡Dˆr¤] !„÷û\É!B!D½Q(Š"¥!„B¯q=$‡D\4¤] !„÷û\É!¢i×Báý>·º’‚É!B!D"‰B!|NrHÄECÚµBx¿Ï•!Ê‘v-„ÞïskC"?ûB!„7¹Ç’C"„BŸ“qÑv-„Þïs%‡Dˆr¤] !„÷ûÜêrH ód!„BÔ!„Âç$‡D\4¤] !„÷ûÜZç(Š"9$â‚&íZ!¼ßçV—CRT”/9$B!„¨;$ B!„ÏI‰¸hH»Bï÷¹²‰åH»Bï÷¹’C"„BˆzC!„Bø\i‰¢(’C".hÒ®…Âû}nu9$Š¢TÌ!ÉÉÉ‘qA“v-„Þïs«Ë!1› $‡D!„u‡$B!„ð9Y‡D\4¤] !„÷ûÜZ¯C"9$âB'íZ!¼ßçÖ:‡DQ)=!„Bx{ì!9$B!„ð9É! i×Báý>·Ö9$¹¹¹’C".hÒ®…Âû}nu9$K¡ä!„·$‡D!„uŠäˆ‹†´k!„ð~Ÿ[ë’¼¼<É!4i×Báý>·º’ââ¢Òƒ™¸˜¤¦ž”BBˆ:HqÑHØ·½ÖÛhZuÏV’®æù='„a@"9$âbвe)!„ðZçäçç—Îó$ÝwNO¦úo™µøæ¨í7MùV*„BÔþþþX­æªsH:vì,¥$„B¯’uH„Bás•æ!„BxCµ9$B!„ç›{‰LÙ!„Âç$ B!„Ï•æ(Š"9$B!„ðEQ*æH‰B!¼Æf³H‰B!ê H„Bás²‰B!|FrH„BáSî9$¥÷²Q”Êo<÷óÏ?H‰ÕS#GŽ‘BBQg¹Ç†Ú\Ø4MCÓ4@+ù7ÿ¾sªnNÕdž ë¥P„BÔ5Ê!)... 8<ÿv%Ô ÄýoÉ BQ×UÈ!),,¬2‡ÄÏϯ’ÑÏ`Dß#åG«$'H!D]f·×<‡¤²‹]eÓ5ø> ©ìßB!D]Uë×FPþ:§( ªÔ¡°DêA!D½T£«ÕJeù"å)φjÏà³/VrÓ´›ëôjmEi(iI\°¡Ž™R! ‘!„u]…’¢¢¢jsH<§k4}z?}X¤t{öž¼$’¼CoóÔë{K· mqÏÏìxÚ²§óÚk¯1eúm|‘¨Î\vì/~ÇÄ‘ =ö{ÓMS9´ŸÇc)?|EÖ­<ÍYÀ¢ÿ>Ä»Û&íÃWßÿΫÏteíª×˜÷ñ·¼2ÿ?ôiPrÑOᆩ3«}?×½õ)£N7š :yÍ™‹2Œ™½Ϻð·¾|icç00ܯô±EOÞÀ¾ObÊ#OðÐ =(8Âúß¾gΓ׳;ëKæÍ¸ÿè¼4øuþ1w;Kê!­X!DýHÎ$‡D8˜/¾è]!‡$0@á›/7#‡ÃŽÃ©¢iNlædÆŸÂ_[Vàtj7¹†Y³úŸö7ìXÅ{ª‡Ã^Ø™;ý ¶¶½ï\¹+Yðñ†\qëÏ{·qÿMϰfåóÐbÚ´©UîÿýgŸä¤¥‡Cï©q:\—ÏY|’Ÿ¿^Ì¢EKØ›ÆÛ?,åÒ`SÙùœ!‡e?³¾Iaîš¶¥ûJ[÷/,ßÉÝ Öp{§ˆ’WFqcÇ^´r&ñÜ꘧<‡IîœÅÑ‘39t×4÷Ó#9$B!ꣳÌ!1’¹à~îúüPékzÎ^Ä=ùðßÃÁ|9´ ƒžÀ¨HòÎá‘Y&ü#F`0]—ØN—sU`¶?:'dUy’Ñ]^àéÑÕ!ªtÛã«f±äD/~[p~:…¼¢­7Uúüð;ßeÙø÷ß2»w œ+®_å1¾yáitzcéöN½kШàèß|ñÅB/_GT·L¼woîK¨þÜL‘¤o{GÔz†•´|öŸµDtxˆ»ºÅVxý€û?åÜ~9„‰áf^ß•Çë}œ;’!„õÆ9É!i3ýmVÞä,Í!ÑLüõÁQÿ`!mü]£ ‘žã“ùÛȱÁ{–nÛïîëöqoð©]@ud3|äÕ,ýy ‘%yzca—ÒÊí¸Ÿ¿ò£_[…_IžHƆ#4^6õ£èü™Ú=ŠV¥AïgôÞ4ÕÊåw¾Ì¸«®fþ·/pIÃà*^WÌoë7×jßú"Ö¨#áƒýļËm_…,Î0Ó~Ê€*¶¬˜3¦g4¼·ú6V-„¢^;ã€äÀ‡wð…®Mƒ^¯-áÆôB–;‡eåGXÂzðá[§gSï/ØÆã÷Þ€Z2M´±ªQ'‹3ͼÓ2´ô‘5_$ÒùmÏ rhë 6çq¡(:^Šþ4¹±š#—§Ÿ~ªVû~rÙOŒ÷'ᤅˆIáeïÌš‚CÕˆèYã}EôˆÄüá~`ˆ´d!„õ; 9ÓuHZN—ŸnöÌ!) ù'£þsß·}˜§/oÀî÷äS·Js.r?bùò¾ÓŽZòü³>„Ÿ[<Òôž¸»+pæaÓttösåx¨öL>ÉŽã‡xý§þ‘IdÏðå÷pñu IDATyh€ê´—¾Ö•C¢ 9í8N·±.Š_~Y]ëBw8ì$;ðo`,=®ª‹B§(äíÍÆqIXöcŠóÃi=R²É!BQÿœõ:$ ¯Ê;…züÕQHP¹,}éRn|õŒ|ŠÂ[–Ò©ø7îú]ϼÕCKs4ÞALß1Œ¨šëù¡#Gâ64áW¶­!šÆ&8bWèhàØ÷Ï1ò ‚M¦Ò׫¶Þ:”G¯'›TzÌ £!PiIM¶=q&={sT÷6>ÒŸõË6b¸¡m¥ÛØ5<Ö$qæØÑ›¹«ä!„¨?jCRÙ}llE…LüèWþÙ0ˆ´ ·ró—NŒÁ=øô…¡LœtÛ™<÷;ºW¼¸«Îžÿ5… ýÿ±í¡Et+Éí2bd5S6pGç(þ³hï_ÄS/oãöoç–§3ŸÏþ};'ân౎®©{á6>\¸¥Êý¥Øôòõ0‚æ PÕ>‹õLN§]ˆ‰Íòár·÷6«ß>1‡÷~Ãýâ=^¿oÉ£Lÿ ï¾ÿ¸t푼}ù˜ÂÛVFdùx!„õM sHÝ÷—­bÛtü\fn¼×”{elŸî„ÛSÙ¸q-oýï{zÜþÑ¥ô\7¯=AË{ÚUZ?B!D½ Hj’CR\\1‡Ä©il˜?›‚ #æ´#€ƒÜ£0ï¥Yu$œç}ÃÐÐÃÌ™ó#?mÆÄñã™æ­±M*jÅŠ©ô'Î•»Ö\Åó]k¬”¯Ÿ-[63räiéB!ê¬ÂÂ<¢££k 2Ìãb§iv‹Õä²üGCHM’AU@îÁbÍÙÀ¤‰ïóþgªyy8­Ç˜2úZñ%=CL•$[·n•€D!D½ HjœÔZ–Øêú¿ÞÏ]¹dW}°¡†ù ey3Sø>x~k’ xéšÁ5ÞnÍç1â•÷¸4Øè$º×‘BQŸÔ(‡Ä•£P’$ªª¥ÀS?EA)ÏPTŸÛ™Lúó¯Zm7p:G÷¿%‡D!D]W«uH e#!úr߯å—uéѫ²Gd!„uÙY®CB¥Áˆ$u! q¯!„¢þ¨Q@²aÃoRRB!„8o”C‡iàš²1ü¤D„Bᇕ    †9$B!„çš{‰,"„BŸ“€D!„>W£uH„B!· ëèt:òóóÏû«úIjm¯+û¨ÍóÞÚÇ™¾ö\Ô¡BQMš4ÁÏÏõƒšÒ{Ù!„BøŠä!„Âç7bÄÀµû©%Ù«ú·ðŽòå¿qãFªûœHJŠºS‡ªª–nëþo©CßÔ¡ªª¥ÿÞ²eKµu(9$>PáSÙ‡Ix¿#t/ûê>'R‡R‡¢nÔ¡ªªþhš†Óéô¸8 ïÕ¡¢(5®C™²©cºÊ"zé}ßJJJÖí:¬,qJNý-¼_‡5-{ HêЇ®ªNP>DÞ¯“Êþ-u(u(ênÖ$‘:ô.UUQEQj4:%9$>vªüËwzÑ×@±|=IJŠºY‡ÅÅÅU”§¦l¤½«ütÍéêPrH|ìÔ¼gmç®Ug!9¹VB#"1ê”:ùÞœÖö'éØ>¶Þv„µ™»–ü©Cá»:ô÷÷ÇétzŒŠœú÷© £äø. ‘’ ؾŸ¿ãt3a-‡2y`KÎåÇÌ\h! 8€š„9)Û×amÑ–a¦ Ï9¬Çøs{ú4%'¯¸Òí í#1ß^£óº¤sç ç8Š’ÈÐ\³¦lÏO!ÝØ€Fõ§éxwϬKóxÌ/t ½s7LŸJºÍéñ\£ÿÇì[Z—þÉg è>éFZûëÝzzÉV…&îUÂZ˜Kž3ˆØ0cå# 'ײSíCŸøJ:ÍŽ#Ær ©(y#;/¥”ÿõ™ÜòÜý¬¹þYmî³s(N_Ë÷›£¹f|§ó²©ïšFRvTÅxÎú²¤¯g·Ú“^qµ:VÑñßÙЃ¾Q~õ¢Øda´z¨ðøf6g„pËÌûh”±‰‰¹5ØJÅf)"'3ƒ”äcܿ۷±ù÷ü¶aÇ+¿_òiΪ §³,ü óç·å+9Yì¤0yK–,aÉâ/Xøù"¾ýá(Šc7¼€…ŸáznÉT·/šw°'ÓI```響¶nAñ(ý@€‘Í›7Yn”¨ˆÕ+6¡hй}«r°|ág¬Ü“S±Áí¬[±¥µü‚£{°ô›Éüùó™?>¯¾8™í»Øý÷6^zãÍÒçî»$Ÿ½I…Û¿þòKl/´yŒ\KþŠ®}–§ÛPjÆ—\;é®7ŽQ#.£w.ôìÝÑcgUð:mi̼þYlž…¹ë»ùL»öJzwíF—N]¹lÂ-¼»lWéóú3^÷(™Ž ëÛªÑ~ßW¤œ“}ûþU–m;Yëíò-ä?¯®®ñëú~©%íœq—ñØÑü*_+õ}z-{“7\ÍÀÞ}èÕw“§ÞÆÇ?ï«ðºÝ³ïàº[{ögöLž›>™ëï|<·>VµàÑi/T(÷šKïoæÉiOÖ›²—«íܵ5ûËN Ïä»i6vë¾]ÁÚ¢aôo×ÀcTÃiKeõê홋(2[Ð !(Ž'§шö­šÙؘPRR³Píä@¿öm8¹/G6­akF!V{16«›ÍN@ÑLÙMÓh܃qý¶²zýq¦Èä6 i‘Í^^Ä=ÿšE ¢'cÝ›|ž3š'¶. f<ˆ8T ¶ÙÇŸ,³€MëÖ2dôåhÙé85ÐT+k×n :&†¬ô“œ*‘´?VRØâ2zµiHÖ¡ØK.®æ“ÉrèÑïØK£~ƒ8šeukñÒh+öÚ¹¢58ª…¯KùUãØ7/r÷&ÿ’@,´ŽØív4à¡{ïáÔ8‡%5mˆ»ÝîDÚíØí®Q¡Ô5¯sÛÊ.¼22‰wþ>É]£\ÁZ`_¦ßCdDQQQësëU3¹ì™Y8ívœåÎkóó·’zùlúéJ·èÉ)üçû$¦<ò/f=߀‚DÖÿö=s¿–鋘7£#ú°¡¼4h.·ÌÞÊÒ‡zœ¿/©^®Ã˜‘ 9ñò.R¯ÖsäðaØONÔ•üsb³ _2OXå¾víÚÃãgõ-Ï3ûŸW ¯á¬¬Ý¡j¹ú¯Ú“<Êók‡îGa~.ÅÖ*·õE}ן•fMæíMÅL{ôqžЕ`GÛ~ý’¿‘_Ö?Á'O_Uö>2ÓHIËÃét}ª4µˆ¹ÿ¸ŽUé—ðÑ—wŒVúÜ–ÿÞEÚ˜ÿÐ7ØPòXÍeŒÊ æs×Ü¿Y4³›×¯o’CRÏÔfî:/i'?®ÙÁ%£of|Fd;‚âΫ¯ä·ï¾ãÛÔ6 t)1®Ë“ÁЀ¶zÓº]KâÄhÂiIæ³7>¤×¸Û˜<¸-N«™ü" v{1F£›9c`'üÅ:­ÛÒ§{CšÆDä‡Éä_@JñqŽ7ݦ?7öŒ£a˜¥_ÇV ÂÈçãoWÑÀZHÒÞ4:ïcÕŠXÚйE0£k À SP­ùd¥ç’g+é„ /'‡Â”hjÙ·{£Ñˆ¨Ž,Ö,âÊ{b*Hê3`,ùqls2qC¦b^û!›tWÒ̘åQæq½z“ñùR‚ûÝLQŽµÚŽ°.ät -®Ïnmçêxsfà•«1(À{Ÿ, ¤äŠµçµ‰<^hÀhtŸbQÐ¥5ó2ÓV\ƒíæÏy8Ôm(רŒ±£\O§ýŒzˆv.à¡‘Í*I–ú&•·~ïZºßÔ5ðÂòÜ¿xwu95šÕ„¶—¦ƒ’¿×|zÛKøé ×ÌÇ9:pÉ3×Ñò4ÓFgœÏ:üaÉB&%‘””ıÃ{È;¼‘ënoE«V-hÕ²Ú•« °d.æŠ)ûØöÛ¿«<ŸqýæígsËÿâú‚–=;Àãù¤eÏðSÀ­Ü6º‰ç(AAS‹HÜ·“cIÉ$'»Î-))‰lg{-|·œ3›¦æoÂht ùë Æ çëËú®/9$É+g1Ý1îZø+wtŒ(y4œQÓþEç&v.Ÿù/ŽÌS½c\Á¿Rò¹ÔëA³óÁ¬ø:µ-}•vA·rßÏcËS™·¶“ëµgp¬î÷>ı’tß´ðÓ{õú&9$ gq»·mᯃY7êLŒ’ÆO+öb¶•}¸"Zv&ÔPÌ_.¦é%]èÑ£ÁzÚ´jLX€üÌ2mVþXö9…í¯brß–äœH"=Ï3Zµ¤eãÛÍ‘çjÍÉ_ö 굷É"í[ÄûóÛê“ÄŒó#Åì¨óí õÔ¹|u{»r£˜&]ûñî—>´çÕ«x$ÿ솞—>{jÁƒýñøÌû0ŵ¥GŸQLZvü=ïî£Á »ÝÚB!‹ÒÍt˜:°ªïJ¹¼w4½³êñê–ÿû?ÿ 3²<«˜;ãƒ<ÊôTº^ìß·Ÿ†z3÷Ü'9‰IÎRiÖ<ˆ½»²Yý÷zâŒeÁLÄ%W2 Ü1S~~”=ú|<¬¡+Àj@ëîƒqus‚sßäŸóz³îçûK__”²ŒaoµcÅçãË}~ P5Ãé烤¾«‹ßóù6«˜öSªžŽÖ'†+?<’ŸçÜÂK?ðÉê…t ®82•ð¿ýÄö¿ã¬5ºg¿êz@"9$¾uú¹k?Æ_síº·Ãšs­q3Â"ÃQ­)lÜ´ &pòä©ä7¢#]õÁÏßDŽÝŽ[Î"é[ŽÞå:¢L…$dV:ú`ɱalå‡Ãb>í<´ÓVHffí8Gò£éÒ.Јê5šAssîàý¥aLžÔž"³ƒ¢C_±5CESËrªë=[3“8\’ë¡j®?IGŽ`Ó44­lÊæTÞDF¡ƒ€þáØ rËÎSs²1!—Fã¡Z3°u#J—À²ƒF†8_¸ˆ‘#»F³bÚ¡95ò=Õ.ÜsHª F¾yþ&ž^rný/#[‰áªƒ±¦íáÿ¾ž¯¯y‡îvu„»OX¿&¤¬-Gq¨á]Cjœ¿Ú-‚¢÷b·8? Ôá¨ø@>ún5 ‚³HHH`ß¾ÎgÍï¿`Nú/—ßòí;´§yl)íÆòòC}iÑ0‚ŸžÇëMÿC*v{ÕÓ ÖÜ-Ld5Ã_Y;v@ПSJ>ãàžCb/ÜÃ?&?Ï=ü@d¹}Û w¡3F£¸WÕawÛv½›ÆœYc|Vßõ!‡ÄaIqv]ÃJó>*¼÷.a¨ËR`w¨SP50Ÿü„§éB¼’ÁÇßâåkÛUØnïI aCJ÷{&Çëù“}8ý½z}“’z¦Fs×Fc‡öb.ù&oN³à´gPPP@ZZÙOBõ~þ˜T+é©éè ž?Ë+pØ.[NniG…dW1FústßqŒ °å£†à§TüÆc46eÐàö««xÿ‡0âbƒ½0[¿~“\½‚ÁidÁG›ì?Ž.®`BÑ•å8èÜ¿¿eáa KIgé–~ú³Ù4¹MÊ!)p:ñòCµZJ÷Uœ¹•L»Jw]2›×g’cuÒ(ÌȾUëh|[/’óË›€0š#½©Fcq•a]É!Qt¬)?±páÁÒ ãÕ«QU•Ï.Dâ>ȽâQ¾§¾­ºç¸*eßdU–>;…g—çðäG?1Åý›T—.ôè¨Ògì,œ÷­Ç_§duØ4¤¬uÑ+ Í{kvj„ÓšTiι HÎW:­ÇY¼hIIÇ8vôGŽ"éd.ú£ï³vdwÚ´îÌ—]M›6mñ7ñoý›{€Ä¯nä¾½ÍhÛ,–üßñØ>ÞÔ¿Ú²P홼8m&ºaóÊȦ•þ,ßhP]é~¶¿óöIó¹¹ctÅ xÑ_˜‚{–¾Ö3‡ÄÉëwÜϱŽÿÂh4ú¬¾ëC‰.° :E!gGú•@änËAg#ÄèúR SÀЖO–Î#lÇÛŒ¹çuý)=2žduØ(¸4äLŽÜ(§5©t?¾H$‡äR”¶‰ï~sÿ +:ž?¾Ç7”†#®bH”Écd¤´Ó5(˜â wVýáòÓcIýÅÛŠ™1%–_?[J‹ëo¥µQ­tŸšj&#ËŠêðü–T”—Çu?M„¢¶r«#ãÏ®¸½¹ÀNd¿!Œi€µä½÷.ƒGÆßvjÊÆÆ»ï}è±]^G~‘5°¬ƒ9²!chc’wïÄfumKH,ÖÄ­ümF4Ùnßjœ(ºPPŒõ¦ Du¿×»»ê~ñÓ×s|ò‹^ü8¯Ì}?Ý©)›šï/óïç¹wY_=;՞ͦ=‘¼óýÇ ŒSù{ÝJœzÓ³µëBØpNûs·©´ö×gÒ“™Q6å§Ó‡3>ÒŸõ_­ƒZUz<»†ÇÖL+zS|ýýP*:~Û~˜6­Û0¦ÏHÚ´iK¤m.WÜÙy/ß_í¦Ñ}{þÞv +»|Ë '>äÒàªÛbAâZfÞñ;M#ùyÎjºb¯Ç¿äSµò‘]sW?ì¹JŸ[ÿîí,ÕÆòëÓc¤¾«mÁ\ÀšŸþ„m+}Íê­YÅM÷xÌÚ6èw¯Oùƒn½N?-¤kHÙšN Lz²2­g},k– ±îO•É:$õD`Ün¼ùŸ<öØc<öØc<üÀM¥ÿ?õgZÏöÄøUgÆv%{ë7¤›ª®vC žŒ_ÖÑ}\FÑ$À@Š=‚ 3X öëŸòþ{o³"É@z³ƒòsË'¬*:6'*À„^¯/É:‡Ø¸†˜ ×c†ŠçiÔSœfA)ùu‰jOgsV1]§Î`úÔ˜:mÓ¦McÚÍ·Ð=Äõ«²wÛ5«}@hŽzÕìG˜ÿðD>ÈÍ·ŸV{ñ3êJך( gm©}#÷}dåã–&ÁJ}WoƬ¾ä$ü—·vfUx.uõ¿Y˜^ÄèWýy8óC&5Iç¾i/x¬ Ô6ØHÁÁ‚³>Vþþ|üÂÛÖùr”³X,•Î[—ÿ?€ÝžÌþ’„EÕ–^ºýû÷×èXþMÑ!r9ï¿÷ —´oC|ƒÂBBñ3–õXºp(¡ŒëИ¬Ã ÄìÆÆEóXÚ¬1þ&šÃŽÙ\H¿á£Kç'-yvE±8#pMh´ìÒ~'ágµ iðå¼9ü¯ÀF««ÃÑÔ"W.ˆZL²ÕÁÄ E©–\4µ’?æÂÂ*sH"Ú‡»;]ïÆØívrvmc&6 !ûp'ŠË.ÀÍ;…³cëRLc§`Ou-–|¬ˆð¡ Qse*»™ÚéòjZ‡gâTÉÆŸã©7–ÓãæÇùê®ñ¥£Rv»]I:*É!íÏOÿÛÌ]¹rM,'ÿ䉻 èêyÜÖ9Ôãµ¶ü­üanÍ3ïĨÜÉ“óô·œœó&ƒX€ê°£nhJê§[°ßWÖÉÅ}•™¿ÝÈk·!éÞGÛ§áö6n\Ë[ÿûŽ·¿K˜æÄnwÕÍÆ_OÐâžÖ5ÎA¨ _Õ¡ЛHõ›rŠèlª&šiDý1þÊ5Ó¥äî!㡟óé÷?ðëoa oÅm/.äŽË/Óä˜"›aÉXÊ«ï5 id0ª½ˆœìrrs°Lä±ûÚ£©fæL¿†<ƘP}iù«Àæ™Ø4Œ+ÿM ƒVúœ/êûLê°²i7÷ óµI£ÑÿåŸ?MæÍ[¯Ã2ëq®Ðŵ6Țż4ÿ;:]õ ÿêU:eä: ÷)$#3ÿ÷Žº…©Ouáë篠ãuM9±pê=íÏøX¬;I‹;Ûx}éüÚÖ¡äø˜Édªò΢§þdØKšÍ³!©N×…uýúõ¤§§{{™âéÐ&²²ê¦Ïå“i}ü Û¶mcÇÖ" þm˜qÓ`œ%¿T ŒñÇØ;Y… ØNL½±-ù¹äää`Sü‚hÝ¢%Ù©IÙ¹‘ßv:èÓÞzÿÚöìÇ‘C‰„Æ7")!K~NU¥ÍÀ¡ôŒŽA¯žà@¦?Fƒ¬k±ù·¥}4tÊgû;S8x¤“¾Eçʇ1 h@Xë.Ø·®Ã|†,;C£K¯F¯YÈr( e£Díú¶= Ãho,ÆîÈg¯YåÊîÑØrŽ{¼öÔ‡¨|Þ@uŸ“šÔáÙt„z‚¢ÓÓæ’æ<µx5C[‡røãWXšY„]Š¿É€59‘c)©f”pƒÇ{ºéÕÛøâú2aW/¢œ'Ù—â`Àå·òéƒ(_䆈\Óü FNœÆàK[rÒ½ø.ÓïŸÏ×—ý$µéØ[1¿üÙÚ4bÝÚÛ_ùŠ^ƒ^çµÏ1ó)riܺ+ÎûŠi#ʶwZ“ù4ÝÆìáM*”ÿ¹ê}U‡ã¢X•e§x`µ¯›Ø o³íô«x^!†ýä„tâéwgdßj8@Ñòqf?ʆÝÛØ—WˆCÿ@ƒ‰‰2a00ŸXÍûH¾š3ƒÛhK·~-82‰·¿®Âσ}Qßµ­CƒÁPáî¾§î6뜜§ñ2f¼ú5]–ÍgÞçóøjöq¬º@šµnËŒ—2cD{Ï/‡±hÚ8Ź¿ðš§IDAT-7ÏÜ™wÞ¾‹ÛžYÀüßroÿXš†ù•—ÈtÜ@Li¹×îXªí8Ÿ¥Ûxqp¼Çñ¼MrHêšt‚6sÅš±\§äO¯^}ÈËËÃáðœv0ý 5‘“[ùýc"µãš. 1¥bb ì;àZòÚ?zÓ¦¶@sä—}x Âc›Ð´U[ z:4ìEØl…lÛ“Ç3fлY0]ìf×Þƒløe%f36›£tèZ§×£×0õô?‘8µˆ“'Ít½f:GEŽ²ï‡£ÆŽ%T¯#K…Ô”@ã’žcÑ)%Ij€ÎØ”¾±°4AÇà•¾W\I\‹†e§â,ßé(á\}õ$Z6¤0Uǽë14Ì¥!FRÒ¬¨ªVmœ‹:<›ŽPÓ\Ljêy#ƒqÝÒ;²WwâÿLæéÿ¼‹¢ª_ý·½¿“b‡Žq³c=ŽÖá6~þ±/k7ïÅÙž:».8šŠZáíéxrÑ&oÿ“ãY¢&ÝL«v- Ñ{Þ>Ü:œu}ž'~HæÝ+<çê2þ^>/¨VŠ1•^ÜÜ·?ºì ú>Cÿ`Ãy¹Hø²¯¹ýºÓ¾¾ï?ï!T_ùmÙã‡?Íüá§N®²zªÚ˜©÷0¦ŠçTUÅ?vß~9¡äzَǽ¸˜qPáq_Õwmë°²`ÄÛ7Hì1án>™p7šjÅ¡ø•æÐ”?nÇ™oñY%Gv™Á×_Ï(ÝÆzty™g~NáÍËŸÑ±Ž­x–€ÞOÒ/ÄèõDÖ¶% ©ÃÉ©QL§î4‹Ž%ÔPó”Õ‘_Mp’›y‚\@§7R`VÜ^«ÃQ”DÂr¿(°™ÉÉ2—»v2~Ò8Z6 $ùÐQŠÔ@ÚtH¿ÈüL%9!nß´Jß›ª’ž\H»aWÙ,”¬¤#çCʱDTc#† oOã†èt 9™®Ÿ¼Òjh?ö._LÐ-#™ûæ5*—›§^ͺmÅ\vËÔ¢T *¹Çù¼˜‹Ž°ë¿¿âSÉc¡í‡rcû²ã·šúk¦Vü6R¾6¸„1W^Råó僒¶ÝzÓª}ý„WŸåã+#uħÄW–—¤˜ð«d[§õ(ÏËæÅ•cÎ[éË:l~Ý4š×`z nø ÄÇi„sÍÛõ}&uX]PâÕ;6+& hœ‹Ã{é)L~Š´Ë> ®Šr¯êXNë13›ÿ[6Ò'í¬¶å.9$>vê·óî•WÙ‡1/-…¼óqv;Öâ³Úû÷äÔPˆÝžÍñÂìo}òpT’hÏ+y·ölŽ©bº ïŸËac43nº‰Ž]»Öè˜ÛOúÓ«‰ÇŽ–Þÿæt¤š¬pº:<óÎMÎm.¾®Ð÷åýç·³:1‡—®RãíÖ|>‹á³ß¥›¿r^òGêd^|Qßµ©C«ÕZå4[}®CCh_Þyvk“ò™}ÝðZmûÓ§pÙKó騯rÝo%îKIV~µDå‚v$Üæ$4ÀÈ®]»j´Í¥-âÉOJÄ‚ŽÊ~–_YÙ×&ÿàbªÃøA÷p#pãεÚî/ IDATxœíyÄ099Yâ(î ÊEQa{Xó‰¾Ë»tÿ>$ZOÂäp_P4M¼Û“èå]º­'arø@,ƒzì7ÁÇÀ€ŸDÔh2[7AÙH[n‚"œß¿ߤ$õ4î Ê@Ø&^ °G”wÑZ \.·IñÅM°™¾ •}áä%¬ó‡az?qå×+—2z;Ùµ…ð9Ç¢žÎ›k/3>»ìÖéøs»6þ:.=‹B@Àûq.ö¶ƒ£ãÿíÃ%2™Ü¤øÀLZÔ?,¤äüìG•‘•{úò÷'wG*×2AÖ—-Û#ê2Afɹûl…&ÈggÏ™·Nü¨EÐ~÷vŠ¿"&¾ ´ÐV¨ëìUÙw_(ô¢AkdiŸ•³qãÆ‰ŽTY6xnÍŠ»?Yõç@km»3°ºb¢NšN™aH#Öã3† àV¼1ý¿æ;ÕUøããâB–RkÆëyÜ/œÎDX¥×öE¼“HÓÆÔq¶µŽÌìϘp®„ ˜€Ác–ØÚÚ ÃU:øÆµ€w¡›"ò«8?3ÑïåÞÞ/`‘Ïô»¿ÆœÞ!Œy©sãWçÏçä/´óq¹•¯68,º‘ªÞV«£QÿYóÝÌõ”ˆt†çxøû4I¿Õ[ x¥Ë–o…¼rð^¹\"ßµÛw¨‘ý¦wäüš>pK\\Wœ8qB<&‘ÒNô=4h›ç¨)†´ú†#fÉ™Rfë_öWëÿ7÷’Á|P·§uÊöß­\ž<ºIDàGÚ:«…èËûÛS®Ç+ŒÞÛ á¢(e”×J’Ÿ°ïØ3‡gÇD!“´ãñyÌ·cl“ÎÅîèš^3,ˆôõ‚È„@=QB.#m–ãéÈKÛ¨¤Iuo$ÝÌxÇ·UR €Žù†ÎÌž[ßlØìà,Š@o?3(h¦x’#£MÞNóÏm­Çü¨°¾$ãîŸvýÒ«4!øìŒW– ŒcÙ£_g:UÀ+ƒî¦_[‘èz¦¦¦„€ètzöå¸4"=¡ŒÝZIQ˜?™é“‘aN§“€BDˆTÝ~ýú óc7áS÷;£óG¬ìa¹Æÿsoü5©†´&ôR¾ ÅÚÚšÏ-_7­cÈåÛtÆX[Yuz“¹÷<ÇŒxwÝieÏ¡<íPÀn5DZº|øðAx(ïrt¹_ß!zªbÑ"™,Ó»bý¸ëêF!S~ä~Uí«‘ö…Üɨ¿ ºêÿÊ+&¥Ï‹ v£*A‰$ñÈ­ÌÌ‘E±9Çf6¾âGx®]»v:t¨®8óçÏ_¾|¹ð{=¾ ì*ýt¶¡ëáw„¨¼keïØ%;ê)ûgÒ¦×åÞÆ¢Œ_Y€èRxíp-Šÿ¢R‚j¾«d {Çä1Š"—.]jciá\e¤ïl3x¤‹{ÈóïÕ™½OŠ¿F¶qðЮv nåjÌ1¯Ã%EˆŠ½È•Ÿ*€¢:lzkÆ–Ôᡯ–-[–RÁ©§.u‘¸Åé.·g7:ränÑø!Z¢ðþËÖVœôX~_">Uµï¨Q£F5bø`UCeJãOJS·¿“˜píÂn>~ìоmë¸L£U¤½,ê¶ïb\×÷‡×Ý+äÝú¢ý‹žn_ðå5£²ÄËËËÞ^¶[oooïååÕ˜Ldô ^é¦7¥«ÆéŠB:ÏSÝj˜á½¶§ºÌ\bW¬ÑµgD+ª(ýq‘ª<à hZLì_õ¶æˆaèkñ´J$DYÇëâE¯ýƒ»UìòÖSžÛÃ`ELÜ(jÖ µ31mŸ QJ±7SËjY]U*Í<óµr¨¾so¡±8ä nU9É11L|· Ri‚.n™½þv›S7]†ÌN×q@ƒrífBþ«R¤'BmÕçØ•ð£x*ņ8ýjâ[G¾ cÀÑ£G…á%¥¬¦ºl9—7)­îTs¿ò3kŸï§”³C·_¸F k€‘PÀâK¤Ré貺ëa¿È¬8÷¿5À ÈæÍ›+**’’’Äí­­7oÞŒ òdø‚Å©kËÈ]&(#b‡Ôw:tZ²úâŠó3¤³(¼è{›ýÌF<«ŸùYm»gqbÚÑ>ÔyÊí2¶xB²b¯óg6Ÿƒ¢ðåóçöõ‚$ÙÚ}»‹ X^•¥\…a¼ÔCAŸ†L·V£¥œŽÈ4Šßd / ˜­D§ãð1vY¼·w>ÆadÝ{˜ÙmäŠZ #(õnÍ8œ†¢ i{R¸lºþÙP _ãW–°;EÆÍ{8;<…°ÿXïð³ùïï|U±˜;Y‡Ëå[™GÄ…æ«´yH<¦ÜÁeË p¿Ý¾}oË–-ÂC÷gØžâójûRuú‚Bö…d %áò0a €V|.ÔH»˜Éí¢"‘pøòþ»–…q]w×SÙæ!^þ   E‹¥¦¦ š›› ñW:šæ ÆøßӲܭX;ÜlÅÂÒ¾~_°ÙÝjµ»ô‰ëÒ(„|çA¡¥}Q8ÝÔ?9RPpç0B OQ’õaÖÅGSÚTgËùy·¯ÍqÑÙ·nâ4Ú0×OŒQÐWsÓ¦M³Ý”¶ëƒ;N‰±ñötàj¤Â‚nÂø9l¾’¾š(-…ˆ DÕöíÛˆT³!£–n²0ïÒZT’ÖúJ|vN“…Kû‚óüý|ÖgQW¯Y…L´¿C±uŸdؽ=”ÜŠ;  ?Üa˜ž•¸sG"!eïýǧ`<!Œ?¾ºÅJ*ôkûm²|A  º )IÝ|›cô ™XB&!¢ØíU(̶0„‹¹¦÷ikºŠXaWÎsÔøÃoÔò;Éäððð™3g~øð¡K—.áááÊÊÊñ›0/Xò,0ä#çD܉pºÆ´Ñª~~±_.8w²~<ža5SyæÞGSª¬íF2˜·Î0%R$ͯ…×ÉÕ~@+Ñ¡“Ñg ìƒÛ WÛ³g§ñú4€fÿÚ¼‘)ù»÷ë<îTý/·£¿×êP)*–,Y"£©Ø%l"E[桦PFNî¾vú¤…ŠîË©dT|º›0p’D\­¾ãýY“Ú÷éÂ*»i>ühRRŒðPòäÁÇ¡¾¿ \rqÀ[ŒÏ\ç3hýee""à•ÝŽ¹žýcä`¼Z‰®MÛ’{y0ÓPÀý>büšKWª RÚ-ïi‚¡ð§MPee刈ŸmÛ¶IÛ_ýÔ2ALÀòu;®?ýˆ•˜W'Âc¶ýÎpþ,Ÿ8gÊüJ[ÿ[ÇâOW q´c2Î…Ì«óö0g·¡ªÕN™¶`åCÑ¡ók¼n—±¸U¯Åß.L€a>s€@Ö<º¹ŸÕع=<¯µ"UÿsÝU()o„FÕðgæOjënŠZ7<æ§Sá‡]x;Å+lOþé—_m Þ`ôã’ã®l¿“'·’ˆ¯9`ùæ¾Ekæ8¦+ÚxZ}Pé4YthXÜýaµ#·! 8¿<9>§À{ÉÅ¡{úýf.m`ܸö°iꘊ! ¬zvÉN½SöÎgÒâg¾>^æí ý„±E6q“ªâVsU‡¨™øÌ3Ñ¿Y÷F¢®®~øðáf$¬å ²Jof°Ôx›Ét•tf,Pt¿¨Š©„•ŸÝ½aË‘[."}&³Q”{Ͼ²ïLj…S*~_<¬:CŽp„¹ñ0ìÓ³ÇäšéS>;@ :Qq“Ô8üªüo÷ßšN›6Ú1À(Šò:±KØüÂw(ÚQ¹ëL½üˆ¨guÌác€ñêrïîÄè/3-zèïòfîÁÈ‘­ê{d"z_Pô€˜ÇåezŽ_¯FDzÒ\;Õn 8ƒ×ÇMí¦\Ç$™Ú¦ˆ›ñAÓ=7¾ÑÐñÚƒ×CÍŒd>M±jC»uôÉBŸ!€=ó[¸Œ11Ä­§ —Ë%«Ù]¼i|›™óEõ幙ˋ=÷ÙÛoôGÿÉÖ=WŸÚ8Aª9Ë¡Ã!§…Ë~>~âu}WS'íšA“N!ñ†G}¾ ]g⃧cH*2º@ Ó'=Ž›„p*^ÇÜ( 8ûpÆÀZÏB:ó‹g1V¶åI£D¾ AÆx¬š®©Àý™[ȤR7Ç^Åìb1¸ @Ù‡(½ë°aÀÇx ¡*#Ê~ÉÙm—¯<[ãìì_²?Э ‰`8i#Я‚´ -™*Úzúeš2½=>;ûX;lŒN ‚–——cZý®!…B‘x@L"uöó4üžóþÞ‹Ô»ÉI·î¼±ž6ß\9ÿlØ Û“Íûôîjl¤¯×¡g¿>ê$xŒiÏ®ÅE](™tº?1óâ± k—ý0égÖ«GOc#ÃŽzzFú:ÂÎÊi—[´£Ç„ su~Ñ»|žåh×Ë-Ic5©ÓlãJç5ÁVîG¾îººSŸ±CÏYȦu$‘ˆàsj_pÀqíà3ŽíU¥*ôç!‘šp[/ñ„½_°.û"lŠJ¿.ÊŒÐeÊæ ¨,kÇx×;Ñr|ƒq!xYø‚È›³ú¶y5i“‹{6:§2ÖzL`ßµ+®æFMÔ€Þ¢¯×‘üKÌ …ÁÁÃjFmë{ÖuDCÂþø¼òeN³ŸüÌVÐékf6`èÌ‹ƒ4hDpòÜð%ýéÓç/2Rn_R›Å#Ñ©Dà LMAòâ–LÀa² Õƒµ€ÉäP "MÆëG’Uȹgçûuê }THö§ûcÍ]7>ˆØ”YÀ+W®Œ1B d¾akéiªRe6¢~9Q¥ÿ'crçùóçÎÎΙ™™O"Þ’?–\¾ô÷ßäÔœá³Ð=øhM,Æ™%TxjGêõ÷%õè#¿ŽÙ›ÌojY,V{¹ƒ’¡"†q¹ÜƘ €" x\É©âÿÍ{FŒýÇÖŽtá=¯Þt³EË›•³¸/ˆ¯‘ÀÙÙˆÄú^-“@¢õðµ#B¦ýÉ»P-‚ŒŒŒ?›!n‚2¿}7ÄæQÿeŒ¯‘‡Ãµ—xÛá&Ø<$Zï¿ã þ=RRRä]„ÿ2&÷w'eppäÿv NK÷qä î âÈ| Æ‘3¸ âÈÜÄ‘3¸/ˆ#gðGÎà&ˆ#gp_GÎà¾ Žœù±ŽŽþù¯ûl9üîk :::ø‹ÿ:ZÔ¿†Ô³öçàw}Á¯§¯ùÌÌÐezëÃ{(þßаPß²W!Ìon<,4g¯GmÂ’‹¿G‹ê׬¿&<Æ«©ãt²U›5;¼yù¯´¶9[Ù¼´Mã]»Ùœ%/ÆŒÝø²þ8|vŽëHçðãÆûó±üãúlÜ^ÉoàõlveYQ¹ŒelÌÂćLñªì»÷Jji_·ûi_°1›Š¯¿ž"ݦ_ø.9Å3e/cÈÑ1tè ŽM-§âž~7§Èë7uj’´ „Ê2•ee\YïÐ+µV£4}ýîƒà)®ÔRîhS£J}íây“1t)Ä-Öý‹ÜÚ£/K¢ãŽ3î2áöóIdFî—?TûØt“—á³sÖLµ{¨íu/ÜaÇlëˆüžÑ¡ýÛJŽ<OìÆì[ªP€Sñ s¿ì¬d‰8Ì⨩.§X, e–ý(f¢\²ú˜÷¯‰÷"|Nþ\K{—[)V­©ï8/¾Ö-ñŠZ|ÝbÂEqÍíÕ Ê˜´¶¶–^0!úþàÁƒôôôΫõ\²²²D9˜:ÌjÍ’Ôôìke=™DPiÆäËÝ”Öí6.^ üÉ­úÆ7ÞvïèX˜ÜÏ4“)£Ð½7qïè&%óÜ:—¼S‰;¹lÑ:çUžÛû[«·¢V”•þd0Q´Öbø ýÌò1"¸¥ ,wœM„jë¶ÚíûÚëZtª5(—¿K\½då~^W§±Ø°äà-žŽCg®ð[1Û–&¶ÖýÛ¹tìûXhðÓ¢Étƒ‡¯>š銛—€:Àm¡ººššz›6ÊÄ,§Q‹m7¯f×nUq îÊ’‚ì\5EAYRs[ü_“;2|A*•*sã+ñ•;¢Tâ×S¯czý¹’ñXŸ=Ž HÉtÒQ†<ñ´FÍPxêë™øR½`ê ëULM:ΩH9{é‹tžmÚ0¬%=–¹Ê9ðÙáû×ûiÖÚ<‚ajJ t:…„ Dª¤Íõ/¸;ïõë×G‹_~ƒŒ¸ì$üÉ.Mßä¹8"é³fŸ“6Z’›—p0P"Ôé(“ÈÔò×›.`ö©:QgÓFO®.¶¯Ÿ“ç4ÚEÛqÙÚɾÿð}›tzÏ¡D–sµKCkkPxoÓ÷a¡Çno>4¨›ÃžÝ35Ò.®Ÿ0qŠAZ|WqYQŒê<îÛèW]{KdZ·HsûØàvÐÂ|AÙ&(³ç“¹„Qx=±Ê—,ùu¡óE…?•tkÔÉi­­’®mƬĤ†W¦õj­E&Ü rت¹ÞEÓ®ŸõŠ=G—ŽíÊ*½q¡Œš¡[§|"Ÿsö;s_/5 k89·ê¹ß¶ôís*?Ç ‰½¼5¶ZçïiL°‡O˜Šõ¼·¤Í/¤Z€_)À05rÝN%ÆÛþdì-îã##_ݹuò¤îú¨etÏ¿xÁ*;;Üj°ÌÔGl:½qÆAëjÕdúÁiÖ5 %¢úuÞ›(Ôü½¦˜Øìˆ5_´-#)À´&©àŒïøð÷>ƒß{¹_¢´32·;exµÊ|ýÜâšÛ-«”ö $U¤¿ƒØRP¡W(Û'&þR^6aN’gâù_"V(Šò9ßV¬XÑ`üo&›ç„;ø|#ÞNOÙÔp—Ó¢/î™ü%¸ÃÄdn²4é¡î z ¬é˜xÐÏÏ_I[ëiì8f¥ñ¢ÓC• ª4c›ç⨧à¹=Ö}L7¡w1[¢8•ωä6ê|ŠÃøl–0·ò¥×¾‚0Ÿ±O¹/oväÄp£Ö|Ö§°Þ“FôÃÊÔÌ&Oœ9Z©Z£Q{ႤŒ—€ç:bš©ugñ3¦®wæ…mè´g^À#3£]í§ù‹ŽöžÑéÛ¦‡¨¯P¯\³aêš3ïû þÓ˜è6”]qhµÝÙiÇNx˜ƒ”7›‡ab²‹âšÛ-Ý”V×ÃjëÃA¾ öǪֽ´$s¦ë§¥¥5¦L‚6nA§ç9tÕS¿cãi+¡ÊW3‡ÓëØ`ˆÇHwßÿzò…'åˈä¶ø§î:½b Hlñ·Ÿ-ë¬L*™€¨’©JžQ”û‹dk|Aþî) ³{øïfoy¶õÆS;#Õ—q!k6 jrßÛ¢cíBÑé µôÇ1~ÕÖéó(s"W ©¥¶ëJ®÷ãþF´•[\6¤T†¤öU“ŠBP Óé‚3¾vëâÊ6y0ÇB´å„Ùè>ÔYõ‚F@$$¸Å}A¨­¹Ý²zAé ºŒOæ@,³&'ŸwÙ×ü‘r[Ç¿~ª6ÑV [éUÇä¶€÷=`ÖlAw·¦m$1óÞ•Fö]ë{ !×d®¼keýx¹ý‚¶m°DàP§3Ø„'[Ç“ p<ò–‰‘êmKZï~”4½_+} ‰ø?³‚æûÕ㹕ï¡Ó¦…vš´mJGÀø•/Pú0U* Ñ_¡SÚjkw1Ï/ãlކEOp¿ßOos<ùܰv‚gI—ù:úi€¢ÎD>wm›ß…N’–àG\s»åØ4h‚ êJI_Oß’ƒ®”S˜Kþ%ÍCÀ+Û8Åön»¹÷×ô“[è7yTlnç )k¤=ÿ;aotìVBnü<Ÿ“ç{#oÅ‘û˜€uÜÛ~Ó5äÚÓõBÕ@“Áz¼ªWóŽä§¼Ö"™§©’-É®|ý*ËèÒ)Ûd¼ð™S%üŽè4`TòüŒ#Û Ú!9›³X£…÷­e™K’+§õYsßµHŒ_åln®e ñUž“t؉‘†Dï¢O#ACÜâšÛ-«”ö Øl¶L°_P”öÛ³óSçì›°ùº†€óûÎ3ÿÙ–•·PÛ[Qî¶T~çÞ¹ýÁ»kÛDÇï0 pÑÚ~bÞ½PïGÄó¡zõø=l®@ÜÄøÌm3ÆaÖëF+‚H"û¡ûðçJÃc7é!¿NÁE\LPTÆPU&Û¬\+®›-„Å ¤Vzz2öÎÍ£‘Ü_']mÖÆz¼óCqà•k]33u0nUi~Bô>¿WfD›S~åÌùù0…Ù%måb2²x—ùêú·m;‡®<'ô%$¸%|AqÍí–î ’ÉdéÁW¢”é ^]ã¸øÔ«É+Žìrêñû%»¹ËÓ+ôÆÐëﯚÙJ–8ë‡ã. wÍZêç>Vú‰È»£ËFÞõ:p¥¯Z}{Hø‚Œ‚+÷x£oîw¥×œÑ|ˆáW•þNª©tºe¸{÷©ƒ­MõÓÓhMÂØeee\šÃ‘БÂ4*ýó~pp•ôIó¾TÌÔ5&¥Ý‰ z£&öТƒ±fŧCý¬·t´´Û|ὉZ­“Ò¬õWçhenXHFžø‡/ðŽðžUÝaKJp·í`ÐI[x ÍíÕ 6çžž^¯^2&¡Ë^ŸËT=¨cÓ¶¨‹üÛûÞ´ŸiÛUò‘—LÀªPUëf~»õ˜=к¡Â?ˆŒù2x±“~ó É­È»ÿyaiÙÏJEAI«Ãà±ÖÕÝ^ñËY©›|eh[<ºùáØ³ñËë¼Pß0Œ´eÃxož=É)aj´×ëÒ­³2±VõONé?ó‚P‚[œ¬¨)3⟞œÒ¤Úý3Èx_0==½Ád"lQ×SËBÀf²‰ ²náùl”K Òšà 6™ÜÒšÛ-ê_Ãßü¯Qt?ôv»ÙN†¿Þ«(ËŒ8÷°ßŸ¹AüóäÿPs‡þë>[¸¾ ŽœÁ×ãÈ|1ŽœÁ×ãÈ| Æ‘3¸ âÈÜÄ‘3¸/ˆ#gðGÎà&ˆ#gp_GÎà¾ ŽœÁb9ƒ› ŽœÁ}A9ƒû‚8ræ¯ Ä§¢¢¢bzÕä\‰‰ÿ\ ¨s%¬œi\Á˜ßÄÅÅe³ù»8ÿþ– ÞöÙ­{·™¡©Œÿ5zûž«¹;oØÔÍWÿR©þïÔ,[>’¾`BBBƒi†^„òQîqœÈak&L2¸îaݾÁ<)úJï¾£(:88®IµÍ8ííMˆyp@WLÍoÕª=¶ éTNE9J’Ô—Õ«{F"ç+˜:î”jëvºz擌Çô©­ìí-¯y%ÍÚ ëÎIDATW'Í¥À÷TJç …³­GÏöÙèã:J\ͲêrtL×YÖƒTøï/‘º¾ÉþnÚµ½¸ÉPÚXìÕQ]]MCCC™øÁÁjÞ¨þе –âïúmÒÁ‘íZRU”[ E§Óéì÷ ™»;3a½lñ‰ˆlA%.ë¢äeœ‹“O¿¸­£t@sà‚;T&Nÿü¾gøv]1±½Ô¦>5@¹zY!³äôÜU%{÷®E@ê²]}]—še+h¢šeêáû×Mj+ð±˜R‹‘àêó5ËC «Y>»±«ï]¢Cí,g^óï±_\ÍÒdAgÿý×?¨Q³ì1,xå4 5K"EwìH]¨V³tïêëc«+~R3ÓýLnD†ŒŽÀlõ†O½d­®V³lùü®Ä¥#÷LxpÀÁÇmºÚéU= {,:4ÉÕ¥$-nIœ³Çrùö"=gS³~j4áw>»-¯ÊJð‹:‰Àg]¾=)dÝÜê"âj–¿¡fÙòù]}A!|ôÃèþ“´ÇºŸøâÌÑbV-˜HÕ÷;r{bâ©]aÑßG(Ò‰ ,ÜÓý<…$šÁž^VÊHDvébmŬž÷žOªgÂ’ÏÎ;û¹» EQPš°qãà2^nÜñzó†Y•_.ˆ½5F˜Ã³ó{V®ß¯rÖ¥ ÝC§bFvUã±²8Ì»T½ŸÃשºêt: è ¨<=>ÞjÃgå8 ±hg&~Æ'þK‰3éïpÞùƪkžÓÑÑÁn†ëÒé[€PMpÍÙfCG2èfzŒaç§íós¸ø.êìŠþð¾UwnW—”`»m˜áYtú˜º°EѰ¾ Èøêw…öganÆȈƒ¨ÏRЇ”pùÍúš*‘«òï)Z`à˜5&àýÜyÙùºµ`xŒô9¡é“/—çs‹ $õô=¾„©»NzôI…¡>îvjµš¥LØe(ÊÒž;?Øqîçܪ—ŽþO·Þx:ò—š%Ój”š%BVQ©5&büª­nÎä9‘ËúkЇo½˜½ê±©m{…¿‹÷ÝÊ=©Ý%ájDÁ_;ïs¥µÔ,{ö45ævêÎòzA# ŸY<]IB„‚®Ÿõ¹®£-ß•¸” °°0ìIÆPÕZ[$p+÷0Ÿ'Âc}âb=x¬¯DZ/Pé´ÌŠæFxå^Wþ¸šeSÕ,[>Õ”¸©ÇQC„PÛ»GD"IeÞiªê $ÿÕkŽZñåLe;E9?_•aBÓoƒqQTpóÌí!S‡+ˆ)G ¸Eþ3&œÏ7<›à%­^’Ùn´ÊâHî}R]¯ÚR‚ÀçäûÜÈõ¸ÛU$%ÈC˯œ½íw°Y(@3ÍÊïçÉKxq¬-™Xn7‘ˆq%ªÿó{úË1Ó¤Oúj½KÔ§(ÚC¨£„Áà¿>¾µ@‹øºÌÊ€F€ò·'—$W|lˆ¢(€òŽØŸ1Ó|P[;Ö»=ÞJ³nìs¬Ì=I¢jc\åvV"ßO/FGTw±¾`qZEÕðßòô_¶¾ tç'Ñ Öã¨Qét:½Ö0D.U"IÆ‘Ä6}ÖðJÏÍ_p‹§¬ç{j}7´36yûŠ‚]3flyx5 ÀéYÇOêBe*Œsçtè–íû‹uF\¸ÚSêN0çÎÎuO)׎šÔ%F RR‚Ÿ±iúTÄv“£nµ† AžxKSyùQPw±•Ë#q1`!T:<É?H:g•@ h™˜˜HªP&È¿Nº®¿ÆXGG滢í·32º´Vâ1‹oEíY½í‚ó¶ ¶Z¿n 8?ŸA¶=nµù¶i¯µï%%:˜»êJ£¯3¯®Zm_ðéÂ.+Lÿ-Oÿ5/ؤw.r;^{š ã—‰ÿä±>­Œû2%¾¿†Áˆ‡O·À»ëûl–m×rÜy!` ðGWLb1ò SɪK=}ˆœåÚ5Ë M˜ c]K⌺æ, 1l%KÍ’¬lîÞm¼ÙÀºÔ,€]~'  \ú,yYÐç×ÏYgï«‹Ô,;YˆÔ,¥Ô,)*ƒõ—™ÛL°27,$Á¿= ¼yϪÞß¡ý8wÆz¿"î\¡š%U½½~Çê‘ÏÎ>ôfÛ²6®‡?)q úíu}¢bÍ”kû‚ŒôÉ3òr«dÖD§™±±Ÿ˜€¹jÌxm÷ÝËí{ C¼‡·°,WyZëÖÄÁÕ,ÿ j–2‘¡/øñãÇ“‰ö “EQ .5E+@Qö¿e\h6Ê&Êôþ¢šeéݱ£öL‰ÒÍHøþõ퉃ú%^î¯B©'m‹wûS˜¼ó¦¶›K—_ïU”fŽªšà1P³žT- Üqä̿敜ÿ*øÚ9ƒ¯Á‘3ø@Œ#gpÄ‘3¸/ˆ#gp_GÎà1ŽœÁMGÎà¾ ŽœÁ}A9ƒÄ8r7A9ƒû‚8rF¶/ؘw§ÿϱ³³“Á­A¤ d®]ÿ‚öÿ+Ä[ 99Yfa£ Ä6—´¸-ñuH=’§¾õ>ÍXÐþ¦‘ë¹µÁ0ŒÏçã×m=V§/Èd2±†”eþ߯¾Ìvc0BSõ ÖüÃ¥m!4ØhuÎ Òh4‰ž¯‘ÝÀÑE(4,™íF¥R¥{A@€ Èÿg£    ŽFkx –ùÿlMÕ ‰#º’ÿfÑZ(ÂkÃ0¡¢†LðyA9S§/( —p%|šÔ-+î:¬[iøuìXÅ÷n¤ªOÛ½á¨õ‚ߢ÷Óª=`\.Éb×'#ïa:½ï@u*ÈB¼‡“ÙnBiF ×Ex;ò»CÆ Í\Œ§db}ÍÚJÖ]:Cfþã ºi5ÙÕo¢^°º$²@—Ðétª1È5ÐùYOn“›NÁ­½×2J-8³=änýqîܺY‚ÈdrèÄ‘ëòQéìûj§@2Uò.þëÌÉ–fæ}MÍFNYpìÚ;a8M™ãçä÷!Ös:‰$léF£Ñhâ­DƒØ\^]Ùïæ4eè@‹–ÖŽ. N&}?úv×ÂóãD?AÙWÇ™‹C«©á—¬™³•§HnL†dÖz— eÒìÒÖ…PéJ¦±ýÖ@Ün”NaÒ›’ܬGÉñ‘÷ìŽÍ®}œÿýSfÂ7™o|lÓ}NOXq1áÚéý³¬Û†ú:,9š ´6¶;†~rÝÙÀæÿ‚£Ë&ÎßzµÏÔåÑ×ï&\8¾`¤Áqß³6œÅ`ÿø–ÿ­Bø0ö¸;Þ,ÖÞ´k©*±úŸM ^X8z»¥*µ1ÒÚØlôiQhÚ?YÉæ(bߌ9õ1'''''ûÓ럟R&Í100èd o`¬_KDý7bÚ»÷ÖKç0zõ‘ö]‚çúyOþ©vÑßRžsqã-º«ÛÈZ›D`‚Êϳsrsss„”ò»ž9å/’±ç`˜"±No—‡¾õŠËT=”ÜYp1ÍóÜÃ…½„2BíôM,Œ°Üõ 'Ùs¶Q `êéóeçgÏ»ú4™ÚÑÿ¹×—‡ÝýºðTÒünB=YåáN¾Ýu8£½6¼®_m™CŒ{t¹Cl~׈¸käxèûÕ B’Ÿ¡Éâ•_‡¯ú²8¾“léì?Os|ÁÜ´·¨†n›>sçÏ>óô¥8-Jõ5ÇåþÚ¨l å;ªØ¾T¸U_³>|-¤[[U7‡ÑØeW;¾Õ2%Á¨Oày­-s¸\.³0vSðÝœœœÜœ&ë±›×#½Žzzô:õ¥|xÜa‘ÏãÖlÁÁ€&às¹\€€Ç/<ØÉUŸÞ“Z]¶#[¯p3Vf¾øØÅð¹\> ôþ“Z1ƒS¿…Ô×ÿ‡}Á#;Ÿ´6Zåj¤"œÑ¢9dí¬¶·.\\si.0Àø|nìÆéÇÞt8³Ã†ˆâ> áªMëI#C“!Q±ÿUfÈó¢ýel/ÐTã Ö9/H§Ó¥g…!óEѬT)×*xîíDÚPá]vyá×÷ïÞk™ËV.-ûò1÷‡@¯£â›ŒÒÄ—÷µÈÕ——¦ÉDq퓼øoH–‘¶zdhªÚ]ú 1©£Ry˜GH¿{ žÂ8Œü‹V»^‰¶'×d"Ô+× SÈd"€@"“ɵÔ?}ßvÈba Ư:WÂ4v*G‚±ýÚ¬<œE¬+.~AÊl7ÆçóÅŸË ç#š1)ƒñ+®”²º:™‰’½‘ÍS×£‰Äy@@IÚ3o{|Udâéµ5Í>D|hk¹@˜C#3€Qfê¾Ç>-þ€N«Èëi´ß”­­˜p#ùò¹A}fO?°¯5ƒŠì­#§-Øæf§¶ ¥ÆvÁ‡bž>ºã¦Çko,²? ØåOæx'Ún]/¼?¥ª ï2}݆:¿•¹•¯Ý6{ßÓV,.ó-‘¬®M‘Ì–[ùÊsûuxSˆ¶îS-ŒÎçäñ˜Z_5¨µ¾jÌü÷Mn‹? ŸS(À05SEmÕ»•€[ʨÑôfEnLPÒFJ"¯Kî¿ò¶meÚª©ª™¶füsÕo²/Èg羞““ý5ûó笜¢râ—‰¶¦ »O6¡sç.DTô|ŸÜõ€/±3–¾ÑÕ×V«øµò:óøCÙ[ ¸ßý§/E†ùn·ªo«ŒWaþœÉaN]jmÐÅþù„¬d&]Ìй‹¿v[_Ù<ºvõÅG häçÛŸÐ[RªZKÆv:ÿ$Dª6AJ_–JµôY)¤ªXã “è]ŽÇíQMÛ?jñìS=oÎìökŽ,›Í§·£75Cº6Ï–¸³ü‹4Ùäsyw_dØN¶6ìl¨ÆÙ;a‰öŽÀ%¢„â>V+³ÞEŸs¹ÝÒ"/ ò9Ô‹ ŽT}½»r¡OÅæú6žÔQ.Sõ^uT@Èáå®+ZC7E¾`Êáù±‚Q·ÖØr¹\ 2±¤Q“Jqœí~LwJÉa š d±ˆ”¶ÒEýg}Aúuzr|*ßÙ@âÀíÔïŠmg ý9•úTú-Ú3ãñrW7ã'Mj†cM áG1Zãù5*C`–° ä¶âþb³ù;¾ ¹ã_zËœŠñhéÙK橊–ú})™}jé¾M >Y×ÐdyH¬óðnÂ$|vnD;x˜&õ¶Aƒ¯KŠ[žÄˆÜ¼×\vÆõ¼¸/äô<6AAϰ˜m§æ ï*Ê¢¡ÝAWEô“Hï~`ÿB·‘¡)K,4Û ŸÅܾ­ˆ=M£¦h0C'ïD1gË Í?ò^Eýý—ZÓ0lØ0QJñ\¤³ûzîä‹IVº²5»¿%F¿5o]Çц×áw&G„‘ÚYÀf…Z[_ÿK¬ëÂ;ö7÷I¾b.^ý§OŸJoÊœ0xð`Q7)n¯õÿ°y•ÜôŽ)nÁè»‡Ž’š`ª#ïç,I5tlsKZû,bÕùò¥Ì¬ëôeîD'³0˜î"éߊ¡;ÂI²öÿ8wœ¿¶xä‰v”Úî(QAb->û«oXÙ–ëc¤=!‰ Z¶[C"‰¿#ø_2Gˆ´æé—Û­‹šº¡ÈæˆVíºËÌÏÎö / ¸8âŒÂB„ÕfØ4_°ûû#múOBi5(bkzbNå{ËúcÞ;·Êv×3%²t3¦ˆbLÖ«¾ &M‡ÒÊâ`ÀëäÜÊí2ö¤ !j¹Íöý}dU¿y4¦î2ÁÒš¿ƒ†ÅBGÇôôcºÕ±ír#MP¼Å$Æâß)ÿï 1`ÞT€©©©‰<çµ1Õ¯s^ÃáˆZÄþ€ÿÛwÐ%ìOf»‰ß‹·þÿm£IдyA‰„ÕÍ_.jKD¢ú2ÛM¸¤ÈæÄùƒÞÕ¿ Sù]_7Áo/ð“ 1u¯Óïܹó§ËóßçáÇ G©ìyAœ \_GÎà‹8qä n‚8r×Ä‘3¸/ˆ#gðGÎüŽÒ™ ·ä¦ìIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/prefmisc.png0000644000175000017500000041156113362606031016723 00000000000000‰PNG  IHDRôf3r^(£zTXtRaw profile type exifxÚ­œir¹’„ÿãïØ—ã`5›Ìñçsd‘*’ju·½i¶D±*+@Dx¸4ûÿç˜ÿüç?ÎÚ”ML¥æ–³å¿ØbóTûü×ïßÎÆû÷ýïDë_¯~yÝp‹ç ÏKïáy£æ×Í6¯s…ó¯×çóÝu^Oo7jûõÆøúFÝÈ××^¯¿kƒ{`_76ýu£à_OŽÏÏã™–Í­–÷)Ì×õçõþ]þýCñ9eW"GoKÉWocaÝ–êçëV¯~ÿÙ|\ê“ßÁËßY# ?ÔÐõó³^íüIüB}n„µ¼±…·uýó¹ùúËä_Lúù¯o¦žçsá?-mî‚~\¾Y(~ÿíë.ýzݼnðñ|ÿþäœ_ÿò___ç/sþ°šþœ³ê9û™]™)çפ>¦xÿÅuC«u?•ù*üI¶j±õÕøª„ÄÄN6øš®9ÉŽ‹n¹îŽÛ÷ût“!F¿}á»÷Ó7 /VŒÑü¼æŽúrÇ—ÐÂÂø>LÜ!ðªÿ‹»m÷qÓU¼\5xãfŽüW_æŸ\tŽÊ9­%¦w}½"QÈrÎë¸ ‹¸óZÔtøãëû²kÀ‚é.se‚ÝÝóä~9W¸†\˜øþ°+ëu–ˆ$ã°Ù…ä²³Å{Sœc!+ê ݇èfq)ùÅ } !c¢€gó™âî¥>ùçe€C¤M(ئ…ޱbLøO‰ê)¤˜RÊ©¤šZê9dEXÎ% Q{ %–Tr)¥–Vº©¡Æšj®¥ÖÚjo¾75â±ÕÖZï<´sçΧ;ô>ü#Ž4ò(£Ž6úôf†gšy–Yg›}ùq¼ò*«®¶úvWÚq§wÙu·Ý®v‰'|Ê©§™Ó?­ö2ë¯a5÷²š¿–Ò…åÓj¼ZÊÇ-œà$ÉfXÌG‡Á‹,à‚ñ^6³ÕÅèe9ÙÌ6OT$Ï “Œ³œ,†ãv>÷i»_–K&äÿ» áÿ?,gdº`¹ŸvûÕV¿‰.\ ) µ¨6}'—¬9ØÉÄ‹›¥&füÀj¨DÀ ‰)²Øõ„¶Ê$³Ö5VÈ`Q/ÉÍ“ºß–5Ÿc€J9¥Jíâvõ½÷ÅlKk#y›N°Û¤cu&£YyS­x“«“@Û>”®Jصö±ô“ï>ô¹|v³c¿8‹<Û‡‘bÙqäm×aÍ:Dá´Y܉=»ãp‡>ÓHeo&`õÎÎÕ⋉ê)Ù —¢­Áª «œNK©×½}Ì Y;Vœ-Ýõ9BÎ=¥Vòd–{kr…ΓGÊÛµ¼ñªæv°½ÇN¨'zøHHו1)+WÇÆCÏZ¦¨ïc×dÜɵ–³Kïå,>תó;ž¾\ ›ð),«Ó娼é;0×Ãs¯çNºy-}‡>ZÆï·­gD&{ÂJáìÓÉV¿}N3÷1où:`°µÆmI—}î´»´}ëQ'pîœðaæqÕ—ºíÙ)•ò}È©—j«NNÙ ônჳ¤À1à!úw[ùôšÆª³â÷´(“³°¶ƒiŒ5›#ZòÈE‹Žáâ°Ë÷ÔºomyŸ0âjÌ otm/ŒÞ÷yÍüsâ¬uùi¸_#wæÇêA‹é–ÚH˃!•x˜{ãÕ®’ ‹—šOÐK"fúÁÓ@ÈSã:iñüCbp ÞÌcæ^óðØp¶”‚ß/ qaçÈʳÎAÐ6œÇ¯Í%PÐs¦Â€žäÞu”Sž.Ì5frŒ4•LOH-©žé@ÈãÜaÀ.›;{œU^âÀ)VÙYâ"¬6rè-1·AÞPð°¼BË3úTM{°rk"‹…‰îrÏ‚õ•[i˜é‰GVŸàæ ƒ­<4ªØ÷®aíôñM’a…eK¢ü¬#$8ÌDQÎê& 99{2o˜’ÃË6^ì@Ùk“l:°—·@Íœý°Ö.®9ÛÀî ïsµêñ¹‡¶ÍÑ ’ë–ïd³¹¦œÚæˆd ¶kyãph×$: Çϼ2ü*Ô§ nY± +ìË€\žZ³,ªü3l² ÐÖ=Ú.GŽ’HÇœNæÁ^¶ Ž@Ä•X<žc‰ßŧ1¡Ü㎠Ÿè6Ccmhg¿Ý¬&ÖM8$h]/ú‡Ô¼_¢W÷ï €˜=fÓmFň ÓKn[ú5Í8¬C1ƒ¹)È7wvŒ”á>àûvæÍ÷V0¤;îš"ž;'œ”»–væ ´ð\r?y#¬{7–¯¥8!$2|¡¹F¬ Ãÿ† fë2“óÜØ³D÷!‹dÂy’Õ<=@,º”ñÏ kÊ<®Z^,•ï  ?¡âÜŒ—wɿ̘Df®7 æÈøÊQ²Aw3¬5å˜ËÜ( äÅZÌ‚Š´ŠWÖÛAÈÕ*«ºˆ8¨’ Dþƒ=\gC@ð&@Þáê§Þ$tÑŽL^£ÁǦùr þ ÜÝ(³u,[ }äàéÖhxT»×êÖ¨e\iï|ãÝØGÔº–1g:1 Bãr;ûC¤p‡(àŒ<¨o  åÉ­=€¥„å`tâ õ¬ÕvShÉ·6ºÈü2|c øÄǰ5èðñT‘QœÚ$ Ad©šç†8á‹Jûâ&liæž×†äÀÇÞGkêû"¥\~ûÑC%j ‡ ÿ'CbåŸË¬ˆa¬‘'–=( ]Õ˜˜‡"ÉM 3áá æÃo3i2 ›ëdÅwƒ“ÙM^ÃóéÄ"5Þ#Ÿ!m!O<«‹+ßYJRkÁÈ3ƒ™Ë6¸;Ù‘15Uk˜Óƒˆ®dœå{­^á:X”J Ó%¼ÝÒªàŠ"“ÛÓY˜5’[áe°[+ '¦Â_ºtP•5¼où ! Æn‡…!d˜!áJðx’[ì’kG¤7¬y‘ œ*hÿ(i¹tBÖ2’‹¢´ž'‡3µ½J+ón>…侻=D³ÀH©µ-à€4Þ¾"ÁPôãC¨Àø6ɪX*ñD ÈmQÕ5Nß´ªØ¢@ë•ag»<œL„l‚ür4ur…B.‰7Î×RÁºä<Ø(ßdI:凸˜è€€ ¬P•D†:—o§EñK”¸7>~Ô<¬©¸uË@ÈÜCê#•ƤÒÙ‡Äó|ÀüãLÄÿðPF„F‚ðáã³n?—0,3éxð~·ŠmÏMéµH@½4óGCõÎ<™…ÉeFUb°6±ùÜwBÿk‰€oC[M5à ;î=“üˆ<¢ºÔ-pæ€Ù ((Ï-™†¤jp‚¯¬*#zM[ñ 2ô+•GÈ~@Fȹˆ—,Á ?í°k¬£ÏÞ|ÚY':ȃd tC%²Pœ6°`t˜!²øÍ¸¥¦?£(ï0"±«øyð‰©@c°¤DÌ€{VWÕnôSã5â‚äz¨Áó‚4]=`g—^h¨Û .3mk"Þ«DåÚŒÌBf4¸¢db½å+‘cí>´b+î¦<•—jç@‰˜GÛr0Kà7þпaÿò­PðæÛTpÅSåanª¨Nåý¡0ý¥ú4ÉJˆ½€oVUDrO.<:mUïÈâ:Z2ù„•b´±‚v[Ħ˜G«Éa–-#AQÒø¢R¶Ðm¥ŽÓ ÜÉ <ˆJr‚ãý‹0¸+”…uÂá»!ìàÌ®§œf! ÷ŸÊ#!Ýâ?ŸÃvY°‚7trœq-$tx ´Ò‚¢*“`žZã®ÄaîVGË‚ÎÀ‰´ùØØI¥Õ~C ­—ؙ҇¼›X‚°šyKråjÞÎÂ'|ûÑ«‡œ«ä·@Áª-بó•aAP¸qE€?Ìc·»#ƒ‡©û¨Ý8Lx†À§…`ÓTÝ:—ͳ´wÊ”/w7G{[*D“`ŸÝ³¢2.4.µñhçTJОìÝäаZDÅx,dH%&$ò1XÏ3{ò–á³ä±{ËŽ¼ƒì}'³Nïèáç$ï8ÌȆȾº'>î§4É{ï÷»w»û7_ïÇÝÌo¦õ~·_£;R_Ûyr ëö xÀŠ×-ͯ{þö–\È.mñø[Izÿ©¿=Ðüi=¬m3‘J¬ÙXÐáµ óïoÔx‰[Å>TõÂX6⥿»ùg¶ùa-Ae³r3õhyu œx~kX«->ä_RSY›¯+Ϊ©ªB›E-ÃY ¨µ§ï f„PCP²j‚\›Ñ†¬vãµ×¦ÔÏeÚÕõÊtSÀVܪ):=ih¸cÅ»ÖP;*#FÞXÔ¦ºäd!ÿe*¬1ïšn‰ÊÏQ´¿G51!d$½[Ï.]dGmyE¿;Ôd1ËÞc"xšWkÓ©“¿‘ctÉà¾0;à}ÉRÌBÌDäXšáH”D+¼"­%Y ’ºâ½FÔÝ„ØÂAg7½ìCÖ÷Úc·ÁIVÁÕ½´ü¡ªgÜšä¥g¯{u¢ËÚ`Bñ7íð â2])ÒíQH“ÃÕ«PÔ¯…wÚRè9÷[ÔãñKȸ“RÞ¶?°Œ†´DÊP7Â$ ‚»’ê±å$åU“ª¨4Ã݆á¦2ó¡,‰\eýT€–«%ÑDûˆ;duSqa¥,”²ŠðeRoK(Ñ ‰È©–«®‘˜–ÆÆŽ`ü¸tYäH]Ê^X4†§,,>…€ìC`КŽoxd8©ÿcø ªÑV*,;äªF›‚sª‹M\Š¡±Ø<§>ñ6…¨¤×L36‡Ž·ÚÖ¬r(®ò\.7GlAlÈ•ª5,\ÙÔKhÈÓÓµ³r8k™_ýÉlÚ7%pUÔAäs…Ã9[]%ÂÈÂ%"¤LžCbŪ6Œ‰ïƳEkwXìJˆUˆÎØ®Ä÷ZyâØN;ÇŠmø5vweΪN /)¨å›ƒ`" ˃³dkmw[ÖµxÇÊ„Mw×>Î^Š¥nq¿Ã^1@Qg_ͳ44Ð\[ÄR€‡7Œ[‘@H{Ô[u€†¬y÷ÿG‚„=/ûÇ!¤š¥=®ÊÈðr:ä‹5}ö-‚‰jràS¼¯r$ ÇbAÊžù<·?ÚÉŇ´¿Užv”á¤â#mŠ3µ èK‡,‘Ž®š\Ò»o.Å/ëGÖåÛ8IÆAmcæ0­ñs^ øÂ‹n×VÀ'ÌóØti*A® ÜU›tþ%‹:ˆI€oYLHhåŸ;»ªkà'& £’²Wå“Ã^Å¢lš¾» ùÆ*úö»ì3ÒÛ£=ñ[G¬pU™ڔ‹ÄRúH}dn‘5ʪƸ«»ŠâÒrñ5v¢j®3,tC… åà • TÝG»óRª )LŒî2€’‰Ó&và€*ÑÀµ‰gÕ%ŸÝŽ$N€w±¦Á¯Á"* oÄ¡¸…cwG˜EžNŒ¨E­¦é…Òc²¶ÀñnÎà¤\¦’>Ò0EÝ ê¥ n M‹»Úðš—fCªÊ!ªŠ¬ÞV)Ë¨Ž­Ú˜­n³Ø­™~/tXÀh)$rà «‡£öç…nQüfg4's1_B™Xí£©/Khܦ‡Œ"ž‰^ n§ŽAuiøž•ûPy×õD*º<›c— ¨t׆Ó/Ñ^£éhQÉ\r,•¨›àðËǾNã¾oÞ>6óúìyQ¿oãPµåus÷›§¼=Ãü¢( çƒË.H+!E‚Ûþ2yÖLˆã±n^ŽÕŽîȰõ´cV>7sÔØNb,"F.<’4VIø,Œn·Ê"ƒtªm8'¨Ý¸.Ø'¬5ÝÝNºÓý-HŽÆ\ÜÅñ˜âÄZÎ>µïâY‡TFÂ@A´C°M~4³6 «ºy’š ÇÍM!‡ìgE–gÈæɺþÒE.@ZE¡´Œzñ„¡Ôæ#ÁÒH˜0rÕkÚ ^§Î‡í²vÀ »áÁª#"{DRÄØÔ¹# @‰vO²ÅÉ*Ã6n¦^:,A–öx?9XéE¢¢Šl+Ù¢¡[0JŒÌC³'¤‘+,Áƒvט‹WcÅ`ñÕÐ T·?­(9X$v¨¹b[Cu¶,l-ÚÚ^òLí±§ 1[²5Ã|žE×½Û¼OHÕÙ¸@û†Sªá¤â: 7Ⱦ“€Ý[ç‚£dÏ©s¨‘É|YåÁò‡5Šäëp޳LØ ( ‡(:ö¡æ07QÙ|ô$Q¯Œ{J¬ÐøÈ¯;‡í+Ò¸ëò½ îRŒNåÖìPänà+à¥nUMVA ¨‡®M#äAm÷Ó?ÂÙ÷ò“Gt¨îê«*89ª‰ª§²lÝ*ï°òSåÑòSõur‘¬¬‹R@z™#úI„"êÛ5íuž]#|¢C¶ÜµÄÔòÒíEgízõ«OÂAdƒ m/.a“k„”Óƒ‚æB®Ë·`¾nÍ €…B"Š]Gª ÁüÝVm«.{wc´M®àhr@ŠÙ¡“ÞéÙʲ(e_fÌ^[Ç>âGwŸ•DWT‚o:t¼H·×¤=ƃ««t¯–?»¶Lh©b:Gí¸!Ñ kÛž’öœd'§&‡w[61)9€DìA]Z{T9ìC«X´n¶E_iÿ»T5”hSêHýiçËq÷•IÁ¨¹»ƒ×ÉÉÞnßn(Q[s¹íÖNxÊдsjJVý}jWC„´ Q[· "lÕ€IÓ„s²//©Fˆùnkÿ&Ìuww¾á:ú!%6ˆvð /Ìxj7Iu&ußÖ:ê:dFµ1Ñê‚ÓnˤÊ‹ªâk…è3A’H¯ Ù–`r¥C¥Òi•A”;DF;ª=  ëVmŸ¼é”'ŽÔ¼>r{ˆ_]w_ÂUã&1¬‹ü±ä¢jàÜP@u+Lƒf¨Ñ¡M*UÏÕJÉÏ€Í爗ättÕUµGéI{·œêÅ#ÓΣ'¦NÓ¨e@ÂÅ ¿SNf<ôGYÁÕƒå|‚ (œt^"´xû®ù*»{Úìÿõâë%#³ M`¶…ËZ-tEE†§qú‹hLëwÿA}Q Œárd²„ŽWÇ%Ñ¡}ˆ)u@@ªží/ovo/Þ—T—S%Œßv5Õã`ðêVŠ¶Ùª{2Ç ‘kö#C Ì­¦•MqÜj;ÿTCuöÝÇþxIÏ<¯"Ï#êµÂËjS önz™Ý>Mî8¡$àVK—"@ûúDäžaìlºú—þæiŸKj\¼Z¹ÁGd ~¢b¸zØqà€™Ž}삼äg515ùü›õ [EJ+¹z²N‹A.Ÿ¾£®Ê ÆãœÀ¸:1+{‘}K ‰Q}j'hêƒïØ|CzôLT©Þ‹™4‹Ôé9zIlnê,Ö± ‹ŽdÕNÔ’ €-pÃ,]èB¨,<9nuµ2 †TR,U4i9ƒé ŸúF%AT÷$壼”y3'´¢Æ¦2»l'Ã(p‚¬4—”0ñØÀÙXMé{©w=Â}Q€®¡oê:8ÙPºÏ‚#Ö±Ág]Ô?‘?&ÿ©y5rî¤d ŠðÀôal*hA/mPE) æKZKŠÊ\qõöIN[úÚy°äµìÅrë¶­p#õ)’ú&Ý ÏŒfm”Avßç豸*R[ÁÊÃ5nüÕlªŠèÀM}] L5 Ö¨Ê ’ ¿je©¨RÁjÖ"j˜Û=øðbÓ4t?)Jô££:º„'pÅ ¤ðò…„Ô–$âsR‚”G•» ³ÍéAâ÷h{8¨—æiŒ['ªžŠ­TëQYXâËeJmOéRóëZU9ïÕˆî) Ú[Sñc<í!­8X!„Bá6ù ‡YT¥Qãµ·²¾öð¨ì\N¢#H¯8ÏY V‡Ç¿Ãf~ þr©äZ†¹¼œÑéÄÃf±Õuß`ÀM¼¶ËÉΖ'Þ’)Ñ–úÔN€Sò‘Ô6[0N{3íÖŦ"Ì&ò q¢C úÜL  ™Ò3$Á»wÞãõ±–ÈÏe^?ÀôV¬d-`¥MmŸ“qÈ;È ç¯÷ÔUU%†kÚšð 9§¬¦œ‘ )0½lÞþMîYö8(q­q…Ë8É1ç¡zn{ãÕâËÐ1BkÊ}µI{uú_?óudcQÓ—cþË‘²½z®‘¹ÚÇ~´cÔ¡‡>u¦g„´°›Žß-£[A"!mPóöB|<ÌüxšÖæoƒ;àzCmi*<­¸*+çÛ¥-@2tùQ÷›¥Ð&„ëv3ñØ»°í|±Ï¯ÃÚuð6ª¯ªl¦Ú¡<ÉTÍ΄ùVß5œNUC²Ò–™J¨ó§ÑßnÚÕç¯SCê¥X`ÈUU¤Aðª>M8ç "*«÷ Ÿ닺:ˆ~{ûkHÙhÓßu²"Ñ£«ÎؘGu£f piÒH=Ü!j;ò íøè¤­®»Çí»kŽ%Lä/ÄT¨ÞMÙšJrÒÉ,ì$vè~nCJhw.“ ¥ "3ÀÖq8Þû«N¨wæÖðTIòÜÕa@…ªMplIò{³ê'T8tÌP)®«Z­Ã"M–8Á]“c!žZ²qûcsKÛ¶:ÄpòyvÙTÒüþ‘ßÂüû|ý„#‰ÀtêP……ž¥øÏ ºñ†x› ,Ä:.c¦LvMý…X¤1ßêÞxn5•@>² HÚZu’sg p¥Œ¦Ï:ŒH¼yb[òD]·{,ueìçÖø¬Y›¿Q‡}T4ΩëÎu9E:IA8mÅIâ"U õTg%NɃ¥ú#²©Àø’Ò‚h«Þ&Rœs9é BÉêÃ\ªŠÕ`E8$'C»'K)¶¶eÔJ‚öéj‰ÏÙS}‰NCצ“d! ³§ˆ— SYG;TcÕÁ‹ä< ‡ôÓÔ8ÐQÝžÒðÚ>Ò¾L¹íøêÆÝuT°#O´•¼¢z‘xÇ­‘™qPrš‰•yO¢ª™¨&“”»›ÛÖ.ÈCôŠìC¦ÝÆí©þáªB²ÌÖ@Éf$º l µnj;L]¢Z‘ï äD»ÞM?pˆ â²S¼/»¼:f¢“+ñ;dLÃÞž¯ç»àI¹(6þX„NÐfr…ïV½,ÓT8CðÑdºZ‘»OÐ1œuïÊUÅC°åv„{ìXMÄá&äÑGq¯®ÝÇÛªcïЙڂ•C:Ö j9»Úå¸=ü©¡†)›•d¢Þ$’M‹‘<ÑÔ“¨_0ô+ºÁq¶zXQ5Û³&<+ßýh Ï_> ñ,Þ÷Ž”/2xˆfaÈ–Õv·K‡(Ó—]Ýv—aÞï~ûÁ÷‹úùˆ¸¼¢Ê|üãï¾?å:UJömÓ1¬Û~ÑZ ªáG«úr#)OXÉ$AʼåÑâ7ø˜Aû½r±‹ŸJ‘‡a%së¼3žŠÝzÙ…"ôøÒa¶cÞ¤5ñSe’^ÈÄx̬ÏúÙgÛ¬x(šáS,m¨QTX™eUu¦ôÜ7ݵ±;I*¸ê×H| é)× îMöÀœÁý¥8PjÆi$â#Ò/n½ôÆó~ójF«cÍÃcs[rkOØìêx[8±ªž:Õ©B‘N÷úå—Îi¢D€UE¸¬ý&æ›Ü]GRšÈèJRÙ;ªm_ Þ^e í¡†{¼§\Hoqé0u]"óh}øÉÝ&² tÏò,öIR½mR,\énÎ…lÀ|ãԦ覵¾Ž2;5_Î ŽŽÓÅ|¾ýuÚgUxk ¦D–F‘>ëØhuÞ-M¿XýÄ<ÒÒÆW]úí+ÝàWÞÙ”ƒ~Uö’‘ÂY‡ä÷rAaÔ›S›Î¬[`$£qƒ»{r”ºªµÍµ l°Õ¶5ΣCù(ˆ{ðþÊ •fª:˜t‚Ø‘ `ªh>_êÚ€]YŒx£ÝĬÁCK¦¤¼gEŠkW+·x.»ªPì\Êò!Þ™Œy£2é‰H¯^1™°“áßÍ_¼ñmy6õÜeíJGí7•/uTÃ~„²¹± ~êðë´mH›}a²:PKÒ)@Iø¢#ѧÁå*Q&¤ià`Øn¢CÍÙŒ®É[‹‚3ê—¤( ¤)Tm·‹Úv§´OÓŽÍUk÷µõ°‘gcò>Þ»¢î;W·O:+" W#2ICå¶;‰ˆA_z‰w8º]¼A'-½ü„qó·ÓY¯Wïf¢öUïá,×Hq̡ՠnH+½cDoäPªöz*1E:Õ¹ç¬Ó…·ÿ”d«N¨…ß®Û<&ËB¡†ûÜ^5?gú6Q4»Ó¹ZQ£"òªˆÅ˜oÎvI§´Š6|ª?Æ¢P|Õ Ö§V…‡çè7l¬ü}¢nüœ>ÇžÞÊ$oW¶~qNÕoRP=»”™¼–a9WˆêH†Ç¥_Âð^Ç>¥» ÃË_^"b åV“ï$ËtD°’îß´Ì›WÏü+xè+`ÕFo–Ôékå·ô¾À,909tÒ u$YòŒªüÝźÖü›‹ÿt­ùoFñ~­ùg¯ÏþXyÕ‘a¤š(̸y`óy"×öm‰\(;ô­~ŠWñ1ͧÔÑÊg¨ê̹sÔQm‡ð$ç0al©’á¡:E*tf’Õ:Þgx|9¥«’F˜BfÁï[Å^ ¬{ÚÐÇË9ÍõN=øó±RÒ® ýJðèŒû;À`ìEõ:fmªDÊ@½¹F—Óé—Ù0ý¾†­m½t¹îÐØ)ëøÙ¹WQø#ß'n>fž]õëb†òiCCPICC profile8­TMHa~vÖÌ~ЩˆŠ-$HÜZw´µÊÌLÊ]É"ZfgöwÆevW݈èè!:DÐM:u ¬.A<A×ÀS§Ž2H‚íù~rU” šá÷y¿÷}¿ï þMÞv‹u!ÀõJþHÿ¹Ðøµë¡­±ͤ6„-»X辌MŸ‹þ>,r=[x1xüñò¶˜_?>1¿˜ÝNªhvâv»à—ˆÇ‰g§K¿·ØYË!þ.||!¡O*Ü)pFá‹ûñ‘^âÄ»2 çN*|[`;ë»Ä÷ˆ[×a~ã¹È︞ÀˆO¸©’[Hón¾lëšE·;SÞØ¨ÈCÚ¾¤^Ä1ÄYnì›—¾qd‘C!àciJy¤(+mšÚ””…-„ xDÓü†`P¡Gæ)Q'¼‹DBg“çèãQs {¹~Ši3ªtK{ªÕå›@ÓRµú³ã °å{=Dý[F_Õâs€Ó´5x5ÝÑFŽnxy«¦sžsŸ¹}Ë·VvÙ0Í¿Éj?øÅçIƒ«¤¤#wƒ ÿaöIߌqrCœeIî'gW”äì’ŽkR¹åàv““x#8+Îy\Ëw´ý!ùvò9òÃä ¢pò¯Úþ‹¼ÍÖ©¼s€¹ ‘§™OKœ” žd¾Ìb”ÈÑGû)Áª®já$¿&¢¬¢“Ø”ëvQŠE©3©"›$ÙŒHK¿ßäš|-%Y×н¨¹L›%ç]–÷Úß´þZd†®ŒrBQ¹¢zk>¾ì,ÁÙDä»Y›è¤sŸŠô1eO1úFÖ¬¥þMÞJ.Sv¾>×j¿Š^3Fnò~FWù%ùç+ËSÙ:äz"cdž^í%º÷=ü‰! QB‹n¼bKGD¾¾¾µ­@› pHYs.#.#x¥?vtIMEâ  Xœ€'tEXtCommentCreated with GIMPW IDATxÚìÝwxÕÆñïìnvÓ)$¡÷Þ‰TA@ ׂvDD,(*¢‚XE¬ ˆ "*Ò¥÷)@zÏö™¹$@¡Hù}îÃsïÍl™93{Î;gΜQ€j€ ¨1zôèöÏ?ÿüÞÞÞ‘Š¢EA!„BñßÒu]×U»Ý~äå—_ž6eÊ”€DÀ­5úñññ£ªW¯ÞÝív£iš¦IÉ !„Bq‰0  L& Ëk×®ý°OºÆÇÇ¿ÕÝétJI !„Bq‰3›Í$%%-¯]»öxãsÏ=wÛ Aƒp:2¾F!„BˆË€ªª×ÊËËÛ£äææ2µ¤X„B!„¸|(Š‚ÓéŒWl6›CUU³‰B!„—£Ñè0éºîQÑBMÓHHˆ'55[u1›Í„‡W%:ºƒA D!.—[cúÂü¼î0é¹6)«Hh€:Ôä±ë›âaª¸Ý•\&¹ìT¹L×u³IÓ´ ÇÎ'$Ä“ŸŸOÛ¶ðòò’Ò¼ŠØl6víÚABB<µjÕ–Bˆ‹`úÂü¸!•zt"Ø_ÚÝ«IVžWl`ø æH.g“Ë4MS”‚‚½¢7¯[·š-Z¡ªªLay•9>%Ò¶m[èС³ˆB\=FÿD»¶m9’¯`wI»{5ñô0å¯óÏ?øcÒ@$—‰³Íe¦S½ÙétÊAs•:¾Ïå’žB\<é¹6’óÁîR¥0®26—Ê‘Ä9§ !„8AÝ7qÞgþÎü“½ÅZ2 &<ÁÃ’$÷l^ØÀvµüÓݨ.'š^ÑrÍeÅíÖÊü]EuVð÷+çß•ÁÕêâ_WZ.ÛÿÄš#r#ð™øzè5—¼Ï¬üÞŒ¹¥ÆK»i#î·™¬ º‘!íCÎòìGCué(Æ¢÷i*. L&#Êiªó¼í󘹥wÜÙ°2¤«v¬6/OÌÆ¢OÒmXðùJüÞEÏ(9ª…¸Œã\îŠwñånܧz‰âIÇǦ0¬eå¿uÝ‘Íá=;Ù—œI®MÇT•:›Ñ(§’ºL#~ío,[žŠ»^Kžþ‚ƒÝÆóëè0Òîe7­±Ká…OôWðÆi¹;ÉÚû¹|| Ø ŒámnÐ/Ëñ#Ó…óÀw8½àRÜfºqú‰üœ`›wC½JÃË¢‡¾pï [H݉Cñ\ð;짬Ìn{;uÄ »±Û¥ö«–ºœ/go¦Ó¤Tœ#/OLÊéò“ŽÛfÅaðÄÇr2T]iÙÉô_ü õüD¶ÌÄø\À0žôët¾ÎmËÛSÃû\.Fhdî]ÅÆj}¹£ýY¾3c /<¹‰î¼@Ÿ@÷®Ïyè#ß¿—F•œÅ¨G—òö§‡è6á6"ŒnÔâ2+<ø³gÿÄ_»3P-Fܨ3€ÑãÓÀ»!z¯çéÉ_Qe½´ðQ¤QâreðÀÛ/“§'ž O ž zú–¯OÄfªN{J~ãö$þúúS>ùq Z©|¨¼¨ÞéVF B» *"-•«Ð<ÛÒ¾©' ËUPy$íXÅîÛÙº}–¾ÕÝ©q$ϟѶ宧 Ó‹‘ã^a@]/ xàd÷ºe¼>c‰ºáí¡ºÏ”]<¾4T\IK l1„o ä£Rù3OÎ,/UÎ{ØçÛ˜Á,Úx;áÚH¥\¾:´ð=–±]È[ÅäÇg°Å}r¹ËéB7Yˆn_W˜`›òÈûÏÑ+@9e~²Å/åƒéß±ö˜‚§ÁÕP…z­ûrÿ°ë¨{…e§‹ÒC¯«.œN'§‡ÓF¾ÛŒžÏŽ=Áx»8΢åj;7"ÌPq¸v:1úxžáYˆŽoLC|gÎà©% èzË=Ü}]C‚*hÃ\‡×ó{fuzµŽÄ\öР ŠÊâxih¶ îÞÁ¶;Ù¶c7¶ö£yãÑ¥®6èLŠ E/šµÀäÁh¤맞Å@Ëà÷™?¡ ~›>A.ÅW™qóxéÕ¥øÜô 3&u¢¦¯E+ io2*:ºæÂØðžjþ8“çîåÝ{”Û!Äå@! öq¦Å–¨KlIüý퇼¿$¥ÖuŒõ(ëU\ jYë™öüæîwÔ°'÷ö `ëŒy숺‰Wî¯KŸó™³lÏÆæ…w^ ODé ѹg ‹©xu¸†Ž,´”MÌÿ2Õé:jÁÆ_Püj3»I¨:ï¡÷J-R=›=˜ß¸–‚é<´ÔJª <|¼è}M>}m=O½™ÊáUK 꺆+e9æ}ùôÖ`¾üáäêWññq©o»ƒë6B마ÁAñ¦z“–´‹)ìT,›Ìü®(EÛxo.|"»Øv|ÈÐQ;éÿáTîŒ>U/¨“üÌìš^q~Rãùaêפľ΂û›`WöV-ÙÚ•—.| w­çÍ{§°Ê¡`4™1[̘qಧðé'Ûð3[°X,X,f<½›Õ±!¡œ$i©¿òâ˜ô(mÎèʈà&ýÑ Ü¹âKÞýh"ÖÇòøèèj(uPZù-ßæÝK¯VezGô¢ÿ8³IØ~˜;w²}ûNvÆçâÝ„Ömaú‡šZ*𗬔õâ_öÿWD[ÊÏÉí~7vwqš×RXüÅ ûNbêZ¨…é¤Y‹~¯ª¡ènwÑD‡›º7"øÉ_X=°Ý¤ÏLˆË»›+­‹¿á“Ù‹Ùá¨A¯&óè „žªþS“˜7a"sxÐrèëLÒÿœ…<ý1˜£›Ñ¹c,=:vãÚÖ“xòÍ¿™üNKšOºª†“ë¯ï㨦V¸ž7Æïf¿[ǾãG¦î(®UýÒï¶þtp,ãÕ/w£ä6¬«/°#Û1ÜÓïÍGµÁëøa^`eá⣘oìÈ ±‹z(£A/g¯¡¦¯@ìÂ̇ªñÓü£ü’©Éñq)¯_ÁVþøG§ã³õ1èÛŠbŒË†Ýn,è]ZqÎÒutÕJNQ¸A/ØÎ§¯ÿ‚åæg‰Úø߬«ø»ŒõèÔ2Ë©ò“5™„Ôtí^ wfé€b¨Bë뻣Ùl¸®°ìtá‡Ü˜c·¨?ÞŠ^tÛ‡sý[ ˜£?A[SÑ1EA×Ianá‰z©xV—ºæu$¦i´‰Rpdœ˜@Bb‡Ž ´Â]íƒJ U…ä9‚ÛßÇ”Ž×³fñ‚BÊ4@j"·äÒ춆œh'5;éñ{ضc;«wÛ9ø×DÆDÔ¥E«Öt2€gÚ6¢š—Ž#íw^ZFl§Œe/”j:μ½S‰[ÿŽSWWO^ HÝÈšCµ8²ÎG‰oÑQÝîR'nß6tžÅª-ùtí&—Á…¸ìkWÇlaåŸËXúçLu‰íû÷Æ6ÂÏ‘ÅÞUKX•‘AFFé™ùÔ¼q4w46:kfóÅV+UûMdÂMPÀ|˜$·ð¨ªÅ•½™j½‡óøú­¼ô÷/üz¸?C‹{Îl;¾eæê|4S-‚ V³þ¨ –Æ·2þÑ&lzóe~0´eðmý¨ö×zÀd2I=s¾+t»s}ëd²h¥gùŸ¥[R¹·s1q:‡ Åå`ßÃØ”χ×çï_Žð]ª&Óz^Ò4Žü±5y~ ö)ÞWZ+f¾ÍAïò¯ÎO(@-ýþ£‹ßäå¹»±Õ~nôgí«Ø_öžX5‡}ë¶Õz8mZDbQ*ÎOøT'ºÊQ6oJáºE÷AꚇõÊÌN¾‡^wP“AA‰ÏÒ >ø;Ž’šA¦çiG)É $$ •ì2–eù©äªP½V4µkV%oïM‡¢”é%?¾³\¶<²Z^׷͆»Ä‹l;–óGv[mi.:©È[Ãä°ž6kF€‰ZwNå‹ûkƒÓÓéÄiÏ"ÝjeçìoØZçf†EëèeîÐÑÝ*.L˜L¥{åK÷Ðkä9La@M"½³9—ELŸêhÚÉÏrM"ɯ5}]h§Ûº71õø&.w×&ò!.›v0“ů>ÎÛ«Ò°WPŠÁŒ—÷–}µ“%³Kÿøƒž>Áôìê*®Æílþ{=9†Üq{[Š:™trâãÉÐÍÄÆT;9$Pñ§C—¦Xþ\Ïîý…è1~(¶ÝÌzïg’TÌôóÓ¼–3➉‹lB»aì1”¨S].tňÅb”}w¾ýšX !ÁÄägóI¾¡Âm,ÈÈáH•*Ô4¹ˆ/^îS«ôŠfÇ¢£|–¤",]Ú=ôzî:¾ûe?Nª£«:º¡·G¶Ó‰ªmól&¬¯ÉÓÇbƒéV¼ƒ#Nd7½ ŽÕâÈðëÅ[c{äv1虑”¼eHËÝÃï¼ÅöfÃxoä5ø»hjÅù jó¿Ç»óì„qŒKÄͽ;Ñ8ܳü¤WHv2ý'5”?þú^ò 5𬤠[Kaá›ãYb«F­Z5 ‹ò#!üvÞ}ª+QÞ n·wÞ&ýµ“õ½N³nìÖ2óF¸Y8g^ý_£µ‡Ž¦Ð'¦wgb5? ®þzí/fa%+#³ÄA ‘¾êSÞý+;ßéF€ê¤ì ¤n+ÄfôÆ»²öNKeùô‰Äßø!Ï´Ê&3Ë›ÀÒoPvÜÞ¡˜u8ýi£N@•` r°ëà+]gB\ ~áÑ´ìÒ‚°°PÂBC %Ðu¥ó°â°7mþ[zµ¦Vhþ¾^˜KVZ É6”4?¾ÀÁÞÝQ5©_ÛRêë<üðRt:ÞÄ}ÿßr£t¼ñtUT¸q¹u;ºâG€¿ ¹9ïÍåº]ÞžxØr)Ô½+ÜFÝj§€`|½\èVÐ1T¿ÁÙ«¿8{ƒ¦xÈáv ³²ù»¯ÙÙ ;mwœ$m\Á¶LCqUâÌ´ƒ3‡ÄøCä*Çãa<9íc©k[ÍoÎd}¶†±y¢±âÖÁ—{"w¥­ù‚ɳ7aé5‚ïi†gañˆ½âü.Ìâ“ZðÍß2噯ðnÖŸ¡CѺԤWFvºà=ôšË†ÕîºÙ‡jù:Gœ%±¤ÚXöÛQªÜ|33þ÷9·ÿè…R»ª<ó’d¤þ »1¬f5žÔ»öš™p§°øõ•øD…“o÷&,?›àîOskŒÐpZ pF>ÀÄvö~[|¯eâ~ù%®Ôó8liy¸k˜3ggQ63†pMx="½*ÎO'/·‚;†Pz==œC÷¿Èòí·Ó²£×•.p½‰vÏÎcÕK†â±ãÅÿ\»™~ïó¤?8™—:{œø;:hÎr­®Š«´°hjä.%)_£^€7! o`ÂXjh¹ØÏ(Í«dïÿ›¾šÃïõxð­ç¹1ÂAóÔÛi´x-qÖ¦*ATSɳ⒀v” ë©Ó­>žÇdž—åñ1ô®cËùxn2íI˜ª£Bt´‘5‰©¨-£N’!méVû~þm½îiDå‹$'¦S­N5ŒÒC/Äeœ~ŽŸè@ñ­MýÈ3§®øÒª}CÌë60ïçxºÞæÉ¢/—’¢TcHßfXJÔ)Oçÿó°4¿—^'zØ=°˜+¹Ä©˜ ªV“êÑë¾ADÏ̇fæëèû? ôç5Î_¡·š¥²2½7Öû…¹[ZãŽÑ¸3±XKŸ'Ÿ$÷à1ö¨ÇŸ$[\N;ßü”Jøí÷òaÚt†nè€Oµ «öfìK·‡^ÇY‹Ó}|,ƒ†Óš‡SËfýŒ×ùÜ1˜ ÿÛȈÅM1ø0“Æ¿‰÷˜Gè^CݹdÙµâK)x·»Ÿ)=÷pãüçø~æ3Üõ›‘´d+UzŽäÖúàLeÇê5¬Zñ?ÿG¾Os¼_åA\QоO×ÁPƒ[ÆÊ-Ç—Ù’”ªbˆ !XÂüyn5¯Ô s0oE=ïx€‰Ö¼²ð09PÌ¡ôt£cl¼>ÛVnЬ¼7ߥۇñfÆûÆ»\Ôyd9JþE#ߨ6²33Ë„×Så§#¬þ5Ž*:Q?Øi~eyRuz7ð=ùWHvª4ÐkÚº§\÷ÆÏòr P5ß³¸|LN6$eán‚f-¬ôÕ…«¦ðÀôͨ^!D×oBëÞOñPïÔñ²“›—IÞl^h·ÁôZ>™gXLh_L¨¨ªŠÛåÄVXˆ-ø:&N¾º@ËbÍ'¯3}sÿ{eíÌ®'EÏ=XÌKü„Ë«.½ï~‹Ç¯‹À™g?1FÌÒª/×ÌšÁ²Cݹ=æø®q⊼™É“™>uOÿdÇËß‚ZXˆÓ· ϼ5”VžEÕ^öº?ØÑ—)‘*š*u‰—-%ž<ÉÚCoóûw¯pï÷F,¾þø˜uœÖB M=xcÞ(:—VïÕœa¯Â5éS–R©}í“<÷t‚@?ÄOïLç×|U]ÏèÓ?¦òz(^^x+:ö-_óò„Õxy`МX òÈHÞÇÎ…ÆMˆ”@^]°v÷PÂS?„ðÔ-ÃYû°N¾MÇÇÇHê¡LÆs”Õú‰hbðÀdDÓŠÚHgf¯ühbê£Ã÷s<“º¯Ên«KþøÐЧ«´íföKïñwø]L~³/á¶5’«j8\WVvº(OŠ-ÏŒ¯Ÿ ›ÕVâ’Ç™©Ñ¦µîrrªˆO—gù¾—?!žè.» ›-“4û™o—êÙœá3äñŒ#$gYQ#&“fO|üðÒ(ÌÎÇ©J0ͮƻO´!FÉ!Ïqò{”ðöÜóhc‚cѪaörsm¥J•zÜqo$O»œkFõæø•vÝ‘‡3¬;ÏN»QÎ2rœxøQÅW#'5»zá6¾ÿ)“~Ïu'ÐíÄ-í¢—5Säµ¼òY3­\ÁÚIJÏÅêR0{úÑ„à sTž™ÖƒgÊ-hÆW^c`XCUóãL&›TüZÐçÚ†$¬>̺?÷áTu01[¼ðö ¡qŸÁ‚^bòâ׫q|õÜ$¦©èŠ'慠¡‚üWa~R‚èðÀëôy€-+ƒl·7a¡>¨Yä í¾’²“RPPPáÑñ÷ßR§N½ õµxE¨ešë<«³l“w~JÙ…®3ø#FƒŽ¦þÛ‡Q(L&L†ó,¡ë:š®¡iZ©1F‹&·G™yé1zâëeDu9q8O=§¼ÑÛDÜŒøL¹Ñ·5,7}’b0b4(蚊züCÜ©,Ÿ6 í_`\7olÎóóƒ‹ÛÏ5×t—Vˆ«‚FÆÞuìÊ  ^ÛÆD”Iê冊ó®é#ßR·­ÄU,ãÀv|x?—¯@ï 3)SD$¡~¨ö–¸ I·zP%À|bd†Áì…‡jÃQü"]ubu{às|º.ÅB@x(~F w^iù®³ÌO £jÉ«üt²Ó…TY.;Íy.ÛŧaÍÉÆèé…Ù­žÙŒ&O¼•ró䱨Bq9Ó5©ÅÅåœË4¶SŒ p;°ŸfL‹îvà¸Xùé ËNÿÑzqšC·ë,~´ºŠ[ν„â lÒî 9>.J~ºÂ²Óif¹‘G!„¸X4¹2.$—‰óèåLP!„¸x¤Ýr|ˆ 襧@!„¸hMz`…ä2qþ½T,B!ÄÅ lÒî 9>Äy ôf³·ÛÑh”Rº ©ª³Ù"!„Ih€…n'ŠÑC ãj 몋°@/$—‰sÉe§ ôáá$$"$$OO vW»ÝAFF*ÑÑ1RBq‘ èP‹Ï߇9¸³·ÈUDsZqf%rûµõ‘\&Î%—2ÐGG×$##;¶`µZ¥4¯"ÞÞ>Ô­[èèšRBq‘)V!„Bqé3H!„B!^!„Bñ0©ª*¥ „B!Äåèm6›”‚B!„—k ÏÏÏ•RB!„âr ô¿þú‹”‚B!„—)%%å˜L[)„B!ÄeJf¹B!„B½B!„B½B!„B½B!„è…B!„è…B!„è…B!„è…B!„@/„B!„@/„B!„@/„B!„úÊèXÓHÎqU¸Ì™ŸEŽÕ}ê·k)lZ²‚Ý9Úy_y½0™MýŪ}Y¸/V‰éVŽ$eàÌÜÌÜ_wQ¨ËA$„¸¹ÉÍ)IJžù+pI!Äeèõ\VLÇÿX)Ÿ]¬šúÏ/HF=ÕûÕÃ,ù=kÒJ¼[ÏaõÌ×;n|‰¯ñÕ6û™¯¹cŸ¿ú!«³ 94ï &-Ïà|ž2¸÷Îcü‡“¦•=‰ØÏü7&3/ÓÇŸ2{—íüŸ3¤4OP!®ν¿0uîVòÊV²Z&k¿þ€{ÿ]m »Ý§®£Oõžœ5Ló>+&’ø˜‰nÙQBq‰2¶R/ÜÁÆ}iÊçLÞ¥ xÔcà#}©k¬ø=Ú‘Œ|æ[¸T\eôül(:‡ˆ¼þQºï݆­ùhîiæÎýÌyû25# cKÚÊÚ¸\*ëüÖÒÖ²¡ÚML½©5ÆcnFÏÞƒ«g,kùlÆ RΤç\©J·î6ö¸Ç IDAT&6¤ìyFÊŽul͈o™EŠosî»o5ÏÍOå•aݘ½![“FxZÂÆLXHre-§1Šc_fpô©Î¥tr×|ÂÓ ëóλ·RKE qÅs§ìàpÛÍ-ðWJ.)ààúÄEÝÇ çôÙjÆ:Þu.~Mbhý“Ÿ¡Æ-bÊÜTÖâLâ»*ãî®ÇìÍI¸kÔ:}£!„âR ô:yÿ¬dkP[þ×¶> èyÛ˜¿`:u 7D`ÒT /=µØ÷GÓË_\lûøI>Ã;ÿóbá 5Ѭ©™Âu¿sÐ/–Û›xÖÄM,[–xš¥|òþÄ—K ܵKãáx&±åŸ£Ôº³ =+y»}/?µÄÛ²y>‹Í[0¹·ð͇Pʽ9[nëBXM#ÏÔ)±ÝU¯á‘QMpTºÞf‚«V–ÒìÙ‡Oé.a^qÎ4rwÍçÍ·ÓùiÆ×-}B Ô Y #®Š:?ÜYüÅj"G¼ÇÛ-‚ñ÷mǨ¶R¢Bqyz-¿~ßE­¾SÜ? Êâ—ï~dÖÌÍ4~¨QÅïS x„´¦mïØ¶O¥_'/P“Ù³Ï@ã‡j`1f”øŽ–.ØDDß7iè` Jçx­óiÖܵ‘·î~—Ýq­èuÍS¼Ð: »1†Ð¼wzû*§>U)ð`Ý· .S“ÿdéÁšö(æµ46ý¶‹‚·Ò£ì2K0Ñu‚ÿÝqdzm·J£ûjKO˜W2×?¼ýÀTÖ:·›kÆ|_f¤†Ãê@›þ ·| ˜ÛóÌŒ'èxšÎzݚȊï>æã¥y´¼oc{×Ä«LefmJŸ¾M+ìÈ)Xó³}Ú1¤U(þÞ²«„â²ôŽ]?³àH+îlmÁ®ƒ·®”cdÕlO»ÝÓûÅÃô8ÕÀuCš7 bÁöƒ¸;5Áüë­­x ©tñyóÓ:òäµg5厞—Nº;ŠƒÐ7òa^^F”ñòBqÙzÇÖŸø¹ '£¶¤1ã0Íx‡WžZE˜â ÙðZxy0lâh”Q/³tó ¶ô©N›*EiÓÔòf|qú)º«%‹E/ÍÅ“VŽáöW^áÕÙ5y羆œY¿´íë¶B‹aÔ?-Žsÿ÷Œÿ<ž£'Ò%°¢ ÜÝÛIªÖˆ†Þ¥—[:?Ë?ê§í¡wïÅ#ãÓ‰ªèDDKcý†D¢Û¶&´äbÛvf¾ò.…C§ñÂ5 B\™t+…6 >Þ¦r'ÿk¾ày9p8=¬íb»óôÔ14L™Å=¯YÏå˰îýŽ7¾É¤ës£ië+5B\öÞÒòNÞçI˜@4×>1‰Z_¿Àð?Ú3¬QQ·â[‡z‘–Æ­dÒˆôöwuŒÀl0áÞ÷3ŸüQ~:KCPkn¿³Ä¤ÑÜøè@V=ó5Kû¿ÊÀ3èq×Rþà‡Õfº½Ø‚óyEØ\§/ϽÞÑ>‡fõË~ÛKt—(7ÊÇ`Âã´«®rdçN²kõ¤¢5ZÆÖªFçÇ«–~äÕ‚[DðÄœ_ˆët'u‹÷ÚæÍåâѪU›s~¯GNÜÔ=œ2ýèùGHΡYx¹ ßȦô¼­36¨M”ßɪÜrnë`_ÄkçgnC¿ªžÖRç!Ä¥ÙÖœºÛ@XÉÙ_ÜélÞšF½þ#hb.ݰ„_;Šë®gÚÏòøžÑLÚ{òþ<΃75ŧ¸eÐÿä“5qôR§ôWEt$6ú{6l/`@/ÿÊ{ ñÌŸú ‰-fTCóù-%C5£OµÐEÂÂO˜“Ëè>çôˆ]=gßý–N‹»;—î/*Ò×­%.²OE•o¼«õLìÏïñÍÊþ¼Ô=å_!Äùóoƒ®GL7îŽ)Wc»y#û1$¢|ãY³-=jžµ×ÈÙù=^_„Ú÷9Ƹæ3õ…7ÑÆ=ËõÑ–óvÒ"„âµ5g8`ÅÎþ¹Ó˜ãèÃÄë£*³„·½“×Þ¿†ÝiÁX€À\ŸØîÝ*Nèîíû˜µ¦‚W<ñòÔ(,°¡sê@ïJßÄ7S¦±ÀÚ“—žïBðÅšÖÑŶùÓxãG^¾‡V>g)ZËß÷o|ÄÆÈÛx§kpù2ÔRX±â 5»>Nµ ¶KñiÅàë«òÄüÅŒ½ƒ:2¸Uˆ+šž¿•ÙsvR­Ï]4¼P¿ww[œÎä9ÉÔ½{#¯¯7ͨâ9‘W^š„ëåQÜã);C!.q§o&ôBö-x›q‹¼¸ëõ[©_I§¸âSƒÆµ€3}f«zŒ ¿îàPÊv~ÛLÇ[«TtídÚÆÊ?–ðó²½˜Ú áúQ¯²ñºƒœ”ŽT6Çš‹½ÒïÖ´lZ»’%¿þÁns˜8’¾1Þg5†]-HfËß‹ù~Îï$EÞÄË£¯§F©R×Ñ\ þÁŸ‡ÂhtCW ;7‡¬ì,2ÒÒHIIáXJ*©Ùv4%•¹ë0º³¯Œ¥âJ¤æsxþš5Ÿ]wñú œÿ{á¤l^Ì—_Ìa³%w{‹ù׿>4¾m,LûÊ(ãF3¨–Eö‹B\®Þ‘º…Ÿ>ŸÁwû"¹{ÜHT?»)Ôô,[¬¸ÑU;’ˆº¥Bs~ÚÒÕZÜøüý\רÄêØ¶1kÂç,;˜D–¡*MÚÆrç„'éZ/°ò•6šññL`΋#™sºô¬Ic韸ì#fþORR"Çl>ÔlÒ†kîšÀÈŽ1œA«ªÛ±bÑZö;Fâá8öÊÆ«v[zß;‰¯‰Á¿ì‹{/Ÿ>2–Ÿ²Íxûx³yÎ,D•Ð*„Æ´¤Q‡0ªV­JdD0YóŸã™—’Üñ&yð”W =—-ó¿bÑöÃÄí‹'Ç·ÝŒáý~M¨rÞ{ç5Ò¿Æ£ßÒaÐH>Ð’ð²U»âMý[Æðª{/¾ú1U§=A¹IV!.Ã@¯cáÔYu#¯O½–ú~gŸuGG’“9Þ·£e”¾IÖE{‡•@€¥:n¼—öUkR+2Ë~½¡Ú ÞújÐ9‡‚õÄöïHÕ¨êÔª‚÷Yv)ŠƒÜ,'žUѽ]?®_—ê§îM75àÁO~àaÙ5–FðZç "%Ì qåP,øV‰¢é5mx}êWÄ|ŽùYñ«AËVÎC+¨% é6‚Ï{PÙmHŠ oËÛíò‰0/„—v3’’rì”O4MÃ`¨,9ªdìßÌïÆ4«Vz(Š;÷(‡ }©éâr±nKçpºˆêØ&b ¨E¤4BˆËÜæÍÏú†ÑsyBik*búw‘zm ©èƒ"©PæìÁ+”Z5Šþ·gT ²o„B!„øWdà†B!„è…B!„è…B!„è…B!„@/„B!„@/„B!„¸pLRâR¥é ¿ìÑXyÐFV¡[ Dü§‚}LÄÖñ↠Š."Ä$==´´T‡ÆUÂbñ$,,ŒÐÐ0) ôâróË^=©.)qÉØâBÁƒ åxBüWaÞn·Ó©S,žžžWÍv§¥¥~Õ®ƒÝngçÎí¤§§*? ôâr²2ÎÀ˜þ4Œð’ÿ©]GmLúõǹÐÐ[ Dˆÿ$T¦Ñ©S—«*Ì ðôô¤I“¦¬Y³Z½zq¹9>ÌF¼¸4Žô’¡_BüÇ»„ù«6Ô{ápØ¥ NAnŠB!„B½B!„B½B!„â¬ÈzqYëÿÞþKvÝ=UOvB!.8é¡B!„â2v öÐ;ÉÍQñ±oç§½U¹¡[4fÙOBˆsôòø ì?p Üß=L&î2„k{ö¸ÄÖXÖ›ƒÛ+?sùú1-n?!¨iˆãŸø@Ú4«¼"weë† BÛ6#J*Ó‹ÈMnŽûN~ÞW•ºFã!…"„¸Z½–öoŽÛO¿1±ýáæVŸÀÚç¯tïúžñ+"ybX,!åú„NÞ¶¹|º©:wÝÓ‘0£Ž³ —Wù'M*¾úz€u?ó?[ÿM÷rm”4— Åb¦~09æ$_Šã²QQ˜p¹Ý|þå—hšJŸk¯½”*A~8œÝ7ÌâÅX3šÛ[?¹ì¯&°§ÿ FÔˆgÙs˜×íiÆ nL©â‡]iy[øêÝ5Ä~Ø„¨J*=ëÚxú‹œÙ£Ü,ídÚý-0޽¿2cùaÎxROCÝï@3ßóó€.çÞ_øhGuî½¥þ%?RËdí·ß“ÚúA58÷ºTw»ÑL&Œgóžœ5L³–Ž£z‘üÃÇ,¨õ*ƒk˜NÑ.œl/Ü6+vƒ'¾–“ߦK›pο ÈÈtá„W…‡¥Š-7·W~æSýŽÎ×k„¸^ÏeÏŠÕì/8ý£Ï ¾uˆíZŸÀ?õÀŒ}9ZÅï1·¾‡§z¯fÒ Cë3íï}Øk7áüÌ:«ql÷¶Ä5dûz3– ^a ®MÛú!gUqWF=òo|°N/ß\\i;XõÞ¼µÙŒO™³Gëa|öl¼½ëÒçš¿9i!¯ßOK_y*åßiÛ«·åaä` dt?Ó?Kaƒzò•~¡>42Øù'UE—‚»d}ûå¬Rÿÿö»ïA×uf}õ5À¥êOTY),xñ¾8 ž|ªÓ‰vð~†¯¤æMäy×8¦ß]“-3_äóíe"¹šÇG)ãžei™ŠÍ£Ù]¼9´%ft4k©A×1ýåÞW^«qè»çx!ÝV|¼ë¸ŽlféÞ º¥>z¿ÏXŽyàÝt 7œxϾ_>äŸÈ»¹³µ?Š!€*æòõš;ç«–¯`ýö83ò°ifªÆÐ´}nèÙ„ÐSdYwÊþØ·Ý\&ÐSÀÁõ+ˆ‹ºïœ½š±Ž÷_‹ßc“Zÿäg¨q‹˜2w•ÍŠíLâ»*ãî®ÇìÍI¸kÔÂTa»¶C¿1í½oX¢à¥Ø)4T¡~Ûëyè±~Ô“6áÂfù£KyéÖ!¼±¡5'.æ°’å[ÈŽ/žå±—¿c»Ý“]#¢çãLy ×FÏók„¸¨ÞAFÂAög•Häöd6­O'¬}Kª—HÞ†à Úé@‰ß†!²3÷=Üç)’!°5«>ëÙ^„…´f|«óÙ8æ°m[Þ./–,L(»aXí'>æQæŒíÊyy¤–ÎÒOç¡ œHßR?X#5o~÷ï¨yŠßæCx¨á¦ÏéÌCʰ£ÿ€Á¨`1œ<|Õ¬<>þj¥÷UTƒPõHcSªyìÐoì+ã8xèP…!¾Â*­8Ô ÆÿxøFúŠ™¼ø© N ¿y…g—ÔæÆQ_óóñ^-…y£÷Þ—í’°“wì0´xžgºæ)Ì?§òê‘<Ô’ÁæÀ<^þ4œ‹ ·­—Éo¥D3PˆoëÒY ¨J ý(‡22Ès»ðH=Âÿæ´ðÝÃæéVGÎ1’’ó0V ¡UÉ·ëVþö¯ÏÚ†¹E7zÆ6'ÿóåÔ¼çº÷²zéÛ<²¨ OŒy˜®¦‹¶?rwÍçÍ·ÓùiÆ×-»½5hÖˆ«¢¶Ì}Å_¬&rÄ{¼Ý"ßvŒj[I» bΔ/In?–/ïhD€QÇ•s˜VFÕ¤M¸ptrþy—»oLV‡¶ÔÚ¬•[ž>ýGeؼ},ï†ÉÇܧrë ¬K óùzÍ•_Ú½úö`ÙâErè]ÞFì=O[²ÚËXÄs›×ûà <Í8Å'‚z"Nû5UCÎ¥+%ÕsþƳßM´(߃¡[Áïq¸{ú‹ô«Rv=Ýìœñ/f[ÎÛ8GwÜbæ%¶â‘Ñáçp÷±ÍoêGÀ³?ò÷M è(=2ÿyÕoµ³ö€”Ã¥îx˜?«}«ëÌþúëÿ8Ðð«×›½Ú îäß™öC&ñLcÉŽ\Š¢†ƒ”D'?¼ÁØ?Šëc$}¹Ø*EÁÏ€;yûsµS×ÃuhdA9R¦Ahp+“Ç_‡²áCF}næ‰×[ñÇð)é2žQ†2/!¸t8™óX|½0nû›ƒ…y°9žæÍÛbñòÇßó©in2r“°·nG„¯¥Dèäàü‰<¿È›Û^Πz¾ þbÛ'áÔoݘvUšÒ®{oºÏšÀ„W¿ èíûiæ­€ëÞ~`*k€ÛŽÍµaC¾/S×j8¬´érËÇ€¹=ÏÌx‚ާû­'²â»ùxi-ï›ÀØÞ5Ë Ã0„6¥Oߦ†Ä‚5ï0Û§CZ…âï}í‚í0q©QtîÑ€cÑ~ô¬EçjI›p©;Þ¤ïÀohúÎ ¾mþÝþU&4Ä3{Ê"GldT—°¢8ï:üoÊ›üÖðÞûýi>ï›z~^ÓßGvˆ¸Èþ¥ìãÇwÞe‘ùÆyWPÑéy¬ýn!Ù±ÓјG¡ˆO©š_%;3Ÿ€ÎO5éæÀªµØÛù>›Þ/ãåä{q$±hÊì|+]—ýNÀò3™ s¾aVâ5 n›ÊÆj·PuÉ$^÷Ëó}ªcÆÍÞeËÉèp?7Ö>yjaOJ =¢!ÕJ¦CÝ{Ôá«Õ;ÈAb! ,ŒÀêoA1ùFX©@_€E¯ÀpÂÃ*îYÑÙÄïÜÌê•+øcmZ€'Y®v¼0öN:œõåZ7I‹>a^^F¬U¾î?U»`ªÏà‡º0jòX^L¾…ÿõëBÓª^åù´ 畱áõü¯’åêÑD’µjô«^vp¬'5j†p4!çyzŠzq¹zc4½zœvî²ÑØÆ?ŸMdeÌ“<ݽdï‚‚Ñ?ê”7§ª‰lüc)‹–üÉ&W†}›^5}*ì]׎ýÆ['ÒyÄxºVñG=ˆ¿òÃü7¸ÿûjtt+·6O`SjM®iä[â3Tâÿ”É+rÏ0Ðèú4Ó†6Á¤e–íEh°g…뤻ØíöËŒ8ÔòŸ„uK&6üÀػߜŠÛ?TzbC€/=ªÚ™7+Ÿd'€ƒ?WdÐ(:Š€ã%âOŸàB¾ú¥¢NK7ÛþÉaÿ½þ´õÎc‰Á—ë¢ÌŸK¼£(°lþ'•¹Q5é_ÉwëV;+v:H ¤›G!¿í1ôâßÓó¶2ã½_Èku3i –pT7’ñûܻ֨ز8?zŒ;?p’g#¦¸.Ý>÷#~9tæÁÎsO n‚7:N§SÌ­¼õR'?Ëøßs‰ŒŠÄd‹¡Ó5õNNL ç°yÁbTõd…ÓéF³%³þÝ<³s–žu麀‘ËšòÌ ýÉþ`.›‚ÚóäKÞLžú3›;?JïlöïË¥A¿F%î[rà0^1ýK‡süCÃðÊÍ&G‡ 3¹”ª[)´Yðñ6•ïäYóïÌÛÈÃéèa hÛ§§Ž¡aÊ,îyÍz.{ëÞïxã›Lº>7š¶ݸzÊvA!¨ÍC¼ûÖZæ}¿€7ÿï–yø¡›ij’6á¿ú-Ú­ØñÂÛS)×yçéå…f·á8O¯q–ó¸îÇÇ«ŸÎ…Ï~ªu(ûwS¹zŇˆ:õ(7z^;ÊÕ@hLS5¬t¸‹–¾•Ÿ]Íö=ûØ{L£f»nti]íÉ-èxŠ0`¨Úƒov"4¢ø¥Gš\{MzÞÂáu‹øöûwö¥SÓ‰ 7”*žfCßåë¡ç²Á*n·c…g$ ÁÍûs÷)oŠ-qd2‚¦ž ŠŠ…àÈH9rï[3aV'‰%§šPݤê'½)ЃpÝHóÁDŸ(G‚0é§`4[ˆ°98l-½ÿ²¬2gÍåìøš3¹1öL^sQDþn¾š8™_’hIß±"v8O}Ë å)fKhÊ£·4=ž UBO }),({¿Ïäß¹êdzŽísý ÃëÄJð3Sª“£° sô@ÚõAáxš ·îË )9XL ^U" ÷1aŠêɘ7zWêV ížø—ø£¥°kO>õÄ”«5‡§Å³Ü¬g5:qS÷pÊŽ¶ÔóœB³pC¹ÎßȦô¼­36¨M”ßɦÐrnûοˆ×&Î#Î܆~U=OÑUÞ.xWïÄ]ÏvâŽÜ,ùì=&¾ÍØ)Ó¦ÄÉ´ bñ‚›ãøÙÓÉ“7»ÝŽÁÓóyzLF*.Ÿ@ª¬p?{ŽS»¦ßéÇ®k.ôÀ†ô¹÷F†×‰ÄßÖ¿öóiòé~•ž„GTp¹ÕàCÍNƒyÂ;‡¸ñ;èxG÷2=Bÿ&iúàk#©ðߥ.È+Äà뇷ÜÿTù.®l™¢ hyv•<ýdú|µ•Cy:„€A¹`}å¹ýî{ÎùDàâ³³îÓ7Xì݋޵“\½Ù»Ö³£±†Û’Cff&F-›B§Ž#/“ŒL ¸òpè'«óª;Sõx0ݶ›™ÁtŠ¥±IãhÆ"¾È«G—ØØ2S;hdfd¡nû†É¼0x¶#ªŠ cJÕí«˜ñÑ6ªF‡×C:vŸ491öL#3#¿ 4R·$ôŽÇéUÙ)¬[°SŸNô¹ûušn—“‡©¸7Ù;ó'š#-m3ë“ëÒ£©w™ßµ›ø}‡ð¨Þ£Ü3DS_xmܳÿgï<ã£*º8ülI²›Þ„$”„@¡JEzS•"HUP)Šô•& ¼ÒA¥ˆÒ‹¨”Ð[(¡RIôd7»{÷ý@4 PÔy~?>°¹{ïì¹÷žóŸ3gfèèiöDqAaS…ö#†1t&»Îö¥nSs^ ·ò¸Ëb‰Š1€c~¹”KlT.e•É1e½påËõ.ܱÊÍ¿ZÐëˆØ¹ƒ¸è¡. IDAT³öé]éñ³Ü¥ݺ”íõã®bÆ‚CØ¿=…>~e8à%wÁËCÁÑ[·‘Vx¡P-ÑQɸ{{äë½ÈÍÖ`0U£VŠVCZ. æTPÃå¬û¶Wào2š>]ǹ‚ë—Ó8YLMŒÌêZ²ß¶GËí3»X½ògBrkÑgÊWt«fç-¨ÞkÓ•3˜09Ù”qtõ6{t\b8øëUš5£šƒ 2t$ÛÎØrùæ›×%bÂóEQ…>´bÞø‘,n±–áÖÈu±ìþ|?Z¿Ëζ֠°,›c‚ç.蓯säÈÅ"C•¯SެЈO¦¸5,$ès‰8°š6à\NºFß:–<ë§s„µ;ÏÁµë‘¤ª*ñJ‹×™9âUªÙ?‹Þ„ ›†¯ÑhÝ*vÝlÇ»•ó_ÃÀÍ £è°¡à7Lëälj-°Ì bwìæ„Kk¾®(v‘{¸žÖ±go<öAÎ|ýž3’FÇùÐTö$9ãrÿ•´lÜ™ˆekW–T5›nDei‚UB#÷daÔ±k_"íÝø¾ŸžD½î¤ñW¸æ%hB\x¡5˜÷¶5I#'ÿˆå§Q/x./F£yž‹•²ã8µû'Vü|uçq ¬e^À'5YdèX+õ¤…]&Â`G}[Ù¡Ç8oZƒ1•xïXKÿ7˜½Ày"§~šGðØa|¯Ðc^³?“5ú{‡ÓìÐc„ªýie›Fòi Cö½!YJ&:td¦Ü!ÙßË›`igJr‡Œw‡/¿ù’/´åh>t ïøæÕÔëÂX7q>›®jðl5„ÙƒšRìV'Æ4ÎnYËŽÐH¯FjY•?ãÛöþ8”¹{—HÚ5“áë³hÐõS¾ï\ —ÂéU™9¾¯ÆTýt¾˜ú=® GÐÀRöˆ¸ B™rˆ9Ó¬´ÅŠLÒdåi1ä#^÷”ÿ}¯ELxÞÈ)×ç¶&ap« L·uÆ,%c@–mFCó²ïüT—T*¬ðó >lì‡ÓSt¨L*ÿ!J%f–îÔhQŸ®ƒ}ñ)oƒé³îE¨yç­Ý|²b­§t¢¼òžãnùù&·}1ó «N¤ÕȶØÏEÈȵ›Ä“›ßVÙÙ¬ßÉú¿}°Šwý%2µŽÑ¥e°tS+̔ث@›c 5_¯TŸžÁâ3Ye©Ä\¯'YcÄH [ò]G“Hÿ¥Å„÷Ô4¦®ÈÀÞJ‰Î@²˜LûB±µµ%55õ‰êçííí_ò_§@ei‹¹"=ó–°'6•H©<õ­e  cÙ¨)´mJñóè\3¿_”cW©*å·l`pè 7±Æ«ÕÔ±Ieëú˜>­éç61uu·õ6xW¯IŸOûSÝ"Žãäë÷7’S©³&´ÃVeO@ëZhÖOä“P= –2æäý;fN @լ‡wfŽ¢•ý=‘kíÿÓ—¾QŒß.O£^#häé‹·í#ŠdfX:”# Y]º ôÅ×Ãö‰ý»Ìªµjç>b9ŽÍG³"È›GÅ/™~½&0§~nù‡IŠ‹ rG ˜L£þ:2SSÈ0¨pp°ÆT.bÂs{³ªŽãDƸbî£ GÿÌ…éÄÇ&£³r£¼C¡%EËê˜9¢vþÙ"»};¾XõqæÌ)j×®+,ôÔj3•ã‹§°Á| Óûû?|ø;?ú8vs0`4“;{þg·øðc:;>òyè1\+ò™‰“s»«Øº&–ß³_\ûÕnÁ³#ôâE¾_¶œ»))¥î <ˆÿÇ>o?ô²~jùðïh‰»t ×Úø:ÈÈŠ»N4åðu·(°¤nVrò₈ Þ›ví:þç~wbbÎÎ.ÿù6ìÚµý?­MkÄ>ϼËdË+ÃfásGƒâÁ̦Ç8{kêAƒ¥˜(S|æa$2Ý€ÁÌ”z>æ¤åP¶°Í‘þþ,Z0ÿü Ìp¯þÀa[¸ûPµÈ1 ,ËcáXðSSµê©¯.S»P;ï?ê‡d‚µðNÏ-.ˆ˜ ƒôϹ ;§RZK„ÙJJjT*Û%å,Ȳ²X±9‘‹©¢ðE ü+₈ @zÁ¿QÖ"࿎XáJ @ ‚^ @ A/@ „ @ „ ^0öJì-”\ŠËƼp.Åæ`o¡ÄÁR¬% ¼(ÌÌTh4aˆÿ M*•Jâ!ˆÈ$xiiVYÍ¥Û:fïŒçn–^DðÂ;˜JüÝÅJàÁ‹ÂÙÙ…‹Cñ÷@¥R ƒü‡ÄüÅ‹¡/|c+!è‚' cU9`ÂÁp!æ/™ üÝMèà+±Ë@ðBprr"))‰#hµ"Sÿ_A¥Ráìì‚££“0†ô‚r™‘Î~2:û™ c^"„˜^´¨wrÂN ( ™„ @ !è@ ô@ @z@ @z@ @ ½@ @ ‚^ @ E¬C/x©IJJ$11­V+Œ!x¡˜™©pvvÆÉÉYC qA ü¯ôAI¶F£¡Q£¦¨T*aÁ E£Ñpñb(IIIbS@Ä…çJbbÎÎ.ÿÙ6ÿûxDÉà%v`‰øû×b^ðR R©ð÷ 11AC qA ü¯ôAIÐj5Âi ^² ¢F«ÕC".„ÿ‚^ @ A/@ A/L @ A/@ „ @ ¥á_·½1+†3'ÃÉq«A_ûçô%rµ ·CØY‘®¯z<£ëJHÈärdOo)rSH7ÑsaÛ5¼Þh‰·Ø•@ð/dÒ´é\»~½Èç&J%}Þ~›ÖA-…‘A^NŸN\ŒOg,dâKJäUÒl«àe+‚@ } …©^'!7QÞ" è$P*O'Tµa¬˜º–ÌWaÌŸ¯|ÊgAŽÏ|Bwe-.20l¤§~X §óº‡¢Ì¯c¸¶†ASÓºòCê?îÎIw9þãF’_y• ¶Å¹Ÿï€/;Øe;”.ñ[Ùtò>ih‘g#éç7²ì´}ú5ÄYa$73Âku¡ß¥Ë"5[Ž¥Eö5¶üï/¬»÷§u9“ódi3ÈЫ±±x` cêuŽ_–ði苽ìÙ_OðrQœ˜Ðéõ¬X½I2жuë—GPfÆq%ÚHùªå°zÂçUÒåc0ÅB¥øGÞ³²°Á“ úëìÝBÓ–--èiœùe#! †ÇžSîò ow Ħ¬~‹1‡° S˜v£ ó?ráÐO!Ä?¤ÊŠA l[c§–ÅÉÚŸ2ÄósÇ\¢ËºOñYÀ¬è¶LËš½ßÕk)ŸÖx"¨hlHË‹ ʇv^t\(Y''“ä;:,œíP{Ÿ 䤥£WÛ`eú0UQVÇÿA/%ïbܰ“-›D;[ú‹Ëyw¡’ñKR]Y¼ɉ>ÇÑð4Œ:oâQN–ïÎ7Ýë ˆ×3nMº ¦˜=EÇãî•cœÏ}ÌaÖxj7ðý±©Œîr”/·_ ã°@T€tk+ŸMßNÌ£|¾¢]&Lâ ϲ|¹³¹yâ/ny("èwÂøë°Š&3Û¡žq«a¯¢;ަaMÔ€!v7Á‹¯ÒhRœZ/ÌFï`¾}Ë‹ügÓ]Æ{ßY0qé j˜W¡m³ƒ|:{޳RËò9Fbc"{ÆugÀÿ¢°-g‡}—ŘÚ@wv>oöÌỘhoúì¯'x9Ù°zUÿ÷îÛ£ÑȪµë^Qo¸¹éÁZ>ZU‚Ž{1"óÔÊYÌÙ›„…£%Ö †òåÛ~/áP¬‘ô›§¹$Uæ•ʶE’.OeƒRø÷ÈŸÇ1êç[pÏF¹¹†ôæ\˜ï7g1ïMϼö*±´wÆéñ‚ÞÞ‚‡u­ô©×9üû_ '*9É׊¼Ò’NAþ8v*Æ .þÌŒ¿Ü:½%NÊœ]Ò …ê^¢FfcO–/ÙÄåqy§:ÇêoQmteL2r!Î »ïÿpJs;,ïÝ„âcÃÖ¸MaÙ€ªÅ>g²Jªåãö2±çÛŸ¬Ã÷Q»xÏ9³¸°òÞŸô#¡J„[ÐÌýö3Z»+Êøà zííKœŠ”S¥¶ΦϪ™F²£N³Î…d÷+«÷fb{)³ê#ŸR`I;ÈþSÙvÙú»ÜH´ –›5šOe Š¿·ÜµÃÆú£}äuL±w•ÊP…²iÕA¢ ùcõuR³sÙúí·–ì´ìוÀR:J™c ÆNËEmkA­j÷c\{—mFê2ƒv¥v22,k¾Í`¿Ñ,ú¹1‹øaúœdÕå|¾XÎÇgo2ºrÁÇZY­? ë T>Ÿë ^,&OáÆÍ›ÅŠøbßòûèL¢“SÁÈåÊm•YàÓ¼3>O^²¹±û;f­:i`s‚šÖ$cÅïxõÆ«Š+Ù;‡a;ê2â³!¼êvÏÇH©—Ù¼h!1m0Må@%šw­T‚`DT®/-j†y)–,)ˆ‹1˜ÕkAU}‰gOrYÍÍéãø 4¤,©ùötfv+ü‰cË‹ %‰ñ©'æÓ·ç×ÜmPï3R‘¿'mJ‡±q Ý|•ß›8£ÌgãG]èÙMÆC4-«cþý¾¹U»ìßµCª—MÐçFþÊ„qk¹n0"óè̤É}´–=ÇëÐø=f6~ÌaºS|Õw>—ÃkÓªÙG|^Çí)ËmøtǬn ¢‰Ûødøüü]0•º¢™=ž•íKïf4Ñ?p·¾íðý»WRß:…Ô\á·u§¨Ô³ –2ôW6ðéÜ¿H1êÉLÎA¿øúÿPèžhÓHO—1{ØiLy¹LžØ‰ rЇïbsTm†syBÛ©©Ù½=6ŸüÂÁîUieû|²1†Èp¢ìjP˳è#-w©G·×Ÿßõ/–ûb¾Tï›ÑÈšuë^Ao[…ÆŸì»Rb<‰^TvþggüžÆ¥JAȵ„m_Ëù‡P5QÄé8²áÄäÛTQ¾ý;ûcY&WÎ寖ŒßaN¯©‹èêc‰<óOÎ/uÁ·Nuê;P¿EZ¬šÎô©+±›3æ2ÈM$Õ­_n†[ìn–÷¢W'?J’Ë‘²"8úÇ1n²ˆØ†›‰ˆÅÔ­ëEzˆ‚ñ—qíô_õõÅBfàÚª‘ÌSŒbF·òÈyÚØðbâÂcýø…/i×e=óþbCÍM´Øþg!£E°fîVÜGŸblç{‰:óʼ9÷Kvû½Ç‚}£XÑ.¡lŽé`!œ·àÅzcÖEV|õé­&²º—;gNgêT%S'÷ÆÿqÞE’0"G^ÆÙczIúr4èÚ™vîϯ6MJJ Y錋m¡kJ:4ZÃ#Ë„D&¦f(óŸBîL`«×zÄ{nÌ4áØ†‚ŽgFo€NJ`÷× ˆkû1j§0„m`üOfôÛ*rÀÌ–{z®>Цîj<ÅÎÚrç4)·¿Ngd}o¸W‘¥Í'ºÃL¦´w.³y ÆäÃ,_²Ÿ¨°3d¦›±zÚdþ’+ðhûÚ!ô§‚é2^Ëg;'ÒØ0\ã»·‡;tšoâÛ¥›9_—©['ÐȤäÿ‚¥n!©(×x 3ç~Ì«Îò]¬K¬Ÿ4ž9¿œ&.Ç'ÿv Ÿ>“!õíå^`á;£kó»º  7W2pÈI:®ZÈëòy‘?{ß»o?tzýË!2Â73i¥žÞ“{Þ+A”âØ>gÙmÞÀ"d-¿žˆ"MæHÍ΃ø°‹/–20¦‡±kÇ9’bn’“c¾Ÿ6*“ãT»#m«æÍÑDq`ý6…„s7Wg:õéK dRÛ¿ZÌöéj¯»C¸t·2}'¼IuyÛ¿^Nj£ röþÈ‘¹¸5ȸîfì]²’]WR1ójÁQïPß^ÆL.üò]!*)lÔ¸TªO÷úÓÊÃ)ù¿í»ÌͰ ²u°n}rä8×éHß{m-bƒ’´ÿ16*ÞïšâT¹µùâˆÄÅÃY”¯V“ÚùT2[GLïÿWw‚ùCq4·7Ö´>£¾Ÿ&`ˆúsé2cÝ+ÝKÍâH0uÁÕ:ÏÈmì7ŠÞW>eåÞ|ÝÕ ¹ss r®°báZB§Úº`öF>²¦“Jí>à:õé7²:agóå­ 8kÁÝ[Kš}wŒeö-1çV³¯ý4º:éH¸Š}íûsО>6<ϸPrTQ;òF-¤+Åü=ó‡/xÒê›JK¦¬šñZC “]FßôzÙÓ¡"=$xþ‚ޘƱeß°Çòu¾î€µ ôül<ÚÉÓ˜<ÃŒ™{à£~Ä÷õô(Q*%ü%Rc"Ȳõ¦\ gñçÞ¼Î-soz;?þxéöi¶…ÜÆ½Q;ê¹>‘¸Nªg#*²¦öÈ^>J‰|¾Â›>óçÒÇ»”mÑæ’‹ ¦y¶”©¨àí’ öf22\¼©T±  ×%©ÁÄŠò^ÞÛ,¥påj ^m*ó`I¹¼ŸŸ7¬w5ÄÜ"×X­ç¶ÃÇÇšWnb Ì;—žì´T24†2~‚-qpqE{[\¡ÆÞÅW…‹nSʈâÂùÒîÇlc6q—OspivEšÓcØ`&V«†¿òžØÿöÍî¬ XÎöKñTÜfÿgxû=GŽo}÷Ç]OŠe}ÿטl:…ŸOn!Ð&‹°Ÿðfç×ÑÜËÞX™W†§UÓÿÑÉ.šÕ#'q½å6: 1/ŒÙÉDDhÉúû-wn…²}Aû eî`¸±™‰³¥Æ\úVT€\…µºSä2S¬lí°“É±2Ëó±Ò]̛̓·˜0•Ì5D^Éô©³1O¡‹«–;Ñ7ݽ€ f4mß–w*xà­$-w¢Bù5ΕÑãçò®É)æ~²ˆOC+ÑrÐ$VŽÉfÇ´OX²µ>µTE‰„©=>ìMeW;,¸ËÙu³˜õÝ~jLk£R…-Ö*9r¹v¶vÈ‘ce¦x¸ JÒþÇÙ¨HºKäõ2±ÅÎ6¿ÈWa"Sbnc‡]Y¬)\ Óâ^Å{eMÞý½‹œó*«Ç/AóÎ× ®YØ‹šqoñ=WöÿNrƒt«ô ÎB}‹$7?ÊçoªÜ-+³öÈÒº¸a'ôñì›ÿ5ÛÕo2·»¦×2ò.˜62ÜÜÅ‚ ºkƒ—BŽ]ySȉbßÒ9¬ˆ©ÇØQ6¬FDZ¸õýü²îq ߢKä6¢b%°ãF´5^]Ìï ïGƆ’*úçJˆÂ¯#o>ªsEŒTžöE¹PQÁË‘¸[1ä–Ñ1„ ˆJ–2À‚ Íޥ߉¡,ßs•ýT`ÔåÊܯúPµp֨ĿóÛ4v1AFUÍåœUWzآĚu=Yq:†lcU¬eÖTkÚ<ß—©Ý¼#ˆ’ÀÙ¶*-^«ŒKÜ6hêÒ¾}àcQÉÚÿþIYáìÛ¸“ˆüó”Òc¸p#™âV¬æ–{>_h4‚Ò›Nõ£¡6ÎÎØHw¹pè*æuÜk—>s…lœpq6A—xŽáv´läù`>—”µ«iTm_ 󞇈둨+v(GdX;9£NK!Õ¶Y×Ù27˜N¥àùvm¹©{6âׯþÖUhö©+§6l¡\‹×püe+¯ßF_.Œ‹©éz¿¤ð1±¡„Šþ¹Å…2{í4ÙhPc®*ü«e¨Ôj$MÚ2:&žb¢Ü¯Wϲžýam(ü¹¨©A‚^¾‰Ù?ÄÓtl0­ P™M ƒ&Bûù&|mFð˜6x#®¤Ô»¤ÙØñ¨2:cÖ5.Ç–£z k”¥ÛØtÄ”æ_æs’p-¾4nªÀÇáéÜHÎ¥ßø5‡î£ËuHr%&=½Ø‹Iñ¢z¾Q ¹}¦®h‰é#ËêôDž>GZ•nT)Üñ—YQ½UÜË+Š^/*™kŠ–ÙÐë(Š-¿•a_³} ¯rs"™]W‹É|( ø»ˆAf†½»ûKôè›PçÔ+dßÜëWˆ§p`þt.Ý> ‘Ü6Þ"<Ên~s/åZ…ÚÚå¸- ¬S…Û».rÇØW™-­g}KëoÑô7_>Ý5š¡æËœû%5%™[’c^(2*xº=x÷dX[BNvFl+²ôQ7‰qª˜'†d+UvçîéhÒU>-ZáS\I…L޹Ú4ï:rÔ*ÌÍÕy>O†¹…9èuèþöñaìÜø+B£I7(éS‰Ï­…Þød?¿Dí/¥d6õ41o}F)‹È#›ønE Õ{Mâ}÷]ŒùÅ“÷¾èE%%3/²bÚj¤ž½i˜/k/Ý>ÈÿŸ%hñ+…Ú–GÆU¶}{žLÏiô(w¿eÙdiTØX›H`] ËÀ§sÅ"«áHZ ¹f*THÄï]Á6Ez×]KHiÅiV.ÃþµÇ8ºûÖMM0$Î3†uÍMð ô#iûYÂÌŽí×:_yÍ£bC)2â/}\(ôŒ˜©1CCŽö~äok¢Ñh«T˜–Ñ1b…4ÁsôÒÝc|üÊÓTË²Ø "·¯ÏûS?Dûù7|6×”à›ã^à*ñ7#Ѻµ§ÜCƒDâÁß u­Ë»%Éžk#ØòÍz¢‡0Ö¯dÊHQ©útÆ“RO±ôÛý¨:L¥ó“u Œ©Çøqw}S`A¹ æ–~Å¥;‡Y¿'“F#êc]4ZQ£cÏb¾ÃÉ3ÉTlYµhÇGn…eÑYÒS?X™éYÈ-­xy÷e‘´ØS IDATãìZ´fÓ(IM­ptpÄñï?:ÒoV5½JPÊ¥7`T˜P¸šLibzÝ=A#™‰56jš4Kl-Ä’eÏŠÞ}û=qGà%WøÈ¸7™·D¾Ê \Yä¹T(`Ð#ï½¶v6%Ê”Êd²âZƒÑn°nÒlN åÓÙ¯àa!Çpc=Ã'$<¹¯-QûKo#cNŽìã×_wi î‡‹˜ÒÚ¹Þ†.¿MdɶÆLošÀª™ßrÂc³ªæÏ¡ê¸º{1oÐľx«™TêÂЖ™¶ò ¯Žo‘çS,±¶Ðp#]ûw–Ïp<¦ -Ì ÅU=WobâÑG¹eÛq,ì¢âì—ëJ-èQÙááéÈ©­»È­Óƒö51Dìgù!Kº÷©Ž­R†E­¦ÔYº„Y› ö°º´gņ—?.z¾ÜÊã.‹%*ÆŽù…L.±QI¸x¸cê–U&Ç”ux²Þ…Û V¹yÖª¦4âӨ£åûŒëáýÈò…ScFMŠïÕÅ|¾0„¤ü>@Šãè±¼kT{èD%]ì^nˆ¦v·ÖTxL uI§Y5y 벂ó~ìŸË¸‘¬ˆ}Ì?‡ãåÞe|oŸ'*“2ÂXü§Ü{ñÞ«ö¥ºRÚVÎZÆUÿwé_×¢„ànï_ËowjѱY1ä.xy(ˆ¹u›§sÛZ¢£’q÷òÈ—u0›EŽ^zI}ÈŠZÍÔ«"årí¨Û(C‡æû7¸7 ]‡Ì*VÆ=ö*ášO)áW"°ªX)/ gslúP6Õ]ÅžÑÙ̾ŒáŒÏW7ìïÄ›[ÐÄE' vuåþ<ÌâÞ‰Òb¸uœÃ‰5éÙ·!÷N¬¹G²±ÈˆÑPÆí/Ù§—3ðÝÑ,8”Eõ·úÒÒÁ[{ë{~QéÉë#º mšÈ€Q‹¸Zs$_}Ô¸À¨¦tç/Öí—êÖ»‡šMEõ×{pe[®æ_Èm©VÍ‘°cgI7Þó×wï#* 9 0cÊ16ÿ¡¥A?L™…5VO¨üäv¾4ôÎæfREºöëAÛ5ÅÞÆíµ·èÕª>-e`^ÕsI‘7àµüq¥LbÃ?!.ª> «Fpਂ¿;;„ýGM¨×¨&euŒpS‚ç)èôì݈’$£•î-3ea¿²?R?BøÖelJ¨Mç®E³£ú4Âÿ\Å短ävÃá ojW¼P•4$‡ç—¥Süþ;¼AðŒþÔzÖ[ ê3‰¹ð'kçŽaà§ëI¨7’¹ãÛR¡”o¢!3†S;—1vÄ$¶É:0i|G*”p¬Ä¨IâžåŒýp&ú0í£¦ù2É'÷ÎUö¯˜Ê'Ëã¨?|Í‹@fÔ©JâÙó$>Õ†q*Ì–:µó-ª¿ÀâÁýÿ[ÒKüB˜Ôy‹·Ü¶338„éAÐIOI§$k (k¿MŸ {™³à4y&ûòR¾ÜlÎ[ý_Ed…LeèÕ˜1½?\Èдi ÿ>¡éÏ E¥WiåtŽM¿Ý ;ï¹ÔFïáç3Zù—éü ™…%æúnFßÛ}C—x”ÿm-ô|˱²¶$'11OÔ>ÿö««ucú’•,Ÿ2„îõÜ1/äGM¼»òÅèÆØèU8:Û`V R"•¯ñ=«=:#³mHïö¦ìßtˆ»FÛu¥ê…ÌÛvž‹`þnÞlœ¯c`$'6„%S—p©z?Þ®©*ƒ;#‘žaN@]SöNÄ{~Æ÷7ªÓ³WÞ8–[{²ô‚3¾ê£¬Ütío[?.6 zt:¹ùþéô…Vxû'ÆEú|Њk_dñ¹ô{mÔŲûóqühý.´µ.»c‚§ä™Nª6õx‰‹[¡P*AºÃÁo¾`î kºŒ]DPJÉ{™ðövrÕ• ê9™ ªͺäœgÕôì¿Í]¹+þõšòÎôyÕÇö™þ)þsçnæTÄmr,½¨Ý¨9£´¢^9u‰2ãÆœ›üµã(Wã㉊ 'ìf êJõhÓ6_4«ø˜ì’‘ôË{Ùrø:Ñ·Â »‹TþÚ æõÆ9t)ÅfÅO‡¸ró×bô¸Ö¢ÿì1U|XF_†MÃ×h´n»n¶ãÝ'Ú0ÉÈÝ#»9áÒš¯+þKILj1îçE¤|‡ê>øzªÉŒäný9œXõ»áÊ|úã·$öëAÕUÎxÙfoIÛY™ÚD ™‡™2t-§§›³ ¨Áèo²©Óp¾k½“÷«ˆuÏB˜xñæØ!¤Î›ÅÀßmqµÈ!ᮚºýÇÒ¯º)eÙ›”»´¤_ÇÃL7„?œÔéÒ³ÞKnôîZScÛJ>øð.J3ê½?‘·*+ž[ûejÜÕ€QOvZ:Ù=‰ç÷±ùêm¢£"¹qKKýÑÓùj² óæ|ÎÐÖôíÓ>¶(õèZ1¢Scìe:Ro'‘%7ÁT—@ŠÆ+SY0[±Ý›-O$Q ö*;´`ô¸;|ùÍ—|¡-Gó¡cxÇ7¯[¢ cÝÄùlºªÁ³Õf*YÒ£„„¹ ¤\z…ºP\”ãPýUÚh%²â£9mV“ ·ë,1ž˜Oãrd1ß·¢çÄtµ9ͼ/f2>{8Ÿ÷«³òQ±Á@ܯŸÓå×B·Ìãu|ÛÅ?9.È)×ç¶&ap« L·uÆ,%c@–mFCó²‚F -˜/ !x,r3 ,Jó….æä8T©‡C¿­ÀTméC7u4Áü¡+¡“’Ø â‚@ð\‚^ð˜¡ÂΩ”±L,qt¦D\žoW_ @ A/@ „ @ BÐ @ BÐ @ !è‚'ÃÌL…F£†¼4h49¨T*a@Äð¿BÐ %ÁÙÙ…‹CÑhr„1/E0¹x1ô…o¬"ˆ¸ â‚𿂈uè/-NNN$%%r­Vdd/•J…³³ ŽŽNˆ á… Jã¼œÄ ,‚‡!Jn@ !è@ ô@  T<²†þÌ™SÂB@ Á?QÐ×®]WXG @ xÉ%7@ ô@ àE Ö¡@ð!))‘ÄÄ´Z­0Æ33ÎÎÎ899 cA/àŸ.æ5 5E¥Rýg~wbbÎÎ.ÿÙ6h4.^ %))Il*öDÉ@ ‚ˆ°MÄß¿ÆJÌ @¥Ráï@bb‚0†ô@ þÉhµ!æÿ³¢^V«†‚^ @ ‚^ @ A/@ „ @ „ @ BÐ à9‘KZjúÛÇÙüç-rÿ!­6fÅpúÏ?9|õ.úç{a"Oœ&2÷_rû¥,Ò3¥'û®>¸ÈD²ŒNHJd‘©zñj BÐ à¹è¹Ä|ùù2ŽL‰Û´˜7tez~ý¥Ÿ˜´øÉRžTÆŠ©K8r7‹››ƒ™ý{2ŸÞ¨%ýNÙ¥Ö“FrîÄ“òC ·Øû[[Ì¢gÅKqŸõ©×9üû_ '*9É׊¼Ò’NAþ8™Ž·\ü)˜¹1tzKœ”88» =ä9QبÈ,ðoìÉò%›¸<Î!ïTçXýã-ª®ŒIÆA.Ĺáo—BBâý.Cin‡ƒå=«bw¼ø*&õÀY åð‚!¬q›Â²U‹2ó*´mvOg¯ÂqÖ@jYÊþ•ïkÖÙ7ñ¶üy…»˜`Ô™P±íG,øî Z»ÝWY\Xù ïOú‘P ¥FÂ-èæ~û­ÝÂé žŸ ×_Ù̬?œ2¤Îù”®1ë[‚ÄñÃþ|Çš ³ê¯þçZ$3„9ïmÃ'xª-¿ªyXˆ’c_ÿ†¹#7êÑdkÑç;Ô˜°«NѰZk23‹qb2*sJ™xA!ïâÞ˜w‡T'÷!îGn[/×™š¢ÆÙ±Ój—áÅ¥TΟÆ\§fÏö[…%Ùñ׈¨8œŸ'¼ŠùýÏ¢N³†Gž8ƒŒ¸_Y½7ÛK!˜U‰É³·$nm‡ð^ü>M[òñLLÜ^ñdÌæÆîê<¦Í jZ“Œ¿ãÕo¯*®pdï†í¨ËˆÏ†ðª›2ï¶\fó¢…lL`Ä´Á4u–•hÞµÒ㯧M"*×—5ɼK–”FÄÅÌêµ ª>‰Ä³'¹¬ææôqüHš Ò –Ô|{:3»•G.%±wÙf¤.3hW*ñ)òæÛ öÍ¢Ÿ³x€¦ÿº·ÕHv|Öçr`ECª8ªÑß>È—oõ ç{å Ý6òr#I[†ÒalC7_å÷&Î(³ÃÙøQzv“qàÐMÿý~­U»ìßµC8ù'è%n_8ƹÔ.XJ[Ë,kòî»G³%ÉC›³æd9þÕPÒ­­|6};1òòŠrt™0‰7<ó8÷&û7…<ú{ûk^éÚ ¿b†Jýr¯^à²yº8§²ûøuxs -ÝäE²B»—ðû­t$Ü‘¥ÿÅì!K9£`/}®IaJħY_¬åkòÁ÷ãic#½@ (äW-Üð©æöØã\ËþÚRü_ì ¯FßE_ÐÞ¡°ïÓsqùû|‘b–OŒËqhü3?æÄºS|Õw>—ÃkÓªÙG|^Çí¹Ô|u¦xTwábx –+rMcV|›£j3lœËÜ355»·Çæ“_8ؽ*­lÿm1O†Sû±ÌÈ÷‰©k3ÆLx“ï»ìäpÖ@zYD°fîVÜGŸblç{#[æ•ysî—ìö{ûF±¢ƒ…p|‚ç 襻œ9w ¥þ,ëWÞ,ƹÙòz¯&8{)ø¸r>gèÚŒacýS³hнk!aÔ£ÉÌ"Óð¸$GGŽ\ñ]+ü,ž.û‘—Æ 4ä4Ô|¥Ý25åkÔ§qeE‘ ¦>»œ÷_g› &ÿô÷_5—W2bêÚ|5ƒ7<ÄPš@ ø‡`LçèÛIiú édI¶XÈ &3Rîd`ãhSj‘kLO"I_Ž];ÓÎýYJy=ñ7 =ËÑã'8…Þµ Ú{¡ ï\`ç–ã¤ôF2o]$.pë?¬MYM¢~cÁÆ\ºÌ˜D÷J÷Ò²†„8L]pµÎ³‹Ü†À~£è}åSVîíÀ×]Ý;7gÐ ç +®%´Ñxª­ foä#3fTj÷ïÔ©O¿‘Õ Û8›/oUÀY îÞZÒìƒø¸c,³Gh‰9·š}í§ÑÕIGÂíTìk;æ‰w=×ESw5ž°¦KîÜ€&å6ð×é ‚‚ò:Hú‹,ýh>Ñf2¥½ó¿nBŸÌL…©L†LdãðOZ}S‰ŠÀª¯5Ô0éÐeôê!ŠsÏ\Ðbþ`ï 7ÚãÄ¥DNï¾Df`OZþ›™=ž•íKß*3:öy|»n®çâ±HÌÕ²§Ï~ÆÌ3ì;n¤îHTœ²x˜yŽÿ-Ü‹Y§x]ÿ“½×âàl«Ò´N¹bëSÁýeV}ö‡3%• ˜ÕÀü(1’}™ð;:Œ%ü®‰C%ü=,óüºDò‘e, ­Ê{s=9µp8‹¢}iÛ¥+Ý[ÕÄÅ 0Ä-Q¾n9J›ªÈ½y[æÞôv~Ré¦#ü÷_/ߎ¶¾Vùb‘MÌ ¶®;Døµë\½Áí\+<|kPÿ•î|>¤~.æŒò møxb›"×:1oKm¬Šé¸<õ\Ùÿ;É Ò­Òƒ Mô-’Üü(Ÿß¨r7Z´¬ÌÚ#Hë↠Ðdzoþ×lW¿ÉÜî>˜^Ë ÈÛX(.îbÁN݇µÁK!Ç®¼)äD±oéVÄÔcì(ÖŒ £ãØNÜúþ~Yw‰¸†oÑ%rQ±ØÇq#Ú¯.æ÷~»”•«)xµ©üä‚Sn‡5¯ÜĘw=Ùi©dh ÿÆ™°ý¿“T{¯˜ƒáZ1RyÚIð©¨àåHÜ­ A/xÖ‚^ºËŸkwþêH¾X$»î8É{oacUÈíI:4ZCÉžL†‰©ÊRúyCRw¬œq6)ƒì1{·r$¶yf1&shùlnÓ4’v3 c“?˜Øí3ølÃE²¼ÞanGÎ/Ûɕ H©\=vŽ”:£©_»f¢âF ÜGáI›ÁP__Øsæpâ38TñCFµÈŸÍ”¡°¾/® Dì[Æ×¥•Phʱyu ø£¤øÝ|õ}GOãUkdãâöçv6m fàOåiѵ'=kÞât‚ͪY–2C¯!ôØ9Šïªcjëø‡±] ]ÛHVä%ÂýñmÔvý«P¥‚#æO38jÔ’š®ÃÊ«¸ßùv–R¸v5ªí«åÍ?¸'þ"®G¢®Ø‚}ÖNΨÓRH5‚mÖu¶Ì æ‡S)x¾]SäÕR¸0K¯:Íâý&4jDàýP–žL¢UG¦O®Cêžøõ놿uš}êÊ© [(×â5ÙÆÊë·Ñ— ãbjEºzæ}YJ&1E“½ê)Jä8:Ú‘}ö9F°’ ?ú~ù zk§]vÞpk5Ÿ/NãÍúà)ƒ& jÌU²"=•Z¤É!Ê4Áw¿^ýq<Ëzö‡µ¡ð碦þ¹zñ¿/aÙµ¼?¿&ÅMu•’≓\©íRð•Ô™ÃëÁGK¶>²Â›>óçÒÇ»4¯µÈ+á¼ßÀSñÀ1>iöÃ6-„5[¯¡£\^›|ycü’ó«æü‚OxòÁ{p´Gíêñw–ʘyƒ!WI²hÆ”1© ’QaÄGtÊo«ô+ü²p>ç«õcæˆ&X 1/ Äw Ü*ûiHq\0Èqª@µª¶VJj ˜ÏºO(¹\[2úËF8¹å•D˜8àߺþA¯yl~šÏÐÕÙ(ÑÔ¥tLº}€MGLiþE`>![Åéuë9W¡# ýÍŠˆE‡&ï2¾¸UnžXЧ“–VÖÖňͧ±s6Y6Ö¦ùÃ¥° |:W,2ê!i5äš©P!¿wÛ]è]w-!¥6_.ÃþµÇ8ºûÖMM0$Î{木kn‚o IÛÏfvœh¿ÖùÊk èõ OY=ªP*@2<Ø@f†½»û¿î6¦eZïqDô\ËÊövÈ™™34ähï÷ftF5 r•ê9Lü§}˜¶"‰ q3hRìD#i—C‰._ ?ó‚7kü ¿üb|lCeæ%Q®´Ã°ú›:v—ª]j÷®cnñ1±dß¿^ì]P·À'ç ¦/%ä®yõjø™è*‘ph³~8²ù0æ¾]g1¶&J,È®gO%/+žY@¦ÂÅ­˜"i¹^Þ`„y*áÓ.Ðð­”Ê]k#ØòÍz¢‡0ÖïI–òлosþ²¥gp;Êsm£ÑX¶¶2HÍ0ÅÚº¬‹"-±¶Ðp#]ûwø•Ïp<¦ -Ì Ý[=WobâÑG¹eÛq,ì¢âì—ëJ-èQÙááéÈ©­»È­Óƒö51Dìgù!Kº÷©Ž­R†E­¦ÔYº„Y› ö°ºt§Ü Ë¢³žnÝôÌô,ä–V˜ÿ‹YÆÔcÌêÞƒ5æ°wN›¼ä(ÜÊã.‹%*ÆŽùƒ.±QI¸x¸SÖ³í^†¬wá6ˆUn^  7­ÜŽ1³ÚSÁÓ¢ø bˆeÿî+x6y"sœäJLëô Ä^¼HŠwÕKµÒ¥Dò_Ù]ŸQMìòePž4ûa†e¹¦ éQ•“GšÌTRRî90cÆUöŒB'ÅðÛŸjÚæM’éÉÖƒ1ñÙõF2Aµ©á ¿sƒÓ‘i6MA"þØIn87gœ¿œ[çÏp nUýH¼zZ<…Á¿€Úµë>£3ëˆØ¹ƒ³öé]éEL²×t3Âþí)ôñ+¹ÈÕ%fýÜ…lÍbâø&Ø—¶¶ÂÊÅ-ß0sC,µFÏà ï¢!K¥2C›C™Jzci™ØX•±)å¶T«æÈúcgIoÖk™Žë»÷ÐÆ…ŒcL9Ææ?´4éw/{kaÕî ,·ó¥¡÷9~NªH×1=h[.…]‡×âöÚDzµòÎÕiP=——›ñZÝ|1_î‚—‡‚£·n#5¬ð„å1Z¢£’q÷öÈ—‰6›­Á`ªF­üçÝâv1¦ë»ìô›ÇÞe½©”?ånUŸ†U#ØñG“+>°avûšP¯g5‘¡<[AÜ/χ;ù[Û—òsZSƵ}²åÇŒ©Çøqw}ãTŠäFî`Ί+Tí÷5 Ô·?iöC‰[÷~øéNpò^ˆÀ§Õ;øèo³'øj7'”5Žéw°}õÞðÎ×ipîǤZQ?mŒäF„°å—ëù¶67’};½ö[·\¿g+…#Í]ªÒ@ð¼8sæÔ³9±”ÁÕ‹˜±)“ q]©ò3ŽËÇÿdû¯;8’âÅŸÏ¢Oûb⌂ò=Ю?‰;5iìP:Iú\ruRÑÎ@ö]RrÍq3Õ’“£GabŠi™ˆNÛu¥êG+˜·ÍжÇX´[A‡)ïMzÍ‹9±GYñõ.UÊ‚še±]˜Dz†9uMÙ;a{¬”$§WgôG^y‘RË­= YzÁ_Ë£¬ÜÔ‚½|ò²éfÔ©Ê‚=çI|³E¥3èÑétäÏßËdr”JŃ˜« ãT˜-uzäÓ ú ,<Èî ™ÛÝí\Go$óü÷ôï1™¸×WóÇŒ6¸îw+ªÐçƒVÌ?’Å-Ö2<й.–ÝŸãGëwÙÙÖZ8QÁ3ôõ¶w9¿e!Á¿hé<©µŸ`kX)#Œ Áßqʽó^µ/áˬ%öèæ,ÚKn˱ÌlUh©«§É~ÛÈ»„|7ƒUÚàº]k IDATÎ|ÖíŸïóヮÑÌŸõöÎ;<ª¢‹Ãï¶d7½wHB ¡÷.5E‚ ‚ŠPQ@PzSº"RT)iR¤éEJBz²Én¶Üûý‘IHB@@øœ÷yò(»÷î{fîÌoÎ=gfnŸ¼C¤o±{ãaW· ét+ÑËßaDüóLz¿‘˜‰ ‚»¹-ˆÙþ-KÖlç¸!Œ®ŒçÅ:<ìhéê^–o8Fl\ ¢.“® ¡AËîLz³9•Ýî2\NðÍ„¥l½GªÒ‡ªõšÒwÂ[4w)ãrj7Ø:k$û 7¸v= •w%·z•9›âPÒ¡À¥ÉóôÛ;•©ƒúbçîŠ] »õi*÷aú[s—$®üò £~¹Zü†X¶ýñP~EI¹Îã˜Ö=ðˆN¥{K†LaÚœiŒÉõ§Å«ïÓ·b¾ƒÈ|–Ïbíy#­_aÊà¦x”墲„„¥$“‹JWÄæJÜ«4§m®DvBGlkéÅü7?äêˆ!xï]À—éõñD:;áó1“ø0g(£ú×ÇK­À¹ÑÓ4^ñ /=ÀPu¡±-~Ý(:­+¢_Ëugö¼~„«òoêÞMònÃŒ ªÿËguË”üt1yj;|§øÊ¦s£·ñF9%þý–ðKò+ i]ž .^ئÝ@®ö‹~O#;Ñã © —ȹÅ‘ý»Ù¼a;Û4äå‰ïñL»{d¬ú«Ûµ‘U«ÿ ί+cGv ü]JaɺʙÃûÙºi»®ºÒjà$· *&ïz? WØ0g2ß$5c̸g :x"¯Slò:c³¦2zÔT2?z‡Î¡öˆÜV@ð »fµÊ‘ª=ÇðV“Jx>ª]$Õjlü¨Þ²>‡T$<À›²vp¶åhØå%øìç‚í=¨_…mmûõ"ÉÖWwoʇäm_¶JJ·Ò1=‘ø=F‹Dq!õJŸ"c†’àîù¾û£®[NU{0á«ÅØ?€ÆÏ¿IãÀŠ»”ÝõcúŽÁï¯#Q¥Fa1cSç î‡(§lcÜ_í_‡¶ÇðE³ 8)%Å_åÒá\Ÿ?ëFmwДáS]Y=g9kOUgh--èjÒ·Ï&F,ÝH›O: ÐÒjÔÚ;—«.:×ÐåÛÕ7hýN»Âùêš¼³|íÿÁ³jKוz¤•w«vW [Í©73I¸–ŒÙÑ—wÝÿÝ ?¥!bçÿUA/»õK–ìˆ!..–ƒ=AUëÒ¬ßÞkTç2L¶eÃ%vþ¾Ÿó Ä^Žæì¥4t!õhûÒÆ4«€S‰­ÙJô¯Ó˜ýûY.'šp®PƒÆÍ_an뺔·W>\ïGîß,9…­n½ÿiGÂí@{ÊMPû‘LÑÎcÜÇ#‰>™¡%zÎ$$+(U`1[P(•¢Å ‚2 ¤\ó^ôzÔWõi@¯>÷{²ëºÝß¹š šu úGö²qñ%Èå ¯v…#Á5ª–:dWé>œWí< 9ª°¾|¹²;F“Ie‹ƒ½–‚/*îÍø`IsìtêB6³ó+OÕç>â‹ç `J—ª<ÿñ”BÇz¶ÊÐsŸ0ã»`&¼TµL;Ôb‰góìo¹Ñ~C#Ä®+ymÝ ß b#xä‚^S¹š4}¶>þå¸÷µ}Š\2RMh}*Ó²~{^©F9M¼ÚJ|j´§Hƒð,ó…€÷ö<ú¢SíÊùI\EÝ=Z½Ã¬À¿¸èTÊ Ë–¼ñ1?]·"cKD_„¤ÁýN\ÜÃêá~ǰ§ÂFgM‰‹Kh°Ó•N”u.T]~L ²/°\›‡úÔ(8i;œ™M]n/™©Žàå/WórøF@ žÌù„WÏ{HÒÕ8àá.Ì&<šé~ <´Ukk¸Z·:å‹y—¨r ¤jˆ¥…²Ú¸êçp§QBÌ @ ± @ BÐ @ !è@ ô@ ô@ [[-F£Qâ?ˆÑh@«Õ CA/àIÆË˛ӧOb4„1þcbþôé“xyy c”€Z˜àÉ@–eâ㯑šš‚Ùl”ŠF£ÁÍÍ?? ±fª@ øÿÀÓÓ“¤¤$öíÛKn®ðÔÿWÐjµxyyãáá)Œ!ý“M|ü5rss©_¿:NDP*ƒ3gN ÿa@ð%ê==…°„ IMM¡V­:rr²…A¥¢T* çøñ£BÐ @ ½àqÀl6cµZ‘$ICpWn¶ž%ô‚Ç«Õ*Œ íE ô@ð8pôèaa@ Aÿ_B–eaàÿ„Úµë #à Ö¡@ ž`„‡þ Bxè@ EyHz‰‡±‹IŸJº¡˜D?s'÷'ÎPºà5%þ;3×1ýWkÛËþ͹ül°gÎJ#Í Vô@ ¸ÜCoˆú•i ¶“$©ñl>„÷º„c÷@6ª4q`îP~¨0yݸrîYùzOÎ<È™Ljxk-Üóç(*W‚+ùã¨0‘Gr®DæÞ¥L>^‡6ÆYiç5ÖÌZÏÅ¢s¥?í^Ds›ó™ÌkXt¤ýú7ÂKusÞbÆh4a²‚ÖÎÕíŸs.ðÓâ8u}‰6þšbÛ²{è-2²19^N=ÂOKP/4 '·Â•¢PØâà¬Cm8Çoßíäʽhie9ZõkOå›û]ÉþÞü1i_Éž{¯~Ž`c•i|ú´›ˆ @ x(‚^NãÐ+‰«>€nUò•œœÁ®U6ƒ±~7X3f)»Z}ÄÓ.·%tc ¾ØN|i‚QéK›×ÓÒ«x)'›âØ÷ëz¢n qó ’¬i˜·®'U›/PíªóBEéÿm[%ÌI×±¤Xµü6ªJôâÄ…SF*ìOíÍß:ɲ‰gÈTÜ.³õÚ&¦.8Oã±ÝòÅ|.ûf¿Ê”Y(í±S[ÉÉ–phJ÷}y:Ä…]íšíâ½)ßà1yµ®V­ùqâ¶e0²)‹äl5îîölÿ&ßêU¸¸ÙÝjJçæŒ˜ü<•4žT¬[ï¢õc:ųâóâ@Zx©¥3^ç,r6—önä òYÚWºòçžãè9_ö¿1/‘~ùonØ…î¥-Þ,úkœ¹fC•Šž¨Ä³/à?/è­W9¸ù¦°Á·?S¨Ñiͤ¦‘\SI5ÙâUä û@ê7oAV ÎfsÌn¼NSUqXÆ’r‘³©õèð|;NÆçæ}ª?FÂÉ\B6£‘«P`_¾:!*/Z ý˜VȤnÇÀ= 9¶=JS6ñ½Â‘€ˆ0Ü/îå\¦ êŒDÒ´ø8å__JbË¢‘:Mä?Õ­rõ9øõœÎü>Á¨ÉÀ¡Õs˜ññ,Ôs>¤»‡/0¤Ò0æ¯n‚•°ù‡•Uf½² CýÀÛJWÏœGY¡ Î{ÇÑù÷:,™Ù çSxn‰?³§7BŸêCÍŒd¦ê1+<©\ß–“›¶s&³€ª·¤a”-d&Æq%÷vÝ("hûtÎ֛œÍX, ´:›²—ÙzžeïMcKŠ ²™œl ›aX¨Bz0mô3x]ZÅ{S¶‘¦Öaçè„«W-z½Ñ•jº¼zÚ¹h:'ÚÌe´§m±o,W·1j*}ç¼ÅSr‚%@ð8 z)í Wô¾4ô/èë´§É‹=ˆ^4·3œ¨ÙcðÂIaHý%üh ›w}}óá4w¿}ž¬ÿ“‰ŸÄáëÒÅߘ¾ÆŽñ bøûL@îu²e#×£ÎqÚ@‰‡¶"5ËÙ#ÇneþªãdJ`N¸‚)9‹¹ÓÿÆ%îa®XózNÒ.\4b²ÚÒ¨ªå{œ-Ñù1¶6¯ô¾Ã[¬( •:_ö{•ÎGÞgëÁtZ·wCŽ]Ûã<âgvu µË?‘e¹1¡OI"#a#ŸŒÜNÕ±ã©qü"ŽÏ"§$‘’c9—ؽ«øò«+4þ/TΑ-˜ úåÎÕëM ¿ü»6kQ+ØÚ;àè˜÷™¿‹åÛ³©Ò<û‚Í@²`2ƒÆF²L™J­Œ`ÐÜå ÆÄ±¯±Àa$_¾šïI—0›ÌXȱ{ŠáSºã¯O#9EÂËVF–s—®yS)ܾÄkÚTêÀs¾Ãøc*Z‹P@ ÿÜ·¦1E_à²}0¡ž…BåUŸ#Çðéè jp/¡ ©{–°,ª2ý{×À® MK"ÉÆg…MPÜÏþÁ¶[Ü<<ðððÀÃÍB…½›{Þ¿=ÜàÊ_œH–P¸„Ò°¶=WOdÒã5F½Þƒz61œ2”£NG”Ö8v,_ζ+Vj ¶¶6HW£óG-DíÙ±ncªkËp w¼Ü!;;ç– Tz5ä)ÿÓì<’u[dZNóÕë/3fà ZÚ§é2?±–´ÖCéåz€u»Õ´hrk "+x<õ.³Þ `×g³ùýª¹P³P)5xGP­J¥¼¿Š8)tx…TºõY•`OÔJU1ȂŢB£¾— Œ„ÕbÂb8ÍÞ£Zžz*ÙbÆb1c1[nÛSi‹Îο@*ׯõæ‹”´D;ø¹•|MÙêFÃfå8{è8bÁ @ ÿ'ܧ‡ÞBô©³XÃûz‡b·raùû|p¥+KÇDRV§´åÚ&f|õ7•_žA¤{a‰h½‘Hº[uœM p+¿1Š$I…ó͸m‡*t|©Jq­@©…Sõš·âøÚeè*Ô£‰o.»÷|EXÓvÔ)·µ Ý\qS©PªSWÇS¡{["¤4ÎO#¨mh™ %gŸáø%[Ÿñ¸-r•®„‡;±æÜ%¬‘5óÇBNF:YFë=Y½Ìzó56ÏšÎÏÊžLïÉâIß‘Ðr #r~fâ”h¤ôhr{¡3êÑ6x‡‰×FòÎçk™Ð›- Ë çpvó÷,Ý—_Öb-餮_A’6ï39+ƒÜ$Ï#^°h²„UR¡RÊ÷´Ô¦lµb<¹‡º¦Œ/'aµIê•AFF2›1™ IY™dØ9ã¤,R–"mÓµjm¼¿?Í߆–4Ö=^ãÚŸ×ñíŠïK=¦wÏôîÙ]ô\@ þ¡ ·Æpðh&ªa‡`WQ¡^mœ7ìçPF+Ú–AÑK©‡˜?a9©Í?`Zs÷"_‰”¸\žA} PUaðü–D¯›Î÷‡-%ü¢ß6¯ÓùæÄ@]Žðò×Ù}шì~ŽÃgý¨Ûß!Ï[­ôÄÛrŒƒò ¦v-õw@y %s#M‡§›¶Ø˜ììøs?cÂÉV"óÚßüùóOüUîyfÖÖ*‹‡‡+9ÇR0Èà¨T•xqÚ,Nž'ìCãEõöo0§vmt'W£¨7€ç²ÖðÕÕ.ôëUƒUÃAA¸+-X¹øvÍô*Ùx,¶Â‰ÆƒÆñv¼Y“”üÃî¤ÙÈñtÍ+c91Ÿ>³Š­Q$IJy¯!FÙßs×–)'ÉÜÓtÇbÆlcƒæ.—”}é¬ÞATœ•ÆáWjlÿ¾}pttdþ— ‹ý~ðÀôîÙ½^/z.@ ÿLÐ[.îg_Jêº+tÕá ià0‘=G2ié\ê²…–¤ƒ,øä36$øÐ­qhžà-|11É4öFu Phpp°A{ŽÔòï0êY¿"a=/þˆm‰Fd@Šÿƒ™³·qñºžëQ£¶FOLš…sÓGs¦f¬(ñ*ïööÓíyTGŽa¨ò"A*ÀbÅbQ¡R/Z³¢þduê.Ì’;ožù‘Uð,bU•Z’•[Ó…-n~~÷l÷²{»5Ԯ”M®O(.kg³à„ ÿjy$ßÀ²„$ªPž{£µCm1›n‡¶ÈRL}…¿loš5›D£Ø/óSþ,DÎÍ MÓ™¢^ñ¼ìÙZЇ^Šã—™«Q÷|‡y–Ó³íx9Ú½è‰E΋óO!65µ“åòþ×4jÔf#¹’Œ\  ™RãIÕùࣻYh‚Ê¥rèZ6R˜#Sj¬^¯§ËsîõƒàùÝÉÊʽ–@ ‚*èMœÙ¶›”Ê=hâ^‚YN£::>9pœìVÍ)~Aýùõ̘º’„Ú¯ñi»}Ì0ÕÈÑ ¨á\Às­¦Ö‹ã·Ópf{aAtp%³/ÚÞñËYñ´yÿ¯ô¨C¯ÁÁ‘ÉÜûŸoÊÇÓçÅã˧øb]"¶ÕÚÒú‡I¬Ý‚óMÞª’·"ÒgqÙÅEº+ñiþ*“úÝ5O@Ÿ™ÒÁñ­Ç_&é)é6ÿÈÊ?®ôTc:Ö®O»šÎ·…°)–M ð§smj¬˜ î¶¥ eÀ×kynï*¶ªZÓ³® ×־ϛÇZ1{b{<ò³žúŠ_w}´Z‰¹V(Ö:2YGÖ³>ƃwýÔ7õâúž?9_¹=íÈé§ønê|¶¨ Ã”Gô•rŸ"E/âT¸í)Ü}ðÐäF¶L•[+¥±û«Y2†™=óÚ”ÂoO ÉI)È<^‚ ;ûNQSÌëõBÌ @ x‚^Î<Èo{ri0´ n%Æ‹h¨X« ªyÇ9mjNâšÛšÎéu_2sõ%Ê÷ËŒ.qT³¨¡‘òε\dëö<5¤Z«•+ÛW±Ík(Ë?i“$£P©1ýœ>mfæˆxZ¿8˜~Mü¹Õ´éÃ'³hÞ$O¨/là— •éýN0 ÙšÿöAÆÁÙ‰¬Ìl¬²Ìã¸x¥^ŸE—ç:››géç{t#++SôV@ „ ·»i[1­~é;€j«Ô¤²é{ŽDYhXU}ëüôóÛønÑrväÔ¤ÿ¸tŒpÊ|jü[½ÍTõ\FNï}Â:Î¥ˆh‰k›gðæî;=À¹™÷,‡ÏºP§›ïí{±œbÁ \î:—Ϻú>ø8z›*¼þõrl­9èõ™Xj½Â‚…µ™;j2¯ÿaƒ­AAØ‹ãYÒ+)³¨¿9y·ú¯1wìb^}9±Š <§¼Aº¹˜Ÿ~ÝHTž„YβrñNœ{O£™ó­€|6:-–LËcý`êõú[ɯ"ÌF Áƒô–Kü¹;…Z=ž£¢¦ôCÕ¨]!“ßÅb­Z`:³ŒaNP¡ËÛ|Ñ¥Þš;‹ãÝìM&YgñþôixÏOÿ’ä®’ÀçÆ2\vN~‘ù«Ä«kòúWßòz¥¾{c©}€ùúnfMû UçA´8¶„¿°aÜ+ðQ+pnô4W|ÃÆKÏ0 ô^_hȤîÝÄ!ï6̨ðÏ0%©¬‹\IOH!õF¼eC¢‡<¶H©§Ù¸3› 6u‚Åõë ÅÆq=z˜ÚµëÞù…ÙH®J‹í];p™ìäëä:xã¦Í?XÊ&3G‹“ÃÝÄ­™„‹ñ8V,ob×äù¡ÂtæõòfÏä~¬ œzKÐ˩ۘøÁj.*eôI™Tú%ã[LÚ½-è¿. èG¾º·ºi$x½Ì¸—jâ”qœo'/äús3ÙÄHÚ6…Û«1ñ“Ž܃¦—õG˜=â;ߙʠÛTQG&,¬bÙ¶^`Ùð©ü)yR‘ªÕjРIj—×aÉÉERkÑ‘Ê‰ÛØ}ä4g.DqÉXŸf¼@„ùóÞÿޝ0ªÕnHäÓ‘Ôr·mT u°G‘v{päï(.ÆÄŸ’Afnƒf¿KË‚K©ìp´\à×U¿±÷\<f N¾á4|º+]ê¹cÊÈÂTŠšVh±Ï>Áº_wsözØ{ѤÏÕ²''ÛJ[ìµ2†ÓmQ®Ðà`oàØæ\v¨Ç³Íý‘2² ‡ýLjŠ:_üs,x ”Ø_Þ Ó%¶®ÝÇÕ²,é¤ô¦AçÖT²bVb×ÏỌúôí܈@û{WäÖ ß0xT"¾Ÿ¦ÑàÉôÿž?ˆ”¨#\³«J5-Ù×cHÕPÞÝ&_=›ÈJM'ËhA¶qÄÓÛ"ãžéÚqv_÷ä©:ù±×–4.Ggãä½Vs;ÔÆ’K.¶ØÞïr:|ÂJ»ALx©j I¾E°Ä³iêTvUƸç±y‚!44¼Œµjƒ£§Ž* ³É„É”‹ÑhÀd–n{ªjlu:´¶¶ØØØ ‘õ$'ebB‡›+‹ S®CŽ£å¶òV¨lÐjµØÚؠѨQ«T(•¹¤'$S4wX¡Öâàà€ÖFR!#YLsôdÌeòŒ+5:ìítyTIVÌÆì»Ÿ«Ð ³×¡–Œää˜îméËÿC¢£/Aÿ8 úÜ ¬ÿf—ïÒPåœöïןÐÁíîœyÝ'¡F“pœ‹=ÜBò‰ßYºôGv&yÒòùA x¦2nÅ8,Ì1ûÙ”\žvõü õcBÐ ÁãƒúÉ)ª÷°z¸çÿËÁ§EE¬»Ž¥ü‚M"ý Þ½+A®ÅXÅ–Bþt… ^›LxŠ• eʤ”¨ûêD"ÝxPc]™“bå\2¯Qj¥lƘmƘ]ô‹RâsJ>Í’KŽ>—œ²Ãl 3ÍÀý¦sZM9dšrîÑH&r²LâÉ<؆ÓaÈÝ'êÖKßsúÀeìteóÎK7±b¥ŒO£pœUÅwý5:ñÞg­é¾{ _-ÇË[šóΘ×hæUÐ[oåâŽïXž1võüE} ôO8J-®…v^º <ÜldYõ ü±&%’âè…Wp5Û¢0™ëKi§Iˀߖ/Ç]©ÄµÚÓt¬évg¾Òžàæ/1©~könÁ¿èÒeÖ+8’Nåî‹wLÈV+ <ô@ ½ ¬‚^Fþ{ržË碱÷ °¨·]­ÅÑÉM¡egõœÛw‰L*áà䌓쵪R_,*t<Õ1àŽÏ '7±5­Cê9¾ùÓ^z•uÕjP»V-êÔªFE_{T¢Ò@zAñH’ôÁË%vH%¢SuŠæÃ*=kÐþ¹Ä|6gVNà'ƒöŽ¡´|®#á÷«®-—ùeùn´mÆÒ°¤Ä!Mm~í©cýs?•„·*Mš6£Eó†Ôðâ^ „ Bxè‚ÿÜ4žäkØ”SŸwŸr-}Ï K{¿šÄ—qøàÝ\æ}õO:›lN}7›UOñQŠ%'õ+´xU¬OÓªõy¶7X³øû¯½ü¹óW&¯ùe¹ô6ŒA*Ž=,ªS þ!%-À ý%èE ½@ð_Âtùwf.=GDÿ%{ÉKÊq¾ÿì v¹ödâ¸Hüã–÷é°¦rdù4&o¶¡Û¸Ôs(û2™*{_ªµèNµÝy-+–cb°óP–:  l”æ‚þ‰ôÂC/ü7ÈåÚþ•Ìœ¿S«˜ÔÚ«x<ÍÅíË™·â$î‡óy‡p•Üçr­RÏí`åÒl¼^Ç §G„Žû]õ^íXžzmÊ‹ª‚G€ôO‹Å‚J%"ReÃjµ ÑØCßÂ)l(W« ³É•kY±^¥Ìì¾ÆâoÞÁÍÕõ}ÄÕ(ì|©\M‹‹BÔ @ üÛ(®_O(60û¾·2‚ÿ÷Ó_Š>V jÜA’@ ÁŒô@ ô@ @z@ @ ½@ @ ½@ @ ‚^ @ <<ÄÆR@ üÇe™øøk¤¦¦`6›…A‚ÇFƒ››;~~þ(eß¹Oz@ þcÄÇ_#77—úõ¡Óé„A‚ǃÁÀ™3§ˆ¿†¿€ô@ Š'55…Zµê`4ÈÉÉ”J%aaá?~ôÑ zI’8uêW®Ä`0ÊtŽNgG``0ÕªUG©!ü@ ŽÛ˜8vê2×ÓôXlt£ÏáÙø…ïԵ³ä»ÁE>5sý¯µÌ[¸ž¸ˆ. Òî1”Ä–E?"ušÈ3~ª[v0æðïõó_F„!%šý¿~Ëœ÷O?~,Ý‚5€‡/0¤Ò0æ¯n‚•Dx˜@ ‚ÇKÐ?Œ¾ÂÞ—ðʾw=ÎÇã!Hà„ü]™硽{Qegáôׯ3&Í–BÒØ6œCÂïúÛÖKßsúÀeìt…½´²þ<l5¸EÙ ‡šw ¹-foDmö£²¿= @NÛÊÑŸ*TüUeS1§²w÷N¶ïFrÖ’j®Ï¨Ñ}ix·(‹ 껬 #‘~5†l—`üóãÚ¥øM|½>½­–«ûðê‡Þäì[Ä„©+ðŸÑ ÷øËÄÄ]%Ù©ø¡”î•hân%ú§‰|¾#µäz²f’p5“*o,fBÛ†øÜ,ŵ Ì^i¤Ë§SðÿñmVMä…`?”–Ëlþ#:½àjgOä#Iÿè}olÇçÝü xÕe q{øvÞÖÍÁ-$Í¡oxË—ÈÜýC¨õT{º¶ŽÀõ¦©¥4ÎO#¨mh™¥KœÖ{Ý îùg)] wb͹KX#kŠ eŸ#ÙF Õã#>e}<çâd"üq|Â4±œÅ–5ûhÚªeé‚^ÎàèÏkØ—x÷ä(¥w^èRçB?'“yb ‹Ž”£_ÿFù¹7¥×­œsŸïÄ©ëK´ñ×<|[Ü—‡^Æ”‰Q逓®ä‘PÎNà|œ„Å'§<š2—Á~éÙvNöØü‹¶“­& Æ\,²òÿµNîªtI;¹Žo6Da¬Ô™÷:…Ñ€fÒ/cÏ‘s\IL!Ë¢Ã'¬­#k {t…~¼BnT´òõ-EÓÀ¡ÅÙ]á-ÞméU@ )P9Ý×VbþXÄŒe]mE‰sów™;°*j@JØÄô…±46žæîN(FÎÅ÷Ïõ¬ýi*ƒVвs/zÕ¸Â‘Ä šUv¸w«å»¤Ñ©:¥çÃJ$lû‚™†!|50µ”ʾek‰«?˜FNŠBÇ%ï[Æç?&êr²Wõ›¶äÝ9Qéú7ôŸ”S¶ú3dcPé°+m쮳åó¹Ø})6²)‰?¾^Í9·|ðÉë´ðQ‘“pŠÝ9*loüÎGƒöâL…òþ”¯]´6T„vý˜]K²S"Ûge]^lZðMˆ…ó›7“Öü º;‘Û ³7!¹‹/öG׳ÅÒœQõò&@¨ühÓ¶2+¶Ÿ$­«?î ÀœÈÁ5 ™ÿÓY¡õé>¸5*…ì㊓NYƒKǶ³|éX†_Éœ×já ¤dn¤éðtÓ–½Î¶hmL¤ ·7WrŽ¥`yâDà‘aè/nå›e?±ýt2’­s®ŒsXFOêE¥G>4shΫ¬ðù˜Ï{¢¬—~cÂÔ\Þþæ-ê«ì½g^:Â)”¡.ÿl6$.¯É»«¯^áK¶b2Y9ûJo+ ÷MÁ='ߺGPãàæ…7w ­t³¿ÃÉsg"}êö‰H¢Ïeÿ¼×Yî3†/ûW,ѹeÙÀ”¹¼ùõPê¨óúÒ >àhÓYŒjéø/½¥”ÉŒ9ÆY)„z!Îw´¯;ÊüÐì÷*Ÿ]ïÄÌéÏzÇuŒœX6‚Ñ[‚yïÛ4Óþv2²ÎP¦íÊÅÖÉ[Ùˆ>WƒoÕ¦t{¡'-u¬þM”ê zÃ|&sˆëfÐêZ!Av/“öÇT}qœ\¨mth$#Æ]Ûøm[ÆŒ‘šè9~¼Bnöø††sGô¼Ï)«Ï Õ¨áRBCRS}à,V ¼¿K+}Z1lZc<}óÃ!4îTmÓŸª‘ݹ|àwV®šÅ«ßæ ®6˜¦Þ÷:ÌH$ï\æœú¼û”ë]) }VvÎöX¯ígéÂ¥ìÈdÔǵ)Ü&”8øU#òù& ÁßñvUZ®ßCÉÒSÉpv¥´°n9û_ó§J :ï^v,bqtoL{ƒfº üzûg¥£gá+(•êÛ×TØÞâ9ÂïçÒÅ&Ò—¥nmýý:äTj*µY–Kt )ƒŸaÄp‰òJYd «I!ÿ‹±ûVâwÃÆAÔ®Pí-qG™*µkì&VüÉèHBí\º¶…Û’a¨y¸å(ÕR&3Aý¿`ÙKÁ(Q"écعl*“?]ˆfæ[4q~D’^¥F©°¢ü7laN`××3™·í:ž­;Óìè:þR…Ú½„¬ó£a¯HºwhIí@GT¹ñü1c8ã6ofùÖÖTëäÇ£èºˤØâåÙx7B‚â¬^¡ÅÛ·˜©°Òž Æ=xÓ.èñ§hÔ§e~¢cÙ1]þ™KÏÑ ï6S“³¹z-ïÊîh4‰ø4—yÍ+áVLMiƒêÑ*èŸy°.]&×·=þª’¹±k'}ê2À'ïÆÝ¼ÀØ*9cñ38]c3¿j„¿­™ŸýÊ’ÔtdÜJø¹þüz;\šP½8CÚV¢E0ïûŽ©éÍø|^á*€² v8æ¿ÞP8Ô¥yÕÅ,Ÿ9‡tËÓLŠô,Z““šŠÑ)”›/5”íx÷]À’±_W°þ` Yf4ŽÞ„׆^jà¡mù üä?IÍ”ÁIJGœ Äe—}â*¥^!&ÛvEŒªÏÌFéàˆÛ”ÜxXÿõdµÃäªÞ^IKeoˆýcSL¥KMš<þæT(s9»~9; ®)lŒ%ÞœÈÞ•‹¹Z ËW4ã¥çªâð®[l"}™ëöÑ%ÑßoÈÍÍÿ–&è±/G­:`6š‘ä<Tð¼¥JB¥*"ÊJ(óC*¨ kZ‹ÄŸ×q¢ñ@jÞl‡r&û×nÂR¿å Gùß± ÍÜHJÊóF+¨ÓÿeÚíËÁóf×Ó<š’È·ÿçQÛÂrnK¶§òÂd¦ô6³¸ÿº[ÏÍí¢(p‹|‹ j 9#i7r6Ômß¿-«‰»–ˆEöåQXë ôfb6üÎ1·&ôQý ÛLÂþo˜8{7n/|B¿J¶÷âkãÚþ•Ìœ¿S«˜ÔÚ뮳49ã/S;B‹Ò£.#¦xˆgÿ«7©LIó óµ-Ì]GíÁÃ(Ÿ_x…C Udô®c£m'æl„¾wIëà„ë]›]Åoð^“’›¸yïtö-/82;âê”IÌ\ˆPƒÂŽêµBHX˜N)Ý(´"§”Ìî]çñ¯> È›‡\N.͔躼ü«TôPcL<ÇïËf0™iLïä‹51DµÞ.ù7«ô&¨œŠýW®#5*_†Y¶‰èÍÛˆ­Ú‘z…âjr‰‹MÆ/¸‚ÉëØ]žgÞ®Œ]icÙþýw¬ÝMªI…s`:ö{‘gÃóÃÎJû^Šgýô¤´ÿ˜Î¶ûX·igRCyqtOª¨AÖGñÛâ%ür$£Ö›jmzQ­È#mþ‘±Ë,ô×+o¿ )žõ3—’Ó¶öû–³îP, j<7˜·:UÌë_d=§~^ÂÊÝçˆMÊ Þ!õéöòK´.gƒ”|œ_ÿø›Kg³È1ï`Å÷gQ¢Ä«NÚVÌ»/)ó,¿}ó=¿ŸH G²Á³r¼Ü‰ê.%<™ ĬWæ³ßt•gSŸw¾NCMñ‰ôe®[JH¢·œæ«·g÷ì$>iï…ò1oËÖ¨5|´ÜBÏÑÝ©T`è–ôQ¬Ÿ¿Ž'Ы=¨Þ®ƒ;VÂ9ÿ†¤ÌólX±ŠM§®“#ÙàÑŠ~:PÍY Rg}EJ»éhs€õàlZ/ŒìF%¥žÓ¿}Ëš½ˆKÊÄ€Ï uéòR_ZØ %Ÿä÷ç¸òw&zË~Xu ¯ s`Á᫞÷P†Ò~£L“…ÜlVÔhµŠ»× eœæÇ¯W°éL ²k;u!äü*.×Å€°F³vê:´ýÞ¥C9å­‰o^¦o•b4Ÿ\z=—ÚFîQB*m}iúöç më‰)ó¹%ì)2I/TF+9)ièQàäìÄ£R®ÿXÐ[­ UYû]}&eÓ‘²8ÿû|&®Õ9²3a2~Ê’MÜÉ=lüí6ü­á©—'ðz›@Ê"ç-YW9sx?[7mb×UWZ œÄàVAw÷ÌZ“Ù½ø¢ë d˜ûCî®eÑ¿,bmbm†¶ô¹cp-Dïù…¯–n$µÑ0¦5u-òÐ+òþŒYè-÷^XMÍ! XðP\m.ÔªWž¥?­áhÕç LØÄìÕ×hðú'¼n[p´à̪ÏYv­!#†û¾/)ƒè‹i„µíAëùƒ¤ÎWw2üê ¬9zÖ~·š £Þ-‡™-ÕêD0{ó nô,O)ÕbÑÇqø·¥ÌÛâLßIÍq+¤çÏrø¬ uºù>ö±à_Aq—‰s%¬´×€R*Û?Çwš>Œž5’;#±{–1áÓ)X§~B'ßôÒ¿÷É%%î"'7ÍæP¢-MÛ·£oùr«9•s'ñ£²cD¤IæØÏ ™uЈC@þ!'™˜˜\²o}KÊ•“¬ŸE“~¯òÙrpñG>þx?UÿŒ+ä­F¥ò¬N··zêãŠ=©[1™É_n¥úøöx¨µ8»ºà¤U¢T:âêâŠ%޶ª[ˆ_§LaKÐLø¢^Š4Ž~;)sœ˜3:;VNårT"z\pu)Ø—hÑ(ÔØ9»âZ(l gsñ ÄM]ƒS¦Óûއü<ß~øƾ3R£è€d‹‹šéËT··”DqIôr2ÒÉ2ZÜ0pŸzYÎñKóÐK¦ bcs1J2²2ßÊ…“?¯'è­÷X2:UÂ.fúœ™¶Ÿ2¶7J)õŸÍdGèp>_þ¾Ê|ù!82ãý¸Ëf2ãc8»uGu´èÜ™ÁAþøæ‡ñhýêÑwä+T ðÀ‘d~=†±‹wPet[ÜmñðöB¯S¢2»àåí… %.öê[v¸£ÌR*;çMâÝKL\<…#—¶Îã£)3±ŒE/3™WOóÛ=M ã«÷+ ¼°œá#¾â—ªSè¤,Ù~’Žý:³æÃµìkñ&O9¤²cÕ.ÜŸŸAeå†Ûž`ë(ÃÝîãŽÍWn†Ix cIãÔ+Ù¡‰dle5²5¾ôº"‘³>g»Ï›ÌYI€å"æÎäËÝ—©Z]ʳ¹d&-6¹À[ÉLfü’²¬¼å•—åÛe*­ž=Km#÷(;*wãíê&²ô¹È’³Y.ÆC_\gr`Û!2p§yÝ w;þqôZ­Ž„„üüüQ«ËöS‹…„„t:]©^Θíß²dÍvŽÂèúÁx^¬ãðГ0¤«{Y¾á±q1\ˆºLº6„-»3éÍæTv»ÛýY‰þu³?ËåDÎjиù+Ìm]—òöwïÀ¥¤ƒ,š±šöŒù°ÞÃMš”RØ5g Ÿr¢ÓÃháZøbRòF¿°“.”È^ãýlNÅÜ‚Cƒ.tÛ8‰QïÆÒ¼q‚½\°³U"›²³HIJƶæóôªSt™O Wv¯æ»+%ÛEŠÅrk}%~ϼΫ§0aà:¬5è4d"/6ðÌkÄÆXönØÊŽ];9š[ƒÁcÓÀ©ˆ•4j]µËÆ25¾µ+xádcáÜ$Ó:F¼EvÕ¾Œ{¹vÏŠçFOÓxÅ7l¼ô  d0i4JbV@¯ÍŽh1™cC@ÍV ™Ü“fêBcêÞMònÃŒ ÿÆ[&Á“‚Ù`ÀbçQêä_º¶ŸN„Ðga$! ÀžòÍÐÿЫ|½ù<Ï´9Sê÷ÏöׂœËÙX>›Þˆ‚^ä¤ýl8@÷/"©à ¼¨Óëuž?ýëïªó$<ÛåÍ–åó‘´©¸Š]1zä Ò–(¶bvoËË ~gîoÑT¯¶‡ŸÒZóqs{,ÑžÉPùn¿Ñ·¸äf‰k[¿`ì [¤ÜLãÓq¨Ý…1Ó»¡2`¸Tz]µ6þÅÎèJôݧìdRq§å›9{l,©7¢P P€RQ¸å(i7¿¾K=+Jk#÷ˆ)›LÓmÝb.Ó\Z"yï2–îËÄ®ö›ô¨¤Ë£‰úG‚¾\¹òœ;w£ÑˆªŒYƒV«•Ë—/Xj±Ô*GªöÃ[M*áù¨¶ÖT«±uð£zËútR‘ðç{X2J‰OöôéC`pžv÷&Ü”.>Ôzî#žoŠó?Ô| ÇòÔªmÂUQ²÷§r›þLìW‡*î…›€Ò§}…âT‘ê8•ÖBt¼0ù š:ÌÑó±\‹º†Þ$¡ÔØ`«µÃÙ5ˆòîêâ»z•¥²”-n‰>­ßC«7Í ÖÔÔfÒS5Tê6Š×†ã®)¾Ž|ÛŒäËÐÃì›±t#m>éHžV×Òôý¬ËJ'#;«J‡³« vêâÞåÛÕ7hýN;ü…{^P uN†RúKì%®zVÈë·Ü+„„ú‘z$ŽÔ+¥Ÿ)‡*Â[¶&\[t²K¼S ÁÎÊ‚ n®e*ÊúÞ {œÀc@&oR/¥ŸeÚul?G¦U…Â’N‚©V™Æ;KÂU®+³9þËj.ß¼5é©ò â“$p+ÜŸ(œë3øãúùÇesyïZ¾\z•*Ïåu¿¼ÿs /yž5ÈúÓ,ÿ-R¯Þ4*ൗ®ïbñ‚cD.hPÄžùdç·y'ÐŽ§Û­œ™âéËR·…ºÀ¢Iô [Üüüh{ûG!³²\|ú-7FQÏj^ìê¨$Ë`Î#2€W0¾‰Ñ$Xd¼o$p]™Ã•ßsú¦¹å4’ådn$KÈNyñçmÛà›“Ná®­¯gËÏëùóô5ô’…%“ÄÜ:H²ŒlÍÅ#a²Ê ™0dgcºK™Í×®pÕ+Ù/欘 üBÊ‘z(L9ýìÑçäÇc˜èþÇÞy‡GQ}øÙÝìnz¯@ :¤H'A‘¦¢XT@+*~ED»ØP±Š( "‚ U‘ŽôÒû–ì”ß ! itðwßçÉ#n¹{æž33Ÿ{æÜ{Ý%NšîUñàK×Ñ\±wÁÐ< IDAT &ø‰O˜ôØaoSÃ¥Pp6-}IlPªjC«WÎÂ2qx°g(º-…­‹?åwÏHj˜ì85W¾R©¤ú×$;. À…ÍæIp LFQæŸRÙw½¬Je‹ã¨*?K•ÅÈE ¸P´2O-Êó9;¿fÊGÈ ŽgâÓ]ñq9P¯Ðýã¢}LL=ÜÏÎÛq8ìÕúŽÕj%"¢&11u+Ç5;fð¾™Ê¡m<äÂóž‘ÍhuÁwòHZ_¢If†¨Þ<ólÙŸFm(o£]9¸9·Ür>æAÍf©Ù¬ºŸ§×£/Ð9¢)Ѿ•dè³n Ñ)35Êùˆl,G­£¹ùÁèêôÞQmèÕæ|’ n£½o¯Å”ûÍ91{ùìUÙE ‘_ßþ’”>O1:ÖŒ@PitÖ¨EDÞf¤h4 /ÿüÐT d#e·Ž0  *¨U¼¯ +_¿s—íCÓÐdÃ%Êî¢\|£V3wâ4þn2Šg¦µ¡¦‡Œzx£Ç'WO?j:ºÑ‚·7>ůzÓãþ¦Ô )?{¡Û“Ùµþ7–,YΆc*­{ŸI=ü‘úý8~jÏ”ŽÉ|ñê{üUó!¦–:G]ì_þ Mn§ƒù=bŠîǨnkyyÎZ:?ßµ°ì§‚‰ôÕñmIþ«“èË"4]GÒu$½0f0¹ãTB`†Ð{T"ÃÎ^}½Ì¨e•r”ï^}ƒmÍÇðâûˆòQ}Áð§O]¸­€dŠþqöUM’‘4½x⬦©%䔎.QÍò—GFܽ‡9Gšs ŠK»ä6T«râÌA¨š¤hEëñ ;¿Ê:†*}%(4@-Ù¶®^üdãjù¹‚¹˜¸u)U¬P§‘ö÷¦¼»’S~]y~úc´1Û°«Wîܺ(AïååEýú ˆŒŒBU«gµÁ`Àb±àááàÿ!’;šW-¡}£ˆó½–ìö¥ÍÃS©—îÀPÁůü«€7­F½B|€§˜ +¨:îÃÚÒ)ê;–ý´‡›G6)wò¤)4 ÿôN@-ËÙìdâÉd¬¡¡ø‡¥Vú~qù\9Ï´å0‚sörʮӰ¸îÏ…ÝqñË«Ç7³.¥÷Ý׎šEO]§IÓËdÖ ïûçÞ¬‚CTr©­«16¶ý3›Gg¬Fªß‰›‡Ü‡å£¯‘ý½ +ÆHnÓ¿ÇO`ø"íþ3îmNIÝ®¥¯aîJøÚUü´ n»“&c¾aÑþŒh`ªp"}u|{–ò&ѫبnV¬ÆK3äºàúr2¨å·­Ÿ]D×ÑѱÛhºGq¿$ž$9(œP£Ž18” Wõºõ¢•¹´XRöâ¥Su]E×KËíäV6¥µâ¡ûãðq¤‘bÛc¤h¦+¤®Þ¢©Z¹¶—µÙN`êIN9uB‹Ï%…¤“IXÃCð–ŠÚ(7Ã\Q­u™¬³â"´×SL1:ÉͶ¡PúIÁ¥°¡Zmè娍+8È€ÓÇÀNŸ3}åN<Ô·*|å ©Axæ?ËÖˆ>£ø•LÒ2tήt$c4àtjèzÑg\Ù…«ÌÉ„—ñIÕ~®8F.ê\Q\ƽ“£+f1uÎõïàµI÷ÑPÎÁ¦\Ùey.êª IžžžR­¿ÀÀ@<==‘$±vŸàzS[ü‚|±žÏYcò$PˆyAµc,‚¾öÃ}ÕLž÷I½XTç$&‘­!º3݃¶³àÇÃØŠÞvžü•ï6˜éßkï»U: hG|ý,^°·èQµBÚ?óX¸ÝuñcbOÜ•ŽœtQÊF>]¸³Ìãh/oOì))䔹c:ÓÕo óì%O;+ly¶ri[`Ês˜=i$o?g ST^|ª=>Š…À`Ì%oIz6æÌçPÓ! nh®b¬ßŽ»ú¸±rÁŸdèpf"}ʶ¤hççÛ³ú h}\‰IôÊ.fÊó?&£]¡Z8IÐEA‰?—¢UQ§¬°ï—¬?]Tìâ8β·Ôµ#‘êt¢GÀ_|=)yùØlùØl¹¤§dPå˜ÒÛOå8ÿîËFÑÀ•ú_.Ù‰Z¦>ÛÓÛ[r*¹ÕÐZRdgz…lã‡eG‹K¥œ «X¸ÞBÏî .ÑŽß:®üL2‹Äüå°á’‡ªS¿GwÜ7¯fs¶^¥¯$ÿvôj|˜Eó6qºp¥ò÷7óX™^‘RµÂ²Ù½;¡°üIÍdë·ß°&[¿H?_†xW\”jùáÆö7ÙÁ72(>ƒ¿Ìå«ï0wÞ\>ÿý®+tNŠèàÂ{S'ûòñì÷µÀ‡%?ÏÎ<ÿþ#´±ÖæŽçF’õæTøÝ—P;ÉVZÝÿC¹U¼¯Vªè¹ù‰Qœ˜úÃGbv ×º‰®7ú²êbÇ*!ÝzË:¦ŒÉê +ª¡ý÷&êƒÓ¥}ø=húÓ}l!F37<2!10ÖáÎq#ÉûMüËÁn8ÒRÈ­?œwŸlOÙ9ð’5€pka–Ñ–ƒMUHÙñ ÷Ÿæä‰c>î¤õSS˜ñRoÎ|Qzpß½èZÏ£’‹+ ;cú¶Ç_r‘u:•|Ù„›+™L‡ ¯R“«ŒÔé}ñ³SHq‚¿¥â‰ôUû¶Pà]©Iôšv!C •S‹'0xq׸•i¯ &F¦¸´B×44 Ð4ÀL»ÞÍØ;ëy¾/°¢e¥bl9Š)ý‚Q.ÐC4áqr§¿Ï˜Ç= 2áÌH#/æ¦?ܯâí\ÛºòàÀõ¼8á VZP Ñ ÚÄwN¢ig>ܶ7q?~ÌÓÏþNѸžã¶:EË,žcsÆ?AÆÔ7xä‚=ì¤fzÐväî­­áp×»”°§h—òl,î¿ÊÞ­È]ÓДK`CUÇQ —c#…uþ%lt…w¢OÍøõÏÓ´¿¹Få¾’Üé6öE2Þx›q£æ yÓ¼on™EgÚõ¤ãÝ·ñÛ¤—ydc(ŠJxÛXï#‹ŽçŸTåg*‰‘‹9W.ýìyS¢WHK8‰MÓÑ×ñù;ëJ}Ï­m4wv­}E–®”NŸN*w̱uëââZ‰»«@ TÁ…\/«þŽŽ+/“Œ<£‡~^æ2T5œ9éd8Lø–÷䨪÷+Ϥæ¥g`7ûèiº„+Œé䤑ár'ÀßSE «6ÒS³Q̾úYËÜ u\y¤çi˜}üð³+ž©Ë_ááv xúDHH85#kU;’¨ÈH"C}p“A·ŸbÃây|ýË?û4-¹n"K&gîA'Š&c nËèÉ£éPé†O©¿Ocìª&¼R<‘¾z¾Õóþáí±_áõÄt¸Œón¶nÝBݺõ/D6à9 Õé®\R“³)$³¡þ™§3(Ôœ<ƒB1;²Ð, ÒÓÈ·l¶“™™_,–$£? ¶T’³T,AóHɰ£aÂ;$Sn"é¶²ÒEÆì€§’AªÝJ` ™‚\V_#¹Å6FüÝÈ9ŠÃÍ/9[уsm>c7R^2)63A¡>H¹™dÙ\èEösÉ(ží,aõdz ™Ô<¥‚þ ÇÃYÑû€›!Fr“Ò±é—Æ†ÊÛ(ßF/W É9®RƒW¯à,¶Âv+÷`°àí닇Y.\Ç>g;Ž™Nþ°7[xVËf¼ =%“žª Åêƒ!7‰ »^ŽOªòse1r1éo/‚C|0ÙÓḬ—ÚXÊêN€{Eóx2HL·]в•î?çQÙ}Cz@ ¸&½à¢³jÎ|ì²S5G3Š Åhº4®õ,6ÏšÄ|÷JL¤¯ê÷Y>}:k›<ÅK·Fâv™c6&¦ÞUòŒ„l0 é*j³$%Ù€A]ÕPÏ£Ö_’ $U­¬üGÆ`”‘t¥š3'ÏØ£**WkŸÛKaÃå8ŽêúÊuìÆOMdÐ;£Kσ‘d  ]­þ¤ÙêùùúæÐ¡ç%èEÉ@ þ“ÈfÎkù…K%æáÂ&Ò_áIô—§÷ U©¼BW´ X!DW•jÌ1PQ\êù·«^Ýx¾6\Žã(¿MŒõ_óé5ƒ½0Ùøgã~üïŸÌV½ôšîºŠ¢]?ÿÿBz@ .ˈ‚_¥úŸ7yp¢.$‘àòáߦ?ƒ}p,5-¬cîzŽÆ^ù¤çüg³êBÐ @ ¸¢\½ ½àÿE|}‰iÙ‘…õ8¸Y¤æˆA¤ô@ .š&½àrX¶¼ÑBÐ @ ¸\ˆ ½@ ½@ ‚ëZЋò@z@ ×± z@z@ ×%&“ EQ0 ¢3‚k UU0™Îo' !è@ ø†¿ ‰‰ †`±˜E‡×‡“´´dÂÂjA/ bÂÂÂHKKeçέØívÑ!Á5‚ÕêNíÚQ„……]9A¯i»víàøñ£Õ¾ X­îDFFѤISdYžà #Ë2Íš5§Y³æ¢3‚ÿ%èwíډ͖ÏwÞƒ——wµ¾“››ÃÊ•+ؽ{'M›VïB¢Û3HÌp`õÃß*·z^"ÿž„ÚõÝÙ¿lÜЃ¸`“ð~ TEA6‘.ôû9‰NÊÇ=¬5¼/¦&SAQ ’pŠ@ AuéóåãÇÒ¥K<ƒ‘üüüjý Fºt‰çر£Õ“w)yç™Ç7y"#žù€u)Êù‹Í„_™9c)‡] zþ.f=õ“¾ßEÆu¶b—®(¨å¾£¡¸ŠGSq)jõ·VÖRXúâL^•}Û1+¤ý3—çÇü·æÌb옗øâŸt*õ’žÏáõ°3ý\h‰KyæÁ÷ùÛY‘3ØòóÉË«ø/ß¡Tp:9;¾cægIQ ÿ¿ /‹{%Ö*6²²ò)ÐA·`ởðÛ)—¸r@ ¸f¸¨ ½ÝnÃÍÍ|^K_麎ÙlÆn·U¥2ÉÚ³3~"¯ËÓ¼{omŽ|õ*SŸ}…“Ï<ÁàF>çŒFôì,üv§Õ²¯ï';×Å¢Ïtñ¥Q=#.ù’µÁä~îé‹_ÉH“ÞŽ– e?×mÄÑj$MËùŒ9¶?·I¯óÕ²›i6°ÀuøGæíoÁÐG½™½íTéè nK‡ˆù¬ù'—øR%C@ ס ×´K—¡—üº0þ“.¸¹påE_ÑäF ƒ»/ž­iyk¸I*UA5Ô¤ë½Ã¸ÁØÿá£Éÿ’ÁÔ©YÀâ#Éh-Ã8²á/r›ÜM£ó®—P9¶ïjÔí”MfKžÑtî}V̦ä+œ†H€ž¹’­‹ê[»üŒ³^ÉÑÝ[YÿçVm<„æc!ÃÕšÆßCÛªªlc+Ãhd%%ß7Šˆ¢ºv-q9³—ž$Ïl!áÆ!Œz>Û†O˜2}.¯" ñGO&æÝ’þm‘9 íT-z…7WgT<‰VÍ!)!‡F~Ê”žm =cÅ©_x{¾ƒ“§±ðq¾ÛšÌÝQáÈÊ1~ý-‰–wµÁÏ݃øGÇ‘õ¿gùtY/ÞQ"«®c?¹Ž/ßûŒ%{møGGcúë ž]ñ!ºÉ“€ˆhZtèÃÀî±øéj-“}û3©Ý3¦‚€÷¥ÓݽY2ñÖÇ?M'¯tV~½ßSi鱂ÙçŒ'ý¨WÏ›ï÷Ao.6s@p} úK[rcÀÍ Ô˜qw¯l÷ºl2înn%Dq’75êÆPÏ äÀ]2`4X©Až}äÜœÊÏØiÿX ÜÏ×<ånÊ ¶_S*Ÿ«‘ôûÌ´àãá±µ 6ÌYÀÉÖÑÎ[*õ¹´ sxsáKEŽ¥uÇ®<ùÎÿhpú †¾j«žìùØ VÜ+þÚiV¼9÷}ÎóíÜ@Kå·Ù߱Ͽ ÏMz„.¡lI»øÓfÀœò3ÿ{`=áµ£¨S+‚Zqú9~Š8Y+ê§dV½5‘Yî·s_GŸl…ý¿þJfçGå³MÞþåÒ„á±u)+”μpCáC8=z6dîªdŒ @\Élþþ#Þ_´)¦5·=Ô’f êꇷՈ+/…#ÛVñõçyúð8Þy¸ž ¥‘’i%ÈßRa6ÝP«÷µ|ŠO Yó?ø.­3ÏõF>^Þ§eý°mKÇ®ƒ—HÑ ‚ë ]×IL67w¬E™ÙÂeM›5Åá&›Ãº ¾¼Õô|·ºÖH[ó=Ëm­y²ƒ_ë}jäåÚp÷ñ@=µ‘Ï?úœÕÎx^˜Gé…Qd<Ûg{FÇFáuöx•ÓçaYVÙ>~TVέçàßS4Š4ËêOøôP,¾ö(¬X<ó#¾Ý)Ó¨S[šFî$¹×L¦õñ/ÿ8õ|ŽlÝÆ‰r—šQIÞð _n±Ð}hÉÿ#"®v‘°ÎdßnÁ„„±y[ô“›`ÿv ‘ýf[<(‘p÷÷Å’—C®hÉÛÙÜ€QoŽ¥mM÷sl3ú„Ó¨Ë=¼è•ŃÓ~fã=Íéá-*ŠbÀPi9¾;qw à™Y¼ðW>1CfRßE·ÁhME×@p’˜x §ÓIëÖí°Z­¢C‚k»ÝΞ=»HLDï2(Ò®{Ì™ÈôÄnÄÕ ÆÛMaߦ£hKûðAòßÃKÆ•˜¸,áÓî&nœûËŽôfXÌÅ„½NÆúåüÒƒ×ëÄUG ÁUç¢}ÍšµØ·o/‡ƒ¡zâFUUŽ;B‘•~N2˜±X¬z7CyéTñlÙ›5äbÁ™¸þgÖ´æ©·o¦uXQ¸ÍH& {‡ÉŸ¬Fïü KeÑeB›õahô"£jä~~‚Mö ¥Å­ÿãζ1ø\¤Ö“¼jÑ"®¿Š² { å•{[Ò( ´åÐ6 y ßÚõi[ïʼlåî©Ði×¶î?Á©ƒ§È+ÐMn˜-îøøÕ¦V@y HÈY®ä@ åo §û“ïÐmŒ Œ¦Òþ5ºÈÊ0Ñ`Ð <ܶåֳȄõLJ1[X³i{ÿ>@^˜B»Ð=¢MZ>A‹ÚÞç¶µ9÷ YÎØÏ—ÑcR_j,t{áºUÒ=†˜{˜ý} 9Ÿ·•/¿K¡û½ˆéy@psí”Ì ‚‹E:}:©Ü3zëÖ-ÄŵªôË999<¸Ÿ„„“8öjý Õj%"¢&uëÖÇÛÛ»¼K y§ö“ Õ¤~¸Guòr\ AÄÙÏœÏ$WMQÐFDŽõBî6Ný{GDS¢}+ÉÐgeû)P«,U IDAT3± ïɣz›gMb¾ûL¹¿1žçk“’ÈòéÓYÛä)^º57 ‚ó¸^^Šï—2f›5k!:B ¸FÙ±cÛ9÷ˆÊî•¡÷òò¢~ýDFFU»ÞÇ`0`±Xððð¨hŒgD,±•Cð¯GÃ2¯Êç±UªlÛ]ø0ЈFÍ«îcß(â|¯%»}ióðTê¥;0èpÞ[¼êÞ´õ ñžb2¬@ ¸îzà¿ÃE©ZI’ðôôÄÓÓSô¤àú@¶àd¹°ïš< ](ü§E®í¿-=Iä-ݨ/Ö¥ÿ½@ .1Šì<«n¨'5—»ê†‡åú,*ÔóÙwR§FlÄ߉Y·dÅ÷èØ­kå‚^ÏfëâïÙ\õÓi9¤ whŽÏ56>¸° ½NA~ÙokÅñ¥ç'±ÿ¤FDýˆëf7í+cs5úO±“•¯áî}á×€Kb©Z€ÝáDÑMXÝ-˜äÿªOª¼¢’¹s _ürGƒþ<Ó¯Þ¹åÚ®Tvý±šu{O‘­¹sÝã[PÃz匂^ ®%=ÿïW<üR÷~6‘Þ¾çy3гÙ2g*3W¤âè‰wÛQ¼vwƒkðB¯“säöh1´‰ñ=gñõÈOL™îäñ/£õe3^ãØwãxò»ã¥wÝÐU Tö޼‹OKu¿¨;¦òæ‘Eöñô&„ª—a–ý=þCóµœl|ï¾}‘‡Ö¯ð¸Ô£¿0íu'cf¦¥ÐÒøeÊslíø/tõBºZqwt{µhnˆö97îÊÚ|ÙúooœîÇÌwrî¢kvÌËøQ<óåX:Y®F?9ØøÎh^[ëÄìí‰Ywç4Ö¸#ƒî¾ƒ.‘Ö+æ¿+ã“JGøúå}¦~ñ§]`±vCƒRq¯Ûö1wòT¾ÝoC¶úàc°±níJ–¬èθIÑÆïÊŒ„„ ‚ÿZ >ÿEâ¶·?fPøµ,!Uþø”w#¹!¦ù9ÂJ®ÕÑ£U¢/ë}P&rЫ|7@/µ‹ŠžºŒÿ=¾‰ßžHß ÒȲñ¬­’õºÜJ½ë8^.´†Þ`”0èº^á4rToÆ>­QKÖÑu@—Tš¤_ÅÚ}•Ä?¿àÇÄÕirŽ(=ÇæË„Á(¡žXÎÜ?âX*þµS+˜û{*ºT#—׎J{ªÀEí¡0çþ(dd´¼£¬™3©“?Â4ó1Ú_©ÇM#²¤"_¾p%±vöLÞûý4AÝûÓiëþ–€Rq¯rhñÇ|@¥îÓycTk yì7'>ùYóZÑdtV!è@PmAŸ’DŠGmb‚¯ï|°ì[—öí/ÿïH²“½K¿fuB‰½ã‰®dÖÏÿ”„ÙQCNÜkcþK3Æ.´äæÌ+ôxÔ¤EKp9\hz¡*ù½«tÄÈ É`(#Ê*°ù2ÙFêvlAòâ%ì¸q8ÍÏÄ™žÃÆËQZ·£ÆßEÂQ¿:ý„º+›”ÔÔÂl´ìMË¡ÒkíD6ïwqã ¦+£gÿq¥ûBÙ÷ Ÿ­J'úî©L»ËŧC—Ÿ7Ŧ¨‡Y·!Í·'Ü]²RHÕeÂú>Hÿ_Çðåæ l¿¿m¯€¢‚^ ®i•žÈÒ™Ÿcëy;¾fÉ_'È–ivëC<Ö¯>žè9{YöóvRŽ`·›øíÛùì”d‚ân¡WlÑÒ¾Ž¬š÷ 6"£À€OdKúÞ{7×ó@ÒY:cé}&Ðß¼%Ë7°'#†ûÆßA#9‘¥¯Ï&ëÆxì+¾aõ±Â:=À¸fV|0‡eû²0×îÊÈ'¿ z»Æü?÷q"5VB¢[3èÁûé^Ó -m;?þö/Göæbs­fî¼½ÈÈ·¼…žõ mU-dâ…»^L#ãY¡]©ýUôQùŠÞ ˜¦ÄžU zŽÆîuùÔhØŒ¸ÛI¾gë™]ñÖÈ÷ÙXp~tkÍ“=B[ ìæãÇßâäͯ2©OðrÇiõà÷üïk…;ÆßFƒãK-ï Kß_²IäiÚë^êÛŸ¢NÐröóËÜoY¾ë46ÍÀØnÜ;ìšøÈ %±ì­Iïõ<}Ý6±ô·MìÍŒæîqƒh ç±û§/ù~ýN¦æ`ÇBPV ¸ÿºÖpCKÛÉÏ«÷qüßò”Õ|óín$$‚Zô¦{½¢¸+ÏfÇIÖ|;ŸÅ›Æ]­ô¹k7Õõ@Ò’XöÎWØââ±i>K·œ$[ ¤éÍÃ}KÝ›ž‹¹þî’¦òͯ½hÒ/à:²Œï¶fäSžÌÚ’Pby l¨¬j]‡œùvTŒX,RÕ¾´ìÝ,œ=—å{ÒÑýjsc¿Dïÿ–c­_`X3¨‡X0} –{Ÿä–šgàŒÇsO£rzå~®4FÎ3Ï!›Ãèøø›ŒîDAÎ6œ®òÌIàXš†±y,µgQž†ËHlO¤Ç9–¬Ò¶öåO²A/×2º“ôã;Yúv.íïÅ#jÂá…L˜0‹EMßà¾:-xûùáÊtC–ÜðòõÃO’ñ2ݪµ V½ù_™†0þ­qD»;8±nS&OC>‰~¡NÒOfçò·ù+ÙLÇ>½¸§VM¢ €æ$ýÄN–$†òÔóo0Ì´…7ƾÏ3;£éöÐDæA„›p¥lgÕ!?ºÝYzï Cî{íï þ«NKÈ…¥:^¦ö€ÇÕÊ[F¸Ç1âþÜóÕzNöHãëX™ÐŠ/7ÁœSXº;ø6_Æ?Ùéé-!ádoBMf½7Œ:º—¢àr©èxÛ¾#’R€’ŸI&tiMÐê“$jä].=ëq é'V:ZÓ»wL€Z`Ç©èåÚ¬%®ã§ÝõþY'‚ ÒII“ñm;‚‘›‡óÞïé}—:¡}Çòt'?ìéOúß²öhzmïJ²ß*®€ž<ØægÞýéM›¬cQfw&tö@9T"ö/ zUmÜSÞäfS+?`â3š3‡äÄ,<ãðâŒAÄìØTî«îŽ¿Ys¨÷Œoƒw~ÐuÌpön›HÆ™N‘$$ d©täHeâ¦äÛUøYª,FΓ‚|r ÎÂ]jyƒbU—0”s"Ë(|ÿJPáuTì`(׊:2Q+2ììMWòÀÛì6;:>U>2WN!!¨N‘>ƒ…è˜p2þ9IŽ^0P¯kwê•·ª†$ãnu+ú«‡wwk‘•p÷pÅÅ™'ÒZÖ^~ù~ «vž$G5 )Y$´@¹ÀØjÙž}$ù´æ¡ ­‹ ÎçØú|øyîœÈ#áËxvq$¾x'ÑFÐóvóùË_¢ ¾‹v%²öÚéµ|:kñ³Ú”±­ˆÜýüôÞò"_fPD É$™ñ¿úãÄ‹)JÖõòëЋs¼e3«…±ãç%“kwúC±CpaɇHRtBR’8-ÛØ4»Ït§žIšžFJš†î]XÛ³a¶,òôÒÙqz;+/åݧÈÓd$%‡dgK4]GWØmªZöü| ª°Ùuê8 ÁÑDèö"1§â²+„G×$ã¯$rôhLD†{g+Š~—„Õ]Âát é^ØtÍ¥{Ç`‚Ÿø„Iÿ؉ö65\ gÓÒ—Ä¥ª6´zœ» –L@ÜìŠnKaëâOùÝ3’&;NMÇU…¯Tg*©þ5 ÅŽKpa³y(“Q”ù§Tö]/ë…R™ðâ8ªÊÏRe1r(.ÒO-,îXe§ÍŽK×Kø[#?߆ŽË•ÙÄM”ÜÁu˜ÿ”ÎCiª²c™›¶ÁhU)š(ãëçS­Œ±T&}VdMá W=Ì܉Ӹ»É(ž™Ö†š2êáyŒŸ|ÁG[=ûÏ¿t{2»ÖÿÆ’%ËÙpL¥Õcï3©‡?²âC¿'ðÁOí™Ò1™/^}¿j>ÄÔXs‰o»Ø¿ü7šÜNÿò{ÍÝQÝÖòòœµt~¾+²ˆÜ²þÐtIבôBŸarÇ/0¨„À ¡÷¨6D†š¾^fÔ²nUŽòÝ«o°­ù^|¿Q2Ê¡/þô© · RÑ?ξªI2’¦Ǧ©%䔎.QÍò—GFܽ‡9Gšs ŠK»ä6T«rÆ£–€êDÕÄ EÓ(ZçЈ/XØùU†Ô1Té+éD¡jɶuõâ'WËÏÄÈÅÄ­KA)çuÙ'„03ìKLä´‘gÎqÝFbB&º¡!áÁW9C/‚ÿ¦Ð0üÓ8UµŠ3ð*‰'“±††â-+õ‹þ-õøfÖ¥4ã¾ûÚQÓ­ð5ÇéDÒtC¹ ºz‰í?lÿÌæÑ«‘êwâæ!÷aùèkdïÂ1’ÛÆôãïñ¾B»?ÁŒ{›SR·kék˜»R#þ…vøUØmÝv'MÆ|âýÑÀTl{ÍêfÅj¼z*ÿ‚kèÏü·² ý™´|‰Úg»Ý¦{ O’N¨QÇJ+‡zÝzÑÊ\Jö£8ì(zQí¾Š®—–/ÚÉ­lJkÅC÷ÇáãH#ŶÇHÑL%VH)\½ESµrm/k³)4œÀÔ“œrê„ÇBÒÉ$¬á!xKEm”›a®hŽA™¬³â"´×SL1:ÉͶ¡PúIÁ¥°¡Zmè娍+8È€ÓÇÀNŸ3}åN<Ô·*|å ©Axæ?ËÖˆ>£ø•LÒ2tήt$c4àtjègÊR\Ùdäèg3áe|RµŸ+Ž‘‹:W¥è d™¸7ÄרÂÊ-ëX{°'÷Ô+ì íôzVíqa¨ÝŒ&^W&C/ò@ðÇÝ™îAÛYðãalE÷çÉ_ùnƒ™nñq»„¿%yxâ®$p䤳ðþœ²‘Oî,½y2^ÞžØSRÈѯŽýÖ†˜òÁfOÉÀÂq/s74EõçŧÚã£X öÁ\R´ëÙl˜3ŸCM‡0¸¡¹òþðmÇ]}ÜX¹àO2Ϋ²‹Y#†òüÉÕØ–êÚ¤p’ ‹‚.E«¢NYaß/ Xº¨ØÅqœe?n!¨kG"%0ÔéD€¿øzþ6Ròò±Ùò±ÙrIOÉÀQUGyûà©çß}Ù(¸RÿâË%;QËÔg{z{bKN%·q'Ev¦WÈ6~Xvû™¸KXÅÂõzv¿T¶é¸ò3É,ó—ÆKrªNýÝqß¼šÍÙz•¾’üÛÑ«ñaÍÛÄéÀ•ÊßßÌcez GJ!Ô Ëf÷î„Âò'5“­ß~Úlý"ý|â]qUP2èA»;n!R:É¢×§ðηKY²às&½<—]NºÝÕƒ+´Ü¦ÈÐ Á^Ñ׿ŽçF’õæTøÝ—P;ÉVZÝÿC¹Á%\lEéÆÐ[Ö1eÜHVYQ uè7¸7Qœ.%èÃoìAÓŸæðèc«1š¹á‘ ‰1\1û%káV@W°eç`SRvüÆÂý§9yâ‡;iýÔf¼›3_`Ô†ÜwïºÖóŨäâ èΘ¾íñ—\dN%_6áæJ&ÓaÂËM*u›­Óûâg§â˵šv!à •S‹'0xqß׸•i¯ &F¦¸´B×44 Ð4ÀL»ÞÍØ;ëy¾/°¢e¥bl9Š)ý‚Q.ÐC4áqr§¿Ï˜Ç= 2áÌH#/æ¦?ܯâí\ÛºòàÀõ¼8á VZP Ñ ÚÄwN¢ig>ܶ7q?~ÌÓÏþNѸžã¶:EË,žcsÆ?AÆÔ7xä‚=ì¤fzÐväî­­áp×»”°§h—òl,î¿ÊÞ­È]ÓДK`CUÇQ —c#…uþ%lt…w¢OÍøõÏÓ´¿¹Få¾’Üé6öE2Þx›q£æ yÓ¼on™EgÚõ¤ãÝ·ñÛ¤—ydc(ŠJxÛXï#‹ŽçŸTåg*‰‘‹9W.ýìy£•è+)j3^2ðúû?ðÇ¢ChH¸4¢ÿ¸'ÙÒˆÍ~eV³’NŸNÒÅÝN ®,[·n¹ ‹h8sÒÉp˜ð ôÅzÙžÑê䤑ár'ÀßSEÙ3ÕFzj6ŠÙ—@?+†+j¿FêòWxø£(žþNÍÈZDÕŽ$*2’ÈPÜdÐí§Ø°x_ÿr„ÆÏ¾Å#MKdåµD–LÏ܃NMÆÜ–Ñ“GÓÁWºæã¯nÝú"pˆÀ¿œrtW.©ÉÙ’ÙP‰ÌÓjNžA¡˜Yh éiä[ƒ6ÛÉÌÌ/K’ÑŠŸ[*ÉY*–€ y¤dØÑ0áŒ)7‘t[Yé"cö ÀSÉ Õn%0ÐLA® «¯‘Üb£þnäœNÅáæ‹—œ‡­èÁ¹6Ÿ±Ç)/™›™ P¤ÜL²l.ô"{Œ9‰dœI}#aõdz ™Ô<¥‚þ ÇÃYÑû€›!Fr“Ò±é—Æ†ÊÛ(ßF/W É9®RƒS¯à,¶Âv+÷`°àí닇Y.\Ç>g;Ž™Nþ°7[x¶Ëf¼ =%“žª Åêƒ!7‰ »^ŽOªòse1r½ñÁdO'1Ã^¦Ï$ŒVo|½Ýpeg’«»ãïkA­°«ÇÁƒûϹGTvß‚^ þßzA)IïÌÇ.[ñ0Usd ¸PŒ¦ÿÄ£í­[·Sï*ýº„l0 é*j³$%Ù€A]ÕPÏ£þX’ $U­¬üGÆ`”‘t¥š3'ÏØ£**WK4] .ÇqT×W®c?0~j"ƒÞMks©0$tµú“f«çç«×2Ú%±ëСç%èEÉ@ þ_"›=ð8Ÿ/üGÄü®ÄD½ ~U©¼BW´ ¨TÐU¥óT—zþíªWÙ_—À†Ëqå·©‘±þk>Ýc¢f°&[ÿlÜÿý“¹Ñª—^Ó]WQ´Ëáç«×W+L„ àÿ!º®‰N\6üÛôg°ïŽ¥æ£…ubÌ]ÏÑØ+ŸôÜDiˆô@ .‰ ²JpãËèKLËŽ4(¬ÇÁåÈ"5G "… @pÉÐ4!è—3À °åˆ~‚^ ÁåBdè!è@ \ׂ^”?BÐ @ ¸Ž½ÈÐ BÐ_lœJ°ä~‚%›ÍôéÝé¿ØU:y§öqL«I£šžH"v@pb2™PƒÁ :C ¸ÆPU“ÉíòzeßB¦®bäÈN—؃CÏ?À¢éßøØý¨«>ä«ZSÕØzýõž–ÎÆùóX—ræ¤L`›;¸«™;ª(ì^8ƒ·\ðÁCM0H,¸ÉNNü±‚#uo¢K„©¨½6.ü…]¹zq{Íû2 ÎYĪ@ ®"þþ$&&‚Åb"\#8NÒÒ’ «q9½Æé]›ØžÕÏ2jTòlưaëyvQ2/êÂWÅÞ¸!V@;þÿ›²”„ÊVÙ7DÐoüDn,ÑpÁV.ØPù÷Î ‡Ð¦w”óX@É:Ⱥß×°yç!N¤å`×Üð ­C“6Ýèߘ SɱۂjžÝ:Ù#ÌÆªw&2ï`áÖÉJn9|Ìã{оhŒæ®)Ïqs°„š·O&Bšòƒ €ŒÉlÅêÒ•ãþÀVKgúÇù‹hÁU%,,Œ´´TvîÜŠÝn"\#X­îÔ®EXXØeôZ[·ǨlcÞœ#å”›ørÛ®màé˜Z;´?×g¥»áZf” +8òòÉ«BÐë¶£¬_€ÀÞÝiàQê /ÿ©_ìÀ­yâ;6#÷óß©=ôa:ö±~ÅLþ¹cþ7’Îa…] %ïfãî#ä—()”Ò¬ô}îCúÈ ;?Å+®G˜3¦E™Žs#ê–g™h™‰“gã>e7øÒêÖÁ´ÐóXqðGŽ8ÅòM@ ¸úȲL³fÍiÖ¬¹è à?@µ½š°š‡ÃhÒÓç\1¯¥ðÏò=ä5L·²ï™ý‰Œ¹€Œ´¹·Œ¨Wµ]Gæ±{Ó1Ü­%­*àð¢Wxþgwîœü>ýëy"çýÁŽC¨ß²­šÐºkOº~1…)“çà7óšºK ›°X,¨%½l6²v6¬KAC'çXùÚ7Lž²  ï†ðx¯H +-Ô»m/ìÀÓR¦—´TN§ªdyg¡¢bQ @på½–Á_ÿLNç'˜1¼9çTÇ»6“¶â8>^eE¬ ‡S­Þö¾’„ÉÍŒñ<‹ËÕÔdÒ½‚ .Q:£žø‘·¿/ ß+]8¡@MN$Ù-„Pï¢}h>ôIîÚ÷ sVÜÌëýÛҶ±}égjè%¼êÔ£Ž›'ýE¯õ+õû¦€ÀÒõð’»u8· Ó÷°ó”ŠÃt‚d­55E½@ àÊz•¤ß?à“Myä­f”7ÕUKM"Q %.¤´Ju®ŸÉmÓ7R­"C÷¾õ÷FÒU9¶ïjÔíD§¼ö­ü´¶0 úìì`ÇÉ㤆5 FÉÔ¸F×n1|½~ÙýÂð“ÒîaÇqåŒQ„zÔD;´œ?˯ý‘ýZâs_B3wòóïûÈÑ@²FÓ­oKÎV©$ü±† â¨d;2R3@(z@ Áô¾ååÏS‰÷ |Ë[¨Q'ûßœ¬Ñî¥ß7·ËâÅz•zeß<ür*Áç)r•#ü¹)ƒØ~MÏ.“©er`6±}â~öƒ=x k›)ýÞAÁX³3ÉÒÁO2Ѭ#ñQg?a –Øþí’›<ÆíõKʨ ¿ñÞ¯‡èsOBQpÚØ2ö°bk*õo>+èõ¬MÌýÙFgÇRóû§ùuM2}†‰•n@ —_лÅôæÙ©}¨éQþºëê)V.ßGd‡ /«Pe#¦*U«Ê©Ý»ÉŒŠ§Ñy­t©‘¶æ{–ÛZód¿âØF¾Ã‚w‰µ;µÓìÙ›K½[ëœS»®9˜-XprxÍB<›¡¯? $cšá¾2?Œæ.Ç>Uîä¥&¡XVj@· C=ô5mÏ.ñ¬›=‡ÝM‡3«a0Æ>­ùòÃléù(­= {tëÖ-" ‚ÿqq­D'àÚôÈ~ÔŽ¬èMÇ—~ÌwÙ×ëÂ2ÎzÖ&¾YžJóûÚt û™™Ÿï#vèë´õ,9ÔðÄÛÃÁágñ¡i)[ÙœP—nMÜË JŽî?‚©f7e3 nÍSêÙe+ f™D{Bjh¤­:F†§„#+‘“NäðŽ<0T"¼¢®z>{¾ywµ`ìô¶øH´ºƒ»k>ËûŸl&æñ¶øËBÿÄÀ\ ×® ¯%ƒ‹Þeúb'·NJÜl «åîeþôÙ~'ov®îfKNNmœÏÌ÷WPÐí9^í\ú{²/ 2oÓ6r:uÀ[rqpùoœh2öþ¥AÏÜÄÂÕNÚ>Ñ p“(-EƲ(;o7Pò31uŸÄ'ÃoǨå«ÓBºù!gÉ}ïpj$ã*ÊìÉ¡;NðìwxE‡ß½%½‘ $Bï½wA)¢ˆØŽ(ÄOl Ò‘"ˆ bAA± €Ò;Hï%H'½ÜÜ~w¿?’x}¯Ô IDAT@: 5ê¼Ï“GL¶ÌÎÌÎüæì™sþúb>ËŽù3jú(Z¸çÖÊŸ^¯¼Àé ‹xg™Ì¤QmЈN(@ ¸/‚^FŸx‰#ûw³ùmœµkňéoÐ+ĉòÈy›.†c»6²æ‡¿ˆ®<€É¡ê-JaÍŠáÌáýlÙ´‰]1•è2ìCFv Æ©ÈÕ„ôêOø++ùè7Wó8À’MjžÒ–J7ŽU0ÄîgåÜO8Sw :ä[øÐsâ"F×V÷ÓÛLJϽÔ!ö'…ѧ–œË{þ˜¿íóy>T ÈdÄ'•ËéÈ,ÜZóöÜÇiêUЄ¯òlÍë3Õ|û{6²$: @ î?Š¢Kjj ‹ETˆ@PAÐjµxzzQ¹r ’Tv¡¨¹•ˆÚ²Œ/¶GE¼Á™àzÍèðì4Þh‚{ª+†+ìü}?â㉺Á¹+i8†6§Çó3y¯Cn%šæmDü:›…¿Ÿãêu3î! iÓq4‹»5£ªsÉö|•WgÆOLaö¢Ù¼g ¤Ó˜ÿñL­\ŸzË9¾´€uŒTë6š™#ÛçºÛäÖLjÔ%ÎIœlDÑ€œqŠo>þcç7éè©" l¤éœ¨á*&¢¶.ãƒ/¢iúpvÍ]IÝ>}¨šO¢ÊG;4ê|R©1ƒŸ‘Ј€ô@ xÄÅÅb2™hÑ¢5ŽŽŽ¢B‚ ‚Á`àÌ™SÄÅÅt·½„[•F´¸5þU¨äS9E¨$™ÈH5ãà_‡Î-z3ºVMªxhË`ÕWáß°7CBŸ¢Zõ |Ê|c ·z™¶|`1OD›'ÇѦZ-ª{h‹97›³~O–‹xR§Y+'~É¡Ðá¼?¬NÈxú¡[6“§vÙ0VêC_Oòµ_˜½*•.oOep]WôÝðǦ½¬ûôGâ“ÒÉÔ›°Øl( 7£þhê2fÙdúˆ–@ ¸Ï¤¦¦Ð¸qSŒFz}¶¨ ‚ R©¨Y3ŒãÇ–KÐK ñЍ>@Éæòß§°ÕjIXžÏ; º´ ì+ypSþËX Ùd›$Ý\°WнQƒ“£çÁ‘£G—{ƒûíœ#ÜÍ>Û´isdY•!T@QäÈßEæˆÒæ ˜lò–6΄¶hUø—¸Tò(\Íh]ñÈÿ…R²ÃI|±Á?›Í&*A ø—¼›Â¤,@ üƒA@ ø¢(ÂãV ø· ,ô@ Á?a¡à?ˆ°Ð ÿ„…^ þq˜ÉH7`M8È;®aþ§ÈìŽìØÁž ©Xïï¹zèWÍ¢ç!è@P·1û´Ù·n)k/ßÝLŸÖ3k˜¼t7Éw3¢¡é+?ø„½©Ù\ùq3·&sãòŠ‰Ì” ôåVù †”XbÒLÅÿÙv'Oâ› ©œùãcf}wSÅXÚyâæ}±ŸÄüÁ,d F}6™YÙ˜ ¹Pôùqñ þн{m­(ÊmüȘtédè­¥'ëâ8w.†LY¹ÍûÜÿŸûSæ2ÔŸEOZºÓ®;Ùj"[—IF–³íßÜ&·ú±‘zâ'>š1‹?_ÀZÜ1æDNþ¹†¥ ç3ã£e¬üíÑzùŽî[^„Ë bZòDZrA9¸ÝTÙÛ¥u¼ûñÒKÔvM‡ðJ½ÌüYfÚ°Z,Þuch=îÎrø³s,¢6'Úa_ÌjÏPš×òF'ª£³?"¥ÔEÈ~þÀ¢MQÇ[™øÍ9,]Ûc(Ù{˜=úÂæ|ÄsÕË“½ÐÆ™Õï°ØáM>Y»è„¦®B›VjÆ/ßϯÆëíÏù¹ó U}°iºm±›˜µôm&?†¯Àľ…c˜¹= •³+Núl¯ðö<>ô uFrªIÏ»xcæWxÏNc—ÕÏMìÿøEVù¿Ç²!µ(©&m‘0s®‰qŸ¥©“ùcÚ›m¿€w:»ò`J¯yŒsr(ÍCÝ‹X4‹”ùžÕßæ'ôcÞœ'©Qä>FN|9wÿ¬Î_O ƒÃƒ¨'#ûeö.ön.Ø+Ft&-õÚóØÓOЩšã}k¿ûÓ&¥u=,aÆW‡H°€ƒcd(Ðïýy¾ý`k.èQ9ºã®Ö³g×~ù³§Œ¤e¥ûc;‚^P!iÉåávSeWTT•Û2tt]Ì%(d•GÁþ¯óAš#¾ÞM™Úä.Þ\Nçĉhœ,ŽlÞp­ˆ ÒÇ_$2d,?¼Û§¼ßEaË–(JœœEVÜ/|ý§3û°¯û*Ú{_“ô͈ø¿H´ëÂëÖCð`Åøí¼—ië~Ÿ$½ZƒJ²¡zua‰g×góøxk>ÝúÓáè/ü-ú½ˆõËY{ÑFÍ'f1L ¼Ô:έžÄ«+¶²tu3êmÂýP1BÐ *$"-¹ \²í6SeWT$çÂêÜò8ï{ 7ãwòWDž[ò½½ [–¬œþìEÞK³Ï'ÆUxµÁ‡mo59fÎs 8Ñ„n^á¦÷ÅçS±ØQ¥®§#®Óºu`‘{*ÙñœLÁ¢·pªJÝ*nwÕiØÈQMxa¢_‘²Hùî¤r  Õ³cèäl9˜N·ÞžH8Òp@oÜ'¬g×€pºyÜYÉnOX+7þ[š Ç¹ ›‚ÅhAVrDPþó *µ„¤Ve%”ù•4ÔlߘëëáD›a4ʳÂ+™ì_· k‹Öý+•SOH X2HLJʱF«Üh:d=wMæà mškïOI”›ÿ¸ßua=ÿ_lK!ôéÌláó!¿ÜxonÅv™=ûb=z0üéZžH’¢" ÏúoÇ×÷qüùÆ´ºŠ^zA…Äb±`³ÙDZrAÙDhn?îYw:{f²ÿû ¤µ‰ÖêL²eœ ¨Ni)Y¸{»—[ä*™I$YiÕ¿/½*ßK)o%+þ çNcÿÁC<…Õ¿­zc‚"–2%åüt4¥  Ñ];M\£‰¬~¹É]œ(­\Ú³c³Ñ4(‹+…ä…¯dgëQðDT¾­hø;dѵkîbÃzšå¯, úá™ÒÛ·Bl޳]ZËÛ«¬<ñîãÔÎ÷QDÖ]bÃ’_Øx"Æ›=ŸedŸÚ¸çZμÀß®aÓ©ô²Þá]xvè#ÔwWÏÆËIéù}ì°á¯œK åé‰Q[¥ãôo_³vïE¢“21à€OH3}þ:Ù!'Ÿä÷íç¹v6u;߯9„„Oã^t sF*©ÌÆhv®ùŽõ/“jVã^µ1½?ÅC5‘äx6.ú}×8øŽ ‡£É¼iððPÆ>RçR^ûZ2XšÁ÷›{R¿_ jÀre#?\jÁèñ.,=sóà»Q†Ò®Q¦AÖŠ)Û€ Ò­Û 3Nóãgß²éL J¥`Úô{”Ð k¸Úâ†6Ô‚-‚u³~ÁáÙ×x¤J^Èkãwy¦n1_Ó”ÒÛ¹Ô>RÎs*ûÚ¿òc{ø`Î<†ÉR\qb¸š,£iN°Õ”»/HÆbò&¼¶ ҟ׸zÝF«à{ÿePzA…E¤%üçú‹õ,_½½Œ=º²š¢$ì› cÁ°FhPÈŠ>KDŠ¥Œçj½B©WÅ%wB—IÞ»‚ON†3b~5/Ë’èZôìןÝâgØâˆŒ– jHy§'ó•K\sªÎ`ßÛ•›"¶®'"¨=kå÷ÁV0Æâçowqñ.E’`v¥J­´h9€wF7¦¶ŸS‰"WUµ¯OêQä^‡>Ær÷â|½ï žå4Î_H#¸G2M¾JöŽ_±§Z¯|nªJ„…¹±öül]å^ÇŠ>#,cùÞÛµÐ+J޹4 ½lÎ *Ê„QVPTäZÄ­œ\¿à—ßà‹w«¡ŽßÅ‚w>bžýLîé‡JŽgÃüyl¯ñ:­jG€*…ËÞbÚRWæþ¯^Š…Ì¸HÎmYÊ‘ëŽtêߟ‘Áäºñ8TnÎ3GS;ÈW’9øÙ{Lþ|;ußí—½+Þ~¾èU¨-øúù¢F…‡³æF=)³œÊÎ?ä{Çç™þùLÂ]Œ\Ùò1oÏœ‡uê;<âk!3æ4¿-ÕÑvèx–ÿ/ÕÅU¼>a9?×›ÉSÁª’ëOv¤å³ýYûÖ:öuG;—T¶¯Ù…דs©£úãFû(¶»P†[=G€ªØ2¢äû cMãÔß±]Û•Éu4(¶¸ÒÛŠël\ðÛüDZhMW‚¬—ùcñ<–í¾J½9›E‘-¤EÅãhÉ÷ÕF¶wd£Œ¢¨nXååf™JkgŸRûHùzºTç1^i`&KgB‘­Xr?ãåï÷r–ŽLYÂÎÝm÷AÆÅÝIÉ"S—ó,BÐ Áu5zŒz‰ÖÂ3CŸOgwÈ˼Ö9¿VBí–'®mDþµ‚¹;3Ê(4U¸w|ÅÃê¡äøMÌù4жã§ÒÑË iâbvl`ÝO³¾&ˆÎý1¨á5Ž\¦C—rZèœV±¯7ûº·BöÕ3œó®G­6èõ|MjVõÆéN bЉôL ®ÁÅ=çÔ³œLbš#>žÅÖ_vÜyŽŸ1ãf/“{–ëâï*O2¯‰Cëy{WB,ƒ® ®Ís³auó©0¡ë$T9?RÁº~ôÆ4sGŸš NMõ|cžùf/ÑÝtm[bš1jj}ì3s\Â=N½a9’Ñ‘n&ÎÅTaéÇC QŒX¬V, n„·md5cÍN#-µ;µÀg{4q2ø¸…Ñ©Gãc‹±½zÕG ØÌL¹ï[á2Ëq{øít-†}Ñ_s ‰É*!õ©îQ‚HÐÐ`ؾv{·Vùwaüì6øäŠ­õº¡^×ǹzàw¾[³€1_ëÑÔI{¿òÉF9aëöÚÑé½F¹iË;dsäÛÕ¯ú‹ëÙÌ^í†òVqQnn{ðÉ$# \ÝÜŠÈwRÏ6¬V5êb2Y—vðCê.,²'?jöz‹¥]ëâSèÁÔ5ȶ›±ü%{<+W¾¿c¬¢ï‡~c™uó9–Õœ¶ªäª"Ë`Éu2€ou®GoUðKŒ'A¥çÀw«9×É•4’•d“e·ÿóðÝ Ð§SðC– cÂqþ\¿§cÑÉ*$k&×MM‘Åf —1ÛͲ³‹äo(\fKì5b|C T ¹bΆÅ`¥rhRÅ“©„‚¤¥Zegtú\ ‹„£“„ÑdDV\K^`) ²E&ü‰Aø¾º‚)G „]HÅŠù¦Yú®”Áz«kÈaÝŽ¡Â«É£Œèá¢OäèúÏÙêR ­“¬`¹E[ÙLI$yVÁÀ‚^·ŠÔ¼°Œ¬ïJáV(` ¿ÑnÕÎRi}ä°Z°Êüjàà„£JÁ¤7`Q”|í-çºÊ9âìpôŒô@PÑ·Ù9çIhð= ÷'9àPŒc·Ê™à6ç”NÄÔS´~ª3åòš1EòÓ¢ÕD5Í›µo'.‹•Ø¿2o§ƒfõ"PuÿréYv¸¹ÙßÝëª\qw1]ÜÞ þÇðáSÁ·tgÒef£rqÅ页p[ÉŠ‚¤(H €Z'*yûä˜~ôÓ’j7ëÉÃÕ[á&·FòÇó9Öhï-é@ugÖˆ¯özìí—ÔRî?nþV–TH²rcã¬,ÛòÉ)E¢Œî çvŒzú _^iÄóÕX-ò]/C™®QL_rð $¤zÔR(uC"F}Å?ä©õ-ÛJŠÊ)€-ÿµÛo6.S;—ÐGî¤ßZ¬Å&ÃS¹û`çãâH¡ZÞø¤è‰‹ICQס²¯°Ð þë"FXèÀBä¿s̳-ƒCÕäþñû¿búÂÝx>=…gk—]äZ’ްzþb~ÖweÒ[íð,¯?ˆ-Ó?-âÃïbi<~:«²ì1é ÜÕÑBÉ"C猻ë]®J•ÁUÔì¿–€ÜºêmºÇ˜ˆŽJ¦rõ*ù" Ù0ëØìqÔ”ýª·íCŸ÷ßÒ,ôyfù|¾Ï ƒYq¾ñìæ¸h®ûTÆ_£ ñõÇÇ’IX—ž4+ÐÍd¬Ff«’ë»oCQ ö9ú(’›1òù&¸“IÔƒþâUem¾)9Ñ[d›\lÙ —Yë_ï¤hbM þ7˜ñÑñ8VöÃMʽF±æ’ö²:[-ø÷Ï4‰¬ =V ~)¸e(Ó5”bʨX1›L¨“¦ :¬dÖ–“<:²v·h+“_•ÓŽp5C&4Oñ[ÓHNU¸éH…FcÆd’QòÜR,¤f*7-á…ÚäÖí\r¹£!ÁjÅR\¿W× I=¶ÞîK=x&,§2䄽l;cAÜú®÷GÏÜ#w;™{œÄ¬K%ÝPŒ“%ž“{m(½ÂÌ×ϲïL"û÷Cû7äªá Ù²ÒH3ˆˆ>‚ÂCi~›ÇûëttÞŸš÷ÓcÍ&úèf–Oy™œ$xø4>Â-å¼l$9â ë—À¨ç±Çk ³¦?Ocײ[©¬º8Nn]͇¯½È›¿šèñÎ ^oç]Ì„¥&(¤ ¦“{9”b-õZÍ F …2SI3;ádgÂ`0b¶Þ­wÓžúMÃIGñÆ£awé³ ™‹Çò}È>~Ü…kçcÉÊíJæA>wŒð—GÑ)/n²ºÕkâ*™IŽ&Ù$“¹w%3Ž×gÒØ6¸«œñ÷‰eí‚ \.¼FPÒóÅátô¾ñí„ÌkYq¤ Ïi›Ùœ4ÝF3f889c—Ïx¦è/òÓç;qð<ݵnã*óŠÖŠ!#c¡ã•Ô#ü´òÍkÔÄͳ`'”${\ÜÑÎóÛ7;¹VžYPU….Ïö¦N^ü;ÅÀÙÍ?Y­?½k;߆K„ƒŸN`cÝÙ|ðg…ÙÔ&x˜‰Üö5_¬ÝÆqCM¼9•皺ÜóìŒrÌ^VýqŒ¨èH.^ºJºC(-;?·ã:RÇóÓ…á_M[É–ËѤªü©×¼=ÏL{™Žae ‰lY0‘ý†Db²PûÕ¦M—1,êÓ–P—’Þ ¶OòìÞYÌþ N^•pÒ_KÚ:O1çåv¸I7 O×~žÂ;?ÇŸË"&åWTTéÿ>³¯vÞM ÷ÖÑæÛ¯Øx¥Ck”w VHÝ»‰C~Ý™rç_kn/,°Œ‚Øõ“´¾ÐÐÔ—™³QCÅ × E–‘%ȱòÙÓºWCÎ-}‹µfGäô$4MÇ0­Ÿ/V£›ô Y³–0î*ûh1¥&£«ñ ³^hë ¹hÙ½:3bÀ^Þ›ô*Û½°ªCylH?âE#Ë7Œ¾­zÑä×å¼þ¿­øhìh2üMÉ ³X¤Ì><úΘϋ;Üñu6”æL«Ñ“x6XÆh¼áï’¯<¹\Š+ãú+íï çD‘edë](힣H;ù†Õ?-•;лÊÏlÞ@Û‡ƒJo+ɉ.Þ#uþB&ŽùÉÙ—F}úÓ·ÆRbÈ»® íŸ~œ¿¦LåÅýþ8[mTîþ8Â>%.÷yŠ´É­Ú™Rúȼ+VË\9÷¹YWRõ§˜ó¾š¹K~fÇOÈHØyÕ¥ÿÄ×ÝTƒÞp"°I ñŪ¦£GÓ¤I³RÆ•4}ÿÑ †òXÝ\e£d°yú,R‡|Ààʉ¬}o%®ÿ{›‡òí¶w±ô“mÄ•VϪº¿0’Î5Íìšñ߇Ìaqß4¾_°KyudIäÌñ$<ê×%0÷s’äÔ€§_y„R"Û–-cËuKÒeN§¹S7Ì;umrcõ¸Ô™8„¦yŸ¡,'ùrú:.›B¯œrÛb72éƒÃ´™ü6WVS¦4Ý(èN|ΟÁ¨š¦ûŸÉÑ£‡©_¿aÙ¶]`Õ[‹Øš‘¯S™³HÎÖàååŒÊ˜A’N‡§Ó a¡rïÈ„OR[IáâÉk¤îæS|¿ð þÏ £Sá €*wB„âw19™ “_å`ûù ‡GùE—é‹_ú‰ê3¦òˆwÙ'Õô«gItªA˜oñ­mºXÎÄÚQ·–êÿH¿9uêDéãÖ=ì¯å½oéçÈDï\Ë>¹]ÚÖÆÇîþ<‡œpµÛbqô"¤f-‚ܱ+k‡–S¹p4 Å?˜ê•=°/úµ\e×oÇH²w¡’—U«‡ìç\‹“Œ9ý:q):ŒV¹Xÿe•‹?¡AîÀÏT&iëL&l«Ïô)}*GÝNø×Wg1<ÜþŽûlÍšµnkQâäˆg1‰rKI×30’}%ü=%ÒRÉÑœj\|ü±7¦#;8`NI&ÛÑ_{iiÙ7Ä’¤qĽ’;j}×Óm8xùà­Ñ‘˜j@F‹›Ÿ/Ú¬8Rô…Y…½».ÖT’ Žx{Ûcβàè¡!ëF3^žvd&$a´óÀU¥CŸûÁ h™óÊㆤ»N¢Þw¤¬4Òõ”Üòh2ãH½á! áèYóu’tÖê¯2Φ’þعãç­!+>½rwÊPú5Š/£«%‘ë™–6`W_?ô9×-½­µn8Û«râØggÙ¸YdÏÐðœYIe+¤$f õôÁŦÇêèŽ:+žTƒRL›ÜªKë#wbþvÅ×Ï­!…¸ÔÂ.~G7<Üì°d¤‘¥8áéိÄú-—.](2G”6oÜþØf‹áàæ˜kŽÌ÷L,¤¦‘+¥’j¶Ç·Ð$çj´èØ©ÄÏ]–È?ùtcíÕR±Ö kÊeÎ¥6ç‘'{r2Δ;È#þ¤‰ÐVh]IH8Wm@Ž»©/]ÆN¢ ©ßgØž–LœÜo()›X-¹^¯Ë{9Ÿi‡&ã:iÞøç™q*Pšna¡/iX—Q+¾ç•™˜3P…ÔÅ}ïûôÿ½)_Ìë‡û™ôý"…sZ£Kõ§Q¨ ÈF2SuX$ê´°çä¦mœȨ́ê­i+™×£¹fÊ—½Ñ-œ…ãn5ßÜp£X°Z%íÊ^fÛ¾|c6¦( XÐgËØÊ·€:t ³ßí…ï•5¼1s+iGœ\ݨäÛ˜A/  ¾cN¿Ü¹b'º/æ]ûbÖ˜­,™•Ê3‹^¦XPþÃPQ¥ã Ýï»ú·dÐS·{²'µšyÞÞ¹Ú`: ¾£ú²ó ØãŸÑ¶>]Æ2öüæ~SiÏ×£L¯§5ŽÍ ¿&±÷xƆßͺ·ëCŸÍ­òw+ÆTââ <Y‰1ddf£RkP铹^( ‰bÑ“–¨GR©±wP!g&£œf2bJT1¦'bR©ÑJÙ¤^ÏB²ô…E†Žäë*ÔZ{ìdÙùR-sÁò8h,¤'\Ï'Њ+‚>%}©õSzý™ÒIˆ½»e(ýe-£…Ìë1d–©­«Œd7Öí9œÆcÁª}ÏfL'ѤB­UaNO$Y2u¥´É­Ú¹´>rX2¹“Yb}Yôé$é%Tj5*²HNÈà~ï¼mA/§]ãš.€Vùmδ}n +¦ñJ†Ž,"$$çj´èT­„‹¦°y×g8w|Ž^ùÒ†èv0}J4 _þ9k˜Ú2’³g²rV¦²# —ÎsÚ9gÀôv¨E£*Î(Q[X²æ8™2Xâ¯aNÎbñœ³Ø¡Â«f¥ÜO­ ú¤k\¼lÄl³§õîÔÏõ’©Hiº… / 3º”$2â72eâ6êMžJÃã—q­ö0JJ)z(&¢ö®aÙòkþ©®_ IDAT´yýmž®“ë£X1â9ôóÏœo>˜Ny,-h$ {g\]s?ÇÆíbÕ¶lêv Ã9·—­˜- µS—Æ­àœÎðÅ«‰™cK_`©ËD–=W#×’.c1[°"£wjÇë3'P—FrŠŒ¯}îæ%K4Wbý¨æ\â=íj?B߀ñüµ?•ÖÝ„+@Pa¸À ¶[ìKPlVäÛðTPlÖ2ì#°aµØÊÝœ»în”á^O{õÄwÚÐ=ŸåZCãçÞ'ÌIË™muÒÁïXx¹ènÿ¬8+á9ÿVy7eÐÈêQÈÜ»œ)ÇÛ3ivÜ% ­rŠO~¹Ž}ýtûþCÖíÅ}»¶/×͉H#ÒtÿS¦%ÌI9°ùG¾û+àvmèÓ¤=¹ßÂæ(6-]Ê÷& ÓÚ0ç7¨k0ô³uôÝ»†-ên<Ñ̃Øuÿcܱ.,œÞ›¼H’¶SËúIq÷·ÃÁÁÌu“ Ší YG6°!Ò›×*kÈÉâ'“°gêôæuwJú)¾™µ„m† j9bN‰&âZ z×v¤èdBÝ ¾k’—?Þºƒ$f+Ô½‘)ÝË'±!ô=æ Ì™-¹âç£%9)…Š%è²³‹Šú<1¯Ó 1/Ü[A/Ü‚ÿ¬ W2òÛ-Ƕ-%·–Zë¢þø8§ÍiUXsÛÒ9ýË2æýp…ªOLfp•Úä¼wf¼åÉŒjê‘+êU8xàP$¿« ÿN£™òX•Bʾ…cùå†Öò¤j O@!õ’j'oª‡ÖÈ [y)GਫÓoPmÆ|4KÍgYT;×9¿‚¥éÖ£°\âë–r¥Þ£LXÖ‡ÀsŸòö¼ˆHÁ¸'ZP)a_~ºŠ£#X0±>F}ÁŒoŠ“΂• v/|‡‹wÅa[< Ÿj…«Éˆ)ï¸:/ðÃç2ºŒ›1“sðÀ×[áïÄlŠ‘~¢èN±úÛ£T}j µrιÖËlÙ–H»QMq°Ù¸¶m [}DzjJ'ÜdI­Á|ô#žz{3ó&ÄÑí¹‘<Û6ðf–N×0|Ëá“Ytl›#Ôÿàç‹uüju$Åv#=»‹»Y™ÙØ…Џ¦Ôé²x´ï#˜L95ýäÀÇÈÊÊ/€@PQÆX@ðoô6¢6ýÂA×.ÌnQzFL‡º¨c^Í‘KVZÕÓÜ8?ýÂV¾Y±ŠíúF y.}ÂÝr†À.¯0K³˜‰sÞ‡7¦0ª©{)"Z&vó\Æí.j5eZñÍýëq–ŒÏö,ÅjÀ`9Ϩ§W£ÒÔàÙ·Zä$áX ?e/‰nù„wNšî…›OøDUüoG{ç¥é~¬pšîi\°˜ù„ýbW—?[…½MN—‰µñh–~Ú„ÅïÌàÅ¿ì°7HÔ|n*_ FÎ,,Æó&6ðlñ‹'Θÿ­"J ¡¯*‘tKUÜòº˜9‹t EÝ_$Gj†yà0±=BU~1‰?Z¾ ‘|ÒÕ ‹1ÇñJ1k©ÒuõëJÈV°Z,8VrÀ”’Bjî¹Æ¤,Œµ†²h˜/fLåísØ8¬9.ý•éÚ»:?ýº‘KMŸ ¦õß}¾÷Á³éàdËLÂÎÑk¦µB7¡N§»±ùU¸Ù÷­V‹ÕjE­V‹Ê*6›­¶|Ù‹Ê'è­Wر;…ÆûRëp%—ú4 Éä÷cQØê… Ìg¾dü´„<ú Ÿ<Ú?mÑâøuLJ¶üoÎlüæMåÑÀ’䮊j}'óq—;g<Ç÷Rn”xM#^\þ5/æK,µ|êÍÄRûKÂnÌþ uÿát:ö“>±ãýÑ­ñ×T¬4Ýÿ5Êž¶ÙHz| ©‰q\‹¼Â¥‹ç8yâ<ñ é7¸ î1ؼn/i@ÓFõ©Jõ ÜíU€Œ1-Ž+—ÎsòØßì>{W˜ÕBÏεsû©ÕÔ£^X(ÕƒüñóöÂÃÕ g;òïõë:€–¿.àÃÙ:úuÃÇÞBjÔIvü¹¤šC™ÿV{œõú›û(œByh ³NEêí»âùÞ æ;?B‡êny•]¿ž ´ß`üƒ+3cY6ï7âªä¥0—ñè:š!»Þdúä+T3]æzèX<ì‰ÙP03]µ§?e£:ƒ„4#ù{FF†èôÁ}ÂÓÓ›¸¸¼½ýpp°"TŒFÉÉ× º‡‚^S“!ó?Á¤v¸µUYåM÷7ÒÁÅï†à¶«ý$ V<›‹ºÔ"t~…ÙUãp­\vÛµ’º•éoþÀe•‚.I¢Vs÷²¹(FN¬ûøVãyÿÙF¸õ âëŸòåÁLlë Žxæ©MLX¹‘î7Òt;Ðå5t¹Õ¥uGùú‡Dº½Ú“ëM#^]µNôÚ[Õ_™³®^ä« ³Ø!ûQ-´õêwdôSoÓ¤ª#V½ YÓŸ¡/§rbçVv9ÂúßsÅØ‚·ç>M¸å(+&}C¤oMê7éΛ#ºÒØËJ¶Q¢YÛ'˜v‘{päì16îŽ&.%ƒLSM†/|ÎùBZ.Ž=LaeìÅv¸úx㪖±˜Í˜Í&ŒFf‹|ÓR-i°wtÄÁÞ;;;´ŠŽä¤LÌ8âé_ ­ÕŒÙdÀ 7`Ì—²NRÛáàà€½Z­ZJe"=>™Â{¥%...8ØiPI ²ÕŒQ¯#Û`)“e\¥uÄÙÉ1'A•lÃb̾õ¹’GgG4²½ÞÌ=³ADÄÅ2nÝÎxYñÆX@ TtmTÒ¼¡ùç<† ¯šÍÉK”çâ‚KaQçå‹k)W° lD×ÀüO_‰àðJÅÔŠ=>@V4Ýÿ5Êl¡WLd^¥Ôm”Šc¶cvá?èI‰Ó—|šÕ„^gB_–bX d¦¸Ýíœ6³žL³¾œ•dFŸ%âü @ð_F#ª ¬ë‰Ÿ¦û¿'èEH5@ !èÿ`A/Bª @ A/øÇ"Ò’ þí=zXT‚@ „ ü{zÁ¿±!V BÐ þ‚^øÐ @ A/ø za¡@ ‚^ðD¤%”—ÛI•-ôÁ=B¤%”‡ÛM•-ôÁ=B¤%”‡ÛM•-ôÁ=B¥RѰa#6l$*C  4Ý$ª@ @ ‚^ @ A/@ „ @ „ @ BÐ @ !è@ ô@ ÈÃbÄ`-üK3©±Ñ$Q?@ðA$–‚Œ5=†Ë ÙÈ%ü]åêO@wÔwõ® éÛg3lkc–¾×€+û’©Ú¹)AªX~›9Ì‘Ë×@L@ ½@ n)¬õç6ò麋6–+ú$®Ä¤c׿u¾y«=.%..±gëNžŒ *9ƒl‡»õ[v¡O×zøh‹»m6Ç_ Rí'ñÊ>ÉìÇx¨M‚ 'IN6âæëh,@ ø÷ zY–9uê×®Eb0ÊtŽ££ÕªU§~ý¨TÂãG üבpk=’ù­ Œ®džÿ…ý„ÜóeÞÞ®x1¯è¹¼i3¾:]£Ntm߬•[ òÕçÙûç<^ø½ãÞMÇ€‚ý’qm'ÝiýXj.ÜüƒÍˆÙjäòÖ/™³þ§Ï]!)ðVÌy”@1d Á¿OП:u½>›'Ÿ|WW·2“••É–-rúôI4ht›w6“‘nÃÙx’_ÎûÓ§S5a9ÿ ”ìklÿn9_u¥× sy«‘W µ™Ë?Mç­ßxòƒ%ôsA¥ÛÁ‰å~ÔjZ—^õiѹ¿šÆ´¾¤Ò¼á4p’n,¢ÿÚÄ©À®Œ¬šMôÑ2-‘¬Ÿú_^‰"Õ¤¡r€DëVÓ­ÞFÞß/‰†‚« ¿v-’ŸD­Ö]¦sÔj W¢âpsÒÞ¶ —·1{ÊEz¿Ýž¸uKY[eO‡jïZ¥XϬaêÎÊŒÓï‰EJ±Z‘5šb|pe¬•V“³CZ¶a‘A£Qs/¦p9êO>úò ieÙo'ÙÓð‰ñ ×€͆ùËÙ‘\ÐËXrmΈ±•Ù1ï.òWPy·ç¥ñQõF*džXËŠ#UxvHk|Õ f]:KÑÂHZ<\´ ¿ÈOŸïÄmÀótÔŠCpÏ°é¢øûÏ_Y»#Ž nƒ™³°~WÙ¢GgRãâb °EýʵfúMŸÌ€Ð“†íz×íüðwËíô*w yÁçßàË?fnÿT€’uˆï~‹¤òCOrxê(VÅ:`ÕvŸ¥ß«ìùð#²ûaP Æ]Û‘ÔjáŸ)ÿVAo0è±³³GQÊ áÓÏ>çëUß2üÙ'JžØ.­ãÝ÷^Â1»¦Cx¥Ç^fþ,3mX-ﺀ1´wGröoŽEÔæäA;ì‹[”x†Ò¼–÷Mql¾Â–uûˆ±•áò*?ZöïFmçûgñ²%àãÖâúâL†Õ*(JåäL|áoº®˜L/ ëéϺXÃ[Ÿ §nzGy}wå¬(N\vdà„‡©^ÚbI‰fÃÜ/¹œ§üe=ñ—"q~ø]ž®“S09z#3WÆ’iqàÊ ßAKçÜr]äßÈ–¹ËÉ»‰YK/ÐfòcøªLìY8‚9Gíp¶+XmÓ1|>¡NN5éÙaoÌü ïÃiì",•‚»……¤óG8z!’K§ÿfÏáH²ÝÃhѨ –s¿±ðÐj23³ÈÊÌ"C§Ã`ÓâÞ|$Kßꊧdåü–­$·Σ¡7¿O£¯‘P› ü+wU»Ô`ÕÞSdô  ÙœXý;Òª«}è=ùú¦oæ/£a‡&„9^eþwÜb­ZÑõàß)è!Ǿ,(ŠÂ⥟°fÝ·Ö¼•Û2tt]Ì%¬TAû¿ÎiŽøz7ej“»X#r:'NDãdqdó†k…Ÿ}üE"CÆòûqºñk+F]6º[zEÉÞ½ñîÕÚÎ÷£ye2ÎüÄì9?“Þö5¦Ö¼‹æ;ðÝŦ#9>ûÒBvؒȲk¡çI‹>Ïi%çD%%#¾¹Òsáι+09&ùNMâÏ?"÷›N¯Êùo¬&ø±ùø©à"ˆH¸4|šQµÇ³ä‡¶,V[¸w îÒ;däâžMìJpÂ͵&û4ÅÍÍ 7G‘»s4«=L§Ax»ºá쨹gXNãâ… Â{×¹9a%òÒUCÆWU°»ùøâ˜‘Fº¢ :¼’…»½hšBvö¥õh‹Å‚ÊÙ G!èàß+è [ç÷ìÛO›V- lxU…/áÇõ?—éš’saunyœ¿÷=Àñ;ù+¢Ï-yÞ^…MÈVNö"ï¥ÙS@Û‡ñȨ°[^Ûve5§\Å©Ð̨è.ðׯ$•¶ ´·ëGÛ2îJSôQìüþS>ý3“ÆC§ñnà»8!߉ï.(V‰1±È*»þ"¾ÚC´¯–+*äDŽl:Šºeu{„Ae¶F뀣CNÈvùޤÆÎÁÇ\AoÓt²FläǨ&¼0Ñï6’/8Òp@oÜ'¬g×€pºye#¸ H®´ñ>m ¼·ùáÃ…\­=–Ÿn‚w‰#´žl£înùĸœÀ™sY„õ )²8•MFÌö8’ìBÓc¨»kK 9±õ4'Åâä‹8zô°h7@ x€4iÒì^ ú›ú/¾ú†•_Cï‡zðæëãQ©T(ŠÂ—òãÏ¿Ü8îÙ§Ÿ‚"Ú*J&û¿ß@Zû—h­Î$[öÀ¹€ú³‘–’…»·ûmù—Û’®“âꋯ¶h3Ø;8âXÒÇ9…Ã?ï&5¼Ï-½œÃߛ׳zý>ÒBæÅyih_Ê 2 *ÊpèN|wTnát~¤;Öt¶Þ†µ~j•+Ïv¤çѶìÆC¡ö¸ØÄ Æ=0”°š¹.7oºDINø…Ô$,×\i³FuäæBìÒžý›¦Ámúe©|[Ñ.ð;vÉ¢kW7„¤Ü}LœZõ¿¸?ÃÒçšPúºÑ7g#—3M7†q9ñ(cjÒ¥¾S¡þi%ò´Uºà­’жzž—0³kÿ-ÍdDŸ'εƒ:WGSÊD"‚{OiF•»àr“c¡ß³o?+¿þ€?6ý HLxõ>Zô1¿ýñÇãŸ{ú)ÆŽÅŠK‹^Ìz–¯Þ^Æ]Y}ò%ì› cÁ°FhPÈŠ>KDŠ¥Œçj½B©WÅ%wò“IÞ»‚ON†3b~5/Ë’èZôìןÝâgØâˆŒ– jx ^l\=­ú@ª:Yr ¥cŸÐ›Ózâ%",•©èŒ(i[8úSáÁÅßU1§yú({wïdÛþdwR--xçÝghu+/« +4©Ô‰==&’lêºÈ·ï»+V+VÅ̉²*ÂDzŒÝÆ%ÌÚ›+Ü=׳ґV/äšS%:Ž}“ÇBr/ª˜ˆØµŽÕ'o–5´Yc<íý¨ßÜÈßÖ™WâôHLJåÜÿIãü…4‚{Ô(¦Ã+¤ÝÂk=òYîÕø7íEÇ|ê_U‰°07Öž¿‚­k#±APp÷±]ãï#éÔy®·ü¤ò NoV8Ff‡v¸I.mú‹¨úhëYpu®¤àÇí&Z½Z›29ÝIZ<Ñ:Ðáù—é DZöÍÑ̸œ -ÄÆp@ ¨ˆÜ5—›ömÛÐ÷‘‡ùuÃï¹¢~3'O"&6îÆ±O?9ˆFÄh41u5zŒz‰ÖÂ’ÜÀ¡Ï§³;äe^ëì›OxI¨ÝòĵȿV0wgF½ ÷ޝ±xX=4€¿‰9ŸFÑvüT:z¹!M\LÀŽ ¬ûiÃ×ѹÿ 5¼Æ‘ëÁt¨ãR~ ­õ »¤Þ¯¥ï‡•‰ßú ó £X>,œÊ¾/×Ýb$­Ý¤Ç%ïû’~<Ì¥«I(¾á´hß™×½M턯ò¡¾lígÈÆ vÄ©´yZNàÏ&qùñ•¼Õ2ã6}w¡’ŠÙ„YëE§Q/3RJå·÷Ær¨Ë|Ð5gñ‚õ$‹G,ÅnÜ F×.Ô=%G=ñ¯U9ÍÆј3'vDãT«.us…NýÎí¨~ácž^žWþdÓññt(¶Ý‹ £Ñ˜ïojL¶¢ýÅÛ»úc)p&zÁÝFrÃÃÝÆþ W0´­c©« éÕŸðWVòÑo®<æq€%›Ô<<¥mÎÂ9w±jˆÝÏʹŸp¦î6t(;‘;žª ú½=%ßûŸÂõd {{Ñéà_,èsüDl6™·Þx­V{ÃW>¿˜´o_^3 £±”T’35Â(â=/ÇqʦÂ'¤>uÂ=JÓ [À·Ãnï9Tþ]?» >¹îZ/êuB½®sõÀï|·fc¾Ö£©?’ö~åõ–IÞ¹–Mú¼Ö®Ò-|¸etYzœÜ±Åîgå§+ÙnêÊ;“šP0ÀŠ —Êõéúd[Ɔ‡èz³)­ å(Yz*î•Jµ*Ù9HÝjîÄwÀ”™…ÑÍÁ¿þ$BÒs6ÅJÒéml²æífåšQöÐV6FIHŽUiÑ.ϵa1‰;²¶–<Ö܇øëùÛ± }›¸RÔsɆժF­.^Éx6|˜çJÜ›OBiÔ Û*¢³˜à߀ʇ†ôg×ÔxñZGº4£ª— v’ ƒ.û°n´©zså­òêÌø‰)Ì^4›÷Ltó?ž©•û^ZÎñí¤¬»`¤Z·ÑÌYz^I­A£¤“›‰>ÔG­ Åb";+„Û9ª«ÆUÕ¢àß+èoÚà ¯¿2 ÀØþ}ûðÆøWJ¶ÌßêÙ9çIh°ë½ó]–ð (Æ‚¥r&¸Í@Æ9¥1õ­Ÿê\È }kÌWgÞÊó„™K«[…=T²‰‰ÕãWÇ ­ö:þ_ã㎵ñ,¦¥‚›Ó%øNZ&þÊUL½ T—|Lâ®­œôoÆP·ï»›s­¤Äd;²â¢‰=½4¦¯k2WcãßVõlNXÎ`‹æäÁëØÕt§aÁ Bv ¡]ç*\NÜÆ![ºt©Î¹¨?8çÑŒ®«âPøkƒÊwÑÙòu]f6*Wœ„¡Rpo!œë>żOš³o×AN\<Ä… V´88W¢^€m¾wL­Þ@¦-XÌÈD›'ÇѦZ-ª{ÜÚMFr¯I³ð_X7iß-ØdP©5Ø;:áêU&Ï¡ƒØ .ÿ AŸ'êÇ¿|SÔ÷}äa&¼ú ƒá6ï`!òß9æÙ–Á¡ÂBd!þÿìw|ÅûÇßW’»K.6ÌØÁ IDATTH'@h¡…Žô&ý+RDÁ‚**"Mª ‚Á‚tQºŠ´Ð„Ð$)$NÊå’»ÛýýA€TÎûõòå‹ÜÎîγ³;Ÿyæ™g¯bÚ‚T4™Á54P6—k‡×0wánòÚcz·ûfX‘ožäèT×¢tiHöÿ`Õ¤x‰Ã¿EMJg˜®íæ«5±4xmLþM»›CôÕDÜš½Áð!\^Êáí6´V¦68~4‰Öùàe/®nþ’™W ÿ°`**á®ÛÝBôže,>”JZÌ ²ô›˜=[MVB&‰ªï™©§fßy© wÇÏ[ÅáèëHÍ|(ß^a¹ÄÆ$SÉßE,øG?ÊNUiÕ«*­jl`‡ÝÚ÷üô×z~,#l\n ÔUè7u1ýnš%P*…€‚ÿŒ ·XÌ(*(¹n0d3ú­7ªU‹ömÛ“S0ž[Q(3νg&Û2mCí?üUçJDs6±g²ã·_Ø~ÞŠg^Ê›})‹œ7gÆqîøaþع“ýqN´:×ÚùÝß³kIæÀòŸ¹<”1Îÿðµr—~YƆ x£­G1‘+›oréà/,]¹ƒÔfc˜ÕÒ)ß3ø±»¦ËœPØÖ§xx‹•?ý>x•˜ñ3yóˆ ‹[{FÍîOcWu±&Ðófµ;μQËКÆµ„.zeŽo3+?tÆ|¢` AÁÕY°ë4‰ý|ðP”JH–ÂAó …²° É½Àñ Ž÷©ˆR|7€ÐÐãO0kŒçªp.y4ð@Y¯@ð/ôZ­Ž„„*UòD­.|*³ÙL‡vm0™L…~3›Í$$$ ÓÝkÉWQ{V³býNåT¥÷¸)¼¬ÿÇSJq!ü°ý$1±Q\Œ¼Jº6€&mŸgúÛ­©Yá~¦²pé×Y,Øv«7òp¨\—æ­_ç« ñ±½ï(%eÙœ%ì³êÊ„ý³‹.¥ö9yÇìé5n mœ _LJÞÍ'ƒ¶’§«Bû>å“nÕ±/P…òÆîæ áhnÃkk¸ãr7¦u!”ë11D]¹‚!¨ crØb$=-³«CñFjŒaû‚ÅóéÇ‚šVL*Ë2(Xòò0[Yc­¸%Pš=KóW±ãJ^©¢.ôÜ®¬y—nk _ºñh~žØ}þ%5d'ÇÜ;2§²ˆ#@ðÿHÐ{{û~£ÑˆJU6¡c±X¸zõ ^^¾÷¼-µÊŽÚý&0ªE \×Öœj5}%ê´mÌÿ†RÍË!_–%u»òrÀ@|ý½pµy0á§tô ~Ïéß´ ©v>Ôo‡Si÷®t¢fÇ—™68˜ZÎ…›€Ò£ ‡UÁÑ/:Õ½°/±…”'vWÆlå@ÕŽqÛ7—ww^æzR:jݾúÉ›ÊþþT®Þ’~5©áÖ›VÛ~`ÅÔ‘¬ÂÌ:ØóUÆÊYMW&¾Ó1ßÛ®ÀÁ»65õ*Bfögæ1…$ãÒqÜ]o¼®/ÜÉ{+wÐqr¼ÔZÚß@»ûØSÎ eõºD:ŒîŒ§ð\ @ xÊP\¿žPb–DzLgddA\\ì½³×@§ÓáééMÕªØÛÛ‹'ðŸCƘG¢Å7g´÷¼˜o—¬ÄÓÃ&n^OÆâèAí½sæ›M&$…Öꢱ5é]4™56Ø:¤6ú² ÖÌñìœ9“ýAcø´§/Öâ Êù½|e@ úš’x(½5ðõõÇb±”©ŒJ¥B«Õbkk+žÌs ‰ÖÙŸ²ªvÀËãö?¬pð¨X†BJÔV¥¬tP8Òdä ª¥QÉP¦.Ùž†#¦ÑÞY/à @ x*y(A¯P(ÐëõèõzaIÁ¿¥'WmÙ·Òãâ,Ì&à)–7Â@ ô@ @z@ @ ½@ @ðA-L O'’$qöìi¢££ÈÉ)kj`|}ý ªƒRlù*BÐ àÉqöìŒÆ Œ^oW¦2YY™üùçï„…¡NzˆE7Ó-Øϰ%܃mÄ^‹ÅlF©V—oç÷Bé†Í¤Å'aåQ}yÆ­¹7I2Xãì¤+w¨ÂCÕE xÄ÷@ <¥DGGÑ®]GlmõȲ\¦ÿlmõ\‰‰çêÕ¨â'”Y»–×$¤¤ã¬ýq?1¥l!"E¯çí—ò·¹¬b+—Œ”›ÌßNRjÛ6%NzÄçMÜìñË8j±&~Ã"Ö_6=š?[I‰ûY4çW"ÌÉVrÞ½ïÙœMZJ&yò=oš­†ñÙž›È÷»ž)•˧òçöͬZ<—F¿ÆÀ‘.H¤]ÂûïLáÛ½¸Á…ð‹D§æ?)ˆ?Ù¶u k×üÀ²%_1õÓyãõWè3úg.[Àt| ¯Íü“d©œïȃԥÌÇHòåb²ä§î[T¾ö&“qzsW&±Êf#YYò,wë+.²ñ«eü~Í„àÁz@ xJÉÉ1`cc‹,—½ƒ_¸x ß­þžaƒû•Ð+gp~ÏLµûÐ\w‘¿v§Qå…V%nô&[L˜¤²«>9û ³^ßBµÙ_ð’¿êji!fë—|³1/þ¯¾¶îg’“O°ñ§Øwo‚×·Dnà“¯’^J5­ƒ_æN!|þ‹ÄÔ¡|µ?c@m´ù\Ëo«»ä]>Ξp µb£Ñ«³µÞ Ogm1ïqym…ásGl"`VÉ÷l¹²±Ç1hÕxÚÛÞtY×.~ÝxKôfgW¤5;]âø‰¢w¦Äλ&Õݬó›ê~ßzˆL)ŽÃ—½6~:\±ÁÀåí ™ösƒ+“ý÷66‘Çõó§Ðö[ÄÌn.(É$úÜy"Í:lÕñÜ™HÝ7†ñf€•*¹ã¤‚\I…¢¸w½Ôw¤üu¹k¤< 9y˜Íys dfe–œÈµè(.]¹Døù‹$È^üZWûT}‹ÊÓÞ,×v2sQÍ'õÁMU M\þƒUßmbOX2’F)WÆ¡ês|2ýjØT¥s«ý¼ÿù*\f £¾^ÌA/ÿ(«˜—e™y ¾äǟז~­VƒJ£@¡Ñ¢Õh¸½¯²œuž_×">ß'ߌ Ù˜Ëöåßr¼HŸªtkLÿ^upx$}­Œwe¬ÿX›Û7Ѷÿ0^éR“ %ôN¦¨ÃìLö¡s#ÏGú¢¬Ô‚W^¯UªWYéè…ŸÇX>KÓáæÌ”O¼âüÉ0r³`Ù”“Åí”™†ªí$V¿Qç wò2éáûØv8 3I§¹á^·]l+nm¼;øèfP:·`Äø˜Ï}KØB U+»¢Ë8ǺE Ù_þ/?oP3¸©É\ÃûVtoáŒÒÒÉutÇUrn  ´Ø‹œJ‰ä´º" ;ÔÅ>#$†Ì 2€B…ÖÖëRß‘ò×å6æó«>q'é*k¬5Zlôz¬s®s]Ì€hÕ÷j¸aóÔÅN”£½IIì^¶©×4ºTº;Ì\Ïø ;ÐöÉüq ñÖ+Á’MÂÕ´üz+Ð×ÄðcX¸®‹†ÖanBÐ ÁÿA_Ø}¼ï@-[4+´àU–ef±€µë7Üûd Í-±b­­F‹æ¶âPZckg}þÔ¸”i"O爋½=öT‰1r›/ºÐ½ç£ôj\êöâýyxþÀz–~÷)¯înÍè #iåVPÙX¸ü×÷üps(y>Û*l+R­fÅûçáRŽ“[’Y·m×Þ;¢:ér$ †Òø \JÀ2yÆ<ÔZ J9ƒóÁÔ¨uóß/9›ð=0ÔëDgå#ioæK;ØÓ€‘ºßí–ØúíF2ÛM`Æ ÚØÜþ»Ê–жJë¨Û»+ïmfïêtp^z!èÿj’’IL¼Ann®0†à‰£ÑhqssÃÕÕí1 ú»øÒå+Xº|%=ºueÂGãP*•Ȳ̜/æ³væ;ǽôâ  „T¥;]ÞÿÙQ‰RÙ†÷&H8ªn‹*tè[åŽHßuž©Mèß¿ ÎwúS‰äígøuŸêÑwJ[ü[azã„ü…g…"ÂÂÍ‘éÔ|>°dá#KX,pUôX²"ØüÅ|¶Y?Ïd›G-FòˆØ¸–P¿|]­„§ g’œbÂÑÏ¡ôErÿ¤­J¬®‰‹[6rÆ;˜Z{çóAh4Yvt{e(]t%±Ä…ðýª“d§Ç’zÃÀw‹oà]£ ᅩ‹è8’‘Ç1iöUšœÈ»-*Ü©¯ÒÞ¢Oñw¢¦$2¤LbΞÄh *6ÌüéCä­ãy#¢?¿ß+SSn¾uï÷xGÊ[—GԨ߻…]qù#ns2gÒp®S—üf öêÀÛþ.ÕärÊn&}x•½N=+IÇװת9uÚèoݯ”ÈÑ-»Pøw¤ó£hof"ÆØðuꈒ®aÿ%º¼Só®˜/ísàÖ”g<×°ïD&íÛÛ‹…ÇBÐ þÍbÞh4Ò¼yK´Z­0ˆà‰c4 ;CRR®®®]Ðï;p¥ËWðÛ¶í(ðñï3sÎ<6ÿúÛ㇠Ĩ7ß`áÂ%œM…Þåö½ÛâRêØDâFB:BÞy‹Éj5êrõ°&.ý¹™K^]èhWb'­ÐyñL¯bÏ9³“?Òê3¼‘¾Íx„YCF°%¨. ê×'¸~m)Ñj>Ϫs°Ì‹heþÐz÷î4¥l®XÏ’ï`Õé-æ>_§r‡O”d+™¬³?ðÅ.}§uÄ£¤s›c¸«Ãç9—ÒýƒØª¬íÔd¤PcU‚¤ø|»5–,–¸æñ‘;†C˘:óG<çôÁ9þ*Q±q$Ûó¿&•PêêÏ3eÆs\\5ŠwÖg¡­7˜)C‘R.søè~ßñçÍŽ8«IË.’áCÎ!îü%lzNd€ûaæ_¥^ß—h•ö “‰'9ˈNosË®²ŒÌíxú{¿#å© Häegc´mo2s%0åp3#£°g]¥Coku·^Ê ´ö1-oW1}7ã_;D˱ŸÐå>l…S jëãï+êê¨ULJ%'Ã1µixëšòMÒ2¨Zt]Þö&¥‘†_§*…ÞKìUbõU¨êV†—BéDµjö¬¿‚¥}=!V… ü[ILL¤yóg„˜<5hµZj×âСÇ*è%é–hÙ¢½ztgËo[øuëvNž:Mlܵ;Ǿ8 ?o‰Éô©f¤4Â#Rð~Æ·˜ÈËË3•u¹œ»rú!~Zñ'Îãz=˜ÇÍ|•_~8€¶ã$š–¶HΪÃ>yíÙ“„îýŽÍK“PT¬M‹–­hÓº)u= V•/†¿EcsQ•ñåÓ8Pyï¶u+ ¨ì=K¼–¬ŽïÙͶ]qÂÔÑŸÌ¥ƒŸíCyK²•”²ysáõê4ž÷/¹ûλp”ã¹ÕxîýAlUF,éédÙ:áXT«IIüþí:Â+´aÜä7iã¡Âp–šÄm|<,„J~þTöñħA‘çaºÈ_!ñÈξh¬e½¿lǯ~SZõ„ÛŽØ–¬À¸émKn.>æ1§ 8¿ý;–iS¹fN%ûç•\4]#@æfz&öNù^e)_Ðßï•·.Ò ~ûl4+.Oõ"[ÌXXÈËEª¨« fÑŒ^x>Šxze%êÕ²°ôÌu¤@O*Ô®I…­a\67¤†¤ähb¬½èPäÝ*w{“’ILÓáZ¡ð"YSNfÊ6i¥ÄÅÅ ÃÉrd°.z!èÿNrsBÌ žBQ¯#7×øX¯Y0äæ“ÇaeeņM› ‰ùÞ½zñÎ[ob6?|ÞH9ã4Ç£<©ÿ†c/¯Œ1Çxk±àƒv°r6'~ü‰S>Ýùª¶æÊý~ko>ÃÇ}K_ §Ðâؘ–µÓmX²8ÿw{÷ýÊŒõß ônÂà1cèî§…-«T£Xô¼ÏY‹×ÊAÔ¬îxOA.%â×í!œ¹Ax‚„_ã6<ìÍ™¸z4{H1_š­”š0tr ÜüÜKÜR ýrKÓwh|¯ì b«ÛXûÓ¾wœJœr°}) ɧ^…nL"ù¯e,¿T·f½E+ÝE6Ï]ÂÚ3JjµjJß3Üè<—Ï»V(a6A&ãè6å:¢·©GïÖX“Ú‹•«ƒÈ9µ‘‹7¡èü?~^{%` cÑèÅXÕtEI(ìhòÊÞòüƒG ù{é–ô×’Äœo='‹3J”÷ÅG™ˆÚ¾“Z0 àþòJéÞˆçz=â‡].[æTNnø’Ù“h2f Ý*–?N£l¶*Ü&.¬[ÁvS+Æ·u-Ö.z_jée²öna‡¦_ m–?HQ ÕÛ£¦Ä]›HüývÚvcvÐ N‡¶•i,c4¿E¯gqRËdYÕ䙸ì`"/ðæŒ–·„J.´yc%o†0r(õÞ}›¶N °vÄõúïœ3T¦Ÿï-ûÊ9ŒèÐiîm·òÕ¥t g~goZ-×µùç?$%æÜ¿É‰• Øá؇yõ`Fü~íM鎟·ŠÃÑבšùÜ]¬\±)­ü×±ã·st{=è>ƒÎ\bc’©äïý4¬s‚^ ‡ÙlFUdîÚd2ñÞèwªU‹g;uÀl.œÑÆb)Ÿ§^Î:Ï÷3V×r c‘³ÏsêŠïgÝï+èÍYñœ?º—­[¶’æGßñ3\¡ÔræœT¢¯p!ìGCB8zªuÀœñ©nÿ'æ–2‰Ø¶i²hÿáÿ¨ú˜{ƵÕmÑ›“|™ÐCûرíO¨ˠO§Ó§–ÃcÛÞ”r?,eåakzOBÃRgP·þ3f’e†[qSjê _Ä¢’‡K¸4yžjU§RÖª»ÖвÍÝsÚøÓ"`'+#]5i$-òÓ»È9l[ù+‘ /åN }¤”î­éå|„„šÝ¹½w“œq“›;ʤi´.%¾id_Ùż¯`ßk ­{ZF QGùeõjvZñáøR¼–»½i ®Î‚]§Iìçs÷ÜJOz¼Ú‹}“æñ™Ý[¼Ó»µ ÀDF|2²GEn›{ã îS%!èà_ŒV«#>>ŽJ•¼P« û©$IâÙN±X,(Æ™M\»v N÷`b>;Œåãgâý*Ó‡Öã–6“ˆY7ŽQ›n ÕX1ƒs7>+mKK"ÌÿÃ9‰\»ž‰Ê½ÍÛàË-ЗÞ-gý5óŽa±qÁ¯ZMêµ~yQ­Â?í›Ë#jÏjV¬ß霪ô7…—‚õ'E^¹l%“uz=ó7…CìM5^µÒ²ÿ§ŒiXâf\Üb §ø3äçΆrìL2úú]3¯/ÏTº÷º}“çè³c:ãß¡uóZø»9b£Q"›Œädg’’”Œ¦^^vÈßX*ˆ`g0Ÿ+6ü!#&Œ½»ùuwІ™3¦Õ ØLaÛ€W&6@2¸³Ï>8ˆ_›¶TËK$‰öÿ–B“W¡Lˆ$"ךœãçH­Ôï2*Ç­KAQœzvë·þɞР*?÷Ÿ½P¦“¤ØŒ}—‹ŒÕÃ^íÏ7w?ƒfOç…R*’{e/?ïú›°³ç‰‘ühÝó¾îTãí¦¼íMC³giþã*v\éÂ+U>€Ÿ9²ôÛ…ŒØ`ÄÖA‹9;‹<}k>Zø&Mt·®›²“cî™SY%:!èàß··gÏž%;;µºl›Ùl!*ê^^¾t-…MeÚý„>AR-*ñê9eÏÜ$3'³¬ÁÅÛ› %h7…&€Nƒ_ I£ÇÉÙÿüÜmËÔÉØ6ÉòU£©àdS®t˜ ›ŠÔ ÒòàŽN5j•µûM`T‹¸>ä^Ljç*Wu¾oËo+6î4içKwOoü}+â`¥xL¶Ê/ŸÉñ(#>Á}™8²!5=teó êª3hÆ7´:{œÐˆ®E^#+OBieFkƒƒ“>Î÷¶@î©•Œž³“x•'õš¶bðô7iêS|=GÞ±… ™½— 4Ø;:Q¡Š 7Ï#¶¢7q¡;3j¹±åfn‰"ÃbKÃ!Mq/«+¸ÜuQ ¶˜Qþ‰Ã›R˹ì Né݇/~îóPíS¥ÖâPùwN o‡2„²aPÍ[—•bwðùÊkd˜´\‰°P÷“Wi’ߙϯeâ¶ëdKÜÙιO¾>HºTò%­ƒ_æN!|þ‹ÄÔ¡|µ?c@m6›¹œ}Y¯o¡Úì/xÉ¿|£ú¼ËÇÙ®¡Vl4ÅÒ+PëÝðtÖ_„–|‚?ÝÀ¾û zÃ!æŽØDÀ¬’ïÙrec?ŽcЪñ´/Òï[®íd梚Oꃛ —ƒ ^ev¨5¶Ö…oÂ*xËß{›ªtnµŸ÷?_…ËŒaÔ×? y¦r92¡}“fqnew„¯Rð¯ë ôz=z½^C üûPjqr}f¥ÇÅY˜í±ú[Š/‹ä„x4÷Ò¶–$2-`Wx8@Zl8aò­‚rJ2Fò÷U–²ˆ‹¸€mþ°ZŠKÇ‚gávQ©¯¼^‹¼Rf”Ž^øyŒå³4n.ÁLið´˜9ó'ÃÈÍ‚eSNûÕ”™†ªí$V¿QçÉ{‘¥$v/ÛˆÔk]*© y5üúLçë~¥äËU ¯;ˆá5ưp]  ­ñħÊä´m|õ£š!¿ub^ ô…„’9‹Ä¸kHÊ.íÿßgié›/ߤDNì EÕ¤õ:t§JámãP[iÑioy§_&â IDATy%kõÝÅ, ÖZ º|Ao±RóV+l+R­fÅûÞŸ‡Ky)I„¬Û¶ko‚­wYÎ:ÎÎÃZz~ú%¯U/jrG¿x…ÅÚ§cÐ|ic0òC÷r¤ŠÒQ·wWÞÛÌþÞÕéàø$½ôÑ?~ÍïµÞàD=1q'@úB(í«Ó¶{G<Íéì Ûƒ9¨Ï6Íl³D´7«&x6@ƒ]¡ÝæT8xP-?ɯ¤½x7ÎMaƒ{åªTËßiÀb>ŽòÄc’~Ylþb>Û¬Ÿgò#ß’,ˆk õëÁ×ÕJ0·œIrŠ G¿{ä–%,øGÊ U×LäÁþNrÆ))ÝšòŒçöȤ}{û[§7‡±ôùÄv›Îä®n'§lÞ –,Ž¤ÛŒeNE&@ðßôf3f9ÓðÃ¥\ÒãòÈÚ±™!ùªI6p#3ÅO ˆ¶q¢õãès;¨œË¥ýøéÌ]а>4î5r ê·µDÝÙéQäÊ•ò¯yžU/æ`–\Æ›T i8”ùCëÝ»‚R6W¬gÉ÷G°êôsŸ¯] ]ÛƒbâÒŸ›¹äՅη· —É:û_ìÒÑwZ)7˜c¸«Ãç9—Ò…®é³†Œ`KP]Ô¯Opý +Ú>ÔVѲɄIQd«k)ðˆ4ü:U)Án2içÿ`ÝzÇ÷©Â#¸ ­+PÿJ'ªU³g}ø,íoÛߌáf:™FËcjÖ27w|Å÷Ê—Ùò¬¶@ }a©”—Kž•3m†â5E*¿Mxƒcí>ã³öù» šÏðÕ«‹°~{¯×(rz…ŽzýÞç]ï0v‰%WÈãôÞXlkQ @éHPÛgðøšAKoëF_: ‹Ææ¢‚>‡c˧q ò(Þm[Ðó«@eïYªàµdÅp|Ïn¶íú‹¦†Œþd.ülj39ý?­øçq½îœGJÙǼ9‡ðzuÏ—²…wÞ…£ϭΰ{¥¾±jÀ°OžE{ö$¡{¿cóÒ$kÓ¢e+Ú´nJ]Ï÷–ôt²lp,8Š’ILÓáZA[¢-dS.F£±Ào*r‹it%..NN¦#ƒPÕà¥Y_b¶w}<Þy)–Ÿ¾ÞE‘S_DÛ@ ‚¾0¹™s²9úûn.) œO1“¶‡æÛ«Y¯m4`uìOvÄ(Pè|hüLu*\LyFâOle¯¥ }¹’pd3ëÚѳÅ’Ø(l©X¥Å¢ç¥xÎZ”¸V¢fuÇ{ r)é¿náÌ…Â$ü·á™`oÎÄÕ£ÙCŠyälNüø§|ºóUí»É²”š0tr ÜüÜKÜR ýrKÓwh|¯¬0 -niY»1Ý€%;ó‡°w߯ÌXÿ Jï& 3†î~®bíOûþÝqr*9oô¥($Ÿ^^â`ÁlV¡*ñfT¨Û—J]{•Z’…;YH*TªôصéäR¾ –©}Ä–Ñ@ „ /¢@IJLF¶v%3>–ka{ØG}zÚ%sõÄIvüm¦^çFTëÔ,±œ9zëªÔ-¬~‘ô•y¦­7—÷pÌÒ€víü¹³ Ž ißÚm½ªröE.ÄW ÀÏîþ‚\2!;Ö óç]¥öj0ì½È²¸‡5¡™k¿/`î>G^˜Ù¥ð®f ^~¥%Í5»c!+ÎðâÁØ<ÀU¶ jó$€Ë«B9|£Æ6ÃÊÔÇ&qÀº1¼ìÅÕÍ_2ó ôLE%Üu»[ˆÞ³ŒÅ‡RI‹¹A–~³g«ÉJÈ$Qõ=3#õÔìû!/Ý÷^LDmᒐ -pÿ€¥{#žëõˆ­gI'lÓ—L_súc¦Ñ׿Œæ4§rr×ÌÞ˜D“1SèV±ü~dµ:ú”½€làºl7µb|Û"!0Jwü¼U޾ŽÔ¬¼Þí\bc’©äï]` ¯…<ƒ‹µúÑúÌ-ÆL²LVØÙiQRìÏ|½½#6›R@ ‚¾¸†¾ÌÙ5m}Ї]XùÓïƒW‰?“7¨°¸µgÔìþ4vU»d@ϘÕî8óF-C7joÔVºèu–9¾Í¬üó½2ÜH™Dl[È´ Y´ÿðT}ÌÉÛÍYñœ?º—­[¶’æGßñ3\á>X"'ù2¡‡ö±cÛŸ„Q—AŸN§O-‡ÇbJ¹ÀΖ²ò°5½' ¡a±0 AÁÕY°ë4‰ý|Š-â•e ©Èn• …¥²Àyr/pü‚#Á}*Þ­—ù,‹†Oåjﯘ׻â#¬¯‰cÐv玜üŒzjg¾]ĹΓYë#‚m@ A_Œ¼s!Í bxm w\îÆT¢.„r=&†¨+W0µ¢aÌA[Œ¤§ecvu(~c Û,æ˜O?Ô´‚»ÑÖȲ –¼<ÌVÖXÒœyDíYÍŠõ{8•S•Þã¦ðR°žÇÙaIäùr8'‘k×3Q¹× y»|Ù£úÒÄ£LÖéõÌßJlL ±7ÕxÕjHËþŸ2¦e Ã@$/ᆜâÜÙPŽIF_¿+cæõå™J%mŒ­À¡Ù³4ÿq;®tá•*oЕ5ïÒmMáÖGóóĶèó뛲“cî™SYõø[sæ|ý™7tÁA!^n@ BЧf+ªvlŒÛ¾¹¼»ó2דÒQëvðÕOÞTö÷§rõ–ô ¬I ·Þ´Úö+¦Žduàf~Ô©Àž¯2†˜PÎjº2ñÛ©8xצ¦^EÈÌþÌ<&£d\:Ž+â%V£VÙQ»ßFµ¨ëCîŤv®BpUçûA¡  ÓàHÒèqrvÇÇ??wÛ2O{ MÚùÒÝÓߊ8X=˜ÒTØT¤f–òîѤH‰äx”Ÿà¾LÙšº{{ÈuõxqàNÞ[¹ƒŽ“{à¥ÐÒnüÚݯ…d…²z]"Fw.¼–@]Ñ?løš¯ÍfGbœ?x¹’€ÃÐé¼l-Þl@ ÿׯ'”˜Ü=4ô8 4,QØSâH´Øãæì€ö^ŽXóMâ’•xzØ¡ÀÄÍëÉX=¨ ½g>Ì&’ kµ›x"Èé]4™56Ø:¤6ú² &Ìñìœ9“ýAcø´§/+©CCÓ¥Kwñ,O;vl-öm,ý{yï6þ e@ðßå^ýF9‚>h½)Ó2Lµ^·ÿa…ƒGÅ2R¢¶Òˆ§öD‡yŽ49ƒj)FT2”)¦I¶§áˆi´w֋Ũ@ µ0 äq•'WmÙ·Òãâ,Ì&÷3_žÃ+$àAewêº ö"õÔ2Y×.~Ýxk0yœ]‘NÔìt‰ã'ŠÊy%vÞ5©îVxI¿)2Œ *ïx‹®[îŒ,+x·÷– ­Ç}ÏGÍ i9ÌÄhÎ\:Ƥd’SÓIÏ4`’@åן¯æ÷§¤½-×v2sQÍ'õÁMXbX÷á‡\꽂ÏÚœ‘Hý}Ãö7aÙŒ¸ÙT¥s«ý¼ÿù*\f £¾^LBÐ à‰"IR™Ž“e™¯}ÃÚ K?HéE§‘céT¬p:!_¼Ç¹¦¯2åÃ6¸”è8¶¥fÿñ|”;‰S~⣱mÐÔì@ך·~5Ÿegœ•*¹b¯”ÉNŽãRš=^U*ægÊRáñÌKŒ}Þ¥”ÊoNqú¶v¨L“–-oí*Ž…+q›YW¤³ ìôÉp2aÆà5xŽýœ—üo+a3¡‹^cžr$_Œ¨] c“IßǶÃiȘIŠ8Í ÷Ú¸…ìb[qãàÝÁ—@7ëb9°Ã'°Ô}熤ß+òYóñ¯yi¥=“¼D`žT©*âWºÒtÀ›4-üT1äJjlJÊ'%±{ÙF¤^ÓèRéA÷ôP ¯;ˆá5ưp]  ­Hä+A/‚'HQïüÁC‡iÞ´I¡¯²,3ÿë…lÜüK9®`"vû|¾8àÌ [•"æokE[ê¼ô1ïý‰Íµƒü¸= §]áäåTÌ2Ìž|ŽZ5*¢S€Âº6ÞŽš÷ëiò²HNLD™/èS²MC0^ÊË}—L¹c²¡À½Jæ<ÌL¦÷JÚ|´rM­”xµɤö §ïcꨛ´ø`"}Ë(’ §ùóˆ…ÆoÕÅêÔR^™{ˆ;ÑJ#YF‡þugçteÅîL›ÝŸª÷=±+­M©ÁÌ—v°1¦#?t/çÎÚ:êöîŠÃ{›Ùß»:…—^ ‚^ xh4ZŒF#Z­VCðÔ`4æ<ö6)Ëw=ô+V}ÏÊÕßÓõÙNŒ;¥R‰,Ë,øz¹ú1xÐ@ îÀ]:ɇ—0é»0r¨‰VHd”Ž‡Ò…¤²Áí›M˜ÔHƵ›/f'Ѳ'Gêi¦"Þ§+,«ºðµRÏîfl‡‚.$Jw: Kì.æL ¹#ŒM™‰HEÂÿ­êgeAýŒy%xèÇò]!ýÝAËÅ-9ãL­½óù 4š,»@º½2”®ºRbé%þü…ýé¶<çdIF n½˜?¯/>J0›Ï€1ôæ3K²Ðˆ¹àHÄœMÂÕH"/_åjì5’RHIÏÆkF©ÑãâY•m:Ó¹Žkqo&òàaŒ _§ÎC45¥[Sžñ\þ™´ooôôÁcÇÍͰ°3Ô®„V«<b>,ì nnîõº’tK!g¶td 㿌$xD_®.>GÞ•¿Xðå_¸ô{÷zU+´©œ”r†m†“!B@›¹ºe%ßþa å[Ÿ2мš¯ù0`â œZ8‡ÑaàðAt®îx§£‘͹ä­P‹É"ßù»* ŸÞënÈÍOcWÐEÂŽ¤ ÂÿÚʦ3Ê;u¹• ¥Ø0~'ßn%K£%®ù@F|äŽáÐ2¦ÎüÏ9}pŽ¿JTlÉöÁü¯I%”€œy‚Ÿ6ÇX`Ÿó"#-d…eiJÙ|ž%#&±Kò$  2þ¾^Ôh\G{ôZCqáGÙ6},_œÎÔî^·ì!¥‘†_§*×A+¨VÍžõáW°´¯':{@zàñãêêJRR‡…›kÖëÞ¹iÙ¢9=»wã×­ÛòEý.Μ=Kܵø;Çêÿ#‡¿†Ñx¿wÆÈÕ]_ñéÊ8‚ÇLâõ€cŒ4U_`ÖTGæ}þ)£.½ÂÄ·;âwgŸ?3¹9F ©çØzkC ;÷DaÐVâܺ¹|œGvÒfN=m@_>lz•5‹Vb;}4môJœë÷àåÛ1ôá{8 È…ò¡%2¦<(”·<ø*_Ú¿Ø‹h³ŒÅb¹s”G³~ ð(~)‰ß¿]Gx…6Œ›ü&mžø4¸í^Ï#lÍ B\ƒ©kºq÷\y7¹¤S|:&YGbL4%Xndb¡À¦ˆê@^úêG^ÓY—Z·úž¡mÕù¼öͯœyö ¨)™Ä4®´éUWâââ„ád 92Ø ½@ ½@ð¤D½«««0„à?Íí‹Eâ£÷Çbeeu'V¾ ˜®gOÞ1£ñ>P™®spåæï·¦ÇÇŸ1¸ŽŠ”Û?*°©Ü…çøðãô™|01… Ÿ¼@¥sž¹–K?pìÔMüûNæ›n ħå‘ul)ãvfƬf¤n™ÉwF-jteôgö¸Ü3ËŠLV¦)ãßMþ_“/g"ÐÆF£´Ö¤ýµi»ã±”vºcsàhwÆ½Ö §üŒ9É-cù¥ê¼5ë-Zé.²yîÖžQR«USêøžáFç¹|ÞµBÑ­ÆÉ«ƒÛÕ&zÊ­Y…½5N³qÉR@&'ñ2y¹)l^{Ë£ŸO­ œC…Nw¿X}6^Þ8.’nºÝ#[0›U¨TßvTjH–2_ !è@ð ú»AÙ999Œ}çm€B `ÿ׳ïy羞yKâQ–ÎüšÝ¹My{æpÚåç)/ºUi_‹ÁŸNÁqî&}”ÊØI¯Óµ¸Â´²¯ˆ¯þ:¿.¥JëQùj9¬sÆùÒ/L}ÿ ‰õ>àçwæ‹e™¬¨ìÝ¥œÅÅ4 °p=!µZGü•¨;錴‡Øì"aF j5H–âòÜb±€•ê"c§¬Œl”z;±ñ•@ ½@ žA[ÔuWÔ÷ìÞ÷F¿CNNÎ}Ï¥´V`WçU¼ÐŸû-¸ÔúÒcÜ4×îÃJ]Š"”nræû/ø1£#;º£T@‹áÓhA6ûf¼ÎºJî¨ ˆ×̸³Sä/B hAsgÃÒì6·ž½½9”…+?]àïÛ1ôr& Üy ur£š.°-kY±ZÍ»cÐÄMEú¹_™¿t+-Ç2e@µ‚/(ô¾ÔÒËdíÝÂM/¾Ú O%€­ÞuéþþbhüêQ=e2ŸÎŒÀ)LGðGw×øwaì›òd-¤œXÍ´¯Ñè­1øÝI•㎟·ŠÃÑבšùÜ9P8ãá¦ä¸x,8è¼ÍÄÅÞ@çæFáÉ\bc’©äïØ^J ‚^ O‹ÅŒB¡¢ Ý`Èfô[oT«íÛ¶!'ÇPPÂÊŒS…cc^|ùAzwZ*¸A•ÄÍ„ëdfÆqêÂb6ÌæÇ´F¼3a µ´.oÿšÏZÐX®sútEz ¨”/H•xÔé@Ÿö}éìxÇŸ{n#ãkÒ¯‘céñây‘œr jÿü°mezO˜ÏºE,xw4›«Xq劆ÖC§1®­%/¡WÜúϘI–n%fWSoø"=ÈÃÐT¡ÿû/röío%ˆÆ6¹HX?`jI©—þæ÷ß6²>$‹:¯L`t‹‚!?‚‚«³`×iûùàqû… Ú6âÛ¯`M£± ª€‰'Ö°ú€†ÖŸÔ*œo>÷Ç/8ܧb9S_ !è@ðÐhµ:¨TɵºðçÚl6Ó¡]L&S¡ßÌf3 èt:;T.1.æ³±wó&döÜj5gØó Pe‘™m…SíöttHÅmúÕ¤¶‡³¬B­PQåÙרRðt9áü´ôT'ÐÖ¹°ä”,ùyöaÇ8© bt5²)ƒk—à ;sŠcǯ’£qGo§Å^ºÌ©¿~áçÌúÔ ªIu_gtET¬¾ÉsôÙ1ñïÆÐºy-üݱÑ(‘MFr²3IIJFS¯?/;”0¸0$]æÄ?ØòÛ>âü{1<8?'`·_3Ú6¦n|=*`¯S+/%Ÿâ×]ǹCdxÑ{ª7ïÄ»ó»ÓÜ«hÚLÍž¥ù«Øq¥ ¯TQßù»}³×™”¼˜3†³V²ÅF6`ÐV¦ãk1´vÁy ™ÔsïÈœÊ*ñ" BÐ àIáííCxøŒF#ª2®’´X,\½z//ßGz/RôfýJ»§0 –†Gؾ3„ý«æ²6) C.&‹Y.0— ®ÅˆÅ“èá\ÔGl!fÛJvZÿ)jÜ ‘‘bXóþ8Ö^S"¸õqF‰ÄÍL#nÏt¦öÕï>ñw,ÞÕ¨T—Öæó^ l” ç¦z„áù~Çr®1þ›7iT0¬HWA3¾¡ÕÙã„FÄp-òYyJ+k4Zœüðq.¥KÌ=Ã·ã¿æ|ņ´ö9“šûc§„ÞÝopöÐ~ßÉâQħšiòÁJ>j¦),Ñ­Àd°Æ½fkšôFÍ@œ¬îØ®«Ç‹wòÞÊtœÜ¯;šÞ–ê=ÇòMw#7SÒ1(ô8;ë±.r*9+”Õëé0ºs~x‘@ øÿŽâúõ¹¤BCÓ ACa!@ ¸åù^–¥LFF‘‘ÄÅÅÞ?{Ím-¨ÓáééMÕªØÛÛ—Q­IK1¢uv,æÙ¾«ó0ÕØè‘B”r0äi±ÑÞU£’ÙHŽ1“dÞN—¿ÈӌɬÆJeÆ,©Q—a\#™Í V?|¨‰t“Ë'£± ¬¾,g“$%ÊGa"9£‹&³ÆfS‡ÔF_Ö…­æxvΜÉþ 1|ÚÓ·pŽ@ øÛ×½@ <¥ØÙÙX__ÿB9×ï…J¥B«Õbkk[ö )µ8¹Þg•¬Â›GÅ£ÔaSä’Jµ[½¶X7e¥¾õu£G”êGÔµ)®ó ˜P8Òdä ª¥QÉPæ¤ô²= GL£½³^,†þCA/O) …½^^¯Æø/R–VQ¬ô¸8 Ó ÿ¹Ï…0@ @ ½@ @ ‚^ @ A/@ A/@ „ @ BÐ @ !è@ !è@ ô@ @z@ @z@ @ ½@ @ xœ¨… àéD’$Ξ=Mtt999e*£ÓÙàëëOPP”Já³!è@ðÄ8{ö C6ýû¿ˆ}™ÊdffðÇ» ;C:õþSöÊ;ÈÏë“ ¢WÿÎÔ°S<¥w*“Âáìªt¬çþ¦Êó¸™nÁÖx†-áôhã‹õ¿yà››IšÑ 'í?`Kcvjc8›jèÚ¥¶ŠÿÇ/‘làZœW›¶Ü£¾³¥Z¢Ü—¹Èï[cñíÞŽ@›ÿÏ‚^ þóDGGÑ·oT*5ÙÙÙe*£R©iÓ¦=6üü z)q?‹W§Ó~tOŸDOb¾Àò1_’3ä+Þj s?|µçW_¥mÒF¾XÂä±Ï`ÿ´‚”ÆŽ}ÙÔíÕ/e™ pæÏ.òÿ­°Æ¯iG¸Ý.,‘xt-ßĤ]‰‚^"ýüŽÉµéPËù‘‹T)q³&_¤ëÇ-‰ß°ˆõÞS`õè͹µLÙW‰·G´Äå~7oŠgÿö‹øtiƒŸµ…‹›f²ìX6rþÏV5zó²Ë>VHAºý·Úý˜übÝüAˆLæ¾y û³KgôÀM)qýØvEÜ=Ç]”¸4èN·ZöE„¨Dò¾Å|q­5“Ö*,ŒL|?þ{ß~™Ü=‹øÞg#jëL¼šÍHj5ª§èÛbßÈŒ¿\yýõV¸xFröE6Íü—QC°ìY\r}¥D¶NxŸS¿db;‡r‰zÙÉîõ‡hÙ®í½½|“ÐÍë9tÃrßs*Ý›0è¹z8(Š žO¯gÙ o¿Ü 7ÕÝ¿›s •ZôU¡Æ¦åû°ï=„ŽžVü›‚^ žRrr X[ke¹ì¥,£ÑhÈÉ1”ÚA^ØÂŬûŸS©¯BËÖ8–Ðßæ]>Ξp µb£Ñm Ôz7<µ…:{)q?‹¾ÙC¼t¯‹V¤ãÈ×hëv?%hÁ˜•IŽ9¿¦d’”Õèà†wÅÚ¸îHÝhs IDATæÿØ»Ïð(ª¾ãß-IvÓ!$$@ -t¡£HQ©VA@¤(Š"]Š ‚"Š•.ÒAz/¡ZHH!½·ÝÍîÎ|§ kOG£ ¤¢‘Þœvœ¯?_‹ÝðY ô·¸û98̲‡I©àÇZí߃±/` HiÇXþý’*ò\…;mÞ~“ÐR½*‰¤‹Ç9—ÕÛÿ¥°­Ç€G¿!™Ï†¶á§SÑè‚0ß¾ÂÕ$ýNRîivÞp"°S$§Ã¥:MvU©ífyÿ½n­™Èè51Å™l¦°ÐÌ•w^ay±—PáÛg&_öñ¾{ìÔØ:»QéÑßWÎ6¥:MæÛ;˜½ä->íy?Ìë¢v°há¯IR UèÉWºà߸+C†w¡–µ[dܬq9ˆ¶ÿž»"Ð ‚ <Ã$Izìç<´ H‹¹ÉõŒ"¯«'üD*nMPUSôéDJ§œB"Î^Â˦ž-õÆÜLTm?eÕ»u‹]d6Þ4 kCn9›gŒÞÅÒíI„ªÅ*lù W¹žb(^q5ÇVhFu3–*•x(·óé§·ðÖ§`Ó} ¯]ý]Ö|†5€…'Ï›„nÚçL^¢å=Ÿ},Ù•ŠZ­@.HG]]AòÁ,ØŽ…ZT†ºæd&¥žcó¾ë¤ßH˜zŽM«õ¸ÕnE5À> ¯½Z»ÈùWÈÁ˜-¬-k›M‘œ¹˜EtÚ8º—ùuöÁ˯cý*ޱɾ¼/æüAVËÑLõ{PíUX{Ñ Y³r?Å>g›–qȺãƒÊãìÉ|_ïBÀÃz`ú«üùóyb_\KnZgÎÅ 6åעʨ°;Ò«_+Ü|TŒ­yg_â¯`ë±LdL¤^;Orå ÜŽìdk鳋ª¼ñw³¼ûºJ¼{Î`ÍKr±Ï¯œºF§ÅÂOéV©øU©T?èˆ)l¨Õ¦;µžè\LeײõH=¦ó¼ÇÝ4oŽbÍüUÄ7ý˜U¯â ’1fÝâä¡[˜¥;ÅÛz¯1$` ‹×´dÉÀ€Íp4èAžaS¯¥¡ýGZôº—¶•ñgŽ:x$=\‚å¼Óì8¦¡ûg_1¸vÉˈ‘_à[MéË ÂÆ›&m¼Ë¹ø¦³óà÷Ø„%Ì¥X]ŸÔðM¬ÚŸ^¢Â§#%߀yßïüpêÞ?:cK ¹ ÞdR¨ë3¶Œ›‹'Þ.fL(ò]ñöö¦ÔýÂ$ngºQËýA½QÛ|8+šWðlªP+°Ê#çîú7t@°;27B—’GÀÄ¥ï‡óI¦Uñ}¶ôáÅñ°W¢ºŠ©á;,XeÊ~Ün"-+¹Ñ¾zËEÂVîQ“#A%¹½N¾PB–Lèõz ÆÇÿ¼œßË!Õ L_Ñ¿’§³Çš¦’èdWáóI.ˆåÀïKYº+‡¦ñq'ŸbwP¶>4iãS¬]2ã¢É·¯Ž—ƒªÈGb¾s&l`PñP©r¥^§ÎtzHõXγàøo1eþŸ9~»nV!¸SÃe¤Âw\&¯~_Ú é^í‡ñi{³0í½lZŽŸÌ«ÞD¤P¸²ågöÅùëcI0&sä·åÄ阨¼ZóV÷ lŸÂ¹hŠÜÎú؆ ›XdX›î‘Éž´lW›;M­ÀÂÑ—–Ý|‹­¯%uÓ>Š¶ÇœM”{^R€Ò­ }û7&{W4»ô éÛ¿nJÎäæ?é\¤`þÜ£x½=^¾e_> ¯œà´¡6ƒ*¸ô”q’ÅÓ~&#l_„=dEs,›æ|ÆÕ® ù¼ƒs©ÀmˆÜÌœ¯ÌŒøz8­˜èݢ{ »‚!U‰CØh *}q´hÈ ŸCsñ,göÿÀÆïRQT ¢ehkÚ„5£žgÉp¯@m©E£1a¡T€B……%Š’¢V P¨°°´@}oçM&L*u±›RöÖnJ¦IŸŽø–7vZåM§!#hR²×€Ž“˧s¨ú{ŒnëV¤¨ìï…ëÿ¬­¤ÄÌYKË1S s±G1qUöoa݆٠ZíEÛûÒ·^ áÉ>´|Ða’ÍFôz=yQ‡ØqÅ™NÕ/1gòné È(PðùÛGî‹Â< ú¦ŽÙUÈP–¾×´Ø$^ÙÊŽ«IÒ´ÄÇ`Ä­å Æ?ïIá¹øx—c>脇4Îö_w~3¶iycZoji¡òW6þÁœ«qiÚ•Wú¾@À•pb¼dW|XÚÑørýinÜJEv«M“жŒþê#’~¤ÿŒ‚Çü`e‘žmw玌îߎɑ*/3ezO‚ž^m¸ðúj¦®L¥ýÄé´*óîLvÄâ¼ (¹òŒ”Êîï×pÕ¹ ¦ §»Š‚Ä‹*Pa•²•ÁÃÇ—êÕ<©Ö°H%>?’Ýk·m.Ú×çâÍLjHX¹Š"“çeÔ¾tÕŸæV8¸¹á epñÐ5¬CšQÃV¦¬UJp¨De7 Œ)çØéD»E†¯™ÓHÉÔRÉYSâ»BS£!,˜sŒõ«ÿ`öˆ•X7èÁ;CzÒ¸’ºØùíêêDÁÙtt2Øý Jô"Ð ‚ <ÓþÙr£tnÊÀ)¸ùT.»2-¥³ïC˜›¢IV‡0¥ž`É”ùlKt§g‹š½hœÙĶüPƇ:—yû[[÷E^vǯ;^$äeÏû+dÔ¸€_>…WhpóoBhP^xÌù‰Dœ:Âþ2sí7(«6å1cèês·evvìÅk5“Y~„[Q[™õÓñûCnîÓgP˜s“¯§^%lø,«A©Bi6cºßPñlš=‡.Ch󰫶†*5kQjô¼”ÀE³’JÕƒ ¬íXÎðÿ¬­”îíóE *U¹;<ÁÂ… Žý jß‹[Ç·òÛê ]U€:x0¡Eª¿*ïÖôïJÆö›ì>*ÏnÌXÑ Ó…¥¼µØŠI‹ß"@ †C³è»9€/gõ¸?ÙYκΞÝ9~8Cl4ëO„ÒåE™ÜÎ!þÔ¨^ …cKÖì'ÍλØûhƒz1mŽ–*nwÕ¡fkÞך>IgÙ²v5ߌýƒüû(1ÁZ‰­G0íûµäÝÚ5ð´{pPLIOÐQÎŽ#&¯2aî*ÐÖ¡ï§ x«JåbãîŸËšÏ3~fªyÛ”}˜oó׎«x·zbû+‘¶oË#k3â‹´Ö^gã¼¥¬¾ ¤NëfÔõ¾@rçyÌêâ\ªC®phÂàÉMî¾L>·Ž¬ãÛ•ñÔé÷)Ã=¶3~£7oÒjó.±rê*¤¾¯Ð¼HGFJ:Èò%gi¿¤é@_Rî56}ž<ï©ôôTÝïÌ›L*Te~Q)°®Ú‚7>hÁ«Ù7ع|!Ó'eòñüwhTäõUjHE>‡"Ð ‚ O蟡!7 -^>å-Øg$nûbVDÔàõ/CJŒƒ/µWä]ÛÂÜÙ¿‘ØpŸw>Ê¢iŸ¡šø1ê•1ö^J`ûº“TîòÁVå&J:õjκ¯ÿ üùá4Öþ½M¡²©Bp›^·éŰÜXÎÆú!c#T¯2÷¹þ w c§Z÷W´1šEŸµ¾LYÐ_å½¾ƒYÞX@ÞÉ5üžƤɡT~‚«¶œ+ ÎÔð±ûûÆ+4T®RÆ­¥ >-z3Ò:‹È©iþj[Ê_‘TâÖ_9uË„”z•¼l5›W­â¨Ìñ±“óYóc6¶jB{w f~Ñ6øùºpBÓžÏ>솛Å)–T®ìxçl{gˆ’Ò[qù/ˆ¨üè2r(ÑCg°ýì›4 }ðÍ•—“ÒÖŽËï^‰ßAxÆý“üùG™28ûût&üLÓQ£xáaëE𳏴a6#?ÝŒÜõSæoCÓnã™=ØC3?ã»ð¬+NËä^džô–¼öœÇC/ZÚúÝéêtŒõ{Sù'ïk¨íªÑ¸cuzWBÆlÈ!bÝ4>\u‘œ‡"…ƒ#öä™#ÙII¼jR㉊7½m+g[ÒºÆã§Œ$[ÎÄY‡p~m4o<|‚§• •\]póoLcç$"3´¸:›‰ºžKµÀZxUrÁÕÙ”žmüN?ž tºÔåÜHn¤yQóþZuE·cG³+ø¹0¥qêÇÏ™ºß‰7ƾBæïlž(þüó"a¡øþ·~yÊ”Áù53øðwÝÇö§a? «°õ¦Ž5'7±Ýªã6çÎ|_[{Ôåü2@Aø÷ 0†…‡ò©óê›´s±ÀÑÙþÎçXíM¯‘=ÖMfàèÅ\«÷>sFµ,òãOw†ùýò—Dû—šãTîÇKC^ý¾ºŽ ׌wÓme|ªªˆIzôwÊG[3z©Èp3q±ixøTåßòóR¢B/‚ð 3›M(* â6LGJ¿Â¡‹ÉÅ&gʹ7È2eqýèAöØ})îÁ-©SæDU ]ÚMÎ=Àö­{¸D=^ûl=ë”·º™¬k{øiÙÏì+¨OÿÏæÒ­¶ýý¡1žíF1[½ˆ‰s>ƒqSr÷u¤LŽì8Oµ—gÑ dÕ]VPlQ¥'ÏufýÚ]D=÷5ÿ«?Í)¡ÏÍ"#3éÎq±ôlÏÄéÌùhÓœg0³›WÙGPãF»4“%¨¬¦J“Pj®_ÍüõÖ¼VTfù¹$Ä&€Wj•uŒ¤\®m]Ìôuy´Ÿøbé%ÿÖ˜OÜ…ÃlßüÛ",hõö4†wô¦ì8o"33cÜUÒ}Rß´‹Õ¿í"±£Þz™&Îz‚Ô¬üå/¶™»2lpªY–ÝiÊ9sŠ«îuTän‰&¨oŒeŪ3ÔRî™ó¸xô/þذƒóÊÆ¼=}(]|ÿÆ4_˜À__Íaƒ©Ÿ¿àUñ «l +)‰Û» V^~øùYrƒðc‡Ø¹m/–Íx{ú8ž¯ný»8Š;ô¹ä™àÎZšjêYÂ’ò:Ù/1í›þTq²@aºÄâe /òÿ¾/òɘ >šŽ«›ÅæËÙýá7"ë¾Å˜À‡wŽÍy¥Ë>\wˆ^·ÃYaEpHmîxR*}ùGU€ÂŽ6w¨Ê­5c¦¸pÃÊ +4ƒRYb(ˆ'>žyì‹ÍBªëŠÒ«+S¦ÙñÛïkù|ílRò%d@¥q¤Š·Ͻ]·D /$zï*V¬ÝË9/O˜Ê›!¶ûÒ{Rü~Þv–ظh®ß¸E–¦MÛöbÆÈ0Ë;9¤\"þXÀŒíZÚÕ»ÅüAýÉÉ^ØùB•´…fKª¶èÇä¶œX÷K¾Ò0õ³nÜ.-ɨ-PI‰ìÞqÐþøm¥3aƒßâð˜¯ùrïL&µw¿~$n[ËæÓ±ÄDEríV&ßF´ùF¶ ÀEýwž‡ørò7µj˸ÏúS·¢ã:T–ØhbXóÉ8Ö<ò ćfªâ!>ö¯oY±/š¸¸Xu6ø5¢õÓ×¼:øÌØ6}‰žÛg0it,a-êàëæˆµ•Ù¨G—ŸKzjVõûÑ7äÎÒ¤ ­ Z@6QCÙDÊùݬ¿–D\ì-nÆh2fs>«Ì—ó&1ôhGÞ|ã%ÚÖrDmÊÅèÒ‘ÝZâ¬0’•”J¾ÒKc2™z ìŠ-u¤¦úó}hÿ} )pÖ(phþ-~ù‘íQÏ3 æ½ƒ©Ayˆyï.!Míˆyd+¼hûÎ(zy?øžË8²ƒ“•;2·ºê_s½P$%%–Ù‡;sæ4 6WTA„Gx’ïËŠ<çÌ™Ódggããã‹JU± ‹ÙlæÖ­(œhØ0ä鑤ó칦§’gU|½«à`QÁ "å“S ÁÞöQûa$ñfvÕ½)=‚E"õÒ^]I#W/aéV—Žƒžâ²~åÕ]Ì_‘Içú\‘g¾ÎÏÿ‚åÉô)k…9Š_?šÅÎLæœTô!cùáƒæEöW"n×RÖË]ٹĸo$L†BÌ*K¬Ôåí¸Dܵ•êÒ®e•þ¡Ÿº”’N°vïm´î^T÷ó§–—ÃC——Ð…/fØ2}&Ž ‹’¤s{غï ·HÉÌ&OWˆÑ$¿?¥òæÕ¹sxÅz'“Ç­!RŸ‡ªÍ$¾îã§ÆÒçË1„–ZF&ïòÏ|øuýç§‘öN;%ŸÜÄ®X+ªTõÆÏßjŽ–ÿQÇǽùk é>¦]èÉœÄÙã™x7 xhGøé’ɺvŒðt-îžUñõrÅúIòª”OÜÅÓœ¹KRZy…J K¬4Ö88¹áÛ°Í}lî/gšºc:ÖžÇdëL%×JT®ìAUïjøúxãëí·»–Ju·9ºñW~ÞEÐø ¯[¤*/%°iÊÇürÀIR¢qkÆ»Ÿ¿[Îj=E¾/öÌ⃽ÁLŸÒ ¯¢í,ÉËÊ$׬ÁÅÅË"%9/œ…ü„Ýû³TÛê_s­^á ô999ܸqøø8ôz]…^W«ÕâéY??ìííÅÁy&™Ñeg‘S`À¤ÐàäæŒõÿêŒ6IOA¡Öš'‰Ñ…ºô&Ö¶ZÔ ƒ®K­U9¡\¦Ð`ÂÒÊBœ‚ÿä!6ä£Sj±±¨àIn2bR[¬¢ªaþ¿qˆ­lx¬o£§æŽ46“ZézT2<òö‹lO£¡ÓiïbË¿íL^á¥P(°µµÅÖÖV4† Âv*U°×ha‹«Ë¿t7Å‘AA„q¿E4 ‚ ‚ ˆ@/‚ ‚ ‚ô‚ ‚ ‚ ˆ@/‚ ‚ "Ð ‚ ‚ ‚ ½ ‚ ‚ "Ð ‚ ‚ ‚ ½ ‚ ‚ ˆ@/‚ ‚ ‚ô‚ ‚ ‚ ˆ@/‚ ‚ "Ð ‚ ‚ ‚ð/¤M ‚ðl’$‰‹ÏN§«Ðs´Zk¼½} ®‹R)j6‚ "Ð ‚ ÿ5/^   Ÿ~ý^ÇÎξBÏÉÍÍ᯿vqéÒêÖ­/±b]'$IÉÿÇþÙdB©V£¨ð3LÈh¬-ŠÝ—sã‰HTãë玵Bœ1‚ð¬åA„gTLL4mÚ´G¥R“ŸŸ_¡?*•š¨ØnÝŠ®X”YËÈþ‹9eúçöËty5Ÿ.9DšôdÏ—ó’ˆNÈÁø¶EwãO¦ŒÃ{£?`ʆëÈ%ßÌ@Nz6¦þøK—غññÒ“¾@ [>Äç{³‘+úœücÌ8ß㊿©éÊ:>·ƒó£N6—÷laëþ㜾E\J&9y: MÚ ™œók˜·â)EßC2¢/È''7ŸÂï-\gý¢eì¾m_Âÿâ9Ç%h9ÿ0_¼³‰Zs¾äM_Õ?züå´pÖÿšŒ}צxUh?eòn_áj’þN€Ï=ÍÎNvŠätxɲº»ªÔv³,ö¯Æ—¸båKõí#è²%©Èk˲‚Ñ/ozð`…a~âÃE6¡Ü”.Dž$95´Œ,²r 0J òéÇ¢ý¨QF3šoï`ö’k´ø´'n*GeÖ¾\”6vX«ÍäK¸Ô¥×€×y®† k?:·>ȸY?â:s lÅ­AzAá$U0l˲̢%ß°zÝú‡?./‚?×%Át/Ó^#Mo`Ûòï9]")ݚЯG]Šü»ÂÆ›&amÈ-§aŒÞÅÒíI„ªÊ WRçÏÇamÔ²sKL©@Zxèêï²æã0¬Ë|W.EbðUç³9ž;Sè7¸ÈΨÑjŒdd葜2È(´Âí_}U”ɺz€­Ç2‘1‘zí<É•ƒp;²“­¥{]Tíà¿›e‘á8…\:޹Þ`^4Œ>äû•}Óé¯ys¥=Ÿ.|ÿ"m¤TY”xÙJ4{e8ÍJtâŒz=IuY}")•]ËÖ#õ˜Îóªûû¢Ï+À£Ï¿ê‹ t‰œ\ós'/@ýÕ‡ttQb[ï5†Œañš–,€¥øÊD Až¹ˆV¢eA=ç IDAT:øè1Z4kZl«,Ë,øz1ë7þñèTZbcgýÝá R®‘B­#®ööØÉàú{ÙxÝ•®ÝËôm¼Ë ëéì<ø=6ac s);ÐK‰ØÈ›‹?¡‹KÉDnâÒ÷Ãù$Ó ‹ò¶ßÍù3j<ÖLÊŒ!&¯ Í<‹&JZ¾Ù›ÈeÓ•mOýÞƒiõT«¼2…úBÔ+”rÇØ¸õïî·œÏÕ½‡(¨ß‰†.Oc¬¯öÃø´=ÈY˜ö^6-ÇOæUï ÞY(8ÏžãfšŒ¨‡Å¹ï0ï(ú{§ŸYOž^Áäûîß9QVéÊô9ýð«ÀvYh¬Ë=¦¦Èí¬mȰ‰•KVén(µUhöÆP^ Ï_'²èÐÅZê½Ü‡6rðåÚtpUzAzAá™ ô*ô+~ü‰•«~¢Ës˜0v J¥Y–YøõÖÿñ`(į½ ”=è[a]“½kÞœY;#XŸÑ”~ýžçA—HÛv?¨ã"!‘qx?ÜdàˆzeW×åŽý¾…ÌÐ4Wå/9bS,Á™ÉLÏÅÁÕ¡ÜIœæ˜3„gûÓëÞ°™ *Œ¼Î-_^¯T<2ªÜš0pb2ó-p²ºõ]9}ŸN¼Eß%ïPßBEêéߨoÑ‚ºmlï쟔‰M;Qøv¤¡Ky/"a6Cù=œ²¹¾i=ª†PgÿÆŸ‰!ÏΟ ¤K m9m+‘¸çfÙ𒓤ê)pëÁ‚ù½©¦ãɼ²Ü‘©‹ß"@ ¦ Kyk±SÑþ¦)ŸÄ[7¸qó·ân“˜šNzV>J+[\=ýhئ3ëV*²;&n>†¾Ñ;ÔÕT`×.¸¹@~~2Î(¥[3ZyþÆð\Ú··GDzᑘ+‚ð “$I’9xø(+WýÀ¶»˜=ïKŒFsæ/,æß|íU†¿3¤Â!<91­»{±ê<€ÙhµuÓ‘éöæ~AàÛïÐÞ¥ì±óiG–ñÍ…Ú ìçÍéEïòÚÐ)|³õ<Ɇ{oš@tœ„—g9ãç%Ïž#¹zêÛ`Ù·bH+w¦‰È‹W0×  f©6sýçñ \pˆ,ùI’‘È=kØq-·ØäS…SA¶9e´Ô©[kg¯>˜Ì+g“™ã€‹óC.ÅÆã|ñÖPFOÿ†Ÿ¶'"1ŸGÍK•vðý–8òb.ïÚž¡~È» Óùiö/œÏÉ$îêYîÞ̆ ÷ÇÈ˹áüº!}ù=Kd…eyçƒ)‚¥CßbøŒØ|:–¯2dðôê@§$¶ÎË'[ât7¥L®^ËÄÇ¿f…:rþeÎEYáííú À(¨UËž›W£Ù6‚ðÿ•¨Ð ‚ <Ãî ¹ mÙ‚î]_àÏ-[ï†ú\¸x‘øÛ ÷ûZ¿¾ 2½^_Á<ŸÉÕkéTmå]*@Á²B…a)ã$‹§ýLFؾs)³R$%î`ÎÒXZŽ™J˜‹=Љ‹¨² ë6ÌfÐj/ھؗ¾õbOö¡u mÙUV)…§bñnB±B»î+>[@þÀELj]Fuß͉39ÔîŒM©ÿTQ½qC¶ãdv;:=Á 9ë(¿®ØƒË„Åß[éAý:f¾»„äï‰sP Î[.qÓÔˆ5Hi1ÄZzÑáaÃ|,2èãçÐ\<Ë™ý?°ñ»TU‚hÚš6aͨçiSüØI©ìþ~ WÛ0aÊpÚ¸«(H¼È¡V)[ùhÐ<||©^Í“j ïu? ¹ôÛ ŽT ¡ž1¹ÈIÍí˜$%²0ÊZRbc°R‚99sÑ)ÍjÞ\ô ƒµ–åV 4nE[¿ þæO.<÷. Õ€”FJ¦–JΚ2y~ÂUÎ].ÄÞJ"çvû7nàTÕ~ÌkX´œ¯ÄÕÕ‰‚³éèd°%zAzAáÙ ôwj¨f³Ä‡ãÆbaaq¬|Ñ0ÿR÷î :½^Wñ×Î9ÏéhO¼ëX"„ÉèuzV4G¦Ô,™2Ÿm‰îôlQ³Ü0¥toǘ/ZP©ÊÝ!.uìOPû^Ü:¾•ßV/`èªÔÁƒ ­\v$”ÒNq4Ê‹–#Ü‹o¯¶>½ºWaäšÍD¶x¿W6ÓÍcM÷£G#Ç2C£ºV3šÚNçpxÛ;<Þ 9Ÿð_~å\µ®, ²*u‰­Y7€œýÑÈžØz6 M­³ ePCÎåK¤øw úÃ®Ä nþM j ¯€9?‘ˆSGØàOf®ýeÕ¦¼1f ]}T€DÚ¾e,¬Íˆ/FÐZ{ó–²ú‚’:­›Q×ûÉç1«‹s‰ã­ÆÉ«1o´ "fê»@ {/γ~éw€Œ.å&…†t6.C Èù äV¬c¤Õ>j¬¾k¯ª¸\'Ëx/˜1™T¨Ê|ªDîý¬É8ˆQRcíX¿ç?dIû:T*Ñf*µ $3&ñ•!ˆ@/‚ <{þÁ NÇØQ#ŠM€}±{7ÆUñÊüݰ”°o7—½[3Ô³d€–ÉÍÍGcgóq™2y×¶0wöo$6Æç²hÚg¨&~Ì€z¥Ÿ§ÐP¹Jƒ¤•6ø´èÍHë,"§^¤ù«m)sµK$R#Ò££Jm¯¯Î½ ýs!¿zÉmŠ­ÜryÏ!Ò{Ó²¼‰§êZ4Ñ2åø9òÛ…Qñy±&nï^ȼŽôý<že¼¼U㑬hrwj§º½F׺óÆh6oŽ¥ÑåÌ7(‡Ê¦ ÁmzܦÃrc9{<kWåývpiúŸÖp%Àþ*Ë'ÌåR½!Ìû®9žVFŽÏÿ“YÈ8—n¿.ñ2cÁ½&©Ó‡Éo)™¾ÑŠAc;;ÿm–»ç‹A¨sôvl³Äî±îJ$Ÿ=Çm÷ |îMWPÚá`«#.¿¬Õœ”¸‡ eÆ«><ª«—“ÒÖNüè•ð?KŒ¡AxÆ}Ñ?:Ž1ï¤çK/нë |ðþ(t:]±Ç=2Z¥äû „õé€G©<_@jJÎ.Ne_$ÌY\Ú0›‘ŸnFîú)s‡·¡i·ñÌìΡ™Ÿñ]x_ÙÞHâ±åLœuç×FóF€U9œÄ7ñ kYæšì ›†ôîêΙ Û¹Y¤L+çœ`óaM;µ¤ü¡êø7¨ƒ*â— +¸Ùæ,.­Á¸ochðÞ8zû–SS(JWü¥lÂW.d»cOú5Ð<ñ¹¡¶«FãŽaÔ)ÒQØzSÇÇš‚“›ØnÕƒñ›ãi @ckú1F™[ùÔ§vú>›½˜gµ„4z°²Ê÷yÆo_Áõñ̤‡ÿÈô_nÓ¸o'|î/•SŸª*âc’ž¸% ÄŦááSõñæ Âÿ#¢B/‚ð 3›M(*(2ݲ  Ÿ÷G¼Kp:´oÛ® h‚,¶2N™„¼~𹂸Ð1ŒmhS*pÊùœ‹RSõ¹’˚ɺ¶‡Ÿ–ý̾‚úôÿl.ÝjÛß}ŒÏv£˜­^ÄÄ9ŸÁ¸) q(¿jdÊ'îÂa¶oþƒm´z{Ã;z—ñCS2’Ñ@þͽì‹r#°[ §Ü 3;‹ŒÌ ÒRRHJJ"1)™äL=’"™µ'º3±¥- ÌÄîØÄ »v|ÑÄæ¡Ci4uêXø+á7L4 *ÿÒhÊK âÄ~¶lÚÊ‘LzOšÉ!Î¬Ž™É‰>Á«V±£ 5'uÄýo)«)îüÑç’g‚;‹³«©?d Kçe¬jÒoÜë\ù g¦‰µ ËǬɈ<ÅîÍëY{$º>áý–EÛËŠàÚ,Üyž”>Õž¬= W8}Å‘žUD•R^Ax¶h4ZñððD­.þum2™èЮ F£±Øÿ™L&ÑjË^ÖQοÄòI³9Rõmf ¬wx‰Dìš ¼·!•è³(pyÏë¯^þ1ÓÎSý¥Q|óR•-J_R*·É óÆÏù‚Êó¦òR‘q(Rü~Þv–ظh®ß¸E–¦MÛöbÆÈ0˹™®²lØÇlÊ´ÄÚÆš3k~䦃#ŽŽN¸Tr¡Rõ6sÃÝÝ*ÎdlÏØ»ˆoþ2U¥(öJ§Aïîø?¢t«° ¦aõ¶žÅT½øs -˜È1] ·“rQU E»¡|Õ­%5l! Qûù}ç).]Œ Vò!¬û(¾î€óßx¶mú=·Ï`ÒèXÂZÔÁ×Ík+%²Q.?—ôÔ4¬ê÷£oHYs$ Ro~è/6m>@¼o†„d±gÊPvù4§m‹êÔÀÛÝ{­ºÔó¥´sü¹ó4Q±±Ü¸z˜{j·èÄè]iáUrÙLÍŸ£Å/?²=êyÔ|ÜF‘É8²ƒ“•;2·ºJ|iÿ³II‰eÞ›=sæ4 6-$‚ðOò}Y‘çœ9sšììl|||Q©*VÌf3·nEáààDÆ!eäŸn^ˆÃ9ا"YTÒçž‘M®Î€I¶ÂµjUœK–Ë¥|r 4ØÛ>j[Œ$ÞLÀ®ºw±ñèRÒ Öî½ÖÝ‹ê~þÔòrÀò‘cže$ ”ÊŠ Ž–ób¹’î„¿·ÝPnÔcPi°R>ú}òÓ’0ØVÆYSäÁÆ[Ü|–T+[œ\*SÍ·>•m«fŠ=Ζ+2Õ ¨êPáa!Rü.æ¯È¤óG} ~’ð/åwñ4g®Å’”–C^¡„ÒÂ+5Nnø6lEsŸ"w.LçX0h9ãß"wá×DTiD›Ž]x¡…/vJuÉ\5jè_ '‹‡?‰Ô=³ø`o0Ó§tÃë1öUÎ gá?a÷þlÕ¶_FÂÿìµFzA„g4ÐçääpãÆ5âãã*¼zV«ÅÓ³*~~þØÛÛ‹ƒ#Á]›àõ”Ød²Íû‡C˜ÿa,.nbùxÊÏâ¶Ô{éMÚy)‰„ ˜p±K&µÃIq§£”ºï&î«ÇüéÝÐÊïœ ëYqÖ‹W_o†›J¦0?‡|cé'),lp°±Ý þXyûoÐÞÓB|A‚ô‚ ÿ£H² ué^J9ÌÒeûIxØê~*w: H˜[Y)T"éúYÎß2pù”–eˆæ„]Ì[E›iý¨¢2aÆÀ±¯‡2ï¬%6–Åw^Ý`0ßnÖ:€îN0zîϸL{‹ú6 ñèAžñðý*ôrþ¶¬;N¢éîßso’ª7°må N” ÖnéÝ5‡¢9ɾ&¡5ä—³)…‘ÛX´96–ål¯”É¥ ±Ø­Ù½=ºTX/H¼Ntõ¡ü2¾%Ú2ßAϵ«7±«×›j ™ 7‰é6áÂTk`‘í²ÄÞÆDLÜmÒñ¤­©mQü5e…µB…Z%ÿãsd… ¥B‰’ÇØOYGÔîeÌùé"šötîÐÃw;q2–öŠ‹ìÛ²÷¶7dØøA„ºß¹Ôž[ÃG‹Oc¨Ò—ÇX¼ð2ͦ5#~å<¶Ü.«÷¦@Óh óê‚lÎãÜ/?²7݆ŽÓWóQÓ»ñÁ|‹ÞÅÕ—bVgÛ¢'2¦‚\ LwwJJc÷ŠM(zÏ£³“ÃÝ·S©ÕÔxm? ¨^¬s'rIÏÑ#ËFTýUos×^eAÿÚevAzAáÿW WZãäâŠñnh’ ×)Ô:ãîâZ,¸ë¯ÿź(7^èRû¢R+´ð¦ÌZ¨”ÆÎ=K°ëø!mA–Jo¯”x„¿"ë1dåT^p.Yv6qñÛŒK³F-Ë”¹·æ[\Š0üv5(ï1emZfÔuõ§q§î<ÿýD>šù3Ž3ß$H«À²á‹t­t˜¡Ä¬žEj» <çbà—äLjXÆû ÕÅö+~ÃÞ)Àh–0„ÿÈWG¡²]ç༥âþñÌÏ0PøÝPú®z°*¯øxBg<ïþ“9rÆ7åýÖÖèMæûï ³III¡¼{#²Á„_Ïq~o3GzÔ¢ƒ¨Ò ‚ô‚ ÿÏ)´5hß'ðn@’ÉÞu…µ™Íyõ•çîŽ{Hß~?öY•¾È& zSY‘™ÌÃß³òz]†®R2–Ûr'×o'«íæÆp[vÀºXŽ5p;9ÇJå®Ê`Ž¹È™¬@úÕVó8ñº0:’h›¼îTl€ã3X4 {ãÅLÝÝ—˜I¿~‚#eñc}» @µ[Þßž¸esH²’IÍîÖÉÍÑü0ì=®ôZÊìNvÎA³ŽìwZÚL䉓šÀO6óø]V“m#¼äðÙ\ÂÚØ#"½ ˆ@/‚ðÌz*C>äBty…÷ƒYt\2Zw”ù¹ä ly:3¨U¨+8ÜÔ°‹+¯Pwä×´´*¤t.–H?úË.1â+wŽ~9‚oãýèØµ+ÝÛãf˜¹+Q­±{9Õw‰Ä‹çI®Õž «¢Ûe&'&£WU\Ê,嚸) ?>%÷ÇTÀ™o>à“¸,FÉïƒ*ùÃÚßÈÍý›‰òìH?»Ò©!Ž;8m&ØOCPC_–]¼AaËúw††H¹dç9ãï¤(óµedäÂ#̉_`êׯKƒºuðs·)§bmæÚþýd†§»[ùwW«Ñߎ%Ù³Uîï»C¾5­:Öæûý—ÉîRG…ɧÍ5Hø6=U˼ë2•e3©‘8“Y¼a”š^ðwG!Ë`_—¶un²RÖqdáPÞXú BŸd@¿|oüöàù*ÏÎ|ð~{<”€”ÉÈ ªw®ŠTìŽÎ;"—þb½d_¤ƒ§¢rƒŽ´òÑy¨5Õk9ðkd ¦° ^AzA„ÿ!R&7®¥âVµTEÜPX¨*ô2á|7g Ù§0¥©%}é*·”´›…+oÓöãÙ4Õ*Q~þµ÷­cÕï_òî:ZwëI¯àÛœIªN»Úšr†ô¤r&<ßõp€_w‰Ÿf.¦à¹|вŒ ­9†3g³ êˆUÑç݉¦Ô mŽó'§ÏiM»'²!gŸdÝO¨4®[‰÷®DÝ`‰o#’ü<° Âõ«Ü2×§– ¤Œ8â,½hÿ°Éœ–M1³+á'8qøW6¯HAá^‡f-ZÚª1ÁE½”EÔÍ»ù"ß_ÆLÌÍhlj¼€³¢xø·p¬„uv9²ŒÕ•í¬ØøRdª¬Ì¨Ü42õn\³R ±wÂŹŒ{&Y©¤IUpÀÎ,V48ƒ‘ î¡cíGŸpã…Où¨µM‘3PhæÎâØr&éÖ¸:–3Ú,a6KE&æ*Jagòc²ÐË`+Jô‚ ½ ³êiOÊ”s.q&º!ïÚ”¨ˆËtzV¬Q¡7§â»Y‹Ù™äA¿¦•‘u¦2‡M(ª<ϤÅ]p¶•È3˜ _EµÖý™ùÜÄYÇò–ðÞ/¨§¹cÙï)¥åD”7¡#ä"k¯hCx­·C7n'²Ij–¸z™£Nq<-€žõµHe½°wZØoçøÙÚ„ïÜBO9cèå|ή^Ãùê½ø¶Ž²©øcª‘³7Ž© 6•êÒ>à,ÆB Y9W.“Ðïò&÷Ê€Â{ BýBèÖß •!‰ GþbÇ®íÌÛø= ÏF¼2r$ÏUS‚¬C¯×b¯•ì§”ÄÕ«¹Ô~±ôœ“®€BZÔn~4íV¦>«ø"ª5‹'×åâÊ%üv°€ÔÔíS‰S3iÖÝŽ#»L´kkfÇæ;SI`E•Ú~DlžÉä?ï½AÑ1jÿšÏä}EO-!¯æ¥*@ÂlV£*³}¸4èÆ€W¼‹u,Mú'o“oéCÓÖ>Äü•@³ÐJ\;m ´¹‘£ûsP*@ÖßæÂÙx4žçÅÆEÞ"'œ£¯Ø©í‹Ï]0eF‘.ùᢰÃѶ€Øü{%û’›©'/7÷‘¿t™Ÿ“Òέ¨Î ‚ô‚ ϲ§Y¡—2óãŸt˜Ð'³\<@Ë:ÒRóq p@QVÅSÊ&bë ¾Þƒï›_°¸‡' s ÙÎãýù31¾7·ê—œØ*c*k.-zâ¬`Þ·Çp8›W«™1”õK¥RGGR£í{¸šåRk£›”µéõ’'C7ï&ªy/ªß-éʹ§ÙqÔ@«Q±–ä²×T—Á§~]Ô /qÅМFVe´yÉUn¤l"þ\ʼuI4™4] ”ñ#H²!‹Tý¿’—YRç~þ–Ý.¯°°6HF¹œã}gã䢫ܘ Œ rQ(m¨Ýº9²^G¡$ƒÂŽÀ:•øåÄy²7Å^a$rÏ^âô£‰LÑ›rÖI6í+¤Õ~(e©0…[QFüëÊ pÀÅ!™³"ˆu¯ŠÇ­¿˜>VM~¶™ã•äÁøÉoÙîN»fqëjIEW›ðc—I.”¹µô{âš×ÇKó m+,jâÖ &Î W¼½UMÆÜÀ³È9sï¼»»ÿ=› ÄǦâUÓ •¨Ð ‚ô‚ ÿƒ¼«ü>ÿÛ̇µ˜Kh9ÿ*nZPí9×z‰ìûøíÇ5Ö‡0dî·t¯&‘“£CBu³±,R/à½y³à½y«¾}ù•Uóÿµwçq:•ÿÇ_ç^fߌ1;cÆ2Ã`„,Y‡6"”JZ´~)ù‰6B)Š%ÑFTJE+!K}E!²Ï0˜1‹Ù—û¾ç^Î9¿?fŒ3¶š¾¥>ÏÇãG÷̹Ï9ŸsÏ9ï뺯s iû¶±~Í*Öö ñ±Ù<ÞÝ[‰³ZÚÖœv,)[ØœJÂÍ©ìØžGAa!ùäæd“••EfV6Ù¥hJ:_í¼‘Ç;ø  ‘¶q ?ûÝÀœVF4õ|HÒ14I ¥ýösÑ®Ùù/jI&wn\|[‚ IDATæÛÕëØVÃ]/¿Æ=MuŠK/ev¢;øfÙÇlt\Ç‹/tÃ×iã÷Ϋ£k.ìÖª­¤Èn£Åÿ½Ë‚5Þô÷ßÁ;Ì xùj<5WycF§4ýg–¾¾ˆC­G3?΀îÔÑ sÈ %ØX iHÖú=ø$tÆ¿¨ ¾Ͳ±iÜ;%˜E¯Øy|¤Ê”ó˹ÿU u Ftì§°iíJ>ÿÎB\ßx¯:NtßHŽoMÁžØŸþ7v¡E°;ŠîÀZdʼn‘fíâÉúfÙý"1œ»ªvîqS0*}2í‡ùõ`®¾5Eâ¼è…âïLÓ´?æ­Y:ù5~ŽÉì¡Ñh;i_N♕Ùx¸›¡´[ð-¼ÜÜPeŽƒK7ëMoÇû·µÆÇZ@^q¥Ÿ[Š0µÅœÇ_å±9s zq}ÃÏ&4íÔv>ݰ—´S'I>z’"ÏFt¼ö^^›Ð“Ʀ" ŠìÕã˜z˜Å£_bM¡;ÞÞ>lÿd)ýêP§AÁõˆˆ‹¡mb8‘‘õiP?ˆÜe#¶ê{RÛÞD¤v”-[ó¸zH"\.\Êz¦XÚ4-âëßRqÅFU4DtMGW3Y?ï9¶XsÈ8]Œ!$ž®7ŒæÝ[;¦Ph½p$·ŸØÂçåàC¤éÑ$ÇâÞ1ŠŠ°_àž¯q©‡^óèÈ““rxù•¹L¶GrÝãáÄæÐÁy˜åSßä«dÑ7>ÎÜaWáV\Ö p¦'#¬5!†Ã€Bƒ›“°~´ çèöX h¨”:Ñt'…ÅβžsMC-8Ìúo¶²uûv~=åA«1fþ8š”|Íkòˆï?މweíÇ1ç±7±E´¦S‡«éÒ¹- }ÜÛô¦Û{ Ùp,‘;cL•äžâ¶ªî£[›á,zº+Þå ”ümß±#¬7³ÂÕ²)>…è…âïªV†Üx5åÆ/ó@|8Z¡µ<ä*44eýJ(²ØpâEhý ô¢‚*Ó­åP.«ƒ'ÅäR\}¢y\Ö"Ü®Íë³31ø+èj¥[mݽð­ÍÕ­zrw|+âë{¡Ù,””ä’g?Ͼ[0rÙÆ›Ëzk5MCÕT4UCUUTÕ…ªª¸\.y9øÝø s:{ROÑÑLq<ôÆûh¶"J.ÚƒîC± éåfÂå¨tc¯[#n|p(¹f/ƒ#ˆiKL°—ÕBqI…—´Mn~Ôkv-]ï|šVQ^¨%Åâ¸ÈáÔ=ÃiÙÚ ÿËz"®µþ¦}x7îŠ [aÖòý15$ñþ±ÜÔ´9 ܬäWÐ#»3l@(nÉÐѱgçãÞæ®‰t èŠ_?OŒŠÞ¹+yeV)9ž}ðBG³¤°ë ‹Øx²[~j Å%¹äZ\èè¸,9äy„Ðý¾çèû`1~XÍÊ»In}QÞTš2ä¾pF/ÛH·g®'ÜàFâó븵†Çë¶<2r­h€nÙÃ'_åÒçéD\\rš¢%33£ÆSÈ®];iÓ¦TH!.â÷œ/kZf×®4nÜ´¶È€ÙÝ„fwTê¡0 :ªÓ‰ªW_Ö`¸”Þb“› Íá¬:fÝ䉯—ÝåÄétàpªµ?@Â`ÆÍ¨âp–¯YQj¾ ¦E&ÍUu¿3^>õ²„ËéÀéÒ.k»³'Þn NG)çe,kò&0Àˆ%·{­Ê€ÙÝ .Îs®bòÀÓè¤8/“4›QÁøù™±RlÕpó ^‰â<?œÓ6Üü½ÐK,8M>˜qZ-Xm޳õS-d¦Yñ‰¬‡Ï™ij#nžÞx{™päa)OàF/É Ç³HÌØÁÍ.íÆdWçÍcG‡ñ¼Ðëì[ˆZœ|D2ŽøG]k¤‡^!þFjç¦XGM½ÕºŠë¢ãTÔKÒ ã´;ª¿ì´RTø'I=ç¡V—q“¤êrÖ°+,EŽ?vÜVŠÏ[8KÈÍ®ÕâÔ|ìÝiÃâ£_±.lŽR óKÞ¾Tg 9Ye¿›kÀäfÀe± ê:8‹kÞN£ bë –ÚÏwÒ]Ø-…Ø-çds‹F³ás˜–“‰EÓÑ —RX?®=›>vŠŠ2z^ˆóõ H „âïè5)‚øs?cNÖ*¯h8ÏmŒèÎKù(êJ­—ºf kA>FOÜ\ê¥ 12y॔PX¤I˜B½B\)^b‹øGÂq9/£Ñª«¸¤+„z!„¸’hšz!„è…âŠ%=ôB!$Ð !Äèe|B ôBqzé¡B!^!®Hf³—Ë…Ñh”bñ'QUf³›BH BQûƒHOO#((w)ˆµ¬´ÔNNNaa‘R !^!Dí #''›½{wa³Ù¤ BÔ2OO/6Œ&,,LŠ!$Ð !„¨}ƒ„„Ö$$´–b!„¸ô뇔@!„B ôB!„B ôB!„B ôB!„BH B!„BH B!„BH B!„BT'óÐ !„Büº®“ž~м¼\œN§äOd6› ¬KxxŠ¢HA$Ð !„Büqéé§°Ûí´oß OOO)ÈŸÈf³±ÿo¤§Ÿ"""R "^!„âËËË媫ÚRZjÃjµHAþDƒ&Mš²{÷. ôè…B!j‡ÓéDUU4M“büÉÎÔX†6I B!„¨UªªJ¤Ö™åF!„Bˆ+˜ôÐ !„BüAº®KÄ_Fzè…B!„¸‚I½B!Ä$=ôâ¯$=ôBñwä*"ýøi,U2‚Fþñƒ/p]~ذœâ·ÝÇ)tZ±Ø/1xØNðãšm¤Ø.º±X ò)©4é„^¸›ï}ÇQÇÿ0Pç—_R(ü &Ñ­GX÷éF[%Ô !þ÷¤‡^!þ.t ;Î`G›§µ™YOï§ÿ‡OÑâ§¹LM½)CüX÷Ú+œü6Oµ¿¼·Ö²61V.·=¤òþ{ùtú wum€—RÈ­…%”jUèž÷3+ýBû¦Mñ¬úDFÅàŽ¯¿WÙEÄu”ž™Aéˆ7ÙÊØ9øù"kä@ñ!üÏ,jŒæ†{g®–ÄÙ»ê ¶eWNâ unæÖ¶—Üó¤[ÍÌמ^ôWý»«tkë–ÿDמ‰Äz]àé•z!»¾XÎOYŸ¥ÃÒ»¶>[¿Új+îÿ„É›Â9¼+Aµ\'ÝåB3™0Vÿârj̦²ã©©850™ŒüSžõYÛ=ôºjÇVªãæåIù½§” §jDÄF૜ÿµßó>B½Bˆš(Þ´èÅÂ7Vp`lݲ iñnÞÿøÍÇ4Æ\ü¿¥‡Ñ¢N>Y§•ŠàkòªC]Ÿ ŸÎƒÅ¥âÝéÿ˜¾ÅoLåUm*z ¸’XþÂlÖT ÔŽbr,FëxñÍóð^‰‘:^AÍÈ3Óï"¾ÚjuŠ÷|Àœuô¹¯ñ^  ’¹y)KÓ¼¹®æ­Ãèæ§Ç™õ»8þÃWìpëÆ-m/=¼88ÂäEnA[6nbûÞdNæaÓÜð¡e‡žôëÕ‚zæªÁôø§cýé Ôªé ‡Cåà°;YT%ð‰¾}*³o*o˜˜ð &„‹`ô®¶/ÚéXðÆw¤_hqC×=ò0‰Á5¥uŒ;ø5¹{·»á^ÃoqulÐe×QÍÙÆë/.ÇwÄ4ˆ­ÚjÓrÖ0ö‘ôzçyz(¸ö-äþy&ƽñ` Ÿ¡u«˱ÿ²té—ü÷@.ª œº/M:õeè=½‰÷7œ)(«§<î®sŸè{ÞF‘š²ši3íŒ\ø(mMçí¢Çöw,#$Ð !Ä¿“=›“ŽX’9¾ÿ­”}i¸_Hœ+›Ó¿îà€+•cSÆò5 •S¨úpצtû‰Ã±÷|£qt UÕyñö-å}þlVµ|ž~u›1tÖÛ ÅIú¡d cñÛþ w¯KàµÉ}ðß9‡!†1å…öXóƒií]þy;—³xóa£~6Ÿ¿º“¼v=Öƒ‰+ï©Ö ÷óßÝ6âzGpzëfr¼ЦM>m_âo¸ƒøŠµ°ñè*RœZ¤qbù³<±âäÙ`­Ú±:&Þµ©z¯¾!Œ[¦LçžF•bªnåèÚ7™úÞÜZ÷ W׊o¤áÐGèn<Äë^å‘oÚ1òÙat;s¹4uëË|:P§r¬ž½†gGmãš¹ÏÓ¯^Õµ ¦³Û£xÓ´ÇÍ4ýÝm¾(ÚwïAñy:ƒ)ëxkM&]ç‰xZ{ö¤âåôäÛU'ª…IkÆRbåÓ Ýñºä­Ò(Üÿ9Óg|IAçÑLnbþwFñZè¡wýŒIS6tד|ðJB= 8òöóÍüW˜21‹§^º«|ÐÕ‰¦è^¯Ñ„AQ1 sæ× ѽyò †³¯]´qù;–è…â_I³¤°õûmdªR6ìâX©FÊ‚bÚµkHÑOFŽf ´ßDfÜ‹·¢rä½Ç™mÍK#1Îä®=¿oñ÷¼0ì{ÚÌT)p*˜Ìgçš¾–Y“6ÐrÊ4Ú>OÔÍ(®ûW³àãt7‰¡ñÞ((xÔkD«xy»Žàlàͱի8 GÑÉ/›Ýß®ç»ÌPzDf“æEwÛvo:ÄY™Ñ: ŸóukE©sþì` ¢÷Ó,èî*ÿÂMsxbss^|öB+gjçNæúg•7spôó—÷ƒ_œÏ€¦>JþËž·CˆmOûº-iŸx=‰ïMaÊ‹K¨óꃴ*o (;W-åû´J}ô¥'Iwfñã²E¤yTÊS‘ݸïæøÔÒgDñŽ¢}¨óÔ-—oXˆw÷'è^·æ@¯elb}rsî?‘>uÏmö¸Ø·póݹÔH®[O²éã·xk]WÝ?… ×7Äó_:$ãz-“Õ‹¿Æ5pÏ÷ Æ^’ÍébP a\ûÄK8žÎ;_uaîÆ˜*Öuá@ö×*qïú\Õœ¥N´KÝäß³Œ@/„ÿF†Àö }<žƒË§1ýD‚ím§0°Oô=Å´‘vÒv¿Ïú>“PÏIVfm‚Ê{ UÂy5~u t/¢ Ä„[x IڑйŸÛí úýÄ«›t}¶)&À è¨Ûq8/;góÔ´Ôyy<ýë›ñŠjÇu¾ÿì{JÛ aPs“»3è‘[?‰ŸõeDÇÍl_Ó‚‡½ß ÙýæE á8IrªŠÕN®Ö–óì–É'àŠ¤¬auÙ0EÒ(4¸j€.õÅM1`¨4Õ“_3w¹ƒþ/=Ï-ÜÊ^ËJ'Ë-„P¿òüi=t4wzŠ%ënb怰²Z+nÔkÜŠ6Ag“^¤±o‹…Èæ ´ñ;»"% ·3ÿëü™9Ãæ³õrnvkÏè·FÐñ¢ [#oË»,IjÎ%ÔÜ»®±õãUäw}ŒNÆ",ZÞUj«’Ÿ[ŒÿEǵk–4v|û}ñù171âÕÛèá~4t .g̾košCêM/óBŸàü,ZÖN~:Ö„›ÆÖÅfuT4fu͉­Äƒn7]ÅÛ‹·sôŽÆÄ– ­$‰Uó¿bÍž JLA´ºáî× ÿ KMZγK]Ü>aÍŒà8¸œ)Ÿ›¹{ìšVœœìÿä¾ô¼‡±7GÁ9Ë”ý]¥²é“e|±ý(y#þ ®¢ÏC¸±‰7Š–Áš×>ÀÚë¼·-cÕÎT • ZÝt?öm‚·ŒÃ—@/„ÿTºí$Þ~•ÅiWóÌh>{¾ÏôãÄ[ßóŇûIï4„þÇWrò”éMõ£a¯ŠðåÚ»ˆá3 ¸Z7½‘Æ· #®n>dzÐÔ³êi¬žñËéÏ ýœ|ðÒbNu~’QÚW¼09 5ïvŸ¦ø(F‚z<Æ„ŒçxvúÇ4™qÍ+õF£¸„Y)¬Ø’ˆ&õ1‡ýœòó³ïßÉ“?>'ösÀÚ—ŸK¹ú;I?•C@X(ÕŒŠŠSÅ0‡6l$§ãƒ ,óeùäÙa͈¬ÜÞ1„‘س1KüÂþaÔQó8ž”E Ô ¨¼ï˜^þu¨Så.Ö|Ž´Þ$Š@S÷O›ÁÕ‚ëaÞ÷¥wÏä? ç^–Ý ¸„+µëÔZf¾}€æͤWÝšÇÎçüøoìã¡YQìœ÷(óSc¹¡ÿn¹6w@M'%U#²]DãçuG>)ûvñãæM|·5Í߃::.ö~±Š†ÿ÷ïNˆÂ˜ñsÆÏæU÷yþ† œí¡×+õÐkŽBNž´SªéèpkGðñ…l9rMâÊ?lÎClÙ”Cä“ 0è:®s–AËcÓë/ó±ç}¼´hq>¥Ûð:ÏN{×äñô vR”¶• Jè|ÿÞ~:Ñ¥<ñäÛ|ÙbCÊ$‹è…âŸÊ™Ãiß¾L™Ô–‚o—Ólè@Zø5¡ÛS¡ì\ö9‰7ôÅJ–$eâŠ8Ⱦ‚D=›šßÅìù·¡ë'>›Èø´›ywTÜP0zØy6ŸÈ@íS5°™ê×óA¦¶ê@HÊç¨ ƒém]Å{'oæÖ›csõáÞ†ÍÊgDñ éíO2©¹“h÷ª£0i< ÑôR’¿™ËòßšóЃ!˜ #¨—´Œ'G}#‡\óHElY»ßë‡síþ·Ø²ËBn>Ÿ EMãÈQ EV £ºË3ngB§–ϑÅÄõi^©'ÛEJÒqŠ Ò¿Ï‰p³Û«ë`Цߍ¡tòwÇ?8-ß6Æ«mGù(à:—Ñþõ 6ã<½›ï’ëÐóš¨Kú¢åýÌü)KÉëþ Ó»×­±'[ËXËŒ·NÒyÌdº×õC;°ÿ®bÅç¯ðà'‘$¸ƒ;NðKVCº5¯\oœŸ–0û³$ÏFŽ£}×DF¿ö,Í2ßcèËÖKl¬Z°=ñºÐi™¬›ýG-f\'706ãÞé¯áò«÷¯˜c[u”âò ÆM…šZTš›^Ø(­hh8pÃÛùcÍ˯6ü羫¸ûƒI½î¢ÎS4CÙ¿3³Þ˜ZÐë¯íLáÞ¸&ç‘üâÖ• ÐôjËhé[X¹/–ÞíF°#—Ó9:þ‡aÛàõIô¾ÓÐ~OòD·:Øòr!´×Å~Â)%è ýNz ôBñ¤[@–ncëÚ#øu5£fm)¿ ×£—™ØÖÍÈ^õ+Ý·“Úì:ZUîŽ6yàëë¨x»QLžøùùáVÌ¢…’µ/™"=†:•¯¦Š'1:•ÅÚÐüÍcÑ^;á- +DSöcns­Êþ·4}7ß}¿_ò H[ùuûD@éQÖo¢ÿ³’´”i) L]ô*…ENœI+xîËó×À~ð –íoÂmÃ;Ð6d=Ÿ®þžÌ.ý»H¢ÓNíbÇé†ôŠ÷®t»R<𬨕K©þ~nUÂäþƒÅ4½9¦úÌ2öRîxŠ{~®|ÎPÍÂñWðæâ4â?ψð5<ýEML#è%ûX<ù}´;î¤S¥^{-ó-ø•^ :”úsfåë{(‰šÌ­žkÆ•½/ÌbuF(·^Óø¼S B{2fú5Ô +R溴¸n(-z âø¶oXöɆ¿oÅÔòaºVãdÀ'¼%½wæÑ¸FDøž ®ÌKÿlkyú×!àB3zZŽpàTñg©Š;ááWÎßïì¡7zxb´Û°é5ßxªÛ¬ØðÀÓíLÏ»:¾Šmβcê²Ap4aYÉd¸t˜9;l§Ò{V{MWˆëÚuÞ’7&ÖèäðŽÝxõGMCÓ«/ãy?gP¤7ÅLT¸7%ÖòT8<½Jí¥hº¯<©–I=…âï£õ£‚(Ù÷޶}é“E¤v„µ›ÒñªJ€IÁûª®´Mÿœ©+NѦg»Ë˜Ú@x³8|“ö²¯üAQšz¶›Y->Îæe¯ðÈK8ÑŽîÉã÷ âŽA·–ý»¹Y{ÙWâA@EÆÔ(IÚÎϧÁÃ=ëïDƒ’l U/â:¶€ýëørÝ~üï:V}·í;w±óðiìE‡Ùv0¿ú ¼¶ƒ,}c=^î¥W]#AÝÐ-÷+Þß^È…£’“þ'­qg®©aªF½¸ˆb¼ñ«0w)Eö³óô.¶§5¡mK¯s.RÃ\¿AÅœíº-‹½–2yÔ0™¾óÓ™:¤ º ¦¿q o¬L¥4g'o?7“Cûssœ{Õm]»ž´–‰t ¬ùlnÔŸá= ùtÉäœ÷.g’Ã+™òÌ\öÇ=‹†ðÔI¼»§°æ£BÂj˜ýÇ›†×ÜÆÈû»b §ïDÎ-¡Gëéyul•0y42ŽÇVŸó·O4Nÿ°‘½¡íhúïŒ&ƈ(êžàDQͽ4õ8uP¿Òôsš®£è:Êeµ-thÔ™nú.~>¦‚ó(ÛwùxMØyo€ÕŨPõSGS (š^±œ¦©U~®+È,9è…â~B®K§h+Dzc0ôVnHl…r*“°‡0øÚöÄø(àOÇxù†ŽÜØÎû²¾¶6Ŷçj·½lþÕ‚Ž‹]o<ÆØUhÎC¼;~_Ä3bæLiëNÒÊ·Y²5߆M¨ïžÎ†%°3ä.¦ŽïKÓÙKHP÷aLÙxo]-¥ÄMÏëâð,)¢¨(—c'speäX~EEE”x5§wbc<ìç„-—ÍoÎe×mŒUöõ±gK†Ü݄݋–ðSÁùS€–±ž÷ÖÙè2 5eA5ç4ù¾AVÌ<@óæAÜö+EzYÈNZ»ž“-{Ðùœ­çoã³ïítìÒ 3`ýe!Þ?†¹›-Ĺ—žuÍú•]LMQ ÙmÅs<0z>‡gƨÎ+ïæ&>Ü Ñk`§ªß’TÐÄLËC+øü°³†*`ßç¯0òù•è}Ÿgæˆtè÷4¯<Êæ©“xû—.ýa¹N2¶.bì´ÍÞ5š{š¹×þ[Kgë¶4¢[5ç|·C8O­cÞ²TÚ ¼Ž‡@Åaµ`siWÄßoYïõïÿG½ötJbã¦tÔs®f³å»=tîDLùT•::6[)Z¥ßs¤§’U/œPS¥÷E/Ÿåæü¯izÝ»ر3[òN~©Ó.Á®ó.c '(;•SöÊïë"#5Ïðü”òi]«­·vj¥K« úù]J „EÅ^´lçÆº 󭯉œ¢xÆŒjX~²¶sâÛy¼ý[0±>[Y²"‘—7å¼&uYÈHÚEòþýìÞgçê‘CéÝÓgVoât‡v¤¦àÞ܃9Œg/À`,ORõbÖ¬xÞziÃÖ¹ãnƒÆwŽãõÛšáwn CÈÕÜq]§³AqËLü>Ž®ñ¹¤;ãxdh{‚jºê¸²ùé)Ì>ØœÑSûm>Û`¨ÛõaFü2–ÙÓVPï¹A4=wgmÉ|2çCN$ü‡';Ôô€ÉûPVyØŽ‘˜Þˆµ˜Ù+}¹5`ó×¹é…ΕB¶ŽíÔVÏ|ƒýñÙ›P6^dzù@¦¼1”°:f×>æ¿¥•ÖfŽÀÄ1y<;ó‚‚ýq¯¼Az!?-YFr«ûÓüÂÁY èÄ}>gÜŠÍ šÐ“²õªÞÈï,å{kk†NšI¿8¿ŠVEôÅ+¦yŒ1 žzÿ´õ?¯ËBêÞ-¬Yù%«˜éòÐF\E­ÇyÝFò—ï°"« &†VÛÝUHò–/y{ñò:az×:g¡ë7üg Ço™Ç¬[Âþù=Z}†`ãĹ¼î;œûºÇàgÍzŠ­Ÿ¾É™]ÿt4èΊÏö¡Õ+ø±Åýt uƒÒ¬ùz'õ§¥Àe5ƒtÈ.Ýp›¾uö=uïO zþ÷P¢ºsCÈx¾\“BóÑx*`OûŽÏ~ôàú‰Í0‘*§s ôBñoe n|w®·kX2RùÅ=^aIÌ9Ž´'ÿCÈ xs»/w<÷üaöÄ—g}”ñCÛlÒÈ=´™Ÿö§‘zò$I¿e`Ïy—g2Ó¢E+Ú\ß…VÞfüûÝÆUÿ·„¹KR(J©O÷¸òo4Ù驤MæÐÁ}üúË>ÒÌñô¾%ÿS;ùî«Wxú@:´M e³¦4nB€{åˆeÄd, òyÉ?³ö‹å|ÁÝÏOä¦ÈlÖ¿>ƒÇŸÜÊÍwÜÌõí¢ (íŽÌ,{}_æµcôäat=w†C ]GöÔ÷l£žº‡neáZ/>ÈGÓ¦²Âq#/ŒìV>$F§äÀz¾:`ÇÏד-‰µërh|{•;ß u36—é¯Mg¢=‚ßæîØò1õ΃|øÜV.%êÚaL{¸kÅÇø¶,IDATpų.កîÂZX„UuqzÏz>;œIêÉã=a§ý˜)̘ÂìWÇ3ü§ë¸÷ž$6 Àä*ÆY÷ZFöëL â¤ 3‹ÁŒ›3‹üR3¾nJ•ËsLïÛéµð4§íèŽýK3e1GñÆÀ¶„˜«_ÒCºäeuOϘNÈ«“qv§µ´YºúWN¦¦p$é8è8ˆ—Gv§yàŸ´\~xm"³~ö£ÿ3cèqÎWZÎ:&ܵ ‡gczÝ1‰ 7Å]°Áø·ÏãÚý&ÁÞ`0³^òãµy3¶DÅÛÇ€µD%¸MžõvšŠ)ÕMÜéÔ;ƒ ƱÜá‰V©íp¦ôÆUZúÏ }Ñ5 íÌ ­5¼ w¤»ÛÓ|¸9–aƒ|pUÚŸjËhõ8áqò¦ÎbÄý ö¶‘ïMÇaÏqOCÒÒŠ17•ꢕõ¬ëZ-ÔJTkdeffÔø½Å®];iÓ¦TH!.â÷œ/kZFÏÝȤÇ’Ñ–ëûÞÂÀn1ø4¬éiÛùów7áá·Ò¦nÙ­`Ÿ¾¶”¼~“xô*7Nn|—ÏyITTCb¢#ò¬v‹'y;ÞeÂÌo)îð8sïL v·™Ä:5”†šÒ¼yL²ãÒ xwäѥ˅îÕ,Y=ðó1^dœdMÇ7&ªÊ-s;Ë¿;…gh$1MbiéÛ˜jDMYìånÓŸØÛ9ûwÚ–øºUA;½›Õ?çÐ0–Vq‘ø™®üs@“&±µÓ¬w÷%ÀßÅ–Gn±†W`]|…Å”ªzEÚ§^(î¥h8rs°xÖ#ØÝF~¾¥bŠXŽ¡ ù™y”^àµ2f|ƒƒñ59(Êʦ¤Òð÷ßÇä‰?”’,N[Ý©êRœOÕ‰Ž¿`LEéäÙάDÁ30GÙ%®?\§¤¤Ãÿºœz¡kz!„ø›zpbµ)xyÖ”nt¨Å‰Þt— Íd*ŸÑEGUuŒÆKïÕ5 °å‘šYˆêLƒz 9:þõ¼/øõ¯«$‡"c]=v;&w÷KN¡ã°»ps7ÿ¥Ç[³[°<ñ6_b½\N\&³|%þ?4nÜ´VßS11Ên^¿ðÓY F#Š®¢þq=³ªKå¹öää#è+‘ó‹Büm˜ñò<ÿE»V/Âa¾ì½ÆË{åÌ#?=iXñzÝz_ÖäÄ™%ÜÜ/gÔ¶ò—‡yƒ»7Þ—³€„ù…Ú¾QSW]h—ôL-õ/¼qøÒ·Sü™ä#„Bñ‡½Œ è…B!®à@/S) ôB!„W,M“@/$Ð !„B\±¤‡^H B!„¸¢½Œ¡è…B!®à@/=ôB½B!ÄÉl6ãr¹0RŒÿUua6»I!$Ð !„BÔŽÀÀ ÒÓÓ ÁÃÃ] ò'*-µ“““EXX¤C½B!Dí #''›½{wa³Ù¤ "OO/6Œ&,,LŠ!^!„¢v Z“ÐZŠ!þšÏ ”@!„B ôB!„B ôB!„BˆËqÁ1ô»ví” !ÄŸDαB!jƒ’™™!OBB!„â %Cn„B!„@/„B!„@/„B!„@/„B!„z!„B!„z!„B!„z!„B!„z!„B!$Ð !„B!þ&þÅ5ØÜcÙå(IEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/datamath.png0000644000175000017500000012372613070106167016702 00000000000000‰PNG  IHDR$`‹Òb—sRGB®ÎébKGDÿÿÿ ½§“ pHYs  šœ IDATxÚìexTG€ßÝ»'!!àî®Å‹·)R\‹–"E )ÅÝ‹ûð@q)ÒâP¬+E<âÉú~?6Ùd“ kÌût™¤U©µ_ H×IB' Ãb± P(Ò• ùLÝh4¢×ëñôôäö½BBu¸ºyàé鉷·7 …‚„gM‚Hd²Äÿ Ò*÷DFBCC #:*_ óø|:ù"ýÒh4é²ï¥w™¼¬ýAº6Hnݺ…F£ÁÓÓŸÂ ð*³µ¤m}úô)aaaÄÆÆròÂS ,„R©D¡P`6›‘Ëå­úÌ‹Å&W£ÑˆÁ`àòåËT¯à÷AèdZô,5ýÊ›7/·oßþhúÞÛèsºLÒ*ƒµ_x]é Û>$qqq œmƒ­Õ ³ë`ó ˜ÐN£Ñˆ\.G.—c2™0M¶›Ùl¶ýÉåb_¹·EÒx¹\n›!¾ŠN&¤ÞÆ€õ6Ë{‘~ݽ{7]ö½ô.“µ?((___ñ`¤/ƒ$a’Ë—/ãçç‡$IÄÆÆr÷îÝÍ ð*3ªc›`lH’„››ð”¤ûµ$$’$9,Ïl|ÊÎí{iøeû—n…kŒ»È¶½q4kZÑv,ìÂúU§ˆ¯óËÛeŽeӆʹlÝÞîøŸG#{¥êx)^ÍhÚ±iewÂOa$Ô¤Ä[ùî.‹Å‚Éd²=“âææ–f|]"5ÝxÕò^¦c©é×åË—)Z´è¿Þ÷Þu¿{“>÷oËä]Éâezó¢öçÌ™SŒP‚ôe$üçùóçäÎûµ¼Ágop1Ì€ÉËŸ&e<^«Ó&ìññ.gà .ß×™©'š™Íf «Ø$IJñ&€Aÿ€S†ñE‹.¼l<7>ÿƒe+BhÕ²jB ˜ù}7ìO}_dr Ÿ6kŸÂ0ˆøgÃú3JM~Z0“6íZѽ~Uzo9I)g3#‡u`Ò¡`|^-@nóüqHõ:`ù­3ßî*Bà²1¨´A²Ÿ«–Ê”NƒÑäˆØ¿sÅ©"å¼4¶Ya‚.$ÕƒWõL% ,wÏÜ&¢HJ8Ko¤I¿— „iÑãÔôë¿ðÀ½ë~÷¦}.­2±Xc‘Âo=!Ò×›ì®RZ%Ö *¬²ˆz!£^Š·#ƒ—É7µö éÖ ^É ”õw³0¦C&.¯ü çª5ßYeÚ§LYyá=ª½0.â!7̾õ|ù)îÙcn¨|(î&½p¦®P(ì^E”Ë嘡Œ9Ô‡ä9ãGõrè!2ižñž ³F(l¡ð¿Gò‡T‡¹}11}Ú,Š7ïLVÊ® eV<8U‘ÓÚ3€Œ¨‹Cx’½•¼ÝÑ>[K¬”™ Þî¯ü±"_•Ä3™’‚mi°½7´ciç¢öíÓßgXç¡´Ü|FÕI_0ü÷`òu dZË|)å¡»M«¦_¢3[X¼ã<¾J <ôüض/kv.ÇK’Ùbsl²ÿj:ykëýk;×µ_= j[{ûðunÊO%gUŠú裞²áŒ™öŸ&ºÄw¼†)‰ÁQ÷ÓÂ8Ëß\ÇÒª_¯Û÷Þ&ûVDýE9jx*ÞZÿz2±˜MoÁ¯WR°Ã\òæËÄãß—ãUî;øç,þ%+“E%a6>eûî|Y¿ ÛæXŽÝÎC­:*ö¸IyÏ­`ФEòv׿íYÕçmç™ÁäP~‹…ó»Ö±ÝÛ™\M;Ey»BhÒ¸®-Íé¿äÉ«©æíïå¹O˜äƉÙÈÛ¦0‚‚¶öãAŒ/ÚГ W PH¸fþ’IÕÇóíì³lRÉnÖžØú"Ì߸?g–jeó×\¶ý¾m$jÇ9æ'1Rº´¯Œ»$µ’»¿íg:5V/‹uŸ“3€ÅÄúÝ—©\»©¸·騂àlÌü®P =N«~½ŠîE裃øåp¸Ãsî9óÒ ˆ‹Ã~gÔ…²âÂ=¦´«ŠR){åþ•£N-†UqOQ¶IÁw㡳X7ª Þ’ìd"—[3t+¡îÄ=zJ±¦U™ØÁŸ¬.J°Xغô8š‚Ùˆ¼Ä“ŽC8¹•ã½%*m±&93y|ô$ºÆ÷¹ßHÇÞgÙ°~ ¾*ëCùìmÜŒ38öBYàÑ™s\Ï™ðpý …“6ñ|Ü_ bö©Röƒ]Ö1x„´bÁÍ0úäõ´;·`ÆÊ?œ#ƒNÚ/Ñ2w+·ãnßëäÔ8ž•;ÒImÄu¾|Ñ.]ÆB•iS­í÷ñîq¿l>êy%꘧³Jh4Ù?þ3úÚÉ¿¯ø®œíšU°d±÷Y¿û2djrk¤4ëXÈs“C½ÔhÒ¦_ŽÚi2„ÓüÁ—ö‹ŒùK2¾½Õ3%Óˈvpoµ¡Alþý9Mç6pXÆ?{ÿÀ"“˜?cw¢®ÉÀ€ïj’+Éš£¶GJj.l»€ªv½Æèý?þà±Î]Äc* ¥ìd0q–u0µÿÏÿ$/y=˜ ‘,»‹÷]Y>·Þ’Œãÿ äIÝúÔò¶ÖÕ¨{ƲsOlu{¨3s×9îÄže;צ‰§¥ Œ3q:3È$<ÝÕ¯ßþ£^»ýâ;c‚t½dãÐ Ì[Ð=UïÅå¥ë™©sÆÝ+1–@!ɑԾüücm‡y~±.~¦l½|ÔS-n>þÜG`®JŒ,c ïì¿Hh™"”‹_Ì5K’íAåp0Õ…2ñhcçgF¡°¦•d WºQ(oâvä•Êå#¸×2VüE…/½)Þ¢2÷¿=À£æíÈÿpJ>S¿M¬ËQC+F9Éèsø ûÛ/×:Kê5¤Ÿl=³{׉ØçeȈ©Ä>žÅÎc!ôë]†Moã¦xİãØ³õcÇ̢㎕ 9“GÖ“0_’+ýèÒ}'—u`G™Aðh"·m£lû¡tiêO« ÷ȶ° ¹rû¦½Ž“Osrå.`«O÷ ËRmË™o 3%×7|?¨´ÃóOO`ðîIIW{cÒ'1´a.†ŒÞAŸ5‰^£è{ÓÙåÉÎ2®IV–ʽ6M2Ä0ûÂfVòwx=G:éêU?ä·· Jîÿy“;:ëÃ<ÆlA¥ã¹d}ª]³â¤LÔ…GVfŒ®MLæ (‰º®ÕÞ³Ð5èYj:†Lžª^¦E¿µS’{УuåÔ=†f=sæ ¶´»íÚ ¯ÂôëT8EÚ-£–s«Z‡u4™¸'Œ’?Áø°è2q7’¢ŠøåÅÔÚîêS÷ð½¬yb¤³¿½Q¶fs%Û–ãôÂÇH …MÖ¯+³QË…«¡<7Z¾ñˆ Î7wþÎÓ<å[ì }†ï¥}M«oeæç1ÙQH²øç’7»VÇ`´>Ë6ßH†–•©ån݈íêœ4z‡ÅdFµ`ÉM±>0¶ŸÆ¥xAÊÙUÓÂþ+aÔ)♢Üg×Naô(FQ'é…KB2¹’|j‰3õV×°Kv¸Xv#–1…]S]RJúïÀeç¤Ï¿ß—û¾åÔì\ÎÖƒù™4ìÙ»“‡†"+&Gãù ‹wm¢C½/äzŒé‹Ù•  ñjΆ=éR! Á{#óï€L&C)—±ûà.nkøÅ_Û{Ž1ÝÛq%CÖNoÇ'»°rÛtab  K/ «’•g'ƒÈX¡ i1EpëÖý”m”«ñýÔ°À'©Æ.\[|‰LU‡Û—Æ…ûõåYµ\kCAg«7ëÔ‹ñ­: O醨_Á—a?]FöIÖ²N}}O"xýN&\޶ôc[Œ¡‘<Œµ ~5Jà§‹áaü„ØIŸòû8nYóâ–L7žý‚Ò]âòùh¨çõJ:–iÑ/‡Í”+)W<{êÆãšÄx`Ysÿ–cˆ fqŽÑC2:Ôëóv ª\Ÿ/‹'–óô ÷BäNâI­í&½Œo*ºóãò;tY(I8«aE~%§ß’LÌÆhö¾†Å¬ãÏX1'þæ©RNëþ­ií¬KÚ__ÃÏ¿û°pb5ë]½1ýF¯5 dRñ4Æ„bãq.)àÒXö,íH-`ÍÀ¥˜‡Ek—õ;úfí{»í>jƒ$é:eÂ@àMR̆HöGžË9Åõ¢| ƒøkiÜóSAsˆ¹×bQ¢*–yk8[‘²ÎŽF™˜ë¥JV [æoäYóйyEjp³•zkG(‹—³¿®,±F Ç#‚®²?ÒHùª¶c5 ;3a{ò¢îv[š'oCÒºXL1„ ²bÇPNÿœ…G,\]™¥G0^ÝCP†:tieÑøÔbÅŽ<ðHôT˜µÏ¸zẈ“tl¸•¼S°qÍ]F-žÀ÷£Ç±ýÂqîéLøÙ\é…)Þh?¶¬IЦNøVéŠä”‹^Ó~ãÒÄJœØÎ­™CКraG¹†g³kƒ>ê(#‡M°z0n^â™OArx(‘«üY4¹4Ñ3¶Ÿ96HÇ’á«”›ÅhÆÉ§ Í}†1nÍuÖt+ŠYw‹N< ûþêX,W–çUÆ›Ø%—É8|E25,Ô±1+,Ios¿º¸Ù%•Õ5ùSd2O,f;»n;ž½R!J8'îÜùœF}бsÞydõë¤('u{ñ+£/Ó¯—õ=½TIŠ ¾È˜C±ŒšU üůû—!S™Z|â–rþñמ},¹éƲÙ9ìêÿà`¾åkÚK­í¦83ùš• ¬ßQnê ’/>nçüªËø«Ny˜CCóud¢rÎÄè¾õyvíÇÎAõöµi•Éê­{rë+׿¶Wa:äb˜ _)™>A†|…iWÓ“#ówâÒ 4eœe v4ñù`´C!a±Éä¶ã¯Õþ¢¯ß~C"HwIÒuÊäæeÉÍ¿¢ñ-C5wEŠN²—¾Ÿp¾SƒŒÌü#©x6fkE.W±OÎ`Ôø‘S-%«œ…sÛ±nÅA&Ž_ÍŽ*åø®cY²iäÜxnÄãS§dÆ‘ Cô殊Áb0úŒ3Wž’§\%F–p³OžùˆÛõ ™,§Ã::’LáA‡Ñ3Á¢ã†S~Ùó9ó—ç°²1Ýš¢ ðd×RV¹ët¥ZŽú$,4Ć, zõ‘øÊŒ¤.¨«ÈëãÄí\ùºaSåJääì_A lÛ®C§²œf}!0oÖþüß6¼ödÞ¬±Öz¹|ɬÖU9¸ë1Ã÷ãÜ3ëKûÚÕ]ãù~ù€ƒ üù_Ÿ,ÿñ7y‹æ§¤‹Uõ·ØãÆÖ•øÇ¸˜ ÷ªÑ*»½ >5{™¾¿Ž~%üûè_ùî ? þI†6,ˆãNѤwk*y¼8ˆüéţ̾h`Ö”;F?:ÏÐ-aŒ›Ö?U¢'ÄlŠcÞïQt›ác—'µ¶[LàäY”Ï3göÁpæ7̈Ùά+Ñ´›–xæ°o"“«‚ðTÈøß˜äŸÐmàfÜRÓ¦i:©ïÐvúuJE9#¹Ò•o»WÁS!C†Œ¸gOùëZ, fœþy„Rm_þ3“…RJ9r‹‹,ÑXý·Û/bHé »µI’l›ó$ü%ÿðg1<#`{u¾)íà¼Y|yŽþd€,Éï¼[0¿{$I"_ÑL($‰Kk¯áWõûºHr@†R“=›±fħX®^ `ÕC$Iâ¾ÁŒ“¯Ú> «É”Ñ,~>T­QŽSºóÓ€r(“¤sñUbÒG8lûKe£p¦~‹2Ìýª»¹Ñ®U)4NÎhœœ1<ØÃ¬™óÓšíòºeîÁ¯>câ(4ùÈïcbÈ€dÊ›Ÿ!:0t`Oôº0† èÀ8î•›³zqUkFRy'oAÜCáföÞt([È_Ø|RFž|ÅñP)¨?g‡~Ž¢ðT²9©R½r™ ™<ñ·R‰ž9œ™¼=Èaú,* ý3CJˬ²ÈZï'2ÄfÅ£¶Í9O™‘#l: OVžñ¹I•í•å^¼çW.øÚöWÖM…¤t§[«Êüyþ6Í›BÅçx^²$]›—dÖö©\Ô­6ƒºÕ¦¬³¹\²½r¹fúïäiT•Š¡³³jòA¢±¿vª:†ÌVŽ#¹½‰~ù•«NUÓ?týñ0£ž0ìû=äiÕ‚Þ½R½¯’$aŠ}Ì÷s.á„“E¥8ïî_–EÓ¾¢bFûöïÛCx±:TöP¥­í2«lÛtÈÊíÇIOþ8ŒÁµ-2©‘¤„˜˜·#]Ø?lЦ¬‹DËV>Œˆ²ågl™ú%5=ŸÒgþ†oF熥©[ÀÈÙ[FÜU kr”jÜ\5hd24®Ü\5¶û'Ir.Æš)á¢D†¹¤yýö»~£ö éÎC’Ük!—Ë­¯¾ÅwФ¯Ü%®ãƲhÊvÌ9KÓ¿`ʽ.ñ†CjA~2@.%µZ,’Ý+oúØûÌø+–‘KýmÁc¦øX–„|ÙJ”dþ¼ü<6;¡PÈȬ”q=Ò>èU’ËPºd§}Ór/ŒM0F™‘+Ülí6™LVoD|Ä{j²Aw“uó§òsàŸ´º…9÷0ê—ÓLž»‚OWñÕ´›ŒÜô'-‹û¤}f%ÄÆÈA&G©ò [ÏÁ¶³ON àØõ,œ}’‡E£¿L\bpÑ Vä¢qgÚŒîAýE}hZ%‹–âÓñýhRƺ·†KÆòdWÆ¥ Æ,)ìÜývFh‚qˆŽ ¿ÏóϽl4žÚš9]†Ûv'î “FO¡GÀ <r »«9õO”½Œe2À€ˆ";ãëæ$`ÌlBC\9ôy y¼NXïMÒ{s-•gñW–ûâË8`RX߈ˆÕRpð—|Ó¦4 ®Ý'£FÉg„šä(œÝ·v }”É@&Yª »vš‰u_fF¡‘³f#>ß¹ˆ>óϳ¬Ûž$©éXBPkj½®~YeêNÿÑÑL\EÇ>W(Ô°1c>÷{aÇÖEÞgð ­¸ÖiÀüjÚX‡ÖКµ÷^±X,äõ‘ìêr“€_¢öS>»ûô¶Çß{ÿ uñ˜¿˜ÏÍDo~B‰Žu¬÷;þÞ' ê|m™˜Œ,™x˜Š=:œKø•¯Éô˜cäðtãÄîCL¼kþ2T/žµþßÍxÂÀ)qŽhö.P™~ëþ5J™ µ§;¾.cûÖD’$ 17ˆSf&£FIl¬Ir²µ÷ÕÛ_טûšíÒA’Z IjVºÙÍÌÑ«Ùû4#ógWKuã-“1šu;Î:<j²c'áh±X0c˜5z~õR. »lÊζ؊¼Î ÎéÀÁ‹ I_­sDlµ»]»“Æ4ØË&±ÕIÎ}å'l:±o…¨Nv¿Î4®ã-5&\¤m)Ÿ—ß ™‚¢Å­û†˜âþfn§KŒÚ{—Ë_`î®ÂÌÚÜÞ ùzDë&T§–ÜŸ'÷ r¦T&kLQŒoV§‹øäÚp÷ó pf\âgj¯œäê­ëܺy“!Ñ\ú¡e‡ÈSò*ÕFÝs¨çâIçi‡ØØ/3+WO¡W€ÕX*Ö)–ƒ¡eRmJÙQƒyT¾'ÙíÆ÷%[Õž:xŸ<ýKÙË4U¹'Þ]œž¾Ó»RÃMÁÙñKØ ¹Ó¬^ôÑw4>vz)“)Éåç9¹K0žkaÄžç|?­#> †LAŸqéÓg3&i^â¥:–t}3ýr”-©é9¼#asæöc –<¤¶]Hä½Û ½ƒ˜²5YÞ± r`Å­Æ­!VÛ’€Ï³Ú®™t¯]Ä=úÞC½(ã ï½¨íÖ¾èÊÐrLYv–°0›*y"A|ËëÈ$öéiPˆ]ÅÝø1>O©¦5ùgËZÖÝÏÉÏ‹{q}Óf¾F9ímüÛµ¤®wâ²Ö­MgÙtÏúû­ ÅÁ? Ž¿çËääéæSø”²n¼hÒ†"Sz¾vû7VðHaÔ½JûE ‰ Ý$I×)“»KX2™ ,&Nî?Éüµ§xæEóRÀÅqgS(åXÌ:.ýýÐqG4[”ŠÅ<¾Ë¸IÛ¸á÷ ›ºL1x˜ãg&©mŒVìs/ælŒ²câ È’¸ÝSãì™(rµö·Ír•¤û$ÊÆ:»–$92u~F Éϳ K>{„C¿ngï¯ç©Ón<‚X3½"Õ–¡bùJ.Z‚<¹òPü“*x+儆E¡4<·.C)ÁbŠæÒÁÕL=ŸhîŸ/·Ÿg|çZTþtÝ»õ yÛdVJ ÌÈ'µpýÏß¹|NEÝ|©V«W cNÖüéý ¿MêŒdú‚ ­JòéçÇøiËZÊ{¨¹5g‹#2R°pqê,£ñ²”(šß΋2q×Zj—o@‡Ë¾¸ç·“õdÎ&ƒˆÓ‡ç|k36\³ä"g¬ ·Å#[&}ÿŸv5mÇTNÞäÎS'5¶c&Ým~~¤efƒœ(Ö-À-ù 䞨“r@¡P¢T*ä WXõéΉ?ðÈý J¥Òz\²np0b9£W ¤Hü.^àh4XÖç³*~Œ«Û„ZÉ^ÙTfÈŹ-ØâmÓ¹ÔtÌlçÄù»öÞ'…+UÊdy ýJÖ÷kÄ÷“›ÑîëõôÝ‹¥ís¤ð\n[û+³·ýCÙ/ê² cI›Ñâ[²k‡h9aZ} ¦´Ìc·T{ûÌYÆÎ=Lö¶méYÖëÕú—,±/—ùº"!]öâ_¥Y4JÛó ¡ß&Ýtíud’Á¿ 3'šQ+Èe Åo`Vä«üæòIIœöîFÞ¾5#êÙ{’ŠuiÄ ³õ:+û.ÀcÀ—4Ô¹÷àÆ8f £Õ¼œ(•JtO¢P9ç{é½O­ý~Nª7j¿ˆ!ˆ%›øuð„Y%p{×z†¬¦Y³FôiZ0Õ%µKVšîÎà®åž_µt9]”v®â§í§Åø4mÿã?Ï‹ÂAù ³­Ô¶Xö¯Z‘Øeûxf.g›é:yg [¤‹5î%•½TÌú0Ö=7òcOÛ 7ùþVÙ`û“ɬ[Ä÷iZ›3×ÿF眓ò•ªS¹^_¾›SLNVÑv±ˆ[çãä©c\<µ•}n¬ÞQ¹F~êϯO¢ÉÙpr™žï*fãRöOé>ëOZT²¾î)Wû3zíß|öËt®ØC‡_!—Ã’¯ò3ç¶;MÛôãøŒv¸HÎï¿ÊíY-‰­:™ßGw±Þ#É›€—qíÕ‡ì. är¨½âµ_¢.™?gÏžÿ1d;èöÚ IDATôj¦®êH‚È3~ÉØ²ß2l×V~iÔJþð+[“åoݤÝo×,=ùíDO»cw»âTm15½Ôñ³CP(Àl&™ÜSê¤L;×þÆE•œÇ´ “ñב|·:šq‹òZÓËä„ßxÊm—G<0ÈÉë¬Dމ­+aê®gŒžñ Ï7obàR _|*'ÄÛ7'% IŽÙhB§7¢ÓÐp.{%ʹH©êXf·§,Xý»½Aã’›jåü_A¿÷½¤h¿ô'ú¬Èâõz³ƒNR­Š÷‘Ôiû¢—1î)’“¾5œÊÂÄÛCº‡O+ýȦËG(›ùõ¾@vïÑumÊØsç©ä®F&“Éúg6ƒNgfÓ¦Môïù¹CœÜ~2.]Û>ž§È°©w1¤)uóY7é{rîý–üƒAåDñÊÕýUÀÂì+(<° u²Z ¡Ð[·øõì=‚C¢ˆŒÑ¡3˜0š-Èer$¥„F©dð€/ðˆ_òzU{™~mÚ´é…}ï]ýàogÈG^——_÷uú×»’Éȶ“(;o M<•ýº‘›biÕ¸­êÄSáè+ÜQ¬ÙsߌndòqÇßןøÝ¥µáWùjØu–Ík‚öè>~ØýÜ3ÒwPC»}GþÍö׫WOŒP‚ôeܼyÓpäÈZ¶l‰Z­N5õC@q“–½Ž²he'>kòãKÓŸù¥7í;n⻥Ý(›ìl4ÑétÌ\¸3^6Ö¥•ƒ$=óèÀvgíGׂ¯÷`~þçLVE·¦•ÌIÈÖ?ƒt: 7nd@¯†uÒ 3 ©•v¦—ÁJÙû¥ciѯ7~0}ïUû×»”‰^g@R)­;åbÁŒìÍLq {Ú_­Z51B Ò©Æ|¨¨=ò²dÐ~¤ãü®€—¦¿ušZÃÛ¥x0@âk‡VÙÈ$lIzǿA~ïÒø.Ù±„å0³Ù~yΑN*Õ)㈔²÷OÇÒ®_Fß{Õþõ.e¢²ÓÙ›ûeïWûE ‰ Ý$ö‚ü£X¿ÌTº:-Ó˜6Cž tMíù”d—H¹ÜjŒˆ/„¿[ä¬×¿ß:™VK»~}8}ïUú×Ç(“«ýAº6H©“ðÆ°Ø"àß•·@ Ò¶’ÿý,¤!à_¥] ë[¥v1$më’@ð¯°fÿ5[¼”mÉ&N/ÎÜx"¤#à_!ÎĽl‰¿2‚¬Ysé@ øW¸?°~^Åî[6Z­VHG Á¿F‚bC¢Ñh„d@ ük¤ˆ!IàêÕKB:@ Þ)… ³û­HK"@ ‚·…#ç‡ÃK"à]’`k¼0†DÄ’@ x—$Ø vˆøh‚@ ‚ÿa@ øÏ1$ï{÷íBxê׫/„ "†ä=¤TÉâTªT)ÝËáäÉ“(Pà•ò\¿~]è«@ |€$!Q‘Þ'üüüÒœöáÇB`@ð‘ Á{…02 $"†Dð.hÖ¬ÙKÓlÞ¼9ű¤ú˜V„¾ Á‡Ç{Cb1E³|õ^ºtjžjcìU÷ÄѪY»ãfS8ËWî¢k—¶ï¨r¢¢ ¸¹9' ðéEî›ò‘7³³Ð¦w@R}ˆŠŠ¢W¯^,\¸777‡yD ‰@ |xü'1$czv!Hg C¯˜9´#:· ùüW„1yÚOtéÔœëKš3úAÖ©b—_yŒ 3BS$}(“§ÌNÕ ¿ò+û.?Os=½ŠÖ£NOÛïØÐ-”¯½‘kgòdžöbRÆÙ˜ZNhÓ+ “”XL†WÊc2™èÚµ+ǧk×®¬[·I’„0à#$ÍIÌým4í0“’}—3¥I.ûs¶Ñ¸ýLJ}³Œ©Íò¤È{þøQú® Dº<ž» SPß?’ïFáÀäü6oÇÀy7øf™ÖãÖªÙl|mÍc ÇbŽaâÄñ¶ón9ÚЧµ~±¯pöìýdN§ü²ãM¿l†,YÙþ^Õì ’˜uLþ#„Ê[ò ÍI#‹Õ¦ÖËé‹6ä.gOleúÒXÒwäÈ‘?~€ãÇ3räH&Nœ(„*£A’ÖÉ»Cj,¦÷÷mhTyeÝTÖÞÇðV#sk¨Ïüæµ9óäåpÀMªŽ-Ǧ œóÅÏ´‹£~Á¬aÄȉxä(Á‘™c8®öcä°˜ÏØ´y?ú¨³c£Y¹rJ·äÏqžïÇícÚäáL/Q‹9Žïà»IÓÈæ«²ÕÁ«j/Æ”}ÄÑ#1Ô¨g5"ôQ§øeÇÆŽG¿-Üš™?Q c'Êziìê¯Ó³íXäÜŽ3ò¨E5¶%³fËØñ8¹Ê‡-;&rvÖ`Öþúfw_«WF••€€Q íW•[%F ¡xDW¯þMÓ"ž,[sŒ«W¯²ò^²6*ÅÕ«W¹zõ*Q¦ÄÿöôËmfðºÛëun¼KŒ¦J’úËžlÛ¶ƒ +¾EáTˆmÛv0Èw.kø°°ÔjµÝŸÂ 2E¢ËäùÅ… <‘út«h2¹ms{p{…ý.´a×j”Ó¹b&Ñ@`㕃Z2ÕaÝŸÑ   Ú ‘ø7™ÍÈšY^šÏ·üH2>èΈҌiÚˆ»Æ2,Ù¿êÇ8û×`ùú)Ì\º‹±ƒç²ycR²e“!„iS§"—dà\–ö¦ÓÑ ÷(Hæk˜qÍš®÷¬E”vUÚò5]…y=ÐwÜ`WžÙøŒáûîÓfÇÉj+ÇÇLJXÜÉøøø°&ð]2q@ŸÄT’3sçLÇl0#©ƒ-£ïÿΖ-§)6hŸ¼ÄPûXQ:ÁM!#èF¤Ýq‹9ŽK1òóp˜ïÀi¾FíÚb‰L >ƒäuö!ñÿ|ÅÇ•â÷§fV ©ùÒôÀHVªÁ˜c&&ÏßÊ×-ê²xÑ< ydkàOhµZnïœÎ™ÌãÙ8¢`1ÅpùÏ»è#ÏÓ¹Õ~œ:-fv½lXL‘|Q¡*S, ‚[òAß„Vk²ýr+<”Ö]‹«Nok£A{›Zõ»ÐÝ_í° IcHº¯ßƒ\îÂá¸ÆIÜJ´Z-±®[™j­äÊÒ$ËÖC¢ÈÀC9Ź:%³:~mºC‡i¾Æ­[·ÒµŒàCæ­ìCòçOm¹lÎO}ß; ¸†ã+{¾xpÔ 9>ó'ä`¿Í<õï@¯ÜJ†Žý‰'ç2¬5Ì=Æ38¸5s'7%6d5•«OÀ;¯’*?CçÌ$pêúí6bÒÝ!ØàÂÚ‘Y›ìzæ/Â5æ(3Kœ±+çÎĤÀÜÙÓ‘µÌœ9Ý–®rïATóP[=(j% —‡U&õ’~Èͬã±A‘zÔ]E,CR“P @uÊUA¥œØq8§|!‹Ë—/§ù^^^iÒW@ ¼¼ñ>$7×ÒvÆ :­<Å·ÙŽSñÓAô^W“­_üQ´ 3績5eŽ0÷ØŠWñTȲ¯B=¨ã?‡Ù…'ÓçÆ0&ñ-#;–ÀÙ»%{δÆ=úg*6 ¥H67T={§‹ _»Nô]²Žêžjô‘ÇiÝu «×/ÇY’á.ÉArÆÛÛ'å@©ÀÛÛG;Z8Kö¨Å¬ãÐúY,^q„õ{·€YÇå“ûÙ½{7{ö¦Ì܃´zªCã+Ťµ·‰2ZÈ™ÏÅ$§2 åÝÔ<¼Žw5!'@ ðê‰Iÿ>_ý€OÝ) «ä |Éÿúo¤ùèì¬v’†þ.©æ}²w5§Õè`œÊ–fsiûp ûܧõª‘H{@R;ᤒ#à 'µƒ”r5™]!6:±œ|…‹qaî—»E ‰@ ‚ÿŒä1$r!@ ÿ5 @ðŸ#bH@ üëˆ@ ÿ9"†D Á{‡0H@ ü爒÷€½ûö !¼õëÕB‚ CòRªdñîk¿¯ÃÉ“')P À+å¹~ýºÐW@ øß²¼×øù¥}×Ú‡ ÁG‚0HïÂÈ‚tjˆÁûDR}L+B_àÃ㽊!±˜¢Y¾z/]:5O51ö*{âhÕ¬ŒÝq³)œå+wѵKÛwT9QÑÜÜœ…÷ô"÷MùÈ›ÙYhÒ;"©>DEEÑ«W/.\ˆ›››Ã<"†D ><þõ’1=»¤3¡ÀWÌZ[Ð|þFŠ+˜<í'ºtjÎõ%Íý ?ëÇT±Ë¯<Æ„¡) ‹>”ÉSf§j„_ù•}—Ÿ§¹ž^EëQ§ˆ§íwlèÊ×Þȵ‹›mÇŽ íŤŒ³90µœÐ¤WµïŒ:d õ+å1™LtíÚ•ãÇÓµkWÖ­[‡$IB˜@ð’fƒdyƬ˜“Í[gá*ÉìÎøŠ)ç\X¹u YTöÆùãGé»2éòxFì6€LA}ÿH¾q„“óÛ¼çÝà›ýe^X‡[«f³ñA´51‹9†‰ÇÛλåhCŸ6¹¬ÅÃ+œ={?™Óã)¿ì8BÓ/›!KV¶¿W5;ƒ$f“ÿ¡ò–¼Bk^‡GWÓsàDŽ\¹‹K¶¢Ôkü-K'·OÓ8#GŽäøñã?~œ‘#G2qâD!T@ ø ’´Æ4Ó—E5»ÓaFKÖ~›h8DÜXIïuÐvÁ!<Í´Zƒ½äÌ“—Ã7©:¶›&p6Î?Ó.FŒú³>„#'â‘£GfŽá¸Ú‘Ãz`6>cÓæýè£ÎbŒfåÊ(Ýr?Çy¾·i“‡3½D,æ8¾<‚ï&M#›¯ÊVw¯ª½SöGÄP£žÕˆÐGâ—G;uüˆ¸fæOèØ‰²^»vëtÀl;yg·ãŒ+¾éF£Š÷¼<£JµÏÁ‡!6ŽO?­AÎ&‹(xp#…{l$°_ »kïjGëÅjÇà€ÿµ Yû³û‡6Ö>ÍÙ¹í¹ë¶çÌÈʹ©RäIC’„ìàÃã¾e“»Ù<”ued» -pvv;ŽK³nj“æ 93M®¸I2².‚ùñYÆŽ?ÀèÀ¹ÈU>lÙ1‘³³³ö×?0»û ©²0Š¡ýj£r«DÀˆ!âêÕ¿iZÄ“ekŽqõêUöOÞKÖF¥¸zõ*W¯^%Êd±]×Å¿=ýr›¼î¶Ãz›°ï£©âž80ÊžlÛ¶ƒ +¾EáTˆmÛv0Èw.kø°°ÔjµÝŸÂ 2E¢ËäùÅ… <‘út­hS4?þJñºÚ÷­8¬J#vݽQ 6^9¨µûÒŸÙV¾1æøpé§¿ºó4¾Êú–IÆݹQš1Mq×X†%û·S@ýgÿ,_?…™Kw1vð\6o Y˜ &CÓ¦NE.ÉÀ¹,íM§£(îQÌ×60ãš5]ïY‹(íª´åk>º óz ï¸Á®<³ñÃ÷ݧ͎äKr|||ˆÅ ™Lk/ÐuA ôIL%93wÎtÌ3’:±ýÑ÷gË–Ó4ŽOÜUéV±tQÇ 3˜)R&£Ýq™äJU5çŽ<…VyRä;pà@š¯Q»¶X&‚Æ yå}HäyX4³5µz΢XU´Ì®yaz `$+Õ`Ì1“çoåëuY¼h…¼ ²5ð'´Z-·wNçLæñlQƒN‹°˜b¸üç]ô‘çéÜj?N3»^6,¦H¾¨P•© P!…Ûß„Vk²ýr+<”Ö]‹«NokŸA{›Zõ»ÐÝ_í°þIcHº¯ßƒ\îÂá¸ÆIFV%Z­–Ø W‹­ŒLµVrå /—ãGŽY@§”Æj>'¿ýé0_‡Ò|[·n¥{9 Á‡Ê[Ù‡$[µîÀjªµ)ýÒ´2@­Ñã3B†¡ñÛÌSÿôÊ­dèØŸxr.ÁZ1ÁÁÜc<ƒƒ[3wrSbCVS¹ú¼óú ©ò3tÎL§¡ßn#&Ý‚ .¬9µÉ®7aþ"\cŽ2cÁ1Û1%°rîLLúGÌ= PûÀÌ™Ómé*÷D5ë«©fµÇ·ÏÚÆzI?âfÖñØ €H=ꌮ"Ž!¹¥ëT€;q¦çîéL¸ås¼§ÈåË—Ó| //¯4é«@ Þ?þ“oÙ9Çõ­Á(s„1¸ÇV¼êŒ§B–ýxêAÿ9Ì.<™>7†1‰oÙ±ÎÞ-Ùs¦5îÑ?S±Y(E²¹¡êÙ›8]ýÚu¢ï’uT÷T£)êaÒÇàí탣E&gÉ>¤ÆbÖqhý,¯8Âú½[À¬ãòÉýìÞ½›={SfîAZ=Õ¡ñbrT®ÅñTʹtþäöH"Óö„Å‘§Š’@ '²ÿÆEžì]ÍiE5:§²¥Ù\Ú>œ@Ã>÷i½j$ÒÔN8©äÈpÂImÆ`¥\MfWˆN,'_áb\˜û%OÔ©š=/Årzص'YL¥BÉ$o¿¸–£[·”›—é#O0uÆZ:wín{í7%‚þ<ÌÖÍ¿`Ò±ö¢‘óæç1}X½c?niÚ¼ówN¥pMƵ‚›Ð¤äÈT̪œ™¾Ë yâ^1÷÷å±AÎÿ¾ÈþÒ"N:Åõë×m¿ (@ÅŠ…làc4H^ç[6&£N‹Vûb›Æ”<‰ÏÕfãs¾¼¸¹1æëUi·˜¾§áô0F‡Ü!ˆQt9¢¡ÛüåT_:ÑêŒ`1ÚꔫñX¤íLîÝ€ûò¬<þ'‚%Gʦ)Ž@Ÿ$†Ä’ŠAb6<¡g÷ÑmÖž­‡‘ÇÓZE–üdšÝ“ZeóÚ6UÓjµœ ‰Ã+wâþ'ONcà¼ktš÷3µ3¤oÏÉg‹§0ªx'ê ÏÇÌ^õ ¿¸Ÿo:®¢t÷åi ø­P¡Z­–   òæÍK—.]·}€/AwE ‰@ |x¼•“äJîܹñquJs ‰F-~Ü=8Ž3‚ùùè\üÜUZÓý½¨ØB`‚¶¼¡á1(MÑ SZ¯c1š,~Yðôpå¡93íê™éY«u¾êD·n(–%õïÌ$߇Ä!šì>}Y²·|Êôèkm»þ[vÃ7s&T17ÙªcFno4«á¢"ŽˆˆpÌ*±7‰k¶fÿ-‚.æSuÎ7¨ü R»ó,VNk–6'‹LF•*UP*•tìØ‘¸¸8=zd;Ÿ »"†D ><ÞJ ‰¤ÌÌþý‡^9_äÝe4ýá4³wl¢tfÈŸ•gH,9ê/à‡º8$e¥X±âTí>‡ù5 ÐçÚo̘1•‰kаvPõ7RrcÄΨQx°;pa‘‘hq§Iß|š!ñ-YjÌ` ¡h d,Ù…m¿uÁ¬C®zõMÏ ÕªUÃh4rïÞ=,‹ª@ |„È|8Íi›6m*ôU >Pþ“}H‚W52@¾É{ÂÉ“'…Ànß@ ¤#ƒäuö!¼]|}ý„Þ¡¯@ðá>»E ‰@ ‚ÿŒä1$r!@ ÿ5 @ðŸ#bH@ üëˆ@ ÿ9"†D Á{‡0H@ ü爒÷€½ûö !ࣤ~½ú‹’÷R%‹‹¯ý à£ãäÉ“©Ú"†D Á{‡0H@ üçˆ@ ïŒÔlŠ÷&†Äl eýÆ}´jÓö¥ncì_¬Ù¦¥cëò¶c¡ìã^¶s§R IDATª”ÊâüÒkY̱ü¼âºvikwüôÃä®QÅ«9ŠÖ¯ZÎ'_u »ÒÈ“_¥p4 @àˆ÷>†Ä¤ " `óËÓê#O1}Þ¤æ #{÷cÔòe,_þ3+V­å‰ƒ‚¯Íå«î›±˜b˜¥ UeVŸ†ôÈf @ÈÍ¥xn,È'¾‹·¯Ð{+)éÑ…’}ra—á7òs£ŸqÞ#ë0fÌ£6†¯£ó Œ.çsªuϹÿ0é¿ÈCî, tã>Të3ÝK›bõìwMHã õøóÁ!rX(“Õž´rßþ£_³pM§—Û8µ`R4éZ›¶RÑÎâÃÿ'áx×ðæµ}kf·.¼±T<ŸÛºW ç&S­ÚMÊ…y|ñCÛ¶¥ÊcnnlŸÀˆæ=|6æ–ƒeŠÎe\wôç—͘iÿDkˆNIçØ€eµFQoøiÎN¨ ŸÈB|ƒR%‡Ämèê)Oß. 9ãßpnª'{Þddõ._l,mPQ½z ºP†ý2¯Ù3°Û3ŽõÜ©^Ý™kצã¯)‡Ù±Á¬ÊÜŸ…=«ÄùÔŒ6"½.’àà`F·âȃZ¿¹Ì°ÎkpmÚ Ãù©ìÏëÅ­­ë¨´ûݳ©ÐG+ ö`..ŸÁÍ“(+ršFÜÅÙksZçEýfͺ\aÇ_rÙZa¦€ËÇs3":Á~ÐàÉÅkå±ùP„©JÿEsoê®ÛKÝ8¿¿<ýˆt™Z’áC¾‹ þ­—?`Ó£1'õí‚õéø½¦ zf·fÛÙWôhhNó˜võæ³üÜqÌñ÷µªÍ0Èћݣ=c 25e綃8×lùa/(ccN£FŒÚ8ª\O uÜ@“,V˜Ùš¡0MºŽøüŠy‘A¬Ý3¦ P~-“—…™Ê3ö^(s ¦OV{ÒJðÁl?ïÆÂ$Ö©1n-væÃ³ÞøÝ¯›^:°÷ì8£þ8б9†É+¨iÿ±ÿRó|fsÿ…™ÝZЬHzì]k3gÁhä$vô¢ ßôŸËØcyy·¶‹qìÃË猷ò#&r+·'7GQÀÒT>½…øÆ¤J‰Bi…ßú©8‡ž›îöpíç]¢í¬u”±Mú&qpL ŽD£°%Ì?ú”†•³ÄÿPê7’e]è<ëØÇQU†÷e`¯ê˜Û¸âÓ£$§¯º`kjƈá 3ufÂh?rX(æ;:Þ‡¹‰YºtéJe ÷Kw…‚‹[÷ò>3MgÅ÷ð²ºÃÅÅ…¬Vw°t¨‡‹‹ f>Ü»O˜ÆÌ™³üéïêHúï~bäÈѱ?Ã}üse.>>ýø=4ê³O`àúޏ ÀÑ¡½½éšÐtìØ‘ýWðôØp¢3wÁõCß›(mÐkCÑÅŒŸ<Óè±°Y¶¤½;Eçm¦œ]üódÐ…1æWÝ!^¹cù)ä0Ó1t×£Û÷üÔ~ ÊÄ– G˜ÌìÌ0QÚÇþþêü:vìÈ‘£& ý9sppüO÷*¦-ÿ =÷,á§– ø¡B ºøŒbwPh¼å//úÓí§T©P…?ucãùçñ–ŸÞ‡Ñ[ðöʆõî@ÝF-<}+Qr#‚÷Žeäú{¨ßîŽ9ý'òÿ‰ 3-‚+“ñZq‹Ð»Ë©7ù,]Vïã‡#&÷ôÌIžüí±cjžÏ2 ºÐ®Húxë<:ñ Ûlß\ߛ̬óSçòãHOÝ«´!s§ xgA´!~²‰…} ÚggxÀsùäâ?,ÅI­–™k°vŒû‡{Ò»ÅH²7œÁ°ªY“¨¡gË8/úîw`Ñ‚œœæÉ•mñÌlÎŽÝû9~é ¥ ûÒ,ß³' ¡Ç²„s2Téë²}ÿ|T& îíÙ›ÆÜMl;p€ õÇä>mÄ|<dÌ%¶ŒmŒ‰‰-ëwÌÆüò–ù÷âq´’Û þŒ¹QzŒƒ«Ëß>ØC¹uë¦ÑÏí {8ºeá͹—‰qØã£lÞìOÐg$ÌþåÉÍlØñçšu¨ZÈ3U>5jD}˜‘Ë“ÿ [Íúqú§&µÒ+èñëÎí˜Ã’W¦x—ÈHÐúN,Ì<¿jÙŒö£yŠ·Ñz¾+•ño7Uk~´³àÅñ— žÓA­—R|ÐrrÅ–7³5ÃÄÔ6ö÷ÐûûYµj7â&]*LÉfõñ¯`}Ô†6î€u¶ÚLÎgÿ™í[»Q¤þ Â2”`ȸ¾°¤•k N¼Ž >0ˆüUºb_œáS‡S<}(ÞnñÙóøc@³cË—Œ¥bÛ¹óšÕÈÏš­i²$&GÃ6UÜŠeÀTUàÃy(“èùK—¥.~kÌvïÚ´wëG.ÏeL®#eUü çóÖéSìÝáϤ~^Ô›Á„Ó¶ùj#›sû‘[¥ü[ä•ô¹ü‹¿w5ö¦kÁÁñ5À KðX›VräÂÄ?äYˆÿ°Ïš‡${ ó+ÁÑ—zV ¨šäúÝ{^FæfÅæ®ÕŠÙ'M˜¿¬83WGwã÷m~àç&ÙP«Õ(l˰|ËlÛ~ÌEÑ©ßrñLšwiVk7y'lÄ€•Ë0rÎ Ôj5ƒ‡õcÛ¹î©u8jÔ¨ÕJ 8ñÇhüšºrS2WhN´"3Ç­æ‰93dA3Æó.¢"§·>"÷ ŒñŽCóî$ýûÏàý¼vp!·&fŽ,_ˆ÷“w¢V'ü×df·å’¬¾LŽ\•kPñ¤ Ê“yðððˆ-¿AÆqn< –Y…÷À ½à̸µ§pU¢ü8'.ÔfÓ¼q¬ß|UþLœÚ/&×&ê.–J£ýæ³4åÈ­P£òg§ú°é]&½ãç.˜Û™cbúñFäÜt?‘M?®W—6ÓºEg®gö`ßÅØ(D|F{ úHtXE™a‡Ù8°4uªÔ¦H–…8( WÓØs.ņbõ ˜ånåݨ½:•Ú4b䋳X™Ä =?¾Ÿí÷oP-}Ìh[öãi3ý8t(€s~,d‡é—xç!1Ú,¡¬{Ÿë98¥aü6kßrîâíØßï©uè/]àl†˜ýZØäû¶©~>7Žš[÷xjG·QciS$ƒQ½+cÇÓjê¡$5¡s ð`{_~^¯cßÝIXš(0$’»êPÁð©WÚò©,Ä7&Uç!¹<Ï‹?õù©åxŸ~«9µ¼KRçÑÉo,¢¸Ÿ«{÷WgZ½Ú6«Eצù(¼Ú¿‰•@ÞšžTu®É_‰Ï—Q®ÒD²ÊŒ©*?ãVþF¾L*Zåqf„ÿz º÷)þ#WÏQð¿u•%*• ]ä#Þ¼¸Àœ9¸°òõÚ2gά˜û¶]]æµ­Èþ½¯rä&gïØV.;*óâª,lßsÓÙï^’eÞ YS'fÈZ¯}ƒy¨+AúÉI—vϼoGj±Êe¯Ì.ŸË7{ÄŽòt*5ñûÏðjSºO·bý¦ñÞ >¥¸<Û SËB17ÄHã¿\itØä³1*Ÿðó:œ[nŠ7:`jm†Bi›¬¶ü­­†m¢ñ¹lЋÊ>§=ê7»¸ͪ_âH5ztŒ¹Ø_oæ°(u(?`h߃èa­ØùFM‹ÉšY*,ˆ FKe@{öúgŸs¿Ö炾 ³ÑÖsA;û~ÁS?`éÒ¥±¿…j0¬[É‹9¾ëÅ÷lSý|Ý}Œ¡@ÈÓôkј"[ Úç1Œ^ÍÀíY945}ŠÏeÄ‹½¸µ[ŒÏ¶›¸&ò¨ê/VNVh#oË'·ߠ俤øn´¯©¿Ó~ùizæ:&¯ÁáoØýõxéYÔÇ›·‰ùßþ—øÌ™zÞ]_„ûÈ£tßy‡ÁyŽàü]GZ.rg݇ É̺8sçÎ]Å©mè'N§½£Õ¿z>cY—òÌØ9 ‡<Þx×—ö1Ä«+ƒQ{ÁT‘òsymÊ0žjUlíS‡­ÏÃjTdšeÎl *Ÿ«QZäOn!þÃRôq«‹zB£ÉTsƒ\±ÊјU½Ër`D3v‡'ZOq‡¿ v£‘äí8ŸYÝJ±fËErWh„{=ë·ÜÇwínšþÛ_a 32ÅP˜XÒ±c§ØŸúE_c휙³ÏsÅ+Ï£R¢4ÏJýº?r`Ï#jhCƈ¾ð–jCÛS¿®vEq2S£°x›¸˜ƒ.‚{gÙ·ï1õÇ×çÏ_Çúaªñ£æñVûïÎ¥PÌΜ«! .{zt$ƒžu`A˼¼Ðbás“1M—½öMl 8ý‡,ü1<~‚æã½ym¨z¹â•Ÿì?«Ìmh“Ùx†\Û<9ðç$Ûüäà@ZÎyÁî+;n`ŸÓK‡FØ(MXpôYüàùÚ ^Gë±ÌØk¥ +NÅÏŸxqj) ¥%Mã|•õKÐiáY}Žõç1®JVlœ<Ùã[‘}ÜØøðýgmóKžO}Ôs–Mð5Êq2b¢³8ÁÇÎ>[Ý·ÐgË|~c‹ÿJÆû3nìZ ÅØ1>p¼Ã"CQùDâ¿DFFÆ>¿‰›C’ÐϪžÍ9Ÿ…c=bË ü´€¦¹`p³Þ< ‹H°ž&*š{Šb¬Ù¿µ¿§RÇ),ò4¥ƒGYª·ñ£è€E4-˜.Ñýª5Z0hQk´äË—Ÿ|ùòãœÓ”5 o0tÑjiÖ3mÇ rºÄ,3ÖÄÖkׯ÷'4§rýÌ|œ‡¬P«ÕD†¿fdóX4MuÍ*êôšÇëðÈØ}Þ»|š]›×2kÊV¼çʘ”(ù#ýÆ/äʃ'ØD «s´™t”ðw²tÍ<¢41û}pt(M›6fç³w‰SœŸÏUªK^n=eTõþÛR4:–.W:Ôo÷ð8ì-gN>3j À’v59ý»–||UAiŸíü좠[Õ_x•ÂIÀ¾ôù4 eóÜÙT®ÒÍûxòŽÛWöÑ£ÎpÒîBåW´×ó¶îö ·~ê\Úp¥fÍšñ>ÌûS´²ÕÝ*ÆnëÈ®` z“Od!¾A‰Ý÷âæDFF&?‡äõ¥9¬ºkN§E‹ÉgwXY…ïºiüá5ŽQ+¯3¿«ñP>ª‚Œè[×npòÂYŽ>ÀÞCToÙr¶Á¬™Õ·•ù(Wº… Â%·ÅÊ—ÆÁÔ„WïÂ1Ó…Â •J…AÎÕ£[˜Ù›É"É]´,uÇdRݘ9/*Œ8À«> äÉÀŽï±É˜›Æ—2­ß±Û°Éí‚söøLTœÈ§ß³»M¢b¶z-P‘º-{Q®b§xmyyv2³®›Ógó&œã~+EaÁÄý‹9ã>„nÓϲÁ§|¼ýTþu$rãÿÒçSižÿ«'Ñ{½ZÕäU„ ÛL”­Ó™ýÓ‡ð×%~ocoJMX”è5šœsi<fBþüù±óxM§¾ÇŒ'j–yä”On!¾AÉÍ!Q‚‚‚ȑÉk×®R¸ð—:ÕëÞÑËÓ‹ó·ï ±ÌA™rå¨PÉÚî•È; ’Ž;—8sîzðà.®®®ŸUw¡»3;>ȶαe!·^a—ß!á á}IL,¦ŠÄÄÜò«¹jOtøŸ8d.ÏÊG¯¨ŸÁøBWGhQ%‘l¬ Ó`amñEÚ÷©¶| ©}>#BÃIgkœ»Ò½@Q|ÿ¼’ê/¼¹Øz;Úrk«—|r ñ ÀÉÉÙ¨ü¯XãñãäÍ›7e‰‹KîdíüÎûFeo®]#*›3Yì?ï[«‰ÆÔÂ,&tÑhQZ$/WùË çãéIÃ÷ ~Ñ€$òÕ>Ê”˜Àž ƒä´Pþ'.ð Õµ¨6·Oö”¶¤Í»”é¨áuSu?ÚÈÛTÌׂIT²³@ñß H’=I``ò^ —PÝtÎΤãŸÍÉ¡Uü&D´:™Ž)ÒÁ˜äkféàÎþ%çØ~÷=] Ùÿ'.ð¬•&±®z^iK*²°¯Á•õ©¿Ÿ›{i¼v#B|ÃRuñuÉVc]þCÇk•³¤-©Nñ/ "f,Þ“ò¿°ß´Ty—B!DjWk~%¤„Büw’Ïy—ø²³I'!„ø&I‰B!¾Z’C"„Bˆ¯Ž$B!„Hs’C"„Bˆä!„"ÍI‰B!¾:!„"ÍIÉW`ï¾½Ò B!¾IµÜk%X.9$_¡Å‹}öÛ~…Bˆ¯U@@€¼ËF!„ÿ?$ B!Dš“!„B¤š¿ËF¡Pük9$zí+ÖmØGKO¯OÑh#þ`õ65íZ•-{uvrþH‰¬é>¹/ƒ>‚%˶Ðág¯xågùÊd2M٠ѺK©Ð¢-¹Ì´<×™áh&ƒLB!Db’Ê!Q(i›C¢S?`øð¡Dë?½nTèi~u0n8ðn½ð]º˜¥K—°lÅž'°¡w×£E' ºp&NšAA“ò9ó> ôjºtû‰»‘Ú·}餱üª!hí/Ôo5µ^.6!„âŸ2Mö¸sÖ=ÉÿÖéX+ñ–Þ‚I¬X¾u!YÍ•Cíz÷õ5µÐ½ ï(Ø×È©3ÉÈÈÅÛk8©¬ÌÜÐE?c̸ÕiÜÌh¤ÂƹN¸sðmL0ó"`Á¹~¦œ9‘¯ü Wf¦ŒyŠ;ÌÑ\É“(=y=SCyÚ/n̺ŽåJB!þI@’Ü’F#½™_µm§6gMÏR±å!·—ÓmíY¼æ&½>µ::Î`† õë7ˆ·g'&2çnæÏoÇ£~,‹nËðFNñÖ1‰Š"<ò9ë7$*ô,Úˆ–,YŒSmöõ\GA¯‘äÌéÀÓc«ÈXº‘—8dÿ¾Ù̕赯ټõÝpo× úHöfíª Û)—~](5«W·ßyþ;Éa¡ä‘¼NdøF­7°i-«2ªÈQ¿1™ÌβvÃCÕ¯$W“Bñ÷ûfJsH éyHTYÝX3¶6îƒ;q¨ÍYêd±Â {oÇä¨;…5ó$°;Õ«×À  eØ/ƒñš=»=ãÈQÏêÕ¹vm:þšr˜̪ÌýYسJlMZOpp0ÚˆPôºH‚ƒƒ ÝŠ#"hýæ2Ã:¯Áµi+ ç§²?¯·¶®£ÒîKtϦB­$,, Û‚y¸¸|6C4O¢¬ÈiEx<8pg¯iÌiõ›m4ër…|Éek…™.;Ì͈è;Po€'¯”ÇæCI¦*½ÌÝ"„B$ $sÓ”lÔ¹É,úø—cXëq¸Ë¥­9©-ÉáÉ “¬wpL ŽD7d¬%ürô) d‰·¼|¿‘ÌvkMgÅ|æ÷¨ €R•‡áÃ}‰x¶€-Ç_áÓ£eê=ÀÖô9#†dÇæÓLíG³mëæ;šUG·òW fb–….]ºrra¶”îOfpqë^ʵígã¬Ô÷{BîÅpqÉÊÍ,êáââÛžî¦%z,§»üˆŸóOŒP,Áåo®Ìeüª  O[s¹…BˆdHqRk§EKÈül=mgNççy7¸fŽfÊDÖÖ³eœ}÷;°hANNóäJ޶xf6gÇîý¿ô…R…}i–ïYÈ“…¿ÐcÙ„#©ôuÙ¾>*÷v‚ìM03Q°íÀ‚ÔTµWðñü‘1—\Ø2¶1&&¶¬ß1óË Xæß‹ÇÑJn/ø€—§ãàêo_](·nÝ4ú¹tG·,¼9÷2Ñþ {|”Í›ý úŒ„Y!„â¿*åó˜¸0Z+ܺL§hç4Ï¥Jt}ƒî=/#s³bsWŽjÅì“&Ì_Vœ™«£»q€û6?ðs“l¨Õj¶eX¾e6m³ÇnO§~ËÅ3AhÞ]¤Y­Ýä°V.ÀÈ9ƒP«Õ Öm縧Öá¨Q£V+1àÄw£ñkêÊýMýÉ\¡9ÑŠÌt·š?&6æÌEÍÏ»ˆŠœÞúˆÜƒ2Æ;Í»“ôï?€÷wnðÚÁ…Üvf˜˜9²p|!ÞOÞ‰ZýC‚ÇœÙm9|º…Bˆÿ€/žCWÎJ€•Tò,ù‰uUtò †(îçªÃÞýÕ™V¯6‡Íjѵi>Нöob%·¦'Uk’áC͈çË(Wi"Ù eÆT•Ÿq+#_&­ò83Â=Ý{Šÿ‘À«ç( øßº€ÆÊ•J….òo^\`Μ \Xy‡zm™3g »ºÌk[‘ý{_1äÈMÎÞ7°­\vTq¾¤ÊâÁöíìw/É2ï…¬©“x«×¾Á<Ô• ýdФ3•+M!„H*øªÞe£0ǽi¦4«Ëö§Ö´mQ ,,,ˆz|ˆÉS—ð*<~iºÌ^¹t•-ó¼Pªò7C4‘^÷ IDATÞÞ=Èä’oïôêãƒFýoïx{÷à˜}NNÀ•p-(­qvvÁæånåjGû’…± ÙÃúßÁ%ol” jÏÈá¾­1+<”ìæÊdЉiº;Yâ·õ\eB!Ä’êâk#î°fî|û_£¹Ï|f=^ɰ-™2m,^ûÓlÊ}|×î¡Yáô bÌÈ”"B?üjbIÇŽb??íÇñ›™9û< ‡}|µ±“J‰R™•úu¤åÈԞ݆†?ädî"?ªùµ§~ ,ìŠâd¦æ½Åc¢ `®Hú8 ºîßø“[³Q|}¦vCh‹%Ø*Œ5.C;‘ÞTfmB!>+ ùœwÙè4š˜`C£F­N:¦ÑEEsOQŒ5ûG’ÑÔøžEƒiâQQTòÝFÓ‚éƤтA‹Z£%_¾ü1ÛTßeZ‡ õ?D`ÏÚLÛ‘›©½ë£2¢5¨£A¯ÓÒ®_7ÖOhNeEf^<ÎC@+Ôj5]8ãZ¶À¢áhÊÝœJ^*Öo‡Õ‡ ߞ޸̵»÷¸w÷§_„seL J ‰Æ¹hIÊWêHåʃ¨aU–6“޲¦k&–®™ÇÏýÛ¡Ö*x~Ú~³®Ó~ÖªÛËW…Bü·¥j‰Ni³³3™¬-?=ÿ†ª #úäõ£œ¼p–#‡°÷P Õ[v£œm0kfµÀme>Ê•.E¡B…pÉíD±ò¥q05áÕ»pÌta 0C¥RaÐ…sõè&™L¦«i–33M6îb\OªÔÛLÇŸ¼hÒƒ,fJ «U'èÏó^6£†Ëuª5ø…õ »ò[Oo.;´ãŸ'J}-Æ·õ fóËÌ]3“²væÜ›?%!é)X° 5M¢W‘b|_8O¼Q”ñþ3©Y¹#®gÂ&wo­búÑœHBBÞ¡7·¹I„Büç¥Ê<$QšeáÀß\O¯{G/O/Îß¾ƒÆ2eÊ•£BµŸè5±™-cvݾÿ8î\à̹ó\9»Ÿý[­X¶¾ Ã=ÊràENµ–‚!Ÿª®ü™£'î¡IÙl@Ìœ#æ֎…Ì_}¯VuXÔ¾*³ï[Ó°ÙOœ׈tJ—ŽÜ&hVwÂ+ âà æ˜)e†¬ØUo_rZÆä’T›»•jŸ86ËLÕØá?Áã¶0qAÓØò¬U¦r Š\€B!DJ(‚ƒƒ wîÜ!{ö\\»v•Â…‹­èâ’û“»sç¾QÙ›k×ˆÊæL–Ï||¡ÕDcja32£Ñ¢´H^ ¥‹|ƒ‰e†Þ•£'Þ)˜¨îâêê*W£BˆoJ@@NNÎFåÅÁÁc'&MvI`àOî8¡zéœIÇ?›“C«ÖÅþ;ZÌ Çé@æB!ÒTªæ!„B$Ç×5‰B!DdªÑ¯D@@€t‚Bˆÿn@ò9óˆ/ËÑ1›t‚Bˆo’ä!„â«%9$B!„øêH@"„Bˆ4'9$B!„ø×I‰B!Òœä!„â«#‰B!Òœä|öîÛ+ „â›T˽V‚剿( É!I#%Š“·ý !„øæ$ù.…B!9$B!„øzH@"„Bˆ4'9$B!„H5ò.!„B¤¹¤rHà_˜‡$âùaN?ø*;'üÑ N¾’Q !„âka𒕝øyÒûpp‚˦î”ì g0¬jÖOî¯Ó¢%l+Û€¶33quÞ î<ƒ£™2Ym½½®£¾bäŽäµ4>Ô:å2Ñ{öuø!¦a²yóŠö÷£B’B!¾p@’’’(½õëx{‰?’Ñró;äàÊÓìšZ%¸ìu&P̯G_êY1 jòæ;1qaþ´V¸u™NÑÎ+hžK•¬zïn¥™ïn~ì¿‘&N ×±þÞžˆ%WQ«+Ùm9$ÙB!„H¾TË!±ÊÚ™Ǻ'ºãGÖ¹íÜÆåy^ü©ÏO-Ç{øô[Í©å]’u09+uVRɳd²æHÑiÑÏs$Vú³¸S)‰¬gŸÇæ¡Ì»"„B¤’ç(Š/²ã,æ&h^jŒÊC‚Öà5õwÚ/XÌÄõ~„L¢ÛÚ›©pè–tmÎC ÖÎïLRG¥y©ÁÄ<›\-B!Dˆ{|ñ¤ÖB6„ÞW¦‹zB£ÉTsƒ\±ÊјU½Ër`D3v‡Ñý.ëÈäSjÆú/ —EÒ¹&!×B°°/(W„B‘ÆRœC‚A›d~EV¹^€ºG¾Ø²õ½šs.:?;ÆzÄÖ-ðÓšn®Èàf½)¹LM8:¢/û3þÂ8ïÂñM̈‹V£F­ŽŸœ·Nèõ´w˜œµ|0 <Æ®@ãö•­â†Í‡‰ÖŽzŠs÷¼±mz~Ú~³®Ó~ÖªÛËc!„âŸJ•Û¬Nä~›)Éœ ç]ˆ˜àKˆòÍLx}i«îšÓiÑbòÙYÅYS…ïºiüá5ŽQ+¯3¿k)6éer§hþÏ©ðöÚ>jL[Ê÷æz™oD!„HE©’C’Nnýù)ë«ò§B ÷ñ9u²–ì‚·\#B!DªK³wÙ!„B¤”¼æö+ „â¿üõìF¡P|r‘:e¶X!„ߦ¤rH Eêç!„B$FrH„BñÕ‘€D!„i.Eï²B!„øþµyH„B!#9$B!„øêH@"„Bˆ4'9$_½ûöJ'!„ø&Õr¯•`¹ä|…J/†«««t„BˆoJ@@€¼ËF!„ÿ?b…B!½!„BˆMÜØCrH„B‘j’z— H‰B!þIå„„|©C4ц¤W‰x~˜ÓO#¾ÊN t‚“¯d4H!„HkŸü±}žkQ¢pA (@¥º­™»åŠÑzº¨'ôj2”(K%á·Q³Zl½go£zµ*øøß1Z¶´sÜëõ"LgùÞ‚š?ó4J¿ÑO©Zµr¢? ÚîŽ9xU8>MûòR«—+A!„HC)Î!Y;¤ãw=Àkàpú-Iº÷÷8ql'S|rñÉ~ëP4vÝÓ£ÛðØceUP¹3 Êº ö¤þû(mc€AÉ–CykÓ_ìFûn4Ò›ùU;ÑvjsÖô,[r{9ÝÖžÅkÎaÒë£Q«£c—ô– 4ب횷gè?l9šfA­V£°©ÂÄŠSh;>€->¥äjB!¾°TÉ! >Ô‡1Û®ÐwóEºŸáCi •­FQ³' <² C×éXš(ÐF\£ßæ`œ/…Je€ÛÐ Ô?Rž¾]rÆ¿ àÜTOö¼ÉÈê]¾ØXšíS•Õ5ckã>¸‡Úœ¥N+ º÷øvœAŽºSQ3O-Uáþ·‰XôÑ/ñvëGƲ½XÖ½$Êåå}|¹_¾7Á>¸¨LåÊB!¾ TÉ!Y仟 ß ‰Œ|äÚ{-Ç7ÍÀÒ$æ+<ÏOO$Ú¡¥¬Íb×Q(­ð[?çÐsÓ]Ân ý¼K´µŽ2¶æ‰î×¹É,ú”¶fXëqh p~FkNjK²vrÃd·}u¯Æz_•‹{Ä#æv•hž>‚I^Æ–½¹2Ÿ~ü%W’Bñ/Hv@bÐ…±æE9êUJdøó˜νN–Ê5Ö²Ì\ƒµc<Ø?Ü“Þ-F’½á †UÍúÉýwZ´„ÌÏÖÓvæt~žwƒkfáh¦LVÛo¯ëÁ胯¶n1y-GAê”ËÄÕÙ×c{|”Í›ý ŠÔÊ"„Bü ’C¢ B«7`_Ô:Þòè°Kì:x?ö÷nu)mcÆ•§Ø5µJp[ÙëL ˜_ Ž¾Ô³b@ÕäÍ{bâÂüi­pë2¢WÐ<—*YõÞ?ÜJ3ßÝüØ#Mœ®cý½=K®¢VW ³ÛrI´/„B‘<)Î!Q(IæèÍœP*¼R£*ÿq¹þý=~ÿýwNîÝM¥2µ©˜É†GÖ¹íÜÖåy^ü©ÏO-Ç{øô[Í©å]’uP9+uVRɳd²æJÑiÑÏs$Vú³¸S)›‹Ö>5:ÍC™E!„øÂ’Ê! U¤<‡ÄD™ž-yä,^yºLžÌœ9‹™3g‘Ãâã#”,æ&h^jŒ¶´¯©¿Ó~Áb&®÷#4`ÝÖÞL….0°¤ks.J°v~g’š_óRƒ‰y6¹j„Bˆ4’¢¤Öƒ~àõÕ1Ì?óÜøö¯ 'Òðq®B6„Þ·Ž.ê =ZŒ&SÍI ruÄ*GcVõ.ËÍØþE,pYG&ŸR3Ö¹,’Î5 ¹‚…}A¹„Bˆ4’¢yHkÏ ß‘æLiS…»½†P·\ rÙÃ[×YÿÛžÙ–fœ½)jµš­r¼"u|±õ×÷jιèüìë»?- éæŠ nÖ›’ûgÁÔ„£#ú²?ã/Œó.? ÑÄŒ¸h5jÔêøÉ©që„ÞYO‹q‡ÉY˳Àcì 4>–²UܰQÆŒ›?ôçîycÛôü´ýf]§ý¬%T·—Ç8B!ÄçJµwÙt¹“¶Ï`²Uôš3Š0l)Vª eë `tÇV8šÅ º87èBÄ_B”¿àhfÂëKsXuלN‹“ÏÎ*ÎUø®›Æ^ãµò:ó»–bãÁÃDŽhÔÒggg2Y[-‹[çñ…ßÉê”®odúõ„cnµZdR™¢Óéer§hþÏ©ðöÚ>jL[Ê÷æz™oD!„H_<‡äÎûŸÕ'·þü”‚õUyŠS!…ûøœ:YKvÁ[®!„"Õ$7‡ÄDºJ!„i-ö»³ …Bz# H'!„øO‰{¤h‘:e–X!„ߦT›‡D!„âŸR©T¼/9$B!„øŠH@"„Bˆ4'9$B!„ø×I‰B!Ò\¢9$òµ_!„Bü›âÆ’C"„Bˆ4'9$_½ûöJ'!„ø&Õr¯•`¹ä|…J/†«««t„BˆoJ@@@’ï² ‘yH„Bñõ€D!„iNrH„B‘jRü.…B!9$B!„ø¢’Ê! ý÷rH"žæôÓˆ¯²“Âàä+ B!ÒZŠ’+~žÔó\•ಳÛS§ÙŒxeº¨'ôj2”(K%á·Q³Zl½go£zµ*øøß1Z¶´sÜëõ"Lg0Zvpx jzüÌÓ(]üýF?¥jÕʉþ4h»;æàUáø4íËK­^®!„" ¥(‡äý‹Ç¥f¬ÿrY$kr- û‚r5!„i$EóDéõ`Ð&¸ ~‡‡GUÒ™(>»s¢CÏÑ®ý@þ¸rÑhÙó!Ô›^…h‡=xõ}ÔS|¼FÓrãîxåîžËÔUû¹qóaZS²æ-IÓv½éX¿JUC½³aç¯8˜ÊìÿB!þÿ}ÖUývõ[üó7ù‡€¡ë¶“ýQv…ÊP±b ž)–ñ˜:ßF‘+½9ÏŽÏfÜš,4®‘-Þv[·nCÐÍñÊ‚÷nâu‡"ñƒî=ë&õgþeM=ʱiWSG~ÏÑ=Ó˜±l;Sf§œ£å‡›~0­ÚôIòxZÌYA㌟MÐcÛ¬:KŽÂ¦*}ʦûÇnb'žzüJE{‹Ø²uÃZ1~×C¼ ¥ÿØ’X¾¿Ë‰ã»øuXKþ|½ž?}‡Ê¡:*ͤóôËø÷/)W±Bˆÿÿ€äsrHLÒUbíÚ²F9$é,lYÿ€,?¥G«F«Óc0舊xD=7/.œ=€NgÀ:gúõ«ðÉž¼²‡z-Zmô‡h$šéíëp.Gv®lïv³rYu*×ió³àzµÉ‘Ýc0S€+Ú¶m“èöŽÆóH5Z­2f¤F§ùï‡ýéÔÏ9°yëÖmäÚ;æîõ§”µùÇö|&mäMúm fú‘ü±Ûzzl(c·ýA·•GèX$ý‡53âY¸ .º‡øZI„—æ&P¤K?î×èCP×}ä¶P"9$B!þýÃ3^­ìE×5A±ë”ž¼Žî¡‹˜tÇšõUrbjª$]Æ „Üþ•ýÌQ¥¯Ž©©YÌ-¶Hm¦ËÉåíñ½þ:ÑF:Ë÷ÆÔ,”1¶îã=ýØø¬ ÇW¶ÆÂDAHø9¬sÕŒ]îÖe>[×þ€ï¥¾L.ëØS§N½D÷±eìL”f±õuʘA£÷÷/±víj6l;FÆâÕiÜãW渗ÇVùe‘¼¸øÚŒ^”¶û8Ò²jüQÒêO×â™Öÿ¡× öçëQ*ÓØ>‚™WC˜YÞñ¯±#É!Bñã‹ääk?—Ý­u±9$&¦æ\XtŸÁ‹V“O3Ú¡Ëg_ämô.Z:¶nfןéé ÑucE´½ö n5áà>äE(ÍìHoW —8û]3å4q/Ç“ IDATîÓö`ñ!OäåÉ»8º}|ô£0QѦDFÆîy e?ëØ z µ»L¤nÃFÌÞ>–ï²Y'²žšã'ΤhÛ…*üHf3®/ºIæŠ]ãl+Œ /#(èõC"5óbj•v`À‚PÞQ®j!„ÿ×>; ¹µ¤WÇŒ PfÚF<_„±urw¶þ}„Å®$Kæ?žQ˜¿dáÊ‹ îÑ ý‡' 2:à`–Ø(„Ž ¯"˜çldí=ŠÎC¶ÍkÃû3!ŸÝ) sNðGù‰ÜXƒö#F OѶ‡mÝOu{ןG’¾©ýÇ#Ó£ÕH_2C²·•¾d"–Ü*Ë•,„âÿ; ùÜyHœÛÏg»ø9$á6ÞÔß•]ù}Q;'.ìËróâ æ\¼»·”mÛ2áÓ%ý‡å£öÇ"NÁ@f£”Ì?æv!4g;6vŠ¢U“ÎøŒî»¯¤¦¡¯5y‡;÷¡Òoá”鱌ú¼{ÈÉßO±sõbnØVeáÊÞ±ÛÐG¿ 00ðíw|EÿÇßWs—Þ „„P¤ƒô&R”"‚RôQAQGDxQ°¢ÒQTéHQ¤H¯IH!É¥^r·w{¿?.¹Ü¥@Â%þæýzå•dowgo>;3ß™ùìl™ç˵Ú\ÒÔz· Tc§Í¥w£ptZ fc6éSÞ[BmÕme|ãáµHþê0<_´Šm­þï1iïpÞ}êŸJß6Íñ—’Ø»w~ö-žø˜`µÂq­v\¥Þ„èRõ J$åñäç—ôXm6ö,^@¶—còEÀBÆåý,š7—/úóâ¢oéâ{… §Ñó«Ú êߟ¡ƒzâ¯V’öÇ—<õùE&­_BD„Ÿš?ãׯðúÔéTòÃC«E¥ÙjÁd61fò4B5JT~mY¸ògΧHD†y!I ¿.âëß¼é=fÿé× ½R$Ù½Jïn,\Ø­Ì øhÆËÔTÛûƒŽŸÌgͯ‡¹xúyf j­///üB"ˆ¨Ó½lA*x:èV í6 ãüy$‡â4"ôè_ÛæC>X½’–ÌÁhÑ^¿ ¬`D׆Žë”ÍWø2ÅÌÜöÁH’Tâ=C7ÒS ‚ÊBa¢HLL´¤¦¦âí]ÒL¹uëOtéÒ­Dï{YïÖ{rýt€ ­>zf8Õ†¾ÈŒgáçä9±mÿýü$ï.Ÿƒ^©`ëì!ìm6ŸY‹èµÉ9Þ»s—¯fÈÀ˜/a•eP(ñÐ×bÒsÃÿq"¬×탗ñaßš¥ï ›0¡u<âìÌ¥µãxzûƒü´Ø¾ÆJq}<@Ïž}Ä.‚JKNN&ÁÁÁåH:wîêÒØÙl6¤<#²V‡š"‰%[BíS3¨ ˆw°˜ {2è>ùù ´åÏ«)Ž‘½_`ʦohé£-% ±qèÐ! Ê$å6µ[íÿ«@ TÊìÙ³Kä”@ ‚;†âüùó6°OÙ¨Õ"G@ Ü,^^^@9=$@ 7αˆ@ ·#@ n§\ë@ Ü J¬C¢T*ÉÊʺ㠗õHjE¶W–sTäó»uŽ[Ý÷ïÐP ‚ŠP³fM<<ìÔ8Þe#@à.„‡D Ûqñ@ ¸% )ô@ ¸ 1e#@$@ ÂC"Àý‰ð@ p7bÊF ÛQ‹,p›6m™PEèß¿¿ÐPh( î† <$n§G€}9öÂ%ÙËú[pw(žÿ{÷îåFåDh(4T eYvëü·ÐÐ=ʲìøûàÁƒ7ÔPxHÜŒ^¯/Q`J+L‚»_:çýʉÐPh(¨ʲ\âÇf³aµZ]GÁÝÓP¡P”[C1eSÉ ]i½¨Ý_ …†BÃÊ­aiÁˆsPRø[p÷5,oÞ‹€¤º²*AQˆî¾&¥ý-4 *¯†å F„†wY–Q((ŠrN ‰›)Ìÿ╞ˆè+G X\'¡¡ÐPP95ÌÏÏ/3 ,œ²:Þ]ŠO×ÜLCá!q3…óž»–­92Lø¢Q**åw³š9sIC£˜Ð*[VdîZø„†÷i¨Óé°Z­.£"…6ŒÂCâ¾€DxHþÁœÞú=ûSŒøÕëÂÐŽõø;‹™1'½·žò„9‰GvbªÛŽz~ÚŸYLqü~ÄmjaÈÌ/õøœ¸Ó\Ê’Êu]÷4iRbáKn<×máT÷.ß­,e%’¢©F„¾êÜúg—NfÖÎd—m¾ùbÉ3¼ðø(RÌV—Ï"zü›c#ÿ¯ùz9͇Œ R§rªé-$˜ÔtÞV ¦œ 2­^„úiJY¸¶ƒcrÚT/¥’±IHhл‘rörÔó^ÚéþQeòàϳý‘ÙLòwÛ5ä§ìà‡Á îßøŽœ_è]ÞHJBVhþ¶…¾òRvó—Ü’Vaú ¥•{å7Žë[Ð6È£Jd›X­ ’så®û0vÒD"®ïc樓r%cÎËÅzÄ„8Î9ͱ#‡9ðÛ^ví9á²çkþG²µ¬pĆÕZþøøéصq3×ò­ä$ìdÍš5¬Yý?V¬\Åw?]Faù‹eË–³båÿ쟭YƒìÔÑÌ>w”©V<==?:ˆB§wü¯×k8pàÅF‰rÙ¶i²ÞOµÒ©Wea㊯Ù|ÂPò†×HìÜ´Eºó³/Ÿ ¯Ý$/^ÌâÅ‹ygîPŽ¿À_fÞ?p|6ñž,NÆç¸ÿþüyÉ1»Œ\Å%¬eøÃ³É¶: ¥^ÿ†‡‡ f@¿~ôêÑÖ-biÙº½ûN.5൚“™ôÈlÌz×Ì<þýbF?<€ÖM›Û¸)ÝŽeé†ãŽÏUz#S‡M%ÕòÏê­j¤sü¶)ño9WÜï°áðµ —·‚·ÞÙVîý·ü°‰¤‚€va¿nL»œUæ¾Bï›ódž3ü!:¶nC«¶:j<˶ž.±ß_ ždظծõ™”Êå‘§Þ%Ó©Ž•ÍW™:úÍù^ž´T:#¯Ž~µÊä½ð¸™ŠÎ]›Òϲqë)Ú }†Øúöcçw›Ø‘Û•öÑÕ\F5¬æ$¶m;B®1—\cJ¼<áJB ú€bê×$$0œÐ_“Ò¥ëd¡§]L×Μäâ¾íºžƒIÊÇl’0›%ôá=Ú3›Í†¾F úµ;ĶÝWx¼WG†F…S3 ·æ¯bÂ+“ñT¨¸¾óVzóâ HG0sþÜ9l€E¶áÕ =ÛèH3ZØ·s{ß-=« l²‰;öBZÊ5 s$yÿfrêv£UT8içÏ"4®Æk{I³¨P=ID»û¸œfrºã#èq˜M'%ˆK£ð•É`‘mÄ};—göé ± °5B’$lÀ”g'P8Α—”ˆ­³I’\ƒHIB’ì£BIÛßgüæXÞîÏ’?¯ñBÓ {°æÙ–ÇŸ !0 €   ¼U÷à$ºÍšŒU’°»®sÆ‘tÿÚz)é­zu$oýÏÈ—_aòœæè³/±{×,œþ0GSV±hL#T~]˜wß{Œ]pˆuSZܹNê]Ö0¤g8Wç'é!/\àìÙ3‚ðÜ Ú%:©Wó ó,ó\ÇŸ`úKÝÙ6v ž{U9ge%‹ ‹é_6¯¾<•9;ºâïANVÙù¦2u‡ÞUÇC"óÅä¡|´/ŸÑS§3³CS¼-iþõæNÁ/»gðåÌ‹¾Gj2‰É™X­öRe“syï_Ãø1å¾øæ¼±9>;øŸ§Iîóm½ÕÛÊŸ–&  ovXÌÓïýɪIÍîzû&<$UŒŠÌ]gÆãçíG¹§÷côoÁõ¸‹(<üéüÐv}ÿ=ß%EÑù¾{ ÑÛ›'µº ·&2ºaÕÂðõÔbÍKàëÿ~N«~ãÚ©V“‘¬Ü<$)FƒÙx gc<ò•j"Цy8µB‚ðõò@«Õá¡×£È¿ÂÅ+F‚£Ú3¢eá~ëÖÏ!ø‘Ųï~¤š)‡ø“É蛜æÇMG1é£hR×µÆ> V*MY¤¥HÌ4TBi0“˜ˆÅ6¹¨w¯Ñh°²%çrðbK´Ùɘ”j4ˆ¸ „u…qÇçìS ¶&Í%ÏÃZµæúÊux·{Œ\ƒé†ae𨕠ê>ò&_‹¶W¼[é8`ðñ—Ëñ)h±N¼;ˆé9j4ç)*Ʊ­vŸùŒÞ4óc+yÉ×i(WS›¾½ì§UºÊ ½¦ýâr¦ô¬]2HÊ;Å”o“øð·¦Žó&m™77ãùÕûx:¶p4«& îíDCE"¯oÿòøyx(¡Õ¤é\î8™„I;©w“i£Û H?­YÁ¹øxâã㉻p‚Ì {öD}êׯKýzõiåUL ÈK]Í#Osx×ëe^O¿iŸQ'fcg¼Â#Ù!l˜ÝÁåóø ³Ø¢ÇøÞ5]GiÔ lr.—N#.>„ûµÅÇÇ“naÕŠÙèœä¯TkJ\¯;õ®*’„Í“Y¼3ާWüÊ“ ¶úÓkô+4©)qÿ¤7˜Û¯¯µ±ÿŠ‚r©RMâÓÉÃYŸÔ/Ö½C´—Ú)ßÏ0mc‹v4¶ï{ i5v q=¦?ñgêz¨îjû&<$ÿ@¬ùþ:|?Î¥áÑ„E2[6Äh.*\õšà«ÎççoVSëžXZ´hˆ·JGTýøéÕd¥&’j6±ÃJrbdhÛz®Æ“’é­æ%§£ m‰Í’i¿yÂjããéFa!;3«lÃ&ËÈ6ׂmͼʥL8yì8÷BLL JÅe¾ÝìÉÀACÑy{“qâ;v§4¤s¬†ôì¢^X江YsÌÊðýšUXóó)«7&Böl½¡:Ïç»LGÊ03¢m]̧=ÙòÝZôð"Í)¯TÚDkÍü’áCg…s0+^øz2ƒ7 ";P?:šÇRÔK¼‡ªçÍÏ7jñº´V–ük)=ßä›QMJÝ%åÀ;HÁ#iá]Ôx}>{^vjœŠhÿÂr~q¿Óúvdˆ¿‘…‡¯³¸}X•-›IÇÏ`­Aû^­QçF}„Õ›7R][vů è oc’_ÇC ²”Ã¥sg¸”¬§G÷FŽý?ø?GEs2ì^Wyä<¦¿¹ž°ùO”…ÕÌš·¸øxâãâ0æïç‰÷S»NêÔ®MíF­ÑÛǯµF¸#ö€¼U7Ÿ¿zߘÏÞ9@@ÌT§¡ˆê]gòXØÖ¿±‘×6/1²²fæ>?Y›O׿ëŒ\?ô>– Gh楹崴¾íyÐÏÈ¢#©¼×¦Zåž²Í}åF¶fóí7›ðiÅøç‡rùØq$cfk¡cÇŽŽ}kÜÛ™n±Ilßy†ˆ@Œ† $›•̬l{c•vÙ¼Ø3…á )™%GÌf<Â|°æ*c–RÛ­tΜK±÷Ìô5©_Û €ð¼x¾?q Ùš‰9_ËÑ£×1™¬DÕVbËÕãç¥v H[?Ì„ÎÁ˜ ’¹³fò连ÆK2alr>3gÍuI;õH:Þuz£°Ès2¥ŽDãÛš¦~ζ©CÖ†o‘~®æº_·ºŽ]Û®ÒσD£¥Òß‘£ÞcíÑÅnŽ|j6mÇÒ/96xçA^κ½¡çu³‡ñéùº¼Øþ<Ó'MDÖ€mz1°KQú'–ž¦Ú}Ï8Ý 9¬J1ÒpTDzúJ%¶Üß:˜)KNCn Æþûß.ÿwõÓ°1-Ÿ§ª{¹äi¡]/ãêeΜ>C¸ÊÈ„çŸÂpé i2µëxqòx:ÛþÜM˜¦(˜ ¸gŠ¥™¸u*'TXÖ5Ü`{U#²y'z{ýÖ^Â§ÏØ+¿®æá?اHǼËXdþM}Êí_ðm@îç'‘¤w¦¡pƒ†½ª{òÅ÷Û¨æÆ©S§8}úç.d±ý·_0Æÿ‡ûÇî"¦a uBõ$F÷eþ”¶Ô `ËŒ~¼_ë-‚‘¤²§LyüåmtûG°HH€Rßž1# Êøïzœ=$RÎ þ5t>ý‰Àbç6çG© "Daß.²Er:ö(Ó–&³pr·é]<$–¼D{`×ÔÏáû(ñÝcý7^&[²à©T ÛÀxíKfþKuÅu–}žùG—8îäµ<üù8Î{+iø5 Àøåi¬Ööwµ}’*F¹æ®56âΟÄXГ7&ça•ÒÈÎÎ&9¹è‘P•‡­l"%)¥ÚõQ°Ìl žÑ¡˜ G‰H’Ñê¸|ú šj~˜s³°yúà¡(ÙãÑhjq_§¼åùä'?ÂB½*7‡Ö@†JÚªaùûðlߨl{0¡PyT@Ɵ߱₼‚ÊÒ¬ûê ,F£=hrš*ôd[­è‚E:*k R(È>gDÓRS¾ª–VS|©ž…¿3 ¹SZMWX½êGâã㈻Çŋ牿–êò'ìèÙœ¨È&ŒèöQQ Ði5è"gp`× .­ÁÄ“µiP;”¬ _3í§<–íkü¥T掞„²ëtÞîY«ÔÇò5j tœçÈ’7‘†,æ±FÁ%ðÜ?Ðz·tìëê!±òþ“Ï×è4Ûô® ¥gM” †£™¨Z”>‘qØ€Rí‡ÆÞ)P*@­oÀ—ëáwô#úL˪¦?1²‘ë#ãñ&+žÞÿÈ­¤à¡ÇjŠwœÇ‰ðüƒÈMÞÇ÷»œ´GÇ‹/vé¡„÷xÎAZ—‘G¥«V`¼˜ƒÕßZváòP‘—ô«ç3fd(¿~½ŽºŒ#R#—zN›läzš ÙâÚKÊÍÌdØô™($o^ĶÀ0üÓKoÌ–l×™>uõ˜ øâã¥têÕ¹pÊÆÌÒ?w9ÎK¥$+ׂìYTÁ\Üs o þ:†Ùd?ŸPL—ñ§¶+Á¤;õj¬(”¾ ÐT™{ ¨ùDÞon×~õÌG¸2t.VOçí÷ÞÇCY8eSþó¥þ9‡g7´eÕìžÈR:ûN²ä‡et “ùsçf¬­iioÈ<Ãûa•ÞàŠY&R§"L«"õzÑ”ŸRåOÿ@»×î„áõKMO²á²F…)Õ„J[½êJ…’]G.EŸ6=‰Šj@ ù=x*œEóŸ¿á¡Ám[òñ )-ÿŽûf|νÞeߋٗv0éÉ)Óödë‘”w)ÄVÓ¿á+¹tÈñ÷6Q½ë¥~¶{鬳õå×™}„Þ7¼ ¼y0HÏö-¿Ã˜¥î³íP^a»lÓú¶#ÊS í&òþÈý¼0î oYASŸ¢5ªiU¤¥šn;-Sš¥¦òO•‰uHªžañØsL›6iÓ¦ñÒ 8þ/üÝ2†ÒãÌЦ¡¤ú–mÙ²«=U\ÿe'Íûµ!<Ø‹šz5‰R^·°ìúå_ñÉDZ)^*F Åç–¯šd"Õ!H¯E¥R¸Î!4,­Zmߦ.y½ùÉy( ž.‘¥¤åÓtÔ5œQ£G3zôhF?6–æ>ìþ1 §ó˜ÒòQéÃÀf©R÷”}‘Å/ âÓôÞ¬qzŒð†ŸFéXkÂΚ“˜úì:´OÁ(5Á,\½„Ža6þÕµ+ë÷_`Õܱô›h_+!7ij]¤Ã¥í­%ûL¶Ë9Ÿy¹=é'°d_r‰k8õÍK´íþ¨Ëz™§2ñˆ®²eR¥ ç£wçñâ„q èÕ™†u«P½yé¹Ùx˜gðŒ××Ð~Öj>Yê~Vs:;Vÿ‡^ý'Öp8«ÖÎÁï&ÏÛ0»TñÊÒΛĬ_yfrÓb#ù¬˜9‚‰_˜X¶|ªÃ+ô¾1c&·Åpê?|x,­ÄgIÛ^gEJ.½_/»¼vœô9Cj¦0qô›.k5ðÖ}.û¶ÓÊ:“…‡ƒJŸÂCâfòòòJ·.þ?€$%p¦À°(›Sç8sæL¹ÒÒÕ¼†ùäão¹'&ŠêÕðóñÅCSTc)ýµ ð¥_ä]8EõŽÍØ»jëj×@§Uc³H9´ëÞÛ1?™—)aÉ=Gž5û4€z±Íh7h¦Ë6Sÿ!lr®Ý "ç“`²0ÈKKnR69¦­àǘ“S¦‡$ ƇŒ¿.¡l]I’0ß šj ªåCú…S\Í/j€ë4öçè¡uhûŽDJ²/–—‹—pdkI¯Li/S»™ÿ ¼Þ …’½Ÿ¿ÁkÿÝH‹Ç¦³öéþŽQ)I’PHh)ÅCÒ5XÇ–Ïðô4»×$ïÚïÌxúrZÄø&¾.ûš³±ßÉþIO¡Q<Ňtbæwž\[ø÷½°Ù"! ‡×"髃H‹*¹ê}ßaÒ®¼;¾ñϾLß6-ð—Ù»w~ö=-žXŠŸÍŠ$ÙµÙûëUêNˆ,·¡"¸KC…¾5òUörií­½A4A¬*Ž?2ŒÄãç®àÉûï›xLԵɻ¾Žw>®F­@od)CºC†I?ˆic°ÉF>þ0tžF_•#ÿeàÀ¤ñêÊòͯSWms|æ½oEÃҦݜ=@wj’ˆÞÿá¹-Cù`Ü0ò&Og@‡XûÚ ÛW3oñ÷4~p¯´ rLÙ/Ãy IäÏþËï½Æ2êµXÖÏy€FÃjquÅaä 1·œÀþרûTÔ]_:¿¢ ‰›Ñjµe¾Y´ð'íìI’Í®7’lµ7¬»wï&%%ÅuØK[†Q¥ÉM›û‡y凿è¡\Ôº(Æ<Ú kÁ“*ž!:4žÑ(H³(ð m̨ ÈÊÎÀ`0`–x轈¬[ô¤x.ÛË®cÚ´„?ù‰-Ûqñü%|«GêyY™Xe™¨Ž]h‚J¾ÊÙTµš´c;0ëã¥&%êânk"ç.æ£Uå¢PÚý0jµýØ-IDATà‹th'yÞO¢N“8w"î}•-4‹µºh”( º=~gv³'ÇM>’%‹“F™̓1®¸ì[XˆŠûnTNÊ£áíT„*¥…REÔ=uxmõ6ºDúraÙÛ¬KÍERú¢Óª1%\ ñ"1ɈÂ_íò}g<ÿ{ä9oEõ§-t¸_½ØâY®èÀà:3è9h4î­Ç55ü1w)?¿˜)z$µVßqç¿Aºm4¡Nío¯¥Õ}ïóîÊULZ2—\«†‘MyqÑZF÷(:ÞjJà«3 º×,‘ÿWEè. ûéù1M¢½¿ç ÷TÍ“ïÒ%Zø•¼.õ >™¹t:=Û6D]ÎÊ€zÓY0Å—=ætft:O<½< Ò¢V«1^ÝÆ©'kŽDí4ÚÒ¬]].û áÃéÃJ<ì½+ª¡Z­.ñvß·Í:'wh¼Œ1ï¬'vÃb­\ÄÚW0)=©Ù€1óV0¦GŒkç04‚Z5üQ8yó´ÞMXòÑÓŒŸµœÅ¿uäÙö¡Dôñíy¤Z†âÈ÷Š¥%›¯ðuŠ™¹ª»¤w·’*@y*A³1—|›¦X¥¤£U«6dffb±¸N;¨5:ü|µ2JL`D4ƒc;⣅¼| Qsú¬}Ék]pWFª‹Í’UTxÕjüCkR«~Ô*5JlH¹Ù˜Í9>‘ÉcÆÐº¶7±gÿâøÉsìùe3ÙF#f³Å1t­T©P)Õ¨5*ÚõD˜œËµkFš~µ%“\KQÿ°Wß¾øª”¤É”˜ظ§e_”Š“ ÔÔ¢mè~ÖRÒI/Óö„Õ '7= kñJGáÏC ¡^5Or’”œ=¹ux'îõјlB–m7ÔäïÐðv*B›ÍžFPËtÂþJïÀVÍ©þ{3ßZŠB–¹²mã?9F¾EI¿¡.éù5ÏÖŸÛ²ãÀI¬1ôèÐÄÞàØdä_OÉ««¶3ôÈï\IË#hÈcÔ®‡ÊõõáZßî¼Òt3~J`鮋sÅö–/ú? ²‰|´ŽÆÍùøËf o;‹öÞê;ÒH¸SÃÁOLà’FyÓýÛ>7_Ué¯e¯Þ}&‹»^\i:•MŸQèSÆg²,£ Èwß ,衸ßÜÕôƒÛÝ¥wE5,-¹Û/Hl1ð¾ø 6Ù„EááðÐO·Ñ¤ùº”í±cX¿~Œã­o7^ŽÏ¬­‰|p[J+nÓlô­_¥æ®¿ ²¢Š€¤$……(¤qsj‡â«.¿åG¶dÝà°’‘z• @©ÒmT8í«Ä’Ï©³Åž(01¤‹µ]žôÒz5=I8™\Ù“¨¦i胇¶ÀâÔÓr|7Y&%!‡è®XÛ—´ø‹.×BbÜ%dM]»ÇP#<¥R!ÕþÈ[!õ»´ãäÆÕxíÉ{|Z®|ylÔCì<œO·±s“È.ågcöwT„M__ËWJ­Ë9|cº0"¦(ýú£>dû¨’½GøZíú ¸§ÌÏ‹% šµ¦ÜpÿïÌfÙ€i$õøŠê¥ù’ZnûÊÉt_°”f:ÅñTJ ÿ¸CïŠhh2™Êœf«Êª}Û²döqvÄg±`X÷ »å«è6o1Íw]ÖZ‚Òñ o„¿ÙН^ÃñãÇËu̽u«“‰<””öX~iy_ÿÁÿ' «ß7ÀˆcÇ*tÜ“wyäQhXõô®¨†*•ª„~ΆVwú'n—ÐvOò0ðð¡C>v¬¯»´2#<$•œU‚‚rŒÑd_#­û[òRI „†ÿ( …[|#‚kRX¶ÊŠ€ÄÍܬЈ徆©¢f:¡¡ÐPà> ‹/ïÜ ýÜ«aY£%%á!q/f³ù¦kˆ‚t÷ Qñ¼¿Q9 î×Ðb±Ü±µ€·§¡3ÂCR‰Ù³gÈ„*ÀʉÐPh(p¿†TÅ5T$&&аQ [ï²@àv„‡D ûá!@ànÄ”@ @ ‰@ ·óJSaÖ IDATxœígXK€Ï¦/½KT@ìØ@°‚½ b»öÞ»r튊½÷ÞÅ.(*WÅ.Š‚RéôÝý~$Ä„¢"Þ\çý‘';{æLÙ9;sfvw°„„@ jÇñßQ]h¿;â;@‹@¨ ÷»ó€@ ª òcuŠuY,¡N ?P'‹@¨50*î3áúE¿è·~KKKƒŸ Ï„#‡ÆýŒQ}0ô\1ñïgÈ̳;‡A-ô±_óÄŸ‚"L‡t±á`?“â@•ÿßãg-¶r~ö¸¿Ÿ­¥µü¶Ö©ùÍ~@ÃΕW-§÷dĪñ¼•ƒ"ÿy‘×¾…Q+¾q"ü-¬è,¡¹h|[ÉÿÏáßse§˜«§6óßv+Ÿø&oÜÌe®§¾ì_ú4kjÀP©ü×U¾°(ãÔ#r\7sÉáÕWbŠ’üïݽ™FM­R¤hŒíæ{š7;-žmÚB‡^‰LåN¥YרÇ××·Ê<­[·NYí ‰(+mO±ÝçôV ¯"^Úôüå¥%Iiˆ¡©6€[*µypMóû¯ñ«!;³švÑ£K#ÿ“`×ÒÆ„_y!ÊÀ9uTß2²?¥Å~ÊNLÉÇ´uÔ5êØÆ/ß^?¾J6åÙFCÅõ r–í{ µØÒôì·Õ]t@P’<}k|ø˜¹Êo¨FÀç[!‡2E²è¤¸dãúú,"9¬ÍÊÇè´ÄÛ¡ëÄž¾½Ì@$"Äy6ð¥«G Z…&ûáÂ-ÿ—%ö=»-pדgü³`_áþU½¾‰=~~,ìó§/\’fl^§G·V^.Æò£1tõ4ÌÌM{z:93ú̓Îm]¾sm}ºê”ä/œ¬8ò,X>¸ž’™•©Xuss£Ñh†ÑÊüÇ0 ð[·n½zõÊÎÎN"°s˜Lƒ‹­–P±šœ,:Ò1æ,ü~¸ñ˜¡©yøÐ]É¡ˆÇ%-Ûî›l ‹ÿ,PÑw™6wÛ5Öê»Rù³:\¼rYG¶/Ëâ®#¦Ù˜jkÐKŠùÅ\G(Ä¢Haè•.Æ<œë„ƤͪÿôQÌñó&¹4ÖûfŸE‰…]•Å E¤¬Z„õõqôº÷ Eòx<¨ÍûîH"óóŠÈÆ™üë‹ÁY-Û;Ò„’€Ú¬| i/^Òyñò-zý¦¶Ðìëá"nÆÙ@ˆ/ähVؽ”ä•ä ñÈ3·:6êפLŒ[Rœž]$ËaèéУ±Å=¶1ܘÍ/|ñ6åä±ïrº/ô0”h(˜®œhCQDaAIÌÃ׋W¼_ºªO3­r‰þÎæÁª3³ÑÓ¿/¦n`¬R¡ü…+É+)Ö™7¬®¼€>Á'•”ÈüXë±4UHÌU&#‹%ßÇ6laÛð»*£RQá¶ð‚IëFö0ÞAß Ø«e(Izûö¿H¥›h܉+»Ú8Ž‹xéa1EÊ: ìmÚš–»¿ Zy%géÚþõÊ 7„¥«¡ã4†ÑÙg—SD‘Ç6\}eÙüÈ2G(Nº_¿c§æ;5´iû³³:ÈÆrt ‹–RÌÄÄ‚¬‡ïð͵àË‹D¾c}[­K»²šdÑ1‹öíWy耰øÓ„™8ŽÓ[2³‡& àÓ ½"¶Džän‹.]¶Í/ëÓk³òÇ­ü—v.­cˆ—•,É€O» ®ØãÉ`Ñ1 ½æƒM£vìêïV’¬ 9t hÍY/#ÇäŽôî]†¶ 2J·¿I õ±dcÀ¢c4–Nc{ ‰ÂömìÒfŸ>÷PЮ¿¡|B¿·y4Ü.}^dî`oK¦âpCá±èeèÒ²rf”|ëc•E%&Ú­[7Ç0¬C‡E)Õ‚DIp?&—*«’€ÑÙ ­u*:[Ô¥}Á ;ö·2ß~Ëm½HWòŸÎ )ßÉ#ßó,Æè)*ILÉQ8›ÿáó‡‡Ðv‰ƒäPT’sähxàëBýÝ[ë)Öƒ@«pü”ñôÞ­<Ó3‹YsÓq“ú’ð¶½»;…Þò¡Õ"{ ™p‡­»è0J³cž¥Oô©·’3ú´eÈì²t¾>zì÷QÚbšØ™@#³¤½/»œ¤’¹ñO ]GGœ¿£ò%hYÔ×’;Ì}“Íԡǽ,}¨BDôšÓáü¼ÐÿØ-i¯«pöê™d]«6eæ*¥iÿÞGû«Ö†Ñ˜¶,zl¦P!ü÷6¦†e7MÑñÞß4NÉ_¸ÊQPR¡ ’Uò¿S§N²pes•)–¤n:üRH¸¹¥,“2Çš­e¹g©+EO_§W™ÑN–†tìÙÕ[çðq4æ-º2lŒ‡—³¾°$)¼”~Ö°Â)(RTV$Z`ͶNÃé#€˜ŸµÿjÎtGnf¤èÏSØJ„ã¢c·œz¥ÙÄi®Ç—cŸUQ¤ˆ¤@§Ây¸y1Ýmê÷¦À¨¥ôÂ`c ­ÆÞ˜³ØËûBncEp¹yi‹ýã 8_,:x;ŽŽ@³©}Æ—¹aînk<53s¥Žã׬¢aC]%ÿµ µ3¯_ÛR63•x+× q ÉÿZ®|Š…D&Jä-Û4lRÖø‚ƒ zMlrð%xtª$ Š15ë­l>çtð›–^åÚ.E oˆl<,«Ì§Œ¢Ôø{ÅbgתoIµÙ<ÀÝߘJ+á¤ÚD%“¾Ý>ØzzVe7y%•ù±îÝ»×¥KÙaDD¤Ô7Å’ú±,«]˾¹I!!ëÞ6Ù5ÏBÂãñH1wÇñ••Æûöo”ýfÕíÂéKú¸3íê¼\uèêû¤ö³^˜¶q)óÚT|—cìÔ’^NBPôõþ“Ü¿zè,_Y¯»gs¦¨´0çäñÈÐÌkD·- >¡HB%ˆxY4:G[Äç‰@LQ„€Ïã‘ æåì-7À*¸Pä«+uA£îÚL¦Ë40ê0Jâ‹xþë+Ÿ5º#K.æà8΀K[Ÿ4èÙCOSkŽÅŒ}{û{ꨚ)eÑ1À˜’¼M\Ð!jÑݽq&Z°%~,É¢Ñ0àfÒðFÒÌó…Üײàù³Ïζ- Ø,:4Ž©±.FoäTßËÇÌÑœ­œµÙ<$áºf,RÄU¾@ ŽEÇpƒæÇü«Ì¶¼’*üX ÃäÇÃàîî.ëce¨||"ø#×j¼–rx5¡Ñ5<í¿jZXØ0=l+0W’àÙy‡²ršP_±‚ø¹yt޵ÃàÖ›0šLùŒÑ-+Ï@üµDãfn ±A¡w¨GG4À0¨Ã€$eÃÁ2Gê¶t•™+).>•&h:¬¬ìù‰OŽïÐÈ’VºlWÚº¹î¤°hÝÞgsfôТci±/SŒºZ—«¨—ÿ„‰ùy…Y/¶ùP˜ÈKÏŒÙÇbëØõóÌŒXb¡âôµ„Z®|xu'ìZ®áÁž`Þ®«Gè¹ù‡^nŸØ¼ò…Y¶®µß@³yÇï\l\–4»³6ãÙÃ4èTÖÉèÚ/šh³f$É"25L‡ôüŽååZn’CaAc(‰¡Ò §Œ¼Yר¢R%k9’ÿ‘‘‘‘‘‘’ÿ$I*»²²”eä¼*¥±­™W‚HBpxóÕgúŽÿW§î~ÿ«·³tWÍm£\˜Øà<“VF€U¼D¨¬P\²÷Y‰÷ ¹©yJt*pݱßü¶ãÚ€s ~¡‡ÖûÓw¿¯R¿M·îºÅ«/çÊB†¶(Hzt)ž+/F‘"©b¥zEø ÍJS…,-åè]8•È+©Â¥(êÁƒû$IòÞ½{E‘$Y¡[Fnâ'ß=/݇öÖóy?²n_~^ö‰SQ1BËÓTè£ÈÑoÏÅåë[®^êbNñŠ’õîõîxlýh¼'G "功Úy“jìÜŽ)âñD ¦¨W®¾c[®[ÞÚ„”&Ñjd›¨}a>×ÄN½<\X¢ì”Ìçï3""Þ&ã–Ëf5–iËzËÖ²ðx¤Pe•æ4¸[ÓÝ7<¤æ-ïç¬_n=–ñÙFúVoJ[Œ1¶2c‹µè,\ÃÊL >Éù±Víµ²Ã¿ðz”»‹×fågÅ|XJRÏ\[èÍZèâ¢-õÆ0ÝåK:…åé*W» €ɇ˜Þ6bEE×ê5wá\|rëÅ/}Z¹Ù™iAjzÞí g9&S9ÇPâj-/ÿ¾æOž—˜÷ÖTÖ¬pá„%äD<þ(/cdoÑ€)(©ÂÅ0Œ¢( Ã$¾«Ätå;X•~lÔ™àM‘ÙûyÌîTá-¹úDߌؔܢ[›ý´U­É§Üö¿ÉíÕ³Óènõ”dI¾û`ö¥/>“ú9êj¨ˆ\†‚£ÂËûø‚´Þ1©)^–¢““^n¿l¨[. ·Y¹¢^R>YÏ€ éñoCâ˜zwZæb%?x¼y-Ƕ¯+›IOÏâˆo¿JLÎIʦï[9Øêj䎵n¹·ªßÚFÊüX6“ ¼x÷–ÝI[=›Ñ˜ªŸOgåˆéZIV­\›ñ®<䱚”¹‹µWùzùÞþûsþZ|gÃÊÃ…Yd ¡ÉaÐiEB!Š qÁ‡zM›•_ÆÐ2Ô1hÊ79oè7(eû#‘,Ð{ÒÀŸ û¸9ø X¶¶¦MÚ´šÞÃ^RR-C ®j^ߨSc‰Ÿ—…ŠÍ&DÅOÆLÝ{úÔ1Å<ð?½ˆ¶jéP–¥W[v/Z´H^†›q÷éâj^Ùh $9â™FÛÆœÊÅ~ ^öËÝ&Æ,4xQÔËUÑažïs5Gñ®3Ë[|BcóöÙUÜþnÙ0iOäi—Ê>r-*y¾âFPÿV•g QVxx„rxÉ—-^ó?½»(9–¾Ý¹s§¼Å´)}¾/VxM½ó0ËØ¼n½úõÛöéÓQº¯</Õofhä~FÍÛÕõƒhgÞx©S#@¨*,¶Ýˆñuø"…ÀÖ#ªÇÃââ\†¶¡ÊS*y»)‰1çôï)9djÚn9»«ÑO¶£—O¸¿³>øÙiÙÜ6·õ§(afjʧøÇ«Fu9Üaäé£k̘tܤמ.›†ù= [Þæ'U€à^ž2è2WÄ/C…kÕÖÕJYP$â‰ÍaÚ¤N=]NE޳Ñ1EB~%ŽÁÿúÓ·¾)>ên¹/v¯9ž0xµ¿›ÎO}­{ßòøÏ­F¢öQc?–Ÿwúô]²CqifF¡–¥¹t.Ž~ç{AëdgIQÖša=ƒug<šß±ò4☠œ¨ÃÀœ´.ÖâþÓβS‰'ïXöÙ¬ƒ:8¹ÛVûž‹.éßÖ²­Fû–ù×»Þšvž]y6ê¸ÿEQ7'º67€~®ÆÓvÄ»”¤„D7[â÷3ËË ¸Roͦí´ÊY¬†‰ÏÇ>²Ã·Û{ ¿3ïa§r´‚¸ IãåòùfK;Tž@Þë£}l[ßq¤gñ±¡›ŽEÞ´bKÛ4)Î[v&Í÷‘£bŒû`ïœéÿs99xŽÿÚ™6ZŠ^.!H¡s¾u¯¿ò F¨Ø®S–V+:†§ñ 9€aÃÒ½oº€u¿Kiý*]5/×­÷Ùz÷gµ •RÙzlöëFŠ{` âmÞt&[¶#Dïÿ¶—÷ZüØ‚·¼Vv_ÔKí±×C}ê`²³ïÉn¿Þ•MÊkø±BÒpš“={]œ¿pí_Kœîøw 4ºN_úMsZ<·—~ä‰ÙÆ4ù½X•w=$(JËŒ. §™pļ5æÃüE7ÌînÕ¯Zñ/CýX.>ÍqØÓ@Q 83ÝrÐ?›iа‡h´ò^«œK=<ç?}éþ޾¶l"9ÛLn[û’Ôi{Ó7ÇôÆñrQŒÇ‚2×®Ë_WõþBèãl:ŽZ4ï›XÂxƒ¦+eI[²é¯ 1Ù¡² Y¡g1Œ>ÍÎÇ™€Šìº5åÃä¼\¾í2§Ž¨±+Ï×ð7 Xÿ´6VÇMºoS…ÒÒÔèåsç^ŠMߺ _Ce~ÎC¯n3ÿ·?¢J¿‘Æ0²RÊ£°èÑ’ˆ¯½nµ•…8é°¢ÞBÿ õ&„ŸfÙcc+m¦4äm![_i@þ£ι¶úÚúšÒ†@T„êGÒcúŽÙ;hÓu™ÏY}Ï.kãæõÕþê£(•æçÈÀΣê/˜ßÉì»ó @ÒV/j;w¹Ã·!h³1õÓ‚bʉñ>†„„]?~pײÙÚw!l5êò^/™@ät» N’ÿQ0àV>¿úÙX9¨Wï’ÿbùãºëý’‡¨yTø±Á+þš}þÕÀY{6ôµ¬|ˆ/ H²¼ÛÔÝ60Ž7oïuŸ.(åè!K½çÜ*Z´#ptGk•Ê+Z•{vÜd¿,«î—öÈÉyŒ-]¾*¹ÈÇ„IÌÐÒTçźu/0Œ©olbj^ÃÑ}ÜÑ¡$!H=ðU°ÍÍ@’·8?77·˜Ëåq¨JÊ+OInn.›+ùÿ9`¶ó†ÃÕŒˆø·¡^~¬ŠÝ(óß\|«ÕÓ­^»¾@ò¥½‘öCG4)7I[ùŽäÅŸ‚ÓŒ=ʆ¦Ê‚¤c§ÂÇ­ò,/+Ì÷lɆYXJiœÜ2tøÕÓ«µšpzð°Ð¡1§WGXB|||Eo´O³o²üÍË:Lô,±úmooÿ»sñüwöåçÞëÚyÇŧWÚÔWñÈ–<ɉ‘½[[ùO¨Ë÷¬¾Vd±‚‚;­'^ôù¾ì"þ¨Åþw^ãv¹¼óyHRI•÷ ¼×‡z¼ð]æZ l=Ï—jDQ5ÿ©ï<é¶ê] ··1¡F½ ‡Õõ2ô'ÄŸŽz™ÀgT\ DGGÿî, þtþ;3OÄŸÀÊE þó ?P'Ð,'¡N ‹E Ô äÇ"êòcuŠuY,¡N ?P'‹@¨hTŒ@¨Èbuù±„:üXBøå£b1?9àÐ΋áÉß«8éæé›©ò!„0ýÐÑkÉ òo;ÿ¾ºYâ¾ ‹­V~HqÁè#‰ˆ¿üýØÛc§:ìÞ‘}å/aÿ.BQÔP¯‡¦Æ^ê$ ýc߯ÿóûë*åó?Œwçù6ÒAò˜ ËäϺnÜ7ÙLSv2£½{̓Í]ªÌ†˜÷±^Ãî_R?!Hñì9ZAÀ÷JpW=¶ìPy“ø_º<âDÑ «2އ‡GÅ'Iù~;+“ÏÔ)~ö*Aô‘g#âóxb~~ÈÁSâ6<¼£¹|_HR¤Çãíu%—Q*æfË’Ö²œn_Gˆß»áô×Raák^NÞüùO`â¼!?Ÿ>æ'‘|8o‹Ü"žž4W%©Ó®%s,–¹»¯PY—}«lt%ÿ žÊ¾DðŠ>¥ÒG‘I®îÖ>»¤”Ç&¥ÂÂô)}¸ÆãaO˜bti¾ËŸÕgÚõ°Æ¿`?xĈ ?¶W¯^E‘$I©"<<üãÇM›6U©®$}§«ÏÃgáçä¼Xä9–ÿ.fODà-úà£ÒMbKÄEEE墤†8ùzüÛÓ²¨°HsF RØtãæÞV/¾€¸ôµÏij~~R;4kè`áÚÑ£PXò5>$ÖÑÃà Œ´pŒ¦éîî.‘ÌÅ)\RLaQì˜KípF“Ã$¶ëu%öÁšØ¥=Œ:»×Aß³y“˱¯ tupF’;{ŽJ”°{÷îîéJŠódùLâ‹»–i€¨Uã¾:ÐÝL°’ÌÔtSÇq«{“g8ÊLV-l†Ém`kæbÄÝ›€ã½ªºD¨«´Õ*]Ù“KnS˜m2kR®³o×ÇQ£\Z‚¼ÇÃ'×À˜!w?·ðmÓJýFËî%Óïï‘…¤x?âZô`#iëF8w=.;»âo_!idÀ]ÜóœA;g___›¿ÆÓXu–ú×ÐqÞ:·ý׎°ÆÛH‹FE‘!“$%‹ (‚‹Å@AÐétŒç¬öé~ê[—}¬«]jÏÖ‹ö¬#IÇ—%_ t-ûÿ‰/Ö°ü¶¨£€†¥ÁÿTIÕ!Õ¤j‹U˜…ªHQöÓµ;> O^î Ž{÷Ôõõ½ôùê(;Y ?÷ѰÎõ‡ïŠ\Ò¥o÷RîµõÚÉÎÒYŠ !ÇæL¹U¶sIä|^ž:wÊÖc/\ðq雳&mWs&tJÛ¶=ËâQ}étQÀ€Î~©ELø_—`M€V­ZDtk:úÛ´Ò±^õàzÿ¼7{‚ƒÂO-íïp¬ãÌý^Ž›>7j|'ôZô,¯ãöMˆ[¶¡tÎéàeúÒ…V3='KPQå²t–yEgˆê£ÂÊî«ÂÌ“B,Šä/w¼¾×Þvr©ŒIÃë{oÞʲUrXðñþäa3JºúÞXäI¸~<×sdߢ‚ӛǴ–E‘­Ç€˜¢Ü†Žrוnl%澊]úX–Êõ‹îðE%ÏK3Ó'N¼ îóGE ÄÚ{V8÷ì5Öqêe¶ˆÏô½ÚK|ðZâï.¹‰¯ Ìl8póì!Wï‰XÑšYKz¯Ýá¬Çâñxšö CS,Ÿðx zÏkuý¾”vlmo–ÎbÑM­­­ ž¼ÆšÙÑì´˜‘¯²xÝL¤uXÞÍz™ÏÒµEp#~~,“ÉTîZúX…XüÜ{ïÆ'ÖtÁq¶ÓÄYF±"&G òÏú/]u ØmܺKËF01«Ž3Âs;Œ&<Ûûm¾|ÙÙåó®FíüŸR¥ˆ£/o· hÁÙ 0–ÿêù‹˜ü3YÜáZL¨ÛgrérßLÑX‰µ³ ë6¨'ío AòÁ¯‚ÝžŠ:ˆïG…Ý¿ÿGé°+9+™~eé´ ŽVý4ÃÁë¶T•D~Âæ~ãî Åôöýª”…M³÷N:2Ò¹ÎðÀ{kFONæ1Ò¦½:rÄØçàÄzÚ`ÞËB"º[õ_ëúèB–ˆ4aï¹²jþ9©ô†DÞ›=v=[yö¾—‹ ˜wbxvÞRÒ¬Ûô†8pô{­uþ{^`ªd“xû‰GC'Jã~˜§á¾©“nÍlW‹øÃÁ‚>~üXe4;;»*e~ŠðÅ œM!Gçàt¬òBŸŽã’GHOÈÂhtŽ #ᓇV¹®r”s´´é(›±¢æ¼ˆÞ=öœŠ:×ÁñÛžßñoî tŸâ{÷FÛÚ`ñ‡ƒö¶«I2·„˜ÝðÛ“Œy¯.é?ÓÅä7æ ñ_Y,¡N WÀu}ç P'ÐwžuŠuY,¡N ?P'‹@¨hTŒ@¨Èbuù±„:üXB@£bB@‹@¨ÈE Ô äÇÖ7oÞüÝYø·Ó·o_…TiU¢\i ò«1ˆ@R¹•–ýB¾ÂÃÃUÊH*”CR]j5»ÿä?±­RYlñcŸeÿ¯RÍ/û‘å¡(ÉGàÑm®ÂJC~lÍÀår©ª6+úÓ/¾ÊfVZZ*±LYï rýL-çö_B••†üØšÃá(ô«Õìdþ«ÈîY;TÙÌØl¶rK’$†af¥‘$I£Ñ$ ¨ ÒШ¸ÆP6Î?ÙbAU…TGFvãû•Yû—"¹UQ…a~î­Ç"êòckI5*8± þØ¿y^ËæÛþÂ]dùY‚Ÿìíô“zxY^“­Û˜–•Q"0™rwÿÒ/_áÎ.†ª?./ߪlf’ŠüÉÌÓÏL(‰1¬;âeE½¥œ[ÕQ,»²BnÚ£×x‹¶•}[ÿ»õ±Òœ ?ö×㸲«0WŒ ƒ³˜s¿WyrÐÖçfô¬S¥d~úyÿ½4¯DævÐÍÆž½ÌYô-}ºdï¾¶¡žŽ‚!üºpÄÚáWC˜Lé¾¾¯÷l:úþ}b1Á0³uö3gÒ€&ÀÑúõ½²Íˆ¡Â:äï_*›‡Ã!B~QG2 ü™QqìµÝ»/Üý˜Ì£k7°³ë=jþhOÙÙ7›&®yïqሗä嬛0å-ÇõÀžYºtÂŒ¥cÖ{_¸N§Ó«TÈÔà/ÿkÅùëUÿYl%•†Fŵ‡Y‹Œ{qÙ© Ñá¡'lßv)¹üy"ç+Weĸ·qKFt¹õ&Qñß ½çŠ€[TP*Va1~ã¿öÙæ®'í:Î.öºøT£þ“Ž] :»od—:;—xM?ò8Fž›;&ŽÛò¼²UGfœ¸>°å¹çnE„]=>©»Íñ%ÃF®¸"“ä~MûZ$ùO‘¥Û' É2_³u†Ä\àɦ)=ýÛ벫£cÔu½[âÔ/k³hæé—pæcJJJJJrâ›ÂĨAclllêÛ4°iԠܾ¼œËݼß?{°\YCÏ…‡ë6Ü4ÖwÑÿ ®­j/ O¹¶ò6>n|÷ºòÂYüáulrJjjjŠ„<Âáü™U²½K„¥Yñž(bÞ»9—ÓöFKÇÕé÷®¾örÖŇSš€Yƒf®öTêò°S‚1Ø4h1kñg·YŸfE4àЬ~jŠÔ[swG$M9so¢£>h{ŒXâd!ì9gõšÞîËÚ”ÚP¢#s½.¥9»¼Å®l/r1/~áµô᪯°Ù´ùI >O ­Ï®¥â#?¶f¨ÄM}ùŽglÙ¶kK¯±Çú ?{ý²iÙ–Ö"‘H¦®í ›KKØ4 E%I ’2ð.¥­Ç¾÷ìÀú¶ïL›É¢P$oñÚ+¦~cD"7ãÒšM)))©))\þ£ñs¢­ëY[[Y[Ù;³>ünåM'Ä"BšIˆD"€‹äóéÿlú4aKóvxå]ýFóÆ7Ò–k=íhð4 ‘ˆ o;H»éÉ×ííµìÇÞòXß~Á8{ÉÒˆ“¬sûÚêkK¯’Š D—Vú³:°Ù–ƒÉä3ïx7áÐ$!ÕQH×lÛ_—»#6sKÛª}–*A~líQ‰;aíZ™Xg]VP‘x²™fY€tÿ­‚Œ¤ø÷ñætîìù3ò?LÍ%­ëiƽλû<Ò”)½y›4(¿{Ï—ÐyqŒö'<­™ptͶìØmP=­‚Ý3w´y6K"Sšv­ó‡›ç0Ë”PD1IQÆ8‹É¤Óh ¦ÌY•ðáH|Ó$Qr1›ÛhTGz·1š(én©^›~,EÝÌã;Œh%ó?etmg|æÖ9:}Ð0ÀîmŸàZrâîÙÆÚå†9Ž}¨Ó~’DC5@V†KŽ&Ò]Í¿+Ã*A~쿎žæšaÁá7.žÜ¸rñ_Þý\œ»%¯ïî=ißùúu4òõÝt0 &úþxkqݾ›d檀 àñ˜Ew=×/—Ìܲu:NíÓ­“‹­…†LFTüf²×º™Ç·×‘S"â¾£3 ÍYŠjEÅ/fù߀¸ ž~KÉ á1I8T^(gnZüw×EB3HŠ2h¡"«zÍõHQ^))í¸¸™'V†i™cÙ'n}V|—ÉÓk¡÷½ ZèsÓk¯øÈýµ‚/ÎÝJIINNJþô)!%³€þyÿ]Ïv¶N>úÛÙ5¤c c½äqÄø|iØŒ8ËæE‰§çßâØF¥NR”³ÊgÖi‰g³J’~±{•ð»GÈm´‚ÂÇL­VÊÙÜ9vZ’ãRHˆqsé­Æ2¥cXá»BhnTIBb¾bë¯eèls†å=ÏSÎjÞÓ<CW³Ìgà _Þ®ûr_ii2ÜñÛb[²€ÀÍðïUˆ›ã„@añ‚üØš¡"?–‰#ž%ØØÚxþ¯‹­­pWÿéæ›×N—E”÷õZ5Ï<+9¾ìÑÜqãŸjV666aÑr³xe^kµ7[@cÖ‘÷uäÇÖú±Ìzûwl”‰ ‹úñòV0˜sTÎÕê˜zñrf0™cÝW´WòXa^äµÃKVŸ0í2öüÆÙFªæf™ Œ±Ìíd*jH_{/mÆ]g‰ £×þµ)»x‰6›ŽÚ¬˜žLô…®7o=ò¤Ïd×oýù» Føzû¤d²ôC[¿‘²¯[Ëë±cçµ»ºdÓ·=¦65”¦ß]~.‹;øà ‰;*ñc%ÿ;Ì=:8¦Ûì1‚.­Ô¦c`¯ÅŠI,•9®ÕQ¥‹ÙzöÊîîP?Šk†j¾ÀÒq5 3cŠ…mµUlÙNçÔkÎH~Y*j¦Yîñš„Ûçݼ+Ô³™´ñÂäÞ+ʧN}~öåíGÌ­ µHai~^^^~¾ì;»Ep7ö‚ξ} 92ù˜9ý_hu=w{UC\ÚšŒ°N? s¥«;VýwÍòÚ<¾ç—Y‹û´sÖ¦EEÝÛu(ÐyòÙcîg6˜ÑH!'òsoåVÙ\e†ZɃµaÕkˬ;ÿÛ5Λ¿Àw@û¦ZDnìÝ‹~»› \µ¬­tÎ “*§sæßó´ëè‘Ë›_÷}¬3N½Àf:U_!ÄDd6˜êðVF¾U$ƒ,¶fP6× L—ÖÇs3“ÛFKõìë+™Ü¦õË=‡Ä¸\M§{¶kÄÀ ’Ë©]w‘ÿ|­¨7Oâ KÄ$p8šÆú4Š¢¸Y!„ž—6 •EoêRÿ“öà½K¼9´oïʘwËõ[“)n"½i`cýZ¶ß¹íì™{Ö”LKÛfsw\åá(‰BRe 6u2¥”è¯òõ`yCUÿØ3O£·\nrmÏŽ³Û6~Ð4¬mŽÙpfŒ‡ƒLËØÜÊRGvHÇöï›2~å‰Q®Ó]MÌk$¿)»ÓÕz–? Mù±¿JÌõµØ*g’P)P²#‹­îß¿ÿ»³ ~<|øðwgAý@뱄:üXB@ïÇ"ê²XB@뱄:üXB@£bBø?D=3¦¬Q´TIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/dialogs/Makefile.in0000644000175000017500000004002613367273152016455 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc/html/ja/dialogs ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_htmldialog_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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)$(htmldialogdir)" DATA = $(dist_htmldialog_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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ htmldialogdir = $(docdir)/html/ja/dialogs dist_htmldialog_DATA = axis.png axisbase.png axisfont.png \ axisgage.png axisnum.png axispos.png data.png dataplot.png \ datafit.png dataload.png datamask.png datamath.png \ datamove.png grid.png lgndarc.png lgndgaus.png lgndpath.png \ lgndmark.png lgndrect.png lgndtext.png loadngp.png \ loadprm.png merge.png pageord.png prefmisc.png save.png 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) --gnu doc/html/ja/dialogs/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/html/ja/dialogs/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_htmldialogDATA: $(dist_htmldialog_DATA) @$(NORMAL_INSTALL) @list='$(dist_htmldialog_DATA)'; test -n "$(htmldialogdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmldialogdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmldialogdir)" || 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)$(htmldialogdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmldialogdir)" || exit $$?; \ done uninstall-dist_htmldialogDATA: @$(NORMAL_UNINSTALL) @list='$(dist_htmldialog_DATA)'; test -n "$(htmldialogdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmldialogdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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)$(htmldialogdir)"; 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_htmldialogDATA 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_htmldialogDATA .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_htmldialogDATA 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_htmldialogDATA .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: ngraph-gtk-6.08.00/doc/html/ja/dialogs/lgndtext.png0000644000175000017500000014660513070106167016751 00000000000000‰PNG  IHDR-â«ÝkÙsBITÛáOàtEXtSoftwaregnome-screenshotï¿> IDATxœìÝg@Ùà3i$tP޶µ!vÔUQQÁ.ö.6D+"ˆ õ©ØÅ†+kïºö†bC\ÛÚPQ¬iJ'=ó~CI@„$Àù~ì:wÎܹs3ÌMæL!âãã!„R‹ÅRwBÕ\u7!„P†ãB!u¢±Ùlu·!„PÍ…ù!„BêDÿïéÓ§êmGuåää$ù7v2BI!i2Ó¨•x°“BHLr„,Êa¢¨2Èô*v2BIˆ‰Eù!LU™^ÅNF! ñ!¯ÛF!¤N8!„R§ÊÍ=w¡ÂëÔdú÷•)Áü&¨iû!BšIѲróC-›wèС«U±˜˜˜† –W²1?¤ ªÇ~ˆP•£èI“dYXX(HNNVMKB¨šÁq¨Lp˜A¡J¢é÷©ëõHÒ“e윒a˜Ò4, ?„ÔBÑï*éÎÉÍÍõòòÚ±c‡žžž’0¹%ØÉ¡KѲ*]·M çPitŠâÙe©BÙ,)B¡ÐÓÓ3**ÊÓÓS(–e‘ 8uùÛÌß©ŸûhÌØ‰Šæ¤Ü¸Ÿ\ dñ¼/·ï¤s~§!$Ca~(/áŒûˆP§97©WT˜x¦ÏðÐV¾û6 sP´`% L,êÔÒgÐ.›óý[jVÑ¡Ð¨Ž¥i-Cª4º  û[Rr.OT² ºŽ‘¥¹‰“!âqrs¾'¦d–eVIAAAÑÑÑ´zõêßß¼}“GžÉý¹j7bã†õd éü¸»g À¨d%œÃ"ÞÊÖn9b¼‹¥t‰ŸvëÖm¹Íò’¼ú-wþ°³óxEM=tr‘oŸ«wwšÒªÒ7„&S˜¢Öî½Èeç”yCuºÑFŸ¤ˆ½`ðÂúƒ—÷µTåv–i=«ZDâç¹–®‘µAƧdó€iZϘøúé}.›GPèu¬mìÞ½ùÀ'Ié( #‡º–ìŒÄ÷Ÿs)ZºV¶Vv ü˜’£|–4Éö—,—;Y–h9l¬G S¨o§S2¸–«ErÈ_†ñïããâ^ÿ¨=xîк…5çg¥¥¥Iç'E†í}<ìñ^éB‡§¨÷ƒG&öÛÜA¯V`` ¸„ûã⬅goÛiÍ(u ºmøsÝÈåÑZ—¬!„”(O~Èué©A7ZÏòÜõìÂàßµÃ/~¯u>ëÑkÖŒ–^jOŸo†ûˬ‘`3ä6CPë{")âemº»»»¸0/):¹öiªSô»¹ã¢e}’=r`âÅ–¡_Pžû‡ªîÿþÙÒ¾íäidž¬oÿhÔ¶§#¶Ó/„¾?Û¶âïxåk;éWâ°DPXt‚Hç+‚¼‚ji@£d Dþ ´³½ÜkÖͯŒÍîïlâ½ù5t6Uí¡j¬ôû‡,û­u nv3]td‘‹tŒiÏâ{{*9WD&~çØÚØMÎåðÚf€JˆxÙŸ?Síê™[³ô :-7=9%#Ofy‚ WTldáŠH]EÉ,™t͸qã”·òÇðëù!Boà%“o¶ ˜xÓ÷ÆiEñÐËB;üÔeSÝŒØ×±¯c_ÇÅg?xvZüZ¿”Û!×ó<î^rq‡íô½k»—úÏÒ!bÐÌ•KfØéÐþK.0¦-Ïáð€Ëa³)ž¯è:å‡?g³Au»B¨Ê+ÿýCÿmþ‚lèföq¶ÏÁÇGfTj+åÊKù˜$´0±°1£ˆ ò?¦Ú7ÒŸ|cÕ²ªgªõíˇÌ<…Æ2µ°ª__ÿcüWé¡…q€A)v¨fP!O¤dïŒRŸ§ î½ß¼ˆû>Ϩ¹™LŒûõÐþóŸ?úôéSüûwŸS2©ŸvÞìÓºaƒ–{hذ¡®v±xî=gÔ&èQÑ)6Y…8?¤kè0gÓ)¡‡}ý–Ni{wS·¯\¡®±ìª™tÐb²X¬bã‘®ûï…Bý’r>_.ûÝAµÑ“<ñ³¹ëÔqö”ƒ.ácUV"³Ò“²Ò '¨Œ:â$AÐë™fz›Y ‘€òõ³qckSf|JѨKŠ8B˜,*]¼@Ñ£Ü|)â+šEUÇ1öÀ¿i Â,eK ÊÍ'ï6lØ×Ù­Q£†µxk»Ž·Ü½yÜ8ߌê6ZoôÖ<—~½ò þY=ª…¢ÕÙtu*Æ5Qhæ jF·Œíä¦s©ŒR¸‡Be¤ì.!/iêà%¦½×u¬£kíq|^»+ƒÎ&ÊžøªlA“þÅ¢kaÈÏOæ‘$P˜élˆO’T–LŸL.à3ëK¦ézf4RsøJgÉ`ùS@@Àoo\‘o·ÖœÏbµ1‘)§2¬þÞ¹)`¶×w—&ö–ÆÙ§Hy5dÅÝÙutNeg–ö7j:êêaÿ3ý|Ã(Y)…VÛF‹ MôÙo²ËØÔìØl-£?ÊŒBÊ)Ëöü/¯áÕµîâY 'ÿ5üd‡yýgµ¾½Í˜FI½¿ÌgóëI»öõ2dVjMí ?R~p…=£:V:DR\6¼¾ÈØÆ"/)½€Í Õ ¶…’ñ•ulë²ÈœÏ_@nbаU=3nò÷\*SÏÒÚˆý#±@D*Ÿ%MÒ9ïß¿‰‰éСC```…Ü?ߟ:1lÀÊK&"^)yFcÑ·[iÙíõŠ®  2m\²jÏ5ç Kö-Âe³@Ïqüù°ï®^9ÙáÛ½»Š#Ý?Ôh´mRD4Û·¾t¡¢üPÔÕd;?{q%*Û BUÝ/ç‡2žnݯåµÿ’K³X+Nmy6tÅâ¿ßìÕšA°³²²H³²óiŸ>Q­ÌmìLè’ÃÎOˆŸSøˆLˆÿdfafkWŸAPÜüÔÄé PiT²ðמˆŸýá#ÅÚ¼–}-KRÀÍËLNø–]ê,iÒÛ!~¾œ®®®’0¹%rûê¢Þ‡ž ™»gئeéAµY—²Én¦EUñr^ž¸œ¾üØýQŠÖ«ß7ð*§`WnmÉzÝ?ä0xF~H`mZzÑOdR¯Ž½½½¾v±üûeo*w››=‹Å•í¡ªNÑ’HJJ€§OŸ:99UøZãââ~óýcÒÏÛ¦P⇠F#…¡üÙÒ‘ å<õ§ä,éçm—ý=x2a2½ª¨“3_ÕíÓ©®ìSSù°w|—Q½leGÁ²r?G¸5yò„’³x8]}æà [å5ÄôuuÄÃåX»ºHï‡ø¼m„Ô¢äTrHTx‚¥e‰„¹ñè¥b G’ðftŠG*„”ϪdFM‡uú•xûqSíË».ªV]¹ƒ ݺ³›O’ûé¶õl-þåÃ]ï5ß7G÷/ïúBH–Âüòÿ¨ì¥Ì{€Ô¥F¼H»Ã¡ÐG—âÒ•|ôi¯"zmÛçHjô†(Uu[ŽPU‡ïú-âgl+!~žBUÿP]Wÿ)JX­gÌQQ[BÕM9ïBbå{lB¡RUú8SÙ«P¸¸8u7ý–ê±"T-•þ|¹ßac£0ã]-UíüPõUÓöC„4æ‡Ô£jå‡BH•ćD|»3B!uÂq!„:Un~a~!„Áü*`~!„ÁüB!õÃq!„:Un~èì¹ ^§&п¯L æ‡4î‡i&Uä‡Z:6ÿÍ÷>h‚²¿÷¡ª?_®ºÂý!̈́ϗûÊ’““UÓT“á~ˆª%‡Êÿ¼‘&ÀýUKxÿP™Ôˆ÷!Wîý!Í„÷ýéÎÉÍÍõòòÚ±c‡žžì›¼+.?$z}9à}§¦µÊÑZT]•{?DH3iêýC$/3«@î>›÷»u ¸å˜%M(zzzFEEyzz …ÂßlŒ/§V/û;ÞîôŒ×®Ÿ³ðìwŽüPRpñÊË_ªœŸûhÌØ‰Šæ¤Ü¸Ÿ,¿ÛÅò¾Ü¾“® 15Â]Tøã[b·ô½BÃ÷C„TLá8>ɽ[¯™¹BRºðÚB.ÝÇ%ó*e¿OŒ _;¿}}ˆ­W›Aòö/™ÖIJ¶¾±A- »a³C¿ñD%?=«¡¡áÉ ùg$’ïèßö##ËFm'ù•mVIAAAâw³FGGýâ&–"óe䵇ÀùÆ17µr°¦¦òåwut船˷fDðéŸÕ'¥”Z¹ŸvëÖmù³xI^ýrYTx¶d˜³³³³³sÇÎÝú{Œô ÜôèKPYù¾ý}ÒÊ»§šS¸‹‚èÀÒ©öµ ur­[˰YÏ ãsäÖP%öC„TLa~È#Äo»³çˆ5ÃOÎn-.Éz1ùàƒqáwŒ„¼ ?ÿœõ~N3×Ë]»÷ho£ýñk±Yg½g¤í9x©g—?ŸÞ 7®kbí¸¤c¾žŸ7ùtmºà•€,6pŠå|:àä6Ýivø“‹nùo#' šÔ £ÖôS>Kš¤s‚ƒƒƒƒƒK–Ë,K€4Ž@D yl6Ûaîêcmɯ5zŠ¥ä"±ÇOØ/8t#T‡ÏeóáéÏýfµ»ñ¿þæ:¤07pÂFë›BúØUFk V§'n ð¯Ï½ÃÅÿÈ-zMÞ2cøÐ¦F`Ø¡ÏöÝZ0¡hKÒ¯w·gÉí‹Û[Ë­üàØ °ò»´|€‰Ç…³‘v®c¥µÑc(™%]CO¸—#?´`ûy…çÙ©_¾ñú÷×OÒ˜ñ>ã:ËÄßÛ7\Èãð»—Úš† YvÔ¡iȈyóå™__ÓEùùÄÂKÚ^3ÜmÅ“›!·‚‚XßI/Û°Xt`P ª–UÛ¶mÅsÝú øÐ¤éú#I®óšv\´ì££OÒ¢GÌšx™¥’]4bÏ“žW{µ¶º¾ÕÈCS¶:lMÎ[WÏ@:Lû!Bš©ôüý°óÛêú[! áaèˆÛ‚V§6 Ïúþl›ŸŸß½œßMØ!´h ¾Ë·0}|S#ÉdÂÝoZú%“¤ Û»ëXÓ©Ç}šhñåý"…y!/2š/÷””ÔijE^LP2ë÷7¨Œ&-^¶ò'/g3ã“%“+–úIGr¼Ûyø¢Ã‚»›iKÏj14(úü¦ ùí$%¤¨`öâc±ôbßÇž¼/Ó€”û«ù&ÛèÑå6 ê4צç~ȆAבFù«¥‹gUü> áï¢6†Œ´˜û’ɼ„ËAílPlÑðý!5*å‹íŒ}ûÏ´p±ÁôÅö7AWŸšý<®å}½uâDL‹€UôÊk¨(ïDLOyqëôºƒÿ»¾IR~ÊÇåŠöð«{‚Hþynnt&_Ô¤UÑ…gU·³Ö“;éÜÞñŠfÁ{éJ"##•7¯GåÙ*€FN­¹™1xŽÔa1.±˜”ÆmÛ¶MŒ>Tà4¼«èÓyxbÏÂmú.S6O¾¹ò©œzŒ›é"5™pÙï­ËñžVÅ£ÈÝÓ]74ìã¿ `@»ÂY/·Æšuó~Ä>‘Áî6¬ðGUgïͯ¡³9¨cÐXž'7ì0¹ÃȯK}G侸ü¿¥Û†/=Ó߸Ø ßR£Òî¢ØÿµmtgÏõ-fa«%‰1íy >^ñR•àÄòE‡ß}JÎ1˜±l娦ÆâÂ/çæL:&¼úq-‹B »"^سŠý2¨Ï¢E½ËQ2K¦’qãÆ)oÞ‡ ¼ù¡¨¹~‹sçÝÛßW’º°q}„®ðÖŽ¡ dÇÿÏ×ûàCð]{rº[Ó×[n“"®ònçf=æs¥×–(‡-øYÈáð€ ¾wm÷Rÿ™C:D š¹rÉ ;ÚɆô%ò„$7óª¿É+HIŽ¿s?ö^s×·7è:å‡?g³Aû€ÆÒ·zöŸl·Ùcžå¥$õ^°}íìî21êÝÒLe½ȶÛt€}]ƵRïIçÀK·²?<˜;|pÓb㯤]é>þ¯ùgã:h)YÆj ŸØÅ.àn†ª |¾BUŒ………ò€äädÕ´¡ „ãBU3¨ZÂüPåÂüª@øþ!TÍ`~H~9?$â&$¥Y[—鵞B^røÞsS¦O§–»}¨J‘Þrss½¼¼vìØ¡§§§$ !M†ù!MÄË{ܾý° IZe¸¢^Èù´bÅŠ‰S§SåÇ®÷ ¼ûM2©eÐõØ>¿iƤò„’BK—ÿ…ù4’L¤Üx&êàl¡-)á DtZQíy_n?Õn÷§ ó×¶ªÆ \‚¦õ;ae¬A(zzzFGG{zz9r„Jů"¨ Ãq¨*IpñúÇlɤǦE1õ]ÝÛÔ€Ü/¸.›±nV䟃îÀ‹ÇþûTJÀ»½#æÊ)ª—äÕoá„k÷@$ÈŠ™·ýäíÔla½?;¹O[íÓ ¨¬|ßþ>Wïî4¥ágÅ$ß=0}îê;±Ÿu¬›ö0kÏš±r;HIXk ¿›5:::((hõêÕ¾E© æ‡*W©ù¡“öå D’I!÷3ìÞ¹]úû-…¦7~¬¼=¼zåëfCœM$³<==ßǽ•L¦Ü:ñ¶]]—¦:À’/šÉ‘ ‹$›²Ùl3<'Š+g§~"Ûq%Mº<2±ßæöL›Í¾·dðÊózë#δ·ÖŠ}½bÞÔ{Žt½nþ\3ryô…€Ö¿Ý7ÕGΧNnÓf‡?¹è–ÿ6rÒ IÝÁ0jM¿²‡•±ɇ\²\î$B óCªPj~(ëû÷L¾Ÿ÷xÿ‰ožûèN›6-3#CÈ~ÿ×Ûã'OÖ¢•./¨E%LZO^¾¼•¢Õ=˜qc!UKÌ  &o;7¹!p~\lÖí ‹Å¢qäôY}oÂܦÆ b}O$E¼lÃbÑ âÂçÆ¾—µoæ–õÛ9Z%×ê"žÕqѲŽ>I‹90ñÇt¡ƒcƒÀÊïÒòQ&ÎFÚ¹Ž}”ÖFQư2ÖPÆ?Rü[FUæ‡4¬€@ …yÿiZ×sÎ8K]qù§ÇnÍX¹t¡tpíV®=éµþéÒÔ;>³dUmç]\×Öµ'«–¤ämØ$—ÅɆú=À®Aƒ®ÝÅ%ÜÌ/”®…‘)÷WóM&¶Ñ£‹'mY´+W®ñ§5¢zu{HîŸdti”¿êQúÞÎæðýÙ¶Ç{,_ÛI¿Ø³æ …y!/2šÿå))©Ó>ÔŠ~(ðbµöe »:´NYj@¨ºÂqH#TÝuSNš{eÜQqɾµ¯Z¯— ³³8†¿ø³„æ]=°móî¨^sCü†88JÅ7òÞ{arC …! `ß…Ë@PiTBü{¨0òåÖX³n~’çý5ÿÊÀ-{<ðöš:fP=é@gïͯ¡³9ä}½uâDL‹€U5vâæFgòEMZ ÿU·³Ö“;é 5Š( ãöŽ/K ©¼1=zôøÝíAHå0?T¹Ê~â¾Þ¤•Â#÷½ê4ÌÞ ëmÄÞt­+j•ú¡ éÜ’æaw7$gw^Ë`²X,&BüL&}å u팥›Çrp^¸ÞyÞ²¯GÃV/^<:6ëÂA?Gñ,#;]!÷+î0b4VcøÄJ&p…zõõÊFc—¥xõê•òÆþ-£ªóCÇÖ}õ†¨nî.j[L|6¦Ì\’äÄÆÆÊêÑ(ÿ½|™Ç*ö9v#I™°Ä+¾.Ï Mìo‰–ÝdWmΠf¤qK6‰¦k3Ƈ÷Ýð­3Àᄌ›Î¥2JyÐYÍÁÐmnD§¼|úì Ä%¤(ÿr&Û¾“Iú6e©¡ê Ç! "ä&¾ÉQ~ñù4÷Òs)4“•+WÊ,róÈÁA —Œ4Õ¥¬zo¾)ý{¨D@}ƽ7Ù0 pòÙ™=†}&ÔýyEœYSC NeÇfkýñ«[WmŒMÍ|ÿ…ŸNâÿ>å`?›²†•±)<ˆ‹‹ÿ»aÆíÛ·¯ðÍBHe0?T¹Ê˜ ²¢Žï Ýa5haôæ‘qg6ÎÕoÿ¾Á3Æ{ôêâ¤Sü2b ÉçpØl9’ü‡'L¹·jüøÂïÚÙ¯SˆŽ6›-j4Ú6)"ší[„¼ä-×G¯½³xÁ§æ6_ŸÞ_øÄÖ}#çg㣮&ÛùÙ‹L½¿ÌgóëI»öõ2¬¹YpÛ½6¸ù„^‹êoôêõüº÷øýNS#œõ°t°Ûcú€ Ǧ)S2K®víÚq8œ/_¾888Lš4)++KüTñ‡‚˨ªÀü*”šzvõøÙë‘Ï]Øv˜³+jL'k¨36ènŸ¾›×nY;sT –Y¿I·.è(½”H‘Í10Ò!x" 3™r?;éüP­æ#æ7-ZœCfdæ¤$Pè…Ë: ž‘˜C›V‡N–}xäPÿ%ûBý¾¤Ótk÷¹p}ð@•!÷ËÞTî67{‹ ‚••E2ä·¡†Ðµ•=ivXç-Þ ‹F=&nÚ:D<+ïû÷ïZ¥†)™%A:u¢ÓéãÇg³Ùß¾>ÀIü)ÔäÏU-˜ÒÌÔ›o¹Ëßîݺn±òÚŽþk÷Î]öíòÑCWG™¥ R9¶_GR‚bêbTÊk·}‘=™ºR—c=ÚÿÄ6Ÿ:`saš‡iäÒ*hî…„ƒƒl€Ê°ðßî ÈgÓtŠÔ>˜«Ýy]WƒÂ¯ê.›ï¸”gë™ZŽ“ÎFMñØF±î ½ýoY”ϒ‹F£ýùçŸ !!,‘D¨ !’’’àéÓ§NNNênLu#Ó«ÝÉ"v^ÉÔÕVð¨7Í£0™4…çôdp¾ßìÞmóñǧ- š)à|toã¹4új‡*u·P\\\õx«‰I)W.ÇÅŕ嵭©äˆù¡ÊU¹þ¢Ò >—ÍW ä(›+C»Ã¡ÐG—âÒ—öVøÜ Gg{mÛçHâÞ¢™0?„ªÌ©Â/¿H­êºúO˜’”¤$fŽÊZƒJ¸}û¶ò€AƒÆïfI`~¡*F<Ì TÍà8„j„˜˜u7¡HîB¨:ÁüPåÂÃh…7„VK¸›¡ªóCªPµòC!¤JâC"¾Ý!„:á8„BH0?T¹0?„BŠ`~H0?„BŠ`~!„úá8„BH0?T¹0?¤ Ξ» î&¨Ô€þ}ÕÝ„ÊóCª€ù!MÐÒ±yõxÞvY¤‡»ª*ðùrU1ÊÄoeE¨jÁq¡*‡T-a~¨ra~U 2î?¸›¡ªóCª Éù¡×ÇÂ"¿æòmûÍÖDõkäed¾Ù³!iøêõT¿ö*JzÿÉÍÍõòòÚ±c‡žžž’0„4Þ?Tõü=ÓçxR^Érçãã§o‹&ó_¬Y³¦ÔÚ‚ï:ùÌ_ØáVˆx’ŸûhÌØ‰Š‚“^=ûÌJ&·lØÌ*  ¯¼T2ÿ¸gŸðׄeƒO§H RnÜO.ã DÒ“y_nßIç([¯Z‘îo†•±¡Pèééåéé)*ý Òx˜R3΋aoe k·1ÞÅR¦Ÿ÷ß’s/®ÝP²’¼ÄõÃF§|s\<ÉËݲe‹¿¿¿x273“O’%—r§ ü‰9Єü´[·¾îsï„á)Gÿ s0OnÚ¸ÁyÊ, UQ|t船gŒÛõØY›F‘»úc–Ý_¼çÈ¥-Smq‰—äÕoá„k÷@$ÈŠ™·ýäíÔla½?;¹O[íÓ ¨¬|ßþ>Wïî4¥©ú+T“&r~5:­ºt`€-$ß=0}îê;±Ÿu¬›ö0kÏš±rÛ§$¬Œ5ˆEGG@tttPPÐêÕ«wóRÌU®RóCìü¬´´4é’ü¤È°½‡=Þ+ùbÛBÐüú÷OÒ´íVÿ½¾‹lŽ@$©œÃáK¯kHÛ–±ü’m³í³õlogÝ1âH‡'·…b’rØl¶–¤„Ëa³i¹Á±ÇOØ/8t#T‡Ïeóåo㥽 ^ýûA%„œÂUÞ™Øos{¦ˆÍfß[2xåy½õgÚ[kÅ>Š^1oꀌ=G:^· ®¹<úB@k¹«®ÄLŽ +¿KËG˜x\8iç:öQPZ=†ô"JÂÊXCÿHñoUxÿ&âfß\ñ*+üHc™òýÓG2‡ìšÜM| r¿üQ{øÚeúøh FɸóÑéöídKIáÉ{ñ$BöçM›6@R.¿ç&­ÂqNìØÊ"ÓÖ!’qˆûãÅ _Mt7Ó–­\é6¦Ü_Í7™ØF.ž´eÑ®\¹ÆŸÖˆNèÕí!¹“aÐu¤QþªGé{;›À÷gÛVüï±|m'ýb‡ìJ•½`}¼É«;݀慼Èhþ—§dnö¡VôC®°—* »:´NYj@¨ºÂqH³œœ»È¢÷&WC-é»§­|bõ¸›¤äÃþëV}CW#$(Ê>Y!÷뱌‚°æÆ%æ»§»nhØÇAÀ€vV@×k}áÂXѺaÊŽ#…ù!ÇÒÚþï3笥òCO¬óY¸MßeÊæÉ7W>ýåm|¹5Ö¬›ŸdrÞ_ó¯ \ѲÇo¯©cuÑ£ÒÁýM¼7¿†Îæ÷õÖ‰1-V©p-á¸ð†¸¹Ñ™|Q“Vµ$³ ªng­'wÒAjQÆí_– 22RyËzôèñ›Û†êa~¨rýÒ‰û”Û!×ó<î.–óq׈uïwEž4ñÄÅ"afà¡ÄyQõŠ>»âù¡¼ìT-{%ëz±eº¶í4)Ãáð€ ¾wm÷Rÿ™C:D š¹rÉ ;ÂñL:?$ä&š±°°=Bvüÿ|½>ßµ'§»5}½å6)â*Z»Üm€ÿ’ ‡iK µމŒl¾c×öyãÖ‡4ôô òÞV¬ëh”þœÍvÓžâãKïÛ ”=ûd–I¬Oáe "^سŠ]²QŸE‹z—#]¢$¬Œ5À¸qã”·íÇ€˨êÀü*”ýþ!î=gÔ&èQÑ)6(Z¤‰ß•;Ó™-øzǨÌ?7¸™JJ‹¾Þ^ù’Êóò>3tš(Z— ÿÅô¯†œÙ/ Îé:ÌÙtÊcèa_¿¥ÓCÚÞÝTø#ŒFT&K¼HAîcºN Ÿ‹‹h&\“þ×ûÕ×£€BP´ä®]Ñ6ÀW®P×ÎXz)–ƒóÂõÎó–}=¶zñâѱYú9ŠgÙé ¹_ÕµÇþoÒQ»'m~ž¢¤±À'v±‹§¸B½úÅnëQFc—¥(ÃóÄ}‚˨ªÀüá|0ªÛh½Ñ[c<ò\úõÊ/øgõ¨’¹ÒƒP^ÂÏ͉ëö”^œiÜw®OÑä«-¯š-•»"‘ cùØñ¢&“—¶¬­¤=6GŠqMIJFoÝõÐÿ;=úŒaý)’YºÙº ó~sÍÔŒ49·ÎÐtmÆøïp྾uøÝrÓ¹TF)OZ«$yI»w}ÍÙ½¬•¤„¡Û܈Nyùô;؈KHQþåL¶}'é•„1tmÊRBÕÞǪ~Yq7FvÓcÙ™¥ýšŽºzØÿL@?ßð%#9÷‡¹ú ÙyNI.„—ó àö7· v%g‰ø)ƒ{ùäpèø"…7þüD¡Õ–|å»k^ª·bÉÓÞ‹äÔ¯„x³]–(ÚÆ&úŒì7Ù’Éggö|æ]nÖÔ€\ó—›­eôÇ/5 ¢Ü›·IÇtìXS©«0ƦŽf/ÿ%)H¼âŸÂ§,ëgSlI%ae¬AJ@@€åO±e© æ‡*—òüHylã’U{®9OX²oá.› zŽãχ}wõòÈÉßîÝUüþæ¾ùþ¡õü{·3Tôa ¹ÉË{òÚÌšoË,Còîß±nCxšE÷#WCí)|6[öŽ"å÷ý¬GxhQ¿G¶ãï;ê)ŠäòEÒù!É6v¼/`¨¢ml4Ú6)"ší[„¼ä-×G¯½³xÁ§æ6_ŸÞ_øÄÖ}ãÏ êj²_a,õþ2ŸÍ¯'íÚ×Ë©¬å‚ä^O´?E¦Øm÷Úàæz-ª¿Ñ«wÖóëÞã÷;MpÖgÀÒÁné.›¦urrRw“ª™^ýNÎýx9ɤG£Ÿ·×ÈÅN‹ <œ÷?ß%GRÄÉiÐ A ä~Ž8pkòä Šy±A[ž,X0ÆXé3uÒ¢÷øÔÙ{L‰›“JsÀÃéêè3Ù[i>›¦Sì¨ÐcÔÕx”½æ¸¸8Õ¼OÄcS¥J”Ì*û{ðʆÚI‰xBÕ g×§Qi1,ÓüäÏ"(LƒÒRT­ºJ! é6ùߢҟÌmÚq¼wÇR£äº+tg7Ÿ$÷Ó–R?æd!ç£÷šï›£û—g•¯,ƒò°2Ö€Pu‚ù¡Ê…'îv‡C¡.Å¥/íÝJQÈ£³½¶ís¤ kfOâû‡P5ƒù!UÐä÷i º®þS¦$%)‰™£²Öhñ3¶•?Ow3TUàýCU1øØT-á8„j„˜˜u7¡ÄÅÅ©» U<ÌU.Ìi…7„VK¸›¡ªóCª€ù!„RD|HÄçú „R'‡B©æ‡*æ‡BHÌ©æ‡BHÌ!„R?‡B©æ‡*æ‡4Add¤º›PáSP¹a~H0?¤!úõë¤<"‘HÝ­«b¤{ïÖ­[¸W£rÃçË¡šEî$þ‡º›VÅH÷¡ºÛ‚ª‡P wøÁƒiù`סЅù¡Ê…ù! QPPRPÀƒéOOŸ>€r¼)XÒu¸W£rÃü*`~HC°X¬’?ƒð¼œØ¸qã~õIÞÒC8îÕ¨Üðþ!„Bê‡ãB!uÂüPåÒ„ü?ïÉ4ßÝ{ÿÚ%w.;5깨}{s…§VòîýÇjÝ©6³Ò¨ ➗ɉÏËñ":­J~!#Eù/=Îשۮ©íonŸÏÿµUKÏÄC*7Ì©B©ù¡ÜÌL¾¼ü„®‘1ƒ(¥òOÿ¬~b9Ñ£™ò0‚}÷î=¹Ÿ¯—4}è’ ×î±XZÏ– ›q=Q&`ÛµÛ ù ø_½»Ó´j¬ÅJ懄‚ÌýëÂÏÜKËÙ6jÖÁuâ’éÝÕÝÌRÜž{\ÐeÓªþ@ ³çëõÃÜ©vö–.Oú4ÿšétú/Åc~U¼H# m×òe¾œ¯¢uûîŠÞÕW¦0ùÊÉÎý;é3Ä“¯^¾ò›Õîš÷Æíþƒi¥ ZrÅN´³›‘pÒ“Ò Úìí'PIe麅¹¬µêqdpÛò¬CSÝ_>zÝyÝu{N·³bÄ>‰^µÀwtöîCþÎên—2œÌŒïüñ¿ÓŸ]y'¼ÿâ¤!•‚7â¢* Ç!5»ðê°Äï¡Gs]æ– ~¶ò”CÉ8Ôoñ!›F!#æùöɬu}MIØç /i{Íp·U¾jAAìô£ /‹¾GS™örŸÑÒzÁ’ŽÓâÍM Sq/6­ºÓxü„†_vìú›ð\7ÏÁ þ¯µÇóû-òiüïÆ•ï'ñr¹þþþtÝÖKüÍþoøÌ™3SSSÏž=[2`À€3gΔôæ‡P…Àü*”ãþ!!÷ë© vXk ‹™ùvfg[’Y‚ÜlîÐm¨„N‰ÿÞ˜[Xg›R‹½èûŠÖ夻ýç™:‚Í€¿}ûokØÇAÀ€vVâò÷»ßš»Ì•4‰A%D¼´7oÞHªÒ6kÔÈB[üïÁM½w~dõ¨‚´èÓ§cœ‚Öt¯:ûLÉüМ³o ÿŸË§S&OÞ·£.µèÌæ«ƒ F¯=7pVO팃[7ŽN4º¶¾7¤D]þç-çrrb¯Áýú:$nX3ÿ½Áù¿†Ù)ôég5wËúöuÞÜ;¼ûÚ!ªÌ™R1_/úZx¿ÿ$¯53­.Þ=Þ}ô…˜3u™Tñêîh¹Ç­žOv9ÕÚ€N§¿íʶKæ6·ëÒ£cÚý©õúôéCe˜ÿjv§$I «V­ÊÍͽyó¦ô\—U«VQ©Ô¢­Áüª˜ÒP/Ãfh×õv7f€QÃMOžÅåáœw=¤t;µÉ΀ äpÜÌû#|®ºí¼O—9´ËOî„Ξ9¤Ã~ÙkC|ìui/¿±ÇKG±œõòŠ’LÖ¿ïàŒFâ×j[+{,@w°í2©Em®Ú7ŸxýZóð»ÿ š¶u]ÃI>>à ÏËÕwŸæ\çO;=hÚ4ÅyÀ6€ÞâYï†ß»ál fÿ^šý×Cf'ä§½È绵q²«§oWo‰ûX‘ óó×LñR4–¹e­¬’1¤0rà§€s«GÙÀÍÿ=lí·ýí?sšˆL¾µpDø•áû˜À¢]§Vt©­»víZ±ÝB¥R7lØ0uêÔ‡ŠKÚ¶m»aÃéA¡Š…ãf俘¸åÅ3N4--¼=8mÛ§Îݾ@ghiiÉ]VÄO àIôX²¥§eɹT-+ŸÐöõ[:!¨åÝMÝ>rÚVÚÒ1:æ^ÿ>ð‘[¹¶•¶óñ7¶Li[¶ôY¾ÝkAÂéð !KǽÌ8>£9hÖ«ýúò–Ó/“¿¥de}r$‹˜´Z-„ v3CÁó÷@e˜oØÉg`ïGC†z Ù¥‰¤îssÛ)ެÓvÏíýJÆp³n|å n…zG¦x²D¢o‘¯áç8Dæ*9U6&“6zôèwïÞ5hÐ ,,ŒÉ¬ÚWí# ‡ù¡ÊõKù!‘àûʱã„'ø7Ò‘ŽLˆ>à±ìÕúëçÁÛE&?$‘ûñ¦çœŒ^7Öà_ ‡Ã“¬ÚÄiÐÁ›& Ùl¶ ’š˜ÍfˆÃ”凲“غiÕÝI”Ü?Œ:ƒ¼×ذß{îšÃŸrvùôÙûÖrÊäÁn\X¢G·cÂÅy ­(‡$ I‘xòÏÙÛ#Ýî?uzáp‡¡ÿÛ»¨–©×³gÓÅ‘Aáóù%c¸ìTè7tX½¢ @FP’ÕéØÔ—¾³G@’@ çŠH E¿zß"2õ0™ÌÝ»w…„„0™Ì’kÁüª˜R…²ç‡Dü”Àá}O&Ô?s/X—UxT ¾ï]ê»úä·5§/¸×5ºI!¨L–L%BÞ÷[Ç·û†›÷š~nÓsmÙ߸âüÔRVõ …Öƒ\éü4E-ä¾Ïe7¯º;IÉüÐó³z=FÛhQÄÇS‹¦†@pitº ïɶ¨Ä%wÎ4Õ€ï/Ïâô ¨’T BP$“æM»ø6í2iÂÙ6½<Ó»žVɬLLkÓ¾Z” ouþç\G â§åPjÓ©”’«AHJhÊïg†ÄJÖcff¶gÏEñ˜BŸ/§1H^Ô¡Ð^­;^t8}çpS¢$ñrð™´gî_òhfPü>‘¸‹æNöhÞ åôõ·¦l9m÷"‡ƒ-&ÖKºø°ŒÁw¯'ןRx²(å^ÐÀ/erʾ.µ“„ܤ۶ ê;óôÕ{Ÿ¿}½sñ˜ßÒguûÌ#(ZVÆ4êýȇ9|ö£Ë‡üg¿!E¼T¾PI弜Ç»ùеLˆ_À#(ô:tÙlŠÜ*Ã|çøÆçgM;r5#üþ%vÙ¨sö¾­Ìž¨’§Äâ+Q…Àüú½Û7Ö34u¬÷–Àéî2ÏP°év±À»=ç\ÎÏxóÃS·è{«6ñ*C·ùêKÝ:5-Ç}¬Ö}§ç¦ò'Õ¡S€YÇÆÎF~*BÈý²ûwÛÏ´“ˆ—ûãÇ®¨*=¦ZæIÛºùæsç·¯Üê˜ð¦cÜuˆ_È‚$IRh¦G×ÏòZ1·ÃÿDu¶Zxà`ß‘W38cÍ´u¬llê°$磆–u­k‘$I×k5¶o½-ݽf>UËtìòã¶?fI(Ši?ïÐÿôC6o ™WËÊÁÙuÑžÉÅËʬ˜fÖ6,q ÃÐÂÖÚ˜¬ ‡…ÿR=$>ªU(">>Þ¼yÓ¸qcu7¦º‘éUELŠ89¤–ìu¾Åò¾¼|“Ì×¶jÛÄúW›!ä~9päî„ cJÎ:<Ú9røÑ½ým”×ðáèè‰×=îü5èWW­!"##»ví*’þ7?ŸMÓ–“‡/ÇsçøùlºN)'©ÅðÙ|:«bN²ý’gÏž7îÅ‹e_Dº>|(÷Þg„J%9$b~¨r•-?ÄÒ–WZ<¤‘³I£ò6¢‘——üeG‡¯ßÛmÁA§ÛÖS8}ùpwî†Ì-Ñ,V•¹kµ$ƒA– þROÑÓ‘»H9®T¦ê˹}µŒ1T]u^ýK+݇€‡ôðþ!ÌZ.§¶üwås^RR’¢˜/ÃÝwëPu —¢AO.‰ýêy9ì:Tpªé̺Π4À¸Ùù·U)ŠF <˜Ž7pBj…÷U.Mxÿ'„@êHJD ?˜>{öìW‘„p¯Få†÷©B9ž/‡*F+yj¿Ô—æ‡PEÁüªA” B8ý*¯ÛF Ç!T#DEE•„RÌU.Ìi¼Á¥Rá^Ê óCª€ù!„RŸ/‡BHýpB!¤N˜ª\˜B!E0?¤ ˜B!E0?„BHýpB!¤N˜ª\˜B!E0?¤ ˜B!E0?„BHýpB!¤N˜ª\˜B!E0?¤ ˜B!E0?„P9‰ß_¿~[Æ`!/yçÎÂJm …ù§/ßæˆdË…Ü´„o²§œø/ÉGàtµ IDAT$ûÛ»· ù•ÝB¤±pBè—±ÓO¸ör+c°óiÅŠ‚hi)7î'(¯'ïËí;éå1jôùÔt¿é³>åónpÆÓ9}ÇGËÇn˜>|^QaÜ.¯)bÕ\²s4¼+ЯÂüPåÂüF‰ŒŒ,5¦,/+âpø øÓÌxtåæ§ɤ€óîßG#Šbôí»÷nUKüo!/Ù«¯ÿ˜ó‘l6ñ}ƒü3!hÇ™Þn¾Æ{W´ -é¾âü¸p­Àô•‘šš*.ù‘/²3%“ÍÐÖʰdçy© Éf,K]TC¼cà{ÁQÍ¢ä8«d©­þ³ß$“ö{ ³fÍ’Ž¡i7ظ¦°¤v«‰ÁÁ­Õö åêBIU±Ó&D¼,:¸S-Z´€6.=ûÆ4h¸ùØgW¯FÐzÁ’ŽÓâr Uj̘âñ1w½#ê2k;®»s óMh‹>[h4¢Ý’#¡Ý-¥ƒ•tNewR%ÌU.Ìi‡#9°Jd¥¿õ—ü˜:¸÷—ž|¾2ܰ™Ù‡çfƒ¶¹H—‹42oôÿ³œæGÙ¶÷Nß%34X0çgð“ͱu:{IÖÈ’Χ˜˜RÀýžúéÊá­ìnkºÔ–ônWÛoãìÖ†×%EÊÓ9ô‹¶^ÐÝVÈMlܼÿ‰'€ÏáZh' ëáyæêvÝâù¡£Sg ít(Bž¤dóÔ½ný-ŸñF\˜5Ãïßõ¤R>2Ã$)PMW ÕÀü*`~HÓ0 ¹çħ¤Ä1¥~L×®$Ø¿ô®Dù$ÉYºt)0 », 8¶4µûÿ;g&凸Y‘Ëÿ«sl—Þ¤% qIæÛõ‡òºœ¶ý8+½Sh×cÓ¶¿¹èßZQçhÑ‚(:dUjW ÕÀüª‰dKÍ‚Hd½Ý‘×䕽ÛD‹qã¶==å'uÂÜ#ÇÎË,ò,9fóÚÑÿ—¾~¹Ï°F4ÊGŽ@ÛJ[:XÇÜûòåñ¤àæŽs=ïwö ·£x®¶•¶óñ—7»lÊ×9í»tMá táÇác׺uë–ÇÙÀ¨ÐK]4xr˜Ÿÿæüñ$JáîÆ=žnm›3S¼ —¼hBø°íwˆ˜±Ð;tïÚýCþ¸ÔÏ^P²s¤UjW UÂqÕ,вe‡HgÕÄí­—\Ò¡-çmÓ¶Õ”ˆ®{&:JÕω•½FFùïåËŒJi0·e%íHåëœ!O[/ZÍb‘@€®QãeŽO5‰Ü8Z<÷ûk:A0¤—b2¨Áp6¢íæmõÈ®£„/VõŸ»ìêêVT‹Iß{sH‰®vÉΑÉUjW ÕÀçË¡š¨çâàÓÅm®N]÷mòÏ•ÍV j¯¹{Ow?qJ`ÔtÔíëáÜk¡]]‚dê 22óø@ 8"…k±î;=?1,•_x³ŽMíÈyóæÍŸ¿`õ¦/òêl<½ÎÃV¨³Wàsíô+ëàû;#ä²Á¢rg'ð„½¨CD|—d°rºHn稠+ H‰˜ª\˜Ò4¥>;®Â±X:¥Xö>½5öJª0))IIØ—áýÂOt­cP¡­+æ·:çWömÙPÅ}$·sTÐH5ðþ!„4…Y×¹J‹1n6ÅGMÑ<%;§ÆvEu…×) „R'¼¨ráýC!¤Þ?¤ ˜B!Eðþ!„Bê‡ãB!uÂüPåÂüB)‚ù!UÀüB)‚ù!„Bê‡ãB!uÂüPåÂüB)‚ù!UÀüB)‚ù!„Bê‡Ï9EÕßùóçÕÝ…úõë§î& ¤f˜ª\˜Ò=zôÉ;FKþCe¤W»ªÉ0?¤ ˜Ò,‹,AòlU¶Dæ­Û¸K š ß?„j¹Ãôx ––¨r½i,‡P dRý8$ó„j8ÌU.ÌiqÏK<’1Iõ‘üp—@5æ‡TóC‚ÅbIÿªS§ŽZš‘ŇCÜ%PM†ù!T£}ûöMÅ×)X[[«fEU-8i Rõø‹KûfênH Ò A•­ëíÛ·*[BU æ‡*WÙóCŸNL¶±Öù#³Ä“ªžµ•±ü:S£ž‹Ú·7/~>‡äóN'Š òîýÇjÝ©6³¼m¯VJæ‡x<ž*Àçó%ÿÅüBb˜R…2懄Ü/óW>lÖÌ)((DüŒ‡O¿ìõÖÅ@K6’—4}è’ ×î±X…³žÙ²çBìë÷¹Bšeƒ¶£§/ôñp0ä/àõîNS>½I6? C•  Óé’ÿb~!1Ìi£³Fp=v]\ÙSóyÒÒ•ÁÛhçÆß¼~&įïóôKy5g™º…¹¬µêqdp[Õm Bý"‡Ôïþ–±‹"…ÿgï¬ãªJ¾~n¼äÑ]R‚b€"ˆ˜¨Ø¹æêÏvC×n]»»u]u5ÖîVlQQ@°H‘îxðúÞßÏG]TÂÝù~øðyw3sãÜ™3±éð÷÷€Â”ë3®svî”0‡†í|,™˜ÊˆqÇ?xåÆ&Üšüû©—³¯„Mib Vu›¶u¥?̾¾OöëVž³G7ù5jö³º|t¡D-ù‡ª– üC´ê†ñ󎽧”ù÷®\dÂB¯]lؾÇK@žÿäQÔäç·0§ï®› oD*%%ìœ{ݨáÜ_ê 5“õœ|äÎdŒ’I$Àõh ^þè㟭, +ôÏ5Gcú.XÑR¯Z»¤jÈ?„@ÔB¨:(ß?D)Ò‚"ŒOßZÝÏwÙöíÛ™À7œVlm.€ì÷?µËUKEîykÙasH«òÿI+lôS§ò/\¿VfþŒø9€2-àìÙ@k;þ÷®5ò!µ´ÿP̓sÌ6ŸØÒX¯?P©¼J–y ¢SÉ>*)Ú¨yécêÔ77.Hˆ`~Ûõ>˜˜ÈX8¨% ·A­@%mÖ¬ó;?CBtm½Ç€Rå€n'u´©RhSdEp®%a¹¹Ð̬œ”…6B•4¦ÊG ˆ¯ù‡ª6ó‡äÁ·»yó\ÉSâä?ü¡¯–2åà© ¹‰>ðûóï½.h£%¥ A=‘(7Q‚sÌÐÅEþ!¢‚üCÕ›ùC„‚€—íN"`8ÇÄÒÖÎÎΫëЭŠòŲ§ôœpÁ›)ùïŸÚ¼f㽇LOýÕÕX¢“!»tx PAž ¾ ¹pNû9s^ߺ¡:6ŒHzxxÜŒÕ"âtlué3鯵ÃK½åDc“ÂÆmoGœÚÛM_ï!·ø ²² EØÜé­WlÄæ,¼¶}cï²T]°`A@@,X°`õêÕšgÑ;QY¨:(ß?D)³{ôªB«Ä0vÐû,S—¯Š,éÞïÁúzÜ¢PR'zHç“Ñdy¹Þ'žñ1g-›ÜowK€ìä ‰÷žÍ}hZžú1>æ]ЪŸºýÝvø‘ýË-9„ Nß~[ÇlŽð_Ôü[”»ö÷!{ë¡Ø­{ÇÑD|(BÿP ƒw€©u ƒÞZÞ¸oôˆä&n–UªO^ìaîã<¦í ¾Ò½à­ÿ˜Ætƒ»kµí_9ÑØ¤“+ݼ7b|D%tõ8i¹€a€cйwË#›vN™Y×ÑXS\m`-Z´hÑ¢’á 肨,È?Tóà„îš5kÔ‡…){†NI¹zuGɘB¢È.éÚÎYV‚{Zº>øô[Y1îøÇ¯ÜÔg ¾cûöí?ý<õ· ÞíõÓøéá!à9{qt“_£f?«Ëÿ7ߧ·Û{z7ªC„ÇŽAz.à888äG³2ÄŒÝÚ:ö²ªíБá ÀfêÕeCL\¾àïØyø³i^º\–ÑØ¤pâL˜‘ksßÆÜˆx iò osà’}šÃ¡{’€ fäÖ~ߡ竗tÑÌD•òo~ã|`¤»»»ú([ ä]5CÊBY˜™ž+× ˜š|Þ¥–òxµÂt´—n™}ý:6Þ·vóùeÎãüþ-u¹\}ß!†«ž¥ïoc ™!;–Œ°l]k=nY)|Ü~œØÆÏëu<¤æ€\ ÙbÐàx‘¿DEIŽ•ƒ}à‹GUª ­¯ËpÛ7VbÞbƒ çèü+oþèÄ&ÚælR¸ó8±u[¿w‰ì —'Ÿ<;BŒî{nBd2X:9=zñ¤êŠŒ@”ù‡ª–Jù‡râs”’Œ•+WjzŽÐV¿Èù,•S@+$IôñQ½Ög:Y>È~ßèbÐu ¨äR&—à­æmÆ«s”«h •Z èyþHÓ—vG¤6u7€®Þ&S7¿”x@FÔíS§ž6˜¶¨ç_õ-Uè3@÷Ák0A7¸þ2r¢¦!3œ, Cc8õ² Ãã}W퇚,? [A5lVÜ †¢6ú¼àé aEʉ&ëÅ&…÷ …]| D€“E‘ºøDÖÙƒ+SÀówò޼Ÿ;Á²S” \/¡D©ýýýË/ˆŸŸ w¢ò ÿPuP©ùC¹2„¶î|~ñ µ#Û·Œ™Ò哟‹Æ|.nÕ~“ÿ-˜ðmÞâñ‚Ëgry—*1a©Î‘K`€‘Úúð[V˜I3á–>&…D Ý Þ€s‰¾²ôµ‚ËÍ“a ÙÐÁösÃ<`íškS˜Þtxøž yçHçV­¢äià$ølÔ™³€¼û>e4–)NJ”XR.4´£»ö\qøÙÍ vÝÂu²®<õ1Ï•a$W» =bĈò  肨<È?TëxîŸÜtÅá¾Åk¨œØ±ÍŠû…Ccc¤J¡MõåùA*šÖ·×a…6B•4æË²û^h\ß(O"ÉUêì¾G[ªü“‹ÀãÂüþ äÂÁ»òcOI‚¡BhZñ@꯸@¬D¥øQ¦ÒuÖe±I¡ž“a~aA–LÿŸ ¸®(P:|œ+!—âÌ>¡4ä$ð1 „…ž±vOl…ë) „øª-( ߬‰/8èa¢F¥*TVe|’‹ãïž<Ïü~&–—Œ`É%2Òdågš|ç†ãêè1‡²tÁ­`%±ï_ËI)¶uœr ñU×ÏU¶®G@ráâsùÁg¤¡Î! '%½I#ã ü¸"7CþêE&8ê3!4Up-[âÔÚ”e4®¨›Úx[Ÿ‹H®S_?3——$&h (p8¤H.pÈNJõrÓ¼ ˆ*ù‡ªöþ¡‡+'ê5_ÒŒ£RÇQ†©³¹D¢dBÔþ!©œ’çD…†ÍâuÔN@K$Mÿ³ˆó0,MÒ¹h±–’þ¡Üè‡Cgø[wZÑT2Y¤…fsõëþ»ï„~ŽüR¯©#Eb4à›€¯ô°#àÑ;ù`ÂÐÇDˆ|?d†sÕjƒq·´²˜¼p (r &\Ÿ“¢ÀôªÃ6»tsúób@ãÎIP4Ÿ}ƒO™èðé¨GoG,iT–¾óæÍ;tèó{Ĉhþâ+Aþ¡ê€¥èãmãŽåí~6D (vågÜ㈚Úèê¨CÔþ!3×NÃ~í1¸“V:šþ!¯±Ž+ö„ z1§¸¦’ÆÞ¿ŸVÉRã£_9óÀ´åès»ÿ'øÔõ÷ônŠËŒ¦ŒxÊ£ã6„ÿràxwÃÕ" ÎözýZ> {ïѪ^v¨(|ûz¤L®¢è᤾!ã`(„ð­]ˆæUß2è¾gÝ"·Q]~wÞ<¾kNè­ #yür ¥–ôëþœÓçò‰_ËVÎ)5æÆüÌÃ"›µªŸ)Š é籊¬BZ¨Ã%p Œtàmx‚ ·‘³–’j3þüÈÈÈÀÀ@Ÿùóç£ùCˆ¯ù‡j´ªà꾕SWž™yâa'c>ÄØ|"‰ceaüúÔq=ûÉ¥J™ùLž¯±ŸNðÑCï8:"ìB¦Ä„_4Óȶ縂EóScÌ98ðÍëXꇮZŠá#S Kk§MGôiÛ xñÙ‡=ɲ¬™CJžŸ••%£hø×ñûO Æ®xù:”lÙÚQ©ÂÄrât44a:\à‘ôóg©Ä˜5˼ªA‘mÿ€»¹c¦íl³mת¾ßè-oèÏœgffò +ŒVÎ)MæŒn0jYð»p^‹V9*°ƒ¯q ÃLŒ0D~÷ÑëDi=¯®s¦1$ñ Kæ¼i8~î@{ Usf-p›¾|˜äyæ,>³yóæ¯/8@Tš?T»ÐêˆÓ g—„2èüòc9ú“~saB÷Oî5ó ½wßiÃ;¦^^ÑcòUp¾Ü¿ú/&BNäÚãçÎì\ò”9Œ¿¸áÊ}Ô¡‡@ ªäª-”êR·Ê,L9ЩÓ%š’e¦¦zõ³ÿêm_Ë¢q õûNØßÖªC]]hâ–Ô¸Ó&€žÎc'n›ôB¼ØCÄy±æF“EsBW,.¤Ú qìÒïêM\W¥E ˆO ÿPÕÂÞ?$•JAÃiý.K\®¢y†~Ë–õyùèÒñƒqb~C›âk |k½Ø+«¾JJNÎÎþ ’ÆI$vîmÄ]s#öï®fK¥.[7ìÏõ—…$/pÈÝžPðWst' ˆêù‡ªöþ!.—[ªHÓ•ê"x¶>>­||Z Ý÷ÇæÝ»ŽÆ‚OMfÎnÝrg„í¤I?ìd-TÞ{¼•IaÒ/.w>R4KK3ík¦oð£ÃÏëæM>˵ø©ƒ¹þ·,?@” òÕ.Ê1B,ýC¤ Þþ‹óR¯]”Šü§ën~Xpiÿ¤á?´mÙÜ^7 (ÇaÓò¢·<ßv¥á´aPï·ñéÁ_l}ÑpÚÿª®€Q*ÈÕÔ¨Ô)D,Ñsøiž›ñ‘q‹•4àü:Æ$ñðú“‡Ã©U-¹o…ú…Ų\*•J¡PH¥RgnnÎápÔµW³uŤ¬k­ÚåS~¡J­º´C j5Eþ¡èø…ã 8$IbF’$ó@Õªo5µJJ¥’$Iœà(UxÄûd½‚‚’$MLLjgK®úÑl;*•ÊŒŒ ‘HD’$MÓµ¹®¾SµÙPVÑjZ/¢æ)j:ù¸~}W‡C’$EQ8Ž×Î'œÑŠÑP©T*ŠðððvÞV|>ßÐÐÐÔÔ´¶ä¾•m©ë!===;;»°°°nݺ1115^Wå7j­Úåæ=TjÑjOˆš¢èsL©Tñù|æÏ€ãµtH·ÚU€ã8ŸÏ…B! ÛÉ´ç@ã½P ­i5 ®¥R‰ã8Žã*•êÇåÔUmà Ôþ^.q©Eûøñc:ujZ5¢†)îP/¬ÀØ!‚ já—MÓ*•ŠyŒÕºººAÆÅÅUK®²Í”jËQ³íH„®®nxxx£F¾a]±iTV¶Ôf©É7OªÔ¢!;„@¯/ÇxM)Šbú¬ ‚P·<h¹¸œš6LÌW$Ð4­6E5Û’SwU›b® ›K¶¿m]}Íœ¢¨²ŠPÕj—ÌN%rôô?}•I³³b D®6ÜÊ&ÅÜ å¨W²hhG¢x}9’$Õd™‰ùqeÍÖÃÞ¿{+Vq,êúôµxtoÑ•yÈh ç­†–œ81+Du­+ýbªAJm;Vª®j¤Ô_¥6ý…û;8qç„u›U 4†ð¨¯—ùìÑ(÷c J,ËMФÌ,—d¦DrMÝt‰ò‹†@üg)î—#‚yÅ«ŸpÇOÌm·æRôÐy›g¶ôä¿{tïÔ¦ßÛGd>Øòs³êו±CêßÌP(­%÷îäõM¯ ì:uœÛZO3J‘7}åM/_Ôׄ¨Ä+æÔƒí Ÿƒ¿Û”^ÓtŸ(Ù’ÃÄ’<‚÷òÂK®_ÍÇ=ᙊL(ËM!¹|~¹Œâä˜Ýç¤3~kÀrq ùLGJµ¡¥-‘ç)€¥eµK­«\…íÚÉõiJ™“÷øAðÂÑK7 j¦K|“RW‘Ú8ŽÿЯE;œð8!J‹_ûg°Ï讦:ÅÍ Z%»|üα(èæmu+8eþH«'Ï^¹ýaþT_wÃâ;?;òI¾[K#±œÀ0’Ïçó88Fpù|~NjÆë¬¥»±:rÈá‹™-:ùë@9·ÙÓ§š·Ÿï2Ç=tÙåÜÍJ @”·ÿÐßK/6\õÉÑ|òµë“‹Þàa§=l0edý¨?ÿØŠýrh†³!ÄÞûãc—c“ŶõZŒž½ÄÍT¨–-çTbàÿœK”87kÝqØÔ¶vz%EFÍZÜØ¤”NŒ’-9‘©·^Îõ£©ÊÑÖÅoÀ£gÒšüÏ+hW A’$YžÊyýêq¬íœOÓ; ˆjží¡¥Cë)}[³–-«íXj]á]׺E‹$ùx9Çßwðn¾w?“oRê*RÇqûFvöýøÉÜC±£¦îá"ÔHKµwÕÉ[ÏÃËCþûs7Ú¶kÒ¶]“ÇçÏ/[pzSGõwÈ…Ãñ¦=H’$H0e|š"7.xҜۙ„nvJÚùƒ¿éàJYÆê‡ùKwZ$•¹ÍܶJ˜äŸ<`˜-×*ò!Åþ!L Uù§ÒÄõGv*Ñ_|˜äêgàÛåÃi¿_²aöñòØ~sîô;wÅDûG×îä{.(ÐŽO@9§’nüÖsêé¶ý~7Ì;öÑé};ï¾{ßÓ¯%2¦³ï™ÀÇŒTä¨Wɱ -ôVˆ½À• )Hù°Ð…ôy̨ ðk¡ 1™J{ÇÑ}]õ,=ôÙÀ\Erý1)°˜6¼¨ERòáÄ­è÷)2;§Ñ½]øŸ2O}uÐ?&>[aec9øGoWƒ" ßœ|ðÔ¾I+Eì™ç¹f½~ð°Ç²Nž •(sqo0Ú϶R:Ä^¸"u™8À”){RxÄß·c>f(ëY·ökâm΀‚äø]'B£3å–¶&]zz{YTÚµƒágñ,E®)YêGÇî‡ êÿÖל‰ (LÚräm·áír™Ü­lMºôöinÁMµ 9âõ·T›¦nŸ¾þggùúAõuñB±$'¿PÊÑw4!SžÞ¼”i}zac.y B3'F§OÏÆ7÷­{Ûb¾«¤ß9‘ uhˆe'§= Ì’æÆø5ÌÀ€æê9MŸÐÕÙ\ÐiÄêîÃÌ7O”ú Š=C%o³ÂÒn3ŽNn"žÈÂ% DZ%@þ!B»“šy³cF)>()ÚÐÃT}J!~ráìaæ/8¿è=•|÷§v…ï\¾´©ˆK«òÇÿ~Òã÷k˧ÿêêÖeêZÿaFñ3w¾€òNQ’ñ³¸M¾ºmå’v-ºšyrû´Ÿ q¬4‘³ÿWk¨©3†aÌpÞ"'0* åÜß=;êa”¬h0Û‹Cá¦ÛàJÐ0º‘þ·'ÿn]ßex‡Ì§“vÇ`&²´mfÇǹFm›;µñ0cò’æENÝðB¡oÖÑÃ4àâ9W2™’ŸÜ»5˜oç4gls[<}ú¬3‰Ê¢S‚£.߸¿ôvrCŸúܸðß×=Û±âæG̸«—éõ./ Ê«”YaQ÷‚ÅE)?»;jC@¡Ètø[NæÒ…ÂÄôïK®)»ÍŸÐ®­¶cÿ ÃÕ5£®·’u¥ù’ÿæVžÒ¥~9¥v²_¼t3WU$+à~¨¼‘WçÞÆÛþ×s 0-µSŸßû&j+òãO\z¾ïxÀš ÇÖ^ŽÓ§³VÌ?Ô}ôŸ¦Ÿ¿ÕÿP@.†açþIh7¥-Ç0 Ë~•mê¥û)Î@gè'b ÃheÞÒÝ‘Þ „0ÿãx)WÇaÿŸcw1Û¸X5sÇ0,úR†±›SñçZi·Ypi·†a¾ „‘³ÕE(ÿ+ øOQÜå¢ù``Fðlp Ë{“ƒyõب¤ïÀãëgZ7íé©Çªà×AŠl•,÷J¼T©woÁ”€"ó–«¢Rn…b3=Ê9%Ͻ+QlÒH{«Q¿€4ó\)"þ¡ØL-…µ4 0ZÃF= ¶ÞÎÙÙÓ˜Räl‰Û`©)âèÓlYcQsK.ÔwÈï?ÿ†9ëXX5±æa>EÉÈó?ŒÚ:º 6 ‘sïÄb½MiJ1oodãaCfû€³“=ývÏòs™{›1R’Tþñ]8Hꞟô(iäÿ6t2ÑóˆUg“0ƒJ耦Uóþ|ëÚoÀŠ>fв¡C]ƒpC£U’·R•¯«U+^+³öiø´2Sùu¥Çn?T@+”™Ï"Ò¼|¸ëbe—ÚÒÛÏjß­KšèÐûnd5Ò>ϽC¨Bµ±Âä\¹¥™³KÛÞý±ÓûoA AíX«[ôåÅ+#õøVŽë,]u ¢:òiù¹â•óá8NÓ4óxP5aß…i³ö?òK +µ­Ê—Ð4F’$IVìÇÖ1û‘‡Ï}£ÓdDkk&„R$åa$‰—{j 1ñDPz«nöÌ©¼÷÷UŽmôJÉ¢LõT*†aêZš8Æ8Ø­½;ëïÜs2‹ŸIuÙ™$I’À9Gbð÷Ú}Gãô†ÿ苇.ŸúøäUSÇÃIq Î->ä`à$IÊA Ý:7©ÃSÏhñ H]&&€$ó›b“EÕE`󛽌ârP€,9‚Àwä€ó¾Îß~µfÑ~ûŽ]·©Ï¦®8:uFôó.ys”UjpÔ…ºòÏciKòŸ×^]l­Ü:uß>¦¾¦Ú ŒQ›Ã8ù5ç±~ÚŒ*yÖÖÅµÙæÚƒNH‘>(qþñÑmƒu8ä§»(wÿG©ÇO†L f$dbÆ\'¢¨ÂIÃ0"ûIÈŸ±ù>íŠe-8Ø»<(®Òo³N%o3PæS8©[òîEþ!¢Ø?ļ‚ œ pÇíúݧ٦!. výú:5>âÑÍ£»Ù§´e®[2-‚[gÏOM/þÒsÇáÓiRUFlð’~M¦î )ÿNšì›ØÜj×MûŽ~ÌÍtl`¯.ÞM()²´_“™…1ê135;mˆOhÎÌÀIÑ/ý³ûžŸÈæÎñÖ×RX!IÜûÃ;×÷jhm#ȨÜ4 ¾ž ƒ÷ /7;ÏÆu<×ñp5rr)}þc©|Ãz:8v>¼@"þø1WY$edg7fLÏ“[º…ܸ"¦NØÔU¥ ùsšèî;Ÿ²=$Øèâ FLî'6u}yíÊ‹B•¦OÏYˆcç^‰™C‚ ¾RmJY ZUZ…tn¹™(ÏK]} aÄТ!´Jvr×™4£&S‹ßþ€}V:–¶Þ.·Ÿzý±rèÚñõV ’Ñu…dþYɼ4o³y-J­±Â2žž©º¨_P£ñÊÆqæ ' Iàrq·ëÙ¹m³?\ß:q »¯ŸïöCgœú®¼t«™!‡Ã}»ºvÖ:¨ÿÚ.~´q¢Ç…m?·uöý³¼íÖ#“=*<å=ûî¦)-/ÿ1ÞÏÍlêÊ?:,z°¨{’"²¶[Oñ$I ˆbm?ל I’Ëå’0ó9N³ŸZ¤½4óîf%àr8’ƒsŠ/41$±ààd)¯ž†­ÜœNÓªŒäp8"K®¢ 6[©|û^Æáp Ã0‚£†ÀÃ8Oh¼©ÅÍugÿöɥɼŒÌÍ‹/¹šÅÄ"1 ðORÌH_R}„a@TN¼¨P\žîæ–·ŸÝwý}ºLý:ò×ygŽ„KiYÒÔY'÷ߊ)ÀHJAcaÉç¨k¦¼ºœSe•š¡íÄVq—Ïåxö7Óáp8š¹Ó*À0ÂRÀÕT›Ç×Û¢¡vTÄû¯Q›ÑA¨ïØ\¨üýØ{%ÉÑ¢ËÌnú.õüõ˜^ÿ{™ 32oßz>kúÞc)Ö;Övø¬˜8†áso`”’ÃáX{w˜;À’9 òä7ÂD\‡ÃiÜÃ(-(E-XêmfÁ#µn3†çÏòz[“$©U4QìÂ0 ÇùÓüPk2`ÑÉ‹€–Ki.ÿóÇïØ?­ôpAŸiûúLÛ§(”s„\Ö§ø}¦íï3m¿L¢ä È EhH(ªxtþ &D`b`#å3ϹÈÄcþðB“.Ì!IêØÛsIÇ1œ«w`fÛé»/vÞOÛÙÛN_3ÂlõßwóT?šp-šú55>Þÿ—CíÚy»7ö™Ø(øêWGßÖRȶ3r©îõ?N]Û·÷¢‘…‰wËN;X1õ'²0´5á1Ñ’goc¬Ç)zûðõ l,upg¯ƒŽ©¡ ŸÏ”Ñã×r®ï ËK†sEn­››T(NS…wï=QòõMì윬MtØeNݹs¯Ô׬]ëFd­Ì¹ûàEYg=Ú¶7(wá+y^ø£çi%ŸqæÙ7ólÝH[–¬”"ãÞÃ0·6¾&œJt?¸'ÆÍÚµn øúÑý4JäÛ¶Y…âaï+¼<¬„´*÷îýàz­ÛYs y^XÀ‹üö¾­Xêû!âQÐÓ×i ÛuîÔ®‰^S¿Õ†#/Oû”L&{øða›6mx¼R^˜Œ c€ŠæEEEÙØØYY™—•Ù¦fÖ+s¥|ƒù‰Ï§³W1ùa§.wLM‹vdQJós °vC—žß=‘Ë¢Š²ß´jr²d¸Èr|zÌ&öjüÓ½îØ»‰Öí÷E]Ê^*ùa§.·õô´ínÛc/N¶·*UD“7»ü|æ=ÿÕºßF42;)lsHÉSgti~$ÁýêÓS^¬¿BàÁx÷.ß»Œºº«-K‘n†÷r¥Í×ߟøùaG»f³žòõ}³S®•ŸÂtGÓ]Éb§ÁGÂöW>ŸåÙíL[65ÿr¡wË a%ÃÝf>ZÞ”M¾æÂ]ô°ò^¢+úÌl+Äù—c /zW(®,|«kÜ”§«Ï¬¬OÉÄbxöü鯿7¸*ò%Ó2ÐÃ9ܯo¾qï”C˜÷1 IDATèCåKËr˜Û©5¤d2‡W¼ áÅ©mõË»s(yjG×ç&#?¾Ü\l°håÔ¦¶‡3½^Çœ7gmT$™çl†KÈêk\‰ï¶W»ôžvyÉýØÙ^E‹]¥?]ëà»´çæ ã¿V|íúYe/ ¼ûS=yÞ}óö›b2Æ[ê¤>ûÁÉ/DœËF»&÷ù—­GÛ¦õMãBž‡ÄJzL^hÑÀªZëII©Ì´´d777µH¥Rݸq#==ÝÚÚºS§NêmˆÀÑÑ1::ZGG/!áCݺuå8y^À’7ÙkŸl˜á3÷qÞÄ–¬¿,€Ôýðá¥ú05ìr»vCvëyá{–)gòZß}y¨Qe®#­Êt2Öc‚Ç«“rw„èl?6_·&Ô \».Ü¥ŸmümV)Øœ™~fôŽ9'ºVbKC†&‹fÏ/eœÝ"v_á êîJ ùlá¡“M¬+ññðkлµE ñÌÈ€I=è> YÔ•áˆa<ÿÍc{Î97ëðýß{Õ­L†<ý¶999Ìï‚ä]&ŽÓ×¾Ioɲ)8×üðÍUö^Óÿõ󙟋>A^ï¼'R²éÙ!–F(5ìö.< €U#F>ôðê3dTÛ¬QlüëñÕ×]÷8 î¶#ŸPI£ö^mÕe5#ôõ„mêÛmQÀŠãO§õ*jw¾9³ØwÔ¨.˜…ÿÂ6Õ €4M?xð ==Ÿ|ûömDD„Ö‘jÿD"ÁÓCW¶ˆZ¸ùë´Ù0{šë›Í‹¾fQ7ñ‡û{R•æUÓÚ ´*oÜŽ·îó6óÞ¦¹îowŒË+ué*&áú¢®KîÎ?¯‡ÛﻯAš}ýX’xøŽþZá]6Ž”æøH-(Uꛣ”DmÕò*ô{öpÏX߃SoZwÜf%²ÚÚÑúÆ”ƒìqŽÑ&_ËíËŠ²/—m3ó\o_Z,¼ÔBr¹ßŽWìE¾žZrá´xw'•§Û‚edÇî³Bìzº¤{Ÿ'ªõÇvK¯ ²*öÃfØÜwX¡õàkKYõèf†Î²ùîŽgïŽo]ùÓ­ Õ 1Ëwž|yiåõƒ„e²I„àÙ»»%ûêÔ!K†L½–½õî?v¬½ªÌ¾‹Ú¡4`XÅ]Vâ”= 2åÔ± µÂëý¼„RænJ³ÔáËPii¶hÑbÞ¼yë5ü´o…²»6ݧã=í>ŸDBã¾™ Ç*ÿJŒÏ~q’è5¼§ÙNm|\Bž„T®¼øb²wå:ú¿]VùO¸_wA×Înï}Ë»mäyç¿Êì~N»kkÄzßýææýâÃzúÚ‚ õ¼—…¸/`5æ¸L0î†++O4žÌc7Êdº›ÓÁÒ¶é˜ÊˆÛU2\‹Úvá*%´æü¯i)〾‹íÏ œ¼'/ð–dž?m3dî¾}ì籦ÝìÐo­¡×Œ‹3›«›Ï¼8ã’Óš:x½ îlV…c£›÷¿´²Œh "L³?<êt;óôÛ¾G’$MCvNaF¦L®¢ùz ÃDBBO@è x"‘ŽJ¥ÊÊÊÒ,Ú(11ÑÄÄÜÑñ³±ò¼×ÏÃsšû´Ôžù@+>5läéZÑI¡XK‘¡­¹!ÛK¢”D>}™îÞÂç :÷??M”•9pžäÙ4oV§ü´”WÃ7lèáZqïyäó ty)9ÇÄÛË¥d¸±ÁA9ú®Më~æÇÊ‹zù&×À»™C…â ²Ì蟄¼N­ëéÓº•—©N¥—W§äIOžÇÙ{¶¨Ô€·¼÷/ߨx5ýìÕ©”Ä<}™"4oܤÜåmïž…f6lî£ÿùmG+sŸF»{Õ+÷/â镵››µTÒ¸ IVÞ̈mifxH4Ö¢¹öðV-bƒƒòŒºÛ¶~DÔó LÌŒMÍG?J-õºsͽ=Ùz,¾øÂe‡<‹G¯ÏÇ£f†<‹º^M +§)Ià“—ÖͼÙ8Ö”~ü8°¬sêA³l ä©OžG;y¶0¯ä0Ë"qEú“g‘Î^-L¿hd¥Ìzòômýæ-ŒH¶ây‘/ÃÓ%ÞŽÚ«IŽH˜6jêÌÊ! ´*?0èU¥ÊžûîEDfQ‹“äÛ6÷°ýøâéGiÑÛoÜУÄ8ÀoHLÌæG^^6†a™YùÏ^&¿#É H¥ÏÈJl)s]žOá`&r°·‹Å8Ž7##ÕÚÚدëƒ@ „šëú$¥d=Z ÖåÖ5Å „n¡‡€±žHW$ÒÕá*óR²t&n¥ªôº>@”Ïå«"¾iÏÁ$-•ª²ò¥\.tE‘ˆ¯«Ã˜9E‡¦½zõªaÃφ ¢ý‡ñ x’:|tKs ]=_GÀÕ×á <¡€'àqù\’ÇÁ9¾¾kBÂG-AVëË!QÍ!‘…JCø$©+ä$Îã<É! >—äAVv6………ðùúrl÷B B‹Ï÷¢iW©äAÊ•*@Ó4†a4E`@­¤§¹ÿò!â€a@b8Ñ8c8ã8†Ó@àA8ã†i-¼ È?„@ ˆoEQMÑMQ4M|ú£i (š¦iš.mYñ ×—C ¢,4 Žã”ŠÂ0 0P(U^ÔΡhš¦TP@&È "ÿ†aÈ?„@ ˆJ¡é"IL,–ÓÐ4%•)€¦•” T*J¦P‘‚¢°ìì\.—ËbÆ Ô/‡@ ˆo€­£áõ+!”‚’É)±D&–È ¥ŠB©B®TÉJ¹’’+!îí[SSíEªˆ3f@vv¶žž¾®®¨´Ä¿ òœ¨þÜéïàÞH—õ‚ß„°;羜©âÛÔ±ä~Ñúÿ_CìÕ«”½“ÀhªàéµSÿÜVžÕ¸n­|ýøêÁ×3)£zö&Õ—ïW£È:wôÐù€HÇzæÂïl@J»{í–LÆdJð‰#‡# íòûDŸ_´šbAÇUW¯D爹–S¨ÊÊ—8%W(qÇp‚ H¹4_üñ]ƒú.|>ŸËååççAµÍ Ù:Ò±aß;‰ªØÛÝÝFæVãæÜ™a³ZõŸ“)ù°nB'·ž'Ÿ¥V[Ö NÜßrìÆ×9²‚¤û?4rl?`|4Îv™Î¯‡RfýæmïÝkJh|èœ~^ã÷½©¶¬¿’W·µpöÙçð`_«ß$Õ¿Åô×Aðíub/ôoÙxô´Egï…å*¾·üçy8eèÔÓq5•û½ÉCj0÷J¡9¨y3‡víM¢Â_ ËŠË'çÈ“sä9y…9ù’ŒÔÔ¼„(÷õ˜5åª{þ$ãZÏA^¿ìd*zA¤¥é¬·Ù{VÓö$²Ì$ÏqñÊí:«6]4t´¯ËÇgq3T¼æã7!õÁqÚÄ=çñ>Ÿ±¿'4\wáØÄNöÕ“5€jË–w§†Ý™â ⤠ç×ûaÔ¦ÑOÕÞ"ü¸y=þx´¬_=J‘vPßþtÆŽáU¹bñ7çÕî_æ7¹ÿþ±'j}Ÿ,=qµÅ”Š×G¯"æ¿ê7íϚʽRhú‡D"®~›¸‰ï?ŒŽOÍ‹ù9´!qå\"¿ž½‰¹‘“¾žîWÌ¢åñÉ…u¬´7A`êž¿xï¼ßÉT€‘®B2*¥XÛ!Iz"ibÍùÒ—§e»}ÃêûüoõíCsÿ·üT ß[Ž•6BtJl‚¾Í¼ÁYÒ{èÈËÿ¾1ª·O)[>—KVŠØÈBT¤Ã‡S;KöË §=¹ðZæ­¤É"7 {ßÊ‘ö6ª™íÔhJ%å8³ëa3o¹`à³z2¢°6mú IŽ\`ðÅ-Wª÷ìcc^&~¥’å$¥« lŒ¿Ö’Ѫü+'¢zmZ¹ÜsÓ’%|{ ¶ EkgJI“ââs$EΦ~ý/Ú 2/.0ÑÌË•uÇlaj×̆Y«¦ r(¡¡ö~B'½9(&ŽÙVzÛ*eaª˜cjð¥;¸SÊ\œÔ—dœ‘ê\­Séš—gK¸†ÅO7%ÏÆ¹ÕôÁÍP¿~}æG÷®ì4­yXT_%'iraùÈúVfõœ,ÛL» {zµýùînn®¥,Ml~Ù¸"Ÿ`C\òqZŸæ¦¶ÎMÝlêvœ–¬ãÒÉ„$jù„ž–Æî {{·øyìØñ0¹~"•iWOìš6²¯W]wUˬmöXÉlBYö‹1í¼\š6pö]§Ú2¹™[ŸmŸ˜·œT$ý9÷'Kÿã€EÕ÷ô[rò=ãÒÔ¥Õ#jÙ¸;Ù7}/Á êàH¯nñr¦ÑK½½ÍÏÉe[¼8íÎ_FNs…ÏûMÌf<¢›÷þh³:.'JÿTiJÖ۳΢ŒÛÿ}Ä3 ÞYÝïT:5;hÜIéÞÐ踋ß^$Ë»1óqæŠõ™6ëÄVÇnÛ^ÌÔcФ‘=šÞ¿ôÜKÍ¥6+qð§6!ùm_''¯öÉµäÆŸn3r¯……cz×7Mvvj+÷Úµvd—Ö“ ]2S„,¶ëüC#®¼ýô1&;=ü—F’KaeßÐW¹' º~l´zK¯Ú:• ¶ë j½")|ãÝef~Üò.ùùªŒ§›ÕýqåHEòÊè|qüÚÖ¥Ûõ€Z:®+³wÄf–ׂvú:¶àêÆ§‚Ž] "¯ñwï5e§[ÿßGè8¶Fá9?·›ŠÓ´D¬Ûú¹E)›’2¥C­Jš½#LfÔŸyq§]Ä¢½ûK—³SÜIKKsè0Wb]hˆù¥ùµ­L,Ý,w¤éÐÒȮͺ½sú)5/3²cúÙ~ï0,›þàÏÍÒ›µ1É.²?qâÄo-x”Ó¼wñi¢WgMN¢•Ó;Þ`ßxœÛ.áD¿Å/™7žRfñns&½ÖÁŸ“_]`¯gÝÿ¯G.0¸b±ô^xæÞqØêÕ3³•{OŸ¿qÿef^æ‘îL>zS‡Þz£ö}¼Ú[žU²"δ) Þ®šÈ´åxÖÐæ-f¸ßˆmm`ÞtÅãÇØ9Ö}D>“â„,vÝþÌsICLÓ§Ÿˆ—f^k?íÜÀÍ{\˜-<]µ³yß…-—ŸþÅÙøÑ¦H·±íY<IÔɾ™—åÜi8¡Îäíƒìôy‘E$±„³»ï¡Ã•kõT{É]ÍüPÉúCñññvvå×Ê__ËoÃ唄 Ð #}Ón M3ú„Ü›[õb¦* ëXçžØh.ºù0*áÉžíÑÏ®m¶bvßJH3E, '»àóôº]Eï‡tuoUgùí­£3üôä G?¿ùò–omC ‰v¶ÞO“Ö¸0^Š’Õ²sßýjµ¯Xšê¶È.!‹v³ Ø—ÜÉLçÜ›$õËÎO]aë¹é|BJGK¡<ÿŠ™ý ”ÂBs'IÆn çégB®è•Ž%f=ÿíç•1©Ẏ)$™Ç¬\§]‰‚˜]7h¢ð\;3Ç?uýp"¬ëø_Ìçn¬ó0×™_OÛ~§ñùu=.?šRÅúušÞ-kÑéx’?Âñµ-â×¾¸5À…y Í,Œ.D_ °€ë[µ^¯ŸŸq“aÙÜ·‡ºôXê;cÕìqýÌ”Y´±½¹ùóM{\m¹_uîŽ?ÝÁ{¶mnò!æ5„ô«»Èrÿûþ¿¹['|ÔŸÙR²ú‹ç ¸ˆä[ª•#¶·Üè·añ× Zt8æ”JÕøØãÁ-k’·ŽyàÞè†ÓY›>ì-»tåy™|3ëN×]¿=É$Y8O{[äÉ`XïÓ–6k,“ϱ±vÖ&Ýޤ̴7<ÑÒq©Í¡èóm™4€&hŒƒ…ojÕåÔ¸.’9oƒ÷„mêΰñk›Ùó9ø~g{ •fæ“>¥O±3ø°Ê/h_vüÆ*‹Ïnlâ¶8úìãfiz;v³±,笙Ãð[âÝÿô˜Ó\ÈËËKóv§"...qqqúúFii)... ÎU4.·mÈ·á'‚L¿®çFj³„ÙLšqÉÇ­"ékwc=¡yïÁ^0x'À©Û¢/Ö4gRœ£g­Z V`ÙE!^½¤óAÁ¬«Ì;!X<épÀÞ×¾µ 0NS}^tª÷C4%ïÞ½ö’ŸƒÎɳåëwiŸ]™]ݨÄìÿ…ÓrG5:!ЯåQ{/[6_×ÑRÅÉçø&AL:! ¤Ql¾]·à õ–U3‡»ÍÒi¬üÁôŽÝ÷W£qìŠ"0?|âÔÞ•“«Qƒèæ¼Q§ /',w¼úVt té‡nžH2öl¡ú/~w"[º¡nså[ñ?|.„[š’L]^wìmæe‡užnµéåæÁn ó½ä–3IuçQß@HÓ¤,¶‰ J™>õ¶hÚ'/R‘´#CÖT·ÉúWf^±ö=¬^~—¦hšÒáRwíáÏ T7/À1'ˆÒ¤xêÅÄQ:¬ßªÂ7³Ço[úÉ8flI–c 1ŒeÈ,/õþ@¬UËߨ˜<ÿÊ ¹É[¨åj(‰ÈeØŒƒ€C¿œ….Ô³¾óÆï+l}¼9§ïý/¶ ´×#ÉU–-Jݸ3–|öd ²˜c¢âz˜vÄ0ìU±âoí‡*¡P(=zÀçk?‡|—«¬šØ“TTLÉßqÊ‘’ôÙ±…y¾±8uÏb€»ðËÅH»>)Wu¸ÍWasí…ÏN~¹0çê½KÑ”äB®¬³OÉß!)O8“#mÏx^8<Ðw«h`bZB¶8?77^§NîŠvèÝP§"e¬ÙÛi}WÕ׉G?»`XkЈÂóÔÓåùWWÄôÝ:’ùGÓ„xúõ”)ëÛ^ü!¶H·™ï˜y® {ý&ãÄüs¹¨‹ï5 IDAT2eê0c^žÿ ýàí}¶Ýhg*°ìýfóôMn mJ¶‰æâ4ÖÓLHS’HÆG%%¬›P»~öÏñ>ýÓ ‰(.TÿÉ„Hn×öËÌã‰æÍ»2/žrsj¾Ðgj-Cqüj–Å07!R3dŒ ÓĦ„B¡ý—®óÑédc¦ƒððIŠÛ¶¶R{ãH¼¹OæÅ@ÿ{š°ójM¼2z}Ÿ÷Ú”v¢‰gÔáÀl,ÚÔ”O@æ£FN³õX}îY¶m‡ªƒ×T-£ijÛm:ÍËprÒ㊠ñÔi“:óxÐç·G{ôª²lÖ“ëzý¼ô¹ ,~#0n=ÂZEÏhšö1¬Îuä·#IòîÝ»"‘èÑ£G•Ï?u~ðò|Q‡S,%y‘—‚½®c&(Œ*ÌZhjÓEÎà´q7B–ý·coJk”;oå¯Ã MÉ!)¸úõ¯_˜£Ó4Œ¥_GÈ }‘@MM˜`«Ã³ºGŸdºhÊÁã±d ËG÷¼˜Pȼ¸W§Æ/guj׹טI³6î=#Ö)7Pœ¶çJ‘áŠÆ%ýèÕK)µ‡yV^DMhÑ¿¡5óB8PxÖÜžÌ[ÌÝ ÃøŒ4÷BŠ‚èa!šXÞ¥[û>ÛtjüÖë"ÏY,žõ2“#ò(]zfREä…IX³ô>/ÓjÉs«£/.:2Ï«aœók‡?éíÓ¾ïìÅkN]y$f܃ªt³ÒK<§Ü ŸŸº$B±x[kæÅÿšóȱÇ2€èÚýZ úÔ´F͆(üöIsN%ãqÈš4%IS²›ûÌz“·hO óOïm¡—p>hJzeçìEáÊmÛ}™€´›¯æ]@)~Û¯y秺¤oÇY·³U}þd_ßE¯f]ΰló5ƒ3žL<ò&óåÆO®?·UŠÓöÏí´¿ ÖÖù:\J*ÄO:?fÁe³ùºM™ûcN«ç¿L~š\|co¬Ç´V¤Lô×¼DëmÌÎΑHôüùs­1 «úù!×b±ŸÕŠ­»x ¿+ZvæÅ£õ®úmÊj»á•€Aœ“.¦ºž÷ysw×µNÞbŸÞK =Üä­ë¡Þœ2WÏjl]¡ÎÕ^Ùß÷§Ö}zÇ„¾+¨wâÑ2~;fn0`ÂÀY¯;ËR>=¾}G?pBO]þQ[®»ž>ëóûˆ¸äÄØëf69•›iÖ^þ¶Å²éJÕ@MìL/×ÑŽaYŒ¥hõ fÃ}>î&}u/×yÄ‹k¿1ÿhšvnjÄïØu°eúÃ"àÙû)ÌË*Ä.åJOÛ@ÀTÏ™Ãù "eA+.Öe4ïÿÚÜàc)6Ï,=ÎêÙ Z–ÑùúR·Ég®ØMYl{À±é#£´7ݵ±“wÛ¦Qo‹.Æ eÒ€ä«ãqšÝ½Í°žS—}Þ=T× ÇM~Ù™0hî£Ï^½z}pÉÀÉ3šÆF†3qjþ¡ÖºFõ¦¢o>ü,Ÿwêõk¦c{²Ü‹›’ »î<ýÜO¿öZxçuáÆÛ/˜L×”eÞà4¿ø+]ß¹A½œð öœ#/FÖÒáÒmÆÙÅÚtèÙKþþêóTî¼CÚ™èv=nP¸`aŸçÞß{`Ñó&º$e'ýâ4¼óÈ>þùñž¼NŸsäÕ/s†e-½WÜÝ„ëî™&–cY=Ìdy´röÕY_æò”|^ðýÇ'Ý}E$íc.$¥›ÙŒó&Ó/lÔÈ¡P©Ð[ÑÕnR~½v}.½>׎AðmZnª/lîìÓÙ2+ÌbØÁ»=¶·qoîc•õ,Ùlû³Õ÷Ó‚_¯?T",,,9ùˈbTT”Aƒ 4_¶­ùüPÉ<…¤¤$kk»òó€’?½rìežy·î]ÍùTØ¥= ƃë2iâLË„£Ï·0x|ëæ«·ÑB{~CzYè:¹žV:š˜ ƒ/EŸ ªzçr’]¾øä“¡KÃN½:ÛñtX îð>AßΣi3_?/G]?=ÿýS‰‹w-C®èÞ€úCò 2˜N|€¸Waû†^¶z NXl[cT¾X‡ s€èÐËמǺ´hܦ©¾î?Ésßî?t]ß½uï.þFºœ‹ yÜË·9~~-hüþñ]96½Ú5fôM„=É5õlêñ%G*RÃ^'[5ñqcp-²ÍËnÛ‹a+,O¼ ß°}¯6 ‹âŸ¸ß~Pÿz–ŒruïŽ-ðôökZ—_Í?b22Y\ÏÑ wLl»_Í(h§Kš­8ñɉËå†nmÚ{Õf<­@)Žxõ©Àǯ%š,<³{o˾{ïÖŒ‹9Ø®ÕòfYqëòâÞ<‰“5oáck¬ÛÜ e™·ÎŸ‰–Zumæ¢ó#8ð!äȵHq“€Àö~ t}'þ݃Ûwžók{µlXÇFçGåŠRVÛ6Ø}ïþ%;纵LuëAC—ö;dù9öTÒJ¿éëÞüé<¸qï?Þ<¯Ãø:ûõ÷®ñ¡ww;Öv6Ó×á²›Âs.í;Bºö j´òÉ•S‰v}xÛWg¦«N*š§`gg§zgZ^^^ZZhÌSÈÌLsrr‚ªû¡oB9þ˜¶D÷²4) Ÿ›ØvYü:~žGuž¢­Q䯼w?5òóH|ù¦Ñ¬ëWµª^Eï–¶h»Û2?ýÊ÷mß%s6µlû0q£{™^Þ‡U^+ SWŸ¦®Yï7ž~F·›Ñšòt¬W¿°Ùi~ªé†Ô˜÷+|;˜ñi†®s^mp ücã›Ä1uŒe9íGÚêƒ^×?žíÌ|nЭ‹7Ä^Ó!Xã¾e¾œº*YHk~èÑdÑÒ?·¶µúÖ™gä}ã~dëÿ¿NØën½ù=+æîƒh—}­ë;èpa[†QãéÛ·5úŽ-û¯"‰¼Ån ¬û>F^†™×üÔÜ™±^½ù$2¹"ÈÏ££Ç 7õ¬æ¥Òƒç´;ÛU£`j’Í®#‡Ô1¡E¯Î½—ÙwòóÐé~N¿ï¢ÍÿÏâ_íŽCõýPrr²••í÷¾BAþ˾å~(++ÝÑÑÐúC‚ Hͪâ9VAaâõë× w311~çoÌ!‚ ÿmš‡æ«(Š"B‰+q%ãAàA$I’¤L&ÕÌýë!‚ ÿIZŸú ”Ž·©n€0LU°¸XüÕúCh\Aù………\î—Îhš&I’$‚ q‚$I‚¢HŠ¢Hªä #_ÆåÊ| ‚ Õ •J9ÇoUýE©þO‘MQªÿJï‹P~Aù6š‡ÍW¯Ö¦(œ ”J%ŽãJœ$œ,IQ2™D3?Ä …B¡Ã0”BAt"(ê×ÇMœ8Ã0ŒÍæñù††¦ffsçÎPç‰hUA ÃTz~AùÔãl[·níÑ£‡z{çÎW®\ TôÎwV™òå©'Ô!‚ H•Ølö‰'Z´hÞͽ÷íÝÇf³Ë÷B_ÖÁ«dý!A©„æúCšË:èéé]ºt©C‡§ÏœõJ‡ä¾ÌÛÖ²þPqq1Ê!‚ :Ñ|~¨Ì¸š¥¥eHHˆê9Ö’MªŽŠ.Éá¸\ÕU6.wcÓ„&î¶`ëÞd¦º¶/åñá^í|¬MÝû¯<Åè}‚ È ÐP2*÷UGóe\®¢²)×Çü´S4sw(„îž)ÚùÓ˜ëLf€üO›õÝÙuþŽ7ñéwm”^š¤sëAÿ{y¡’Á¹²·=Xll,H$‡ïââ¤þÁ7+þ…¨å Í„B¡L&Ë _âÑK–»–á'¯ñ²MÙòf[ í7µAù‹OR}QX˜ß¤I“òï—ÃqWJ×x~ˆ”ɤl6 úúú ~~ʽ_îJžll/ë¶»ÿ,ËÓa1Г"Éô–ßrx‚ È¿œæóCÚÑ_nˆhÉ ª"ªˆùèÍüÖŽUñTqAä¿'&&†Åú*×CÓ4MQýàñxš»•¬Çš““c`PýU«AD'ÅÅb P¿_ÎÐа°°à;~€æDr­[ªÜá﫤òíÕûQ%EtÚ矩A¤Æ988”¼àTu?„ ‚ 5½_A©I¨BAjRI~AAj½NA©Ah\A©I¨BAjÊ!‚ 5IK~($$¤FšòŸÔ½{÷šn‚ È¿šö÷˩Ξ´6Eý³-ü?£«ÐÐКn‚ È¿]…ï9ÕÚ©ßR‡T¤ÌëüAÊiÏI¥RÕiTó”ŠN¯ i ¥ßA*§ýù!@Pæ]æ3¤î³U˜èñ,AÊU1.W~ ꇪ„¢„ ÂÜßþüMI?~üXSsðâ\‰M¬@ù÷ÒžRmTß|ºw?F¬ú‘e˾æ|EÁû'orU[xÆ[53«è(e~XX˜Ÿ«‚Üœ¿ï¦ÙÙ…VV_­D.Ž~œÊu‚ÜwÍŒ0L×: ijmc£ÿõ-#MQÀbiT†¥es¬í„lÆ|¹Bù!AÊiÏ …BÍÌEö}}Ì- ¸Àé¬Ôøœœl™Kߎ’ô{wb ì 3²åª²Êü”¤¹º*’@jjjvf†z#ßÂÑÑ”¯ù‰’,QJfvn^>ŒÌÍ-\]¹,zB.ºqãþäÉ5Ïû áÕÏŸšcjg'ËUP:ôƒ)¹w=¬Aÿ‘Æ|¥”  ;îÍ‹ðļ¼%雨x4lÞØÝXBúIHØÐAmèÒû.ÍL”B©\…ù!5Bwòì3Í-þ½ûâ+÷†õ,b$\šfë Ù…rÒHÀ€âä×O#L¼<Ô«Œ³›5óÎLO“J¥ªïÅQ$ÞÎõ¬Yª3šVD>»ÿ6 óô¨ÿ©OW÷Ï/O}Jn¥º¡ÈâË!w´¶­^Çîu5nD¢£cJ¿£ùžµß?»O*m}m¹z,L§~(ýùu‰kŸ:ö‰ññàòó8qÃÀŽ=Ô5  b¢Þ^½{¹êߺ®[X»ÃÛH¢—‡@Y!AUÝqøÎýºÛÙ˜ª·ðÂ{× }H¹T*'iŠ¢ˆ¢³ÇOŽ;LIÒÀ7o9 Ÿ³¸×Za\FÔc3 }…D©šzr6Í¼éø±Á¦ôÇïê¶hX˽aÝ×g/]{3v¯œ¤0ŒßЫ‰¥…i™zB/žãÙÚg‰‰¯2@4)‰ŒˆˆˆÌ– z]×D”$[ªC–ˆ"rïE÷˜Ù˜[˜&!éâäЧŸ³üGÏïåaœŸY(a;xø÷“fÞI‰³öõËÌ—[6óÎ>~–ï;‚ÈW0ÿAæ‡ò>^9u¢@õ#›ÀîM•Q¡yÜ¡-”‰4‡/ϾqüÆÔ®íêòéSÛĩޡqì‘Ý'S$åkZ¶ò³u­mɧÉbÇ‹îG[OØÕX‘õž£_Ÿ"Åù9YGÛç§’Mq1 àèXËØÈ°LU< €ËÇÇ)'@’÷òÑí˜ØUm¯V½Fû51åQ‰ÑŸ%¤n÷)Å©/(aýfVü¤È"œ¢ß=NXõªg–•-#Tº·ÜÊEO'²ŠhÌÚ§¸S`èOJòC‚ Ì1ÊY7í:¢•¦iŒÍ‰ yÐgDCCHÊCëÖ=»ã&¦¼¶–N4YÌåršøè ëwȵ°ä³’¬Z³eêÜùú,[ee(èb9‹Ë导Nwí9ÕŠ/M-Tfé»ÙR¸ŒËåp=­ù/>½ZÓ¤¨‡õÔ(€ÍårÂHM“«ö„¸º»œ0¨®£9)+çgÄIH‡Ëš&RSÓ« ‡™}-}&Ï7pî„‘8›ÃÁ”12ºMCRž]@`\.W½³"/5!8\.¸Ú ÞÍì×M ’(?„ Â\Õãr÷îÚÕyª¯mƒzÕË£“ÏÇ<ÂÉÒ±.®^­þ=’Kº B’—Kä‡}ˆ ði@SR015ÍMŒ'òiš$IY%%Õ1/%Ó‰b›þDQÉß”/M-惔`ÒH c/[8HE¡X,Jˆ•ã_ÖQò‡±ªšûÐvø(cRž[Lèµ4!$Å@SEM»áE¹•Úá©sO†­EATõCæMºýhkk\r+P`Lä=¹g×µ#3H¹ü ÇÃÔT/%õË@œRþ9ưgƒÌ¬"8wü˜¼¸H5VÅ7näßÌh'èsÓÒIš’~”ëOv1”‰rT5§Éô\ôYžpbatL\¢Ö18Û`è°Ÿ\]œª¬$+1^L’|s>)“Æ6`a˜,MFÚ“•”âpi"‡ÅhDA*Â(?yñä;%› 4M)¹ÖízX¹¾=y[Ò¤?+7öÖgªç ž…ã_&&d¾ËÚ·46b¥Šp¨×Ð äRUÁÑs°4•¥eÉX,ÈP… ¥8îßÉ×’ƒGKäMJ^åÉ{›E9šÕj¢i i ñ/ù!PV°3àQQQL‚"`±Š‹ ’§Äq€å"`g¼ˆÄúÛ•i EƒúþJ^L`˜!`ÇQ~A„9íù!>ŸÿÕ åp¢Ñ/³{˜ñ büõÂÁÝ‘Ÿ˜ÎíÞÆáġۖʤzG61g‹âêÜ MËÃRФ¬›±¹}T=6”d¦«GÊ¤Š’DKKá…§‰- ¯¿ÌòÕ„,Êfs¹,Zþä–Ä A#iJ6›Î}ÿIKjGBQV’bQ<ZNÑšù›j³ä±s3d,[.W ÐÔÇþÌëOò~qÔ¨<7*ôʻ⺠X ¶ž-Ð$‡ÃQ¿—P~A¤*ÚÇå´¼Ù”Å*LMJÊ % ãÓ4-§é‡ 0¨gÀÉ%KÉ/ù˜Ì77^S»íØ{Ýß¿¡jcqQaùÇk\ÚµÝ=r GnÕ¬w›ÚF¢wŸ“Sâ>}ÈåÕ8¦/‡ÈÏ”$)ÍÉÉãrÙeÊâ4ÆÂJšŠq­õX°ëÄe{Îb³I\)—Ër…\.kÔɈ£ÛË,< ÂؾNt! †nA¾Y7nÞ×Ð××ÞÒ’O§‰’_¿³k1¤¡›c||2Aƒ(YjhG“r- ¢ Fý$Þ½~—ˆÅÀE¾èÉÍ{q‚–ÝGú;7BNíº;;×­[[ÀÂdo½/h9v¬•Õ-÷YØãpæÄIL©`±Y4E‘ÙÐÇWŸ…a|ûÀî#¹&ÖÎVBIvbjüˈ4A=¿®?µjaH'%dRÍâ9µoXËθL#CÏŸµæ²iŠ¢( €Ó£s»¬bE~žD*Ç1—Ïšš …'‡¢´¥.½‚^íxØ©ÞXŠ*™yááÛѹNBØ›¨{/ž(i–¡©Më^£:·¬'ÍNR’E…KÈî-¹Éšó «ó‚ òƒÑž’Ëå´ÆšCM9¹Ôåàrªn3³ƒ{N`u|'Ž ²R¢”d¯ AÄIŸ¤X¶¨_˜'ÅÆ9µÒÉÕ8=*B`éÐqx²X\——“›'SâE†q¸¦Î66Yi©8 €ãŠŒ¢Ïy˜\IÕ ìåïRË,ÈJNÍ+ür‡…çÆÇ—®æØ¸© .‘)qœ €mbã`gÜØØ€Çe³0ŒVuwII‹¸R·7°ì¼-©s‘¬–/-È2¬Ü«¹¹>G¨'À@©¦%Æäˆe þüˆcëßÌ›œ,%ȯúo”B©&‰Êl iß¾½æýIà&nú9éEÓ4)•ÙÔqÇó2Ò²òÕOˆ Ì­-…Éq©ÐFöî†Ò‘úåKßÀÏãq9lõÌišRfdV6ºf‘ ѕ˟GŽÎ/*?cúer@“…WÏÞ÷=¹¥EQtRfÜÂÂÂT+¬#‚ ©z\Ž¢(ÀXñŸóI’*½Ìޤ¿~ITœ“PòJn§~UY\XPü·´ÿïÂâÙuh%ŽçZ]>´ªò=vkîØ¶›ƒ %&¥üx&‚ R¹*ÖÁû’í(VòSß”óÿH`SÏPIÌ;*WQÙ“CÐ 62¦ò}A­´ç‡ …æE}™¯ÿé6Ö"_¤kz§L P~A¤rÚŸR=S‘¾•ÿGh‡‡=?„ Ríãr÷ïßÿ‡Û ‚ü˜´Ì—CAŒöü‚ ‚ü3´ç‡A䟡ê ‚ òÝ¡~A©I(?„ ‚Ô$”BAj—CAjê‡Aš„òCÈß;wjº ÿvÁÁÁe¶  U ­Ê P~ùA¨‚Òú¾DŠ¢ª,þߣÐÐP­ç´2˜Ò  U²rôGs݆gÏži£é?ß,©ZO¦?ì«{¾¹MàQ_£iš$IÔyW4Ô!?­gR&ç”ÿ*&‡‚V“ç´¡¿~ ÿEó÷§¢}P~ù!H¥R(·’Ö|JUQ¾Öó šV•M"‘€ºïQýæi ÃÔÑÐ4”B~B¡°üý<Ä_w0ZÏ(hå1 I’ši!úÇ—SuBªÞ*š· :{úè³Be5 ’xfhhhñ#ž¤"¨B¦ž]Ü!%àùîÍ· äðhíš[ÉÅêRnŽn?ú©êë;‹fŽ/u2Z¬Ú{xÚôEÓ‡. ÑZ¿,34,½êqrIÊ“§¹òo<–ïåÅòik>ü­!Ï =þíõh/ã_ßÚý«Âû¯öõ‹,ëÑË -Ç^¾BIê³ç¹Šê~N5¡üòCPýž—Iuèš:9¸6©ùé‰õHš¦pBV>ãð±u?O*Ê83{µlÛºÁ¸R©À•8Ž@ÒóG¼I+ú[÷ÍšœÍ!q§É¿îˆ]wùÔ¾žý¿ÙxA;;ÍÊ)eúôK¹‚ãøÇ5cæ>HŒÅ5·±wtplÚ~@Ÿ–.%{r ç˜súÊ: Î7]Gj¯i=0 ¦ˆyz1 Ÿ®¯ë§']ûó½íM¬ªÜ37îèªõ{tª[É>·¯]­ÜÙŽÇÚÔ»cîŸgþp2*³ƒfxU[¯íÚxôVTt\1ÁµukÒoÄ´±=@Uá­2hr¹œ.7­C5.WíÁÌ×—¶ï8}?6.IÆ6tvsë2|Öˆà/Ñø´~üŠ˜àãõ+9R³jÓŒîl¬²vr9KÕŠ,]°`u›ÎNú\EaØåwÖ /Ÿ7pÅ•¤aó›ç×TX”ð 4dý¢!g·ý\¿òðV4@P>?¤™¨×µozßÏd#ç.\ÐØ€Èy}÷ä ‡ÝºèÈï}T{àù¢ô"6› 4%Ù¿<1-/7S  è¢œì,R˜°ŸÑ™2³A–꬛V6ÉÁ5ñfc˜4‡Pm·ô6“íårƒª“ï’€.vúûn?q0ÈŒˆˆˆŒˆ‰-|ü*T’¼ªÛO¡õêy:[ë‰<{¬_àçbgvs^§MÎëkéñµ¶GQ6vá½›îèñ¸À5o7ág€¬—‡Ôù!¼(|ÊÕSݱרDYô™Í5wÒç €Åá–îünöδÍsºh†—emîcUy©¢ðþ“ù!B™MÑ´Y3 UîG“YSêr’cé³0ÒÌÃËî6²ÃÂÜL^7ð« Ñ™2Ó~æªVMM¥?³Ùmtj°V(?„ ß™•_ÿq]¿¤.v¾xXùþz6}Lò–†? GãT[â$Dêªe¸ð }ö혉 BhWÅ¡²èIÓF%9={=BžPíù¤"õÔ‰kÉÉII‰Iññ±É™ì„]wÛ7qw«?8°§»{6FNóÃÌ€„³C¦DÔr±3+Œ;:ûšôàS­uRxÎ`ó×¶µ­ä£ßmû]ÙwÛ°:Æšâ0®AóòÍÜ2zR¢çø:¼,ž ÃÄ‘bh\ÙÅ~ †WÍ·caXÞÛ¼òMÍ{•Çâë—ŽLr„užûÓøýÎN“Fkxc¨§‰zÏ$)´êZ¡ÐNH*’þ–£ÒõC¢¥8S$ú’‡RUÞKaõ„ì„æó+vœx2~X—~¶î„c;ü'ζ+Í©ØðØ9ÙU<´‘ñ膱G;ª¾Uä(ؼÊNÙ#Œõð]œ»›{§íÝÝë˜)ÿì:ÞnóšiZ÷µðmšõ×;€FáG.,ÜßL[¬(!tƸÙxíooZéÔ9ðžê0U6ôñÏÛ¶ËËl|´{ì9ºË½%]àëð²Ø&ÝÍÎ>€Á®eŠà4pK?¾&Ã[ cô2Þ¿õ FÕ)ó£»/sõmFª¿åù¹ëqÀoÊ–¡Ï§ÿ<¶Á­c K&ŒXóع9 ]+Tä*YÜ.7†òCÈá»ä‡Š–¦G¾y“®Þ’ƒ“$¯N׎Šòù¡ø³#[_NÓn „XÜÅYGN67°= @4–xwÐ8½[WMòr3à=ÌÇ;”œøÊç‡ žŒ]jÛnq~I6%÷“˜gâVy’£rÕÏÅ–µ_ÎûÊÂN²¼åJ|¢Ö.„kÒKš=LJx/<ÖL#¤B)ó_Þ¿hÅaë¶#®˜ªGå­Ä š¦åê‚, qR³†´¥·Eoy–„€Ä‹ÿ6aÃmìÄ­™l’Àɲá;Ë÷ÒÂuÛóûÒÓD™7roú•«T UÞ2?#f´8¿pí¶·í5gU¤Ý[z,KÒwWwUšG•R}í7uOß°ÎS†ÿqùôbC6nܰh1ÙÞŽy…PYÈ7v+ŸFª”B|>Ÿ®ÃJ8,Ì.xìüŸ¾ÌSXtõ4›Ã5°ê²|!@™üKß=k†ãà5ØiÑœé ™W¯eºLô,­ó›¨³b(?„üè*9Ÿ2?;ÐêËašN41¦))wŒ¦iúÑ£g†&&É/rY|Vi…4 csS™9ƒÛË}i~!–OP€q,7]ÔcúÙâI¾úlÌ®ãhéÊå™Ê¡V\ð-kÙ…oØޱ¸¦VÖ¶Î+öÌîÒÒƒUúÇL*Rd*ÖÚTãÔ¦H•Ó4ÕÍ\’)õ©`Þy/+½ó™R/ç¯Þq €ˆ\ýúKvÏkï[ƒA%Í0t˜»v¶Áãð—âb‚@OO_ÏÒ”EÓ´4ëÆCeû³ë©‹{ù9ÇöÛ1 €…©7– /6z홦þ[6?6eûr É­åÖhææ³?{V^&A+³ÐƒæQõÞs:rù†·o>¾éÌšTKÏɭΨÕÇF{¨kãYÚ9Ö2RËÖßµs˜¥‡¶ù@÷É@)äÀS=ФnaEáe4­Ð7¾¤¼iω‡zN¤)ñU,ͪ|¨rÏŠÂËäðËtBš#r54Kß±ýú¿|ÉdçQßµ©L­?„ü(´žOkºQÿv(hºÒ|}À¾v­ †aª•XUÿ× =?„ü …æi´Ì×5ݺPæðµžPÐÊ`4¥RYQÐ~Le~aÐóCÈ‹ÃáЫéÖÕúëÇx+Ju  ib4‹¥5J?fÄT4å‡×ýû÷kº ÿPЪáéÓ§5Ý„ÿ?˜H$ªé6 ‚ ?.”BAjÊ!‚ 5 ÍÛFAjê‡Aš„òC‚ HMBù!A¤&ý ¹=åÃæIEND®B`‚ngraph-gtk-6.08.00/doc/html/ja/object.html.in0000644000175000017500000000570713246234367015537 00000000000000 Object  

Ngraphオブジェクト




概è¦


Ngraphã§æç”»ã•れるグラフã¯Ngraphオブジェクトã®é›†åˆã‹ã‚‰æˆã‚Šç«‹ã£ã¦ã„ã¾ã™ã€‚
Ngraphã§ã®ã‚°ãƒ©ãƒ•ã®ä½œæˆã¯, グラフを構æˆã™ã‚‹Ngraphオブジェクトã®ãƒ•ィールド値を設定ã™ã‚‹ã“ã¨ã«ã‚ˆã‚Šè¡Œã‚れã¾ã™ã€‚
フィールド値ã®è¨­å®šã¯, メニューやダイアログボックスã§ã®æŒ‡å®š, ã‚ã‚‹ã„㯠*.ngp ファイルã«è¨˜è¿°ã•れã—ãŸã‚¹ã‚¯ãƒªãƒ—トをインタープリタã§å®Ÿè¡Œã—ã¦è¡Œã‚れã¾ã™ã€‚

  • オブジェクトã®ä¸€è¦§ã‚’表示ã™ã‚‹ã«ã¯[Graph]-[Ngraph shell]ã§ã‚¹ã‚¯ãƒªãƒ—ト・インタープリタを起動ã—ã€object コマンドを実行ã—ã¦è¦‹ã‚‹äº‹ãŒã§ãã¾ã™ã€‚
  • オブジェクトã®ãƒ•ィールドを表示ã™ã‚‹ã«ã¯ object object_name 㨠object コマンドã®å¼•æ•°ã«ã‚ªãƒ–ジェクトåを指定ã—ã¾ã™ã€‚

Ngraphオブジェクト階層




Ngraphオブジェクト一覧

å„オブジェクトã®ãƒ•ィールド一覧を示ã—ã¾ã™ã€‚

ngraph-gtk-6.08.00/doc/html/ja/data.html0000644000175000017500000003074413256674413014575 00000000000000 Data file  

データファイル




データファイルã®å½¢å¼


データファイルã¯ãƒ†ã‚­ã‚¹ãƒˆãƒ•ァイルã§ã€åŸºæœ¬çš„ã«ã¯æ¬¡ã®ã‚ˆã†ãªãƒ•ォーマットã§ã™ã€‚

コメント行
… (コメントã¯ç„¡ãã¦ã‚‚æ§‹ã„ã¾ã›ã‚“)
コメント行
カラム1カラム2カラム3カラム4 …
カラム1カラム2カラム3カラム4 …
% コメント行
カラム1カラム2カラム3カラム4 …
カラム1カラム2カラム3カラム4 …
…………

データファイル中ã®ã‚³ãƒ¡ãƒ³ãƒˆ
  • データファイル先頭部分ã¯Dataダイアログボックスã®[Load...]ã®å…ˆé ­ã‚¹ã‚­ãƒƒãƒ—è¡Œæ•°ã§æŒ‡å®šã—ãŸè¡Œæ•°ã ã‘ã¾ã¨ã‚ã¦èª­ã¿é£›ã°ã›ã‚‹ã®ã§, コメントãªã©ã‚’入れã¦ãŠãã“ã¨ãŒã§ãã¾ã™ã€‚
  • デフォルトã§ã“ã®è¡Œæ•°ã¯0行ã§ã™ã€‚
  • コメントã¯ãªãã¦ã‚‚ã‹ã¾ã„ã¾ã›ã‚“。

ファイル途中ã¸ã®ã‚³ãƒ¡ãƒ³ãƒˆã®æŒ¿å…¥
  • ファイル途中ã«ã‚³ãƒ¡ãƒ³ãƒˆã‚’入れるã«ã¯è¡Œé ­ã«Dataダイアログボックスã®[Load...]ã§Remarkã«è¨­å®šã•れã¦ã„る文字を入れã¾ã™ã€‚
  • デフォルトã§ã¯ # % ' ã§ã™ã€‚

データファイルã‹ã‚‰ã®èª­ã¿è¾¼ã¿
  • データファイルã®ç¬¬ä¸€è¡Œç›®ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル埋ã‚è¾¼ã¿ã‚ªãƒ—ションを記述ã—ã¦ãŠã㨠Dataダイアログボックスã®[Load settings]ボタンを押ã—ã¦å„種設定をデータファイルã‹ã‚‰èª­ã¿å–る事ãŒã§ãã¾ã™ã€‚

データ
  • カラム1, カラム2, カラム3, ... ã«æ•°å€¤ãƒ‡ãƒ¼ã‚¿ã‚’入れã¾ã™ã€‚
  • ãƒ‡ãƒ¼ã‚¿ãƒ•ã‚¡ã‚¤ãƒ«ã®æœ€å¤§ã‚«ãƒ©ãƒ æ•°ã¯999個ã§ã™ã€‚
  • ä¸€è¡Œã®æœ€å¤§æ–‡å­—æ•°ã¯ç‰¹ã«åˆ¶é™ãŒã‚りã¾ã›ã‚“。
  • カラムã®åŒºåˆ‡ã‚Šã¯Dataダイアログボックス[Load...]ã®IFSã§è¨­å®šã§ãã¾ã™ã€‚
  • デフォルトã§ã¯ã‚¹ãƒšãƒ¼ã‚¹, コンマ, タブ, 括弧ã§ã™ã€‚
  • 改行コード㯠LF, CR LF, CR ã®ã„ãšã‚Œã‹ã§ã™ã€‚

æ•°å€¤ãƒ‡ãƒ¼ã‚¿ã®æŒ‡æ•°éƒ¨æŒ‡å®š
  • æ•°å€¤ãƒ‡ãƒ¼ã‚¿ã®æŒ‡æ•°éƒ¨æŒ‡å®šå­ã«ã¯ e, E, DãŒä½¿ãˆã¾ã™ã€‚
  • (例) 1.0D+002

ç©ºè¡Œã®æ‰±ã„
  • ヌル行(IFSã®ã¿ã‹ã‚‰ãªã‚‹è¡Œ)ã¯èª­ã¿é£›ã°ã—ã¾ã™ã€‚



欠æãƒ‡ãƒ¼ã‚¿ã‚’å«ã‚€ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル


Ngraph ã§æ¬ æãƒ‡ãƒ¼ã‚¿ã‚’指定ã™ã‚‹æ–¹æ³•を示ã—ã¾ã™ã€‚例ã¨ã—ã¦ï¼Œ2行目ã®ãƒ‡ãƒ¼ã‚¿ãŒæ¬ è½ã—ã¦ã„ã‚‹å ´åˆã‚’考ãˆã¾ã™ã€‚

XYZ
1.02.03.0
2.0 4.0↠YãŒæ¬ è½ã—ã¦ã„ã‚‹
3.04.05.0

ã“ã®ã¾ã¾, Dataダイアログボックスã§(X) columnã‚’1, (Y) columnã‚’2ã«ã—ã¦æç”»ã™ã‚‹ã¨, 2行目ã®Yã«ã¯Zã®å€¤ãŒä½¿ã‚れã¦ã—ã¾ã„ã¾ã™ã€‚

欠æãƒ‡ãƒ¼ã‚¿ã‚’æ­£ã—ãæç”»ã™ã‚‹ã«ã¯ | ã‚ã‚‹ã„㯠= を欠æéƒ¨åˆ†ã«å…¥ã‚Œã¾ã™ã€‚

1.02.03.0
2.0 | 4.0
3.04.05.0
ã‚ã‚‹ã„ã¯
1.02.03.0
2.0 = 4.0
3.04.05.0

ã“れã§Yã®æ¬ æãƒ‡ãƒ¼ã‚¿ã‚’æ­£ã—ãスキップã—ã¾ã™ã€‚

  • | 㨠= ã®é•ã„

    • データプロット形å¼ãŒmarkãªã©ã®ç‚¹é¡žã¨Fitã®å ´åˆã¯åŒºåˆ¥ãŒã‚りã¾ã›ã‚“。ã©ã¡ã‚‰ã§ã‚‚åŒã˜ã‚°ãƒ©ãƒ•ã«ãªã‚Šã¾ã™ã€‚
    • データプロット形å¼ãŒlineãªã©ã®ç·šé¡žã§ã¯ç•°ãªã‚Šã¾ã™ã€‚ | ã§ã¯æ¬ æãƒ‡ãƒ¼ã‚¿ã®å‰å¾Œã‚’直線・曲線ã§çµã³ã¾ã™ã€‚ = ã§ã¯ãã®å‰å¾Œã§ç›´ç·šãƒ»æ›²ç·šãŒåˆ†æ–­ã•れã¾ã™ã€‚

  • 欠æãƒ‡ãƒ¼ã‚¿ã®åˆ¥è¡¨è¨˜æ³•

    • 'CONT' 㯠'|' ã¨åŒç­‰ã§ã™ã€‚
    • 'BREAK'㯠'=' ã¨åŒç­‰ã§ã™ã€‚

欠æãƒ‡ãƒ¼ã‚¿ã®(ã‚ã¾ã‚ŠãŠå‹§ã‚ã—ãªã„)指定方法

  • 欠æéƒ¨åˆ†ã‚’数値データã§ã¯ãªã„文字ã§åŸ‹ã‚ã¾ã™ã€‚

    1.02.03.0
    2.0 A 4.0
    3.04.05.0

    ã“ã®æ–¹æ³•ã§ã¯, æç”»ã®åº¦ã«ã‚¨ãƒ©ãƒ¼ãŒå‡ºã¦ä¸€æ™‚åœæ­¢ã—ã¾ã™ã€‚

  • 2行目ã®å…ˆé ­ã«%#'ã®ã„ãšã‚Œã‹ã®è¨˜å·(Dataダイアログボックスã®Remarkã§å¤‰æ›´å¯èƒ½)を入れã¦2行目全体をスキップã•ã›ã¾ã™ã€‚

    1.02.03.0
    %2.0 4.0
    3.04.05.0

    ã“れã§ã¯2行目ã®ãƒ‡ãƒ¼ã‚¿ã¯X, Y, Zã¨ã‚‚åˆã‚ã‹ã‚‰å­˜åœ¨ã—ãªã„ã®ã¨åŒã˜äº‹ã§ã™ã€‚ 従ã£ã¦, (Y) columnã‚’3ã«ã—ãŸã¨ã, Z=4.0もスキップã—ã¦ã—ã¾ã„ã¾ã™ã€‚

欠æãƒ‡ãƒ¼ã‚¿ã‚’利用ã—ãŸè¤‡æ•°ã‚°ãƒ©ãƒ•ã®æç”»

  • 欠æãƒ‡ãƒ¼ã‚¿ã®æŒ‡å®šã‚’応用ã—ã¦ï¼Œãƒ‡ãƒ¼ã‚¿ã‚’ = = ã§åˆ†æ–­ã™ã‚Œã°ä¸€ã¤ã®ãƒ•ァイルã§è¤‡æ•°æœ¬ã®ã‚°ãƒ©ãƒ•ã‚’æç”»ã§ãã¾ã™ã€‚

  • [例]データを = = ã§åˆ†æ–­ã—ã¦2本ã®ç›´ç·šã‹ã‚‰ãªã‚‹ã‚°ãƒ©ãƒ•ã‚’æã例を示ã—ã¾ã™ã€‚

    1.02.0
    2.03.0
    3.04.0
    = =
    4.05.0
    5.06.0
    6.07.0




ãƒ‡ãƒ¼ã‚¿ãƒ—ãƒ­ãƒƒãƒˆå½¢å¼ diagonal, arrow, rectangle ã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル


ãƒ‡ãƒ¼ã‚¿ãƒ—ãƒ­ãƒƒãƒˆå½¢å¼ diagonal, arrow, rectangle, rectangle_fill, rectangle_solid_fill ãªã©ã‚’用ã„ã¦å¯¾è§’線や矩形をプロットã—ãŸã„時ã«ç”¨ã„るデータファイル形å¼ã§ã™ã€‚

[例](0, 0)-(1, 1) 㨠(1, 1)-(1, 2) ã«å¯¾è§’ç·š, ã‚ã‚‹ã„ã¯çŸ©å½¢ã‚’æããŸã„ã¨ã次ã®ã‚ˆã†ãªãƒ•ァイルを作り, (X) columnã‚’1, (Y) columnã‚’3ã«ã—ã¾ã™ã€‚

0.00.01.01.0
1.01.01.02.0


始点ã®Xã¨Y, 終点ã®Xã¨Yã¯ãれãžã‚Œé€£ç¶šã—ã¦ã„ãªã‘れã°ãªã‚Šã¾ã›ã‚“。 (4ã¤ãŒé€£ç¶šã—ã¦ã„ã‚‹å¿…è¦ã¯ã‚りã¾ã›ã‚“)



データプロット形å¼error_bar_xã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル


データプロット形å¼error_bar_xを用ã„ã¦èª¤å·®æ£’をプロットã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

例ãˆã°æ¬¡ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ã‚’考ãˆã¾ã™ã€‚

XError(X)Y
1.0+/-0.52.0
2.0+/-1.03.0


ã“ã®ã¨ã, 次ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを作り (X) columnã‚’1〠(Y) column ã‚’4ã«ã—ã¾ã™ã€‚

1.0-0.5+0.52.0
2.0-1.0+1.03.0


X, Xã®èª¤å·®ä¸‹é™, Xã®èª¤å·®ä¸Šé™ ã®3ã¤ã®ã‚«ãƒ©ãƒ ã¯é€£ç¶šã—ã¦ã„ãªã‘れã°ãªã‚Šã¾ã›ã‚“。



データプロット形å¼error_bar_yã®ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル


データプロット形å¼error_bar_yを用ã„ã¦èª¤å·®æ£’をプロットã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚

例ãˆã°æ¬¡ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ã‚’考ãˆã¾ã™ã€‚

XYError(Y)
1.02.0+/-0.5
2.03.0+/-1.0


ã“ã®ã¨ã, 次ã®ã‚ˆã†ãªãƒ‡ãƒ¼ã‚¿ãƒ•ァイルを作り, (X) columnã‚’1, (Y) column ã‚’2ã«ã—ã¾ã™ã€‚

1.02.0-0.5+0.5
2.03.0-1.0+1.0


Y, Yã®èª¤å·®ä¸‹é™, Yã®èª¤å·®ä¸Šé™ ã®3ã¤ã®ã‚«ãƒ©ãƒ ã¯é€£ç¶šã—ã¦ã„ãªã‘れã°ãªã‚Šã¾ã›ã‚“。



データファイル埋ã‚è¾¼ã¿ã‚ªãƒ—ション


データファイルã®ä¸€è¡Œç›®ã«ãƒ‡ãƒ¼ã‚¿ãƒ•ァイル埋ã‚è¾¼ã¿ã‚ªãƒ—ションを記述ã—ã¦ãŠãã¨ã€Dataダイアログボックス㮠[Load settings]ボタンã§å„種設定をå–り込む事ãŒã§ãã¾ã™ã€‚ 複数ã®ã‚ªãƒ—ションを記述ã™ã‚‹å ´åˆã«ã¯, å„オプションã¯ã‚¹ãƒšãƒ¼ã‚¹, タブã§åŒºåˆ‡ã‚‰ãªã‘れã°ãªã‚Šã¾ã›ã‚“。

-xcolumn(X) Column ã‚’ column ã«ã—ã¾ã™ã€‚
-ycolumn(Y) Column ã‚’ column ã«ã—ã¾ã™ã€‚
-dtype[,{mark_type|interpolation}]プロットタイプを type ã«ã—ã¾ã™ã€‚ type ㌠mark ã®æ™‚ã«ã¯ã‚«ãƒ³ãƒžã«ç¶šã„ã¦ãƒžãƒ¼ã‚¯ã®ç¨®é¡žã‚’æ•°å­—ã§æŒ‡å®šã—ã¾ã™ã€‚ type ㌠curve ã®æ™‚ã«ã¯ã‚«ãƒ³ãƒžã«ç¶šã„ã¦è£œé–“æ–¹å¼(spline, spline_close, bspline, bspline_close)を指定ã—ã¾ã™ã€‚
[例] -dline -dmark,10 -dcurve,spline_close
-omark_sizeマークã®å¤§ãã•ã‚’mark_size ã«ã—ã¾ã™ã€‚
-lline_styleラインスタイルを指定ã—ã¾ã™ã€‚
例) -l100,40,40,40
-wline_widthライン幅を line_width ã«ã—ã¾ã™ã€‚
-cR, G, BプロットカラーをRGBã§æŒ‡å®šã—ã¾ã™ã€‚
-CR, G, BプロットタイプãŒmarkã®æ™‚ã«ä½¿ç”¨ã•れる第2カラーをRGBã§æŒ‡å®šã—ã¾ã™ã€‚
-v{x|y}smoothéš£æŽ¥å¹³å‡æ•°ã‚’ smooth ã«ã—ã¾ã™ã€‚
-sskip先頭スキップ行数を skip ã«ã—ã¾ã™ã€‚
-rstep読込ステップ行数を step ã«ã—ã¾ã™ã€‚
-ffinal_line読込最終行数を final_line ã«ã—ã¾ã™ã€‚
-m{x|y}mathå¤‰æ›æ•°å¼ã‚’ math ã«ã—ã¾ã™ã€‚
-e{x|y}scale_type軸ã®ã‚¹ã‚±ãƒ¼ãƒ«ã‚¿ã‚¤ãƒ—ã‚’ scale_type ã«ã—ã¾ã™ã€‚
scal_type ã«ã¯ linear, log, inverse を指定ã—ã¾ã™ã€‚
-z{x|y}min, max, incè»¸ã®æœ€å°, 最大, 増分を min, max, inc ã§æŒ‡å®šã—ã¾ã™ã€‚



ngraph-gtk-6.08.00/doc/html/ja/Makefile.am0000644000175000017500000000174313070106167015015 00000000000000ngraphconfdir = $(sysconfdir)/$(PACKAGE) dist_html_DATA = addin.html copyrigh.html data.html gra.html math.html \ ngraph.html operate.html refer.html text.html tutorial.html nodist_html_DATA = object.html intro.html script.html EXTRA_DIST = object.html.in intro.html.in script.html.in htmldir = $(docdir)/html/ja object.html: $(top_builddir)/src/libngraph.la object.html.in $(srcdir)/../objlist.nsc cat $(srcdir)/object.html.in > object.html $(top_builddir)/src/ngraph -i $(srcdir)/../objlist.nsc >> object.html intro.html: intro.html.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/intro.html.in script.html: script.html.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/script.html.in CLEANFILES = intro.html script.html DISTCLEANFILES = object.html SUBDIRS = tutorial dialogs ngraph-gtk-6.08.00/doc/html/ja/copyrigh.html0000644000175000017500000000602013246234367015475 00000000000000 Copyright  

ãã®ä»–




著作権・連絡先・è¬è¾ž


  • 著作権等

    Ngraph for X11. Copyright (C) 2002, Satoshi ISHIZAKA.
    
    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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
    
    
    Ngraph for X11. Copyright (C) 2002, çŸ³å‚æ™º
    
    ã“ã®ãƒ—ログラムã¯ãƒ•リーソフトウェアã§ã™ã€‚ã‚ãªãŸã¯ã“れをã€ãƒ•リーソフトウェ
    ア財団ã«ã‚ˆã£ã¦ç™ºè¡Œã•れ㟠GNU一般公衆利用許諾契約書(ãƒãƒ¼ã‚¸ãƒ§ãƒ³2ã‹ã€å¸Œæœ›
    ã«ã‚ˆã£ã¦ã¯ãれ以é™ã®ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã®ã†ã¡ã©ã‚Œã‹)ã®å®šã‚ã‚‹æ¡ä»¶ã®ä¸‹ã§å†é ’布ã¾
    ãŸã¯æ”¹å¤‰ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚
    
    ã“ã®ãƒ—ãƒ­ã‚°ãƒ©ãƒ ã¯æœ‰ç”¨ã§ã‚ã‚‹ã“ã¨ã‚’願ã£ã¦é ’布ã•れã¾ã™ãŒã€*å…¨ãã®ç„¡ä¿è¨¼* 
    ã§ã™ã€‚商業å¯èƒ½æ€§ã®ä¿è¨¼ã‚„特定ã®ç›®çš„ã¸ã®é©åˆæ€§ã¯ã€è¨€å¤–ã«ç¤ºã•れãŸã‚‚ã®ã‚‚å«
    ã‚å…¨ã存在ã—ã¾ã›ã‚“。詳ã—ãã¯GNU一般公衆利用許諾契約書をã”覧ãã ã•ã„。
    
    ã‚ãªãŸã¯ã“ã®ãƒ—ログラムã¨å…±ã«ã€GNU一般公衆利用許諾契約書ã®è¤‡è£½ç‰©ã‚’一部
    å—ã‘å–ã£ãŸã¯ãšã§ã™ã€‚ã‚‚ã—å—ã‘å–ã£ã¦ã„ãªã‘れã°ã€ãƒ•リーソフトウェア財団ã¾
    ã§è«‹æ±‚ã—ã¦ãã ã•ã„(宛先㯠the Free Software Foundation, Inc., 59
    Temple Place, Suite 330, Boston, MA 02111-1307 USA)。
    
  • ソースファイル
    本プログラムã®ã‚½ãƒ¼ã‚¹ãƒ•ァイルã¯GitHubã‹ã‚‰å…¥æ‰‹ã§ãã¾ã™ã€‚
  • 連絡先

  • è¬è¾ž
    • é©åˆ‡ãªã‚‹æ•°å¤šãã®ã‚¢ãƒ‰ãƒã‚¤ã‚¹ã‚’戴ã,開発ã«åŠ›ã‚’è²¸ã—ã¦ãã ã•ã£ãŸé£¯åŽŸé †æ¬¡ã•ã‚“ã«æ„Ÿè¬è‡´ã—ã¾ã™ã€‚
    • ドキュメント作æˆã«ã‚ãŸã£ã¦ã¯æ³‰ é”也ã•ã‚“ã«ã”å”力ã„ãŸã ãã¾ã—ãŸã€‚感è¬è‡´ã—ã¾ã™ã€‚
    • ã”æ„è¦‹ãƒ»ã”æ„Ÿæƒ³ãƒ»ã”è¦æœ›ãƒ»ãƒã‚°æƒ…å ±ãªã©ã‚’寄ã›ã¦ãã ã•ã£ãŸå¤šãã®æ–¹ã€…ã«æ„Ÿè¬è‡´ã—ã¾ã™ã€‚



ngraph-gtk-6.08.00/doc/html/ja/ngraph.html0000644000175000017500000001613013250631401015114 00000000000000 Ngraph-gtk User's Manual

Ngraph-gtk User's Manual

Ngraph logo

Copyright (C) 2002, Satoshi ISHIZAKA.


  1. Ngraphã®æ¦‚è¦
  2. ãƒãƒ¥ãƒ¼ãƒˆãƒªã‚¢ãƒ«
  3. æ“作方法
  4. リファレンス
  5. データファイル
  6. データã®åŠ å·¥
  7. フォント/テキスト
  8. GRAファイル
  9. Ngraphスクリプト
  10. Ngraphオブジェクト
  11. アドイン
  12. ãã®ä»–
ngraph-gtk-6.08.00/doc/html/ja/Makefile.in0000644000175000017500000005734313367273152015045 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc/html/ja ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_html_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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 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)$(htmldir)" "$(DESTDIR)$(htmldir)" DATA = $(dist_html_DATA) $(nodist_html_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 distdir-am 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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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 = $(docdir)/html/ja 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ ngraphconfdir = $(sysconfdir)/$(PACKAGE) dist_html_DATA = addin.html copyrigh.html data.html gra.html math.html \ ngraph.html operate.html refer.html text.html tutorial.html nodist_html_DATA = object.html intro.html script.html EXTRA_DIST = object.html.in intro.html.in script.html.in CLEANFILES = intro.html script.html DISTCLEANFILES = object.html SUBDIRS = tutorial dialogs 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) --gnu doc/html/ja/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/html/ja/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_htmlDATA: $(dist_html_DATA) @$(NORMAL_INSTALL) @list='$(dist_html_DATA)'; test -n "$(htmldir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmldir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmldir)" || 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)$(htmldir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmldir)" || exit $$?; \ done uninstall-dist_htmlDATA: @$(NORMAL_UNINSTALL) @list='$(dist_html_DATA)'; test -n "$(htmldir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmldir)'; $(am__uninstall_files_from_dir) install-nodist_htmlDATA: $(nodist_html_DATA) @$(NORMAL_INSTALL) @list='$(nodist_html_DATA)'; test -n "$(htmldir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmldir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmldir)" || 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)$(htmldir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmldir)" || exit $$?; \ done uninstall-nodist_htmlDATA: @$(NORMAL_UNINSTALL) @list='$(nodist_html_DATA)'; test -n "$(htmldir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmldir)'; $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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 $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(htmldir)" "$(DESTDIR)$(htmldir)"; 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) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) 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-dist_htmlDATA install-nodist_htmlDATA 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_htmlDATA uninstall-nodist_htmlDATA .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-dist_htmlDATA install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-nodist_htmlDATA \ 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 \ uninstall-dist_htmlDATA uninstall-nodist_htmlDATA .PRECIOUS: Makefile object.html: $(top_builddir)/src/libngraph.la object.html.in $(srcdir)/../objlist.nsc cat $(srcdir)/object.html.in > object.html $(top_builddir)/src/ngraph -i $(srcdir)/../objlist.nsc >> object.html intro.html: intro.html.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/intro.html.in script.html: script.html.in Makefile $(SHELL) $(top_srcdir)/pathconv.sh "$(bindir)" "$(docdir)" "$(pkglibexecdir)" "$(pkglibdir)" "$(pkgdatadir)" "$(ngraphconfdir)" $(srcdir)/script.html.in # 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: ngraph-gtk-6.08.00/doc/html/Makefile.am0000644000175000017500000000017213070106167014416 00000000000000HTML_FILE = index.html EXTRA_DIST = objlist.nsc htmldir = $(docdir)/html dist_html_DATA = ${HTML_FILE} SUBDIRS = img jangraph-gtk-6.08.00/doc/html/Makefile.in0000644000175000017500000005351513367273151014447 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc/html ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_html_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.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 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)$(htmldir)" DATA = $(dist_html_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 distdir-am 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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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 = $(docdir)/html 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ HTML_FILE = index.html EXTRA_DIST = objlist.nsc dist_html_DATA = ${HTML_FILE} SUBDIRS = img ja 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) --gnu doc/html/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/html/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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_htmlDATA: $(dist_html_DATA) @$(NORMAL_INSTALL) @list='$(dist_html_DATA)'; test -n "$(htmldir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(htmldir)'"; \ $(MKDIR_P) "$(DESTDIR)$(htmldir)" || 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)$(htmldir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(htmldir)" || exit $$?; \ done uninstall-dist_htmlDATA: @$(NORMAL_UNINSTALL) @list='$(dist_html_DATA)'; test -n "$(htmldir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(htmldir)'; $(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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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 $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(htmldir)"; 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 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_htmlDATA 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_htmlDATA .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-dist_htmlDATA 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 uninstall-dist_htmlDATA .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: ngraph-gtk-6.08.00/doc/Makefile.am0000644000175000017500000000001713070106167013450 00000000000000SUBDIRS = html ngraph-gtk-6.08.00/doc/Makefile.in0000644000175000017500000004703113367273151013477 00000000000000# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2018 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 = doc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \ $(top_srcdir)/m4/glib-2.0.m4 $(top_srcdir)/m4/gsl.m4 \ $(top_srcdir)/m4/gtk-3.0.m4 $(top_srcdir)/m4/iconv.m4 \ $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/lib-ld.m4 \ $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.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/nls.m4 \ $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \ $(top_srcdir)/acinclude.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.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 distdir-am 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@ ALLOCA = @ALLOCA@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ 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@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GLIB_CFLAGS = @GLIB_CFLAGS@ GLIB_COMPILE_RESOURCES = @GLIB_COMPILE_RESOURCES@ GLIB_GENMARSHAL = @GLIB_GENMARSHAL@ GLIB_LIBS = @GLIB_LIBS@ GLIB_MKENUMS = @GLIB_MKENUMS@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GOBJECT_QUERY = @GOBJECT_QUERY@ GREP = @GREP@ GSL_CFLAGS = @GSL_CFLAGS@ GSL_CONFIG = @GSL_CONFIG@ GSL_LIBS = @GSL_LIBS@ GTKSOURCEVIEW_CFLAGS = @GTKSOURCEVIEW_CFLAGS@ GTKSOURCEVIEW_LIBS = @GTKSOURCEVIEW_LIBS@ GTK_CFLAGS = @GTK_CFLAGS@ GTK_LIBS = @GTK_LIBS@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBNGRAPH_VERSION = @LIBNGRAPH_VERSION@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGFMT_015 = @MSGFMT_015@ MSGMERGE = @MSGMERGE@ 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@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ POW_LIB = @POW_LIB@ RANLIB = @RANLIB@ READLINE_LIBS = @READLINE_LIBS@ RM = @RM@ RUBY = @RUBY@ RUBY_DLEXT = @RUBY_DLEXT@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ WINDRES = @WINDRES@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ XMKMF = @XMKMF@ 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@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ runstatedir = @runstatedir@ 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@ vsymldflags = @vsymldflags@ SUBDIRS = html 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) --gnu doc/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu doc/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__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ 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: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(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: ngraph-gtk-6.08.00/ChangeLog0000644000175000017500000165655413345203342012447 000000000000002018-09-09 Hiroyuki Ito * src/gtk/gtk_subwin.c (focus_out, focus_in): added. (sub_window_create): connect "focus-in-event" and "focus-out-event". 2018-09-08 Hiroyuki Ito * src/gtk/gtk_subwin.c (set_object_name) (list_sub_window_object_name): added. 2018-09-02 Hiroyuki Ito * src/gtk/x11menu.c (application): call "gtk_icon_theme_add_resource_path()". 2018-08-23 Hiroyuki Ito * merge "marker type" feature of the path object. 2018-07-31 Hiroyuki Ito * src/gtk/gtk_widget.c (set_linumber_color): removed. 2018-07-30 Hiroyuki Ito * src/odraw.h (ARROW_POSITION_TYPE_NUM, JOIN_TYPE_NUM): added. 2018-07-28 Hiroyuki Ito * src/gtk/x11menu.c (create_toplevel_window): set toplevel window modal for the GtkColorButton (modal GtkColorChooserDialog). 2018-07-27 Hiroyuki Ito * addin/fitrslt.c (set_parameter): use "g_strdup_printf()" instead of "snprintf()". * src/shellcm.c (cmget): fix check "NWRITE" flag. * src/gtk/x11file.c (FileDialogAxis): increase size of the buffer. * src/gtk/init.c (exec_console): increase size of the buffer. 2018-07-25 Hiroyuki Ito * src/odraw.h (DEFAULT_FONT_PT): added. (DEFAULT_MARK_SIZE): added. * src/omark.c (markinit): use "DEFAULT_MARK_SIZE". * src/odata.c (f2dinit): use "DEFAULT_MARK_SIZE". * src/otext.c (textinit): use "DEFAULT_FONT_PT". * src/oaxis.c (axisinit): use "DEFAULT_FONT_PT". * src/gtk/x11axis.c (create_num_combo_item, select_type) (numbering_tab_create): now the type of the field "no_zero" is not NBOOL but NENUM. * src/oaxis.c (AXIS_NUM_NO_ZERO, anumnozero): added. (get_axis_gauge_num_str): add 3rd argument. (anumnozeroput): added. (axis): the type of the field "num_no_zero" is now "NENUM". (anumnozero): use "false" and "true" for backward compatibility. >>>>>>> d2bc2fde064a82a450f7c6aa30293de51b4b636e 2018-07-21 Hiroyuki Ito * src/axis.c (getaxisposition): compare "*po", "alocal->posst" an "alocal->posed" with "N_EPSILON". * src/mathfn.c (nraise): use "N_EPSILON" if x is nagative. * src/mathfn.h (N_EPSILON): added. 2018-07-19 Hiroyuki Ito * src/odraw.h (DEFAULT_LINE_WIDTH): added. 2018-07-17 Hiroyuki Ito * addin/legend.nsc: use "-escape" option to get fields of a data object. * src/shellcm.c (put_field_str): added. (cmget): add "escape" option. 2018-07-12 Hiroyuki Ito * src/gtk/x11file.c (FileDialogType): set sensitivity of only curve and fit button (for drawing math-functions). 2018-07-06 Hiroyuki Ito * test/math_test_new.dat: fix some tests related to comparison with precision. * src/math/math_basic_function.c (compare_double_with_prec): use "gsl_fcmp()" when available. 2018-06-30 Hiroyuki Ito * src/common.h: check "G_OS_WIN32" instead of "__MINGW32__". 2018-06-29 Hiroyuki Ito * src/ioutil.c (nstat): remove codes for windows. * configure.ac: add AC_SYS_LARGEFILE. 2018-06-27 Hiroyuki Ito * src/ioutil.c (nstat): add codes to avoid segmentation fault on Windows. 2018-06-24 Hiroyuki Ito * src/odata.c (set_const): add constants AXISX_MAX, AXISX_MIN, AXISX_LEN, AXISY_MAX, AXISY_MIN and AXISY_LEN. 2018-06-15 Hiroyuki Ito * src/gtk/x11file.c (RANGE_ENTRY_WIDTH): add and use the constant. * src/nhash.c (hash_each_sub): check returned value of the function "hash_each_sub()". * src/gra.c (GRAtextextentraw): fix calculation of the bounding box of a raw-text. 2018-06-06 Hiroyuki Ito * src/gtk/x11graph.c (CmGraphNewMenu): clear all lists. 2018-03-28 Hiroyuki Ito * src/odata.c (opendata): save "f2dlocal" to "struct f2ddata". (fitout): initialize and check "f2dlocal->use_drawing_func". 2018-03-25 Hiroyuki Ito * src/odata.c (draw_fit): use "fp->color" instead of "fp->fg". 2018-03-23 Hiroyuki Ito * src/odata.c (dummyout): added. (fitout): use "dummyout()" when redrawing. 2018-03-20 Hiroyuki Ito * gtksourceview/create_lang.nsc: remove "%D" and "%N" from the list of constrants. 2018-03-09 Hiroyuki Ito * src/gtk/ox11menu.c (mx_show_source_view_search_path): added. (gtkmenu): add field "source_view_search_path". 2018-03-08 Hiroyuki Ito * src/gtk/x11menu.c (souce_view_set_search_path): renamed. check language. 2018-03-04 Hiroyuki Ito * src/gtk/data/css/ngraph.css: remove unused style. * src/gtk/x11dialg.h (MathTextDialog): remove unused member "label". * src/gtk/x11file.c (MathTextDialogSetup): don't use label but window title. 2018-03-03 Hiroyuki Ito * src/gtk/x11file.c (MathTextDialogSetup): call "gtk_widget_grab_focus()". (math_common_widgets_create, MathTextDialogSetup): change position of the tabs. 2018-03-01 Hiroyuki Ito * src/odata.c (ofile_create_math_equation): add static constants definitions. 2018-02-28 Hiroyuki Ito * src/odata.c (file_draw_path, file_draw_polyline) (file_draw_polygon): added. (draw_polygon): add 3rd parameter. don't call "arraydel()". 2018-02-27 Hiroyuki Ito * src/gtk/x11file.c (RangeDialogSetup): update label to avoid collision with the short cut to show information of a completion. * src/odata.c (file_draw_errorbar, file_draw_errorbar2) (draw_errorbar): added. (errorbarout): use "draw_errorbar()". 2018-02-26 Hiroyuki Ito * src/gtk/x11file.c (math_common_widgets_create): call "gtk_widget_set_vexpand()". * src/gtk/x11menu.c (souce_view_initialize): moved from "x11file.c". (application): call "souce_view_initialize()". 2018-02-24 Hiroyuki Ito * src/gtk/x11opt.c (MiscDialogSetup): call "souce_view_initialize()". * src/gtk/x11file.c (souce_view_initialize): renamed. 2018-02-23 Hiroyuki Ito * src/gtk/x11file.c (set_source_style): added. (MathTextDialogSetup, math_tab_setup_item): call "set_source_style()". * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): add source style settings. * src/gtk/ox11menu.c (mx_show_lib_version): show version of GtkSourceView. (MenuConfigMisc): add "sourece_style_id" setting. (menuinit): initialize "Menulocal.source_style_id". * src/math/math_parser.c (parse_primary_expression): don't apply the limitation of the length of a variable. * src/math/math_error.c (math_err_get_error_message): show error line and line-offset. * src/math/math_equation.c (math_equation_set_parse_error): change type of the 3rd parameter from "int" to "const struct math_string *str". * src/math/math_scanner.c (math_scanner_get_token): save current line and line-offset. 2018-02-22 Hiroyuki Ito * src/object.c (get_localized_str): added. (error2, error22): use "get_localized_str()". 2018-02-21 Hiroyuki Ito * src/gtk/x11file.c (move_cursor_to_error_line): added. (MathTextDialogClose, focus_math_widget): use "move_cursor_to_error_line()". * src/math/math_error.c (math_err_get_error_message): show line number. (math_err_get_recent_error_line_number): added. * src/math/math_equation.c (math_equation_set_parse_error): add 3rd parameter. * src/math/math_scanner.c (math_scanner_init_string): added. (math_scanner_free_token): use "struct math_token *". * src/math/math_basic_function.c (math_func_array): added. * src/math/math_equation.c (math_equation_add_func): use "math_function_get_arg_type_num()". * src/math/math_parser.c (get_argument): use "math_function_get_arg_type_num()". * src/math/math_expression.c (math_function_get_arg_type_num): added. (check_argument, call_func): use "math_function_get_arg_type_num()". 2018-02-20 Hiroyuki Ito * src/gtk/x11opt.c (FontSettingDialogSetupItem) (MiscDialogSetupItem): use "gtk_font_chooser_set_font()" instead of "gtk_font_button_set_font_name()". (FontSettingDialogAddAlternative, FontSettingDialogClose) (set_font): use "gtk_font_chooser_get_font()" instead of "gtk_font_button_get_font_name()". * src/gtk/x11gui.c (message_beep): use "gdk_display_beep()". 2018-02-19 Hiroyuki Ito * src/math/math_scanner.c (math_scanner_get_token): support shell-like-comment. 2018-02-17 Hiroyuki Ito * src/gtk/x11file.c (set_text_to_source_buffer): added. (MathTextDialogChangeInputType, MathTextDialogSetup) (copy_entry_to_text): use "set_text_to_source_buffer(). 2018-02-15 Hiroyuki Ito * src/gtk/completion_info.h: added. * src/gtk/completion_info.c: added. * src/gtk/create_const_info.rb: added. * src/gtk/create_func_info.rb: added. 2018-02-11 Hiroyuki Ito * src/odata.c (odata_get_functions, odata_get_constants) (get_functions, get_constants): added. (file2d): add fields "functions" and "constants". 2018-02-10 Hiroyuki Ito * src/gtk/x11file.c (FileDialogCloseCommon, MathTextDialogSetup) (MathTextDialogClose, FileDialogSetup): save and restore math-transformation intput type. * src/gtk/ox11menu.c (menuinit): initialize "Menulocal.math_input_mode". * src/gtk/x11dialg.h (FileDialog): add member "math_input_tab". (MathTextDialog): add member "input_tab". * src/gtk/ox11menu.h (menulocal): add member "math_input_mode". 2018-02-09 Hiroyuki Ito * src/gtk/gtk_entry_completion.c (entry_completion_load): don't save a string which includes line feed. 2018-02-08 Hiroyuki Ito * src/gtk/gtk_action.c (create_application_window): don't use appmenu on Windows. * src/gtk/x11file.c (set_escaped_str): added. (file_list_set_val, MathDialogSetupItem): use "set_escaped_str()". (MathTextDialogSetup): don't use mnemonic label. 2018-02-07 Hiroyuki Ito * src/gtk/gtk_widget.c (create_text_view_with_line_number): use "GtkSourceview". * configure.ac: ckeck "gtksourceview-3.0". * src/gtk/x11menu.c (menu_undo_common, menu_undo_internal): added. (menu_undo): use "menu_undo_common()". (menu_delete_undo): check undo id. (menu_save_undo_single, menu_save_undo): return undo id. (undo_info_push): save undo id. 2018-02-06 Hiroyuki Ito * src/gtk/x11file.c: add multi line input feature for math-transformations. 2018-02-03 Hiroyuki Ito * src/omerge.c (get_mtime): removed. (read_gra): check not only "st_mtime" but "st_size". 2018-02-02 Hiroyuki Ito * src/omerge.c (OLD_GRA_HEADER): added. (USE_MERGE_CACHE): added. (gra_data_new, gra_data_free, gra_cache_new, gra_cache_get) (gra_cache_free, gra_cache_init, read_new_gra_file) (read_old_gra_file, read_gra_file, dup_cpar, draw_gra) (free_cache, read_gra, merge_cache_clear, draw_gra_data): added. (mergedraw): use "read_gra()" when "USE_MERGE_CACHE" is true. (gra_info): added. 2018-01-30 Hiroyuki Ito * src/gtk/x11commn.c (check_ref_axis, file_auto_scale): added. (FileAutoScale): don't save undo information. 2018-01-29 Hiroyuki Ito * src/gtk/x11menu.c (application): call "CmViewerDraw()" when "LoadNgpFile()" is not called. * src/gtk/x11commn.c (file_auto_scale): added. (FileAutoScale): use the function "file_auto_scale()". 2018-01-27 Hiroyuki Ito * src/math/math_basic_function.c (math_func_m, math_func_rm): accepts negative index. (math_func_cm): add 2nd argument. 2018-01-26 Hiroyuki Ito * src/gtk/x11gui.c (FileSelectionDialog): use "gtk_file_chooser_set_extra_widget()" instead of "gtk_box_pack_start()". * src/odata.c (file_draw_line, file_draw_rect, file_draw_arc): always restore current point. 2018-01-25 Hiroyuki Ito * src/gtk/x11graph.c (CmGraphShell): use "set_graph_modified()" instead of "set_graph_modified_gra()". 2018-01-21 Hiroyuki Ito * src/math/math_basic_function.c (math_func_am) (math_func_array_average, math_func_array_stdevp) (math_func_array_stdev): added. 2018-01-20 Hiroyuki Ito * src/odata.c (file_draw_line): added. 2018-01-19 Hiroyuki Ito * src/gtk/x11file.c (set_headline_table_array) (set_headline_table): check maximum column. * src/odata.c (column_array_push, column_array_clear): added. (getdataarray): use "column_array_clear()" and "column_array_push()". * src/math/math_basic_function.c (math_func_push): use "math_equation_push_array_val()". * src/math/math_equation.c (math_equation_push_array_val): added. 2018-01-18 Hiroyuki Ito * src/odata.c (getdataarray): call the function "set_column_array()". (set_column_array): call the function "math_equation_clear_array()". (set_column_array): check the parameter "id". * src/math/math_basic_function.c (math_func_array_clear): added. (math_func_array_sum): added. (math_func_array_max, math_func_array_min): added. (math_func_array_compact): added. * src/math/math_equation.c (math_equation_clear_array): added. 2018-01-17 Hiroyuki Ito * src/odata.c (getposition): use "getposition2()" and "_f2dtransf()". (f2dtransf): use "_f2dtransf()". (_f2dtransf): return integer. 2018-01-16 Hiroyuki Ito * src/odata.c (f2ddata, f2dlocal): add member "column_array_id_x" and "column_array_id_y". (opendata): initialize "fp->column_array_id_x" and "fp->column_array_id_y". (f2dputmath): check "column" array. (f2dinit): initialize "f2dlocal->column_array_id_x" and "f2dlocal->column_array_id_y". (set_column_array): added. (get_data_from_source): use the function "set_column_array()". (file_draw_mark): added. 2018-01-14 Hiroyuki Ito * src/odata.c (file_draw_arc, file_draw_rect): added. (FileFunc): add drawing functions. (opendata): initialize "fp->GC". (f2ddraw): set "fp->GC". (file_draw_rect, file_draw_arc): check the variable "fp". * src/gra.c (GRAcurrent_point): added. * src/odraw.c (curve_expand, curve_expand_points): moved from "opath.c". * src/opath.c (curve_expand_points): change parameters. (opath_curve_expand_points): added. (arrowdraw, arrowbbox, point_match): use "opath_curve_expand_points()". 2018-01-05 Hiroyuki Ito * addin/gimg2gra.c (gra_save, fputcolor): don't draw fully transparent color information and image. 2017-12-31 Hiroyuki Ito * src/gtk/x11commn.c (FileAutoScale): save undo information. 2017-12-27 Hiroyuki Ito * src/odata.c (ofile_create_math_equation): use "STDEVPX" and "STDEVPY" instead of "SGX" and "SGY". (f2dstat): add fields "dstdevpx", "dstdevpyy", "dstdevx" and "dstdevy". 2017-12-26 Hiroyuki Ito * src/math/math_basic_function.c (math_func_sumsq): added. 2017-12-21 Hiroyuki Ito * src/gtk/x11view.c (create_axis): use "menu_undo()" to cancel creation of instances. * src/gtk/x11merge.c (CmMergeOpen): use "menu_undo()" to cancel edit. (CmMergeUpdate): call "MergeWinUpdate()" only when merge objects are updated. * src/gtk/x11file.c (CmFileHistory, CmRangeAdd): use "menu_undo()" instead of "menu_delete_undo()" to cancel creation of an instance. (FileWinFileUpdate): don't consider "IDDELETE". * src/gtk/x11axis.c (SectionDialogGrid): use "menu_undo()" to cancel edit. (CmAxisNewFrame, CmAxisNewSection, CmAxisNewCross) (CmAxisNewSingle, CmAxisGridNew): use "menu_undo()" to cancel creation. (CmAxisUpdate): check the returned value of the function "DialogExecute()" is "IDCANCEL" or not. 2017-12-20 Hiroyuki Ito * src/gtk/x11view.c (new_merge_obj, new_file_obj) (create_single_axis, create_axis): don't consider "IDDELETE". (ViewUpdate): remove codes related to "IDDELETE". 2017-12-19 Hiroyuki Ito * src/gtk/x11file.c (CmFileMath): check the variable "modified". (MathTextDialog, MathDialog): initialize "modified" member variable. (MathTextDialogClose, MathDialogList): set "modified" member variable. * src/gtk/x11dialg.h (MathDialog, MathTextDialog): add member "modified". 2017-12-14 Hiroyuki Ito * src/gtk/x11view.c (ViewUpdate): redraw only when the graph is modified. * src/gtk/x11axis.c (select_type): redraw data object when "type" field is changed. 2017-12-13 Hiroyuki Ito * src/gtk/x11file.c (CmFileNew): removed. (update_file_obj_multi): "modified" is always true when "IDDELETE" is returned; 2017-12-12 Hiroyuki Ito * src/gtk/x11menu.c (set_undo_menu_label): update undo and redo menu label when use GtkBuilder. * src/gtk/x11file.c (update_file_obj_multi): call "data_save_undo()" befor call "DialogExecute()". (update_file_obj_multi): return modified or not. * src/gtk/x11menu.c (MODIFIED_TYPE_UNMODIFIED): added. (undo_check_modified): call "set_graph_modified()" only when "modified_saved"is TRUE. * src/gtk/x11menu.h (MENU_UNDO_TYPE): add "UNDO_TYPE_DUMMY". * src/gtk/x11view.c (CmEditMenuCB): check "Menulock" and "Globallock". * src/gtk/gtk_subwin.c (update): call "d->undo_save" if available. (update): always call "set_graph_modified()" after call "DialogExecute()". (update): use "menu_undo(FALSE)" instead of "menu_delete_undo()". 2017-12-11 Hiroyuki Ito * src/gtk/gtk_subwin.c (update): don't call "d->update()" if the returned value of the function "DialogExecute()" is "IDCANCEL". * src/gtk/x11file.c (FitDialogResult): use "markup_message_box()". (select_type): check the returned value of the function "show_fit_dialog()". (FileWinFileUpdate): don't call "d->update()" if the returned value of the function "DialogExecute()" is "IDCANCEL". * src/gtk/x11gui.c (markup_message_box): added. (message_box): use "markup_message_box()". 2017-12-07 Hiroyuki Ito * src/omerge.c (set_bbox): added. (mergebbox, mergemove, mergezoom, mergegeometry): use "set_bbox()". 2017-12-06 Hiroyuki Ito * src/omerge.c (get_mtime): added. (mergedraw): check mtime. (mergemove, mergegeometry): use saved bounding box. * src/odata.c (f2dredraw): check the returned value of the function "f2ddraw()". 2017-12-05 Hiroyuki Ito * src/gtk/x11merge.c (MergeWinUpdate): call "draw_notify()". * src/osystem.c (system_set_draw_notify_func, system_draw_notify): added. * src/omerge.c (mergeredraw): call "system_draw_notify()". * src/odata.c (f2dredraw): call "system_draw_notify()". * src/gtk/x11view.c (graph_dropped): don't call "CmViewerDraw()". * src/gtk/x11menu.c (application): call "system_set_draw_notify_func()". (UpdateAll2): add 2nd argment. (ChangePage): call "draw_notify()". * src/gtk/x11graph.c (CmGraphNewMenu): call "UpdateAll2()" instead of "UpdateAll()". * src/gtk/x11view.c (Draw): call "draw_notify()". * src/gtk/x11menu.c (draw_notify): added. * src/gtk/x11menu.h (FileDrawFlag): added. * src/gtk/x11file.c (FileWinUpdate): call "draw_notify()". * src/gtk/gtk_subwin.c (update): redraw flag is now "FILE_DRAW_NOTIFY". * src/gtk/data/css/ngraph.css: add definition of "draw_notify" class. 2017-12-04 Hiroyuki Ito * src/gtk/x11file.c (CmFileHistory, CmFileNew, CmFileOpen) (FileWinFileCopy, FileWinFileCopy2): don't redraw. * src/gtk/x11lgnd.c (LegendWinUpdate): add 3rd argument. * src/gtk/x11merge.c (MergeWinUpdate): add 3rd argument. * src/gtk/x11file.c (FileWinUpdate): add 3rd argument. * src/gtk/x11axis.c (AxisWinUpdate): add 3rd argument. * src/gtk/x11lgnd.c (TextListUpdate, MarkListUpdate) (RectListUpdate, ArcListUpdate, PathListUpdate): add 3rd argument. (ObjListUpdate): redraw object depend on the 3rd parameter. 2017-12-02 Hiroyuki Ito * src/gtk/x11file.c (FileWinFileDraw): save undo information. * src/gtk/x11merge.c (MergeWinUpdate): draw merge object. * src/gtk/x11menu.c (UpdateAll): call only "UpdateAll2()". (check_update_obj): added. (UpdateAll2): use "check_update_obj()". * src/gtk/x11file.c (FileWinFileDraw): don't call "CmViewerDraw()". (FileWinUpdate): draw data object. * src/gtk/x11axis.c (AxisWinUpdate): draw axis, axisgrid and data objects. 2017-12-01 Hiroyuki Ito * src/gtk/x11gui.c (message_beep): call "gdk_beep()" when the variable "parent" is NULL. 2017-11-30 Hiroyuki Ito * src/gtk/x11gui.c (message_beep): use "gdk_window_beep()" instead of "gdk_beep()". (fsok): use "message_beep()" instead of "gdk_beep()". 2017-11-29 Hiroyuki Ito * addin/timer.nsc: execute "gra::flush". * addin/img2gra.nsc: execute "gra::flush". 2017-11-27 Hiroyuki Ito * src/gtk/x11menu.c (reset_graph_modified): call "reset_modified_info()". (undo_info_push): initialize the member "modified". (undo_check_modified): added. (menu_undo, menu_redo): save the modified information. (get_graph_modified): return "Menulocal.modified". (set_graph_modified_gra, reset_modified_info): added. * src/gtk/x11graph.c (CmGraphShell, CmGraphSwitch, CmGraphPage): call "set_graph_modified_gra()" instead of "set_graph_modified()". * src/gtk/ox11menu.c (menuinit): initialize "Menulocal.modified". (mxmodified): set value to "Menulocal.modified". 2017-11-09 Hiroyuki Ito * src/math/math_parser.c (parse_primary_expression): the limitation of the length is not applied when the variable is start with the character '_'. 2017-10-27 Hiroyuki Ito * src/math/math_scanner.c (math_scanner_get_token): accepts '_' as the first character of a symbol. 2017-10-12 Hiroyuki Ito * src/gtk/x11print.c (CmOutputPrinter): fix memory leak. 2017-10-03 Hiroyuki Ito * src/gtk/ox11menu.c (create_layer): added. (init_layer): use "create_layer()". 2017-09-30 Hiroyuki Ito * src/gra.c (GRAtextextent, GRAdrawtext): use "g_strndup()" instead of "g_malloc()" and "strncpy()". (GRAtextextent): fix calculation of the bounding-box. 2017-09-28 Hiroyuki Ito * src/gtk/x11commn.c (get_save_opt): check source field of data objects. 2017-09-25 Hiroyuki Ito * src/gtk/ox11menu.c (MenuConfigToggleView): add "show_grid" configration. * src/gtk/x11menu.c (toggle_view): add case for MenuIdToggleGridLine. (ViewMenu): agg grid menu item. * src/gtk/x11view.c (draw_grid): added. 2017-09-22 Hiroyuki Ito * src/gtk/x11menu.c (UpdateAll2): add parameter. * src/gtk/x11lgnd.c (LegendWinUpdate): add first parameter. 2017-09-18 Hiroyuki Ito * src/gtk/x11menu.c (UpdateAll): don't redraw legends. 2017-09-12 Hiroyuki Ito * src/gtk/x11gui.c (DialogExecute): dont connect "key-press-event" signal (use CSS). 2017-09-11 Hiroyuki Ito * src/gtk/x11dialg.c (CopyDialog, SelectDialog): add "title" parameter. * src/gtk/x11commn.c (ProgressDialogCreate): use predefined function "gtk_true()". * src/gtk/x11gui.c (DialogExecute): remove redundant call of the function "gtk_window_set_title()". (DialogExecute): use predefined function "gtk_true()". 2017-09-07 Hiroyuki Ito * src/gtk/ox11menu.c (MenuConfigMisc): add custom palette support. (add_color_ary_to_array, menu_config_set_custom_palette) (init_custom_palette): added. (menu_save_config_sub, mgtkloadconfig, menulocal_finalize) (menuinit): add custom palette support. * src/gtk/gtk_widget.c (add_default_color, add_default_gray) (set_default_palette, show_color_dialog, set_custom_palette): added. (create_color_button, select_obj_color): add custom palette support. * src/gtk/x11opt.c (edit_custom_palette, save_custom_palette) (create_custom_palette_buttons): added. (MiscDialogSetup, MiscDialogClose, MiscDialogSetupItem): add custom palette support. 2017-09-06 Hiroyuki Ito * src/object.c (arraycmp, arraycpy): added. 2017-09-05 Hiroyuki Ito * src/gtk/x11view.c (ViewerEvLButtonUp): don't call "UpdateAll()". (check_last_insts, focus_new_insts): static function. (focus_new_insts): save created objects. * src/odata.c (f2dredraw): don't call "ignorestdio()" and "restorestdio()". * src/gtk/ox11menu.c (mx_redraw): call "ignorestdio()" and "restorestdio()". * src/odata.c (f2derror): use snprintf() instead of sprintf(). 2017-09-04 Hiroyuki Ito * src/gtk/x11view.c (CmEditMenuCB): call the function "set_focus_sensitivity()". * src/omerge.c (mergeredraw): draw a rectangle instead of a image. 2017-09-03 Hiroyuki Ito * src/gtk/x11axis.c (axis_save_undo): save undo information of the data object. * src/gtk/ox11menu.c (mx_redraw): use the function "GRArederaw()". * src/gra.c (_GRAredraw): now static function. * src/gtk/x11graph.c (CmGraphShell): call "set_graph_modified()". 2017-09-02 Hiroyuki Ito * src/object.c (arraydup): bug fix: array->data can be NULL. 2017-09-01 Hiroyuki Ito * src/odata.c (f2dredraw): call "ignorestdio()" and "restorestdio()". * src/gtk/x11lgnd.c (ObjListUpdate): set "NgraphApp.Viewer.allclear" as TRUE. * src/gtk/x11view.c (mouse_down_move_data, Evaluate): call "UpdateAll()". * src/gtk/x11commn.c (GetPageSettingsFromGRA): check alias name and duplications. * src/object.c (arrayuniq_all_str): added. 2017-08-30 Hiroyuki Ito * src/gtk/gtk_subwin.c (update_viewer): added. * src/gtk/x11view.c (create_pix): dont set "Menulocal.local->cairo". * src/gtk/x11menu.c (script_exec): call "UpdateAll()" instead of "UpdateAll2()". * src/gtk/x11lgnd.c (ObjListUpdate): call "ViewerWinUpdate()". * src/gtk/x11commn.c (LoadNgpFile): call "CmViewerDraw()". 2017-08-27 Hiroyuki Ito * src/gtk/x11view.c (create_layers): added. * src/gtk/ogra2cairo.c (set_cairo_antialias): added. * src/ogra.c (oGRAdrawparent, oGRAdraw): call "GRAlayer()". * src/gra.c (GRAlayer): added. 2017-08-26 Hiroyuki Ito * src/gtk/x11view.c (ViewerEvPaint): draw background and foreground images. (update_bg): added. (create_pix): create background image. (draw_paper_frame): removed. * src/gtk/x11opt.c (ViewerDialogClose): call "update_bg()" anf "UpdateAll2()" when background color is changed. * src/gtk/ox11menu.c (mx_clear): fill "empty" image. * src/odata.c (file_alpha): add "break" statement. 2017-08-18 Hiroyuki Ito * src/gtk/x11view.c (get_focused_obj_array): added. * src/gtk/x11file.c (data_save_undo): added. * src/gtk/x11axis.c (axis_save_undo): added. * src/gtk/x11menu.c (menu_redo, menu_undo, menu_clear_undo) (menu_delete_undo, menu_save_undo): save undo informations. (menu_save_undo_single): added. (set_undo_menu_label): added. (undo_info_pop, undo_info_push): added. (menu_undo_iteration): add second parameter. (menu_check_undo, menu_check_redo): check undo informations. * src/gtk/x11menu.h (MENU_UNDO_TYPE): added. 2017-08-12 Hiroyuki Ito * src/gtk/x11axis.c (axis_check_history): added. 2017-08-11 Hiroyuki Ito * src/gtk/x11lgnd.c (legend_menu_update_object): added. (CmLineUpdate, CmRectUpdate, CmArcUpdate, CmMarkUpdate) (CmTextUpdate): use "legend_menu_update_object()". (legend_menu_delete_object): added. (CmLineDel, CmRectDel, CmArcDel, CmMarkDel, CmTextDel): use "legend_menu_delete_object()". 2017-08-10 Hiroyuki Ito * src/object.c: add undo related functions. 2017-08-09 Hiroyuki Ito * src/odata.c (data_inst_dup, data_inst_free): added. * src/omerge.c (merge_inst_dup, merge_inst_free): added. * src/ofit.c (fit_inst_dup, fit_inst_free, create_math_equation): added. (fitput): use "create_math_equation()". 2017-08-08 Hiroyuki Ito * src/gtk/x11view.c (move_objects): added. (mouse_up_drag, ViewerEvKeyUp): use "move_objects()". 2017-07-25 Hiroyuki Ito * addin/gimg2gra.c (create_widgets): added. (main): use create_widgets(). (create_widgets): use gdk_pixbuf_new_from_file() and gtk_image_new_from_pixbuf() instead of gtk_image_new_from_file(). 2017-06-23 Hiroyuki Ito * src/gtk/init.c (exec_console): use "system" to execute xterm on macOS. * src/otext.c (textmatch): fix point coordinates calculation. 2017-06-08 Hiroyuki Ito * src/odata.c (getdata_skip_step): bug fix: use "rstep" instead of "hskip". 2017-06-07 Hiroyuki Ito * src/gtk/x11file.c (CmRangeAdd): default plot type is "line" when data source is "range". 2017-05-25 Hiroyuki Ito * src/gtk/x11menu.c (create_recent_menu): use RECENT_CHOOSER_LIMIT. * src/gtk/gtk_common.h (RECENT_CHOOSER_LIMIT): added. 2017-05-16 Hiroyuki Ito * src/gtk/ox11menu.h (paper_id): add PAPER_ID_NORMAL and PAPER_ID_WIDE. * src/gtk/x11graph.c (pagelist): add "normal display" and "wide display". 2017-04-12 Hiroyuki Ito * src/oiarray.c (iarray_sdev): check the value befor call sqrt. * src/odata.c (f2dstat_sub, set_const): check the value befor call sqrt. * src/odarray.c (darray_sdev): check the value befor call sqrt. 2017-03-31 Hiroyuki Ito * src/ofit.c (show_poly_equation): improve tne notation of an equation. 2017-03-30 Hiroyuki Ito * src/nstring.c (get_printf_format_str): check '^' flag. (str_to_pow): added. (add_printf_formated_str): support '^' flag. 2017-03-03 Hiroyuki Ito * src/gtk/gtk_action.c (create_application_window): set G_APPLICATION_NON_UNIQUE flag to GtkApplication. * src/gtk/x11gui.c (FileSelectionDialog): don't use global variable. 2017-03-02 Hiroyuki Ito * src/gtk/x11menu.c (setup_toolbar): added. (create_toplevel_window): call "setup_toolbar()" before realize the window. * src/gtk/x11commn.c (ProgressDialogCreate): don't destory existent widget. (ProgressDialogFinalize): don't destory widget. 2017-03-01 Hiroyuki Ito * src/odata.c (getdataarray, f2dcolumn_file): remove extraneous parentheses. * src/math/math_parser.c (my_get_token): remove duplicate 'const'. 2017-02-26 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar, create_menu_sub): use "gtk_image_new_from_resource()". * src/gtk/x11lgnd.c (LegendWinState): use "gtk_image_new_from_resource()". * src/gtk/gtk_widget.c (create_image_from_file): removed. * src/gtk/init.c (load_css): use "gtk_css_provider_load_from_resource()". * src/gtk/gtk_subwin.c (sub_window_create): use "gdk_pixbuf_new_from_resource()". * src/gtk/gtk_action.c (create_application_window): add GtkShortcutsWindow. (help_overlay_action): app menu is automatically generated by GtkApplication. * src/gtk/dir_defs.h: remove "PIXMAPDIR". * src/gtk/data/ngraph.resources.xml: add resource files as sources. 2017-02-24 Hiroyuki Ito * src/gtk/x11menu.c (MainMenu): show "Help" menu because appmenu can be hidden. * src/gtk/gtk_action.c (AppEntries): add "preference" action (for macOS). (create_application_window): divide appmenu resource file. 2017-02-22 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar): use "gtk_menu_tool_button_set_arrow_tooltip_text()". (SaveMenu, create_save_menu): added. (create_toolbar): use GtkMenuToolButton for save tool button. (create_save_menu): use GtkAction when "USE_GTK_BUILDER" is true. 2017-02-21 Hiroyuki Ito * src/gtk/x11file.c (FileWinState): use "tree_view_set_no_expand_column()". * src/gtk/x11lgnd.c (LegendWinState): use "tree_view_set_no_expand_column()". * src/gtk/gtk_liststore.c (tree_view_set_no_expand_column): added. 2017-02-17 Hiroyuki Ito * src/common.h (OSX): check OSX environment. 2017-02-16 Hiroyuki Ito * configure.ac: check OSX environment. * src/gtk/x11menu.c (ObjectMenu): add "Object" menu. 2017-02-13 Hiroyuki Ito * src/gtk/x11lgnd.c (create_color_combo_box): add "Stroke" and "Fill" menu items under the each submenu. 2017-02-10 Hiroyuki Ito * configure.ac: remove GTK+2 support. (GTK3_REQUIRED_VERSION): support GTK+ 3.4.0 or later. 2017-02-09 Hiroyuki Ito * src/gtk/x11menu.c (MainMenu): remove "Help" menu (integrated to the app menu). 2017-02-08 Hiroyuki Ito * src/gtk/x11lgnd.c (Mlist): change step for mark size. (Tlist): change step size for font size. * src/gtk/gtk_widget.c (create_spin_entry_type): change step size for font size. * src/gtk/init.c (n_initialize): don't use "g_mem_set_vtable()". * src/osystem.c (system_mem_profile): removed. * src/common.h (MARK_TYPE_NUM): removed. * src/gtk/gtk_subwin.c (do_popup): set "d->select" before call "gtk_menu_popup_at_pointer()". * src/odata.c (line_number, add_func_sub, add_basic_func): added. (add_file_func, add_fit_func): use "add_func_sub()". (ofile_create_math_equation): call "add_basic_func()". * src/ntime.c (mjd2gd): fix time calculation. 2017-02-05 Hiroyuki Ito * src/gtk/ox11dlg.c (get_toplevel_window): added. * addin/spellchecker.rb (NgraphSpellchecker): save and restore dialog position. 2017-02-02 Hiroyuki Ito * src/gtk/x11view.c (do_popup): call "gtk_widget_realize()" when the popup menu is not realized. 2017-02-01 Hiroyuki Ito * src/gtk/x11lgnd.c (LegendArrowDialogScale): added. (LegendArrowDialogScaleW, LegendArrowDialogScaleL): use "LegendArrowDialogScale()". 2017-02-01 Hiroyuki Ito * plugins/ruby/ngraph.c (wrap_load_script): added. (load_script): use "wrap_load_script()" with "rb_protect()" instead of "rb_load_protect()". * plugins/ruby.c (require_files): added. (ngraph_plugin_open_ruby): use "require_files()" with "rb_protect()". 2017-01-31 Hiroyuki Ito * src/gtk/gtk_combo.c (set_model): "gtk_cell_renderer_text_new()" shoud be called only when the variable "renderer" is true. * plugins/ruby.c (ngraph_plugin_open_ruby): use "rb_protect()" to avoid exception. 2017-01-27 Hiroyuki Ito * src/gtk/x11menu.c (set_focus_sensitivity_sub): the merge object can be deleted and duplicated. * addin/spellchecker.rb (NgraphSpellchecker#spell_check): use "buttons" and "response_button" fields of the Ngraph::Dialog object. * src/gtk/x11gui.c (add_buttons): added. (DialogButton, DialogCombo, DialogComboEntry, DialogSpinEntry) (DialogCheck): use "add_buttons()". * src/gtk/ox11dlg.c (dlg_get_buttons): added. (dlginput, dlgradio, dlgcombo, dlgspin, dlgcheck): use "dlg_get_buttons()". (dialog): add "buttons" and "response_button" fields. 2017-01-26 Hiroyuki Ito * plugins/ruby/ngraph.c (set_ngraph_obj_class_name): added. (get_ngraph_obj, add_obj_name_const): use "set_ngraph_obj_class_name()". 2017-01-25 Hiroyuki Ito * src/odata.c (f2dlocal_array_sub, f2dstat_array, f2dstat_range): removed. (f2dstat_sub): renamed from "f2dstat_file()". (f2dstat): always use "f2dstat_sub()". (opendata): "fp->mtime" is always 1 for the source type "DATA_SOURCE_ARRAY" and "DATA_SOURCE_RANGE". 2017-01-23 Hiroyuki Ito * src/math/math_parser.c (parse_primary_expression): now accepts two character variable. * src/shell.c (nsleep): use g_thread. * plugins/ruby/ngraph.c (nsleep): accepts real number (not only integer). * src/shellux.c (cmsleep): accepts real number (not only integer). 2017-01-01 Hiroyuki Ito * plugins/ruby/Makefile.am: use "$(MAKE)" and "$(AM_MAKEFLAGS)". * src/Makefile.am (ngraph_DEPENDENCIES): set dependency. 2016-12-30 Hiroyuki Ito * src/oio.c (io_open): check security. 2016-12-26 Hiroyuki Ito * src/gtk/gtk_widget.c (set_widget_font): use PangoFontDescription to make css string. 2016-12-23 Hiroyuki Ito * src/gtk/x11menu.c (create_icon): use image file for application icon (Windows). * src/gtk/gtk_subwin.c (sub_window_create): use image file instead of xpm data. * pixmap/Makefile.am (dist_pixmap_DATA): add application icons and 48 dot window icons. 2016-12-13 Hiroyuki Ito * mingw/windows64.sh: use mingw package for the installation. * src/gtk/init.c (set_dir_defs, set_path_env): add "BINDIR" to the windows "PATH" environment. 2016-11-29 Hiroyuki Ito * src/gtk/gtk_ruler.c (_Nruler): hold widget style and foreground color. * initfile/Ngraph.ini.win (font): add "Malgun Gothic". * debian/control (Build-Depends): depend on "libreadline-dev". 2016-11-28 Hiroyuki Ito * src/gtk/gtk_ruler.c (nruler_get_color): use cached color to avoid busy loop in the function "AppMainLoop()". * src/gtk/x11menu.c (check_pending_event): removed (redundant event check). 2016-11-25 Hiroyuki Ito * src/gtk/ogra2x11.c (gtk_evloop): use "check_pending_event()" instead of "gtk_events_pending()". 2016-11-01 Hiroyuki Ito * src/gtk/gtk_subwin.c (popup_menu_position): not used if the version of GTK+ is greater or equal to 3.22. * src/gtk/x11view.c (popup_menu_position): not used if the version of GTK+ is greater or equal to 3.22. 2016-10-26 Hiroyuki Ito * src/gtk/x11menu.c (defaultwindowconfig) (create_toplevel_window): use "gdk_monitor_get_geometry();" if the version of GTK+ is greater or equal to 3.22. * src/gtk/x11lgnd.c (LegendArrowDialogScaleL) (LegendArrowDialogScaleW): use "gdk_window_invalidate_rect()" if the version of GTK+ is greater or equal to 3.22. * src/gtk/x11view.c (do_popup): use "gtk_menu_popup_at_pointer()" if the version of GTK+ is greater or equal to 3.22. (mouse_down_zoom2): don't use "show_zoom_animation()" if the version of GTK+ is greater or equal to 3.22. * src/gtk/gtk_subwin.c (do_popup): use "gtk_menu_popup_at_pointer()" if the version of GTK+ is greater or equal to 3.22. 2016-09-07 Hiroyuki Ito * src/gtk/x11menu.c (check_pending_event): added. (AppMainLoop, reset_event, ChkInterrupt): use "check_pending_event()". 2016-08-01 Hiroyuki Ito * src/gtk/gtk_widget.c (create_text_view_with_line_number): call "gtk_widget_set_margin_end()". 2016-07-29 Hiroyuki Ito * addin/cal.nsc: use "ncal" instead of "cal". * src/gtk/gtk_widget.c (set_widget_font): us "*" as a selector. * initfile/ngraph.css: fix selector and style. 2016-07-28 Hiroyuki Ito * src/shell.c (ngraphenvironment): check returned value of the function "g_strdup_printf()". * src/oshell.c (cmdshell): functions "shellsavestdio()" and "shellrestorestdio()" must be called always. 2016-01-05 Hiroyuki Ito * debian/control (Build-Depends): depend on "libgsl-dev". 2016-01-01 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar): set label for radio tool buttons. (show_recent_dialog): check "Menulock" and "Globallock". * src/gtk/gtk_subwin.c (spin_button_size_allocated) (start_editing): don't change allocated size. * src/gtk/x11file.c (FileDialogClose): save range parameters. 2015-09-21 Hiroyuki Ito * src/math/math_expression.c: fix typo. * src/math/math_expression.h (MATH_EXPRESSION_TYPE_DOUBLE): fix typo. * src/math/math_equation.c (optimize_func_cb, check_const_sub): fix typo. 2015-08-19 Hiroyuki Ito * initfile/Ngraph.nsc: unset used variables. * src/gtk/x11gui.c (FileSelectionDialog): call "gtk_file_chooser_set_local_only()". * src/gtk/x11graph.c (DirectoryDialogSetup): call "gtk_file_chooser_set_local_only()". 2015-08-03 Hiroyuki Ito * src/gtk/gtk_action.c (ViewSidebarAction_activated) (ViewStatusbarAction_activated, ViewRulerAction_activated) (ViewScrollbarAction_activated) (ViewCommandToolbarAction_activated) (ViewToolboxAction_activated, ViewCrossGaugeAction_activated): check returned value of the function "toggle_view()". (ViewToggleSingleWindowModeAction_activated): check "Menulocal.single_window_mode". * src/gtk/x11menu.c (toggle_view, CmReloadWindowConfig) (CmToggleSingleWindowMode): check "Menulock" and "Globallock". (toggle_view): return success or false. 2015-07-30 Hiroyuki Ito * src/osystem.c (WEB): The repository is moved from SourceForge to GitHub. 2015-07-15 Hiroyuki Ito * src/shell.c (expand): remove "WILD_PERIOD" flag. * src/nconfig.c (replaceconfig, removeconfig): free "fil" when the variable "fptmp" is NULL. * src/gtk/init.c (load_css): this function is used only when the vertsion of the GTK+ is greater or equal to 3.16. * src/gtk/ox11menu.c (mx_show_lib_version): check "RL_VERSION_MAJOR" instead of "HAVE_READLINE_READLINE_H". 2015-07-14 Hiroyuki Ito * src/gtk/x11menu.c (create_cursor): use "gdk_cursor_new_for_display()" instead of "gdk_cursor_new()". * src/gtk/x11info.c (InfoWinSetFont): use "set_widget_font()". * src/gtk/x11file.c (HEADLINE_FONT_COLUMN): added. (create_preview_table): add font column. (update_table_visibility, set_headline_table_array) (set_headline_table): set font. (FileDialogSetup, ArrayDialogSetup): dont setup font. * src/gtk/x11cood.c (CoordWinSetFont): use "set_widget_font()". * src/gtk/ogra2x11.c (gtkwait_action): use "gdk_cursor_new_for_display()" instead of "gdk_cursor_new()". * src/gtk/init.c (load_css): added. (n_initialize): use "load_css()". * src/gtk/gtk_widget.c (set_widget_font): added. (text_view_with_line_number_set_font): use "set_widget_font()". * src/gtk/gtk_ruler.c (nruler_get_color): remove 3rd parameter. (nruler_draw_ticks): use "gtk_render_background()". 2015-07-06 Hiroyuki Ito * src/gtk/init.c (n_initialize): load css file. * initfile/ngraph.css: added. * initfile/Makefile.am (dist_ngraphui_DATA): add "ngraph.css" 2015-07-05 Hiroyuki Ito * src/gtk/gtk_widget.c (set_linumber_color): not used if the vertsion of the GTK+ is greater or equal to 3.16. * src/gtk/gtk_common.h (LINE_NUMBER_WIDGET_NAME): added. 2015-07-04 Hiroyuki Ito * src/math/math_expression.h: remove unnecessary definition of a variable "function_argument". * src/gtk/gtk_widget.c (set_button_icon): do nothing when the vertsion of the GTK+ is greater or equal to 3.12. (set_linumber_color): use "GTK_STATE_FLAG_*" instead of "GTK_STATE_*". 2015-07-01 Hiroyuki Ito * src/gtk/gtk_liststore.c (add_line_style_item_to_cbox): use "g_strcmp0()" instead of "strcmp()". 2015-06-03 Hiroyuki Ito * src/gtk/init.c (n_save_shell_history): "HistoryFile" is not declared when "HAVE_READLINE_READLINE_H" is false. 2015-05-09 Hiroyuki Ito * use "void *" instead of "GtkAction *". 2015-04-03 Hiroyuki Ito * src/shell.c (cmdexec): don't call "check_interrupt()" and "reset_interrupt()". 2015-03-13 Hiroyuki Ito * src/shell.h: the function "set_signal()"is not used in Windows. * src/oshell.c (cmdshell): signal is not used in Windows. 2015-03-06 Hiroyuki Ito * src/odata.c (set_data_progress): check not only "ninterrupt()" but "fp->interrupt". (file_calculate): "fp->interrupt" is true when "val->type" is "MATH_VALUE_INTERRUPT". (getdata_sub1): check "fp->interrupt". * src/math/math_expression.c (math_expression_calculate): retain "val->type" when the type is "MATH_VALUE_INTERRUPT". * src/math/math_basic_function.c (math_func_for) (math_func_while): return "MATH_VALUE_INTERRUPT" when interrupted. * src/math/math_equation.h (MATH_VALUE_INTERRUPT): added. * src/gtk/x11view.c (check_paint_lock): added. * src/gtk/x11menu.h (NgraphApp): remove member "Interrupt". * src/gtk/x11menu.c (kill_signal_handler): call "set_interrupt()". (AppMainLoop): don't reset interruption. (ChkInterrupt): call "check_interrupt()" when "DrawLock != DrawLockDraw". * src/gtk/x11commn.c (stop_btn_clicked): use "set_interrupt()". (ProgressDialogCreate): call "reset_interrupt()". * src/gtk/x11axis.c (pos_edited_common, axis_prm_edited_common): call "menu_lock(FALSE)". (pos_y_edited, pos_x_edited): don't call "menu_lock(FALSE)". 2015-03-04 Hiroyuki Ito * src/oshell.c (int_handler): added. (cmdshell): save, set and restore signal handler for the "SIGINT" signal. * src/shell.c (nsleep): use "reset_interrupt()" and "check_interrupt()". (set_signal): add 4th parameter. (set_interrupt, reset_interrupt, check_interrupt): added. (cmdexec): use "reset_interrupt()" and "check_interrupt()". 2015-02-28 Hiroyuki Ito * src/math/math_function.h.in: add function "while". * src/math/math_basic_function.c (math_func_while): added. (math_func_for): check interruption. 2015-01-22 Hiroyuki Ito * doc/html/ja/math.html (特殊関数): update document. * src/math/math_function.h.in: add function "mjd2unix". * src/math/math_basic_function.c (math_func_mjd2unix): added. 2014-12-24 Hiroyuki Ito * src/gtk/x11axis.c (scale_tab_create): change label fron "File" to "Data". 2014-12-17 Hiroyuki Ito * addin/fitrslt.c (savescript, create_format_frame) :add "shadow" check button. (frame_toggled): added. * addin/legend.c (savescript, create_option_frame): add "shadow" check button. (frame_toggled): added. 2014-12-13 Hiroyuki Ito * addin/fitrslt.nsc: use "get" command. * addin/fitrslt.c (set_parameter): check variable "i". (set_parameter): use "data" object. 2014-11-20 Hiroyuki Ito * src/gtk/gtk_widget.c (_create_spin_entry) (create_direction_entry): call "gtk_entry_set_max_width_chars()". 2014-11-13 Hiroyuki Ito * src/gtk/x11view.c (graph_dropped): don't call "LoadDialog()". * src/gtk/x11graph.c (LoadDialog): free "data->exdir" if necessary. (CmGraphLoad, CmGraphHistory): don't call "LoadDialog()". * src/gtk/x11dialg.c (initdialog): initialize "DlgLoad.exdir". * src/gtk/x11commn.c (LoadNgpFile): call "LoadDialog()". 2014-11-12 Hiroyuki Ito * src/oprm.c (addfontcontrol, remarkconv, prmload): support recent Ngraph objects. * src/gtk/x11view.c (graph_dropped): don't load PRM file. * src/gtk/x11menu.c (check_instance): call "set_axis_undo_button_sensitivity()". (application): don't load PRM file. * src/gtk/x11graph.c (PrmDialogSetup, PrmDialogClose, PrmDialog): removed. (CmGraphLoad): don't load PRM file. * src/gtk/x11dialg.c (initdialog): remove "PrmDialog". * src/gtk/x11commn.c (GraphSave): don't consider PRM file. (LoadPrmFile): removed. * src/gtk/ox11dlg.c (dlgconfirm, dlgmessage, dlginput) (dlgbutton, dlgradio, dlgcombo, dlgspin, dlgcheck): update title of the window. * addin/load_prm.nsc: added. 2014-10-26 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar): use gettext to show tooltips. 2014-10-05 Hiroyuki Ito * src/gtk/x11menu.c (set_widget_visibility): call "set_toggle_action_widget_state()" twice when "USE_GTK_BUILDER" is false. 2014-10-03 Hiroyuki Ito * src/gtk/x11menu.c (create_toplevel_window): call "set_widget_visibility()" only once. 2014-10-02 Hiroyuki Ito * debian/rules (override_dh_auto_configure): add "--with-versioned-symbol" option. * src/Makefile.am (libngraph_ldflags): use "vsymldflags". * configure.ac (vsymldflags): add "--with-versioned-symbol" option. 2014-09-27 Hiroyuki Ito * src/gtk/x11view.c (ViewerWinSetup): check "d->popup". * src/gtk/x11menu.c (setupwindow): check "NgraphApp.Viewer.popup". (create_menu_sub): don't call "gtk_application_add_accelerator()". (create_toplevel_window): don't call "gtk_window_set_has_resize_grip()". * src/gtk/x11file.c (RangeDialogSetup): change width of numeric entries. * src/gtk/gtk_action.c (create_application_window): create popup menu. 2014-09-05 Hiroyuki Ito * debian/libngraph0.install: added. * debian/libngraph0-dev.install: added (renamed from "ngraph-gtk-dev"). * src/gtk/gtk_action.c (DataAddRecentFileAction_activated) (GraphRecentAction_activated): added. * src/gtk/x11menu.c (create_recent_filter, show_recent_dialog): added. (create_recent_menu): use "create_recent_filter()". 2014-08-26 Hiroyuki Ito * src/gtk/x11menu.c (ActionWidget): add member "action". (ToolItem, MenuItem): add member "action_name". (add_addin_menu): added. (create_addin_menu): call "add_addin_menu()". (set_window_action_visibility): call "g_simple_action_set_enabled()". (clipboard_changed, unref_entry_history, get_subwindow_state): added. (save_entry_history): dont call "g_object_unref()". (toggle_view): added. (toggle_view_cb): use "toggle_view()". (set_toggle_action_widget_state): use "g_action_change_state()". (create_toolbar): call "gtk_actionable_set_action_name()". (create_menu_sub): initialize GActionMap. (create_toplevel_window): added. (application): use "create_toplevel_window()" and destroy "TopLevel" only when terminate signal is received. (script_exec, CmToggleSingleWindowMode): not static. (CmToggleSingleWindowMode): the variable "state" is given from the parameter "client_data" when the first parameter is NULL. * src/gtk/ox11menu.c (mx_get_accel_map): use GtkApplication if necessary. * src/gtk/x11view.c (ViewerWinClose): don't call "CloseGC()" and "CloseGRA()". (ViewerEvKeyDown): add case for "GDK_KEY_Return". * src/gtk/x11menu.h (NgraphApp): remove members "ghistory" and "fhistory", add member "recent_manager". * src/gtk/ox11menu.h (menulocal): remove member "ngpfilelist". * src/gtk/gtk_action.h: added. * src/gtk/gtk_action.c: added. * initfile/menus.ui: added. 2014-08-18 Hiroyuki Ito * src/odata.c (getdata_skip_step): always return 0 when data source is "DATA_SOURCE_ARRAY" or "DATA_SOURCE_RANGE". (get_data_from_source): return 2 when remarked line. (getdata_sub1): call "getdata_sub2()" only when "get_data_from_source()" returns 0. (getdata2, getdataraw): continue loop when "get_data_from_source()" returns non zero. 2014-08-07 Hiroyuki Ito * addin/fft.c (read_data): use "fgets()" and "sscanf()" instead of "fscanf()". 2014-07-31 Hiroyuki Ito * src/gtk/x11menu.c (PlotAddMenu): add "recent data" menu item. (recent_filter): static function. (create_recent_menu): not static function. * src/gtk/x11file.c (add_menu_list): add "recent data" menu item. (file_setup_item): check source type. (FileDialogSetupItem): remove third parameter. (FileDialogSetupCommon): check source type. (RangeDialogSetup): renamed from "FuncDialogSetup()". (ArrayDialogClose, FuncDialogClose): removed. (FileDialog): always "0FileDialogClose" is used. (FileDefDialog): initialize "source" member. (draw_type_pixbuf, start_editing_type): don't check the "source" field. (create_type_color_combo_box): remove fifth parameter. * src/shell.c (gettok): second argument "len" is always initialized. * src/oplot.c (ERR_INVALID_RANGE): added. (f2ddata): add members "range_min", "range_max" and "range_div". (opendata): initialize members "range_min", "range_max" and "range_div". (put_func): don't use the variable "is_fuinc". (f2dinit): initialize fields "range_min", "range_max" and "range_div". (hskipdata, getdata_skip_step, get_data_from_source): handle case for "PLOT_SOURCE_RANGE". (get_func_prm, get_func_value, funcout): removed. (f2dcolumn_range): added. (f2dopendata, f2dgetdata, f2dopendataraw): don't check the "source" field. (f2dstat_range): added. (f2dstat): use "f2dstat_range()". (f2dboundings_func, save_data_func): removed. (solve_equation, calc_fit_equation, get_fit_parameter): don't check the "source" field. 2014-07-30 Hiroyuki Ito * addin/fft.c (save_data): change numerical format of the output. * src/gtk/gtk_subwin.c (create_popup_menu_sub): add case for "POP_UP_MENU_ITEM_TYPE_RECENT_DATA". * src/gtk/x11commn.c (PlotFileArrayCB): removed. * src/odarray.c (darray_modified): added. (odarray): "darray_modified()" is called for the "@" field. * addin/fft.c (main, save_data, read_data): fix order of arguments. 2014-06-30 Hiroyuki Ito * src/oplot.c (f2ddraw): call "GRAview()". 2014-06-08 Hiroyuki Ito * src/oplot.c (open_array): check maximum value of the id. * src/gtk/x11commn.c (del_darray): added. (DeleteDrawable): call "del_darray()". (store_file, save_array, save_merge, save_plot): added. (SaveParent): use "save_plot()" and "save_merge()". 2014-06-05 Hiroyuki Ito * debian/rules (XDG_RUNTIME_DIR): set environment variable (https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=750043). 2014-06-02 Hiroyuki Ito * src/gtk/x11menu.h (obj_list_data): remove member "ev_button". * src/gtk/gtk_subwin.c (do_popup): "button" argument is always zero because this function is called from "button-release-event" or "key-press-event". 2014-05-27 Hiroyuki Ito * src/oplot.c (f2dstat_file): add parameter "field". 2014-05-24 Hiroyuki Ito * src/oplot.c (f2ddraw): add label "FinishDrawing" and use "goto" instead of "return 0". (f2dredraw): check "source" field. * src/gtk/x11file.c (copy_file_obj_field): ignore not only "file" but also "array" field. 2014-05-22 Hiroyuki Ito * src/gtk/x11axis.c (Popup_list): add "_Add" sub menu. * src/gtk/x11file.c (popup_show_cb): check "source" field. 2014-05-21 Hiroyuki Ito * src/gtk/x11merge.c (Popup_list): use "_Delete" instead of "_Close". * src/gtk/x11file.c (Popup_list): use "_Delete" instead of "_Close". * src/gtk/x11menu.c (create_recent_menu): call "g_signal_connect()". (create_toolbar): handle "TOOL_TYPE_RECENT_GRAPH" and "TOOL_TYPE_RECENT_GRAPH". (create_menu_sub): don't call "g_signal_connect()" for "GtkRecentChooserMenu". * src/gtk/x11merge.c (MergeWinState): use "tree_view_set_tooltip_column()". * src/gtk/x11lgnd.c (LegendWinState): use "tree_view_set_tooltip_column()". * src/gtk/x11file.c (FileWinState): use "tree_view_set_tooltip_column()". * src/gtk/x11axis.c (AxisWinState): use "tree_view_set_tooltip_column()". * src/gtk/gtk_liststore.c (tree_view_set_tooltip_column) (tree_view_set_tooltip_query_cb): added. 2014-05-14 Hiroyuki Ito * src/oplot.c (save_data_func): don't check returned value of the function "math_equation_calculate()". * addin/fitrslt.c (loaddatalist): get and check "source" and "array" fields. * addin/text-in.nsc: use "plot" object and check "source" field. * addin/legend.nsc: use "plot" object and save "source" and "array" fields. * addin/legend.c (loaddatalist): get and check "source" and "array" fields. (set_parameter): set 3rd column based on "source" field. * addin/fitrslt.nsc: use "plot" object and save "source" and "array" fields. * addin/fft.nsc: use "plot" object. * addin/append.nsc: use "plot" object. * addin/Makefile.am (addins, pkglibexec_PROGRAMS): remove "calc" addin. 2014-05-13 Hiroyuki Ito * src/oplot.c (file_fit_calc, file_fit_prm): use "plot" object. (add_file_prm): added. (opendata): check "src" and use "add_file_prm()". (f2dputmath): strip math string. (f2dinit): initialize "max", "min" and "div" field. (draw_fit): check "code->exp". (draw_fit): check "val.type" instead of the returned value of the function "math_equation_calculate()". (get_func_value): check "f2dlocal->codex[0]->exp" and "f2dlocal->codey[0]->exp". (funcout): initialize cnstant of the equation. (save_data_func): check "val.type", "f2dlocal->codex[0]->exp" and "f2dlocal->codey[0]->exp". (solve_equation): check "eq->exp". * src/ofit.c (fituser): check "var.type" instead of the returned value of the function "math_equation_calculate()". * src/math/math_equation.c (math_equation_calculate): check and initalize the parmetar "val". * src/gtk/x11file.c (add_menu_list): added. (move_tab_copy, mask_tab_copy): use "PlotFileArrayCB". (load_tab_setup_item): check "d->source". (load_tab_copy): use "PlotFileArrayCB". (load_tab_create, load_tab_set_value): check "d->source". (math_tab_copy): use "PlotFileArrayCB". (math_common_widgets_create): added. (math_tab_create): use "math_common_widgets_create()". (math_set_value_common): added. (math_tab_set_value): use "math_set_value_common()". (set_axis_combo_box, plot_axis_setup_item): added. (file_setup_item): use "plot_axis_setup_item()". (FileDialogSetupItem): check "d->source". (plot_tab_copy, file_settings_copy): use "PlotFileArrayCB". (FileDialogSetupCommon): use default width for the deta clumn entries. (CHECK_VISIBILITY_ARRAY): added. (set_headline_table_array): added. (update_table_visibility): check "d->source". (FileDialogSetup): change title of the dialog. (ArrayDialogSetup, FuncDialogSetupItem, FuncDialogSetup) (ArrayDialogClose, FuncDialogClose): added. (FileDialog): check "d->source". (CmFileHistory): use "data->dialog" instead of "&DlgFile". (CmFileNew): use "plot" object. (CmFileNew): use "data->dialog" instead of "&DlgFile". (CmFuncAdd): added. (CmFileOpen): use "plot" object. (update_file_obj_multi): use "data->dialog" instead of "&DlgFile". (CmFileUpdate): use "plot" object. (check_plot_obj_file): added. (CmFileEdit): use "plot" object, "PlotFileCB" and "check_plot_obj_file()". (CmOptionFileDef): use "plot" object. (get_plot_info_str): added. (file_list_set_val): use "get_plot_info_str()". (CmFileMath, GetDrawFiles, CmFileSaveData, select_type) (start_editing_type, FileWinState): use "plot" object. 2014-05-12 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar): add 3rd parameter. (check_instance): use "plot" object. (PlotAddMenu): added. * src/gtk/x11dialg.h (FileDialog): add members "min", "max, "div" and "sourece". * src/gtk/x11dialg.c: add "DlgFunc" and "DlgArray". * src/gtk/x11commn.c (AxisDel2, AxisMove, FitClear) (DeleteDrawable, SaveParent, get_save_opt, FileAutoScale) (SetFileHidden): use "plot" object. (field_obj_del, get_plot_cb_str, ArrayDel, PlotFileCB) (PlotFileArrayCB): added. (FileCB): use "get_plot_cb_str()". (FitDel): use "field_obj_del()". * src/gtk/x11view.c (ViewerWinFileUpdate, Evaluate) (mouse_down_move_data, data_dropped): use "plot" object. (ViewerWinSetup): call "gtk_menu_attach_to_widget()". * src/gtk/x11opt.c (CmOptionSaveNgp): use "plot" object. * src/gtk/gtk_subwin.c (create_popup_menu_sub): added. (sub_win_create_popup_menu): use "create_popup_menu_sub()". 2014-05-11 Hiroyuki Ito * src/shell.c (shprintfstdout, shprintfstderr): type of the first parameter is "const char *". * src/ogra.c (set_progress_val): type of the last parameter is "const char *". * src/object.c (vnprintf, seprintf): type of the first parameter is "const char *". (registerevloop): type of the first and second parameters are "const char *". * src/ngraph_api.c (ngraph_get_object_alias): added. * src/gtk/ox11menu.c (mgtkprintfstdout, mgtkprintfstderr): type of the first parameter is "const char *". * src/gtk/init.c (printfconsole): type of the first parameter is "const char *". * src/gra.c (_GRAopen, GRAopen, GRAaddlist, GRAinslist): type of some parameters are "const char *". * plugins/ruby/create_objs.rb (NgraphObj): now "alias" name can be used as an object. * src/gtk/x11axis.c (AxisDialogFile, file_button_show): use "plot" object. 2014-05-03 Hiroyuki Ito * src/oaxis.c (get_reference_parameter): keep original axis type when the typeboth axis are linear or MJD. 2014-05-01 Hiroyuki Ito * src/oaxis.c (calc_numbering_value, get_axis_math) (alloc_axis_math, free_axis_math, num_put_math): added. (numformat): use "calc_numbering_value()". (axisdraw, axis_get_numbering): use "alloc_axis_math()" and "free_axis_math()". (axis): add field "num_math". (axisdraw): don't call "get_axis_parameter()" twice when "aconf.code" is not NULL. * src/gtk/x11axis.c (Alist): add "num_math" column. (numbering_tab_set_value): save "num_math"field. (numbering_tab_setup_item): setup "num_math". (numbering_tab_create): add widget to set "num_math" field. (axis_list_set_val): set style depend on "num_math" field. (AxisWinState): min, max and inc column refer "num_math" column as the font style. * src/gtk/x11file.c (FileWinState): use "set_cell_attribute_source()". (set_source_attribute): removed. * src/gtk/gtk_subwin.c (set_cell_attribute_source): added. 2014-04-25 Hiroyuki Ito * addin/spellchecker.rb: add "About" button. 2014-04-23 Hiroyuki Ito * addin/spellchecker.rb: usr "Ruby/GTK3" if available. 2014-04-22 Hiroyuki Ito * initfile/20append_addins_ruby.nsc: added. * initfile/Makefile.am (init_scripts): install "20append_addins_ruby.nsc". * src/osystem.c (get_basename): renemed from "get_plugin_name()". (get_plugin_name): added. (load_plugin_sub): use "get_plugin_name()". (system_plugin_check): added. (nsystem): add field "plugin_check". * addin/Makefile.am (ruby_addins): added. * addin/legend.c (main): change order of buttons. * addin/fitrslt.c (main): change order of buttons. (my_create_spin_button): use "gtk_widget_set_margin_end()" when the version of GTK+ is greater or equal to 3.12. * addin/calc.c (main): change order of buttons. 2014-04-19 Hiroyuki Ito * addin/spell_check.rb: handle "LoadError". 2014-04-18 Hiroyuki Ito * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): don't use "Menulocal.browser" when ter version of GTK+ is greater or equal to "3.0.0". * src/gtk/x11gui.c (message_box): change order ob buttons in the case of "RESPONS_YESNOCANCEL". * debian/ruby-ngraph.install: install "usr/lib/*/ruby/*". 2014-04-16 Hiroyuki Ito * src/gtk/x11lgnd.c (Tlist): add "bgcolor" column. (text_list_set_val, LegendWinState): set background color of the text column. * src/gtk/gtk_common.h (USE_HEADER_BAR): added. 2014-04-15 Hiroyuki Ito * src/gtk/x11opt.c (MiscDialogSetup, ExViewerDialogSetup) (ViewerDialogSetup): use "GTK_RESPONSE_CANCEL" instead of "IDCANCEL". * src/gtk/x11gui.c (DialogExecute): use "gtk_dialog_new_with_buttons()" instead of "gtk_dialog_new()". (DialogInput, DialogRadio, DialogCombo, DialogComboEntry) (DialogSpinEntry, DialogCheck): add "GTK_DIALOG_USE_HEADER_BAR" flag. 2014-04-10 Hiroyuki Ito * src/gtk/x11menu.c (create_toolbar, create_menu_sub): use "create_image_from_file()". * src/gtk/x11lgnd.c (LegendWinState): use "create_image_from_file()". * src/gtk/gtk_widget.c (create_image_from_file): added. 2014-04-04 Hiroyuki Ito * src/gtk/x11file.c (MarkDialogSetup): use "gtk_widget_set_margin_start()" and "gtk_widget_set_margin_end()" when the version of GTK+ is greater or equal to 3.12. * src/gtk/gtk_widget.c (set_widget_margin): use "gtk_widget_set_margin_start()" and "gtk_widget_set_margin_end()" when the version of GTK+ is greater or equal to 3.12. * plugins/Makefile.am (RUBY_ARCH_INCLUDEDIR): added. 2014-04-03 Hiroyuki Ito * src/gtk/x11lgnd.c (LegendWinState): show "text::text" field as a tool-tip. * src/gtk/x11file.c (FileWinState, file_list_set_val): show "file::file" field as a tool-tip. * src/gtk/x11view.c (AlignFocusedObj): swap "VIEW_ALIGN_HCENTER" and "VIEW_ALIGN_VCENTER". (ViewerEvLButtonDblClk, ViewerEvKeyDown): use "set_pointer_mode()" instead of "gtk_radio_action_set_current_value()". * src/gtk/x11merge.c (MergeWinState): renamed from "CmMergeWindow". * src/gtk/x11menu.c (set_pointer_mode, init_action_widget_list) (set_action_widget_sensitivity, set_subwin_state) (set_toggle_action_widget_state, create_toolbar) (create_menu_sub, create_menu, create_popup, toggle_subwindow) (set_subwindow_state): added. (CmViewerButtonArm): moved from "x11view.c". (set_axis_undo_button_sensitivity): use "set_action_widget_sensitivity()". (create_addin_menu): don't use "gtk_ui_manager_get_widget()". (set_action_sensitivity): removed. (set_focus_sensitivity_sub, set_window_action_visibility): don't use "GtkAction". (multi_to_single, destroy_sub_windows): call "set_subwindow_state()" instead of "window_action_set_active()". (setupwindow): don't use "GTkUIManager". (init_ngraph_app_struct): initialize member valiables "action_widget_id" and "state_func". (create_sub_windows): use "set_subwindow_state()". (set_modified_state): use set_action_widget_sensitivity()". (toggle_view_cb): inhibit recursive call. (set_widget_visibility): use "set_toggle_action_widget_state()". (check_instance): use "set_action_widget_sensitivity()". (application): don't use "GTkUIManager" and "GtkAction". (CmReloadWindowConfig): use "set_subwindow_state()" instead of "window_action_set_active()". (CmToggleSingleWindowMode): use "gtk_check_menu_item_get_active()" instead of "gtk_toggle_tool_button_get_active()". * src/gtk/x11lgnd.c (LegendWinState): renamed from "CmLegendWindow". * src/gtk/x11info.c (InfoWinState): renamed from "CmInformationWindow". * src/gtk/x11file.c (FileWinState): renamed from "CmFileWindow". * src/gtk/x11cood.c (CoordWinState): renamed from "CmCoordinateWindow". * src/gtk/x11axis.c (AxisWinState): renamed from "CmAxisWindow". * src/gtk/ox11menu.c (mx_show_win, mx_hide_win, mx_toggle_win): call "set_subwindow_state()" instead of "window_action_set_active()". (mx_get_ui): removed. (gtkmenu): remove field "get_ui". * src/gtk/init.c (n_initialize): use "rl_completion_func_t *" instead of "CPPFunction *". * src/gtk/gtk_subwin.c (sub_window_hide, sub_window_show): set "visible" member variable and call "set_toggle_action_widget_state()". (cb_del, ev_sub_win_key_down): call "set_subwindow_state()" instead of "window_action_set_active()". 2014-04-02 Hiroyuki Ito * src/gtk/x11menu.c (create_ui_from_file, set_toolbar_caption) (set_btn_press_cb, get_toolbar, create_action_group) (create_action_widget, init_action_widget_list): removed. 2014-04-01 Hiroyuki Ito * src/gtk/x11menu.c (window_action_toggle) (window_action_set_active, set_toggle_action): removed. 2014-03-27 Hiroyuki Ito * src/gtk/x11menu.c (set_gdk_color): removed. 2014-03-01 Hiroyuki Ito * src/gtk/gtk_widget.h (NUM_ENTRY_WIDTH): change width from 11 to 12. * src/gtk/x11axis.c (font_tab_create): use "gtk_check_button_new_with_mnemonic()" instead of "gtk_check_button_new_with_label()". 2014-02-28 Hiroyuki Ito * src/gtk/x11view.c (EvalDialogSetup): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". (EvalDialogSetup): don't use "GtkStockItem". * src/gtk/x11opt_proto.h (CREATE_NAME): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". (CREATE_NAME): don't use "GtkStockItem". * src/gtk/x11opt.c (PrefScriptDialogSetup) (PrefDriverDialogSetup, PrefFontDialogSetup, MiscDialogSetup) (ExViewerDialogSetup, ViewerDialogSetup): don't use "GtkStockItem". (FontSettingDialogSetup): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". * src/gtk/x11merge.c (Popup_list): don't use "GtkStockItem". * src/gtk/x11menu.c (ActionEntry): don't use "GtkStockItem". (create_action_group): use "gtk_action_set_icon_name()"; * src/gtk/x11lgnd.c (Popup_list): don't use "GtkStockItem". (points_setup, legend_dialog_setup_sub): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". (LegendTextDialogSetup, LegendArrowDialogSetup) (LegendRectDialogSetup, LegendArcDialogSetup) (LegendMarkDialogSetup): don't use "GtkStockItem". * src/gtk/x11gui.c (DialogExecute, message_box, DialogInput) (DialogRadio, DialogCombo, DialogComboEntry, DialogSpinEntry) (DialogCheck, nGetOpenFileNameMulti, nGetSaveFileName): don't use "GtkStockItem". * src/gtk/x11graph.c (SwitchDialogSetup): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". * src/gtk/x11file.c (Popup_list): don't use "GtkStockItem." (MathDialogSetup, FitDialogSetup) (move_tab_create,mask_tab_create): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". (MathDialogSetup, FitSaveDialogSetup, FitDialogSetup): don't use "GtkStockItem". * src/gtk/x11dialg.c (SelectDialogSetup): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". * src/gtk/x11commn.c (ProgressDialogCreate): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_button_new_from_stock()". * src/gtk/x11axis.c (Popup_list): don't use "GtkStockItem". (scale_tab_create): use "gtk_button_new_with_mnemonic()" instead of "gtk_button_new_from_stock()". (font_tab_create): use "gtk_check_button_new_with_mnemonic()" and "set_button_icon()" instead of "gtk_check_button_new_with_label()" and "gtk_button_set_use_stock()". * src/gtk/gtk_widget.c (set_button_icon): added. (create_file_entry_with_cb, create_direction_entry): use "gtk_entry_set_icon_from_icon_name()" instead of "gtk_entry_set_icon_from_stock()". * src/gtk/gtk_subwin.h (subwin_popup_list): remove member "use_stock". * src/gtk/gtk_subwin.c (start_editing): use "gtk_entry_set_icon_from_icon_name()" instead of "gtk_entry_set_icon_from_stock()". (sub_win_create_popup_menu): use "gtk_menu_item_new_with_mnemonic()" instead of "gtk_image_menu_item_new_from_stock()". * initfile/NgraphUI.xml: remove preview tool button. * initfile/Ngraph.ini.in (browser): don't use "yelp". * addin/legend.c (main): don't use "GtkStockItem". * addin/fitrslt.c (main): don't use "GtkStockItem". * addin/calc.c (main): don't use "GtkStockItem". 2014-02-25 Hiroyuki Ito * src/gtk/x11menu.c (single_to_multi): set "Menulocal.single_window_mode" true before call "CmReloadWindowConfig()". * src/gtk/gtk_subwin.c (sub_window_set_visibility): check "Menulocal.single_window_mode". 2014-02-15 Hiroyuki Ito * plugins/Makefile.am (libruby_ldflags): don't link aginst libngraph. * configure.ac: use "AC_CHECK_LIB" to check libm. 2014-02-14 Hiroyuki Ito * src/gtk/x11file.c (file_list_set_val) (create_type_color_combo_box, select_type, select_axis): support sourece type. (set_source_attribute): added. 2014-02-13 Hiroyuki Ito * doc/html/ja/text.html: update document. * src/gtk/x11file.c (draw_type_pixbuf, file_list_set_val): support sourece type "function" and "array". * src/oplot.c (set_array): added. (open_array): return non zero when failed. (ERR_INVALID_OBJ): added. * src/gra.c (GRAdrawtext, GRAtextextent): add space between the lines setting. 2014-02-11 Hiroyuki Ito * src/oplot.h: added. * src/oplot.c: added. * src/gtk/x11view.c (ViewerEvLButtonUp): call "gtk_widget_queue_draw()". 2014-02-02 Hiroyuki Ito * src/odarray.c (calc_sum, calc_square_sum): removed. (cache_data): added. (darray_sum, darray_average, darray_rms, darray_sdev) (darray_min, darray_max): use "cache_data()". 2014-02-01 Hiroyuki Ito * src/object.c (obj_do_tighten_all): added. 2014-01-28 Hiroyuki Ito * addin/fft.c (save_data, read_data): added. (main): use "save_data()" and "read_data()". (MAXP): changed from 16 to 24. 2013-12-15 Ito Hiroyuki * addin/legend.c (create_geometry_frame): use "create_spin_button()". * addin/fitrslt.c (my_create_spin_button, create_position_frame): use "create_spin_button()". * addin/addin_common.c (create_spin_button): added. (create_font_frame): use "create_spin_button()". 2013-12-07 Ito Hiroyuki * plugins/ruby/ngraph.c (load_script): use File#expand_path to get full path name of the script. * plugins/ruby.c (ngraph_plugin_open_ruby): check returned value of th function "rb_require()". 2013-12-01 Hiroyuki Ito * plugins/ruby/lib/ngraph/ngp2.rb: added. 2013-11-29 Ito Hiroyuki * plugins/ruby/create_objs.rb: don't add '?' to some methods. * plugins/ruby.c (ngraph_plugin_exec_ruby): removed. * src/osystem.h: added. * src/osarray.c (sarrayerrorlist): bug fix: add ',' as the needed. * src/osystem.c (syserrorlist): bug fix: add ',' as the needed. (close_module, get_symbol, get_plugin_name, load_plugin_sub) (get_plugin_from_name, load_plugin, system_plugin_load) (free_argv, allocate_argv, system_plugin_exec) (system_plugin_get_module): added (moved from "oplugin.c"). (sysdone): unload modules. * src/oplugin.c: removed. * plugins/ruby/ngraph.c (load_script): added. (ruby_ngraph_init): the function "ngraph_set_exec_func()" is always called. 2013-11-28 Ito Hiroyuki * src/osystem.c (ext_shell_exec, system_check_prohibited_plugin) (system_set_ext_shell): added. (nsystem): add fields "ext_shell", "ext_shell_name" and "prohibited_plugin". (addsystem): initialize "ProhibitedPlugins". * src/oplugin.c (load_plugin): check prohibited plugins. * src/ngraph_api.c (ngraph_set_exec_func): added. * plugins/ruby/ngraph.c (ruby_ngraph_exec_loginshell): use "ALLOCA_N()" and "strcpy()" instead of "strdup()". (ruby_ngraph_init): add 3rd parameter and call "ngraph_set_ext_shell()" ic necessary. 2013-11-27 Ito Hiroyuki * plugins/ruby/ngraph.c (ruby_ngraph_init): set "Initialized". (Init_ngraph): check "Initialized". * src/ngraph_api.c (ngraph_exec_loginshell): return returned valu of the function "exeobj()" or "sexeobj()". * plugins/ruby/ngraph.c (ruby_ngraph_exec_loginshell) (ruby_ngraph_init_file): added. (Init_ngraph): add singleton methods "get_initialize_file" and "execute_loginshell". 2013-11-26 Ito Hiroyuki * plugins/ruby/ngraph.c (ruby_ngraph_init): added. (Init_ngraph): add singleton method "ngraph_initialize". * plugins/ruby/extconf.rb: check first argument. * plugins/ruby/Makefile.am (ruby_ext): use "RUBY_DLEXT." * debian/ruby-ngraph.install: added. * debian/control (Package): add ruby-ngraph package. * configure.ac: set "RUBY_DLEXT". * plugins/ruby/lib/ngraph.rb.win: added. * plugins/ruby/lib/ngraph.rb: added. * plugins/ruby/lib/Makefile.am: added. 2013-11-25 Ito Hiroyuki * plugins/ruby.c: many functions are moved to "plugins/ruby/ngraph.c". (get_ext_name): added. (ngraph_plugin_exec_ruby): use "get_ext_name()" on Windows. * plugins/ruby/ngraph.c: added. * plugins/ruby/getobj.nsc: moved from "plugins/". * plugins/ruby/extconf.rb: added. * plugins/ruby/create_objs.rb: moved from "plugins/". * plugins/ruby/Makefile.am: added. 2013-11-24 Hiroyuki Ito * src/ngraph_api.c (ngraph_save_shell_history): added. * src/gtk/init.c (n_save_shell_history): added. (n_finalize): use "n_save_shell_history()". (n_initialize): check already initialized or not. * plugins/ruby.c (ngraph_save_hist): added. (ngraph_plugin_open_ruby): add singleton method "save_shell_history". 2013-11-23 Ito Hiroyuki * Makefile.am (AM_CFLAGS): added. * src/shell.c (cmdexec, system_bg): use "g_thread_new()" instead of "g_thread_create()" when the version of glib is greater or equal to 2.32. 2013-11-22 Hiroyuki Ito * src/gtk/Makefile.am (libngraphui_la_LDFLAGS): removed. * src/math/Makefile.am (libmath_la_LDFLAGS): removed. 2013-11-21 Ito Hiroyuki * src/oplugin.c (ngraph_plugin_set_user_data) (ngraph_plugin_get_user_data): removed. * src/gtk/x11view.c (create_axis, ViewCopyAxis): use "g_strdup_printf()". * src/gtk/x11commn.c (axis_move_each_obj): use "g_strdup_printf()". * src/gtk/x11axis.c (SectionDialogGrid, CmAxisNewSection): use "g_strdup_printf()". * src/gtk/ox11menu.c (add_str_with_int_to_array) (add_child_geometry_to_array, add_geometry_to_array) (add_color_to_array): use "g_strdup_printf()". * src/gtk/init.c (my_sprintf): removed. (get_file_list): use "g_strdup_printf()". * plugins/ruby.c (str2inst_ensure, obj_del_from_str) (inst_get_obj, inst_put_obj): use "ngraph_free()". (obj_get): don't use "ngraph_object_free()". * src/main.c: added. * src/ngraph_api.c: added. * src/ntime.c (ndate, ntime): use "g_strdup_printf()". * src/oaxis.c (axisinit, axisdone, set_group, axis_default_set): use "g_strdup_printf()". * src/object.c (getvaluestr): add case for "NVOID", "NPOINTER" and "NVFUNC". * src/odraw.c: include "mathfn.h". * src/oplugin.c: api functions are moved to "ngraph_api.c". * src/oroot.c (obj_save_config_numeric, obj_save_config_string): use "g_strdup_printf()". * src/math/math_basic_function.c (math_func_fmod): remove unused variables. * debian/ngraph-gtk.install: install "libngraph". * mingw/windows.sh: now some processes are automatically done. * src/gtk/init.c: added (renamed from main.c). * src/gtk/init.h: added (renamed from main.h). * configure.ac: add "LIBNGRAPH_VERSION" and "AC_CANONICAL_HOST", check OS type. * acinclude.m4: remove macro. * Makefile.am (libtool): added. * test/: now "del system" is not necessary to end interpreter. 2013-11-20 Ito Hiroyuki * plugins/libruby.def: moved from "mingw/" * plugins/libruby_resource.rc: added * src/ngraph_resource.rc: moved from "mingw/windows_resource.rc". * src/libngraph_resource.rc: added. 2013-11-15 Ito Hiroyuki * mingw/windows.sh (DEFS): define "_USE_32BIT_TIME_T". * src/gtk/x11gui.c (fsok): use "GStatBuf" instead of "struct stat". * src/omerge.c (mergetime, mergedate): use "GStatBuf" instead of "struct stat". (mergestore, mergestoredum): use default date and time if the date and time are not available. * src/shellux.c (testexpand): use "GStatBuf" instead of "struct stat". * src/ofile.c (f2dtime, f2ddate, get_mtime): use "GStatBuf" instead of "struct stat". (f2dstat, f2dstat2): use "g_strdup_printf()" instead of "snprintf()". (f2dstore, f2dstoredum): use default date and time if the date and time are not available. * src/nconfig.c (openconfig, writecheckconfig, copyconfig): use "GStatBuf" instead of "struct stat". * src/ioutil.c (getfilename, findfilename): type of all parameters are "cost char *". (findfilename): use "GStatBuf" instead of "struct stat". (nstat): type of the second parameter is "GStatBuf *". * acinclude.m4: save "CFLAGS". 2013-11-11 Ito Hiroyuki * src/otext.c (text): add field "hsb". * src/orect.c (rect): add fields "fill_hsb" and "stroke_hsb". * src/opath.c (arrow): add fields "fill_hsb" and "stroke_hsb". * src/omark.c (mark): add fields "hsb" and "hsb2". * src/ofile.c (file2d): add fields "hsb" and "hsb2". * src/odraw.c (put_hsb_color, put_fill_hsb, put_stroke_hsb) (put_hsb, put_hsb2): added. * src/oaxis.c (put_gauge_hsb, put_num_hsb): added. (axis): add fields "gauge_hsb", "num_hsb" and "hsb". * src/oarc.c (arc): add fields "fill_hsb" and "stroke_hsb". * src/oagrid.c (agrid): add field "hsb". * src/math/math_basic_function.c (math_func_fmod): added. 2013-11-10 Ito Hiroyuki * src/gtk/x11axis.c (gauge_tab_create): use "gtk_entry_set_width_chars()". * src/gtk/gtk_widget.c (create_direction_entry) (create_text_entry, _create_spin_entry):use "gtk_entry_set_width_chars()". * src/gtk/x11lgnd.c (style_setup): use "combo_box_entry_set_width()". * src/gtk/x11file.c (FitSaveDialogSetup, plot_tab_create) (FileDialogSetupCommon): use "combo_box_entry_set_width()". * src/gtk/x11axis.c (scale_tab_create, position_tab_create): use "combo_box_entry_set_width()". * src/gtk/gtk_combo.c (combo_box_entry_set_width): added. 2013-11-06 Ito Hiroyuki * src/oplugin.c (ngraph_get_obj_field_type): type of the returned value is "enum ngraph_object_field_type". (ngraph_putobj): free allocated string when the returned value of the function "putobj()" is negative. * src/ngraph.h (ngraph_object_field_type): added. 2013-11-05 Ito Hiroyuki * src/gtk/ogra2x11.c (gtkclose): always returns "TRUE". 2013-11-02 Ito Hiroyuki * src/oplugin.c (get_plugin_name, get_plugin_from_name): added. (load_plugin, plugin_open): use "get_plugin_name()". (get_plugin, plugin_open): use "get_plugin_from_name()". 2013-11-01 Ito Hiroyuki * src/math/math_basic_function.c (math_func_dif): returned value is 0 if the type of saved value is not "MATH_VALUE_NORMAL". 2013-10-30 Hiroyuki Ito * plugins/ruby.c (ngraph_plugin_open_ruby): set default encodings and require some libraries. * plugins/create_objs.rb (NgraphObj#create_str_func_with_args) (NgraphObj#create_str_func_with_argv) (NgraphObj#add_str_array_func): use "tainted_utf8_str_new()". * plugins/ruby.c (tainted_utf8_str_new): added. (inst_get_str, inst_get_sarray, obj_func_obj, get_str_func_argv): use "tainted_utf8_str_new()". 2013-10-29 Hiroyuki Ito * configure.ac: use "AC_SEARCH_LIBS" instead of "AC_CHECK_LIB" to find math functions in "AC_CHECK_FUNCS". 2013-10-28 Hiroyuki Ito * configure.ac: check linker option. * acinclude.m4: added. 2013-10-27 Hiroyuki Ito * plugins/create_objs.rb (NgraphObj#create_str_func_with_argv): use "create_val_func_with_argv()". 2013-10-26 Ito Hiroyuki * src/oplugin.c (Plugin): remove field "_local" and add field "lock". * src/Makefile.am (ngraph_LDFLAGS): added. * src/ngraph_export.map: added. 2013-10-25 Ito Hiroyuki * src/gtk/ogra2emf.c (check_fonts): use "EnumFontFamiliesEx()" instead of "EnumFontFamiliesExW()" befcase the program is crashed when call "EnumFontFamiliesExW()" on Windows8 64bit. * mingw/windows.sh: create ruby plugin. * mingw/libruby.def: added. 2013-10-23 Ito Hiroyuki * src/Makefile.am (noinst_LTLIBRARIES): use convenience library. * plugins/ruby.c (ngraph_plugin_exec_ruby): check "argc". 2013-10-21 Ito Hiroyuki * mingw/windows_make.sed: change "$(pkglibdir)". * configure.ac: add "AC_LIBTOOL_WIN32_DLL". 2013-10-19 Hiroyuki Ito * plugins/ruby.c (ngraph_plugin_exec_ruby): check error string. 2013-10-19 Ito Hiroyuki * plugins/ruby.c (get_array_arg): added. (allocate_iarray, allocate_darray, allocate_sarray): use "get_array_arg()". 2013-10-16 Ito Hiroyuki * src/oplugin.c (load_plugin): check interrupt function. (plugin_done): call interrupt function when the plugin is locked. * plugins/ruby.c (obj_get_from_str, obj_del_from_str): use "rb_sprintf()". (ngraph_plugin_exec_ruby): show detail information aobut the error. (ngraph_plugin_interrupt_ruby): added. * src/gtk/ogra2x11.c (gra2gtk): argument of the "fullscreen" field is boolean. 2013-10-15 Ito Hiroyuki * src/ngraph_plugin.h: renamed to "ngraph.h". * src/ngraph.h: definitions are moved to "common.h". * plugins/ruby.c (obj_del_from_str): added. 2013-10-11 Ito Hiroyuki * src/oplugin.c (ngraph_plugin_copy): added. * plugins/ruby.c (ngraph_inst_method_copy, obj_copy): added. (ngraph_plugin_open_ruby): call "ruby_sysinit()" and "rb_enc_find_index()". 2013-10-10 Ito Hiroyuki * src/oplugin.c (allocate_iarray, allocate_darray) (allocate_sarray): check if the "arg" is NULL or not. (ngraph_plugin_get_instances_by_str, ngraph_plugin_sleep) (ngraph_plugin_get_obj_root): added. (ngraph_plugin_get_inst): removed. * test/sarray_test.nsc: add test for "put" and "ins" fields. * addin/timer.nsc: fix name of text object and field name of color of rectanble object. * addin/text-in.nsc: fix horizontal alignment. * addin/fig2gra.rb (Fig2Gra): added. * src/shellux.c (cmsleep): use "nsleep()". * src/shell.c (nsleep, cmsleeptimeout, SleepThread): added. * src/object.c (arrayadd, arrayins, arrayput): type of the second parameter is "const void *". (arrayadd2, arrayins2, arrayput2): type of the second parameter is "const char *". 2013-10-06 Ito Hiroyuki * src/oplugin.c (Plugin): type of the fields "open" and "exec" are NIFUNC. 2013-10-05 Ito Hiroyuki * src/osystem.c (nsystem): add field "plugin_dir". * src/oplugin.c (plugin_file, plugin_name): added. (plugin_open): check multiple loading. * src/gtk/ox11menu.c (menuinit): check "OpenApplication()" first. * src/gtk/main.c (set_dir_defs, main): initialize "PLUGINDIR" settings. * src/gtk/dir_defs.h.in: add "PLUGINDIR" definition. * plugins/ruby.c (ngraph_plugin_close_ruby): 0 (ngraph_plugin_open_ruby): added. (ngraph_plugin_exec_ruby): change name. * plugins/create_objs.rb (NgraphObj): add instants variable "singleton". * pathconv.sh (LIBDIR): add "LIBDIR" definition. 2013-10-04 Ito Hiroyuki * plugins/Makefile.am (ngraphplugindir): change install directory. * initfile/Ngraph.nsc: check "${NGRAPHCONF}/init.d". * initfile/10append_addins.nsc: mobed from "Ngraph.nsc". 2013-09-25 Hiroyuki Ito * src/gtk/ox11dlg.c: include "mathfn.h". 2013-09-24 Hiroyuki Ito * src/gtk/ox11menu.c (mx_show_lib_version): the first argument of the field means indent width. 2013-09-20 Hiroyuki Ito * plugins/Makefile.am: check develop environment of Ruby. * initfile/save_ui_file.nsc: use "get" commend to get informations. * initfile/Ngraph.nsc (NULL_DEVICE): use "get" commend to show version of the libraries. * configure.ac: call LT_INIT, check develop environment of Ruby. * src/plugins.c (plugin_shell_exec): check security. (ngraph_plugin_shell_err_puts, ngraph_plugin_shell_puts) (ngraph_plugin_shell_get_inst): added. * src/otext.c (test): type of argument of the field "save_config" is "void". * src/osystem.c (nsystem): type of argument of the field "temp_file" is "void". * src/ostring.c (ostring): type of argument of some fields are "void". * src/osarray.c (osarray): type of argument of some fields are "void". * src/oregexp.c (oregexp): type of argument of some fields are "void". * src/oprm.c (prm): type of argument of the field "load" is "void". * src/omerge.c (merge): type of argument of some fields are "void". * src/omath.c (math): type of argument of the field "clear" is "void". * src/oiarray.c (oiarray): type of argument of some fields are "void". * src/ofile.c (file2d): type of argument of some fields are "void". * src/odarray.c (odarray): type of argument of some fields are "void". * src/oaxis.c (draw_numbering, numbering): type of the last parameter is "struct narray *". (draw_numbering): use "g_strdup_printf()" when the parameter "array" is not NULL. (axis_get_numbering): type of field is "NSAFUNC". (axis): type of the argument of fields "scale_push", "scale_pop", "clear", "adjust", "tight", "group_manager" and "get_numbering" are "void". * src/oagrid.c (agrid): type of "tight" field is "void (void)". * src/gtk/x11menu.c (get_ui_definition): name is changed from "show_ui_definition()". * src/gtk/x11gui.c (DialogInput, DialogRadio, DialogCombo) (DialogComboEntry, DialogSpinEntry, DialogCheck): chang order of buttons. * src/gtk/ox11menu.c (mx_get_ui, mx_get_accel_map) (mx_show_lib_version, mx_get_locale): type of the fields is changed from "NVFUNC" to "NSFUNC". (mx_get_active): added. (gtkmenu): add "active" field, change type of some fields from "NVFUNC" to "NSFUNC". 2013-09-18 Hiroyuki Ito * src/gtk/ox11dlg.c (dlgspin): fix case for "double_entry". (dialog): type of "double_entry" and "integer_entry" is "NDFUNC" and "NIFUNC" respectively. 2013-09-16 Hiroyuki Ito * src/plugins.c (ngraph_plugin_shell_exeobj): check type of the field. * src/shellcm.c (dispfield): the macro "NLABEL" is not used. * src/object.c (addobject, _putobj, putobj, _getobj, getobj) (copyobj): the macro "NLABEL" is not used. * src/object.h: macro for field type and permission definitions are moved to the file "ngraph_plugin_shell.h". 2013-09-14 Hiroyuki Ito * plugins/: added. * src/shellcm.c (dispfield): fix representation of "char*" and "void*". 2013-08-28 Ito Hiroyuki * src/ofile.c (f2dstore, f2dstoredum): bug fix: use "g_strdup_printf()" instead of "g_malloc()" and "sprintf()". * src/omerge.c (mergestore, mergestoredum): bug fix: use "g_strdup_printf()" instead of "g_malloc()" and "sprintf()". 2013-07-26 Hiroyuki Ito * src/object.c (chkobjarglist): type of the returned value "const char *". (getargument, freeargument): type of second parameter is "const char *". 2013-07-25 Ito Hiroyuki * src/plugins.h: added (experimental). * src/plugins.c: added (experimental). * src/shell.c (get_security): added. (cmdtable): add "load_plugin" command. 2013-07-24 Ito Hiroyuki * src/gtk/x11merge.c (MergeDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11axis.c (GridDialogSetup, SectionDialogSetup) (CrossDialogSetup, ZoomDialogSetup, AxisDialogSetup): call "gtk_widget_show_all()". * src/gtk/gtk_widget.c (set_widget_visibility_with_label): added. (set_scroll_visibility): use "gtk_widget_set_visible()" instead of "gtk_widget_show()" and "gtk_widget_hide()". * src/gtk/x11print.c (DriverDialogSetup, OutputDataDialogSetup) (OutputImageDialogSetup): call "gtk_widget_show_all()". (OutputImageDialogSetupItem): hide unused widgets and reset window size. * src/gtk/x11lgnd.c (LegendArrowDialogSetup) (LegendRectDialogSetup, LegendArcDialogSetup) (LegendMarkDialogSetup, LegendTextDialogSetup) (LegendTextDefDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11menu.c (toggle_view_cb): use "gtk_widget_set_visible()" instead of "gtk_widget_show()" and "gtk_widget_hide()". (InputYN): use "get_current_window()". * src/gtk/x11graph.c (PageDialogSetup, SwitchDialogSetup) (DirectoryDialogSetup, LoadDialogSetup, PrmDialogSetup) (SaveDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11lgndx.c (LegendGaussDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11dialg.c (SelectDialogSetup, CopyDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11file.c (MathTextDialogSetup, MathDialogSetup) (FitLoadDialogSetup, FitSaveDialogSetup, FitDialogSetup) (MarkDialogSetup, FileDialogSetup, FileDefDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11view.c (EvalDialogSetup): call "gtk_widget_show_all()". * src/gtk/x11opt.c (DefaultDialogSetup, SetScriptDialogSetup) (PrefScriptDialogSetup, SetDriverDialogSetup) (PrefDriverDialogSetup, FontSettingDialogSetup) (PrefFontDialogSetup, MiscDialogSetup, ExViewerDialogSetup) (ViewerDialogSetup): call "gtk_widget_show_all()". (DefaultDialogSetup): use "gtk_widget_set_visible()" instead of "gtk_widget_set_sensitive()". * src/gtk/x11gui.c (DialogExecute): use "gtk_widget_show()" instead of "gtk_widget_show_all()". 2013-07-24 Koichi Akabe * misc/ngraph.desktop (Keywords): added. 2013-07-18 Ito Hiroyuki * src/gra.h (GRA_FILL_MODE): added. * src/gra.c (GRAdrawpoly): type of the 4th parameter is "enum GRA_FILL_MODE". 2013-07-17 Ito Hiroyuki * src/gtk/x11lgnd.c (LegendArrowDialogSetup): use "set_scale_mark()". (points_setup, LegendArrowDialogSetup, LegendRectDialogSetup) (LegendArcDialogSetup): use "set_widget_margin()". (create_color_combo_box, select_type): the field "line_join" can be modified from a combo-box. (create_mark_color_combo_box): call "add_line_style_item_to_cbox()". * src/gtk/x11lgndx.c (LegendGaussDialogSetup): use "set_scale_mark()". * src/gtk/gtk_widget.h (WIDGET_MARGIN): added. * src/gtk/gtk_widget.c (set_widget_margin, set_scale_mark): added. * src/gtk/gtk_subwin.c (spin_button_size_allocated): use variable "new_allocation". * src/gtk/x11file.c (move_tab_create, mask_tab_create) (load_tab_create, math_tab_create): use "set_widget_margin()". (create_type_color_combo_box, select_type): the field "line_join" can be modified from the combo-box. * src/gtk/x11axis.c (scale_tab_create, baseline_tab_create) (gauge_tab_create, numbering_tab_create, font_tab_create) (position_tab_create): use "set_widget_margin()". * src/gra.h (GRA_LINE_JOIN, GRA_LINE_CAP): added. * src/gra.c (GRAlinestyle): type of 5th and 6th parameters are "enum GRA_LINE_CAP" and "enum GRA_LINE_JOIN" respectively. 2013-07-13 Hiroyuki Ito * src/gtk/x11lgnd.c (create_character_view): don't set the number of columns when the version of GTK+ is greater or equal to "3.8.0". (create_character_view): call "gtk_icon_view_set_activate_on_single_click()" when the version of GTK+ is greater or equal to "3.8.0". 2013-07-12 Ito Hiroyuki * src/gtk/x11file.c (create_user_fit_frame): use "gtk_container_add()" instead of "gtk_scrolled_window_add_with_viewport()" when the version of GTK+ is greater or equal to "3.8.0". * src/gtk/ogra2x11.c (gtkinit): use "gtk_container_add()" instead of "gtk_scrolled_window_add_with_viewport()" when the version of GTK+ is greater or equal to "3.8.0". * src/gtk/gtk_subwin.c (label_sub_window_create): use "gtk_container_add()" instead of "gtk_scrolled_window_add_with_viewport()" when the version of GTK+ is greater or equal to "3.8.0". * src/gtk/gtk_ruler.c (nruler_get_color): use "TopLevel" to get the default color. 2013-07-05 Hiroyuki Ito * src/gtk/x11menu.c (application): check the state of "ViewToggleSingleWindowModeAction". * src/gtk/main.c (main): the "-i" option with no filename means to execute a console. * src/gtk/gtk_subwin.c (start_editing): the function "spin_button_size_allocated()" is connected to the "size-allocate" signal. (spin_button_size_allocated): added. 2013-06-27 Ito Hiroyuki * src/gtk/x11view.c (PasteObjectsFromClipboard): check "d->Win". (PasteObjectsFromClipboard, ShowCrossGauge, show_zoom_animation) (show_move_animation, mouse_move_scroll, ViewerEvMouseMove) (popup_menu_position, SetHRuler, SetVRuler, create_pix): use "gtk_widget_get_window()". (move_focus_frame, ViewerEvVScroll, ViewerEvHScroll) (ViewerWinUpdate, ChangeDPI, Draw): use "main_window_redraw()". 2013-06-26 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo_draw_path): check "local->cairo". * src/gtk/x11file.c (draw_type_pixbuf): use "gra2cairo_draw_path()". (CmFileSaveData): use "main_window_redraw()". * src/gtk/x11lgnd.c (draw_color_pixbuf): use "gra2cairo_draw_path()". * src/gtk/ogra2gtkprint.c (gra2gtkprint_done): use "gra2cairo_draw_path()". * src/gtk/ox11menu.c (main_window_redraw): added. (mx_redraw, mxdpi, mxclear): use "gra2cairo_draw_path()". (mxflush): use "gra2cairo_draw_path()". * src/gtk/ogra2x11.c (gtklocal): remove member "win". (redraw_window): added. (gtkclear, gtkflush, gtkredraw): use "redraw_window()". * src/gtk/x11menu.h (Viewer): remove member "gdk_win". * src/gtk/x11menu.c (NSetCursor): check "NgraphApp.Viewer.Win" and use "gtk_widget_get_window()". (script_exec): use "main_window_redraw()". * src/gtk/x11print.c (draw_gra): use "main_window_redraw()". 2013-06-05 Ito Hiroyuki * src/object.h (objlist): type of the member "root" and "root2" should be "N_VALUE *". 2013-06-05 Hiroyuki Ito * src/gtk/ogra2x11.c (gtkwait_action): renamed from "wait_key()". (action_type, button_released, scrolled): added. (gtklocal): use "struct action_type". (gtkinit): add event handler for signals "button-release-event" and "scroll-event". 2013-06-04 Ito Hiroyuki * src/gra.c (GRAcolor): don't change the color when an argument is negative. (GRAdrawtext, GRAtextextent): add "C" and "A" parameter. * src/gtk/ogra2x11.c (gtklocal): add member "blank_cursor". (cursor_moved): added. (gtkinit): initialize "gtklocal->blank_cursor". (gtkinit): the "motion-notify-event" signal is connected to the function "cursor_moved()". (gtkdone): unref "gtklocal->blank_cursor" if necessary. (gtk_wait_key): set mouse cursor invisible. * src/gtk/gtk_common.h (SE_ENTRY_ICON): removed. * configure.in (GTK2_REQUIRED_VERSION, GLIB_REQUIRED_VERSION): changed from "2.14.0" to "2.16.0". 2013-06-02 Hiroyuki Ito * src/ofile.c (f2dredraw): redraw when the variable "dmax" equal to zero. * src/gtk/ogra2x11.c (ev_key_down): save "e->keyval". (ev_key_down): use "gtkclose()" to close the window. (gtk_wait_key): added. (gra2gtk): add "wait_key" field. * src/gtk/x11menu.c (application): call "multi_to_single()" if necessary. * src/omerge.c (mergeredraw): redraw when the variable "dmax" equal to zero. 2013-05-31 Ito Hiroyuki * src/gtk/ox11dlg.c (dlgbutton): set "rval->str". 2013-05-29 Ito Hiroyuki * src/ogra.c (close_gc): added. (oGRAclose): use "close_gc()". (oGRAopen): call "close_gc()" when "GRAinit()" returns non-zero value. (oGRAopen): bug fix: initialize the variable "robj" and check before call the function "GRAopen()". * src/gtk/ogra2cairo.c (addgra2cairo): use "CAIRO_STATUS_LAST_STATUS" to generate error messages. * src/gtk/ox11dlg.c (dlgbutton): added. (dialog): add "button" field. * src/gtk/x11gui.c (DialogButton): added. * src/gtk/x11view.c (Draw, Clear): don't use "Menulocal.GRAinst". * src/gtk/ogra2x11.c (size_allocate, gtkfullscreen, gtk_set_fit) (gtk_set_frame): added. (gtkinit): initialize "fit" and "frame" fields. (gtkinit): the "GtkDrawingArea" is located center of the window. (gtkinit): the function "size_allocate()" is connected to the "size-allocate" signal. (gtkchangedpi): use function "cairo_surface_destroy()" instead of "g_object_unref()". (gtkMakeRuler): check "gtklocal->frame". (gtk_set_dpi): set "fit" field as FALSE. (gra2gtk): add fields "fit", "frame" and "fullscreen". * src/gtk/x11commn.c (OpenGRA): remove redundant call of the function "chkobjinstoid()". (OpenGRA, CheckPage, CloseGRA, ChangeGRA): don't use "Menulocal.GRAinst". (SetPageSettingsToGRA): bug fix: the last argument of the function "_putobj()" is not "&drawable" but "drawable". 2013-05-24 Ito Hiroyuki * doc/html/ja/math.html: update document. * src/math/math_basic_function.c (math_func_for): use variables "start", "stop" and "step". * src/gtk/x11file.c (set_headline_table_header): fix title of the table. 2013-05-20 Ito Hiroyuki * src/math/math_parser.c (create_variable_assign_expression): initialize the variable "bin". * src/math/math_scanner.c (math_scanner_get_token, get_ope): EOEQ is treated as an operator. * src/math/math_operator.h.in: add operators ":=", "==", ">=", "<=", "!=", "-=", "+=", "*=", "/=", "\=" and "^=". EOEQ is treated as an operator. * src/math/math_operator.rb: accept multiple representations for one operator. * src/osarray.c (ERROUTBOUND): added (sarrayerrorlist): add error message for the error "ERROUTBOUND". (sarrayget, sarrayput, sarraysns, sarraydel): show error message for the error "ERROUTBOUND". * src/odarray.c (ERROUTBOUND): added (darrayerrorlist): add error message for the error "ERROUTBOUND". (darrayget, darrayput, darraydns, darraydel): show error message for the error "ERROUTBOUND". * src/oiarray.c (ERROUTBOUND): added. (iarrayerrorlist): add error message for the error "ERROUTBOUND". (iarrayget, iarrayput, iarrayins, iarraydel): show error message for the error "ERROUTBOUND". 2013-05-16 Ito Hiroyuki * src/math/math_expression.c (optimize_div_expression): check if the right hand side of the operator is zero or not. (calc): compare with "0.0" (not "0"). * src/gtk/x11file.c (set_headline_table): remark character is located at the top of a line. 2013-05-09 Ito Hiroyuki * debian/patches/series: remove "01_replace_to_free_fonts.patch". * initfile/Ngraph.ini.in: use "Liberation" fonts as default. * src/gtk/x11view.c (ViewerEvKeyDown): initialize the variable "d" first. 2013-04-13 Ito Hiroyuki * src/ofile.c (get_value_from_str): accepts space character around the value. 2013-04-11 Ito Hiroyuki * src/gtk/x11file.c (check_add_str): use "〓" if the character is not printable. (set_headline_table): use "g_ascii_isprint()" and "g_ascii_isspace()". * src/ofile.c (get_value_from_str): added. (getdataarray): use 'get_value_from_str()'. 2013-04-06 Ito Hiroyuki * src/gtk/x11file.c (decode_ifs_text): accepts ascii character only. (check_add_str): added. (parse_data_line): use "check_add_str()". (set_headline_table): only ascii character can be accepted as mark. 2013-04-05 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvLButtonUp): call "set_focus_sensitivity()". 2013-04-04 Ito Hiroyuki * src/gtk/x11file.c (set_headline_table, create_preview_table) (update_table_visibility): don't use "GtkTreeModelFilter". (set_headline_table_header): check space of the cilumn header. 2013-04-03 Ito Hiroyuki * src/gtk/x11file.c (parse_data_line): remove 6th parameter. (create_preview_table): use "GtkTreeModelFilter". (update_table_visibility): added. * src/ofile.c (getdataarray): set terminator at the end of the column. 2013-03-31 Ito Hiroyuki * src/gtk/x11dialg.h (FileDialog): add member "head_linese." * src/gtk/x11file.c (set_headline_table_header, update_table) (update_table_header): added. (FileDialogSetup): use "set_headline_table_header()". 2013-03-29 Ito Hiroyuki * src/gtk/x11dialg.h (FileDialog): add members "comment_table" and "initialized". * src/gtk/x11file.c (decode_ifs_text, set_headline_table) (create_preview_table): added. (load_tab_set_value): use "decode_ifs_text()". (FileDialogSetupCommon): use "GtkGrid" when the version of GTK+ is greater or equal to "3.0.0". (FileDialogSetup): add table preview. (FileDialogClose, FileDialog): set "d->initialize" as FALSE. 2013-03-15 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvKeyDown): call "set_focus_sensitivity()" when the signal is propagated further. (add_focus_obj, clear_focus_obj): don't call "set_focus_sensitivity()". * src/gtk/gtk_subwin.c (start_editing): the function "UnFocus()" don't have to be called before "menu_lock()". (list_unfocused): removed. * src/gtk/x11menu.c (menu_lock): don't call "set_focus_insensitive()" and "set_focus_sensitivity()". (edit_menu_shown): added. (setupwindow): "edit_menu_shown()" is connected to the "show"signal of the popup menu and edit menu. 2013-03-12 Ito Hiroyuki * src/gtk/x11menu.c (menu_lock): call "set_focus_insensitive()" or "set_focus_sensitivity()". (set_focus_sensitivity_sub): set sensitivity of "EditPasteAction". * src/gtk/gtk_subwin.c (start_editing): call "UnFocus()" before call "menu_lock()". (list_unfocused): call "set_focus_sensitivity()" only when "Menulock" is false. 2013-03-11 Ito Hiroyuki * src/gtk/x11axis.c (type_edited): removed. (CmAxisWindow): the 5th argument of the function "set_combo_cell_renderer_cb()" is "NULL". * src/gtk/x11lgnd.c (select_type): call "gtk_widget_grab_focus()". (edited_line_type, edited_font): removed. (CmLegendWindow): the 5th argument of the function "set_combo_cell_renderer_cb()" is "NULL". * src/gtk/gtk_subwin.c (cancel_editing, enum_cb): call "gtk_widget_grab_focus()". (set_cell_renderer_cb): the 4th argument of the function "g_signal_connect()" for the "editing-canceled" signal is "d" when tha case is "G_TYPE_ENUM". (combo_edited_cb): added. (set_combo_cell_renderer_cb): use "combo_edited_cb()" as the default call-back for the signal "edited". (set_combo_cell_renderer_cb, set_obj_cell_renderer_cb): the 4th argument of the function "g_signal_connect()" for the "editing-canceled" signal is "d" * src/gtk/x11file.c (select_type, edited_axis): call "gtk_widget_grab_focus()". 2013-03-08 Ito Hiroyuki * src/gtk/x11file.c (MARK_PIX_LINE_WIDTH, set_line_style) (CURVE_POINTS_MAX, draw_curve): added. (draw_type_pixbuf): use "MARK_PIX_LINE_WIDTH", "set_line_style()", "CURVE_POINTS_MAX" and "draw_curve()". (draw_type_pixbuf): update image. (select_type): check if the graph is modified or not after call the function "chk_sputobjfield()". 2013-03-06 Ito Hiroyuki * src/gtk/x11file.c (select_type): add "break" statement for the case "FILE_COMBO_ITEM_LINESTYLE:". * src/gtk/x11commn.c (FitClear): fix indent. 2013-03-04 Ito Hiroyuki * src/gtk/x11file.c (select_type): add case for "FILE_COMBO_ITEM_CLIP". (create_type_color_combo_box): add "clip" combo-item. 2013-03-02 Ito Hiroyuki * src/gtk/gtk_widget.c (select_obj_color): change type of the return value. * src/gtk/x11lgnd.c (select_type): check returned value of the function "select_obj_color()" * src/gtk/x11axis.c (AxisCB): initialize the variable "s". (AxisHistoryCB): use "AxisCB()". * src/gtk/ox11menu.c (menuinit): fix initial value of "Menulocal.side_pane1_pos" and "Menulocal.side_pane2_pos". 2013-03-01 Ito Hiroyuki * src/gtk/x11axis.c (select_type): use "OBJECT_COLUMN_TYPE_ENUM". * src/gtk/x11file.c (select_type): use "OBJECT_COLUMN_TYPE_ENUM". * src/gtk/x11lgnd.c (select_type, select_line_type): use "OBJECT_COLUMN_TYPE_ENUM". * src/gtk/gtk_liststore.c (add_text_combo_item_to_cbox): use "TOGGLE_TYPE". add parameter "enum_id". (add_enum_combo_item_to_cbox, add_bool_combo_item_to_cbox) (add_line_style_item_to_cbox, add_font_style_combo_item_to_cbox): use "add_text_combo_item_to_cbox()". * src/gtk/gtk_liststore.h (TOGGLE_TYPE): added. (OBJECT_COLUMN_TYPE): add "OBJECT_COLUMN_TYPE_ENUM". 2013-02-28 Ito Hiroyuki * src/gtk/x11lgnd.c (points_setup): check the version of GTK+ to avoid the bug (Bug 691592). * src/gtk/gtk_liststore.c (create_column): check the version of GTK+ to avoid the bug (Bug 691592). 2013-02-26 Ito Hiroyuki * src/shellcm.c (cmget): check returned value via 3rd argument of the function "sgetobjfield()". * src/gtk/gtk_liststore.c (add_line_style_item_to_cbox): don't duplicate returned value via 3rd argument of the function "sgetobjfield()". * src/gtk/x11axis.c (Popup_list): remove "Show" item from the pop-up menu. (popup_show_cb): remove case for "POPUP_ITEM_HIDE". (AxisCB, AxisHistoryCB, GridDialogSetupItem) (scale_tab_setup_item, position_tab_setup_item) (axis_list_set_val): check returned value via 3rd argument of the function "sgetobjfield()". * src/gtk/x11merge.c (Popup_list): remove "Show" item from the pop-up menu. (popup_show_cb): remove case for "POPUP_ITEM_HIDE". * src/gtk/x11lgnd.c (Popup_list): remove "Show" item from the pop-up menu. (legend_dialog_setup_item, path_list_set_val): check returned value via 3rd argument of the function "sgetobjfield()". (popup_show_cb): remove case for "POPUP_ITEM_HIDE". * src/gtk/x11file.c (Flist): remove "Show" and "Fit" items from the pop-up menu. (FitCB, load_tab_setup_item, file_setup_item) (FileDialogSetupItem, get_axis_obj_str): check returned value via 3rd argument of the function "sgetobjfield()". (FileDialogSetupItem): remove 4th parameter. (show_fit_dialog): added. (FileDialogFit): use "show_fit_dialog()". (file_fit_popup_func): removed. (popup_show_cb): remove cases for "POPUP_ITEM_HIDE" and "POPUP_ITEM_FIT". (start_editing): don't show radio buttom on the combo-box. (add_fit_combo_item_to_cbox): added. (create_type_color_combo_box): use "add_fit_combo_item_to_cbox()". (select_type): show fitting dialog when the plot type fit is selected and the fit field of the file instance is not set. (select_type): add case for "FILE_COMBO_ITEM_FIT". * src/gtk/gtk_subwin.c (start_editing): check returned value via 3rd argument of the function "sgetobjfield()". 2013-02-24 Ito Hiroyuki * src/gtk/gtk_widget.c (combo_box_create_mark): removed. (select_obj_color): handle case for "OBJ_FIELD_COLOR_TYPE_AXIS_BASE", "OBJ_FIELD_COLOR_TYPE_AXIS_GAUGE" and "OBJ_FIELD_COLOR_TYPE_AXIS_NUM". * src/gtk/x11lgnd.c (text_list_set_val): set color of the text column. (create_mark_color_combo_box): use "add_text_combo_item_to_cbox()" and "add_mark_combo_item_to_cbox()". (create_fill_rule_combo_box): removed. (create_color_combo_box): use "add_bool_combo_item_to_cbox()", "add_line_style_item_to_cbox()", "add_text_combo_item_to_cbox()" and "add_enum_combo_item_to_cbox()". (select_type): dant handle the case "LEGEND_COMBO_ITEM_COLOR_0". (select_line_type): now the ComboBox use "GtkTreeStore". (start_editing_line_type): use "init_object_combo_box()". (select_font): added. (start_editing_font): use "init_object_combo_box()". (edited_font): only call "menu_lock()". (CmLegendWindow): set "foreground" column. * src/gtk/gtk_liststore.c (combo_box_separator_func) (init_object_combo_box, create_object_tree_model) (add_separator_combo_item_to_cbox, add_font_combo_item_to_cbox) (add_font_style_combo_item_to_cbox, add_text_combo_item_to_cbox) (add_mark_combo_item_to_cbox, add_enum_combo_item_to_cbox) (add_bool_combo_item_to_cbox, add_line_style_item_to_cbox): added. (create_object_cbox): use "create_object_tree_model()". (create_column): use "create_object_tree_model()" for the case "G_TYPE_PARAM". * src/gtk/x11dialg.c (SetFontListFromObj): type of the lase parameter is "const char *". * src/gtk/x11file.c (create_type_color_combo_box): use "create_type_combo_item()" and "add_text_combo_item_to_cbox()". (create_type_combo_item): use "add_text_combo_item_to_cbox()". (create_type_combo_item): added. (create_type_combo_box): removed. (select_axis): use "gtk_tree_model_get()" to get active item. (start_editing): use "init_object_combo_box()" and "add_text_combo_item_to_cbox()". * src/gtk/x11axis.c (AXIS_COMBO_ITEM, create_base_combo_item) (create_gauge_combo_item, create_num_combo_item) (create_type_combo_box, select_type, start_editing_type) (type_edited): added. (CmAxisWindow): call "set_combo_cell_renderer_cb()". 2013-02-21 Ito Hiroyuki * src/gtk/x11view.c (ViewerWinClose): assign NULL to freed member. * src/gtk/gtk_liststore.c (create_object_cbox): use "OBJECT_COLUMN_TYPE_NUM" for the function "gtk_tree_store_new()". (add_line_style_item_to_cbox): add 3rd, 5th, 6rh and 7th parameters. * src/gtk/gtk_liststore.h (OBJECT_COLUMN_TYPE): add "OBJECT_COLUMN_TYPE_TOGGLE_IS_RADIO" and "OBJECT_COLUMN_TYPE_NUM". * src/gtk/x11file.c (FileDialogType): set sensitivity of the widgets to set "line style" and "line width". (create_type_color_combo_box): add 4th parameter. (create_type_combo_box): add 3rd parameter. * src/gtk/gtk_widget.c (combo_box_create_mark): add 4th parameter. * src/gtk/x11lgnd.c (LEGEND_COMBO_ITEM): add "LEGEND_COMBO_ITEM_FILL_EVEN_ODD" and "LEGEND_COMBO_ITEM_FILL_WINDING". (create_mark_color_combo_box): add 3rd parameter. (create_fill_rule_combo_box): added. (create_color_combo_box): some menus are placed as a child menu. (set_bool_field, set_stroke, set_fill): added. (select_type): use "set_stroke()" and "set_fill()". set "fill_rule" field. 2013-02-20 Ito Hiroyuki * src/gtk/x11file.c (create_type_color_combo_box): use "add_line_style_item_to_cbox()". (select_type): add case for "FILE_COMBO_ITEM_LINESTYLE". * src/gtk/gtk_liststore.c (add_line_style_item_to_cbox): added. * src/gtk/x11lgnd.c (select_color, select_line_style): removed. (create_mark_color_combo_box, create_color_combo_box): use "add_line_style_item_to_cbox()". (select_type): handle all legend objects. (start_editing_color): use "select_type()" as a callback function. * addin/fitrslt.c (set_parameter): use "file::fit_prm". (ACCURACY): defined as 7 2013-02-19 Ito Hiroyuki * src/gtk/x11lgnd.c (add_line_style_item): added. (create_mark_color_combo_box, create_color_combo_box): use "add_line_style_item()". (select_line_style): added. (select_type, select_color): use "select_line_style()". * mingw/windows.sh: create "$PKG_DIR/lib". * mingw/gtkrc (msw-combobox-thickness): set "GtkComboBox::appears-as-list" as 0. 2013-02-18 Ito Hiroyuki * addin/ps2gra.nsc: use "get" command to obtain returned value of "dialog::yesno". * src/ofit.c (fitput, fitcalc): use "ofile_create_math_equation()". * src/ofile.c (file_fit_calc, file_fit_prm): don't use "math_equation_get_user_data()". (FitFunc, add_fit_func): added. (ofile_create_math_equation): add 7th parameter "use_fit_func". (ofile_create_math_equation): 2nd parameter represents the digit of prm. (ofile_calc_fit_equation): added. 2013-02-12 Ito Hiroyuki * src/ofit.c (fitlocal): add member "result_code". (fitinit): initialize "fitlocal->result_code". (fitdone): free "fitlocal->result_code". (set_equation, fitequation): added. (fitput, fitfit): use "set_equation()". (fitfit): check case "FitError_Interrupt". (fitcalc): use "fitlocal->result_code". (fitcalc): returned value is not string but double. * src/ofile.c (MATH_CONST_MASK): add "MATH_CONST_FILE_OBJ", "MATH_CONST_PATH_OBJ", MATH_CONST_RECT_OBJ, "MATH_CONST_ARC_OBJ", "MATH_CONST_MARK_OBJ" and "MATH_CONST_TEXT_OBJ". (FIT_FIELD_PREFIX, file_obj_color_alpha, file_objcolor) (file_objalpha): added. (file_color): now first argument of the "COLOR()" function accepts "8" and "9". (file_fit_calc, file_fit_prm): added. (file_func): add functions "FIT_CALC", "FIT_PRM", "OBJ_COLOR" and "OBJ_ALPHA". (ofile_create_math_equation): add constants "FILE_OBJ", "PATH_OBJ", "RECT_OBJ", "ARC_OBJ", "MARK_OBJ" and "TEXT_OBJ". (set_const): initialize constants "FILE_OBJ", "PATH_OBJ", "RECT_OBJ", "ARC_OBJ", "MARK_OBJ" and "TEXT_OBJ". (newton): don't check the number of the iteration is 1 or not ("i = 1"). (solve_equation): add prefix to the fields. (solve_equation): the error message is not set to the returned string. (calc_fit_equation): added. (calc_equation): use "calc_fit_equation()". (calc_equation): the error message is not set to the returned string. (get_fit_parameter): added. (file2d): add fields "fit_prm". change name of the fields "newton", "bisection" and "calc". * src/gtk/x11file.c (MathDialogSetup): initialize "d->Mode" whine "makewidget" is true (MathDialog): don't modify "data->Mode". * src/gtk/x11view.c (Draw): call "FitClear()" after call "FileAutoScale()". * src/object.c (addobject): object id is start from 1. 2013-01-24 Ito Hiroyuki * initfile/NgraphUI.xml.win: add "Sidebar" menu. * initfile/NgraphUI.xml: add "Sidebar" menu. * src/gtk/ox11menu.h (menulocal): add member "sidebar". * src/gtk/x11menu.h (MenuID): add id "MenuIdToggleSidebar". * src/gtk/x11menu.c (ActionEntry): add "ViewSidebarAction". (ActionEntry): change shortcut key of "cross bar" menu from "+" to "^g", (set_window_action_visibility): set visibility of "ViewSidebarAction". (multi_to_single): check "Menulocal.sidebar".0 (toggle_view_cb): handle "MenuIdToggleSidebar". (application): hide only "NgraphApp.Viewer.side_pane1". * src/gtk/ox11menu.c (MenuConfigToggleView): add sidebar setting. (menuinit): initialize "Menulocal.sidebar". 2013-01-23 Ito Hiroyuki * src/gtk/x11file.c (FileWinFit): use "list_store_get_selected_int()". (filewin_ev_key_down): check "GDK_CONTROL_MASK" for the case "GDK_KEY_f". 2013-01-22 Ito Hiroyuki * src/gtk/gtk_subwin.c (copy, delete, move_top, move_last) (move_up, move_down, hidden): call "UnFocus()". (list_focused, list_unfocused): added. (list_widget_create): use "focus-in-event" and "focus-in-event" to improve behavior of single window mode. * src/gtk/x11file.c (FitDialogSetup): add delete button to the dialog. (filewin_ev_key_down): call "UnFocus()". * src/gtk/x11view.c (ShowFocusFrame): don't call "set_focus_sensitivity()". (ViewerEvKeyDown): "DGK_KEY_Insert" is not handled. (Focus): don't call "gtk_widget_grab_focus()". (CmEditMenuCB): add case "MenuIdEditDuplicate". * src/gtk/x11axis.c (axiswin_delete_axis): call "UnFocus()". * src/gtk/x11menu.c (set_action_sensitivity) (set_focus_sensitivity_sub, set_focus_insensitive): added. (set_focus_sensitivity): use "set_focus_sensitivity_sub()". * initfile/NgraphUI.xml.win: add "EditDuplicate" item. * initfile/NgraphUI.xml: add "EditDuplicate" item. 2013-01-18 Ito Hiroyuki * src/gtk/gtk_subwin.c (swin_realized): type of the "user_data" is "struct obj_list_data *". (list_widget_create): "realize" signal is connected to the function "swin_realized()". (sub_window_create): don't call "g_signal_connect()" to the variable "swin". (tree_sub_window_create): remove redundant cast to "struct SubWin *". 2013-01-14 Ito Hiroyuki * src/gtk/gtk_liststore.c (create_column): don't use GtkCellRendererSpin while the GTK+ bug is not fixed. * src/gtk/x11lgnd.c (points_setup): don't use GtkCellRendererSpin while the GTK+ bug is not fixed. 2013-01-11 Ito Hiroyuki * src/gtk/x11view.c (ZOOM_SPEED_LITTLE, ZOOM_SPEED_NORMAL) (mouse_down_zoom_little, mouse_down_zoom2): added. (ViewerEvScroll): use "mouse_down_zoom_little()". * src/gtk/ogra2emf.c (enum_font_cb): check argument "FontType" and return with 0 if necessary. 2013-01-09 Ito Hiroyuki * src/gtk/x11view.c (PasteObjectsFromClipboard): check source device. 2013-01-08 Ito Hiroyuki * addin/legend.c (loaddatalist): check "hidden" field of data instances. 2013-01-07 Ito Hiroyuki * addin/legend.c (create_file_frame): not set hight of tree view but scrolled window. (create_file_frame): sensitivity of columns are depend on the state of the top column. (create_control): setting frames are expandable. * addin/fitrslt.c (create_spin_button): set margin of spin button widget. (create_control): setting frames are expandable. * addin/addin_common.c (create_font_frame): table widget is expandable * src/gtk/gtk_subwin.c (list_widget_create): sensitivity of columns are depend of the state of top column. * src/gtk/gtk_liststore.c (create_column): expand some editable columns. * src/gtk/x11lgnd.c (CmLegendWindow): don't expand some columns. 2013-01-04 Ito Hiroyuki * addin/fitrslt.c (get_opt): check "argv[i]". * addin/legend.c (get_opt): check "argv[i]". 2013-01-01 Ito Hiroyuki * addin/fitrslt.c (savescript, caption_toggled, set_parameter): use GtkTreeModel. (text_edited, caption_edited, value_edited): added. (create_caption_frame): use GtkTreeView widgret. (VERSION): 1.00.02 2012-12-28 Ito Hiroyuki * src/gtk/x11menu.c (application): call "CheckIniFile()" before save configurations. 2012-12-27 Ito Hiroyuki * src/gtk/ox11menu.c (mx_show_win, mx_hide_win, mx_toggle_win): check "Menulocal.single_window_mode". 2012-12-21 Ito Hiroyuki * src/gtk/gtk_subwin.c (tree_sub_window_create): call "gtk_notebook_popup_enable()". (tree_sub_window_create): set text label of the popup menu. 2012-12-20 Ito Hiroyuki * src/gtk/x11lgnd.c (CmLegendWindow): use icon file macros. (CmLegendWindow): add data for the key "ngraph_object_data" to widgets of inside of tabs. * src/gtk/x11menu.c (ActionEntry, window_to_tab, multi_to_single): use icon file macros. (window_to_tab): add parameter "tip". (tab_info_compare, init_tab_info, save_tab_position_sub) (save_tab_position): added. (multi_to_single): restore tab positions. (single_to_multi): call function "save_tab_position()". (single_to_multi): enable popup of tabs. (create_action_group): use icon file macros. (application): call function "save_tab_position()". * src/gtk/ox11menu.h (menulocal): add member related to tabs used in the single window mode. * src/gtk/ox11menu.c (MenuConfigOthers): add settings related to tabs used in the single window mode. (menuinit): initialize settings related to tabs used in the single window mode. * src/gtk/gtk_subwin.c (file_select, update): parent window is depend on the setting "Menulocal.single_window_mode". (swin_realized): added. (sub_window_create): connect "realize" signal to the function "swin_realized()". (sub_window_set_visibility): don't update content in this function. * src/gtk/x11file.c (FileWinFileUpdate, FileWinFit): parent window is depend on the setting "Menulocal.single_window_mode". * src/gtk/x11bitmp.h: add macros for icon files. * src/ioutil.h (DIRSEP_STR): added. 2012-12-18 Ito Hiroyuki * src/gtk/gtk_ruler.c (nruler_destroy): destroy or unref "ruler->backing_store". 2012-12-17 Ito Hiroyuki * src/gtk/x11view.c (popup_menu_position): use the function "gdk_window_get_origin()" to get the position. (ViewerWinSetup): the function "ev_popup_menu()" is connect to the signal "popup-menu". (ev_popup_menu): added. * src/gtk/gtk_subwin.c (popup_menu_position): use the function "gdk_window_get_origin()" to get the position. (do_popup): data for the positon function is "d->text". 2012-12-16 Ito Hiroyuki * src/gtk/x11file.c (init_dnd): destination of DnD is listsore widget. * src/gtk/x11merge.c (init_dnd): destination of DnD is listsore widget. * src/gtk/x11cood.c (CoordWinSetCoord): the variable "str" should be initialized as "NULL". (CoordWinSetCoord): don't check visibility of the widget "d->Win". (CoordWinSetCoord): show date and time in new line. * src/gtk/ox11menu.c (MenuConfigOthers): add pane and single window mode settings. (menuinit): initialize pane and single window mode settings. * src/gtk/x11opt.c (DefaultDialogSetup): set widget sensitivity depend on "Menulocal.single_window_mode". * src/gtk/gtk_subwin.c (sub_window_save_geometry): check "Menulocal.single_window_mode". (sub_window_create, text_sub_window_create) (label_sub_window_create, list_sub_window_create) (tree_sub_window_create): type of the second parameter is "const char *". * src/gtk/x11menu.c (SIDE_PANE_TAB_ID): added. (ActionEntry): add "ViewToggleSingleWindowModeAction". (menu_lock): check "NgraphApp.Viewer.menu", lock "NgraphApp.Viewer.menu" and the first child of the widget "NgraphApp.Viewer.main_pane". (set_window_action_visibility, OBJ_ID_KEY, window_to_tab) (tab_to_window, get_pane_position, set_pane_position) (multi_to_single, check_move_widget, check_move_legend_widget) (single_to_multi): added. (setupwindow): add paned widget for the single window mode. (create_sub_windows): check "Menulocal.single_window_mode". (set_toggle_action): added. (window_action_set_active): use the function "set_toggle_action()". (application): call "gtk_window_set_has_resize_grip()". (application): check "Menulocal.single_window_mode". (CmToggleSingleWindowMode): added. * initfile/NgraphUI.xml: add single window mode menu item. * initfile/NgraphUI.xml.win: add single window mode menu item. 2012-12-11 Ito Hiroyuki * src/gtk/x11menu.c (setupwindow): remove redundant call of the function "gtk_menu_bar_new()". 2012-12-04 Ito Hiroyuki * src/gtk/x11view.c (draw_paper_frame): the origin of the rectangle is 0 is the version of GTK+ is less than "2.22". * src/gtk/gtk_common.h (CAIRO_COORDINATE_OFFSET): always defined as "1". * src/gtk/gtk_ruler.c (_Nruler): add member "widget" and "parent". (nruler_new): change name from "ruler_new". (nruler_new): use "GtkFrame". (nruler_make_pixmap): add argument "parent". (nruler_draw_ticks): don't draw frame. * src/gtk/x11menu.c (setupwindow): use "nruler_new()". 2012-12-03 Ito Hiroyuki * src/gtk/gtk_ruler.c (nruler_get_preferred_width) (nruler_get_preferred_height, nruler_size_request, hruler_new) (vruler_new): removed. 2012-12-01 Ito Hiroyuki * src/gtk/gtk_ruler.c (nruler_set_style, nruler_parent_set): removed. (nruler_get_color): added. (nruler_draw_pos, nruler_draw_ticks): use "nruler_get_color()". * src/gtk/main.c (main): dan't call "gdk_threads_init()" and "gdk_threads_enter()". 2012-11-30 Ito Hiroyuki * src/gtk/gtk_ruler.c (nruler_set_style): added. (nruler_parent_set): connect the function "nruler_set_style" to the signal "changed". (nruler_draw_ticks, nruler_draw_pos): always use the color correspond to "GTK_STATE_NORMAL". * src/gtk/x11file.c (Flist): type of the "masked" column is now "G_TYPE_INT". (file_list_set_val): set style instead of color to distinguish masked or mobed data. (CmFileWindow): "masked" column is correspond to "style" property. 2012-11-29 Ito Hiroyuki * src/gtk/gtk_ruler.c (ruler_new): connect the function "nruler_parent_set()" to the signal "parent-set". (nruler_parent_set): added. * src/gtk/gtk_widget.c (create_text_view_with_line_number): call "gtk_text_buffer_new()". * src/gtk/gtk_subwin.c (text_sub_window_create): call "gtk_text_buffer_new()". 2012-11-10 Ito Hiroyuki * src/ofit.c (show_poly_equation, show_poly_result) (show_user_result, show_user_equation): added. (fitpoly): use "show_poly_equation()" and "show_poly_result()". (fituser): use "show_user_equation()" and "show_user_result()". 2012-11-06 Ito Hiroyuki * src/ofit.c (fitpoly, fituser): use "GString" to show fitting results. 2012-11-04 Ito Hiroyuki * src/ofit.c (fitpoly, fituser): use "GString" to show calclated equation. 2012-11-03 Ito Hiroyuki * src/gtk/x11bitmp.c (ICON_WIDTH, ICON_HEIGHT): removed. * src/gtk/x11commn.c (MESSAGE_BUF_SIZE): removed. * src/gtk/x11opt.c (BUF_SIZE): removed. * src/gtk/x11file.c (CB_BUF_SIZE): removed. * src/gtk/x11axis.c (CB_BUF_SIZE): removed. * src/gtk/x11lgnd.c (CmLegendWindow): use ""struct legend_data legend_data[]". (CB_BUF_SIZE): removed. 2012-11-02 Ito Hiroyuki * src/gtk/x11lgnd.c (CmLegendWindow): add tooltip to icons. 2012-10-31 Ito Hiroyuki * src/ofile.c (getdataarray): 'D' can be used as a prefix for a decimal exponent. Accept hexadecimal number. * src/otext.c (USE_UTF8): removed. (text_set_text): remove code for shift-jis. 2012-10-28 Ito Hiroyuki * src/gtk/gtk_subwin.c (get_cell_renderer_from_tree_view): added. (set_combo_cell_renderer_cb, set_obj_cell_renderer_cb) (set_editable_cell_renderer_cb): use "get_cell_renderer_from_tree_view()". * src/gtk/x11lgnd.c (select_line_type): remove redundant call of the function "g_object_get_data()". (select_text, start_editing_text): added. (CmLegendWindow): connect the function "start_editing_text()" to the signal "editing-started". 2012-10-20 Ito Hiroyuki * doc/html/ja/math.html: add explanation of the functions "eq", "neq", "ge", "gt", "le" and "lt". * test/math_test_new.dat: add tests for the functions "eq", "neq", "ge", "gt", "le" and "lt". * doc/html/ja/math.html: update explanation of the functions "eq", "neq", "ge", "gt", "le" and "lt". * src/math/math_function.rb: fix invarid expression for case statement. * src/math/math_function.h.in: increase number of arguments for the functions "ge", "gt", "le" and "lt". * src/math/math_basic_function.c (math_func_lt, math_func_le) (math_func_ge, math_func_gt): use "compare_double_with_prec()". (compare_double_with_prec): use "long double". * configure.in (AC_CHECK_FUNCS): check functions "log10l", "fabsl" and "floorl". 2012-10-19 Ito Hiroyuki * src/math/math_constant.c: include "config.h". * src/math/math_operator.rb: convert integer to string (for Ruby 1.9). * src/math/math_expression.c: include "config.h". * src/math/math_parser.c: include "config.h". * src/math/math_equation.c: include "config.h". * src/math/math_error.c: include "config.h". * src/math/math_scanner.c: include "config.h". * src/math/math_equation.c: include "config.h". * src/math/math_constant.rb: include "config.h". 2012-10-18 Ito Hiroyuki * test/math_test_new.dat: add tests for the functions "EQ()" and "NEQ()". * src/math/math_basic_function.c (compare_double_with_prec): fix calculation. 2012-10-17 Ito Hiroyuki * initfile/Ngraph.ini.win: change initial size of main-window. * initfile/Ngraph.ini.in: set initial size of sub-windows. 2012-10-16 Ito Hiroyuki * src/gtk/gtk_subwin.c (set_geometry): don't save state. (set_visibility, sub_window_save_visibility) (get_window_visibility): added. (sub_window_save_geometry): check return value of the function "get_window_visibility()". * src/gtk/x11gui.c (get_window_geometry): don't call "gdk_window_get_state()". * src/gtk/ox11menu.c (add_child_geometry_to_array): call "sub_window_save_visibility()". * src/gtk/x11menu.c (destroy_sub_windows): hide window before destroy. 2012-10-09 Ito Hiroyuki * src/gtk/x11graph.c (PageDialogSetup): left and top margin can be nagative. 2012-10-08 Ito Hiroyuki * src/gra.c (GRAinit, GRAreopen): "GRAClist[GC].width" and "GRAClist[GC].height" is as same as paper width. (GRAregion): remove unused parameters. (GRAregion): calculate width and height depend on "GRAClist[GC].topm" and "GRAClist[GC].leftm". 2012-09-21 Ito Hiroyuki * src/gtk/x11lgnd.c (start_editing_common, start_editing_font): call "menu_lock()" if the variable "sel" is negative. (start_editing_mark): the function "start_editing_common()" is failed if the return value is nagative. 2012-09-07 Ito Hiroyuki * src/gtk/x11graph.c (LoadDialogSetup): remove redundant call of the function "gtk_box_pack_start()". 2012-09-04 Ito Hiroyuki * src/gtk/x11opt.c (MiscDialogSetup): use "LoadPathStr". * src/gtk/x11commn.c (LoadNgpFile): use "LOAD_PATH_FULL" and "LOAD_PATH_BASE". * src/gtk/x11graph.h (LOAD_PATH_TYPE): added. * src/gtk/x11graph.c (LoadPathStr): added. (LoadDialogSetup): use "LoadPathStr". 2012-08-24 Ito Hiroyuki * src/gtk/x11view.c (graph_dropped): use "loadpath" instead of "ignorepath". * src/gtk/x11menu.c (application): use "loadpath" instead of "ignorepath". * src/gtk/x11commn.c (LoadNgpFile): use "loadpath" instead of "ignorepath" and "expandtofullpath". * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): use "loadpath" instead of "ignorepath". * src/gtk/x11graph.c (LoadDialogSetup, LoadDialogClose) (CmGraphLoad, CmGraphHistory): use "load_path" instead of "ignore_path". 2012-08-23 Ito Hiroyuki * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): add UI for "Menulocal.select_data". * src/gtk/x11view.c (Draw): call "FileWinUpdate()". * src/gtk/x11dialg.h (MiscDialog): add member "select_data". * src/gtk/ox11menu.h (menulocal): add member "select_data". * src/gtk/ox11menu.c (menuinit): initialize "Menulocal.select_data". * src/gtk/x11print.c (CmOutputPrinter, CmOutputDriver) (CmPrintGRAFile, CmOutputImage, CmOutputEMF): call "FileWinUpdate()". (CmOutputDriver, CmPrintGRAFile, CmOutputImage, CmOutputEMF): check "Menulocal.select_data". * src/gtk/x11commn.c (SetFileHidden): call "set_graph_modified()" if necessary. 2012-08-21 Ito Hiroyuki * src/gtk/x11gui.c (get_filename_with_ext): added. (FileSelectionDialog): use "get_filename_with_ext()". 2012-08-16 Ito Hiroyuki * src/gtk/x11cood.c (CmCoordinateWindow): don't call functions "sub_window_show_all()", "sub_window_set_geometry()". * src/gtk/x11file.c (CmFileWindow): don't call functions "sub_window_show_all()", "sub_window_set_geometry()" and "FileWinUpdate()". * src/gtk/x11axis.c (CmAxisWindow): don't call functions "sub_window_show_all()", "sub_window_set_geometry()" and "AxisWinUpdate()". * src/gtk/x11merge.c (CmMergeWindow): don't call functions "sub_window_show_all()", "sub_window_set_geometry()" and "MergeWinUpdate()". * src/gtk/x11lgnd.c (CmLegendWindow): don't call functions "sub_window_show_all()", "sub_window_set_geometry()" and "LegendWinUpdate()". * src/gtk/gtk_subwin.c (sub_window_show_all): static function. (sub_window_set_visibility): realize a window when the window is not realized. * src/gtk/x11menu.c (create_sub_windows): call "CmInformationWindow()", "CmCoordinateWindow()", "CmMergeWindow", "CmLegendWindow()", "CmAxisWindow()" and "CmFileWindow()". * src/gtk/x11info.c (create_win): removed. (InfoWinDrawInfoText, CmInformationWindow): don't use "create_win()". 2012-08-15 Ito Hiroyuki * src/gtk/x11file.c (FileWinFileEdit, FileWinFileDelete) (file_obj_copy, FileWinFileCopy2, FileWinFileUpdate) (FileWinFileDraw, FileWinFit, popup_show_cb): use "chkobjlastinst()". * src/gtk/x11axis.c (axiswin_scale_clear, popup_show_cb) (axis_prm_edited_common, axiswin_delete_axis, AxisWinAxisTop) (AxisWinAxisLast, AxisWinAxisUp, AxisWinAxisDown): use "chkobjlastinst()". * src/gtk/x11merge.c (popup_show_cb): use "chkobjlastinst()". * src/gtk/x11lgnd.c (rect_size_edited): use "chkobjlastinst()". * src/gtk/gtk_subwin.c (file_select, copy, delete, move_top) (move_last, move_up, move_down, update, focus, toggle_boolean) (modify_numeric, modify_string, hidden, set_hidden_state) (list_sub_window_set): use "chkobjlastinst()". * src/gtk/x11menu.h (obj_list_data): remove member "num". 2012-08-14 Ito Hiroyuki * src/terminal.c (sig_handler, my_signal): not used if the os is Windows. 2012-08-13 Ito Hiroyuki * src/gtk/ogra2emf.c (open_emf): call "SaveDC()". (close_emf): call "RestoreDC()". (select_font): "id_font.lfOutPrecision" is "OUT_TT_ONLY_PRECIS". * src/gtk/main.c (interruptconsole, reset_fifo, consolesave) (consolefd): not used if the os is Windows. 2012-08-12 Ito Hiroyuki * src/shell.c (set_shell_args): added. * src/oshell.c (cmdshell): use "set_shell_args()". * src/shellcm.c (cmset): use "set_shell_args()". (cmset): options "--" and "-" work as same as bash. 2012-08-11 Ito Hiroyuki * src/shellcm.c (cmset): "--" means the last argument. 2012-08-10 Ito Hiroyuki * src/gtk/ogra2cairo.c (CompatibleFont): "Mincho" should be corresponded to "Seril" and "Gothic" should be corresponded to "Sans-serif". 2012-08-09 Ito Hiroyuki * src/gtk/ogra2emf.c (gra2emf_local): add members "update_pen_attribute", "update_brush_attribute", "line", "null_pen", "the_pen" and "the_brush". (gra2emf_init): initialize "null_pen" and "line". (gra2emf_done): finalize "null_pen" and "line". (open_emf): initialize "update_pen_attribute", "update_brush_attribute", "null_pen", "the_pen" and "the_brush". (close_emf): finalize "update_pen_attribute", "update_brush_attribute", "null_pen", "the_pen" and "the_brush". (create_pen): create object only when "local->update_pen_attribute" is TRUE. (create_brush): added. (draw_polygon, draw_polyline, draw_lines): added. (gra2emf_output): use "draw_polygon()", "draw_polyline()" and "draw_lines()". * src/gtk/main.c (check_console): remove unused variable "menu". * src/shell.c (cmdexec): remove unused variable "r" (Windows only). * mingw/windows.sh (DEFS, CCOPT): add compile options. * src/gtk/x11menu.c (create_sub_windows): file window, axis window, legend window and merge window must be created in this function. (kill_signal_handler, term_signal_handler): not used when the OS is Windows. 2012-08-08 Ito Hiroyuki * src/gtk/ogra2emf.c (draw_text_rect, draw_rectangle): added. (draw_str_sub): don't call "SetBkMode()". (draw_str_sub): call "draw_text_rect()". (check_font_indices): check return value of the function "GetGlyphIndicesW()". (gra2emf_output): use "SelectClipPath()" instead of "SelectClipRgn()". (gra2emf_output): use "draw_rectangle()". (gra2emf_output): call "SetPolyFillMode()" before drawing path. * initfile/Ngraph.ini.win (font): use "batangche" instead of "gulimche" for "Serif" font. 2012-08-07 Ito Hiroyuki * driver/ngp2.in: remove EMF output. * src/gtk/ogra2emf.c (gra2emf_fontmap, enum_font_cb) (get_char_set, fontmap_append, check_fonts, free_fontmap_sub) (free_fontmap, add_fontmap, check_font_indices, draw_str_sub) (set_alternative_font): added. (gra2emf_init): create dumy hdc. (gra2emf_done): delete dumy hdc and fontmaps. 2012-08-06 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo_get_fontmap) (gra2cairo_remove_fontmap, gra2cairo_get_compatible_font_info): type of the argument is "const char *". 2012-07-29 Ito Hiroyuki * src/gtk/ogra2cairo.c (add_font_map): added. (create_font_map): use "add_font_map()". 2012-07-28 Ito Hiroyuki * src/gtk/ogra2emf.c (gra2emf_output): call "SetPolyFillMode()" to set fill mode. 2012-07-28 Ito Hiroyuki * initfile/NgraphUI.xml.win: add "GraphExportEMFFileAction" and "GraphExportEMFClipboardAction", remove "GraphExportEMFAction" and "GraphExportClipboardAction". * src/gtk/ogra2emf.c: added. * src/gtk/Makefile.am (libngraph_la_SOURCES): add "ogra2emf.c". * src/gtk/x11print.c (OutputImageDialogSetupItem) (OutputImageDialogSetup, OutputImageDialogClose, CmOutputImage): don't handle "MenuIdOutputEMFFile" and "MenuIdOutputEMFClipboard". (CmOutputEMF): added. * src/gtk/x11menu.h (MenuID): add "MenuIdOutputCairoEMFFile", "MenuIdOutputEMFFile" and "MenuIdOutputEMFClipboard", remove "MenuIdOutputClipboard". * src/gtk/x11menu.c (NgraphActionEntry): change name from "GraphExportEMFAction" to "GraphExportCairoEMFAction", add "GraphExportEMFFileAction" and "GraphExportEMFClipboardAction". * src/gtk/main.c (obj_add_func_ary): add function "addgra2emf". 2012-07-27 Ito Hiroyuki * src/gtk/ogra2cairofile.c (surface_type, open_emf, close_emf) (create_cairo): remove clipboard output. * src/gra.c (GRAreopen): width and height of the paper should be "GRAClist[GC].width+GRAClist[GC].leftm" and "GRAClist[GC].height+GRAClist[GC].topm" respectively. (GRAinit): width and height of the drawing region should be "width-leftm" and "height-topm" respectively. 2012-07-26 Ito Hiroyuki * src/gtk/ox11menu.c (mxflush): call "cairo_surface_flush()". * src/gtk/ogra2cairo.c (gra2cairo_flush): call "cairo_surface_flush()". (gra2cairo_output): fix typo ("tmp2" to "tmp"). 2012-07-23 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo_get_utf8_str): added. (gra2cairo_output): use "gra2cairo_get_utf8_str()". * src/gtk/ox11menu.c (menuinit): set default dpi of an EMF file as 576. 2012-07-18 Ito Hiroyuki * pathconv.sh (LC_ALL): set as "C" and export. * src/math/math_scanner.c (get_dec): use function "powl()" only if "HAVE_POWL" is defined. * src/gtk/ox11menu.c (graph_modified_sub): don't call "SetCaption()" and "set_modified_state()". (mxmodified): call "set_modified_state()". * configure.in (AC_CHECK_HEADERS): check "readline.h". 2012-07-10 Ito Hiroyuki * src/gtk/ogra2cairofile.c (open_emf): remove parameters "fname" and "clipboard". (close_emf): change second parameter from "clipboard" to "fname". (gra2cairofile_output): check return value of the function "close_emf()". 2012-07-09 Ito Hiroyuki * src/gtk/ox11menu.c (menuinit): set default dpi of an EMF file as 600. * src/gtk/ogra2cairofile.c (create_reference_dc): removed. (open_emf): use display device as referencs DC. use "SetWorldTransform()" to scale image. 2012-07-06 Ito Hiroyuki * src/gtk/x11lgnd.c (path_list_set_val): set columns "PATH_LIST_COL_X", "PATH_LIST_COL_Y" and "PATH_LIST_COL_POINTS" at once. * src/gtk/ogra2cairofile.c (open_emf, close_emf): added. (create_cairo): use "open_emf()". (gra2cairofile_output): use "close_emf()". 2012-07-05 Ito Hiroyuki * src/gtk/ogra2cairofile.h (surface_type_id): add "TYPE_CLIPBOARD". * src/gtk/ogra2cairofile.c (surface_type, create_cairo) (gra2cairofile_output): support clipboard. * src/gtk/x11menu.h (MenuID): add "MenuIdOutputClipboard". * src/gtk/x11menu.c (ActionEntry): add clipboard action. * src/gtk/x11print.c (OutputImageDialogSetupItem) (OutputImageDialogSetup, OutputImageDialogClose) (CmOutputImage, CmOutputMenu): support clipboard. * initfile/NgraphUI.xml.win: add clipboard menu. 2012-07-03 Ito Hiroyuki * src/gtk/x11lgnd.c (create_mark_color_combo_box) (create_color_combo_box): change order of items. * src/gtk/x11file.c (create_type_color_combo_box): change order of items. 012-07-02 Ito Hiroyuki * src/gtk/x11file.c (create_type_combo_box): use "combo_box_create_mark()". (create_type_combo_box): set visibility of toggle and pixbudf column. (select_type): use "select_obj_color()". (start_editing_type, start_editing): use "tree_view_get_selected_row_int_from_path()". (CmFileWindow): set "foreground" attribute column. * src/gtk/gtk_liststore.h (_list_store): the member "color" is removed. * src/gtk/gtk_liststore.c (create_object_cbox): add columns to show toggle item and set visibility of toggle and pixbuf column. (create_tree_view): don't create invisible column. (tree_view_get_selected_row_int_from_path): added. * src/gtk/gtk_widget.h (OBJ_FIELD_COLOR_TYPE): added. * src/gtk/gtk_widget.c (combo_box_create_mark, select_obj_color): added. * src/gtk/x11lgnd.c (get_points): get number of points. (draw_color_pixbuf): added. (path_list_set_val): support type of interpolation. (path_list_set_val): show number of points. (rect_list_set_val, arc_list_set_val): line type is shown as image. (draw_mark_pixbuf): added. (mark_list_set_val): use "draw_mark_pixbuf()". (rect_size_edited): use "tree_view_get_selected_row_int_from_path()". (LEGEND_COMBO_ITEM, create_mark_color_combo_box) (create_color_combo_box, select_type, select_color) (start_editing_common, start_editing_mark, start_editing_color) (select_line_type, start_editing_line_type, edited_line_type) (start_editing_font, edited_font): added. (CmLegendWindow): set callback functions to columns. 2012-07-01 Ito Hiroyuki * src/gtk/x11file.c (select_color): removed. * src/gtk/x11lgnd.c (mark_list_set_property) (legend_list_set_color): removed. 2012-07-01 Ito Hiroyuki * src/ofile.c (nstrrchr, get_filename_last_index): added. (f2dload_sub): use "get_filename_last_index()" instead of "getitok2()". 2012-06-24 Ito Hiroyuki * src/gtk/x11lgnd.c (get_points): only get first point. (path_list_set_property, text_list_set_property): removed. (path_list_set_val): support "PATH_LIST_COL_TYPE" and "PATH_LIST_COL_ARROW". (text_list_set_val): support "TEXT_LIST_COL_TEXT" and "TEXT_LIST_COL_FONT". * src/gtk/gtk_subwin.c (select_enum, start_editing_enum, enum_cb): added. (start_editing, set_cell_renderer_cb): support G_TYPE_ENUM. (set_combo_cell_renderer_cb): check and save "list[i].edited_id". * src/gtk/x11file.c (Flist): change type of the columns "ax" and "ay" from G_TYPE_ENUM to G_TYPE_PARAM. * src/gtk/gtk_liststore.c (create_column, create_tree_view): check "G_TYPE_PARAM". * src/gtk/x11axis.c (start_editing, select_type, edited): removed. (CmAxisWindow): don't call "set_combo_cell_renderer_cb()". * src/gtk/x11view.c (ViewerEvLButtonDown, ViewerEvLButtonUp) (ViewerEvMouseMove): treat "MOUSESCROLLE". * src/gtk/x11menu.h (MouseMode): add "MOUSESCROLLE". 2012-06-23 Ito Hiroyuki * src/gtk/gtk_subwin.c (sub_window_get_nth_content) (tree_get_selected, tree_copy, tree_delete, tree_move_top) (tree_move_last, tree_move_up, tree_move_down, tree_update) (tree_focus, tree_hidden, tree_set_hidden_state) (ev_key_down_tree): removed. (start_editing): accepts legend window. (toggle_cb): use "g_object_get_data()" and "toggle_boolean()". (set_cell_renderer_cb, set_editable_cell_renderer_cb) (set_combo_cell_renderer_cb, set_obj_cell_renderer_cb): change type of the firest parameter from "struct SubWin *" to "struct obj_list_data *". (cb_destroy): free data.data member of the "SubWin" struct. (copy, delete, move_top, move_last, move_up, move_down, update) (focus, modify_numeric, modify_string, hidden, set_hidden_state): change type of the firest parameter from "struct SubWin *" to "struct obj_list_data *". (toggle_boolean): added. (do_popup): change type of the second parameter from "struct SubWin *" to "struct obj_list_data *". (do_popup): accepts legend window. (sub_window_create): remove last parameter. (sub_window_create): don't create scrolled window. (text_sub_window_create, label_sub_window_create): create scrolled window. (list_widget_create): added. (list_sub_window_create, tree_sub_window_create): use "list_widget_create()". (list_sub_window_must_rebuild, list_sub_window_build) (list_sub_window_set, sub_win_create_popup_menu): change type of the second parameter from "struct SubWin *" to "struct obj_list_data *". * src/gtk/x11axis.c (AxisDialog): change type of the firest parameter from "void *" to "struct obj_list_data *" and remove second parameter. (AxisWinUpdate): add parameter "struct obj_list_data *". (AxisDelCB): added. (axis_list_set_val, pos_edited_common, axis_prm_edited_common) (axiswin_delete_axis): change type of the firest parameter from "struct SubWin *" to "struct obj_list_data *". (CmAxisWindow): use "AxisDelCB" instead of "AxisDel". * src/gtk/x11lgnd.c (Plist, Alist, Rlist, Mlist, Tlist): added. (Llist): removed. (LegendWinPathUpdate, LegendWinRectUpdate, LegendWinArcUpdate) (LegendWinMarkUpdate, LegendWinTextUpdate): added. (LegendWinLegendUpdate): removed. (ObjListUpdate, PathListUpdate, ArcListUpdate, RectListUpdate) (MarkListUpdate, TextListUpdate): added.0 (legend_list_set_color): change type of the firest parameter from "struct LegendWin *" to "struct obj_list_data *" and remove second parameter. (path_list_set_property, mark_list_set_property) (text_list_set_property, path_list_set_val, rect_list_set_val) (arc_list_set_val, mark_list_set_val, text_list_set_val): added. (legend_list_set_val): removed. (popup_show_cb): use "list_store_get_selected_int()" instead of "tree_store_get_selected_nth()". (pos_edited): get column number from the "title" member of "n_list_store". (pos_edited): use "gtk_tree_model_get_iter_from_string()" to get current row instead of "gtk_tree_path_new_from_string()". (rect_size_edited, rect_width_edited, rect_height_edited): added. (width_edited): removed. * src/gtk/x11file.c (FileDialog): change type of the firest parameter from "void *" to "struct obj_list_data *" and remove second parameter. (FileWinFileEdit, file_obj_copy, FileWinFileCopy) (FileWinFileUpdate, FileWinFileDraw, FileWinFit) (file_list_set_val): change type of the firest parameter from "struct SubWin *" to "struct obj_list_data *". (delete_file_obj, FileWinUpdate): add parameter "struct obj_list_data *". * src/gtk/x11menu.h (obj_list_data): added. (SubWin): use "struct obj_list_data *". (LegendWin): removed. * src/gtk/gtk_liststore.c (create_column): set "user-data" to "GtkCellRendererToggle" when the column is editable. * src/gtk/x11merge.c (merge_list_set_val): change type of the firest parameter from "struct SubWin *" to "struct obj_list_data *". (MergeDialog): change type of the firest parameter from "void *" to "struct obj_list_data *". (MergeWinUpdate): add parameter "struct obj_list_data *". * src/omark.c (marktype): moved to "oroot.c". * src/oroot.c (oputmarktype): moved and renamed from "omark.c". * src/ofile.c (file_marktype): use "MARK_TYPE_NUM". (file2d): check argument of the field "mark_type". 2012-06-20 Ito Hiroyuki * src/gtk/main.c (HAVE_READLINE_READLINE_H): used instead of "HAVE_LIBREADLINE". * src/gtk/ox11menu.c (HAVE_READLINE_READLINE_H): used instead of "HAVE_LIBREADLINE". * src/shell.c (getcmdline): use global valuable "Multiline" only when "HAVE_READLINE_READLINE_H" is defined. (HAVE_READLINE_READLINE_H): used instead of "HAVE_LIBREADLINE". * configure.in (READLINE_LIBS): defined when readline library is installed. (AC_CHECK_HEADERS): check "readline/readline.h" 2012-06-16 Ito Hiroyuki * src/gtk/x11opt.c (SetScriptDialogSetupItem): addin selection combobox is always available. * addin/fig2gra.rb: support Ruby 1.9. 2012-06-15 Ito Hiroyuki * src/gtk/x11axis.c (baseline_tab_create): don't call "gtk_widget_set_size_request()". * src/gtk/x11menu.c (setupwindow): call "gtk_toolbar_set_style()" when the version of GTK+ is greater or equal to 3.4.0. 2012-06-14 Ito Hiroyuki * addin/text-in.nsc: vertical offset of text can be changed. 2012-06-13 Ito Hiroyuki * driver/ngp2.in: accepts "-emf" option if EMF output is supported. * src/gtk/ox11dlg.c (dlginput): argument of the field is used as initial string of the text entry. * src/gtk/x11gui.c (DialogInput): add parameter "init_str". * addin/math.nsc: retry when error will be occurred. * src/gtk/ogra2cairo.c (gra2cairo_output): don't call "cairo_save()" on the 'I' command. 2012-06-12 Ito Hiroyuki * driver/ngp2.in (save_gra): copy field of "gra:viewer". * src/gtk/ox11menu.c (mx_clear): call "cairo_reset_clip()" before call "cairo_paint()". 2012-06-11 Ito Hiroyuki * zsh/Makefile.am (dist_zsh_DATA): use "dist_" prefix. * pixmap/Makefile.am (dist_pixmap_DATA): use "dist_" prefix. * initfile/Makefile.am (dist_ngraphconf_DATA): use "dist_" prefix. * doc/html/ja/tutorial/Makefile.am (dist_htmltutorial_DATA): use "dist_" prefix. * doc/html/ja/dialogs/Makefile.am (dist_htmldialog_DATA): use "dist_" prefix. * doc/html/img/Makefile.am (dist_htmlimg_DATA): use "dist_" prefix. * doc/html/Makefile.am (dist_html_DATA): use "dist_" prefix. * demo/Makefile.am (.ngp.in.ngp): use suffix rule. 2012-06-09 Ito Hiroyuki * src/gtk/x11view.c (show_move_animation, mouse_down_zoom) (ViewerEvMButtonDown): disable move animation. 2012-06-07 Ito Hiroyuki * addin/ps2gra.nsc (gra_file): check overwrite. 2012-06-06 Ito Hiroyuki * addin/ps2gra.nsc: add import pdf menu. * addin/fig2gra.rb: print creator comment. * addin/fig2gra.nsc (fig2gra): print creator comment. 2012-06-06 Koichi Akabe * demo/Makefile.am (CLEANFILES): add "demo6.ngp" 2012-06-05 Koichi Akabe * debian/ngraph-gtk.install: add scalable icons. * misc/ngraph.desktop (Icon): add scalable icons. * configure.in: add scalable icons. * icons/scalable/mimetypes/application-x-ngraph.svg: added. * icons/scalable/mimetypes/application-x-ngraph-script.svg: added. * icons/scalable/mimetypes/application-x-ngraph-graphic.svg: added. * icons/scalable/mimetypes/Makefile.am: added. * icons/scalable/apps/ngraph.svg: added. * icons/scalable/apps/Makefile.am: added. * icons/scalable/Makefile.am: added. 2012-06-03 Ito Hiroyuki * addin/fig2gra.nsc (fig2gra): accepts dummy option "-dummy". * addin/tex_equation.nsc: addin scripts are installed not in the directory "$NGRAPHLIB" but "${system::data_dir}/addin". * addin/ps2gra.nsc: addin scripts are installed not in the directory "$NGRAPHLIB" but "${system::data_dir}/addin". 2012-05-30 Ito Hiroyuki * src/gtk/x11print.c (CmOutputViewerB): set "width" and "height" fields of the "gra2dtk" object. * src/gtk/ox11menu.h (SAVE_CONFIG_TYPE_X11MENU): add "SAVE_CONFIG_TYPE_EXTERNAL_VIEWER". * src/gtk/ox11menu.c (exwinloadconfig): removed. (MenuConfigExiView): added. (MenuConfigArrray): add "MenuConfigExiView". (menu_save_config): check "SAVE_CONFIG_TYPE_EXTERNAL_VIEWER". (menuinit): initialize "Menulocal.exwindpi", "Menulocal.exwinwidth" and "Menulocal.exwinheight". * src/gtk/x11lgnd.c (format_value_percent, format_value_degree): added. (LegendArrowDialogSetup): connect "format_value_degree" and "format_value_percent" to the "format-value" signal. * src/gtk/ogra2x11.c (gtkloadconfig): removed. (gra2gtk): add fields "width" and "height". (gtkinit): use "gtk_window_set_default_size()" instead of "gtk_widget_set_size_request()". (gtk_set_size): added. * src/gtk/x11opt.c (add_str_with_int_to_array) (save_ext_viewer_config): removed. (ViewerDialogSetup): change layout. 2012-05-26 Ito Hiroyuki * addin/fitrslt.c: don't use deprecated functions. * addin/addin_common.c: don't use deprecated functions. * addin/calc.c (create_control): don't use deprecated functions. * addin/legend.c: don't use deprecated functions. * src/gtk/gtk_subwin.c (label_sub_window_create): use "gtk_widget_set_halign()" and "gtk_widget_set_valign()" instead of "gtk_misc_set_alignment()". * src/gtk/x11lgndx.c (LegendGaussDialogSetup): don't use deprecated functions. * src/gtk/ogra2x11.c (gtkinit): don't use deprecated functions. * src/gtk/x11axis.c (GridDialogSetup, SectionDialogSetup) (CrossDialogSetup, ZoomDialogSetup, scale_tab_create) (baseline_tab_create, gauge_tab_create, numbering_tab_create) (font_tab_create, position_tab_create): don't use deprecated functions. * src/gtk/gtk_widget.c (add_widget_to_table_sub) (add_copy_button_to_box, item_setup) (create_text_view_with_line_number): don't use deprecated functions. * src/gtk/x11print.c (DriverDialogSetup, OutputDataDialogSetup): don't use deprecated functions. * src/gtk/x11lgnd.c (points_setup): call "gtk_tree_view_column_set_expand()". (points_setup, LegendArrowDialogSetup, LegendRectDialogSetup) (LegendArcDialogSetup, LegendMarkDialogSetup) (legend_dialog_setup_sub, LegendTextDialogSetup) (LegendTextDefDialogSetup): don't use deprecated functions. * src/gtk/x11dialg.c (SelectDialogSetup): don't use deprecated functions. * src/gtk/x11file.c (MathTextDialogSetup, MathDialogSetup) (FitSaveDialogSetup, create_user_fit_frame, FitDialogSetup) (move_tab_create, mask_tab_create, load_tab_create) (math_tab_create, button_set_mark_image, MarkDialogSetup) (plot_tab_create, FileDialogSetupCommon, FileDialogSetup): don't use deprecated functions. (set_fitdialog_sensitivity): set sensitivity of initial value input for user function. (FitDialogSetSensitivity): call "check_fit_func()". * src/gtk/x11view.c (EvalDialogSetup): don't use deprecated functions. * src/gtk/x11commn.c (ProgressDialogCreate): don't use deprecated functions. * src/gtk/x11menu.c (create_message_box, setupwindow): don't use deprecated functions. * src/gtk/x11opt.c (SetScriptDialogSetup, SetDriverDialogSetup) (FontSettingDialogSetup, PrefFontDialogSetup, MiscDialogSetup) (ExViewerDialogSetup, ViewerDialogSetup): don't use deprecated functions. * src/gtk/x11graph.c (PageDialogSetup, SwitchDialogSetup) (DirectoryDialogSetup, LoadDialogSetup, PrmDialogSetup) (SaveDialogSetup): don't use deprecated functions. * src/gtk/x11merge.c (MergeDialogSetup): don't use deprecated functions. 2012-05-23 Ito Hiroyuki * src/shell.c (set_shellevloop, nreadline): use "g_thread_new()" instead of "g_thread_create()" when the version of glib is greater or equal to 2.32. * src/gtk/main.c (main): don't use duplicate function "g_thread_init()" if the version of glib is greater or equal to 2.32. * src/gtk/x11view.c (draw_cairo_arc): check if radius is not less than 1. (ViewerEvScroll): check "e->state" when "e->direction" is "GDK_SCROLL_SMOOTH". 2012-05-22 Ito Hiroyuki * src/gtk/x11view.c (scrollbar_scroll_cb): handle "GDK_SCROLL_SMOOTH". (ViewerEvScroll): multiply "x" and "y" by "SCROLL_INC" when the direction is "GDK_SCROLL_SMOOTH". * src/gtk/gtk_widget.c (set_adjustment): added. (text_view_scroll_event): handle "GDK_SCROLL_SMOOTH". (text_view_scroll_event): use "set_adjustment()". 2012-05-16 Ito Hiroyuki * src/gtk/x11menu.c (detach_toolbar, create_toolbar_box): not used if the version of GTK+ is greater or equal to 3.4. (setupwindow): don't use GtkHandleBox. * src/gtk/gtk_widget.c (show_color_sel, create_color_button): set tool-tip. * src/gtk/x11file.c (select_color): use GtkColorChooserDialog when the version of GTK+ is greater or equal to 3.4. * src/gtk/x11view.c (EvalDialogSetup): change default width of the window. (show_zoom_animation, show_move_animation): call "cairo_set_source()" only once. 2012-05-11 Ito Hiroyuki * src/gtk/gtk_widget.h (NUM_ENTRY_WIDTH): change width of entries. * src/gtk/gtk_widget.c (create_direction_entry): change width of the entry. (show_color_sel, color_button_key_event): not used if the version of GTK+ is greater or equal to 3.4. * src/gtk/ox11menu.c (get_palette, set_palette): not used if the version of GTK+ is greater or equal to 3.4. * src/gtk/x11dialg.c (_set_color, _putobj_color): use "GtkColorChooser" if the version of GTK+ is greater or equal to 3.4. * src/gtk/x11axis.c (position_tab_create): change width of the "Adjust:" entry. * src/gtk/x11opt.c (ViewerDialogSetupItem, ViewerDialogClose): use "GtkColorChooser" if the version of GTK+ is greater or equal to 3.4. * src/gtk/x11view.c (PasteObjectsFromClipboard): use "gdk_window_get_device_position()" instead of "gtk_widget_get_pointer()" if the version of GTK+ is greater or equal to 3.4. (ViewerWinSetup): add "GDK_SCROLL_MASK" and "GDK_SMOOTH_SCROLL_MASK". (ViewerEvScroll): add case for "GDK_SCROLL_SMOOTH". 2012-05-09 Ito Hiroyuki * src/gtk/x11view.c (calc_mouse_x, calc_mouse_y): added. (text_dropped, mouse_up_point, mouse_up_drag, mouse_up_change) (mouse_up_lgend1, mouse_up_lgend2, update_frame_rect) (mouse_move_drag, mouse_move_change, ViewerEvMouseMove) (SetVRuler, SetHRuler): use "calc_mouse_x()" and/or "calc_mouse_y()". 2012-05-08 Ito Hiroyuki * src/math/math_basic_function.c (math_func_rand): use "g_random_double()". (math_func_srand): use "g_random_set_seed()". (create_random_buf): removed. 2012-05-01 Ito Hiroyuki * src/gtk/x11view.c (show_zoom_animation, show_move_animation): don't call "gdk_window_invalidate_rect()". (ViewerEvPaint): check "ZoomLock". 2012-04-27 Ito Hiroyuki * src/gtk/x11view.c (mouse_down_zoom): now cursor position is static. (ViewerEvScroll): control + wheel works as zoom. (get_range_max): added. (ChangeDPI): use "get_range_max()". (show_zoom_animation, show_move_animation): added. (mouse_down_zoom): use "show_zoom_animation()" and "show_move_animation()". (ViewerEvMButtonDown): use "show_move_animation()". * src/gtk/x11menu.h (Viewer): remove members "hupper" and "vupper". 2012-04-26 Ito Hiroyuki * src/gtk/x11view.c (ChangeDPI): use "nround()" to avoid floating point error when calculating scroll position. 2012-04-22 Ito Hiroyuki * src/shell.c (remove_duplicate_history): added. (shget): combine multi-line input. (getcmdline, checkcmd): set "MultiLine" state. 2012-04-20 Ito Hiroyuki * src/shell.c (checkcmd, gettok): accepts here-document "<<-". 2012-04-19 Ito Hiroyuki * src/shellux.c (SleepThread): argument of the function "Sleep()" is milliseconds. 2012-04-14 Ito Hiroyuki * misc/ngraph.keys: filename is changed from "ngraph.key". * misc/ngraph.desktop (Exec): special field code "%f" is added. 2012-04-11 Ito Hiroyuki * addin/ps2gra.nsc: fix error message. * src/ofile.c (rectout): use "GRAdrawpoly()" instead of "GRArectangle()". (draw_rect): added. (barout): use "draw_rect()" instead of "GRAdrawpoly()" when draw outline of the bar. 2012-04-07 Ito Hiroyuki * src/ofile.c (poly_add_elements): fix calculation to avoid influence of floating point error. 2012-04-06 Ito Hiroyuki * src/math/math_scanner.c (get_dec): fix calculation to reduce floating point error. 2012-04-05 Ito Hiroyuki * src/ofile.c (file_color, file_alpha, file_rgb_sub) (file_hsb_sub, file_marksize, file_marktype): check parameters are normal value or not. (draw_polygon): added. (polyout): use "draw_polygon()". (accept_ascii_only): added. (file2d): "ifs" and "remark" fields are accepts only printable ascii character. (check_ifs_init): check if the index of the array is positive. 2012-04-04 Ito Hiroyuki * demo/Makefile.am: add settings for demo#6. * demo/demo.ngp.in: add demo#6. * demo/demo6.dat: added. * demo/demo6.ngp.in: added. * src/ofile.c (uniq_points): fix index pf the array. 2012-04-03 Ito Hiroyuki * src/ofile.c (poly_add_point, poly_add_clip_point) (poly_pos_sort_cb, poly_set_pos, poly_add_elements): added. (polyout): remove parameters related to line attributes. * src/gtk/x11file.c (FileWinUpdate): don't use "FileWinExpose()". (FileWinExpose): removed. (CmFileWindow): don't connect "draw" or "expose-event" signal. (CmFileWindow): call "FileWinUpdate()". * src/gtk/x11axis.c (AxisWinUpdate): don't use "AxisWinExpose()". (AxisWinExpose): removed. (CmAxisWindow): don't connect "draw" or "expose-event" signal. (CmAxisWindow): call "AxisWinUpdate()". * src/gtk/x11merge.c (MergeWinUpdate): don't use "MergeWinExpose()". (MergeWinExpose): removed. (CmMergeWindow): don't connect "draw" or "expose-event" signal. (CmMergeWindow): call "MergeWinUpdate()". * src/gtk/x11lgnd.c (LegendWinUpdate): don't use "LegendWinExpose()". (LegendWinExpose): removed. (CmLegendWindow): don't connect "draw" or "expose-event" signal. (CmLegendWindow): call "LegendWinUpdate()". 2012-03-30 Ito Hiroyuki * addin/legend.c (makescript): add condition to check plot type "polygon_solid_fill". * src/ofile.h (FILE_OBJ_PLOT_TYPE): add plot type "polygon_solid_fill". * src/ofile.c (f2dtypechar): add plot type "polygon_solid_fill". (add_polygon_point, remove_same_points, polyout): added. (f2ddraw): add case "PLOT_TYPE_POLYGON_SOLID_FILL". * src/gtk/x11file.c (FileDialogType): add case "PLOT_TYPE_POLYGON_SOLID_FILL". (draw_type_pixbuf): simplify conditions. (create_type_combo_box): suffix of the array "curvelist" is not "i" but "j". 2012-03-29 Ito Hiroyuki * src/ofile.c (f2dgetcoord): call "arraydel()" when the number of elements is greater than zero. 2012-03-28 Ito Hiroyuki * addin/fitrslt.nsc: use int object to count number of fitting plots. * addin/text-in.nsc: an id of a file instance can be selected. use "dialog::integer_entry" to specify column number. use color of the file object as text color. * doc/html/ja/addin.html: update document. * doc/html/ja/script.html.in: update document. * doc/html/ja/object.html.in: add link to title of each object. * doc/html/objlist.nsc: add link to title of each object. * initfile/Ngraph.nsc (append_addin_list): check size of the sarray object. * src/gtk/ox11menu.c (mx_addin_list_append): check return value of the function "getobj()". (mx_addin_list_append): don't modify sarray object. 2012-03-27 Ito Hiroyuki * src/gtk/main.c (set_dir_defs): use function "g_locale_to_utf8()" instead of "g_locale_from_utf8()". * src/gtk/ox11menu.c (mx_addin_list_append): check if strings are valid UTF-8. * src/gtk/x11opt.c (remove_char): added. (SetScriptDialogSetupItem): use "remove_char()". 2012-03-25 Ito Hiroyuki * src/gtk/x11opt.c (SetScriptDialogSetupItem): use basename of the add-ins as add-in combo-box. 2012-03-23 Ito Hiroyuki * src/gtk/x11dialg.h (SetScriptDialog): add member "assins". * src/gtk/ox11menu.h (menulocal): add member "addin_list". * src/gtk/ox11menu.c (gtkmenu): add field "addin_list_append". (mx_addin_list_append, free_script_list): added. (menulocal_finalize): use "free_script_list()". * src/gtk/x11opt.c (active_script_changed): added. (SetScriptDialogSetupItem): initialize addin combo box. (SetScriptDialogSetup): add addin combo box. * initfile/Ngraph.nsc (append_addin_list): added. 2012-03-16 Ito Hiroyuki * src/math/math_expression.c (math_expression_calculate, calc): "val->type" is always "MATH_VALUE_ERROR" when an error is occurred during calculation. (FACT_MAX): added. (calc): the operator "!" accepts a number lesser then "FACT_MAX". * src/math/math_basic_function.c (math_func_choose): added. (create_random_buf): added. (math_func_rand, math_func_srand): use functions included in GSL if available. * src/shellcm.c (cmdexpr): use "%.0f" instead of "%d" for "iexpr" command. (cmdexpr): use "round()" instead of "nround()" for "iexpr" command. 2012-03-14 Ito Hiroyuki * debian/control (Build-Depends): add "libreadline6-dev". 2012-03-07 Ito Hiroyuki * addin/addin_common.c (fgets_str): return NULL instead of 0. 2012-02-28 Ito Hiroyuki * src/gtk/x11print.c (init_print): removed. 2012-02-22 Ito Hiroyuki * src/gtk/x11lgnd.c (LegendArrowDialogSetup) (LegendRectDialogSetup, LegendMarkDialogSetup) (LegendTextDialogSetup, LegendArcDialogSetup): add delete button again. * src/ofile.c (set_data_progress): consider "fp->bufnum". (getdata_skip_step): call "set_data_progress()". (getdata_sub1): check return value of the function "getdata_sub2()". * addin/fitrslt.c (savescript): width of the frame is now a multiple of 100. * addin/legend.c (savescript): width of the frame is now a multiple of 100. 2012-02-21 Ito Hiroyuki * src/gtk/x11file.c (FitDialogSetupItem) (FitDialogSetSensitivity): set "user_func" field aftr setting of "derivative". (check_fit_func): added. (create_user_fit_frame): connect "changed" signal to the function "check_fit_func()". (create_user_fit_frame): connect "focus-in" signal to the function "func_entry_focused()". (FitDialogResult): 4th argument of the function "math_equation_add_parameter()" should be 2. (func_entry_focused): use parameter "user_data" as a instance of the "GtkEntryCompletion". (FitDialogApply): save user fitting function to the history. * src/gtk/x11menu.h (NgraphApp): add member "fit_list". * src/gtk/x11menu.c (FIT_HISTORY): added. (load_hist, save_entry_history): load and save history of user fitting functions. 2012-02-16 Ito Hiroyuki * mingw/windows_make.sed: update install path. * initfile/Ngraph.ini.win: the first line should be blank or comment. * src/gtk/main.c: add global variable "ADDINDIR"(only for Windows). 2012-02-15 Ito Hiroyuki * doc/html/index.html: remove English documents from the package. * doc/html/Makefile.am: remove English documents from the package. * src/gtk/x11graph.c (check_help_file): default language of the help file is Japanese. * configure.in: remove English documents from the package. * src/gtk/gtk_entry_completion.c (add_completion): check if the string is valid UTF8. 2012-02-14 Ito Hiroyuki * src/gtk/gtk_entry_completion.c (add_completion): use "g_strchomp()". * misc/debian/ngraph-gtk.install: update install directory of demonstration files. * misc/debian/ngraph-gtk-addins.install: update install directory. * misc/debian/watch (http): fix URL. * misc/debian/rules: remove rule "override_dh_compress". * misc/debian/control (Description): fix description of addin package. * mingw/windows_make.sed: change "pkgdatadir". * addin/Makefile.am (addindir): added. * src/osystem.c (sysinit): free string set to the field "doc_dir". (nsystem): add field "doc_dir". * src/shell.c (ngraphenvironment): add "addin" to the "PATH" environment instead of "data". * src/gtk/dir_defs.h.in (ADDINDIR): added. * src/gtk/main.c (set_dir_defs): initialize "ADDINDIR". (set_path_env): add "ADDINDIR" to the "PATH" environment instead of "DATADIR". (main): initialize "doc_dir" field of the system object. * demo/Makefile.am (demodir): change install directory to "pkgdatadir". 2012-02-13 Ito Hiroyuki * mingw/associate.bat: change line feed code. * mingw/echo.nsc: show program neme and version. 2012-02-10 Ito Hiroyuki * src/gtk/dir_defs.h.in: add global variable "NDATADIR" when "WINDOWS" is teue. * src/shell.c (ngraphenvironment): set "data_dir" of the system object to the "PATH" environment. * src/gtk/main.c (main): don't call "set_path_env()". (main): initialize the "data_dir" field of the system object. * src/osystem.c (nsystem): add field "data_dir". (sysdone): free string set to the field "data_dir". * pathconv.sh: number of the argument is fixed. * addin/Makefile.am (dist_pkgdata_DATA): addins are installed in "pkgdatadir". * misc/debian/ngraph-gtk-addins.install: addins are installed in "pkgdatadir". * mingw/windows_make.sed: replace "pkglibexecdir" and "pkgdatadir" to bin directory and lib directory respectively. * mingw/windows.sh: don't move addins to the bin directory. copy hicolor icons to share/icons if exist. 2012-02-09 Ito Hiroyuki * misc/debian/ngraph-gtk.install: update path of "pkglibexedir". * misc/debian/ngraph-gtk-addins-base.install: update path of "pkglibexedir". * misc/debian/ngraph-gtk-addins.install: update path of "pkglibexedir". * misc/debian/control (Build-Depends): use debhelper version 9. * misc/debian/compat: use version 9. * addin/Makefile.am (calc_CFLAGS, fitrslt_CFLAGS): remove option "-D_FORTIFY_SOURCE". (dist_pkglibexec_SCRIPTS, pkglibexec_PROGRAMS): installed in pkglibexedir. * doc/html/ja/Makefile.am (intro.html): use "pkglibexecdir" instead of "libexecdir". * doc/html/en/Makefile.am (intro.html): use "pkglibexecdir" instead of "libexecdi5D5D5Dr". * initfile/Makefile.am (Ngraph.ini): use "pkglibexecdir" instead of "libexecdir". * src/Makefile.am (ngraph_CFLAGS): remove option "-D_FORTIFY_SOURCE". (pkglibexec_PROGRAMS): installed in pkglibexedir. * src/math/Makefile.am (libmath_la_CFLAGS): remove option "-D_FORTIFY_SOURCE". * src/gtk/Makefile.am (libngraph_la_CFLAGS): remove option "-D_FORTIFY_SOURCE". 2012-02-09 Ito Hiroyuki * addin/legend.c (savescript): add font style setting. 2012-01-31 Ito Hiroyuki * src/gtk/x11file.c (button_set_mark_image): check return value of "gtk_image_new_from_pixbuf()" or "gtk_image_new_from_pixmap()". 2012-01-27 Ito Hiroyuki * mingw/windows.sh: add "--libexecdir" option for "configure" script. * addin/Makefile.am (dist_libexec_SCRIPTS): used instead of "pkglib_DATA". (libexec_PROGRAMS): used instead of "pkglib_PROGRAMS". (pkglib_SCRIPTS, EXTRA_DIST): removed. * doc/html/en/Makefile.am (dist_html_DATA): used instead of "html_DATA". (nodist_html_DATA, CLEANFILES): added * doc/html/ja/Makefile.am (dist_html_DATA): used instead of "html_DATA". (nodist_html_DATA, CLEANFILES): added * initfile/Makefile.am (nodist_ngraphconf_DATA): added. (Ngraph.ini): now install directory of the "terminal" command is not "lib" but "libexec". (CLEANFILES): added. * driver/Makefile.am (CLEANFILES): added. * src/Makefile.am (libexec_PROGRAMS): now install directory of the "terminal" command is not "lib" but "libexec". * src/math/Makefile.am (BUILT_SOURCES): added. * src/gtk/Makefile.am (nodist_libngraph_la_SOURCES) (BUILT_SOURCES, CLEANFILES): added. * demo/Makefile.am (nodist_demo_DATA): files "demo[1-4].ngp" are not included in tarball. 2012-01-23 Ito Hiroyuki * src/gtk/x11lgnd.c (set_sensitive_with_label): removed. (legend_dialog_set_sensitive): use "set_widget_sensitivity_with_label()". * src/gtk/x11print.c (OutputImageDialogSetupItem): use functions "set_widget_sensitivity_with_label()" and "get_mnemonic_label()". * src/gtk/x11opt.c (use_external_toggled, load_file_toggled): use function "set_widget_sensitivity_with_label()". * src/gtk/x11graph.c (PageDialogPage): use function "set_widget_sensitivity_with_label()". * src/gtk/x11file.c (set_fitdialog_sensitivity) (set_user_fit_sensitivity, FitDialogSetSensitivity) (FileDialogType): use function "set_widget_sensitivity_with_label()". * src/gtk/x11axis.c (bg_button_toggled, num_direction_changed): use function "set_widget_sensitivity_with_label()". * src/gtk/gtk_widget.c (get_mnemonic_label) (set_widget_sensitivity_with_label): added. (get_widget): removed. 2012-01-22 Ito Hiroyuki * src/gtk/x11file.c (FileDialogType): set sensitivity of widgets "d->fit" and "d->fit_label". (plot_tab_create): initialize "d->fit_label". * src/gtk/x11dialg.h (FileDialog): add member "fit_label". 2012-01-21 Ito Hiroyuki * src/gtk/x11dialg.h (FitDialog): add member "usr_def_prm_tbl". * src/gtk/x11file.c (set_fitdialog_sensitivity) (FitDialogSetSensitivity): set sensitivity of the widget "usr_def_prm_tb". (create_user_fit_frame): initialize "usr_def_prm_tbl". 2012-01-20 Ito Hiroyuki * src/gtk/x11lgnd.c (text_dialog_show_tab): removed. (LegendTextDialogSetup): don't connect "show" signal. * src/gtk/x11axis.c (scale_tab_create): use "map" signal instead of "show" signal. (TIME_FORMAT_STR): added. (numbering_tab_create): add tool tip for "Date/time format" entry. (axis_dialog_show_tab): removed. (AxisDialogSetup): don't connect "show" signal. * src/gtk/x11file.c (file_dialog_show_tab): removed. (FileDialogSetupCommon): don't connect "show" signal. * src/gtk/gtk_widget.c (add_copy_button_to_box): use "map" signal instead of "show" signal. 2012-01-19 Ito Hiroyuki * src/gtk/x11dialg.h (AxisDialog): remove member "del_btn" and "CanDel". * src/gtk/x11view.c (ViewerAlignType): added. (ViewerEvKeyDown): actions related to delete and change order of objects are managed in "GtkAction". (ViewerPopupMenu): removed. (ViewerUpdateCB): added. (CmEditMenuCB): manage actions related to change order of an object. * src/gtk/x11axis.c (AxisDialogSetup): remove redundant call of the function "gtk_widget_set_sensitive()". (AxisDialog): the parameter "candel" is not used. * src/gtk/x11menu.c (ActionEntry): "Edit/drow Order" menu item is added. * addin/timer.nsc (rectangle): use "dup" command. * src/shell.c (cmdtable): add internal command "dup". * src/shellcm.c (cmdup): added. 2012-01-13 Ito Hiroyuki * src/gtk/gtk_subwin.c (cell_focus_out, start_editing): connect "cell_focus_out()" to "focus-out-event" only when the version of GTK+ is 3.0. * src/gtk/gtk_ruler.c (get_thickness): added. (nruler_size_request, nruler_draw_ticks, nruler_draw_pos): use "get_thickness()". 2012-01-06 Ito Hiroyuki * src/gtk/ox11menu.c (mx_get_locale): added. (gtkmenu): add field "locale". * src/gtk/main.c (n_getlocale): added. (main): get locale string. * src/gtk/x11graph.c (check_help_file): added. (CmHelpHelp): use "check_help_file()" to get full-path of help file. 2011-12-22 Ito Hiroyuki * addin/legend.c (caption_edited, caption_toggled): remove unused variables. * addin/addin_common.h (gtk_hbox_new, gtk_vbox_new): don't use deprecated functions. * src/gtk/gtk_common.h (gtk_hbox_new, gtk_vbox_new) (gtk_hbutton_box_new, gtk_hseparator_new, gtk_hscrollbar_new) (gtk_vscrollbar_new, gtk_hscale_new_with_range): don't use deprecated functions. * src/gtk/x11opt.c (FontSettingDialogAddAlternative): use "GtkFontChooserDialog" when the version of GTK+ library is greater or equal to 3.2. * src/gtk/gtk_widget.c (set_linumber_color): use "gtk_widget_override_color()" to set color of text. initialize "alpha" member of the structure "GdkRGBA". The range of each member of the structure "GdkRGBA" is from 0.0 to 1.0. 2011-12-18 Ito Hiroyuki * addin/fitrslt.c (makescript, savescript): use "iarray" object to calculate the maximum length of the text. * addin/legend.c (caption_toggled, caption_edited): use "gtk_tree_model_get()" to get file id. (COLUMN_CHECK, COLUMN_ID): added. (COLUMN_CAPTION): change name. (savescript): use "iarray" object to calculate the maximum length of the text. 2011-12-14 Ito Hiroyuki * addin/legend.c (savescript): fix font setting. 2011-12-14 Ito Hiroyuki * addin/tex_equation.nsc: add quotation mark around the variable "$NGRAPHLIB". * addin/ps2gra.nsc: add quotation mark around the variable "$NGRAPHLIB". * addin/legend.nsc: add quotation mark around the variable "$NGRAPHLIB". * addin/fitrslt.nsc: add quotation mark around the variable "$NGRAPHLIB". * addin/fft.nsc: add quotation mark around the variable "$NGRAPHLIB". * addin/calc.nsc: add quotation mark around the variable "$NGRAPHLIB". 2011-12-07 Ito Hiroyuki * initfile/NgraphUI.xml: remove "View Clear" button. * initfile/NgraphUI.xml.win: remove "View Clear" button. 2011-12-06 Ito Hiroyuki * misc/ngraph.1: escape '-'. * misc/ngraph.desktop (Encoding): removed. * debian/control (Description): add text. * src/gtk/x11menu.c (ActionEntry): change menu strings from "Open" to "Add". * initfile/NgraphUI.xml: chang name of action from "DataOpenAction" and "MergeOpenAction" to "DataAddAction" and "MergeAddAction" respectively. 2011-12-05 Ito Hiroyuki * src/gtk/x11file.c (FitDialogSetup, FileDialogSetup): remove "Delete" button from dialog. * src/gtk/x11merge.c (MergeDialogSetup): remove "Delete" button from dialog. * src/gtk/x11axis.c (GridDialogSetup, SectionDialogSetup) (CrossDialogSetup, AxisDialogSetup): remove "Delete" button from dialog. * src/gtk/x11lgnd.c (LegendArrowDialogSetup) (LegendRectDialogSetup, LegendArcDialogSetup) (LegendMarkDialogSetup, LegendTextDialogSetup): remove "Delete" button from dialog. 2011-12-05 Ito Hiroyuki * debian/ngraph-gtk.manpages: added. * configure.in: change name of the package from "Ngraph-gtk" to "ngraph-gtk". * src/gtk/main.c (set_path_env): change order of "PATH" environment. 2011-11-23 Ito Hiroyuki * misc/ngp2.1: added. * misc/ngraph.1: added. 2011-11-21 Ito Hiroyuki * configure.in (GTK2_REQUIRED_VERSION, GTK3_REQUIRED_VERSION): added. * configure.in: use GTK+3 if available. * icons/application-x-ngraph.xpm: added. * configure.in (AC_CONFIG_FILES): add "icons/Makefile" and "misc/Makefile". * MAKEFILE.am (SUBDIRS): add "icons" and "misc". 2011-11-21 Koichi Akabe * debian/rules: updated for debian repository. * debian/control: updated for debian repository. * debian/install: added. 2011-11-21 Ito Hiroyuki * addin/timer.nsc: remove shebang. * addin/tex_equation.nsc: remove shebang. * addin/ps2gra.nsc: remove shebang. * addin/fig2gra.nsc: remove shebang. * addin/cal.nsc: remove shebang. 2011-11-20 Ito Hiroyuki * src/gtk/Makefile.am (libngraph_la_CFLAGS): remove settingis -DGTK_DISABLE_DEPRECATED=1 -DGDK_DISABLE_DEPRECATED=1 -DGDK_PIXBUF_DISABLE_DEPRECATED=1 -DG_DISABLE_DEPRECATED=1 -DGTK_DISABLE_SINGLE_INCLUDES=1 -DG_DISABLE_SINGLE_INCLUDES=1 -DGDK_PIXBUF_DISABLE_SINGLE_INCLUDES=1 -DGSEAL_ENABLE=1 * src/Makefile.am (ngraph_CFLAGS): remove settingis -DG_DISABLE_DEPRECATED=1 -DG_DISABLE_SINGLE_INCLUDES=1 * addin/Makefile.am (APP_CFLAGS): remove settingis -DGTK_DISABLE_DEPRECATED=1 -DGDK_DISABLE_DEPRECATED=1 -DGDK_PIXBUF_DISABLE_DEPRECATED=1 -DG_DISABLE_DEPRECATED=1 -DGTK_DISABLE_SINGLE_INCLUDES=1 -DG_DISABLE_SINGLE_INCLUDES=1 \ -DGDK_PIXBUF_DISABLE_SINGLE_INCLUDES=1 -DGSEAL_ENABLE=1 * debian/copyright: specify GPL version. 2011-11-14 Ito Hiroyuki * addin/Makefile.am (pkglib_DATA): add "timer.nsc". * addin/timer.nsc: added. 2011-11-08 Ito Hiroyuki * src/gtk/x11menu.c (recent_filter): use "g_ascii_strncasecmp()" and "g_ascii_strcasecmp()" instead of "g_strcmp0()". * src/gtk/main.h (NGRAPH_TEXT_MIME): added. 2011-11-04 Ito Hiroyuki * src/gtk/main.h (NGRAPH_GRAPH_MIME, NGRAPH_DATA_MIME): added. * src/gtk/x11dialg.h (MiscDialog): remove member "history". * src/gtk/ox11menu.c (menu_save_config_sub, mgtkloadconfig) (menulocal_finalize, menuinit): remove codes related to data file history. * src/gtk/x11file.c (CmFileHistory): use "GtkRecentChooser". * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): remove codes related to data file history. * src/gtk/x11commn.c (add_hist): added. (AddNgpFileList, AddDataFileList): use "add_hist()". * src/gtk/ox11menu.h (menulocal): remove member "datafilelist". * src/gtk/x11menu.c (SaveHistory, create_recent_data_menu) (add_underscore): removed. (recent_filter): added. (create_action_group): use "gtk_recent_filter_add_custom()" instead of "gtk_recent_filter_add_mime_type()". 2011-11-02 Ito Hiroyuki * addin/calc.c (load_settings): set maximum length of a string of "%s" parameter for the function "sscanf()". * addin/fft.c (MAXP, MAXDATA): increase maximum data number. * src/gtk/main.h (APP_MIME): added. * src/gtk/x11menu.c (create_action_group): use "gtk_recent_filter_add_mime_type()" instead of "gtk_recent_filter_add_application()" and "gtk_recent_filter_add_pattern()". * src/gtk/x11commn.c (AddNgpFileList): use "APP_MIME". 2011-11-01 Ito Hiroyuki * addin/fitrslt.c: move some functions to "addin_common.c". * addin/legend.c: added. * src/gtk/x11menu.c (application): call "SaveHistory()" before call "gtk_ui_manager_remove_ui()". 2011-10-24 Ito Hiroyuki * initfile/Ngraph.ini.win (script): add fft add-in. * src/gtk/main.c (set_dir_defs): "LIBDIR" is now "app_path/bin". * mingw/windows.sh: add-in programs are now installed in "$PKG_DIR/bin". * addin/Makefile.am (pkglib_SCRIPTS): remove "calc.tcl" and "fitrslt.tcl". (pkglib_PROGRAMS): add "calc" and "fitrslt". * addin/addin_common.h: added. * addin/addin_common.c: added. * addin/calc.c: added. * addin/fitrslt.c: added. 2011-10-07 Ito Hiroyuki * debian/control (Recommends): add pstoedit. * addin/calc.tcl (savedata, savescript): remove white space in the formula. 2011-09-26 Ito Hiroyuki * debian/ngraph.bash: add "-V" and "--VERSION" option. add "MJD" to the parameter of the "-ex" and "-ey" option. * zsh/_ngraph: add "-V" and "--VERSION" option. add "MJD" to the parameter of the "-ex" and "-ey" option. 2011-09-16 Ito Hiroyuki * src/gtk/gtk_subwin.c (sub_window_show): use "gtk_window_present()" instead of "gtk_widget_show()". * src/gtk/x11commn.c: fix typo. 2011-09-14 Ito Hiroyuki * src/gtk/main.c: "License" is defined when the version of GTK+ is less than 3. 2011-09-13 Ito Hiroyuki * src/ofile.c (set_data_progress): consider "d->hskip". * src/gtk/x11lgnd.c (width_edited, pos_edited): the argument of the function "LegendWinUpdate()" is "TRUE". 2011-09-12 Ito Hiroyuki * src/gtk/x11commn.c (ProgressDialogCreate): call "gtk_progress_bar_set_show_text()" when the version of GTK+ is 3. * src/gtk/x11graph.c (CmHelpAbout): use "license-type" instead of "license" when the version of GTK+ is 3. 2011-09-09 Ito Hiroyuki * src/gtk/ogra2cairo.h (gra2cairo_local): use "cairo_region_t" instead of "GdkRegion" when the version of GTK+ is 3. * src/gtk/ogra2cairo.c (gra2cairo_clip_region): use "cairo_region_t" instead of "GdkRegion" when the version of GTK+ is 3. * src/gtk/ox11menu.h (menulocal): type of "pix" is not "GdkPixmap" but "cairo_surface_t". (menulocal): use "cairo_region_t" instead of "GdkRegion" when the version of GTK+ is 3. * src/gtk/x11dialg.h (DIALOG_PROTOTYPE): type of "vbox" is not "GtkVBox" but "GtkBox". (LegendDialog): type of "arrow_pixmap" is not "GdkPixmap" but "cairo_surface_t". * src/gtk/x11gui.c (DialogInput, DialogRadio, DialogCombo) (DialogComboEntry, DialogSpinEntry, DialogCheck): type of "vbox" is not "GtkVBox" but "GtkBox". * src/gtk/ox11menu.c (mx_clear): use "cairo_region_t" instead of "GdkRegion" when the version of GTK+ is 3. * src/gtk/x11file.c (button_set_mark_image, draw_type_pixbuf) (create_type_combo_box): use "cairo_surface_t" instead of "GdkPixmap" when the version of GTK+ is 3. * src/gtk/x11view.c (region): use "cairo_region_t" instead of "GdkRegion" when the version of GTK+ is 3. (paste_cb, mouse_move_scroll): use "gdk_window_get_width()" and "gdk_window_get_height()" instead of "gdk_window_get_geometry()" when the version of GTK+ is greater than 2.24. (ViewerWinSetup, ShowCrossGauge, SetHRuler, SetVRuler): use "gdk_window_get_width()" and "gdk_window_get_height()" instead of "gdk_drawable_get_size()" when the version of GTK+ is greater than 2.24. (popup_menu_position): use "gdk_window_get_position()" instead of "gdk_window_get_geometry()" when the version of GTK+ is greater than 2.24. (ViewerEvPaint): use "cairo_set_source_surface()" instead of "gdk_cairo_set_source_pixmap()." (ViewerEvPaint): added codes for GTK+ 3. (create_pix): use "cairo_surface_t" instead of "GdkPixmap". (OpenGC): added codes for GTK+ 3. * src/gtk/ogra2x11.c (gtkevpaint): added codes for GTK+ 3. (gtklocal): use "cairo_surface_t" instead of "GdkPixmap" when the version of GTK+ is 3. * src/gtk/ogra2gdk.c (gra2gdk_create_pixmap): use "cairo_surface_t" instead of "GdkPixmap" when the version of GTK+ is 3. * src/gtk/gtk_widget.c (text_view_size_allocate): fix typo. (set_linumber_color): use "gtk_widget_override_background_color()" instead of "gtk_widget_modify_base()" when the version of GTK+ is 3. (get_preferred_width, get_preferred_height): added for GTK+ 3. (create_text_view_with_line_number): added codes for GTK+ 3. (text_view_with_line_number_set_font): use "gtk_widget_override_font()" instead of "gtk_widget_modify_font()" when the version of GTK+ is 3. * src/gtk/x11lgnd.c (LegendArrowDialogPaint) (LegendArrowDialogScaleL, LegendArrowDialogSetup) (create_character_view, LegendWinExpose, CmLegendWindow): add codes for GTK+ 3. * src/gtk/x11menu.h (NgraphApp): use "cairo_surface_t" instead of "GdkPixmap" when the version of GTK+ is 3. * src/gtk/gtk_common.h: add "GDK_KEY_*" definitions. * src/gtk/x11menu.c (create_markpixmap, free_markpixmap): use "cairo_surface_t" instead of "GdkPixmap" when the version of GTK+ is 3. * src/gtk/gtk_liststore.c (start_editing_obj): add "const" to the 5th parameter when the version of GTK+ is 3. * src/gtk/x11info.c (InfoWinSetFont): use "gtk_widget_override_font()" instead of "gtk_widget_modify_font()" when the version of GTK+ is 3. * src/gtk/gtk_subwin.c (cell_focus_out): added for GTK+ 3. (start_editing): add codes for GTK+ 3. * src/gtk/x11lgndx.c (LegendGaussDialogPaint) (LegendGaussDialogSetup): add codes for GTK+ 3. * src/gtk/gtk_ruler.c (ruler_new): add codes for GTK+ 3. (nruler_get_preferred_width, nruler_get_preferred_height): added for GTK+ 3. (nruler_size_request, nruler_expose, nruler_make_pixmap) (nruler_draw_ticks, nruler_draw_pos): add codes for GTK+ 3. 2011-08-15 Ito Hiroyuki * initfile/NgraphUI.xml.win: fix typo. * initfile/NgraphUI.xml: fix typo. * src/gtk/x11menu.c (ActionEntry): fix typo. 2011-08-09 Ito Hiroyuki * src/math/math_equation.c (check_const_sub): check "exp->u.assign.right" instead of "exp->u.bin.right" when type of the expression is "MATH_EXPRESSION_TYPE_ASSIGN". 2011-08-08 Ito Hiroyuki * src/gtk/gtk_subwin.c (sub_window_minimize) (sub_window_restore_state): removed. 2011-08-07 Ito Hiroyuki * src/gtk/gtk_subwin.c (ev_sub_win_key_down): use "window_action_set_active()" instead of "gtk_widget_hide()". * src/gtk/x11file.c (execute_fit_dialog): added. (FileDialogFit, FileWinFit): use "execute_fit_dialog()". 2011-07-31 Ito Hiroyuki * src/shellcm.c (cmwhich): check built-in command. 2011-07-29 Ito Hiroyuki * src/gtk/x11lgnd.c (LegendWinLegendUpdate): save "d->select" and "d->legend_type" when "ret" is equal to "IDOK". 2011-07-28 Ito Hiroyuki * src/ofile.c (getdata2, getminmaxdata, f2dgetdataraw): use stack instead of heap for the data buffer. (getdata, getdata2, getminmaxdata, f2dgetdataraw): size of the data buffer is "FILE_OBJ_MAXCOL + 3" (for error-bar plot). 2011-07-27 Ito Hiroyuki * src/gtk/x11gui.c (message_box): increase maximum length of a message. * src/ofile.c (getminmaxdata): bug fix: update "fp->maxy.val" instead of "fp->maxx.val". (getdataraw): bug fix: set value to not "fp->d3" but "d3". 2011-07-22 Ito Hiroyuki * addin/ps2gra.nsc: change name of functions. * addin/fig2gra.nsc: change name of functions. * addin/fig2gra.rb (set_line_attribute): fix typo. * addin/tex_equation.nsc: change name of functions. * src/nstring.c (nstrncat): this function is not used. 2011-07-21 Ito Hiroyuki * addin/tex_equation.nsc: fix typo. 2011-07-20 Ito Hiroyuki * addin/fig2gra.nsc: added. * addin/tex_equation.nsc: use "fig2gra.nsc" when ruby is not available. * addin/ps2gra.nsc: use "fig2gra.nsc" when ruby is not available. * src/object.c (get_array_argument): call "g_strfreev()" when the function "g_shell_parse_argv()" returns false. * src/oregexp.c (regexp_match): call "g_match_info_free()" when the function "g_regex_match()" returns false. 2011-07-18 Ito Hiroyuki * src/oiarray.c (oarray_get_index, oarray_create_math) (iarray_map): added. (iarrayget, iarrayput, iarrayins, iarraydel): use "oarray_get_index()". (oiarray): add field "map". * src/odarray.c (darrayget, darrayput, darrayins, darraydel): use "oarray_get_index()". (odarray): add field "map". * src/osarray.c (sarrayget, sarrayput, sarrayins, sarraydel): use "oarray_get_index()". * test/sarray_test.nsc: add tests for "get" and "map" fields. * test/iarray_test.nsc: add tests for "get" and "map" fields. * test/darray_test.nsc: add tests for "get" and "map" fields. 2011-07-16 Ito Hiroyuki * src/oint.c (int_times, int_inc, int_dec): added. (oint): add fields "times", "inc" and "dec". 2011-07-13 Ito Hiroyuki * addin/ps2gra.nsc: remove automatically created files. * addin/fig2gra.rb (#draw_poly_line, #uniq_pos): close path when start and end points are same position. * initfile/Ngraph.ini.in (script): add "import PS" and "import EPS" addin. * addin/ps2gra.nsc: added. * addin/Makefile.am: add ps2gra.nsc * src/gtk/x11view.c (ncopyobj): don't copy "name" field. 2011-07-12 Ito Hiroyuki * src/osystem.c (nsystem): type of the field "pid" is "NINT". 2011-07-12 Ito Hiroyuki * src/osystem.c (nsystem): add field "pid". (syspid): added. * src/math/math_basic_function.c (math_func_srand): added. * src/math/math_function.h.in: add function "srand()". * src/gtk/x11menu.h (SubWinType): change order. 2011-07-11 Ito Hiroyuki * src/shellcm.c (cmwhich): added. * src/shell.c (cmdtable): add internal command "which". * doc/html_ja/addin.html: update document. * addin/Makefile.am (pkglib_SCRIPTS): add "fig2gra.rb". (pkglib_DATA): add "tex_equation.nsc". * addin/fig2gra.rb: added. * addin/tex_equation.nsc: added. * initfile/Ngraph.ini.in (script): add "TeX equation" addin. * src/math/math_expression.c (math_func_call_expression_new): "buf" is NULL when argc is less than 1. * src/math/math_basic_function.c (math_func_time): added. * src/math/math_function.h.in: add function "time()". 2011-07-10 Ito Hiroyuki * src/object.c (add_arg_object, getargument): accept character "," as a string of an id list. * src/gtk/ox11menu.c (mx_focus_obj, mx_unfocus_obj): added. (gtkmenu): add fields "focus" and "unfocus". 2011-07-05 Ito Hiroyuki * src/omerge.c (ZOOM_MAX): added. (mergezoom): do nothing if "zm * zoom" is larger than "ZOOM_MAX". (mergegeometry): upper limit of the field "zoom" is "ZOOM_MAX". * src/gtk/x11view.c (calc_zoom, set_zoom_prm): added. (init_zoom, mouse_move_zoom): use "calc_zoom()" and "set_zoom_prm()". (mouse_up_zoom): use "calc_zoom()". (ViewUpdate): set "d->ShowRect" as FALSE. * src/gtk/gtk_widget.h (SPIN_ENTRY_MAX): change limit to 1000000. 2011-07-02 Ito Hiroyuki * src/gtk/x11gui.c (message_box): limit length of an error message. * src/gra.c (GRAlines): fix argument number. (GRAinputdraw): fix check of the argument number. 2011-06-23 Ito Hiroyuki * src/ofile.c (f2dhead): don't add line number. * src/gtk/x11dialg.h (FileDialog):remove members "comment" and "comment_num_tag". * src/gtk/x11file.c (count_line_number_str, set_line_number_tag) (create_text_tag, set_file_preview): removed. (set_headlines): use "text_view_with_line_number_set_text()". (FileDialogSetup): use "create_text_view_with_line_number()". (CmFileWindow): call "gtk_tree_view_set_enable_search()", "gtk_tree_view_set_search_column()" and "gtk_tree_view_set_tooltip_column()". * src/gtk/x11merge.c (CmMergeWindow): call "gtk_tree_view_set_enable_search()", "gtk_tree_view_set_search_column()" and "gtk_tree_view_set_tooltip_column()". * src/gtk/x11axis.c (CmAxisWindow): call "gtk_tree_view_set_enable_search()", "gtk_tree_view_set_search_column()" and "gtk_tree_view_set_tooltip_column()". * src/gtk/gtk_widget.c (text_view_scroll_event) (set_scroll_visibility, text_view_size_alocate) (set_linumber_color, create_text_view_with_line_number) (text_view_with_line_number_set_text) (text_view_with_line_number_set_font): added. * src/gtk/gtk_common.h: remove macros for Gtk+ which version is lesser than 2.14. * configure.in: "GTK_REQUIRED_VERSION" is now 2.14.0. 2011-06-20 Ito Hiroyuki * src/gtk/x11merge.c (MergeDialogSetupItem): cursor will be set after the last character. * src/gtk/x11file.c (FileDialogSetupItem): cursor will be set after the last character. 2011-06-15 Shijo Nagao * src/gtk/ox11menu.c (mx_show_lib_version): use macro "GSL_VERSION" if available. 2011-06-14 Ito Hiroyuki * initfile/Ngraph.nsc: open dummy "gra2cairofile" object when save "GRA" file to render strings corectry. * src/ogra2nul.c (g2nul_chardescent): remove unused variable "font". * src/oaxis.c (draw_numbering_normalize): add "default" in the "case" statement. * src/oprm.c (prmload): remove unused variables "scauto" and "scperiod". * src/math/math_expression.c (register_arg): remove unused variable "i". (call_func): remove unused variable "use_array". * src/math/math_scanner.c (get_dec): remove unused variable "ptr". * src/object.c (getvaluestr): remove unused variable "len". * src/otext.c (textmatch): calculate margin. * src/shell.c (puts_localized): return "r". * src/ofile.c (put_func): remove unused variables "default_func" and "fname". (getdata_sub2): remove unused variables "data2" and "data3". (f2doutputfile): return "r". * src/orect.c (rectrotate): remove unused variables "nx1", "ny1", "nx2" and "ny2". * src/gra.c (GRAdrawtext): remove unused variable "j". * src/gtk/ogra2cairo.c (loadconfig): remove unused variables "fontcashsize" and "fontcashsize, fontcashdirfontcashdir". * src/gtk/ox11dlg.c (dlgmessage): remove unused variable "rcode". * src/gtk/x11cood.c (CmCoordinateWindow): remove unused variable "dlg". * src/gtk/x11file.c (FitSaveDialogSetup): remove unused variable "j". (func_entry_focused): remove unused variable "d". (FileDialogSetup): remove unused variable "rcode". (start_editing_type): remove unused variable "list". * src/gtk/x11view.c (CutFocusedObjects): remove unused variable "text". (EvalDialogSetupItem): initialize variable "n". (scrollbar_scroll_cb, AddList, AddInvalidateRect): remove unused variable "d". (mouse_down_point): remove unused variable "zoom". (calc_integer_ratio): check variable "po2" (not "pow"). * src/gtk/x11opt.c (SetScriptDialogBrowse): remove unused variable "d". * src/gtk/ogra2x11.c (gtk_output): remove unused variables "cstr"and "local". * src/gtk/x11axis.c (GridDialogAxis): remove unused variable "d". (AxisDialogFile): remove unused variable "room". (CmAxisScaleUndo): remove unused variable "d". * src/gtk/x11print.c (print_obj): remove unused member "g2wid". (draw_page): remove unused variable "g2wid". * src/gtk/x11lgnd.c (LegendWinLegendUpdate): remove unused variable "num". * src/gtk/x11commn.c (FileAutoScale): remove unused variable "room". * src/gtk/x11graph.c (SwitchDialogUp): remove unused variable "num". (SaveDialogSetup): remove unused variable "hbox". * src/gtk/ogra2cairofile.c (gra2cairofile_output): remove unused variable "cstr". 2011-06-11 Ito Hiroyuki * demo/demo.ngp.in (dialog): don't clear graph before exit demonstration. * src/gtk/x11print.c (DriverDialogSelectCB): type of variables "l" and "n"is now "int". * initfile/Ngraph.nsc: add option "-V". * src/oaxis.c (axis): add field "auto_scale_margin". remove 2nd argument for "auto_scale" and "get_auto_scale" fields. (axisautoscale_margin): added. (axisinit): initialize "auto_scale_margin" field. (axisadjust, axischangescale, axiscoordinate): use "AXIS_TYPE_", "AXIS_TYPE_LOG" and "AXIS_TYPE_LOG" instead of 1 and 2. (axischangescale): now parameter "room" means margin of the scale. (axisautoscale, axisgetautoscale): remove 2nd argument. * src/oagrid.c (agrid): add fields "grid_x" and "grid_y". (agridinit): initialize "grid_x" and "grid_y" fields. (agriddraw): check "grid_x" and "grid_y" fields. * src/shellcm.c (dispfield): "NCHAR" and "NCFUNC" are not used now. * src/object.c (check_arglist): added. (addobject): call "check_arglist()". (chkobjarglist, _putobj, putobj, _getobj, getobj, copyobj) (getvaluestr): "NCHAR" and "NCFUNC" are not used now. (add_arg_object, add_arg_int, add_arg_double, add_arg_bool) (add_arg_num, add_arg_sarray, add_arg_iarray, add_arg_darray) (set_arg_enum, get_array_argument): added. (getargument): use "set_arg_enum()", "g_shell_parse_argv()", "get_array_argument()", "add_arg_num()" and "add_arg_object()". * src/oio.c (io): add "mode" field. remove 2nd argument for "open" and "popen" field. (io_init): initialize "mode" field. (io_open): use "mode" filed instead of 2nd argument. * src/mathfn.c (nround): use "G_MAXINT" and "G_MAXINT" instead of "LANG_MIN" and "LONG_MAX" . * src/ofile.c (barout): use "case" statement instead of "if". (f2dboundings): minimum or maximum value for bar plot is now 0. * src/gtk/x11dialg.h (AAxisDialog): add member "margin". (GridDialog): add members "draw_x" and "draw_y". * src/gtk/x11axis.c (GridDialogSetupItem): get "grid_x" and "grid_y" fields. (GridDialogSetup): add widgets to set "grid_x" and "grid_y" fields. (GridDialogClose): set "grid_x" and "grid_y" fields. (scale_tab_setup_item): remove redundant function call "getobj()" for "div" fields. (scale_tab_setup_item): get "auto_scale_margin" field. (AxisDialogFile): remove second argument for "get_auto_scale" field. (scale_tab_create): add widget to set "auto_scale_margin" field. (scale_tab_set_value): set "auto_scale_margin" field. (CmAxisZoom): now 3rd argument for "scale" field is 0. * src/gtk/x11commn.c (FileAutoScale): remove second argument for "auto_scale" field. * demo/demo.ngp (dialog): don't clear graph before exit demonstration. * demo/demo4.ngp.in: use "axisgrid" instead of "path" to show grid line. * src/math/math_basic_function.c (mjd): check parameters "m" and "d". * src/gtk/ox11menu.c (get_palette): initialize variable "palette" as NULL. 2011-06-10 Ito Hiroyuki * src/gtk/ox11menu.c (gtkmenu): add argument for the field "lib_version". (mx_show_lib_version): add prefix for the output strings. * src/gtk/x11view.c (ViewerPopupMenu, CmEditMenuCB) (CmViewerButtonArm): use "GPOINTER_TO_INT()" to get data. * src/gtk/x11print.c (CmOutputMenu): use "GPOINTER_TO_INT()" to get data. * src/gtk/x11menu.c (toggle_view_cb, detach_toolbar): use "GPOINTER_TO_INT()" to get data. * src/gtk/x11graph.c (CmGraphNewMenu): use "GPOINTER_TO_INT()" to get data. 2011-06-08 Ito Hiroyuki * src/gtk/x11commn.c (get_new_axis_id): add argument "aobj". 2011-05-20 Ito Hiroyuki * src/ostring.c (utf8_string_slice, string_slice, string_match) (string_rindex, string_index, string_replace): added. (ostring): add field "slice", "replace", "index", "rindex" and "match". * src/oregexp.c (regexp_replace): added. (oregexp): add field "replace". * test/string_test.nsc: added. * src/math/math_basic_function.c (compare_double_with_prec): added. (math_func_eq, math_func_neq): add 3rd argument. use "compare_double_with_prec()". 2011-05-19 Ito Hiroyuki * src/math/math_parser.c (parse_argument_list): update "*buf" after call the function "g_realloc()". * src/object.c (array_reverse): added. * src/odarray.c (odarray): add field "reverse", "sum", "average", "RMS", "sdev", min", "max" and "slice". (calc_sum, calc_square_sum, darray_sum, darray_average) (darray_rms, darray_sdev, darray_min, darray_max): added. * src/oiarray.c (oarray_reverse, oarray_slice): added. (oiarray): add field "reverse", "sum", "average", "RMS", "sdev", min", "max" and "slice". (calc_sum, calc_square_sum, iarray_sum, iarray_average) (iarray_rms, iarray_sdev, iarray_min, iarray_max): added. * src/mathfn.c (bsearch_int): add braces after "if" statements. * src/osarray.c (osarray): add field "reverse" and "slice". (sarray_slice): added. 2011-05-18 Ito Hiroyuki * src/ofit.c (fituser): "MSERR" is not used. * src/ofile.c (errordisp, errordisp2): "MSERR" is not used. * src/oregexp.c (regexp_get): return 1 when failed. 2011-05-17 Ito Hiroyuki * test/iarray_test.nsc: added. * test/darray_test.nsc: added. * test/sarray_test.nsc: added. * test/regexp_test.nsc: added. * initfile/save_ui_file.nsc: don't use external programs. * src/shellcm.c (cmecho): length of the output strings is now not limited. * src/object.c (cmp_func_int_r, arrayrsort_int, cmp_func_double) (cmp_func_double_r, arraysort_double, arrayrsort_double) (arrayuniq_double, cmp_func_str, cmp_func_str_r, arraysort_str) (arrayrsort_str, arrayuniq_str): added. (getvaluestr): use "g_string_append_printf()" instead of "sprintf()". * src/oio.c (io_eof): return value is depend on the return value of the function "feof()". * src/gtk/main.c (obj_add_func_ary): add "addregexp". * src/oiarray.c (oarray_get_array, oarray_num, oarray_seq) (iarraypop, iarrayunshift, iarrayshift, iarraysort, iarrayrsort) (iarrayuniq, iarrayjoin, oarray_reverse_seq): added (iarrayadd, iarrayins): use "oarray_get_array()". (oiarray): add fields "push", "pop", "unshift", "shift", "sort", "rsort", "uniq", "join", "seq" and "rseq". * src/odarray.c (darrayadd, darrayins): use "oarray_get_array()". (darraypop, darrayunshift, darrayshift, darraysort, darrayrsort) (darrayuniq, darrayjoin): added. (odarray): add fields "push", "pop", "unshift", "shift", "sort", "rsort", "uniq", "join", "seq" and "rseq". * src/osarray.c (sarrayadd, sarrayins): use "oarray_get_array()". (sarraypop, sarrayunshift, sarrayshift, sarraysort, sarrayrsort) (sarrayuniq): added. (osarray): add fields "push", "pop", "unshift", "shift", "sort", "rsort" and "uniq". * src/oregexp.c: added. 2011-05-16 Ito Hiroyuki * src/ostring.c (string_strip, set_length, string_upcase) (string_downcase, string_reverse): added. (ostring): add field "byte", "length", "strip", "upcase", "downcase" and "reverse". * src/odarray.c (odarray): add field "seq" and "rseq". (odarray): use "oarray_num()", "oarray_seq()" and "oarray_reverse_seq()". * src/oiarray.c (oarray_num): change name from "iarraunum()". (oarray_seq, oarray_rseq): added. (oiarray): add field "seq"and "rseq". (oiarray): use "oarray_num()", "oarray_seq()" and "oarray_reverse_seq()". * src/osarray.c (ERRREGEXP, set_delimiter, sarraysplit) (sarrayjoin): added. (sarrayinit): initialize field "_local". (sarraydone): finalize field "_local". (osarray): add fields "delimiter", "split", "seq", "rseq" and "join". (osarray): use "oarray_num()", "oarray_seq()" and "oarray_reverse_seq()". * src/object.c (arrayins2, arrayput2): use "g_strdup()" instead of "g_malloc()" and "strcpy()". 2011-05-13 Ito Hiroyuki * src/gtk/x11menu.c (ActionEntry): fix callback function (from "CmOutputMenu()" to "CmViewerClear()"). * src/gtk/x11opt.c (CmOptionSaveNgp): fix window title. 2011-05-10 Ito Hiroyuki * initfile/Ngraph.ini.win (palette): added. * initfile/Ngraph.ini.in (palette): added. * src/gtk/ox11menu.h (menulocal): add member "Palette". * src/gtk/ox11menu.c (MenuConfigOthers): change name from "MenuConfigExportImage". Add setting "palette". (get_palette, set_palette): added. (menu_save_config): call "get_palette()" before call "menu_save_config_sub()" when "type & SAVE_CONFIG_TYPE_OTHERS" is true. (menuinit): call "set_palette()". 2011-05-09 Ito Hiroyuki * src/gtk/x11dialg.c: add braces after "if" statements. 2011-05-01 Ito Hiroyuki * src/gtk/x11view.c (UnFocus): use "gtk_widget_queue_draw()" instead of "gdk_window_invalidate_rect()". 2011-04-29 Ito Hiroyuki * src/gtk/x11view.c (UnFocus): call "gdk_window_invalidate_rect()". 2011-04-28 Ito Hiroyuki * src/gtk/x11file.c (CmFileNew, CmFileOpen, CmFileClose) (CmFileUpdate, CmFileEdit, CmFileMath): add parameters "GtkAction *w" and "gpointer client_data". (FileWinFileDraw): call "CmViewerDraw()" instead of "CmViewerDrawB()". (CmFileMenu): removed. (GetDrawFiles, CmFileSaveData): moved from "x11print.c". * src/gtk/x11view.c (ViewerEvKeyUp): call "reset_drag_info()" only when "CLEAR_DRAG_INFO" is true. (graph_dropped, ViewerEvKeyDown): call "CmViewerDraw()" instead of "CmViewerDrawB()". (CmViewerDraw, CmViewerClear): add parameters "GtkAction *w" and "gpointer client_data". (CmViewerDraw): second parameter represents if select files before drawing or not. * src/gtk/x11opt.c (CmOptionSaveNgp, CmOptionViewer) (CmOptionExtViewer, CmOptionPrefFont, CmOptionScript) (CmOptionMisc, CmOptionSaveDefault): add parameters "GtkAction *w" and "gpointer client_data". (CmOptionMenu): removed. * src/gtk/x11merge.c (CmMergeOpen, CmMergeClose, CmMergeUpdate): add parameters "GtkAction *w" and "gpointer client_data". (CmMergeMenu, MergeWinMergeOpen): removed. * src/gtk/x11axis.c (CmAxisNewFrame, CmAxisNewSection) (CmAxisNewCross, CmAxisNewSingle, CmAxisDel, CmAxisUpdate) (CmAxisZoom, CmAxisClear, CmAxisGridNew, CmAxisGridDel) (CmAxisGridUpdate, CmAxisScaleUndo): add parameters "GtkAction *w" and "gpointer client_data". (CmAxisMenu, CmGridMenu): removed. * src/gtk/x11print.c (CmOutputViewer): removed. (CmOutputViewerB): merged with the function "CmOutputViewer()". (CmOutputViewerB): never call "SetFileHidden()". (CmPrintGRAFile, CmOutputImage): static function. (CmOutputMenu): remove unused case. * src/gtk/x11lgnd.c (CmLineDel, CmLineUpdate, CmRectDel) (CmRectUpdate, CmArcDel, CmArcUpdate, CmMarkDel, CmMarkUpdate) (CmTextDel, CmOptionTextDef): add parameters "GtkAction *w" and "gpointer client_data". (CmLineMenu, CmRectangleMenu, CmArcMenu, CmMarkMenu, CmTextMenu): removed. * src/gtk/x11menu.h (MenuID): remove unused items. 2011-04-23 Ito Hiroyuki * src/gtk/main.c (main): call "g_mem_set_vtable()" when "USE_MEM_PROFILE" is true. * src/osystem.c (system_mem_profile): added. (nsystem): add field "mem_profile" when "USE_MEM_PROFILE" is true. * src/common.h (USE_MEM_PROFILE): added. 2011-04-21 Ito Hiroyuki * src/gtk/main.c (obj_member_completion_function) (my_completion_function): use "strdup()" to create return value. * src/gtk/gtk_ruler.c (nruler_destroy): remove unused parameter "event". (ruler_new): function "nruler_destroy()" is now connected to the "unrealize" signal. 2011-04-20 Ito Hiroyuki * src/object.c (arrayadd): check if the parameter "val" is NULL or not. * src/oroot.c (oputstyle): when size of the array is 1, it is as same as the array has the same two elements. * src/gtk/x11dialg.c (SetObjPointsFromText) (SetObjFieldFromStyle): call "gtk_widget_grab_focus()" when an error is occurred. 2011-04-15 Ito Hiroyuki * src/gtk/x11menu.c (setupwindow, create_message_box): exchange position of messages. * src/gtk/x11view.c (move_focus_frame, viewer_key_scroll): added. (ViewerEvKeyDown): use "move_focus_frame()" and "viewer_key_scroll()". (set_drag_info, reset_drag_info): added. (SetPoint, move_focus_frame): use "set_drag_info()". (ViewerEvKeyUp): call "reset_drag_info()" * pixmap/Makefile.am (EXTRA_DIST): add pixmaps ngraph_align_b.png, ngraph_align_hc.png, ngraph_align_l.png, ngraph_align_r.png, ngraph_align_t.png and ngraph_align_vc.png 2011-04-11 Ito Hiroyuki * src/gtk/x11menu.c (ActionEntry): fix typo (from "_Right" to "_Bottom"). 2011-04-06 Ito Hiroyuki * src/gtk/x11gui.c (check_overwrite): moved from x11commn.c. * src/gtk/x11view.c (SetPoint): moved from x11menu.c. (CmViewerClearB): removed. * src/gtk/x11axis.c (check_axis_history): static function. * src/gtk/x11print.c (GetDrawFiles): moved from x11commn.c. (CmOutputDriverB): removed. * src/gtk/x11menu.c (SaveHistory): moved from x11commn.c. * src/gtk/x11lgndx.c (get_radio_index): moved from x11dialg.c. 2011-04-03 Ito Hiroyuki * src/ofile.c (f2dsettings): fix infinite loop. * src/gtk/gtk_common.h (CAIRO_COORDINATE_OFFSET): always 0. * src/gtk/main.c (main): don't call "gtk_set_locale()" when version of the GTK+ is greater than 2.24. * src/gtk/x11gui.c (DialogExecute): use "gtk_widget_hide()" instead of "gtk_widget_hide_all()". * src/gtk/x11dialg.c (SetObjFieldFromWidget) (SetWidgetFromObjField): use "gtk_combo_box_get_has_entry()" when version of the GTK+ is greater than 2.24. * src/gtk/x11view.c (ViewerWinSetup, ShowCrossGauge, SetHRuler) (SetVRuler): use "gdk_window_get_width()" and "gdk_window_get_height()" when version of the GTK+ is greater than 2.24. (ChangeDPI, draw_paper_frame): use "gdk_pixmap_get_size()" when version of the GTK+ is greater than 2.24. * src/gtk/ogra2x11.c (gtkchangedpi): use "gdk_pixmap_get_size()" when version of the GTK+ is greater than 2.24. * src/gtk/x11graph.c (CmHelpAbout): don't call "gtk_about_dialog_set_url_hook()" when version of the GTK+ is greater than 2.24. * src/gtk/gtk_subwin.c (sub_window_minimize): use "gtk_widget_hide()" instead of "gtk_widget_hide_all()". * src/gtk/gtk_combo.c (combo_box_entry_create): use "gtk_combo_box_new_with_entry()" and "gtk_combo_box_set_entry_text_column()" when version of the GTK+ is greater than 2.24. * src/gtk/gtk_ruler.c (nruler_make_pixmap): use "gdk_pixmap_get_size()" when version of the GTK+ is greater than 2.24. 2011-04-01 Ito Hiroyuki * src/gtk/x11menu.h (Viewer): change type of members "VRuler" and "HRuler". * src/gtk/gtk_ruler.c (_Nruler): remove member "widget". (ruler_new): call "g_object_set_data()" to save data. (nruler_set_range, nruler_set_position): use "g_object_get_data()" to get data. (nruler_make_pixmap, nruler_draw_ticks): add parameter "widget". (nruler_draw_ticks): remove redundant call of the function "pango_layout_get_extents()". * src/gtk/gtk_common.h (CAIRO_COORDINATE_OFFSET): always 1. * src/gtk/x11view.c (coord_conv_x, coord_conv_y): add CAIRO_COORDINATE_OFFSET. * src/gtk/ogra2x11.c (clear_pixmap): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". * src/gtk/x11lgnd.c (draw_arrow_pixmap, LegendArrowDialogPaint): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". * src/gtk/ogra2cairofile.c (create_cairo): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". * src/gtk/x11lgndx.c (LegendGaussDialogPaint): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". 2011-03-31 Ito Hiroyuki * src/gtk/x11view.c (mouse_down_zoom): improve calculation of dpi. (ChangeDPI): remove parameter. (create_legend1, create_path, create_legend3, create_legendx) (create_single_axis, create_axis): call "UpdateAll()". (ViewerEvLButtonDblClk): don't call "UpdateAll()". * src/gtk/x11opt.c (CmOptionViewer): simplify condition. 2011-03-30 Ito Hiroyuki * src/gtk/Makefile.am (libngraph_la_SOURCES): add "gtk_ruler.c" and "gtk_ruler.h". * src/gtk/gtk_ruler.h: added. * src/gtk/gtk_ruler.c: added. * src/gtk/ox11menu.h (menulocal): remove unused members "scrollx", "scrolly", "pixel_dot", "offsetx" and "offsety". * src/gtk/ox11menu.c (mx_redraw): call "draw_paper_frame()" after call "mxflush()". (mx_clear): use "Menulocal.local->cairo". (mx_clear): use "cairo_paint()" when clear whole drawing area. * src/gtk/x11view.c (ViewerEvSize): remove unused codes. (ViewerEvPaint): use "nround()" to get coordinate. (SetHRuler, SetVRuler): use "nruler_set_range()" instead of "gtk_ruler_set_range()". (create_pix): size of the pixmap is now "(w + 1) x (h + 1)". (create_pix): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". (create_pix): don't call "draw_paper_frame()". (ChangeDPI): size of drawing area is now "(w - 1) x (h - 1)". (draw_paper_frame): use "gdk_drawable_get_size()" to get size of the pixmap. (draw_paper_frame): call "cairo_reset_clip()" before drawing. * src/gtk/x11menu.h (Viewer): change type of members "VRuler" and "HRuler". remove unused members "width" and "height". * src/gtk/x11menu.c (setupwindow): use "hruler_new()" and "vruler_new()". (SetPoint): use "nruler_set_position()" instead of "g_object_set()". * src/gtk/ogra2gdk.c (gra2gdk_create_pixmap): use "cairo_paint()" instead of "cairo_rectangle()" and "cairo_fill()". 2011-03-28 Ito Hiroyuki * src/gtk/x11view.c (SetHRuler, SetVRuler): keep position of the ruler. 2011-03-25 Ito Hiroyuki * src/gtk/x11view.c (ViewerWinSetup): initialize "d->KeyMask". (Evaluate, Trimming, Match, DelList, GetLargeFrame) (coord_conv_x, coord_conv_y, GetFocusFrame, ShowFocusFrame) (show_focus_line_arc, draw_frame_rect, draw_focus_line) (ShowFocusLine, ShowPoints, ShowFrameRect, ShowCrossGauge): add parameter "struct Viewer *" or "const struct Viewer *". (mouse_down_move_data): remove unused parameter "TPoint *dpoint". (ViewerWinUpdate): remove unused parameter "int clear". (ShowFocusLine, show_focus_line_arc): remove unused parameter "int clear" and "unsigned int state". (show_focus_line_arc): remove unused variable "clear". (ViewerEvMouseMove, ViewerEvButtonDown, ViewerEvButtonUp): save "d->KeyMask". * src/gtk/x11menu.h (struct Viewer): add member "KeyMask". * src/gtk/x11menu.c (set_focus_sensitivity): change type of the parameter to "const struct Viewer *". 2011-03-24 Ito Hiroyuki * src/gtk/ox11menu.c (mx_show_lib_version): show version of the readline library and GSL. * src/gtk/x11print.c (CmPrintDataFile): update progress dialog. 2011-03-23 Ito Hiroyuki * src/gtk/x11print.c (CmOutputViewer): execute "present" field of the "gra2gtk" object. * src/gtk/ox11menu.c (menuinit): use "gra2cairo_set_antialias()" to set antialias. (mx_show_lib_version): added. (gtkmenu): add field "lib_version", remove fields "GTK_compile_version" and "GTK_runtime_version". * src/gtk/x11view.c (draw_paper_frame): use "CAIRO_COORDINATE_OFFSET". (ViewerEvLButtonDown, ViewerEvRButtonDown, CmViewerButtonArm): call "gtk_widget_queue_draw()". (ViewerEvMouseMove): call "gtk_widget_queue_draw()" when "d->Mode & POINT_TYPE_DRAW_ALL"is true. (create_pix): use "gra2cairo_set_antialias()" to set antialias. * src/gtk/x11lgndx.c (LegendGaussDialogPaint): use "CAIRO_COORDINATE_OFFSET". * src/gtk/x11lgnd.c (draw_arrow_pixmap, LegendArrowDialogPaint): use "CAIRO_COORDINATE_OFFSET". * src/gtk/gtk_common.h (CAIRO_COORDINATE_OFFSET): added. * src/gtk/ogra2x11.c (gtkpresent): added. (gra2gtk): add field "present". (gtkMakeRuler): use "CAIRO_COORDINATE_OFFSET". 2011-03-22 Ito Hiroyuki * src/gtk/x11print.c (CmOutputViewer): range of color is 0.0 to 1.0. * src/gtk/ox11menu.h (menulocal): remove members "win", "gc" and "do_not_use_arc_for_draft". (menulocal): change type of members "bg_r", "bg_g" and "bg_b" from int to double. * src/gtk/x11lgnd.c (draw_arrow_pixmap, LegendArrowDialogPaint): use cairo to draw graphics. * src/gtk/ox11menu.c (MenuConfigViewer): remove setting "do_not_use_arc_for_draft". (add_color_to_array, menu_config_set_bgcolor): range of color is 0.0 to 1.0. (mx_redraw): call "draw_paper_frame()" before call "GRAredraw()". (mx_redraw, mxdpi, mxclear): use "NgraphApp.Viewer.gdk_win" instead of "Menulocal.win". (mx_clear): use cairo to draw graphics. * src/gtk/x11view.c (GRAY, DOT_LENGTH, create_cairo) (draw_cairo_arc): added. (paste_cb, text_dropped, mouse_down_point, init_zoom) (mouse_down_move, mouse_up_point, mouse_up_drag, mouse_up_zoom) (mouse_up_change, mouse_up_lgend1, mouse_up_lgend2) (update_frame_rect, mouse_move_drag, mouse_move_zoom) (mouse_move_change, mouse_move_draw, ViewerEvMouseMove) (ViewerEvKeyDown, ViewerEvKeyUp, UnFocus, Draw, ViewUpdate) (ViewCopy, ViewCross): don't call "ShowFocusFrame()", "ShowPoints()", "ShowFocusLine()", "ShowFrameRect()" or "ShowCrossGauge()". (ShowFocusFrame, show_focus_line_arc, draw_frame_rect) (draw_focus_line, ShowFocusLine, ShowPoints, ShowFrameRect) (ShowCrossGauge, ViewerEvPaint, create_pix, draw_paper_frame): use cairo to draw graphics. (ViewerEvPaint): always redraw pixmap. (ViewerEvMouseMove): call "gtk_widget_queue_draw()" if necessary. (show_focus_line_arc, draw_focus_line): call "cairo_close_path()" if necessary. (draw_focus_line): add parameter "close_path". (ViewDelete): fix memory leak. * src/gtk/gtk_common.h: include "cairo/cairo.h". * src/gtk/x11opt.c (ViewerDialogSetupItem, ViewerDialogClose): range of color is 0.0 to 1.0. * src/gtk/x11lgndx.c (LegendGaussDialogPaint): use cairo to draw graphics. (LegendGaussDialogPaint): change background color depend on the setting. * src/gtk/ogra2x11.c (gtklocal): change type of members "bg_r", "bg_g" and "bg_b" from int to double. (gtklocal): remove member "gc". (gtkevpaint, gtkMakeRuler): use cairo. (clear_pixmap): added. (gtkclear, gtkchangedpi): use "clear_pixmap()". (get_color): return 0.0 to 1.0 instead of 0 to 255. * src/gtk/ogra2gdk.c (gra2gdk_create_pixmap): change type of parameters "r", "g" and "b" from int to double. 2011-03-15 Ito Hiroyuki * src/ofit.c (fitpoly, fituser): use enumerate for return code. 2011-03-14 Ito Hiroyuki * src/ofile.c (get_axis_prm): added. (opendata, f2dgetcoord): use "get_axis_prm()". (ofile_create_math_equation, set_const): add constants "AXISX", "AXISY" and "FLINE". * src/gtk/x11commn.c (AxisDel2): use "g_strdup_printf()" instead of "snprintf()". 2011-03-11 Ito Hiroyuki * src/gtk/x11view.c (search_axis_group): added. (ViewUpdate, ViewCopyAxis): use "search_axis_group()". * src/gtk/x11commn.c (get_new_axis_id): added. (AxisDel2): use "get_new_axis_id()". 2011-03-10 Ito Hiroyuki * src/gtk/x11commn.c (AxisDel2): use "get_axis_id()". * src/gtk/x11view.c (ViewUpdate, ViewCopyAxis): use "get_axis_id()". (ViewUpdate): bug fix: id of the axis object to delete is not "aid" but "id" when "type == 'c'". * src/ofile.c (get_axis_id): added. (opendata, f2dgetcoord, f2dsettings, f2dbounding): use "get_axis_id()". 2011-03-09 Ito Hiroyuki * src/gtk/x11view.c (mouse_up_drag): invert logic and fix indent. (ViewerWinUpdate): set and restore "PaintLock". (ViewerWinUpdate): don't check "region" when "d->allclear" is true. 2011-03-08 Ito Hiroyuki * src/ofile.c (ofile_create_math_equation, set_const): add constants "COLX", "COLY", "HSKIP" and "RSTEP". 2011-03-04 Ito Hiroyuki * src/gtk/x11menu.c (ActionEntry): add callback to actions "GraphDrawOrderAction" and "GraphPageSetupAction". * src/gtk/gtk_subwin.h (NgraphActionEntry): moved from "x11menu.c". * src/gtk/x11graph.c (CmGraphLoadB, CmGraphSaveB, CmGraphMenu) (CmHelpMenu): removed. 2011-03-02 Ito Hiroyuki * src/gtk/x11menu.c (application): call "gtk_ui_manager_ensure_update()" after add ui. 2011-03-01 Ito Hiroyuki * src/gtk/x11cood.c (CoordWinUpdate): don't set type to the variable "d->type." * src/gtk/x11lgnd.c (CmLegendWindow): don't set type to the variable "d->type." * src/gtk/x11merge.c (CmMergeWindow): don't set type to the variable "d->type." * src/gtk/x11info.c (create_win, InfoWinUpdate): don't set type to the variable "d->type." * src/gtk/x11axis.c (CmAxisWindow): don't set type to the variable "d->type." * src/math/math_parser.c (parse_argument_list): reallocate memory for arguments if necessary. * src/gtk/x11file.c (CmFileHistory, CmFileNew): call "AddDataFileList()" only when the file is really opened. (update_file_obj_multi): call "AddDataFileList()" when "new_file" is TRUE and the file is really opened. (CmFileOpen): don't call "AddDataFileList()". (CmFileWindow): don't set type to the variable "d->type." * src/gtk/x11view.c (new_file_obj): call "AddDataFileList()" only when the file is really opened. * src/gtk/x11opt.c (PrefScriptDialogClose): call "create_addin_menu()". * src/gtk/x11commn.c (AddDataFileList): check if the file name is valid UTF-8 string or not. (AddDataFileList): call "create_recent_data_menu()". * src/gtk/x11menu.c (show_graph_menu, show_data_menu): removed. (application): call "create_addin_menu()" and "create_recent_data_menu()" after create UI. (create_addin_menu, create_recent_data_menu): remove parameter. (init_ngraph_app_struct): initialize "type" member of each struct. 2011-02-25 Ito Hiroyuki * addin/cal.nsc: fix argument for "menu::show_window". * src/gtk/x11menu.c (ActionEntry): fix callback functions. 2011-02-24 Ito Hiroyuki * src/gtk/x11menu.c (show_ui_definition): use "printfstdout()". * src/gtk/ox11menu.c (mx_get_accel_map): use "putstderr()" and "printfstdout()". * initfile/save_ui_file.nsc: NgraphUI.xml.win is automatically generated. 2011-02-23 Ito Hiroyuki * src/gtk/ox11menu.c (mx_get_ui, mx_get_accel_map): added. (gtkmenu): add fields "get_ui" and "get_accel_map". * src/gtk/x11menu.c (read_keymap_file): read keymap file in the "CONFDIR". (show_ui_definition): added. * initfile/Makefile.am (update_ui_file): add rule. * initfile/save_ui_file.nsc: added. * initfile/NgraphUI.xml.win: added. 2011-02-22 Ito Hiroyuki * initfile/NgraphUI.xml: added. * src/object.c (set_newobj_cb, set_delobj_cb): added. (newobj_alias): call "NewObjCB()" when "NewObjCB" is not NULL. (delobj): call "DelObjCB()" when "DelObjCB" is not NULL. * src/gtk/main.c (set_dir_defs): add setting for "PIXMAPDIR". * src/gtk/x11lgnd.c (CmLegendWindow): type of the first argument is "GtkToggleAction *". (CmLegendWindow): visibility is depend on the state of the action. * src/gtk/x11cood.c (CmCoordinateWindow): type of the first argument is "GtkToggleAction *". (CmCoordinateWindow): visibility is depend on the state of the action. * src/gtk/ox11menu.c (subwindow_show, subwindow_hide): removed. (mx_show_win, mx_hide_win): use "window_action_set_active()". (mx_toggle_win): use "window_action_toggle()". * src/gtk/x11file.c (CmFileHistory): get identifier of the history entry from second argument. (CmFileOpen): check number of instances. (update_file_obj_multi): don't call "set_graph_modified()" when "new_file" is TRUE and "ret" is "IDDELETE". (CmFileWindow): type of the first argument is "GtkToggleAction *". (CmFileWindow): visibility is depend on the state of the action. * src/gtk/x11view.c (ViewerEvPopupMenu, ViewerPopupMenu) (create_menu, create_popup_menu): removed. (ShowFocusFrame): call "set_focus_sensitivity()". (clear_focus_obj): type of the argument is "struct Viewer *". (clear_focus_obj): call "set_focus_sensitivity()". (ViewerPopupMenu): remove unused case. (CmViewerButtonArm): data point button can be default. * src/gtk/x11menu.h (Viewer): remove members "PToolbar", "CToolbar" and "popup_item". * src/gtk/x11menu.c (ActionEntry, create_action_group) (reate_ui_from_file): added. (application): use "GtkUIManager" to make the menu and toolbars. (set_focus_sensitivity, set_btn_press_cb, get_toolbar) (set_toolbar_caption, show_graph_menu, show_data_menu) (check_instance, check_exist_instances) (window_action_set_active, window_action_toggle) (create_action_group): added. (CmReloadWindowConfig): use "window_action_set_active". * src/gtk/x11opt.c (PrefScriptDialogClose): don't update "add-in" menu. * src/gtk/x11graph.c (CmGraphHistory): check "uri" is NULL or not. * src/gtk/x11merge.c (CmMergeWindow): type of the first argument is "GtkToggleAction *". (CmMergeWindow): visibility is depend on the state of the action. * src/gtk/x11info.c (InfoWinUpdate): type of the first argument is "GtkToggleAction *". (InfoWinUpdate): visibility is depend on the state of the action. * src/gtk/dir_defs.h.in (PIXMAPDIR): added. * src/gtk/gtk_subwin.c (sub_window_hide, sub_window_show): static function. (sub_window_set_visibility): added. (sub_window_toggle_visibility): removed. (cb_del): use "window_action_set_active()". * src/gtk/Makefile.am (pixmapdir): added. (dir_defs.h): add pixmapdir setting. * src/gtk/x11axis.c (CmAxisWindow): type of the first argument is "GtkToggleAction *". (CmAxisWindow): visibility is depend on the state of the action. * pixmap/Makefile.am: added. * mingw/windows_make.sed: add command for pixmap directory. * configure.in (AC_CONFIG_FILES): add "pixmap/Makefile". * Makefile.am (SUBDIRS): add directory "pixmap". 2011-02-08 Ito Hiroyuki * src/math/math_basic_function.c (math_func_for): don't set first argument to the memory when the argument is negative value. * src/gtk/ox11menu.c (menuinit): initialize fields "GTK_compile_version" and "GTK_runtime_version". (gtkmenu): add fields "GTK_compile_version" and "GTK_runtime_version". * src/gtk/x11print.c (CmOutputPrinter): use "GTK_CHECK_VERSION()". * src/gtk/x11menu.c (create_graphmenu, create_toolbar): use "GTK_CHECK_VERSION()". * src/gtk/x11lgnd.c (create_character_view): use "GTK_CHECK_VERSION()". * src/gtk/x11dialg.c: use "GTK_CHECK_VERSION()". * src/gtk/gtk_common.h: use "GTK_CHECK_VERSION()". 2011-02-04 Ito Hiroyuki * src/math/math_function.rb: add comment after case labels. * src/math/math_function.h.in: fix indent. 2011-02-03 Ito Hiroyuki * src/gtk/gtk_subwin.c (hide_minimize_menu_item): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/Makefile.am (libngraph_la_CFLAGS): add option "-DGSEAL_ENABLE=1". * src/gtk/ogra2gdk.c (gra2gdk_create_pixmap): check if the variable "drawable" is NULL or not. * src/gtk/x11axis.c (AxisPosDialogRef): removed. (position_tab_create): use "AxisDialogRef()" for "changed" signal. (AxisDialogRef): set empty text when the index of the active item is 0. (position_tab_setup_item, scale_tab_setup_item): add item "none" to the GtkComboBoxEntry widget. * src/gtk/gtk_widget.c (show_color_sel): use "GTK_COLOR_SELECTION_DIALOG_GET_COLOR_SELECTION()". * src/gtk/x11gui.c (DialogExecute, DialogInput, DialogRadio) (DialogCombo, DialogComboEntry, DialogSpinEntry, DialogCheck) (FileSelectionDialog): use "GTK_DIALOG_GET_CONTENT_AREA()". * src/gtk/x11view.c (paste_cb, ViewerWinSetup, create_pix) (OpenGC): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11menu.c (create_markpixmap): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11lgndx.c (clear_view, LegendGaussDialogPaint): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11lgnd.c (draw_arrow_pixmap, LegendArrowDialogPaint): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11gui.c (get_window_geometry): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11file.c (select_color): use "GTK_COLOR_SELECTION_DIALOG_GET_COLOR_SELECTION()". (draw_type_pixbuf): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/ogra2x11.c (gtkinit): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/gtk_subwin.c (sub_window_save_geometry) (sub_window_minimize): use "GTK_WIDGET_GET_WINDOW()". * src/gtk/x11view.c (ViewerWinSetup): use "GTK_WIDGET_SET_CAN_FOCUS()". * src/gtk/gtk_common.h (GTK_WIDGET_GET_WINDOW) (GTK_DIALOG_GET_CONTENT_AREA, GTK_WIDGET_SET_CAN_FOCUS) (GTK_COLOR_SELECTION_DIALOG_GET_COLOR_SELECTION): added. 2011-02-02 Ito Hiroyuki * src/gtk/x11dialg.c (SetObjFieldFromWidget) (SetWidgetFromObjField, SetObjFieldFromStyle) (SetStyleFromObjField): use "gtk_bin_get_child()". * src/gtk/gtk_combo.c (combo_box_entry_create) (combo_box_entry_set_text, combo_box_entry_get_text): use "gtk_bin_get_child()". 2011-02-01 Ito Hiroyuki * zsh/Makefile.am (zsh_DATA): remove settings for gra2ps and gra2wmf. * driver/Makefile.am (ngraphconf_DATA): remove settings for gra2ps and gra2wmf. * debian/ngraph.bash: remove settings for gra2ps and gra2wmf. 2011-01-31 Ito Hiroyuki * test/math_test.nsc: don't create io object every time. * mingw/install.txt: update document. 2011-01-28 Ito Hiroyuki * src/ofile.c (set_data_progress): variable "msgbuf" is not static now. (solve_equation): variable "eq" is not static now. * src/gtk/ox11menu.c (mx_cat): variable "buf" is not static now. * src/gtk/x11view.c (check_focused_obj_type): check variables "axis", "merge", "legend" and "text" are NULL or not. * src/gtk/x11menu.c (find_gra2gdk_inst): remove first parameter. (find_gra2gdk_inst): variable "inxt" is not static now. (find_gra2gdk_inst): remove variable "local" and "onamek". 2011-01-27 Ito Hiroyuki * src/gtk/x11cood.c (CoordWinSetCoord): this function is now reentrant. 2011-01-26 Ito Hiroyuki * src/oaxis.c (get_axis_gauge_num_str): use "GString" to create format string. (get_axis_gauge_num_str): numbering string is now well formated such as "5.0×10^-7@". * src/gtk/x11cood.c (CoordWinSetCoord): use static variable to create information strings. (CoordWinSetCoord, CoordWinUpdate): type of the coordinate window is "SubWin". * src/gtk/x11commn.c (FileAutoScale): use "GString" to create argument string for "auto_scale" field. * src/gtk/x11menu.h (NgraphApp): the type of members "InfoWin" and "CoordWin" is "struct SubWin *". * src/gtk/x11menu.c (application): now "NgraphApp.InfoWin" and "NgraphApp.CoordWin" don't have the member "str". * src/gtk/x11info.c (create_win, InfoWinUpdate): type of the information window is "SubWin". * src/gtk/x11axis.c (AxisDialogFile): use "GString" to create argument string for "get_auto_scale" field. (set_num_format): added. (numbering_tab_set_value): use "set_num_format()". (axis_list_set_val): variable "len" is not used. 2011-01-24 Ito Hiroyuki * src/gra.c (GRAC, _GRAopencallback): use "directfunc". * src/gra.h (directfunc): typedefed. * src/ogra2nul.c (g2nuldone): call "_exeparent()". * src/ogra2.c (gra2done): check number of element of "sarray" when "GC" is not equal to -1. * src/ogra.c (oGRAopen): fix indent. (oGRAdrawparent): add parameter "oGRAargv". (oGRAdraw): "oGRAargv" is local variable now. 2011-01-21 Ito Hiroyuki * src/gtk/x11graph.c (SwitchDialogSetupItem) (switch_dialog_top_cb, switch_dialog_last_cb, SwitchDialogUp) (SwitchDialogDown, SwitchDialogClose): use "arraynget_int()". (SwitchDialogSetup): use "arraynget_str()". * src/gtk/x11axis.c (AxisDialogFile): use "arraynget_double()". * src/gtk/x11view.c (mouse_down_move_data, ViewUpdate) (ViewCopyAxis): use "arraylast_int()". (focus_new_insts, mask_selected_data, mouse_down_move_data): use "arraynget_int()". (Evaluate): use "arraynget_double()". * src/gtk/x11file.c (FileDialogFit, FileWinFit): use "arraylast_int()". (move_tab_setup_item): use "arraynget_int()" and "arraynget_double()". (move_tab_set_value, mask_tab_setup_item): use "arraynget_int()". * src/gtk/x11commn.c (AxisDel2, axis_move_each_obj, FitDel) (FitCopy, FitClear, FileAutoScale): use "arraylast_int()". * src/gtk/ox11dlg.c (dlgradio, dlgcombo): use "arraylast_int()". (get_sarray_argument): use "arraynget_int()". * src/ofile.c (opendata, get_fit_obj_id, f2dgetcoord) (f2dsettings, f2dbounding, f2dsave): use "arraylast_int()". * src/oagrid.c (get_grid_prm): use "arraylast_int()". * src/otext.c (textmatch): use "arraynget_int()". * src/oroot.c (obj_save_config_line_style): use "arraynget_int()". * src/orect.c (rectmatch): use "arraynget_int()". * src/opath.c (curvematch): use "arraynget_int()". * src/omerge.c (mergematch): use "arraynget_int()". * src/omark.c (markmatch): use "arraynget_int()". * src/olegend.c (legendmatch): use "arraynget_int()". * src/ogra2.c (gra2done, gra2disconnect): use "arraynget_str()". * src/ogra.c (oGRAdisconnect, oGRAopen): use "arraynget_str()". (oGRAopen): bug fix: use "arraylast_int()" instead of "*(char *)". * src/oaxis.c (get_axis_box, axismatch2, axisautoscalefile): use "arraynget_int()" and "arraynget_double()". (get_reference_parameter, axisadjust): use "arraylast_int()". * src/oarc.c (arcmatch): use "arraynget_int()". * src/nconfig.c (replaceconfig_match, replaceconfig): use "arraynget_int()". * src/object.c (arraynget_int, arraynget_double, arraynget_str) (arraylast_int): added. (getvaluestr): use "arraynget_int()", "arraynget_double()" and "arraynget_str()". (obj_do_tighten): use "arraylast_int()". 2011-01-20 Ito Hiroyuki * src/gtk/gtk_widget.c (show_color_sel): set tooltip text. * src/gtk/x11lgnd.c (LegendMarkCB): added. (CmMarkDel, CmMarkUpdate): use "LegendMarkCB". (legend_dialog_setup_item, LegendMarkDialogMark): use "button_set_mark_image()". (CmLineUpdate, CmRectUpdate, CmArcUpdate, CmMarkUpdate) (CmTextUpdate): don't use the variable "ret". * src/gtk/x11dialg.c (_set_color): set tooltip text. * src/gtk/x11file.c (button_set_mark_image): added. (MarkDialogSetup, plot_tab_setup_item, FileDialogMark): use "button_set_mark_image()". (MarkDialog): check "type". * src/gtk/x11commn.c (SetFileHidden): add braces after "for" statement. * src/gtk/x11merge.c (CmMergeUpdate): don't use the variable "ret". 2011-01-19 Ito Hiroyuki * src/object.h (n_value, N_VALUE): added. * src/object.h: use "N_VALUE *" instead of "char *" for an instance of an Ngraph object and return value of an object field. * src/gtk/ogra2gdk.c: ditto. * src/gtk/ogra2x11.c: ditto. * src/gtk/ogra2gdk.h: ditto. * src/gtk/x11lgndx.c: ditto. * src/gtk/ogra2cairofile.c: ditto. * src/gtk/x11graph.c: ditto. * src/gtk/ogra2gtkprint.c: ditto. * src/gtk/x11menu.c: ditto. * src/gtk/x11menu.h: ditto. * src/gtk/x11commn.c: ditto. * src/gtk/x11view.c: ditto. * src/gtk/x11file.c: ditto. * src/gtk/ox11menu.c: ditto. * src/gtk/ox11dlg.c: ditto. * src/gtk/ox11menu.h: ditto. * src/gtk/main.c: ditto. * src/gtk/x11print.c: ditto. * src/gtk/ogra2cairo.c: ditto. * src/gtk/ogra2cairo.h: ditto. * src/gra.c: ditto. * src/orect.c: ditto. * src/olegend.c: ditto. * src/gra.h: ditto. * src/osarray.c: ditto. * src/olegend.h: ditto. * src/ngraph.h: ditto. * src/ofile.c: ditto. * src/oroot.c: ditto. * src/oroot.h: ditto. * src/oint.c: ditto. * src/ogra2.c: ditto. * src/opath.c: ditto. * src/omerge.c: ditto. * src/ostring.c: ditto. * src/oio.c: ditto. * src/oshell.c: ditto. * src/ofit.c: ditto. * src/otext.c: ditto. * src/osystem.c: ditto. * src/object.c: ditto. * src/oiarray.c: ditto. * src/omath.c: ditto. * src/omark.c: ditto. * src/odraw.c: ditto. * src/odraw.h: ditto. * src/oarc.c: ditto. * src/ogra.c: ditto. * src/odouble.c: ditto. * src/ogra2prn.c: ditto. * src/odarray.c: ditto. * src/ogra2fil.c: ditto. * src/oagrid.c: ditto. * src/oprm.c: ditto. * src/oaxis.c: ditto. * src/ogra2nul.c: ditto 2011-01-17 Ito Hiroyuki * test/math_test_new.dat: add test for the the functions "push", "pop", "unshift" and "shift". * doc/html_ja/math.html: add documents about the functions "push", "pop", "unshift" and "shift". * src/math/math_basic_function.c (math_func_unshift) (math_func_shift, math_func_pop) (math_func_push): added. * src/math/math_function.h.in: add "push", "pop", "unshift" and "shift". * src/math/math_operator.rb: check coments. 2011-01-14 Ito Hiroyuki * src/opath.c (arrowdraw): check if the path should be closed or not. (draw_stroke): last parameter represents that the path should be closed or not. * src/ofile.c (draw_fit, curveoutfile): initialize variable "a". (curveout, curveoutfile): use "FREE_INTP_BUF()". (UPDATE_PROGRESS_LINE_NUM): added. (hskipdata, getdata_sub1, getdataraw): use "UPDATE_PROGRESS_LINE_NUM". 2010-12-24 Ito Hiroyuki * src/gtk/gtk_widget.c (color_button_key_event): added. (create_color_button): the function "color_button_key_event()" is connected to "key-press-event" and "key-release-event". 2010-12-23 Ito Hiroyuki * src/osystem.c (WEB): change url (sourceforge). * src/gtk/x11file.c (FitDialogSetSensitivity): show simple equation when the "type" is FIT_TYPE_POLY and "dim == 1". 2010-10-20 Ito Hiroyuki * src/ntime.c (append_date_str): format string for "%y" is "%02d". * src/gtk/x11lgnd.c (insert_selcted_char): focus entry widget after insert character. 2010-10-19 Ito Hiroyuki * src/object.c (error): add braces after "if" statements. 2010-10-15 Ito Hiroyuki * src/ofile.c (f2dredraw): check the "type" is "PLOT_TYPE_FIT" or not. 2010-10-14 Ito Hiroyuki * src/gtk/x11gui.c (DialogExecute): don't use "data->show_buttons". * src/gtk/x11file.c (MarkDialogSetup): show number of the mark as a tooltip. 2010-10-13 Ito Hiroyuki * addin/legend.tcl (savescript): don't set "fill_A" field. * src/gtk/x11file.c (draw_type_pixbuf): add braces after "if" statement. (create_type_color_combo_box): renamed from "create_type_combo_box()" . (create_type_combo_box): create only "type", "mark" and "interpolation" item. (start_editing_type): use "create_type_color_combo_box()". * src/gtk/gtk_liststore.c (create_object_cbox): added. (start_editing_obj): use "create_object_cbox()". 2010-10-07 Ito Hiroyuki * src/gtk/x11file.c (create_type_combo_box): change order of columns. (create_type_combo_box): use "OBJECT_COLUMN_TYPE_STRING", "OBJECT_COLUMN_TYPE_PIXBUF" and "OBJECT_COLUMN_TYPE_INT". (select_color): use "OBJECT_COLUMN_TYPE_INT". * src/gtk/gtk_liststore.h (OBJECT_COLUMN_TYPE_STRING) (OBJECT_COLUMN_TYPE_PIXBUF, OBJECT_COLUMN_TYPE_INT): added. * src/gtk/gtk_liststore.c (start_editing_obj): change order of columns. (start_editing_obj): use "OBJECT_COLUMN_TYPE_STRING", "OBJECT_COLUMN_TYPE_PIXBUF" and "OBJECT_COLUMN_TYPE_INT". 2010-10-06 Ito Hiroyuki * src/gtk/x11file.c (create_type_combo_box): show number of a merk type. 2010-09-22 Ito Hiroyuki * src/gtk/x11file.c (file_list_set_val): unref pixbuf. * src/gtk/x11commn.c (ProgressDialogFinalize): set NULL to "ProgressBar2". * src/gtk/x11menu.h (NgraphApp):remove members "swin" and "iconpix". * src/gtk/x11menu.c (create_icon): renamed from "createicon()". (create_icon): unref pixbufs. free "list". * src/gtk/gtk_subwin.c (sub_window_create): unref pixbufs. free "list". * src/ofit.c (fitput): use "math_equation_free()" instead of "g_free()". 2010-09-15 Ito Hiroyuki * src/gtk/gtk_widget.c (direction_icon_released): change direction from 360 to 0 or 0 to 360 when an icon is released. * src/gtk/x11lgnd.c (LegendArcDialogSetup): use "create_direction_entry()" instead of "create_spin_entry_type()". 2010-09-13 Ito Hiroyuki * src/ofile.c (put_func, rectout): fix indent. 2010-09-09 Ito Hiroyuki * src/math/math_function.h.in: add functions "cm". * src/math/math_basic_function.c (math_func_rm): added. 2010-09-08 Ito Hiroyuki * src/ntime.c (get_iso_8601_week): added. * src/gtk/main.c (main): don't set "LC_TIME". * src/math/math_basic_function.c (math_func_mjd2year) (math_func_mjd2month, math_func_mjd2day): use "mjd2gd()" in "ntime.c". (math_func_mjd2wday, math_func_mjd2yday): added. 2010-09-07 Ito Hiroyuki * src/oaxis.c (mjd_to_date_str): use "nstrftime()" instead of "strftime()". (get_axis_gauge_num_str): added. (numformat): use "get_axis_gauge_num_str()". * src/oprm.c (gettimeval2): meved from "ntime.c". * src/ntime.c (mjd2gd, append_date_str, nstrftime): added. * src/gtk/x11cood.c (CoordWinSetCoord): use "nstrftime()" instead of "strftime()". 2010-09-03 Ito Hiroyuki * src/ofile.c (lineout, curveout, stairout, draw_fit): set line style attribute when "EXPAND_DOTTED_LINE" is false. * src/gra.c (GRAreopen, _GRAclose, GRAclose, GRAcurvefirst): allocate , free and initialize "gdashlist" and so on only when "EXPAND_DOTTED_LINE" is treu. (GRAdashlinetod): expand dotted line only when "EXPAND_DOTTED_LINE" is treu. * src/gra.h (EXPAND_DOTTED_LINE): added. 2010-09-02 Ito Hiroyuki * src/nstring.c (get_printf_format_str): call "g_strdup()" after check the strings. * src/ofile.c (rectout): initialize "emig" and "emng". * src/gtk/gtk_widget.c (show_color_sel, create_color_button): check "Menulocal.use_opacity". * src/gtk/ogra2cairo.c (gra2cairo_init): initialize "local->use_opacity". (gra2cairo_output): check "local->use_opacity". (use_opacity): added. (gra2cairo): add field "use_opacity". * src/gtk/x11print.c (OutputImageDialogSetupItem): setup "d->use_opacity". (OutputImageDialogSetup): add widget to set "Use opacity". (OutputImageDialogClose): save setting of "d->use_opacity". (CmOutputImage): set opacity setting to "g2wobj". (CmOutputPrinter, CmOutputViewer): save setting of "Menulocal.use_opacity". * src/gtk/ox11menu.h (menulocal): add member "use_opacity". * src/gtk/x11dialg.h (MiscDialog, OutputImageDialog): add member "use_opacity". * src/gtk/ox11menu.c (menuinit): initialize opacity setting. (mxuse_opacity): added. (gtkmenu): add field "use_opacity". * src/gtk/x11dialg.c (_set_color, _putobj_color): check "Menulocal.use_opacity". * src/gtk/x11file.c (select_color): use opacity settings when "Menulocal.use_opacity" is treu. * src/gtk/x11opt.c (MiscDialogSetupItem): setup "d->use_opacity". (MiscDialogSetup): add widget to set "Use opacity". (MiscDialogClose): save setting of "d->use_opacity". * debian/control (Depends): use "${shlibs:Depends}". 2010-09-01 Ito Hiroyuki * src/nstring.c (add_printf_formated_str): free "format2". 2010-08-31 Ito Hiroyuki * src/gtk/x11file.c (select_color): set opacity. 2010-08-30 Ito Hiroyuki * src/ofile.c (f2ddata_buf, f2ddata): use "struct rgba" instead of "int". (file_alpha): added. (file_func): add function "ALPHA". (opendata): use fields "A" and "A2". (dataadd): add parameters "fa" and "a". * src/oaxis.c (axis): rename fields from "gauge_alpha" to "gauge_A" end "num_alpha" to "num_A". * src/oagrid.c (agridinit): initialize field "BA". (draw_background, agriddraw): remove parameter "alpha". (draw_background): use field "BA". (agriddraw): use field "A". (agrid): add field "BA". * src/oarc.c (arcinit): initialize field "stroke_A" and "fill_A". (arcdraw): use field "stroke_A" and "fill_A". (arc): add field "stroke_A" and "fill_A". * src/omark.c (markinit): initialize field "A2". (markdraw): use field "A" and "A2". (mark): add field "A2". * src/opath.c (arrowinit): initialize field "stroke_A" and "fill_A". (draw_stroke, draw_fill): remove parameter "alpha". (draw_stroke): use field "stroke_A". (draw_fill): use field "fill_A". (arrow): add field "stroke_A" and "fill_A". * src/olegend.c (put_color_for_backward_compatibility): set opacity. * src/orect.c (rectinit): initialize field "stroke_A" and "fill_A". (rectdraw): use field "stroke_A" and "fill_A". (rect): add field "stroke_A" and "fill_A". * src/gra.c (GRAmark): remove parameter "alpha". add parameter "fa" and "ba". * src/gtk/gtk_widget.c (show_color_sel, create_color_button): use opacity control. * src/gtk/x11dialg.c (_set_color, _putobj_color): setup opacity. * src/gtk/x11axis.c (opacity_setup): removed. 2010-08-27 Ito Hiroyuki * src/oaxis.c (axisinit): initialize field "gauge_alpha" and "num_alpha". (AxisConfig): add data "alpha", "gauge_alpha" and "num_alpha". (numbering): use field "num_alpha". (draw_gauge): use field "gauge_alpha". (axisdraw): use field "alpha". (axis): add fields "num_alpha" and "gauge_alpha". * src/oarc.c (arcdraw): use field "alpha". * src/omark.c (markdraw): use field "alpha". * src/otext.c (textdraw): use field "alpha". (TextConfig): add data "alpha". * src/opath.c (draw_stroke, draw_fill): add parameter "alpha". (arrowdraw): use field "alpha". * src/ofile.c (f2ddata): add member "alpha". (opendata): use field "alpha". (markout, lineout, curveout, rectout, errorbarout, stairout) (barout, draw_fit): use "fp->alpha". (FileConfig): add data "alpha". * src/oagrid.c (draw_background): add parameter "alpha". (agriddraw): use field "alpha". * src/odraw.c (drawinit): initialize field "alpha". (draw): add field "alpha". * src/orect.c (rectdraw): use field "alpha". * src/gra.c (GRAmark): add parameter "alpha". * src/gtk/x11lgnd.c (init_legend_dialog_widget_member): initialize "d->opacity". (legend_dialog_setup_item): setup "d->opacity". (legend_dialog_close): save opacity. (opacity_setup): added. (LegendArrowDialogSetup, LegendRectDialogSetup) (LegendArcDialogSetup, LegendMarkDialogSetup) (legend_dialog_setup_sub): add widget to set opacity. * src/gtk/x11file.c (plot_tab_setup_item): setup "d->opacity". (plot_tab_create): add widget to set opacity. (plot_tab_set_value): save opacity. * src/gtk/x11lgndx.c (LegendGaussDialogSetupItem): setup "d->opacity". (LegendGaussDialogSetup): add widget to set opacity. (LegendGaussDialogClose): save opacity. * src/gtk/x11axis.c (opacity_setup): added. (GridDialogSetupItem, baseline_tab_setup_item) (gauge_tab_setup_item, font_tab_setup_item): setup "d->opacity". (GridDialogSetup, baseline_tab_create, gauge_tab_create) (font_tab_create): add widget to set opacity. (GridDialogClose, baseline_tab_set_value, gauge_tab_set_value) (font_tab_set_value): save opacity. 2010-08-26 Ito Hiroyuki * src/oprm.c (prmload): don't use the field "num_jfont". (prmload): id of path object is not "pid" but "cid" when the type of the instance is "PATH_TYPE_CURVE". * src/gra.c (GRAcolor): add argument "alpha". (GRAC): add member "alpha". (GRAdraw): check "GRAClist[GC].alpha". * src/gtk/ogra2cairo.c (gra2cairo_output): use "cairo_set_source_rgba()" when the value "alpha" is less than 255. 2010-08-25 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo_output): now 7th argument of "C" command means not only fill method but stroke. * src/oarc.c (get_pos): removed (arcdraw): use 7th argument of "C" command to draw stroke. 2010-08-19 Ito Hiroyuki * src/gra.c (GRAdrawtext, GRAtextextent): consider subscript strings for the calculation of new line position. 2010-08-18 Ito Hiroyuki * src/gra.c (GRAdrawtext, GRAtextextent): use "case" instead of "if". (GRAtextextent): bug fix: fix calculation of bounding box when "c[j] == '\n" and "scriptf != 0". (GRAtextextent, GRAtextextentraw): fix calculation of space. (get_str_bbox): fix treatment of '\' character. * src/gtk/ogra2cairo.c (gra2cairo_output): fix treatment of '\' character. 2010-08-17 Ito Hiroyuki * src/gtk/x11commn.c (LoadNgpFile, LoadPrmFile): call "set_axis_undo_button_sensitivity()". * src/gtk/x11graph.c (CmGraphNewMenu): call "set_axis_undo_button_sensitivity()". * src/gtk/gtk_liststore.c (list_store_set_align): added. * src/gtk/x11axis.c (axis_list_set_val): use "%g" instead of "%.2e" for format string of the function "snprintf()". (CmAxisWindow): call "list_store_set_align()" for columns AXIS_WIN_COL_MIN, AXIS_WIN_COL_MAX and. AXIS_WIN_COL_INC. 2010-07-16 Ito Hiroyuki * initfile/Ngraph.nsc: -n option works after all other options are managed. 2010-07-13 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_dialog_close): save color of "d->color". 2010-07-09 Ito Hiroyuki * src/omath.c (math): remove fields "m00" to "m19". (mlocal): remove member "idpm". (msettbl, minit, mparam): now memories are not used. * src/math/math_basic_function.c (MATH_FUNCTION_MEMORY_NUM): added. (init_memory): added. (math_func_rm, math_func_m, math_func_for): use static variable "Memory". * src/math/math_equation.c (math_equation_clear): don't initialize "eq->memory". * src/math/math_equation.h (_math_equation): remove member "memory". * src/gtk/x11lgnd.c (create_character_panel): use "Menulocal.char_map". * src/gtk/ox11menu.c (MenuConfig): use "character_map" instead of "greece_character", "mathematics_character", "physics_character" and "misc_character". (save_char_map_config, menu_config_set_char_map): added. (menu_save_config_sub, mgtkloadconfig): add case for "MENU_CONFIG_TYPE_CHARMAP". (menulocal_finalize): free "Menulocal.char_map". 2010-07-08 Ito Hiroyuki * src/gtk/ox11menu.h (menulocal): add members "greece_char", "mathematics_char", "physics_char" and "misc_char". * src/gtk/ox11menu.c (MenuConfigMisc): "browser" and "help_browser" ins member of miscellaneous settings menu. (MenuConfig): append character selection data. * src/gtk/x11opt.c (FontSettingDialogClose): free returned string from the function "list_store_get_string()". * src/gtk/x11lgnd.c (insert_selcted_char, create_character_view) (create_character_panel): added. (LegendTextDialogSetup): append character selection panel. 2010-07-07 Ito Hiroyuki * initfile/Ngraph.ini.win: add alternative fonts settings. * src/gtk/ogra2cairo.c (free_font_map): free "d->alternative". (create_font_map): add 3rd argument "alternative". (gra2cairo_save_config): save alternative fonts. (loadconfig): load alternative fonts. (gra2cairo_add_fontmap): don't duplicate font names. (gra2cairo_set_alternative_font): added. (loadfont): use alternative fonts. * src/gtk/x11dialg.h (FontSettingDialog): added. * src/gtk/x11opt.c (FontSettingDialogSetupItem) (AlternativeFontListSelCb, get_font_family) (FontSettingDialogAddAlternative) (FontSettingDialogRemoveAlternative) (FontSettingDialogDownAlternative) (FontSettingDialogUpAlternative, FontSettingDialogSetup) (FontSettingDialogClose, FontSettingDialog): added (get_font_alias): type of the parameter is "struct FontSettingDialog *". (PrefFontDialogUpdate, PrefFontDialogAdd): use "FontSettingDialog". (PrefFontDialogSetupItem, PrefFontDialogSetup): show alternative fonts. 2010-07-02 Ito Hiroyuki * src/nstring.c (getitok, getitok2): type of the 3rd parameter is "const char *". (add_printf_formated_str): type of the 1st parameter is "GString *". * src/otext.c (textprintf): use "GString *" instead of "char *". * src/gra.c (GRAexpandobj, GRAexpandpf): use "GString *" instead of "char *". 2010-07-01 Ito Hiroyuki * src/ioutil.c (getrelativepath): use "GString *" instead of "char *". * src/gra.c (GRAexpandmath): use "GString *" instead of "char *". * src/ofile.c (f2dhead, f2dsave): use "GString *" instead of "char *". * src/oroot.c (osave): use "GString *" instead of "char *". * src/odraw.c (pathsave): use "GString *" instead of "char *". * src/oaxis.c (axis_save_group): use "GString *" instead of "char *". * src/ogra2prn.c (gra2p_output): use "GString *" instead of "char *". * src/shellcm.c (cmeval, cmread, cmdexpr): use "GString *" instead of "char *". * src/gtk/ogra2cairo.c (gra2cairo_output): use "g_unichar_to_utf8()"instead of "iso8859_to_utf8()". * src/gra.c (GRAtextextent, get_str_bbox): use "g_string_append_unichar()" (GRAdrawtext): convert string such as "\x31" to unicode character. * src/strconv.c (iso8859_to_utf8): removed. 2010-06-30 Ito Hiroyuki * src/gtk/x11dialg.c (set_entry_from_obj_point): use "GString *" instead of "char *". * src/gtk/x11file.c (load_tab_set_value): use "GString *" instead of "char *". * src/gtk/x11view.c (eval_dialog_copy_selected) (CopyFocusedObjects): use "GString *" instead of "char *". * src/gra.c (GRAtextextent, GRAexpandtext): use "GString *" instead of "char *". * src/ogra2nul.c (g2nul_strwidth): added. (g2nul_charwidth): removed. (gra2null): remove "_charwidth" field, add "_strwidth" field. * src/ogra.c (oGRAopen): use "_strwidth" field instead of "_charwidth" field. * src/gra.c (GRAC): remove "charwidth" member, add "strwidth" member. (_GRAopen, GRAopen): initialize "strwidth" member. (GRAstrwidth): added. (GRAcharwidth): removed. (GRAtextextent, GRAtextextentraw, get_str_bbox): use "GRAstrwidth()" instead of "GRAcharwidth()". * src/gtk/x11opt_proto.h (CREATE_NAME): call "gtk_scrolled_window_set_policy()". * src/gtk/ogra2cairo.c (gra2cairo): remove "_charwidth" field, add "_strwidth" field. (gra2cairo_strwidth): added. (gra2cairo_charwidth): removed. * src/gtk/ogra2cairofile.c (gra2cairofile): remove "_charwidth" field, add "_strwidth" field. * src/gtk/ogra2x11.c (gra2gtk): remove "_charwidth" field, add "_strwidth" field. 2010-06-28 Ito Hiroyuki * src/oprm.c (prminit, prmload): the field "symbol_greek" in not used now. (remarkconv): use UTF-8 string. (prm): the field "symbol_greek" is removed. * src/omerge.c (mergeinit, mergedraw, mergebbox): the field "symbol_greek" in not used now. * src/gra.c (GRAexpandtext, GRAdrawtext, GRAtextextent) (get_str_bbox): use "g_ascii_isxdigit()" instead of "isxdigit()". (GRAtextextent): use "g_ascii_xdigit_value()". (get_str_bbox): added. (GRAboundingbox): use "get_str_bbox()". (GRAinputold): just convert string from Shift-jis to UTF-8 when the variable "code" is 'K'. * src/gtk/x11dialg.h (MergeDialog, PrmDialog): the member "greek_symbol" is removed. * src/gtk/x11graph.c (PrmDialogSetup, PrmDialogClose): the field "symbol_greek" in not used now. * src/jnstring.c: removed. 2010-06-25 Ito Hiroyuki * initfile/Ngraph.ngp: change font settings. * initfile/Ngraph.ini.win: change font settings. * initfile/Ngraph.ini.in: change font settings. * driver/ngp2.in: remove "-wmf" option. * driver/Makefile.am (ngraphconfdir): gra2ps and gra2wmf are not used now. * src/ogra2nul.c (g2nul_charwidth, g2nul_charheight): check backward compatibility. (addgra2null): initialize "FontDataHash". * src/oaxis.c (AxisConfig): remove configuration "num_jfont", add configuration "num_font_style". (axisinit): "jfont" field does not exist now. (axis): add field "num_font_style". * src/jnstring.c (njis2jms, njms2euc, neuc2jms): removed. * src/shellcm.c (cmdexpr): remove old math related codes. * src/mathcode.c: remove old math related codes. * src/omath.c: remove old math related codes. * src/object.c (getargument): remove old math related codes. * src/otext.c (TextConfig): remove configuration "jfont". add configuration "style". (textinit): "jfont" field does not exist now. (textgeometry): check value of "style" field. (text): add field "style". * src/ofit.c: remove old math related codes. * src/mathfn.c: remove old math related functions. * src/opath.c (draw_stroke): arr parameter "intp". * src/shell.c (str_calc): remove old math related codes. * src/ofile.c: remove old math related codes. * src/gra.c (FONT_STYLE_NORMAL, FONT_STYLE_BOLD) (FONT_STYLE_ITALIC): added. (GRAC): add member "style". (GRAdraw, GRAcharwidth, GRAcharascent, GRAchardescent) (GRAtextstyle): 4th argument of the "H" command represents style of the font. (GRAoutkanji): removed. (GRAexpandmath): remove old math related codes. (GRAexpandtext): use "case" statement. (GRAdrawtext, GRAtextextent): add format command "\B", "\I" and "\N". (GRAtextextent, GRAtextextentraw): don't check "kanji" code. (GRAinputold): convert argument of the "S" command Shift-JI to UTF-8. * src/ioutil.c (getrelativepath): "cwd2" may not be Shift-JIS code. * src/gtk/ogra2cairo.h (compatible_font_info): added. * src/gtk/ogra2cairo.c (check_type, gra2cairo_get_font_type_str): removed. (create_font_map): don't save type, symbol and twobyte. (gra2cairo_save_config): save "font" configurations. remove "font-map" configurations. (loadconfig): load "font" configurations. (loadconfig): load "font-map" configurations only when the "font" configuration related to the font is not loaded yet. (init_conf): don't initialize "FontFace". (gra2cairo_update_fontmap, gra2cairo_add_fontmap): remove parameter "type" and "two_byte". (gra2cairo_done): save configurations when old configurations are used. (gra2cairo_get_compatible_font_info): add. (loadfont): add parameter "font_style" and "symbol". (loadfont): set weight and style every time. (gra2cairo_output): use UTF-8 in the 'S' command. (gra2cairo_charwidth): use "gunichar" instead of "char *". (addgra2cairo): initialize "CompatibleFontHash". * src/gtk/main.c (get_obj_font_list): remove japanese specified codes. * src/gtk/x11dialg.h (AxisFont, LegendDialog): add member "font_bold" and "font_italic". * src/gtk/x11lgnd.c (LegendTextCB): remove japanese specified settings. (init_legend_dialog_widget_member): remove "d->jfont", add "d->font_bold" and "d->font_italic". (get_font, set_font): get and set font style settings. (set_fonts): remove. (legend_dialog_setup_item, legend_dialog_close) (legend_dialog_setup_sub, legend_list_set_property): remove japanese specified settings. (legend_dialog_setup_item, legend_dialog_close) (legend_dialog_setup_sub): get and set font style settings. * src/gtk/x11dialg.c (SetFontListFromObj) (SetObjFieldFromFontList): remove japanese specified settings. * src/gtk/x11file.c (FitDialogResult): remove old math related codes. (draw_type_pixbuf): add 3rd argument for "GRAtextstyle()". * src/gtk/x11view.c (CopyFocusedObjects, focus_new_insts) (text_dropped): remove japanese specified settings. * src/gtk/x11menu.c (USE_EXT_DRIVER): add. (show_graph_menu_cb, create_graphmenu, create_preferencemenu): external driver menu is not shown. * src/gtk/x11opt.c (PrefFontDialogSetupItem) (create_font_selection_dialog): don't save font type. (create_font_selection_dialog) (set_font_from_font_selection_dialog): remove japanese specified settings. (set_font_from_font_selection_dialog): remove settings related to font type. (PrefFontDialogSetup): don't show the style of the font. * src/gtk/x11merge.c (MergeDialogSetupItem, MergeDialogSetup) (MergeDialogClose): remove japanese specified settings. * src/gtk/x11axis.c (font_tab_set_value, font_tab_setup_item) (font_tab_create): remove japanese specified settings. (font_tab_set_value, font_tab_setup_item, font_tab_create): add font style settings. * demo/encodeing.ngp: remove. * demo/demo5a.ngp: change font settings. * demo/demo5b.ngp: change font settings. * demo/demo5c.ngp: show muliti languages. * demo/demo5d.ngp: change font settings. * demo/demo5e.ngp: change font settings. * demo/demo4.ngp.in: change font settings. * demo/demo3.ngp.in: change font settings. * demo/demo2.ngp.in: change font settings. * demo/demo1.ngp.in: change font settings. * debian/rules: remove configure option "--enable-janese". 2010-06-17 Ito Hiroyuki * src/opath.c (distance, check_point_match, point_match): add. (curvematch): use "point_match()". (get_arrow_pos): use "distance()". 2010-06-16 Ito Hiroyuki * src/opath.c (path_fill_mode): "fill" field accept "true" or "false" . (PATH_FUILL_MODE, path_fill_rule, PATH_FILL_RULE): add. (draw_stroke, draw_fill): add. (arrowdraw): use "draw_stroke()" and "draw_fill()". (put_fill_mode): add. (arrow): use "put_fill_mode()" for "fill" field. (arrow): add "fill_rule" field. * src/gtk/x11lgnd.c (legend_dialog_set_sensitive): sensitivity of the widget "d->fill_rule" is depend on the widget "d->fill". (legend_dialog_setup_item, legend_dialog_close): field name for the widget "d->fill_rule" is "fill_rule". (LegendArrowDialogSetup): add widget "d->fill". 2010-06-11 Ito Hiroyuki * src/opath.c (get_arrow_pos): remove parameter "strict". (arrowdraw, arrowbbox): remove 3rd argument of the function "get_arrow_pos()". 2010-06-10 Ito Hiroyuki * src/opath.c (get_arrow_pos): add strict mode. (arrowdraw, arrowbbox): use strict mode for "get_arrow_pos()" when the type is "PATH_TYPE_LINE". * demo/demo5a.ngp: change position of "path" instances. * src/gtk/x11lgndx.c (LegendGaussDialogSetupItem): use "set_stroke_color()" instead of "set_color()". (LegendGaussDialogClose): use "putobj_stroke_color()" instead of "putobj_color()". 2010-06-09 Ito Hiroyuki * src/gtk/ox11menu.c (graph_modified_sub): call "set_modified_state()". * src/gtk/x11menu.c (set_modified_state): add. 2010-06-04 Ito Hiroyuki * src/oarc.c (arcinit): initialize fields "miter_limit", "join" and "stroke". (get_pos): add. (arcdraw): use "stroke_[RGB]" instead of "[RGB]". (arcdraw): use "stroke", "miter_limit", "join", "fill_[RGB]" and "close_path". (arcbbox): use "stroke" and "close_path". (arc): add fields "fill_[RGB]", "stroke_[RGB]", "close_path" and "stroke". * src/odraw.h (JOIN_TYPE): add. * src/olegend.c (put_color_for_backward_compatibility): add. * src/orect.c (rectdraw): use "fill_[RGB]" and "stroke_[RGB]" instead of "[RGB]2" and "[RGB]". (rectdraw, rectbbox, rectmatch): don't use "frame". use "stroke". (rect_frame, put_color2): add. (rect): add fields "fill_[RGB]", "stroke_[RGB]" and "stroke". * src/gtk/x11dialg.h (LegendDialog): add member "stroke_color". * src/gtk/x11lgnd.c (init_legend_dialog_widget_member): initialize "d->fill_color" and "d->stroke_color". (set_sensitive_with_label): fix typo. (legend_dialog_set_sensitive): set sensitivity of "d->fill_color" and "d->stroke_color". (legend_dialog_setup_item): setup "d->fill_color" and "d->stroke_color". (legend_dialog_close): get value from "d->fill_color" and "d->stroke_color". (fill_color_setup, stroke_color_setup): add. (LegendArrowDialogSetup, LegendRectDialogSetup): use "fill_color_setup()" and "stroke_color_setup()" instead of "color_setup()" and "color2_setup()" respectively. (LegendRectDialogSetup): remove "d->frame" setting. add "d->stroke" setting. (LegendArcDialogSetup): use "fill_color_setup()" and "stroke_color_setup()" instead of "color_setup()" and "color2_setup()" respectively. (LegendArcDialogSetup): add settings for "d->stroke" and "d->close_path". (COLOR_TYPE): add. (legend_list_set_color): support "COLOR_TYPE_FILL" and "COLOR_TYPE_STROKE". (legend_list_set_property): use "COLOR_TYPE_FILL" and "COLOR_TYPE_STROKE". * src/gtk/x11dialg.c (set_fill_color, set_stroke_color) (putobj_fill_color, putobj_stroke_color): add. 2010-06-03 Ito Hiroyuki * src/gtk/x11view.c (create_path): use "goto" statement to handle errors. * src/object.c (newobj_alias): check arguments. 2010-06-02 Ito Hiroyuki * demo/encoding.ngp: use "path" object instead of "line" object. * demo/demo5d.ngp: use "path" object instead of "line" object. * demo/demo5a.ngp: use "path" object instead of "line" object. * demo/demo4.ngp.in: use "path" object instead of "line" object. * demo/demo3.ngp.in: use "path" object instead of "line" object. * demo/demo2.ngp.in: use "path" object instead of "curve" object. * addin/legend.tcl (makescript): use "path" object instead of "line" object. * initfile/Ngraph.ngp (gra::draw_obj): remove "line", "polygon" and "curve" objects. add "path" object. * src/Makefile.am (ngraph_SOURCES): remove "oline.c", "opolygon.c" and "ocurve.c". add "opath.c" and "opath.h". * src/oprm.c (prmload): use "path" object instead of "line", "polygon" and "curve" objects. * src/shellcm.c (cmnew): use object name from the functions"getobjiname()" for "newobj_alias()". * src/object.c (newobj_alias): add. (newobj): use "newobj_alias()". (getobjiname): add. (chkobjilist, getobjilist): use "getobjiname()". * src/gtk/gtk_widget.c (get_widget): add. (spin_entry_set_val, spin_entry_get_val): use "get_widget()". * src/gtk/main.c (obj_add_func_ary): remove "addline", "addcurve" and "addpolygon". add "addpath". * src/gtk/x11dialg.h: remove prototype of unused functions. (LegendDialog):add member "stroke", "path_type" and "close_path". remove member "color2_label". * src/gtk/x11lgnd.c (legendlist): remove "line", "polygon" and "curve" items. add "path" item. (Ldlg): remove "DlgLegendCurve" and "DlgLegendPoly". (LegendType): remove "LegendTypeLine", "LegendTypeCurve", "LegendTypePoly". add "LegendTypePath". (LegendLineCB): show the type of the "path" object. (init_legend_dialog_widget_member): initialize "d->path_type", "d->stroke" and "d->close_path". (set_sensitive_with_labdl): add. (legend_dialog_set_sensitive): use "set_sensitive_with_labdl()". (legend_dialog_set_sensitive): set sensitivity for stroke and fill related widgets. (legend_dialog_setup_item): set up "d->stroke", "d->path_type" and "d->close_path". (legend_dialog_setup_item): call "get_widget()" before call "gtk_range_set_value" and "gtk_entry_set_text()". (width_setup, style_setup, miter_setup, join_setup, color_setup) (color2_setup): save label instead of control widgets. (LegendCurveDialogSetup, LegendCurveDialog, LegendPolyDialogSetup) (LegendPolyDialog, CmCurveDel, CmCurveUpdate, CmCurveMenu) (CmPolyDel, CmPolyUpdate, CmPolygonMenu): removed. (LegendArrowDialogSetup): add control widgets for "d->stroke", "d->fill_rule", "d->path_type" and "d->close_path". (CmLineDel, CmLineUpdate): use "path" object instead of "line" object. (LegendWinLegendUpdate, legend_list_set_property): remove case for "LegendTypeLine", "LegendTypeCurve" and "LegendTypePoly". add case for "LegendTypePath". (legend_list_set_property): show some attributes for "path" object. * src/gtk/x11dialg.c (initdialog): don't initialize "DlgLegendCurve" and "DlgLegendPoly". (SetWidgetFromObjField, SetObjFieldFromWidget) (SetObjFieldFromStyle, SetStyleFromObjField, _putobj_color) (_set_color): call "get_widget()" for the parameter "widget". (SetComboList, SetComboList2): removed. (SetObjFieldFromText, SetTextFromObjField, SetObjFieldFromSpin) (SetSpinFromObjField, SetObjFieldFromToggle) (SetToggleFromObjField, SetObjFieldFromStyle): now these functions are static. * src/gtk/x11view.c (create_legend2): create only "path" object. (create_legendx): create "path" object instead of "curve" object. (ViewerEvLButtonDblClk, ViewerEvRButtonDown): remove case for "LineB", "CurveB" and "PolyB". add case for "PathB". (ViewerEvRButtonDown): "g_object_unref()" should be called outside of the "switch" block. (ViewUpdate): don't check "line", "polygon" and "curve" objects. check "path" object. * src/gtk/x11menu.h (PointerType): remove "LineB", "CurveB" and "PolyB" add "PathB". * src/gtk/x11menu.c (Command2_data): remove "line", "polygon" and "curve" buttons. add "path" button. (create_legendmenu): remove "line", "polygon" and "curve" menu items. add "path" menu item. * src/gtk/x11graph.c (SwitchDialogSetupItem, SwitchDialogSetup): localize. (SwitchDialogSetup): check duplicate item. 2010-06-01 Ito Hiroyuki * src/math/math_basic_function.c (mjd2gd): "mjd" must be an integer. * src/oline.c: removed. * src/ocurve.c: removed. * src/opolygon.c: removed. 2010-05-21 Ito Hiroyuki * src/oaxis.c (anumdirchar): add new settings "oblique1" and "oblique2". (get_num_pos): renamed from "get_num_pos_parallel". (get_num_pos_normal): removed. (get_num_pos_oblique, get_num_ofst_oblique1) (get_num_ofst_oblique2): add. (draw_numbering_normalize): add case for "AXIS_NUM_POS_OBLIQUE1" and "AXIS_NUM_POS_OBLIQUE2". (draw_numbering): add argument "ndir". (draw_numbering): add case for "AXIS_NUM_POS_OBLIQUE1" and "AXIS_NUM_POS_OBLIQUE2". (draw_numbering): use "get_num_pos()" instead of "get_num_pos_normal()" and "get_num_pos_parallel()". (numbering): get field "num_direction". (numbering): "align" is not used when "ndir" is "AXIS_NUM_POS_OBLIQUE1" or "AXIS_NUM_POS_OBLIQUE2". (anumdirput): add case for "AXIS_NUM_POS_OBLIQUE1" and "AXIS_NUM_POS_OBLIQUE2". * src/axis.h (AXIS_NUM_DIR): moved from "oaxis.c". * src/gra.c (GRAexpandmath): show "0" when calculated value is equal to 0. * src/gtk/x11dialg.h (AxisNumbering): add member "align_label". * src/gtk/x11axis.c (num_direction_changed): add. (numbering_tab_create): "change" signal is connected to the function "num_direction_changed()". (numbering_tab_create): initialize "d->align_label". 2010-05-20 Ito Hiroyuki * src/gtk/x11menu.c (SetPoint): don't show the position in the status bar when the widget is not visible. * src/gtk/x11cood.c (CoordWinSetCoord): show date when tyoe of the axis is "AXIS_TYPE_MJD". (CoordWinSetCoord): do nothing when the widget is not visible. 2010-05-19 Ito Hiroyuki * src/ofile.c (opendata, getposition, f2dgetcoord): use "AXIS_TYPE_LINEAR", "AXIS_TYPE_LOG" and "AXIS_TYPE_INVERSE". (get_pos_sub): add. (getposition2): use "get_pos_sub()". 2010-05-18 Ito Hiroyuki * src/gtk/x11menu.c (create_image_outputmenu): change accel path of "Export image" menu items. 2010-05-17 Ito Hiroyuki * src/ofit.c (ERR_SMALL_ARGS, ERR_INVALID_PARAM): remove. (fittypechar): remove some error messages. (bisection, newton, fitsolve): remove. (fit): remove fields "newton" and "bisection". * src/ofile.c (ERR_SMALL_ARGS, ERR_INVALID_TYPE) (ERR_INVALID_PARAM, ERRCONVERGE): add. (f2derrorlist): add error messages. (get_fit_obj_id): add. (fitout): use "get_fit_obj_id()". (bisection, newton): moved from "ofit.c". (solve_equation): add. (calc_equation): add. (file2d): add fields "newton", "bisection" and "calc". 2010-05-15 Ito Hiroyuki * test/math_test_new.dat: add test for functions "mjd2year()", "mjd2month()", "mjd2day()" and "unix2mjd()". 2010-05-14 Ito Hiroyuki * src/otext.c (textprintf): use "add_printf_formated_str()". * src/ofit.c (ERR_SMALL_ARGS, ERR_INVALID_PARAM): add. (fittypechar): add error messages. (fitcalc): variable "eq" is not static. (bisection, newton, fitsolve): add. (fit): add fields "newton" and "bisection". * src/nstring.c (get_printf_format_str, add_printf_formated_str): add. * src/gra.c (GRAexpandmath): use "g_strdup_printf()" instead of "sprintf()". (GRAexpandmath): change format string depend on the value "vd". (GRAexpandpf): use "add_printf_formated_str()". 2010-05-13 Ito Hiroyuki * src/math/math_basic_function.c (mjd2gd, math_func_mjd2year) (math_func_mjd2month, math_func_mjd2day): add. * src/math/math_function.h.in: add functions "mjd2year", "mjd2month" and "mjd2day". * src/gtk/x11graph.c (CmGraphSaveB): call "CmGraphOverWrite()" instead of "CmGraphSave()". * src/gtk/x11menu.c (show_outputmenu_cb, create_outputmenu): remove. (command_data): add member "stock". (Command1_data): use stock items. (show_graph_menu_cb): set sensitivity of the widget "ExtDrvOutMenu". (create_graphmenu): move "Export image", "external _Driver" and "Print preview" menu items from "Output" menu. (create_filemenu): move "Save data" menu item from "Output" menu. (create_windowmenu): move "Draw" and "Clear" menu items from "Output" menu. (createmenu): don't call "create_outputmenu()". (createpixmap): check "data[i].xpm". (createcommand1): call "gtk_tool_button_new_from_stock()" when "cdata->xpm" is NULL. (createcommand1): call "gtk_tool_item_set_homogeneous()". (createcommand2): call "gtk_tool_button_set_stock_id()" when "cdata->img" is NULL. 2010-05-10 Ito Hiroyuki * src/oaxis.c (get_num_ofst_horizontal, get_num_ofst_parallel) (get_num_ofst_normal1, get_num_ofst_normal2): the type of the parameter "aconf" is "const struct axis_config *". (mjd_to_date_str): add parameter "date_format". (draw_numbering_normalize): the type of parameters "aconf" and "font" are "const struct axis_config *" and "const struct font_config *" respectively. (axis): add field "num_date_format". * src/math/math_basic_function.c (math_func_unix2mjd): first argument of the function "mjd()" is "tm->tm_year + 1900". * src/gtk/ogra2cairo.c (draw_str): check if the parameter "str" is NULL or not. * src/gtk/main.c (main): set "LC_TIME" as "C". * src/gtk/x11dialg.h (AxisNumbering):add member "date_format". * src/gtk/x11file.c (FitCB): localize message. * src/gtk/x11axis.c (AxisCB, AxisHistoryCB): localize message. (numbering_tab_set_value, numbering_tab_setup_item) (numbering_tab_create): add settings for date format. 2010-05-08 Ito Hiroyuki * src/oaxis.c (axistypechar): add scale type "MJD". (anumdirchar): use "horizontal" and "parallel1" instead of "normal" and "parallel" respectively. (AxisConfig): remove duplicated member "type". (mjd_to_date_str): add. (numformat): construct whole numbering string. (draw_numbering_normalize, draw_numbering, anumdirput): use "AXIS_NUM_POS_HORIZONTAL" and "AXIS_NUM_POS_PARALLEL1" instead of "AXIS_NUM_POS_NORMAL" and "AXIS_NUM_POS_PARALLEL" respectively. (draw_numbering): remove unused argument "taillen". (draw_numbering): remove unused variable "num". (draw_numbering): move some codes to the function "numformat()". (get_step): add. (numbering): remove unused variables "taillen", "num", "n" and "count". (numbering): use "get_step()". (numbering): move some codes to the function "numformat()". (anumdirput): add. (axis): use "anumdirput" to set value to the field "num_direction". * src/axis.h (AXIS_SCALE_TYPE): meved from "oaxis.c". 2010-05-07 Ito Hiroyuki * src/math/math_basic_function.c (mjd): add. (math_func_mjd): use "mjd()". (math_func_unix2mjd): add. * src/math/math_function.h.in: add function "unix2mjd". add 4th, 5th and 6th arguments to the function "mjd". * src/shellcm.c (dispfield): check first character of a string "enumlist[j]". * src/axis.h (AXIS_SCALE_TYPE): moved from "oaxis.c". * src/object.c (getargument): check first character of a string "enumlist[i]". * src/gtk/main.c (get_obj_enum_list): check first character of a string "enumlist[i]". * src/gtk/x11dialg.c (SetListFromObjField): check first character of a string "enumlist[i]". * src/gtk/x11file.c (FitDialogSetup, create_type_combo_box) (create_type_combo_box): check first character of strings "curvelist[j]" and "enumlist[i]". 2010-04-28 Ito Hiroyuki * src/Makefile.am (ngraph_CFLAGS): add option "-DG_DISABLE_DEPRECATED=1" and "-DG_DISABLE_SINGLE_INCLUDES=1". * src/nconfig.c (replaceconfig, removeconfig): use "n_tmpfile()" and "n_tmpfile_close()". * src/ioutil.c (n_tmpfile, n_tmpfile_close): add. * src/gtk/x11commn.c (AddNgpFileList): use "g_filename_to_uri()". * src/gtk/x11graph.c (CmGraphHistory): use "g_filename_from_uri()". 2010-04-27 Ito Hiroyuki * src/gtk/x11graph.c (PageDialogPage): change sensitivity of labels. (PageDialogSetup): initialize "d->paperheight_label" and "d->paperwidth_label". * src/gtk/x11opt.c (MiscDialogSetupItem): initialize "d->help_browser" and "d->browser". (set_file_in_entry): change title of the dialog. (MiscDialogSetup): add entries to set programs for help browser and web browser. (MiscDialogSetup): change order of frames. (use_external_toggled): toggle sensitivity of labels. (load_file_toggled): add. (ViewerDialogSetup): "load_file_toggled()" is connected to the "toggled" signal. (set_program_name): add. (MiscDialogClose): use "set_program_name()". * src/gtk/x11dialg.h (PageDialog): add member "paperwidth_label" and "paperheight_label". (ExViewerDialog):add member "d_label", "w_label" and "h_label". (ViewerDialog): add member *data_num_label". * src/gtk/gtk_entry_completion.c (entry_completion_set_entry): add. * src/gtk/x11lgnd.c (LegendTextDialogSetup): don't call "gtk_entry_set_completion()". (LegendTextDialogSetup): use "entry_completion_set_entry()" instead of "gtk_entry_set_completion()". * src/gtk/x11file.c (clear_math_completion): remove. (MathTextDialogSetup, math_tab_setup_item, func_entry_focused): use "entry_completion_set_entry()" instead of "gtk_entry_set_completion()". (FileDialogClose, FileDefDialogClose): don't call "clear_math_completion()". 2010-04-26 Ito Hiroyuki * src/jnstring.c (niskanji): conditions are simplified. (niskanji2): use variable "l" to compare length of string. * mingw/install.txt: add document. * src/gtk/x11file.c (MathTextDialogClose): call "gtk_entry_set_completion()" before exit the function except the case of "d->ret == IDLOOP". (math_tab_setup_item): call "gtk_entry_set_completion()". (clear_math_completion): add. (FileDialogClose, FileDefDialogClose): call "clear_math_completion()" before exit the function except the case of "d->ret == IDLOOP". 2010-04-25 Ito Hiroyuki * src/gtk/x11print.c (SvgVersion): change order of SVG version. (OutputImageDialogSetupItem): initialize image export settings. (OutputImageDialogClose): save image export settings. (OutputImageDialogClose): "d->Version" is "TYPE_SVG1_1" when selected version is "SVG version 1.1". * src/gtk/ox11menu.h (menulocal): add image export settings. (SAVE_CONFIG_TYPE): add "SAVE_CONFIG_TYPE_EXPORT_IMAGE". * src/gtk/ox11menu.c (MenuConfigExportImage): add. (MenuConfigArrray): add "MenuConfigExportImage". (menu_save_config): save image export settings. (menuinit): initialize image export settings. * src/gtk/x11menu.c (application): call "menu_save_config()" for "SAVE_CONFIG_TYPE_EXPORT_IMAGE". 2010-04-23 Ito Hiroyuki * mingw/windows_make.sed: add "-lwinspool" option to the variable "LIBS". * src/gtk/x11print.c (OutputImageDialogSetupItem): "d->dpi" and "d->dlabel" are sensitive. * src/gtk/ogra2cairofile.c (create_reference_dc): add. (create_cairo): use "create_reference_dc()" to get reference DC. (create_cairo): call "StartPage()". (gra2cairofile_output): call "cairo_surface_flush()", "cairo_surface_copy_page()" and "EndPage()". 2010-04-21 Ito Hiroyuki * src/gtk/x11menu.c (create_image_outputmenu): add "EMF file" menu item. * src/gtk/x11print.c (OutputImageDialogSetupItem) (OutputImageDialogSetup, OutputImageDialogClose) (CmOutputImage, CmOutputMenu): add case for "MenuIdOutputEMFFile". * src/gtk/x11menu.h (MenuID): add "MenuIdOutputEMFFile". * src/gtk/ogra2cairofile.h (surface_type_id): add "TYPE_EMF". * src/gtk/ogra2cairofile.c (CAIRO_EMF_SCALE): add. (surface_type): add type "emf". (create_cairo, gra2cairofile_output): add case for "TYPE_EMF". 2010-04-20 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_list_build): use "tree_store_prepend()" instead of "tree_store_append()". * src/gtk/x11file.c (delete_file_obj): add. (CmFileHistory, CmFileNew, CmFileClose, update_file_obj_multi) (FileWinFileDelete, FileWinFileUpdate): use "delete_file_obj()". (CmFileWindow): "d->delete" is set as "delete_file_obj". * src/gtk/x11view.c (EvalDialogSetupItem): use "tree_store_prepend()" instead of "tree_store_append()". * src/gtk/x11menu.c (init_ngraph_app_struct): use "memset()". * src/gtk/gtk_subwin.c (update, delete): use "d->delete" instead of "delobj()" if "d->delete" is not NULL. * src/gtk/x11axis.c (CmAxisWindow): "d->delete" is set as "AxisDel". * src/gtk/x11menu.h (SUBWIN_PROTOTYPE): add member "delete". * src/math/math_scanner.h (struct math_token): add member "next". * src/math/math_scanner.c (create_token): use "g_malloc0()" instead of "g_malloc()". * src/math/math_parser.c (parse_expression_list): fix memory leak when the type of the token is "MATH_TOKEN_TYPE_EOEQ". (my_get_token, unget_token, math_parser_parse): use list instead of array. * src/gtk/gtk_liststore.c (tree_store_prepend): add. 2010-04-15 Ito Hiroyuki * src/omath.c (create_func_def_str): use "g_strdup_printf()". * src/ofile.c (EQUATION_NUM): add. (struct f2ddata, set_user_fnc, set_equation): use "EQUATION_NUM". (create_func_def_str): use "g_strdup_printf()". (set_const_all): last argument of "set_const()" for "fp->codex[1]" and "fp->codey[1]" is depend on "fp->type". (f2ddraw): use "set_const_all()" instead of "set_const()". * src/gtk/gtk_common.h (GTK_WIDGET_VISIBLE): use "gtk_widget_get_visible()" if "GTK_WIDGET_VISIBLE" is not defined. 2010-04-13 Ito Hiroyuki * src/gtk/x11file.c (FileDialogCopyAll): remove. (FileDialogClose): remove case "IDCOPYALL" (FileDialogSetup): remove "Copy all" button. (FileDialogSetup): set width of the file preview as 240. 2010-04-06 Ito Hiroyuki * src/gtk/x11menu.c (SUB_WINDOW_STATE, change_window_state_cb): add. (application): "change_window_state_cb()" is connected to the "window-state-event" signal. * src/gtk/gtk_subwin.c (hide_minimize_menu_item): add. (sub_window_create): "hide_minimize_menu_item()" is connected to the "realize" signal. 2010-04-05 Ito Hiroyuki * src/gtk/x11menu.c (create_sub_windows, destroy_sub_windows): add. (application): use "create_sub_windows()" and "destroy_sub_windows()" . * src/gtk/gtk_subwin.c (ev_sub_win_key_down): call "gtk_widget_hide()" instead of "gtk_widget_hide_all()". 2010-04-04 Ito Hiroyuki * mingw/windows.sh: remove "--enable-new_math" option for configure script. 2010-04-01 Ito Hiroyuki * initfile/Ngraph.ini.win: change Japanese fonts. * src/otext.c (text_set_text): treat shift-jis strings. * src/shell.c (getcmdline): treat shit-jis strings. * driver/gra2wmf.c (main): use g_mkstemp() when the version of GLIB is lesser than 2.22. * src/gtk/x11view.c (graph_dropped): add "-f" option for "LoadNgpFile()". (ViewerEvMouseMove, ViewerEvPaint, create_pix): check "Menulocal.gc". * src/gtk/x11opt.c (set_file_in_entry): add. (MiscDialogSetup): use "create_file_entry_with_cb()" instead of "create_text_entry()". (CmOptionSaveNgp): use "naccess()" instead of "access()". * src/gtk/x11merge.c (merge_list_set_val): the filename is always UTF-8. * src/gtk/x11menu.h (NgraphApp): remove member "Message1", and members "Message_pos" and "Message_extra". * src/gtk/x11menu.c (show_file_menu_cb): the filename is always UTF-8. (createpixmap, create_toolbar_pixmap, createicon): remove unused argument "win". (create_message_box): add. (setupwindow): call "gtk_widget_show_all()" and "reset_event()" just after call "gtk_table_attach" for "NgraphApp.Viewer.Win". (SetPoint): use GtkLabel to show the cursor position in the status bar. * src/gtk/x11gui.c (fsok): use "naccess()" instead of "access()". (fsok): use "nstat()" instead of "stat()". (fsok): convert filename string to UTF-8. (fsok): use "g_path_get_dirname()". (file_dialog_set_current_neme): use "getbasename()". (FileSelectionDialog): second argument of "file_dialog_set_current_neme()" has to be converted from UTF-8. * src/gtk/x11graph.c (DirectoryDialogClose, CmGraphHistory): use "nchdir()" instead of "chdir()". (CmGraphHistory): use "g_path_get_dirname()". (about_link_activated_cb, CmHelpHelp): use "system_bg()". * src/gtk/x11file.c (edit_file): add. (FileDialogEdit, CmFileEdit, FileWinFileEdit): use "edit_file()". (file_list_set_val): the filename is always UTF-8. * src/gtk/x11dialg.c (SetObjFieldFromText, SetTextFromObjField): strings are always UTF-8. * src/gtk/x11commn.c (SaveDrawrable): don't write platform information. (check_overwrite, GraphSave): use "naccess()" instead of "access()". (GraphSave): use "nchdir()" instead of "chdir()". (LoadNgpFile): check if the file is readable or not. (LoadNgpFile): the filename is always UTF-8. (CheckIniFile): get home directory from "system" object. (ErrorMessage): use "g_strerror()" instead of "strerror()". * src/gtk/ox11menu.c (menumenu): convert filename string from UTF-8. (menumenu): call "hide_console()" and "resotre_console()" before and after call "application()" respectively. (SetCaption): the filename is always UTF-8. * src/gtk/ogra2cairofile.c (create_cairo, gra2cairofile_output): convert filename string from UTF-8. * src/gtk/main.c (check_console, hide_console, resotre_console): added. (nallocconsole, exec_console): use "g_unlink()" instead of "unlink()". (set_dir_defs, set_path_env): added. (main): don't use third argument. (main): call "g_thread_init()", "gdk_threads_init()" and "gdk_threads_enter()". (main): call "set_dir_defs()" when "WINDOWS" is defined. (main): use "g_getenv()" instead of "getenv()". (main): use "g_get_user_config_dir()". (main): check return value of "exeobj()" for "shell::shell". (get_file_list): use "nstat()" instead of "stat()". * src/gtk/gtk_widget.c (filename_from_utf8, filename_to_utf8): remove. (entry_set_filename, entry_get_filename): don't convert file name. * src/gtk/gtk_subwin.c (start_editing, modify_string): strings are always UTF-8. (sub_window_create): type hint for subwindows are "GDK_WINDOW_TYPE_HINT_UTILITY". (sub_window_create): call "gtk_window_set_transient_for()". * src/shellux.c (testexpand): use "nstat()" instead of "stat()". * src/shellcm.c (cmcd): use "nchdir()" instead of "chdir()". (cmbasename): use "getbasename()" instead of "basename()". (cmdirname): use "getdirname()" instead of "dirname()". * src/shell.c (set_environ): use "g_getenv()" to get environment variable. (unlinkfile): use "g_unlink()" instead of "unlink()". (set_shellevloop): use "g_thread_create()" instead of "pthread_create()". (reset_shellevloop): use "g_thread_join()" instead of "pthread_join()". (readline_thread, nreadline): added. (shget): use "nreadline()" when readline library is available. (puts_localized): added. (shputstdout, shprintfstdout): use "puts_localized()". (getcmdline): convert strings to UTF-8 if the strings are not valid UTF-8. (expand): use "g_unlink()" instead of "unlink()". (expand): use function "strlen()" only once for a loop. (set_env_val, cmdexec, newshell): use "g_getenv()" instead of "getenv()". (proc_in_thread, quote_args): added. (cmdexec): use "g_strerror()" instead of "strerror()". (cmdexec): use "g_thread_create()" and "proc_in_thread()" to execute command. (show_system_error, system_in_thread, system_bg): added. * src/osystem.c (nsystem): add field "compiler". (sysinit): set compiler name. (sysdone, sysunlink): use "g_unlink()" instead of "unlink()". (syscwd): use "nchdir()" instead of "chdir()". * src/oprm.c (prmload): use "naccess()" instead of "access()". * src/omerge.c (mergefile): call "get_utf8_filename()" for filename argument. (mergetime, mergedate): use "nstat()" instead of "stat()". (mergeload): use "naccess()" instead of "access()". * src/oio.c (io_error): use "g_strerror()" instead of "strerror()". * src/ogra2prn.c (gra2p_output): use "g_unlink()" instead of "unlink()". * src/ofile.c (f2dfile): call "get_utf8_filename()" for filename argument. (f2dtime, f2ddate, get_mtime): use "nstat()" instead of "stat()". (f2dload): use "naccess()" instead of "access()". (f2doutputfile): use "g_strerror()" instead of "strerror()". * src/object.c (error2, error22): call "g_locale_from_utf8()" for message string. * src/nconfig.c (unlockconfig, make_backup, copyconfig): use "g_unlink()" instead of "unlink()". (openconfig, writecheckconfig, copyconfig): use "nstat()" instead of "stat()". (writecheckconfig): use "naccess()" instead of "access()". * src/ioutil.c (changefilename): don't check Shit-JIS kanji code. Encodeing of the filename should be UTF-8. (path_to_win): added. (getfullpath): use "get_utf8_filename()". (getdisk): added. (getrelativepath): use "get_utf8_filename()". (get_utf8_filename, get_localized_filename): added. (getbasename): use "g_path_get_basename()". (getdirname): use "g_path_get_dirname()". (nsearchpath): call "g_find_program_in_path()". (nselectdir): use "nstat()" instead of "stat()". (nfopen): use "g_fopen()". (nstat, naccess, nchdir): added. (n_mkstemp): use "g_get_tmp_dir()". * src/common.h (COMPILER_NAME): added. (WINDOWS): define if "__MINGW32__" is defined * initfile/Ngraph.ini.in (help_browser): change format (file name is not included). * driver/wmfapi.c (chk_write): added. (Polygon, Ellipse, Arc, Pie, Chord, SetPixel, SetPolyFillMode) (SetBkMode, SetTextAlign, SetTextCharacterExtra, TextOut) (SetTextColor, Rectangle, MoveTo, LineTo, SelectObject) (DeleteObject, SetWindowOrg, SetWindowExt, CloseMetaFile) (SetMapMode): use "chk_write()" instead of "write()". (CloseMetaFile): don't close the file but call "fseek()". (CreateMetaFile): add argument "dc". (CreateMetaFile): don't open a file. * driver/gra2wmf.c (getboundingbox, draw): use function "strlen()" only once for each loops. (main): use environment variable "NGRAPHCONF" instead of "NGRAPHLIB". (main): use "g_mkstemp_full()" to create temporally file. (main): use "chk_write()" instead of "write()". 2010-03-31 Ito Hiroyuki * driver/gra2ps.c (getboundingbox, draw): use function "strlen()" only once for each loops. (main): use environment variable "NGRAPHCONF" instead of "NGRAPHLIB". * mingw/windows_resource.rc: added. * mingw/windows_make.sed: added. * mingw/windows_demo.sed: added. * mingw/windows.sh: added. * mingw/pango.aliases: added. * mingw/gtkrc: added. * mingw/associate.bat: added. * mingw/Makefile.am: added. 2010-03-19 Ito Hiroyuki * src/gtk/main.c (main): use "g_listenv()" instead of 3rd argument of "main()" function. 2010-03-04 Ito Hiroyuki * src/gtk/x11menu.c (reset_event): change name from "ResetEvent" * Src/Gtk/x11gui.c (message_beep): change name from "MessageBeep" (message_box): change name from "MessageBox". * src/gtk/x11commn.c (allocate_console): change name from "AllocConsole". (free_console): change name from "FreeConsol". * src/gtk/main.c (reset_fifo, nallocconsole, reset_fifo) (nfreeconsole): use "nopen()" and "nclose()". (get_file_list): use "g_dir_open()", "g_dir_read_name()" and "g_dir_close()". * src/gtk/ox11menu.h (DEFAULT_GEOMETRY): change name from "CW_USEDEFAULT". * src/gtk/gtk_entry_completion.c (entry_completion_save) (entry_completion_load): use "nfopen()". * src/strconv.c (str2utf8): use "g_iconv". * src/object.c: change variable name form "GlovalLock" to "Glovallock". * src/nconfig.c (lockconfig, openconfig, make_backup) (replaceconfig, removeconfig, copyconfig): use "nfopen()". * src/ioutil.c (nscandir): use "g_dir_open()", "g_dir_read_name()" and "g_dir_close()". (nscandir): remove 3rd argument. (nopen): use "g_open()". (nfopen): use "g_fopen()". (n_mkstemp): use "g_mkstemp()". * configure.in: check library "pthreadGC2". 2010-02-24 Ito Hiroyuki * src/ofile.c (draw_interpolation): added. (draw_fit): use "draw_interpolation()". 2010-02-23 Ito Hiroyuki * src/math/math_expression.c (math_parameter_expression_new): set errorcode to "err" when the variable "prm" is NULL. * src/ofit.c (ERR_INCONSISTENT_DATA_NUM): added. (fiterrorlist): add error message. (fit_put_weight_func): fix arguments of the function "ofile_create_math_equation()". * src/ofile.c (calc_fit, draw_fit): added. (fitout): use "calc_fit()" and "draw_fit()". (ofile_create_math_equation): add argument "use_const". (set_equation): fix second argument of "set_user_fnc()" from "g" to "h". (set_const): add arguments "const_id" and "need2pass". (f2ddraw): constant "FIRST" for equatiosn "fp->codex[0]" and "fp->codey[0]" is TRUE. 2010-02-22 Ito Hiroyuki * src/ofile.c (fitout): use "calc_weight()" to calculate weight. (calc_weight): added. * src/object.c (moveobj): move object only when id of instances of "sid" and "did" are exist. (_newobj, _delobj, _copyobj): remove. * src/math/math_function.h.in: add functions "prog1" and "prog2". * src/math/math_basic_function.c (math_func_prog1) (math_func_prog2): added. 2010-02-19 Ito Hiroyuki * src/math/math_expression.c (calc): divided by zero is not error. returned value is 'NaN'. 2010-02-18 Ito Hiroyuki * src/math/math_function.h.in: add function "progn". * src/math/math_basic_function.c (math_func_progn): add * src/oaxis.c (numformat, draw_numbering, numbering): use "snprintf()". (draw_numbering): delete argument "num" and add argument "draw". (draw_numbering): print position, direction and numbering value when "draw" is false. (numbering): add argument "draw". (axis_get_numbering): added. (axis): add field "get_numbering". (draw_numbering_normalize): added. (draw_numbering): use "draw_numbering_normalize()". * driver/ngp2.in: add "-d dpi" option. 2010-02-16 Ito Hiroyuki * src/gtk/x11file.c (load_tab_create): type of the spin button "d->load.finalline" is "SPIN_BUTTON_TYPE_INT". 2010-02-15 Ito Hiroyuki * src/ofile.c (ofile_create_math_equation): change name from "create_math_equation()" and this function is now global. (fitout): call "math_equation_parse()", "set_const()" and "math_equation_optimize()" for weight function. * src/ofit.c (fit_put_weight_func): added. (show_eqn_error): added. (fit): check "weight_func". (fitput): use "show_eqn_error()". 2010-02-10 Ito Hiroyuki * src/gtk/x11axis.c (ZoomDialogSetupItem): use "spin_entry_set_val()" . (ZoomDialog): don't initialize "data->zoom". * src/gtk/x11dialg.c (initdialog): initialize "DlgZoom.zoom" 2010-02-05 Ito Hiroyuki * src/gtk/x11commn.c (get_save_opt): return "IDOK" (not "IDCANCEL") when both "fnum" and "mnum" is negative. 2010-02-03 Ito Hiroyuki * src/gtk/gtk_liststore.c (list_store_remove_selected_cb): set cursor on the first selected path. 2010-02-02 Ito Hiroyuki * src/gtk/x11view.c (show_focus_line_arc, ShowPoints): call "gdk_draw_arc()" only when "Menulocal.do_not_use_arc_for_draft" is false. * src/gtk/ox11menu.h (menulocal): add member "do_not_use_arc_for_draft". * src/gtk/ox11menu.c (MenuConfigViewer): add setting related to "do_not_use_arc_for_draft". * src/gtk/x11lgnd.c (renderer_func, column_edited) (column_0_edited, column_1_edited, insert_column) (set_delete_button_sensitivity): added. (points_setup): use "GtkTreeView". (LegendCurveDialogSetup, LegendPolyDialogSetup) (LegendArrowDialogSetup): change layout. * src/gtk/x11dialg.c (SetObjPointsFromText) (SetTextFromObjPoints): use "GtkTreeView". (set_obj_points_from_text, set_entry_from_obj_point): added. (SetObjFieldFromStyle): use "set_obj_points_from_text()" instead of "SetObjPointsFromText()". (SetStyleFromObjField): use "set_entry_from_obj_point()" instead of "SetTextFromObjPoints()". 2010-01-26 Ito Hiroyuki * src/gtk/x11graph.c (DirectoryDialogSetup): use "GtkTable" instead of "GtkHBox". (DirectoryDialogSetup): add current directory label. * src/gtk/x11dialg.h (DirectoryDialog): add member "dir_label". 2010-01-22 Ito Hiroyuki * src/gtk/x11view.c (EvalDialogSetup): set "d->ok_button" as "GTK_STOCK_CLOSE". * src/gtk/x11opt_proto.h (CREATE_NAME): set "d->ok_button" as "GTK_STOCK_CLOSE". * src/gtk/x11gui.c (DialogExecute): initialize "data->ok_button". (DialogExecute): use "data->ok_button" for "ok" button. * src/gtk/x11file.c (MathDialogSetup): set "d->ok_button" as "GTK_STOCK_CLOSE". * src/gtk/x11dialg.h (DIALOG_PROTOTYPE): add member "ok_button". 2010-01-21 Ito Hiroyuki * src/gtk/x11print.c (init_print): added. (CmOutputPrinter): "begin_print" signal is connected to the function "init_print()". (CmOutputPrinter): don't call "gtk_print_operation_set_current_page()". 2010-01-04 Ito Hiroyuki * src/gra.h (CURVE_OBJ_USE_EXPAND_BUFFER): added. * src/ocurve.c (curveinit): initialize "_points" field when "CURVE_OBJ_USE_EXPAND_BUFFER" is TRUE. (curve_expand, curve_expand_points, curve_clear) (curve_set_points, curve_flip, curve_move, curve_rotate) (curve_zoom, curve_change): added. (curve): add field "_points". (curvedraw, curvebbox, curvematch): use "_points" field when "CURVE_OBJ_USE_EXPAND_BUFFER" is TRUE. * src/object.c (arrayclear, arrayclear2): added. 2009-12-25 Ito Hiroyuki * src/ofile.c (file_color): allow negative or greater than 255 for "val". * src/gtk/x11view.c (EvalDialogSetup): call "gtk_scrolled_window_set_policy()". * src/gtk/x11file.c (MathDialogSetup, create_user_fit_frame) (move_tab_create, mask_tab_create, FileDialogSetup): call "gtk_scrolled_window_set_policy()". * src/gtk/ogra2x11.c (gtkinit): call "gtk_scrolled_window_set_policy()". * src/gtk/x11dialg.c (SelectDialogSetup, CopyDialogSetup): call "gtk_scrolled_window_set_policy()". * src/gtk/ogra2x11.c (gtkinit): call "gtk_scrolled_window_set_policy()". * src/gtk/gtk_subwin.c (sub_window_create): call "gtk_scrolled_window_set_policy()". (sub_window_create): call "gtk_window_set_skip_taskbar_hint()" * src/gtk/x11file.c (create_user_fit_frame): initial values and derivative equations are shown in scrolled window. 2009-12-24 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_list_set_val): use "legend_list_set_property()". (legend_list_set_color, legend_list_set_property): added. * src/gtk/x11menu.c (create_toolbar): use "gtk_orientable_set_orientation()" instead of "gtk_toolbar_set_orientation()" is the version of the GTK+ is greater or equal to 2.16. * src/gtk/gtk_subwin.c (set_cell_renderer_cb) (set_editable_cell_renderer_cb, set_combo_cell_renderer_cb) (set_obj_cell_renderer_cb): use "gtk_cell_layout_get_cells()" instead of "gtk_tree_view_column_get_cell_renderers()". * src/gtk/x11file.c (FitDialogSetSensitivity): don't change sensitivity of widgets related to division settings. (FitDialogSetup): don't use "toggled" signal of "d->interpolation". * src/gtk/x11dialg.h (struct FitDialog): remove member "div_box" 2009-12-22 Ito Hiroyuki * src/gtk/x11print.c: initialize "DriverDialogBrowseCB" as NULL when "USE_ENTRY_ICON" is FALSE. (DriverDialogSelectCB): now "ext" of "struct extprinter" is not include ".". * src/gtk/x11opt.c: initialize "SetScriptDialogBrowse" and "SetDriverDialogBrowse" as NULL when "USE_ENTRY_ICON" is FALSE. * src/gtk/gtk_widget.c: initialize "entry_icon_file_select" as NULL when "USE_ENTRY_ICON" is FALSE. 2009-12-18 Ito Hiroyuki * src/gtk/x11file.c (set_user_fit_sensitivity) (create_user_fit_frame): added. (FitDialogSetSensitivity): use "set_user_fit_sensitivity()". (FitDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". (FitDialogResult): call "math_equation_add_parameter()". (FitDialogSave, FitDialogLoad, FitDialogCopy): connected to "clicked" signal. 2009-12-17 Ito Hiroyuki * src/gtk/gtk_widget.c (create_file_entry_with_cb): added. * src/gtk/x11dialg.h (struct FileMath, struct FileLoad) (struct FileMask, struct FileMove): added. (struct FileDialog): add member "math", "load", "mask" and "move" * src/gtk/x11file.c (move_tab_setup_item, move_tab_copy) (move_tab_create, move_tab_set_value, mask_tab_setup_item) (mask_tab_copy, mask_tab_create, mask_tab_set_value) (load_tab_setup_item, load_tab_copy, load_tab_create) (load_tab_set_value, math_tab_setup_item, math_tab_copy) (math_tab_create, math_tab_set_value, file_setup_item) (set_fit_button_label, plot_tab_setup_item, file_settings_copy) (plot_tab_create, file_dialog_show_tab, set_headlines) (plot_tab_set_value): added. (FileDialogSetup): use "set_headlines()". * src/gtk/x11graph.c (PageDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". * src/gtk/x11lgnd.c (LegendLineCB, LegendRectCB, LegendArcCB): use "g_strdup_printf()" instead of "g_malloc()" and "snprintf()". (legend_dialog_set_sensitive): added. (legend_dialog_setup_item): call "legend_dialog_set_sensitive()". (legend_copy_clicked): added. (width_setup, points_setup, style_setup, miter_setup) (join_setup, color_setup, color2_setup, LegendCurveDialogSetup) (LegendPolyDialogSetup, LegendArrowDialogSetup) (LegendRectDialogSetup, LegendArcDialogSetup) (legend_dialog_setup_sub, LegendTextDialogSetup) (LegendTextDefDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". * src/gtk/x11lgndx.c (LegendGaussDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". * src/gtk/x11merge.c (MergeDialogCopy): connected to "clicked" signal. (MergeDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". (MergeDialogClose): remove case for "IDCOPY". * src/gtk/x11opt.c (ViewerDialogSetup, ExViewerDialogSetup) (MiscDialogSetup, SetDriverDialogSetup, SetScriptDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". (SetDriverDialogSetup, SetScriptDialogSetup): use "create_file_entry_with_cb()" instead of "create_text_entry()". (SetScriptDialogBrowse, SetDriverDialogBrowse): connected to "icon-release" signal. * src/gtk/x11print.c (DriverDialogSetup): use "GtkTable" instead of "GtkHBox" or "GtkVBox". (DriverDialogSetup): use "create_file_entry_with_cb()" instead of "create_text_entry()". (DriverDialogBrowseCB): connected to "icon-release" signal. 2009-12-11 Ito Hiroyuki * src/gtk/x11opt.c (MiscDialogSetup): use "GtkTable" instead of "GtkHBox" and "GtkVBox". 2009-12-10 Ito Hiroyuki * src/gtk/x11file.c (select_color): use "ndialog_run()" instead of "gtk_dialog_run()". * src/gtk/gtk_widget.c (show_color_sel): use "ndialog_run()" instead of "gtk_dialog_run()". * src/gtk/x11opt.c (PrefFontDialogUpdate, PrefFontDialogAdd): use "ndialog_run()" instead of "gtk_dialog_run()". * src/gtk/x11gui.c (DialogExecute): use "DnDLock" instead of "GlobalLock". (ndialog_run): added. (DialogExecute, MessageBox, DialogInput, DialogRadio) (DialogCombo, DialogComboEntry, DialogSpinEntry, DialogCheck) (FileSelectionDialog): use "ndialog_run()" instead of "gtk_dialog_run()". * src/gtk/x11menu.c: add gloval variable "DnDLock". * src/gtk/x11view.c (drag_drop_cb): check "DnDLock". * src/gtk/x11lgndx.c (enum LEGEND_DIRECTION) (LEGEND_DIRECTION_NUM): add (LegendGaussDialogPaint, LegendGaussDialogClose): use "switch" instead of "if". (LegendGaussDialogSetup): use "GtkTable" instead of "GtkHBox" and "GtkVBox". * src/gtk/x11dialg.h: add definition of structs "AxisBase", "AxisPos", "AxisFont", "AxisNumbering" and "AxisGauge". (struct AxisDialog): add member "tab", "del_btn", "tab_active", "base", "font", "position", "gauge" and "numbering". * src/gtk/x11dialg.c: remove gloval variables "DlgAxisBase", "DlgAxisPos", "DlgNum", "DlgAxisFont" and "DlgGauge". (SetObjFieldFromWidget): focus the widget when an error is occurred. * src/gtk/x11axis.c (bg_button_toggled): added. (GridDialogSetupItem): call "bg_button_toggled()". (GridDialogSetup): "toggled" signal is connected to "bg_button_toggled()" . (grid_copy_clicked): change name from "GridDialogCopy()". (gauge_syle_setup, GridDialogSetup, SectionDialogSetup) (CrossDialogSetup): use "GtkTable" instead of "GtkHBox" and "GtkVBox". (scale_tab_setup_item, scale_tab_copy_clicked, scale_tab_create) (baseline_tab_set_value, baseline_tab_setup_item) (baseline_tab_copy_clicked, baseline_tab_create) (gauge_tab_set_value, gauge_tab_setup_item) (gauge_tab_copy_clicked, gauge_tab_create) (numbering_tab_set_value, numbering_tab_setup_item) (numbering_tab_copy_clicked, numbering_tab_create) (font_tab_set_value, font_tab_setup_item, font_tab_copy_clicked) (font_tab_create, position_tab_set_value) (position_tab_setup_item, position_tab_copy_clicked) (position_tab_create, axis_dialog_show_tab): added. (AxisDialogSetup): use "GtkNotebook". (scale_tab_set_value): added. (AxisDialogClose): call "gtk_notebook_set_current_page()" when errors are occurred. (AxisDialogSetup): sensitivity of the delete button is depemd on "d->CanDel". * src/gtk/gtk_widget.c (add_widget_to_table_sub) (add_widget_to_table, add_copy_button_to_box): added. 2009-12-05 Ito Hiroyuki * configure.in: set "AM_SILENT_RULES". 2009-11-30 Ito Hiroyuki * src/osystem.c (sysinit): call "gsl_set_error_handler_off()" when "HAVE_LIBGSL" is defined. * src/math/math_basic_function.c (math_func_icgam) (math_func_gamma, math_func_erfc, math_func_beta, math_func_lgn) (math_func_pn, math_func_yn, math_func_jn, math_func_ei): use GSL function when available. (math_func_icbeta, math_func_erf, math_func_zeta) (math_func_zetam1, math_func_zeta_int, math_func_zetam1_int) (math_func_ynu, math_func_jnu, math_func_inu, math_func_knu) (math_func_in, math_func_kn, math_func_yl, math_func_jl): added. 2009-11-26 Ito Hiroyuki * src/omath.c (parse_original_formula): this function is not used if "NEW_MATH_CODE" is not defined. * src/shellcm.c (cmdexpr): variable "err_msg" is always used. * src/gtk/main.c (obj_add_func_ary[]): add "addio". * src/oio.c: added. 2009-11-24 Ito Hiroyuki * src/math/math_equation.c (clear_pos_func_buf): added. (math_equation_clear): use "clear_pos_func_buf()". (math_equation_parse): call "clear_pos_func_buf()" if "eq->pos_func_num" is greater than zero. * src/math/math_basic_function.c (math_func_asin) (math_func_acos): minimum value of "v" is -1 (not 0). (math_func_not): don't have to check "exp->buf[1]". (math_func_gt): comparing condition is ">" (not ">="). (math_func_pn): "x" is "double" (not "int"). (math_func_pn): check maximum value of "x". (math_func_rsort): 3rd argument of the function "qsort" is "sizeof(MathValue)" (not "sizeof(double)"). * src/shell.c (str_calc): set rcode as "MNAN" or "MUNDEF" when "value.type" is "MATH_VALUE_NAN" or "MATH_VALUE_UNDEF" respectively. (str_calc): initialize "value" and "val". 2009-11-23 Ito Hiroyuki * src/math/math_basic_function.c (math_func_acos) (math_func_asin): initialize variable "v". 2009-11-21 Ito Hiroyuki * src/math/math_parser.c (parse_const_def_expression): return NULL when "eq->func_def" is TRUE. (parse_const_def_expression): set and restore "eq->func_def" before and after call the function "parse_expression()". (parse_expression_list): don't call "math_expression_free()" before call "math_equation_set_parse_error()". (parse_expression_list): return NULL when "token->type" is "MATH_TOKEN_TYPE_CONST" and "inside_block" is TRUE. * src/math/math_error.h (MATH_ERROR_INVALID_CDEF) (MATH_ERROR_PRM_IN_DEF): added. * src/math/math_error.c (ERR_MSG_INVALID_C, ERR_MSG_PRM_IN_DEF): added. (ERR_MSG_POS_FUNC): change message. (math_err_get_error_message): add case for "MATH_ERROR_INVALID_CDEF" and "MATH_ERROR_PRM_IN_DEF#. * src/math/math_equation.c (math_equation_get_parameter): add argument "int *err" and set error id when "err" is not NULL. * src/ofile.c (put_func): don't substitute return value of the function "set_equation()" when rcode is TRUE. * src/object.c (ERR_MSG_BUF_SIZE): change buffer size. (error, error2, error22): change maximumlength of an error message. 2009-11-20 Ito Hiroyuki * src/ofile.c (MATH_CONST_NUM): add constant "MASK" and "MOVE". (set_const): set constant "MASK" and "MOVE". 2009-11-17 Ito Hiroyuki * src/math/math_parser.c (parse_primary_expression): return NULL when the type of the token is "MATH_TOKEN_TYPE_EOEQ". * src/gtk/x11commn.c (AddNgpFileList): check if the filename is valid UTF-8 string. * src/gtk/x11menu.c (show_file_menu_cb): change filename to UTF-8. * src/gtk/x11opt.c (SetScriptDialogBrowse) (SetDriverDialogBrowse): use "entry_set_filename()". * src/gtk/gtk_widget.c (entry_icon_file_select): use "entry_set_filename()". * src/gtk/x11opt.c (set_scrpt_file, SetDriverDialogClose): use "entry_get_filename()". * src/gtk/x11dialg.c (SetObjFieldFromText): change filename from UTF-8. * src/gtk/gtk_widget.c (entry_get_filename, entry_set_filename): added. * src/gtk/gtk_subwin.c (modify_string): change filename from UTF-8. * src/gtk/x11merge.c (merge_list_set_val): change filename to UTF-8. * src/gtk/x11gui.c (file_dialog_set_current_neme): change filename to UTF-8. * src/gtk/x11file.c (file_list_set_val): change filename to UTF-8. * src/gtk/x11dialg.c (SetTextFromObjField): change filename to UTF-8. * src/gtk/x11commn.c (check_overwrite, LoadNgpFile): change filename to UTF-8. * src/gtk/ox11menu.c (SetCaption): change filename to UTF-8. * src/gtk/gtk_widget.c (entry_set_filename): change filename to UTF-8. * src/gtk/gtk_subwin.c (file_select, start_editing): change filename to UTF-8. * src/ofile.c (set_data_progress): don't show the filename. * src/gtk/gtk_widget.c (filename_from_utf8, filename_to_utf8): added. 2009-11-16 Ito Hiroyuki * src/nstring.c (nstrdup): remove (use g_strdup instead). * src/object.c (memalloc, memrealloc, memfree): remove (use g_malloc, g_realloc and g_free instead). 2009-11-14 Ito Hiroyuki * src/strconv.h: moved from "src/gtk/strconv.c". * src/strconv.c: moved from "src/gtk/strconv.c". * src/math/math_parser.c (parse_primary_expression) (parse_const_def_expression): "*err" is "MATH_ERROR_EOEQ" when the type of the token is "MATH_TOKEN_TYPE_EOEQ". * src/gtk/strconv.c (utf8_to_sjis, sjis_to_utf8): use "CP932" instead of "shift-jis" 2009-11-12 Ito Hiroyuki * src/omath.c (parse_original_formula): added. (mformula): use "parse_original_formula()". 2009-11-11 Ito Hiroyuki * src/shellcm.c (str_calc): remove. * src/shell.c (str_calc): added. * src/object.c (getargument): use "str_calc()". * src/gra.c (GRAexpandmath): use "str_calc()". * src/ofile.c (put_func): restore old equation when new equation causes error. 2009-11-10 Ito Hiroyuki * src/math/math_parser.c (parse_const_def_expression): set error code. (parse_const_def_expression): fix condition from "token->data.op == MATH_OPERATOR_TYPE_EQ" to "token->data.op != MATH_OPERATOR_TYPE_ASSIGN" 2009-11-07 Ito Hiroyuki * src/gtk/x11commn.c (get_save_opt): return "IDOK" or "IDCANCEL". (GraphSave): return "IDCANCEL" when "get_save_opt()" returns "IDCANCEL". 2009-11-06 Ito Hiroyuki * src/gtk/x11view.c (mouse_down_move_data, move_data_cancel): first argument of "MessageBox()" is NULL. * src/gtk/x11print.c (CmOutputPrinter): first argument of "MessageBox()" is NULL. * src/gtk/x11opt.c (set_scrpt_option, CmOptionSaveNgp): first argument of "MessageBox()" is NULL. * src/gtk/x11menu.c: (static GtkWidget *CurrentWindow) (set_current_window, get_current_window): add (PutStderr): first argument of "MessageBox()" is NULL. * src/gtk/x11gui.c (DialogExecute): save and restore current window. (MessageBox): use "get_current_window()" as parent if "parent" is NULL. * src/gtk/x11commn.c (ErrorMessage): first argument of "MessageBox()" is NULL. * src/math/math_error.c (math_err_get_error_message): convert error message from utf-8 to locale. * src/gtk/x11lgnd.c (pos_edited, width_edited): don't show error message. * src/gtk/x11axis.c (pos_edited_common): don't show error message. (pos_edited_common): change first argument (from "struct objlist *" to "struct SubWin*"). * src/gtk/gtk_widget.c (spin_change_value_cb): don't show error message (because Gtk+ shows following error message). Gtk-WARNING **: GtkEntry - did not receive focus-out-event. If you connect a handler to this signal, it must return FALSE so the entry gets the event as well 2009-11-04 Ito Hiroyuki * src/ofile.c (put_func): change 5th argument from "int type" to "char *field". * src/ofit.c (fitput): use "math_err_get_error_message()". 2009-11-03 Ito Hiroyuki * src/math/math_expression.c (math_constant_definition_expression_new): set error id to "*err" when the constant is already defined. * src/math/math_error.c (ERR_MSG_CONST_EXIST) (ERR_MSG_CALCULATION): added. * src/math/math_equation.c (math_equation_set_const_error) (math_equation_get_const_name): added. (math_equation_add_const_definition): add argument "int *err". * src/math/math_error.c (check_error_position) (math_err_get_error_message, ERR_MSG_FUNC_NEST) (ERR_MSG_UNEXP_OP, ERR_MSG_UNEXP_TOK, ERR_MSG_ARG_NUM) (ERR_MSG_MISS_RP, ERR_MSG_MISS_RC, ERR_MSG_MISS_RB) (ERR_MSG_UNKNOWN_F, ERR_MSG_INVARID_F, ERR_MSG_INVARID_P) (ERR_MSG_MEMORY, ERR_MSG_UNKNOWN, ERR_MSG_POS_FUNC): added. * src/math/math_parser.c (parse_array_expression) (parse_primary_expression, get_argument, create_math_func) (parse_unary_expression, parse_expression) (parse_expression_list): call "math_equation_set_parse_error()", "math_equation_set_func_arg_num_error()" or "math_equation_set_func_error()" when parse error. * src/math/math_equation.h (_struct _math_equation): add member "err_info". * src/math/math_equation.c (math_equation_new): use "memset()" to initialize struct. (math_equation_set_parse_error) (math_equation_set_func_arg_num_error) (math_equation_set_func_error): added. (math_equation_parse): initialize "eq->err_info". * src/gtk/x11lgnd.c (width_edited, pos_edited): add 4th argument for the function "str_calc()". (width_edited, pos_edited): show message on an error. * src/gtk/x11axis.c (pos_edited_common): add 4th argument for the function "str_calc()". (pos_edited_common): show message on an error. * src/gtk/gtk_widget.c (spin_change_value_cb): add 4th argument for the function "str_calc()". (spin_change_value_cb): show message on an error. * src/gtk/gtk_subwin.c (numeric_cb): add 4th argument for the function "str_calc()". * src/shellcm.c (str_calc): add argument "char **err_msg". (str_calc): set error message when "*err_msg" is not NULL. (cmdexpr): show error message created in new math code. * src/ofile.c (put_func): show message on an error. (f2dputmath): don't show error message. 2009-10-27 Ito Hiroyuki * addin/legend.tcl (savescript): move frame rectangle to the top of the instances. (makescript): bug fix: fix typo "in" to "int". 2009-10-22 Ito Hiroyuki * src/ofile.c (struct f2dlocal): add member "total_line", (f2dinit): initialize "f2dlocal->total_line". (set_final_line): added. (check_mtime, getminmaxdata): call "set_final_line()". 2009-10-21 Ito Hiroyuki * src/shellcm.c (str_calc): add code for new math code. * src/omath.c (mlocalclear, minit, mdone): add code for new math code. (create_func_def_str): added. (mformula, mcalc): add code for new math code. * src/ofit.c (fitdone, fitput, fituser): add code for new math code. * src/ofile.c (struct f2ddata_buf): add members "colr2", "colg2" and "colb2" when "NEW_MATH_CODE" is true. (struct f2ddata): add some members when "NEW_MATH_CODE" is true. (struct f2dload): add some members when "NEW_MATH_CODE" is true. (file_color, file_rgb_sub, file_rgb, file_rgb2, file_hsb_sub) (file_hsb, file_hsb2, file_marksize, file_marktype, struct funcs) (add_file_func): added. (opendata, reopendata, f2dputmath): add code for new math code. (create_func_def_str, set_user_fnc, set_equation, put_func): added. (create_math_equation): added. (f2dinit, f2ddone, getdataarray, getdata_get_other_files): add code for new math code. (set_var, set_const, file_calculate, set_const_all): added. (getdata_sub2, getdata_sub1, getdata, getdata2, getdataraw) (getminmaxdata, markout, rectout, barout, fitout, f2ddraw) (f2devaluate, f2dgetdataraw, f2dstat, f2dstat2, f2dboundings) (f2doutputfile): add code for new math code. * src/object.c (getargument): add code for new math code. * src/gra.c (GRAexpandmath): add code for new math code. * src/gtk/x11file.c (FitDialogResult): add code for new math code. * src/math/parse_bin_expression.h: added. * src/math/math_scanner.h: added. * src/math/math_scanner.c: added. * src/math/math_parser.h: added. * src/math/math_parser.c: added. * src/math/math_operator.rb: added. * src/math/math_operator.h.in: added. * src/math/math_operator.h: added. * src/math/math_operator.c: added. * src/math/math_function.rb: added. * src/math/math_function.h.in: added. * src/math/math_function.h: added. * src/math/math_function.c: added. * src/math/math_expression.h: added. * src/math/math_expression.c: added. * src/math/math_error.h: added. * src/math/math_equation.h: added. * src/math/math_equation.c: added. * src/math/math_constant.rb: added. * src/math/math_constant.h.in: added. * src/math/math_constant.h: added. * src/math/math_constant.c: added. * src/math/math_basic_function.c: added. * src/math/Makefile.am: added. * configure.in: add macro for new math code. * src/gtk/x11axis.c (axiswin_scale_clear): call "set_graph_modified()" after call "exeobj()". 2009-10-20 Ito Hiroyuki * src/shell.c (expand): new upstream release (6.3.51). * src/ofile.c (f2dtime, f2ddate): new upstream release (6.3.51). * src/omerge.c (mergedate, mergetime): new upstream release (6.3.51). 2009-10-10 Ito Hiroyuki * src/gtk/x11commn.c (AxisDel): fix 3rd argument of "strncpy()" (from "sizeof(group)" to "sizeof(group3)"). 2009-10-02 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvKeyDown): call "UnFocus()" when the escape key is pressed. 2009-09-05 Ito Hiroyuki * src/mathcode.c (mathexpand): maximum value of the operand for operator '!' is 169 (not 69). 2009-08-28 Ito Hiroyuki * src/gtk/x11commn.c (get_save_opt): added. (GraphSave): use "get_save_opt()". 2009-08-19 Ito Hiroyuki * src/gtk/x11file.c (draw_type_pixbuf): call "g_object_unref()" for "pix" when "ggc" is lesser than 0. * src/gtk/x11view.c (drag_drop_cb): check the drop is success or not. (text_dropped): use "CheckGrid()". (enum EvalDialogColType, eval_dialog_set_parent_cal) (mask_selected_data): added. (EvalDialogSetupItem, eval_dialog_copy_selected) (EvalDialogSetup, select_data_cb): use "GtkTreeStore" instead of "GtkListStore". (Evaluate): use "mask_selected_data". (mouse_down_move_data): don't return but "goto ErrEnd;" when "fileobj" is NULL. 2009-08-18 Ito Hiroyuki * src/gtk/x11view.c (eval_dialog_copy_selected): save text to not only "CLIPBOARD" but "PRIMARY". 2009-08-17 Ito Hiroyuki * src/gtk/gtk_widget.c (_create_spin_entry): fix argument of "gtk_spin_button_set_digits()". * src/gtk/x11dialg.c (get_style_string): added. (SetStyleFromObjField): use "get_style_string()". * src/gtk/x11lgnd.c (legend_list_set_val): don't display size of mark object. (legend_list_set_val): show mark size in "LEGEND_WIN_COL_WIDTH" column. (legend_list_set_val): show some fields in "LEGEND_WIN_COL_PROP" column. (width_edited): edit "size" field of mark object. (get_points): added. 2009-08-14 Ito Hiroyuki * src/gtk/x11gui.c (DialogExecute): set "GlobalLock" as TRUE, save and restore "GlobalLock" to inhibit DnD during executing dialog. * src/gtk/x11view.c (init_dnd): use "gtk_target_list_add_text_targets()" to add text target. (drag_drop_cb): do nothing when "GlobalLock" is TRUE. (drag_drop_cb): always call "gtk_drag_finish()". (paste_cb): call "UpdateAll()" after call "ShowFocusFrame()". (text_dropped): focus newly created text. 2009-08-13 Ito Hiroyuki * src/gtk/x11gui.c (DialogSpinEntry): call "gtk_spin_button_set_numeric()". * src/gtk/x11print.c (OutputImageDialogSetup): second argument of "gtk_spin_button_set_numeric()" is TRUE. * src/gtk/x11lgnd.c (pos_edited, width_edited): use "str_calc()" instead of "strtod()". * src/gtk/x11axis.c (pos_edited_common): use "str_calc()" instead of "strtod()". * src/gtk/gtk_widget.c (spin_change_value_cb): added. (_create_spin_entry): call "g_signal_connect()" for "input" signal. (_create_spin_entry): second argument of "gtk_spin_button_set_numeric()" is FALSE. * src/gtk/gtk_subwin.c (start_editing): second argument of "gtk_spin_button_set_numeric()" is FALSE. (numeric_cb): use "str_calc()" instead of "strtod()". * src/gtk/x11lgnd.c (width_edited): added. (CmLegendWindow): call "set_editable_cell_renderer_cb()" for "LEGEND_WIN_COL_WIDTH". (legend_list_set_val): add case for "LEGEND_WIN_COL_WIDTH". (legend_list_set_val): add mark character and mark size for the case of "LegendTypeMark". (MarkChar, MarkCharNum): added. (Llist): add column "lw/pt", remove column "object" and change column from "property" to "object/property". (LEGEND_WIN_COL_WIDTH): added. (legend_list_set_val): gettextize some strings. (legend_list_set_val): remove case for "LEGEND_WIN_COL_NAME". (legend_list_build, legend_list_set): set strings to "LEGEND_WIN_COL_PROP" column. 2009-08-12 Ito Hiroyuki * src/gtk/x11file.c (fit_load_dialog_default_cb): remove. (FitLoadDialogSetup): use "GtkComboBox" instead of "GtkTreeView". (FitSaveDialogSetup): add delete button. (FitSaveDialogClose): call "g_strstrip()" for the profile. (FitSaveDialogClose): show confirm message when the profile is not specified. (copy_settings_to_fitobj, delete_fitobj): added. (FitDialogSave): use "copy_settings_to_fitobj()" and "delete_fitobj()". (FitCB): return "type" only when "profile" is NULL. 2009-08-11 Ito Hiroyuki * src/gtk/x11view.c (eval_dialog_copy_selected) (eval_data_sel_cb): added. (EvalDialogSetup): add "Copy" button. (paste_cb): place pasted text to center of the widget. (text_dropped): position of the text is multiple of 100. * src/gtk/x11file.c (math_dialog_key_pressed_cb): use "gtk_tree_selection_count_selected_rows()" to check rows are selected or not. * src/gtk/x11dialg.c (multi_list_default_cb): use "gtk_tree_selection_count_selected_rows()" to check rows are selected or not. * src/gtk/x11dialg.c (multi_list_default_cb): remove redundant call of "gtk_tree_view_get_selection()". * src/gtk/x11dialg.h (struct FitDialog): add member "func_label". * src/gtk/x11file.c (FitDialogSetup): add equation label. (FitDialogSetup): improve the placement of widgets. (FitDialogSetup): maximum number of "d->dim" is 9. (FitDialogSetup): maximum number of "d->div" is 65535. (FitDialogSetSensitivity): set equation label string. (set_fitdialog_sensitivity): added. * src/ofit.c (fituser): show "dxxc" in the progress dialog. 2009-08-10 Ito Hiroyuki * src/gra.c (GRAexpandtext): output '-' character when the string is '\-' (because 0xad "soft hyphen" is not printable usually). (GRAexpandtext): output no character when the string is '\x00'. * src/gtk/gtk_subwin.c (sub_window_create): call "gtk_widget_show_all()" for "swin". 2009-08-07 Ito Hiroyuki * src/gtk/x11file.c (select_color): check version of GTK. * src/gtk/x11gui.c (FileSelectionDialog): call "file_dialog_set_current_neme()" only when "type" is "GTK_FILE_CHOOSER_ACTION_SAVE". 2009-08-06 Ito Hiroyuki * src/object.c (sexeobjfield): check "arglist" before call "strcmp()". * src/odraw.h (enum SAVE_PATH_TYPE): added. * src/gtk/x11commn.c (SetFileName): use copy of "str". (ToRalativePath): added. (GraphSave): save and restore previous working directory. (GraphSave): change "file::file" and "merge::file" depend on the value of "path". 2009-08-05 Ito Hiroyuki * src/gtk/x11opt.c (MiscDialogSetup): set label to some frames. * src/gtk/x11file.c (FitCB): just return "valstr". * src/gtk/x11commn.c (FileCB): use "g_strdup_printf()". (change_filename, get_basename, ToBasename): added. (ToFullPath): use "change_filename()". (LoadNgpFile): "system::ignore_path" is always FALSE. (LoadNgpFile): call "ToBasename()" when "ignorepath" is TRUE. * src/gtk/x11axis.c (AxisCB, AxisHistoryCB, GridCB): use "g_strdup_printf()". * src/gtk/x11commn.c (LoadPrmFile): set modified flag when load PRM file. * src/oaxis.c (draw_wave, draw_arrow): added. (axisdraw): use "draw_wave()" and "draw_arrow()". 2009-08-04 Ito Hiroyuki * src/gtk/gtk_widget.c (direction_icon_released) (create_direction_entry): exchange up and down icon. * src/oline.c (arrowdraw, arrowbbox): use "enum ARROW_POSITION_TYPE". * src/oaxis.c (enum AXIS_SCALE_TYPE): added. (anumdirchar, enum AXIS_NUM_DIR): add member "normal2". (get_num_pos_horizontal, get_num_pos_parallel) (get_num_pos_normal, struct font_config, struct axis_config) (get_num_ofst_horizontal, get_num_ofst_parallel) (get_num_ofst_normal1, get_num_ofst_normal2, draw_numbering) (numbering, draw_gauge, get_axis_parameter) (get_reference_parameter): added. (axisdraw): use "get_reference_parameter()", "draw_gauge()" and "numbering()". (axisdraw): use "enum ARROW_POSITION_TYPE". * src/odraw.h (enum ARROW_POSITION_TYPE): added. * src/mathfn.c (compare_double): added. * src/axis.c (getaxispositionini): use "compare_double()" to compare two floating-point value. 2009-07-27 Ito Hiroyuki * src/gtk/x11view.c (ncopyobj): use "copy_obj_field()". (new_file_obj): add argument "multi". (data_dropped): "Apply All" button is active when "i" is lesser than "num - 1". * src/gtk/x11file.c (copy_file_obj_field): use "copy_obj_field()". * src/gtk/x11commn.c (FitCopy): use "copy_obj_field()". * src/gtk/gtk_subwin.c (obj_copy): use "copy_obj_field()". * src/shellcm.c (cmcpy): use "copy_obj_field()". * src/object.c (copy_obj_field): added. 2009-07-26 Ito Hiroyuki * src/gtk/x11file.c (copy_file_obj_field): add (FitDialogSave): check "DlgFitSave.Profile" and "DlgFitSave.Profile[0]". (FitDialogSave): check arguments of "strcmp()". (CmFileHistory): use "nstrdup()" instead of "memalloc()" and "strcpy()". (FileDialogCopyAll, update_file_obj_multi, file_obj_copy): use "copy_file_obj_field()". * src/gtk/x11gui.c (fsok): use "g_strdup_printf()" or "strdup()" instead of "malloc()" and "strcpy()". * src/gtk/x11commn.c (AxisDel): use "strncpy()" instead of "strcpy()". * src/gtk/ogra2cairofile.c (gra2cairofile_output): don't check "local->linetonum" before call "gra2cairo_draw_path()". * src/gtk/ogra2cairo.c (gra2cairo_update_fontmap): check arguments "fontname" and "fontalias". (gra2cairo_draw_path): check "local->linetonum". (gra2cairo_free, gra2cairo_flush, gra2cairo_output): don't check "local->linetonum" before call "gra2cairo_draw_path()". * src/gtk/gtk_entry_completion.c (entry_completion_append): check argument "str". 2009-07-23 Ito Hiroyuki * src/gtk/x11file.c (FitDialogSave): bug fix: check and argument of "strcmp()". * src/gtk/x11gui.c (set_dialog_position, get_dialog_position): added. (DialogInput, DialogRadio, DialogCombo, DialogComboEntry) (DialogSpinEntry, DialogCheck): add add argument "x" and "y". * src/gtk/ox11dlg.c (dlginit): initialize "x" and "y" field. (dlginput, dlgradio, dlgcombo, dlgspin, dlgcheck): add argument "x" and "y" to create dialog window. (dialog): add field "x" and "y". 2009-07-22 Ito Hiroyuki * src/gtk/x11axis.c (CmAxisWindow): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/x11cood.c (CoordWinUpdate): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/x11file.c (CmFileWindow): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/x11info.c (InfoWinUpdate): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/x11lgnd.c (CmLegendWindow): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/x11merge.c (CmMergeWindow): call "sub_window_show_all()" instead of "sub_window_show()". * src/gtk/gtk_subwin.c (sub_window_show_all): added. (sub_window_show, sub_window_hide): call "gtk_widget_show()" and "gtk_widget_hide()" instead of "gtk_widget_show_all()" and "gtk_widget_hide_all()" respectively. 2009-07-21 Ito Hiroyuki * src/omark.c (MODIFY_MARK_TYPE, rotate_cw, v_flip, h_flip): added. (markrotate, markflip): modify mark type when "MODIFY_MARK_TYPE" is TRUE. 2009-07-15 Ito Hiroyuki * src/gtk/x11file.c (select_type): use 3rd column of the combo-box to specify which type of item is selected. (start_editing_type): don't activate the combo-box item. * src/gtk/gtk_liststore.c (start_editing_obj): add column to the model. 2009-07-14 Ito Hiroyuki * src/gtk/gtk_liststore.c (create_column): set "expand" property as TRUE when ellipsize mode is not "PANGO_ELLIPSIZE_NONE". * src/gtk/x11file.c (enum FILE_COMBO_ITEM, select_color): added. (select_type): set not only "type" but color. (create_type_combo_box): add color setting combo item. 2009-07-10 Ito Hiroyuki * src/gtk/x11file.c (count_line_number_str, set_line_number_tag) (create_text_tag): added. (FileDialogSetup): initialize "d->comment_num_tag" and set tag for line number. * src/gtk/x11dialg.h (struct FileDialog): add member "comment_num_tag". * addin/Makefile.am (pkglib_DATA): add "cal.nsc". * addin/cal.nsc: added. * src/gtk/x11gui.c (DialogSpinEntry): added. * src/gtk/ox11dlg.c (dlgspin): added. (dialog): add new field "double_entry" and "integer_entry". 2009-07-09 Ito Hiroyuki * src/gtk/x11menu.c (clear_information): added. (create_windowmenu): add menu item "_Clear information window". * src/gtk/ox11menu.c (menudone): return "1" when GUI is active. (mxredraw, mxdpi, mxflush, mx_get_focused, mx_echo, mx_cat) (mx_clear_info, mx_toggle_win, mxdraw, mxclear): do nothing when GUI is not active. (menuerrorlist): add error message ("the GUI is not active"). (SubwinData, _subwin_data, subwindow_show, subwindow_hide) (mx_show_win, mx_hide_win): added. (gtkmenu): add new field "show_window" and "hide_window". * src/gtk/x11info.c (create_win): initialize font and geometry settings. 2009-07-08 Ito Hiroyuki * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose): add code for "infowin_font" setting. * src/gtk/x11info.c (InfoWinSetFont): added. (InfoWinUpdate): call "InfoWinSetFont()". * src/gtk/ox11menu.h (struct menulocal): add member "infowin_font". * src/gtk/ox11menu.c (menuerrorlist): add error message ("cannot open the file"). (MenuConfigMisc): add "infowin_font" setting. (mx_cat, mx_clear_info, mx_toggle_win): added. (gtkmenu): add new field "cat", "clear_info" and "toggle_window". 2009-07-07 Ito Hiroyuki * src/gtk/gtk_subwin.c (tree_hidden): don't execute "d->update()" but call "gtk_tree_store_set()". (toggle_cb): use "tree_hidden()". * src/object.c (sexefield): don't remove space character. (sexeobjfield): remove space character only when "arglist" is "s". 2009-07-06 Ito Hiroyuki * src/gtk/x11commn.c (AddNgpFileList): free "full_name" after call "g_strdup_printf()". * src/gtk/x11view.c (paste_cb): don't use a temporary file and use "eval_script()". * src/shell.c (getcmdline): the type of argument "str" is "const char *". (eval_script): added. (cmdexecute): the type of argument "cline" is "const char *". 2009-07-05 Ito Hiroyuki * initfile/Ngraph.nsc: use "NGRAPHCONF" instead of "NGRAPHLIB". * src/gtk/x11print.c (DriverDialogClose): use "g_strdup_printf()" instead of "snprintf()". * src/gtk/x11opt.c (create_font_selection_dialog): use "g_strdup_printf()" instead of "snprintf()". * src/gtk/x11menu.c (createmenu): use "g_strdup_printf()" instead of "snprintf()". (load_hist_file, save_hist_file): added. (save_entry_history): use "save_hist_file()". (load_hist): use "load_hist_file()". * src/gtk/x11dialg.c (SetObjAxisFieldFromWidget): use "g_strdup_printf()" instead of "snprintf()". * src/gtk/x11commn.c (check_overwrite, AddNgpFileList) (SaveHistory): use "g_strdup_printf()" instead of "snprintf()". * src/gtk/ox11menu.c (add_prm_str_to_array) (save_ext_driver_config, save_script_config): use "g_strdup_printf()" instead of "snprintf()". (menu): "arglist" of "menu" field is "s". * src/gtk/main.c (main, obj_member_completion_function): use "g_strdup_printf()" instead of "snprintf()". * src/shellcm.c (cmbasename): call "basename(3)" to duplicated string. (cmdirname): use duplicated string. (cmexist): add "-q" option. * driver/ngp2.in: use "-q" option for "exist" command. (save_image): copy settings of "gra" object. (save_image): set "display" field of "fit" object as false if exist. * initfile/Ngraph.nsc: use "-q" option for "exist" command. (load_graph): argument of "$LOGIN_SHELL" is full-path filename. 2009-07-02 Ito Hiroyuki * src/gtk/x11print.c (DriverDialogBrowseCB, CmPrintGRAFile) (CmOutputImage, CmPrintDataFile): change the arguments of the function "nGetSaveFileName()". * src/gtk/x11opt.c (SetScriptDialogBrowse) (SetDriverDialogBrowse): change the arguments of the function "nGetOpenFileName()". * src/gtk/x11merge.c (CmMergeOpen): change the arguments of the function "nGetOpenFileName()". * src/gtk/x11gui.c (file_dialog_set_current_neme): added. (FileSelectionDialog): use "file_dialog_set_current_neme()". (nGetOpenFileNameMulti, nGetOpenFileName, nGetSaveFileName): remove the argument "filter". (struct nGetOpenFileData): remove member "filter". * src/gtk/x11graph.c (CmGraphLoad): change the arguments of the function "nGetOpenFileName()". * src/gtk/x11file.c (CmFileNew, CmFileOpen): change the arguments of the functions "nGetOpenFileName()" and "nGetOpenFileNameMulti()". * src/gtk/x11commn.c (GraphSave): change the arguments of the function "nGetSaveFileName()". * src/gtk/ox11dlg.c (dlggetopenfile, dlggetopenfiles) (dlggetsavefile): change the arguments of the functions "nGetOpenFileName()", "nGetOpenFileNameMulti()" and "nGetSaveFileName()". * src/gtk/ogra2cairo.c (gra2cairo_save_config): use "g_strdup_printf()" instead of "snprintf()". * src/gtk/gtk_widget.c (entry_icon_file_select): change the arguments of the function "nGetOpenFileName()". * src/gtk/gtk_subwin.c (file_select): change the arguments of the function "nGetOpenFileName()". 2009-07-01 Ito Hiroyuki * src/gtk/x11print.c (DriverDialogClose): use "check_overwrite()". * src/gtk/x11gui.c (FileSelectionDialog): don't call "gtk_file_chooser_set_do_overwrite_confirmation()". (FileSelectionDialog): call "check_overwrite()" when "type" is " GTK_FILE_CHOOSER_ACTION_SAVE" and "data->overwrite" is false. * src/gtk/x11commn.c (check_overwrite): added. 2009-06-30 Ito Hiroyuki * src/gtk/ogra2cairofile.c (gra2cairofile_output): call "gra2cairo_draw_path()" before call "cairo_surface_write_to_png()". * src/gtk/ogra2cairo.c (gra2cairo_draw_path): added. (gra2cairo_free, gra2cairo_flush, gra2cairo_output): use "gra2cairo_draw_path()". 2009-06-29 Ito Hiroyuki * src/ofit.c (fitpoly, fituser): call "display_equation()" only when "disp" is true. 2009-06-26 Ito Hiroyuki * src/gtk/x11file.c (FitDialogClose): check "ret" instead of "d->ret" with "IDOK". 2009-06-24 Ito Hiroyuki * src/gtk/main.c (reset_fifo, exec_console): added. (nallocconsole): use "exec_console()". (nallocconsole): call "unlink()" after open fifo. * src/terminal.c (main): don't call "unlink()". 2009-06-18 Ito Hiroyuki * src/gtk/main.c (main): initialize system::conf_dir. (main): search "conf_dir" instead of "lib_dir". * src/gtk/dir_defs.h.in (CONFDIR): added. * src/shell.c (ngraphenvironment): add new environment variable "NGRAPHCONF". * src/osystem.c (nsystem): add new field "conf_dir". * src/nconfig.c (searchscript, openconfig, replaceconfig) (removeconfig, writecheckconfig, copyconfig): search "conf_dir" instead of "lib_dir". * src/ioutil.h (CONFSEP): change from "/." to "/". * src/Makefile.am (pkglib_PROGRAMS): "terminal" is installed in "$pkglibdir". * initfile/Ngraph.ini.in: specify full path of "nterminal". * initfile/Makefile.am (ngraphconfdir): configration files are installed in "$(sysconfdir)/$(PACKAGE)". * initfile/fit.ngp: change file name from ".fit.ngp" * initfile/Ngraph.nsc: change file name from ".Ngraph" * initfile/Ngraph.ngp: change file name from ".Ngraph.ngp" * driver/Makefile.am (ngraphconfdir): configration files are installed in "$(sysconfdir)/$(PACKAGE)". * addin/Makefile.am (pkglib_DATA): install addins to $pkglibdir. 2009-06-15 Ito Hiroyuki * src/gtk/x11commn.c (SaveDrawrable): use "NFMODE_NORMAL_FILE" instead of "NFMODE". * src/gtk/x11file.c (FitDialogSave): use "NFMODE_NORMAL_FILE" instead of "NFMODE". * src/ioutil.h (NFMODE_NORMAL_FILE): added. * src/osystem.c (sysdone): delete temporary files if exist. 2009-06-14 Ito Hiroyuki * src/osystem.c (systemp): use "n_mkstemp()". * src/ioutil.c (n_mkstemp): set and restore umask. 2009-06-11 Ito Hiroyuki * zsh/_ngraph: added. * zsh/_ngp2: added. * zsh/_gra2wmf: added. * zsh/_gra2ps: added. * zsh/Makefile.am: added. * src/gtk/x11print.c (draw_gra): check "NgraphApp.Viewer.win" before call "gdk_window_invalidate_rect()". * initfile/.Ngraph: add new option -cr, -cg, -cb, -CR, -CG, -CB, -incx, -maxx, -minx, -incy, -maxy, -miny, -L and -dialog. option -c, -C, -zx and -zy are obsolete. 2009-06-10 Ito Hiroyuki * debian/rules: add mime types and bash completion settings. * src/ofile.c (markout): the argument "type" is not used in this function. 2009-06-09 Ito Hiroyuki * src/gtk/x11menu.c (show_graph_menu_cb): remove code related to "ngp_history" and "ngp_dir_history". (create_recent_graph_menu): use "GtkRecentChooserMenu". * src/gtk/x11graph.c (CmGraphHistory): use "GtkRecentChooser". * src/gtk/x11commn.c (AddNgpFileList): static function. (AddNgpFileList): use "GtkRecentManager". (SaveHistory): don't save "ngp_history" and "ngp_dir_history". * src/gtk/ox11menu.c (MenuConfig): remove "ngp_history" and "ngp_dir_history". (menulocal_finalize, menuinit): remove code related to "ngp_history" and "ngp_dir_history". (menuinit): "Menulocal.ngpfilelist" is "GtkRecentManager *". * initfile/Ngraph.ini.in (viewer_load_file_data_number): remove "ngp_history" and "ngp_dir_history". 2009-06-08 Ito Hiroyuki * src/gtk/x11graph.c (pagelist, PageDialogSetup): gettextize paper size strings. 2009-06-03 Ito Hiroyuki * src/gra.c (getintpar): check size of "s2". (GRAinputdraw): check number of the parameters and return success or not. (GRAinput): return the return value of "GRAinputdraw()". * src/gtk/x11menu.c (AppMainLoop): return 1 when terminated. (application): delete instance of "system" object when return value of "AppMainLoop()" is 1. 2009-06-02 Ito Hiroyuki * src/gtk/main.c (nfreeconsole): send "SIGTERM" instead of "SIGCHLD". * src/terminal.c (main): use "sigsuspend()" if available. (main): trap "SIGTERM" instead of "SIGCHLD". * src/shell.c (cmdexec): bug fix: use "WEXITSTATUS" to get return status of external command. * src/gtk/x11menu.c (application): call "SaveHistory()". (AppMainLoop): don't call "SaveHistory()". 2009-06-01 Ito Hiroyuki * src/shell.c (set_signal, set_shellevloop, reset_shellevloop): added. (shellevloop): use pthread. (shgetstdin, shget): use "set_shellevloop()" and "reset_shellevloop()". (childhandler, set_childhandler, unset_childhandler): added. (cmdexec): call "unset_childhandler()" and "set_childhandler()" before and after execute command. * src/gtk/x11menu.c (term_signal_handler): added. (childhandler): remove. (AppMainLoop): check type of "Hide_window". (application): use "set_signal()". (application): trap "SIGTERM" while GUI is active. * src/gtk/x11file.c (FitDialogClose): bug fix: delete unused fit objects not only in the case of "d->ret" is "IDOK" but "IDCANCEL" and "IDDELETE". (FileDialogFit): call "set_graph_modified()" if necessary. (FileDialogEdit, CmFileEdit, FileWinFileEdit): don't call "arrayadd()" for "ChildList". * src/shellux.c (cmsleep): use "set_signal()". 2009-05-26 Ito Hiroyuki * src/gtk/x11menu.c (create_graphmenu): use "GTK_STOCK_PAGE_SETUP" when the version of GTK++ is greater than 2.14. 2009-05-23 Ito Hiroyuki * src/gtk/x11lgnd.c (pos_edited): call "set_graph_modified()" after "exeobj()". 2009-05-19 Ito Hiroyuki * src/nconfig.c (getconfig): treat the line as comment when the first caractor of the line is "#" or ";". 2009-05-18 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo): change permission of fields "init" and "done". * src/gtk/main.c (load_config): added. (load_config): bug fix: check return value of "getobject". * src/gtk/x11axis.c (file_button_show): added. (AxisDialogSetup): call "g_signal_connect()" for "show" signal of "File" button. * src/gtk/x11opt.c (set_font): added. (MiscDialogClose): use "set_font()". (MiscDialogSetupItem, MiscDialogSetup): initialize and setup "d->file_preview_font". * src/gtk/x11dialg.h (struct FileDialog): add member "comment_view". (struct MiscDialog): add member "file_preview_font". * src/gtk/x11file.c (FileDialogSetup): call "gtk_widget_modify_font" if "Menulocal.file_preview_font" is not NULL. * src/gtk/ox11menu.h (struct menulocal): add member "file_preview_font". * src/gtk/ox11menu.c (MenuConfigMisc): add config "file_preview_font". (menulocal_finalize): added. (menuinit, menudone): use "menulocal_finalize()". (menuinit): call "memset()" to initialize "Menulocal". * src/gtk/ogra2x11.c (gtkloadconfig): check string "use_external_viewer". 2009-05-17 Ito Hiroyuki * src/gtk/x11axis.c (AxisPosDialogSetup): use "create_direction_entry()" instead of "create_spin_entry_type()". * src/gtk/x11lgnd.c (legend_dialog_setup_sub): use "create_direction_entry()" instead of "create_spin_entry_type()". * src/gtk/gtk_widget.c (direction_icon_released) (create_direction_entry): added. 2009-05-15 Ito Hiroyuki * src/gtk/x11print.c (DriverDialogSelectCB): set value to "d->ext". (DriverDialogBrowseCB): set filter when "d->ext" is not NULL. (DriverDialogClose): use "d->widget" for first argument of "MessageBox()". (DriverDialog): initialize "data->ext". (CmPrintGRAFile, CmOutputImage, CmPrintDataFile): remove check of confirmation about overwriting an existing file. * src/gtk/x11opt.c (SetDriverDialogBrowse, SetDriverDialogClose) (PrefFontDialogAdd): use "d->widget" for first argument of "MessageBox()" and "nGetOpenFileName()". * src/gtk/x11merge.c (MergeDialogSetup): use "create_file_entry()" instead of "create_text_entry()". * src/gtk/x11gui.c (struct nGetOpenFileData): add member "overwrite". (FileSelectionDialog): check "parent". (FileSelectionDialog): call "gtk_file_chooser_set_do_overwrite_confirmation()" when "type" is "GTK_FILE_CHOOSER_ACTION_SAVE". (FileSelectionDialog): hide "data->chdir_cb" when "data->initdir" is NULL. (nGetSaveFileName): add argument "overwrite". * src/gtk/x11file.c (FitDialogLoadConfig, FitDialogLoad) (FitDialogSave): use "d->widget" for first argument of "DialogExecute". (FileDialogSetup): use "create_file_entry()" instead of "create_text_entry()". (FileWinFit): use "d->Win" for first argument of "DialogExecute". * src/gtk/x11dialg.h (struct DriverDialog): add member "ext". * src/gtk/x11commn.c (GraphSave): remove check of confirmation about overwriting an existing file. * src/gtk/x11axis.c (AxisDialogFile): use "d->widget" for first argument of "DialogExecute". * src/gtk/gtk_widget.c (get_parent_window) (entry_icon_file_select, create_file_entry): added. * src/gtk/gtk_subwin.c (file_select): added. (start_editing): call gtk_entry_set_icon_from_stock when "list->name" is "file". * src/gtk/gtk_common.h (USE_ENTRY_ICON): added. * src/omerge.c (merge): add field "ext". (mergeinit): initialize field "ext". 2009-05-14 Ito Hiroyuki * initfile/.Ngraph: change directory when "ngp" or "prm" file is specified. * src/gtk/x11graph.c (DirectoryDialogSetup): use "GtkFileChooserButton" instead of "GtkEntry". * src/shell.c (cmdtable): add commands "basename" and "dirname". * src/shellcm.c (cmdirname, cmbasename): added. 2009-05-13 Ito Hiroyuki * src/gtk/x11view.c (Trimming): use "axis_scale_push()" instead of "exeobj()". * src/gtk/x11axis.c (check_axis_history): added. (CmAxisWinScaleUndo): call "check_axis_history()" instead of "chkobjlastinst()". (axis_scale_push): added. (AxisDialogClose, axiswin_scale_clear, CmAxisClear) (axis_prm_edited_common): use "axis_scale_push()" instead of "exeobj()". (CmAxisWinScaleUndo): call "set_axis_undo_button_sensitivity()". * src/gtk/x11menu.c (hide_instance_menu_cb): added. (set_show_instance_menu_cb): add arguments "show_cb" and "hide_cb". (show_axis_menu_cb, hide_axis_menu_cb): added. (create_axismenu): add 5th and 6th arguments to call "set_show_instance_menu_cb()". (set_axis_undo_button_sensitivity): added. (setupwindow): call "set_axis_undo_button_sensitivity()". * src/gtk/x11file.c (CmFileWinMath): check number of instance. 2009-05-12 Ito Hiroyuki * src/gtk/x11axis.c (AxisDialogSetupItem): add item to combo boxes when the value is different from previous one. (axis_prm_edited_common, min_edited, max_edited, inc_edited): added. (CmAxisWindow): call "set_editable_cell_renderer_cb()" for "AXIS_WIN_COL_MIN", "AXIS_WIN_COL_MAX" and "AXIS_WIN_COL_INC". (AxisHistoryCB): added. (AxisWinExpose): use "AxisHistoryCB()". (CmAxisDel): check "DlgCopy.sel". * src/gtk/x11lgnd.c (LegendTextCB): return whole string. * src/gtk/x11dialg.c (SelectDialogSetup, CopyDialogSetup): "PangoEllipsizeMode" of "property" column is "PANGO_ELLIPSIZE_END". (SelectDialogSetup, CopyDialogSetup): append item only when return value of a function "d->cb()" is not NULL. (SelectDialogClose): save value of "id" column. (CopyDialogClose): set value of "id" column of the selected row to "d->sel". * src/oaxis.c (axisbbox2): check "inst". (get_axis_box): this function returns int. (get_axis_box): check return value of "axisbbox2()". (get_axis_group_box): this function returns int. (get_axis_group_box): check return value of "get_axis_box()". (axisbbox): check return value of "get_axis_group_box()". (axisrotate2, axisflip2): check "inst". (axisrotate, axisflip): check return value of "get_axis_group_box()". (AXIS_HISTORY_NUM): added. (axisscalepush): use "AXIS_HISTORY_NUM". 2009-05-11 Ito Hiroyuki * src/gtk/ox11menu.c (MenuConfigToggleView): add "{NULL}" at the end of the array. 2009-05-08 Ito Hiroyuki * src/ofile.c (USE_BUF_PTR, USE_RING_BUF, BUF_TYPE, USE_MEMMOVE) (RING_BUF_INC, ring_buf_index): added. (struct f2ddata): add new member "buf_ptr" or "ringbuf_top". (struct f2ddata): now "buf" is array. (opendata): initialize "buf_ptr" or "ringbuf_top". (getdata): use array of pointer or ring buffer. 2009-05-01 Ito Hiroyuki * src/gtk/x11view.h (enum FOCU_OBJ_TYPE): add "FOCUS_OBJ_TYPE_TEXT". * src/gtk/x11view.c (enum ViewerPopupIdn): add "VIEW_FLIP_HORIZONTAL" and "VIEW_FLIP_VERTICAL". (create_popup_menu): added. (create_popup_menu): add flip menu. (VIEWER_POPUP_ITEM_FLIP): added. (execute_selected_instances): added. (RotateFocusedObj): use "execute_selected_instances()". (FlipFocusedObj): added. (do_popup): set sensitivity of flip menu. (ViewerPopupMenu): add case for "VIEW_FLIP_HORIZONTAL" and "VIEW_FLIP_VERTICAL". (CmEditMenuCB): add case for "MenuIdEditFlipHorizontally" and "MenuIdEditFlipVertically". * src/gtk/x11menu.h (enum MenuID): add "MenuIdEditFlipHorizontally" and "MenuIdEditFlipVertically". * src/gtk/x11menu.c (show_edit_menu_cb): set sensitivity of "FlipH" and "FlipV". (create_editmenu): add flip menu. * src/orect.c (rectflip): added. (rect): add new field "flip". * src/opolygon.c (opoly): add new field "flip". * src/omark.c (markflip): added. (mark): add new field "flip". * src/oline.c (arrow): add new field "flip". * src/olegend.h (enum FLIP_DIRECTION): added. * src/olegend.c (flip, legendflip): added. * src/ocurve.c (curve): add new field "flip". * src/oaxis.c (axisbbox2, get_axis_box): remove unused arguments "argc" and "argv". (get_axis_group_box): added. (axisbbox, axisrotate): use "get_axis_group_box()". (axisflip2, axisflip): added. (axis): add new field "flip". * src/oarc.c (arcflip): added. (arc): add new field "flip". * addin/append.nsc: hide and recover axisgrid. 2009-04-30 Ito Hiroyuki * src/gtk/x11menu.h (SUBWIN_PROTOTYPE): added. (struct SubWin, struct LegendWin, struct InfoWin): use "SUBWIN_PROTOTYPE". (struct CoordWin): remove. * src/gtk/x11dialg.h (DIALOG_PROTOTYPE): added. use "DIALOG_PROTOTYPE" for all struct which inherit "DialogType" struct. * src/gtk/x11cood.c (CoordWinSetCoord, CoordWinUpdate): use "struct InfoWin" instead of "struct CoordWin". 2009-04-28 Ito Hiroyuki * src/gtk/gtk_subwin.c (ev_button_down_tree): remove. (ev_button_down): don't respond to right button click. (ev_button_down): call "tree_update()" when "d->type" is "TypeLegendWin". (ev_button_up): added. (list_sub_window_create, tree_sub_window_create): call back function for "button-release-event" is "ev_button_up()". * src/gtk/x11view.h (struct FocusObj): change name of the struct from "focuslist". (struct Point): moved from x11view.c and change name of the struct from "pointslist". * src/gtk/x11menu.c (SetPoint): show width and height when "d->Capture" is TRUE. 2009-04-27 Ito Hiroyuki * src/gtk/x11menu.c (create_windowmenu): change accel path of "View" menu. (create_legendmenu): do not gettextize menu title. (create_legendsubmenu): gettextize "label". (create_legendsubmenu): remove under score from "label" for accel path string. * src/gtk/gtk_subwin.c (numeric_cb, string_cb): do nothing when "d->type" is "TypeLegendWin". * src/gtk/x11lgnd.c (LEGEND_WIN_COL_HIDDEN, LEGEND_WIN_COL_PROP) (LEGEND_WIN_COL_X, LEGEND_WIN_COL_Y): added. (legend_list_set_val): use "case" instead of "strcmp()". (enum CHANGE_DIR, pos_edited, pos_x_edited, pos_y_edited): added. (CmLegendWindow): call "set_editable_cell_renderer_cb()" for "LEGEND_WIN_COL_X" and "LEGEND_WIN_COL_Y". (Llist): colum "x" and "y" is editable. * src/gtk/x11file.c (FILE_WIN_COL_HIDDEN, FILE_WIN_COL_FILE) (FILE_WIN_COL_X, FILE_WIN_COL_Y): added. (file_list_set_val): use "case" instead of "strcmp()". * src/gtk/x11axis.c (AXIS_WIN_COL_HIDDEN, AXIS_WIN_COL_NAME) (AXIS_WIN_COL_MIN, AXIS_WIN_COL_MAX, AXIS_WIN_COL_INC): added. (axis_list_set_val): use "case" instead of "strcmp()". * src/gtk/x11merge.c (MERG_WIN_COL_HIDDEN, MERG_WIN_COL_FILE): added. (merge_list_set_val): use "case" instead of "strcmp()". * src/gtk/gtk_liststore.h (tree_store_path_get_string): added. 2009-04-26 Ito Hiroyuki * src/gtk/ox11menu.c (menuinit): free "sdel->description" when error is occurred. * src/oaxis.c (check_group): added. (axisuniqgroup): use "check_group()". 2009-04-25 Ito Hiroyuki * src/gtk/x11view.c (Focus): check if "man" is valid id. * src/gtk/x11commn.c (AxisDel): call "delobj()" after check all instances. * src/odraw.c (clear_bbox): check if "inst" is NULL. * src/oaxis.c (INST_ARRAY_NUM): added. (axisdone): change "group" field of other instances belong to the same group. (get_axis_group_type): initialize "inst_array". 2009-04-24 Ito Hiroyuki * src/gtk/x11axis.c (enum CHANGE_DIR, pos_edited_common) (pos_x_edited, pos_y_edited): added. (CmAxisWindow): call "set_editable_cell_renderer_cb()" for "AXIS_WIN_COL_X" and "AXIS_WIN_COL_Y". * src/gtk/gtk_subwin.c (start_editing): call "UnFocus()". (set_cell_renderer_cb): set "list[i].edited_id" when "g_signal_connect()" is called for "edited" signal. (set_editable_cell_renderer_cb): added. (update): call "UnFocus()". * src/gtk/gtk_liststore.h: add member "edited_id". * src/gtk/gtk_liststore.c (create_tree_view): initialize "list[i].edited_id". * src/oaxis.c (axisgeometry): clear all bbox of instances belong to the group. (get_axis_group_type): add argument "check_all". * src/gtk/x11menu.c (struct command_data): add member "button", (createcommand1, createcommand2): set pointer of the GtkToolItem to "cdata->button" when "cdata->button" is not NULL. * src/gtk/x11file.c (set_btn_sensitivity_delete_cb) (set_btn_sensitivity_insert_cb, set_sensitivity_by_row_num): added. (MathDialogSetup, FileMoveDialogSetup, FileMaskDialogSetup): call "set_sensitivity_by_row_num()". 2009-04-23 Ito Hiroyuki * src/gtk/x11file.c (set_btn_sensitivity_cb) (set_sensitivity_by_selection): added. (MathDialogSetup, FileMoveDialogSetup, FileMaskDialogSetup): call "set_sensitivity_by_selection()" * src/oshell.c (cmdsecurity): use "set_security()". * src/shell.c (set_security, set_environ): added. * src/gtk/x11commn.c (LoadNgpFile): check execution of "shell::shell" for loding graph is success or not. * src/gtk/x11view.c (create_popup_menu): change title of a menuitem from "Show cross" to "cross Gauge". (ViewerEvKeyDown): change case from " GDK_KP_Space" to " GDK_space". remove case for "GDK_BackSpace". * src/gtk/x11opt.c (MiscDialogSetupItem): remove codes related to widgets visibility. (MiscDialogSetup): remove codes related to widgets visibility and change order of widgets. (MiscDialogClose): remove codes related to widgets visibility. * src/gtk/x11menu.h (enum MenuID): add "MenuIdToggleStatusBar", "MenuIdToggleRuler", "MenuIdToggleScrollbar", "MenuIdToggleCToolbar", "MenuIdTogglePToolbar", MenuIdToggleCrossGauge", "MenuIdAxisUndo" and "MenuIdFileMath". (struct Viewer): add "PToolbar" and "CToolbar", remove "ShowCross". * src/gtk/x11menu.c (create_filemenu): add menu item for "Math Transformation". (create_axismenu): add menu item for "Scale Undo". (show_win_menu_cb): set active state for "ToggleStatusBar", "ToggleRuler", "ToggleScrollbar", "ToggleCToobar", "TogglePToobar" and "ToggleCrossGauge". (toggle_view_cb): added. (create_windowmenu): create some menu items to show and hide widgets. (create_windowmenu): now the title of this menu is "View". (createmenu): reorder menus. (create_toolbar): add argument "hbox" and set GtkHandleBox to the variable. (set_widget_visibility): add argument "cross" and set visibility of some other widgets and cross gauge. (setupwindow): add argment to call "create_toolbar()".x (application): save settings for widgets visibility. * src/gtk/x11file.c (CmFileMenu): add case for "MenuIdFileMath". * src/gtk/x11dialg.h (struct MiscDialog): remove member "ruler" and "statusbar". * src/gtk/x11axis.c (CmAxisMenu): add case for "MenuIdAxisUndo". * src/gtk/ox11menu.h (struct menulocal): add member "scrollbar", "ctoolbar", "show_cross" and "ptoolbar". (enum SAVE_CONFIG_TYPE): add "SAVE_CONFIG_TYPE_TOGGLE_VIEW". * src/gtk/ox11menu.c (MenuConfigToggleView): added. (MenuConfigArrray): add "MenuConfigToggleView". (menu_save_config): add codes for "SAVE_CONFIG_TYPE_TOGGLE_VIEW". * src/nconfig.c (replaceconfig_match): return "buf" when next section was found. (replaceconfig): print "buf" after print configurations if "buf" is not NULL. 2009-04-22 Ito Hiroyuki * src/gtk/x11view.c (CmEditMenuCB): add case for "MenuIdAlignLeft", "MenuIdAlignVCenter", "MenuIdAlignRight", "MenuIdAlignTop", "MenuIdAlignHCenter" and "MenuIdAlignHBottom". * src/gtk/x11menu.h (enum MenuID): add "MenuIdAlignLeft", "MenuIdAlignVCenter", "MenuIdAlignRight", "MenuIdAlignTop", "MenuIdAlignHCenter" and "MenuIdAlignHBottom". * src/gtk/x11menu.c (hide_edit_menu_cb, create_alignmenu): added. (create_editmenu): call "create_alignmenu()". * src/object.h (struct objlist): add member "child". * src/object.c (addobject): set "parent->child" if "parent" in not NULL. (addobject): initialize "objnew->child" as NULL. (addobject): change the order of object list. 2009-04-21 Ito Hiroyuki * src/gtk/x11view.h (ROTATE_CLOCKWISE, ROTATE_COUNTERCLOCKWISE) (enum FOCU_OBJ_TYPE): added. * src/gtk/x11view.c (enum ViewerPopupIdn): add "VIEW_CUT", "VIEW_PASTE" add "VIEW_DUP". (CopyFocusedObjects, CutFocusedObjects, check_last_insts) (focus_new_insts, paste_cb, PasteObjectsFromClipboard): added. (create_popup_menu): add cut, copy and paste menu item. (check_focused_obj_type): added. (do_popup): use "check_focused_obj_type()". (ViewerPopupMenu): add case for "VIEW_CUT", "VIEW_PASTE" add "VIEW_DUP". (CmEditMenuCB): added. * src/gtk/x11menu.h (enum MenuID): add "MenuIdEditCut", "MenuIdEditCopy", "MenuIdEditPaste", "MenuIdEditDelete", "MenuIdEditRotateCW" and "MenuIdEditRotateCCW". * src/gtk/x11menu.c (show_edit_menu_cb, hide_edit_menu_cb) (create_editmenu): added. (createmenu): call "create_editmenu()". 2009-04-19 Ito Hiroyuki * src/orect.c (rectrotate, rectmove, rectchange, rectzoom) (rectgeometry): use "clear_bbox()". (set_position, get_position): added. (rectdraw): use "get_position()". (rectrotate, rectmove, rectchange, rectzoom): use "set_position()". * src/otext.c (textgeometry, textmove, textrotate, textzoom): use "clear_bbox()". * src/opolygon.c (polygeometry): use "clear_bbox()". * src/omerge.c (mergefile, mergemove, mergezoom, mergegeometry): use "clear_bbox()". * src/omark.c (markmove, markrotate, markzoom, markgeometry): use "clear_bbox()". * src/oline.c (arrowput): use "clear_bbox()". * src/olegend.c (legendgeometry, legendmove, legendrotate) (legendchange, legendzoom): use "clear_bbox()". * src/ocurve.c (curvegeometry): use "clear_bbox()". * src/oaxis.c (axisgeometry, axismove2, axisrotate2) (axischange2, axischange, axiszoom2, axisadjust, set_group_pos): use "clear_bbox()". * src/oarc.c (arcgeometry, arcmove, arcchange, arcrotate) (arczoom): use "clear_bbox()". * src/odraw.c (clear_bbox): added. 2009-04-17 Ito Hiroyuki * src/oagrid.c (struct axis_prm, struct axis_pos) (struct grid_prm, get_grid_prm, draw_grid_line, draw_background) (calc_intersection): added. (agriddraw): use "get_grid_prm()", "draw_grid_line()" and "draw_background()". 2009-04-16 Ito Hiroyuki * src/gtk/x11view.c (do_popup): popup item related to change order of instances is also sesensitive when the focused instances is "merge" object. (reorder_object): reorder instances when the focused instance is "merge" object. * src/oaxis.c (axis_get_box): added. (axisbbox2): use "axis_get_box()". (axisrotate2, axisrotate): added. (axis): add field "rotate". 2009-04-15 Ito Hiroyuki * src/gtk/x11menu.c (SetPoint): show the value of "s->Angle" when "d->Angle" is greater or equal to 0. * src/gtk/x11menu.h (struct Viewer): add member "Angle". * src/gtk/x11view.c (show_focus_line_arc): add argument "clear" and save previous state when "clear" is TRUE. (ShowFocusLine): add argument "clear". (mouse_move_change): second argument of "ShowFocusLine()" is TRUE at the first time to call "ShowFocusLine()". (enum ViewerPopupIdn): add "VIEW_ROTATE_CLOCKWISE" and "VIEW_ROTATE_COUNTER_CLOCKWISE". (create_popup_menu): added. (create_popup_menu): add item "_Rotate". (VIEWER_POPUP_ITEM_ROTATE): added. (RotateFocusedObj): added. (do_popup): set sensitivity of "d->popup_item[VIEWER_POPUP_ITEM_ROTATE]". (ViewerPopupMenu): add case for "VIEW_ROTATE_CLOCKWISE" and "VIEW_ROTATE_CONTER_CLOCKWISE" * src/orect.c (rectrotate): added. * src/otext.c (textrotate): added. (text): add field "rotate". * src/orect.c (rectrotate): added. (rect): add field "rotate". * src/opolygon.c (opoly): add field "rotate". * src/omark.c (markrotate): added. (mark): add field "rotate". * src/oline.c (arrow): add field "rotate". * src/olegend.c (rotate, legendrotate): added. * src/ocurve.c (curve): add field "rotate". * src/oarc.c (arcrotate): added. (arc): add field "rotate". 2009-04-14 Ito Hiroyuki * src/gtk/ox11menu.c (mxd2p, mxd2px, mxd2py, mxp2d): remove. * src/gtk/x11view.c (mxd2p, mxp2d coord_conv_x, coord_conv_y) (draw_frame_rect, draw_focus_line): added. (GetFocusFrame, ShowFocusFrame, show_focus_line_arc) (draw_frame_rect, ShowFocusLine, ShowPoints, ShowFrameRect) (ShowCrossGauge, get_mouse_cursor_type): use "coord_conv_x()" and "coord_conv_y()". (ShowFocusLine): use "draw_frame_rect()" and "draw_focus_line()". 2009-04-13 Ito Hiroyuki * src/gtk/x11view.c (arc_get_angle, show_focus_line_arc): added. (ShowFocusLine): call "show_focus_line_arc()" when focused object is "arc". (ShowFocusLine): add argument "state". (mouse_up_change): check if the focused object is "arc". * src/oarc.h: added. * src/oarc.c (arcbbox): add points to modify angle. (arcchange): added. (arc): add "change" field. * src/gtk/ogra2cairo.c (gra2cairo_output): do nothing when "a1 == a2" in the case of "code" ic "C". * src/gtk/x11commn.c (ToFullPath): use loop to modify "file" field of "file" and "merge" object. 2009-04-11 Ito Hiroyuki * src/gtk/x11view.c (do_popup): check if the focused object is child of the "legend" object when "num == 1" . 2009-04-10 Ito Hiroyuki * src/gtk/x11view.c (ShowPoints): draw arc and rectangle when "num" is greater or equal to 2. (mouse_move_drag, mouse_move_zoom, mouse_move_change) (mouse_move_scroll, mouse_move_draw): added. (ViewerEvMouseMove): use "mouse_move_drag()", "mouse_move_zoom()", "mouse_move_change()", "mouse_move_scroll()" and "mouse_move_draw()". (get_mouse_cursor_type): return "GDK_TCROSS" when "d->MoveData" is TRUE. 2009-04-09 Ito Hiroyuki * src/gtk/x11view.c (ShowCrossGauge): don't call "gdk_window_get_position()". (ViewerEvMouseMotion): call "gdk_event_request_motions()". (ViewerWinSetup): set GDK_POINTER_MOTION_HINT_MASK to "d->Win". 2009-04-07 Ito Hiroyuki * src/gtk/x11scrip.h: remove. * src/gtk/x11scrip.c: remove. * src/gtk/x11menu.c (script_exec): added. (create_addin_menu): use "script_exec()" as callback. 2009-04-06 Ito Hiroyuki * src/gtk/x11lgnd.c (LegendWinLegendUpdate): remove argument of function "UnFocus()". * src/gtk/x11view.c (clear_focus_obj): remove unused arguments. (UnFocus): remove unused argument "init_cursor". (CloseGC, Clear, CmViewerButtonArm, Focus): remove argument of function "UnFocus()". * src/gtk/x11commn.c (axis_move_each_obj): added. (AxisMove): use "axis_move_each_obj()". * src/gtk/x11axis.c (AxisWinAxisTop, AxisWinAxisLast) (AxisWinAxisUp, AxisWinAxisDown): added. (axiswin_ev_key_down): call "AxisWinAxisTop()", "AxisWinAxisLast()", "AxisWinAxisUp()" and "AxisWinAxisDown()". (Popup_list): set "AxisWinAxisTop()", "AxisWinAxisLast()", "AxisWinAxisUp()" and "AxisWinAxisDown()" to related member. * src/ofit.c (enum FitError, display_equation): added. (fitpoly, fituser, fitfit): use "FitError". (fitpoly, fituser): use "snprintf()" instead of "sprintf()". (fitpoly, fituser): call "display_equation()". (fitpoly, fituser): return "enum FitError". (fitfit): change type of "type" from "int" to "enum FIT_OBJ_TYPE". * demo/demo2.ngp.in: use "fit::calc" for legend text. * src/gtk/x11graph.c (CmGraphHistory, DirectoryDialogClose): remove argument of "ErrorMessage()". * src/gtk/x11file.c (FitDialogSave): check return value of "nopen()". (FitDialogSave): call "ErrorMessage()" instead of "MessageBox()". * src/gtk/x11commn.c (SaveDrawrable): check return value of "nopen()". (SaveDrawrable): call "ErrorMessage()" instead of "MessageBox()". (SaveDrawrable): return "error" instead of "! error". (GraphSave): call "reset_graph_modified()", "changefilename()", "AddNgpFileList()" and "SetFileName()" only when success "SaveDrawrable()". (ErrorMessage): argument of function is now "void". 2009-04-04 Ito Hiroyuki * src/mathcode.c (mathexpand, calculate): new upstream release (6.3.48). * driver/gra2ps.c: new upstream release (6.3.48). * driver/Ngraph.ps: new upstream release (6.3.48). 2009-04-03 Ito Hiroyuki * src/ofit.c (fitfit): use loop to initialize values related to parameters "%0?" and "parameter0?". (fitcalc): added. (fit): add member "calc". * src/omath.c (mparam): bug fix: fix calculation of "m". (struct mlocal): now member "idpm" is array. (msettbl): use loop to set value related to "mlocal->idpm[]". (minit): use loop to set value to "mlocal->idpm[]". 2009-04-02 Ito Hiroyuki * src/gtk/x11graph.c (DirectoryDialogSetup): change width of "d->dir". * src/gtk/ogra2cairo.c (relative_move): added. (draw_str, gra2cairo_output): use "relative_move()" instead of "cairo_rel_move_to()". 2009-04-01 Ito Hiroyuki * src/gtk/x11merge.c (Mlist): gettextize. * src/gtk/x11file.c (Flist): gettextize. * src/gtk/x11axis.c (Alist): gettextize. * src/gtk/x11lgnd.c (legend_list_set_val): just set converted text to tree view when "type" is "LegendTypeText". (Llist): gettextize. (Llist): ellipsize mode of "property" column is "PANGO_ELLIPSIZE_END". * src/gtk/gtk_liststore.c (create_column): add attribute "ellipsize" to "renderer". * src/gtk/gtk_liststore.h (_list_store): add member "ellipsize". * src/ofile.c (search_mask): check if the index "i" of array "mask" is lesser than "n". * src/gtk/x11graph.c (CmHelpHelp, about_link_activated_cb): use "execlp()" instead of "system()". 2009-03-31 Ito Hiroyuki * src/gtk/x11file.c (FileMoveDialogClose): free "ptr". (FileMoveDialogClose): call "set_graph_modified()". * src/gtk/x11opt.c (PrefFontDialogUpdate): free "fontalias". * src/shell.c (shputstdout, shprintfstdout): check return value of "write()". (expand, checkcmd, cmdexec): use "n_mkstemp()" instead of "tempnam()". * src/ioutil.c (n_mkstemp): added. * src/ogra2prn.c (mytempfile): added. (gra2p_output): use "mytempfile()". * src/nconfig.c (replaceconfig_match, removeconfig_match, make_backup): added. (replaceconfig): use "replaceconfig_match()" and "make_backup()". (removeconfig): use "removeconfig_match()" and "make_backup()". (replaceconfig, removeconfig): use "tmpfile()" instead of "tempnam()". (lockconfig): call "msleep()" while checking "configlocked()". 2009-03-29 Ito Hiroyuki * driver/gra2wmf.c (getboundingbox): remove unused variable "exchange". (draw): remove unused variables "lBrush" and "rect". 2009-03-26 Ito Hiroyuki * src/gtk/x11axis.c (NumDialogSetup): arrange widgets. * src/oprm.c (prmload): use "R_OK", "W_OK", "X_OK" for "access()". * src/omerge.c (mergeload): use "R_OK", "W_OK", "X_OK" for "access()". * src/ofile.c (f2dload): use "R_OK", "W_OK", "X_OK" for "access()". * src/nconfig.c (writecheckconfig): use "R_OK", "W_OK", "X_OK" for "access()". * src/ioutil.c (findfilename, nsearchpath, nglob2): use "R_OK", "W_OK", "X_OK" for "access()". * src/ofile.c (f2dload): use "R_OK", "W_OK", "X_OK" for "access()". * src/gra.c (GRAC_INIT_VAL): added. (GRAClist): use "GRAC_INIT_VAL". (get_gra_font): added. (GRAinputold): use "get_gra_font()". * src/shell.c (shputstderr, shprintfstderr): comment out. * src/ogra2.c (gra2disconnect): comment out. * src/object.c (vdisplaywindow, unregisterallevloop) (chkobjectlocal, chkobjproc, getobjproc, getuniqname): comment out. * src/nstring.c (getitok3, getitok4): comment out. * src/ioutil.c (nselectdir, nselectfile): comment out. * src/gra.c (GRAdirect, GRAremark): comment out. * src/gtk/ox11dlg.c (dialogclose): remove. * src/gtk/ogra2cairo.c (FONT_FACE_NUM): added. (check_type): use "FONT_FACE_NUM". * src/gtk/ogra2x11.c (gtkevsize): remove. 2009-03-24 Ito Hiroyuki * src/oprm.c (remarkconv): use "greektable_num()". * src/gra.c (greektable_num): added. (FONTTBL_NUM): added. (GREEK_TBL_NUM): added. (GRAinputold): check index of "fonttbl[]". 2009-03-23 Ito Hiroyuki * src/gtk/ox11menu.c (SetCaption, graph_modified_sub): added. (set_graph_modified, reset_graph_modified): use "graph_modified_sub()". (gtkmenu): field "modified" use function "mxmodified". (mxmodified): added. * src/gtk/x11menu.c (SetCaption): remove. * src/ofile.c (f2dload_sub): added. (f2dload, f2dloaddum): use "f2dload_sub()". * src/gtk/x11file.c (FileDialogSetupItemCommon,start_editing): use "CHK_STR()". * src/gtk/x11axis.c (AxisDialogSetup, AxisCB) (AxisDialogSetupItem, AxisPosDialogSetupItem): use "CHK_STR()". * src/gtk/x11print.c (DriverDialogSelectCB): use "CHK_STR()". * src/gtk/ox11dlg.c (dlgconfirm): use "CHK_STR()". * src/oaxis.c (axisautoscale): return 0 even if the return value of axisautoscalefile() is not 0. 2009-03-20 Ito Hiroyuki * src/gtk/x11print.c (OutputImageDialogSetupItem): sensitivity of dpi settings is FALSE for ps and pdf output. 2009-03-18 Ito Hiroyuki * src/gtk/x11view.c (ViewerWinFileUpdate): use "update_file_obj_multi()". * src/gtk/x11file.c (update_file_obj_multi): added. (CmFileUpdate, CmFileOpen): use "update_file_obj_multi()". 2009-03-17 Ito Hiroyuki * src/gtk/ox11dlg.c (get_sarray_argument): accept multi "sarray"s. 2009-03-12 Ito Hiroyuki * src/gtk/x11menu.h (struct NgraphApp): remove member "Message3". * src/gtk/x11view.c (init_zoom, mouse_up_zoom) (ViewerEvMouseMove): remove "SetZoom()" or "ResetZoom()". (mouse_up_zoom): set coordinate of a mouse to "d->MouseX2" and "d->MouseY2". (ViewerEvLButtonUp): call "SetPoint()" after call "SetCursor()". * src/gtk/x11print.c (CmOutputDriver): call "ResetStatusBar()". * src/gtk/x11menu.c (SetZoom, ResetZoom): remove. 2009-03-11 Ito Hiroyuki * src/gtk/x11menu.c (tool_button_enter_leave_cb): use "SetStatusBarSub()" instead of "SetStatusBarXm()". (SetStatusBarXm): remove. (ResetZoom, SetZoom, ResetStatusBar): use "SetStatusBarSub()" or "ResetStatusBarSub()". (SetStatusBarSub, ResetStatusBarSub): added. * src/gtk/ox11menu.c (mgtkdisplaystatus): use "DisplayDialog()" instead of "DisplayStatus()". * src/gtk/x11graph.c (CmGraphNewFrame, CmGraphNewSection) (CmGraphNewCross, CmGraphAllClear): remove. (CmGraphNewMenu): clear graph and set NULL to "NgraphApp.FileName". call "reset_graph_modified()". * src/gtk/x11view.c (ViewerWinSetup): use "value-changed" signal instead of "change-value" signal for "d->HScroll" and "d->VScroll". (ViewerEvVScroll, ViewerEvHScroll): change return value and argument. don't call "gdk_window_get_position()", "gdk_draw_drawable()", "gdk_drawable_get_size()", "gdk_gc_new()" and "g_object_unre()". (scrollbar_scroll_cb, ViewerEvMouseMove, ViewerEvScroll) (ViewerEvKeyDown): don't call "ViewerEvVScroll()" or "ViewerEvHScroll()" after call "range_increment()". (SetHRuler, SetVRuler): change argument. get size of drawable widget inside the function. 2009-03-10 Ito Hiroyuki * src/gtk/gtk_liststore.c (create_column): set user data with "g_object_set_data()" instead of "g_object_set()". * src/gtk/x11file.c (start_editing_type, start_editing): remove unused variable "list". * src/gtk/x11axis.c (start_editing): remove unused variable "list". * src/gtk/gtk_widget.c (spin_entry_set_range) (spin_entry_set_inc, spin_entry_set_val, spin_entry_get_val) (_create_spin_entry): use "g_object_[gs]et_data()" instead of "gtk_object_[gs]et_user_data()". * src/gtk/gtk_subwin.c (numeric_cb, string_cb, start_editing): use "g_object_[gs]et_data()" instead of "gtk_object_[gs]et_user_data()". * src/gtk/x11lgndx.c (LegendGaussDialogSetup): use "gtk_widget_set_size_request()" instead of "gtk_drawing_area_size()". * src/gtk/x11opt.c (add_str_to_array): remove. * src/gtk/x11lgnd.c (CmOptionTextDef): save and restore modified state. * src/gtk/x11file.c (CmOptionFileDef): save and restore modified state. * src/ofile.c (f2dstore): use "nstrdup()" instead of "memalloc()" to create string "[EOF]\n". (f2dstat, f2dstat2): use "nstrdup()" instead of "memalloc()". * src/osystem.c (sysinit): use "nstrdup()" instead of "memalloc()" to create string "./". * src/ofit.c (fitfit): use "nstrdup()" instead of "memalloc()" to create string "equation". * src/ntime.c (ndate, ntime): use "nstrdup()" instead of "memalloc()". * src/nconfig.c (removeconfig): free "buf" when "change" is FALSE. * src/ioutil.c (fgetline): set NULL to "*buf" when EOF or error. 2009-03-09 Ito Hiroyuki * src/gtk/ox11menu.c (enum menu_config_type): add "MENU_CONFIG_TYPE_CHILD_WINDOW", "MENU_CONFIG_TYPE_HISTORY", "MENU_CONFIG_TYPE_COLOR", "MENU_CONFIG_TYPE_SCRIPT" and "MENU_CONFIG_TYPE_DRIVER". (struct child_win_stat, MenuConfigDriver, MenuConfigScript) (MenuConfigMisc, MenuConfigViewer, MenuConfigGeometry) (MenuConfigChildGeometry, MenuConfigArrray, BUF_SIZE) (add_str_with_int_to_array, add_child_geometry_to_array) (add_geometry_to_array, add_color_to_array) (add_prm_str_to_array, save_ext_driver_config) (save_script_config, add_str_to_array, menu_save_config_sub) (menu_save_config): added. (menu_config_set_child_window_geometry): use "struct child_win_stat *" (addmenu): initialize "MenuConfigHash" with "MenuConfigArrray". * src/gtk/ox11menu.h (enum SAVE_CONFIG_TYPE) (SAVE_CONFIG_TYPE_X11MENU): added. * src/gtk/x11opt.c (CHK_STR, save_font_config, save_misc_config) (save_script_config, save_ext_driver_config, save_viewer_config) (save_child_geometory_config, add_geometry_to_array) (save_geometory_config, add_prm_str_to_array) (SAVE_CONFIG_TYPE_X11MENU, SAVE_CONFIG_TYPE): remove. (save_config): use "menu_save_config()" and "gra2cairo_save_config()". * src/nstring.h (CHK_STR): add * src/gtk/ogra2cairo.c (gra2cairo_save_config): added. * src/oaxis.c (enum axis_config_type): remove. (axisloadconfig): use "obj_load_config()". * src/otext.c (TextConfig): added. (textloadconfig): use "obj_load_config()". (textsaveconfig): use "obj_save_config()". (addtext): initialize "TextConfigHash". * src/ofile.c (f2dinit): use "nstrdup()" instead of "memalloc()". (f2dinit): free "s3" and "s4" when error is occurred. (f2dsaveconfig): use "obj_save_config()". (f2dloadconfig): use "obj_load_config()". (enum file_config_type, struct file_config): remove. * src/oaxis.c (axisinit): use "nstrdup()" instead of "memalloc()". 2009-03-06 Ito Hiroyuki * src/gtk/x11commn.c (LoadPrmFile, LoadNgpFile): call "reset_graph_modified()". * src/gtk/x11view.c (graph_dropped): don't call "reset_graph_modified()". * src/gtk/x11graph.c (CmGraphLoad): don't call "reset_graph_modified()". * src/omerge.c (mergestore): bug fix: buffer over run. use "nstrdup()" instead of "memalloc()". * src/gtk/gtk_liststore.c (create_tree_view): header of the tree view is visible when "n" greater than 1. (list_store_set_sort_all, list_store_set_sort_column): header of the tree view is always visible. * src/gtk/x11view.c (struct viewer_popup): add member "type". (create_menu): create GtkCheckMenuItem when "popup[i].type" is "POP_UP_MENU_ITEM_TYPE_CHECK". (do_popup): set active state of the menu item when i is "POPUP_ITEM_HIDE". (ViewCross): add argument "dtate". * src/gtk/x11merge.c (Popup_list): add initial data for member "type". (POPUP_ITEM_HIDE): add (MergeWinExpose): set active state of the menu item when i is "POPUP_ITEM_HIDE". * src/gtk/x11menu.h (enum pop_up_menu_item_type): added. * src/gtk/x11lgnd.c (Popup_list): add initial data for member "type". (POPUP_ITEM_HIDE): add (LegendWinExpose): set active state of the menu item when i is "POPUP_ITEM_HIDE". * src/gtk/x11file.c (Popup_list): add initial data for member "type". (POPUP_ITEM_HIDE): add (popup_show_cb): set active state of the menu item when i is "POPUP_ITEM_HIDE". * src/gtk/x11axis.c (Popup_list): add initial data for member "type". (POPUP_ITEM_HIDE): added. (popup_show_cb): set active state of the menu item when i is "POPUP_ITEM_HIDE". * src/gtk/gtk_subwin.h (struct subwin_popup_list): add member "type". * src/gtk/gtk_subwin.c (tree_set_hidden_state, set_hidden_state): added. (list_sub_window_hide): use "set_hidden_state()". (tree_sub_window_hide): use "tree_set_hidden_state()" (sub_win_create_popup_menu): create GtkCheckMenuItem when "list[i].type" is "POP_UP_MENU_ITEM_TYPE_CHECK". * src/gtk/ox11menu.c (reset_graph_modified, set_graph_modified): call "SetCaption()". * src/gtk/x11menu.c (SetCaption): no argument. use "ngp" field of "menu" object for file name of the window title. * src/gtk/x11commn.c (LoadPrmFile, LoadNgpFile, GraphSave): don't call "SetCaption()". 2009-03-05 Ito Hiroyuki * src/gtk/x11menu.c (SetPoint): add argument "struct Viewer *d". (SetPoint): show parameter when change, zoom or drag object. (change_window_state_cb): remove. 2009-03-04 Ito Hiroyuki * src/gtk/ogra2x11.c (gtkloadconfig): print warning when unused parameter is appeared. * src/otext.c (textloadconfig): print warning when unused parameter is appeared. * src/gtk/ogra2cairo.c (loadconfig): print warning when unused parameter is appeared. * src/ofile.c (f2dloadconfig): print warning when unused parameter is appeared. * src/gtk/ox11menu.c (mgtkloadconfig): print warning when unused parameter is appeared. * src/oaxis.c (axisloadconfig): print warning when unused parameter is appeared. * src/gtk/x11dialg.h (struct ViewerDialog): remove unused member "redraw". * src/gtk/ox11menu.h (struct menulocal): remove unused member "autoredraw". * src/gtk/x11opt.c (ViewerDialogSetupItem, ViewerDialogClose) (ViewerDialogSetup, save_viewer_config): remove codes related to "Menulocal.autoredraw". * src/gtk/ox11menu.c (mxautoredraw): remove. (MenuConfig, menuinit, gtkmenu): remove codes related to "Menulocal.autoredraw". * src/gtk/x11opt.c (enum SAVE_CONFIG_TYPE) (SAVE_CONFIG_TYPE_X11MENU, save_config): added. (DefaultDialogClose): use "save_config()" to save configuration. (PrefScriptDialogSetup, PrefDriverDialogSetup) (PrefFontDialogSetup, MiscDialogSetup, ExViewerDialogSetup) (ViewerDialogSetup): add a save button. (PrefScriptDialogClose, PrefDriverDialogClose) (PrefFontDialogClose, MiscDialogClose, ExViewerDialogClose) (ViewerDialogClose): save configuration if the save button is clicked. 2009-03-03 Ito Hiroyuki * src/gtk/x11opt.c (save_viewer_config, save_misc_config) (MiscDialogSetupItem, MiscDialogSetup, MiscDialogClose) (ViewerDialogSetupItem, ViewerDialogSetup, ViewerDialogClose): settings for status-bar and ruler are moved from viewer dialog to misc dialog, and setting for line attribute of focus frame is moved from misc dialog to viewer dialog 2009-02-28 Ito Hiroyuki * src/object.c (_newobj, _delobj): static. 2009-02-26 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvMouseMove): don't call "CoordWinSetCoord()". * src/gtk/x11menu.c (SetPoint): call "CoordWinSetCoord()". * src/gtk/ox11menu.c (set_menu_config_mxlocal): remove. (gtkmenu): remove field "_gtklocal". (mx_clear): call "draw_paper_frame()" after call "gdk_draw_rectangle()". (menuinit): unref "Menulocal.pix" if "Menulocal.pix" is not NULL. (menu_config_set_prn_driver): remove. * src/gtk/ox11menu.h (struct menulocal): remove unused member "output", "outputobh", "prnprinterroot". (struct mxlocal): remove mxlocal and use menulocal. (struct prnprinter): remove. * src/gtk/x11opt.c (save_viewer_config, ViewerDialogSetupItem) (ViewerDialogSetup, ViewerDialogClose): add codes related to status bar. * src/gtk/x11menu.c (toggle_status_bar): remove. (show_outputmenu_cb): added. (create_outputmenu): call "g_signal_connect()" for "Output" menu. (show_winmwnu_cb, create_windowmenu): remove codes related to status bar. (SetPoint): add offset to coordinate. * src/gtk/x11opt_proto.h (Pref*DialogMoveSub): added. (Pref*DialogUp, Pref*DialogUp): use Pref*DialogMoveSub. (Pref*ListDefailtCb): respond to "GDK_Up", "GDK_Down" and "GDK_Delete". 2009-02-25 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvLButtonDblClk): use "POINT_TYPE_DRAW_ALL". * src/gtk/x11menu.h (POINT_TYPE_DRAW_ALL): add * src/gtk/x11opt.c (script_free, script_init, extprinter_free) (extprinter_init): added. (PrefScriptDialogUpdate, PrefScriptDialogRemove) (PrefScriptDialogAdd, PrefScriptDialogUp, PrefScriptDialogDown) (script_list_defailt_cb, script_list_sel_cb) (PrefDriverDialogUpdate, PrefDriverDialogRemove) (driver_list_defailt_cb, driver_list_sel_cb) (PrefDriverDialogAdd, PrefDriverDialogUp, PrefDriverDialogDown) (PrefFontDialogUp, PrefFontDialogDown, font_list_defailt_cb) (font_list_sel_cb) : remove (use "x11opt_proto.h"). (PrefScriptDialogSetupItem, PrefDriverDialogSetupItem): remove unused argument. * src/gtk/ogra2cairo.c (free_font_map, create_font_map): remove codes related to "fcur->prev" and so on. * src/gtk/ogra2cairo.h (struct fontmap): remove member "prev". * src/gtk/Makefile.am (libngraph_la_SOURCES): add "x11opt_proto.h". 2009-02-24 Ito Hiroyuki * src/gtk/x11opt.c (PrefScriptDialogUp, PrefScriptDialogDown) (PrefDriverDialogUp, PrefDriverDialogDown, PrefFontDialogUp) (PrefFontDialogDown): add (scriptlist_sel_cb, drvlist_sel_cb, fontlist_sel_cb): set sensitivity of "d->up_b" and "d->down_b". (PrefScriptDialogSetup, PrefDriverDialogSetup) (PrefFontDialogSetup): create GtkButton "d->up_b" and "d->down_b". * src/gtk/x11view.c (ShowPoints, mouse_up_lgend2): use "POINT_TYPE_DRAW1". (ViewerEvLButtonUp): use "POINT_TYPE_POINT". (ViewerEvMouseMove): use "POINT_TYPE_TRIM", "POINT_TYPE_POINT", "POINT_TYPE_DRAW1" and "POINT_TYPE_DRAW2". (ViewerEvKeyDown): use "POINT_TYPE_POINT". (ViewCopy): use "POINT_TYPE_POINT". (ShowPoints): use "POINT_TYPE_DRAW1". (mouse_up_lgend2): use "POINT_TYPE_DRAW1". (ViewerEvMouseMove, ViewerEvPaint): use "Mxlocal->gc" instead of newly created GdkGC. * src/gtk/x11menu.h (POINT_TYPE_POINT, POINT_TYPE_DRAW1) (POINT_TYPE_DRAW2, POINT_TYPE_TRIM): added. * src/gtk/x11menu.c (SetCursor): do nothing when "type" is same as "CursorType". * src/gtk/ox11menu.c (mx_clear): turn off clipping after draw pixmap. * src/gtk/ogra2x11.c (gtkevpaint): turn off clipping after draw pixmap. 2009-02-23 Ito Hiroyuki * src/gtk/ox11menu.c (mx_redraw): call "draw_paper_frame()" after call "GRAredraw()". (check_object_name): added. (mx_get_focused): use "check_object_name()" to check the object is exist in the argument. (gtkmenu): argument type of "focused" is "sa". * src/gtk/x11menu.h (struct Viewer): add member "VRuler" and "HRuler". * src/gtk/x11opt.c (ViewerDialogClose): call "set_widget_visibility()". * src/gtk/x11menu.c (setupwindow): create GtkHRuler and GtkVRuler. (SetPoint): set position of "NgraphApp.Viewer.HRuler" and "NgraphApp.Viewer.VRuler". (set_widget_visibility): added. (application): call "set_widget_visibility()" after call "gtk_widget_show_all()". * src/gtk/x11view.c (MakeRuler): remove. (SetVRuler, SetHRuler): added. (ChangeDPI): call "SetHRuler()" and "SetVRuler()". (ViewerEvHScroll): call "SetVRuler()". (ViewerEvVScroll): call "SetHRuler()". (draw_paper_frame): added. (Draw, create_pix): call "draw_paper_frame()". (ViewerWinSetup): call "ChangeDPI" after initialize "d->cx", "d->cy", "d->hscroll" and "d->vscroll". (ViewerEvPaint): don't call "MakeRuler()". * src/gtk/main.c (my_sprintf): don't change "buf_size" when the return value of "realloc()" is NULL. 2009-02-20 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvPaint): call "gdk_draw_drawable()" even if "GlobalLock" is TRUE. (ViewerEvPaint): don't check "chkobjinstoid(Menulocal.GRAobj, Menulocal.GRAoid)". * demo/demo.ngp: use dialog::check * src/gtk/ox11dlg.c (get_sarray_argument): added. (dlgradio, dlgcombo, dlgcheck): use "get_sarray_argument()". * src/object.c (saveobj, restoreobj): remove. (_copyobj): static function. * src/shellcm.c (cmput): never save and restore image of instance. 2009-02-19 Ito Hiroyuki * src/gtk/ox11dlg.c (dlgradio, dlgcombo, dlgcheck): return 1 when no arguments are given. * src/shell.c (cmdstackfree): call "memfree(stdel->pat)". (cmdstackcat): initialize "stnew->pat". (cmdstackrmlast): call "memfree(stdel->pat)". (cmdexec): set NULL to "st->pat" if "st->pat" will not be used any more. * src/gtk/x11opt.c (PrefScriptDialogRemove): call "memfree(sdel->description)". * src/gtk/ox11menu.c (menudone): call "memfree(sdel->description)". (mx_get_focused): use "arrayfree2()" instead of "memfree()" to free "*rval". * src/gtk/ox11dlg.c (dlggetopenfiles): use "arrayfree2()" instead of "memfree()" to free "*rval". * src/oaxis.c (axisbbox): set NULL to "rval" when return value of "set_axis_box()" is NULL. * src/otext.c (textbbox): set NULL to "rval" after call "arrayfree()". * src/orect.c (rectbbox): set NULL to "rval" after call "arrayfree()". * src/olegend.c (legendbbox): set NULL to "rval" after call "arrayfree()". * src/omerge.c (mergebbox): set NULL to "rval" after call "arrayfree()". * src/omark.c (markbbox): set NULL to "rval" after call "arrayfree()". * src/oline.c (arrowbbox): set NULL to "rval" after call "arrayfree()". * src/ofile.c (f2dgetcoord): set NULL to "rval" after call "arrayfree()". * src/ocurve.c (curvebbox): set NULL to "rval" after call "arrayfree()". * src/oarc.c (arcbbox): set NULL to "rval" after call "arrayfree()". 2009-02-18 Ito Hiroyuki * src/gtk/ox11dlg.c (dlgcombo_entry): remove. (dlgradio, dlgcombo, dlgcheck): check "select" field. (dlgcheck): now "check" field return array of selected index. (dialog): add field "select". * src/gtk/x11gui.c (DialogRadio): initialize state of toggle button by the value of "*r". (DialogCombo, DialogComboEntry): add argument "sel" and activate item related to "sel". (DialogCheck): change type of argument from "int **r" to "int *r". (DialogCheck): initialize state of toggle button by the value of "r[i]". * src/gtk/ox11menu.c (mx_get_focused): return 0 when "num" is less than 1. (mx_echo): added. (gtkmenu): add field "echo". 2009-02-17 Ito Hiroyuki * src/ofile.c (f2ddraw): do "fp->datanum = f2dlocal->num" after call "fitout()" when "fp->datanum" is zero. * src/gtk/x11opt.c (CHK_STR): added. (save_ext_driver_config, save_script_config) (SetScriptDialogSetupItem, SetDriverDialogSetupItem): use "CHK_STR" (PrefScriptDialogAdd): initialize "fnew->description". 2009-02-16 Ito Hiroyuki * src/gtk/x11scrip.c (ScriptDialog, ScriptDialogClose) (ScriptDialogSetup, script_list_default_cb) (ScriptDialogSetupItem): remove. (CmScriptExec): add arguments "GtkWidget *w" and "gpointer client_data". (CmScriptExec): don't use "ScriptDialog". * src/gtk/x11opt.c (save_script_config): save description of the script. (SetScriptDialogSetup): change title from "Script:" to "Script file". (SetScriptDialogSetup): add widgets for script description. (set_scrpt_option): added. (SetScriptDialogClose): use "set_scrpt_option()". (SetScriptDialogClose): save description of the script. (PrefScriptDialogSetup): add column for file name and script description. (PrefScriptDialogSetupItem): set file name and script description. (PrefScriptDialogClose): call "update_addin_menu()". * src/gtk/x11menu.h (enum MenuID): remove "MenuIdScriptExec". * src/gtk/x11menu.c: add global variable "AddinMenu". (show_graphmwnu_cb): set sensitivity of "AddinMenu". (create_addin_menu, update_addin_menu): added. (create_graphmenu): now "Add-In" menu has sub menu. * src/gtk/x11graph.c (CmGraphMenu): remove case for "MenuIdScriptExec". * src/gtk/x11dialg.h (struct ScriptDialog): remove. (struct SetScriptDialog): add member "description". * src/gtk/x11dialg.c: remove unused variable "DlgScript". * src/gtk/ox11menu.h (struct script): add member "description". * src/gtk/ox11menu.c (menu_config_set_script): set description. * initfile/Ngraph.ini.in (script): change format (add description column). 2009-02-13 Ito Hiroyuki * src/object.c (error22): now the type of the argument "mes1" and "mes2" are "const char *". (error2): now the type of the argument "mes" is "const char *". * initfile/Ngraph.ini.in (num_script_size): fix typo (from "num_scriptsize" to "num_script_size"). * src/gtk/x11dialg.c (SetObjPointsFromText): check field of the instance is modified or not after call "sgetobjfield()". (chk_sputobjfield): added. (SetObjFieldFromText, SetObjFieldFromStyle) (SetObjFieldFromFontList, SetObjAxisFieldFromWidget): use "chk_sputobjfield()". * src/gtk/gtk_subwin.c (modify_numeric): check field of the instance is modified or not after call "getobj()". (modify_string): use "chk_sputobjfield()". 2009-02-12 Ito Hiroyuki * src/gtk/x11axis.c (axiswin_delete_axis) (axis_delete_popup_func, axiswin_ev_key_down): added. (CmAxisWindow): initialize "d->ev_key". (Popup_list): "axis_delete_popup_func()" is called when delete menu is activated. * src/oaxis.c (check_direction): also check position of axises. * src/gtk/x11axis.c (Alist): "length" column accept negative value. 2009-02-11 Ito Hiroyuki * src/oaxis.c (axischange): check length of axis instead of position. (FIND_X, FIND_Y, FIND_U, FIND_R, FIND_FRAME, FIND_CROSS) (CHECK_FRAME, CHECK_CROSS): added. (get_axis_group_type): use "FIND_X", "FIND_Y", "FIND_U", "FIND_R", "CHECK_FRAME" and "CHECK_CROSS". (axis_save_groupe): added. (axissave): use "axis_save_groupe()" and "get_axis_group_type()". (struct axis_config, AxisConfig, enum axis_config_type): added. (addaxis): initialize "AxisConfigHash". (axisloadconfig): use "AxisConfigHash". 2009-02-10 Ito Hiroyuki * src/gtk/x11commn.c (GraphSave): "overwrite" is FALSE when "initfil" is NULL. (GraphSave): check overwrite before show save dialog. * src/gtk/x11axis.c (SectionDialogSetup, CrossDialogSetup) (AxisPosDialogSetup): type of spin buttons for width, height and length are "SPIN_BUTTON_TYPE_POSITION". * src/oaxis.c (get_axis_group_type, get_axis_box, set_axis_box): added. (axisbbox): use "get_axis_group_type()", "get_axis_box()" and "set_axis_box()". (axismatch, axismove, axischange, axiszoom): use "get_axis_group_type()". (axis_change_point0, axis_change_point1, axis_change_point2) (axis_change_point3): added. (axischange): use "axis_change_point0()", "axis_change_point1()", "axis_change_point2()" and "axis_change_point3()". (check_direction): added. (axisbbox, axischange): call "check_direction()" to check direction of axises. 2009-02-09 Ito Hiroyuki * src/oaxis.c (axissave, axisbbox, axismatch, axismove) (axischange, axiszoom, axisadjust, axisautoscalefile) (axisdraw): add initialization to avoid compile warnings. (axisautoscalefile): set "set" as TRUE when "set" is FALSE. (axisgrouping): check "data[0]". (set_group, set_group_pos): added. (axisgrouping): use "set_group()". (axisgrouppos): use "set_group_pos()". (axis_default, axis_default_set, axis_default_set_ref) (axis_default_set_adj): added. (axisdefgrouping): use "axis_default()", "axis_default_set_adj()" and "axis_default_set_ref()". (enum AXIS_TYPE, enum AXIS_GAUGE, enum AXIS_NUM_POS) (enum AXIS_NUM_ALIGN, enum AXIS_NUM_DIR): added. * src/omath.c (mformula): use "mathcode_error()". * src/ofit.c (fitput): use "mathcode_error()". * src/omath.c (addmath): initialize "MathErrorCodeArray". * src/ofit.c (addfit): initialize "MathErrorCodeArray". * src/ofile.c (f2dloadconfig2): remove. (mathcode_error): remove. (addfile): initialize "MathErrorCodeArray". * src/mathcode.c (mathcode_error): added. 2009-02-06 Ito Hiroyuki * src/gtk/x11opt.c (add_prm_str_to_array): added. (save_misc_config): use "add_prm_str_to_array()". (save_misc_config): save "coordwin_font". (DefaultDialogClose): call "add_str_to_array()" when "Menulocal.coordwin_font" is NULL. (MiscDialogSetupItem): set font name to "d->coordwin_font" if "Menulocal.coordwin_font" is not NULL. (MiscDialogSetup): create widgets for "Menulocal.coordwin_font". (MiscDialogClose): set selected font to "Menulocal.coordwin_font" and call "CoordWinSetFont()". * src/gtk/x11dialg.h (struct MiscDialog): add member "coordwin_font". * src/gtk/x11cood.c (CoordWinSetFont): added. (CoordWinDrawTex): remove. (CoordWinSetCoord): call "gtk_label_set_text()" instead of "CoordWinSetCoord()". (CoordWinSetCoord): change format strings for "x" and "y" from "%.2f" to "%6.2f". (CoordWinSetCoord): change format strings for axis id from "%d" to "%2d". (CoordWinUpdate): call "label_sub_window_create()" instead of "text_sub_window_create()". * src/gtk/ox11menu.c (MenuConfig): add data for "coordwin_font". (menuinit): initialize "Menulocal.coordwin_font". * src/gtk/ox11menu.h (struct menulocal): add member "coordwin_font". * src/gtk/gtk_subwin.c (sub_window_create): add argument "with_view_port". (sub_window_create): use "gtk_scrolled_window_add_with_viewport()" when "with_view_port" is TRUE. (label_sub_window_create): added. * src/omath.c (mformula): use "switch" to check "rcode". * src/ofile.c (mathcode_error): added. (f2dputmath, fitout): use "mathcode_error()". * src/gtk/x11gui.c (DialogExecute): call "gtk_widget_grab_focus()" when "data->focus" is not NULL. (DialogExecute): call "gtk_widget_show_all()" outside of the loop. (DialogExecute): check "data->show_buttons "outside of the loop. * src/gtk/x11lgnd.c (LegendTextDialogSetup): set poniter of the widget as "d->focus" instead of call "gtk_widget_grab_focus()". * src/gtk/x11graph.c (SaveDialogSetup): set poniter of the widget as "d->focus" instead of call "gtk_widget_grab_focus()". * src/gtk/x11file.c (MarkDialogSetup): set poniter of the widget as "d->focus" instead of call "gtk_widget_grab_focus()". * src/gtk/x11dialg.c (initdialog): initialize member "focus" of each instance of struct. * src/gtk/x11dialg.h (struct DialogType): add member "focus" to dialog related struct. 2009-02-05 Ito Hiroyuki * src/oagrid.c (agriddraw): bug fix: fix calculation of coordinate when "axdir" or "aydir" is 3. (agriddraw): adjust "dirx" and "diry" as these value is greater or equal to zero and less than 36000. * src/oaxis.c (axisdirection): added. (axis): "axisdirection()" is called when field "direction" is changed. * src/odraw.h (enum INTERPOLATION_TYPE): added. * src/mathcode.c (mathcode): return value type of "mathcode()" is "enum MATH_CODE_ERROR_NO". * src/gtk/x11graph.c (DirectoryDialogClose, CmGraphHistory): call "ErrorMessage()" when "chdir()" returns non zero value. * src/gtk/x11commn.c (ErrorMessage): added. * src/gtk/x11file.c (FitDialogSetSensitivity): use "FIT_OBJ_TYPE". (enum MATH_FNC_TYPE): added. (MathTextDialogSetup, MathTextDialogClose): use "MATH_FNC_TYPE". (FitDialogSetSensitivity): use "FIT_OBJ_TYPE". (FileDialogFit, FileDialogType, draw_type_pixbuf, select_type) (start_editing_type, f2dsettings): use "FILE_OBJ_PLOT_TYPE". * src/ofit.c (fitpoly, fitfit): use "FIT_OBJ_TYPE". * src/ofit.h: added. * src/ofile.c (f2ddraw): do "fp->datanum = f2dlocal->num" after call "fitout()" when "redraw" is true. (opendata, rectout, errorbarout, stairout, barout, f2ddraw): use "FILE_OBJ_PLOT_TYPE". (curveout, curveoutfile, f2dsettings): use "INTERPOLATION_TYPE". * src/ofile.h (enum FILE_OBJ_PLOT_TYPE): add 2009-02-04 Ito Hiroyuki * driver/Makefile.am (ngp2, dir_defs.h): depend on Makefile. * src/gtk/Makefile.am (dir_defs.h): depend on Makefile. * src/gtk/ogra2cairo.c (loadfont): remove unused variables "lang" and "lang_ja". (gra2cairo_get_fontmap_num): added. * src/gtk/x11opt.c (save_font_config, save_ext_viewer_config) (save_misc_config, save_script_config, save_ext_driver_config) (save_viewer_config, save_child_geometory_config) (save_geometory_config, add_str_to_array) (add_str_with_int_to_array, add_geometry_to_array): added. (DefaultDialogClose): use "add_str_to_array()", "save_geometory_config()" and so on. (scriptlist_sel_cb, drvlist_sel_cb, fontlist_sel_cb): added. (PrefScriptDialogSetup, PrefDriverDialogSetup) (PrefFontDialogSetup): set signal handler to GtkTreeSelection for "changed" signal. (get_font_alias): added. (set_font_from_font_selection_dialog): use "get_font_alias()". (PrefFontDialogAdd): use "get_font_alias()" and "gra2cairo_get_fontmap()" to check if "alias" is valid string. * src/gtk/x11dialg.h (struct PrefScriptDialog) (struct PrefDriverDialog, struct PrefFontDialog): add member "update_b" and "del_b". * src/gtk/gtk_liststore.c (list_store_set_string) (list_store_path_set_string, tree_store_set_string): type of argument "v" is "const char *". 2009-02-03 Ito Hiroyuki * src/gtk/x11opt.c (DefaultDialogSetup): add "Font aliases" button. (DefaultDialogClose): add codes for save font map. (PrefFontDialogSetupItem, create_font_selection_dialog) (set_font_from_font_selection_dialog, PrefFontDialogUpdate) (PrefFontDialogRemove, PrefFontDialogAdd, font_list_defailt_cb) (PrefFontDialogSetup, PrefFontDialogClose, PrefFontDialog) (CmOptionPrefFont): added. (CmOptionMenu): add case for "MenuIdOptionPrefFont". * src/gtk/x11menu.h (enum MenuID): add "MenuIdOptionPrefFont". * src/gtk/x11menu.c (create_preferencemenu): add menu item "Font aliases". * src/gtk/x11dialg.h (struct PrefFontDialog): added. * src/gtk/x11dialg.c: add global variable "DlgPrefFont". * src/gtk/ogra2cairo.c (FontFaceStr, gra2cairo_get_fontmap) (gra2cairo_remove_fontmap, gra2cairo_add_fontmap, free_fonts) (gra2cairo_update_fontmap, check_type): added. (init_conf, free_conf): use "free_fonts()". (loadconfig): remove unused variable "fcur". (init_conf): use "FontFaceStr". * src/gtk/ogra2cairo.h (struct gra2cairo_local): remove unused member "font_opt". 2009-01-29 Ito Hiroyuki * src/gtk/x11view.c (create_legendx): use "swapint()". 2009-01-28 Ito Hiroyuki * addin/math.nsc: format result with "text::printf". * src/gtk/x11view.c (mouse_down_move): don't check "arraynum(d->focusobj)". (mouse_up_point): remove unused variables "num" and "focused". (mouse_up_point): use "switch" instead of "if". (mouse_up_drag, mouse_up_zoom, mouse_up_change): don't call "SetCursor()". (ViewerEvLButtonUp): call "SetCursor()" when "d->Mode" is "PointB", "LegendB", "AxisB", "TrimB", "DataB" or "EvalB". (get_mouse_cursor_type): return GDK_LEFT_PTR when "num == 0". * src/gtk/x11scrip.c (ScriptDialogClose): initialize "d->execscript" as NULL before check "d->ret". (CmScriptExec): call "delobj(shell, newid)" when "arrayadd()" returns NULL. 2009-01-23 Ito Hiroyuki * debian/Makefile.am: add files for debian package. * src/gtk/x11menu.c (application): call "gtk_widget_show_all()" instead of "gtk_window_present()". 2009-01-20 Ito Hiroyuki * src/gtk/x11file.c (start_editing): treat "id" as oid when "name[0] == '^'". * src/oagrid.c (agridtight): use "obj_do_tighten()". * src/oaxis.c (axistight): use "obj_do_tighten()". * src/ofile.c (f2dtight): use "obj_do_tighten()". * src/object.c (obj_do_tighten): added. 2009-01-18 Ito Hiroyuki * src/gtk/x11merge.c (POPUP_ITEM_TOP, POPUP_ITEM_UP) (POPUP_ITEM_DOWN, POPUP_ITEM_BOTTOM): added. (MergeWinExpose): change sensitivity of popup menu item. * src/gtk/x11lgnd.c (POPUP_ITEM_TOP, POPUP_ITEM_UP) (POPUP_ITEM_DOWN, POPUP_ITEM_BOTTOM): added. (LegendWinExpose): change sensitivity of popup menu item. * src/gtk/x11file.c (POPUP_ITEM_TOP, POPUP_ITEM_UP) (POPUP_ITEM_DOWN, POPUP_ITEM_BOTTOM): added. (popup_show_cb): change sensitivity of popup menu item. (FileDialog): d->multi_open is TRUE when "multi > 0". * src/gtk/x11axis.c (POPUP_ITEM_TOP, POPUP_ITEM_UP) (POPUP_ITEM_DOWN, POPUP_ITEM_BOTTOM): added. (popup_show_cb): change sensitivity of popup menu item. 2009-01-17 Ito Hiroyuki * src/gtk/x11dialg.h (struct FitDialog): add members "through_box", "dim_box", "weight_box", "usr_deriv_box", "usr_def_frame" and "div_box". * src/gtk/x11file.c (FitDialogSetSensitivity): added. (FitDialogSetup): add signal handler for some widgets to change sensitivity of widgets. 2009-01-14 Ito Hiroyuki * src/gtk/x11dialg.h (struct FileDialog): add member "apply_all" and "multi_open". * src/gtk/x11merge.c (MergeDialogSetup): add signal handler for "copy" button. * src/gtk/x11lgnd.c (LegendCurveDialogSetup) (LegendPolyDialogSetup, LegendArrowDialogSetup) (LegendRectDialogSetup, LegendArcDialogSetup) (LegendMarkDialogSetup, LegendTextDialogSetup): add signal handler for "copy" and "copy all" button. * src/gtk/x11file.c (FitDialogSetup, FileMoveDialogSetup) (FileMaskDialogSetup, FileLoadDialogSetup, FileMathDialogSetup) (FileDialogSetup): add signal handler for "copy" button. (FileDialogSetupItem): set sensitivity of "d->apply_all" by "d->multi_open". (FileDialog): initialize "d->multi_open". (FitDialogApply): check "poly_dimension" field is changed or not. (FileMoveDialogSetupItem, FileMoveDialogClose): execute "move_data_adjust" before get "move_data", "move_data_x" and "move_data_y". (FileDialogFit): delete instance of "fit" object when "ret == IDCANCEL" and "create == FALSE". * src/gtk/x11axis.c (GridDialogSetup, AxisBaseDialogSetup) (AxisPosDialogSetup, NumDialogSetup, AxisFontDialogSetup) (GaugeDialogSetup, AxisDialogSetup): add signal handler for "copy" button. (SectionDialogGrid): delete instance of "axisgrid" object when "ret == IDCANCEL" and "create == FALSE". (SectionDialogGrid): don't call "set_graph_modified()" when "axisgrid" object is not created. * src/gtk/x11gui.c (set_sensitivity_by_check_instance): added. (DialogExecute): call "gtk_widget_hide_all()" before call "gtk_widget_show_all()". * src/shellcm.c (dispfield): change field size for field name from 15 to 16. * src/gtk/x11view.c (mouse_down_move_data): execute "move_data_adjust" before get "move_data", "move_data_x" and "move_data_y". * src/oprm.c (prmload): execute "move_data_adjust" before get "move_data", "move_data_x" and "move_data_y". * src/ofile.c (adjust_move_num): added. (file2d): add field "move_data_adjust". (opendata): execute "move_data_adjust" before get "move_data", "move_data_x" and "move_data_y". 2009-01-13 Ito Hiroyuki * src/gtk/x11view.c (menu_activate): added. (ViewerWinSetup): add signal handler for "selection-done" to "d->menu". (Evaluate): cursor type is "GDK_TCROSS" when move data mode. (mouse_down_move_data): check return value of "getobj()" and "getobjlist()" and goto "ErrEnd" when these functions return FALSE. (move_data_cancel): add argument "show_message". (mouse_down_move_data): check return value of "arraynget()". (do_popup): check id of focused object when "num == 1". * src/gtk/x11menu.h (struct Viewer): add member "menu". * src/gtk/x11menu.c (Cursor): add "GDK_TCROSS". (SetCursor): add case "GDK_TCROSS". (setupwindow): initialize "NgraphApp.Viewer.menu". 2009-01-11 Ito Hiroyuki * src/gtk/x11menu.h (enum MouseMode): added. (struct Viewer): member "MouseMode" and "Mode" are enum. * src/gtk/x11view.c (init_zoom): added. (mouse_down_move): use "get_mouse_cursor_type()" to check cursor position. (get_mouse_cursor_type): set "d->ChangePoint". (POINT_LENGTH, FOCUS_FRAME_OFST, FOCUS_RECT_SIZE): added. (ShowFocusFrame, get_mouse_cursor_type): use "FOCUS_RECT_SIZE" and "FOCUS_FRAME_OFST". (ShowPoints): use "POINT_LENGTH". 2009-01-10 Ito Hiroyuki * src/gtk/x11view.c (do_popup): set sensitivity of popup item related to "VIEWER_POPUP_ITEM_UP" and "VIEWER_POPUP_ITEM_DOWN". (create_popup_menu): add "#error" directive to check array size. 2009-01-09 Ito Hiroyuki * src/gtk/x11menu.h (VIEWER_POPUP_ITEM_NUM): change value from 7 to 9. * src/gtk/x11gui.c (GetColor): remove. * src/gtk/x11menu.c (application): change color of "gray" from "#7f7f7f" to "#aaaaaa". 2009-01-08 Ito Hiroyuki * src/gtk/ogra2x11.c (gtkMakeRuler): use "GDK_INVERT" instead of "GDK_XOR". (gtkRGB): remove. * src/gtk/x11lgndx.c (clear_view): don't call "gdk_window_clear()". (LegendGaussDialogSetup): use "value-changed" signal instead of "change-value". * src/gtk/x11opt.c (DefaultDialogClose): use "sub_window_save_geometry()" to get geometry of a sub window. * src/gtk/x11menu.c (CmReloadWindowConfig): use "sub_window_hide()" to hide sub window. * src/gtk/x11info.c (CmInformationWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/x11cood.c (CmCoordinateWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/x11merge.c (CmMergeWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/x11lgnd.c (CmLegendWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/x11axis.c (CmAxisWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/x11file.c (CmFileWindow): use "sub_window_show()" and "sub_window_toggle_visibility()". * src/gtk/gtk_subwin.c (set_geometry): add argument "state" and save window state. (sub_window_save_geometry): save window state. (sub_window_hide, sub_window_show, sub_window_toggle_visibility): added. (cb_del): just call "sub_window_hide()". 2009-01-07 Ito Hiroyuki * src/gtk/x11menu.c (CmReloadWindowConfig): call "sub_window_set_geometry()" after show the window. * src/gtk/x11cood.c (CmCoordinateWindow): call "sub_window_save_geometry()" before hide. (CmCoordinateWindow): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/x11axis.c (CmAxisWindow): call "sub_window_save_geometry()" before hide. (CmAxisWindow): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/x11file.c (CmFileWindow): call "sub_window_save_geometry()" before hide. (CmFileWindow): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/x11lgnd.c (CmLegendWindow): call "sub_window_save_geometry()" before hide. (CmLegendWindow): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/x11merge.c (CmMergeWindow): call "sub_window_save_geometry()" before hide. (CmMergeWindow): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/x11info.c (InfoWinUpdate): call "sub_window_save_geometry()" before hide. (InfoWinUpdate): call "sub_window_set_geometry()" after call "gtk_widget_show_all()". * src/gtk/gtk_subwin.c (sub_window_set_geometry) (sub_window_save_geometry): added. (cb_show): call "sub_window_set_geometry()". (cb_del): call "sub_window_save_geometry()". * src/gtk/x11view.c (ShowFocusFrame): use "Menulocal.focus_frame_type" for line attribute of focus frame. * src/gtk/x11opt.c (DefaultDialogClose): save "Menulocal.focus_frame_type". (MiscDialogSetupItem): setpu "d->fftype". (MiscDialogClose): set "Menulocal.focus_frame_type". * src/gtk/ox11menu.h (struct menulocal): add member "focus_frame_type". * src/gtk/ox11menu.c (MenuConfig): add item for "focus_frame_type". (menuinit): initialize "Menulocal.focus_frame_type". * src/gtk/x11menu.c (show_instance_menu_cb) (set_show_instance_menu_cb, struct show_instance_menu_data): added. (create_filemenu, create_axisgridmenu, create_axismenu) (create_mergemenu, create_outputmenu): call "show_instance_menu_cb()". (create_legendmenu): call "g_signal_connect()" for "show" signal. (create_legendsubmenu): return "menu". 2009-01-06 Ito Hiroyuki * src/object.c: variable "looproot" is static. (has_eventloop): added. * src/shell.c (msleep): added. (cmdexec): don't set "WNOHANG" when "has_eventloop()" returns FALSE. (cmdexec): use "msleep()" after call "eventloop()". * src/shellux.c (cmsleep): use "sleep()" when "has_eventloop()" returns FALSE. (cmsleep): use "msleep()" after call "eventloop()". * demo/demo.ngp.in: added. * src/gtk/gtk_subwin.c (sub_window_create): add argument "xpm2" and call "gtk_window_set_icon_list()" when "xpm2" is not NULL. * src/gtk/x11bitmp.c: add "Axiswin48_xpm", "Coordwin48_xpm", "Filewin48_xpm", "Infowin48_xpm", "Legendwin48_xpm" and "Mergewin48_xpm". * src/gtk/x11menu.c (struct command_data): remove member "xbm". * src/gtk/x11bitmp.c: remove xbm data. * src/gtk/x11menu.c (createpixmap, createicon): use "gdk_pixbuf_new_from_xpm_data()" instead of "create_pixbuf_from_xpm()". * src/gtk/gtk_subwin.c (sub_window_create): use "gdk_pixbuf_new_from_xpm_data()" instead of "create_pixbuf_from_xpm()". * src/gtk/x11menu.c (create_pixbuf_from_xpm): remove. 2009-01-04 Ito Hiroyuki * src/terminal.c (my_signal): added. (main): use "my_signal". * src/gtk/main.c: variables "consolecol", "consolerow", "consolefdout", "consolefdin", "consoleac" and "systemname" are static. (interruptconsole, inputynconsole, displaydialogconsole) (displaystatusconsole): these functions are static. * src/osystem.c (systemresize): don't check "data[0]" and "data[1]". 2009-01-03 Ito Hiroyuki * src/gtk/x11menu.c (create_cursor): use "gdk_cursor_new()" instead of "gdk_cursor_new_for_display()". * src/gtk/main.c: remove global variable "Disp". * src/gtk/x11view.c (OpenGC): don't call "gdk_display_get_default()". * src/gtk/ogra2x11.c (gtkflush): added. * src/gtk/ox11menu.c (mxflush): don't call "gdk_display_flush()". * src/gtk/x11view.c (CloseGC, ReopenGC): don't call "gdk_display_flush()". 2009-01-02 Ito Hiroyuki * src/terminal.c (main): use named pipe. (main): use "pause()" to wait termination. * src/gtk/main.c: global variables "terminal", "consolesave", "consolefd[]" and "consolepid" are static. remove unused variable "pipefd". (nallocconsole): use named pipe. (nfreeconsole): use "kill()" to terminate "nterminal". 2008-12-31 Ito Hiroyuki * src/gtk/main.c (putconsole, printfconsole, inputynconsole) (nallocconsole): check return value of "write()". (nfreeconsole): check value of "pipefd". * src/gtk/ogra2x11.c (gtkflush): remove. (gra2gtk): remove field "flush". (gra2gtk): rename field "redraw" to "expose". (gra2gtk): add field "dpix" and "dpiy". (gtkinit): "gtkevpaint()" is connected to "gtklocal->View". (gdkgc_set_arc_mode, gdkgc_set_fill_rule): remove. (gtkinit): show error message when "OpenApplication()" returns FALSE. 2008-12-30 Ito Hiroyuki * demo/demo.ngp: added. * src/gtk/x11view.c (AlignFocusedObj, ViewDelete, ViewCopy) (ViewCross): do nothing when "Menulock" or "GlobalLock" is TRUE. (mouse_up_zoom): minimum value of "zm" is 1000. * src/gtk/x11opt.c (CmOptionSaveNgp): do nothing when "Menulock" or "GlobalLock" is TRUE. * src/gtk/x11graph.c (CmHelpAbout, CmHelpHelp): do nothing when "Menulock" or "GlobalLock" is TRUE. * src/gtk/ogra2x11.c (gtkclear): clear pixmap. (gtk_set_dpi): added. (gra2gtk): add filed "dpi". * src/gtk/x11scrip.c (CmScriptExec): use "menu_lock()" to lock gui. * src/gtk/x11menu.c (menu_lock): add * src/gtk/x11graph.c (CmGraphShell): use "menu_lock()" to lock gui. * src/gtk/x11file.c (select_type, start_editing_type) (start_editing, edited_axis): use "menu_lock()" to lock gui. * src/gtk/x11commn.c (LoadNgpFile): use "menu_lock()" to lock gui. (LoadNgpFile): call "registerevloop()" and "unregisterevloop()" before and after call "_exeobj()" respectively. * src/gtk/x11axis.c (start_editing, edited): use "menu_lock()" to lock gui. * src/gtk/ox11menu.c (mx_print): use "menu_lock()" to lock gui. (gtkmenu): type of "print" field is "NVFUNC". * src/gtk/gtk_subwin.c (start_editing, cancel_editing) (numeric_cb, string_cb): use "menu_lock()" to lock gui. * src/shellux.c (cmsleep): call "sleep()" while waiting timeout. 2008-12-28 Ito Hiroyuki * src/gtk/x11view.c (mouse_up_drag): move object only when "dx != 0 || dy != 0". (mouse_up_change): change object only when "dx != 0 || dy != 0". (mouse_up_zoom): zoom object only when "zm != 0 && zm != 10000". 2008-12-26 Ito Hiroyuki * src/omark.c (marktype): added. (mark): check marktype. * demo/demo5b.ngp (text): maximum value of "i" is 8. * src/gtk/x11view.c (ShowFrameRect, ShowPoints, ShowFocusLine) (ShowFocusFrame): do not call "gdk_gc_set_dashes()". * src/gtk/x11lgndx.c (LegendGaussDialogPaint): do not call "gdk_gc_set_dashes()". * src/gtk/x11dialg.c: remove variables "Dashes" and "DashesNum". * src/gtk/x11view.c (get_mouse_cursor_type): bug fix: fix conditions for "GDK_TOP_RIGHT_CORNER". * src/gtk/ogra2cairo.c (draw_str): create PangoLayoute only when "local->layout" is NULL. (gra2cairo_init): initialize "local->layout". (gra2cairo_free): unref "local->layout" if "local->layout" is not NULL. * src/gtk/ogra2cairo.h (struct gra2cairo_local): add member "layout". 2008-12-25 Ito Hiroyuki * initfile/.Ngraph: add "-gra" option. do not create new "gra" object after evaluate ngp file. 2008-12-22 Ito Hiroyuki * src/gtk/x11view.c (new_merge_obj, new_file_obj) (text_dropped, ViewerWinFileUpdate, Evaluate, Trimming) (AlignFocusedObj, mouse_down_move_data, mouse_up_drag) (mouse_up_zoom, mouse_up_change, create_legend1, create_legend2) (create_legend3, create_legendx, create_single_axis) (create_axis, ViewerEvKeyUp, ViewUpdate, ViewDelete) (reorder_object, ViewCopyAxis, ViewCopy): use "set_graph_modified()". (graph_dropped): use "reset_graph_modified()". * src/gtk/x11merge.c (CmMergeOpen, CmMergeClose, CmMergeUpdate): use "set_graph_modified()". * src/gtk/x11lgnd.c (legend_dialog_close, CmLineDel) (CmLineUpdate, CmCurveDel, CmCurveUpdate, CmPolyDel) (CmPolyUpdate, CmRectDel, CmRectUpdate, CmArcDel, CmArcUpdate) (CmMarkDel, CmMarkUpdate, CmTextDel, CmTextUpdate) (LegendWinLegendUpdate): use "set_graph_modified()". * src/gtk/x11graph.c (CmGraphSwitch, CmGraphPage): use "set_graph_modified()". (CmGraphLoad, CmGraphHistory): use "reset_graph_modified()". * src/gtk/x11file.c (MathDialogList, FileMaskDialogClose) (FileLoadDialogClose, FileDialogCopyAll, CmFileHistory) (CmFileNew, CmFileOpen, CmFileClose, CmFileUpdate) (FileWinFileDelete, file_obj_copy, FileWinFileUpdate) (FileWinFileDraw, select_type, edited_axis): use "set_graph_modified()". * src/gtk/x11dialg.c (SetObjPointsFromText, SetObjFieldFromText) (SetObjFieldFromSpin, SetObjFieldFromToggle) (SetObjFieldFromStyle, SetObjFieldFromList) (SetObjFieldFromFontList, SetObjAxisFieldFromWidget) (_putobj_color): use "set_graph_modified()". * src/gtk/x11commn.c (CheckSave): use "get_graph_modified()". (GraphSave): use "reset_graph_modified()". * src/gtk/x11axis.c (SectionDialogGrid, CmAxisNewFrame) (CmAxisNewSection, CmAxisNewCross, CmAxisNewSingle, CmAxisDel) (CmAxisZoom, CmAxisClear, CmAxisGridNew, CmAxisGridDel) (CmAxisGridUpdate, AxisWinExpose, edited): use "set_graph_modified()". * src/gtk/ox11menu.h: add prototype of "get_graph_modified", "reset_graph_modified" and "set_graph_modified". * src/gtk/ox11menu.c (get_graph_modified, reset_graph_modified) (set_graph_modified): add (menuinit): initialize "modified" field. (gtkmenu): add "modified" field. * src/gtk/gtk_subwin.c (copy, delete, move_top, move_last) (move_up, move_down, modify_numeric, modify_string, hidden) (tree_copy, tree_delete, tree_move_top, tree_move_last) (tree_move_up, tree_move_down, tree_hidden): use "set_graph_modified()". * addin/math.nsc: set +e and check return value of dexpr. * src/gtk/x11dialg.h (struct MiscDialog): add menber "Obj" and "Id". * src/gtk/x11menu.c (init_ngraph_app_struct): initialize "NgraphApp.Interrupt". * src/gtk/x11menu.h (struct NgraphApp): remove unused member "interrupt" and "Changed". * src/gtk/x11opt.c (ViewerDialogClose): call "putobj()" to set "redraw_num" field. (MiscDialog): add argument "struct objlist *obj" and "int id". (CmOptionMisc): add argument to call "MiscDialog()". (MiscDialogClose): call "putobj()" to save "data_head_lines". * src/gtk/ox11menu.c (gtkmenu): type of "redraw_num" field is "NINT". 2008-12-20 Ito Hiroyuki * src/gtk/ox11menu.c (menuerrorlist): add message "cannot open display.". (enum): add error identifier. (menuinit): call "error()" when "OpenApplication()" returns FALSE. * src/gtk/ox11dlg.c (dlginit): call "error()" when "OpenApplication()" returns FALSE. 2008-12-19 Ito Hiroyuki * src/ofile.c (set_data_progress): check if "frac" is greater than 1 or not. 2008-12-18 Ito Hiroyuki * src/gtk/x11menu.c (kill_signal_handler): added. (childhandler): use "sigaction()" instead of "signal()". (AppMainLoop): call "CheckSave()" when "Hide_window" is TRUE. (application): use "sigaction()" instead of "signal()". (application): set signal handler for "SIGINT" signal. * src/gtk/x11graph.c (CmGraphQuit): just call "QuitGUI()". * src/gtk/x11opt.c (MiscDialogSetup): change design of the dialog. * src/gtk/x11view.c (enum ViewerPopupIdn): add "VIEW_UP" and "VIEW_DOWN". (enum object_move_type): added. (create_popup_menu): add up and down object menu item. (ViewerPopupMenu): add case "VIEW_DOWN" and "VIEW_UP". (reorder_object): change argument from int to "enum object_move_type". * src/gtk/ogra2cairo.c (gra2cairo_output): don't draw arc if "w" or "h" is 0 in the case of "code" is 'C'. * src/otext.c (textzoom): minimum value of "pt" is 1. * src/orect.c (rectzoom): minimum value of "width" is 1. * src/omark.c (markzoom): minimum value of "size" and "width" is 1. (markgeometry): use temporal variable "val". * src/olegend.c (legendzoom): minimum value of "width" is 1. * src/oarc.c (arcgeometry): use temporal variable "val". (arczoom): minimum value of "rx", "ry", and "width" is 1. 2008-12-17 Ito Hiroyuki * src/gtk/x11file.c (FileWinFileDraw): check if the graph is changed or not. * src/oline.c (arrowbbox): bug fix: add valiable "num2" and "num2" is used only to calculate positions of an arrow. * src/gtk/x11view.c (Match): return matched instance number. (mouse_up_point): change cursor if any object is focused. * src/gtk/ox11menu.c (gtkmenu): add field "draw". (mxdraw): added. (mx_redraw): call "gdk_window_invalidate_rect()". * src/gtk/x11merge.c (MergeDialogSetup): use "gtk_check_button_new_with_mnemonic()" instead of "gtk_check_button_new_with_label()". * src/gtk/x11gui.c (FileSelectionDialog): use "gtk_check_button_new_with_mnemonic()" instead of "gtk_check_button_new_with_label()". 2008-12-16 Ito Hiroyuki * src/gtk/x11view.c (struct viewer_popup): add member "submenu_item_num". (create_menu): add argument "int n". (create_menu): add separator when "popup[i].title" is NULL. (create_popup_menu): add separator to menus. * src/gtk/x11merge.c (Mlist): add separator. (Mlist): "file" column is editable. * src/gtk/x11lgnd.c (Popup_list): add separator. * src/gtk/x11file.c (Flist): minimum value of "step" is 1. (Popup_list): add separator. * src/gtk/x11axis.c (Popup_list): add separator. (Popup_list): add clear menu item. (axiswin_scale_clear): added. * src/gtk/gtk_subwin.c (sub_win_create_popup_menu): add "GtkSeparatorMenuItem" when "list[i].title" is NULL. 2008-12-15 Ito Hiroyuki * src/gtk/x11menu.c (find_gra2gdk_inst): bug fix: always get "_local" field. 2008-12-12 Ito Hiroyuki * src/gtk/ogra2x11.c (struct gtklocal): remove unused member "autoredraw", "cmap" and "minus_hyphen". (gra2gtk): remove unused field "auto_redraw". * src/gtk/ox11menu.h (struct mxlocal): remove unused member "privatecolor", "cmap", "cdepth", "cairo_save", "minus_hyphen" and "points". (struct menulocal): remove unused member "mousecloick" and "movechild". * src/gtk/x11menu.c (createcommand1, createcommand2): check "Menulocal.showtip". * src/gtk/gtk_liststore.c (create_column): set page_size of GtkAdjustment as 0. 2008-12-09 Ito Hiroyuki * src/shellcm.c (cmecho): add "-n" option. 2008-12-03 Ito Hiroyuki * src/ofile.c (getdata_skip_step): call "memfree(buf)" when "rcode" is 1 or -1. 2008-12-02 Ito Hiroyuki * src/ofile.c (search_mask): added. (getdata_sub2, getdata2, getdataraw): use "search_mask()". (struct f2ddata): add member "mask_index". (opendata, reopendata): initialize "fp->mask_index". 2008-12-01 Ito Hiroyuki * src/gtk/ox11dlg.c * src/gtk/x11gui.c (DialogRadio, DialogCombo, DialogCheck): add label if "caption" is not NULL. (DialogComboEntry): added. * src/gtk/ox11dlg.c (dlgconfirm, dlgmessage, dlgradio, dlgcombo) (dlgcheck): check and use "title" field. (dlginput, dlgradio, dlgcombo, dlgcheck): check and use "caption" field. (dlgcombo_entry): added. (dialog): add "combo_entry", "title" and "caption" field. 2008-11-28 Ito Hiroyuki * src/gtk/ox11dlg.c (dlggetopenfile, dlggetopenfiles) (dlggetsavefile): second argument is used as an initial file name. * src/gtk/x11gui.c (FileSelectionDialog): check "type" before call set name. (fsok): check "filter". * src/gtk/ox11dlg.c (dlgcombo): added. (dialog): add field "combo". (dlggetsavefile, dlggetopenfile): use "memfree()" to free "*(char **)rval". * src/gtk/x11gui.c (DialogCombo): added. * demo/encoding.ngp: use "dialog::combo" instead of "dialog::input". 2008-11-27 Ito Hiroyuki * src/gtk/ox11dlg.c (dlgcheck, dlgradio): added. (dialog): add fields "radio" and "check". now all functions dfined in ox11dlg.c is static. * src/gtk/x11gui.h: add prototype of "DialogCheck" and "DialogRadio" * src/gtk/x11gui.c (DialogCheck, DialogRadio): added. * src/gtk/ox11menu.h (struct menulocal): remove unused member "framex", "framey" and "exwinbackingstore". (struct mxlocal): remove unused member "backingstore". * src/gtk/ox11menu.c (enum menu_config_type) (menu_config_menu_geometry, menu_config_file_geometry) (menu_config_axis_geometry, menu_config_legend_geometry) (menu_config_merge_geometry, menu_config_dialog_geometry) (menu_config_coord_geometry, struct menu_config, MenuConfig) (MenuConfigHash, menu_config_set_four_elements) (menu_config_set_window_geometry, menu_config_set_bgcolor) (menu_config_set_ext_driver, menu_config_set_prn_driver) (menu_config_set_script, set_menu_config_mxlocal): added. (addmenu): initialize "MenuConfigHash". (mgtkloadconfig, mgtkwindowconfig): use "FileConfigHash". 2008-11-26 Ito Hiroyuki * src/ofile.c add global valiable "FileConfigHash". (enum file_config_type, struct file_config, FileConfig): added. (f2dloadconfig): use "FileConfigHash". (addfile): initialize "FileConfigHash". * src/gtk/ox11menu.h (struct mxlocal): remove unused member "fontalias". * src/gtk/x11dialg.c (SetObjFieldFromFontList): free "fontalias". * src/gtk/main.c (get_obj_font_list): use "Gra2cairoConf->font_num". * src/gtk/ogra2cairo.c (free_font_map): added. (create_font_map): added. (loadconfig): use "create_font_map()" (init_conf): initialize "Gra2cairoConf->font_num". (free_fonts_sub): added. (free_conf): use "nhash_each" and "nhash_free" to free font maps. (loadfont): remove second argument and return "struct fontmap *". (loadfont): remove codes related with " Gra2cairoConf->font". (draw_str): change 4th argument. (gra2cairo_output): use "local->loadfont". * src/gtk/ogra2cairo.h: remove definition of "struct fontlocal". (struct fontmap): add member "PangoFontDescription *font". (struct fontmap): add member "struct fontmap *prev". (struct gra2cairo_local): remove member "loadfontf" and add member "loadfont". 2008-11-25 Ito Hiroyuki * src/orect.c (rect): use "oputcolor()" to set value to fields "R2", "G2" and "B2". * src/omark.c (mark): use "oputcolor()" to set value to fields "R2", "G2" and "B2". * src/ofile.c (file2d): use "oputcolor()" to set value to fields "R2", "G2" and "B2". * src/odraw.c (draw): use "oputcolor()" to set value to fields "R", "G" and "B". * src/oroot.h: add prototype of "oputcolor()". * src/oroot.c (oputcolor): added. * src/gtk/x11dialg.c (SetFontListFromObj): use "Gra2cairoConf->fontmap_list_root" instead of "Gra2cairoConf->fontmaproot". (SetFontListFromObj): bug fix: check if "font" is NULL or not. (SetFontListFromObj): default value of "selfont" is now 0. (SetObjFieldFromFontList): use hash to search font alias. (_set_color): check value of "R", "G" and "B". * src/gtk/ogra2cairo.h (struct gra2cairo_config): add member "fontmap_list_root". * src/gtk/ogra2cairo.c: add global valiable "FontFace". (loadconfig): save font configuration to hash. (init_conf): init "FontFace" and "Gra2cairoConf->fontmaproot". (free_conf): use "nhash_free_with_memfree_ptr()" to free fontmap. (loadfont, gra2cairo_charheight): use hash to search font alias settings. * src/gtk/main.c (get_obj_font_list): use "Gra2cairoConf->fontmap_list_root" instead of "Gra2cairoConf->fontmaproot". * src/nhash.h: add prototype of "nhash_num()". * src/nhash.c (count_hash, nhash_num): added. 2008-11-21 Ito Hiroyuki * src/gra.c (GRAcharascent, GRAchardescent, GRAcharwidth): return calculated value when return value of "__exeobj()" is not zero. 2008-11-18 Ito Hiroyuki * initfile/.Ngraph: use new gra to create image file. * driver/ngp2.in: added. * driver/Makefile.am (ngp2): added. (bin_SCRIPTS): added. 2008-11-17 Ito Hiroyuki * src/ogra.c (oGRAopen): put error message when the return value of "GRAinit()" is false. * src/gra.c (GRAinit): don't return "ERROPEN" when "GRAClist[GC]output == -1". 2008-11-16 Ito Hiroyuki * src/nhash.c (create_hash_with_hkey): fix condition (from "lr == -1" to "lr < 0"). * src/gtk/main.c (main): check return value of "newobj()" and "chkobjinst()". 2008-11-12 Ito Hiroyuki * src/gtk/x11graph.c (CmGraphShell): create new instance when there are no instances of "shell" object. * src/shell.h (struct nshell): add member "deleted". * src/shell.c (cmdexecute): exit loop when "nshell->deleted" is true. (newshell): initialize "nshell->deleted". * src/oshell.c (cmddone): if "shlocal->lock" is true, set "shlocal->nshell->deleted" as 1. (cmdshell): exit roop when "nshell->deleted" is true. (cmdshell): call "delshell()" when "nshell->deleted" is true. * src/nhash.c (nhash_del_with_hkey, nhash_del): check "h". 2008-11-10 Ito Hiroyuki * src/gtk/x11file.c (FileDialogType): set sensitivity of parent widgets. * src/gtk/x11opt.c (use_external_toggled): set sensitivity of parent widgets. * src/gtk/x11graph.c (pagelist): fix label string of "Legal L". (PageDialogPage): set sensitivity of parent widgets. 2008-11-07 Ito Hiroyuki * src/gtk/x11menu.c (get_home): added. (createmenu): load accel map when "KEYMAP_FILE" is exist in "NGRAPH_HOME". * src/object.h (struct objlist): add member "fieldnum". * src/object.c (addobject): initialize "objnew->fieldnum". (chkobjfieldnum): return "obj->fieldnum" when value of "obj->fieldnum" is valid. 2008-11-06 Ito Hiroyuki * src/shell.c (saveval): bug fix: "valcur->next" is NULL when "name" is found in nshell->valroot. * src/gtk/x11print.c (DriverDialogClose): change buffer size of a message. * src/shellcm.c (printexp): added. (cmexport, cmset): use hash when "USE_HASH" is true. * src/shell.c (create_vallist, free_vallist): added. (addval, saveval, restoreval, addexp, delval, getval, getexp) (newfunc, addfunc, getfunc, cmdexec, newshell, delshell): use hash when "USE_HASH" is true. * src/object.c (ARGBUFNUM): change value from 10 to 32. * src/nhash.c (free_hash_list): add argument "free_ptr". (free_hash_list): call memfree() when "free_ptr" is true. (nhash_free): add second argument. (nhash_free_with_memfree_ptr, create_hash_with_hkey) (nhash_set_int_with_hkey, nhash_set_ptr_with_hkey) (nhash_get_with_hkey, nhash_get_int_with_hkey) (nhash_del_with_hkey, nhash_get_ptr_with_hkey): added. 2008-10-23 Ito Hiroyuki * src/ofile.c: add macro "check_infinite()". (getdataarray, f2dsettings): use "check_infinite()". 2008-10-22 Ito Hiroyuki * src/ofile.c (f2dinit): initialize "line_join" as "bevel". 2008-10-20 Ito Hiroyuki * src/gtk/main.c (main): call 'init_cmd_tbl()'. * src/shellcm.c (cmtype): use 'check_cpcmd()' and 'check_cmd()'. * src/shell.c (init_cmd_tbl, check_cmd, check_cpcmd): added. (checkcmd): use 'check_cpcmd()'. (cmdexec): use 'check_cmd()'. 2008-10-17 Ito Hiroyuki * src/shell.c (cmdtable): add setting for 'seq'. * src/shellcm.c (cmseq): added. 2008-10-10 Ito Hiroyuki * src/gtk/x11graph.c (set_objlist_btn_state) (set_drawlist_btn_state): added. (SwitchDialogAdd, SwitchDialogInsert, SwitchDialogRemove): call set_drawlist_btn_state() after call SwitchDialogSetupItem(). (SwitchDialogSetup): set_drawlist_btn_state() and set_objlist_btn_state() after call SwitchDialogSetupItem(). (drawlist_sel_cb, objlist_sel_cb): added. * src/gtk/x11dialg.h (struct SwitchDialog): add member "top", "up", "down", "bottom", "del", "ins", "add" and "btn_lock". 2008-10-08 Ito Hiroyuki * src/gtk/x11graph.c (SwitchDialogDown, SwitchDialogUp): added. (SwitchDialogSetup): add 'GO UP' and 'GO DOWN' button. (SwitchDialogLast): select last item after move object. (SwitchDialogTop): select first item after move object. * src/gtk/x11view.c (ViewDelete): set mouse cursor to GDK_LEFT_PTR after delete objects. * src/otext.c (textprintf): add 'G' to the conversion specifier. (textprintf): check format string. * src/gra.c (GRAexpandpf): add 'G' to the conversion specifier. (GRAexpandpf): check format string. 2008-10-07 Ito Hiroyuki * src/gtk/x11scrip.c (CmScriptExec): call gdk_window_invalidate_rect() after execute script. 2008-10-06 Ito Hiroyuki * src/gtk/x11file.c (FileMaskDialogClose): don't check if the line number is already contained in mask. * call arrayuniq_int() after call arrayuniq_int(). * src/object.c (arrayndel): use memmove() instead of memcpy(). (arrayuniq_int): add * src/gtk/x11view.c (Evaluate): call file::modified when add mask points. * src/ofile.c (opendata): initialize fp->num. (closedata): add argument "f2dlocal". (closedata): set fp->datanum to f2dlocal->num. (f2ddone, getminmaxdata, f2ddraw, f2devaluate, f2dopendata) (f2dgetdata, f2dclosedata, f2dopendataraw, f2dgetdataraw) (f2dclosedataraw, f2dstat, f2dstat2, f2dboundings) (f2doutputfile): add argument to closedata(). (get_mtime): added. (f2dstat): use get_mtime() to check mtime. (fitout): remove closedata(). 2008-10-03 Ito Hiroyuki * src/ofile.c (update_mask): added. (file2d): use update_mask() for "mask" field. (getdataraw, getdata2, getdata_sub2): use bsearch_int() to check mask. * src/gtk/x11view.c (Evaluate): add masked line as sorted. * src/object.c (cmp_func_int, arraysort_int): added. * src/mathfn.c (bsearch_int): added. 2008-09-25 Ito Hiroyuki * src/gtk/x11view.c (ViewerEvKeyDown): add case "GDK_Page_Up" and "GDK_Page_Down". (ViewerEvKeyDown): in case of GDK_Down, GDK_Up, GDK_Left and GDK_Right, scroll screen if no objects are focused. 2008-09-24 Ito Hiroyuki * src/ofile.c (getdata_sub2, getdata_skip_step): added. (getdata_sub1): use getdata_sub2(). (struct f2ddata): use enum instead of int for 'type'. 2008-09-23 Ito Hiroyuki * initfile/.Ngraph (check_set): added. * initfile/.Ngraph: use check_set to initialize file object. 2008-09-22 Ito Hiroyuki * src/ofile.c (struct f2ddata): add member 'mtime' and 'interrupt'. (opendata): set mtime to 'fp->mtime'. (check_mtime): added. (getminmaxdata): call check_mtime() and hskipdata(). (f2ddraw, f2devaluate, f2dopendata, f2dstat, f2dstat2) (f2dboundings, f2doutputfile): remove check_mtime() placed before getminmaxdata(). (f2dstat): check if 'f2dlocal->mtime == fp->mtime'. 2008-09-19 Ito Hiroyuki * src/gtk/x11file.c (FileMoveDialogAdd, FileMoveDialogRemove) (FileMoveDialogCopy): set 'd->changed' as 'TRUE'. (FileMoveDialogClose, FileMaskDialogClose): do nothing when 'd->changed' is 'FALSE'. (FileMaskDialog, FileMoveDialog): initialize 'data->changed'. * src/gtk/gtk_widget.h (enum SPIN_BUTTON_TYPE): add 'SPIN_BUTTON_TYPE_NATURAL'. * src/gtk/gtk_widget.c (create_spin_entry_type): add case 'SPIN_BUTTON_TYPE_NATURAL' * src/gtk/x11dialg.h (struct FileMoveDialog) (struct FileMaskDialog): add member 'changed'. * src/gtk/x11view.c (ViewerWinFileUpdate, ViewUpdate): set 'NgraphApp.Changed' as 'TRUE' only when return value is 'IDDELETE'. * src/gtk/x11merge.c (CmMergeClose): set 'NgraphApp.Changed' as 'TRUE' only when return value is 'IDDELETE'. * src/gtk/x11lgnd.c (legend_dialog_close): check if the value is really changed. (CmLineUpdate, CmCurveUpdate, CmPolyUpdate, CmRectUpdate) (CmArcUpdate, CmMarkUpdate, CmTextUpdate, LegendWinLegendUpdate): set 'NgraphApp.Changed' as 'TRUE' only when return value is 'IDDELETE'. * src/gtk/x11file.c (MathDialogList): remove AddMathList(). (MathDialogList): check if the math text is really changed. (FitDialogApply): do not set 'TRUE' to 'NgraphApp.Changed'. (FileLoadDialogClose): check if the ifs text is really changed. (FileDialogCloseCommon): call SetObjAxisFieldFromWidget(). (FileDefDialogClose): remove duplicate settings. * src/gtk/x11axis.c (CmAxisUpdate, CmAxisGridUpdate): do not set 'TRUE' to 'NgraphApp.Changed' when the return value is not IDOK. * src/gtk/x11file.c (FileDialogCloseCommon): use SetObjAxisFieldFromWidget(). * src/gtk/x11axis.c (GridDialogClose, AxisPosDialogClose) (AxisDialogClose): use SetObjAxisFieldFromWidget(). * src/gtk/x11dialg.c (SetObjPointsFromText, SetObjFieldFromText) (SetObjFieldFromSpin, SetObjFieldFromToggle) (SetObjFieldFromStyle, SetObjFieldFromList) (SetObjFieldFromFontList, _putobj_color): check if the value is really changed. (SetObjAxisFieldFromWidget): add * src/gtk/gtk_subwin.c (update): do not set 'TRUE' to 'NgraphApp.Changed'. * src/ofile.c (struct f2dlocal): add member "sumx, sumy, sumxx, sumyy, sumxy, minx, maxx, miny, maxy, num and mtime". (f2dfile, f2dput): set 'f2dlocal->mtime' as 0. (update_field, foputabs, foputge1): added. (getminmaxdata): add argument 'local'. (f2ddraw, f2devaluate, f2dopendata, f2dstat, f2dstat2) (f2dboundings, f2doutputfile): add argument to getminmaxdata(). 2008-09-18 Ito Hiroyuki * src/ofile.c (opendata): check mtime of the file. (file2d): add field "mtime". * src/gtk/x11commn.c (FileAutoScale): return when fail to allocate memory. * src/ofile.c (f2dbounding): return 1 when error is occurred. * src/oaxis.c (axisautoscalefile): check the return value of getobj(). (axisautoscale): return 1 when the return value of axisautoscalefile() is not 0. * src/gtk/x11print.c (CmPrintDataFile): check the return value of exeobj(). * src/gtk/ogra2gtkprint.c (create_cairo): show error message when error is occurred. * src/ofile.c (f2doutputfile): show error message when error is occurred. * src/gtk/x11menu.c (PutStdout, PutStderr): convert string from locale to UTF-8. 2008-09-17 Ito Hiroyuki * src/gtk/x11print.c (draw_gra): check the return value of exeobj(). * src/gtk/x11gui.c (fsok): set NULL to data->ext when filer name is "All". (fsok): call error22() after call gdk_beep(). * src/gtk/ogra2cairofile.c (create_cairo): add argument 'err' and set cairo_status to err. (gra2cairofile_output): call error2() when some error is occurred in the case of 'I' and 'E'. (addgra2cairofile): add error messages. * src/gtk/ogra2cairo.c (check_cairo_status): added. (gra2cairo_flush): call check_cairo_status(). (gra2cairo_output): call check_cairo_status() in the case of 'I' and 'E'. (addgra2cairo): add error messages. * src/ogra.c (oGRAopen): check the return value of GRAinit(). * src/gra.c (GRAreopen, GRAdraw, GRAinit, GRAend): return int. * src/ogra.h (ERROPEN): added. 2008-09-16 Ito Hiroyuki * src/object.c (add_obj_to_hash): added. (addobject): set object name and table position to hash. (chkobject): use hash to search object. (chkobjtblpos): use hash to search table position. (chkobjoffset, chkobjfield): use chkobjtblpos(). * src/object.h (struct objlist): add member 'table_hash'. * src/nhash.h: added. * src/nhash.c: added. 2008-09-12 Ito Hiroyuki * src/gtk/x11opt.c (DefaultDialogClose, ExViewerDialogSetupItem) (ExViewerDialogSetup): add settings for 'use_external'. (use_external_toggled): added. * src/gtk/ox11menu.h (struct menulocal): add member "exwin_use_external". * src/gtk/x11dialg.h (struct ExViewerDialog): add member "use_external". * src/gtk/x11print.c (draw_gra): use 'exeobj()' to call "open" member function. (CmOutputViewer): add argument 'select_file'. (CmOutputViewer): use "menu::print" instead of "gra2gtk". (CmOutputMenu, CmOutputViewerB): add argument to call CmOutputViewer(). (CmOutputPrinterB): now second argument of CmOutputPrinter() is 'FALSE'. * src/shellcm.c (cmset): use memmove(). (cmobject): fix typo ("filed" to "field"). * src/object.c (arrayndel2): use memmove(). 2008-09-11 Ito Hiroyuki * src/gtk/x11print.c (CmOutputPrinter): add argument 'int show_dialog'. (CmOutputPrinter): check 'show_dialog' when call gtk_print_operation_run(). (CmOutputPrinterB): add argument when call CmOutputPrinter(). (init_graobj): added. (CmOutputPrinter, CmOutputDriver, CmOutputViewer) (CmPrintGRAFile, CmOutputImage): use init_graobj(). (draw_gra): added. (draw_page, CmOutputDriver, CmPrintGRAFile, CmOutputImage): use draw_gra(). * src/gtk/x11menu.c (SetPoint, SetZoom, ResetZoom, SetStatusBar) (SetStatusBarXm, ResetStatusBar): check 'NgraphApp.Message' is NULL or not. (SetCursor): check 'NgraphApp.Cursor' is NULL or not. * src/gtk/x11graph.c (CmGraphMenu): add argument when call CmOutputPrinter(). * src/gtk/ox11menu.c (mx_print): added. (gtkmenu): add member "print". * src/gtk/ogra2gtkprint.c (gra2gtkprint): remove member "next". * src/gtk/ogra2cairo.c (gra2cairo): remove member "next". * initfile/.Ngraph: add -p option. 2008-09-10 Ito Hiroyuki * src/gtk/x11print.c (CmPrintGRAFile): set base-name of ngp file as default GRA filename. (get_base_ngp_name): added. (CmPrintGRAFile, CmOutputImage): use get_base_ngp_name(). * src/gtk/ogra2cairo.c (draw_str, gra2cairo_charheight) (gra2cairo_charwidth): check font size. * src/gtk/x11view.c (new_merge_obj, new_file_obj): added. (data_dropped): add argument 'file_type'. use new_file_obj() and new_merge_obj(). * src/gtk/x11view.h: add prototype of data_dropped(). * src/gtk/x11merge.c: include "x11view.h" (drag_drop_cb, init_dnd): added. (CmMergeWindow): call init_dnd(). * src/gtk/x11file.c (drag_drop_cb, init_dnd): added. (CmFileWindow): call init_dnd(). * src/gtk/x11menu.c (createcommand2): set signal handler for "button-press-event". * src/gtk/x11view.h: add prototype of CmViewerButtonPressed(). * src/gtk/x11view.c: add 'KeepMouseMode'. (ViewerEvLButtonDblClk): call gtk_toggle_tool_button_set_active() when 'KeepMouseMode == FALSE'. (CmViewerButtonPressed): added. 2008-09-08 Ito Hiroyuki * src/gtk/x11view.c (Focus): remove 'gtk_toggle_tool_button_set_active()'. (check_focused_obj): now return index of found item. (ShowPoints): draw arc when 'd->Mode == ArcB'. (calc_snap_angle, calc_integer_ratio, SQRT3): added. (ViewerEvMouseMove): call calc_snap_angle() or calc_integer_ratio(). * src/gtk/gtk_subwin.c (ev_key_down_tree): add 'break;' in the case of 'GDK_space'. (ev_key_down_tree): return 'FALSE' when shift key is pressed in the case of 'GDK_Return'. 2008-09-05 Ito Hiroyuki * src/gtk/x11view.c (mouse_up_point): don't change cursor. (get_mouse_cursor_type): added. (set_mouse_cursor_hover): use get_mouse_cursor_type(). * src/gtk/x11menu.c (Command2_data): remove MoveB. 2008-09-04 Ito Hiroyuki * src/gtk/x11file.c (POPUP_ITEM_FIT): added. (popup_show_cb): check if the object associate with fit. * src/gtk/x11view.c (ViewerWinFileUpdate): call ProgressDialogCreate() before evaluate. (range_increment): added. (scrollbar_scroll_cb, ViewerEvScroll): use range_increment(). (ViewerEvMouseMove): scroll when mouse position is out of the widget. (AlignFocusedObj): align to the paper when number of focused object is 1. (do_popup): set sensitivity of d->popup_item[3] as TRUE when 'num > 0'. 2008-09-01 Ito Hiroyuki * src/gtk/gtk_subwin.c (start_editing): use snprintf() when 'list->type == G_TYPE_STRING' and 'chkobjfieldtype(d->obj, list->name) == NDOUBLE' to set value. (modify_string): check if the value is really modified. 2008-08-29 Ito Hiroyuki * src/gtk/gtk_subwin.c (ev_button_down, ev_button_down_tree): check 'event->time' to treat double click as double click. 2008-08-28 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_dialog_close): bug fix: call SetObjPointsFromText(). 2008-08-27 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_dialog_close): bug fix: call SetObjFieldFromStyle(). * src/gtk/x11opt.c (CmOptionViewer): uncomment 'ChangeDPI(TRUE);'. * src/gtk/x11dialg.h (struct MiscDialog): add 'data_head_lines'. * src/gtk/ox11menu.h (struct mxlocal): add 'data_head_lines'. * src/gtk/x11file.c (FileDialogSetup): use Mxlocal->data_head_lines. * src/gtk/ox11menu.c (mgtkloadconfig, menuinit): add settings for 'Mxlocal->data_head_lines'. (mx_data_head_lines): added. (gtkmenu): add 'data_head_lines'. * src/gtk/x11opt.c (DefaultDialogClose, MiscDialogSetupItem) (MiscDialogSetup, MiscDialogClose): add settings for 'Mxlocal->data_head_lines'. 2008-08-26 Ito Hiroyuki * src/ofile.c (f2dhead): check the return value of nstrnew() is NULL or not. * src/gtk/x11gui.c (dialog_key_down_cb): return FALSE when 'w' key is pressed without control key. * src/gtk/gtk_subwin.c (ev_sub_win_key_down): return FALSE when 'w' key is pressed without control key. * src/gtk/ogra2x11.c (ev_key_down): return FALSE when 'w' key is pressed without control key. * src/ofile.c (f2dhead): add line number. * src/ioutil.c (fgetnline): use fgetline(). 2008-08-25 Ito Hiroyuki * src/ofile.c (f2dhead): change length of 'buf' from 128 to 256. (f2dhead): use 'sizeof()' instead of immediate. * src/gtk/x11file.c (FileDialogSetup): change value of 'line' from 10 to 20. 2008-08-22 Ito Hiroyuki * src/ofile.c (struct f2ddata): add ifs_buf. (check_ifs_init, CHECK_IFS, CHECK_REMARK): added. (opendata): call check_ifs_init(). (getdataarray, getdata_sub1, getdata2, getdataraw): use CHECK_REMARK and CHECK_IFS instead of strchr(). * src/ioutil.c: added. (char_type_buf_init): added. (fgetline): use is_line_sep() when EOF == -1. * src/gtk/x11file.c (FileMoveDialogAdd): check if x and y are NaN or INF. * src/gtk/x11dialg.c (SetObjPointsFromText): check if d is NaN or INF. * src/gtk/gtk_subwin.c (numeric_cb): check if val is NaN or INF. * src/ofile.c (f2dsettings): check if f1, a2 and f3 are NaN or INF. 2008-08-21 Ito Hiroyuki * src/ofile.c (struct f2ddata_buf): added. (struct f2ddata, opendata, closedata, getdata_sub1, getdata): use 'struct f2ddata_buf'. * src/gra.c (GRAboundingbox): consider line width in the case 'R'. * src/ofile.c (reopendata): set fp->prev_datanum. (getdataraw): call set_data_progress(). (getdataraw): increment fp->datanum in loop. * src/ioutil.c (fgetline): bug fix: increment 'i' only after nstraddchar(). (fgetline) now '\r' is treated as line break. 2008-08-20 Ito Hiroyuki * src/ofile.c (getdataarray): bug fix: check if val is NaN or INF. * src/ioutil.c (fgetline): use switch instead of if. * src/ofile.c (getdata_sub1): added. (getdata): use getdata_sub1(). (getdata): use memmove() instead of loop. * src/axis.c (getaxispositionfirst): use alocal->inc instead of alocal->dposm to determine alocal->dposs. 2008-08-19 Ito Hiroyuki * src/gra.c (GRAboundingbox): now ch is int. (GRAboundingbox): first argument of Gracharwidth is '(ch & 0xff)'. 2008-08-18 Ito Hiroyuki * src/gtk/x11file.c (select_type): set selected item to d->select. * src/gtk/x11menu.c (add_underscore): added. (show_graphmwnu_cb, show_filemwnu_cb): call add_underscore(). 2008-08-15 Ito Hiroyuki * src/gtk/x11menu.c: added. (create_graphmenu, create_axismenu): add accelerator. (create_toggle_menu_item): added. (create_windowmenu): use create_toggle_menu_item(). * src/gtk/x11menu.h: added. * src/gtk/gtk_subwin.c (sub_window_create): add accel group to sub window. * src/gtk/x11view.c (AddList): bug fix: call GRAdellist() when inst2 == NULL. 2008-08-14 Ito Hiroyuki * src/gtk/x11opt.c (DefaultDialogClose): check NgraphApp.FileWin.Win->window etc. 2008-08-11 Ito Hiroyuki * src/gtk/x11menu.c (MARK_PIX_SIZE): change mark size from 28 to 24. * src/gtk/x11file.c (create_type_combo_box): added. (select_type, start_editing_type): modified for tree model. * src/gtk/gtk_liststore.c (start_editing_obj): use GtkTreeModel for combo_box. 2008-08-08 Ito Hiroyuki * src/gtk/gtk_liststore.c (start_editing_obj): added. (create_column): set some properties to GtkCellRenderer. set start_editing virtual function. * src/gtk/gtk_subwin.c (set_obj_cell_renderer_cb): added. * src/gtk/x11file.c (select_type, start_editing_type): added. (CmFileWindow): call set_obj_cell_renderer_cb. 2008-08-06 Ito Hiroyuki * initfile/.Ngraph: add save_image(). add -png, -ps, -eps, -pdf and -svg option. * src/gtk/main.c (inputynconsole): add message ' [yn] '. use strchr() to check input character. read while '\n' appear. 2008-08-05 Ito Hiroyuki * src/gtk/ox11menu.h (struct menulocal): add member 'expandtofullpath' * src/gtk/ox11menu.c (mgtkloadconfig): add condition for 'expand_to_fullpath' (menuinit): initialize Menulocal.expandtofullpath. * src/gtk/x11commn.c (ToFullPath): added. (LoadNgpFile): call ToFullPath() when 'Menulocal.expandtofullpath && (!ignorepath)' * src/ioutil.c (getfullpath): argument of changefilename() is 'name'. * src/object.c (memrealloc): add sleep(). * src/shellux.c (cmtest): add condition '(strcmp2(argv[i+1],"=")!=0) && (strcmp2(argv[i+1],"!=")!=0)' * src/jnstring.h: added. * src/jnstring.c: added. * src/ngraph.h (ALIGNSIZE): added. 2008-07-24 Ito Hiroyuki * src/gtk/x11file.c (get_axis_obj_str): added. (file_list_set_val): use get_axis_obj_str(). (start_editing): check axis object. 2008-07-23 Ito Hiroyuki * src/gtk/x11file.c (select_axis, select_axis_x, select_axis_y): added. (start_editing): use "changed" signal. * src/gtk/x11axis.c (select_type): added. (start_editing): use "changed" signal. 2008-07-22 Ito Hiroyuki * src/gtk/x11file.c (edited_y, edited_x, edited_axis) (start_editing): added. (CmFileWindow): call set_combo_cell_renderer_cb(). * src/gtk/x11axis.c (start_editing, edited): added. (CmAxisWindow): call set_combo_cell_renderer_cb(). * src/gtk/gtk_subwin.c (set_combo_cell_renderer_cb): added. * src/gtk/gtk_liststore.c (create_column): add case G_TYPE_ENUM. (create_tree_view): column type of G_TYPE_ENUM is string. * src/gtk/x11menu.c: add global variables RecentGraph and RecentData. (create_recent_graph_menu, create_recent_data_menu): added. (create_graphmenu): call create_recent_graph_menu. (create_filemenu): call create_recent_data_menu. * src/gtk/gtk_subwin.c (modify_numeric, modify_string): check the value is modified or not. (ev_button_down, ev_button_down_tree): return FALSE when locked. 2008-07-18 Ito Hiroyuki * src/gtk/x11dialg.c (search_id): added. (SelectDialogSetup, SelectDialogSetup): add id column. check id column insteadof index. * src/gtk/x11lgnd.c (LegendLineCB, LegendRectCB, LegendArcCB) (LegendTextCB): remove id. * src/gtk/x11file.c (FitCB): remove id. * src/gtk/x11commn.c (FileCB): remove id. * src/gtk/x11axis.c (AxisDialogFile): always get scale type. (AxisDialogSetup): bug fix: widget type of Scale setting is GtkComboBox. (AxisCB, GridCB): remove id. * src/gtk/x11file.c (MathDialogSetup, MathDialogList): now math dialog can be sorted. * src/gtk/gtk_liststore.c (list_store_path_get_int): added. * src/gtk/x11file.c (FileMoveDialogSetup, FileMaskDialogSetup): now lists of masked and moved data are sorted by line number. * src/gtk/gtk_liststore.c (list_store_set_sort_column) (list_store_set_sort_all): added. 2008-07-17 Ito Hiroyuki * src/gtk/ogra2cairo.c (gra2cairo_output): in the case 'V' call cairo_reset_clip() before clip rectangle and restore clip region when local->region is not NULL. * src/shell.c (checkcmd): bug fix: initialize prmcur->prmno as NULL when prmcur->str[1] == ';'. (checkcmd): fix indent. * src/gtk/ogra2x11.c (gtkinit): free gra2cairo_local when failed. * src/gtk/ogra2gdk.c (g2g_init): free gra2cairo_local when failed. * src/gtk/ox11menu.c (menuinit): free gra2cairo_local when failed. * src/gtk/ogra2cairo.c (gra2cairo_free): added. (gra2cairo_init): call free_conf() only when Instance == 0. * src/gtk/ogra2cairofile.c (gra2cairofile_init): free gra2cairo_local when failed. 2008-07-16 Ito Hiroyuki * src/gtk/gtk_subwin.c (start_editing, cancel_editing) (numeric_cb, string_cb): added. (set_cell_renderer_cb): set callback functions when type is G_TYPE_DOUBLE, G_TYPE_INT or G_TYPE_STRING. (modify_numeric, modify_string): added. * src/gtk/gtk_liststore.h (_list_store): add min, max, inc and page. * src/gtk/gtk_liststore.c (create_column): set "editable", "adjustment", "digits" and "user-data" properties to renderer when editable is TRUE. * src/ofile.c (closedata): call set_data_progress(); * src/gtk/x11dialg.c (SetObjFieldFromWidget) (SetWidgetFromObjField): added. 2008-07-15 Ito Hiroyuki * src/gtk/x11dialg.c (SetTextFromObjPoints) (SetObjPointsFromText): added. (SetObjFieldFromStyle): call SetObjPointsFromText() to set value. (SetStyleFromObjField): call SetTextFromObjPoints() to set value. * src/gtk/x11axis.c (Alist): type of 'x', 'y', 'dir' and 'len' are G_TYPE_DOUBLE. (axis_list_set_val): now position and length are shown in mm. direction is shown in degree. * src/gtk/x11file.c (Flist): type of 'size' and 'width' are G_TYPE_DOUBLE. (file_list_set_val): now size and width are shown in mm. * src/gtk/x11merge.c (Mlist): type of 'tm', 'lm' and 'zm' are G_TYPE_DOUBLE. (merge_list_set_val): now margin and zoom are shown in mm and percent respectively. * src/gtk/x11cood.c (CoordWinSetCoord): now position is shown in mm. * src/gtk/x11menu.c (SetPoint): now position is shown in mm. * src/gtk/x11lgnd.c (Llist): type of 'x' and 'y' are G_TYPE_DOUBLE. (LegendLineCB, LegendRectCB, LegendArcCB): now position is shown in mm. (legend_dialog_setup_item): use SetTextFromObjPoints() for "points" property. (legend_dialog_close): use SetObjPointsFromText() for "points" property. (legend_list_set_val): now position and size are shown in mm. * src/gtk/gtk_liststore.c (tree_store_set_double) (list_store_set_double): set formated string. (create_tree_view): set G_TYPE_STRING when type is G_TYPE_DOUBLE. 2008-07-14 Ito Hiroyuki * src/ofile.c (curveoutfile): remove condition "getposition2(fp, fp->axtype, fp->aytype, &(fp->dx), &(fp->dy)) == 0" (opendata): bug fix: initialize some variables when "axis" is FALSE. * src/gtk/x11gui.c (fsok): bug fix: : add braces as "(n + 1)" in argument of malloc. * src/orect.c (rectzoom): check if x1 and y1 are equal to x2 and y2 respectively. * src/oaxis.c (axisput): use TEXT_SIZE_MIN macro. * src/oarc.c (arczoom): check value of rx and ry. * src/otext.c (textgeometry): use macro; TEXT_OBJ_SCRIPT_SIZE_MIN, TEXT_OBJ_SCRIPT_SIZE_MAX and TEXT_SIZE_MIN. * src/gtk/x11print.c (OutputDataDialogSetupItem) (OutputDataDialogClose): use GtkSpinButton. * src/gtk/x11opt.c (MiscDialogSetupItem, MiscDialogSetup) (MiscDialogClose, ExViewerDialogSetupItem, ExViewerDialogSetup) (ExViewerDialogClose, ViewerDialogSetupItem, ViewerDialogSetup) (ViewerDialogClose): use GtkSpinButton. * src/gtk/x11merge.c (MergeDialogSetup): use GtkSpinButton. * src/gtk/x11lgndx.c (LegendGaussDialogSetup): use GtkSpinButton. * src/gtk/x11lgnd.c (legend_dialog_setup_item) (legend_dialog_close, width_setup, miter_setup) (LegendRectDialogSetup, LegendArcDialogSetup) (LegendMarkDialogSetup, legend_dialog_setup_sub) (LegendTextDialogSetup): use GtkSpinButton. * src/gtk/x11graph.c (PageDialogSetupItem, PageDialogPage) (PageDialogSetup, PageDialogClose): use GtkSpinButton. * src/gtk/x11file.c (FitDialogSetup, FileMaskDialogAdd) (FileLoadDialogSetup, FileMathDialogSetup) (FileDialogSetupCommon): use GtkSpinButton. * src/gtk/x11dialg.c (SetObjFieldFromSpin, SetSpinFromObjField): use GtkSpinButton. * src/gtk/x11axis.c (gauge_syle_setup, SectionDialogSetupItem) (SectionDialogSetup, SectionDialogClose, CrossDialogSetupItem) (CrossDialogSetup, CrossDialogClose, ZoomDialogSetup) (ZoomDialogClose, AxisBaseDialogSetup, AxisPosDialogSetup) (NumDialogSetup, AxisFontDialogSetup, AxisDialogSetup): use GtkSpinButton. * src/gtk/gtk_widget.c: added. 2008-07-11 Ito Hiroyuki * src/gtk/gtk_liststore.c (create_column): set "mode" attribute as GTK_CELL_RENDERER_MODE_ACTIVATABLE when the column is editable. * src/gtk/gtk_subwin.c (set_cell_renderer_cb, toggle_cb): added. (list_sub_window_create, tree_sub_window_create): call set_cell_renderer_cb(). 2008-07-05 Ito Hiroyuki * src/gtk/x11file.c (FileMoveDialogSetup, FileMaskDialogSetup): add copy button. (FileMaskDialogClose, FileMoveDialogClose): add case for IDCOPY. (FileMoveDialogCopy, FileMaskDialogCopy): added. 2008-07-04 Ito Hiroyuki * src/gtk/x11menu.c (SetCaption): free 'buf'. * src/ogra.c (set_progress_val): initialize progress bar when 'i == 0'. * src/gtk/ogra2cairo.c (gra2cairo_done): free 'local->fontalias'. * src/gtk/x11file.c (file_list_set_val, FileDialogSetupItem): free 'valstr'. * src/gtk/ogra2cairo.c (free_conf): free fontmap. * src/gtk/gtk_entry_completion.c (add_completion): free 'buf'. * src/gtk/ogra2gtkprint.c (create_cairo): remove cairo_destroy(). (gra2gtkprint_done): set NULL to local->cairo. * src/gtk/x11graph.c (PageDialogPage): width and height entry is sensitive only when paper type is custom. * src/gtk/ox11menu.h (struct menulocal): add PaperLandscape, PaperId and PaperName. (enum paper_id): added. * src/gtk/x11graph.c (PageDialogClose): check paper size. (set_paper_type): added. (struct pagelisttype, pagelist): add name, landscape and id; * src/gtk/x11commn.c (CheckPage): bug fix: remove redundant return. 2008-07-03 Ito Hiroyuki * src/gtk/x11graph.c (CmGraphMenu): call CmOutputPrinter() when sel == MenuIdOutputDriver. * src/gtk/ogra2gtkprint.c: added. * src/gtk/x11print.c (CmOutputPrinter, draw_page) (struct print_obj): added. add global variable PrintSettings. * src/gtk/ogra2cairo.c (gra2cairo_output): save current point after call cairo_stroke() for graphic command 'T'. * src/ofile.c (fitout): fitout is now static. * src/ofit.c (fitpoly): bug fix: write information in 'buf' instead of 'equation'. * src/gtk/x11file.c (FitDialogSetupItem, FitDialogSave) (FitDialogApply): bug fix: poly_dimension is active item + 1. * src/gtk/x11commn.c (GetDrawFiles): added. * src/gtk/x11print.c (CmPrintDataFile): now CmPrintDataFile() can output multi data files into one file. * src/gtk/x11commn.c (SetFileHidden): add arraydel(&ifarray) when return value of DialogExecute() is not IDOK. * src/ofile.c (f2doutputfile): add append mode. (file2d): change arguments of "output_file" from "si" to "sib". 2008-07-02 Ito Hiroyuki * src/gtk/x11view.c (create_pix): add settings for antialias. (OpenGC, ReopenGC): add settings for pixel_dot_x and pixel_dot_y. * src/gtk/x11opt.c (DefaultDialogClose, ViewerDialogSetupItem) (ViewerDialogSetup, ViewerDialogClose): add settings for antialias. * src/gtk/ox11menu.c (mgtkloadconfig, menuinit): add settings for antialias. (mxdpi): add settings for pixel_dot_x and pixel_dot_y. (mxd2p, mxd2px, mxd2py, mxp2d): use pixel_dot_x and pixel_dot_y. remove gtk_output(). * src/gtk/ogra2x11.c (gtkinit): add settings for dpix and dpiy. (dot2pixel): use pixel_dot_x. * src/gtk/ogra2gdk.c (g2g_init): add settings for dpix and dpiy. * src/gtk/ogra2cairofile.c (gra2cairofile_init): add settings for dpix and dpiy * src/gtk/ogra2cairo.c (gra2cairo_antialias_type) (gra2cairo_set_antialias, set_antialias): added. (gra2cairo_output, gra2cairo_init): add antialias settings. (gra2cairo): add member "antialias", "dpix" and "dpiy". (mxp2dw, mxd2pw, mxp2dh, mxd2ph, mxd2px, mxd2py): added. (gra2cairo_init, gra2cairo_set_dpi): add settings for pixel_dot_x and pixel_dot_y. (gra2cairo_set_dpi_x, gra2cairo_set_dpi_y): added. (draw_str, gra2cairo_output): use mxp2dw(), mxd2pw(), mxp2dh(), mxd2ph(), mxd2px() and mxd2py(). * src/gtk/ogra2cairo.h (struct gra2cairo_local): add antialias, pixel_dot_x and pixel_dot_y. 2008-07-01 Ito Hiroyuki * src/gtk/x11menu.c (create_image_outputmenu): added. (create_outputmenu): add "Export image" sub menu. * src/gtk/x11menu.h (enum MenuID): add MenuId MenuIdOutputPSFile, MenuIdOutputEPSFile, MenuIdOutputPDFFile, MenuIdOutputPNGFile and MenuIdOutputSVGFile. * src/gtk/x11print.c (OutputImageDialogSetupItem) (OutputImageDialogSetup, OutputImageDialogClose) (OutputImageDialog, CmOutputImage): added. (CmOutputMenu): add case MenuIdOutputPSFile, MenuIdOutputEPSFile, MenuIdOutputPDFFile, MenuIdOutputPNGFile and MenuIdOutputSVGFile. 2008-06-30 Ito Hiroyuki * src/gtk/x11menu.c (MARK_PIX_SIZE): change mark pix size. * src/gra.c (GRAmark): fix size of triangle. * src/gtk/ox11menu.c: remove mxsaveGC() and mxrestoreGC(). * src/gtk/x11file.c (draw_type_pixbuf): use gra2gdk. * src/gtk/x11lgndx.c (LegendGaussDialogPaint): use gra2gdk. * src/gtk/x11menu.c (create_markpixmap): use gra2gdk. (find_gra2gdk_inst): added. * src/gtk/x11view.c (ViewerWinSetup): call OpenGRA() after OpenGC(). * src/gtk/Makefile.am (libngraph_la_SOURCES): add ogra2cairo.c, ogra2cairo.h, ogra2cairofile.c, ogra2x11.h, ogra2gdk.c and ogra2gdk.h 2008-06-27 Ito Hiroyuki * src/gtk/ogra2x11.c (gtkinit): gtkclose() is now called when "delete-event" signal is emitted. object 'gra2gtk' is now child of 'gra2cairo'. 2008-06-25 Ito Hiroyuki * src/gtk/ogra2cairofile.c: added. * src/gtk/ogra2cairo.c: added. 2008-06-22 Ito Hiroyuki * src/gtk/x11merge.c: remove ev_key_down(). (CmMergeWindow): remove setting for d->ev_key. * src/gtk/x11axis.c: remove ev_key_down(). (CmAxisWindow): remove setting for d->ev_key. * src/gtk/strconv.c (ascii2greece): bug fix: dlen must be "slen * 2 + 1". (str2utf8): bug fix: dlen must be "slen * 6 + 1". * src/gtk/ogra2x11.c (gtk_charwidth, gtk_charheight): save and restore fontdir, fontsin and fontcos and set fontdir as 0 before call draw_str(). * src/gtk/gtk_subwin.c (ev_key_down): add case for "GDK_SPACE" * src/gtk/gtk_liststore.c (create_tree_view): bug fix: add braces as "(n + cnum)" in argument of malloc. 2008-06-19 Ito Hiroyuki * src/gtk/x11menu.c (detach_toolbar, create_toolbar): added. (setupwindow): use create_toolbar(). * src/gtk/x11view.c (reorder_object): added. (ViewTop, ViewLast): use reorder_object(). (ViewCopyAxis): added. (ViewCopy): use ViewCopyAxis(). 2008-06-18 Ito Hiroyuki * src/gtk/x11commn.c (ProgressDialogCreate): set cursor to GDK_WATCH. (ProgressDialogFinalize): restore cursor. * src/gtk/x11menu.c (GetCursor): added. * src/gtk/x11merge.c (ev_key_down): added. * src/gtk/x11view.c (Focus): now merge object can be focused. 2008-06-17 Ito Hiroyuki * src/gtk/x11view.c (mouse_down_move_data) (mouse_down_set_points, mouse_down_zoom): added. (ViewerEvLButtonDown): use mouse_down_move_data(), mouse_down_set_points() and mouse_down_zoom(). (ViewerEvRButtonDown): use mouse_down_zoom(); (ViewerEvRButtonDown): cancel make arc, rectangle, gauss and axis when Button3 is pressed. (create_axis, create_single_axis, create_legendx) (create_legend3, create_legend2, create_legend1): added. (ViewerEvLButtonDblClk): use create_axis(), create_single_axis(), create_legendx(), create_legend3(), create_legend2() and create_legend1(). (clear_focus_obj, UnFocus): add argument "int init_cursor". 2008-06-16 Ito Hiroyuki * src/gtk/x11view.c (add_focus_obj, clear_focus_obj) (mouse_down_point, mouse_down_move, mouse_up_point) (set_mouse_cursor_hover, mouse_up_drag, mouse_up_zoom) (mouse_up_change, mouse_up_lgend1, mouse_up_lgend2): added. (Match, Focus): use add_focus_obj(); (ViewerWinUpdate, UnFocus, ViewUpdate): use clear_focus_obj(); (ViewerEvLButtonUp): use mouse_down_point(), mouse_up_drag(), mouse_up_zoom() and mouse_up_change(). * src/gtk/x11menu.c (Command2_data): add move tool button. (createcommand2): default sensitivity of the MoveButton is false. (SetMoveButtonState): added. (SetCursor): add GDK_FLEUR. * src/gtk/x11view.c (enum ViewerPopupIdn): add alignment id. (struct viewer_popup): add member 'struct viewer_popup *submenu' (create_menu): added. (create_popup_menu): add alignment submenu. use create_menu. (AlignFocusedObj): added. (do_popup): add codes for alignment submenu. (check_focused_obj): added. (Focus): add argument "int add". add codes for multiple focus. (ViewerPopupMenu): call AlignFocusedObj(). * src/gtk/x11axis.c (ev_key_down): check 'e->state & GDK_SHIFT_MASK' when e->keyval == GDK_space. * src/gtk/gtk_subwin.c (focus, tree_focus): add argument "int add". (ev_key_down_tree): check 'e->state & GDK_SHIFT_MASK' when e->keyval == GDK_space. (list_sub_window_add_focus, tree_sub_window_add_focus): added. 2008-06-13 Ito Hiroyuki * src/gtk/x11lgnd.c (legend_dialog_close) (legend_dialog_setup_item, LegendRectDialogSetup): use width and height instaed of x2 and y2 for legend rectangle. * src/gtk/x11view.c (swapint): added. (ViewerEvLButtonDblClk): x2 and y2 are always greater than x1 and y2 respectivery. 2008-06-12 Ito Hiroyuki * src/gtk/x11view.c (EvalDialogSetup): now "X" and "Y" is string. (EvalDialogSetupItem): add string converted from double. * src/gtk/x11file.c (FileMoveDialogClose): x and y is converted from string to double. (FileMoveDialogSetup): now "X" and "Y" is string. (FileMoveDialogAdd): add string converted from double. * src/omerge.c (mergeinit): initialize "line_num". * src/ogra.c (set_progress_val): added. (oGRAdraw): use set_progress_val(). (oGRAdrawparent): call set_progress_val(). * src/omerge.c (mergeredraw): check redraw_num. * src/gra.c (_GRAredraw): set "redraw_flag" as FALSE when redrawf is zero. (GRAredraw2, GRAredraw, _GRAredraw): replace redrawf to redraw_num. * src/omerge.c (merge): add "line_num" * src/oaxis.c (axisautoscalefile): display "group" property when the property is not NULL. * src/gtk/x11axis.c (axis_list_set_val): get "group" instead of "name". * src/gtk/ox11menu.c (mx_redraw): remove set_draw_lock(). * src/gtk/x11view.c (AddInvalidateRect, Match): remove set_draw_lock(). * src/gtk/x11menu.c (ChkInterrupt): do gtk_main_iteration_do() only when DrawLock == DrawLockDraw. * src/gtk/ox11menu.c (mx_output): bug fix: add 360 to Mxlocal->fontdir when Mxlocal->fontdir is negative. * configure.in: required version of GTK+ is greater than 2.12 because gtk_tool_item_set_tooltip_text() is available since 2.12. 2008-06-10 Ito Hiroyuki * src/gtk/x11commn.c (FreeConsole): restore ninterrupt. * driver/gra2wmf.c (draw, getboundingbox): bug fix: reported at http://www2e.biglobe.ne.jp/~isizaka/bbs_old/light.cgi [670]. * src/gtk/ox11menu.c (mx_get_focused): added. (gtkmenu): add "focused". * src/gtk/x11dialg.c (CopyDialogSetup, SelectDialogSetup): select item if there is only one item. * src/gtk/x11view.c (Match, AddInvalidateRect): add set_draw_lock(). * src/gtk/x11menu.c (save_hist): bug fix: remove redundant return. * src/gtk/x11opt.c (ViewerDialogSetupItem, ViewerDialogSetup) (ViewerDialogClose): add settings for "redraw_num". * src/gtk/ox11menu.c (menuinit): set "redraw_num". (mxredraw_num): added. (mx_redraw): check Mxlocal->redrawf_num. (mgtkloadconfig): get Mxlocal->redrawf_num from init file. (menuinit): initialize Mxlocal->redrawf_num. (gtkmenu): add "redraw_num" * src/odraw.c (draw): add "redraw_num". * src/gra.c (_GRAredraw): set "redraw_num". * src/ofile.c (f2dredraw): check "redraw_num". * src/gtk/x11commn.c (ProgressDialogFinalize) (ProgressDialogCreate): call set_draw_lock(). * src/gtk/x11menu.c (ChkInterrupt): check DrawLock. (set_draw_lock): added. add DrawLock. * src/gtk/ox11menu.c (mx_redraw): call set_draw_lock(). * src/gtk/x11commn.c: add ProgressBar2. * src/ogra.c (oGRAdraw): call set_progress(). * src/gtk/x11print.c (CmOutputDriver, CmOutputViewer) (CmPrintGRAFile, CmPrintDataFile): call ProgressDialogCreate() and ProgressDialogFinalize(). 2008-06-09 Ito Hiroyuki * src/ofit.c (fituser): call set_progress() instead of ndisplaystatus(). * src/ioutil.c add ShowProgressFunc, set_progress_func() and set_progress(). * src/ofile.c add set_data_progress(). (getdata): call set_data_progress(). * src/gtk/x11menu.c (Command1_data): remove do_interrupt. (application): remove snooper_id, gtk_key_snooper_remove() and gtk_key_snooper_install(). * src/gtk/x11commn.c add global variables ProgressBar and ProgressDiaog. add ProgressDialogCreate(), ProgressDialogFinalize() and ProgressDialogSetTitle(). * src/gtk/x11view.c (Draw): call ProgressDialogCreate(), ProgressDialogFinalize() and ProgressDialogSetTitle(). * src/object.c (addobject): add alignment for 64bit architecture. 2008-06-08 Ito Hiroyuki * src/gtk/x11view.c (ViewerWinFileUpdate): bug fix: reported at http://www2e.biglobe.ne.jp/~isizaka/bbs_old/light.cgi [802]-[805]. (ViewerEvLButtonDown, ViewerEvRButtonDown): use nround() when change dpi. (ViewerEvScroll): bug fix: d->VScroll to d->HScroll. 2008-06-07 Ito Hiroyuki * src/gtk/main.c (main): add g_set_application_name(). * src/gtk/x11menu.c (application): remove g_set_application_name(). * src/gtk/x11gui.c (FileSelectionDialog): call ResetEvent() after gtk_widget_destroy(). 2008-06-04 Ito Hiroyuki * src/shell.c (ngraphenvironment): add $NGRAPHHOME to PATH. * src/ofile.c (f2dsettings): ignore remark character placed at the top of the line. 2008-06-03 Ito Hiroyuki * src/gtk/x11opt.c (DefaultDialogClose): add preserve_width. (MiscDialogSetupItem): add preserve_width. (MiscDialogSetup): add preserve_width. (MiscDialogClose): add preserve_width. (MiscDialogClose): add preserve_width. * src/gtk/ox11menu.c (mgtkloadconfig): add preserve_width. * src/gtk/x11view.c (ViewerEvLButtonUp): add preserve_width. * src/orect.c (rectzoom): add preserve_width. * src/omark.c (markzoom): add preserve_width. * src/olegend.c (legendzoom): add preserve_width. * src/oaxis.c (axiszoom2): add preserve_width. * src/oarc.c (arczoom): add preserve_width. * src/gtk/gtk_liststore.c (create_tree_view): add gtk_tree_view_column_set_resizable(); * src/gtk/x11file.c (FileDialogSetup): check string by g_utf8_validate(); * src/gtk/x11lgnd.c (legend_list_set_val): use g_utf8_strncpy() instead of strncpy(). 2008-06-02 Ito Hiroyuki * src/gtk/x11axis.c (AxisPosDialogSetupItem): add combo_box_clear(d->adjust). * src/gtk/ox11menu.c (mx_output): in the case 'V': remove Mxlocal->scrollx and Mxlocal->scrolly. (mx_output): in the case 'V': second argument must be mxd2py and third argument must be mxd2px. * src/gtk/x11view.c (MakeRuler): use mxd2p() instead of mxd2px() and mxd2y(). 2008-05-30 Ito Hiroyuki * src/gtk/x11view.c (CloseGC): fix conditional expression ("Mxlocal->font[i].fontalias != NULL" to "Mxlocal->font[i].fontalias != NULL"). * src/gtk/ox11menu.c (menudone): free Mxlocal->font[i].fontalias and Mxlocal->font[i].font only when Mxlocal->font[i].fontalias is not NULL. * src/gtk/gtk_subwin.c (sub_window_minimize): do nothing when a sub window is already iconified. 2008-05-27 gettextize * Makefile.am (SUBDIRS): Add po, m4. (ACLOCAL_AMFLAGS): New variable. (EXTRA_DIST): Add config.rpath. * configure.in (AC_CONFIG_FILES): Add po/Makefile.in, m4/Makefile. ngraph-gtk-6.08.00/TODO0000644000175000017500000000143213344731000011333 00000000000000* データæç”»â†’æ•°å¼å¤‰æ›ã« while(-1,1,1) ãªã©ã¨è¨­å®šâ†’レジェンドを動ã‹ã—ã¦å†æç”»â†’ç„¡é™ãƒ«ãƒ¼ãƒ— * レーダーグラフ (?) 用グリッド * fit 設定ã®ä¿å­˜æ™‚ã«ã‚°ãƒ©ãƒ•更新フラグãŒã‚»ãƒƒãƒˆã•れã¦ã—ã¾ã†ä¸å…·åˆã®ä¿®æ­£ã€‚ * ã‚³ãƒ¼ãƒ‰ã®æ•´ç† * axis ã‚’ cut & paste ã§ããªã„ã‹ï¼Ÿ * EMF 出力ã®åˆ¶é™ 1. ä¸é€æ˜Žåº¦è¨­å®šéžå¯¾å¿œ 2. libreoffice ãŒå¤šè§’形塗りã¤ã¶ã—ã® WindingRule ã«éžå¯¾å¿œ 3. libreoffice ãŒç‚¹ç·šã«éžå¯¾å¿œ 4. libreoffice ã§æ¥•å††ã®æ‰‡å½¢ã¾ãŸã¯å¼“型輪郭ã®ç›´ç·šéƒ¨åˆ†ãŒè¡¨ç¤ºã•れãªã„ 5. paint ã«ãƒšãƒ¼ã‚¹ãƒˆã—ãŸæ™‚ä¸€éƒ¨ã®æ–‡å­—ãŒæ­£å¸¸ã«è¡¨ç¤ºã•れãªã„ 6. æ–‡å­—ãŒæç”»ç¯„å›²ã‹ã‚‰ã¯ã¿å‡ºã™ã“ã¨ãŒã‚ã‚‹ã®ã§é€æ˜ŽãªçŸ©å½¢ã‚’æç”»ã—ã¦ã„ã‚‹ ngraph-gtk-6.08.00/gtksourceview/0000755000175000017500000000000013375640234013640 500000000000000ngraph-gtk-6.08.00/gtksourceview/ngraph-math.lang.post0000644000175000017500000000100713254171066017611 00000000000000 ngraph-gtk-6.08.00/gtksourceview/create_lang.nsc0000644000175000017500000000061613254174507016535 00000000000000#! /usr/bin/ngraph SED="$1" cat "$2" new data echo ' ' get data -field math_functions | "$SED" -Ee 's!.+! &!' echo ' ' echo echo ' ' get data -field math_constants | "$SED" -E -e '/^%/d' -e 's/.+/ &<\/keyword>/' echo ' ' echo cat "$3" ngraph-gtk-6.08.00/gtksourceview/ngraph-math.lang.pre0000644000175000017500000000602213254175012017407 00000000000000 text/x-ngraph-math #