a
    db$                     @   s>   d Z ddlZdgZedZdd Zdd Zedkr:e  dS )	z!
Generic dylib path manipulation
    N
dylib_infoz(?x)
(?P<location>^.*)(?:^|/)
(?P<name>
    (?P<shortname>\w+?)
    (?:\.(?P<version>[^._]+))?
    (?:_(?P<suffix>[^._]+))?
    \.dylib$
)
c                 C   s   t | }|sdS | S )a1  
    A dylib name can take one of the following four forms:
        Location/Name.SomeVersion_Suffix.dylib
        Location/Name.SomeVersion.dylib
        Location/Name_Suffix.dylib
        Location/Name.dylib

    returns None if not found or a mapping equivalent to:
        dict(
            location='Location',
            name='Name.SomeVersion_Suffix.dylib',
            shortname='Name',
            version='SomeVersion',
            suffix='Suffix',
        )

    Note that SomeVersion and Suffix are optional and may be None
    if not present.
    N)DYLIB_REmatch	groupdict)filenameZis_dylib r   X/home/tom/ab/renpy-build/tmp/install.linux-x86_64/lib/python3.9/ctypes/macholib/dylib.pyr      s    
c                  C   s   ddd} t dd u sJ t dd u s*J t d| dddksBJ t d	| dd
dddks^J t d| ddddksxJ t d| ddddksJ t d| dddddksJ d S )Nc                 S   s   t | ||||dS )NlocationnameZ	shortnameversionsuffix)dictr	   r   r   r   d.   s    ztest_dylib_info.<locals>.dzcompletely/invalidzcompletely/invalide_debugzP/Foo.dylibPz	Foo.dylibZFoozP/Foo_debug.dylibzFoo_debug.dylibdebug)r   zP/Foo.A.dylibzFoo.A.dylibAzP/Foo_debug.A.dylibzFoo_debug.A.dylibZ	Foo_debugzP/Foo.A_debug.dylibzFoo.A_debug.dylib)NNNNN)r   )r   r   r   r   test_dylib_info-   s    
r   __main__)__doc__re__all__compiler   r   r   __name__r   r   r   r   <module>   s   

