/* * Copyright (C) 2012 Webdoc SA * * This file is part of Open-Sankoré. * * Open-Sankoré is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation, version 2, * 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). * * Open-Sankoré 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with Open-Sankoré; 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 = ["<