(defun my-close-children () (interactive) (cperl-mode) (end-of-buffer) (let ((p t)) (while (setq p (search-backward-regexp "\\ \\[" nil t)) (progn (search-forward "[") (backward-char) (forward-sexp) (backward-char) (if (not (string-equal (buffer-substring (point) (1+ (point))) "]")) (insert "]")) (goto-char p)))) (save-buffer) (kill-emacs) )