Set up Qt Linguist workflow with .ts files, lupdate/lrelease integration, and translation management
Configures Qt Linguist translation workflows with .ts file management and lupdate/lrelease integration.
npx claudepluginhub a5c-ai/babysitterThis skill is limited to using the following tools:
README.mdSet up Qt Linguist translation workflow with .ts files and lrelease integration. This skill configures the complete internationalization pipeline for Qt applications.
{
"type": "object",
"properties": {
"projectPath": {
"type": "string",
"description": "Path to the Qt project"
},
"languages": {
"type": "array",
"items": { "type": "string" },
"description": "Target language codes (e.g., ['de', 'fr', 'ja'])"
},
"sourceLanguage": {
"type": "string",
"default": "en",
"description": "Source language code"
},
"translationDir": {
"type": "string",
"default": "translations"
},
"includeQml": {
"type": "boolean",
"default": true
},
"pluralForms": {
"type": "boolean",
"default": true
},
"generateCMake": {
"type": "boolean",
"default": true
}
},
"required": ["projectPath", "languages"]
}
{
"type": "object",
"properties": {
"success": { "type": "boolean" },
"files": {
"type": "array",
"items": {
"type": "object",
"properties": {
"path": { "type": "string" },
"language": { "type": "string" },
"type": { "enum": ["ts", "qm", "cmake"] }
}
}
},
"commands": {
"type": "object",
"properties": {
"extract": { "type": "string" },
"compile": { "type": "string" }
}
}
},
"required": ["success"]
}
# CMakeLists.txt
find_package(Qt6 REQUIRED COMPONENTS LinguistTools)
set(TS_FILES
translations/myapp_de.ts
translations/myapp_fr.ts
translations/myapp_ja.ts
)
# Create translation targets
qt_add_translations(myapp
TS_FILES ${TS_FILES}
QM_FILES_OUTPUT_VARIABLE QM_FILES
LUPDATE_OPTIONS -no-obsolete -locations relative
LRELEASE_OPTIONS -compress
)
# Add to resources
qt_add_resources(myapp "translations"
PREFIX "/translations"
FILES ${QM_FILES}
)
project/
├── translations/
│ ├── myapp_de.ts
│ ├── myapp_fr.ts
│ ├── myapp_ja.ts
│ └── myapp_en.ts # Reference
├── src/
│ ├── main.cpp
│ └── mainwindow.cpp
└── qml/
└── main.qml
// mainwindow.cpp
#include <QCoreApplication>
MainWindow::MainWindow() {
// Simple translation
setWindowTitle(tr("My Application"));
// With context
label->setText(QCoreApplication::translate("MainWindow", "Welcome"));
// Plural forms
QString message = tr("%n file(s) selected", "", count);
// With disambiguation
QString open1 = tr("Open", "menu item");
QString open2 = tr("Open", "window title");
// Dynamic translation
QString format = tr("Hello, %1!");
label->setText(format.arg(userName));
}
// Enable retranslation
void MainWindow::changeEvent(QEvent* event) {
if (event->type() == QEvent::LanguageChange) {
retranslateUi();
}
QMainWindow::changeEvent(event);
}
// main.qml
import QtQuick 2.15
Window {
title: qsTr("My Application")
Text {
// Simple translation
text: qsTr("Welcome to the app")
}
Text {
// Plural forms
text: qsTr("%n item(s)", "", itemCount)
}
Text {
// With context
text: qsTranslate("SettingsPage", "Language")
}
}
// main.cpp
#include <QTranslator>
#include <QLocale>
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
// Load system locale
QTranslator translator;
const QStringList uiLanguages = QLocale::system().uiLanguages();
for (const QString &locale : uiLanguages) {
const QString baseName = "myapp_" + QLocale(locale).name();
if (translator.load(":/translations/" + baseName)) {
app.installTranslator(&translator);
break;
}
}
// Or load specific language
QTranslator germanTranslator;
if (germanTranslator.load(":/translations/myapp_de")) {
app.installTranslator(&germanTranslator);
}
return app.exec();
}
class LanguageManager : public QObject {
Q_OBJECT
public:
void setLanguage(const QString& languageCode) {
// Remove old translator
if (m_translator) {
qApp->removeTranslator(m_translator);
}
// Load new translator
m_translator = new QTranslator(this);
QString path = QString(":/translations/myapp_%1").arg(languageCode);
if (m_translator->load(path)) {
qApp->installTranslator(m_translator);
emit languageChanged();
}
}
signals:
void languageChanged();
private:
QTranslator* m_translator = nullptr;
};
# Extract strings from source
lupdate src/*.cpp qml/*.qml -ts translations/myapp_de.ts
# Extract with options
lupdate -recursive -locations relative -no-obsolete \
src/ qml/ -ts translations/*.ts
# Compile translations
lrelease translations/*.ts
# Open in Qt Linguist
linguist translations/myapp_de.ts
# Check translation completeness
lconvert -if ts -i translations/myapp_de.ts -of csv -o status.csv
# Custom script to report status
for file in translations/*.ts; do
total=$(grep -c '<source>' "$file")
translated=$(grep -c 'type="finished"' "$file")
echo "$file: $translated/$total translated"
done
qt-cmake-project-generator - Project setupdesktop-i18n process - Full i18n workflowdocs-localization - Documentation localizationqt-cpp-specialist - Qt implementationlocalization-coordinator - Translation managementActivates when the user asks about AI prompts, needs prompt templates, wants to search for prompts, or mentions prompts.chat. Use for discovering, retrieving, and improving prompts.
Search, retrieve, and install Agent Skills from the prompts.chat registry using MCP tools. Use when the user asks to find skills, browse skill catalogs, install a skill for Claude, or extend Claude's capabilities with reusable AI agent components.
This skill should be used when the user asks to "create an agent", "add an agent", "write a subagent", "agent frontmatter", "when to use description", "agent examples", "agent tools", "agent colors", "autonomous agent", or needs guidance on agent structure, system prompts, triggering conditions, or agent development best practices for Claude Code plugins.