contrib/gadict.el
author Oleksandr Gavenko <gavenkoa@gmail.com>
Thu, 29 Dec 2016 01:20:21 +0200
changeset 724 98fd211d27db
parent 719 ebc16c3a9129
child 726 d41eddc3561f
permissions -rw-r--r--
Target to show combined statistics about missing words.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
381
1729e4655e4d Fix (package-buffer-info) errors: "Package lacks a \"Version\" or \"Package-Version\" header"
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 380
diff changeset
     1
;;; gadict.el --- major mode for editing gadict dictionary source files -*- lexical-binding: t -*-
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     2
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
     3
;; Copyright (C) 2016 by Oleksandr Gavenko <gavenkoa@gmail.com>
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     4
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     5
;; You can do anything with this file without any warranty.
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     6
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     7
;; Author: Oleksandr Gavenko <gavenkoa@gmail.com>
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     8
;; Maintainer: Oleksandr Gavenko <gavenkoa@gmail.com>
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
     9
;; Created: 2016
381
1729e4655e4d Fix (package-buffer-info) errors: "Package lacks a \"Version\" or \"Package-Version\" header"
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 380
diff changeset
    10
;; Version: 0.1
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    11
;; Keywords: dict, dictionary
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    12
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    13
;;; Commentary:
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    14
;;
510
212d9ff8725c Mode can be installed by...
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 457
diff changeset
    15
;; Mode can be installed by:
212d9ff8725c Mode can be installed by...
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 457
diff changeset
    16
;;
212d9ff8725c Mode can be installed by...
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 457
diff changeset
    17
;;   (autoload 'gadict-mode "gadict")
212d9ff8725c Mode can be installed by...
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 457
diff changeset
    18
;;
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
    19
;; File association can be registered by:
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
    20
;;
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
    21
;;   (add-to-list 'auto-mode-alist (cons "\\.gadict$" 'gadict-mode))
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    22
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    23
;;; Code:
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    24
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    25
(defun gadict--trim-left (s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    26
  "Remove whitespace at the beginning of S."
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    27
  (if (string-match "\\`[ \t\n\r]+" s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    28
      (replace-match "" t t s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    29
    s))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    30
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    31
(defun gadict--trim-right (s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    32
  "Remove whitespace at the end of S."
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    33
  (if (string-match "[ \t\n\r]+\\'" s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    34
      (replace-match "" t t s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    35
    s))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    36
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    37
(defun gadict--trim (s)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    38
  "Remove whitespace at the beginning and end of S."
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    39
  (gadict--trim-left (gadict--trim-right s)))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
    40
652
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
    41
(defconst gadict--pos '("n" "v" "adj" "adv" "pron" "prep" "num" "conj" "int" "phr" "phr.v" "contr" "abbr" "prefix")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
    42
  "Defined parts of speech.")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
    43
565
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    44
(defconst gadict--art-lang-regex (regexp-opt '("en" "ru" "uk" "la")))
618
6ad7203ac9dc Add support for hypernyms and hyponyms.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 581
diff changeset
    45
(defconst gadict--art-rel-regex (regexp-opt '("ant" "syn" "rel" "topic" "hyper" "hypo")))
647
6ae5399c8087 Add ``rare`` attribute to headword to filter low frequency headwords out from
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 618
diff changeset
    46
(defconst gadict--art-var-regex (regexp-opt '("rare" "v1" "v2" "v3" "s" "pl" "male" "female" "abbr" "comp" "super" "Am" "Br" "Au")))
652
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
    47
(defconst gadict--art-pos-regex (regexp-opt gadict--pos))
565
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    48
580
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    49
(defgroup gadict nil
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    50
  "gadict-mode customization."
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    51
  :group 'wp)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    52
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    53
(defface gadict-tr-face '((t :foreground "#40a040" :slant italic))
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    54
  "Face for marker of translation."
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    55
  :group 'gadict)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    56
(defface gadict-ex-face '((t :foreground "#20a0c0" :slant italic))
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    57
  "Face for marker of example."
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    58
  :group 'gadict)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    59
(defface gadict-glos-face '((t :foreground "#a04040" :slant italic))
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    60
  "Face for marker of explanation."
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    61
  :group 'gadict)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    62
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
    63
(defvar gadict-font-lock-keywords
565
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    64
  `( ("^\\(__\\)\n\n\\(\\w.*\\)$" (1 font-lock-function-name-face) (2 font-lock-keyword-face))
378
8c629eb20c0b Highlight other article headers.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 375
diff changeset
    65
     ("^ .*\n\\(\\w.*\\)" (1 font-lock-keyword-face))
373
51565d9fe630 Highlight comment syntax. Fix uncommenting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 372
diff changeset
    66
     ("^#.*" . font-lock-comment-face)
581
8497d1849d57 Help to find places where COLON is used instead of MODIFIER LETTER TRIANGULAR COLON.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 580
diff changeset
    67
     ("^ +\\[[^]\n:]+]" . font-lock-type-face)
580
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    68
     (,(format "^%s: " gadict--art-lang-regex) . 'gadict-tr-face)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    69
     (,(format "^%s> " gadict--art-lang-regex) . 'gadict-ex-face)
f7c1fd21a5dd Add custom faces for translations, explanations and examples.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 579
diff changeset
    70
     (,(format "^%s= " gadict--art-lang-regex) . 'gadict-glos-face)
565
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    71
     (,(format "^%s: " gadict--art-rel-regex) . font-lock-doc-face)
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    72
     (,(format "^ +%s$" gadict--art-var-regex) . font-lock-doc-face)
ac68f2680ea0 Add syntax to add related words. Add separators between ant/syn/rel in
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 563
diff changeset
    73
     (,(format "^%s$" gadict--art-pos-regex) . font-lock-warning-face) ))
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    74
371
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    75
(defun gadict-setup-fontlock ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
    76
  "Setup gadict fontlock."
371
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    77
  (setq font-lock-defaults
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    78
        '(gadict-font-lock-keywords
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    79
          t nil nil nil
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    80
          (font-lock-multiline . t) ))
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    81
  (add-hook 'font-lock-extend-region-functions 'gadict-font-lock-extend-region t) )
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
    82
382
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
    83
(defun gadict-setup-syntax ()
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
    84
  "Setup gadict characters syntax."
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
    85
  (modify-syntax-entry ?' "w"))
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
    86
367
ba263c893207 Rename to gadict-setup-comment
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 366
diff changeset
    87
(defun gadict-setup-comment ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
    88
  "Setup gadict comment commands."
370
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    89
  (set (make-local-variable 'comment-start)  "#")
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    90
  (set (make-local-variable 'comment-continue)  nil)
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    91
  (set (make-local-variable 'comment-end)  "")
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    92
  (set (make-local-variable 'comment-end-skip)  nil)
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    93
  (set (make-local-variable 'comment-multi-line)  nil)
373
51565d9fe630 Highlight comment syntax. Fix uncommenting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 372
diff changeset
    94
  (set (make-local-variable 'comment-use-syntax)  nil) )
365
86acae5bd220 gadict-setup-comment-style
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 362
diff changeset
    95
368
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
    96
(defun gadict-setup-paragraph ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
    97
  "Setup gadict paragraph definition."
370
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    98
  (set (make-local-variable 'paragraph-separate)  "__$")
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
    99
  (set (make-local-variable 'paragraph-start)  "__$") )
368
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
   100
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
   101
(defun gadict-setup-page ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
   102
  "Setup gadict page definition."
370
04caf7b9657c Use same code for setting local variables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 369
diff changeset
   103
  (set (make-local-variable 'page-delimiter)  "__$") )
368
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
   104
382
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   105
(defvar gadict-indent-offset 2
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   106
  "Indent level.")
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   107
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   108
(defun gadict-indent-line ()
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   109
  "Indent line in gdict mode."
390
7783ce39023d Fix: Warning: Unused lexical variable `indent'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 382
diff changeset
   110
  (if (eq (current-indentation) gadict-indent-offset)
382
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   111
      (indent-line-to 0)
390
7783ce39023d Fix: Warning: Unused lexical variable `indent'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 382
diff changeset
   112
    (indent-line-to gadict-indent-offset)))
382
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   113
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   114
(defun gadict-setup-indent ()
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   115
  "Setup indenting for gdict mode."
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   116
  (set (make-local-variable 'indent-line-function) 'gadict-indent-line))
369
0f500491f990 Setup syntax table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 368
diff changeset
   117
374
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   118
(defun gadict-mark-article ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
   119
  "Mark current article."
374
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   120
  (end-of-line)
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   121
  (re-search-backward "^__$")
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   122
  (set-mark (point))
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   123
  (forward-line)
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   124
  (if (re-search-forward "^__$" nil t)
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   125
      (forward-line 0)
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   126
    (goto-char (point-max)))
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   127
  (exchange-point-and-mark))
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   128
391
68d510b25621 Fix: Warning: assignment to free variable `er/try-expand-list'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 390
diff changeset
   129
(defvar er/try-expand-list)
374
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   130
(defun gadict-setup-expansions ()
375
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   131
  "Add `gadict-mode' specific expansions."
374
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   132
  (set (make-local-variable 'er/try-expand-list) (list #'gadict-mark-article)))
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   133
395
32309860fe92 Simplify code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 392
diff changeset
   134
(defvar font-lock-beg)
32309860fe92 Simplify code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 392
diff changeset
   135
(defvar font-lock-end)
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   136
(defun gadict-font-lock-extend-region ()
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   137
  "Look for '__' expression and extend `font-lock-beg' and `font-lock-end'."
329
410c26a389a6 Fix highlighting near beginning and end of buffer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 328
diff changeset
   138
  ;; (message "%d:%d, %d lines" font-lock-beg font-lock-end (count-lines font-lock-beg font-lock-end))
328
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   139
  (cond
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   140
   ((and
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   141
     (< (count-lines font-lock-beg font-lock-end) 5)
329
410c26a389a6 Fix highlighting near beginning and end of buffer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 328
diff changeset
   142
     (not (and (<= (point-max) font-lock-end) (<= font-lock-beg (point-min)) )))
325
e64b740278c5 Finally fix multiline highlighting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 324
diff changeset
   143
    (save-excursion
e64b740278c5 Finally fix multiline highlighting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 324
diff changeset
   144
      (goto-char font-lock-beg)
e64b740278c5 Finally fix multiline highlighting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 324
diff changeset
   145
      (forward-line -2)
328
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   146
      (setq font-lock-beg (point))
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   147
      (goto-char font-lock-end)
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   148
      (forward-line 3)
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   149
      (setq font-lock-end (point))
327
21124e46bf6e Return non-nil if region was adjusted.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 326
diff changeset
   150
      )
328
80146b5ba6e6 Fix infinite invocation of 'dict-c5-font-lock-extend-region' by guarding condition.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 327
diff changeset
   151
    t)
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   152
   (t nil) ))
325
e64b740278c5 Finally fix multiline highlighting.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 324
diff changeset
   153
372
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   154
(defvar-local gadict-tr nil
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   155
  "Translation markers as string separated by comma. Define own
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   156
  values in .dir-local.el or as -*- gadict-tr: \"...\" -*- file prelude")
379
c336b3ebd9df Mark gadict-tr as safe variable.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 378
diff changeset
   157
(put 'gadict-tr 'safe-local-variable 'string-or-null-p)
372
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   158
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   159
(defun gadict-insert-template (&optional headword)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   160
  "Insert new article template after the current place."
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   161
  (interactive)
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   162
  (if (re-search-forward "^__" nil t)
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   163
      (beginning-of-line)
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   164
    (goto-char (point-max)))
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   165
  (while (eq (char-before) ?\n)
375
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   166
    (delete-char -1))
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   167
  (insert-char ?\n)
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   168
  (insert-char ?_ 2)
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   169
  (insert-char ?\n 3)
372
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   170
  (when (stringp gadict-tr)
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   171
    (mapc (lambda (tr)
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   172
            (insert-char ?\n)
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   173
            (insert tr)
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   174
            (insert ": "))
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   175
          (split-string gadict-tr ","))
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   176
    (insert-char ?\n)
563
e003bfd46c29 Fix: proper back to headword position.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 542
diff changeset
   177
    (backward-char)
372
e14e384267ee Article template automatically insert translation tags.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 371
diff changeset
   178
    (re-search-backward "^$"))
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   179
  (backward-char)
423
6a772e1fc63d Add bracket for pronunciation if headword is provided. Recenter point for best view.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 420
diff changeset
   180
  (when headword
6a772e1fc63d Add bracket for pronunciation if headword is provided. Recenter point for best view.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 420
diff changeset
   181
    (insert headword)
6a772e1fc63d Add bracket for pronunciation if headword is provided. Recenter point for best view.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 420
diff changeset
   182
    (insert "\n  []")
435
ca2c73d8698f Recenter also if article is found.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 423
diff changeset
   183
    (backward-char)))
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   184
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   185
(defun gadict-search-floor (headword)
440
fb584cf490db Fix: very first word inserted in second position, should at first.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 435
diff changeset
   186
  "Move to HEADWORD definition or place on posiiton for new corresponding
fb584cf490db Fix: very first word inserted in second position, should at first.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 435
diff changeset
   187
definition. Check for headwords ordering during search.
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   188
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   189
Return `t' if definition found, `nil' if no such headword."
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   190
  (let ( prev curr )
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   191
    (catch 'exit
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   192
      (goto-char (point-min))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   193
      (unless (re-search-forward "^__$" nil t)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   194
        (throw 'exit nil))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   195
      (forward-line 2)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   196
      (setq prev (buffer-substring-no-properties (point) (line-end-position)))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   197
      (when (string= headword prev)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   198
        (throw 'exit t))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   199
      (when (string< headword prev)
440
fb584cf490db Fix: very first word inserted in second position, should at first.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 435
diff changeset
   200
        (goto-char (point-min))
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   201
        (throw 'exit nil))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   202
      (while t
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   203
        (unless (re-search-forward "^__$" nil t)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   204
          (throw 'exit nil))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   205
        (forward-line 2)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   206
        (setq curr (buffer-substring-no-properties (point) (line-end-position)))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   207
        (unless (string< prev curr)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   208
          (error (format "%s < %s" curr prev)))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   209
        (when (string= headword curr)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   210
          (throw 'exit t))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   211
        (when (string< headword curr)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   212
          (forward-line -2)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   213
          (re-search-backward "^__$")
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   214
          (forward-line 2)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   215
          (throw 'exit nil))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   216
        (setq prev curr)) )))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   217
448
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   218
(defun gadict-search (headword)
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   219
  "Move to HEADWORD definition or place on posiiton for new corresponding
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   220
definition. Check for headwords ordering during search."
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   221
  (interactive (list (read-string "Headword: ")))
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   222
  (gadict-search-floor headword)
453
ad2b19c9d05d Fix: "recenter-top-bottom" => "recenter" to place view point at center of
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 448
diff changeset
   223
  (recenter))
448
a61c140a4b6f Recenter screen to article on search request.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 444
diff changeset
   224
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   225
(defun gadict-insert-template-in-order (headword)
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   226
  "Insert new article template with respect of headword order."
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   227
  (interactive (list (read-string "Headword: ")))
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   228
  (unless (gadict-search-floor headword)
435
ca2c73d8698f Recenter also if article is found.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 423
diff changeset
   229
    (gadict-insert-template headword))
453
ad2b19c9d05d Fix: "recenter-top-bottom" => "recenter" to place view point at center of
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 448
diff changeset
   230
  (recenter))
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   231
652
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   232
(defun gadict--find-headword-end ()
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   233
  (save-excursion
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   234
    (end-of-line)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   235
    (re-search-backward "^__$")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   236
    (re-search-forward "^$")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   237
    (forward-char)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   238
    (re-search-forward "^$")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   239
    (point)))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   240
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   241
(defun gadict-insert-translation (pos)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   242
  "Insert translation template with using value of `gadict-tr'."
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   243
  (interactive (list (completing-read "POS: " gadict--pos nil t)))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   244
  (let ( (headword-end (gadict--find-headword-end)) )
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   245
    (if (< (point) headword-end)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   246
        (goto-char headword-end)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   247
      (re-search-forward "^\\(?:\\|__\\)$")
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   248
      (when (eq (char-before) ?_)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   249
        (beginning-of-line)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   250
        ;; (newline)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   251
        ;; (backward-char)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   252
        ))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   253
    (insert-char ?\n)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   254
    (insert pos)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   255
    (insert-char ?\n)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   256
    (save-excursion
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   257
      (mapc (lambda (lang)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   258
              (insert lang)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   259
              (insert ": \n"))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   260
            (split-string gadict-tr ",")))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   261
    (end-of-line) ))
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   262
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   263
(defun gadict-nearest-headword ()
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   264
  "Return nearest headword looking upward."
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   265
  (save-excursion
714
ac5c3669ce32 Fix Warning: Unused lexical variable.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 712
diff changeset
   266
    (let ( (orig (point)) limit )
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   267
      (re-search-backward "^__$")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   268
      (forward-line 1)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   269
      (unless (and (eq (char-before) ?\n) (eq (char-after) ?\n))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   270
        (error "Syntax error: there is not empty line after '__'..."))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   271
      (forward-line 1)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   272
      (when (< orig (point))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   273
        (setq orig (point)))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   274
      (setq limit (point))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   275
      (re-search-forward "^$")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   276
      (when (< orig (point))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   277
        (goto-char orig)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   278
        (end-of-line))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   279
      (re-search-backward "^\\([^ ].*\\)$" limit)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   280
      (match-string 1)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   281
      )))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   282
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   283
(defvar gadict-espeak-program "espeak")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   284
(defvar gadict-espeak-program-ipa-args "-q --ipa=2")
711
d6040290ee78 In case of parsing error do not display IPA headline.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 710
diff changeset
   285
;; "en" "en-gb" "en-us" "en-sc"
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   286
(defvar gadict-espeak-voices-list '("en-gb" "en-us")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   287
  "What voices to show. Look to 'espeak --voices' for full list.")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   288
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   289
(defun gadict-espeak-ipa (str &optional voice)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   290
  (gadict--trim
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   291
   (shell-command-to-string
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   292
    (format "%s %s %s %s"
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   293
            gadict-espeak-program
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   294
            gadict-espeak-program-ipa-args
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   295
            (if (stringp voice) (concat "-v" (shell-quote-argument voice)) "")
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   296
            (shell-quote-argument str)))))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   297
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   298
(defun gadict-espeak-ipa-line (headword)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   299
  (mapconcat (lambda (voice) (format "%s: %s"
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   300
                                (propertize voice 'face '(:foreground "red"))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   301
                                (gadict-espeak-ipa headword voice)))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   302
             (if (listp gadict-espeak-voices-list) gadict-espeak-voices-list '(nil))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   303
             " | "))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   304
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   305
;; (defun gadict-espeak-ipa-display ()
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   306
;;   (interactive)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   307
;;   (message (gadict-espeak-ipa-line)))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   308
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   309
(defvar gadict-espeak-ipa-headword nil)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   310
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   311
(defun gadict-espeak-ipa-display ()
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   312
  (when (eq major-mode 'gadict-mode)
711
d6040290ee78 In case of parsing error do not display IPA headline.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 710
diff changeset
   313
    (let ( (headword (condition-case nil (gadict-nearest-headword) (error nil))) )
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   314
      (unless (eq headword gadict-espeak-ipa-headword)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   315
        (setq gadict-espeak-ipa-headword headword)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   316
        (setq header-line-format (if headword (gadict-espeak-ipa-line headword) nil))
712
f543ce84794f http://emacs.stackexchange.com/questions/29225/force-window-update-vs-redisplay/
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 711
diff changeset
   317
        (force-mode-line-update)))))
710
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   318
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   319
(defvar gadict-espeak-ipa-timer nil)
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   320
(defun gadict-espeak-ipa-enable ()
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   321
  (unless gadict-espeak-ipa-timer
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   322
    (setq gadict-espeak-ipa-timer (run-with-idle-timer 1 t #'gadict-espeak-ipa-display))))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   323
(defun gadict-espeak-ipa-disable ()
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   324
  (when gadict-espeak-ipa-timer
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   325
    (cancel-timer gadict-espeak-ipa-timer))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   326
  (setq gadict-espeak-ipa-timer nil))
59bfd8195afa Initial code for displaying IPA pronunciation from espeak.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 652
diff changeset
   327
366
98ac19478839 gadict-setup-keymap
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 365
diff changeset
   328
(defun gadict-setup-keymap ()
380
f0e2c538bf85 Add docs to functions to 100% satisfy checkdoc.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 379
diff changeset
   329
  "Setup gadict keymap."
652
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   330
  (define-key (current-local-map) [M-return] 'gadict-search)
fa97354a56d3 Insert translation template with using value of `gadict-tr'.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 647
diff changeset
   331
  (define-key (current-local-map) [S-return] 'gadict-insert-translation)
398
54ef571cf72a Function to maintain articles in headword lexical order.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 395
diff changeset
   332
  (define-key (current-local-map) [C-return] 'gadict-insert-template-in-order))
335
8732c7c894af dict-c5-new-entry
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 334
diff changeset
   333
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
   334
;;;###autoload
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   335
(define-derived-mode gadict-mode fundamental-mode "gadict"
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   336
  "Derived mode for editing gadict dictionary source files."
371
d5d1d3e6d11e gadict-setup-fontlock
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 370
diff changeset
   337
  (gadict-setup-fontlock)
366
98ac19478839 gadict-setup-keymap
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 365
diff changeset
   338
  (gadict-setup-keymap)
369
0f500491f990 Setup syntax table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 368
diff changeset
   339
  (gadict-setup-syntax)
368
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
   340
  (gadict-setup-paragraph)
9c6515663b38 Define paragraph/page break at "__" delimiter.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 367
diff changeset
   341
  (gadict-setup-page)
374
aeaa3f721014 Add expand-region support.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 373
diff changeset
   342
  (gadict-setup-comment)
382
9a596f1366ac Setup indenting for gdict mode.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 381
diff changeset
   343
  (gadict-setup-indent)
719
ebc16c3a9129 Enable gadict-espeak-ipa if "espeak" available in PATH.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 714
diff changeset
   344
  (gadict-setup-expansions)
ebc16c3a9129 Enable gadict-espeak-ipa if "espeak" available in PATH.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 714
diff changeset
   345
  (when (executable-find gadict-espeak-program)
ebc16c3a9129 Enable gadict-espeak-ipa if "espeak" available in PATH.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 714
diff changeset
   346
    (gadict-espeak-ipa-enable)))
361
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   347
6dee73a3e3cb Basic adaptation to gadict format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 335
diff changeset
   348
(provide 'gadict)
320
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
   349
4272023569f3 major mode for dict dictionary source files
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
   350
;;; dict-mode.el ends here
375
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   351
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   352
(provide 'gadict)
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   353
a2ec98ead57a Fix warning from M-x checkdoc. Add lexical-binding: t.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 374
diff changeset
   354
;;; gadict.el ends here