From 70a898f7fb921da73630b445ce065d3fa7b75b23 Mon Sep 17 00:00:00 2001 From: Thomas von Dein Date: Tue, 25 Jul 2017 14:37:29 +0200 Subject: [PATCH] fixed ip handling in org tables --- .emacs | 47 ++- emacs.html | 943 ++++++++++++++++++++++++++++------------------------- 2 files changed, 537 insertions(+), 453 deletions(-) diff --git a/.emacs b/.emacs index d542b6d..5fec497 100644 --- a/.emacs +++ b/.emacs @@ -574,6 +574,8 @@ ;; 20170725.01: ;; - autoscratch lambda=>progn +;; - added sort-table-ip[desc] and fixed auto-alignment so +;; that ip's are left aligned ;; ** TODO @@ -3372,6 +3374,36 @@ specify another regex for cell splitting." (interactive) (org-table-sort-lines nil ?T)) +;; [[http://irreal.org/blog/?p=3542][via jcs/irreal.org]] +;; however, I renamed the actual sort wrappers to match my +;; naming scheme +(defun jcs-ip-lessp (ip1 ip2 &optional op) + "Compare two IP addresses. +Unless the optional argument OP is provided, this function will return T +if IP1 is less than IP2 or NIL otherwise. The optional argument OP is +intended to be #'> to support reverse sorting." + (setq cmp (or op #'<)) + (cl-labels ((compare (l1 l2) + (if (or (null l1) (null l2)) + nil + (let ((n1 (string-to-number (car l1))) + (n2 (string-to-number (car l2)))) + (cond + ((funcall cmp n1 n2) t) + ((= n1 n2) (compare (cdr l1) (cdr l2))) + (t nil)))))) + (compare (split-string ip1 "\\.") (split-string ip2 "\\.")))) + +(defun sort-table-ip () + (interactive) + (org-table-sort-lines nil ?f #'org-sort-remove-invisible #'jcs-ip-lessp)) + +(defun sort-table-ip-desc () + (interactive) + (org-table-sort-lines nil ?F #'org-sort-remove-invisible + (lambda (ip1 ip2) (jcs-ip-lessp ip1 ip2 #'>)))) + + ;; easy access for the shortcuts (defalias 'stn 'sort-table-numeric) (defalias 'stnd 'sort-table-numeric-desc) @@ -3379,6 +3411,8 @@ specify another regex for cell splitting." (defalias 'stad 'sort-table-alphanumeric-desc) (defalias 'stt 'sort-table-time) (defalias 'sttd 'sort-table-time-desc) +(defalias 'sti 'sort-table-ip) +(defalias 'stid 'sort-table-ip-desc) ;; generic table exporter (defun tvd-export-org-table (fmt) @@ -3507,8 +3541,11 @@ specify another regex for cell splitting." (add-hook 'org-mode-hook (lambda () (local-set-key (kbd "C-c o") 'org-table-copy-col) - (local-set-key (kbd "C-c t") 'tvd-copy-org-table-cell))))) + (local-set-key (kbd "C-c t") 'tvd-copy-org-table-cell) + )))) +;; integers, reals, positives, set via custom +(setq org-table-number-regexp "^[-+]?\\([0-9]*\\.[0-9]+\\|[0-9]+\\.?[0-9]*\\)$") ;; *** org mode slideshows @@ -4932,10 +4969,10 @@ converted to PDF at the same location." '(org-level-2 ((t (:height 1.16 :foreground "sea green" :underline t :weight normal)))) '(org-level-3 ((t (:height 1.14 :foreground "saddle brown" :underline t)))) '(org-level-4 ((t (:height 1.12 :foreground "OrangeRed2" :underline t)))) - '(org-level-5 ((t (:height 1.1 :underline t)))) - '(outline-1 ((t (:height 1.2 :inherit font-lock-function-name-face :underline t :weight bold )))) - '(outline-2 ((t (:height 1.15 :inherit font-lock-variable-name-face :underline t :weight bold )))) - '(outline-3 ((t (:height 1.1 :inherit font-lock-keyword-face :underline t :weight bold)))) + '(org-level-5 ((t (:height 1.1 :underline t)))) + '(outline-1 ((t (:height 1.2 :inherit font-lock-function-name-face :underline t :weight bold)))) + '(outline-2 ((t (:height 1.15 :inherit font-lock-variable-name-face :underline t :weight bold)))) + '(outline-3 ((t (:height 1.1 :inherit font-lock-keyword-face :underline t :weight bold)))) '(outline-4 ((t (:height 1.05 :foreground "DodgerBlue3" :underline t)))) '(region ((t (:foreground "Aquamarine" :background "Darkblue")))) '(secondary-selection ((t (:foreground "Green" :background "darkslateblue")))) diff --git a/emacs.html b/emacs.html index 87c8a5f..526798b 100644 --- a/emacs.html +++ b/emacs.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + @@ -232,191 +232,191 @@ for the JavaScript code in this tag.

Table of Contents

@@ -425,8 +425,8 @@ for the JavaScript code in this tag.

Toms Emacs Config - portable - version (20170725.01) -*-emacs-lisp-*-

-
-

1 Introduction

+
+

1 Introduction

This is my emacs config, it is more than twenty years old. It @@ -480,11 +480,11 @@ outshine-to-html, written by myself, see below.

-
-

2 Config Log, Trivia, Notes, Changes

+
+

2 Config Log, Trivia, Notes, Changes

-
-

2.1 Changelog

+
+

2.1 Changelog

20160420.03: @@ -1469,12 +1469,14 @@ it because inappropriate,

  • autoscratch lambda=>progn
  • +
  • added sort-table-ip[desc] and fixed auto-alignment so +that ip's are left aligned
-
-

2.2 TODO

+
+

2.2 TODO

-
-

2.3 Parking Lot / Snippets

+
+

2.3 Parking Lot / Snippets

Snippets which maybe of use in the future

-
-

2.3.1 buffer-local hook

+
+

2.3.1 buffer-local hook

(with-current-buffer (get-buffer "scratch") @@ -1511,8 +1513,8 @@ Snippets which maybe of use in the future

-
-

2.4 .emacs config version

+
+

2.4 .emacs config version

My emacs config has a version (consisting of a timestamp with a @@ -1529,11 +1531,11 @@ I'm using an outdated config somewhere.

-
-

3 System Specifics

+
+

3 System Specifics

-
-

3.1 Global init file+dir vars, portable

+
+

3.1 Global init file+dir vars, portable

  • added dev function which opens a new development frame
  • @@ -1571,8 +1573,8 @@ all modes and extensions are located here
-
-

3.2 Fontlock-mode - use syntax highlighting on graphical displays

+
+

3.2 Fontlock-mode - use syntax highlighting on graphical displays

look: emacswiki @@ -1589,8 +1591,8 @@ look: emacswiki


-
-

3.3 line-cursor in console

+
+

3.3 line-cursor in console

better visibility of cursor in console sessions @@ -1606,8 +1608,8 @@ better visibility of cursor in console sessions


-
-

3.4 Backup Config

+
+

3.4 Backup Config

I save backup files in a central location below the init dir, that @@ -1678,8 +1680,8 @@ This is system specific and only matches special host names.


-
-

3.5 console backspace fix

+
+

3.5 console backspace fix

make backspace work in console sessions @@ -1692,8 +1694,8 @@ make backspace work in console sessions


-
-

3.6 hide menu- and tool-bar

+
+

3.6 hide menu- and tool-bar

I prefer a bare bones emacs window without any distractions, so turn them off. @@ -1709,8 +1711,8 @@ I prefer a bare bones emacs window without any distractions, so turn them off.


-
-

3.7 stay silent on startup

+
+

3.7 stay silent on startup

(setq initial-scratch-message "")
@@ -1723,8 +1725,8 @@ I prefer a bare bones emacs window without any distractions, so turn them off.
 
-
-

3.8 y means yes

+
+

3.8 y means yes

y is shorter than yes and less error prone. @@ -1737,8 +1739,8 @@ y is shorter than yes and less error prone.


-
-

3.9 show col in modeline

+
+

3.9 show col in modeline

very useful to know current column @@ -1751,8 +1753,8 @@ very useful to know current column


-
-

3.10 file or buffer in title

+
+

3.10 file or buffer in title

this can be seen in xmobar @@ -1766,8 +1768,8 @@ this can be seen in xmobar


-
-

3.11 avoid invalid files

+
+

3.11 avoid invalid files

(setq require-final-newline t)
@@ -1777,8 +1779,8 @@ this can be seen in xmobar
 
-
-

3.12 prepare load-path

+
+

3.12 prepare load-path

where to look for extensions: @@ -1805,8 +1807,8 @@ modules


-
-

3.13 byte-compile all of them, if needed

+
+

3.13 byte-compile all of them, if needed

handy function to recompile all lisp files @@ -1821,8 +1823,8 @@ handy function to recompile all lisp files


-
-

3.14 increase fontsize with ctrl-+ and ctrl--

+
+

3.14 increase fontsize with ctrl-+ and ctrl--

I use those bindings everywhere (firefox, terminal, etc), and in @@ -1848,11 +1850,11 @@ emacs as well.


-
-

3.15 WINDOW management stuff

+
+

3.15 WINDOW management stuff

-
-

3.15.1 resize windows by keyboard

+
+

3.15.1 resize windows by keyboard

Very practical: resize windows easily. @@ -1869,8 +1871,8 @@ hit C-c C-r then use cursor keys to resize, <ret> to finish

-
-

3.15.2 switch windows with MS-WINDOWS key

+
+

3.15.2 switch windows with MS-WINDOWS key

(require 'windmove)
@@ -1881,8 +1883,8 @@ hit C-c C-r then use cursor keys to resize, <ret> to finish
 
-
-

3.15.3 M-o switch window or buffer

+
+

3.15.3 M-o switch window or buffer

via mbork @@ -1960,8 +1962,8 @@ Use only in X11 emacs - setting M-O inside console causes <up> and


-
-

3.15.4 Split window to 4 parts

+
+

3.15.4 Split window to 4 parts

(defun tvd-quarter-windows ()
@@ -1979,8 +1981,8 @@ Use only in  X11 emacs - setting M-O inside console  causes <up> and
 
-
-

3.15.5 Remember and Restore Window Configurations - winner mode

+
+

3.15.5 Remember and Restore Window Configurations - winner mode

(winner-mode 1)
@@ -1995,8 +1997,8 @@ keybindings: C-c right   - winner-redo
 
-
-

3.16 re-read a modified buffer

+
+

3.16 re-read a modified buffer

F5 == reload file if it has been modified by another process, shift @@ -2021,8 +2023,8 @@ because Xmonad


-
-

3.17 global TAB/Indent config

+
+

3.17 global TAB/Indent config

I use spaces everywhere but Makefiles. If I encounter TABs I @@ -2062,8 +2064,8 @@ Use normal tabs in makefiles


-
-

3.18 handy aliases

+
+

3.18 handy aliases

M-x q r <ret> is short enough for me, no need for key bindings for @@ -2095,8 +2097,8 @@ those


-
-

3.19 various settings

+
+

3.19 various settings

point stays while scrolling @@ -2149,8 +2151,8 @@ I'm grown up!


-
-

3.20 load imenu

+
+

3.20 load imenu

(define-key global-map [C-down-mouse-2] 'imenu)
@@ -2160,8 +2162,8 @@ I'm grown up!
 
-
-

3.21 copy/paste Config

+
+

3.21 copy/paste Config

Related: @@ -2228,8 +2230,8 @@ marked region automatically copied, also on win


-
-

3.22 use more mem

+
+

3.22 use more mem

are you from the past? @@ -2242,8 +2244,8 @@ are you from the past?


-
-

3.23 better file name completion

+
+

3.23 better file name completion

Complete filenames case insensitive and ignore certain files during completion. @@ -2273,8 +2275,8 @@ via -

3.24 abbreviations

+
+

3.24 abbreviations

Do I really need those anymore? Added ca 1999… @@ -2304,8 +2306,8 @@ do NOT ask to save abbrevs on exit

-
-

3.25 meaningful names for buffers with the same name

+
-
-

3.26 packages

+
+

3.26 packages

I dont need it all the time and only for experimentation, so lets @@ -2347,8 +2349,8 @@ only use melpa on demand


-
-

3.27 My own global variables

+
+

3.27 My own global variables

narrowed fringe background @@ -2361,11 +2363,11 @@ narrowed fringe background


-
-

3.28 More scratch space

+
+

3.28 More scratch space

-
-

3.28.1 Text scratch

+
+

3.28.1 Text scratch

Sometimes I need a text mode scratch buffer while scratch is @@ -2381,8 +2383,8 @@ this never gets deleted, but cleaned instead.

-
-

3.28.2 Autoscratch

+
+

3.28.2 Autoscratch

use autoscratch otherwise @@ -2412,8 +2414,8 @@ use autoscratch otherwise

-
-

3.28.3 Persistent Scratch

+
+

3.28.3 Persistent Scratch

I also like to be scratch buffers persistent with @@ -2435,8 +2437,8 @@ I also like to be scratch buffers persistent with

-
-

3.29 Recenter config

+
+

3.29 Recenter config

via abo abo @@ -2457,13 +2459,13 @@ I think this is a recenter calculation bug.

-
-

4 Global Key Bindings

+
+

4 Global Key Bindings


-
-

4.1 c-h != delete

+
+

4.1 c-h != delete

(keyboard-translate ?\C-h ?\C-?)
@@ -2474,8 +2476,8 @@ I think this is a recenter calculation bug.
 
-
-

4.2 general keys (re-)mappings

+
+

4.2 general keys (re-)mappings

(global-set-key (kbd "C-s")             'isearch-forward-regexp)
@@ -2503,8 +2505,8 @@ I think this is a recenter calculation bug.
 
-
-

4.3 display a list of my own global key bindings and aliases

+
+

4.3 display a list of my own global key bindings and aliases

via emacswiki @@ -2581,13 +2583,13 @@ more help with: describe-function occur-mode

-
-

5 Productivity Functions

+
+

5 Productivity Functions


-
-

5.1 goto line with tmp line numbers

+
+

5.1 goto line with tmp line numbers

I stole this somewhere, as far as I remember, emacswiki, however, I @@ -2611,8 +2613,8 @@ always had F7 for goto-line


-
-

5.2 invert fore- and background

+
+

5.2 invert fore- and background

Sometimes when sitting in a very dark enviroment, my usual light @@ -2655,8 +2657,8 @@ fast


-
-

5.3 Some useful bindings for Home and End keys Hit the key once to

+
+

5.3 Some useful bindings for Home and End keys Hit the key once to

Go to the beginning/end of a line, hit it twice in a row to go to @@ -2720,8 +2722,8 @@ This is the most natural use for those keys


-
-

5.4 percent function

+
+

5.4 percent function

by Jens Heunemann: jump to percent position into current buffer @@ -2742,8 +2744,8 @@ by Jens Heunemann: jump to percent position into current buffer


-
-

5.5 Simulate vi's % function

+
+

5.5 Simulate vi's % function

There's not a lot about vi[m] I like, but jumping with % to a @@ -2775,8 +2777,8 @@ just insert a literal ?%. Only make sense if bound to %.


-
-

5.6 Move region

+
+

5.6 Move region

Mark a region, then use M-up|down to move it around @@ -2875,8 +2877,8 @@ code from -

5.7 comment-uncomment region with one key binding

+ -
-

5.8 search for symbol at point

+
+

5.8 search for symbol at point

Simulate the # function of vi, marks the symbol at point, C-s then @@ -2943,8 +2945,8 @@ via ergomacs


-
-

5.9 Window Margin

+
+

5.9 Window Margin

Kinda screen reader for the poor. I use this sometimes with info @@ -2970,8 +2972,8 @@ left+right margin on demand (but nothing else)


-
-

5.10 Fill and justify a paragraph

+
+

5.10 Fill and justify a paragraph

this is just a shortcut for: @@ -3000,8 +3002,8 @@ idea via: -

5.11 Make a read-only copy of the current buffer

+
+

5.11 Make a read-only copy of the current buffer

I just create a new read-only buffer and copy the contents of the @@ -3050,8 +3052,8 @@ a file is not maintained via VC anyway.


-
-

5.12 Cleanup, close all windows and kill all buffers

+
+

5.12 Cleanup, close all windows and kill all buffers

From time to time I get annoyed by the many dozen buffers @@ -3084,8 +3086,8 @@ setup accidentally.


-
-

5.13 Cleanup current buffer

+
-
-

5.14 Better newline(s)

+
+

5.14 Better newline(s)

Add newline and jump to indent from wherever I am in the current @@ -3159,8 +3161,8 @@ disabled, interferes with modes.


-
-

5.15 Mouse Rectangle

+
-
-

5.16 DOS <=> UNIX conversion helpers

+
+

5.16 DOS <=> UNIX conversion helpers

(defun dos2unix ()
@@ -3209,8 +3211,8 @@ via stackoverflow
 
-
-

5.17 helper do add the same thing to multiple mode hooks

+
+

5.17 helper do add the same thing to multiple mode hooks

via stackoverflow @@ -3228,8 +3230,8 @@ usage samples below.

-
-

5.18 helper to catch load errors

+
+

5.18 helper to catch load errors

Try to eval 'fn, catch errors, if any but make it possible for @@ -3251,8 +3253,8 @@ emacs to continue undisturbed, used with SMEX, see below.


-
-

5.19 Alignment Wrappers

+
+

5.19 Alignment Wrappers

align-regexp is already a very usefull tool, however, sometimes I @@ -3302,8 +3304,8 @@ wrappers to make this easier.

-
-

5.20 String Helpers

+
+

5.20 String Helpers

Some helper functions I use here and there. @@ -3342,14 +3344,14 @@ Some helper functions I use here and there.

-
-

6 Modes

+
+

6 Modes

-
-

6.1 Programming Languages

+
+

6.1 Programming Languages

-
-

6.1.1 VALA

+
+

6.1.1 VALA

(autoload 'vala-mode "vala-mode" "Major mode for editing Vala code." t)
@@ -3364,8 +3366,8 @@ Some helper functions I use here and there.
 
-
-

6.1.2 python mode

+
+

6.1.2 python mode

Not much configured for python, I'm happy with the defaults as it seems :) @@ -3393,8 +3395,8 @@ Not much configured for python, I'm happy with the defaults as it seems :)

-
-

6.1.3 cperl mode

+
+

6.1.3 cperl mode

I am a perl addict. I love it, therefore, emacs must be prepared @@ -3541,8 +3543,8 @@ and hook them into cperl

-
-

6.1.4 Paredit for lisp only

+
+

6.1.4 Paredit for lisp only

I use paredit in lisp a lot, but are mostly happy with the defaults. @@ -3585,8 +3587,8 @@ sometimes I need to be able to turn it off fast:

-
-

6.1.5 ETAGS

+
+

6.1.5 ETAGS

I use ETAGS for some projects. With etags I can easily jump to the @@ -3663,11 +3665,11 @@ some handy aliases

-
-

6.2 Text Modes

+
+

6.2 Text Modes

-
-

6.2.1 sgml

+
+

6.2.1 sgml

Used for XML and the likes. @@ -3694,8 +3696,8 @@ Used for XML and the likes.

-
-

6.2.2 web-mode (JS, HTML, CSS combined)

+
+

6.2.2 web-mode (JS, HTML, CSS combined)

Web development is shit. Tech involved is a mess, and in most cases @@ -3789,8 +3791,8 @@ convert a text list into a html list.

-
-

6.2.3 Cisco Mode

+
+

6.2.3 Cisco Mode

Written by myself many years ago, but I'm still using it daily to @@ -3808,8 +3810,8 @@ view and prepare cisco configs.

-
-

6.2.4 Markdown

+
+

6.2.4 Markdown

I rarely use markdown, but sometimes I stumble upon such a file and @@ -3845,8 +3847,8 @@ parens and quotes constraints check on save

-
-

6.2.5 POD mode

+
+

6.2.5 POD mode

I LOVE POD! POD is the documentation format of perl and there's a @@ -3980,8 +3982,8 @@ pod mode config


-
-

6.2.6 conf-mode

+
+

6.2.6 conf-mode

conf-mode annoyingly overwrites the global keybinding C-c C-c with @@ -4002,10 +4004,10 @@ configs. Applies for derivates as well.

-
-

6.2.7 Config::General mode

+
+

6.2.7 Config::General mode

-
  1. Config and doc
    +
    1. Config and doc

      config-general-mode (also on Melpa).

      @@ -4024,7 +4026,7 @@ both did not satisfy me. Now (as of 20170625) I solved this mess once and for al
-
  • Convenicence Wrappers
    +
  • Convenicence Wrappers
    (defun config-general-completion-at-point ()
       "Complete word at point using hippie-expand, if not on a comment."
    @@ -4124,7 +4126,7 @@ Bugreport: http://d
     
  • -
  • Mode Hook
    +
  • Mode Hook

    I use TAB for completion AND tab and outshine. Also, the mode enables electric indent automatically, but I disabled it for @@ -4174,8 +4176,8 @@ for config-general-mode (which inherits from conf-mode).


  • -
    -

    6.2.8 Xmodmap Mode

    +
    +

    6.2.8 Xmodmap Mode

    the shortest mode ever, via emacswiki. @@ -4198,10 +4200,10 @@ the shortest mode ever, vi

    -
    -

    6.2.9 MMM Mode

    +
    +

    6.2.9 MMM Mode

    -
    1. MMM configure:
      +
      1. MMM configure:
        (add-to-list 'load-path (concat tvd-lisp-dir "/mmm-mode"))
         
        @@ -4220,7 +4222,7 @@ see doc for class definition in var 'mmm-classes-alist
         

      2. -
      3. MMM config for POD mode
        +
      4. MMM config for POD mode
        (mmm-add-classes
          '((html-pod
        @@ -4238,11 +4240,11 @@ see doc for class definition in var 'mmm-classes-alist
         
        -
        -

        6.3 Text Manupilation

        +
        +

        6.3 Text Manupilation

        -
        -

        6.3.1 expand-region

        +
        +

        6.3.1 expand-region

        One of the best modes I ever discovered. Press C-= multiple times @@ -4261,8 +4263,8 @@ related to ER:

        -
        -

        6.3.2 Mark, Copy, Yank Things

        +
        +

        6.3.2 Mark, Copy, Yank Things

        For a long time this stuff was located here in my emacs config. As @@ -4365,8 +4367,8 @@ it appears as NNN,NN.

        -
        -

        6.3.3 change-inner

        +
        +

        6.3.3 change-inner

        I use change-inner with a prefix key and some wrappers around @@ -4488,8 +4490,8 @@ typing the prefix key twice calls the real change-inner


        -
        -

        6.3.4 Rotate text

        +
        +

        6.3.4 Rotate text

        This one is great as well, I use it to toggle flags and such stuff @@ -4545,8 +4547,8 @@ short command anymore, so C-t would be free now, wouldn't it?

        -
        -

        6.3.5 Word wrapping

        +
        +

        6.3.5 Word wrapping

        same as word-wrap but without the fringe which I hate the most! @@ -4568,8 +4570,8 @@ overwritten by visual-line-mode above for specifics

        -
        -

        6.3.6 Viking Mode

        +
        +

        6.3.6 Viking Mode

        Delete stuff fast. Press the key multiple times - delete more @@ -4587,8 +4589,8 @@ things. Inspired by expand-region. Written by myself.

        -
        -

        6.3.7 HTMLize

        +
        +

        6.3.7 HTMLize

        extracted from debian package emacs-goodies-el-35.2+nmu1, since @@ -4605,8 +4607,8 @@ the current buffer, however it looks.

        -
        -

        6.3.8 iEdit (inline edit multiple searches)

        +
        +

        6.3.8 iEdit (inline edit multiple searches)

        Edit all occurences of something at once. Great for re-factoring. @@ -4647,11 +4649,11 @@ behavior, so, I modify it myself using defadvice.

        -
        -

        6.4 Interactives

        +
        +

        6.4 Interactives

        -
        -

        6.4.1 eShell stuff, or if interactive stuff is needed, use ansi-term

        +
        +

        6.4.1 eShell stuff, or if interactive stuff is needed, use ansi-term

        I am a hardcore bash user, but from time to time eshell is good @@ -4931,8 +4933,8 @@ no need for less or more, this is emacs, isn't it?

        -
        -

        6.4.2 Emacs LISP interactive

        +
        +

        6.4.2 Emacs LISP interactive

        General configuration for all things elisp. @@ -5143,8 +5145,8 @@ opens a new frame with all those buffers already opened and pinned.


        -
        -

        6.4.3 el2markdown

        +
        +

        6.4.3 el2markdown

        el2markdown is a module which @@ -5168,8 +5170,8 @@ README.md. Take care though: it doesn't convert the META section.

        -
        -

        6.4.4 tramp mode

        +
        +

        6.4.4 tramp mode

        Edit remote files, one of the best things in emacs. I use it every day heavily. @@ -5197,8 +5199,8 @@ see also backup section

        -
        -

        6.4.5 org mode

        +
        +

        6.4.5 org mode

        I use org mode to take notes mostly at work. I also track projects @@ -5500,8 +5502,8 @@ is in the outline section.


        -
        -

        6.4.6 org table mode

        +
        +

        6.4.6 org table mode

        I'm so used to lovely org mode tables, I need them everywhere! @@ -5572,6 +5574,41 @@ table sorting shortcuts

        +

        +via jcs/irreal.org +however, I renamed the actual sort wrappers to match my +naming scheme +

        +
        +
        (defun jcs-ip-lessp (ip1 ip2 &optional op)
        +  "Compare two IP addresses.
        +Unless the optional argument OP is provided, this function will return T
        +if IP1 is less than IP2 or NIL otherwise. The optional argument OP is
        +intended to be #'> to support reverse sorting."
        +  (setq cmp (or op #'<))
        +  (cl-labels ((compare (l1 l2)
        +                       (if (or (null l1) (null l2))
        +                           nil
        +                         (let ((n1 (string-to-number (car l1)))
        +                               (n2 (string-to-number (car l2))))
        +                           (cond
        +                            ((funcall cmp n1 n2) t)
        +                            ((= n1 n2) (compare (cdr l1) (cdr l2)))
        +                            (t nil))))))
        +    (compare (split-string ip1 "\\.") (split-string ip2 "\\."))))
        +
        +(defun sort-table-ip ()
        +  (interactive)
        +  (org-table-sort-lines nil ?f #'org-sort-remove-invisible #'jcs-ip-lessp))
        +
        +(defun sort-table-ip-desc ()
        +  (interactive)
        +  (org-table-sort-lines nil ?F #'org-sort-remove-invisible
        +                        (lambda (ip1 ip2) (jcs-ip-lessp ip1 ip2 #'>))))
        +
        +
        + +

        easy access for the shortcuts

        @@ -5582,6 +5619,8 @@ easy access for the shortcuts (defalias 'stad 'sort-table-alphanumeric-desc) (defalias 'stt 'sort-table-time) (defalias 'sttd 'sort-table-time-desc) +(defalias 'sti 'sort-table-ip) +(defalias 'stid 'sort-table-ip-desc)
        @@ -5740,15 +5779,23 @@ tables as well (add-hook 'org-mode-hook (lambda () (local-set-key (kbd "C-c o") 'org-table-copy-col) - (local-set-key (kbd "C-c t") 'tvd-copy-org-table-cell))))) + (local-set-key (kbd "C-c t") 'tvd-copy-org-table-cell) + )))) + +
        + +

        +integers, reals, positives, set via custom +

        +
        +
        (setq org-table-number-regexp "^[-+]?\\([0-9]*\\.[0-9]+\\|[0-9]+\\.?[0-9]*\\)$")
         
        - -
        -

        6.4.7 org mode slideshows

        +
        +

        6.4.7 org mode slideshows

        Making presentations within emacs with org mode is cool as well. @@ -5856,8 +5903,8 @@ Will be inserted as first help slide in a slide show


        -
        -

        6.4.8 outshine mode

        +
        +

        6.4.8 outshine mode

        I maintain my emacs config with outshine mode. It works a lot like @@ -6037,8 +6084,8 @@ posting online, which makes it way easier to read.

        -
        -

        6.4.9 outline mode

        +
        +

        6.4.9 outline mode

        I use the very same cycle style as in org mode: when on a heading, @@ -6135,8 +6182,8 @@ orange fringe when narrowed


        -
        -

        6.4.10 narrowing (no mode but fits here)

        +
        +

        6.4.10 narrowing (no mode but fits here)

        I use narrowing quite frequently, so here are some enhancements. @@ -6176,8 +6223,8 @@ via -

        6.4.11 ANSI-TERM (inferior shells/interpreters and REPLs)

        +
        +

        6.4.11 ANSI-TERM (inferior shells/interpreters and REPLs)

        I use ansi term for inferior shells only. @@ -6293,8 +6340,8 @@ finally the inferior REPLs:

        -
        -

        6.4.12 Puppet

        +
        +

        6.4.12 Puppet

        adds hook for .pp files @@ -6308,8 +6355,8 @@ adds hook for .pp files

        -
        -

        6.4.13 Novel Mode - Screen Reader

        +
        +

        6.4.13 Novel Mode - Screen Reader

        my own emacs screen reader, very handy to read docs on the road. @@ -6325,8 +6372,8 @@ my own emacs screen reader, very handy to read docs on the road.

        -
        -

        6.4.14 Macro Math

        +
        +

        6.4.14 Macro Math

        see macro-math @@ -6349,8 +6396,8 @@ mark something and hit C-x C-0 (which is a reminder to C-x C-= w/o the shift)

        -
        -

        6.4.15 Common-Lisp (SLIME)

        +
        +

        6.4.15 Common-Lisp (SLIME)

        I'm learing CL with slime, start with M-x slime. @@ -6383,8 +6430,8 @@ INSTALL: (see: -

        6.4.16 INFO Mode

        +
        +

        6.4.16 INFO Mode

        open an info file somewhere outside %infodir% with info-mode @@ -6416,8 +6463,8 @@ easier navigation in Info mode, intuitive history back and forth.

        -
        -

        6.4.17 calc et al.

        +
        +

        6.4.17 calc et al.

        emacs provides 4 ways to calculate: @@ -6467,8 +6514,8 @@ or, inferior perl calc: M-x icalc, see above

        -
        -

        6.4.18 MACROs

        +
        +

        6.4.18 MACROs

        help: emacswiki macro tricks. @@ -6681,8 +6728,8 @@ but only load if in use


        -
        -

        6.4.19 EWW browser stuff

        +
        +

        6.4.19 EWW browser stuff

        Emacs has a builtin browser, which is not too bad. @@ -6750,8 +6797,8 @@ hides menus and distractions! Update emacs.


        -
        -

        6.4.20 Firestarter

        +
        +

        6.4.20 Firestarter

        experimental: do things on save buffer etc. @@ -6760,8 +6807,8 @@ Source: firestarter

        -
        -

        6.4.21 Tabulated List Mode

        +
        +

        6.4.21 Tabulated List Mode

        built-in, used by many interactive major modes @@ -6809,8 +6856,8 @@ we need to kill tablist's binding in order to have ours run (see below)

        -
        -

        6.4.22 Help Mode

        +
        +

        6.4.22 Help Mode

        I even customize help windows! … at least a little :) @@ -6833,8 +6880,8 @@ I even customize help windows! … at least a little :)

        -
        -

        6.4.23 Suggest Mode

        +
        +

        6.4.23 Suggest Mode

        suggest mode is a great @@ -6884,8 +6931,8 @@ I use my own clearing function, since suggest doesn't provide this

        -
        -

        6.4.24 Followcursor Mode

        +
        +

        6.4.24 Followcursor Mode

        source on github @@ -6915,11 +6962,11 @@ The mode is a work-in-progress… -

        -

        6.5 Emacs Interface

        +
        +

        6.5 Emacs Interface

        -
        -

        6.5.1 Parens

        +
        +

        6.5.1 Parens

        display matching braces @@ -6940,8 +6987,8 @@ display matching braces

        -
        -

        6.5.2 highlight todo keywords (such as FIXME)

        +
        +

        6.5.2 highlight todo keywords (such as FIXME)

        Absolutely needed! @@ -6956,8 +7003,8 @@ Absolutely needed!


        -
        -

        6.5.3 UNDO Tree Mode

        +
        +

        6.5.3 UNDO Tree Mode

        Better undo, with redo support. @@ -7000,8 +7047,8 @@ M-_ catched by Xmonad


        -
        -

        6.5.4 Smarter M-x Mode (smex)

        +
        +

        6.5.4 Smarter M-x Mode (smex)

        This is really cool and I don't know how I could ever live without it. @@ -7024,8 +7071,8 @@ fails @win, so wrap it

        -
        -

        6.5.5 Which Func

        +
        +

        6.5.5 Which Func

        display current function - if any - in mode line @@ -7040,8 +7087,8 @@ display current function - if any - in mode line


        -
        -

        6.5.6 Show current-line in the Fringe

        +
        +

        6.5.6 Show current-line in the Fringe

        (require 'fringe-current-line)
        @@ -7060,8 +7107,8 @@ also change the color (matching the mode line
         
        -
        -

        6.5.7 Recent Files

        +
        +

        6.5.7 Recent Files

        You know the file you edited yesterday had "kri" in its name, but @@ -7155,8 +7202,8 @@ exclude some auto generated files

        -
        -

        6.5.8 IDO mode

        +
        +

        6.5.8 IDO mode

        There are other completion enhancement packages available like ivy @@ -7288,8 +7335,8 @@ by howardism: [re]open non-writable file with sudo

        -
        -

        6.5.9 Save cursor position

        +
        +

        6.5.9 Save cursor position

        So the next time I start emacs and open a file I were editing @@ -7310,8 +7357,8 @@ before.

        -
        -

        6.5.10 DoReMi experimentation

        +
        +

        6.5.10 DoReMi experimentation

        I'm not using it a lot, sometimes I tune the background color though. @@ -7340,8 +7387,8 @@ cool ones: doremi-buffers, doremi-all-faces-fg+ [s, h]


        -
        -

        6.5.11 Hightligt TABs

        +
        +

        6.5.11 Hightligt TABs

        not a mode, but however: higlight TABs in certain modes @@ -7364,8 +7411,8 @@ not a mode, but however: higlight TABs in certain modes

        -
        -

        6.5.12 Browse kill-ring

        +
        +

        6.5.12 Browse kill-ring

        when active use n and p to browse, <ret> to select, it's the same @@ -7383,8 +7430,8 @@ as <M-y> and I never really use it…

        -
        -

        6.5.13 goto-last-change

        +
        +

        6.5.13 goto-last-change

        Very handy, jump to last change[s]. @@ -7401,8 +7448,8 @@ Very handy, jump to last change[s].

        -
        -

        6.5.14 Bookmarks

        +
        +

        6.5.14 Bookmarks

        I use the builtin bookmark feature quite a lot and am happy with @@ -7434,8 +7481,8 @@ I use the same aliases as in apparix for bash (since I'm used to them)

        -
        -

        6.5.15 which-key

        +
        +

        6.5.15 which-key

        One of the best unobstrusive modes for key help ever. Just start @@ -7455,8 +7502,8 @@ press from there along with the associated functions.

        -
        -

        6.5.16 iBuffer mode

        +
        +

        6.5.16 iBuffer mode

        iBuffer is a great interactive buffer management tool included with @@ -7666,8 +7713,8 @@ override ibuffer M-o binding

        -
        -

        6.5.17 Printing

        +
        +

        6.5.17 Printing

        overwrites printing default menu, access via menu File => Print @@ -7712,8 +7759,8 @@ via -

        6.5.18 Beacon mode (pointer blink)

        +
        +

        6.5.18 Beacon mode (pointer blink)

        Source: beacon mode @@ -7743,8 +7790,8 @@ editing position.

        -
        -

        6.6 mode-line setup (must be the last mode)

        +
        +

        6.6 mode-line setup (must be the last mode)

        I just append the current version of my emacs config and leave out @@ -7809,13 +7856,13 @@ custom modeline

        -
        -

        7 Emacs Autoconfig / Customizegroup stuff

        +
        +

        7 Emacs Autoconfig / Customizegroup stuff


        -
        -

        7.1 font faces

        +
        +

        7.1 font faces

        Font color config, must always be the last thing so all hook faces are loaded. @@ -7861,10 +7908,10 @@ show available colors: '(org-level-2 ((t (:height 1.16 :foreground "sea green" :underline t :weight normal)))) '(org-level-3 ((t (:height 1.14 :foreground "saddle brown" :underline t)))) '(org-level-4 ((t (:height 1.12 :foreground "OrangeRed2" :underline t)))) - '(org-level-5 ((t (:height 1.1 :underline t)))) - '(outline-1 ((t (:height 1.2 :inherit font-lock-function-name-face :underline t :weight bold )))) - '(outline-2 ((t (:height 1.15 :inherit font-lock-variable-name-face :underline t :weight bold )))) - '(outline-3 ((t (:height 1.1 :inherit font-lock-keyword-face :underline t :weight bold)))) + '(org-level-5 ((t (:height 1.1 :underline t)))) + '(outline-1 ((t (:height 1.2 :inherit font-lock-function-name-face :underline t :weight bold)))) + '(outline-2 ((t (:height 1.15 :inherit font-lock-variable-name-face :underline t :weight bold)))) + '(outline-3 ((t (:height 1.1 :inherit font-lock-keyword-face :underline t :weight bold)))) '(outline-4 ((t (:height 1.05 :foreground "DodgerBlue3" :underline t)))) '(region ((t (:foreground "Aquamarine" :background "Darkblue")))) '(secondary-selection ((t (:foreground "Green" :background "darkslateblue")))) @@ -7894,8 +7941,8 @@ unless we're on windoze


        -
        -

        7.2 variables

        +
        +

        7.2 variables

        If I ever use custom-group to customize a mode, then I create a @@ -7916,8 +7963,8 @@ here. So, in normal times this should be empty, but needs to exist.

        -
        -

        7.3 done

        +
        +

        7.3 done

        Finally, this message is being displayed. If this isn't the case I @@ -7934,7 +7981,7 @@ know easily that something went wrong.

        Author: Thomas von Dein

        -

        Created: 2017-07-25 Tue 13:18

        +

        Created: 2017-07-25 Tue 14:36

        Validate