diff options
author | Alon Zakai <alonzakai@gmail.com> | 2012-01-17 14:08:09 -0800 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2012-01-17 14:08:09 -0800 |
commit | 76ddb8091266741ae046d1b6fdeef4f782617d5b (patch) | |
tree | 21fc75bfcbdce916ab91b8a61d196ab059e082d3 /system/lib/libcxx/valarray.cpp | |
parent | 8a9fa2c6d739a53221ee717121c6f4d318abd3dd (diff) |
libc++ sources
Diffstat (limited to 'system/lib/libcxx/valarray.cpp')
-rw-r--r-- | system/lib/libcxx/valarray.cpp | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/system/lib/libcxx/valarray.cpp b/system/lib/libcxx/valarray.cpp new file mode 100644 index 00000000..2d8db52a --- /dev/null +++ b/system/lib/libcxx/valarray.cpp @@ -0,0 +1,54 @@ +//===------------------------ valarray.cpp --------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "valarray" + +_LIBCPP_BEGIN_NAMESPACE_STD + +template valarray<size_t>::valarray(size_t); +template valarray<size_t>::~valarray(); +template void valarray<size_t>::resize(size_t, size_t); + +void +gslice::__init(size_t __start) +{ + valarray<size_t> __indices(__size_.size()); + size_t __k = __size_.size() != 0; + for (size_t __i = 0; __i < __size_.size(); ++__i) + __k *= __size_[__i]; + __1d_.resize(__k); + if (__1d_.size()) + { + __k = 0; + __1d_[__k] = __start; + while (true) + { + size_t __i = __indices.size() - 1; + while (true) + { + if (++__indices[__i] < __size_[__i]) + { + ++__k; + __1d_[__k] = __1d_[__k-1] + __stride_[__i]; + for (size_t __j = __i + 1; __j != __indices.size(); ++__j) + __1d_[__k] -= __stride_[__j] * (__size_[__j] - 1); + break; + } + else + { + if (__i == 0) + return; + __indices[__i--] = 0; + } + } + } + } +} + +_LIBCPP_END_NAMESPACE_STD |