X-Git-Url: http://git.nguyen.vg/gitweb/?a=blobdiff_plain;f=libcds%2Fsrc%2Fstatic_sequence%2Fstatic_sequence.cpp;h=e97a1120ddcbb4a4b40a535ff82b8f024fb0c3dd;hb=52cb7bbcda67f4676335cdd4eb96d4d87ad1445d;hp=7f9fde2b20e6329193f8537ed17b7aa1dc402306;hpb=0bf9688e2615a9fc07860c5762240e4ce26ee5d3;p=SXSI%2FXMLTree.git diff --git a/libcds/src/static_sequence/static_sequence.cpp b/libcds/src/static_sequence/static_sequence.cpp index 7f9fde2..e97a112 100644 --- a/libcds/src/static_sequence/static_sequence.cpp +++ b/libcds/src/static_sequence/static_sequence.cpp @@ -1,16 +1,43 @@ - +/* static_sequence.cpp + * Copyright (C) 2008, Francisco Claude, all rights reserved. + * + * static_sequence definition + * + * This library 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 2.1 of the License, or (at your option) any later version. + * + * This library 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 this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + #include static_sequence::static_sequence() {} static_sequence::~static_sequence() {} uint static_sequence::length() { return len; } +uint static_sequence::count(uint s) { + return rank(s,len-1); +} + static_sequence * static_sequence::load(FILE * fp) { uint rd; if(fread(&rd,sizeof(uint),1,fp)!=1) return NULL; fseek(fp,-sizeof(uint),SEEK_CUR); switch(rd) { case WVTREE_HDR: return static_sequence_wvtree::load(fp); + case GMR_CHUNK_HDR: return static_sequence_gmr_chunk::load(fp); + case GMR_HDR: return static_sequence_gmr::load(fp); + case WVTREE_NOPTRS_HDR: return static_sequence_wvtree_noptrs::load(fp); } return NULL; }