forked from mirrors/gecko-dev
		
	
		
			
				
	
	
		
			102 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
 | |
| /* This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
|  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| #include "ChunkSet.h"
 | |
| 
 | |
| namespace mozilla {
 | |
| namespace safebrowsing {
 | |
| 
 | |
| nsresult
 | |
| ChunkSet::Serialize(nsACString& aChunkStr)
 | |
| {
 | |
|   aChunkStr.Truncate();
 | |
| 
 | |
|   uint32_t i = 0;
 | |
|   while (i < mChunks.Length()) {
 | |
|     if (i != 0) {
 | |
|       aChunkStr.Append(',');
 | |
|     }
 | |
|     aChunkStr.AppendInt((int32_t)mChunks[i]);
 | |
| 
 | |
|     uint32_t first = i;
 | |
|     uint32_t last = first;
 | |
|     i++;
 | |
|     while (i < mChunks.Length() && (mChunks[i] == mChunks[i - 1] + 1 || mChunks[i] == mChunks[i - 1])) {
 | |
|       last = i++;
 | |
|     }
 | |
| 
 | |
|     if (last != first) {
 | |
|       aChunkStr.Append('-');
 | |
|       aChunkStr.AppendInt((int32_t)mChunks[last]);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   return NS_OK;
 | |
| }
 | |
| 
 | |
| nsresult
 | |
| ChunkSet::Set(uint32_t aChunk)
 | |
| {
 | |
|   size_t idx = mChunks.BinaryIndexOf(aChunk);
 | |
|   if (idx == nsTArray<uint32_t>::NoIndex) {
 | |
|     mChunks.InsertElementSorted(aChunk);
 | |
|   }
 | |
|   return NS_OK;
 | |
| }
 | |
| 
 | |
| nsresult
 | |
| ChunkSet::Unset(uint32_t aChunk)
 | |
| {
 | |
|   mChunks.RemoveElementSorted(aChunk);
 | |
| 
 | |
|   return NS_OK;
 | |
| }
 | |
| 
 | |
| bool
 | |
| ChunkSet::Has(uint32_t aChunk) const
 | |
| {
 | |
|   return mChunks.BinaryIndexOf(aChunk) != nsTArray<uint32_t>::NoIndex;
 | |
| }
 | |
| 
 | |
| nsresult
 | |
| ChunkSet::Merge(const ChunkSet& aOther)
 | |
| {
 | |
|   const uint32_t *dupIter = aOther.mChunks.Elements();
 | |
|   const uint32_t *end = aOther.mChunks.Elements() + aOther.mChunks.Length();
 | |
| 
 | |
|   for (const uint32_t *iter = dupIter; iter != end; iter++) {
 | |
|     nsresult rv = Set(*iter);
 | |
|     NS_ENSURE_SUCCESS(rv, rv);
 | |
|   }
 | |
| 
 | |
|   return NS_OK;
 | |
| }
 | |
| 
 | |
| nsresult
 | |
| ChunkSet::Remove(const ChunkSet& aOther)
 | |
| {
 | |
|   uint32_t *addIter = mChunks.Elements();
 | |
|   uint32_t *end = mChunks.Elements() + mChunks.Length();
 | |
| 
 | |
|   for (uint32_t *iter = addIter; iter != end; iter++) {
 | |
|     if (!aOther.Has(*iter)) {
 | |
|       *addIter = *iter;
 | |
|       addIter++;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   mChunks.SetLength(addIter - mChunks.Elements());
 | |
| 
 | |
|   return NS_OK;
 | |
| }
 | |
| 
 | |
| void
 | |
| ChunkSet::Clear()
 | |
| {
 | |
|   mChunks.Clear();
 | |
| }
 | |
| 
 | |
| }
 | |
| }
 | 
