ÿØÿàJFIFÿþ ÿÛC       ÿÛC ÿÀÿÄÿÄ"#QrÿÄÿÄ&1!A"2qQaáÿÚ ?Øy,æ/3JæÝ¹È߲؋5êXw²±ÉyˆR”¾I0ó2—PI¾IÌÚiMö¯–þrìN&"KgX:Šíµ•nTJnLK„…@!‰-ý ùúmë;ºgµŒ&ó±hw’¯Õ@”Ü— 9ñ-ë.²1<yà‚¹ïQÐU„ہ?.’¦èûbß±©Ö«Âw*VŒ) `$‰bØÔŸ’ëXÖ-ËTÜíGÚ3ð«g Ÿ§¯—Jx„–’U/ÂÅv_s(Hÿ@TñJÑãõçn­‚!ÈgfbÓc­:él[ðQe 9ÀPLbÃãCµm[5¿ç'ªjglå‡Ûí_§Úõl-;"PkÞÞÁQâ¼_Ñ^¢SŸx?"¸¦ùY騐ÒOÈ q’`~~ÚtËU¹CڒêV  I1Áß_ÿÙ oQ+Pc@sddlmZddlmZddlmZmZdeefdYZdefdYZdefd YZ d e fd YZ d e fd YZ dS(i(t BaseElement(tXLink(tstrlistt is_stringtSetc BsteZdZdZddZdZddZdddddZdddddddddZ dZ RS( s The **set** element provides a simple means of just setting the value of an attribute for a specified duration. It supports all attribute types, including those that cannot reasonably be interpolated, such as string and boolean values. The **set** element is non-additive. The additive and accumulate attributes are not allowed, and will be ignored if specified. tsetcKs6tt|j||dk r2|j|ndS(s Set constructor. :param href: target svg element, if **href** is not `None`; else the target SVG Element is the parent SVG Element. N(tsuperRt__init__tNonetset_href(tselfthreftextra((sA/opt/alt/python27/lib/python2.7/site-packages/svgwrite/animate.pyRs cCs|jtt|jS(N(t update_idRRtget_xml(R ((sA/opt/alt/python27/lib/python2.7/site-packages/svgwrite/animate.pyR s cCs'||d<|dk r#||d`) tfreezetfillN((R ((sA/opt/alt/python27/lib/python2.7/site-packages/svgwrite/animate.pyR SsN( t__name__t __module__t__doc__t elementnameRRRRRRR (((sA/opt/alt/python27/lib/python2.7/site-packages/svgwrite/animate.pyR s  t AnimateMotioncBs8eZdZdZdddZdddddZRS(s` The **animateMotion** element causes a referenced element to move along a motion path. t animateMotioncKs9tt|jd|||dk r5||d` or a python `list` :param href: target svg element, if **href** is not `None`; else the target SVG Element is the parent SVG Element. R N(RR-RRR,R(R RtvaluesR R ((sA/opt/alt/python27/lib/python2.7/site-packages/svgwrite/animate.pyR{s   cCs|d k r7t|s*t|d}n||d sK+