Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 1 | " Vim indent file |
Bram Moolenaar | 6e64922 | 2021-10-04 21:32:54 +0100 | [diff] [blame] | 2 | " Language: Makefile |
| 3 | " Maintainer: Doug Kearns <dougkearns@gmail.com> |
| 4 | " Previous Maintainer: Nikolai Weibull <now@bitwi.se> |
Bram Moolenaar | cbaff5e | 2022-04-08 17:45:08 +0100 | [diff] [blame] | 5 | " Last Change: 2022 Apr 06 |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 6 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 7 | if exists("b:did_indent") |
| 8 | finish |
| 9 | endif |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 10 | let b:did_indent = 1 |
| 11 | |
| 12 | setlocal indentexpr=GetMakeIndent() |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 13 | setlocal indentkeys=!^F,o,O,<:>,=else,=endif |
Bram Moolenaar | f193fff | 2006-04-27 00:02:13 +0000 | [diff] [blame] | 14 | setlocal nosmartindent |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 15 | |
Bram Moolenaar | cbaff5e | 2022-04-08 17:45:08 +0100 | [diff] [blame] | 16 | let b:undo_indent = "setl inde< indk< si<" |
Bram Moolenaar | 6e64922 | 2021-10-04 21:32:54 +0100 | [diff] [blame] | 17 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 18 | if exists("*GetMakeIndent") |
| 19 | finish |
| 20 | endif |
| 21 | |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 22 | let s:comment_rx = '^\s*#' |
Bram Moolenaar | 57657d8 | 2006-04-21 22:12:41 +0000 | [diff] [blame] | 23 | let s:rule_rx = '^[^ \t#:][^#:]*:\{1,2}\%([^=:]\|$\)' |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 24 | let s:continued_rule_rx = '^[^#:]*:\{1,2}\%([^=:]\|$\)' |
Bram Moolenaar | 57657d8 | 2006-04-21 22:12:41 +0000 | [diff] [blame] | 25 | let s:continuation_rx = '\\$' |
Bram Moolenaar | 4c29502 | 2021-05-02 17:19:11 +0200 | [diff] [blame] | 26 | let s:assignment_rx = '^\s*\h\w*\s*[+:?]\==\s*\zs.*\\$' |
| 27 | let s:folded_assignment_rx = '^\s*\h\w*\s*[+:?]\==' |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 28 | " TODO: This needs to be a lot more restrictive in what it matches. |
| 29 | let s:just_inserted_rule_rx = '^\s*[^#:]\+:\{1,2}$' |
| 30 | let s:conditional_directive_rx = '^ *\%(ifn\=\%(eq\|def\)\|else\)\>' |
| 31 | let s:end_conditional_directive_rx = '^\s*\%(else\|endif\)\>' |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 32 | |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 33 | function s:remove_continuation(line) |
| 34 | return substitute(a:line, s:continuation_rx, "", "") |
| 35 | endfunction |
| 36 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 37 | function GetMakeIndent() |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 38 | " TODO: Should this perhaps be v:lnum -1? |
| 39 | " let prev_lnum = prevnonblank(v:lnum - 1) |
| 40 | let prev_lnum = v:lnum - 1 |
| 41 | if prev_lnum == 0 |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 42 | return 0 |
| 43 | endif |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 44 | let prev_line = getline(prev_lnum) |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 45 | |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 46 | let prev_prev_lnum = prev_lnum - 1 |
| 47 | let prev_prev_line = prev_prev_lnum != 0 ? getline(prev_prev_lnum) : "" |
Bram Moolenaar | 57657d8 | 2006-04-21 22:12:41 +0000 | [diff] [blame] | 48 | |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 49 | " TODO: Deal with comments. In comments, continuations aren't interesting. |
| 50 | if prev_line =~ s:continuation_rx |
| 51 | if prev_prev_line =~ s:continuation_rx |
| 52 | return indent(prev_lnum) |
| 53 | elseif prev_line =~ s:rule_rx |
Bram Moolenaar | 036986f | 2017-03-16 17:41:02 +0100 | [diff] [blame] | 54 | return shiftwidth() |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 55 | elseif prev_line =~ s:assignment_rx |
| 56 | call cursor(prev_lnum, 1) |
Bram Moolenaar | f193fff | 2006-04-27 00:02:13 +0000 | [diff] [blame] | 57 | if search(s:assignment_rx, 'W') != 0 |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 58 | return virtcol('.') - 1 |
| 59 | else |
| 60 | " TODO: ? |
Bram Moolenaar | 036986f | 2017-03-16 17:41:02 +0100 | [diff] [blame] | 61 | return shiftwidth() |
Bram Moolenaar | f193fff | 2006-04-27 00:02:13 +0000 | [diff] [blame] | 62 | endif |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 63 | else |
| 64 | " TODO: OK, this might be a continued shell command, so perhaps indent |
| 65 | " properly here? Leave this out for now, but in the next release this |
| 66 | " should be using indent/sh.vim somehow. |
| 67 | "if prev_line =~ '^\t' " s:rule_command_rx |
| 68 | " if prev_line =~ '^\s\+[@-]\%(if\)\>' |
| 69 | " return indent(prev_lnum) + 2 |
| 70 | " endif |
| 71 | "endif |
Bram Moolenaar | 036986f | 2017-03-16 17:41:02 +0100 | [diff] [blame] | 72 | return indent(prev_lnum) + shiftwidth() |
Bram Moolenaar | f193fff | 2006-04-27 00:02:13 +0000 | [diff] [blame] | 73 | endif |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 74 | elseif prev_prev_line =~ s:continuation_rx |
| 75 | let folded_line = s:remove_continuation(prev_prev_line) . ' ' . s:remove_continuation(prev_line) |
| 76 | let lnum = prev_prev_lnum - 1 |
| 77 | let line = getline(lnum) |
| 78 | while line =~ s:continuation_rx |
| 79 | let folded_line = s:remove_continuation(line) . ' ' . folded_line |
Bram Moolenaar | 57657d8 | 2006-04-21 22:12:41 +0000 | [diff] [blame] | 80 | let lnum -= 1 |
| 81 | let line = getline(lnum) |
| 82 | endwhile |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 83 | let folded_lnum = lnum + 1 |
| 84 | if folded_line =~ s:rule_rx |
| 85 | if getline(v:lnum) =~ s:rule_rx |
| 86 | return 0 |
| 87 | else |
| 88 | return &ts |
| 89 | endif |
| 90 | else |
| 91 | " elseif folded_line =~ s:folded_assignment_rx |
| 92 | if getline(v:lnum) =~ s:rule_rx |
| 93 | return 0 |
| 94 | else |
| 95 | return indent(folded_lnum) |
| 96 | endif |
| 97 | " else |
| 98 | " " TODO: ? |
| 99 | " return indent(prev_lnum) |
| 100 | endif |
| 101 | elseif prev_line =~ s:rule_rx |
| 102 | if getline(v:lnum) =~ s:rule_rx |
| 103 | return 0 |
| 104 | else |
| 105 | return &ts |
| 106 | endif |
| 107 | elseif prev_line =~ s:conditional_directive_rx |
Bram Moolenaar | 036986f | 2017-03-16 17:41:02 +0100 | [diff] [blame] | 108 | return shiftwidth() |
Bram Moolenaar | f193fff | 2006-04-27 00:02:13 +0000 | [diff] [blame] | 109 | else |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 110 | let line = getline(v:lnum) |
| 111 | if line =~ s:just_inserted_rule_rx |
| 112 | return 0 |
| 113 | elseif line =~ s:end_conditional_directive_rx |
Bram Moolenaar | 036986f | 2017-03-16 17:41:02 +0100 | [diff] [blame] | 114 | return v:lnum - 1 == 0 ? 0 : indent(v:lnum - 1) - shiftwidth() |
Bram Moolenaar | 2bb8df2 | 2007-05-10 17:26:28 +0000 | [diff] [blame] | 115 | else |
| 116 | return v:lnum - 1 == 0 ? 0 : indent(v:lnum - 1) |
| 117 | endif |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 118 | endif |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 119 | endfunction |