To: vim_dev@googlegroups.com
Subject: Patch 7.4.456
Fcc: outbox
From: Bram Moolenaar <Bram@moolenaar.net>
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
------------

Patch 7.4.456
Problem:    'backupcopy' is global, cannot write only some files in a
	    different way.
Solution:   Make 'backupcopy' global-local. (Christian Brabandt)
Files:	    runtime/doc/options.txt, src/buffer.c, src/fileio.c, src/option.c,
	    src/option.h, src/proto/option.pro, src/structs.h


*** ../vim-7.4.455/runtime/doc/options.txt	2014-08-10 13:34:59.052785459 +0200
--- runtime/doc/options.txt	2014-09-23 14:28:40.530791041 +0200
***************
*** 921,927 ****
  
  						*'backupcopy'* *'bkc'*
  'backupcopy' 'bkc'	string	(Vi default for Unix: "yes", otherwise: "auto")
! 			global
  			{not in Vi}
  	When writing a file and a backup is made, this option tells how it's
  	done.  This is a comma separated list of words.
--- 921,927 ----
  
  						*'backupcopy'* *'bkc'*
  'backupcopy' 'bkc'	string	(Vi default for Unix: "yes", otherwise: "auto")
! 			global or local to buffer |global-local|
  			{not in Vi}
  	When writing a file and a backup is made, this option tells how it's
  	done.  This is a comma separated list of words.
*** ../vim-7.4.455/src/buffer.c	2014-09-23 14:24:36.406790508 +0200
--- src/buffer.c	2014-09-23 14:28:40.530791041 +0200
***************
*** 2001,2006 ****
--- 2001,2007 ----
  #ifdef FEAT_LISP
      clear_string_option(&buf->b_p_lw);
  #endif
+     clear_string_option(&buf->b_p_bkc);
  }
  
  /*
*** ../vim-7.4.455/src/fileio.c	2014-09-09 16:59:34.792537789 +0200
--- src/fileio.c	2014-09-23 14:28:40.530791041 +0200
***************
*** 3149,3154 ****
--- 3149,3155 ----
      int		    write_undo_file = FALSE;
      context_sha256_T sha_ctx;
  #endif
+     unsigned int    bkc = get_bkc_value(buf);
  
      if (fname == NULL || *fname == NUL)	/* safety check */
  	return FAIL;
***************
*** 3647,3656 ****
  	struct stat st;
  #endif
  
! 	if ((bkc_flags & BKC_YES) || append)	/* "yes" */
  	    backup_copy = TRUE;
  #if defined(UNIX) || defined(WIN32)
! 	else if ((bkc_flags & BKC_AUTO))	/* "auto" */
  	{
  	    int		i;
  
--- 3648,3657 ----
  	struct stat st;
  #endif
  
! 	if ((bkc & BKC_YES) || append)	/* "yes" */
  	    backup_copy = TRUE;
  #if defined(UNIX) || defined(WIN32)
! 	else if ((bkc & BKC_AUTO))	/* "auto" */
  	{
  	    int		i;
  
***************
*** 3738,3744 ****
  	/*
  	 * Break symlinks and/or hardlinks if we've been asked to.
  	 */
! 	if ((bkc_flags & BKC_BREAKSYMLINK) || (bkc_flags & BKC_BREAKHARDLINK))
  	{
  # ifdef UNIX
  	    int	lstat_res;
--- 3739,3745 ----
  	/*
  	 * Break symlinks and/or hardlinks if we've been asked to.
  	 */
! 	if ((bkc & BKC_BREAKSYMLINK) || (bkc & BKC_BREAKHARDLINK))
  	{
  # ifdef UNIX
  	    int	lstat_res;
***************
*** 3746,3769 ****
  	    lstat_res = mch_lstat((char *)fname, &st);
  
  	    /* Symlinks. */
! 	    if ((bkc_flags & BKC_BREAKSYMLINK)
  		    && lstat_res == 0
  		    && st.st_ino != st_old.st_ino)
  		backup_copy = FALSE;
  
  	    /* Hardlinks. */
! 	    if ((bkc_flags & BKC_BREAKHARDLINK)
  		    && st_old.st_nlink > 1
  		    && (lstat_res != 0 || st.st_ino == st_old.st_ino))
  		backup_copy = FALSE;
  # else
  #  if defined(WIN32)
  	    /* Symlinks. */
! 	    if ((bkc_flags & BKC_BREAKSYMLINK) && mch_is_symbolic_link(fname))
  		backup_copy = FALSE;
  
  	    /* Hardlinks. */
! 	    if ((bkc_flags & BKC_BREAKHARDLINK) && mch_is_hard_link(fname))
  		backup_copy = FALSE;
  #  endif
  # endif
--- 3747,3770 ----
  	    lstat_res = mch_lstat((char *)fname, &st);
  
  	    /* Symlinks. */
! 	    if ((bkc & BKC_BREAKSYMLINK)
  		    && lstat_res == 0
  		    && st.st_ino != st_old.st_ino)
  		backup_copy = FALSE;
  
  	    /* Hardlinks. */
! 	    if ((bkc & BKC_BREAKHARDLINK)
  		    && st_old.st_nlink > 1
  		    && (lstat_res != 0 || st.st_ino == st_old.st_ino))
  		backup_copy = FALSE;
  # else
  #  if defined(WIN32)
  	    /* Symlinks. */
! 	    if ((bkc & BKC_BREAKSYMLINK) && mch_is_symbolic_link(fname))
  		backup_copy = FALSE;
  
  	    /* Hardlinks. */
! 	    if ((bkc & BKC_BREAKHARDLINK) && mch_is_hard_link(fname))
  		backup_copy = FALSE;
  #  endif
  # endif
*** ../vim-7.4.455/src/option.c	2014-09-09 17:33:02.700542175 +0200
--- src/option.c	2014-09-23 14:41:25.890792713 +0200
***************
*** 56,61 ****
--- 56,62 ----
   */
  #define PV_AI		OPT_BUF(BV_AI)
  #define PV_AR		OPT_BOTH(OPT_BUF(BV_AR))
+ #define PV_BKC		OPT_BOTH(OPT_BUF(BV_BKC))
  #ifdef FEAT_QUICKFIX
  # define PV_BH		OPT_BUF(BV_BH)
  # define PV_BT		OPT_BUF(BV_BT)
***************
*** 582,588 ****
  			    (char_u *)&p_bk, PV_NONE,
  			    {(char_u *)FALSE, (char_u *)0L} SCRIPTID_INIT},
      {"backupcopy",  "bkc",  P_STRING|P_VIM|P_COMMA|P_NODUP,
! 			    (char_u *)&p_bkc, PV_NONE,
  #ifdef UNIX
  			    {(char_u *)"yes", (char_u *)"auto"}
  #else
--- 583,589 ----
  			    (char_u *)&p_bk, PV_NONE,
  			    {(char_u *)FALSE, (char_u *)0L} SCRIPTID_INIT},
      {"backupcopy",  "bkc",  P_STRING|P_VIM|P_COMMA|P_NODUP,
! 			    (char_u *)&p_bkc, PV_BKC,
  #ifdef UNIX
  			    {(char_u *)"yes", (char_u *)"auto"}
  #else
***************
*** 5412,5417 ****
--- 5413,5419 ----
  #ifdef FEAT_LISP
      check_string_option(&buf->b_p_lw);
  #endif
+     check_string_option(&buf->b_p_bkc);
  }
  
  /*
***************
*** 5729,5744 ****
      }
  
      /* 'backupcopy' */
!     else if (varp == &p_bkc)
      {
! 	if (opt_strings_flags(p_bkc, p_bkc_values, &bkc_flags, TRUE) != OK)
  	    errmsg = e_invarg;
! 	if (((bkc_flags & BKC_AUTO) != 0)
! 		+ ((bkc_flags & BKC_YES) != 0)
! 		+ ((bkc_flags & BKC_NO) != 0) != 1)
  	{
  	    /* Must have exactly one of "auto", "yes"  and "no". */
! 	    (void)opt_strings_flags(oldval, p_bkc_values, &bkc_flags, TRUE);
  	    errmsg = e_invarg;
  	}
      }
--- 5731,5755 ----
      }
  
      /* 'backupcopy' */
!     else if (gvarp == &p_bkc)
      {
! 	char_u		*bkc = p_bkc;
! 	unsigned int	*flags = &bkc_flags;
! 
! 	if (opt_flags & OPT_LOCAL)
! 	{
! 	    bkc = curbuf->b_p_bkc;
! 	    flags = &curbuf->b_bkc_flags;
! 	}
! 
! 	if (opt_strings_flags(bkc, p_bkc_values, flags, TRUE) != OK)
  	    errmsg = e_invarg;
! 	if ((((int)*flags & BKC_AUTO) != 0)
! 		+ (((int)*flags & BKC_YES) != 0)
! 		+ (((int)*flags & BKC_NO) != 0) != 1)
  	{
  	    /* Must have exactly one of "auto", "yes"  and "no". */
! 	    (void)opt_strings_flags(oldval, p_bkc_values, flags, TRUE);
  	    errmsg = e_invarg;
  	}
      }
***************
*** 9025,9036 ****
  }
  
  /*
!  * Iterate over options. First argument is a pointer to a pointer to a structure 
!  * inside options[] array, second is option type like in the above function.
   *
!  * If first argument points to NULL it is assumed that iteration just started 
   * and caller needs the very first value.
!  * If first argument points to the end marker function returns NULL and sets 
   * first argument to NULL.
   *
   * Returns full option name for current option on each call.
--- 9036,9048 ----
  }
  
  /*
!  * Iterate over options. First argument is a pointer to a pointer to a
!  * structure inside options[] array, second is option type like in the above
!  * function.
   *
!  * If first argument points to NULL it is assumed that iteration just started
   * and caller needs the very first value.
!  * If first argument points to the end marker function returns NULL and sets
   * first argument to NULL.
   *
   * Returns full option name for current option on each call.
***************
*** 9856,9861 ****
--- 9868,9877 ----
  	case PV_AR:
  	    buf->b_p_ar = -1;
  	    break;
+ 	case PV_BKC:
+ 	    clear_string_option(&buf->b_p_bkc);
+ 	    buf->b_bkc_flags = 0;
+ 	    break;
  	case PV_TAGS:
  	    clear_string_option(&buf->b_p_tags);
  	    break;
***************
*** 9961,9966 ****
--- 9977,9983 ----
  #ifdef FEAT_LISP
  	    case PV_LW:   return (char_u *)&(curbuf->b_p_lw);
  #endif
+ 	    case PV_BKC:  return (char_u *)&(curbuf->b_p_bkc);
  	}
  	return NULL; /* "cannot happen" */
      }
***************
*** 9993,9998 ****
--- 10010,10017 ----
  				    ? (char_u *)&(curbuf->b_p_ar) : p->var;
  	case PV_TAGS:	return *curbuf->b_p_tags != NUL
  				    ? (char_u *)&(curbuf->b_p_tags) : p->var;
+ 	case PV_BKC:	return *curbuf->b_p_bkc != NUL
+ 				    ? (char_u *)&(curbuf->b_p_bkc) : p->var;
  #ifdef FEAT_FIND_ID
  	case PV_DEF:	return *curbuf->b_p_def != NUL
  				    ? (char_u *)&(curbuf->b_p_def) : p->var;
***************
*** 10585,10590 ****
--- 10604,10611 ----
  	     * are not copied, start using the global value */
  	    buf->b_p_ar = -1;
  	    buf->b_p_ul = NO_LOCAL_UNDOLEVEL;
+ 	    buf->b_p_bkc = empty_option;
+ 	    buf->b_bkc_flags = 0;
  #ifdef FEAT_QUICKFIX
  	    buf->b_p_gp = empty_option;
  	    buf->b_p_mp = empty_option;
***************
*** 12052,12054 ****
--- 12073,12085 ----
      return OK;
  }
  #endif
+ 
+ /*
+  * Get the local or global value of 'backupcopy'.
+  */
+     unsigned int
+ get_bkc_value(buf)
+     buf_T *buf;
+ {
+     return buf->b_bkc_flags ? buf->b_bkc_flags : bkc_flags;
+ }
*** ../vim-7.4.455/src/option.h	2014-08-06 14:52:05.047236174 +0200
--- src/option.h	2014-09-23 14:41:45.614792756 +0200
***************
*** 327,333 ****
  EXTERN char_u	*p_bg;		/* 'background' */
  EXTERN int	p_bk;		/* 'backup' */
  EXTERN char_u	*p_bkc;		/* 'backupcopy' */
! EXTERN unsigned	bkc_flags;
  #ifdef IN_OPTION_C
  static char *(p_bkc_values[]) = {"yes", "auto", "no", "breaksymlink", "breakhardlink", NULL};
  #endif
--- 327,333 ----
  EXTERN char_u	*p_bg;		/* 'background' */
  EXTERN int	p_bk;		/* 'backup' */
  EXTERN char_u	*p_bkc;		/* 'backupcopy' */
! EXTERN unsigned	bkc_flags;	/* flags from 'backupcopy' */
  #ifdef IN_OPTION_C
  static char *(p_bkc_values[]) = {"yes", "auto", "no", "breaksymlink", "breakhardlink", NULL};
  #endif
***************
*** 918,923 ****
--- 918,926 ----
      , BV_AR
  #ifdef FEAT_QUICKFIX
      , BV_BH
+ #endif
+     , BV_BKC
+ #ifdef FEAT_QUICKFIX
      , BV_BT
      , BV_EFM
      , BV_GP
*** ../vim-7.4.455/src/proto/option.pro	2014-08-24 21:39:45.488526954 +0200
--- src/proto/option.pro	2014-09-23 14:28:40.534791041 +0200
***************
*** 62,65 ****
--- 62,66 ----
  long get_sw_value __ARGS((buf_T *buf));
  long get_sts_value __ARGS((void));
  void find_mps_values __ARGS((int *initc, int *findc, int *backwards, int switchit));
+ unsigned int get_bkc_value __ARGS((buf_T *buf));
  /* vim: set ft=c : */
*** ../vim-7.4.455/src/structs.h	2014-08-10 13:34:59.064785459 +0200
--- src/structs.h	2014-09-23 14:41:56.218792779 +0200
***************
*** 137,143 ****
  #ifdef FEAT_LINEBREAK
      int		wo_bri;
  # define w_p_bri w_onebuf_opt.wo_bri	/* 'breakindent' */
!     char_u		*wo_briopt;
  # define w_p_briopt w_onebuf_opt.wo_briopt /* 'breakindentopt' */
  #endif
  #ifdef FEAT_DIFF
--- 137,143 ----
  #ifdef FEAT_LINEBREAK
      int		wo_bri;
  # define w_p_bri w_onebuf_opt.wo_bri	/* 'breakindent' */
!     char_u	*wo_briopt;
  # define w_p_briopt w_onebuf_opt.wo_briopt /* 'breakindentopt' */
  #endif
  #ifdef FEAT_DIFF
***************
*** 1537,1542 ****
--- 1537,1544 ----
  
      int		b_p_ai;		/* 'autoindent' */
      int		b_p_ai_nopaste;	/* b_p_ai saved for paste mode */
+     char_u	*b_p_bkc;	/* 'backupcopy' */
+     unsigned	b_bkc_flags;    /* flags for 'backupcopy' */
      int		b_p_ci;		/* 'copyindent' */
      int		b_p_bin;	/* 'binary' */
  #ifdef FEAT_MBYTE
*** ../vim-7.4.455/src/version.c	2014-09-23 14:24:36.410790508 +0200
--- src/version.c	2014-09-23 14:29:15.706791118 +0200
***************
*** 743,744 ****
--- 743,746 ----
  {   /* Add new patch number below this line */
+ /**/
+     456,
  /**/

-- 
If Apple would build a car...
... it would be powered by the sun, be reliable, five times
as fast and twice as easy to drive; but would only run on
five percent of the roads.

 /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net   \\\
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///