X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=db-postgresql-socket%2Fpostgresql-socket-api.lisp;h=13ce8e9965d2f5a1765796c904c4bdaabd5e162f;hb=5691bb90517d7c565a141d131da76c3de1f8d566;hp=9e9b10e406d9e00cd9482bedf3bc99e3fd907f12;hpb=8d558ce162d1360f92e4d65d054e2f61c786319e;p=clsql.git diff --git a/db-postgresql-socket/postgresql-socket-api.lisp b/db-postgresql-socket/postgresql-socket-api.lisp index 9e9b10e..13ce8e9 100644 --- a/db-postgresql-socket/postgresql-socket-api.lisp +++ b/db-postgresql-socket/postgresql-socket-api.lisp @@ -9,7 +9,7 @@ ;;;; ;;;; Date Started: Feb 2002 ;;;; -;;;; $Id: postgresql-socket-api.lisp,v 1.4 2003/05/02 03:05:54 kevin Exp $ +;;;; $Id$ ;;;; ;;;; This file, part of CLSQL, is Copyright (c) 2002 by Kevin M. Rosenberg ;;;; and Copyright (c) 1999-2001 by Pierre R. Mai @@ -29,8 +29,7 @@ ;;;; - Added field type processing -(declaim (optimize (debug 3) (speed 3) (safety 1) (compilation-speed 0))) -(in-package :postgresql-socket) +(in-package #:postgresql-socket) (uffi:def-enum pgsql-ftype ((:bytea 17) @@ -332,6 +331,15 @@ socket interface" :buffering :none :timeout *postgresql-server-socket-timeout*)) + +#+sbcl +(defun open-postgresql-socket-stream (host port) + (sb-sys:make-fd-stream + (open-postgresql-socket host port) + :input t :output t :element-type '(unsigned-byte 8) + :buffering :none + :timeout *postgresql-server-socket-timeout*)) + #+allegro (defun open-postgresql-socket-stream (host port) (etypecase host @@ -347,8 +355,7 @@ socket interface" (mp:with-timeout (*postgresql-server-socket-timeout* (error "connect failed")) (socket:make-socket :type :stream :address-family :internet :remote-port port :remote-host host - :connect :active :nodelay t)))) - )) + :connect :active :nodelay t)))))) #+lispworks (defun open-postgresql-socket-stream (host port) @@ -849,12 +856,12 @@ connection, if it is still open." (error 'postgresql-fatal-error :connection connection :message "Received garbled message from backend"))))))) -(defun run-query (connection query &optional (types nil)) +(defun run-query (connection query &optional (result-types nil)) (start-query-execution connection query) (multiple-value-bind (status cursor) (wait-for-query-results connection) (assert (eq status :cursor)) - (loop for row = (read-cursor-row cursor types) + (loop for row = (read-cursor-row cursor result-types) while row collect row finally