/* * This program 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, either version 3 of the License, or * (at your option) any later version. * * This program 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 this program. If not, see . */ #include #include "ASCII85Decode.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 = ["<