⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mksqlite3c.tcl

📁 sqlite-3.4.1,嵌入式数据库.是一个功能强大的开源数据库,给学习和研发以及小型公司的发展带来了全所未有的好处.
💻 TCL
字号:
#!/usr/bin/tclsh## To build a single huge source file holding all of SQLite (or at# least the core components - the test harness, shell, and TCL # interface are omitted.) first do##      make target_source## The make target above moves all of the source code files into# a subdirectory named "tsrc".  (This script expects to find the files# there and will not work if they are not found.)  There are a few# generated C code files that are also added to the tsrc directory.# For example, the "parse.c" and "parse.h" files to implement the# the parser are derived from "parse.y" using lemon.  And the # "keywordhash.h" files is generated by a program named "mkkeywordhash".## After the "tsrc" directory has been created and populated, run# this script:##      tclsh mksqlite3c.tcl## The amalgamated SQLite code will be written into sqlite3.c## Begin by reading the "sqlite3.h" header file.  Count the number of lines# in this file and extract the version number.  That information will be# needed in order to generate the header of the amalgamation.#if {[lsearch $argv --nostatic]>=0} {  set addstatic 0} else {  set addstatic 1}set in [open tsrc/sqlite3.h]set cnt 0set VERSION ?????while {![eof $in]} {  set line [gets $in]  if {$line=="" && [eof $in]} break  incr cnt  regexp {#define\s+SQLITE_VERSION\s+"(.*)"} $line all VERSION}close $in# Open the output file and write a header comment at the beginning# of the file.#set out [open sqlite3.c w]set today [clock format [clock seconds] -format "%Y-%m-%d %H:%M:%S UTC" -gmt 1]puts $out [subst \{/******************************************************************************** This file is an amalgamation of many separate C source files from SQLite** version $VERSION.  By combining all the individual C code files into this ** single large file, the entire code can be compiled as a one translation** unit.  This allows many compilers to do optimizations that would not be** possible if the files were compiled separately.  Performance improvements** of 5% are more are commonly seen when SQLite is compiled as a single** translation unit.**** This file is all you need to compile SQLite.  To use SQLite in other** programs, you need this file and the "sqlite3.h" header file that defines** the programming interface to the SQLite library.  (If you do not have ** the "sqlite3.h" header file at hand, you will find a copy in the first** $cnt lines past this header comment.)  Additional code files may be** needed if you want a wrapper to interface SQLite with your choice of** programming language.  The code for the "sqlite3" command-line shell** is also in a separate file.  This file contains only code for the core** SQLite library.**** This amalgamation was generated on $today.*/#define SQLITE_AMALGAMATION 1}]if {$addstatic} {  puts $out \{#ifndef SQLITE_PRIVATE# define SQLITE_PRIVATE static#endif#ifndef SQLITE_API# define SQLITE_API#endif}}# These are the header files used by SQLite.  The first time any of these # files are seen in a #include statement in the C code, include the complete# text of the file in-line.  The file only needs to be included once.#foreach hdr {   btree.h   btreeInt.h   hash.h   keywordhash.h   opcodes.h   os_common.h   os.h   os_os2.h   pager.h   parse.h   sqlite3ext.h   sqlite3.h   sqliteInt.h   sqliteLimit.h   vdbe.h   vdbeInt.h} {  set available_hdr($hdr) 1}set available_hdr(sqlite3.h) 0# 78 stars used for comment formatting.set s78 \{*****************************************************************************}# Insert a comment into the code#proc section_comment {text} {  global out s78  set n [string length $text]  set nstar [expr {60 - $n}]  set stars [string range $s78 0 $nstar]  puts $out "/************** $text $stars/"}# Read the source file named $filename and write it into the# sqlite3.c output file.  If any #include statements are seen,# process them approprately.#proc copy_file {filename} {  global seen_hdr available_hdr out addstatic  set tail [file tail $filename]  section_comment "Begin file $tail"  set in [open $filename r]  if {[file extension $filename]==".h"} {    set declpattern {^ *[a-zA-Z][a-zA-Z_0-9 ]+ \*?(sqlite3[_A-Z][a-zA-Z0-9]+)\(}  } else {    set declpattern {^[a-zA-Z][a-zA-Z_0-9 ]+ \*?(sqlite3[_A-Z][a-zA-Z0-9]+)\(}  }  while {![eof $in]} {    set line [gets $in]    if {[regexp {^#\s*include\s+["<]([^">]+)[">]} $line all hdr]} {      if {[info exists available_hdr($hdr)]} {        if {$available_hdr($hdr)} {          if {$hdr!="os_common.h"} {            set available_hdr($hdr) 0          }          section_comment "Include $hdr in the middle of $tail"          copy_file tsrc/$hdr          section_comment "Continuing where we left off in $tail"        }      } elseif {![info exists seen_hdr($hdr)]} {        set seen_hdr($hdr) 1        puts $out $line      }    } elseif {[regexp {^#ifdef __cplusplus} $line]} {      puts $out "#if 0"    } elseif {[regexp {^#line} $line]} {      # Skip #line directives.    } elseif {$addstatic && [regexp $declpattern $line all funcname]                   && ![regexp {^static} $line]} {      # Add the SQLITE_PRIVATE or SQLITE_API keyword before functions.      # so that linkage can be modified at compile-time.      if {[regexp {^sqlite3_} $funcname]} {        puts $out "SQLITE_API $line"      } else {        puts $out "SQLITE_PRIVATE $line"      }    } else {      puts $out $line    }  }  close $in  section_comment "End of $tail"}# Process the source files.  Process files containing commonly# used subroutines first in order to help the compiler find# inlining opportunities.#foreach file {   sqlite3.h   date.c   os.c   malloc.c   printf.c   random.c   utf.c   util.c   hash.c   opcodes.c   os_os2.c   os_unix.c   os_win.c   pager.c      btree.c   vdbefifo.c   vdbemem.c   vdbeaux.c   vdbeapi.c   vdbe.c   vdbeblob.c   expr.c   alter.c   analyze.c   attach.c   auth.c   build.c   callback.c   complete.c   delete.c   func.c   insert.c   legacy.c   loadext.c   pragma.c   prepare.c   select.c   table.c   trigger.c   update.c   vacuum.c   vtab.c   where.c   parse.c   tokenize.c   main.c} {  copy_file tsrc/$file}close $out

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -