X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetCommandParams.cpp;h=e22db995959860beb69ff563c9d07e0f667cd5ae;hb=62af7ee772f16f154225d2d0b65d77f4376b6001;hp=24d1afad883008cac73637bfdf2251b5aa28b376;hpb=e43ba7cf46779c6a8394310b9487ebe2c75132b2;p=lyx.git diff --git a/src/insets/InsetCommandParams.cpp b/src/insets/InsetCommandParams.cpp index 24d1afad88..e22db99595 100644 --- a/src/insets/InsetCommandParams.cpp +++ b/src/insets/InsetCommandParams.cpp @@ -490,8 +490,42 @@ docstring InsetCommandParams::prepareCommand(OutputParams const & runparams, } else if (handling & ParamInfo::HANDLING_ESCAPE) result = escape(command); - else if (handling & ParamInfo::HANDLING_NONE) - result = command; + else if (handling & ParamInfo::HANDLING_NONE) { + // we can only output characters covered by the current + // encoding! + docstring uncodable; + for (size_type i = 0 ; i < command.size() ; ++i) { + char_type c = command[i]; + try { + if (runparams.encoding->encodable(c)) + result += c; + else if (runparams.dryrun) { + result += "<" + _("LyX Warning: ") + + _("uncodable character") + " '"; + result += docstring(1, c); + result += "'>"; + } else + uncodable += c; + } catch (EncodingException & /* e */) { + if (runparams.dryrun) { + result += "<" + _("LyX Warning: ") + + _("uncodable character") + " '"; + result += docstring(1, c); + result += "'>"; + } else + uncodable += c; + } + } + if (!uncodable.empty() && !runparams.silent) { + // issue a warning about omitted characters + // FIXME: should be passed to the error dialog + frontend::Alert::warning(_("Uncodable characters in inset"), + bformat(_("The following characters in one of the insets are\n" + "not representable in the current encoding and have been omitted: %1$s.\n" + "Unchecking 'Literal' in the respective inset dialog might help."), + uncodable)); + } + } // INDEX_ESCAPE is independent of the others if (handling & ParamInfo::HANDLING_INDEX_ESCAPE) { // Now escape special commands