Revert r35106.

Help needed here. Why isn't this equivalent?


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35108 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Richard Heck 2010-08-09 19:17:44 +00:00
parent 9d09dca920
commit 350b82fd62
8 changed files with 12 additions and 18 deletions

View File

@ -1801,7 +1801,7 @@ void Buffer::checkBibInfoCache() const
if (!d->bibinfo_cache_valid_) {
d->bibinfo_.clear();
for (InsetIterator it = inset_iterator_begin(inset()); it; ++it)
it->fillWithBibKeys(d->bibinfo_);
it->fillWithBibKeys(d->bibinfo_, it);
d->bibinfo_cache_valid_ = true;
}
}

View File

@ -478,7 +478,7 @@ public:
/// pit is the ParConstIterator of the paragraph containing the inset
virtual void addToToc(DocIterator const &) {}
/// Fill keys with BibTeX information
virtual void fillWithBibKeys(BiblioInfo &) const {}
virtual void fillWithBibKeys(BiblioInfo &, InsetIterator const &) const {}
/// Update the counters of this inset and of its contents.
/// The boolean indicates whether we are preparing for output, e.g.,
/// of XHTML.

View File

@ -258,17 +258,11 @@ docstring bibitemWidest(Buffer const & buffer, OutputParams const & runparams)
}
void InsetBibitem::fillWithBibKeys(BiblioInfo & keys) const
void InsetBibitem::fillWithBibKeys(BiblioInfo & keys, InsetIterator const & it) const
{
docstring const key = getParam("key");
// false means it's not BibTeX
BibTeXInfo keyvalmap(false);
keyvalmap.label(bibLabel());
// The indirection here is a little annoying, but
// DocIterator(Buffer *, Inset *)
// is private.
InsetBibitem & me = const_cast<InsetBibitem &>(*this);
InsetIterator it(me);
DocIterator doc_it(it);
doc_it.forwardPos();
keyvalmap[from_ascii("ref")] = doc_it.paragraph().asString();

View File

@ -63,7 +63,7 @@ private:
///
docstring xhtml(XHTMLStream &, OutputParams const &) const;
///
virtual void fillWithBibKeys(BiblioInfo &) const;
virtual void fillWithBibKeys(BiblioInfo &, InsetIterator const &) const;
/// Update the counter of this inset
void updateBuffer(ParIterator const &, UpdateType);
///

View File

@ -662,7 +662,8 @@ namespace {
// This method returns a comma separated list of Bibtex entries
void InsetBibtex::fillWithBibKeys(BiblioInfo & keylist) const
void InsetBibtex::fillWithBibKeys(BiblioInfo & keylist,
InsetIterator const & /*di*/) const
{
// This bibtex parser is a first step to parse bibtex files
// more precisely.

View File

@ -42,7 +42,7 @@ public:
///
int latex(odocstream &, OutputParams const &) const;
///
void fillWithBibKeys(BiblioInfo &) const;
void fillWithBibKeys(BiblioInfo &, InsetIterator const &) const;
///
support::FileNameList getBibFiles() const;
///

View File

@ -830,13 +830,12 @@ void InsetInclude::validate(LaTeXFeatures & features) const
}
void InsetInclude::fillWithBibKeys(BiblioInfo & keys) const
void InsetInclude::fillWithBibKeys(BiblioInfo & keys,
InsetIterator const & /*di*/) const
{
if (loadIfNeeded()) {
string const included_file =
includedFileName(buffer(), params()).absFileName();
Buffer * tmp =
theBufferList().getBuffer(FileName(included_file));
string const included_file = includedFileName(buffer(), params()).absFileName();
Buffer * tmp = theBufferList().getBuffer(FileName(included_file));
BiblioInfo const & newkeys = tmp->localBibInfo();
keys.mergeBiblioInfo(newkeys);
}

View File

@ -59,7 +59,7 @@ public:
* \param keys the list of bibkeys in the child buffer.
* \param it not used here
*/
void fillWithBibKeys(BiblioInfo & keys) const;
void fillWithBibKeys(BiblioInfo & keys, InsetIterator const & it) const;
///
bool hasSettings() const { return true; }