Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 16 Dec 2007 14:14:31 +0000 (UTC)
From:      Diomidis Spinellis <dds@FreeBSD.org>
To:        src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org
Subject:   cvs commit: src/bin/mv mv.c
Message-ID:  <200712161414.lBGEEV3O050572@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
dds         2007-12-16 14:14:31 UTC

  FreeBSD src repository

  Modified files:
    bin/mv               mv.c 
  Log:
  When moving a directory across devices to a place where a directory
  with the same name exists, delete that directory first, before performing
  the copy.  This ensures that mv(1) across devices follows the semantics
  of rename(2), as required by POSIX.
  
  This change could introduce the potential of data loss, even if the
  copy fails, violating the atomicity properties of rename(2).  This is
  (mostly) mitigated by first renaming the destination and obliterating
  it only after a succesfull copy.
  
  The above logic also led to the introduction of code that will cleanup
  the results of a partial copy, if a cross-device copy fails.
  
  PR:             bin/118367
  MFC after:      1 month
  
  Revision  Changes    Path
  1.47      +83 -23    src/bin/mv/mv.c



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200712161414.lBGEEV3O050572>