Merge recent trunk changes into the NGQP branch.
FossilOrigin-Name: aebe1f2603ee04d792af73aaf59625bda99d5cd1
This commit is contained in:
commit
e1e9766dee
@ -393,6 +393,7 @@ TESTSRC += \
|
|||||||
$(TOP)/ext/misc/fuzzer.c \
|
$(TOP)/ext/misc/fuzzer.c \
|
||||||
$(TOP)/ext/misc/ieee754.c \
|
$(TOP)/ext/misc/ieee754.c \
|
||||||
$(TOP)/ext/misc/nextchar.c \
|
$(TOP)/ext/misc/nextchar.c \
|
||||||
|
$(TOP)/ext/misc/percentile.c \
|
||||||
$(TOP)/ext/misc/regexp.c \
|
$(TOP)/ext/misc/regexp.c \
|
||||||
$(TOP)/ext/misc/spellfix.c \
|
$(TOP)/ext/misc/spellfix.c \
|
||||||
$(TOP)/ext/misc/wholenumber.c
|
$(TOP)/ext/misc/wholenumber.c
|
||||||
|
@ -713,6 +713,7 @@ TESTEXT = \
|
|||||||
$(TOP)\ext\misc\fuzzer.c \
|
$(TOP)\ext\misc\fuzzer.c \
|
||||||
$(TOP)\ext\misc\ieee754.c \
|
$(TOP)\ext\misc\ieee754.c \
|
||||||
$(TOP)\ext\misc\nextchar.c \
|
$(TOP)\ext\misc\nextchar.c \
|
||||||
|
$(TOP)\ext\misc\percentile.c \
|
||||||
$(TOP)\ext\misc\regexp.c \
|
$(TOP)\ext\misc\regexp.c \
|
||||||
$(TOP)\ext\misc\spellfix.c \
|
$(TOP)\ext\misc\spellfix.c \
|
||||||
$(TOP)\ext\misc\wholenumber.c
|
$(TOP)\ext\misc\wholenumber.c
|
||||||
|
370
autoconf/INSTALL
Normal file
370
autoconf/INSTALL
Normal file
@ -0,0 +1,370 @@
|
|||||||
|
Installation Instructions
|
||||||
|
*************************
|
||||||
|
|
||||||
|
Copyright (C) 1994-1996, 1999-2002, 2004-2011 Free Software Foundation,
|
||||||
|
Inc.
|
||||||
|
|
||||||
|
Copying and distribution of this file, with or without modification,
|
||||||
|
are permitted in any medium without royalty provided the copyright
|
||||||
|
notice and this notice are preserved. This file is offered as-is,
|
||||||
|
without warranty of any kind.
|
||||||
|
|
||||||
|
Basic Installation
|
||||||
|
==================
|
||||||
|
|
||||||
|
Briefly, the shell commands `./configure; make; make install' should
|
||||||
|
configure, build, and install this package. The following
|
||||||
|
more-detailed instructions are generic; see the `README' file for
|
||||||
|
instructions specific to this package. Some packages provide this
|
||||||
|
`INSTALL' file but do not implement all of the features documented
|
||||||
|
below. The lack of an optional feature in a given package is not
|
||||||
|
necessarily a bug. More recommendations for GNU packages can be found
|
||||||
|
in *note Makefile Conventions: (standards)Makefile Conventions.
|
||||||
|
|
||||||
|
The `configure' shell script attempts to guess correct values for
|
||||||
|
various system-dependent variables used during compilation. It uses
|
||||||
|
those values to create a `Makefile' in each directory of the package.
|
||||||
|
It may also create one or more `.h' files containing system-dependent
|
||||||
|
definitions. Finally, it creates a shell script `config.status' that
|
||||||
|
you can run in the future to recreate the current configuration, and a
|
||||||
|
file `config.log' containing compiler output (useful mainly for
|
||||||
|
debugging `configure').
|
||||||
|
|
||||||
|
It can also use an optional file (typically called `config.cache'
|
||||||
|
and enabled with `--cache-file=config.cache' or simply `-C') that saves
|
||||||
|
the results of its tests to speed up reconfiguring. Caching is
|
||||||
|
disabled by default to prevent problems with accidental use of stale
|
||||||
|
cache files.
|
||||||
|
|
||||||
|
If you need to do unusual things to compile the package, please try
|
||||||
|
to figure out how `configure' could check whether to do them, and mail
|
||||||
|
diffs or instructions to the address given in the `README' so they can
|
||||||
|
be considered for the next release. If you are using the cache, and at
|
||||||
|
some point `config.cache' contains results you don't want to keep, you
|
||||||
|
may remove or edit it.
|
||||||
|
|
||||||
|
The file `configure.ac' (or `configure.in') is used to create
|
||||||
|
`configure' by a program called `autoconf'. You need `configure.ac' if
|
||||||
|
you want to change it or regenerate `configure' using a newer version
|
||||||
|
of `autoconf'.
|
||||||
|
|
||||||
|
The simplest way to compile this package is:
|
||||||
|
|
||||||
|
1. `cd' to the directory containing the package's source code and type
|
||||||
|
`./configure' to configure the package for your system.
|
||||||
|
|
||||||
|
Running `configure' might take a while. While running, it prints
|
||||||
|
some messages telling which features it is checking for.
|
||||||
|
|
||||||
|
2. Type `make' to compile the package.
|
||||||
|
|
||||||
|
3. Optionally, type `make check' to run any self-tests that come with
|
||||||
|
the package, generally using the just-built uninstalled binaries.
|
||||||
|
|
||||||
|
4. Type `make install' to install the programs and any data files and
|
||||||
|
documentation. When installing into a prefix owned by root, it is
|
||||||
|
recommended that the package be configured and built as a regular
|
||||||
|
user, and only the `make install' phase executed with root
|
||||||
|
privileges.
|
||||||
|
|
||||||
|
5. Optionally, type `make installcheck' to repeat any self-tests, but
|
||||||
|
this time using the binaries in their final installed location.
|
||||||
|
This target does not install anything. Running this target as a
|
||||||
|
regular user, particularly if the prior `make install' required
|
||||||
|
root privileges, verifies that the installation completed
|
||||||
|
correctly.
|
||||||
|
|
||||||
|
6. You can remove the program binaries and object files from the
|
||||||
|
source code directory by typing `make clean'. To also remove the
|
||||||
|
files that `configure' created (so you can compile the package for
|
||||||
|
a different kind of computer), type `make distclean'. There is
|
||||||
|
also a `make maintainer-clean' target, but that is intended mainly
|
||||||
|
for the package's developers. If you use it, you may have to get
|
||||||
|
all sorts of other programs in order to regenerate files that came
|
||||||
|
with the distribution.
|
||||||
|
|
||||||
|
7. Often, you can also type `make uninstall' to remove the installed
|
||||||
|
files again. In practice, not all packages have tested that
|
||||||
|
uninstallation works correctly, even though it is required by the
|
||||||
|
GNU Coding Standards.
|
||||||
|
|
||||||
|
8. Some packages, particularly those that use Automake, provide `make
|
||||||
|
distcheck', which can by used by developers to test that all other
|
||||||
|
targets like `make install' and `make uninstall' work correctly.
|
||||||
|
This target is generally not run by end users.
|
||||||
|
|
||||||
|
Compilers and Options
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Some systems require unusual options for compilation or linking that
|
||||||
|
the `configure' script does not know about. Run `./configure --help'
|
||||||
|
for details on some of the pertinent environment variables.
|
||||||
|
|
||||||
|
You can give `configure' initial values for configuration parameters
|
||||||
|
by setting variables in the command line or in the environment. Here
|
||||||
|
is an example:
|
||||||
|
|
||||||
|
./configure CC=c99 CFLAGS=-g LIBS=-lposix
|
||||||
|
|
||||||
|
*Note Defining Variables::, for more details.
|
||||||
|
|
||||||
|
Compiling For Multiple Architectures
|
||||||
|
====================================
|
||||||
|
|
||||||
|
You can compile the package for more than one kind of computer at the
|
||||||
|
same time, by placing the object files for each architecture in their
|
||||||
|
own directory. To do this, you can use GNU `make'. `cd' to the
|
||||||
|
directory where you want the object files and executables to go and run
|
||||||
|
the `configure' script. `configure' automatically checks for the
|
||||||
|
source code in the directory that `configure' is in and in `..'. This
|
||||||
|
is known as a "VPATH" build.
|
||||||
|
|
||||||
|
With a non-GNU `make', it is safer to compile the package for one
|
||||||
|
architecture at a time in the source code directory. After you have
|
||||||
|
installed the package for one architecture, use `make distclean' before
|
||||||
|
reconfiguring for another architecture.
|
||||||
|
|
||||||
|
On MacOS X 10.5 and later systems, you can create libraries and
|
||||||
|
executables that work on multiple system types--known as "fat" or
|
||||||
|
"universal" binaries--by specifying multiple `-arch' options to the
|
||||||
|
compiler but only a single `-arch' option to the preprocessor. Like
|
||||||
|
this:
|
||||||
|
|
||||||
|
./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
|
||||||
|
CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
|
||||||
|
CPP="gcc -E" CXXCPP="g++ -E"
|
||||||
|
|
||||||
|
This is not guaranteed to produce working output in all cases, you
|
||||||
|
may have to build one architecture at a time and combine the results
|
||||||
|
using the `lipo' tool if you have problems.
|
||||||
|
|
||||||
|
Installation Names
|
||||||
|
==================
|
||||||
|
|
||||||
|
By default, `make install' installs the package's commands under
|
||||||
|
`/usr/local/bin', include files under `/usr/local/include', etc. You
|
||||||
|
can specify an installation prefix other than `/usr/local' by giving
|
||||||
|
`configure' the option `--prefix=PREFIX', where PREFIX must be an
|
||||||
|
absolute file name.
|
||||||
|
|
||||||
|
You can specify separate installation prefixes for
|
||||||
|
architecture-specific files and architecture-independent files. If you
|
||||||
|
pass the option `--exec-prefix=PREFIX' to `configure', the package uses
|
||||||
|
PREFIX as the prefix for installing programs and libraries.
|
||||||
|
Documentation and other data files still use the regular prefix.
|
||||||
|
|
||||||
|
In addition, if you use an unusual directory layout you can give
|
||||||
|
options like `--bindir=DIR' to specify different values for particular
|
||||||
|
kinds of files. Run `configure --help' for a list of the directories
|
||||||
|
you can set and what kinds of files go in them. In general, the
|
||||||
|
default for these options is expressed in terms of `${prefix}', so that
|
||||||
|
specifying just `--prefix' will affect all of the other directory
|
||||||
|
specifications that were not explicitly provided.
|
||||||
|
|
||||||
|
The most portable way to affect installation locations is to pass the
|
||||||
|
correct locations to `configure'; however, many packages provide one or
|
||||||
|
both of the following shortcuts of passing variable assignments to the
|
||||||
|
`make install' command line to change installation locations without
|
||||||
|
having to reconfigure or recompile.
|
||||||
|
|
||||||
|
The first method involves providing an override variable for each
|
||||||
|
affected directory. For example, `make install
|
||||||
|
prefix=/alternate/directory' will choose an alternate location for all
|
||||||
|
directory configuration variables that were expressed in terms of
|
||||||
|
`${prefix}'. Any directories that were specified during `configure',
|
||||||
|
but not in terms of `${prefix}', must each be overridden at install
|
||||||
|
time for the entire installation to be relocated. The approach of
|
||||||
|
makefile variable overrides for each directory variable is required by
|
||||||
|
the GNU Coding Standards, and ideally causes no recompilation.
|
||||||
|
However, some platforms have known limitations with the semantics of
|
||||||
|
shared libraries that end up requiring recompilation when using this
|
||||||
|
method, particularly noticeable in packages that use GNU Libtool.
|
||||||
|
|
||||||
|
The second method involves providing the `DESTDIR' variable. For
|
||||||
|
example, `make install DESTDIR=/alternate/directory' will prepend
|
||||||
|
`/alternate/directory' before all installation names. The approach of
|
||||||
|
`DESTDIR' overrides is not required by the GNU Coding Standards, and
|
||||||
|
does not work on platforms that have drive letters. On the other hand,
|
||||||
|
it does better at avoiding recompilation issues, and works well even
|
||||||
|
when some directory options were not specified in terms of `${prefix}'
|
||||||
|
at `configure' time.
|
||||||
|
|
||||||
|
Optional Features
|
||||||
|
=================
|
||||||
|
|
||||||
|
If the package supports it, you can cause programs to be installed
|
||||||
|
with an extra prefix or suffix on their names by giving `configure' the
|
||||||
|
option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
|
||||||
|
|
||||||
|
Some packages pay attention to `--enable-FEATURE' options to
|
||||||
|
`configure', where FEATURE indicates an optional part of the package.
|
||||||
|
They may also pay attention to `--with-PACKAGE' options, where PACKAGE
|
||||||
|
is something like `gnu-as' or `x' (for the X Window System). The
|
||||||
|
`README' should mention any `--enable-' and `--with-' options that the
|
||||||
|
package recognizes.
|
||||||
|
|
||||||
|
For packages that use the X Window System, `configure' can usually
|
||||||
|
find the X include and library files automatically, but if it doesn't,
|
||||||
|
you can use the `configure' options `--x-includes=DIR' and
|
||||||
|
`--x-libraries=DIR' to specify their locations.
|
||||||
|
|
||||||
|
Some packages offer the ability to configure how verbose the
|
||||||
|
execution of `make' will be. For these packages, running `./configure
|
||||||
|
--enable-silent-rules' sets the default to minimal output, which can be
|
||||||
|
overridden with `make V=1'; while running `./configure
|
||||||
|
--disable-silent-rules' sets the default to verbose, which can be
|
||||||
|
overridden with `make V=0'.
|
||||||
|
|
||||||
|
Particular systems
|
||||||
|
==================
|
||||||
|
|
||||||
|
On HP-UX, the default C compiler is not ANSI C compatible. If GNU
|
||||||
|
CC is not installed, it is recommended to use the following options in
|
||||||
|
order to use an ANSI C compiler:
|
||||||
|
|
||||||
|
./configure CC="cc -Ae -D_XOPEN_SOURCE=500"
|
||||||
|
|
||||||
|
and if that doesn't work, install pre-built binaries of GCC for HP-UX.
|
||||||
|
|
||||||
|
HP-UX `make' updates targets which have the same time stamps as
|
||||||
|
their prerequisites, which makes it generally unusable when shipped
|
||||||
|
generated files such as `configure' are involved. Use GNU `make'
|
||||||
|
instead.
|
||||||
|
|
||||||
|
On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot
|
||||||
|
parse its `<wchar.h>' header file. The option `-nodtk' can be used as
|
||||||
|
a workaround. If GNU CC is not installed, it is therefore recommended
|
||||||
|
to try
|
||||||
|
|
||||||
|
./configure CC="cc"
|
||||||
|
|
||||||
|
and if that doesn't work, try
|
||||||
|
|
||||||
|
./configure CC="cc -nodtk"
|
||||||
|
|
||||||
|
On Solaris, don't put `/usr/ucb' early in your `PATH'. This
|
||||||
|
directory contains several dysfunctional programs; working variants of
|
||||||
|
these programs are available in `/usr/bin'. So, if you need `/usr/ucb'
|
||||||
|
in your `PATH', put it _after_ `/usr/bin'.
|
||||||
|
|
||||||
|
On Haiku, software installed for all users goes in `/boot/common',
|
||||||
|
not `/usr/local'. It is recommended to use the following options:
|
||||||
|
|
||||||
|
./configure --prefix=/boot/common
|
||||||
|
|
||||||
|
Specifying the System Type
|
||||||
|
==========================
|
||||||
|
|
||||||
|
There may be some features `configure' cannot figure out
|
||||||
|
automatically, but needs to determine by the type of machine the package
|
||||||
|
will run on. Usually, assuming the package is built to be run on the
|
||||||
|
_same_ architectures, `configure' can figure that out, but if it prints
|
||||||
|
a message saying it cannot guess the machine type, give it the
|
||||||
|
`--build=TYPE' option. TYPE can either be a short name for the system
|
||||||
|
type, such as `sun4', or a canonical name which has the form:
|
||||||
|
|
||||||
|
CPU-COMPANY-SYSTEM
|
||||||
|
|
||||||
|
where SYSTEM can have one of these forms:
|
||||||
|
|
||||||
|
OS
|
||||||
|
KERNEL-OS
|
||||||
|
|
||||||
|
See the file `config.sub' for the possible values of each field. If
|
||||||
|
`config.sub' isn't included in this package, then this package doesn't
|
||||||
|
need to know the machine type.
|
||||||
|
|
||||||
|
If you are _building_ compiler tools for cross-compiling, you should
|
||||||
|
use the option `--target=TYPE' to select the type of system they will
|
||||||
|
produce code for.
|
||||||
|
|
||||||
|
If you want to _use_ a cross compiler, that generates code for a
|
||||||
|
platform different from the build platform, you should specify the
|
||||||
|
"host" platform (i.e., that on which the generated programs will
|
||||||
|
eventually be run) with `--host=TYPE'.
|
||||||
|
|
||||||
|
Sharing Defaults
|
||||||
|
================
|
||||||
|
|
||||||
|
If you want to set default values for `configure' scripts to share,
|
||||||
|
you can create a site shell script called `config.site' that gives
|
||||||
|
default values for variables like `CC', `cache_file', and `prefix'.
|
||||||
|
`configure' looks for `PREFIX/share/config.site' if it exists, then
|
||||||
|
`PREFIX/etc/config.site' if it exists. Or, you can set the
|
||||||
|
`CONFIG_SITE' environment variable to the location of the site script.
|
||||||
|
A warning: not all `configure' scripts look for a site script.
|
||||||
|
|
||||||
|
Defining Variables
|
||||||
|
==================
|
||||||
|
|
||||||
|
Variables not defined in a site shell script can be set in the
|
||||||
|
environment passed to `configure'. However, some packages may run
|
||||||
|
configure again during the build, and the customized values of these
|
||||||
|
variables may be lost. In order to avoid this problem, you should set
|
||||||
|
them in the `configure' command line, using `VAR=value'. For example:
|
||||||
|
|
||||||
|
./configure CC=/usr/local2/bin/gcc
|
||||||
|
|
||||||
|
causes the specified `gcc' to be used as the C compiler (unless it is
|
||||||
|
overridden in the site shell script).
|
||||||
|
|
||||||
|
Unfortunately, this technique does not work for `CONFIG_SHELL' due to
|
||||||
|
an Autoconf bug. Until the bug is fixed you can use this workaround:
|
||||||
|
|
||||||
|
CONFIG_SHELL=/bin/bash /bin/bash ./configure CONFIG_SHELL=/bin/bash
|
||||||
|
|
||||||
|
`configure' Invocation
|
||||||
|
======================
|
||||||
|
|
||||||
|
`configure' recognizes the following options to control how it
|
||||||
|
operates.
|
||||||
|
|
||||||
|
`--help'
|
||||||
|
`-h'
|
||||||
|
Print a summary of all of the options to `configure', and exit.
|
||||||
|
|
||||||
|
`--help=short'
|
||||||
|
`--help=recursive'
|
||||||
|
Print a summary of the options unique to this package's
|
||||||
|
`configure', and exit. The `short' variant lists options used
|
||||||
|
only in the top level, while the `recursive' variant lists options
|
||||||
|
also present in any nested packages.
|
||||||
|
|
||||||
|
`--version'
|
||||||
|
`-V'
|
||||||
|
Print the version of Autoconf used to generate the `configure'
|
||||||
|
script, and exit.
|
||||||
|
|
||||||
|
`--cache-file=FILE'
|
||||||
|
Enable the cache: use and save the results of the tests in FILE,
|
||||||
|
traditionally `config.cache'. FILE defaults to `/dev/null' to
|
||||||
|
disable caching.
|
||||||
|
|
||||||
|
`--config-cache'
|
||||||
|
`-C'
|
||||||
|
Alias for `--cache-file=config.cache'.
|
||||||
|
|
||||||
|
`--quiet'
|
||||||
|
`--silent'
|
||||||
|
`-q'
|
||||||
|
Do not print messages saying which checks are being made. To
|
||||||
|
suppress all normal output, redirect it to `/dev/null' (any error
|
||||||
|
messages will still be shown).
|
||||||
|
|
||||||
|
`--srcdir=DIR'
|
||||||
|
Look for the package's source code in directory DIR. Usually
|
||||||
|
`configure' can determine that directory automatically.
|
||||||
|
|
||||||
|
`--prefix=DIR'
|
||||||
|
Use DIR as the installation prefix. *note Installation Names::
|
||||||
|
for more details, including other options available for fine-tuning
|
||||||
|
the installation locations.
|
||||||
|
|
||||||
|
`--no-create'
|
||||||
|
`-n'
|
||||||
|
Run the configure checks, but stop before creating any output
|
||||||
|
files.
|
||||||
|
|
||||||
|
`configure' also accepts some other, not widely useful, options. Run
|
||||||
|
`configure --help' for more details.
|
||||||
|
|
19
autoconf/Makefile.am
Normal file
19
autoconf/Makefile.am
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
|
||||||
|
AM_CFLAGS = @THREADSAFE_FLAGS@ @DYNAMIC_EXTENSION_FLAGS@ -DSQLITE_ENABLE_FTS3 -DSQLITE_ENABLE_RTREE
|
||||||
|
|
||||||
|
lib_LTLIBRARIES = libsqlite3.la
|
||||||
|
libsqlite3_la_SOURCES = sqlite3.c
|
||||||
|
libsqlite3_la_LDFLAGS = -no-undefined -version-info 8:6:8
|
||||||
|
|
||||||
|
bin_PROGRAMS = sqlite3
|
||||||
|
sqlite3_SOURCES = shell.c sqlite3.h
|
||||||
|
sqlite3_LDADD = $(top_builddir)/libsqlite3.la @READLINE_LIBS@
|
||||||
|
sqlite3_DEPENDENCIES = $(top_builddir)/libsqlite3.la
|
||||||
|
|
||||||
|
include_HEADERS = sqlite3.h sqlite3ext.h
|
||||||
|
|
||||||
|
EXTRA_DIST = sqlite3.1 tea
|
||||||
|
pkgconfigdir = ${libdir}/pkgconfig
|
||||||
|
pkgconfig_DATA = sqlite3.pc
|
||||||
|
|
||||||
|
man_MANS = sqlite3.1
|
32
autoconf/README
Normal file
32
autoconf/README
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
|
||||||
|
This package contains:
|
||||||
|
|
||||||
|
* the SQLite library amalgamation (single file) source code distribution,
|
||||||
|
* the shell.c file used to build the sqlite3 shell too, and
|
||||||
|
* the sqlite3.h and sqlite3ext.h header files required to link programs
|
||||||
|
and sqlite extensions against the installed libary.
|
||||||
|
* autoconf/automake installation infrastucture.
|
||||||
|
|
||||||
|
The generic installation instructions for autoconf/automake are found
|
||||||
|
in the INSTALL file.
|
||||||
|
|
||||||
|
The following SQLite specific boolean options are supported:
|
||||||
|
|
||||||
|
--enable-readline use readline in shell tool [default=yes]
|
||||||
|
--enable-threadsafe build a thread-safe library [default=yes]
|
||||||
|
--enable-dynamic-extensions support loadable extensions [default=yes]
|
||||||
|
|
||||||
|
The default value for the CFLAGS variable (options passed to the C
|
||||||
|
compiler) includes debugging symbols in the build, resulting in larger
|
||||||
|
binaries than are necessary. Override it on the configure command
|
||||||
|
line like this:
|
||||||
|
|
||||||
|
$ CFLAGS="-Os" ./configure
|
||||||
|
|
||||||
|
to produce a smaller installation footprint.
|
||||||
|
|
||||||
|
Other SQLite compilation parameters can also be set using CFLAGS. For
|
||||||
|
example:
|
||||||
|
|
||||||
|
$ CFLAGS="-Os -DSQLITE_OMIT_TRIGGERS" ./configure
|
||||||
|
|
57
autoconf/README.first
Normal file
57
autoconf/README.first
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
|
||||||
|
This file describes how to use the files in this directory to create a new
|
||||||
|
version of the "autoconf-amalgamation" package.
|
||||||
|
|
||||||
|
1. The following files should have executable permission:
|
||||||
|
|
||||||
|
chmod 755 install-sh
|
||||||
|
chmod 755 missing
|
||||||
|
chmod 755 depcomp
|
||||||
|
chmod 755 config.sub
|
||||||
|
chmod 755 config.guess
|
||||||
|
|
||||||
|
2. Copy new versions of the following SQLite files into this directory:
|
||||||
|
|
||||||
|
sqlite3.c
|
||||||
|
sqlite3.h
|
||||||
|
sqlite3ext.h
|
||||||
|
sqlite3.1
|
||||||
|
sqlite3.pc.in
|
||||||
|
shell.c
|
||||||
|
|
||||||
|
3. Update the SQLite version number in the AC_INIT macro in file
|
||||||
|
configure.ac:
|
||||||
|
|
||||||
|
AC_INIT(sqlite, 3.6.3, http://www.sqlite.org)
|
||||||
|
|
||||||
|
4. Run the following commands to push the version number change through
|
||||||
|
to the generated files.
|
||||||
|
|
||||||
|
aclocal
|
||||||
|
autoconf
|
||||||
|
automake
|
||||||
|
|
||||||
|
5. Create the tclsqlite3.c file in the tea/generic directory. As follows:
|
||||||
|
|
||||||
|
mkdir -p tea/generic
|
||||||
|
echo "#ifdef USE_SYSTEM_SQLITE" > tea/generic/tclsqlite3.c
|
||||||
|
echo "# include <sqlite3.h>" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#else" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#include \"../../sqlite3.c\"" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#endif" >> tea/generic/tclsqlite3.c
|
||||||
|
cat ../src/tclsqlite.c >> tea/generic/tclsqlite3.c
|
||||||
|
|
||||||
|
6. Update the SQLite version in the AC_INIT macro in file tea/configure.in:
|
||||||
|
|
||||||
|
AC_INIT([sqlite], [3.6.3])
|
||||||
|
|
||||||
|
7. From the 'tea' directory, run the following commands:
|
||||||
|
|
||||||
|
autoconf
|
||||||
|
rm -rf autom4te.cache
|
||||||
|
|
||||||
|
8. Run "./configure && make dist". This builds a distribution package
|
||||||
|
named something like "sqlite-3.6.3.tar.gz". Rename to
|
||||||
|
"sqlite-amalgamation-3.6.3.tar.gz" and use.
|
||||||
|
|
||||||
|
|
1530
autoconf/config.guess
vendored
Executable file
1530
autoconf/config.guess
vendored
Executable file
File diff suppressed because it is too large
Load Diff
1773
autoconf/config.sub
vendored
Executable file
1773
autoconf/config.sub
vendored
Executable file
File diff suppressed because it is too large
Load Diff
108
autoconf/configure.ac
Normal file
108
autoconf/configure.ac
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# Supports the following non-standard switches.
|
||||||
|
#
|
||||||
|
# --enable-threadsafe
|
||||||
|
# --enable-readline
|
||||||
|
# --enable-dynamic-extensions
|
||||||
|
#
|
||||||
|
|
||||||
|
AC_PREREQ(2.61)
|
||||||
|
AC_INIT(sqlite, 3.7.5, http://www.sqlite.org)
|
||||||
|
AC_CONFIG_SRCDIR([sqlite3.c])
|
||||||
|
|
||||||
|
# Use automake.
|
||||||
|
AM_INIT_AUTOMAKE([foreign])
|
||||||
|
|
||||||
|
AC_SYS_LARGEFILE
|
||||||
|
|
||||||
|
# Check for required programs.
|
||||||
|
AC_PROG_CC
|
||||||
|
AC_PROG_RANLIB
|
||||||
|
AC_PROG_LIBTOOL
|
||||||
|
AC_PROG_MKDIR_P
|
||||||
|
|
||||||
|
# Check for library functions that SQLite can optionally use.
|
||||||
|
AC_CHECK_FUNCS([fdatasync usleep fullfsync localtime_r gmtime_r])
|
||||||
|
AC_FUNC_STRERROR_R
|
||||||
|
|
||||||
|
AC_CONFIG_FILES([Makefile sqlite3.pc])
|
||||||
|
AC_SUBST(BUILD_CFLAGS)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# --enable-readline
|
||||||
|
#
|
||||||
|
AC_ARG_ENABLE(readline, [AS_HELP_STRING(
|
||||||
|
[--enable-readline],
|
||||||
|
[use readline in shell tool (yes, no) [default=yes]])],
|
||||||
|
[], [enable_readline=yes])
|
||||||
|
if test x"$enable_readline" != xno ; then
|
||||||
|
sLIBS=$LIBS
|
||||||
|
LIBS=""
|
||||||
|
AC_SEARCH_LIBS(tgetent, curses ncurses ncursesw, [], [])
|
||||||
|
AC_SEARCH_LIBS(readline, readline, [], [enable_readline=no])
|
||||||
|
AC_CHECK_FUNCS(readline, [], [])
|
||||||
|
READLINE_LIBS=$LIBS
|
||||||
|
LIBS=$sLIBS
|
||||||
|
fi
|
||||||
|
AC_SUBST(READLINE_LIBS)
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# --enable-threadsafe
|
||||||
|
#
|
||||||
|
AC_ARG_ENABLE(threadsafe, [AS_HELP_STRING(
|
||||||
|
[--enable-threadsafe], [build a thread-safe library [default=yes]])],
|
||||||
|
[], [enable_threadsafe=yes])
|
||||||
|
THREADSAFE_FLAGS=-DSQLITE_THREADSAFE=0
|
||||||
|
if test x"$enable_threadsafe" != "xno"; then
|
||||||
|
THREADSAFE_FLAGS="-D_REENTRANT=1 -DSQLITE_THREADSAFE=1"
|
||||||
|
AC_SEARCH_LIBS(pthread_create, pthread)
|
||||||
|
fi
|
||||||
|
AC_SUBST(THREADSAFE_FLAGS)
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# --enable-dynamic-extensions
|
||||||
|
#
|
||||||
|
AC_ARG_ENABLE(dynamic-extensions, [AS_HELP_STRING(
|
||||||
|
[--enable-dynamic-extensions], [support loadable extensions [default=yes]])],
|
||||||
|
[], [enable_dynamic_extensions=yes])
|
||||||
|
if test x"$enable_dynamic_extensions" != "xno"; then
|
||||||
|
AC_SEARCH_LIBS(dlopen, dl)
|
||||||
|
else
|
||||||
|
DYNAMIC_EXTENSION_FLAGS=-DSQLITE_OMIT_LOAD_EXTENSION=1
|
||||||
|
fi
|
||||||
|
AC_MSG_CHECKING([for whether to support dynamic extensions])
|
||||||
|
AC_MSG_RESULT($enable_dynamic_extensions)
|
||||||
|
AC_SUBST(DYNAMIC_EXTENSION_FLAGS)
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_CHECK_FUNCS(posix_fallocate)
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# UPDATE: Maybe it's better if users just set CFLAGS before invoking
|
||||||
|
# configure. This option doesn't really add much...
|
||||||
|
#
|
||||||
|
# --enable-tempstore
|
||||||
|
#
|
||||||
|
# AC_ARG_ENABLE(tempstore, [AS_HELP_STRING(
|
||||||
|
# [--enable-tempstore],
|
||||||
|
# [in-memory temporary tables (never, no, yes, always) [default=no]])],
|
||||||
|
# [], [enable_tempstore=no])
|
||||||
|
# AC_MSG_CHECKING([for whether or not to store temp tables in-memory])
|
||||||
|
# case "$enable_tempstore" in
|
||||||
|
# never ) TEMP_STORE=0 ;;
|
||||||
|
# no ) TEMP_STORE=1 ;;
|
||||||
|
# always ) TEMP_STORE=3 ;;
|
||||||
|
# yes ) TEMP_STORE=3 ;;
|
||||||
|
# * )
|
||||||
|
# TEMP_STORE=1
|
||||||
|
# enable_tempstore=yes
|
||||||
|
# ;;
|
||||||
|
# esac
|
||||||
|
# AC_MSG_RESULT($enable_tempstore)
|
||||||
|
# AC_SUBST(TEMP_STORE)
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_OUTPUT
|
708
autoconf/depcomp
Executable file
708
autoconf/depcomp
Executable file
@ -0,0 +1,708 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
# depcomp - compile a program generating dependencies as side-effects
|
||||||
|
|
||||||
|
scriptversion=2012-03-27.16; # UTC
|
||||||
|
|
||||||
|
# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009, 2010,
|
||||||
|
# 2011, 2012 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
|
||||||
|
|
||||||
|
# A tabulation character.
|
||||||
|
tab=' '
|
||||||
|
# A newline character.
|
||||||
|
nl='
|
||||||
|
'
|
||||||
|
|
||||||
|
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"
|
||||||
|
|
||||||
|
# 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 informations.
|
||||||
|
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 -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
mv "$tmpdepfile" "$depfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
gcc)
|
||||||
|
## 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).
|
||||||
|
## - 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 -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
|
||||||
|
## 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.
|
||||||
|
tr ' ' "$nl" < "$tmpdepfile" |
|
||||||
|
## 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.
|
||||||
|
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 -eq 0; then :
|
||||||
|
else
|
||||||
|
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
|
||||||
|
# The sourcefile does not contain any dependencies, so just
|
||||||
|
# store a dummy comment line, to avoid errors with the Makefile
|
||||||
|
# "include basename.Plo" scheme.
|
||||||
|
echo "#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.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
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 -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
|
||||||
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
|
do
|
||||||
|
test -f "$tmpdepfile" && break
|
||||||
|
done
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
# Each line is of the form 'foo.o: dependent.h'.
|
||||||
|
# Do two passes, one to just change these to
|
||||||
|
# '$object: dependent.h' and one to simply 'dependent.h:'.
|
||||||
|
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
||||||
|
sed -e 's,^.*\.[a-z]*:['"$tab"' ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
# The sourcefile does not contain any dependencies, so just
|
||||||
|
# store a dummy comment line, to avoid errors with the Makefile
|
||||||
|
# "include basename.Plo" scheme.
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
icc)
|
||||||
|
# Intel's C compiler anf tcc (Tiny C Compiler) understand '-MD -MF file'.
|
||||||
|
# However on
|
||||||
|
# $CC -MD -MF foo.d -c -o sub/foo.o sub/foo.c
|
||||||
|
# ICC 7.0 will fill foo.d with something like
|
||||||
|
# foo.o: sub/foo.c
|
||||||
|
# foo.o: sub/foo.h
|
||||||
|
# which is wrong. We want
|
||||||
|
# sub/foo.o: sub/foo.c
|
||||||
|
# sub/foo.o: sub/foo.h
|
||||||
|
# sub/foo.c:
|
||||||
|
# sub/foo.h:
|
||||||
|
# ICC 7.1 will output
|
||||||
|
# foo.o: sub/foo.c sub/foo.h
|
||||||
|
# and will wrap long lines using '\':
|
||||||
|
# foo.o: sub/foo.c ... \
|
||||||
|
# sub/foo.h ... \
|
||||||
|
# ...
|
||||||
|
# tcc 0.9.26 (FIXME still under development at the moment of writing)
|
||||||
|
# will emit a similar output, but also prepend the continuation lines
|
||||||
|
# with horizontal tabulation characters.
|
||||||
|
"$@" -MD -MF "$tmpdepfile"
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
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 -e "s/^[ $tab][ $tab]*/ /" -e "s,^[^:]*:,$object :," \
|
||||||
|
< "$tmpdepfile" > "$depfile"
|
||||||
|
sed '
|
||||||
|
s/[ '"$tab"'][ '"$tab"']*/ /g
|
||||||
|
s/^ *//
|
||||||
|
s/ *\\*$//
|
||||||
|
s/^[^:]*: *//
|
||||||
|
/^$/d
|
||||||
|
/:$/d
|
||||||
|
s/$/ :/
|
||||||
|
' < "$tmpdepfile" >> "$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.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
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 -eq 0; then :
|
||||||
|
else
|
||||||
|
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,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile"
|
||||||
|
# Add 'dependent.h:' lines.
|
||||||
|
sed -ne '2,${
|
||||||
|
s/^ *//
|
||||||
|
s/ \\*$//
|
||||||
|
s/$/:/
|
||||||
|
p
|
||||||
|
}' "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
echo "#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.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
# With Tru64 cc, shared objects can also be used to make a
|
||||||
|
# static library. This mechanism is used in libtool 1.4 series to
|
||||||
|
# handle both shared and static libraries in a single compilation.
|
||||||
|
# With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d.
|
||||||
|
#
|
||||||
|
# With libtool 1.5 this exception was removed, and libtool now
|
||||||
|
# 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.libs/$base.lo.d # libtool 1.4
|
||||||
|
tmpdepfile2=$dir$base.o.d # libtool 1.5
|
||||||
|
tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5
|
||||||
|
tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504
|
||||||
|
"$@" -Wc,-MD
|
||||||
|
else
|
||||||
|
tmpdepfile1=$dir$base.o.d
|
||||||
|
tmpdepfile2=$dir$base.d
|
||||||
|
tmpdepfile3=$dir$base.d
|
||||||
|
tmpdepfile4=$dir$base.d
|
||||||
|
"$@" -MD
|
||||||
|
fi
|
||||||
|
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
|
||||||
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
||||||
|
do
|
||||||
|
test -f "$tmpdepfile" && break
|
||||||
|
done
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
||||||
|
sed -e 's,^.*\.[a-z]*:['"$tab"' ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
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" = 0; then :
|
||||||
|
else
|
||||||
|
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"
|
||||||
|
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"
|
||||||
|
tr ' ' "$nl" < "$tmpdepfile" | \
|
||||||
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
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"
|
||||||
|
sed '1,2d' "$tmpdepfile" | tr ' ' "$nl" | \
|
||||||
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
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:
|
527
autoconf/install-sh
Executable file
527
autoconf/install-sh
Executable file
@ -0,0 +1,527 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# install - install a program, script, or datafile
|
||||||
|
|
||||||
|
scriptversion=2011-01-19.21; # 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-writeable 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:
|
9655
autoconf/ltmain.sh
Normal file
9655
autoconf/ltmain.sh
Normal file
File diff suppressed because it is too large
Load Diff
331
autoconf/missing
Executable file
331
autoconf/missing
Executable file
@ -0,0 +1,331 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
# Common stub for a few missing GNU programs while installing.
|
||||||
|
|
||||||
|
scriptversion=2012-01-06.13; # UTC
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006,
|
||||||
|
# 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
||||||
|
# Originally 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
|
||||||
|
|
||||||
|
run=:
|
||||||
|
sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p'
|
||||||
|
sed_minuso='s/.* -o \([^ ]*\).*/\1/p'
|
||||||
|
|
||||||
|
# In the cases where this matters, `missing' is being run in the
|
||||||
|
# srcdir already.
|
||||||
|
if test -f configure.ac; then
|
||||||
|
configure_ac=configure.ac
|
||||||
|
else
|
||||||
|
configure_ac=configure.in
|
||||||
|
fi
|
||||||
|
|
||||||
|
msg="missing on your system"
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
--run)
|
||||||
|
# Try to run requested program, and just exit if it succeeds.
|
||||||
|
run=
|
||||||
|
shift
|
||||||
|
"$@" && exit 0
|
||||||
|
# Exit code 63 means version mismatch. This often happens
|
||||||
|
# when the user try to use an ancient version of a tool on
|
||||||
|
# a file that requires a minimum version. In this case we
|
||||||
|
# we should proceed has if the program had been absent, or
|
||||||
|
# if --run hadn't been passed.
|
||||||
|
if test $? = 63; then
|
||||||
|
run=:
|
||||||
|
msg="probably too old"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
-h|--h|--he|--hel|--help)
|
||||||
|
echo "\
|
||||||
|
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
||||||
|
|
||||||
|
Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
|
||||||
|
error status if there is no known handling for PROGRAM.
|
||||||
|
|
||||||
|
Options:
|
||||||
|
-h, --help display this help and exit
|
||||||
|
-v, --version output version information and exit
|
||||||
|
--run try to run the given command, and emulate it if it fails
|
||||||
|
|
||||||
|
Supported PROGRAM values:
|
||||||
|
aclocal touch file \`aclocal.m4'
|
||||||
|
autoconf touch file \`configure'
|
||||||
|
autoheader touch file \`config.h.in'
|
||||||
|
autom4te touch the output file, or create a stub one
|
||||||
|
automake touch all \`Makefile.in' files
|
||||||
|
bison create \`y.tab.[ch]', if possible, from existing .[ch]
|
||||||
|
flex create \`lex.yy.c', if possible, from existing .c
|
||||||
|
help2man touch the output file
|
||||||
|
lex create \`lex.yy.c', if possible, from existing .c
|
||||||
|
makeinfo touch the output file
|
||||||
|
yacc create \`y.tab.[ch]', if possible, from existing .[ch]
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
# normalize program name to check for.
|
||||||
|
program=`echo "$1" | sed '
|
||||||
|
s/^gnu-//; t
|
||||||
|
s/^gnu//; t
|
||||||
|
s/^g//; t'`
|
||||||
|
|
||||||
|
# Now exit if we have it, but it failed. Also exit now if we
|
||||||
|
# don't have it and --version was passed (most likely to detect
|
||||||
|
# the program). This is about non-GNU programs, so use $1 not
|
||||||
|
# $program.
|
||||||
|
case $1 in
|
||||||
|
lex*|yacc*)
|
||||||
|
# Not GNU programs, they don't have --version.
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
|
||||||
|
# We have it, but it failed.
|
||||||
|
exit 1
|
||||||
|
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
||||||
|
# Could not run --version or --help. This is probably someone
|
||||||
|
# running `$TOOL --version' or `$TOOL --help' to check whether
|
||||||
|
# $TOOL exists and not knowing $TOOL uses missing.
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# If it does not exist, or fails to run (possibly an outdated version),
|
||||||
|
# try to emulate it.
|
||||||
|
case $program in
|
||||||
|
aclocal*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`acinclude.m4' or \`${configure_ac}'. You might want
|
||||||
|
to install the \`Automake' and \`Perl' packages. Grab them from
|
||||||
|
any GNU archive site."
|
||||||
|
touch aclocal.m4
|
||||||
|
;;
|
||||||
|
|
||||||
|
autoconf*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`${configure_ac}'. You might want to install the
|
||||||
|
\`Autoconf' and \`GNU m4' packages. Grab them from any GNU
|
||||||
|
archive site."
|
||||||
|
touch configure
|
||||||
|
;;
|
||||||
|
|
||||||
|
autoheader*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`acconfig.h' or \`${configure_ac}'. You might want
|
||||||
|
to install the \`Autoconf' and \`GNU m4' packages. Grab them
|
||||||
|
from any GNU archive site."
|
||||||
|
files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
|
||||||
|
test -z "$files" && files="config.h"
|
||||||
|
touch_files=
|
||||||
|
for f in $files; do
|
||||||
|
case $f in
|
||||||
|
*:*) touch_files="$touch_files "`echo "$f" |
|
||||||
|
sed -e 's/^[^:]*://' -e 's/:.*//'`;;
|
||||||
|
*) touch_files="$touch_files $f.in";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
touch $touch_files
|
||||||
|
;;
|
||||||
|
|
||||||
|
automake*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
|
||||||
|
You might want to install the \`Automake' and \`Perl' packages.
|
||||||
|
Grab them from any GNU archive site."
|
||||||
|
find . -type f -name Makefile.am -print |
|
||||||
|
sed 's/\.am$/.in/' |
|
||||||
|
while read f; do touch "$f"; done
|
||||||
|
;;
|
||||||
|
|
||||||
|
autom4te*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is needed, but is $msg.
|
||||||
|
You might have modified some files without having the
|
||||||
|
proper tools for further handling them.
|
||||||
|
You can get \`$1' as part of \`Autoconf' from any GNU
|
||||||
|
archive site."
|
||||||
|
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -f "$file"; then
|
||||||
|
touch $file
|
||||||
|
else
|
||||||
|
test -z "$file" || exec >$file
|
||||||
|
echo "#! /bin/sh"
|
||||||
|
echo "# Created by GNU Automake missing as a replacement of"
|
||||||
|
echo "# $ $@"
|
||||||
|
echo "exit 0"
|
||||||
|
chmod +x $file
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
bison*|yacc*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' $msg. You should only need it if
|
||||||
|
you modified a \`.y' file. You may need the \`Bison' package
|
||||||
|
in order for those modifications to take effect. You can get
|
||||||
|
\`Bison' from any GNU archive site."
|
||||||
|
rm -f y.tab.c y.tab.h
|
||||||
|
if test $# -ne 1; then
|
||||||
|
eval LASTARG=\${$#}
|
||||||
|
case $LASTARG in
|
||||||
|
*.y)
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" y.tab.c
|
||||||
|
fi
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" y.tab.h
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
if test ! -f y.tab.h; then
|
||||||
|
echo >y.tab.h
|
||||||
|
fi
|
||||||
|
if test ! -f y.tab.c; then
|
||||||
|
echo 'main() { return 0; }' >y.tab.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
lex*|flex*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a \`.l' file. You may need the \`Flex' package
|
||||||
|
in order for those modifications to take effect. You can get
|
||||||
|
\`Flex' from any GNU archive site."
|
||||||
|
rm -f lex.yy.c
|
||||||
|
if test $# -ne 1; then
|
||||||
|
eval LASTARG=\${$#}
|
||||||
|
case $LASTARG in
|
||||||
|
*.l)
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" lex.yy.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
if test ! -f lex.yy.c; then
|
||||||
|
echo 'main() { return 0; }' >lex.yy.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
help2man*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a dependency of a manual page. You may need the
|
||||||
|
\`Help2man' package in order for those modifications to take
|
||||||
|
effect. You can get \`Help2man' from any GNU archive site."
|
||||||
|
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -f "$file"; then
|
||||||
|
touch $file
|
||||||
|
else
|
||||||
|
test -z "$file" || exec >$file
|
||||||
|
echo ".ab help2man is required to generate this page"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
makeinfo*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a \`.texi' or \`.texinfo' file, or any other file
|
||||||
|
indirectly affecting the aspect of the manual. The spurious
|
||||||
|
call might also be the consequence of using a buggy \`make' (AIX,
|
||||||
|
DU, IRIX). You might want to install the \`Texinfo' package or
|
||||||
|
the \`GNU make' package. Grab either from any GNU archive site."
|
||||||
|
# The file to touch is that specified with -o ...
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -z "$file"; then
|
||||||
|
# ... or it is the one specified with @setfilename ...
|
||||||
|
infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
|
||||||
|
file=`sed -n '
|
||||||
|
/^@setfilename/{
|
||||||
|
s/.* \([^ ]*\) *$/\1/
|
||||||
|
p
|
||||||
|
q
|
||||||
|
}' $infile`
|
||||||
|
# ... or it is derived from the source name (dir/f.texi becomes f.info)
|
||||||
|
test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info
|
||||||
|
fi
|
||||||
|
# If the file does not exist, the user really needs makeinfo;
|
||||||
|
# let's fail without touching anything.
|
||||||
|
test -f $file || exit 1
|
||||||
|
touch $file
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is needed, and is $msg.
|
||||||
|
You might have modified some files without having the
|
||||||
|
proper tools for further handling them. Check the \`README' file,
|
||||||
|
it often tells you about the needed prerequisites for installing
|
||||||
|
this package. You may also peek at any GNU archive site, in case
|
||||||
|
some other package would contain this missing \`$1' program."
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
# 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:
|
439
autoconf/tea/Makefile.in
Normal file
439
autoconf/tea/Makefile.in
Normal file
@ -0,0 +1,439 @@
|
|||||||
|
# Makefile.in --
|
||||||
|
#
|
||||||
|
# This file is a Makefile for Sample TEA Extension. If it has the name
|
||||||
|
# "Makefile.in" then it is a template for a Makefile; to generate the
|
||||||
|
# actual Makefile, run "./configure", which is a configuration script
|
||||||
|
# generated by the "autoconf" program (constructs like "@foo@" will get
|
||||||
|
# replaced in the actual Makefile.
|
||||||
|
#
|
||||||
|
# Copyright (c) 1999 Scriptics Corporation.
|
||||||
|
# Copyright (c) 2002-2005 ActiveState Corporation.
|
||||||
|
#
|
||||||
|
# See the file "license.terms" for information on usage and redistribution
|
||||||
|
# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
#
|
||||||
|
# RCS: @(#) $Id: Makefile.in,v 1.59 2005/07/26 19:17:02 mdejong Exp $
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Add additional lines to handle any additional AC_SUBST cases that
|
||||||
|
# have been added in a customized configure script.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
#SAMPLE_NEW_VAR = @SAMPLE_NEW_VAR@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Nothing of the variables below this line should need to be changed.
|
||||||
|
# Please check the TARGETS section below to make sure the make targets
|
||||||
|
# are correct.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# The names of the source files is defined in the configure script.
|
||||||
|
# The object files are used for linking into the final library.
|
||||||
|
# This will be used when a dist target is added to the Makefile.
|
||||||
|
# It is not important to specify the directory, as long as it is the
|
||||||
|
# $(srcdir) or in the generic, win or unix subdirectory.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
PKG_SOURCES = @PKG_SOURCES@
|
||||||
|
PKG_OBJECTS = @PKG_OBJECTS@
|
||||||
|
|
||||||
|
PKG_STUB_SOURCES = @PKG_STUB_SOURCES@
|
||||||
|
PKG_STUB_OBJECTS = @PKG_STUB_OBJECTS@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# PKG_TCL_SOURCES identifies Tcl runtime files that are associated with
|
||||||
|
# this package that need to be installed, if any.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
PKG_TCL_SOURCES = @PKG_TCL_SOURCES@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# This is a list of public header files to be installed, if any.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
PKG_HEADERS = @PKG_HEADERS@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# "PKG_LIB_FILE" refers to the library (dynamic or static as per
|
||||||
|
# configuration options) composed of the named objects.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
PKG_LIB_FILE = @PKG_LIB_FILE@
|
||||||
|
PKG_STUB_LIB_FILE = @PKG_STUB_LIB_FILE@
|
||||||
|
|
||||||
|
lib_BINARIES = $(PKG_LIB_FILE)
|
||||||
|
BINARIES = $(lib_BINARIES)
|
||||||
|
|
||||||
|
SHELL = @SHELL@
|
||||||
|
|
||||||
|
srcdir = @srcdir@
|
||||||
|
prefix = @prefix@
|
||||||
|
exec_prefix = @exec_prefix@
|
||||||
|
|
||||||
|
bindir = @bindir@
|
||||||
|
libdir = @libdir@
|
||||||
|
datadir = @datadir@
|
||||||
|
mandir = @mandir@
|
||||||
|
includedir = @includedir@
|
||||||
|
|
||||||
|
DESTDIR =
|
||||||
|
|
||||||
|
PKG_DIR = $(PACKAGE_NAME)$(PACKAGE_VERSION)
|
||||||
|
pkgdatadir = $(datadir)/$(PKG_DIR)
|
||||||
|
pkglibdir = $(libdir)/$(PKG_DIR)
|
||||||
|
pkgincludedir = $(includedir)/$(PKG_DIR)
|
||||||
|
|
||||||
|
top_builddir = .
|
||||||
|
|
||||||
|
INSTALL = @INSTALL@
|
||||||
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||||
|
INSTALL_DATA = @INSTALL_DATA@
|
||||||
|
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||||
|
|
||||||
|
PACKAGE_NAME = @PACKAGE_NAME@
|
||||||
|
PACKAGE_VERSION = @PACKAGE_VERSION@
|
||||||
|
CC = @CC@
|
||||||
|
CFLAGS_DEFAULT = @CFLAGS_DEFAULT@
|
||||||
|
CFLAGS_WARNING = @CFLAGS_WARNING@
|
||||||
|
CLEANFILES = @CLEANFILES@
|
||||||
|
EXEEXT = @EXEEXT@
|
||||||
|
LDFLAGS_DEFAULT = @LDFLAGS_DEFAULT@
|
||||||
|
MAKE_LIB = @MAKE_LIB@
|
||||||
|
MAKE_SHARED_LIB = @MAKE_SHARED_LIB@
|
||||||
|
MAKE_STATIC_LIB = @MAKE_STATIC_LIB@
|
||||||
|
MAKE_STUB_LIB = @MAKE_STUB_LIB@
|
||||||
|
OBJEXT = @OBJEXT@
|
||||||
|
RANLIB = @RANLIB@
|
||||||
|
RANLIB_STUB = @RANLIB_STUB@
|
||||||
|
SHLIB_CFLAGS = @SHLIB_CFLAGS@
|
||||||
|
SHLIB_LD = @SHLIB_LD@
|
||||||
|
SHLIB_LD_LIBS = @SHLIB_LD_LIBS@
|
||||||
|
STLIB_LD = @STLIB_LD@
|
||||||
|
#TCL_DEFS = @TCL_DEFS@
|
||||||
|
TCL_BIN_DIR = @TCL_BIN_DIR@
|
||||||
|
TCL_SRC_DIR = @TCL_SRC_DIR@
|
||||||
|
#TK_BIN_DIR = @TK_BIN_DIR@
|
||||||
|
#TK_SRC_DIR = @TK_SRC_DIR@
|
||||||
|
|
||||||
|
# This is no longer necessary even for packages that use private Tcl headers
|
||||||
|
#TCL_TOP_DIR_NATIVE = @TCL_TOP_DIR_NATIVE@
|
||||||
|
# Not used, but retained for reference of what libs Tcl required
|
||||||
|
#TCL_LIBS = @TCL_LIBS@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# TCLLIBPATH seeds the auto_path in Tcl's init.tcl so we can test our
|
||||||
|
# package without installing. The other environment variables allow us
|
||||||
|
# to test against an uninstalled Tcl. Add special env vars that you
|
||||||
|
# require for testing here (like TCLX_LIBRARY).
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
EXTRA_PATH = $(top_builddir):$(TCL_BIN_DIR)
|
||||||
|
#EXTRA_PATH = $(top_builddir):$(TCL_BIN_DIR):$(TK_BIN_DIR)
|
||||||
|
TCLLIBPATH = $(top_builddir)
|
||||||
|
TCLSH_ENV = TCL_LIBRARY=`@CYGPATH@ $(TCL_SRC_DIR)/library` \
|
||||||
|
@LD_LIBRARY_PATH_VAR@="$(EXTRA_PATH):$(@LD_LIBRARY_PATH_VAR@)" \
|
||||||
|
PATH="$(EXTRA_PATH):$(PATH)" \
|
||||||
|
TCLLIBPATH="$(TCLLIBPATH)"
|
||||||
|
# TK_LIBRARY=`@CYGPATH@ $(TK_SRC_DIR)/library`
|
||||||
|
|
||||||
|
TCLSH_PROG = @TCLSH_PROG@
|
||||||
|
TCLSH = $(TCLSH_ENV) $(TCLSH_PROG)
|
||||||
|
|
||||||
|
#WISH_PROG = @WISH_PROG@
|
||||||
|
#WISH = $(TCLSH_ENV) $(WISH_PROG)
|
||||||
|
|
||||||
|
|
||||||
|
SHARED_BUILD = @SHARED_BUILD@
|
||||||
|
|
||||||
|
INCLUDES = @PKG_INCLUDES@ @TCL_INCLUDES@ -I$(srcdir)/..
|
||||||
|
#INCLUDES = @PKG_INCLUDES@ @TCL_INCLUDES@ @TK_INCLUDES@ @TK_XINCLUDES@
|
||||||
|
|
||||||
|
PKG_CFLAGS = @PKG_CFLAGS@
|
||||||
|
|
||||||
|
# TCL_DEFS is not strictly need here, but if you remove it, then you
|
||||||
|
# must make sure that configure.in checks for the necessary components
|
||||||
|
# that your library may use. TCL_DEFS can actually be a problem if
|
||||||
|
# you do not compile with a similar machine setup as the Tcl core was
|
||||||
|
# compiled with.
|
||||||
|
#DEFS = $(TCL_DEFS) @DEFS@ $(PKG_CFLAGS)
|
||||||
|
DEFS = @DEFS@ $(PKG_CFLAGS)
|
||||||
|
|
||||||
|
CONFIG_CLEAN_FILES = Makefile pkgIndex.tcl
|
||||||
|
|
||||||
|
CPPFLAGS = @CPPFLAGS@
|
||||||
|
LIBS = @PKG_LIBS@ @LIBS@
|
||||||
|
AR = @AR@
|
||||||
|
CFLAGS = @CFLAGS@
|
||||||
|
COMPILE = $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Start of user-definable TARGETS section
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# TEA TARGETS. Please note that the "libraries:" target refers to platform
|
||||||
|
# independent files, and the "binaries:" target inclues executable programs and
|
||||||
|
# platform-dependent libraries. Modify these targets so that they install
|
||||||
|
# the various pieces of your package. The make and install rules
|
||||||
|
# for the BINARIES that you specified above have already been done.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
all: binaries libraries doc
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# The binaries target builds executable programs, Windows .dll's, unix
|
||||||
|
# shared/static libraries, and any other platform-dependent files.
|
||||||
|
# The list of targets to build for "binaries:" is specified at the top
|
||||||
|
# of the Makefile, in the "BINARIES" variable.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
binaries: $(BINARIES)
|
||||||
|
|
||||||
|
libraries:
|
||||||
|
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Your doc target should differentiate from doc builds (by the developer)
|
||||||
|
# and doc installs (see install-doc), which just install the docs on the
|
||||||
|
# end user machine when building from source.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
doc:
|
||||||
|
@echo "If you have documentation to create, place the commands to"
|
||||||
|
@echo "build the docs in the 'doc:' target. For example:"
|
||||||
|
@echo " xml2nroff sample.xml > sample.n"
|
||||||
|
@echo " xml2html sample.xml > sample.html"
|
||||||
|
|
||||||
|
install: all install-binaries install-libraries install-doc
|
||||||
|
|
||||||
|
install-binaries: binaries install-lib-binaries install-bin-binaries
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# This rule installs platform-independent files, such as header files.
|
||||||
|
# The list=...; for p in $$list handles the empty list case x-platform.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
install-libraries: libraries
|
||||||
|
@mkdir -p $(DESTDIR)$(includedir)
|
||||||
|
@echo "Installing header files in $(DESTDIR)$(includedir)"
|
||||||
|
@list='$(PKG_HEADERS)'; for i in $$list; do \
|
||||||
|
echo "Installing $(srcdir)/$$i" ; \
|
||||||
|
$(INSTALL_DATA) $(srcdir)/$$i $(DESTDIR)$(includedir) ; \
|
||||||
|
done;
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Install documentation. Unix manpages should go in the $(mandir)
|
||||||
|
# directory.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
install-doc: doc
|
||||||
|
@mkdir -p $(DESTDIR)$(mandir)/mann
|
||||||
|
@echo "Installing documentation in $(DESTDIR)$(mandir)"
|
||||||
|
@list='$(srcdir)/doc/*.n'; for i in $$list; do \
|
||||||
|
echo "Installing $$i"; \
|
||||||
|
rm -f $(DESTDIR)$(mandir)/mann/`basename $$i`; \
|
||||||
|
$(INSTALL_DATA) $$i $(DESTDIR)$(mandir)/mann ; \
|
||||||
|
done
|
||||||
|
|
||||||
|
test: binaries libraries
|
||||||
|
@echo "SQLite TEA distribution does not include tests"
|
||||||
|
|
||||||
|
shell: binaries libraries
|
||||||
|
@$(TCLSH) $(SCRIPT)
|
||||||
|
|
||||||
|
gdb:
|
||||||
|
$(TCLSH_ENV) gdb $(TCLSH_PROG) $(SCRIPT)
|
||||||
|
|
||||||
|
depend:
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# $(PKG_LIB_FILE) should be listed as part of the BINARIES variable
|
||||||
|
# mentioned above. That will ensure that this target is built when you
|
||||||
|
# run "make binaries".
|
||||||
|
#
|
||||||
|
# The $(PKG_OBJECTS) objects are created and linked into the final
|
||||||
|
# library. In most cases these object files will correspond to the
|
||||||
|
# source files above.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
$(PKG_LIB_FILE): $(PKG_OBJECTS)
|
||||||
|
-rm -f $(PKG_LIB_FILE)
|
||||||
|
${MAKE_LIB}
|
||||||
|
$(RANLIB) $(PKG_LIB_FILE)
|
||||||
|
|
||||||
|
$(PKG_STUB_LIB_FILE): $(PKG_STUB_OBJECTS)
|
||||||
|
-rm -f $(PKG_STUB_LIB_FILE)
|
||||||
|
${MAKE_STUB_LIB}
|
||||||
|
$(RANLIB_STUB) $(PKG_STUB_LIB_FILE)
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# We need to enumerate the list of .c to .o lines here.
|
||||||
|
#
|
||||||
|
# In the following lines, $(srcdir) refers to the toplevel directory
|
||||||
|
# containing your extension. If your sources are in a subdirectory,
|
||||||
|
# you will have to modify the paths to reflect this:
|
||||||
|
#
|
||||||
|
# sample.$(OBJEXT): $(srcdir)/generic/sample.c
|
||||||
|
# $(COMPILE) -c `@CYGPATH@ $(srcdir)/generic/sample.c` -o $@
|
||||||
|
#
|
||||||
|
# Setting the VPATH variable to a list of paths will cause the makefile
|
||||||
|
# to look into these paths when resolving .c to .obj dependencies.
|
||||||
|
# As necessary, add $(srcdir):$(srcdir)/compat:....
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
VPATH = $(srcdir):$(srcdir)/generic:$(srcdir)/unix:$(srcdir)/win
|
||||||
|
|
||||||
|
.c.@OBJEXT@:
|
||||||
|
$(COMPILE) -c `@CYGPATH@ $<` -o $@
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Distribution creation
|
||||||
|
# You may need to tweak this target to make it work correctly.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
#COMPRESS = tar cvf $(PKG_DIR).tar $(PKG_DIR); compress $(PKG_DIR).tar
|
||||||
|
COMPRESS = gtar zcvf $(PKG_DIR).tar.gz $(PKG_DIR)
|
||||||
|
DIST_ROOT = /tmp/dist
|
||||||
|
DIST_DIR = $(DIST_ROOT)/$(PKG_DIR)
|
||||||
|
|
||||||
|
dist-clean:
|
||||||
|
rm -rf $(DIST_DIR) $(DIST_ROOT)/$(PKG_DIR).tar.*
|
||||||
|
|
||||||
|
dist: dist-clean
|
||||||
|
mkdir -p $(DIST_DIR)
|
||||||
|
cp -p $(srcdir)/README* $(srcdir)/license* \
|
||||||
|
$(srcdir)/aclocal.m4 $(srcdir)/configure $(srcdir)/*.in \
|
||||||
|
$(DIST_DIR)/
|
||||||
|
chmod 664 $(DIST_DIR)/Makefile.in $(DIST_DIR)/aclocal.m4
|
||||||
|
chmod 775 $(DIST_DIR)/configure $(DIST_DIR)/configure.in
|
||||||
|
|
||||||
|
for i in $(srcdir)/*.[ch]; do \
|
||||||
|
if [ -f $$i ]; then \
|
||||||
|
cp -p $$i $(DIST_DIR)/ ; \
|
||||||
|
fi; \
|
||||||
|
done;
|
||||||
|
|
||||||
|
mkdir $(DIST_DIR)/tclconfig
|
||||||
|
cp $(srcdir)/tclconfig/install-sh $(srcdir)/tclconfig/tcl.m4 \
|
||||||
|
$(DIST_DIR)/tclconfig/
|
||||||
|
chmod 664 $(DIST_DIR)/tclconfig/tcl.m4
|
||||||
|
chmod +x $(DIST_DIR)/tclconfig/install-sh
|
||||||
|
|
||||||
|
list='demos doc generic library mac tests unix win'; \
|
||||||
|
for p in $$list; do \
|
||||||
|
if test -d $(srcdir)/$$p ; then \
|
||||||
|
mkdir $(DIST_DIR)/$$p; \
|
||||||
|
cp -p $(srcdir)/$$p/*.* $(DIST_DIR)/$$p/; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
|
||||||
|
(cd $(DIST_ROOT); $(COMPRESS);)
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# End of user-definable section
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Don't modify the file to clean here. Instead, set the "CLEANFILES"
|
||||||
|
# variable in configure.in
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
clean:
|
||||||
|
-test -z "$(BINARIES)" || rm -f $(BINARIES)
|
||||||
|
-rm -f *.$(OBJEXT) core *.core
|
||||||
|
-test -z "$(CLEANFILES)" || rm -f $(CLEANFILES)
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
-rm -f *.tab.c
|
||||||
|
-rm -f $(CONFIG_CLEAN_FILES)
|
||||||
|
-rm -f config.cache config.log config.status
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Install binary object libraries. On Windows this includes both .dll and
|
||||||
|
# .lib files. Because the .lib files are not explicitly listed anywhere,
|
||||||
|
# we need to deduce their existence from the .dll file of the same name.
|
||||||
|
# Library files go into the lib directory.
|
||||||
|
# In addition, this will generate the pkgIndex.tcl
|
||||||
|
# file in the install location (assuming it can find a usable tclsh shell)
|
||||||
|
#
|
||||||
|
# You should not have to modify this target.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
install-lib-binaries: binaries
|
||||||
|
@mkdir -p $(DESTDIR)$(pkglibdir)
|
||||||
|
@list='$(lib_BINARIES)'; for p in $$list; do \
|
||||||
|
if test -f $$p; then \
|
||||||
|
echo " $(INSTALL_PROGRAM) $$p $(DESTDIR)$(pkglibdir)/$$p"; \
|
||||||
|
$(INSTALL_PROGRAM) $$p $(DESTDIR)$(pkglibdir)/$$p; \
|
||||||
|
stub=`echo $$p|sed -e "s/.*\(stub\).*/\1/"`; \
|
||||||
|
if test "x$$stub" = "xstub"; then \
|
||||||
|
echo " $(RANLIB_STUB) $(DESTDIR)$(pkglibdir)/$$p"; \
|
||||||
|
$(RANLIB_STUB) $(DESTDIR)$(pkglibdir)/$$p; \
|
||||||
|
else \
|
||||||
|
echo " $(RANLIB) $(DESTDIR)$(pkglibdir)/$$p"; \
|
||||||
|
$(RANLIB) $(DESTDIR)$(pkglibdir)/$$p; \
|
||||||
|
fi; \
|
||||||
|
ext=`echo $$p|sed -e "s/.*\.//"`; \
|
||||||
|
if test "x$$ext" = "xdll"; then \
|
||||||
|
lib=`basename $$p|sed -e 's/.[^.]*$$//'`.lib; \
|
||||||
|
if test -f $$lib; then \
|
||||||
|
echo " $(INSTALL_DATA) $$lib $(DESTDIR)$(pkglibdir)/$$lib"; \
|
||||||
|
$(INSTALL_DATA) $$lib $(DESTDIR)$(pkglibdir)/$$lib; \
|
||||||
|
fi; \
|
||||||
|
fi; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
@list='$(PKG_TCL_SOURCES)'; for p in $$list; do \
|
||||||
|
if test -f $(srcdir)/$$p; then \
|
||||||
|
destp=`basename $$p`; \
|
||||||
|
echo " Install $$destp $(DESTDIR)$(pkglibdir)/$$destp"; \
|
||||||
|
$(INSTALL_DATA) $(srcdir)/$$p $(DESTDIR)$(pkglibdir)/$$destp; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
@if test "x$(SHARED_BUILD)" = "x1"; then \
|
||||||
|
echo " Install pkgIndex.tcl $(DESTDIR)$(pkglibdir)"; \
|
||||||
|
$(INSTALL_DATA) pkgIndex.tcl $(DESTDIR)$(pkglibdir); \
|
||||||
|
fi
|
||||||
|
|
||||||
|
#========================================================================
|
||||||
|
# Install binary executables (e.g. .exe files and dependent .dll files)
|
||||||
|
# This is for files that must go in the bin directory (located next to
|
||||||
|
# wish and tclsh), like dependent .dll files on Windows.
|
||||||
|
#
|
||||||
|
# You should not have to modify this target, except to define bin_BINARIES
|
||||||
|
# above if necessary.
|
||||||
|
#========================================================================
|
||||||
|
|
||||||
|
install-bin-binaries: binaries
|
||||||
|
@mkdir -p $(DESTDIR)$(bindir)
|
||||||
|
@list='$(bin_BINARIES)'; for p in $$list; do \
|
||||||
|
if test -f $$p; then \
|
||||||
|
echo " $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/$$p"; \
|
||||||
|
$(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/$$p; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
|
||||||
|
.SUFFIXES: .c .$(OBJEXT)
|
||||||
|
|
||||||
|
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
|
cd $(top_builddir) \
|
||||||
|
&& CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
|
||||||
|
|
||||||
|
uninstall-binaries:
|
||||||
|
list='$(lib_BINARIES)'; for p in $$list; do \
|
||||||
|
rm -f $(DESTDIR)$(pkglibdir)/$$p; \
|
||||||
|
done
|
||||||
|
list='$(PKG_TCL_SOURCES)'; for p in $$list; do \
|
||||||
|
p=`basename $$p`; \
|
||||||
|
rm -f $(DESTDIR)$(pkglibdir)/$$p; \
|
||||||
|
done
|
||||||
|
list='$(bin_BINARIES)'; for p in $$list; do \
|
||||||
|
rm -f $(DESTDIR)$(bindir)/$$p; \
|
||||||
|
done
|
||||||
|
|
||||||
|
.PHONY: all binaries clean depend distclean doc install libraries test
|
||||||
|
|
||||||
|
# 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:
|
36
autoconf/tea/README
Normal file
36
autoconf/tea/README
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
This is the SQLite extension for Tcl using the Tcl Extension
|
||||||
|
Architecture (TEA). For additional information on SQLite see
|
||||||
|
|
||||||
|
http://www.sqlite.org/
|
||||||
|
|
||||||
|
|
||||||
|
UNIX BUILD
|
||||||
|
==========
|
||||||
|
|
||||||
|
Building under most UNIX systems is easy, just run the configure script
|
||||||
|
and then run make. For more information about the build process, see
|
||||||
|
the tcl/unix/README file in the Tcl src dist. The following minimal
|
||||||
|
example will install the extension in the /opt/tcl directory.
|
||||||
|
|
||||||
|
$ cd sqlite-*-tea
|
||||||
|
$ ./configure --prefix=/opt/tcl
|
||||||
|
$ make
|
||||||
|
$ make install
|
||||||
|
|
||||||
|
WINDOWS BUILD
|
||||||
|
=============
|
||||||
|
|
||||||
|
The recommended method to build extensions under windows is to use the
|
||||||
|
Msys + Mingw build process. This provides a Unix-style build while
|
||||||
|
generating native Windows binaries. Using the Msys + Mingw build tools
|
||||||
|
means that you can use the same configure script as per the Unix build
|
||||||
|
to create a Makefile. See the tcl/win/README file for the URL of
|
||||||
|
the Msys + Mingw download.
|
||||||
|
|
||||||
|
If you have VC++ then you may wish to use the files in the win
|
||||||
|
subdirectory and build the extension using just VC++. These files have
|
||||||
|
been designed to be as generic as possible but will require some
|
||||||
|
additional maintenance by the project developer to synchronise with
|
||||||
|
the TEA configure.in and Makefile.in files. Instructions for using the
|
||||||
|
VC++ makefile are written in the first part of the Makefile.vc
|
||||||
|
file.
|
9
autoconf/tea/aclocal.m4
vendored
Normal file
9
autoconf/tea/aclocal.m4
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#
|
||||||
|
# Include the TEA standard macro set
|
||||||
|
#
|
||||||
|
|
||||||
|
builtin(include,tclconfig/tcl.m4)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Add here whatever m4 macros you want to define for your package
|
||||||
|
#
|
200
autoconf/tea/configure.in
Normal file
200
autoconf/tea/configure.in
Normal file
@ -0,0 +1,200 @@
|
|||||||
|
#!/bin/bash -norc
|
||||||
|
dnl This file is an input file used by the GNU "autoconf" program to
|
||||||
|
dnl generate the file "configure", which is run during Tcl installation
|
||||||
|
dnl to configure the system for the local environment.
|
||||||
|
#
|
||||||
|
# RCS: @(#) $Id: configure.in,v 1.43 2005/07/26 19:17:05 mdejong Exp $
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# Sample configure.in for Tcl Extensions. The only places you should
|
||||||
|
# need to modify this file are marked by the string __CHANGE__
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# __CHANGE__
|
||||||
|
# Set your package name and version numbers here.
|
||||||
|
#
|
||||||
|
# This initializes the environment with PACKAGE_NAME and PACKAGE_VERSION
|
||||||
|
# set as provided. These will also be added as -D defs in your Makefile
|
||||||
|
# so you can encode the package version directly into the source files.
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_INIT([sqlite], [3.7.4])
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Call TEA_INIT as the first TEA_ macro to set up initial vars.
|
||||||
|
# This will define a ${TEA_PLATFORM} variable == "unix" or "windows"
|
||||||
|
# as well as PKG_LIB_FILE and PKG_STUB_LIB_FILE.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_INIT([3.9])
|
||||||
|
|
||||||
|
AC_CONFIG_AUX_DIR(tclconfig)
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Load the tclConfig.sh file
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_PATH_TCLCONFIG
|
||||||
|
TEA_LOAD_TCLCONFIG
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Load the tkConfig.sh file if necessary (Tk extension)
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
#TEA_PATH_TKCONFIG
|
||||||
|
#TEA_LOAD_TKCONFIG
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# Handle the --prefix=... option by defaulting to what Tcl gave.
|
||||||
|
# Must be called after TEA_LOAD_TCLCONFIG and before TEA_SETUP_COMPILER.
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_PREFIX
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# Standard compiler checks.
|
||||||
|
# This sets up CC by using the CC env var, or looks for gcc otherwise.
|
||||||
|
# This also calls AC_PROG_CC, AC_PROG_INSTALL and a few others to create
|
||||||
|
# the basic setup necessary to compile executables.
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_SETUP_COMPILER
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# __CHANGE__
|
||||||
|
# Specify the C source files to compile in TEA_ADD_SOURCES,
|
||||||
|
# public headers that need to be installed in TEA_ADD_HEADERS,
|
||||||
|
# stub library C source files to compile in TEA_ADD_STUB_SOURCES,
|
||||||
|
# and runtime Tcl library files in TEA_ADD_TCL_SOURCES.
|
||||||
|
# This defines PKG(_STUB)_SOURCES, PKG(_STUB)_OBJECTS, PKG_HEADERS
|
||||||
|
# and PKG_TCL_SOURCES.
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_ADD_SOURCES([tclsqlite3.c])
|
||||||
|
TEA_ADD_HEADERS([])
|
||||||
|
TEA_ADD_INCLUDES([-I\"`\${CYGPATH} \${srcdir}/generic`\"])
|
||||||
|
TEA_ADD_LIBS([])
|
||||||
|
TEA_ADD_CFLAGS([-DSQLITE_ENABLE_FTS3=1])
|
||||||
|
TEA_ADD_CFLAGS([-DSQLITE_3_SUFFIX_ONLY=1])
|
||||||
|
TEA_ADD_CFLAGS([-DSQLITE_ENABLE_RTREE=1])
|
||||||
|
TEA_ADD_CFLAGS([-DSQLITE_OMIT_DEPRECATED=1])
|
||||||
|
TEA_ADD_STUB_SOURCES([])
|
||||||
|
TEA_ADD_TCL_SOURCES([])
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# The --with-system-sqlite causes the TCL bindings to SQLite to use
|
||||||
|
# the system shared library for SQLite rather than statically linking
|
||||||
|
# against its own private copy. This is dangerous and leads to
|
||||||
|
# undersirable dependences and is not recommended.
|
||||||
|
# Patchs from rmax.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
AC_ARG_WITH([system-sqlite],
|
||||||
|
[AC_HELP_STRING([--with-system-sqlite],
|
||||||
|
[use a system-supplied libsqlite3 instead of the bundled one])],
|
||||||
|
[], [with_system_sqlite=no])
|
||||||
|
if test x$with_system_sqlite != xno; then
|
||||||
|
AC_CHECK_HEADER([sqlite3.h],
|
||||||
|
[AC_CHECK_LIB([sqlite3],[sqlite3_initialize],
|
||||||
|
[AC_DEFINE(USE_SYSTEM_SQLITE)
|
||||||
|
LIBS="$LIBS -lsqlite3"])])
|
||||||
|
fi
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# __CHANGE__
|
||||||
|
# Choose which headers you need. Extension authors should try very
|
||||||
|
# hard to only rely on the Tcl public header files. Internal headers
|
||||||
|
# contain private data structures and are subject to change without
|
||||||
|
# notice.
|
||||||
|
# This MUST be called after TEA_LOAD_TCLCONFIG / TEA_LOAD_TKCONFIG
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_PUBLIC_TCL_HEADERS
|
||||||
|
#TEA_PRIVATE_TCL_HEADERS
|
||||||
|
|
||||||
|
#TEA_PUBLIC_TK_HEADERS
|
||||||
|
#TEA_PRIVATE_TK_HEADERS
|
||||||
|
#TEA_PATH_X
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Check whether --enable-threads or --disable-threads was given.
|
||||||
|
# This auto-enables if Tcl was compiled threaded.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_ENABLE_THREADS
|
||||||
|
if test "${TCL_THREADS}" = "1" ; then
|
||||||
|
AC_DEFINE(SQLITE_THREADSAFE, 1, [Trigger sqlite threadsafe build])
|
||||||
|
# Not automatically added by Tcl because its assumed Tcl links to them,
|
||||||
|
# but it may not if it isn't really a threaded build.
|
||||||
|
TEA_ADD_LIBS([$THREADS_LIBS])
|
||||||
|
else
|
||||||
|
AC_DEFINE(SQLITE_THREADSAFE, 0, [Trigger sqlite non-threadsafe build])
|
||||||
|
fi
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# The statement below defines a collection of symbols related to
|
||||||
|
# building as a shared library instead of a static library.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_ENABLE_SHARED
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# This macro figures out what flags to use with the compiler/linker
|
||||||
|
# when building shared/static debug/optimized objects. This information
|
||||||
|
# can be taken from the tclConfig.sh file, but this figures it all out.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_CONFIG_CFLAGS
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Set the default compiler switches based on the --enable-symbols option.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_ENABLE_SYMBOLS
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Everyone should be linking against the Tcl stub library. If you
|
||||||
|
# can't for some reason, remove this definition. If you aren't using
|
||||||
|
# stubs, you also need to modify the SHLIB_LD_LIBS setting below to
|
||||||
|
# link against the non-stubbed Tcl library. Add Tk too if necessary.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_DEFINE(USE_TCL_STUBS, 1, [Use Tcl stubs])
|
||||||
|
#AC_DEFINE(USE_TK_STUBS, 1, [Use Tk stubs])
|
||||||
|
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Redefine fdatasync as fsync on systems that lack fdatasync
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_CHECK_FUNC(fdatasync, , AC_DEFINE(fdatasync, fsync))
|
||||||
|
|
||||||
|
AC_FUNC_STRERROR_R
|
||||||
|
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# This macro generates a line to use when building a library. It
|
||||||
|
# depends on values set by the TEA_ENABLE_SHARED, TEA_ENABLE_SYMBOLS,
|
||||||
|
# and TEA_LOAD_TCLCONFIG macros above.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_MAKE_LIB
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Determine the name of the tclsh and/or wish executables in the
|
||||||
|
# Tcl and Tk build directories or the location they were installed
|
||||||
|
# into. These paths are used to support running test cases only,
|
||||||
|
# the Makefile should not be making use of these paths to generate
|
||||||
|
# a pkgIndex.tcl file or anything else at extension build time.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
TEA_PROG_TCLSH
|
||||||
|
#TEA_PROG_WISH
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
# Finally, substitute all of the various values into the Makefile.
|
||||||
|
# You may alternatively have a special pkgIndex.tcl.in or other files
|
||||||
|
# which require substituting th AC variables in. Include these here.
|
||||||
|
#--------------------------------------------------------------------
|
||||||
|
|
||||||
|
AC_OUTPUT([Makefile pkgIndex.tcl])
|
15
autoconf/tea/doc/sqlite3.n
Normal file
15
autoconf/tea/doc/sqlite3.n
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
.TH sqlite3 n 4.1 "Tcl-Extensions"
|
||||||
|
.HS sqlite3 tcl
|
||||||
|
.BS
|
||||||
|
.SH NAME
|
||||||
|
sqlite3 \- an interface to the SQLite3 database engine
|
||||||
|
.SH SYNOPSIS
|
||||||
|
\fBsqlite3\fI command_name ?filename?\fR
|
||||||
|
.br
|
||||||
|
.SH DESCRIPTION
|
||||||
|
SQLite3 is a self-contains, zero-configuration, transactional SQL database
|
||||||
|
engine. This extension provides an easy to use interface for accessing
|
||||||
|
SQLite database files from Tcl.
|
||||||
|
.PP
|
||||||
|
For full documentation see http://www.sqlite.org/ and
|
||||||
|
in particular http://www.sqlite.org/tclsqlite.html.
|
6
autoconf/tea/license.terms
Normal file
6
autoconf/tea/license.terms
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
The author disclaims copyright to this source code. In place of
|
||||||
|
a legal notice, here is a blessing:
|
||||||
|
|
||||||
|
May you do good and not evil.
|
||||||
|
May you find forgiveness for yourself and forgive others.
|
||||||
|
May you share freely, never taking more than you give.
|
7
autoconf/tea/pkgIndex.tcl.in
Normal file
7
autoconf/tea/pkgIndex.tcl.in
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
#
|
||||||
|
# Tcl package index file
|
||||||
|
#
|
||||||
|
# Note sqlite*3* init specifically
|
||||||
|
#
|
||||||
|
package ifneeded sqlite3 @PACKAGE_VERSION@ \
|
||||||
|
[list load [file join $dir @PKG_LIB_FILE@] Sqlite3]
|
119
autoconf/tea/tclconfig/install-sh
Normal file
119
autoconf/tea/tclconfig/install-sh
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
#
|
||||||
|
# install - install a program, script, or datafile
|
||||||
|
# This comes from X11R5; it is not part of GNU.
|
||||||
|
#
|
||||||
|
# $XConsortium: install.sh,v 1.2 89/12/18 14:47:22 jim Exp $
|
||||||
|
#
|
||||||
|
# This script is compatible with the BSD install script, but was written
|
||||||
|
# from scratch.
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
# set DOITPROG to echo to test this script
|
||||||
|
|
||||||
|
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
||||||
|
doit="${DOITPROG-}"
|
||||||
|
|
||||||
|
|
||||||
|
# put in absolute paths if you don't have them in your path; or use env. vars.
|
||||||
|
|
||||||
|
mvprog="${MVPROG-mv}"
|
||||||
|
cpprog="${CPPROG-cp}"
|
||||||
|
chmodprog="${CHMODPROG-chmod}"
|
||||||
|
chownprog="${CHOWNPROG-chown}"
|
||||||
|
chgrpprog="${CHGRPPROG-chgrp}"
|
||||||
|
stripprog="${STRIPPROG-strip}"
|
||||||
|
rmprog="${RMPROG-rm}"
|
||||||
|
|
||||||
|
instcmd="$mvprog"
|
||||||
|
chmodcmd=""
|
||||||
|
chowncmd=""
|
||||||
|
chgrpcmd=""
|
||||||
|
stripcmd=""
|
||||||
|
rmcmd="$rmprog -f"
|
||||||
|
mvcmd="$mvprog"
|
||||||
|
src=""
|
||||||
|
dst=""
|
||||||
|
|
||||||
|
while [ x"$1" != x ]; do
|
||||||
|
case $1 in
|
||||||
|
-c) instcmd="$cpprog"
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
|
||||||
|
-m) chmodcmd="$chmodprog $2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
|
||||||
|
-o) chowncmd="$chownprog $2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
|
||||||
|
-g) chgrpcmd="$chgrpprog $2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
|
||||||
|
-s) stripcmd="$stripprog"
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
|
||||||
|
*) if [ x"$src" = x ]
|
||||||
|
then
|
||||||
|
src=$1
|
||||||
|
else
|
||||||
|
dst=$1
|
||||||
|
fi
|
||||||
|
shift
|
||||||
|
continue;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ x"$src" = x ]
|
||||||
|
then
|
||||||
|
echo "install: no input file specified"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ x"$dst" = x ]
|
||||||
|
then
|
||||||
|
echo "install: no destination specified"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# If destination is a directory, append the input filename; if your system
|
||||||
|
# does not like double slashes in filenames, you may need to add some logic
|
||||||
|
|
||||||
|
if [ -d $dst ]
|
||||||
|
then
|
||||||
|
dst="$dst"/`basename $src`
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Make a temp file name in the proper directory.
|
||||||
|
|
||||||
|
dstdir=`dirname $dst`
|
||||||
|
dsttmp=$dstdir/#inst.$$#
|
||||||
|
|
||||||
|
# Move or copy the file name to the temp name
|
||||||
|
|
||||||
|
$doit $instcmd $src $dsttmp
|
||||||
|
|
||||||
|
# and set any options; do chmod last to preserve setuid bits
|
||||||
|
|
||||||
|
if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; fi
|
||||||
|
if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; fi
|
||||||
|
if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; fi
|
||||||
|
if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; fi
|
||||||
|
|
||||||
|
# Now rename the file to the real destination.
|
||||||
|
|
||||||
|
$doit $rmcmd $dst
|
||||||
|
$doit $mvcmd $dsttmp $dst
|
||||||
|
|
||||||
|
|
||||||
|
exit 0
|
3997
autoconf/tea/tclconfig/tcl.m4
Normal file
3997
autoconf/tea/tclconfig/tcl.m4
Normal file
File diff suppressed because it is too large
Load Diff
414
autoconf/tea/win/makefile.vc
Normal file
414
autoconf/tea/win/makefile.vc
Normal file
@ -0,0 +1,414 @@
|
|||||||
|
# makefile.vc -- -*- Makefile -*-
|
||||||
|
#
|
||||||
|
# Microsoft Visual C++ makefile for use with nmake.exe v1.62+ (VC++ 5.0+)
|
||||||
|
#
|
||||||
|
# This makefile is based upon the Tcl 8.4 Makefile.vc and modified to
|
||||||
|
# make it suitable as a general package makefile. Look for the word EDIT
|
||||||
|
# which marks sections that may need modification. As a minumum you will
|
||||||
|
# need to change the PROJECT, DOTVERSION and DLLOBJS variables to values
|
||||||
|
# relevant to your package.
|
||||||
|
#
|
||||||
|
# See the file "license.terms" for information on usage and redistribution
|
||||||
|
# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
#
|
||||||
|
# Copyright (c) 1995-1996 Sun Microsystems, Inc.
|
||||||
|
# Copyright (c) 1998-2000 Ajuba Solutions.
|
||||||
|
# Copyright (c) 2001 ActiveState Corporation.
|
||||||
|
# Copyright (c) 2001-2002 David Gravereaux.
|
||||||
|
# Copyright (c) 2003 Pat Thoyts
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# RCS: @(#)$Id: makefile.vc,v 1.4 2004/07/26 08:22:05 patthoyts Exp $
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if !defined(MSDEVDIR) && !defined(MSVCDIR) && !defined(VCINSTALLDIR) && !defined(MSSDK) && !defined(WINDOWSSDKDIR)
|
||||||
|
MSG = ^
|
||||||
|
You will need to run vcvars32.bat from Developer Studio, first, to setup^
|
||||||
|
the environment. Jump to this line to read the new instructions.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
# HOW TO USE this makefile:
|
||||||
|
#
|
||||||
|
# 1) It is now necessary to have %MSVCDir% set in the environment. This is
|
||||||
|
# used as a check to see if vcvars32.bat had been run prior to running
|
||||||
|
# nmake or during the installation of Microsoft Visual C++, MSVCDir had
|
||||||
|
# been set globally and the PATH adjusted. Either way is valid.
|
||||||
|
#
|
||||||
|
# You'll need to run vcvars32.bat contained in the MsDev's vc(98)/bin
|
||||||
|
# directory to setup the proper environment, if needed, for your current
|
||||||
|
# setup. This is a needed bootstrap requirement and allows the swapping of
|
||||||
|
# different environments to be easier.
|
||||||
|
#
|
||||||
|
# 2) To use the Platform SDK (not expressly needed), run setenv.bat after
|
||||||
|
# vcvars32.bat according to the instructions for it. This can also turn on
|
||||||
|
# the 64-bit compiler, if your SDK has it.
|
||||||
|
#
|
||||||
|
# 3) Targets are:
|
||||||
|
# all -- Builds everything.
|
||||||
|
# <project> -- Builds the project (eg: nmake sample)
|
||||||
|
# test -- Builds and runs the test suite.
|
||||||
|
# install -- Installs the built binaries and libraries to $(INSTALLDIR)
|
||||||
|
# in an appropriate subdirectory.
|
||||||
|
# clean/realclean/distclean -- varying levels of cleaning.
|
||||||
|
#
|
||||||
|
# 4) Macros usable on the commandline:
|
||||||
|
# INSTALLDIR=<path>
|
||||||
|
# Sets where to install Tcl from the built binaries.
|
||||||
|
# C:\Progra~1\Tcl is assumed when not specified.
|
||||||
|
#
|
||||||
|
# OPTS=static,msvcrt,staticpkg,threads,symbols,profile,loimpact,none
|
||||||
|
# Sets special options for the core. The default is for none.
|
||||||
|
# Any combination of the above may be used (comma separated).
|
||||||
|
# 'none' will over-ride everything to nothing.
|
||||||
|
#
|
||||||
|
# static = Builds a static library of the core instead of a
|
||||||
|
# dll. The shell will be static (and large), as well.
|
||||||
|
# msvcrt = Effects the static option only to switch it from
|
||||||
|
# using libcmt(d) as the C runtime [by default] to
|
||||||
|
# msvcrt(d). This is useful for static embedding
|
||||||
|
# support.
|
||||||
|
# staticpkg = Effects the static option only to switch
|
||||||
|
# tclshXX.exe to have the dde and reg extension linked
|
||||||
|
# inside it.
|
||||||
|
# threads = Turns on full multithreading support.
|
||||||
|
# thrdalloc = Use the thread allocator (shared global free pool).
|
||||||
|
# symbols = Adds symbols for step debugging.
|
||||||
|
# profile = Adds profiling hooks. Map file is assumed.
|
||||||
|
# loimpact = Adds a flag for how NT treats the heap to keep memory
|
||||||
|
# in use, low. This is said to impact alloc performance.
|
||||||
|
#
|
||||||
|
# STATS=memdbg,compdbg,none
|
||||||
|
# Sets optional memory and bytecode compiler debugging code added
|
||||||
|
# to the core. The default is for none. Any combination of the
|
||||||
|
# above may be used (comma separated). 'none' will over-ride
|
||||||
|
# everything to nothing.
|
||||||
|
#
|
||||||
|
# memdbg = Enables the debugging memory allocator.
|
||||||
|
# compdbg = Enables byte compilation logging.
|
||||||
|
#
|
||||||
|
# MACHINE=(IX86|IA64|ALPHA)
|
||||||
|
# Set the machine type used for the compiler, linker, and
|
||||||
|
# resource compiler. This hook is needed to tell the tools
|
||||||
|
# when alternate platforms are requested. IX86 is the default
|
||||||
|
# when not specified.
|
||||||
|
#
|
||||||
|
# TMP_DIR=<path>
|
||||||
|
# OUT_DIR=<path>
|
||||||
|
# Hooks to allow the intermediate and output directories to be
|
||||||
|
# changed. $(OUT_DIR) is assumed to be
|
||||||
|
# $(BINROOT)\(Release|Debug) based on if symbols are requested.
|
||||||
|
# $(TMP_DIR) will de $(OUT_DIR)\<buildtype> by default.
|
||||||
|
#
|
||||||
|
# TESTPAT=<file>
|
||||||
|
# Reads the tests requested to be run from this file.
|
||||||
|
#
|
||||||
|
# CFG_ENCODING=encoding
|
||||||
|
# name of encoding for configuration information. Defaults
|
||||||
|
# to cp1252
|
||||||
|
#
|
||||||
|
# 5) Examples:
|
||||||
|
#
|
||||||
|
# Basic syntax of calling nmake looks like this:
|
||||||
|
# nmake [-nologo] -f makefile.vc [target|macrodef [target|macrodef] [...]]
|
||||||
|
#
|
||||||
|
# Standard (no frills)
|
||||||
|
# c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
|
||||||
|
# Setting environment for using Microsoft Visual C++ tools.
|
||||||
|
# c:\tcl_src\win\>nmake -f makefile.vc all
|
||||||
|
# c:\tcl_src\win\>nmake -f makefile.vc install INSTALLDIR=c:\progra~1\tcl
|
||||||
|
#
|
||||||
|
# Building for Win64
|
||||||
|
# c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
|
||||||
|
# Setting environment for using Microsoft Visual C++ tools.
|
||||||
|
# c:\tcl_src\win\>c:\progra~1\platfo~1\setenv.bat /pre64 /RETAIL
|
||||||
|
# Targeting Windows pre64 RETAIL
|
||||||
|
# c:\tcl_src\win\>nmake -f makefile.vc MACHINE=IA64
|
||||||
|
#
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
#==============================================================================
|
||||||
|
###############################################################################
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if !exist("makefile.vc")
|
||||||
|
MSG = ^
|
||||||
|
You must run this makefile only from the directory it is in.^
|
||||||
|
Please `cd` to its location first.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# Project specific information (EDIT)
|
||||||
|
#
|
||||||
|
# You should edit this with the name and version of your project. This
|
||||||
|
# information is used to generate the name of the package library and
|
||||||
|
# it's install location.
|
||||||
|
#
|
||||||
|
# For example, the sample extension is going to build sample04.dll and
|
||||||
|
# would install it into $(INSTALLDIR)\lib\sample04
|
||||||
|
#
|
||||||
|
# You need to specify the object files that need to be linked into your
|
||||||
|
# binary here.
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
PROJECT = sqlite3
|
||||||
|
!include "rules.vc"
|
||||||
|
|
||||||
|
# nmakehelp -V <file> <tag> will search the file for tag, skips until a
|
||||||
|
# number and returns all character until a character not in [0-9.ab]
|
||||||
|
# is read.
|
||||||
|
|
||||||
|
!if [echo REM = This file is generated from Makefile.vc > versions.vc]
|
||||||
|
!endif
|
||||||
|
# get project version from row "AC_INIT([sqlite], [3.7.14])"
|
||||||
|
!if [echo DOTVERSION = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\configure.in AC_INIT >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!include "versions.vc"
|
||||||
|
|
||||||
|
VERSION = $(DOTVERSION:.=)
|
||||||
|
STUBPREFIX = $(PROJECT)stub
|
||||||
|
|
||||||
|
DLLOBJS = \
|
||||||
|
$(TMP_DIR)\tclsqlite3.obj
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# Target names and paths ( shouldn't need changing )
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
BINROOT = .
|
||||||
|
ROOT = ..
|
||||||
|
|
||||||
|
PRJIMPLIB = $(OUT_DIR)\$(PROJECT)$(VERSION)$(SUFX).lib
|
||||||
|
PRJLIBNAME = $(PROJECT)$(VERSION)$(SUFX).$(EXT)
|
||||||
|
PRJLIB = $(OUT_DIR)\$(PRJLIBNAME)
|
||||||
|
|
||||||
|
PRJSTUBLIBNAME = $(STUBPREFIX)$(VERSION).lib
|
||||||
|
PRJSTUBLIB = $(OUT_DIR)\$(PRJSTUBLIBNAME)
|
||||||
|
|
||||||
|
### Make sure we use backslash only.
|
||||||
|
PRJ_INSTALL_DIR = $(_INSTALLDIR)\$(PROJECT)$(DOTVERSION)
|
||||||
|
LIB_INSTALL_DIR = $(PRJ_INSTALL_DIR)
|
||||||
|
BIN_INSTALL_DIR = $(PRJ_INSTALL_DIR)
|
||||||
|
DOC_INSTALL_DIR = $(PRJ_INSTALL_DIR)
|
||||||
|
SCRIPT_INSTALL_DIR = $(PRJ_INSTALL_DIR)
|
||||||
|
INCLUDE_INSTALL_DIR = $(_TCLDIR)\include
|
||||||
|
|
||||||
|
### The following paths CANNOT have spaces in them.
|
||||||
|
GENERICDIR = $(ROOT)\generic
|
||||||
|
WINDIR = $(ROOT)\win
|
||||||
|
LIBDIR = $(ROOT)\library
|
||||||
|
DOCDIR = $(ROOT)\doc
|
||||||
|
TOOLSDIR = $(ROOT)\tools
|
||||||
|
COMPATDIR = $(ROOT)\compat
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Compile flags
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if !$(DEBUG)
|
||||||
|
!if $(OPTIMIZING)
|
||||||
|
### This cranks the optimization level to maximize speed
|
||||||
|
cdebug = -O2 -Op -Gs
|
||||||
|
!else
|
||||||
|
cdebug =
|
||||||
|
!endif
|
||||||
|
!else if "$(MACHINE)" == "IA64"
|
||||||
|
### Warnings are too many, can't support warnings into errors.
|
||||||
|
cdebug = -Z7 -Od -GZ
|
||||||
|
!else
|
||||||
|
cdebug = -Z7 -WX -Od -GZ
|
||||||
|
!endif
|
||||||
|
|
||||||
|
### Declarations common to all compiler options
|
||||||
|
cflags = -nologo -c -W3 -YX -Fp$(TMP_DIR)^\
|
||||||
|
|
||||||
|
!if $(MSVCRT)
|
||||||
|
!if $(DEBUG)
|
||||||
|
crt = -MDd
|
||||||
|
!else
|
||||||
|
crt = -MD
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
!if $(DEBUG)
|
||||||
|
crt = -MTd
|
||||||
|
!else
|
||||||
|
crt = -MT
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
INCLUDES = $(TCL_INCLUDES) -I"$(WINDIR)" -I"$(GENERICDIR)" \
|
||||||
|
-I"$(ROOT)\.."
|
||||||
|
BASE_CLFAGS = $(cflags) $(cdebug) $(crt) $(INCLUDES) \
|
||||||
|
-DSQLITE_3_SUFFIX_ONLY=1 -DSQLITE_ENABLE_RTREE=1 \
|
||||||
|
-DSQLITE_ENABLE_FTS3=1 -DSQLITE_OMIT_DEPRECATED=1
|
||||||
|
CON_CFLAGS = $(cflags) $(cdebug) $(crt) -DCONSOLE -DSQLITE_ENABLE_FTS3=1
|
||||||
|
TCL_CFLAGS = -DBUILD_sqlite -DUSE_TCL_STUBS \
|
||||||
|
-DPACKAGE_VERSION="\"$(DOTVERSION)\"" $(BASE_CLFAGS) \
|
||||||
|
$(OPTDEFINES)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Link flags
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if $(DEBUG)
|
||||||
|
ldebug = -debug:full -debugtype:cv
|
||||||
|
!else
|
||||||
|
ldebug = -release -opt:ref -opt:icf,3
|
||||||
|
!endif
|
||||||
|
|
||||||
|
### Declarations common to all linker options
|
||||||
|
lflags = -nologo -machine:$(MACHINE) $(ldebug)
|
||||||
|
|
||||||
|
!if $(PROFILE)
|
||||||
|
lflags = $(lflags) -profile
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $(ALIGN98_HACK) && !$(STATIC_BUILD)
|
||||||
|
### Align sections for PE size savings.
|
||||||
|
lflags = $(lflags) -opt:nowin98
|
||||||
|
!else if !$(ALIGN98_HACK) && $(STATIC_BUILD)
|
||||||
|
### Align sections for speed in loading by choosing the virtual page size.
|
||||||
|
lflags = $(lflags) -align:4096
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $(LOIMPACT)
|
||||||
|
lflags = $(lflags) -ws:aggressive
|
||||||
|
!endif
|
||||||
|
|
||||||
|
dlllflags = $(lflags) -dll
|
||||||
|
conlflags = $(lflags) -subsystem:console
|
||||||
|
guilflags = $(lflags) -subsystem:windows
|
||||||
|
baselibs = $(TCLSTUBLIB)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# TclTest flags
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
!IF "$(TESTPAT)" != ""
|
||||||
|
TESTFLAGS = $(TESTFLAGS) -file $(TESTPAT)
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Project specific targets (EDIT)
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
all: setup $(PROJECT)
|
||||||
|
$(PROJECT): setup $(PRJLIB)
|
||||||
|
install: install-binaries install-libraries install-docs
|
||||||
|
|
||||||
|
# Tests need to ensure we load the right dll file we
|
||||||
|
# have to handle the output differently on Win9x.
|
||||||
|
#
|
||||||
|
!if "$(OS)" == "Windows_NT" || "$(MSVCDIR)" == "IDE"
|
||||||
|
test: setup $(PROJECT)
|
||||||
|
set TCL_LIBRARY=$(ROOT)/library
|
||||||
|
$(TCLSH) <<
|
||||||
|
load $(PRJLIB:\=/)
|
||||||
|
cd "$(ROOT)/tests"
|
||||||
|
set argv "$(TESTFLAGS)"
|
||||||
|
source all.tcl
|
||||||
|
<<
|
||||||
|
!else
|
||||||
|
test: setup $(PROJECT)
|
||||||
|
echo Please wait while the test results are collected
|
||||||
|
set TCL_LIBRARY=$(ROOT)/library
|
||||||
|
$(TCLSH) << >tests.log
|
||||||
|
load $(PRJLIB:\=/)
|
||||||
|
cd "$(ROOT)/tests"
|
||||||
|
set argv "$(TESTFLAGS)"
|
||||||
|
source all.tcl
|
||||||
|
<<
|
||||||
|
type tests.log | more
|
||||||
|
!endif
|
||||||
|
|
||||||
|
setup:
|
||||||
|
@if not exist $(OUT_DIR)\nul mkdir $(OUT_DIR)
|
||||||
|
@if not exist $(TMP_DIR)\nul mkdir $(TMP_DIR)
|
||||||
|
|
||||||
|
$(PRJLIB): $(DLLOBJS)
|
||||||
|
$(link32) $(dlllflags) -out:$@ $(baselibs) @<<
|
||||||
|
$**
|
||||||
|
<<
|
||||||
|
-@del $*.exp
|
||||||
|
|
||||||
|
$(PRJSTUBLIB): $(PRJSTUBOBJS)
|
||||||
|
$(lib32) -nologo -out:$@ $(PRJSTUBOBJS)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Implicit rules
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
{$(WINDIR)}.c{$(TMP_DIR)}.obj::
|
||||||
|
$(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ @<<
|
||||||
|
$<
|
||||||
|
<<
|
||||||
|
|
||||||
|
{$(GENERICDIR)}.c{$(TMP_DIR)}.obj::
|
||||||
|
$(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ @<<
|
||||||
|
$<
|
||||||
|
<<
|
||||||
|
|
||||||
|
{$(COMPATDIR)}.c{$(TMP_DIR)}.obj::
|
||||||
|
$(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ @<<
|
||||||
|
$<
|
||||||
|
<<
|
||||||
|
|
||||||
|
{$(WINDIR)}.rc{$(TMP_DIR)}.res:
|
||||||
|
$(rc32) -fo $@ -r -i "$(GENERICDIR)" -D__WIN32__ \
|
||||||
|
!if $(DEBUG)
|
||||||
|
-d DEBUG \
|
||||||
|
!endif
|
||||||
|
!if $(TCL_THREADS)
|
||||||
|
-d TCL_THREADS \
|
||||||
|
!endif
|
||||||
|
!if $(STATIC_BUILD)
|
||||||
|
-d STATIC_BUILD \
|
||||||
|
!endif
|
||||||
|
$<
|
||||||
|
|
||||||
|
.SUFFIXES:
|
||||||
|
.SUFFIXES:.c .rc
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Installation. (EDIT)
|
||||||
|
#
|
||||||
|
# You may need to modify this section to reflect the final distribution
|
||||||
|
# of your files and possibly to generate documentation.
|
||||||
|
#
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
install-binaries:
|
||||||
|
@echo Installing binaries to '$(SCRIPT_INSTALL_DIR)'
|
||||||
|
@if not exist "$(SCRIPT_INSTALL_DIR)" mkdir "$(SCRIPT_INSTALL_DIR)"
|
||||||
|
@$(CPY) $(PRJLIB) "$(SCRIPT_INSTALL_DIR)" >NUL
|
||||||
|
|
||||||
|
install-libraries:
|
||||||
|
@echo Installing libraries to '$(SCRIPT_INSTALL_DIR)'
|
||||||
|
@if exist $(LIBDIR) $(CPY) $(LIBDIR)\*.tcl "$(SCRIPT_INSTALL_DIR)"
|
||||||
|
@echo Installing package index in '$(SCRIPT_INSTALL_DIR)'
|
||||||
|
@type << >"$(SCRIPT_INSTALL_DIR)\pkgIndex.tcl"
|
||||||
|
package ifneeded $(PROJECT) $(DOTVERSION) \
|
||||||
|
[list load [file join $$dir $(PRJLIBNAME)] sqlite3]
|
||||||
|
<<
|
||||||
|
|
||||||
|
install-docs:
|
||||||
|
@echo Installing documentation files to '$(DOC_INSTALL_DIR)'
|
||||||
|
@if exist $(DOCDIR) $(CPY) $(DOCDIR)\*.n "$(DOC_INSTALL_DIR)"
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Clean up
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@if exist $(TMP_DIR)\nul $(RMDIR) $(TMP_DIR)
|
||||||
|
@if exist $(WINDIR)\version.vc del $(WINDIR)\version.vc
|
||||||
|
|
||||||
|
realclean: clean
|
||||||
|
@if exist $(OUT_DIR)\nul $(RMDIR) $(OUT_DIR)
|
||||||
|
|
||||||
|
distclean: realclean
|
||||||
|
@if exist $(WINDIR)\nmakehlp.exe del $(WINDIR)\nmakehlp.exe
|
||||||
|
@if exist $(WINDIR)\nmakehlp.obj del $(WINDIR)\nmakehlp.obj
|
694
autoconf/tea/win/nmakehlp.c
Normal file
694
autoconf/tea/win/nmakehlp.c
Normal file
@ -0,0 +1,694 @@
|
|||||||
|
/*
|
||||||
|
* ----------------------------------------------------------------------------
|
||||||
|
* nmakehlp.c --
|
||||||
|
*
|
||||||
|
* This is used to fix limitations within nmake and the environment.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2002 by David Gravereaux.
|
||||||
|
* Copyright (c) 2006 by Pat Thoyts
|
||||||
|
*
|
||||||
|
* See the file "license.terms" for information on usage and redistribution of
|
||||||
|
* this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
* ----------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define _CRT_SECURE_NO_DEPRECATE
|
||||||
|
#include <windows.h>
|
||||||
|
#define NO_SHLWAPI_GDI
|
||||||
|
#define NO_SHLWAPI_STREAM
|
||||||
|
#define NO_SHLWAPI_REG
|
||||||
|
#include <shlwapi.h>
|
||||||
|
#pragma comment (lib, "user32.lib")
|
||||||
|
#pragma comment (lib, "kernel32.lib")
|
||||||
|
#pragma comment (lib, "shlwapi.lib")
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This library is required for x64 builds with _some_ versions of MSVC
|
||||||
|
*/
|
||||||
|
#if defined(_M_IA64) || defined(_M_AMD64)
|
||||||
|
#if _MSC_VER >= 1400 && _MSC_VER < 1500
|
||||||
|
#pragma comment(lib, "bufferoverflowU")
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* ISO hack for dumb VC++ */
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* protos */
|
||||||
|
|
||||||
|
static int CheckForCompilerFeature(const char *option);
|
||||||
|
static int CheckForLinkerFeature(const char *option);
|
||||||
|
static int IsIn(const char *string, const char *substring);
|
||||||
|
static int SubstituteFile(const char *substs, const char *filename);
|
||||||
|
static int QualifyPath(const char *path);
|
||||||
|
static const char *GetVersionFromFile(const char *filename, const char *match);
|
||||||
|
static DWORD WINAPI ReadFromPipe(LPVOID args);
|
||||||
|
|
||||||
|
/* globals */
|
||||||
|
|
||||||
|
#define CHUNK 25
|
||||||
|
#define STATICBUFFERSIZE 1000
|
||||||
|
typedef struct {
|
||||||
|
HANDLE pipe;
|
||||||
|
char buffer[STATICBUFFERSIZE];
|
||||||
|
} pipeinfo;
|
||||||
|
|
||||||
|
pipeinfo Out = {INVALID_HANDLE_VALUE, '\0'};
|
||||||
|
pipeinfo Err = {INVALID_HANDLE_VALUE, '\0'};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* exitcodes: 0 == no, 1 == yes, 2 == error
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
main(
|
||||||
|
int argc,
|
||||||
|
char *argv[])
|
||||||
|
{
|
||||||
|
char msg[300];
|
||||||
|
DWORD dwWritten;
|
||||||
|
int chars;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Make sure children (cl.exe and link.exe) are kept quiet.
|
||||||
|
*/
|
||||||
|
|
||||||
|
SetErrorMode(SEM_FAILCRITICALERRORS | SEM_NOOPENFILEERRORBOX);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Make sure the compiler and linker aren't effected by the outside world.
|
||||||
|
*/
|
||||||
|
|
||||||
|
SetEnvironmentVariable("CL", "");
|
||||||
|
SetEnvironmentVariable("LINK", "");
|
||||||
|
|
||||||
|
if (argc > 1 && *argv[1] == '-') {
|
||||||
|
switch (*(argv[1]+1)) {
|
||||||
|
case 'c':
|
||||||
|
if (argc != 3) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -c <compiler option>\n"
|
||||||
|
"Tests for whether cl.exe supports an option\n"
|
||||||
|
"exitcodes: 0 == no, 1 == yes, 2 == error\n", argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
return CheckForCompilerFeature(argv[2]);
|
||||||
|
case 'l':
|
||||||
|
if (argc != 3) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -l <linker option>\n"
|
||||||
|
"Tests for whether link.exe supports an option\n"
|
||||||
|
"exitcodes: 0 == no, 1 == yes, 2 == error\n", argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
return CheckForLinkerFeature(argv[2]);
|
||||||
|
case 'f':
|
||||||
|
if (argc == 2) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -f <string> <substring>\n"
|
||||||
|
"Find a substring within another\n"
|
||||||
|
"exitcodes: 0 == no, 1 == yes, 2 == error\n", argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
} else if (argc == 3) {
|
||||||
|
/*
|
||||||
|
* If the string is blank, there is no match.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return IsIn(argv[2], argv[3]);
|
||||||
|
}
|
||||||
|
case 's':
|
||||||
|
if (argc == 2) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -s <substitutions file> <file>\n"
|
||||||
|
"Perform a set of string map type substutitions on a file\n"
|
||||||
|
"exitcodes: 0\n",
|
||||||
|
argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
return SubstituteFile(argv[2], argv[3]);
|
||||||
|
case 'V':
|
||||||
|
if (argc != 4) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -V filename matchstring\n"
|
||||||
|
"Extract a version from a file:\n"
|
||||||
|
"eg: pkgIndex.tcl \"package ifneeded http\"",
|
||||||
|
argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
printf("%s\n", GetVersionFromFile(argv[2], argv[3]));
|
||||||
|
return 0;
|
||||||
|
case 'Q':
|
||||||
|
if (argc != 3) {
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -Q path\n"
|
||||||
|
"Emit the fully qualified path\n"
|
||||||
|
"exitcodes: 0 == no, 1 == yes, 2 == error\n", argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars,
|
||||||
|
&dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
return QualifyPath(argv[2]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"usage: %s -c|-f|-l|-Q|-s|-V ...\n"
|
||||||
|
"This is a little helper app to equalize shell differences between WinNT and\n"
|
||||||
|
"Win9x and get nmake.exe to accomplish its job.\n",
|
||||||
|
argv[0]);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, chars, &dwWritten, NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
CheckForCompilerFeature(
|
||||||
|
const char *option)
|
||||||
|
{
|
||||||
|
STARTUPINFO si;
|
||||||
|
PROCESS_INFORMATION pi;
|
||||||
|
SECURITY_ATTRIBUTES sa;
|
||||||
|
DWORD threadID;
|
||||||
|
char msg[300];
|
||||||
|
BOOL ok;
|
||||||
|
HANDLE hProcess, h, pipeThreads[2];
|
||||||
|
char cmdline[100];
|
||||||
|
|
||||||
|
hProcess = GetCurrentProcess();
|
||||||
|
|
||||||
|
ZeroMemory(&pi, sizeof(PROCESS_INFORMATION));
|
||||||
|
ZeroMemory(&si, sizeof(STARTUPINFO));
|
||||||
|
si.cb = sizeof(STARTUPINFO);
|
||||||
|
si.dwFlags = STARTF_USESTDHANDLES;
|
||||||
|
si.hStdInput = INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
|
ZeroMemory(&sa, sizeof(SECURITY_ATTRIBUTES));
|
||||||
|
sa.nLength = sizeof(SECURITY_ATTRIBUTES);
|
||||||
|
sa.lpSecurityDescriptor = NULL;
|
||||||
|
sa.bInheritHandle = FALSE;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a non-inheritible pipe.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CreatePipe(&Out.pipe, &h, &sa, 0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Dupe the write side, make it inheritible, and close the original.
|
||||||
|
*/
|
||||||
|
|
||||||
|
DuplicateHandle(hProcess, h, hProcess, &si.hStdOutput, 0, TRUE,
|
||||||
|
DUPLICATE_SAME_ACCESS | DUPLICATE_CLOSE_SOURCE);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Same as above, but for the error side.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CreatePipe(&Err.pipe, &h, &sa, 0);
|
||||||
|
DuplicateHandle(hProcess, h, hProcess, &si.hStdError, 0, TRUE,
|
||||||
|
DUPLICATE_SAME_ACCESS | DUPLICATE_CLOSE_SOURCE);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Base command line.
|
||||||
|
*/
|
||||||
|
|
||||||
|
lstrcpy(cmdline, "cl.exe -nologo -c -TC -Zs -X -Fp.\\_junk.pch ");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Append our option for testing
|
||||||
|
*/
|
||||||
|
|
||||||
|
lstrcat(cmdline, option);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Filename to compile, which exists, but is nothing and empty.
|
||||||
|
*/
|
||||||
|
|
||||||
|
lstrcat(cmdline, " .\\nul");
|
||||||
|
|
||||||
|
ok = CreateProcess(
|
||||||
|
NULL, /* Module name. */
|
||||||
|
cmdline, /* Command line. */
|
||||||
|
NULL, /* Process handle not inheritable. */
|
||||||
|
NULL, /* Thread handle not inheritable. */
|
||||||
|
TRUE, /* yes, inherit handles. */
|
||||||
|
DETACHED_PROCESS, /* No console for you. */
|
||||||
|
NULL, /* Use parent's environment block. */
|
||||||
|
NULL, /* Use parent's starting directory. */
|
||||||
|
&si, /* Pointer to STARTUPINFO structure. */
|
||||||
|
&pi); /* Pointer to PROCESS_INFORMATION structure. */
|
||||||
|
|
||||||
|
if (!ok) {
|
||||||
|
DWORD err = GetLastError();
|
||||||
|
int chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"Tried to launch: \"%s\", but got error [%u]: ", cmdline, err);
|
||||||
|
|
||||||
|
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM|FORMAT_MESSAGE_IGNORE_INSERTS|
|
||||||
|
FORMAT_MESSAGE_MAX_WIDTH_MASK, 0L, err, 0, (LPVOID)&msg[chars],
|
||||||
|
(300-chars), 0);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, lstrlen(msg), &err,NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Close our references to the write handles that have now been inherited.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CloseHandle(si.hStdOutput);
|
||||||
|
CloseHandle(si.hStdError);
|
||||||
|
|
||||||
|
WaitForInputIdle(pi.hProcess, 5000);
|
||||||
|
CloseHandle(pi.hThread);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Start the pipe reader threads.
|
||||||
|
*/
|
||||||
|
|
||||||
|
pipeThreads[0] = CreateThread(NULL, 0, ReadFromPipe, &Out, 0, &threadID);
|
||||||
|
pipeThreads[1] = CreateThread(NULL, 0, ReadFromPipe, &Err, 0, &threadID);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Block waiting for the process to end.
|
||||||
|
*/
|
||||||
|
|
||||||
|
WaitForSingleObject(pi.hProcess, INFINITE);
|
||||||
|
CloseHandle(pi.hProcess);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Wait for our pipe to get done reading, should it be a little slow.
|
||||||
|
*/
|
||||||
|
|
||||||
|
WaitForMultipleObjects(2, pipeThreads, TRUE, 500);
|
||||||
|
CloseHandle(pipeThreads[0]);
|
||||||
|
CloseHandle(pipeThreads[1]);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Look for the commandline warning code in both streams.
|
||||||
|
* - in MSVC 6 & 7 we get D4002, in MSVC 8 we get D9002.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return !(strstr(Out.buffer, "D4002") != NULL
|
||||||
|
|| strstr(Err.buffer, "D4002") != NULL
|
||||||
|
|| strstr(Out.buffer, "D9002") != NULL
|
||||||
|
|| strstr(Err.buffer, "D9002") != NULL
|
||||||
|
|| strstr(Out.buffer, "D2021") != NULL
|
||||||
|
|| strstr(Err.buffer, "D2021") != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
CheckForLinkerFeature(
|
||||||
|
const char *option)
|
||||||
|
{
|
||||||
|
STARTUPINFO si;
|
||||||
|
PROCESS_INFORMATION pi;
|
||||||
|
SECURITY_ATTRIBUTES sa;
|
||||||
|
DWORD threadID;
|
||||||
|
char msg[300];
|
||||||
|
BOOL ok;
|
||||||
|
HANDLE hProcess, h, pipeThreads[2];
|
||||||
|
char cmdline[100];
|
||||||
|
|
||||||
|
hProcess = GetCurrentProcess();
|
||||||
|
|
||||||
|
ZeroMemory(&pi, sizeof(PROCESS_INFORMATION));
|
||||||
|
ZeroMemory(&si, sizeof(STARTUPINFO));
|
||||||
|
si.cb = sizeof(STARTUPINFO);
|
||||||
|
si.dwFlags = STARTF_USESTDHANDLES;
|
||||||
|
si.hStdInput = INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
|
ZeroMemory(&sa, sizeof(SECURITY_ATTRIBUTES));
|
||||||
|
sa.nLength = sizeof(SECURITY_ATTRIBUTES);
|
||||||
|
sa.lpSecurityDescriptor = NULL;
|
||||||
|
sa.bInheritHandle = TRUE;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a non-inheritible pipe.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CreatePipe(&Out.pipe, &h, &sa, 0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Dupe the write side, make it inheritible, and close the original.
|
||||||
|
*/
|
||||||
|
|
||||||
|
DuplicateHandle(hProcess, h, hProcess, &si.hStdOutput, 0, TRUE,
|
||||||
|
DUPLICATE_SAME_ACCESS | DUPLICATE_CLOSE_SOURCE);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Same as above, but for the error side.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CreatePipe(&Err.pipe, &h, &sa, 0);
|
||||||
|
DuplicateHandle(hProcess, h, hProcess, &si.hStdError, 0, TRUE,
|
||||||
|
DUPLICATE_SAME_ACCESS | DUPLICATE_CLOSE_SOURCE);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Base command line.
|
||||||
|
*/
|
||||||
|
|
||||||
|
lstrcpy(cmdline, "link.exe -nologo ");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Append our option for testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
lstrcat(cmdline, option);
|
||||||
|
|
||||||
|
ok = CreateProcess(
|
||||||
|
NULL, /* Module name. */
|
||||||
|
cmdline, /* Command line. */
|
||||||
|
NULL, /* Process handle not inheritable. */
|
||||||
|
NULL, /* Thread handle not inheritable. */
|
||||||
|
TRUE, /* yes, inherit handles. */
|
||||||
|
DETACHED_PROCESS, /* No console for you. */
|
||||||
|
NULL, /* Use parent's environment block. */
|
||||||
|
NULL, /* Use parent's starting directory. */
|
||||||
|
&si, /* Pointer to STARTUPINFO structure. */
|
||||||
|
&pi); /* Pointer to PROCESS_INFORMATION structure. */
|
||||||
|
|
||||||
|
if (!ok) {
|
||||||
|
DWORD err = GetLastError();
|
||||||
|
int chars = snprintf(msg, sizeof(msg) - 1,
|
||||||
|
"Tried to launch: \"%s\", but got error [%u]: ", cmdline, err);
|
||||||
|
|
||||||
|
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM|FORMAT_MESSAGE_IGNORE_INSERTS|
|
||||||
|
FORMAT_MESSAGE_MAX_WIDTH_MASK, 0L, err, 0, (LPVOID)&msg[chars],
|
||||||
|
(300-chars), 0);
|
||||||
|
WriteFile(GetStdHandle(STD_ERROR_HANDLE), msg, lstrlen(msg), &err,NULL);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Close our references to the write handles that have now been inherited.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CloseHandle(si.hStdOutput);
|
||||||
|
CloseHandle(si.hStdError);
|
||||||
|
|
||||||
|
WaitForInputIdle(pi.hProcess, 5000);
|
||||||
|
CloseHandle(pi.hThread);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Start the pipe reader threads.
|
||||||
|
*/
|
||||||
|
|
||||||
|
pipeThreads[0] = CreateThread(NULL, 0, ReadFromPipe, &Out, 0, &threadID);
|
||||||
|
pipeThreads[1] = CreateThread(NULL, 0, ReadFromPipe, &Err, 0, &threadID);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Block waiting for the process to end.
|
||||||
|
*/
|
||||||
|
|
||||||
|
WaitForSingleObject(pi.hProcess, INFINITE);
|
||||||
|
CloseHandle(pi.hProcess);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Wait for our pipe to get done reading, should it be a little slow.
|
||||||
|
*/
|
||||||
|
|
||||||
|
WaitForMultipleObjects(2, pipeThreads, TRUE, 500);
|
||||||
|
CloseHandle(pipeThreads[0]);
|
||||||
|
CloseHandle(pipeThreads[1]);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Look for the commandline warning code in the stderr stream.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return !(strstr(Out.buffer, "LNK1117") != NULL ||
|
||||||
|
strstr(Err.buffer, "LNK1117") != NULL ||
|
||||||
|
strstr(Out.buffer, "LNK4044") != NULL ||
|
||||||
|
strstr(Err.buffer, "LNK4044") != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static DWORD WINAPI
|
||||||
|
ReadFromPipe(
|
||||||
|
LPVOID args)
|
||||||
|
{
|
||||||
|
pipeinfo *pi = (pipeinfo *) args;
|
||||||
|
char *lastBuf = pi->buffer;
|
||||||
|
DWORD dwRead;
|
||||||
|
BOOL ok;
|
||||||
|
|
||||||
|
again:
|
||||||
|
if (lastBuf - pi->buffer + CHUNK > STATICBUFFERSIZE) {
|
||||||
|
CloseHandle(pi->pipe);
|
||||||
|
return (DWORD)-1;
|
||||||
|
}
|
||||||
|
ok = ReadFile(pi->pipe, lastBuf, CHUNK, &dwRead, 0L);
|
||||||
|
if (!ok || dwRead == 0) {
|
||||||
|
CloseHandle(pi->pipe);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
lastBuf += dwRead;
|
||||||
|
goto again;
|
||||||
|
|
||||||
|
return 0; /* makes the compiler happy */
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
IsIn(
|
||||||
|
const char *string,
|
||||||
|
const char *substring)
|
||||||
|
{
|
||||||
|
return (strstr(string, substring) != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* GetVersionFromFile --
|
||||||
|
* Looks for a match string in a file and then returns the version
|
||||||
|
* following the match where a version is anything acceptable to
|
||||||
|
* package provide or package ifneeded.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
GetVersionFromFile(
|
||||||
|
const char *filename,
|
||||||
|
const char *match)
|
||||||
|
{
|
||||||
|
size_t cbBuffer = 100;
|
||||||
|
static char szBuffer[100];
|
||||||
|
char *szResult = NULL;
|
||||||
|
FILE *fp = fopen(filename, "rt");
|
||||||
|
|
||||||
|
if (fp != NULL) {
|
||||||
|
/*
|
||||||
|
* Read data until we see our match string.
|
||||||
|
*/
|
||||||
|
|
||||||
|
while (fgets(szBuffer, cbBuffer, fp) != NULL) {
|
||||||
|
LPSTR p, q;
|
||||||
|
|
||||||
|
p = strstr(szBuffer, match);
|
||||||
|
if (p != NULL) {
|
||||||
|
/*
|
||||||
|
* Skip to first digit.
|
||||||
|
*/
|
||||||
|
|
||||||
|
while (*p && !isdigit(*p)) {
|
||||||
|
++p;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Find ending whitespace.
|
||||||
|
*/
|
||||||
|
|
||||||
|
q = p;
|
||||||
|
while (*q && (isalnum(*q) || *q == '.')) {
|
||||||
|
++q;
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(szBuffer, p, q - p);
|
||||||
|
szBuffer[q-p] = 0;
|
||||||
|
szResult = szBuffer;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(fp);
|
||||||
|
}
|
||||||
|
return szResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List helpers for the SubstituteFile function
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct list_item_t {
|
||||||
|
struct list_item_t *nextPtr;
|
||||||
|
char * key;
|
||||||
|
char * value;
|
||||||
|
} list_item_t;
|
||||||
|
|
||||||
|
/* insert a list item into the list (list may be null) */
|
||||||
|
static list_item_t *
|
||||||
|
list_insert(list_item_t **listPtrPtr, const char *key, const char *value)
|
||||||
|
{
|
||||||
|
list_item_t *itemPtr = malloc(sizeof(list_item_t));
|
||||||
|
if (itemPtr) {
|
||||||
|
itemPtr->key = strdup(key);
|
||||||
|
itemPtr->value = strdup(value);
|
||||||
|
itemPtr->nextPtr = NULL;
|
||||||
|
|
||||||
|
while(*listPtrPtr) {
|
||||||
|
listPtrPtr = &(*listPtrPtr)->nextPtr;
|
||||||
|
}
|
||||||
|
*listPtrPtr = itemPtr;
|
||||||
|
}
|
||||||
|
return itemPtr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
list_free(list_item_t **listPtrPtr)
|
||||||
|
{
|
||||||
|
list_item_t *tmpPtr, *listPtr = *listPtrPtr;
|
||||||
|
while (listPtr) {
|
||||||
|
tmpPtr = listPtr;
|
||||||
|
listPtr = listPtr->nextPtr;
|
||||||
|
free(tmpPtr->key);
|
||||||
|
free(tmpPtr->value);
|
||||||
|
free(tmpPtr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SubstituteFile --
|
||||||
|
* As windows doesn't provide anything useful like sed and it's unreliable
|
||||||
|
* to use the tclsh you are building against (consider x-platform builds -
|
||||||
|
* eg compiling AMD64 target from IX86) we provide a simple substitution
|
||||||
|
* option here to handle autoconf style substitutions.
|
||||||
|
* The substitution file is whitespace and line delimited. The file should
|
||||||
|
* consist of lines matching the regular expression:
|
||||||
|
* \s*\S+\s+\S*$
|
||||||
|
*
|
||||||
|
* Usage is something like:
|
||||||
|
* nmakehlp -S << $** > $@
|
||||||
|
* @PACKAGE_NAME@ $(PACKAGE_NAME)
|
||||||
|
* @PACKAGE_VERSION@ $(PACKAGE_VERSION)
|
||||||
|
* <<
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int
|
||||||
|
SubstituteFile(
|
||||||
|
const char *substitutions,
|
||||||
|
const char *filename)
|
||||||
|
{
|
||||||
|
size_t cbBuffer = 1024;
|
||||||
|
static char szBuffer[1024], szCopy[1024];
|
||||||
|
char *szResult = NULL;
|
||||||
|
list_item_t *substPtr = NULL;
|
||||||
|
FILE *fp, *sp;
|
||||||
|
|
||||||
|
fp = fopen(filename, "rt");
|
||||||
|
if (fp != NULL) {
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Build a list of substutitions from the first filename
|
||||||
|
*/
|
||||||
|
|
||||||
|
sp = fopen(substitutions, "rt");
|
||||||
|
if (sp != NULL) {
|
||||||
|
while (fgets(szBuffer, cbBuffer, sp) != NULL) {
|
||||||
|
char *ks, *ke, *vs, *ve;
|
||||||
|
ks = szBuffer;
|
||||||
|
while (ks && *ks && isspace(*ks)) ++ks;
|
||||||
|
ke = ks;
|
||||||
|
while (ke && *ke && !isspace(*ke)) ++ke;
|
||||||
|
vs = ke;
|
||||||
|
while (vs && *vs && isspace(*vs)) ++vs;
|
||||||
|
ve = vs;
|
||||||
|
while (ve && *ve && !(*ve == '\r' || *ve == '\n')) ++ve;
|
||||||
|
*ke = 0, *ve = 0;
|
||||||
|
list_insert(&substPtr, ks, vs);
|
||||||
|
}
|
||||||
|
fclose(sp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* debug: dump the list */
|
||||||
|
#ifdef _DEBUG
|
||||||
|
{
|
||||||
|
int n = 0;
|
||||||
|
list_item_t *p = NULL;
|
||||||
|
for (p = substPtr; p != NULL; p = p->nextPtr, ++n) {
|
||||||
|
fprintf(stderr, "% 3d '%s' => '%s'\n", n, p->key, p->value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Run the substitutions over each line of the input
|
||||||
|
*/
|
||||||
|
|
||||||
|
while (fgets(szBuffer, cbBuffer, fp) != NULL) {
|
||||||
|
list_item_t *p = NULL;
|
||||||
|
for (p = substPtr; p != NULL; p = p->nextPtr) {
|
||||||
|
char *m = strstr(szBuffer, p->key);
|
||||||
|
if (m) {
|
||||||
|
char *cp, *op, *sp;
|
||||||
|
cp = szCopy;
|
||||||
|
op = szBuffer;
|
||||||
|
while (op != m) *cp++ = *op++;
|
||||||
|
sp = p->value;
|
||||||
|
while (sp && *sp) *cp++ = *sp++;
|
||||||
|
op += strlen(p->key);
|
||||||
|
while (*op) *cp++ = *op++;
|
||||||
|
*cp = 0;
|
||||||
|
memcpy(szBuffer, szCopy, sizeof(szCopy));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf(szBuffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
list_free(&substPtr);
|
||||||
|
}
|
||||||
|
fclose(fp);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QualifyPath --
|
||||||
|
*
|
||||||
|
* This composes the current working directory with a provided path
|
||||||
|
* and returns the fully qualified and normalized path.
|
||||||
|
* Mostly needed to setup paths for testing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int
|
||||||
|
QualifyPath(
|
||||||
|
const char *szPath)
|
||||||
|
{
|
||||||
|
char szCwd[MAX_PATH + 1];
|
||||||
|
char szTmp[MAX_PATH + 1];
|
||||||
|
char *p;
|
||||||
|
GetCurrentDirectory(MAX_PATH, szCwd);
|
||||||
|
while ((p = strchr(szPath, '/')) && *p)
|
||||||
|
*p = '\\';
|
||||||
|
PathCombine(szTmp, szCwd, szPath);
|
||||||
|
PathCanonicalize(szCwd, szTmp);
|
||||||
|
printf("%s\n", szCwd);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Local variables:
|
||||||
|
* mode: c
|
||||||
|
* c-basic-offset: 4
|
||||||
|
* fill-column: 78
|
||||||
|
* indent-tabs-mode: t
|
||||||
|
* tab-width: 8
|
||||||
|
* End:
|
||||||
|
*/
|
711
autoconf/tea/win/rules.vc
Normal file
711
autoconf/tea/win/rules.vc
Normal file
@ -0,0 +1,711 @@
|
|||||||
|
#------------------------------------------------------------------------------
|
||||||
|
# rules.vc --
|
||||||
|
#
|
||||||
|
# Microsoft Visual C++ makefile include for decoding the commandline
|
||||||
|
# macros. This file does not need editing to build Tcl.
|
||||||
|
#
|
||||||
|
# See the file "license.terms" for information on usage and redistribution
|
||||||
|
# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
#
|
||||||
|
# Copyright (c) 2001-2003 David Gravereaux.
|
||||||
|
# Copyright (c) 2003-2008 Patrick Thoyts
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
!ifndef _RULES_VC
|
||||||
|
_RULES_VC = 1
|
||||||
|
|
||||||
|
cc32 = $(CC) # built-in default.
|
||||||
|
link32 = link
|
||||||
|
lib32 = lib
|
||||||
|
rc32 = $(RC) # built-in default.
|
||||||
|
|
||||||
|
!ifndef INSTALLDIR
|
||||||
|
### Assume the normal default.
|
||||||
|
_INSTALLDIR = C:\Program Files\Tcl
|
||||||
|
!else
|
||||||
|
### Fix the path separators.
|
||||||
|
_INSTALLDIR = $(INSTALLDIR:/=\)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Set the proper copy method to avoid overwrite questions
|
||||||
|
# to the user when copying files and selecting the right
|
||||||
|
# "delete all" method.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(OS)" == "Windows_NT"
|
||||||
|
RMDIR = rmdir /S /Q
|
||||||
|
ERRNULL = 2>NUL
|
||||||
|
!if ![ver | find "4.0" > nul]
|
||||||
|
CPY = echo y | xcopy /i >NUL
|
||||||
|
COPY = copy >NUL
|
||||||
|
!else
|
||||||
|
CPY = xcopy /i /y >NUL
|
||||||
|
COPY = copy /y >NUL
|
||||||
|
!endif
|
||||||
|
!else # "$(OS)" != "Windows_NT"
|
||||||
|
CPY = xcopy /i >_JUNK.OUT # On Win98 NUL does not work here.
|
||||||
|
COPY = copy >_JUNK.OUT # On Win98 NUL does not work here.
|
||||||
|
RMDIR = deltree /Y
|
||||||
|
NULL = \NUL # Used in testing directory existence
|
||||||
|
ERRNULL = >NUL # Win9x shell cannot redirect stderr
|
||||||
|
!endif
|
||||||
|
MKDIR = mkdir
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
# Determine the host and target architectures and compiler version.
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
_HASH=^#
|
||||||
|
_VC_MANIFEST_EMBED_EXE=
|
||||||
|
_VC_MANIFEST_EMBED_DLL=
|
||||||
|
VCVER=0
|
||||||
|
!if ![echo VCVERSION=_MSC_VER > vercl.x] \
|
||||||
|
&& ![echo $(_HASH)if defined(_M_IX86) >> vercl.x] \
|
||||||
|
&& ![echo ARCH=IX86 >> vercl.x] \
|
||||||
|
&& ![echo $(_HASH)elif defined(_M_AMD64) >> vercl.x] \
|
||||||
|
&& ![echo ARCH=AMD64 >> vercl.x] \
|
||||||
|
&& ![echo $(_HASH)endif >> vercl.x] \
|
||||||
|
&& ![cl -nologo -TC -P vercl.x $(ERRNULL)]
|
||||||
|
!include vercl.i
|
||||||
|
!if ![echo VCVER= ^\> vercl.vc] \
|
||||||
|
&& ![set /a $(VCVERSION) / 100 - 6 >> vercl.vc]
|
||||||
|
!include vercl.vc
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
!if ![del $(ERRNUL) /q/f vercl.x vercl.i vercl.vc]
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if ![reg query HKLM\Hardware\Description\System\CentralProcessor\0 /v Identifier | findstr /i x86]
|
||||||
|
NATIVE_ARCH=IX86
|
||||||
|
!else
|
||||||
|
NATIVE_ARCH=AMD64
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# Since MSVC8 we must deal with manifest resources.
|
||||||
|
!if $(VCVERSION) >= 1400
|
||||||
|
_VC_MANIFEST_EMBED_EXE=if exist $@.manifest mt -nologo -manifest $@.manifest -outputresource:$@;1
|
||||||
|
_VC_MANIFEST_EMBED_DLL=if exist $@.manifest mt -nologo -manifest $@.manifest -outputresource:$@;2
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifndef MACHINE
|
||||||
|
MACHINE=$(ARCH)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifndef CFG_ENCODING
|
||||||
|
CFG_ENCODING = \"cp1252\"
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!message ===============================================================================
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# build the helper app we need to overcome nmake's limiting
|
||||||
|
# environment.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if !exist(nmakehlp.exe)
|
||||||
|
!if [$(cc32) -nologo nmakehlp.c -link -subsystem:console > nul]
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Test for compiler features
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
### test for optimizations
|
||||||
|
!if [nmakehlp -c -Ot]
|
||||||
|
!message *** Compiler has 'Optimizations'
|
||||||
|
OPTIMIZING = 1
|
||||||
|
!else
|
||||||
|
!message *** Compiler does not have 'Optimizations'
|
||||||
|
OPTIMIZING = 0
|
||||||
|
!endif
|
||||||
|
|
||||||
|
OPTIMIZATIONS =
|
||||||
|
|
||||||
|
!if [nmakehlp -c -Ot]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -Ot
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -Oi]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -Oi
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -Op]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -Op
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -fp:strict]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -fp:strict
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -Gs]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -Gs
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -GS]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -GS
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if [nmakehlp -c -GL]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -GL
|
||||||
|
!endif
|
||||||
|
|
||||||
|
DEBUGFLAGS =
|
||||||
|
|
||||||
|
!if [nmakehlp -c -RTC1]
|
||||||
|
DEBUGFLAGS = $(DEBUGFLAGS) -RTC1
|
||||||
|
!elseif [nmakehlp -c -GZ]
|
||||||
|
DEBUGFLAGS = $(DEBUGFLAGS) -GZ
|
||||||
|
!endif
|
||||||
|
|
||||||
|
COMPILERFLAGS =-W3 -DUNICODE -D_UNICODE
|
||||||
|
|
||||||
|
# In v13 -GL and -YX are incompatible.
|
||||||
|
!if [nmakehlp -c -YX]
|
||||||
|
!if ![nmakehlp -c -GL]
|
||||||
|
OPTIMIZATIONS = $(OPTIMIZATIONS) -YX
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if "$(MACHINE)" == "IX86"
|
||||||
|
### test for pentium errata
|
||||||
|
!if [nmakehlp -c -QI0f]
|
||||||
|
!message *** Compiler has 'Pentium 0x0f fix'
|
||||||
|
COMPILERFLAGS = $(COMPILERFLAGS) -QI0f
|
||||||
|
!else
|
||||||
|
!message *** Compiler does not have 'Pentium 0x0f fix'
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if "$(MACHINE)" == "IA64"
|
||||||
|
### test for Itanium errata
|
||||||
|
!if [nmakehlp -c -QIA64_Bx]
|
||||||
|
!message *** Compiler has 'B-stepping errata workarounds'
|
||||||
|
COMPILERFLAGS = $(COMPILERFLAGS) -QIA64_Bx
|
||||||
|
!else
|
||||||
|
!message *** Compiler does not have 'B-stepping errata workarounds'
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if "$(MACHINE)" == "IX86"
|
||||||
|
### test for -align:4096, when align:512 will do.
|
||||||
|
!if [nmakehlp -l -opt:nowin98]
|
||||||
|
!message *** Linker has 'Win98 alignment problem'
|
||||||
|
ALIGN98_HACK = 1
|
||||||
|
!else
|
||||||
|
!message *** Linker does not have 'Win98 alignment problem'
|
||||||
|
ALIGN98_HACK = 0
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
ALIGN98_HACK = 0
|
||||||
|
!endif
|
||||||
|
|
||||||
|
LINKERFLAGS =
|
||||||
|
|
||||||
|
!if [nmakehlp -l -ltcg]
|
||||||
|
LINKERFLAGS =-ltcg
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Decode the options requested.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(OPTS)" == "" || [nmakehlp -f "$(OPTS)" "none"]
|
||||||
|
STATIC_BUILD = 0
|
||||||
|
TCL_THREADS = 1
|
||||||
|
DEBUG = 0
|
||||||
|
SYMBOLS = 0
|
||||||
|
PROFILE = 0
|
||||||
|
PGO = 0
|
||||||
|
MSVCRT = 0
|
||||||
|
LOIMPACT = 0
|
||||||
|
TCL_USE_STATIC_PACKAGES = 0
|
||||||
|
USE_THREAD_ALLOC = 1
|
||||||
|
UNCHECKED = 0
|
||||||
|
!else
|
||||||
|
!if [nmakehlp -f $(OPTS) "static"]
|
||||||
|
!message *** Doing static
|
||||||
|
STATIC_BUILD = 1
|
||||||
|
!else
|
||||||
|
STATIC_BUILD = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "msvcrt"]
|
||||||
|
!message *** Doing msvcrt
|
||||||
|
MSVCRT = 1
|
||||||
|
!else
|
||||||
|
MSVCRT = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "staticpkg"]
|
||||||
|
!message *** Doing staticpkg
|
||||||
|
TCL_USE_STATIC_PACKAGES = 1
|
||||||
|
!else
|
||||||
|
TCL_USE_STATIC_PACKAGES = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "nothreads"]
|
||||||
|
!message *** Compile explicitly for non-threaded tcl
|
||||||
|
TCL_THREADS = 0
|
||||||
|
!else
|
||||||
|
TCL_THREADS = 1
|
||||||
|
USE_THREAD_ALLOC= 1
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "symbols"]
|
||||||
|
!message *** Doing symbols
|
||||||
|
DEBUG = 1
|
||||||
|
!else
|
||||||
|
DEBUG = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "pdbs"]
|
||||||
|
!message *** Doing pdbs
|
||||||
|
SYMBOLS = 1
|
||||||
|
!else
|
||||||
|
SYMBOLS = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "profile"]
|
||||||
|
!message *** Doing profile
|
||||||
|
PROFILE = 1
|
||||||
|
!else
|
||||||
|
PROFILE = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "pgi"]
|
||||||
|
!message *** Doing profile guided optimization instrumentation
|
||||||
|
PGO = 1
|
||||||
|
!elseif [nmakehlp -f $(OPTS) "pgo"]
|
||||||
|
!message *** Doing profile guided optimization
|
||||||
|
PGO = 2
|
||||||
|
!else
|
||||||
|
PGO = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "loimpact"]
|
||||||
|
!message *** Doing loimpact
|
||||||
|
LOIMPACT = 1
|
||||||
|
!else
|
||||||
|
LOIMPACT = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "thrdalloc"]
|
||||||
|
!message *** Doing thrdalloc
|
||||||
|
USE_THREAD_ALLOC = 1
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "tclalloc"]
|
||||||
|
!message *** Doing tclalloc
|
||||||
|
USE_THREAD_ALLOC = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(OPTS) "unchecked"]
|
||||||
|
!message *** Doing unchecked
|
||||||
|
UNCHECKED = 1
|
||||||
|
!else
|
||||||
|
UNCHECKED = 0
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
|
||||||
|
!if !$(STATIC_BUILD)
|
||||||
|
# Make sure we don't build overly fat DLLs.
|
||||||
|
MSVCRT = 1
|
||||||
|
# We shouldn't statically put the extensions inside the shell when dynamic.
|
||||||
|
TCL_USE_STATIC_PACKAGES = 0
|
||||||
|
!endif
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Figure-out how to name our intermediate and output directories.
|
||||||
|
# We wouldn't want different builds to use the same .obj files
|
||||||
|
# by accident.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
#----------------------------------------
|
||||||
|
# Naming convention:
|
||||||
|
# t = full thread support.
|
||||||
|
# s = static library (as opposed to an
|
||||||
|
# import library)
|
||||||
|
# g = linked to the debug enabled C
|
||||||
|
# run-time.
|
||||||
|
# x = special static build when it
|
||||||
|
# links to the dynamic C run-time.
|
||||||
|
#----------------------------------------
|
||||||
|
SUFX = tsgx
|
||||||
|
|
||||||
|
!if $(DEBUG)
|
||||||
|
BUILDDIRTOP = Debug
|
||||||
|
!else
|
||||||
|
BUILDDIRTOP = Release
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if "$(MACHINE)" != "IX86"
|
||||||
|
BUILDDIRTOP =$(BUILDDIRTOP)_$(MACHINE)
|
||||||
|
!endif
|
||||||
|
!if $(VCVER) > 6
|
||||||
|
BUILDDIRTOP =$(BUILDDIRTOP)_VC$(VCVER)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$(DEBUG) || $(DEBUG) && $(UNCHECKED)
|
||||||
|
SUFX = $(SUFX:g=)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
TMP_DIRFULL = .\$(BUILDDIRTOP)\$(PROJECT)_ThreadedDynamicStaticX
|
||||||
|
|
||||||
|
!if !$(STATIC_BUILD)
|
||||||
|
TMP_DIRFULL = $(TMP_DIRFULL:Static=)
|
||||||
|
SUFX = $(SUFX:s=)
|
||||||
|
EXT = dll
|
||||||
|
!if $(MSVCRT)
|
||||||
|
TMP_DIRFULL = $(TMP_DIRFULL:X=)
|
||||||
|
SUFX = $(SUFX:x=)
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
TMP_DIRFULL = $(TMP_DIRFULL:Dynamic=)
|
||||||
|
EXT = lib
|
||||||
|
!if !$(MSVCRT)
|
||||||
|
TMP_DIRFULL = $(TMP_DIRFULL:X=)
|
||||||
|
SUFX = $(SUFX:x=)
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$(TCL_THREADS)
|
||||||
|
TMP_DIRFULL = $(TMP_DIRFULL:Threaded=)
|
||||||
|
SUFX = $(SUFX:t=)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifndef TMP_DIR
|
||||||
|
TMP_DIR = $(TMP_DIRFULL)
|
||||||
|
!ifndef OUT_DIR
|
||||||
|
OUT_DIR = .\$(BUILDDIRTOP)
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
!ifndef OUT_DIR
|
||||||
|
OUT_DIR = $(TMP_DIR)
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Decode the statistics requested.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(STATS)" == "" || [nmakehlp -f "$(STATS)" "none"]
|
||||||
|
TCL_MEM_DEBUG = 0
|
||||||
|
TCL_COMPILE_DEBUG = 0
|
||||||
|
!else
|
||||||
|
!if [nmakehlp -f $(STATS) "memdbg"]
|
||||||
|
!message *** Doing memdbg
|
||||||
|
TCL_MEM_DEBUG = 1
|
||||||
|
!else
|
||||||
|
TCL_MEM_DEBUG = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(STATS) "compdbg"]
|
||||||
|
!message *** Doing compdbg
|
||||||
|
TCL_COMPILE_DEBUG = 1
|
||||||
|
!else
|
||||||
|
TCL_COMPILE_DEBUG = 0
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Decode the checks requested.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(CHECKS)" == "" || [nmakehlp -f "$(CHECKS)" "none"]
|
||||||
|
TCL_NO_DEPRECATED = 0
|
||||||
|
WARNINGS = -W3
|
||||||
|
!else
|
||||||
|
!if [nmakehlp -f $(CHECKS) "nodep"]
|
||||||
|
!message *** Doing nodep check
|
||||||
|
TCL_NO_DEPRECATED = 1
|
||||||
|
!else
|
||||||
|
TCL_NO_DEPRECATED = 0
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(CHECKS) "fullwarn"]
|
||||||
|
!message *** Doing full warnings check
|
||||||
|
WARNINGS = -W4
|
||||||
|
!if [nmakehlp -l -warn:3]
|
||||||
|
LINKERFLAGS = $(LINKERFLAGS) -warn:3
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
WARNINGS = -W3
|
||||||
|
!endif
|
||||||
|
!if [nmakehlp -f $(CHECKS) "64bit"] && [nmakehlp -c -Wp64]
|
||||||
|
!message *** Doing 64bit portability warnings
|
||||||
|
WARNINGS = $(WARNINGS) -Wp64
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $(PGO) > 1
|
||||||
|
!if [nmakehlp -l -ltcg:pgoptimize]
|
||||||
|
LINKERFLAGS = $(LINKERFLAGS:-ltcg=) -ltcg:pgoptimize
|
||||||
|
!else
|
||||||
|
MSG=^
|
||||||
|
This compiler does not support profile guided optimization.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
!elseif $(PGO) > 0
|
||||||
|
!if [nmakehlp -l -ltcg:pginstrument]
|
||||||
|
LINKERFLAGS = $(LINKERFLAGS:-ltcg=) -ltcg:pginstrument
|
||||||
|
!else
|
||||||
|
MSG=^
|
||||||
|
This compiler does not support profile guided optimization.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Set our defines now armed with our options.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
OPTDEFINES = -DTCL_CFGVAL_ENCODING=$(CFG_ENCODING) -DSTDC_HEADERS
|
||||||
|
|
||||||
|
!if $(TCL_MEM_DEBUG)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_MEM_DEBUG
|
||||||
|
!endif
|
||||||
|
!if $(TCL_COMPILE_DEBUG)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_COMPILE_DEBUG -DTCL_COMPILE_STATS
|
||||||
|
!endif
|
||||||
|
!if $(TCL_THREADS)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_THREADS=1
|
||||||
|
!if $(USE_THREAD_ALLOC)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DUSE_THREAD_ALLOC=1
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
!if $(STATIC_BUILD)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DSTATIC_BUILD
|
||||||
|
!endif
|
||||||
|
!if $(TCL_NO_DEPRECATED)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_NO_DEPRECATED
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !$(DEBUG)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DNDEBUG
|
||||||
|
!if $(OPTIMIZING)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_CFG_OPTIMIZED
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
!if $(PROFILE)
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_CFG_PROFILED
|
||||||
|
!endif
|
||||||
|
!if "$(MACHINE)" == "IA64" || "$(MACHINE)" == "AMD64"
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DTCL_CFG_DO64BIT
|
||||||
|
!endif
|
||||||
|
!if $(VCVERSION) < 1300
|
||||||
|
OPTDEFINES = $(OPTDEFINES) -DNO_STRTOI64
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Locate the Tcl headers to build against
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(PROJECT)" == "tcl"
|
||||||
|
|
||||||
|
_TCL_H = ..\generic\tcl.h
|
||||||
|
|
||||||
|
!else
|
||||||
|
|
||||||
|
# If INSTALLDIR set to tcl root dir then reset to the lib dir.
|
||||||
|
!if exist("$(_INSTALLDIR)\include\tcl.h")
|
||||||
|
_INSTALLDIR=$(_INSTALLDIR)\lib
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if !defined(TCLDIR)
|
||||||
|
!if exist("$(_INSTALLDIR)\..\include\tcl.h")
|
||||||
|
TCLINSTALL = 1
|
||||||
|
_TCLDIR = $(_INSTALLDIR)\..
|
||||||
|
_TCL_H = $(_INSTALLDIR)\..\include\tcl.h
|
||||||
|
TCLDIR = $(_INSTALLDIR)\..
|
||||||
|
!else
|
||||||
|
MSG=^
|
||||||
|
Failed to find tcl.h. Set the TCLDIR macro.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
_TCLDIR = $(TCLDIR:/=\)
|
||||||
|
!if exist("$(_TCLDIR)\include\tcl.h")
|
||||||
|
TCLINSTALL = 1
|
||||||
|
_TCL_H = $(_TCLDIR)\include\tcl.h
|
||||||
|
!elseif exist("$(_TCLDIR)\generic\tcl.h")
|
||||||
|
TCLINSTALL = 0
|
||||||
|
_TCL_H = $(_TCLDIR)\generic\tcl.h
|
||||||
|
!else
|
||||||
|
MSG =^
|
||||||
|
Failed to find tcl.h. The TCLDIR macro does not appear correct.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#--------------------------------------------------------------
|
||||||
|
# Extract various version numbers from tcl headers
|
||||||
|
# The generated file is then included in the makefile.
|
||||||
|
#--------------------------------------------------------------
|
||||||
|
|
||||||
|
!if [echo REM = This file is generated from rules.vc > versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo TCL_MAJOR_VERSION = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V "$(_TCL_H)" TCL_MAJOR_VERSION >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo TCL_MINOR_VERSION = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V "$(_TCL_H)" TCL_MINOR_VERSION >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo TCL_PATCH_LEVEL = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V "$(_TCL_H)" TCL_PATCH_LEVEL >> versions.vc]
|
||||||
|
!endif
|
||||||
|
|
||||||
|
# If building the tcl core then we need additional package versions
|
||||||
|
!if "$(PROJECT)" == "tcl"
|
||||||
|
!if [echo PKG_HTTP_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\http\pkgIndex.tcl http >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_TCLTEST_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\tcltest\pkgIndex.tcl tcltest >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_MSGCAT_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\msgcat\pkgIndex.tcl msgcat >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_PLATFORM_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\platform\pkgIndex.tcl "platform " >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_SHELL_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\platform\pkgIndex.tcl "platform::shell" >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_DDE_VER = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\dde\pkgIndex.tcl "dde " >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo PKG_REG_VER =\>> versions.vc] \
|
||||||
|
&& [nmakehlp -V ..\library\reg\pkgIndex.tcl registry >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!include versions.vc
|
||||||
|
|
||||||
|
#--------------------------------------------------------------
|
||||||
|
# Setup tcl version dependent stuff headers
|
||||||
|
#--------------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(PROJECT)" != "tcl"
|
||||||
|
|
||||||
|
TCL_VERSION = $(TCL_MAJOR_VERSION)$(TCL_MINOR_VERSION)
|
||||||
|
|
||||||
|
!if $(TCL_VERSION) < 81
|
||||||
|
TCL_DOES_STUBS = 0
|
||||||
|
!else
|
||||||
|
TCL_DOES_STUBS = 1
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $(TCLINSTALL)
|
||||||
|
TCLSH = "$(_TCLDIR)\bin\tclsh$(TCL_VERSION)$(SUFX).exe"
|
||||||
|
!if !exist($(TCLSH)) && $(TCL_THREADS)
|
||||||
|
TCLSH = "$(_TCLDIR)\bin\tclsh$(TCL_VERSION)t$(SUFX).exe"
|
||||||
|
!endif
|
||||||
|
TCLSTUBLIB = "$(_TCLDIR)\lib\tclstub$(TCL_VERSION).lib"
|
||||||
|
TCLIMPLIB = "$(_TCLDIR)\lib\tcl$(TCL_VERSION)$(SUFX).lib"
|
||||||
|
TCL_LIBRARY = $(_TCLDIR)\lib
|
||||||
|
TCLREGLIB = "$(_TCLDIR)\lib\tclreg13$(SUFX:t=).lib"
|
||||||
|
TCLDDELIB = "$(_TCLDIR)\lib\tcldde14$(SUFX:t=).lib"
|
||||||
|
COFFBASE = \must\have\tcl\sources\to\build\this\target
|
||||||
|
TCLTOOLSDIR = \must\have\tcl\sources\to\build\this\target
|
||||||
|
TCL_INCLUDES = -I"$(_TCLDIR)\include"
|
||||||
|
!else
|
||||||
|
TCLSH = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tclsh$(TCL_VERSION)$(SUFX).exe"
|
||||||
|
!if !exist($(TCLSH)) && $(TCL_THREADS)
|
||||||
|
TCLSH = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tclsh$(TCL_VERSION)t$(SUFX).exe"
|
||||||
|
!endif
|
||||||
|
TCLSTUBLIB = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tclstub$(TCL_VERSION).lib"
|
||||||
|
TCLIMPLIB = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tcl$(TCL_VERSION)$(SUFX).lib"
|
||||||
|
TCL_LIBRARY = $(_TCLDIR)\library
|
||||||
|
TCLREGLIB = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tclreg13$(SUFX:t=).lib"
|
||||||
|
TCLDDELIB = "$(_TCLDIR)\win\$(BUILDDIRTOP)\tcldde14$(SUFX:t=).lib"
|
||||||
|
COFFBASE = "$(_TCLDIR)\win\coffbase.txt"
|
||||||
|
TCLTOOLSDIR = $(_TCLDIR)\tools
|
||||||
|
TCL_INCLUDES = -I"$(_TCLDIR)\generic" -I"$(_TCLDIR)\win"
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# Locate the Tk headers to build against
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if "$(PROJECT)" == "tk"
|
||||||
|
_TK_H = ..\generic\tk.h
|
||||||
|
_INSTALLDIR = $(_INSTALLDIR)\..
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef PROJECT_REQUIRES_TK
|
||||||
|
!if !defined(TKDIR)
|
||||||
|
!if exist("$(_INSTALLDIR)\..\include\tk.h")
|
||||||
|
TKINSTALL = 1
|
||||||
|
_TKDIR = $(_INSTALLDIR)\..
|
||||||
|
_TK_H = $(_TKDIR)\include\tk.h
|
||||||
|
TKDIR = $(_TKDIR)
|
||||||
|
!elseif exist("$(_TCLDIR)\include\tk.h")
|
||||||
|
TKINSTALL = 1
|
||||||
|
_TKDIR = $(_TCLDIR)
|
||||||
|
_TK_H = $(_TKDIR)\include\tk.h
|
||||||
|
TKDIR = $(_TKDIR)
|
||||||
|
!endif
|
||||||
|
!else
|
||||||
|
_TKDIR = $(TKDIR:/=\)
|
||||||
|
!if exist("$(_TKDIR)\include\tk.h")
|
||||||
|
TKINSTALL = 1
|
||||||
|
_TK_H = $(_TKDIR)\include\tk.h
|
||||||
|
!elseif exist("$(_TKDIR)\generic\tk.h")
|
||||||
|
TKINSTALL = 0
|
||||||
|
_TK_H = $(_TKDIR)\generic\tk.h
|
||||||
|
!else
|
||||||
|
MSG =^
|
||||||
|
Failed to find tk.h. The TKDIR macro does not appear correct.
|
||||||
|
!error $(MSG)
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# Extract Tk version numbers
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
!if defined(PROJECT_REQUIRES_TK) || "$(PROJECT)" == "tk"
|
||||||
|
|
||||||
|
!if [echo TK_MAJOR_VERSION = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V $(_TK_H) TK_MAJOR_VERSION >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo TK_MINOR_VERSION = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V $(_TK_H) TK_MINOR_VERSION >> versions.vc]
|
||||||
|
!endif
|
||||||
|
!if [echo TK_PATCH_LEVEL = \>> versions.vc] \
|
||||||
|
&& [nmakehlp -V $(_TK_H) TK_PATCH_LEVEL >> versions.vc]
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!include versions.vc
|
||||||
|
|
||||||
|
TK_DOTVERSION = $(TK_MAJOR_VERSION).$(TK_MINOR_VERSION)
|
||||||
|
TK_VERSION = $(TK_MAJOR_VERSION)$(TK_MINOR_VERSION)
|
||||||
|
|
||||||
|
!if "$(PROJECT)" != "tk"
|
||||||
|
!if $(TKINSTALL)
|
||||||
|
WISH = "$(_TKDIR)\bin\wish$(TK_VERSION)$(SUFX).exe"
|
||||||
|
TKSTUBLIB = "$(_TKDIR)\lib\tkstub$(TK_VERSION).lib"
|
||||||
|
TKIMPLIB = "$(_TKDIR)\lib\tk$(TK_VERSION)$(SUFX).lib"
|
||||||
|
TK_INCLUDES = -I"$(_TKDIR)\include"
|
||||||
|
!else
|
||||||
|
WISH = "$(_TKDIR)\win\$(BUILDDIRTOP)\wish$(TCL_VERSION)$(SUFX).exe"
|
||||||
|
TKSTUBLIB = "$(_TKDIR)\win\$(BUILDDIRTOP)\tkstub$(TCL_VERSION).lib"
|
||||||
|
TKIMPLIB = "$(_TKDIR)\win\$(BUILDDIRTOP)\tk$(TCL_VERSION)$(SUFX).lib"
|
||||||
|
TK_INCLUDES = -I"$(_TKDIR)\generic" -I"$(_TKDIR)\win" -I"$(_TKDIR)\xlib"
|
||||||
|
!endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
||||||
|
#----------------------------------------------------------
|
||||||
|
# Display stats being used.
|
||||||
|
#----------------------------------------------------------
|
||||||
|
|
||||||
|
!message *** Intermediate directory will be '$(TMP_DIR)'
|
||||||
|
!message *** Output directory will be '$(OUT_DIR)'
|
||||||
|
!message *** Suffix for binaries will be '$(SUFX)'
|
||||||
|
!message *** Optional defines are '$(OPTDEFINES)'
|
||||||
|
!message *** Compiler version $(VCVER). Target machine is $(MACHINE)
|
||||||
|
!message *** Host architecture is $(NATIVE_ARCH)
|
||||||
|
!message *** Compiler options '$(COMPILERFLAGS) $(OPTIMIZATIONS) $(DEBUGFLAGS) $(WARNINGS)'
|
||||||
|
!message *** Link options '$(LINKERFLAGS)'
|
||||||
|
|
||||||
|
!endif
|
||||||
|
|
@ -2984,11 +2984,7 @@ static int fts3FilterMethod(
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = sqlite3Fts3ReadLock(p);
|
|
||||||
if( rc!=SQLITE_OK ) return rc;
|
|
||||||
|
|
||||||
rc = fts3EvalStart(pCsr);
|
rc = fts3EvalStart(pCsr);
|
||||||
|
|
||||||
sqlite3Fts3SegmentsClose(p);
|
sqlite3Fts3SegmentsClose(p);
|
||||||
if( rc!=SQLITE_OK ) return rc;
|
if( rc!=SQLITE_OK ) return rc;
|
||||||
pCsr->pNextId = pCsr->aDoclist;
|
pCsr->pNextId = pCsr->aDoclist;
|
||||||
|
@ -489,37 +489,30 @@ static void fts3SqlExec(
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** This function ensures that the caller has obtained a shared-cache
|
** This function ensures that the caller has obtained an exclusive
|
||||||
** table-lock on the %_content table. This is required before reading
|
** shared-cache table-lock on the %_segdir table. This is required before
|
||||||
** data from the fts3 table. If this lock is not acquired first, then
|
** writing data to the fts3 table. If this lock is not acquired first, then
|
||||||
** the caller may end up holding read-locks on the %_segments and %_segdir
|
** the caller may end up attempting to take this lock as part of committing
|
||||||
** tables, but no read-lock on the %_content table. If this happens
|
** a transaction, causing SQLite to return SQLITE_LOCKED or
|
||||||
** a second connection will be able to write to the fts3 table, but
|
** LOCKED_SHAREDCACHEto a COMMIT command.
|
||||||
** attempting to commit those writes might return SQLITE_LOCKED or
|
|
||||||
** SQLITE_LOCKED_SHAREDCACHE (because the commit attempts to obtain
|
|
||||||
** write-locks on the %_segments and %_segdir ** tables).
|
|
||||||
**
|
**
|
||||||
** We try to avoid this because if FTS3 returns any error when committing
|
** It is best to avoid this because if FTS3 returns any error when
|
||||||
** a transaction, the whole transaction will be rolled back. And this is
|
** committing a transaction, the whole transaction will be rolled back.
|
||||||
** not what users expect when they get SQLITE_LOCKED_SHAREDCACHE. It can
|
** And this is not what users expect when they get SQLITE_LOCKED_SHAREDCACHE.
|
||||||
** still happen if the user reads data directly from the %_segments or
|
** It can still happen if the user locks the underlying tables directly
|
||||||
** %_segdir tables instead of going through FTS3 though.
|
** instead of accessing them via FTS.
|
||||||
**
|
|
||||||
** This reasoning does not apply to a content=xxx table.
|
|
||||||
*/
|
*/
|
||||||
int sqlite3Fts3ReadLock(Fts3Table *p){
|
static int fts3Writelock(Fts3Table *p){
|
||||||
int rc; /* Return code */
|
int rc = SQLITE_OK;
|
||||||
sqlite3_stmt *pStmt; /* Statement used to obtain lock */
|
|
||||||
|
if( p->nPendingData==0 ){
|
||||||
if( p->zContentTbl==0 ){
|
sqlite3_stmt *pStmt;
|
||||||
rc = fts3SqlStmt(p, SQL_SELECT_CONTENT_BY_ROWID, &pStmt, 0);
|
rc = fts3SqlStmt(p, SQL_DELETE_SEGDIR_LEVEL, &pStmt, 0);
|
||||||
if( rc==SQLITE_OK ){
|
if( rc==SQLITE_OK ){
|
||||||
sqlite3_bind_null(pStmt, 1);
|
sqlite3_bind_null(pStmt, 1);
|
||||||
sqlite3_step(pStmt);
|
sqlite3_step(pStmt);
|
||||||
rc = sqlite3_reset(pStmt);
|
rc = sqlite3_reset(pStmt);
|
||||||
}
|
}
|
||||||
}else{
|
|
||||||
rc = SQLITE_OK;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
@ -5297,6 +5290,9 @@ int sqlite3Fts3UpdateMethod(
|
|||||||
aSzIns = &aSzDel[p->nColumn+1];
|
aSzIns = &aSzDel[p->nColumn+1];
|
||||||
memset(aSzDel, 0, sizeof(aSzDel[0])*(p->nColumn+1)*2);
|
memset(aSzDel, 0, sizeof(aSzDel[0])*(p->nColumn+1)*2);
|
||||||
|
|
||||||
|
rc = fts3Writelock(p);
|
||||||
|
if( rc!=SQLITE_OK ) goto update_out;
|
||||||
|
|
||||||
/* If this is an INSERT operation, or an UPDATE that modifies the rowid
|
/* If this is an INSERT operation, or an UPDATE that modifies the rowid
|
||||||
** value, then this operation requires constraint handling.
|
** value, then this operation requires constraint handling.
|
||||||
**
|
**
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
** * Implementations of the SQL scalar upper() and lower() functions
|
** * Implementations of the SQL scalar upper() and lower() functions
|
||||||
** for case mapping.
|
** for case mapping.
|
||||||
**
|
**
|
||||||
** * Integration of ICU and SQLite collation seqences.
|
** * Integration of ICU and SQLite collation sequences.
|
||||||
**
|
**
|
||||||
** * An implementation of the LIKE operator that uses ICU to
|
** * An implementation of the LIKE operator that uses ICU to
|
||||||
** provide case-independent matching.
|
** provide case-independent matching.
|
||||||
|
219
ext/misc/percentile.c
Normal file
219
ext/misc/percentile.c
Normal file
@ -0,0 +1,219 @@
|
|||||||
|
/*
|
||||||
|
** 2013-05-28
|
||||||
|
**
|
||||||
|
** The author disclaims copyright to this source code. In place of
|
||||||
|
** a legal notice, here is a blessing:
|
||||||
|
**
|
||||||
|
** May you do good and not evil.
|
||||||
|
** May you find forgiveness for yourself and forgive others.
|
||||||
|
** May you share freely, never taking more than you give.
|
||||||
|
**
|
||||||
|
******************************************************************************
|
||||||
|
**
|
||||||
|
** This file contains code to implement the percentile(Y,P) SQL function
|
||||||
|
** as described below:
|
||||||
|
**
|
||||||
|
** (1) The percentile(Y,P) function is an aggregate function taking
|
||||||
|
** exactly two arguments.
|
||||||
|
**
|
||||||
|
** (2) If the P argument to percentile(Y,P) is not the same for every
|
||||||
|
** row in the aggregate then an error is thrown. The word "same"
|
||||||
|
** in the previous sentence means that the value differ by less
|
||||||
|
** than 0.001.
|
||||||
|
**
|
||||||
|
** (3) If the P argument to percentile(Y,P) evaluates to anything other
|
||||||
|
** than a number in the range of 0.0 to 100.0 inclusive then an
|
||||||
|
** error is thrown.
|
||||||
|
**
|
||||||
|
** (4) If any Y argument to percentile(Y,P) evaluates to a value that
|
||||||
|
** is not NULL and is not numeric then an error is thrown.
|
||||||
|
**
|
||||||
|
** (5) If any Y argument to percentile(Y,P) evaluates to plus or minus
|
||||||
|
** infinity then an error is thrown. (SQLite always interprets NaN
|
||||||
|
** values as NULL.)
|
||||||
|
**
|
||||||
|
** (6) Both Y and P in percentile(Y,P) can be arbitrary expressions,
|
||||||
|
** including CASE WHEN expressions.
|
||||||
|
**
|
||||||
|
** (7) The percentile(Y,P) aggregate is able to handle inputs of at least
|
||||||
|
** one million (1,000,000) rows.
|
||||||
|
**
|
||||||
|
** (8) If there are no non-NULL values for Y, then percentile(Y,P)
|
||||||
|
** returns NULL.
|
||||||
|
**
|
||||||
|
** (9) If there is exactly one non-NULL value for Y, the percentile(Y,P)
|
||||||
|
** returns the one Y value.
|
||||||
|
**
|
||||||
|
** (10) If there N non-NULL values of Y where N is two or more and
|
||||||
|
** the Y values are ordered from least to greatest and a graph is
|
||||||
|
** drawn from 0 to N-1 such that the height of the graph at J is
|
||||||
|
** the J-th Y value and such that straight lines are drawn between
|
||||||
|
** adjacent Y values, then the percentile(Y,P) function returns
|
||||||
|
** the height of the graph at P*(N-1)/100.
|
||||||
|
**
|
||||||
|
** (11) The percentile(Y,P) function always returns either a floating
|
||||||
|
** point number or NULL.
|
||||||
|
**
|
||||||
|
** (12) The percentile(Y,P) is implemented as a single C99 source-code
|
||||||
|
** file that compiles into a shared-library or DLL that can be loaded
|
||||||
|
** into SQLite using the sqlite3_load_extension() interface.
|
||||||
|
*/
|
||||||
|
#include "sqlite3ext.h"
|
||||||
|
SQLITE_EXTENSION_INIT1
|
||||||
|
#include <assert.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
/* The following object is the session context for a single percentile()
|
||||||
|
** function. We have to remember all input Y values until the very end.
|
||||||
|
** Those values are accumulated in the Percentile.a[] array.
|
||||||
|
*/
|
||||||
|
typedef struct Percentile Percentile;
|
||||||
|
struct Percentile {
|
||||||
|
unsigned nAlloc; /* Number of slots allocated for a[] */
|
||||||
|
unsigned nUsed; /* Number of slots actually used in a[] */
|
||||||
|
double rPct; /* 1.0 more than the value for P */
|
||||||
|
double *a; /* Array of Y values */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Return TRUE if the input floating-point number is an infinity.
|
||||||
|
*/
|
||||||
|
static int isInfinity(double r){
|
||||||
|
sqlite3_uint64 u;
|
||||||
|
assert( sizeof(u)==sizeof(r) );
|
||||||
|
memcpy(&u, &r, sizeof(u));
|
||||||
|
return ((u>>52)&0x7ff)==0x7ff;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Return TRUE if two doubles differ by 0.001 or less
|
||||||
|
*/
|
||||||
|
static int sameValue(double a, double b){
|
||||||
|
a -= b;
|
||||||
|
return a>=-0.001 && a<=0.001;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** The "step" function for percentile(Y,P) is called once for each
|
||||||
|
** input row.
|
||||||
|
*/
|
||||||
|
static void percentStep(sqlite3_context *pCtx, int argc, sqlite3_value **argv){
|
||||||
|
Percentile *p;
|
||||||
|
double rPct;
|
||||||
|
int eType;
|
||||||
|
double y;
|
||||||
|
assert( argc==2 );
|
||||||
|
|
||||||
|
/* Requirement 3: P must be a number between 0 and 100 */
|
||||||
|
eType = sqlite3_value_numeric_type(argv[1]);
|
||||||
|
rPct = sqlite3_value_double(argv[1]);
|
||||||
|
if( (eType!=SQLITE_INTEGER && eType!=SQLITE_FLOAT) ||
|
||||||
|
((rPct = sqlite3_value_double(argv[1]))<0.0 || rPct>100.0) ){
|
||||||
|
sqlite3_result_error(pCtx, "2nd argument to percentile() is not "
|
||||||
|
"a number between 0.0 and 100.0", -1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Allocate the session context. */
|
||||||
|
p = (Percentile*)sqlite3_aggregate_context(pCtx, sizeof(*p));
|
||||||
|
if( p==0 ) return;
|
||||||
|
|
||||||
|
/* Remember the P value. Throw an error if the P value is different
|
||||||
|
** from any prior row, per Requirement (2). */
|
||||||
|
if( p->rPct==0.0 ){
|
||||||
|
p->rPct = rPct+1.0;
|
||||||
|
}else if( !sameValue(p->rPct,rPct+1.0) ){
|
||||||
|
sqlite3_result_error(pCtx, "2nd argument to percentile() is not the "
|
||||||
|
"same for all input rows", -1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Ignore rows for which Y is NULL */
|
||||||
|
eType = sqlite3_value_type(argv[0]);
|
||||||
|
if( eType==SQLITE_NULL ) return;
|
||||||
|
|
||||||
|
/* If not NULL, then Y must be numeric. Otherwise throw an error.
|
||||||
|
** Requirement 4 */
|
||||||
|
if( eType!=SQLITE_INTEGER && eType!=SQLITE_FLOAT ){
|
||||||
|
sqlite3_result_error(pCtx, "1st argument to percentile() is not "
|
||||||
|
"numeric", -1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Throw an error if the Y value is infinity or NaN */
|
||||||
|
y = sqlite3_value_double(argv[0]);
|
||||||
|
if( isInfinity(y) ){
|
||||||
|
sqlite3_result_error(pCtx, "Inf input to percentile()", -1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Allocate and store the Y */
|
||||||
|
if( p->nUsed>=p->nAlloc ){
|
||||||
|
unsigned n = p->nAlloc*2 + 250;
|
||||||
|
double *a = sqlite3_realloc(p->a, sizeof(double)*n);
|
||||||
|
if( a==0 ){
|
||||||
|
sqlite3_free(p->a);
|
||||||
|
memset(p, 0, sizeof(*p));
|
||||||
|
sqlite3_result_error_nomem(pCtx);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
p->nAlloc = n;
|
||||||
|
p->a = a;
|
||||||
|
}
|
||||||
|
p->a[p->nUsed++] = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Compare to doubles for sorting using qsort()
|
||||||
|
*/
|
||||||
|
static int doubleCmp(const void *pA, const void *pB){
|
||||||
|
double a = *(double*)pA;
|
||||||
|
double b = *(double*)pB;
|
||||||
|
if( a==b ) return 0;
|
||||||
|
if( a<b ) return -1;
|
||||||
|
return +1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Called to compute the final output of percentile() and to clean
|
||||||
|
** up all allocated memory.
|
||||||
|
*/
|
||||||
|
static void percentFinal(sqlite3_context *pCtx){
|
||||||
|
Percentile *p;
|
||||||
|
unsigned i1, i2;
|
||||||
|
double v1, v2;
|
||||||
|
double ix, vx;
|
||||||
|
p = (Percentile*)sqlite3_aggregate_context(pCtx, 0);
|
||||||
|
if( p==0 ) return;
|
||||||
|
if( p->a==0 ) return;
|
||||||
|
if( p->nUsed ){
|
||||||
|
qsort(p->a, p->nUsed, sizeof(double), doubleCmp);
|
||||||
|
ix = (p->rPct-1.0)*(p->nUsed-1)*0.01;
|
||||||
|
i1 = ix;
|
||||||
|
i2 = ix==(double)i1 || i1==p->nUsed-1 ? i1 : i1+1;
|
||||||
|
v1 = p->a[i1];
|
||||||
|
v2 = p->a[i2];
|
||||||
|
vx = v1 + (v2-v1)*(ix-i1);
|
||||||
|
sqlite3_result_double(pCtx, vx);
|
||||||
|
}
|
||||||
|
sqlite3_free(p->a);
|
||||||
|
memset(p, 0, sizeof(*p));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
__declspec(dllexport)
|
||||||
|
#endif
|
||||||
|
int sqlite3_percentile_init(
|
||||||
|
sqlite3 *db,
|
||||||
|
char **pzErrMsg,
|
||||||
|
const sqlite3_api_routines *pApi
|
||||||
|
){
|
||||||
|
int rc = SQLITE_OK;
|
||||||
|
SQLITE_EXTENSION_INIT2(pApi);
|
||||||
|
(void)pzErrMsg; /* Unused parameter */
|
||||||
|
rc = sqlite3_create_function(db, "percentile", 2, SQLITE_UTF8, 0,
|
||||||
|
0, percentStep, percentFinal);
|
||||||
|
return rc;
|
||||||
|
}
|
6
main.mk
6
main.mk
@ -275,6 +275,7 @@ TESTSRC += \
|
|||||||
$(TOP)/ext/misc/fuzzer.c \
|
$(TOP)/ext/misc/fuzzer.c \
|
||||||
$(TOP)/ext/misc/ieee754.c \
|
$(TOP)/ext/misc/ieee754.c \
|
||||||
$(TOP)/ext/misc/nextchar.c \
|
$(TOP)/ext/misc/nextchar.c \
|
||||||
|
$(TOP)/ext/misc/percentile.c \
|
||||||
$(TOP)/ext/misc/regexp.c \
|
$(TOP)/ext/misc/regexp.c \
|
||||||
$(TOP)/ext/misc/spellfix.c \
|
$(TOP)/ext/misc/spellfix.c \
|
||||||
$(TOP)/ext/misc/wholenumber.c
|
$(TOP)/ext/misc/wholenumber.c
|
||||||
@ -620,6 +621,11 @@ extensiontest: testfixture$(EXE) $(TEST_EXTENSION)
|
|||||||
checksymbols: sqlite3.o
|
checksymbols: sqlite3.o
|
||||||
nm -g --defined-only sqlite3.o | grep -v " sqlite3_" ; test $$? -ne 0
|
nm -g --defined-only sqlite3.o | grep -v " sqlite3_" ; test $$? -ne 0
|
||||||
|
|
||||||
|
# Build the amalgamation-autoconf package.
|
||||||
|
#
|
||||||
|
dist: sqlite3.c
|
||||||
|
TOP=$(TOP) sh $(TOP)/tool/mkautoconfamal.sh
|
||||||
|
|
||||||
|
|
||||||
# Standard install and cleanup targets
|
# Standard install and cleanup targets
|
||||||
#
|
#
|
||||||
|
91
manifest
91
manifest
@ -1,9 +1,9 @@
|
|||||||
C Update\sthe\sNGQP\sto\srecord\swhich\sloops\sneed\sbe\srun\sin\sreverse\sorder\sto\nsatisfy\sORDER\sBY\sclauses.
|
C Merge\srecent\strunk\schanges\sinto\sthe\sNGQP\sbranch.
|
||||||
D 2013-05-27T17:59:37.917
|
D 2013-05-30T11:48:36.654
|
||||||
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
||||||
F Makefile.in f6b58b7bdf6535f0f0620c486dd59aa4662c0b4f
|
F Makefile.in 5e41da95d92656a5004b03d3576e8b226858a28e
|
||||||
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
||||||
F Makefile.msc 5dc042f51187414d5886ac6d8308630d484690c4
|
F Makefile.msc 7d226394826f060f232c0a02a468e8651819b7c2
|
||||||
F Makefile.vxworks db21ed42a01d5740e656b16f92cb5d8d5e5dd315
|
F Makefile.vxworks db21ed42a01d5740e656b16f92cb5d8d5e5dd315
|
||||||
F README cd04a36fbc7ea56932a4052d7d0b7f09f27c33d6
|
F README cd04a36fbc7ea56932a4052d7d0b7f09f27c33d6
|
||||||
F VERSION 05c7bd63b96f31cfdef5c766ed91307ac121f5aa
|
F VERSION 05c7bd63b96f31cfdef5c766ed91307ac121f5aa
|
||||||
@ -12,6 +12,29 @@ F addopcodes.awk 17dc593f791f874d2c23a0f9360850ded0286531
|
|||||||
F art/sqlite370.eps aa97a671332b432a54e1d74ff5e8775be34200c2
|
F art/sqlite370.eps aa97a671332b432a54e1d74ff5e8775be34200c2
|
||||||
F art/sqlite370.ico af56c1d00fee7cd4753e8631ed60703ed0fc6e90
|
F art/sqlite370.ico af56c1d00fee7cd4753e8631ed60703ed0fc6e90
|
||||||
F art/sqlite370.jpg d512473dae7e378a67e28ff96a34da7cb331def2
|
F art/sqlite370.jpg d512473dae7e378a67e28ff96a34da7cb331def2
|
||||||
|
F autoconf/INSTALL 83e4a25da9fd053c7b3665eaaaf7919707915903
|
||||||
|
F autoconf/Makefile.am 8fc2972d92769cf20ab8e4a73ea901b84d69bf44
|
||||||
|
F autoconf/README 14458f1046c118efa721aadec5f227e876d3cd38
|
||||||
|
F autoconf/README.first 47dd53221023b18c836ab00dba6e00bd86132453
|
||||||
|
F autoconf/config.guess 94cc57e2a3fdb9c235b362ace86d77e89d188cad x
|
||||||
|
F autoconf/config.sub 1efb390a8fb4bfafd74783a15a8fb5311c84300e x
|
||||||
|
F autoconf/configure.ac ba3e99ba1a8171d0682b68443517088fc5d6f13a
|
||||||
|
F autoconf/depcomp 0b26f101e3bc9fd1ff0be1da9fb4a82371142f92 x
|
||||||
|
F autoconf/install-sh 06ee6336e63bb845c8439d777c32eb2eccc4fbf1 x
|
||||||
|
F autoconf/ltmain.sh 7a658a24028f02331c1d2446562758083c5eadd1
|
||||||
|
F autoconf/missing d7c9981a81af13370d4ed152b24c0a82b7028585 x
|
||||||
|
F autoconf/tea/Makefile.in 5c3b0bdfb66c20d55ebff59d1718864461570ca9
|
||||||
|
F autoconf/tea/README 3e9a3c060f29a44344ab50aec506f4db903fb873
|
||||||
|
F autoconf/tea/aclocal.m4 52c47aac44ce0ddb1f918b6993e8beb8eee88f43
|
||||||
|
F autoconf/tea/configure.in e0466b881b53f31f5a4a69e7a91ad130902fb359
|
||||||
|
F autoconf/tea/doc/sqlite3.n e268faa1691c33663d3a7faf9fa30673d14bd879
|
||||||
|
F autoconf/tea/license.terms 13bd403c9610fd2b76ece0ab50c4c5eda933d523
|
||||||
|
F autoconf/tea/pkgIndex.tcl.in 3ef61715cf1c7bdcff56947ffadb26bc991ca39d
|
||||||
|
F autoconf/tea/tclconfig/install-sh b087e5c4b92820c60bffb74acc1d9c2d40d80b8f
|
||||||
|
F autoconf/tea/tclconfig/tcl.m4 a68179d7cc45524fa59db428a36610e20bdba808
|
||||||
|
F autoconf/tea/win/makefile.vc f89d0184d0eee5f7e356ea407964dcd139939928
|
||||||
|
F autoconf/tea/win/nmakehlp.c 2070e086f39866b353a482d3a14dedaf26196506
|
||||||
|
F autoconf/tea/win/rules.vc c511f222b80064096b705dbeb97060ee1d6b6d63
|
||||||
F config.guess 226d9a188c6196f3033ffc651cbc9dcee1a42977
|
F config.guess 226d9a188c6196f3033ffc651cbc9dcee1a42977
|
||||||
F config.h.in 0921066a13130082764ab4ab6456f7b5bebe56de
|
F config.h.in 0921066a13130082764ab4ab6456f7b5bebe56de
|
||||||
F config.sub 9ebe4c3b3dab6431ece34f16828b594fb420da55
|
F config.sub 9ebe4c3b3dab6431ece34f16828b594fb420da55
|
||||||
@ -55,7 +78,7 @@ F ext/fts3/README.content fdc666a70d5257a64fee209f97cf89e0e6e32b51
|
|||||||
F ext/fts3/README.syntax a19711dc5458c20734b8e485e75fb1981ec2427a
|
F ext/fts3/README.syntax a19711dc5458c20734b8e485e75fb1981ec2427a
|
||||||
F ext/fts3/README.tokenizers e0a8b81383ea60d0334d274fadf305ea14a8c314
|
F ext/fts3/README.tokenizers e0a8b81383ea60d0334d274fadf305ea14a8c314
|
||||||
F ext/fts3/README.txt 8c18f41574404623b76917b9da66fcb0ab38328d
|
F ext/fts3/README.txt 8c18f41574404623b76917b9da66fcb0ab38328d
|
||||||
F ext/fts3/fts3.c 4bc160e6ff9ab5456b600f389f8941485ea5082f
|
F ext/fts3/fts3.c 931b3c83abdd1ab3bb389b2130431c2a9ff73b91
|
||||||
F ext/fts3/fts3.h 3a10a0af180d502cecc50df77b1b22df142817fe
|
F ext/fts3/fts3.h 3a10a0af180d502cecc50df77b1b22df142817fe
|
||||||
F ext/fts3/fts3Int.h 0b167bed9e63151635620a4f639bc62ac6012cba
|
F ext/fts3/fts3Int.h 0b167bed9e63151635620a4f639bc62ac6012cba
|
||||||
F ext/fts3/fts3_aux.c b02632f6dd0e375ce97870206d914ea6d8df5ccd
|
F ext/fts3/fts3_aux.c b02632f6dd0e375ce97870206d914ea6d8df5ccd
|
||||||
@ -73,7 +96,7 @@ F ext/fts3/fts3_tokenizer.h 64c6ef6c5272c51ebe60fc607a896e84288fcbc3
|
|||||||
F ext/fts3/fts3_tokenizer1.c 5c98225a53705e5ee34824087478cf477bdb7004
|
F ext/fts3/fts3_tokenizer1.c 5c98225a53705e5ee34824087478cf477bdb7004
|
||||||
F ext/fts3/fts3_unicode.c 92391b4b4fb043564c6539ea9b8661e3bcba47b9
|
F ext/fts3/fts3_unicode.c 92391b4b4fb043564c6539ea9b8661e3bcba47b9
|
||||||
F ext/fts3/fts3_unicode2.c a863f05f758af36777dffc2facc898bc73fec896
|
F ext/fts3/fts3_unicode2.c a863f05f758af36777dffc2facc898bc73fec896
|
||||||
F ext/fts3/fts3_write.c d92c6cbe07363791cfe8b62b4dee67e6f8afc9e2
|
F ext/fts3/fts3_write.c 6a1fc0e922e76b68e594bf7bc33bac72af9dc47b
|
||||||
F ext/fts3/fts3speed.tcl b54caf6a18d38174f1a6e84219950d85e98bb1e9
|
F ext/fts3/fts3speed.tcl b54caf6a18d38174f1a6e84219950d85e98bb1e9
|
||||||
F ext/fts3/mkfts3amal.tcl 252ecb7fe6467854f2aa237bf2c390b74e71f100
|
F ext/fts3/mkfts3amal.tcl 252ecb7fe6467854f2aa237bf2c390b74e71f100
|
||||||
F ext/fts3/tool/fts3view.c 6cfc5b67a5f0e09c0d698f9fd012c784bfaa9197
|
F ext/fts3/tool/fts3view.c 6cfc5b67a5f0e09c0d698f9fd012c784bfaa9197
|
||||||
@ -81,13 +104,14 @@ F ext/fts3/unicode/CaseFolding.txt 8c678ca52ecc95e16bc7afc2dbf6fc9ffa05db8c
|
|||||||
F ext/fts3/unicode/UnicodeData.txt cd07314edb62d49fde34debdaf92fa2aa69011e7
|
F ext/fts3/unicode/UnicodeData.txt cd07314edb62d49fde34debdaf92fa2aa69011e7
|
||||||
F ext/fts3/unicode/mkunicode.tcl 7a9bc018e2962abb79563c5a39fe581fcbf2f675
|
F ext/fts3/unicode/mkunicode.tcl 7a9bc018e2962abb79563c5a39fe581fcbf2f675
|
||||||
F ext/icu/README.txt d9fbbad0c2f647c3fdf715fc9fd64af53aedfc43
|
F ext/icu/README.txt d9fbbad0c2f647c3fdf715fc9fd64af53aedfc43
|
||||||
F ext/icu/icu.c eb9ae1d79046bd7871aa97ee6da51eb770134b5a
|
F ext/icu/icu.c 7538f98eab2854cf17fa5f7797bffa6c76e3863b
|
||||||
F ext/icu/sqliteicu.h 728867a802baa5a96de7495e9689a8e01715ef37
|
F ext/icu/sqliteicu.h 728867a802baa5a96de7495e9689a8e01715ef37
|
||||||
F ext/misc/amatch.c eae8454cd9dcb287b2a3ec2e65a865a4ac5f0d06
|
F ext/misc/amatch.c eae8454cd9dcb287b2a3ec2e65a865a4ac5f0d06
|
||||||
F ext/misc/closure.c 40788c54c59190a1f52f6492a260d8894a246fe9
|
F ext/misc/closure.c 40788c54c59190a1f52f6492a260d8894a246fe9
|
||||||
F ext/misc/fuzzer.c 51bd96960b6b077d41d6f3cedefbcb57f29efaa2
|
F ext/misc/fuzzer.c 51bd96960b6b077d41d6f3cedefbcb57f29efaa2
|
||||||
F ext/misc/ieee754.c 2565ce373d842977efe0922dc50b8a41b3289556
|
F ext/misc/ieee754.c 2565ce373d842977efe0922dc50b8a41b3289556
|
||||||
F ext/misc/nextchar.c 1131e2b36116ffc6fe6b2e3464bfdace27978b1e
|
F ext/misc/nextchar.c 1131e2b36116ffc6fe6b2e3464bfdace27978b1e
|
||||||
|
F ext/misc/percentile.c 4fb5e46c4312b0be74e8e497ac18f805f0e3e6c5
|
||||||
F ext/misc/regexp.c c25c65fe775f5d9801fb8573e36ebe73f2c0c2e0
|
F ext/misc/regexp.c c25c65fe775f5d9801fb8573e36ebe73f2c0c2e0
|
||||||
F ext/misc/rot13.c 1ac6f95f99b575907b9b09c81a349114cf9be45a
|
F ext/misc/rot13.c 1ac6f95f99b575907b9b09c81a349114cf9be45a
|
||||||
F ext/misc/spellfix.c 6d7ce6105a4b7729f6c44ccdf1ab7e80d9707c02
|
F ext/misc/spellfix.c 6d7ce6105a4b7729f6c44ccdf1ab7e80d9707c02
|
||||||
@ -114,7 +138,7 @@ F ext/rtree/viewrtree.tcl eea6224b3553599ae665b239bd827e182b466024
|
|||||||
F install-sh 9d4de14ab9fb0facae2f48780b874848cbf2f895 x
|
F install-sh 9d4de14ab9fb0facae2f48780b874848cbf2f895 x
|
||||||
F ltmain.sh 3ff0879076df340d2e23ae905484d8c15d5fdea8
|
F ltmain.sh 3ff0879076df340d2e23ae905484d8c15d5fdea8
|
||||||
F magic.txt f2b23a6bde8f1c6e86b957e4d94eab0add520b0d
|
F magic.txt f2b23a6bde8f1c6e86b957e4d94eab0add520b0d
|
||||||
F main.mk a8ebdf910e2cc10db1f9f54ec316f637458e8001
|
F main.mk e536751ac719806209c51f5dc63022a5dd40c631
|
||||||
F mkdll.sh 7d09b23c05d56532e9d44a50868eb4b12ff4f74a
|
F mkdll.sh 7d09b23c05d56532e9d44a50868eb4b12ff4f74a
|
||||||
F mkextu.sh 416f9b7089d80e5590a29692c9d9280a10dbad9f
|
F mkextu.sh 416f9b7089d80e5590a29692c9d9280a10dbad9f
|
||||||
F mkextw.sh 4123480947681d9b434a5e7b1ee08135abe409ac
|
F mkextw.sh 4123480947681d9b434a5e7b1ee08135abe409ac
|
||||||
@ -132,13 +156,13 @@ F sqlite.pc.in 42b7bf0d02e08b9e77734a47798d1a55a9e0716b
|
|||||||
F sqlite3.1 6be1ad09113570e1fc8dcaff84c9b0b337db5ffc
|
F sqlite3.1 6be1ad09113570e1fc8dcaff84c9b0b337db5ffc
|
||||||
F sqlite3.pc.in ae6f59a76e862f5c561eb32a380228a02afc3cad
|
F sqlite3.pc.in ae6f59a76e862f5c561eb32a380228a02afc3cad
|
||||||
F src/alter.c f8db986c03eb0bfb221523fc9bbb9d0b70de3168
|
F src/alter.c f8db986c03eb0bfb221523fc9bbb9d0b70de3168
|
||||||
F src/analyze.c d5f895810e8ff9737c9ec7b76abc3dcff5860335
|
F src/analyze.c 27e541b9b5b48b41eb899b22a49ff42384899151
|
||||||
F src/attach.c 1816f5a9eea8d2010fc2b22b44f0f63eb3a62704
|
F src/attach.c 1816f5a9eea8d2010fc2b22b44f0f63eb3a62704
|
||||||
F src/auth.c 523da7fb4979469955d822ff9298352d6b31de34
|
F src/auth.c 523da7fb4979469955d822ff9298352d6b31de34
|
||||||
F src/backup.c b266767351ae2d847716c56fcb2a1fea7c761c03
|
F src/backup.c b266767351ae2d847716c56fcb2a1fea7c761c03
|
||||||
F src/bitvec.c 19a4ba637bd85f8f63fc8c9bae5ade9fb05ec1cb
|
F src/bitvec.c 19a4ba637bd85f8f63fc8c9bae5ade9fb05ec1cb
|
||||||
F src/btmutex.c 976f45a12e37293e32cae0281b15a21d48a8aaa7
|
F src/btmutex.c 976f45a12e37293e32cae0281b15a21d48a8aaa7
|
||||||
F src/btree.c fcfbe61a311e54224b23527bbf7586ce320e7b40
|
F src/btree.c 7fba377c29573adfc6091832e27ee1fcbefb51d0
|
||||||
F src/btree.h 6fa8a3ff2483d0bb64a9f0105a8cedeac9e00cca
|
F src/btree.h 6fa8a3ff2483d0bb64a9f0105a8cedeac9e00cca
|
||||||
F src/btreeInt.h eecc84f02375b2bb7a44abbcbbe3747dde73edb2
|
F src/btreeInt.h eecc84f02375b2bb7a44abbcbbe3747dde73edb2
|
||||||
F src/build.c 92ef9483189389828966153c5950f2e5a49c1182
|
F src/build.c 92ef9483189389828966153c5950f2e5a49c1182
|
||||||
@ -147,10 +171,10 @@ F src/complete.c dc1d136c0feee03c2f7550bafc0d29075e36deac
|
|||||||
F src/ctime.c 4262c227bc91cecc61ae37ed3a40f08069cfa267
|
F src/ctime.c 4262c227bc91cecc61ae37ed3a40f08069cfa267
|
||||||
F src/date.c 067a81c9942c497aafd2c260e13add8a7d0c7dd4
|
F src/date.c 067a81c9942c497aafd2c260e13add8a7d0c7dd4
|
||||||
F src/delete.c aeabdabeeeaa0584127f291baa9617153d334778
|
F src/delete.c aeabdabeeeaa0584127f291baa9617153d334778
|
||||||
F src/expr.c e40d198a719aba1d2514f6e1541f9154f976ceb6
|
F src/expr.c ac9d259eea3123faa05fabe6dd8717696aca72b1
|
||||||
F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb
|
F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb
|
||||||
F src/fkey.c e16942bd5c8a868ac53287886464a5ed0e72b179
|
F src/fkey.c e16942bd5c8a868ac53287886464a5ed0e72b179
|
||||||
F src/func.c d3fdcff9274bc161152e67ed3f626841c247f4b9
|
F src/func.c 5c50c1ea31fd864b0fe921fe1a8d4c55acd609ef
|
||||||
F src/global.c 5caf4deab621abb45b4c607aad1bd21c20aac759
|
F src/global.c 5caf4deab621abb45b4c607aad1bd21c20aac759
|
||||||
F src/hash.c ac3470bbf1ca4ae4e306a8ecb0fdf1731810ffe4
|
F src/hash.c ac3470bbf1ca4ae4e306a8ecb0fdf1731810ffe4
|
||||||
F src/hash.h 8890a25af81fb85a9ad7790d32eedab4b994da22
|
F src/hash.h 8890a25af81fb85a9ad7790d32eedab4b994da22
|
||||||
@ -160,7 +184,7 @@ F src/journal.c b4124532212b6952f42eb2c12fa3c25701d8ba8d
|
|||||||
F src/legacy.c 0df0b1550b9cc1f58229644735e317ac89131f12
|
F src/legacy.c 0df0b1550b9cc1f58229644735e317ac89131f12
|
||||||
F src/lempar.c cdf0a000315332fc9b50b62f3b5e22e080a0952b
|
F src/lempar.c cdf0a000315332fc9b50b62f3b5e22e080a0952b
|
||||||
F src/loadext.c c48f7f3f170e502fe0cc20748e03c6e0b5a016c2
|
F src/loadext.c c48f7f3f170e502fe0cc20748e03c6e0b5a016c2
|
||||||
F src/main.c c6419ef57392b1aa0cf6ed9c80dfc06b153fe299
|
F src/main.c f33742ab539602cf18becc6a85ecef164706c86a
|
||||||
F src/malloc.c fe085aa851b666b7c375c1ff957643dc20a04bf6
|
F src/malloc.c fe085aa851b666b7c375c1ff957643dc20a04bf6
|
||||||
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
||||||
F src/mem1.c 437c7c4af964895d4650f29881df63535caaa1fa
|
F src/mem1.c 437c7c4af964895d4650f29881df63535caaa1fa
|
||||||
@ -179,29 +203,29 @@ F src/os.h 4a46270a64e9193af4a0aaa3bc2c66dc07c29b3f
|
|||||||
F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
|
F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
|
||||||
F src/os_unix.c 42c9b8b7c61c9fa3561258f523be5749e52ed0e0
|
F src/os_unix.c 42c9b8b7c61c9fa3561258f523be5749e52ed0e0
|
||||||
F src/os_win.c 5f018dbd4cec25c5b47e11432b946a7d2ccee60b
|
F src/os_win.c 5f018dbd4cec25c5b47e11432b946a7d2ccee60b
|
||||||
F src/pager.c 3709c5c9e2eb566fffba6348508b7212c4d06ca3
|
F src/pager.c 79df56da9dd49aceaa4cac207484a9a82cba40ae
|
||||||
F src/pager.h 5cb78b8e1adfd5451e600be7719f5a99d87ac3b1
|
F src/pager.h 5cb78b8e1adfd5451e600be7719f5a99d87ac3b1
|
||||||
F src/parse.y 9708365594eea519cdc8504dee425c0a41c79502
|
F src/parse.y 9acfcc83ddbf0cf82f0ed9582ccf0ad6c366ff37
|
||||||
F src/pcache.c f8043b433a57aba85384a531e3937a804432a346
|
F src/pcache.c f8043b433a57aba85384a531e3937a804432a346
|
||||||
F src/pcache.h a5e4f5d9f5d592051d91212c5949517971ae6222
|
F src/pcache.h a5e4f5d9f5d592051d91212c5949517971ae6222
|
||||||
F src/pcache1.c 9fd22671c270b35131ef480bbc00392b8b5f8ab9
|
F src/pcache1.c d23d07716de96c7c0c2503ec5051a4384c3fb938
|
||||||
F src/pragma.c 8bf4bfaef7975abff45e55230ed1033b5f208d11
|
F src/pragma.c 67a611bd4be0754f27ee13eb87932c3b14415862
|
||||||
F src/prepare.c 743e484233c51109666d402f470523553b41797c
|
F src/prepare.c 743e484233c51109666d402f470523553b41797c
|
||||||
F src/printf.c 4a9f882f1c1787a8b494a2987765acf9d97ac21f
|
F src/printf.c bff529ed47657098c55c9910b9c69b1b3b1a1353
|
||||||
F src/random.c cd4a67b3953b88019f8cd4ccd81394a8ddfaba50
|
F src/random.c cd4a67b3953b88019f8cd4ccd81394a8ddfaba50
|
||||||
F src/resolve.c 89f9003e8316ee3a172795459efc2a0274e1d5a8
|
F src/resolve.c 89f9003e8316ee3a172795459efc2a0274e1d5a8
|
||||||
F src/rowset.c 64655f1a627c9c212d9ab497899e7424a34222e0
|
F src/rowset.c 64655f1a627c9c212d9ab497899e7424a34222e0
|
||||||
F src/select.c a4641882279becc200f2680f55f3e89d4e7c7f78
|
F src/select.c 22ee971346a736ddefdc4497d07c92f2e9978afc
|
||||||
F src/shell.c 9a18124ff209ca308d786c99a466e8e270193ff3
|
F src/shell.c 9a18124ff209ca308d786c99a466e8e270193ff3
|
||||||
F src/sqlite.h.in 5a5a22a9b192d81a9e5dee00274e3a0484c4afb1
|
F src/sqlite.h.in 5b390ca5d94e09e56e7fee6a51ddde4721b89f8e
|
||||||
F src/sqlite3.rc fea433eb0a59f4c9393c8e6d76a6e2596b1fe0c0
|
F src/sqlite3.rc fea433eb0a59f4c9393c8e6d76a6e2596b1fe0c0
|
||||||
F src/sqlite3ext.h d936f797812c28b81b26ed18345baf8db28a21a5
|
F src/sqlite3ext.h d936f797812c28b81b26ed18345baf8db28a21a5
|
||||||
F src/sqliteInt.h 9e12a56e05420b5c7aa40aca4d44ee4d9535b68a
|
F src/sqliteInt.h 55f43f10f165c8c17334e33a11b2d58a557b4a2c
|
||||||
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
||||||
F src/status.c bedc37ec1a6bb9399944024d63f4c769971955a9
|
F src/status.c bedc37ec1a6bb9399944024d63f4c769971955a9
|
||||||
F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e
|
F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e
|
||||||
F src/tclsqlite.c 2ecec9937e69bc17560ad886da35195daa7261b8
|
F src/tclsqlite.c 2ecec9937e69bc17560ad886da35195daa7261b8
|
||||||
F src/test1.c 045d45a4f7eeb5d963f8fc150339f1bad279011a
|
F src/test1.c 6d2a340eea1d866bf7059894491652a69a7ee802
|
||||||
F src/test2.c 7355101c085304b90024f2261e056cdff13c6c35
|
F src/test2.c 7355101c085304b90024f2261e056cdff13c6c35
|
||||||
F src/test3.c 1c0e5d6f080b8e33c1ce8b3078e7013fdbcd560c
|
F src/test3.c 1c0e5d6f080b8e33c1ce8b3078e7013fdbcd560c
|
||||||
F src/test4.c 9b32d22f5f150abe23c1830e2057c4037c45b3df
|
F src/test4.c 9b32d22f5f150abe23c1830e2057c4037c45b3df
|
||||||
@ -247,19 +271,19 @@ F src/test_vfs.c 8e6087a8b3dcc260282074b0efba14b76311120c
|
|||||||
F src/test_vfstrace.c 34b544e80ba7fb77be15395a609c669df2e660a2
|
F src/test_vfstrace.c 34b544e80ba7fb77be15395a609c669df2e660a2
|
||||||
F src/test_wsd.c 41cadfd9d97fe8e3e4e44f61a4a8ccd6f7ca8fe9
|
F src/test_wsd.c 41cadfd9d97fe8e3e4e44f61a4a8ccd6f7ca8fe9
|
||||||
F src/tokenize.c 1e86210d3976717a19238ea7b047fac481fe8c12
|
F src/tokenize.c 1e86210d3976717a19238ea7b047fac481fe8c12
|
||||||
F src/trigger.c cd95ac64efa60e39faf9b5597443192ff27a22fa
|
F src/trigger.c 5c0ea9b8755e7c5e1a700f3e27ac4f8d92dd221e
|
||||||
F src/update.c 4c0c6864c4349ba292042e984a56d15985b57f4e
|
F src/update.c 4c0c6864c4349ba292042e984a56d15985b57f4e
|
||||||
F src/utf.c 8d819e2e5104a430fc2005f018db14347c95a38f
|
F src/utf.c 8d819e2e5104a430fc2005f018db14347c95a38f
|
||||||
F src/util.c f566b5138099a2df8533b190d0dcc74b7dfbe0c9
|
F src/util.c f566b5138099a2df8533b190d0dcc74b7dfbe0c9
|
||||||
F src/vacuum.c ddf21cc9577c4cb459d08bee9863a78ec000c5bb
|
F src/vacuum.c ddf21cc9577c4cb459d08bee9863a78ec000c5bb
|
||||||
F src/vdbe.c 5f0047130f80c7fd0bc41bc51a653b5542c4fbd5
|
F src/vdbe.c 34929e1b5bd95a85b5e1b7767b5cc8da582ad78d
|
||||||
F src/vdbe.h b52887278cb173e66188da84dfab216bea61119d
|
F src/vdbe.h b52887278cb173e66188da84dfab216bea61119d
|
||||||
F src/vdbeInt.h c1e830268b75f04a2901dd895b51a637a26c7045
|
F src/vdbeInt.h c1e830268b75f04a2901dd895b51a637a26c7045
|
||||||
F src/vdbeapi.c 085cf9bf169b859a6c8fa43791702bac805cb7aa
|
F src/vdbeapi.c 0b2c78797058c6c9bfa1687977de039566e22877
|
||||||
F src/vdbeaux.c ecb43014bcd3019e5aa2b5561e5c3a447f007a08
|
F src/vdbeaux.c af9cd9372c7ab82294b9645723e652c2d4213b95
|
||||||
F src/vdbeblob.c 5dc79627775bd9a9b494dd956e26297946417d69
|
F src/vdbeblob.c 5dc79627775bd9a9b494dd956e26297946417d69
|
||||||
F src/vdbemem.c 833005f1cbbf447289f1973dba2a0c2228c7b8ab
|
F src/vdbemem.c 833005f1cbbf447289f1973dba2a0c2228c7b8ab
|
||||||
F src/vdbesort.c 4fad64071ae120c25f39dcac572d716b9cadeb7f
|
F src/vdbesort.c 3937e06b2a0e354500e17dc206ef4c35770a5017
|
||||||
F src/vdbetrace.c 18cc59cb475e6115129bfde224367d13a35a7d13
|
F src/vdbetrace.c 18cc59cb475e6115129bfde224367d13a35a7d13
|
||||||
F src/vtab.c b05e5f1f4902461ba9f5fc49bb7eb7c3a0741a83
|
F src/vtab.c b05e5f1f4902461ba9f5fc49bb7eb7c3a0741a83
|
||||||
F src/wal.c 436bfceb141b9423c45119e68e444358ee0ed35d
|
F src/wal.c 436bfceb141b9423c45119e68e444358ee0ed35d
|
||||||
@ -513,7 +537,7 @@ F test/fts3prefix.test b36d4f00b128a51e7b386cc013a874246d9d7dc1
|
|||||||
F test/fts3prefix2.test 477ca96e67f60745b7ac931cfa6e9b080c562da5
|
F test/fts3prefix2.test 477ca96e67f60745b7ac931cfa6e9b080c562da5
|
||||||
F test/fts3query.test ef79d31fdb355d094baec1c1b24b60439a1fb8a2
|
F test/fts3query.test ef79d31fdb355d094baec1c1b24b60439a1fb8a2
|
||||||
F test/fts3rnd.test 1320d8826a845e38a96e769562bf83d7a92a15d0
|
F test/fts3rnd.test 1320d8826a845e38a96e769562bf83d7a92a15d0
|
||||||
F test/fts3shared.test 8bb266521d7c5495c0ae522bb4d376ad5387d4a2
|
F test/fts3shared.test c2f60e152e8554549eb25f0a7593ea01389c5037
|
||||||
F test/fts3snippet.test 8e956051221a34c7daeb504f023cb54d5fa5a8b2
|
F test/fts3snippet.test 8e956051221a34c7daeb504f023cb54d5fa5a8b2
|
||||||
F test/fts3sort.test 95be0b19d7e41c44b29014f13ea8bddd495fd659
|
F test/fts3sort.test 95be0b19d7e41c44b29014f13ea8bddd495fd659
|
||||||
F test/fts3tok1.test 4d9e7401679dc71f6b2f76416309b923210bfdbe
|
F test/fts3tok1.test 4d9e7401679dc71f6b2f76416309b923210bfdbe
|
||||||
@ -525,6 +549,7 @@ F test/fts4langid.test 24a6e41063b416bbdf371ff6b4476fa41c194aa7
|
|||||||
F test/fts4merge.test c424309743fdd203f8e56a1f1cd7872cd66cc0ee
|
F test/fts4merge.test c424309743fdd203f8e56a1f1cd7872cd66cc0ee
|
||||||
F test/fts4merge2.test 5faa558d1b672f82b847d2a337465fa745e46891
|
F test/fts4merge2.test 5faa558d1b672f82b847d2a337465fa745e46891
|
||||||
F test/fts4merge3.test aab02a09f50fe6baaddc2e159c3eabc116d45fc7
|
F test/fts4merge3.test aab02a09f50fe6baaddc2e159c3eabc116d45fc7
|
||||||
|
F test/fts4merge4.test c19c85ca1faa7b6d536832b49c12e1867235f584
|
||||||
F test/fts4unicode.test 25ccad45896f8e50f6a694cff738a35f798cdb40
|
F test/fts4unicode.test 25ccad45896f8e50f6a694cff738a35f798cdb40
|
||||||
F test/full.test 6b3c8fb43c6beab6b95438c1675374b95fab245d
|
F test/full.test 6b3c8fb43c6beab6b95438c1675374b95fab245d
|
||||||
F test/func.test b0fc34fdc36897769651975a2b0a606312753643
|
F test/func.test b0fc34fdc36897769651975a2b0a606312753643
|
||||||
@ -680,6 +705,7 @@ F test/pageropt.test 6b8f6a123a5572c195ad4ae40f2987007923bbd6
|
|||||||
F test/pagesize.test 1dd51367e752e742f58e861e65ed7390603827a0
|
F test/pagesize.test 1dd51367e752e742f58e861e65ed7390603827a0
|
||||||
F test/pcache.test 065aa286e722ab24f2e51792c1f093bf60656b16
|
F test/pcache.test 065aa286e722ab24f2e51792c1f093bf60656b16
|
||||||
F test/pcache2.test a83efe2dec0d392f814bfc998def1d1833942025
|
F test/pcache2.test a83efe2dec0d392f814bfc998def1d1833942025
|
||||||
|
F test/percentile.test 4614301e38398df7fdd5f28f4ed8f272b328251b
|
||||||
F test/permutations.test d997a947ab8aabb15f763d50a030b3c11e8ef1b6
|
F test/permutations.test d997a947ab8aabb15f763d50a030b3c11e8ef1b6
|
||||||
F test/pragma.test 5e7de6c32a5d764f09437d2025f07e4917b9e178
|
F test/pragma.test 5e7de6c32a5d764f09437d2025f07e4917b9e178
|
||||||
F test/pragma2.test 3a55f82b954242c642f8342b17dffc8b47472947
|
F test/pragma2.test 3a55f82b954242c642f8342b17dffc8b47472947
|
||||||
@ -924,7 +950,7 @@ F test/tkt3997.test a335fa41ca3985660a139df7b734a26ef53284bd
|
|||||||
F test/tkt4018.test 7c2c9ba4df489c676a0a7a0e809a1fb9b2185bd1
|
F test/tkt4018.test 7c2c9ba4df489c676a0a7a0e809a1fb9b2185bd1
|
||||||
F test/tokenize.test ce430a7aed48fc98301611429595883fdfcab5d7
|
F test/tokenize.test ce430a7aed48fc98301611429595883fdfcab5d7
|
||||||
F test/trace.test 4b36a41a3e9c7842151af6da5998f5080cdad9e5
|
F test/trace.test 4b36a41a3e9c7842151af6da5998f5080cdad9e5
|
||||||
F test/trace2.test c1dc104a8d11a347c870cfea6235e3fc6f6cb06d
|
F test/trace2.test e7a988fdd982cdec62f1f1f34b0360e6476d01a0
|
||||||
F test/trans.test 6e1b4c6a42dba31bd65f8fa5e61a2708e08ddde6
|
F test/trans.test 6e1b4c6a42dba31bd65f8fa5e61a2708e08ddde6
|
||||||
F test/trans2.test d5337e61de45e66b1fcbf9db833fa8c82e624b22
|
F test/trans2.test d5337e61de45e66b1fcbf9db833fa8c82e624b22
|
||||||
F test/trans3.test 373ac5183cc56be69f48ae44090e7f672939f732
|
F test/trans3.test 373ac5183cc56be69f48ae44090e7f672939f732
|
||||||
@ -1033,6 +1059,7 @@ F tool/genfkey.test 4196a8928b78f51d54ef58e99e99401ab2f0a7e5
|
|||||||
F tool/getlock.c f4c39b651370156cae979501a7b156bdba50e7ce
|
F tool/getlock.c f4c39b651370156cae979501a7b156bdba50e7ce
|
||||||
F tool/lemon.c 680980c7935bfa1edec20c804c9e5ba4b1dd96f5
|
F tool/lemon.c 680980c7935bfa1edec20c804c9e5ba4b1dd96f5
|
||||||
F tool/lempar.c 01ca97f87610d1dac6d8cd96ab109ab1130e76dc
|
F tool/lempar.c 01ca97f87610d1dac6d8cd96ab109ab1130e76dc
|
||||||
|
F tool/mkautoconfamal.sh 9ef9ad69bc3021a6fd2dac53a2e8cf5b97e0df05
|
||||||
F tool/mkkeywordhash.c bb52064aa614e1426445e4b2b9b00eeecd23cc79
|
F tool/mkkeywordhash.c bb52064aa614e1426445e4b2b9b00eeecd23cc79
|
||||||
F tool/mkopts.tcl 66ac10d240cc6e86abd37dc908d50382f84ff46e
|
F tool/mkopts.tcl 66ac10d240cc6e86abd37dc908d50382f84ff46e
|
||||||
F tool/mkspeedsql.tcl a1a334d288f7adfe6e996f2e712becf076745c97
|
F tool/mkspeedsql.tcl a1a334d288f7adfe6e996f2e712becf076745c97
|
||||||
@ -1066,7 +1093,7 @@ F tool/vdbe-compress.tcl f12c884766bd14277f4fcedcae07078011717381
|
|||||||
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
||||||
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
|
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
|
||||||
F tool/win/sqlite.vsix 97894c2790eda7b5bce3cc79cb2a8ec2fde9b3ac
|
F tool/win/sqlite.vsix 97894c2790eda7b5bce3cc79cb2a8ec2fde9b3ac
|
||||||
P b49fa74561f38c945be6149693678fd6518c2de4
|
P 211f7a5374fe20a02535edc8b799a8a7136ff6b3 d5b084e9d8cfe9c0c339aca076d472bb50aa764c
|
||||||
R dbfb376dc6b826c13c37ea187ec4a9c4
|
R 6c4c190a12a33f58ef606f4f8676d338
|
||||||
U drh
|
U drh
|
||||||
Z 716f8aec8e11bc86fa358274cd806e0b
|
Z e692c34c627e293c83ac7dc20bf238bc
|
||||||
|
@ -1 +1 @@
|
|||||||
211f7a5374fe20a02535edc8b799a8a7136ff6b3
|
aebe1f2603ee04d792af73aaf59625bda99d5cd1
|
@ -25,7 +25,7 @@
|
|||||||
** The sqlite_stat2 table is not created or used unless the SQLite version
|
** The sqlite_stat2 table is not created or used unless the SQLite version
|
||||||
** is between 3.6.18 and 3.7.8, inclusive, and unless SQLite is compiled
|
** is between 3.6.18 and 3.7.8, inclusive, and unless SQLite is compiled
|
||||||
** with SQLITE_ENABLE_STAT2. The sqlite_stat2 table is deprecated.
|
** with SQLITE_ENABLE_STAT2. The sqlite_stat2 table is deprecated.
|
||||||
** The sqlite_stat2 table is superceded by sqlite_stat3, which is only
|
** The sqlite_stat2 table is superseded by sqlite_stat3, which is only
|
||||||
** created and used by SQLite versions 3.7.9 and later and with
|
** created and used by SQLite versions 3.7.9 and later and with
|
||||||
** SQLITE_ENABLE_STAT3 defined. The fucntionality of sqlite_stat3
|
** SQLITE_ENABLE_STAT3 defined. The fucntionality of sqlite_stat3
|
||||||
** is a superset of sqlite_stat2.
|
** is a superset of sqlite_stat2.
|
||||||
|
@ -1215,7 +1215,7 @@ static int allocateSpace(MemPage *pPage, int nByte, int *pIdx){
|
|||||||
}else if( gap+2<=top ){
|
}else if( gap+2<=top ){
|
||||||
/* Search the freelist looking for a free slot big enough to satisfy
|
/* Search the freelist looking for a free slot big enough to satisfy
|
||||||
** the request. The allocation is made from the first free slot in
|
** the request. The allocation is made from the first free slot in
|
||||||
** the list that is large enough to accomadate it.
|
** the list that is large enough to accommodate it.
|
||||||
*/
|
*/
|
||||||
int pc, addr;
|
int pc, addr;
|
||||||
for(addr=hdr+1; (pc = get2byte(&data[addr]))>0; addr=pc){
|
for(addr=hdr+1; (pc = get2byte(&data[addr]))>0; addr=pc){
|
||||||
@ -3158,7 +3158,7 @@ int sqlite3BtreeIncrVacuum(Btree *p){
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
** This routine is called prior to sqlite3PagerCommit when a transaction
|
** This routine is called prior to sqlite3PagerCommit when a transaction
|
||||||
** is commited for an auto-vacuum database.
|
** is committed for an auto-vacuum database.
|
||||||
**
|
**
|
||||||
** If SQLITE_OK is returned, then *pnTrunc is set to the number of pages
|
** If SQLITE_OK is returned, then *pnTrunc is set to the number of pages
|
||||||
** the database file should be truncated to during the commit process.
|
** the database file should be truncated to during the commit process.
|
||||||
|
@ -1646,7 +1646,7 @@ int sqlite3FindInIndex(Parse *pParse, Expr *pX, int *prNotFound){
|
|||||||
**
|
**
|
||||||
** If rMayHaveNull is zero, that means that the subquery is being used
|
** If rMayHaveNull is zero, that means that the subquery is being used
|
||||||
** for membership testing only. There is no need to initialize any
|
** for membership testing only. There is no need to initialize any
|
||||||
** registers to indicate the presense or absence of NULLs on the RHS.
|
** registers to indicate the presence or absence of NULLs on the RHS.
|
||||||
**
|
**
|
||||||
** For a SELECT or EXISTS operator, return the register that holds the
|
** For a SELECT or EXISTS operator, return the register that holds the
|
||||||
** result. For IN operators or if an error occurs, the return value is 0.
|
** result. For IN operators or if an error occurs, the return value is 0.
|
||||||
|
@ -228,7 +228,7 @@ static void instrFunc(
|
|||||||
**
|
**
|
||||||
** If p1 is negative, then we begin abs(p1) from the end of x[].
|
** If p1 is negative, then we begin abs(p1) from the end of x[].
|
||||||
**
|
**
|
||||||
** If p2 is negative, return the p2 characters preceeding p1.
|
** If p2 is negative, return the p2 characters preceding p1.
|
||||||
*/
|
*/
|
||||||
static void substrFunc(
|
static void substrFunc(
|
||||||
sqlite3_context *context,
|
sqlite3_context *context,
|
||||||
@ -887,10 +887,6 @@ static const char hexdigits[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** EXPERIMENTAL - This is not an official function. The interface may
|
|
||||||
** change. This function may disappear. Do not write code that depends
|
|
||||||
** on this function.
|
|
||||||
**
|
|
||||||
** Implementation of the QUOTE() function. This function takes a single
|
** Implementation of the QUOTE() function. This function takes a single
|
||||||
** argument. If the argument is numeric, the return value is the same as
|
** argument. If the argument is numeric, the return value is the same as
|
||||||
** the argument. If the argument is NULL, the return value is the string
|
** the argument. If the argument is NULL, the return value is the string
|
||||||
@ -1079,7 +1075,7 @@ static void zeroblobFunc(
|
|||||||
/*
|
/*
|
||||||
** The replace() function. Three arguments are all strings: call
|
** The replace() function. Three arguments are all strings: call
|
||||||
** them A, B, and C. The result is also a string which is derived
|
** them A, B, and C. The result is also a string which is derived
|
||||||
** from A by replacing every occurance of B with C. The match
|
** from A by replacing every occurrence of B with C. The match
|
||||||
** must be exact. Collating sequences are not used.
|
** must be exact. Collating sequences are not used.
|
||||||
*/
|
*/
|
||||||
static void replaceFunc(
|
static void replaceFunc(
|
||||||
|
@ -701,7 +701,7 @@ static int binCollFunc(
|
|||||||
/*
|
/*
|
||||||
** Another built-in collating sequence: NOCASE.
|
** Another built-in collating sequence: NOCASE.
|
||||||
**
|
**
|
||||||
** This collating sequence is intended to be used for "case independant
|
** This collating sequence is intended to be used for "case independent
|
||||||
** comparison". SQLite's knowledge of upper and lower case equivalents
|
** comparison". SQLite's knowledge of upper and lower case equivalents
|
||||||
** extends only to the 26 characters used in the English language.
|
** extends only to the 26 characters used in the English language.
|
||||||
**
|
**
|
||||||
@ -1024,7 +1024,6 @@ void sqlite3RollbackAll(sqlite3 *db, int tripCode){
|
|||||||
inTrans = 1;
|
inTrans = 1;
|
||||||
}
|
}
|
||||||
sqlite3BtreeRollback(p, tripCode);
|
sqlite3BtreeRollback(p, tripCode);
|
||||||
db->aDb[i].inTrans = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sqlite3VtabRollback(db);
|
sqlite3VtabRollback(db);
|
||||||
@ -2791,8 +2790,6 @@ int sqlite3_global_recover(void){
|
|||||||
** mode. Return TRUE if it is and FALSE if not. Autocommit mode is on
|
** mode. Return TRUE if it is and FALSE if not. Autocommit mode is on
|
||||||
** by default. Autocommit is disabled by a BEGIN statement and reenabled
|
** by default. Autocommit is disabled by a BEGIN statement and reenabled
|
||||||
** by the next COMMIT or ROLLBACK.
|
** by the next COMMIT or ROLLBACK.
|
||||||
**
|
|
||||||
******* THIS IS AN EXPERIMENTAL API AND IS SUBJECT TO CHANGE ******
|
|
||||||
*/
|
*/
|
||||||
int sqlite3_get_autocommit(sqlite3 *db){
|
int sqlite3_get_autocommit(sqlite3 *db){
|
||||||
return db->autoCommit;
|
return db->autoCommit;
|
||||||
|
39
src/pager.c
39
src/pager.c
@ -5180,7 +5180,7 @@ static void pagerUnlockIfUnused(Pager *pPager){
|
|||||||
** page is initialized to all zeros.
|
** page is initialized to all zeros.
|
||||||
**
|
**
|
||||||
** If noContent is true, it means that we do not care about the contents
|
** If noContent is true, it means that we do not care about the contents
|
||||||
** of the page. This occurs in two seperate scenarios:
|
** of the page. This occurs in two scenarios:
|
||||||
**
|
**
|
||||||
** a) When reading a free-list leaf page from the database, and
|
** a) When reading a free-list leaf page from the database, and
|
||||||
**
|
**
|
||||||
@ -6590,7 +6590,27 @@ void sqlite3PagerSetCodec(
|
|||||||
void *sqlite3PagerGetCodec(Pager *pPager){
|
void *sqlite3PagerGetCodec(Pager *pPager){
|
||||||
return pPager->pCodec;
|
return pPager->pCodec;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
/*
|
||||||
|
** This function is called by the wal module when writing page content
|
||||||
|
** into the log file.
|
||||||
|
**
|
||||||
|
** This function returns a pointer to a buffer containing the encrypted
|
||||||
|
** page content. If a malloc fails, this function may return NULL.
|
||||||
|
*/
|
||||||
|
void *sqlite3PagerCodec(PgHdr *pPg){
|
||||||
|
void *aData = 0;
|
||||||
|
CODEC2(pPg->pPager, pPg->pData, pPg->pgno, 6, return 0, aData);
|
||||||
|
return aData;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Return the current pager state
|
||||||
|
*/
|
||||||
|
int sqlite3PagerState(Pager *pPager){
|
||||||
|
return pPager->eState;
|
||||||
|
}
|
||||||
|
#endif /* SQLITE_HAS_CODEC */
|
||||||
|
|
||||||
#ifndef SQLITE_OMIT_AUTOVACUUM
|
#ifndef SQLITE_OMIT_AUTOVACUUM
|
||||||
/*
|
/*
|
||||||
@ -7145,19 +7165,4 @@ int sqlite3PagerWalFramesize(Pager *pPager){
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SQLITE_HAS_CODEC
|
|
||||||
/*
|
|
||||||
** This function is called by the wal module when writing page content
|
|
||||||
** into the log file.
|
|
||||||
**
|
|
||||||
** This function returns a pointer to a buffer containing the encrypted
|
|
||||||
** page content. If a malloc fails, this function may return NULL.
|
|
||||||
*/
|
|
||||||
void *sqlite3PagerCodec(PgHdr *pPg){
|
|
||||||
void *aData = 0;
|
|
||||||
CODEC2(pPg->pPager, pPg->pData, pPg->pgno, 6, return 0, aData);
|
|
||||||
return aData;
|
|
||||||
}
|
|
||||||
#endif /* SQLITE_HAS_CODEC */
|
|
||||||
|
|
||||||
#endif /* SQLITE_OMIT_DISKIO */
|
#endif /* SQLITE_OMIT_DISKIO */
|
||||||
|
@ -213,7 +213,7 @@ id(A) ::= INDEXED(X). {A = X;}
|
|||||||
.
|
.
|
||||||
%wildcard ANY.
|
%wildcard ANY.
|
||||||
|
|
||||||
// Define operator precedence early so that this is the first occurance
|
// Define operator precedence early so that this is the first occurrence
|
||||||
// of the operator tokens in the grammer. Keeping the operators together
|
// of the operator tokens in the grammer. Keeping the operators together
|
||||||
// causes them to be assigned integer values that are close together,
|
// causes them to be assigned integer values that are close together,
|
||||||
// which keeps parser tables smaller.
|
// which keeps parser tables smaller.
|
||||||
|
@ -562,7 +562,7 @@ static sqlite3_pcache *pcache1Create(int szPage, int szExtra, int bPurgeable){
|
|||||||
int sz; /* Bytes of memory required to allocate the new cache */
|
int sz; /* Bytes of memory required to allocate the new cache */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** The seperateCache variable is true if each PCache has its own private
|
** The separateCache variable is true if each PCache has its own private
|
||||||
** PGroup. In other words, separateCache is true for mode (1) where no
|
** PGroup. In other words, separateCache is true for mode (1) where no
|
||||||
** mutexing is required.
|
** mutexing is required.
|
||||||
**
|
**
|
||||||
|
10
src/pragma.c
10
src/pragma.c
@ -1313,7 +1313,7 @@ void sqlite3Pragma(
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef SQLITE_OMIT_INTEGRITY_CHECK
|
#ifndef SQLITE_OMIT_INTEGRITY_CHECK
|
||||||
/* Pragma "quick_check" is an experimental reduced version of
|
/* Pragma "quick_check" is reduced version of
|
||||||
** integrity_check designed to detect most database corruption
|
** integrity_check designed to detect most database corruption
|
||||||
** without most of the overhead of a full integrity-check.
|
** without most of the overhead of a full integrity-check.
|
||||||
*/
|
*/
|
||||||
@ -1771,10 +1771,10 @@ void sqlite3Pragma(
|
|||||||
|
|
||||||
#ifdef SQLITE_HAS_CODEC
|
#ifdef SQLITE_HAS_CODEC
|
||||||
if( sqlite3StrICmp(zLeft, "key")==0 && zRight ){
|
if( sqlite3StrICmp(zLeft, "key")==0 && zRight ){
|
||||||
sqlite3_key(db, zRight, sqlite3Strlen30(zRight));
|
sqlite3_key_v2(db, zDb, zRight, sqlite3Strlen30(zRight));
|
||||||
}else
|
}else
|
||||||
if( sqlite3StrICmp(zLeft, "rekey")==0 && zRight ){
|
if( sqlite3StrICmp(zLeft, "rekey")==0 && zRight ){
|
||||||
sqlite3_rekey(db, zRight, sqlite3Strlen30(zRight));
|
sqlite3_rekey_v2(db, zDb, zRight, sqlite3Strlen30(zRight));
|
||||||
}else
|
}else
|
||||||
if( zRight && (sqlite3StrICmp(zLeft, "hexkey")==0 ||
|
if( zRight && (sqlite3StrICmp(zLeft, "hexkey")==0 ||
|
||||||
sqlite3StrICmp(zLeft, "hexrekey")==0) ){
|
sqlite3StrICmp(zLeft, "hexrekey")==0) ){
|
||||||
@ -1786,9 +1786,9 @@ void sqlite3Pragma(
|
|||||||
zKey[i/2] = (h2 & 0x0f) | ((h1 & 0xf)<<4);
|
zKey[i/2] = (h2 & 0x0f) | ((h1 & 0xf)<<4);
|
||||||
}
|
}
|
||||||
if( (zLeft[3] & 0xf)==0xb ){
|
if( (zLeft[3] & 0xf)==0xb ){
|
||||||
sqlite3_key(db, zKey, i/2);
|
sqlite3_key_v2(db, zDb, zKey, i/2);
|
||||||
}else{
|
}else{
|
||||||
sqlite3_rekey(db, zKey, i/2);
|
sqlite3_rekey_v2(db, zDb, zKey, i/2);
|
||||||
}
|
}
|
||||||
}else
|
}else
|
||||||
#endif
|
#endif
|
||||||
|
@ -413,13 +413,7 @@ void sqlite3VXPrintf(
|
|||||||
else prefix = 0;
|
else prefix = 0;
|
||||||
}
|
}
|
||||||
if( xtype==etGENERIC && precision>0 ) precision--;
|
if( xtype==etGENERIC && precision>0 ) precision--;
|
||||||
#if 0
|
|
||||||
/* Rounding works like BSD when the constant 0.4999 is used. Wierd! */
|
|
||||||
for(idx=precision, rounder=0.4999; idx>0; idx--, rounder*=0.1);
|
|
||||||
#else
|
|
||||||
/* It makes more sense to use 0.5 */
|
|
||||||
for(idx=precision, rounder=0.5; idx>0; idx--, rounder*=0.1){}
|
for(idx=precision, rounder=0.5; idx>0; idx--, rounder*=0.1){}
|
||||||
#endif
|
|
||||||
if( xtype==etFLOAT ) realvalue += rounder;
|
if( xtype==etFLOAT ) realvalue += rounder;
|
||||||
/* Normalize realvalue to within 10.0 > realvalue >= 1.0 */
|
/* Normalize realvalue to within 10.0 > realvalue >= 1.0 */
|
||||||
exp = 0;
|
exp = 0;
|
||||||
|
@ -109,7 +109,7 @@ void sqlite3SelectDelete(sqlite3 *db, Select *p){
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Given 1 to 3 identifiers preceeding the JOIN keyword, determine the
|
** Given 1 to 3 identifiers preceding the JOIN keyword, determine the
|
||||||
** type of join. Return an integer constant that expresses that type
|
** type of join. Return an integer constant that expresses that type
|
||||||
** in terms of the following bit values:
|
** in terms of the following bit values:
|
||||||
**
|
**
|
||||||
@ -1523,7 +1523,7 @@ static void computeLimitRegisters(Parse *pParse, Select *p, int iBreak){
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
** "LIMIT -1" always shows all rows. There is some
|
** "LIMIT -1" always shows all rows. There is some
|
||||||
** contraversy about what the correct behavior should be.
|
** controversy about what the correct behavior should be.
|
||||||
** The current implementation interprets "LIMIT 0" to mean
|
** The current implementation interprets "LIMIT 0" to mean
|
||||||
** no rows.
|
** no rows.
|
||||||
*/
|
*/
|
||||||
@ -4046,7 +4046,7 @@ int sqlite3Select(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Increment Parse.nHeight by the height of the largest expression
|
/* Increment Parse.nHeight by the height of the largest expression
|
||||||
** tree refered to by this, the parent select. The child select
|
** tree referred to by this, the parent select. The child select
|
||||||
** may contain expression trees of at most
|
** may contain expression trees of at most
|
||||||
** (SQLITE_MAX_EXPR_DEPTH-Parse.nHeight) height. This is a bit
|
** (SQLITE_MAX_EXPR_DEPTH-Parse.nHeight) height. This is a bit
|
||||||
** more conservative than necessary, but much easier than enforcing
|
** more conservative than necessary, but much easier than enforcing
|
||||||
|
@ -4513,6 +4513,11 @@ int sqlite3_key(
|
|||||||
sqlite3 *db, /* Database to be rekeyed */
|
sqlite3 *db, /* Database to be rekeyed */
|
||||||
const void *pKey, int nKey /* The key */
|
const void *pKey, int nKey /* The key */
|
||||||
);
|
);
|
||||||
|
int sqlite3_key_v2(
|
||||||
|
sqlite3 *db, /* Database to be rekeyed */
|
||||||
|
const char *zDbName, /* Name of the database */
|
||||||
|
const void *pKey, int nKey /* The key */
|
||||||
|
);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Change the key on an open database. If the current database is not
|
** Change the key on an open database. If the current database is not
|
||||||
@ -4526,6 +4531,11 @@ int sqlite3_rekey(
|
|||||||
sqlite3 *db, /* Database to be rekeyed */
|
sqlite3 *db, /* Database to be rekeyed */
|
||||||
const void *pKey, int nKey /* The new key */
|
const void *pKey, int nKey /* The new key */
|
||||||
);
|
);
|
||||||
|
int sqlite3_rekey_v2(
|
||||||
|
sqlite3 *db, /* Database to be rekeyed */
|
||||||
|
const char *zDbName, /* Name of the database */
|
||||||
|
const void *pKey, int nKey /* The new key */
|
||||||
|
);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Specify the activation key for a SEE database. Unless
|
** Specify the activation key for a SEE database. Unless
|
||||||
|
@ -114,7 +114,7 @@
|
|||||||
** The SQLITE_THREADSAFE macro must be defined as 0, 1, or 2.
|
** The SQLITE_THREADSAFE macro must be defined as 0, 1, or 2.
|
||||||
** 0 means mutexes are permanently disable and the library is never
|
** 0 means mutexes are permanently disable and the library is never
|
||||||
** threadsafe. 1 means the library is serialized which is the highest
|
** threadsafe. 1 means the library is serialized which is the highest
|
||||||
** level of threadsafety. 2 means the libary is multithreaded - multiple
|
** level of threadsafety. 2 means the library is multithreaded - multiple
|
||||||
** threads can use SQLite as long as no two threads try to use the same
|
** threads can use SQLite as long as no two threads try to use the same
|
||||||
** database connection at the same time.
|
** database connection at the same time.
|
||||||
**
|
**
|
||||||
@ -748,7 +748,6 @@ typedef struct WhereLevel WhereLevel;
|
|||||||
struct Db {
|
struct Db {
|
||||||
char *zName; /* Name of this database */
|
char *zName; /* Name of this database */
|
||||||
Btree *pBt; /* The B*Tree structure for this database file */
|
Btree *pBt; /* The B*Tree structure for this database file */
|
||||||
u8 inTrans; /* 0: not writable. 1: Transaction. 2: Checkpoint */
|
|
||||||
u8 safety_level; /* How aggressive at syncing data to disk */
|
u8 safety_level; /* How aggressive at syncing data to disk */
|
||||||
Schema *pSchema; /* Pointer to database schema (possibly shared) */
|
Schema *pSchema; /* Pointer to database schema (possibly shared) */
|
||||||
};
|
};
|
||||||
|
@ -2469,7 +2469,7 @@ static int sqlite_static_bind_nbyte = 0;
|
|||||||
/*
|
/*
|
||||||
** Usage: sqlite3_bind VM IDX VALUE FLAGS
|
** Usage: sqlite3_bind VM IDX VALUE FLAGS
|
||||||
**
|
**
|
||||||
** Sets the value of the IDX-th occurance of "?" in the original SQL
|
** Sets the value of the IDX-th occurrence of "?" in the original SQL
|
||||||
** string. VALUE is the new value. If FLAGS=="null" then VALUE is
|
** string. VALUE is the new value. If FLAGS=="null" then VALUE is
|
||||||
** ignored and the value is set to NULL. If FLAGS=="static" then
|
** ignored and the value is set to NULL. If FLAGS=="static" then
|
||||||
** the value is set to the value of a static variable named
|
** the value is set to the value of a static variable named
|
||||||
@ -5563,7 +5563,7 @@ static int test_wal_checkpoint(
|
|||||||
**
|
**
|
||||||
** Otherwise, this command returns a list of three integers. The first integer
|
** Otherwise, this command returns a list of three integers. The first integer
|
||||||
** is 1 if SQLITE_BUSY was returned, or 0 otherwise. The following two integers
|
** is 1 if SQLITE_BUSY was returned, or 0 otherwise. The following two integers
|
||||||
** are the values returned via the output paramaters by wal_checkpoint_v2() -
|
** are the values returned via the output parameters by wal_checkpoint_v2() -
|
||||||
** the number of frames in the log and the number of frames in the log
|
** the number of frames in the log and the number of frames in the log
|
||||||
** that have been checkpointed.
|
** that have been checkpointed.
|
||||||
*/
|
*/
|
||||||
@ -6012,6 +6012,7 @@ static int tclLoadStaticExtensionCmd(
|
|||||||
extern int sqlite3_fuzzer_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_fuzzer_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
extern int sqlite3_ieee_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_ieee_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
extern int sqlite3_nextchar_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_nextchar_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
|
extern int sqlite3_percentile_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
extern int sqlite3_regexp_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_regexp_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
extern int sqlite3_spellfix_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_spellfix_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
extern int sqlite3_wholenumber_init(sqlite3*,char**,const sqlite3_api_routines*);
|
extern int sqlite3_wholenumber_init(sqlite3*,char**,const sqlite3_api_routines*);
|
||||||
@ -6024,6 +6025,7 @@ static int tclLoadStaticExtensionCmd(
|
|||||||
{ "fuzzer", sqlite3_fuzzer_init },
|
{ "fuzzer", sqlite3_fuzzer_init },
|
||||||
{ "ieee754", sqlite3_ieee_init },
|
{ "ieee754", sqlite3_ieee_init },
|
||||||
{ "nextchar", sqlite3_nextchar_init },
|
{ "nextchar", sqlite3_nextchar_init },
|
||||||
|
{ "percentile", sqlite3_percentile_init },
|
||||||
{ "regexp", sqlite3_regexp_init },
|
{ "regexp", sqlite3_regexp_init },
|
||||||
{ "spellfix", sqlite3_spellfix_init },
|
{ "spellfix", sqlite3_spellfix_init },
|
||||||
{ "wholenumber", sqlite3_wholenumber_init },
|
{ "wholenumber", sqlite3_wholenumber_init },
|
||||||
|
@ -1002,7 +1002,7 @@ void sqlite3CodeRowTriggerDirect(
|
|||||||
/*
|
/*
|
||||||
** This is called to code the required FOR EACH ROW triggers for an operation
|
** This is called to code the required FOR EACH ROW triggers for an operation
|
||||||
** on table pTab. The operation to code triggers for (INSERT, UPDATE or DELETE)
|
** on table pTab. The operation to code triggers for (INSERT, UPDATE or DELETE)
|
||||||
** is given by the op paramater. The tr_tm parameter determines whether the
|
** is given by the op parameter. The tr_tm parameter determines whether the
|
||||||
** BEFORE or AFTER triggers are coded. If the operation is an UPDATE, then
|
** BEFORE or AFTER triggers are coded. If the operation is an UPDATE, then
|
||||||
** parameter pChanges is passed the list of columns being modified.
|
** parameter pChanges is passed the list of columns being modified.
|
||||||
**
|
**
|
||||||
|
@ -2914,8 +2914,8 @@ case OP_AutoCommit: {
|
|||||||
** other process can start another write transaction while this transaction is
|
** other process can start another write transaction while this transaction is
|
||||||
** underway. Starting a write transaction also creates a rollback journal. A
|
** underway. Starting a write transaction also creates a rollback journal. A
|
||||||
** write transaction must be started before any changes can be made to the
|
** write transaction must be started before any changes can be made to the
|
||||||
** database. If P2 is 2 or greater then an EXCLUSIVE lock is also obtained
|
** database. If P2 is greater than or equal to 2 then an EXCLUSIVE lock is
|
||||||
** on the file.
|
** also obtained on the file.
|
||||||
**
|
**
|
||||||
** If a write-transaction is started and the Vdbe.usesStmtJournal flag is
|
** If a write-transaction is started and the Vdbe.usesStmtJournal flag is
|
||||||
** true (this flag is set if the Vdbe may modify more than one row and may
|
** true (this flag is set if the Vdbe may modify more than one row and may
|
||||||
|
@ -813,13 +813,6 @@ int sqlite3_column_type(sqlite3_stmt *pStmt, int i){
|
|||||||
return iType;
|
return iType;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The following function is experimental and subject to change or
|
|
||||||
** removal */
|
|
||||||
/*int sqlite3_column_numeric_type(sqlite3_stmt *pStmt, int i){
|
|
||||||
** return sqlite3_value_numeric_type( columnMem(pStmt,i) );
|
|
||||||
**}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Convert the N-th element of pStmt->pColName[] into a string using
|
** Convert the N-th element of pStmt->pColName[] into a string using
|
||||||
** xFunc() then return that string. If N is out of range, return 0.
|
** xFunc() then return that string. If N is out of range, return 0.
|
||||||
|
@ -1996,7 +1996,7 @@ static void checkActiveVdbeCnt(sqlite3 *db){
|
|||||||
** close it now. Argument eOp must be either SAVEPOINT_ROLLBACK or
|
** close it now. Argument eOp must be either SAVEPOINT_ROLLBACK or
|
||||||
** SAVEPOINT_RELEASE. If it is SAVEPOINT_ROLLBACK, then the statement
|
** SAVEPOINT_RELEASE. If it is SAVEPOINT_ROLLBACK, then the statement
|
||||||
** transaction is rolled back. If eOp is SAVEPOINT_RELEASE, then the
|
** transaction is rolled back. If eOp is SAVEPOINT_RELEASE, then the
|
||||||
** statement transaction is commtted.
|
** statement transaction is committed.
|
||||||
**
|
**
|
||||||
** If an IO error occurs, an SQLITE_IOERR_XXX error code is returned.
|
** If an IO error occurs, an SQLITE_IOERR_XXX error code is returned.
|
||||||
** Otherwise SQLITE_OK.
|
** Otherwise SQLITE_OK.
|
||||||
|
@ -54,7 +54,7 @@ typedef struct FileWriter FileWriter;
|
|||||||
** other key value. If the keys are equal (only possible with two EOF
|
** other key value. If the keys are equal (only possible with two EOF
|
||||||
** values), it doesn't matter which index is stored.
|
** values), it doesn't matter which index is stored.
|
||||||
**
|
**
|
||||||
** The (N/4) elements of aTree[] that preceed the final (N/2) described
|
** The (N/4) elements of aTree[] that precede the final (N/2) described
|
||||||
** above contains the index of the smallest of each block of 4 iterators.
|
** above contains the index of the smallest of each block of 4 iterators.
|
||||||
** And so on. So that aTree[1] contains the index of the iterator that
|
** And so on. So that aTree[1] contains the index of the iterator that
|
||||||
** currently points to the smallest key value. aTree[0] is unused.
|
** currently points to the smallest key value. aTree[0] is unused.
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
#
|
||||||
# 2010 September 17
|
# 2010 September 17
|
||||||
#
|
#
|
||||||
# May you do good and not evil.
|
# May you do good and not evil.
|
||||||
@ -5,6 +6,9 @@
|
|||||||
# May you share freely, never taking more than you give.
|
# May you share freely, never taking more than you give.
|
||||||
#
|
#
|
||||||
#***********************************************************************
|
#***********************************************************************
|
||||||
|
# This file implements regression tests for SQLite library. The
|
||||||
|
# focus of this file is the interactions between the FTS3/4 module
|
||||||
|
# and shared-cache mode.
|
||||||
#
|
#
|
||||||
|
|
||||||
set testdir [file dirname $argv0]
|
set testdir [file dirname $argv0]
|
||||||
@ -14,6 +18,7 @@ ifcapable !fts3||!shared_cache {
|
|||||||
finish_test
|
finish_test
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
set ::testprefix fts3shared
|
||||||
|
|
||||||
db close
|
db close
|
||||||
set ::enable_shared_cache [sqlite3_enable_shared_cache 1]
|
set ::enable_shared_cache [sqlite3_enable_shared_cache 1]
|
||||||
@ -67,6 +72,106 @@ do_test fts3shared-1.6 { sqlite3_get_autocommit db2 } 0
|
|||||||
db close
|
db close
|
||||||
db2 close
|
db2 close
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
# The following tests - fts3shared-2.* - test that unless FTS is bypassed
|
||||||
|
# and the underlying tables accessed directly, it is not possible for an
|
||||||
|
# SQLITE_LOCKED error to be enountered when committing an FTS transaction.
|
||||||
|
#
|
||||||
|
# Any SQLITE_LOCKED error should be returned when the fts4 (or fts4aux)
|
||||||
|
# table is first read/written within a transaction, not later on.
|
||||||
|
#
|
||||||
|
set LOCKED {1 {database table is locked}}
|
||||||
|
forcedelete test.db
|
||||||
|
sqlite3 dbR test.db
|
||||||
|
sqlite3 dbW test.db
|
||||||
|
do_test 2.1 {
|
||||||
|
execsql {
|
||||||
|
CREATE VIRTUAL TABLE t1 USING fts4;
|
||||||
|
CREATE TABLE t2ext(a, b);
|
||||||
|
CREATE VIRTUAL TABLE t2 USING fts4(content=t2ext);
|
||||||
|
CREATE VIRTUAL TABLE t1aux USING fts4aux(t1);
|
||||||
|
CREATE VIRTUAL TABLE t2aux USING fts4aux(t2);
|
||||||
|
|
||||||
|
INSERT INTO t1 VALUES('a b c');
|
||||||
|
INSERT INTO t2(rowid, a, b) VALUES(1, 'd e f', 'g h i');
|
||||||
|
} dbW
|
||||||
|
} {}
|
||||||
|
|
||||||
|
# Test that once [dbW] has written to the FTS table, no client may read
|
||||||
|
# from the FTS or fts4aux table.
|
||||||
|
do_test 2.2.1 {
|
||||||
|
execsql {
|
||||||
|
BEGIN;
|
||||||
|
INSERT INTO t1 VALUES('j k l');
|
||||||
|
} dbW
|
||||||
|
execsql BEGIN dbR
|
||||||
|
} {}
|
||||||
|
do_test 2.2.2 { catchsql "SELECT * FROM t1 WHERE rowid=1" dbR } $LOCKED
|
||||||
|
do_test 2.2.3 { catchsql "SELECT * FROM t1 WHERE t1 MATCH 'a'" dbR } $LOCKED
|
||||||
|
do_test 2.2.4 { catchsql "SELECT rowid FROM t1 WHERE t1 MATCH 'a'" dbR } $LOCKED
|
||||||
|
do_test 2.2.5 { catchsql "SELECT * FROM t1" dbR } $LOCKED
|
||||||
|
do_test 2.2.6 { catchsql "SELECT * FROM t1aux" dbR } $LOCKED
|
||||||
|
do_test 2.2.7 { execsql COMMIT dbW } {}
|
||||||
|
do_test 2.2.8 { execsql COMMIT dbR } {}
|
||||||
|
|
||||||
|
# Same test as 2.2.*, except with a content= table.
|
||||||
|
#
|
||||||
|
do_test 2.3.1 {
|
||||||
|
execsql {
|
||||||
|
BEGIN;
|
||||||
|
INSERT INTO t2(rowid, a, b) VALUES(2, 'j k l', 'm n o');
|
||||||
|
} dbW
|
||||||
|
execsql BEGIN dbR
|
||||||
|
} {}
|
||||||
|
do_test 2.3.3 { catchsql "SELECT * FROM t2 WHERE t2 MATCH 'a'" dbR } $LOCKED
|
||||||
|
do_test 2.3.4 { catchsql "SELECT rowid FROM t2 WHERE t2 MATCH 'a'" dbR } $LOCKED
|
||||||
|
do_test 2.3.6 { catchsql "SELECT * FROM t2aux" dbR } $LOCKED
|
||||||
|
do_test 2.3.7 { execsql COMMIT dbW } {}
|
||||||
|
do_test 2.3.8 { execsql COMMIT dbR } {}
|
||||||
|
|
||||||
|
# Test that once a connection has read from the FTS or fts4aux table,
|
||||||
|
# another connection may not write to the FTS table.
|
||||||
|
#
|
||||||
|
foreach {tn sql} {
|
||||||
|
1 "SELECT * FROM t1 WHERE rowid=1"
|
||||||
|
2 "SELECT * FROM t1 WHERE t1 MATCH 'a'"
|
||||||
|
3 "SELECT rowid FROM t1 WHERE t1 MATCH 'a'"
|
||||||
|
4 "SELECT * FROM t1"
|
||||||
|
5 "SELECT * FROM t1aux"
|
||||||
|
} {
|
||||||
|
|
||||||
|
do_test 2.4.$tn {
|
||||||
|
execsql BEGIN dbR
|
||||||
|
execsql $::sql dbR
|
||||||
|
execsql BEGIN dbW
|
||||||
|
catchsql "INSERT INTO t1 VALUES('p q r')" dbW
|
||||||
|
} $LOCKED
|
||||||
|
|
||||||
|
execsql ROLLBACK dbR
|
||||||
|
execsql ROLLBACK dbW
|
||||||
|
}
|
||||||
|
|
||||||
|
# Same test as 2.4.*, except with a content= table.
|
||||||
|
#
|
||||||
|
foreach {tn sql} {
|
||||||
|
2 "SELECT * FROM t2 WHERE t2 MATCH 'a'"
|
||||||
|
3 "SELECT rowid FROM t2 WHERE t2 MATCH 'a'"
|
||||||
|
5 "SELECT * FROM t2aux"
|
||||||
|
} {
|
||||||
|
|
||||||
|
do_test 2.5.$tn {
|
||||||
|
execsql BEGIN dbR
|
||||||
|
execsql $::sql dbR
|
||||||
|
execsql BEGIN dbW
|
||||||
|
catchsql "INSERT INTO t2(rowid, a, b) VALUES(3, 's t u', 'v w x')" dbW
|
||||||
|
} $LOCKED
|
||||||
|
|
||||||
|
execsql ROLLBACK dbR
|
||||||
|
execsql ROLLBACK dbW
|
||||||
|
}
|
||||||
|
|
||||||
|
dbW close
|
||||||
|
dbR close
|
||||||
sqlite3_enable_shared_cache $::enable_shared_cache
|
sqlite3_enable_shared_cache $::enable_shared_cache
|
||||||
finish_test
|
finish_test
|
||||||
|
|
||||||
|
58
test/fts4merge4.test
Normal file
58
test/fts4merge4.test
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
# 2013 May 29
|
||||||
|
#
|
||||||
|
# The author disclaims copyright to this source code. In place of
|
||||||
|
# a legal notice, here is a blessing:
|
||||||
|
#
|
||||||
|
# May you do good and not evil.
|
||||||
|
# May you find forgiveness for yourself and forgive others.
|
||||||
|
# May you share freely, never taking more than you give.
|
||||||
|
#
|
||||||
|
#*************************************************************************
|
||||||
|
# This file implements regression tests for SQLite library.
|
||||||
|
#
|
||||||
|
|
||||||
|
set testdir [file dirname $argv0]
|
||||||
|
source $testdir/tester.tcl
|
||||||
|
source $testdir/fts3_common.tcl
|
||||||
|
set ::testprefix fts4merge4
|
||||||
|
|
||||||
|
ifcapable !fts3 {
|
||||||
|
finish_test
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
set ::enable_shared_cache [sqlite3_enable_shared_cache 1]
|
||||||
|
|
||||||
|
do_execsql_test 1.1 { CREATE VIRTUAL TABLE t1 USING fts4 }
|
||||||
|
|
||||||
|
do_test 1.2 {
|
||||||
|
for {set i 0} {$i < 2000} {incr i} {
|
||||||
|
execsql {INSERT INTO t1 VALUES('a b c d e f g h i j k l');}
|
||||||
|
}
|
||||||
|
} {}
|
||||||
|
|
||||||
|
do_test 1.3 {
|
||||||
|
execsql BEGIN
|
||||||
|
for {set i 0} {$i < 2000} {incr i} {
|
||||||
|
execsql {INSERT INTO t1 VALUES('a b c d e f g h i j k l');}
|
||||||
|
}
|
||||||
|
execsql {
|
||||||
|
INSERT INTO t1(t1) VALUES('merge=8,50');
|
||||||
|
COMMIT
|
||||||
|
}
|
||||||
|
} {}
|
||||||
|
|
||||||
|
reset_db
|
||||||
|
do_execsql_test 2.0 { CREATE VIRTUAL TABLE t1 USING fts4 }
|
||||||
|
do_test 2.1 {
|
||||||
|
for {set i 0} {$i < 2000} {incr i} {
|
||||||
|
execsql {INSERT INTO t1 VALUES('a b c d e f g h i j k l');}
|
||||||
|
}
|
||||||
|
} {}
|
||||||
|
do_execsql_test 2.2 { SELECT count(*) FROM t1_segdir; } 35
|
||||||
|
do_execsql_test 2.3 { INSERT INTO t1(t1) VALUES('optimize') } {}
|
||||||
|
do_execsql_test 2.4 { SELECT count(*) FROM t1_segdir; } 1
|
||||||
|
|
||||||
|
|
||||||
|
sqlite3_enable_shared_cache $::enable_shared_cache
|
||||||
|
finish_test
|
207
test/percentile.test
Normal file
207
test/percentile.test
Normal file
@ -0,0 +1,207 @@
|
|||||||
|
# 2013-05-28
|
||||||
|
#
|
||||||
|
# The author disclaims copyright to this source code. In place of
|
||||||
|
# a legal notice, here is a blessing:
|
||||||
|
#
|
||||||
|
# May you do good and not evil.
|
||||||
|
# May you find forgiveness for yourself and forgive others.
|
||||||
|
# May you share freely, never taking more than you give.
|
||||||
|
#
|
||||||
|
#***********************************************************************
|
||||||
|
# This file implements regression tests for SQLite library. The
|
||||||
|
# focus of this file is percentile.c extension
|
||||||
|
#
|
||||||
|
|
||||||
|
set testdir [file dirname $argv0]
|
||||||
|
source $testdir/tester.tcl
|
||||||
|
|
||||||
|
# Basic test of the percentile() function.
|
||||||
|
#
|
||||||
|
do_test percentile-1.0 {
|
||||||
|
load_static_extension db percentile
|
||||||
|
execsql {
|
||||||
|
CREATE TABLE t1(x);
|
||||||
|
INSERT INTO t1 VALUES(1),(4),(6),(7),(8),(9),(11),(11),(11);
|
||||||
|
}
|
||||||
|
execsql {SELECT percentile(x,0) FROM t1}
|
||||||
|
} {1.0}
|
||||||
|
foreach {in out} {
|
||||||
|
100 11.0
|
||||||
|
50 8.0
|
||||||
|
12.5 4.0
|
||||||
|
15 4.4
|
||||||
|
20 5.2
|
||||||
|
80 11.0
|
||||||
|
89 11.0
|
||||||
|
} {
|
||||||
|
do_test percentile-1.1.$in {
|
||||||
|
execsql {SELECT percentile(x,$in) FROM t1}
|
||||||
|
} $out
|
||||||
|
}
|
||||||
|
|
||||||
|
# Add some NULL values.
|
||||||
|
#
|
||||||
|
do_test percentile-1.2 {
|
||||||
|
execsql {INSERT INTO t1 VALUES(NULL),(NULL);}
|
||||||
|
} {}
|
||||||
|
foreach {in out} {
|
||||||
|
100 11.0
|
||||||
|
50 8.0
|
||||||
|
12.5 4.0
|
||||||
|
15 4.4
|
||||||
|
20 5.2
|
||||||
|
80 11.0
|
||||||
|
89 11.0
|
||||||
|
} {
|
||||||
|
do_test percentile-1.3.$in {
|
||||||
|
execsql {SELECT percentile(x,$in) FROM t1}
|
||||||
|
} $out
|
||||||
|
}
|
||||||
|
|
||||||
|
# The second argument to percentile can change some, but not much.
|
||||||
|
#
|
||||||
|
do_test percentile-1.4 {
|
||||||
|
catchsql {SELECT round(percentile(x, 15+0.000001*rowid),1) FROM t1}
|
||||||
|
} {0 4.4}
|
||||||
|
do_test percentile-1.5 {
|
||||||
|
catchsql {SELECT round(percentile(x, 15+0.1*rowid),1) FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not the same for all input rows}}
|
||||||
|
|
||||||
|
# Input values in a random order
|
||||||
|
#
|
||||||
|
do_test percentile-1.6 {
|
||||||
|
execsql {
|
||||||
|
CREATE TABLE t2(x);
|
||||||
|
INSERT INTO t2 SELECT x+0.0 FROM t1 ORDER BY random();
|
||||||
|
}
|
||||||
|
} {}
|
||||||
|
foreach {in out} {
|
||||||
|
100 11.0
|
||||||
|
50 8.0
|
||||||
|
12.5 4.0
|
||||||
|
15 4.4
|
||||||
|
20 5.2
|
||||||
|
80 11.0
|
||||||
|
89 11.0
|
||||||
|
} {
|
||||||
|
do_test percentile-1.7.$in {
|
||||||
|
execsql {SELECT percentile(x,$in) FROM t2}
|
||||||
|
} $out
|
||||||
|
}
|
||||||
|
|
||||||
|
# Wrong number of arguments
|
||||||
|
#
|
||||||
|
do_test percentile-1.8 {
|
||||||
|
catchsql {SELECT percentile(x,0,1) FROM t1}
|
||||||
|
} {1 {wrong number of arguments to function percentile()}}
|
||||||
|
do_test percentile-1.9 {
|
||||||
|
catchsql {SELECT percentile(x) FROM t1}
|
||||||
|
} {1 {wrong number of arguments to function percentile()}}
|
||||||
|
|
||||||
|
# Second argument must be numeric
|
||||||
|
#
|
||||||
|
do_test percentile-1.10 {
|
||||||
|
catchsql {SELECT percentile(x,null) FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not a number between 0.0 and 100.0}}
|
||||||
|
do_test percentile-1.11 {
|
||||||
|
catchsql {SELECT percentile(x,'fifty') FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not a number between 0.0 and 100.0}}
|
||||||
|
do_test percentile-1.12 {
|
||||||
|
catchsql {SELECT percentile(x,x'3530') FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not a number between 0.0 and 100.0}}
|
||||||
|
|
||||||
|
# Second argument is out of range
|
||||||
|
#
|
||||||
|
do_test percentile-1.13 {
|
||||||
|
catchsql {SELECT percentile(x,-0.0000001) FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not a number between 0.0 and 100.0}}
|
||||||
|
do_test percentile-1.14 {
|
||||||
|
catchsql {SELECT percentile(x,100.0000001) FROM t1}
|
||||||
|
} {1 {2nd argument to percentile() is not a number between 0.0 and 100.0}}
|
||||||
|
|
||||||
|
# First argument is not NULL and is not NUMERIC
|
||||||
|
#
|
||||||
|
do_test percentile-1.15 {
|
||||||
|
catchsql {
|
||||||
|
BEGIN;
|
||||||
|
UPDATE t1 SET x='50' WHERE x IS NULL;
|
||||||
|
SELECT percentile(x, 50) FROM t1;
|
||||||
|
}
|
||||||
|
} {1 {1st argument to percentile() is not numeric}}
|
||||||
|
do_test percentile-1.16 {
|
||||||
|
catchsql {
|
||||||
|
ROLLBACK;
|
||||||
|
BEGIN;
|
||||||
|
UPDATE t1 SET x=x'3530' WHERE x IS NULL;
|
||||||
|
SELECT percentile(x, 50) FROM t1;
|
||||||
|
}
|
||||||
|
} {1 {1st argument to percentile() is not numeric}}
|
||||||
|
do_test percentile-1.17 {
|
||||||
|
catchsql {
|
||||||
|
ROLLBACK;
|
||||||
|
SELECT percentile(x, 50) FROM t1;
|
||||||
|
}
|
||||||
|
} {0 8.0}
|
||||||
|
|
||||||
|
# No non-NULL entries.
|
||||||
|
#
|
||||||
|
do_test percentile-1.18 {
|
||||||
|
execsql {
|
||||||
|
UPDATE t1 SET x=NULL;
|
||||||
|
SELECT ifnull(percentile(x, 50),'NULL') FROM t1
|
||||||
|
}
|
||||||
|
} {NULL}
|
||||||
|
|
||||||
|
# Exactly one non-NULL entry
|
||||||
|
#
|
||||||
|
do_test percentile-1.19 {
|
||||||
|
execsql {
|
||||||
|
UPDATE t1 SET x=12345 WHERE rowid=5;
|
||||||
|
SELECT percentile(x, 0), percentile(x, 50), percentile(x,100) FROM t1
|
||||||
|
}
|
||||||
|
} {12345.0 12345.0 12345.0}
|
||||||
|
|
||||||
|
# Infinity as an input
|
||||||
|
#
|
||||||
|
do_test percentile-1.20 {
|
||||||
|
catchsql {
|
||||||
|
DELETE FROM t1;
|
||||||
|
INSERT INTO t1 SELECT x+0.0 FROM t2;
|
||||||
|
UPDATE t1 SET x=1.0e300*1.0e300 WHERE rowid=5;
|
||||||
|
SELECT percentile(x,50) from t1;
|
||||||
|
}
|
||||||
|
} {1 {Inf input to percentile()}}
|
||||||
|
do_test percentile-1.21 {
|
||||||
|
catchsql {
|
||||||
|
UPDATE t1 SET x=-1.0e300*1.0e300 WHERE rowid=5;
|
||||||
|
SELECT percentile(x,50) from t1;
|
||||||
|
}
|
||||||
|
} {1 {Inf input to percentile()}}
|
||||||
|
|
||||||
|
# Million-row Inputs
|
||||||
|
#
|
||||||
|
do_test percentile-2.0 {
|
||||||
|
load_static_extension db wholenumber
|
||||||
|
execsql {
|
||||||
|
CREATE VIRTUAL TABLE nums USING wholenumber;
|
||||||
|
CREATE TABLE t3(x);
|
||||||
|
INSERT INTO t3 SELECT value-1 FROM nums WHERE value BETWEEN 1 AND 500000;
|
||||||
|
INSERT INTO t3 SELECT value*10 FROM nums
|
||||||
|
WHERE value BETWEEN 500000 AND 999999;
|
||||||
|
SELECT count(*) FROM t3;
|
||||||
|
}
|
||||||
|
} {1000000}
|
||||||
|
foreach {in out} {
|
||||||
|
0 0.0
|
||||||
|
100 9999990.0
|
||||||
|
50 2749999.5
|
||||||
|
10 99999.9
|
||||||
|
} {
|
||||||
|
do_test percentile-2.1.$in {
|
||||||
|
execsql {
|
||||||
|
SELECT percentile(x, $in) from t3;
|
||||||
|
}
|
||||||
|
} $out
|
||||||
|
}
|
||||||
|
|
||||||
|
finish_test
|
@ -128,6 +128,7 @@ ifcapable fts3 {
|
|||||||
INSERT INTO x1 VALUES('North northwest wind between 8 and 14 mph');
|
INSERT INTO x1 VALUES('North northwest wind between 8 and 14 mph');
|
||||||
} {
|
} {
|
||||||
"INSERT INTO x1 VALUES('North northwest wind between 8 and 14 mph');"
|
"INSERT INTO x1 VALUES('North northwest wind between 8 and 14 mph');"
|
||||||
|
"-- DELETE FROM 'main'.'x1_segdir' WHERE level = ?"
|
||||||
"-- INSERT INTO 'main'.'x1_content' VALUES(?,(?))"
|
"-- INSERT INTO 'main'.'x1_content' VALUES(?,(?))"
|
||||||
"-- REPLACE INTO 'main'.'x1_docsize' VALUES(?,?)"
|
"-- REPLACE INTO 'main'.'x1_docsize' VALUES(?,?)"
|
||||||
"-- SELECT value FROM 'main'.'x1_stat' WHERE id=?"
|
"-- SELECT value FROM 'main'.'x1_stat' WHERE id=?"
|
||||||
|
70
tool/mkautoconfamal.sh
Normal file
70
tool/mkautoconfamal.sh
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# This script is used to build the amalgamation autoconf package.
|
||||||
|
# It assumes the following:
|
||||||
|
#
|
||||||
|
# 1. The files "sqlite3.c", "sqlite3.h" and "sqlite3ext.h"
|
||||||
|
# are available in the current directory.
|
||||||
|
#
|
||||||
|
# 2. Variable $TOP is set to the full path of the root directory
|
||||||
|
# of the SQLite source tree.
|
||||||
|
#
|
||||||
|
# 3. There is nothing of value in the ./mkpkg_tmp_dir directory.
|
||||||
|
# This is important, as the script executes "rm -rf ./mkpkg_tmp_dir".
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
# Bail out of the script if any command returns a non-zero exit
|
||||||
|
# status. Or if the script tries to use an unset variable. These
|
||||||
|
# may fail for old /bin/sh interpreters.
|
||||||
|
#
|
||||||
|
set -e
|
||||||
|
set -u
|
||||||
|
|
||||||
|
TMPSPACE=./mkpkg_tmp_dir
|
||||||
|
VERSION=`cat $TOP/VERSION`
|
||||||
|
|
||||||
|
rm -rf $TMPSPACE
|
||||||
|
cp -R $TOP/autoconf $TMPSPACE
|
||||||
|
|
||||||
|
cp sqlite3.c $TMPSPACE
|
||||||
|
cp sqlite3.h $TMPSPACE
|
||||||
|
cp sqlite3ext.h $TMPSPACE
|
||||||
|
cp $TOP/sqlite3.1 $TMPSPACE
|
||||||
|
cp $TOP/sqlite3.pc.in $TMPSPACE
|
||||||
|
cp $TOP/src/shell.c $TMPSPACE
|
||||||
|
|
||||||
|
chmod 755 $TMPSPACE/install-sh
|
||||||
|
chmod 755 $TMPSPACE/missing
|
||||||
|
chmod 755 $TMPSPACE/depcomp
|
||||||
|
chmod 755 $TMPSPACE/config.sub
|
||||||
|
chmod 755 $TMPSPACE/config.guess
|
||||||
|
|
||||||
|
cat $TMPSPACE/configure.ac |
|
||||||
|
sed "s/AC_INIT(sqlite, .*, http:\/\/www.sqlite.org)/AC_INIT(sqlite, $VERSION, http:\/\/www.sqlite.org)/" > $TMPSPACE/tmp
|
||||||
|
mv $TMPSPACE/tmp $TMPSPACE/configure.ac
|
||||||
|
|
||||||
|
cd $TMPSPACE
|
||||||
|
aclocal
|
||||||
|
autoconf
|
||||||
|
automake
|
||||||
|
|
||||||
|
mkdir -p tea/generic
|
||||||
|
echo "#ifdef USE_SYSTEM_SQLITE" > tea/generic/tclsqlite3.c
|
||||||
|
echo "# include <sqlite3.h>" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#else" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#include \"../../sqlite3.c\"" >> tea/generic/tclsqlite3.c
|
||||||
|
echo "#endif" >> tea/generic/tclsqlite3.c
|
||||||
|
cat $TOP/src/tclsqlite.c >> tea/generic/tclsqlite3.c
|
||||||
|
|
||||||
|
cat tea/configure.in |
|
||||||
|
sed "s/AC_INIT(\[sqlite\], .*)/AC_INIT([sqlite], [$VERSION])/" > tmp
|
||||||
|
mv tmp tea/configure.in
|
||||||
|
|
||||||
|
cd tea
|
||||||
|
autoconf
|
||||||
|
rm -rf autom4te.cache
|
||||||
|
|
||||||
|
cd ../
|
||||||
|
./configure && make dist
|
||||||
|
mv sqlite-$VERSION.tar.gz ../sqlite-amalgamation-$VERSION.tar.gz
|
||||||
|
|
Loading…
Reference in New Issue
Block a user