Translating an external workbench/pl

W poniższych uwagach, powinien być nazwą twojego dodatku lub środowiska pracy, na przykład,  lub, lub cokolwiek innego. Ten kontekst sprawia, że wszystkie tłumaczenia twojego kodu będą zebrane pod tą samą nazwą, aby tłumacze mogli je łatwiej zidentyfikować. Oznacza to, że będą oni dokładnie wiedzieli, do którego dodatku lub środowiska pracy należy dany ciąg znaków.

Uwaga: Oto skrypt all-in-one, który automatyzuje całą procedurę opisaną poniżej (zalecamy jednak przeczytanie procedury, aby wiedzieć, co skrypt powinien zrobić): https://github.com/yorikvanhavre/BIM_Workbench/blob/master/utils/updateTranslations.py

Informacje ogólne

 * Dodaj folder . Możesz nadać mu inną nazwę, ale tak będzie łatwiej, ponieważ jest on taki sam w całym FreeCAD. W tym folderze umieścisz pliki (pliki tłumaczenia "źródła") i  (skompilowane pliki tłumaczenia).
 * Należy tłumaczyć tylko tekst, który jest wyświetlany użytkownikowi w interfejsie użytkownika programu FreeCAD. Tekst, wyświetlany w konsoli Python nie powinien być tłumaczony.
 * Tekst, który jest wyświetlany w, jest wyświetlany w oknie "Widok raportu" i dlatego powinien zostać przetłumaczony. Okno "Widok raportu" jest czymś innym niż konsola Python.

W każdym pliku .py Python

 * W każdym pliku, w którym trzeba przetłumaczyć tekst, należy zdefiniować funkcję . Możesz użyć w pełni kwalifikowanej nazwy z Qt, ale to jest trochę bardziej przejrzyste w użyciu:




 * Cały tekst, który musi zostać przetłumaczony, musi zostać przekazany przez funkcję :




 * staje się:




 * Pamiętaj, że nie jest zwykłą funkcją: służy również jako "tag" dla narzędzia do przetwarzania tekstu, więc musi mieć nazwę dokładnie "translate". Program  jest prostym procesorem tekstu, nie wykonuje Twojego kodu. Do funkcji  musisz przekazywać bezpośrednio literały łańcuchowe: nie możesz przekazywać zmiennych, stałych, itp. Na przykład:



Może to być użyte wszędzie: w, w , w oknach dialogowych Qt, itd. Funkcje nie dodają automatycznie znaku nowej linii , więc musi on być dodany na końcu, jeśli jest to pożądane. Ten znak również nie wymaga tłumaczenia, więc może znajdować się poza funkcją tłumaczącą:


 * Jeśli używasz plików wykonanych za pomocą QtDesigner, nie trzeba z nimi robić nic specjalnego.
 * Podczas tworzenia nowych obiektów, nie tłumacz "Nazwy" obiektu. Należy raczej tłumaczyć "Etykietę" obiektu. Różnica polega na tym, że "Nazwa" jest unikalna; pozostaje taka sama przez całe życie obiektu; z drugiej strony, "Etykieta" może być zmieniana przez użytkownika wedle życzenia.
 * Kiedy tworzysz właściwości dla swoich obiektów, nie tłumacz nazwy właściwości. Ale umieść opis wewnątrz :

Nie używaj swojego własnego w tym konkretnym przypadku. Zachowaj.
 * Nie tłumacz tekstu operacji na dokumentach wykonanych za pomocą




 * If you are using files made with QtDesigner, nothing special needs to be done with them.
 * When creating new objects, do not translate the object's "Name". Rather, translate the object's "Label". The difference is that a "Name" is unique; it stays the same throughout the life of the object; on the other hand, a "Label" can be changed by the user as desired.
 * When creating properties for your objects, don't translate the property name. But place the description inside :




 * Don't use your own in this specific case. Keep.


 * Do not translate the text of document transactions made with

Wewnątrz InitGui.py

 * Dodaj następującą linię, blisko początku pliku:


 * Aby przetłumaczyć nazwy menu:


 * Makro nie robi nic, ale zaznacza teksty, które później zostaną pobrane przez narzędzie . Ponieważ nie robi ono w zasadzie nic, używamy go tylko w szczególnych przypadkach, gdy FreeCAD sam się wszystkim zajmuje.
 * Dodaj ścieżkę do folderu w funkcji Initialized:

Plik nie ma atrybutu plik, więc nie jest łatwo znaleźć względną lokalizację folderu tłumaczeń. Łatwym sposobem na obejście tego problemu jest zaimportowanie innego pliku z tego samego folderu, a następnie wykonanie w tym pliku polecenia




 * To translate menu names:




 * The macro doesn't do anything, but it marks texts to be picked up by the  utility later on. Since it doesn't actually do anything, we only use it in special cases where FreeCAD itself takes care of everything.
 * Add the path to your folder in the Initialized function:




 * The file has no file attribute, so it is not easy to find the translations folder's relative location. An easy way to work around this is to make it import another file from the same folder, and in that file do:



Wewnątrz każdej klasy poleceń FreeCAD

 * Dodaj następującą linię, na początku pliku:


 * Przetłumacz i  polecenia w ten sposób:




 * Translate the and  of the command like this:



gdzie jest nazwą polecenia, zdefiniowaną przez



Zbierz wszystkie ciągi z twojego modułu

 * Będziesz potrzebował zainstalowanych w systemie narzędzi, , i . W dystrybucjach Linuksa są one zwykle dostępne w pakietach o nazwach  lub . W niektórych systemach  nazywa się  lub  lub  lub podobnie. To samo dotyczy innych narzędzi. Możesz użyć wersji Qt4 lub Qt5 według własnego uznania.
 * Jeśli masz pliki, musisz najpierw uruchomić :

To działa rekurencyjnie i znajdzie pliki wewnątrz wszystkich twoich katalogów.
 * Jeśli masz pliki, musisz również uruchomić :


 * Jeśli wykonałeś obie operacje, musisz teraz połączyć te dwa pliki w jeden:


 * Sprawdź zawartość trzech plików, aby upewnić się, że zawierają one łańcuchy znaków, a następnie możesz usunąć zarówno , jak i.
 * Możesz to wszystko zrobić w jednym skrypcie bash, tak jak poniżej:




 * This is recursive and will find files inside your whole directory structure.


 * If you have files, you need to run  too:




 * If you ran both operations, you now need to unify these two files into one:




 * Check the contents of the three files to make sure that they contain the strings, then you can delete both  and.
 * You can do it all in one bash script like this:



Przesłanie pliku .ts do platformy tłumaczeniowej
Nadszedł czas, aby zlecić tłumaczenie Twojego pliku. Możesz założyć konto na publicznej platformie tłumaczeniowej, takiej jak Crowdin lub Transifex, lub możesz skorzystać z naszego istniejącego konta FreeCAD-addons na Crowdin, które ma już wielu użytkowników, a zatem jest większa szansa, że Twój plik zostanie przetłumaczony szybko i przez ludzi, którzy znają FreeCAD.

Jeśli chcesz udostępnić swój plik na koncie FreeCAD Crowdin, skontaktuj się z użytkownikiem Yorik na forum FreeCAD.

niektóre platformy, takie jak Crowdin, mogą zintegrować się z GitHubem i wykonać wszystkie procesy z punktów 2, 3 i 4 automatycznie. W tym celu nie można korzystać z konta FreeCAD Crowdin. Będziesz musiał założyć własne konto.

Scalanie tłumaczeń
Kiedy Twój plik został przetłumaczony, choćby częściowo, możesz pobrać tłumaczenia ze strony:


 * Zazwyczaj pobierasz plik zawierający jeden plik  na każdy język.
 * Umieść wszystkie przetłumaczone pliki, razem ze swoim podstawowym plikiem , w folderze.

Kompilacja tłumaczeń
Teraz uruchom program dla każdego pliku, który posiadasz:

Możesz zautomatyzować ten proces:

Powinieneś znaleźć jeden plik dla każdego przetłumaczonego pliku. Pliki będą używane przez Qt i FreeCAD w czasie pracy.

To wszystko, czego potrzebujesz. Zauważ, że niektóre części Twojego środowiska pracy nie mogą być tłumaczone w locie, jeśli zdecydujesz się na zmianę języka. Jeśli tak jest, będziesz musiał ponownie uruchomić FreeCAD, aby nowy język został zastosowany.

Testowanie tłumaczeń

 * 1) Przełącz FreeCAD na język, który przetłumaczyłeś (np. niemiecki)
 * 2) Załaduj tłumaczenie do FreeCAD, np.
 * 3) Przetestuj coś, np.

Wynik: To powinno dać ci niemieckie tłumaczenie. Jeśli to działa dobrze, to znaczy, że podstawowa konfiguracja jest w porządku. Wtedy możemy przyjrzeć się czemuś innemu. Na przykład, nazwy poleceń powinny zawsze używać specjalnego kontekstu, który jest nazwą polecenia zarejestrowanego we FreeCAD.

Istotne uwagi

 * Upewnij się, że używasz *kontekstu* i *ciągu znaków*, które rzeczywiście znajdują się w pliku ts/qm.

Wygodniejszy skrypt
Yorik utrzymuje wygodny skrypt dla środowiska pracy BIM, który może zbierać, wysyłać i pobierać pliki ts. Możesz po prostu skopiować i dostosować ten skrypt do swojego środowiska pracy:

https://github.com/yorikvanhavre/BIM_Workbench/blob/master/utils/updateTranslations.py

Technical details and advanced usage
In the above examples there are two separate functions being used: and. You may also run across and, which automatically provide the "context" argument based on their calling location. These two pairs of functions are fundamentally different.

and accomplish two separate tasks: at runtime they perform the actual translation from the string passed into them to the final translated string. This is true whether they are provided a literal string, or a variable, or a constant: the lookup is dynamic and real-time during the run of the code. However, they provide an additional non-runtime function: they are recognized by the utility. If (and only if) they contain a string literal, that literal is extracted by the utility. ONLY string literals are extracted by -- if a variable is passed it is ignored by the  utility. Qt will attempt to provide a translation at runtime, but this will only work if some other piece of code called one of the translation functions with the literal string that needs to be translated, so that can extract it. Note that the code with the string literal need not actually ever execute, it must simply exist as a line of code in a file somewhere: performs no analysis or code execution, it is simply performing a string search and extraction.

In contrast, and  do nothing at all at runtime: they are literal "no-ops", and are completely ignored by running code. Their only use is to mark a literal string for extraction by : it never makes sense to place a variable within a call to one of these functions, it will have no effect. They are used in circumstances where or  will be called with a variable containing the text to translate. For example, any code that is used to create a Command or a Property will use a NOOP-type function around the command menu text or tooltip, or the property docstring: at runtime when FreeCAD displays these items to the user it calls : the literal strings must have been extracted by at the point of creation, for example:

In this usage, at runtime the dictionary returned by this function is literally:

There is no reference to any type of translation information. When FreeCAD actually displays this information to the user, the pseudo-code is:

In this case, cannot extract any string from the call to  because it refers to a variable. So ignores that call, but at runtime Qt searches for the string that's passed to it. As long as someplace in the code there is a call to one of the translation functions with a matching literal string (in this case, in the function), this translation call will succeed.

To verify that the expected strings are being extracted, you can manually run the command:

The file will contain the set of strings that are uploaded to CrowdIn for translation.

Ważne odnośniki

 * Dlaczego warto i jak tłumaczyć funkcje (forum thread).

Strony pokrewne

 * Zewnętrzne środowiska pracy
 * Lokalizacja - tłumaczenie interfejsu i dokumentacji
 * Aby uzyskać więcej informacji, złóż zapytanie tutaj Tłumaczenie zewnętrznych środowisk pracy.