+ changed condition hierachy: removed session and code fields from

root-condition because that information might not be available in
  all cases.

+ added session and code fields to &ldap-data-error,
  &ldap-security-error and &ldap-service-error

+ fixed raise-ldap-condition to distinguish conditions with/without
  fields session and code
This commit is contained in:
eknauel 2004-02-16 08:29:00 +00:00
parent 29f82084b3
commit b9e53e5cc6
1 changed files with 16 additions and 10 deletions

View File

@ -1,18 +1,22 @@
;; conditions with sub-conditions
(define-condition-type &ldap-error &condition
ldap-error?
ldap-error?)
(define-condition-type &ldap-data-error &ldap-error
ldap-data-error?
(code ldap-error-code)
(session ldap-error-session))
(define-condition-type &ldap-data-error &ldap-error
ldap-data-error?)
(define-condition-type &ldap-security-error &ldap-error
ldap-security-error?)
ldap-security-error?
(code ldap-error-code)
(session ldap-error-session))
(define-condition-type &ldap-service-error &ldap-error
ldap-service-error?)
ldap-service-error?
(code ldap-error-code)
(session ldap-error-session))
(define-condition-type &ldap-bindings-error &ldap-error
ldap-bindings-error?)
@ -228,14 +232,16 @@
(,(ldap-return not-supported) ,&ldap-not-supported)
(,(ldap-return control-not-found) ,&ldap-control-not-found)
(,(ldap-return referral-limit-exceeded) ,&ldap-referral-limit-exceeded))))
(lambda (return-object session)
(lambda (return-object ldap-session)
(cond
((assoc return-object alist)
=> (lambda (p)
(let ((the-condition (cadr p)))
(if (ldap-bindings-error? the-condition)
(raise (condition (the-condition)))
(raise (condition (the-condition
(code return-object)
(session session)))))))
(session ldap-session))))))))
(else
(raise
(condition (&ldap-bindings-internal-error