def execute(self, context): global _cached_enum_addons _cached_enum_addons[:] = [] if not hasattr(self, "settings"): self.settings = settings.settings i18n_sett = context.window_manager.i18n_update_svn_settings module_name, mod = validate_module(self, context) if not (module_name and mod): return {'CANCELLED'} path = mod.__file__ if path.endswith("__init__.py"): path = os.path.dirname(path) trans = utils_i18n.I18n(kind='PY', src=path, settings=self.settings) # Now search given dir, to find po's matching given languages... # Mapping po_uid: po_file. po_files = dict(utils_i18n.get_po_files_from_dir(self.directory)) # Note: uids in i18n_sett.langs and addon's py code should be the same (both taken from the locale's languages # file). So we just try to find the best match in po's for each enabled uid. for lng in i18n_sett.langs: if lng.uid in self.settings.IMPORT_LANGUAGES_SKIP: print( "Skipping {} language ({}), edit settings if you want to enable it." .format(lng.name, lng.uid)) continue if not lng.use: print("Skipping {} language ({}).".format(lng.name, lng.uid)) continue uid = lng.uid po_uid = utils_i18n.find_best_isocode_matches(uid, po_files.keys()) if not po_uid: print("Skipping {} language, no PO file found for it ({}).". format(lng.name, uid)) continue po_uid = po_uid[0] msgs = utils_i18n.I18nMessages(uid=uid, kind='PO', key=uid, src=po_files[po_uid], settings=self.settings) if uid in trans.trans: trans.trans[uid].merge(msgs, replace=True) else: trans.trans[uid] = msgs trans.write(kind='PY') return {'FINISHED'}
def execute(self, context): global _cached_enum_addons _cached_enum_addons[:] = [] if not hasattr(self, "settings"): self.settings = settings.settings i18n_sett = context.window_manager.i18n_update_svn_settings module_name, mod = validate_module(self, context) if not (module_name and mod): return {'CANCELLED'} path = mod.__file__ if path.endswith("__init__.py"): path = os.path.dirname(path) trans = utils_i18n.I18n(kind='PY', src=path, settings=self.settings) trans.dst = self._dst uids = [self.settings.PARSER_TEMPLATE_ID ] if self.use_export_pot else [] for lng in i18n_sett.langs: if lng.uid in self.settings.IMPORT_LANGUAGES_SKIP: print( "Skipping {} language ({}), edit settings if you want to enable it." .format(lng.name, lng.uid)) continue if not lng.use: print("Skipping {} language ({}).".format(lng.name, lng.uid)) continue uid = utils_i18n.find_best_isocode_matches(lng.uid, trans.trans.keys()) if uid: uids.append(uid[0]) # Try to update existing POs instead of overwriting them, if asked to do so! if self.use_update_existing: for uid in uids: if uid == self.settings.PARSER_TEMPLATE_ID: continue path = trans.dst(trans, trans.src[uid], uid, 'PO') if not os.path.isfile(path): continue msgs = utils_i18n.I18nMessages(kind='PO', src=path, settings=self.settings) msgs.update(trans.msgs[self.settings.PARSER_TEMPLATE_ID]) trans.msgs[uid] = msgs trans.write(kind='PO', langs=set(uids)) return {'FINISHED'}
def execute(self, context): global _cached_enum_addons _cached_enum_addons[:] = [] if not hasattr(self, "settings"): self.settings = settings.settings i18n_sett = context.window_manager.i18n_update_svn_settings module_name, mod = validate_module(self, context) # Generate addon-specific messages (no need for another blender instance here, this should not have any # influence over the final result). pot = bl_extract_messages.dump_addon_messages(module_name, True, self.settings) # Now (try to) get current i18n data from the addon... path = mod.__file__ if path.endswith("__init__.py"): path = os.path.dirname(path) trans = utils_i18n.I18n(kind='PY', src=path, settings=self.settings) uids = set() for lng in i18n_sett.langs: if lng.uid in self.settings.IMPORT_LANGUAGES_SKIP: print( "Skipping {} language ({}), edit settings if you want to enable it." .format(lng.name, lng.uid)) continue if not lng.use: print("Skipping {} language ({}).".format(lng.name, lng.uid)) continue uids.add(lng.uid) # For now, add to processed uids all those not found in "official" list, minus "tech" ones. uids |= ( trans.trans.keys() - {lng.uid for lng in i18n_sett.langs} - {self.settings.PARSER_TEMPLATE_ID, self.settings.PARSER_PY_ID}) # And merge! for uid in uids: if uid not in trans.trans: trans.trans[uid] = utils_i18n.I18nMessages( uid=uid, settings=self.settings) trans.trans[uid].update(pot, keep_old_commented=False) trans.trans[self.settings.PARSER_TEMPLATE_ID] = pot # For now we write all languages found in this trans! trans.write(kind='PY') return {'FINISHED'}