"Enter the group at the current line."
(interactive)
(let ((group (gnus-browse-group-name)))
- (unless (gnus-group-read-ephemeral-group
- group gnus-browse-current-method nil
- (cons (current-buffer) 'browse))
- (error "Couldn't enter %s" group))))
-
+ (if (or (not (gnus-get-info group))
+ (gnus-ephemeral-group-p group))
+ (unless (gnus-group-read-ephemeral-group
+ group gnus-browse-current-method nil
+ (cons (current-buffer) 'browse))
+ (error "Couldn't enter %s" group))
+ (unless (gnus-group-read-group nil no-article group)
+ (error "Couldn't enter %s" group)))))
+
(defun gnus-browse-select-group ()
"Select the current group."
(interactive)
;; If this group it killed, then we want to subscribe it.
(when (= (following-char) ?K)
(setq sub t))
- (when (cadr (gnus-gethash (setq group (gnus-browse-group-name))
- gnus-newsrc-hashtb))
+ (setq group (gnus-browse-group-name))
+ (when (and sub
+ (cadr (gnus-gethash group gnus-newsrc-hashtb)))
(error "Group already subscribed"))
- ;; Make sure the group has been properly removed before we
- ;; subscribe to it.
- (gnus-kill-ephemeral-group group)
(delete-char 1)
(if sub
(progn
+ ;; Make sure the group has been properly removed before we
+ ;; subscribe to it.
+ (gnus-kill-ephemeral-group group)
(gnus-group-change-level
(list t group gnus-level-default-subscribed
nil nil (if (gnus-server-equal