remove some unneeded version of functions from lstrings,

some gcc 3.2. minor compile fixes.


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@4800 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Lars Gullik Bjønnes 2002-07-28 18:13:51 +00:00
parent 4d51fc96b4
commit e39935204d
35 changed files with 236 additions and 255 deletions

View File

@ -1,3 +1,7 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* lyxinclude.m4 (LYX_PROG_CXX): remove the double -Winline
2002-07-17 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr> 2002-07-17 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
* lyxinclude.m4 (LYX_SCO): * lyxinclude.m4 (LYX_SCO):

View File

@ -211,7 +211,7 @@ if test x$GXX = xyes; then
2.96*) CXXFLAGS="$lyx_opt -fno-exceptions -Wno-non-template-friend";; 2.96*) CXXFLAGS="$lyx_opt -fno-exceptions -Wno-non-template-friend";;
3.0*) CXXFLAGS="$lyx_opt";; 3.0*) CXXFLAGS="$lyx_opt";;
3.1*) CXXFLAGS="$lyx_opt -finline-limit=500 -fno-exceptions";; 3.1*) CXXFLAGS="$lyx_opt -finline-limit=500 -fno-exceptions";;
3.2*) CXXFLAGS="$lyx_opt";; 3.2*) CXXFLAGS="$lyx_opt -fno-exceptions";;
*) CXXFLAGS="$lyx_opt";; *) CXXFLAGS="$lyx_opt";;
esac esac
if test x$enable_debug = xyes ; then if test x$enable_debug = xyes ; then
@ -222,7 +222,7 @@ if test x$GXX = xyes; then
case $gxx_version in case $gxx_version in
2.95.*) CXXFLAGS="$CXXFLAGS -W -Wall";; 2.95.*) CXXFLAGS="$CXXFLAGS -W -Wall";;
2.96*) CXXFLAGS="$CXXFLAGS -W -Wall";; 2.96*) CXXFLAGS="$CXXFLAGS -W -Wall";;
3.1*) CXXFLAGS="$CXXFLAGS -W -Wall -Winline";; 3.1*) CXXFLAGS="$CXXFLAGS -W -Wall";;
*) CXXFLAGS="$CXXFLAGS -W -Wall";; *) CXXFLAGS="$CXXFLAGS -W -Wall";;
esac esac
if test $lyx_devel_version = yes ; then if test $lyx_devel_version = yes ; then

View File

@ -8,7 +8,6 @@ src/converter.C
src/CutAndPaste.C src/CutAndPaste.C
src/debug.C src/debug.C
src/exporter.C src/exporter.C
src/ext_l10n.h
src/FloatList.C src/FloatList.C
src/frontends/controllers/biblio.C src/frontends/controllers/biblio.C
src/frontends/controllers/ButtonController.h src/frontends/controllers/ButtonController.h

View File

@ -77,6 +77,7 @@
#include "support/lyxfunctional.h" #include "support/lyxfunctional.h"
#include <boost/bind.hpp> #include <boost/bind.hpp>
#include <boost/signals/connection.hpp>
#include <cstdio> #include <cstdio>
#include <ctime> #include <ctime>

View File

@ -133,11 +133,12 @@ private:
*/ */
Box insetDimensions(LyXText const & text, LyXCursor const & cursor) const; Box insetDimensions(LyXText const & text, LyXCursor const & cursor) const;
/** /**
* check if the given co-ordinates are inside an inset at the given cursor, * check if the given co-ordinates are inside an inset at the
* if one exists. If so, the inset is returned, and the co-ordinates are * given cursor, if one exists. If so, the inset is returned,
* made relative. Otherwise, 0 is returned. * and the co-ordinates are made relative. Otherwise, 0 is returned.
*/ */
Inset * checkInset(LyXText const & text, LyXCursor const & cursor, int & x, int & y) const; Inset * checkInset(LyXText const & text, LyXCursor const & cursor,
int & x, int & y) const;
/// ///
friend class BufferView; friend class BufferView;
/// open and lock an updatable inset /// open and lock an updatable inset

View File

@ -1,3 +1,19 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* PrinterParams.h: remove extern containsOnly, and include
support/lstrings.h instead.
* LaTeX.C (scanAuxFile): modify because of strip changes
(deplog): ditto
* buffer.C (makeLaTeXFile): ditto
* bufferparams.C (writeFile): ditt
* lyxfont.C (stateText): ditto
* lyxserver.C (read_ready): ditto
* vc-backend.C (scanMaster): ditto
* BufferView_pimpl.h: ws changes
* BufferView_pimpl.C: inlude boost/signals/connection.hpp
2002-07-26 André Pönitz <poenitz@gmx.net> 2002-07-26 André Pönitz <poenitz@gmx.net>

View File

@ -430,7 +430,7 @@ void LaTeX::scanAuxFile(string const & file, Aux_Info & aux_info)
regex reg4("\\\\@input\\{([^}]+)\\}"); regex reg4("\\\\@input\\{([^}]+)\\}");
while (getline(ifs, token)) { while (getline(ifs, token)) {
token = strip(token, '\r'); token = strip(token, "\r");
smatch sub; smatch sub;
if (regex_match(token, sub, reg1)) { if (regex_match(token, sub, reg1)) {
string data = sub[1]; string data = sub[1];
@ -679,7 +679,7 @@ void LaTeX::deplog(DepTable & head)
string foundfile; string foundfile;
string token; string token;
getline(ifs, token); getline(ifs, token);
token = strip(token, '\r'); token = strip(token, "\r");
if (token.empty()) continue; if (token.empty()) continue;
smatch sub; smatch sub;

View File

@ -18,8 +18,8 @@
#include "lyxrc.h" #include "lyxrc.h"
#ifdef ENABLE_ASSERTIONS #ifdef ENABLE_ASSERTIONS
#include "support/lstrings.h"
#include "support/LAssert.h" #include "support/LAssert.h"
extern bool containsOnly(string const &, char const *);
#endif #endif

View File

@ -2338,7 +2338,7 @@ void Buffer::makeLaTeXFile(ostream & os,
string strOptions(options.str().c_str()); string strOptions(options.str().c_str());
if (!strOptions.empty()) { if (!strOptions.empty()) {
strOptions = strip(strOptions, ','); strOptions = strip(strOptions, ",");
os << '[' << strOptions << ']'; os << '[' << strOptions << ']';
} }

View File

@ -81,7 +81,7 @@ void BufferParams::writeFile(ostream & os) const
// then the the preamble // then the the preamble
if (!preamble.empty()) { if (!preamble.empty()) {
// remove '\n' from the end of preamble // remove '\n' from the end of preamble
string const tmppreamble = strip(preamble, '\n'); string const tmppreamble = strip(preamble, "\n");
os << "\\begin_preamble\n" os << "\\begin_preamble\n"
<< tmppreamble << tmppreamble
<< "\n\\end_preamble\n"; << "\n\\end_preamble\n";

View File

@ -1,3 +1,7 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* biblio.C (parseBibTeX): modify because of strip changes
2002-07-24 Juergen Spitzmueller <j.spitzmueller@gmx.de> 2002-07-24 Juergen Spitzmueller <j.spitzmueller@gmx.de>
* ControlFloat.[Ch]: Implement Wide Float toggle * ControlFloat.[Ch]: Implement Wide Float toggle

View File

@ -451,10 +451,10 @@ string const parseBibTeX(string data, string const & findkey)
// Clean-up. // Clean-up.
// 1. Spaces // 1. Spaces
data = strip(data, ' '); data = strip(data);
// 2. if there is no opening '{' then a closing '{' is probably cruft. // 2. if there is no opening '{' then a closing '{' is probably cruft.
if (!contains(data, '{')) if (!contains(data, '{'))
data = strip(data, '}'); data = strip(data, "}");
// happens, when last keyword // happens, when last keyword
string::size_type const idx = string::size_type const idx =
!data.empty() ? data.find('=') : string::npos; !data.empty() ? data.find('=') : string::npos;
@ -469,7 +469,7 @@ string const parseBibTeX(string data, string const & findkey)
return string(); return string();
} else { } else {
// delete '=' and the following spaces // delete '=' and the following spaces
data = frontStrip(frontStrip(data,'=')); data = frontStrip(frontStrip(data, "="));
if (data.length() < 2) { if (data.length() < 2) {
return data; // not long enough to find delimiters return data; // not long enough to find delimiters
} else { } else {
@ -482,7 +482,7 @@ string const parseBibTeX(string data, string const & findkey)
} else { } else {
// no {} and no "", pure data but with a // no {} and no "", pure data but with a
// possible ',' at the end // possible ',' at the end
return strip(data,','); return strip(data, ",");
} }
string tmp = data.substr(keypos); string tmp = data.substr(keypos);
while (tmp.find('{') != string::npos && while (tmp.find('{') != string::npos &&

View File

@ -679,8 +679,8 @@ ButtonPolicy::SMInput FormGraphics::input(FL_OBJECT * ob, long)
setEnabled(lyxview_->check_lyxaspectratio, 1); setEnabled(lyxview_->check_lyxaspectratio, 1);
setEnabled(lyxview_->input_lyxscale, 0); setEnabled(lyxview_->input_lyxscale, 0);
} else if (ob == lyxview_->button_latex_values) { } else if (ob == lyxview_->button_latex_values) {
if (contains(fl_get_choice_text(size_->choice_width),'%') || if (contains(fl_get_choice_text(size_->choice_width), '%') ||
contains(fl_get_choice_text(size_->choice_height),'%')) contains(fl_get_choice_text(size_->choice_height), '%'))
Alert::alert(_("Warning!"), Alert::alert(_("Warning!"),
_("The %-units are not allowed here."), _("The %-units are not allowed here."),
_("Cannot use the values from LaTeX size!")); _("Cannot use the values from LaTeX size!"));

View File

@ -1,3 +1,8 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* PreviewLoader.C (setAscentFractions): modify because of strip
changes
2002-07-22 Lars Gullik Bjønnes <larsbj@birdstep.com> 2002-07-22 Lars Gullik Bjønnes <larsbj@birdstep.com>
* GraphicsConverter.C (build_script): take a ostream as a more * GraphicsConverter.C (build_script): take a ostream as a more

View File

@ -737,7 +737,7 @@ void setAscentFractions(vector<double> & ascent_fractions,
if (!ifs.good() || if (!ifs.good() ||
page != "%%Page" || page != "%%Page" ||
!isStrUnsignedInt(strip(page_id, ':'))) { !isStrUnsignedInt(strip(page_id, ":"))) {
lyxerr[Debug::GRAPHICS] << "setAscentFractions(" lyxerr[Debug::GRAPHICS] << "setAscentFractions("
<< metrics_file << ")\n" << metrics_file << ")\n"
<< "Error reading file!" << "Error reading file!"

View File

@ -1,3 +1,9 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* insetbib.C (latex): modify because of strip changes
(getKeys): ditto
* insetnote.C (InsetNote): ditto
2002-07-26 Juergen Vigna <jug@sad.it> 2002-07-26 Juergen Vigna <jug@sad.it>
* insettabular.C (searchForward): check for lastcell if we * insettabular.C (searchForward): check for lastcell if we
@ -12,7 +18,7 @@
2002-07-25 Dekel Tsur <dekelts@tau.ac.il> 2002-07-25 Dekel Tsur <dekelts@tau.ac.il>
* insetfloat.C (read, write): Allow default placement * insetfloat.C (read, write): Allow default placement
(floatPlacement_ is empty). (floatPlacement_ is empty).
2002-07-23 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr> 2002-07-23 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>

View File

@ -152,10 +152,10 @@ int InsetBibtex::latex(Buffer const * buffer, ostream & os,
// Style-Options // Style-Options
string style = getOptions(); // maybe empty! and with bibtotoc string style = getOptions(); // maybe empty! and with bibtotoc
string bibtotoc; string bibtotoc;
if (prefixIs(style,"bibtotoc")) { if (prefixIs(style, "bibtotoc")) {
bibtotoc = "bibtotoc"; bibtotoc = "bibtotoc";
if (contains(style,',')) { if (contains(style, ',')) {
style = split(style,bibtotoc,','); style = split(style, bibtotoc, ',');
} }
} }
@ -206,7 +206,7 @@ int InsetBibtex::latex(Buffer const * buffer, ostream & os,
db_out += ','; db_out += ',';
db_in= split(db_in, adb,','); db_in= split(db_in, adb,',');
} }
db_out = strip(db_out, ','); db_out = strip(db_out, ",");
os << "\\bibliography{" << db_out << "}\n"; os << "\\bibliography{" << db_out << "}\n";
return 2; return 2;
} }
@ -264,7 +264,7 @@ vector<pair<string, string> > const InsetBibtex::getKeys(Buffer const * buffer)
&& !prefixIs(tmp, "@preamble")) { && !prefixIs(tmp, "@preamble")) {
linebuf = split(linebuf, tmp, ','); linebuf = split(linebuf, tmp, ',');
tmp = frontStrip(tmp); tmp = frontStrip(tmp);
tmp = frontStrip(tmp,'\t'); tmp = frontStrip(tmp,"\t");
if (!tmp.empty()) { if (!tmp.empty()) {
keys.push_back(pair<string,string>(tmp,string())); keys.push_back(pair<string,string>(tmp,string()));
} }

View File

@ -90,10 +90,10 @@ string const getNatbibLabel(Buffer const * buffer,
// We don't currently use the full or forceUCase fields. // We don't currently use the full or forceUCase fields.
// bool const forceUCase = citeType[0] == 'C'; // bool const forceUCase = citeType[0] == 'C';
bool const full = citeType[citeType.size()-1] == '*'; bool const full = citeType[citeType.size() - 1] == '*';
string const cite_type = full ? string const cite_type = full ?
ascii_lowercase(citeType.substr(0,citeType.size()-1)) : ascii_lowercase(citeType.substr(0, citeType.size() - 1)) :
ascii_lowercase(citeType); ascii_lowercase(citeType);
string before_str; string before_str;
@ -120,17 +120,18 @@ string const getNatbibLabel(Buffer const * buffer,
// One day, these might be tunable (as they are in BibTeX). // One day, these might be tunable (as they are in BibTeX).
char const op = '('; // opening parenthesis. char const op = '('; // opening parenthesis.
char const cp = ')'; // closing parenthesis. char const cp = ')'; // closing parenthesis.
char const sep = ';'; // puctuation mark separating citation entries. // puctuation mark separating citation entries.
char const * const sep = ";";
string const op_str(string(1, ' ') + string(1, op)); string const op_str(string(1, ' ') + string(1, op));
string const cp_str(string(1, cp) + string(1, ' ')); string const cp_str(string(1, cp) + string(1, ' '));
string const sep_str(string(1, sep) + string(1, ' ')); string const sep_str(string(sep) + " ");
string label; string label;
vector<string> keys = getVectorFromString(keyList); vector<string> keys = getVectorFromString(keyList);
vector<string>::const_iterator it = keys.begin(); vector<string>::const_iterator it = keys.begin();
vector<string>::const_iterator end = keys.end(); vector<string>::const_iterator end = keys.end();
for (; it != end; ++it) { for (; it != end; ++it) {
// get the bibdata corresponding to the key // get the bibdata corresponding to the key
string const author(biblio::getAbbreviatedAuthor(infomap, *it)); string const author(biblio::getAbbreviatedAuthor(infomap, *it));
string const year(biblio::getYear(infomap, *it)); string const year(biblio::getYear(infomap, *it));
@ -176,7 +177,7 @@ string const getNatbibLabel(Buffer const * buffer,
if (!after_str.empty()) { if (!after_str.empty()) {
if (cite_type == "citet") { if (cite_type == "citet") {
// insert "after" before last ')' // insert "after" before last ')'
label.insert(label.size()-1, after_str); label.insert(label.size() - 1, after_str);
} else { } else {
bool const add = !(numerical && bool const add = !(numerical &&
(cite_type == "citeauthor" || (cite_type == "citeauthor" ||
@ -351,13 +352,23 @@ int InsetCitation::latex(Buffer const * buffer, ostream & os,
else else
os << "cite"; os << "cite";
#warning What is this code supposed to do? (Lgb)
#if 1
// The current strange code
string const before = string(); string const before = string();
string const after = getOptions(); string const after = getOptions();
if (!before.empty() && buffer->params.use_natbib) if (!before.empty() && buffer->params.use_natbib)
os << "[" << before << "][" << after << "]"; os << "[" << before << "][" << after << "]";
else if (!after.empty()) else if (!after.empty())
os << "[" << after << "]"; os << "[" << after << "]";
#else
// and the cleaned up equvalent, should it just be changed? (Lgb)
string const after = getOptions();
if (!after.empty())
os << "[" << after << "]";
#endif
string::const_iterator it = getContents().begin(); string::const_iterator it = getContents().begin();
string::const_iterator end = getContents().end(); string::const_iterator end = getContents().end();
// Paranoia check: make sure that there is no whitespace in here // Paranoia check: make sure that there is no whitespace in here

View File

@ -77,7 +77,7 @@ InsetNote::InsetNote(Buffer const * buf, string const & contents,
font.setLanguage(default_language); font.setLanguage(default_language);
lyx::pos_type pos = 0; lyx::pos_type pos = 0;
buf->insertStringAsLines(par, pos, font, strip(contents, '\n')); buf->insertStringAsLines(par, pos, font, strip(contents, "\n"));
} }

View File

@ -571,8 +571,7 @@ string const LyXFont::stateText(BufferParams * params) const
ost << _(" Number ") << _(GUIMiscNames[number()]); ost << _(" Number ") << _(GUIMiscNames[number()]);
string buf(ost.str().c_str()); string buf(ost.str().c_str());
buf = strip(buf, ' '); buf = strip(buf, ", ");
buf = strip(buf, ',');
return buf; return buf;
} }

View File

@ -270,7 +270,7 @@ void LyXComm::read_ready()
while ((status = read(infd, charbuf, CMDBUFLEN-1))) { while ((status = read(infd, charbuf, CMDBUFLEN-1))) {
if (status > 0) { if (status > 0) {
charbuf[status]= '\0'; // turn it into a c string charbuf[status]= '\0'; // turn it into a c string
lsbuf += strip(charbuf, '\r'); lsbuf += strip(charbuf, "\r");
// commit any commands read // commit any commands read
while (lsbuf.find('\n') != string::npos) { while (lsbuf.find('\n') != string::npos) {
// split() grabs the entire string if // split() grabs the entire string if

View File

@ -1,3 +1,7 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* math_nestinset.C: add using std::vector
2002-07-23 Angus Leeming <leeming@lyx.org> 2002-07-23 Angus Leeming <leeming@lyx.org>
* formula.C (descent): add an arbitrary 12 pixels to the descent when * formula.C (descent): add an arbitrary 12 pixels to the descent when

View File

@ -102,8 +102,8 @@ InsetFormula::InsetFormula()
InsetFormula::InsetFormula(InsetFormula const & other) InsetFormula::InsetFormula(InsetFormula const & other)
: InsetFormulaBase(other), : InsetFormulaBase(other),
par_(other.par_), par_(other.par_),
preview_(new PreviewImpl(*this)) preview_(new PreviewImpl(*this))
{} {}

View File

@ -12,6 +12,8 @@
#include "graphics/PreviewLoader.h" #include "graphics/PreviewLoader.h"
#include "graphics/Previews.h" #include "graphics/Previews.h"
using std::vector;
MathNestInset::MathNestInset(idx_type nargs) MathNestInset::MathNestInset(idx_type nargs)
: MathDimInset(), cells_(nargs), lock_(false) : MathDimInset(), cells_(nargs), lock_(false)

View File

@ -1,3 +1,17 @@
2002-07-28 Lars Gullik Bjønnes <larsbj@gullik.net>
* filetools.C (GetEnvPath): modify because of strip changes
(createDirectory): ditto
(findtexfile): ditto
* lstrings.[Ch] (isStrInt): ditto
(isStrUnsignedInt): ditto
(strToInt): ditto
(strToUnsignedInt): ditto
(isStrDbl): ditto
(contains): removed unneeded version of contains
(containsOnly): removed uneeded versions of containsOnly
(strip, frontStrip): removed unneded versions, changed argument types.
2002-07-22 Dekel Tsur <dekelts@tau.ac.il> 2002-07-22 Dekel Tsur <dekelts@tau.ac.il>
* filetools.C (RunCommand): Made public * filetools.C (RunCommand): Made public

View File

@ -364,7 +364,7 @@ string const GetEnvPath(string const & name)
#else #else
string const pathlist = os::slashify_path(GetEnv(name)); string const pathlist = os::slashify_path(GetEnv(name));
#endif #endif
return strip(pathlist, ';'); return strip(pathlist, ";");
} }
@ -564,7 +564,7 @@ int DestroyLyXTmpDir(string const & tmpdir)
// Creates directory. Returns true if succesfull // Creates directory. Returns true if succesfull
bool createDirectory(string const & path, int permission) bool createDirectory(string const & path, int permission)
{ {
string temp(strip(os::slashify_path(path), '/')); string temp(strip(os::slashify_path(path), "/"));
if (temp.empty()) { if (temp.empty()) {
Alert::alert(_("Internal error!"), Alert::alert(_("Internal error!"),
@ -1352,10 +1352,10 @@ string const findtexfile(string const & fil, string const & /*format*/)
cmd_ret const c = RunCommand(kpsecmd); cmd_ret const c = RunCommand(kpsecmd);
lyxerr[Debug::LATEX] << "kpse status = " << c.first << "\n" lyxerr[Debug::LATEX] << "kpse status = " << c.first << "\n"
<< "kpse result = `" << strip(c.second, '\n') << "kpse result = `" << strip(c.second, "\n")
<< "'" << endl; << "'" << endl;
if (c.first != -1) if (c.first != -1)
return os::internal_path(strip(strip(c.second, '\n'), '\r')); return os::internal_path(strip(strip(c.second, "\n"), "\r"));
else else
return string(); return string();
} }

View File

@ -120,7 +120,7 @@ bool isStrInt(string const & str)
if (str.empty()) return false; if (str.empty()) return false;
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
if (tmpstr.empty()) return false; if (tmpstr.empty()) return false;
string::const_iterator cit = tmpstr.begin(); string::const_iterator cit = tmpstr.begin();
@ -138,7 +138,7 @@ bool isStrUnsignedInt(string const & str)
if (str.empty()) return false; if (str.empty()) return false;
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
if (tmpstr.empty()) return false; if (tmpstr.empty()) return false;
string::const_iterator cit = tmpstr.begin(); string::const_iterator cit = tmpstr.begin();
@ -154,7 +154,7 @@ int strToInt(string const & str)
{ {
if (isStrInt(str)) { if (isStrInt(str)) {
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
// Do the conversion proper. // Do the conversion proper.
return lyx::atoi(tmpstr); return lyx::atoi(tmpstr);
} else { } else {
@ -167,7 +167,7 @@ unsigned int strToUnsignedInt(string const & str)
{ {
if (isStrUnsignedInt(str)) { if (isStrUnsignedInt(str)) {
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
// Do the conversion proper. // Do the conversion proper.
return lyx::atoi(tmpstr); return lyx::atoi(tmpstr);
} else { } else {
@ -181,7 +181,7 @@ bool isStrDbl(string const & str)
if (str.empty()) return false; if (str.empty()) return false;
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
if (tmpstr.empty()) return false; if (tmpstr.empty()) return false;
// if (1 < tmpstr.count('.')) return false; // if (1 < tmpstr.count('.')) return false;
@ -210,7 +210,7 @@ double strToDbl(string const & str)
{ {
if (isStrDbl(str)) { if (isStrDbl(str)) {
// Remove leading and trailing white space chars. // Remove leading and trailing white space chars.
string const tmpstr = frontStrip(strip(str, ' '), ' '); string const tmpstr = frontStrip(strip(str));
// Do the conversion proper. // Do the conversion proper.
return ::atof(tmpstr.c_str()); return ::atof(tmpstr.c_str());
} else { } else {
@ -371,22 +371,6 @@ bool suffixIs(string const & a, string const & suf)
} }
bool contains(char const * a, string const & b)
{
lyx::Assert(a);
string const at(a);
return contains(at, b);
}
bool contains(string const & a, char const * b)
{
lyx::Assert(b);
string const bt(b);
return contains(a, bt);
}
bool contains(string const & a, string const & b) bool contains(string const & a, string const & b)
{ {
if (a.empty()) if (a.empty())
@ -403,45 +387,12 @@ bool contains(string const & a, char b)
} }
bool contains(char const * a, char const * b)
{
lyx::Assert(a && b);
string const at(a);
string const bt(b);
return contains(at, bt);
}
bool containsOnly(string const & s, char const * cset)
{
lyx::Assert(cset);
return s.find_first_not_of(cset) == string::npos;
}
bool containsOnly(string const & s, string const & cset) bool containsOnly(string const & s, string const & cset)
{ {
return s.find_first_not_of(cset) == string::npos; return s.find_first_not_of(cset) == string::npos;
} }
bool containsOnly(char const * s, char const * cset)
{
lyx::Assert(s && cset);
return string(s).find_first_not_of(cset) == string::npos;
}
bool containsOnly(char const * s, string const & cset)
{
lyx::Assert(s);
return string(s).find_first_not_of(cset) == string::npos;
}
// ale970405+lasgoutt-970425 // ale970405+lasgoutt-970425
// rewritten to use new string (Lgb) // rewritten to use new string (Lgb)
string const token(string const & a, char delim, int n) string const token(string const & a, char delim, int n)
@ -543,23 +494,26 @@ string const subst(string const & a,
} }
string const strip(string const & a, char c) string const strip(string const & a, char const * p)
{ {
if (a.empty()) return a; lyx::Assert(p);
if (a.empty() || !*p) return a;
string tmp(a); string tmp(a);
string::size_type i = tmp.find_last_not_of(c); string::size_type i = tmp.find_last_not_of(p);
if (i == a.length() - 1) return tmp; // no c's at end of a if (i == a.length() - 1) return tmp; // no c's at end of a
if (i != string::npos) if (i != string::npos)
tmp.erase(i + 1, string::npos); tmp.erase(i + 1, string::npos);
#if !defined(USE_INCLUDED_STRING) && !defined(STD_STRING_IS_GOOD) #if !defined(USE_INCLUDED_STRING) && !defined(STD_STRING_IS_GOOD)
// Ok This code is now suspect... (Lgb)
/// Needed for broken string::find_last_not_of /// Needed for broken string::find_last_not_of
else if (tmp[0] != c) { else if (tmp[0] != p[0]) {
if (a.length() == 1) return tmp; if (a.length() == 1) return tmp;
tmp.erase(1, string::npos); tmp.erase(1, string::npos);
} }
#endif #endif
else else
tmp.erase(); // only c in the whole string tmp.erase(); // only chars from p in the whole string
return tmp; return tmp;
} }
@ -577,17 +531,6 @@ string const frontStrip(string const & a, char const * p)
} }
string const frontStrip(string const & a, char c)
{
if (a.empty()) return a;
string tmp(a);
string::size_type i = tmp.find_first_not_of(c);
if (i > 0)
tmp.erase(0, i);
return tmp;
}
string const split(string const & a, string & piece, char delim) string const split(string const & a, string & piece, char delim)
{ {
string tmp; string tmp;

View File

@ -16,9 +16,6 @@
#pragma interface #pragma interface
#endif #endif
//#include <cstring>
//#include <cctype>
//#include <cctype>
#include <vector> #include <vector>
#include "Lsstream.h" #include "Lsstream.h"
@ -134,21 +131,12 @@ bool suffixIs(string const &, char const *);
/// Does the string end with this suffix? /// Does the string end with this suffix?
bool suffixIs(string const &, string const &); bool suffixIs(string const &, string const &);
///
bool contains(char const * a, string const & b);
///
bool contains(string const & a, char const * b);
/// ///
bool contains(string const & a, string const & b); bool contains(string const & a, string const & b);
/// ///
bool contains(string const & a, char b); bool contains(string const & a, char b);
///
bool contains(char const * a, char const * b);
/// This should probably we rewritten to be more general. /// This should probably we rewritten to be more general.
class contains_functor { class contains_functor {
public: public:
@ -162,18 +150,9 @@ public:
}; };
///
bool containsOnly(string const &, char const *);
/// ///
bool containsOnly(string const &, string const &); bool containsOnly(string const &, string const &);
///
bool containsOnly(char const *, char const *);
///
bool containsOnly(char const *, string const &);
/** Extracts a token from this string at the nth delim. /** Extracts a token from this string at the nth delim.
Doesn't modify the original string. Similar to strtok. Doesn't modify the original string. Similar to strtok.
Example: Example:
@ -215,24 +194,17 @@ string const subst(string const & a,
/** Strips characters off the end of a string. /** Strips characters off the end of a string.
\code \code
"abccc".strip('c') = "ab". strip("abccc", "c") == "ab".
\endcode \endcode
*/ */
string const strip(string const & a, char c = ' '); string const strip(string const & a, char const * p = " ");
/** Strips characters of the beginning of a string.
\code
"cccba".frontstrip('c') = "ba"
\endcode
*/
string const frontStrip(string const & a, char c = ' ');
/** Strips characters off the beginning of a string. /** Strips characters off the beginning of a string.
\code \code
"ababcdef".frontstrip("ab") = "cdef" frontstrip("ababcdef", "ab") = "cdef"
\endcode \endcode
*/ */
string const frontStrip(string const & a, char const * p); string const frontStrip(string const & a, char const * p = " ");
/** Splits the string by the first delim. /** Splits the string by the first delim.
Splits the string by the first appearance of delim. Splits the string by the first appearance of delim.

View File

@ -107,7 +107,7 @@ void RCS::scanMaster()
// get version here // get version here
string tmv; string tmv;
ifs >> tmv; ifs >> tmv;
tmv = strip(tmv, ';'); tmv = strip(tmv, ";");
version_ = tmv; version_ = tmv;
lyxerr[Debug::LYXVC] << "LyXVC: version found to be " lyxerr[Debug::LYXVC] << "LyXVC: version found to be "
<< tmv << endl; << tmv << endl;
@ -127,7 +127,7 @@ void RCS::scanMaster()
string s2; string s2;
do { do {
ifs >> tmpt; ifs >> tmpt;
s1 = strip(tmpt, ';'); s1 = strip(tmpt, ";");
// tmp is now in the format <user>:<version> // tmp is now in the format <user>:<version>
s1 = split(s1, s2, ':'); s1 = split(s1, s2, ':');
// s2 is user, and s1 is version // s2 is user, and s1 is version
@ -265,7 +265,7 @@ void CVS::scanMaster()
FileInfo fi(file_); FileInfo fi(file_);
// FIXME: must double check file is stattable/existing // FIXME: must double check file is stattable/existing
time_t mod = fi.getModificationTime(); time_t mod = fi.getModificationTime();
string mod_date = strip(asctime(gmtime(&mod)), '\n'); string mod_date = strip(asctime(gmtime(&mod)), "\n");
lyxerr[Debug::LYXVC] lyxerr[Debug::LYXVC]
<< "Date in Entries: `" << file_date << "Date in Entries: `" << file_date
<< "'\nModification date of file: `" << "'\nModification date of file: `"