/* * Copyright (C) 2015-2018 Département de l'Instruction Publique (DIP-SEM) * * Copyright (C) 2013 Open Education Foundation * * Copyright (C) 2010-2013 Groupement d'Intérêt Public pour * l'Education Numérique en Afrique (GIP ENA) * * This file is part of OpenBoard. * * OpenBoard is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, version 3 of the License, * with a specific linking exception for the OpenSSL project's * "OpenSSL" library (or with modified versions of it that use the * same license as the "OpenSSL" library). * * OpenBoard 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with OpenBoard. If not, see . */ #include #include #include "ASCII85Decode.h" #include "core/memcheck.h" using namespace merge_lib; static const unsigned long pow85[] = { 85*85*85*85, 85*85*85, 85*85, 85, 1 }; void ASCII85Decode::_wput(std::string &cur,unsigned long tuple, int len) { switch (len) { case 4: cur+=static_cast(tuple >> 24); cur+=static_cast(tuple >> 16); cur+=static_cast(tuple >> 8); cur+=static_cast(tuple); break; case 3: cur+=static_cast(tuple >> 24); cur+=static_cast(tuple >> 16); cur+=static_cast(tuple >> 8); break; case 2: cur+=static_cast(tuple >> 24); cur+=static_cast(tuple >> 16); break; case 1: cur+=static_cast(tuple >> 24); break; default: std::cerr<<"Asci85Filter - unexpected len = "< 'u' ) { std::cerr<<"bag character in ascii85 block["<') { if( count > 0 ) { count --; tuple += pow85[count]; _wput(decoded,tuple,count); } } encoded = decoded; return true; } std::cerr<<"~ without > in ascii85 stream!\n = ["<