Produced by Araxis Merge on 11/20/2017 2:15:51 PM GMT Standard Time. See www.araxis.com for information about Merge. This report uses XHTML and CSS2, and is best viewed with a modern standards-compliant browser. For optimum results when printing this report, use landscape orientation and enable printing of background images and colours in your browser.
| # | Location | File | Last Modified |
|---|---|---|---|
| 1 | Mon Nov 20 14:15:51 2017 UTC | ||
| 2 | C:\Merge Test Files\8.5.23\java\org\apache\catalina\authenticator\jaspic | PersistentProviderRegistrations.java | Thu Sep 28 11:32:16 2017 UTC |
| 3 | C:\Merge Test Files\9.0.1\java\org\apache\catalina\authenticator\jaspic | PersistentProviderRegistrations.java | Wed Sep 27 18:33:40 2017 UTC |
| Note: Merge considers the second file to be the common ancestor of the others. | |||
| Description | Between Files 1 and 2 |
Between Files 2 and 3 |
Relative to Common Ancestor |
|||
|---|---|---|---|---|---|---|
| Text Blocks | Lines | Text Blocks | Lines | Text Blocks | Lines | |
| Unchanged | 0 | 0 | 2 | 512 | ||
| Changed | 0 | 0 | 1 | 5 | 0 | 0 |
| Inserted | 1 | 257 | 0 | 0 | 0 | 0 |
| Removed | 0 | 0 | 0 | 0 | 0 | 0 |
| Note: An automatic merge would leave 1 conflict(s). | ||||||
| Whitespace | Consecutive whitespace is treated as a single space |
|---|---|
| Character case | Differences in character case are significant |
| Line endings | Differences in line endings (CR and LF characters) are ignored |
| CR/LF characters | Not shown in the comparison detail |
No regular expressions were active.
| 1 | /** | 1 | /** | |||||||
| 2 | * Licens ed to the Apache Sof tware Foun dation (AS F) under o ne or more | 2 | * Licens ed to the Apache Sof tware Foun dation (AS F) under o ne or more | |||||||
| 3 | * contri butor lice nse agreem ents. See the NOTIC E file dis tributed w ith | 3 | * contri butor lice nse agreem ents. See the NOTIC E file dis tributed w ith | |||||||
| 4 | * this w ork for ad ditional i nformation regarding copyright ownership . | 4 | * this w ork for ad ditional i nformation regarding copyright ownership . | |||||||
| 5 | * The AS F licenses this file to You un der the Ap ache Licen se, Versio n 2.0 | 5 | * The AS F licenses this file to You un der the Ap ache Licen se, Versio n 2.0 | |||||||
| 6 | * (the " License"); you may n ot use thi s file exc ept in com pliance wi th | 6 | * (the " License"); you may n ot use thi s file exc ept in com pliance wi th | |||||||
| 7 | * the Li cense. Yo u may obta in a copy of the Lic ense at | 7 | * the Li cense. Yo u may obta in a copy of the Lic ense at | |||||||
| 8 | * | 8 | * | |||||||
| 9 | * htt p://www.ap ache.org/l icenses/LI CENSE-2.0 | 9 | * htt p://www.ap ache.org/l icenses/LI CENSE-2.0 | |||||||
| 10 | * | 10 | * | |||||||
| 11 | * Unless required by applica ble law or agreed to in writin g, softwar e | 11 | * Unless required by applica ble law or agreed to in writin g, softwar e | |||||||
| 12 | * distri buted unde r the Lice nse is dis tributed o n an "AS I S" BASIS, | 12 | * distri buted unde r the Lice nse is dis tributed o n an "AS I S" BASIS, | |||||||
| 13 | * WITHOU T WARRANTI ES OR COND ITIONS OF ANY KIND, either exp ress or im plied. | 13 | * WITHOU T WARRANTI ES OR COND ITIONS OF ANY KIND, either exp ress or im plied. | |||||||
| 14 | * See th e License for the sp ecific lan guage gove rning perm issions an d | 14 | * See th e License for the sp ecific lan guage gove rning perm issions an d | |||||||
| 15 | * limita tions unde r the Lice nse. | 15 | * limita tions unde r the Lice nse. | |||||||
| 16 | */ | 16 | */ | |||||||
| 17 | package or g.apache.c atalina.au thenticato r.jaspic; | 17 | package or g.apache.c atalina.au thenticato r.jaspic; | |||||||
| 18 | 18 | |||||||||
| 19 | import jav a.io.File; | 19 | import jav a.io.File; | |||||||
| 20 | import jav a.io.FileI nputStream ; | 20 | import jav a.io.FileI nputStream ; | |||||||
| 21 | import jav a.io.FileO utputStrea m; | 21 | import jav a.io.FileO utputStrea m; | |||||||
| 22 | import jav a.io.IOExc eption; | 22 | import jav a.io.IOExc eption; | |||||||
| 23 | import jav a.io.Input Stream; | 23 | import jav a.io.Input Stream; | |||||||
| 24 | import jav a.io.Outpu tStream; | 24 | import jav a.io.Outpu tStream; | |||||||
| 25 | import jav a.io.Outpu tStreamWri ter; | 25 | import jav a.io.Outpu tStreamWri ter; | |||||||
| 26 | import jav a.io.Write r; | 26 | import jav a.io.Write r; | |||||||
| 27 | import jav a.nio.char set.Standa rdCharsets ; | 27 | import jav a.nio.char set.Standa rdCharsets ; | |||||||
| 28 | import jav a.util.Arr ayList; | 28 | import jav a.util.Arr ayList; | |||||||
| 29 | import jav a.util.Has hMap; | 29 | import jav a.util.Has hMap; | |||||||
| 30 | import jav a.util.Lis t; | 30 | import jav a.util.Lis t; | |||||||
| 31 | import jav a.util.Map ; | 31 | import jav a.util.Map ; | |||||||
| 32 | import jav a.util.Map .Entry; | 32 | import jav a.util.Map .Entry; | |||||||
| 33 | 33 | |||||||||
| 34 | import org .apache.ju li.logging .Log; | 34 | import org .apache.ju li.logging .Log; | |||||||
| 35 | import org .apache.ju li.logging .LogFactor y; | 35 | import org .apache.ju li.logging .LogFactor y; | |||||||
| 36 | import org .apache.to mcat.util. digester.D igester; | 36 | import org .apache.to mcat.util. digester.D igester; | |||||||
| 37 | import org .apache.to mcat.util. res.String Manager; | 37 | import org .apache.to mcat.util. res.String Manager; | |||||||
| 38 | import org .xml.sax.S AXExceptio n; | 38 | import org .xml.sax.S AXExceptio n; | |||||||
| 39 | 39 | |||||||||
| 40 | /** | 40 | /** | |||||||
| 41 | * Utility class for the loadi ng and sav ing of JAS PIC persis tent provi der | 41 | * Utility class for the loadi ng and sav ing of JAS PIC persis tent provi der | |||||||
| 42 | * registr ations. | 42 | * registr ations. | |||||||
| 43 | */ | 43 | */ | |||||||
| 44 | final clas s Persiste ntProvider Registrati ons { | 44 | final clas s Persiste ntProvider Registrati ons { | |||||||
| 45 | 45 | |||||||||
| 46 | privat e static f inal Log l og = LogFa ctory.getL og(Persist entProvide rRegistrat ions.class ); | 46 | privat e static f inal Log l og = LogFa ctory.getL og(Persist entProvide rRegistrat ions.class ); | |||||||
| 47 | privat e static f inal Strin gManager s m = | 47 | privat e static f inal Strin gManager s m = | |||||||
| 48 | StringMa nager.getM anager(Per sistentPro viderRegis trations.c lass); | 48 | StringMa nager.getM anager(Per sistentPro viderRegis trations.c lass); | |||||||
| 49 | 49 | |||||||||
| 50 | 50 | |||||||||
| 51 | privat e Persiste ntProvider Registrati ons() { | 51 | privat e Persiste ntProvider Registrati ons() { | |||||||
| 52 | // Utility c lass. Hide default c onstructor | 52 | // Utility c lass. Hide default c onstructor | |||||||
| 53 | } | 53 | } | |||||||
| 54 | 54 | |||||||||
| 55 | 55 | |||||||||
| 56 | static Providers loadProvi ders(File configFile ) { | 56 | static Providers loadProvi ders(File configFile ) { | |||||||
| 57 | tr y (InputSt ream is = new FileIn putStream( configFile )) { | 57 | tr y (InputSt ream is = new FileIn putStream( configFile )) { | |||||||
| 58 | // Const ruct a dig ester to r ead the XM L input fi le | 58 | // Const ruct a dig ester to r ead the XM L input fi le | |||||||
| 59 | Digester digester = new Dige ster(); | 59 | Digester digester = new Dige ster(); | |||||||
| 60 | 60 | |||||||||
| 61 | try { | 61 | try { | |||||||
| 62 | dige ster.setFe ature("htt p://apache .org/xml/f eatures/al low-java-e ncodings", true); | 62 | dige ster.setFe ature("htt p://apache .org/xml/f eatures/al low-java-e ncodings", true); | |||||||
| 63 | dige ster.setVa lidating(t rue); | 63 | dige ster.setVa lidating(t rue); | |||||||
| 64 | dige ster.setNa mespaceAwa re(true); | 64 | dige ster.setNa mespaceAwa re(true); | |||||||
| 65 | } catch (Exception e) { | 65 | } catch (Exception e) { | |||||||
| 66 | thro w new Secu rityExcept ion(e); | 66 | thro w new Secu rityExcept ion(e); | |||||||
| 67 | } | 67 | } | |||||||
| 68 | 68 | |||||||||
| 69 | // Creat e an objec t to hold the parse results an d put it o n the top | 69 | // Creat e an objec t to hold the parse results an d put it o n the top | |||||||
| 70 | // of th e digester 's stack | 70 | // of th e digester 's stack | |||||||
| 71 | Provider s result = new Provi ders(); | 71 | Provider s result = new Provi ders(); | |||||||
| 72 | digester .push(resu lt); | 72 | digester .push(resu lt); | |||||||
| 73 | 73 | |||||||||
| 74 | // Confi gure the d igester | 74 | // Confi gure the d igester | |||||||
| 75 | digester .addObject Create("ja spic-provi ders/provi der", Prov ider.class .getName() ); | 75 | digester .addObject Create("ja spic-provi ders/provi der", Prov ider.class .getName() ); | |||||||
| 76 | digester .addSetPro perties("j aspic-prov iders/prov ider"); | 76 | digester .addSetPro perties("j aspic-prov iders/prov ider"); | |||||||
| 77 | digester .addSetNex t("jaspic- providers/ provider", "addProvi der", Prov ider.class .getName() ); | 77 | digester .addSetNex t("jaspic- providers/ provider", "addProvi der", Prov ider.class .getName() ); | |||||||
| 78 | 78 | |||||||||
| 79 | digester .addObject Create("ja spic-provi ders/provi der/proper ty", Prope rty.class. getName()) ; | 79 | digester .addObject Create("ja spic-provi ders/provi der/proper ty", Prope rty.class. getName()) ; | |||||||
| 80 | digester .addSetPro perties("j aspic-prov iders/prov ider/prope rty"); | 80 | digester .addSetPro perties("j aspic-prov iders/prov ider/prope rty"); | |||||||
| 81 | digester .addSetNex t("jaspic- providers/ provider/p roperty", "addProper ty", Prope rty.class. getName()) ; | 81 | digester .addSetNex t("jaspic- providers/ provider/p roperty", "addProper ty", Prope rty.class. getName()) ; | |||||||
| 82 | 82 | |||||||||
| 83 | // Parse the input | 83 | // Parse the input | |||||||
| 84 | digester .parse(is) ; | 84 | digester .parse(is) ; | |||||||
| 85 | 85 | |||||||||
| 86 | return r esult; | 86 | return r esult; | |||||||
| 87 | } catch (IOE xception | SAXExcept ion e) { | 87 | } catch (IOE xception | SAXExcept ion e) { | |||||||
| 88 | throw ne w Security Exception( e); | 88 | throw ne w Security Exception( e); | |||||||
| 89 | } | 89 | } | |||||||
| 90 | } | 90 | } | |||||||
| 91 | 91 | |||||||||
| 92 | 92 | |||||||||
| 93 | static void writ eProviders (Providers providers , File con figFile) { | 93 | static void writ eProviders (Providers providers , File con figFile) { | |||||||
| 94 | Fi le configF ileOld = n ew File(co nfigFile.g etAbsolute Path() + " .old"); | 94 | Fi le configF ileOld = n ew File(co nfigFile.g etAbsolute Path() + " .old"); | |||||||
| 95 | Fi le configF ileNew = n ew File(co nfigFile.g etAbsolute Path() + " .new"); | 95 | Fi le configF ileNew = n ew File(co nfigFile.g etAbsolute Path() + " .new"); | |||||||
| 96 | 96 | |||||||||
| 97 | // Remove le ft over te mporary fi les if pre sent | 97 | // Remove le ft over te mporary fi les if pre sent | |||||||
| 98 | if (configFi leOld.exis ts()) { | 98 | if (configFi leOld.exis ts()) { | |||||||
| 99 | if (conf igFileOld. delete()) { | 99 | if (conf igFileOld. delete()) { | |||||||
| 100 | thro w new Secu rityExcept ion(sm.get String( | 100 | thro w new Secu rityExcept ion(sm.get String( | |||||||
| 101 | "persi stentProvi derRegistr ations.exi stsDeleteF ail", | 101 | "persi stentProvi derRegistr ations.exi stsDeleteF ail", | |||||||
| 102 | config FileOld.ge tAbsoluteP ath())); | 102 | config FileOld.ge tAbsoluteP ath())); | |||||||
| 103 | } | 103 | } | |||||||
| 104 | } | 104 | } | |||||||
| 105 | if (configFi leNew.exis ts()) { | 105 | if (configFi leNew.exis ts()) { | |||||||
| 106 | if (conf igFileNew. delete()) { | 106 | if (conf igFileNew. delete()) { | |||||||
| 107 | thro w new Secu rityExcept ion(sm.get String( | 107 | thro w new Secu rityExcept ion(sm.get String( | |||||||
| 108 | "persi stentProvi derRegistr ations.exi stsDeleteF ail", | 108 | "persi stentProvi derRegistr ations.exi stsDeleteF ail", | |||||||
| 109 | config FileNew.ge tAbsoluteP ath())); | 109 | config FileNew.ge tAbsoluteP ath())); | |||||||
| 110 | } | 110 | } | |||||||
| 111 | } | 111 | } | |||||||
| 112 | 112 | |||||||||
| 113 | // Write out the provi ders to th e temporar y new file | 113 | // Write out the provi ders to th e temporar y new file | |||||||
| 114 | tr y (OutputS tream fos = new File OutputStre am(configF ileNew); | 114 | tr y (OutputS tream fos = new File OutputStre am(configF ileNew); | |||||||
| 115 | Writ er writer = new Outp utStreamWr iter(fos, StandardCh arsets.UTF _8)) { | 115 | Writ er writer = new Outp utStreamWr iter(fos, StandardCh arsets.UTF _8)) { | |||||||
| 116 | writer.w rite( | 116 | writer.w rite( | |||||||
| 117 | "<?xml ver sion='1.0' encoding= 'utf-8'?>\ n" + | 117 | "<?xml ver sion='1.0' encoding= 'utf-8'?>\ n" + | |||||||
| 118 | "<jaspic-p roviders\n " + | 118 | "<jaspic-p roviders\n " + | |||||||
| 119 | " xmlns =\"http:// tomcat.apa che.org/xm l\"\n" + | 119 | " xmlns =\"http:// tomcat.apa che.org/xm l\"\n" + | |||||||
| 120 | " xmlns :xsi=\"htt p://www.w3 .org/2001/ XMLSchema- instance\" \n" + | 120 | " xmlns :xsi=\"htt p://www.w3 .org/2001/ XMLSchema- instance\" \n" + | |||||||
| 121 | " xsi:s chemaLocat ion=\"http ://tomcat. apache.org /xml jaspi c-provider s.xsd\"\n" + | 121 | " xsi:s chemaLocat ion=\"http ://tomcat. apache.org /xml jaspi c-provider s.xsd\"\n" + | |||||||
| 122 | " versi on=\"1.0\" >\n"); | 122 | " versi on=\"1.0\" >\n"); | |||||||
| 123 | for (Pro vider prov ider : pro viders.pro viders) { | 123 | for (Pro vider prov ider : pro viders.pro viders) { | |||||||
| 124 | writ er.write(" <provide r classNam e=\""); | 124 | writ er.write(" <provide r classNam e=\""); | |||||||
| 125 | writ er.write(p rovider.ge tClassName ()); | 125 | writ er.write(p rovider.ge tClassName ()); | |||||||
| 126 | writ er.write(" \" layer=\ ""); | 126 | writ er.write(" \" layer=\ ""); | |||||||
| 127 | writ er.write(p rovider.ge tLayer()); | 127 | writ er.write(p rovider.ge tLayer()); | |||||||
| 128 | writ er.write(" \" appCont ext=\""); | 128 | writ er.write(" \" appCont ext=\""); | |||||||
| 129 | writ er.write(p rovider.ge tAppContex t()); | 129 | writ er.write(p rovider.ge tAppContex t()); | |||||||
| 130 | if ( provider.g etDescript ion() != n ull) { | 130 | if ( provider.g etDescript ion() != n ull) { | |||||||
| 131 | writer.wri te("\" des cription=\ ""); | 131 | writer.wri te("\" des cription=\ ""); | |||||||
| 132 | writer.wri te(provide r.getDescr iption()); | 132 | writer.wri te(provide r.getDescr iption()); | |||||||
| 133 | } | 133 | } | |||||||
| 134 | writ er.write(" \">\n"); | 134 | writ er.write(" \">\n"); | |||||||
| 135 | for (Entry<Str ing,String > entry : provider.g etProperti es().entry Set()) { | 135 | for (Entry<Str ing,String > entry : provider.g etProperti es().entry Set()) { | |||||||
| 136 | writer.wri te(" <p roperty na me=\""); | 136 | writer.wri te(" <p roperty na me=\""); | |||||||
| 137 | writer.wri te(entry.g etKey()); | 137 | writer.wri te(entry.g etKey()); | |||||||
| 138 | writer.wri te("\" val ue=\""); | 138 | writer.wri te("\" val ue=\""); | |||||||
| 139 | writer.wri te(entry.g etValue()) ; | 139 | writer.wri te(entry.g etValue()) ; | |||||||
| 140 | writer.wri te("\"/>\n "); | 140 | writer.wri te("\"/>\n "); | |||||||
| 141 | } | 141 | } | |||||||
| 142 | writ er.write(" </provid er>\n"); | 142 | writ er.write(" </provid er>\n"); | |||||||
| 143 | } | 143 | } | |||||||
| 144 | writer.w rite("</ja spic-provi ders>\n"); | 144 | writer.w rite("</ja spic-provi ders>\n"); | |||||||
| 145 | } catch (IOE xception e ) { | 145 | } catch (IOE xception e ) { | |||||||
| 146 |
|
146 | if (! configFile New.delete () ) { | |||||||
| 147 | log. warn(sm.ge tString("p ersistentP roviderReg istrations .deleteFai l", | |||||||||
| 148 | config FileNew.ge tAbsoluteP ath())); | |||||||||
| 149 | } | |||||||||
| 147 | throw ne w Security Exception( e); | 150 | throw ne w Security Exception( e); | |||||||
| 148 | } | 151 | } | |||||||
| 149 | 152 | |||||||||
| 150 | // Move the current fi le out of the way | 153 | // Move the current fi le out of the way | |||||||
| 151 | if (configFi le.isFile( )) { | 154 | if (configFi le.isFile( )) { | |||||||
| 152 | if (!con figFile.re nameTo(con figFileOld )) { | 155 | if (!con figFile.re nameTo(con figFileOld )) { | |||||||
| 153 | thro w new Secu rityExcept ion(sm.get String("pe rsistentPr oviderRegi strations. moveFail", | 156 | thro w new Secu rityExcept ion(sm.get String("pe rsistentPr oviderRegi strations. moveFail", | |||||||
| 154 | config File.getAb solutePath (), config FileOld.ge tAbsoluteP ath())); | 157 | config File.getAb solutePath (), config FileOld.ge tAbsoluteP ath())); | |||||||
| 155 | } | 158 | } | |||||||
| 156 | } | 159 | } | |||||||
| 157 | 160 | |||||||||
| 158 | // Move the new file i nto place | 161 | // Move the new file i nto place | |||||||
| 159 | if (!configF ileNew.ren ameTo(conf igFile)) { | 162 | if (!configF ileNew.ren ameTo(conf igFile)) { | |||||||
| 160 | throw ne w Security Exception( sm.getStri ng("persis tentProvid erRegistra tions.move Fail", | 163 | throw ne w Security Exception( sm.getStri ng("persis tentProvid erRegistra tions.move Fail", | |||||||
| 161 | configFile New.getAbs olutePath( ), configF ile.getAbs olutePath( ))); | 164 | configFile New.getAbs olutePath( ), configF ile.getAbs olutePath( ))); | |||||||
| 162 | } | 165 | } | |||||||
| 163 | 166 | |||||||||
| 164 | // Remove th e old file | 167 | // Remove th e old file | |||||||
| 165 | if (configFi leOld.exis ts() && !c onfigFileO ld.delete( )) { | 168 | if (configFi leOld.exis ts() && !c onfigFileO ld.delete( )) { | |||||||
| 166 | log.warn (sm.getStr ing("persi stentProvi derRegistr ations.del eteFail", | 169 | log.warn (sm.getStr ing("persi stentProvi derRegistr ations.del eteFail", | |||||||
| 167 | configFile Old.getAbs olutePath( ))); | 170 | configFile Old.getAbs olutePath( ))); | |||||||
| 168 | } | 171 | } | |||||||
| 169 | } | 172 | } | |||||||
| 170 | 173 | |||||||||
| 171 | 174 | |||||||||
| 172 | public static cl ass Provid ers { | 175 | public static cl ass Provid ers { | |||||||
| 173 | pr ivate fina l List<Pro vider> pro viders = n ew ArrayLi st<>(); | 176 | pr ivate fina l List<Pro vider> pro viders = n ew ArrayLi st<>(); | |||||||
| 174 | 177 | |||||||||
| 175 | pu blic void addProvide r(Provider provider) { | 178 | pu blic void addProvide r(Provider provider) { | |||||||
| 176 | provider s.add(prov ider); | 179 | provider s.add(prov ider); | |||||||
| 177 | } | 180 | } | |||||||
| 178 | 181 | |||||||||
| 179 | pu blic List< Provider> getProvide rs() { | 182 | pu blic List< Provider> getProvide rs() { | |||||||
| 180 | return p roviders; | 183 | return p roviders; | |||||||
| 181 | } | 184 | } | |||||||
| 182 | } | 185 | } | |||||||
| 183 | 186 | |||||||||
| 184 | 187 | |||||||||
| 185 | public static cl ass Provid er { | 188 | public static cl ass Provid er { | |||||||
| 186 | pr ivate Stri ng classNa me; | 189 | pr ivate Stri ng classNa me; | |||||||
| 187 | pr ivate Stri ng layer; | 190 | pr ivate Stri ng layer; | |||||||
| 188 | pr ivate Stri ng appCont ext; | 191 | pr ivate Stri ng appCont ext; | |||||||
| 189 | pr ivate Stri ng descrip tion; | 192 | pr ivate Stri ng descrip tion; | |||||||
| 190 | pr ivate fina l Map<Stri ng,String> propertie s = new Ha shMap<>(); | 193 | pr ivate fina l Map<Stri ng,String> propertie s = new Ha shMap<>(); | |||||||
| 191 | 194 | |||||||||
| 192 | 195 | |||||||||
| 193 | pu blic Strin g getClass Name() { | 196 | pu blic Strin g getClass Name() { | |||||||
| 194 | return c lassName; | 197 | return c lassName; | |||||||
| 195 | } | 198 | } | |||||||
| 196 | pu blic void setClassNa me(String className) { | 199 | pu blic void setClassNa me(String className) { | |||||||
| 197 | this.cla ssName = c lassName; | 200 | this.cla ssName = c lassName; | |||||||
| 198 | } | 201 | } | |||||||
| 199 | 202 | |||||||||
| 200 | 203 | |||||||||
| 201 | pu blic Strin g getLayer () { | 204 | pu blic Strin g getLayer () { | |||||||
| 202 | return l ayer; | 205 | return l ayer; | |||||||
| 203 | } | 206 | } | |||||||
| 204 | pu blic void setLayer(S tring laye r) { | 207 | pu blic void setLayer(S tring laye r) { | |||||||
| 205 | this.lay er = layer ; | 208 | this.lay er = layer ; | |||||||
| 206 | } | 209 | } | |||||||
| 207 | 210 | |||||||||
| 208 | 211 | |||||||||
| 209 | pu blic Strin g getAppCo ntext() { | 212 | pu blic Strin g getAppCo ntext() { | |||||||
| 210 | return a ppContext; | 213 | return a ppContext; | |||||||
| 211 | } | 214 | } | |||||||
| 212 | pu blic void setAppCont ext(String appContex t) { | 215 | pu blic void setAppCont ext(String appContex t) { | |||||||
| 213 | this.app Context = appContext ; | 216 | this.app Context = appContext ; | |||||||
| 214 | } | 217 | } | |||||||
| 215 | 218 | |||||||||
| 216 | 219 | |||||||||
| 217 | pu blic Strin g getDescr iption() { | 220 | pu blic Strin g getDescr iption() { | |||||||
| 218 | return d escription ; | 221 | return d escription ; | |||||||
| 219 | } | 222 | } | |||||||
| 220 | pu blic void setDescrip tion(Strin g descript ion) { | 223 | pu blic void setDescrip tion(Strin g descript ion) { | |||||||
| 221 | this.des cription = descripti on; | 224 | this.des cription = descripti on; | |||||||
| 222 | } | 225 | } | |||||||
| 223 | 226 | |||||||||
| 224 | 227 | |||||||||
| 225 | pu blic void addPropert y(Property property) { | 228 | pu blic void addPropert y(Property property) { | |||||||
| 226 | properti es.put(pro perty.getN ame(), pro perty.getV alue()); | 229 | properti es.put(pro perty.getN ame(), pro perty.getV alue()); | |||||||
| 227 | } | 230 | } | |||||||
| 228 | vo id addProp erty(Strin g name, St ring value ) { | 231 | vo id addProp erty(Strin g name, St ring value ) { | |||||||
| 229 | properti es.put(nam e, value); | 232 | properti es.put(nam e, value); | |||||||
| 230 | } | 233 | } | |||||||
| 231 | pu blic Map<S tring,Stri ng> getPro perties() { | 234 | pu blic Map<S tring,Stri ng> getPro perties() { | |||||||
| 232 | return p roperties; | 235 | return p roperties; | |||||||
| 233 | } | 236 | } | |||||||
| 234 | } | 237 | } | |||||||
| 235 | 238 | |||||||||
| 236 | 239 | |||||||||
| 237 | public static cl ass Proper ty { | 240 | public static cl ass Proper ty { | |||||||
| 238 | pr ivate Stri ng name; | 241 | pr ivate Stri ng name; | |||||||
| 239 | pr ivate Stri ng value; | 242 | pr ivate Stri ng value; | |||||||
| 240 | 243 | |||||||||
| 241 | 244 | |||||||||
| 242 | pu blic Strin g getName( ) { | 245 | pu blic Strin g getName( ) { | |||||||
| 243 | return n ame; | 246 | return n ame; | |||||||
| 244 | } | 247 | } | |||||||
| 245 | pu blic void setName(St ring name) { | 248 | pu blic void setName(St ring name) { | |||||||
| 246 | this.nam e = name; | 249 | this.nam e = name; | |||||||
| 247 | } | 250 | } | |||||||
| 248 | 251 | |||||||||
| 249 | 252 | |||||||||
| 250 | pu blic Strin g getValue () { | 253 | pu blic Strin g getValue () { | |||||||
| 251 | return v alue; | 254 | return v alue; | |||||||
| 252 | } | 255 | } | |||||||
| 253 | pu blic void setValue(S tring valu e) { | 256 | pu blic void setValue(S tring valu e) { | |||||||
| 254 | this.val ue = value ; | 257 | this.val ue = value ; | |||||||
| 255 | } | 258 | } | |||||||
| 256 | } | 259 | } | |||||||
| 257 | } | 260 | } |
Araxis Merge (but not the data content of this report) is Copyright © 1993–2017 Araxis Ltd (www.araxis.com). All rights reserved.