From 2682027796fbd9b7afa036c52c5146bf0e1c6fb1 Mon Sep 17 00:00:00 2001 From: per1234 Date: Fri, 9 Sep 2022 07:17:57 -0700 Subject: [PATCH 1/2] Add contributor guide templates Arduino tooling projects are produced through the collaboration of numerous contributors. High quality documentation of how to contribute to the projects can give everyone the opportunity to participate, while also reducing maintenance effort and increasing quality of contributions. Producing such documentation for each project can seem a daunting task. Those who are knowledgeable enough to do so are also the ones less likely to recognize the need for it. These factors have resulted in less than ideal coverage of contribution documentation in the Arduino Tooling projects. A collection of "template" contribution guides are established here. These are intended to be easily applied to Arduino tooling projects, reducing the effort to establish and maintain contribution documentation. This guides document the various ways of contributing to the project. It takes advantage of GitHub's "contributing guidelines" feature to increase the visibility of the information to prospective contributors. The promoted "CONTRIBUTING.md" file is used as an entry point to the guide, with links from there leading to dedicated guides for each specific type of contribution. In this way, the contributor is only presented with relevant information, improving the approachability and readability of the content. --- .markdown-link-check.json | 14 +- documentation-templates/README.md | 75 +++++++ .../contributor-guide/assets/checks-tab.png | Bin 0 -> 53644 bytes .../assets/tester-build-artifacts.png | Bin 0 -> 67455 bytes .../assets/tester-build-link.png | Bin 0 -> 27025 bytes .../contributor-guide/beta-testing.md | 75 +++++++ .../contributor-guide/general/CONTRIBUTING.md | 27 +++ .../contributor-guide/assets/checks.png | Bin 0 -> 40075 bytes .../general/contributor-guide/issues.md | 33 +++ .../contributor-guide/pull-requests.md | 199 ++++++++++++++++++ .../other/contributor-guide/beta-testing.md | 45 ++++ .../contributor-guide/other/development.md | 25 +++ .../contributor-guide/task/development.md | 45 ++++ .../template-choosers/general/config.yml | 8 + .../github-actions/config.yml | 8 + other/installation-script/installation.md | 2 +- .../check-go-dependencies-task.md | 24 ++- .../check-npm-dependencies-task.md | 24 ++- .../deploy-cobra-mkdocs-versioned-poetry.md | 8 +- workflow-templates/deploy-mkdocs-poetry.md | 22 +- .../deploy-mkdocs-versioned-poetry.md | 8 +- 21 files changed, 635 insertions(+), 7 deletions(-) create mode 100644 documentation-templates/README.md create mode 100644 documentation-templates/contributor-guide/application/contributor-guide/assets/checks-tab.png create mode 100644 documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-artifacts.png create mode 100644 documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-link.png create mode 100644 documentation-templates/contributor-guide/application/contributor-guide/beta-testing.md create mode 100644 documentation-templates/contributor-guide/general/CONTRIBUTING.md create mode 100644 documentation-templates/contributor-guide/general/contributor-guide/assets/checks.png create mode 100644 documentation-templates/contributor-guide/general/contributor-guide/issues.md create mode 100644 documentation-templates/contributor-guide/general/contributor-guide/pull-requests.md create mode 100644 documentation-templates/contributor-guide/other/contributor-guide/beta-testing.md create mode 100644 documentation-templates/contributor-guide/other/development.md create mode 100644 documentation-templates/contributor-guide/task/development.md diff --git a/.markdown-link-check.json b/.markdown-link-check.json index ea266716..bd9245f1 100644 --- a/.markdown-link-check.json +++ b/.markdown-link-check.json @@ -12,7 +12,19 @@ "aliveStatusCodes": [200, 206], "ignorePatterns": [ { - "pattern": "^CONTRIBUTING\\.md#building-the-source-code$" + "pattern": "^../development\\.md#development-guide$" + }, + { + "pattern": "^contributor-guide/beta-testing\\.md#beta-testing-guide$" + }, + { + "pattern": "^development\\.md#building-the-project$" + }, + { + "pattern": "^development\\.md#development-guide$" + }, + { + "pattern": "^issues\\.md#issue-report-guide$" }, { "pattern": "/TODO_REPO_NAME/" diff --git a/documentation-templates/README.md b/documentation-templates/README.md new file mode 100644 index 00000000..e7847834 --- /dev/null +++ b/documentation-templates/README.md @@ -0,0 +1,75 @@ +# Documentation Templates + +## Contributor Guide + +The file `CONTRIBUTING.md` serves as an entry point to the content. This file is given special treatment by GitHub, which presents it to potential contributors: + +https://docs.github.com/communities/setting-up-your-project-for-healthy-contributions/setting-guidelines-for-repository-contributors + +### Installation + +Install the files and folders from [`contributor-guide/general/`](contributor-guide/general/) to the `docs/` subfolder of the repository. + +#### Beta Testing Guide + +An additional file named `beta-testing.md` must be added to the `docs/contributor-guide/` subfolder of the repository. + +##### Application Projects + +If tester builds are generated for the project, use the template files from [`contributor-guide/application/contributor-guide/beta-testing.md`](contributor-guide/application/contributor-guide/beta-testing.md). + +The project is assumed to use a workflow with the standardized name "**Publish Tester Build**" to produce tester builds for pull requests. + +A workflow template for Go-based projects is available [here](../workflow-templates/publish-go-tester-task.md). + +##### Other Projects + +A basic template providing the standardized structure for the document is available at [`contributor-guide/other/contributor-guide/beta-testing.md`](contributor-guide/other/contributor-guide/beta-testing.md). + +#### Development Guide + +An additional file named `development.md` must be added to the `docs/` subfolder of the repository. + +##### Task-Based Projects + +For projects which use the standardized Task-based approach to project management, use the template file from [`contributor-guide/task/development.md`](contributor-guide/task/development.md). + +The taskfile must contain the following standardized "umbrella" tasks: + +- `build` - build the project +- `check` - run all tasks that check for problems with the project +- `fix` - run all tasks that make automated corrections to the project's files + +##### Other Projects + +A basic template providing the standardized structure for the document is available at [`contributor-guide/other/development.md`](contributor-guide/other/development.md). + +#### Configuration + +"**TODO**" comments and placeholders mark the locations in the documents where project-specific adjustments or additions should be made. + +### Commit message + +```text +Add a project contributor guide + +Documentation of how to contribute to the project gives everyone the opportunity to participate, while also reducing +maintenance effort and increasing quality of contributions. + +This guide documents the various ways of contributing to the project. + +It takes advantage of GitHub's "contributing guidelines" feature to increase the visibility of the information to +prospective contributors. The promoted "CONTRIBUTING.md" file is used as an entry point to the guide, with links from +there leading to dedicated guides for each specific type of contribution. In this way, the contributor is only presented +with relevant information, improving the approachability and readability of the content. +``` + +### PR message + +```markdown +Documentation of how to contribute to the project gives everyone the opportunity to participate, while also reducing maintenance effort and increasing quality of contributions. + +This guide documents the various ways of contributing to the project. + +It takes advantage of [GitHub's "contributing guidelines" feature](https://docs.github.com/en/communities/setting-up-your-project-for-healthy-contributions/setting-guidelines-for-repository-contributors) to increase the visibility of the information to prospective contributors. The promoted `CONTRIBUTING.md` file is used as an entry point to the guide, with links from there leading to dedicated guides for each specific type of contribution. In this way, the contributor is only presented with relevant information, improving the approachability and readability of the content. +``` diff --git a/documentation-templates/contributor-guide/application/contributor-guide/assets/checks-tab.png b/documentation-templates/contributor-guide/application/contributor-guide/assets/checks-tab.png new file mode 100644 index 0000000000000000000000000000000000000000..bfb2b029391207cc88d15297e87a0858911b39c9 GIT binary patch literal 53644 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�#d_*qi!~NpBJ4G#6R-8#H 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 literal 0 HcmV?d00001 diff --git a/documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-artifacts.png b/documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-artifacts.png new file mode 100644 index 0000000000000000000000000000000000000000..ecea9d6d732424dc9a4ff0c125ac938900b7cea2 GIT binary patch literal 67455 zcmb@tRZtz#wuaj{1P>B|ySrO(2@b*C-F4v(!3pjV+#$HTySux)`{nF?&dYte5BFhJ zSIzF4>#wfabB_NTV}#1fiX(o({sI61qQp;;UjP7J2>@V&u;8B~7ufN2pBFg0pX!bP zfYkdxKd=NEBpd)B1SCWRm0XukGn_rq#Xkm2K@-~B=QgB}Usu=i)%=!c_&N&TXEU04 z=<@00|29ey3V{3lK_MIJ)24Tj827qR@%9OvM)41vE@Z!0Xp^krXyLiZNV)Lb=c(}k z1PD=JA;JCrdwHS=xP23zVXcMw&(H@ao-ZK)pksso&jWvaIMp`zPv*-ZfJHkB!Cws@ z3U@^fRvU%`8M>Y~JH?|n*Q(fPK^&6d-F_7J~RGA|zQ)7ci&1UKttHe4v>S%>GI zZl39L;YTu%X)RW0vg(>duJRF52}62TG>{vnhQLP0a8fO?%H+AWYc=@ZOKOCB5fV4~ zD=(Ovs#mS{Ki>0@5D%_UhKs6yy!bJDM*KVSJP<#)oKm0-%S%TZSkSF6A;aZICHxs? zmt5^)MOFCvW>i+%wLH%YVQ%m@B&g=oPk^Nj5#AWol5t4URhh>H$E$x zdOt`4Xqi~@0L8f+@5edW1+$n*Bd_Z>6(}^R``%~GIkWnda(47H9y2;Fw^lgU7C0vV zJogiZ3qFU6@@(?TsookkJbrC0jda-u}>Asm%A-)gAM~n_Aq&oUreUWOT`vD>Z$7V?p73t>!=@bGr6^d|0-{u3w1(1pisvo9OV8g? zA(G!zyoozr!>34N3jUHAvwn%rQ&yULetLfYC0%{IdvK$}&26&%)B3$$bOK)*8^huG zrc&~BwbnZ8?lOP|RL;LLf?)=~@y-;`k7rW2cO$ocFM*{9a$36=i_R0ElK2HFkwT|Z zKCZ{CDQyxyWX0L?o{_8lOCI!CN`i5h#EgzDl5q95aCArR3~KPx)2m&wVoITN!6neM zUfrUlrZ-n~X>4pp(hzUMM)Wrz6@7R!AHdVd@Sd#JZQH!ph5?=NlpU+Uz`*GIsQM6B zOnX`lMk_83h1KVIxl#29uM2)YeG6K%c}BA>OcNI!iEjOnE{Nr`=afOmCDS+bN}4mf z6N_6is!tw$4tssg8D2JQ0nMp3X&-Hr@y{3?pPjRRMVP(3k+Pi)&)t*$eIyx!7r_1x zzYe=6Ilv^Ekg8@*OyM@NUHR_zpIW*u&6-*D4wCQR0CHKWiP6F4WL34;%ot<#mHO9K z3R=>@J`?2F#Ys0_l9r|>w}J71kky?_Q(g9}$1u8$eX}R^w1oz}Yr~U{`rpx)+d54# zV^O7S&AQ9J`_oIO*Co|i?HkcgFS}=t?V&{F6XO#jJT-SBqMy>cX>fSlhaWO*Z|>u{ ztk~n04Ci6Br->{y4<{guY+I$0p2$`f4J*Cq_}`iz1&&wu04 zmPsKUvoDfh<;NA%I^(IZR1Pxr00fj>5Jw!72afsl8qdcTgO@6F&&w8o0&_1 zZ=d%&;LGIrE$V5HQ*;UwhaU416|!Wvqxk-ys#S#ybVg_MP8x7VR1G@xI+wygya8KK z;R>L-x!VDyHr){5pG;WnRvBXv?(DCo;hxDoRZ>w_vC?M)CZNJv}+>+A(eUqV-BzQ@}Dzdpej5>l0wq4V&L@ z)362U#@0J*QWIl|7^1)UPah6cwVf`TqgsA{b9JstUc~`^!{{W&p|lfq`!TJuI8rka!=_JB!~>0|ki{T%{)6f_G8slAS!WS{j|o$U!}* zJ(3l_T2Z%Bj^qz1!0OpWoQQK`5yO@4C)$q3X?4HG95SwFrdThR#jHS|grQAew{+@) z+u?VE0pli_$}Pi!SsC)h0lw8%Fe4aAqpGA@aHrj>Zno!#WTObZ{`>OdcLegdBPZ?` zjX-(d5|8hSs=Xwe-eS6?%3!lM^=~uXD8pB`W&JG&V;FqiIeJ ze~0%OIz0e=!n`G zk4|M0Heg8OP)yIAFgRz|^oRCJ13_I} z-nggF>$g(a{(iEusDr2nS5_}Yq0DmeoH3Sv#9#+rkgZr*WpKt+03fZ;h#3oueK+{$ zOl^+@Cmi?y-q$J=;jQf{U7WNru_^Sdfes05$GYKPxP}TTs0i8$?bsQJKG@#}2V5@J>Ar^MaQ$PO%$`cwfr})&nBFoG)LU5!=^WxifIt2F_R4tbYW&as7_@L`i@~W|mTk1Wy zf{Ad%4DYjPfQJOfJYm4iX$e>q$dVZ~srgBIOyK<2d|8iil9dkq3lqXiX~S=x5X4E= zGbe5t6PBc&CPQUby?j03V=w_6b~g)BRN-@`ExSMHPZXp05QhJjtni~bI{Ri=KNq4s zE`>xav`-JmUqYaZ@pRvq0(QGnQy{iEZW1Y=3*{1OfkEI8=~6@C7E|Nc!_j!^cci+{S$=-&{+09gW5$gP_vE&2!BSLRwDhb7x- zEf_p?P^jwI>d6=>j3E!^tK)@t`1&vvj4>>n4Y1gv2HaTM~1|LZp_ zfd6_9C5ZppkH6Ty|GhH@{MU^XLI1BYVFUhaPD;T3>r?)Jn8L>qYZ9`9hE;|q9a7>C zspu5z4_9KyE)>WfM$B-(9QiD;*gRZWe`1N)0zsc#L1Dp9DM}C^)`~xOkz-`}dm0&0 zLq^b#FXV{fNh5h5H42CWc#sn7znK59%KVCtBjm)zjAN>m%r@7UTY~`X9G%G|el1OX z$36T=!jS8fK;b;c(&BnEp!6qQJSD>U0{HGk#a3T82a^YM5u$$)_6Lvsy3>R^o+U4G zjM%SJ*W6s7v$TG+cZ7=ZegFKJIwk}K@(E2v%eGR3I)M?(&IQcxRavmYodEbeIo@4t zWfe$+^#LF(2N00I6&nwC`3flmf!>F;xOu~ynsb<@y){qIwxi`Ds4%p9WvHdSCtFyf zq_8wos?(}h-;i|R+lwwiMCtHNn@$EIZOq$}ijh&;_p%We0jIlHb#CqEZ9gkTy8oIC zzQpqQ3q#Ua3KttSam2_Tf`uZCAUGh8V2F^eGlMRXjV1YqH8|U6Fj*KSZ!BtqG30s$ zVb6*CGjz6M#S+gamCFAb(4{7?)vd>zNS8Tra8=QOE{Fo#-)XZ*Y8IO(kMQyXL0Lt| zZCk0pcLEt6?)v6NftttS1ZNEMCSGDE4h;=@s3h($;IA)S(Xg@DS8;t8EHjcg3UYLA zYDb=C{XzK0u{3R(RO0UGkEI7?=qulRu)uo-ifnp85ssJUoS_Wd)uCe{;7g-zv)1ek z0RDO2J8cX}R4x}htkh)R0lRG_lc~Mxe}DdVnIJeFU6u3W|4_A~sw@~o#l#rI?=77P zdwaoPHxFqz9A{S4%Auqyb=~cn>k8O9SC4TeB(UChp=LDtCY9 zn2`tAzf|Y7h-)iqMjI3*6?!C<6xPX@H>`{d(-;~Oe_v=)@(_LwQ}wne9`8uj#lX#? zHMk2m;$&T6f7>M3d>E>~-QC5SU$aSizE70J`y(ny?mP@|3q%&$55wewx6&iMYQwcRK2O@S+rX;a{jn5$tj)r? zBQ!JvMRBAgiTozFpdpE#im@n}n1m|O!xa2C2ArTweVtgMwW5}SJV_`|BO~J~$!)r> zbJm^%2A#0TsIOlhA!^rRb|_A;u}QjxUkECB-SQga@UR(OL&o)wM#sx8zg!z?DH5&m zci7KbJEi{t1AzD$9Ys~5#HJ6y5)AMsO92Ja#;e_uh3(rIH~_G1ej-0rF?_%=Ls-J4A8;pC>%`R0KIdYb{ z4>wm)py+L<_h;%&@E(Z zD=Rbe8gtX-FtSoI&iOexU6SAcrM0GGiqKSvlKCCGW971*GkEIx*;y60M5;smJoRwN zi8DL6{QZ0?wWw&&lmXQ!x8tjmP2rUOsX3iue1pq(nAMoPL2m`H>cYB}K8D6Z&K+rW z57nWjxP<;c|LnkObcGA4!rHZk&7Gf*mz$ed3Yk(OZkC$H$|YlSr!$kl`X?d#FZ75=d$Z2S*>S4sw$M&%kJs7^3PwvlW9$|3Z$hb{wRC2pOrNEw zIi8J;PAj?-#a00%HS~^0!O&3T?#>POWfFaAJ>Mzz7LU_!`MDqBceEz0%I}^S@BOms zHpkP$*{-*EnT?!dn<9nTS|?O=LVMvzA%(R`Ax3S3;NOh$0&1+rUqpp9Rl_wlD8Q6t zK9?ADc-&;2Dgke6M~;p$NDUi3Y`EE^G%mP;0Q`w=wa&Sn-S}l{r!bK=9Ssd*3KTf7 zQ=w6B_EPaiG0lR>kUYacrxUZr>pmxh`Ux31wc173{^<|IOm^C7YwDbZsOR=Z4$#*% z59ZBkTx${H1(x?asC?%(;N9EkJ`gA3=e79r1+PP3l#?4HS*_2 z(ONXPHsB#JPL#tX(2KeUny8iBgGXpv|-(!g3C~Pc>>YDpC#;rJ6 z_V?J@`wULpJTTN8t{zkvnQ=d8iab5Kw zW+{1VuSh=dQ?8(pOjdKSL}tRm@ETQHImtfO@*vc+CW%MS@rOqpcO=xz_vUI)RzWxK z4;d@uiFWeK(!S?nuu%s3A>{0_xhHE(O&h}>XojZR%nVn^M}?p9bB^tdEOc(@#Lk^W z&++mziTP1ne{=@3eY)>NQb-?m`TWYr&I0wnd!zj#iXTlmW<4($bnXv!>q~eiEGt-k zHtY6=tvt%9ne_!a36GryhX*5=l@E<$a4(2^|q$gwdq6#B95Q!ZPnwvddLu;*buPG3oQ&e^| zAMSox6x{XQ~?ZIvyOaMz>It z;Ab#j4-{mdDo$-|ZRP5HBh$GuyeDEs2S6E4?nBATr;6AUbQ2Nh=M`k=4&ps~ygS3{ z;E}SXN_U5D%`>Lx;JQA=qkU-)9wO$S#2Nua$L^a$=?`2l8#{y*P#r&$2|$Wg+FNDR zvFV^X9!#Xwm~~yA_e&++Xc+X5rSRL1kIr6s`s(tz^$M|MbRO|~G)*zpYE7xWOBo_W z3>m#U{1NNiv_aY%0`xask#7=naghKm7gyf}-{Qrg9yas<5m@Tn#zZ4{rdgAuUh(Hu zUJ?;;(fJsS{=hB4GGBXsuNHd0x!MCYLGAM+@}Ymd0z)4a-Bi`Ih7YE?HihDAEX#3j zC%4<3LyG&PP!eAxS>$mWSk%^_Ov7nTNaOZLvl{HiXBE2r_;ljDYZDFrPzq*HRpc%b zBdFn3KVIs&IauBP3!Iud=ZylKHSn^p^iMTs@zlNEJB`adEpoEj8%B8SpKk@u3IfPL z^$o@XUL>%?MvTu<(+fidnFZ6H`6b&{VhyrB*E#-&v^)iNe2=$21Wyy!vyJ*yVCykE zCZeve&(!Q^YEQFs(Y)7LAF?hBnN()bz6s3c_a#0*2#=}G>bd3P`{8IUluF{ zMDa4T0RS_O%cCD1KM4XjJpConyHK8*o!;2=;N3{Azfn**4WDY^I9`OIy1q&n?bjcL#qPPki)z3Q@mEdF$tqB{J3fB#NdJ`uLwh+Dews;9v@Dwo zCT*Zw z73cEmUZYiSyf}gu==}Hix#J93EwwvVMmH>sn#WbjjD%&PG+tTRulhss!PjUYP{tWE z9|8cW?7t_^%pNP|WiViEZS3ARCbRmlz{4e}?fWHZ;)C_UH$jw8wbiBK*pWPgn8Wow zsb}^tn@Hl?UOUONF#(yRa2d_LR;xTe1`~JP{TwoypgP z9F>Ev4ETwosBlKDPcvS}VaT@BP9BU)XQ@;?VLEFWbT-fA7BM2vswxTe@`* z5Fy6LB;Wzfv&tcZ&_zE_Dji!p=a`2DB8(tW9VV(w<`hn@D?1&Vi&HLG^YgPQw_MtI zabnoB-Z2-LIS#CwB_&X0|G8{2oorLGDWHXk0|h`)3M|IDS>oH2HvW5hAuwj>z#?s0 zvxtn0;!SYlGw!t`hu{Id=Tt@~#Szk!ob*RESFFW0f))1Jpq83AovO|THa$KEH&KYW zBFRZ&5N059ow0vqq+FFCgfu8Lo1V06l=$J%pEu2)`D5a%oLjG95&X3k`^)DN-esl= z%aOtyBZG^bAn2yYjZRLvd2^S`*ziNjTIPshETWYKq?hS)x5V5EjQ!A5n~Q5EvWE7@ za0rgU@wg$c2TH*J0WE2CnHdUMhXfSa^$WWZD&Fa7KM17)M9mKm9FE&PQ zGAdcnxJ54L|igdbit5e#}^jr7RH55{fK=;-F?PBwd>hl z0acgf2TjQdS2RF8d3#7vsQtwT`46+uz$pHFHm_$v?{MrG9+%zfr*lq(HJ1R-((_1P=feiNR}Y za(w}b>BuQ=l3Ou&sMxPMQ=ScL*|}mX21idyn0J)teu!-6t4LjC>s@9` z%gVH9cz*h@+`7UutQ{>gn3i%ntUocVp2ua?*ap76m-+i3%F;bOwQ7Rm1w^ZXhu*oVEEes_NtBSHf2 zXzTpgj#FxQ7*T9yTGa979__ValJ(!x+1ta{^#Uop;{eBul5-jUvra~t=*y1rh$OlrMk3~hn~HpxQS zLY;66g+Ys1I%O0qk-s2ne9k<)olgFH;&Ha+shXrP?jH{>t20YnHs!E>O|S(e;M=oR zR#seIZaH~;`?ZRan3k2BI(_Upj-HDLcf5Tb=Nk?N`sToM#*GA583oA8;9jRu&w$n= zq~PpGc_*ri`mY)<;;xI}F8`B?9y{3j^9<|zVuB%j*&1}Uf}4IK`5#tX@a-nVEM z&iOgf>xFMF`hVb|kDR-^yA$`?-N4)H>;IC)T>`(Eqt7Jo0>Q-#QTDs|<~GfLp8at8 zKlJ$j28>S>j$`yfztP%lfol#hrsG9ZWJ1zU-imXyb%4bM#hCmrl@Mj{;t;x+=ym#` zZUTMslB1i*C&{LBi}|Y<5$m1lD6Xn6Atho94kY-KV?T7S(BlZfpAJM%!nijs$9{02 zT?_70_PQEv;))!?!++7}wH(a<3i&@>;QybI=o3Y^?fMzs;71b2r1&ns@|H>tUK^v}-xB-WA8ZEB>?0du~QogKsL%{SKyk)jKrJc(T1 zl|K#Thm($I1Ue`zL4MuFu>ZlmHefO{l-#>itp0?vYcEu@Jn3CL65D&V(H%{VXC>&3 z8hJ><4=myvD;iEAc{V2lM%Hc4FVXnriYq>b60pJpT_giEJdtn6$I8R>8D|Y?5*s>o z7msAGa<}lcN~TXiB)YMj6i*9} zgQ0P*m48UFY1#Olw4Kj=+NAXD=L z#5M>S=XOrZq3Sxh*JK^@Bg&P=y~1kx6IpS^teVK2ysDPWxTLo>6#Om}^_GybU$ojmW;lXK3xUsDK$HkKA#-dxn-+aZ4 zs<%4|-L;AiQf!}`$KLM z<5_t_$K&=1B7tYE_dylzn=jMl@lW%GtRI?sj!2L5N_OlW3nC~c&en0$-WhMW>~l|! z#+*#adsKzQCyT1Owy(D{6S{6EH52X2k7LL@8cq$jKkv_N=-61Dw56;G zXt>f`PK9KAJf>tV_bVEZt_Vd|;C!sZ2L+PII2Y*8KsZ#g$_J z$QFNRb9_VrXDD)dx``%l=A7-f+#jY5-FTDZO*tIT`S_BPRWOK_w&C&N`ecpq-B4Eh zYPCZp@ABM*9i>3;9YSt2?BP*&JRbJ9%}(<`bkf6Wx2{WK+wJ-Rl;q7Cx><0PEx(sX zr4Y+s_GN}F*O$1;cu?cQZ<|Ugn_Q8J*7tkin>g_?_s69H({NkosOHyQVFIfewRb_m zBqD?a6|@;Ti?gu4k^M**nWU&)Ruo~|EZmF5m-CeKZh~PQn|M@q&(~uNsYKbZuOSdB zt2IV*+v@8L8kcoAX~?H7dLSfoOra%d%#A~)(j1PvB6YsiyqYD;057GN7sgkLh z{W2YPAFGIOz+a||-6L*`@$H~+a2f?9CL%k(2Kr$J(=qR!MxAVWA?0<0 zArWve_6o|VhNy~jgVuKj3f)5&JIza}80ag^p`_KX8>{rs{olQ^33rt0db~cgDlCgwdR;DjdjRBKjA3go0W34uu`DK}Xg(UwUHZVjs4HWmnCz$jW)s}Z&eZ@I@-=Jv3M6t^=PM{7xUM>X-$rr>sO@vv+&H> z-pLr8M4g`{KXwUj=f1b$?vK<)%C=Z*=Fl=%da~lRpoVmjTiW?9plXY zqoG>ed!Hg$|GqlKp;tvSRab3^9xfz>ky^I5Sp|H$cImHq1J1Vp9v&GN8Qy3fr}}xH zP@-vXuR^E+JGhz9oV**oZr4rd-SIcJrDGHF#s!#$o4^9Z_csYXo6 zSSq8y3f6O4rP%OHDkqELDHjx5qLo#Yv$$FbA~G25jbJSncGD+pj_Y98Ajm&+99N9f z*<5uufeVktKgG@M!C>Wr>NG!HTSo6n)2)D(*s~+ zND5`~=#2otSG{=AnKids(%J5!0xqub4g+h!Ih`{uS3EDSP{!fF5SUbnyngNTw}Jo4 zZz0s$@p_CVMxMVd5Zs+JV}#2eIG%iD!d&aDDB}6Is_Aq!|GanVJ!wQEZXhy=hr7lx zTuF?YmWnJem&f(7ta`rD{m@awkr# zFR0P{gdW#cZ8{lb=(jV%)u09aGHY zr9Dz+L2V*iSJ##j$!$XS5Vx;ZT9(AxtFqYIBXIHgM zRumJf#xm>h2;IZaG{E0?D2dOb8rEl^DTl+uq|nO&)P~_xJq>e6m2ABOsOZ^ieV`U+ z&&U!Yq5ZcQ`k}`mJT${4ElZ`2{VECDa*C(uJCtZ8@G+$cS0&(8)vg~fv}-2+^4ix^ zvr*NfwtcM}9V#K{uv4z>zyc-@BuhtDg5|XFc6XpXwJ6wUrGf11n6c_!?4tJ(Yf0tzMh zUQeMebX$LF-*-LujHZ7ahSTbCwHPb*Ji-)`1t}R@dwk&5P_YZxp3{}T7H2%(#}s?h z9k{%1h{Lq`_vD{$ldK_PTUZ>Qx{lMuSJm9V`X%wNOgvmCI{G3#+-u^;*1x}5LoE~X zHz{w_ylfV$ZuocwBJ&$g6q=7u4M}%<&3@r`c{A0$_zE>pb=TB_Z0dD8*D}RCpP(>2 zS#?p!K>jp=3^M)|XmTLVKN=+km%ze&@97RrM{qGd{k^u1=V5Q{;T4BQ5xtP3<9g2g z;g4Q+&g!B%{OT$g@H{*^0WxuG3~4Eqa>*)vx-W-m=FyykZb>-)%rvHlXjV7)w6b)7 z)SNbhA{0}|X!yJ>=GoTM$Qkfoj#>}bi%B3(9HM-h8`xZ=u~rHcC|#2HUym(E#O4pq zeVzi=csB^S8u|;0!AFe%-~5*AJJt32L1M4Q$M+u7_nZDSL#T)y-F91y=dw_CugCR% zi3#svY^z~GtTcY_r@L1j6_G!d3W?D+OB z@B35t0dQX$i_Yw&$NTW_+O14*g4REN2(GhWr>00M z-weLrUdyd}3Lv?AzaJ{vxRs`xvzf)OJmh^G)HzFuKWfwclsS(Nc$r{W ze4f9ppJ%VZfEg|jv+cO*C?a27oSDq7Q>TmkOwWfJ_IxJ&KWj4|GYwf(l9Y6cSiE01 zM4jZ8a4LO5TEyI#>0Xes+^)+T3PrWPciRhtgn!T5G_Z5bgO13}u93ZT4jc6P?UbFz zpQB|(rN31Ft-uGX$m)0~7$>3ckINl49om5$JNwajTx4qoD=P`LIh>y!-2b5CT0S}m z4{t}sZE4P?rLIKDd%uIDS=|N>t|r@)ne|ZNezhi%9#zT5`;DKMFW7dm?OhuRWFmcC z+PYk3{cx#eQJ zx=>duv4l?I!(FcZw^mUZ=f4A?x9E#^O(R>Mm!<=1yW)MehVIop$VHJ(Eqq%u1)2)h&len?;aCeLOz^9(`F_8l2&JNLG{a z#?Gd6^oj9tdXgQ8vIa!%5Z%(EmBo4k?PchATv!>jo7CoK{#^(>#W%&Fb$emG)lvUt zT^mldXe}*~PGw!s=pim|P9L>;NTvjfgYsqKXNkr^A-AVyaaa~2_ECmF(w@1e8))j9 z>S8|VyUG7CZ@Ddx8zUuBRMT8xC}g2_v$VfORUG4IfH`~_i3bf((j9J0lyjL@_g)za zM+QZHZlpkSA|}o-{pjeA`GA>LrkR3hSkM5aa-gxW0!B8~a8&@`j#-cWvMU($Be`gw z%^gR6Bes3rHC{@+8(W_Ku;+YQZ}Ta}(vs^XicBttW^My&XfwiV{HJqAcw_0aIF{&M z-s^M28iVvfL~xaMJNZp+0uxwysC=U-zhm!?aNpaf(`?&+ zeQ0~3fKQ3nu~bmad^-}@>tH`iCLqflElDEKx>gi>x_tTUpTSMs*vaC>pzZ4Lx@96Z z*us$;&$**x=(t?X9PM975?i0X6;e1ftX#bqCW`XByViVR$*8*O+PFFIfuJxd>B4#2oCz>~Jgk5S zc7G+JZSZO;!U6vdE|yg$@ZaX(A6lw2S~>97-EOb*z7_Jf5_|7d(1m2-NvPMENu#j; ztSrDD&lE6_3-8;ggE|1mc!DQ~Ib@i`F?ZXuo{vIKFVg4t z4?gDk$}HbAI$Gu5^q$*SF#Y~EZ3Mh+F1jWPK5Qt-tT#Keds@(x{7-9+7khQn59MzY zZ=#WG*$@0Lr<@a|L%UOoncC_v)8k>LI^HBgUrMII^fu!Xf3y*Xfwo!>@JHxa)C;Ly zY-}+jUY?)kn1ij~PCnM%TAj3dXWOe=dZoQwjL+gUhw**x6GUw1hhDu4MCyhdJ2ZH@ zHkR%7gCt*iqSqQc0~!8Ok%zx6rUnc1JGDPQ!|M>w&+(}wxt0A*dO0r4iiF2x(_X%r z<%R+}=e29h52o}-*4+%3?4XU`pUw)SPr3QdBh^XNH?(Xfp;{KOIb(1wO&uGeG!-tk zS-Lk8*1!PG?WajJ2C_y!+xHeTABDS03*Y&Rjei+Y8t-ExrI1CrW*Y;@=bW_;DzUnY zjSm|cBzlv0P#)j-WAbYkpF};Pod+9UAMIl~bd?)FR!_t$BBL8@SCTQSA5#jyQK)Nt z$#lQVjl(FV00h8k9fq$9_eEyd$IJoOoXdj^??F{FuZ#7Dsbr51H~S!<5B}cswld?l z%9t!907P2%4u4b4hi0y@4l7B0z2M;Bq2tCotKVP8D%gSku@U%NHWl@P47jyBez6TZ z<_`E(Ifu@=RDNvGOhy(dy&2h$f?l=RDQ!0}p1w_COwov{n`y(!^>y#Gi@}zKHA_)V z0#kw&-5F#0|=)E5}%N1sAGgf+P(ko142bJ;JAEXZar3#xpibVPiF$n;F zRV-6RH%|21c$zAbNp2Hd=WkiLe;$1MR^Q6KH^ou#Y|%5wb3jl?EPuEOL9)>5lu^m%BkvJF13GtprZlcCE;XNQ79S&#*vOYe z6b1YRaDc+|&4&}zjiC!UIV0U~wnDrRtx#BiKVz{J+}^+MY-h*wy)TM^(&&JVnt;H* zbrD!xduh31n?biL5j+%-FxWTtElmTer(a}*5n%MQ)bgCou0L;&G@=hB3COq7v#zvN zUSKG>^1{7UZ@)w^vj>+HME{77?ocX!#tuu&G~Y3n5u%5YUMV1=Z;L*`S!O z$oAHFqL#F*HwoI|l#G2#!a6!f%5QFQ9-&}3)BmhyM+bn;$85h}@^HRAS{sXV>N;;51J?=wpa&C% zCmYXnmpSM0z+c}Ucy+fGoo8h=iHB%SR}OCP;PeL)AbhyANBvAL3(n=#h(zI^2N406 zMkEG?B~mNafL+BGkP1k{p+gx*=Pt#MR(9IYNWphh%QY*T49se!8}-#`KPa={Yb zu~e@=9Qwl&ztyKNefB-Y(v~)nlrB8h9sr0h0vj0(EgRrOzyV%yvfqy10Y)v7o>e5L z+l@AH&@AQ|pL_d^(Ly~(vM-Lrx{aZ!!Fu-lS9B<%n3%^Pmtp-fTP0_u1^y>9q|bM^ ziUMl6S*}KIrwPX6b7sw9thq`b+!*R>cc6BZ^`QqAjm z{e=nw07MK3RN)>ZwVm#0nndR&`@c6a7gzogic{RRwVvB?u>p-Gd*>%Ky&E`IzSt&WA1^}Hm2Ae9_0Q>JaX5L^w|8`@$O4Q6*Yu9v`UHqxmkjf ztaiS~p#Q0_+u?4L)!Z7;DutF;neIJ08yNR|GS@L0e*A8j3kLk+u>Bql2cU#NHs%hQ zz-&TWbehka)s?JiHryc=X{8_!Z;orQzFZES1tqUM7RSYsv_32Utx?UjY_iMaYM7|I ziu+`4A%QmCCk+gQql3E=G~|#(foHe%w$TSc^ir*eKLox~*RhilwN_qSKN2IIq+VEF zGdo})%DB(_c@30umnX&zI1j~%1^YvoOUhAsfl_>tkpmkV&rlgLyWPFZBiV*r6 zbbP5_LA=TBzPlIpV~qNxXm;u2Ytn8!hr=3#;*L`!GZg~DZPj*WkgAv&wBcEaM+Lsm zdq?zplgbw@sOqaO5({_im-pA(*MhO2mu8s->E0!T`Se4HhPJAK3Y8P!Ps$wL+!@~b zj;Gq@f;9u|MxWH+z3%&C&rHsD%71Bhw8aaV9Pf(MKAU5zAA1~oM9h@3h=^jam zXN%4D8&65|vimHyE^-llJNCVF&N7d%-!P5KEi9_QvNZSO$1uV~PlZJ9BK~k=1(A?<6t4 ze>1YSwYdQ42**u}k=mhpI5+u+!Nod=f>Ew77Ligwg00Fcu0Z(W{4=lj>Bv@KKS)UG zCmg;R!RNd!efh`p)A#2tb7uI$@PKX_#sRdMkZG@%Hdyl2+e>)ni3khF zWrS@3LdvSSSBarb(!gio=c>K+ZVF)!Ma8S`8Rg23p`Bj7%)JBE1eV&IR9=k zSaMR0lIb~GVs3T3D;IME#t1PvlcyBNRMA=REB>yRwDC@J<#_S>T~6;AqLM+%$u=E~jN|G&Ux~f@t}QVm-%PTLUo z>Z@2*@F|(jmY(GW4nVT5&*|Ub@(qsYt5y5${Fh5^+8C1!eUk8B2Xh(+8wM0F&J^Fs0k)&XV^5{D^jYEc*GEwn&Ykpk@TX$@* zjZ1i_=v$7Q)|^Nvd=?x>cEjN?u#xp1lLH;7@e^B0rOkt!M8QC5ALnLv=wVe2dVPOiXg_*xi_PViPyO+-P8B3b#w~-80a*^J|7)1R1oAE-v)yHzJ_fhb{P$}sDs|DCdiz3%y8HjW>e4(hUjX;@do@a;IVQ*&I zU^7};Ev~fkT=6u6U8bZ=o{11>zvUSWRzlRC90&UD@cX=| z-wa}rS6J`%zFpQLZ++(H6 zPjP_^Yn&~1F`mWeQUwS|_w$of=*_a1n{&=GUUPk@^yATA24nrDTyC$~)fO6-b>U+B zjA6MCF0!|(Js5Slz0V4U8$ELUud|K1-X>pARh|-PSS}#az7Wfwzieu6A0Cyr<+=M9 z-GqJALmT}|9ys*iqiqtX-ov;YKVYkKS?f-*G2d+POxTN<6oC{8)LOWk&@iCa>zuVi z#-hgt*}jxmbbp?GSNYR2Jg-F5eG)xjFX~B`UQBU$pBq^qx{+z!zER|a4;=zWQPnJ( z>-+IuK=GYw-~|jL^oHSZ#rXZ(^;iV)u!=3tY}y-vEx~Cz=k0zJqJZa+3hMOTqY(z{ z?!&gB_0}|cl9{J_okP8ncLQRqCUQ-8U;CSMO!ECNj&r3w%q=T6RGn|)++F_ZyrxY#cy%yG*@&yiPZ(DWq2h^~7(x-!gw{ z6vT_#E}v0_8CtcO0K3Pd$HMId8dy6jyc#WD{T*!=b66ZL{rY z$BI?8ARKE%_|8f_HacEIC&~{ojR+gAaky`Z!^mix<>=fh>PsI=_dUjCf;Yk6$yS#* zTybzdw1ivBj7v!EMTMh_|}@(Zn2$h=`S4bGc!kLhb2`WTdIu z`-Pm`(6V%fc3FN|=5*h>y&lf+D2KCg=riK&;*!b9F1Y>;!dndXcJH&nV=GWC*@LJj zm+f+suWiLgq!-?2L^XuEENrJnyQz7xc~$-I>Z01(s*zr;U9}Hs0ksdB2(jsp`X#xG z&BvVQ4-``#h;aIVTp{gof!)o+s!OjNmz=|0g_ZDUy;qNXAPNrU`o`Sy;zZfL?0(LB zl%H$99(?NF?a}ap#X^Oe1$(A?32u6t!KT|V(Q5`)sRR|qyW6#co%I~oB-6{%+ihfl z&4EP*I_VT^1kfhc0O!=E@VwCf`CqJyoU+m$4&fL*Zmv}vDZ&&Xho4x%I?IuS^IX+$ z4Xl*~sN&ruCxtk6CLK%JfE>I{r>Z73q?!7}-TKpcb3t z1U2CJ^3sB3ptWtRWDhr%v)L%ApvX3f{J`9Fkz%Z-+1PaRNx3p%z3pNDsmRA3hsNO^ zS;oH2W8jV-pNv(S3Y`j7pk}!YM}v`CE(KRb1|EJW3NJheNjTYQp-=luc`~b%rjN$5DyPZ!(`sSH-{Qc}J;pTZw~G%xAq?C2Kan4NrFt z_2X^FqEMx2Xlj%-YCMV6SgajE5+5xwZI)_}QmaAQBDt9F6(1o#vteg)tp=NcggGl| zZy&=Ykl0?9F!OW28X9oZ^-*IFldO4{n7gi)QPjHtSE$S$@7SNFtfa_nYV=| z-iC%H@V09+4j&ZRvDo?cF%ILe_p`&-bXHI3{dit?*J&ua-PD#5%XOzDh@xT0rnr5l zUZhD`CnFQ}yXW3uR003%j0V?y_zI0RfO?z)D}~%jO4b}-O}&gXzK5-9p502UnT5n- zvcEUZf*E-r!h$|WFT>r}gno)e%7~GMQBlT;kuW)9b_lE32tT-}WVT)eBb+%R3Zc>C z2c+%5T!7!@JthTBgDIxYpP!J$`xumX7zR0obLLTFG0y@8g0CTFE)%p`_A}U#5;+3a ztIMtfKf4pBDYpDSzuiiZqhgbCNZ3WmWOCYh$H-ME?qaL)8chz{vIUaF7@?;$qKKC( zf_ET^nn6;k~e!`f<@rd4}K+v2vOPqrPfJ87jAW z(E{0E%nSfUgtU(t;AI8{XAS(*-|56AotPCP9K%kp>Gde*A~DNN>4?D8AWJ)uoU18G zaYbLwUP@sdOYpUbpO1@UdT#Z2Us4`Fw=Axtgd%}^$8xU!tDc>oOdPX*n`@Vz3>i7I z6FFxg6yBJy5cc3hIF0)+4e7JQ1WplMOpxS(XT{(ra0y9#{gl8Jt&c6 zW3GfG@>=d(mwR^ihc;tRf8iK?;Sd3Vg$V&c{kp4)XG{#anG;hqrL~iJDoP6sbTgaQ zgT8D6`P{!b$r)v2VmXBi<$%G&#h!s(`PvSTX#z60$Xe|*J0(NN?DR|mH`iuF=txT0 zKVul-R_;6$tZAeSDjq`y>jjqJK2yDu1kbmFd01!p90lOMP>&_dhvJjlu>|e7d+hJm)??}5p28@-GZ}1!lHB;_i-{XguTn|l{vES&;m*`MLDm7{) zByHFS*aBkp#fDg+CSA%2Ft4st(c|n_T92g4E1jn!SG4WPW!jz?#(h zV|pA^Yj?np)h|UXMytji(;DZp5LO z!LIe-+kJIMiHNZPlW|~(&S*{M!w!{)Y`v%z1Vop{w_y2X?OTG`UrVQeKiXY9rofK& z_AL2B4WZG|(Gvs{v-HLMc6nFMU35cOy88V$t8G!a$p^vDpTwA~)UM?({p8i>NuroW zY1=VWM2@7R_KMlvH-~s!@0U&A^efd*j>}e7EPS30O^T%wa&#K$Ti7Xt(A*WlX2&6f zFf#s-61tm&ixa;BYQLjjXoH_dU{AQOjCt2SLTz@Mac|Jrl+QDG(9=6vnchXBN}lxb zTi8+k7LD8v(S_aXXna<6nwYR%bJs~?_1=kBJ0+_q0tSt`9B7Ms_phy*R_BO1q|gTp ziSy>lLQna8A5;Dl(t<$vo;yVpK0uCod<^+j7#W+AF`ot`|HzP-UHE@8L`yKlOOeh{ z59N5jQQ{BH(W`<)@S1TuG^i3NKqbws`tJ$m>}CxjUoygPgmBpfnR z)~-%Md-}66n@fra8#L^g1q=A6Oc4=8OdP>os5gp*U;@i_%t0>v6Xh#J56|GO2s`HE zQ;yqT zUmwjWbly6XR}eL+Ydansk*-6xOr6h zT?SV$wy^r0#n$K;#)*P~Q1J5uiUOl`nu+XBTd&)Ty+KGMs+{(Xn|T4Bg>K4lda7vw zZ%Ivfo7Q26>wcGr^k|8RQs`m`L&zdQ)H~Re5u_qg=;8=N@x)=UeNG7B1;3CfBVhZO z5#WNtwz)&%z*-p8qzHH!PDcZ+`A30%ZPd1{?Iz&cLJ%YRcJx)BM`Df7S#yB=kW$R{ zS+&f)S36hceyA_yBtbVG^nYwLEf7364DSC4zJL7OGx*VUkFWJO0Gev)e7)O`-Foz~ z8hLtn=VLIjST@ni{Lyytd`<=z`gvXXBb)`0AHirma@RPz(NU-+^Wm#9lj%@vWo>ti z=At3sDtB(+|HzrkN+Uogsop@ze0-fL;|^+VFTd*IqoVqW|KB6Z&oR$0KmI`Yc#QTC z)PH=S?szQ!VQj*3~G_-L*>I_iFY77e~{?_^b}zFvc{7*E|Ra5lDgbUWpE^Mi;H=4NC71 zn->@78!u2Mw#fgr&M%h?Xw49{;r+)=HydVb^sam=$gG6@nB3b_Nq>yWw>*F1Fvs|P z6x5jhuiB(_xQ)0?+9XO=9L^m|GH~FwsjRnRcP`ADJ&wk$1{D4ynAmslebN$D@c?dn z35&t1q))KND82L=XXuJG5%)$@1JLVxyh;$U%$Wpw6njP(PhrzZDSSy)y6&D z5*dsZ>A)z>;xJI3xVbgoQ?5oEpY{J>c0K{#8G!!WzZeL9!NUL-!A&Mr^Y7NJCQ-l-;@NXUlg^Ift&U)fkM!xQ z%0Mkh)1|pjN0o1^!7y%;w_r)%-dc<#P$3XnguE4I82ssD4n&V@ShOZ*9zrSrdW(if&F-)DU zbWIQmv~kexxk#qZ5x9ll-`lO~?b^`R@}CjpY~kLXb1%P{&HrmZvC+}V~|fIY+c*Pm@+c-u}8eSVHOq4zg1r#+<$O)$FE1K%3-6i|fiis-6(?sbcdRK${t>IB? z*OPI~Xs`hOR2#n_%ifc#N?RYnTRWa(b7B1`fsn)2Th&Fha>6;y$j}RJh9V~z2Z1Mb z>zzHMr2p+Q1{Exe$Ff=i%LmgixJT{1il<9LDy$$4=$+e8o;zX5*gFC0vTaui&dbuO zC6Sc()Y$X>vG}Eefw9kKAG*Xr4H%CL^}%Zwp?UT?Hm|7bEMW=??T%W>uC~+msfdWW zb04%srE+p@ZSR~5p1rx9ov;QfjxVeTVtep_!o9qXrJHA>4_7&|^)|Fm_U3+fw6xU< z(aMa@vgyIB@rNHj^I%rgG~545EU8SA=omaFQ${VyKELQ6?>E%w`|Ivt>@6HYsqa#T zb9_c)`gvd%E!|c?%@6_uLxfdhpe%r1WmrwqET_utcVbE3Mo%%#?JHkx62! z>dh(};>Ckbvd*t4R>;lLNU;A2`&&RDw1N+^+D+C7`qF-DZn~6B8;t=oGHAu^PdJ7d z#jZ3vbHrXT$psE^l*|~VwW-+d!6R3TNuzPa^x7=i0P9Tz#^mb6TKhcw>MuwWZPvN1 zfs<-k4HXbsoE|?TAfWCHQcT3&DTsD)u`E|NW&6^8WtH#TXp1ZUuv%?M(@9oSAck_5bOFR$E=?fxBbmKxoV8%@>DXfGkRHZ1q!KHh^ zk2)&DDTbu@>viBLDpwi_7^9P2x@C}KbQq@KD8?w!xpHx=9G0wj4F}*FY;M&4th>1(!u0c>kKo2L43}*=>oP*jLB-_Xk7~S11Wr(cwSu3)UeDr$aCqQD zlbyiw4Ct`ot3rdWV~M8u!r+pFR1Ya~qqp z>(I5z%5_@}x8HOTBWA2D?5$=F8}Vzun}ahe2q*X`Hh!+ZXEbCJ$$;Y5|4{4QR!cJDJUw9vvN(C(w|LzGVe0C$?{n3Yo(!KJMpL z0-7@z@v9Ts#nOd~Cw7u_(7!z`L>tnQszhN)`UkStnitYh?@&CjNyGsAsQnikIv4my zwKhjPFPV?7h@5spVRx977gA$i0RU=TH+9uUwbYp%|_m80F}`X zLhCr%ChO|WGIi;FSAJ&2y4uMNZI3*l}-!-o9iP4C_8hKjhfJ(cH>lyiL$WbK2EVA8_2}oo3`2Xf78$+h+ z=_cqTC1WDBb>E-P(8{T+H)s8j*!?OIH*$PjCq>>-#?8Paq(LXJt$Xk&mQFTDUV51J z^x@~04U{dMJ*tAnh#?`rVNip4DaZgMeh)!nU_47m|L$Dh0Pj)_%Tf(f8O(wZ*>461 zH@s_Y{TM?%Jc*x;W>;NlFLcAfhgad_>!cjT`?8S$Y(yy^;Q^0wIYaX=@#*O}Z3C{Y zkw!)>?d*zH6uY%u&fb0l_97)5*iqj8e>(FGddj4hsnjf0wL#*w{0~yGs(iddi^^)7 z=OF4wh?GceRA)9e|m5&dAnvy7`zI-FGyrFd5@a7R~_$dP|sH7IO#Z4ToE#E zA!kwZnhJiok)n_|_rL}3>=Db^VQQcvJt{3e4<%V8vC1idBbkh|zLBu^S2^IbOFVQ| zXr%`c_tgWIPbFPtwo?&jT0I*pD!q2}V3~#tiimWwMDZNX^WU36VIWF=TzAV-a#nJ7 z3b?t;@2uSl7UD8g$hmPV*I))*@Los|f4Q`_0OUNM9OdNR|F-J`=V|@Q+6yjzs=2U7 z;3OcVNv%~iLnht~Gt^I7mx=|iWM!Gkaps)_N4p^|WE(6Z#)VWBX_|D?&Pb5}^SVJi|ya; z)k1MQSwxCWUU4gIGCDxQ>5D~!F|uUIBW{?LTf1TKQlpT(1p2~a{AhM|Cq+eNg-smT zlCUJo)`lDR3r+WGZho-hFy7y!8e`wQ9K(pka(x`^Oc`J43at|q@9teFwoW65qmpF;-@Zij|S~zS#8z|#p+qSq%6K3(*q0&ZA5R7yaRg$ zhxYFzF<1aPZM8a?8Xg*li!SvfGdis?hBKR$L2uL-MBBox=D?n5MG{qnV+9xZb2%v^ z-CE5@cM{u-kq(gj4{HI0PqSdjK?(X>QHp=@i?lqCT(4H0&e%w>ftu{>-U_W@HgOy? zQNMaY88X4Lk+vTJvNa0@%Ds|jA}R)w9+Mdynt`e)X8p%4pYXRjXo0Q9{Y-*qTSn z%Sfv^)00!n(!fbX%hxVg$^rnRp3EUOE|JP-zH2r^&GS3zZs$DqTjyPW)rv9mn-orM{L9 z&w)C#Ht|9X6wsem1$6j8*FP2O|Fx&*myC|OJIv!@^Vr#^$O(?CxhLo1C&^`J*YZZ1 z0X@1vG&VCLk#|02O146OygY{b=~BS#P<|95J8sXi1q`H+9X9i+<}$#t#utboyg@Dm z1t)(JSP|rS;+$RF?~XOrP|QFhY{0)mYd244`S|$0J=!LC5?T_!q>y5AXOOz!+375n zY$h;w-`K41U@DJdOGc?|0*9@3n8UiujWny-!qnzGODun;k{C=M>Y7^XRncd#j6jCe z6+?z$9AIZ=*WKfhCBiLyKEhC}m|aobTB?98zo{aFW>lf+F0G|fvXm!aV-_i%t2E?- zg2;MgcibxqGm%_F|IY<>3=i}G7yBO=^WX22QLtoU&!ZGFWQdVwia4wiJ462QoNp`& zIIZZ5BTX2aEH!!oSZsn?7@Z6(e~PbOuF4LjcbHX;9V>z#@%_s2lDQ8h0aZ$z6uv_4 z3m6fbBDR{6-Dj@6r&{E6^kmNAO}yp&Io;1Um4;P zxI-WXN10*CiczgC36u!icEW;*uLO!UzleL8CJ?`5K?cP&_`Rea@K6E@PAfRBC;Da-3K@EW!^ul*z55tN$VedLHo-5M2G|@4EtLI{&(-TBT$5- zTHS^HFKH{!gIk3DXXP!;1h5SvpBGC+&jzK{Q{vWi>~U8xaY637JzW5r1Gsp0#W%T>K!&s$m=8)1Wf{^K62XO|-* z4-tqti1AMsl=quWGM5i7*X` ztM$h7S2j;&6eyxl@8H>(X8ap@T;OEaT`Bj{Fw_@7%m0!F=;l?>XNo!_W@bQ6ct*k@I?pa!Otu&S;d zf5}da;|VmYQjo+UuifpS?LSl!<>W5ZA1^FDP<`zD9n)RVG4S(AAUt}klpJD`kqF9BZw&K<+E>HZTl?r;3V29dchES zIUa_5dCNg|)k@5H@>?_+%l!#UQk26T5Y+Q5qcVHSoD=Jv8*oFCBrv4bv{6pqW?paI zXTi5oAEef;X{C$|OG4hV>HRqMpc0@TiaZ5;tnoYD1w|JP`k(p70#*qywzAePu6^GttY5nT+!1)XxxBSk#SFDTVq)PocY)q5V&95f zZa+^%DMev5GMrbsDnM=_p08c+=eHNQRBzi3xw`%`5-1rTY4B6DC}pv?*`n*9Zq9)yg1p6HwekD^Kg6@4YMH4 zmg~UtArIg522_xYhwqwKT`dG?uK|%o;KXl(YCAtd;eE%)2V6T#E4N%d-|2|NWrf<^ zXqMVT``AA2mUnSfYCGM%QDR6?@^@i=z#%~jZQyLXCZywN%IJ-Y8vB3gw#{m;9qDLM z8J?IK$EUGdJzSrj{EqLxV7%LD6(Xkt4GCrvnD;d^=cgcXXsez(p5vgG$W0$oC^|Vf zS|DcdD~XdCT@o&JsbkJbmwZ3lMBJ<(&fpYIO?5mQiB$}(ePdq2M`g+^n_$1vS%S{+ zVt2@xtea}MP`u02p~tIc7~{r-6Ek>Pm>@x-s>#S-2mNiR&aHH?IGAFklr}zH4C&?d z{t%0<1nU)z6C7L>MlT*HEPYnV-*TYUm-48*|zd-@IGG&x51F+yNUmP-=R~%IF1rc=uD6Jh62;k#?LXfS zVy#6`r3+F#yEHY}=E0DkcFqIj2(YuNs32kQ=4S9jG_+KnF+t|&?Rbg4>t)r&w>+!-N)GKixqV8D3j*w=^(8 zc;sw!L`lt?!w;Y|vF5T@(DOYc^Dx-z@Q@4u5;*c6>UwO|VrG224iY*{Pg&j&eVk7< za-6!~2Q=Me2sF~MJ2hXw;Ao>qBRZSf{$c^_5co6xr3N%1Gj!I>JymDb<;cdFr@2o%Xj2DNCJi0Tae^%jEp) zXqqZG^7Y6IeEjc!Zv%=_-}6TjcjLEFSz%*$5#GdGu}VGmI)3bp+$IdYsJwE5E}_+fB8i2(1R z1+c)Dco+59%47AL{Nh@i2g(@d!)7WoO}G5U-E&7I1UWMOo)-1Fi!~biXuZ2MC?`M% zP9%zlLdb3Wh(6o&z|5K<5LqN;eP(W~okK-}kQ=DS#r4|1rZl-hz^ahCqnt!M(A!8d zVVZA6u7tPepK9)!!&A`X82-24i;Q1nex!*Rfs#-8GJ2)jH4Bv`V&8a1;I$A6O*Oxd zMa)>=;jKxbKghQ!N$kibqi;YnYHD0HN;+Ap2$&=$C0$xdj4G)s*24~oXSRc|!z0W{ z!Hf|81Xq}X3~9ckj7l$`5Vjky8o?a+vxqtZ)@err9=#!oIp#9j@5RVrhFym;ra&_1 z7c$fr06A=*;}Gf9xXc;Ywd;acKy`U%Q$nh5pj3NjXu3=fhrV z#Ia9?ijt1qq(Ev}S{Mq4%OEX?suNU65txUb>r`>Dcjz^E!3&^=I7S zI*9r${i>^L3*A*Q9W<4@Z1$7epn#(d%sW4>2Vr1_%4?QC_cRoE{QI3d_VVBuqKnkVm$>|=t(GSOk>`o-C@Yk zvmAY-QDOZ|d{J1cOh?_?C>W*$?k|}J*db`#^2+FeMv!vx zqw`KOGPHv4R|3B`TRqK=rvV!qo#&r|G!`ZyV;8LDXlQ5SFm^9^uFl5DRDiFdu-oKv z)QMCn=U&%8DtSiz$K+H(2c7$wv&dnA+vwqBz$mYVsQp@jyJ7DpZII)NG@#S>sOei) zo)mtc)7M>-%kHZ?bAy-dEsdD0#zs$($y1xp29+d>Nqr}kAfqGNGwJGf5_H z>=+fum^k10Stq7x4i?lK}4^fLx#ngbOQW7U@6XD=4gbnshes za_Q8$GGNiKe|6dVkgxf0*_uF8{mZe*L7=MNWvw00e*x!PuhjXWUC1x&{q#+v8&e6l zjYhKlolK)mb{H@-5@VAvkJv_F+fNd1=eMO>9mS1!0d*Koe$(Q#W@*+VsnRG(Ulsp3ZlyCRv zUwC2YP+T@KFOI8Y z$#&lsuHMS(>>`AFD;P%(JEt}`&cDj<9UpN^cvOcI^wK-#9}yR&*Xk?M4wX8kQvGpi zqQGfEhm%1$|1kTiLFjv&z6Gk5OY>WZZb;eMcz#SJ^0oAF-b~}uV0^xw^lN(QguX@#zB&QvNDw9+MN7-@!cPk1Zih z4L@`|J3v?e@pR@uv|{=P>)qD=`oD&X)yh!8!s)V+)NA&VdyJ+~o|=c5`bOvIx6iv!ay>%9i$xt(To8a}cr! z`fml?LZyJ$F0w1W?xU#;%Z9SBG`8kq7T&x0qD^8Nx}*TN#obaCZ1UYM`;5z<0MbNA zBoD`YJ`Xb7+#Q6m!B+x(n}qx2k)L}TG5*pH8hwFxeG)23+Qsl8BBEMssNsL;>B0&m z3ZLzjAV~TlU-f-&7wbCjAEJ02xEGrMpJP%&tx9ct11Gyu`^=k8NHJvK;#&cdKG)$Eb462{C#ebFlD8I zm8a=%eyDICO$|Ad>=wR5F(e$SnL$Kp4HbA{Nbc|F`}ZCKzC(4w8d{$jsrt-%*O71| zip@et?SX}_7-RMHLnJ`z1bpu`gaTMKkdDrpm#iW88Okc;vcv2!Bh<$mUj603}m0_;uLTGDv< z7;5k)F%sJiLR&7A2aiGUmwyumeDMD! zr2TU>!iFvcYY6msQAO-9KU~0DL1f`XknbSC?1Qr(YS2$k&;N0g{@<5>%c4dO;lP4x z#_{8d|MEx3g7k_b1M&+mj795ET#*FDDuL={G!^txgN#1T^HC?VU}AtVS9|FLhLz7z+3^!zh$fAet|`rFlG*i2)me=(0y zh-qbJO|1pa@ed{*`UFPXzwTkAqAMi-lYf3`ntQsvW49+#hDbviz3=9oRw#gwslADO zThl{^6zlQ z5JVr=7l@v=kX>v5D!H&OvK8^TSnlS{%?$M~8h3nLBLeF|ql2qF$6g@49}BqIhw>La7{!e!k*3OsIimD(GG z>@H8UbH|uqqe2P4InNY?A%kmS2MVRnDT{Nm)tNPfObJ~KD7L*!9~8!n(8p4@^R7@d zcc?JTF{Q-`(}#j84lYmxOdLEK?v1TEg^AhqY!Mp%{x#;W3l+F&YY-91D>djSP*2`U z16MyvMsqTDKb@EQG2m$D92P&H3s<8xV$*WVz{+`LZbRJ$E5{4R4HEzK2lm>~T;!PE z51#?IwdZd`-Lw1HiK^AKfvYah1H^Lpf>eyPlef2W~kT@sN?QS?RE&12;spxo4 zLN4InBpo>wlLV*#j9cu-fxO@{5z5X6gWLi~6X?t5Ujm=QDqq9>onSM%Y@788eU-n51LTNX_}HZ;kDzERyQzM_r$X(> z&0r)`z)>ofPrR~nT<+9AI-%&!JbhW^NG%rQHtNI4~$7p?{_$KwFdeLd0?iB zUbTTR@T7B$AUP;h`A0$mZT76M42=uj`$`&FlUlFIzrmz2)w~2Dc+CYzA+L=#pwHG zj^y#P>;PgQx^prxg<=^)xFeoir1zTRRXJH(fLq<-E0)n-1pbK=IwSt$FStN3ercbz3GEV^&jNC^+mACRX9$-q9;Zh2AL_3vYJta_%$EUqlfvVDBW63?%o z$c*Id%uAaJDAz-4K=)R+5%Z-KNJB6zOnEkq>3WSf(zf)JW|5~b^KPma_rdE|Gu!Qs%ny1J;jPZ8p9$P z8d(I~mj(nJK1`NAW1zn_%sOuE;W^;CaM+Un@5zBNh22s8&^1}?x~FmN;6QF;&M9w+ zE6xOvo5o8EunA`PZwA*D3)x1h?MYBG90@A;-&4Bsv=0I}0RlV+fj|F4KK}nW;ZAKm zsm7~V0}Xv3<2z5h?~DR@SKvEsY< zLlT8E+nCUR@y<68B2Ob{Bu0KK9wPcuIC6Pb`ky|F|rxUD4v`2 z;UREx7K(gVLL@#~tXKiUn17pTyh*wxIchXZkmoE!a$t3>;O7>DoKlD=EaC*V1rHb$ zhnJ2af3s;I9d zKfZLJL;QP%1Wg2A{_b#FnhJQ)Uf~d*@UhM^y(z3D!mQNyG0c9tW@~BJ_V_sY>(>2h z$suB^vX2$8vZl9ilIt_3pn*x))=cPod--`W<#&=Z^XY$3D<>F8%I1H67Y#db`cM<# z{kk1&mq1kO?J03lSJUQ4kR0H3le>{LQX{$W`X|8u1=t9>`F*%`W6d+t(Q+S(kXNr|k~`y7zhzD(3|ueJ7$CqYHlvV$Ftvd13DOS_sF4M8Rp`}R6b z-{T2|SA0gUoZBNZE^iP2tD8Y@xSE^}XS0)OhOX}2+F1VN_N&cP^F1Z(2*i1TyVFuE zftT4ku>%kl5e_v7u{xllk6rs%KozZy0Vj7xxuKLY?J09hFb>8CY%HBX_YA;%$B^wZ zy1xwIliR%gnB@GhDKRuXSnnXxy&uCc5%f8XyaMEUt#Wd_9x{TiErj$c#9>L);}spZ zL<4k{|7~jO(~0?UgjPHdm7QDU}t*9M!+ zR%Jfx+z*XJ#hfY+Vw&wH&QMs0Q>hQ+Ikkc^WJpYWo3 zzRTwo471-FdLC{SjJG*H4os>K@2AxfGb)GlXx9=BL%mLiZNLSMH0 zx5ZbU@M>~0M2)~JN^BP6jPmPUm6NBI8;6RM*$L8yS)5*b!IkQ#qCnIZAyVDxvH8 z{T6h?=qdi|yMqw_gc8T7Jc`DnbF0Xkx?fX7DF&c7>&zfZSkeu9vZv+kmy8<_#{Ic` zd=UVZiY6Q=*0i?t_S!drnEmZ5W+d@MJw^+4N4Mt*)932ki3lu|?)jQ^7FtPELc9T? zH?Y8VbH3}H@3az0F};vA2~s4Ys2?(UHBSkfb&gGyHgO}0lm+?$?0G#}U~9wk@(Z}d zU}`L97BygKHONVSL#O)*TW7mF$iT77{w-I%ebhg_Ml`sh`A0LCY;4k{Gh`^`_2ovL zoi%6I=bT+auhR>f1=d%4e!rVo<%C@Cn_P~VN_lN=v+>UDl=1w4p?cNNjYcDDPJNJn zDH#xX79*8fNV~&7$;odE9Q>>nTfr!Ps?um=RA=Ok0vFXPS#}pWLxIM0n4P zl>w~I%*?KrueP~?itf7V`JI+tmHNeCyzXapF2ReZmy4HHtpZT#%7Zn!z|ZseA-4ce zYDu(}_UbOzQBS#(C)b_b)I}4G%@F0eNSK>;{?Xax?2M# zE(I$#TJyb@LJqR|)*dsHLR>{}04fsiNCx;C_yUPJ!vfQUgGol0c|S+UB`?xF6-t9O zDlE%7TYJO`oPvm9chK=DcaGPe#1*!soOk1|qOSfA7og;1d}WC-JFa{Y*H!GYU9M@c zk)4MUFF>ojwn-*6Yq|9_(%m$*P`Ltnido<{+^r*>acH+N$`JnyG^+FrZ`!1 z{=-)6xnov*0LtXL;8j$>R(3vXpRB2w?}Zy#-A!PZPiu?__GyMfA8C**RXbZgK#rn; z?oH9dwOqaVyINh<ZhI>GtUWv``IW2rx3=sUZw9r150_jTgT93UlaOtwC z$VGw}LYr2KwcsL{KJy9BEPK#ozRQ-GG4opAVRImMkU&6?07>gwC1^embXXTJA0^z*vhp;pfoed9C`t-P-J= z*QUr5yV{+mHa?+egM-FmlSFpW?&}6ggC_o~U1bj2i|>*DV?xO*Rqk1@e2l?>71JaY zD11K+0LY&D$WF5Stq;#s9%Ea+C(V(^+nP#ytw-(Mwbp>{Yl}#DlJ~C=^0{ND3iY_% z$8(O{>kA9}uKp7pD_UAw*+y0La}mhB%m~?XGQuq_pDT8s9=_;OikWOtG<>VHIqNsQ zTQ$C_3~D)w@yJJ?ccAwwL7&B>I$Z~^+D`Th<@PT)GTt0BY(i-?0K zoUh0&+9ntUC3)+_3>)YeX9Iu3uNuh)gAE)V{CpqUN5o>pDHX$|bd*~h7uItdy}fgn zUqymrh~Ewik2<{JxPvn?y>^|n$QN4I1*lH#UGK7((JAE+klA=OIku{g>_aC0X|!~v zU7FBM_e{&cQD&-5j`NHMwRfm|02hJI@WKw_0Dl*XAg|6? z^exFo=MGvj130r))zH;1%L)AOoU!+r5y~>gZ2b0RPD;vy4gXhbjrq%BWVZv5+uBHz zrEMqM35RH?(Q|B&R?zY{cFdF*{2lu_ugV23($lHu+>kb0i+AFISswddc7sy4*^egu z&IR20-Dvulrqrd5eC~m{Yqs|(cU45EHdZ@AeX6QUs;LPf>w8y*jAU<%kBxGUIPM~c zVD@HP_aN4yY3%Z~CA9Aup9lA}fBAu*RVX(y>FviU$lL%+^_lt7{P>K&4a_ThUC3p? zhm*VMx_)$QpRc+t=sti3^p>ivap)jt6E;K-$RdF}^$#yY}5v%F@-~4&2K;cR;exb^h z>WAsfV!7E^x$<7LwNA^_5k?XFeRKsiJPFp}9k5Euvo)P+>7C7&<+awv#~_r%b$92^ z)Z3XNlVF1&{tdkgSsUdbE{|a^kHZ3c6Cl#mPu;Tk{w6{U8|5wMj5P!kgE(LCg$};~ zg)t$3iqMIq-@Jmp(ad2$Ga(qB?=HUtE73qnqX7d=G=Fa+hwS||IEAUo_q>1{c8|TsxopUdN7GQuPVLJ(S3PSlnD;c{j%Wn zI4<%peN`JPH|fconz#_}yY!zn2=5Xn@ty|B7>*yOx3@BksH)NLqz^=V&;Z{e~^ zhq2XKU2-&Y_xZa{1rqWNu>9WT>Jg)8WCaM$J$>~tyxojb3X{aEJr4m{AnQ?f8LjUu zioPx{>QyV%$(G(MEWWICE%aI{Sm?PcQ-@;=R?<@A9O=k9(nmj(e3S#wM9dw8eG#Ws zOW|HH*$CIxB#L8Bao&^>d?v669*Ayk45Fv9c+3J`$A=ovbyWCntEIULU_=hBoTbN= z1EyhS#s0|bPBn2U4w!E^Y45MN6-W(#>rJhICvzcV#uw_rGuE+Ea1mE6L6sXC7lY6H z^rPlGx(Jx&0B?uk$%1D9|Bm2+;3Jv@)W73z3vd+r_ozt0$3v@ms2yZB9<4DRD;qz_ zPR3$)ml}91dGl!S+jZGzgu+qn>DTUZvvav1t4VQ`MpV)hXyRgf?2T&B1shT}ZErBF z8YJ#-cn^HDZ96%H-Df1zlODethkX@bjD&wVIkqyHNx$MDTty)Zo>tur+`zPvj-|7jvIZ+Elr{JU*bUY7%Tvb^SYeH?%t0?yUdR4D*y4_57Dtc9GZyNgC4p z$R!+bN9nD$PkeNHBZ$r(&h72I%1?-m5B?Y$oDL#M4QEYR3ci1PM<{19hEbaQQZ^YUzuw{bf&!r7UF?>-myT4wWqR8J>D*KZ zSKSKxmaQ-0@d2cV=gZEGhTA_YMYWwyKtHaQrcjdS#Ze~~owDJMA^YnKXrpe3kSD$5 zepkAf4ZYX@>@JWrm262NSy!C?`IE)#cKWeeVOh=3K~gw~h3qUtF=(AV?D%y02un9i zeQz%7YSNKh7`jrmV#&U-94?*Bq;C+ph*7^LFG-?M5>0q4RF&JWsm?$0x?_(Ht~t~$ zn;!%mN(@447YXjq8X^IkOOi*(-UDG2F`*T!RBGvi(oSb1VMiI7IC4J&*jQ7T2$`u} zYsNjuYw8^QeTAj9LnbaxiIE$zZQi>>d)$V9)ee0|{qBC@&cKWXbuT)pBI*L-RqqHQWdsyfe-~r+tvY{vhsS8Xi zO6>#tjwE!;>x!1#zu|?;|KgUh-)3i|;2{I5DF$BDna&>4;P#O&_AF5o!2hAddfcDS znd`+)$`JE;z@vqMb`QzkL@H35;4Exwkc`H*Oh))`4}e+U35n3r4@fQG+5$8~?ye0W?v9c+5+_pvn;SLLGs z*0Zzu(1O0i+E1=&%5^U*LV2?t+G{-hXh`iK zVu+|uB8P~gXwahi9C2LqvfghHiWpbFbwymEG!-pZ_VwWKW9=%|wO17vj-0b}*lBE4 z3Rma(9XIio78o_T{FfpHlI#cy*(DNL0n-`V!t$oEcs*NDEosmL!e1}4*$s3yfA8Jo zuGkR^oIF?-S8hO=A0co0z2B9VX?i!G-jplvPn-;tCHDC46#e;g8ypP8pmufv`;Szy zipOKd+lVwqBtotUezY&{5IE0W#IOPYtgI{zdnX6EYu1ThifD1E$n}yT0Ai>=)!r5Z zML#&{1b6}=r*X+WDT&f@x~x{V1Lf*i(yxw(lf8>gx~_kJDwet-a{q7?Yczbz7e5w! zC6kY#gd=ki7lRU#N}F0?Ws6yW#Hj*;^U=U;1#Y4g6qBhS zzdl5oG<9gCn&RO%K<3c}kcKA$EmTIwwr%g=AM}_lgDMxm*m?RE7SSFBWRR z>{!!3+Nh7bwV1LksK5#3WD!nvtm5;mYjw3cuOuY6k1s;=iYD_g4vuf#e3)V)0|F$9 zpB*!W!I2}4zluZmx~Z8hSv@gB4Eym{Ok(hJSW+_c!u!$C z{Mo?bqZaq-r<{`ox{kDK4@1@Q;ri8V@s+tj3Gr-h{9iOmm|{N44mAG>&((auiuBpE zCy%2(8e^{|wWY>|lr$C2W~>(0B@~5;cuE2+MPEsI0s|ejO%r(qEDn13m{$HGb%`Z- zi7MAU$_2Tq0ozHIl_T&9OS0P2?WOM{vEE&L9e()u(?yqXrM{@XZ*hi}W8unVRkxw! zq_nwUf3Vy4xq`PG6^CSEbW~-!Wb;~FQHc(VBTcgCdzND*FcBC**OE>quKNcUz5pT^ zt=$VD&|#kpUYd$kfYs39<9+D9u;`1Ijva=GfZj2vM?u8}*4txkqZvY4(JC}GlY-(z zw%kjfcWGf(CHZ2Xji$fe7@p>ECr_bg!z(61y%d6!ZnW0bzixz(EUDu2Hy}*m=4YAl z(}KA1aH;j@4ebksjvY5=qmy${$x^o(rL;j-b1pi?L=$=<%jx#6cYwcFjXgp@9(7_T zYXL+c>AywMWPHH#kMDnw7yJt*sS71S=x=(tvg9;L@0x0DEXO7{R!s4cy(_Sb3@d4? z$}@Q1g4SLsoe0zuPzZt+MpM7?fC5UFsz!dN_EB_;)rb8DmRKXgw#WzU{tKPddH;*C z{tu*8ZMLj{q)Y$909*v4_-C@B$1Xqt0{{lP6cIUbca+lCa6$RhKY~Gt{`}yJ2z_Ux zNgH!`7Xah5_AF>ovee=fEi8G#XSyUnEAzoMtcr~1)crsraD)WjN(C`B523TNhfy&x zu&-7SO@(&%=iOmGpOgXiuP8FYeN`FmP{^J>XCPpVl}#Kmf4RYXA0`0^k2hvOeM#`D z^f_3GED0LS^o}FDL@XjNzg2Uz4B*^@_sqCenheTD&3b2XC5h0ae;IaKq7mRlFera{ z-PcC~<*{zo2B9%&WH3VTelRv!2qhP8H(wt#zqd?o>>_#O&le|1Ly-`<>qpZ3z1>7l zI1mraqXD2j)=Eu}GiCb#l;iiTfFq29pi;xw-Lkc0m1ZGK5r$j3E ztH>HLWA4I4q|j(&V8Sq>A<9BmDP`@Pa7KJ`#2mvQg$;s8R2`-69LO7^qVB-u9qndk3-MGyIOslvp=TCyW z+B}-V?Q~iT_yqlYdeELbdeiq?=DWQ&+^!4Bya6W2XL_AnNED}?t<^HNXeEkoylsIT z1(Dj$PHdjfJNDE%7zjCcNc;)4GaueUp}_TK=EoN#xj#$a(+gmDM`J@VBnA?OnhyrP zbxV|w=w80%u(a^;uq}i}SUMV6kpw}m8UCAT8Tk-VOZO6!=3l`6tJ5Rw=(M6S zRaaH(Q~E#OIVmf+c0v;nELla+9h%o(I}6&fW2L?+u(T1Zt~_$FqgPuy|2Z7NCIQin zg2_3$IB8~DaF+qKujU)N7u|PvGbb-Z(hn3*j`Gr#aqb*;JHk2g{;4c>kjGq?-f zI&|Jk=1SRxcX)3UAT8a#dxwDt6L>rZjSG@>=3?C!Q=jmhGjCL&f_F*hxv zWi|Ud3_s#mN^2Y~IN&-5N0U1&dZW#9gL*oTn?-(cRdL}AHmgL@y$mZ_R>`9U%opW> z^ur=L_2?|IZ^SeD0|t5EjfhJ+_eV>>UTOxcBpu*85C(uG{?Rky-|ah158#@1Xq>xv zEJL=AbmGKnX(3*_-FUGkU`Q3$_xZkXH2mTuS42W;@!>O|MshF-den6_A6u<);}I>{ zuQXXWDtP(4Nxvfa+&;o4v>0F=$-&^^tok?Ea3#5^Q)1rd;fn62XLa25WL5$_kHQ+K z>wWKjT+^5WFMceg@XtbOGCo{kR;M*55x&bK0s7aoiAr!^MeIFd-~LQ$DR4Lkr*58et~T7LVcind#FAvL08!=$XPTcrZuOJrPe7- zyMiaguv0(ToNbER7pyLB-Sip1-e#}@cdAwA+NnKSV@5Gfd>#TCeV{_up9o@3omsc_X9n_ZE3fP0iKK=|sWtQFoJ2)3@-cm3Ip-h3_y{c^3I zUkKB96zh650%Ru{5j$aba!`{ypCY3d32hyC`Pa{}Hs{KWKiI6lwU8_J*l3FPMC>$R z#F+ET%Fe9%s!jYsC@`J}_KyZJwx|PQKZOS3lIHejYh$Qm*}jjJo2O#gajk;APak84 zmbzc%&(mgWHWs+>=i zx#~DA;Og}1s;h!#j}j(t54WzKsyM=^BPFtV#vNZn_$A;2(U3yPk+q}~>9gHhmX>_i z$>g^_l5UP(C+w@4KFB}Ot3m*i@-8Grsopn;Tu4azWT7k@mY2tw+NB7Oz zHqd10xA?hCqpHJ}-S!6z zAMTctt}VbH`3xQ1dXK(EU%%J>T~i{TQEv5g_TvWxU{Zq`8tPtJXbj%`Cgf$OVgHguEC5A7+CvU9sPS(&up}9T4WE;ko?Ql53eL+tP^F9 z?T1dX6KP>;*e$ARS|^=k`b*_xSH2Vrf>uDOc$b+)@f%c|*^*llbjfL}MCj0BDF7*6 zDES_gc}dsx_RY)qj6g!Y+PSVi760v}v8>+9xyQKfTRuAg&8^9&%W7);x zNjJxOyE567M6hR>>cV?xeR+8P{h7a}r!{SU=>2>{&x)aHQ34>OEq)$2Qr7hC>EGKII${;W2xRy zRPZ85Z@lu)VsAZxpqkd~a2a`!&*p(9h0c26sM%0MZ@1gu%}?26;FqC7eQarKFc6pD zD@|`PiGov43nnMuhOrJ~39LLO9W<+0JXjp>wvOe*4aeYB_iq;XGwn+D_U0~UIkMSo zrfxZSSmv18Sv2PMG+w9KXFw>&PPA6%GDpVYw|rrS%Ba&ZOBGjY=d|u~aAv94Bj>-m z7#TS0#)?*+%VFCYooo?W`fit42lHD@Ar%4{c*D2D7-!PnIwD z82UoIm4um%a>u3tGk~6og_fb@2xu^IL%RB^v~zj|_nv1}u5!dr$v+Ydg^e`tO&+K- z`&0Bau=lw_bU17b>_c?0kwTaX7l&}*Gj22X7h`8fd4w_LBtY?gnut%DqazQL+Ro*u zIghGe!cB~Ix(c3dI!$XPU*SYuL2{U)<_aq*{+Pd;6Dhi{6i}22z@|r>zYj6D`n#D) z2IASnI4YMFE2W8Cr~Xh!+#FQBxW!=Eb)CU>yIou}gany`JVEh5z=)o9t;ZgRT&`t< zTziuaz{&qrn23)GYw68v_)DT%hyU31ORZOW#^>` z?igxmGTrg9z<#Mi&T&LBVKImRW&R=CZ7x}FJQS+}-&E$pl*>s}RoB^8G>SU1P7(dh zyCh1tKk$7Y%vCTRUm^H=*qq7c#M^^YbuBzl{eo1W8YBN(I?H3ugSVFbtXF43Kre_! z_v7O&8_YVrWnSp|v-Syo1pv zDd~#y&GS{RB-iBIesIagPlxL%LBXEWTTG{$AO!*UX;^LZPHD8ZO&wZ23hnrhu)O1cXDXrQffO7>V zCTzVgwqXxgf=`ocsdpsU?t|;|vOFr^+1uUM@4*?UcaFO%^~DtAM4SU+MM~7`Q{AFW zmkWB|2|Dp1#1=-a?oEDXj?1HMV+B3ldY$ydLnaSf$Mf*_nF>KIG{P?`-o@h`EO%x8 zH5vDRoD;;S?B>^9Wj`XtJK~Co$HMY8?L`y!Lt+4{Q0?kTBl zw!xKOUm7ke&FfWY(tBtDC>5+VN$Z#rw2$#v1xS266|!Rt36 z9H8&}^4`5zM)VM!b(g@0XRb~(H#ybp^o->Ne$nX86^!WL+&I|ZJ|5NsdVp{hJR*pt z-P@U@Imw>-ogE_8mmr_RFzAx7>;I(%u-GygfS*D@426)W-U6Zkgf7)F2^DWgG`h>* zufC9!>t2nj!+mi~{9^bg21*v2QMZeGxz_&F)<1Ka6CEJt{x+0rm;O3TQI~TK4*aKt z9v8;SRZPB(Mzf^q3C{ESLsYLPpcwmZk2mugd%8?%qOxy3cX_-$o_~|bK>$FW(VO|F zn^rQ#ccz{V$B$^1=G1xg+dR+B{WwC4_t%P$4V%?W7Z6l`@WJ&lQwO=}nTyK;!U|#a zck1%T9ny!ZVa+5zvHNJSEsde9|#}lCQ z6lu6~;#e{hw+p5|T#=aI154w_s3S3<6Ue2jo>eMIc0~cqJf6d)yL~)u`)45i`IQU^ z(m!vd@9IT!)S7C=M$lTtI6--6IEe41D5P6Wbood~W92{T+A^zWG5yb`9Tz0ykdKL! zm(jsW%Gvn%EDMnO+BkAV6n^qwuJ0Qhv|sBwXC;FX9{-+Ks*EB8#sedYX+m@uBaN(# z2<3A9=YAN3e-=}$P}8)Pmrm43LN?aZHNr z(7Dd5A(fo~<4}le&?de@#0rfIB6&t}5Pl^9Q?hUdm%-daSY;?9nN^L!Tnrrmtx!VI zG{rtAF{F@}^1V$Hl5DGvM(O!m28Yvc%yyq4j3&h~YRJ(s2OqW+rN7r65JGwJb8HNu zt+JH(2Gm|o&p%H~Z?&`wzHY_NikV0hTkY{{s#kLimd6BC1035e3Y7c{pFAo#Wa9rI zn{oq43s!8LSIfkp2kPkoe@xB11ofJFvAzTZ0%`E*AkgT?m|1m=f>D5u+r!au0xz{} zbQl`No5PN#vWq@9x&ys5&ed|GNQ@fGe1CIX_Ewp27)Y2eGmuhEJuw1K%iW9cQj2Ir z@-;K^HSxqT#v}HkzvXc}X>*(#1{i5*CTnii+o-2Ur_k)c$wv#^-hW~mQ>k-bPf2$d zlRy_zVv~C_yDDRmX|X**^sVtb+Tf5}p52%nz>{yBpRrPbdNEnfVl2`j{!Daq1*1w! z=?&4M5xe92F4VXJgb$n|nYWtfIV-#H*gQl^ByCYUR~$=*nJ7w0;i4fEXV)>&1 zDciKc%0hOWgxBGipu_%5!S}6`c-doFH(gAnL00Lvk^`T|J#XZ)4Q3r~3Lo@cRC@>b zNOA-~Xvz#*)%RiQNFY20z(ZYfa*|(8&r8Dp{BZ*+Ov}a>Hs;*I_D(Y^HXf~v+wpHc zdGuSu9G_mUUP%P=ag|$|jH@s*0!^fo=WCg?BWo%+d#IQo(R588)3w`3PeIOIlXscf zUtxF1yLa-cid};Ys2{gPTB#x;6=tTFoe527knH|Ain=b1<~^T$HAJqG$7hjv>pNj0 zPAl8-^S9pi=H_i-cwRO_(DNT_<>ysTb-z4%Qw8+mDx2S}J-kOTnIdJf`VH=iM{V+r z)6P;&eY>@E!_X(IY7{x_)Wlm6!2$_OP;cznEjzaUe;SLe(z zpE`tl@&pxtMq9KE`G5@{Dkl7$W{(xmTWilG{u6)weu&&&hx~geGbX?PXwU<4Pda%m zM@+f5&D@@+?a!}iU#GFC zk~?y4XAR2=kFzEscfpUeLgF*;g^ZWU%mq=sxBk`&lTsXMNWHDMAGJ(q^Q9^BEu3UL z+a(w;K43dEiHe2io{HJIIRc+Q!;Kbz!(;Af)Dr9{EhUg4lb*`PLBj!uo6)cNP4(nxHY2=fcsk`PdoyL8~ zvnSx%*?(U$q;_EO@C7eg$~0Iwewqk?CZ)csK+vA*sHs=gu}*X3k|a~>-5#ftU`^v< zME*~c@NCZGd-MpX$s(!hcOTu~$tT<1?F1YZQL-_My8IM_H;|iVuB9o6*%Av4H=za~ zz;ntmto-rq3K2w$Vi_l`3m3tL__oW7RG`6fj*lLqa~3et>kLm11~K2@hL_0CJ$bND z-Gb$V2_th3Y&b3Yuxo(?zP-G%xxmg`ob7&W`!7t9EE!VVK?RksqcZ^p?q2MIji4i! z)>=D&ZZ)~eAUqZaY+L?!ps8BsxYcK~fdwIn283sg@i021#r^-SBlyP)cwq~p>G~G1 z(D~6}NQo)92LRzAnU3szG{qzSq;h~qxZvektdbxZ3cONr%hLiHG?^5+bi7OmQjfyFi=@B#(O|JkCqkoN;Pp67ipDJ=W{F`0%h05WNuyEr zzRcE0NucdgqG{fcJso7SKb>aMi7yV3go2{xuFr3sRb$N5!iva^Ikw2m`GtF_!00qSQg z($<&64Cq+JdFlIaAt^g>87C%PlBIY8Teg;^78TdJbH3E9ea@Yg>6NZ2=!k6%bBLm+ z*%RmZd+7S2&G`*M-;^W=E%$z|^l;dSgKJI?vxX@W?K8Z;&Sj`uf1ZPl!Oh8`4&~!3 zAY%7YF@r`gNV;d!XrM40VmTx#07QUA>Xvp*9E%*e0(bSpoSufamxiKngHLNZUe4Et zj-tj=WVBT+hxK0Tem*@Oni5d*Jr%!|+#8D;7Z(pdJ+UaDiyTIpFbKA8olxHSDce*^ zR~X?HX<4&TS%wU3GFGLSBjY9z% zSpCoGOZ56}f5ZKIe?ha@=-z==f3Xa%=&a#gOBWLAi@iNFTI4`VC(7`a=YpQ~JvbL9dL>u?;t{OC_f7@3AuYFJ3eSVm@9em>u(tiXh@|*X z;Xr>RAagU2S`X^RN+{*GqZ$ntNHP_d?Ji z;0(L|CC$Qwwm@lf%fj=^!Wq_j0t%c@?zkw5{VKjCp1V$6yfmZ7Ga;(kG+(<(EeJE@jw_1$>0HATU{&L~*016p0d*G$M_wtZh&%=s>n|eQKdfury zwM9W)yx>*xAENM=n|~`!i)^WK(|0{gILKAW)u3NYCcYo@o2MHzx399Ot;aW(kkMJ* zuzC2A3+F%bu<3##)9R`6{7XQr)%oWAZMBkyBB_z+ZjT|hmW-8#Mo;o`<9a)z_8WRd zNm`W_i`8}2=dgRl?XO=&zy$Tg(-LyBw$<_J1V9J_2>1^DG$rldZhlAzSXTG{v+w>s zAG#32%Zb_4L`2kZw>jMy8D;eYP7P&t=NuB5AS@dadYgmKg zteC)GP=7WX=~e`LiU2gBs%chhw_;KxOOQ|GG)IqnYhRPpbDzyRmd~ofsv49jq-we! zf4@}Rh+qV-j&Uqq8$Xx0fpg%mZ$l?1Y5r}kwF8bmb3?f{JgY`^nrA3+MFW2y2p@e^ z(?P~fD`%-3J)89(4w|~UE5Geim-)`SWYvgDEvPH#%POqhxz>q@QqdMs{&7*|$FQsG z*!IJcfLG_)&buP+7L=c5DHZyguPY;}=Ai!gbY(l-%(509TQ&QKJtyPm`8?!{&Z}z% ze?R_-VK@DOIV8C@A7KPi4-5C1;7xv3nT6Y#$gZQLc{#?T3;&N6{)e3hchjjDyLHX) z_TQuwuzAWM_i=JxK-~);x($*HXA{|Oo7vq&;vjvMKX)hEsmi1`FWS7FbFS&k{S?gnSupK@5ZSR5qvdE zhA@8yn`gPGE+GF@frY7v2j~c2tZ|OVeJ9wr_X20le@L5tXYMKOpdO+A{r(FV<@xoT z6ma0|gkV*)M2x0Tl)!iQf_S`h(ep5vUq#>}G7Q3Jv(k{Ujm+y8wmpsiX%Px7TDWp_ zZDph+iA1u<$uDg#^DS~75THjyGoP|MpXPsa)$xe~i$SwFAJh*4c*IwuXOJThpr@2@ zUumLXgp?%N-bEEg&q3G!h}u?tI?ED2>oi=zkI^p5YQ>3i7KaF61V zSEhKYk?fFo-d>5=p(v^iz1j5JHUFW}bRG^A4?1(yW>~80C ze5d6~}mLnU#<% zxLOZdm>Scm0wk`yJ5U}Z!S7r|I(~&1a!T%c^dGTiwG~jB6B)Aqey$C4%1KNpGf#$}g|Q)_cy%&0T`Xb1)j(Z%ux z1s+;2w>FcaUE9B&pZWVXm-mllvv6O4J9Rf1c>ZIhUB#iY1%@))J`qAZj8Iys;nl=h zI=Xju98>^sUdxb;XP?c*DnxT8QLH6Zr7dk6bmPU;D+ZVV;W|+R*!R2{Hg9H={S=fcW1qYnSy}H z3cc_V7gZE{as?zLL#*gzqGYW)#$LuqcFk2tb!V!x@CTT z8NY++X^8#io$D1Fu&nIfI(Go(+A9#7YZz>-88sfBGshxj#suCDK~^2cA794Cd;t(^ zl2M%PP^og8OmU;6G&JZKrn5@GdD8? zOnby-7S`5{E-oBw9M2-QbOP%evm2+in#bBatC?{Z6LcF*W`9>-d1kafKnEvr#Db|w z>ZWHFZq4i*S~?nq|E8_mWDiKFqN1PR79HTg<`QFvAL!RLOXucyG7-EJR-@61u-{#+#b11gL|uFEn5aW&S? zzr8VFqV?(GBMtIh>lgdiVj!cQyI6R|S1ObpZD%3Ow<^ic2Lf-m>kmWt;ipn3`8+&{qua`~rHP3+9HR5Y&pr`8mvzw>6V5q5^~OwR!E@!aHXB>cAX zfDLomSgZ1fTDW80(B)>y$tQp3dJ_OzDMFD{q@!)gE~a8!ginm>>%v6L`Ik zxiNOxeQ>&Io^wY#mR0A1KCTT=g~CeshL< zAaYsjUs|wVKENR}o1Vwf^C=T_wm6wdtyUTRGn1|~dGFgz){g-Ju<)#;nfUd^vTgMA z3o14-L+QrVv9rD12!E%Cz4#JUjN}7}9qF@aG3|20poG!;y*=M*bTsg*CaMVHTnS!7v-QOTdpy;F4 z0%E?TDjE4F-p97{)Hz3Hl|Zf9xt=4}?eJ#KvcOQ&Ma<%58aH}$FT3doO0=FkNR6|7Ld$pjZ7D9GFVn7kJ(CfqtGA17o}b zh*yGMtZEITHRm3-VzWZ|+MFU}yS6Q>+z=LRqrc2xl&S-S!s9FUY8sG~$K^sM(w{99-DixTt>Hs5R(*_K318kp;8OU~7tAm@1-F(g6$V5DpOn zhg=P;Yc89dTAEQ@7uW@_wtj-h=`v9PN$rv_)4fJ5>&0PEEJ_D&;e7hIS6e|-kn-`k z*FuV}QKcIW*nLNICk>7)*iSnfMP0<@k3!YmlTS=cj9SH=zj{$g3Fl*Yg5}Jm=+x6q z94w$0=iWcN=eWlk=eaEaoMe_BI2wog0D8!jWkwVNV1il}^l zO*53gPL%yj0e=zG3k3hIaljA*=M{344}||C)ytz(w)yvWn!fb(3i|ks7Xz-B$g3dw zZ*|1~t488D#24}360-o5Mhp!k9D19t?F34XYT%94o9m1@>VSJriC@u&kxlwhK?^gp zQKXG^48r~SPnpFtI9;)Il`EDyh@upHRPD3R0bSrSntV} zFHx&_d0GRX_pih9k(1Rte#X11{q%pLe7o0^j{x2nE#_#h!XR_>+8JVq2y1$!ca;zq z;o`~N!8Nr)BId+25L`8XOFtGWLRPa>v2@};;nVB(ui~Rxk8o&YFS3D(0$!wQ@$t2L zjvOIIVs5ADnSLxX(ZjC+!3gxPOyo97n$#6EDVpb?tDC)f5yvJ;^=Al5$Wqgj8J7(| zMmhokTKGGrtJV%c5p&9MeN#V}6h7YX%;)fj1-OtyZ;LWsDzH#G<8@(80KBab!8z1W zoOvPfA;iMsHvIiqZDDYe$`BJX;nuM;7q^)qzvn&Hek^GvC$YraYtPX-yoDZgm)m?>DsI zD3|HujMd19%%>v~t`IW_wXxfdv23bIGk;JmiI zG#GQlp0BFg^7c?T#nw-4c$G~5h7#)4y2~{u$@v)nG$rsbQpX_(ohj&ZbqAGFU7eiY zbC>(!(_XkUWd8dJ#ZLF>w=$Do-Lu1%ITPbW69-Q}=_5+z`Z{KCZP!&n%f_pnG0el~ zqikDj_kjMI&)^wUoIkz~Hm#V$uBYeqS^gf`eZ5(p`|;&A^woZsp4zg84@(oR5PJ5< zb07>{ngH85ajKDgHHL^?$51tVnDK(FdAh7PC!0hXd)M}MFtQUi(`r5fq)yi z%^my8qFlQr<`^oaazw?a)@SRqo17%MDAwaTr-RPDYGg%|#~`+@q1xEK?{5NL5(1i) zdkwW44U{3cKVU|_5Qe8>V~WjGi{$Is%9GXcJY0gFT2gd27*D!I8mbB0Io^!lIFw+7 zg@@1Qv1Neku_{s|a&;NxFOW7-QC^{k*1?p;V|v|MXY5Di=BKQH|>d_86+-kol01SPy_4SO7dCxZ5j!4-66`A}>J$~v7u7k9uDpboi znxd!EmovZRV=Kz#PyKbx&%N{Xz7C?Q+v;?HZNUVAhZ+E8Ao5S{FXdGhvZ~5M%wH3@ zj21gj=5!@@-Ijt8(nDhazhXNqj|-u-XPfXODtyQ@kH@u><`y*?y!~%Th+q8Cqk-^z zx`vAK=@EJ06-u}G8kNM-%BtIP5*dU83;6?8;B_|-?!#qKE!ZpDZZ{nLz=OU^Z!-nF zfXXJanT;QAzV77ucR;`}6wn|728)rNwu;RUZZq#|V(e917oh^OQfGEoc92r^#388h zihz*9GKoOxMCu3(z@Z%aJC&@95wvUhhHfeMPl}7A*_C4{0?SElWn9>BJhroelHB=K z#MqV>2tWYyeJ1u=v+2@#>ZxHmxY>cz>*?)|H_GA~g@g%yjAB=qnR!vk14p@K6em0Y z@Yk68ByOo$gD|I-6cSLO^u8OebUv8U@##2ITeli*%31G+Y6G-%B3ld*J2*Xhy|`jo zQC*D=EsUw)a`9Q51r45%jur#@ikv7Jh!EKhgnj4!SkrJ*(Q4$W-&tFFOFXo!%_1QJwm?MjC54AEY) zPyFTho-(rRm%1$}1z-j^GF zaK(}e&#w%er>_5uZb-|m_k39pCztLrA;$@V2h_YD#5{+>h8kLAv`fJeu{-^#%@bt| ziSys4dE^`9!w|c==`5<*_rc%ypSKVhq3!NGTbLOUZAYB~LW3r37i$5HBA@dTt{O!s zpP+(8N|K)l1y%S2Jm;c;J>oKrgRnbpIn@}I01T@X`5D(jReq5mTj|H zi&$~Dzj+abcNX3Rh`<5>C@svcRkyJ2Ft!f)QQerLWv5OjQIVHWaKJ{~f;? z;dzR17(Y0*IJ+G+K}_i@EfH}O#w#-uLTs658!6Z^@e?F61P0{*rj8q3%#EWc#>+6h zL<{x$;2GHE{4!!9BUB?cs4CWQu_{s&)$efzt=#MA$5=Ip0@2#Z%b{(usR|-U!#Ixt7x8(){c3<(M&58DE=l;rs$3B)d3FKaYQ){VOuM~6ndDgWBpCZ86j^Ntg(PHJr8wd6& zo?03xEMZMfg6Dn#616)lJDK<4TZ4vt+iULy{?)jt;A7K(0ZUqTb!PR{fpeR#U`i+{e5lzi56H5`Cy?~k zt840@Va3MWw-j4^#;zsz&IdO`v0~vsNqwf_5&`ue)Qlp9Z_}BqKb_i~luqO`o`8^> z)2g~}T#5FZA!bDXFN|B&9aag}og>h@=MD(@SA^TXxY%MwM&A^nCBP~h`E z%hADh3iQYq9F`GnYXl#r8RAJ)C3bY_r5e&87D$5!G$8~IgF)!v@RXrhfj$#{ybuN@ z0uTW{5X{}dcdDp!fEmo`gbVy4frGU@|DTg>!m;LEZ)GtD)&r1{apQ!9>nu`dk6zguY+bw=@>#^XT!f@?VddT@tmrv|{b` z{vm$9$&aoYCPEK>^S+Vq002Bd9vr%epZVOltF!oJ~sukOJdTP zVv5NCq2p&bAxz3cue<4{%OT$tE0p9!t+TqI6ac9c1dr!o)D*w#3+`O^*^n@j>wM!m zz8F6?b=cE6_r5LU4B{xEFUPxVyVd`p=q~hnacF zA`jeToqKZ6x4*r=y?It#xhvOdpQ{otoVy40B1Ghx4iuS%?q+H~j4F&B66HR9!v006 zgaMy@BtWSY|5eE)$?lb*Qv7ow#hzSrvbd~PG23IBPUUbGmD2r228;-{1hh(2;;H-L zs}u~&zxr>hfe#U6mcGPt;JF)I?yP^{bs4)a^S3EScZEh(*ynmKo)IMpyRHT33=M;r=!}(WKf^bgbGUtZC?9af+=WlJiAZ(t zNpek(;>VxPf`e4g5)Csj#rhpbN+sGNc4+@TN~+tEGB5iJk=79yLVRUmk&Mho{`c#| zMB`{#f{2mbtKGEJUW$`n|fWFrt@E7dqw$wNBnJ_K=Q6R`oP`}ZJ09wGJY z*E>;vIl8qv34b6WphVmFG?nnRpP>TIwFzIsR(;V5(apaRJ4^#FP6oKtxm;0WC^5sw z9slfzV&y47k^TJdjuMn z@+GR6{eYSgitRhOyxJq1)cvHU1EeGg?FOf3w)sxnye-|Eh34Y|wmFvT5BDs85)z8^ z6;X=9i5=c52mFkPb((9S%9BtkT#`lR^yJUiua4nlya=v)n#Xnoum%^j-Opgj$cjps zL+vV%rUMQp<)rRZQ69EsH~?dLIe7mSBE+RpXD;4#Q4)qO z^$QOsV790TWR-Vdso(bW*660JyS1-lpXr;~%Yp3@{(uDRd%x%yLkND*P0OG-wVv2a~ODD^X!pflmyOI2=6{Tyq4*?BrteP@B9~Q&m@OKtR_zi>-v8 z!Yu^xPvbC;k6&_^2{SINrJZH`GGCFp$RQ5ACC=!LEg^b1&984%sKza7>y#$Se~R1d()M--=MGcQm9>+#?M;^# zSxjbKk#n^=@nnhn1aP$sw9AdF^i~An{uDH*QMuk$?Mzgw3L0_{($d44n>#o^6^@pa zh!ls!W8QBd{u<0`ZZ>~NVRd-qDEKV4@0UA$P^NwqGl$!FfcVG@BXZaCc$*6Y*ylK$ zGe6c&Xn2tkSttM1%H}c|zpv$f)H7qCFvOq&3s{@8UigdjNyusv;<^d#cB0iZaO=!WbXr@z{8$N%uFTwA6JO@!xdplx zs)5l-MFT&3J_lkv8hl0y>N8o0x|c)P5{g2Ypa{*O%`ZvlF>+jFAUp{K7G~Asn2m*8 zUzf^eWRUX{WdJ`he~^*gNVi{~%I{cIq6`Xv&XA7_1@Bu_)&6%yG77pOlLiYuS4^Er z;SoG%*-1bwFx)Oi!9HvHz=vrM<`vaTP!5Q!rKOQ9@WjBNhYSRsZ-iHw4zGo6c5Zdu ztp%6T%Vk9L0X|*7MMz>0<4zCl6xH)p$DCIXV?i}I)~M9%paIV+;hw4d`H*+?8r@l< z=d&7B_G>pfU~u>LAd8=X94J;R4g*~2&}^eth;DN_HVL&UX@nLvgcszBDycxULWP^> z<1JVU$$)gCkyKa`5{<@>$lhtN>Xl)l!7S4s#qP|}y7X*z1}p%AKjtdh9@p<~!*V_^ zG+m^j^~Z%L8-z(Gut1SQ96D6ClbhH6YSjk-P*UmDx~+@+`et}#_UlIn{(r705DG}{ z1Cs$d+hT|P$VTVktcHL7bl^bCbgexESzg}1!|mB)q3%80J3xSje&DSezAz~+V-RBF z8XPnsmLuSlpNLz`n%?KUi}85Md%{3i*kcFB<6&pH5@(?SEs42f1A#^{D0-Mv_VpeX z6~W`xbA&HsLj1!3kw{~KUNP=_4;$Po+}pw7V9%?p23)xUem?FP1V5-xkS^2nIV>tZ zK=*X?l-~p?FCTJAAQczZ`*p-6Wa6c`TJ3Zf>M|-%Y!85tsebXekN^Z+yA+kSnBj!O zj`;tiap5C>W1ILSE#~PtK29M8UHJ8NfbcWG=e1*guXMK2VMjxoD$^IY_T#5(+D;1q zgouc{dt6vtfAwZKH^=baL9+>?yXVdFj=3Y`_V(z*LJJl-fS7lx_8H=CG>D0W`dkQm zy7u8{4szW0^wi@#ZbbSygp_1KIlykTqYm4|TwDsV^%8kzMt6+~0}FOIsVn5YKRf%x zXi;&XfnVUU4Im&M)55yNtUMZJB;&oJApFat5i~rA^rL%qJ^;Frl5=2!VH7d~`l3a1 zo6UIR5IG2clAxq>2Y+*MXZp-qZSEiv48xFAI!r=hbZK(G5uTXW^iYnLCsRLtIWGyG@BSwmKHHLT((tz7kdU_9@xEo>+3qfaqvQFU&ia|Z z{rFQa7KH?6;%F!d+mepg-*7K= z>O3;KaG+@#FvEF(C~I*=gZ@0=J||rpX;QV1rWH9FQQfP%rYxf5u#dr@J)=Sob%c;*?%M3b_y_~Yo3-IcV8D%5XqlWr_)|u^^Igbx z^?Ad`*SWg_vXc|>VGq4!XP7PB=+4gL&9|uXOsm_ZJBg9SU&xF=Y~RS$pbi_Kp@2Dl z?gkwmAYwgZJG$6GA zm(pc>I$G;enez5s7~cGG3*pGUyJDg{T|OaJkC5DRtInxkZEp_ka|@bw7eoi5wNjC%kg+r*FC`@IQ$e2V-n zLz@}s^VxQGoBHF}B{JoQM?=HogI6eMjm8O=E9`0wteA7NqL#EOPxfn-#p;+aJq1iL zJ7o)LKco_(kEsf;YOLKN3@$Zrr-E!t;uSK7XAz}@34Yw$NU;HP`UKk<=K5T=I}0+9 z6AVQDRDY%_Zj~k6;_ zLs&m(!mXO!P8a&>eqvd#F{j->w!Ydm_#?ooiYuY7Z8H7f*wN)0$=r9~DYaakc{Lz8 z5kwX8?cU^u3mamNOB9p)HPq{OF#F-8e70XKd=W*;Ezf4(gq3E*$7Y0T06rlX-&X#t zooF%5^UKW-UXYsEWqP$$cBOj0^4!H@atc23GZxbw*wOz6O{fX(+$K*ca)spZLx>8{#Ee!lRjaobIftVDvcF#~M{3I%;>oPN~xpvhh%;tgJHOg$t^$nO?@m14NOIk7rypRqZ|& zD?M<`Z78eaB@3`mR-Mb4)EpRX^fZGtk`%Rpe({m=)BLxtpb0pfr6jeN1v z#P@`_SSE6uiAQnO)N0xMrAw1yI-Z{tDhDgu1nWNp1E6=nFWdslYyi#m;l_}HjsS!E ztQsTEI(<}3%y6kL(+Ga*r}fgR;Ny*KFxlE~k1BrXV~QNn zfOY)VAdcL+I7zmxAMxqLwww~FI01NTGV}mw&&1>5t9aWX;g9=pxK*T~YH*6|JCxAm z@ff0Y3@AZpkA@`n`vzq_EP>53M$a2&T|WlXFrM;{Ss<8Nx)lyJ7QS|Vq32Wdj3L39 zQO=yUw&5oX@3UYovT-}}6*bdyvh?j;P%4=!V?+5!YSlr{8;QFM%hArBoUb-J+ZgV- za8*6Ag6gYtbAe)-SQo>*%cdre%;V~G@vB*c;{Ns>!bO}?h(yOh^oQ+L<8XMdCFSD0 zNpg04J>tCUqdQCnk0;-_Khtae*Q;6iXM&tlducb$yM{F4&`y!TSJ+qO%8Nj8Zu2v1 z)%sTV>!Z?ft)K>SpQse`X>a53EF;+W-sBOlN3eXSn6f6El4vZu_5t z(L$bsSmx|kX=<&X8eA@lB9B`$x_5D7Cp^2Rx`+vRnlGWCDB$S6_a{;qG^HmV0C15s zSux=O&E{>4YqP1YkWe=*3E5gZR3G@c2Am4}7)d*2;^ryJpCF2Dto)9Z1FSdwOkbu^ zTs*)R@F5@loi!;rPSCltIGWBzUfz^?M8rP4+B3{;#&zYRq*5xSS(Z?H)JY4JG4Hlm zr=G<#OA-aWRd`5>z$TO&1MkrP)XN{Y!D#eO&R}PZqB?+?2&)e1qv`d!&2^TnmSO<9 zgA258YDDv3E$Ui+`Hu-X4`ROk`NwSj7Iap1cVrlcE)7lXG4IIUVUa)!ka?0D7S%&F z5KZ~A^T9$QDI6E^#@6rYRU%(zn!x(Q+E`*9y(u^V$6DaoC}~vleTR$hhn`Rrqdf%x zfQv{0_~^_)&UUvwCu28~Ve|rRvhaJtC&@%dJ z1@ls!Itd@?%`ryNAIdjlAhQb6J!E$%YCc!)NUim;Ie3sp#6n4<5@JOu95}Rc+WY{z zBNgZ?;N-6_59Asc>KOId!ynL0|E;Bfl?&GmoMbxS$pP@aBe3-)y8jcl};~@rPJvDnxW8@)|Z0a zSBgVm!1Xw!gI3ev=wG=My#qa2qHkR$=vmwP=fG(|3;Pr zlQD@8AwYm_uz?8#_&q=?6YAiP6o$P>DO@M9=tsK9A_Kv8e$Er&vDn(q+siAFkdXNNW{h^^jN-K78)3)}=m~J#s%W=bKeOko z-!V`PK|?izi1u2u?z>QThn0_m7jU_FLZTm{|CvE%r;Fu^f`rsb54iX(uF3aQE(l0o zKm8z-{s;$@)MQjAN8$@s0GL*5GE#>&)I_7AQxm|&07`N8U4rVg%P+k5Q3*wraOtHd z4xoQ%GpI*DJRkJ#8*OFSEC57)t4Al=$O%txkdkaz%1&5{#AAyBB$Oy6Ch|65^Wa2( zt53-&b07c}Fw{#!^NOSAeiD(o)^4+OVl_HpU!j!tWII68bRT-~biDtX^k)^WMV zZuVDI*HN~$tzGVZkEU(EAP%DvYlpLqtlpiUu1sDH)a`-nv%M2I59)zsofdeWFd-qS z<9Ra^_}bvR6s;Em{yXX^+mI!ztC2g9!#kFPQn%+{7DOagm4A5UGU#kuGSgXE_7=2qE`!RvN;Q9!({aWTh^Ukm@b<8uO*&-B(fZ)JbvjJ81S02{Hn;1Dd?^%XR9V{+TytMGc`^z z7Dtchx7(jR?}h zFigm+cHO(&@HkRjWI#cKByP04F&k2%Tt#D5y%jZ3{9w7BI#|yhb~mHysH?a;K4kdQgy%LF{xH@`aPEJs-tB)MTbF zMB&i0Fiwn4xDzZgPzS#<#|cN(VKQWXWq<=j)o3HN=hg;S!k%99&y4CxZMDGi;Qb%UP6>f{`0Jl=9XyojK+?6ET1=!< z;HY;v)1qH6dHIlO3D=am>oFM2y@{eD>+a5mr?F`YcDN4~15Ys-h>)`1SYyV2hkzbMotULHSPb7Kv=4eN-Xr_`|bgLnqMi%$?Y4ged;U6f3tGu@3qYxS-N_< z&0w&@{s!D*);_cpueDgd?LPzSRz{{YS@Z+OSBZ$!&{`DtMluCsU_}nC{2zZ<^T&|; zAeQ_5sMFW4zxvvR6{om|2>?)QEsm*hChRHvVjHZfds)VmrJ!ca#66LOotV+%QI<>> zWO^i9?xBm%v*5@%75fogwAN|(w8`$BK;Lwgq!9mnVuvm9ZUTuo839UE_@3M@E5_hX z?@1q3guK%zLFO_!S@d!QB|@RJ8o`*&Bb^3Dwbjlgo>~7h_%hio;imU=Hvac`nf8NS zUGzD)+OY2TJ_$yn&6aOzQfOqBWUc+&-ivW{HNbtH9s5C4i zcmUbuaS0QN^vD?eCy561IEGjqG^XcoLtmUEO<~5Ej#K<)T)*S(r+#UsfVp1@=l1CP z7eHq}mCM23-h_N@Zk_a{%Xjt5BJS=Nob#eq*7S^6xUoWDVfnWq4~6k$r!-(`Edc{S z(((TL&B0gGPUD8WvcbmM3mG0V4LJsPPNBPDTY4FNsLRp|*;|AE-LJELhWSb@h5uH!-3 zQ7XXq{Gu~`*HG!gnV@MD`c+HC)z75Qy_ZxlQd6ajF01#Jag`o#T1}b@Rx@P0PG*l& z8XAoLJ;3kjdFb7l=qDWBc!fg^V+)SaZGYoIt55Y+4`~$cbNWSFO<;aRN1ncND=dIo zMq<@vEt&E*X`B=v0HCtJ^+{Q^(Pbv@)HE!%%5)M?6qXacv!jLsKiKm6_wf4+=}-}f zpE~F6nhS0a_^|42FUXqHK#9np=OpO6T1zIxYumkWE^W_@Z#4BqRZ{YJgwD8|hA9=h ztKqE0=fRsjS0MVz8YPZw`bkcwelwT=D~DPRh|TQ>^RJ=`AzcE)SL^msbSIQ)tVzjhY#YoZ~P=bYY?(UgM!oScXywMRM0LPX1e(* zg}#0pDGMEMwpsoqqm+vTAdi^L^=-(MFVKcZS^Y@1j0gx>U^bbU8LSXnxP6Keo=cCC zwx65KD|t8FH`Oj4L=5w{A?&hEs`2km6neM=U_A;VVFP$s^JQ_?@U(oKjLFv{(qN(ZC6%&zg8hJeY-kYX+QwJkIr+|5DNr&+w*6Rc94qB zsb;$%XOMPBtZB<&U?TF%Pd%Unz9Shn*VNt52VNA0hw>h5Cwc;Xle{LK5-_E`rS>g$ z`SeLtGuf=I`F;+s`margSy~Q1SsDE1n}7w}PX+My4Eyu{y7lk}00PZ_+AeEE39%o8 zDe!}KZMS?rF)q(5%)`S{GawOJvIN!~x9XmpE|8d|l*XfwAS%QvClfPs-jzrj)#69x zXs0??DjIPX#Yg?AEl{XXR80C<_u3T?p`$B%6{2)FUSt4*tEE5ge%bhMySuD`Uw%j0 z@^nAO?gk|(*Jod;E;bXI8Y==}L|cV?EbF}2Rw2kKHi5w2L50o@rw7dHkiN~OMQPYJ zJ%$s`7_-y$_UzM4h3xEhMoye^k}@G*-?nF;UP&!S+k{lQOdj8|2t@rOP`DpK1!rZ9Y$4o&{dM<%kuZ1-%nYb7q?2VAUUIhi6AS zJEp^?7q+%15X#k8{iVktZ7S!@l?$dHI>oA=>y!DKJ>bBR(2OrsL}o`*>D15zVosjF zv#XPH>c?Mjrtm*Us_GRRhCFyjQYpB-Yo8dKn;h#PALeMf7?M30+K2lRaFv z5eRw_1kyUEN1m*k4ES2ejL1WeHR!`qzr{e3T76#)1k|rRyObUV2_k(Z?g~1mBa78@ z`ykw=2J&<`i_Ad)WIdogTD&4LV7$qGIQ`oT-Alikqbab~4g}z}6JEa#E?#lsrO(um zBZ4kOdvYL8H3SSJl>bSa1!*Tcfw2;_h8Jcx(do0y=+5v^>fcLbM!)JS4qGY^ujM3VZ*5hF@#tJ$p4T- z%isdtxWf1f&>^SCkg7bbyA?T@0NS-DD;^bmk#f=-$r62Or82DF=jWHlMNWVhtiex# z+b1+ zo9n*b(sJ$m_%n^AYwhEnyT~1~Xs!}m*Y^81AHf4NUvCvb?r(`np4nB+;)@m6Q9vHf z5WjoPwC=A6Ut>uLHbiMyMxhU6au*_Z9X|V!UL#imb8DRbQz`-Tjzwqln?@z-9aUG$ zKjls;BPpyV52?t}%YQc7wFr32Z*W=^abq%s7>7jNKj&jiV?g-re8UuCv5z%d?8b|A zfsv|zwd*PE*B6=w20~a<8-Bk|ZNEq@bcvhCp^Wn-E=-#CV~cBY2Ta&*HeaV>=)3Ok zdt!Q+Bv&vz>6#WwXfe~kGIYWOmKH|ObgimW-Z;d2)ey)2bxCt;mh*dD_u~sl0AXN3 zKh`C->TTchB^>qTWLbVufeQdNZYJDmxy?sSeXXk`$*{Gx9hR}%Vd=HA;~<13ex0;27Jy%)nJH%rzl92KHh3sN(QbAb91^v$`^p zHvBZTAr*2vP&-0<{+(@8x>G?L9RD;pS)48u-=IF-&tjVKVm*=9Y!4hx0VO!#$&;gR85PgVG~g$Px;6cAuGa z$ZMRhF3>NWq4tWB2y4?l@||5eEMN_!ps52?+ycY(iR?hTAMJnp7e#HTQZpUqrPw8e#oTLJ-3OyG-&(H+p_U$y+lfl9`ZkKb!ftU|Yn15xM zsLgQGSDu7;3*JUEX3A`Zb>=vzYy6W-4n_`4);>B1A77wwKpWzSohSa0jlYr%*xg?I zjNH#ck$nf|={kV4@>IpvVQIxoO}a}tFj>kUDxY@03B8|CcgikPIKaTS8gJ`*Py2;} zzfInopTrx9I=pn0&!<7OvIvr?dO$^$;C{9hj_#zYFOaDwpE{Gyb?kr?OH6>X&~l?= zy&n&jL_^y+fq*Iszr{>qa{5FRZjO-g4*AN*vVK#LzEKFZ;*?f9;IEll-ut_O6%agg$C2@*#>j-U0&1-u#K31X^q!O!^;WD zEr&ZMU?gmJ6!Zd}@!RHHjmg;HWC_gTg;&bTTXr;Z4yb3YNQJ1=Nn9#WGUBsj< zNt)}x1ZO?mks$$Mzue8TaR%T606*z2h%loQVK(AM(+M>*914C}RZa&U&#=}8`dD|J zk3=Q0GVMaVWA~}H*F|3Yf$yE_{ho8U!#$jDVmv`FeyS#CJQMS`alVnRGL`fCDL;4q zNeF}WxW6x{Q_Z^q0!m{jf+at=oIl)F-^r=71F#3bV0)>Z#lU{1ux6SqA!17xBqPI_ z)nCf7ocyA95<0Xb%gFbg6B}rYS@C#o+A@5>%eV_!-a;Jp*-dblbo)csRkm~qNvgtI z)q6O_QY(zL^z5!%A*{`2vsBTScGl6dY7Ykmmz!~?l)hM0j#knQX}(S08Tizfm)~`6?~e6ST(qdrleFeT){g2=OfL{i z_WHc;h!^u*3G2?M=hYLPEW1Z?+>#GHeum2k8zcqNC z!mJK$USGr$@-h2pQMH4-fsfRbOs++Kgy*T&_dsZ6$| z*IMeoeNuR?~E(V@xBFM?;#?eWsg-E`PpE;UT7 z>#^FinS@?Lzxd{9WtvWIdiTKP+MCxmodcmB)wbdMduO9<@bNwqD8RpAbG47Bk91!f z+hbERS75uUUq(OI4Of~dxe(s84A_5V@}!M!-daxsasr*O2=adooj8D=-UjSpTs_Zg^EG7*}pzw7a*p`;9xScUH^w z0gg9|?Cwl)3~G**IBLshs%EE;0%SfcE#=pko20XEE2_OqUU~>|wH>XBjX=v!*8dS5 zimE4DsIpyZFR0>c*0^-Pmz#17Zt`ZQcUj%84jw`W{c(iD^z@AuThrBn5(#54tl*p< z`QY4!*aHii%=66}HF}|xk0%9ot-6Z^^FxG3IG8X}?%UgoN(qu)3oJkV70jl*9!yGI zuD$Ks@V(^2(SsBagS)=np5{yc9vsx_nkMysI*jIKA>^f z+#?yX%+hJabp?FxlS3Kk@0yLZu1~QcenFJ-pdk_br3~-5_2dnHKqH>K>+X*!j3Nq` zOC_M(K)!GI@td-9IYHFk{W{hShrRa0F~8U8)H#j*E!Le+Mn!A^N6dcY*#0YsDndc>pzD~ym5z?OusP22)Ps*e{8VCA!2hcoHOArHWft|in}3r(FC!6js>tE ze2PV|;0PLos!TqGyn>4BAD^fQMdF~N@f27TP%+Co6SPbgNBTF&7svNsHT(a|FoGBp z#uU_*J(KA>Km$gv-{8Gta=jHQ&t#+p-OndJB6mts`uKD`|5_)fjx~T@4l0V4f{~8j z!AVSSv`ZewQ50j{1JAwRP0Fh7_9 zV0fyWs6RG5I7-h@Ih$Gr*nQ0D?p|uhtc@=?+-!Byq5*tQssKlAw#rHjRh$ab$k5xD z75&j-u_hz^Qy?*EdfKcPPYo=~t)16aIoTQJZT6Iym7fzfx0t6(vrgx)IIhs(Qfn+K zQ+L+W(pRus%^$uolT*Dmgx2v8`f|3#hz;?(6XE;OyHXv~n$t&`cuHrdD-FL#PiJRY z!>kUOd~nxl(lf;oSDtDDw6E_u&~P?x)pWw|_Y&$0^1I#2K1KlS7Y*xO9B>zo71-Th z4A+M{!|-vnUi44fmuW!hIRvdP|4iM-#ouD&qX*vem5Y9q6jwf4r5^#b(ME4z#Uy`E z-Ds_+UtiyuT;;1&cC>!Fa4n4Q@eODQg3(Rbsi9K?_9+ySRJLFAHggaoS{_RpEV!}`9? zLwWCwvVCul1<9?gby(bQQzj{d-wv141>&VNQ59+DIPnVSQ+UB)>Qx{PuYiKbAH`jM zUsKE_)RmL#Dyz8$sBKcXYhP>vo&IJyjDaN5Yw#6KhjvHsQ-HtiNOsWxHp%Ukt*=(z zOBEl`al7RdfAQUBCz6h82$3?42z#ooxC0P7vuGiy*{|!XEg+5n{!wE5LZ|vJ@L*x;bx1CWRSnIn%dK9IK6mKaQox) z^klB&$`I?{sanKw>^iFwHuaY}*@10bl2>2%iZbfAnbkUFz+Zj>kouHDkqq~lkRzp^ zRBGx#*4<-JAw#M11)?Nc7H1-MX&Jy!UG+?Mq47)?QdA918BB2#r->Qk2QE$Or)x5& zVxB6%?w8To%xX8jUGJ2V`6bWil@Cb^sE(xwQU!!IK7{Y4|N85BxW6w9x^@8>Ilin^ z0(}xqI1)4N?-R!TgjGx$^gU~%7R@_Dl3I=Va;vvjwBiMk$5&U(! zZnhxOJ}^xD=c{y?DQo8za}Lr&tQ|(T0ldCR&QCNkyGJL2{;OpLNl7%gV=W1X2#Rm# zUE<+R^oqb@`@4=^;_JUn4|Mh&;6y>IE0w^XrSKElKu3YnydO7wTJmaL2iHpvLQu@L zpFX^EJ>TOCGXn_Wafq;8-5o&{9EPl=j=%t>Y`CiXYBRlBH}09!-HEZ2NGlDS|01VF z(MJXsvqp!98a4<$=VhKE|G6U5+VaA zMT3(BU!#gIHnV4lD^tZ&JW#&IsX_w!vtABI9tXIDp88TK;>27cV7R=+!g12i&`j()Uh zB5QW=2;FwAo|#p}`ZG*tj-5~wv(eKe%6!|UIDtuc!`YHQgY2}gb}bVHRV~Ctg@*HJ zo6a*CrZdYQfO!P+K6}{%`JD#On{8(ZR2vp4VKEv zT49^z*GyaG2W<03hP0KWBk{RketjcJj|-E$-qLT$on0taF%G5o>dk>cv4s4pf0`fB zYr|_e;%k@F_Xi8a%aYJf zFWGRO8SG!g9gYB)PzOChgLw(j-h3J=oULDJXJLR;Naqgl0kQ-G*bSnw?;h9u8A>0% zcQ0|B^axXe0>+u?7^hv_UiDU$M;Xf*8QHk@Bo`GUj`b3o!`ok82WAJDmUz6uQJxIH zgF!7J2qAwbr^UOk;xbt#3NDiM%&A`6W5qUov?1Gt$*n@dUnqEG?N5v6PgEPybw3Xb z+mLpb;nvddmJYscrPIOH?1 zB5`2%1D}nXoZQ=I1?hKOQQV&kr6FFX(phba!t?8p2dQumsdC^=B+2~lP)RpM2i{^# z3f2+k+jI$=1ZYo4^H)NZ1UAlI0Z%1LhUIjo+V{1j-$_RT9{thK)G}8{+UR>*5_HrL zHyMM9@C&YXuh;X0LBb}N$4E+goE!WTYZrg3?<2C=Z4-G5Z$w3-wrwN(K25Tl%cGm= zy(F!@?zj^L1p#NfQ~HcsKa@Qv@oZ@AO(o>Jv2IcIU6^)V(Ri>NxFEb(3Cw(V;i^?) zaWydr8Z(@FpT!|HKd`q`O5^)r)>Pz;rE-{wR)~xvsx-YPcR>$H);6&%pHr@B8yM-K zZmT!+a8q0UM$@xr;9H(7_q-m{1k3Nyg$qg_3G=^DyxMzP0C&asd+4u0$F2cCchAK~)1ZF7OU7fi7~`{u{TX8+w0y*xTOFr$et_D4 z2%6(?7tjGg&8e>r5wk~(>$UgxKn~pVW#vUcexEsGW5rtI1&t;vJ(qOQEgH49PY6%%WH)#ExbW+#!xrTk$eV(G zkq4?3GS=Ssb;n2`w!l;X(NLK|yKT(}n~wGh*2T2r6h8XSZdmfz_K(}piNWz0q{g*b1<0|ya_jE1ejm1#@ z^ESJ-?MdF(ORh6?Ygqv(sQrsJy(z0!ZqlsGc7J*xMuKL<%%Z8vXaK>s8h5iyozRHv z&RwKIQ%TNHa7>rORj6pbfRopVR7X zZm2{b9phGQevIJl52kZ;J#BKCA%=jS?r6-h2%Y71!lhLb66U||p*&ewO_$aq)C*|P z+$1b{hFft18)J!AlGS}8sc_j`*@E4V)6awr{G7Z85+@I7jrF^!KU=ICZy86UXZ&%# zZ?KJViqTrtwcl~fcs6#)-_dSss1E#8U!VTJVeszuu~p)H`ly~vsF=+WmxoCJIKR4F zWp=fo>K6b|o*Y}h6!)_KqS15gZNMTr(fOnL`$TDd=;s6l^RN-k=Pu_sn1F8#c67{^ z?CEMz+ReB~$fU)^&y+tdre*Q`ZwCiJ6`HRPg=BFg?8yI^ba3T$t5EHaz9=2YbgZ?` z=TZjyO3S%A+i~6$C>3Wq>l}=WdKa1fabDnrm!V=}k)CfNv1hB%dZ9;3YKe_Dx;lD~ znAR*s^RpB;f5l=R9xps<%(YOp{avv#o1KrpVq<_PMbFqv&8>wf7pPQAP{WZ>48c&MBbJSo(Wj0%dD?<%A=_iUQ3T0+@l5Bqf9qUx^5jRL> znK6TFWNcMxDzW1v&SbDkYb%IKqvAWcW8z`doQ>cihsEljK+!JIz%J3(TZZ(ikFb+kwUuwNQG5arJSvO|btGx@5{kp=glAEHbd>WYUAB_QRYYDpIt$l8t=0!CHUK&ih z=g*nA#tC8Las05mrzDESV1NIgDb5EO4hJaI=0naWi}5F@g^nv=csXoTY5iXmPaGQp zR2`&ti9Tw3&GHr69&v}*Ap)SoFc9*3EF;jr0b&37g)bdC;oV8lH)8ur|EXF3f2qOQ z-f`gQwto(V5W$5Wj2C8Fem-AYHM2`-`8m^$`>{pYeO#=i-ziGvU4VjA;LBUR8l%kc)DXqOO-#s9mkIg3mC{ zzJ1`wlT)85uPO050k0*N#NuUo^X2#pBLsgWSbh6@kx(l1=C!}R0IlU4>+8Ez|Ftqo z-05xap8NbIo?WNY=PhT-<=3hoSD>BeWB5&tFa|F+vs>Zge2WUZ!bL>h_pIThUr%J} zzjd~xRwF59$mv!eUNx?HxE}tIzP6TPJ3TynJRY{cyh8E2zm*j>Ap4(CKc?J?o8};9 z?$8B%s=W{r64Dd?0TuunH)ycY`t}V8fc@W`nO@`vyN>)$F>P*Bnljln&(U15(r5cA z@b(aD{Ac?*V--^cul#q;7um@^T(g6dp9HtW?CjbHO~5s}A9@%Ot@M}M8gm2RD@dcdk9&I^nn<(V zqU^X&`+yt_Af+CSJ~RDovMcB)HY+jl?0M&?arMdKjYJm#yoNu^_~gH;F*^wl0PHTI zm^aYu7~BC%Ho61H8}m|MTS1AS=(pE-_T9`xDDFDySOCuEYgD{BEqasrK5ksPCTg=& zGl19RfPAh~dD3Fp=c(qI2k7vxhqt+b;Mf8nZ@AoCsl=MbCTr~(G_c6XSF&|!!V_|v ztoU}jF#tLhP`=zlUrMl^_i6eu8|p<7aB$frEcARo&52kuik+C2>EyJQ_CcczJYm?Y z>yy=X{ya?)hW4^M0BV2mt5;qWRhr2U>b^^=6mVp_5Uyk*Vzoh%Sf#bfs@^7onix|8+&@MZJ>^BRIBg+kOjq>L>m4`0b@}#L5 zU&3)q5JP&a`?NZIKkNrK(qwMWsSw7FO6RIZf1^d~@wWRRjkQ;36J&&}7!08E&x4dB4Z*B)U)u}-ftoJpS90Ps{Ap(2=7p}yUWugvY4MEPO^v+(1yZnHF z0Dn#Ir^$fHA2spn?;^&j+b>1}n%{u;yK~V`=(tp_l{LTG*6<6X(!n{;ZP5As(|$NW zmQ}j7!tsOe!w~0U|CmCsg#W`#IGKO)%EYQ^Re;L(qLvhlC%C0Lo%6mcM6&Q6Pp3gF z=JxY4?OeSV=$RdcnzObW@)ujyLijFp9`7a>lX>oji4ZQB(|9mv4(fO(FwySeNDT7a z36pdElToUCS+A!qE#)aw9rccdbI12-P3?*PVSI#a@gcg_5*} zhOj*L#}tdb)0}=xX>qYfG^C56G3J4ETrUiWAIG}c7UlLiUDllWD{G6tu9N95v~_M) z+H8)KzV@Vl!dPIAJO3`AHMG@CdFNkj-yQ-c91vgtGJ~z2jE#^^3V|W&7dR zy#%_r+JHX109P8NJ}Vutq?N|`XA~&{9gb7 literal 0 HcmV?d00001 diff --git a/documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-link.png b/documentation-templates/contributor-guide/application/contributor-guide/assets/tester-build-link.png new file mode 100644 index 0000000000000000000000000000000000000000..62be4174a03b060a45a8173506047fa843165069 GIT binary patch literal 27025 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

~k4-N;l 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 + +# Beta Testing Guide + +Beta testing of development versions is a valuable contribution to the project. You can help to ensure the quality of the production release that will be distributed to the user community. + +Builds of the project are automatically created after every relevant change to the project in order to make it easy for anyone to participate in the testing effort. + +--- + +❗ Make sure to always download the newest available tester build in order to ensure effective results from your beta testing efforts. + +--- + +Beta testing is done during both the proposal (pull request) and pre-release (nightly build) phases of development: + +## Testing Pull Requests + +Tester builds are automatically created for every [pull request](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) (PR) that proposes a relevant change. + +The builds are updated if the author pushes changes to the PR. + +### Installation + +The tester build for a PR can be downloaded by following these instructions: + +1. Sign in to your [**GitHub**](https://github.com/) account.
+ (GitHub only allows downloads of the tester builds when you are signed in.) +1. Open the PR you are interested in.
+ They are listed here:
+ https://github.com/arduino/TODO_REPO_NAME/pulls +1. Click the "**Checks**" tab at the top of the PR's page. +1. From the list on the left side of the page, click on "**Publish Tester Build**". +1. From the "**Artifacts**" section of the page that opens, click the download link for your operating system.
+ **ⓘ** For example, if you are using Windows, click the "**Windows_X86-64_zip**" link. +1. Wait for the download to finish. +1. Extract or install the downloaded file as usual. + +![checks tab](assets/checks-tab.png) + +![tester build link](assets/tester-build-link.png) + +![tester build artifacts](assets/tester-build-artifacts.png) + +### Feedback + +Feedback after beta testing a pull request is always valuable, regardless of which categories your findings fall under: + +- working as expected +- problems encountered +- areas for improvement + +Please submit feedback related to the changes made in the pull request as a PR review: + +https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews + +--- + +If you discover problems or areas for improvement that are unrelated to the changes made by the PR (i.e., they also occur when using the [nightly build](#testing-nightly-build)), please submit that feedback as an issue report instead of a review. + +[More information on issue reports](issues.md#issue-report-guide) + +## Testing Nightly Build + +Builds of the project's production branch are produced daily. This build represents the current pre-release state of the project, which is planned for distribution in the next release. + +### Installation + + + +### Feedback + +If you discover any problems or areas for improvement please submit an issue report. + +[More information on issue reports](issues.md#issue-report-guide) diff --git a/documentation-templates/contributor-guide/general/CONTRIBUTING.md b/documentation-templates/contributor-guide/general/CONTRIBUTING.md new file mode 100644 index 00000000..0d7ad214 --- /dev/null +++ b/documentation-templates/contributor-guide/general/CONTRIBUTING.md @@ -0,0 +1,27 @@ + + +# Contributor Guide + +Thanks for your interest in contributing to this project! + +There are several ways you can get involved: + +| Type of contribution | Contribution method | +| ----------------------------------------- | -------------------------------------------------------------------------------- | +| - Support
- Question
- Discussion | Post on the [**Arduino Forum**][forum] | +| - Bug report
- Feature request | Issue report (see the guide [**here**][issues]) | +| Testing | Beta testing, PR review (see the guide [**here**][beta-testing]) | +| - Bug fix
- Enhancement | Pull request (see the guide [**here**][prs]) | +| Monetary | - [Donate][donate]
- [Sponsor][sponsor]
- [Buy official products][store] | + +[forum]: https://forum.arduino.cc +[issues]: contributor-guide/issues.md#issue-report-guide +[beta-testing]: contributor-guide/beta-testing.md#beta-testing-guide +[prs]: contributor-guide/pull-requests.md#pull-request-guide +[donate]: https://www.arduino.cc/en/donate/ +[sponsor]: https://github.com/sponsors/arduino +[store]: https://store.arduino.cc + +## Resources + +- [**Development Guide**](development.md#development-guide) diff --git a/documentation-templates/contributor-guide/general/contributor-guide/assets/checks.png b/documentation-templates/contributor-guide/general/contributor-guide/assets/checks.png new file mode 100644 index 0000000000000000000000000000000000000000..888e711b4a2ea0c64d0e470aa4997c0c21ecaa59 GIT binary patch literal 40075 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

W`+0NwJpCYq|gkp3MnG?=k~g0**X^r20} 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 + +# Issue Report Guide + +--- + +❗ Do you need help or have a question about using this project? Support requests should be made to the [Arduino Forum](https://forum.arduino.cc). + +--- + +High quality bug reports and feature requests are valuable contributions to this project. These can be made by submitting an issue report to the project's GitHub repository: + +https://github.com/arduino/TODO_REPO_NAME/issues/new/choose + +## Before Reporting an Issue + +- Give the latest development version a test drive to see if your issue was already resolved:
+ +- Search [existing pull requests and issues](https://github.com/arduino/TODO_REPO_NAME/issues?q=) to see if it was already reported.
+ If you have additional information to provide about an existing issue, please comment there instead of creating a duplicate. You can use [GitHub's "Reactions" feature](https://github.blog/2016-03-10-add-reactions-to-pull-requests-issues-and-comments/) if you only want to express support 👍. + +## Qualities of an Excellent Report + +- Concise and descriptive issue title.
+ Vague titles make it difficult to decipher the purpose of the issue when looking through the list of reports, which might result in your issue not being given proper attention. +- Describe the issue and what behavior you were expecting.
+ Include the full and exact text of any relevant error or warning messages you might have encountered. +- Provide a full set of steps necessary to reproduce the issue.
+ Demonstration code or commands should be complete and simplified to the minimum necessary to reproduce the issue. +- Be responsive.
+ We may need you to provide additional information in order to investigate and resolve the issue.
+ Make sure your GitHub account is configured so that you will receive notifications of responses to your issue report. +- If you find a solution to your problem, please comment on your issue report with an explanation of how you were able to fix it, then close the issue. diff --git a/documentation-templates/contributor-guide/general/contributor-guide/pull-requests.md b/documentation-templates/contributor-guide/general/contributor-guide/pull-requests.md new file mode 100644 index 00000000..7b67554a --- /dev/null +++ b/documentation-templates/contributor-guide/general/contributor-guide/pull-requests.md @@ -0,0 +1,199 @@ + + +# Pull Request Guide + +A [**pull request**](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) (PR) is the mechanism used to propose changes to the content of this project's repository. + +If you are looking for ideas of what to work on, check [the list of open issue reports](https://github.com/arduino/TODO_REPO_NAME/issues). Pull requests addressing any of those bug reports and feature requests are welcome. + +## Contribution Workflow + +Each contribution travels through a formal process which allows it to be efficiently incorporated into the project. + +### 1. Plan + +#### Research + +Start by searching the repository for existing pull requests and issues related to your planned contribution so you can see any related conversations and proposals and avoid duplicate effort: + +https://github.com/arduino/TODO_REPO_NAME/issues?q= + +#### Discussion + +It can sometimes be useful to get feedback from others during the planning process. There are a couple good options for discussing planned development work: + +- Talk with the user community on the [Arduino Forum](https://forum.arduino.cc/). +- Talk with Arduino developers on the [Arduino Developers Mailing List](https://groups.google.com/a/arduino.cc/g/developers). + +### 2. Fork + +Forking a GitHub repository creates a copy of it under your account. You will stage contributions in your fork of this project. + +[More information about forking repositories](https://docs.github.com/get-started/quickstart/fork-a-repo) + +#### Enabling CI in Your Fork + +The repository is configured to run automated [continuous integration](https://wikipedia.org/wiki/Continuous_integration) (CI) checks and tests. It's a good idea to enable CI in your fork so you can make sure your work will pass the checks before you submit a pull request: + +1. Open the homepage of your fork in the browser. +1. Click the "**Actions**" tab. +1. Click the **I understand my workflows, go ahead and enable them** button. +1. Some of the workflows will now need to be activated individually. Perform the following steps for each of the useful workflows listed on the left side of the page that have a "**!**" icon: + 1. Click on the workflow name. + 1. Click the **Enable workflow** button. + +### 3. Clone + +Cloning a repository creates a copy of it on your computer. + +It is possible to make simple changes to your repository using the GitHub web interface without cloning the repository. However, the GitHub web interface is quite limiting so you will likely find the need to work with a clone (using **Git** directly or your choice of [Git client software](https://git-scm.com/downloads/guis)) for any significant development work. + +[More information about cloning repositories](https://git-scm.com/docs/git-clone) + +### 4. Branch + +Create a branch in your fork to contain the changes for your contribution. You must make a separate branch in your fork for each pull request you submit. + +[More information about branches](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-branches) + +### 5. Make a change + +Some things to keep in mind: + +- Make sure your change complies with the project's established style conventions. +- Remember to also update the documentation content in the repository if required by your changes. +- If the project contains a test suite, update or add tests according to your change as appropriate. + +See [the development guide](../development.md#development-guide) for more information. + +### 6. Test + +Test your change carefully to make sure it works correctly and did not break other components of the project. + +As a supplement for general testing, the project is set up with automated checks and tests to facilitate development. + +See [the development guide](../development.md#development-guide) for instructions. + +### 7. Commit + +Once the work on your change is complete, add it to the revision history of the Git repository by making a commit. + +Make sure to follow the [Commit Guidelines](#commit-guidelines). + +[More information about commits](https://git-scm.com/docs/git-commit) + +### 8. Push + +If you're working from a [clone](#3-clone), you will need to push your commit to your fork on GitHub. + +[More information about pushing commits](https://git-scm.com/docs/git-push) + +#### Checking CI Results + +If you have [enabled CI in your repository](#enabling-ci-in-your-fork), GitHub will run the relevant checks automatically every time you push a commit to your fork. + +You can see the results of these checks by doing either of the following: + +- Clicking the status icon (✔️ or ❌) shown to the right of a commit. +- Opening the repository's "**Actions**" tab. + +### 9. Pull request + +A pull request (PR) is a proposal to make a change in a repository. The repository maintainer is able to accept the changes you propose in a pull request by simply clicking a button. + +[More information about pull requests](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) + +#### Scope + +Each pull request should address a single bug fix or enhancement. If you have multiple unrelated fixes or enhancements to contribute, submit them as separate pull requests. + +#### Description + +Pull request title and description should follow [the same guidelines as commit messages](#commit-message). + +If your pull request fixes an issue in the issue tracker, use [a closing keyword](https://docs.github.com/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword) in the body to indicate this. + +In some cases, it might make sense to request feedback on a proposal before it is ready to be merged. You can indicate this by starting the pull request title with **[WIP]** (work in progress). Once the pull request is ready to be merged, edit the title and remove the "[WIP]". + +#### Cross-repository Contributions + +Some proposals may require changes to multiple repositories. Pull requests should be submitted in parallel to each repository. + +Clearly note any dependencies on other PRs in the description so that these can be evaluated by the reviewer and the merges coordinated. + +--- + +Please check whether any changes are required to the related documentation content hosted in the separate dedicated repositories: + +- [**arduino/docs-content**](https://github.com/arduino/docs-content) +- [**arduino/help-center-content**](https://github.com/arduino/help-center-content) + +### 10. Resolve CI failures + +Relevant checks will run automatically once you have submitted the pull request. Once these checks are finished, you can see a summary of the results near the bottom of the pull request page: + +![checks](assets/checks.png) + +Failed checks will be indicated with an ❌. If any checks failed, please fix whatever caused it to fail. Click the "**Details**" link to the right of the check name to open the logs, which provide details about the failure. + +--- + +**ⓘ** In some rare cases, a CI failure may be unrelated to the changes made in your pull request. So if the information in the logs doesn't seem relevant, please comment on the pull request to ask a maintainer to take a look. + +--- + +When you push to the branch of your fork the pull request was submitted from, the commit is automatically added to the pull request. Don't create a new pull request to fix problems; update the existing pull request. + +### 11. Resolve changes requested from reviews + +Interested parties may review your pull request and suggest improvements. + +To act on general review suggestions, you can add commits to the branch you submitted the pull request from, which will automatically be added to the pull request. Don't create a new pull request to act on review suggestions; update the existing pull request. + +Reviewers may suggest specific changes, which can be applied by [clicking the **Commit suggestion** button](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/incorporating-feedback-in-your-pull-request#applying-suggested-changes). + +[More information about pull request reviews](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews) + +### 12. Merge + +One of the repository maintainers can now choose to accept your proposed change. Once the pull request is [merged](https://docs.github.com/pull-requests/collaborating-with-pull-requests/incorporating-changes-from-a-pull-request/merging-a-pull-request), you can delete the branch you created in your fork for the pull request and delete the fork as well if you like. + +Thanks so much for your contribution! + +--- + +It is possible that the maintainers may decide a pull request doesn't align with Arduino's goals for the project and close it rather than merging. A record of the proposed changes will always be available on GitHub for future reference. If you think your modifications will be of use to others, you are welcome to maintain your own fork of the repository. + +--- + +## Commit Guidelines + +The commit history of a repository is an important resource for developers. Repositories may accumulate thousands of commits over the course of decades. Each individual commit contributes either to the commit history being pleasant and efficient to work with, or to it being a confusing mess. For this reason, it's essential for contributors to create clean, high quality commits. + +### Scope + +Commits must be "atomic". This means that the commit completely accomplishes a single task. Each commit should result in fully functional code. Multiple tasks should not be combined in a single commit, but a single task should not be split over multiple commits (e.g., one commit per file modified is not a good practice). + +[More information about atomic commits](https://www.freshconsulting.com/insights/blog/atomic-commits/) + +### Commit Message + +The commit message documents what the change was and why it was done. A little effort now writing a good commit message can save future developers from wasted time and frustration trying to understand the purpose of a poorly documented commit. + +#### Commit Message Title + +- Use the [imperative mood](https://cbea.ms/git-commit/#imperative) in the title.
+ For example: + > Use LED_BUILTIN macro in LED pin definition +- Capitalize the title. +- Do not end the title with punctuation. +- Do not use GitHub's default commit titles (e.g., "Update examples/Foo/Foo.ino"). + +#### Commit Message Body + +- Separate title from the body with a blank line. If you're committing via GitHub or [GitHub Desktop](https://desktop.github.com/) this will be done automatically. +- Wrap body at 120 characters. +- Completely explain the purpose of the commit.
+ Include a rationale for the change, any caveats, side-effects, etc. + +[More information on commit messages](https://cbea.ms/git-commit/) diff --git a/documentation-templates/contributor-guide/other/contributor-guide/beta-testing.md b/documentation-templates/contributor-guide/other/contributor-guide/beta-testing.md new file mode 100644 index 00000000..b0a4d9d8 --- /dev/null +++ b/documentation-templates/contributor-guide/other/contributor-guide/beta-testing.md @@ -0,0 +1,45 @@ + + +# Beta Testing Guide + +Beta testing of development versions is a valuable contribution to the project. You can help to ensure the quality of the production release that will be distributed to the user community. + +--- + +❗ Make sure to always download the newest available development version of the project in order to ensure effective results from your beta testing efforts. + +--- + +Beta testing is done during both the pull request and pre-release phases of development: + +## Testing Pull Requests + + + +### Feedback + +Feedback after beta testing a pull request is always valuable, regardless of which categories your findings fall under: + +- working as expected +- problems encountered +- areas for improvement + +Please submit feedback related to the changes made in the pull request as a PR review: + +https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews + +--- + +If you discover problems or areas for improvement that are unrelated to the changes made by the PR (i.e., they also occur when using the [pre-release](#testing-pre-release) version), please submit that feedback as an issue report instead of a review. + +[More information on issue reports](issues.md#issue-report-guide) + +## Testing Pre-Release + + + +### Feedback + +If you discover any problems or areas for improvement please submit an issue report. + +[More information on issue reports](issues.md#issue-report-guide) diff --git a/documentation-templates/contributor-guide/other/development.md b/documentation-templates/contributor-guide/other/development.md new file mode 100644 index 00000000..9f039538 --- /dev/null +++ b/documentation-templates/contributor-guide/other/development.md @@ -0,0 +1,25 @@ + + +# Development Guide + +## Prerequisites + +The following development tools must be available in your local environment: + + + +## Building the Project + + + +## Running Checks + +Checks and tests are set up to ensure the project content is functional and compliant with the established standards. + + + +## Automatic Corrections + +Tools are provided to automatically bring the project into compliance with some of the required checks. + + diff --git a/documentation-templates/contributor-guide/task/development.md b/documentation-templates/contributor-guide/task/development.md new file mode 100644 index 00000000..52233c87 --- /dev/null +++ b/documentation-templates/contributor-guide/task/development.md @@ -0,0 +1,45 @@ + + +# Development Guide + +## Prerequisites + +The following development tools must be available in your local environment: + + + +- [**Task**](https://taskfile.dev/installation/) - task runner tool + +## Building the Project + +--- + +**ⓘ** If you only want to test an existing version of the project, automatically generated builds are available for download without building from source. See the instructions in the [**beta testing guide**](contributor-guide/beta-testing.md#beta-testing-guide). + +--- + +You can build the project by running this command from the root folder of the project: + +```text +task build +``` + +## Running Checks + +Checks and tests are set up to ensure the project content is functional and compliant with the established standards. + +You can run the checks by running this command from the root folder of the project: + +```text +task check +``` + +## Automatic Corrections + +Tools are provided to automatically bring the project into compliance with some of the required checks. + +You can make these automatic fixes by running this command from the root folder of the project: + +```text +task fix +``` diff --git a/issue-templates/template-choosers/general/config.yml b/issue-templates/template-choosers/general/config.yml index a967c310..6ae7499f 100644 --- a/issue-templates/template-choosers/general/config.yml +++ b/issue-templates/template-choosers/general/config.yml @@ -11,6 +11,14 @@ contact_links: - name: Support request url: https://forum.arduino.cc/ about: We can help you out on the Arduino Forum! + - name: Issue report guide + # TODO: Replace TODO_REPO_OWNER/TODO_REPO_NAME with the repository owner and name + url: https://github.com/TODO_REPO_OWNER/TODO_REPO_NAME/blob/main/docs/contributor-guide/issues.md#issue-report-guide + about: Learn about submitting issue reports to this repository. + - name: Contributor guide + # TODO: Replace TODO_REPO_OWNER/TODO_REPO_NAME with the repository owner and name + url: https://github.com/TODO_REPO_OWNER/TODO_REPO_NAME/blob/main/docs/CONTRIBUTING.md#contributor-guide + about: Learn about contributing to this project. - name: Discuss development work on the project url: https://groups.google.com/a/arduino.cc/g/developers about: Arduino Developers Mailing List diff --git a/issue-templates/template-choosers/github-actions/config.yml b/issue-templates/template-choosers/github-actions/config.yml index 54565e3c..8abf02d2 100644 --- a/issue-templates/template-choosers/github-actions/config.yml +++ b/issue-templates/template-choosers/github-actions/config.yml @@ -14,6 +14,14 @@ contact_links: - name: Support request url: https://forum.arduino.cc/ about: We can help you out on the Arduino Forum! + - name: Issue report guide + # TODO: Replace TODO_REPO_OWNER/TODO_REPO_NAME with the repository owner and name + url: https://github.com/TODO_REPO_OWNER/TODO_REPO_NAME/blob/main/docs/contributor-guide/issues.md#issue-report-guide + about: Learn about submitting issue reports to this repository. + - name: Contributor guide + # TODO: Replace TODO_REPO_OWNER/TODO_REPO_NAME with the repository owner and name + url: https://github.com/TODO_REPO_OWNER/TODO_REPO_NAME/blob/main/docs/CONTRIBUTING.md#contributor-guide + about: Learn about contributing to this project. - name: Discuss development work on the project url: https://groups.google.com/a/arduino.cc/g/developers about: Arduino Developers Mailing List diff --git a/other/installation-script/installation.md b/other/installation-script/installation.md index 3359a802..1a564dc8 100644 --- a/other/installation-script/installation.md +++ b/other/installation-script/installation.md @@ -93,4 +93,4 @@ Checksums for the nightly builds are available at ## Build from source If you're familiar with Golang or if you want to contribute to the project, you will probably build TODO_PRODUCT_NAME locally -with your Go toolchain. See the ["How to contribute"](CONTRIBUTING.md#building-the-source-code) page for instructions. +with your Go toolchain. See the ["How to contribute"](development.md#building-the-project) page for instructions. diff --git a/workflow-templates/check-go-dependencies-task.md b/workflow-templates/check-go-dependencies-task.md index 700fa92c..b5359424 100644 --- a/workflow-templates/check-go-dependencies-task.md +++ b/workflow-templates/check-go-dependencies-task.md @@ -65,7 +65,9 @@ A dependency might use a license type that can not be allowed globally via the ` In this case, the dependency's identifier must be added to the `reviewed.[*]` key in the `.licensed.yml` configuration file. -### Readme badge +### Documentation + +#### Readme badge Markdown badge: @@ -85,6 +87,26 @@ image:https://github.com/{repository-owner}/{repository-name}/actions/workflows/ Define the `{repository-owner}` and `{repository-name}` attributes and use them throughout the readme ([example](https://raw.githubusercontent.com/arduino-libraries/WiFiNINA/master/README.adoc)). +#### Development Guide + +Add the following under the "**Running Checks**" section of the project's development documentation (template available [here](../documentation-templates/contributor-guide/task/development.md)): + +````markdown +### Dependency License Metadata + +Metadata about the license types of all dependencies is cached in the repository. To update this cache, run the following command from the repository root folder: + +```text +task general:cache-dep-licenses +``` + +The necessary **Licensed** tool can be installed by following [these instructions](https://github.com/github/licensed#as-an-executable). + +Unfortunately, **Licensed** does not have Windows support. + +An updated cache is also generated whenever the cache is found to be outdated by the by the "**Check Go Dependencies**" CI workflow and made available for download via the `dep-licenses-cache` [workflow artifact](https://docs.github.com/actions/managing-workflow-runs/downloading-workflow-artifacts). +```` + ## Commit message ``` diff --git a/workflow-templates/check-npm-dependencies-task.md b/workflow-templates/check-npm-dependencies-task.md index 4b8f133c..5535e4d4 100644 --- a/workflow-templates/check-npm-dependencies-task.md +++ b/workflow-templates/check-npm-dependencies-task.md @@ -90,7 +90,9 @@ ignore: | /.licenses/ ``` -### Readme badge +### Documentation + +#### Readme badge Markdown badge: @@ -110,6 +112,26 @@ image:https://github.com/{repository-owner}/{repository-name}/actions/workflows/ Define the `{repository-owner}` and `{repository-name}` attributes and use them throughout the readme ([example](https://raw.githubusercontent.com/arduino-libraries/WiFiNINA/master/README.adoc)). +#### Development Guide + +Add the following under the "**Running Checks**" section of the project's development documentation (template available [here](../documentation-templates/contributor-guide/task/development.md)): + +````markdown +### Dependency License Metadata + +Metadata about the license types of all dependencies is cached in the repository. To update this cache, run the following command from the repository root folder: + +```text +task general:cache-dep-licenses +``` + +The necessary **Licensed** tool can be installed by following [these instructions](https://github.com/github/licensed#as-an-executable). + +Unfortunately, **Licensed** does not have Windows support. + +An updated cache is also generated whenever the cache is found to be outdated by the by the "**Check Go Dependencies**" CI workflow and made available for download via the `dep-licenses-cache` [workflow artifact](https://docs.github.com/actions/managing-workflow-runs/downloading-workflow-artifacts). +```` + ## Commit message ``` diff --git a/workflow-templates/deploy-cobra-mkdocs-versioned-poetry.md b/workflow-templates/deploy-cobra-mkdocs-versioned-poetry.md index 6239e5e0..5aa4417a 100644 --- a/workflow-templates/deploy-cobra-mkdocs-versioned-poetry.md +++ b/workflow-templates/deploy-cobra-mkdocs-versioned-poetry.md @@ -89,7 +89,9 @@ Add the following to `.gitignore`: ``` 1. Follow the remaining setup steps from the ["Deploy Website" workflow (versioned, MkDocs, Poetry) documentation](deploy-mkdocs-versioned-poetry.md#setup). -### Readme badge +### Documentation + +#### Readme badge Markdown badge: @@ -109,6 +111,10 @@ image:https://github.com/{repository-owner}/{repository-name}/actions/workflows/ Define the `{repository-owner}` and `{repository-name}` attributes and use them throughout the readme ([example](https://raw.githubusercontent.com/arduino-libraries/WiFiNINA/master/README.adoc)). +#### Development Guide + +See the ["Deploy Website" workflow (MkDocs, Poetry) documentation](deploy-mkdocs-poetry.md#development-guide) + ## Website versioning See the ["Deploy Website" workflow (versioned, MkDocs, Poetry) documentation](deploy-mkdocs-versioned-poetry.md#website-versioning) for an explanation of how the versioning works. diff --git a/workflow-templates/deploy-mkdocs-poetry.md b/workflow-templates/deploy-mkdocs-poetry.md index 3d273328..df38903a 100644 --- a/workflow-templates/deploy-mkdocs-poetry.md +++ b/workflow-templates/deploy-mkdocs-poetry.md @@ -53,7 +53,9 @@ Add entries for each website source file to the `nav` array in `mkdocs.yml`, or Reference: https://www.mkdocs.org/user-guide/configuration/ -### Readme badge +### Documentation + +#### Readme badge Markdown badge: @@ -73,6 +75,24 @@ image:https://github.com/{repository-owner}/{repository-name}/actions/workflows/ Define the `{repository-owner}` and `{repository-name}` attributes and use them throughout the readme ([example](https://raw.githubusercontent.com/arduino-libraries/WiFiNINA/master/README.adoc)). +#### Development Guide + +Add the following to the project's development documentation (templates available [here](../documentation-templates/README.md#development-guide)): + +````markdown +## Documentation + +The [Markdown](https://www.markdownguide.org/basic-syntax/) files under the `docs` subfolder of the repository are the source content for the project's documentation website. + +When working on the documentation, it may be useful to see the effect the changes will have on the generated documentation website. You can build the documentation website and serve it from your personal computer by running this command from the project root: + +```text +task website:serve +``` + +The website will now build. If you don't see any error, open `http://127.0.0.1:8000` in your browser to load the local copy of the documentation site. +```` + ## Commit message ``` diff --git a/workflow-templates/deploy-mkdocs-versioned-poetry.md b/workflow-templates/deploy-mkdocs-versioned-poetry.md index 363b0ca8..8384fbdc 100644 --- a/workflow-templates/deploy-mkdocs-versioned-poetry.md +++ b/workflow-templates/deploy-mkdocs-versioned-poetry.md @@ -89,7 +89,9 @@ This will do the following: After this initial deployment, all further website updates will be handled automatically by the "Deploy Website" workflow. -### Readme badge +### Documentation + +#### Readme badge Markdown badge: @@ -109,6 +111,10 @@ image:https://github.com/{repository-owner}/{repository-name}/actions/workflows/ Define the `{repository-owner}` and `{repository-name}` attributes and use them throughout the readme ([example](https://raw.githubusercontent.com/arduino-libraries/WiFiNINA/master/README.adoc)). +#### Development Guide + +See the ["Deploy Website" workflow (MkDocs, Poetry) documentation](deploy-mkdocs-poetry.md#development-guide) + ## Website versioning This system is designed for projects that use release branches. The website versioning is based on branch names: From 5716569fd919fac4a4a4fe7afa8a61413aad2725 Mon Sep 17 00:00:00 2001 From: per1234 Date: Fri, 9 Sep 2022 07:32:33 -0700 Subject: [PATCH 2/2] Add a project contributor guide Documentation of how to contribute to the project gives everyone the opportunity to participate, while also reducing maintenance effort and increasing quality of contributions. This guide documents the various ways of contributing to the project. It takes advantage of GitHub's "contributing guidelines" feature to increase the visibility of the information to prospective contributors. The promoted "CONTRIBUTING.md" file is used as an entry point to the guide, with links from there leading to dedicated guides for each specific type of contribution. In this way, the contributor is only presented with relevant information, improving the approachability and readability of the content. --- .github/ISSUE_TEMPLATE/config.yml | 6 + .../workflows/check-community-health-sync.yml | 4 + Taskfile.yml | 10 + docs/CONTRIBUTING.md | 27 +++ docs/contributor-guide/assets/checks.png | Bin 0 -> 40075 bytes docs/contributor-guide/beta-testing.md | 51 +++++ docs/contributor-guide/issues.md | 32 +++ docs/contributor-guide/pull-requests.md | 199 ++++++++++++++++++ docs/development.md | 44 ++++ 9 files changed, 373 insertions(+) create mode 100644 docs/CONTRIBUTING.md create mode 100644 docs/contributor-guide/assets/checks.png create mode 100644 docs/contributor-guide/beta-testing.md create mode 100644 docs/contributor-guide/issues.md create mode 100644 docs/contributor-guide/pull-requests.md create mode 100644 docs/development.md diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml index b0e14d19..28473a0a 100644 --- a/.github/ISSUE_TEMPLATE/config.yml +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -13,6 +13,12 @@ contact_links: - name: Support request url: https://forum.arduino.cc/ about: We can help you out on the Arduino Forum! + - name: Issue report guide + url: https://github.com/arduino/tooling-project-assets/blob/main/docs/contributor-guide/issues.md#issue-report-guide + about: Learn about submitting issue reports to this repository. + - name: Contributor guide + url: https://github.com/arduino/tooling-project-assets/blob/main/docs/CONTRIBUTING.md#contributor-guide + about: Learn about contributing to this project. - name: Discuss development work on the project url: https://groups.google.com/a/arduino.cc/g/developers about: Arduino Developers Mailing List diff --git a/.github/workflows/check-community-health-sync.yml b/.github/workflows/check-community-health-sync.yml index e962c5f0..9285c258 100644 --- a/.github/workflows/check-community-health-sync.yml +++ b/.github/workflows/check-community-health-sync.yml @@ -13,12 +13,16 @@ on: - ".github/workflows/check-community-health-sync.ya?ml" - "Taskfile.ya?ml" - ".github/ISSUE_TEMPLATE/**" + - "docs/**" + - "documentation-templates/**" - "issue-templates/**" pull_request: paths: - ".github/workflows/check-community-health-sync.ya?ml" - "Taskfile.ya?ml" - ".github/ISSUE_TEMPLATE/**" + - "docs/**" + - "documentation-templates/**" - "issue-templates/**" schedule: # Run periodically to catch breakage caused by external changes. diff --git a/Taskfile.yml b/Taskfile.yml index be860107..21fc920f 100644 --- a/Taskfile.yml +++ b/Taskfile.yml @@ -453,9 +453,19 @@ tasks: github:sync: desc: Sync GitHub community health files vars: + DOCUMENTATION_INSTALLATION_PATH: "./docs" + DOCUMENTATION_TEMPLATES_PATH: "./documentation-templates" ISSUE_TEMPLATES_INSTALLATION_PATH: "./.github/ISSUE_TEMPLATE" ISSUE_TEMPLATES_PATH: "./issue-templates" cmds: + - | + cp \ + "{{.DOCUMENTATION_TEMPLATES_PATH}}/contributor-guide/general/CONTRIBUTING.md" \ + "{{.DOCUMENTATION_INSTALLATION_PATH}}" + - | + cp \ + "{{.DOCUMENTATION_TEMPLATES_PATH}}/contributor-guide/general/contributor-guide/assets/"* \ + "{{.DOCUMENTATION_INSTALLATION_PATH}}/contributor-guide/assets/" - | cp \ "{{.ISSUE_TEMPLATES_PATH}}/minimal/bug-report.md" \ diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md new file mode 100644 index 00000000..0d7ad214 --- /dev/null +++ b/docs/CONTRIBUTING.md @@ -0,0 +1,27 @@ + + +# Contributor Guide + +Thanks for your interest in contributing to this project! + +There are several ways you can get involved: + +| Type of contribution | Contribution method | +| ----------------------------------------- | -------------------------------------------------------------------------------- | +| - Support
- Question
- Discussion | Post on the [**Arduino Forum**][forum] | +| - Bug report
- Feature request | Issue report (see the guide [**here**][issues]) | +| Testing | Beta testing, PR review (see the guide [**here**][beta-testing]) | +| - Bug fix
- Enhancement | Pull request (see the guide [**here**][prs]) | +| Monetary | - [Donate][donate]
- [Sponsor][sponsor]
- [Buy official products][store] | + +[forum]: https://forum.arduino.cc +[issues]: contributor-guide/issues.md#issue-report-guide +[beta-testing]: contributor-guide/beta-testing.md#beta-testing-guide +[prs]: contributor-guide/pull-requests.md#pull-request-guide +[donate]: https://www.arduino.cc/en/donate/ +[sponsor]: https://github.com/sponsors/arduino +[store]: https://store.arduino.cc + +## Resources + +- [**Development Guide**](development.md#development-guide) diff --git a/docs/contributor-guide/assets/checks.png b/docs/contributor-guide/assets/checks.png new file mode 100644 index 0000000000000000000000000000000000000000..888e711b4a2ea0c64d0e470aa4997c0c21ecaa59 GIT binary patch literal 40075 zcmZ^q1B@?0xaI#dcWm39JJucBwr$(Cb;q`S$F^~>P=q?4}hq^qmy ze7|$TRB+e; z00BT;h+oNV?IO!n4`*=oJIA`&vlBhbHx(5I^t^J zMpp3o5eDiI5MRqj@c01$RA>RAgNkqpA4Ej?4{1;&%A)(vIu&}T_bVS5gB!Aua zW3fcIAR^{|;4nvjA|hQBgm4hm(IOPe*Tg+|QNvv^se*W9wip5f|A;Uz1_Y2?%pv?J z2w*YF(e8~)Q#D$Ih!YkGNW$N`LI=>s&xi!1LHrdDpn}xnpW}PSY;eNzLJOT?Bj}Bg zeDo;B>|eTQ-2@P&rCx|}bc_@M5cro>$eo`*k6kS0rw0DtZ>j5kTTgv_^Fj(ji}p8c zL{;nqXBvKeQ=(OhFeL(%gy_!rP-1<`{$r<9u`00w_0D&6c{*z4)AaZ0F5=QI$=?1* zA&9X$L$z|GFg4K~C<5=eLqA-z2&F33VGdU~pK;^oqV!ikxqAo@KY$+q0tCV@9{$zj zT-?5_cv@z_9~q{#yy+8j%$`ktBg?UXjtG0Z6)O7o zuJ>KzGtH)TBQFYo5-2PxxEAe(TV(MjTQ%PFZdzsy{`fe)PX+z6w{@4?zWE-0wi3jOw;5zNGK2tdT-rsPCnhnN99|z!*LK;lTGt zdx+F#<0FM12+wd*C>I^U33)ogVTfktF!2)hF@UW6XxyLPX-RW?nzZe}T?N?Bx)RD& zm;eRzxinUroA9HT!XM$E2ilqyOBBC$iihF*$+FvnEn zkzDMgKsv6pmPdkFgP&hQ;wv%ypFNhsyfIDZ~HbYeNs&|Mej+{U|WOk|x^P1DXJ zz$|gt>>K~sm(y^DH(YH2*b(RwGc_&rOg#iKaiTwi0Qez5i?mr0u%4nz6%C)T0e=2;`c*n&0w2fhdr#bs{jB~ z*AWe_BG%PrviQg*ExE)T2S=a)GK|xDNUpqW7FqK+NGFOp78LBW*qAqv>}c30;k7oy zE(!ny4l?#dv=baXqDta;3M7v}4nFEtDi!Yr#sQxh@AVmEJ|$Uocfv7nT=Z~fxC-N0 zJ~-_|Jf^6fs3F@?v~okJNBIUzfmWNkg74by%`7Ua4i>=y6ibsRSjHwk^Dt6_Az6SW z$0gVPUSm&(_e6#nskZc0+pOB8dJb>jpA^pz`L_ki999%IFEWEgBJdbC>(Ab|uGErE z-^#ILjOa#JAzr3&-`+1puIW&s+SoPtiKrFt&{)}v%L0Wmk|~_aE8KV0^ejYdjHCYD zNU-(#=f9_4>-JSg{jdn-^O996QoX+jdfdT%p5GCOku!-SShfqbu47#eQMg?+8$4v! zdBNwuY?pS3>D0bn>IxlAzlSWOBI$LiUa=#yc)b;#=gzU-Zjfu!CU9s zgLnk>^k_A8j=G*f>WfG9`^I4jM5DbExu{DT<5aZIs|X z4SNv6}WGH zxv1>)Vxk$L{5}jOfW;%f{0RGO1c@m!miRt~o1fnnZ)=pxMwiX5e#EM(t3?yY7h0B4 z`JA>+?*7oV;Qy1hiR+Aw3aXG_6gx{Ums5NAt!Ci;smk_x^2NWNlf$~{8fr1bY%X&& zbDeFBGc`WOh-Iv;ic2W<2e4Q-EM^Wn}UvfJ|k=cD}Q*m?3h#1QEKhKkSfYDbW0o-c9 z7jFM1l1NL$*DTF%V#}L@N#sF@$&&&DAY>r8Xl{BOHbJcy5FgAFr^=}v z-S9mfnU#ad26X@BLc~`Rj8QrT`{?!vM>IllC zU6K~cBc^~kAR9F5JP&Wa)IhaAHprrs7HPPJq(sS;&%#qJGJBwj8Qu;TlRBtLu9#FO zsp(0GzVq%E>i~N17@ThPR;}FukEJq|V&b+ly_Us?US!oZXES6z?ksox+cQ@eb&o!C z$&2OTvpr zhe3GiaRzGgg6gXqc-CgHsqF4O$@@T8N{N!Fk4MsZ@8)_q)rN}aI-romxy=@Z^fZ^l zU@qFi^R|F+eai_*}AXM{b%A0i(=7~U}j`I9G=H)hD zQa4Q^a9R6@kP#asTIL`wa(_%~IoL7zFBcj>+hF#KipQ=A_gHrS3xf(D0PGDQ?*Z>(Y&lWD7?QfdU3AT zrbUWI1d-WMeS*XDevoe&YJVe|Rb!JlXBn#?J6rW^dDrAkTe&AsKt{&@EW4ETg=b;5 zM4O(k)?|2DFG)juFCvpEk^b4@M8u!Z{|V8s^-}wq-zJrjMX;sDdtFm;I zk~kl^OZ>485pud*GrIbQm4@<7ITyR~Zm||pU2%tHRc?g`_mvU;?`u}^Q2K!!LOj+b zyBv4tt8;u-U-NKPqq%uZ+xG5241`%$GD5EdEn;oN#*^ju|DlqYCrvYyQllw zT?He*PfJN*@svnD+?~#DkG}M_l}zEJ zw)j%u{&-I4DNM9^WSq=zZLm&+4t^B_Nf>7+%KVoqcehUkbbNKa<6LS>(g!iS6*6yK z#oaEu+2)okE4s+UPOcx0hx-y3*@i0=BUg@On;;Ef5NiUk^F7TK00 zr_2^mN_l6BKY1G>tRd1juRc3j{Y`#iqroE^3JQnH67L#^bfXXx*h894hJomuh+1b$zNov zq^VNu;BvvWBy}2Zl9KlJ7H-~J=lxz`y3w$q?TbbIY9%V{Uc$-K?6ynt+EtY#PbxJ= zS58+0qd(-_OeY64z{Rb6DVJWe(tQ09m7(HxHZ26vx(SKoDJ`8aocWi+ZZu4;OkqQ>SA&Azah zE|t-F?PIiz!mnpg=K3plm9P*sg(f?bdBNdpWtEnQ$NROia%sQh{PHS5z2d$|a2<|C zjQKWFMaoe%hhzOpJm*gZ-`R$DQ`+M3MzhzL>g=7agcw=ToZ^A7`&gZUIzL=m=8JeD zJfM?i6Y{lnu&}v~u2PbQLULTK)gs`|zg`vJ4(n*E*~P|F5LS9$5uL{OrU?_bq&)O3 zz2L1(x7}ENs&MbrJdH|KCn^}bQYFbLzi9u!KKOatGc^4Q^WUpgXI5FgZI`hR|KVuD zte)NgqV~V97)lFUWy2g#qaL+}2Ig>HuPK*#+~!SYx{ACGD0H`ser&Tc*VBng&jtM5 zjV3(iqKhwO_T$*a=O)z{vAXMSZ$eD_cOt`1c%B^$viM@UsU$phUWak(=E>QZ?1pg) z&3bZ#va7q(!dd;$SUhVkR*G)Jek_Mv?jE7F_BYWs?L59%>xIZ5b{s(TP=nB9w2}l2bTr>w03tqhJ{&-27ZSt_pE1AQCCy1ZOePMvI)-t3_VaRao^e3Y4$dHTfb$H( zE#xWZO0#}9hVn>EQ+8l$UJw6vE_>=~*RNz*GRUJ``wSLaB`)i+e>ZGWa9XP&;JTVo zTH9gz5_)K9Mn7?ARnfND-CWjm*{)~)TwX%GJ#Z?Ar!&{=ETD{%uYT=g&J)d4N!c~V zSUci2Fzd64U)QQ-^~x2D8;R%aF20PFHWlYSM$bOD$Q?5hZ8DjyVl7|%*-8zi)EtMi zgdafIZgkptZqmTgESUQ&rhOB_X``!?Y;IZRWDbSbVX2)?)NyP!dXLegSGSisyC(-i99+yqBx`@3eBD3&CfFXP`cEk&1n6f|@mPwEZ+DW)9Y47R z{XT^`a~V&0iYbdZ0AqRQrq&z3!?8^_ngI_!1EHq((4pR7kCs~9A^MoXAA+s#yR0uUGgkTPQI z&@s%Ds-kdK#l^x$c0NKi#0V8BL&K604II_j!jZtT;}T`(WztsryzwfgkPbpPF+?Rv zeDtrmLAA5Vyc_xOl;TI8IOT9T??hXNf_-YOT=h&qT2PkHo%C(_QT76YBqZx>wrAe4 zS@9~dNfXo6jWOG|eV?Tg9IxW*h6FuXaVx(9t`5KG@TVr>7F!pE>*uL4)SQS-!Esj; zL9}RXGxu<0;^qN!}WqEe>66MadWS-(-F&-U(J9cQvk3vBj2Ndh`` zIgiU2?(al%T5iTho~gf4lR0U!e;MPiEO}NoQbwGaVfm(vAY&dMpB-jhSgpZQOR>vX zXvA~4DEljw&S9qRJChb+>rl+i1&%I!<32|WtbMOE>pIZ9EwW%GyldL z{*#&fBM(&-5|)?EdN~H_cp!!i$WtoGps_Eik75+4QH14Ok9mGeu1ei-d_diAJ9U87 zFbY1skD!n+N#>XW03e(|Mzfi;**rW};8#5WFtV!1!yX;uD$=LyZ*@M_m_XbBzdek; zpiTdiLBh?!fWAeItnEML<1~_T7o5x8PI1ZA=`a8M1`uux+K)gGnEKsU>dLX;!Iv51Y((hj`q3{VxqoEk_{ua#Br)|i%LO+M|d4kS9J|* zd@6(I(m{gg8d!TSxtMG5G_fRQdLpW*eBzYV zUxm8~6l+68)4$7;*@^_cg&L@(dvnniP{bs^JLO9f&tOE-f(S_FUMi&`@T{>T&Sw0W z&Eu7$fe0}8%cDh#w6cu~u{7H*uKc#*OP9yYq~fx&NJ!}=s-q;uSi}OQaX$zlhQM>LqJIA!1f5D^LvMZz`t%wXKt73WwGLw^Sv zsEJX{t{l#t!*t{2lF?b$)~QaA>*DvK!IG4UnbRAg8dVD7(<+N+w_>{VL#1+3GqZ=H zo1VaL`!1{$GyVGj2p}n?6bti~kx3KT`f>;md)Ka%#Rr))7kYNK!hLIq#jpG^# z_mR~lp2JX>Qw1D=gri>X90wAT5_5G_e3a5e+*7lefb{_VaNOW2+24<5@?tM`e`Bl3iu6QnB z=dyHTJ$$P+|3#4;13GGnaPbv_O`?gLwLB1hcfs`qLB7z-M` zQgSw&&h>52{_>|g_FHHirn9?@s5b`AA(4P=2#oLOeYuse8rPmt;PU1HOyvdNPq4Iq z%hThJPK8`mvYXae%m*!jW_yDiDLu2fqpPI z*XTN_OaK7@`MwS6&*l?Rr|$20hIM2@PfsD~@#MUahN11(?}w7Ue2UY-jLRrUh;oaK zz7fH+AO2mCjD+7AX7*ZxJ(c|knRW*&nfQz43qochqoCb1rqY-m3fN2m^|^X(gpII! zI|t(3;ezR-`VEYyZ^ia1|9A!=J&Cb}u;O>-k26a*|8 z*M|^ERzBmGAhK8pgR14DQbULU0$@9)sA1SeM2{{PSJ3MO5~>*nu2yUQkr81=xJULg zjKt!E2)8qrHgM!KPS98PkYL2LU2=*C<|a(en4J? z?hnU9>Hgt(|2c;K7u;JWUS3-qrne%Ih&29zWT3$&?5icnyp#WS&7`RLe+F9l3+9ue zhEHo066;e~n3q2yi2cO>)!F~_^*^A{YxQMf>eAGG3i*DJO$5~>2?DYZByJoC8GZy6 z@l_$R+n{0hhR=P_ERgfe^TcQeEd_7ZeD*@>VrWq;Q<&QL=ec<=)`Y|O7CPMATDXU_ z7r;Agy?=;SL|%?mo@V5|9-%&#GWcnc$2Eiw#+i<;Z{fenKj=ci$LJ`1i2?v$fOdE6 z`>}I`=r2_p+1&nF9!@&1I#<7YYVL*UftMO9YXrBDCRkzXD=O%y=z$Os_a~~)-_B$c zA}6&-JApjOhe4g>T2nV}*7mS&6&Xa!GQBJ(>^`&?mv9#quQTuYYDYJ4?fd&fODyjq zo&wAMFM(1ovMe>KYZ(BJpRv{~k&kzh(y>YBM zm~I!bg4bDkL^-uLCtu}FHQc!Qyz+HgBb(p%wy`cE-F1(g3eNvNJ!74(*~Ycy4W8Pb za=1|c`6lVw{f1d!I|mz*An-6~r}87DIy!@`vj?3;9KwD{wHOk@_$j#wRBldtkK91O ztqX&{$Ez14`(-lMyn3o4D$ zhzo#TsJp%UPiC27?L!pjq!8&57IfkG_ZP;n)irw`Bo}}JVs$#AyNMtVMVNL00|hjG zz(gigF7NR`7||TRv{>t>a5$X zT4gAb{l(2`4(WS_fzKvqNU0z$>5pe$kHxiU@y^SYM1+Pg7~L)r5< zpmrF`oQLH>rs}rcRYdjzCi9$6p=4;gK3Ty4u(SCYunHZ+{@-4J^`smJ)w26Z(}0hM zM9+vzy6%AF%{(Qz*skW3M$t0mW_6PRPo05moc z0L*vG>0m?5fbJ07B6Z)6&My_E6WsnGVck*m2iCgTIBW@{JTJOzGbCJOFiD$c^ zHlD##dJFbFFu03HENdX`{UxV45T_WpV2h>J(35a@ zgJWjmMx?7svK=9f!GC6sS7X+B9g%XU5K?skf5x#xky)mZO1R*;)@GMYNg#ObX#ZS{ zIm*lRzPN`iyFXHk{Fz^XS2ES*QrB~;eJx|2!h`a3u6shUat2!PCmy-(-Ii-|p4rWJ zh^ke;_V5?ZyB}GUHSA8FZH2t!#5^4rLdtD3@i)I>XU}qvjs_pLQnIuWw@0lD$OA*J zy|p76;X2$O`skDJ-Jj%bb2e_WY|l)L^eFtQLW>+0sY>3ypJZ!to-RE5H>EJUzX3-) zOfNplJ2S<3%N2>(S4`D8qGNUdJ&`rA>`fB&HZW}VW4CsluNhWn=zBSJ*}pmSN#bBn6FdPO0)3OUD7S|?0cv7)2pXcZT+t!!IK@l^(LRk&u1z{ z@BZn_m}u9`*A>2unmWPGvp+btwbmSnj!!TjUvy$u4*RUj_s-YwHr8^qEpbxyzps7O zvhuJZk*nGFR@TZsu9_R`6%aWvEG~B0baqbcETM4^1CsC`K0m|Gl0Boalj93*Z@#mk z?#qhtc}gk&36(!ZUDTgZ%%J7ASLG4s)&9dP{3&l8t9o zQHT?uRnt>X6uz$!Rnr6P3O;xFV@o{&06rUya^C}+dtz5h)3TxSU;PdmlyHDT5Cou) z%o*EAl_x%}t|$!rWAG_e@M-5cRc|V%k#R~T3cb`!0Yngn3i>js-^7Gihr~cfTAEQ3 z%0qozRRchBtvJXaghJ4_P{4wv<4fuhObhOq3aFrfuI}&XQ8n|d1QKaV zrIgalZuha}Jzys;XCiAx%&R6AW;-Sm%GMh(LvHMx0>2nJZC$hFKkxVN;)=iRr~xA; zDe)xOTxyd~&2BngENaMw)WBLCn*N2wQ*#H#<|aq>TXAZ#$d?l{+icQV+~UoJ1ZxVC zSvW)lVr>(ei>s`EN1X*v9q`K1aG>M$)J-~htC;!BEh5|BL$IR8YY^2wX-{Z+SJ&)XDu-f;I`ekzt2+l&;UG%2d6-81$`agw zo{%vT0AN)4hX}&|S5&8FYOX@17&Gw|xutxfAjusxH+<0m3KXl;e0XAyJ+Lpsl^S&! ziDqnF{eD*?1SnQQIdJx8S90<{DtJ*g{v7~c?U%~aO7Cp_Yq2<3|8jR8UghQc;Cc3j zm18v!fIgT%Ex@gbnQFN@enYQY<=VCgb4zno%ko*?^i-RCMS*3K>(RVX^YN z7pzQ*j~Tw`?tFdSrA7*Ba{zJ9UY(-FU0Lw_veVBhm?zKc6TvO%^74PqDz`)BS{@=A&4dSpf6`LE?@1pbfBsHzfqipa!^5|AYBm3?4 zn(G?6hD&+9`J(|kdR@Fo=8amyo0aW0A3L1L`gD9RwazEn?RnqJ7ZuRtc*8bZRDfKt zqq2$Xvu*Z)ubrdbvJK%xei74Q@-1>SLbw(W`TW;2nzBcoP#V)mp!ZNsNr0AZmu>lF zEBU7fv4&cDo&M;cR5^OhbEc2Qj%areEY@MxwoE#z?<1bVozZ-ibYSwq6>*sMM}e=l~FE3-`e@Q)Wq$FZD9pg&%Xl#P>|a9)`nO}QvfickpKiR2Ppj@ zhS}88X&BKx4vMrauZbvt9_C&E#(t^2svpiT0D)W<7@)_jh_(%anap8K4TlsAkV~!% z&?AZentZw_0Ko|#>XUyfh`C)`b3Un!@Qr%>@Rh%tsY)B?Jp=Z&U3u`@Hvz~Y-IbVp znwe}IP-Rj8j|0&G0st|D5DurnmT8NT+?0atg@*zT?aG){#{Rrr(cQEWW)S!cNkrj^FcR)af zf!u!X!1)CN#E-y+<_3Tfq*u~Y=c~O{<0AjZMKGe~GlaaW27u{B*kR}A8@lM|sUwIg z0oV~5vN3GUL3Q*v0QOHIKGd2Rc3z>M2Z4rv1rUJ11rXTbKo|!5>9~yd1$__%^w_1` z4b=h%5K=f0asVO#1P~z*)S-H8Vf+4cD73MNu9qy_<1@H=@v{4D8}w^0GT+| zI`PbklI1)&mArbKTyi`-9Qg~X*aQR+F}nBIAid%6-Wc$HdTd%nrgrL35dPYKj9%oZ zLHcR0_*{@TF^Z)=1kEENC!(jT`_8FmsX3``u#|!N(a~P|1G2dC#T=ypDF$}hO zoM+heAINdL3xc5MDJ2skLZ)$HBPj*z@Bl`wxBk&*9+q=a;Sg$^&bbm&{&4oCGT)5v z$ajZjZN=BxtD$7V=^{*i)$>)~j+WZCb?@7Z8?ouQu_wNL|CHFLwe)FK=hm-J&gW=m zJoXv3S@~W3GYfo&Z*mv(o7tXfR$ZU(p4XWm^wOy8^;iDEP*v{Nn2t9a*&D+Te8)0BY%Umci8ZQ*1UaxvitqaQlXUzo?jX$7&@e7V*O$z{|N`E3+&hL+jS5wZNyS5mhsT?MTBd%7% z9Aax5kq(>6Jg63t4MhG5Rs*ZBzvUzlm#}vhEW+=d1ziY53u(-W>n6~5rCVlXD}I}( zBuQ9-B6yD+7yhXlw(IjQw9NqI>g5XyBM*7J)Gnl9Q;6xRcX`^`CYjBv%wKs9o>#$W(Fo6jEtSD`v@NI4iZPi_< z9cJIpc6gcVc3&K2m?+_J6OBC9&Tf_N&e8Tit#M3PbT*XtuD|zoVHpZ&(H3Erv!STA zaVXDu?$|jU*0mUN#v+=aMwUo1wZXB1FoO{?D4f}HT@1nU%NkwPiJQi%mOg}_gg4Z@ zIkB1{AtN_7Y+gRDg?PTNcTm}6V4qal#-@=~XF7l5%4uss2Xpp}*3Feb)=+ z(~OA2rr%Hg_O_At8qQ@pd4>)+>NkuruQ#2Tn7i<_v~&&ROx9^@V%8TM{-gDhCN(C5 zUy6UA6g5vu5gt%C3N4uc*ZHiX>njNpuR{A9GU{Y%IaX6!S5(-Q-o^n=dCQZ5r|7_4 zqL>N0P!Ks3ED+ahEvkqK$sg`&W3}FE6Nx6cSMIRD`(uJKUeEX3uR<(9uVVqhRt{za z=yu;8GF(I{jR_?!Q6J0dUgxp6z5Q*@bRr|O7!hPUj$<>kC{n8WO?y&Mx}+V{oXFpv z#yd+xDgBT4RiaZB!3%t1d(%Z_+jCw<6$UroO^bx}62-t8_1$aq>vsXj+H~ecs9R*V z5U<4#cTSWF$;B87Dgb1z+xKo#44ggTLsCksWElvU1;vZYqeKqn2LKR5=Xsy7k;}}@ z&d&}!0)pqy~3@K8YX*lE$A7y^2j7-Z>5Ahf6j=4bur`tG;{ z?^8ueWE;q&G`kqdNqt7=)WfZ|s~t4oq6SIbl@_;0EC2g0X>kxy#`|9lDhR)F+s6f5dHaVNoGCZp&h`KIh{sv$+cN!XGoUy zBj_7ZWwH0=d2T~FKZ91}u?`>Ca`wlxPt+Xp)qm4`j_G)|s6gH{qZWbOI9*LJBJ0`JHx*jJ7(k;`oE2c=jq>oUKS8O&cy8xlH%w>x-ee$;8S$%`j!gD1t0?e z5PpD>!`WdT*%vp;o}#~ouibzBYvud^L=b&JQd&{)0d~9j`x#(6g3B22#1MUIvs#Zf zLS1(sqDxP{OVS7q(b=Ct1p66!}R(So~Y!--tn_Y%6|ZL ze>bY?`dlumwzsvZJYjNYs2$?NH=QG@L>Eb@XF0Ohb<|(9=oiu+)GkJ_j|W)gI-ORIx-Q<^^^_iXZdFQaM4##L=_c(B{#)U4oDSu%a8n-oYc$`x?aD)!7^P^{Q*T-Z>#r0FVox5%Z1^2D}JkO{eF^o0W zjyksp_LRj%GgBJAu^H`MZJ$@JO*hu5 z-}h@0$tu5T^{U^tTY=d9;&Iu zeTkyPgqDiqkEYGT^Z-!SDe0=!E>jE;o@%4V2PK#ub`)Ao@9St%NH)UomG&mDf8%tL zx}N=eAZ4!4$;3b?^~L1yuAz3-p^;RR!|k!nA}SkR38;>ED~%P4;+0+ZODnHc*xMXO z&zy}{S2U*JeNolS%J~Tr*s(Ym2CY}gU2`nWvXaTJN_Z>E=i?GWsAbT{N9jXjN)W4X zxOiG0g8eJq4Yqpgo}4&lXVFDHA(@`6ohXTiTa6B6Q=qXI8yjc~l{)o|>NJ@v^_O0< zZntmkLmErPhU=Y6>h*On0QxzlS&VramEf2zPXuN+=M>+~%k#dYj&@Jny3L7;?!E&Mw%klS4uT1_yY8|%j{S(Cd56!6ECT<%4 zb+kmM?4N*$mF;Lm#`s*Kv*{CFB^G5CQ-%KeIQd3e-L(%D;mp70A}8;>qu;Q2qUU>e zwpywJ09(s4E@j?aDM}5UV|XclZV`bsjDgzBlg5QOJ0oIjPxWV`*ipXR+CK$his zJ#d`ncKvv<4;Hwsvh|MKZwUv7g3`ZE{?+;H{W+B%HPBKxLGlX|R#*!`*Tku#;gi|2 z=41T)F;bPzcJ*PeY)w(NyTf&C43?=Ll?xu>zT+ttoy|LbZ;um1J~N(@*@Auew&3zO zwyEB=hGz36_Sjib1tlo9!)}PzRYU%0q3FjXouiY;<2?FCsgk!lA>Lm9zS@1AQ|BQ4 zaHILosRcVM^E3{nDkItY*P`_Fqpb6NI*P3=`@R2s2(x)=VLiv)UNp-7dR;Y6t;s23 zqU&DC`t2b8Zu#q)IzhRxq4TZxwUkdr(``JxV+5Kmhgmv3J2T7m9`^ibGABMsvCYCh zyLsPAySt?RNN=#zYLR)dg6`__jO+R0sCbd;c%@=`;mMOOd5UlT)y{)I83_nLyZ3g? zH2v3o+(tch&|wDxwnR32v)fcMcv7?L)OOP7G~Veg$JUm!>(-WhBl)p;D_0N$;FEj1 zBN-aPh%}T%T}9I=o~8~FBx}2FS-`k_Wbf;3zkMRM9G=c2liNNf`|MF|6Z0$3*%OIAk<2l`iph0GJ2D__jJ8JD5D0Zx%C5fQ^jaA37g0K`+62x

W`+0NwJpCYq|gkp3MnG?=k~g0**X^r20} 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 + +# Beta Testing Guide + +Beta testing of development versions is a valuable contribution to the project. You can help to ensure the quality of the production release that will be distributed to the user community. + +--- + +❗ Make sure to always download the newest available development version of the project in order to ensure effective results from your beta testing efforts. + +--- + +Beta testing is done during both the pull request and pre-release phases of development: + +## Testing Pull Requests + +The project's open pull requests are listed here: + +https://github.com/arduino/tooling-project-assets/pulls + +Testing and review is always welcome. + +### Feedback + +Feedback after beta testing a pull request is always valuable, regardless of which categories your findings fall under: + +- working as expected +- problems encountered +- areas for improvement + +Please submit feedback related to the changes made in the pull request as a PR review: + +https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews + +--- + +If you discover problems or areas for improvement that are unrelated to the changes made by the PR (i.e., they also occur when using the [pre-release](#testing-pre-release) version), please submit that feedback as an issue report instead of a review. + +[More information on issue reports](issues.md#issue-report-guide) + +## Testing Pre-Release + +This repository is the central point of maintenance of the reusable assets, from which they continuously propagate to the "downstream" projects". + +See the documentation associated with the specific assets of interest to learn more about their usage. + +### Feedback + +If you discover any problems or areas for improvement please submit an issue report. + +[More information on issue reports](issues.md#issue-report-guide) diff --git a/docs/contributor-guide/issues.md b/docs/contributor-guide/issues.md new file mode 100644 index 00000000..df31d911 --- /dev/null +++ b/docs/contributor-guide/issues.md @@ -0,0 +1,32 @@ + + +# Issue Report Guide + +--- + +❗ Do you need help or have a question about using this project? Support requests should be made to the [Arduino Forum](https://forum.arduino.cc). + +--- + +High quality bug reports and feature requests are valuable contributions to this project. These can be made by submitting an issue report to the project's GitHub repository: + +https://github.com/arduino/tooling-project-assets/issues/new/choose + +## Before Reporting an Issue + +- Give the latest version of the asset from the `main` branch of this repository a test drive to see if your issue was already resolved. +- Search [existing pull requests and issues](https://github.com/arduino/tooling-project-assets/issues?q=) to see if it was already reported.
+ If you have additional information to provide about an existing issue, please comment there instead of creating a duplicate. You can use [GitHub's "Reactions" feature](https://github.blog/2016-03-10-add-reactions-to-pull-requests-issues-and-comments/) if you only want to express support 👍. + +## Qualities of an Excellent Report + +- Concise and descriptive issue title.
+ Vague titles make it difficult to decipher the purpose of the issue when looking through the list of reports, which might result in your issue not being given proper attention. +- Describe the issue and what behavior you were expecting.
+ Include the full and exact text of any relevant error or warning messages you might have encountered. +- Provide a full set of steps necessary to reproduce the issue.
+ Demonstration code or commands should be complete and simplified to the minimum necessary to reproduce the issue. +- Be responsive.
+ We may need you to provide additional information in order to investigate and resolve the issue.
+ Make sure your GitHub account is configured so that you will receive notifications of responses to your issue report. +- If you find a solution to your problem, please comment on your issue report with an explanation of how you were able to fix it, then close the issue. diff --git a/docs/contributor-guide/pull-requests.md b/docs/contributor-guide/pull-requests.md new file mode 100644 index 00000000..c8c7767e --- /dev/null +++ b/docs/contributor-guide/pull-requests.md @@ -0,0 +1,199 @@ + + +# Pull Request Guide + +A [**pull request**](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) (PR) is the mechanism used to propose changes to the content of this project's repository. + +If you are looking for ideas of what to work on, check [the list of open issue reports](https://github.com/arduino/tooling-project-assets/issues). Pull requests addressing any of those bug reports and feature requests are welcome. + +## Contribution Workflow + +Each contribution travels through a formal process which allows it to be efficiently incorporated into the project. + +### 1. Plan + +#### Research + +Start by searching the repository for existing pull requests and issues related to your planned contribution so you can see any related conversations and proposals and avoid duplicate effort: + +https://github.com/arduino/tooling-project-assets/issues?q= + +#### Discussion + +It can sometimes be useful to get feedback from others during the planning process. There are a couple good options for discussing planned development work: + +- Talk with the user community on the [Arduino Forum](https://forum.arduino.cc/). +- Talk with Arduino developers on the [Arduino Developers Mailing List](https://groups.google.com/a/arduino.cc/g/developers). + +### 2. Fork + +Forking a GitHub repository creates a copy of it under your account. You will stage contributions in your fork of this project. + +[More information about forking repositories](https://docs.github.com/get-started/quickstart/fork-a-repo) + +#### Enabling CI in Your Fork + +The repository is configured to run automated [continuous integration](https://wikipedia.org/wiki/Continuous_integration) (CI) checks and tests. It's a good idea to enable CI in your fork so you can make sure your work will pass the checks before you submit a pull request: + +1. Open the homepage of your fork in the browser. +1. Click the "**Actions**" tab. +1. Click the **I understand my workflows, go ahead and enable them** button. +1. Some of the workflows will now need to be activated individually. Perform the following steps for each of the useful workflows listed on the left side of the page that have a "**!**" icon: + 1. Click on the workflow name. + 1. Click the **Enable workflow** button. + +### 3. Clone + +Cloning a repository creates a copy of it on your computer. + +It is possible to make simple changes to your repository using the GitHub web interface without cloning the repository. However, the GitHub web interface is quite limiting so you will likely find the need to work with a clone (using **Git** directly or your choice of [Git client software](https://git-scm.com/downloads/guis)) for any significant development work. + +[More information about cloning repositories](https://git-scm.com/docs/git-clone) + +### 4. Branch + +Create a branch in your fork to contain the changes for your contribution. You must make a separate branch in your fork for each pull request you submit. + +[More information about branches](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-branches) + +### 5. Make a change + +Some things to keep in mind: + +- Make sure your change complies with the project's established style conventions. +- Remember to also update the documentation content in the repository if required by your changes. +- If the project contains a test suite, update or add tests according to your change as appropriate. + +See [the development guide](../development.md#development-guide) for more information. + +### 6. Test + +Test your change carefully to make sure it works correctly and did not break other components of the project. + +As a supplement for general testing, the project is set up with automated checks and tests to facilitate development. + +See [the development guide](../development.md#development-guide) for instructions. + +### 7. Commit + +Once the work on your change is complete, add it to the revision history of the Git repository by making a commit. + +Make sure to follow the [Commit Guidelines](#commit-guidelines). + +[More information about commits](https://git-scm.com/docs/git-commit) + +### 8. Push + +If you're working from a [clone](#3-clone), you will need to push your commit to your fork on GitHub. + +[More information about pushing commits](https://git-scm.com/docs/git-push) + +#### Checking CI Results + +If you have [enabled CI in your repository](#enabling-ci-in-your-fork), GitHub will run the relevant checks automatically every time you push a commit to your fork. + +You can see the results of these checks by doing either of the following: + +- Clicking the status icon (✔️ or ❌) shown to the right of a commit. +- Opening the repository's "**Actions**" tab. + +### 9. Pull request + +A pull request (PR) is a proposal to make a change in a repository. The repository maintainer is able to accept the changes you propose in a pull request by simply clicking a button. + +[More information about pull requests](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) + +#### Scope + +Each pull request should address a single bug fix or enhancement. If you have multiple unrelated fixes or enhancements to contribute, submit them as separate pull requests. + +#### Description + +Pull request title and description should follow [the same guidelines as commit messages](#commit-message). + +If your pull request fixes an issue in the issue tracker, use [a closing keyword](https://docs.github.com/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword) in the body to indicate this. + +In some cases, it might make sense to request feedback on a proposal before it is ready to be merged. You can indicate this by starting the pull request title with **[WIP]** (work in progress). Once the pull request is ready to be merged, edit the title and remove the "[WIP]". + +#### Cross-repository Contributions + +Some proposals may require changes to multiple repositories. Pull requests should be submitted in parallel to each repository. + +Clearly note any dependencies on other PRs in the description so that these can be evaluated by the reviewer and the merges coordinated. + +--- + +Please check whether any changes are required to the related documentation content hosted in the separate dedicated repositories: + +- [**arduino/docs-content**](https://github.com/arduino/docs-content) +- [**arduino/help-center-content**](https://github.com/arduino/help-center-content) + +### 10. Resolve CI failures + +Relevant checks will run automatically once you have submitted the pull request. Once these checks are finished, you can see a summary of the results near the bottom of the pull request page: + +![checks](assets/checks.png) + +Failed checks will be indicated with an ❌. If any checks failed, please fix whatever caused it to fail. Click the "**Details**" link to the right of the check name to open the logs, which provide details about the failure. + +--- + +**ⓘ** In some rare cases, a CI failure may be unrelated to the changes made in your pull request. So if the information in the logs doesn't seem relevant, please comment on the pull request to ask a maintainer to take a look. + +--- + +When you push to the branch of your fork the pull request was submitted from, the commit is automatically added to the pull request. Don't create a new pull request to fix problems; update the existing pull request. + +### 11. Resolve changes requested from reviews + +Interested parties may review your pull request and suggest improvements. + +To act on general review suggestions, you can add commits to the branch you submitted the pull request from, which will automatically be added to the pull request. Don't create a new pull request to act on review suggestions; update the existing pull request. + +Reviewers may suggest specific changes, which can be applied by [clicking the **Commit suggestion** button](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/incorporating-feedback-in-your-pull-request#applying-suggested-changes). + +[More information about pull request reviews](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews) + +### 12. Merge + +One of the repository maintainers can now choose to accept your proposed change. Once the pull request is [merged](https://docs.github.com/pull-requests/collaborating-with-pull-requests/incorporating-changes-from-a-pull-request/merging-a-pull-request), you can delete the branch you created in your fork for the pull request and delete the fork as well if you like. + +Thanks so much for your contribution! + +--- + +It is possible that the maintainers may decide a pull request doesn't align with Arduino's goals for the project and close it rather than merging. A record of the proposed changes will always be available on GitHub for future reference. If you think your modifications will be of use to others, you are welcome to maintain your own fork of the repository. + +--- + +## Commit Guidelines + +The commit history of a repository is an important resource for developers. Repositories may accumulate thousands of commits over the course of decades. Each individual commit contributes either to the commit history being pleasant and efficient to work with, or to it being a confusing mess. For this reason, it's essential for contributors to create clean, high quality commits. + +### Scope + +Commits must be "atomic". This means that the commit completely accomplishes a single task. Each commit should result in fully functional code. Multiple tasks should not be combined in a single commit, but a single task should not be split over multiple commits (e.g., one commit per file modified is not a good practice). + +[More information about atomic commits](https://www.freshconsulting.com/insights/blog/atomic-commits/) + +### Commit Message + +The commit message documents what the change was and why it was done. A little effort now writing a good commit message can save future developers from wasted time and frustration trying to understand the purpose of a poorly documented commit. + +#### Commit Message Title + +- Use the [imperative mood](https://cbea.ms/git-commit/#imperative) in the title.
+ For example: + > Use LED_BUILTIN macro in LED pin definition +- Capitalize the title. +- Do not end the title with punctuation. +- Do not use GitHub's default commit titles (e.g., "Update examples/Foo/Foo.ino"). + +#### Commit Message Body + +- Separate title from the body with a blank line. If you're committing via GitHub or [GitHub Desktop](https://desktop.github.com/) this will be done automatically. +- Wrap body at 120 characters. +- Completely explain the purpose of the commit.
+ Include a rationale for the change, any caveats, side-effects, etc. + +[More information on commit messages](https://cbea.ms/git-commit/) diff --git a/docs/development.md b/docs/development.md new file mode 100644 index 00000000..b0a5ccc7 --- /dev/null +++ b/docs/development.md @@ -0,0 +1,44 @@ + + +# Development Guide + +## Prerequisites + +The following development tools must be available in your local environment: + +- [**Node.js** / **npm**](https://nodejs.org/en/download/) - Node.js dependencies management tool + - + This project uses Node.js 16.x +- [**Python**](https://wiki.python.org/moin/BeginnersGuide/Download) + - + This project uses Python 3.9.x +- [**Poetry**](https://python-poetry.org/docs/#installation) - Python dependencies management tool +- [**Task**](https://taskfile.dev/installation/) - task runner tool + +## Building the Project + +You can build the project by running this command from the root folder of the project: + +```text +task build +``` + +## Running Checks + +Checks and tests are set up to ensure the project content is functional and compliant with the established standards. + +You can run the checks by running this command from the root folder of the project: + +```text +task check +``` + +## Automatic Corrections + +Tools are provided to automatically bring the project into compliance with some of the required checks. + +You can make these automatic fixes by running this command from the root folder of the project: + +```text +task fix +```