summaryrefslogtreecommitdiff
path: root/elpa/auctex-13.1.3/style/wrapfig.el
blob: 35d8a0572e52d48e6400126c17853df27f39a102 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
;;; wrapfig.el --- AUCTeX style for `wrapfig.sty' version v3.6  -*- lexical-binding: t; -*-

;; Copyright (C) 2014, 2015 Free Software Foundation, Inc.

;; Author: Arash Esbati <arash@gnu.org>
;; Maintainer: auctex-devel@gnu.org
;; Created: 2014-12-13
;; Keywords: tex

;; This file is part of AUCTeX.

;; AUCTeX is free software; you can redistribute it and/or modify it
;; under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 3, or (at your option)
;; any later version.

;; AUCTeX is distributed in the hope that it will be useful, but
;; WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
;; General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with AUCTeX; see the file COPYING.  If not, write to the Free
;; Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
;; 02110-1301, USA.

;;; Commentary:

;; This file adds support for `wrapfig.sty' version v3.6 from
;; 2003/01/31.  `wrapfig.sty' is part of TeXLive.

;;; Code:

(require 'tex)
(require 'latex)

(TeX-add-style-hook
 "wrapfig"
 (lambda ()
   (LaTeX-add-environments
    ;; \begin{wrapfigure}[No.lines]{Placement}[Overhang]{Width} ... \end{wrapfigure}
    '("wrapfigure"
      (lambda (env &rest ignore)
        (LaTeX-insert-environment
         env
         (let ((narrow    (TeX-read-string "(Optional) Number of narrow lines: "))
               (placement (completing-read
                           "Placement: " '(("r") ("R")
                                           ("l") ("L")
                                           ("i") ("I")
                                           ("o") ("O"))))
               (overhang  (TeX-read-string "(Optional) Overhang: "))
               (width     (TeX-read-string "Width: ")))
           (concat
            (unless (string= narrow "")
              (format "[%s]" narrow))
            (format "{%s}" placement)
            (unless (string= overhang "")
              (format "[%s]" overhang))
            (format "{%s}" width))))))
    ;;
    ;; \begin{wraptable}[No.lines]{Placement}[Overhang]{Width} ... \end{wraptable}
    '("wraptable"
      (lambda (env &rest ignore)
        (LaTeX-insert-environment
         env
         (let ((narrow    (TeX-read-string "(Optional) Number of narrow lines: "))
               (placement (completing-read
                           "Placement: " '(("r") ("R")
                                           ("l") ("L")
                                           ("i") ("I")
                                           ("o") ("O"))))
               (overhang  (TeX-read-string "(Optional) Overhang: "))
               (width     (TeX-read-string "Width: ")))
           (concat
            (unless (string= narrow "")
              (format "[%s]" narrow))
            (format "{%s}" placement)
            (unless (string= overhang "")
              (format "[%s]" overhang))
            (format "{%s}" width))))))
    ;;
    ;; \begin{wrapfloat}{<Type>}[No.lines]{Placement}[Overhang]{Width} ... \end{wrapfloat}
    ;;
    ;; <Type> can be a new floating environment defined with
    ;; "\DeclareFloatingEnvironment" from newfloat.el.  We check if
    ;; the function `LaTeX-newfloat-DeclareFloatingEnvironment-list'
    ;; is bound and returns non-nil before offering environment for
    ;; completion.  Otherwise, just ask user without completion.
    '("wrapfloat"
      (lambda (env &rest ignore)
        (LaTeX-insert-environment
         env
         (let ((floattype (if (and (fboundp 'LaTeX-newfloat-DeclareFloatingEnvironment-list)
                                   (LaTeX-newfloat-DeclareFloatingEnvironment-list))
                              (completing-read
                               "Float type: "
                               (mapcar #'car (LaTeX-newfloat-DeclareFloatingEnvironment-list)))
                            (TeX-read-string "Float type: ")))
               (narrow    (TeX-read-string "(Optional) Number of narrow lines: "))
               (placement (completing-read
                           "Placement: " '(("r") ("R")
                                           ("l") ("L")
                                           ("i") ("I")
                                           ("o") ("O"))))
               (overhang  (TeX-read-string "(Optional) Overhang: "))
               (width     (TeX-read-string "Width: ")))
           (concat
            (format "{%s}" floattype)
            (unless (string= narrow "")
              (format "[%s]" narrow))
            (format "{%s}" placement)
            (unless (string= overhang "")
              (format "[%s]" overhang))
            (format "{%s}" width))))))))
 TeX-dialect)

(defvar LaTeX-wrapfig-package-options '("verbose")
  "Package options for the wrapfig package.")

;;; wrapfig.el ends here