![]() |
OpendTect
7.0
|
String that is able to hold international (UTF-8) strings for the user interface. More...
Public Types | |
enum | AppendType { OnSameLine , OnNewLine , AfterEmptyLine } |
enum | SeparType { NoSep , CloseLine , Space , Tab , Comma , MoreInfo , SemiColon } |
Public Member Functions | |
uiString () | |
uiString (const char *)=delete | |
uiString (const char *original, const char *context, const char *package, const char *disambiguation, int pluralnr) | |
uiString (const uiString &) | |
no copy, ref counted More... | |
~uiString () | |
void | addAlternateVersion (const uiString &) |
void | addLegacyVersion (const uiString &uistr) |
uiString & | addMoreInfo (const char *) |
template<class T > | |
uiString & | addMoreInfo (const T &) |
uiString & | addMoreInfo (const uiString &, bool newline=false) |
will deliver ": the string with more info" More... | |
uiString & | addNewLine (int=1) |
uiString & | addSpace (int=1) |
uiString & | addTab (int=1) |
uiString & | append (const char *s, bool nl=false) |
uiString & | append (const OD::String &s, bool nl=false) |
uiString & | append (const uiString &s, bool nl=false) |
uiString & | appendAfterList (const uiString &) |
uiString & | appendIncorrect (const char *, char sep=' ') |
uiString & | appendIncorrect (const OD::String &, char sep=' ') |
uiString & | appendIncorrect (const uiString &, char sep=' ') |
uiString & | appendPhrase (const uiString &, SeparType septyp=uiString::CloseLine, AppendType apptyp=uiString::OnNewLine) |
uiString & | appendPhrases (const uiStringSet &, SeparType septyp=uiString::CloseLine, AppendType apptyp=uiString::OnNewLine) |
uiString & | appendPhraseSameLine (const uiString &) |
uiString & | appendPlainText (const char *, bool addspace=false, bool addquotes=false) |
uiString & | appendPlainText (const OD::String &, bool addspace=false, bool addquotes=false) |
template<class T > | |
uiString & | arg (const T &) |
uiString & | arg (const uiString &) |
uiString & | arg (double, int nrdecimals) |
uiString & | arg (float, int nrdecimals) |
uiString & | constructWordWith (const uiString &, bool addspace=false) |
wchar_t * | createWCharString () const |
returns new string: use 'delete []'. More... | |
uiString & | embed (const char *open, const char *close) |
uiString & | embedFinalState () |
void | encodeStorageString (BufferString &) const |
const QString & | fillQString (QString &) const |
translated with arguments inserted More... | |
void | fillUTF8String (BufferString &) const |
translated with arguments inserted More... | |
const OD::String & | getFullString (BufferString *=nullptr) const |
void | getHexEncoded (BufferString &) const |
const char * | getOriginalString () const |
untranslated, no argument substitution More... | |
const QString & | getQString () const |
BufferString | getString () const |
untranslated but arguments evaluated More... | |
bool | isEmpty () const |
bool | isPlainAscii () const |
bool | isSet () const |
void | makeIndependent () |
Reads hex-data and sets the translated str. More... | |
bool | operator! () const |
bool | operator!= (const uiString &oth) const |
bool | operator< (const uiString &b) const |
uiString & | operator= (const char *)=delete |
uiString & | operator= (const uiString &) |
no copy, ref counted More... | |
bool | operator== (const uiString &oth) const |
bool | operator> (const uiString &b) const |
uiString & | optional () |
uiString & | parenthesize () |
uiString & | postFixWord (const uiString &) |
uiString & | preFixWord (const uiString &) |
uiString & | quote (bool single) |
uiString & | set (const char *) |
uiString & | set (const uiString &s) |
uiString & | setArg (int, const uiString &) |
void | setEmpty () |
void | setFrom (const QString &) |
bool | setFromHexEncoded (const char *) |
int | size () const |
uiString & | toLower (bool yn=true) |
applied before arg subst. More... | |
uiString & | toTitleCase () |
uiString & | toUpper (bool yn=true) |
bool | translate (const QTranslator &, QString &) const |
Returns true if the translation succeeded. More... | |
int | useEncodedStorageString (const char *) |
returns -1 for fail, >= 0 the number of chars used More... | |
uiString & | withNumber (std::int64_t) |
uiString & | withSurvDepthUnit () |
uiString & | withSurvXYUnit () |
uiString & | withSurvZUnit () |
uiString & | withUnit (const char *) |
just the unit itself, please More... | |
uiString & | withUnit (const uiString &) |
Static Public Member Functions | |
static uiString & | dummy () |
static const uiString & | empty () |
static const uiString & | emptyString () |
static uiString | getOrderString (int) |
1st, 2nd, 3rd, ... More... | |
static const char * | sODLocalizationApplication () |
Will be deprecated (soon): More... | |
Protected Member Functions | |
bool | isEqualTo (const uiString &oth) const |
Private Member Functions | |
const QString & | getQStringInternal () const |
bool | isCacheValid () const |
operator bool () const =delete | |
operator double () const =delete | |
operator float () const =delete | |
operator int () const =delete | |
Private Attributes | |
uiStringData * | data_ |
Threads::Lock | datalock_ |
char * | debugstr_ |
Static Private Attributes | |
static uiString | dummystring_ |
static const uiString | emptystring_ |
Friends | |
class | uiStringData |
String that is able to hold international (UTF-8) strings for the user interface.
uiString is reference counted; Making a copied object is cheap.
The string will have an 'original string' of simple ASCI characters, which can be used as a 'key' but never for user display.
The string can have %1, %2, ... arguments. For these, sooner or later arguments must be provided, as in: uiString string = tr("%1 plus %2 is %3").arg( 4 ).arg( 5 ).arg( 4+5 ); ... will result in the string "4 plus 5 is 9"
As such, uiString's are suited for limited text manipulation. But if we are doing this for translated words and phrases, beware that alteration and combining is not right. Tranalations allow: Entire phrases to be concatenated Construction of lists with certain 'reasonable' separators. In no case, just glue together words and/or verbs into your own phrases.
The translation in OpendTect is done using Qt's subsystem for localization. A class that needs to use localized strings should:
Notes:
Use the pre-translated strings and phrases in uistrings.h as often as possible. Examples: uiStrings::phrCannotRead() and uiStrings::sTraceNumber().
Do not juggle with words to construct phrases. This will lead to bad translations, sometimes hilarious stuff. You can however join multiple phrases into one error message. Prefer this style:
uiString msg( tr("Rendering %1 data in background").arg(objnm) ); msg.appendPhrase( tr("When finished, the image will appear") );
Note the absence of '.' at the end of lines - these phrase terminators should be added if necessary depending on the situation. Do not put them in tr() messages. There are options for different separators when appending.
All uiStrings:sXXX() start with a capital. To get the no-caps or all-caps versions, simply use toLower() and toUpper(), as in: uiStrings::sColumn().toLower()
Units of measure are not translated. Some common units may have a translation, if they are not abbreviated. For example, 'ft' is not translated, 'Feet' is. Easy to use is uiStrings::sFeet( bool abbreviation=true );
You can add 'delimiters' and 'embedding' to words ot phrases. Try to not juggle with these yourself, make sure things are handled in a decent, standard way. For example, there is a uiString::withUnit() that adds the unit (if not empty) with parentheses. Also look at parenthesize(), embed(), optional(), ...
m3Dots: This is only for menus. For buttons, the last argument 'immediate' determines the possible 3 dots at the end of the text. m3Dots is therefore for menu items only (which actually should have been designed to use the same construction, a design error). Set the flag to false and the user will expect a new dialog to pop up rather than immediate action. So the button object will add the '...' if that is the style (but that may change).
<>
enum uiString::AppendType |
enum uiString::SeparType |
uiString::uiString | ( | ) |
uiString::uiString | ( | const uiString & | ) |
no copy, ref counted
uiString::~uiString | ( | ) |
|
delete |
uiString::uiString | ( | const char * | original, |
const char * | context, | ||
const char * | package, | ||
const char * | disambiguation, | ||
int | pluralnr | ||
) |
void uiString::addAlternateVersion | ( | const uiString & | ) |
|
inline |
|
inline |
|
inline |
will deliver ": the string with more info"
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
uiString& uiString::appendPhrase | ( | const uiString & | , |
SeparType | septyp = uiString::CloseLine , |
||
AppendType | apptyp = uiString::OnNewLine |
||
) |
uiString& uiString::appendPhrases | ( | const uiStringSet & | , |
SeparType | septyp = uiString::CloseLine , |
||
AppendType | apptyp = uiString::OnNewLine |
||
) |
uiString& uiString::appendPlainText | ( | const char * | , |
bool | addspace = false , |
||
bool | addquotes = false |
||
) |
uiString& uiString::appendPlainText | ( | const OD::String & | , |
bool | addspace = false , |
||
bool | addquotes = false |
||
) |
|
inline |
|
inline |
|
inline |
wchar_t* uiString::createWCharString | ( | ) | const |
returns new string: use 'delete []'.
|
inlinestatic |
uiString& uiString::embed | ( | const char * | open, |
const char * | close | ||
) |
uiString& uiString::embedFinalState | ( | ) |
|
inlinestatic |
|
inlinestatic |
void uiString::encodeStorageString | ( | BufferString & | ) | const |
const QString& uiString::fillQString | ( | QString & | ) | const |
translated with arguments inserted
void uiString::fillUTF8String | ( | BufferString & | ) | const |
translated with arguments inserted
const OD::String& uiString::getFullString | ( | BufferString * | = nullptr | ) | const |
void uiString::getHexEncoded | ( | BufferString & | ) | const |
Encodes translated string into a const char* buffer that can has only 0-9 A-F
|
static |
1st, 2nd, 3rd, ...
const char* uiString::getOriginalString | ( | ) | const |
untranslated, no argument substitution
const QString& uiString::getQString | ( | ) | const |
|
private |
BufferString uiString::getString | ( | ) | const |
untranslated but arguments evaluated
|
private |
bool uiString::isEmpty | ( | ) | const |
|
protected |
bool uiString::isPlainAscii | ( | ) | const |
|
inline |
void uiString::makeIndependent | ( | ) |
Reads hex-data and sets the translated str.
create a separate copy (with its own ref count)
|
privatedelete |
|
privatedelete |
|
privatedelete |
|
privatedelete |
|
inline |
|
inline |
bool uiString::operator< | ( | const uiString & | b | ) | const |
|
delete |
|
inline |
bool uiString::operator> | ( | const uiString & | b | ) | const |
uiString& uiString::optional | ( | ) |
uiString& uiString::parenthesize | ( | ) |
uiString& uiString::quote | ( | bool | single | ) |
uiString& uiString::set | ( | const char * | ) |
void uiString::setEmpty | ( | ) |
void uiString::setFrom | ( | const QString & | ) |
Set the translated text. No further translation will be done.
bool uiString::setFromHexEncoded | ( | const char * | ) |
int uiString::size | ( | ) | const |
|
inlinestatic |
Will be deprecated (soon):
uiString& uiString::toLower | ( | bool | yn = true | ) |
applied before arg subst.
uiString& uiString::toTitleCase | ( | ) |
|
inline |
bool uiString::translate | ( | const QTranslator & | , |
QString & | |||
) | const |
Returns true if the translation succeeded.
int uiString::useEncodedStorageString | ( | const char * | ) |
returns -1 for fail, >= 0 the number of chars used
|
inline |
uiString& uiString::withSurvDepthUnit | ( | ) |
uiString& uiString::withSurvXYUnit | ( | ) |
uiString& uiString::withSurvZUnit | ( | ) |
|
inline |
just the unit itself, please
|
friend |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
staticprivate |
|
staticprivate |
Generated at 02/08/2024 10:20:04 for the OpendTect seismic interpretation project. Copyright (C): dGB Beheer B.V. 1995-2024