From 73d6a1616ef0ca7ba65685594c4236b438bf5146 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Wed, 13 Jun 2012 13:40:48 +0200 Subject: updated for version 7.3.549 Problem: In 'cinoptions' "0s" is interpreted as one shiftwidth. (David Pineau) Solution: Use the zero as zero. (Lech Lorens) --- src/misc1.c | 4 +++- src/testdir/test3.in | 18 ++++++++++++++++++ src/testdir/test3.ok | 12 ++++++++++++ src/version.c | 2 ++ 4 files changed, 35 insertions(+), 1 deletion(-) diff --git a/src/misc1.c b/src/misc1.c index 7ba39727..988e368d 100644 --- a/src/misc1.c +++ b/src/misc1.c @@ -6635,6 +6635,7 @@ get_c_indent() int whilelevel; linenr_T lnum; char_u *options; + char_u *digits; int fraction = 0; /* init for GCC */ int divider; int n; @@ -6650,6 +6651,7 @@ get_c_indent() l = options++; if (*options == '-') ++options; + digits = options; /* remember where the digits start */ n = getdigits(&options); divider = 0; if (*options == '.') /* ".5s" means a fraction */ @@ -6666,7 +6668,7 @@ get_c_indent() } if (*options == 's') /* "2s" means two times 'shiftwidth' */ { - if (n == 0 && fraction == 0) + if (options == digits) n = curbuf->b_p_sw; /* just "s" is one 'shiftwidth' */ else { diff --git a/src/testdir/test3.in b/src/testdir/test3.in index 67fc131d..abb7750f 100644 --- a/src/testdir/test3.in +++ b/src/testdir/test3.in @@ -975,6 +975,24 @@ main ( int first_par, /* } +STARTTEST +:set cin +:set cino=es,n0s +/main +=][ +ENDTEST + +main(void) +{ + /* Make sure that cino=X0s is not parsed like cino=Xs. */ + if (cond) + foo(); + else + { + bar(); + } +} + STARTTEST :set cin :set cino= diff --git a/src/testdir/test3.ok b/src/testdir/test3.ok index 72cb75f1..011751be 100644 --- a/src/testdir/test3.ok +++ b/src/testdir/test3.ok @@ -940,6 +940,18 @@ main ( int first_par, /* } +main(void) +{ + /* Make sure that cino=X0s is not parsed like cino=Xs. */ + if (cond) + foo(); + else + { + bar(); + } +} + + { do { diff --git a/src/version.c b/src/version.c index e9f16079..1e5d5cdb 100644 --- a/src/version.c +++ b/src/version.c @@ -714,6 +714,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 549, /**/ 548, /**/ -- cgit v1.2.1