From 07ffc7d605cc96557db28a9e35da69bc0719611b Mon Sep 17 00:00:00 2001 From: Adrian Holovaty Date: Wed, 13 Jul 2005 01:25:57 +0000 Subject: [PATCH] Imported fledgeling Django documentation from private SVN repository git-svn-id: http://code.djangoproject.com/svn/django/trunk@2 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- django-docs/build.py | 48 ++ django-docs/db-api.txt | 258 +++++++ django-docs/images/flatfiles_admin.png | Bin 0 -> 42243 bytes django-docs/images/users_changelist.png | Bin 0 -> 59355 bytes django-docs/model-api.txt | 760 +++++++++++++++++++ django-docs/templates.txt | 804 +++++++++++++++++++++ django-docs/writing-apps-guide-outline.txt | 15 + 7 files changed, 1885 insertions(+) create mode 100755 django-docs/build.py create mode 100644 django-docs/db-api.txt create mode 100644 django-docs/images/flatfiles_admin.png create mode 100644 django-docs/images/users_changelist.png create mode 100644 django-docs/model-api.txt create mode 100644 django-docs/templates.txt create mode 100644 django-docs/writing-apps-guide-outline.txt diff --git a/django-docs/build.py b/django-docs/build.py new file mode 100755 index 0000000000..29b5c5add4 --- /dev/null +++ b/django-docs/build.py @@ -0,0 +1,48 @@ +#!/usr/bin/env python + +""" +Script to build the documentation for Django from ReST -> HTML. +""" + +import os +import sys +import glob +import locale +from docutils.core import publish_parts +from docutils.writers import html4css1 + +SETTINGS = { + 'initial_header_level': 2 +} + +locale.setlocale(locale.LC_ALL, '') + +def build(dirs): + writer = html4css1.Writer() + writer.translator_class = DjangoHTMLTranslator + for dir in dirs: + for fname in glob.glob1(dir, "*.txt"): + in_file = os.path.join(dir, fname) + out_file = os.path.join(dir, os.path.splitext(fname)[0] + ".html") + print "+++", in_file + parts = publish_parts( + open(in_file).read(), + source_path=in_file, + destination_path=out_file, + writer=writer, + settings_overrides={ + 'initial_header_level' : 2, + } + ) + open(out_file, 'w').write(parts['html_body']) + +class DjangoHTMLTranslator(html4css1.HTMLTranslator): + """Remove the damn border=1 from the standard HTML writer""" + def visit_table(self, node): + self.body.append(self.starttag(node, 'table', CLASS='docutils')) + +if __name__ == "__main__": + if len(sys.argv) > 1: + build(sys.argv[1:]) + else: + build([os.getcwd()]) diff --git a/django-docs/db-api.txt b/django-docs/db-api.txt new file mode 100644 index 0000000000..aebfd36cfa --- /dev/null +++ b/django-docs/db-api.txt @@ -0,0 +1,258 @@ +====================== +Database API reference +====================== + +XXX INTRO HERE XXX + +Throughout this reference, I'll be referring to the following Poll application:: + + class Poll(meta.Model): + module_name = 'polls' + verbose_name = 'poll' + db_table = 'polls' + fields = ( + meta.SlugField('slug', 'slug', unique_for_month='pub_date'), + meta.CharField('question', 'question', maxlength=255), + meta.DateTimeField('pub_date', 'date published'), + meta.DateTimeField('expire_date', 'expiration date'), + ) + + class Choice(meta.Model): + module_name = 'choices' + verbose_name = 'choice' + db_table = 'poll_choices' + fields = ( + meta.IntegerField('poll_id', 'poll', rel=meta.ManyToOne(Poll, 'poll', 'id', + edit_inline=True, edit_inline_type=meta.TABULAR, num_in_admin=10, + min_num_in_admin=5)), + meta.CharField('choice', 'choice', maxlength=255, core=True), + meta.IntegerField('votes', 'votes', editable=False, default=0), + ) + +Basic lookup functions +====================== + +Each model exposes three basic functions for lookups: ``get_object``, +``get_list``, and ``get_count``. These functions all take the same arguments, +but ``get_object`` assumes that only a single record will be returned (and +raises an exception if that's not true), ``get_count`` simple returns a count of +objects matched by the lookup, and ``get_list`` returns the entire list. + +Field lookups +============= + +Basic field lookups take the form ``field__lookuptype`` (that's a +double-underscore). For example:: + + polls.get_list(pub_date__lte=datetime.datetime.now()) + +translates (roughly) into the following SQL: + + SELECT * FROM polls WHERE pub_date < NOW(); + +The DB API supports the following lookup types: + + ========== ============================================================== + Type Description + ========== ============================================================== + exact Exact match: ``polls.get_object(id__exact=14)`` + iexact Case-insensitive exact match: + ``polls.get_list(slug__iexact="foo")`` matches a slug of ``foo``, + ``FOO``, ``fOo``, etc. + contains Case-sensitive contains test: + ``polls.get_list(question__contains="spam")`` returns all polls + that contain "spam" in the question. + icontains Case-insensitive contains + gt Greater than: ``polls.get_list(id__gt=4)`` + gte Greater than or equal to + lt Less than + lte Less than or equal to + startswith Case-sensitive starts-with: + ``polls.get_list(question_startswith="Would")`` + endswith Case-sensitive ends-with + range Range test: + ``polls.get_list(pub_date__range=(start_date, end_date)`` + returns all polls with a pub_date between ``start_date`` + and ``end_date`` (inclusive). + year For date/datetime fields, exact year match: + ``polls.get_count(pub_date__year=2005)``. + month For date/datetime fields, exact month match. + day For date/datetime fields, exact day match. + isnull True/False; does is IF NULL/IF NOT NULL lookup: + ``polls.get_list(expire_date__isnull=True)``. + ========== ============================================================== + +Multiple lookups are of course allowed, and are translated as "ands":: + + polls.get_list( + pub_date__year=2005, + pub_date__month=1, + question__startswith="Would", + ) + +retrieves all polls published in Jan. 2005 whose question starts with "Would." + +"Or" lookups are also possible:: + + XXX FIXME XXX + +Ordering +======== + +The results are automatically ordered by the ordering tuple given by the +``ordering`` key in the model, but the ordering may be explicitly +provided by the ``order_by`` argument to a lookup:: + + polls.get_list( + pub_date__year=2005, + pub_date__month=1, + order_by=(("pub_date", "DESC"), ("question", "ASC")), + ) + +The result set above will be ordered by ``pub_date`` (descending), then +by ``question`` (ascending). Just like in models, the ``order_by`` clause +is a list of ordering tuples where the first element is the field and the +second is "ASC" or "DESC" to order ascending or descending. You may also +use the tuple ``(None, "RANDOM")`` to order the result set randomly. + +Relationships (joins) +===================== + +Joins may implicitly be performed by following relationships: +``choices.get_list(poll__slug__exact="eggs")`` fetches a list of ``Choice`` +objects where the associated ``Poll`` has a slug of ``eggs``. Multiple levels +of joins are allowed. + +Given an instance of an object, related objects can be looked up directly using +connivence functions, for example, if ``poll`` is a ``Poll`` instance, +``poll.get_choice_list()`` will return a list of all associated choices (astute +readers will note that this is the same as +``choices.get_list(poll_id__exact=poll.id)``, except clearer). + +Each type of relationship creates a set of methods on each object in the +relationship. These created methods go both ways, so objects that are +"related-to" need not explicitly define reverse relationships; that happens +automatically. + +One-to-one relations +-------------------- + +Each object in a one-to-one relationship will have a ``get_relatedobject()`` +method. For example:: + + class Place(meta.Model): + ... + fields = ( + ... + ) + + class Restaurant(meta.Model): + ... + fields = ( + meta.IntegerField('id', 'ID', primary_key=True, + rel=meta.OneToOne(places.Place, 'place', 'id')), + ... + ) + +In the above example, each ``Place`` will have a ``get_restaurant()`` method, +and each ``Restaurant`` will have a ``get_place()`` method. + +Many-to-one relations +--------------------- + +In each many-to-one relationship the related object will have a +``get_relatedobject()`` method, and the related-to object will have +``get_relatedobject()``, ``get_relatedobject_list()``, and +``get_relatedobject_count()`` methods (the same as the module-level +``get_object()``, ``get_list()``, and ``get_count()`` methods). + +Thus, for the ``Poll`` example at the top, ``Choice`` objects will have a +``get_poll()`` method, and ``Poll`` objects will have ``get_choice()``, +``get_choice_list()``, and ``get_choice_count()`` functions. + +Many-to-many relations +---------------------- + +Many-to-many relations result in the same set of methods as `Many-to-one relations`_, +except that the ``get_relatedobjects()`` function on the related object will +return a list of instances instead of a single instance. So, if the relationship +between ``Poll`` and ``Choice`` was many-to-many, ``choice.get_polls()`` would +return a list. + +Relationships across applications +--------------------------------- + +If a relation spans applications -- if ``Place`` was had a ManyToOne relation to +a ``geo.City`` object, for example -- the name of the other application will be +added to the method, i.e. ``place.get_geo_city()`` and +``city.get_places_place_list()``. + +Selecting related objects +------------------------- + +Relations are the bread and butter of databases, so there's an option to "follow" +all relationships and pre-fill them in a simple cache so that later calls to +objects with a one-to-many relationship don't have to hit the database. If you pass +``select_related=True`` to a lookup, this pre-caching of relationships will be performed. +This results in (sometimes much) larger queries, but it means that later use of +relationships is much faster. + +For example, using the Poll and Choice models from above, if you do the following:: + + c = choices.get_object(id__exact=5, select_related=True) + +Then subsequent calls to ``c.get_poll()`` won't hit the database. + +Limiting selected rows +====================== + +The ``limit``, ``offset``, and ``distinct`` keywords can be used to control +which rows are returned. Both ``limit`` and ``offset`` should be integers which +will be directly passed to the SQL ``LIMIT``/``OFFSET`` commands. + +If ``distinct`` is True, only distinct rows will be returned (this is equivalent +to a ``SELECT DISTINCT`` SQL clause). + +Other lookup options +==================== + +There are a few other ways of more directly controlling the generated SQL +for the lookup. Note that by definition these extra lookups may not be +portable to different database engines (since you're explicitly writing +SQL code) and should be avoided where ever possible.: + +``params`` +---------- + +All the extra-SQL params described below may use standard Python string +formatting codes to indicate parameters that the database engine will +automatically quote. The ``params`` argument can contain any extra +parameters to be substituted. + +``select`` +---------- + +The ``select`` keyword allows you to select extra fields. This should be a +dict mapping field names to a SQL clause to use for that field. For example:: + + polls.get_list( + select={ + 'choice_count' : 'SELECT COUNT(*) FROM choices WHERE poll_id = polls.id' + } + ) + +Each of the resulting ``Poll`` objects will have an extra ``choice_count`` with +a count of associated ``Choice`` objects. Note that the parenthesis required by +most database engines around sub-selects are not required in Django's ``select`` +clauses. + +``where`` / ``tables`` +---------------------- + +If you need to explicitly pass extra ``WHERE`` clauses -- perhaps to perform +non-explicit joins -- use the ``where`` keyword.. If you need to +join other tables into your query, you can pass their names to ``tables``. + +Creating new objects +==================== + diff --git a/django-docs/images/flatfiles_admin.png b/django-docs/images/flatfiles_admin.png new file mode 100644 index 0000000000000000000000000000000000000000..391a629348e22c2ef6d966bf65e909bfaabf5372 GIT binary patch literal 42243 zcmeFZWmKHa(>{0;T!T9Vg1fsza0?E>A-KD12rj{$;4-)ecL)$H$OLzHci74Eyzl$_ z@Bi%Xm;JII_CAL*(>>7DU0qdObzMC~d{mM~MIuB300321=7TB#yb%Tfs1SrVke-(P z4mZdPqN9wC3jiQv{r!OgGP3Xi07=4mkTG)o5xY%RCh!TnP2Y!n@KlV#Oc;v|Ax=(@4T>I_L*h?c=c(>v*yM6+`8v!LnhC_ub5T#6< z6l3knQ2*fi7PDv&5~U-6j!^%Z+~t`93b^wZ6l8ec4c`esc}^oE0Nsk2-K@l6uWt{; z)AgVNL!i1{<9X!~0#qJ&FN`epgn)H0+U-0SndaZMVGKgJ2NE+sDt@qcJLJ{#q0%C~C(oUT8 zQ#11G6Up@Zep!_zV*#1rTSsD8hG-dJUPgce@q0&1*!$Lp!cvve*M5NIx&-~<2$A1ImCN9sj} z5CGsqZV-Kq7|~S^K4Ui=aS!ZL5Au@{cZfJ;f3G;YIMU}pVrL_|iePct(6Jg4dLxz@ zQ4-E>70b{>M>OVMjUQ-2j&C1~5psHH+k+5c#C{@R8Iv!BLzzTsQ^X?RrGLF6?~#GQ zjG`nP4#!q`FCWh(!=@UkPNpG4av|jWhA&J{sx@BVC%_*36xuG$mK0Q{A~b{2DA7{N zLl`2Jk39L=l`SIB-m+MzP*vHEmZ%F`CIC@ zy(+~%V_7Dr3?W70@WN-CI(WV$Mlyzh_=Wtbdj=6M4bxn)HY~UN37)t zw$Zmax8cmv*u^voGE|pK^VBi8;y#I2<~6BStAv$eak^#jjeWtDl`pEyPo5^U#IwA$ zs@`*L#aK=zRZ5-I`aQZYy_dQNedU3I8jAB}DBOaUAQK-R--5sczdB8!m|!}JU`U;n zhwU(JH~nq8gN8PJ6TL4^{0LIATrzbs5j~4~8K@Yv0z%ff)EHHdD>G2@tCG^-P}?j+ zoJlFy0A+tXR3lQeC=)0R16hpVxm>GUb|DN7WpEPle9$%fy(muBsk52su1QdqGevRdi&82f?3bBFNcQbc0!I`VgMxQ)C zF*cPp{ViWn)9aN zrm|*&n(aSui&af_O@77}CU_Rj166$|i5-c4t$s1jLhz_z^JwKHpGf>&8l18DHThRE z#O8qM3BEHv)Zgy z_$x~&2U#@kQm~k^#A{W8YnqEZK)1%Hc)~Zr&fhnMHwAfC*jIE6fAMrT|7;#r?sLd7 z{JJU;K=Jzd)%$e{C<&y3vVe{V5)0CO^LXd&OWqYL!oO&CQ#XGs7MK5(+SiZ%dvlZU#yiGQef}skU&Fp?g^I*FhHDc}v88f(Of5;c ztbTa-kn&+A(}GQzubN4Yi(VMSY%RFJ)5_T@GRSPM^J`W+TU*vvo|uoBzKYx4wsZCA z_%duGdjomX2QQ7~r@o_C-gxiT*Am<^W=ux@6j6n6CElbnF?9M;+-Rx`EDx$!B(GkQ zUW@lEQ`}SGetuXsq_cCA~)yzVg3_omB|E&U6hY6`kym(Lj6D^n? zzRto-%e-qWVuUZHJcnWI_*ebN;y0eG)9)zJ+B+Q;)_iq>PF{;h zn>erxp_*_NfZN9&=!jz+nmI6xM zNky|qonL4`UDa$jzP^!MWJw*PU2OZ(B+*jPCHSM=tYmn6Oh81vQ2k2%L7n^L_j02# z_|AUngvh7;hVy84QMdi}S$Mc}Q3Fatan^j+>{0fy{#K+a0Q8IQUqx~qXt-HkQ^8 zt&D1ZL%Rdl1HqTXY2~4|thS7*7CoDm6Yq{jAM@LNq8y&_<*N>_bKKXt*&IHh<&H~l zhueYM>s8!ke`lKK@zJ(<51Nz8cI9@%E74=Id5Pt)SrOfrr9Y=j0oL6fxtCK*(zkG5 zzf8QuU&pl-*7s2*5z;0zl~Gj$0Bb#7_pgxG zeE@J{1%Lx10N_sp06d2T!vQG($RL&dAg1oQaJ1}ZM4~YVoVg6;>}(G#>o0J+@z7%5 z!s2S%Itix?xH;+I;?kkPMz%@NH564@Wfsd4dISu+5Ou7+t5!sYWMfbX&i=2CGMChe zj|Mxx_*{0;@{)RkXd`>;7|B1VV22uGOA?@b)nIRstY z^7DrH>lCNrG$%0{q)CC*$BNSTMCQiD!xP3I!po099wJ339=>|YLQjumRxMN(rJ9kP zJm5r(1{oy}qqM0>bGqTG!0vl#y>x-X^`F6}@>2hz=TY!eaxys1FDv z6nnr~lXr+z`!i9fkG-tDrKOCr@(@8NFhiogU>8*EKhGc^g8q@#5e8u8{q;t!OcMRK z>DLO&M1$@dXmJXC$YXA9POJQ!uP4c+k%FUyjxSzXEQ2(Qm<6J(qa3Ekx$-8NfC?<8 zuTy{(67ile(vW-9bJlk-l6GUV#Qe$53NS*m!-l@3KtT~mY32go`uK8_Okuykc^M0S zCoCA+d?OyF+gD?DIE1JFIRC{#NPuZt^>#L@xl`b5Cn2Eyc828jIhUPJAu%}|`JJBY z_{^4ugP{AZTH{2OXDzQugQf#Eeq8B-A5?kzL>yu>zE>30(z+u6g$ep70rfF3FSy5n zv}!H&=_882jwk}JpYw7c?;5h_8*jNnU@Yo%U5Y(_f}jGQ-h z#^Y0iDj~4Pc??pbQQYINa#0h4mP#*~i(z(`%l_6_rwpINTc8}oJO zY$I@C$;}+4FHQv6p9do`N)G3 zpfYPVoaQpr^)C8!@oF^;?^;U1>!dS^V2vG_MtL|6POTpnyyB`(e!C26Eo?t`*;Te* zX}D=S)v8*V%RSc=nuu+BG^;Vbvp5$)l?a&(cc0`yfg-b*)0r6OmoG?~e;i31Z`-B> z02x~SyDJ-HC?NOl>wU?|D=1NVbnOnKTDu*HAR33@Sq>xC+@qwIJoUurBhH9v?GW0W4|Jy6T+V5(TJqZ>X3}GMNbUPxO=w=C9rXuYF!432ks&y zThRjPBlu4axgQCnq`ONew=thFZO}{+qu%+3NCioxL*&cq8?n_!s63>I=C%(pU9o*o z(TJr2P~gH;a-Av)K^0{EQV1Bhq>En>VyZ&Pi>uxlA;@xGa4!73^zCMWE>g!rv;jcR zgF*hM6a2o=x#}b;P;BXUM~=dC-RqDrD5ceh{*KEF$j^t<7-Sj#ph4S*IRgAlGIHdF z4N+x1gr$II^gqBLM76fDsjsU;+fYdi;O38=bwaPg0z!J28Q{Y71JMa9Awf;|D{&M}F2$T|CB`eSU3et1lYf z5xg@bv-D`iIp!fCria(d=@#{n*DwXYy}{wU4Xj)xL3xf_oZGyDxqY?hYAb1~)p+(> z9SLk}F3!9DHg~O>d1(F6-b3Cgk32Iw_XxB%tq3;=2ZPXk+aL|ukW`IvyHoB!oKUZ#7) z%Ubx6RduNY;Y(&mS(mfNwz3)i_vV7uvh#16qmvoB)@_183sI9R& zbCN{H$HupJ;0)*Hf;)b$m7;NT)21KP@Dx#G1(!4HgaTv7bjW?Ap3f1R#@6KG@ijG$ zZd?hWgJg=XrCa(HH2u$8_u-YnvGRkS$Azq{Q z7XxBT!$zmJ_aCCav(I;@_g*E13zg5!DrfMFF4t66v@$T;{0d>)_i5f-?KJk2?#j~V zryIy`a-)-kl@$Qnhi9{Yu~|}CS;*5-8!8-{OLj<%X4|Auh~};ZCe_+ZmoJzq(fHdq z%k7_U?U=b*9GCio)$4W@#tP>TwfvhEj5p#0O>8H|$F^hi=eC~mQ6%)s1^rCyb4@*3 zhE(whXcsk^2&T=)nAlFAu@OG7USti;{V=mh{w$LzP~AWMv9_@;sGeFOO_1x8qwSNw zVw^IrWGs{sCkDdwqDog=>ns6Ee<7~&yHsO`#ZGr=fsahwroXQewkF*l1>7ALHB0t- zi+`m%xN}xG?5XNK`|6!M4G%Q!km%BXTFMc1weDRjy_r4L>++R|lF0mKJ+H5|i!oM2 zC41aB%gvK0Fjc2ww1!LTI7FVU<)*5uPbE;WU zWq(~#JansNr{8QGr9U+!bzquMSFFU~>~?Z;e!mQz&E#*aXKXz^H&RpB?uc)Bgx1=| zulI7cujcZ}UGvJD(uhFAywP z4hzfqA_|iNRkXwX`{$-X(8`KiW~Qp#&aZ4f*~7AVRr^f${;4VFi6#(#+{Dy+Xx0X! zt_u!ooI-RY3oTRv{)DvW>p>&0IlMDc zRB2~sr(j@U*bl28!I>N?8AOb!e2y7giEiM1KgutEG*hPb%UW5&0uMt0WNFx8T|!s+ z(V}{}ra*{-s>lm`6B;C>5xj9yVeP!Dn4bQfn8N$WPsko{M7{F<;OORd<)ffBSOT_R z?e8x-@U7gw9?R2`q^21fEJ;n;YD%p-Bt$3N1W0tpY}!{J8u}O?e>2S(rPDsB}S(OM6o_8B{mX=`xK5>1x)p1CfR+ z$bM(94EZCl!2h6I-sFXP?_!a3CP)r6jVon>H(lJpi@~Omb;L}H+!Nh9bvs%6E=Zeq z_H7=HX$tGZo5czUYTnihLUrJ|S+faRx~s+}_XdxYQ(IXA5f9%`oEg7lwa==~w!WXv z)86zf&(3c%GLod?lW>{$7G_x%x3tV2;w|d7z5y6VYbxfZr;pCyeaCYiR=U$RY_)W4 zEIc-wii657Eru@ZmN!W&<~|YGz>|3&{L+D&q|`v7&!7@^JD9;7(_B4yqw97ZXq_(X zC+^Ez4r?}!uc`fQMs0ehna5#a?ps#YioUMO^s<`18eXD+y{{7c%AXiWvNDud6v#(! zy^(}SrxMKko`EJ~S!X^$pH&GcYOD3~@FOyIWt31)W+KfbazKnzh*6$ULgsO*qom7X zYw@)8H8IfUBtd}V6A$009~SGf5XDQ!&f`g|U}K9neoXDj>zoiRVG(9P6WzD5U(s*g zmHvrI_fuY8Nlr0p?U<<%gdR^|r6j8iTg~zlJ;ylcBgv3sbkJ-)eFp}GuqsZ0k>d-x$Umn}(v*c#2tKhsSyYX*W9l!@7oqm>tSFCAwNq?k-IBY(EN2aD)}&;90{@%O1R?X|bdMQCAaJ zG5649GrnP)Lr7FSQb*kDO{~Le$w19~yf#MEtY0QTxXaS>6c@i+YfufvbIqqk3zaHfG0!#^ zQtD{GYU;`f7Il%giK3Cge}gTfE$(FR96eun3Fq@Bm`i}_Ju|c1{HZvV#iUa(I_@AA z;PU%VmS@3+8`n|Av6~ki4S?Qj)BWb7To8sQbRW88=u>SA9U>x}!KJ`s1T)*5ZA4vv zf*;=VpXjC9;AWS;6m}8x>|C1M`Aou32aC|68alFsYPLmwqgoCm2=tf}(#5z`G*XUP zYfg`!WeLxI^qM5*E2u!+t8E1AP<=S(2y1#Jz>UJ@_N+eiv7mbom73&j)k>>*brr7w zD6e%1&(U^4gCsTHY$q5>Rx^STmNQ1Rixxz0Syy4DzQz?-&NI1+dG$@EgG`nkwjh2} zQN?PySaBqr{eIaX^>irJT)m~5#z+PY9$|s|Xz7w7IH9n1L-hNo#p$sdTqRvuwC(A& zsD(U_8DB^7)y*FP{=>`%$bE|@vi_Gc)|69={zx4a?J1t|!eZ@q!}8=dDkjCa;&KJEgAvB0bgy!XIye1KlN3Bt{K0`uiXbe3UF^ zdbf)$S)JOs4pVp#_EkA$7TDv;ee{I6Sr_L=2SIpn=|=)lXoMRN+cNtYrJtO#CZg(U z&eKFZ4yt{aSSA#G(OGotP6tO;^G;u2*^;SbY4&>iVAMWu%(T=yQ$R0rYi8spzDJE- zWg)umpPJjaHy^FJY61fZ|%(tNM zlu&9NiG*aC!AK`)quz0n17+djQeS)w_E(Fbj}XI9S5y&$3!Kw$TQHLl*Gt;CEX$xC z1%V*D{V_N4JqJKo5S}1McP-Cu5mRVlp>HFRSebqC(9xA;&MG~T!6RV@vT})3SHq4g z@UhWbMx{)pqN~U*(2Q4OR{9f6HXr@S&tZQiX1*MlrPiO6V{?Bd7a)g)GJyac!`ueq zgQ+UJv)V6I9GvUQ%AJr84$As*{R6svH?I-TjRLLLR~Ygf^$^9%MC_(~e6Qy7CM zJE1#Gop%*%RA2ctvpp8)?3V3~e?RTBnOi!P9_?vRY!*!aR(&7s>fz?{K|Q+7ubEga zi?DJNB?W<8yVlOfCQhK%(xh;%zS6cNGbWqUKROo9Y%T-6LjAxA4ZzHET5IFe*rQBf#DN5_1l%+|Sh;6kxdUnN~qWl-oHjzfUjp(q(0IrG)4 zy$>rlpD;NG108dY+81`bY~lg82Dgvsg=7(tF-9<>TM=FzsMo&MDpK0HbtYPw`q9xb zJcuYj>B{&u(a4dQzP*!*b97l(ZSl%ZRD%?CQHje76gfXP^)F03vy-aoDm!b6lv2wm zL?Dpsqn3|^LvBqW?WA@~eH9nAhpp2?j=rh}A1&K(M6Fmeg&b!cfL$K2zRI1s~i}?Xb@Nu(2YJz`-XUPn%EJG>uIj!3Hes zt-~E-};5xxG1_70Xwa8IuWLend3B>R+6n*{u&D;+6QI z8a>cmF0@P{{8d#lIy~n0sDgq?#g^KJ+J>)^#|QOxr9@GLxEM}Yp`g1gHpEa-`8WaR!AK6yaDObcFbZ~d z_M{R=t{B5Fq-Vwi0-g8bBj4Gmgf4QMW}E!N5;8Ig>>j8@HY^S$%Rsi$S7~%kq3f?- zCBdSm5*`mBCKR3bT}N1|T`uKnzlr^BN_)?-*f(BtJI>UTX2Y#>!6!_#*~!W1p$;g7 zF$V_+>>L~tUPx--GvpuH>hH|4(N31s)M)z>*0mMltO;3vIn>d=D-z`zsrj+B%CdcQ z=g;lo648u z&$f50p)JBEHV?|DB_7gupEvXTAZn@3d&V>@B8l3tG$2;-OP-7?51`K>hi#t6ER$v zVs~A|=yu(_ttYRjWy7B?V_w$-6BIhI(3OMY5KG5xhS^Pj8)+w1q%{&sh(J*(zQl3l z0N%^yaQoL(;k)kv+6Yr&wSsTa_Y5Ca;JNJmPkOQBT`0Kyo{L!Ak1(+6rKa$4u>U@1 zf^qLs`!vYVORKAgoJ1`-xlz&$&z8kaKAAiF%K83~MQ0?~r;8x4`lNg;AJu8ybPvyO zC#K>wzwn^PZj3PH$-L+JJVo?Q=hM37lIQ$&oMw|im)}PGgl1Jqfps*tWDgF>TZfF| zGEn4Z;H0HfI0uS`R3gqt@mC2k4a)a>)DwoR!oA)*$*;7vNJy+%DmBfsmCxoH*2d?5 z@)hhhOLPy8UwvOQ+n9xtqZh7X(Z%=PdN`u?J;&~JJBi-*BW=UPu%bXoBEm!v(`y7? zK+NX-^;Oeb${oF%(>8OQ!4RE3r%A~6qiRVyp=+cbUHf#H(7Kg@4$dDq6`_qj4>a#T zHu{OF{Qg`*fliv5pph^?wLX!iosmjR^RN`fEOZ%!*F~(4+SgNu4Y6Dq$8glXem1pY z1!5Wq=fcKr+Jk{b;nq!wljVM0bOTZ}JU$wxP2=_Ou41FVe?9SjDz&|@EWzuz?{TiC z)Jfdv{bl@*E4co=allXbh-vdL(-4-^y^>LvpPye-!|G~-$Ip20+u7RM`un#kF;a-s zSIFC6zkYqp>7C_7LxCWq(d*5+8B zTref4j@^k+;50M{LZJY~X;xm_Hz{U9q;Zt8cPi4B4ZQuj39o|qp|UbElbnj!k{TL1 zDX;(vT1nt0uegl3_#6KP48oXfOa*;-(%h>nS7LaGbMyUgzW(3MzcYjQ9R#lZ8v)P+ z`#w%{`ZBZrC2+!x)1X%qh!J2Mw>|&zKOAngj6Q+735wKM#eexB3N=gFAfa@WFldOD ze}-}V8#Q?UD_k^FQv4mU=D!^J-}UZHl6s5#3H$iy#;q7}hv`rh^uFCJl%{*$N>qjz z9{m3MkV(gQGd^bKlW>Yy-iFk7PihHPxld8M)h(x{@}I0LbWRRqJnt$?qA2dk4T?N% zJZ1+A@uZ~iL!S^0w02M2YfD+DdEcn!7h4e!5SR`|_iRf-0?H3-Y87l7Yil$wWccT# zt&}?D>K`Zjhyfk1O^3?JG|-A}9TDa$4mM9)&&sV-n==JUX*x+8$5pzWwOq}#_I-7Y z7+z}10^Z`+BVd-+o3g9|=GM!VOy{pJEUUiFgJTmyJB1Oj=R#b%+%xd?n*&_Bg!1Mj z95%LBna!(rtH;p0299H9B{8cHV;M91$V28KuR$7kMc59LQV4nLLJcn&n+HAID2>Mq zT?b>lJ0J!nWt3eg%s~YObRP!NA3Jr5M>PC^UzU-bQfSj|Iy0UCzLsn$v<6m z6uUaL6LfT(Yqc$Q`VO5giwqjYeCHe6JTo1QTdOav8qG^j21-&@dlla06|cubEFSRs z-uW$X4{-dMt3G?3UK6;_L1oAQK3w%1$Oa%dL)Zd>F3adhvQR&g-i7SdfRDKTm&UQCz-)-9c{(5?BaZmEhi05}iH+@%luBGQ?y#7Zvj_GxWW%}afPcN=K#IOie z(A-1Gv2qelK=TW8^Fnu2d~4VE?|ZeOJm(6*!!Lk}pQ@*dtWvR9BBvZDATApJEcUHb ziZjC7PG5=qKJs-*pp8uGqOC8H40R2Fcb*tdTp0kH@zp{t_=COHG;{zteiJ(qs%jCY#M4UxAQl>$c7x)dPR- z!8kpJR(Bc9f>r&WouvJK6rIG8Q2cee$?&>>|25g3`_6B0$W&Ipqi}3vQ(DScT~_8X zdDoQ{aMR#ayQo>c)ZXTCK=9grQ!$?bp0d%hAm*Y7M*QPFAd4I)qpWBI_ZF=8p?s8J?P^$!i6CP`i5DaA_cu~ zIPY%YHTB)wgt)nJMHnCvOHW;+ao+a){56KmB>@m+=s}A9_O9C$&=s#2_<_mq;g-mCd)r|yS6Oxs1<{R}nBK#vJ9`1j{e@<&fLn;5qGHZ-^Vg8XI^W}devqJ)H zs0L)f7}`Iq#BcsxEkr8%ze^%0u7d6ZLC9_?Y+HP^zhoIX=kNcBK~Vz-8P7tJpnujL z_&3WUwEB;j(7&oV_#2M@qYlph5kuJr(TX;NRi6z1k0uEJM@)h-L?IQekO25s3;#7A zREUcI74!cu`#;<8|KZ&ZCW8>NyZ>7GTD;dkp74LQ=lUrof6rd2h5r}7lL5)wiP46j z)KW*cK~+`7Ng&V&B)jcW27t(XBi01y6f;C}d?Uvis6N&pQKKJ(p%C8)G)|LEq^65x zPa77O2<@4GM|kd4lXx<{pN12hcq`wBt_D`tEDk1H<0XTfF1Gj^jepaJ0$}{#0%HxO z&rmYq18gZHES2Ijg_0oWJPQNT&xF^>Di*rB(o&?(IE1_@SPOi#v0dx=hN@57yb_*E zA!Ss9e(4gG%bf=D>BMt7>#;1vsn)OnP+3q#Z5chP6st;{oqTM+ak76A9^74CC)1ly zU(jNZ%ISW=OVKUrb6;iPK601eM6%d-K|`7GbFE3=Zwysv<45hi2oIZx5zAsLLyIM- z(pvt*{x6i#p3W~p5678bL)di6RPLB5LZmPtel~V^4nVv-{Ux%cQ3il>M zO0v3-#j0*}9q+dC$CQQ5v0E!3dVS61dPB97GM;5{RPP~aj-yDb)$g;|bWCfrp9tg{ zA3h9@L#b%C>1Hf%yq%zn-YKPJfL`-Jb-lfUr*dO8^oD!z_I{+o2~;ha#!Hg?K255Q z4~)&Of~QXt)af6dF=0OjcLt&W{)U0p){~~ECj=ikkpQvklCJ8KHt;UuT8QZ1GL8c! zY_P^V)?zDg^>fpWx`PYh=3rqOcg1oJhf}di^(FfUvxp{#GlYo?{pXHKeJR6ceF`a; z!r5*_xWoZW5-fWY=&UKr$!m`Wu@Bl|qxi}FZ;INLj1caP%fR57st^0^tJPJkQdBrN zcvK%Up#XIcH;u+2GjP7kZj9^(OioP*o@dUN&eqCIYg^)i zSeIaj((%#oatCW{s<8|ecBaHf|84$}y$9RQepTO93`ltjVP~nz&~y*&cQU^o;gAjJYU7Xln?*Rj`q@bR#-E1(iu z6#tw~MW#k3@?)pa%7lz;SS(K3oIMKpc8dvEs~EtNQ#FZ3Ym-*Rjs=j3X;I?6>D@hc zCJa1}o_>p3Ae+v#@n`VcVtV=<5-pgdyo`e5eOwj)qLX23Z;z&N`_Ezm^p*nYa=ONA$A%Y z2>=z-<(+GA&1R(G7Q6Y^=Ls-z$R>stTP2wxJbpO{1CT}g66E8ua~l2TQx^%nB@8_p zQ>(RgnK`_LMlpM7kt{(-j8Hln>L%-m2!c?UDc?41mL|nEke$bDz|E2a18f zn=JYDBvUCb9E1z13529o*ns6n6i^-|d4$;9x3rv`1VijT#K=;%kb=7UV&BoGO5H<& zET0KFfY#IYID0%7eK2AnN8VVjd-uYsN3{FosE!XhiJpE6o3E4rOBKsiceKe~Pm3xXp;3e|-7&mdgfY-i6gal_-rCn@cZWeV+c$MZutetkEb9=C{1#0(ofgcu;Md8{~} zTB*X#6ev|ih*FY`;DQd^^WcZ3%zDe+?50ZoobZL<1rA);9b`- z#C*OB^ADq}JcOnM_Li8Lhi39h8?u;2vtFuJ3*nQzqd>3hsxRu>VGpA*Gyibo&bfG$ zu<}_}AsUQf=o3Ij$0inL!2&U;+@>aO2rHRX!urpRI#_xJhRcf!@p7^aI-b9X4)9-y z&VN^V|JD3I7h{kk?|-fR{vSU?drJEJeWC<>2r*kw9V4VxFbaf%!#85Zd=qNS8%t!1 zeolkcV1I4|JyVj zWTha<(SIXO^#Oh8CD^2CW9C?rPONgw2N7~*^A#CIuM z-$&gNY^Ectc{Dsq#h;c;l{4@SUb_VZ%-;o!SD^G6^ND5@R~mFISU0N5A(H3y^sc4C zgrI9^=rgC1A>`?@dFH&00a40k6lZ&GMBL$pqw~Z3a}VnPboa7desb@V&gE=SJ>J0!Yqo*PsMbY$#%twzkmDWAZxB8@{q$Deg=&y+u zL@7%`LbATT?%iQfGL5>zC_`6STH1XshCq_>CEK`kHr4L<>mM)ViT2x0pK&2>@aCnb zEgA=r@9X+&=k>)jkD=f3LaTwru?P71xxE07^!bm#DhTLo8f!MZyyX}dJZ{g#jRMM7 z9w+wkL@X1fb^QqUydRg}l6-k(areEL@^}{BM(3VYZ!(@=kOFFb!OZ7t1_!SXU)~(xlAd0o&o}$~ z;dWa29?Ws-aTgfxt#w4};9R2?myMtE&A*pm7e`va{^3!vDx~0~?W8cyz{lQ=#@6dN zetWxeclBbDX_qt)Iyp{GF;3>UjjK8eIyq&-Uij9D_xXM5tr>meWs5ZUmLHAWZE9H; z+!khsV57LR2ZrANacU4X6JF{9sAD9u#u=#-{BiVWtrSvAk@M~m zgr48mfA`zo&K&>wy0_nU5^ya+V}rtRz?H1X^pky%a%&=u0K>8rDdYG$Q{=gdaji(P zEn|?_Pm`CS>t$whlz~V;Dcfl)Jx{0A;$viL1L(EA`Wz2mPP~F2nz}n< zF1&FO0$FKJ5j>U$n}zkupehX8xB4dN0l`(K$JS!4g`0sW>0jS(18zlDkwtw#!uK25 zuS)^*%Lr=p+0`0`oyz{?Iur`mrIDwZ>G{d9*|)LQY_ZB=^|9S;C?WIv%KhYJwZgft(>Td@iQMb> zHU~GUY}dJXtIk|YR+yaj+wmB=!H&23_$A)4+eYgHr`%xD5ZB-3Y$2a)xpYye#P`1AL~I!%weA~1mm#-BVzy>I z?+*|Qc-MZ~6CiZ==l948lY_A1Dg_Hyi#{E!B-X{)DzpFD-Zbe!s?-pG+SC-Bkdni7 zofj3C;jyHHtX|nib1BHcmr2-sNuwab!{lPq;oH^L;y!(Y?5HLY)rH5*N-kakYkBc`4o?rUG}3MTIsE?cb7cG zRQzR4crWd;?Vg;5QVY!tyk}-|nnt|aoVO4y44r;2In^uWq&b~W)yL%|^+aCrbghN_ zy_s4g@F$d9WdF`(LfG8bdn&2T!0S3=dS`%A$^RkVXZJHv(5UZTdWn7O!whZW{oWy| z*U7rTt|EPUz_0T}R4(OE~MjrF8NVs1hl&OE=j# zcET2qO*kLqCS5>yO*ngODDb#U(k_mVl&U;O)cJ?U9Je}@G4Bjg!+$pjhl zLKw$@i~ak=+flO!mtv~W-kFX4vH_n?LHmU#r|BDi<*WY9X&SW7_uTcY+%B9kDy70} zF!JtoC-aLFb`|?S_FlB6`|j_`F!I?BVju0>wlWq6v4uFj*3IzrSSj>|omSj$Z4B>d zu!~>6@2rl(`{I`|Jb)fiiHXW~dA&g%X}Z=MMur}yoW^1|fgx15~Vi9fV;(h-KfMnlHhFlRSCST)udSuU<9?+56bLyj z#s2%d1;$nUjyi`=(%h;+sTWLi)$2 ztJrTCe9=C)gpkZE&sd<)=-@#Xo-2=xx^k=4Ce*;2!f&HJlVpAawWdHg}FxaCO)RRd4%oZ$#4ql{IEN%4Joij_q(YSS80ZGOECRx9#Z}HF0WqWHm8bcwmuJ+FUWD<-ubU9M)cpgo>#Zue+Tj8wB1&s*49(6 zI{Rj50EwiUUDr?04wbRBlP5}qL`}Csv&3(gyk}FKEj$mdqJKY)#2I!T&L*o+cYS0% z?QFBR_rD$-;)YSXs$xRP8XXB~d>zVu92ud~3!5lc&gS0^8D;KTzc7sy_PvQWGP#*?(mD0N)Mztw`mtEm zbvi7MtKi`=|Do9Nd^D>1G0JSS%3ptdY4o(^GM{g%@*0O(gzDgh<4qY{F8aq{XvL}; z3JW5wTiZ`MDs4s97KYa&#{#R-=?TwA@(vT7#>0>Ax;XIY4PM+!hUT#iIrl3ARzKk@ zm32pv2&{g(*`|8iem%GGSUeu#;eD(3c(8nNB7N9WqUHBIcj)mM#=Y}uSQ<~{YOw8H z7p{Kec48bo2}qYgaDRT_^w;&V0^eik#HwG#`6HUyk1(e*b)&OFL=pXef^g5wwTl}x zfIhMpjwVXk%0`o=jsyas2NmVgCJdef`Pk91inRRar{K=>r7!DZ%Ia4QbocAP%)|!; zrfeIy*mX>`fQHg~c-(5c~8er0U?LW1tg=wzDybXn|s8UA#D472f5m$(|pM{;U z6o^D2lTYYQqY#HpBTl00BUAt$&Pr zo^^+X&rhSxR7vRMbFsb0YT?&-bid=?ja2*g`_9EG&oX_Fli&#TL_c=OKWqRkZt@f> zXM9H0bsaE#^}5$D2fImyo|orzJ*R{TE9X2n_g-aiyxs(Oth{)(xg9xe%B3#3-^YOU z+mND%ve;!^Z^MJgfOCFMIv^S|mkd>F_Um81vd{iCl-%cb*#kOo*}nNxrKc(}q;S*H z(t@z4qv_7bmsn~Wb4+nvSgoGj@BJQ9h5J-YwUS59w{0X78zviNeszBgjP(nh&>i({5$HcPR z0M>V~;MGYTkq5`K;~3!?VY#Zlf9a<*hr4yH@-CAiwvIIMTmZGwNUS zh7tc+E%;L|c1L;D_hGZTv-1`d_1&+;>FhA)WdzTlf_SCl*s}6vr|lp<MGuJk7(umnK^)~y}yw*aJUI-Hh-3XZ8=|N5&}A#?E_5I5+MZ_OXvN< zGuW5$4QHj-YkFK0bT>$AwH!Cm!TaLSV^!OES5lf$x7N3-!t%2=GSqgTZq;K`UAf0& z9ZT0L3Lwy_*Xk~TY*{7gVd!#IJ5+6dDduoJWa#^U@b%VVZAIO>Z-8P2T8e9_;O_1f zin~jY0>xc}m(t?Jo!}CzxP$#~}xCFOgft&W*d!KvGeeQYq3tM^C%AA?w9pfFp zaW{^kJ1h#X8G-l$I&^9e$7@w2@42=st7_3cP)iz~_P;?aA^+g1-d|+$4NI;8727mJ zDy@%@y<@#JjWuSb?Kf2q7u1{?VwS6KMk>*QMzWi|?ps9=;>cull-iU+uB~^+-k<$a zbh-_IPcNv79YzEqLDICtW;EiYv$b3iAz;pbauF4mq_qSCf~FBmnqX~2`Q6@<*f1CM zalqAXilrr-OsejQy=CMw)NL&JFzculSfAhGv#_Sj+v>Bj{s24B4?0k7)g~+O4Z{Ro zd&R=)Ebn~e4yk=(%!vHJQl7Wg$T-aiVyIBXe5)ljK+E1pSAEH-`ewbjZPp+8Ms-MD zKz_L8VHs4*_Yftvy?fYnz1!1r(YWGku`Kd**`t3}t`b_>$x;z;c^T_f76|=QH*Ud5 zrXsw1WKE;ryms&qVBoRz_d2n&w-{4Qhb=BHx*PeCEmKr?W+z!VV$udoh!2 zciHzg5z7sBQ%gde=~o?jpskMtj`|~RODp1__2Px$rjr|Iz~h=eRMXzE8LwFcBZn}Q zd$klB>}`<}ozR+Qy&Q1ZcNQahRFx+AX0FAU9q4|D`z1j|f`#SXTx&DOOP-_jz?Gyl z3fhEtsuaENw)EZWu~&93Yno3bPi`)YB&1Z~B`d2U$k{U{vh9LjRDv7_BJe?!JN9%0 zYCc>VxL7{mD0b5HT6Jic{k#9q)em?7jt@RmMZ`EcY^(F#R^k?R zwqKyvfaQaK%i2%SLgv;)QLORzY0%69JhtUH?&Jbd<+y9?Y}B`Lm!B+gUsY$*3-%8f z%X(_x4|Y#~lJ3-Wj=q^1xG2dqw0n;6+fX;4xxP=HU%=)5`e|0$=?+07KN=4D%;G0I zhlRVbTgBGaV1eGdvoG7jN+mw0=~XWm=WFvJ7387=I(1CgcoA;czgniE(QYqKm#KK9 zgr>P5ths;}$G;ACFEOOw4%UxIA!asi-aXvKur^pK>OOkG%9DY#I^%@`&)F1)h0l8J z1Z`eac{|z3I8sfK;GsR2R@Y|80Wjz7)AjUnSfDCz{H=0ZKPgbPu4w`QfZleiPiUAU zJ`x9LuKu0+cmSd}98H-`CNSL4O#w=RLYkiGH2H(o$*C*73QY0y!014o9W z*)WDGrx>zLx7dp-P10tM_bl_aD!XT|b37qmAK>q)%Q%7J`E1sI^C)n1s(g7a&{Or`%HhIi~LPCb@ zWLYXqI3Xrg))Zl86e#+ zpxA%SaW;)s2Ku)>Priqg!kLh(ie%61rsJm7jT*wJ!mMib)e}dF)c&Iug}a=8*K9PV zEFFH|90jm%dT1-$tiY}xY9xEO-5fzIEg3c2U1vS`L{ZNDRr5cXmi|_1 z&&!^&pjzK69RWf2!J>}7Y?zfhMO3;`OB$kxxp8&oiV@$jV z0U;O-Xx-vRi=bs+>%K+rlkD3zn#FSF>v;oz0HFlPH8b2z^wttE2dDkih#@WQzF;IX zDh_W0wmE_-fEc46V@DPi)Td^rFjdrU(E#+InM-9hwthGU>;_5x!5uLb*l0gDJ^$o! zPE(6u#f=p*+4nIZeZK*OJrAD_05Zx4ZyCd9wCa&XBL9;2VN3S}Z(6540HK6os{qsP zJUoL~pWU81V{2N_LtxtqRohy#^-93I%)1`Dhlr;0a=s#omUAkz>n=L`9ldjqA1?%f`TU&t9>=G1Qm z4*)OxZl)#{z)huIJ=*g^RWRK#vVoR-m6q%3+8)Wk+iv(x;co9@YQN#Te9VIE;s=*q zEN%@sFiGIBDeDj2cK=Q7qpR}$s{}4O;vx37O-PdD&y}*lwmly2zn~Vs>5 z*RNft1NLb9Qx?r(|C_BZ`c5m=+16&gVNS_dy?)m}-$bv#Zm+0m_m&%vVIY%fW!Toz zR~4+F8dbX6PcL={V!@Y5{_eXDiVbwgA0z9?0fMK`-$2{DIjy?Hpf%-N!tbb|pm+zy+1|KXYqb zhkg|k0?1I!ts(Kf>n|yc_nWA^+JNXmx$4$nW(pD3(TeAV&`(@8DeoM$r+{>NOl?4P z?juwMGUw`oB`__$=Ai3##X;;L4fC3A#iz|~wRw*J1!W#Co~Zye?iGfK-E`{OB0J!_ z%os`cx@#?2{u2QDbJ|US^fLwkt4|5%E77_$llDhjIIn|Ltf#0$o`Y$~4aGTDNJw5) zgt6cPlv4ZQfnBv^|2e{kxoJ90?II&T(1|S{xePGTfc$)cZ@B%;%!CufeC(MfBrfXm zPshcge(t>Hjs7BXO$M^_+m8zWGN=4R#A3_nhf~18&G+@@~&6X z;m00}B|YE|&WB3r`*691+r501EYN&w>dnm|p4H~t!Dds}oXxGkMfY7&uRXHiw0Kg6 zYl#RYG(ZW>$KM4uXI*yfB8YUm`-{c3C$PBB!G`yqt8&_>n27B0tD6g5s!}Y77ma(PG{nhg5=o4 zdp26-Pr^EqhmhCAyc}5XT_*jG#}H56^prBuk~%$}6sZ5&yWN|X1Fe+deOplYR^VX1 z&VFdPU=6oa9d|wA^)!buxsZ>FN@8W<-MZ7XJA;aW^IBc&ea{j&us%w4NaVU;y_4VR zVtQ+^)FM=RB^k?QFEufE$q+UsV#71NVt$ULJ3;tJrg&oa!uPL-C68H0TU$Am8%@d- zC-;q-pR?5^5?cb~3z? zGo7*|js7$7ftsJDKZ=Tq>gq`Tb0vNKw3L+IGx0zC(HJ+%hK91{%Sf=J&-cxz>%^G< zQ8b^KP!lCrN(yEm}7|Z>Js-*W>Qt>^=$jtjk za6re& zxYoVT4q@aEw~%;lGZ*1Fg67*dZWOnaL~nwN zbum7GId6LJG&zyZcDMI$#+tUS-Bi*&_k2>Ouyee6BQ#@-o%g=XIP4#P-ZQE{M|!1* z`^@Wax3#qHUo2FKUMJQzdSE@(TlyF2vHw@3H%0IW(9z&JX05%%))w#pBzJ@({I2F^ z7QE~OE>`S*>Rb+DdvVM!8s86pg|gYsd$u*mhX~Pm@AZj+i+>!HB0L{yy{yZUcDnEa zw|frXS;VAD1P(cdA&_jWi)HtqT|4UG_KgBk#rxY~1QI3&T%-tX zd~R_5>tMw82Xao;v)&O1z1rm>H$wadS``Q9sX>?{>{VEzZonh zl_+aR{uz#Jn9l_JooM?gtFE`CJijeD=~NuCyS{91gh6k{?Ku4&z}rWYIUuAW;_kMP z*s-bcI%CAE&Rqhu!Vw9z$o57ybNz{<0&R`s+3W*OlA)PE^w4egrqrZ7b7HOJz16;fM(c z`CAoo0yxP(M|~WZo!136N%I&LHsl2hA@Zx!5(;PWuE5!>g{Ph`Aj4e*lW$JN=kQAyLV7Rg`862 zVec!`$6pP)y2N99bt1%89Ne}!P0j5~my72-wTyCwKVlkgTt{qrGj$EVr%_Z?-4qFl zmt0&Wilnh@!HhT3=N&%Eo@nDKOt_9`LZ?fK6=E}`Jnw*9%1@i9_NeQ4dNTt~NbwXE zxSBq7_K~wQXQ@4w@o`$~{o6v*h3Y&&47elvN> z;zh^JAdg&z@H(!p6lh?MWrV|blBrtUIcoO4KQMb|>TwUbTvIDj2Y$tKp61o>1-$un zR{!AhW7$fw;nzMQ+$sqmtz^|^|1H&HzI#O6Sy2!>4-35vy+o#aByF9zX4Xm2pAQ8; zVqma_=yQkBx@=`Vy}ymvz$vsvHo_sI<9rd~VtbP12MM2L+z* zp6~;PZeq!$xVzbkGp*5WrI<%SKYrJdV32#AXL)6sHeCTLnH(B`$_|8rywrf7NKlrhCjsS6%a4E%b~?8P*Ee+~}(s2TYzZ4T+tE z4BYam`s~lkKQ-px{tZugSWy-t-|C?+WHj_PjqWKg$EOW?`I6JY_2Z}WzXl_!|A{`d z>;EGLyXs|7RrJW0NXqw4&M%q&znU-qpXP)8Z<^2D+e!Z3Et~kSDfZluMgu?{CS^(S z_h-rfRT=x6$d2PDS8+SPY-$ZwPxr1fCc3qWATK*i^d{*DP za&xzk4PF5PP^Bzw*rz@i8}z-AN9^B^B<|-L+#X1yB>(_P>mZ|#sYWek6#w{zkC-7f z7Ck1wK3XC`9aC){)Ix1X19)*uD^d9ZaCO_Vw3cn*eu0uF)vZU(Rl0r`{rR;M7dcn7 zPgFH8rjK-VzOe#G4?I;>HI=&$JpnuA24@%J^%9TTNkI=E26RFS=W9U6 z(Y}|rCEyt9z}9Bm($ZS*KOkqF$@|a_)GC#|`_)Rhi-jp|S2o|`K6jdpGJ;A%m*|{z z?C%@>QRG*IHQ?V)_$O8@@O?WmO~^ZX_r z`ic_?r<}O2J*R6SecImMW>Imon7lpU)V>!toL08{u&|WEA$k}`y}j`kFxp?Sa^(7s z3v~BPKxA{Ajgvr-<6&TmYlEa%r*c+w^&C~-VOR(28qegu1-th6w6s(mnVddbH3tW9 zoOaJ-@65Gs9DZF29N2ug%dup`Ge09B4-Pm< zcUgxvieI&q7M!=%#s6})+tID`-`*`-@t!DG6y2@KFu%Sxygw3^BA=)TIBry=Yccg3 zqTH5B(aBV6Ht)I$pL<`ADC_yYEx7ev7>pzLhG~%GH6~Q%RlS9h*SleFZ|Y`7S?W+W#z9SJUCZY#ZoyG!@8lk8%q? zcUiY{YJb>zW;9d=4!j&=E8EUO99gHdI=f#g0in8&`zswu0YNwZnWbAuF(Jw#|J%9V zk(JAtG-7M8>v?A2l9zJ4KD>U8Hm1_+@OrIIj0|=?ygfG`BPZoxA%U^gYC#9G+Kn@- zD;p`pq7uV4!c%E>*NO2sa@udQJ7HVrGPvtwqBH*C+#e=HhWG-$p9VQex~L3WSKUK3 z*KVM%9h=Thgetkp%}?q4ZLZPr7RHty2L3CXv-w*b)#q{3*MbJ%MZKj>$V(?T)W$bei-s^H%f$(UKw73M6yKCTP76%JZ zPL?&Y{=M`ge;Pmw=Nr`03ur}r4qK}L5X!**^cVHVrr*qb zL1Y!=t?}jki&6Qp*lMq|@^?;)=mL9->7<(P58Z}aH~azL(W!z+)JR{l)*ZegxI&uI z69H0xe|Ue1t<53oVB1D1tf;Ve^#x!aYGt}JGSs1k==@vFZ$i1}U*b132;0r4p2&c8 zB?4BfDH|C3eC>n3^reY6L>{F1&WB{4t0YiJNOh@wPar?ESNxVCS^c7Riotp?^(lts zL(|oGQgna#Hh8509#`hrikuS?Q@Oq^jf|*1v);Tkb>Sr>?&baLlC_7U;{*nst^JLyTV>K*%lE6u-V#V*VLqxkm`cZ|OR3Ke_# z5-muP4m7@B%9mi?*$d{jIL*}Oc|V=5<9e4_`cA&Ok60yB#74!aJh<_#iWJDq#>`CC zeNSI*h?O&HorU^2DL5@H?Rz4hhf;FIjO6Xr*+_bZ`BC|eckN;8dd+KBa--Y8GxuMq zLJUl7916Yh=ag;4y}g*)-d(`I)zByTWuw$O4O8Iqv)t$kh8k9(5IwxY5GU#^TD zrMm2=k!K6WtiF!0{>acBmSN7@yJgj5poF@PzCH`11VWP`Wny=7*FAS1h5YQ|{_Ca% zfk4E>#Q&-7A(6oJ0V z(m3FF>Yp^0d^na`S)L^LI-;&3)2=3mEVdW|T8&-on#9-?)TfQ7c(Kld|&7#&-x$@a4bm)+Y=;@*hsNXhaP zU$48B@LnU|g?6!b-){}u0uWO(;P%UciIJ<;R%!s%Ok3d3RuQ}yXyKURExhgic8)32 zYXkhg+@wbV*gx=jx_*_t+4Tf-d6UxxW6-x-*HAvA;X^-hp*Is;+K6LpfP%eI)Pp;isn@Rg$e_H~rbj z`L zH;O!JYl=_v?rgoAA%k(XG=gseRfl2gW7go7o_Xj^O~#>;p0|(d47QNCPJ>r({kv`8 zc`|6awyM>+f1@=P+_V-MHj7ve7;nD&8Q3=S79_NMGMX1(TN!J7yEcS4Xu8i;Z1=X; zc33zDPW^4i{xoZb3T{4ERJau1ciqm3aoJA}HytNdkxOZB&cxjGM$YZWL+_zyO_~oy zD5K0-^mx^i@kQ}`n_c7H_-0ASQByOi1lJJN>lH5UWZf_Rz;89VAuW1+rOi!_R9Hm=#v8U zJzVUprhGfo1hPwYT=kJt>hDvSw1-`~hQ(#Bj`dBf4S^Eg-wHJhKR`Fmd79sa^V}4L zMNsPAONjXFmojBdwz(Qhb!{ULfW1oT?piKu*Ir=0fXlj_k`J3gso(#p>>pjI&PYp} zPhn;shnvJ*#%={TQtqwQH{T!{MY>e8bll(iKERIb^_*ARdxa$Hikh8%@>no!(_JrV zdKD{+91fmE90qv19flGQjkcdhjJ)oICi#uNkH^t&$(N)=Clj?2Qdtb1f$a zARXksR6kup49_v8e1OnkQK`Mqp1>ZAhCrL{M6s6PB=srG5V zt*IG+d)CCo;ieh*U6$J&`rTC(TPsu+jYt}7nG1539siNaOJ~#7R zVymegU3xDrPy|_UH{SUpzJ2kB^M0v3Kwdjc*oj8L?m{Wg^DIsi488pY9hN$2N^ttoI|BNXi`NEy zxZ1^gxH;{2RDpxm^MwqT?v$%q)mp9k;?81?T5I+)GafYe1Iygk#xl;CBz!G-@?!_0 zq8|nA43-z*@Ri(@i^%()9S36lZwidgrwrAt8%6o~jSJ3Ob$dt020eDsEEU2>Fq07! z=$Si@d3t*Kp3E-sMd&^L|G-Mzrh*5?O}Rg?Xiu4C1j^x{<&fZ9%S_!StPB&52JGG9 zyaY8q+v`Rikx|NG0aYku1#WKfY5&5eJ*096jMIx)B3?zj3PAOwe)aqKJc`GIR{B$f zjE|4VlkQv;Ynr6{CyF+PUzn(2%TMLvjQT4qaJ;ztZcy2;zrE5S|9_ByD?B^Rn|5v6 zZzRs%e!(zcp-D>DW=eox2;uRpKia|ffQFIvog*(_eLJTGuhpxtod1q3^T$+Bl5FOC5>VEq<0BmR4v2}_Sc6RUx zg^Z2Y&u$M}v2gPZJi4taEfPLJ%A~CUxkQbg_J8L2e|w60cU~BRri%K9>n0!d*crln ziQg6(5Zq!F=jXMyE~R8s4FCWo9)>9%qZ^6L$a}+`%EkKHrL1HsuVYnJb?OGc#sF(* z?CF@5&D6N%6i3#D00ArUb2{QnJ}1b;AwLCyR1%(N<=h`MO{dMC3J&APt0;nT;5BxU z8N3nh<>{?0D5_)(bJzE9lk->pjGr7j`(x$P9krmt{)=C8O;CuR9F!(GgXRL>z~qPw z*xh<>kV;ALBH;GEmsZlk*Yy{dPhlRj30Spwf_CxV>9&D~BICK8sPjtK_L*YM3!JX{ z@8Kic38dOD#=|_|Zxs#fDOB2JzvgCVXP1f7iI zhLUS}eMKn;yWp4-`V(-uO?&jD) z^3a%-p`MrClXW2>1vqX_)?Wv9UBeX&OsY-GuKccJP^T(ho`*3^5d3RnV~ZK);gNN@ zbKaTxR>G13Aj!$mw@w!SD$s9I=MG7lbWy|8@k3jrPIa)i$K4 zfIii;!g!!SN!&wrYZXzlNtWGs;gnD~9WvqNxizl|TJ954f z_vA`QqM939c8pQ!S5e$|Se#nij#TIyRF2t&?>UPua;huzvwx`DGhQO_Fh0C*%PtuV zN&Q7HZ#GoQb6ZogUr|+7>+{Joz$G)urp)Pr4b4l9nRQs;1hkB<8fa+jkImCfLbkbs z$QJ&c*WRArk9kcd=a#UPlra3M#-cZ73Bt+CB_y`kalt>uehsH)DZvQ(a&Nzv+wcYbxld6_LnHF$%w?!*RW#J| zoULcEbrI+F%!1LvFl=1>+@D5THQ z%kkdRCVy#e!N7Rtz_DamU1w}_uVTeuq5*MlO_U{QwG|c45~mak9{Meh4KSt9`D5T| z&td2Fl^T6v+VMi6?Q)5FX8+KYz}u& z+H=;Q{Y{W_-+tG4!g;0*VDFv|{l2=ktoLnZu-GCZ(rzG65BbarzgkcELUq@Cn2?0;ZH8f8XixZZHUQTbC= z$NF1jgEy5Z2JHnhZj4M>J1L09szG?(4q^zp!>BLo_pD|tI}CjMQi3qcYSgX3_h4R> zX+RMMpRtd_g0J@_d%5}_0^e*4q`%;HPzBWHwt?&gFD{?D*LF-l zV<7hr|2eN{WM$h{)&via+HloEK)ZpW?n>eXuwvS310uZf_KX&MINE=EOV^(h)J(kEx;9lt41 z19=67rd}Mu2pJX(S|o~C5*Rm%ttqtwfr<${tPXywv+?c;IGKR9n;60O+|B#O6~@_< zt#8##PoK#}DJxr{FaInQqX=8q@3c*q4I;l}=)Q@$+z63>S2z)sS+;U8_F;Czg_tR3 zfIhDzHarq1w(mo@xg`T?GY+mLwl(N*y!KKWD^Q}HajeA%9=#o|p?N9gz0!R+eTf#J zvHQ!$V*KvXF(rk5lT10yz&2B+F_wwA_fuP*`A#qnn&nEeJzt2$1(X)>5 zyaEjuXLY}K=23mSlnr~)Q<5(wM3OZvhfN=;edJ+gb9LK1EZON~vB2Xc4ls%}AR^8u zPSCKp7R>++PKFa(seJeMAC{oD>Uv#%*k+Np10jT5S7w6mvsat)lun{bc{sKlS{^dPX0OG+d1eB$?kvQwlj~nB-C6 z195|g4L0~hVf%}S82CLcIU|d*$O26dU4}sV)HfJY0avX*Z7N4r zAjc$Dbk^Gvw~ISosTAlQnRv`-EIrOF&Ar2PQ=s+PNOwWd^Af)~zi5aq!Rq5X?bqU% zkebg)$EN7Sugocd{>s>ZAS?hY-Xju9>3GXLbu4B!6c6kVMe-O)PHt2IPx=#pw~7Ul z6>wG3$xU;;+6`)7SbefDa*6Ak%@FZHCZ0czYu8S&Dpt9&^&`ayi{VVw9*KvG%PM|;8b?pg+EZn*xX&`h3uOml;c@g3^dIk&KM+Ze zD(8zW95hqklmU-Y9HO-H`*1BAnwznGcK_;1B`*o<9 zcQUGZ24~>-?fT#trCW@+qd`Csv#&9yl*)rNDp7q>ibt=FpJi{$UY1Ub=W4#A3l6yU z_W=%v(q!j$?B=c4{#3u6BL^QHl6vefqcey~h#1{n){Y2i39$IO$=U|%+dN#=R5KVRCjoGaz|uZZqe2v{71^ zwYd^_eZsi)9=KM$)UCT=A%lfO%&EV(-ySrb%;iQ1yEVRAuM|Y=Zv7p(Kkb)0? zaJmQ><>p%~mKtasKrxxm=DJxr(+j}?>eKPbDR$F#Io~k`In4;xi=(M>mgWMd6o21sl@VywO=ARs4Je6s(#(M2@ar{2mvgAOmQpM&wX% zvZ@rY#ZxgK+UT>1*ldGI$b5d8c{yWW<`Km*SaNkZQMlq5Ge|?+yj?6m1f8y``eb=s zvQw~M{e>l(6s}u7KWm4;MKAs>d(w20S>e*%Pb!vvvlhwtHM{~G(B?i>gyrTJwPib} zv(&gf1R&MwL?cXk33w!|%(W54LiV>0c?15ODlUuoO$e15>5FoAbCZ=AWjn!goBcEV zdsp?bXTxC!+75yyrrt4yq0G|CW~+I{Wx350PVnc)zTUyEMxQ(eVV&aWtI^U?J) zK1RjV7>rSpFRnCYtdF~Da=UHyV=$C8S)BLLhUp7(dg0{SIygdUm@#p8l|f4QW@hMb z__fi(7;;KkH-%#q@>J2Yf-P{&D6s(ib4Qm0zHd@ZOl4OF_eHF89iW02HFF7%5yL?_ z5d#MdAv}XG0NUE5!iOE2uixC}bB9dXlL^1Sgx(SH=v}VRK_H3idZ<_HRo6Dtds0%Q zVM>_?VeN9&y2K)ld95`j{5kvXPviH`&)a`do}&OQsSjBpa__2`a?}zSGObJUO4w2V znHx&W&RD|k`!0OjT`Rv;y%!CjhT;TTsah%uXiwqvesZh=j-I5;o@2ovC?VfIM)VRf z?d0@CB~#S%sF0ZuX_9pO{`2sW3wCgQy7K4S!beDxKsBc)GkEMlWX?VziBIt+YTs(I z3{<~;g0s&)}?u!)t-1ljeB>*T*+&L%?P=gS}P&m`P(I&;|<*wN{yJq;z zV${o*8)%LT7!8`C9xdtnIDK&2q1HZ zT}ZD$W9r~UO@+>Cl20o^yWg!G!rXzHPG#P)NuXh&mzw=4Ug4{Y0=?|loSGV5F0R;Z zA0^|!<;i`oTZ#nzku|luRElG^L_SK)ztlw%za89H?;|PYR)gHJ@}J0|>mg z{5;}MmPDyy@q~xFJ8Hh9nmSp(*?$8wWYLu;Qemn&47b25*}pgp$$tn`oWDdeR4sen ztzy8j5d>TQS!M=-mUHc-rsdwaAlZd3zmb#*mO?}4H*`+z~k^k~YznOt8i=TNfzr_YyL*Ccv* z{4O;GZEe(L0Z%B7LjYO{mYddX+uzZn$sa*jB3zldX85Bm^c_mFdjFw3O!=`AHL|y# z{s?>dGE_s}(5nAL-Z`G>)nukFV3?V|01-QWByoR>-y%=lM zRIYC(s_g^HxYrZQ_2j4^i4 z{o120x89L#qgQJ0rld!AeHceg+F?t)f+8=&3Tx=ur1ipHLLRqv5Tp1T@$`0~tHQ~) zsL2@+g&GLj5AhM6MUU}18}@mpo>%Y7_{RsjC% zPZ6)mSh?A|xJhsZ2({w`AU-#s(wE||22J4$#uj`^S!zU_C<^{FbjT~Vh|W`SMcE;Z z?+o(l+S%LsVY%t7Y>=X{(Ql!ymoiwqh5J?B*G}ZjiM&k~O%`7#VvuW^mB1E@_S?Qf zS(Z0Ae5b>{q$mc-e#vY#MtKoWDvY@>lsmK}3knyH--kFI^?gu`#UsudzJVyHligy( z^Mvf$l$@#=+qx35iBY%Es_R&&f~=);d%iU-4$`kk%T*ckpW0S+rF>6MqM+UK@TjYE zzYS3`GO*HkqzRn*ll+23f{&+v&&5Mm*F!OWUst}VNCRS%uE0VVmLK1kTiLz!SkFR} zSHptT8u+Hlu(uz>k%#dm-~5h#^La*&NUnSTB(wj=L{c1Pv{+bWuC~@()8zSvUTsCi z*h{ylefR4R1|~6IiVrG=U`UK~7FIS62BVR%8iAMe?h>e=FN|=s?o9ydkq|EO{QIf~ zwpwh&&R46+-h>CC0H>PR?dX8pk)B!dz8ZYOy{_OFa~arv*9pZwtOHb{po9t~x9dipBD;0{Wb@oQh z)7_yAdXoZnqD&*1MS?T-pWJ)jQY|^Ae2wOeK3u7BDU%ct>dUc-C}O68Gfvb{Ct)d!$b&!@7sjThw$

Nk4!b&ZMg(5bU+FUVcNYr^kYo5S_xSuQgRezokb(*MyVO}*C9yc5{F<{=t%;j zDywp2p+i>IfcV^5p!v(`3p77RJa(WiVOGxEPe3Pm(k$ogm0W8t+{`Yk1)p=bi ztzkoI{+jj2Uz6nzEyGTKXLZ1jG_@h6(wKZslbYI=6g?fgn1l`(m$S|=Ml=leH~1`+ zUsx!4pT_54K$n)QN-+X{{OCAqrNJjko}fN2?|`;C%GW>oT+>%D;X)Hc^Bt+wq4Fr% zjH2HzoxTq(Ngd~9M~$e8c0th0`Y9w7-Hf>q)s<3=Li0h;_2h0^a&xgJXcv5GKAa|%Rw5VE$HvmxrJw6Bo<(8&;RgR@%Q>95Iy?K zCwbk-Ut%h{fk)GN)4GVh_p2DF1-q4>fhVuFy1G~L&rAo&GcX}-;Y>)wy`-jsiJ3yw z2z;+*?p-%mcp^l!%;eDPW@4O})_)fcq4aoQ zDlHcXo62DRCq=GimV_iDADbMxvjG33#|8fJGx=@{KBRHhlXu`asE+o6YT5ID$LCD2)UfwO{LIn4lZ+$!EF&k7XA4pJ^YNX!z$p9?q|_uZ z=-DF~^^XMS@3Zo3b8OgqZKw*RF|!j|mva;d7;8KDBx6zdHj_~|aVF@E=J55(Gh1XC^%!_bNsIJ^Yg^S#5>b#V*m~wUe|wv z+&4X;*biR7N-84;%)jG2)dLc915R1`J|1Z_pq4(tSy!TdGUXNrk*P@7%d2}-*=E(| zC|*@6t3@wnlbL~P(>ocf`_hE&`x|*Y66rtsv~mH7;!XyWGmNt$mWw0G)&}mfkT_C!lev-fG|A zO}!9W?NGv-E~K{!mKhH2BOUu)1-8BiL-bkgEE0FcfYQbp8#l;Y>8fb5I(qPuu}RX* zCR5sH$M#>3)vYKfj&ZH>gVkFOY(ExssG0gqFHOTLTZSx7>3Ei@MhFS&igdn8pY&S#Vd!-cRqI+p+VF9$9oM?Z$~_=Smn~sx(qj+Vp>$ zL3qp?ihoZca-6Eo>Ax6yQZ=x^RLYwB(P?=+B>40RxQP65LYIhg&77s$=984%0v&=l^TgCqA&iIiw^k+2xg6e?oU zWRjm{R9jrAhX6Z3G5Q(_6aTgM5q9z#$SFGc#AbdcGtPX@xRAA?B|2{u9B~?hh8lkr zdOCL6pXILrQg+IZeS|IAe)J+?t?+B|{&=2+MaUA$3T#E9FM~l_RXI1SV)3dXAXb%5 zC*FRxH2_g;>7N}`JSJCUoi1szY^o5WjJ`bpuBYfs>-V)*)J0qh`e;$n%tJ{jDp;N6 zW&Fc|WxY01!%)*Y1qh@d_uC!VJAD#pJ-K6H3 zCqEioO~_AGu8*0gf|Ai@r#u&dF|+dZ&+`3o`4q*6zp zgxw$y@oPc*I)R%HwvXzjL~o({cIkd+=~izyUd zQ{M8TP_(n;l^P*Fy4)i*-00|U_!Bfv6^%gek9pJMSIyBX{oKq{&Ts8@DRzkDl`ZA6 zbSZY+rY^i$oUv+UwE4qJ9$WUr#(HTB_-P$v7?I5VsNF+mVU)_R#)%I9u1$Z>JHd{H z9!jV}AhAi|oop6Nq!StagCth|wwH1a{dKs^``!|&skce-Y7%dyNd;&>q56-6ld+RN zv3ET_8GGMJl+2JWOaC|&;QZDCw=l<6tC$b{Wr)f+GXXOpsb#bvp|+;}dtOFH;6n=f z_}u+kjaB3OFi;Bviu0I@+C+C?J7e}Ye#@k6)VJ=8;GwKc61ta%Aix|n? zlIt7=91J|3+6`BT%KA<_t<7ZroLi+o3Noid_neNj%mNj7GCR&%W$-j^R3%jK?*zh; z4%E~blyQr_;AAJh5895F@kL*{-xs@hWX$cXkqjJK^-LUb*&QR!BcbU__+`vgWi0%J zYM)YV4CK!T4EHh}mTb~^G#MEhs`iZa3xE7_?kp%-`*t~!e8`%w5gjQN@){tm&B4jU zQ`&r48e8UV9cZg#U_gTO6kDfk!IR=-GV4i;NYZdR&v&^%?dwU|h1Ad-%7jh{#wq=`D?XZ@DTUE+0jK=^N+(o~#Z;;ANCn&=S=dh@L`rKmW4@4nr~jJ0s}>+FonHeXP{}pbPqtdo|I8NRrRzu{NLeDwn#O|9O)offtD zSNQ%;A}1#$MJnxy?h|$rDNp>E`HFIkyqW4gcz8OvyqWgIQ{*O&PR$e-gIkH3#xwBu z(|0)0neDw@M#gr4e$ z0S3Qw5W25xUn?!tFdP^d2m}Inc8?H3Xk=npHZCrX?EjE^gb+e#w7}bI5kd%I>Ou%1 zgnmnVrfGC^bOZvvy)z6c0KotQ3^2d|gAo%@N|~&ztkAWtJ*ms@_ok%uahx6i0Av9E zR|FD(fB^;=V1NMzKMW2%xv(tk+NCH;1|M34V(%@<_37zOj-vn!00W?4@EZpNfZZ=p z0RRIGFc>`n1>p7zGyn~Q-!!PJ<1;f$IF5n+Zb_y9p}a*f_#*=Hy9C&Fz~IjiF#8?Q zez$<^jWPJGg8k>i?>|jL-uvGF%0R+kqy_|o!zEw<H>%TSN0;BMi@o`pg%Em zgEiTK{qOQl_>~|26Bqih0T2N7K;691$isep)c@VizU}?!pZ5N5=qrQ}6+p#?AvO%L zVR+c|!L(p7P+#BK+}z&X?O_;`D9Qi~AvE+i53u)~bk70eF#n38$T}U(%8Ja+PESjV zV_EJ%-8{zU^VHY3*4KCS^+^mPXxg497cmTI+TINl8ruG!3zd}L_SN@u>C`zcJ0;khnU0qdCu`MSj{M1ut8w||e)Bn)Wv2AUgZ@#%s z5TYkdnv{`|$+8?Fgy*@?23eLRB=nfVJ%z#_`W0YVCiE3mRVn>LzCs8ARn;h^9LK7v zrYMRi2HM-(Hf~(cFz$2Dot>DN1mNHAlWFjHobSH7rlUidJb6lPZl1|xW*9c~^3ZmE z>OCF&S%eU`+fiLzy>n+-N{Zo(Gv=Dj+}^ixPjacORPypB;tWG<7-BGr0zMcFE?M$j zTbs0C!I7n&*Sn4VHk!1 zs;Jtp`suvDtCFn!?DuGz#Pto3hR99Dj^Ub$mVZnTGQni7q-e z&ZOf)3zKVFD3k47so~JSLRli!Y}-xa(z4>MEFlNA9m24Jj;D$u%979PH-=dls?lGy zKbod#gb+>g)>YNSkC_@loNk2=)9ds)P7)=Cp-zviGw>|4XM{tqQdO1b`N5Y?^LkJjXJs zs>&)gTOuMNEG*Fo00l;8wnT*cpL=j=MWsV$(3vcek-YQs?;ifFQPL5W5TdFYWw?ll zh;Xw}Q)HIsc|qU=W4I-ZBUF+kPB2)kk!F*Q0m=w$?Ut>I5N=}Z58r*iP30q^B6$V~ z05F`%Dz$ zABX+@>+|dnqEWrfG(0^GJPn(L)n|KjDtwPFlHsm(7^VW`4;rH`Dj-t3rw&M=Rz&xv?{9Ac7!59)CaWi-IWdoNbz>scD*~ zXCc-ehd>>@!6{1{pvsOojm!mS#NX$hAH#= z{fZpFRU*S+p$62AoTsDSmD3>RoV&{h0^A>+uAJ6F(JXE?P&IdCj>xAOG_sPnIW0er~pr zh}!^Q&fK^8?dP6f`gxs^m!FNh>h|rgt2(fG-r_A8ee!*N)^zxj7hhSiZU5eGe{j@@ zk#?dRa4_Cl@%rL9E7u*6dT03+-ikFZe}2hFn?KoC7rWx8SB3bFl}n$0% zuO8$_UC}r~pmNuTbLYSC#mVlRe*F@46&1&7%8K83^TX0$?!YuR-&Vczh53KlP~4C= zcu1n+&D+M`zNuR4lb3P2xWOGrtX#N63ub2oyz$eApIz{L$$^dmh5f9^>9QTAo43Ay zLKU*pJgS&}n4jOi4Zf{vls(^!r z7GL}3D=#ivb6iUs)>kQ6yJ*hyZ=ccJg9i4hJ#x6JqN-%=%Jn5>`Gbq9Ha$K5&W8^r zJcDy{ynIGlj;ns}p6bTR)i3?|NF-R0<0}7j_ZeGo3-Ql)ml?#Ppy*r6o?G$G7rh1! zP@rj;W-_T_0xFB&di=S!l0v9opJ24La`~b^zrVfgXy?gcSKZ*ZnAejY*}iK0Zzdn; zOyuU~1%iA=rgCiGk*3DFRSV|r?@;^o>j#q^tCu~uY{T}t`Ud9C^ocMMjm6_}gpepo z9UaYCS$>yG0l-Km?fv`f!r=l%kyCj^hLUSvc`erW!AY* zmec?z<`3#${r(fHOPl$`@p~pudZ{e#i)@_n;TMt0%`=}_sCxTIS~AjR1KYGr(=d!= zEa43g?q%$sId>!GV)LJRwB%GgJ5z{TT^xuFw>ZCMaPLI@$m<#Itt z4CAXguW7aqp~1Pr7>HnmvR`Rx&R5at3ADv!7Vr)Nx|bD{mZa z)v9-FT(@HL;hpQ|Ejd=ypFR4(!V@tSSf*(jx~frkM!ziSljTo+R&UhrTyfVUPj`FL zt6rG%MRWI_7Z?0x%dx&Wy(6*Ch-IZV|B#(r|MIj~-~W72(U5Qk{cO>krR$FkA2IN~ zS7-gTcz?^$ZFk-HV0D}vDc=72n-xl0I%QHgBTet9UiX(xI+IJ5Pn|kzzL*hwY2Kof zYOG}4`@8qo^Qdd(qK^(8ZT{f3mpAOt{G|5bY0HzC*rthjsd?uMQ&w-!51}PXmhUXD zUA^SNZB4ADy1xMd;El-DiUu&1=~ zZz~tB+SXi{>)N_%(auwGfj~ltBuRu2#u%l7rhQe9rRy4mP!vUsG0*cH zg&FA?N<~o+V!95Tl4J**s&yzqcYT zr@Q5VC$l#&3=|kQ;)0gSJ(~_3s>Y+P%4j}%v_lbDC*`9Yl0=agc*+n}_ zkRW1TXv~7?58ie2H5oowz4K@w@Zkw_pdKcpjQCu)uy z@lUw(j}soeyU;sCJyw0Jy?orXS@-_#wkyXDjA@7xB8rkA2#P2MJQ=;A&1oix>-|UG zeBab3Zyr6$pHS;+Di10b%zXI%2kxDi)m(m59&};2@7VD-6^6Y?_B=3u#^if$mY_Fw za{s}DB~)aJ*eLQHaSrDVDVQ^N#$|aSLNLadQkr_O5|TPV&jFxAXj94|ghf##giwMY z^N)XQ@v~3fv*D5HbD#SJxV>%<@TKLGXe4;ib%T|T-KCrMAE@th$#1j+Z#1haqe-t& ziI^Y=BF03L1wLJJ2LqXDMntusDD?luA7|b-dF)_?fUb2%PyhJVNfReLbiqMH5d%f8&+ znRDmB?vev1ss&LI=?RLv857SLN=hj>TkQ2U3B#VHivxh3_2c>%fjRIEz&al+2ORh( zfDi$|qLeC%f)L_)!J`QAuJ&NTj}|Xmkwd#aKd@`Y%qP$VBL;`vhDC<``bKxWeD16T zSKj?!c^(Duy^AjY#hUjvPP(QD0Kj-bZ$3C{+I)HFj|XN3P0I5GGr3oYN4kX>7Q8Ou zWM{i-g37v@T21uHG9gqD$i`=aUZn12? zz*!cAkTC-3z>JV+>ZWBuPar7w?o;@q>lZBFJmrpGA=UP<3*6Kuj3I;&LKtH~5EMlw zBy}3i1b}iJM+glB0;y*%<9TFgkvO{c<_BJy_lvd@`%5;y_RL?(F8}EjA;y_F|gtGwZrr9(`xy!qFF}x9PDHU0S@Ws^p9*GD;wVgdm7H+klYq zjB*eX%pp6kPbi18RL$fhug~qm6?=Er9NDvGM}ynNi-L#{qLjK^F2;BWO^hi3HUK7s z6aWijq9{sg;c>}gq@z2t==x=EF9@4u2M=$V`RKAh(Z~TAB8TN`uNs>f{rv7J@7?y; zm~>CN5X!pjy4zR1yX9x2FE(^N_14AnyrL)=lb)eW-HTG%Q$6h@44s6b1K$Cll$Ru1 z*L9ZKw_(gBlN}phy6lpRM_hNeKH%54US3qxJNnG@8K2p3+gl&Dy9VEOiJ*yt?-&u3 z^T$lRXT%>T{_2Kb-0;!CCQ%Rtf%jzeE$oe6yzimyRf!{iTV4;mikD&m@k~G_9z5=s z1FXvHM_m5o>Vsb1Bk+h2EDBQpONN(yI)C14#i-`PcTa`>Fn-80lgEvpG^5$iEBy*@ z{?AccpSXJTjZd`b@t`b2#t24|xA(|=W8RDzTMX{gwOhL|a(fs7K$HZGS^pu||9+Hz z!iZsG?|N+1gsG#lvqz84opRs(YY%s2`6Yw}#(2`(au;0x=bt}<4~%6Tb3DwI>yB9b}Nb^NG?%tdf~C#hYr7Z^0FOQ zPQ2yf3;x3@-!WzGQk7M_{^pMCYi=uwnxU&F6uI#gcg(*S?-_ILm|G_-?6R3Gi5QWL z0fl`)?X3G3R@HQrZe4GPK3<>zP>Dwt4ctBPrY(ye8gtXcPg{T>C=_FXXUyB@uF2Ee zK7MM@@XMzyt9fMR18r~4y>w{NhW5aHzrDfBphy`6jHQXR7w-xWF3OJn=68=A?0`X! zz;jUYGoElzWP-qK0uvmj1=!k(XWl*z9*{&@1xPRKXRK zr(YA=aodeQ8FSaO&2rIAHw|AnX5_UqmPeD4OU5oqWE6tX;ITywQzrjmPZRPLh=ivu zK@d0s5S24{kly?DyXMHnFV9~3vEugvlW<>6I>s2YEQ?Y@5QNms#F)5TP}h^G#4Ke@ z=FyJ7K0bQXs4IT{2k#BHTsvf7U(T5Q@Y79+x_95-YK1SoJUvs$y>3)*cW~5Q4~@%x z@Xm49jk#xU#Tmt|q~!5pw%=DLKum} zi;F+(-=7s0<^x~>VCXvc@yGkp(k?74ECRsBgkT7|T3Z`iJ6wUxj0_(#&F=Q*I1m)c zj%qaBBO8eXU<`8rK$J{$H8wQ!l0O*qL13p!Ya{I~ok`B)5;W74L;(OqF{i6ZjtCgR z&gRCbfxLbX#SkNysxrnHM!Q;CJK~-|rblM6j@ITg(O@v-a`C#RTNc0snWkZJkYcPQ zqb=( zo@r?8;3RLr@8xa1@nnOgc!Dm0qYRju2{6Ub)}pO#33t#3Y>Q%SYPt;(!JKNCjNsFa zRUdCZXhlzcwCU4d&tLcRzBHNCHBD1h{ouh;U9Z0Cs=*kG007(8_U)@^Xy7lt_zF?v z2_ckHJ=s;?)S_WAFFVXbE)i*KIb)`INh|?90WZ>%I>Z=3U<1Tyjg5_($pUEsfnilu zIgU#twBq8;Sy|T5p#uQ00nnV1WTzzAf$u2b=H`~ITMvc97hZJH2vHP(qjS{N)xC3P zaV&Ox%$T8)B%Cct1~oOcJ9gAvc;S@=1p_E0PN2S_D)(-lvtpC3a+h5<;hu3tsf((r z9XL>WT7B$>+7q7K{#w!|Lp8usZ!TeIxCq>96Wfeyu2O&Pj2qO+}zwiAked4@^_(g zuJjmZV9GNB0RXmTMIzlTt!*by9zS)e$~4=D4((e|kk44pP6W_2yS~0@*RDhHI1PvU zWo6}tLYX|zfAg6M05A-rzP{o3@v4(2t9(9d*sy*%IbjGP09MZvtg;g37#gODc2>03(?+T3T8wDo)naGKJe1?W*_ru2xR-5P9A^T6Y&%uXWjS4v9dJsLzc&CN)Xw?Brv5EW z`MmuQf#Xs^=n2c$ckksmz;O@&?b{kL?b{9Z*9I!YJIPkrMl=t?x6H*XR z=m7w%t}ZfY(1oeaHD4`Vi9{lq)Gf>AI4)(A?7%;P^V`@s;D7@T{HtKwHiXcDe*%O+ zmrG8iAO5}zjw45o9656IEf;h`;K-39M~L-g$Os zdZoLkd%90mol{XNO41mpgs1=jV93fyssR8j?OXW}8TRe$tPEJcT~M55blm^|?frjm z7$74H9{^C5Z6zdBRBW8wo!o4koXKP*B*>gyovdu_EdjuLDO=rIL;Vm}_;&3|Ts{(% zBJZU35t&R)JR0;Nk%oaB1xqfHJpb=U)gEjqDR`oxyhymXI8e+-RVMWBsEbHD#FG!KhTu z02Xq+1-aWZB@A#EC?v#4(T&szz;y(>wK%p?*?umTz$e<5^ zm~WhT2_W_b29%vnqYmW3116*9X4`-YGhjj+v^NWYvhRNS!2tRx*2bc^|QhEcS zKYC%Oq)JjM?^rm&_NVl2HrKM6R3 zxiB{_#{eKN@#EWQFQ2_9-c?Ub@Wg@N88aVsA-+ z*jB}HiIdETx#TFOh!Rht|3f|VYO%G>^av-i&JEOl6@l?fWd3Dn4tFC@i>2e$x! z7i~^Gb9BgXAe)fQNw3#4(P!yAY5-&rloayLbmLmC=d;?7@_I*FT z83%iWjtmp!0#5vURxH0riGE%xoG1wn+Li=Z+22JPGdMF}W*pTh51Gm`xnu|_lZTfq z?COyCQ<%sYhr)KUclvfXcZhb#FZ5Bf&BR=a?$o#F)JDF_5$s~^a_u5orgMDOEX+__ z{gtnQ%^j~NUX>44t5J>k^`6TkgMT~(S605bs^G^gp$(qRt!>SLdn@+pk55WzQ`$45 zhtdaW2XI$j=osN2Lk1(Q=?F6Mk?^evyzpz%6-o$ZqX`Bz*m&8Y>H9x1e>!REFn}5S zKPHZ#{*e1Y^Mi5yvEeGGp0c~FklfL7W%egYwTU;VH8YAI?duA;EO zbu~-5T`^I9o1|BlW9eynPNxwlN5QFd&8K7kfjEHmS>xH^q4ZiBT?erqoeFUoeF9(T z54Vex5DDwx^0}&nVV{^pvFQ)fw9U}OmT95F`7g0wFk@^747RDZ9R?f*3TY5&$Z6yi zj}%Wc)D&Av=t~3@1QiCy$HoiB7k+YQ3bR8v_A~c0A(`t$1wv5uymVf~k?>?-PowyL&L?9vvcWTlFn1?#@rbMP>@tcjp@cM);98tecL zFts+rvu^rR-FKSYksQz(5c@2Qgc0%gT?L6ANuXPU>jwcXfwhc@tW(i|KUb-Ttkyb{ zSd)vK+u--3^!>Kk>Y20B)_B$}ZXuVE(NXf>Mp@ECSTczQR);!vK6nx5f_+=#g5Zi{RS@vd>K=^Bsmb~g<*jVkv!-wwS4~gIsRMKx80s9a+{&!gevme{q%{% z3EOvJDuD+JQ%I(JrqO+Y=(J%GVcOxMan6xCgwyP4++Ncw5^n2~50a^pYnj&U%KSCV za@-6ezU zg$#qDZ_;sMJGT$jAI@T?-Ih?=vV?X8429K9fgIcnPcjD%VSx_zkfg)}7x8j(#bmJc zk@cRH=V+y6Sl!DX$LJ>3Pd|``?dlUM5pv#5th3zL6P#Y0%_MMfxV$zqiOya}5!O(P zUtokvzZ)d&e91oZV#eUX(2UI**rIfn^w~MQMOnZ7gdwox8RJ*Ei8M>}x7lRti^-VmAK3wcEcYuW z%LQP+ee;R+ub56}tyu1xGg7b7`-1I)69yN}?iY2-yYID|wKHl2j2({LkAz;5XO#!r zvf47LTMX=4PJKHX{j6>eiE?-+R2D;KdPmH$x z^`bqkYFBPIz7jk6{8wT%VqR4LWo7YfCFpCnSKj6Hiu5gFSjgl{;&nWx1Va4J_|b5T zaA*#n2tWUpsO$6LQ>nzH#UxD*-b=yDXf+-#YvA2H6f!ZLKAoR-k(S)$;9vZF)D0!5 zSsv&e_|!S<&B<Na#pyGsl4M)7DV@IbN~BVeX8^^nIJj&6&^1A^2wZ& zdHK!Xgtz{z_!$6x$N4|1Cck|qGnY|Q1OQ)Z004ym!2Rpn^$-9&*Z|#5+1tK1FVKtZ+=FDW>2MH3t<41xe6T=$A9{Y^LtXe=NS662N z)lFp<744b~bWO0NW=u@7kxl8(LfM1If)~T$C!N`J=096KEjoR8Ir#avLxM~U)StM* z!SqsHT3YJmS!!3_dZaBQnUI{dLq*F!JnTo2J}baKEUV<2lw4ow5ecw+xxE$t`}M4D z!KIk^;N19y~`m34Gak53Og4Fm~e=jP{4C(cs;UyoH- ziC9}H4;76Mh6ouYE!7oVGB>J{J6XA6x;8ybw1!otGzjGBs$j;7{yAL&bNO$}?d5-rZXq2Vg; zx_@61wfx1!h2GLKV|h8Bx%E-F-f&L}lrXVfM`!f89RP(23Qe8aY_@x6)vr7c$tsD= znPu#iYgTxku9Vpl?i(QI+ef+!WMf2{XpE|YU`!aY7nJ7q=KyS3dXhmGVp=vk`(;F+ zj}7dw{NF1K4bRAD_eZ!Xu|BkD))wM{hKh>ia&!FGZEx)UXw>K13U zQ#?dKB6~ULsc`-Jf`0vJfwtnp4V(CFX++$Sq}W^^%?o;+&Us|BBLYW3KZId&1f#Lp z`b@x5BeQ?-DJd+*kO^i!8d+Op*&&lXixdvr-1;zhk;y*=J-PI; z6{Xlgs^_^*Mi^@>C>=g3L)jFg`_1m}@5Lk0Slh7xL?k4V!5oo*42NaOqC;PO`Dj7w z2^7cK?ls<5sI?dGbxFbRZ|Qr)MlB4ssk|#fkKWI-&mGcwZI5cFWy|n~;J%1tu#vhk z9_K{4s+i|~;=-wEQ>CxJY*y}`Nz&id2z>#x3MrN-23r1m=h2=JB(JlzD(J&`wjqx9 zufU#Lfug-SV0KWN+1!B_^`o}>&csZeR*ZyD}z4B$&>8PqpZbOuen z)8etzTlw2qTIDNlZYe7+(ANgGS2Xiq$dW2%UvRa7^t{Uwu=M{d#H8M#?|IAv!yQ{u z!AP5#Q4VcYlUv3ctxJKizz>JEzAbe@@B)40pVs9zq=+O01ccUVS=sUNh~?$w03y_k zj11K8mlqe8aY1P_^lm0HDg}AIdWPI^zbZ5F+xyRSZ&xUlYY3e!ROhekoLWrHY~g_+ zY~=oD;p|Ot2j=?gzv{RmToxVodv0x(s};vS62Dykqn{^_t&ytj?nlxhzC9DAxx)6e zTbrBfs{xZUVWTXD904gEv$IzV60Gf-LXLa8+AQCP=N|BKz1_UNZZ<;3Ynb6HUgv)( zcXm3g*V-0p`5$_a8uFCl05jQ0pITmfPO6^u=z?CTwQF=ZFkpZOEs?9mO^wZ@dyGtN z5wJW_(4#{W5AJ36ly29>@c8&}K`nUqx3TJA7{su(Tg-2;Vp8N~DZF8nO|SN;z>ZZ% z#cS-*(v#HNcXwpGZJAoF$hnufY1QEULa-abUdV~!^Rw1?%%zCuWf%&ma}Ptg z%3#&Kc@;sp%m3-ESQ%TQRwa9ICw#KpFdt8cl#s9Ql?K-wH=wTR- z=R`r*e{V+0Cq()kh9qmt%Tag%GQeG>d%qYB^_x*Du-_UFa#1&TVYPqpHsw%-pXdz)2@?%fIx20ON-@bDzk3g&QK!Q1IlCMF>gsI+5-+U z^3c`n1fO)@?7w!s;raPY?V

    wzr{--r0g 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 in HTML). + +``TimeField`` +````````````` + +A time. Accepts the same auto-population options as ``DateField`` and +``DateTimeField``. + +``URLField`` +```````````` + +A field for a URL. If the ``verify_exists`` option is ``True``, the URL given +will be checked for existence (i.e. actually loads and doesn't give a 404 +response). + +``USStateField`` +```````````````` + +A US state. + +``XMLField`` +```````````` + +A field containing XML. Takes one required argument, ``schema_path`` which +is the path to a RelaxNG_ scheme against which to validate the field. + +.. _RelaxNG: http://www.relaxng.org/ + +Relationships +============= + +The ``rel`` option for a field marks that field as being a relationship to +another object. For the most common cases, using ``ForeignKey`` or +``ManyToManyField`` is best; these "shortcuts" encapsulate best practices +in database design (i.e. using integer foreign keys into another table's +primary key). If you do need to explicitly create a relation, these relation +objects should be used as the value of the ``rel`` attribute. Also, all +the options for ``ManyToOne`` are allowed as options for ``ForeignKey``, +and the same goes for ``ManyToMany`` and ``ManyToManyField``. + +``ManyToOne`` +------------- + +Signifies a many-to-one relation: if a ``Pizza`` can have many ``Topping``s, +then the ``Topping`` object should have a ``ManyToOne`` relation to ``Pizza``. + +The three positional arguments to ``ManyToMany`` are: + + * The class to relate to (i.e. ``Pizza`` or ``core.Site``). + + * The name of the relation (i.e. ``pizza``, or ``site``); this is used in + the generated functions for managing that relationship (i.e. + ``get_pizza`` and ``get_site``). + + * The name of the field the relationship "points" to. In most cases this + will be "id", but if the other object's PK isn't named "id", this + must match the PK field name. + +The keyword arguments accepted by ``ManyToOne`` are: + + ======================= ================================================== + Option Description + ======================= ================================================== + ``edit_inline`` If ``True``, this related object is edited + "inline" on the related object's page. This means + that the object will not have its own admin + interface. + + ``edit_inline_type`` This is either ``meta.TABULAR`` or + ``meta.STACKED`` and controls weather the inline + editable objects are displayed as a table or as + a "stack" of fieldsets. Defaults to + ``meta.STACKED``. + + ``limit_choices_to`` A dictionary of lookup arguments and values (see + the `Dictionary API reference`_) to limit choices + of this object to. Use this along with + ``meta.LazyDate`` to limit choices of objects + by date, for example:: + + limit_choices_to = {'pub_date__lte' : meta.LazyDate()} + + only allows the choice of related objects with a + ``pub_date`` before the current date/time to be + chosen. + + Not compatible with ``edit_inline``. + + ``lookup_overrides`` XXX FIXME XXX + + ``max_num_in_admin`` For inline-edited objects, this is the maximum + number of related objects to display in the admin. + Thus, if a pizza could only have up to 10 + toppings, ``max_num_in_admin=10`` would ensure + that a user never enters more than 10 toppings. + + Note that this doesn't ensure more than 10 related + toppings ever get created. + + ``min_num_in_admin`` The minimum number of related objects displayed in + the admin. Normally, at the creation stage + ``num_in_admin`` inline objects are shown, and at + the edit stage ``num_extra_on_change`` objects are + shown in addition to all pre-existing related + objects. However, no fewer than + ``min_num_in_admin`` related objects will ever be + displayed. + + ``num_extra_on_change`` The number of extra blank related object fields to + show at the change stage. + + ``num_in_admin`` The default number of inline objects to display + on the object page at the add stage. + + ``raw_id_admin`` Only display a field for the integer to be entered + instead of a drop-down menu. This is useful when + related to an object type that will have too many + rows to make a menu practical. + + Not used with ``edit_inline``. + + ``related_name`` The name to use for the relation from the related + object back to this one. For example, when if + ``Topping`` has this field:: + + meta.ForeignKey(Pizza) + + the ``related_name`` will be "topping" (taken from + the class name which will in turn give ``Pizza`` + methods like ``get_topping_list()`` and + ``get_topping_count()``. + + If you instead were to use:: + + meta.ForeignKey(Pizza, related_name="munchie") + + then the methods would be called + ``get_munchie_list()``, ``get_munchie_count()``, + etc. + + This is only really useful when you have a single + object that relates to the same object more than + once. For example, if a ``Story`` object has both + ``primary_category`` and ``secondary_category`` + fields, to make sure that the category objects + have the correct methods, you'd use fields like:: + + ... + meta.ForeignKey(Category, name="primary_category_id", + rel_name="primary_category", + related_name="primary_story"), + + meta.ForeignKey(Category, name="secondary_category_id", + rel_name="secondary_category", + related_name="secondary_story"), + ... + + which would give the category objects methods + named ``get_primary_story_list()`` and + ``get_secondary_story_list()``. + ======================= ================================================== + +.. _`Dictionary API reference`: http://www.djangoproject.com/FIXME/ + +``ManyToMany`` +-------------- + +XXX will this still exist given the changes to ManyToManyField? XXX + +``OneToOne`` +------------ + +Signifies a one-to-one relationship. This is most useful on the primary key +of an object when that object "extends" another object in some way. + +For example, if you are building a database of "places", you would build pretty +standard stuff like address, phone number, etc. in the database. If you then +wanted to build a database of restaurants on top of the places, instead of +repeating yourself and replicating those fields in the restaurants object, you +could make ``Restaurant`` have a ``OneToOne`` relation to ``Place`` (since +a restaurant "is-a" place). + +This has a few repercussions in the admin interface: + + * No selection interface is displayed on ``Restaurant`` pages; there will + be one (and only one) ``Restaurant`` for each place. + + * On the ``Restaurant`` change list, every single ``Place`` -- weather it + has an associated ``Restaurant`` or not -- will be displayed. Adding + a ``Restaurant`` to a ``Place`` just means filling out the required + ``Restaurant`` fields. + +Admin options +============= + +The ``admin`` field in the model tells Django how to construct the admin +interface for the object. The field is an instance of the ``meta.Admin`` +object, which has the following options (of which only ``fields`` is required): + +``date_hierarchy`` +------------------ + +To allow filtering of objects in the admin by date, set ``date_hierarchy`` +to the name of the field to filter by:: + + date_hierarchy = 'order_date' + +``fields`` +---------- + +A list of fieldsets to display on the admin page. Each fieldset is a 2-tuple: +``(name, field_options)``. The ``name`` is a string to name the field set, +and ``field_options`` is a dictionary of information about the fields to be +displayed in that fieldset. This dictionary has the following keys: + + ``fields`` + A tuple of field names to display in this fieldset. To display + multiple fields on the same line, wrap those fields in their + own tuple. + + This key is required in the dict. + + ``classes`` + Extra CSS classes to apply to the fieldset. This is a simple + string; you can apply multiple classes by separating them with + spaces. + + Two useful classes defined by the default stylesheet are ``collapse`` + and ``wide``. Fieldsets with the ``collapse`` style will be + initially collapsed in the admin and replaced with a small "click + to expand" link. Fieldsets with the ``wide`` style will be given + extra horizontal space. + +For example (taken from the ``core.flatfiles`` model):: + + fields = ( + (None, { + 'fields': ('url', 'title', 'content', 'sites') + }), + ('Advanced options', { + 'classes': 'collapse', + 'fields' : ('enable_comments', 'registration_required', 'template_name') + }), + ), + +results in an admin that looks like: + + .. image:: images/flatfiles_admin.png + +``js`` +------ + +Extra JavaScript files to link into the admin screen. This can be used to +tweak a given type of admin page in JS or to provide "quick links" to fill +in default values for certain fields. + +``list_display`` +---------------- + +List of fields to display on the list page in the admin. + +There are a few special cases that do other things besides displaying the +contents of the given fields: + + * If the field given has a relationship, that relationship is + followed and the ``repr()`` of the related object is displayed. + + * If the field is a ``BooleanField``, a "on" or "off" icon will + be displayed instead of ``True`` or ``False``. + + * If the field name given does not exist, a function of the model + will be searched for and called if present. This function + should have a ``short_description`` attribute that will be + used as the header for the field. + +See the exmaple below. + +``list_filter`` +--------------- + +List of fields to filter by. Each field should either be a ``BooleanField`` +or else a field with a ``ManyToOne`` relation. + +An example of how ``list_display`` and ``list_filter`` work (taken from +the ``auth.user`` model):: + + list_display = ('username', 'email', 'first_name', 'last_name', 'is_staff'), + list_filter = ('is_staff', 'is_superuser'), + +results in a admin that looks like: + + .. image:: images/users_changelist.png + +(This example also has ``search_fields`` defined; see below). + +``ordering`` +------------ + +An ordering tuple (see the `Options for models`_, above) that gives a +different ordering for the admin change list. If not given, the +model's default ordering will be used. + +``save_as`` +----------- + +Enables a "save as" feature on object pages. Normally, objects have +three save options: "Save", "Save and continue editing", and "Save +and add another". If ``save_as`` is ``True``, "Save and add another" +will be replaced by a "Save as" button. + +``save_on_top`` +--------------- + +If this option is ``True``, object pages will have the save buttons +across the top as well as at the bottom of the page. + +``search_fields`` +----------------- + +A list of fields to provide a text search for. These fields should, +obviously, be some kind of text field. + diff --git a/django-docs/templates.txt b/django-docs/templates.txt new file mode 100644 index 0000000000..72b863513c --- /dev/null +++ b/django-docs/templates.txt @@ -0,0 +1,804 @@ +============================ +The Django template language +============================ + +Django's template language is designed to strike a balance between power and +ease; it's designed to feel comfortable to those used to working with HTML. If +you have any exposure to other text-based template languages like Smarty_ or +CheetahTemplate_, you should feel right at home with Django's templates. + +.. _Smarty: http://smarty.php.net/ +.. _CheetahTemplate: http://www.cheetahtemplate.org/ + +What's a template? +================== + +A template is simply a text file. All Django templates by convention have +".html" extensions, but they can actually generate any text-based format (HTML, +XML, CSV, etc.). + +To actually be useful, a template will contain **variables**, which get replaced +with values from the database when the template is evaluated, and **tags**, +which control the logic of the template. + +Below is a minimal template that I'll be using to illustrate the parts of a template throughout this introduction:: + + {% extends base_generic %} + + {% block title %}{{ section.title }}{% endblock %} + + {% block content %} +

    {{ section.title }}

    + + {% for story in story_list %} +
    +

    {{ story.tease|truncatewords:"100" }}

    + {% endfor %} + {% endblock %} + +What's a variable? +================== + +Variables look like this: ``{{ variable }}``. When the template engine +encounters a variable, it evaluates that variable and replaces the variable with +the result. Many variables will be structures with named attributes; you can +"drill down" into these structures with dots (``.``), so in the above example `` +{{ section.title }}`` will be replaces with the ``title`` attribute of the +``section`` object. + +If you use a variable that doesn't exist, it will be silently ignored; the +variable will be replaced by nothingness. + +See `Using the built-in reference`_, below, for help on finding what variables +are available in a given template. + +Variables may be modified before being displayed by **filters**. + +What's a filter? +================ + +Filters look like this: ``{{ name|lower }}``. This display the value of the +``{{ name }}`` variable after being filtered through the ``lower`` filter which, +as you might have guessed, lowercases the text passed through it. + +We use the pipe character to apply filters to emphasize the analogy with filters +on a water pipe: text enters one side, has some operation performed on it, and +"flows" out the other side. Stretching the analogy to the breaking point, +filters may be "chained"; the output of one filter applied to the next: ``{{ +text|escape|linebreaks }}`` is a common idiom for escaping text contents and +then converting line breaks to ``

    `` tags. + +Certain filters take arguments; a filter argument looks like this: ``{{ +bio|truncatewords:"30" }}``. This will display the first 30 words of the +``bio`` variable. Filter arguments always are in double quotes. + +The `Built-in filter reference`_ below describes all the built-in filters. + +What's a tag? +============= + +Tags look like this: ``{% tag %}``. Tags are much more complex than variables: +some create text in the output; some control flow by performing loops, or logic; +some load external information into the template to be used by later variables. + +Some tags are "block" tags with matching beginning and ending tags (i.e. ``{% tag %} ... tag contents ... {% endtag %}``. The `Built-in tag reference`_ below describes all the built-in tags. + +Template Inheritance +==================== + +The most powerful -- and thus the most complex -- part of Django's template +engine is template inheritance. In a nutshell, template inheritance allows you +to build a base "skeleton" template that contains all the common elements of +your site and defines **blocks** that child templates can override. + +It's easiest to understand template inheritance by starting with an example:: + + + + + {% block title %}My Amazing Site{% endblock %} + + + +

    + +
    + {% block content %}{% endblock %} +
    + + +This template, which we'll call ``base.html`` defines a simple HTML skeleton +document that you might use for a simple two-column page. Since this template +won't actually be used directly, I've used the ``{% block %}`` tag to define the +three blocks that child templates will fill in. All that the ``block`` tag does +is to signal to the template engine that a child template may override those +portions of the template. + +To use this template, I might define a child template as follows:: + + {% extends "base" %} + + {% block title %}My Amazing Blog{% endblock %} + + {% block content %} + + {% for entry in blog_entries %} +

    {{ entry.title }}

    +

    {{ entry.body }}

    + {% endfor %} + + {% endblock %} + +The ``{% extends %}`` tag is the key here; it tells the template engine that +this template "extends" another template. When this template is evaluated, the +first step the template engine will perform is to locate the parent template -- +in this case, "base" (note the dropping of the ".html" extension). At that +point, the template engine will notice the three blocks in ``base.html``, and +replace those blocks with the contents of the child template. Depending on the +value of ``blog_entries``, the output might look like:: + + + + + My Amazing Blog + + + + + +
    +

    Entry one

    +

    This is my first entry.

    + +

    Entry two

    +

    This is my second entry.

    +
    + + +Note that since the child template did not define the ``sidebar`` block, the +value from the parent template is used instead. + +Template inheritance does not have to be only single-level; multi-level +inheritance is possible, and indeed, quite useful. + +Here are some tips for working with inheritance: + + * More ``{% block %}`` tags in your base templates are better. Remember, + child templates do not have to define all parent blocks, so you can + fill in reasonable defaults in a number of blocks, then only define + the ones you need later on. + + * If you find yourself reproducing the same content in a number of + documents, it probably means you should move that content to a + new ``{% block %}`` in a parent template. + + * We often prefer to use three-level inheritance: a single base template + for the entire site, a set of mid-level templates for each section of + the site, and then the individual templates for each page. This + maximizes code reuse, and makes adding items to places like the + section-wide navigation possible. + + * If you need to get the content of the block from the parent template, + the ``{{ block.super }}`` variable will do the trick. This is useful + if you want to add to the contents of a parent block instead of + completely overriding it. + +Using the built-in reference +============================ + +Since Django can be used to develop any sort of site, the tags, filters, and +variables available will be different depending on the application. To make it +simple to figure out what's available in a given site. + +This documentation is integrated into the administration interface for your +sites and is divided into 4 sections: tags, filters, models, and views. The +tags and filters sections describe all the built-in tags (in fact, the tag and +filter references below come directly from those pages) as well as any custom +tag or filter libraries available. + +The views page is perhaps the most valuable. Each URL in your site has a +separate entry here, and clicking on a URL will show you: + + * The name of the view function that generates that view. + * A short description of what the view does. + * The **context**, or each variable available in the view. + * The name of the template or templates that are used for that view. + +The documentation page also has a bookmarklet that you can use to jump from any +page to the documentation page for that view. + +Since most of Django revolves around database objects, the "models" section of +the documentation page describes each type of object in the system along with all +the fields available on that object. + +Take together, the documentation pages should tell you every tag, filter, +variable and object available to you in a given template. + +Custom tag and filter libraries +=============================== + +As mentioned above, certain applications will provide custom tag and filter +libraries. To use them, use the ``{% load %}`` tag:: + + {% load comments %} + + {% comment_form for blogs.entries entry.id with is_public yes %} + +In the above, the ``load`` tag loads the ``comments`` tag library, which then +makes the ``comment_form`` tag available for use. Consult the documentation +area in your admin to find the list of custom libraries in your installation. + +Built-in tag and filter reference +================================= + +For those without an admin site available, the reference for the stock tags and +filters follows. Since Django is highly customizable, the documentation +references in your admin should be considered the final word on these +tags/filters. + +Built-in tag reference +---------------------- + +block +````` + +Define a block that can be overridden by child templates. See `Template +inheritance`_ for more information. + +comment +``````` + +Ignore everything between ``{% comment %}`` and ``{% endcomment %}`` + +cycle +````` + +Cycle among the given strings each time this tag is encountered. + +Within a loop, cycles among the given strings each time through +the loop:: + + {% for o in some_list %} + + ... + + {% endfor %} + +Outside of a loop, give the values a unique name the first time you call it, +then use that name each successive time through:: + + ... + ... + ... + +You can use any number of values, separated by commas. Make sure not to put +spaces between the values -- only commas. + +debug +````` + +Output a whole load of debugging information, including the current context and +imported modules. + +extends +``````` + +Signal that this template extends a parent template. + +This tag may be used in two ways: ``{% extends "base" %}`` (with quotes) uses +the literal value "base" as the name of the parent template to extend, or ``{% +extends variable %}`` uses the value of ``variable`` as the name of the parent +template to extend. + +See `Template inheritance`_ for more information. + +filter +`````` + +Filter the contents of the blog through variable filters. + +Filters can also be piped through each other, and they can have arguments -- +just like in variable syntax. + +Sample usage:: + + {% filter escape|lower %} + This text will be HTML-escaped, and will appear in all lowercase. + {% endfilter %} + +firstof +``````` + +Outputs the first variable passed that is not False. Outputs nothing if all the +passed variables are False. + +Sample usage:: + + {% firstof var1 var2 var3 %} + +This is equivalent to:: + + {% if var1 %} + {{ var1 }} + {% else %}{% if var2 %} + {{ var2 }} + {% else %}{% if var3 %} + {{ var3 }} + {% endif %}{% endif %}{% endif %} + +but obviously much cleaner! + +for +``` + +Loop over each item in an array. For example, to display a list of athletes +given ``athlete_list``:: + +
      + {% for athlete in athlete_list %} +
    • {{ athlete.name }}
    • + {% endfor %} +
    + +You can also loop over a list in reverse by using ``{% for obj in list reversed %}``. + +The for loop sets a number of variables available within the loop: + + ========================== ================================================ + Variable Description + ========================== ================================================ + ``forloop.counter`` The current iteration of the loop (1-indexed) + ``forloop.counter0`` The current iteration of the loop (0-indexed) + ``forloop.first`` True if this is the first time through the loop + ``forloop.last`` True if this is the last time through the loop + ``forloop.parentloop`` For nested loops, this is the loop "above" the + current one + ========================== ================================================ + +if +`` + +The ``{% if %}`` tag evaluates a variable, and if that variable is "true" (i.e. +exists, is not empty, and is not a false boolean value) the contents of the +block are output:: + + {% if athlete_list %} + Number of athletes: {{ athlete_list|count }} + {% else %} + No athletes. + {% endif %} + +In the above, if ``athlete_list`` is not empty, the number of athletes will be +displayed by the ``{{ athlete_list|count }}`` variable. + +As you can see, the ``if`` tag can take an option ``{% else %}`` clause that +will be displayed if the test fails. + +``if`` tags may use ``or`` or ``not`` to test a number of variables or to negate +a given variable:: + + {% if not athlete_list %} + There are no athletes. + {% endif %} + + {% if athlete_list or coach_list %} + There are some athletes or some coaches. + {% endif %} + + {% if not athlete_list or coach_list %} + There are no athletes or there are some coaches (OK, so + writing English translations of boolean logic sounds + stupid; it's not my fault). + {% endif %} + +For simplicity, ``if`` tags do not allow ``and`` clauses; use nested ``if`` +tags instead:: + + {% if athlete_list %} + {% if coach_list %} + Number of athletes: {{ athlete_list|count }}. + Number of coaches: {{ coach_list|count }}. + {% endif %} + {% endif %} + +ifchanged +````````` + +Check if a value has changed from the last iteration of a loop. + +The 'ifchanged' block tag is used within a loop. It checks its own rendered +contents against its previous state and only displays its content if the value +has changed:: + +

    Archive for {{ year }}

    + + {% for date in days %} + {% ifchanged %}

    {{ date|date:"F" }}

    {% endifchanged %} + {{ date|date:"j" }} + {% endfor %} + +ifnotequal +`````````` + +Output the contents of the block if the two arguments do not equal each other. + +Example:: + + {% ifnotequal user.id_ comment.user_id %} + ... + {% endifnotequal %} + +load +```` + +Load a custom template tag set. + +See `Custom tag and filter libraries`_ for more information. + +now +``` + +Display the date, formatted according to the given string. + +Uses the same format as PHP's ``date()`` function; see http://php.net/date +for all the possible values. + +Sample usage:: + + It is {% now "jS F Y H:i" %} + +regroup +``````` + +Regroup a list of alike objects by a common attribute. + +This complex tag is best illustrated by use of an example: say that ``people`` +is a list of ``Person`` objects that have ``first_name``, ``last_name``, and +``gender`` attributes, and you'd like to display a list that looks like: + + * Male: + * George Bush + * Bill Clinton + * Female: + * Margaret Thatcher + * Colendeeza Rice + * Unknown: + * Janet Reno + +The following snippet of template code would accomplish this dubious task:: + + {% regroup people by gender as grouped %} +
      + {% for group in grouped %} +
    • {{ group.grouper }} +
        + {% for item in group.list %} +
      • {{ item }}
      • + {% endfor %} +
      + {% endfor %} +
    + +As you can see, ``{% regroup %}`` populates a variable with a list of objects +with ``grouper`` and ``list`` attributes. ``grouper`` contains the item that +was grouped by; ``list`` contains the list of objects that share that +``grouper``. In this case, ``grouper`` would be ``Male``, ``Female`` and +``Unknown``, and ``list`` is the list of people with those genders. + +Note that ``{% regroup %}`` does not work when the list to be grouped is not +sorted by the key you are grouping by! This means that if your list of people +was not sorted by gender, you'd need to make sure it is sorted before using it, +i.e.:: + + {% regroup people|dictsort:"gender" by gender as grouped %} + +ssi +``` + +Output the contents of a given file into the page. + +Like a simple "include" tag, the ``ssi`` tag includes the contents +of another file -- which must be specified using an absolute page -- +in the current page:: + + {% ssi /home/html/ljworld.com/includes/right_generic.html %} + +If the optional "parsed" parameter is given, the contents of the included +file are evaluated as template code, with the current context:: + + {% ssi /home/html/ljworld.com/includes/right_generic.html parsed %} + +templatetag +``````````` + +Output one of the bits used to compose template tags. + +Since the template system has no concept of "escaping", to display one of the +bits used in template tags, you must use the ``{% templatetag %}`` tag. + +The argument tells which template bit to output: + + ================== ======= + Argument Outputs + ================== ======= + ``openblock`` ``{%`` + ``closeblock`` ``%}`` + ``openvariable`` ``{{`` + ``closevariable`` ``}}`` + ================== ======= + +widthratio +`````````` + +For creating bar charts and such, this tag calculates the ratio of a given value +to a maximum value, and then applies that ratio to a constant. + +For example:: + + + +Above, if ``this_value`` is 175 and ``max_value`` is 200, the the image in the +above example will be 88 pixels wide (because 175/200 = .875; .875 * 100 = 87.5 +which is rounded up to 88). + +Built-in filter reference +------------------------- + +add +``` +Adds the arg to the value + +addslashes +`````````` +Adds slashes - useful for passing strings to JavaScript, for example. + +capfirst +```````` +Capitalizes the first character of the value + +center +`````` +Centers the value in a field of a given width + +cut +``` +Removes all values of arg from the given string + +date +```` +Formats a date according to the given format (same as the now_ tag) + +default +``````` +If value is unavailable, use given default + +dictsort +```````` +Takes a list of dicts, returns that list sorted by the property given in the +argument. + +dictsortreversed +```````````````` +Takes a list of dicts, returns that list sorted in reverse order by the property +given in the argument. + +divisibleby +``````````` +Returns true if the value is divisible by the argument + +escape +`````` +Escapes a string's HTML + +filesizeformat +`````````````` +Format the value like a 'human-readable' file size (i.e. 13 KB, 4.1 MB, 102 +bytes, etc). + +first +````` +Returns the first item in a list + +fix_ampersands +`````````````` +Replaces ampersands with ``&`` entities + +floatformat +``````````` +Displays a floating point number as 34.2 (with one decimal places) - but +only if there's a point to be displayed + +get_digit +````````` +Given a whole number, returns the requested digit of it, where 1 is the +right-most digit, 2 is the second-right-most digit, etc. Returns the +original value for invalid input (if input or argument is not an integer, +or if argument is less than 1). Otherwise, output is always an integer. + +join +```` +Joins a list with a string, like Python's ``str.join(list)`` + +length +`````` +Returns the length of the value - useful for lists + +length_is +````````` +Returns a boolean of whether the value's length is the argument + +linebreaks +`````````` +Converts newlines into

    and
    s + +linebreaksbr +```````````` +Converts newlines into
    s + +linenumbers +``````````` +Displays text with line numbers + +ljust +````` +Left-aligns the value in a field of a given width + +Argument: field size + +lower +````` +Converts a string into all lowercase + +make_list +````````` +Returns the value turned into a list. For an integer, it's a list of +digits. For a string, it's a list of characters. + +phone2numeric +````````````` +Takes a phone number and converts it in to its numerical equivalent + +pluralize +````````` +Returns 's' if the value is not 1, for '1 vote' vs. '2 votes' + +pprint +`````` +A wrapper around pprint.pprint -- for debugging, really + +random +`````` +Returns a random item from the list + +removetags +``````````` +Removes a space separated list of [X]HTML tags from the output + +rjust +````` +Right-aligns the value in a field of a given width + +Argument: field size + +slice +````` +Returns a slice of the list. + +Uses the same syntax as Python's list slicing; see +http://diveintopython.org/native_data_types/lists.html#odbchelper.list.slice +for an introduction. + +slugify +``````` +Converts to lowercase, removes non-alpha chars and converts spaces to hyphens + +stringformat +```````````` +Formats the variable according to the argument, a string formatting specifier. +This specifier uses Python string formating syntax, with the exception that +the leading "%" is dropped. + +See http://docs.python.org/lib/typesseq-strings.html for documentation +of Python string formatting + +striptags +````````` +Strips all [X]HTML tags + +time +```` +Formats a time according to the given format (same as the now_ tag). + +timesince +````````` +Formats a date as the time since that date (i.e. "4 days, 6 hours") + +title +````` +Converts a string into titlecase + +truncatewords +````````````` +Truncates a string after a certain number of words + +Argument: Number of words to truncate after + +unordered_list +`````````````` +Recursively takes a self-nested list and returns an HTML unordered list -- +WITHOUT opening and closing

      tags. + +The list is assumed to be in the proper format. For example, if ``var`` contains +``['States', [['Kansas', [['Lawrence', []], ['Topeka', []]]], ['Illinois', []]]]``, +then ``{{ var|unordered_list }}`` would return:: + +
    • States +
        +
      • Kansas +
          +
        • Lawrence
        • +
        • Topeka
        • +
        +
      • +
      • Illinois
      • +
      +
    • + +upper +````` +Converts a string into all uppercase + +urlencode +````````` +Escapes a value for use in a URL + +urlize +`````` +Converts URLs in plain text into clickable links + +urlizetrunc +``````````` +Converts URLs into clickable links, truncating URLs to the given character limit + +Argument: Length to truncate URLs to. + +wordcount +````````` +Returns the number of words + +wordwrap +```````` +Wraps words at specified line length + +Argument: number of words to wrap the text at. + +yesno +````` +Given a string mapping values for true, false and (optionally) None, +returns one of those strings according to the value: + +========== ====================== ================================== +Value Argument Outputs +========== ====================== ================================== +``True`` ``"yeah,no,maybe"`` ``yeah`` +``False`` ``"yeah,no,maybe"`` ``no`` +``None`` ``"yeah,no,maybe"`` ``maybe`` +``None`` ``"yeah,no"`` ``"no"`` (converts None to False + if no mapping for None is given. +========== ====================== ================================== diff --git a/django-docs/writing-apps-guide-outline.txt b/django-docs/writing-apps-guide-outline.txt new file mode 100644 index 0000000000..a2d8c7e010 --- /dev/null +++ b/django-docs/writing-apps-guide-outline.txt @@ -0,0 +1,15 @@ +- Getting started + - The application package structure + - INSTALLED_APPS + - Each step, explained tersely +- Writing models + - The model + - Admin specification +- Initializing the database + - Custom SQL +- Views + - URL dispatch + - View functions + - Request object + - Response objects +- Custom template tags/filters

    + + {{ story.headline|upper }} + +