class Sqlite < Formula desc "Command-line interface for SQLite" homepage "https://sqlite.org/" url "https://sqlite.org/2018/sqlite-autoconf-3240000.tar.gz" version "3.24.0" sha256 "d9d14e88c6fb6d68de9ca0d1f9797477d82fc3aed613558f87ffbdbbc5ceb74a" bottle do cellar :any sha256 "a51a1d0a22f6648b41980363dae433223785b55cf62bd9c67a78c15eadad7a99" => :high_sierra sha256 "420f968d54ba111108f4e53d99765dfba26fb4ad2c2e1f6836d5c6ab82358692" => :sierra sha256 "be63f67e5dd205236d60823bb733381a787c6a82ecbe3b6f85c5cc35dd7a67ae" => :el_capitan end keg_only :provided_by_macos, "macOS provides an older sqlite3" option "with-docs", "Install HTML documentation" option "without-rtree", "Disable the R*Tree index module" option "with-fts", "Enable the FTS3 module" option "with-fts5", "Enable the FTS5 module (experimental)" option "with-secure-delete", "Defaults secure_delete to on" option "with-unlock-notify", "Enable the unlock notification feature" option "with-icu4c", "Enable the ICU module" option "with-functions", "Enable more math and string functions for SQL queries" option "with-dbstat", "Enable the 'dbstat' virtual table" option "with-json1", "Enable the JSON1 extension" option "with-session", "Enable the session extension" option "with-soundex", "Enable the SOUNDEX function" depends_on "readline" => :recommended depends_on "icu4c" => :optional resource "functions" do url "https://sqlite.org/contrib/download/extension-functions.c?get=25", :using => :nounzip version "2010-02-06" sha256 "991b40fe8b2799edc215f7260b890f14a833512c9d9896aa080891330ffe4052" end resource "docs" do url "https://sqlite.org/2018/sqlite-doc-3240000.zip" version "3.24.0" sha256 "77b104df2b57a32c40d0336bbf77ab013a1a95ab49a5fe0ea92250e9f2ae82c1" end def install ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_COLUMN_METADATA=1" # Default value of MAX_VARIABLE_NUMBER is 999 which is too low for many # applications. Set to 250000 (Same value used in Debian and Ubuntu). ENV.append "CPPFLAGS", "-DSQLITE_MAX_VARIABLE_NUMBER=250000" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_RTREE=1" if build.with? "rtree" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_FTS3=1 -DSQLITE_ENABLE_FTS3_PARENTHESIS=1" if build.with? "fts" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_FTS5=1" if build.with? "fts5" ENV.append "CPPFLAGS", "-DSQLITE_SECURE_DELETE=1" if build.with? "secure-delete" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_UNLOCK_NOTIFY=1" if build.with? "unlock-notify" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_DBSTAT_VTAB=1" if build.with? "dbstat" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_JSON1=1" if build.with? "json1" ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_PREUPDATE_HOOK=1 -DSQLITE_ENABLE_SESSION=1" if build.with? "session" ENV.append "CPPFLAGS", "-DSQLITE_SOUNDEX" if build.with? "soundex" if build.with? "icu4c" icu4c = Formula["icu4c"] icu4cldflags = `#{icu4c.opt_bin}/icu-config --ldflags`.tr("\n", " ") icu4ccppflags = `#{icu4c.opt_bin}/icu-config --cppflags`.tr("\n", " ") ENV.append "LDFLAGS", icu4cldflags ENV.append "CPPFLAGS", icu4ccppflags ENV.append "CPPFLAGS", "-DSQLITE_ENABLE_ICU=1" end args = [ "--prefix=#{prefix}", "--disable-dependency-tracking", "--enable-dynamic-extensions", ] args << "--enable-readline" << "--disable-editline" if build.with? "readline" system "./configure", *args system "make", "install" if build.with? "functions" buildpath.install resource("functions") system ENV.cc, "-fno-common", "-dynamiclib", "extension-functions.c", "-o", "libsqlitefunctions.dylib", *ENV.cflags.to_s.split lib.install "libsqlitefunctions.dylib" end doc.install resource("docs") if build.with? "docs" end def caveats s = "" if build.with? "functions" s += <<~EOS Usage instructions for applications calling the sqlite3 API functions: In your application, call sqlite3_enable_load_extension(db,1) to allow loading external libraries. Then load the library libsqlitefunctions using sqlite3_load_extension; the third argument should be 0. See https://sqlite.org/loadext.html. Select statements may now use these functions, as in SELECT cos(radians(inclination)) FROM satsum WHERE satnum = 25544; Usage instructions for the sqlite3 program: If the program is built so that loading extensions is permitted, the following will work: sqlite> SELECT load_extension('#{lib}/libsqlitefunctions.dylib'); sqlite> select cos(radians(45)); 0.707106781186548 EOS end if build.with? "readline" user_history = "~/.sqlite_history" user_history_path = File.expand_path(user_history) if File.exist?(user_history_path) && File.read(user_history_path).include?("\\040") s += <<~EOS Homebrew has detected an existing SQLite history file that was created with the editline library. The current version of this formula is built with Readline. To back up and convert your history file so that it can be used with Readline, run: sed -i~ 's/\\\\040/ /g' #{user_history} before using the `sqlite` command-line tool again. Otherwise, your history will be lost. EOS end end s end test do path = testpath/"school.sql" path.write <<~EOS create table students (name text, age integer); insert into students (name, age) values ('Bob', 14); insert into students (name, age) values ('Sue', 12); insert into students (name, age) values ('Tim', 13); select name from students order by age asc; EOS names = shell_output("#{bin}/sqlite3 < #{path}").strip.split("\n") assert_equal %w[Sue Tim Bob], names end end