mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-12-27 14:29:21 +00:00
68ab4023cc
These are biblatex-specific multicite commands that allow for multiple pre- and postnotes, as in: \cites(pre)(post)[pre1][post1]{key1}[pre2][post2]{key2}... with an optional general pre- and postnote, which applies to the whole list (like [][] in normal cite commands) and an optional pre- and postnotes for each item, so that pagination can actually be specified in multi-cite references, as in: (cf. Miller 2015, 2; furthermore Smith 2013, 23-23; Jenkins 2012, 103, also refer to chapter 6 in this book) See the biblatex manual, sec. 3.8.3., for details. File format change.
110 lines
2.7 KiB
C++
110 lines
2.7 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file Citation.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Herbert Voß
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef CITATION_H
|
|
#define CITATION_H
|
|
|
|
#include "support/docstring.h"
|
|
#include <map>
|
|
#include <string>
|
|
|
|
namespace lyx {
|
|
|
|
class Buffer;
|
|
|
|
|
|
enum CiteEngineType {
|
|
ENGINE_TYPE_AUTHORYEAR = 1,
|
|
ENGINE_TYPE_NUMERICAL = 2,
|
|
ENGINE_TYPE_DEFAULT = 3,
|
|
};
|
|
|
|
|
|
class CitationStyle
|
|
{
|
|
public:
|
|
///
|
|
CitationStyle() : name("cite"), cmd("cite"), forceUpperCase(false),
|
|
hasStarredVersion(false), hasQualifiedList(false),
|
|
textAfter(false), textBefore(false) {}
|
|
|
|
/// the LyX name
|
|
std::string name;
|
|
/// the LaTeX command (might differ from the LyX name)
|
|
std::string cmd;
|
|
/// Optional alternative description what the starred version does (for the GUI)
|
|
std::string stardesc;
|
|
/// Optional tooltip for the starred version
|
|
std::string startooltip;
|
|
/// upper casing author prefixes (van -> Van)
|
|
bool forceUpperCase;
|
|
/// starred version (full author list by default)
|
|
bool hasStarredVersion;
|
|
/// allows for qualified citation lists (a Biblatex feature)
|
|
bool hasQualifiedList;
|
|
/// supports text after the citation
|
|
bool textAfter;
|
|
/// supports text before the citation
|
|
bool textBefore;
|
|
};
|
|
|
|
|
|
/**
|
|
* Class for storing information about a given citation item in a given context.
|
|
* This is used in the label and menu string generation process.
|
|
*/
|
|
class CiteItem
|
|
{
|
|
public:
|
|
/// The context this citation is displayed
|
|
enum CiteContext{
|
|
Everywhere,
|
|
Dialog,
|
|
Export
|
|
};
|
|
///
|
|
CiteItem() : forceUpperCase(false), Starred(false), isQualified(false),
|
|
context(CiteItem::Everywhere), textAfter(docstring()),
|
|
textBefore(docstring()), max_size(128), max_key_size(128),
|
|
richtext(false) {}
|
|
/// requests upper casing author prefixes (van -> Van)
|
|
bool forceUpperCase;
|
|
/// is starred version (full author list by default)
|
|
bool Starred;
|
|
/// is a real qualified list
|
|
bool isQualified;
|
|
/// where this to be displayed?
|
|
CiteItem::CiteContext context;
|
|
/// text after the citation
|
|
docstring textAfter;
|
|
/// text before the citation
|
|
docstring textBefore;
|
|
/// Qualified lists's pre texts
|
|
std::map<docstring, docstring> pretexts;
|
|
///
|
|
std::map<docstring, docstring> getPretexts() const { return pretexts; }
|
|
/// Qualified lists's post texts
|
|
std::map<docstring, docstring> posttexts;
|
|
///
|
|
std::map<docstring, docstring> getPosttexts() const { return posttexts; }
|
|
/// the maximum display size as a label
|
|
size_t max_size;
|
|
/// the maximum size of the processed keys
|
|
/// (limited for performance reasons)
|
|
size_t max_key_size;
|
|
/// output richtext information?
|
|
bool richtext;
|
|
};
|
|
|
|
} // namespace lyx
|
|
|
|
#endif
|