X-Git-Url: https://git.hcoop.net/clinton/lisp-on-lines.git/blobdiff_plain/4e7631c95e2ad041f95c5c0377d9d5cf15df8658..da26d00333fa0ced964dc777a00bd917c543e4ed:/src/meta-model.lisp diff --git a/src/meta-model.lisp b/src/meta-model.lisp index 4416423..09f7f6f 100644 --- a/src/meta-model.lisp +++ b/src/meta-model.lisp @@ -156,14 +156,23 @@ most of the below functions expect this method to exist" :test-key :target-slot :return-full t))) -(defmethod explode-foreign-key ((model clsql:standard-db-object) slot) +(defmethod explode-foreign-key ((model clsql:standard-db-object) slot &key (createp t)) "returns the clsql view-class joined on SLOT" (dolist (s (list-join-attributes model)) (when (equal (getf (cdr s) :home-key) slot) - (let ((val (slot-value model (car s)))) - (return-from explode-foreign-key - (values (if val val (make-instance (getf (cdr s) :join-class))) - (getf (cdr s) :foreign-key))))))) + (let* ((fkey (getf (cdr s) :foreign-key)) + (new (sync-instance (make-instance (getf (cdr s) :join-class)))) + (val (or (slot-value model (car s)) + (progn + (when createp + (setf + (slot-value model slot) + (slot-value new fkey)) + (sync-instance model) + (slot-value model (car s))))))) + + (return-from explode-foreign-key + (values val fkey)))))) (defun find-join-helper (foreign-key) (lambda (class slot)