aboutsummaryrefslogtreecommitdiff
path: root/dump.scm
diff options
context:
space:
mode:
Diffstat (limited to 'dump.scm')
-rwxr-xr-xdump.scm37
1 files changed, 19 insertions, 18 deletions
diff --git a/dump.scm b/dump.scm
index 112cc1a..30cb8dd 100755
--- a/dump.scm
+++ b/dump.scm
@@ -1,7 +1,8 @@
#! /usr/bin/env guile
!#
-(use-modules (rnrs io ports)
+(use-modules (rnrs programs)
+ (rnrs io ports)
(srfi srfi-1)
(srfi srfi-26)
(ice-9 match)
@@ -13,25 +14,24 @@
;;; GeneNetwork database connection parameters and dump path
+(define %connection-settings
+ (call-with-input-file (list-ref (command-line) 0)
+ read))
+
(define (call-with-genenetwork-database proc)
- (let ((connection-settings (call-with-input-file "conn.scm" read)))
- (call-with-database "mysql" (string-join
- (list (assq-ref connection-settings 'username)
- (assq-ref connection-settings 'password)
- (assq-ref connection-settings 'database)
- "tcp"
- (assq-ref connection-settings 'host)
- (number->string
- (assq-ref connection-settings 'port)))
- ":")
- proc)))
-
-(define %database-name
- (assq-ref (call-with-input-file "conn.scm" read)
- 'database))
+ (call-with-database "mysql" (string-join
+ (list (assq-ref %connection-settings 'username)
+ (assq-ref %connection-settings 'password)
+ (assq-ref %connection-settings 'database)
+ "tcp"
+ (assq-ref %connection-settings 'host)
+ (number->string
+ (assq-ref %connection-settings 'port)))
+ ":")
+ proc))
(define %dump-directory
- (string-append (getenv "HOME") "/data/dump"))
+ (list-ref (command-line) 1))
(define (call-with-dump-file filename proc)
(let ((absolute-path (string-append %dump-directory filename)))
@@ -717,7 +717,8 @@ is a <table> object."
(select-query ((information_schema.tables table_name)
(information_schema.tables data_length))
(information_schema.tables)
- (format #f "WHERE table_schema = '~a'" %database-name)))))
+ (format #f "WHERE table_schema = '~a'"
+ (assq-ref %connection-settings 'database))))))
(define (dump-schema db)
(let ((tables (tables db)))