$include_dir="/home/hyper-archives/boost-commit/include"; include("$include_dir/msg-header.inc") ?>
Subject: [Boost-commit] svn:boost r60581 - in trunk: boost/iostreams libs/iostreams/test
From: daniel_james_at_[hidden]
Date: 2010-03-14 14:00:46
Author: danieljames
Date: 2010-03-14 14:00:45 EDT (Sun, 14 Mar 2010)
New Revision: 60581
URL: http://svn.boost.org/trac/boost/changeset/60581
Log:
In `position_to_offset`, only cast to `stream_offset` after calculating `_Myoff`. Refs #3969.
Thanks to Garth Sylvester-Bradley.
Text files modified: 
   trunk/boost/iostreams/positioning.hpp                  |     6 ++++--                                  
   trunk/libs/iostreams/test/stream_offset_64bit_test.cpp |    17 ++++++++++++++++-                       
   2 files changed, 20 insertions(+), 3 deletions(-)
Modified: trunk/boost/iostreams/positioning.hpp
==============================================================================
--- trunk/boost/iostreams/positioning.hpp	(original)
+++ trunk/boost/iostreams/positioning.hpp	2010-03-14 14:00:45 EDT (Sun, 14 Mar 2010)
@@ -102,8 +102,10 @@
 inline stream_offset position_to_offset(std::streampos pos)
 {
     return fpos_t_to_offset(streampos_to_fpos_t(pos)) +
-           static_cast<stream_offset>(static_cast<std::streamoff>(pos)) -
-           static_cast<stream_offset>(_FPOSOFF(streampos_to_fpos_t(pos)));
+        static_cast<stream_offset>(
+            static_cast<std::streamoff>(pos) -
+            _FPOSOFF(streampos_to_fpos_t(pos))
+        );
 }
 
 # endif // # ifndef BOOST_IOSTREAMS_HAS_DINKUMWARE_FPOS 
Modified: trunk/libs/iostreams/test/stream_offset_64bit_test.cpp
==============================================================================
--- trunk/libs/iostreams/test/stream_offset_64bit_test.cpp	(original)
+++ trunk/libs/iostreams/test/stream_offset_64bit_test.cpp	2010-03-14 14:00:45 EDT (Sun, 14 Mar 2010)
@@ -56,15 +56,30 @@
               << hex
               << static_cast<unsigned int>(off >> 32) 
               << " and (off & 0xFFFFFFFF) == 0x"
-              << static_cast<unsigned int>(off & 0xFFFFFFFF);
+              << static_cast<unsigned int>(off & 0xFFFFFFFF)
+	      << std::endl;
             BOOST_REQUIRE_MESSAGE(0, s.str().c_str());
         }
     }
 }
 
+void stream_offset_64bit_test2()
+{
+    boost::int64_t val = boost::int64_t(1) << 31;
+    std::streampos pos = boost::iostreams::offset_to_position(val);
+    pos -= 2;
+    BOOST_CHECK_EQUAL(val - 2, boost::iostreams::position_to_offset(pos));
+
+    val = -val;
+    pos = boost::iostreams::offset_to_position(val);
+    pos += 2;
+    BOOST_CHECK_EQUAL(val + 2, boost::iostreams::position_to_offset(pos));
+}
+
 test_suite* init_unit_test_suite(int, char* [])
 {
     test_suite* test = BOOST_TEST_SUITE("stream_offset 64-bit test");
     test->add(BOOST_TEST_CASE(&stream_offset_64bit_test));
+    test->add(BOOST_TEST_CASE(&stream_offset_64bit_test2));
     return test;
 }