Blame src/StringPool.cc

Packit 8f70b4
/*
Packit 8f70b4
 * lftp - file transfer program
Packit 8f70b4
 *
Packit 8f70b4
 * Copyright (c) 1996-2012 by Alexander V. Lukyanov (lav@yars.free.net)
Packit 8f70b4
 *
Packit 8f70b4
 * This program is free software; you can redistribute it and/or modify
Packit 8f70b4
 * it under the terms of the GNU General Public License as published by
Packit 8f70b4
 * the Free Software Foundation; either version 3 of the License, or
Packit 8f70b4
 * (at your option) any later version.
Packit 8f70b4
 *
Packit 8f70b4
 * This program is distributed in the hope that it will be useful,
Packit 8f70b4
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 8f70b4
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 8f70b4
 * GNU General Public License for more details.
Packit 8f70b4
 *
Packit 8f70b4
 * You should have received a copy of the GNU General Public License
Packit 8f70b4
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
Packit 8f70b4
 */
Packit 8f70b4
Packit 8f70b4
#include <config.h>
Packit 8f70b4
#include "StringPool.h"
Packit 8f70b4
#include "xarray.h"
Packit 8f70b4
Packit 8f70b4
xarray_m<char> StringPool::strings;
Packit 8f70b4
Packit 8f70b4
const char *StringPool::Get(const char *s)
Packit 8f70b4
{
Packit 8f70b4
   if(!s)
Packit 8f70b4
      return 0;
Packit 8f70b4
Packit 8f70b4
   int l=0;
Packit 8f70b4
   int u=strings.count();
Packit 8f70b4
Packit 8f70b4
   while(l
Packit 8f70b4
   {
Packit 8f70b4
      int m = (l + u) / 2;
Packit 8f70b4
      int cmp = strcmp(strings[m], s);
Packit 8f70b4
Packit 8f70b4
      if(cmp==0)  // found it.
Packit 8f70b4
	 return strings[m];
Packit 8f70b4
Packit 8f70b4
      if(cmp>0)
Packit 8f70b4
	 u=m;
Packit 8f70b4
      else
Packit 8f70b4
	 l=m+1;
Packit 8f70b4
   }
Packit 8f70b4
Packit 8f70b4
   // not found.
Packit 8f70b4
   // l==u points to first elementh greater than s or past end of array.
Packit 8f70b4
   strings.insert(xstrdup(s),u);
Packit 8f70b4
   return strings[u];
Packit 8f70b4
}