METADATA 78 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609
  1. Metadata-Version: 2.4
  2. Name: yarl
  3. Version: 1.23.0
  4. Summary: Yet another URL library
  5. Home-page: https://github.com/aio-libs/yarl
  6. Author: Andrew Svetlov
  7. Author-email: andrew.svetlov@gmail.com
  8. Maintainer: aiohttp team <team@aiohttp.org>
  9. Maintainer-email: team@aiohttp.org
  10. License: Apache-2.0
  11. Project-URL: Chat: Matrix, https://matrix.to/#/#aio-libs:matrix.org
  12. Project-URL: Chat: Matrix Space, https://matrix.to/#/#aio-libs-space:matrix.org
  13. Project-URL: CI: GitHub Workflows, https://github.com/aio-libs/yarl/actions?query=branch:master
  14. Project-URL: Code of Conduct, https://github.com/aio-libs/.github/blob/master/CODE_OF_CONDUCT.md
  15. Project-URL: Coverage: codecov, https://codecov.io/github/aio-libs/yarl
  16. Project-URL: Docs: Changelog, https://yarl.aio-libs.org/en/latest/changes/
  17. Project-URL: Docs: RTD, https://yarl.aio-libs.org
  18. Project-URL: GitHub: issues, https://github.com/aio-libs/yarl/issues
  19. Project-URL: GitHub: repo, https://github.com/aio-libs/yarl
  20. Keywords: cython,cext,yarl
  21. Classifier: Development Status :: 5 - Production/Stable
  22. Classifier: Intended Audience :: Developers
  23. Classifier: Programming Language :: Cython
  24. Classifier: Programming Language :: Python
  25. Classifier: Programming Language :: Python :: 3
  26. Classifier: Programming Language :: Python :: 3.10
  27. Classifier: Programming Language :: Python :: 3.11
  28. Classifier: Programming Language :: Python :: 3.12
  29. Classifier: Programming Language :: Python :: 3.13
  30. Classifier: Programming Language :: Python :: 3.14
  31. Classifier: Topic :: Internet :: WWW/HTTP
  32. Classifier: Topic :: Software Development :: Libraries :: Python Modules
  33. Requires-Python: >=3.10
  34. Description-Content-Type: text/x-rst
  35. License-File: LICENSE
  36. License-File: NOTICE
  37. Requires-Dist: idna>=2.0
  38. Requires-Dist: multidict>=4.0
  39. Requires-Dist: propcache>=0.2.1
  40. Dynamic: license-file
  41. yarl
  42. ====
  43. The module provides handy URL class for URL parsing and changing.
  44. .. image:: https://github.com/aio-libs/yarl/workflows/CI/badge.svg
  45. :target: https://github.com/aio-libs/yarl/actions?query=workflow%3ACI
  46. :align: right
  47. .. image:: https://codecov.io/gh/aio-libs/yarl/graph/badge.svg?flag=pytest
  48. :target: https://app.codecov.io/gh/aio-libs/yarl?flags[]=pytest
  49. :alt: Codecov coverage for the pytest-driven measurements
  50. .. image:: https://img.shields.io/endpoint?url=https://codspeed.io/badge.json
  51. :target: https://codspeed.io/aio-libs/yarl
  52. .. image:: https://badge.fury.io/py/yarl.svg
  53. :target: https://badge.fury.io/py/yarl
  54. .. image:: https://readthedocs.org/projects/yarl/badge/?version=latest
  55. :target: https://yarl.aio-libs.org
  56. .. image:: https://img.shields.io/pypi/pyversions/yarl.svg
  57. :target: https://pypi.python.org/pypi/yarl
  58. .. image:: https://img.shields.io/matrix/aio-libs:matrix.org?label=Discuss%20on%20Matrix%20at%20%23aio-libs%3Amatrix.org&logo=matrix&server_fqdn=matrix.org&style=flat
  59. :target: https://matrix.to/#/%23aio-libs:matrix.org
  60. :alt: Matrix Room — #aio-libs:matrix.org
  61. .. image:: https://img.shields.io/matrix/aio-libs-space:matrix.org?label=Discuss%20on%20Matrix%20at%20%23aio-libs-space%3Amatrix.org&logo=matrix&server_fqdn=matrix.org&style=flat
  62. :target: https://matrix.to/#/%23aio-libs-space:matrix.org
  63. :alt: Matrix Space — #aio-libs-space:matrix.org
  64. Introduction
  65. ------------
  66. Url is constructed from ``str``:
  67. .. code-block:: pycon
  68. >>> from yarl import URL
  69. >>> url = URL('https://www.python.org/~guido?arg=1#frag')
  70. >>> url
  71. URL('https://www.python.org/~guido?arg=1#frag')
  72. All url parts: *scheme*, *user*, *password*, *host*, *port*, *path*,
  73. *query* and *fragment* are accessible by properties:
  74. .. code-block:: pycon
  75. >>> url.scheme
  76. 'https'
  77. >>> url.host
  78. 'www.python.org'
  79. >>> url.path
  80. '/~guido'
  81. >>> url.query_string
  82. 'arg=1'
  83. >>> url.query
  84. <MultiDictProxy('arg': '1')>
  85. >>> url.fragment
  86. 'frag'
  87. All url manipulations produce a new url object:
  88. .. code-block:: pycon
  89. >>> url = URL('https://www.python.org')
  90. >>> url / 'foo' / 'bar'
  91. URL('https://www.python.org/foo/bar')
  92. >>> url / 'foo' % {'bar': 'baz'}
  93. URL('https://www.python.org/foo?bar=baz')
  94. Strings passed to constructor and modification methods are
  95. automatically encoded giving canonical representation as result:
  96. .. code-block:: pycon
  97. >>> url = URL('https://www.python.org/шлях')
  98. >>> url
  99. URL('https://www.python.org/%D1%88%D0%BB%D1%8F%D1%85')
  100. Regular properties are *percent-decoded*, use ``raw_`` versions for
  101. getting *encoded* strings:
  102. .. code-block:: pycon
  103. >>> url.path
  104. '/шлях'
  105. >>> url.raw_path
  106. '/%D1%88%D0%BB%D1%8F%D1%85'
  107. Human readable representation of URL is available as ``.human_repr()``:
  108. .. code-block:: pycon
  109. >>> url.human_repr()
  110. 'https://www.python.org/шлях'
  111. For full documentation please read https://yarl.aio-libs.org.
  112. Installation
  113. ------------
  114. ::
  115. $ pip install yarl
  116. The library is Python 3 only!
  117. PyPI contains binary wheels for Linux, Windows and MacOS. If you want to install
  118. ``yarl`` on another operating system where wheels are not provided,
  119. the tarball will be used to compile the library from
  120. the source code. It requires a C compiler and and Python headers installed.
  121. To skip the compilation you must explicitly opt-in by using a PEP 517
  122. configuration setting ``pure-python``, or setting the ``YARL_NO_EXTENSIONS``
  123. environment variable to a non-empty value, e.g.:
  124. .. code-block:: console
  125. $ pip install yarl --config-settings=pure-python=false
  126. Please note that the pure-Python (uncompiled) version is much slower. However,
  127. PyPy always uses a pure-Python implementation, and, as such, it is unaffected
  128. by this variable.
  129. Dependencies
  130. ------------
  131. YARL requires multidict_ and propcache_ libraries.
  132. API documentation
  133. ------------------
  134. The documentation is located at https://yarl.aio-libs.org.
  135. Why isn't boolean supported by the URL query API?
  136. -------------------------------------------------
  137. There is no standard for boolean representation of boolean values.
  138. Some systems prefer ``true``/``false``, others like ``yes``/``no``, ``on``/``off``,
  139. ``Y``/``N``, ``1``/``0``, etc.
  140. ``yarl`` cannot make an unambiguous decision on how to serialize ``bool`` values because
  141. it is specific to how the end-user's application is built and would be different for
  142. different apps. The library doesn't accept booleans in the API; a user should convert
  143. bools into strings using own preferred translation protocol.
  144. Comparison with other URL libraries
  145. ------------------------------------
  146. * furl (https://pypi.python.org/pypi/furl)
  147. The library has rich functionality but the ``furl`` object is mutable.
  148. I'm afraid to pass this object into foreign code: who knows if the
  149. code will modify my url in a terrible way while I just want to send URL
  150. with handy helpers for accessing URL properties.
  151. ``furl`` has other non-obvious tricky things but the main objection
  152. is mutability.
  153. * URLObject (https://pypi.python.org/pypi/URLObject)
  154. URLObject is immutable, that's pretty good.
  155. Every URL change generates a new URL object.
  156. But the library doesn't do any decode/encode transformations leaving the
  157. end user to cope with these gory details.
  158. Source code
  159. -----------
  160. The project is hosted on GitHub_
  161. Please file an issue on the `bug tracker
  162. <https://github.com/aio-libs/yarl/issues>`_ if you have found a bug
  163. or have some suggestion in order to improve the library.
  164. Discussion list
  165. ---------------
  166. *aio-libs* google group: https://groups.google.com/forum/#!forum/aio-libs
  167. Feel free to post your questions and ideas here.
  168. Authors and License
  169. -------------------
  170. The ``yarl`` package is written by Andrew Svetlov.
  171. It's *Apache 2* licensed and freely available.
  172. .. _GitHub: https://github.com/aio-libs/yarl
  173. .. _multidict: https://github.com/aio-libs/multidict
  174. .. _propcache: https://github.com/aio-libs/propcache
  175. =========
  176. Changelog
  177. =========
  178. ..
  179. You should *NOT* be adding new change log entries to this file, this
  180. file is managed by towncrier. You *may* edit previous change logs to
  181. fix problems like typo corrections or such.
  182. To add a new change log entry, please see
  183. https://pip.pypa.io/en/latest/development/#adding-a-news-entry
  184. we named the news folder "changes".
  185. WARNING: Don't drop the next directive!
  186. .. towncrier release notes start
  187. 1.23.0
  188. ======
  189. *(2025-12-16)*
  190. Features
  191. --------
  192. - Added support for ``pydantic``, the ``~yarl.URL`` could be used as a
  193. field type in ``pydantic`` models seamlessly.
  194. *Related issues and pull requests on GitHub:*
  195. `#1607 <https://github.com/aio-libs/yarl/issues/1607>`__.
  196. Packaging updates and notes for downstreams
  197. -------------------------------------------
  198. - The CI has been set up to notify Codecov about upload completion
  199. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  200. With this, Codecov no longer needs to guess whether it received all
  201. the intended coverage reports or not.
  202. *Related issues and pull requests on GitHub:*
  203. `#1577 <https://github.com/aio-libs/yarl/issues/1577>`__.
  204. - The in-tree build backend allows the end-users appending
  205. ``CFLAGS`` and ``LDFLAGS`` by setting respective environment
  206. variables externally.
  207. It additionally sets up default compiler flags to perform
  208. building with maximum optimization in release mode. This
  209. makes the resulting artifacts shipped to PyPI smaller.
  210. When line tracing is requested, the compiler and linker
  211. flags are configured to include as much information as
  212. possible for debugging and coverage tracking. The
  213. development builds are therefore smaller.
  214. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__
  215. *Related issues and pull requests on GitHub:*
  216. `#1586 <https://github.com/aio-libs/yarl/issues/1586>`__.
  217. - The `PEP 517 <https://peps.python.org/pep-517>`__ build backend now supports a new config
  218. setting for controlling whether to build the project in-tree
  219. or in a temporary directory. It only affects wheels and is
  220. set up to build in a temporary directory by default. It does
  221. not affect editable wheel builds — they will keep being
  222. built in-tree regardless.
  223. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__
  224. Here's an example of using this setting:
  225. .. code-block:: console
  226. $ python -m build \
  227. --config-setting=build-inplace=true
  228. *Related issues and pull requests on GitHub:*
  229. `#1590 <https://github.com/aio-libs/yarl/issues/1590>`__.
  230. - Starting this version, when building the wheels is happening
  231. in an automatically created temporary directory, the build
  232. backend makes an effort to normalize the respective file
  233. system path to a deterministic source checkout directory.
  234. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__
  235. It does so by injecting the ``-ffile-prefix-map`` compiler
  236. option into the ``CFLAGS`` environment variable as suggested
  237. by known `reproducible build practices
  238. <https://reproducible-builds.org/docs/build-path/>`__.
  239. The effect is that downstreams will get more reproducible
  240. build results.
  241. *Related issues and pull requests on GitHub:*
  242. `#1591 <https://github.com/aio-libs/yarl/issues/1591>`__.
  243. - Dropped Python 3.9 support; Python 3.10 is the minimal supported Python version
  244. -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  245. *Related issues and pull requests on GitHub:*
  246. `#1609 <https://github.com/aio-libs/yarl/issues/1609>`__.
  247. Contributor-facing changes
  248. --------------------------
  249. - The deprecated license classifier was removed from ``setup.cfg``
  250. -- by `@yegorich <https://github.com/sponsors/yegorich>`__.
  251. *Related issues and pull requests on GitHub:*
  252. `#1550 <https://github.com/aio-libs/yarl/issues/1550>`__.
  253. - The in-tree build backend allows the end-users appending
  254. ``CFLAGS`` and ``LDFLAGS`` by setting respective environment
  255. variables externally.
  256. It additionally sets up default compiler flags to perform
  257. building with maximum optimization in release mode. This
  258. makes the resulting artifacts shipped to PyPI smaller.
  259. When line tracing is requested, the compiler and linker
  260. flags are configured to include as much information as
  261. possible for debugging and coverage tracking. The
  262. development builds are therefore smaller.
  263. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__
  264. *Related issues and pull requests on GitHub:*
  265. `#1586 <https://github.com/aio-libs/yarl/issues/1586>`__.
  266. - The CI has been updated to consistently benchmark optimized
  267. release builds -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  268. When the release workflow is triggered, the pre-built wheels
  269. ready to hit PyPI are being tested. Otherwise, the job
  270. builds the project from source, while the rest of the
  271. workflow uses debug builds for line tracing and coverage
  272. collection.
  273. *Related issues and pull requests on GitHub:*
  274. `#1587 <https://github.com/aio-libs/yarl/issues/1587>`__.
  275. ----
  276. 1.22.0
  277. ======
  278. *(2025-10-05)*
  279. Features
  280. --------
  281. - Added arm64 Windows wheel builds
  282. -- by `@finnagin <https://github.com/sponsors/finnagin>`__.
  283. *Related issues and pull requests on GitHub:*
  284. `#1516 <https://github.com/aio-libs/yarl/issues/1516>`__.
  285. ----
  286. 1.21.0
  287. ======
  288. *(2025-10-05)*
  289. Contributor-facing changes
  290. --------------------------
  291. - The ``reusable-cibuildwheel.yml`` workflow has been refactored to
  292. be more generic and ``ci-cd.yml`` now holds all the configuration
  293. toggles -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  294. *Related issues and pull requests on GitHub:*
  295. `#1535 <https://github.com/aio-libs/yarl/issues/1535>`__.
  296. - When building wheels, the source distribution is now passed directly
  297. to the ``cibuildwheel`` invocation -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  298. *Related issues and pull requests on GitHub:*
  299. `#1536 <https://github.com/aio-libs/yarl/issues/1536>`__.
  300. - Added CI for Python 3.14 -- by `@kumaraditya303 <https://github.com/sponsors/kumaraditya303>`__.
  301. *Related issues and pull requests on GitHub:*
  302. `#1560 <https://github.com/aio-libs/yarl/issues/1560>`__.
  303. ----
  304. 1.20.1
  305. ======
  306. *(2025-06-09)*
  307. Bug fixes
  308. ---------
  309. - Started raising a ``ValueError`` exception raised for corrupted
  310. IPv6 URL values.
  311. These fixes the issue where exception ``IndexError`` was
  312. leaking from the internal code because of not being handled and
  313. transformed into a user-facing error. The problem was happening
  314. under the following conditions: empty IPv6 URL, brackets in
  315. reverse order.
  316. -- by `@MaelPic <https://github.com/sponsors/MaelPic>`__.
  317. *Related issues and pull requests on GitHub:*
  318. `#1512 <https://github.com/aio-libs/yarl/issues/1512>`__.
  319. Packaging updates and notes for downstreams
  320. -------------------------------------------
  321. - Updated to use Cython 3.1 universally across the build path -- by `@lysnikolaou <https://github.com/sponsors/lysnikolaou>`__.
  322. *Related issues and pull requests on GitHub:*
  323. `#1514 <https://github.com/aio-libs/yarl/issues/1514>`__.
  324. - Made Cython line tracing opt-in via the ``with-cython-tracing`` build config setting -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  325. Previously, line tracing was enabled by default in ``pyproject.toml``, which caused build issues for some users and made wheels nearly twice as slow.
  326. Now line tracing is only enabled when explicitly requested via ``pip install . --config-setting=with-cython-tracing=true`` or by setting the ``YARL_CYTHON_TRACING`` environment variable.
  327. *Related issues and pull requests on GitHub:*
  328. `#1521 <https://github.com/aio-libs/yarl/issues/1521>`__.
  329. ----
  330. 1.20.0
  331. ======
  332. *(2025-04-16)*
  333. Features
  334. --------
  335. - Implemented support for the free-threaded build of CPython 3.13 -- by `@lysnikolaou <https://github.com/sponsors/lysnikolaou>`__.
  336. *Related issues and pull requests on GitHub:*
  337. `#1456 <https://github.com/aio-libs/yarl/issues/1456>`__.
  338. Packaging updates and notes for downstreams
  339. -------------------------------------------
  340. - Started building wheels for the free-threaded build of CPython 3.13 -- by `@lysnikolaou <https://github.com/sponsors/lysnikolaou>`__.
  341. *Related issues and pull requests on GitHub:*
  342. `#1456 <https://github.com/aio-libs/yarl/issues/1456>`__.
  343. ----
  344. 1.19.0
  345. ======
  346. *(2025-04-05)*
  347. Bug fixes
  348. ---------
  349. - Fixed entire name being re-encoded when using ``yarl.URL.with_suffix()`` -- by `@NTFSvolume <https://github.com/sponsors/NTFSvolume>`__.
  350. *Related issues and pull requests on GitHub:*
  351. `#1468 <https://github.com/aio-libs/yarl/issues/1468>`__.
  352. Features
  353. --------
  354. - Started building armv7l wheels for manylinux -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  355. *Related issues and pull requests on GitHub:*
  356. `#1495 <https://github.com/aio-libs/yarl/issues/1495>`__.
  357. Contributor-facing changes
  358. --------------------------
  359. - GitHub Actions CI/CD is now configured to manage caching pip-ecosystem
  360. dependencies using `re-actors/cache-python-deps`_ -- an action by
  361. `@webknjaz <https://github.com/sponsors/webknjaz>`__ that takes into account ABI stability and the exact
  362. version of Python runtime.
  363. .. _`re-actors/cache-python-deps`:
  364. https://github.com/marketplace/actions/cache-python-deps
  365. *Related issues and pull requests on GitHub:*
  366. `#1471 <https://github.com/aio-libs/yarl/issues/1471>`__.
  367. - Increased minimum `propcache`_ version to 0.2.1 to fix failing tests -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  368. .. _`propcache`:
  369. https://github.com/aio-libs/propcache
  370. *Related issues and pull requests on GitHub:*
  371. `#1479 <https://github.com/aio-libs/yarl/issues/1479>`__.
  372. - Added all hidden folders to pytest's ``norecursedirs`` to prevent it
  373. from trying to collect tests there -- by `@lysnikolaou <https://github.com/sponsors/lysnikolaou>`__.
  374. *Related issues and pull requests on GitHub:*
  375. `#1480 <https://github.com/aio-libs/yarl/issues/1480>`__.
  376. Miscellaneous internal changes
  377. ------------------------------
  378. - Improved accuracy of type annotations -- by `@Dreamsorcerer <https://github.com/sponsors/Dreamsorcerer>`__.
  379. *Related issues and pull requests on GitHub:*
  380. `#1484 <https://github.com/aio-libs/yarl/issues/1484>`__.
  381. - Improved performance of parsing query strings -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  382. *Related issues and pull requests on GitHub:*
  383. `#1493 <https://github.com/aio-libs/yarl/issues/1493>`__, `#1497 <https://github.com/aio-libs/yarl/issues/1497>`__.
  384. - Improved performance of the C unquoter -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  385. *Related issues and pull requests on GitHub:*
  386. `#1496 <https://github.com/aio-libs/yarl/issues/1496>`__, `#1498 <https://github.com/aio-libs/yarl/issues/1498>`__.
  387. ----
  388. 1.18.3
  389. ======
  390. *(2024-12-01)*
  391. Bug fixes
  392. ---------
  393. - Fixed uppercase ASCII hosts being rejected by ``URL.build()()`` and ``yarl.URL.with_host()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  394. *Related issues and pull requests on GitHub:*
  395. `#954 <https://github.com/aio-libs/yarl/issues/954>`__, `#1442 <https://github.com/aio-libs/yarl/issues/1442>`__.
  396. Miscellaneous internal changes
  397. ------------------------------
  398. - Improved performances of multiple path properties on cache miss -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  399. *Related issues and pull requests on GitHub:*
  400. `#1443 <https://github.com/aio-libs/yarl/issues/1443>`__.
  401. ----
  402. 1.18.2
  403. ======
  404. *(2024-11-29)*
  405. No significant changes.
  406. ----
  407. 1.18.1
  408. ======
  409. *(2024-11-29)*
  410. Miscellaneous internal changes
  411. ------------------------------
  412. - Improved cache performance when ``~yarl.URL`` objects are constructed from ``yarl.URL.build()`` with ``encoded=True`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  413. *Related issues and pull requests on GitHub:*
  414. `#1432 <https://github.com/aio-libs/yarl/issues/1432>`__.
  415. - Improved cache performance for operations that produce a new ``~yarl.URL`` object -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  416. *Related issues and pull requests on GitHub:*
  417. `#1434 <https://github.com/aio-libs/yarl/issues/1434>`__, `#1436 <https://github.com/aio-libs/yarl/issues/1436>`__.
  418. ----
  419. 1.18.0
  420. ======
  421. *(2024-11-21)*
  422. Features
  423. --------
  424. - Added ``keep_query`` and ``keep_fragment`` flags in the ``yarl.URL.with_path()``, ``yarl.URL.with_name()`` and ``yarl.URL.with_suffix()`` methods, allowing users to optionally retain the query string and fragment in the resulting URL when replacing the path -- by `@paul-nameless <https://github.com/sponsors/paul-nameless>`__.
  425. *Related issues and pull requests on GitHub:*
  426. `#111 <https://github.com/aio-libs/yarl/issues/111>`__, `#1421 <https://github.com/aio-libs/yarl/issues/1421>`__.
  427. Contributor-facing changes
  428. --------------------------
  429. - Started running downstream ``aiohttp`` tests in CI -- by `@Cycloctane <https://github.com/sponsors/Cycloctane>`__.
  430. *Related issues and pull requests on GitHub:*
  431. `#1415 <https://github.com/aio-libs/yarl/issues/1415>`__.
  432. Miscellaneous internal changes
  433. ------------------------------
  434. - Improved performance of converting ``~yarl.URL`` to a string -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  435. *Related issues and pull requests on GitHub:*
  436. `#1422 <https://github.com/aio-libs/yarl/issues/1422>`__.
  437. ----
  438. 1.17.2
  439. ======
  440. *(2024-11-17)*
  441. Bug fixes
  442. ---------
  443. - Stopped implicitly allowing the use of Cython pre-release versions when
  444. building the distribution package -- by `@ajsanchezsanz <https://github.com/sponsors/ajsanchezsanz>`__ and
  445. `@markgreene74 <https://github.com/sponsors/markgreene74>`__.
  446. *Related issues and pull requests on GitHub:*
  447. `#1411 <https://github.com/aio-libs/yarl/issues/1411>`__, `#1412 <https://github.com/aio-libs/yarl/issues/1412>`__.
  448. - Fixed a bug causing ``~yarl.URL.port`` to return the default port when the given port was zero
  449. -- by `@gmacon <https://github.com/sponsors/gmacon>`__.
  450. *Related issues and pull requests on GitHub:*
  451. `#1413 <https://github.com/aio-libs/yarl/issues/1413>`__.
  452. Features
  453. --------
  454. - Make error messages include details of incorrect type when ``port`` is not int in ``yarl.URL.build()``.
  455. -- by `@Cycloctane <https://github.com/sponsors/Cycloctane>`__.
  456. *Related issues and pull requests on GitHub:*
  457. `#1414 <https://github.com/aio-libs/yarl/issues/1414>`__.
  458. Packaging updates and notes for downstreams
  459. -------------------------------------------
  460. - Stopped implicitly allowing the use of Cython pre-release versions when
  461. building the distribution package -- by `@ajsanchezsanz <https://github.com/sponsors/ajsanchezsanz>`__ and
  462. `@markgreene74 <https://github.com/sponsors/markgreene74>`__.
  463. *Related issues and pull requests on GitHub:*
  464. `#1411 <https://github.com/aio-libs/yarl/issues/1411>`__, `#1412 <https://github.com/aio-libs/yarl/issues/1412>`__.
  465. Miscellaneous internal changes
  466. ------------------------------
  467. - Improved performance of the ``yarl.URL.joinpath()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  468. *Related issues and pull requests on GitHub:*
  469. `#1418 <https://github.com/aio-libs/yarl/issues/1418>`__.
  470. ----
  471. 1.17.1
  472. ======
  473. *(2024-10-30)*
  474. Miscellaneous internal changes
  475. ------------------------------
  476. - Improved performance of many ``~yarl.URL`` methods -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  477. *Related issues and pull requests on GitHub:*
  478. `#1396 <https://github.com/aio-libs/yarl/issues/1396>`__, `#1397 <https://github.com/aio-libs/yarl/issues/1397>`__, `#1398 <https://github.com/aio-libs/yarl/issues/1398>`__.
  479. - Improved performance of passing a `dict` or `str` to ``yarl.URL.extend_query()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  480. *Related issues and pull requests on GitHub:*
  481. `#1401 <https://github.com/aio-libs/yarl/issues/1401>`__.
  482. ----
  483. 1.17.0
  484. ======
  485. *(2024-10-28)*
  486. Features
  487. --------
  488. - Added ``~yarl.URL.host_port_subcomponent`` which returns the ``3986#section-3.2.2`` host and ``3986#section-3.2.3`` port subcomponent -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  489. *Related issues and pull requests on GitHub:*
  490. `#1375 <https://github.com/aio-libs/yarl/issues/1375>`__.
  491. ----
  492. 1.16.0
  493. ======
  494. *(2024-10-21)*
  495. Bug fixes
  496. ---------
  497. - Fixed blocking I/O to load Python code when creating a new ``~yarl.URL`` with non-ascii characters in the network location part -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  498. *Related issues and pull requests on GitHub:*
  499. `#1342 <https://github.com/aio-libs/yarl/issues/1342>`__.
  500. Removals and backward incompatible breaking changes
  501. ---------------------------------------------------
  502. - Migrated to using a single cache for encoding hosts -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  503. Passing ``ip_address_size`` and ``host_validate_size`` to ``yarl.cache_configure()`` is deprecated in favor of the new ``encode_host_size`` parameter and will be removed in a future release. For backwards compatibility, the old parameters affect the ``encode_host`` cache size.
  504. *Related issues and pull requests on GitHub:*
  505. `#1348 <https://github.com/aio-libs/yarl/issues/1348>`__, `#1357 <https://github.com/aio-libs/yarl/issues/1357>`__, `#1363 <https://github.com/aio-libs/yarl/issues/1363>`__.
  506. Miscellaneous internal changes
  507. ------------------------------
  508. - Improved performance of constructing ``~yarl.URL`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  509. *Related issues and pull requests on GitHub:*
  510. `#1336 <https://github.com/aio-libs/yarl/issues/1336>`__.
  511. - Improved performance of calling ``yarl.URL.build()`` and constructing unencoded ``~yarl.URL`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  512. *Related issues and pull requests on GitHub:*
  513. `#1345 <https://github.com/aio-libs/yarl/issues/1345>`__.
  514. - Reworked the internal encoding cache to improve performance on cache hit -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  515. *Related issues and pull requests on GitHub:*
  516. `#1369 <https://github.com/aio-libs/yarl/issues/1369>`__.
  517. ----
  518. 1.15.5
  519. ======
  520. *(2024-10-18)*
  521. Miscellaneous internal changes
  522. ------------------------------
  523. - Improved performance of the ``yarl.URL.joinpath()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  524. *Related issues and pull requests on GitHub:*
  525. `#1304 <https://github.com/aio-libs/yarl/issues/1304>`__.
  526. - Improved performance of the ``yarl.URL.extend_query()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  527. *Related issues and pull requests on GitHub:*
  528. `#1305 <https://github.com/aio-libs/yarl/issues/1305>`__.
  529. - Improved performance of the ``yarl.URL.origin()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  530. *Related issues and pull requests on GitHub:*
  531. `#1306 <https://github.com/aio-libs/yarl/issues/1306>`__.
  532. - Improved performance of the ``yarl.URL.with_path()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  533. *Related issues and pull requests on GitHub:*
  534. `#1307 <https://github.com/aio-libs/yarl/issues/1307>`__.
  535. - Improved performance of the ``yarl.URL.with_query()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  536. *Related issues and pull requests on GitHub:*
  537. `#1308 <https://github.com/aio-libs/yarl/issues/1308>`__, `#1328 <https://github.com/aio-libs/yarl/issues/1328>`__.
  538. - Improved performance of the ``yarl.URL.update_query()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  539. *Related issues and pull requests on GitHub:*
  540. `#1309 <https://github.com/aio-libs/yarl/issues/1309>`__, `#1327 <https://github.com/aio-libs/yarl/issues/1327>`__.
  541. - Improved performance of the ``yarl.URL.join()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  542. *Related issues and pull requests on GitHub:*
  543. `#1313 <https://github.com/aio-libs/yarl/issues/1313>`__.
  544. - Improved performance of ``~yarl.URL`` equality checks -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  545. *Related issues and pull requests on GitHub:*
  546. `#1315 <https://github.com/aio-libs/yarl/issues/1315>`__.
  547. - Improved performance of ``~yarl.URL`` methods that modify the network location -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  548. *Related issues and pull requests on GitHub:*
  549. `#1316 <https://github.com/aio-libs/yarl/issues/1316>`__.
  550. - Improved performance of the ``yarl.URL.with_fragment()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  551. *Related issues and pull requests on GitHub:*
  552. `#1317 <https://github.com/aio-libs/yarl/issues/1317>`__.
  553. - Improved performance of calculating the hash of ``~yarl.URL`` objects -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  554. *Related issues and pull requests on GitHub:*
  555. `#1318 <https://github.com/aio-libs/yarl/issues/1318>`__.
  556. - Improved performance of the ``yarl.URL.relative()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  557. *Related issues and pull requests on GitHub:*
  558. `#1319 <https://github.com/aio-libs/yarl/issues/1319>`__.
  559. - Improved performance of the ``yarl.URL.with_name()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  560. *Related issues and pull requests on GitHub:*
  561. `#1320 <https://github.com/aio-libs/yarl/issues/1320>`__.
  562. - Improved performance of ``~yarl.URL.parent`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  563. *Related issues and pull requests on GitHub:*
  564. `#1321 <https://github.com/aio-libs/yarl/issues/1321>`__.
  565. - Improved performance of the ``yarl.URL.with_scheme()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  566. *Related issues and pull requests on GitHub:*
  567. `#1322 <https://github.com/aio-libs/yarl/issues/1322>`__.
  568. ----
  569. 1.15.4
  570. ======
  571. *(2024-10-16)*
  572. Miscellaneous internal changes
  573. ------------------------------
  574. - Improved performance of the quoter when all characters are safe -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  575. *Related issues and pull requests on GitHub:*
  576. `#1288 <https://github.com/aio-libs/yarl/issues/1288>`__.
  577. - Improved performance of unquoting strings -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  578. *Related issues and pull requests on GitHub:*
  579. `#1292 <https://github.com/aio-libs/yarl/issues/1292>`__, `#1293 <https://github.com/aio-libs/yarl/issues/1293>`__.
  580. - Improved performance of calling ``yarl.URL.build()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  581. *Related issues and pull requests on GitHub:*
  582. `#1297 <https://github.com/aio-libs/yarl/issues/1297>`__.
  583. ----
  584. 1.15.3
  585. ======
  586. *(2024-10-15)*
  587. Bug fixes
  588. ---------
  589. - Fixed ``yarl.URL.build()`` failing to validate paths must start with a ``/`` when passing ``authority`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  590. The validation only worked correctly when passing ``host``.
  591. *Related issues and pull requests on GitHub:*
  592. `#1265 <https://github.com/aio-libs/yarl/issues/1265>`__.
  593. Removals and backward incompatible breaking changes
  594. ---------------------------------------------------
  595. - Removed support for Python 3.8 as it has reached end of life -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  596. *Related issues and pull requests on GitHub:*
  597. `#1203 <https://github.com/aio-libs/yarl/issues/1203>`__.
  598. Miscellaneous internal changes
  599. ------------------------------
  600. - Improved performance of constructing ``~yarl.URL`` when the net location is only the host -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  601. *Related issues and pull requests on GitHub:*
  602. `#1271 <https://github.com/aio-libs/yarl/issues/1271>`__.
  603. ----
  604. 1.15.2
  605. ======
  606. *(2024-10-13)*
  607. Miscellaneous internal changes
  608. ------------------------------
  609. - Improved performance of converting ``~yarl.URL`` to a string -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  610. *Related issues and pull requests on GitHub:*
  611. `#1234 <https://github.com/aio-libs/yarl/issues/1234>`__.
  612. - Improved performance of ``yarl.URL.joinpath()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  613. *Related issues and pull requests on GitHub:*
  614. `#1248 <https://github.com/aio-libs/yarl/issues/1248>`__, `#1250 <https://github.com/aio-libs/yarl/issues/1250>`__.
  615. - Improved performance of constructing query strings from ``~multidict.MultiDict`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  616. *Related issues and pull requests on GitHub:*
  617. `#1256 <https://github.com/aio-libs/yarl/issues/1256>`__.
  618. - Improved performance of constructing query strings with ``int`` values -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  619. *Related issues and pull requests on GitHub:*
  620. `#1259 <https://github.com/aio-libs/yarl/issues/1259>`__.
  621. ----
  622. 1.15.1
  623. ======
  624. *(2024-10-12)*
  625. Miscellaneous internal changes
  626. ------------------------------
  627. - Improved performance of calling ``yarl.URL.build()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  628. *Related issues and pull requests on GitHub:*
  629. `#1222 <https://github.com/aio-libs/yarl/issues/1222>`__.
  630. - Improved performance of all ``~yarl.URL`` methods that create new ``~yarl.URL`` objects -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  631. *Related issues and pull requests on GitHub:*
  632. `#1226 <https://github.com/aio-libs/yarl/issues/1226>`__.
  633. - Improved performance of ``~yarl.URL`` methods that modify the network location -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  634. *Related issues and pull requests on GitHub:*
  635. `#1229 <https://github.com/aio-libs/yarl/issues/1229>`__.
  636. ----
  637. 1.15.0
  638. ======
  639. *(2024-10-11)*
  640. Bug fixes
  641. ---------
  642. - Fixed validation with ``yarl.URL.with_scheme()`` when passed scheme is not lowercase -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  643. *Related issues and pull requests on GitHub:*
  644. `#1189 <https://github.com/aio-libs/yarl/issues/1189>`__.
  645. Features
  646. --------
  647. - Started building ``armv7l`` wheels -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  648. *Related issues and pull requests on GitHub:*
  649. `#1204 <https://github.com/aio-libs/yarl/issues/1204>`__.
  650. Miscellaneous internal changes
  651. ------------------------------
  652. - Improved performance of constructing unencoded ``~yarl.URL`` objects -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  653. *Related issues and pull requests on GitHub:*
  654. `#1188 <https://github.com/aio-libs/yarl/issues/1188>`__.
  655. - Added a cache for parsing hosts to reduce overhead of encoding ``~yarl.URL`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  656. *Related issues and pull requests on GitHub:*
  657. `#1190 <https://github.com/aio-libs/yarl/issues/1190>`__.
  658. - Improved performance of constructing query strings from ``~collections.abc.Mapping`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  659. *Related issues and pull requests on GitHub:*
  660. `#1193 <https://github.com/aio-libs/yarl/issues/1193>`__.
  661. - Improved performance of converting ``~yarl.URL`` objects to strings -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  662. *Related issues and pull requests on GitHub:*
  663. `#1198 <https://github.com/aio-libs/yarl/issues/1198>`__.
  664. ----
  665. 1.14.0
  666. ======
  667. *(2024-10-08)*
  668. Packaging updates and notes for downstreams
  669. -------------------------------------------
  670. - Switched to using the ``propcache`` package for property caching
  671. -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  672. The ``propcache`` package is derived from the property caching
  673. code in ``yarl`` and has been broken out to avoid maintaining it for multiple
  674. projects.
  675. *Related issues and pull requests on GitHub:*
  676. `#1169 <https://github.com/aio-libs/yarl/issues/1169>`__.
  677. Contributor-facing changes
  678. --------------------------
  679. - Started testing with Hypothesis -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__ and `@bdraco <https://github.com/sponsors/bdraco>`__.
  680. Special thanks to `@Zac-HD <https://github.com/sponsors/Zac-HD>`__ for helping us get started with this framework.
  681. *Related issues and pull requests on GitHub:*
  682. `#860 <https://github.com/aio-libs/yarl/issues/860>`__.
  683. Miscellaneous internal changes
  684. ------------------------------
  685. - Improved performance of ``yarl.URL.is_default_port()`` when no explicit port is set -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  686. *Related issues and pull requests on GitHub:*
  687. `#1168 <https://github.com/aio-libs/yarl/issues/1168>`__.
  688. - Improved performance of converting ``~yarl.URL`` to a string when no explicit port is set -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  689. *Related issues and pull requests on GitHub:*
  690. `#1170 <https://github.com/aio-libs/yarl/issues/1170>`__.
  691. - Improved performance of the ``yarl.URL.origin()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  692. *Related issues and pull requests on GitHub:*
  693. `#1175 <https://github.com/aio-libs/yarl/issues/1175>`__.
  694. - Improved performance of encoding hosts -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  695. *Related issues and pull requests on GitHub:*
  696. `#1176 <https://github.com/aio-libs/yarl/issues/1176>`__.
  697. ----
  698. 1.13.1
  699. ======
  700. *(2024-09-27)*
  701. Miscellaneous internal changes
  702. ------------------------------
  703. - Improved performance of calling ``yarl.URL.build()`` with ``authority`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  704. *Related issues and pull requests on GitHub:*
  705. `#1163 <https://github.com/aio-libs/yarl/issues/1163>`__.
  706. ----
  707. 1.13.0
  708. ======
  709. *(2024-09-26)*
  710. Bug fixes
  711. ---------
  712. - Started rejecting ASCII hostnames with invalid characters. For host strings that
  713. look like authority strings, the exception message includes advice on what to do
  714. instead -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__.
  715. *Related issues and pull requests on GitHub:*
  716. `#880 <https://github.com/aio-libs/yarl/issues/880>`__, `#954 <https://github.com/aio-libs/yarl/issues/954>`__.
  717. - Fixed IPv6 addresses missing brackets when the ``~yarl.URL`` was converted to a string -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  718. *Related issues and pull requests on GitHub:*
  719. `#1157 <https://github.com/aio-libs/yarl/issues/1157>`__, `#1158 <https://github.com/aio-libs/yarl/issues/1158>`__.
  720. Features
  721. --------
  722. - Added ``~yarl.URL.host_subcomponent`` which returns the ``3986#section-3.2.2`` host subcomponent -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  723. The only current practical difference between ``~yarl.URL.raw_host`` and ``~yarl.URL.host_subcomponent`` is that IPv6 addresses are returned bracketed.
  724. *Related issues and pull requests on GitHub:*
  725. `#1159 <https://github.com/aio-libs/yarl/issues/1159>`__.
  726. ----
  727. 1.12.1
  728. ======
  729. *(2024-09-23)*
  730. No significant changes.
  731. ----
  732. 1.12.0
  733. ======
  734. *(2024-09-23)*
  735. Features
  736. --------
  737. - Added ``~yarl.URL.path_safe`` to be able to fetch the path without ``%2F`` and ``%25`` decoded -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  738. *Related issues and pull requests on GitHub:*
  739. `#1150 <https://github.com/aio-libs/yarl/issues/1150>`__.
  740. Removals and backward incompatible breaking changes
  741. ---------------------------------------------------
  742. - Restore decoding ``%2F`` (``/``) in ``URL.path`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  743. This change restored the behavior before `#1057 <https://github.com/aio-libs/yarl/issues/1057>`__.
  744. *Related issues and pull requests on GitHub:*
  745. `#1151 <https://github.com/aio-libs/yarl/issues/1151>`__.
  746. Miscellaneous internal changes
  747. ------------------------------
  748. - Improved performance of processing paths -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  749. *Related issues and pull requests on GitHub:*
  750. `#1143 <https://github.com/aio-libs/yarl/issues/1143>`__.
  751. ----
  752. 1.11.1
  753. ======
  754. *(2024-09-09)*
  755. Bug fixes
  756. ---------
  757. - Allowed scheme replacement for relative URLs if the scheme does not require a host -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  758. *Related issues and pull requests on GitHub:*
  759. `#280 <https://github.com/aio-libs/yarl/issues/280>`__, `#1138 <https://github.com/aio-libs/yarl/issues/1138>`__.
  760. - Allowed empty host for URL schemes other than the special schemes listed in the WHATWG URL spec -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  761. *Related issues and pull requests on GitHub:*
  762. `#1136 <https://github.com/aio-libs/yarl/issues/1136>`__.
  763. Features
  764. --------
  765. - Loosened restriction on integers as query string values to allow classes that implement ``__int__`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  766. *Related issues and pull requests on GitHub:*
  767. `#1139 <https://github.com/aio-libs/yarl/issues/1139>`__.
  768. Miscellaneous internal changes
  769. ------------------------------
  770. - Improved performance of normalizing paths -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  771. *Related issues and pull requests on GitHub:*
  772. `#1137 <https://github.com/aio-libs/yarl/issues/1137>`__.
  773. ----
  774. 1.11.0
  775. ======
  776. *(2024-09-08)*
  777. Features
  778. --------
  779. - Added ``URL.extend_query()()`` method, which can be used to extend parameters without replacing same named keys -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  780. This method was primarily added to replace the inefficient hand rolled method currently used in ``aiohttp``.
  781. *Related issues and pull requests on GitHub:*
  782. `#1128 <https://github.com/aio-libs/yarl/issues/1128>`__.
  783. Miscellaneous internal changes
  784. ------------------------------
  785. - Improved performance of the Cython ``cached_property`` implementation -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  786. *Related issues and pull requests on GitHub:*
  787. `#1122 <https://github.com/aio-libs/yarl/issues/1122>`__.
  788. - Simplified computing ports by removing unnecessary code -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  789. *Related issues and pull requests on GitHub:*
  790. `#1123 <https://github.com/aio-libs/yarl/issues/1123>`__.
  791. - Improved performance of encoding non IPv6 hosts -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  792. *Related issues and pull requests on GitHub:*
  793. `#1125 <https://github.com/aio-libs/yarl/issues/1125>`__.
  794. - Improved performance of ``URL.build()()`` when the path, query string, or fragment is an empty string -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  795. *Related issues and pull requests on GitHub:*
  796. `#1126 <https://github.com/aio-libs/yarl/issues/1126>`__.
  797. - Improved performance of the ``URL.update_query()()`` method -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  798. *Related issues and pull requests on GitHub:*
  799. `#1130 <https://github.com/aio-libs/yarl/issues/1130>`__.
  800. - Improved performance of processing query string changes when arguments are ``str`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  801. *Related issues and pull requests on GitHub:*
  802. `#1131 <https://github.com/aio-libs/yarl/issues/1131>`__.
  803. ----
  804. 1.10.0
  805. ======
  806. *(2024-09-06)*
  807. Bug fixes
  808. ---------
  809. - Fixed joining a path when the existing path was empty -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  810. A regression in ``URL.join()()`` was introduced in `#1082 <https://github.com/aio-libs/yarl/issues/1082>`__.
  811. *Related issues and pull requests on GitHub:*
  812. `#1118 <https://github.com/aio-libs/yarl/issues/1118>`__.
  813. Features
  814. --------
  815. - Added ``URL.without_query_params()()`` method, to drop some parameters from query string -- by `@hongquan <https://github.com/sponsors/hongquan>`__.
  816. *Related issues and pull requests on GitHub:*
  817. `#774 <https://github.com/aio-libs/yarl/issues/774>`__, `#898 <https://github.com/aio-libs/yarl/issues/898>`__, `#1010 <https://github.com/aio-libs/yarl/issues/1010>`__.
  818. - The previously protected types ``_SimpleQuery``, ``_QueryVariable``, and ``_Query`` are now available for use externally as ``SimpleQuery``, ``QueryVariable``, and ``Query`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  819. *Related issues and pull requests on GitHub:*
  820. `#1050 <https://github.com/aio-libs/yarl/issues/1050>`__, `#1113 <https://github.com/aio-libs/yarl/issues/1113>`__.
  821. Contributor-facing changes
  822. --------------------------
  823. - Replaced all ``~typing.Optional`` with ``~typing.Union`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  824. *Related issues and pull requests on GitHub:*
  825. `#1095 <https://github.com/aio-libs/yarl/issues/1095>`__.
  826. Miscellaneous internal changes
  827. ------------------------------
  828. - Significantly improved performance of parsing the network location -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  829. *Related issues and pull requests on GitHub:*
  830. `#1112 <https://github.com/aio-libs/yarl/issues/1112>`__.
  831. - Added internal types to the cache to prevent future refactoring errors -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  832. *Related issues and pull requests on GitHub:*
  833. `#1117 <https://github.com/aio-libs/yarl/issues/1117>`__.
  834. ----
  835. 1.9.11
  836. ======
  837. *(2024-09-04)*
  838. Bug fixes
  839. ---------
  840. - Fixed a ``TypeError`` with ``MultiDictProxy`` and Python 3.8 -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  841. *Related issues and pull requests on GitHub:*
  842. `#1084 <https://github.com/aio-libs/yarl/issues/1084>`__, `#1105 <https://github.com/aio-libs/yarl/issues/1105>`__, `#1107 <https://github.com/aio-libs/yarl/issues/1107>`__.
  843. Miscellaneous internal changes
  844. ------------------------------
  845. - Improved performance of encoding hosts -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  846. Previously, the library would unconditionally try to parse a host as an IP Address. The library now avoids trying to parse a host as an IP Address if the string is not in one of the formats described in ``3986#section-3.2.2``.
  847. *Related issues and pull requests on GitHub:*
  848. `#1104 <https://github.com/aio-libs/yarl/issues/1104>`__.
  849. ----
  850. 1.9.10
  851. ======
  852. *(2024-09-04)*
  853. Bug fixes
  854. ---------
  855. - ``URL.join()()`` has been changed to match
  856. ``3986`` and align with
  857. ``/ operation()`` and ``URL.joinpath()()``
  858. when joining URLs with empty segments.
  859. Previously ``urllib.parse.urljoin`` was used,
  860. which has known issues with empty segments
  861. (`python/cpython#84774 <https://github.com/python/cpython/issues/84774>`_).
  862. Due to the semantics of ``URL.join()()``, joining an
  863. URL with scheme requires making it relative, prefixing with ``./``.
  864. .. code-block:: pycon
  865. >>> URL("https://web.archive.org/web/").join(URL("./https://github.com/aio-libs/yarl"))
  866. URL('https://web.archive.org/web/https://github.com/aio-libs/yarl')
  867. Empty segments are honored in the base as well as the joined part.
  868. .. code-block:: pycon
  869. >>> URL("https://web.archive.org/web/https://").join(URL("github.com/aio-libs/yarl"))
  870. URL('https://web.archive.org/web/https://github.com/aio-libs/yarl')
  871. -- by `@commonism <https://github.com/sponsors/commonism>`__
  872. This change initially appeared in 1.9.5 but was reverted in 1.9.6 to resolve a problem with query string handling.
  873. *Related issues and pull requests on GitHub:*
  874. `#1039 <https://github.com/aio-libs/yarl/issues/1039>`__, `#1082 <https://github.com/aio-libs/yarl/issues/1082>`__.
  875. Features
  876. --------
  877. - Added ``~yarl.URL.absolute`` which is now preferred over ``URL.is_absolute()`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  878. *Related issues and pull requests on GitHub:*
  879. `#1100 <https://github.com/aio-libs/yarl/issues/1100>`__.
  880. ----
  881. 1.9.9
  882. =====
  883. *(2024-09-04)*
  884. Bug fixes
  885. ---------
  886. - Added missing type on ``~yarl.URL.port`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  887. *Related issues and pull requests on GitHub:*
  888. `#1097 <https://github.com/aio-libs/yarl/issues/1097>`__.
  889. ----
  890. 1.9.8
  891. =====
  892. *(2024-09-03)*
  893. Features
  894. --------
  895. - Covered the ``~yarl.URL`` object with types -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  896. *Related issues and pull requests on GitHub:*
  897. `#1084 <https://github.com/aio-libs/yarl/issues/1084>`__.
  898. - Cache parsing of IP Addresses when encoding hosts -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  899. *Related issues and pull requests on GitHub:*
  900. `#1086 <https://github.com/aio-libs/yarl/issues/1086>`__.
  901. Contributor-facing changes
  902. --------------------------
  903. - Covered the ``~yarl.URL`` object with types -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  904. *Related issues and pull requests on GitHub:*
  905. `#1084 <https://github.com/aio-libs/yarl/issues/1084>`__.
  906. Miscellaneous internal changes
  907. ------------------------------
  908. - Improved performance of handling ports -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  909. *Related issues and pull requests on GitHub:*
  910. `#1081 <https://github.com/aio-libs/yarl/issues/1081>`__.
  911. ----
  912. 1.9.7
  913. =====
  914. *(2024-09-01)*
  915. Removals and backward incompatible breaking changes
  916. ---------------------------------------------------
  917. - Removed support ``3986#section-3.2.3`` port normalization when the scheme is not one of ``http``, ``https``, ``wss``, or ``ws`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  918. Support for port normalization was recently added in `#1033 <https://github.com/aio-libs/yarl/issues/1033>`__ and contained code that would do blocking I/O if the scheme was not one of the four listed above. The code has been removed because this library is intended to be safe for usage with ``asyncio``.
  919. *Related issues and pull requests on GitHub:*
  920. `#1076 <https://github.com/aio-libs/yarl/issues/1076>`__.
  921. Miscellaneous internal changes
  922. ------------------------------
  923. - Improved performance of property caching -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  924. The ``reify`` implementation from ``aiohttp`` was adapted to replace the internal ``cached_property`` implementation.
  925. *Related issues and pull requests on GitHub:*
  926. `#1070 <https://github.com/aio-libs/yarl/issues/1070>`__.
  927. ----
  928. 1.9.6
  929. =====
  930. *(2024-08-30)*
  931. Bug fixes
  932. ---------
  933. - Reverted ``3986`` compatible ``URL.join()()`` honoring empty segments which was introduced in `#1039 <https://github.com/aio-libs/yarl/issues/1039>`__.
  934. This change introduced a regression handling query string parameters with joined URLs. The change was reverted to maintain compatibility with the previous behavior.
  935. *Related issues and pull requests on GitHub:*
  936. `#1067 <https://github.com/aio-libs/yarl/issues/1067>`__.
  937. ----
  938. 1.9.5
  939. =====
  940. *(2024-08-30)*
  941. Bug fixes
  942. ---------
  943. - Joining URLs with empty segments has been changed
  944. to match ``3986``.
  945. Previously empty segments would be removed from path,
  946. breaking use-cases such as
  947. .. code-block:: python
  948. URL("https://web.archive.org/web/") / "https://github.com/"
  949. Now ``/ operation()`` and ``URL.joinpath()()``
  950. keep empty segments, but do not introduce new empty segments.
  951. e.g.
  952. .. code-block:: python
  953. URL("https://example.org/") / ""
  954. does not introduce an empty segment.
  955. -- by `@commonism <https://github.com/sponsors/commonism>`__ and `@youtux <https://github.com/sponsors/youtux>`__
  956. *Related issues and pull requests on GitHub:*
  957. `#1026 <https://github.com/aio-libs/yarl/issues/1026>`__.
  958. - The default protocol ports of well-known URI schemes are now taken into account
  959. during the normalization of the URL string representation in accordance with
  960. ``3986#section-3.2.3``.
  961. Specified ports are removed from the ``str`` representation of a ``~yarl.URL``
  962. if the port matches the scheme's default port -- by `@commonism <https://github.com/sponsors/commonism>`__.
  963. *Related issues and pull requests on GitHub:*
  964. `#1033 <https://github.com/aio-libs/yarl/issues/1033>`__.
  965. - ``URL.join()()`` has been changed to match
  966. ``3986`` and align with
  967. ``/ operation()`` and ``URL.joinpath()()``
  968. when joining URLs with empty segments.
  969. Previously ``urllib.parse.urljoin`` was used,
  970. which has known issues with empty segments
  971. (`python/cpython#84774 <https://github.com/python/cpython/issues/84774>`_).
  972. Due to the semantics of ``URL.join()()``, joining an
  973. URL with scheme requires making it relative, prefixing with ``./``.
  974. .. code-block:: pycon
  975. >>> URL("https://web.archive.org/web/").join(URL("./https://github.com/aio-libs/yarl"))
  976. URL('https://web.archive.org/web/https://github.com/aio-libs/yarl')
  977. Empty segments are honored in the base as well as the joined part.
  978. .. code-block:: pycon
  979. >>> URL("https://web.archive.org/web/https://").join(URL("github.com/aio-libs/yarl"))
  980. URL('https://web.archive.org/web/https://github.com/aio-libs/yarl')
  981. -- by `@commonism <https://github.com/sponsors/commonism>`__
  982. *Related issues and pull requests on GitHub:*
  983. `#1039 <https://github.com/aio-libs/yarl/issues/1039>`__.
  984. Removals and backward incompatible breaking changes
  985. ---------------------------------------------------
  986. - Stopped decoding ``%2F`` (``/``) in ``URL.path``, as this could lead to code incorrectly treating it as a path separator
  987. -- by `@Dreamsorcerer <https://github.com/sponsors/Dreamsorcerer>`__.
  988. *Related issues and pull requests on GitHub:*
  989. `#1057 <https://github.com/aio-libs/yarl/issues/1057>`__.
  990. - Dropped support for Python 3.7 -- by `@Dreamsorcerer <https://github.com/sponsors/Dreamsorcerer>`__.
  991. *Related issues and pull requests on GitHub:*
  992. `#1016 <https://github.com/aio-libs/yarl/issues/1016>`__.
  993. Improved documentation
  994. ----------------------
  995. - On the ``Contributing docs`` page,
  996. a link to the ``Towncrier philosophy`` has been fixed.
  997. *Related issues and pull requests on GitHub:*
  998. `#981 <https://github.com/aio-libs/yarl/issues/981>`__.
  999. - The pre-existing ``/ magic method()``
  1000. has been documented in the API reference -- by `@commonism <https://github.com/sponsors/commonism>`__.
  1001. *Related issues and pull requests on GitHub:*
  1002. `#1026 <https://github.com/aio-libs/yarl/issues/1026>`__.
  1003. Packaging updates and notes for downstreams
  1004. -------------------------------------------
  1005. - A flaw in the logic for copying the project directory into a
  1006. temporary folder that led to infinite recursion when ``TMPDIR``
  1007. was set to a project subdirectory path. This was happening in Fedora
  1008. and its downstream due to the use of `pyproject-rpm-macros
  1009. <https://src.fedoraproject.org/rpms/pyproject-rpm-macros>`__. It was
  1010. only reproducible with ``pip wheel`` and was not affecting the
  1011. ``pyproject-build`` users.
  1012. -- by `@hroncok <https://github.com/sponsors/hroncok>`__ and `@webknjaz <https://github.com/sponsors/webknjaz>`__
  1013. *Related issues and pull requests on GitHub:*
  1014. `#992 <https://github.com/aio-libs/yarl/issues/992>`__, `#1014 <https://github.com/aio-libs/yarl/issues/1014>`__.
  1015. - Support Python 3.13 and publish non-free-threaded wheels
  1016. *Related issues and pull requests on GitHub:*
  1017. `#1054 <https://github.com/aio-libs/yarl/issues/1054>`__.
  1018. Contributor-facing changes
  1019. --------------------------
  1020. - The CI/CD setup has been updated to test ``arm64`` wheels
  1021. under macOS 14, except for Python 3.7 that is unsupported
  1022. in that environment -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1023. *Related issues and pull requests on GitHub:*
  1024. `#1015 <https://github.com/aio-libs/yarl/issues/1015>`__.
  1025. - Removed unused type ignores and casts -- by `@hauntsaninja <https://github.com/sponsors/hauntsaninja>`__.
  1026. *Related issues and pull requests on GitHub:*
  1027. `#1031 <https://github.com/aio-libs/yarl/issues/1031>`__.
  1028. Miscellaneous internal changes
  1029. ------------------------------
  1030. - ``port``, ``scheme``, and ``raw_host`` are now ``cached_property`` -- by `@bdraco <https://github.com/sponsors/bdraco>`__.
  1031. ``aiohttp`` accesses these properties quite often, which cause ``urllib`` to build the ``_hostinfo`` property every time. ``port``, ``scheme``, and ``raw_host`` are now cached properties, which will improve performance.
  1032. *Related issues and pull requests on GitHub:*
  1033. `#1044 <https://github.com/aio-libs/yarl/issues/1044>`__, `#1058 <https://github.com/aio-libs/yarl/issues/1058>`__.
  1034. ----
  1035. 1.9.4 (2023-12-06)
  1036. ==================
  1037. Bug fixes
  1038. ---------
  1039. - Started raising ``TypeError`` when a string value is passed into
  1040. ``yarl.URL.build()`` as the ``port`` argument -- by `@commonism <https://github.com/sponsors/commonism>`__.
  1041. Previously the empty string as port would create malformed URLs when rendered as string representations. (`#883 <https://github.com/aio-libs/yarl/issues/883>`__)
  1042. Packaging updates and notes for downstreams
  1043. -------------------------------------------
  1044. - The leading ``--`` has been dropped from the `PEP 517 <https://peps.python.org/pep-517>`__ in-tree build
  1045. backend config setting names. ``--pure-python`` is now just ``pure-python``
  1046. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1047. The usage now looks as follows:
  1048. .. code-block:: console
  1049. $ python -m build \
  1050. --config-setting=pure-python=true \
  1051. --config-setting=with-cython-tracing=true
  1052. (`#963 <https://github.com/aio-libs/yarl/issues/963>`__)
  1053. Contributor-facing changes
  1054. --------------------------
  1055. - A step-by-step ``Release Guide`` guide has
  1056. been added, describing how to release *yarl* -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1057. This is primarily targeting maintainers. (`#960 <https://github.com/aio-libs/yarl/issues/960>`__)
  1058. - Coverage collection has been implemented for the Cython modules
  1059. -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1060. It will also be reported to Codecov from any non-release CI jobs.
  1061. To measure coverage in a development environment, *yarl* can be
  1062. installed in editable mode:
  1063. .. code-block:: console
  1064. $ python -Im pip install -e .
  1065. Editable install produces C-files required for the Cython coverage
  1066. plugin to map the measurements back to the PYX-files.
  1067. `#961 <https://github.com/aio-libs/yarl/issues/961>`__
  1068. - It is now possible to request line tracing in Cython builds using the
  1069. ``with-cython-tracing`` `PEP 517 <https://peps.python.org/pep-517>`__ config setting
  1070. -- `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1071. This can be used in CI and development environment to measure coverage
  1072. on Cython modules, but is not normally useful to the end-users or
  1073. downstream packagers.
  1074. Here's a usage example:
  1075. .. code-block:: console
  1076. $ python -Im pip install . --config-settings=with-cython-tracing=true
  1077. For editable installs, this setting is on by default. Otherwise, it's
  1078. off unless requested explicitly.
  1079. The following produces C-files required for the Cython coverage
  1080. plugin to map the measurements back to the PYX-files:
  1081. .. code-block:: console
  1082. $ python -Im pip install -e .
  1083. Alternatively, the ``YARL_CYTHON_TRACING=1`` environment variable
  1084. can be set to do the same as the `PEP 517 <https://peps.python.org/pep-517>`__ config setting.
  1085. `#962 <https://github.com/aio-libs/yarl/issues/962>`__
  1086. 1.9.3 (2023-11-20)
  1087. ==================
  1088. Bug fixes
  1089. ---------
  1090. - Stopped dropping trailing slashes in ``yarl.URL.joinpath()`` -- by `@gmacon <https://github.com/sponsors/gmacon>`__. (`#862 <https://github.com/aio-libs/yarl/issues/862>`__, `#866 <https://github.com/aio-libs/yarl/issues/866>`__)
  1091. - Started accepting string subclasses in ``yarl.URL.__truediv__()`` operations (``URL / segment``) -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__. (`#871 <https://github.com/aio-libs/yarl/issues/871>`__, `#884 <https://github.com/aio-libs/yarl/issues/884>`__)
  1092. - Fixed the human representation of URLs with square brackets in usernames and passwords -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__. (`#876 <https://github.com/aio-libs/yarl/issues/876>`__, `#882 <https://github.com/aio-libs/yarl/issues/882>`__)
  1093. - Updated type hints to include ``URL.missing_port()``, ``URL.__bytes__()``
  1094. and the ``encoding`` argument to ``yarl.URL.joinpath()``
  1095. -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__. (`#891 <https://github.com/aio-libs/yarl/issues/891>`__)
  1096. Packaging updates and notes for downstreams
  1097. -------------------------------------------
  1098. - Integrated Cython 3 to enable building *yarl* under Python 3.12 -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__. (`#829 <https://github.com/aio-libs/yarl/issues/829>`__, `#881 <https://github.com/aio-libs/yarl/issues/881>`__)
  1099. - Declared modern ``setuptools.build_meta`` as the `PEP 517 <https://peps.python.org/pep-517>`__ build
  1100. backend in ``pyproject.toml`` explicitly -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__. (`#886 <https://github.com/aio-libs/yarl/issues/886>`__)
  1101. - Converted most of the packaging setup into a declarative ``setup.cfg``
  1102. config -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__. (`#890 <https://github.com/aio-libs/yarl/issues/890>`__)
  1103. - The packaging is replaced from an old-fashioned ``setup.py`` to an
  1104. in-tree `PEP 517 <https://peps.python.org/pep-517>`__ build backend -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1105. Whenever the end-users or downstream packagers need to build ``yarl`` from
  1106. source (a Git checkout or an sdist), they may pass a ``config_settings``
  1107. flag ``--pure-python``. If this flag is not set, a C-extension will be built
  1108. and included into the distribution.
  1109. Here is how this can be done with ``pip``:
  1110. .. code-block:: console
  1111. $ python -m pip install . --config-settings=--pure-python=false
  1112. This will also work with ``-e | --editable``.
  1113. The same can be achieved via ``pypa/build``:
  1114. .. code-block:: console
  1115. $ python -m build --config-setting=--pure-python=false
  1116. Adding ``-w | --wheel`` can force ``pypa/build`` produce a wheel from source
  1117. directly, as opposed to building an ``sdist`` and then building from it. (`#893 <https://github.com/aio-libs/yarl/issues/893>`__)
  1118. .. attention::
  1119. v1.9.3 was the only version using the ``--pure-python`` setting name.
  1120. Later versions dropped the ``--`` prefix, making it just ``pure-python``.
  1121. - Declared Python 3.12 supported officially in the distribution package metadata
  1122. -- by `@edgarrmondragon <https://github.com/sponsors/edgarrmondragon>`__. (`#942 <https://github.com/aio-libs/yarl/issues/942>`__)
  1123. Contributor-facing changes
  1124. --------------------------
  1125. - A regression test for no-host URLs was added per `#821 <https://github.com/aio-libs/yarl/issues/821>`__
  1126. and ``3986`` -- by `@kenballus <https://github.com/sponsors/kenballus>`__. (`#821 <https://github.com/aio-libs/yarl/issues/821>`__, `#822 <https://github.com/aio-libs/yarl/issues/822>`__)
  1127. - Started testing *yarl* against Python 3.12 in CI -- by `@mjpieters <https://github.com/sponsors/mjpieters>`__. (`#881 <https://github.com/aio-libs/yarl/issues/881>`__)
  1128. - All Python 3.12 jobs are now marked as required to pass in CI
  1129. -- by `@edgarrmondragon <https://github.com/sponsors/edgarrmondragon>`__. (`#942 <https://github.com/aio-libs/yarl/issues/942>`__)
  1130. - MyST is now integrated in Sphinx -- by `@webknjaz <https://github.com/sponsors/webknjaz>`__.
  1131. This allows the contributors to author new documents in Markdown
  1132. when they have difficulties with going straight RST. (`#953 <https://github.com/aio-libs/yarl/issues/953>`__)
  1133. 1.9.2 (2023-04-25)
  1134. ==================
  1135. Bugfixes
  1136. --------
  1137. - Fix regression with ``yarl.URL.__truediv__()`` and absolute URLs with empty paths causing the raw path to lack the leading ``/``.
  1138. (`#854 <https://github.com/aio-libs/yarl/issues/854>`_)
  1139. 1.9.1 (2023-04-21)
  1140. ==================
  1141. Bugfixes
  1142. --------
  1143. - Marked tests that fail on older Python patch releases (< 3.7.10, < 3.8.8 and < 3.9.2) as expected to fail due to missing a security fix for CVE-2021-23336. (`#850 <https://github.com/aio-libs/yarl/issues/850>`_)
  1144. 1.9.0 (2023-04-19)
  1145. ==================
  1146. This release was never published to PyPI, due to issues with the build process.
  1147. Features
  1148. --------
  1149. - Added ``URL.joinpath(*elements)``, to create a new URL appending multiple path elements. (`#704 <https://github.com/aio-libs/yarl/issues/704>`_)
  1150. - Made ``URL.__truediv__()()`` return ``NotImplemented`` if called with an
  1151. unsupported type — by `@michaeljpeters <https://github.com/sponsors/michaeljpeters>`__.
  1152. (`#832 <https://github.com/aio-libs/yarl/issues/832>`_)
  1153. Bugfixes
  1154. --------
  1155. - Path normalization for absolute URLs no longer raises a ValueError exception
  1156. when ``..`` segments would otherwise go beyond the URL path root.
  1157. (`#536 <https://github.com/aio-libs/yarl/issues/536>`_)
  1158. - Fixed an issue with update_query() not getting rid of the query when argument is None. (`#792 <https://github.com/aio-libs/yarl/issues/792>`_)
  1159. - Added some input restrictions on with_port() function to prevent invalid boolean inputs or out of valid port inputs; handled incorrect 0 port representation. (`#793 <https://github.com/aio-libs/yarl/issues/793>`_)
  1160. - Made ``yarl.URL.build()`` raise a ``TypeError`` if the ``host`` argument is ``None`` — by `@paulpapacz <https://github.com/sponsors/paulpapacz>`__. (`#808 <https://github.com/aio-libs/yarl/issues/808>`_)
  1161. - Fixed an issue with ``update_query()`` getting rid of the query when the argument
  1162. is empty but not ``None``. (`#845 <https://github.com/aio-libs/yarl/issues/845>`_)
  1163. Misc
  1164. ----
  1165. - `#220 <https://github.com/aio-libs/yarl/issues/220>`_
  1166. 1.8.2 (2022-12-03)
  1167. ==================
  1168. This is the first release that started shipping wheels for Python 3.11.
  1169. 1.8.1 (2022-08-01)
  1170. ==================
  1171. Misc
  1172. ----
  1173. - `#694 <https://github.com/aio-libs/yarl/issues/694>`_, `#699 <https://github.com/aio-libs/yarl/issues/699>`_, `#700 <https://github.com/aio-libs/yarl/issues/700>`_, `#701 <https://github.com/aio-libs/yarl/issues/701>`_, `#702 <https://github.com/aio-libs/yarl/issues/702>`_, `#703 <https://github.com/aio-libs/yarl/issues/703>`_, `#739 <https://github.com/aio-libs/yarl/issues/739>`_
  1174. 1.8.0 (2022-08-01)
  1175. ==================
  1176. Features
  1177. --------
  1178. - Added ``URL.raw_suffix``, ``URL.suffix``, ``URL.raw_suffixes``, ``URL.suffixes``, ``URL.with_suffix``. (`#613 <https://github.com/aio-libs/yarl/issues/613>`_)
  1179. Improved Documentation
  1180. ----------------------
  1181. - Fixed broken internal references to ``yarl.URL.human_repr()``.
  1182. (`#665 <https://github.com/aio-libs/yarl/issues/665>`_)
  1183. - Fixed broken external references to ``multidict:index`` docs. (`#665 <https://github.com/aio-libs/yarl/issues/665>`_)
  1184. Deprecations and Removals
  1185. -------------------------
  1186. - Dropped Python 3.6 support. (`#672 <https://github.com/aio-libs/yarl/issues/672>`_)
  1187. Misc
  1188. ----
  1189. - `#646 <https://github.com/aio-libs/yarl/issues/646>`_, `#699 <https://github.com/aio-libs/yarl/issues/699>`_, `#701 <https://github.com/aio-libs/yarl/issues/701>`_
  1190. 1.7.2 (2021-11-01)
  1191. ==================
  1192. Bugfixes
  1193. --------
  1194. - Changed call in ``with_port()`` to stop reencoding parts of the URL that were already encoded. (`#623 <https://github.com/aio-libs/yarl/issues/623>`_)
  1195. 1.7.1 (2021-10-07)
  1196. ==================
  1197. Bugfixes
  1198. --------
  1199. - Fix 1.7.0 build error
  1200. 1.7.0 (2021-10-06)
  1201. ==================
  1202. Features
  1203. --------
  1204. - Add ``__bytes__()`` magic method so that ``bytes(url)`` will work and use optimal ASCII encoding.
  1205. (`#582 <https://github.com/aio-libs/yarl/issues/582>`_)
  1206. - Started shipping platform-specific arm64 wheels for Apple Silicon. (`#622 <https://github.com/aio-libs/yarl/issues/622>`_)
  1207. - Started shipping platform-specific wheels with the ``musl`` tag targeting typical Alpine Linux runtimes. (`#622 <https://github.com/aio-libs/yarl/issues/622>`_)
  1208. - Added support for Python 3.10. (`#622 <https://github.com/aio-libs/yarl/issues/622>`_)
  1209. 1.6.3 (2020-11-14)
  1210. ==================
  1211. Bugfixes
  1212. --------
  1213. - No longer loose characters when decoding incorrect percent-sequences (like ``%e2%82%f8``). All non-decodable percent-sequences are now preserved.
  1214. `#517 <https://github.com/aio-libs/yarl/issues/517>`_
  1215. - Provide x86 Windows wheels.
  1216. `#535 <https://github.com/aio-libs/yarl/issues/535>`_
  1217. ----
  1218. 1.6.2 (2020-10-12)
  1219. ==================
  1220. Bugfixes
  1221. --------
  1222. - Provide generated ``.c`` files in TarBall distribution.
  1223. `#530 <https://github.com/aio-libs/multidict/issues/530>`_
  1224. 1.6.1 (2020-10-12)
  1225. ==================
  1226. Features
  1227. --------
  1228. - Provide wheels for ``aarch64``, ``i686``, ``ppc64le``, ``s390x`` architectures on
  1229. Linux as well as ``x86_64``.
  1230. `#507 <https://github.com/aio-libs/yarl/issues/507>`_
  1231. - Provide wheels for Python 3.9.
  1232. `#526 <https://github.com/aio-libs/yarl/issues/526>`_
  1233. Bugfixes
  1234. --------
  1235. - ``human_repr()`` now always produces valid representation equivalent to the original URL (if the original URL is valid).
  1236. `#511 <https://github.com/aio-libs/yarl/issues/511>`_
  1237. - Fixed requoting a single percent followed by a percent-encoded character in the Cython implementation.
  1238. `#514 <https://github.com/aio-libs/yarl/issues/514>`_
  1239. - Fix ValueError when decoding ``%`` which is not followed by two hexadecimal digits.
  1240. `#516 <https://github.com/aio-libs/yarl/issues/516>`_
  1241. - Fix decoding ``%`` followed by a space and hexadecimal digit.
  1242. `#520 <https://github.com/aio-libs/yarl/issues/520>`_
  1243. - Fix annotation of ``with_query()``/``update_query()`` methods for ``key=[val1, val2]`` case.
  1244. `#528 <https://github.com/aio-libs/yarl/issues/528>`_
  1245. Removal
  1246. -------
  1247. - Drop Python 3.5 support; Python 3.6 is the minimal supported Python version.
  1248. ----
  1249. 1.6.0 (2020-09-23)
  1250. ==================
  1251. Features
  1252. --------
  1253. - Allow for int and float subclasses in query, while still denying bool.
  1254. `#492 <https://github.com/aio-libs/yarl/issues/492>`_
  1255. Bugfixes
  1256. --------
  1257. - Do not requote arguments in ``URL.build()``, ``with_xxx()`` and in ``/`` operator.
  1258. `#502 <https://github.com/aio-libs/yarl/issues/502>`_
  1259. - Keep IPv6 brackets in ``origin()``.
  1260. `#504 <https://github.com/aio-libs/yarl/issues/504>`_
  1261. ----
  1262. 1.5.1 (2020-08-01)
  1263. ==================
  1264. Bugfixes
  1265. --------
  1266. - Fix including relocated internal ``yarl._quoting_c`` C-extension into published PyPI dists.
  1267. `#485 <https://github.com/aio-libs/yarl/issues/485>`_
  1268. Misc
  1269. ----
  1270. - `#484 <https://github.com/aio-libs/yarl/issues/484>`_
  1271. ----
  1272. 1.5.0 (2020-07-26)
  1273. ==================
  1274. Features
  1275. --------
  1276. - Convert host to lowercase on URL building.
  1277. `#386 <https://github.com/aio-libs/yarl/issues/386>`_
  1278. - Allow using ``mod`` operator (``%``) for updating query string (an alias for ``update_query()`` method).
  1279. `#435 <https://github.com/aio-libs/yarl/issues/435>`_
  1280. - Allow use of sequences such as ``list`` and ``tuple`` in the values
  1281. of a mapping such as ``dict`` to represent that a key has many values::
  1282. url = URL("http://example.com")
  1283. assert url.with_query({"a": [1, 2]}) == URL("http://example.com/?a=1&a=2")
  1284. `#443 <https://github.com/aio-libs/yarl/issues/443>`_
  1285. - Support ``URL.build()`` with scheme and path (creates a relative URL).
  1286. `#464 <https://github.com/aio-libs/yarl/issues/464>`_
  1287. - Cache slow IDNA encode/decode calls.
  1288. `#476 <https://github.com/aio-libs/yarl/issues/476>`_
  1289. - Add ``@final`` / ``Final`` type hints
  1290. `#477 <https://github.com/aio-libs/yarl/issues/477>`_
  1291. - Support URL authority/raw_authority properties and authority argument of ``URL.build()`` method.
  1292. `#478 <https://github.com/aio-libs/yarl/issues/478>`_
  1293. - Hide the library implementation details, make the exposed public list very clean.
  1294. `#483 <https://github.com/aio-libs/yarl/issues/483>`_
  1295. Bugfixes
  1296. --------
  1297. - Fix tests with newer Python (3.7.6, 3.8.1 and 3.9.0+).
  1298. `#409 <https://github.com/aio-libs/yarl/issues/409>`_
  1299. - Fix a bug where query component, passed in a form of mapping or sequence, is unquoted in unexpected way.
  1300. `#426 <https://github.com/aio-libs/yarl/issues/426>`_
  1301. - Hide ``Query`` and ``QueryVariable`` type aliases in ``__init__.pyi``, now they are prefixed with underscore.
  1302. `#431 <https://github.com/aio-libs/yarl/issues/431>`_
  1303. - Keep IPv6 brackets after updating port/user/password.
  1304. `#451 <https://github.com/aio-libs/yarl/issues/451>`_
  1305. ----
  1306. 1.4.2 (2019-12-05)
  1307. ==================
  1308. Features
  1309. --------
  1310. - Workaround for missing ``str.isascii()`` in Python 3.6
  1311. `#389 <https://github.com/aio-libs/yarl/issues/389>`_
  1312. ----
  1313. 1.4.1 (2019-11-29)
  1314. ==================
  1315. * Fix regression, make the library work on Python 3.5 and 3.6 again.
  1316. 1.4.0 (2019-11-29)
  1317. ==================
  1318. * Distinguish an empty password in URL from a password not provided at all (#262)
  1319. * Fixed annotations for optional parameters of ``URL.build`` (#309)
  1320. * Use None as default value of ``user`` parameter of ``URL.build`` (#309)
  1321. * Enforce building C Accelerated modules when installing from source tarball, use
  1322. ``YARL_NO_EXTENSIONS`` environment variable for falling back to (slower) Pure Python
  1323. implementation (#329)
  1324. * Drop Python 3.5 support
  1325. * Fix quoting of plus in path by pure python version (#339)
  1326. * Don't create a new URL if fragment is unchanged (#292)
  1327. * Included in error message the path that produces starting slash forbidden error (#376)
  1328. * Skip slow IDNA encoding for ASCII-only strings (#387)
  1329. 1.3.0 (2018-12-11)
  1330. ==================
  1331. * Fix annotations for ``query`` parameter (#207)
  1332. * An incoming query sequence can have int variables (the same as for
  1333. Mapping type) (#208)
  1334. * Add ``URL.explicit_port`` property (#218)
  1335. * Give a friendlier error when port can't be converted to int (#168)
  1336. * ``bool(URL())`` now returns ``False`` (#272)
  1337. 1.2.6 (2018-06-14)
  1338. ==================
  1339. * Drop Python 3.4 trove classifier (#205)
  1340. 1.2.5 (2018-05-23)
  1341. ==================
  1342. * Fix annotations for ``build`` (#199)
  1343. 1.2.4 (2018-05-08)
  1344. ==================
  1345. * Fix annotations for ``cached_property`` (#195)
  1346. 1.2.3 (2018-05-03)
  1347. ==================
  1348. * Accept ``str`` subclasses in ``URL`` constructor (#190)
  1349. 1.2.2 (2018-05-01)
  1350. ==================
  1351. * Fix build
  1352. 1.2.1 (2018-04-30)
  1353. ==================
  1354. * Pin minimal required Python to 3.5.3 (#189)
  1355. 1.2.0 (2018-04-30)
  1356. ==================
  1357. * Forbid inheritance, replace ``__init__`` with ``__new__`` (#171)
  1358. * Support PEP-561 (provide type hinting marker) (#182)
  1359. 1.1.1 (2018-02-17)
  1360. ==================
  1361. * Fix performance regression: don't encode empty ``netloc`` (#170)
  1362. 1.1.0 (2018-01-21)
  1363. ==================
  1364. * Make pure Python quoter consistent with Cython version (#162)
  1365. 1.0.0 (2018-01-15)
  1366. ==================
  1367. * Use fast path if quoted string does not need requoting (#154)
  1368. * Speed up quoting/unquoting by ``_Quoter`` and ``_Unquoter`` classes (#155)
  1369. * Drop ``yarl.quote`` and ``yarl.unquote`` public functions (#155)
  1370. * Add custom string writer, reuse static buffer if available (#157)
  1371. Code is 50-80 times faster than Pure Python version (was 4-5 times faster)
  1372. * Don't recode IP zone (#144)
  1373. * Support ``encoded=True`` in ``yarl.URL.build()`` (#158)
  1374. * Fix updating query with multiple keys (#160)
  1375. 0.18.0 (2018-01-10)
  1376. ===================
  1377. * Fallback to IDNA 2003 if domain name is not IDNA 2008 compatible (#152)
  1378. 0.17.0 (2017-12-30)
  1379. ===================
  1380. * Use IDNA 2008 for domain name processing (#149)
  1381. 0.16.0 (2017-12-07)
  1382. ===================
  1383. * Fix raising ``TypeError`` by ``url.query_string()`` after
  1384. ``url.with_query({})`` (empty mapping) (#141)
  1385. 0.15.0 (2017-11-23)
  1386. ===================
  1387. * Add ``raw_path_qs`` attribute (#137)
  1388. 0.14.2 (2017-11-14)
  1389. ===================
  1390. * Restore ``strict`` parameter as no-op in ``quote`` / ``unquote``
  1391. 0.14.1 (2017-11-13)
  1392. ===================
  1393. * Restore ``strict`` parameter as no-op for sake of compatibility with
  1394. aiohttp 2.2
  1395. 0.14.0 (2017-11-11)
  1396. ===================
  1397. * Drop strict mode (#123)
  1398. * Fix ``"ValueError: Unallowed PCT %"`` when there's a ``"%"`` in the URL (#124)
  1399. 0.13.0 (2017-10-01)
  1400. ===================
  1401. * Document ``encoded`` parameter (#102)
  1402. * Support relative URLs like ``'?key=value'`` (#100)
  1403. * Unsafe encoding for QS fixed. Encode ``;`` character in value parameter (#104)
  1404. * Process passwords without user names (#95)
  1405. 0.12.0 (2017-06-26)
  1406. ===================
  1407. * Properly support paths without leading slash in ``URL.with_path()`` (#90)
  1408. * Enable type annotation checks
  1409. 0.11.0 (2017-06-26)
  1410. ===================
  1411. * Normalize path (#86)
  1412. * Clear query and fragment parts in ``.with_path()`` (#85)
  1413. 0.10.3 (2017-06-13)
  1414. ===================
  1415. * Prevent double URL arguments unquoting (#83)
  1416. 0.10.2 (2017-05-05)
  1417. ===================
  1418. * Unexpected hash behavior (#75)
  1419. 0.10.1 (2017-05-03)
  1420. ===================
  1421. * Unexpected compare behavior (#73)
  1422. * Do not quote or unquote + if not a query string. (#74)
  1423. 0.10.0 (2017-03-14)
  1424. ===================
  1425. * Added ``URL.build`` class method (#58)
  1426. * Added ``path_qs`` attribute (#42)
  1427. 0.9.8 (2017-02-16)
  1428. ==================
  1429. * Do not quote ``:`` in path
  1430. 0.9.7 (2017-02-16)
  1431. ==================
  1432. * Load from pickle without _cache (#56)
  1433. * Percent-encoded pluses in path variables become spaces (#59)
  1434. 0.9.6 (2017-02-15)
  1435. ==================
  1436. * Revert backward incompatible change (BaseURL)
  1437. 0.9.5 (2017-02-14)
  1438. ==================
  1439. * Fix BaseURL rich comparison support
  1440. 0.9.4 (2017-02-14)
  1441. ==================
  1442. * Use BaseURL
  1443. 0.9.3 (2017-02-14)
  1444. ==================
  1445. * Added BaseURL
  1446. 0.9.2 (2017-02-08)
  1447. ==================
  1448. * Remove debug print
  1449. 0.9.1 (2017-02-07)
  1450. ==================
  1451. * Do not lose tail chars (#45)
  1452. 0.9.0 (2017-02-07)
  1453. ==================
  1454. * Allow to quote ``%`` in non strict mode (#21)
  1455. * Incorrect parsing of query parameters with %3B (;) inside (#34)
  1456. * Fix core dumps (#41)
  1457. * ``tmpbuf`` - compiling error (#43)
  1458. * Added ``URL.update_path()`` method
  1459. * Added ``URL.update_query()`` method (#47)
  1460. 0.8.1 (2016-12-03)
  1461. ==================
  1462. * Fix broken aiohttp: revert back ``quote`` / ``unquote``.
  1463. 0.8.0 (2016-12-03)
  1464. ==================
  1465. * Support more verbose error messages in ``.with_query()`` (#24)
  1466. * Don't percent-encode ``@`` and ``:`` in path (#32)
  1467. * Don't expose ``yarl.quote`` and ``yarl.unquote``, these functions are
  1468. part of private API
  1469. 0.7.1 (2016-11-18)
  1470. ==================
  1471. * Accept not only ``str`` but all classes inherited from ``str`` also (#25)
  1472. 0.7.0 (2016-11-07)
  1473. ==================
  1474. * Accept ``int`` as value for ``.with_query()``
  1475. 0.6.0 (2016-11-07)
  1476. ==================
  1477. * Explicitly use UTF8 encoding in ``setup.py`` (#20)
  1478. * Properly unquote non-UTF8 strings (#19)
  1479. 0.5.3 (2016-11-02)
  1480. ==================
  1481. * Don't use ``typing.NamedTuple`` fields but indexes on URL construction
  1482. 0.5.2 (2016-11-02)
  1483. ==================
  1484. * Inline ``_encode`` class method
  1485. 0.5.1 (2016-11-02)
  1486. ==================
  1487. * Make URL construction faster by removing extra classmethod calls
  1488. 0.5.0 (2016-11-02)
  1489. ==================
  1490. * Add Cython optimization for quoting/unquoting
  1491. * Provide binary wheels
  1492. 0.4.3 (2016-09-29)
  1493. ==================
  1494. * Fix typing stubs
  1495. 0.4.2 (2016-09-29)
  1496. ==================
  1497. * Expose ``quote()`` and ``unquote()`` as public API
  1498. 0.4.1 (2016-09-28)
  1499. ==================
  1500. * Support empty values in query (``'/path?arg'``)
  1501. 0.4.0 (2016-09-27)
  1502. ==================
  1503. * Introduce ``relative()`` (#16)
  1504. 0.3.2 (2016-09-27)
  1505. ==================
  1506. * Typo fixes #15
  1507. 0.3.1 (2016-09-26)
  1508. ==================
  1509. * Support sequence of pairs as ``with_query()`` parameter
  1510. 0.3.0 (2016-09-26)
  1511. ==================
  1512. * Introduce ``is_default_port()``
  1513. 0.2.1 (2016-09-26)
  1514. ==================
  1515. * Raise ValueError for URLs like 'http://:8080/'
  1516. 0.2.0 (2016-09-18)
  1517. ==================
  1518. * Avoid doubling slashes when joining paths (#13)
  1519. * Appending path starting from slash is forbidden (#12)
  1520. 0.1.4 (2016-09-09)
  1521. ==================
  1522. * Add ``kwargs`` support for ``with_query()`` (#10)
  1523. 0.1.3 (2016-09-07)
  1524. ==================
  1525. * Document ``with_query()``, ``with_fragment()`` and ``origin()``
  1526. * Allow ``None`` for ``with_query()`` and ``with_fragment()``
  1527. 0.1.2 (2016-09-07)
  1528. ==================
  1529. * Fix links, tune docs theme.
  1530. 0.1.1 (2016-09-06)
  1531. ==================
  1532. * Update README, old version used obsolete API
  1533. 0.1.0 (2016-09-06)
  1534. ==================
  1535. * The library was deeply refactored, bytes are gone away but all
  1536. accepted strings are encoded if needed.
  1537. 0.0.1 (2016-08-30)
  1538. ==================
  1539. * The first release.