Author: jleroux
Date: Sun Aug 20 14:18:24 2017 New Revision: 1805560 URL: http://svn.apache.org/viewvc?rev=1805560&view=rev Log: "Applied fix BY HAND from trunk framework for revision: 1805558" ------------------------------------------------------------------------ r1805558 | jleroux | 2017-08-20 16:14:26 +0200 (dim. 20 août 2017) | 11 lignes Fixed: LabelManager doesn't search labels in .groovy files (OFBIZ-8153) The logic written needs more use cases to be covered for groovy files, existing findUiLabelMapInFile is not fit for groovy files. Following patterns are currently used in groovy files: 1. uiLabelMap.xxxxx 2. uiLabelMap.get("xxxxx") Thanks: Suraj Khurana ------------------------------------------------------------------------ Modified: ofbiz/branches/release13.07/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java ofbiz/branches/release14.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java ofbiz/branches/release15.12/ (props changed) ofbiz/branches/release15.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java Modified: ofbiz/branches/release13.07/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java URL: http://svn.apache.org/viewvc/ofbiz/branches/release13.07/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java?rev=1805560&r1=1805559&r2=1805560&view=diff ============================================================================== --- ofbiz/branches/release13.07/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java (original) +++ ofbiz/branches/release13.07/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java Sun Aug 20 14:18:24 2017 @@ -211,12 +211,29 @@ public class LabelReferences { List<File> groovyFiles = FileUtil.findFiles("groovy", rootFolder + "groovyScripts", null, null); for (File file : groovyFiles) { String inFile = FileUtil.readString("UTF-8", file); - findUiLabelMapInFile(inFile, file.getPath()); + findUiLabelMapInGroovy(inFile, uiLabelMap, file.getPath()); + findUiLabelMapInGroovy(inFile, "uiLabelMap.get(\"", file.getPath()); } } } - - + protected void findUiLabelMapInGroovy(String inFile, String pattern, String filePath) { + int pos = inFile.indexOf(pattern); + while (pos >= 0) { + String label = inFile.substring(pos + pattern.length()); + String[] realLabel = label.split("\\P{Alpha}+"); + String labelKey = realLabel[0]; + int endPos = pos + labelKey.length(); + if (endPos >= 0) { + if (this.labelSet.contains(labelKey)) { + setLabelReference(labelKey, filePath); + } + pos = endPos; + } else { + pos = pos + pattern.length(); + } + pos = inFile.indexOf(pattern, pos); + } + } protected void findUiLabelMapInFile(String inFile, String filePath) { int pos = inFile.indexOf(uiLabelMap); while (pos >= 0) { Modified: ofbiz/branches/release14.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java URL: http://svn.apache.org/viewvc/ofbiz/branches/release14.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java?rev=1805560&r1=1805559&r2=1805560&view=diff ============================================================================== --- ofbiz/branches/release14.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java (original) +++ ofbiz/branches/release14.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java Sun Aug 20 14:18:24 2017 @@ -211,12 +211,29 @@ public class LabelReferences { List<File> groovyFiles = FileUtil.findFiles("groovy", rootFolder + "groovyScripts", null, null); for (File file : groovyFiles) { String inFile = FileUtil.readString("UTF-8", file); - findUiLabelMapInFile(inFile, file.getPath()); + findUiLabelMapInGroovy(inFile, uiLabelMap, file.getPath()); + findUiLabelMapInGroovy(inFile, "uiLabelMap.get(\"", file.getPath()); } } } - - + protected void findUiLabelMapInGroovy(String inFile, String pattern, String filePath) { + int pos = inFile.indexOf(pattern); + while (pos >= 0) { + String label = inFile.substring(pos + pattern.length()); + String[] realLabel = label.split("\\P{Alpha}+"); + String labelKey = realLabel[0]; + int endPos = pos + labelKey.length(); + if (endPos >= 0) { + if (this.labelSet.contains(labelKey)) { + setLabelReference(labelKey, filePath); + } + pos = endPos; + } else { + pos = pos + pattern.length(); + } + pos = inFile.indexOf(pattern, pos); + } + } protected void findUiLabelMapInFile(String inFile, String filePath) { int pos = inFile.indexOf(uiLabelMap); while (pos >= 0) { Propchange: ofbiz/branches/release15.12/ ------------------------------------------------------------------------------ --- svn:mergeinfo (original) +++ svn:mergeinfo Sun Aug 20 14:18:24 2017 @@ -9,5 +9,5 @@ /ofbiz/branches/json-integration-refactoring:1634077-1635900 /ofbiz/branches/multitenant20100310:921280-927264 /ofbiz/branches/release13.07:1547657 -/ofbiz/ofbiz-framework/trunk:1786214,1786525,1787176,1789665,1789863,1789874,1791342,1791634,1796262,1798803,1798808,1799327,1800250,1804319,1805143 +/ofbiz/ofbiz-framework/trunk:1786214,1786525,1787176,1789665,1789863,1789874,1791342,1791634,1796262,1798803,1798808,1799327,1800250,1804319,1805143,1805558 /ofbiz/trunk:1722712,1723007,1723248,1724402,1724411,1724566,1724689,1724763,1724916,1724918,1724925,1724930,1724940,1724943,1724946,1724951,1724957,1724975,1724978,1725006,1725217,1725257,1725561,1725574,1726388,1726486,1726493,1726828,1727894,1728398,1728411,1729005,1729078,1729609,1729809,1730035,1730456,1730735-1730736,1730747,1730758,1730882,1730889,1731382,1731396,1732454,1732570,1732721,1733951,1733956,1734246,1734269,1734276,1734912,1734918,1735021,1735244,1735385,1735398,1735569,1735731,1735734,1735750,1735753,1735756,1735759,1735773,1736083,1736087,1736272,1736434,1736628,1736851,1736854,1736890,1737156,1737440,1738235,1738303,1738407,1738902,1739438,1739448,1739571,1740008,1740442,1740629,1741146,1741563,1741684,1741925,1741930,1741960,1742018,1742097,1742103,1742712,1742737,1742741,1743025,1743027,1743230,1743411-1743412,1743656,1743937,1744117,1744198,1744396,1744662,1744768,1744773,1744873,1744911,1745111,1745264,1745428,1745438,1745573,1745577,1745592,1745751,1746228, 1746422,1746459,1746524,1746527,1746536,1746601,1746676,1746714,1746755,1746805,1746832,1746890,1747223,1747349,1747402,1747498,1747639,1747642,1747646,1747650,1747661,1747956,1747959,1747963,1748121,1748133,1748206,1748218,1748223,1748260,1748357,1748394,1748401,1748543,1748559,1748628,1748689,1748693,1748703,1748837,1748854,1748907,1748925,1748929,1748944,1748972,1749026,1749083,1749092,1749111,1749220,1749282,1749519,1749525,1749543,1749546,1749552,1749704,1750045,1750166,1750336,1750555,1750624,1750651,1750922,1750925,1750940,1750959,1750964,1751030,1751042,1751357,1751362,1751423,1752928,1752933,1752941,1752947,1752954,1752956,1752966,1753834,1757963,1757968,1757992,1758017,1758089,1758143,1758280,1759002,1759005,1759014,1759024,1759678,1759941,1760406,1761127,1761170,1761179,1761492,1761618,1761678,1761978,1762331,1762738,1765017,1765038,1765104,1766074,1770481,1772346,1775441,1779724,1782520 Modified: ofbiz/branches/release15.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java URL: http://svn.apache.org/viewvc/ofbiz/branches/release15.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java?rev=1805560&r1=1805559&r2=1805560&view=diff ============================================================================== --- ofbiz/branches/release15.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java (original) +++ ofbiz/branches/release15.12/framework/webtools/src/org/ofbiz/webtools/labelmanager/LabelReferences.java Sun Aug 20 14:18:24 2017 @@ -210,12 +210,29 @@ public class LabelReferences { List<File> groovyFiles = FileUtil.findFiles("groovy", rootFolder + "groovyScripts", null, null); for (File file : groovyFiles) { String inFile = FileUtil.readString("UTF-8", file); - findUiLabelMapInFile(inFile, file.getPath()); + findUiLabelMapInGroovy(inFile, uiLabelMap, file.getPath()); + findUiLabelMapInGroovy(inFile, "uiLabelMap.get(\"", file.getPath()); } } } - - + protected void findUiLabelMapInGroovy(String inFile, String pattern, String filePath) { + int pos = inFile.indexOf(pattern); + while (pos >= 0) { + String label = inFile.substring(pos + pattern.length()); + String[] realLabel = label.split("\\P{Alpha}+"); + String labelKey = realLabel[0]; + int endPos = pos + labelKey.length(); + if (endPos >= 0) { + if (this.labelSet.contains(labelKey)) { + setLabelReference(labelKey, filePath); + } + pos = endPos; + } else { + pos = pos + pattern.length(); + } + pos = inFile.indexOf(pattern, pos); + } + } protected void findUiLabelMapInFile(String inFile, String filePath) { int pos = inFile.indexOf(uiLabelMap); while (pos >= 0) { |
Free forum by Nabble | Edit this page |