Merged branches polyel with constant volume
3 files added
8 files modified
3 files deleted
New file |
| | |
| | | #! /bin/sh |
| | | # depcomp - compile a program generating dependencies as side-effects |
| | | |
| | | scriptversion=2013-05-30.07; # UTC |
| | | |
| | | # Copyright (C) 1999-2013 Free Software Foundation, Inc. |
| | | |
| | | # This program is free software; you can redistribute it and/or modify |
| | | # it under the terms of the GNU General Public License as published by |
| | | # the Free Software Foundation; either version 2, or (at your option) |
| | | # any later version. |
| | | |
| | | # This program is distributed in the hope that it will be useful, |
| | | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
| | | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| | | # GNU General Public License for more details. |
| | | |
| | | # You should have received a copy of the GNU General Public License |
| | | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
| | | |
| | | # As a special exception to the GNU General Public License, if you |
| | | # distribute this file as part of a program that contains a |
| | | # configuration script generated by Autoconf, you may include it under |
| | | # the same distribution terms that you use for the rest of that program. |
| | | |
| | | # Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>. |
| | | |
| | | case $1 in |
| | | '') |
| | | echo "$0: No command. Try '$0 --help' for more information." 1>&2 |
| | | exit 1; |
| | | ;; |
| | | -h | --h*) |
| | | cat <<\EOF |
| | | Usage: depcomp [--help] [--version] PROGRAM [ARGS] |
| | | |
| | | Run PROGRAMS ARGS to compile a file, generating dependencies |
| | | as side-effects. |
| | | |
| | | Environment variables: |
| | | depmode Dependency tracking mode. |
| | | source Source file read by 'PROGRAMS ARGS'. |
| | | object Object file output by 'PROGRAMS ARGS'. |
| | | DEPDIR directory where to store dependencies. |
| | | depfile Dependency file to output. |
| | | tmpdepfile Temporary file to use when outputting dependencies. |
| | | libtool Whether libtool is used (yes/no). |
| | | |
| | | Report bugs to <bug-automake@gnu.org>. |
| | | EOF |
| | | exit $? |
| | | ;; |
| | | -v | --v*) |
| | | echo "depcomp $scriptversion" |
| | | exit $? |
| | | ;; |
| | | esac |
| | | |
| | | # Get the directory component of the given path, and save it in the |
| | | # global variables '$dir'. Note that this directory component will |
| | | # be either empty or ending with a '/' character. This is deliberate. |
| | | set_dir_from () |
| | | { |
| | | case $1 in |
| | | */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; |
| | | *) dir=;; |
| | | esac |
| | | } |
| | | |
| | | # Get the suffix-stripped basename of the given path, and save it the |
| | | # global variable '$base'. |
| | | set_base_from () |
| | | { |
| | | base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` |
| | | } |
| | | |
| | | # If no dependency file was actually created by the compiler invocation, |
| | | # we still have to create a dummy depfile, to avoid errors with the |
| | | # Makefile "include basename.Plo" scheme. |
| | | make_dummy_depfile () |
| | | { |
| | | echo "#dummy" > "$depfile" |
| | | } |
| | | |
| | | # Factor out some common post-processing of the generated depfile. |
| | | # Requires the auxiliary global variable '$tmpdepfile' to be set. |
| | | aix_post_process_depfile () |
| | | { |
| | | # If the compiler actually managed to produce a dependency file, |
| | | # post-process it. |
| | | if test -f "$tmpdepfile"; then |
| | | # Each line is of the form 'foo.o: dependency.h'. |
| | | # Do two passes, one to just change these to |
| | | # $object: dependency.h |
| | | # and one to simply output |
| | | # dependency.h: |
| | | # which is needed to avoid the deleted-header problem. |
| | | { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" |
| | | sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" |
| | | } > "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | else |
| | | make_dummy_depfile |
| | | fi |
| | | } |
| | | |
| | | # A tabulation character. |
| | | tab=' ' |
| | | # A newline character. |
| | | nl=' |
| | | ' |
| | | # Character ranges might be problematic outside the C locale. |
| | | # These definitions help. |
| | | upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ |
| | | lower=abcdefghijklmnopqrstuvwxyz |
| | | digits=0123456789 |
| | | alpha=${upper}${lower} |
| | | |
| | | if test -z "$depmode" || test -z "$source" || test -z "$object"; then |
| | | echo "depcomp: Variables source, object and depmode must be set" 1>&2 |
| | | exit 1 |
| | | fi |
| | | |
| | | # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. |
| | | depfile=${depfile-`echo "$object" | |
| | | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} |
| | | tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} |
| | | |
| | | rm -f "$tmpdepfile" |
| | | |
| | | # Avoid interferences from the environment. |
| | | gccflag= dashmflag= |
| | | |
| | | # Some modes work just like other modes, but use different flags. We |
| | | # parameterize here, but still list the modes in the big case below, |
| | | # to make depend.m4 easier to write. Note that we *cannot* use a case |
| | | # here, because this file can only contain one case statement. |
| | | if test "$depmode" = hp; then |
| | | # HP compiler uses -M and no extra arg. |
| | | gccflag=-M |
| | | depmode=gcc |
| | | fi |
| | | |
| | | if test "$depmode" = dashXmstdout; then |
| | | # This is just like dashmstdout with a different argument. |
| | | dashmflag=-xM |
| | | depmode=dashmstdout |
| | | fi |
| | | |
| | | cygpath_u="cygpath -u -f -" |
| | | if test "$depmode" = msvcmsys; then |
| | | # This is just like msvisualcpp but w/o cygpath translation. |
| | | # Just convert the backslash-escaped backslashes to single forward |
| | | # slashes to satisfy depend.m4 |
| | | cygpath_u='sed s,\\\\,/,g' |
| | | depmode=msvisualcpp |
| | | fi |
| | | |
| | | if test "$depmode" = msvc7msys; then |
| | | # This is just like msvc7 but w/o cygpath translation. |
| | | # Just convert the backslash-escaped backslashes to single forward |
| | | # slashes to satisfy depend.m4 |
| | | cygpath_u='sed s,\\\\,/,g' |
| | | depmode=msvc7 |
| | | fi |
| | | |
| | | if test "$depmode" = xlc; then |
| | | # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. |
| | | gccflag=-qmakedep=gcc,-MF |
| | | depmode=gcc |
| | | fi |
| | | |
| | | case "$depmode" in |
| | | gcc3) |
| | | ## gcc 3 implements dependency tracking that does exactly what |
| | | ## we want. Yay! Note: for some reason libtool 1.4 doesn't like |
| | | ## it if -MD -MP comes after the -MF stuff. Hmm. |
| | | ## Unfortunately, FreeBSD c89 acceptance of flags depends upon |
| | | ## the command line argument order; so add the flags where they |
| | | ## appear in depend2.am. Note that the slowdown incurred here |
| | | ## affects only configure: in makefiles, %FASTDEP% shortcuts this. |
| | | for arg |
| | | do |
| | | case $arg in |
| | | -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; |
| | | *) set fnord "$@" "$arg" ;; |
| | | esac |
| | | shift # fnord |
| | | shift # $arg |
| | | done |
| | | "$@" |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | mv "$tmpdepfile" "$depfile" |
| | | ;; |
| | | |
| | | gcc) |
| | | ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. |
| | | ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. |
| | | ## (see the conditional assignment to $gccflag above). |
| | | ## There are various ways to get dependency output from gcc. Here's |
| | | ## why we pick this rather obscure method: |
| | | ## - Don't want to use -MD because we'd like the dependencies to end |
| | | ## up in a subdir. Having to rename by hand is ugly. |
| | | ## (We might end up doing this anyway to support other compilers.) |
| | | ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like |
| | | ## -MM, not -M (despite what the docs say). Also, it might not be |
| | | ## supported by the other compilers which use the 'gcc' depmode. |
| | | ## - Using -M directly means running the compiler twice (even worse |
| | | ## than renaming). |
| | | if test -z "$gccflag"; then |
| | | gccflag=-MD, |
| | | fi |
| | | "$@" -Wp,"$gccflag$tmpdepfile" |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | rm -f "$depfile" |
| | | echo "$object : \\" > "$depfile" |
| | | # The second -e expression handles DOS-style file names with drive |
| | | # letters. |
| | | sed -e 's/^[^:]*: / /' \ |
| | | -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" |
| | | ## This next piece of magic avoids the "deleted header file" problem. |
| | | ## The problem is that when a header file which appears in a .P file |
| | | ## is deleted, the dependency causes make to die (because there is |
| | | ## typically no way to rebuild the header). We avoid this by adding |
| | | ## dummy dependencies for each header file. Too bad gcc doesn't do |
| | | ## this for us directly. |
| | | ## Some versions of gcc put a space before the ':'. On the theory |
| | | ## that the space means something, we add a space to the output as |
| | | ## well. hp depmode also adds that space, but also prefixes the VPATH |
| | | ## to the object. Take care to not repeat it in the output. |
| | | ## Some versions of the HPUX 10.20 sed can't process this invocation |
| | | ## correctly. Breaking it into two sed invocations is a workaround. |
| | | tr ' ' "$nl" < "$tmpdepfile" \ |
| | | | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ |
| | | | sed -e 's/$/ :/' >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | hp) |
| | | # This case exists only to let depend.m4 do its work. It works by |
| | | # looking at the text of this script. This case will never be run, |
| | | # since it is checked for above. |
| | | exit 1 |
| | | ;; |
| | | |
| | | sgi) |
| | | if test "$libtool" = yes; then |
| | | "$@" "-Wp,-MDupdate,$tmpdepfile" |
| | | else |
| | | "$@" -MDupdate "$tmpdepfile" |
| | | fi |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | rm -f "$depfile" |
| | | |
| | | if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files |
| | | echo "$object : \\" > "$depfile" |
| | | # Clip off the initial element (the dependent). Don't try to be |
| | | # clever and replace this with sed code, as IRIX sed won't handle |
| | | # lines with more than a fixed number of characters (4096 in |
| | | # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; |
| | | # the IRIX cc adds comments like '#:fec' to the end of the |
| | | # dependency line. |
| | | tr ' ' "$nl" < "$tmpdepfile" \ |
| | | | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ |
| | | | tr "$nl" ' ' >> "$depfile" |
| | | echo >> "$depfile" |
| | | # The second pass generates a dummy entry for each header file. |
| | | tr ' ' "$nl" < "$tmpdepfile" \ |
| | | | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ |
| | | >> "$depfile" |
| | | else |
| | | make_dummy_depfile |
| | | fi |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | xlc) |
| | | # This case exists only to let depend.m4 do its work. It works by |
| | | # looking at the text of this script. This case will never be run, |
| | | # since it is checked for above. |
| | | exit 1 |
| | | ;; |
| | | |
| | | aix) |
| | | # The C for AIX Compiler uses -M and outputs the dependencies |
| | | # in a .u file. In older versions, this file always lives in the |
| | | # current directory. Also, the AIX compiler puts '$object:' at the |
| | | # start of each line; $object doesn't have directory information. |
| | | # Version 6 uses the directory in both cases. |
| | | set_dir_from "$object" |
| | | set_base_from "$object" |
| | | if test "$libtool" = yes; then |
| | | tmpdepfile1=$dir$base.u |
| | | tmpdepfile2=$base.u |
| | | tmpdepfile3=$dir.libs/$base.u |
| | | "$@" -Wc,-M |
| | | else |
| | | tmpdepfile1=$dir$base.u |
| | | tmpdepfile2=$dir$base.u |
| | | tmpdepfile3=$dir$base.u |
| | | "$@" -M |
| | | fi |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" |
| | | exit $stat |
| | | fi |
| | | |
| | | for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" |
| | | do |
| | | test -f "$tmpdepfile" && break |
| | | done |
| | | aix_post_process_depfile |
| | | ;; |
| | | |
| | | tcc) |
| | | # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 |
| | | # FIXME: That version still under development at the moment of writing. |
| | | # Make that this statement remains true also for stable, released |
| | | # versions. |
| | | # It will wrap lines (doesn't matter whether long or short) with a |
| | | # trailing '\', as in: |
| | | # |
| | | # foo.o : \ |
| | | # foo.c \ |
| | | # foo.h \ |
| | | # |
| | | # It will put a trailing '\' even on the last line, and will use leading |
| | | # spaces rather than leading tabs (at least since its commit 0394caf7 |
| | | # "Emit spaces for -MD"). |
| | | "$@" -MD -MF "$tmpdepfile" |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | rm -f "$depfile" |
| | | # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. |
| | | # We have to change lines of the first kind to '$object: \'. |
| | | sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" |
| | | # And for each line of the second kind, we have to emit a 'dep.h:' |
| | | # dummy dependency, to avoid the deleted-header problem. |
| | | sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | ## The order of this option in the case statement is important, since the |
| | | ## shell code in configure will try each of these formats in the order |
| | | ## listed in this file. A plain '-MD' option would be understood by many |
| | | ## compilers, so we must ensure this comes after the gcc and icc options. |
| | | pgcc) |
| | | # Portland's C compiler understands '-MD'. |
| | | # Will always output deps to 'file.d' where file is the root name of the |
| | | # source file under compilation, even if file resides in a subdirectory. |
| | | # The object file name does not affect the name of the '.d' file. |
| | | # pgcc 10.2 will output |
| | | # foo.o: sub/foo.c sub/foo.h |
| | | # and will wrap long lines using '\' : |
| | | # foo.o: sub/foo.c ... \ |
| | | # sub/foo.h ... \ |
| | | # ... |
| | | set_dir_from "$object" |
| | | # Use the source, not the object, to determine the base name, since |
| | | # that's sadly what pgcc will do too. |
| | | set_base_from "$source" |
| | | tmpdepfile=$base.d |
| | | |
| | | # For projects that build the same source file twice into different object |
| | | # files, the pgcc approach of using the *source* file root name can cause |
| | | # problems in parallel builds. Use a locking strategy to avoid stomping on |
| | | # the same $tmpdepfile. |
| | | lockdir=$base.d-lock |
| | | trap " |
| | | echo '$0: caught signal, cleaning up...' >&2 |
| | | rmdir '$lockdir' |
| | | exit 1 |
| | | " 1 2 13 15 |
| | | numtries=100 |
| | | i=$numtries |
| | | while test $i -gt 0; do |
| | | # mkdir is a portable test-and-set. |
| | | if mkdir "$lockdir" 2>/dev/null; then |
| | | # This process acquired the lock. |
| | | "$@" -MD |
| | | stat=$? |
| | | # Release the lock. |
| | | rmdir "$lockdir" |
| | | break |
| | | else |
| | | # If the lock is being held by a different process, wait |
| | | # until the winning process is done or we timeout. |
| | | while test -d "$lockdir" && test $i -gt 0; do |
| | | sleep 1 |
| | | i=`expr $i - 1` |
| | | done |
| | | fi |
| | | i=`expr $i - 1` |
| | | done |
| | | trap - 1 2 13 15 |
| | | if test $i -le 0; then |
| | | echo "$0: failed to acquire lock after $numtries attempts" >&2 |
| | | echo "$0: check lockdir '$lockdir'" >&2 |
| | | exit 1 |
| | | fi |
| | | |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | rm -f "$depfile" |
| | | # Each line is of the form `foo.o: dependent.h', |
| | | # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. |
| | | # Do two passes, one to just change these to |
| | | # `$object: dependent.h' and one to simply `dependent.h:'. |
| | | sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" |
| | | # Some versions of the HPUX 10.20 sed can't process this invocation |
| | | # correctly. Breaking it into two sed invocations is a workaround. |
| | | sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ |
| | | | sed -e 's/$/ :/' >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | hp2) |
| | | # The "hp" stanza above does not work with aCC (C++) and HP's ia64 |
| | | # compilers, which have integrated preprocessors. The correct option |
| | | # to use with these is +Maked; it writes dependencies to a file named |
| | | # 'foo.d', which lands next to the object file, wherever that |
| | | # happens to be. |
| | | # Much of this is similar to the tru64 case; see comments there. |
| | | set_dir_from "$object" |
| | | set_base_from "$object" |
| | | if test "$libtool" = yes; then |
| | | tmpdepfile1=$dir$base.d |
| | | tmpdepfile2=$dir.libs/$base.d |
| | | "$@" -Wc,+Maked |
| | | else |
| | | tmpdepfile1=$dir$base.d |
| | | tmpdepfile2=$dir$base.d |
| | | "$@" +Maked |
| | | fi |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile1" "$tmpdepfile2" |
| | | exit $stat |
| | | fi |
| | | |
| | | for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" |
| | | do |
| | | test -f "$tmpdepfile" && break |
| | | done |
| | | if test -f "$tmpdepfile"; then |
| | | sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" |
| | | # Add 'dependent.h:' lines. |
| | | sed -ne '2,${ |
| | | s/^ *// |
| | | s/ \\*$// |
| | | s/$/:/ |
| | | p |
| | | }' "$tmpdepfile" >> "$depfile" |
| | | else |
| | | make_dummy_depfile |
| | | fi |
| | | rm -f "$tmpdepfile" "$tmpdepfile2" |
| | | ;; |
| | | |
| | | tru64) |
| | | # The Tru64 compiler uses -MD to generate dependencies as a side |
| | | # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. |
| | | # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put |
| | | # dependencies in 'foo.d' instead, so we check for that too. |
| | | # Subdirectories are respected. |
| | | set_dir_from "$object" |
| | | set_base_from "$object" |
| | | |
| | | if test "$libtool" = yes; then |
| | | # Libtool generates 2 separate objects for the 2 libraries. These |
| | | # two compilations output dependencies in $dir.libs/$base.o.d and |
| | | # in $dir$base.o.d. We have to check for both files, because |
| | | # one of the two compilations can be disabled. We should prefer |
| | | # $dir$base.o.d over $dir.libs/$base.o.d because the latter is |
| | | # automatically cleaned when .libs/ is deleted, while ignoring |
| | | # the former would cause a distcleancheck panic. |
| | | tmpdepfile1=$dir$base.o.d # libtool 1.5 |
| | | tmpdepfile2=$dir.libs/$base.o.d # Likewise. |
| | | tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 |
| | | "$@" -Wc,-MD |
| | | else |
| | | tmpdepfile1=$dir$base.d |
| | | tmpdepfile2=$dir$base.d |
| | | tmpdepfile3=$dir$base.d |
| | | "$@" -MD |
| | | fi |
| | | |
| | | stat=$? |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" |
| | | exit $stat |
| | | fi |
| | | |
| | | for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" |
| | | do |
| | | test -f "$tmpdepfile" && break |
| | | done |
| | | # Same post-processing that is required for AIX mode. |
| | | aix_post_process_depfile |
| | | ;; |
| | | |
| | | msvc7) |
| | | if test "$libtool" = yes; then |
| | | showIncludes=-Wc,-showIncludes |
| | | else |
| | | showIncludes=-showIncludes |
| | | fi |
| | | "$@" $showIncludes > "$tmpdepfile" |
| | | stat=$? |
| | | grep -v '^Note: including file: ' "$tmpdepfile" |
| | | if test $stat -ne 0; then |
| | | rm -f "$tmpdepfile" |
| | | exit $stat |
| | | fi |
| | | rm -f "$depfile" |
| | | echo "$object : \\" > "$depfile" |
| | | # The first sed program below extracts the file names and escapes |
| | | # backslashes for cygpath. The second sed program outputs the file |
| | | # name when reading, but also accumulates all include files in the |
| | | # hold buffer in order to output them again at the end. This only |
| | | # works with sed implementations that can handle large buffers. |
| | | sed < "$tmpdepfile" -n ' |
| | | /^Note: including file: *\(.*\)/ { |
| | | s//\1/ |
| | | s/\\/\\\\/g |
| | | p |
| | | }' | $cygpath_u | sort -u | sed -n ' |
| | | s/ /\\ /g |
| | | s/\(.*\)/'"$tab"'\1 \\/p |
| | | s/.\(.*\) \\/\1:/ |
| | | H |
| | | $ { |
| | | s/.*/'"$tab"'/ |
| | | G |
| | | p |
| | | }' >> "$depfile" |
| | | echo >> "$depfile" # make sure the fragment doesn't end with a backslash |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | msvc7msys) |
| | | # This case exists only to let depend.m4 do its work. It works by |
| | | # looking at the text of this script. This case will never be run, |
| | | # since it is checked for above. |
| | | exit 1 |
| | | ;; |
| | | |
| | | #nosideeffect) |
| | | # This comment above is used by automake to tell side-effect |
| | | # dependency tracking mechanisms from slower ones. |
| | | |
| | | dashmstdout) |
| | | # Important note: in order to support this mode, a compiler *must* |
| | | # always write the preprocessed file to stdout, regardless of -o. |
| | | "$@" || exit $? |
| | | |
| | | # Remove the call to Libtool. |
| | | if test "$libtool" = yes; then |
| | | while test "X$1" != 'X--mode=compile'; do |
| | | shift |
| | | done |
| | | shift |
| | | fi |
| | | |
| | | # Remove '-o $object'. |
| | | IFS=" " |
| | | for arg |
| | | do |
| | | case $arg in |
| | | -o) |
| | | shift |
| | | ;; |
| | | $object) |
| | | shift |
| | | ;; |
| | | *) |
| | | set fnord "$@" "$arg" |
| | | shift # fnord |
| | | shift # $arg |
| | | ;; |
| | | esac |
| | | done |
| | | |
| | | test -z "$dashmflag" && dashmflag=-M |
| | | # Require at least two characters before searching for ':' |
| | | # in the target name. This is to cope with DOS-style filenames: |
| | | # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. |
| | | "$@" $dashmflag | |
| | | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" |
| | | rm -f "$depfile" |
| | | cat < "$tmpdepfile" > "$depfile" |
| | | # Some versions of the HPUX 10.20 sed can't process this sed invocation |
| | | # correctly. Breaking it into two sed invocations is a workaround. |
| | | tr ' ' "$nl" < "$tmpdepfile" \ |
| | | | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ |
| | | | sed -e 's/$/ :/' >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | dashXmstdout) |
| | | # This case only exists to satisfy depend.m4. It is never actually |
| | | # run, as this mode is specially recognized in the preamble. |
| | | exit 1 |
| | | ;; |
| | | |
| | | makedepend) |
| | | "$@" || exit $? |
| | | # Remove any Libtool call |
| | | if test "$libtool" = yes; then |
| | | while test "X$1" != 'X--mode=compile'; do |
| | | shift |
| | | done |
| | | shift |
| | | fi |
| | | # X makedepend |
| | | shift |
| | | cleared=no eat=no |
| | | for arg |
| | | do |
| | | case $cleared in |
| | | no) |
| | | set ""; shift |
| | | cleared=yes ;; |
| | | esac |
| | | if test $eat = yes; then |
| | | eat=no |
| | | continue |
| | | fi |
| | | case "$arg" in |
| | | -D*|-I*) |
| | | set fnord "$@" "$arg"; shift ;; |
| | | # Strip any option that makedepend may not understand. Remove |
| | | # the object too, otherwise makedepend will parse it as a source file. |
| | | -arch) |
| | | eat=yes ;; |
| | | -*|$object) |
| | | ;; |
| | | *) |
| | | set fnord "$@" "$arg"; shift ;; |
| | | esac |
| | | done |
| | | obj_suffix=`echo "$object" | sed 's/^.*\././'` |
| | | touch "$tmpdepfile" |
| | | ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" |
| | | rm -f "$depfile" |
| | | # makedepend may prepend the VPATH from the source file name to the object. |
| | | # No need to regex-escape $object, excess matching of '.' is harmless. |
| | | sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" |
| | | # Some versions of the HPUX 10.20 sed can't process the last invocation |
| | | # correctly. Breaking it into two sed invocations is a workaround. |
| | | sed '1,2d' "$tmpdepfile" \ |
| | | | tr ' ' "$nl" \ |
| | | | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ |
| | | | sed -e 's/$/ :/' >> "$depfile" |
| | | rm -f "$tmpdepfile" "$tmpdepfile".bak |
| | | ;; |
| | | |
| | | cpp) |
| | | # Important note: in order to support this mode, a compiler *must* |
| | | # always write the preprocessed file to stdout. |
| | | "$@" || exit $? |
| | | |
| | | # Remove the call to Libtool. |
| | | if test "$libtool" = yes; then |
| | | while test "X$1" != 'X--mode=compile'; do |
| | | shift |
| | | done |
| | | shift |
| | | fi |
| | | |
| | | # Remove '-o $object'. |
| | | IFS=" " |
| | | for arg |
| | | do |
| | | case $arg in |
| | | -o) |
| | | shift |
| | | ;; |
| | | $object) |
| | | shift |
| | | ;; |
| | | *) |
| | | set fnord "$@" "$arg" |
| | | shift # fnord |
| | | shift # $arg |
| | | ;; |
| | | esac |
| | | done |
| | | |
| | | "$@" -E \ |
| | | | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ |
| | | -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ |
| | | | sed '$ s: \\$::' > "$tmpdepfile" |
| | | rm -f "$depfile" |
| | | echo "$object : \\" > "$depfile" |
| | | cat < "$tmpdepfile" >> "$depfile" |
| | | sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | msvisualcpp) |
| | | # Important note: in order to support this mode, a compiler *must* |
| | | # always write the preprocessed file to stdout. |
| | | "$@" || exit $? |
| | | |
| | | # Remove the call to Libtool. |
| | | if test "$libtool" = yes; then |
| | | while test "X$1" != 'X--mode=compile'; do |
| | | shift |
| | | done |
| | | shift |
| | | fi |
| | | |
| | | IFS=" " |
| | | for arg |
| | | do |
| | | case "$arg" in |
| | | -o) |
| | | shift |
| | | ;; |
| | | $object) |
| | | shift |
| | | ;; |
| | | "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") |
| | | set fnord "$@" |
| | | shift |
| | | shift |
| | | ;; |
| | | *) |
| | | set fnord "$@" "$arg" |
| | | shift |
| | | shift |
| | | ;; |
| | | esac |
| | | done |
| | | "$@" -E 2>/dev/null | |
| | | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" |
| | | rm -f "$depfile" |
| | | echo "$object : \\" > "$depfile" |
| | | sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" |
| | | echo "$tab" >> "$depfile" |
| | | sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" |
| | | rm -f "$tmpdepfile" |
| | | ;; |
| | | |
| | | msvcmsys) |
| | | # This case exists only to let depend.m4 do its work. It works by |
| | | # looking at the text of this script. This case will never be run, |
| | | # since it is checked for above. |
| | | exit 1 |
| | | ;; |
| | | |
| | | none) |
| | | exec "$@" |
| | | ;; |
| | | |
| | | *) |
| | | echo "Unknown depmode $depmode" 1>&2 |
| | | exit 1 |
| | | ;; |
| | | esac |
| | | |
| | | exit 0 |
| | | |
| | | # Local Variables: |
| | | # mode: shell-script |
| | | # sh-indentation: 2 |
| | | # eval: (add-hook 'write-file-hooks 'time-stamp) |
| | | # time-stamp-start: "scriptversion=" |
| | | # time-stamp-format: "%:y-%02m-%02d.%02H" |
| | | # time-stamp-time-zone: "UTC" |
| | | # time-stamp-end: "; # UTC" |
| | | # End: |
New file |
| | |
| | | #!/bin/sh |
| | | # install - install a program, script, or datafile |
| | | |
| | | scriptversion=2011-11-20.07; # UTC |
| | | |
| | | # This originates from X11R5 (mit/util/scripts/install.sh), which was |
| | | # later released in X11R6 (xc/config/util/install.sh) with the |
| | | # following copyright and license. |
| | | # |
| | | # Copyright (C) 1994 X Consortium |
| | | # |
| | | # Permission is hereby granted, free of charge, to any person obtaining a copy |
| | | # of this software and associated documentation files (the "Software"), to |
| | | # deal in the Software without restriction, including without limitation the |
| | | # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
| | | # sell copies of the Software, and to permit persons to whom the Software is |
| | | # furnished to do so, subject to the following conditions: |
| | | # |
| | | # The above copyright notice and this permission notice shall be included in |
| | | # all copies or substantial portions of the Software. |
| | | # |
| | | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| | | # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| | | # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| | | # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN |
| | | # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- |
| | | # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| | | # |
| | | # Except as contained in this notice, the name of the X Consortium shall not |
| | | # be used in advertising or otherwise to promote the sale, use or other deal- |
| | | # ings in this Software without prior written authorization from the X Consor- |
| | | # tium. |
| | | # |
| | | # |
| | | # FSF changes to this file are in the public domain. |
| | | # |
| | | # Calling this script install-sh is preferred over install.sh, to prevent |
| | | # 'make' implicit rules from creating a file called install from it |
| | | # when there is no Makefile. |
| | | # |
| | | # This script is compatible with the BSD install script, but was written |
| | | # from scratch. |
| | | |
| | | nl=' |
| | | ' |
| | | IFS=" "" $nl" |
| | | |
| | | # set DOITPROG to echo to test this script |
| | | |
| | | # Don't use :- since 4.3BSD and earlier shells don't like it. |
| | | doit=${DOITPROG-} |
| | | if test -z "$doit"; then |
| | | doit_exec=exec |
| | | else |
| | | doit_exec=$doit |
| | | fi |
| | | |
| | | # Put in absolute file names if you don't have them in your path; |
| | | # or use environment vars. |
| | | |
| | | chgrpprog=${CHGRPPROG-chgrp} |
| | | chmodprog=${CHMODPROG-chmod} |
| | | chownprog=${CHOWNPROG-chown} |
| | | cmpprog=${CMPPROG-cmp} |
| | | cpprog=${CPPROG-cp} |
| | | mkdirprog=${MKDIRPROG-mkdir} |
| | | mvprog=${MVPROG-mv} |
| | | rmprog=${RMPROG-rm} |
| | | stripprog=${STRIPPROG-strip} |
| | | |
| | | posix_glob='?' |
| | | initialize_posix_glob=' |
| | | test "$posix_glob" != "?" || { |
| | | if (set -f) 2>/dev/null; then |
| | | posix_glob= |
| | | else |
| | | posix_glob=: |
| | | fi |
| | | } |
| | | ' |
| | | |
| | | posix_mkdir= |
| | | |
| | | # Desired mode of installed file. |
| | | mode=0755 |
| | | |
| | | chgrpcmd= |
| | | chmodcmd=$chmodprog |
| | | chowncmd= |
| | | mvcmd=$mvprog |
| | | rmcmd="$rmprog -f" |
| | | stripcmd= |
| | | |
| | | src= |
| | | dst= |
| | | dir_arg= |
| | | dst_arg= |
| | | |
| | | copy_on_change=false |
| | | no_target_directory= |
| | | |
| | | usage="\ |
| | | Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE |
| | | or: $0 [OPTION]... SRCFILES... DIRECTORY |
| | | or: $0 [OPTION]... -t DIRECTORY SRCFILES... |
| | | or: $0 [OPTION]... -d DIRECTORIES... |
| | | |
| | | In the 1st form, copy SRCFILE to DSTFILE. |
| | | In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. |
| | | In the 4th, create DIRECTORIES. |
| | | |
| | | Options: |
| | | --help display this help and exit. |
| | | --version display version info and exit. |
| | | |
| | | -c (ignored) |
| | | -C install only if different (preserve the last data modification time) |
| | | -d create directories instead of installing files. |
| | | -g GROUP $chgrpprog installed files to GROUP. |
| | | -m MODE $chmodprog installed files to MODE. |
| | | -o USER $chownprog installed files to USER. |
| | | -s $stripprog installed files. |
| | | -t DIRECTORY install into DIRECTORY. |
| | | -T report an error if DSTFILE is a directory. |
| | | |
| | | Environment variables override the default commands: |
| | | CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG |
| | | RMPROG STRIPPROG |
| | | " |
| | | |
| | | while test $# -ne 0; do |
| | | case $1 in |
| | | -c) ;; |
| | | |
| | | -C) copy_on_change=true;; |
| | | |
| | | -d) dir_arg=true;; |
| | | |
| | | -g) chgrpcmd="$chgrpprog $2" |
| | | shift;; |
| | | |
| | | --help) echo "$usage"; exit $?;; |
| | | |
| | | -m) mode=$2 |
| | | case $mode in |
| | | *' '* | *' '* | *' |
| | | '* | *'*'* | *'?'* | *'['*) |
| | | echo "$0: invalid mode: $mode" >&2 |
| | | exit 1;; |
| | | esac |
| | | shift;; |
| | | |
| | | -o) chowncmd="$chownprog $2" |
| | | shift;; |
| | | |
| | | -s) stripcmd=$stripprog;; |
| | | |
| | | -t) dst_arg=$2 |
| | | # Protect names problematic for 'test' and other utilities. |
| | | case $dst_arg in |
| | | -* | [=\(\)!]) dst_arg=./$dst_arg;; |
| | | esac |
| | | shift;; |
| | | |
| | | -T) no_target_directory=true;; |
| | | |
| | | --version) echo "$0 $scriptversion"; exit $?;; |
| | | |
| | | --) shift |
| | | break;; |
| | | |
| | | -*) echo "$0: invalid option: $1" >&2 |
| | | exit 1;; |
| | | |
| | | *) break;; |
| | | esac |
| | | shift |
| | | done |
| | | |
| | | if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then |
| | | # When -d is used, all remaining arguments are directories to create. |
| | | # When -t is used, the destination is already specified. |
| | | # Otherwise, the last argument is the destination. Remove it from $@. |
| | | for arg |
| | | do |
| | | if test -n "$dst_arg"; then |
| | | # $@ is not empty: it contains at least $arg. |
| | | set fnord "$@" "$dst_arg" |
| | | shift # fnord |
| | | fi |
| | | shift # arg |
| | | dst_arg=$arg |
| | | # Protect names problematic for 'test' and other utilities. |
| | | case $dst_arg in |
| | | -* | [=\(\)!]) dst_arg=./$dst_arg;; |
| | | esac |
| | | done |
| | | fi |
| | | |
| | | if test $# -eq 0; then |
| | | if test -z "$dir_arg"; then |
| | | echo "$0: no input file specified." >&2 |
| | | exit 1 |
| | | fi |
| | | # It's OK to call 'install-sh -d' without argument. |
| | | # This can happen when creating conditional directories. |
| | | exit 0 |
| | | fi |
| | | |
| | | if test -z "$dir_arg"; then |
| | | do_exit='(exit $ret); exit $ret' |
| | | trap "ret=129; $do_exit" 1 |
| | | trap "ret=130; $do_exit" 2 |
| | | trap "ret=141; $do_exit" 13 |
| | | trap "ret=143; $do_exit" 15 |
| | | |
| | | # Set umask so as not to create temps with too-generous modes. |
| | | # However, 'strip' requires both read and write access to temps. |
| | | case $mode in |
| | | # Optimize common cases. |
| | | *644) cp_umask=133;; |
| | | *755) cp_umask=22;; |
| | | |
| | | *[0-7]) |
| | | if test -z "$stripcmd"; then |
| | | u_plus_rw= |
| | | else |
| | | u_plus_rw='% 200' |
| | | fi |
| | | cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; |
| | | *) |
| | | if test -z "$stripcmd"; then |
| | | u_plus_rw= |
| | | else |
| | | u_plus_rw=,u+rw |
| | | fi |
| | | cp_umask=$mode$u_plus_rw;; |
| | | esac |
| | | fi |
| | | |
| | | for src |
| | | do |
| | | # Protect names problematic for 'test' and other utilities. |
| | | case $src in |
| | | -* | [=\(\)!]) src=./$src;; |
| | | esac |
| | | |
| | | if test -n "$dir_arg"; then |
| | | dst=$src |
| | | dstdir=$dst |
| | | test -d "$dstdir" |
| | | dstdir_status=$? |
| | | else |
| | | |
| | | # Waiting for this to be detected by the "$cpprog $src $dsttmp" command |
| | | # might cause directories to be created, which would be especially bad |
| | | # if $src (and thus $dsttmp) contains '*'. |
| | | if test ! -f "$src" && test ! -d "$src"; then |
| | | echo "$0: $src does not exist." >&2 |
| | | exit 1 |
| | | fi |
| | | |
| | | if test -z "$dst_arg"; then |
| | | echo "$0: no destination specified." >&2 |
| | | exit 1 |
| | | fi |
| | | dst=$dst_arg |
| | | |
| | | # If destination is a directory, append the input filename; won't work |
| | | # if double slashes aren't ignored. |
| | | if test -d "$dst"; then |
| | | if test -n "$no_target_directory"; then |
| | | echo "$0: $dst_arg: Is a directory" >&2 |
| | | exit 1 |
| | | fi |
| | | dstdir=$dst |
| | | dst=$dstdir/`basename "$src"` |
| | | dstdir_status=0 |
| | | else |
| | | # Prefer dirname, but fall back on a substitute if dirname fails. |
| | | dstdir=` |
| | | (dirname "$dst") 2>/dev/null || |
| | | expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ |
| | | X"$dst" : 'X\(//\)[^/]' \| \ |
| | | X"$dst" : 'X\(//\)$' \| \ |
| | | X"$dst" : 'X\(/\)' \| . 2>/dev/null || |
| | | echo X"$dst" | |
| | | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ |
| | | s//\1/ |
| | | q |
| | | } |
| | | /^X\(\/\/\)[^/].*/{ |
| | | s//\1/ |
| | | q |
| | | } |
| | | /^X\(\/\/\)$/{ |
| | | s//\1/ |
| | | q |
| | | } |
| | | /^X\(\/\).*/{ |
| | | s//\1/ |
| | | q |
| | | } |
| | | s/.*/./; q' |
| | | ` |
| | | |
| | | test -d "$dstdir" |
| | | dstdir_status=$? |
| | | fi |
| | | fi |
| | | |
| | | obsolete_mkdir_used=false |
| | | |
| | | if test $dstdir_status != 0; then |
| | | case $posix_mkdir in |
| | | '') |
| | | # Create intermediate dirs using mode 755 as modified by the umask. |
| | | # This is like FreeBSD 'install' as of 1997-10-28. |
| | | umask=`umask` |
| | | case $stripcmd.$umask in |
| | | # Optimize common cases. |
| | | *[2367][2367]) mkdir_umask=$umask;; |
| | | .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; |
| | | |
| | | *[0-7]) |
| | | mkdir_umask=`expr $umask + 22 \ |
| | | - $umask % 100 % 40 + $umask % 20 \ |
| | | - $umask % 10 % 4 + $umask % 2 |
| | | `;; |
| | | *) mkdir_umask=$umask,go-w;; |
| | | esac |
| | | |
| | | # With -d, create the new directory with the user-specified mode. |
| | | # Otherwise, rely on $mkdir_umask. |
| | | if test -n "$dir_arg"; then |
| | | mkdir_mode=-m$mode |
| | | else |
| | | mkdir_mode= |
| | | fi |
| | | |
| | | posix_mkdir=false |
| | | case $umask in |
| | | *[123567][0-7][0-7]) |
| | | # POSIX mkdir -p sets u+wx bits regardless of umask, which |
| | | # is incompatible with FreeBSD 'install' when (umask & 300) != 0. |
| | | ;; |
| | | *) |
| | | tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ |
| | | trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 |
| | | |
| | | if (umask $mkdir_umask && |
| | | exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 |
| | | then |
| | | if test -z "$dir_arg" || { |
| | | # Check for POSIX incompatibilities with -m. |
| | | # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or |
| | | # other-writable bit of parent directory when it shouldn't. |
| | | # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. |
| | | ls_ld_tmpdir=`ls -ld "$tmpdir"` |
| | | case $ls_ld_tmpdir in |
| | | d????-?r-*) different_mode=700;; |
| | | d????-?--*) different_mode=755;; |
| | | *) false;; |
| | | esac && |
| | | $mkdirprog -m$different_mode -p -- "$tmpdir" && { |
| | | ls_ld_tmpdir_1=`ls -ld "$tmpdir"` |
| | | test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" |
| | | } |
| | | } |
| | | then posix_mkdir=: |
| | | fi |
| | | rmdir "$tmpdir/d" "$tmpdir" |
| | | else |
| | | # Remove any dirs left behind by ancient mkdir implementations. |
| | | rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null |
| | | fi |
| | | trap '' 0;; |
| | | esac;; |
| | | esac |
| | | |
| | | if |
| | | $posix_mkdir && ( |
| | | umask $mkdir_umask && |
| | | $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" |
| | | ) |
| | | then : |
| | | else |
| | | |
| | | # The umask is ridiculous, or mkdir does not conform to POSIX, |
| | | # or it failed possibly due to a race condition. Create the |
| | | # directory the slow way, step by step, checking for races as we go. |
| | | |
| | | case $dstdir in |
| | | /*) prefix='/';; |
| | | [-=\(\)!]*) prefix='./';; |
| | | *) prefix='';; |
| | | esac |
| | | |
| | | eval "$initialize_posix_glob" |
| | | |
| | | oIFS=$IFS |
| | | IFS=/ |
| | | $posix_glob set -f |
| | | set fnord $dstdir |
| | | shift |
| | | $posix_glob set +f |
| | | IFS=$oIFS |
| | | |
| | | prefixes= |
| | | |
| | | for d |
| | | do |
| | | test X"$d" = X && continue |
| | | |
| | | prefix=$prefix$d |
| | | if test -d "$prefix"; then |
| | | prefixes= |
| | | else |
| | | if $posix_mkdir; then |
| | | (umask=$mkdir_umask && |
| | | $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break |
| | | # Don't fail if two instances are running concurrently. |
| | | test -d "$prefix" || exit 1 |
| | | else |
| | | case $prefix in |
| | | *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; |
| | | *) qprefix=$prefix;; |
| | | esac |
| | | prefixes="$prefixes '$qprefix'" |
| | | fi |
| | | fi |
| | | prefix=$prefix/ |
| | | done |
| | | |
| | | if test -n "$prefixes"; then |
| | | # Don't fail if two instances are running concurrently. |
| | | (umask $mkdir_umask && |
| | | eval "\$doit_exec \$mkdirprog $prefixes") || |
| | | test -d "$dstdir" || exit 1 |
| | | obsolete_mkdir_used=true |
| | | fi |
| | | fi |
| | | fi |
| | | |
| | | if test -n "$dir_arg"; then |
| | | { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && |
| | | { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && |
| | | { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || |
| | | test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 |
| | | else |
| | | |
| | | # Make a couple of temp file names in the proper directory. |
| | | dsttmp=$dstdir/_inst.$$_ |
| | | rmtmp=$dstdir/_rm.$$_ |
| | | |
| | | # Trap to clean up those temp files at exit. |
| | | trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 |
| | | |
| | | # Copy the file name to the temp name. |
| | | (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && |
| | | |
| | | # and set any options; do chmod last to preserve setuid bits. |
| | | # |
| | | # If any of these fail, we abort the whole thing. If we want to |
| | | # ignore errors from any of these, just make sure not to ignore |
| | | # errors from the above "$doit $cpprog $src $dsttmp" command. |
| | | # |
| | | { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && |
| | | { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && |
| | | { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && |
| | | { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && |
| | | |
| | | # If -C, don't bother to copy if it wouldn't change the file. |
| | | if $copy_on_change && |
| | | old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && |
| | | new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && |
| | | |
| | | eval "$initialize_posix_glob" && |
| | | $posix_glob set -f && |
| | | set X $old && old=:$2:$4:$5:$6 && |
| | | set X $new && new=:$2:$4:$5:$6 && |
| | | $posix_glob set +f && |
| | | |
| | | test "$old" = "$new" && |
| | | $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 |
| | | then |
| | | rm -f "$dsttmp" |
| | | else |
| | | # Rename the file to the real destination. |
| | | $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || |
| | | |
| | | # The rename failed, perhaps because mv can't rename something else |
| | | # to itself, or perhaps because mv is so ancient that it does not |
| | | # support -f. |
| | | { |
| | | # Now remove or move aside any old file at destination location. |
| | | # We try this two ways since rm can't unlink itself on some |
| | | # systems and the destination file might be busy for other |
| | | # reasons. In this case, the final cleanup might fail but the new |
| | | # file should still install successfully. |
| | | { |
| | | test ! -f "$dst" || |
| | | $doit $rmcmd -f "$dst" 2>/dev/null || |
| | | { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && |
| | | { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } |
| | | } || |
| | | { echo "$0: cannot unlink or rename $dst" >&2 |
| | | (exit 1); exit 1 |
| | | } |
| | | } && |
| | | |
| | | # Now rename the file to the real destination. |
| | | $doit $mvcmd "$dsttmp" "$dst" |
| | | } |
| | | fi || exit 1 |
| | | |
| | | trap '' 0 |
| | | fi |
| | | done |
| | | |
| | | # Local variables: |
| | | # eval: (add-hook 'write-file-hooks 'time-stamp) |
| | | # time-stamp-start: "scriptversion=" |
| | | # time-stamp-format: "%:y-%02m-%02d.%02H" |
| | | # time-stamp-time-zone: "UTC" |
| | | # time-stamp-end: "; # UTC" |
| | | # End: |
New file |
| | |
| | | #! /bin/sh |
| | | # Common wrapper for a few potentially missing GNU programs. |
| | | |
| | | scriptversion=2012-06-26.16; # UTC |
| | | |
| | | # Copyright (C) 1996-2013 Free Software Foundation, Inc. |
| | | # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 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 <http://www.gnu.org/licenses/>. |
| | | |
| | | # 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 <bug-automake@gnu.org>." |
| | | exit $? |
| | | ;; |
| | | |
| | | -v|--v|--ve|--ver|--vers|--versi|--versio|--version) |
| | | echo "missing $scriptversion (GNU Automake)" |
| | | exit $? |
| | | ;; |
| | | |
| | | -*) |
| | | echo 1>&2 "$0: unknown '$1' option" |
| | | echo 1>&2 "Try '$0 --help' for more information" |
| | | exit 1 |
| | | ;; |
| | | |
| | | esac |
| | | |
| | | # Run the given program, remember its exit status. |
| | | "$@"; st=$? |
| | | |
| | | # If it succeeded, we are done. |
| | | test $st -eq 0 && exit 0 |
| | | |
| | | # Also exit now if we it failed (or wasn't found), and '--version' was |
| | | # passed; such an option is passed most likely to detect whether the |
| | | # program is present and works. |
| | | case $2 in --version|--help) exit $st;; esac |
| | | |
| | | # Exit code 63 means version mismatch. This often happens when the user |
| | | # tries to use an ancient version of a tool on a file that requires a |
| | | # minimum version. |
| | | if test $st -eq 63; then |
| | | msg="probably too old" |
| | | elif test $st -eq 127; then |
| | | # Program was missing. |
| | | msg="missing on your system" |
| | | else |
| | | # Program was found and executed, but failed. Give up. |
| | | exit $st |
| | | fi |
| | | |
| | | perl_URL=http://www.perl.org/ |
| | | flex_URL=http://flex.sourceforge.net/ |
| | | gnu_software_URL=http://www.gnu.org/software |
| | | |
| | | program_details () |
| | | { |
| | | case $1 in |
| | | aclocal|automake) |
| | | echo "The '$1' program is part of the GNU Automake package:" |
| | | echo "<$gnu_software_URL/automake>" |
| | | echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" |
| | | echo "<$gnu_software_URL/autoconf>" |
| | | echo "<$gnu_software_URL/m4/>" |
| | | echo "<$perl_URL>" |
| | | ;; |
| | | autoconf|autom4te|autoheader) |
| | | echo "The '$1' program is part of the GNU Autoconf package:" |
| | | echo "<$gnu_software_URL/autoconf/>" |
| | | echo "It also requires GNU m4 and Perl in order to run:" |
| | | echo "<$gnu_software_URL/m4/>" |
| | | echo "<$perl_URL>" |
| | | ;; |
| | | esac |
| | | } |
| | | |
| | | give_advice () |
| | | { |
| | | # Normalize program name to check for. |
| | | normalized_program=`echo "$1" | sed ' |
| | | s/^gnu-//; t |
| | | s/^gnu//; t |
| | | s/^g//; t'` |
| | | |
| | | printf '%s\n' "'$1' is $msg." |
| | | |
| | | configure_deps="'configure.ac' or m4 files included by 'configure.ac'" |
| | | case $normalized_program in |
| | | autoconf*) |
| | | echo "You should only need it if you modified 'configure.ac'," |
| | | echo "or m4 files included by it." |
| | | program_details 'autoconf' |
| | | ;; |
| | | autoheader*) |
| | | echo "You should only need it if you modified 'acconfig.h' or" |
| | | echo "$configure_deps." |
| | | program_details 'autoheader' |
| | | ;; |
| | | automake*) |
| | | echo "You should only need it if you modified 'Makefile.am' or" |
| | | echo "$configure_deps." |
| | | program_details 'automake' |
| | | ;; |
| | | aclocal*) |
| | | echo "You should only need it if you modified 'acinclude.m4' or" |
| | | echo "$configure_deps." |
| | | program_details 'aclocal' |
| | | ;; |
| | | autom4te*) |
| | | echo "You might have modified some maintainer files that require" |
| | | echo "the 'automa4te' program to be rebuilt." |
| | | program_details 'autom4te' |
| | | ;; |
| | | bison*|yacc*) |
| | | echo "You should only need it if you modified a '.y' file." |
| | | echo "You may want to install the GNU Bison package:" |
| | | echo "<$gnu_software_URL/bison/>" |
| | | ;; |
| | | lex*|flex*) |
| | | echo "You should only need it if you modified a '.l' file." |
| | | echo "You may want to install the Fast Lexical Analyzer package:" |
| | | echo "<$flex_URL>" |
| | | ;; |
| | | help2man*) |
| | | echo "You should only need it if you modified a dependency" \ |
| | | "of a man page." |
| | | echo "You may want to install the GNU Help2man package:" |
| | | echo "<$gnu_software_URL/help2man/>" |
| | | ;; |
| | | makeinfo*) |
| | | echo "You should only need it if you modified a '.texi' file, or" |
| | | echo "any other file indirectly affecting the aspect of the manual." |
| | | echo "You might want to install the Texinfo package:" |
| | | echo "<$gnu_software_URL/texinfo/>" |
| | | echo "The spurious makeinfo call might also be the consequence of" |
| | | echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" |
| | | echo "want to install GNU make:" |
| | | echo "<$gnu_software_URL/make/>" |
| | | ;; |
| | | *) |
| | | echo "You might have modified some files without having the proper" |
| | | echo "tools for further handling them. Check the 'README' file, it" |
| | | echo "often tells you about the needed prerequisites for installing" |
| | | echo "this package. You may also peek at any GNU archive site, in" |
| | | echo "case some other package contains this missing '$1' program." |
| | | ;; |
| | | esac |
| | | } |
| | | |
| | | give_advice "$1" | sed -e '1s/^/WARNING: /' \ |
| | | -e '2,$s/^/ /' >&2 |
| | | |
| | | # Propagate the correct exit status (expected to be 127 for a program |
| | | # not found, 63 for a program that failed due to version mismatch). |
| | | exit $st |
| | | |
| | | # Local variables: |
| | | # eval: (add-hook 'write-file-hooks 'time-stamp) |
| | | # time-stamp-start: "scriptversion=" |
| | | # time-stamp-format: "%:y-%02m-%02d.%02H" |
| | | # time-stamp-time-zone: "UTC" |
| | | # time-stamp-end: "; # UTC" |
| | | # End: |
| | |
| | | #include "bondflip.h" |
| | | //#include "io.h" |
| | | #include<stdio.h> |
| | | #include<string.h> |
| | | |
| | | ts_bool single_bondflip_timestep(ts_vesicle *vesicle, ts_bond *bond, ts_double *rn){ |
| | | /*c Vertex and triangle (lm and lp) indexing for bond flip: |
| | |
| | | ts_vertex *it=bond->vtx1; |
| | | ts_vertex *k=bond->vtx2; |
| | | ts_uint nei,neip,neim; |
| | | ts_uint i; //j; |
| | | ts_double oldenergy, delta_energy; |
| | | // ts_triangle *lm=NULL,*lp=NULL, *lp1=NULL, *lp2=NULL, *lm1=NULL, *lm2=NULL; |
| | | ts_uint i,j; |
| | | ts_double oldenergy, delta_energy, dvol=0.0; |
| | | ts_triangle *lm=NULL,*lp=NULL, *lp1=NULL, *lm2=NULL; |
| | | |
| | | ts_vertex *kp,*km; |
| | | |
| | |
| | | // fprintf(stderr,"Bond will not be too long.. Continue.\n"); |
| | | |
| | | /* we make a bond flip. this is different than in original fortran */ |
| | | // 0. step. Get memory prior the flip |
| | | oldenergy=0; |
| | | oldenergy+=k->xk* k->energy; |
| | | oldenergy+=kp->xk* kp->energy; |
| | | oldenergy+=km->xk* km->energy; |
| | | oldenergy+=it->xk* it->energy; |
| | | // for(i=0;i<k->neigh_no;i++) oldenergy+=k->neigh[i]->xk*k->neigh[i]->energy; |
| | | // for(i=0;i<kp->neigh_no;i++) oldenergy+=kp->neigh[i]->xk*kp->neigh[i]->energy; |
| | | // for(i=0;i<km->neigh_no;i++) oldenergy+=km->neigh[i]->xk*km->neigh[i]->energy; |
| | | // for(i=0;i<it->neigh_no;i++) oldenergy+=it->neigh[i]->xk*it->neigh[i]->energy; |
| | | /* |
| | | fprintf(stderr,"*** Naslov k=%ld\n",(long)k); |
| | | fprintf(stderr,"*** Naslov it=%ld\n",(long)it); |
| | | fprintf(stderr,"*** Naslov km=%ld\n",(long)km); |
| | | fprintf(stderr,"*** Naslov kp=%ld\n",(long)kp); |
| | | |
| | | for(i=0;i<k->neigh_no;i++) |
| | | fprintf(stderr,"k sosed=%ld\n",(long)k->neigh[i]); |
| | | for(i=0;i<it->neigh_no;i++) |
| | | fprintf(stderr,"it sosed=%ld\n",(long)it->neigh[i]); |
| | | |
| | | for(i=0;i<km->neigh_no;i++) |
| | | fprintf(stderr,"km sosed=%ld\n",(long)km->neigh[i]); |
| | | for(i=0;i<kp->neigh_no;i++) |
| | | fprintf(stderr,"kp sosed=%ld\n",(long)kp->neigh[i]); |
| | | |
| | | |
| | | */ |
| | | // fprintf(stderr,"I WAS HERE! Before bondflip!\n"); |
| | | ts_flip_bond(k,it,km,kp, bond); |
| | | // fprintf(stderr,"I WAS HERE! Bondflip successful!\n"); |
| | | |
| | | /* Calculating the new energy */ |
| | | delta_energy=0; |
| | | for(i=0;i<k->neigh_no;i++) energy_vertex(k->neigh[i]); |
| | | for(i=0;i<kp->neigh_no;i++) energy_vertex(kp->neigh[i]); |
| | | for(i=0;i<km->neigh_no;i++) energy_vertex(km->neigh[i]); |
| | | for(i=0;i<it->neigh_no;i++) energy_vertex(it->neigh[i]); |
| | | delta_energy+=k->xk* k->energy; |
| | | delta_energy+=kp->xk* kp->energy; |
| | | delta_energy+=km->xk* km->energy; |
| | | delta_energy+=it->xk* it->energy; |
| | | // for(i=0;i<k->neigh_no;i++) delta_energy+=k->neigh[i]->xk*k->neigh[i]->energy; |
| | | // for(i=0;i<kp->neigh_no;i++) delta_energy+=kp->neigh[i]->xk*kp->neigh[i]->energy; |
| | | // for(i=0;i<km->neigh_no;i++) delta_energy+=km->neigh[i]->xk*km->neigh[i]->energy; |
| | | // for(i=0;i<it->neigh_no;i++) delta_energy+=it->neigh[i]->xk*it->neigh[i]->energy; |
| | | delta_energy-=oldenergy; |
| | | // fprintf(stderr,"I WAS HERE! Got energy!\n"); |
| | | /* MONTE CARLO */ |
| | | if(delta_energy>=0){ |
| | | #ifdef TS_DOUBLE_DOUBLE |
| | | if(exp(-delta_energy)< drand48() ) |
| | | #endif |
| | | #ifdef TS_DOUBLE_FLOAT |
| | | if(expf(-delta_energy)< (ts_float)drand48()) |
| | | #endif |
| | | #ifdef TS_DOUBLE_LONGDOUBLE |
| | | if(expl(-delta_energy)< (ts_ldouble)drand48()) |
| | | #endif |
| | | { |
| | | //not accepted, reverting changes |
| | | // fprintf(stderr,"Failed to move, due to MC\n"); |
| | | |
| | | // ts_flip_bond(km,kp,it,k, bond); |
| | | ts_flip_bond(kp,km,k,it, bond); |
| | | |
| | | |
| | | /* |
| | | fprintf(stderr,"*** Naslov k=%d\n",k); |
| | | fprintf(stderr,"*** Naslov it=%d\n",it); |
| | | fprintf(stderr,"*** Naslov km=%d\n",km); |
| | | fprintf(stderr,"*** Naslov kp=%d\n",kp); |
| | | for(i=0;i<k->neigh_no;i++) |
| | | fprintf(stderr,"k sosed=%d\n",k->neigh[i]); |
| | | for(i=0;i<it->neigh_no;i++) |
| | | fprintf(stderr,"it sosed=%d\n",it->neigh[i]); |
| | | |
| | | |
| | | for(i=0;i<km->neigh_no;i++) |
| | | fprintf(stderr,"km sosed=%d\n",km->neigh[i]); |
| | | for(i=0;i<kp->neigh_no;i++) |
| | | fprintf(stderr,"kp sosed=%d\n",kp->neigh[i]); |
| | | */ |
| | | |
| | | |
| | | |
| | | // fprintf(stderr,"Reverted condition!\n"); |
| | | return TS_FAIL; |
| | | } |
| | | } |
| | | // fprintf(stderr,"Success\n"); |
| | | |
| | | |
| | | /* IF BONDFLIP ACCEPTED, THEN RETURN SUCCESS! */ |
| | | return TS_SUCCESS; |
| | | } |
| | | |
| | | |
| | | ts_bool ts_flip_bond(ts_vertex *k,ts_vertex *it,ts_vertex *km, ts_vertex *kp, |
| | | ts_bond *bond){ |
| | | |
| | | ts_triangle *lm=NULL,*lp=NULL, *lp1=NULL, *lm2=NULL; |
| | | ts_uint i,j; //lmidx, lpidx; |
| | | if(k==NULL || it==NULL || km==NULL || kp==NULL){ |
| | | fatal("ts_flip_bond: You called me with invalid pointers to vertices",999); |
| | | } |
| | | // find lm, lp |
| | | // 1. step. We find lm and lp from k->tristar ! |
| | | for(i=0;i<it->tristar_no;i++){ |
| | | for(j=0;j<k->tristar_no;j++){ |
| | |
| | | } |
| | | } |
| | | } |
| | | /* |
| | | // DEBUG TESTING! |
| | | fprintf(stderr,"*** Naslov k=%d\n",k); |
| | | fprintf(stderr,"*** Naslov it=%d\n",it); |
| | | fprintf(stderr,"*** Naslov km=%d\n",km); |
| | | fprintf(stderr,"*** Naslov kp=%d\n",kp); |
| | | |
| | | for(i=0;i<k->neigh_no;i++) |
| | | fprintf(stderr,"k sosed=%d\n",k->neigh[i]); |
| | | for(i=0;i<it->neigh_no;i++) |
| | | fprintf(stderr,"it sosed=%d\n",it->neigh[i]); |
| | | |
| | | |
| | | // END DEBUG TESTING! |
| | | */ |
| | | if(lm2==NULL || lp1==NULL) fatal("ts_flip_bond: Cannot find triangles lm2 and lp1!",999); |
| | | |
| | | /* |
| | | //DEBUG TESTING |
| | | fprintf(stderr,"1. step: lm, lm2, lp1 and lp found!\n"); |
| | | fprintf(stderr,"--- Naslov lm=%ld",(long)lm); |
| | | |
| | | /* backup old structure */ |
| | | /* need to backup: |
| | | * vertices k, kp, km, it |
| | | * triangles lm, lp, lm2, lp1 |
| | | * bond |
| | | */ |
| | | ts_vertex *bck_vtx[4]; |
| | | ts_triangle *bck_tria[4]; |
| | | ts_bond *bck_bond; |
| | | ts_vertex *orig_vtx[]={k,it,kp,km}; |
| | | ts_triangle *orig_tria[]={lm,lp,lm2,lp1}; |
| | | |
| | | fprintf(stderr," vtxs(%ld, %ld, %ld)\n",(long)lm->vertex[0],(long)lm->vertex[1], (long)lm->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lp=%ld",(long)lp); |
| | | fprintf(stderr," vtxs(%ld, %ld, %ld)\n",(long)lp->vertex[0],(long)lp->vertex[1], (long)lp->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lm2=%ld",(long)lm2); |
| | | fprintf(stderr," vtxs(%ld, %ld, %ld)\n",(long)lm2->vertex[0],(long)lm2->vertex[1], (long)lm2->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lp1=%ld",(long)lp1); |
| | | fprintf(stderr," vtxs(%ld, %ld, %ld)\n",(long)lp1->vertex[0],(long)lp1->vertex[1], (long)lp1->vertex[2]); |
| | | |
| | | for(i=0;i<lm->neigh_no;i++) |
| | | fprintf(stderr,"lm sosed=%ld\n",(long)lm->neigh[i]); |
| | | for(i=0;i<lp->neigh_no;i++) |
| | | fprintf(stderr,"lp sosed=%ld\n",(long)lp->neigh[i]); |
| | | // END DEBUG TESTING |
| | | //fprintf(stderr,"Backuping!!!\n"); |
| | | bck_bond=(ts_bond *)malloc(sizeof(ts_bond)); |
| | | for(i=0;i<4;i++){ |
| | | /* fprintf(stderr,"vtx neigh[%d]=",i); |
| | | for(j=0;j<orig_vtx[i]->neigh_no;j++) fprintf(stderr," %d", orig_vtx[i]->neigh[j]->idx); |
| | | fprintf(stderr,"\n"); |
| | | */ |
| | | /* |
| | | // DEBUG TESTING! |
| | | bck_vtx[i]=(ts_vertex *)malloc(sizeof(ts_vertex)); |
| | | bck_tria[i]=(ts_triangle *)malloc(sizeof(ts_triangle)); |
| | | memcpy((void *)bck_vtx[i],(void *)orig_vtx[i],sizeof(ts_vertex)); |
| | | memcpy((void *)bck_tria[i],(void *)orig_tria[i],sizeof(ts_triangle)); |
| | | /* level 2 pointers */ |
| | | |
| | | for(i=0;i<3;i++){ |
| | | bck_vtx[i]->neigh=(ts_vertex **)malloc(orig_vtx[i]->neigh_no*sizeof(ts_vertex *)); |
| | | bck_vtx[i]->tristar=(ts_triangle **)malloc(orig_vtx[i]->tristar_no*sizeof(ts_triangle *)); |
| | | bck_vtx[i]->bond=(ts_bond **)malloc(orig_vtx[i]->bond_no*sizeof(ts_bond *)); |
| | | bck_tria[i]->neigh=(ts_triangle **)malloc(orig_tria[i]->neigh_no*sizeof(ts_triangle *)); |
| | | |
| | | if(lp1->neigh[i]==lp) fprintf(stderr,"Nasel sem par lp1->lp\n"); |
| | | if(lp->neigh[i]==lp1) fprintf(stderr,"Nasel sem par lp->lp1\n"); |
| | | if(lm2->neigh[i]==lm) fprintf(stderr,"Nasel sem par lm2->lm\n"); |
| | | if(lm->neigh[i]==lm2) fprintf(stderr,"Nasel sem par lm->lm2\n"); |
| | | memcpy((void *)bck_vtx[i]->neigh,(void *)orig_vtx[i]->neigh,orig_vtx[i]->neigh_no*sizeof(ts_vertex *)); |
| | | memcpy((void *)bck_vtx[i]->tristar,(void *)orig_vtx[i]->tristar,orig_vtx[i]->tristar_no*sizeof(ts_triangle *)); |
| | | memcpy((void *)bck_vtx[i]->bond,(void *)orig_vtx[i]->bond,orig_vtx[i]->bond_no*sizeof(ts_bond *)); |
| | | |
| | | memcpy((void *)bck_tria[i]->neigh,(void *)orig_tria[i]->neigh,orig_tria[i]->neigh_no*sizeof(ts_triangle *)); |
| | | } |
| | | // END DEBUG TESTING! |
| | | */ |
| | | memcpy(bck_bond,bond,sizeof(ts_bond)); |
| | | //fprintf(stderr,"Backup complete!!!\n"); |
| | | /* end backup vertex */ |
| | | |
| | | /* Save old energy */ |
| | | oldenergy=0; |
| | | oldenergy+=k->xk* k->energy; |
| | | oldenergy+=kp->xk* kp->energy; |
| | | oldenergy+=km->xk* km->energy; |
| | | oldenergy+=it->xk* it->energy; |
| | | //Neigbours of k, it, km, kp don't change its energy. |
| | | |
| | | if(vesicle->pswitch == 1){dvol = -lm->volume - lp->volume;} |
| | | |
| | | /* fix data structure for flipped bond */ |
| | | ts_flip_bond(k,it,km,kp, bond,lm, lp, lm2, lp1); |
| | | |
| | | |
| | | /* Calculating the new energy */ |
| | | delta_energy=0; |
| | | delta_energy+=k->xk* k->energy; |
| | | delta_energy+=kp->xk* kp->energy; |
| | | delta_energy+=km->xk* km->energy; |
| | | delta_energy+=it->xk* it->energy; |
| | | //Neigbours of k, it, km, kp don't change its energy. |
| | | |
| | | delta_energy-=oldenergy; |
| | | if(vesicle->pswitch == 1){ |
| | | dvol = dvol + lm->volume + lp->volume; |
| | | delta_energy-= vesicle->pressure*dvol; |
| | | } |
| | | |
| | | /* MONTE CARLO */ |
| | | if(delta_energy>=0){ |
| | | #ifdef TS_DOUBLE_DOUBLE |
| | | if(exp(-delta_energy)< drand48() ) |
| | | #endif |
| | | #ifdef TS_DOUBLE_FLOAT |
| | | if(expf(-delta_energy)< (ts_float)drand48()) |
| | | #endif |
| | | #ifdef TS_DOUBLE_LONGDOUBLE |
| | | if(expl(-delta_energy)< (ts_ldouble)drand48()) |
| | | #endif |
| | | { |
| | | //not accepted, reverting changes |
| | | //restore all backups |
| | | // fprintf(stderr,"Restoring!!!\n"); |
| | | |
| | | for(i=0;i<4;i++){ |
| | | // fprintf(stderr,"Restoring vtx neigh[%d] with neighbours %d\n",i, orig_vtx[i]->neigh_no ); |
| | | free(orig_vtx[i]->neigh); |
| | | free(orig_vtx[i]->tristar); |
| | | free(orig_vtx[i]->bond); |
| | | free(orig_tria[i]->neigh); |
| | | memcpy((void *)orig_vtx[i],(void *)bck_vtx[i],sizeof(ts_vertex)); |
| | | memcpy((void *)orig_tria[i],(void *)bck_tria[i],sizeof(ts_triangle)); |
| | | // fprintf(stderr,"Restored vtx neigh[%d] with neighbours %d\n",i, orig_vtx[i]->neigh_no ); |
| | | /* level 2 pointers are redirected*/ |
| | | } |
| | | memcpy(bond,bck_bond,sizeof(ts_bond)); |
| | | |
| | | for(i=0;i<4;i++){ |
| | | free(bck_vtx[i]); |
| | | free(bck_tria[i]); |
| | | /* fprintf(stderr,"Restoring vtx neigh[%d] with neighbours %d =",i, orig_vtx[i]->neigh_no ); |
| | | for(j=0;j<orig_vtx[i]->neigh_no;j++) fprintf(stderr," %d", orig_vtx[i]->neigh[j]->idx); |
| | | fprintf(stderr,"\n"); */ |
| | | } |
| | | |
| | | free(bck_bond); |
| | | // fprintf(stderr,"Restoration complete!!!\n"); |
| | | |
| | | return TS_FAIL; |
| | | } |
| | | } |
| | | /* IF BONDFLIP ACCEPTED, THEN RETURN SUCCESS! */ |
| | | // fprintf(stderr,"SUCCESS!!!\n"); |
| | | |
| | | // delete all backups |
| | | for(i=0;i<4;i++){ |
| | | free(bck_vtx[i]->neigh); |
| | | free(bck_vtx[i]->bond); |
| | | free(bck_vtx[i]->tristar); |
| | | free(bck_vtx[i]); |
| | | free(bck_tria[i]->neigh); |
| | | free(bck_tria[i]); |
| | | /* fprintf(stderr,"Afret backup deletion vtx neigh[%d]=",i); |
| | | for(j=0;j<orig_vtx[i]->neigh_no;j++) fprintf(stderr," %d", orig_vtx[i]->neigh[j]->idx); |
| | | fprintf(stderr,"\n"); |
| | | */ |
| | | } |
| | | free(bck_bond); |
| | | |
| | | return TS_SUCCESS; |
| | | } |
| | | |
| | | |
| | | ts_bool ts_flip_bond(ts_vertex *k,ts_vertex *it,ts_vertex *km, ts_vertex *kp, |
| | | ts_bond *bond, ts_triangle *lm, ts_triangle *lp, ts_triangle *lm2, ts_triangle *lp1){ |
| | | |
| | | ts_uint i; //lmidx, lpidx; |
| | | if(k==NULL || it==NULL || km==NULL || kp==NULL){ |
| | | fatal("ts_flip_bond: You called me with invalid pointers to vertices",999); |
| | | } |
| | | // 2. step. We change the triangle vertices... (actual bond flip) |
| | | for(i=0;i<3;i++) if(lm->vertex[i]== it) lm->vertex[i]= kp; |
| | | for(i=0;i<3;i++) if(lp->vertex[i]== k) lp->vertex[i]= km; |
| | |
| | | vtx_remove_tristar(it,lm); |
| | | vtx_remove_tristar(k,lp); |
| | | //fprintf(stderr,"6. step: tristar corrected\n"); |
| | | |
| | | /* |
| | | //DEBUG TESTING |
| | | fprintf(stderr,"--- Naslov lm=%d",lm); |
| | | |
| | | |
| | | fprintf(stderr," vtxs(%d, %d, %d)\n",lm->vertex[0],lm->vertex[1], lm->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lp=%d",lp); |
| | | fprintf(stderr," vtxs(%d, %d, %d)\n",lp->vertex[0],lp->vertex[1], lp->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lm2=%d",lm2); |
| | | fprintf(stderr," vtxs(%d, %d, %d)\n",lm2->vertex[0],lm2->vertex[1], lm2->vertex[2]); |
| | | fprintf(stderr,"--- Naslov lp1=%d",lp1); |
| | | fprintf(stderr," vtxs(%d, %d, %d)\n",lp1->vertex[0],lp1->vertex[1], lp1->vertex[2]); |
| | | |
| | | for(i=0;i<lm->neigh_no;i++) |
| | | fprintf(stderr,"lm sosed=%d\n",lm->neigh[i]); |
| | | for(i=0;i<lp->neigh_no;i++) |
| | | fprintf(stderr,"lp sosed=%d\n",lp->neigh[i]); |
| | | // END DEBUG TESTING |
| | | */ |
| | | energy_vertex(k); |
| | | energy_vertex(kp); |
| | | energy_vertex(km); |
| | | energy_vertex(it); |
| | | |
| | | |
| | | // END modifications to data structure! |
| | | |
| | | |
| | | return TS_SUCCESS; |
| | | } |
| | |
| | | |
| | | ts_bool single_bondflip_timestep(ts_vesicle *vesicle, ts_bond *bond, ts_double *rn); |
| | | |
| | | ts_bool ts_flip_bond(ts_vertex *k,ts_vertex *it,ts_vertex *km, ts_vertex *kp, ts_bond *bond); |
| | | ts_bool ts_flip_bond(ts_vertex *k,ts_vertex *it,ts_vertex *km, ts_vertex *kp, ts_bond *bond, ts_triangle *lm, ts_triangle *lp, ts_triangle *lm2, ts_triangle *lp1); |
| | | #endif |
| | |
| | | |
| | | ts_poly_list *poly_list; |
| | | ts_double spring_constant; |
| | | ts_double pressure; |
| | | ts_int pswitch; |
| | | } ts_vesicle; |
| | | |
| | | |
| | |
| | | |
| | | ts_vesicle *vesicle=init_vesicle(no_vertices,ncmax1,ncmax2,ncmax3,stepsize); |
| | | |
| | | //TODO: debugging only. Please remove ASAP! |
| | | vesicle->bending_rigidity=25.0; |
| | | |
| | | vesicle->nshell=nshell; |
| | | retval = vtx_set_global_values(vesicle); |
| | | retval = pentagonal_dipyramid_vertex_distribution(vesicle->vlist); |
| | |
| | | fprintf(fh," %.17E\t%.17E\t%.17E\t%.17E\t%.17E\t%u\n", |
| | | vlist->vtx[i]->xk,vlist->vtx[i]->c,vlist->vtx[i]->energy, |
| | | vlist->vtx[i]->energy_h, vlist->vtx[i]->curvature, 0); |
| | | for(j=0;j<vlist->vtx[i]->neigh_no;j++){ |
| | | for(j=0;j<vlist->vtx[i]->bond_no;j++){ |
| | | fprintf(fh," %.17E", vlist->vtx[i]->bond[j]->bond_length_dual); |
| | | } |
| | | fprintf(fh,"\n"); |
| | | for(j=0;j<vlist->vtx[i]->neigh_no;j++){ |
| | | for(j=0;j<vlist->vtx[i]->bond_no;j++){ |
| | | fprintf(fh," %.17E", vlist->vtx[i]->bond[j]->bond_length); |
| | | } |
| | | fprintf(fh,"\n"); |
| | |
| | | |
| | | |
| | | ts_vesicle *parsetape(ts_uint *mcsweeps, ts_uint *inititer, ts_uint *iterations){ |
| | | long int nshell=17,ncxmax=60, ncymax=60, nczmax=60, npoly=10, nmono=20; // THIS IS DUE TO CONFUSE BUG! |
| | | long int nshell=17,ncxmax=60, ncymax=60, nczmax=60, npoly=10, nmono=20, pswitch=0; // THIS IS DUE TO CONFUSE BUG! |
| | | char *buf=malloc(255*sizeof(char)); |
| | | long int brezveze0=1; |
| | | long int brezveze1=1; |
| | | long int brezveze2=1; |
| | | ts_double xk0=25.0, dmax=1.67,stepsize=0.15,kspring=800.0; |
| | | ts_double xk0=25.0, dmax=1.67,stepsize=0.15,kspring=800.0,pressure=0.0; |
| | | long int iter=1000, init=1000, mcsw=1000; |
| | | |
| | | |
| | |
| | | CFG_SIMPLE_INT("nmono", &nmono), |
| | | CFG_SIMPLE_FLOAT("dmax", &dmax), |
| | | CFG_SIMPLE_FLOAT("xk0",&xk0), |
| | | CFG_SIMPLE_FLOAT("k_spring",&kspring), |
| | | CFG_SIMPLE_INT("pswitch",&pswitch), |
| | | CFG_SIMPLE_FLOAT("pressure",&pressure), |
| | | CFG_SIMPLE_FLOAT("k_spring",&kspring), |
| | | CFG_SIMPLE_FLOAT("stepsize",&stepsize), |
| | | CFG_SIMPLE_INT("nxmax", &ncxmax), |
| | | CFG_SIMPLE_INT("nymax", &ncymax), |
| | |
| | | vesicle->nshell=nshell; |
| | | vesicle->dmax=dmax*dmax; |
| | | vesicle->bending_rigidity=xk0; |
| | | vtx_set_global_values(vesicle); //copies xk0 to every vertex |
| | | |
| | | |
| | | vesicle->stepsize=stepsize; |
| | | vesicle->clist->ncmax[0]=ncxmax; |
| | | vesicle->clist->ncmax[1]=ncymax; |
| | | vesicle->clist->ncmax[2]=nczmax; |
| | | vesicle->clist->max_occupancy=8; |
| | | |
| | | vesicle->pressure=pressure/vesicle->bending_rigidity; //all energy contributions need to be divided by bending_rigidity! |
| | | vesicle->pswitch=pswitch; |
| | | cfg_free(cfg); |
| | | free(buf); |
| | | // fprintf(stderr,"NSHELL=%u\n",vesicle->nshell); |
| | |
| | | ####### Vesicle definitions ########### |
| | | # nshell is a number of divisions of dipyramid |
| | | nshell=17 |
| | | # dmax is the max. bond length |
| | | # dmax is the max. bond length (in units l_min) |
| | | dmax=1.7 |
| | | # bending rigidity of the membrane |
| | | xk0=25.0 |
| | | # max step size |
| | | # bending rigidity of the membrane (in units kT) |
| | | xk0=1.0 |
| | | # max step size (in units l_min) |
| | | stepsize=0.15 |
| | | |
| | | # Pressure calculations |
| | | # (pswitch=1: calc. p*dV energy contribution) |
| | | pswitch = 0 |
| | | # pressure difference: p_inside - p_outside (in units l_min^3/kT): |
| | | pressure=0.0 |
| | | |
| | | ####### Polymer definitions ########### |
| | | # npoly is a number of polymers attached to npoly distinct vertices on vesicle |
| | | npoly=2 |
| | | npoly=0 |
| | | # nmono is a number of monomers in each polymer |
| | | nmono=10 |
| | | # Spring constant between monomers of the polymer |
| | |
| | | |
| | | ####### Program Control ############ |
| | | #how many MC sweeps between subsequent records of states to disk |
| | | mcsweeps=5000 |
| | | mcsweeps=500 |
| | | #how many initial mcsweeps*inititer MC sweeps before recording to disk? |
| | | inititer=1 |
| | | #how many records do you want on the disk iteration are there in a run? |
| | | iterations=10000 |
| | | iterations=10 |
| | | |
| | | |
| | | #shut up if we are using cluster!!! |
| | |
| | | // fprintf(stderr,"*** tria_number=%d\n",tria->neigh_no); |
| | | tria->neigh=(ts_triangle **)realloc(tria->neigh,tria->neigh_no*sizeof(ts_triangle *)); |
| | | if(tria->neigh == NULL){ |
| | | fprintf(stderr,"Ooops: tria->neigh_no=%d\n",tria->neigh_no); |
| | | fatal("Reallocation of memory failed during removal of vertex neighbour in triangle_remove_neighbour",100); |
| | | } |
| | | /* we repeat the procedure for neighbour */ |
| | |
| | | // fprintf(stderr,"*** ntria_number=%d\n",ntria->neigh_no); |
| | | ntria->neigh=(ts_triangle **)realloc(ntria->neigh,ntria->neigh_no*sizeof(ts_triangle *)); |
| | | if(ntria->neigh == NULL){ |
| | | fprintf(stderr,"Ooops: ntria->neigh_no=%d\n",ntria->neigh_no); |
| | | fatal("Reallocation of memory failed during removal of vertex neighbour in triangle_remove_neighbour",100); |
| | | } |
| | | return TS_SUCCESS; |
| | |
| | | ts_double dist; |
| | | ts_bool retval; |
| | | ts_uint cellidx; |
| | | ts_double delta_energy,oenergy; |
| | | ts_double delta_energy,oenergy,dvol=0.0; |
| | | ts_double costheta,sintheta,phi,r; |
| | | //This will hold all the information of vtx and its neighbours |
| | | ts_vertex backupvtx[20]; |
| | |
| | | memcpy((void *)&backupvtx[i+1],(void *)vtx->neigh[i],sizeof(ts_vertex)); |
| | | } |
| | | |
| | | |
| | | if(vesicle->pswitch == 1){ |
| | | for(i=0;i<vtx->tristar_no;i++) dvol-=vtx->tristar[i]->volume; |
| | | }; |
| | | |
| | | delta_energy=0; |
| | | //update the normals of triangles that share bead i. |
| | |
| | | energy_vertex(vtx->neigh[i]); |
| | | delta_energy+=vtx->neigh[i]->xk*(vtx->neigh[i]->energy-oenergy); |
| | | } |
| | | |
| | | if(vesicle->pswitch == 1){ |
| | | for(i=0;i<vtx->tristar_no;i++) dvol+=vtx->tristar[i]->volume; |
| | | delta_energy-=vesicle->pressure*dvol; |
| | | }; |
| | | |
| | | /* No poly-bond energy for now! |
| | | if(vtx->grafted_poly!=NULL){ |
| | | delta_energy+= |