You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@isis.apache.org by da...@apache.org on 2017/08/15 06:51:33 UTC

[1/3] isis-site git commit: ISIS-1521: fixes links in template email to announce release

Repository: isis-site
Updated Branches:
  refs/heads/asf-site e8832fc0a -> caac5e5c5


http://git-wip-us.apache.org/repos/asf/isis-site/blob/caac5e5c/content/guides/cgcom/cgcom.html
----------------------------------------------------------------------
diff --git a/content/guides/cgcom/cgcom.html b/content/guides/cgcom/cgcom.html
index c464c2a..f587eb7 100644
--- a/content/guides/cgcom/cgcom.html
+++ b/content/guides/cgcom/cgcom.html
@@ -2336,8 +2336,8 @@ Enjoy!
 
 --The Apache Isis team
 
-[1] http://isis.apache.org/release-notes.html#r1.16.0
-[2] http://isis.apache.org/migration-notes.html#_migration-notes_1.15.0-to-1.16.0
+[1] http://isis.apache.org/release-notes/release-notes.html#_release-notes_1.16.0
+[2] http://isis.apache.org/migration-notes/migration-notes.html#_migration-notes_1.15.0-to-1.16.0
 [3] http://search.maven.org
 [4] http://isis.apache.org/downloads.html</code></pre> 
           </div> 

http://git-wip-us.apache.org/repos/asf/isis-site/blob/caac5e5c/content/guides/cgcom/cgcom.pdf
----------------------------------------------------------------------
diff --git a/content/guides/cgcom/cgcom.pdf b/content/guides/cgcom/cgcom.pdf
index b095d2e..486c355 100644
--- a/content/guides/cgcom/cgcom.pdf
+++ b/content/guides/cgcom/cgcom.pdf
@@ -4,8 +4,8 @@
 << /Title (Committers' Guide)
 /Creator (Asciidoctor PDF 1.5.0.alpha.11, based on Prawn 1.3.0)
 /Producer (Asciidoctor PDF 1.5.0.alpha.11, based on Prawn 1.3.0)
-/CreationDate (D:20170814212448+01'00')
-/ModDate (D:20170814212448+01'00')
+/CreationDate (D:20170815064832+01'00')
+/ModDate (D:20170815064832+01'00')
 >>
 endobj
 2 0 obj
@@ -29130,7 +29130,7 @@ endobj
 >>
 endobj
 275 0 obj
-<< /Length 12017
+<< /Length 11866
 >>
 stream
 q
@@ -29140,10 +29140,10 @@ q
 52.240 805.890 m
 543.040 805.890 l
 545.249 805.890 547.040 804.099 547.040 801.890 c
-547.040 507.830 l
-547.040 505.621 545.249 503.830 543.040 503.830 c
-52.240 503.830 l
-50.031 503.830 48.240 505.621 48.240 507.830 c
+547.040 493.090 l
+547.040 490.881 545.249 489.090 543.040 489.090 c
+52.240 489.090 l
+50.031 489.090 48.240 490.881 48.240 493.090 c
 48.240 801.890 l
 48.240 804.099 50.031 805.890 52.240 805.890 c
 h
@@ -29154,10 +29154,10 @@ f
 52.240 805.890 m
 543.040 805.890 l
 545.249 805.890 547.040 804.099 547.040 801.890 c
-547.040 507.830 l
-547.040 505.621 545.249 503.830 543.040 503.830 c
-52.240 503.830 l
-50.031 503.830 48.240 505.621 48.240 507.830 c
+547.040 493.090 l
+547.040 490.881 545.249 489.090 543.040 489.090 c
+52.240 489.090 l
+50.031 489.090 48.240 490.881 48.240 493.090 c
 48.240 801.890 l
 48.240 804.099 50.031 805.890 52.240 805.890 c
 h
@@ -29270,7 +29270,7 @@ ET
 BT
 59.24 561.9649999999999 Td
 /F4.0 11 Tf
-<5b315d20687474703a2f2f697369732e6170616368652e6f72672f72656c656173652d6e6f7465732e68746d6c2372312e31362e30> Tj
+<5b315d20687474703a2f2f697369732e6170616368652e6f72672f72656c656173652d6e6f7465732f72656c656173652d6e6f7465732e68746d6c235f72656c656173652d6e6f7465735f312e31362e30> Tj
 ET
 
 0.000 0.000 0.000 SCN
@@ -29281,7 +29281,7 @@ ET
 BT
 59.24 547.2249999999999 Td
 /F4.0 11 Tf
-<5b325d20687474703a2f2f697369732e6170616368652e6f72672f6d6967726174696f6e2d6e6f7465732e68746d6c235f6d6967726174696f6e2d6e6f7465735f312e31352e302d746f2d312e31362e30> Tj
+<5b325d20687474703a2f2f697369732e6170616368652e6f72672f6d6967726174696f6e2d6e6f7465732f6d6967726174696f6e2d6e6f7465732e68746d6c235f6d6967726174696f6e2d> Tj
 ET
 
 0.000 0.000 0.000 SCN
@@ -29292,7 +29292,7 @@ ET
 BT
 59.24 532.4849999999999 Td
 /F4.0 11 Tf
-<5b335d20687474703a2f2f7365617263682e6d6176656e2e6f7267> Tj
+<6e6f7465735f312e31352e302d746f2d312e31362e30> Tj
 ET
 
 0.000 0.000 0.000 SCN
@@ -29303,6 +29303,17 @@ ET
 BT
 59.24 517.7449999999999 Td
 /F4.0 11 Tf
+<5b335d20687474703a2f2f7365617263682e6d6176656e2e6f7267> Tj
+ET
+
+0.000 0.000 0.000 SCN
+0.000 0.000 0.000 scn
+0.200 0.200 0.200 scn
+0.200 0.200 0.200 SCN
+
+BT
+59.24 503.00499999999994 Td
+/F4.0 11 Tf
 <5b345d20687474703a2f2f697369732e6170616368652e6f72672f646f776e6c6f6164732e68746d6c> Tj
 ET
 
@@ -29312,7 +29323,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 467.8059999999999 Td
+48.24 453.0659999999999 Td
 /F2.0 18 Tf
 <362e382e20426c6f6720706f7374> Tj
 ET
@@ -29325,7 +29336,7 @@ ET
 0.158 Tw
 
 BT
-48.24 439.7859999999999 Td
+48.24 425.0459999999999 Td
 /F1.0 10.5 Tf
 <4c6f67206f6e746f> Tj
 ET
@@ -29340,7 +29351,7 @@ ET
 0.158 Tw
 
 BT
-91.95204700520833 439.7859999999999 Td
+91.95204700520833 425.0459999999999 Td
 /F1.0 10.5 Tf
 <2074686520> Tj
 ET
@@ -29355,7 +29366,7 @@ ET
 0.158 Tw
 
 BT
-113.677641015625 439.7859999999999 Td
+113.677641015625 425.0459999999999 Td
 /F1.0 10.5 Tf
 <41706163686520626c6f67> Tj
 ET
@@ -29370,7 +29381,7 @@ ET
 0.158 Tw
 
 BT
-175.13468802083332 439.7859999999999 Td
+175.13468802083332 425.0459999999999 Td
 /F1.0 10.5 Tf
 [<20616e64206372656174652061206e657720706f73742e20436f70> 20.01953125 <792d6e2d7061737465207468652061626f7665206d61696c696e67206c69737420616e6e6f756e63656d656e74>] TJ
 ET
@@ -29383,7 +29394,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 424.00599999999986 Td
+48.24 409.26599999999985 Td
 /F1.0 10.5 Tf
 <73686f756c6420737566666963652e> Tj
 ET
@@ -29394,7 +29405,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 384.1659999999999 Td
+48.24 369.4259999999999 Td
 /F2.0 18 Tf
 [<362e392e204d6572676520696e2072656c65617365206272> 20.01953125 <616e6368>] TJ
 ET
@@ -29407,7 +29418,7 @@ ET
 1.166 Tw
 
 BT
-48.24 356.14599999999984 Td
+48.24 341.40599999999984 Td
 /F1.0 10.5 Tf
 [<426563617573652077652072656c656173652066726f6d2061206272> 20.01953125 <616e63682c20746865206368616e676573206d61646520696e20746865206272> 20.01953125 <616e636820286368616e67657320746f20>] TJ
 ET
@@ -29422,7 +29433,7 @@ ET
 1.166 Tw
 
 BT
-462.50362817382813 356.14599999999984 Td
+462.50362817382813 341.40599999999984 Td
 /F4.0 10.5 Tf
 <706f6d2e786d6c> Tj
 ET
@@ -29437,7 +29448,7 @@ ET
 1.166 Tw
 
 BT
-499.25362817382813 356.14599999999984 Td
+499.25362817382813 341.40599999999984 Td
 /F1.0 10.5 Tf
 [<206d6164652062> 20.01953125 <79>] TJ
 ET
@@ -29452,7 +29463,7 @@ ET
 1.908 Tw
 
 BT
-48.24 340.3659999999999 Td
+48.24 325.62599999999986 Td
 /F1.0 10.5 Tf
 <74686520> Tj
 ET
@@ -29467,7 +29478,7 @@ ET
 1.908 Tw
 
 BT
-68.83841616586538 340.3659999999999 Td
+68.83841616586538 325.62599999999986 Td
 /F4.0 10.5 Tf
 <6d6176656e2d72656c656173652d706c7567696e> Tj
 ET
@@ -29482,7 +29493,7 @@ ET
 1.908 Tw
 
 BT
-173.8384161658654 340.3659999999999 Td
+173.8384161658654 325.62599999999986 Td
 /F1.0 10.5 Tf
 [<2c206f7220616e> 20.01953125 <79206d616e75616c206564697473292073686f756c64206265206d6572676564206261636b2066726f6d207468652072656c65617365206272> 20.01953125 <616e6368>] TJ
 ET
@@ -29495,7 +29506,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 324.58599999999984 Td
+48.24 309.84599999999983 Td
 /F1.0 10.5 Tf
 <6261636b20696e746f2074686520> Tj
 ET
@@ -29506,7 +29517,7 @@ ET
 0.694 0.129 0.275 SCN
 
 BT
-115.881 324.58599999999984 Td
+115.881 309.84599999999983 Td
 /F4.0 10.5 Tf
 <6d6173746572> Tj
 ET
@@ -29517,7 +29528,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-147.381 324.58599999999984 Td
+147.381 309.84599999999983 Td
 /F1.0 10.5 Tf
 [<206272> 20.01953125 <616e63683a>] TJ
 ET
@@ -29526,28 +29537,28 @@ ET
 0.000 0.000 0.000 scn
 q
 0.961 0.961 0.961 scn
-52.240 308.770 m
-543.040 308.770 l
-545.249 308.770 547.040 306.979 547.040 304.770 c
-547.040 217.070 l
-547.040 214.861 545.249 213.070 543.040 213.070 c
-52.240 213.070 l
-50.031 213.070 48.240 214.861 48.240 217.070 c
-48.240 304.770 l
-48.240 306.979 50.031 308.770 52.240 308.770 c
+52.240 294.030 m
+543.040 294.030 l
+545.249 294.030 547.040 292.239 547.040 290.030 c
+547.040 202.330 l
+547.040 200.121 545.249 198.330 543.040 198.330 c
+52.240 198.330 l
+50.031 198.330 48.240 200.121 48.240 202.330 c
+48.240 290.030 l
+48.240 292.239 50.031 294.030 52.240 294.030 c
 h
 f
 0.800 0.800 0.800 SCN
 0.75 w
-52.240 308.770 m
-543.040 308.770 l
-545.249 308.770 547.040 306.979 547.040 304.770 c
-547.040 217.070 l
-547.040 214.861 545.249 213.070 543.040 213.070 c
-52.240 213.070 l
-50.031 213.070 48.240 214.861 48.240 217.070 c
-48.240 304.770 l
-48.240 306.979 50.031 308.770 52.240 308.770 c
+52.240 294.030 m
+543.040 294.030 l
+545.249 294.030 547.040 292.239 547.040 290.030 c
+547.040 202.330 l
+547.040 200.121 545.249 198.330 543.040 198.330 c
+52.240 198.330 l
+50.031 198.330 48.240 200.121 48.240 202.330 c
+48.240 290.030 l
+48.240 292.239 50.031 294.030 52.240 294.030 c
 h
 S
 Q
@@ -29555,7 +29566,7 @@ Q
 0.200 0.200 0.200 SCN
 
 BT
-59.24 285.9449999999998 Td
+59.24 271.2049999999998 Td
 /F4.0 11 Tf
 <67697420636865636b6f7574206d61737465722020202020202020202020202020202020202020202020202020202320757064617465206d61737465722077697468206c6174657374> Tj
 ET
@@ -29566,7 +29577,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 271.20499999999987 Td
+59.24 256.46499999999986 Td
 /F4.0 11 Tf
 <6769742070756c6c> Tj
 ET
@@ -29577,7 +29588,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 256.46499999999986 Td
+59.24 241.72499999999985 Td
 /F4.0 11 Tf
 <676974206d657267652072656c656173652d312e31362e302d52433120202020202020202020202020202020202023206d65726765206272616e6368206f6e746f206d6173746572> Tj
 ET
@@ -29588,7 +29599,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 241.72499999999985 Td
+59.24 226.98499999999984 Td
 /F4.0 11 Tf
 <6769742070757368206f726967696e202d2d64656c6574652072656c656173652d312e31362e302d524331202020232072656d6f7465206272616e6368206e6f206c6f6e676572206e6565646564> Tj
 ET
@@ -29599,7 +29610,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 226.98499999999984 Td
+59.24 212.24499999999983 Td
 /F4.0 11 Tf
 <676974206272616e6368202d642072656c656173652d312e31362e302d524331202020202020202020202020202023206272616e6368206e6f206c6f6e676572206e6565646564> Tj
 ET
@@ -29612,7 +29623,7 @@ ET
 0.735 Tw
 
 BT
-48.24 189.10599999999985 Td
+48.24 174.36599999999984 Td
 /F1.0 10.5 Tf
 [<46696e616c6c79> 89.84375 <2c207570646174652068656c6c6f776f726c64d57320>] TJ
 ET
@@ -29627,7 +29638,7 @@ ET
 0.735 Tw
 
 BT
-191.60765673828126 189.10599999999985 Td
+191.60765673828126 174.36599999999984 Td
 /F4.0 10.5 Tf
 <706f6d2e786d6c> Tj
 ET
@@ -29642,7 +29653,7 @@ ET
 0.735 Tw
 
 BT
-228.35765673828126 189.10599999999985 Td
+228.35765673828126 174.36599999999984 Td
 /F1.0 10.5 Tf
 <20616e642073696d706c65617070d57320726f6f7420> Tj
 ET
@@ -29657,7 +29668,7 @@ ET
 0.735 Tw
 
 BT
-341.48334488932295 189.10599999999985 Td
+341.48334488932295 174.36599999999984 Td
 /F4.0 10.5 Tf
 <706f6d2e786d6c> Tj
 ET
@@ -29672,7 +29683,7 @@ ET
 0.735 Tw
 
 BT
-378.23334488932295 189.10599999999985 Td
+378.23334488932295 174.36599999999984 Td
 /F1.0 10.5 Tf
 [<20746f207265666572656e636520746865206e65787420534e415053484f> 20.01953125 <54>] TJ
 ET
@@ -29685,7 +29696,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 173.32599999999985 Td
+48.24 158.58599999999984 Td
 /F1.0 10.5 Tf
 <72656c656173652028> Tj
 ET
@@ -29696,7 +29707,7 @@ ET
 0.694 0.129 0.275 SCN
 
 BT
-90.28200000000001 173.32599999999985 Td
+90.28200000000001 158.58599999999984 Td
 /F4.0 10.5 Tf
 <312e31372e302d534e415053484f54> Tj
 ET
@@ -29707,7 +29718,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-169.032 173.32599999999985 Td
+169.032 158.58599999999984 Td
 /F1.0 10.5 Tf
 <29> Tj
 ET
@@ -29718,7 +29729,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 133.48599999999982 Td
+48.24 118.74599999999982 Td
 /F2.0 18 Tf
 <362e31302e2055706461746520646570656e64656e63696573> Tj
 ET
@@ -29731,7 +29742,7 @@ ET
 0.422 Tw
 
 BT
-48.24 105.46599999999985 Td
+48.24 90.72599999999983 Td
 /F1.0 10.5 Tf
 <57697468207468652072656c6561736520636f6d706c6574652c206e6f77206973206120676f6f642074696d6520746f2062756d702076657273696f6e73206f6620646570656e64656e636965732028736f20746861742074686572652069732061> Tj
 ET
@@ -29744,28 +29755,13 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 89.68599999999985 Td
+48.24 74.94599999999983 Td
 /F1.0 10.5 Tf
 [<66756c6c2072656c65617365206379636c6520746f206964656e7469667920616e> 20.01953125 <7920706f737369626c6520697373756573292e>] TJ
 ET
 
 0.000 0.000 0.000 SCN
 0.000 0.000 0.000 scn
-0.200 0.200 0.200 scn
-0.200 0.200 0.200 SCN
-
-1.942 Tw
-
-BT
-48.24 61.90599999999985 Td
-/F1.0 10.5 Tf
-[<59> 69.82421875 <6f752077696c6c2070726f6261626c792077616e7420746f206372656174652061206e6577204a495241207469636b> 20.01953125 <657420666f72207468657365207570646174657320286f72206966206d696e6f72207468656e2075736520746865>] TJ
-ET
-
-
-0.000 Tw
-0.000 0.000 0.000 SCN
-0.000 0.000 0.000 scn
 q
 0.000 0.000 0.000 scn
 0.000 0.000 0.000 SCN
@@ -29807,7 +29803,7 @@ endobj
 >>
 endobj
 277 0 obj
-[276 0 R /XYZ 0 491.8299999999999 null]
+[276 0 R /XYZ 0 477.0899999999999 null]
 endobj
 278 0 obj
 << /Border [0 0 0]
@@ -29816,7 +29812,7 @@ endobj
 /URI (https://blogs.apache.org/roller-ui/login.rol)
 >>
 /Subtype /Link
-/Rect [48.24 436.7199999999999 91.95204700520833 450.9999999999999]
+/Rect [48.24 421.9799999999999 91.95204700520833 436.2599999999999]
 /Type /Annot
 >>
 endobj
@@ -29827,12 +29823,12 @@ endobj
 /URI (http://blogs.apache.org/isis/)
 >>
 /Subtype /Link
-/Rect [113.677641015625 436.7199999999999 175.13468802083332 450.9999999999999]
+/Rect [113.677641015625 421.9799999999999 175.13468802083332 436.2599999999999]
 /Type /Annot
 >>
 endobj
 280 0 obj
-[276 0 R /XYZ 0 408.1899999999999 null]
+[276 0 R /XYZ 0 393.4499999999999 null]
 endobj
 281 0 obj
 << /Limits [(prereqs) (publishing-partial-build)]
@@ -29840,10 +29836,10 @@ endobj
 >>
 endobj
 282 0 obj
-[276 0 R /XYZ 0 157.50999999999985 null]
+[276 0 R /XYZ 0 142.76999999999984 null]
 endobj
 283 0 obj
-<< /Length 14054
+<< /Length 14441
 >>
 stream
 q
@@ -29852,9 +29848,24 @@ q
 /DeviceRGB CS
 0.200 0.200 0.200 SCN
 
+1.942 Tw
+
 BT
 48.24 794.6759999999999 Td
 /F1.0 10.5 Tf
+[<59> 69.82421875 <6f752077696c6c2070726f6261626c792077616e7420746f206372656174652061206e6577204a495241207469636b> 20.01953125 <657420666f72207468657365207570646174657320286f72206966206d696e6f72207468656e2075736520746865>] TJ
+ET
+
+
+0.000 Tw
+0.000 0.000 0.000 SCN
+0.000 0.000 0.000 scn
+0.200 0.200 0.200 scn
+0.200 0.200 0.200 SCN
+
+BT
+48.24 778.896 Td
+/F1.0 10.5 Tf
 [<2263617463682d616c6c22204a495241207469636b> 20.01953125 <65742072> 20.01953125 <6169736564206561726c69657220666f7220746865206e6578742072656c65617365292e>] TJ
 ET
 
@@ -29864,7 +29875,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 760.176 Td
+48.24 744.3960000000001 Td
 /F2.0 13 Tf
 <362e31302e312e2055706461746520706172656e74206f6620436f7265> Tj
 ET
@@ -29877,7 +29888,7 @@ ET
 6.300 Tw
 
 BT
-48.24 733.6160000000001 Td
+48.24 717.8360000000001 Td
 /F1.0 10.5 Tf
 <436865636b202876696120> Tj
 ET
@@ -29892,7 +29903,7 @@ ET
 6.300 Tw
 
 BT
-115.25058333333331 733.6160000000001 Td
+115.25058333333331 717.8360000000001 Td
 /F1.0 10.5 Tf
 <7365617263682e6d6176656e2e6f7267> Tj
 ET
@@ -29907,7 +29918,7 @@ ET
 6.300 Tw
 
 BT
-204.45858333333334 733.6160000000001 Td
+204.45858333333334 717.8360000000001 Td
 /F1.0 10.5 Tf
 <2920776865746865722074686572652069732061206e657765722076657273696f6e206f66207468652041706163686520706172656e74> Tj
 ET
@@ -29920,7 +29931,7 @@ ET
 0.694 0.129 0.275 SCN
 
 BT
-48.24 717.8360000000001 Td
+48.24 702.0560000000002 Td
 /F4.0 10.5 Tf
 <6f72672e6170616368653a617061636865> Tj
 ET
@@ -29931,7 +29942,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-137.49 717.8360000000001 Td
+137.49 702.0560000000002 Td
 /F1.0 10.5 Tf
 <2e> Tj
 ET
@@ -29944,7 +29955,7 @@ ET
 1.680 Tw
 
 BT
-48.24 690.0560000000002 Td
+48.24 674.2760000000002 Td
 /F1.0 10.5 Tf
 <49662074686572652069732c207570646174652074686520> Tj
 ET
@@ -29959,7 +29970,7 @@ ET
 1.680 Tw
 
 BT
-165.92635294117648 690.0560000000002 Td
+165.92635294117648 674.2760000000002 Td
 /F4.0 10.5 Tf
 <3c76657273696f6e3e> Tj
 ET
@@ -29974,7 +29985,7 @@ ET
 1.680 Tw
 
 BT
-213.17635294117648 690.0560000000002 Td
+213.17635294117648 674.2760000000002 Td
 /F1.0 10.5 Tf
 <20696e2074686520> Tj
 ET
@@ -29989,7 +30000,7 @@ ET
 1.680 Tw
 
 BT
-252.46876470588236 690.0560000000002 Td
+252.46876470588236 674.2760000000002 Td
 /F4.0 10.5 Tf
 <3c706172656e743e> Tj
 ET
@@ -30004,7 +30015,7 @@ ET
 1.680 Tw
 
 BT
-294.46876470588234 690.0560000000002 Td
+294.46876470588234 674.2760000000002 Td
 /F1.0 10.5 Tf
 <20656c656d656e7420696e2074686520706172656e7420504f4d20746f206d6174636820746865206e65776572> Tj
 ET
@@ -30017,7 +30028,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 674.2760000000002 Td
+48.24 658.4960000000002 Td
 /F1.0 10.5 Tf
 <76657273696f6e3a> Tj
 ET
@@ -30026,28 +30037,28 @@ ET
 0.000 0.000 0.000 scn
 q
 0.961 0.961 0.961 scn
-52.240 658.460 m
-543.040 658.460 l
-545.249 658.460 547.040 656.669 547.040 654.460 c
-547.040 552.020 l
-547.040 549.811 545.249 548.020 543.040 548.020 c
-52.240 548.020 l
-50.031 548.020 48.240 549.811 48.240 552.020 c
-48.240 654.460 l
-48.240 656.669 50.031 658.460 52.240 658.460 c
+52.240 642.680 m
+543.040 642.680 l
+545.249 642.680 547.040 640.889 547.040 638.680 c
+547.040 536.240 l
+547.040 534.031 545.249 532.240 543.040 532.240 c
+52.240 532.240 l
+50.031 532.240 48.240 534.031 48.240 536.240 c
+48.240 638.680 l
+48.240 640.889 50.031 642.680 52.240 642.680 c
 h
 f
 0.800 0.800 0.800 SCN
 0.75 w
-52.240 658.460 m
-543.040 658.460 l
-545.249 658.460 547.040 656.669 547.040 654.460 c
-547.040 552.020 l
-547.040 549.811 545.249 548.020 543.040 548.020 c
-52.240 548.020 l
-50.031 548.020 48.240 549.811 48.240 552.020 c
-48.240 654.460 l
-48.240 656.669 50.031 658.460 52.240 658.460 c
+52.240 642.680 m
+543.040 642.680 l
+545.249 642.680 547.040 640.889 547.040 638.680 c
+547.040 536.240 l
+547.040 534.031 545.249 532.240 543.040 532.240 c
+52.240 532.240 l
+50.031 532.240 48.240 534.031 48.240 536.240 c
+48.240 638.680 l
+48.240 640.889 50.031 642.680 52.240 642.680 c
 h
 S
 Q
@@ -30055,7 +30066,7 @@ Q
 0.184 0.435 0.624 SCN
 
 BT
-59.24 635.6350000000002 Td
+59.24 619.8550000000002 Td
 /F4.0 11 Tf
 <3c706172656e743e> Tj
 ET
@@ -30066,7 +30077,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 620.8950000000002 Td
+59.24 605.1150000000002 Td
 /F4.0 11 Tf
 <ca202020> Tj
 ET
@@ -30077,7 +30088,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-81.24000000000001 620.8950000000002 Td
+81.24000000000001 605.1150000000002 Td
 /F4.0 11 Tf
 <3c67726f757049643e> Tj
 ET
@@ -30088,7 +30099,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-130.74 620.8950000000002 Td
+130.74 605.1150000000002 Td
 /F4.0 11 Tf
 <6f72672e617061636865> Tj
 ET
@@ -30099,7 +30110,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-185.74 620.8950000000002 Td
+185.74 605.1150000000002 Td
 /F4.0 11 Tf
 <3c2f67726f757049643e> Tj
 ET
@@ -30110,7 +30121,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 606.1550000000002 Td
+59.24 590.3750000000002 Td
 /F4.0 11 Tf
 <ca202020> Tj
 ET
@@ -30121,7 +30132,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-81.24000000000001 606.1550000000002 Td
+81.24000000000001 590.3750000000002 Td
 /F4.0 11 Tf
 <3c617274696661637449643e> Tj
 ET
@@ -30132,7 +30143,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-147.24 606.1550000000002 Td
+147.24 590.3750000000002 Td
 /F4.0 11 Tf
 <617061636865> Tj
 ET
@@ -30143,7 +30154,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-180.24 606.1550000000002 Td
+180.24 590.3750000000002 Td
 /F4.0 11 Tf
 <3c2f617274696661637449643e> Tj
 ET
@@ -30154,7 +30165,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 591.4150000000003 Td
+59.24 575.6350000000003 Td
 /F4.0 11 Tf
 <ca202020> Tj
 ET
@@ -30165,7 +30176,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-81.24000000000001 591.4150000000003 Td
+81.24000000000001 575.6350000000003 Td
 /F4.0 11 Tf
 <3c76657273696f6e3e> Tj
 ET
@@ -30176,7 +30187,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-130.74 591.4150000000003 Td
+130.74 575.6350000000003 Td
 /F4.0 11 Tf
 <4e4e> Tj
 ET
@@ -30187,7 +30198,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-141.74 591.4150000000003 Td
+141.74 575.6350000000003 Td
 /F4.0 11 Tf
 <3c2f76657273696f6e3e> Tj
 ET
@@ -30198,7 +30209,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 576.6750000000003 Td
+59.24 560.8950000000003 Td
 /F4.0 11 Tf
 <ca202020> Tj
 ET
@@ -30209,7 +30220,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-81.24000000000001 576.6750000000003 Td
+81.24000000000001 560.8950000000003 Td
 /F4.0 11 Tf
 <3c72656c617469766550617468> Tj
 ET
@@ -30220,7 +30231,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-152.74 576.6750000000003 Td
+152.74 560.8950000000003 Td
 /F4.0 11 Tf
 <20> Tj
 ET
@@ -30231,7 +30242,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-158.24 576.6750000000003 Td
+158.24 560.8950000000003 Td
 /F4.0 11 Tf
 <2f3e> Tj
 ET
@@ -30242,7 +30253,7 @@ ET
 0.184 0.435 0.624 SCN
 
 BT
-59.24 561.9350000000003 Td
+59.24 546.1550000000003 Td
 /F4.0 11 Tf
 <3c2f706172656e743e> Tj
 ET
@@ -30253,7 +30264,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 524.0560000000003 Td
+48.24 508.27600000000024 Td
 /F1.0 10.5 Tf
 <776865726520> Tj
 ET
@@ -30264,7 +30275,7 @@ ET
 0.694 0.129 0.275 SCN
 
 BT
-82.8375 524.0560000000003 Td
+82.8375 508.27600000000024 Td
 /F4.0 10.5 Tf
 <4e4e> Tj
 ET
@@ -30275,7 +30286,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-93.3375 524.0560000000003 Td
+93.3375 508.27600000000024 Td
 /F1.0 10.5 Tf
 <2069732074686520757064617465642076657273696f6e206e756d6265722e> Tj
 ET
@@ -30286,7 +30297,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 489.5560000000002 Td
+48.24 473.77600000000024 Td
 /F2.0 13 Tf
 <362e31302e322e2055706461746520706c7567696e2076657273696f6e73> Tj
 ET
@@ -30299,7 +30310,7 @@ ET
 1.287 Tw
 
 BT
-48.24 462.9960000000002 Td
+48.24 447.21600000000024 Td
 /F1.0 10.5 Tf
 <54686520> Tj
 ET
@@ -30314,7 +30325,7 @@ ET
 1.287 Tw
 
 BT
-70.94714700520834 462.9960000000002 Td
+70.94714700520834 447.21600000000024 Td
 /F4.0 10.5 Tf
 <6d6176656e2d76657273696f6e732d706c7567696e> Tj
 ET
@@ -30329,7 +30340,7 @@ ET
 1.287 Tw
 
 BT
-181.19714700520834 462.9960000000002 Td
+181.19714700520834 447.21600000000024 Td
 /F1.0 10.5 Tf
 [<2073686f756c64206265207573656420746f2064657465726d696e6520696620746865726520617265206e657765722076657273696f6e73206f6620616e> 20.01953125 <79206f6620746865>] TJ
 ET
@@ -30344,7 +30355,7 @@ ET
 0.542 Tw
 
 BT
-48.24 447.21600000000024 Td
+48.24 431.43600000000026 Td
 /F1.0 10.5 Tf
 [<706c7567696e73207573656420746f206275696c642041706163686520497369732e2053696e6365207468697320676f6573206f666620746f2074686520696e7465726e65742c206974206d61> 20.01953125 <792074616b> 20.01953125 <652061206d696e757465206f722074776f20746f>] TJ
 ET
@@ -30357,7 +30368,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 431.4360000000002 Td
+48.24 415.65600000000023 Td
 /F1.0 10.5 Tf
 <72756e3a> Tj
 ET
@@ -30366,28 +30377,28 @@ ET
 0.000 0.000 0.000 scn
 q
 0.961 0.961 0.961 scn
-52.240 415.620 m
-543.040 415.620 l
-545.249 415.620 547.040 413.829 547.040 411.620 c
-547.040 368.140 l
-547.040 365.931 545.249 364.140 543.040 364.140 c
-52.240 364.140 l
-50.031 364.140 48.240 365.931 48.240 368.140 c
-48.240 411.620 l
-48.240 413.829 50.031 415.620 52.240 415.620 c
+52.240 399.840 m
+543.040 399.840 l
+545.249 399.840 547.040 398.049 547.040 395.840 c
+547.040 352.360 l
+547.040 350.151 545.249 348.360 543.040 348.360 c
+52.240 348.360 l
+50.031 348.360 48.240 350.151 48.240 352.360 c
+48.240 395.840 l
+48.240 398.049 50.031 399.840 52.240 399.840 c
 h
 f
 0.800 0.800 0.800 SCN
 0.75 w
-52.240 415.620 m
-543.040 415.620 l
-545.249 415.620 547.040 413.829 547.040 411.620 c
-547.040 368.140 l
-547.040 365.931 545.249 364.140 543.040 364.140 c
-52.240 364.140 l
-50.031 364.140 48.240 365.931 48.240 368.140 c
-48.240 411.620 l
-48.240 413.829 50.031 415.620 52.240 415.620 c
+52.240 399.840 m
+543.040 399.840 l
+545.249 399.840 547.040 398.049 547.040 395.840 c
+547.040 352.360 l
+547.040 350.151 545.249 348.360 543.040 348.360 c
+52.240 348.360 l
+50.031 348.360 48.240 350.151 48.240 352.360 c
+48.240 395.840 l
+48.240 398.049 50.031 399.840 52.240 399.840 c
 h
 S
 Q
@@ -30395,7 +30406,7 @@ Q
 0.200 0.200 0.200 SCN
 
 BT
-59.24 392.79500000000024 Td
+59.24 377.01500000000027 Td
 /F4.0 11 Tf
 <6d766e2076657273696f6e733a646973706c61792d706c7567696e2d75706461746573203e202f746d702f666f6f> Tj
 ET
@@ -30406,7 +30417,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 378.05500000000023 Td
+59.24 362.27500000000026 Td
 /F4.0 11 Tf
 <6772657020225c2d3e22202f746d702f666f6f207c202f62696e2f736f7274202d75> Tj
 ET
@@ -30419,7 +30430,7 @@ ET
 0.700 Tw
 
 BT
-48.24 340.1760000000002 Td
+48.24 324.39600000000024 Td
 /F1.0 10.5 Tf
 [<526576696577207468652067656e6572> 20.01953125 <61746564206f757470757420616e64206d616b> 20.01953125 <65207570646174657320617320796f7520736565206669742e2028486f77657665722c206966207570646174696e672c20706c6561736520636865636b>] TJ
 ET
@@ -30432,7 +30443,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 324.3960000000002 Td
+48.24 308.6160000000002 Td
 /F1.0 10.5 Tf
 [<62> 20.01953125 <7920736561726368696e6720666f72206b6e6f776e206973737565732077697468206e657765722076657273696f6e73292e>] TJ
 ET
@@ -30443,7 +30454,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 289.8960000000002 Td
+48.24 274.1160000000002 Td
 /F2.0 13 Tf
 <362e31302e332e2055706461746520646570656e64656e63792076657273696f6e73> Tj
 ET
@@ -30456,7 +30467,7 @@ ET
 1.086 Tw
 
 BT
-48.24 263.3360000000002 Td
+48.24 247.5560000000002 Td
 /F1.0 10.5 Tf
 <54686520> Tj
 ET
@@ -30471,7 +30482,7 @@ ET
 1.086 Tw
 
 BT
-70.74624700520833 263.3360000000002 Td
+70.74624700520833 247.5560000000002 Td
 /F4.0 10.5 Tf
 <6d6176656e2d76657273696f6e732d706c7567696e> Tj
 ET
@@ -30486,7 +30497,7 @@ ET
 1.086 Tw
 
 BT
-180.99624700520835 263.3360000000002 Td
+180.99624700520835 247.5560000000002 Td
 /F1.0 10.5 Tf
 [<2073686f756c64206265207573656420746f2064657465726d696e6520696620746865726520617265206e657765722076657273696f6e73206f6620616e> 20.01953125 <79206f66204973697327>] TJ
 ET
@@ -30499,7 +30510,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 247.55600000000018 Td
+48.24 231.7760000000002 Td
 /F1.0 10.5 Tf
 [<646570656e64656e636965732e2053696e6365207468697320676f6573206f666620746f2074686520696e7465726e65742c206974206d61> 20.01953125 <792074616b> 20.01953125 <652061206d696e757465206f722074776f20746f2072756e3a>] TJ
 ET
@@ -30508,28 +30519,28 @@ ET
 0.000 0.000 0.000 scn
 q
 0.961 0.961 0.961 scn
-52.240 231.740 m
-543.040 231.740 l
-545.249 231.740 547.040 229.949 547.040 227.740 c
-547.040 184.260 l
-547.040 182.051 545.249 180.260 543.040 180.260 c
-52.240 180.260 l
-50.031 180.260 48.240 182.051 48.240 184.260 c
-48.240 227.740 l
-48.240 229.949 50.031 231.740 52.240 231.740 c
+52.240 215.960 m
+543.040 215.960 l
+545.249 215.960 547.040 214.169 547.040 211.960 c
+547.040 168.480 l
+547.040 166.271 545.249 164.480 543.040 164.480 c
+52.240 164.480 l
+50.031 164.480 48.240 166.271 48.240 168.480 c
+48.240 211.960 l
+48.240 214.169 50.031 215.960 52.240 215.960 c
 h
 f
 0.800 0.800 0.800 SCN
 0.75 w
-52.240 231.740 m
-543.040 231.740 l
-545.249 231.740 547.040 229.949 547.040 227.740 c
-547.040 184.260 l
-547.040 182.051 545.249 180.260 543.040 180.260 c
-52.240 180.260 l
-50.031 180.260 48.240 182.051 48.240 184.260 c
-48.240 227.740 l
-48.240 229.949 50.031 231.740 52.240 231.740 c
+52.240 215.960 m
+543.040 215.960 l
+545.249 215.960 547.040 214.169 547.040 211.960 c
+547.040 168.480 l
+547.040 166.271 545.249 164.480 543.040 164.480 c
+52.240 164.480 l
+50.031 164.480 48.240 166.271 48.240 168.480 c
+48.240 211.960 l
+48.240 214.169 50.031 215.960 52.240 215.960 c
 h
 S
 Q
@@ -30537,7 +30548,7 @@ Q
 0.200 0.200 0.200 SCN
 
 BT
-59.24 208.91500000000016 Td
+59.24 193.1350000000002 Td
 /F4.0 11 Tf
 <6d766e2076657273696f6e733a646973706c61792d646570656e64656e63792d75706461746573203e202f746d702f666f6f> Tj
 ET
@@ -30548,7 +30559,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-59.24 194.17500000000018 Td
+59.24 178.3950000000002 Td
 /F4.0 11 Tf
 <6772657020225c2d3e22202f746d702f666f6f207c202f62696e2f736f7274202d75> Tj
 ET
@@ -30561,7 +30572,7 @@ ET
 1.678 Tw
 
 BT
-48.24 156.29600000000016 Td
+48.24 140.5160000000002 Td
 /F1.0 10.5 Tf
 [<55706461746520616e> 20.01953125 <79206f662074686520646570656e64656e63696573207468617420617265206f75742d6f662d646174652e205468617420736169642c20646f206e6f7465207468617420736f6d6520646570656e64656e63696573>] TJ
 ET
@@ -30576,7 +30587,7 @@ ET
 1.688 Tw
 
 BT
-48.24 140.51600000000016 Td
+48.24 124.73600000000019 Td
 /F1.0 10.5 Tf
 [<6d61> 20.01953125 <792073686f7720757020776974682061206e657720646570656e64656e6379> 89.84375 <2c207768656e20696e20666163742074686520646570656e64656e637920697320666f7220616e206f6c642c206261646c79206e616d6564>] TJ
 ET
@@ -30591,7 +30602,7 @@ ET
 3.298 Tw
 
 BT
-48.24 124.73600000000016 Td
+48.24 108.95600000000019 Td
 /F1.0 10.5 Tf
 [<76657273696f6e2e20416c736f2c207468657265206d61> 20.01953125 <79206265206e657720646570656e64656e63696573207468617420796f7520646f206e6f74207769736820746f206d6f766520746f2c2065672072656c65617365>] TJ
 ET
@@ -30604,7 +30615,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 108.95600000000016 Td
+48.24 93.17600000000019 Td
 /F1.0 10.5 Tf
 <63616e64696461746573206f72206d696c6573746f6e65732e> Tj
 ET
@@ -30615,7 +30626,7 @@ ET
 0.200 0.200 0.200 SCN
 
 BT
-48.24 81.17600000000016 Td
+48.24 65.39600000000019 Td
 /F1.0 10.5 Tf
 [<46> 40.0390625 <6f72206578616d706c652c20686572652069732061207265706f72742073686f77696e6720626f7468206f662074686573652063617365733a>] TJ
 ET
@@ -30663,7 +30674,7 @@ endobj
 >>
 endobj
 285 0 obj
-[284 0 R /XYZ 0 778.86 null]
+[284 0 R /XYZ 0 763.08 null]
 endobj
 286 0 obj
 << /Border [0 0 0]
@@ -30672,15 +30683,15 @@ endobj
 /URI (http://search.maven.org/#search%7Cga%7C1%7Cg%3A%22org.apache%22%20a%3A%22apache%22)
 >>
 /Subtype /Link
-/Rect [115.25058333333331 730.5500000000001 204.45858333333334 744.8300000000002]
+/Rect [115.25058333333331 714.7700000000001 204.45858333333334 729.0500000000002]
 /Type /Annot
 >>
 endobj
 287 0 obj
-[284 0 R /XYZ 0 508.24000000000024 null]
+[284 0 R /XYZ 0 492.46000000000026 null]
 endobj
 288 0 obj
-[284 0 R /XYZ 0 308.5800000000002 null]
+[284 0 R /XYZ 0 292.80000000000024 null]
 endobj
 289 0 obj
 << /Length 13555
@@ -56825,7 +56836,7 @@ endobj
 /Count 0
 /Next 694 0 R
 /Prev 692 0 R
-/Dest [276 0 R /XYZ 0 491.8299999999999 null]
+/Dest [276 0 R /XYZ 0 477.0899999999999 null]
 >>
 endobj
 694 0 obj
@@ -56834,7 +56845,7 @@ endobj
 /Count 0
 /Next 695 0 R
 /Prev 693 0 R
-/Dest [276 0 R /XYZ 0 408.1899999999999 null]
+/Dest [276 0 R /XYZ 0 393.4499999999999 null]
 >>
 endobj
 695 0 obj
@@ -56843,7 +56854,7 @@ endobj
 /Count 0
 /Next 696 0 R
 /Prev 694 0 R
-/Dest [276 0 R /XYZ 0 157.50999999999985 null]
+/Dest [276 0 R /XYZ 0 142.76999999999984 null]
 >>
 endobj
 696 0 obj
@@ -57870,499 +57881,499 @@ xref
 0001193422 00000 n 
 0001193479 00000 n 
 0001193686 00000 n 
-0001205758 00000 n 
-0001206025 00000 n 
-0001206082 00000 n 
-0001206300 00000 n 
-0001206515 00000 n 
-0001206572 00000 n 
-0001207031 00000 n 
-0001207089 00000 n 
-0001221198 00000 n 
-0001221457 00000 n 
-0001221503 00000 n 
-0001221773 00000 n 
-0001221831 00000 n 
-0001221888 00000 n 
-0001235498 00000 n 
-0001235797 00000 n 
-0001235996 00000 n 
-0001236053 00000 n 
-0001236298 00000 n 
-0001236527 00000 n 
-0001236585 00000 n 
-0001236643 00000 n 
-0001236857 00000 n 
-0001237070 00000 n 
-0001237128 00000 n 
-0001238230 00000 n 
-0001238486 00000 n 
-0001238544 00000 n 
-0001251909 00000 n 
-0001252189 00000 n 
-0001252246 00000 n 
-0001252460 00000 n 
-0001252716 00000 n 
-0001268184 00000 n 
-0001268472 00000 n 
-0001268743 00000 n 
-0001268801 00000 n 
-0001269004 00000 n 
-0001269259 00000 n 
-0001285521 00000 n 
-0001285788 00000 n 
-0001286092 00000 n 
-0001286362 00000 n 
-0001296178 00000 n 
-0001296419 00000 n 
-0001296465 00000 n 
-0001307191 00000 n 
-0001307466 00000 n 
-0001307512 00000 n 
-0001307721 00000 n 
-0001307931 00000 n 
-0001308158 00000 n 
-0001308215 00000 n 
-0001308273 00000 n 
-0001313363 00000 n 
-0001313622 00000 n 
-0001313668 00000 n 
-0001313884 00000 n 
-0001313941 00000 n 
-0001329348 00000 n 
-0001329628 00000 n 
-0001329674 00000 n 
-0001329731 00000 n 
-0001329984 00000 n 
-0001330203 00000 n 
-0001330260 00000 n 
-0001330912 00000 n 
-0001335074 00000 n 
-0001335346 00000 n 
-0001335392 00000 n 
-0001335609 00000 n 
-0001348884 00000 n 
-0001349188 00000 n 
-0001349234 00000 n 
-0001349457 00000 n 
-0001349652 00000 n 
-0001349842 00000 n 
-0001349888 00000 n 
-0001350083 00000 n 
-0001350280 00000 n 
-0001350338 00000 n 
-0001350396 00000 n 
-0001359406 00000 n 
-0001359647 00000 n 
-0001359693 00000 n 
-0001374557 00000 n 
-0001374872 00000 n 
-0001374918 00000 n 
-0001375129 00000 n 
-0001375327 00000 n 
-0001375527 00000 n 
-0001375728 00000 n 
-0001375967 00000 n 
-0001376176 00000 n 
-0001376233 00000 n 
-0001376473 00000 n 
-0001376707 00000 n 
-0001376765 00000 n 
-0001389765 00000 n 
-0001390051 00000 n 
-0001390229 00000 n 
-0001390287 00000 n 
-0001401157 00000 n 
-0001401432 00000 n 
-0001401478 00000 n 
-0001401700 00000 n 
-0001401916 00000 n 
-0001402141 00000 n 
-0001402198 00000 n 
-0001402255 00000 n 
-0001412676 00000 n 
-0001412904 00000 n 
-0001425309 00000 n 
-0001425537 00000 n 
-0001434728 00000 n 
-0001434982 00000 n 
-0001435039 00000 n 
-0001443028 00000 n 
-0001443269 00000 n 
-0001452737 00000 n 
-0001452996 00000 n 
-0001453054 00000 n 
-0001453296 00000 n 
-0001462820 00000 n 
-0001463048 00000 n 
-0001475938 00000 n 
-0001476229 00000 n 
-0001476275 00000 n 
-0001476333 00000 n 
-0001476539 00000 n 
-0001476790 00000 n 
-0001477037 00000 n 
-0001477244 00000 n 
-0001477477 00000 n 
-0001486829 00000 n 
-0001487096 00000 n 
-0001487142 00000 n 
-0001487199 00000 n 
-0001487409 00000 n 
-0001487466 00000 n 
-0001487699 00000 n 
-0001510193 00000 n 
-0001510421 00000 n 
-0001522993 00000 n 
-0001523268 00000 n 
-0001523325 00000 n 
-0001523782 00000 n 
-0001523993 00000 n 
-0001524051 00000 n 
-0001524109 00000 n 
-0001524635 00000 n 
-0001524876 00000 n 
-0001525099 00000 n 
-0001537776 00000 n 
-0001538017 00000 n 
-0001538063 00000 n 
-0001556994 00000 n 
-0001557306 00000 n 
-0001557352 00000 n 
-0001557550 00000 n 
-0001557607 00000 n 
-0001557859 00000 n 
-0001557916 00000 n 
-0001558133 00000 n 
-0001558338 00000 n 
-0001558546 00000 n 
-0001558603 00000 n 
-0001558817 00000 n 
-0001569278 00000 n 
-0001569545 00000 n 
-0001569786 00000 n 
-0001570002 00000 n 
-0001582760 00000 n 
-0001583051 00000 n 
-0001583097 00000 n 
-0001583154 00000 n 
-0001583211 00000 n 
-0001583396 00000 n 
-0001583453 00000 n 
-0001583716 00000 n 
-0001583773 00000 n 
-0001583975 00000 n 
-0001584197 00000 n 
-0001584414 00000 n 
-0001596342 00000 n 
-0001596601 00000 n 
-0001596807 00000 n 
-0001596853 00000 n 
-0001600730 00000 n 
-0001600997 00000 n 
-0001601043 00000 n 
-0001601258 00000 n 
-0001601463 00000 n 
-0001611717 00000 n 
-0001612026 00000 n 
-0001612072 00000 n 
-0001612261 00000 n 
-0001612318 00000 n 
-0001612557 00000 n 
-0001612808 00000 n 
-0001612866 00000 n 
-0001613084 00000 n 
-0001613141 00000 n 
-0001620573 00000 n 
-0001620827 00000 n 
-0001620873 00000 n 
-0001631834 00000 n 
-0001632106 00000 n 
-0001632152 00000 n 
-0001632611 00000 n 
-0001632857 00000 n 
-0001632903 00000 n 
-0001632961 00000 n 
-0001645106 00000 n 
-0001645391 00000 n 
-0001645592 00000 n 
-0001645649 00000 n 
-0001657529 00000 n 
-0001657814 00000 n 
-0001657860 00000 n 
-0001657917 00000 n 
-0001658115 00000 n 
-0001658173 00000 n 
-0001660585 00000 n 
-0001660813 00000 n 
-0001660933 00000 n 
-0001661054 00000 n 
-0001661179 00000 n 
-0001661305 00000 n 
-0001661451 00000 n 
-0001661599 00000 n 
-0001661732 00000 n 
-0001661867 00000 n 
-0001662001 00000 n 
-0001662137 00000 n 
-0001662290 00000 n 
-0001662444 00000 n 
-0001662595 00000 n 
-0001662748 00000 n 
-0001662896 00000 n 
-0001663045 00000 n 
-0001663196 00000 n 
-0001663338 00000 n 
-0001663499 00000 n 
-0001663653 00000 n 
-0001663811 00000 n 
-0001663971 00000 n 
-0001664148 00000 n 
-0001664326 00000 n 
-0001664511 00000 n 
-0001664698 00000 n 
-0001664884 00000 n 
-0001665072 00000 n 
-0001665246 00000 n 
-0001665422 00000 n 
-0001665606 00000 n 
-0001665801 00000 n 
-0001665997 00000 n 
-0001666193 00000 n 
-0001666377 00000 n 
-0001666563 00000 n 
-0001666739 00000 n 
-0001666917 00000 n 
-0001667086 00000 n 
-0001667257 00000 n 
-0001667437 00000 n 
-0001667619 00000 n 
-0001667795 00000 n 
-0001667981 00000 n 
-0001668180 00000 n 
-0001668379 00000 n 
-0001668558 00000 n 
-0001668739 00000 n 
-0001668902 00000 n 
-0001669067 00000 n 
-0001669224 00000 n 
-0001669383 00000 n 
-0001669558 00000 n 
-0001669733 00000 n 
-0001669883 00000 n 
-0001670043 00000 n 
-0001670190 00000 n 
-0001670348 00000 n 
-0001670519 00000 n 
-0001670690 00000 n 
-0001670843 00000 n 
-0001671006 00000 n 
-0001671151 00000 n 
-0001671307 00000 n 
-0001671456 00000 n 
-0001671615 00000 n 
-0001671772 00000 n 
-0001671939 00000 n 
-0001672085 00000 n 
-0001672241 00000 n 
-0001672411 00000 n 
-0001672581 00000 n 
-0001672735 00000 n 
-0001672899 00000 n 
-0001673048 00000 n 
-0001673208 00000 n 
-0001673344 00000 n 
-0001673490 00000 n 
-0001673679 00000 n 
-0001673868 00000 n 
-0001674034 00000 n 
-0001674200 00000 n 
-0001674350 00000 n 
-0001674510 00000 n 
-0001674671 00000 n 
-0001674832 00000 n 
-0001674999 00000 n 
-0001675166 00000 n 
-0001675306 00000 n 
-0001675456 00000 n 
-0001675626 00000 n 
-0001675807 00000 n 
-0001675957 00000 n 
-0001676117 00000 n 
-0001676264 00000 n 
-0001676421 00000 n 
-0001676570 00000 n 
-0001676721 00000 n 
-0001676909 00000 n 
-0001677097 00000 n 
-0001677247 00000 n 
-0001677407 00000 n 
-0001677556 00000 n 
-0001677715 00000 n 
-0001677867 00000 n 
-0001678019 00000 n 
-0001678185 00000 n 
-0001678363 00000 n 
-0001678511 00000 n 
-0001678670 00000 n 
-0001678826 00000 n 
-0001678992 00000 n 
-0001679162 00000 n 
-0001679332 00000 n 
-0001679500 00000 n 
-0001679668 00000 n 
-0001679827 00000 n 
-0001679998 00000 n 
-0001680155 00000 n 
-0001680315 00000 n 
-0001680474 00000 n 
-0001680636 00000 n 
-0001680815 00000 n 
-0001680994 00000 n 
-0001681149 00000 n 
-0001681306 00000 n 
-0001681495 00000 n 
-0001681697 00000 n 
-0001681885 00000 n 
-0001682075 00000 n 
-0001682276 00000 n 
-0001682485 00000 n 
-0001682650 00000 n 
-0001682825 00000 n 
-0001682987 00000 n 
-0001683159 00000 n 
-0001683324 00000 n 
-0001683489 00000 n 
-0001683654 00000 n 
-0001683832 00000 n 
-0001684007 00000 n 
-0001684158 00000 n 
-0001684320 00000 n 
-0001684496 00000 n 
-0001684674 00000 n 
-0001684835 00000 n 
-0001685006 00000 n 
-0001685157 00000 n 
-0001685318 00000 n 
-0001685461 00000 n 
-0001685615 00000 n 
-0001685786 00000 n 
-0001685957 00000 n 
-0001686124 00000 n 
-0001686291 00000 n 
-0001686578 00000 n 
-0001686656 00000 n 
-0001686833 00000 n 
-0001687025 00000 n 
-0001687290 00000 n 
-0001687465 00000 n 
-0001687726 00000 n 
-0001687907 00000 n 
-0001688092 00000 n 
-0001688377 00000 n 
-0001688586 00000 n 
-0001688793 00000 n 
-0001688972 00000 n 
-0001689185 00000 n 
-0001689450 00000 n 
-0001689655 00000 n 
-0001689910 00000 n 
-0001690166 00000 n 
-0001690377 00000 n 
-0001690618 00000 n 
-0001690859 00000 n 
-0001691067 00000 n 
-0001691222 00000 n 
-0001691496 00000 n 
-0001691678 00000 n 
-0001691887 00000 n 
-0001692136 00000 n 
-0001692389 00000 n 
-0001692622 00000 n 
-0001692820 00000 n 
-0001693119 00000 n 
-0001693313 00000 n 
-0001693514 00000 n 
-0001693755 00000 n 
-0001693984 00000 n 
-0001694173 00000 n 
-0001694386 00000 n 
-0001694622 00000 n 
-0001694814 00000 n 
-0001695062 00000 n 
+0001205607 00000 n 
+0001205874 00000 n 
+0001205931 00000 n 
+0001206149 00000 n 
+0001206364 00000 n 
+0001206421 00000 n 
+0001206880 00000 n 
+0001206938 00000 n 
+0001221434 00000 n 
+0001221693 00000 n 
+0001221739 00000 n 
+0001222009 00000 n 
+0001222067 00000 n 
+0001222125 00000 n 
+0001235735 00000 n 
+0001236034 00000 n 
+0001236233 00000 n 
+0001236290 00000 n 
+0001236535 00000 n 
+0001236764 00000 n 
+0001236822 00000 n 
+0001236880 00000 n 
+0001237094 00000 n 
+0001237307 00000 n 
+0001237365 00000 n 
+0001238467 00000 n 
+0001238723 00000 n 
+0001238781 00000 n 
+0001252146 00000 n 
+0001252426 00000 n 
+0001252483 00000 n 
+0001252697 00000 n 
+0001252953 00000 n 
+0001268421 00000 n 
+0001268709 00000 n 
+0001268980 00000 n 
+0001269038 00000 n 
+0001269241 00000 n 
+0001269496 00000 n 
+0001285758 00000 n 
+0001286025 00000 n 
+0001286329 00000 n 
+0001286599 00000 n 
+0001296415 00000 n 
+0001296656 00000 n 
+0001296702 00000 n 
+0001307428 00000 n 
+0001307703 00000 n 
+0001307749 00000 n 
+0001307958 00000 n 
+0001308168 00000 n 
+0001308395 00000 n 
+0001308452 00000 n 
+0001308510 00000 n 
+0001313600 00000 n 
+0001313859 00000 n 
+0001313905 00000 n 
+0001314121 00000 n 
+0001314178 00000 n 
+0001329585 00000 n 
+0001329865 00000 n 
+0001329911 00000 n 
+0001329968 00000 n 
+0001330221 00000 n 
+0001330440 00000 n 
+0001330497 00000 n 
+0001331149 00000 n 
+0001335311 00000 n 
+0001335583 00000 n 
+0001335629 00000 n 
+0001335846 00000 n 
+0001349121 00000 n 
+0001349425 00000 n 
+0001349471 00000 n 
+0001349694 00000 n 
+0001349889 00000 n 
+0001350079 00000 n 
+0001350125 00000 n 
+0001350320 00000 n 
+0001350517 00000 n 
+0001350575 00000 n 
+0001350633 00000 n 
+0001359643 00000 n 
+0001359884 00000 n 
+0001359930 00000 n 
+0001374794 00000 n 
+0001375109 00000 n 
+0001375155 00000 n 
+0001375366 00000 n 
+0001375564 00000 n 
+0001375764 00000 n 
+0001375965 00000 n 
+0001376204 00000 n 
+0001376413 00000 n 
+0001376470 00000 n 
+0001376710 00000 n 
+0001376944 00000 n 
+0001377002 00000 n 
+0001390002 00000 n 
+0001390288 00000 n 
+0001390466 00000 n 
+0001390524 00000 n 
+0001401394 00000 n 
+0001401669 00000 n 
+0001401715 00000 n 
+0001401937 00000 n 
+0001402153 00000 n 
+0001402378 00000 n 
+0001402435 00000 n 
+0001402492 00000 n 
+0001412913 00000 n 
+0001413141 00000 n 
+0001425546 00000 n 
+0001425774 00000 n 
+0001434965 00000 n 
+0001435219 00000 n 
+0001435276 00000 n 
+0001443265 00000 n 
+0001443506 00000 n 
+0001452974 00000 n 
+0001453233 00000 n 
+0001453291 00000 n 
+0001453533 00000 n 
+0001463057 00000 n 
+0001463285 00000 n 
+0001476175 00000 n 
+0001476466 00000 n 
+0001476512 00000 n 
+0001476570 00000 n 
+0001476776 00000 n 
+0001477027 00000 n 
+0001477274 00000 n 
+0001477481 00000 n 
+0001477714 00000 n 
+0001487066 00000 n 
+0001487333 00000 n 
+0001487379 00000 n 
+0001487436 00000 n 
+0001487646 00000 n 
+0001487703 00000 n 
+0001487936 00000 n 
+0001510430 00000 n 
+0001510658 00000 n 
+0001523230 00000 n 
+0001523505 00000 n 
+0001523562 00000 n 
+0001524019 00000 n 
+0001524230 00000 n 
+0001524288 00000 n 
+0001524346 00000 n 
+0001524872 00000 n 
+0001525113 00000 n 
+0001525336 00000 n 
+0001538013 00000 n 
+0001538254 00000 n 
+0001538300 00000 n 
+0001557231 00000 n 
+0001557543 00000 n 
+0001557589 00000 n 
+0001557787 00000 n 
+0001557844 00000 n 
+0001558096 00000 n 
+0001558153 00000 n 
+0001558370 00000 n 
+0001558575 00000 n 
+0001558783 00000 n 
+0001558840 00000 n 
+0001559054 00000 n 
+0001569515 00000 n 
+0001569782 00000 n 
+0001570023 00000 n 
+0001570239 00000 n 
+0001582997 00000 n 
+0001583288 00000 n 
+0001583334 00000 n 
+0001583391 00000 n 
+0001583448 00000 n 
+0001583633 00000 n 
+0001583690 00000 n 
+0001583953 00000 n 
+0001584010 00000 n 
+0001584212 00000 n 
+0001584434 00000 n 
+0001584651 00000 n 
+0001596579 00000 n 
+0001596838 00000 n 
+0001597044 00000 n 
+0001597090 00000 n 
+0001600967 00000 n 
+0001601234 00000 n 
+0001601280 00000 n 
+0001601495 00000 n 
+0001601700 00000 n 
+0001611954 00000 n 
+0001612263 00000 n 
+0001612309 00000 n 
+0001612498 00000 n 
+0001612555 00000 n 
+0001612794 00000 n 
+0001613045 00000 n 
+0001613103 00000 n 
+0001613321 00000 n 
+0001613378 00000 n 
+0001620810 00000 n 
+0001621064 00000 n 
+0001621110 00000 n 
+0001632071 00000 n 
+0001632343 00000 n 
+0001632389 00000 n 
+0001632848 00000 n 
+0001633094 00000 n 
+0001633140 00000 n 
+0001633198 00000 n 
+0001645343 00000 n 
+0001645628 00000 n 
+0001645829 00000 n 
+0001645886 00000 n 
+0001657766 00000 n 
+0001658051 00000 n 
+0001658097 00000 n 
+0001658154 00000 n 
+0001658352 00000 n 
+0001658410 00000 n 
+0001660822 00000 n 
+0001661050 00000 n 
+0001661170 00000 n 
+0001661291 00000 n 
+0001661416 00000 n 
+0001661542 00000 n 
+0001661688 00000 n 
+0001661836 00000 n 
+0001661969 00000 n 
+0001662104 00000 n 
+0001662238 00000 n 
+0001662374 00000 n 
+0001662527 00000 n 
+0001662681 00000 n 
+0001662832 00000 n 
+0001662985 00000 n 
+0001663133 00000 n 
+0001663282 00000 n 
+0001663433 00000 n 
+0001663575 00000 n 
+0001663736 00000 n 
+0001663890 00000 n 
+0001664048 00000 n 
+0001664208 00000 n 
+0001664385 00000 n 
+0001664563 00000 n 
+0001664748 00000 n 
+0001664935 00000 n 
+0001665121 00000 n 
+0001665309 00000 n 
+0001665483 00000 n 
+0001665659 00000 n 
+0001665843 00000 n 
+0001666038 00000 n 
+0001666234 00000 n 
+0001666430 00000 n 
+0001666614 00000 n 
+0001666800 00000 n 
+0001666976 00000 n 
+0001667154 00000 n 
+0001667323 00000 n 
+0001667494 00000 n 
+0001667674 00000 n 
+0001667856 00000 n 
+0001668032 00000 n 
+0001668218 00000 n 
+0001668417 00000 n 
+0001668616 00000 n 
+0001668795 00000 n 
+0001668976 00000 n 
+0001669139 00000 n 
+0001669304 00000 n 
+0001669461 00000 n 
+0001669620 00000 n 
+0001669795 00000 n 
+0001669970 00000 n 
+0001670120 00000 n 
+0001670280 00000 n 
+0001670427 00000 n 
+0001670585 00000 n 
+0001670756 00000 n 
+0001670927 00000 n 
+0001671080 00000 n 
+0001671243 00000 n 
+0001671388 00000 n 
+0001671544 00000 n 
+0001671693 00000 n 
+0001671852 00000 n 
+0001672009 00000 n 
+0001672176 00000 n 
+0001672322 00000 n 
+0001672478 00000 n 
+0001672648 00000 n 
+0001672818 00000 n 
+0001672972 00000 n 
+0001673136 00000 n 
+0001673285 00000 n 
+0001673445 00000 n 
+0001673581 00000 n 
+0001673727 00000 n 
+0001673916 00000 n 
+0001674105 00000 n 
+0001674271 00000 n 
+0001674437 00000 n 
+0001674587 00000 n 
+0001674747 00000 n 
+0001674908 00000 n 
+0001675069 00000 n 
+0001675236 00000 n 
+0001675403 00000 n 
+0001675543 00000 n 
+0001675693 00000 n 
+0001675863 00000 n 
+0001676044 00000 n 
+0001676194 00000 n 
+0001676354 00000 n 
+0001676501 00000 n 
+0001676658 00000 n 
+0001676807 00000 n 
+0001676958 00000 n 
+0001677146 00000 n 
+0001677334 00000 n 
+0001677484 00000 n 
+0001677644 00000 n 
+0001677793 00000 n 
+0001677952 00000 n 
+0001678104 00000 n 
+0001678256 00000 n 
+0001678422 00000 n 
+0001678600 00000 n 
+0001678748 00000 n 
+0001678907 00000 n 
+0001679063 00000 n 
+0001679229 00000 n 
+0001679399 00000 n 
+0001679569 00000 n 
+0001679737 00000 n 
+0001679905 00000 n 
+0001680064 00000 n 
+0001680235 00000 n 
+0001680392 00000 n 
+0001680552 00000 n 
+0001680711 00000 n 
+0001680873 00000 n 
+0001681052 00000 n 
+0001681231 00000 n 
+0001681386 00000 n 
+0001681543 00000 n 
+0001681732 00000 n 
+0001681934 00000 n 
+0001682122 00000 n 
+0001682312 00000 n 
+0001682513 00000 n 
+0001682722 00000 n 
+0001682887 00000 n 
+0001683062 00000 n 
+0001683224 00000 n 
+0001683396 00000 n 
+0001683561 00000 n 
+0001683726 00000 n 
+0001683891 00000 n 
+0001684069 00000 n 
+0001684244 00000 n 
+0001684395 00000 n 
+0001684557 00000 n 
+0001684733 00000 n 
+0001684911 00000 n 
+0001685072 00000 n 
+0001685243 00000 n 
+0001685394 00000 n 
+0001685555 00000 n 
+0001685698 00000 n 
+0001685852 00000 n 
+0001686023 00000 n 
+0001686194 00000 n 
+0001686361 00000 n 
+0001686528 00000 n 
+0001686815 00000 n 
+0001686893 00000 n 
+0001687070 00000 n 
+0001687262 00000 n 
+0001687527 00000 n 
+0001687702 00000 n 
+0001687963 00000 n 
+0001688144 00000 n 
+0001688329 00000 n 
+0001688614 00000 n 
+0001688823 00000 n 
+0001689030 00000 n 
+0001689209 00000 n 
+0001689422 00000 n 
+0001689687 00000 n 
+0001689892 00000 n 
+0001690147 00000 n 
+0001690403 00000 n 
+0001690614 00000 n 
+0001690855 00000 n 
+0001691096 00000 n 
+0001691304 00000 n 
+0001691459 00000 n 
+0001691733 00000 n 
+0001691915 00000 n 
+0001692124 00000 n 
+0001692373 00000 n 
+0001692626 00000 n 
+0001692859 00000 n 
+0001693057 00000 n 
+0001693356 00000 n 
+0001693550 00000 n 
+0001693751 00000 n 
+0001693992 00000 n 
+0001694221 00000 n 
+0001694410 00000 n 
+0001694623 00000 n 
+0001694859 00000 n 
+0001695051 00000 n 
 0001695299 00000 n 
-0001695519 00000 n 
-0001695728 00000 n 
-0001695975 00000 n 
-0001696281 00000 n 
-0001696475 00000 n 
-0001696696 00000 n 
-0001696929 00000 n 
-0001697091 00000 n 
-0001697357 00000 n 
-0001697551 00000 n 
-0001697755 00000 n 
-0001697910 00000 n 
-0001698172 00000 n 
-0001698355 00000 n 
-0001698560 00000 n 
-0001698731 00000 n 
-0001699009 00000 n 
-0001699211 00000 n 
-0001699464 00000 n 
-0001699715 00000 n 
-0001699973 00000 n 
-0001700219 00000 n 
-0001700435 00000 n 
-0001700663 00000 n 
-0001700956 00000 n 
-0001701149 00000 n 
-0001701494 00000 n 
-0001701817 00000 n 
-0001702119 00000 n 
-0001702373 00000 n 
-0001702605 00000 n 
-0001702823 00000 n 
-0001703057 00000 n 
-0001703271 00000 n 
-0001703457 00000 n 
-0001703697 00000 n 
-0001703871 00000 n 
-0001704128 00000 n 
-0001704355 00000 n 
-0001705068 00000 n 
-0001715214 00000 n 
-0001715430 00000 n 
-0001716793 00000 n 
-0001717837 00000 n 
-0001726652 00000 n 
-0001726873 00000 n 
-0001728236 00000 n 
-0001729301 00000 n 
-0001730750 00000 n 
-0001730961 00000 n 
-0001731281 00000 n 
-0001732197 00000 n 
-0001738218 00000 n 
-0001738432 00000 n 
-0001739795 00000 n 
-0001740841 00000 n 
-0001742514 00000 n 
-0001742728 00000 n 
-0001743040 00000 n 
-0001744178 00000 n 
-0001745573 00000 n 
-0001745791 00000 n 
-0001747154 00000 n 
-0001748293 00000 n 
-0001750791 00000 n 
-0001751017 00000 n 
-0001752380 00000 n 
+0001695536 00000 n 
+0001695756 00000 n 
+0001695965 00000 n 
+0001696212 00000 n 
+0001696518 00000 n 
+0001696712 00000 n 
+0001696933 00000 n 
+0001697166 00000 n 
+0001697328 00000 n 
+0001697594 00000 n 
+0001697788 00000 n 
+0001697992 00000 n 
+0001698147 00000 n 
+0001698409 00000 n 
+0001698592 00000 n 
+0001698797 00000 n 
+0001698968 00000 n 
+0001699246 00000 n 
+0001699448 00000 n 
+0001699701 00000 n 
+0001699952 00000 n 
+0001700210 00000 n 
+0001700456 00000 n 
+0001700672 00000 n 
+0001700900 00000 n 
+0001701193 00000 n 
+0001701386 00000 n 
+0001701731 00000 n 
+0001702054 00000 n 
+0001702356 00000 n 
+0001702610 00000 n 
+0001702842 00000 n 
+0001703060 00000 n 
+0001703294 00000 n 
+0001703508 00000 n 
+0001703694 00000 n 
+0001703934 00000 n 
+0001704108 00000 n 
+0001704365 00000 n 
+0001704592 00000 n 
+0001705305 00000 n 
+0001715451 00000 n 
+0001715667 00000 n 
+0001717030 00000 n 
+0001718074 00000 n 
+0001726889 00000 n 
+0001727110 00000 n 
+0001728473 00000 n 
+0001729538 00000 n 
+0001730987 00000 n 
+0001731198 00000 n 
+0001731518 00000 n 
+0001732434 00000 n 
+0001738455 00000 n 
+0001738669 00000 n 
+0001740032 00000 n 
+0001741078 00000 n 
+0001742751 00000 n 
+0001742965 00000 n 
+0001743277 00000 n 
+0001744415 00000 n 
+0001745810 00000 n 
+0001746028 00000 n 
+0001747391 00000 n 
+0001748530 00000 n 
+0001751028 00000 n 
+0001751254 00000 n 
+0001752617 00000 n 
 trailer
 << /Size 764
 /Root 2 0 R
 /Info 1 0 R
 >>
 startxref
-1753503
+1753740
 %%EOF


[3/3] isis-site git commit: ISIS-1521: fixes links in template email to announce release

Posted by da...@apache.org.
ISIS-1521: fixes links in template email to announce release


Project: http://git-wip-us.apache.org/repos/asf/isis-site/repo
Commit: http://git-wip-us.apache.org/repos/asf/isis-site/commit/caac5e5c
Tree: http://git-wip-us.apache.org/repos/asf/isis-site/tree/caac5e5c
Diff: http://git-wip-us.apache.org/repos/asf/isis-site/diff/caac5e5c

Branch: refs/heads/asf-site
Commit: caac5e5c54f399d1710579f4ab23808fc08e5a25
Parents: e8832fc
Author: Dan Haywood <da...@haywood-associates.co.uk>
Authored: Tue Aug 15 06:52:54 2017 +0100
Committer: Dan Haywood <da...@haywood-associates.co.uk>
Committed: Tue Aug 15 06:52:54 2017 +0100

----------------------------------------------------------------------
 content/elasticlunr/index.json  |    2 +-
 content/guides/cgcom/cgcom.html |    4 +-
 content/guides/cgcom/cgcom.pdf  | 1389 +++++++++++++++++-----------------
 3 files changed, 703 insertions(+), 692 deletions(-)
----------------------------------------------------------------------



[2/3] isis-site git commit: ISIS-1521: fixes links in template email to announce release

Posted by da...@apache.org.
http://git-wip-us.apache.org/repos/asf/isis-site/blob/caac5e5c/content/elasticlunr/index.json
----------------------------------------------------------------------
diff --git a/content/elasticlunr/index.json b/content/elasticlunr/index.json
index 3b19667..94d72b0 100644
--- a/content/elasticlunr/index.json
+++ b/content/elasticlunr/index.json
@@ -1 +1 @@
-{"version":"0.9.5","fields":["title","body","description","url"],"ref":"id","documentStore":{"docs":{"372886":{"title":"Rows, full-width cols, and tabs","url":"guides/ugvw/ugvw.html#_rows_full_width_cols_and_tabs","body":"Rows, full-width cols, and tabs  The example layout consists of three rows: a row for the object/icon, a row containing a properties, and a row containing collections. In all three cases the row contains a single column spanning the full width of the page. For the property and collection rows, the column contains a tab group.  This corresponds to the following XML:  You will notice that one of the columns has an unreferencedActions attribute, while one of the tabGroups has a similar unreferencedCollections attribute. This topic is discussed in more detail below. ","description":" The example layout consists of three rows: a row for the object/icon, a row containing a properties, and a row containing collections. In all three cases the row contains a single column s
 panning the full width of the page. For the property and collection rows, the column contains a","id":372886},"2646929":{"title":"Apache Isis vs …​","url":"guides/ugfun/ugfun.html#_ugfun_core-concepts_apache-isis-vs","body":"Apache Isis vs …​  Many other frameworks promise rapid application development and provide automatically generated user interfaces, so how do they compare to Apache Isis? ","description":" Many other frameworks promise rapid application development and provide automatically generated user interfaces, so how do they compare to Apache Isis? ","id":2646929},"3836440":{"title":"Running","url":"guides/dg/dg.html#__dg_ide_intellij_running","body":"Running  Let’s see how to run both the app and the tests. ","description":" Let’s see how to run both the app and the tests. ","id":3836440},"11600575":{"title":"Using Contributions","url":"pages/tg/tg.html#_using_contributions","body":"Using Contributions  One of Apache Isis' most powerful features is the abilit
 y for the UI to combine functionality from domain services into the representation of an entity. The effect is similar to traits or mix-ins in other languages, however the \"mixing in\" is done at runtime, within the Apache Isis metamodel. In Apache Isis' terminology, we say that the domain service action is contributed to the entity.  Any action of a domain service that has a domain entity type as one of its parameter types will (by default) be contributed. If the service action takes more than one argument, or does not have safe semantics, then it will be contributed as an entity action. If the service action has precisely one parameter type (that of the entity) and has safe semantics then it will be contributed either as a collection or as a property (dependent on whether it returns a collection of a scalar).  Why are contributions so useful? Because the service action will match not on the entity type, but also on any of the entity’s supertypes (all the way up to java.lang.Obj
 ect). That means that you can apply the dependency inversion principle to ensure that the modules of your application have acyclic dependencies; but in the UI it can still appear as if there are bidirectional dependencies between those modules. The lack of bidirectional dependencies can help save your app degrading into a big ball of mud.  Finally, note that the layout of contributed actions/collections/properties can be specified using the .layout.json file (and it is highly recommended that you do so). ","description":" One of Apache Isis' most powerful features is the ability for the UI to combine functionality from domain services into the representation of an entity. The effect is similar to traits or mix-ins in other languages, however the \"mixing in\" is done at runtime, within the Apache Isis metamodel","id":11600575},"12649581":{"title":"Mark the version as released","url":"guides/cgcom/cgcom.html#_mark_the_version_as_released","body":"Mark the version as released  In JIRA
 , go to the administration section for the Apache Isis project and update the version as being released.  In the Kanban view this will have the effect of marking all tickets as released (clearing the \"done\" column). ","description":" In JIRA, go to the administration section for the Apache Isis project and update the version as being released. ","id":12649581},"13573617":{"title":"hide…​()","url":"guides/rgcms/rgcms.html#_rgcms_methods_prefixes_hide","body":"hide…​()  The hide…​() supporting method is called for properties, collections and actions. It allows the property/collection to be completely hidden from view.  It’s comparatively rare for properties or collections to be imperatively hidden from view, but actions are sometimes hidden or shown visible (as opposed to being just disabled, ie greyed out).  The signature of the supporting method is simply:  Returning true will hide the property, collection or action, returning false leaves it visible.  For example, t
 o hide an action:  Or, to hide a property: ","description":" The hide…​() supporting method is called for properties, collections and actions. It allows the property/collection to be completely hidden from view. ","id":13573617},"14971197":{"title":"Suppressing 'remember me'","url":"guides/ugvw/ugvw.html#_ugvw_configuration-properties_suppressing-remember-me","body":"Suppressing 'remember me'  The 'remember me' checkbox on the login page can be suppressed, if required, by setting a configuration flag. ","description":" The 'remember me' checkbox on the login page can be suppressed, if required, by setting a configuration flag. ","id":14971197},"16629694":{"title":"allowLateRegistration","url":"migration-notes/migration-notes.html#__code_allowlateregistration_code","body":"allowLateRegistration  One possible issue is that (as per ISIS-830) the EventBusService is now initialized as one of the first domain services; this is to ensure that any object lifecycle events caused by domai
 n services initializing themselves can be posted on the event bus for subscribers. The typical case for such lifecycle events to occur is from domain services that seed reference data; one such example can be found in the (non-ASF) Isis addons' security module.  In previous releases, the ordering of initialization for the EventBusService was undefined (but would typically be towards the \"end\" of the list of services. What this meant in practice is that it generally didn’t matter whether (domain service) subscribers were initialized before or after seed services.  Now, though, because the EventBusService is initialized early on, it proactively checks that all subscribers have been registered before any event posts occur (so that no events get missed). If any subscriber attempts to register after at least one event has been posted, then the service will fail fast and the framework will not start. The error looks something like:  To ensure that subscriber domain services are initia
 lized before \"seed\" domain services, the @DomainServiceLayout#menuOrder() attribute can be used. Normally this attribute is just used to order UI-visible services on the menu bars, but it also is used internally to sequence the internal list of services being initialized.  Alternatively, you can disable this checking within the EventBusService using:  If you do that, be aware that not all subscribers may not receive some events generated by other domain services.  For more details, see the EventBusService man page. ","description":" One possible issue is that (as per ISIS-830) the EventBusService is now initialized as one of the first domain services; this is to ensure that any object lifecycle events caused by domain services initializing themselves can be posted on the event bus for subscribers. The typical case for such","id":16629694},"17000573":{"title":"ObjectCreatedEvent","url":"guides/rgcms/rgcms.html#_rgcms_classes_lifecycleevent_ObjectCreatedEvent","body":"ObjectCreatedE
 vent  Subclass of AbstractLifecycleEvent, broadcast when an object is first instantiated using the DomainObjectContainer's #newTransientInstance(…​) method.  ObjectCreatedEvent.Default is the concrete implementation that is used. ","description":" Subclass of AbstractLifecycleEvent, broadcast when an object is first instantiated using the DomainObjectContainer's #newTransientInstance(…​) method. ","id":17000573},"17618894":{"title":"New Feature","url":"release-notes/release-notes.html#_new_feature_20","body":"New Feature ","description":"","id":17618894},"17724516":{"title":"Multi-select action parameters","url":"guides/ugfun/ugfun.html#_multi_select_action_parameters","body":"Multi-select action parameters  As well as scalar values, action parameters can also be collections. For this to be valid, a choices or autoComplete supporting method must be provided.  For example, suppose we want to \"tag\" or \"label\" an object: ","description":" As well as scalar values, action pa
 rameters can also be collections. For this to be valid, a choices or autoComplete supporting method must be provided. ","id":17724516},"18445041":{"title":"Verifying Releases","url":"downloads.html#_verifying_releases","body":"Verifying Releases ","description":"","id":18445041},"19254915":{"title":"API & Implementation","url":"guides/rgsvc/rgsvc.html#_api_implementation_7","body":"API & Implementation  The API of Scratchpad service is:  This class (o.a.i.applib.services.scratchpad.Scratchpad) is also the implementation. And, as you can see, the service is just a request-scoped wrapper around a java.util.Map. ","description":" The API of Scratchpad service is: ","id":19254915},"21190750":{"title":"Run the archetype","url":"pages/tg/tg.html#_run_the_archetype","body":"Run the archetype  Throughout this tutorial you can, if you wish, just checkout from the github repo wherever you see a \"git checkout\" note:  Run the simpleapp archetype to build an empty Isis application. With the *n
 ix bash shell, use:  Adjust as necessary if using Windows cmd.exe or Powershell.  This will generate the app in a petclinic directory. Move the contents back: ","description":" Throughout this tutorial you can, if you wish, just checkout from the github repo wherever you see a \"git checkout\" note: ","id":21190750},"21212015":{"title":"Key features","url":"pages/powered-by/powered-by.html#_key_features","body":"Key features ","description":"","id":21212015},"21857601":{"title":"Other Guides","url":"guides/cgcom/cgcom.html#_other_guides","body":"Other Guides  Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides.  The user guides available are:  The reference guides are:  The remaining guides are:  This guide provides guidance for Apache Isis' own committers. ","description":" Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides. ","id":21857601},"23125949":{"title":"Edit
 ing","url":"guides/dg/dg.html#__dg_ide_intellij_hints-and-tips_editing","body":"Editing ","description":"","id":23125949},"23524101":{"title":"Collections","url":"guides/ugvw/ugvw.html#_collections","body":"Collections  In the final row the collections are placed in tabs, simply one collection per tab. This corresponds to the following XML:  As with properties, actions can be associated with collections; this indicates that they should be rendered in the collection’s header. ","description":" In the final row the collections are placed in tabs, simply one collection per tab. This corresponds to the following XML: ","id":23524101},"26509816":{"title":"Commit changes","url":"guides/cgcom/cgcom.html#__cgcom_cutting-a-release_releasing-core_commit-changes","body":"Commit changes  Commit any changes from the preceding steps: ","description":" Commit any changes from the preceding steps: ","id":26509816},"27806498":{"title":"renderedAsDayBefore()","url":"guides/rgant/rgant.html#_rgant-P
 arameterLayout_renderedAsDayBefore","body":"renderedAsDayBefore()  The renderedAsDayBefore() attribute applies only to date parameters whereby the date will be rendered as the day before the value actually held in the domain object. It is ignored for parameters of other types. This attribute is also supported for properties.  This behaviour might at first glance appear odd, but the rationale is to support the use case of a sequence of instances that represent adjacent intervals of time. In such cases there would typically be startDate and endDate properties, eg for all of Q2. Storing this as a half-closed interval — eg [1-Apr-2015, 1-July-2015) — can substantially simplify internal algorithms; the endDate of one interval will correspond to the startDate of the next.  However, from an end-user perspective the requirement may be to render the interval as a fully closed interval; eg the end date should be shown as 30-Jun-2015.  This attribute therefore bridges the gap; it presents 
 the information in a way that makes sense to an end-user, but also stores the domain object in a way that is easy work with internally.  For example: ","description":" The renderedAsDayBefore() attribute applies only to date parameters whereby the date will be rendered as the day before the value actually held in the domain object. It is ignored for parameters of other types. This attribute is also supported for properties. ","id":27806498},"31857620":{"title":"Interacting with the services","url":"guides/rgsvc/rgsvc.html#_interacting_with_the_services","body":"Interacting with the services  Typically domain objects will have little need to interact with the CommandContext and Command directly; what is more useful is that these are persisted in support of the various use cases identified above.  One case however where a domain object might want to obtain the Command is to determine whether it has been invoked in the foreground, or in the background. It can do this using the getExecu
 tedIn() method:  Although not often needed, this then allows the domain object to access the Command object through the CommandContext service. To expand th above example:  If run in the background, it might then notify the user (eg by email) if all work is done.  This leads us onto a related point, distinguishing the current effective user vs the originating \"real\" user. When running in the foreground, the current user can be obtained from the UserService, using:  If running in the background, however, then the current user will be the credentials of the background process, for example as run by a Quartz scheduler job.  The domain object can still obtain the original (\"effective\") user that caused the job to be created, using: ","description":" Typically domain objects will have little need to interact with the CommandContext and Command directly; what is more useful is that these are persisted in support of the various use cases identified above. ","id":31857620},"36734123":{"
 title":"Bug","url":"release-notes/release-notes.html#_bug_8","body":"Bug ","description":"","id":36734123},"39248326":{"title":"Runtime vs Noop implementation","url":"guides/rgfis/rgfis.html#_runtime_vs_noop_implementation","body":"Runtime vs Noop implementation  The framework provides two implementations:  The …​Default implementation takes priority over the …​Noop implementation. ","description":" The framework provides two implementations: ","id":39248326},"39290887":{"title":"Implementation","url":"guides/rgsvc/rgsvc.html#_implementation_22","body":"Implementation  The core framework provides a default implementation of this service (o.a.i.core.metamodel.services.container.DomainObjectContainerDefault). ","description":" The core framework provides a default implementation of this service (o.a.i.core.metamodel.services.container.DomainObjectContainerDefault). ","id":39290887},"42240053":{"title":"Screenshots","url":"guides/ugvw/ugvw.html#_screenshots_9","body":"Screensho
 ts  The screenshot below shows the Isis addons example todoapp (not ASF) with a 'brand logo' image in its header:  A custom brand logo (typically larger) can also be specified for the signin page: ","description":" The screenshot below shows the Isis addons example todoapp (not ASF) with a 'brand logo' image in its header: ","id":42240053},"44483327":{"title":"New Feature","url":"release-notes/release-notes.html#_new_feature_17","body":"New Feature ","description":"","id":44483327},"45128293":{"title":"getConfigurationProperties()","url":"guides/rgcms/rgcms.html#__rgcms_classes_AppManifest-bootstrapping_api_getConfigurationProperties","body":"getConfigurationProperties()  This method allow arbitrary other configuration properties to be overridden. One common use case is in conjunction with the getFixtures() method, discussed above: ","description":" This method allow arbitrary other configuration properties to be overridden. One common use case is in conjunction with the getFixtures
 () method, discussed above: ","id":45128293},"57327287":{"title":"cssClassFa()","url":"guides/rgant/rgant.html#_rgant-ViewModelLayout_cssClassFa","body":"cssClassFa()  The cssClassFa() attribute is used to specify the name of a Font Awesome icon name, to be rendered as the domain object’s icon.  These attribute can also be applied to domain objects to specify the object’s icon, and to actions to specify an icon for the action’s representation as a button or menu item.  If necessary the icon specified can be overridden by a particular object instance using the iconName() method.  For example:  There can be multiple \"fa-\" classes, eg to mirror or rotate the icon. There is no need to include the mandatory fa \"marker\" CSS class; it will be automatically added to the list. The fa- prefix can also be omitted from the class names; it will be prepended to each if required.  The related cssClassFaPosition() attribute is currently unused for domain objects; the icon is always render
 ed to the left. ","description":" The cssClassFa() attribute is used to specify the name of a Font Awesome icon name, to be rendered as the domain object’s icon. ","id":57327287},"64932464":{"title":"Other Guides","url":"guides/ugtst/ugtst.html#_other_guides","body":"Other Guides  Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides.  The user guides available are:  The reference guides are:  The remaining guides are: ","description":" Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides. ","id":64932464},"66604001":{"title":"@Programmatic","url":"guides/rgant/rgant.html#_rgant-Programmatic","body":"@Programmatic ","description":"","id":66604001},"68441589":{"title":"License headers","url":"guides/cgcom/cgcom.html#__cgcom_cutting-a-release_releasing-core_license-headers","body":"License headers  The Apache Release Audit Tool RAT (from the Apache Creadur project) checks
  for missing license header files. The parent pom.xml of each releasable module specifies the RAT Maven plugin, with a number of custom exclusions.  To run the RAT tool, use:  where rat.numUnapprovedLicenses property is set to a high figure, temporarily overriding the default value of 0. This will allow the command to run over all submodules, rather than failing after the first one. The command writes out a target\\rat.txt for each submodule. missing license notes are indicated using the key !???. The for command collates all the errors.  Investigate and fix any reported violations, typically by either:  To add missing headers, use the groovy script addmissinglicenses.groovy (in the scripts directory) to automatically insert missing headers for certain file types. The actual files checked are those with extensions specified in the line def fileEndings = [\".java\", \".htm\"]:  (If the -x is omitted then the script is run in \"dry run\" mode). Once you’ve fixed all issues, confirm 
 once more that apache-rat-plugin no longer reports any license violations, this time leaving the rat.numUnapprovedLicenses property to its default, 0: ","description":" The Apache Release Audit Tool RAT (from the Apache Creadur project) checks for missing license header files. The parent pom.xml of each releasable module specifies the RAT Maven plugin, with a number of custom exclusions. ","id":68441589},"73703450":{"title":"New Feature","url":"release-notes/release-notes.html#_new_feature_29","body":"New Feature ","description":"","id":73703450},"75054401":{"title":"Supporting Method Prefixes","url":"guides/rgcms/rgcms.html#_rgcms_methods_prefixes","body":"Supporting Method Prefixes  Supporting methods are those that are associated with properties, collections and actions, providing additional imperative business rule checking and behaviour to be performed when the user interacts with those object members.  This association is performed by name matching. Thus, a property called \"f
 irstName\", derived from a method getFirstName() may have supporting methods hideFirstName(), disableFirstName() and validateFirstName(). Supporting methods are, therefore, each characterized by their own particular prefix.  The table below lists the method prefixes that are recognized as part of Apache Isis' default programming model. ","description":" Supporting methods are those that are associated with properties, collections and actions, providing additional imperative business rule checking and behaviour to be performed when the user interacts with those object members. ","id":75054401},"77231561":{"title":"Interaction Execution","url":"guides/rgcms/rgcms.html#_rgcms_schema-ixn","body":"Interaction Execution  The interaction (\"ixn\") schema defines the serialized form of an action invocation or a property edit. In fact, it actually defines a call-graph of such executions for those cases where the WrapperFactory is used to execute sub-actions/property edits.  Each execution id
 entifies the target object, the member to invoke, and the arguments. It also captures metrics about the execution, and the result of the execution (eg return value of an action invocation). ","description":" The interaction (\"ixn\") schema defines the serialized form of an action invocation or a property edit. In fact, it actually defines a call-graph of such executions for those cases where the WrapperFactory is used to execute sub-actions/property edits. ","id":77231561},"78112488":{"title":"Screencast","url":"guides/ugvw/ugvw.html#_screencast","body":"Screencast  This screencast describes the feature. ","description":" This screencast describes the feature. ","id":78112488},"78624086":{"title":"Other Guides","url":"guides/ugsec/ugsec.html#_other_guides","body":"Other Guides  Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides.  The user guides available are:  The reference guides are:  The remaining guides are: ","descrip
 tion":" Apache Isis documentation is broken out into a number of user, reference and \"supporting procedures\" guides. ","id":78624086},"80534397":{"title":"ContentMappingService","url":"guides/rgsvc/rgsvc.html#_rgsvc_presentation-layer-spi_ContentMappingService","body":"ContentMappingService  The ContentMappingService supports the (default implementation of the) ContentNegotiationService enabling the RestfulObjects viewer to represent domain objects in some other format as specified by the HTTP Accept header.  See ContentNegotiationService for further discussion. ","description":" The ContentMappingService supports the (default implementation of the) ContentNegotiationService enabling the RestfulObjects viewer to represent domain objects in some other format as specified by the HTTP Accept header. ","id":80534397},"83803344":{"title":"MessageService","url":"guides/rgsvc/rgsvc.html#_rgsvc_application-layer-api_MessageService","body":"MessageService  The MessageService allows domain 
 objects to raise information, warning or error messages. These messages can either be simple strings, or can be translated. ","description":" The MessageService allows domain objects to raise information, warning or error messages. These messages can either be simple strings, or can be translated. ","id":83803344},"83933647":{"title":"Persistence Concerns","url":"guides/ugbtb/ugbtb.html#_persistence_concerns","body":"Persistence Concerns ","description":"","id":83933647},"85931482":{"title":"Task","url":"release-notes/release-notes.html#_task_24","body":"Task ","description":"","id":85931482},"87271564":{"title":"2004:","url":"pages/articles-and-presentations/articles-and-presentations.html#_2004","body":"2004: ","description":"","id":87271564},"90561824":{"title":"Wicket Viewer","url":"release-notes/release-notes.html#_wicket_viewer_8","body":"Wicket Viewer ","description":"","id":90561824},"90935214":{"title":"Wicket Viewer","url":"release-notes/release-notes.html#_wicket_viewer_1
 0","body":"Wicket Viewer ","description":"","id":90935214},"91902412":{"title":"The issue in more detail","url":"guides/ugodn/ugodn.html#_the_issue_in_more_detail","body":"The issue in more detail  Consider these entities (yuml.me/b8681268):  In the course of a transaction, the Agreement entity is loaded into memory (not necessarily modified), and then new AgreementRoles are associated to it.  All these entities implement Comparable using ObjectContracts, and the implementation of AgreementRole's (simplified) is:  while Agreement's is implemented as:  and Party's is similarly implemented as:  DataNucleus’s persistence-by-reachability algorithm adds the AgreementRole instances into a SortedSet, which causes AgreementRole#compareTo() to fire:  In other words, in figuring out whether AgreementRole requires the persistence-by-reachability algorithm to run, it causes the adjacent associated entity Party to also be retrieved. ","description":" Consider these entities (yuml.me/b8681268):
  ","id":91902412},"92467660":{"title":"API and Usage","url":"guides/ugtst/ugtst.html#_ugtst_fixture-scripts_api-and-usage","body":"API and Usage  There are two parts to using fixture scripts: the FixtureScripts domain service class, and the FixtureScript view model class:  Let’s look at FixtureScripts domain service in more detail first. ","description":" There are two parts to using fixture scripts: the FixtureScripts domain service class, and the FixtureScript view model class: ","id":92467660},"95725933":{"title":"Appendix: Isis Add-ons (not ASF)","url":"guides/ugvw/ugvw.html#_ugvw_isis-addons","body":"Appendix: Isis Add-ons (not ASF) ","description":"","id":95725933},"96583162":{"title":"Configure toolchains plugin","url":"guides/cgcom/cgcom.html#_configure_toolchains_plugin","body":"Configure toolchains plugin  Apache Isis releases are built using Java 7, enforced using the maven toolchains plugin. Ensure that Java 7 is installed and the toolchains plugin is configured, as de
 scribed in the contributors' guide. ","description":" Apache Isis releases are built using Java 7, enforced using the maven toolchains plugin. Ensure that Java 7 is installed and the toolchains plugin is configured, as described in the contributors' guide. ","id":96583162},"99090360":{"title":"Running the App","url":"guides/ugfun/ugfun.html#__ugfun_getting-started_simpleapp-archetype_running-the-app","body":"Running the App  The simpleapp archetype generates a single WAR file, configured to run both the Wicket viewer and the Restful Objects viewer. The archetype also configures the DataNucleus/JDO Objectstore to use an in-memory HSQLDB connection.  Once you’ve built the app, you can run the WAR in a variety of ways. ","description":" The simpleapp archetype generates a single WAR file, configured to run both the Wicket viewer and the Restful Objects viewer. The archetype also configures the DataNucleus/JDO Objectstore to use an in-memory HSQLDB connection. ","id":99090360},"100682
 258":{"title":"Update dependencies","url":"guides/cgcom/cgcom.html#_update_dependencies","body":"Update dependencies  With the release complete, now is a good time to bump versions of dependencies (so that there is a full release cycle to identify any possible issues).  You will probably want to create a new JIRA ticket for these updates (or if minor then use the \"catch-all\" JIRA ticket raised earlier for the next release). ","description":" With the release complete, now is a good time to bump versions of dependencies (so that there is a full release cycle to identify any possible issues). ","id":100682258},"102347041":{"title":"Bug","url":"release-notes/release-notes.html#_bug_10","body":"Bug ","description":"","id":102347041},"104167755":{"title":"How to implement a spellchecker?","url":"guides/ugbtb/ugbtb.html#_ugbtb_hints-and-tips_how-to-implement-a-spellchecker","body":"How to implement a spellchecker?  From this thread on the Apache Isis users mailing list:  One way to impl
 ement is to use the event bus:  if if the change is made through an edit, you can use @Property#domainEvent().  You’ll need some way to know which fields should be spell checked. Two ways spring to mind:  And you’ll (obviously) also need some sort of spell checker implementation to call. ","description":" From this thread on the Apache Isis users mailing list: ","id":104167755},"105480253":{"title":"Visitor","url":"guides/ugbtb/ugbtb.html#__code_visitor_code","body":"Visitor  More often than not, you’ll want to visit every element in the metamodel, and so for this you can instead subclass from MetaModelValidatorVisiting.Visitor:  You can then create your custom validator by subclassing MetaModelValidatorComposite and adding the visiting validator:  If you have more than one rule then each can live in its own visitor. ","description":" More often than not, you’ll want to visit every element in the metamodel, and so for this you can instead subclass from MetaModelValidatorVisi
 ting.Visitor: ","id":105480253},"106558909":{"title":"contributedAs()","url":"guides/rgant/rgant.html#_rgant-ActionLayout_contributedAs","body":"contributedAs()  For a domain service action that can be contributed, the contributedAs() attribute determines how it is contributed: as an action or as an association (ie a property or collection).  The distinction between property or collection is automatic: if the action returns a java.util.Collection (or subtype) then the action is contributed as a collection; otherwise it is contributed as a property.  For a domain service action to be contributed, the domain services must have a nature nature of either VIEW or VIEW_CONTRIBUTIONS_ONLY, and the action must have safe action semantics, and takes a single argument, namely the contributee domain object.  For example:  It’s also possible to use the attribute to suppress the action completely:  In such cases, though, it would probably make more sense to annotate the action as either hidden 
 or indeed @Programmatic. ","description":" For a domain service action that can be contributed, the contributedAs() attribute determines how it is contributed: as an action or as an association (ie a property or collection). ","id":106558909},"106606865":{"title":"Using the Wicket Viewer","url":"guides/rgcfg/rgcfg.html#_using_the_wicket_viewer","body":"Using the Wicket Viewer  Most of the you’re likely to run Apache Isis using the Wicket viewer. In this case Apache Isis' \"deployment type\" concept maps to Wicket’s \"configuration\" concept:  Wicket’s mechanism for specifying the \"configuration\" is to use a context parameter in web.xml; Apache Isis automatically infers its own deployment type from this. In other words: ","description":" Most of the you’re likely to run Apache Isis using the Wicket viewer. In this case Apache Isis' \"deployment type\" concept maps to Wicket’s \"configuration\" concept: ","id":106606865},"108721033":{"title":"Incode Catalog","url":"guides/
 ugfun/ugfun.html#_ugfun_available-domain-services_incode-catalog","body":"Incode Catalog  The Incode Catalog website also provides a number of reusable modules, focusing on business logic for generic subdomains.  This section surveys the functionality available.  The modules themselves fall into a number of broader groups:  Each of the modules has a full README and demo application demonstrating their usage. The sections below briefly outline the capabilities of these modules. ","description":" The Incode Catalog website also provides a number of reusable modules, focusing on business logic for generic subdomains. ","id":108721033},"108815435":{"title":"unchanging()","url":"guides/rgant/rgant.html#_rgant-PropertyLayout_unchanging","body":"unchanging()  The unchanging() attribute is used to indicate that the value held by the property never changes over time, even when other properties of the object do change.  Setting this attribute to true is used as a hint to the viewer to not red
 raw the property after an AJAX update of some other property/ies of the object have changed. This is primarily for performance, eg can improve the user experience when rendering PDFs/blobs.  Note that for this to work, the viewer will also ensure that none of the property’s parent component (such as a tab group panel) are re-rendered.  For example: ","description":" The unchanging() attribute is used to indicate that the value held by the property never changes over time, even when other properties of the object do change. ","id":108815435},"109833874":{"title":"Persistable","url":"guides/rgcms/rgcms.html#_rgcms_classes_mixins_Persistable","body":"Persistable  All domain entities automatically implement the DataNucleus Persistable role interface as a result of the enhancer process (the fully qualified class name is org.datanucleus.enhancement.Persistable). So as a developer you do not need to write any code to obtain the mixins that contribute to this interface. ","description":" 
 All domain entities automatically implement the DataNucleus Persistable role interface as a result of the enhancer process (the fully qualified class name is org.datanucleus.enhancement.Persistable). So as a developer you do not need to write any code to obtain the mixins that contribute to this interface. ","id":109833874},"112375674":{"title":"Auditing","url":"migration-notes/migration-notes.html#_auditing","body":"Auditing  The AuditingService SPI service has been deprecated, instead replaced by the AuditerService.  There can be more than one implementation of this new SPI, and a framework-provided implementation (AuditerServiceLogging) will log to a file. The (non-ASF) Isis addons' audit module also implements the new SPI. ","description":" The AuditingService SPI service has been deprecated, instead replaced by the AuditerService. ","id":112375674},"114685873":{"title":"Usage","url":"guides/rgsvc/rgsvc.html#_usage_19","body":"Usage  To indicate that an action invocation should 
 be published, annotate it with the @Action#publishing() annotation.  To indicate that an property edit should be published, annotate it with the @Property#publishing() annotation.  To indicate that a changed object should be published is to annotate it with the @DomainObject#publishing() annotation. ","description":" To indicate that an action invocation should be published, annotate it with the @Action#publishing() annotation. ","id":114685873},"115229271":{"title":"Domain Entities","url":"guides/ugfun/ugfun.html#_ugfun_programming-model_domain-entities","body":"Domain Entities  Entities are persistent domain objects, with their persistence handled by JDO/DataNucleus. As such, they are mapped to a persistent object store, typically an RDBMS, with DataNucleus taking care of both lazy loading and also the persisting of modified (\"dirty\") objects.  Domain entities are generally decorated with both DataNucleus and Apache Isis annotations. Let’s look at some of the most commonly-use
 d annotations.  To start with, entities are flagged as being \"persistence capable\", indicating how JDO/DataNucleus should manage their identity:  All domain entities will have some sort of mandatory key properties. The example below is a very simple case, where the entity is identified by a name property:  It’s also common for domain entities to have queries annotated on them. These are used by repository domain services to query for instances of the entity:  DataNucleus provides several APIs for defining queries, including entirely programmatic and type-safe APIs; but JDOQL is very similar to SQL and so easily learnt.  The corresponding repository method for the above query is: ","description":" Entities are persistent domain objects, with their persistence handled by JDO/DataNucleus. As such, they are mapped to a persistent object store, typically an RDBMS, with DataNucleus taking care of both lazy loading and also the persisting of modified (\"dirty\") objects. ","id":1152292
 71},"117553409":{"title":"Object Icon","url":"guides/ugfun/ugfun.html#_object_icon","body":"Object Icon  The icon is often the same for all instances of a particular class, and is picked up by convention.  It’s is also possible for an individual instance to return a custom icon, typically so that some significant state of that domain object is represented. For example, a custom icon could be used to represent a shipped order, say, or an overdue library loan. ","description":" The icon is often the same for all instances of a particular class, and is picked up by convention. ","id":117553409},"121574190":{"title":"Related Services","url":"guides/rgsvc/rgsvc.html#_related_services_18","body":"Related Services  The ActionInteractionContext service allows bulk actions to co-ordinate with each other.  The QueryResultsCache is useful for caching the results of expensive method calls. ","description":" The ActionInteractionContext service allows bulk actions to co-ordinate with each othe
 r. ","id":121574190},"121879267":{"title":"Wicket Viewer","url":"release-notes/release-notes.html#_wicket_viewer_2","body":"Wicket Viewer ","description":"","id":121879267},"122762699":{"title":"Contributee","url":"guides/rgcms/rgcms.html#_rgcms_classes_contributee","body":"Contributee  The interfaces listed in this chapter act as contributees; they allow domain services to contribute actions/properties/collections to any domain objects that implement these interfaces. ","description":" The interfaces listed in this chapter act as contributees; they allow domain services to contribute actions/properties/collections to any domain objects that implement these interfaces. ","id":122762699},"125299345":{"title":"Example","url":"guides/rgant/rgant.html#_example_2","body":"Example  This example is taken from the (non-ASF) Isis addons' todoapp: ","description":" This example is taken from the (non-ASF) Isis addons' todoapp: ","id":125299345},"125961908":{"title":"Do it!","url":"pages/tg/tg
 .html#_do_it","body":"Do it! ","description":"","id":125961908},"134804772":{"title":"How to handle void/null results","url":"guides/ugbtb/ugbtb.html#_ugbtb_hints-and-tips_how-to-handle-void-and-null-results","body":"How to handle void/null results  From this thread on the Apache Isis users mailing list:  One way to implement this idea is to provide a custom implementation of the RoutingService SPI domain service. The default implementation will either return the current object (if not null), else the home page (as defined by @HomePage) if one exists.  The following custom implementation refines this to use the breadcrumbs (available in the Wicket viewer) to return the first non-deleted domain object found in the list of breadcrumbs:  Note that the above implementation uses Java 8, so if you are using Java 7 then you’ll need to backport accordingly. ","description":" From this thread on the Apache Isis users mailing list: ","id":134804772},"140760147":{"title":"Isis Add-on modules
 ","url":"guides/ugvw/ugvw.html#_isis_add_on_modules","body":"Isis Add-on modules  Some of the (non-ASF) Isis Addons modules also provide services whose actions appear in top-level menus.  The security's module places its domain service menus in three top-level menus:  Meanwhile the devutils module places its actions - to download layouts and so forth - on a \"Prototyping\" top-level menu, on the SECONDARY menu bar.  Currently there is no facility to alter the placement of these services. However, their UI can be suppressed using security or using a vetoing subscriber. ","description":" Some of the (non-ASF) Isis Addons modules also provide services whose actions appear in top-level menus. ","id":140760147},"145340696":{"title":"Registering the Services","url":"guides/rgsvc/rgsvc.html#_registering_the_services_20","body":"Registering the Services  The (non-ASF) Isis addons' audit module provides an implementation of this service (AuditingService), and also provides a number of relate
 d domain services (AuditingServiceMenu, AuditingServiceRepository and AuditingServiceContributions).  Assuming that an AppManifest is being used to bootstrap the app) then this can be activated by updating the pom.xml and updating the AppManifest#getModules() method.  If menu items or contributions are not required in the UI, these can be suppressed either using security or by implementing a vetoing subscriber. ","description":" The (non-ASF) Isis addons' audit module provides an implementation of this service (AuditingService), and also provides a number of related domain services (AuditingServiceMenu, AuditingServiceRepository and AuditingServiceContributions). ","id":145340696},"148135206":{"title":"Layout Metadata Reader (deprecated)","url":"guides/ugbtb/ugbtb.html#_ugbtb_programming-model_layout-metadata-reader","body":"Layout Metadata Reader (deprecated)  The metadata for domain objects is obtained both annotations and files. There is also deprecated support for reading layout
 s from .layout.json files. This service provides an SPI (and default implementation) for reading layouts defined in this fashion. ","description":" The metadata for domain objects is obtained both annotations and files. There is also deprecated support for reading layouts from .layout.json files. This service provides an SPI (and default implementation) for reading layouts defined in this fashion. ","id":148135206},"153666205":{"title":"Implementation","url":"guides/rgsvc/rgsvc.html#_implementation_17","body":"Implementation  The core framework provides a default implementation of this service (o.a.i.core.metamodel.services.title.TitleServiceDefault). ","description":" The core framework provides a default implementation of this service (o.a.i.core.metamodel.services.title.TitleServiceDefault). ","id":153666205},"155655500":{"title":"@PrimaryKey (javax.jdo)","url":"guides/rgant/rgant.html#_rgant-PrimaryKey","body":"@PrimaryKey (javax.jdo) ","description":"","id":155655500},"15803341
 2":{"title":"SPI","url":"guides/rgsvc/rgsvc.html#_spi_27","body":"SPI  The SPI defined by the service is: ","description":" The SPI defined by the service is: ","id":158033412},"158069558":{"title":"Usability: Defaults","url":"pages/tg/tg.html#_usability_defaults","body":"Usability: Defaults  Quick detour: often we want to set up defaults to go with choices. Sensible defaults for action parameters can really improve the usability of the app. ","description":" Quick detour: often we want to set up defaults to go with choices. Sensible defaults for action parameters can really improve the usability of the app. ","id":158069558},"158897592":{"title":"Refactoring","url":"guides/dg/dg.html#__dg_ide_intellij_hints-and-tips_refactoring","body":"Refactoring  Loads of good stuff on the Refactor menu; most used are:  If you can’t remember all those shortcuts, just use ctrl-shift-alt-T (might want to rebind that to something else!) and get a context-sensitive list of refactorings available f
 or the currently selected object ","description":" Loads of good stuff on the Refactor menu; most used are: ","id":158897592},"160872749":{"title":"Related Services","url":"guides/rgfis/rgfis.html#_related_services","body":"Related Services  The default implementation of ContentNegotiationService delegates to ContentMappingService (if present) to convert domain entities into a stable form (eg DTO).  The ContentNegotiationService is itself called by the (default implementation of) RepresentationService. ","description":" The default implementation of ContentNegotiationService delegates to ContentMappingService (if present) to convert domain entities into a stable form (eg DTO). ","id":160872749},"163456888":{"title":"Dependency upgrade","url":"release-notes/release-notes.html#_dependency_upgrade_9","body":"Dependency upgrade ","description":"","id":163456888},"163915714":{"title":"web.xml","url":"migration-notes/migration-notes.html#_web_xml","body":"web.xml  In the web.xml, the \"is
 is.viewers\" context-param is now ignored. Instead the viewer_wicket.properties and viewer_restfulobjects.properties will both be loaded if present (but neither need be present). ","description":" In the web.xml, the \"isis.viewers\" context-param is now ignored. Instead the viewer_wicket.properties and viewer_restfulobjects.properties will both be loaded if present (but neither need be present). ","id":163915714},"165602306":{"title":"GridLoaderService","url":"guides/rgsvc/rgsvc.html#_rgsvc_presentation-layer-spi_GridLoaderService","body":"GridLoaderService  The GridLoaderService provides the ability to load the XML layout (grid) for a domain class. ","description":" The GridLoaderService provides the ability to load the XML layout (grid) for a domain class. ","id":165602306},"165750333":{"title":"loaded()","url":"guides/rgcms/rgcms.html#_rgcms_methods_lifecycle_loaded","body":"loaded()  The loaded() lifecycle callback method is called when a (persistent) object has just been loade
 d from the object store. ","description":" The loaded() lifecycle callback method is called when a (persistent) object has just been loaded from the object store. ","id":165750333},"166045728":{"title":"Sanity Check","url":"guides/cgcom/cgcom.html#_sanity_check_2","body":"Sanity Check  Ensure that the framework builds ok using the same command that your CI server is set up to execute (see section above). ","description":" Ensure that the framework builds ok using the same command that your CI server is set up to execute (see section above). ","id":166045728},"166899251":{"title":"Installing and Setting up","url":"guides/dg/dg.html#__dg_ide_intellij_installing","body":"Installing and Setting up  This section covers installation and setup. These notes/screenshots were prepared using IntelliJ Community Edition 14.1.x, but are believed to be compatible with more recent versions/other editions of the IDE. ","description":" This section covers installation and setup. These notes/screensho
 ts were prepared using IntelliJ Community Edition 14.1.x, but are believed to be compatible with more recent versions/other editions of the IDE. ","id":166899251},"167039338":{"title":"Task","url":"release-notes/release-notes.html#_task_14","body":"Task ","description":"","id":167039338},"169081251":{"title":"Interaction","url":"guides/rgsvc/rgsvc.html#__code_interaction_code","body":"Interaction  The public API of the Interaction class consists of:  This class is concrete (is also the implementation). ","description":" The public API of the Interaction class consists of: ","id":169081251},"174738887":{"title":"Related functionality","url":"guides/ugvw/ugvw.html#_related_functionality_2","body":"Related functionality  The Recent Pages also lists recently visited pages, selected from a drop-down. ","description":" The Recent Pages also lists recently visited pages, selected from a drop-down. ","id":174738887},"175028546":{"title":"Implementation","url":"guides/rgsvc/rgsvc.html#_imple
 mentation_5","body":"Implementation  The framework provides a default implementation of this service, namely GridServiceDefault. ","description":" The framework provides a default implementation of this service, namely GridServiceDefault. ","id":175028546},"175197970":{"title":"Performance tuning","url":"pages/tg/tg.html#_performance_tuning","body":"Performance tuning  The QueryResultsCache (request-scoped) domain service allows arbitrary objects to be cached for the duration of a request.  This can be helpful for \"naive\" code which would normally make the same query within a loop. ","description":" The QueryResultsCache (request-scoped) domain service allows arbitrary objects to be cached for the duration of a request. ","id":175197970},"175636232":{"title":"RepositoryService","url":"guides/rgsvc/rgsvc.html#_rgsvc_persistence-layer-api_RepositoryService","body":"RepositoryService  The RepositoryService collects together methods for creating, persisting and searching for entities 
 from the underlying persistence store. It acts as an abstraction over the JDO/DataNucleus objectstore.  You can use it during prototyping to write naive queries (find all rows, then filter using the Guava Predicate API, or you can use it to call JDO named queries using JDOQL.  As an alternative, you could also use JDO typesafe queries through the IsisJdoSupport service. ","description":" The RepositoryService collects together methods for creating, persisting and searching for entities from the underlying persistence store. It acts as an abstraction over the JDO/DataNucleus objectstore. ","id":175636232},"176767338":{"title":"Command and Events","url":"guides/rgsvc/rgsvc.html#__rgsvc_intro_commands-and-events","body":"Command and Events  A good number of the domain services manage the execution of action invocations/property edits, along with the state of domain objects that are modified as a result of these. These services capture information which can then be used for various purp
 oses, most notably for auditing or for publishing events, or for deferring execution such that the execution be performed in the background at some later date.  The diagram below shows how these services fit together. The outline boxes are services while the coloured boxes represent data structures - defined in the applib and therefore accessible to domain applications - which hold various information about the executions.  To explain:  Implementations of CommandService can use the Command#getMemento() method to obtain a XML equivalent of that Command, reified using the cmd.xsd schema. This can be converted back into a CommandDto using the CommandDtoUtils utility class (part of the applib).  Similarly, implementations of PublisherService can use the InteractionDtoUtils utility class to obtain a InteractionDto representing the interaction, either just for a single execution or for the entire call-graph. This can be converted into XML in a similar fashion.  Likewise, the PublishedObje
 cts class passed to the PublisherService at the end of the interaction provides the PublishedObjects#getDto() method which returns a ChangesDto instance. This can be converted into XML using the ChangesDtoUtils utility class.  One final point: multiple PublisherService implementations are supported because different implementations may have different responsibilities. For example, the (non-ASF) Isis addons' publishmq module is responsible for publishing messages onto an ActiveMQ event bus, for inter-system communication. However, the SPI can also be used for profiling; each execution within the call-graph contains metrics of the number of objects loaded or modified as a result of that execution, and thus could be used for application profiling. The framework provides a default PublisherServiceLogging implementation that logs this using SLF4J. ","description":" A good number of the domain services manage the execution of action invocations/property edits, along with the state of doma
 in objects that are modified as a result of these. These services capture information which can then be used for various purposes, most notably for auditing or for publishing events","id":176767338},"178125062":{"title":"domainEvent()","url":"guides/rgant/rgant.html#_rgant-Action_domainEvent","body":"domainEvent()  Whenever a domain object (or list of domain objects) is to be rendered, the framework fires off multiple domain events for every property, collection and action of the domain object. In the cases of the domain object’s actions, the events that are fired are:  Subscribers subscribe through the EventBusService using either Guava or Axon Framework annotations and can influence each of these phases.  By default the event raised is ActionDomainEvent.Default. For example:  The domainEvent() attribute allows a custom subclass to be emitted allowing more precise subscriptions (to those subclasses) to be defined instead. This attribute is also supported for collections and prope
 rties.  For example:  The benefit is that subscribers can be more targeted as to the events that they subscribe to. ","description":" Whenever a domain object (or list of domain objects) is to be rendered, the framework fires off multiple domain events for every property, collection and action of the domain object. In the cases of the domain object’s actions, the events that are fired are: ","id":178125062},"180783343":{"title":"TranslatableException","url":"guides/ugbtb/ugbtb.html#__code_translatableexception_code","body":"TranslatableException  Another mechanism by which messages can be rendered to the user are as the result of exception messages thrown and recognized by an ExceptionRecognizer.  In this case, if the exception implements TranslatableException, then the message will automatically be translated before being rendered. The TranslatableException itself takes the form: ","description":" Another mechanism by which messages can be rendered to the user are as the result o
 f exception messages thrown and recognized by an ExceptionRecognizer. ","id":180783343},"183226640":{"title":"updatedLifecycleEvent()","url":"guides/rgant/rgant.html#_rgant-DomainObject_updatedLifecycleEvent","body":"updatedLifecycleEvent()  Whenever a (persistent) domain object has been modified and has been updated in the database, an \"updated\" lifecycle event is fired.  Subscribers subscribe through the EventBusService and can use the event to obtain a reference to the domain object.  By default the event raised is ObjectUpdatedEvent.Default. For example:  The purpose of the updatedLifecycleEvent() attribute is to allows a custom subclass to be emitted instead. A similar attribute is available for other lifecycle events.  For example:  The benefit is that subscribers can be more targeted as to the events that they subscribe to. ","description":" Whenever a (persistent) domain object has been modified and has been updated in the database, an \"updated\" lifecycle event is fired.
  ","id":183226640},"188123644":{"title":"2013","url":"pages/articles-and-presentations/articles-and-presentations.html#_2013","body":"2013 ","description":"","id":188123644},"189180810":{"title":"HoldsUpdatedAt","url":"guides/rgcms/rgcms.html#_rgcms_classes_roles_HoldsUpdatedAt","body":"HoldsUpdatedAt  The HoldsUpdatedAt role interface allows the (framework-provided) TimestampService to update each object with the current timestamp whenever it is modified in a transaction.  The interface is defined as:  The current time is obtained from the ClockService.  Entities that implement this interface often also implement HoldsUpdatedBy role interface; as a convenience the Timestampable interface combines the two roles. ","description":" The HoldsUpdatedAt role interface allows the (framework-provided) TimestampService to update each object with the current timestamp whenever it is modified in a transaction. ","id":189180810},"191180113":{"title":"persistence.xml","url":"guides/ugodn/ugodn.
 html#_ugodn_configuring_persistence-xml","body":"persistence.xml  DataNucleus will for itself also and read the META-INF/persistence.xml. In theory it can hold mappings and even connection strings. However, with Apache Isis we tend to use annotations instead and externalize connection strings. so its definition is extremely simply, specifying just the name of the \"persistence unit\".  Here’s the one provided by the SimpleApp archetype:  Normally all one needs to do is to change the persistence-unit name.  See DataNucleus' documentation on persistence.xml to learn more. ","description":" DataNucleus will for itself also and read the META-INF/persistence.xml. In theory it can hold mappings and even connection strings. However, with Apache Isis we tend to use annotations instead and externalize connection strings. so its definition is extremely simply, specifying just the name of the \"persistence unit","id":191180113},"193237835":{"title":"Core","url":"release-notes/release-notes.h
 tml#_core_8","body":"Core ","description":"","id":193237835},"193497711":{"title":"UI Hints","url":"guides/ugfun/ugfun.html#_ugfun_ui-hints","body":"UI Hints ","description":"","id":193497711},"194608562":{"title":"SPI","url":"guides/rgsvc/rgsvc.html#_spi_19","body":"SPI  The SPI defined by the service is:  where FixtureScriptsSpecification exposes these values:  The class is immutable but it has a builder (obtained using FixturescriptsSpecification.builder(…​)) for a fluent API. ","description":" The SPI defined by the service is: ","id":194608562},"195374240":{"title":"Update the LDAP committee (if a PMC member)","url":"guides/cgcom/cgcom.html#_update_the_ldap_committee_if_a_pmc_member","body":"Update the LDAP committee (if a PMC member)  (Assuming that the new committer is a PMC member), also add them as to the PMC committee. This takes two steps:  The new committer does not officially become a member of the PMC until the ASF records have been updated. ","description":" (Assu
 ming that the new committer is a PMC member), also add them as to the PMC committee. This takes two steps: ","id":195374240},"195848147":{"title":"ICLA, obtain new account","url":"guides/cgcom/cgcom.html#_icla_obtain_new_account","body":"ICLA, obtain new account  If required (that is, if the committer is not already a committer for a different ASF project), then ask them to complete an ICLA. As a result of this, they should also get an @apache.org user name.  More info can be found in the ASF new committers guide. ","description":" If required (that is, if the committer is not already a committer for a different ASF project), then ask them to complete an ICLA. As a result of this, they should also get an @apache.org user name. ","id":195848147},"198329644":{"title":"Strings (Length)","url":"guides/ugfun/ugfun.html#__ugfun_programming-model_properties_datatypes_strings","body":"Strings (Length)  By default JDO/DataNucleus will map string properties to a VARCHAR(255). To limit the len
 gth, use the @Column(length=…​) annotation.  For example:  This is a good example of a case where Apache Isis infers domain semantics from the JDO annotation. ","description":" By default JDO/DataNucleus will map string properties to a VARCHAR(255). To limit the length, use the @Column(length=…​) annotation. ","id":198329644},"198382465":{"title":"Actions","url":"pages/tg/tg.html#_actions","body":"Actions  Most business functionality is implemented using actions basically a public method accepting domain classes and primitives as its parameter types. The action can return a domain entity, or a collection of entities, or a primitive/String/value, or void. If a domain entity is returned then that object is rendered immediately; if a collection is returned then the Wicket viewer renders a table. Such collections are sometimes called \"standalone\" collections. ","description":" Most business functionality is implemented using actions basically a public method accepting domain c
 lasses and primitives as its parameter types. The action can return a domain entity, or a collection of entities, or a primitive/String/value, or void. If a domain entity is returned then that object is rendered","id":198382465},"203208629":{"title":"New Feature","url":"release-notes/release-notes.html#_new_feature_18","body":"New Feature ","description":"","id":203208629},"203740710":{"title":"RoutingService","url":"guides/rgsvc/rgsvc.html#_rgsvc_presentation-layer-spi_RoutingService","body":"RoutingService  The RoutingService provides the ability to return (and therefore render) an alternative object from an action invocation.  There are two primary use cases:  Currently the routing service is used only by the Wicket viewer; it is ignored by the Restful Objects viewer. ","description":" The RoutingService provides the ability to return (and therefore render) an alternative object from an action invocation. ","id":203740710},"204452611":{"title":"Related services","url":"guides/rgs
 vc/rgsvc.html#_related_services_15","body":"Related services  The ConfigurationServiceMenu exposes the allConfigurationProperties action in the user interface. ","description":" The ConfigurationServiceMenu exposes the allConfigurationProperties action in the user interface. ","id":204452611},"207811701":{"title":"API","url":"guides/rgsvc/rgsvc.html#_api_2","body":"API  The API of TitleService is: ","description":" The API of TitleService is: ","id":207811701},"209853740":{"title":"To run","url":"guides/rgmvn/rgmvn.html#_to_run","body":"To run  The plugin is activated by default, so is run simply using:  This will run any tests, and then also - because the plugin is activated by the isis-validate property and bound to the test phase, will run the plugin’s validate goal.  If for any reason you want to disable the validation, use: ","description":" The plugin is activated by default, so is run simply using: ","id":209853740},"213642269":{"title":"Moving on","url":"guides/ugfun/ugfun
 .html#__ugfun_getting-started_helloworld-archetype_moving-on","body":"Moving on  When you are ready to start working on your own app, we don’t recommend building on top of the helloworld app.  Instead, we suggest that you start with the simpleapp archetype instead. Although a little more complex, it provides more structure and tests, all of which will help you as your application grows. ","description":" When you are ready to start working on your own app, we don’t recommend building on top of the helloworld app. ","id":213642269},"216231183":{"title":"Raising a pull request","url":"guides/dg/dg.html#_raising_a_pull_request","body":"Raising a pull request  If you have your own fork, you can now simply push the changes you’ve made locally to your fork:  This will create a corresponding branch in the remote github repo. If you use gitk --all, you’ll also see a remotes/origin/ISIS-123-blobs branch.  Then, use github to raise a pull request. Pull requests sent to the Apache GitH
 ub repositories will forward a pull request e-mail to the dev mailing list. You’ll probably want to sign up to the dev mailing list first before issuing your first pull request (though that isn’t mandatory).  The process to raise the pull request, broadly speaking: ","description":" If you have your own fork, you can now simply push the changes you’ve made locally to your fork: ","id":216231183},"220685197":{"title":"AbstractSubscriber","url":"guides/rgcms/rgcms.html#_rgcms_classes_super_AbstractSubscriber","body":"AbstractSubscriber  This is a convenience superclass for creating subscriber domain services on the EventBusService. It uses @PostConstruct and @PreDestroy callbacks to automatically register/unregister itself with the EventBusService.  It’s important that subscribers register before any domain services that might emit events on the EventBusService. For example, the (non-ASF) Isis addons' security module provides a domain service that automatically seeds certain d
 omain entities; these will generate lifecycle events and so any subscribers must be registered before such seed services. The easiest way to do this is to use the @DomainServiceLayout#menuOrder() attribute.  As a convenience, the AbstractSubscriber specifies this attribute. ","description":" This is a convenience superclass for creating subscriber domain services on the EventBusService. It uses @PostConstruct and @PreDestroy callbacks to automatically register/unregister itself with the EventBusService. ","id":220685197},"221961571":{"title":"Release prepare \"dry run\"","url":"guides/cgcom/cgcom.html#__cgcom_cutting-a-release_releasing-core_release-prepare-dry-run","body":"Release prepare \"dry run\"  Most of the work is done using the mvn release:prepare goal. Since this makes a lot of changes, we run it first in \"dry run\" mode; only if that works do we run the goal for real.  Run the dry-run as follows:  You may be prompted for the gpg passphrase. ","description":" Most of the 
 work is done using the mvn release:prepare goal. Since this makes a lot of changes, we run it first in \"dry run\" mode; only if that works do we run the goal for real. ","id":221961571},"224301547":{"title":"IsisWebAppBootstrapper","url":"guides/ugbtb/ugbtb.html#__code_isiswebappbootstrapper_code","body":"IsisWebAppBootstrapper  The IsisWebAppBootstrapper servlet context listener bootstraps the shared (global) metadata for the Apache Isis framework. This listener is not required (indeed must not be configured) if the Wicket viewer is in use.  Its definition is:  Its context parameters are: ","description":" The IsisWebAppBootstrapper servlet context listener bootstraps the shared (global) metadata for the Apache Isis framework. This listener is not required (indeed must not be configured) if the Wicket viewer is in use. ","id":224301547},"227377078":{"title":"Initialization","url":"guides/ugfun/ugfun.html#_ugfun_programming-model_domain-services_initialization","body":"Initializati
 on  Services can optionally declare lifecycle callbacks to initialize them (when the app is deployed) and to shut them down (when the app is undeployed).  An Apache Isis session is available when initialization occurs (so services can interact with the object store, for example).  The framework will call any public method annotated with @PostConstruct with either no arguments of an argument of type Map<String,String>. In the latter case, the framework passes in the configuration (isis.properties and any other component-specific configuration files).  Shutdown is similar; the framework will call any method annotated with @PreDestroy. ","description":" Services can optionally declare lifecycle callbacks to initialize them (when the app is deployed) and to shut them down (when the app is undeployed). ","id":227377078},"228550183":{"title":"Policies","url":"guides/cgcom/cgcom.html#_cgcom_policies","body":"Policies ","description":"","id":228550183},"229025509":{"title":"Remove reference
 s to isis-viewer-wicket parent pom.","url":"migration-notes/migration-notes.html#_remove_references_to_code_isis_viewer_wicket_code_parent_pom","body":"Remove references to isis-viewer-wicket parent pom.  In earlier releases the Wicket viewer defined its own parent pom.xml for dependency management and its dependencies and to declare the various submodules that make up the viewer. This pom.xml has now been incorporated into the parent pom.xml for the Core framework.  Therefore, in the parent pom.xml of your own domain applications, remove: ","description":" In earlier releases the Wicket viewer defined its own parent pom.xml for dependency management and its dependencies and to declare the various submodules that make up the viewer. This pom.xml has now been incorporated into the parent pom.xml for the Core framework. ","id":229025509},"230599582":{"title":"AuditingServiceInternal","url":"guides/rgfis/rgfis.html#_rgfis_persistence-layer_AuditingServiceInternal","body":"AuditingServi
 ceInternal  The (internal) AuditingServiceInternal domain service acts as an internal facade to any configured AuditingService and AuditerService services. It is responsible for obtaining the details of all changes to domain objects within an interaction, and then to call the configured AuditingService to actually create audit entries of those changes. ","description":" The (internal) AuditingServiceInternal domain service acts as an internal facade to any configured AuditingService and AuditerService services. It is responsible for obtaining the details of all changes to domain objects within an interaction, and then to call the configured AuditingService to actually create audit entries of those changes. ","id":230599582},"232471644":{"title":"Registering Subscribers","url":"guides/rgsvc/rgsvc.html#_registering_subscribers","body":"Registering Subscribers  The register() method should be called in the @PostConstruct lifecycle method. It is valid and probably the least confusing to
  readers to also \"unregister\" in the @PreDestroy lifecycle method (though as noted above, unregistering is actually a no-op).  For example:  This works for both singleton (application-scoped) and also @RequestScoped domain services. ","description":" The register() method should be called in the @PostConstruct lifecycle method. It is valid and probably the least confusing to readers to also \"unregister\" in the @PreDestroy lifecycle method (though as noted above, unregistering is actually a no-op). ","id":232471644},"235512052":{"title":"Usage","url":"guides/rgsvc/rgsvc.html#_usage_21","body":"Usage  The usage will vary depending upon the conventions of the design. As of 1.9.0, the usage of the service has been centralized such that the packages to be scanned are located from the AppManifest's #getModules() method.  For example, the SimpleApp archetype's app manifest includes:  where the three module classes in effect define three different package prefixes to search under (for d
 omain services, fixture scripts and persistent entities).  Other usages of the ClassDiscoveryService are likely to work in a similar way, requiring some sort of scope to be specified. ","description":" The usage will vary depending upon the conventions of the design. As of 1.9.0, the usage of the service has been centralized such that the packages to be scanned are located from the AppManifest's #getModules() method. ","id":235512052},"238546442":{"title":"rebuildMetamodel()","url":"guides/rgcms/rgcms.html#__rgcms_classes_mixins_Object_rebuildMetamodel","body":"rebuildMetamodel()  The Object_rebuildMetamodel mixin provides the ability to discard the current internal metamodel data (an instance of ObjectSpecification) for the domain class of the rendered object, and recreate from code and other sources (most notably, layout XML data). It has the following signature: ","description":" The Object_rebuildMetamodel mixin provides the ability to discard the current internal metamodel data
  (an instance of ObjectSpecification) for the domain class of the rendered object, and recreate from code and other sources (most notably, layout XML data). It has the following signature: ","id":238546442},"238979657":{"title":"New Feature","url":"release-notes/release-notes.html#_new_feature_22","body":"New Feature ","description":"","id":238979657},"240026998":{"title":"Improvement","url":"release-notes/release-notes.html#_improvement_14","body":"Improvement ","description":"","id":240026998},"242030985":{"title":"1.4.0","url":"release-notes/release-notes.html#_release-notes_1.4.0","body":"1.4.0 ","description":"","id":242030985},"243439147":{"title":"hidden()","url":"guides/rgant/rgant.html#_rgant-Property_hidden","body":"hidden()  Properties can be hidden at the domain-level, indicating that they are not visible to the end-user. This attribute can also be applied to actions and collections.  For example:  The acceptable values for the where parameter are:  For example, if a pro
 perty is annotated with @Title, then normally this should be hidden from all tables. Annotating with @Property(where=Where.NOWHERE) overrides this. ","description":" Properties can be hidden at the domain-level, indicating that they are not visible to the end-user. This attribute can also be applied to actions and collections. ","id":243439147},"243876171":{"title":"Task","url":"release-notes/release-notes.html#_task_28","body":"Task ","description":"","id":243876171},"244520152":{"title":"SessionLoggingService","url":"guides/rgsvc/rgsvc.html#_rgsvc_presentation-layer-spi_SessionLoggingService","body":"SessionLoggingService  The SessionLoggingService defines an SPI to keep track of (typically: to log) the current sessions that are using the application. ","description":" The SessionLoggingService defines an SPI to keep track of (typically: to log) the current sessions that are using the application. ","id":244520152},"246275568":{"title":"Registering the Services","url":"guides/rgsv
 c/rgsvc.html#_registering_the_services_4","body":"Registering the Services  Assuming that the configuration-and-annotation services installer is configured (implicit if using the AppManifest to bootstrap the app), then the default implementation of GridLoaderService is automatically registered and injected, and no further configuration is required.  To use an alternative implementation, use @DomainServiceLayout#menuOrder() (as explained in the introduction to this guide). That said, there should be little reason to use a different implementation; if behaviour does need to be changed, it would also be possible to replace the implementation of either the GridLoaderService or the GridSystemService. ","description":" Assuming that the configuration-and-annotation services installer is configured (implicit if using the AppManifest to bootstrap the app), then the default implementation of GridLoaderService is automatically registered and injected, and no further configuration is required.
  ","id":246275568},"246409050":{"title":"Using system properties","url":"guides/ugbtb/ugbtb.html#_using_system_properties","body":"Using system properties  The servlet context initializer will search for any system properties called isis.xxx and if present will use them as overrides.  Thus, an alternative option for a Docker image is to bootstrap the servlet container (Tomcat, Jetty) with appropriate system properties set up. For example, with Tomcat this can be done by writing into the conf/catalina.properties file (see for example this stackoverflow post).  The Docker’s ENTRYPOINT therefore just needs to parse the Docker container’s own command line arguments and use to create this file. ","description":" The servlet context initializer will search for any system properties called isis.xxx and if present will use them as overrides. ","id":246409050},"251015067":{"title":"myapp-dom Module","url":"migration-notes/migration-notes.html#__code_myapp_dom_code_module","body":"myapp-d
 om Module  In your myapp-dom module (containing definitions of your persistent entities and domain services), create an empty class to represent the module. This should be at the root package for the domain, eg:  Since there is no requirement to actually instantiate this class (it merely provides the location of the myapp.dom package), we give it a private constructor.  If you have any other modules where you have either domain services or entities, similarly create an empty \"module\" class. ","description":" In your myapp-dom module (containing definitions of your persistent entities and domain services), create an empty class to represent the module. This should be at the root package for the domain, eg: ","id":251015067},"255768608":{"title":"Multi-tenancy support","url":"pages/isis-in-pictures/isis-in-pictures.html#_multi_tenancy_support","body":"Multi-tenancy support  Of the various Isis Addons, the security module has the most features. One significant feature is the ability 
 to associate users and objects with a \"tenancy\". The todoapp uses this feature so that different users' list of todo items are kept separate from one another. A user with administrator is able to switch their own \"tenancy\" to the tenancy of some other user, in order to access the objects in that tenancy:  For more details, see the security module README. ","description":" Of the various Isis Addons, the security module has the most features. One significant feature is the ability to associate users and objects with a \"tenancy\". The todoapp uses this feature so that different users' list of todo items are kept separate from one another. A user with administrator is","id":255768608},"257661017":{"title":"AppManifest (bootstrapping)","url":"guides/rgcms/rgcms.html#_rgcms_classes_AppManifest-bootstrapping","body":"AppManifest (bootstrapping)  This section describes how to implement the AppManifest interface to bootstrap both an Apache Isis web application, and also its integration
  tests. ","description":" This section describes how to implement the AppManifest interface to bootstrap both an Apache Isis web application, and also its integration tests. ","id":257661017},"259358868":{"title":"Hints and Tips","url":"guides/ugodn/ugodn.html#_ugodn_hints-and-tips","body":"Hints and Tips ","description":"","id":259358868},"266250802":{"title":"Implementation","url":"guides/rgsvc/rgsvc.html#_implementation_2","body":"Implementation  The (non-ASF) Isis addons' kitchensink app provides an example implementation:  which is rendered as: ","description":" The (non-ASF) Isis addons' kitchensink app provides an example implementation: ","id":266250802},"267695496":{"title":"Building Apache Isis","url":"guides/dg/dg.html#_dg_building-isis","body":"Building Apache Isis ","description":"","id":267695496},"273843820":{"title":"Simulated UI (WrapperFactory)","url":"guides/ugtst/ugtst.html#_simulated_ui_code_wrapperfactory_code","body":"Simulated UI (WrapperFactory)  When we tal
 k about integration tests/specs here, we mean tests that exercise the domain object logic, through to the actual database. But we also want the tests to exercise the app from the users’s perspective, which means including the user interface.  For most other frameworks that would require having to test the application in a very heavy weight/fragile fashion using a tool such as Selenium, driving a web browser to navigate . In this regard though, Apache Isis has a significant trick up its sleeve. Because Apache Isis implements the naked objects pattern, it means that the UI is generated automatically from the UI. This therefore allows for other implementations of the UI.  The WrapperFactory domain service allows a test to wrap domain objects and thus to interact with said objects \"as if\" through the UI:  If the test invokes an action that is disabled, then the wrapper will throw an appropriate exception. If the action is ok to invoke, it delegates through.  What this means is that 
 an Isis application can be tested end-to-end without having to deploy it onto a webserver; the whole app can be tested while running in-memory. Although integration tests re (necessarily) slower than unit tests, they are not any harder to write (in fact, in some respects they are easier). ","description":" When we talk about integration tests/specs here, we mean tests that exercise the domain object logic, through to the actual database. But we also want the tests to exercise the app from the users’s perspective, which means including the user interface. ","id":273843820},"273985863":{"title":"addTo…​() (deprecated)","url":"guides/rgcms/rgcms.html#_rgcms_methods_prefixes_addTo","body":"addTo…​() (deprecated)  The addTo…​() supporting method is called whenever an object is added to a collection. Its purpose is to allow additional business logic to be performed.  For example:  See also removeFrom…​()` ","description":" The addTo…​() supporting method is called wh
 enever an object is added to a collection. Its purpose is to allow additional business logic to be performed. ","id":273985863},"278859977":{"title":"promptStyle()","url":"guides/rgant/rgant.html#_rgant-PropertyLayout_promptStyle","body":"promptStyle()  The promptStyle() attribute is used to specify whether, when editing a domain object property, the new value for the property is prompted by way of a dialog box, or is prompted using an inline panel (replacing the property on the page).  If the attribute is not set, then the value of the configuration property isis.viewer.wicket.promptStyle is used. If this is itself not set, then an inline prompt is used.  For example:  Alternatively, the promptStyle() can be specified using file-based layouts. ","description":" The promptStyle() attribute is used to specify whether, when editing a domain object property, the new value for the property is prompted by way of a dialog box, or is prompted using an inline panel (replacing the property o
 n the page). ","id":278859977},"278890330":{"title":"Build a domain app","url":"pages/tg/tg.html#_build_a_domain_app","body":"Build a domain app  The remainder of the tutorial provides guidance on building a domain application. We don’t mandate any particular design, but we suggest one with no more than 3 to 6 domain entities in the first instance. If you’re stuck for ideas, then how about:  Hopefully one of those ideas appeals or sparks an idea for something of your own. ","description":" The remainder of the tutorial provides guidance on building a domain application. We don’t mandate any particular design, but we suggest one with no more than 3 to 6 domain entities in the first instance. If you’re stuck for ideas, then how about: ","id":278890330},"278999912":{"title":"Integration API","url":"guides/rgsvc/rgsvc.html#_rgsvc_integration-api","body":"Integration API ","description":"","id":278999912},"282766365":{"title":"Object CSS Styling","url":"guides/ugfun/ugfun.html#_o
 bject_css_styling","body":"Object CSS Styling  It is also possible for an object to return a CSS class. In conjunction with customized CSS this can be used to apply arbitrary styling; for example each object could be rendered in a page with a different background colour. ","description":" It is also possible for an object to return a CSS class. In conjunction with customized CSS this can be used to apply arbitrary styling; for example each object could be rendered in a page with a different background colour. ","id":282766365},"283629224":{"title":"App Structure","url":"guides/ugfun/ugfun.html#_app_structure","body":"App Structure  As noted above, the generated app is a very simple application consisting of a single domain object that can be easily renamed and extended. The intention is not to showcase all of Apache Isis' capabilities; rather it is to allow you to very easily modify the generated application (eg rename SimpleObject to Customer) without having to waste time deleting 
 lots of generated code.  If you run into issues, please don’t hesitate to ask for help on the users mailing list. ","description":" As noted above, the generated app is a very simple application consisting of a single domain object that can be easily renamed and extended. The intention is not to showcase all of Apache Isis' capabilities; rather it is to allow you to very easily modify the generated application (eg rename","id":283629224},"285898371":{"title":"ObjectUpdatedEvent","url":"guides/rgcms/rgcms.html#_rgcms_classes_lifecycleevent_ObjectUpdatedEvent","body":"ObjectUpdatedEvent  Subclass of AbstractLifecycleEvent, broadcast when an object has just been updated in the database. This is done either explicitly when the current transaction is flushed using the DomainObjectContainer's #flush(…​) method, else is done implicitly when the transaction commits at the end of the user request.  ObjectUpdatedEvent.Default is the concrete implementation that is used. ","description":
 " Subclass of AbstractLifecycleEvent, broadcast when an object has just been updated in the database. This is done either explicitly when the current transaction is flushed using the DomainObjectContainer's #flush(…​) method, else is done implicitly when the transaction commits at the end of the user request. ","id":285898371},"286850218":{"title":"Dependent choices for action parameters","url":"guides/ugfun/ugfun.html#_dependent_choices_for_action_parameters","body":"Dependent choices for action parameters  For action it is also possible (in a limited form) to define dependencies between parameters. Specifically, if one parameter is a drop-down choice, then other drop-down choices can be derived from it.  A good example is a category/sub-category:  Note how the choices method for the 2nd parameter also accepts the first parameter. ","description":" For action it is also possible (in a limited form) to define dependencies between parameters. Specifically, if one parameter is a d
 rop-down choice, then other drop-down choices can be derived from it. ","id":286850218},"287120012":{"title":"Actions","url":"guides/ugfun/ugfun.html#_actions_2","body":"Actions  Of course, the precondition business rules described above are only one type of business rule.  More generally, business rules are implemented in the form of the implementation of actions. Rather than have the end-user have to edit individual properties of numerous objects, an action can encode these rules and allow only safe transformations of the application from one consistent state to the next. ","description":" Of course, the precondition business rules described above are only one type of business rule. ","id":287120012},"288377989":{"title":"Philosophy and Architecture","url":"guides/ugfun/ugfun.html#_ugfun_core-concepts_philosophy","body":"Philosophy and Architecture  This section describes some of the core ideas and architectural patterns upon which Apache Isis builds. ","description":" This sectio
 n describes some of the core ideas and architectural patterns upon which Apache Isis builds. ","id":288377989},"288392697":{"title":"User Experience","url":"guides/ugvw/ugvw.html#_user_experience_3","body":"User Experience  The copy URL dialog is typically obtained by clicking on the icon.  Alternatively, alt+] will also open the dialog. It can be closed with either OK or the Esc key. ","description":" The copy URL dialog is typically obtained by clicking on the icon. ","id":288392697},"291813215":{"title":"Raising events programmatically","url":"guides/rgant/rgant.html#_raising_events_programmatically","body":"Raising events programmatically  Normally events are only raised for interactions through the UI. However, events can be raised programmatically either by calling the EventBusService API directly, or by emulating the UI by wrapping the target object using the WrapperFactory domain service. ","description":" Normally events are only raised for interactions through the UI. Howe
 ver, events can be raised programmatically either by calling the EventBusService API directly, or by emulating the UI by wrapping the target object using the WrapperFactory domain service. ","id":291813215},"293860175":{"title":"Usage","url":"guides/rgsvc/rgsvc.html#_usage_10","body":"Usage  The most common use-case is for bulk actions that act upon multiple objects in a list. The (same) Scratchpad service is injected into each of these objects, and so they can use pass information.  For example, the Isis addons example todoapp (not ASF) demonstrates how the Scratchpad service can be used to calculate the total cost of the selected `ToDoItem`s:  A more complex example could use a view model to enable bulk updates to a set of objects. The view model’s job is to gather track of the items to be updated:  The bulk action in the objects simply adds the selected item to the view model:  If using the Wicket viewer, the ToDoItemBulkUpdate view model returned from the last action invoked w
 ill be displayed. Thereafter this view model can be used to perform a bulk update of the \"enlisted\" items. ","description":" The most common use-case is for bulk actions that act upon multiple objects in a list. The (same) Scratchpad service is injected into each of these objects, and so they can use pass information. ","id":293860175},"295225295":{"title":"updatingLifecycleEvent()","url":"guides/rgant/rgant.html#_rgant-DomainObject_updatingLifecycleEvent","body":"updatingLifecycleEvent()  Whenever a (persistent) domain object has been modified and is about to be updated to the database, an \"updating\" lifecycle event is fired.  Subscribers subscribe through the EventBusService and can use the event to obtain a reference to the domain object. The subscriber could then, for example, update the object, or it could use it maintain an external datastore. One possible application is to maintain a full-text search database using Apache Lucene or similar.  By default the event raised is
  ObjectUpdatingEvent.Default. For example:  The purpose of the updatingLifecycleEvent() attribute is to allows a custom subclass to be emitted instead. A similar attribute is available for other lifecycle events.  For example:  The benefit is that subscribers can be more targeted as to the events that they subscribe to. ","description":" Whenever a (persistent) domain object has been modified and is about to be updated to the database, an \"updating\" lifecycle event is fired. ","id":295225295},"295564393":{"title":"FactoryService","url":"guides/rgsvc/rgsvc.html#_rgsvc_core-dom

<TRUNCATED>