blob: 3f59aef4675dd478b48a7fd253c60896e25f6509 [file] [log] [blame]
danielk19772d04deb2009-08-11 05:50:36 +00001#!/usr/bin/tclsh
2#
drh47baebc2009-08-14 16:01:24 +00003# This script constructs the "sqlite3.h" header file from the following
4# sources:
5#
6# 1) The src/sqlite.h.in source file. This is the template for sqlite3.h.
7# 2) The VERSION file containing the current SQLite version number.
8# 3) The manifest file from the fossil SCM. This gives use the date.
9# 4) The manifest.uuid file from the fossil SCM. This gives the SHA1 hash.
10#
11# Run this script by specifying the root directory of the source tree
12# on the command-line.
13#
danielk19772d04deb2009-08-11 05:50:36 +000014# This script performs processing on src/sqlite.h.in. It:
15#
16# 1) Adds SQLITE_EXTERN in front of the declaration of global variables,
17# 2) Adds SQLITE_API in front of the declaration of API functions,
18# 3) Replaces the string --VERS-- with the current library version,
19# formatted as a string (e.g. "3.6.17"), and
20# 4) Replaces the string --VERSION-NUMBER-- with current library version,
21# formatted as an integer (e.g. "3006017").
drh47baebc2009-08-14 16:01:24 +000022# 5) Replaces the string --SOURCE-ID-- with the date and time and sha1
23# hash of the fossil-scm manifest for the source tree.
danielk19772d04deb2009-08-11 05:50:36 +000024#
drh47baebc2009-08-14 16:01:24 +000025# This script outputs to stdout.
danielk19772d04deb2009-08-11 05:50:36 +000026#
drh47baebc2009-08-14 16:01:24 +000027# Example usage:
28#
29# tclsh mksqlite3h.tcl ../sqlite >sqlite3.h
danielk19772d04deb2009-08-11 05:50:36 +000030#
31
drh47baebc2009-08-14 16:01:24 +000032
33# Get the source tree root directory from the command-line
34#
35set TOP [lindex $argv 0]
36
37# Get the SQLite version number (ex: 3.6.18) from the $TOP/VERSION file.
38#
39set in [open $TOP/VERSION]
40set zVersion [string trim [read $in]]
41close $in
danielk19772d04deb2009-08-11 05:50:36 +000042set nVersion [eval format "%d%03d%03d" [split $zVersion .]]
43
drh47baebc2009-08-14 16:01:24 +000044# Get the fossil-scm version number from $TOP/manifest.uuid.
45#
46set in [open $TOP/manifest.uuid]
47set zUuid [string trim [read $in]]
48close $in
danielk19772d04deb2009-08-11 05:50:36 +000049
drh47baebc2009-08-14 16:01:24 +000050# Get the fossil-scm check-in date from the "D" card of $TOP/manifest.
51#
52set in [open $TOP/manifest]
53set zDate {}
54while {![eof $in]} {
55 set line [gets $in]
drhbbd91942011-01-11 12:46:05 +000056 if {[regexp {^D (2[-0-9T:]+)} $line all date]} {
drh47baebc2009-08-14 16:01:24 +000057 set zDate [string map {T { }} $date]
58 break
59 }
60}
61close $in
62
63# Set up patterns for recognizing API declarations.
64#
65set varpattern {^[a-zA-Z][a-zA-Z_0-9 *]+sqlite3_[_a-zA-Z0-9]+(\[|;| =)}
mistachkin59b9b022015-03-24 21:27:27 +000066set declpattern {^ *([a-zA-Z][a-zA-Z_0-9 ]+ \**)(sqlite3_[_a-zA-Z0-9]+)(\(.*)$}
drh47baebc2009-08-14 16:01:24 +000067
shaneh5e0fb2c2011-06-17 15:54:59 +000068# Force the output to use unix line endings, even on Windows.
69fconfigure stdout -translation lf
70
drh339d6c62013-03-19 16:12:40 +000071set filelist [subst {
72 $TOP/src/sqlite.h.in
73 $TOP/ext/rtree/sqlite3rtree.h
drh50065652015-10-08 19:29:18 +000074 $TOP/ext/fts5/fts5.h
drh339d6c62013-03-19 16:12:40 +000075}]
76
mistachkin59b9b022015-03-24 21:27:27 +000077# These are the functions that accept a variable number of arguments. They
78# always need to use the "cdecl" calling convention even when another calling
79# convention (e.g. "stcall") is being used for the rest of the library.
80set cdecllist {
81 sqlite3_config
82 sqlite3_db_config
83 sqlite3_log
84 sqlite3_mprintf
85 sqlite3_snprintf
86 sqlite3_test_control
87 sqlite3_vtab_config
88}
89
drh339d6c62013-03-19 16:12:40 +000090# Process the source files.
drh47baebc2009-08-14 16:01:24 +000091#
drh339d6c62013-03-19 16:12:40 +000092foreach file $filelist {
danc223b8f2010-08-30 18:39:49 +000093 set in [open $file]
94 while {![eof $in]} {
95
96 set line [gets $in]
drh47baebc2009-08-14 16:01:24 +000097
danc223b8f2010-08-30 18:39:49 +000098 # File sqlite3rtree.h contains a line "#include <sqlite3.h>". Omit this
99 # line when copying sqlite3rtree.h into sqlite3.h.
100 #
drh9676c482015-10-15 12:06:11 +0000101 if {[string match {*#include*[<"]sqlite3.h[>"]*} $line]} continue
danc223b8f2010-08-30 18:39:49 +0000102
103 regsub -- --VERS-- $line $zVersion line
104 regsub -- --VERSION-NUMBER-- $line $nVersion line
105 regsub -- --SOURCE-ID-- $line "$zDate $zUuid" line
drh790fa6e2015-03-24 21:54:42 +0000106
mistachkin59b9b022015-03-24 21:27:27 +0000107 if {[regexp $varpattern $line] && ![regexp {^ *typedef} $line]} {
danc223b8f2010-08-30 18:39:49 +0000108 set line "SQLITE_API $line"
mistachkin59b9b022015-03-24 21:27:27 +0000109 } else {
110 if {[regexp $declpattern $line all rettype funcname rest]} {
111 set line SQLITE_API
112 append line " " [string trim $rettype]
113 if {[string index $rettype end] ne "*"} {
114 append line " "
115 }
116 if {[lsearch -exact $cdecllist $funcname] >= 0} {
117 append line SQLITE_CDECL
118 } else {
119 append line SQLITE_STDCALL
120 }
121 append line " " $funcname $rest
122 }
danc223b8f2010-08-30 18:39:49 +0000123 }
danielk19772d04deb2009-08-11 05:50:36 +0000124 puts $line
danielk19772d04deb2009-08-11 05:50:36 +0000125 }
danc223b8f2010-08-30 18:39:49 +0000126 close $in
danielk19772d04deb2009-08-11 05:50:36 +0000127}