예제 #1
0
static void spWriteFreeFlush(SecBuffer& sb, const ZStreamW& w)
{
    if (not sb.pvBuffer)
        return;

    if (not sb.cbBuffer)
    {
        spPSFT->FreeContextBuffer(sb.pvBuffer);
        sb.pvBuffer = nullptr;
    }
    else
    {
        size_t countWritten = 0;
        w.Write(sb.pvBuffer, sb.cbBuffer, &countWritten);

        const bool shortWrite = (countWritten != sb.cbBuffer);
        sb.cbBuffer = 0;

        spPSFT->FreeContextBuffer(sb.pvBuffer);
        sb.pvBuffer = nullptr;

        if (shortWrite)
            ZStreamW::sThrowEndOfStream();
        w.Flush();
    }
}
예제 #2
0
bool ZTSWatcherServerAsync::Write(const ZStreamW& iStreamW)
{
    bool wroteAnything = false;

    ZMutexLocker locker(fMutex);
    if (fSendClose)
    {
        iStreamW.WriteUInt8(eResp_Close);
        return false;
    }
    else if (fIDsNeeded)
    {
        if (ZLOG(s, eDebug, "ZTSWatcherServerAsync"))
            s << "Write, sending IDs";
        const size_t countNeeded = fIDsNeeded;
        fIDsNeeded = 0;
        locker.Release();

        uint64 theBaseID;
        size_t countIssued;

        bool success = fTSWatcher->AllocateIDs(countNeeded, theBaseID, countIssued);

        if (!success)
        {
            iStreamW.WriteUInt8(eResp_Close);
            return false;
        }

        iStreamW.WriteUInt8(eResp_IDs);
        iStreamW.WriteUInt64(theBaseID);
        iStreamW.WriteCount(countIssued);

        wroteAnything = true;

        if (ZLOG(s, eDebug, "ZTSWatcherServerAsync"))
            s << "Write, sent IDs";
    }
    else if (fSyncNeeded)
    {
        if (ZLOG(s, eDebug, "ZTSWatcherServerAsync"))
            s << "Write, sync";
        fSyncNeeded = false;

        vector<uint64> removedIDs;
        vector<uint64> addedIDs;
        vector<int64> removedQueries;
        vector<ZTSWatcher::AddedQueryCombo> addedQueries;
        vector<uint64> writtenTupleIDs;
        vector<ZTuple> writtenTuples;

        fRemovedIDs.swap(removedIDs);
        fAddedIDs.swap(addedIDs);
        fRemovedQueries.swap(removedQueries);
        fAddedQueries.swap(addedQueries);
        fWrittenTupleIDs.swap(writtenTupleIDs);
        fWrittenTuples.swap(writtenTuples);

        locker.Release();

        vector<uint64> watcherAddedIDs;
        vector<uint64> changedTupleIDs;
        vector<ZTuple> changedTuples;
        map<int64, vector<uint64> > changedQueries;

        using ZUtil_STL::sFirstOrNil;
        bool success = fTSWatcher->Sync(
                           sFirstOrNil(removedIDs), removedIDs.size(),
                           sFirstOrNil(addedIDs), addedIDs.size(),
                           sFirstOrNil(removedQueries), removedQueries.size(),
                           sFirstOrNil(addedQueries), addedQueries.size(),
                           watcherAddedIDs,
                           changedTupleIDs, changedTuples,
                           sFirstOrNil(writtenTupleIDs), sFirstOrNil(writtenTuples), writtenTupleIDs.size(),
                           changedQueries);

        if (!success)
        {
            iStreamW.WriteUInt8(eResp_Close);
            return false;
        }

        iStreamW.WriteUInt8(eResp_SyncResults);

        iStreamW.WriteCount(watcherAddedIDs.size());
        for (vector<uint64>::const_iterator
                i = watcherAddedIDs.begin(), theEnd = watcherAddedIDs.end();
                i != theEnd; ++i)
        {
            iStreamW.WriteUInt64(*i);
        }

        iStreamW.WriteCount(changedTupleIDs.size());
        vector<ZTuple>::const_iterator iterCT = changedTuples.begin();
        for (vector<uint64>::const_iterator
                i = changedTupleIDs.begin(), theEnd = changedTupleIDs.end();
                i != theEnd; ++i, ++iterCT)
        {
            iStreamW.WriteUInt64(*i);
            (*iterCT).ToStream(iStreamW);
        }

        iStreamW.WriteCount(changedQueries.size());
        for (map<int64, vector<uint64> >::const_iterator
                i = changedQueries.begin(), theEnd = changedQueries.end();
                i != theEnd; ++i)
        {
            iStreamW.WriteInt64((*i).first);
            const vector<uint64>& theVector = (*i).second;
            iStreamW.WriteCount(theVector.size());
            for (vector<uint64>::const_iterator j = theVector.begin(); j != theVector.end(); ++j)
                iStreamW.WriteUInt64(*j);
        }

        wroteAnything = true;
    }
    else if (fCallbackNeeded)
    {
        if (ZLOG(s, eDebug, "ZTSWatcherServerAsync"))
            s << "Write, callback";
        fCallbackNeeded = false;
        locker.Release();
        iStreamW.WriteUInt8(eResp_SyncSuggested);

        wroteAnything = true;
    }

    if (wroteAnything)
        ZStreamerWriter::Wake();
    else
        iStreamW.Flush();

    return true;
}