Unify all mid() functions in QtBase.
authorJędrzej Nowacki <jedrzej.nowacki@digia.com>
Fri, 14 Feb 2014 15:32:31 +0000 (16:32 +0100)
committerThe Qt Project <gerrit-noreply@qt-project.org>
Fri, 16 May 2014 07:51:38 +0000 (09:51 +0200)
commit71fb3633e8d909e9a91e1bee6eaf53c146f25998
tree93995d7c6965b3cc944ed461dfcb4c5bbf5ac6f1
parent8f3a393e412fccd6606af5ef8d909da6435e16e2
Unify all mid() functions in QtBase.

Up to now, Qt had at least 3 different implementations of the mid().
Only QString::mid implementation was not crashing on edge cases and
was protected against overflows, therefore I picked that one as the
base implementation, even if it has weird semantics for an invalid
input.

As a side effect QVector::mid was slightly optimized to not detach in
all cases (which follows current QList behavior). Documentation of
QVector::mid and QList::mid was updated to not mention "copy of data"
which could suggest that the mid() result is detached.

QStringRef::mid was fixed and now it follows general Qt behavior, by
returning a null value for a null input.

Change-Id: Ie9ff5d98372bd193d66508e6dd92b6ed1180ad9b
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
src/corelib/tools/qarraydata.cpp
src/corelib/tools/qarraydata.h
src/corelib/tools/qbytearray.cpp
src/corelib/tools/qlist.cpp
src/corelib/tools/qlist.h
src/corelib/tools/qstring.cpp
src/corelib/tools/qvector.cpp
src/corelib/tools/qvector.h