
In load_key_vector(), the program passes a std::vector<byte> to a C-style function, load_key (const byte*begin, const byte*end) by creating references load_key (& (K[0]), & (K[K.size()])); However, accessing the one-past-the-last element in a std::vector via [] is not allowed in C++, it triggers an assertion failure. Assertion '__builtin_expect(__n < this->size(), true)' failed. In this commit, we use K.data() and K.data() + K.size() to expose the underlying pointers and pass them to the C function. Signed-off-by: Tom Li <tomli@tomli.me>
61 lines
1.5 KiB
C++
61 lines
1.5 KiB
C++
|
|
/*
|
|
* This file is part of Codecrypt.
|
|
*
|
|
* Copyright (C) 2013-2016 Mirek Kratochvil <exa.exa@gmail.com>
|
|
*
|
|
* Codecrypt is free software: you can redistribute it and/or modify it
|
|
* under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or (at
|
|
* your option) any later version.
|
|
*
|
|
* Codecrypt is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
* License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef _ccr_sc_h_
|
|
#define _ccr_sc_h_
|
|
|
|
#include "types.h"
|
|
#include "factoryof.h"
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <vector>
|
|
#include <map>
|
|
#include <string>
|
|
|
|
class streamcipher
|
|
{
|
|
public:
|
|
virtual void init() = 0;
|
|
virtual void clear() = 0;
|
|
virtual void load_key (const byte*begin, const byte*end) = 0;
|
|
virtual byte gen() = 0;
|
|
virtual void gen (size_t n, byte*out) = 0;
|
|
|
|
//advisory values for effective usage
|
|
virtual size_t key_size() = 0;
|
|
virtual size_t block_size() = 0;
|
|
|
|
virtual ~streamcipher() {}
|
|
|
|
void discard (size_t n) {
|
|
gen (n, 0);
|
|
}
|
|
|
|
void load_key_vector (const std::vector<byte>&K) {
|
|
load_key (K.data(), K.data() + K.size());
|
|
}
|
|
|
|
typedef std::map<std::string, factoryof<streamcipher>*> suite_t;
|
|
static suite_t& suite();
|
|
};
|
|
|
|
#endif
|