* problem with fullscreen(now with actual attachment)
@ 2009-06-08 20:32 joakim
0 siblings, 0 replies; only message in thread
From: joakim @ 2009-06-08 20:32 UTC (permalink / raw)
To: Emacs Development
[-- Attachment #1: Type: text/plain, Size: 467 bytes --]
I have a mode which toggles full-screen and other things.
(find it attached)
It has worked well, but suddenly it has stopped working when I did an
emacs update. The problem is that the following code doesnt enter
fullscreen:
(set-frame-parameter nil 'fullscreen 'fullboth)
However, the fragment does work in an emacs -Q session.
So, it would appear some of my other emacs init code disables fullscreen
somehow. Any hints on where I should look?
--
Joakim Verona
[-- Attachment #2: zen-mode.el --]
[-- Type: text/plain, Size: 4104 bytes --]
;;; zen-mode.el --- remove/restore Emacs frame distractions quickly
;;; Copyright (C) 2008 Joakim Verona
;;Author: Joakim Verona, joakim@verona.se
;;License: GPL V3 or later
;;; Commentary:
;;
;;zen-mode is Emacs in fullscreen without toolbar and menubar
;;the function toggles between previous state of features and zen
;;
;;
;;I bind zen-mode to f11 like this:
;;;(global-set-key [f11] 'zen-mode)
;;
;;TODO:
;;
;;- Zen-master mode, like writeroom mode. (c-u m-x zen-mode), which
;; isn't customizable, it just turns all distractions off
;;
;;- There shouldnt just be a toogle, but a way to enter a specific
;; state, like scroll-bar-mode, probably with a numeric argument
;;
;;- Optionaly advice some modes like ERC so as not to interrupt while
;; in Zen, also dont Gnus while in Zen. You are supposed to concentrate :)
;;
;;- Currently zen isnt entered properly the 1st time, you have to try twice.
;;Note:
;; There are some problems in the Compiz WM, (and maybe other WM:s) regarding fullscreen:
;; When selecting another workspace temporarily and going back, Emacs
;; does not cover the wm panels as it should. This can be resolved with alt-tab a bit,
;; but its annoying. In Metacity it works well.
;;
;;
;;; History:
;;
;; 2008.08.17 -- v0.1
;;; Code:
(provide 'zen-mode)
(defvar zen-mode-is-active-p nil "If zen mode is currently active
or not.")
(defvar zen-mode-previous-state nil "The state of features to be
disabled in zen-mode, before entering zen-mode.")
(defgroup zen-mode nil "zen-mode"); :group 'some-apropriate-root-group)
(defcustom zen-mode-what-is-not-zen '()
"These Emacs features are not considered Zen.
They will be disabled when entering Zen. They will be restored
to their previous settings when leaving Zen."
:group 'zen-mode
:type
'(set :tag "zen"
(const scroll-bar-mode)
(const menu-bar-mode)
(const tool-bar-mode)
(const windowed-mode) ;windowed is the inverse of fullscreen, for didactic reasons
)
)
(defun zen-mode-get-feature-state (feature)
"An uniform get/set facility for each feature zen handles.
FEATURE is a symbol from 'zen-mode-what-is-not-zen'."
(cond
((eq feature 'scroll-bar-mode)
scroll-bar-mode)
((eq feature 'menu-bar-mode)
menu-bar-mode)
((eq feature 'tool-bar-mode)
tool-bar-mode)
((eq feature 'windowed-mode)
(if (frame-parameter nil 'fullscreen) nil t))
)
)
(defun zen-mode-set-feature-state (feature state)
"Set zen FEATURE to STATE."
(let*
((modeflag (if state t -1)))
(cond
((eq feature 'scroll-bar-mode)
(scroll-bar-mode modeflag))
((eq feature 'menu-bar-mode)
(menu-bar-mode modeflag))
((eq feature 'tool-bar-mode)
(tool-bar-mode modeflag))
((eq feature 'windowed-mode)
(set-frame-parameter nil 'fullscreen (if state nil 'fullboth)))
))
)
(defun zen-mode-store-state ()
"Store the state of all features zen is interested in."
(setq zen-mode-previous-state nil)
(let
((f zen-mode-what-is-not-zen))
(while f
(setq zen-mode-previous-state
(append zen-mode-previous-state
(list (list (car f)
(zen-mode-get-feature-state (car f))) )))
(setq f (cdr f))))
zen-mode-previous-state)
(defun zen-mode-disable-nonzen-features ()
"Disable all non-zen features."
(let
((f zen-mode-what-is-not-zen))
(while f
(zen-mode-set-feature-state (car f) nil)
(setq f (cdr f)))))
(defun zen-mode-restore-state ()
"Restore the feature state as before entering zen."
(let
((f zen-mode-previous-state))
(while f
(zen-mode-set-feature-state (caar f) (cadar f))
(setq f (cdr f))))
)
(defun zen-mode ()
"Toggle Zen mode."
(interactive)
(if zen-mode-is-active-p
(progn;deactivate zen
(setq zen-mode-is-active-p nil)
(zen-mode-store-state)
(zen-mode-disable-nonzen-features)
)
(progn;activate zen
(setq zen-mode-is-active-p t)
(zen-mode-restore-state))))
(provide 'zen-mode)
;;; zen-mode.el ends here
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2009-06-08 20:32 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-06-08 20:32 problem with fullscreen(now with actual attachment) joakim
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.