author Asier Lostalé <>
Fri, 11 Aug 2017 16:21:42 +0200
changeset 32608 f8c3d0a4f7a4
parent 9072 79e55dfc8af0
child 32665 2148091224be
permissions -rw-r--r--
fixed bug 36755: inefficient translate task

Several improvements applied:
* A single invocation is performed instead one per file extension.
* Look for labels just once regardless number of installed translations.
* Cache all labels in memory so that a single query is performed to look for
them up instead of one per each label found in files.
* Execute all DB updates in a single transaction
* Reduced log vebosity (specially when no modules in development)
<?xml version="1.0" encoding="UTF-8" ?>
 * The contents of this file are subject to the Openbravo  Public  License
 * Version  1.1  (the  "License"),  being   the  Mozilla   Public  License
 * Version 1.1  with a permitted attribution clause; you may not  use this
 * file except in compliance with the License. You  may  obtain  a copy of
 * the License at 
 * Software distributed under the License  is  distributed  on  an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
 * License for the specific  language  governing  rights  and  limitations
 * under the License. 
 * The Original Code is Openbravo ERP. 
 * The Initial Developer of the Original Code is Openbravo SLU 
 * All portions are Copyright (C) 2001-2017 Openbravo SLU 
 * All Rights Reserved. 
 * Contributor(s):  ______________________________________.

<SqlClass name="TranslateData" package="org.openbravo.translate">
  <SqlMethod name="getTextInterfaces" type="preparedStatement" return="multiple">
      select ad_textinterfaces_id as id, isUsed as tr, text, t.ad_module_id as module, filename, m.ad_language as lang, '' as name,'' as javapackage
        from ad_textinterfaces t, ad_module m
       where t.ad_module_id = m.ad_module_id
       order by text, case when filename is not null then 0 else 1 end
  <SqlMethod name="getModulesInDevelopment" type="preparedStatement" return="multiple">
      select AD_Module_id as id, name, javapackage, AD_LANGUAGE as lang
        from AD_Module
       where isInDevelopment = 'Y'
       order by 1
  <SqlMethod name="insert" type="preparedStatement" connection="true" return="rowCount">
      insert into ad_textinterfaces
        (get_uuid(),'0' ,'0', 'Y', now(), '0', now(), '0', ?, ?, 'Y', ?)
    <Parameter name="text"/>
    <Parameter name="filename"/>
    <Parameter name="module"/>

  <SqlMethod name="update" type="preparedStatement" connection="true" return="rowCount">
      update ad_textinterfaces t
         set isUsed='Y', updated=now(), updatedBy = '0'
       where ad_textinterfaces_id = ?
    <Parameter name="adTextinterfacesId"/>

  <SqlMethod name="clean" type="preparedStatement" return="rowCount">
      update ad_textinterfaces t
         set isUsed='N', updated=now(), updatedBy = '0'
       where exists (select 1 
                       from ad_module m
                      where m.ad_module_id = t.ad_module_id
                        and m.isInDevelopment = 'Y')  
  <SqlMethod name="remove" type="preparedStatement" return="rowCount">
      delete from ad_textinterfaces t
       where isUsed='N'
         and exists (select 1 
                       from ad_module m
                      where m.ad_module_id = t.ad_module_id
                        and m.isInDevelopment = 'Y')