Skip to content
Fetching contributors…
Cannot retrieve contributors at this time
112 lines (90 sloc) 3.79 KB
;;; rdebug-fns.el --- Ruby debugger miscellaneous functions
;; Copyright (C) 2008 Rocky Bernstein (
;; Copyright (C) 2008 Anders Lindgren
;; $Id: rdebug-frames.el 711 2008-02-20 07:09:17Z andersl $
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING. If not, write to the
;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;; Boston, MA 02111-1307, USA.
;;; Commentary:
;; See the manual and the file `rdebug.el' for more information.
;; This file contains code dealing with the frames secondary buffer.
;;; Code:
(require 'gud)
(require 'rdebug-vars)
(defun chomp(string &optional multiple)
"Remove trailing \n if it's there"
(if multiple
(while (and (> (length string) 0)
(eq (elt string (- (length string) 1)) ?\n))
(setq string (substring string 0 -1)))
(if (> (length string) 0)
(let ((s string))
(if (string= "\n" (substring s -1))
(substring s 0 -1)
(defun rdebug-dead-process-p ()
"Return true if the rdebug comint-process is dead or exited."
;; FIXME? Use a variable in gud-comint-buffer's status?
(or (not gud-comint-buffer)
(null (get-buffer-process gud-comint-buffer))
(not (member (process-status gud-comint-buffer) '(run open)))))
(defun rdebug-get-secondary-buffer-name (name)
"Get the rdebug NAME secondary buffer. If none found return nil."
(let ((target-name
(or (and gud-comint-buffer
(buffer-local-value 'gud-target-name
(cond ((and (string= "cmd" name) gud-comint-buffer)
(buffer-name gud-comint-buffer))
(t (format "*rdebug-%s-%s*" name target-name)))))
(defun rdebug-set-frame-top-arrow (buf)
"Set the fringe arrow in BUF to indicate the top frame."
(with-current-buffer buf
(setq fringe-indicator-alist
'((overlay-arrow . right-triangle)))))
(defun rdebug-set-frame-not-top-arrow (buf)
"Set the fringe arrow in BUF to indicate a frame other than the top frame."
(with-current-buffer buf
(setq fringe-indicator-alist
'((overlay-arrow . hollow-right-triangle)))))
(defun rdebug-set-frame-arrow (buf)
"Set the fringe arrow in buffer BUF."
(if (equal 0 rdebug-frames-current-frame-number)
(rdebug-set-frame-top-arrow buf)
(rdebug-set-frame-not-top-arrow buf)))
;; From Emacs 23
(unless (fboundp 'split-string-and-unquote)
(defun split-string-and-unquote (string &optional separator)
"Split the STRING into a list of strings.
It understands Emacs Lisp quoting within STRING, such that
(split-string-and-unquote (combine-and-quote-strings strs)) == strs
The SEPARATOR regexp defaults to \"\\s-+\"."
(let ((sep (or separator "\\s-+"))
(i (string-match "[\"]" string)))
(if (null i)
(split-string string sep t) ; no quoting: easy
(append (unless (eq i 0) (split-string (substring string 0 i) sep t))
(let ((rfs (read-from-string string i)))
(cons (car rfs)
(split-string-and-unquote (substring string (cdr rfs))
(provide 'rdebug-fns)
;;; Local variables:
;;; eval:(put 'rdebug-debug-enter 'lisp-indent-hook 1)
;;; End:
;;; rdebug-fns.el ends here
Something went wrong with that request. Please try again.