| // | |
| // Copyright (c) 2011 The ANGLE Project Authors. All rights reserved. | |
| // Use of this source code is governed by a BSD-style license that can be | |
| // found in the LICENSE file. | |
| // | |
| #include "Input.h" | |
| #include <algorithm> | |
| #include <cassert> | |
| #include <cstring> | |
| namespace pp | |
| { | |
| Input::Input() : mCount(0), mString(0) | |
| { | |
| } | |
| Input::Input(int count, const char* const string[], const int length[]) : | |
| mCount(count), | |
| mString(string) | |
| { | |
| assert(mCount >= 0); | |
| mLength.reserve(mCount); | |
| for (int i = 0; i < mCount; ++i) | |
| { | |
| int len = length ? length[i] : -1; | |
| mLength.push_back(len < 0 ? strlen(mString[i]) : len); | |
| } | |
| } | |
| int Input::read(char* buf, int maxSize) | |
| { | |
| int nRead = 0; | |
| while ((nRead < maxSize) && (mReadLoc.sIndex < mCount)) | |
| { | |
| int size = mLength[mReadLoc.sIndex] - mReadLoc.cIndex; | |
| size = std::min(size, maxSize); | |
| memcpy(buf + nRead, mString[mReadLoc.sIndex] + mReadLoc.cIndex, size); | |
| nRead += size; | |
| mReadLoc.cIndex += size; | |
| // Advance string if we reached the end of current string. | |
| if (mReadLoc.cIndex == mLength[mReadLoc.sIndex]) | |
| { | |
| ++mReadLoc.sIndex; | |
| mReadLoc.cIndex = 0; | |
| } | |
| } | |
| return nRead; | |
| } | |
| } // namespace pp | |