SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > > site-packages > svgwrite


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/cloudlinux/venv/lib64/python3.11//site-packages/svgwrite

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
data Directory - -
extensions Directory - -
__init__.py File 2506 bytes April 17 2025 13:10:58.
animate.py File 6663 bytes April 17 2025 13:10:58.
base.py File 8624 bytes April 17 2025 13:10:58.
container.py File 10741 bytes April 17 2025 13:10:58.
drawing.py File 5291 bytes April 17 2025 13:10:58.
elementfactory.py File 2297 bytes April 17 2025 13:10:58.
etree.py File 1361 bytes April 17 2025 13:10:58.
filters.py File 8002 bytes April 17 2025 13:10:58.
gradients.py File 4702 bytes April 17 2025 13:10:58.
image.py File 2493 bytes April 17 2025 13:10:58.
masking.py File 1856 bytes April 17 2025 13:10:58.
mixins.py File 10749 bytes April 17 2025 13:10:58.
params.py File 1903 bytes April 17 2025 13:10:58.
path.py File 2848 bytes April 17 2025 13:10:58.
pattern.py File 1973 bytes April 17 2025 13:10:58.
shapes.py File 5310 bytes April 17 2025 13:10:58.
solidcolor.py File 1734 bytes April 17 2025 13:10:58.
text.py File 8138 bytes April 17 2025 13:10:58.
utils.py File 7421 bytes April 17 2025 13:10:58.
validator2.py File 6205 bytes April 17 2025 13:10:58.
version.py File 1119 bytes April 17 2025 13:10:58.

Reading File: //opt/cloudlinux/venv/lib64/python3.11//site-packages/svgwrite/path.py

#coding:utf-8
# Author:  mozman
# Purpose: svg path element
# Created: 08.09.2010
# License: MIT License

from svgwrite.base import BaseElement
from svgwrite.utils import strlist
from svgwrite.mixins import Presentation, Markers, Transform


class Path(BaseElement, Transform, Presentation, Markers):
    """ The <path> element represent the outline of a shape which can be filled,
    stroked, used as a clipping path, or any combination of the three.

    """
    elementname = 'path'

    def __init__(self, d=None, **extra):
        """
        :param `iterable` d: *coordinates*, *length* and *commands*
        :param dict attribs: additional SVG attributes
        :param extra: additional SVG attributes as keyword-arguments

        """
        super(Path, self).__init__(**extra)
        self.commands = []
        self.push(d)
        if self.debug:
            self.validator.check_all_svg_attribute_values(self.elementname, self.attribs)

    def push(self, *elements):
        """ Push commands and coordinates onto the command stack.

        :param `iterable` elements: *coordinates*, *length* and *commands*

        """
        self.commands.extend(elements)

    @staticmethod
    def arc_flags(large_arc=True, angle_dir='+'):
        large_arc_flag = int(large_arc)
        sweep_flag = {'+': 1, '-': 0}[angle_dir]
        return "%d,%d" % (large_arc_flag, sweep_flag)

    def push_arc(self, target, rotation, r, large_arc=True, angle_dir='+', absolute=False):
        """ Helper function for the elliptical-arc command.

        see SVG-Reference: http://www.w3.org/TR/SVG11/paths.html#PathData

        :param 2-tuple target: *coordinate* of the arc end point
        :param number rotation: x-axis-rotation of the ellipse in degrees
        :param number|2-tuple r: radii rx, ry when r is a *2-tuple* or rx=ry=r if r is a *number*
        :param bool large_arc: draw the arc sweep of greater than or equal to 180 degrees (**large-arc-flag**)
        :param angle_dir: ``'+|-'`` ``'+'`` means the arc will be drawn in a "positive-angle" direction (**sweep-flag**)
        :param bool absolute: indicates that target *coordinates* are absolute else they are relative to the current point

        """
        self.push({True: 'A', False: 'a'}[absolute])
        if isinstance(r, (float, int)):
            self.push(r, r)
        else:
            self.push(r)
        self.push(rotation)
        self.push(Path.arc_flags(large_arc, angle_dir))
        self.push(target)

    def get_xml(self):
        """ Get the XML representation as `ElementTree` object.

        :return: XML `ElementTree` of this object and all its subelements

        """
        self.attribs['d'] = str(strlist(self.commands, ' '))
        return super(Path, self).get_xml()

SILENT KILLER Tool