From 7a3a1ed8c9c71a269f16698c98f6f6d402d20d6f Mon Sep 17 00:00:00 2001 From: wyn <1074145239@qq.com> Date: Tue, 26 May 2026 18:01:32 +0800 Subject: [PATCH] Changes --- public/nginx.htaccess | 6 + sql/article_main_ref_check_status.sql | 4 + sql/reference_check_result.sql | 28 + ...reference_check_result_alter_positions.sql | 7 + sql/reference_check_result_can_support.sql | 3 + thinkphp/library/think/cache/driver/Redis.php | 2 +- vendor/aliemail/email.php | 237 - vendor/autoload.php | 7 +- vendor/composer/InstalledVersions.php | 45 +- vendor/composer/autoload_classmap.php | 4 + vendor/composer/autoload_files.php | 5 +- vendor/composer/autoload_psr4.php | 4 +- vendor/composer/autoload_real.php | 10 +- vendor/composer/autoload_static.php | 137 +- vendor/composer/installed.json | 5254 +++++++++-------- vendor/composer/installed.php | 108 +- vendor/composer/platform_check.php | 5 +- vendor/doctrine/annotations/LICENSE | 19 - vendor/doctrine/annotations/README.md | 18 - vendor/doctrine/annotations/composer.json | 44 - .../annotations/docs/en/annotations.rst | 252 - .../doctrine/annotations/docs/en/custom.rst | 443 -- vendor/doctrine/annotations/docs/en/index.rst | 101 - .../doctrine/annotations/docs/en/sidebar.rst | 6 - .../Common/Annotations/Annotation.php | 59 - .../Annotations/Annotation/Attribute.php | 21 - .../Annotations/Annotation/Attributes.php | 15 - .../Common/Annotations/Annotation/Enum.php | 69 - .../Annotation/IgnoreAnnotation.php | 43 - .../Annotation/NamedArgumentConstructor.php | 13 - .../Annotations/Annotation/Required.php | 13 - .../Common/Annotations/Annotation/Target.php | 101 - .../Annotations/AnnotationException.php | 171 - .../Common/Annotations/AnnotationReader.php | 389 -- .../Common/Annotations/AnnotationRegistry.php | 190 - .../Common/Annotations/CachedReader.php | 268 - .../Doctrine/Common/Annotations/DocLexer.php | 129 - .../Doctrine/Common/Annotations/DocParser.php | 1459 ----- .../Common/Annotations/FileCacheReader.php | 315 - .../ImplicitlyIgnoredAnnotationNames.php | 177 - .../Common/Annotations/IndexedReader.php | 100 - .../NamedArgumentConstructorAnnotation.php | 14 - .../Doctrine/Common/Annotations/PhpParser.php | 92 - .../Common/Annotations/PsrCachedReader.php | 232 - .../Doctrine/Common/Annotations/Reader.php | 80 - .../Annotations/SimpleAnnotationReader.php | 114 - .../Common/Annotations/TokenParser.php | 208 - vendor/doctrine/lexer/LICENSE | 19 - vendor/doctrine/lexer/README.md | 9 - vendor/doctrine/lexer/composer.json | 41 - .../Doctrine/Common/Lexer/AbstractLexer.php | 328 - vendor/fpdf/FAQ.htm | 341 -- vendor/fpdf/bg.png | Bin 162471 -> 0 bytes vendor/fpdf/changelog.htm | 146 - vendor/fpdf/doc/acceptpagebreak.htm | 63 - vendor/fpdf/doc/addfont.htm | 55 - vendor/fpdf/doc/addlink.htm | 26 - vendor/fpdf/doc/addpage.htm | 56 - vendor/fpdf/doc/aliasnbpages.htm | 45 - vendor/fpdf/doc/cell.htm | 104 - vendor/fpdf/doc/close.htm | 21 - vendor/fpdf/doc/error.htm | 25 - vendor/fpdf/doc/footer.htm | 35 - vendor/fpdf/doc/fpdf.htm | 63 - vendor/fpdf/doc/getstringwidth.htm | 23 - vendor/fpdf/doc/getx.htm | 20 - vendor/fpdf/doc/gety.htm | 20 - vendor/fpdf/doc/header.htm | 37 - vendor/fpdf/doc/image.htm | 99 - vendor/fpdf/doc/index.htm | 57 - vendor/fpdf/doc/line.htm | 38 - vendor/fpdf/doc/link.htm | 46 - vendor/fpdf/doc/ln.htm | 28 - vendor/fpdf/doc/multicell.htm | 76 - vendor/fpdf/doc/output.htm | 42 - vendor/fpdf/doc/pageno.htm | 18 - vendor/fpdf/doc/rect.htm | 48 - vendor/fpdf/doc/setauthor.htm | 33 - vendor/fpdf/doc/setautopagebreak.htm | 33 - vendor/fpdf/doc/setcompression.htm | 31 - vendor/fpdf/doc/setcreator.htm | 34 - vendor/fpdf/doc/setdisplaymode.htm | 45 - vendor/fpdf/doc/setdrawcolor.htm | 41 - vendor/fpdf/doc/setfillcolor.htm | 40 - vendor/fpdf/doc/setfont.htm | 92 - vendor/fpdf/doc/setfontsize.htm | 25 - vendor/fpdf/doc/setkeywords.htm | 33 - vendor/fpdf/doc/setleftmargin.htm | 30 - vendor/fpdf/doc/setlinewidth.htm | 29 - vendor/fpdf/doc/setlink.htm | 34 - vendor/fpdf/doc/setmargins.htm | 37 - vendor/fpdf/doc/setrightmargin.htm | 28 - vendor/fpdf/doc/setsubject.htm | 33 - vendor/fpdf/doc/settextcolor.htm | 40 - vendor/fpdf/doc/settitle.htm | 33 - vendor/fpdf/doc/settopmargin.htm | 28 - vendor/fpdf/doc/setx.htm | 29 - vendor/fpdf/doc/setxy.htm | 31 - vendor/fpdf/doc/sety.htm | 29 - vendor/fpdf/doc/text.htm | 39 - vendor/fpdf/doc/write.htm | 51 - vendor/fpdf/font/courier.php | 8 - vendor/fpdf/font/courierb.php | 8 - vendor/fpdf/font/courierbi.php | 8 - vendor/fpdf/font/courieri.php | 8 - vendor/fpdf/font/helvetica.php | 19 - vendor/fpdf/font/helveticab.php | 19 - vendor/fpdf/font/helveticabi.php | 19 - vendor/fpdf/font/helveticai.php | 19 - vendor/fpdf/font/symbol.php | 19 - vendor/fpdf/font/times.php | 19 - vendor/fpdf/font/timesb.php | 19 - vendor/fpdf/font/timesbi.php | 19 - vendor/fpdf/font/timesi.php | 19 - vendor/fpdf/font/zapfdingbats.php | 19 - vendor/fpdf/fpdf.css | 21 - vendor/fpdf/fpdf.php | 1804 ------ vendor/fpdf/install.txt | 15 - vendor/fpdf/license.txt | 6 - vendor/fpdf/makefont/cp1250.map | 251 - vendor/fpdf/makefont/cp1251.map | 255 - vendor/fpdf/makefont/cp1252.map | 251 - vendor/fpdf/makefont/cp1253.map | 239 - vendor/fpdf/makefont/cp1254.map | 249 - vendor/fpdf/makefont/cp1255.map | 233 - vendor/fpdf/makefont/cp1257.map | 244 - vendor/fpdf/makefont/cp1258.map | 247 - vendor/fpdf/makefont/cp874.map | 225 - vendor/fpdf/makefont/iso-8859-1.map | 256 - vendor/fpdf/makefont/iso-8859-11.map | 248 - vendor/fpdf/makefont/iso-8859-15.map | 256 - vendor/fpdf/makefont/iso-8859-16.map | 256 - vendor/fpdf/makefont/iso-8859-2.map | 256 - vendor/fpdf/makefont/iso-8859-4.map | 256 - vendor/fpdf/makefont/iso-8859-5.map | 256 - vendor/fpdf/makefont/iso-8859-7.map | 250 - vendor/fpdf/makefont/iso-8859-9.map | 256 - vendor/fpdf/makefont/koi8-r.map | 256 - vendor/fpdf/makefont/koi8-u.map | 256 - vendor/fpdf/makefont/makefont.php | 373 -- vendor/fpdf/makefont/ttfparser.php | 289 - vendor/fpdf/tutorial/20k_c1.txt | 10 - vendor/fpdf/tutorial/20k_c2.txt | 23 - vendor/fpdf/tutorial/calligra.php | 23 - vendor/fpdf/tutorial/calligra.ttf | Bin 40120 -> 0 bytes vendor/fpdf/tutorial/calligra.z | Bin 25604 -> 0 bytes vendor/fpdf/tutorial/countries.txt | 15 - vendor/fpdf/tutorial/index.htm | 20 - vendor/fpdf/tutorial/logo.png | Bin 2373 -> 0 bytes vendor/fpdf/tutorial/makefont.php | 6 - vendor/fpdf/tutorial/tuto1.htm | 76 - vendor/fpdf/tutorial/tuto1.php | 9 - vendor/fpdf/tutorial/tuto2.htm | 80 - vendor/fpdf/tutorial/tuto2.php | 41 - vendor/fpdf/tutorial/tuto3.htm | 115 - vendor/fpdf/tutorial/tuto3.php | 81 - vendor/fpdf/tutorial/tuto4.htm | 134 - vendor/fpdf/tutorial/tuto4.php | 111 - vendor/fpdf/tutorial/tuto5.htm | 134 - vendor/fpdf/tutorial/tuto5.php | 102 - vendor/fpdf/tutorial/tuto6.htm | 165 - vendor/fpdf/tutorial/tuto6.php | 124 - vendor/fpdf/tutorial/tuto7.htm | 241 - vendor/fpdf/tutorial/tuto7.php | 11 - vendor/fpdi/filters/FilterASCII85.php | 114 - vendor/fpdi/filters/FilterASCIIHexDecode.php | 52 - vendor/fpdi/filters/FilterLZW.php | 173 - vendor/fpdi/fpdf_tpl.php | 555 -- vendor/fpdi/fpdi.php | 699 --- vendor/fpdi/fpdi_bridge.php | 215 - vendor/fpdi/fpdi_pdf_parser.php | 354 -- vendor/fpdi/pdf_context.php | 153 - vendor/fpdi/pdf_parser.php | 913 --- vendor/hg/apidoc/.github/workflows/mirror.yml | 17 - vendor/hg/apidoc/.gitignore | 1 - vendor/hg/apidoc/LICENSE | 21 - vendor/hg/apidoc/README.md | 79 - vendor/hg/apidoc/composer.json | 43 - vendor/hg/apidoc/src/Auth.php | 172 - vendor/hg/apidoc/src/Controller.php | 259 - vendor/hg/apidoc/src/Service.php | 35 - vendor/hg/apidoc/src/Utils.php | 330 -- vendor/hg/apidoc/src/annotation/AddField.php | 44 - vendor/hg/apidoc/src/annotation/Author.php | 14 - vendor/hg/apidoc/src/annotation/Desc.php | 14 - vendor/hg/apidoc/src/annotation/Field.php | 14 - vendor/hg/apidoc/src/annotation/Group.php | 14 - vendor/hg/apidoc/src/annotation/Header.php | 40 - vendor/hg/apidoc/src/annotation/Method.php | 14 - vendor/hg/apidoc/src/annotation/Param.php | 27 - vendor/hg/apidoc/src/annotation/ParamBase.php | 62 - vendor/hg/apidoc/src/annotation/ParamType.php | 14 - vendor/hg/apidoc/src/annotation/Returned.php | 34 - vendor/hg/apidoc/src/annotation/Route.php | 17 - vendor/hg/apidoc/src/annotation/Rule.php | 77 - vendor/hg/apidoc/src/annotation/Sort.php | 14 - vendor/hg/apidoc/src/annotation/Tag.php | 14 - vendor/hg/apidoc/src/annotation/Title.php | 14 - vendor/hg/apidoc/src/annotation/Url.php | 14 - .../hg/apidoc/src/annotation/WithoutField.php | 14 - vendor/hg/apidoc/src/config.php | 62 - vendor/hg/apidoc/src/crud/CreateCrud.php | 383 -- .../hg/apidoc/src/exception/AuthException.php | 33 - .../apidoc/src/exception/ErrorException.php | 44 - .../hg/apidoc/src/parseApi/CacheApiData.php | 127 - .../apidoc/src/parseApi/ParseAnnotation.php | 663 --- .../hg/apidoc/src/parseApi/ParseMarkdown.php | 71 - vendor/hg/apidoc/src/parseApi/ParseModel.php | 236 - vendor/itxq/api-doc-php/.gitignore | 3 - vendor/itxq/api-doc-php/LICENSE | 191 - vendor/itxq/api-doc-php/README.md | 49 - .../api-doc-php/assets/css/bootstrap.min.css | 7 - vendor/itxq/api-doc-php/assets/index.html | 193 - .../api-doc-php/assets/js/bootstrap.min.js | 7 - .../itxq/api-doc-php/assets/js/jquery.min.js | 2 - vendor/itxq/api-doc-php/composer.json | 20 - vendor/itxq/api-doc-php/src/ApiDoc.php | 126 - .../itxq/api-doc-php/src/BootstrapApiDoc.php | 357 -- .../itxq/api-doc-php/src/lib/ParseComment.php | 87 - vendor/itxq/api-doc-php/src/lib/ParseLine.php | 73 - vendor/itxq/api-doc-php/src/lib/Tools.php | 82 - vendor/itxq/api-doc-php/test/Api.php | 49 - vendor/itxq/api-doc-php/test/Api2.php | 33 - vendor/itxq/api-doc-php/test/index.php | 22 - vendor/phpmailer/phpmailer/.editorconfig | 15 - vendor/phpmailer/phpmailer/README.md | 17 +- vendor/phpmailer/phpmailer/VERSION | 2 +- .../phpmailer/language/phpmailer.lang-pt.php | 41 +- vendor/phpmailer/phpmailer/src/PHPMailer.php | 142 +- vendor/phpmailer/phpmailer/src/POP3.php | 2 +- vendor/phpmailer/phpmailer/src/SMTP.php | 44 +- .../phpoffice/math/.github/workflows/php.yml | 2 + vendor/phpoffice/math/docs/index.md | 2 +- vendor/phpoffice/math/mkdocs.yml | 4 +- .../phpoffice/math/src/Math/Reader/MathML.php | 12 +- .../phpoffice/math/src/Math/Writer/MathML.php | 23 + .../math/tests/Math/Reader/MathMLTest.php | 12 + .../math/tests/Math/Writer/MathMLTest.php | 29 + vendor/phpoffice/phpword/LICENSE | 2 +- vendor/phpoffice/phpword/README.md | 11 +- vendor/phpoffice/phpword/bootstrap.php | 28 - vendor/phpoffice/phpword/composer.json | 91 +- vendor/phpoffice/phpword/mkdocs.yml | 5 +- .../phpoffice/phpword/phpstan-baseline.neon | 140 +- vendor/phpoffice/phpword/phpword.ini.dist | 1 + .../PhpWord/Collection/AbstractCollection.php | 2 + .../src/PhpWord/Collection/Bookmarks.php | 2 + .../phpword/src/PhpWord/Collection/Charts.php | 2 + .../src/PhpWord/Collection/Comments.php | 2 + .../src/PhpWord/Collection/Endnotes.php | 2 + .../src/PhpWord/Collection/Footnotes.php | 2 + .../phpword/src/PhpWord/Collection/Titles.php | 2 + .../ComplexType/FootnoteProperties.php | 1 + .../src/PhpWord/ComplexType/ProofState.php | 1 + .../src/PhpWord/ComplexType/TblWidth.php | 1 + .../PhpWord/ComplexType/TrackChangesView.php | 1 + .../src/PhpWord/Element/AbstractContainer.php | 22 +- .../src/PhpWord/Element/AbstractElement.php | 13 +- .../phpword/src/PhpWord/Element/Bookmark.php | 1 + .../phpword/src/PhpWord/Element/Cell.php | 7 +- .../phpword/src/PhpWord/Element/Chart.php | 5 +- .../phpword/src/PhpWord/Element/CheckBox.php | 1 + .../phpword/src/PhpWord/Element/Comment.php | 5 +- .../phpword/src/PhpWord/Element/Endnote.php | 1 + .../phpword/src/PhpWord/Element/Field.php | 11 +- .../phpword/src/PhpWord/Element/Footer.php | 1 + .../phpword/src/PhpWord/Element/Footnote.php | 7 +- .../phpword/src/PhpWord/Element/FormField.php | 1 + .../phpword/src/PhpWord/Element/Formula.php | 1 + .../phpword/src/PhpWord/Element/Header.php | 1 + .../phpword/src/PhpWord/Element/Image.php | 1 + .../phpword/src/PhpWord/Element/Line.php | 5 +- .../phpword/src/PhpWord/Element/Link.php | 13 +- .../phpword/src/PhpWord/Element/ListItem.php | 9 +- .../src/PhpWord/Element/ListItemRun.php | 5 +- .../phpword/src/PhpWord/Element/OLEObject.php | 5 +- .../phpword/src/PhpWord/Element/PageBreak.php | 1 + .../src/PhpWord/Element/PreserveText.php | 9 +- .../phpword/src/PhpWord/Element/Row.php | 11 +- .../phpword/src/PhpWord/Element/SDT.php | 1 + .../phpword/src/PhpWord/Element/Section.php | 9 +- .../phpword/src/PhpWord/Element/Shape.php | 5 +- .../phpword/src/PhpWord/Element/TOC.php | 11 +- .../phpword/src/PhpWord/Element/Table.php | 15 +- .../phpword/src/PhpWord/Element/Text.php | 23 +- .../phpword/src/PhpWord/Element/TextBox.php | 5 +- .../phpword/src/PhpWord/Element/TextBreak.php | 15 +- .../phpword/src/PhpWord/Element/TextRun.php | 4 + .../phpword/src/PhpWord/Element/Title.php | 1 + .../src/PhpWord/Element/TrackChange.php | 1 + .../src/PhpWord/Escaper/AbstractEscaper.php | 1 + .../src/PhpWord/Escaper/EscaperInterface.php | 1 + .../phpword/src/PhpWord/Escaper/RegExp.php | 1 + .../phpword/src/PhpWord/Escaper/Rtf.php | 1 + .../phpword/src/PhpWord/Escaper/Xml.php | 1 + .../PhpWord/Exception/CopyFileException.php | 1 + .../CreateTemporaryFileException.php | 1 + .../src/PhpWord/Exception/Exception.php | 1 + .../Exception/InvalidImageException.php | 1 + .../Exception/InvalidObjectException.php | 1 + .../Exception/InvalidStyleException.php | 1 + .../UnsupportedImageTypeException.php | 1 + .../phpword/src/PhpWord/IOFactory.php | 13 +- .../phpoffice/phpword/src/PhpWord/Media.php | 1 + .../src/PhpWord/Metadata/Compatibility.php | 1 + .../phpword/src/PhpWord/Metadata/DocInfo.php | 1 + .../src/PhpWord/Metadata/Protection.php | 1 + .../phpword/src/PhpWord/Metadata/Settings.php | 7 +- .../phpoffice/phpword/src/PhpWord/PhpWord.php | 57 +- .../src/PhpWord/Reader/AbstractReader.php | 1 + .../phpword/src/PhpWord/Reader/HTML.php | 3 +- .../phpword/src/PhpWord/Reader/MsDoc.php | 1 + .../phpword/src/PhpWord/Reader/ODText.php | 5 +- .../PhpWord/Reader/ODText/AbstractPart.php | 1 + .../src/PhpWord/Reader/ODText/Content.php | 1 + .../src/PhpWord/Reader/ODText/Meta.php | 1 + .../phpword/src/PhpWord/Reader/RTF.php | 3 +- .../src/PhpWord/Reader/RTF/Document.php | 3 +- .../src/PhpWord/Reader/ReaderInterface.php | 1 + .../phpword/src/PhpWord/Reader/Word2007.php | 3 +- .../PhpWord/Reader/Word2007/AbstractPart.php | 56 +- .../PhpWord/Reader/Word2007/DocPropsApp.php | 1 + .../PhpWord/Reader/Word2007/DocPropsCore.php | 1 + .../Reader/Word2007/DocPropsCustom.php | 1 + .../src/PhpWord/Reader/Word2007/Document.php | 3 +- .../src/PhpWord/Reader/Word2007/Endnotes.php | 1 + .../src/PhpWord/Reader/Word2007/Footnotes.php | 1 + .../src/PhpWord/Reader/Word2007/Numbering.php | 1 + .../src/PhpWord/Reader/Word2007/Settings.php | 1 + .../src/PhpWord/Reader/Word2007/Styles.php | 4 + .../phpword/src/PhpWord/Settings.php | 58 +- .../src/PhpWord/Shared/AbstractEnum.php | 1 + .../phpword/src/PhpWord/Shared/Converter.php | 1 + .../phpword/src/PhpWord/Shared/Css.php | 5 +- .../phpword/src/PhpWord/Shared/Drawing.php | 1 + .../phpword/src/PhpWord/Shared/Html.php | 282 +- .../Shared/Microsoft/PasswordEncoder.php | 8 +- .../phpword/src/PhpWord/Shared/Text.php | 6 + .../phpword/src/PhpWord/Shared/Validate.php | 1 + .../phpword/src/PhpWord/Shared/XMLReader.php | 1 + .../phpword/src/PhpWord/Shared/XMLWriter.php | 1 + .../phpword/src/PhpWord/Shared/ZipArchive.php | 18 +- .../phpword/src/PhpWord/SimpleType/Border.php | 1 + .../src/PhpWord/SimpleType/DocProtect.php | 1 + .../phpword/src/PhpWord/SimpleType/Jc.php | 3 +- .../src/PhpWord/SimpleType/JcTable.php | 1 + .../PhpWord/SimpleType/LineSpacingRule.php | 1 + .../src/PhpWord/SimpleType/NumberFormat.php | 1 + .../src/PhpWord/SimpleType/TblWidth.php | 1 + .../src/PhpWord/SimpleType/TextAlignment.php | 1 + .../src/PhpWord/SimpleType/VerticalJc.php | 1 + .../phpword/src/PhpWord/SimpleType/Zoom.php | 1 + .../phpoffice/phpword/src/PhpWord/Style.php | 15 +- .../src/PhpWord/Style/AbstractStyle.php | 10 +- .../phpword/src/PhpWord/Style/Border.php | 1 + .../phpword/src/PhpWord/Style/Cell.php | 129 +- .../phpword/src/PhpWord/Style/Chart.php | 1 + .../phpword/src/PhpWord/Style/Extrusion.php | 1 + .../phpword/src/PhpWord/Style/Fill.php | 1 + .../phpword/src/PhpWord/Style/Font.php | 23 +- .../phpword/src/PhpWord/Style/Frame.php | 1 + .../phpword/src/PhpWord/Style/Image.php | 1 + .../phpword/src/PhpWord/Style/Indentation.php | 84 +- .../phpword/src/PhpWord/Style/Language.php | 1 + .../phpword/src/PhpWord/Style/Line.php | 1 + .../src/PhpWord/Style/LineNumbering.php | 1 + .../phpword/src/PhpWord/Style/ListItem.php | 1 + .../phpword/src/PhpWord/Style/Numbering.php | 29 +- .../src/PhpWord/Style/NumberingLevel.php | 1 + .../phpword/src/PhpWord/Style/Outline.php | 1 + .../phpword/src/PhpWord/Style/Paper.php | 1 + .../phpword/src/PhpWord/Style/Paragraph.php | 175 +- .../phpword/src/PhpWord/Style/Row.php | 1 + .../phpword/src/PhpWord/Style/Section.php | 11 +- .../phpword/src/PhpWord/Style/Shading.php | 1 + .../phpword/src/PhpWord/Style/Shadow.php | 1 + .../phpword/src/PhpWord/Style/Shape.php | 21 +- .../phpword/src/PhpWord/Style/Spacing.php | 1 + .../phpword/src/PhpWord/Style/TOC.php | 1 + .../phpword/src/PhpWord/Style/Tab.php | 1 + .../phpword/src/PhpWord/Style/Table.php | 13 +- .../src/PhpWord/Style/TablePosition.php | 1 + .../phpword/src/PhpWord/Style/TextBox.php | 1 + .../phpword/src/PhpWord/TemplateProcessor.php | 26 +- .../src/PhpWord/Writer/AbstractWriter.php | 11 +- .../phpword/src/PhpWord/Writer/HTML.php | 3 +- .../Writer/HTML/Element/AbstractElement.php | 3 +- .../PhpWord/Writer/HTML/Element/Bookmark.php | 1 + .../PhpWord/Writer/HTML/Element/Container.php | 3 +- .../PhpWord/Writer/HTML/Element/Endnote.php | 1 + .../PhpWord/Writer/HTML/Element/Footnote.php | 1 + .../src/PhpWord/Writer/HTML/Element/Image.php | 1 + .../src/PhpWord/Writer/HTML/Element/Link.php | 1 + .../PhpWord/Writer/HTML/Element/ListItem.php | 1 + .../Writer/HTML/Element/ListItemRun.php | 1 + .../PhpWord/Writer/HTML/Element/PageBreak.php | 1 + .../src/PhpWord/Writer/HTML/Element/Table.php | 1 + .../src/PhpWord/Writer/HTML/Element/Text.php | 3 +- .../PhpWord/Writer/HTML/Element/TextBreak.php | 1 + .../PhpWord/Writer/HTML/Element/TextRun.php | 1 + .../src/PhpWord/Writer/HTML/Element/Title.php | 1 + .../PhpWord/Writer/HTML/Part/AbstractPart.php | 1 + .../src/PhpWord/Writer/HTML/Part/Body.php | 3 +- .../src/PhpWord/Writer/HTML/Part/Head.php | 6 +- .../Writer/HTML/Style/AbstractStyle.php | 1 + .../src/PhpWord/Writer/HTML/Style/Font.php | 1 + .../src/PhpWord/Writer/HTML/Style/Generic.php | 1 + .../src/PhpWord/Writer/HTML/Style/Image.php | 1 + .../PhpWord/Writer/HTML/Style/Paragraph.php | 1 + .../src/PhpWord/Writer/HTML/Style/Table.php | 4 + .../phpword/src/PhpWord/Writer/ODText.php | 3 +- .../Writer/ODText/Element/AbstractElement.php | 29 + .../Writer/ODText/Element/Container.php | 6 + .../PhpWord/Writer/ODText/Element/Field.php | 1 + .../PhpWord/Writer/ODText/Element/Formula.php | 1 + .../PhpWord/Writer/ODText/Element/Image.php | 18 +- .../PhpWord/Writer/ODText/Element/Link.php | 1 + .../Writer/ODText/Element/PageBreak.php | 1 + .../PhpWord/Writer/ODText/Element/Table.php | 5 +- .../PhpWord/Writer/ODText/Element/Text.php | 70 +- .../Writer/ODText/Element/TextBreak.php | 1 + .../PhpWord/Writer/ODText/Element/TextRun.php | 1 + .../PhpWord/Writer/ODText/Element/Title.php | 1 + .../Writer/ODText/Part/AbstractPart.php | 1 + .../PhpWord/Writer/ODText/Part/Content.php | 13 +- .../PhpWord/Writer/ODText/Part/Manifest.php | 1 + .../src/PhpWord/Writer/ODText/Part/Meta.php | 1 + .../PhpWord/Writer/ODText/Part/Mimetype.php | 1 + .../src/PhpWord/Writer/ODText/Part/Styles.php | 4 +- .../Writer/ODText/Style/AbstractStyle.php | 1 + .../src/PhpWord/Writer/ODText/Style/Font.php | 3 +- .../src/PhpWord/Writer/ODText/Style/Image.php | 1 + .../PhpWord/Writer/ODText/Style/Paragraph.php | 9 +- .../PhpWord/Writer/ODText/Style/Section.php | 1 + .../src/PhpWord/Writer/ODText/Style/Table.php | 1 + .../phpword/src/PhpWord/Writer/PDF.php | 3 +- .../PhpWord/Writer/PDF/AbstractRenderer.php | 1 + .../phpword/src/PhpWord/Writer/PDF/DomPDF.php | 1 + .../phpword/src/PhpWord/Writer/PDF/MPDF.php | 1 + .../phpword/src/PhpWord/Writer/PDF/TCPDF.php | 1 + .../phpword/src/PhpWord/Writer/RTF.php | 3 +- .../Writer/RTF/Element/AbstractElement.php | 11 +- .../PhpWord/Writer/RTF/Element/Container.php | 1 + .../src/PhpWord/Writer/RTF/Element/Field.php | 1 + .../src/PhpWord/Writer/RTF/Element/Image.php | 1 + .../src/PhpWord/Writer/RTF/Element/Link.php | 1 + .../PhpWord/Writer/RTF/Element/ListItem.php | 1 + .../PhpWord/Writer/RTF/Element/PageBreak.php | 1 + .../src/PhpWord/Writer/RTF/Element/Table.php | 1 + .../src/PhpWord/Writer/RTF/Element/Text.php | 1 + .../PhpWord/Writer/RTF/Element/TextBreak.php | 1 + .../PhpWord/Writer/RTF/Element/TextRun.php | 1 + .../src/PhpWord/Writer/RTF/Element/Title.php | 10 +- .../PhpWord/Writer/RTF/Part/AbstractPart.php | 1 + .../src/PhpWord/Writer/RTF/Part/Document.php | 9 +- .../src/PhpWord/Writer/RTF/Part/Header.php | 5 +- .../Writer/RTF/Style/AbstractStyle.php | 1 + .../src/PhpWord/Writer/RTF/Style/Border.php | 1 + .../src/PhpWord/Writer/RTF/Style/Font.php | 1 + .../PhpWord/Writer/RTF/Style/Indentation.php | 1 + .../PhpWord/Writer/RTF/Style/Paragraph.php | 1 + .../src/PhpWord/Writer/RTF/Style/Section.php | 1 + .../src/PhpWord/Writer/RTF/Style/Tab.php | 1 + .../phpword/src/PhpWord/Writer/Word2007.php | 11 +- .../Word2007/Element/AbstractElement.php | 13 +- .../Writer/Word2007/Element/Bookmark.php | 1 + .../PhpWord/Writer/Word2007/Element/Chart.php | 1 + .../Writer/Word2007/Element/CheckBox.php | 1 + .../Writer/Word2007/Element/Container.php | 18 +- .../Writer/Word2007/Element/Endnote.php | 1 + .../PhpWord/Writer/Word2007/Element/Field.php | 5 +- .../Writer/Word2007/Element/Footnote.php | 1 + .../Writer/Word2007/Element/FormField.php | 1 + .../Writer/Word2007/Element/Formula.php | 1 + .../PhpWord/Writer/Word2007/Element/Image.php | 1 + .../PhpWord/Writer/Word2007/Element/Line.php | 1 + .../PhpWord/Writer/Word2007/Element/Link.php | 1 + .../Writer/Word2007/Element/ListItem.php | 1 + .../Writer/Word2007/Element/ListItemRun.php | 1 + .../Writer/Word2007/Element/OLEObject.php | 1 + .../Writer/Word2007/Element/PageBreak.php | 1 + .../Word2007/Element/ParagraphAlignment.php | 1 + .../Writer/Word2007/Element/PreserveText.php | 1 + .../PhpWord/Writer/Word2007/Element/SDT.php | 1 + .../PhpWord/Writer/Word2007/Element/Shape.php | 1 + .../PhpWord/Writer/Word2007/Element/TOC.php | 3 +- .../PhpWord/Writer/Word2007/Element/Table.php | 1 + .../Word2007/Element/TableAlignment.php | 1 + .../PhpWord/Writer/Word2007/Element/Text.php | 1 + .../Writer/Word2007/Element/TextBox.php | 8 + .../Writer/Word2007/Element/TextBreak.php | 1 + .../Writer/Word2007/Element/TextRun.php | 1 + .../PhpWord/Writer/Word2007/Element/Title.php | 1 + .../Writer/Word2007/Part/AbstractPart.php | 7 +- .../PhpWord/Writer/Word2007/Part/Chart.php | 3 +- .../PhpWord/Writer/Word2007/Part/Comments.php | 5 +- .../Writer/Word2007/Part/ContentTypes.php | 3 +- .../Writer/Word2007/Part/DocPropsApp.php | 1 + .../Writer/Word2007/Part/DocPropsCore.php | 1 + .../Writer/Word2007/Part/DocPropsCustom.php | 1 + .../PhpWord/Writer/Word2007/Part/Document.php | 1 + .../PhpWord/Writer/Word2007/Part/Endnotes.php | 1 + .../Writer/Word2007/Part/FontTable.php | 1 + .../PhpWord/Writer/Word2007/Part/Footer.php | 1 + .../Writer/Word2007/Part/Footnotes.php | 3 +- .../PhpWord/Writer/Word2007/Part/Header.php | 1 + .../Writer/Word2007/Part/Numbering.php | 3 +- .../src/PhpWord/Writer/Word2007/Part/Rels.php | 1 + .../Writer/Word2007/Part/RelsDocument.php | 1 + .../PhpWord/Writer/Word2007/Part/RelsPart.php | 1 + .../PhpWord/Writer/Word2007/Part/Settings.php | 3 +- .../PhpWord/Writer/Word2007/Part/Styles.php | 12 +- .../PhpWord/Writer/Word2007/Part/Theme.php | 1 + .../Writer/Word2007/Part/WebSettings.php | 1 + .../Writer/Word2007/Style/AbstractStyle.php | 7 +- .../PhpWord/Writer/Word2007/Style/Cell.php | 35 + .../Writer/Word2007/Style/Extrusion.php | 1 + .../PhpWord/Writer/Word2007/Style/Fill.php | 1 + .../PhpWord/Writer/Word2007/Style/Font.php | 1 + .../PhpWord/Writer/Word2007/Style/Frame.php | 1 + .../PhpWord/Writer/Word2007/Style/Image.php | 1 + .../Writer/Word2007/Style/Indentation.php | 4 + .../PhpWord/Writer/Word2007/Style/Line.php | 1 + .../Writer/Word2007/Style/LineNumbering.php | 1 + .../Writer/Word2007/Style/MarginBorder.php | 1 + .../PhpWord/Writer/Word2007/Style/Outline.php | 1 + .../Writer/Word2007/Style/Paragraph.php | 5 +- .../src/PhpWord/Writer/Word2007/Style/Row.php | 1 + .../PhpWord/Writer/Word2007/Style/Section.php | 1 + .../PhpWord/Writer/Word2007/Style/Shading.php | 1 + .../PhpWord/Writer/Word2007/Style/Shadow.php | 1 + .../PhpWord/Writer/Word2007/Style/Shape.php | 1 + .../PhpWord/Writer/Word2007/Style/Spacing.php | 1 + .../src/PhpWord/Writer/Word2007/Style/Tab.php | 1 + .../PhpWord/Writer/Word2007/Style/Table.php | 1 + .../Writer/Word2007/Style/TablePosition.php | 1 + .../PhpWord/Writer/Word2007/Style/TextBox.php | 1 + .../src/PhpWord/Writer/WriterInterface.php | 1 + vendor/psr/cache/CHANGELOG.md | 16 - vendor/psr/cache/LICENSE.txt | 19 - vendor/psr/cache/README.md | 9 - vendor/psr/cache/composer.json | 25 - vendor/psr/cache/src/CacheException.php | 10 - vendor/psr/cache/src/CacheItemInterface.php | 105 - .../psr/cache/src/CacheItemPoolInterface.php | 138 - .../cache/src/InvalidArgumentException.php | 13 - vendor/symfony/class-loader/.gitignore | 3 - .../symfony/class-loader/ApcClassLoader.php | 141 - vendor/symfony/class-loader/CHANGELOG.md | 36 - .../class-loader/ClassCollectionLoader.php | 444 -- vendor/symfony/class-loader/ClassLoader.php | 203 - .../class-loader/ClassMapGenerator.php | 156 - vendor/symfony/class-loader/LICENSE | 19 - .../symfony/class-loader/MapClassLoader.php | 68 - .../symfony/class-loader/Psr4ClassLoader.php | 93 - vendor/symfony/class-loader/README.md | 14 - .../class-loader/Tests/ApcClassLoaderTest.php | 197 - .../Tests/ClassCollectionLoaderTest.php | 316 - .../class-loader/Tests/ClassLoaderTest.php | 235 - .../Tests/ClassMapGeneratorTest.php | 148 - .../Tests/Fixtures/Apc/Namespaced/Bar.php | 17 - .../Tests/Fixtures/Apc/Namespaced/Baz.php | 17 - .../Tests/Fixtures/Apc/Namespaced/Foo.php | 17 - .../Tests/Fixtures/Apc/Namespaced/FooBar.php | 17 - .../Tests/Fixtures/Apc/Pearlike/Bar.php | 6 - .../Tests/Fixtures/Apc/Pearlike/Baz.php | 6 - .../Tests/Fixtures/Apc/Pearlike/Foo.php | 6 - .../alpha/Apc/ApcPrefixCollision/A/Bar.php | 6 - .../alpha/Apc/ApcPrefixCollision/A/Foo.php | 6 - .../alpha/Apc/NamespaceCollision/A/Bar.php | 17 - .../alpha/Apc/NamespaceCollision/A/Foo.php | 17 - .../beta/Apc/ApcPrefixCollision/A/B/Bar.php | 6 - .../beta/Apc/ApcPrefixCollision/A/B/Foo.php | 6 - .../beta/Apc/NamespaceCollision/A/B/Bar.php | 17 - .../beta/Apc/NamespaceCollision/A/B/Foo.php | 17 - .../Apc/fallback/Apc/Pearlike/FooBar.php | 6 - .../Apc/fallback/Namespaced/FooBar.php | 17 - .../Tests/Fixtures/ClassesWithParents/A.php | 7 - .../Fixtures/ClassesWithParents/ATrait.php | 7 - .../Tests/Fixtures/ClassesWithParents/B.php | 7 - .../Fixtures/ClassesWithParents/BTrait.php | 8 - .../ClassesWithParents/CInterface.php | 7 - .../Fixtures/ClassesWithParents/CTrait.php | 7 - .../Tests/Fixtures/ClassesWithParents/D.php | 8 - .../Tests/Fixtures/ClassesWithParents/E.php | 8 - .../Tests/Fixtures/ClassesWithParents/F.php | 8 - .../Tests/Fixtures/ClassesWithParents/G.php | 8 - .../ClassesWithParents/GInterface.php | 7 - .../Tests/Fixtures/DeclaredClass.php | 7 - .../Tests/Fixtures/DeclaredInterface.php | 7 - .../Tests/Fixtures/Namespaced/Bar.php | 17 - .../Tests/Fixtures/Namespaced/Baz.php | 17 - .../Tests/Fixtures/Namespaced/Foo.php | 17 - .../Fixtures/Namespaced/WithComments.php | 37 - .../Fixtures/Namespaced/WithDirMagic.php | 15 - .../Fixtures/Namespaced/WithFileMagic.php | 15 - .../Fixtures/Namespaced/WithHaltCompiler.php | 18 - .../Fixtures/Namespaced/WithStrictTypes.php | 13 - .../Tests/Fixtures/Namespaced2/Bar.php | 8 - .../Tests/Fixtures/Namespaced2/Baz.php | 8 - .../Tests/Fixtures/Namespaced2/Foo.php | 8 - .../Tests/Fixtures/Pearlike/Bar.php | 6 - .../Tests/Fixtures/Pearlike/Baz.php | 6 - .../Tests/Fixtures/Pearlike/Foo.php | 6 - .../Tests/Fixtures/Pearlike/WithComments.php | 16 - .../Tests/Fixtures/Pearlike2/Bar.php | 6 - .../Tests/Fixtures/Pearlike2/Baz.php | 6 - .../Tests/Fixtures/Pearlike2/Foo.php | 6 - .../Tests/Fixtures/WarmedClass.php | 7 - .../Tests/Fixtures/WarmedInterface.php | 7 - .../alpha/NamespaceCollision/A/Bar.php | 17 - .../alpha/NamespaceCollision/A/Foo.php | 17 - .../alpha/NamespaceCollision/C/Bar.php | 8 - .../alpha/NamespaceCollision/C/Foo.php | 8 - .../Fixtures/alpha/PrefixCollision/A/Bar.php | 6 - .../Fixtures/alpha/PrefixCollision/A/Foo.php | 6 - .../Fixtures/alpha/PrefixCollision/C/Bar.php | 6 - .../Fixtures/alpha/PrefixCollision/C/Foo.php | 6 - .../beta/NamespaceCollision/A/B/Bar.php | 17 - .../beta/NamespaceCollision/A/B/Foo.php | 17 - .../beta/NamespaceCollision/C/B/Bar.php | 8 - .../beta/NamespaceCollision/C/B/Foo.php | 8 - .../Fixtures/beta/PrefixCollision/A/B/Bar.php | 6 - .../Fixtures/beta/PrefixCollision/A/B/Foo.php | 6 - .../Fixtures/beta/PrefixCollision/C/B/Bar.php | 6 - .../Fixtures/beta/PrefixCollision/C/B/Foo.php | 6 - .../Tests/Fixtures/classmap/SomeClass.php | 16 - .../Tests/Fixtures/classmap/SomeInterface.php | 16 - .../Tests/Fixtures/classmap/SomeParent.php | 16 - .../Tests/Fixtures/classmap/multipleNs.php | 25 - .../Tests/Fixtures/classmap/notAClass.php | 3 - .../Tests/Fixtures/classmap/notPhpFile.md | 1 - .../classmap/sameNsMultipleClasses.php | 19 - .../Tests/Fixtures/deps/traits.php | 37 - .../Fixtures/fallback/Namespaced/FooBar.php | 17 - .../Fixtures/fallback/Namespaced2/FooBar.php | 8 - .../Fixtures/fallback/Pearlike/FooBar.php | 6 - .../Fixtures/fallback/Pearlike2/FooBar.php | 6 - .../Tests/Fixtures/includepath/Foo.php | 5 - .../Tests/Fixtures/php5.4/traits.php | 32 - .../Tests/Fixtures/php5.5/class_cons.php | 11 - .../Fixtures/psr-4/Class_With_Underscores.php | 7 - .../class-loader/Tests/Fixtures/psr-4/Foo.php | 7 - .../Lets/Go/Deeper/Class_With_Underscores.php | 7 - .../Fixtures/psr-4/Lets/Go/Deeper/Foo.php | 7 - .../Tests/Psr4ClassLoaderTest.php | 72 - .../class-loader/WinCacheClassLoader.php | 140 - .../class-loader/XcacheClassLoader.php | 141 - vendor/symfony/class-loader/composer.json | 40 - vendor/symfony/class-loader/phpunit.xml.dist | 31 - vendor/topthink/think-captcha/src/Captcha.php | 10 +- 651 files changed, 4599 insertions(+), 32312 deletions(-) create mode 100644 sql/article_main_ref_check_status.sql create mode 100644 sql/reference_check_result.sql create mode 100644 sql/reference_check_result_alter_positions.sql create mode 100644 sql/reference_check_result_can_support.sql delete mode 100644 vendor/aliemail/email.php delete mode 100644 vendor/doctrine/annotations/LICENSE delete mode 100644 vendor/doctrine/annotations/README.md delete mode 100644 vendor/doctrine/annotations/composer.json delete mode 100644 vendor/doctrine/annotations/docs/en/annotations.rst delete mode 100644 vendor/doctrine/annotations/docs/en/custom.rst delete mode 100644 vendor/doctrine/annotations/docs/en/index.rst delete mode 100644 vendor/doctrine/annotations/docs/en/sidebar.rst delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attributes.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/NamedArgumentConstructor.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Required.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Target.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/ImplicitlyIgnoredAnnotationNames.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/NamedArgumentConstructorAnnotation.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PhpParser.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PsrCachedReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php delete mode 100644 vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php delete mode 100644 vendor/doctrine/lexer/LICENSE delete mode 100644 vendor/doctrine/lexer/README.md delete mode 100644 vendor/doctrine/lexer/composer.json delete mode 100644 vendor/doctrine/lexer/lib/Doctrine/Common/Lexer/AbstractLexer.php delete mode 100644 vendor/fpdf/FAQ.htm delete mode 100644 vendor/fpdf/bg.png delete mode 100644 vendor/fpdf/changelog.htm delete mode 100644 vendor/fpdf/doc/acceptpagebreak.htm delete mode 100644 vendor/fpdf/doc/addfont.htm delete mode 100644 vendor/fpdf/doc/addlink.htm delete mode 100644 vendor/fpdf/doc/addpage.htm delete mode 100644 vendor/fpdf/doc/aliasnbpages.htm delete mode 100644 vendor/fpdf/doc/cell.htm delete mode 100644 vendor/fpdf/doc/close.htm delete mode 100644 vendor/fpdf/doc/error.htm delete mode 100644 vendor/fpdf/doc/footer.htm delete mode 100644 vendor/fpdf/doc/fpdf.htm delete mode 100644 vendor/fpdf/doc/getstringwidth.htm delete mode 100644 vendor/fpdf/doc/getx.htm delete mode 100644 vendor/fpdf/doc/gety.htm delete mode 100644 vendor/fpdf/doc/header.htm delete mode 100644 vendor/fpdf/doc/image.htm delete mode 100644 vendor/fpdf/doc/index.htm delete mode 100644 vendor/fpdf/doc/line.htm delete mode 100644 vendor/fpdf/doc/link.htm delete mode 100644 vendor/fpdf/doc/ln.htm delete mode 100644 vendor/fpdf/doc/multicell.htm delete mode 100644 vendor/fpdf/doc/output.htm delete mode 100644 vendor/fpdf/doc/pageno.htm delete mode 100644 vendor/fpdf/doc/rect.htm delete mode 100644 vendor/fpdf/doc/setauthor.htm delete mode 100644 vendor/fpdf/doc/setautopagebreak.htm delete mode 100644 vendor/fpdf/doc/setcompression.htm delete mode 100644 vendor/fpdf/doc/setcreator.htm delete mode 100644 vendor/fpdf/doc/setdisplaymode.htm delete mode 100644 vendor/fpdf/doc/setdrawcolor.htm delete mode 100644 vendor/fpdf/doc/setfillcolor.htm delete mode 100644 vendor/fpdf/doc/setfont.htm delete mode 100644 vendor/fpdf/doc/setfontsize.htm delete mode 100644 vendor/fpdf/doc/setkeywords.htm delete mode 100644 vendor/fpdf/doc/setleftmargin.htm delete mode 100644 vendor/fpdf/doc/setlinewidth.htm delete mode 100644 vendor/fpdf/doc/setlink.htm delete mode 100644 vendor/fpdf/doc/setmargins.htm delete mode 100644 vendor/fpdf/doc/setrightmargin.htm delete mode 100644 vendor/fpdf/doc/setsubject.htm delete mode 100644 vendor/fpdf/doc/settextcolor.htm delete mode 100644 vendor/fpdf/doc/settitle.htm delete mode 100644 vendor/fpdf/doc/settopmargin.htm delete mode 100644 vendor/fpdf/doc/setx.htm delete mode 100644 vendor/fpdf/doc/setxy.htm delete mode 100644 vendor/fpdf/doc/sety.htm delete mode 100644 vendor/fpdf/doc/text.htm delete mode 100644 vendor/fpdf/doc/write.htm delete mode 100644 vendor/fpdf/font/courier.php delete mode 100644 vendor/fpdf/font/courierb.php delete mode 100644 vendor/fpdf/font/courierbi.php delete mode 100644 vendor/fpdf/font/courieri.php delete mode 100644 vendor/fpdf/font/helvetica.php delete mode 100644 vendor/fpdf/font/helveticab.php delete mode 100644 vendor/fpdf/font/helveticabi.php delete mode 100644 vendor/fpdf/font/helveticai.php delete mode 100644 vendor/fpdf/font/symbol.php delete mode 100644 vendor/fpdf/font/times.php delete mode 100644 vendor/fpdf/font/timesb.php delete mode 100644 vendor/fpdf/font/timesbi.php delete mode 100644 vendor/fpdf/font/timesi.php delete mode 100644 vendor/fpdf/font/zapfdingbats.php delete mode 100644 vendor/fpdf/fpdf.css delete mode 100644 vendor/fpdf/fpdf.php delete mode 100644 vendor/fpdf/install.txt delete mode 100644 vendor/fpdf/license.txt delete mode 100644 vendor/fpdf/makefont/cp1250.map delete mode 100644 vendor/fpdf/makefont/cp1251.map delete mode 100644 vendor/fpdf/makefont/cp1252.map delete mode 100644 vendor/fpdf/makefont/cp1253.map delete mode 100644 vendor/fpdf/makefont/cp1254.map delete mode 100644 vendor/fpdf/makefont/cp1255.map delete mode 100644 vendor/fpdf/makefont/cp1257.map delete mode 100644 vendor/fpdf/makefont/cp1258.map delete mode 100644 vendor/fpdf/makefont/cp874.map delete mode 100644 vendor/fpdf/makefont/iso-8859-1.map delete mode 100644 vendor/fpdf/makefont/iso-8859-11.map delete mode 100644 vendor/fpdf/makefont/iso-8859-15.map delete mode 100644 vendor/fpdf/makefont/iso-8859-16.map delete mode 100644 vendor/fpdf/makefont/iso-8859-2.map delete mode 100644 vendor/fpdf/makefont/iso-8859-4.map delete mode 100644 vendor/fpdf/makefont/iso-8859-5.map delete mode 100644 vendor/fpdf/makefont/iso-8859-7.map delete mode 100644 vendor/fpdf/makefont/iso-8859-9.map delete mode 100644 vendor/fpdf/makefont/koi8-r.map delete mode 100644 vendor/fpdf/makefont/koi8-u.map delete mode 100644 vendor/fpdf/makefont/makefont.php delete mode 100644 vendor/fpdf/makefont/ttfparser.php delete mode 100644 vendor/fpdf/tutorial/20k_c1.txt delete mode 100644 vendor/fpdf/tutorial/20k_c2.txt delete mode 100644 vendor/fpdf/tutorial/calligra.php delete mode 100644 vendor/fpdf/tutorial/calligra.ttf delete mode 100644 vendor/fpdf/tutorial/calligra.z delete mode 100644 vendor/fpdf/tutorial/countries.txt delete mode 100644 vendor/fpdf/tutorial/index.htm delete mode 100644 vendor/fpdf/tutorial/logo.png delete mode 100644 vendor/fpdf/tutorial/makefont.php delete mode 100644 vendor/fpdf/tutorial/tuto1.htm delete mode 100644 vendor/fpdf/tutorial/tuto1.php delete mode 100644 vendor/fpdf/tutorial/tuto2.htm delete mode 100644 vendor/fpdf/tutorial/tuto2.php delete mode 100644 vendor/fpdf/tutorial/tuto3.htm delete mode 100644 vendor/fpdf/tutorial/tuto3.php delete mode 100644 vendor/fpdf/tutorial/tuto4.htm delete mode 100644 vendor/fpdf/tutorial/tuto4.php delete mode 100644 vendor/fpdf/tutorial/tuto5.htm delete mode 100644 vendor/fpdf/tutorial/tuto5.php delete mode 100644 vendor/fpdf/tutorial/tuto6.htm delete mode 100644 vendor/fpdf/tutorial/tuto6.php delete mode 100644 vendor/fpdf/tutorial/tuto7.htm delete mode 100644 vendor/fpdf/tutorial/tuto7.php delete mode 100644 vendor/fpdi/filters/FilterASCII85.php delete mode 100644 vendor/fpdi/filters/FilterASCIIHexDecode.php delete mode 100644 vendor/fpdi/filters/FilterLZW.php delete mode 100644 vendor/fpdi/fpdf_tpl.php delete mode 100644 vendor/fpdi/fpdi.php delete mode 100644 vendor/fpdi/fpdi_bridge.php delete mode 100644 vendor/fpdi/fpdi_pdf_parser.php delete mode 100644 vendor/fpdi/pdf_context.php delete mode 100644 vendor/fpdi/pdf_parser.php delete mode 100644 vendor/hg/apidoc/.github/workflows/mirror.yml delete mode 100644 vendor/hg/apidoc/.gitignore delete mode 100644 vendor/hg/apidoc/LICENSE delete mode 100644 vendor/hg/apidoc/README.md delete mode 100644 vendor/hg/apidoc/composer.json delete mode 100644 vendor/hg/apidoc/src/Auth.php delete mode 100644 vendor/hg/apidoc/src/Controller.php delete mode 100644 vendor/hg/apidoc/src/Service.php delete mode 100644 vendor/hg/apidoc/src/Utils.php delete mode 100644 vendor/hg/apidoc/src/annotation/AddField.php delete mode 100644 vendor/hg/apidoc/src/annotation/Author.php delete mode 100644 vendor/hg/apidoc/src/annotation/Desc.php delete mode 100644 vendor/hg/apidoc/src/annotation/Field.php delete mode 100644 vendor/hg/apidoc/src/annotation/Group.php delete mode 100644 vendor/hg/apidoc/src/annotation/Header.php delete mode 100644 vendor/hg/apidoc/src/annotation/Method.php delete mode 100644 vendor/hg/apidoc/src/annotation/Param.php delete mode 100644 vendor/hg/apidoc/src/annotation/ParamBase.php delete mode 100644 vendor/hg/apidoc/src/annotation/ParamType.php delete mode 100644 vendor/hg/apidoc/src/annotation/Returned.php delete mode 100644 vendor/hg/apidoc/src/annotation/Route.php delete mode 100644 vendor/hg/apidoc/src/annotation/Rule.php delete mode 100644 vendor/hg/apidoc/src/annotation/Sort.php delete mode 100644 vendor/hg/apidoc/src/annotation/Tag.php delete mode 100644 vendor/hg/apidoc/src/annotation/Title.php delete mode 100644 vendor/hg/apidoc/src/annotation/Url.php delete mode 100644 vendor/hg/apidoc/src/annotation/WithoutField.php delete mode 100644 vendor/hg/apidoc/src/config.php delete mode 100644 vendor/hg/apidoc/src/crud/CreateCrud.php delete mode 100644 vendor/hg/apidoc/src/exception/AuthException.php delete mode 100644 vendor/hg/apidoc/src/exception/ErrorException.php delete mode 100644 vendor/hg/apidoc/src/parseApi/CacheApiData.php delete mode 100644 vendor/hg/apidoc/src/parseApi/ParseAnnotation.php delete mode 100644 vendor/hg/apidoc/src/parseApi/ParseMarkdown.php delete mode 100644 vendor/hg/apidoc/src/parseApi/ParseModel.php delete mode 100644 vendor/itxq/api-doc-php/.gitignore delete mode 100644 vendor/itxq/api-doc-php/LICENSE delete mode 100644 vendor/itxq/api-doc-php/README.md delete mode 100644 vendor/itxq/api-doc-php/assets/css/bootstrap.min.css delete mode 100644 vendor/itxq/api-doc-php/assets/index.html delete mode 100644 vendor/itxq/api-doc-php/assets/js/bootstrap.min.js delete mode 100644 vendor/itxq/api-doc-php/assets/js/jquery.min.js delete mode 100644 vendor/itxq/api-doc-php/composer.json delete mode 100644 vendor/itxq/api-doc-php/src/ApiDoc.php delete mode 100644 vendor/itxq/api-doc-php/src/BootstrapApiDoc.php delete mode 100644 vendor/itxq/api-doc-php/src/lib/ParseComment.php delete mode 100644 vendor/itxq/api-doc-php/src/lib/ParseLine.php delete mode 100644 vendor/itxq/api-doc-php/src/lib/Tools.php delete mode 100644 vendor/itxq/api-doc-php/test/Api.php delete mode 100644 vendor/itxq/api-doc-php/test/Api2.php delete mode 100644 vendor/itxq/api-doc-php/test/index.php delete mode 100644 vendor/phpmailer/phpmailer/.editorconfig delete mode 100644 vendor/phpoffice/phpword/bootstrap.php delete mode 100644 vendor/psr/cache/CHANGELOG.md delete mode 100644 vendor/psr/cache/LICENSE.txt delete mode 100644 vendor/psr/cache/README.md delete mode 100644 vendor/psr/cache/composer.json delete mode 100644 vendor/psr/cache/src/CacheException.php delete mode 100644 vendor/psr/cache/src/CacheItemInterface.php delete mode 100644 vendor/psr/cache/src/CacheItemPoolInterface.php delete mode 100644 vendor/psr/cache/src/InvalidArgumentException.php delete mode 100644 vendor/symfony/class-loader/.gitignore delete mode 100644 vendor/symfony/class-loader/ApcClassLoader.php delete mode 100644 vendor/symfony/class-loader/CHANGELOG.md delete mode 100644 vendor/symfony/class-loader/ClassCollectionLoader.php delete mode 100644 vendor/symfony/class-loader/ClassLoader.php delete mode 100644 vendor/symfony/class-loader/ClassMapGenerator.php delete mode 100644 vendor/symfony/class-loader/LICENSE delete mode 100644 vendor/symfony/class-loader/MapClassLoader.php delete mode 100644 vendor/symfony/class-loader/Psr4ClassLoader.php delete mode 100644 vendor/symfony/class-loader/README.md delete mode 100644 vendor/symfony/class-loader/Tests/ApcClassLoaderTest.php delete mode 100644 vendor/symfony/class-loader/Tests/ClassCollectionLoaderTest.php delete mode 100644 vendor/symfony/class-loader/Tests/ClassLoaderTest.php delete mode 100644 vendor/symfony/class-loader/Tests/ClassMapGeneratorTest.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/ApcPrefixCollision/A/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/ApcPrefixCollision/A/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/fallback/Apc/Pearlike/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Apc/fallback/Namespaced/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/A.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/ATrait.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/B.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/BTrait.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/CInterface.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/CTrait.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/D.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/E.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/F.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/G.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/GInterface.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/DeclaredClass.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/DeclaredInterface.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithComments.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithDirMagic.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithFileMagic.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithHaltCompiler.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithStrictTypes.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced2/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced2/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Namespaced2/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike/WithComments.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Baz.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/WarmedClass.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/WarmedInterface.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/A/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/A/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/C/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/C/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/PrefixCollision/A/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/PrefixCollision/A/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/PrefixCollision/C/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/alpha/PrefixCollision/C/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/A/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/A/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/C/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/C/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/PrefixCollision/A/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/PrefixCollision/A/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/PrefixCollision/C/B/Bar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/beta/PrefixCollision/C/B/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeClass.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeInterface.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeParent.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/multipleNs.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/notAClass.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/notPhpFile.md delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/classmap/sameNsMultipleClasses.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/deps/traits.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/fallback/Namespaced/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/fallback/Namespaced2/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/fallback/Pearlike/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/fallback/Pearlike2/FooBar.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/includepath/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/php5.4/traits.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/php5.5/class_cons.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/psr-4/Class_With_Underscores.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/psr-4/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/psr-4/Lets/Go/Deeper/Class_With_Underscores.php delete mode 100644 vendor/symfony/class-loader/Tests/Fixtures/psr-4/Lets/Go/Deeper/Foo.php delete mode 100644 vendor/symfony/class-loader/Tests/Psr4ClassLoaderTest.php delete mode 100644 vendor/symfony/class-loader/WinCacheClassLoader.php delete mode 100644 vendor/symfony/class-loader/XcacheClassLoader.php delete mode 100644 vendor/symfony/class-loader/composer.json delete mode 100644 vendor/symfony/class-loader/phpunit.xml.dist diff --git a/public/nginx.htaccess b/public/nginx.htaccess index e69de29b..cc2badf0 100644 --- a/public/nginx.htaccess +++ b/public/nginx.htaccess @@ -0,0 +1,6 @@ +location / { + if (!-e $request_filename) { + rewrite ^(.*)$ /index.php?s=$1 last; + break; + } +} \ No newline at end of file diff --git a/sql/article_main_ref_check_status.sql b/sql/article_main_ref_check_status.sql new file mode 100644 index 00000000..6f2f2d6b --- /dev/null +++ b/sql/article_main_ref_check_status.sql @@ -0,0 +1,4 @@ +-- 分节(t_article_main)引用校对总结果:明细仍在 t_reference_check_result(如 [70-73] 四条) +ALTER TABLE `t_article_main` + ADD COLUMN `ref_check_status` tinyint(1) NOT NULL DEFAULT 0 + COMMENT '引用校对总结果: 0未检测 1通过 2未通过 3检测中' AFTER `content`; diff --git a/sql/reference_check_result.sql b/sql/reference_check_result.sql new file mode 100644 index 00000000..16a31c50 --- /dev/null +++ b/sql/reference_check_result.sql @@ -0,0 +1,28 @@ +-- 单条引用检测结果(如 [70-73] 展开为 reference_no=70,71,72,73 共 4 行) +-- 分节是否通过见 t_article_main.ref_check_status +CREATE TABLE IF NOT EXISTS `t_reference_check_result` ( + `check_id` int(11) unsigned NOT NULL AUTO_INCREMENT, + `article_id` int(11) NOT NULL DEFAULT 0 COMMENT 't_article.article_id', + `am_id` int(11) NOT NULL DEFAULT 0 COMMENT 't_article_main.am_id', + `p_article_id` int(11) NOT NULL DEFAULT 0, + `p_refer_id` int(11) NOT NULL DEFAULT 0 COMMENT 't_production_article_refer.p_refer_id', + `refer_index` int(11) NOT NULL DEFAULT 0 COMMENT 'refer.index,正文序号=index+1', + `reference_no` int(11) NOT NULL DEFAULT 0 COMMENT 'blue 括号内序号 n,对应 index=n-1', + `reference_raw` varchar(64) NOT NULL DEFAULT '' COMMENT '如 70-73', + `cite_tag_start` int(11) NOT NULL DEFAULT 0 COMMENT 'blue标签起始字节偏移', + `cite_tag_end` int(11) NOT NULL DEFAULT 0 COMMENT 'blue标签结束字节偏移', + `text_start` int(11) NOT NULL DEFAULT 0 COMMENT '引用句起始字节偏移', + `text_end` int(11) NOT NULL DEFAULT 0 COMMENT '引用句结束字节偏移', + `content_a` text COMMENT '引用处上下文(正文)', + `content_b` text COMMENT '参考文献条目文本', + `is_match` tinyint(1) NOT NULL DEFAULT 0, + `confidence` decimal(6,4) NOT NULL DEFAULT 0.0000, + `reason` varchar(512) NOT NULL DEFAULT '', + `status` tinyint(1) NOT NULL DEFAULT 0 COMMENT '0待处理 1完成 2失败', + `error_msg` varchar(512) NOT NULL DEFAULT '', + `created_at` datetime DEFAULT NULL, + `updated_at` datetime DEFAULT NULL, + PRIMARY KEY (`check_id`), + KEY `idx_article_status` (`article_id`,`status`), + KEY `idx_p_refer` (`p_refer_id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='引用文献 LLM 校对结果'; diff --git a/sql/reference_check_result_alter_positions.sql b/sql/reference_check_result_alter_positions.sql new file mode 100644 index 00000000..688dd47e --- /dev/null +++ b/sql/reference_check_result_alter_positions.sql @@ -0,0 +1,7 @@ +-- 为预览标记增加原文位置字段([70-73] 展开为 4 条时共用 cite_tag_* / text_*) +ALTER TABLE `t_reference_check_result` + ADD COLUMN `cite_tag_start` int(11) NOT NULL DEFAULT 0 COMMENT 'blue标签起始字节偏移' AFTER `reference_raw`, + ADD COLUMN `cite_tag_end` int(11) NOT NULL DEFAULT 0 COMMENT 'blue标签结束字节偏移' AFTER `cite_tag_start`, + ADD COLUMN `text_start` int(11) NOT NULL DEFAULT 0 COMMENT '引用句起始字节偏移' AFTER `cite_tag_end`, + ADD COLUMN `text_end` int(11) NOT NULL DEFAULT 0 COMMENT '引用句结束字节偏移' AFTER `text_start`, + ADD KEY `idx_am_cite` (`am_id`,`cite_tag_start`,`reference_no`); diff --git a/sql/reference_check_result_can_support.sql b/sql/reference_check_result_can_support.sql new file mode 100644 index 00000000..86c62bc6 --- /dev/null +++ b/sql/reference_check_result_can_support.sql @@ -0,0 +1,3 @@ +-- 引用校对:是否能支撑(与 is_match 同步,便于前端单独展示) +ALTER TABLE `t_article_reference_check_result` + ADD COLUMN `can_support` tinyint(1) NOT NULL DEFAULT 0 COMMENT '文献能否支撑正文引用句 0否1是' AFTER `is_match`; diff --git a/thinkphp/library/think/cache/driver/Redis.php b/thinkphp/library/think/cache/driver/Redis.php index 7ab7b9fd..8956e774 100644 --- a/thinkphp/library/think/cache/driver/Redis.php +++ b/thinkphp/library/think/cache/driver/Redis.php @@ -25,7 +25,7 @@ class Redis extends Driver protected $options = [ 'host' => '127.0.0.1', 'port' => 6379, - 'password' => 'Jgll2015', + 'password' => '', 'select' => 0, 'timeout' => 0, 'expire' => 0, diff --git a/vendor/aliemail/email.php b/vendor/aliemail/email.php deleted file mode 100644 index 48c612e4..00000000 --- a/vendor/aliemail/email.php +++ /dev/null @@ -1,237 +0,0 @@ - debug = FALSE; - $this->smtp_port = $smtp_port; - $this->relay_host = $relay_host; - $this->time_out = 30; //is used in fsockopen() - $this->auth = $auth;//auth - $this->user = $user; - $this->pass = $pass; - $this->host_name = "localhost"; //is used in HELO command - $this->log_file = ""; - $this->sock = FALSE; - } - - /* Main Function */ - function sendmail($to, $from, $subject, $body, $mailtype, $cc, $bcc, $additional_headers, $fromUser, $replyToAddress) - { - $mail_from = $this->get_address($this->strip_comment($from)); - $body = preg_replace("/(^|(\r\n))(\.)/", "\1.\3", $body); - $header = "MIME-Version:1.0\r\n"; - if($mailtype=="HTML"){ - $header .= "Content-Type:text/html; charset=utf-8\r\n"; - } - $header .= "To: ".$to."\r\n"; - if ($cc != "") { - $header .= "Cc: ".$cc."\r\n"; - } - $header .= "From: $fromUser<".$from.">\r\n"; - $header .= "Subject: ".$subject."\r\n"; - $header .= "Reply-To: ".$replyToAddress."\r\n"; - $header .= $additional_headers; - $header .= "Date: ".date("r")."\r\n"; - $header .= "X-Mailer:By Redhat (PHP/".phpversion().")\r\n"; - list($msec, $sec) = explode(" ", microtime()); - $header .= "Message-ID: <".date("YmdHis", $sec).".".($msec*1000000).".".$mail_from.">\r\n"; - //若需要开启邮件跟踪服务,请使用以下代码设置跟踪链接头。前置条件和约束见文档"如何开启数据跟踪功能?" - //$header .= "Content-Transfer-Encoding: quoted-printable\r\n"; - //$header .= "X-AliDM-Trace: ". base64_encode(json_encode(['TagName'=>'用户创建的Tag','OpenTrace'=>"1"]))."\r\n"; - $TO = explode(",", $this->strip_comment($to)); - if ($cc != "") { - $TO = array_merge($TO, explode(",", $this->strip_comment($cc))); - } - if ($bcc != "") { - $TO = array_merge($TO, explode(",", $this->strip_comment($bcc))); - } - $sent = TRUE; - foreach ($TO as $rcpt_to) { - $rcpt_to = $this->get_address($rcpt_to); - if (!$this->smtp_sockopen($rcpt_to)) { - $this->log_write("Error: Cannot send email to ".$rcpt_to."\n"); - $sent = FALSE; - continue; - } - if ($this->smtp_send($this->host_name, $mail_from, $rcpt_to, $header, $body)) { - $this->log_write("E-mail has been sent to <".$rcpt_to.">\n"); - } else { - $this->log_write("Error: Cannot send email to <".$rcpt_to.">\n"); - $sent = FALSE; - } - fclose($this->sock); - $this->log_write("Disconnected from remote host\n"); - } - return $sent; - } - /* Private Functions */ - function smtp_send($helo, $from, $to, $header, $body = "") - { - if (!$this->smtp_putcmd("HELO", $helo)) { - return $this->smtp_error("sending HELO command"); - } - //auth - if($this->auth){ - if (!$this->smtp_putcmd("AUTH LOGIN", base64_encode($this->user))) { - return $this->smtp_error("sending HELO command"); - } - if (!$this->smtp_putcmd("", base64_encode($this->pass))) { - return $this->smtp_error("sending HELO command"); - } - } - if (!$this->smtp_putcmd("MAIL", "FROM:<".$from.">")) { - return $this->smtp_error("sending MAIL FROM command"); - } - if (!$this->smtp_putcmd("RCPT", "TO:<".$to.">")) { - return $this->smtp_error("sending RCPT TO command"); - } - if (!$this->smtp_putcmd("DATA")) { - return $this->smtp_error("sending DATA command"); - } - if (!$this->smtp_message($header, $body)) { - return $this->smtp_error("sending message"); - } - if (!$this->smtp_eom()) { - return $this->smtp_error("sending . [EOM]"); - } - if (!$this->smtp_putcmd("QUIT")) { - return $this->smtp_error("sending QUIT command"); - } - return TRUE; - } - function smtp_sockopen($address) - { - if ($this->relay_host == "") { - return $this->smtp_sockopen_mx($address); - } else { - return $this->smtp_sockopen_relay(); - } - } - function smtp_sockopen_relay() - { - $this->log_write("Trying to ".$this->relay_host.":".$this->smtp_port."\n"); - $this->sock = @fsockopen($this->relay_host, $this->smtp_port, $errno, $errstr, $this->time_out); - if (!($this->sock && $this->smtp_ok())) { - $this->log_write("Error: Cannot connenct to relay host ".$this->relay_host."\n"); - $this->log_write("Error: ".$errstr." (".$errno.")\n"); - return FALSE; - } - $this->log_write("Connected to relay host ".$this->relay_host."\n"); - return TRUE; - } - function smtp_sockopen_mx($address) - { - $domain = preg_replace("/^.+@([^@]+)$/", "\1", $address); - if (!@getmxrr($domain, $MXHOSTS)) { - $this->log_write("Error: Cannot resolve MX \"".$domain."\"\n"); - return FALSE; - } - foreach ($MXHOSTS as $host) { - $this->log_write("Trying to ".$host.":".$this->smtp_port."\n"); - $this->sock = @fsockopen($host, $this->smtp_port, $errno, $errstr, $this->time_out); - if (!($this->sock && $this->smtp_ok())) { - $this->log_write("Warning: Cannot connect to mx host ".$host."\n"); - $this->log_write("Error: ".$errstr." (".$errno.")\n"); - continue; - } - $this->log_write("Connected to mx host ".$host."\n"); - return TRUE; - } - $this->log_write("Error: Cannot connect to any mx hosts (".implode(", ", $MXHOSTS).")\n"); - return FALSE; - } - function smtp_message($header, $body) - { - fputs($this->sock, $header."\r\n".$body); - $this->smtp_debug("> ".str_replace("\r\n", "\n"."> ", $header."\n> ".$body."\n> ")); - return TRUE; - } - function smtp_eom() - { - fputs($this->sock, "\r\n.\r\n"); - $this->smtp_debug(". [EOM]\n"); - return $this->smtp_ok(); - } - function smtp_ok() - { - $response = str_replace("\r\n", "", fgets($this->sock, 512)); - $this->smtp_debug($response."\n"); - if (!preg_match("/^[23]/", $response)) { - fputs($this->sock, "QUIT\r\n"); - fgets($this->sock, 512); - $this->log_write("Error: Remote host returned \"".$response."\"\n"); - return FALSE; - } - return TRUE; - } - function smtp_putcmd($cmd, $arg = "") - { - if ($arg != "") { - if($cmd=="") $cmd = $arg; - else $cmd = $cmd." ".$arg; - } - fputs($this->sock, $cmd."\r\n"); - $this->smtp_debug("> ".$cmd."\n"); - return $this->smtp_ok(); - } - function smtp_error($string) - { - $this->log_write("Error: Error occurred while ".$string.".\n"); - return FALSE; - } - function log_write($message) - { - $this->smtp_debug($message); - if ($this->log_file == "") { - return TRUE; - } - $message = date("M d H:i:s ").get_current_user()."[".getmypid()."]: ".$message; - if (!@file_exists($this->log_file) || !($fp = @fopen($this->log_file, "a"))) { - $this->smtp_debug("Warning: Cannot open log file \"".$this->log_file."\"\n"); - return FALSE; - } - flock($fp, LOCK_EX); - fputs($fp, $message); - fclose($fp); - return TRUE; - } - function strip_comment($address) - { - $comment = "/\([^()]*\)/"; - while (preg_match($comment, $address)) { - $address = preg_replace($comment, "", $address); - } - return $address; - } - function get_address($address) - { - $address = preg_replace("/([ \t\r\n])+/", "", $address); - $address = preg_replace("/^.*<(.+)>.*$/", "\1", $address); - return $address; - } - function smtp_debug($message) - { - if ($this->debug) { - echo $message; - } - } - } - ?> \ No newline at end of file diff --git a/vendor/autoload.php b/vendor/autoload.php index 9eaf68c9..bfdba2e0 100644 --- a/vendor/autoload.php +++ b/vendor/autoload.php @@ -14,12 +14,9 @@ if (PHP_VERSION_ID < 50600) { echo $err; } } - trigger_error( - $err, - E_USER_ERROR - ); + throw new RuntimeException($err); } require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInit2bc4f313dba415539e266f7ac2c87dcd::getLoader(); +return ComposerAutoloaderInit7020b987d316c2076c2a6f439a1140f9::getLoader(); diff --git a/vendor/composer/InstalledVersions.php b/vendor/composer/InstalledVersions.php index 51e734a7..2052022f 100644 --- a/vendor/composer/InstalledVersions.php +++ b/vendor/composer/InstalledVersions.php @@ -26,12 +26,23 @@ use Composer\Semver\VersionParser; */ class InstalledVersions { + /** + * @var string|null if set (by reflection by Composer), this should be set to the path where this class is being copied to + * @internal + */ + private static $selfDir = null; + /** * @var mixed[]|null * @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array}|array{}|null */ private static $installed; + /** + * @var bool + */ + private static $installedIsLocalDir; + /** * @var bool|null */ @@ -309,6 +320,24 @@ class InstalledVersions { self::$installed = $data; self::$installedByVendor = array(); + + // when using reload, we disable the duplicate protection to ensure that self::$installed data is + // always returned, but we cannot know whether it comes from the installed.php in __DIR__ or not, + // so we have to assume it does not, and that may result in duplicate data being returned when listing + // all installed packages for example + self::$installedIsLocalDir = false; + } + + /** + * @return string + */ + private static function getSelfDir() + { + if (self::$selfDir === null) { + self::$selfDir = strtr(__DIR__, '\\', '/'); + } + + return self::$selfDir; } /** @@ -322,19 +351,27 @@ class InstalledVersions } $installed = array(); + $copiedLocalDir = false; if (self::$canGetVendors) { + $selfDir = self::getSelfDir(); foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) { + $vendorDir = strtr($vendorDir, '\\', '/'); if (isset(self::$installedByVendor[$vendorDir])) { $installed[] = self::$installedByVendor[$vendorDir]; } elseif (is_file($vendorDir.'/composer/installed.php')) { /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */ $required = require $vendorDir.'/composer/installed.php'; - $installed[] = self::$installedByVendor[$vendorDir] = $required; - if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) { - self::$installed = $installed[count($installed) - 1]; + self::$installedByVendor[$vendorDir] = $required; + $installed[] = $required; + if (self::$installed === null && $vendorDir.'/composer' === $selfDir) { + self::$installed = $required; + self::$installedIsLocalDir = true; } } + if (self::$installedIsLocalDir && $vendorDir.'/composer' === $selfDir) { + $copiedLocalDir = true; + } } } @@ -350,7 +387,7 @@ class InstalledVersions } } - if (self::$installed !== array()) { + if (self::$installed !== array() && !$copiedLocalDir) { $installed[] = self::$installed; } diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php index 18e0a0b7..730bac18 100644 --- a/vendor/composer/autoload_classmap.php +++ b/vendor/composer/autoload_classmap.php @@ -6,6 +6,10 @@ $vendorDir = dirname(__DIR__); $baseDir = dirname($vendorDir); return array( + 'Attribute' => $vendorDir . '/symfony/polyfill-php80/Resources/stubs/Attribute.php', 'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php', + 'PhpToken' => $vendorDir . '/symfony/polyfill-php80/Resources/stubs/PhpToken.php', 'Stringable' => $vendorDir . '/myclabs/php-enum/stubs/Stringable.php', + 'UnhandledMatchError' => $vendorDir . '/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php', + 'ValueError' => $vendorDir . '/symfony/polyfill-php80/Resources/stubs/ValueError.php', ); diff --git a/vendor/composer/autoload_files.php b/vendor/composer/autoload_files.php index 6377326c..8c79ad6e 100644 --- a/vendor/composer/autoload_files.php +++ b/vendor/composer/autoload_files.php @@ -6,12 +6,13 @@ $vendorDir = dirname(__DIR__); $baseDir = dirname($vendorDir); return array( + '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php', + '6e3fae29631ef280660b3cdad06f25a8' => $vendorDir . '/symfony/deprecation-contracts/function.php', + 'a4a119a56e50fbb293281d9a48007e0e' => $vendorDir . '/symfony/polyfill-php80/bootstrap.php', '9c67151ae59aff4788964ce8eb2a0f43' => $vendorDir . '/clue/stream-filter/src/functions_include.php', '7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php', - '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php', '2cffec82183ee1cea088009cef9a6fc3' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier.composer.php', '8cff32064859f4559445b89279f3199c' => $vendorDir . '/php-http/message/src/filters.php', - '6e3fae29631ef280660b3cdad06f25a8' => $vendorDir . '/symfony/deprecation-contracts/function.php', '9b552a3cc426e3287cc811caefa3cf53' => $vendorDir . '/topthink/think-helper/src/helper.php', '37a3dc5111fe8f707ab4c132ef1dbc62' => $vendorDir . '/guzzlehttp/guzzle/src/functions_include.php', '1cfd2761b63b0a29ed23657ea394cb2d' => $vendorDir . '/topthink/think-captcha/src/helper.php', diff --git a/vendor/composer/autoload_psr4.php b/vendor/composer/autoload_psr4.php index 38d20f11..ee3d45d2 100644 --- a/vendor/composer/autoload_psr4.php +++ b/vendor/composer/autoload_psr4.php @@ -8,13 +8,15 @@ $baseDir = dirname($vendorDir); return array( 'think\\composer\\' => array($vendorDir . '/topthink/think-installer/src'), 'think\\captcha\\' => array($vendorDir . '/topthink/think-captcha/src'), - 'think\\' => array($baseDir . '/thinkphp/library/think', $vendorDir . '/topthink/think-helper/src', $vendorDir . '/topthink/think-image/src', $vendorDir . '/topthink/think-queue/src'), + 'think\\' => array($vendorDir . '/topthink/think-queue/src', $vendorDir . '/topthink/think-image/src', $vendorDir . '/topthink/think-helper/src', $baseDir . '/thinkphp/library/think'), 'app\\' => array($baseDir . '/application'), 'apimatic\\jsonmapper\\' => array($vendorDir . '/apimatic/jsonmapper/src'), 'ZipStream\\' => array($vendorDir . '/maennchen/zipstream-php/src'), 'Unirest\\' => array($vendorDir . '/apimatic/unirest-php/src'), 'Tectalic\\OpenAi\\' => array($vendorDir . '/tectalic/openai/src'), + 'Symfony\\Polyfill\\Php80\\' => array($vendorDir . '/symfony/polyfill-php80'), 'Symfony\\Polyfill\\Mbstring\\' => array($vendorDir . '/symfony/polyfill-mbstring'), + 'Symfony\\Component\\HttpFoundation\\' => array($vendorDir . '/symfony/http-foundation'), 'Spatie\\DataTransferObject\\' => array($vendorDir . '/spatie/data-transfer-object/src'), 'Psr\\SimpleCache\\' => array($vendorDir . '/psr/simple-cache/src'), 'Psr\\Log\\' => array($vendorDir . '/psr/log/Psr/Log'), diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php index b341152f..11d4dcbc 100644 --- a/vendor/composer/autoload_real.php +++ b/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInit2bc4f313dba415539e266f7ac2c87dcd +class ComposerAutoloaderInit7020b987d316c2076c2a6f439a1140f9 { private static $loader; @@ -24,16 +24,16 @@ class ComposerAutoloaderInit2bc4f313dba415539e266f7ac2c87dcd require __DIR__ . '/platform_check.php'; - spl_autoload_register(array('ComposerAutoloaderInit2bc4f313dba415539e266f7ac2c87dcd', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInit7020b987d316c2076c2a6f439a1140f9', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__)); - spl_autoload_unregister(array('ComposerAutoloaderInit2bc4f313dba415539e266f7ac2c87dcd', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInit7020b987d316c2076c2a6f439a1140f9', 'loadClassLoader')); require __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::getInitializer($loader)); $loader->register(true); - $filesToLoad = \Composer\Autoload\ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::$files; + $filesToLoad = \Composer\Autoload\ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::$files; $requireFile = \Closure::bind(static function ($fileIdentifier, $file) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true; diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php index dc16926a..836bb54e 100644 --- a/vendor/composer/autoload_static.php +++ b/vendor/composer/autoload_static.php @@ -4,15 +4,16 @@ namespace Composer\Autoload; -class ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd +class ComposerStaticInit7020b987d316c2076c2a6f439a1140f9 { public static $files = array ( + '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php', + '6e3fae29631ef280660b3cdad06f25a8' => __DIR__ . '/..' . '/symfony/deprecation-contracts/function.php', + 'a4a119a56e50fbb293281d9a48007e0e' => __DIR__ . '/..' . '/symfony/polyfill-php80/bootstrap.php', '9c67151ae59aff4788964ce8eb2a0f43' => __DIR__ . '/..' . '/clue/stream-filter/src/functions_include.php', '7b11c4dc42b3b3023073cb14e519683c' => __DIR__ . '/..' . '/ralouphie/getallheaders/src/getallheaders.php', - '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php', '2cffec82183ee1cea088009cef9a6fc3' => __DIR__ . '/..' . '/ezyang/htmlpurifier/library/HTMLPurifier.composer.php', '8cff32064859f4559445b89279f3199c' => __DIR__ . '/..' . '/php-http/message/src/filters.php', - '6e3fae29631ef280660b3cdad06f25a8' => __DIR__ . '/..' . '/symfony/deprecation-contracts/function.php', '9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php', '37a3dc5111fe8f707ab4c132ef1dbc62' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/functions_include.php', '1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php', @@ -20,35 +21,37 @@ class ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd ); public static $prefixLengthsPsr4 = array ( - 't' => + 't' => array ( 'think\\composer\\' => 15, 'think\\captcha\\' => 14, 'think\\' => 6, ), - 'a' => + 'a' => array ( 'app\\' => 4, 'apimatic\\jsonmapper\\' => 20, ), - 'Z' => + 'Z' => array ( 'ZipStream\\' => 10, ), - 'U' => + 'U' => array ( 'Unirest\\' => 8, ), - 'T' => + 'T' => array ( 'Tectalic\\OpenAi\\' => 16, ), - 'S' => + 'S' => array ( + 'Symfony\\Polyfill\\Php80\\' => 23, 'Symfony\\Polyfill\\Mbstring\\' => 26, + 'Symfony\\Component\\HttpFoundation\\' => 33, 'Spatie\\DataTransferObject\\' => 26, ), - 'P' => + 'P' => array ( 'Psr\\SimpleCache\\' => 16, 'Psr\\Log\\' => 8, @@ -60,28 +63,28 @@ class ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd 'PaypalServerSdkLib\\' => 19, 'PHPMailer\\PHPMailer\\' => 20, ), - 'N' => + 'N' => array ( 'Nyholm\\Psr7\\' => 12, ), - 'M' => + 'M' => array ( 'MyCLabs\\Enum\\' => 13, 'Matrix\\' => 7, ), - 'H' => + 'H' => array ( 'Http\\Message\\MultipartStream\\' => 29, 'Http\\Message\\' => 13, 'Http\\Discovery\\' => 15, ), - 'G' => + 'G' => array ( 'GuzzleHttp\\Psr7\\' => 16, 'GuzzleHttp\\Promise\\' => 19, 'GuzzleHttp\\' => 11, ), - 'C' => + 'C' => array ( 'Core\\' => 5, 'CoreInterfaces\\' => 15, @@ -91,158 +94,166 @@ class ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd ); public static $prefixDirsPsr4 = array ( - 'think\\composer\\' => + 'think\\composer\\' => array ( 0 => __DIR__ . '/..' . '/topthink/think-installer/src', ), - 'think\\captcha\\' => + 'think\\captcha\\' => array ( 0 => __DIR__ . '/..' . '/topthink/think-captcha/src', ), - 'think\\' => + 'think\\' => array ( - 0 => __DIR__ . '/../..' . '/thinkphp/library/think', - 1 => __DIR__ . '/..' . '/topthink/think-helper/src', - 2 => __DIR__ . '/..' . '/topthink/think-image/src', - 3 => __DIR__ . '/..' . '/topthink/think-queue/src', + 0 => __DIR__ . '/..' . '/topthink/think-queue/src', + 1 => __DIR__ . '/..' . '/topthink/think-image/src', + 2 => __DIR__ . '/..' . '/topthink/think-helper/src', + 3 => __DIR__ . '/../..' . '/thinkphp/library/think', ), - 'app\\' => + 'app\\' => array ( 0 => __DIR__ . '/../..' . '/application', ), - 'apimatic\\jsonmapper\\' => + 'apimatic\\jsonmapper\\' => array ( 0 => __DIR__ . '/..' . '/apimatic/jsonmapper/src', ), - 'ZipStream\\' => + 'ZipStream\\' => array ( 0 => __DIR__ . '/..' . '/maennchen/zipstream-php/src', ), - 'Unirest\\' => + 'Unirest\\' => array ( 0 => __DIR__ . '/..' . '/apimatic/unirest-php/src', ), - 'Tectalic\\OpenAi\\' => + 'Tectalic\\OpenAi\\' => array ( 0 => __DIR__ . '/..' . '/tectalic/openai/src', ), - 'Symfony\\Polyfill\\Mbstring\\' => + 'Symfony\\Polyfill\\Php80\\' => + array ( + 0 => __DIR__ . '/..' . '/symfony/polyfill-php80', + ), + 'Symfony\\Polyfill\\Mbstring\\' => array ( 0 => __DIR__ . '/..' . '/symfony/polyfill-mbstring', ), - 'Spatie\\DataTransferObject\\' => + 'Symfony\\Component\\HttpFoundation\\' => + array ( + 0 => __DIR__ . '/..' . '/symfony/http-foundation', + ), + 'Spatie\\DataTransferObject\\' => array ( 0 => __DIR__ . '/..' . '/spatie/data-transfer-object/src', ), - 'Psr\\SimpleCache\\' => + 'Psr\\SimpleCache\\' => array ( 0 => __DIR__ . '/..' . '/psr/simple-cache/src', ), - 'Psr\\Log\\' => + 'Psr\\Log\\' => array ( 0 => __DIR__ . '/..' . '/psr/log/Psr/Log', ), - 'Psr\\Http\\Message\\' => + 'Psr\\Http\\Message\\' => array ( 0 => __DIR__ . '/..' . '/psr/http-factory/src', 1 => __DIR__ . '/..' . '/psr/http-message/src', ), - 'Psr\\Http\\Client\\' => + 'Psr\\Http\\Client\\' => array ( 0 => __DIR__ . '/..' . '/psr/http-client/src', ), - 'PhpOffice\\PhpWord\\' => + 'PhpOffice\\PhpWord\\' => array ( 0 => __DIR__ . '/..' . '/phpoffice/phpword/src/PhpWord', ), - 'PhpOffice\\PhpSpreadsheet\\' => + 'PhpOffice\\PhpSpreadsheet\\' => array ( 0 => __DIR__ . '/..' . '/phpoffice/phpspreadsheet/src/PhpSpreadsheet', ), - 'PhpOffice\\Math\\' => + 'PhpOffice\\Math\\' => array ( 0 => __DIR__ . '/..' . '/phpoffice/math/src/Math', ), - 'PaypalServerSdkLib\\' => + 'PaypalServerSdkLib\\' => array ( 0 => __DIR__ . '/..' . '/paypal/paypal-server-sdk/src', ), - 'PHPMailer\\PHPMailer\\' => + 'PHPMailer\\PHPMailer\\' => array ( 0 => __DIR__ . '/..' . '/phpmailer/phpmailer/src', ), - 'Nyholm\\Psr7\\' => + 'Nyholm\\Psr7\\' => array ( 0 => __DIR__ . '/..' . '/nyholm/psr7/src', ), - 'MyCLabs\\Enum\\' => + 'MyCLabs\\Enum\\' => array ( 0 => __DIR__ . '/..' . '/myclabs/php-enum/src', ), - 'Matrix\\' => + 'Matrix\\' => array ( 0 => __DIR__ . '/..' . '/markbaker/matrix/classes/src', ), - 'Http\\Message\\MultipartStream\\' => + 'Http\\Message\\MultipartStream\\' => array ( 0 => __DIR__ . '/..' . '/php-http/multipart-stream-builder/src', ), - 'Http\\Message\\' => + 'Http\\Message\\' => array ( 0 => __DIR__ . '/..' . '/php-http/message/src', ), - 'Http\\Discovery\\' => + 'Http\\Discovery\\' => array ( 0 => __DIR__ . '/..' . '/php-http/discovery/src', ), - 'GuzzleHttp\\Psr7\\' => + 'GuzzleHttp\\Psr7\\' => array ( 0 => __DIR__ . '/..' . '/guzzlehttp/psr7/src', ), - 'GuzzleHttp\\Promise\\' => + 'GuzzleHttp\\Promise\\' => array ( 0 => __DIR__ . '/..' . '/guzzlehttp/promises/src', ), - 'GuzzleHttp\\' => + 'GuzzleHttp\\' => array ( 0 => __DIR__ . '/..' . '/guzzlehttp/guzzle/src', ), - 'Core\\' => + 'Core\\' => array ( 0 => __DIR__ . '/..' . '/apimatic/core/src', ), - 'CoreInterfaces\\' => + 'CoreInterfaces\\' => array ( 0 => __DIR__ . '/..' . '/apimatic/core-interfaces/src', ), - 'Complex\\' => + 'Complex\\' => array ( 0 => __DIR__ . '/..' . '/markbaker/complex/classes/src', ), - 'Clue\\StreamFilter\\' => + 'Clue\\StreamFilter\\' => array ( 0 => __DIR__ . '/..' . '/clue/stream-filter/src', ), ); public static $prefixesPsr0 = array ( - 'R' => + 'R' => array ( - 'Rs\\Json' => + 'Rs\\Json' => array ( 0 => __DIR__ . '/..' . '/php-jsonpointer/php-jsonpointer/src', ), ), - 'P' => + 'P' => array ( - 'PHPExcel' => + 'PHPExcel' => array ( 0 => __DIR__ . '/..' . '/phpoffice/phpexcel/Classes', ), ), - 'H' => + 'H' => array ( - 'HTMLPurifier' => + 'HTMLPurifier' => array ( 0 => __DIR__ . '/..' . '/ezyang/htmlpurifier/library', ), @@ -250,17 +261,21 @@ class ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd ); public static $classMap = array ( + 'Attribute' => __DIR__ . '/..' . '/symfony/polyfill-php80/Resources/stubs/Attribute.php', 'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php', + 'PhpToken' => __DIR__ . '/..' . '/symfony/polyfill-php80/Resources/stubs/PhpToken.php', 'Stringable' => __DIR__ . '/..' . '/myclabs/php-enum/stubs/Stringable.php', + 'UnhandledMatchError' => __DIR__ . '/..' . '/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php', + 'ValueError' => __DIR__ . '/..' . '/symfony/polyfill-php80/Resources/stubs/ValueError.php', ); public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::$prefixesPsr0; - $loader->classMap = ComposerStaticInit2bc4f313dba415539e266f7ac2c87dcd::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::$prefixDirsPsr4; + $loader->prefixesPsr0 = ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::$prefixesPsr0; + $loader->classMap = ComposerStaticInit7020b987d316c2076c2a6f439a1140f9::$classMap; }, null, ClassLoader::class); } diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json index 2f9fcbf0..103df237 100644 --- a/vendor/composer/installed.json +++ b/vendor/composer/installed.json @@ -1,2709 +1,2717 @@ { - "packages": [ - { - "name": "apimatic/core", - "version": "0.3.13", - "version_normalized": "0.3.13.0", - "source": { - "type": "git", - "url": "https://github.com/apimatic/core-lib-php.git", - "reference": "944678aa7017457daacd9750b96962fb693ea81a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/apimatic/core-lib-php/zipball/944678aa7017457daacd9750b96962fb693ea81a", - "reference": "944678aa7017457daacd9750b96962fb693ea81a", - "shasum": "" - }, - "require": { - "apimatic/core-interfaces": "~0.1.5", - "apimatic/jsonmapper": "^3.1.1", - "ext-curl": "*", - "ext-dom": "*", - "ext-json": "*", - "ext-libxml": "*", - "php": "^7.2 || ^8.0", - "php-jsonpointer/php-jsonpointer": "^3.0.2", - "psr/log": "^1.1.4 || ^2.0.0 || ^3.0.0" - }, - "require-dev": { - "phan/phan": "5.4.5", - "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", - "squizlabs/php_codesniffer": "^3.5" - }, - "time": "2024-12-18T08:29:12+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Core\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "description": "Core logic and the utilities for the Apimatic's PHP SDK", - "homepage": "https://github.com/apimatic/core-lib-php", - "keywords": [ - "apimatic", - "core", - "corelib", - "php" - ], - "support": { - "issues": "https://github.com/apimatic/core-lib-php/issues", - "source": "https://github.com/apimatic/core-lib-php/tree/0.3.13" - }, - "install-path": "../apimatic/core" - }, - { - "name": "apimatic/core-interfaces", - "version": "0.1.5", - "version_normalized": "0.1.5.0", - "source": { - "type": "git", - "url": "https://github.com/apimatic/core-interfaces-php.git", - "reference": "b4f1bffc8be79584836f70af33c65e097eec155c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/apimatic/core-interfaces-php/zipball/b4f1bffc8be79584836f70af33c65e097eec155c", - "reference": "b4f1bffc8be79584836f70af33c65e097eec155c", - "shasum": "" - }, - "require": { - "php": "^7.2 || ^8.0" - }, - "time": "2024-05-09T06:32:07+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "CoreInterfaces\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "description": "Definition of the behavior of apimatic/core, apimatic/unirest-php and Apimatic's PHP SDK", - "homepage": "https://github.com/apimatic/core-interfaces-php", - "keywords": [ - "apimatic", - "core", - "corelib", - "interface", - "php", - "unirest" - ], - "support": { - "issues": "https://github.com/apimatic/core-interfaces-php/issues", - "source": "https://github.com/apimatic/core-interfaces-php/tree/0.1.5" - }, - "install-path": "../apimatic/core-interfaces" - }, - { - "name": "apimatic/jsonmapper", - "version": "3.1.6", - "version_normalized": "3.1.6.0", - "source": { - "type": "git", - "url": "https://github.com/apimatic/jsonmapper.git", - "reference": "c6cc21bd56bfe5d5822bbd08f514be465c0b24e7" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/apimatic/jsonmapper/zipball/c6cc21bd56bfe5d5822bbd08f514be465c0b24e7", - "reference": "c6cc21bd56bfe5d5822bbd08f514be465c0b24e7", - "shasum": "" - }, - "require": { - "ext-json": "*", - "php": "^5.6 || ^7.0 || ^8.0" - }, - "require-dev": { - "phpunit/phpunit": "^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0 || ^9.0.0", - "squizlabs/php_codesniffer": "^3.0.0" - }, - "time": "2024-11-28T09:15:32+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "apimatic\\jsonmapper\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "OSL-3.0" - ], - "authors": [ + "packages": [ { - "name": "Christian Weiske", - "email": "christian.weiske@netresearch.de", - "homepage": "http://www.netresearch.de/", - "role": "Developer" + "name": "apimatic/core", + "version": "0.3.17", + "version_normalized": "0.3.17.0", + "source": { + "type": "git", + "url": "https://github.com/apimatic/core-lib-php.git", + "reference": "a48a583f686ee3786432b976c795a2817ec095b3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/apimatic/core-lib-php/zipball/a48a583f686ee3786432b976c795a2817ec095b3", + "reference": "a48a583f686ee3786432b976c795a2817ec095b3", + "shasum": "" + }, + "require": { + "apimatic/core-interfaces": "~0.1.5", + "apimatic/jsonmapper": "^3.1.1", + "ext-curl": "*", + "ext-dom": "*", + "ext-json": "*", + "ext-libxml": "*", + "php": "^7.2 || ^8.0", + "php-jsonpointer/php-jsonpointer": "^3.0.2", + "psr/log": "^1.1.4 || ^2.0.0 || ^3.0.0", + "symfony/http-foundation": "^5.4 || ^6.0 || ^7.0 || ^8.0" + }, + "require-dev": { + "phan/phan": "5.4.5", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", + "squizlabs/php_codesniffer": "^3.5" + }, + "time": "2026-01-27T05:14:10+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Core\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Core logic and the utilities for the Apimatic's PHP SDK", + "homepage": "https://github.com/apimatic/core-lib-php", + "keywords": [ + "apimatic", + "core", + "corelib", + "php" + ], + "support": { + "issues": "https://github.com/apimatic/core-lib-php/issues", + "source": "https://github.com/apimatic/core-lib-php/tree/0.3.17" + }, + "install-path": "../apimatic/core" }, { - "name": "Mehdi Jaffery", - "email": "mehdi.jaffery@apimatic.io", - "homepage": "http://apimatic.io/", - "role": "Developer" - } - ], - "description": "Map nested JSON structures onto PHP classes", - "support": { - "email": "mehdi.jaffery@apimatic.io", - "issues": "https://github.com/apimatic/jsonmapper/issues", - "source": "https://github.com/apimatic/jsonmapper/tree/3.1.6" - }, - "install-path": "../apimatic/jsonmapper" - }, - { - "name": "apimatic/unirest-php", - "version": "4.0.5", - "version_normalized": "4.0.5.0", - "source": { - "type": "git", - "url": "https://github.com/apimatic/unirest-php.git", - "reference": "e16754010c16be5473289470f129d87a0f41b55e" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/apimatic/unirest-php/zipball/e16754010c16be5473289470f129d87a0f41b55e", - "reference": "e16754010c16be5473289470f129d87a0f41b55e", - "shasum": "" - }, - "require": { - "apimatic/core-interfaces": "^0.1.0", - "ext-curl": "*", - "ext-json": "*", - "php": "^7.2 || ^8.0" - }, - "require-dev": { - "phan/phan": "5.4.2", - "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", - "squizlabs/php_codesniffer": "^3.5" - }, - "time": "2023-04-25T14:19:45+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Unirest\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Mashape", - "email": "opensource@mashape.com", - "homepage": "https://www.mashape.com", - "role": "Developer" + "name": "apimatic/core-interfaces", + "version": "0.1.5", + "version_normalized": "0.1.5.0", + "source": { + "type": "git", + "url": "https://github.com/apimatic/core-interfaces-php.git", + "reference": "b4f1bffc8be79584836f70af33c65e097eec155c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/apimatic/core-interfaces-php/zipball/b4f1bffc8be79584836f70af33c65e097eec155c", + "reference": "b4f1bffc8be79584836f70af33c65e097eec155c", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "time": "2024-05-09T06:32:07+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "CoreInterfaces\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Definition of the behavior of apimatic/core, apimatic/unirest-php and Apimatic's PHP SDK", + "homepage": "https://github.com/apimatic/core-interfaces-php", + "keywords": [ + "apimatic", + "core", + "corelib", + "interface", + "php", + "unirest" + ], + "support": { + "issues": "https://github.com/apimatic/core-interfaces-php/issues", + "source": "https://github.com/apimatic/core-interfaces-php/tree/0.1.5" + }, + "install-path": "../apimatic/core-interfaces" }, { - "name": "APIMATIC", - "email": "opensource@apimatic.io", - "homepage": "https://www.apimatic.io", - "role": "Developer" - } - ], - "description": "Unirest PHP", - "homepage": "https://github.com/apimatic/unirest-php", - "keywords": [ - "client", - "curl", - "http", - "https", - "rest" - ], - "support": { - "email": "opensource@apimatic.io", - "issues": "https://github.com/apimatic/unirest-php/issues", - "source": "https://github.com/apimatic/unirest-php/tree/4.0.5" - }, - "install-path": "../apimatic/unirest-php" - }, - { - "name": "clue/stream-filter", - "version": "v1.7.0", - "version_normalized": "1.7.0.0", - "source": { - "type": "git", - "url": "https://github.com/clue/stream-filter.git", - "reference": "049509fef80032cb3f051595029ab75b49a3c2f7" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/clue/stream-filter/zipball/049509fef80032cb3f051595029ab75b49a3c2f7", - "reference": "049509fef80032cb3f051595029ab75b49a3c2f7", - "shasum": "" - }, - "require": { - "php": ">=5.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" - }, - "time": "2023-12-20T15:40:13+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "files": [ - "src/functions_include.php" - ], - "psr-4": { - "Clue\\StreamFilter\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Christian Lück", - "email": "christian@clue.engineering" - } - ], - "description": "A simple and modern approach to stream filtering in PHP", - "homepage": "https://github.com/clue/stream-filter", - "keywords": [ - "bucket brigade", - "callback", - "filter", - "php_user_filter", - "stream", - "stream_filter_append", - "stream_filter_register" - ], - "support": { - "issues": "https://github.com/clue/stream-filter/issues", - "source": "https://github.com/clue/stream-filter/tree/v1.7.0" - }, - "funding": [ - { - "url": "https://clue.engineering/support", - "type": "custom" + "name": "apimatic/jsonmapper", + "version": "3.1.7", + "version_normalized": "3.1.7.0", + "source": { + "type": "git", + "url": "https://github.com/apimatic/jsonmapper.git", + "reference": "61e45f6021e4a4e07497be596b4787c3c6b39bea" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/apimatic/jsonmapper/zipball/61e45f6021e4a4e07497be596b4787c3c6b39bea", + "reference": "61e45f6021e4a4e07497be596b4787c3c6b39bea", + "shasum": "" + }, + "require": { + "ext-json": "*", + "php": "^5.6 || ^7.0 || ^8.0" + }, + "require-dev": { + "phpunit/phpunit": "^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0 || ^9.0.0", + "squizlabs/php_codesniffer": "^3.0.0" + }, + "time": "2025-11-06T14:43:04+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "apimatic\\jsonmapper\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "OSL-3.0" + ], + "authors": [ + { + "name": "Christian Weiske", + "email": "christian.weiske@netresearch.de", + "homepage": "http://www.netresearch.de/", + "role": "Developer" + }, + { + "name": "Mehdi Jaffery", + "email": "mehdi.jaffery@apimatic.io", + "homepage": "http://apimatic.io/", + "role": "Developer" + } + ], + "description": "Map nested JSON structures onto PHP classes", + "support": { + "email": "mehdi.jaffery@apimatic.io", + "issues": "https://github.com/apimatic/jsonmapper/issues", + "source": "https://github.com/apimatic/jsonmapper/tree/3.1.7" + }, + "install-path": "../apimatic/jsonmapper" }, { - "url": "https://github.com/clue", - "type": "github" - } - ], - "install-path": "../clue/stream-filter" - }, - { - "name": "ezyang/htmlpurifier", - "version": "v4.18.0", - "version_normalized": "4.18.0.0", - "source": { - "type": "git", - "url": "https://github.com/ezyang/htmlpurifier.git", - "reference": "cb56001e54359df7ae76dc522d08845dc741621b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/ezyang/htmlpurifier/zipball/cb56001e54359df7ae76dc522d08845dc741621b", - "reference": "cb56001e54359df7ae76dc522d08845dc741621b", - "shasum": "" - }, - "require": { - "php": "~5.6.0 || ~7.0.0 || ~7.1.0 || ~7.2.0 || ~7.3.0 || ~7.4.0 || ~8.0.0 || ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0" - }, - "require-dev": { - "cerdic/css-tidy": "^1.7 || ^2.0", - "simpletest/simpletest": "dev-master" - }, - "suggest": { - "cerdic/css-tidy": "If you want to use the filter 'Filter.ExtractStyleBlocks'.", - "ext-bcmath": "Used for unit conversion and imagecrash protection", - "ext-iconv": "Converts text to and from non-UTF-8 encodings", - "ext-tidy": "Used for pretty-printing HTML" - }, - "time": "2024-11-01T03:51:45+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "files": [ - "library/HTMLPurifier.composer.php" - ], - "psr-0": { - "HTMLPurifier": "library/" - }, - "exclude-from-classmap": [ - "/library/HTMLPurifier/Language/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-2.1-or-later" - ], - "authors": [ - { - "name": "Edward Z. Yang", - "email": "admin@htmlpurifier.org", - "homepage": "http://ezyang.com" - } - ], - "description": "Standards compliant HTML filter written in PHP", - "homepage": "http://htmlpurifier.org/", - "keywords": [ - "html" - ], - "support": { - "issues": "https://github.com/ezyang/htmlpurifier/issues", - "source": "https://github.com/ezyang/htmlpurifier/tree/v4.18.0" - }, - "install-path": "../ezyang/htmlpurifier" - }, - { - "name": "guzzlehttp/guzzle", - "version": "7.9.2", - "version_normalized": "7.9.2.0", - "source": { - "type": "git", - "url": "https://github.com/guzzle/guzzle.git", - "reference": "d281ed313b989f213357e3be1a179f02196ac99b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/guzzle/guzzle/zipball/d281ed313b989f213357e3be1a179f02196ac99b", - "reference": "d281ed313b989f213357e3be1a179f02196ac99b", - "shasum": "" - }, - "require": { - "ext-json": "*", - "guzzlehttp/promises": "^1.5.3 || ^2.0.3", - "guzzlehttp/psr7": "^2.7.0", - "php": "^7.2.5 || ^8.0", - "psr/http-client": "^1.0", - "symfony/deprecation-contracts": "^2.2 || ^3.0" - }, - "provide": { - "psr/http-client-implementation": "1.0" - }, - "require-dev": { - "bamarni/composer-bin-plugin": "^1.8.2", - "ext-curl": "*", - "guzzle/client-integration-tests": "3.0.2", - "php-http/message-factory": "^1.1", - "phpunit/phpunit": "^8.5.39 || ^9.6.20", - "psr/log": "^1.1 || ^2.0 || ^3.0" - }, - "suggest": { - "ext-curl": "Required for CURL handler support", - "ext-intl": "Required for Internationalized Domain Name (IDN) support", - "psr/log": "Required for using the Log middleware" - }, - "time": "2024-07-24T11:22:20+00:00", - "type": "library", - "extra": { - "bamarni-bin": { - "bin-links": true, - "forward-command": false - } - }, - "installation-source": "dist", - "autoload": { - "files": [ - "src/functions_include.php" - ], - "psr-4": { - "GuzzleHttp\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Graham Campbell", - "email": "hello@gjcampbell.co.uk", - "homepage": "https://github.com/GrahamCampbell" + "name": "apimatic/unirest-php", + "version": "4.0.7", + "version_normalized": "4.0.7.0", + "source": { + "type": "git", + "url": "https://github.com/apimatic/unirest-php.git", + "reference": "bdfd5f27c105772682c88ed671683f1bd93f4a3c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/apimatic/unirest-php/zipball/bdfd5f27c105772682c88ed671683f1bd93f4a3c", + "reference": "bdfd5f27c105772682c88ed671683f1bd93f4a3c", + "shasum": "" + }, + "require": { + "apimatic/core-interfaces": "^0.1.0", + "ext-curl": "*", + "ext-json": "*", + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "phan/phan": "5.4.2", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", + "squizlabs/php_codesniffer": "^3.5" + }, + "time": "2025-06-17T09:09:48+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Unirest\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mashape", + "email": "opensource@mashape.com", + "homepage": "https://www.mashape.com", + "role": "Developer" + }, + { + "name": "APIMATIC", + "email": "opensource@apimatic.io", + "homepage": "https://www.apimatic.io", + "role": "Developer" + } + ], + "description": "Unirest PHP", + "homepage": "https://github.com/apimatic/unirest-php", + "keywords": [ + "client", + "curl", + "http", + "https", + "rest" + ], + "support": { + "email": "opensource@apimatic.io", + "issues": "https://github.com/apimatic/unirest-php/issues", + "source": "https://github.com/apimatic/unirest-php/tree/4.0.7" + }, + "install-path": "../apimatic/unirest-php" }, { - "name": "Michael Dowling", - "email": "mtdowling@gmail.com", - "homepage": "https://github.com/mtdowling" + "name": "clue/stream-filter", + "version": "v1.7.0", + "version_normalized": "1.7.0.0", + "source": { + "type": "git", + "url": "https://github.com/clue/stream-filter.git", + "reference": "049509fef80032cb3f051595029ab75b49a3c2f7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/clue/stream-filter/zipball/049509fef80032cb3f051595029ab75b49a3c2f7", + "reference": "049509fef80032cb3f051595029ab75b49a3c2f7", + "shasum": "" + }, + "require": { + "php": ">=5.3" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" + }, + "time": "2023-12-20T15:40:13+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "src/functions_include.php" + ], + "psr-4": { + "Clue\\StreamFilter\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering" + } + ], + "description": "A simple and modern approach to stream filtering in PHP", + "homepage": "https://github.com/clue/stream-filter", + "keywords": [ + "bucket brigade", + "callback", + "filter", + "php_user_filter", + "stream", + "stream_filter_append", + "stream_filter_register" + ], + "support": { + "issues": "https://github.com/clue/stream-filter/issues", + "source": "https://github.com/clue/stream-filter/tree/v1.7.0" + }, + "install-path": "../clue/stream-filter" }, { - "name": "Jeremy Lindblom", - "email": "jeremeamia@gmail.com", - "homepage": "https://github.com/jeremeamia" + "name": "ezyang/htmlpurifier", + "version": "v4.19.0", + "version_normalized": "4.19.0.0", + "source": { + "type": "git", + "url": "https://github.com/ezyang/htmlpurifier.git", + "reference": "b287d2a16aceffbf6e0295559b39662612b77fcf" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ezyang/htmlpurifier/zipball/b287d2a16aceffbf6e0295559b39662612b77fcf", + "reference": "b287d2a16aceffbf6e0295559b39662612b77fcf", + "shasum": "" + }, + "require": { + "php": "~5.6.0 || ~7.0.0 || ~7.1.0 || ~7.2.0 || ~7.3.0 || ~7.4.0 || ~8.0.0 || ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0" + }, + "require-dev": { + "cerdic/css-tidy": "^1.7 || ^2.0", + "simpletest/simpletest": "dev-master" + }, + "suggest": { + "cerdic/css-tidy": "If you want to use the filter 'Filter.ExtractStyleBlocks'.", + "ext-bcmath": "Used for unit conversion and imagecrash protection", + "ext-iconv": "Converts text to and from non-UTF-8 encodings", + "ext-tidy": "Used for pretty-printing HTML" + }, + "time": "2025-10-17T16:34:55+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "library/HTMLPurifier.composer.php" + ], + "psr-0": { + "HTMLPurifier": "library/" + }, + "exclude-from-classmap": [ + "/library/HTMLPurifier/Language/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-2.1-or-later" + ], + "authors": [ + { + "name": "Edward Z. Yang", + "email": "admin@htmlpurifier.org", + "homepage": "http://ezyang.com" + } + ], + "description": "Standards compliant HTML filter written in PHP", + "homepage": "http://htmlpurifier.org/", + "keywords": [ + "html" + ], + "support": { + "issues": "https://github.com/ezyang/htmlpurifier/issues", + "source": "https://github.com/ezyang/htmlpurifier/tree/v4.19.0" + }, + "install-path": "../ezyang/htmlpurifier" }, { - "name": "George Mponos", - "email": "gmponos@gmail.com", - "homepage": "https://github.com/gmponos" + "name": "guzzlehttp/guzzle", + "version": "7.10.0", + "version_normalized": "7.10.0.0", + "source": { + "type": "git", + "url": "https://github.com/guzzle/guzzle.git", + "reference": "b51ac707cfa420b7bfd4e4d5e510ba8008e822b4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/guzzle/zipball/b51ac707cfa420b7bfd4e4d5e510ba8008e822b4", + "reference": "b51ac707cfa420b7bfd4e4d5e510ba8008e822b4", + "shasum": "" + }, + "require": { + "ext-json": "*", + "guzzlehttp/promises": "^2.3", + "guzzlehttp/psr7": "^2.8", + "php": "^7.2.5 || ^8.0", + "psr/http-client": "^1.0", + "symfony/deprecation-contracts": "^2.2 || ^3.0" + }, + "provide": { + "psr/http-client-implementation": "1.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "ext-curl": "*", + "guzzle/client-integration-tests": "3.0.2", + "php-http/message-factory": "^1.1", + "phpunit/phpunit": "^8.5.39 || ^9.6.20", + "psr/log": "^1.1 || ^2.0 || ^3.0" + }, + "suggest": { + "ext-curl": "Required for CURL handler support", + "ext-intl": "Required for Internationalized Domain Name (IDN) support", + "psr/log": "Required for using the Log middleware" + }, + "time": "2025-08-23T22:36:01+00:00", + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "installation-source": "dist", + "autoload": { + "files": [ + "src/functions_include.php" + ], + "psr-4": { + "GuzzleHttp\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Jeremy Lindblom", + "email": "jeremeamia@gmail.com", + "homepage": "https://github.com/jeremeamia" + }, + { + "name": "George Mponos", + "email": "gmponos@gmail.com", + "homepage": "https://github.com/gmponos" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://github.com/sagikazarmark" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + } + ], + "description": "Guzzle is a PHP HTTP client library", + "keywords": [ + "client", + "curl", + "framework", + "http", + "http client", + "psr-18", + "psr-7", + "rest", + "web service" + ], + "support": { + "issues": "https://github.com/guzzle/guzzle/issues", + "source": "https://github.com/guzzle/guzzle/tree/7.10.0" + }, + "install-path": "../guzzlehttp/guzzle" }, { - "name": "Tobias Nyholm", - "email": "tobias.nyholm@gmail.com", - "homepage": "https://github.com/Nyholm" + "name": "guzzlehttp/promises", + "version": "2.3.0", + "version_normalized": "2.3.0.0", + "source": { + "type": "git", + "url": "https://github.com/guzzle/promises.git", + "reference": "481557b130ef3790cf82b713667b43030dc9c957" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/promises/zipball/481557b130ef3790cf82b713667b43030dc9c957", + "reference": "481557b130ef3790cf82b713667b43030dc9c957", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.44 || ^9.6.25" + }, + "time": "2025-08-22T14:34:08+00:00", + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "GuzzleHttp\\Promise\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + } + ], + "description": "Guzzle promises library", + "keywords": [ + "promise" + ], + "support": { + "issues": "https://github.com/guzzle/promises/issues", + "source": "https://github.com/guzzle/promises/tree/2.3.0" + }, + "install-path": "../guzzlehttp/promises" }, { - "name": "Márk Sági-Kazár", - "email": "mark.sagikazar@gmail.com", - "homepage": "https://github.com/sagikazarmark" + "name": "guzzlehttp/psr7", + "version": "2.9.0", + "version_normalized": "2.9.0.0", + "source": { + "type": "git", + "url": "https://github.com/guzzle/psr7.git", + "reference": "7d0ed42f28e42d61352a7a79de682e5e67fec884" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/psr7/zipball/7d0ed42f28e42d61352a7a79de682e5e67fec884", + "reference": "7d0ed42f28e42d61352a7a79de682e5e67fec884", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.1 || ^2.0", + "ralouphie/getallheaders": "^3.0" + }, + "provide": { + "psr/http-factory-implementation": "1.0", + "psr/http-message-implementation": "1.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "http-interop/http-factory-tests": "0.9.0", + "jshttp/mime-db": "1.54.0.1", + "phpunit/phpunit": "^8.5.44 || ^9.6.25" + }, + "suggest": { + "laminas/laminas-httphandlerrunner": "Emit PSR-7 responses" + }, + "time": "2026-03-10T16:41:02+00:00", + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "GuzzleHttp\\Psr7\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "George Mponos", + "email": "gmponos@gmail.com", + "homepage": "https://github.com/gmponos" + }, + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com", + "homepage": "https://github.com/Nyholm" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://github.com/sagikazarmark" + }, + { + "name": "Tobias Schultze", + "email": "webmaster@tubo-world.de", + "homepage": "https://github.com/Tobion" + }, + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com", + "homepage": "https://sagikazarmark.hu" + } + ], + "description": "PSR-7 message implementation that also provides common utility methods", + "keywords": [ + "http", + "message", + "psr-7", + "request", + "response", + "stream", + "uri", + "url" + ], + "support": { + "issues": "https://github.com/guzzle/psr7/issues", + "source": "https://github.com/guzzle/psr7/tree/2.9.0" + }, + "install-path": "../guzzlehttp/psr7" }, { - "name": "Tobias Schultze", - "email": "webmaster@tubo-world.de", - "homepage": "https://github.com/Tobion" - } - ], - "description": "Guzzle is a PHP HTTP client library", - "keywords": [ - "client", - "curl", - "framework", - "http", - "http client", - "psr-18", - "psr-7", - "rest", - "web service" - ], - "support": { - "issues": "https://github.com/guzzle/guzzle/issues", - "source": "https://github.com/guzzle/guzzle/tree/7.9.2" - }, - "funding": [ - { - "url": "https://github.com/GrahamCampbell", - "type": "github" + "name": "maennchen/zipstream-php", + "version": "2.1.0", + "version_normalized": "2.1.0.0", + "source": { + "type": "git", + "url": "https://github.com/maennchen/ZipStream-PHP.git", + "reference": "c4c5803cc1f93df3d2448478ef79394a5981cc58" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/maennchen/ZipStream-PHP/zipball/c4c5803cc1f93df3d2448478ef79394a5981cc58", + "reference": "c4c5803cc1f93df3d2448478ef79394a5981cc58", + "shasum": "" + }, + "require": { + "myclabs/php-enum": "^1.5", + "php": ">= 7.1", + "psr/http-message": "^1.0", + "symfony/polyfill-mbstring": "^1.0" + }, + "require-dev": { + "ext-zip": "*", + "guzzlehttp/guzzle": ">= 6.3", + "mikey179/vfsstream": "^1.6", + "phpunit/phpunit": ">= 7.5" + }, + "time": "2020-05-30T13:11:16+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "ZipStream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Paul Duncan", + "email": "pabs@pablotron.org" + }, + { + "name": "Jonatan Männchen", + "email": "jonatan@maennchen.ch" + }, + { + "name": "Jesse Donat", + "email": "donatj@gmail.com" + }, + { + "name": "András Kolesár", + "email": "kolesar@kolesar.hu" + } + ], + "description": "ZipStream is a library for dynamically streaming dynamic zip files from PHP without writing to the disk at all on the server.", + "keywords": [ + "stream", + "zip" + ], + "support": { + "issues": "https://github.com/maennchen/ZipStream-PHP/issues", + "source": "https://github.com/maennchen/ZipStream-PHP/tree/2.1.0" + }, + "install-path": "../maennchen/zipstream-php" }, { - "url": "https://github.com/Nyholm", - "type": "github" + "name": "markbaker/complex", + "version": "3.0.2", + "version_normalized": "3.0.2.0", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPComplex.git", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPComplex/zipball/95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "time": "2022-12-06T16:21:08+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Complex\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@lange.demon.co.uk" + } + ], + "description": "PHP Class for working with complex numbers", + "homepage": "https://github.com/MarkBaker/PHPComplex", + "keywords": [ + "complex", + "mathematics" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPComplex/issues", + "source": "https://github.com/MarkBaker/PHPComplex/tree/3.0.2" + }, + "install-path": "../markbaker/complex" }, { - "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/guzzle", - "type": "tidelift" - } - ], - "install-path": "../guzzlehttp/guzzle" - }, - { - "name": "guzzlehttp/promises", - "version": "2.0.4", - "version_normalized": "2.0.4.0", - "source": { - "type": "git", - "url": "https://github.com/guzzle/promises.git", - "reference": "f9c436286ab2892c7db7be8c8da4ef61ccf7b455" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/guzzle/promises/zipball/f9c436286ab2892c7db7be8c8da4ef61ccf7b455", - "reference": "f9c436286ab2892c7db7be8c8da4ef61ccf7b455", - "shasum": "" - }, - "require": { - "php": "^7.2.5 || ^8.0" - }, - "require-dev": { - "bamarni/composer-bin-plugin": "^1.8.2", - "phpunit/phpunit": "^8.5.39 || ^9.6.20" - }, - "time": "2024-10-17T10:06:22+00:00", - "type": "library", - "extra": { - "bamarni-bin": { - "bin-links": true, - "forward-command": false - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "GuzzleHttp\\Promise\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Graham Campbell", - "email": "hello@gjcampbell.co.uk", - "homepage": "https://github.com/GrahamCampbell" + "name": "markbaker/matrix", + "version": "3.0.1", + "version_normalized": "3.0.1.0", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPMatrix.git", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPMatrix/zipball/728434227fe21be27ff6d86621a1b13107a2562c", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpdocumentor/phpdocumentor": "2.*", + "phploc/phploc": "^4.0", + "phpmd/phpmd": "2.*", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "sebastian/phpcpd": "^4.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "time": "2022-12-02T22:17:43+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Matrix\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@demon-angel.eu" + } + ], + "description": "PHP Class for working with matrices", + "homepage": "https://github.com/MarkBaker/PHPMatrix", + "keywords": [ + "mathematics", + "matrix", + "vector" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPMatrix/issues", + "source": "https://github.com/MarkBaker/PHPMatrix/tree/3.0.1" + }, + "install-path": "../markbaker/matrix" }, { - "name": "Michael Dowling", - "email": "mtdowling@gmail.com", - "homepage": "https://github.com/mtdowling" + "name": "myclabs/php-enum", + "version": "1.8.5", + "version_normalized": "1.8.5.0", + "source": { + "type": "git", + "url": "https://github.com/myclabs/php-enum.git", + "reference": "e7be26966b7398204a234f8673fdad5ac6277802" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/myclabs/php-enum/zipball/e7be26966b7398204a234f8673fdad5ac6277802", + "reference": "e7be26966b7398204a234f8673fdad5ac6277802", + "shasum": "" + }, + "require": { + "ext-json": "*", + "php": "^7.3 || ^8.0" + }, + "require-dev": { + "phpunit/phpunit": "^9.5", + "squizlabs/php_codesniffer": "1.*", + "vimeo/psalm": "^4.6.2 || ^5.2" + }, + "time": "2025-01-14T11:49:03+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "MyCLabs\\Enum\\": "src/" + }, + "classmap": [ + "stubs/Stringable.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP Enum contributors", + "homepage": "https://github.com/myclabs/php-enum/graphs/contributors" + } + ], + "description": "PHP Enum implementation", + "homepage": "https://github.com/myclabs/php-enum", + "keywords": [ + "enum" + ], + "support": { + "issues": "https://github.com/myclabs/php-enum/issues", + "source": "https://github.com/myclabs/php-enum/tree/1.8.5" + }, + "install-path": "../myclabs/php-enum" }, { - "name": "Tobias Nyholm", - "email": "tobias.nyholm@gmail.com", - "homepage": "https://github.com/Nyholm" + "name": "nyholm/psr7", + "version": "1.8.2", + "version_normalized": "1.8.2.0", + "source": { + "type": "git", + "url": "https://github.com/Nyholm/psr7.git", + "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Nyholm/psr7/zipball/a71f2b11690f4b24d099d6b16690a90ae14fc6f3", + "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3", + "shasum": "" + }, + "require": { + "php": ">=7.2", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.1 || ^2.0" + }, + "provide": { + "php-http/message-factory-implementation": "1.0", + "psr/http-factory-implementation": "1.0", + "psr/http-message-implementation": "1.0" + }, + "require-dev": { + "http-interop/http-factory-tests": "^0.9", + "php-http/message-factory": "^1.0", + "php-http/psr7-integration-tests": "^1.0", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.4", + "symfony/error-handler": "^4.4" + }, + "time": "2024-09-09T07:06:30+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.8-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Nyholm\\Psr7\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com" + }, + { + "name": "Martijn van der Ven", + "email": "martijn@vanderven.se" + } + ], + "description": "A fast PHP7 implementation of PSR-7", + "homepage": "https://tnyholm.se", + "keywords": [ + "psr-17", + "psr-7" + ], + "support": { + "issues": "https://github.com/Nyholm/psr7/issues", + "source": "https://github.com/Nyholm/psr7/tree/1.8.2" + }, + "install-path": "../nyholm/psr7" }, { - "name": "Tobias Schultze", - "email": "webmaster@tubo-world.de", - "homepage": "https://github.com/Tobion" - } - ], - "description": "Guzzle promises library", - "keywords": [ - "promise" - ], - "support": { - "issues": "https://github.com/guzzle/promises/issues", - "source": "https://github.com/guzzle/promises/tree/2.0.4" - }, - "funding": [ - { - "url": "https://github.com/GrahamCampbell", - "type": "github" + "name": "paypal/paypal-server-sdk", + "version": "0.6.1", + "version_normalized": "0.6.1.0", + "source": { + "type": "git", + "url": "https://github.com/paypal/PayPal-PHP-Server-SDK.git", + "reference": "b26f3e7dcd6cc1c426283d211b218b26473c509d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/paypal/PayPal-PHP-Server-SDK/zipball/b26f3e7dcd6cc1c426283d211b218b26473c509d", + "reference": "b26f3e7dcd6cc1c426283d211b218b26473c509d", + "shasum": "" + }, + "require": { + "apimatic/core": "~0.3.11", + "apimatic/core-interfaces": "~0.1.5", + "apimatic/unirest-php": "^4.0.0", + "ext-json": "*", + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "phan/phan": "5.4.2", + "squizlabs/php_codesniffer": "^3.5" + }, + "time": "2024-11-21T20:04:48+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "PaypalServerSdkLib\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "PayPal's SDK for interacting with the REST APIs", + "homepage": "https://github.com/paypal/PayPal-PHP-Server-SDK", + "support": { + "issues": "https://github.com/paypal/PayPal-PHP-Server-SDK/issues", + "source": "https://github.com/paypal/PayPal-PHP-Server-SDK/tree/0.6.1" + }, + "install-path": "../paypal/paypal-server-sdk" }, { - "url": "https://github.com/Nyholm", - "type": "github" + "name": "php-http/discovery", + "version": "1.20.0", + "version_normalized": "1.20.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-http/discovery.git", + "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-http/discovery/zipball/82fe4c73ef3363caed49ff8dd1539ba06044910d", + "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d", + "shasum": "" + }, + "require": { + "composer-plugin-api": "^1.0|^2.0", + "php": "^7.1 || ^8.0" + }, + "conflict": { + "nyholm/psr7": "<1.0", + "zendframework/zend-diactoros": "*" + }, + "provide": { + "php-http/async-client-implementation": "*", + "php-http/client-implementation": "*", + "psr/http-client-implementation": "*", + "psr/http-factory-implementation": "*", + "psr/http-message-implementation": "*" + }, + "require-dev": { + "composer/composer": "^1.0.2|^2.0", + "graham-campbell/phpspec-skip-example-extension": "^5.0", + "php-http/httplug": "^1.0 || ^2.0", + "php-http/message-factory": "^1.0", + "phpspec/phpspec": "^5.1 || ^6.1 || ^7.3", + "sebastian/comparator": "^3.0.5 || ^4.0.8", + "symfony/phpunit-bridge": "^6.4.4 || ^7.0.1" + }, + "time": "2024-10-02T11:20:13+00:00", + "type": "composer-plugin", + "extra": { + "class": "Http\\Discovery\\Composer\\Plugin", + "plugin-optional": true + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Http\\Discovery\\": "src/" + }, + "exclude-from-classmap": [ + "src/Composer/Plugin.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com" + } + ], + "description": "Finds and installs PSR-7, PSR-17, PSR-18 and HTTPlug implementations", + "homepage": "http://php-http.org", + "keywords": [ + "adapter", + "client", + "discovery", + "factory", + "http", + "message", + "psr17", + "psr7" + ], + "support": { + "issues": "https://github.com/php-http/discovery/issues", + "source": "https://github.com/php-http/discovery/tree/1.20.0" + }, + "install-path": "../php-http/discovery" }, { - "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/promises", - "type": "tidelift" - } - ], - "install-path": "../guzzlehttp/promises" - }, - { - "name": "guzzlehttp/psr7", - "version": "2.7.0", - "version_normalized": "2.7.0.0", - "source": { - "type": "git", - "url": "https://github.com/guzzle/psr7.git", - "reference": "a70f5c95fb43bc83f07c9c948baa0dc1829bf201" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/guzzle/psr7/zipball/a70f5c95fb43bc83f07c9c948baa0dc1829bf201", - "reference": "a70f5c95fb43bc83f07c9c948baa0dc1829bf201", - "shasum": "" - }, - "require": { - "php": "^7.2.5 || ^8.0", - "psr/http-factory": "^1.0", - "psr/http-message": "^1.1 || ^2.0", - "ralouphie/getallheaders": "^3.0" - }, - "provide": { - "psr/http-factory-implementation": "1.0", - "psr/http-message-implementation": "1.0" - }, - "require-dev": { - "bamarni/composer-bin-plugin": "^1.8.2", - "http-interop/http-factory-tests": "0.9.0", - "phpunit/phpunit": "^8.5.39 || ^9.6.20" - }, - "suggest": { - "laminas/laminas-httphandlerrunner": "Emit PSR-7 responses" - }, - "time": "2024-07-18T11:15:46+00:00", - "type": "library", - "extra": { - "bamarni-bin": { - "bin-links": true, - "forward-command": false - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "GuzzleHttp\\Psr7\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Graham Campbell", - "email": "hello@gjcampbell.co.uk", - "homepage": "https://github.com/GrahamCampbell" + "name": "php-http/message", + "version": "1.16.2", + "version_normalized": "1.16.2.0", + "source": { + "type": "git", + "url": "https://github.com/php-http/message.git", + "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-http/message/zipball/06dd5e8562f84e641bf929bfe699ee0f5ce8080a", + "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a", + "shasum": "" + }, + "require": { + "clue/stream-filter": "^1.5", + "php": "^7.2 || ^8.0", + "psr/http-message": "^1.1 || ^2.0" + }, + "provide": { + "php-http/message-factory-implementation": "1.0" + }, + "require-dev": { + "ergebnis/composer-normalize": "^2.6", + "ext-zlib": "*", + "guzzlehttp/psr7": "^1.0 || ^2.0", + "laminas/laminas-diactoros": "^2.0 || ^3.0", + "php-http/message-factory": "^1.0.2", + "phpspec/phpspec": "^5.1 || ^6.3 || ^7.1", + "slim/slim": "^3.0" + }, + "suggest": { + "ext-zlib": "Used with compressor/decompressor streams", + "guzzlehttp/psr7": "Used with Guzzle PSR-7 Factories", + "laminas/laminas-diactoros": "Used with Diactoros Factories", + "slim/slim": "Used with Slim Framework PSR-7 implementation" + }, + "time": "2024-10-02T11:34:13+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "src/filters.php" + ], + "psr-4": { + "Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Márk Sági-Kazár", + "email": "mark.sagikazar@gmail.com" + } + ], + "description": "HTTP Message related tools", + "homepage": "http://php-http.org", + "keywords": [ + "http", + "message", + "psr-7" + ], + "support": { + "issues": "https://github.com/php-http/message/issues", + "source": "https://github.com/php-http/message/tree/1.16.2" + }, + "install-path": "../php-http/message" }, { - "name": "Michael Dowling", - "email": "mtdowling@gmail.com", - "homepage": "https://github.com/mtdowling" + "name": "php-http/multipart-stream-builder", + "version": "1.4.2", + "version_normalized": "1.4.2.0", + "source": { + "type": "git", + "url": "https://github.com/php-http/multipart-stream-builder.git", + "reference": "10086e6de6f53489cca5ecc45b6f468604d3460e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-http/multipart-stream-builder/zipball/10086e6de6f53489cca5ecc45b6f468604d3460e", + "reference": "10086e6de6f53489cca5ecc45b6f468604d3460e", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0", + "php-http/discovery": "^1.15", + "psr/http-factory-implementation": "^1.0" + }, + "require-dev": { + "nyholm/psr7": "^1.0", + "php-http/message": "^1.5", + "php-http/message-factory": "^1.0.2", + "phpunit/phpunit": "^7.5.15 || ^8.5 || ^9.3" + }, + "time": "2024-09-04T13:22:54+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Http\\Message\\MultipartStream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Tobias Nyholm", + "email": "tobias.nyholm@gmail.com" + } + ], + "description": "A builder class that help you create a multipart stream", + "homepage": "http://php-http.org", + "keywords": [ + "factory", + "http", + "message", + "multipart stream", + "stream" + ], + "support": { + "issues": "https://github.com/php-http/multipart-stream-builder/issues", + "source": "https://github.com/php-http/multipart-stream-builder/tree/1.4.2" + }, + "install-path": "../php-http/multipart-stream-builder" }, { - "name": "George Mponos", - "email": "gmponos@gmail.com", - "homepage": "https://github.com/gmponos" + "name": "php-jsonpointer/php-jsonpointer", + "version": "v3.0.2", + "version_normalized": "3.0.2.0", + "source": { + "type": "git", + "url": "https://github.com/raphaelstolt/php-jsonpointer.git", + "reference": "4428f86c6f23846e9faa5a420c4ef14e485b3afb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/raphaelstolt/php-jsonpointer/zipball/4428f86c6f23846e9faa5a420c4ef14e485b3afb", + "reference": "4428f86c6f23846e9faa5a420c4ef14e485b3afb", + "shasum": "" + }, + "require": { + "php": ">=5.4" + }, + "require-dev": { + "friendsofphp/php-cs-fixer": "^1.11", + "phpunit/phpunit": "4.6.*" + }, + "time": "2016-08-29T08:51:01+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-0": { + "Rs\\Json": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Raphael Stolt", + "email": "raphael.stolt@gmail.com", + "homepage": "http://raphaelstolt.blogspot.com/" + } + ], + "description": "Implementation of JSON Pointer (http://tools.ietf.org/html/rfc6901)", + "homepage": "https://github.com/raphaelstolt/php-jsonpointer", + "keywords": [ + "json", + "json pointer", + "json traversal" + ], + "support": { + "issues": "https://github.com/raphaelstolt/php-jsonpointer/issues", + "source": "https://github.com/raphaelstolt/php-jsonpointer/tree/master" + }, + "install-path": "../php-jsonpointer/php-jsonpointer" }, { - "name": "Tobias Nyholm", - "email": "tobias.nyholm@gmail.com", - "homepage": "https://github.com/Nyholm" + "name": "phpmailer/phpmailer", + "version": "v6.12.0", + "version_normalized": "6.12.0.0", + "source": { + "type": "git", + "url": "https://github.com/PHPMailer/PHPMailer.git", + "reference": "d1ac35d784bf9f5e61b424901d5a014967f15b12" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPMailer/PHPMailer/zipball/d1ac35d784bf9f5e61b424901d5a014967f15b12", + "reference": "d1ac35d784bf9f5e61b424901d5a014967f15b12", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-filter": "*", + "ext-hash": "*", + "php": ">=5.5.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "^1.0", + "doctrine/annotations": "^1.2.6 || ^1.13.3", + "php-parallel-lint/php-console-highlighter": "^1.0.0", + "php-parallel-lint/php-parallel-lint": "^1.3.2", + "phpcompatibility/php-compatibility": "^9.3.5", + "roave/security-advisories": "dev-latest", + "squizlabs/php_codesniffer": "^3.7.2", + "yoast/phpunit-polyfills": "^1.0.4" + }, + "suggest": { + "decomplexity/SendOauth2": "Adapter for using XOAUTH2 authentication", + "ext-mbstring": "Needed to send email in multibyte encoding charset or decode encoded addresses", + "ext-openssl": "Needed for secure SMTP sending and DKIM signing", + "greew/oauth2-azure-provider": "Needed for Microsoft Azure XOAUTH2 authentication", + "hayageek/oauth2-yahoo": "Needed for Yahoo XOAUTH2 authentication", + "league/oauth2-google": "Needed for Google XOAUTH2 authentication", + "psr/log": "For optional PSR-3 debug logging", + "symfony/polyfill-mbstring": "To support UTF-8 if the Mbstring PHP extension is not enabled (^1.2)", + "thenetworg/oauth2-azure": "Needed for Microsoft XOAUTH2 authentication" + }, + "time": "2025-10-15T16:49:08+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "PHPMailer\\PHPMailer\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-2.1-only" + ], + "authors": [ + { + "name": "Marcus Bointon", + "email": "phpmailer@synchromedia.co.uk" + }, + { + "name": "Jim Jagielski", + "email": "jimjag@gmail.com" + }, + { + "name": "Andy Prevost", + "email": "codeworxtech@users.sourceforge.net" + }, + { + "name": "Brent R. Matzelle" + } + ], + "description": "PHPMailer is a full-featured email creation and transfer class for PHP", + "support": { + "issues": "https://github.com/PHPMailer/PHPMailer/issues", + "source": "https://github.com/PHPMailer/PHPMailer/tree/v6.12.0" + }, + "install-path": "../phpmailer/phpmailer" }, { - "name": "Márk Sági-Kazár", - "email": "mark.sagikazar@gmail.com", - "homepage": "https://github.com/sagikazarmark" + "name": "phpoffice/math", + "version": "0.3.0", + "version_normalized": "0.3.0.0", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/Math.git", + "reference": "fc31c8f57a7a81f962cbf389fd89f4d9d06fc99a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/Math/zipball/fc31c8f57a7a81f962cbf389fd89f4d9d06fc99a", + "reference": "fc31c8f57a7a81f962cbf389fd89f4d9d06fc99a", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-xml": "*", + "php": "^7.1|^8.0" + }, + "require-dev": { + "phpstan/phpstan": "^0.12.88 || ^1.0.0", + "phpunit/phpunit": "^7.0 || ^9.0" + }, + "time": "2025-05-29T08:31:49+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "PhpOffice\\Math\\": "src/Math/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Progi1984", + "homepage": "https://lefevre.dev" + } + ], + "description": "Math - Manipulate Math Formula", + "homepage": "https://phpoffice.github.io/Math/", + "keywords": [ + "MathML", + "officemathml", + "php" + ], + "support": { + "issues": "https://github.com/PHPOffice/Math/issues", + "source": "https://github.com/PHPOffice/Math/tree/0.3.0" + }, + "install-path": "../phpoffice/math" }, { - "name": "Tobias Schultze", - "email": "webmaster@tubo-world.de", - "homepage": "https://github.com/Tobion" + "name": "phpoffice/phpexcel", + "version": "1.8.2", + "version_normalized": "1.8.2.0", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/PHPExcel.git", + "reference": "1441011fb7ecdd8cc689878f54f8b58a6805f870" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/PHPExcel/zipball/1441011fb7ecdd8cc689878f54f8b58a6805f870", + "reference": "1441011fb7ecdd8cc689878f54f8b58a6805f870", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "ext-xml": "*", + "ext-xmlwriter": "*", + "php": "^5.2|^7.0" + }, + "require-dev": { + "squizlabs/php_codesniffer": "2.*" + }, + "time": "2018-11-22T23:07:24+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-0": { + "PHPExcel": "Classes/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-2.1" + ], + "authors": [ + { + "name": "Maarten Balliauw", + "homepage": "http://blog.maartenballiauw.be" + }, + { + "name": "Erik Tilt" + }, + { + "name": "Franck Lefevre", + "homepage": "http://rootslabs.net" + }, + { + "name": "Mark Baker", + "homepage": "http://markbakeruk.net" + } + ], + "description": "PHPExcel - OpenXML - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", + "homepage": "https://github.com/PHPOffice/PHPExcel", + "keywords": [ + "OpenXML", + "excel", + "php", + "spreadsheet", + "xls", + "xlsx" + ], + "support": { + "issues": "https://github.com/PHPOffice/PHPExcel/issues", + "source": "https://github.com/PHPOffice/PHPExcel/tree/master" + }, + "abandoned": "phpoffice/phpspreadsheet", + "install-path": "../phpoffice/phpexcel" }, { - "name": "Márk Sági-Kazár", - "email": "mark.sagikazar@gmail.com", - "homepage": "https://sagikazarmark.hu" - } - ], - "description": "PSR-7 message implementation that also provides common utility methods", - "keywords": [ - "http", - "message", - "psr-7", - "request", - "response", - "stream", - "uri", - "url" - ], - "support": { - "issues": "https://github.com/guzzle/psr7/issues", - "source": "https://github.com/guzzle/psr7/tree/2.7.0" - }, - "funding": [ - { - "url": "https://github.com/GrahamCampbell", - "type": "github" + "name": "phpoffice/phpspreadsheet", + "version": "1.25.2", + "version_normalized": "1.25.2.0", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/PhpSpreadsheet.git", + "reference": "a317a09e7def49852400a4b3eca4a4b0790ceeb5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/PhpSpreadsheet/zipball/a317a09e7def49852400a4b3eca4a4b0790ceeb5", + "reference": "a317a09e7def49852400a4b3eca4a4b0790ceeb5", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-dom": "*", + "ext-fileinfo": "*", + "ext-gd": "*", + "ext-iconv": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-simplexml": "*", + "ext-xml": "*", + "ext-xmlreader": "*", + "ext-xmlwriter": "*", + "ext-zip": "*", + "ext-zlib": "*", + "ezyang/htmlpurifier": "^4.15", + "maennchen/zipstream-php": "^2.1", + "markbaker/complex": "^3.0", + "markbaker/matrix": "^3.0", + "php": "^7.3 || ^8.0", + "psr/http-client": "^1.0", + "psr/http-factory": "^1.0", + "psr/simple-cache": "^1.0 || ^2.0 || ^3.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "dompdf/dompdf": "^1.0 || ^2.0", + "friendsofphp/php-cs-fixer": "^3.2", + "mitoteam/jpgraph": "10.2.4", + "mpdf/mpdf": "8.1.1", + "phpcompatibility/php-compatibility": "^9.3", + "phpstan/phpstan": "^1.1", + "phpstan/phpstan-phpunit": "^1.0", + "phpunit/phpunit": "^8.5 || ^9.0", + "squizlabs/php_codesniffer": "^3.7", + "tecnickcom/tcpdf": "6.5" + }, + "suggest": { + "dompdf/dompdf": "Option for rendering PDF with PDF Writer", + "ext-intl": "PHP Internationalization Functions", + "mitoteam/jpgraph": "Option for rendering charts, or including charts with PDF or HTML Writers", + "mpdf/mpdf": "Option for rendering PDF with PDF Writer", + "tecnickcom/tcpdf": "Option for rendering PDF with PDF Writer" + }, + "time": "2022-09-25T17:21:01+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "PhpOffice\\PhpSpreadsheet\\": "src/PhpSpreadsheet" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Maarten Balliauw", + "homepage": "https://blog.maartenballiauw.be" + }, + { + "name": "Mark Baker", + "homepage": "https://markbakeruk.net" + }, + { + "name": "Franck Lefevre", + "homepage": "https://rootslabs.net" + }, + { + "name": "Erik Tilt" + }, + { + "name": "Adrien Crivelli" + } + ], + "description": "PHPSpreadsheet - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", + "homepage": "https://github.com/PHPOffice/PhpSpreadsheet", + "keywords": [ + "OpenXML", + "excel", + "gnumeric", + "ods", + "php", + "spreadsheet", + "xls", + "xlsx" + ], + "support": { + "issues": "https://github.com/PHPOffice/PhpSpreadsheet/issues", + "source": "https://github.com/PHPOffice/PhpSpreadsheet/tree/1.25.2" + }, + "install-path": "../phpoffice/phpspreadsheet" }, { - "url": "https://github.com/Nyholm", - "type": "github" + "name": "phpoffice/phpword", + "version": "1.4.0", + "version_normalized": "1.4.0.0", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/PHPWord.git", + "reference": "6d75328229bc93790b37e93741adf70646cea958" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/PHPWord/zipball/6d75328229bc93790b37e93741adf70646cea958", + "reference": "6d75328229bc93790b37e93741adf70646cea958", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-gd": "*", + "ext-json": "*", + "ext-xml": "*", + "ext-zip": "*", + "php": "^7.1|^8.0", + "phpoffice/math": "^0.3" + }, + "require-dev": { + "dompdf/dompdf": "^2.0 || ^3.0", + "ext-libxml": "*", + "friendsofphp/php-cs-fixer": "^3.3", + "mpdf/mpdf": "^7.0 || ^8.0", + "phpmd/phpmd": "^2.13", + "phpstan/phpstan": "^0.12.88 || ^1.0.0", + "phpstan/phpstan-phpunit": "^1.0 || ^2.0", + "phpunit/phpunit": ">=7.0", + "symfony/process": "^4.4 || ^5.0", + "tecnickcom/tcpdf": "^6.5" + }, + "suggest": { + "dompdf/dompdf": "Allows writing PDF", + "ext-xmlwriter": "Allows writing OOXML and ODF", + "ext-xsl": "Allows applying XSL style sheet to headers, to main document part, and to footers of an OOXML template" + }, + "time": "2025-06-05T10:32:36+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "PhpOffice\\PhpWord\\": "src/PhpWord" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-3.0-only" + ], + "authors": [ + { + "name": "Mark Baker" + }, + { + "name": "Gabriel Bull", + "email": "me@gabrielbull.com", + "homepage": "http://gabrielbull.com/" + }, + { + "name": "Franck Lefevre", + "homepage": "https://rootslabs.net/blog/" + }, + { + "name": "Ivan Lanin", + "homepage": "http://ivan.lanin.org" + }, + { + "name": "Roman Syroeshko", + "homepage": "http://ru.linkedin.com/pub/roman-syroeshko/34/a53/994/" + }, + { + "name": "Antoine de Troostembergh" + } + ], + "description": "PHPWord - A pure PHP library for reading and writing word processing documents (OOXML, ODF, RTF, HTML, PDF)", + "homepage": "https://phpoffice.github.io/PHPWord/", + "keywords": [ + "ISO IEC 29500", + "OOXML", + "Office Open XML", + "OpenDocument", + "OpenXML", + "PhpOffice", + "PhpWord", + "Rich Text Format", + "WordprocessingML", + "doc", + "docx", + "html", + "odf", + "odt", + "office", + "pdf", + "php", + "reader", + "rtf", + "template", + "template processor", + "word", + "writer" + ], + "support": { + "issues": "https://github.com/PHPOffice/PHPWord/issues", + "source": "https://github.com/PHPOffice/PHPWord/tree/1.4.0" + }, + "install-path": "../phpoffice/phpword" }, { - "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/psr7", - "type": "tidelift" - } - ], - "install-path": "../guzzlehttp/psr7" - }, - { - "name": "maennchen/zipstream-php", - "version": "2.1.0", - "version_normalized": "2.1.0.0", - "source": { - "type": "git", - "url": "https://github.com/maennchen/ZipStream-PHP.git", - "reference": "c4c5803cc1f93df3d2448478ef79394a5981cc58" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/maennchen/ZipStream-PHP/zipball/c4c5803cc1f93df3d2448478ef79394a5981cc58", - "reference": "c4c5803cc1f93df3d2448478ef79394a5981cc58", - "shasum": "" - }, - "require": { - "myclabs/php-enum": "^1.5", - "php": ">= 7.1", - "psr/http-message": "^1.0", - "symfony/polyfill-mbstring": "^1.0" - }, - "require-dev": { - "ext-zip": "*", - "guzzlehttp/guzzle": ">= 6.3", - "mikey179/vfsstream": "^1.6", - "phpunit/phpunit": ">= 7.5" - }, - "time": "2020-05-30T13:11:16+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "ZipStream\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Paul Duncan", - "email": "pabs@pablotron.org" + "name": "psr/http-client", + "version": "1.0.3", + "version_normalized": "1.0.3.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-client.git", + "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-client/zipball/bb5906edc1c324c9a05aa0873d40117941e5fa90", + "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90", + "shasum": "" + }, + "require": { + "php": "^7.0 || ^8.0", + "psr/http-message": "^1.0 || ^2.0" + }, + "time": "2023-09-23T14:17:50+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\Http\\Client\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP clients", + "homepage": "https://github.com/php-fig/http-client", + "keywords": [ + "http", + "http-client", + "psr", + "psr-18" + ], + "support": { + "source": "https://github.com/php-fig/http-client" + }, + "install-path": "../psr/http-client" }, { - "name": "Jonatan Männchen", - "email": "jonatan@maennchen.ch" + "name": "psr/http-factory", + "version": "1.1.0", + "version_normalized": "1.1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-factory.git", + "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-factory/zipball/2b4765fddfe3b508ac62f829e852b1501d3f6e8a", + "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a", + "shasum": "" + }, + "require": { + "php": ">=7.1", + "psr/http-message": "^1.0 || ^2.0" + }, + "time": "2024-04-15T12:06:14+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "PSR-17: Common interfaces for PSR-7 HTTP message factories", + "keywords": [ + "factory", + "http", + "message", + "psr", + "psr-17", + "psr-7", + "request", + "response" + ], + "support": { + "source": "https://github.com/php-fig/http-factory" + }, + "install-path": "../psr/http-factory" }, { - "name": "Jesse Donat", - "email": "donatj@gmail.com" + "name": "psr/http-message", + "version": "1.1", + "version_normalized": "1.1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-message.git", + "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-message/zipball/cb6ce4845ce34a8ad9e68117c10ee90a29919eba", + "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "time": "2023-04-04T09:50:52+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP messages", + "homepage": "https://github.com/php-fig/http-message", + "keywords": [ + "http", + "http-message", + "psr", + "psr-7", + "request", + "response" + ], + "support": { + "source": "https://github.com/php-fig/http-message/tree/1.1" + }, + "install-path": "../psr/http-message" }, { - "name": "András Kolesár", - "email": "kolesar@kolesar.hu" - } - ], - "description": "ZipStream is a library for dynamically streaming dynamic zip files from PHP without writing to the disk at all on the server.", - "keywords": [ - "stream", - "zip" - ], - "support": { - "issues": "https://github.com/maennchen/ZipStream-PHP/issues", - "source": "https://github.com/maennchen/ZipStream-PHP/tree/2.1.0" - }, - "funding": [ - { - "url": "https://github.com/maennchen", - "type": "github" + "name": "psr/log", + "version": "1.1.4", + "version_normalized": "1.1.4.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/log.git", + "reference": "d49695b909c3b7628b6289db5479a1c204601f11" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/log/zipball/d49695b909c3b7628b6289db5479a1c204601f11", + "reference": "d49695b909c3b7628b6289db5479a1c204601f11", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "time": "2021-05-03T11:20:27+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\Log\\": "Psr/Log/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for logging libraries", + "homepage": "https://github.com/php-fig/log", + "keywords": [ + "log", + "psr", + "psr-3" + ], + "support": { + "source": "https://github.com/php-fig/log/tree/1.1.4" + }, + "install-path": "../psr/log" }, { - "url": "https://opencollective.com/zipstream", - "type": "open_collective" - } - ], - "install-path": "../maennchen/zipstream-php" - }, - { - "name": "markbaker/complex", - "version": "3.0.2", - "version_normalized": "3.0.2.0", - "source": { - "type": "git", - "url": "https://github.com/MarkBaker/PHPComplex.git", - "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/MarkBaker/PHPComplex/zipball/95c56caa1cf5c766ad6d65b6344b807c1e8405b9", - "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9", - "shasum": "" - }, - "require": { - "php": "^7.2 || ^8.0" - }, - "require-dev": { - "dealerdirect/phpcodesniffer-composer-installer": "dev-master", - "phpcompatibility/php-compatibility": "^9.3", - "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", - "squizlabs/php_codesniffer": "^3.7" - }, - "time": "2022-12-06T16:21:08+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Complex\\": "classes/src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Mark Baker", - "email": "mark@lange.demon.co.uk" - } - ], - "description": "PHP Class for working with complex numbers", - "homepage": "https://github.com/MarkBaker/PHPComplex", - "keywords": [ - "complex", - "mathematics" - ], - "support": { - "issues": "https://github.com/MarkBaker/PHPComplex/issues", - "source": "https://github.com/MarkBaker/PHPComplex/tree/3.0.2" - }, - "install-path": "../markbaker/complex" - }, - { - "name": "markbaker/matrix", - "version": "3.0.1", - "version_normalized": "3.0.1.0", - "source": { - "type": "git", - "url": "https://github.com/MarkBaker/PHPMatrix.git", - "reference": "728434227fe21be27ff6d86621a1b13107a2562c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/MarkBaker/PHPMatrix/zipball/728434227fe21be27ff6d86621a1b13107a2562c", - "reference": "728434227fe21be27ff6d86621a1b13107a2562c", - "shasum": "" - }, - "require": { - "php": "^7.1 || ^8.0" - }, - "require-dev": { - "dealerdirect/phpcodesniffer-composer-installer": "dev-master", - "phpcompatibility/php-compatibility": "^9.3", - "phpdocumentor/phpdocumentor": "2.*", - "phploc/phploc": "^4.0", - "phpmd/phpmd": "2.*", - "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", - "sebastian/phpcpd": "^4.0", - "squizlabs/php_codesniffer": "^3.7" - }, - "time": "2022-12-02T22:17:43+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Matrix\\": "classes/src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Mark Baker", - "email": "mark@demon-angel.eu" - } - ], - "description": "PHP Class for working with matrices", - "homepage": "https://github.com/MarkBaker/PHPMatrix", - "keywords": [ - "mathematics", - "matrix", - "vector" - ], - "support": { - "issues": "https://github.com/MarkBaker/PHPMatrix/issues", - "source": "https://github.com/MarkBaker/PHPMatrix/tree/3.0.1" - }, - "install-path": "../markbaker/matrix" - }, - { - "name": "myclabs/php-enum", - "version": "1.8.5", - "version_normalized": "1.8.5.0", - "source": { - "type": "git", - "url": "https://github.com/myclabs/php-enum.git", - "reference": "e7be26966b7398204a234f8673fdad5ac6277802" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/myclabs/php-enum/zipball/e7be26966b7398204a234f8673fdad5ac6277802", - "reference": "e7be26966b7398204a234f8673fdad5ac6277802", - "shasum": "" - }, - "require": { - "ext-json": "*", - "php": "^7.3 || ^8.0" - }, - "require-dev": { - "phpunit/phpunit": "^9.5", - "squizlabs/php_codesniffer": "1.*", - "vimeo/psalm": "^4.6.2 || ^5.2" - }, - "time": "2025-01-14T11:49:03+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "MyCLabs\\Enum\\": "src/" - }, - "classmap": [ - "stubs/Stringable.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP Enum contributors", - "homepage": "https://github.com/myclabs/php-enum/graphs/contributors" - } - ], - "description": "PHP Enum implementation", - "homepage": "https://github.com/myclabs/php-enum", - "keywords": [ - "enum" - ], - "support": { - "issues": "https://github.com/myclabs/php-enum/issues", - "source": "https://github.com/myclabs/php-enum/tree/1.8.5" - }, - "funding": [ - { - "url": "https://github.com/mnapoli", - "type": "github" + "name": "psr/simple-cache", + "version": "1.0.1", + "version_normalized": "1.0.1.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/simple-cache.git", + "reference": "408d5eafb83c57f6365a3ca330ff23aa4a5fa39b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/408d5eafb83c57f6365a3ca330ff23aa4a5fa39b", + "reference": "408d5eafb83c57f6365a3ca330ff23aa4a5fa39b", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "time": "2017-10-23T01:57:42+00:00", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "Psr\\SimpleCache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Common interfaces for simple caching", + "keywords": [ + "cache", + "caching", + "psr", + "psr-16", + "simple-cache" + ], + "support": { + "source": "https://github.com/php-fig/simple-cache/tree/master" + }, + "install-path": "../psr/simple-cache" }, { - "url": "https://tidelift.com/funding/github/packagist/myclabs/php-enum", - "type": "tidelift" - } - ], - "install-path": "../myclabs/php-enum" - }, - { - "name": "nyholm/psr7", - "version": "1.8.2", - "version_normalized": "1.8.2.0", - "source": { - "type": "git", - "url": "https://github.com/Nyholm/psr7.git", - "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Nyholm/psr7/zipball/a71f2b11690f4b24d099d6b16690a90ae14fc6f3", - "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3", - "shasum": "" - }, - "require": { - "php": ">=7.2", - "psr/http-factory": "^1.0", - "psr/http-message": "^1.1 || ^2.0" - }, - "provide": { - "php-http/message-factory-implementation": "1.0", - "psr/http-factory-implementation": "1.0", - "psr/http-message-implementation": "1.0" - }, - "require-dev": { - "http-interop/http-factory-tests": "^0.9", - "php-http/message-factory": "^1.0", - "php-http/psr7-integration-tests": "^1.0", - "phpunit/phpunit": "^7.5 || ^8.5 || ^9.4", - "symfony/error-handler": "^4.4" - }, - "time": "2024-09-09T07:06:30+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.8-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Nyholm\\Psr7\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Tobias Nyholm", - "email": "tobias.nyholm@gmail.com" + "name": "ralouphie/getallheaders", + "version": "3.0.3", + "version_normalized": "3.0.3.0", + "source": { + "type": "git", + "url": "https://github.com/ralouphie/getallheaders.git", + "reference": "120b605dfeb996808c31b6477290a714d356e822" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822", + "reference": "120b605dfeb996808c31b6477290a714d356e822", + "shasum": "" + }, + "require": { + "php": ">=5.6" + }, + "require-dev": { + "php-coveralls/php-coveralls": "^2.1", + "phpunit/phpunit": "^5 || ^6.5" + }, + "time": "2019-03-08T08:55:37+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "src/getallheaders.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ralph Khattar", + "email": "ralph.khattar@gmail.com" + } + ], + "description": "A polyfill for getallheaders.", + "support": { + "issues": "https://github.com/ralouphie/getallheaders/issues", + "source": "https://github.com/ralouphie/getallheaders/tree/develop" + }, + "install-path": "../ralouphie/getallheaders" }, { - "name": "Martijn van der Ven", - "email": "martijn@vanderven.se" - } - ], - "description": "A fast PHP7 implementation of PSR-7", - "homepage": "https://tnyholm.se", - "keywords": [ - "psr-17", - "psr-7" - ], - "support": { - "issues": "https://github.com/Nyholm/psr7/issues", - "source": "https://github.com/Nyholm/psr7/tree/1.8.2" - }, - "funding": [ - { - "url": "https://github.com/Zegnat", - "type": "github" + "name": "spatie/data-transfer-object", + "version": "1.14.1", + "version_normalized": "1.14.1.0", + "source": { + "type": "git", + "url": "https://github.com/spatie/data-transfer-object.git", + "reference": "12c25e15f08684f1c57c88ccfb3a38a677a11314" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/spatie/data-transfer-object/zipball/12c25e15f08684f1c57c88ccfb3a38a677a11314", + "reference": "12c25e15f08684f1c57c88ccfb3a38a677a11314", + "shasum": "" + }, + "require": { + "php": "^7.1|^8.0" + }, + "require-dev": { + "larapack/dd": "^1.1", + "phpunit/phpunit": "^7.0|^9.0" + }, + "time": "2021-12-15T07:25:06+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Spatie\\DataTransferObject\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Brent Roose", + "email": "brent@spatie.be", + "homepage": "https://spatie.be", + "role": "Developer" + } + ], + "description": "Data transfer objects with batteries included", + "homepage": "https://github.com/spatie/data-transfer-object", + "keywords": [ + "data-transfer-object", + "spatie" + ], + "support": { + "issues": "https://github.com/spatie/data-transfer-object/issues", + "source": "https://github.com/spatie/data-transfer-object/tree/1.14.1" + }, + "abandoned": "spatie/laravel-data", + "install-path": "../spatie/data-transfer-object" }, { - "url": "https://github.com/nyholm", - "type": "github" - } - ], - "install-path": "../nyholm/psr7" - }, - { - "name": "paypal/paypal-server-sdk", - "version": "0.6.1", - "version_normalized": "0.6.1.0", - "source": { - "type": "git", - "url": "https://github.com/paypal/PayPal-PHP-Server-SDK.git", - "reference": "b26f3e7dcd6cc1c426283d211b218b26473c509d" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/paypal/PayPal-PHP-Server-SDK/zipball/b26f3e7dcd6cc1c426283d211b218b26473c509d", - "reference": "b26f3e7dcd6cc1c426283d211b218b26473c509d", - "shasum": "" - }, - "require": { - "apimatic/core": "~0.3.11", - "apimatic/core-interfaces": "~0.1.5", - "apimatic/unirest-php": "^4.0.0", - "ext-json": "*", - "php": "^7.2 || ^8.0" - }, - "require-dev": { - "phan/phan": "5.4.2", - "squizlabs/php_codesniffer": "^3.5" - }, - "time": "2024-11-21T20:04:48+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "PaypalServerSdkLib\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "description": "PayPal's SDK for interacting with the REST APIs", - "homepage": "https://github.com/paypal/PayPal-PHP-Server-SDK", - "support": { - "issues": "https://github.com/paypal/PayPal-PHP-Server-SDK/issues", - "source": "https://github.com/paypal/PayPal-PHP-Server-SDK/tree/0.6.1" - }, - "install-path": "../paypal/paypal-server-sdk" - }, - { - "name": "php-http/discovery", - "version": "1.20.0", - "version_normalized": "1.20.0.0", - "source": { - "type": "git", - "url": "https://github.com/php-http/discovery.git", - "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-http/discovery/zipball/82fe4c73ef3363caed49ff8dd1539ba06044910d", - "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d", - "shasum": "" - }, - "require": { - "composer-plugin-api": "^1.0|^2.0", - "php": "^7.1 || ^8.0" - }, - "conflict": { - "nyholm/psr7": "<1.0", - "zendframework/zend-diactoros": "*" - }, - "provide": { - "php-http/async-client-implementation": "*", - "php-http/client-implementation": "*", - "psr/http-client-implementation": "*", - "psr/http-factory-implementation": "*", - "psr/http-message-implementation": "*" - }, - "require-dev": { - "composer/composer": "^1.0.2|^2.0", - "graham-campbell/phpspec-skip-example-extension": "^5.0", - "php-http/httplug": "^1.0 || ^2.0", - "php-http/message-factory": "^1.0", - "phpspec/phpspec": "^5.1 || ^6.1 || ^7.3", - "sebastian/comparator": "^3.0.5 || ^4.0.8", - "symfony/phpunit-bridge": "^6.4.4 || ^7.0.1" - }, - "time": "2024-10-02T11:20:13+00:00", - "type": "composer-plugin", - "extra": { - "class": "Http\\Discovery\\Composer\\Plugin", - "plugin-optional": true - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Http\\Discovery\\": "src/" - }, - "exclude-from-classmap": [ - "src/Composer/Plugin.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Márk Sági-Kazár", - "email": "mark.sagikazar@gmail.com" - } - ], - "description": "Finds and installs PSR-7, PSR-17, PSR-18 and HTTPlug implementations", - "homepage": "http://php-http.org", - "keywords": [ - "adapter", - "client", - "discovery", - "factory", - "http", - "message", - "psr17", - "psr7" - ], - "support": { - "issues": "https://github.com/php-http/discovery/issues", - "source": "https://github.com/php-http/discovery/tree/1.20.0" - }, - "install-path": "../php-http/discovery" - }, - { - "name": "php-http/message", - "version": "1.16.2", - "version_normalized": "1.16.2.0", - "source": { - "type": "git", - "url": "https://github.com/php-http/message.git", - "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-http/message/zipball/06dd5e8562f84e641bf929bfe699ee0f5ce8080a", - "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a", - "shasum": "" - }, - "require": { - "clue/stream-filter": "^1.5", - "php": "^7.2 || ^8.0", - "psr/http-message": "^1.1 || ^2.0" - }, - "provide": { - "php-http/message-factory-implementation": "1.0" - }, - "require-dev": { - "ergebnis/composer-normalize": "^2.6", - "ext-zlib": "*", - "guzzlehttp/psr7": "^1.0 || ^2.0", - "laminas/laminas-diactoros": "^2.0 || ^3.0", - "php-http/message-factory": "^1.0.2", - "phpspec/phpspec": "^5.1 || ^6.3 || ^7.1", - "slim/slim": "^3.0" - }, - "suggest": { - "ext-zlib": "Used with compressor/decompressor streams", - "guzzlehttp/psr7": "Used with Guzzle PSR-7 Factories", - "laminas/laminas-diactoros": "Used with Diactoros Factories", - "slim/slim": "Used with Slim Framework PSR-7 implementation" - }, - "time": "2024-10-02T11:34:13+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "files": [ - "src/filters.php" - ], - "psr-4": { - "Http\\Message\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Márk Sági-Kazár", - "email": "mark.sagikazar@gmail.com" - } - ], - "description": "HTTP Message related tools", - "homepage": "http://php-http.org", - "keywords": [ - "http", - "message", - "psr-7" - ], - "support": { - "issues": "https://github.com/php-http/message/issues", - "source": "https://github.com/php-http/message/tree/1.16.2" - }, - "install-path": "../php-http/message" - }, - { - "name": "php-http/multipart-stream-builder", - "version": "1.4.2", - "version_normalized": "1.4.2.0", - "source": { - "type": "git", - "url": "https://github.com/php-http/multipart-stream-builder.git", - "reference": "10086e6de6f53489cca5ecc45b6f468604d3460e" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-http/multipart-stream-builder/zipball/10086e6de6f53489cca5ecc45b6f468604d3460e", - "reference": "10086e6de6f53489cca5ecc45b6f468604d3460e", - "shasum": "" - }, - "require": { - "php": "^7.1 || ^8.0", - "php-http/discovery": "^1.15", - "psr/http-factory-implementation": "^1.0" - }, - "require-dev": { - "nyholm/psr7": "^1.0", - "php-http/message": "^1.5", - "php-http/message-factory": "^1.0.2", - "phpunit/phpunit": "^7.5.15 || ^8.5 || ^9.3" - }, - "time": "2024-09-04T13:22:54+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Http\\Message\\MultipartStream\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Tobias Nyholm", - "email": "tobias.nyholm@gmail.com" - } - ], - "description": "A builder class that help you create a multipart stream", - "homepage": "http://php-http.org", - "keywords": [ - "factory", - "http", - "message", - "multipart stream", - "stream" - ], - "support": { - "issues": "https://github.com/php-http/multipart-stream-builder/issues", - "source": "https://github.com/php-http/multipart-stream-builder/tree/1.4.2" - }, - "install-path": "../php-http/multipart-stream-builder" - }, - { - "name": "php-jsonpointer/php-jsonpointer", - "version": "v3.0.2", - "version_normalized": "3.0.2.0", - "source": { - "type": "git", - "url": "https://github.com/raphaelstolt/php-jsonpointer.git", - "reference": "4428f86c6f23846e9faa5a420c4ef14e485b3afb" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/raphaelstolt/php-jsonpointer/zipball/4428f86c6f23846e9faa5a420c4ef14e485b3afb", - "reference": "4428f86c6f23846e9faa5a420c4ef14e485b3afb", - "shasum": "" - }, - "require": { - "php": ">=5.4" - }, - "require-dev": { - "friendsofphp/php-cs-fixer": "^1.11", - "phpunit/phpunit": "4.6.*" - }, - "time": "2016-08-29T08:51:01+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-0": { - "Rs\\Json": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Raphael Stolt", - "email": "raphael.stolt@gmail.com", - "homepage": "http://raphaelstolt.blogspot.com/" - } - ], - "description": "Implementation of JSON Pointer (http://tools.ietf.org/html/rfc6901)", - "homepage": "https://github.com/raphaelstolt/php-jsonpointer", - "keywords": [ - "json", - "json pointer", - "json traversal" - ], - "support": { - "issues": "https://github.com/raphaelstolt/php-jsonpointer/issues", - "source": "https://github.com/raphaelstolt/php-jsonpointer/tree/master" - }, - "install-path": "../php-jsonpointer/php-jsonpointer" - }, - { - "name": "phpmailer/phpmailer", - "version": "v6.9.3", - "version_normalized": "6.9.3.0", - "source": { - "type": "git", - "url": "https://github.com/PHPMailer/PHPMailer.git", - "reference": "2f5c94fe7493efc213f643c23b1b1c249d40f47e" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/PHPMailer/PHPMailer/zipball/2f5c94fe7493efc213f643c23b1b1c249d40f47e", - "reference": "2f5c94fe7493efc213f643c23b1b1c249d40f47e", - "shasum": "" - }, - "require": { - "ext-ctype": "*", - "ext-filter": "*", - "ext-hash": "*", - "php": ">=5.5.0" - }, - "require-dev": { - "dealerdirect/phpcodesniffer-composer-installer": "^1.0", - "doctrine/annotations": "^1.2.6 || ^1.13.3", - "php-parallel-lint/php-console-highlighter": "^1.0.0", - "php-parallel-lint/php-parallel-lint": "^1.3.2", - "phpcompatibility/php-compatibility": "^9.3.5", - "roave/security-advisories": "dev-latest", - "squizlabs/php_codesniffer": "^3.7.2", - "yoast/phpunit-polyfills": "^1.0.4" - }, - "suggest": { - "decomplexity/SendOauth2": "Adapter for using XOAUTH2 authentication", - "ext-mbstring": "Needed to send email in multibyte encoding charset or decode encoded addresses", - "ext-openssl": "Needed for secure SMTP sending and DKIM signing", - "greew/oauth2-azure-provider": "Needed for Microsoft Azure XOAUTH2 authentication", - "hayageek/oauth2-yahoo": "Needed for Yahoo XOAUTH2 authentication", - "league/oauth2-google": "Needed for Google XOAUTH2 authentication", - "psr/log": "For optional PSR-3 debug logging", - "symfony/polyfill-mbstring": "To support UTF-8 if the Mbstring PHP extension is not enabled (^1.2)", - "thenetworg/oauth2-azure": "Needed for Microsoft XOAUTH2 authentication" - }, - "time": "2024-11-24T18:04:13+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "PHPMailer\\PHPMailer\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-2.1-only" - ], - "authors": [ - { - "name": "Marcus Bointon", - "email": "phpmailer@synchromedia.co.uk" + "name": "symfony/deprecation-contracts", + "version": "v2.5.4", + "version_normalized": "2.5.4.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/deprecation-contracts.git", + "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/605389f2a7e5625f273b53960dc46aeaf9c62918", + "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918", + "shasum": "" + }, + "require": { + "php": ">=7.1" + }, + "time": "2024-09-25T14:11:13+00:00", + "type": "library", + "extra": { + "thanks": { + "url": "https://github.com/symfony/contracts", + "name": "symfony/contracts" + }, + "branch-alias": { + "dev-main": "2.5-dev" + } + }, + "installation-source": "dist", + "autoload": { + "files": [ + "function.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "A generic function and convention to trigger deprecation notices", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.4" + }, + "install-path": "../symfony/deprecation-contracts" }, { - "name": "Jim Jagielski", - "email": "jimjag@gmail.com" + "name": "symfony/http-foundation", + "version": "v5.4.50", + "version_normalized": "5.4.50.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-foundation.git", + "reference": "1a0706e8b8041046052ea2695eb8aeee04f97609" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-foundation/zipball/1a0706e8b8041046052ea2695eb8aeee04f97609", + "reference": "1a0706e8b8041046052ea2695eb8aeee04f97609", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "symfony/deprecation-contracts": "^2.1|^3", + "symfony/polyfill-mbstring": "~1.1", + "symfony/polyfill-php80": "^1.16" + }, + "require-dev": { + "predis/predis": "^1.0|^2.0", + "symfony/cache": "^4.4|^5.0|^6.0", + "symfony/dependency-injection": "^5.4|^6.0", + "symfony/expression-language": "^4.4|^5.0|^6.0", + "symfony/http-kernel": "^5.4.12|^6.0.12|^6.1.4", + "symfony/mime": "^4.4|^5.0|^6.0", + "symfony/rate-limiter": "^5.2|^6.0" + }, + "suggest": { + "symfony/mime": "To use the file extension guesser" + }, + "time": "2025-11-03T12:58:48+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Symfony\\Component\\HttpFoundation\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Defines an object-oriented layer for the HTTP specification", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/http-foundation/tree/v5.4.50" + }, + "install-path": "../symfony/http-foundation" }, { - "name": "Andy Prevost", - "email": "codeworxtech@users.sourceforge.net" + "name": "symfony/polyfill-mbstring", + "version": "v1.37.0", + "version_normalized": "1.37.0.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-mbstring.git", + "reference": "6a21eb99c6973357967f6ce3708cd55a6bec6315" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/6a21eb99c6973357967f6ce3708cd55a6bec6315", + "reference": "6a21eb99c6973357967f6ce3708cd55a6bec6315", + "shasum": "" + }, + "require": { + "ext-iconv": "*", + "php": ">=7.2" + }, + "provide": { + "ext-mbstring": "*" + }, + "suggest": { + "ext-mbstring": "For best performance" + }, + "time": "2026-04-10T17:25:58+00:00", + "type": "library", + "extra": { + "thanks": { + "url": "https://github.com/symfony/polyfill", + "name": "symfony/polyfill" + } + }, + "installation-source": "dist", + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Mbstring\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for the Mbstring extension", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "mbstring", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.37.0" + }, + "install-path": "../symfony/polyfill-mbstring" }, { - "name": "Brent R. Matzelle" - } - ], - "description": "PHPMailer is a full-featured email creation and transfer class for PHP", - "support": { - "issues": "https://github.com/PHPMailer/PHPMailer/issues", - "source": "https://github.com/PHPMailer/PHPMailer/tree/v6.9.3" - }, - "funding": [ - { - "url": "https://github.com/Synchro", - "type": "github" - } - ], - "install-path": "../phpmailer/phpmailer" - }, - { - "name": "phpoffice/math", - "version": "0.2.0", - "version_normalized": "0.2.0.0", - "source": { - "type": "git", - "url": "https://github.com/PHPOffice/Math.git", - "reference": "fc2eb6d1a61b058d5dac77197059db30ee3c8329" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/PHPOffice/Math/zipball/fc2eb6d1a61b058d5dac77197059db30ee3c8329", - "reference": "fc2eb6d1a61b058d5dac77197059db30ee3c8329", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-xml": "*", - "php": "^7.1|^8.0" - }, - "require-dev": { - "phpstan/phpstan": "^0.12.88 || ^1.0.0", - "phpunit/phpunit": "^7.0 || ^9.0" - }, - "time": "2024-08-12T07:30:45+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "PhpOffice\\Math\\": "src/Math/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Progi1984", - "homepage": "https://lefevre.dev" - } - ], - "description": "Math - Manipulate Math Formula", - "homepage": "https://phpoffice.github.io/Math/", - "keywords": [ - "MathML", - "officemathml", - "php" - ], - "support": { - "issues": "https://github.com/PHPOffice/Math/issues", - "source": "https://github.com/PHPOffice/Math/tree/0.2.0" - }, - "install-path": "../phpoffice/math" - }, - { - "name": "phpoffice/phpexcel", - "version": "1.8.2", - "version_normalized": "1.8.2.0", - "source": { - "type": "git", - "url": "https://github.com/PHPOffice/PHPExcel.git", - "reference": "1441011fb7ecdd8cc689878f54f8b58a6805f870" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/PHPOffice/PHPExcel/zipball/1441011fb7ecdd8cc689878f54f8b58a6805f870", - "reference": "1441011fb7ecdd8cc689878f54f8b58a6805f870", - "shasum": "" - }, - "require": { - "ext-mbstring": "*", - "ext-xml": "*", - "ext-xmlwriter": "*", - "php": "^5.2|^7.0" - }, - "require-dev": { - "squizlabs/php_codesniffer": "2.*" - }, - "time": "2018-11-22T23:07:24+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-0": { - "PHPExcel": "Classes/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-2.1" - ], - "authors": [ - { - "name": "Maarten Balliauw", - "homepage": "http://blog.maartenballiauw.be" + "name": "symfony/polyfill-php80", + "version": "v1.37.0", + "version_normalized": "1.37.0.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php80.git", + "reference": "dfb55726c3a76ea3b6459fcfda1ec2d80a682411" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/dfb55726c3a76ea3b6459fcfda1ec2d80a682411", + "reference": "dfb55726c3a76ea3b6459fcfda1ec2d80a682411", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "time": "2026-04-10T16:19:22+00:00", + "type": "library", + "extra": { + "thanks": { + "url": "https://github.com/symfony/polyfill", + "name": "symfony/polyfill" + } + }, + "installation-source": "dist", + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php80\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ion Bazan", + "email": "ion.bazan@gmail.com" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php80/tree/v1.37.0" + }, + "install-path": "../symfony/polyfill-php80" }, { - "name": "Erik Tilt" + "name": "tectalic/openai", + "version": "v1.6.0", + "version_normalized": "1.6.0.0", + "source": { + "type": "git", + "url": "https://github.com/tectalichq/public-openai-client-php.git", + "reference": "aa321d55bdd01511515e7b3436c092325fa651f4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tectalichq/public-openai-client-php/zipball/aa321d55bdd01511515e7b3436c092325fa651f4", + "reference": "aa321d55bdd01511515e7b3436c092325fa651f4", + "shasum": "" + }, + "require": { + "ext-json": "*", + "nyholm/psr7": "^1.4", + "php": "^7.2.5 || ^8.0", + "php-http/message": "^1.11", + "php-http/multipart-stream-builder": "^1.2", + "psr/http-client": "^1.0.1", + "spatie/data-transfer-object": "^1.14" + }, + "conflict": { + "cebe/php-openapi": "<1.7", + "riverline/multipart-parser": "<2.0.9", + "symfony/yaml": "<3.4.31 || >4.0 <4.3.4" + }, + "require-dev": { + "league/openapi-psr7-validator": "^0.17.0", + "mikey179/vfsstream": "^1.6.10", + "php-http/mock-client": "^1.5", + "phpstan/phpstan": "^1.4", + "phpunit/phpunit": "^8.5.14 || ^9.5 || ^10.0", + "squizlabs/php_codesniffer": "^3.6", + "symfony/http-client": "^5.3" + }, + "suggest": { + "php-http/mock-client": "Simplify testing by using a mock HTTP client" + }, + "time": "2023-09-06T02:15:29+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Tectalic\\OpenAi\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "An OpenAI REST API Client with support for ChatGPT, GPT-4, GPT-3.5, GPT-3, Codex, DALL·E, Whisper, Embeddings, Fine-Tuning and Moderation models. Includes fully typed Data Transfer Objects (DTOs) for all requests and responses and IDE autocomplete support.", + "homepage": "https://tectalic.com/apis/openai", + "keywords": [ + "ChatGpt", + "GPT-3", + "ai", + "api", + "dall-e", + "dalle", + "fine-tuning", + "gpt-3.5", + "gpt-4", + "gpt3", + "gpt3.5", + "gpt4", + "openai", + "rest", + "tectalic", + "whisper" + ], + "support": { + "source": "https://github.com/tectalichq/public-openai-client-php/tree/v1.6.0" + }, + "abandoned": true, + "install-path": "../tectalic/openai" }, { - "name": "Franck Lefevre", - "homepage": "http://rootslabs.net" + "name": "topthink/framework", + "version": "v5.0.25", + "version_normalized": "5.0.25.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/framework.git", + "reference": "643c58ed1bd22a2823ce5e95b3b68a5075f9087c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/framework/zipball/643c58ed1bd22a2823ce5e95b3b68a5075f9087c", + "reference": "643c58ed1bd22a2823ce5e95b3b68a5075f9087c", + "shasum": "" + }, + "require": { + "php": ">=5.4.0", + "topthink/think-installer": "~1.0" + }, + "require-dev": { + "johnkary/phpunit-speedtrap": "^1.0", + "mikey179/vfsstream": "~1.6", + "phpdocumentor/reflection-docblock": "^2.0", + "phploc/phploc": "2.*", + "phpunit/phpunit": "4.8.*", + "sebastian/phpcpd": "2.*" + }, + "time": "2022-10-25T14:59:38+00:00", + "type": "think-framework", + "installation-source": "dist", + "autoload": { + "psr-4": { + "think\\": "library/think" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "liu21st", + "email": "liu21st@gmail.com" + } + ], + "description": "the new thinkphp framework", + "homepage": "http://thinkphp.cn/", + "keywords": [ + "framework", + "orm", + "thinkphp" + ], + "support": { + "issues": "https://github.com/top-think/framework/issues", + "source": "https://github.com/top-think/framework/tree/v5.0.25" + }, + "install-path": "../../thinkphp" }, { - "name": "Mark Baker", - "homepage": "http://markbakeruk.net" - } - ], - "description": "PHPExcel - OpenXML - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", - "homepage": "https://github.com/PHPOffice/PHPExcel", - "keywords": [ - "OpenXML", - "excel", - "php", - "spreadsheet", - "xls", - "xlsx" - ], - "support": { - "issues": "https://github.com/PHPOffice/PHPExcel/issues", - "source": "https://github.com/PHPOffice/PHPExcel/tree/master" - }, - "abandoned": "phpoffice/phpspreadsheet", - "install-path": "../phpoffice/phpexcel" - }, - { - "name": "phpoffice/phpspreadsheet", - "version": "1.25.2", - "version_normalized": "1.25.2.0", - "source": { - "type": "git", - "url": "https://github.com/PHPOffice/PhpSpreadsheet.git", - "reference": "a317a09e7def49852400a4b3eca4a4b0790ceeb5" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/PHPOffice/PhpSpreadsheet/zipball/a317a09e7def49852400a4b3eca4a4b0790ceeb5", - "reference": "a317a09e7def49852400a4b3eca4a4b0790ceeb5", - "shasum": "" - }, - "require": { - "ext-ctype": "*", - "ext-dom": "*", - "ext-fileinfo": "*", - "ext-gd": "*", - "ext-iconv": "*", - "ext-libxml": "*", - "ext-mbstring": "*", - "ext-simplexml": "*", - "ext-xml": "*", - "ext-xmlreader": "*", - "ext-xmlwriter": "*", - "ext-zip": "*", - "ext-zlib": "*", - "ezyang/htmlpurifier": "^4.15", - "maennchen/zipstream-php": "^2.1", - "markbaker/complex": "^3.0", - "markbaker/matrix": "^3.0", - "php": "^7.3 || ^8.0", - "psr/http-client": "^1.0", - "psr/http-factory": "^1.0", - "psr/simple-cache": "^1.0 || ^2.0 || ^3.0" - }, - "require-dev": { - "dealerdirect/phpcodesniffer-composer-installer": "dev-master", - "dompdf/dompdf": "^1.0 || ^2.0", - "friendsofphp/php-cs-fixer": "^3.2", - "mitoteam/jpgraph": "10.2.4", - "mpdf/mpdf": "8.1.1", - "phpcompatibility/php-compatibility": "^9.3", - "phpstan/phpstan": "^1.1", - "phpstan/phpstan-phpunit": "^1.0", - "phpunit/phpunit": "^8.5 || ^9.0", - "squizlabs/php_codesniffer": "^3.7", - "tecnickcom/tcpdf": "6.5" - }, - "suggest": { - "dompdf/dompdf": "Option for rendering PDF with PDF Writer", - "ext-intl": "PHP Internationalization Functions", - "mitoteam/jpgraph": "Option for rendering charts, or including charts with PDF or HTML Writers", - "mpdf/mpdf": "Option for rendering PDF with PDF Writer", - "tecnickcom/tcpdf": "Option for rendering PDF with PDF Writer" - }, - "time": "2022-09-25T17:21:01+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "PhpOffice\\PhpSpreadsheet\\": "src/PhpSpreadsheet" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Maarten Balliauw", - "homepage": "https://blog.maartenballiauw.be" + "name": "topthink/think-captcha", + "version": "v1.0.8", + "version_normalized": "1.0.8.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-captcha.git", + "reference": "1d64363c814c92f6086c4fa5e3223fe7e23db09d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/think-captcha/zipball/1d64363c814c92f6086c4fa5e3223fe7e23db09d", + "reference": "1d64363c814c92f6086c4fa5e3223fe7e23db09d", + "shasum": "" + }, + "require": { + "topthink/framework": "~5.0.0", + "topthink/think-installer": ">=1.0.10" + }, + "time": "2019-01-28T04:48:36+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "src/helper.php" + ], + "psr-4": { + "think\\captcha\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "captcha package for thinkphp5", + "support": { + "issues": "https://github.com/top-think/think-captcha/issues", + "source": "https://github.com/top-think/think-captcha/tree/master" + }, + "install-path": "../topthink/think-captcha" }, { - "name": "Mark Baker", - "homepage": "https://markbakeruk.net" + "name": "topthink/think-helper", + "version": "v3.1.12", + "version_normalized": "3.1.12.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-helper.git", + "reference": "fe277121112a8f1c872e169a733ca80bb11c4acb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/think-helper/zipball/fe277121112a8f1c872e169a733ca80bb11c4acb", + "reference": "fe277121112a8f1c872e169a733ca80bb11c4acb", + "shasum": "" + }, + "require": { + "php": ">=7.1.0" + }, + "require-dev": { + "phpunit/phpunit": "^9.5" + }, + "time": "2025-12-26T09:58:29+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "files": [ + "src/helper.php" + ], + "psr-4": { + "think\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "The ThinkPHP6 Helper Package", + "support": { + "issues": "https://github.com/top-think/think-helper/issues", + "source": "https://github.com/top-think/think-helper/tree/v3.1.12" + }, + "install-path": "../topthink/think-helper" }, { - "name": "Franck Lefevre", - "homepage": "https://rootslabs.net" + "name": "topthink/think-image", + "version": "v1.0.8", + "version_normalized": "1.0.8.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-image.git", + "reference": "d1d748cbb2fe2f29fca6138cf96cb8b5113892f1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/think-image/zipball/d1d748cbb2fe2f29fca6138cf96cb8b5113892f1", + "reference": "d1d748cbb2fe2f29fca6138cf96cb8b5113892f1", + "shasum": "" + }, + "require": { + "ext-gd": "*" + }, + "require-dev": { + "phpunit/phpunit": "4.8.*", + "topthink/framework": "^5.0" + }, + "time": "2024-08-07T10:06:35+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "think\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "The ThinkPHP5 Image Package", + "support": { + "issues": "https://github.com/top-think/think-image/issues", + "source": "https://github.com/top-think/think-image/tree/v1.0.8" + }, + "install-path": "../topthink/think-image" }, { - "name": "Erik Tilt" + "name": "topthink/think-installer", + "version": "v1.0.14", + "version_normalized": "1.0.14.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-installer.git", + "reference": "eae1740ac264a55c06134b6685dfb9f837d004d1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/think-installer/zipball/eae1740ac264a55c06134b6685dfb9f837d004d1", + "reference": "eae1740ac264a55c06134b6685dfb9f837d004d1", + "shasum": "" + }, + "require": { + "composer-plugin-api": "^1.0||^2.0" + }, + "require-dev": { + "composer/composer": "^1.0||^2.0" + }, + "time": "2021-03-25T08:34:02+00:00", + "type": "composer-plugin", + "extra": { + "class": "think\\composer\\Plugin" + }, + "installation-source": "dist", + "autoload": { + "psr-4": { + "think\\composer\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "support": { + "issues": "https://github.com/top-think/think-installer/issues", + "source": "https://github.com/top-think/think-installer/tree/v1.0.14" + }, + "install-path": "../topthink/think-installer" }, { - "name": "Adrien Crivelli" + "name": "topthink/think-queue", + "version": "v1.1.4", + "version_normalized": "1.1.4.0", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-queue.git", + "reference": "ad709611d516e13d6760234bc98e91faa901cae8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/top-think/think-queue/zipball/ad709611d516e13d6760234bc98e91faa901cae8", + "reference": "ad709611d516e13d6760234bc98e91faa901cae8", + "shasum": "" + }, + "require": { + "topthink/think-helper": ">=1.0.4", + "topthink/think-installer": ">=1.0.10" + }, + "time": "2017-06-25T00:49:56+00:00", + "type": "think-extend", + "extra": { + "think-config": { + "queue": "src/config.php" + } + }, + "installation-source": "dist", + "autoload": { + "files": [ + "src/common.php" + ], + "psr-4": { + "think\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "The ThinkPHP5 Queue Package", + "support": { + "issues": "https://github.com/top-think/think-queue/issues", + "source": "https://github.com/top-think/think-queue/tree/master" + }, + "install-path": "../topthink/think-queue" } - ], - "description": "PHPSpreadsheet - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", - "homepage": "https://github.com/PHPOffice/PhpSpreadsheet", - "keywords": [ - "OpenXML", - "excel", - "gnumeric", - "ods", - "php", - "spreadsheet", - "xls", - "xlsx" - ], - "support": { - "issues": "https://github.com/PHPOffice/PhpSpreadsheet/issues", - "source": "https://github.com/PHPOffice/PhpSpreadsheet/tree/1.25.2" - }, - "install-path": "../phpoffice/phpspreadsheet" - }, - { - "name": "phpoffice/phpword", - "version": "1.3.0", - "version_normalized": "1.3.0.0", - "source": { - "type": "git", - "url": "https://github.com/PHPOffice/PHPWord.git", - "reference": "8392134ce4b5dba65130ba956231a1602b848b7f" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/PHPOffice/PHPWord/zipball/8392134ce4b5dba65130ba956231a1602b848b7f", - "reference": "8392134ce4b5dba65130ba956231a1602b848b7f", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-json": "*", - "ext-xml": "*", - "php": "^7.1|^8.0", - "phpoffice/math": "^0.2" - }, - "require-dev": { - "dompdf/dompdf": "^2.0", - "ext-gd": "*", - "ext-libxml": "*", - "ext-zip": "*", - "friendsofphp/php-cs-fixer": "^3.3", - "mpdf/mpdf": "^8.1", - "phpmd/phpmd": "^2.13", - "phpstan/phpstan-phpunit": "@stable", - "phpunit/phpunit": ">=7.0", - "symfony/process": "^4.4 || ^5.0", - "tecnickcom/tcpdf": "^6.5" - }, - "suggest": { - "dompdf/dompdf": "Allows writing PDF", - "ext-gd2": "Allows adding images", - "ext-xmlwriter": "Allows writing OOXML and ODF", - "ext-xsl": "Allows applying XSL style sheet to headers, to main document part, and to footers of an OOXML template", - "ext-zip": "Allows writing OOXML and ODF" - }, - "time": "2024-08-30T18:03:42+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "PhpOffice\\PhpWord\\": "src/PhpWord" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-3.0" - ], - "authors": [ - { - "name": "Mark Baker" - }, - { - "name": "Gabriel Bull", - "email": "me@gabrielbull.com", - "homepage": "http://gabrielbull.com/" - }, - { - "name": "Franck Lefevre", - "homepage": "https://rootslabs.net/blog/" - }, - { - "name": "Ivan Lanin", - "homepage": "http://ivan.lanin.org" - }, - { - "name": "Roman Syroeshko", - "homepage": "http://ru.linkedin.com/pub/roman-syroeshko/34/a53/994/" - }, - { - "name": "Antoine de Troostembergh" - } - ], - "description": "PHPWord - A pure PHP library for reading and writing word processing documents (OOXML, ODF, RTF, HTML, PDF)", - "homepage": "https://phpoffice.github.io/PHPWord/", - "keywords": [ - "ISO IEC 29500", - "OOXML", - "Office Open XML", - "OpenDocument", - "OpenXML", - "PhpOffice", - "PhpWord", - "Rich Text Format", - "WordprocessingML", - "doc", - "docx", - "html", - "odf", - "odt", - "office", - "pdf", - "php", - "reader", - "rtf", - "template", - "template processor", - "word", - "writer" - ], - "support": { - "issues": "https://github.com/PHPOffice/PHPWord/issues", - "source": "https://github.com/PHPOffice/PHPWord/tree/1.3.0" - }, - "install-path": "../phpoffice/phpword" - }, - { - "name": "psr/http-client", - "version": "1.0.3", - "version_normalized": "1.0.3.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/http-client.git", - "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/http-client/zipball/bb5906edc1c324c9a05aa0873d40117941e5fa90", - "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90", - "shasum": "" - }, - "require": { - "php": "^7.0 || ^8.0", - "psr/http-message": "^1.0 || ^2.0" - }, - "time": "2023-09-23T14:17:50+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\Http\\Client\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "https://www.php-fig.org/" - } - ], - "description": "Common interface for HTTP clients", - "homepage": "https://github.com/php-fig/http-client", - "keywords": [ - "http", - "http-client", - "psr", - "psr-18" - ], - "support": { - "source": "https://github.com/php-fig/http-client" - }, - "install-path": "../psr/http-client" - }, - { - "name": "psr/http-factory", - "version": "1.1.0", - "version_normalized": "1.1.0.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/http-factory.git", - "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/http-factory/zipball/2b4765fddfe3b508ac62f829e852b1501d3f6e8a", - "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a", - "shasum": "" - }, - "require": { - "php": ">=7.1", - "psr/http-message": "^1.0 || ^2.0" - }, - "time": "2024-04-15T12:06:14+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\Http\\Message\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "https://www.php-fig.org/" - } - ], - "description": "PSR-17: Common interfaces for PSR-7 HTTP message factories", - "keywords": [ - "factory", - "http", - "message", - "psr", - "psr-17", - "psr-7", - "request", - "response" - ], - "support": { - "source": "https://github.com/php-fig/http-factory" - }, - "install-path": "../psr/http-factory" - }, - { - "name": "psr/http-message", - "version": "1.1", - "version_normalized": "1.1.0.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/http-message.git", - "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/http-message/zipball/cb6ce4845ce34a8ad9e68117c10ee90a29919eba", - "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba", - "shasum": "" - }, - "require": { - "php": "^7.2 || ^8.0" - }, - "time": "2023-04-04T09:50:52+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.1.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\Http\\Message\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "description": "Common interface for HTTP messages", - "homepage": "https://github.com/php-fig/http-message", - "keywords": [ - "http", - "http-message", - "psr", - "psr-7", - "request", - "response" - ], - "support": { - "source": "https://github.com/php-fig/http-message/tree/1.1" - }, - "install-path": "../psr/http-message" - }, - { - "name": "psr/log", - "version": "1.1.4", - "version_normalized": "1.1.4.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/log.git", - "reference": "d49695b909c3b7628b6289db5479a1c204601f11" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/log/zipball/d49695b909c3b7628b6289db5479a1c204601f11", - "reference": "d49695b909c3b7628b6289db5479a1c204601f11", - "shasum": "" - }, - "require": { - "php": ">=5.3.0" - }, - "time": "2021-05-03T11:20:27+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.1.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\Log\\": "Psr/Log/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "https://www.php-fig.org/" - } - ], - "description": "Common interface for logging libraries", - "homepage": "https://github.com/php-fig/log", - "keywords": [ - "log", - "psr", - "psr-3" - ], - "support": { - "source": "https://github.com/php-fig/log/tree/1.1.4" - }, - "install-path": "../psr/log" - }, - { - "name": "psr/simple-cache", - "version": "1.0.1", - "version_normalized": "1.0.1.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/simple-cache.git", - "reference": "408d5eafb83c57f6365a3ca330ff23aa4a5fa39b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/408d5eafb83c57f6365a3ca330ff23aa4a5fa39b", - "reference": "408d5eafb83c57f6365a3ca330ff23aa4a5fa39b", - "shasum": "" - }, - "require": { - "php": ">=5.3.0" - }, - "time": "2017-10-23T01:57:42+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\SimpleCache\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "description": "Common interfaces for simple caching", - "keywords": [ - "cache", - "caching", - "psr", - "psr-16", - "simple-cache" - ], - "support": { - "source": "https://github.com/php-fig/simple-cache/tree/master" - }, - "install-path": "../psr/simple-cache" - }, - { - "name": "ralouphie/getallheaders", - "version": "3.0.3", - "version_normalized": "3.0.3.0", - "source": { - "type": "git", - "url": "https://github.com/ralouphie/getallheaders.git", - "reference": "120b605dfeb996808c31b6477290a714d356e822" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822", - "reference": "120b605dfeb996808c31b6477290a714d356e822", - "shasum": "" - }, - "require": { - "php": ">=5.6" - }, - "require-dev": { - "php-coveralls/php-coveralls": "^2.1", - "phpunit/phpunit": "^5 || ^6.5" - }, - "time": "2019-03-08T08:55:37+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "files": [ - "src/getallheaders.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Ralph Khattar", - "email": "ralph.khattar@gmail.com" - } - ], - "description": "A polyfill for getallheaders.", - "support": { - "issues": "https://github.com/ralouphie/getallheaders/issues", - "source": "https://github.com/ralouphie/getallheaders/tree/develop" - }, - "install-path": "../ralouphie/getallheaders" - }, - { - "name": "spatie/data-transfer-object", - "version": "1.14.1", - "version_normalized": "1.14.1.0", - "source": { - "type": "git", - "url": "https://github.com/spatie/data-transfer-object.git", - "reference": "12c25e15f08684f1c57c88ccfb3a38a677a11314" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/spatie/data-transfer-object/zipball/12c25e15f08684f1c57c88ccfb3a38a677a11314", - "reference": "12c25e15f08684f1c57c88ccfb3a38a677a11314", - "shasum": "" - }, - "require": { - "php": "^7.1|^8.0" - }, - "require-dev": { - "larapack/dd": "^1.1", - "phpunit/phpunit": "^7.0|^9.0" - }, - "time": "2021-12-15T07:25:06+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Spatie\\DataTransferObject\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Brent Roose", - "email": "brent@spatie.be", - "homepage": "https://spatie.be", - "role": "Developer" - } - ], - "description": "Data transfer objects with batteries included", - "homepage": "https://github.com/spatie/data-transfer-object", - "keywords": [ - "data-transfer-object", - "spatie" - ], - "support": { - "issues": "https://github.com/spatie/data-transfer-object/issues", - "source": "https://github.com/spatie/data-transfer-object/tree/1.14.1" - }, - "funding": [ - { - "url": "https://spatie.be/open-source/support-us", - "type": "custom" - }, - { - "url": "https://github.com/spatie", - "type": "github" - } - ], - "abandoned": "spatie/laravel-data", - "install-path": "../spatie/data-transfer-object" - }, - { - "name": "symfony/deprecation-contracts", - "version": "v2.5.4", - "version_normalized": "2.5.4.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/deprecation-contracts.git", - "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/605389f2a7e5625f273b53960dc46aeaf9c62918", - "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918", - "shasum": "" - }, - "require": { - "php": ">=7.1" - }, - "time": "2024-09-25T14:11:13+00:00", - "type": "library", - "extra": { - "thanks": { - "url": "https://github.com/symfony/contracts", - "name": "symfony/contracts" - }, - "branch-alias": { - "dev-main": "2.5-dev" - } - }, - "installation-source": "dist", - "autoload": { - "files": [ - "function.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "A generic function and convention to trigger deprecation notices", - "homepage": "https://symfony.com", - "support": { - "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.4" - }, - "funding": [ - { - "url": "https://symfony.com/sponsor", - "type": "custom" - }, - { - "url": "https://github.com/fabpot", - "type": "github" - }, - { - "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", - "type": "tidelift" - } - ], - "install-path": "../symfony/deprecation-contracts" - }, - { - "name": "symfony/polyfill-mbstring", - "version": "v1.31.0", - "version_normalized": "1.31.0.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-mbstring.git", - "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/85181ba99b2345b0ef10ce42ecac37612d9fd341", - "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341", - "shasum": "" - }, - "require": { - "php": ">=7.2" - }, - "provide": { - "ext-mbstring": "*" - }, - "suggest": { - "ext-mbstring": "For best performance" - }, - "time": "2024-09-09T11:45:10+00:00", - "type": "library", - "extra": { - "thanks": { - "url": "https://github.com/symfony/polyfill", - "name": "symfony/polyfill" - } - }, - "installation-source": "source", - "autoload": { - "files": [ - "bootstrap.php" - ], - "psr-4": { - "Symfony\\Polyfill\\Mbstring\\": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "Symfony polyfill for the Mbstring extension", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "mbstring", - "polyfill", - "portable", - "shim" - ], - "support": { - "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.31.0" - }, - "funding": [ - { - "url": "https://symfony.com/sponsor", - "type": "custom" - }, - { - "url": "https://github.com/fabpot", - "type": "github" - }, - { - "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", - "type": "tidelift" - } - ], - "install-path": "../symfony/polyfill-mbstring" - }, - { - "name": "tectalic/openai", - "version": "v1.6.0", - "version_normalized": "1.6.0.0", - "source": { - "type": "git", - "url": "https://github.com/tectalichq/public-openai-client-php.git", - "reference": "aa321d55bdd01511515e7b3436c092325fa651f4" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/tectalichq/public-openai-client-php/zipball/aa321d55bdd01511515e7b3436c092325fa651f4", - "reference": "aa321d55bdd01511515e7b3436c092325fa651f4", - "shasum": "" - }, - "require": { - "ext-json": "*", - "nyholm/psr7": "^1.4", - "php": "^7.2.5 || ^8.0", - "php-http/message": "^1.11", - "php-http/multipart-stream-builder": "^1.2", - "psr/http-client": "^1.0.1", - "spatie/data-transfer-object": "^1.14" - }, - "conflict": { - "cebe/php-openapi": "<1.7", - "riverline/multipart-parser": "<2.0.9", - "symfony/yaml": "<3.4.31 || >4.0 <4.3.4" - }, - "require-dev": { - "league/openapi-psr7-validator": "^0.17.0", - "mikey179/vfsstream": "^1.6.10", - "php-http/mock-client": "^1.5", - "phpstan/phpstan": "^1.4", - "phpunit/phpunit": "^8.5.14 || ^9.5 || ^10.0", - "squizlabs/php_codesniffer": "^3.6", - "symfony/http-client": "^5.3" - }, - "suggest": { - "php-http/mock-client": "Simplify testing by using a mock HTTP client" - }, - "time": "2023-09-06T02:15:29+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Tectalic\\OpenAi\\": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "description": "An OpenAI REST API Client with support for ChatGPT, GPT-4, GPT-3.5, GPT-3, Codex, DALL·E, Whisper, Embeddings, Fine-Tuning and Moderation models. Includes fully typed Data Transfer Objects (DTOs) for all requests and responses and IDE autocomplete support.", - "homepage": "https://tectalic.com/apis/openai", - "keywords": [ - "ChatGpt", - "GPT-3", - "ai", - "api", - "dall-e", - "dalle", - "fine-tuning", - "gpt-3.5", - "gpt-4", - "gpt3", - "gpt3.5", - "gpt4", - "openai", - "rest", - "tectalic", - "whisper" - ], - "support": { - "source": "https://github.com/tectalichq/public-openai-client-php/tree/v1.6.0" - }, - "abandoned": true, - "install-path": "../tectalic/openai" - }, - { - "name": "topthink/framework", - "version": "v5.0.25", - "version_normalized": "5.0.25.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/framework.git", - "reference": "643c58ed1bd22a2823ce5e95b3b68a5075f9087c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/framework/zipball/643c58ed1bd22a2823ce5e95b3b68a5075f9087c", - "reference": "643c58ed1bd22a2823ce5e95b3b68a5075f9087c", - "shasum": "" - }, - "require": { - "php": ">=5.4.0", - "topthink/think-installer": "~1.0" - }, - "require-dev": { - "johnkary/phpunit-speedtrap": "^1.0", - "mikey179/vfsstream": "~1.6", - "phpdocumentor/reflection-docblock": "^2.0", - "phploc/phploc": "2.*", - "phpunit/phpunit": "4.8.*", - "sebastian/phpcpd": "2.*" - }, - "time": "2022-10-25T14:59:38+00:00", - "type": "think-framework", - "installation-source": "dist", - "autoload": { - "psr-4": { - "think\\": "library/think" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "liu21st", - "email": "liu21st@gmail.com" - } - ], - "description": "the new thinkphp framework", - "homepage": "http://thinkphp.cn/", - "keywords": [ - "framework", - "orm", - "thinkphp" - ], - "support": { - "issues": "https://github.com/top-think/framework/issues", - "source": "https://github.com/top-think/framework/tree/v5.0.25" - }, - "install-path": "../../thinkphp" - }, - { - "name": "topthink/think-captcha", - "version": "v1.0.8", - "version_normalized": "1.0.8.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-captcha.git", - "reference": "1d64363c814c92f6086c4fa5e3223fe7e23db09d" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/think-captcha/zipball/1d64363c814c92f6086c4fa5e3223fe7e23db09d", - "reference": "1d64363c814c92f6086c4fa5e3223fe7e23db09d", - "shasum": "", - "mirrors": [ - { - "url": "https://mirrors.aliyun.com/composer/dists/%package%/%reference%.%type%", - "preferred": true - } - ] - }, - "require": { - "topthink/framework": "~5.0.0", - "topthink/think-installer": ">=1.0.10" - }, - "time": "2019-01-28T04:48:36+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "think\\captcha\\": "src/" - }, - "files": [ - "src/helper.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "yunwuxin", - "email": "448901948@qq.com" - } - ], - "description": "captcha package for thinkphp5", - "install-path": "../topthink/think-captcha" - }, - { - "name": "topthink/think-helper", - "version": "v3.1.10", - "version_normalized": "3.1.10.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-helper.git", - "reference": "ac66cc0859a12cd5d73258f50f338aadc95e9b46" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/think-helper/zipball/ac66cc0859a12cd5d73258f50f338aadc95e9b46", - "reference": "ac66cc0859a12cd5d73258f50f338aadc95e9b46", - "shasum": "" - }, - "require": { - "php": ">=7.1.0" - }, - "require-dev": { - "phpunit/phpunit": "^9.5" - }, - "time": "2024-11-21T01:47:51+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "files": [ - "src/helper.php" - ], - "psr-4": { - "think\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "yunwuxin", - "email": "448901948@qq.com" - } - ], - "description": "The ThinkPHP6 Helper Package", - "support": { - "issues": "https://github.com/top-think/think-helper/issues", - "source": "https://github.com/top-think/think-helper/tree/v3.1.10" - }, - "install-path": "../topthink/think-helper" - }, - { - "name": "topthink/think-image", - "version": "v1.0.8", - "version_normalized": "1.0.8.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-image.git", - "reference": "d1d748cbb2fe2f29fca6138cf96cb8b5113892f1" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/think-image/zipball/d1d748cbb2fe2f29fca6138cf96cb8b5113892f1", - "reference": "d1d748cbb2fe2f29fca6138cf96cb8b5113892f1", - "shasum": "" - }, - "require": { - "ext-gd": "*" - }, - "require-dev": { - "phpunit/phpunit": "4.8.*", - "topthink/framework": "^5.0" - }, - "time": "2024-08-07T10:06:35+00:00", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "think\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "yunwuxin", - "email": "448901948@qq.com" - } - ], - "description": "The ThinkPHP5 Image Package", - "support": { - "issues": "https://github.com/top-think/think-image/issues", - "source": "https://github.com/top-think/think-image/tree/v1.0.8" - }, - "install-path": "../topthink/think-image" - }, - { - "name": "topthink/think-installer", - "version": "v1.0.14", - "version_normalized": "1.0.14.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-installer.git", - "reference": "eae1740ac264a55c06134b6685dfb9f837d004d1" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/think-installer/zipball/eae1740ac264a55c06134b6685dfb9f837d004d1", - "reference": "eae1740ac264a55c06134b6685dfb9f837d004d1", - "shasum": "" - }, - "require": { - "composer-plugin-api": "^1.0||^2.0" - }, - "require-dev": { - "composer/composer": "^1.0||^2.0" - }, - "time": "2021-03-25T08:34:02+00:00", - "type": "composer-plugin", - "extra": { - "class": "think\\composer\\Plugin" - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "think\\composer\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "yunwuxin", - "email": "448901948@qq.com" - } - ], - "support": { - "issues": "https://github.com/top-think/think-installer/issues", - "source": "https://github.com/top-think/think-installer/tree/v1.0.14" - }, - "install-path": "../topthink/think-installer" - }, - { - "name": "topthink/think-queue", - "version": "v1.1.4", - "version_normalized": "1.1.4.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-queue.git", - "reference": "ad709611d516e13d6760234bc98e91faa901cae8" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/top-think/think-queue/zipball/ad709611d516e13d6760234bc98e91faa901cae8", - "reference": "ad709611d516e13d6760234bc98e91faa901cae8", - "shasum": "" - }, - "require": { - "topthink/think-helper": ">=1.0.4", - "topthink/think-installer": ">=1.0.10" - }, - "time": "2017-06-25T00:49:56+00:00", - "type": "think-extend", - "extra": { - "think-config": { - "queue": "src/config.php" - } - }, - "installation-source": "dist", - "autoload": { - "files": [ - "src/common.php" - ], - "psr-4": { - "think\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "yunwuxin", - "email": "448901948@qq.com" - } - ], - "description": "The ThinkPHP5 Queue Package", - "support": { - "issues": "https://github.com/top-think/think-queue/issues", - "source": "https://github.com/top-think/think-queue/tree/master" - }, - "install-path": "../topthink/think-queue" - } - ], - "dev": true, - "dev-package-names": [] + ], + "dev": false, + "dev-package-names": [] } diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php index e164285a..6ab50d37 100644 --- a/vendor/composer/installed.php +++ b/vendor/composer/installed.php @@ -3,17 +3,17 @@ 'name' => 'topthink/think', 'pretty_version' => 'dev-master', 'version' => 'dev-master', - 'reference' => 'f3d3ae04ca0af2673209a5a3fde61c3ff53bd1ba', + 'reference' => 'fa878334cd151a29627aac8f2e01d8ce27770606', 'type' => 'project', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), - 'dev' => true, + 'dev' => false, ), 'versions' => array( 'apimatic/core' => array( - 'pretty_version' => '0.3.13', - 'version' => '0.3.13.0', - 'reference' => '944678aa7017457daacd9750b96962fb693ea81a', + 'pretty_version' => '0.3.17', + 'version' => '0.3.17.0', + 'reference' => 'a48a583f686ee3786432b976c795a2817ec095b3', 'type' => 'library', 'install_path' => __DIR__ . '/../apimatic/core', 'aliases' => array(), @@ -29,18 +29,18 @@ 'dev_requirement' => false, ), 'apimatic/jsonmapper' => array( - 'pretty_version' => '3.1.6', - 'version' => '3.1.6.0', - 'reference' => 'c6cc21bd56bfe5d5822bbd08f514be465c0b24e7', + 'pretty_version' => '3.1.7', + 'version' => '3.1.7.0', + 'reference' => '61e45f6021e4a4e07497be596b4787c3c6b39bea', 'type' => 'library', 'install_path' => __DIR__ . '/../apimatic/jsonmapper', 'aliases' => array(), 'dev_requirement' => false, ), 'apimatic/unirest-php' => array( - 'pretty_version' => '4.0.5', - 'version' => '4.0.5.0', - 'reference' => 'e16754010c16be5473289470f129d87a0f41b55e', + 'pretty_version' => '4.0.7', + 'version' => '4.0.7.0', + 'reference' => 'bdfd5f27c105772682c88ed671683f1bd93f4a3c', 'type' => 'library', 'install_path' => __DIR__ . '/../apimatic/unirest-php', 'aliases' => array(), @@ -56,36 +56,36 @@ 'dev_requirement' => false, ), 'ezyang/htmlpurifier' => array( - 'pretty_version' => 'v4.18.0', - 'version' => '4.18.0.0', - 'reference' => 'cb56001e54359df7ae76dc522d08845dc741621b', + 'pretty_version' => 'v4.19.0', + 'version' => '4.19.0.0', + 'reference' => 'b287d2a16aceffbf6e0295559b39662612b77fcf', 'type' => 'library', 'install_path' => __DIR__ . '/../ezyang/htmlpurifier', 'aliases' => array(), 'dev_requirement' => false, ), 'guzzlehttp/guzzle' => array( - 'pretty_version' => '7.9.2', - 'version' => '7.9.2.0', - 'reference' => 'd281ed313b989f213357e3be1a179f02196ac99b', + 'pretty_version' => '7.10.0', + 'version' => '7.10.0.0', + 'reference' => 'b51ac707cfa420b7bfd4e4d5e510ba8008e822b4', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/guzzle', 'aliases' => array(), 'dev_requirement' => false, ), 'guzzlehttp/promises' => array( - 'pretty_version' => '2.0.4', - 'version' => '2.0.4.0', - 'reference' => 'f9c436286ab2892c7db7be8c8da4ef61ccf7b455', + 'pretty_version' => '2.3.0', + 'version' => '2.3.0.0', + 'reference' => '481557b130ef3790cf82b713667b43030dc9c957', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/promises', 'aliases' => array(), 'dev_requirement' => false, ), 'guzzlehttp/psr7' => array( - 'pretty_version' => '2.7.0', - 'version' => '2.7.0.0', - 'reference' => 'a70f5c95fb43bc83f07c9c948baa0dc1829bf201', + 'pretty_version' => '2.9.0', + 'version' => '2.9.0.0', + 'reference' => '7d0ed42f28e42d61352a7a79de682e5e67fec884', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/psr7', 'aliases' => array(), @@ -200,18 +200,18 @@ 'dev_requirement' => false, ), 'phpmailer/phpmailer' => array( - 'pretty_version' => 'v6.9.3', - 'version' => '6.9.3.0', - 'reference' => '2f5c94fe7493efc213f643c23b1b1c249d40f47e', + 'pretty_version' => 'v6.12.0', + 'version' => '6.12.0.0', + 'reference' => 'd1ac35d784bf9f5e61b424901d5a014967f15b12', 'type' => 'library', 'install_path' => __DIR__ . '/../phpmailer/phpmailer', 'aliases' => array(), 'dev_requirement' => false, ), 'phpoffice/math' => array( - 'pretty_version' => '0.2.0', - 'version' => '0.2.0.0', - 'reference' => 'fc2eb6d1a61b058d5dac77197059db30ee3c8329', + 'pretty_version' => '0.3.0', + 'version' => '0.3.0.0', + 'reference' => 'fc31c8f57a7a81f962cbf389fd89f4d9d06fc99a', 'type' => 'library', 'install_path' => __DIR__ . '/../phpoffice/math', 'aliases' => array(), @@ -236,9 +236,9 @@ 'dev_requirement' => false, ), 'phpoffice/phpword' => array( - 'pretty_version' => '1.3.0', - 'version' => '1.3.0.0', - 'reference' => '8392134ce4b5dba65130ba956231a1602b848b7f', + 'pretty_version' => '1.4.0', + 'version' => '1.4.0.0', + 'reference' => '6d75328229bc93790b37e93741adf70646cea958', 'type' => 'library', 'install_path' => __DIR__ . '/../phpoffice/phpword', 'aliases' => array(), @@ -256,8 +256,8 @@ 'psr/http-client-implementation' => array( 'dev_requirement' => false, 'provided' => array( - 0 => '1.0', - 1 => '*', + 0 => '*', + 1 => '1.0', ), ), 'psr/http-factory' => array( @@ -272,8 +272,8 @@ 'psr/http-factory-implementation' => array( 'dev_requirement' => false, 'provided' => array( - 0 => '1.0', - 1 => '*', + 0 => '*', + 1 => '1.0', ), ), 'psr/http-message' => array( @@ -288,8 +288,8 @@ 'psr/http-message-implementation' => array( 'dev_requirement' => false, 'provided' => array( - 0 => '1.0', - 1 => '*', + 0 => '*', + 1 => '1.0', ), ), 'psr/log' => array( @@ -337,15 +337,33 @@ 'aliases' => array(), 'dev_requirement' => false, ), + 'symfony/http-foundation' => array( + 'pretty_version' => 'v5.4.50', + 'version' => '5.4.50.0', + 'reference' => '1a0706e8b8041046052ea2695eb8aeee04f97609', + 'type' => 'library', + 'install_path' => __DIR__ . '/../symfony/http-foundation', + 'aliases' => array(), + 'dev_requirement' => false, + ), 'symfony/polyfill-mbstring' => array( - 'pretty_version' => 'v1.31.0', - 'version' => '1.31.0.0', - 'reference' => '85181ba99b2345b0ef10ce42ecac37612d9fd341', + 'pretty_version' => 'v1.37.0', + 'version' => '1.37.0.0', + 'reference' => '6a21eb99c6973357967f6ce3708cd55a6bec6315', 'type' => 'library', 'install_path' => __DIR__ . '/../symfony/polyfill-mbstring', 'aliases' => array(), 'dev_requirement' => false, ), + 'symfony/polyfill-php80' => array( + 'pretty_version' => 'v1.37.0', + 'version' => '1.37.0.0', + 'reference' => 'dfb55726c3a76ea3b6459fcfda1ec2d80a682411', + 'type' => 'library', + 'install_path' => __DIR__ . '/../symfony/polyfill-php80', + 'aliases' => array(), + 'dev_requirement' => false, + ), 'tectalic/openai' => array( 'pretty_version' => 'v1.6.0', 'version' => '1.6.0.0', @@ -367,7 +385,7 @@ 'topthink/think' => array( 'pretty_version' => 'dev-master', 'version' => 'dev-master', - 'reference' => 'f3d3ae04ca0af2673209a5a3fde61c3ff53bd1ba', + 'reference' => 'fa878334cd151a29627aac8f2e01d8ce27770606', 'type' => 'project', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), @@ -383,9 +401,9 @@ 'dev_requirement' => false, ), 'topthink/think-helper' => array( - 'pretty_version' => 'v3.1.10', - 'version' => '3.1.10.0', - 'reference' => 'ac66cc0859a12cd5d73258f50f338aadc95e9b46', + 'pretty_version' => 'v3.1.12', + 'version' => '3.1.12.0', + 'reference' => 'fe277121112a8f1c872e169a733ca80bb11c4acb', 'type' => 'library', 'install_path' => __DIR__ . '/../topthink/think-helper', 'aliases' => array(), diff --git a/vendor/composer/platform_check.php b/vendor/composer/platform_check.php index 92370c5a..d826bd13 100644 --- a/vendor/composer/platform_check.php +++ b/vendor/composer/platform_check.php @@ -19,8 +19,7 @@ if ($issues) { echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL; } } - trigger_error( - 'Composer detected issues in your platform: ' . implode(' ', $issues), - E_USER_ERROR + throw new \RuntimeException( + 'Composer detected issues in your platform: ' . implode(' ', $issues) ); } diff --git a/vendor/doctrine/annotations/LICENSE b/vendor/doctrine/annotations/LICENSE deleted file mode 100644 index 5e781fce..00000000 --- a/vendor/doctrine/annotations/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2006-2013 Doctrine Project - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/vendor/doctrine/annotations/README.md b/vendor/doctrine/annotations/README.md deleted file mode 100644 index c2c7eb7b..00000000 --- a/vendor/doctrine/annotations/README.md +++ /dev/null @@ -1,18 +0,0 @@ -# Doctrine Annotations - -[![Build Status](https://github.com/doctrine/annotations/workflows/Continuous%20Integration/badge.svg?label=build)](https://github.com/doctrine/persistence/actions) -[![Dependency Status](https://www.versioneye.com/package/php--doctrine--annotations/badge.png)](https://www.versioneye.com/package/php--doctrine--annotations) -[![Reference Status](https://www.versioneye.com/php/doctrine:annotations/reference_badge.svg)](https://www.versioneye.com/php/doctrine:annotations/references) -[![Total Downloads](https://poser.pugx.org/doctrine/annotations/downloads.png)](https://packagist.org/packages/doctrine/annotations) -[![Latest Stable Version](https://img.shields.io/packagist/v/doctrine/annotations.svg?label=stable)](https://packagist.org/packages/doctrine/annotations) - -Docblock Annotations Parser library (extracted from [Doctrine Common](https://github.com/doctrine/common)). - -## Documentation - -See the [doctrine-project website](https://www.doctrine-project.org/projects/doctrine-annotations/en/latest/index.html). - -## Contributing - -When making a pull request, make sure your changes follow the -[Coding Standard Guidelines](https://www.doctrine-project.org/projects/doctrine-coding-standard/en/current/reference/index.html#introduction). diff --git a/vendor/doctrine/annotations/composer.json b/vendor/doctrine/annotations/composer.json deleted file mode 100644 index 00d02310..00000000 --- a/vendor/doctrine/annotations/composer.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "name": "doctrine/annotations", - "type": "library", - "description": "Docblock Annotations Parser", - "keywords": ["annotations", "docblock", "parser"], - "homepage": "https://www.doctrine-project.org/projects/annotations.html", - "license": "MIT", - "authors": [ - {"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"}, - {"name": "Roman Borschel", "email": "roman@code-factory.org"}, - {"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"}, - {"name": "Jonathan Wage", "email": "jonwage@gmail.com"}, - {"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"} - ], - "require": { - "php": "^7.1 || ^8.0", - "ext-tokenizer": "*", - "doctrine/lexer": "1.*", - "psr/cache": "^1 || ^2 || ^3" - }, - "require-dev": { - "doctrine/cache": "^1.11 || ^2.0", - "doctrine/coding-standard": "^6.0 || ^8.1", - "phpstan/phpstan": "^0.12.20", - "phpunit/phpunit": "^7.5 || ^8.0 || ^9.1.5", - "symfony/cache": "^4.4 || ^5.2" - }, - "config": { - "sort-packages": true - }, - "autoload": { - "psr-4": { "Doctrine\\Common\\Annotations\\": "lib/Doctrine/Common/Annotations" } - }, - "autoload-dev": { - "psr-4": { - "Doctrine\\Performance\\Common\\Annotations\\": "tests/Doctrine/Performance/Common/Annotations", - "Doctrine\\Tests\\Common\\Annotations\\": "tests/Doctrine/Tests/Common/Annotations" - }, - "files": [ - "tests/Doctrine/Tests/Common/Annotations/Fixtures/functions.php", - "tests/Doctrine/Tests/Common/Annotations/Fixtures/SingleClassLOC1000.php" - ] - } -} diff --git a/vendor/doctrine/annotations/docs/en/annotations.rst b/vendor/doctrine/annotations/docs/en/annotations.rst deleted file mode 100644 index 2c3c4286..00000000 --- a/vendor/doctrine/annotations/docs/en/annotations.rst +++ /dev/null @@ -1,252 +0,0 @@ -Handling Annotations -==================== - -There are several different approaches to handling annotations in PHP. -Doctrine Annotations maps docblock annotations to PHP classes. Because -not all docblock annotations are used for metadata purposes a filter is -applied to ignore or skip classes that are not Doctrine annotations. - -Take a look at the following code snippet: - -.. code-block:: php - - namespace MyProject\Entities; - - use Doctrine\ORM\Mapping AS ORM; - use Symfony\Component\Validator\Constraints AS Assert; - - /** - * @author Benjamin Eberlei - * @ORM\Entity - * @MyProject\Annotations\Foobarable - */ - class User - { - /** - * @ORM\Id @ORM\Column @ORM\GeneratedValue - * @dummy - * @var int - */ - private $id; - - /** - * @ORM\Column(type="string") - * @Assert\NotEmpty - * @Assert\Email - * @var string - */ - private $email; - } - -In this snippet you can see a variety of different docblock annotations: - -- Documentation annotations such as ``@var`` and ``@author``. These - annotations are ignored and never considered for throwing an - exception due to wrongly used annotations. -- Annotations imported through use statements. The statement ``use - Doctrine\ORM\Mapping AS ORM`` makes all classes under that namespace - available as ``@ORM\ClassName``. Same goes for the import of - ``@Assert``. -- The ``@dummy`` annotation. It is not a documentation annotation and - not ignored. For Doctrine Annotations it is not entirely clear how - to handle this annotation. Depending on the configuration an exception - (unknown annotation) will be thrown when parsing this annotation. -- The fully qualified annotation ``@MyProject\Annotations\Foobarable``. - This is transformed directly into the given class name. - -How are these annotations loaded? From looking at the code you could -guess that the ORM Mapping, Assert Validation and the fully qualified -annotation can just be loaded using -the defined PHP autoloaders. This is not the case however: For error -handling reasons every check for class existence inside the -``AnnotationReader`` sets the second parameter $autoload -of ``class_exists($name, $autoload)`` to false. To work flawlessly the -``AnnotationReader`` requires silent autoloaders which many autoloaders are -not. Silent autoloading is NOT part of the `PSR-0 specification -`_ -for autoloading. - -This is why Doctrine Annotations uses its own autoloading mechanism -through a global registry. If you are wondering about the annotation -registry being global, there is no other way to solve the architectural -problems of autoloading annotation classes in a straightforward fashion. -Additionally if you think about PHP autoloading then you recognize it is -a global as well. - -To anticipate the configuration section, making the above PHP class work -with Doctrine Annotations requires this setup: - -.. code-block:: php - - use Doctrine\Common\Annotations\AnnotationReader; - use Doctrine\Common\Annotations\AnnotationRegistry; - - AnnotationRegistry::registerFile("/path/to/doctrine/lib/Doctrine/ORM/Mapping/Driver/DoctrineAnnotations.php"); - AnnotationRegistry::registerAutoloadNamespace("Symfony\Component\Validator\Constraint", "/path/to/symfony/src"); - AnnotationRegistry::registerAutoloadNamespace("MyProject\Annotations", "/path/to/myproject/src"); - - $reader = new AnnotationReader(); - AnnotationReader::addGlobalIgnoredName('dummy'); - -The second block with the annotation registry calls registers all the -three different annotation namespaces that are used. -Doctrine Annotations saves all its annotations in a single file, that is -why ``AnnotationRegistry#registerFile`` is used in contrast to -``AnnotationRegistry#registerAutoloadNamespace`` which creates a PSR-0 -compatible loading mechanism for class to file names. - -In the third block, we create the actual ``AnnotationReader`` instance. -Note that we also add ``dummy`` to the global list of ignored -annotations for which we do not throw exceptions. Setting this is -necessary in our example case, otherwise ``@dummy`` would trigger an -exception to be thrown during the parsing of the docblock of -``MyProject\Entities\User#id``. - -Setup and Configuration ------------------------ - -To use the annotations library is simple, you just need to create a new -``AnnotationReader`` instance: - -.. code-block:: php - - $reader = new \Doctrine\Common\Annotations\AnnotationReader(); - -This creates a simple annotation reader with no caching other than in -memory (in php arrays). Since parsing docblocks can be expensive you -should cache this process by using a caching reader. - -To cache annotations, you can create a ``Doctrine\Common\Annotations\PsrCachedReader``. -This reader decorates the original reader and stores all annotations in a PSR-6 -cache: - -.. code-block:: php - - use Doctrine\Common\Annotations\AnnotationReader; - use Doctrine\Common\Annotations\PsrCachedReader; - - $cache = ... // instantiate a PSR-6 Cache pool - - $reader = new PsrCachedReader( - new AnnotationReader(), - $cache, - $debug = true - ); - -The ``debug`` flag is used here as well to invalidate the cache files -when the PHP class with annotations changed and should be used during -development. - -.. warning :: - - The ``AnnotationReader`` works and caches under the - assumption that all annotations of a doc-block are processed at - once. That means that annotation classes that do not exist and - aren't loaded and cannot be autoloaded (using the - AnnotationRegistry) would never be visible and not accessible if a - cache is used unless the cache is cleared and the annotations - requested again, this time with all annotations defined. - -By default the annotation reader returns a list of annotations with -numeric indexes. If you want your annotations to be indexed by their -class name you can wrap the reader in an ``IndexedReader``: - -.. code-block:: php - - use Doctrine\Common\Annotations\AnnotationReader; - use Doctrine\Common\Annotations\IndexedReader; - - $reader = new IndexedReader(new AnnotationReader()); - -.. warning:: - - You should never wrap the indexed reader inside a cached reader, - only the other way around. This way you can re-use the cache with - indexed or numeric keys, otherwise your code may experience failures - due to caching in a numerical or indexed format. - -Registering Annotations -~~~~~~~~~~~~~~~~~~~~~~~ - -As explained in the introduction, Doctrine Annotations uses its own -autoloading mechanism to determine if a given annotation has a -corresponding PHP class that can be autoloaded. For annotation -autoloading you have to configure the -``Doctrine\Common\Annotations\AnnotationRegistry``. There are three -different mechanisms to configure annotation autoloading: - -- Calling ``AnnotationRegistry#registerFile($file)`` to register a file - that contains one or more annotation classes. -- Calling ``AnnotationRegistry#registerNamespace($namespace, $dirs = - null)`` to register that the given namespace contains annotations and - that their base directory is located at the given $dirs or in the - include path if ``NULL`` is passed. The given directories should *NOT* - be the directory where classes of the namespace are in, but the base - directory of the root namespace. The AnnotationRegistry uses a - namespace to directory separator approach to resolve the correct path. -- Calling ``AnnotationRegistry#registerLoader($callable)`` to register - an autoloader callback. The callback accepts the class as first and - only parameter and has to return ``true`` if the corresponding file - was found and included. - -.. note:: - - Loaders have to fail silently, if a class is not found even if it - matches for example the namespace prefix of that loader. Never is a - loader to throw a warning or exception if the loading failed - otherwise parsing doc block annotations will become a huge pain. - -A sample loader callback could look like: - -.. code-block:: php - - use Doctrine\Common\Annotations\AnnotationRegistry; - use Symfony\Component\ClassLoader\UniversalClassLoader; - - AnnotationRegistry::registerLoader(function($class) { - $file = str_replace("\\", DIRECTORY_SEPARATOR, $class) . ".php"; - - if (file_exists("/my/base/path/" . $file)) { - // file_exists() makes sure that the loader fails silently - require "/my/base/path/" . $file; - } - }); - - $loader = new UniversalClassLoader(); - AnnotationRegistry::registerLoader(array($loader, "loadClass")); - - -Ignoring missing exceptions -~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -By default an exception is thrown from the ``AnnotationReader`` if an -annotation was found that: - -- is not part of the list of ignored "documentation annotations"; -- was not imported through a use statement; -- is not a fully qualified class that exists. - -You can disable this behavior for specific names if your docblocks do -not follow strict requirements: - -.. code-block:: php - - $reader = new \Doctrine\Common\Annotations\AnnotationReader(); - AnnotationReader::addGlobalIgnoredName('foo'); - -PHP Imports -~~~~~~~~~~~ - -By default the annotation reader parses the use-statement of a php file -to gain access to the import rules and register them for the annotation -processing. Only if you are using PHP Imports can you validate the -correct usage of annotations and throw exceptions if you misspelled an -annotation. This mechanism is enabled by default. - -To ease the upgrade path, we still allow you to disable this mechanism. -Note however that we will remove this in future versions: - -.. code-block:: php - - $reader = new \Doctrine\Common\Annotations\AnnotationReader(); - $reader->setEnabledPhpImports(false); diff --git a/vendor/doctrine/annotations/docs/en/custom.rst b/vendor/doctrine/annotations/docs/en/custom.rst deleted file mode 100644 index 11fbe1a3..00000000 --- a/vendor/doctrine/annotations/docs/en/custom.rst +++ /dev/null @@ -1,443 +0,0 @@ -Custom Annotation Classes -========================= - -If you want to define your own annotations, you just have to group them -in a namespace and register this namespace in the ``AnnotationRegistry``. -Annotation classes have to contain a class-level docblock with the text -``@Annotation``: - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** @Annotation */ - class Bar - { - // some code - } - -Inject annotation values ------------------------- - -The annotation parser checks if the annotation constructor has arguments, -if so then it will pass the value array, otherwise it will try to inject -values into public properties directly: - - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** - * @Annotation - * - * Some Annotation using a constructor - */ - class Bar - { - private $foo; - - public function __construct(array $values) - { - $this->foo = $values['foo']; - } - } - - /** - * @Annotation - * - * Some Annotation without a constructor - */ - class Foo - { - public $bar; - } - -Optional: Constructors with Named Parameters --------------------------------------------- - -Starting with Annotations v1.11 a new annotation instantiation strategy -is available that aims at compatibility of Annotation classes with the PHP 8 -attribute feature. You need to declare a constructor with regular parameter -names that match the named arguments in the annotation syntax. - -To enable this feature, you can tag your annotation class with -``@NamedArgumentConstructor`` (available from v1.12) or implement the -``Doctrine\Common\Annotations\NamedArgumentConstructorAnnotation`` interface -(available from v1.11 and deprecated as of v1.12). -When using the ``@NamedArgumentConstructor`` tag, the first argument of the -constructor is considered as the default one. - - -Usage with the ``@NamedArgumentContrustor`` tag - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** - * @Annotation - * @NamedArgumentConstructor - */ - class Bar implements NamedArgumentConstructorAnnotation - { - private $foo; - - public function __construct(string $foo) - { - $this->foo = $foo; - } - } - - /** Usable with @Bar(foo="baz") */ - /** Usable with @Bar("baz") */ - -In combination with PHP 8's constructor property promotion feature -you can simplify this to: - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** - * @Annotation - * @NamedArgumentConstructor - */ - class Bar implements NamedArgumentConstructorAnnotation - { - public function __construct(private string $foo) {} - } - - -Usage with the -``Doctrine\Common\Annotations\NamedArgumentConstructorAnnotation`` -interface (v1.11, deprecated as of v1.12): -.. code-block:: php - - namespace MyCompany\Annotations; - - use Doctrine\Common\Annotations\NamedArgumentConstructorAnnotation; - - /** @Annotation */ - class Bar implements NamedArgumentConstructorAnnotation - { - private $foo; - - public function __construct(private string $foo) {} - } - - /** Usable with @Bar(foo="baz") */ - -Annotation Target ------------------ - -``@Target`` indicates the kinds of class elements to which an annotation -type is applicable. Then you could define one or more targets: - -- ``CLASS`` Allowed in class docblocks -- ``PROPERTY`` Allowed in property docblocks -- ``METHOD`` Allowed in the method docblocks -- ``FUNCTION`` Allowed in function dockblocks -- ``ALL`` Allowed in class, property, method and function docblocks -- ``ANNOTATION`` Allowed inside other annotations - -If the annotations is not allowed in the current context, an -``AnnotationException`` is thrown. - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** - * @Annotation - * @Target({"METHOD","PROPERTY"}) - */ - class Bar - { - // some code - } - - /** - * @Annotation - * @Target("CLASS") - */ - class Foo - { - // some code - } - -Attribute types ---------------- - -The annotation parser checks the given parameters using the phpdoc -annotation ``@var``, The data type could be validated using the ``@var`` -annotation on the annotation properties or using the ``@Attributes`` and -``@Attribute`` annotations. - -If the data type does not match you get an ``AnnotationException`` - -.. code-block:: php - - namespace MyCompany\Annotations; - - /** - * @Annotation - * @Target({"METHOD","PROPERTY"}) - */ - class Bar - { - /** @var mixed */ - public $mixed; - - /** @var boolean */ - public $boolean; - - /** @var bool */ - public $bool; - - /** @var float */ - public $float; - - /** @var string */ - public $string; - - /** @var integer */ - public $integer; - - /** @var array */ - public $array; - - /** @var SomeAnnotationClass */ - public $annotation; - - /** @var array */ - public $arrayOfIntegers; - - /** @var array */ - public $arrayOfAnnotations; - } - - /** - * @Annotation - * @Target({"METHOD","PROPERTY"}) - * @Attributes({ - * @Attribute("stringProperty", type = "string"), - * @Attribute("annotProperty", type = "SomeAnnotationClass"), - * }) - */ - class Foo - { - public function __construct(array $values) - { - $this->stringProperty = $values['stringProperty']; - $this->annotProperty = $values['annotProperty']; - } - - // some code - } - -Annotation Required -------------------- - -``@Required`` indicates that the field must be specified when the -annotation is used. If it is not used you get an ``AnnotationException`` -stating that this value can not be null. - -Declaring a required field: - -.. code-block:: php - - /** - * @Annotation - * @Target("ALL") - */ - class Foo - { - /** @Required */ - public $requiredField; - } - -Usage: - -.. code-block:: php - - /** @Foo(requiredField="value") */ - public $direction; // Valid - - /** @Foo */ - public $direction; // Required field missing, throws an AnnotationException - - -Enumerated values ------------------ - -- An annotation property marked with ``@Enum`` is a field that accepts a - fixed set of scalar values. -- You should use ``@Enum`` fields any time you need to represent fixed - values. -- The annotation parser checks the given value and throws an - ``AnnotationException`` if the value does not match. - - -Declaring an enumerated property: - -.. code-block:: php - - /** - * @Annotation - * @Target("ALL") - */ - class Direction - { - /** - * @Enum({"NORTH", "SOUTH", "EAST", "WEST"}) - */ - public $value; - } - -Annotation usage: - -.. code-block:: php - - /** @Direction("NORTH") */ - public $direction; // Valid value - - /** @Direction("NORTHEAST") */ - public $direction; // Invalid value, throws an AnnotationException - - -Constants ---------- - -The use of constants and class constants is available on the annotations -parser. - -The following usages are allowed: - -.. code-block:: php - - namespace MyCompany\Entity; - - use MyCompany\Annotations\Foo; - use MyCompany\Annotations\Bar; - use MyCompany\Entity\SomeClass; - - /** - * @Foo(PHP_EOL) - * @Bar(Bar::FOO) - * @Foo({SomeClass::FOO, SomeClass::BAR}) - * @Bar({SomeClass::FOO_KEY = SomeClass::BAR_VALUE}) - */ - class User - { - } - - -Be careful with constants and the cache ! - -.. note:: - - The cached reader will not re-evaluate each time an annotation is - loaded from cache. When a constant is changed the cache must be - cleaned. - - -Usage ------ - -Using the library API is simple. Using the annotations described in the -previous section, you can now annotate other classes with your -annotations: - -.. code-block:: php - - namespace MyCompany\Entity; - - use MyCompany\Annotations\Foo; - use MyCompany\Annotations\Bar; - - /** - * @Foo(bar="foo") - * @Bar(foo="bar") - */ - class User - { - } - -Now we can write a script to get the annotations above: - -.. code-block:: php - - $reflClass = new ReflectionClass('MyCompany\Entity\User'); - $classAnnotations = $reader->getClassAnnotations($reflClass); - - foreach ($classAnnotations AS $annot) { - if ($annot instanceof \MyCompany\Annotations\Foo) { - echo $annot->bar; // prints "foo"; - } else if ($annot instanceof \MyCompany\Annotations\Bar) { - echo $annot->foo; // prints "bar"; - } - } - -You have a complete API for retrieving annotation class instances from a -class, property or method docblock: - - -Reader API -~~~~~~~~~~ - -Access all annotations of a class -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getClassAnnotations(\ReflectionClass $class); - -Access one annotation of a class -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getClassAnnotation(\ReflectionClass $class, $annotationName); - -Access all annotations of a method -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getMethodAnnotations(\ReflectionMethod $method); - -Access one annotation of a method -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getMethodAnnotation(\ReflectionMethod $method, $annotationName); - -Access all annotations of a property -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getPropertyAnnotations(\ReflectionProperty $property); - -Access one annotation of a property -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getPropertyAnnotation(\ReflectionProperty $property, $annotationName); - -Access all annotations of a function -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getFunctionAnnotations(\ReflectionFunction $property); - -Access one annotation of a function -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -.. code-block:: php - - public function getFunctionAnnotation(\ReflectionFunction $property, $annotationName); diff --git a/vendor/doctrine/annotations/docs/en/index.rst b/vendor/doctrine/annotations/docs/en/index.rst deleted file mode 100644 index 95476c31..00000000 --- a/vendor/doctrine/annotations/docs/en/index.rst +++ /dev/null @@ -1,101 +0,0 @@ -Introduction -============ - -Doctrine Annotations allows to implement custom annotation -functionality for PHP classes and functions. - -.. code-block:: php - - class Foo - { - /** - * @MyAnnotation(myProperty="value") - */ - private $bar; - } - -Annotations aren't implemented in PHP itself which is why this component -offers a way to use the PHP doc-blocks as a place for the well known -annotation syntax using the ``@`` char. - -Annotations in Doctrine are used for the ORM configuration to build the -class mapping, but it can be used in other projects for other purposes -too. - -Installation -============ - -You can install the Annotation component with composer: - -.. code-block:: - -   $ composer require doctrine/annotations - -Create an annotation class -========================== - -An annotation class is a representation of the later used annotation -configuration in classes. The annotation class of the previous example -looks like this: - -.. code-block:: php - - /** - * @Annotation - */ - final class MyAnnotation - { - public $myProperty; - } - -The annotation class is declared as an annotation by ``@Annotation``. - -:ref:`Read more about custom annotations. ` - -Reading annotations -=================== - -The access to the annotations happens by reflection of the class or function -containing them. There are multiple reader-classes implementing the -``Doctrine\Common\Annotations\Reader`` interface, that can access the -annotations of a class. A common one is -``Doctrine\Common\Annotations\AnnotationReader``: - -.. code-block:: php - - use Doctrine\Common\Annotations\AnnotationReader; - use Doctrine\Common\Annotations\AnnotationRegistry; - - // Deprecated and will be removed in 2.0 but currently needed - AnnotationRegistry::registerLoader('class_exists'); - - $reflectionClass = new ReflectionClass(Foo::class); - $property = $reflectionClass->getProperty('bar'); - - $reader = new AnnotationReader(); - $myAnnotation = $reader->getPropertyAnnotation( - $property, - MyAnnotation::class - ); - - echo $myAnnotation->myProperty; // result: "value" - -Note that ``AnnotationRegistry::registerLoader('class_exists')`` only works -if you already have an autoloader configured (i.e. composer autoloader). -Otherwise, :ref:`please take a look to the other annotation autoload mechanisms `. - -A reader has multiple methods to access the annotations of a class or -function. - -:ref:`Read more about handling annotations. ` - -IDE Support ------------ - -Some IDEs already provide support for annotations: - -- Eclipse via the `Symfony2 Plugin `_ -- PhpStorm via the `PHP Annotations Plugin `_ or the `Symfony Plugin `_ - -.. _Read more about handling annotations.: annotations -.. _Read more about custom annotations.: custom diff --git a/vendor/doctrine/annotations/docs/en/sidebar.rst b/vendor/doctrine/annotations/docs/en/sidebar.rst deleted file mode 100644 index 6f5d13c4..00000000 --- a/vendor/doctrine/annotations/docs/en/sidebar.rst +++ /dev/null @@ -1,6 +0,0 @@ -.. toctree:: - :depth: 3 - - index - annotations - custom diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php deleted file mode 100644 index 750270e4..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php +++ /dev/null @@ -1,59 +0,0 @@ - $data Key-value for properties to be defined in this class. - */ - final public function __construct(array $data) - { - foreach ($data as $key => $value) { - $this->$key = $value; - } - } - - /** - * Error handler for unknown property accessor in Annotation class. - * - * @param string $name Unknown property name. - * - * @throws BadMethodCallException - */ - public function __get($name) - { - throw new BadMethodCallException( - sprintf("Unknown property '%s' on annotation '%s'.", $name, static::class) - ); - } - - /** - * Error handler for unknown property mutator in Annotation class. - * - * @param string $name Unknown property name. - * @param mixed $value Property value. - * - * @throws BadMethodCallException - */ - public function __set($name, $value) - { - throw new BadMethodCallException( - sprintf("Unknown property '%s' on annotation '%s'.", $name, static::class) - ); - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php deleted file mode 100644 index b1f85140..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php +++ /dev/null @@ -1,21 +0,0 @@ - */ - public $value; -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php deleted file mode 100644 index 35d6410b..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php +++ /dev/null @@ -1,69 +0,0 @@ - */ - public $value; - - /** - * Literal target declaration. - * - * @var mixed[] - */ - public $literal; - - /** - * @throws InvalidArgumentException - * - * @phpstan-param array{literal?: mixed[], value: list} $values - */ - public function __construct(array $values) - { - if (! isset($values['literal'])) { - $values['literal'] = []; - } - - foreach ($values['value'] as $var) { - if (! is_scalar($var)) { - throw new InvalidArgumentException(sprintf( - '@Enum supports only scalar values "%s" given.', - is_object($var) ? get_class($var) : gettype($var) - )); - } - } - - foreach ($values['literal'] as $key => $var) { - if (! in_array($key, $values['value'])) { - throw new InvalidArgumentException(sprintf( - 'Undefined enumerator value "%s" for literal "%s".', - $key, - $var - )); - } - } - - $this->value = $values['value']; - $this->literal = $values['literal']; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php deleted file mode 100644 index ae60f7d5..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php +++ /dev/null @@ -1,43 +0,0 @@ - */ - public $names; - - /** - * @throws RuntimeException - * - * @phpstan-param array{value: string|list} $values - */ - public function __construct(array $values) - { - if (is_string($values['value'])) { - $values['value'] = [$values['value']]; - } - - if (! is_array($values['value'])) { - throw new RuntimeException(sprintf( - '@IgnoreAnnotation expects either a string name, or an array of strings, but got %s.', - json_encode($values['value']) - )); - } - - $this->names = $values['value']; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/NamedArgumentConstructor.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/NamedArgumentConstructor.php deleted file mode 100644 index 16906010..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/NamedArgumentConstructor.php +++ /dev/null @@ -1,13 +0,0 @@ - */ - private static $map = [ - 'ALL' => self::TARGET_ALL, - 'CLASS' => self::TARGET_CLASS, - 'METHOD' => self::TARGET_METHOD, - 'PROPERTY' => self::TARGET_PROPERTY, - 'FUNCTION' => self::TARGET_FUNCTION, - 'ANNOTATION' => self::TARGET_ANNOTATION, - ]; - - /** @phpstan-var list */ - public $value; - - /** - * Targets as bitmask. - * - * @var int - */ - public $targets; - - /** - * Literal target declaration. - * - * @var string - */ - public $literal; - - /** - * @throws InvalidArgumentException - * - * @phpstan-param array{value?: string|list} $values - */ - public function __construct(array $values) - { - if (! isset($values['value'])) { - $values['value'] = null; - } - - if (is_string($values['value'])) { - $values['value'] = [$values['value']]; - } - - if (! is_array($values['value'])) { - throw new InvalidArgumentException( - sprintf( - '@Target expects either a string value, or an array of strings, "%s" given.', - is_object($values['value']) ? get_class($values['value']) : gettype($values['value']) - ) - ); - } - - $bitmask = 0; - foreach ($values['value'] as $literal) { - if (! isset(self::$map[$literal])) { - throw new InvalidArgumentException( - sprintf( - 'Invalid Target "%s". Available targets: [%s]', - $literal, - implode(', ', array_keys(self::$map)) - ) - ); - } - - $bitmask |= self::$map[$literal]; - } - - $this->targets = $bitmask; - $this->value = $values['value']; - $this->literal = implode(', ', $this->value); - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php deleted file mode 100644 index b1ea64e6..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php +++ /dev/null @@ -1,171 +0,0 @@ - $available - */ - public static function enumeratorError($attributeName, $annotationName, $context, $available, $given) - { - return new self(sprintf( - '[Enum Error] Attribute "%s" of @%s declared on %s accepts only [%s], but got %s.', - $attributeName, - $annotationName, - $context, - implode(', ', $available), - is_object($given) ? get_class($given) : $given - )); - } - - /** - * @return AnnotationException - */ - public static function optimizerPlusSaveComments() - { - return new self( - 'You have to enable opcache.save_comments=1 or zend_optimizerplus.save_comments=1.' - ); - } - - /** - * @return AnnotationException - */ - public static function optimizerPlusLoadComments() - { - return new self( - 'You have to enable opcache.load_comments=1 or zend_optimizerplus.load_comments=1.' - ); - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php deleted file mode 100644 index 1f538ee5..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php +++ /dev/null @@ -1,389 +0,0 @@ - - */ - private static $globalImports = [ - 'ignoreannotation' => Annotation\IgnoreAnnotation::class, - ]; - - /** - * A list with annotations that are not causing exceptions when not resolved to an annotation class. - * - * The names are case sensitive. - * - * @var array - */ - private static $globalIgnoredNames = ImplicitlyIgnoredAnnotationNames::LIST; - - /** - * A list with annotations that are not causing exceptions when not resolved to an annotation class. - * - * The names are case sensitive. - * - * @var array - */ - private static $globalIgnoredNamespaces = []; - - /** - * Add a new annotation to the globally ignored annotation names with regard to exception handling. - * - * @param string $name - */ - public static function addGlobalIgnoredName($name) - { - self::$globalIgnoredNames[$name] = true; - } - - /** - * Add a new annotation to the globally ignored annotation namespaces with regard to exception handling. - * - * @param string $namespace - */ - public static function addGlobalIgnoredNamespace($namespace) - { - self::$globalIgnoredNamespaces[$namespace] = true; - } - - /** - * Annotations parser. - * - * @var DocParser - */ - private $parser; - - /** - * Annotations parser used to collect parsing metadata. - * - * @var DocParser - */ - private $preParser; - - /** - * PHP parser used to collect imports. - * - * @var PhpParser - */ - private $phpParser; - - /** - * In-memory cache mechanism to store imported annotations per class. - * - * @psalm-var array<'class'|'function', array>> - */ - private $imports = []; - - /** - * In-memory cache mechanism to store ignored annotations per class. - * - * @psalm-var array<'class'|'function', array>> - */ - private $ignoredAnnotationNames = []; - - /** - * Initializes a new AnnotationReader. - * - * @throws AnnotationException - */ - public function __construct(?DocParser $parser = null) - { - if ( - extension_loaded('Zend Optimizer+') && (ini_get('zend_optimizerplus.save_comments') === '0' || - ini_get('opcache.save_comments') === '0') - ) { - throw AnnotationException::optimizerPlusSaveComments(); - } - - if (extension_loaded('Zend OPcache') && ini_get('opcache.save_comments') === 0) { - throw AnnotationException::optimizerPlusSaveComments(); - } - - // Make sure that the IgnoreAnnotation annotation is loaded - class_exists(IgnoreAnnotation::class); - - $this->parser = $parser ?: new DocParser(); - - $this->preParser = new DocParser(); - - $this->preParser->setImports(self::$globalImports); - $this->preParser->setIgnoreNotImportedAnnotations(true); - $this->preParser->setIgnoredAnnotationNames(self::$globalIgnoredNames); - - $this->phpParser = new PhpParser(); - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - $this->parser->setTarget(Target::TARGET_CLASS); - $this->parser->setImports($this->getImports($class)); - $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); - $this->parser->setIgnoredAnnotationNamespaces(self::$globalIgnoredNamespaces); - - return $this->parser->parse($class->getDocComment(), 'class ' . $class->getName()); - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName) - { - $annotations = $this->getClassAnnotations($class); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - $class = $property->getDeclaringClass(); - $context = 'property ' . $class->getName() . '::$' . $property->getName(); - - $this->parser->setTarget(Target::TARGET_PROPERTY); - $this->parser->setImports($this->getPropertyImports($property)); - $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); - $this->parser->setIgnoredAnnotationNamespaces(self::$globalIgnoredNamespaces); - - return $this->parser->parse($property->getDocComment(), $context); - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) - { - $annotations = $this->getPropertyAnnotations($property); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - $class = $method->getDeclaringClass(); - $context = 'method ' . $class->getName() . '::' . $method->getName() . '()'; - - $this->parser->setTarget(Target::TARGET_METHOD); - $this->parser->setImports($this->getMethodImports($method)); - $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); - $this->parser->setIgnoredAnnotationNamespaces(self::$globalIgnoredNamespaces); - - return $this->parser->parse($method->getDocComment(), $context); - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName) - { - $annotations = $this->getMethodAnnotations($method); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * Gets the annotations applied to a function. - * - * @phpstan-return list An array of Annotations. - */ - public function getFunctionAnnotations(ReflectionFunction $function): array - { - $context = 'function ' . $function->getName(); - - $this->parser->setTarget(Target::TARGET_FUNCTION); - $this->parser->setImports($this->getImports($function)); - $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($function)); - $this->parser->setIgnoredAnnotationNamespaces(self::$globalIgnoredNamespaces); - - return $this->parser->parse($function->getDocComment(), $context); - } - - /** - * Gets a function annotation. - * - * @return object|null The Annotation or NULL, if the requested annotation does not exist. - */ - public function getFunctionAnnotation(ReflectionFunction $function, string $annotationName) - { - $annotations = $this->getFunctionAnnotations($function); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * Returns the ignored annotations for the given class or function. - * - * @param ReflectionClass|ReflectionFunction $reflection - * - * @return array - */ - private function getIgnoredAnnotationNames($reflection): array - { - $type = $reflection instanceof ReflectionClass ? 'class' : 'function'; - $name = $reflection->getName(); - - if (isset($this->ignoredAnnotationNames[$type][$name])) { - return $this->ignoredAnnotationNames[$type][$name]; - } - - $this->collectParsingMetadata($reflection); - - return $this->ignoredAnnotationNames[$type][$name]; - } - - /** - * Retrieves imports for a class or a function. - * - * @param ReflectionClass|ReflectionFunction $reflection - * - * @return array - */ - private function getImports($reflection): array - { - $type = $reflection instanceof ReflectionClass ? 'class' : 'function'; - $name = $reflection->getName(); - - if (isset($this->imports[$type][$name])) { - return $this->imports[$type][$name]; - } - - $this->collectParsingMetadata($reflection); - - return $this->imports[$type][$name]; - } - - /** - * Retrieves imports for methods. - * - * @return array - */ - private function getMethodImports(ReflectionMethod $method) - { - $class = $method->getDeclaringClass(); - $classImports = $this->getImports($class); - - $traitImports = []; - - foreach ($class->getTraits() as $trait) { - if ( - ! $trait->hasMethod($method->getName()) - || $trait->getFileName() !== $method->getFileName() - ) { - continue; - } - - $traitImports = array_merge($traitImports, $this->phpParser->parseUseStatements($trait)); - } - - return array_merge($classImports, $traitImports); - } - - /** - * Retrieves imports for properties. - * - * @return array - */ - private function getPropertyImports(ReflectionProperty $property) - { - $class = $property->getDeclaringClass(); - $classImports = $this->getImports($class); - - $traitImports = []; - - foreach ($class->getTraits() as $trait) { - if (! $trait->hasProperty($property->getName())) { - continue; - } - - $traitImports = array_merge($traitImports, $this->phpParser->parseUseStatements($trait)); - } - - return array_merge($classImports, $traitImports); - } - - /** - * Collects parsing metadata for a given class or function. - * - * @param ReflectionClass|ReflectionFunction $reflection - */ - private function collectParsingMetadata($reflection): void - { - $type = $reflection instanceof ReflectionClass ? 'class' : 'function'; - $name = $reflection->getName(); - - $ignoredAnnotationNames = self::$globalIgnoredNames; - $annotations = $this->preParser->parse($reflection->getDocComment(), $type . ' ' . $name); - - foreach ($annotations as $annotation) { - if (! ($annotation instanceof IgnoreAnnotation)) { - continue; - } - - foreach ($annotation->names as $annot) { - $ignoredAnnotationNames[$annot] = true; - } - } - - $this->imports[$type][$name] = array_merge( - self::$globalImports, - $this->phpParser->parseUseStatements($reflection), - [ - '__NAMESPACE__' => $reflection->getNamespaceName(), - 'self' => $name, - ] - ); - - $this->ignoredAnnotationNames[$type][$name] = $ignoredAnnotationNames; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php deleted file mode 100644 index 259d497d..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php +++ /dev/null @@ -1,190 +0,0 @@ -|null $dirs - */ - public static function registerAutoloadNamespace(string $namespace, $dirs = null): void - { - self::$autoloadNamespaces[$namespace] = $dirs; - } - - /** - * Registers multiple namespaces. - * - * Loading of this namespaces will be done with a PSR-0 namespace loading algorithm. - * - * @deprecated This method is deprecated and will be removed in - * doctrine/annotations 2.0. Annotations will be autoloaded in 2.0. - * - * @param string[][]|string[]|null[] $namespaces indexed by namespace name - */ - public static function registerAutoloadNamespaces(array $namespaces): void - { - self::$autoloadNamespaces = array_merge(self::$autoloadNamespaces, $namespaces); - } - - /** - * Registers an autoloading callable for annotations, much like spl_autoload_register(). - * - * NOTE: These class loaders HAVE to be silent when a class was not found! - * IMPORTANT: Loaders have to return true if they loaded a class that could contain the searched annotation class. - * - * @deprecated This method is deprecated and will be removed in - * doctrine/annotations 2.0. Annotations will be autoloaded in 2.0. - */ - public static function registerLoader(callable $callable): void - { - // Reset our static cache now that we have a new loader to work with - self::$failedToAutoload = []; - self::$loaders[] = $callable; - } - - /** - * Registers an autoloading callable for annotations, if it is not already registered - * - * @deprecated This method is deprecated and will be removed in - * doctrine/annotations 2.0. Annotations will be autoloaded in 2.0. - */ - public static function registerUniqueLoader(callable $callable): void - { - if (in_array($callable, self::$loaders, true)) { - return; - } - - self::registerLoader($callable); - } - - /** - * Autoloads an annotation class silently. - */ - public static function loadAnnotationClass(string $class): bool - { - if (class_exists($class, false)) { - return true; - } - - if (array_key_exists($class, self::$failedToAutoload)) { - return false; - } - - foreach (self::$autoloadNamespaces as $namespace => $dirs) { - if (strpos($class, $namespace) !== 0) { - continue; - } - - $file = str_replace('\\', DIRECTORY_SEPARATOR, $class) . '.php'; - - if ($dirs === null) { - $path = stream_resolve_include_path($file); - if ($path) { - require $path; - - return true; - } - } else { - foreach ((array) $dirs as $dir) { - if (is_file($dir . DIRECTORY_SEPARATOR . $file)) { - require $dir . DIRECTORY_SEPARATOR . $file; - - return true; - } - } - } - } - - foreach (self::$loaders as $loader) { - if ($loader($class) === true) { - return true; - } - } - - if ( - self::$loaders === [] && - self::$autoloadNamespaces === [] && - self::$registerFileUsed === false && - class_exists($class) - ) { - return true; - } - - self::$failedToAutoload[$class] = null; - - return false; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php deleted file mode 100644 index c036b2da..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php +++ /dev/null @@ -1,268 +0,0 @@ -> */ - private $loadedAnnotations = []; - - /** @var int[] */ - private $loadedFilemtimes = []; - - /** - * @param bool $debug - */ - public function __construct(Reader $reader, Cache $cache, $debug = false) - { - $this->delegate = $reader; - $this->cache = $cache; - $this->debug = (bool) $debug; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - $cacheKey = $class->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class); - if ($annots === false) { - $annots = $this->delegate->getClassAnnotations($class); - $this->saveToCache($cacheKey, $annots); - } - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName) - { - foreach ($this->getClassAnnotations($class) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - $class = $property->getDeclaringClass(); - $cacheKey = $class->getName() . '$' . $property->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class); - if ($annots === false) { - $annots = $this->delegate->getPropertyAnnotations($property); - $this->saveToCache($cacheKey, $annots); - } - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) - { - foreach ($this->getPropertyAnnotations($property) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - $class = $method->getDeclaringClass(); - $cacheKey = $class->getName() . '#' . $method->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class); - if ($annots === false) { - $annots = $this->delegate->getMethodAnnotations($method); - $this->saveToCache($cacheKey, $annots); - } - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName) - { - foreach ($this->getMethodAnnotations($method) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * Clears loaded annotations. - * - * @return void - */ - public function clearLoadedAnnotations() - { - $this->loadedAnnotations = []; - $this->loadedFilemtimes = []; - } - - /** - * Fetches a value from the cache. - * - * @param string $cacheKey The cache key. - * - * @return mixed The cached value or false when the value is not in cache. - */ - private function fetchFromCache($cacheKey, ReflectionClass $class) - { - $data = $this->cache->fetch($cacheKey); - if ($data !== false) { - if (! $this->debug || $this->isCacheFresh($cacheKey, $class)) { - return $data; - } - } - - return false; - } - - /** - * Saves a value to the cache. - * - * @param string $cacheKey The cache key. - * @param mixed $value The value. - * - * @return void - */ - private function saveToCache($cacheKey, $value) - { - $this->cache->save($cacheKey, $value); - if (! $this->debug) { - return; - } - - $this->cache->save('[C]' . $cacheKey, time()); - } - - /** - * Checks if the cache is fresh. - * - * @param string $cacheKey - * - * @return bool - */ - private function isCacheFresh($cacheKey, ReflectionClass $class) - { - $lastModification = $this->getLastModification($class); - if ($lastModification === 0) { - return true; - } - - return $this->cache->fetch('[C]' . $cacheKey) >= $lastModification; - } - - /** - * Returns the time the class was last modified, testing traits and parents - */ - private function getLastModification(ReflectionClass $class): int - { - $filename = $class->getFileName(); - - if (isset($this->loadedFilemtimes[$filename])) { - return $this->loadedFilemtimes[$filename]; - } - - $parent = $class->getParentClass(); - - $lastModification = max(array_merge( - [$filename ? filemtime($filename) : 0], - array_map(function (ReflectionClass $reflectionTrait): int { - return $this->getTraitLastModificationTime($reflectionTrait); - }, $class->getTraits()), - array_map(function (ReflectionClass $class): int { - return $this->getLastModification($class); - }, $class->getInterfaces()), - $parent ? [$this->getLastModification($parent)] : [] - )); - - assert($lastModification !== false); - - return $this->loadedFilemtimes[$filename] = $lastModification; - } - - private function getTraitLastModificationTime(ReflectionClass $reflectionTrait): int - { - $fileName = $reflectionTrait->getFileName(); - - if (isset($this->loadedFilemtimes[$fileName])) { - return $this->loadedFilemtimes[$fileName]; - } - - $lastModificationTime = max(array_merge( - [$fileName ? filemtime($fileName) : 0], - array_map(function (ReflectionClass $reflectionTrait): int { - return $this->getTraitLastModificationTime($reflectionTrait); - }, $reflectionTrait->getTraits()) - )); - - assert($lastModificationTime !== false); - - return $this->loadedFilemtimes[$fileName] = $lastModificationTime; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php deleted file mode 100644 index f6567c51..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php +++ /dev/null @@ -1,129 +0,0 @@ -= 100 - public const T_IDENTIFIER = 100; - public const T_AT = 101; - public const T_CLOSE_CURLY_BRACES = 102; - public const T_CLOSE_PARENTHESIS = 103; - public const T_COMMA = 104; - public const T_EQUALS = 105; - public const T_FALSE = 106; - public const T_NAMESPACE_SEPARATOR = 107; - public const T_OPEN_CURLY_BRACES = 108; - public const T_OPEN_PARENTHESIS = 109; - public const T_TRUE = 110; - public const T_NULL = 111; - public const T_COLON = 112; - public const T_MINUS = 113; - - /** @var array */ - protected $noCase = [ - '@' => self::T_AT, - ',' => self::T_COMMA, - '(' => self::T_OPEN_PARENTHESIS, - ')' => self::T_CLOSE_PARENTHESIS, - '{' => self::T_OPEN_CURLY_BRACES, - '}' => self::T_CLOSE_CURLY_BRACES, - '=' => self::T_EQUALS, - ':' => self::T_COLON, - '-' => self::T_MINUS, - '\\' => self::T_NAMESPACE_SEPARATOR, - ]; - - /** @var array */ - protected $withCase = [ - 'true' => self::T_TRUE, - 'false' => self::T_FALSE, - 'null' => self::T_NULL, - ]; - - /** - * Whether the next token starts immediately, or if there were - * non-captured symbols before that - */ - public function nextTokenIsAdjacent(): bool - { - return $this->token === null - || ($this->lookahead !== null - && ($this->lookahead['position'] - $this->token['position']) === strlen($this->token['value'])); - } - - /** - * {@inheritdoc} - */ - protected function getCatchablePatterns() - { - return [ - '[a-z_\\\][a-z0-9_\:\\\]*[a-z_][a-z0-9_]*', - '(?:[+-]?[0-9]+(?:[\.][0-9]+)*)(?:[eE][+-]?[0-9]+)?', - '"(?:""|[^"])*+"', - ]; - } - - /** - * {@inheritdoc} - */ - protected function getNonCatchablePatterns() - { - return ['\s+', '\*+', '(.)']; - } - - /** - * {@inheritdoc} - */ - protected function getType(&$value) - { - $type = self::T_NONE; - - if ($value[0] === '"') { - $value = str_replace('""', '"', substr($value, 1, strlen($value) - 2)); - - return self::T_STRING; - } - - if (isset($this->noCase[$value])) { - return $this->noCase[$value]; - } - - if ($value[0] === '_' || $value[0] === '\\' || ctype_alpha($value[0])) { - return self::T_IDENTIFIER; - } - - $lowerValue = strtolower($value); - - if (isset($this->withCase[$lowerValue])) { - return $this->withCase[$lowerValue]; - } - - // Checking numeric value - if (is_numeric($value)) { - return strpos($value, '.') !== false || stripos($value, 'e') !== false - ? self::T_FLOAT : self::T_INTEGER; - } - - return $type; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php deleted file mode 100644 index ae530c50..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php +++ /dev/null @@ -1,1459 +0,0 @@ - - */ - private static $classIdentifiers = [ - DocLexer::T_IDENTIFIER, - DocLexer::T_TRUE, - DocLexer::T_FALSE, - DocLexer::T_NULL, - ]; - - /** - * The lexer. - * - * @var DocLexer - */ - private $lexer; - - /** - * Current target context. - * - * @var int - */ - private $target; - - /** - * Doc parser used to collect annotation target. - * - * @var DocParser - */ - private static $metadataParser; - - /** - * Flag to control if the current annotation is nested or not. - * - * @var bool - */ - private $isNestedAnnotation = false; - - /** - * Hashmap containing all use-statements that are to be used when parsing - * the given doc block. - * - * @var array - */ - private $imports = []; - - /** - * This hashmap is used internally to cache results of class_exists() - * look-ups. - * - * @var array - */ - private $classExists = []; - - /** - * Whether annotations that have not been imported should be ignored. - * - * @var bool - */ - private $ignoreNotImportedAnnotations = false; - - /** - * An array of default namespaces if operating in simple mode. - * - * @var string[] - */ - private $namespaces = []; - - /** - * A list with annotations that are not causing exceptions when not resolved to an annotation class. - * - * The names must be the raw names as used in the class, not the fully qualified - * - * @var bool[] indexed by annotation name - */ - private $ignoredAnnotationNames = []; - - /** - * A list with annotations in namespaced format - * that are not causing exceptions when not resolved to an annotation class. - * - * @var bool[] indexed by namespace name - */ - private $ignoredAnnotationNamespaces = []; - - /** @var string */ - private $context = ''; - - /** - * Hash-map for caching annotation metadata. - * - * @var array - */ - private static $annotationMetadata = [ - Annotation\Target::class => [ - 'is_annotation' => true, - 'has_constructor' => true, - 'has_named_argument_constructor' => false, - 'properties' => [], - 'targets_literal' => 'ANNOTATION_CLASS', - 'targets' => Target::TARGET_CLASS, - 'default_property' => 'value', - 'attribute_types' => [ - 'value' => [ - 'required' => false, - 'type' => 'array', - 'array_type' => 'string', - 'value' => 'array', - ], - ], - ], - Annotation\Attribute::class => [ - 'is_annotation' => true, - 'has_constructor' => false, - 'has_named_argument_constructor' => false, - 'targets_literal' => 'ANNOTATION_ANNOTATION', - 'targets' => Target::TARGET_ANNOTATION, - 'default_property' => 'name', - 'properties' => [ - 'name' => 'name', - 'type' => 'type', - 'required' => 'required', - ], - 'attribute_types' => [ - 'value' => [ - 'required' => true, - 'type' => 'string', - 'value' => 'string', - ], - 'type' => [ - 'required' => true, - 'type' => 'string', - 'value' => 'string', - ], - 'required' => [ - 'required' => false, - 'type' => 'boolean', - 'value' => 'boolean', - ], - ], - ], - Annotation\Attributes::class => [ - 'is_annotation' => true, - 'has_constructor' => false, - 'has_named_argument_constructor' => false, - 'targets_literal' => 'ANNOTATION_CLASS', - 'targets' => Target::TARGET_CLASS, - 'default_property' => 'value', - 'properties' => ['value' => 'value'], - 'attribute_types' => [ - 'value' => [ - 'type' => 'array', - 'required' => true, - 'array_type' => Annotation\Attribute::class, - 'value' => 'array<' . Annotation\Attribute::class . '>', - ], - ], - ], - Annotation\Enum::class => [ - 'is_annotation' => true, - 'has_constructor' => true, - 'has_named_argument_constructor' => false, - 'targets_literal' => 'ANNOTATION_PROPERTY', - 'targets' => Target::TARGET_PROPERTY, - 'default_property' => 'value', - 'properties' => ['value' => 'value'], - 'attribute_types' => [ - 'value' => [ - 'type' => 'array', - 'required' => true, - ], - 'literal' => [ - 'type' => 'array', - 'required' => false, - ], - ], - ], - Annotation\NamedArgumentConstructor::class => [ - 'is_annotation' => true, - 'has_constructor' => false, - 'has_named_argument_constructor' => false, - 'targets_literal' => 'ANNOTATION_CLASS', - 'targets' => Target::TARGET_CLASS, - 'default_property' => null, - 'properties' => [], - 'attribute_types' => [], - ], - ]; - - /** - * Hash-map for handle types declaration. - * - * @var array - */ - private static $typeMap = [ - 'float' => 'double', - 'bool' => 'boolean', - // allow uppercase Boolean in honor of George Boole - 'Boolean' => 'boolean', - 'int' => 'integer', - ]; - - /** - * Constructs a new DocParser. - */ - public function __construct() - { - $this->lexer = new DocLexer(); - } - - /** - * Sets the annotation names that are ignored during the parsing process. - * - * The names are supposed to be the raw names as used in the class, not the - * fully qualified class names. - * - * @param bool[] $names indexed by annotation name - * - * @return void - */ - public function setIgnoredAnnotationNames(array $names) - { - $this->ignoredAnnotationNames = $names; - } - - /** - * Sets the annotation namespaces that are ignored during the parsing process. - * - * @param bool[] $ignoredAnnotationNamespaces indexed by annotation namespace name - * - * @return void - */ - public function setIgnoredAnnotationNamespaces($ignoredAnnotationNamespaces) - { - $this->ignoredAnnotationNamespaces = $ignoredAnnotationNamespaces; - } - - /** - * Sets ignore on not-imported annotations. - * - * @param bool $bool - * - * @return void - */ - public function setIgnoreNotImportedAnnotations($bool) - { - $this->ignoreNotImportedAnnotations = (bool) $bool; - } - - /** - * Sets the default namespaces. - * - * @param string $namespace - * - * @return void - * - * @throws RuntimeException - */ - public function addNamespace($namespace) - { - if ($this->imports) { - throw new RuntimeException('You must either use addNamespace(), or setImports(), but not both.'); - } - - $this->namespaces[] = $namespace; - } - - /** - * Sets the imports. - * - * @param array $imports - * - * @return void - * - * @throws RuntimeException - */ - public function setImports(array $imports) - { - if ($this->namespaces) { - throw new RuntimeException('You must either use addNamespace(), or setImports(), but not both.'); - } - - $this->imports = $imports; - } - - /** - * Sets current target context as bitmask. - * - * @param int $target - * - * @return void - */ - public function setTarget($target) - { - $this->target = $target; - } - - /** - * Parses the given docblock string for annotations. - * - * @param string $input The docblock string to parse. - * @param string $context The parsing context. - * - * @throws AnnotationException - * @throws ReflectionException - * - * @phpstan-return list Array of annotations. If no annotations are found, an empty array is returned. - */ - public function parse($input, $context = '') - { - $pos = $this->findInitialTokenPosition($input); - if ($pos === null) { - return []; - } - - $this->context = $context; - - $this->lexer->setInput(trim(substr($input, $pos), '* /')); - $this->lexer->moveNext(); - - return $this->Annotations(); - } - - /** - * Finds the first valid annotation - * - * @param string $input The docblock string to parse - */ - private function findInitialTokenPosition($input): ?int - { - $pos = 0; - - // search for first valid annotation - while (($pos = strpos($input, '@', $pos)) !== false) { - $preceding = substr($input, $pos - 1, 1); - - // if the @ is preceded by a space, a tab or * it is valid - if ($pos === 0 || $preceding === ' ' || $preceding === '*' || $preceding === "\t") { - return $pos; - } - - $pos++; - } - - return null; - } - - /** - * Attempts to match the given token with the current lookahead token. - * If they match, updates the lookahead token; otherwise raises a syntax error. - * - * @param int $token Type of token. - * - * @return bool True if tokens match; false otherwise. - * - * @throws AnnotationException - */ - private function match(int $token): bool - { - if (! $this->lexer->isNextToken($token)) { - throw $this->syntaxError($this->lexer->getLiteral($token)); - } - - return $this->lexer->moveNext(); - } - - /** - * Attempts to match the current lookahead token with any of the given tokens. - * - * If any of them matches, this method updates the lookahead token; otherwise - * a syntax error is raised. - * - * @throws AnnotationException - * - * @phpstan-param list $tokens - */ - private function matchAny(array $tokens): bool - { - if (! $this->lexer->isNextTokenAny($tokens)) { - throw $this->syntaxError(implode(' or ', array_map([$this->lexer, 'getLiteral'], $tokens))); - } - - return $this->lexer->moveNext(); - } - - /** - * Generates a new syntax error. - * - * @param string $expected Expected string. - * @param mixed[]|null $token Optional token. - */ - private function syntaxError(string $expected, ?array $token = null): AnnotationException - { - if ($token === null) { - $token = $this->lexer->lookahead; - } - - $message = sprintf('Expected %s, got ', $expected); - $message .= $this->lexer->lookahead === null - ? 'end of string' - : sprintf("'%s' at position %s", $token['value'], $token['position']); - - if (strlen($this->context)) { - $message .= ' in ' . $this->context; - } - - $message .= '.'; - - return AnnotationException::syntaxError($message); - } - - /** - * Attempts to check if a class exists or not. This never goes through the PHP autoloading mechanism - * but uses the {@link AnnotationRegistry} to load classes. - * - * @param class-string $fqcn - */ - private function classExists(string $fqcn): bool - { - if (isset($this->classExists[$fqcn])) { - return $this->classExists[$fqcn]; - } - - // first check if the class already exists, maybe loaded through another AnnotationReader - if (class_exists($fqcn, false)) { - return $this->classExists[$fqcn] = true; - } - - // final check, does this class exist? - return $this->classExists[$fqcn] = AnnotationRegistry::loadAnnotationClass($fqcn); - } - - /** - * Collects parsing metadata for a given annotation class - * - * @param class-string $name The annotation name - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function collectAnnotationMetadata(string $name): void - { - if (self::$metadataParser === null) { - self::$metadataParser = new self(); - - self::$metadataParser->setIgnoreNotImportedAnnotations(true); - self::$metadataParser->setIgnoredAnnotationNames($this->ignoredAnnotationNames); - self::$metadataParser->setImports([ - 'enum' => Enum::class, - 'target' => Target::class, - 'attribute' => Attribute::class, - 'attributes' => Attributes::class, - 'namedargumentconstructor' => NamedArgumentConstructor::class, - ]); - - // Make sure that annotations from metadata are loaded - class_exists(Enum::class); - class_exists(Target::class); - class_exists(Attribute::class); - class_exists(Attributes::class); - class_exists(NamedArgumentConstructor::class); - } - - $class = new ReflectionClass($name); - $docComment = $class->getDocComment(); - - // Sets default values for annotation metadata - $constructor = $class->getConstructor(); - $metadata = [ - 'default_property' => null, - 'has_constructor' => $constructor !== null && $constructor->getNumberOfParameters() > 0, - 'constructor_args' => [], - 'properties' => [], - 'property_types' => [], - 'attribute_types' => [], - 'targets_literal' => null, - 'targets' => Target::TARGET_ALL, - 'is_annotation' => strpos($docComment, '@Annotation') !== false, - ]; - - $metadata['has_named_argument_constructor'] = $metadata['has_constructor'] - && $class->implementsInterface(NamedArgumentConstructorAnnotation::class); - - // verify that the class is really meant to be an annotation - if ($metadata['is_annotation']) { - self::$metadataParser->setTarget(Target::TARGET_CLASS); - - foreach (self::$metadataParser->parse($docComment, 'class @' . $name) as $annotation) { - if ($annotation instanceof Target) { - $metadata['targets'] = $annotation->targets; - $metadata['targets_literal'] = $annotation->literal; - - continue; - } - - if ($annotation instanceof NamedArgumentConstructor) { - $metadata['has_named_argument_constructor'] = $metadata['has_constructor']; - if ($metadata['has_named_argument_constructor']) { - // choose the first argument as the default property - $metadata['default_property'] = $constructor->getParameters()[0]->getName(); - } - } - - if (! ($annotation instanceof Attributes)) { - continue; - } - - foreach ($annotation->value as $attribute) { - $this->collectAttributeTypeMetadata($metadata, $attribute); - } - } - - // if not has a constructor will inject values into public properties - if ($metadata['has_constructor'] === false) { - // collect all public properties - foreach ($class->getProperties(ReflectionProperty::IS_PUBLIC) as $property) { - $metadata['properties'][$property->name] = $property->name; - - $propertyComment = $property->getDocComment(); - if ($propertyComment === false) { - continue; - } - - $attribute = new Attribute(); - - $attribute->required = (strpos($propertyComment, '@Required') !== false); - $attribute->name = $property->name; - $attribute->type = (strpos($propertyComment, '@var') !== false && - preg_match('/@var\s+([^\s]+)/', $propertyComment, $matches)) - ? $matches[1] - : 'mixed'; - - $this->collectAttributeTypeMetadata($metadata, $attribute); - - // checks if the property has @Enum - if (strpos($propertyComment, '@Enum') === false) { - continue; - } - - $context = 'property ' . $class->name . '::$' . $property->name; - - self::$metadataParser->setTarget(Target::TARGET_PROPERTY); - - foreach (self::$metadataParser->parse($propertyComment, $context) as $annotation) { - if (! $annotation instanceof Enum) { - continue; - } - - $metadata['enum'][$property->name]['value'] = $annotation->value; - $metadata['enum'][$property->name]['literal'] = (! empty($annotation->literal)) - ? $annotation->literal - : $annotation->value; - } - } - - // choose the first property as default property - $metadata['default_property'] = reset($metadata['properties']); - } elseif ($metadata['has_named_argument_constructor']) { - foreach ($constructor->getParameters() as $parameter) { - $metadata['constructor_args'][$parameter->getName()] = [ - 'position' => $parameter->getPosition(), - 'default' => $parameter->isOptional() ? $parameter->getDefaultValue() : null, - ]; - } - } - } - - self::$annotationMetadata[$name] = $metadata; - } - - /** - * Collects parsing metadata for a given attribute. - * - * @param mixed[] $metadata - */ - private function collectAttributeTypeMetadata(array &$metadata, Attribute $attribute): void - { - // handle internal type declaration - $type = self::$typeMap[$attribute->type] ?? $attribute->type; - - // handle the case if the property type is mixed - if ($type === 'mixed') { - return; - } - - // Evaluate type - $pos = strpos($type, '<'); - if ($pos !== false) { - // Checks if the property has array - $arrayType = substr($type, $pos + 1, -1); - $type = 'array'; - - if (isset(self::$typeMap[$arrayType])) { - $arrayType = self::$typeMap[$arrayType]; - } - - $metadata['attribute_types'][$attribute->name]['array_type'] = $arrayType; - } else { - // Checks if the property has type[] - $pos = strrpos($type, '['); - if ($pos !== false) { - $arrayType = substr($type, 0, $pos); - $type = 'array'; - - if (isset(self::$typeMap[$arrayType])) { - $arrayType = self::$typeMap[$arrayType]; - } - - $metadata['attribute_types'][$attribute->name]['array_type'] = $arrayType; - } - } - - $metadata['attribute_types'][$attribute->name]['type'] = $type; - $metadata['attribute_types'][$attribute->name]['value'] = $attribute->type; - $metadata['attribute_types'][$attribute->name]['required'] = $attribute->required; - } - - /** - * Annotations ::= Annotation {[ "*" ]* [Annotation]}* - * - * @throws AnnotationException - * @throws ReflectionException - * - * @phpstan-return list - */ - private function Annotations(): array - { - $annotations = []; - - while ($this->lexer->lookahead !== null) { - if ($this->lexer->lookahead['type'] !== DocLexer::T_AT) { - $this->lexer->moveNext(); - continue; - } - - // make sure the @ is preceded by non-catchable pattern - if ( - $this->lexer->token !== null && - $this->lexer->lookahead['position'] === $this->lexer->token['position'] + strlen( - $this->lexer->token['value'] - ) - ) { - $this->lexer->moveNext(); - continue; - } - - // make sure the @ is followed by either a namespace separator, or - // an identifier token - $peek = $this->lexer->glimpse(); - if ( - ($peek === null) - || ($peek['type'] !== DocLexer::T_NAMESPACE_SEPARATOR && ! in_array( - $peek['type'], - self::$classIdentifiers, - true - )) - || $peek['position'] !== $this->lexer->lookahead['position'] + 1 - ) { - $this->lexer->moveNext(); - continue; - } - - $this->isNestedAnnotation = false; - $annot = $this->Annotation(); - if ($annot === false) { - continue; - } - - $annotations[] = $annot; - } - - return $annotations; - } - - /** - * Annotation ::= "@" AnnotationName MethodCall - * AnnotationName ::= QualifiedName | SimpleName - * QualifiedName ::= NameSpacePart "\" {NameSpacePart "\"}* SimpleName - * NameSpacePart ::= identifier | null | false | true - * SimpleName ::= identifier | null | false | true - * - * @return object|false False if it is not a valid annotation. - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function Annotation() - { - $this->match(DocLexer::T_AT); - - // check if we have an annotation - $name = $this->Identifier(); - - if ( - $this->lexer->isNextToken(DocLexer::T_MINUS) - && $this->lexer->nextTokenIsAdjacent() - ) { - // Annotations with dashes, such as "@foo-" or "@foo-bar", are to be discarded - return false; - } - - // only process names which are not fully qualified, yet - // fully qualified names must start with a \ - $originalName = $name; - - if ($name[0] !== '\\') { - $pos = strpos($name, '\\'); - $alias = ($pos === false) ? $name : substr($name, 0, $pos); - $found = false; - $loweredAlias = strtolower($alias); - - if ($this->namespaces) { - foreach ($this->namespaces as $namespace) { - if ($this->classExists($namespace . '\\' . $name)) { - $name = $namespace . '\\' . $name; - $found = true; - break; - } - } - } elseif (isset($this->imports[$loweredAlias])) { - $namespace = ltrim($this->imports[$loweredAlias], '\\'); - $name = ($pos !== false) - ? $namespace . substr($name, $pos) - : $namespace; - $found = $this->classExists($name); - } elseif ( - ! isset($this->ignoredAnnotationNames[$name]) - && isset($this->imports['__NAMESPACE__']) - && $this->classExists($this->imports['__NAMESPACE__'] . '\\' . $name) - ) { - $name = $this->imports['__NAMESPACE__'] . '\\' . $name; - $found = true; - } elseif (! isset($this->ignoredAnnotationNames[$name]) && $this->classExists($name)) { - $found = true; - } - - if (! $found) { - if ($this->isIgnoredAnnotation($name)) { - return false; - } - - throw AnnotationException::semanticalError(sprintf( - <<<'EXCEPTION' -The annotation "@%s" in %s was never imported. Did you maybe forget to add a "use" statement for this annotation? -EXCEPTION - , - $name, - $this->context - )); - } - } - - $name = ltrim($name, '\\'); - - if (! $this->classExists($name)) { - throw AnnotationException::semanticalError(sprintf( - 'The annotation "@%s" in %s does not exist, or could not be auto-loaded.', - $name, - $this->context - )); - } - - // at this point, $name contains the fully qualified class name of the - // annotation, and it is also guaranteed that this class exists, and - // that it is loaded - - // collects the metadata annotation only if there is not yet - if (! isset(self::$annotationMetadata[$name])) { - $this->collectAnnotationMetadata($name); - } - - // verify that the class is really meant to be an annotation and not just any ordinary class - if (self::$annotationMetadata[$name]['is_annotation'] === false) { - if ($this->isIgnoredAnnotation($originalName) || $this->isIgnoredAnnotation($name)) { - return false; - } - - throw AnnotationException::semanticalError(sprintf( - <<<'EXCEPTION' -The class "%s" is not annotated with @Annotation. -Are you sure this class can be used as annotation? -If so, then you need to add @Annotation to the _class_ doc comment of "%s". -If it is indeed no annotation, then you need to add @IgnoreAnnotation("%s") to the _class_ doc comment of %s. -EXCEPTION - , - $name, - $name, - $originalName, - $this->context - )); - } - - //if target is nested annotation - $target = $this->isNestedAnnotation ? Target::TARGET_ANNOTATION : $this->target; - - // Next will be nested - $this->isNestedAnnotation = true; - - //if annotation does not support current target - if ((self::$annotationMetadata[$name]['targets'] & $target) === 0 && $target) { - throw AnnotationException::semanticalError( - sprintf( - <<<'EXCEPTION' -Annotation @%s is not allowed to be declared on %s. You may only use this annotation on these code elements: %s. -EXCEPTION - , - $originalName, - $this->context, - self::$annotationMetadata[$name]['targets_literal'] - ) - ); - } - - $arguments = $this->MethodCall(); - $values = $this->resolvePositionalValues($arguments, $name); - - if (isset(self::$annotationMetadata[$name]['enum'])) { - // checks all declared attributes - foreach (self::$annotationMetadata[$name]['enum'] as $property => $enum) { - // checks if the attribute is a valid enumerator - if (isset($values[$property]) && ! in_array($values[$property], $enum['value'])) { - throw AnnotationException::enumeratorError( - $property, - $name, - $this->context, - $enum['literal'], - $values[$property] - ); - } - } - } - - // checks all declared attributes - foreach (self::$annotationMetadata[$name]['attribute_types'] as $property => $type) { - if ( - $property === self::$annotationMetadata[$name]['default_property'] - && ! isset($values[$property]) && isset($values['value']) - ) { - $property = 'value'; - } - - // handle a not given attribute or null value - if (! isset($values[$property])) { - if ($type['required']) { - throw AnnotationException::requiredError( - $property, - $originalName, - $this->context, - 'a(n) ' . $type['value'] - ); - } - - continue; - } - - if ($type['type'] === 'array') { - // handle the case of a single value - if (! is_array($values[$property])) { - $values[$property] = [$values[$property]]; - } - - // checks if the attribute has array type declaration, such as "array" - if (isset($type['array_type'])) { - foreach ($values[$property] as $item) { - if (gettype($item) !== $type['array_type'] && ! $item instanceof $type['array_type']) { - throw AnnotationException::attributeTypeError( - $property, - $originalName, - $this->context, - 'either a(n) ' . $type['array_type'] . ', or an array of ' . $type['array_type'] . 's', - $item - ); - } - } - } - } elseif (gettype($values[$property]) !== $type['type'] && ! $values[$property] instanceof $type['type']) { - throw AnnotationException::attributeTypeError( - $property, - $originalName, - $this->context, - 'a(n) ' . $type['value'], - $values[$property] - ); - } - } - - if (self::$annotationMetadata[$name]['has_named_argument_constructor']) { - if (PHP_VERSION_ID >= 80000) { - return new $name(...$values); - } - - $positionalValues = []; - foreach (self::$annotationMetadata[$name]['constructor_args'] as $property => $parameter) { - $positionalValues[$parameter['position']] = $parameter['default']; - } - - foreach ($values as $property => $value) { - if (! isset(self::$annotationMetadata[$name]['constructor_args'][$property])) { - throw AnnotationException::creationError(sprintf( - <<<'EXCEPTION' -The annotation @%s declared on %s does not have a property named "%s" -that can be set through its named arguments constructor. -Available named arguments: %s -EXCEPTION - , - $originalName, - $this->context, - $property, - implode(', ', array_keys(self::$annotationMetadata[$name]['constructor_args'])) - )); - } - - $positionalValues[self::$annotationMetadata[$name]['constructor_args'][$property]['position']] = $value; - } - - return new $name(...$positionalValues); - } - - // check if the annotation expects values via the constructor, - // or directly injected into public properties - if (self::$annotationMetadata[$name]['has_constructor'] === true) { - return new $name($values); - } - - $instance = new $name(); - - foreach ($values as $property => $value) { - if (! isset(self::$annotationMetadata[$name]['properties'][$property])) { - if ($property !== 'value') { - throw AnnotationException::creationError(sprintf( - <<<'EXCEPTION' -The annotation @%s declared on %s does not have a property named "%s". -Available properties: %s -EXCEPTION - , - $originalName, - $this->context, - $property, - implode(', ', self::$annotationMetadata[$name]['properties']) - )); - } - - // handle the case if the property has no annotations - $property = self::$annotationMetadata[$name]['default_property']; - if (! $property) { - throw AnnotationException::creationError(sprintf( - 'The annotation @%s declared on %s does not accept any values, but got %s.', - $originalName, - $this->context, - json_encode($values) - )); - } - } - - $instance->{$property} = $value; - } - - return $instance; - } - - /** - * MethodCall ::= ["(" [Values] ")"] - * - * @return mixed[] - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function MethodCall(): array - { - $values = []; - - if (! $this->lexer->isNextToken(DocLexer::T_OPEN_PARENTHESIS)) { - return $values; - } - - $this->match(DocLexer::T_OPEN_PARENTHESIS); - - if (! $this->lexer->isNextToken(DocLexer::T_CLOSE_PARENTHESIS)) { - $values = $this->Values(); - } - - $this->match(DocLexer::T_CLOSE_PARENTHESIS); - - return $values; - } - - /** - * Values ::= Array | Value {"," Value}* [","] - * - * @return mixed[] - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function Values(): array - { - $values = [$this->Value()]; - - while ($this->lexer->isNextToken(DocLexer::T_COMMA)) { - $this->match(DocLexer::T_COMMA); - - if ($this->lexer->isNextToken(DocLexer::T_CLOSE_PARENTHESIS)) { - break; - } - - $token = $this->lexer->lookahead; - $value = $this->Value(); - - $values[] = $value; - } - - $namedArguments = []; - $positionalArguments = []; - foreach ($values as $k => $value) { - if (is_object($value) && $value instanceof stdClass) { - $namedArguments[$value->name] = $value->value; - } else { - $positionalArguments[$k] = $value; - } - } - - return ['named_arguments' => $namedArguments, 'positional_arguments' => $positionalArguments]; - } - - /** - * Constant ::= integer | string | float | boolean - * - * @return mixed - * - * @throws AnnotationException - */ - private function Constant() - { - $identifier = $this->Identifier(); - - if (! defined($identifier) && strpos($identifier, '::') !== false && $identifier[0] !== '\\') { - [$className, $const] = explode('::', $identifier); - - $pos = strpos($className, '\\'); - $alias = ($pos === false) ? $className : substr($className, 0, $pos); - $found = false; - $loweredAlias = strtolower($alias); - - switch (true) { - case ! empty($this->namespaces): - foreach ($this->namespaces as $ns) { - if (class_exists($ns . '\\' . $className) || interface_exists($ns . '\\' . $className)) { - $className = $ns . '\\' . $className; - $found = true; - break; - } - } - - break; - - case isset($this->imports[$loweredAlias]): - $found = true; - $className = ($pos !== false) - ? $this->imports[$loweredAlias] . substr($className, $pos) - : $this->imports[$loweredAlias]; - break; - - default: - if (isset($this->imports['__NAMESPACE__'])) { - $ns = $this->imports['__NAMESPACE__']; - - if (class_exists($ns . '\\' . $className) || interface_exists($ns . '\\' . $className)) { - $className = $ns . '\\' . $className; - $found = true; - } - } - - break; - } - - if ($found) { - $identifier = $className . '::' . $const; - } - } - - /** - * Checks if identifier ends with ::class and remove the leading backslash if it exists. - */ - if ( - $this->identifierEndsWithClassConstant($identifier) && - ! $this->identifierStartsWithBackslash($identifier) - ) { - return substr($identifier, 0, $this->getClassConstantPositionInIdentifier($identifier)); - } - - if ($this->identifierEndsWithClassConstant($identifier) && $this->identifierStartsWithBackslash($identifier)) { - return substr($identifier, 1, $this->getClassConstantPositionInIdentifier($identifier) - 1); - } - - if (! defined($identifier)) { - throw AnnotationException::semanticalErrorConstants($identifier, $this->context); - } - - return constant($identifier); - } - - private function identifierStartsWithBackslash(string $identifier): bool - { - return $identifier[0] === '\\'; - } - - private function identifierEndsWithClassConstant(string $identifier): bool - { - return $this->getClassConstantPositionInIdentifier($identifier) === strlen($identifier) - strlen('::class'); - } - - /** - * @return int|false - */ - private function getClassConstantPositionInIdentifier(string $identifier) - { - return stripos($identifier, '::class'); - } - - /** - * Identifier ::= string - * - * @throws AnnotationException - */ - private function Identifier(): string - { - // check if we have an annotation - if (! $this->lexer->isNextTokenAny(self::$classIdentifiers)) { - throw $this->syntaxError('namespace separator or identifier'); - } - - $this->lexer->moveNext(); - - $className = $this->lexer->token['value']; - - while ( - $this->lexer->lookahead !== null && - $this->lexer->lookahead['position'] === ($this->lexer->token['position'] + - strlen($this->lexer->token['value'])) && - $this->lexer->isNextToken(DocLexer::T_NAMESPACE_SEPARATOR) - ) { - $this->match(DocLexer::T_NAMESPACE_SEPARATOR); - $this->matchAny(self::$classIdentifiers); - - $className .= '\\' . $this->lexer->token['value']; - } - - return $className; - } - - /** - * Value ::= PlainValue | FieldAssignment - * - * @return mixed - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function Value() - { - $peek = $this->lexer->glimpse(); - - if ($peek['type'] === DocLexer::T_EQUALS) { - return $this->FieldAssignment(); - } - - return $this->PlainValue(); - } - - /** - * PlainValue ::= integer | string | float | boolean | Array | Annotation - * - * @return mixed - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function PlainValue() - { - if ($this->lexer->isNextToken(DocLexer::T_OPEN_CURLY_BRACES)) { - return $this->Arrayx(); - } - - if ($this->lexer->isNextToken(DocLexer::T_AT)) { - return $this->Annotation(); - } - - if ($this->lexer->isNextToken(DocLexer::T_IDENTIFIER)) { - return $this->Constant(); - } - - switch ($this->lexer->lookahead['type']) { - case DocLexer::T_STRING: - $this->match(DocLexer::T_STRING); - - return $this->lexer->token['value']; - - case DocLexer::T_INTEGER: - $this->match(DocLexer::T_INTEGER); - - return (int) $this->lexer->token['value']; - - case DocLexer::T_FLOAT: - $this->match(DocLexer::T_FLOAT); - - return (float) $this->lexer->token['value']; - - case DocLexer::T_TRUE: - $this->match(DocLexer::T_TRUE); - - return true; - - case DocLexer::T_FALSE: - $this->match(DocLexer::T_FALSE); - - return false; - - case DocLexer::T_NULL: - $this->match(DocLexer::T_NULL); - - return null; - - default: - throw $this->syntaxError('PlainValue'); - } - } - - /** - * FieldAssignment ::= FieldName "=" PlainValue - * FieldName ::= identifier - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function FieldAssignment(): stdClass - { - $this->match(DocLexer::T_IDENTIFIER); - $fieldName = $this->lexer->token['value']; - - $this->match(DocLexer::T_EQUALS); - - $item = new stdClass(); - $item->name = $fieldName; - $item->value = $this->PlainValue(); - - return $item; - } - - /** - * Array ::= "{" ArrayEntry {"," ArrayEntry}* [","] "}" - * - * @return mixed[] - * - * @throws AnnotationException - * @throws ReflectionException - */ - private function Arrayx(): array - { - $array = $values = []; - - $this->match(DocLexer::T_OPEN_CURLY_BRACES); - - // If the array is empty, stop parsing and return. - if ($this->lexer->isNextToken(DocLexer::T_CLOSE_CURLY_BRACES)) { - $this->match(DocLexer::T_CLOSE_CURLY_BRACES); - - return $array; - } - - $values[] = $this->ArrayEntry(); - - while ($this->lexer->isNextToken(DocLexer::T_COMMA)) { - $this->match(DocLexer::T_COMMA); - - // optional trailing comma - if ($this->lexer->isNextToken(DocLexer::T_CLOSE_CURLY_BRACES)) { - break; - } - - $values[] = $this->ArrayEntry(); - } - - $this->match(DocLexer::T_CLOSE_CURLY_BRACES); - - foreach ($values as $value) { - [$key, $val] = $value; - - if ($key !== null) { - $array[$key] = $val; - } else { - $array[] = $val; - } - } - - return $array; - } - - /** - * ArrayEntry ::= Value | KeyValuePair - * KeyValuePair ::= Key ("=" | ":") PlainValue | Constant - * Key ::= string | integer | Constant - * - * @throws AnnotationException - * @throws ReflectionException - * - * @phpstan-return array{mixed, mixed} - */ - private function ArrayEntry(): array - { - $peek = $this->lexer->glimpse(); - - if ( - $peek['type'] === DocLexer::T_EQUALS - || $peek['type'] === DocLexer::T_COLON - ) { - if ($this->lexer->isNextToken(DocLexer::T_IDENTIFIER)) { - $key = $this->Constant(); - } else { - $this->matchAny([DocLexer::T_INTEGER, DocLexer::T_STRING]); - $key = $this->lexer->token['value']; - } - - $this->matchAny([DocLexer::T_EQUALS, DocLexer::T_COLON]); - - return [$key, $this->PlainValue()]; - } - - return [null, $this->Value()]; - } - - /** - * Checks whether the given $name matches any ignored annotation name or namespace - */ - private function isIgnoredAnnotation(string $name): bool - { - if ($this->ignoreNotImportedAnnotations || isset($this->ignoredAnnotationNames[$name])) { - return true; - } - - foreach (array_keys($this->ignoredAnnotationNamespaces) as $ignoredAnnotationNamespace) { - $ignoredAnnotationNamespace = rtrim($ignoredAnnotationNamespace, '\\') . '\\'; - - if (stripos(rtrim($name, '\\') . '\\', $ignoredAnnotationNamespace) === 0) { - return true; - } - } - - return false; - } - - /** - * Resolve positional arguments (without name) to named ones - * - * @param array $arguments - * - * @return array - */ - private function resolvePositionalValues(array $arguments, string $name): array - { - $positionalArguments = $arguments['positional_arguments'] ?? []; - $values = $arguments['named_arguments'] ?? []; - - if ( - self::$annotationMetadata[$name]['has_named_argument_constructor'] - && self::$annotationMetadata[$name]['default_property'] !== null - ) { - // We must ensure that we don't have positional arguments after named ones - $positions = array_keys($positionalArguments); - $lastPosition = null; - foreach ($positions as $position) { - if ( - ($lastPosition === null && $position !== 0) || - ($lastPosition !== null && $position !== $lastPosition + 1) - ) { - throw $this->syntaxError('Positional arguments after named arguments is not allowed'); - } - - $lastPosition = $position; - } - - foreach (self::$annotationMetadata[$name]['constructor_args'] as $property => $parameter) { - $position = $parameter['position']; - if (isset($values[$property]) || ! isset($positionalArguments[$position])) { - continue; - } - - $values[$property] = $positionalArguments[$position]; - } - } else { - if (count($positionalArguments) > 0 && ! isset($values['value'])) { - if (count($positionalArguments) === 1) { - $value = array_pop($positionalArguments); - } else { - $value = array_values($positionalArguments); - } - - $values['value'] = $value; - } - } - - return $values; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php deleted file mode 100644 index 6c6c22c3..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php +++ /dev/null @@ -1,315 +0,0 @@ -> */ - private $loadedAnnotations = []; - - /** @var array */ - private $classNameHashes = []; - - /** @var int */ - private $umask; - - /** - * @param string $cacheDir - * @param bool $debug - * @param int $umask - * - * @throws InvalidArgumentException - */ - public function __construct(Reader $reader, $cacheDir, $debug = false, $umask = 0002) - { - if (! is_int($umask)) { - throw new InvalidArgumentException(sprintf( - 'The parameter umask must be an integer, was: %s', - gettype($umask) - )); - } - - $this->reader = $reader; - $this->umask = $umask; - - if (! is_dir($cacheDir) && ! @mkdir($cacheDir, 0777 & (~$this->umask), true)) { - throw new InvalidArgumentException(sprintf( - 'The directory "%s" does not exist and could not be created.', - $cacheDir - )); - } - - $this->dir = rtrim($cacheDir, '\\/'); - $this->debug = $debug; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - if (! isset($this->classNameHashes[$class->name])) { - $this->classNameHashes[$class->name] = sha1($class->name); - } - - $key = $this->classNameHashes[$class->name]; - - if (isset($this->loadedAnnotations[$key])) { - return $this->loadedAnnotations[$key]; - } - - $path = $this->dir . '/' . strtr($key, '\\', '-') . '.cache.php'; - if (! is_file($path)) { - $annot = $this->reader->getClassAnnotations($class); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - $filename = $class->getFilename(); - if ( - $this->debug - && $filename !== false - && filemtime($path) < filemtime($filename) - ) { - @unlink($path); - - $annot = $this->reader->getClassAnnotations($class); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - return $this->loadedAnnotations[$key] = include $path; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - $class = $property->getDeclaringClass(); - if (! isset($this->classNameHashes[$class->name])) { - $this->classNameHashes[$class->name] = sha1($class->name); - } - - $key = $this->classNameHashes[$class->name] . '$' . $property->getName(); - - if (isset($this->loadedAnnotations[$key])) { - return $this->loadedAnnotations[$key]; - } - - $path = $this->dir . '/' . strtr($key, '\\', '-') . '.cache.php'; - if (! is_file($path)) { - $annot = $this->reader->getPropertyAnnotations($property); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - $filename = $class->getFilename(); - if ( - $this->debug - && $filename !== false - && filemtime($path) < filemtime($filename) - ) { - @unlink($path); - - $annot = $this->reader->getPropertyAnnotations($property); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - return $this->loadedAnnotations[$key] = include $path; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - $class = $method->getDeclaringClass(); - if (! isset($this->classNameHashes[$class->name])) { - $this->classNameHashes[$class->name] = sha1($class->name); - } - - $key = $this->classNameHashes[$class->name] . '#' . $method->getName(); - - if (isset($this->loadedAnnotations[$key])) { - return $this->loadedAnnotations[$key]; - } - - $path = $this->dir . '/' . strtr($key, '\\', '-') . '.cache.php'; - if (! is_file($path)) { - $annot = $this->reader->getMethodAnnotations($method); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - $filename = $class->getFilename(); - if ( - $this->debug - && $filename !== false - && filemtime($path) < filemtime($filename) - ) { - @unlink($path); - - $annot = $this->reader->getMethodAnnotations($method); - $this->saveCacheFile($path, $annot); - - return $this->loadedAnnotations[$key] = $annot; - } - - return $this->loadedAnnotations[$key] = include $path; - } - - /** - * Saves the cache file. - * - * @param string $path - * @param mixed $data - * - * @return void - */ - private function saveCacheFile($path, $data) - { - if (! is_writable($this->dir)) { - throw new InvalidArgumentException(sprintf( - <<<'EXCEPTION' -The directory "%s" is not writable. Both the webserver and the console user need access. -You can manage access rights for multiple users with "chmod +a". -If your system does not support this, check out the acl package., -EXCEPTION - , - $this->dir - )); - } - - $tempfile = tempnam($this->dir, uniqid('', true)); - - if ($tempfile === false) { - throw new RuntimeException(sprintf('Unable to create tempfile in directory: %s', $this->dir)); - } - - @chmod($tempfile, 0666 & (~$this->umask)); - - $written = file_put_contents( - $tempfile, - 'umask)); - - if (rename($tempfile, $path) === false) { - @unlink($tempfile); - - throw new RuntimeException(sprintf('Unable to rename %s to %s', $tempfile, $path)); - } - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName) - { - $annotations = $this->getClassAnnotations($class); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName) - { - $annotations = $this->getMethodAnnotations($method); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) - { - $annotations = $this->getPropertyAnnotations($property); - - foreach ($annotations as $annotation) { - if ($annotation instanceof $annotationName) { - return $annotation; - } - } - - return null; - } - - /** - * Clears loaded annotations. - * - * @return void - */ - public function clearLoadedAnnotations() - { - $this->loadedAnnotations = []; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/ImplicitlyIgnoredAnnotationNames.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/ImplicitlyIgnoredAnnotationNames.php deleted file mode 100644 index 2efeb1d2..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/ImplicitlyIgnoredAnnotationNames.php +++ /dev/null @@ -1,177 +0,0 @@ - true, - 'Attribute' => true, - 'Attributes' => true, - /* Can we enable this? 'Enum' => true, */ - 'Required' => true, - 'Target' => true, - 'NamedArgumentConstructor' => true, - ]; - - private const WidelyUsedNonStandard = [ - 'fix' => true, - 'fixme' => true, - 'override' => true, - ]; - - private const PhpDocumentor1 = [ - 'abstract' => true, - 'access' => true, - 'code' => true, - 'deprec' => true, - 'endcode' => true, - 'exception' => true, - 'final' => true, - 'ingroup' => true, - 'inheritdoc' => true, - 'inheritDoc' => true, - 'magic' => true, - 'name' => true, - 'private' => true, - 'static' => true, - 'staticvar' => true, - 'staticVar' => true, - 'toc' => true, - 'tutorial' => true, - 'throw' => true, - ]; - - private const PhpDocumentor2 = [ - 'api' => true, - 'author' => true, - 'category' => true, - 'copyright' => true, - 'deprecated' => true, - 'example' => true, - 'filesource' => true, - 'global' => true, - 'ignore' => true, - /* Can we enable this? 'index' => true, */ - 'internal' => true, - 'license' => true, - 'link' => true, - 'method' => true, - 'package' => true, - 'param' => true, - 'property' => true, - 'property-read' => true, - 'property-write' => true, - 'return' => true, - 'see' => true, - 'since' => true, - 'source' => true, - 'subpackage' => true, - 'throws' => true, - 'todo' => true, - 'TODO' => true, - 'usedby' => true, - 'uses' => true, - 'var' => true, - 'version' => true, - ]; - - private const PHPUnit = [ - 'author' => true, - 'after' => true, - 'afterClass' => true, - 'backupGlobals' => true, - 'backupStaticAttributes' => true, - 'before' => true, - 'beforeClass' => true, - 'codeCoverageIgnore' => true, - 'codeCoverageIgnoreStart' => true, - 'codeCoverageIgnoreEnd' => true, - 'covers' => true, - 'coversDefaultClass' => true, - 'coversNothing' => true, - 'dataProvider' => true, - 'depends' => true, - 'doesNotPerformAssertions' => true, - 'expectedException' => true, - 'expectedExceptionCode' => true, - 'expectedExceptionMessage' => true, - 'expectedExceptionMessageRegExp' => true, - 'group' => true, - 'large' => true, - 'medium' => true, - 'preserveGlobalState' => true, - 'requires' => true, - 'runTestsInSeparateProcesses' => true, - 'runInSeparateProcess' => true, - 'small' => true, - 'test' => true, - 'testdox' => true, - 'testWith' => true, - 'ticket' => true, - 'uses' => true, - ]; - - private const PhpCheckStyle = ['SuppressWarnings' => true]; - - private const PhpStorm = ['noinspection' => true]; - - private const PEAR = ['package_version' => true]; - - private const PlainUML = [ - 'startuml' => true, - 'enduml' => true, - ]; - - private const Symfony = ['experimental' => true]; - - private const PhpCodeSniffer = [ - 'codingStandardsIgnoreStart' => true, - 'codingStandardsIgnoreEnd' => true, - ]; - - private const SlevomatCodingStandard = ['phpcsSuppress' => true]; - - private const Phan = ['suppress' => true]; - - private const Rector = ['noRector' => true]; - - private const StaticAnalysis = [ - // PHPStan, Psalm - 'extends' => true, - 'implements' => true, - 'template' => true, - 'use' => true, - - // Psalm - 'pure' => true, - 'immutable' => true, - ]; - - public const LIST = self::Reserved - + self::WidelyUsedNonStandard - + self::PhpDocumentor1 - + self::PhpDocumentor2 - + self::PHPUnit - + self::PhpCheckStyle - + self::PhpStorm - + self::PEAR - + self::PlainUML - + self::Symfony - + self::SlevomatCodingStandard - + self::PhpCodeSniffer - + self::Phan - + self::Rector - + self::StaticAnalysis; - - private function __construct() - { - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php deleted file mode 100644 index 42e70765..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php +++ /dev/null @@ -1,100 +0,0 @@ -delegate = $reader; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - $annotations = []; - foreach ($this->delegate->getClassAnnotations($class) as $annot) { - $annotations[get_class($annot)] = $annot; - } - - return $annotations; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotation) - { - return $this->delegate->getClassAnnotation($class, $annotation); - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - $annotations = []; - foreach ($this->delegate->getMethodAnnotations($method) as $annot) { - $annotations[get_class($annot)] = $annot; - } - - return $annotations; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotation) - { - return $this->delegate->getMethodAnnotation($method, $annotation); - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - $annotations = []; - foreach ($this->delegate->getPropertyAnnotations($property) as $annot) { - $annotations[get_class($annot)] = $annot; - } - - return $annotations; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotation) - { - return $this->delegate->getPropertyAnnotation($property, $annotation); - } - - /** - * Proxies all methods to the delegate. - * - * @param string $method - * @param mixed[] $args - * - * @return mixed - */ - public function __call($method, $args) - { - return call_user_func_array([$this->delegate, $method], $args); - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/NamedArgumentConstructorAnnotation.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/NamedArgumentConstructorAnnotation.php deleted file mode 100644 index 8af224c0..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/NamedArgumentConstructorAnnotation.php +++ /dev/null @@ -1,14 +0,0 @@ -ReflectionClass object. - * - * @return array A list with use statements in the form (Alias => FQN). - */ - public function parseClass(ReflectionClass $class) - { - return $this->parseUseStatements($class); - } - - /** - * Parse a class or function for use statements. - * - * @param ReflectionClass|ReflectionFunction $reflection - * - * @psalm-return array a list with use statements in the form (Alias => FQN). - */ - public function parseUseStatements($reflection): array - { - if (method_exists($reflection, 'getUseStatements')) { - return $reflection->getUseStatements(); - } - - $filename = $reflection->getFileName(); - - if ($filename === false) { - return []; - } - - $content = $this->getFileContent($filename, $reflection->getStartLine()); - - if ($content === null) { - return []; - } - - $namespace = preg_quote($reflection->getNamespaceName()); - $content = preg_replace('/^.*?(\bnamespace\s+' . $namespace . '\s*[;{].*)$/s', '\\1', $content); - $tokenizer = new TokenParser('parseUseStatements($reflection->getNamespaceName()); - } - - /** - * Gets the content of the file right up to the given line number. - * - * @param string $filename The name of the file to load. - * @param int $lineNumber The number of lines to read from file. - * - * @return string|null The content of the file or null if the file does not exist. - */ - private function getFileContent($filename, $lineNumber) - { - if (! is_file($filename)) { - return null; - } - - $content = ''; - $lineCnt = 0; - $file = new SplFileObject($filename); - while (! $file->eof()) { - if ($lineCnt++ === $lineNumber) { - break; - } - - $content .= $file->fgets(); - } - - return $content; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PsrCachedReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PsrCachedReader.php deleted file mode 100644 index a7099d57..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PsrCachedReader.php +++ /dev/null @@ -1,232 +0,0 @@ -> */ - private $loadedAnnotations = []; - - /** @var int[] */ - private $loadedFilemtimes = []; - - public function __construct(Reader $reader, CacheItemPoolInterface $cache, bool $debug = false) - { - $this->delegate = $reader; - $this->cache = $cache; - $this->debug = (bool) $debug; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - $cacheKey = $class->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class, 'getClassAnnotations', $class); - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName) - { - foreach ($this->getClassAnnotations($class) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - $class = $property->getDeclaringClass(); - $cacheKey = $class->getName() . '$' . $property->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class, 'getPropertyAnnotations', $property); - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) - { - foreach ($this->getPropertyAnnotations($property) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - $class = $method->getDeclaringClass(); - $cacheKey = $class->getName() . '#' . $method->getName(); - - if (isset($this->loadedAnnotations[$cacheKey])) { - return $this->loadedAnnotations[$cacheKey]; - } - - $annots = $this->fetchFromCache($cacheKey, $class, 'getMethodAnnotations', $method); - - return $this->loadedAnnotations[$cacheKey] = $annots; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName) - { - foreach ($this->getMethodAnnotations($method) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - public function clearLoadedAnnotations(): void - { - $this->loadedAnnotations = []; - $this->loadedFilemtimes = []; - } - - /** @return mixed[] */ - private function fetchFromCache( - string $cacheKey, - ReflectionClass $class, - string $method, - Reflector $reflector - ): array { - $cacheKey = rawurlencode($cacheKey); - - $item = $this->cache->getItem($cacheKey); - if (($this->debug && ! $this->refresh($cacheKey, $class)) || ! $item->isHit()) { - $this->cache->save($item->set($this->delegate->{$method}($reflector))); - } - - return $item->get(); - } - - /** - * Used in debug mode to check if the cache is fresh. - * - * @return bool Returns true if the cache was fresh, or false if the class - * being read was modified since writing to the cache. - */ - private function refresh(string $cacheKey, ReflectionClass $class): bool - { - $lastModification = $this->getLastModification($class); - if ($lastModification === 0) { - return true; - } - - $item = $this->cache->getItem('[C]' . $cacheKey); - if ($item->isHit() && $item->get() >= $lastModification) { - return true; - } - - $this->cache->save($item->set(time())); - - return false; - } - - /** - * Returns the time the class was last modified, testing traits and parents - */ - private function getLastModification(ReflectionClass $class): int - { - $filename = $class->getFileName(); - - if (isset($this->loadedFilemtimes[$filename])) { - return $this->loadedFilemtimes[$filename]; - } - - $parent = $class->getParentClass(); - - $lastModification = max(array_merge( - [$filename ? filemtime($filename) : 0], - array_map(function (ReflectionClass $reflectionTrait): int { - return $this->getTraitLastModificationTime($reflectionTrait); - }, $class->getTraits()), - array_map(function (ReflectionClass $class): int { - return $this->getLastModification($class); - }, $class->getInterfaces()), - $parent ? [$this->getLastModification($parent)] : [] - )); - - assert($lastModification !== false); - - return $this->loadedFilemtimes[$filename] = $lastModification; - } - - private function getTraitLastModificationTime(ReflectionClass $reflectionTrait): int - { - $fileName = $reflectionTrait->getFileName(); - - if (isset($this->loadedFilemtimes[$fileName])) { - return $this->loadedFilemtimes[$fileName]; - } - - $lastModificationTime = max(array_merge( - [$fileName ? filemtime($fileName) : 0], - array_map(function (ReflectionClass $reflectionTrait): int { - return $this->getTraitLastModificationTime($reflectionTrait); - }, $reflectionTrait->getTraits()) - )); - - assert($lastModificationTime !== false); - - return $this->loadedFilemtimes[$fileName] = $lastModificationTime; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php deleted file mode 100644 index 0663ffda..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php +++ /dev/null @@ -1,80 +0,0 @@ - An array of Annotations. - */ - public function getClassAnnotations(ReflectionClass $class); - - /** - * Gets a class annotation. - * - * @param ReflectionClass $class The ReflectionClass of the class from which - * the class annotations should be read. - * @param class-string $annotationName The name of the annotation. - * - * @return T|null The Annotation or NULL, if the requested annotation does not exist. - * - * @template T - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName); - - /** - * Gets the annotations applied to a method. - * - * @param ReflectionMethod $method The ReflectionMethod of the method from which - * the annotations should be read. - * - * @return array An array of Annotations. - */ - public function getMethodAnnotations(ReflectionMethod $method); - - /** - * Gets a method annotation. - * - * @param ReflectionMethod $method The ReflectionMethod to read the annotations from. - * @param class-string $annotationName The name of the annotation. - * - * @return T|null The Annotation or NULL, if the requested annotation does not exist. - * - * @template T - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName); - - /** - * Gets the annotations applied to a property. - * - * @param ReflectionProperty $property The ReflectionProperty of the property - * from which the annotations should be read. - * - * @return array An array of Annotations. - */ - public function getPropertyAnnotations(ReflectionProperty $property); - - /** - * Gets a property annotation. - * - * @param ReflectionProperty $property The ReflectionProperty to read the annotations from. - * @param class-string $annotationName The name of the annotation. - * - * @return T|null The Annotation or NULL, if the requested annotation does not exist. - * - * @template T - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName); -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php deleted file mode 100644 index 8a78c119..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php +++ /dev/null @@ -1,114 +0,0 @@ -parser = new DocParser(); - $this->parser->setIgnoreNotImportedAnnotations(true); - } - - /** - * Adds a namespace in which we will look for annotations. - * - * @param string $namespace - * - * @return void - */ - public function addNamespace($namespace) - { - $this->parser->addNamespace($namespace); - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotations(ReflectionClass $class) - { - return $this->parser->parse($class->getDocComment(), 'class ' . $class->getName()); - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotations(ReflectionMethod $method) - { - return $this->parser->parse( - $method->getDocComment(), - 'method ' . $method->getDeclaringClass()->name . '::' . $method->getName() . '()' - ); - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotations(ReflectionProperty $property) - { - return $this->parser->parse( - $property->getDocComment(), - 'property ' . $property->getDeclaringClass()->name . '::$' . $property->getName() - ); - } - - /** - * {@inheritDoc} - */ - public function getClassAnnotation(ReflectionClass $class, $annotationName) - { - foreach ($this->getClassAnnotations($class) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getMethodAnnotation(ReflectionMethod $method, $annotationName) - { - foreach ($this->getMethodAnnotations($method) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } - - /** - * {@inheritDoc} - */ - public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) - { - foreach ($this->getPropertyAnnotations($property) as $annot) { - if ($annot instanceof $annotationName) { - return $annot; - } - } - - return null; - } -} diff --git a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php b/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php deleted file mode 100644 index 9605fb8d..00000000 --- a/vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php +++ /dev/null @@ -1,208 +0,0 @@ - - */ - private $tokens; - - /** - * The number of tokens. - * - * @var int - */ - private $numTokens; - - /** - * The current array pointer. - * - * @var int - */ - private $pointer = 0; - - /** - * @param string $contents - */ - public function __construct($contents) - { - $this->tokens = token_get_all($contents); - - // The PHP parser sets internal compiler globals for certain things. Annoyingly, the last docblock comment it - // saw gets stored in doc_comment. When it comes to compile the next thing to be include()d this stored - // doc_comment becomes owned by the first thing the compiler sees in the file that it considers might have a - // docblock. If the first thing in the file is a class without a doc block this would cause calls to - // getDocBlock() on said class to return our long lost doc_comment. Argh. - // To workaround, cause the parser to parse an empty docblock. Sure getDocBlock() will return this, but at least - // it's harmless to us. - token_get_all("numTokens = count($this->tokens); - } - - /** - * Gets the next non whitespace and non comment token. - * - * @param bool $docCommentIsComment If TRUE then a doc comment is considered a comment and skipped. - * If FALSE then only whitespace and normal comments are skipped. - * - * @return mixed[]|string|null The token if exists, null otherwise. - */ - public function next($docCommentIsComment = true) - { - for ($i = $this->pointer; $i < $this->numTokens; $i++) { - $this->pointer++; - if ( - $this->tokens[$i][0] === T_WHITESPACE || - $this->tokens[$i][0] === T_COMMENT || - ($docCommentIsComment && $this->tokens[$i][0] === T_DOC_COMMENT) - ) { - continue; - } - - return $this->tokens[$i]; - } - - return null; - } - - /** - * Parses a single use statement. - * - * @return array A list with all found class names for a use statement. - */ - public function parseUseStatement() - { - $groupRoot = ''; - $class = ''; - $alias = ''; - $statements = []; - $explicitAlias = false; - while (($token = $this->next())) { - if (! $explicitAlias && $token[0] === T_STRING) { - $class .= $token[1]; - $alias = $token[1]; - } elseif ($explicitAlias && $token[0] === T_STRING) { - $alias = $token[1]; - } elseif ( - PHP_VERSION_ID >= 80000 && - ($token[0] === T_NAME_QUALIFIED || $token[0] === T_NAME_FULLY_QUALIFIED) - ) { - $class .= $token[1]; - - $classSplit = explode('\\', $token[1]); - $alias = $classSplit[count($classSplit) - 1]; - } elseif ($token[0] === T_NS_SEPARATOR) { - $class .= '\\'; - $alias = ''; - } elseif ($token[0] === T_AS) { - $explicitAlias = true; - $alias = ''; - } elseif ($token === ',') { - $statements[strtolower($alias)] = $groupRoot . $class; - $class = ''; - $alias = ''; - $explicitAlias = false; - } elseif ($token === ';') { - $statements[strtolower($alias)] = $groupRoot . $class; - break; - } elseif ($token === '{') { - $groupRoot = $class; - $class = ''; - } elseif ($token === '}') { - continue; - } else { - break; - } - } - - return $statements; - } - - /** - * Gets all use statements. - * - * @param string $namespaceName The namespace name of the reflected class. - * - * @return array A list with all found use statements. - */ - public function parseUseStatements($namespaceName) - { - $statements = []; - while (($token = $this->next())) { - if ($token[0] === T_USE) { - $statements = array_merge($statements, $this->parseUseStatement()); - continue; - } - - if ($token[0] !== T_NAMESPACE || $this->parseNamespace() !== $namespaceName) { - continue; - } - - // Get fresh array for new namespace. This is to prevent the parser to collect the use statements - // for a previous namespace with the same name. This is the case if a namespace is defined twice - // or if a namespace with the same name is commented out. - $statements = []; - } - - return $statements; - } - - /** - * Gets the namespace. - * - * @return string The found namespace. - */ - public function parseNamespace() - { - $name = ''; - while ( - ($token = $this->next()) && ($token[0] === T_STRING || $token[0] === T_NS_SEPARATOR || ( - PHP_VERSION_ID >= 80000 && - ($token[0] === T_NAME_QUALIFIED || $token[0] === T_NAME_FULLY_QUALIFIED) - )) - ) { - $name .= $token[1]; - } - - return $name; - } - - /** - * Gets the class name. - * - * @return string The found class name. - */ - public function parseClass() - { - // Namespaces and class names are tokenized the same: T_STRINGs - // separated by T_NS_SEPARATOR so we can use one function to provide - // both. - return $this->parseNamespace(); - } -} diff --git a/vendor/doctrine/lexer/LICENSE b/vendor/doctrine/lexer/LICENSE deleted file mode 100644 index e8fdec4a..00000000 --- a/vendor/doctrine/lexer/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2006-2018 Doctrine Project - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/vendor/doctrine/lexer/README.md b/vendor/doctrine/lexer/README.md deleted file mode 100644 index e1b419a6..00000000 --- a/vendor/doctrine/lexer/README.md +++ /dev/null @@ -1,9 +0,0 @@ -# Doctrine Lexer - -Build Status: [![Build Status](https://travis-ci.org/doctrine/lexer.svg?branch=master)](https://travis-ci.org/doctrine/lexer) - -Base library for a lexer that can be used in Top-Down, Recursive Descent Parsers. - -This lexer is used in Doctrine Annotations and in Doctrine ORM (DQL). - -https://www.doctrine-project.org/projects/lexer.html diff --git a/vendor/doctrine/lexer/composer.json b/vendor/doctrine/lexer/composer.json deleted file mode 100644 index 3432bae4..00000000 --- a/vendor/doctrine/lexer/composer.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "name": "doctrine/lexer", - "type": "library", - "description": "PHP Doctrine Lexer parser library that can be used in Top-Down, Recursive Descent Parsers.", - "keywords": [ - "php", - "parser", - "lexer", - "annotations", - "docblock" - ], - "homepage": "https://www.doctrine-project.org/projects/lexer.html", - "license": "MIT", - "authors": [ - {"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"}, - {"name": "Roman Borschel", "email": "roman@code-factory.org"}, - {"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"} - ], - "require": { - "php": "^7.2 || ^8.0" - }, - "require-dev": { - "doctrine/coding-standard": "^6.0", - "phpstan/phpstan": "^0.11.8", - "phpunit/phpunit": "^8.2" - }, - "autoload": { - "psr-4": { "Doctrine\\Common\\Lexer\\": "lib/Doctrine/Common/Lexer" } - }, - "autoload-dev": { - "psr-4": { "Doctrine\\Tests\\": "tests/Doctrine" } - }, - "extra": { - "branch-alias": { - "dev-master": "1.2.x-dev" - } - }, - "config": { - "sort-packages": true - } -} diff --git a/vendor/doctrine/lexer/lib/Doctrine/Common/Lexer/AbstractLexer.php b/vendor/doctrine/lexer/lib/Doctrine/Common/Lexer/AbstractLexer.php deleted file mode 100644 index 385643a4..00000000 --- a/vendor/doctrine/lexer/lib/Doctrine/Common/Lexer/AbstractLexer.php +++ /dev/null @@ -1,328 +0,0 @@ -input = $input; - $this->tokens = []; - - $this->reset(); - $this->scan($input); - } - - /** - * Resets the lexer. - * - * @return void - */ - public function reset() - { - $this->lookahead = null; - $this->token = null; - $this->peek = 0; - $this->position = 0; - } - - /** - * Resets the peek pointer to 0. - * - * @return void - */ - public function resetPeek() - { - $this->peek = 0; - } - - /** - * Resets the lexer position on the input to the given position. - * - * @param int $position Position to place the lexical scanner. - * - * @return void - */ - public function resetPosition($position = 0) - { - $this->position = $position; - } - - /** - * Retrieve the original lexer's input until a given position. - * - * @param int $position - * - * @return string - */ - public function getInputUntilPosition($position) - { - return substr($this->input, 0, $position); - } - - /** - * Checks whether a given token matches the current lookahead. - * - * @param int|string $token - * - * @return bool - */ - public function isNextToken($token) - { - return $this->lookahead !== null && $this->lookahead['type'] === $token; - } - - /** - * Checks whether any of the given tokens matches the current lookahead. - * - * @param array $tokens - * - * @return bool - */ - public function isNextTokenAny(array $tokens) - { - return $this->lookahead !== null && in_array($this->lookahead['type'], $tokens, true); - } - - /** - * Moves to the next token in the input string. - * - * @return bool - */ - public function moveNext() - { - $this->peek = 0; - $this->token = $this->lookahead; - $this->lookahead = isset($this->tokens[$this->position]) - ? $this->tokens[$this->position++] : null; - - return $this->lookahead !== null; - } - - /** - * Tells the lexer to skip input tokens until it sees a token with the given value. - * - * @param string $type The token type to skip until. - * - * @return void - */ - public function skipUntil($type) - { - while ($this->lookahead !== null && $this->lookahead['type'] !== $type) { - $this->moveNext(); - } - } - - /** - * Checks if given value is identical to the given token. - * - * @param mixed $value - * @param int|string $token - * - * @return bool - */ - public function isA($value, $token) - { - return $this->getType($value) === $token; - } - - /** - * Moves the lookahead token forward. - * - * @return array|null The next token or NULL if there are no more tokens ahead. - */ - public function peek() - { - if (isset($this->tokens[$this->position + $this->peek])) { - return $this->tokens[$this->position + $this->peek++]; - } - - return null; - } - - /** - * Peeks at the next token, returns it and immediately resets the peek. - * - * @return array|null The next token or NULL if there are no more tokens ahead. - */ - public function glimpse() - { - $peek = $this->peek(); - $this->peek = 0; - - return $peek; - } - - /** - * Scans the input string for tokens. - * - * @param string $input A query string. - * - * @return void - */ - protected function scan($input) - { - if (! isset($this->regex)) { - $this->regex = sprintf( - '/(%s)|%s/%s', - implode(')|(', $this->getCatchablePatterns()), - implode('|', $this->getNonCatchablePatterns()), - $this->getModifiers() - ); - } - - $flags = PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_OFFSET_CAPTURE; - $matches = preg_split($this->regex, $input, -1, $flags); - - if ($matches === false) { - // Work around https://bugs.php.net/78122 - $matches = [[$input, 0]]; - } - - foreach ($matches as $match) { - // Must remain before 'value' assignment since it can change content - $type = $this->getType($match[0]); - - $this->tokens[] = [ - 'value' => $match[0], - 'type' => $type, - 'position' => $match[1], - ]; - } - } - - /** - * Gets the literal for a given token. - * - * @param int|string $token - * - * @return int|string - */ - public function getLiteral($token) - { - $className = static::class; - $reflClass = new ReflectionClass($className); - $constants = $reflClass->getConstants(); - - foreach ($constants as $name => $value) { - if ($value === $token) { - return $className . '::' . $name; - } - } - - return $token; - } - - /** - * Regex modifiers - * - * @return string - */ - protected function getModifiers() - { - return 'iu'; - } - - /** - * Lexical catchable patterns. - * - * @return array - */ - abstract protected function getCatchablePatterns(); - - /** - * Lexical non-catchable patterns. - * - * @return array - */ - abstract protected function getNonCatchablePatterns(); - - /** - * Retrieve token type. Also processes the token value if necessary. - * - * @param string $value - * - * @return int|string|null - */ - abstract protected function getType(&$value); -} diff --git a/vendor/fpdf/FAQ.htm b/vendor/fpdf/FAQ.htm deleted file mode 100644 index 72094a96..00000000 --- a/vendor/fpdf/FAQ.htm +++ /dev/null @@ -1,341 +0,0 @@ - - - - -FAQ - - - - -

FAQ

- - -
    -
  • -

    1. What's exactly the license of FPDF? Are there any usage restrictions?

    -FPDF is released under a permissive license: there is no usage restriction. You may embed it -freely in your application (commercial or not), with or without modifications. -
  • - -
  • -

    2. When I try to create a PDF, a lot of weird characters show on the screen. Why?

    -These "weird" characters are in fact the actual content of your PDF. This behavior is a bug of -IE6. When it first receives an HTML page, then a PDF from the same URL, it displays it directly -without launching Acrobat. This happens frequently during the development stage: on the least -script error, an HTML page is sent, and after correction, the PDF arrives. -
    -To solve the problem, simply quit and restart IE. You can also go to another URL and come -back. -
    -To avoid this kind of inconvenience during the development, you can generate the PDF directly -to a file and open it through the explorer. -
  • - -
  • -

    3. I try to generate a PDF and IE displays a blank page. What happens?

    -First of all, check that you send nothing to the browser after the PDF (not even a space or a -carriage return). You can put an exit statement just after the call to the Output() method to -be sure. If it still doesn't work, it means you're a victim of the "blank page syndrome". IE -used in conjunction with the Acrobat plug-in suffers from many bugs. To avoid these problems -in a reliable manner, two main techniques exist: -
    -
    -- Disable the plug-in and use Acrobat as a helper application. To do this, launch Acrobat, go -to the Edit menu, Preferences, Internet, and uncheck "Display PDF in browser". Then, the next -time you load a PDF in IE, it displays the dialog box "Open it" or "Save it to disk". Uncheck -the option "Always ask before opening this type of file" and choose Open. From now on, PDF files -will open automatically in an external Acrobat window. -
    -The drawback of the method is that you need to alter the client configuration, which you can do -in an intranet environment but not for the Internet. -
    -
    -- Use a redirection technique. It consists in generating the PDF in a temporary file on the server -and redirect the client to it. For example, at the end of the script, you can put the following: -
    -
    //Determine a temporary file name in the current directory
    -$file = basename(tempnam('.', 'tmp'));
    -rename($file, $file.'.pdf');
    -$file .= '.pdf';
    -//Save PDF to file
    -$pdf->Output($file, 'F');
    -//Redirect
    -header('Location: '.$file);
    -
    -This method turns the dynamic PDF into a static one and avoids all troubles. But you have to do -some cleaning in order to delete the temporary files. For example: -
    -
    function CleanFiles($dir)
    -{
    -    //Delete temporary files
    -    $t = time();
    -    $h = opendir($dir);
    -    while($file=readdir($h))
    -    {
    -        if(substr($file,0,3)=='tmp' && substr($file,-4)=='.pdf')
    -        {
    -            $path = $dir.'/'.$file;
    -            if($t-filemtime($path)>3600)
    -                @unlink($path);
    -        }
    -    }
    -    closedir($h);
    -}
    -
    -This function deletes all files of the form tmp*.pdf older than an hour in the specified -directory. You may call it where you want, for example in the script which generates the PDF. -
  • - -
  • -

    4. I can't make line breaks work. I put \n in the string printed by MultiCell but it doesn't work.

    -You have to enclose your string with double quotes, not single ones. -
  • - -
  • -

    5. I try to display a variable in the Header method but nothing prints.

    -You have to use the global keyword to access global variables, for example: -
    -
    function Header()
    -{
    -    global $title;
    -
    -    $this->SetFont('Arial', 'B', 15);
    -    $this->Cell(0, 10, $title, 1, 1, 'C');
    -}
    -
    -$title = 'My title';
    -
    -Alternatively, you can use an object property: -
    -
    function Header()
    -{
    -    $this->SetFont('Arial', 'B', 15);
    -    $this->Cell(0, 10, $this->title, 1, 1, 'C');
    -}
    -
    -$pdf->title = 'My title';
    -
    -
  • - -
  • -

    6. I defined the Header and Footer methods in my PDF class but nothing appears.

    -You have to create an object from the PDF class, not FPDF: -
    -
    $pdf = new PDF();
    -
    -
  • - -
  • -

    7. Accented characters are replaced by some strange characters like é.

    -Don't use UTF-8 encoding. Standard FPDF fonts use ISO-8859-1 or Windows-1252. -It is possible to perform a conversion to ISO-8859-1 with utf8_decode(): -
    -
    $str = utf8_decode($str);
    -
    -But some characters such as Euro won't be translated correctly. If the iconv extension is available, the -right way to do it is the following: -
    -
    $str = iconv('UTF-8', 'windows-1252', $str);
    -
    -
  • - -
  • -

    8. I try to display the Euro symbol but it doesn't work.

    -The standard fonts have the Euro character at position 128. You can define a constant like this -for convenience: -
    -
    define('EURO', chr(128));
    -
    -
  • - -
  • -

    9. I get the following error when I try to generate a PDF: Some data has already been output, can't send PDF file

    -You must send nothing to the browser except the PDF itself: no HTML, no space, no carriage return. A common -case is having extra blank at the end of an included script file.
    -If you can't figure out where the problem comes from, this other message appearing just before can help you:
    -
    -Warning: Cannot modify header information - headers already sent by (output started at script.php:X)
    -
    -It means that script.php outputs something at line X. Go to this line and fix it. -In case the message doesn't show, first check that you didn't disable warnings, then add this at the very -beginning of your script: -
    -
    ob_end_clean();
    -
    -If you still don't see it, disable zlib.output_compression in your php.ini and it should appear. -
  • - -
  • -

    10. I draw a frame with very precise dimensions, but when printed I notice some differences.

    -To respect dimensions, select "None" for the Page Scaling setting instead of "Shrink to Printable Area" in the print dialog box. -
  • - -
  • -

    11. I'd like to use the whole surface of the page, but when printed I always have some margins. How can I get rid of them?

    -Printers have physical margins (different depending on the models); it is therefore impossible to remove -them and print on the whole surface of the paper. -
  • - -
  • -

    12. How can I put a background in my PDF?

    -For a picture, call Image() in the Header() method, before any other output. To set a background color, use Rect(). -
  • - -
  • -

    13. How can I set a specific header or footer on the first page?

    -Simply test the page number: -
    -
    function Header()
    -{
    -    if($this->PageNo()==1)
    -    {
    -        //First page
    -        ...
    -    }
    -    else
    -    {
    -        //Other pages
    -        ...
    -    }
    -}
    -
    -
  • - -
  • -

    14. I'd like to use extensions provided by different scripts. How can I combine them?

    -Use an inheritance chain. If you have two classes, say A in a.php: -
    -
    require('fpdf.php');
    -
    -class A extends FPDF
    -{
    -...
    -}
    -
    -and B in b.php: -
    -
    require('fpdf.php');
    -
    -class B extends FPDF
    -{
    -...
    -}
    -
    -then make B extend A: -
    -
    require('a.php');
    -
    -class B extends A
    -{
    -...
    -}
    -
    -and make your own class extend B: -
    -
    require('b.php');
    -
    -class PDF extends B
    -{
    -...
    -}
    -
    -$pdf = new PDF();
    -
    -
  • - -
  • -

    15. How can I send the PDF by email?

    -As any other file, but an easy way is to use PHPMailer and -its in-memory attachment: -
    -
    $mail = new PHPMailer();
    -...
    -$doc = $pdf->Output('', 'S');
    -$mail->AddStringAttachment($doc, 'doc.pdf', 'base64', 'application/pdf');
    -$mail->Send();
    -
    -
  • - -
  • -

    16. What's the limit of the file sizes I can generate with FPDF?

    -There is no particular limit. There are some constraints, however: -
    -
    -- The maximum memory size allocated to PHP scripts is usually 8MB. For very big documents, -especially with images, this limit may be reached (the file being built into memory). The -parameter is configured in the php.ini file. -
    -
    -- The maximum execution time allocated defaults to 30 seconds. This limit can of course be easily -reached. It is configured in php.ini and may be altered dynamically with set_time_limit(). -
    -
    -- Browsers generally have a 5 minute time-out. If you send the PDF directly to the browser and -reach the limit, it will be lost. It is therefore advised for very big documents to -generate them in a file, and to send some data to the browser from time to time (with a call -to flush() to force the output). When the document is finished, you can send a redirection to -it or create a link. -
    -Remark: even if the browser times out, the script may continue to run on the server. -
  • - -
  • -

    17. Can I modify a PDF with FPDF?

    -It is possible to import pages from an existing PDF document thanks to the FPDI extension:
    -
    -http://www.setasign.de/products/pdf-php-solutions/fpdi/
    -
    -You can then add some content to them. -
  • - -
  • -

    18. I'd like to make a search engine in PHP and index PDF files. Can I do it with FPDF?

    -No. But a GPL C utility does exist, pdftotext, which is able to extract the textual content from -a PDF. It is provided with the Xpdf package:
    -
    -http://www.foolabs.com/xpdf/ -
  • - -
  • -

    19. Can I convert an HTML page to PDF with FPDF?

    -Not real-world pages. But a GPL C utility does exist, htmldoc, which allows to do it and gives good results:
    -
    -http://www.htmldoc.org -
  • - -
  • -

    20. Can I concatenate PDF files with FPDF?

    -Not directly, but it is possible to use FPDI -to perform this task. Some free command-line tools also exist:
    -
    -mbtPdfAsm
    -pdftk -
  • -
- - diff --git a/vendor/fpdf/bg.png b/vendor/fpdf/bg.png deleted file mode 100644 index 0980b8fe26d4b4fcf2a607ab5d0f31ab8b9117e2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 162471 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�UmKDgJ(_;Xsk}|9Jef73lx3)<32H)b$^EMbiJruK&af zP~)FnVGdmE;kyhB40IZYGqd%sGfjyPjMuXvh{j;KIOU-cRPMU+E!*aVNP7Mb5<;DzpO^*kbXR1; zcweS#zFfd~lJipy(@lP{mVui>rGvEKV>f;o!Jr(O+U zqtQWvsuTLjY$CDmvfysQh&IX#b7%-7rpF8&+K_qYy-+3BxCv5seq5mTrhe;M%B z$EUi9czX%|pOpn&fFsMX@QW!k%JvYf%F{cbvY z_4GqLJDV{~y2hr5J@RTw&8_EmwFJh|V~jHO`O=)|Nx>guFDz_1T^<)xbGD&duk>B2 zkQH@FzY)3oDamS3Wd%t>Q7nk>{?q)2C4~9Qun^NLFf~`vc=Bc0-r4?^h z-Vz6yK*}rf?(^j-Z|9;YyCrqCO%xv~Ej~~gvZ}sI_9bhT#X4gA%Dsju1x679(15prrG47xR zFA7Y2-_OivNYqm-u)6*{TBF@{_j?Whgf09qO?G*j3Rr}Ue2Dro;*c}Y`~xS$3}|~H zm;Nchzf5n@KwBMX?jS8;FUKQM7asPQ1WrkbE|ryCu4=Gcv~2vCiu`ro0wo%)nsoOb z_8U=BR6$g?v*;Eo4G|&qeQ55-{N!~dMNy(MmpxAhq}^iG#jKW^^M$d5jQ4n?u&!x)OinlrW?15+GkN z_)fq}BhEk1_}do!cs$GCUVkSMi5eWfJOBPYHU0~YZ|BSuK`7;tyr=;_gz)n&*J}|Nt}p)yLFGiydFLHB1m|c!YM)+R{s>>KN2Cu7X(}fKe=bT)y2n+L z3964GKJpQ>SLsfHLYnvCCd`C`<+0Na!0LO}JT|qd*2^C$y5Rr&c!JPd8E|_qTyWTj zi#~a8w|7k!SLBL;l|7GzOuK*hUM&nQ$jMVK*hNHR`#1_7`yM;X!k)x6*Dj}V1~9=|(<^5Z23atWWUL`ctQATv;i7yqyIU1Fp1fMhdvrb1qjtFvr> zU?MV+HN$6i+JTU>K}_hmC+6nPgcc6!Vp-9uTeJA;TWi(Q-n?@()4Q?u^I!tylQ9O(mGK$?}$Wc0{+_C4=rT89jh{ zVs#4Y-^lQMK@ITn>*kCP5r5|MFudHY+f$m#wT_on76LCe-WIZI6j51y0-f)Uc}F$c|?7UzGE);lFu?4(HQu{ z+ypAHSia2RevnE0aK%N(zE9{473Y}*Ncra`<8P%SArhkf%=GKJ9w)t>O#TC6=epVj zKL)qI-g~(k=nBy?3B7>UZwGU49pA-`B}0lI8PRtSQX^4O8NEN7E?q+munmkK9`5)f zZ@4-d6$rxG1YrlA_UXi&^NB(4y=5$7t0qu;zw$Oy?>&jTpqf=qkxrE0iActmZ;eNz zIyX8QSGh3eJF1O8mu)E8v_G@XpDRF}Jn1`{4SZ|(`?o|C;8?}|kL`uQ>EbGnea8jP zlou9JL+Yo!u+H@c2`6?>;YAW|JOS~UD4B*HyC8HRY5XGANwMw_Ha5$>;Ul&5Q`=6y z;mwAG*+QQUE@#6T?PB@i06e5jcez`8sDtDmWwPSrIJ}hmPUR*x(eFXpMX2ISYO^Vk zY);I^F1jX(l<7l1BSwu%t!0L+l)Q+qb-kNiG1(bH2ApRux`*HiSabhDi zHK&gb1b6iv3>PHiY$MyO`{U799;g&FP<%z|IxGAV_yd;8tdu#(73KB`zRv)!R zHm(MhmbyhHsv(Zb9S&flg0K$LxZdOa8PR2ofu%&S8&+rfdcyc}K&jtBQ^mTO63d4U z(}`dU68*J<=H=dq2BEC@Yp$SV;#q2;AT#1r;yu$+TmYmp6>Dh%$CFwtO3-O0FcsT_ zjn3n`jwM5vDJ9<$q0budNK$v)vCeWg<11%l>NO@yRw|^$fC$gP2l_~O)n^NjEkQ)p z(bZEx8mL6i>b`ZyIr{!C*th^TqOBGw#;mLyy%LJl8~H-YC{5f_g6#zv>dA-Pv7Zc09VQ zj#g>-v{V>SLL4H_!voVlFLZ7uh~@1-5-h^vWOisHO(ZXA4ns@$oCgjSi+945xYq)2 zAb4S;TBOg-7|6OSVo$Fa%LmJ65fGh=M#W`f<2V7;&k{YFHi+@$;snp8AF=!7;CF@8 z@Hr^0bq^7ZR#CKW^;Cu1ZKZi6t*-kT^j?C}GQHzq(AG=98`0b1ZWH?7so^r?A$mHv zYp@VqWstuepbmnDWBTUR&%7$7skK0^N&G0j{=4ns9J0;Wg`gsM_~|jdd&#=t zt9oUM9gmeIDDw?iStqHYBhG(u`_i-aFv}Ya750`ejVqo$c#A@`rPbmpqr&` z#P95*X}dg^bFSG>g~)p5M&XdsJ*!)=$}-~o3C5MJIVqhtx#9Fp_T*s91KhKwJ2a4P z_dt`)`JRUO9q7*^m2sS?5feJrozu7bfoNmn9fI?D$WyFHh$ZbbDpC*E0Y@SGVT@?I z`o0%}*+pmRkSS?a!gZ}*{4m?P0z0dwD(H(8M)A71wC3mMxfIq9D(SeRg_^aXD>8_r z_)OWH1JR$$amzd$ImBLl%cfb96eUBebgb zc@s~%3%h`M)eW=rD6f6SBn`zY!bBRZ#}goPwuvUxDhT-8n1>)m8`^*5ZgbdpERs4q z)V$*!?qf83<$P>GC%kM!a_|B=3hJ^4skrElw`n-T0Hx)qp>i*QHrxV=EH#-#W4s^r z$j=~<+VC<70T}E9U@=l^N{8~m!Wti7{ubB>HYA> z0PIlAqsvo~BIA*k8)0KK^9wUXvSIz2_2j`3j-=%(>@;eJH z;fK{spDNnIl4?I5dF~QZA6;(SzK7!{jKMyG$G9<68_d{UXe`1A$3Io#-io$wY_yEz zq@m41dGnxSW%DdheUHULFWL1*lP*`p`Ivpn92w=H5LMXl3Abx?&<#XzciHco z`rjhqqbQLCJi@QEq$TAS5p@(Ahpz*U3{c3NTXHMmYSVXy7}jIEC|mKJ&8l&k(!0*h zA&`E?IF6DEoSB*Th}%hjnlVD2U)b3ghKwmI#HJE{vJk<_6>r5jfVJ^~8uB|%9(I7A zO=fb(Z`0ozi4=)x@1?lBy_s(&8ay@RfM^Z~X%0xr*G`4HSlfi;)b_b{h`4^cmFVoN z1;M@hFk6MT^wF&p;;`==8~)IaxZ%ZuE@JZh39hIqo1;vP>g$k>{`v%W@18A{Ui9A; zv#i$;ST0uG4k{&)$S2JXW*TPGNcnda;99fjMG|+XfVw!_z`Hg60rhTwmjw z5IGBVf!kPCuj?|)M)q|OmS%Qu0;%zle(yWX+0q4%xj9PpHuPA><&eedZFfdl$Lp|n z*A_3;RE>px26Cmhq(n@!XM@2={*;v(ff3zB?%SLWnE?7^6eK)viTs+%dk>#^moU3N z^QJf)^@s!G6z;=Wb8TSu=2b+5uDd4gW&&PXLhR^EXe?f{ZDxjDCjYum`}`wt$ihIF zSp(mOcr=k_8;e<*!XaO&J3>3roslly9_I&E?01QlBaG<&xv~9u?wpw^Pj@Dn$g)A~ zmSk-qb}EiTgzAVLFNNO~-F&i!@JM#Br5iYy9--QL|Af(u0n(3sT*(Xb(Lzp&Fv~Ea z-_Hp;^TPBx^+w1^8=2Cij_UyM5_gJ7Jpu^IB%4=-isPh00$T&{0QN#e7*OYh%~1ly zKaYRZf$pa$KEQ`_g21D!1AdMC(@DB11ElIM)<}_C1n!F=^Y;mAH~>?yS0^MTUZ#RX z{z=}oz)-DN{8TtLn?s%vJvQefh%lUP6_;N+>WrW$*jlM%xAjh27ub1liLaZpR2^j_ z^s9}-1b*X<0+)@S{d~(ak+v`J!|-oPvpP)-#88)clueaQ$=+EoH>F3)y1+F}x`Dr> zSzJB*RQZ=QQ5l3bJz1?qOZF>UH2h&GI2U#&pR#RCk8q1VvaA>z$3X>o066#hN=s{S z7&B)W>J-&q4_+9kjq>luf3*Uof42VV|BqdNv-#8iue^X!|EcRg^5TX4x31vb3ef5l zy$k*>OW17LjrZpFRH@!YUfe$kHKw{6c@Y88xbfz#ko)M=>d<-JoEQBW{@mC|T0P;O z%yEIoX*oeB$5UpY-v0>}_uo;q($oLI?*7Lp-Tw>Q`|tez0~p8%{#P+!3`#XLzXE^F z$E7|$*b3Y^I@sy4%sp8r^x^Vqijc?B$vx>Si$jTzHf3<8ya}5gf}_(_S1}xa4}3inHU{q&k4v znZ-|LkWsjcHI09Pah^s@U`83>LB&?{H$F!T)Ewi0ZfO~a;$Deu&+jhfZEhNl=?OImF43iGCWp>L8_>-vy6?U5>SKNz$+V; zhC88L=p&@s0MyuT@s?n~h_m!4_KwAG`W&l9^s+(`iAbm^prE<+{emW!r)Y6f-x< zDw?$4-rFq}VqRfGcou}ZX!l+aMun%L@HR~=Y){5Sq;v&Odv*#%goTNKI4bcYQ7*{)T~JlHO<*5afo4W_K*^8H-T#6zKHGQ zuZ3$XXkT*bs^vvs+9e4!Y~XGj?*5OW>^ddp{yUt$?n|qSIeM<5eHXyj88PpkmM~)K z&$=tRkYp}^@1K3!xlnQmBcB_>ZAK1+unGKct$oeb1*{b#X4Ba69MqPnoi|`=2v+v> zS59g|PdJtY0Z_Hd)aF%%6G_oE8qsz(Oi4y^C?BjPcMg02p^YMLi%TKuSAocp+)YzL znCK?grzYTg?QnKY39nEu_~_OGr(~w~_gx+XC>JlHuM=2iIs{R)c{B_dgZ3ESOaX*j zET=d^k^o7gEyvDWy-9e#izGyk-6sIpiZFMt#|5xU0&z}N5yhlk5c94EK<&1LJIZQ- z-&hE+@qvfvo~+y=Bw4<<745-)$?l3VWzPb(zXEoRn_e zEANdTegrTuH3G2Lp`gAG|NfPZDOe*|?z@<<1G+vJIQIN$;b!D6e;*JXI|rG6YLhN) z0$fvbI%#{Mb z99c&?T-W$02VWcuxvebO`_Yk2_6uMYzRjtbxT+jrLCSCRk+D*R3Vd)W`Q{j^6TtME z31b$+9hq1p^+Mi???>?1wmk9P$Hk3@(1KKpAW zV{{{YZR+B8p|cgC?C6y9oT3Ny4=C?DRCs>UEjuwSw~Exqy{?f^<_u{lUN3ZwAuZ|? zBFny(mha94Iq%BWx~uYpG{OZmjLc__ebX!Utlc?hFZT2ScOl$na4dtJG; zmt?V=y(9U>Q_7{MDv9v!*$lk50;58L1|41>KebsF+20+(j(lv^Hx^e!=+>?` zXgXZGOW;Se_Ld97)WT8gWRHg+6( z3ES<>%C{8P7@$%R$cE|YrP`j%9&zAv0CuT_+`ZowL|1bU@YzSeT=E(T{R&8ZeU&+h zaHk40yQ9L;th$tR4>(krZp^ByR@G#l8z}tVq`bA3^)Z2VYyjTl-s91fd;a`>(&TYR z;?l=oU3>7Lga=0Ta^yKM?BbyVKCtMOpu*gnpgIz20&Un*m(H?VUG(ZxHCAw!dp?zUlMaJiLmaf;3mv zAkS2NHlPjJ+Ip#&DV7L{s|eF;zcryM1o4=ORF%`4%uxi zGkd+Kf>L2VwUh3cn&b^W*zd-bpxP(zZy=h@$I{yduRE}e zbdM?2vr1W>CrPJQ?e}@Su7oc7tfCve#@!lDG(JPl=$|k*(w$riVErs@yJCa(Pz@P! zuy}<`eK^?%IaEkB%eh^3z##>Oy1>MD+#Y-rLA+`haxXO?`Z^YNbBZOam zyaYC4sBiV}I)CHc%8LAEurfliP21PKM4}`y;IM35_EzpQa2;}jM9KApOYhoz)0Eqz zAkLhbgDb9gf%9;a$W&D1Xb|p}tc?F-Jfj zPZx1y-a%HDp$3y>>w}Hl)(P}t1QJdBvH$K`tqEfl$x%@zly`$;du zQ8E{5bhc{{qWp+XADvDs+%1u>lED{c0g6mBbghXwvuq~&l5%#pG4$KY7SM93)qB4&1DEt=>29QtVXRAgCP z(b3FIQ|4ZlD2>W-s(K=jxDv6-y+K(Pv)#!k2wmIQ-H|kv=`kL`STa}!+=kF)pleo^ z4go)bYv9@Q4gUzK`N4vFsT+P>d+m+o4+}~E*OoVZjn4|C+f7ID4lPSx~Ip=i4YqmJ#Z4YbgBfMWJ)H0936doqlIJmXjlKR?6&z>QthEypr z9m4jBEqb9RL1m<~P$o?O7%}&>iHCA>{e~q*#oIT5G-3_k_!-w7bK63$ zJ`X4#dIa0kMHT@|I1cjQDN_wNa&P@xtlFWn@XFGt@xABgFTEFgv1Z2c+-QdG7QAX} zS|68m^x+=c%{Ucw-Y`E^c3?j7_I5?A3+ghx=5J;#0wM%0jFI^B=oO z4n3;E-6gZ#o6pWGTDp?HJb(KcxKx|PE!<(lJU+MUBAPPwFp~yS4V)NZkLOsvm6)B@ zK|YEyCF-x0$C?+%`6i@OgEp(|{$k!#eSUo&%$KK90AKI+F+;*My!Mdx zXBo%#xK_kaK%`)Mn!BMko{L$Q zitX>41ixQPKNqc?H6SMG>38_zKm6kz-x%hXZVspVMQ+e zMGJYWE^i^}m}CItDVAVE%U<)vTa z+@M?-C16G5RK^bTSY#tb{0Wq-x^q5l)=mBEr-3&FEK-OaDI(g+meIgBRnn6J3X#5E z;m}1oe2v`#`vIq!cy>(veRoCgul9{j&;DXa3deHYq#KLr6~h7z5=0+GqDen@cUcE- zpO2@Fdx6fQpF(EAZ%*PyClajK9Rgx%A{dW5&-?H^VsTA3)}VzV)0~u|eYm~ThVPQU zVp)AweqfW7`>Nbqbi%tmV(vZwjUCVVAeXah?vsHr_yKlQAx~ACR31Y=>;CCh;_48$ z?ZIcsq!*(8QAzd74@_f^-#@up4Ym#ZJ*RRh%PAH>eR?fEME%qPK%jTnDFdsS(~)I~ zf6yRL_svnhe?iC80I=-4@P9(X;>eKLUufCi;2AG0_TPhP(PYa1M*bI=_OIk=R}r3? zR8)}f{{*J~6~4-M#&=kG6elcUjrCBtz-JcmEQ!|F<|!H0 z8se?Ny}`X6Q}}@9Z6{|85RF zKHM8BN)SN%a&A_qT3tHBX(&0;RQa4%wp9=ZSjeuahouI$Qc{5(uZ%<@t(jn9))4`@ z74fW6mQSt`&LFKRS}Cv4%ghSm&TyKV(w*+z@mEMrCqAQXa$|yp)1TpdF7ekmUR>Cb zs;a|=N9L0aR(N zFr^xRA|MU80g|ewMkE}Vr8krS*&B2rJaY023&1qY5U?Z6kja@bx90UX?Ne!1zv)hw z4a_dzIjci^_}!w^)&vb27`=Or8q5g$YJ(+<<;C&(WBnJeh0`;_#D@tgfZ5@yZ3XWb z0UuG!M*s1ZZE0-?i&$YBJ>X6?)Kj<3UPJOg>-V*)TKEh%O%$0QFG1LYfX_NKlC1`V%l&}?M z1KI-7GMnZFGo$&#gAq{>JvnYHp%3|o1goNVJOX6)j0g=9&k9?*Ue_Klrj@cyujneh z%wIk6kw`;wkQ5v@>Gt$9uj`LF^sL>>I0UPFWa zuN7%e>05wL$t>=|XM8t2hQ3#*!g}o(Ft^^I6L%_|{S|4!YN*6|pt&N_49y19B(irSP-+%|PnY)DAo0U{g@OHXxU zLXbPcN#N~DU+us(xMcRGPi0GZa7K{%dq+i~T>-EJr3(-apjNPXsr(0@b?}Ff^K!Fb zdmu*u4(EW`z_&?{7PeUp-m1tqYxGWcA2eS8+|CHoP4ZqA(#&QZaf5|k-MUanGn;m- zq)MJ|+G9`O zB=~-a6u!=_!-x5g!nPt$WGhu0W!p5*#JjD0PbRM=^ivjbo$*NI-&rU;u^kAWe=UrWy;d9TOMUv*P8 zko8~$QXoVKh(F9}*8?cwEn1(9z?)jw8W{#nN~G2~6qVwavAv*-pR+sYud2;)wN)$# zZ!#%e-MZWta7ROJYyj^#d0L)N> z(Dtobxyye66D}*nrTd;eUVfj1u3-VZmDhN7+@#=bVk*nhecD-IDuvPcedd{XcyFPi zt;CGOJ=7^vM=fOS!+GZ+0>BPHf%+6e;@hqr*Y?5fJ)CpI zcfWp+8`PD<129*s4vrUqFTN^(d)xR_Y+QhWSa1kd)81m1b`kSVITCrh5Ju%E1}}|x z4WOAkohSaV*Q+)Pw%n2~w1M>#7qH)wO-VlWa9UgU`GV6Zf`;k-TbC}RiE>{t8*-Gm z3)9KHmV`PrZ_0=no_pfeSJE45eTA){%1=IfHrK3s7slOv2X)G;0o#?&9L*dQohB#(KC6|h}_FP z8n-HD!R=AYdVVoikRvp40*l+!#^KTYN-YJww@K(=w4<(s{V?;p;na7zb4MWrPjg`J zd=eu)eg~sl7au$TkHNqHWb(F6uR23#feOq^(pTI_+8o;ch~u9m`{9M)oHM*xb#B4e zR-^5xHMsW;XTePz=!Nl6bIw`0@8GF}%UpFh*@mQa*?cQ<5IUbOCv0c4OpZsfaMD&B zMb-)cTP{`2qEA!00KzrCBDhP6&ig8coXAIh?Xw+V4L+lTD~0YvA%kP~_yOA9P4*0y z9|8iEu@M>i|mOcvYvnzR5lTPY{<-@eOsOBl!d z`KNw2F%w4I?B$xZKe5rL0$b0Ty8P(+I8osHdA)4?IGeawH8{`XM`l;`LZYo7tllE> zE7d7#hxFlo?pYwwwCF!9VrE|<`pH|lT?>7@ca+v74*kCO#ENV?F3!wUF>yf$k7FsB z))+m!2m=^B<@ydq5IqAOIyO5YeP_j{iB1h!k9LiwvY4EbPDZRM%T6u<_61D)8`rMA zF5vF#fYf{{W<&IQ_DB^LmK4v>fC0I@&`Ys3g2b}PN3WUN`^;B;xeEig%K_JZeMn`> zi%-Uw;ZeUj*>dNCgQbxl`tde8o7wGxxV#-M$3Y!~xSBcqTC(3>BgU)oQ$0sbN2 z85Biu(+3mY$+Tcf{R$nXJ_9^Cx2&_S;qcWxo2@KzF#}OF^l(M8*-0Y|Bimex1i>Vh zcp0D}uQ|KelnKE+{h%1Hd6*#JdH~P8iJ=87rWc;~$x}wG-Ly&^Fs z%@f*6=~L>Hj}DHX1-`}j?br(C+BfE-joeh|3M6|k0Tm(Q0Xg4l|H2|bMc97?UY*A_ z>+VdRi*!YZ;{8otBdnh6oU*=T?|BKz@x_GTgg*=^TB{TYj_A&bq|`}h)o-P^ zogGQbX<4k3J$>C-*OZSHd^|rz0kx>Wk@)5r+rF3qTPt$VzBPR=yTNY3`FL}lmC%`0 ztM^N#5FcTVn~OJF4blNzV_g)5v+7#Z72ACO)N?w3_QC-J*JFe`cs^b6%I9ZP_0CZ?h~KKZD7yNMXeBPPalbaz}L zlt&FoE(J68VRZXo-Aa_;)JQg@HhbLZGtEx`)Z~mBgjE<``J-D>n8xICN zrCDS*HsUXrgyx$BPG(@mAA_pZ=>@K;@jnd@o-Ut`+*xGUJ_@IQBS@Ge~pS}B6&TNwNkfZ7dL%>_Tr#h=%HEhZ%n5}!* z%HJyO=IVe94w@PcMRJf;$r=EsZhvbD^qRO1S;sC-_%fIGLM5*Apz$ICm;9RNkF3Ds z-I0Bot-Oi=+T_;X$6~G)Yro>o0C53lo;T-kg~THXxEg8LqZ;ixx3JYR zyWL928zYFb0=)Z@9v0d0j6X^kHOBG*Hw(a2!#8O`SvpOjNG<$Q3tETVr2l5D7mE>( zPF*zrQINE)7*3uWMrU+8xXa6q;aFsgWY~M~c&Y>4BwGilX5W2daOm2q$tIbQb+Kyp`5@DMV%N~XUvm9n7?Jv}bz@#RmisurC68>&FSwbu#lr)<@j3 z^I*Ce?j7=u7;l!XV;L7_Uw|(t272jd(Yvp6J9-o^{IXMeruxLPp$}d5UZ<+D60U}- zBqU)!m0dsVG*_8a`sKpX1n#SXgDXYGv@es5MLg~bKo=kzxn2~xl`kYKb@*8#-&mnL zrF8~`M8lHG$+|S7l!4<~#F^#C#;!Qvb`Os<60jY@3 z@_z>C{kutR8(YN+8||u%s?du9F2$|UfRai{{!CU}K5fCQqq54OX9?zmQ#HXWI_tS94N2l_^z0(hoPvZpucX;JH`ybY*!6LNoI zT$(76&h)r53qLtW4!#)0Z~Q76*i^q{8PEf1hNLtE%eiTa^{Hy%pu`4;lXu#jxdA;56K4I2AsfPIk z6fR9nqjWqGk}j=9>_cNy8Kmq2QSg3jQrThoFrDDNue z-c4=`Fm6e>h|qxd)}H0X*;Ant;vLJPu1z0!6`y2u)?~OXjUO^^t{Sw1sL;_7A`@*{ zbC}bGme7^1i zyM^Mc;0R^h^a@+^xgKg>+)YZPp^N7RGvcVfk|nug?B;WQXum^iG2!zxu(i(a%_KuoPWZ7LIhAbF zp|70;E+448^Q(R+K)Z<2!E?`qE^mrNL0-x~#=&7riohvH+oV;H&}DiBqCjKBM=*c0 zdk9b2x1rR*Gs3)hV9X~USP=Po*o+blda~BiIA>BU=}D-AMXyO8sdRocxun^+)c|9*pNH;2>(*K|w;(Vo*;2{#OjE z6z&=?;B6rBv9kg=3v%+@U)3xxxu!*aa+#$^*hq4x5mguHSXWC$1?*>?AM1ISz3=sD zsR5P>r|Bk<2$;Ly_rKisyg-&2Z^uehXp_r~4+Eq<7KZQ))U&liY#l_yfpDg~3@|(- zUJpq8BbP8umgLdbPUU-`(S!bH8)nct75IW1K(DTC1vNt~smb zthKlax*Ek0459}2iv-mEhD13zt(Z7-67mt&rKX*-x=@M#<@h6EoRuv#KhK;i;7TaI{UfLiYP=4-g7strC+do1X3j^@`y!2!4%3Tx6Pwad=@P%`tf>p9p&3 zOEz_w-=#$Qra7PMhZxkg5Gzgg6zOkoTm~s9O29#8zRT{z=ai$JjgqtQV<7WM3#(O6 z6*zuic98)Zaf#cB5HBhUr-W|4ayb3#DRlAt%X1;buLl3y6Q@>eg&D{c6+Yt{bjAF> zbg%`J>1-C$08cyem0x^jByEq<{h6N98AIAhK!Yp?e0>4T$PT5Ri{hyk?PouxZRz!IFJHLZ02}E9|a`*P-=;tKWJ=m&F$XL{e^bP=` zSl9ef#C{lJ*a|`)m>O6MHOGTPo%xiUb`hyem{7 zfm|0EQ=^q5QJDfM2@=nX|9D|g^jvo2F*h`TjO>K_UGU|pe`MDG`+~wh$^w5^3I0QN z{y)GVRUt?z{Xa#Ce-8tyNBrM{@!ymu{`VygYqdkRpqgFh2-_A81xIc3mi0ucqbDy+ z?bnHM-KEuxvRwUi@+G{6aIdiCvYXqdoZ5kP73PsZ+~i+_ZvOAH1FLseC!c_l3~f8h zKPxW(seJKYlu`blmO%c4fd0PyM=9pt3mIztd(eL&p#N7C^$+49@%)k6-&XejeIW*Y z-k>M%-&`714k2?N53%ZvB?zbom~%(hzC(?D8UIPkLuRu$&e(UTCI`Y3SvVImaF_#Z z+sMLskQrc-lQDcrL}(R}Yfu)8;DH3XHS$!WF`>_)NA0G&U1sN?r_Ay=Z7{LPxWnao zpz0Eh&7uR^U%G?@Q71qiT#(?@@7Wrlg@(w|-v%9r&>#epNh4`Rh$FY&qA^g#idg{{ zu(wr=)&bXoIO31x)jTjz&?7H}0Fla!1h&GAw1J4Ufl5#|22i_3UIbM33WtD%%YiKh zC0Q|4k17@+LHWWBZoWV@tS^bCfQukgs5oWH`oDt)703X{{}P&%L7q4fluff)___`W z{XYkQQSEBDYmE>(n`V41giFJmNbPeS+S3qqLG{>E5M|5?$wbm9j=X}%()jl5I1-Ga z<^OAWtY+8d70CArf^9dsAYL2fama{2%qU0%s0@gE;t#ZaCj+Svh-hkfMtrnj zN{}O69r?SF#s=(LVPswg=={d70*42E$LH%1AVt1%6D{tl2j3YS;Z|zG2Vf6Vp{Lg+ z@h^0)_82SSv_TT*f1xdmz&x?c%=aJ>k)%t=X+~TP?0fLol&2h9nQ#`E&_(p3o_CFH z9^X??GY6Fo<&)kP8R9FPAcG0&JnzSAJJhs_2VGyB)JrmjN`zV; zBFgJ~L~u}Hhxz{S#mos*g7PyMf7|NBFS=q8P-SZJAgtb>UC~&9xZp?VVzd zsjj1*ti#rmYi`A=&W@=AQ81z&aC@+Dm*100i!bYVa!qo5PL(`gg=b0otXzZ2j;u(6 zIJbDJzIyWVhFbS$U#CtYOc*w- z?kLob%~yt97hU^2iNl{6BKu;tG`R2Yw|Hxb9Htie`z7!q;%l$ZYI_OqTtT;)Oj7SE z3HcA<3%nLcKYg7fqJP=Av@Jp;${HRUCWw4D@>&H?dJuo_x;ba)hL#R+lfYH!3 zB^m}YnO2UWnd{L3kl%F7&CC|Bqs{#3V2}m6DTBf z<>P8is|~m9!L;+Cex@}Mz4l2xcnLEg^IN_X19=AIRfC4;`m=6)dxL1>64OG9bBAM+ zW7m#DoQNEaOYXrW1y9RvapoP1f&gwr{1G%3h#>6!@3bvpBAR#faxA9eWi+KlhqSY|+!z8D@}Y z-!&46*cr=QEYU#oC89i}$cj*CJ7N66v?ntw#62%q=D=ukzQG zUGd~LIbC>X(zQs;n+-_^Vg0hq3yB(V<$8Ln%dfpgSk@9G^E;BHb7Eu;&N%g&nzP09 zh|Hu3gCL=pW2TUX;tiR|?Mc?d$Ml-=CP8w^He3rM>tUC`GwJ}wygsey9}HYILv%*v zA(D3YxH1=shLQg(2-$-f*mIZ``sqNw)EoO6GMCdMTohwx2mSGhidT{{7T;>1QxZV| z^M|>ai^!o_Geuv=2v_RkXVc~d#+~;>PoQ?kjDi^i+bC>lKSf|B%nQU~i;feuy0_5E zT%?nC*Z1+Qt4x;!GR0>nt3Sm6J2Q0&+>77a;1}oPyYoWv)%?lFeN9bwECliFKwq?M zsQkvjM+m~AG^B)Un0t}@pgfJpsGPb4pM@;qm!dS4MeBoWcU?J3=zHR}xjtGzTy6#O z-)cPZ_JtjPnUCc=h!Z18F-87c)89kXW?!rgx9SoW#_s_P_{bBJJ;P5xJ@=XSji2i< zs=c-g4SqY{_Xn(qS~UAb-Re>{HD!2_8MUvIltQcVi2Ahn$$PpO!Zup=7-R+LJ6+7Q z;G4dHLXACYT&1J`Zrq(~DL!fIEI|DAYHuz)c=%>waH-20%-fVB8hN2#{D<4mxn6+~ zgiAK(t0k)I-2^v5*CWF-9Y?!9x`$c$&g{dMH&d-CKM0ERZq%vK>Z@j7i|X*p>|mr! z@1*$t^oB9(VJ+oy<+d(hcSt{`Y9NghSD;R-Ldycl<-LWf(YhzTPd~Nq52a8 zJ8YG}_E2<91~KFFxi^Gt)C|;(T`T;bT2s=NRH)s)tIll^KclMf#&@*ls^r}qzNiFB zmhq|OF+Sj{Sr1x$%Z0Wa{GMd9=?74n%m1|)VCgTNh7l-a2)R~7-sox8aAVD^>%(5+ z#+l8O7~iRICeJ2q?rImfs#@l+ z?mxGtd~D_{eG(t8lGZK^B8%WSqi;oc`V;ud$ou`CX?o1yO4*NlJx$tc4i$}UM_ey~ z#X)#gW`TF(y+yts-jf80!Jh6XvM|x*n57Nsn3AI~4nB>0bOFf1!wZZ0&T#rpeS(Yn z{+KG$u_uh1kugP&OpzKd<>%eicr<5w&v(2%lDU(%X~Y_st!Jc}%=fFnbT>2Pj$_l> zw%NlZhl2Psj+6b&XuTrMC{rGOzA~xflFOw{F36Ln4=uHY@ad)QpG`8ZtKz~8t9Et2 z8zfc;Id@k4S_iKTK0P;k{$Q17&c-$@Vx9NpPp*@d~>WoL#ggy zLcsnFpV67VJq!J6frm&*ER9O(OWqiY8u{b5n-!))k0x}LyH1a{+f^KnCEQ>G@A@fv zzH_VyRjLzT+jcDAr3U`tdXgJ6YD5RD?KJXMpR6)r7>sAQombqySN`gGb_`Ze!7VqE zljf+Z#{FX~dGhs|{hZ<&_5%jXcJi4zv)P`tTgt(xn&*qPt(HB3pW~V#h0Bf=!=8&t zos3<29bCo@%O18C@hxWGFCTfPI+P*s)Aap*z0dbSKV0{b&n;GgXvLHG1*7)ZdscPU zl*+iGO)6zc6~>0qEiD0uyc$FV?0o0zNcwVms02bq;IYWw+}$Lzy)c41HN|>VncpbZnKPJib6VC@~GQCgz! zClfr~q?Dg~b^Ih!cxhLssBsp<|4eVdl*gks-@j4%praw9IA&!ts{C*$Uy89|zHZ@M z3^|rYj(sO*_Fmb+WpCP!Rk;zGEm!u*K}=TjH`wMp2iQWTdzPiL`KV_X%Jm{Ed9AwK zr`7H1bVuk51JA7W==LN@$q&ee9BZ0@bEiD{*nhSqqHMHvA~Z zUN^lJpLyH&xKpfLx%1D$>Z`nRY^YPq3}BP>s|o)pnmbfhSQDzC z$9Qr$2b@a%$X;^1T(d&D7p~WF1&u-}m@Joa-Et2sy$7L$ouOu*5^bnn=Tv*8hKKbb ze3wOgb2{k(>o&EqOZ2N#cZ?QRjb)-?vt{5}!0pF%T%j$^ziqO=EvjEhJ-nra_tQB7 zXt+1@s&>CQqu(~|SY3gP{IEF3S6y&`R9c)t^LfR&b$wjlP5IjryeOvL< zRq>^Fs={ZHp&!#L6tsExi=&#GA~zaRsgk2 zow?|dy`uPh(&SyXeLqfRfe%ZwqK|&PmH6Q@ORBJLVdTg~S8VB1YMy$ibYZ}G^0T-u z$Reb_(HY5F$q?5=r<@2dxHYrN>6F%e6y9s4ydEKTXUp;os)nlH{LYG5mo|GeZFofYMQFE2gF?ONjzZTmynlgXPq zxty7S{cGDOHp|US&l0eB7Q%<|^voRW?7aKErg&97%CCZ`S-NE#ERAF3A&ja+ zo8WR_vUKEL+AS{&t*C;WIu?6=rv^o2?J?aV&8iIsO;CkZ-T%6Cw)l#kHGf9(E45}9 z9!as=e^`>ghhyZ$lrfX3qAGU>u(ld2@ehCYB z+R@@{hDG9bj?v$T?x2E(&T<@17gx9%XfYPB9n&ouv|M_sILr zff|lIb?pbTMXx0~c0}oTaWJ&`1-tbyQAHD(0RPI7cMqx(y?C#AQdmu((x5Xl>{Fi0 zVY_z?{9XG7T;SB1qIj4~!b~e_dQkpx>rZ{ypo>+_?l|9b9!c)4!jz_hl@rj8TCh7>*)e9+titx7#biEt{J1$6 zzwPVAN2`;ny&0hmW#U$^3bUwru6I8dibtUtn4-Ge*;bsMVj2*IgDhz_VYy)f3?bH( z)`{USluZ7WZF8ohUx?O#Kw-| zBt?jtmn_?qm#sIa3URXU84=o-b>31U z`z(&no+KHU7<`~F->GOhfr`{^o+@;Kd#cHIs`3Clto&SGi@HCVp$ox!+5GE-A7(VH z*>3pf>#WU~9I&ReX}VlM?IRshTp9SVfAPW6n&7_c{L9YDA7l?}vG3K-&osr)+@RA` zs47mpU9`5QKnH`Mz3LWv_Ze@}*70$IJl8u_rylgr{oR56$; z+3Z>_f@ky3<~vP?U);H8m+gzeKE1o=q$s}q%-Y8v@dEDz8tMY0)B|VL_II<-vN|d* z4F5&e!R3_fqvTHY6mySbeOLNx`mxPBAs3W)TR1Mt_b&RVsZMRxfaDNJQ47vJ2};>H zGXbhKGv)P4t@hUvjDU9vUzX59-{t`ksE(IKs3E!afpSdfbD(Q|0n}LApH;OOEv%^G zS{nGd>!)F;@I9Q6y_%W|=g7R+n`u91Qz?9Uw$MZVyY`Q#!NJ7rXg$T;1a!ATnqdq}2NMs-$mv$2?UePx(0eTCq`I z{TnUplNqPllK$qmA4$CBXKB>}&M0#&`Pw~Vb7VbiMb2766ZYh!VQrST&mh)oMqzV7 zx=&pDhnwX#bC7jz!)tZzqmi?I0lyx7JK4OgsOiBy%hiPQO>RCni*=EJC+3!iu^lU{ zi78@H=ua)}e6Sl_8B?5ja;$2Gb?<>19c*ENu4cG1x?Csj-fVw=wq*OpC3#>Ucg{$T z!1y*NJd_prXKJt5{GYt* zYyJhROxn?kE^uJ#Sd*E2= zoV7v2^dE+iqHOkk%PP!yk4(p6>$V;LS#qkQ(?jNMjy)jm-}QI}8(gaI3f@!QLpcFheu zq|aEqP;&rZmI6~8EKou26YH|phw#ix^Ls0>+!|>9GkVk&o!?YwoiG?+yA>oqZ89#e zD3ApmeTyh_7@e-RGJUJTf(k6xFAQAdldsx;lIci``DX4Wh%2Eoh%oj2HLfJ7GS*X= z+OD|4j{;R?gbI%TzJCe-VHHQlqLr<*%BQ)v&4Y{}t&8k}8|;5b0&!=O(`o+Vq<|vc zxTe>k+&Q3sdGs>X@i_Z8HBOND`5RcsnX>%2&zYu{1(VezLkPH!=b$s8WYn9yEWD$kP?90K*0 z$X%u2v@Y1luTz_gCfAw^mwytT3xV@OxK?pcdL9Zf7|mwsA@&``6eCIK+ZtZ|SuSlvyoQLAcO|Wjf~GJgiw2?bRwRyge93 zMg=lpsE%0w$XO%ISHU@hzGMR@W zr({DXG6eJZT+kN`vbKjPu6yG%;P6&QIZd#5`s4TjqSew=Lf3EJryd(J5Sxd)uPtN z%WD~_0l1`m+cg)w;{8;dcisENrC{Jm!eKXT{4DvLMg!P>_#X>qh|FpX8f0FPB^SqmTf}R_!&dk2<~04<38oxvkJ%_HIC7wmkkXWroaQ+?ii_bT^$%BC}RiE~_&}5x}}b zc7KRzXO`hk<-(%s-Z2vgzvMdIHUWNWAnMFwUYo_c!B*?;-)CPXzLZHC>}mR%uL5nY zdvKGcmWJD3MO`mcJwewPQ#akMU~5VBf==X$J@c58Zdx7N);Q#D6S`(rV}(cI!`{Ga z4<>Hd^+*QMZr_py_ACMf@?6@jKVzi&i%O_*aL28T6T{nPUc)w)mYhe6X==cUV^~I4 zo8BYl)+{iG!w@0rody%eqb_6k{5#M+@}`f0z?q#}OPqDXd(|?>Z#9kSKnH112D?%{ z%iGz*zhZDkF~S@4^%F|~TKi#<<4 zH#Pj(1AVaivDe>e_mHXe?&RT)ylh*4 zF~J?4@=oB0ZpJuMvfvOm9j4W)&Z2VyBnvXdZ@+(F<_UXa&$jWXeE5W3@9c+&OmZ^KjjAw z^q5z$g=21UzkE^|z+B|zp_mQMr(yy^Q1(_RS@%X`rk*%tz-{e@uEi0neL7Iv-lrl& zb!l<&yZN8N&*{Qvw%3a$Dz@j)2fPBc7gSH&2S=p|^M{12rEL3V9$QUOeiT-n-aLDC z%c*=mRkckQg5k-`TdVm}Nz9Y#`tu zMZUvg#n)&ivql5Xxt?$Y<>l!ZjHT@&$2I#Sz(cblsV&~2cF*Er2T92s+ojF2VH{x~ zZx@W}8~1$`;CCTw?9_td6^AOu2X5R#_%HZKWf`kC6d;tV?kf9MopUmwb9#(mMHU|4 z_#h6}lSB*#Q$jTxuT4dHK9dFKhX5QI;-2V;GViW)WY{>xA?~MT6HS>7Z0?&~)p4;u zn~%^r<{?~JB3*!%i#Zl^B5(Tm`~GZBXk3q-lo`2c`&#%Y7D~GBHijCKzz<<}x%-3hpa7?5%%-0GQEZ5RngG36ryZ7GLnzV~bS_OS{LQ zex(hiNruH;0ZSK-=Ir0k^?GnCyjN{yRT!qe#)BiaEy3cZdHbtPIebk|5p9`2Sh8e| z)4;MFIvG}@I27Dy##%0TR>fXOQX8Rw2j2`BY;v?Uaj13@69VGmbi~?-JH}I)`sM02 znNytVy^$&F)G(Np#+|q{AaMZ2(8$su7zfg@$))1vN_zGXLK+`sC1870m6|dIlzx-k zu;LHj-E?bLmg?nXly@3KBIW}9mu|QK58?=?Nis#sn`skrL-&=o6CTiSwi7r;vZW91 zZ$^WYdj_12kJtxpt4&@pkMy{ zldF-KlWRp)rn`3F1GO4=no*kI{2=B!7U!N9fw|B#^TA+MBlQI#Sa9fv@({&Bb)#7& z!uOJG&2f}0uMFyX z*k&r0iz#|-*3LWnp`6c*$Jezu0(D}7B2>ibj+U#yHF^q3e7?$MzR~ar@FtA8qcu-{ z)8b$Am#J(RK5V`%n_9e^Qr;}0g8}DZsN zz{vONLAolRH>Nx#9_nUg@&xj3eoUKJNan3|^wZ~cNb1@V7(;>d>Co!?!xMsXKPTi)kM37jbRV5?+p{tY0F;=ymKlwHx-v zh8zu?E|+ccl;Pyi!_O!V3iJ(GaWkCv50|2C7Y2(=mG5^YK&gietLsq3VDMvNz9;$3 zkffjLmB;D7*3Xi4&=4xF7ihz)?!0K)C@p3|k+rJ~9n&S$eth2Ot0{^n`yn`VOo#9h zp@k*~YgV{u?KNJ(v>BL21_K#(;~^*#JKx;wiEG*l_-^Gb+xOr&3V4`%?5%ASJsyah zqC052nx4`dG|Y|}i(N4~JUpF^3x=~&tz^Ll=m^Ys!f#}cY)p0rstVz{%LSa44|>|K zTEDQzLv?jIY2W)%WhSawl@h#VFiAI^k4W;#UNBSIPGKO}`$Nueae8lM9d zVFF?O1XpS&^kx()e`lmG(mnGYcn_hi2Xh=X!TWn7SO<(-+z$OkEd5?{b9I1EH0yw6k2@5GquTZvIH!&&gz3j;mEO>|A`8Ryp`nH|CdAcpnPO`D;G z@SrUN6^;o#*A&(>^OF}aex(N^iXU>3@KHJfaad!pL#XpgY8Sze$S`XZm4QXeWY2t6~&RcaX>kYth&NNIfU_<9eH1Bf2h!>){1JF(?#o?uZJL!v(%^Dyu#cOQ?; z{D3V)W^nXaW=B51HX+8B25fM8*uh&u&NsnP35fX&UHHV|Qc42aAMLGl1bnn06Ct`k zesyxQL+rkd#F9^(7&J#{!q3u`R3c&kLOQ!|p(VW+{hVjwBT2W^3ekfmrA_8k;2iu} z@#>ijXw#3bx{fnZW5i{W9oq( zIad}k;C7;Fo>?XxojFMs+;Nf1i`<~_uXt18&e5UzL2e_L++f>gL?nbjS zt~c_)QEs}dLEUeQc5q7KrS`W)`#+Z#zb)STbE)xd5kb1FOQ|RHVSsV7x6*KE(Rr!6 z_CR;C6=%)rs}dufg6Xd(@XYFtoW(j9h~hpaMpila7DiLu9nI#ZvYet#5VI*tSeK+Ai{h5;O-ex!9d4_LCWi&TUhV3dmSOfd~mTs`?|9Qd3Hi^97v+(6jD zM{fP**`$DmBicNSjC!Cx4jJIg7(PsomCFGd8H2eCEEQy5@Zj?-I1n;`fSDb?#9&?{ zz|09l@MM6r3nf71flhe}HGy`prej5wgBec6Q%pMd!41IzgKQxb;GIB#$0=j+CK{sA z13d~(*$IQQ_rcLaJsanA2*uB7fD#uF$|q2OCuZp9hX~&IZ-CGQ{2QSEKLMi7L6ov6 z<8jm(i|v1?TFgSgIsc%y_+P!%K$1!sn7rUnxPVh-=3?Xx5>5heVSjKkqlg%ZKSZv< zVVu9o2QQNX0YV8WNC?Cq)_)DufcVmaW&}|j;F};M2|}KSG?2&>5k8iNgv5X}1`MPm zArXNrlsNFwzuk7&0`vlz|LX%if8TeH0{DkArPL44koj(YW*vNyb@YU<%8AK`yFzzwf4#VOn0D(Ttq|QE zSFWe;xl~vNM?MXmif=D9v|k7>J0%L28NHRjqHHNJyZU{1bJ>g>`p2QhQ<53bU#Uky zK)hsRBFsQqWMuVJ6hK8}WbqpH;Gf=;k+ISO0g{nfQ;-9rA|ulm1Og-@3pz>#^zuK0 zfe8LbVETiQ7Va?M079h zC_Y{0SNgZgTOkxdK@34cxKANLhn$)`ZWsAas5IZdP6oVB_d2(yR6}51I>U>XN2t5X zxKEG)FXL8;;mez-o53WXV=9A92{Ro_b(K3y2Het*`v%HG^?~`I|8vm4=1>3PI6m1G zIV#k%$0}#N7;))jz-0-pb7QR3EMXgERH$wRi10ij;To-FxsBF~Cc!YoE71GepWXwB zuZ2wEZt;h2#zNjVz0(a(P9mYaRBW6@k7MVZ1N=9c_5-n?No*Pv-te8at!ikfNoRm5 z)5u+%GS4Src!@N6gT)7H)q)0@4cUuR$$uJ*kiE>Hp#e1DlxIN0$e#vQWY05bL>*|5 z!GQ+e0+N(<2L-Wst@7zSpATHtYQNG=3uS@JuHUKgTD2+ntL{0j&XPxd?kME2ahHlP z&#W0P89-jVh$gr!lnSZAL3G+O$MeKz>}WI$Nq1hW-*p%UJj%XwfgZ8MXOF0mkw_6-NCRV^6UU}% z7GdJ88Hk}|sC@xjd zlyZv!iat`ZSbQdE>N*9*ps-V>zWuA4%j1P|l=W*6(4e=pIR4Y7l%~(2h{o9z$sx&z z{!AGx7Zd@prLjqcq&tcu3x*qvLrMxeF%>1a$_XN?(}3< z+*X7&LplotF8wx99c0l&a2){mDN{{=OIjkRg4Vlgj+jjtmQR~|eBcUle{qDm z(1A2Vcv3_381Pic`lhcT!GjkVj*(Hof^=uT-xw1-Z%PTf#($zZ%z-!~WnpJFxzRwK z_E1lWKRst>EQ4WK?rvT%j}o(prrEv4o1%(P7Mm@As~$yb0|>?>2&WQqH(Q%MzNZNy zC=-R4j#*~P66fxVj^SW%9vC{mhS%15GY= z8Ng&G!F0Ruh7M1b3O%9u^8}W?92YAe5g44#5T61j@?sBh+W&BK>f%SI#I4~&Q>kVI z0eV*wdZn~UY7|-BGawW>l2Ah0*8xGwz(>jH5`C0)kz!q#V-*ReKEQ=R5M@HIv`L2# zy3+y#a)Klf>|oG>CP7DWFlFwtH5Y(TrcH!ErpY744jAFiAWdIGBp~lcDnwp4kv!`O ze36CP#_>ZcO`esr5X)~#JzpZVH_{hBCGWV zY2KXytnrXoGj&+>x~;as3IU~u=oTT-E#<(#f|lOlRH)b$aK0+ecmFvrkp83w$ss>0 zJLTIg!h2^pQT_T=Z@^r02+6U%MLtcB9z*VZt30gAiaW?^#Ghh1#?L_#T6+nG7XKsv zJ(KZ%9UHn#5BPF55*6|ODTYZDo8>{Uvnlv=uATR4qjej_52iXLb;j`Bd-4@Gf;3vA1NFy?wm$U2B=1z$lIT* z=xBj&5D~TX@st)xSaRH|hz9OJSp`SP|J!xIcxBDalUQp-R*32Wm%1Ta< zfs~a=Qr2ibaySGg)Y7*vYHB3&5^Bl%(^B9ZjH%r*D%$9F`1qWzqeun9_Xp~(`?c=4 zszWLy(@~rVa1^mdBu$0gUM@Kzr$vn-Iv7pJT>ixG37o1XoUm`SYj2Wupk2fc>`cXp z6e2l2_S^W;?rfhx-1v0X-!F&jJ48nzkq#-sNXc4KL&t05jOS)-XcT6j8bWF>0yNl6 z6kC0W;#(Tq!;w~S2#7FsU~ypKLpVuZCW(MM`_kd~kLTq_0P9ylLUR!tWLwLBU;R~} zGlu3X&%iY)`qa^tp8#~D#p*(~G)|~%;aD)UfbF!p1$lB_vTl0XEf3%TilJ~qP z6*3yAr|SuczHZaJa=!rF@rLd1jmLgAJ8h(+ZqlAIh5x{yf4;RxyaBNIi5d=Jh*dvg z6mZK~R8`{MYq-I4Clw|(bV3~nfTw{^PCX>rxwY100srUnGODgAT(9|L)qJ`E6lKJ@ zfTdJt6CD$h7wJTPy47r)rlr+Z&6jyy5FuLkQ=L0-mAfK7b?!prVDp; zw^vUj*hjPGxf2S(^p+rz6eK-meEq^&STAgbMH6mIg&f^11k1Vx66c?XK1xaq4IFp- zGJr}-GoeE9h?w%cPXnvC5mI~;jpFJuv^k+S-R_pj1-sBii^u5~!OR1ZkH0EjC8{=# zS2DG<>BGpCPYH^8-7py}zG%My5O|(QAUF*7vCEXucYGy#?O~i!A3ZW9gbIbFLN;vH z0WwHIu^!7VQYki@BbkWxdlhOOU8U3w7MP^)s3HwhL82^yk=M1=&6h~lG0v5yddzB z+*Gc8eA%^{plKm2cPwOynnX)nY4c((P+dCJcFO^o^V+8oUeo&kj{J}rHg~gI#B`Di zsN6M{sLYXQ$}YI?CFT+{@d0?G`u&J|ERWkwo(R*Rns0Quz6%5sRZ)*9&sNS4CW4C& z5&20a>T138r2|9R;wJ2>GnoFdxAyT_8@jY$1tVqv$Q>lcH)+59L3x7!?uw(2?-5ocoNz1v0jIQlH4j;_&h?UbqpzN6N zj~(@a+ekGc8WSgGNzVuVAp{{H2QPHYeMIsG$1uA1CE?sOZe3lQQeNqcyj;O&R)V=OBN%M%@OlVq(cPj%p zBgCab)Ah2kT{sV)*mf>XujW%nDgOI?;LSYD?oV7a{KX0SCI746eEwTY%lhT}b-SYS z94?V=`imfTzW^8uh)W6Ec%|hF=B~#~fr%7D>J`pi z$h0&zzi`iA)OWbh=S_rd=GcXOk7sG~S+vq}Mp~HBFY21zO=*zMNlOT=elHV~!pi&6 z2~91R?j#ZPvInnjq<09MqXDayR92$Ue$>`h`3zOLM9W1d-S~_tz3{$see0cB3qRUB zY&so+^@wOcql2E3CWYS0CzH6fgjGsAwh}GR1jBAZ+dp!mw%n}7RjC{q1JD;zKLzr9 z%+)?K7@i(2W@{m=9pg`&ik}J=fe&{7l{QhN7ipUt=D3@3sNdy~WGp;vC1Ja?m<%M+ zPISRN?x=fpJ{>6JUCw)QUk-*=4fk#~O=P87R;ra8LCs8DgW}pJB3%}P9&g@!$4(<25O1F1)rizs-JAvki@BM)$NT z<+7Y?#*jF~xzC6?#I&icn@RSznC@Ly8}r!eb81si?Qakr)Y)J*?v8^<)F+XMvba~H z+W(es^1`_0C|h>!AXqqdB&T?e+<*MFn7GFc3#krK%JcVoUmHr;O34zTLgo2ZgH~x` zt8Te_inMjrx!peDnkU7H2j3(R@EU&52bl~($c5%hm{ygRqO7#N`s>(~PR5m{-*dq4 z+b*pF|J$7Rhv>2(hKDhu3(g6$n2y=aqj)^u8(=fZ#Et!g1}=Q9L|(Pe^_dUv;gW_V zf~SK2ccAP3TL2)N2!PRs(XxBbYfN0gSxIS#XPL5Nd8ckT0QkSjn?!eTMCypdC7FV% zPyYQC0?5?C!;UiGIC*1}hwL_Csq+RLThSBDndq}5Wxqc(E7o3ZOV?_1ua@NRWb zQg-a_1WqpI1FUHztY!=q=XZNqYiM3J`AK#;tl?UUXAX~0p^(UXVEMO1GEGbY#P}&I zlX{v5w$PS zEDR(Nyog~Sa~@wHskk*&M6Yr|?=F*RJKtRTadbY+1N2ZJ_1N9%e3FyFE(B{Zj6F_Njnb(d%xx^)T%=ime75bMpOm`4B@nNiLWT$s2|IxN%+1B z8ASw9JzD)+yT4W?uqOM)8`)OtoU-yy?$)~ZuMK~nvj*vo%X_R;s7;8VC&caz{gt^x zK_AyH&7?1)+a)=Cq~9@ud1`e<+&pG17Fq%lU11pI4cnMj{&n40&AzqEGwB^kBF%6U zei^qP=fTpCiRANd%@^2Eh9w!XyATkLe6;xE(5je{sJF13b*AY_@ZI1#VDcT}w?klE z{!#gqn(&hV#m*oUZyPi#Gz%mi`MF-Lv2#TPrBP*CM; zLf%B{g9P7#^>nj}?6!1+dUo?!kW&b{!=%D>5hH0==ku{#aNXRf(4Nq_QA52~+8>;r zpU-Xb>iN1j$Q*EPq`&-rr=PL1yCeDKst&DXu#}^V@XKagl*D03=8cv-Hfsw;q z_~<}-B}{#&;?{|w{yn2{#GX>0Cyb-Rj42qijw{KC%(H^B7MBZbs?PZi3fEB2q|=zk zZU2Z&P0HuDd>z{r5qR+_k+E_pS#q4u#jx#Q{i3tx8`ti(U&U!Zm8%jB4EA*UG?RkF zD=eu&W@ls(d(&L{n+Dxzm(DpScwKXn?rdQM*ps6^K5w8IG-_nKoejY%;d2ail=|ZL zY7TQ_t=H`S#cpC^KiY7mgU5{}#_Z{9GLYEZ7-z}$O~@~ZOZm97p;j$ll@`(M&J zxGa#M38Du7e%vI+{B_Mj#8|M<%)1@?mc>(6$KoI@n=Gs~*-}#cJbHAuMM$ z?3AY`je-k({@N&$_n{9c!72S53TdDg=#O|*8RZVSN9E9@phQqoyI6cIt5#+Y^ z*Hf}am8@$p3w6MB;&H%q(UhgQ&R5KIf}_+gl`<1G46ENQNyM;UK0OZ_!gCqIb8NRv zOem>AG)md9=Da`}Am7<8btk78W+@5MWOlgax+~oxKw3hOv_zM{|8{e8&TC?TfpM+URJcN1rcB+d&Zsnbk-$lUpyCeIL1)^}5#qb|=^ zNvvcUvVMA>A=9Z33$f0>x#^Xy$`16%g_6pgZ!-m#)d3&0YYs`6d&ARVOzP9Lu^6X+ z?ap6n9^3~{%k5&6`i&gs9E>yxnOM9Pl_S<4ax~V_yVYV{cCKw_qf||5Bn6g1--5es zCPwqe@But|qwrZb{ksB?t1w-&To&vZR6VylEm}jP)p<*fei*eSdTh9Vz`u(TcL1i& z5*#uHo}p!bF@eIDeir4n*b3KMfFU@30H^cuQQxftCTf8AJospaggmMc6QH6FUU{}f z*4}IB7xkT^oH!gG6&Zi6CI-(=WA&eIxH(zw!x)y7YsNHe%xHSa!s_L&MLqk-8z8hx zrR2GHwEg+pldc8y+HG$>xgK-3Jj(J-qACt4HKH=$^VP$6=Dn+`oOX05bq+9nH89^b zjF8s;eKs}jORsTTMm0)Hgp#fkLUxPg2e?`*rqh-|WRo36`A-~ExrX&p2Fh0Yf)5K< zMA;yk&j6aE^F0$%H3xEh*v$8H_oLtcu+hI;W!GOCYhCSq-@-ZAJYuCT*DN>CZIqC> z+UfwDY#K-nTZuM@LepL?ZfzeZ#iQi)~pHW)w$2GHKFI`|ZomOLl^ z{*03x>Y*dwsomBw*<&-=BDk^(9DF}drvk;KvVyr#^vh=&({}grr0y52qQo>DLzU<&3yUD<> zv*hpIb3R#RXqoFv@k4EISMEI(K}wKtdAMdRPD z3Hf8=y0qM(3KKf8m|g(0h4XIdJQwo!w~~d?T142r*xitKR{PyDJK#HS;&+^YTpmbT zQ>L#m6qE<|%4oJP&j$IhwKTswB4CoBF;+RNwe5urc)RMZ3n=sj6!JMc{a@_8`9IX( z7dZa3D~YI-Jt~zfB~x}%T4ZTM491HPGbGu!k)mFOR8;noHrr$wJ0n6_3uEkC_AUD| zmhX8^ug~ZEczpkX?=SD4=5e3T^E~%#_uO;OJ@*bzHZzOTVS0gd-JcQPrwjRybCWH3 z7Q|^Gugo5T9~PYhc9lCD3q)T0gcV;Am|0ig(&5%*gYX6MchSzOk3-*sZ?7tX`60w^ zB-(CLHCD<2DUF#Q_o+EbdwG9HW+((Hs@>pZ?q&wMwFs_tUvHzw*#~dd3f*uPN`rkm z>-Zg{pLaGPmog)ZW1$R1`ivaTp<+_@LY7&0RIcS*a@deY(iQIu6Yq$M6(d z<$jReILJ=eyJ^7892p5TNBz+)5jZasIZ5%l}G6qBwi*S=>SXS7;kQAdtjv*T>1SlH6M zVmIf}tU4M&;?KwQW73Oqj@+hOy|QD8Qty!ylY74Tq|a%EjsE&v{y+Zm|Mj2PS2uD# z_qRxt;)+p*$Mw=~6Xo;f9gklwzV?=H z+|Z$5ctLC?sMxAIdzxH7bn^XBuF}tFkXgI_()gm=p6qsW&MVzP;y&}=usb0??cq`wb33%M^15@w3BcEI zYy5=$oa#lLxDbVskCnRH*}<1HM!Mjur6$YbgV?0Lnd{o*^?Dx8%`s9Bxu(h@q-!C0 zzBM`G(R%30i-W6XV7FdC045QWv`v9JmesC)*Vm9Yd$8{_W`a}ekGL+Vq~ zpijOrSNDwDS7~7&w|mqd>+XNxt)2SM4!Aofd@nQk%m49(+zl(Q6ZqY(Q-AUopPxNu zqD^jy+bEKCJ~uI#EFb=7w{2#4L$g&Lk#H1rFaxfRqV@CO&Z$c44Cj55vxKNP4uaFZ zZ+Tb^-AhqoQDG5-|JVRrslsGI3BG$P-NL%! zOZz}pyEk{cx8K}IhW^D(^SyDjn)|2Z21YMAhn)qq0)Up*>uZ^?Fn_quw!+eLuiu2N zztVRJb9RD=$XY_Vm^!Uud2Gnt+b8B2_?BT-kg8DZv;sT+<;}^pw@bYZ$JWTcz9S=2 z3&Pn8yZ==`OAB6cRyujJR(P~!1|&Dk_VHvGm{F0QIO&T?l*laDCr0u zUc1)7!AB~~s&Y4Q&Yr;77mlYyIEk&-5JsD{B_j`1Uhw-~lhW<~(yxvNV|4C5I7L)} z%;c0zr}z;?6Ne{D^Ex$;k8{MjcN#15c8O$PD~@=vV~AuK7g?auS~I{$Vrvip--A&d zw%bZ8>P0H|P8*CW+mEMa81+Rd1@GZVx6lR|+M%lP@*_Ln>{|QWikr=w9*nAJIxdC1 z+ik4YHRd?=p{n@%#ruw(ErAefs6ePet5CKn3$6?(o^&V-O1Og^3LdYgJ5;=sP<>Cw zwZy;kIhP#lJbw!16-pUUUY7<3%%5dQ)*Oxy#lKbSb9Q8U~=N*{GZN@ z@#D_IJXGgmRWoP(g%x9|_@Ly2b=r7OOGp+D3xdwMYw5SrePJ6+XXv5mJ@P*1x;tE> zSH|Y(V{@Idif7MHhI%KrXJGRyuhLDy!%c$}Z*!VCNJ`*>>gxE_SP9zQM`$&KQlTs3 zgO5|X{LQQ_N@kwERG2CBO9MHEfE-U8U$R@#&8j<+ea!A%$#I9@B=xqAB(syhh4xK< zT@<91TwxAZ=KC@Ggb^C)fi4AK)5j04WCa}~{qBrVvM-dG``*{PZY;+0$Mir$|K~Nj zBwgl1vX1(T@Z5qX^#?Z?A*wMtQNAEx%htYJ)>cm-Xo-0%eYI^CpMuSf8n>Pj?5ghv z-?an?cHO-#+V7T!EFLZX0BJYZXt259q0Lo+F`g|YpF7UH>GIm|+KBl**Csl8&PwR$ zhmy#}iwdM|VD{|?VAS?`CUZYZp(O&?LJe=N9M9_9)fL)LK3u(c5t;_`2B5?*isCip z8RoZ`CmW<*2a(5*R|$`QhprVe8N=63Fo)$ zu1wr5&vhPRAEW5JP44Uxl5bsmwty*5IX)aaQf9Z{!rftUYm0KfgV7MJ3etT!u-w&5 z3Q0O@EGZnBGY@&JA6^H?V~&`s6=F3?WyQpDSTDrAobi9Z_f-%WVKEqCjOayL22`9aBRAr5=iMxligF7Z3IVb62g>;hs|t+qaHy#?8)L&?Pa&f2ll3 z-5$!D9}FgU{&w&8+t!20jYVfa}mNF?LO%&Uw!|KfXK62r-n9EK)^1WaYt3)5n@YiQ zXB_5}{i+{rINR2~3D%xX6M2WNqZ+MqcCFqqsidXZinkRc0!lQX+ro3;u;}qgd9I-( z_WaEElin9+iY{;5HLCoTZ!4|<_9zS?g!t&b{ogD%ASqQF`(l)klzY=jx!Lj4SdD8J z#voD01Kg@BWY!Um_O_F9r!jl1^*_)3^nV)^nSVH-u0>$8S>x2CeW+pUOKzQ;=&h)5&5L9lq(W+~jCZwc_^ei41VgseF!oT}eV6cRCEB z?b~-i{xBtTD1Jmn{-mOJ^&Q2ISBjy}I&Ult_K&+#!YdrhIWfS*yC+Hzcy zIiH+7*)nW?c}@_9DY|S)V!`{-=7w1<7qU}J1t9AclXRtMeR-;JFzPa~9_GeY zG~$R8!HpB76Zm|u?-PO~QgU9jUNw8;NkFoS24&^tj!{qRCf~|W{g;Aj;cv)g9(fLC zOF*Nm(Z1`|?AhuDH}liF%$_nSL!55Wic;t6S;v>Dgyvi#&2*S(6-BUn+vE3AV4dmpG8+VNz zBX)v($MaBWwGLraK!ZLdKW^82d?|+P2W?rDLdU1_F!_BuGRq*>Q=H@X0n$PiL!T9j z*`A^#PeQ&`zPD^a{JXK5?D%|+Xpq(L=gHYGt;?-NvUAN}x|ypXb}4c~iJ0$=hK$f5 z$AwR#EOXb(ooZCwK7K&%K&Y6}3WJ7SJ)3HmS$rvz=?M|^pi_vkibI2qUAsk{8J)O z846T}itTs!0}7sAh~AKPt|@&yJKb~oNuNVn_mP5x-{amNPeGq8L_+S2cFa@mL>K6G z;Rb~r?^)DpW!s5*RfYR4m&nbnZ!AEPDep6ic4ac1P|<+3=Yk1^oi(iMgtImNO!2SD z(+Vfdn_kD)7>N`R_6Emg+{YtFRZaq24!~X7lhXDzglZnCv~ot_RNiOF#H##@V1=DU zsUR>bCLz-A<(;3?!V}-6wP!$$QrsY2x%w+4Fl+X8=)H~!o9EM1pq~Y%*nug#u$oIe ze$y?v$L#`Iwh4)Fv@zQ@Y_QC|@Y+Ir0QTcZB655FbF}2JSfT0L3!)CCZC@frqb?g~ zm3g{e^DAo{4laFb_mnyN%Q@IH8qa|EL7u&MT_IuMc!H&4a8B6sOU`@KI`3?QL{Hjg zM6K=(1WFTk7cFk35q+$uHKp(Ny{nxxjxNjdvXLBg!0fT}|IE}OG`9l@uPukPL)R|2 zGdd@IO9xdUIMaM#bhkA?IIQmdd>TUxtuF(Jx?QBQ#u%rvc9YI9g=x7k@20*)s0Pqo_f{H3C#EmY`&Rc%b~;xF4PahW>KG(K5<(`R!6-hu0_sPqaV#3>tYz8~Mh6;rIM=RmP;euaf2? zn;Uw%)b&bJ!{hAjOsRg|5FU)D61fYy&wnVq9(oW~*L_%p`=RAejI)$RP{^9H&9kq4 z^cVOj?TbFZM(8g1yTBN`GQl0HDRp`Ce_TeKWj`B}{G66aQk@(oJ+TmXwVE&qouZU0 zc(RNl934`zQ5&U=L5+3T-$s|AR{7_63Uo+2#6>j`(9*4am6rR&NosBEp3#V%sKbiU zD7uK5YR0mugdL>!RDlY~|3Xb4{t_fL{3ChSdrej8y66rgg*Mo}Y^tqQbOpKA> zu2L{ox9b%4!x+lFoR+wkUQ_tWlD5NeZ%(O*-lXPELxUTZ_YA$%#eTy{VeAoWT?YUyMnygLYLAeT{7RRz|cyPKspOQQ)C{s|T}uY_LAE;hV&cvsRjNeI!Xv%0kq zeO`pJwLP&d|J!vu5`=ohWM&NQd}ym7!B|(d*C_MD_@LPWx%np5T8A~kr@*n9;+0yZ&t3Z=f`s&SwyY$J&tGQRCx)j1h;Dx_N-UMg)EI+vaRfb?aPqg!@Svn`Q;YOxNarbYEDmL#&D)}%{ORg?wv|M7*jfUZvBa$ zi9dV8FpF!jA`>qD|3ZDbQ5LO73Ti4UBHUf@pB|+4HCCneI=dfee&E25)#i|5Q~tY%J26 z5^ZsCZEQHXzJ9*<$9i{-f<%U{i17Gj&N#6vYfP15X2{o}t6&phTWPpY?GuAWDfUn( z<`#F{-jx#FIjv~p)AW7FP)4)12x7WD4`IeZsmOA;f>xKOWhgi7$@W4v=KZJpLbHbU zzfu>NcoA-JVf%eBqE{=|Kn$Qj&&=IG?-xm`AK5Ou>xH-KFW2Yv;tz>+Tsv?pN{PXa zD*vAkOiY6A<$S}+oS>dMzbjkm_Jais?O1AXGjsTD z*l_xXS{RXA9G!vDQL+@%c$1Sl;vk$Sb33YJTE<>s>DcNke{*&9gDSky9Zdf)Wc(gv zJg7W**xt2fXUda6@0t-IjxSd9(hs>|8{c$ykP^PTh@Z${si;M3W5E@ac?w;Pxuzq; zGUiL&m_BBof^Dhf99Tj#$ezm6AmNBGA}S5n%V^8`&IhF5;h<>{@Q zJ3XhQN%Q>-zVkYh(EV2D#bJJtD6c*vgI@zyb#L%8icd#Fvuf_Bs0}%~DrufXCp_?? zwkg(HLJmD;_}|JOb3>=x*7)lpUVS(@V7AxCazR3~y2J$3ngR30Be#b(!3C(;6pLQ- zW~OEA9$U-pnK8J_b-1n4#?N|Wydp$v?xbdCEJ^~n@6@#PEDcU^>7KhksR0 zypv{~xRj!-*18L)17pMuz;B&wX$vAhKE4?{cA@jgMMII$#VhyEc3wQGU)(B9wQ%21 zP{C*vc#&-@Fin$GbCR>hqk5|cfI0e=l*Ju~_YUi<&$SX#m00^{4 zocQC{$GEj(Sl+RS{>*7v(C(E|KAhv9yf-?vV|T*kTT^T!j`gT;av@mgdd1aVZIqQ} z{%z=iuphMzgs88p`s2D&Oj^U6a$KJvrG3~Ob&Ws^z0Mmw6;OM%%KOeMZ?|1S)|XCYsV zy>Kg?&E9GQjgbn8+`%2qTccqH zUb$#ETAlx*G=`P1PPNrF{?d}zi_O?(_Bj3czizH4-^;3G#0dWKKe}l#Hv3_`tRtEU zqYJSg2jr;!a8#oO8Lz9hFW49>wq2pPUmqJklVLcP$$l^+r=n=iYh|g58ve4gbN|Oj z`+8>g{??t=lGbDg4Hv@+)jT1Odl=JCXB(`N76j9BpHA67I*5%7*z{ZSQaJFcuy8hY zgC4S>_t%lwQi^u*NCN&JE?*BIjLXe{n|ms4@x3TcvJoA1Quce=#n0e6MZl3KSTnMJ2L) zxLH!vxDEMKuMHS20V8u|YGUX^<UrWQ`Bh4SKPjw!4)&OOc zFVgl&DXW+H@t&7FFEh))=`D1%*wFM5U{PpSuq#>AyHsiI{in2M=UV>kItww5Rgu$`&nVok z`;eO28DL88AWrBGOLu>oNrY3bf6+=qOlo^dakG}0i^}y&qIX*95Sa6@yxTqKFxRpJ&VVv+@ zY{K>6Oo$qC8kL|DGuhVPm78brg^hpQNE&N|8dIj4fyqLx*|Nn>SCt$QtP^dv@QfpYifl>4W;|fl~5p>7P#< zWrN}IR2D|oV)`;GUWgvr=Im9zFaLqde)|qQor~ITnBk-}^AES@os!jYrGFJ)&@Ih0 zENXdoHJW#YmT$JL&fH-#PGEj|4-Bz%AI^;K%%3_Vog1MqW(@UbQ89A3w7(`Uq5yHM39f5py2~d9TTPB6sRWO z^!CPpEeyIy**_*2l$rKm&vGI1;-HB93lvO;GjHmSZ@Z*Y!pqSUVWadWZgK*SaA`s2 zeO3B`!)|S^G<+M33_kd9YoVRGCq)%N>6UE_O(-huYa$VaPGl z>+dO2zh5V$!1<4krpbW=M~{}LB_qfqSR*!EWhVFWO#F5?tNioE*2KG$%6m(0#()z& z*~glH#LesNUIe+rOJYk99J7jBd%@p_Lu=u=XPM#l2_4XVLnJfVE|@s`Gn!SZ1^ z>=JRQxL}edGYvJ63H)G-N>?b0BObh|G8v;B*q7?-Ch8VE-RDA_>P$b|LJ?<9hUM4= zTsHxVn@b{2mIdVECRg-_N{$e?*VV=%)fUE{Iv!Y?P==!MKt)c3n1GTT%1qu| z^VmxD&!9_lUKBwW1}qDoPOixqi`^spw{+}~t0~?5v^i&8R@WtbxuqeX)9+XC`;52j zh&^Pwmy1q$Qx2NY)8vwMWJ5&62Z}mRH)xgb*O(EVE)|&B*6D|sVsMj} zyK8q}wG{hN)v-MwI+3tq%A1|mBhOP<>XWMFr~fXuyuRi!4k1o~p)8FRbKvhOa{S_M zcJ_O3>D*v?hlVZL&Pteb=ESg^2a!en?xh9&!spGcj^acky z?dO@Jz4CIOROWa!3J)uKzuSxanv^@i%$wCSbr|PL1W2ldU#nS^kEj1H!lyKCHHUap z7GwQ-<8Zao)MU1vi+mK19E41<%7iGq9P#=`MC@F5=1{PXOtd2?!3$Wt~{sGr7~44z;<(vqpOr4vQU{av(niIIDEY_Ls+H#KKcL*-LNDW{DiwkqPmSC2hfDamo`kA)@$A7)_#V%Wy z)$mi3N;KbCMEIs0Cfd*qLXnCI6(3I8)Ot@c*G~U^_SRuDFDB1&rsMvd4A2rc?l!?Myt3>e!$SC0auY z&fu7>4jaDaJ4L<{x+V8X{S}tBbo(_pF6#D#U(VoF&zp`5fjWyZf=mzFv=@Z|cLRTR zS%bAiU5CyCd{zq_nyX8*dv($k&ZwtNDx!L}6yAp`TuOjqq=c$7QMsYYPwR|X?qN&_ z6Gbv&V%hh-gsb7S|NTjxb6aWtE7PaWcRJt0NK}0to}D>TW~_GDEg-qdHibn?=#r4O zMLg*hj@ur#PdPhy!UUoF=^w&SViHyz)Q4`sn0;Ew@WxY3X(e1+GWoK9{_+%D8QfxF zi`Xa`+=3A>ebO7)EWO$oyk%e2Dc;1?54%|jyc+2`o?iEG+|}-3zc@8(Eet4&y`^T2 zl_MOKZ9KCjM{@k%=2EZlz*24eigcCtv*0Qd?oM~*<-_+B#m84JNFvAR%1j+eJ#YY` znxmw3aKL)N@@h4?JDNAU%)8Q*JiKo!mDr5hhPpmwv13}o-nv=aA~<)-B1&)*P@4*X zI5x4^gow8G8h-s6lY&NVO?Ol+JqK|_f z)Ck<4%wWa$^_VwSa&jo_6Y6TNapr7C60L!ziB3se%;ZTp*5%P}(!i4Q;gsBh&-)M2 zDMAhDtca;u515f__YP9shS}nOhw@>}Z@^reVs7+NL`w*1{85m;gZRod3=ND9qv!D* z2HT(Zy)1A~In+fBUu7n4z#@V)7fK{dmg+U?I4gGDIe+KI*urCrE7}UqwQ#8ZsfS1_ zC_i6^LjKZo$X;6}!>(!nTJ=@kdl&@QHJ%GTrCx!V9J)z`!))LJd9(YBE(d>>T7Y^^ zR1m{ZKc-N6qfuvQHO+Zv*R5sg_!p~1zpjpsU2J4WYKtu#S;dFeByf&XxpqA5`nr1N zdrY;d=_#~VDdfePs+tNRj~otUGQA0gmQpS!En3ZRD`SamNtjP={+%3u(cJn|5V@b! z+?y89N_0o3in)J@X)7$ra8N8~6>8`meOU%CzEyY7gAUJ3@}N@F-$6=NGNe8woJ1)O zz5F4~@|*j$u|GNnZdYNLAviwpZtm&;rDABy(=L0lE^h3*(|FcO$gjeG(`pJjq{TWI zR|z1P+>_0ye9lm!7BvssCw(i}NrI#7{Mk%M%@jAu4izYrNB6Dx&j-ue8_vaMZ;=%8&iio$3-n6*H#*u zrusc@5$Ub`)3Ll2ZgfG|Vfp&CUI1d&?Jv+&5PBnoV=j67aX-u4M|U#Z!E)pep=_n| zlDK^mf!VI8cD3f`bOtltQf!nVrG(p}3|U(Ca2HkF8w;xaU5nVLpfz zW5pk}--N9S%f|N>@rAGX;O`>@;qnR152(+{*P>MNuZ!C!bqMYteK}nWcTgn4K85%M zWTgl8u0yd4|GSTm&!%5Aj~zK{l)8@YUZJTvq<1>&9%}Vlm@!c!0$M@=EvNk~dTJ^( z$~tyG+QWgm!{giGrUyilAx0L+Hq3`75+-2sO8><4w(35JZ+42IPg!2lu{Q~Ru_0L0$L|0(6N-&AVB(3=@0isbZIR7n==`v`{(0)PiVw>>j7EUL>YS)aRx2902R0a zP%UDGg9CcQH$ASdPE?O1^|_3+MIxlvikE;UA8#fhp^4!M<4eig+b_~#KgZ)~=<{-o z8hlX!tBJR$FMqnDJzBNo5-X+26>+56ev5F0b}AKYaV#>oTx4mwFkU z#I&!zO^H7iU z2};&7-rsnRzCQ==M>Jon*~ct+;qK*V#J$9*E12%Fx9EgwTz)YJ&<5UH2Ay2Hu@s%J z;Ibx%7kN|HZ(nI&xTqjMQgq0kh1fzBN28nXZ20}^hTBE5BYP})n&?N$`h=(IxEQYQ z$uL~gLJ?ewK476gqE8TtxS^{*MaAz>5%n@-l$8zLMc^hF(Pg9d z@f2I4)bO`dNayYC3GwD7=A&~$aV{}*JI@QS=Euin4W`#c%i7CBpQcc8`CebtKe%)( zvlBVS!%%dcfKJ`;Jx@FNj)t|R~%&Rc~POW~j>) zXC1d+KM`E9=|Mpxv zhQzMP!7OCBICYd%#?z3{NZxM6y;}P%iSb4XeNzu_`dO zf4sRSU%&V`g;kRQmJVPc4M~kg175W;QZJb>#{_zUF;?6}GAkx=LgWT6C@Der&EyFn z2f4~eBOYNEid}r-@3u>Qe<~9quNcVvQG%qkn7Wmq!AFH#h_rAlpE>b{bG2Iu#>OGX z3`EW0Dx(5k#)r-7g+AL*#t@k;c+DF;ytLk<4Sz&W12>4KBM?nxV#S;q&no)Xco2}2 zw!kCuCKsOcL!tOVvu_coz$aso7*Hb+5#y^o;6Xj>dBg5ySM2?v>!1EN*qYGD_(|F7REt@k0@cFrZ#^W64O9!*OTzVN=q&1;xA@s}p={~jDJ)IX2By1mwE1SZ;_IsN<4pc;c_6MiH9iuugpTX-@A4yWfzy={agi@5V9U9 z&m9M3%z2^mezjoUa29cJw+!Sq8O5S@P`em5EP*JhWKh^seM`{ZY`t<_cMzk^jd5`D zs2+VHyROfGNvE)5my6J^uw&-+C?2yw?pMD%(I=_v+ZixvQ2gV*fqq5x_F&*K!m+#; z)~~svp`I>Onz{vG=Ss8k!AQ4DlbEjZd>VQ~@Z96N_zm>_Djek^omr^y9}^UCC+ZsF zuH#rtxn)psNuZ3UY{hHV^yM7&7#Mi}*Q#VMpts|&Ci zaoQ-(N)+dIz*(dc4kQypQ5L!`<5*5P$o{{!yDWxc+Y8tX>OKHA`Js&@=mgk%Q23U@ ze*0G}AJ{@PDqIox_Tf+@SXJW-RQAElLYm(@3q-}1{*I^#hTYzWr=x3QqU{!y4G%bg zFd7Tm0~_>^ReKDW$K62*WdTC%;_O7UJIa^a{`5~VA!bsj=n^RGq#xLE-uC;72+o)x zHhvmnl;C11MVH*-h)`rvw&DR6i>I0^XQPkO(MSI1Bj2Gkk#^Cl35~p2gwl;Zwt&Z% z6zKILC_>^%6k!4&d><3o@))n1L)%t^s!JU!)SZfq^-D-URIRD4_okv9>;Q~?+z-M8Oj{} zbs*}Qkq?FLThQO$yUbu(aQ>AQEDBr=C!8IH3wC+oASZ%|g9_kBQxm|?Qb%0ih72}U|2A%HRaT?udF-nmu^-aujI78 z&o3sD5ym^#5m#$-(`SG9yir55*@CKgb|;sTLQ6~XR06$0J}l`nI;M$Ici8^Aga7=% ze-7aPjQszG{Qq8p+5b-n{}aOh#tOppKc4_0(f@?-KOy`Lj{pC+gg>>sNMoVZo^8xX z@urOGYk!gOfn}<_rr7)SF7chew?d##3?uZnuWtHVpFu6R3v@dPR%@kcf;gn=_QET*um zg4a(^pzLcxf(V51<3PBhkc3djxV%I8%cIWmv^1SF&o z$j#6T5HWTI%i_&oPc% z`wQ)}ArDfR_{-j(Dxjseit&c17$6RBM8z4Db@qjW=~C3-Rr)tYV#bO#K$0FXD5&RV zp|q}j0pR6e27|YG0#Kw=dxHC#^M83%C=xlAlTdhanBzH}e(8Qe3J-%hX_rY+XlzH- zm*~UbloG~hIR0%wVgO7x_b)+^Bm(=BedK7?^)Fny&#=udRObWjD&@!@Pn7S*T?~1P zGe%Frv2EqwFJkFYdF;H9he8l@ld2qR$(da)+=&P(GW&Q2y@rsngHfu-Q1PMjsCJ?c zFxcM7(2gD-st{y1L-}>kBY!Ir#n8PTG=!>V(k>$=!3-SQ*baRxi%ArtVYMe%DfN+K z4=;c-s2xokXnz#391S(tVkoswqw~md(9mEsqW(548I5Ou8v%?)7^87}52Nw#-^M9M z0|X8TZksR~_x?5*f-o$$+7o8f-;PROnIXj%s>@{ad0()Ak0B^|*K`@QetgVmT=?67 ztRK8N_qXw!(K!3J@siQd#um1!Xd{MlsQ5nK%X8207&z4}$WHWzbPPf%d*rwTlHx;i zEW{weU@LXG9jzr&=}h|>;^N2(bF|axSLqkjg!~~4NZ$VTVj$24)j4juBFE>EBeI2o z$>J}jXAGVD`B-tHro5k_4j;v^fx-FlujkhWuvnIAhBI8$x1m=Fx2AKmXgdAHED@8( z-nbPd^VF*_NwmSsXnb_DQJEf*e(VVUX~3Y;jN^kS16Z8F(`k+f5RpBk;6M;bebook znNC1b6G1-z!r6f01sR%bxpgSh{GlTfARsQ_P_5O#4|-;_&Mk@XETWV zd@z&AP=$fLTRF2>cWu`h3^5pGQ*$dwFZ~P#Il{2dTPOJ1>hTwdWQM|yaGxP30Oa46 zvV;(FU1ls823GZX8;$t8G3p^6nedyzz@XN26nuzx#-Amg;mX|yV5TorGt;13RmMQP z0o~FWhOYb!k%VY+%CxMG72B7(lHslb4@dB6=4H>TQ?gb!u zCn|ywm>V=UmN17j6TD`gxz}>rGcnIjhMuY4-2#*i;Q`2 zx$;!lv=I=d!f0u-z~O&k>Iku9}OiW>2{# z8h1(KoX)-Y8<)_>A0w(4YomUD8p^}0E64lmpT&4HY?So`Z=1h>j_1EB=scTbhVrXv z$P%Hqr|&YkLecdRBvnDyY!C7C{egMz9KYyEjJVTgIU4-R8 zPLI;cX%_-FUsUV-ox<6`TrFtN)(`J##hk%JGvbG%se#ptrh7(fm>C2!v`Y~MF78L@ zAKlYhd*CnF1W+}($lE$qpUf|*FU_D&jj!!vizq}fU#fNfd&1xLv5pCiRdo0nAS@>5 z$PJH5?^RPDvY=r|==|Tud#h%e=Eo&q@1X5j47um$7zyoN5;pl@9wJt{#5(WV)kZ6X zcq(l~@)7acGwG7LpRLTG99Q2J}#Ym6Z3ypGL)nMh?$ zq3dYvw%$etZ}-n&Fv>ur#v{D2FP|V7GBNfHrXnZcAzs*>nb9tSVPoE(A)cugk+&G9 zl)3J-=T!A?1sL*3e&~Q_Azz#K{&c@d_jZA9A@=PIOR^_cQ(xXn?cVbsqt<0I&Z^gt z(U}hTC2ZsZ3u8Lju8-QB{dty%y7DnG2oK`s`UOKQ^R~fw&@?+k#=rzUylR%Dx$AKh z>QC&$tEszP2;;&6tsm{mj-%ZZ_}bdh4?Fq=-DHeVf0bx1Vdm7|PF0dgzua^BCb%f1 z9dnNS`|{fw@W6z)8i16&!hqzFFca-Jb)9<&J1_tyvZHNGDqZoU^XT9B`8B(QSr*ep ztfN!OFW7tl)Y@%HXCLo_C(iM|coDqc&8MTh@5)FOG^w|_w~1EA0Hil{d4(;Z)8V8lTume8(fXQWTuQldcWy2 zLQ7d5+6fst*#ez}PIb6mq7x2$R;wHyUF&^r)m!hsKQmIqz$I;#(A-8tVRHfYdl0}* zHc6#yIBjCT`d;slk~7e>k;a7ew=Z?;bqrJGh4DS|oClU%Shf=RIba`~7CxNPtRGh- z`=f>6H*GCphF`15nSSIL(j&JGB;JWiTniUeL7!e@Z|r$e(OqYpV}43$$|-=qEgk~~ zvs96zytoCpvpfmhS@F`u`}|dUn7#km|5=>80I2ZcLUJyXKK-U@^dPN6`K3aJNbFHg z{8Re?w{NChvLEIibCox)`5(%h#OO276)ds=x&##6Wk6TvudHD`=^+{MuN^t3*x-HG zIo)#@G{#ITS*M7<=$z(0gy{3JVs1+`d{y@r`s9~|(LGDPg&h(|7k<6Za!2b}CkL?N z*8{Au0xK7n>Q?qTR_VMwY}~X`#Zlha>>sU06yVnAZ=bckq~vYbx6lZnzcq0|KNc_K z1}$3oAN!hYW&cmYt~Lngo>|u%pHKYi_y*N~AccL`WcVD{ws@gO>AtV)FQ^L!&(ob+ zA%N)^^A&7zEH{)>`}jxM9xUsMI7y3*{w9T*XP)r1XV1UcbeESX+(oReCeM)~c0rH} zFDL$XuU}&pbr}x$&P_F#pJi|=vjvc>+M(ttP6~YPa>Pw3E(5!VoxTu1xw8$8&2!G6 zG$o)k!64+IO%FZ)bycz~%<27H)Kc)i7WMAC5IR8&{p@GZ)(jtXR6ts3!YhI9wz}{* zqIb(s?@YJZmZpjEHpylxI^YkaA9%;H%VKUDNEZR=e$_i}@er5L^D;vs#!klxUMIur zX?VST18NMKN`|}~kMO9MB9Q=h;k&YH+~nel3ZUB)`p!okLys`Nmn&g%$CSg`wkrOaVVDIUyNBHynzs_GM_Mi+wn;?IiTOv4wXq1Dw84#dw8dvg?_2U zUbtwA{Ifh&QKDnxp`*wz=;{XA)gS2UpMcjHrYeejcdI*ec(R5#S8MoNl~I$)K=s_s zhViV}=uc*!pK2Ht9^)w|wYu4r{5x53{^)7!_$y#5?KrS?8`N0kcNQD8IdFiJZXR%k zJX?`dKdN=pYn&fJ3S&DGtj62+?}|jamKR(jg#3}Ta6oueTqB45AL6ZAoA&sh*k%}SM`G#?e`7}~)23Io z{m}R!JLs^w(y->Ee6aLLUR}IF=}^L^>85R|Y79Zc@wr{5TDNd3ti6T6XSjU_pCN9J z3-VbET_GD955Ac3T3uPXJK^WoOHk&>-F)pIMtFAC&n2?aVkoPctl|`BB@H>kFNt3j)CyPku!{Iy`Ehxb#i&n+0F?#iQ`mbZ_~!`sOZPsC z^NkMspm9=NY{>H%$4TdBp>fqEid!EyT#cA?>=)E9eF@Ie4ecip`f*;|k{hf(VY{j{ zy+AF!tZgUVyM=&P_6%F7V2yh8+s|2cjZ=L%_wcQ01r3k820dI!GcizMpKtijskWl3dm>t!vDJ^WPn7?poI28t4fT0*T% zY-AUO+gP#g@4;YvP=l!e$1u%hf&Y_}GHS9CWaaq_d*{G!r;3ijAzXOGq=eQK^cZ3++DMqaFS6X##vYcjKS$BQ_WKE_wVd@uaRWV9@iTC6))-)n=Jnws3@#a zs5}N#u|@Hsm-6-v8}@4_#VqwoEd(D0Ti`%ULj=_B?x;>M81X$&%Rks18nlPul7;ZjiYAnLfQG(8fpp*Po8 z8+G415B|0|V4HcFPQskOzt6yBDa$2q?p7L+ zkPeYNnxk9c04d4ifCFg|L7JnUz3=aNJ&*tRdhyxYot>SXnSIaf&f-&8LoQ&EGM+_6 zfJLdhQbuQ7rTapeD}p;GMc78?pDr5 zZ~vBR)(M9nB7d96vK!yT_iI|?#2!+F|IGcPSLs1Z^2e(i@A%K8dCS)LLF%HGV5pmurSUrcT+F>3OEilZ`e)= zNKfLFmetoatb7&&>dk2`Y;JD(?U+wNS-S2Jn>3N^UGv{Sb zHr1BBo%9Ltw$@+9ObIR)CxM9jkSs@v*Xl9O_Llql>2clq#=-9@^Xn#)JM$g@X)wf} z2P|)u(!#JNO;p^?M&!qy*F)(Hr6nB|VRLvCTz27GeBnxzPu}t72T|nxyl1;>BSo3T z=;#T@YuvCmpcOB^)rqgopYI1j&wB}Xi}JzOCi7}k8i1Mo@Ic3=-P&cOb87r;m-iy6 zqLGPT1h`nX4|8n6k>$y&mX6ga!SZSey(*E5Z<>zR`5u}o!thw6_37gAO9h^aEx6`^ z_A;V7Ql;>xROY_fUE&$lzWa+dK>~{CLnB%= zxHJPO!1v$;I=Krv@t-ngCbSidUP$^wU`1LM zYW}FAMq$@7<7VwknN}2uI!KO$G){WfLo~B0#l%QICw6ZA6TFg-d~Y57b1?E6I_oC> z1S+!oN2I8ls+F%5nzz0lDr6`wto%zE=9nBZg9b>B zl?X0F_vj{7X_)~<*yP)GVIXe(xXi`Oi*fE-K`x5N)9Yfn7~+VZ)Nz!|Z$K)j^~5gt zIL&=4;w`HTg1N;?+md4NzmKE@kW-1?2Kidl^Cw6#%nn~J=o(ncxhx6**suShi5(OF zDl8Tzb<~2Ira@=Pxn6-FTS@X}!OOyeVTR59FD*azgRsKPbuiRFvE(MkCCGFWkkKE3$9nq9g#gxNExx95 zLNdIMxt@J@BYEddkg0t%yc_9cZ34h0F5VKncWsUmud8L86|DxJ;Ta^4qx=sNg{Ul9yCc>n!oa5r6hjIf7t1X? zgjn6vLwW1Lf53#Xg{i7#ME^&zN~@LzP0L*T2Jl~KGVn&CSH~Vj*HX5e%HqEtuRo5X zWOWCry}74loLO%F_wS@&Bs`2;u%x)tdq*~2K!yhWYBxIswY*s={2vTg@Ke0VNO&(n z5qac|0`vix>OcHb+nTjotRPJk|7Fq}tj{aFNXh2m*Pv!UR5Okb#-Ru+z$2`(l#+gw ze~0H-9)s!Qo66&*JhhUz*e>-7J2Dz%6MM6P_KcuCNNa{<=~p5`A=gRGuD315)d@Fz z?pFpc%O5bBe}D@s0bXa3IM9Z$MJ+sPJ({bGE4x|weYr!D8vGcK4Gev|xOLJ58Yo-O zt>-l=CQcfG5efg3_p}?c%*5_{zCvLMyN_FY0zdd_jLif5yjN~)|cCm zF0Oz4N`KHF#}s<>69q6)5Jd!--WJ+4o^S0UFdQE ziX;TjveCJEPX9C88>K(hLd~5bJiOVP{zJ=)@K9a#<}VuP(B@WUx+mRRclK$3o0CDU~r0m@80-u5yxKby3tr2MFtX; z-3beLOZ9065Eym#Oc-b#s13GJ_vv^ur!36e{k3Y>O8ed}438%2`+fqQg8*8UZ=>}x z>Yx#!59j{?cfu0ki8MY+n^*9RzcYH*%QAI5Q55;A0xxpN9z1H+5WA#ADudD1$S2`S zE!T432TCfCcZmm&#I63eT;=Xj-j{t>;KkR&ie4^%XUofwO7Z1pYBBTO*0$^TFCNNKO~CX2|n}2 zxukCAX1cG*{i~k?PTMO20%&!RQ31Md#oFzrBGa%^k&sEj#WI7}eYp7FV(^iV{X(gi z-}N%<645)ir_B}OrR!YH)!~!3cI`*`zct);U?=VW3~^izMs-o+)qzj%cH~z^7~R*T zf3Cy1AP{HYQ2BqgB-cIu9m2$aDc$Ip)>7DC!k~sS>$2Tg6 zS@Gt>H1i5Uxc~s5)mr(h(uJryonCG5J>&oeyq0!%?3FoQPNdQOPFEMq7lsBJguwOC z^gk9H>Kj9Gh+35Q6E-yW8!i?WZbC>F`!H>?&Xb7wVf4cBJyUJ5nk9x*YA%-Nf*`{h zw``x&HjBu8dM~4~<_Ku-C;dP?S5LlnVH5)t5HgNcKFc3glJe*{pS$~IH; z^J`O|H=iOIGrEziaZx|v?jYa)I^i4*P_P!g-Ig4f-O0psI%ms9H4rF6s-agwe)sE# zM(r?c%90i7&@!_yw#fI(nvnX&@E5+?)wE>OV9v_8a7rqu?S5y~WVAiE^#~AD3cZKK z37Lu)KURWKkMF^NGTQz4EZngATYSPBB!h4xRXWcJs(buv^UsfefWkWw$A>6mdmKZd zsf6wRoK}o+r{DBRCYl4J-rNF^eTUu+=BGCw{&Ks3{&;A!M@b4#o79JL<&T|*6 zn6)Qg@4@TgHzN&;OmTgK6md~Sc!8Ksm|t8<=qIvQJ$kJv019+A(Vz?PLE<)Jj)&e) zs2Rcz5ZL>ksY|b4Z>@h z`$2@n7Ow^2ySLll?2SvWet#6Lr!t<`dZlv?c5v1o1r%lL8%q2Zm~`#fdC;R$5`T5o z&bW6c4YgAGY-(c~s7bd_c_oBjR@iy#B)FH<2q#r`k9kc8uTMFydN88 z>A{e?V6cjM6zx~CBN@}L13$^+;9~JwktG6O)wC*`Y6f-SLs;DBWe>Omy%g#+8Q3O# zyyG^0k8Iy$a`^Gih{C7$Dth{!C$#WrK(FE>{1FW>LE&_tWgdDDtlj$lUkAci?vy1D zcE8uy%hcLyPBF-S~7T0y}>xQ za{3-_TJd&MtkJ3tC z1vyL>pi-Mgu%4_(?Y**3Jf)=k1W8!|_gVmbJWp=$iODM9u z{N8u;skQrZ`Ctl_y>E*P7}-Z3m;(L)Gwp;YG{ckY)6zYp9+KgGv#wRW&Rz&Y=Z7~f z+8x}6gZw}A-Qp=Nv%j}$5NfD|c#%MZcE`u^{ZT3?rB5;Iy)>&{h^L@e(lI>|aBgGA zJAXIU2d{9v6Cd7=yt%6X$xtcAzOZOH64f<;A1;UIhM%R_LAsi72Kv=dje3or?8SAB z8EhTMKEk^gNFO#!yaBw7+UW?wf`KOuP^s|dsU#iIweYh70qhv>DEac z6i>H2wT+OQco=*Y^n=BU#YK_gclzfYY2Xq3_!j7kQ0PgTl35YFVltq$GTp_z;i_%s0Rt3^F!pT zm-to8Qx}(heO%HhSVv3&1}mbzHC|Y>qTU6p&Z_OMHl8_&PH~IQEy-#oY;+1(>4_FK zwBr6#1_137izP#l*+;tQK1Gg+&W!A>{q+}{nQyO?)K*VOg)KYnBX?r%mh$2KPP4l< zREttiSQ`$rcLrDT?vszQf)1AOJh|^8D1(JLr!Ove#y;9>HZdMMXKLPm&~N0qA+)c8 z|7}kYZufqsi@1kN@tr-y0k3xkTG8hGpn3l#4!@VntM3a)9@&7CE{t){#%FBvd4J}x z4!m%A#4s~k06$4pj=49U^X z^MlS~K1!F?hRb8mOO87|7z}$`0~`&Huyek60!}`!A#xny{Hwt9_-UWh8vjUiHfioZ z!oC*$@3Ulmor%tQVoPJFxx0O_Ty0T{&ZrLD=7OrFe;d2_55EcrKJWfX4|n@KNdMlT zMT9ddw)H~?)ZE>g_B34ZivZU(A%6wbo+M1~qim~fYk0p7QYC@R;p{=*Zh2QNt^=yL<426%KF5PsSdk zpACzPeA#nRzgAA~U0a3wf5K>)UGlFcwRBE)ug6K`NR{nb3=sVF%g-!cOJ3;Jy@~m_ zAu6r5dlZ2nnL)hh9x00tm-(GZZqh5;-WrmZQ`DyGE&(o|#jZmaD{CtS0cAp_YX=}w z`b)=gW^hC7YHRO~hw)v)nNpq7SGnP0x<|+MBrS`uYm-pc)FlLCacif70QG|m1x)KV zi}*pLubZ>f2qH(#GJDXa=%9F#|7z3c0FJ>b(GyUfqnv&g&wTBDQ70-}fvE2?%kd#H z#!Jgza~|&U4RXLm%GJgcPaR)p*q)#|T zbf8c7-Zqk3bx6m7n3U=dj(^R5v9_;Eedy7N;rWDy^P3>AqfPF7yua431$LFw+45vD zG1*o9j_ryq?drSqqT_o=jE%A98(xt^(SI{q7v*;Vb*}++fA$@xPfrsqZdQ=#)rxt{ zNW@W|vej}|%z2;K^eiw3Ahr*H88{7JsN0y8o@G4bUyT`X-l4v;a=tz zohw5dv=Re!AZ%(3_EQ!LTZ;W=IvAyBkeP3hqaNDsOTS3zJ2Z$B#)f-nZLH8uPQJ~! z9{gz|5I8`a>}I>xyJK(;$udNd&wUIchh30rJfGS7%Xm%<@+vj$WbZo)3g|mk$&Z?Y z=&0qSn@wMQ;TUntMy@~ZK3=>-Eh(AK2OY}+Qkg7xOo7XslHO?;vZNY!RWWt?8aG1-Vfv2M6 zwGHk%$5oli@;}jUzIi2VE>)U(6U=7Z-%1gT_r4y8^iirXpcSCL?m$m6rMvqjV)>-J zcgx36kzlTWE3b3U?uE*BWK+?)a8&+Z`X5hcf1I+jlX$^NqZCejUiAC5;Y{FLO1VyXFKDQnVc8D z;&r|6yOZ36Ue@*MMYv@DJs-P~g>GDeXHS=f2hWC;mYR0bzZ zR=8A`WUW*z^}V1PWfz{{7@K80zDXTN<;``Z$)>{9Y;S@yL*99|iijhf z%PDars0J%r8@hQFX;;C|F)eQJ^X(80tLrlKnL-IV123fwxP%bRHTihwxD_ zBVQ|}P5zZ&Bu`n7mXTgAA#Y%M{dq38fpdIHt6mQLldp zN1`Aq|I#b-Ax=>#Yy{axaV68Vb_5iZQCPIOXq$2I!)k- zFKx%S9Cyrn@%}dz#!9TI`QpeBw%?7qL_-{)tVKUv>2R#VN>%@B@$_Zq*uR&gafzwt zH=2qD&7JK;A{78DM&R{1a@fH)&d~!b-$vF{hLo|im2#^sE7?2Brv-^w;Q3alpBZUz zT$-!H0cT0K$vN=?ZQdTR3x48Lf|kC#hlaiiKbR5m|4N69YT;Xdiu69n@V)X1n4=+l zwVi$@-Mz_kS@jl2mKmLE>d*5>ycsYaL)|hom2yw~w54@-z}x$v+^2QinB?AiuBuc9 z;M6X{w^oirCJf%SNmD#nc=joQ+LpX`M~PDQMKHzorqmM|-M7-|+Zmviqa4S@6BG%G zuuYX1%2kaYRDVivju)UVub5}~BMWUYTe_AXmegovWv3$1SSfd9WUcxjRWZGjWTkWdLiB7pucC7^aKBn)bi@^RY<1MXK11~;ZcPFP zbNyA;+!lX`9plo*4r;S~*igplTCiWk`7o9f(0I?K)QUd(*&OM8bi%Q=;%Qu)Ng2@H z%F|J+^N8H3Z|2^V5!IwCp?dVQ=rCtd0Et{>|ZF!RK8924VjU)3%t^GSM^Bi2YW7mHe_vx;*EJXiOelZdY3STQd&6+kEOgbQ>N_)9;C|!uY+}LfhU+Dy7|{G z^_w?w?fcvYIEH=F=lge$V`Rf{l=l!`AsRdX@xiIQLFO&lx#~{6ZGN-kq1UMH&eLvI zB>Jgjro-SO6Y>TJai-vx`wGTq;Sp2?HGk>ld)&Ze{Cgbf{*JieKE86V*(AeM7rw+i zrP@9WQcro7oSh;4Ly2@0XPgZfwgDIxNU3EE-_8x&GxjaHzU-iU{3$r*=__ty6aOK3 z79jZ|XDXWnsVsRCx6OD@OF`WkGGW=7r>#_CV@l!3O&y?bORpVQ{XzF+ zbe*MoWt7E5rPaYTpU?C#%9%AIn8aa*0iLUs?Ng^rS$<9ockinJi6Ck&HEDENbz*CA zpUY(>M?+advQKCsjf$XX z>5ZV>@!z<+)*CaL)Qs_8aV@H?11yDQeEkeiB2buZhoiU|%K0np;ED1+8t(Y!sHmtj zs`V4kUyo6)H!Lqfbc_)5XKt_NY1Wj^ninFoiONZwd)}HqT&Y(oDLFANmpGQP!V<#T ziY)|=q5JI=M6w9a5tZ(Qom6l)-jvDlTU(WK#|je1Xe@RxI+!MiS{>2W8$50UY+cg!-V!xj%D_uWP&$ z;zi-?U}zSin?-qdy+A!`!qK1RXu9?W^-Kk9U_yPbepBR52Yf z1|}|KP#>`98e@u$?St<#xhM6C5P`RWN<~6GYxeLbvz6vtWGpl;NCzoe5klrY+@SIlJf4@o@ zB6=ds$STW&=g>oF#{SREnMZC>pF*9ME8}A@e_onKg}_rCu7`-8snW`V7to;5-wGD- zs{%!zX{W{}qIIi8yvFtHTvkIh-4lc;vgumL2)5I;GZ5L4MY&_}{*3)GGmZ67O~Dls z0SQRsXEP$ZMBbzywzlwX*n50JF4tw!0F|i6cD}qxl%)(5%sBsZ)U2qmInpyq2U)u% z8Z|3?u34)k^LEsl4ardHV=Y1xLfj>)>msj=CuVNqv2=G$ktJKG(1iiD8@9$X%QuMA zuqxord+`>6*GvU>2*Gux@AL;YpS(-&y|g%KN9kTtQJ&Ccl6pBY^KEui9^eyyK~ zAd~9>vqWx0ye*~t2Xkl z104QGMBfoqVL)p}@KVn=wsGztrh#twiKR4)Cbopb>KfYWE8!fLPv-G9d&C+(< zlwC!O8O{FBc2XVE2=IVh+q-zvAkCZ_bRwueB*I*|gln*?Zjtulwb2;ewYtz7YsYVv z@;VA7S;Z(vrWxCRf@hqTc02M3^F~N}NA9TV71WzDG}mQSyuSVx2Vd;@it%eQkzetKV>45H&}=9+t0tj5(rCtXtzS00R!DpqTfjwyA9o^);eQzmv|W#s;h-t;Jk)ENE~w`CY}ZiU;~;S z7S;4ogQh#r%U9Th`}m5{`Zc4ou#vL<$I{U4j#Q9c9D+N z_pZ#{i7ZyrhmfEI@8sP6M+3VzKA@ialHguZ6?e*pGd8uCOACWmX`R-lXnF!>QRS>g z-jv;5)dH4bXS}>>AZ7KSJjK2n(_0cMZC2JE!&+)62W%+egs& z_WCtY^3yE6ge<75=6#kgDEX$L*XlMU;7C=BmiDwbUQ3s;b{~LWA;Ej~(DgCEK|0Yf z7n;g__v3cAMunk+SwmG@(&L{si2@>zUi4`s0!!$EdjYibw-FoZjg_3Zk8T^BhNbx< z(Wx8xoYt7V7a;i_`V&{BftbJn66IaFe844d1mCH3yH zA;0`;A5H0|$oYe^G2zcEeIVqT@I@`(zwXP{6(uiKl&QYF$FBjEMuy5B#}o-*&q_8Uo(H2 z$smt(OAm&7{D@E(zNmkzJv1IW&>^z*AX4Op27p;hI&=9x%y*C41o{ri`OLtyOmCA- zF~_ZMFMQ2Suydtu`w&Ec-$E%o-h9C@Lz|oytftS5UA^Bidv*O4&aCO{v=(IkQ zlqF{4j%B0ct?O*XY~FvZbS#Jp`DgP@m8Ed>|y%@a0>J;`xp}*A8%jHC%teP@JBbFWx2{wY`B`@1irrPh!5%sV<@5y|8q~Aek#2ML1U8NvI$T8&es$*-L3uj#PQK>fhK+f2(j- z`kQH^!S>J67ZPH6SCpnqq%RGl-RO!Z+^c-<1b_000fKiKcXo#WgHQ-Gw?7Mx<$K+{ z#3rO{uszMMR8rm5V_TWQ^>k?E1sz?~-1G2ZxG zo!Yzi*7{4IXqW?aT&pwiDlg4wH48OX6=VD1&e?ibZ7qM4Ny!s5Bmhx$WckxwEWMDvR~r zUm5u@IQMs|V$)pKzsqf#t%Yo}rP;H)UME{0{cAp36i+1Yo+typjNth)deOKF=~rLS zRMu$5h*?&#m9vYz?+fU^pt|sQs7fPRqS&{8bap5}$2m2*Gd?5`9w650bxmGw0E7*) zLR31A1q=N+{vD50apVm;m9XdM>sIM3y}ff_Ze9E|Z@^8tj>PUj4V*S;G0gr}Jjt2@ zlvsy7DYcu6JgCP$ES!zS&DNPr{A^-4G+Ih~f-QWI~Dc{_BO!*qAb+MCbaGK4p z{+Xz0eY)OGgB0vAk>}rXrU#CTrvi&kKA|`cW~e{MaeU*;rz|1H<8Q`4pnXvHxb2lIJ;8TccZq~lCDXDAOtypLXA(Bl=GoH+ zvgvq-b=8Cx$|I&iPv6J6&iGc?f9{gHlH>y=06cv@vg2=mZ+q%lPb>Xx);nP?LkhIzk!#l(MT50#>ggn z^VcoW-}dnwh_8IQ7x@Z9Z_9-B#~$%mw_ZB^&iDYTImsdO*SXyAY4J%vz5OMgK$z~F zr@k14uqq_C8!(DH?RBotM3z(?zzP3_i@d~J64ZQXsz)j?a8>Nxf^m* zve-JAVuy7Tn=q4;M+FCuZK(746|%AxMl&3)U8=^{ZYOe}Bi7}A?!T3@ClmAMTZ{FJ z&8Tti7Sm8Cgs^^_X%Z7r!*}xJppOtl%PkDrj*nd|-nea${H|d6u_NP(!jNmBaPn|M z-<2$Tz_XkWg6%G;cZ97U@!TC{G8(Wje2F;{C$fL@G)Ql;>XaW03SRq{{Yvf-tb#zi z9D2>MCBng+utpX~UIrLero7GhcZQMQ#0gN4=t8=lx%BY`meQoq-%xYWMA`a20l)-*}MM{po+Tc5_2Ex=9 zA4!(Prhk|4Y)>_gU&=|%lEt21yPV}o%jUkpgCTLyqco^zCp-61DcC-TN}l9Q3o)Q| z@xFLG#l}l)y1zDV>S@FE;<43ee}t3FeX~n9wk^5Txul7&H%*2U`|LkAmxrCb*u}<) zIbpPz1sYUkOiP6G^}z6FpvpHyhyF*pjeI4iccw)pOcf~k*JnLbZPb8q^C782tJ?H4 zPoZNZ@n{I~d-XQm@o!wvjXH1D6^Erk>wRcX#JnDeK59i&>Cp#YAyR?0FOH)|yPFRu z{$cke)2vcjWt>+JO6OxT^zx0Z7uqIE0CDF@FC%r}6KfKOM)q=gJ}+86+*WilFTSIY z+P^76+If-k-FPiAs9GjXfJ|ur4DUaH%D7np4e6xqU2Q&|4DvK zJZ><2RGHxYW55RqB}n$B{B&Rv_mo7@<%ZNYqh~D$)W;!ZwxS16awb?+UG8#fId&Iy zd$}YZ?a#aYJBSbv=7=jKnSEfOf)>gD^W#j$&^)uH#|QWQG{n8M75dXPWU@h_sRnw|~&Smhd!{X)Ma ziM**p3{?SpG?a6vc+&TU&QRvORwBjOHK-aNwTOtH0DqP);9EszHau$?Zs=66F`QI@IP`Hi_4kjL}^{3e4Nkq=hQ%fh15 zO?YoJ=YaIt*(lE#5rnxt5Zo+9D@5V42#J9GXP6hf0ggAOQRMHfHpbQ6D45Zm3>YyBn12< zDRl$&9LWt}*Lg%pj3b=p+mW_}S$e=+c)BqyieV+5u;S@XoL>$i#` zmDG-D$A#1}Lk>coYW6%8*TpL`Wb7qjWG*4(L7cc&Carh=fw4uIKtA#=h)!(1Az;xM zZp_rn_DS#4Z*=S&uP^M|vEZ(Wl)iL#cMb9ETLj(_LO$8la<{>1FzwyS1Z(e-Ac*S=5>lhJ( zzMNmeNs$}9%t9`CjlRY#$-aZ1M2e2e%K-bB0pf`%AfKy^Im{K?i^JB(~nTxoSo$s4&4#1!?Kecb<|93 zF23vKr3$TTDR66x(_@__^(3VpWqx10-f}O7R+|>;AN+^_?`tQO7{hypYiW`&DYhTl#jb{X-)q5d2_Warq@rl>^SCOQlTlX z=o>UX$OJ-C?IcaGCxdcEAddCbP%Y>?kR>sYLnEs(T)1Dflj)IVGF;yHV# z`vQIfs=&~9+5!dFxVHfVb?#-ud~pRu0#~1$4QBwB+$Mz0dDXqn!h{0sPFFl2$~AXm ze7oh6PhIg5dQS-w2EJ)JU8zW)EpkkZ>Y&MszuR9L^j1_`d165W@jYk@jV7N+IrI@p z#Y}ajw@H6BWo&21C~?bD8o5HULPX#W)VzTnm6nf$siPuTi+g9DWaFfDdl1g4lngTS z1|@G}oe-*9#P=3b)bhItP6(6OWlwxYT$av;lxv7&DL@ZQ^9G0e;Gq3Boy5xoeCDui z`D3QH4-J8$VDA;{x^9^I&rPS&0E?t*<+@JGpc0?XVvN8*2);f3XkI034V3mXSrz z!7e(=VM$RkhVR(AkwF;EG3HHWcz*6tmI!_5CA!Rf(Uzk772(=W-kOps5$T_h8O+P{+<~k|>(e2cOuII6mVs)RD3< zf1e2F<19oA%034Y1RNBWt?NSVERpIyO!zX%PP%C^DpP(BoG@PfAAO zf(nu{<}#iWns~iUfOcG z8yzC|-kbH!{ffRc(fpQ(NF-gYRabf$t)mJlzB0Qa2Qp43Gh*!vRUBryakp0&Hsbv& zyaAA?_?sC{CR?YgEo}r4owYsJ0ddqDwKKb&O{42RD=)+>F(p1qiU_UxnXfyIUx*~# z?wESUWn8$`kX?HXQco+oe%NRjEtnbix5;b;IoZE;TU&WGD`-D}I|gQMOmWU}qOfU@ zzO!R>1{Sd-Qtcl{-bwnq!1AUf}*(?+60?Hyvb+gI#AF!A69$NGi^ zZq29hYpi{}>z>&5jprzmE~eYYdA>{X&j})7t}lR1&?APM4Pic1JX$i9>R`_9n(!;ik#@io18*InBW}cAL+BS@fIITGS$P8LESg|H!TgD z`WKP!X!ibvz|ER8-|c`xOV`U{bie>FzyRfTgss0C5NA!Pzk=ZrwFymQ?gFa|*gQ`e zod}wovK~KZs`Q8!WNrvv1)lJhHUW$F#CeEanS{#OxX-2iG#;Uo^wBS|_WxXWY_4v< z9uA15e6=TZd?zS|UM9zR5_-&K#@mN*)0nuSS9eg^*Yx~rh?D)%!$vk_bDE2Wn?xs3 z^f9IMQTf1wDqR+o}VI?0}8$Y-tHiqFkw4gG267u%|s++Z7!5A#T{dw zEbjh%heGBvfGdsZ{*?D_75zmglg!@+dWAmJ8IrkzaO8vY86`>$u5ff zN2P^1JQMOuMZKv|Y7v%2k?a?p#fY~SaY43k0x#Kd8F`KS2pG!0iMx~#S{ubqj%Ki> zb6e9}WO*3^*T|RQ^=q-$A(GvE=3oYb+Jg-lYWY0j^M%To#~jQj*2=bS*#}PP*rYZN zInZ;x4iQui0u3d}PMa^qj3o4~l(9I(H*HG`HVL=|$OOhxuCKoU-efu0xh1iJ^DkFA zYU;V=`e#Z~W+`~l40aU9l1NlBa|pam5=+l74rSRA!t`g_H0lmUkIQGG#6W=lIWJae z?d*|8F-1+#Dx*0W+W+O5AwcW)zdojII|3wLE#ZG*wQS^|eZZ zs`5Ze|0429GfTiC@`=kmwNGKyR>Guw61Fbc|D^`_i(D;l|A3z*LurC2(S0{c@6XM9 zvqugFk()UnpO>5af#B8osj6uP@tpag6NcUiJY?k8vV8-WIM22MF00T06Z#meW}=fl zap+h8&uq5ChD_P3$ny+)aaJl!$7}CKEHCv zcSism;SfXw8Xo}HK}*%8OzM^x@8kBcJqPL2W=!a9_FZ;QqXURVc3R%6UeG{>)13 zCMRx%rV`u-7RrY1%d8!;pFOG5Eu1$hEpUm~d$3vfBV^;eE>2nxMY3?r0pc5~&-6j^ zh~zL`sgw(kQ8C7;bJ1p~8>_OFzU#(Nc7ioLVimJgmBE?Z8T3ek%84#%>%#+ijJ(zz zCc_^uX-O>!)#r?l1uz>G{q=KP%w?@VC2U{|I#!^7bgt60onDfdpL)?zW5yK*2M|)j zUqf;<)${81Q)0+lPVVQ&vw*{8@_7S|00pEsJEj!h3%-Sx;iP7+#&_fjk^gP(yW!Al zp*&D9pTPJn(Kmv3zHbipgJlnNI&Chg1Q{BXY}s73&VF zSWDS>Lw&#E&QpAiNj(>-Z4pnJm78@AZif}B`<1<(e-6%9`k(wMGt>mjxGMrfD##~5 zUfPcCaO0i94gZr@`?Ch9gS$0RQX&*(I3*BZdPfA`J|z+&rI3fsr?|~ykaJ;our^3B z`r^ZJd1SizhRn944-a%-f=QET`!|tL7<`3|F~BKmYfJvCYk65$_?VX+CnixR8iFE$ z_g1DZxO)%Dt^k{7mT9GERrVMMm?fuSy{99erI)CYui5D(NERLNjmuw@C%HKU-XUUg zHP0AMp%H!%fCvG(1hzN%s{(pV{XS1>UWUpg>1dMe1JSA|Zli^o!#U0&FQ{>bw1NlMpJuLcsDbhBmudpp@!i4M|4Z&H5l{mkyy6r=9@SRl1Vu#}`J_t8Geb8WBxdhJse z%*B@QSX!XnvT**lYu+-lN9tWrBOF9H2CSSrxe&N(d-Yp7;GWpka=9<$-(sU?$7auK zb%s~Z%!*gU*jG7hv`1B?@OlbtfFf_vsXhD@*UnlgC5-zAXCej<))KHp3e{h$9Ja#@zF8P;(%EY^FnDQ*N-_m8di2Am z`Yl)jGgd;_bw_+J6G&5+M)gfx?tg7KF~+$ZgNd3QzO4X;xo+-MKxQ`DlNTFhk`8?7 z#-cZQXJ&sdm9dZJdMrZGpu&?XjXlM_=+I;$(@aK9M9Za`iG>WZ4Tu zhJj?hqWPFQsgl=1r8%y{CoLC6@{q074YJ}dM$1`psK<_*Ez7X2Sln1`Sj65&)4v#x z&$wRfC``n5@m;i?2su#P@bU&c73?$GlIT6QI-IYddbB#rMKXtxzieJd*)&_17GPXF zh5lKapeO3}ZYP30Pet`5>=rKEVk5K=3@u4T` zKn>NE#(&SJ^tnz|i?86>>1@05*=Jmzf`}S%a5E%$p!kxu&67Kcj+5oA`p}lT*3D#m z3Os+ri2-@Z_J&ba-+W6Gwl;Wc$YsakEtMd%Z}0Eo2KKN<{_}Uk_7w4b>|0hC+&??(nVwN5(A+(&%gQpHgO@; z*k9DAZJQ#El!tk0Zrp=~`ArNnE@PC+B#!G&aL>CErzTspAb)zbNO}V82NjXNbG5Ni zFQ+^Z#gir6Mfp)_`KBw)k?o;l@J8E=Us{b*@Dj&H&0uKeEz9LN~Zb&>73S8IiEtlBCFzkZDgSG z=#S-G5M5s!$+0}l#1=D=fPBem*z9BOSgc1?Lh?F5`hLuYp%Jl-*BywHY%=Toqt#-2 zOKeoq==Dl;hMuG8MRP>|^&k_b~dt{eM3Hm(RRO z*LL=EZRfs@G`rhPMw9DrPw455{L|kAqCn{_r zEw1c$nDs;3`d=nHZ)+}0&lxnH8?I^Se#yZX^*gso6|oR~s+VvBbgnt!c&k~^QROCD z82={Qz>!u9=jY+4m<^I+iv`@&<|~pj9g)WZd3sq_!T#^Jdq#4!1i{olTU~0Vv-oVh zP1KdQ(?SSAZ#n->IA)k6z}e&Ua;oj&$4L7b%YEP#(a3?ixzi!9X=h2ZO z?H420Z)%kj%iYxJ6}X-3;~z{U^7XdsaY#1F?mLv&$m;x`S;G0Ja^uRZqOQQLU)dZ>ebbR$)sSDeP0|}z<1vyVtBnux`w4vYEi-0CpY?&#Pso~d}@ncWAa zHrIRq@_UD;;O#7qEhUyTwbfQwjw7M)oDoZd7{^*?_WSBit=O6jlUl!g905V*Il#LkD6FQ1m-n6H{crI_GnE!#J#&%A$a%@ zrrT_MOJMF}qrE1SPfv3fyw97=4*vY>zV__v$tYP zz2pvC;oWvE>^&yL^U93+{?*yIjKrT9V#b!hxQ>(M?0FU1C#3JqC#}!Z^9k{n7Ka$c z7sR25(_U@tY*O{F4(jyJUZ6M|62G%#`DA4Z7zcLqw5HTw4b&cYR2ngYhypT(4fm~a zjf*C~>WeFu01rQedj%S*W$<;G~gY9GyJ zVukkxDCurmK*4B36r(;y(K(_r%}&ykIioPZavkC$6Yd)HEIHn5YCPl5_+ViW$5KvK zSW`bTdCLoqrALDae4<^Nz??z@Ch?-;&sT(hq~1-}U(@YTxfC=*+xcKCuhJJxIJL@7 zF8JHaA1M<1D&U)(F^$ie_fsFN)7PV}Wg1Bj(Sn0@ zK7ppHJZ>iJ@Z#9Eg}oL+s^glQZCFw+z*$~DQ(iP5mbf?;$jRp#%U`G46gC!q#v0 zd6!ZPGH{c?7w7m`6vCc_^O;-*G;_mKC}tNLAJ%`HD)L9rjOphR6}a0Fks+ON<0N5O zJ^8UTcDr>fNIBe0jhhOE;gE>QWEvo1lBQQJVdISGLh^D_SX>t3*@)O^pejV3-!+Fa2t1B;CiVK|le!hBXO`A-2w7f%RL+(w& zr`gZp()Xqx@8;~fALfF)5PmCc(gLP zVJc;JdPyR83(_M9Hx|w*n}8*P`Poh3+{y2_G0knywRzQdCMobK;*tRtdL^Zx(Ib-o z`G~(ro`r#CndF;WyVCSz@kdJ7kp|GnG>$HP%&+gf`{FX($~Of^dZty0ky8N^+q?|U zID4T4a{b)Ic1oMitD8T@Z@XrTT{w#bCbpX_Mp=Zs*qFcI)l<@La{~f2&Qa~Y z<_`6;I|T7!k5{;zWJhcvBlXD(JxMHucJkfKMaNqu0=0RoKGXP7|@v!N^O!E)2;#~+{ig!Ccx4Eb@*Lk}s zc`xU@U``nB2{EerU}Dhlt8cXe!>5G`cU+73w%&FtI|0)a#}OtG#nsANBR;LbU+vI} z`S*2_y!dwYjqaNzPheI zBTsn9gU;cf4KV$U_wfA5E&-Sr6EVLAOn6|+$I%Zmb{MZ`qR6Zi!2BbWr>2#DTjJck zbMeXECxfH2O*Qwt@O_h;o6h~Kr|m}%kweBGKQi*@lpI;$~_j*0y0c`uVN ziVjDY)LNEa9?#vqxaOBhq<1W9Ncgw@O-k&9Mb1|4sF$p`Lws?G#XEJZrJGx9!*C1D z3;mBkiw@rsAGj_a!?afpa3BH>J9IzwXKqxyk@ia2WfE^y*KC*AQgPs;@tU&u30*r5 z0wH_C*O(*{sB1H>VQA5&{kk2q&EaT^+RWX-aYOv)QUBL5ft0N`p8f7erXvX1BYU8+ zHWu3Hb1L|pS+ zGzSJxr_p}s@3_@P48!4DsQsJ`Td^VMySpK>wmv2+E^4b?yT|u25hQ8D95`irIVS6L zrku(xxewOi`-(>gq{#u!o8_Iy4wnDIr&=>fG)=kt&INobjtV>`bmj+^V!Hzw*$8Kh z7w;03|HWeb1{%fm;-?nHIE=fh!Dp=kv*h~+svx(C_%Szw%Nr@8^qWNil z^;PY*B%{iMI#iy;aStr5`(1JTT$Vy=OW-~lhlcw&NA+0F(Qc0%QRKuu;CP7<>D*ak zi%;j3mdrTYCeD03bn|P2WNvm`h~ZrL72(M{BEaWDVYL`$ zqO*3vcyqfw*=dIM!?UN>ZLfoH&N{Ey_V;0DQ>wMKA&BEyGCpne!T7iJHcISB4KQcl zeZf2~KGD-%?=LU7~+*2~$X|0a_yrNCo=s4@RTV0+YCW1Adz zo%wl<8Ih-*JfGpqGf4|h*;;XCVr&qcjdW|oXMfO?b+8V2*iSi`Tv(x~v33(eIN2`) zO1|$PiTI^K)~4^gtC;e*D_5JPRrBSywO1{z%FBX(eGoYU!3Ph+Atu#RmWljcJH|b- zC1KAG-`_r_b(p{nJS}HErZyu;!$&*A42Ll3bpD`JC*Sz!@6!Zfa=T*XB;0r zS+*j&&q2ujX3UtFD=!@DoocCeeA4mm*-Dqm0~rNUOvtP>2s211?_tML+EexNC$%?I z8))u{Xd4$IWS@aRFH7Gwve;c2@~p+Tyl1s@HiLHTC^%3O>IRwT|;HlqY9$wjJ3}Zc=%> zP{j7koB{;Hpoks?M1AzVLo1cS7Q4Rg7&={2lhC2fjR*wUW(XL6%3#IGQ9`{Ey1F^u zs?z2j89ep5TFDwDnQ970I*K$s`B@o+5benWs$(mQwVpj0=92aG!Ni(wg=??6t)MZr*Kr}x8U(A_au~}Jo&x)&+yFrBw$D@_(9x0~vls0o>$A<-NpY{1%Ehj>* zn32oR!kc{IKzqj#5{6d5)skKwbE$e@p6aCz{Ebx8G{-}D7QAJ)!v{hT`eT`iuaZnk z4A;7fCN3@fk#YDMWpN|^n{A~6JEUP2%v+aql)Lp@pj^z6#~O#Iw8XP~&?>dV z)_h(Mp8uFcc^Jb?e3(@Gv@nZ2F%E8K9WRaNTkW~oN$rJsr3IYQC#$yGYC&_(JE5l_ z>A^Q|x3w$?$r)yt23asL z@JIHnp0VxJFrZKL0noSa2x)52bHClY{Oy;Iw?FW5GdG zG9lc;&{BuHHEDsy({j#7$MnjZjfWElY4)>4b1B2B$C?R7g3vM$L z<(FK0+i|W($r?PJ)0L<1yEmQ*(0Te=vpKZiSqVCrRBY*o^)&)t1ZIzvS&*ixE8(h% zDA(}sZ&h8v{0o~K_uFA+h&N|#Eg;{w5vchm1?=2h_f{K!^2MjwDLllGg@Z=L(a&b* zPZuO*25`2ud&LJXZVc=$|JIU*$ZL=w* zPj#VvIK_Tl{>PT>p}5f>hbg!wYp$c#@48ha}2jB78y=3+aNFiqbF^jY%|WOGzJx)r+OhLUxF82YK@_M)#(dE_zVG$;w`)1DTWI7#mj(VRD5SURjj!ilAv=4k#ZT?< zu@=bBwzVqWfn5SCIPNAo{qQI#1uy+5nt~VLQn^JtILlBcZK&G9XbwDQ>VTJXbR*UeS$e!-M>7NV=8G`&f?~~ z)?a{3*s$)awdQLzbxoGtauTn(2)D`boaesOBrY_ zEg~E$nVM(SEg?=}I=|evkglDdRB`zF$Jr?y7EhK!Pc+OSZhQywFMN7+^LDW{s>pEX z*Yq{V`nBV?{T_?6>+_ZW$Q2c<+)O=TT^Ml5<_(r0#fsDYe9>D8Wh-2f&9-~5Y1LL6 zyEsNn*DTs=1xu=5{lk@`?e?}GiMd-0J#{8xU|vsw=_+Ml`gItJ5?q9p$F$%7HiawQy2+5={Nx~RQL&^cC%&_~*^`=sQRI~9KIlA7yUB!A z_LL7p?uly}@wW0#+sy|H3SN}G1ac-dEFw4NC#HG(XNs(UK@&mONy+#<=$in`6%+aW1ZD zsD!)3G-G|JU0@4K%+O6sZy}4~eUcg<GX9~ZKZIgbCORKSyMVr6n`O5 z3SM0PGQ*<)pUqiQl{>a6+4NnEp9(KrSLPYxMmD0ZVo%6{SMUp-gpjw2po{{C~3`g(Le2pGgh|68B zZ}Ojr{-_A?^<*%yV`5KUn^Ai}#?$^ebo|>Nu@HN8e8gcr;oGNmW7c)!bK*h@`}!Oo zY4Pmhi|b`>skn)2HLYhUhse(ZwJ(b}aMeqtrO}5oIaY@oRm7f4aO z@%h#74FmAepTge2NP#@QrQ&@Lue2OAQn`XnqRF1E`?W9U=g{doLlt~y7-#0ihh6V- zZ!!&_M-F>kBZZ(n?H4dwjHhCkpaCXR?tU&Hp;hFwUM8ys@2AqRmZgye&M+>OiEYJ- zFD}6skqL+1?xY?ni9VEK^Rz1rH_`g*^!2=8AI~vL0@42fQ=u`5eeI^_hCHp;mX=T% zipk0)ehwDtHGVZ4b;UBxoAj8{1(@`*JEa^%{Xy&Qvn0&C&na|id(Y2D#x>RBkNGR` zI&dfDBmKtN<~eP`W(TBBLwWJk0$5ksq7S!`PbTJs|LD3~ABbqKjOJUAw67-{nn&6Z z22kJh(&+~QKTS2{Z)3&X8eJ1+{ZZOM>D1C40}TGE5S73qXjvPkru$<@IBG$9Pk_Ne zcJMTJcf`I|9o!Rj#GCiCgQUf~Sk}u7R5RI1x+#DjwHAcInBAOhQq%s@$F|xo>0_q* z1Ka_{j%PkJST*a_h;cJ1sCVIHfmJ@AEr;h#>uN-)N7JJZq<`^QaN*DDNt^~ppR&d9 zLG3P>ae!UN_I*0csr%~UITI%GNaecxs;@MeBXu5kx~?h}HRBg_)Th_w@2K(b1*_38 zr;Zk#MHDx}_dO{c)A>axHau-TwLUW6u68rWTC@|Q`I3Uv$7XQh#%E=7zLs9e5hdKL zS&t%>gWCZ}ZTM_JEX)3GCY;vezwUzdHv{LTTIXzEae@4*dTKaur9V)#f7)Iq@6XFH zedOllmO&1a#Ge;t*J-5e6}8-?m*Ml>CB^4^;*^fDIOnFr2lzQN78mNO7T=8|btvAk zfXj4*(7d}enDSYt-WW4In#d`9y}*1zmiEvd)kEP9mA&zF-xK|dFr z0%OwmG6{T78q>?@$m10%+xIINl(2upBmr}FQ2nN(i4kvv?Sl99-+m#MZC7}D?YSVk zoN%9C`!8%Wg+sF4*%9k-QH!rE^YzMTRbd=`L>8qs>>{lujB{KthpFiHX4Fz|wH^gc zD;O7vs>?hZio173@^PrrOwXvlT62J=?*;d54)%%EhQQgP>@BuiY*?Hn3{W&n@`_P3 zdD^gJG{sv_q*$b+-6BgMa?@) zp1uZlFbEgeeC(CPCyV|5z7f%pr@FI6RQ3b9z35DAzmJK`zho;dzBdekCn3*TU+@RT z@ugZxcn+(LScJOh{zErtGt$(LZe@ojG%mX?x!2Y+_Fd1s1D_Esn_;=B`bSe_MxV7; zOaOIRzY}GAzr6dEef~~yGKDWlF#JIG)d(c&RrWK>cDb=18Xme{yEpFUFRHMoRlo0; z&*|jwyVNU&kVxFb2g%a2L_Vdq6VDcmP8>S3jyy;Xi-oISTJ{u=AfVz4p9sm$L@d@P z;@3QXoa;b793M&8}X>(tX~eS+&hBH0l3r0~vetozTUCot-U?XH9a9pAbtj(@G^w zR6E#6QwjffW>bevQ{~YT_QD!&Ov;v^s^s$VqPvl{r!5z+NFMv#KKph+34(1ZOVZ@H zW*2{&u$x_L96HCgq>XY!i4`}_w;grIe=_Yh-ES}A;csry4#njy(%iqH3_*}xA58Fq zrw3+m>(g>?%jm|dGuilyzdXHGY`9=DTelu3$Yz`$jDLB1Pp*R|-@IU!gZ&+h-CXFA zAYvB=uEUOfJFoLvp!dv;pxbcrjBVD)ScfywI-hiF6KhV8Qd`{f@+C~hTv@@~6^T2K zPWfxTyvsLuMV(*X)8@JqB+SLKi66eZPO{#s?y`_bfGk;F?cFU(`BXtGrs>E!%D={# z^zqL5Kjk4pMvmE|-0+ZA{5F0IXMZbg&r#cP8On;b8S9U@6q8DmZb8C9-1)BeC{NgW+L z7zUr~u+0A)_TwIN zg~!p52+!$00blmcff4+WTSU!#FL}{i`FNWv8k?va!;0%OlN-0(3k!i4mow8VvbzE; z>L9J=?%FMv=HEH+NRv|^{n*g2rjsD>bTDv7abi6^QV>DrbxFiW?;Iwg@w*PmMSa_% zQ#2I+Uh*^M^J{WL%fX-06l;nJI?xq)taYcuN+`oFiM3276A=IiMGiuriS6&6!Yy{m zp?i*VZ$y9J-Elkb==R^w6uG~uz?}~q->~9_5>2(ACU0@MyyGsG@10196_vlE$(Q88}itkBfX12M1VS&iD$f*x6Q4CxsWan@> z{)ooQz*TU-PyAO!VqCy?{H&MQ^kz1m*K<;T~qMtm9Nl}Y`8mSJy&99Cq3zQMOxmpL44s*Aq z*!Xu?a`(=`trUzT%VfQPj&!egBM~#ZT(*hH`W9DOG~fO6Y}T3qbjhdRBq)Chh4=}I z>pCW-VPQJaYOJ`ID1y$v9%KwU{>_HFT;k_$3G#jPYOa?Kvcl$Sevq_#-6@(fz zCLuy2b#1=IlTxH%I@8%X-yDK5p&YbXNbN0WmziLB)ZEn|1?ji7g88J<#|e zbSJ6$VoBpSH^i%RVw4;s=q-S0ukF~?IFhPQj@$k zt4`(-Q~?Fq|J+P@$K|+uDIT^~wj@6|yJ1<&Z>c+3v3@iII9cuYWm3jgN_SzcSP!Al z2h4kF19$k<{mL>%5LM}Od@%>5#Ys^MXMaS03{wSRNLL+@Tq&b-UBS@lbA!Xqa2!2a zHv7-Jir3O-m-Y0f>efFlJ1_4Q%-?Z)(*fPaWmww|o%r1Ca0HfZfyY@{|Il@lbcA(X zfSDXz1`@wH9LH?d!a3`ZU))NbJ%B1eo+^`dWemiykRjGtp<`Ls!#G=KlT5kW6n13z zEQ%>lM$j4Q3WuP8aQ$pLr&E?4U22|!dD0FBI?U#C^ue%aKXjl?B22%>YADl|yU8(Q zB+TVJ>%2FidTmLKkx3a{#p~! zcJ`P!SPD5#GL|8#2<44_K^*{51rh5^l1V8D+!2oBw@8NdFC5 z;qjeE=n^KFZTP3)1Krh0ACjYe`$0aU5#XHO*_CNwh_lmhDCLu%<;c`n)(;&jNoI5hw~och*c4O`uX%)3)u$4?1ThV~1Qx@LF+K$4e9jkK21qk5 zS^0JlaIgtw6uk~rV!jP>&DnUq1%r?I-ojD|9e-!pA<^KB>RyIWMByeo|}WSw3gM#`*36nYrelK5s*5_3D*Q5?QZ^L>2Qq*Ir{u9uh$stEY^#e74jX*$?MIyz z5nU6ccrjz(dvoqK?(3Ik-f-dvI^y@+<4>U`r^dl_lVB_#!~eUVR!42#%aYUE-8nQD zFvR!x^D?K3t|2!G@4;6SHM}Hpequa-eN640Qbr{z#)2HsCBR&RH!Kf#5k8;$*(e#E zh6(L*OE(Ep!tcQ^4LsoEY)L3Lw8CqJ%4}m-hb(+(sbsg z1VuJr!O*{UVPp zD6nr?afLfmaoTWirIq1nZP5FZw%M=FI|sf3xxSxdXd?Xn92`Hi3)kL6x`u_R!4*o+ zs|z6ZSrkT$Ka4@IbCODoC+AZ{vCp)3R4U!kCwju-5E0~Rb-JkEW(sEv{@u6&vsF?|C+utKo_~wvPenb? z8`m10h;pVX1^9gzL;TB#g`A|bWg(GCOK)&mHP>D2#>-uzJB3{Wt2@q$@sm_2 z@5|t)Rrv6UypnH*=i=2MuZUFMjyJlOZ{oh2mIh9y_2&&}y}S=e7a_3;-_=M9_V-^^ zx8@i1(=Jd0U-ITnYh9!+SFXDnd57KjPPTIGg$C`D>?bHmC03Bp5H%T6jT1{+UGuft z3%P%kS+WAnuXIe8D!xU5ZOPm5U3Y7K6XjypW^C!)cab}k0u;MkR*c~$xdX)4H1^iT zcI#dFiQn5pj7OpTiH{$);9Gw9-zk1(2e_q-$r6 zI1J%aI0j4PP(atD^Qw9q>bwhuKCT(lJ>BvQfRG?H_Owe}na*{bGT(@9VoN$&2&oOG z{o>ZP4N7!eeVu#!BD~oy&4nAef)NIl#)gx1vwtd-u&=fCB7(X7O#<5xSfa)!kS5M0Oex?Km{? z%YC_Uc_~NUt92>q;>R$Y!e6iIb;bvMcuXtPf~ugY-m zb)4IN@HO-vd>`*nj#fXH0#|^L)S<(Ptv_kM-MdG&UI%B7j6ecxO@*|Lko5-scL`EB zCteb2>uLj^gBZeKw_&hidfgM@RxISrf%3vb*br`d@5b#{`4pwmp>^X~G3nP)pNmig zTT^yIejAtRwR9}5$>iyU8E=h(lxtA?2r@ON(aW76@65WPE&1ieu;D`{Od%z-mjIfs z3jR0nki^a>fc};8J+(zhSDfA>{Zda6YvUUFIEov+m6-|;fImhE@7YhAAQX)Q#NVSY zfBHwESm>&-Vw~dW_^jhCxsSBV(HZcmI$M@71z@yW;fo*S(I%WS(?sfMoi`np6Qm1+ zgzHd&^=B5pWJn(z&xLE0rh_DI&eMBNN2K){G!&*c41k7a^oCwsI8}t+uz7P{l@z_< ziEt7-%kqeqnZUakCO`B^hdM#n@D81#aUi65lv%cQdu)h688+qfmy6_vDw6g}}<)8^0b z-M4!MYyFCgAV>K@}S*&0E^R?1lqdjTAu(-U6(-sVWo6_Iwg|W zhv|Bd;>aw1n2nB$B~Ysd=}H*J#v;^8cyaH@ZMr28u5sdYz39W7lF4H_J_wdjfLg)= z@WdHZ)D;yeVG+h?qPKDedYb6;qys&>>H3gj$t>Q;O9v(f4UYn_mKEtG0?xmHkIR-F zE6_@iqs!u(K9=QC6Hw-cQq~T69}WRW7q*~U1D4J5NFMzwZ|LxOE&`;21B8Y#jVGB? z*3;!t%IkR_8MuKO7U@?=f-K_ac@y`w&%T~^4#grRRr-?&=-zUc$M(*XwNw=g5Yk6HoBB`%ULm4QTq5UfM+Tl>NddT8st3%Tp+QK=v_L< zBhc^!y`c%(kWSE3DD$P4ab4x>p*uQvt*d-ky2ZQmK^df#1WuZ8;gD{+DwlxM8)2pw zdZL9pjEJ?C$&f!3V4>~TrQItHp~F*R#SkRveS9NH?C^fE40*!60ZueeTs_0nW14M5 zeCLmjgT2hIOyHs8eWgB{&3#$hpYxtTAmJUba9XE&9VwR13Nv0y!u09b(%Y6focP4Q^u@d#u zgmF$BqU5wMf7A2+rMKImb%GJJKKSGgWsi;<0RIHqo|XP`d5W@uj29=`HfF=~AG^_M zg`fl+5LZasw{b8M2WullR~O6D`cE3mP+_T(X9H1%|9A1Ws0jS3mZqX4XT?645pWd+CClc*b zx_h|~Ss42GxH`lKb{l1~fmA^sQkZmL-3A1b0->MbhdY$TFuV2Wl2_t|ci510w`9^(Oq7Ab$<~ z=;<~Qgq0Qb#t0_}27Ur)8XjzM2b_AWEeX}WreE%NoIc`HId?3Z z?T|r^siVP^ocUf8myb%QF4BMQUW+^s$GY;9VWrRI^#ARL*ZUa1>kvD`_*($t{1|^r z!6UGYzjfjDQpVo|P9}5@z5IhSU&f!ve*hS)_>V>ZY0c0!ZKONV6$UZKVDi?%w zqB*F-pLOt0D*IZfK({ZXZ|c1wIpsRj^-&PiAR4ZH{mWcB6P$;lDGm_TpUTrVCEk$h z6k%!Pu<%n+OM!m$J=3$-Oz`yFngwE@#3>iMGAU#@3hkTmx9?jD?U6gB@$2j>2#O$8 z41_3@KNmX;{ptHJgYGN+oGoi0?geW!p?9y#icbNm&|MTk+O6Cq)Fm7ui}F}zrHrZB zf3ZER-lg`Y$N*4PFqPc@d!dN{hve|kI$Y;|C(e}w25>IHLx#xVXu!okYZaHgp?KH1 zqN38XLE9i2ZS7AS8iXrDDHZesW8$ zx$SoqV1TLN~S)!l%bu^qn&O4cD9*h7tWc4@G6oxii@Q9s+_D| zm4~{x$vdzRtWXUw$E<3=c0W(9mhFA1MNPG_Q(|9cc<({Q3*xaQn1Pv z_hxaElKT*8MOcr5()kPO{HyFx7c~eD>mi_B3Rk;~Jc~Cjv5WyGR(t^*lKt%wk zYVURpb!h@kic3QK6|MGb^fG|jsR);1TYD=&#nc4Vnf6r??D_32loJUbDUdFqDp>GW z1tq&o-xTdYhr9+u&JkCK92w5uViR9&5B9VRQQe6W?fRE!74^IBcr(z>YiYpWMf|F8 zI9sL-0gO8erg{|&b}as%k{VCIjF+w)9jlnhm4}78Bx~rQOZ}Sqva65P! z2JvE?owO?VifsZf5S7G)q=+!OmcrA_kXQyuSskqO<+l3p$)P6?dRS2)5azeM{5{;2 zzm1%m-FcbI3}WDsR(K9(8M-4^%K*JZno;tTbERYlqr`EgM3inH(2uYOutCXUf%kIg z;|KsI)s?4QmL`B-_KZ?@uQzIY_Ys>V_Q7}4aSW!|M7l?=L9ydvP*+moc+#~c*RG6J z9{nQ4bpOg}5b5m|z83B5WFOm*%_ul{s$m(NyEhDse$gNYiOc8+^x#5WE}@<2o(hV3 zC@TdckVlE$gkS|}v-Qx(93KWMm!PDV*4$ox9y(|+WMl^4bX9{-b;}MI1t(s%ijKt! z)IDelMD#~kuUwzc=2F=)O*7so4~$KTH(17pKn2u^b~dGxVjHEQqNj-g^U8|Q2L$<>+X7mzOL689vOQ8ZMk?rts z*>Wipy%az9wn*L_;@Q&BTz%+|9cV&Tg^Iqex%UVp> zvm$?z6xhi>z&G6uj5hEvJ6&gyp9~Rt8?R{kJxKdXhuFHIS4>_AjWtSI;TBdNL^9oR zYVPAMxYdUDk?HMHP-R+CZ9+LiVb{v8;Cq@O^R)%r>P1#H7~8_&=YbXN#BwsQQ(e(c zUU-C*4nja?WiV+5J8~EtHej&B=Ee$#pD{G31RZCw^VD28Xa`n=F*=VR=*-Kash$l8 z635W3o)0V9rmDu^+QV)29;JZ+r*x=g>_(`r_Ao>@a&ASBddwL_Hpu-)!1l{V~;q7!fT_nMkfl@+NnAyVyCHu0I=bGEsgZz=_4DvP#EbBhv#vpIn zctyz)uC8>B11DjfM+^gBzHD#qhATv4PcblNUcs1jX@y`C+X_z!7ghv8P+|zNdd1)n zE6BJ-$M_m?TfK_<8@1cQpcuN}&sjfk&xH!rxr-&+B$yDwXP++GP)p*2o(*(F%#+|f z&sdlqXpb1v18IM0Zgk`l+W#xema}HNQeXg74ddK7MDjmEHb=zN2qvMq4-8k2{eJpH z9flvYTvZun6Y9>@*+g@cA)*?0a4@6^m^>k~GgrAIW9A~gD=mo5 zz8~J){sa_ldIyT)wpA2g`#4EkH%kunw=9d)JppA$EQ1|LZdY0u?j(5$GhqvhjuCrU zlyo0oU6hnvelC*lh(H-D+?-@KH6i}M2N$_G)vF&D<1CbG46s*E3*iRMqJZ<@* zFpmYHOSuJyRczmSr@qLG92dW+`LI`b5q$ly`NLImLEHUHAgEi{;m8eq2f@FMjMx+;>O#rGBAgBd6|I< z=73~;%_{cNQ+_KI=pxGcZ$;{q|4Id_*y4XHq-pa}LoFOCf)Lt0t>W)fEo^i*ji=n-mzmQ*`+6gFy9izXLG-Famn#!$yk7`4aRMDp?>Gc!6W=nUI~UYri0q*8;e0+&|#6j)%VEfrZYAZ}Td3mMw>je;4dTkfV3`WhOLlvY`uX1RU44F)iKb?3~hj zUt-bPXs9i{@waw10BX1EVG!)4F}=`0`ImIYq5gxl?S(J|uo=>!39drxiJ-CQ5nr={ z0IN_GH~qVc;&hFFu$1-bU>rii{s`e*_;cnex|uG1YV7I4TM+7YxJ9a-`Y%AT-Q2B?z!!&XN2p#y!h3RHAt0Y*l7(_@aJyXG&t zw?>kr>ntBgi6bL!C^({T%FKC+rZCi;iRWcbs!$uA4#D zB+d_&4Tk(VzfDFqfyle;w$VKr%!Gu8<$Wk!s?6g9qWsS(KeyNH(4DG3C1yj0Hy=X z+$mmA&4*T-|E&)4HA08MvR@Lbddo_LdTnNGb6%;1>LJ3Re9|>+eKk!c%Yy z_gj6Y#`{7lgzrm<_tKT-ZzItkoyK%Y-fuiVg$ekjtM*8$&QKIpobFY{LD&Oo>BvNC zOs%UbB68(hB%-3!SQRC~qN|8*e`nSN>_<7HM>nbefiszC0&uPho*EWMS<7pTs!P(U zx{$U|ZRxCS)K3<$vA*Ab$j{4ut?OA^?jMSd{EQMUS-47c z`q*|ky2BHkCG?2d2|3vBMrq+!W*7nTq9TUQHp572d5@TmOkGV6s!b}VR<$YAS6$dC z!z4N~qhjc%e_*=MJWNm_F(B$Lr&Uo43~mDd2i&chbxrj`6?TAk5b*~CN)}4ebyruz?owahN5)%FG_OV zKk2I1_p?-?#85KW<(Mpr&bL)`QhxjFr8D{dT&J+j6aFeSebgN%Ij_>L8sSqaYYXQgl&#j&?Ri?c!M#OELT>w^|6RTgK? zj9)R^sx@28`5{l8z8)Aks-u#88y$(}$@k>|IcLt3K zU70(-xUb)wt5PfNUeY~w&h~CLbRvyEm$)*73@WnKA*Ro6SGZa@HdFuWa*ATioK>B2 z&|>#59Ubm6rgc*xbk4sJbPzv(dZqUk6oGaI0wP7!2fC*;wo-yD%}nD%JlCu<#lUCtGn4+ZQ|lPq8De6F~-GW6TxYmZ>DA%Zp6>)2?rf${H? z2MNkkB6KApCf_i2$D6B7GgYaH=%G?2GNih@H2i_2qsc!Mg`lb9p~|sG$$zYvU3DwV z>2pi`;;y?rVio2iY$)G58GLX2H}Etwi)_}fcJpVJW^Qw}&YN8QkFDv62sjv>Em0Nk zmTLk+RcOgcR$?(hmxNj!3_{;fKE81-{4U$!oqWXa$eI(wNwRg8QBq`M_sA||fu%PW z3bw_f#^S*+mh{*B4@cY6y4r(cX4ytrQD5q*B4A-Eq8#ujkRUqpgW%> zGmf?UD?@p(UjmBfNp{RG951T$7nE9wr;^)$g*(LcYs=SJHpm3yKsUFPu-lF&?_DTE~D5a>2Ox zo_7BN5gq9g_FPoE%exso_oF;;vm9!CB-xR==_d!JbbjV^I^P>gCOD}u-bK!w&ttP; z17M(9;tT^N`OxY-l$~Ble2W@VmDI-zxa6*L$W+=d@Q-_>)o`z4xwax(SrW+Uygoxt z)72FUh3xf5gK?F)%~nGiAK3yeJzAQW$KQdh(%0Y&3SWqv;%W(H3eOl#M$OW$KnclSnPv);LdKkxN8l8C*a0*0Z zf%Yjo+px|i#yR?pvd=JUiBRDDzl9>!$Y`RHxM7M5EBBs~VC%_yV~=U3E# z#5}dvDwO%Cf_y>ekA{WT7HSnU&4VfZHIX}ihGu9U?4rs9qG|ABh~~qkASIo+`;F~) zoRQcv8%;l@M)r_DRA!6Gi8c8@gRIW~QuP~-fo_6mH{aE6I6KcKQGvEj=K#t;%n_2= zTscfZ-F(nR{iljRNlv1qAY_q8B|~Pcvs7aihWF^09bKHzdOrsrRIguiCb}m4+kv-rXyB@r# z>CP97uEU1Ut?*En#Xq)3jFcSfV(7-o+7rGjR7%_wZAItwYO5YCV|Tuk%J8PWdq$qF z9eMsxKbo&bwuBwsE&5q9gecY11-6|04i<3$7eJdz6h27;F^4s(56tCl$I{nw<}Mps_!iZ&uhQ z#1Mrl!GM}FrhVzYq>&=i;mEITSlCRXrWJ{Dc;hPmX$$>ZbZ#GKmb&L5L#A#`YcQ?~ zKEGBEGaXf0CU3KqrO+I>JpO>eWnrr3&%&Zzv51qtMr?M%>+z>+x4EAabg+NN+JZfY zV(7!bQ1x?Q!2?Oj@$=?t$fINWIIA2n$E&+;Nr{`tl(6qYmkXEcR}7rMH6^Aq&-@`G z({M)vsf;tH>H|v1r~H)_8TMbT8n0BO-u;12%ht5>X;`LlSgIBbb_cuU@uCvWWk^`` zjN8_h(29m+mL_-{)#I(xE9Z%WTjOTRj_Tu{E9yM~EYF}=TCHL^QsI#xDX+++J5_Qj zyiFoDcteABFs^XFJD&);x*Wg9Af1IG|MOcBKk8bMD+U^OvP0V>?gc;mq#umiFIU1& zU*>BtmiYvxDWT^%Oe10qnOqHEf~Rm#G({>^YfhK=JQUws0< z@$FcSYeil8u6N788K;xnNSrZX>TKf}9%0w*iQ2ivQwa~EeS$IrWs zL;AMqhP?f6a33z7g9Yp0NkezOX<^h{SGO*>mp=D;+V2<(oZyO&m2_Wn8^4l3=6^Ng zKP}{~bhTt>VIQD(_Am^E@!>j|s9b`GmUdS>X?_rIO^ zx2AFY99UQg;3`?5{koj4xO;zGq{gJZ9_AY8`vkhcn5kn3IcY9T$>8A;u8ev6qBR*> zTWcM<#~%oHF6LjBNatpXO>&ndz327IkrFQzuwk)9*QB0z802eB-5l#16pzKSs^}H@ z>yR*?d5lTfp(pK_UFTltJIazQ-r%B)^{UH@Lc_Xq6WmRfD&$Mp%O0WjCC#v}zvuo&s#NGDE}i5mwlLDTLwTPOxx2%Ft!-McN)0QIDpm+Xv8F#Q z9)2S)X&JcRQB(GxBX68(##PUf@41uhta4->#nNatTz-vC4Qn0xOhCv|DBG488}E_G z^3;T+30qm;u+sTg7smv1ht-1drl}Lp8s6)MXdQ{h!$eEaLsk9{V<+B|8PJQm$>3yx z6ZRjpkLiocew#WcTTx3ffvx+Rdgi}>yAKN2t ze3;T6n{sT}T(-o58E@udpPuBsRZ8DJ;BYj)3xHbC?Ti5wTOgT`)7&fIYw^a}Dkn$A zy<1WGwg=nqrJT_A)~;&jP3OK2Ii=CK@;^rOh^eBpdxJV-F8EQNGSBIkF65v-x;3S5>w|+@~a~npvNhSD6TsgxJFQxpxej*nU05DE;wKN{Vz*ELQ=+(Kwe`G~c=bii#kGww0?Rz|V8&h;&)9j!{ z%k8luA=Zku|D;~khP`7;>;~TJbPHbX{(W}w_j@h_lb-jQqC_9=!ci^R1dr@)p|T*@ zN%pZ~q*zfLl~!>aoS|9{DUHRc$On)vX-)cmJ<8Uukfg3PZM&7Ty#V$xG)_HCiWu5y z>uRUpH1JVJW8-9XuIn#I425DUeylZp3@42kPw_leR7uPkN+R-kh~H{RQt{z~vFiRX z0&D1SsjQSozK7#3vzjg5$*@(2)14T6+5y>u!vPans zk&%#$YuuzzNuLi&b|ic6Eh%MmiLyeGmF?o<8o%?pH+??e$IsvQHO_dQ@jU0eA%3&} zenI#S(&9}2PZ7bRLOwQ4rXojZ{${t5*4}TojnJDhWLrzx7AcP*VGx>wt+_o9r9$ zFqh0b-NTMjp_`BW1)vq3@&Pa`9qXv5dBIBg@~~?P`-N?`c#HW-$0aT1JgF!;(s~z)OzuI9OPO5Q;Bh>2Ich0HL1U3J3V{t+GoV}#fxgGKI z7|$FJcKWLAP+pTh26{&JLH7?Jx5~Y?7H(RUvl& zUli;hOB{)2*SctOM@M1J2T zvYmgH{TdlaDGm~B4yg_KTr7r3&#yW17%_+JO@3cSdi>>NQQs?d=p&(IN%$VbL7hJw zOi7GM_vJ8jJmQNz&f*9W?W)&{Z+QNFWF_Q!m z)GRQ*PA=1GTU^Rff{aD}mdsN^8)%jSDPUz4f{xuEtRtOa7vw|?{3cRQyQ-VeSx@ZX z9W$ootF|TT(Asj$@A8=qXOEQ83b3Z{z{^nrtaU(E^pWX=O7+5iZB>psjJ{KPi@~U9 z#1wIvDU&UMP}VWKdzLm<46%^q4=;uXDpM4#AOtY7z-T8A!XZE1wc=)XQK-jgB(4xP zuK%`?G)+la6$S6!b+mxs6x%#5gl;weQmyR~du%0On9k41RiR>4Vu&2&b#kmKf}}l# z`3xS=I<;T*?HH^*cmDLSFa-{ILyLYX@#mK%e(=lJT_KIF2b~O`B%nr3l57LWwgRi3ASzmP)R^ckwR|S{j7 zEIpE4(5hSFz)ow@KlhdodEa>J{LUTAItViPH>tZYKjD%(Cvc*bzl>q3UnZ4av+kTK zV@h+Hqs+WT&t!C{&qL4CkW(v2grSsUa&BEfu+VX-vqDuDEi73{HQwZ!!>)MaOTYEL zYq=z?R6i4FY~0(N<-x!?NbQ^nGk=1)E5kXg{qg{qyPmG~d^&uzD}yzCQZV6mA`5nJ%x2(pb8e`R@_4}1(kivOaU4kt zSF+9zC(qL5vo1;OU%tH#$q1z}50Rndd)0@8OFokOEiGcTC#j_mPD--64iLl^SFEH8 z>Jp!7muNEJ&&^94JT4eHG8t-6C!bJ3J%}EmAAb;q*yLyvbyHj>yWXk95HB4D{6|s+ z`&og+oZ>5a!aj#vC-(T*R;*QVz}qf&G5U=!9{-ZtJ5XyBniRLpM2cm>^hj?`K%^OX zhbc!h*ODn`ag}ZlB0u*J`M){_7>krb!@k+6ju`I7s>l3zA3I*xuvKNw3gNDg*Vat7 z43X+Q_rw`8EDSA8{m;_Mlc{Dj0uPS|$XzG#9GQ8~(kZ_O!zpUesP3J3jnnyfoX~Ujn7e3SJ zP}i%jVCfy%O0^z%B*8yGg!av99A8I;w^6Mix8^Bi-Gf z$>CDA0(LKs^W`>@@v+UKAY!TO&#`gVhNgh|Rmke=jhILFTFFUKSp^B}c_si=RiBQF zd9QJW(7Kn83eq}|bpGd*1!Jy_RYCK86l+_}el7mGH!yNk(0gq%gr)*zkL0BFCv|Ma z5O3#k0^9hf6l1iVc`dhB0@e}T43g} zo~6b@hO|N%9DyqTp0ra95gz|Pgd1}}wgfA_uarjC=+g?Rq-=e{y-6JRHsXSP6^V-v z5$@UiFX5gAGySA6`gUv=PQ?2;m%Sd(UWJ|3^BWW-dcDICazIl0k0iLtRYJ6vA_Otf z=4eye5#FqvM9!DU8i)X2or5daVnXk}s3al*D*U@_&cQ1(sYVhGNy;kZ`l%vy+1X57 zvADtMO}Ut6GG*!W$~A+!s`I^WJMI>dWB#RRNmLFV>!D~J)k*<6EOdUMym7yGET_Zu zdta8^r@=dEn^9g=Ui#R zw*OQ3u}ZOAOW7FDW=_Z587-2>UazwnIpp@^l0eh8ogm#oWD;W5K@a%x^U-%(^sd~Z zwZ%?%lhv#S{(?&0L0?DquKV13LQ&Bk)c-g|KoRTY=*W;wyvpO_VZF-u9#*vm15;hlVuO(zj-#SiyyqmQMq}& zD;I%^Pt~t+&Q4A{2z5~$ zqoosg6UuJxrn^yap4!IXzwjxQsiwQ|&)r75D6qmkAvsYQ5XP~v9Z!h;r+J|n;-I1& zReqxA0hq000LME@z4h)RK8Y5(y`*+K72!Rv4;Q*onnhL%kS$nSoB33yrREwTO4*8rQhKcqsD%|2_c{ieRhC}|5^ld_!46-0!e*R2DM;84Ou~C1WAkI}6Tt}jDD zRo3Fm8}d|fYzpUvhc5Iol-(3Digd61g4~ps78Kld$|lisS;r6X*U5!8r~Lr&b=PFT zc1q}guJV^Dh5#L}IYf1k%)S5cb-Wj#Jgq;JAHH1x%$z(z-~r0<6v|t6@1~HmZ~b1c zajuJ6h+EXy0oy5S7E)DrX>}}BS=_*luULnHc9tr|T@-@${JU@=Vp&oz;0M)wa~HAW zzi(WkS)x&@pcw2w>GB|XAu~nv5PvjQ#bvqqO=wB<%+M(UKSA}bSC*@ftu3mTk=GMe zd7|esf(EaMQWFBaT;pCJA?NOa-2v^W(&l?iN1QORs)v=m|C}~8~E7f zGv!R1AbCiy%j0?rK`za>``D}ALTNBlnPB)`Kj&?pd3wk=RM|C7v46FL; z6u@n?Z{TNwhWbCe<{FgOWcLHDQTflB=Ul$(z-0BKH2ChJZHYBse;8`TQO=<6pg@qg z^{$$#v8587_6NV!W7jq1t$CSB7w;#@C_KGjZ?1?4-u8#!wzd_?Q)!Q&q9X?X@GaqT z#tvS`-&Z(*uE6o<3OR+|AA;!M+McQ-+Pg9HDYr9L7Va54&S-qc(RW-|2c^KR=N2gY z)$)o2wtUi24XVSi_y%D`p_bBy+{SV-wmg2xglwpZz5tB;_GIDjXfVvq+dGB}TqaXu z7ERSc?xStj66f*^{bo&sR9mAdMxd(!m|rqv6kC2mvM-piF$+sdiF3|A8>mWNEgOb_jN`EEhz*ut>Jj>s!Bk5pL(c@kzJmKN_z=?Zb=6DDHkKKKyH{;zWl{&-(;jp?N1E7GTR`F`4b)#mDN5ZR=OM@eR7yvUi3(!Tk)`O!Na~Sg z8KYhwgJeJ-in$zUxNAHhk)Ldo3@#!N2?=7cCz_x)4IxPr9l-U*3skO~wmA=^q#uJt zS5-%hcVpZQk^QX+BOxvA`$O(3yHnfQP&-G70TQw}MabqmOEQFL3J$_5XVnpXSk;== z-#L4OiP&OjPkAlr2ml~iA;Ml$2y0M;gBT;gnTl3IRU6)Ab>k_nnSOa*WtULPm(muo zFME)4?6>xO81Ir40HHz233TF7>WLD@yeEHq7Woe^Eal`>pI*?kFs2pAYv-cxm<>Eb zkz4^t&Xgj#sps9)%OcibLJ5)vY2cLq=-q49_(MH2s*!9HG635Ua zF6#%=0tvIPSTHvC`K{l%%wG6?y02xGMU8GHDD;>kdJ?Ggd>T{?V(VY4%F%Vrp|^K-vGFu|4_(hd$h1oi8t0Ui9LR+;^i%q=Y4G5&*maU zx{4I(Z;B#`+L*NM8>oGu%F-vBa66d=61r1A>#C+r2Bk(!cUu){zyqEu8ab$;I(-tU zQ#yLYXDR9wR-Q4cKGT1Zm%)J=I5hn{|I@J9K?ar@@3tyKOZC*R2=V902%eEci<6Nq zs!$eR^vxKROLb`MGup z$USWQ+fUAUha&CmlO~Vt^c5tK*rY*h?_()qo4TJdTF07=oZkTnOjLT>J!89tzzSt! zddkK_Xk#Dh#s=UfC>beJqCZx(Y{{RP9r!jh?r?%%k{Ro#}`Pf>`r(g?n5>mgcX zc03YBOUjoI9Vn3bvdfok4|e$K14qsXsf~9=4h$SG&_H^16O^{^l};vsiDlvq`b?Y`iLqvj1l6 z*)bL1&qYG&TxcAqxX+S5@Ybbx$oR~fhybjVMJpGmE9JOrBqV|8i=Xy7hj3X69!(lO zr3T3Nrcqu{gZos0c!NOplvAnKDB5UqOA)3Kb2!48#+s03Q@RR=EK(Y-M1aSE=kmt z3K$2&I2;5 zT8JL39HQwal_p{4?9HD(9>B61UZfcFyT`HLTMV&G;kS^thtSyeAL=nr;h4+RW5(p+ z7%1It0#o;{QJ2?z#(~#LETsOFPPY&pQ_hB|FgcE^QCpBeSFZxMTdCZZX1}uM+wahp zXDB6iSyDSd;oHv_zjDQ@D#@skIi9N0E}+tz4JkIk984tqJ2!fr0D z6QCg3y>s>3RS*&9af(!-EqMNB1N9ubk&>I<`4vkKe}GU>9Njl4Xz*}L?MT7YxGXd$ zw{cV1y&KrAq)%b@uBU8Whw6ejkxzRRnQkm_@-aJ`6p4fGdxWPl2q?;jVyr~KSShDb z9;T=$|AWVUR5Up2L&vWRUXdv^+{^E<1+PrtnoTN|YY%~IG*qrVHs5xI{8Wydax{zz z`B(8+rmi&F@?Ol5_CAVv_1M>q1Tm&)y@R$SWEuJ4u=lCd!{WdSoU>K5ed|WWJPzL} z5Ii99@}KT*D*IT;7nmC=+MH5Gs2U56-MACRRO$YWY}>4)ZonJpnOd~Te1?p;Q8|J= zvvW&NX+TwNId2F#)3?++`@x-?sgdpZ*wGS7x5>Sw5a?E8z%Kr@)mwF}!iBcKXt8_g z-3z3q(zkIX!Hh<+#*>iqF#1={&c3GC(v z?|8GBk9MD>9wj(TQI(m8KP08-v1c-7QX_YE#rU?Hr$P}h50;lXD=Mkx`=?4$;T#RVgJ3`j z{-w8Gx%b2UAMUOyPlQYLy1_ee(xtourdKEk9ma+3`bLeY&HpBTDP49=Wk-uHlVOp3 zIjVy8I>REJ--})&7qSor0P)czDim79GnC4{9sFq&Q}&yw@^eq^YFAM+$7B)Q?|0Tj z{{_SxFb-UqD>F0`SbDV`%PQ)qJ6Bj*`q8P?(gOd6+@gKYR+{nZ0F0A#Lri@_fy$Ap zb&f;|ouM&*k^4o#%R`fLl&g$2bmzWNzYPw4)}<44YMBzpU_PTIP<{ENd*xP;K!Ov+ zZt0U#=bXoF3C?k%H)FzWp4v_Ipy+2Z2d+3GKr!3L&524jQo`3X#2F00E$D(Ow%Y1l zPYJr7iU?aMw}xc3c?rq8@+~~q-`P{s(~MD7|8aR<2AALRZZ+1cwy`MaGzd&*&VF-z zCB?U0ea>GF)uvq9;FdqBx8!Vb?mp+WH?`(_wEk#Idvqu*wo}|FG`QWjy@0=lp=B-= zs#PwI#l6*c5t|P0o)XpW_f0F z&V`-EI0}s^Kx6W68m*ni^%k?8fkqOgIDly6ttr@ZKq9Qd{tR=@h5f%5CBdQ>ltsd2 zmHX3Hw|zQ9xR<%Av1%j!DTrll`Tg2hz1(AO)Np))o_;u(qHOV!ZKE{iT27&CT{mS1 zI!4azHlOLy6Z)VJ0~@H)-+KWRX`2qxzV}|F!`@S7vI8llGd%8Di$e*k+*7mfhSn;U zExkXmj~V<`aL-(A`TYG7 z`cH+S10F%oF3ljJJR~8!eYr?QWZ3-k#ul#5!U5i~c|s%c4J%_-k?g8hOXcn!yNTpB z1;D34ACUG0J>m(yJ-UmVF2_dA$7bm1IFDfm>FE7S~K7Fely6u~( z&rQXfqLs3fs?F1qdSH%@>A;nyKD`(MPm5IcWgiyA`S z>I)Sr8a9KaLP+f+fpb!bb5$Na({)^@LMty^sw5i)OMzQz$2w+ z$Zpr*3~*8=>GWUeSuXy=e!Y|sQ<)gDKa@_n+eZBaZgYQ8qvsgZG|itm>ArXgV46)O zGnq~aHEMn{zdOG_i*ke2(o4)~SV4c8J#eosKejf7=0Hf(hso5r z-dS(`EejJpa}EQyo3wCR6AD8}QNmx=E&mirwHx|uc8c~6>a>(X#As58xixulU@70x zJ+RVqv)!S#C(ksyqBQp`UzQWXy};&+G8}sWXvV_cjptCF^f-(t#l4 zEN?;ILuYd#B#+HVpF)s4Jl3La*ynFaUwmu%-LmdWJT!dsGZt-mT0HS+Kvhd&!XZ?1 z?7l25c7brd@@H+ds%?UC<|;7320_F}z_+t%K7?(ihFlU*KL)e8iu#SKPjJ_monw+~ zhHpAfE1UZP?HYi0LKu#1I=5dlQbc@wnlL zFH0$Q?*|OEFe@j0_J!Uai)hb@P?}*he@nyz_irKYn+HrP4us@8c81HHW#HLr75`4g zSwya}B{+^Rr_B#{nfy>f|l)IKle023K_<&aV3 z`uuneKooIlE$y!zCg5bzgThsw(QZdVX%=>axg*empL=-@%pIP$j2t3&*ejmBisc)O z9!T)#ZFMF%>wP_LEVL0DZ%`SaUpN@rUZ)rB0%*korQMtc7T={TF0Pmi(fL}(#m<$& zAgYtGm-p9xkGzh1yL(MmSIr>n_l*uT<}HcnEt|yT&>NOQR~AKA7A+)2&M>|O4Ah(E zS>ke%j=E*3-bSCXj}~$}|B89gat`C3H~uNuJYKB2ec=GQG6tt!rk+~XJC^x1v79M` zCQT;&>&s`139)^v#`6P!+Xb*+5pH`3!vvUbri4LMJ!=4l-TMcL zD!sBTL~dD_zicd-p^7z>%L7XDz_I%)C6SUd%DjA9&?}YENsGTld}_WnA5F9+Mu=g( zh=i41AmI=qq3IX-Jaby8+(Ng(X1syWn`gbmA^i{cnMpTa5^r=5Op-zY>q>GPrqpbN z2D%3fcjGfrX%v8X9P2rxuzBRnJLmL1YmKM9Sc*xM?cmz2evCR&@!QBjL&+RaPV1sw}* zpNRU4APS}EDHN9AAdtpMB1Px!D^)G#o4u!s`5LHO2=Q|R5=A$@#`~clku$iMGPZ@` z1#>kPouCHNuDZBM93p`2=<<_Dd=xD6?;fo>)~^G8Hs1J6P0{REgbV_Egf>WjqMMxQ zPggx(r)P|bt~B&-FX;A|;kZHR+$NX91w<(qs3V^%7Mu-K#Twqj>_)Cw)_^g0t0~kM zvGdYI$@_LV^?x?3QbzF5nnP$!>^$z{59<{=ag3-3mwppwnNStUX1W+{`g3wLUK^_# z&Q)K0KQWI5yvz~J!?J+V)e6GhGycw{P;|dosdj+cIW+YXTtgj zw#)O=B7&H*L&>L7jRolrBXEcWDFjLW738Y&fi8bjOd9?joa!isI&iPTXc@_|@fnwE zqF(iD4t33+Yq>6kG7h|Lop>_0BGUnLUpB=L;cIKT$~zT>eY18yU{mLsX?3@Y3aMKUoBi6q@Z_4b8ksrl#3HwLCXvC)SqU9q^%Tb@5>2xZ z%~X3jY+OrVK|#(zQx=8&KDJnsnKv<5&~_|&mS4>RzXqYJ7=id&|HNZ@Ea+@n%Ude8Xa0oJfLKR_; z>{mWZXBeig`1ED=E==Cx@QInSthV*Y9P-Dy?n4+~aVi+SCnM6a=6a?9`-zg-zaWky z!Z_Klxo#}|rY{OhhHWahR_^UFVCLhlwoIKNd5?Nmo?ld(oD(5&j1GxNtWMLO-t}ZB zbMADylxT*KoOXcLw`W7s3J~q|%ML0nLXI3LwQuKjXsK=;Eu}H+W}>{*IoX4XV$-QV z_I)wGwpH{jU0xg~GS4hu$SN6Pyc6~X5O~#IWL7X2C_8H}!g<+q6*2m0&$u|Mkjg33DT0MF?+Pkyb?(xBl9Z$F$bF~}p?0?AC z^-}e*GJLtf>sw|`(A`gZSAi)_{^6^3PX}_+q^<}24goRn68 z-MhUzUxuqBH1&$^0;ao;tM$$1JAqeDncZOk8VvU4mowrJ9&yN(u)kV-=klem{?dN^1CnCk99=Y{Z?>%}Ft~K~A zX!+GfBd5Sa4bTjg+;$uGSkyws^ZMki;#=;`-_BT#D_h-D9x7rQ@+$Y*Ze3&S%5U7V z{Edx2+a#%G7^D?;m8(z1x9k7!@m+mmU{TX7^gGbli@eP+R7noyX+S8-92qyDw}>OMr}jq!m}dN zS<~I&?q3g9-IQ^4AsU&fAlEg)1}Q+&89Bxj)k6%SEemsJ_b?c4nP39 zHk~{H9~-p;%x6ywO&l?$d#hgdv!bEdr7ku`k(C~+92EfB5OtUCCWy(Gq9^bg-eO}A zdW-6tZv@-qnHv&smBj)-E36yzBX>FA1UXE?*6D+O2FEnllLv?lyjSdfWe9i9YU40f=_w`fm-o$LF8%KkTKu`HTD=}p` z3svyD0Us!y);a=3t(R|^ zYlzQkVN>@i-jKw*m$biZy!(K6E$Up=ZSS(}e7!}rQ zd64!5Yn^DvkT|XFP;{GaA0zFFrNbEeEOYb0vDDL+`WBv*|BoqQL#9ctbk&nDfFOZ2godMDuLvLuQzOmxeooF2-kbFYAl1pSXK zLR;i`j6q~vbY%PRRpA9q+0|^ekQ*IJm*j4SUjB!W$Ze!Pea~l)NCnNVSdMlx67B7J zl2FqjB%e_*19T{)5zUm5r{4)}RP6ifd*+pQ<7vJ=kPH=8x7_yZMsQPOUQDA-=vjXC zE2YAOR*3AHbXdQaMtCu0Da8Me#jf&L@;1;sU+dh_CM!fIT5Y&BQRcMy`*Trt51ShA ziJhM)-hQoqwBnQwgdFmR?0E8+!yA~#K zsn>+7lk5MjwyKo!`xH?GLch}~Se8MR-$*b;U) zL8FDGb-mqcj;4D56SU$BaH}!82SQVG%%Jom+VA`^|E!(sq0x?XvGaq)L`4tIiFzkz z7;?xp$?Tt9HVGXL#r7OW@u5u_#1AYee#q;Z#9ex!5}DyJ5Pk^1mZs&vX%ty^Cy6t7 zXQHxjy1l#7N$-rCQFRRFfv=sK3!$Q(2c?GAQM3Wu?+s#}qh7bDDbA{{QN76H4%Us~ z%Z5XoH6y2-O#jjF3%-I4W=nV<=8_g{mR^^f8_4|tlDk!ITabt>JiUz>n>QqxRr1u_ zDVU6AZ5!0D|noNQV zd52V#T5!}1aO`ECV7s*{IkvE zi~TM|&betXAO@mXPQCXJ7t zyx?Hi3R9x&gfQ-|*%~M3{_W=YS(~&}CBLDKH?6|Zi}D1{Do{9^Nm$dA1$(nS;}y2c ztNYQ@3z2n$zs7C^#5R7O^9y!+Pv7ynHrWqzYx~NSDW&ClF`Ew*nR1CybO}nTk1nxE zS!BA_L2o`D;LTljn;*}KRNG3Y9Ni5~c<%4}QgUIKWN+dp?4sJxgkdG~IC>?Wh$9rJ zVSH{8ICAJ_z3D9EDxcH*Ot%=SjZ8vBg$vTX;%Izyqv*ua?(z|6g2_ztLi}v+noAf{kQ1V-di7NeylcJE zB^&$D%VGrm$Rp4#c)@|QD{31X%}J9zS1*+1Nj#|w+Vau?tj@#+mZo2?5snm_zF*FC z*F>py^{w`!R79gFKJ_6h_@!&wrsVrk7S>V+YUsj*Vn#OJ#XmSelyaPZYpC= z!&R6uaquk)DNFcahlt-hEXU|x7ER3|m1#5J`Py{uM%?h%Yy>3}BZQ_-bWMSVZuJ}5 z@||oGJ!QDRO?}(_d2|O6bcaKK?(n1LqX-E`b!JOA6T{yp+nUM_@`hyr$^P$mE9h2TmsQQQ+`IN1abpOKiQit>mNHQ#*Hp-YFeF!RGCk zCCs;sw)xFCq_HP2{5a46{c_19LU7azDp z&0D)qfQUAu0t|?#95Y%ot@A>9JN0C)V=m4ODvQJy4~Ir{dBb!iDR@E8SVAs_g+EIUAXk(4Al7Lv8Ep-!ncEixw~%12=VXx zRJ+nQSIZl%6H9P@cO#}{TKlUnFpdb7$zNX8pdMwvO^Ubn{ne22LC6Z^Sw~4)i!hRT z8>}k%{F(3EK4@lk(==VMWYjo(#bHa^Kaxk=SU11!|0)nA3JCtI2?4MOgKAWZV1`du zp|!e|NrYxD4GvEzkrWish8{rm~o%8uaKi-S`j zcC^?Y76<-bT!9&Rm%U=(erqUlD_Fx=V)qQtl)F!M-9 zy#H4dM*?LB7j%61I?-+p8SLd~ET|>Cve1<1qI+<&LV-kddi;z-9D6RuU4OH>-tt@Y z$Hi+mW#nHSp}+852t6?_cw+IW>fU4;vlc8ktBBu>e?00%-_ds_EjZrMKUS?w(^LQ9 zM>(U?f&PZvcb(SdTx{C+Z+sf@v9X(8VVPn?VpIY#K0xiyvE{OBC{H*&TrkT zS=#Bic}-qz01!X#@NGP0q;AoVqwnNy^AIljI&5q-*a5D16^4CVJp;f~S5YFdwjoMz z)GS3KfxZ3;AIKRv@ZoC@aR+#&x`KF44<-6eF9C1XXj~JyDIiQOvmv>v5IF<6qhQLV zkSU*ET9))2ht6n{?tHi!yilL=yEONW<$QS(#y$q}LzFa$lK^PN2!c9f`7==U=QNF5?(nPsW4;S@5gU5Et{S_dj995_MW%bIm zdmS-Y8(;C@gm7bMl@VH<3#%J{ul9`q(t8z>lDmkm;maV%ro7=2K|I~G1{nT*>F zuVjSsN+4$Cuy`)mTx=uqoW?2(TGZ=*SajQ@g~WAO3TKo`Pp4%k)V{Mx0^r)p*kE38r3%PFww6~Iu1%lMBVvKH!HofZ+%v3Gd7`-uP;~fwf;268jmw2?ag4bC0}w1 zXER~9jt^bbvI=}x?IKbojcBPvw4nAG{2j8V+47x9wGMkPXszO$JV4*!=z7Sr7DTmH zR(vI-VtH*;rM@>_{_scKmb<228m^mN5y(!Gh6`LxqF#VY)5NsO?}QBFge|sEUTG~40`>a~ z^(p0b6HArzu3A(s=ECSldTM99 z^{-3r9n$qZveD(90EQnW)#$xiGcJ43)o_Lw9TCU1P+A=HNGiMxKJl<@?D(4{X?RP)q`7vFrVW#7ekSC$8H^chr`N-GX+xBfL%$FkVJ#6~c z8ot){Y*~_R7$&rm$^3A+X3FI%Cxb+u5p?6EEeMEFRa{G8sT{hWt^QQleZ70K_E=Fo z=XrVGuGM_k&4n@oDxGe;)!Almt#N{iwa=oxW1*V%Y9bY`#-IyVGv8mnR(qer&}7C! z2=gc%V!O77P+y|rrvLDg+`Z}LsNt0tS(*GrE0cZVKd-Bg+E@6y@u=IZbuG07JYi{0 zHI{m@br?R4lZ-n87nFil6_kfV{~sj0md0%xFniK|AlB`OXI;LSX7tL(f*Q%w$ z*DCjW_1f zG%@nOp}mLjjp%wTy(bcBcY_Tpn@Au@FYcIuPVr5^;pPq^#vCdK%QzKfsS^gZqcay} z)xDwR*!&R4sK*knxJMg3RJU;&p0Ya`>`{x_^D$_GOyZXseaCwzBlj>yi|>I$M5}4e z>s?x#F+t`!x_F4&=6dSjTwlt$_FUh$7fh6etPDXv3O?O^n?k|gOJVOu^W)Tm2UG~d z3X75^Ot~~uE78@-HdR)@obnhk`P389DBL1;F-qP~H&Pd+!QXTbDR&Oy`RiC(?dN(Z zWlgrLoer}z5XTNpsBt+YvQ&kkrG98>1ZC;BO|Vp&V8QC14lN9qVnAYBUV2El>1&J$ zVb=xJZv_S$n}yKsLIDKn0)y2YgAP*2Xxv@bj@!WGVgYiK3S9XUd51#5IWMDTfiEL`*<`x<^2F^`oJA zrNxC>MQn$>H`a6vtk`5Aynzd^C@Mgr1NW@Wd$OP71J-0e$@AfL<>hd~#OhKy8%M^|C?L&(rxsdmQA}b-YEkCyTNPTUF>g~Rav2%dxVGQFI zaY4lwCEwjRl%a0vKePnA@*CnbXJfUntJGsKe~3hz36A3g9*MT5hg)4r(jY*+EJS7m zX_c0Hc)7F2!6`A8#5~c~+*N!t8OV%K3lkn=@?YNHG6yx$OF5`wjdB<_wxfiZ;IkZT^WulqqL#HvUi# z-GEQVq2(j0P`YegRhIXbq+Nbo93*8}#?XnmMttXN+KU8i00Is~fdE$7dr&g{m9&P1 zeF-?Jv(5d+AuyIUY!X>ra9E}(S6j4?xIZx`Dx?y=^|rv;=0(?tAc$3nt$IFCjvex> zc3XsR52-Ks?80VdB^^|C=sS$1+T{{UpN@0{l{aR~Y!TI|c#egmplrn-#N>b+{dWS{ z*EJcJ3{O{gK1rkw!)~}oNd^ehlBH9cOKlRf|Gu@wUnlWk6JNu|yt;s-sx(xuS-T86 z){25UD6{;qnsy)G(&a?UjQt#QF^-aDX-heFzgRwYv(=SGVeb=Orx_dIGr!5CJ)l_c z&x2y&C&xMZ9;O3@{g3qc~ibQ^6dfcye zNeLk!&?R`b+#4-6M2fX+)q4wJxN+MGEh-@^$DUTKNeRL?^_qnevzzNYwi*N~hmCU$ z*sGku%YJQmXS0Ay*p98iBuguK1CVhQWxMi?JqI$_=fqy`iK&a8I|DkxE~6Rwe$cSl zODZsM=g^bPyAnjktmK8B?_W8Yr>-Jfiy(vu1V&)i^II}nem!YX#?0M4n-&$r%)IF% z2nQWhyQcf*uGu&-Pwj;7VV0rl3yBul9!g_R=gM2ZccW??1ukau>42MK!N2bJolejR z9sZItdsYKJdN3Hml>1J=j+{c1>rx5foK*Tgb2{XT$$%hkrZl!pb|}@195l_k{nq&s zCfevVY&-4#kbT8fQ0BAt?yw)4og=fTlrcUT87*;@%vHao(PpeY8|f3 zg=;H+R#fU~{^O5i;)vs`JH70)o$=VNSkYE~(@Kxm0JuY~1#&>AiDvc?Ffi zk$agV{Kbc#&$!sj(0+iAvbC-h!VX%$cQ{jqrp}`le{Q;kS-nLoPng@&~QoHdJoCNOu;dnOi*zVD$mY>MqZBt9^4Dgu9GFSH_@$3NIVLi*Ki^7@#-TX1)A5W0Kbw43#ZW#RqUhkcb6Ao=3d=(_ab ziELd@8|?8HWsf=8e#aji^Crc@d_00@ma8pG z+9JtFWORSs7YET^nUS8p!q~0}#U|m@OqzV}cZqI$@FavZnOOtUM41Vj&F}R$dlv(7 zEKF;~j`w`LVY^Z!Ak!KzhS@h%n!UBl_6y{&G`nZ7zN1&&_wyB2GBn)CZAygb59LVV z2z<*x<|qcYMdV6p|MsmA8n4~XzQt+OwqKRiIh94emN@qb-J{KoEHb)Q*7Cu)!f@@r zce>o#ns{^uk)9hGytPS>VJD|_v{Ntn2?dXcV!J|zcbnCK4C_4a$sIJ0Z9L(Bn&cri zka2W*Ihue2VO65IAPU@ka$0-745n&;41f$2E4LvG`4aj)n2Yt_mojd>GWrC@1RE0lIt94k zoo86z9xR^KZUgIwwV-Z+6{zuCIs{k(X1?J0f$Be*pgp;4DTzvkn}By)LX4rn2Iy<1 z7}RM7D~p%(?cl;3=6MutySE}b=b)t2WwF?$75M4fGp}Dz0|3*EZsYgoHjfLr;5O=! zoa~8yWrsFk4X>X+3~q{w93^AatfFKj1@2)Z{n)hWXFMlh^@;+$`L$+jQ)LI+^L zUr!|8Ko-*2V_xWg!)!xEPEY87`hEFj&j25WuGC|WyS#Oo`X9R zKj~n$lq_ull$RmWH2#qGvooG4+u7#Qd@bOISng=DdR^_`5VHxli;Um${<^KJ7 zS0enpe$D_BB}5A@B|CvLukV|?-36!@hBrn(KJo95zoo*DN7Xv`y#W9SGtt;#5MUZo zY4T;b#(5+eSy5~T#a|WQu=K+rfazgRT`C<7Ww$^UL$b*9fXbj~eMMbpT(?7sFoykw zY|2W}AD)n+&-kYs0WweqL06cC8O*{?z_cEQ{ew0&{dZIE-Wh7fsBb~=fR63on@+z4 z=ADI4Ww(-V{n6^<^G852+y%T1EGC!Zw!?3GexU}3ny<^E@N;E~;(<;7ExVKC=S8Zs zy1XZyP38#%#KEz2o~k>q*^P*3_g#M@Ki>04?QV=;p0BShR=xeJVC*FqdNUnH@ATpv z5{92x+X^e%3L%!mKeqVWz1MDCo?$(*e5QG(DW?-B>SdSUv6vUE==p-@xMEZPSqGXJ z;B`^rZ@YhqAc;Asp7m{y-1#{wG3U7{*zJab%98@{h2?DV#4cK_3cm1lw!BSZ{kfgT zX>2=C00r0v5av=U2ory4UZ3**3+5AMbx=}>Eg_vm9_csjOXP6k41l>&jw?H`hQdNe z6PN^S-U9y*5%GV2*Sb)f-uDdVdB9ix5+nE0V#M+EzVP`+_k(X1&S@^eWGYa+ilS2Q zKNMS8dJ`!EON_2tb%%L;(XLgP)>;w(aZzG1>vc-yjc}3oX5eGPQ51>AtWYGjS{Fo* zrkF5HhLR+A{<%qyEPqBx3556EA?5R6X{!#CQ;SldzqcSqu)Gz#DkfiuI1}@SGkL{r z9Rge&1NH{uC!NjayHN0zJC-^Bb!A7ywkvcP{t1$n$iH{T5u8kA=K(m;uI0CKz(X2=aK z)AA_Z-0Dg;ST;ID7alQ5H5wCYFGL_PhFvNhKabz(JKiOf*a`Y@2T|>^PIY?b+;sf{ zlijlO%E-&No;`oh_Zj*A{ONJ8*ZcW;?)iE>e9(K4BzMD!=c>vO%qg60&^3j+ z;F7us0{;rU*QkjDy+j6@v;Y}$OxAT=U|loQuhRE;6u4$fJ++QTxE{>!O$wv9P;;*8 zHt%Iz{qffVrK1e^RdM-Y)nSM)q%c;MIo;g?q_&W|CjT{J!`fh}@u`6Frml;+dK#f7Fim zO01C#JL|_qocZ%jO6YuKM8Syh7VkK!Meqtxtm!aHC5^I;2vdPHEwGKfdAzg%kM(#_ z^Od&F$is%&ad-9J<8TZGB>*_lkxh|N{nCj0*Qrul*F9;F;UWDUE!gj9{&z-y?iyqZoq!?cc<7u@ei4q{9y6^(fss5-1Go;&&bz=YC z83eB;U=Y_`<_TX$PfY%}f0cBYG3q}70k&1kgM#0HJYDNU_ZulN@ea>?q5|e)w*bMX z>PcbiFVzYkA7vlr;O_3He38)Ew!*lfOQX9ho9P2eUG$N&UxVZ{ORULq%1UC2L>|fo z){9(FXm+|QC^z5Ru<`m|XpuaW%=M~gl$l8>3Gw;`=}(g5Xf1*7`yTKb6i|}ME|QFz zmIB>4^nJnP*j?9EJ$(pK2sKWBSjx~QjOjHZ5Bt&SH^@^x2Y(R3&oPyA<^s|^`F@?ykUt(YFqGs_^BV$`TSMOdp05TtEaxX4+PQN?&Z1Rpi zDWKw|qlf=ULmhR1Q1pQ+Z>7o zWPBQL?(BZ;#f~(lMHO1)KlD3on6?6$kK$=6^Y(^ROfGphxl)9(2jHmPe!o;4V>0}DzfDjA;CD76qnq-Y~m71fF?4=}lvWTRH zsCDP)5NcWRquyI7+0L}Pej5-3hr0hW1QxTIO1u>EX-FMzTK_6pcNmL3kx=3Ol(z&T zFw_nC`@=L%-x|GX6RBfb>_UjVAF$p=bi?TJ3MDqpz_+FwFJiQ={&!?9vDViW%{Us& z{nSI^ar)qyz zG7Az5x2~M(cZMKMft8;Hzb(TKp1d&Pu`S{`W%C4UVzI3-mAB-op8#S|=5TexRF9Ru z!tha`d@SnnFIz{jhCAR*Tq}P$oF}PQ?b-RLnG^AT9_PK&?-P^&5k<6q*hUpj{%*|* z0n}-;JYO#^->4mjfGB%Ws;{n+5^Kb(XDVfJ6g*v~@Gp5C)fzs-K_CjQX8R{*7N1hdQU)bJ6X?O8mj zpIDJkJ5l7G2cjG=lR~0xv>-iMwcaGGZEtYsQ)~)cUxJhVwi>znD@v*(;3cn!*S48@ zl(mx&p;)d3EXVr;n(Ew+xNy~MVs$(w%Ny@Y`%xPmU(N>%Q_ZtU*2%|f?l;!F z8dhWC_89uzTj+PE;JfST5pcu)8Sr+xyif9`znr40+_$mtnPu5@-iSZ-t2nSj-?0E3 z`0~gbX1&7%Qc5WqoXBuNJu??6A2`Eq*DZnK_7F0cR#VB)UZUU zQ3^uYUC68ONdc{dA<6@9JWH&;y)+0fnN7SG1-E*Iuit_E{2kb-5u$a!F@*0q3v%%W z>RF|O9^kO%L4Mh4g?5-FAYI4oFp-J1?Wdw6*s)pbCo+qNSKtSIlJif^7;I4;I^`XQ zMp2}1O!bIDJOB_ok>QaBeEUH>+|3P-mV{t)Ucb>CgF(Mp+0qA)^o?kFpxuK8!Le}X z)~S9|H1kp-1(Oq#(62q<$8)g&w~J3Y3w?%g{6bg)`@o;pwv~f$ML^d1nH;+MiYX7>@e>O`n?`DhhaK z9%PpJyy2LItS?+1pm?OLYxRiSXxlS~0*Dfk=Wy5eH=i?bnA30=U##E2fANxFzXM{* zQop=Q7xqo;T%kWbN0rEC2jBf-yGnXUKyyHSH43-1k_>OX^$ zACNgP<+jfyLc8+!r80S|Kn;ZtgGrm-x7W7so1mV#V+ya3q)pJ!7^NcFw%7cE`f+|l z_^+$fi++s=uCc#Re?jJJ6h_ZQaOhKHOlZ85Us9`JgUz zlZaiN$_;u~`W-;~C!+wIu{Mkw+A+7eiVDx-HW)b<)-{$PuXW1u#nUMcDy%Yd1I4OF zfa@MXic)NR(tRfMgedWIaXja!?kRY+AQxWY@;X6Y*c~ zHpBgpLOA_|vsa(;28P{jj3J*!K7HN%1MV3_WS9oW7*MMWsAa@Yt)Mg-CuF;uPo~K} zJ2K^4y-mNm+u2&>p=3=JJdA)nR1Nn=Bdxt*3Gzh+sb8XCOasBcWCnNNK_}PkU?utX z_?D}v@+f?jelwcJf7iEfMRT(&{k9cHqK*_vK*1k)Z#L3Lk z<<(ec_xr#VR4;5pA({OKkkss8)h)smcL?|MQ0^a6>^ZsZg0f!4OZ~z9v?D4q6UFku z1{*!=)pnrw8m`_4b3y_Aox-1cE$@rlqc-23nQVCpTK|p-JASmsy=(t+NgE3$IWLJkM&vlCOeIa-r2>CX$bC69; z*3kL!uqZT`LW<~@`G)JoKBs|Hd_bzNNwr^kv(&zB4d%Rzm&ajQSZ!94eB|s7Q8hV8ImPJQIkZAdLrZ#1neNY>1a! zzH=XF;1XOTt7=AL+2oKk1YFkra(E+}_}Rp)VIBkV;VPCw44nG}EK39ax0~Ax~|WGn9OEFfFfb^XRr)F!-tPEDxPeN9<8Q z&JQKfbs*3*E*G|7r_?Aqh~0;KEss=x*ZF1L18;!9xYpcs12YUX_mbDDM9n}nQ^`F; z6*-V)sQ$Cn^r>Sm5#hMTdhc}_CnAh3L+DF zDh|nJW?fLhECv}YZeZ-D9} zSyUhOgFc#R`4hYYSgd0P=Li?*Kx?<_eM|yz;0gb)*TeE35K_hDDi&g&W{gz_R3VWX zv{vME3Z#_*Df!lqFRe09)#mzU&LoKJBl6+;IuhPi#5NQUT!v;9#NcIANdINX5b?eK z!e)U=NZkL>XsW;%P;IEligV$^#jTf@)@Hz^l_H3z^V}v9`EhpNT-s_#hSE=>8e;LA z@ePmn^L-n-Dp>bku5cTpIc1mP7i9@qMe&yhg%#*lG-%U4(zpkm?jlb!Ihz>=97SD? zA}ORepfB9zpzlOMs_-;CBfC~dZ%sBA{bil&vGbS;2W>+;cvfKd6Iuc8yCU*_GC0Zj z@#!pbJNVs*>2lDM{p!I>dmsLzFgK$6ZaK0C zx(ZG)c`Mp^ouIu)q@d}qrtuiHh+e}0cG8iV^4UV2WDP?b4rCKE=2?_R-+;(r-h053 z(E*0Atm@UYWjy!icY}}oe?PC|hBi_RsdSU!MJ*_Np&9x4ZjMDYFza(=_{&{btXQ(w zD%wd%X%8fxywyu3C!dSp*b%l7w)q0p>$EPWJ`SBc4O4}sC`*%orJZq49wdC@wFvy( zFkxu>tKBb77M>8$5_fhPQAGU4SU$7C%vc^;XgESnLK%ATyST>>9)1fWHRrz0NPejT zFT7j7-sJ%O6-N`tT8CV-Tv+W6Lop&kVkPqF-6S-8UNeG>KHh%jrBt-Xq6&>=h{8j* z>7H@IvS`=G?jo6kA#k^qH_mC@md}j7?KWD12;&@s8!ZwH+x}K}0f9sv^7`s~P5ko!4Z_d;DAOPry**k>TPs+1>8uJ>e_QBbcyU?YG#K+dr>i0ng#f z@(oD)qa)_vWjuxzpH$t|g7uewzq5-ocfNPszM*)N`H+_#bPM51wj%wOUGuY0|9`y% zt&-_UUVujm$7dd9LcKcoQ#!O~=%2LV&(;EVpWKZ!n^Iu4!qV3l4LvE3Rt?Nyyye2X zH77gLRen766@7`$#T6Hw;^0MPWx{V8quSv-(h)JDNgndM|0@D5EnGr5H2_tFKR2*+ z^m?6&PItP2)$R3Ozc0pf6-<;pD%^$}NZA!VTp(y)+wav{yZ18>zCGgyvvtQCtzzj4 zqiQ$>Rl{C~kQea^E1H@C4~~W6oNul*9M$*i`~4)ZXb0{+bar>Jckkmw`Hq>PU3A#m z_BgN3K8|*feE05nb}mo+LyPb0wVMO_Rx~}AG;}L=+b%+Kq|nc$!n{$xwkehcsbR)U zsLyr)9D(?cNifrbqZ_YF?#kU{6=^wNO*tKx`rreJJ<$(Z)k7Zq*<*N%CAL+)_m&LX zRyrMezY*Ohv&K9%MT>rCW~=7*nwX>xVT@dCR@$QtL^I1Og`?1+g7PlrK=Qh3-`vF}2a2Y#=Bp=2RfF{pd)32Kb(WGK|A z%E7p?gs$fH6{M$>_I&kgCU6(6h9H8RLJiZ>Hf0RQ;{0&ISO8<-*>=Sq;STGE{a8fdkbB?y+7aKI3hV*);a!0U~J#1C9A^lb`_*8+j2@9K*H z0&lBg|IdGnxiG&b=9qUSq^&yXW|ges36u5K^-&)pn( zKeinpL5pH&ak}I^K;qhCy$H#S;P$KylB#BL+>lX&ch(ZXdwvg>ALB*omwYp_Gk62N zx6wP8wgBE<{1+&PYjCg0jsR~`$gXefiIc{D$2YqrpkXx7(YyRoXq(avM{a!<#b#k) z*@xmU;rh4_lX)nGcA==9MJeB<*q2D2c7f^Ua7 zfnlt8zRO6VwM2?Tsd4D%v=7bh%m4r_$dsUIpWlGQ7RH+g54zxDgPRZg8$MKD*DsEL zaIwzDKV-+3b!Tj|pG3jLkNAC7%N_^<;asf|IIAP3Wjwfj}hc4>Ts8& zLqc;4Bs2|t#KFSC0~nuZ)8Y#Bgv?>>J?9PmjX5r;Ss#pcf`HKlRQONmOvPEZCm1Bu z=JsoYxHG%I%pv&~2FbsRcG?SjP^QHtRa1AAG~C}Y5j&XR%B=TpeCtTEpyZsZH9R8~ zk(w<4^Kl414aG(^sGPF3C)n}C9=Cav`qlL+WoVebYdtd% zpkjJQ-vT#-rXT0ShQ+k(o4sZ8jQz{oO3>CP>DI25?c3RUBIiP_6bXWE|Jj)bHQ~=v z(!+xLm9o9I(LXYA$qa+sP+YFyXG!k$0&fBMTK562a6NSj?wFcw;_EMIn+lzh`Gg#LX%$?ScLTY5k9nl;TnIZ z$xF$8^y1)MalwoqmNu%S!h^CO9u7eVHlldF^b9EP{)OzhVs(Law38+PA;`#IZ(c&% zMT6NbUz~g>pSPX1YxD8=M1c$&RY@yd>)PiDr5p%pGiv(!7qa!3dMthu6)rEpJJDPe zrv9`(n1ENSI*J&fJ7`ovNg`(sgsai^y`d_!{aa4?Y@=79c)-BZ$VW;R3l$i6hDyY| z*ueJ$2PSZ0iaAnpAN$zm#X}ROCw|ck<`l#D-0(aU;r4w7f&Flb*tMvb1}>DQ2B;4^ zj{S6blB>>G^8ib;eebqvh zb$rlFvPM-NUbMVG5ZL*WaiZrNjI*Wp#Fvct=A;Ve487?)W}?qxoVLOBhQl=J?U}K! zL#KKs<`aV`C88E8WB5rGwC(?fBi^e}gmCaiU(chvL-1rmPS-V6U8Cmb@w@VL(30F~ zX1RE=me^M2uGZ~<>Q-~yaQEAzf;vOSJ)dD#F%@S7Z`@cxMba*j@uySe)96!vMSAWg z){nB=l}riiRzS-gO2oyAD5(b<0*V0`!TIAy9;+hbP>HLB?8C|{58>tBt}$$j%TtS! zV|7x{XDJoI@SZ(i5BCl%7?$us)tMj? z>`wDabtZPbs{6VF<)T+8009fs)b+sLCROB%>(Aj{uO)dKYNPp?K^eIFNRjcmzEE$s zERWQt!AfpL%oj#shne~G)^!N}Jz5gbUaaW1WpXt!@hYM7{>`Qh zMlb}Dr1_xCI)Q_Ibac2rYA=j#Ful3&3!LyPAbs%s7+?_7h8s9E(Rezv-+L$SXT&bj z3&uD9i4bhmqhIgx@~`q&#V6^Y5$Z+U6*9Yu}$3JhX9BWx|HkY_XT@&LI<%51^^uqvy&mfAKccvB;@cpNBQQ&jVSLx1eq* zRwVg;FfWD;GoGu*%#b&;JM$iI(m0M zw2M5vD7&_Nj7Dh;(>ph=t8(FhCxk3AX!c-kX)_8uPznxGxn_@9YG#R(Y0q1@uJjut zHhG2lNO5<+2~KNTR>;?po6x=j!JkEiL}HIQ@L$Zlo<`|3h*^QU<{i2F$Kc);IQZfEM*m;syP zKXkHgZ0_749`?hSr$+I2=G;M<_-w<-g2bqKk${=VMxtc#s0 z@X&^l#KGU~4Su>BE4N_SlKb}R*Tft{H!(RR&h0}X7az03zbCkgD}4~U(*LbzFvZ}! zoNsfR)r8i=+`JnW2oj@;lo314?G2WmPIf@BI!ZqlFY>tk!)yOl)*`MTF(Rnyf~O&D?PZ=)Uis{Q1f zg*|N7Di*mlw1%kNqZZ}Pq&_mLj|jX&$rU90_Qc3}(>*)@mV+oPT??>aylL{1=JJvv z20mO7A@9W0``lZ}MC%Ba3nd)h_jYZgJ-DA4F+-Lw7cL<*t24+#a1E`n-}+|(8DlKH zqW55g@OR=nP2ueiqPducX?}V>2O2;_-)914zyvr<*qSZJ;*=E0La%E643Z z_7JvglOd!#cM;dPQqwYOrJnj-;IcK6psEkXE5WpbF^Zzu{sj~<_NLCGNS)qYcKnBx z>Kvwto}w|m>lwCRhjq`7k*DMb{U&?LAFAAxoL~b3A%GIPpWSz!&=`N3s-!ug(LlqA zV*B7Q%X!NCbJ9`AI}OE4*jotqdEzSU4r{%QdTDjHnm*>~;p9J%+htA1$~_jgyR9Sc zLyxL~fQ@w6iIv#4Z&f1_+rQVaCT2(JL7gm9jxCgG&RvNQD;{+!ImuQbzPVR!H^tIN zCg-H`Mhma@w&jW+j1|b}C-;+A>>5vjG+tve_mf>L=Kaa+j&KLAg{*z;7W+VNdS~tE z=-bVG{PAPX5iFhcQH*fa7MjO}V&n)mh#fvpxTgY8p()pKe6 zeQF$9+aDFo8us1+&(dY3-}?Kj8og18zDDhBU%wvGee9?ybw=nn5Qmch`)fU^+V+s1Rg ztyV?`(!mNpe+nIr4;A;yiTRdO~Z zK0F94Bzh%1EV{GcXv=XDM|l2hm4rcsu&=!^GTsWzck}T-l)6wRPS(U!KNwM*6&8## z(pC*ETGfbWORvmYr&rhGI*PPRej^-Wp2bn`-&r~yGoD7vQ7#od*HGpV@^zZ>>OSc{ z#+%8qihi}_jvPUwvJ$D~52zU-THdk}Sph9kz+sDsNT&I2W0LU)Ifs+tuNpc9pJb&E zhuzoHVjK4pgto9J{~*l#=ykd#rdDt&b54EqX-SDvsE=i?TTi+Y5=`#pY?8W&qZ#16 z_F^fIQc?0wef>w?#_nn6huG+pbMnoTS8dnoepb;GR}!X=-?@Yskk9)(^0e5Bwjcfj z4wJ-qv3@g%HPJe6)@e1jx-_(>RSAmcB z^dH4sY8V7`!HSr|(SyaKjhjo~TZ&wNmZZ?hlfsjuwTBBSvxAmB<6nU<3`k@RRH@r1 z1Oz)4IPSuf{E#mr=Kg3FLS{YI4d$Oj%1*N)x?an;JdS2#b5uTlU7cS<=s<_;-CtKf zlLPte5YK^PUP!tSJd zNStpq)ES;HQPyBi*;nM%40guQX|OSPeAj@7_3F20v5$b*00_hja>G@diM$^7{2bsC z8CrV2h&Q`a-|cnwq5aPdwe-co`~Ig7W63m?S^X(fpGs?|Ftr}p(%sWwFO{rH)q;vB z`@sHqIu3=Z+W64eNy?}_^w^5k9ESD&viW9j;cLrdSg_V)pS{xD>bso zqY6=+z}Z;LX`4>?vy7kC6dwNOaR4?GUD~Ybhc>n^^YBfoMy?-kOlEZMSrn40$B`qA z$#b8xN*}15RS0Ln5NYqJdQs{oZ+BI=wcc{~^SA{3l&Se|8_%Tl@&D9rs6@Sa@^Ji= za^DyCEBtkyTmmSHlzIkduKGn(_I2|71cj5CPw(PvPRu`iv&khD)IkULzil#;QuB+N zUyph_3LAtJy-}jM?Nz1uXUeDYK!tfw)WeeD`DSM3Pd+zrzIK+_Cwwx#D7U;1gxtflND*WNBlr(L?~HKS}O-R)@t-gnStd6-vL`(CgOI48vVD z|IEg*nSvs!@Xs&>Z=E-c?*%7MjQdKWG>oUYZn3c2$&)uD-tW|!uec81WPQ3q#k-}T zH))5*6+7R-*2;jheQAJ3{$;yOnue`UCPs;?=npcEucvF z$DVVrkw=AxE>CW2l~d`OCnnSNgOwxDyr8&ciJHWqBv;>)8>3eF*$XRfba)+Klr!=A z!uCXyAV;qt$FG_fg0KcQPN7AwTB@7~I!KIb1aG@wCB0~*s6Qg6>(6LQKVblHCi)L& z2?0daV>aTQwLiIMhvII~HcFZ&h8%12Ihc%9QbRm!Sk8@(7_=0~S+%FPYrVQAOd!(+ zsCr>jY~Z+I$V)_aiqtv1kEPC}VtcA;v}>EqfwWZ)RVV($t|w%%zg0z4GXgsMobs}$ zbLs6-WQCh^R-5We<{}tbI+sCm)@PoKXL`WIf@#sNu(u{VSXg$3#ztJGNufr{d{$|b zMPR%}wf~^nE<`;eN$Ofy|C=lQe@9y<=SuF4_o`}#X*{d6jFDbnHsk}DQj+^Wxc=yr zji2hj_5GtYk+pV%wRd$Fdq%_!R+lnwyjAJYcCEg9T1jL@{TU{M4eE47Q7Cp%25dz4lF|zk zj$b9f^+OtOEm_awy|gVBY{bE=N8AC*9RD>~GS~gk`TABx$SBQZkn_u$6m$vV{f{)p z{)TT=FcPj0AVnkaU&DFkk{O+MZ&hj}FM~6WAbro4Y~ktgjZFh9Z(jRu)vrYet6-QV ze6@-{C@e`GO)~u<{O#)0_~-nufA71Z%ShQv=P~b2ig4i)GIyLkTzA!pe{%vY2vra5 zv*D{L7&NW_mrY%tK(=2<}r-`1K%0Vzit|OZl%ocH^}Ur=X0v z-Xngd#foO@hc1i#r_f#x=d35NZ1AkuYDz;5YCiV!@3%UEZ&hN;@~8gNh;5ca;F&|q zaNrW!&Wvy5q~Ko(NW6)@YQ>+uw~u=!j*n1&wenGu)a9vPpP4vQ{O9__?DhE}thgbo zV5+TEUv0qaR80(aR5IR$D_<|jF^NJ?){6pxLUdi1Bq~M;2P@7y^p2F@lwYaoyt?VX zsELAL$6nYFQxW9Q64t1a4ssT3Jr$NsYQtW}@Qoq#8$#piTc6A} zEd07)i3fYvD+>@vNo{*RKqL9X_v7DspuHIW4*!c!?COm3IWo;2 z6|${bsooDE!2LB%L0DZIo~Z!G3N6*2C<3l~O|C%-t4 zrM8CV3d+N^)T4&%AL%ML`b~|c&%!~cs1{nx;Sr6LCE?Lh<|QZ{GNGG{`*oE`h?r9= z*!1WyH2dyPLs6^a?3m5g!KQFh_m{0ggT?apwcvXJ+>P&hEt@UOQJ@vgm-uP)lVcFp z7?)KT`q`H4PxesjD{_>FPqDur#j1Koxd?Ty+e)6pR;l6{4RA?KT*?lVmTR~B2aLB^ zIf(y2k3+KfrvfaMT^$6nD{g-A@|kHPXEK6CosF8QIwpIr$A<(JRdCQ>Dk*lV4`1|a z%j4+IS4KAzHJEPW@wmkF1JLfzCDf=oNLqBAu)RC$o>J50+ovtwr5668*SdG4!u9>1 zo^?U}t#UzkC}N=hb@mfSy>od9EcSDRt3D5iJGxMOC95wf06u~eu@Sjly~&@*vb$zb zxcU;iQ+vi0);%$)^sK;4nz}UHVy;su!RtHd38^jw*}mvzty$L?gbm-^`LIFNW1YXI z-nUW5Etk#z<7_l+sf^~KY>*T|S^~rbJnqf@in@lbtXXvT1%xtJQH0J_C`&Xy#M$sa zi)5&kcJW-}$rX#MNn6#VR^crLAH8*`W;Cm$zI7W!?FjzB(q~u0XV-34wd-7mE!$Z6 zlZ?;TpoZNqdh>CjQPZiqr{JXG7h!aLZ-wQ{vT-}6`mS0u-vaB=PwTcc{r)DFcp*=f zv$==<&CYkDYw!B(eZ5$s=ggkAoF{Q3>O9yANbod7%n8Tr?E5nMtVFxu7_>?t$bm({ zRz}bNcUxa4e-uZ_uG^Jqw|KHk%tBA~9IUB|#omnOx_U5KfTeE2g7B40*_0LIn^(As z9(-lz(V*uNt4Up%)uD9N(&puK(QpvWO+q>X;QV&w>1(>3VRU&3Lc}D>96Z zvvCOSt9|e+;|JYM<}ERR&>oyqXF4rET2N9yt;B-@rnMlP-@;i{J@(t^iF4~WO!Ct8 z*|&@DQFq#}T4lAvDkI1-GwNK5&h4}Ag@#^VtmcM_)+^6G>dm36pt+z5VPrUV}(_kMVyDqe218jiTSz!1V zt5(8^+}Fp8N@z;myH0sRjs5t1V3@N>$j5Jec6qyH8pZna(Y{IkvIF4BucAg81Z@ma z>9+HEH06gX8;t4VY1r9Re+Zl3{unma_qY5yIkk~JQZJ&JGf_ZN#4dwtziLdqG&R*t zj-h}RQ0Ad{SWnBNdQ{PQL5wf&XNh--kgMeQ9a>f@>-tgsiZf4oNYnEJHC2uD8_^NZ zLN(g`cinuSVd*NzXG2w{s2EsGUl}hb(Voyk(TdSt0)%xQkPz-F-7L4As(#WIgR!44 zg%qhKim*u&R_#~qscR+2AQ-r1phxoa!gH8sP7AyTnSDpq45S2wYG<89L1H)?nXx(NMqZtx*haMPqX03_~fK*x2q%ktupQq_*jrl*Gp`WWGOV+ z`X7pbM?u(~ZV~?9+Y;js9%Ws(E{lV+DYGx@r^>+RNsmg0UN?IwgHIEGdgPr1QB%^D zvu7=0ycv?1#-~U!7AbdKxUP`vJl|YRixZ>Rnvu?xPe=c;zm>ITM2C|9H?N?p*Uixm_ zmu4Z4OMH{chg@gID*N2V=9uS+_ubO80 zsm$u|H+OqsgA+lH5>$GNFerzyr6Yek!V({QLoUJFV)a_$Xw{>`wli*dcZ9WbM|uO5 zT<~_*HC5VxPS;k=E6(jxkM6GuYkyqk8Kebwy1Z{wL{8j6{c+}@iQsz=l1Dik{m*$7 zU)<17_4c^3R?vMR*(#Pksl~LMj1LL&0K@G2iP9{|>Fjm(n z!hvk(g?#koYW#7|a)BW132dw2n{y(rEjc^E^>+4)Xb+RVtg(wr#y4{OZy`T|-^f=A4_YO#m?I(JLVR{dGBIgM?iFp)dtUR9pY*bu&VZ$Ld zUEY9iQCWxH~p8|3XC3 z8>S0=X6e{}5`p!q;Mj^~xImn)c+|9XSF9j(?ZB2L91^*Cf?)pD>na)!xjrBo5$vEp z&UT6CGgwtWvziaoXvEI#eY;n(;TEyVe;3C(-?}wT&kup0U&;~oqPGV9vIbQ!V1NT+ z@ud%67RwCfM!tq0RC)P3&WW8+Yg~#)N+1n`F z`>lbos|BK~Yk3cE6+b;xwfPq?;Ikx)U`MibjC-9PNkEcn_jN1qf+L}!fl6=EcdUB@ zR{yhQGu#hwV+nV&gWUUA+ockaQf&`4XVFBL;5s|NphD!_8aqV%-0LoRNE&{&`-7?8y%k>Xn(MM7z0e|5O+bGZR+skB?@eLB0dtEC zFz}}ZXeA20BQGDZWkkTt_S8QlNMoqu{i}Fmj*GH5`pCPssqOTzlb!+sn6lx2Tjf+* zHb)u+hK3dW=YP%P6x^w^1i+t2yi?blQFJD-8Kxa~n{m@E{=66v9g^jkb~jCOKegyh z`L~A9BnqXv&v-SGd1CY?3;s5mUiRJuUrplKTo;e93Qe|j7Q3otnU2*T7JFY^94!|h zwmzE$Zi)rWO@aTT6n}e}83NQe@-F@f)rN--%(rw2>SuF=9?klKQ6d`31)- zPT{DHW$(TYZR%z`{`Skgus z?2aOHMf-`DAoh%-iR`QWk>G928|ia)ziNjIynN;8`am^G?EJb;b#-wqZyPwz*MGdM zg@UnG(%k8-O7a&k+4>DSdmY02o}^F7R_Q*rYkwrf;B3Ml$e0)uD_5p#D}w_Kk#CZ3 z1}mh%mspB}vr%<6C&)1uV$u&Z30n9&Pg%3ajahI8aCo!Hv-xd4ZB}RsHo_~UD97&# z?HdjPyBF`4&cMb2XNY?e_+|EWk86b5tfVNEB7_J&1s#eOK*Ccb4P@Mw6I z^r4r&(`(Qg6d)^P-0(*ngI$>y^c+MwrLS3##-t_0t`o|1nr;u*_vDjUpsvb2;!%l$6X=T_QbSh2bXIWvw+MZkG$3pU?SZP!v< z*+<|;GA}FqYjBwAW_dX!_cBPm3Des z*$S*pU2NOXOL-61X;;seF=$_DZR42(Ty+p?c_YBdq;Wx#L!`+bk4qY= zT>o)W;OV0BC9dZ~<;Ikmch>F31r=p+HAu6@b(+lsA9J-dROd-P&_d@a#sI2)c*7-K z_V5JIv_aH*U3Jw@KAm#@{i?}-CdykIZ;oZ9kCkm?8FUB(Y1H} ztrZ8Z^aTT84jQ|6E9lW zu%#_7@WK{ToJ~U&57H!>vpg>F>po`eKjFE&3QzW&k0I7&e&|R zuZ1W!e`=cF<3bT&6!&d9<8?4_16%fzR|84PhyWd?@;=e+yFUK9>mF5+>+eEBdOrxo zmN(B6WqhZ%m}p@Zm+{+aft+U?XSohkR3(r(Q2SV+_F5OBxJ63U<5go4x&a@P!|^`|K3!8$4)vE(Ae(}0{)hj! zuzYVtYa=tS%3Q71-MD#F#@4Q$9>nA&%s9^6mwTv$-cgQe?35X^q`)TBFY588RNVivusIkvgnvnNx3WkSkmFyy1ou6BuQ`K9`6q8S%Pp(1 zE*^cI*owA;jyunP^n7ClMVP%oj>xUDv;IVgsAC}E28HS+Vu3$_<3$T{EVnEeUF-OC z;wr49WW084x7kO($vpC={^>DaH@;lCAA`*(y5BBozbzQ5yA>0q9q=%vBk54ZXw7bS zXlwdw9dUgHL2N&G|!V(FfV(vnDr;S5xSViBKri0+~JP8Ih@^SVo| z!c4)I+J447qg|M7jinB==7G4?hq`)nfggMA#@sjx!K!5^cWR$tb{^rgC|*3&S@~u& zKijoCJ-Gm-ppU<4?$L%4w3FVUIVDs`_?Fxj!21bY`0@9R3H)k5!C|t?VDMy##Ra(u zyIUM!(hQmv=7qwsEAvZnX&PH6@6lA%O)2Y97K3lurhWcL&8fw6x-(&*}QOJ33?DP z719C@0;?$6EvahWOfl~^Cb=;$Ml}0|2dXx^Utp~7v$me66GJ_a<6G7wH4Cc6c9(5U7-|#KVs^LNtyT1TN#tCWauBFQ*7ytaoRM zajDXo_58B-@H_mfWe83G(6Enb`v2zKocq=mX<#c$aq6A18gk;Qc{o^>!EwBs2D$zX`wj&`_MgSq zu4J~LL~B>*ql7%S(Gn$6Jv~ZeU(ft9sb#YAe3UUSukB{3NpJG@$Yd$AaQ-b@x2h@4 z4j{=?TmFd=nhX;ZakCU@jE^m^24m|}$wh`LCgxp%Li@pW;&kJ;E?u5hL z#wJs96Qc+g4)eP~j^y3&<5;a_p!5vknC%WM))}=5RO*_$jizZYp`R#_aE!SL{9fpv zv1NC}O?l1p{zsL)eQ!r=HoIT_PX3Ztg`}h%Us~`lB?Jp*o2sgQp1z9`%2v#u*-}xj z{l;zht`g}Y_8wC`!ACfjOEs^571K;)a?DZr-6`Y-YXg?U)~WL%4H>}YdM9Q$2de)( z+2vO$Z4Y{TgOC3Gd)izBde21dOXiUbX&&)qvSZ%aU{Mo8f0J$mO#)%2IEb&4j@v4f z5#1QgLLC@784B?Se6)5&fFA>ZH7-BQvDqf3uZ-DC?~NZFt=R0|BkvfUfopcpl(LA`%zv&Rt7_@YMjlHrM&+91FDav=caQ$GAViN-ZMJS^_xM3@J=l zbZ^$Br(gg;bha)dK-QeY5vC&eYO1ip@tupTek{3p2`HZBK;<|5$K=F68FvTAKS>za zI-59^_+Zy67N|h`WwASv;^UDCtp^yw@>Syv^ZfgV5XDOTQPCPCAI>6EAOHelnL#-L zRT8))X(_sej*5V+CrU9UmdZ315f}V_bI@ixGsQ6k1{sYa|zz$EBskf>h zIyfe))tJvEqWVWEmfJ~d${zZmbC(uuUbX;QlZ-%So|LrZ zBBqK|T&`J9(sH&k8ETMHaIUN6=*4r+)IzuOYcpfrpp*+n4lKf@WwbuouRPx#I!Mk7 zh=1E*TT-aVajwN1ny1{F$!*H0UQOm*hO!q^O-#jCo{4Q9^geEP4%(te;+06Yl(S4b z2fshR6mja44$m~aU{dO)X)V-n1Z9-+!-(3CgxGfaM{HOyQPK6w4*i^A8i9tV63p)G zzj-%jn1;=TRTYCvUs_SMe8pH?ghp1SSQFFR%bY3f9(*i)nf_VfIdnYtEz(_0ZP_7W z`y5P|1fHSakG4I?s!EzPkAWK@5PaZrZu%W?6Wj%+pnTcd(Wdgp;jT~=p6l1SFl+QE zcMdZ-ocOJ2xD+HO?Bf5Muk3B~!iVTLXqtmVaf!?>W;c8K8{R zv{I^MF>FN3B<6qMmur{fre~^&*|B9KHd(DB73q1IH-#^grHJqq*u=qUMq34_i`-nw zbAjYA=E9kZ_uQXmK5TuIjO%*9W4p?H9s#(!Z8_|FliZlFA2Y}KUv}1;|M835r61QX z|FKun1ZR^~x+Ym6EIMLKnsQc^=AO_%o=lbl8C^^n0Z@obkv@P@J3C!n1%1r7q9GdD z0fk04ZHRVN+q%xs<<4BLiCXY?jF`QyjE}A+_1>!de4Qu8Ef=VsRBVXoEF@Q4P&Rj@pa1sc)(D0dPUH7&F+-yz+_u zBwbLp3K8}E7|_z@e{NM%HU!mh@4d(}*6DcMbs+jbXbChX-!|#(EjapA&6!>SP0Rn0 z0~Q5fZYhlg`wxqPiwl{}?HSxm6?}w|mCg+&B-&SgeRg-DW5!)~?R-@zC*ix7!dPfb zC+@Xk>O5m}z6$Jw)VX{`j^rAzd3O)=HD(!_%H^v;WS}c_H68DnjwcFCLt}k8Za!)Q z-Ftl*-2(k0lR_4PJk#pg*Q28?o4;7TQR%1Feydu z09QE2eVv*L2Z!c!X|pNUEoxhziP6epSrtDs^b?Gv?0p=Cw?Qn2Aj-=;9+7Y_-}x_f zszp`@mnyBQ-b3P~fnyCK2<#oc{1~^?>QQLr|9byDoDV*T{?Padj3G^A@yBcb=f|3D z%%cs9zvkhcelt|_=@p?l3;J2{aft!o^Dig`faiJjGF?=o*2i3?dCgbb**U}D$(yKN zp;Q|?r=yvj|wh+bY5Gi*q8B}HTs+Fj6V9IH7 zlIG&*NB$>1*jL%bv}45ZuAP1Pqu(~mRJKx(v-^pxOw=!r3OMdZ8KEhWdz!9!sZC-g z)%330p_i&VLF*3WF&=Kxh(h&g^7>_>gIQhuk_nJ_^_}WqL+UN}wNP@w!yULxuN5TV zf56`+mVu&%_*-1VwM8_(;#yRRdrOHj2jpL%Da*)0y40DL#%wH8(_H?Q+tp|XeYBH$ z_3h)+UY<09DpG%)57%68363kwlq`=D%I`&4qx3g#wd*?X<72~{Gw@Q(P69f7X}CoX zV_8CZ3np-{Xf+cm_3HhOpUPB2oANJLe>b;7gno+7k3WFp|1TfJ?x>jBwU?F1*~FYS zGH-LR&Q~>ZrVd^^zZMBhR9;l`(#s42SC6L!Q)#aoGZiF!e8A<8cZCaERB13$_&?qb zSC6kR{1D1RZDLOkPdKij^z^2Q?MbadT%vKW7A0-da!tV-i36hL^O?8Y>HV^Gbap4K z>3<@&1GHX;Xpti7F5|V9IWQc@)Z3Ua76rIFy;Arobg8;J1Ad!OgkkeH zT*>uOa0qnZW*O|)-5||?l;DTfb<9~F0h4n7qG!@ z7D72wz(*Yp)a6m&n&Ea2FKOL#|1wLz70&*M>n;dg}r7JE)ttd zX+X@0p(^2LQ3prpFTJ^CkH#cOpE@`Jru>&k7(UQo2R3y)McUK2bo3iU!5}YZP2b@z`Y>}1G-n?y7#Wx48ad?IVh^xasF&ONsxRNy=w>i z>=+Iuf@knsl{Qb148f(psB)C7!*;AbDte0zvWb-1D;*-}H#bY&0JB5e@SFMMFg=4? z>TcC1=NyYnirB4LxJm~_@09Y8?2`)KFI%5LP&FIZ?_=2~APLa{p=Z*wNYz50_9O7G zCFP@oj@hgNs0r2d=fwvJeUl0x0Bbp#a@%!QR@08HfGbcI&^Nbr8Phi#gNl5mycJbe z(a{Uy#-OF88|?DKnLaZP;C*fv(0u|6l_fFZ(eU)et{6Hlpy5z7BN^|g=RLpm+%+^l z)FI`+R^I4@9E`PA4c482OZQ~OW(JI#8oKX>p=d2SvrAg^C-@FM9Znl{`Q8jC$0P9e z$Nzrxoq~19DBnwGmpu7KE zx`+@VF%GuD2Zld#aujD&CR^k^ZYiH?qOU(s1M&LHKsCJo5&_|_U&dYBNmob$#L=IL z86>1imEKN{0E}yYY$;y}Mh$+#Uxw{p7S$VDlJBcC=(ij*zJuns^09LkLFErPUpDR= zX$4Qpvl^O`g-||4tEeQzed27EZW{~~_2i!t{x!{xyRh^s$bc}C{n*~l5SJ~HD{c7IVI=$c+gzonJsj@*r zlmUTv($vVVF{r8}xY3m*Yy5YZ4Iz;<32wVUmTy)|`9VLHLxL>BuMSf~bKij_?_3RT zw4sY$5n6%E;OVC6iNa7QsD=i#3%5PKI(kl9UdJ65`&60{5HgM(S+ri+J4|JN+SD`z z=d!gVd6=pp-PAM!Z?Y-KhNd)A6C#?f%7&?4kD=8Bijv?&+6(rK&hIFoWu=?~do|s| zV?1Wos3JHlQAj6C;I|aNw^Bde3vg1uFf|RQuqz}a>Y)zc4P&PWjmOg!Xj4nXVxfG^ zmJN)=5VFR}sR}-rD6D5TD|l0gujYHAb7Pg~0^04s@$gHQ<-Zj(-&H*~EoO&1neW}s zO;sC?vNHK$GS1e2hK3l z6wAoV4iA;6^-4DP#S9ur4B9h+j>*0B~%K=U|Cg3=Ui z+{FMuT09P>K2w?lMMU)%E5H-yjc<3eseGD^e2j|jP^TyB2W#kB)s)n{w z?zo09`4GMfw8r$pstiCy<_N5)y}FU6mjItNg3eN51AJxt^>zJR0dzIFp zV;_^!qdcbL)TW4rb4WP=mUsY+-ms5*Aijb@INoNlR+kB>59W>r-`K_R3-mlIgMr9c zTnSP_gh1~sSXPcfNXWw)r)6zlAf(4l)2=jUg_&aqa!iyO3n1e|HJV{8`I9 z*I}N){9uP`_hj4L)n>&XC-|%XIGqEXkz_qih(}J;X;bI{yAXaHqnAE~>>zEQx;S@3 zVXd>|r|Wi~ubeXI{qDYm;3)^jbgx}K>%`{YU8T)6ohL3Y(_I+s=f2mY`Cvqi5Kba$ zQ884VI$AfJfmg;Bk&Rw$N7Ln#+;hCnq%t5jp!t>K;Cs3ZlMDD?g%?ZNhFlVd5+3k1E9R6RveL&BJF(k;?1-C z^LuD)23~rMA;z{lPBD+oz{gSn{S9C2z$TUCXcjvKm^KUX`-T5Nd}j;wF8a#|uQi41 zs_vP5#k~pR0scSl(qXF2EcyJK;r6IuIpxWGxL|L)wA4zdOwmifc44A(M16tFhx+rj zU4DV7Wh~LMO5<;)r2CNC1LdVk!sh{2g~Tn6(?SJ7mI^`Dt6R)gp>4$Z))qvZOOdi> zCOH;`vlnpnoS%XLQ4#Y01*dd-kHXA@_c)yKBBkSWPK;U?Vxfl-Qu9Llh=rD2D`}q@ zqRChcwE?tdhWvpGtlT&~w1t7~kd}|n_=6aZ#|bp#0jKJIoM~a~(L|wiMEZk{T*g7D zsGT@tYufY8l(;>{*K*W^ndSH?p&ZXLI3Z2K$d=%X&A$Qv0>xx?{8_j#V$X;II4hw1 zw%zA8!YK7~RS~xlMJnO;Q(RhQTuWhiO z;-1Dmr!4SQLmhiJi^5l>`r3y;kF(V}H+KW(d*{6XC-|OEV7DlXb zhGZ}(N_&UkRjnV*8JpyD+;q|QvJl`xDbYLR@0rbPW3_~V6lt=ZIAio4j2ol2*LZ-l zdhM^oa+P|hZeeX(vWQr2Vp)P&Xv52KOMLq3J&u3Mi4b(p!kxCNhd~PyW+&}Wp)d53 zvrlk~YQ4Wk=A`a&HEr>R;{+{PK8I4IP@YN)%uB{C*pTUSgcAwhmJn94XdK6$Z!JEXcZI(*w@wv7U*-MqUh$i^ z*Ij0_oBKp^+>_*}9-czvn#x{D4IYF!T@=AfHrAY|2e`)|UBmAELg~@;p6-3jUKTlm z7+4%L$vp5jIk54Y{ha4|HRBq{j2}CSGx*ZexI`o=Ql=;cX)}nqx_5f@k2r~spweUh z^%sw}$2WKM`o7GC6WHq@oOX09YXzqmLk4aIC^+B8TD3W6W=_t`lHRafFb1RzBgSg- z7eNnJ(!Dou4QY8L09~;snlELAE|_i)DDrUDN^ZSOl8FyRkgs6HA4zP~sH@>3Cq?Re zLf?&1$}8k??MCbahVQagam$S-mva_DU1WSigE0mD~LJgw@h>kHO^+6ZjnvKh0x?>8bw&-_%G!?0v5GF-g5~`a`mDxYZih) z-G>P()^(NU9uO+|dI#B_7xecz5p{y-@LSi_-2Dvh0ti(VE*0&Jc+Djil7S}TI;0gE zHE^1D4NCYsLn?A6Of~F*Wg#~(n7CAETaDT@7G^_~7k;-y+LDi0C{vNB-5Nq%hR!`5X-?{c)!Dtjt*1lcq7QJHp>6Ta0v6aoNJMNFRQ0P$ zxI5nXP|aWS~io2;0&Am%r@ zqk=8~Vt-SHHgJEU=5*ua1d4A{W`wGDK? Zziv+4)ANJp{z5Bi#S;I;GC%&e{{!OIW-tH% diff --git a/vendor/fpdf/changelog.htm b/vendor/fpdf/changelog.htm deleted file mode 100644 index e768b4aa..00000000 --- a/vendor/fpdf/changelog.htm +++ /dev/null @@ -1,146 +0,0 @@ - - - - -Changelog - - - - -

Changelog

-
-
v1.7 (2011-06-18)
-
-- The MakeFont utility has been completely rewritten and doesn't depend on ttf2pt1 anymore.
-- Alpha channel is now supported for PNGs.
-- When inserting an image, it's now possible to specify its resolution.
-- Default resolution for images was increased from 72 to 96 dpi.
-- When inserting a GIF image, no temporary file is used anymore if the PHP version is 5.1 or higher.
-- When output buffering is enabled and the PDF is about to be sent, the buffer is now cleared if it contains only a UTF-8 BOM and/or whitespace (instead of throwing an error).
-- Symbol and ZapfDingbats fonts now support underline style.
-- Custom page sizes are now checked to ensure that width is smaller than height.
-- Standard font files were changed to use the same format as user fonts.
-- A bug in the embedding of Type1 fonts was fixed.
-- A bug related to SetDisplayMode() and the current locale was fixed.
-- A display issue occurring with the Adobe Reader X plug-in was fixed.
-- An issue related to transparency with some versions of Adobe Reader was fixed.
-- The Content-Length header was removed because it caused an issue when the HTTP server applies compression.
-
-
v1.6 (2008-08-03)
-
-- PHP 4.3.10 or higher is now required.
-- GIF image support.
-- Images can now trigger page breaks.
-- Possibility to have different page formats in a single document.
-- Document properties (author, creator, keywords, subject and title) can now be specified in UTF-8.
-- Fixed a bug: when a PNG was inserted through a URL, an error sometimes occurred.
-- An automatic page break in Header() doesn't cause an infinite loop any more.
-- Removed some warning messages appearing with recent PHP versions.
-- Added HTTP headers to reduce problems with IE.
-
-
v1.53 (2004-12-31)
-
-- When the font subdirectory is in the same directory as fpdf.php, it's no longer necessary to define the FPDF_FONTPATH constant.
-- The array $HTTP_SERVER_VARS is no longer used. It could cause trouble on PHP5-based configurations with the register_long_arrays option disabled.
-- Fixed a problem related to Type1 font embedding which caused trouble to some PDF processors.
-- The file name sent to the browser could not contain a space character.
-- The Cell() method could not print the number 0 (you had to pass the string '0').
-
-
v1.52 (2003-12-30)
-
-- Image() now displays the image at 72 dpi if no dimension is given.
-- Output() takes a string as second parameter to indicate destination.
-- Open() is now called automatically by AddPage().
-- Inserting remote JPEG images doesn't generate an error any longer.
-- Decimal separator is forced to dot in the constructor.
-- Added several encodings (Turkish, Thai, Hebrew, Ukrainian and Vietnamese).
-- The last line of a right-aligned MultiCell() was not correctly aligned if it was terminated by a carriage return.
-- No more error message about already sent headers when outputting the PDF to the standard output from the command line.
-- The underlining was going too far for text containing characters \, ( or ).
-- $HTTP_ENV_VARS has been replaced by $HTTP_SERVER_VARS.
-
-
v1.51 (2002-08-03)
-
-- Type1 font support.
-- Added Baltic encoding.
-- The class now works internally in points with the origin at the bottom in order to avoid two bugs occurring with Acrobat 5 :
  * The line thickness was too large when printed under Windows 98 SE and ME.
  * TrueType fonts didn't appear immediately inside the plug-in (a substitution font was used), one had to cause a window refresh to make them show up.
-- It's no longer necessary to set the decimal separator as dot to produce valid documents.
-- The clickable area in a cell was always on the left independently from the text alignment.
-- JPEG images in CMYK mode appeared in inverted colors.
-- Transparent PNG images in grayscale or true color mode were incorrectly handled.
-- Adding new fonts now works correctly even with the magic_quotes_runtime option set to on.
-
-
v1.5 (2002-05-28)
-
-- TrueType font (AddFont()) and encoding support (Western and Eastern Europe, Cyrillic and Greek).
-- Added Write() method.
-- Added underlined style.
-- Internal and external link support (AddLink(), SetLink(), Link()).
-- Added right margin management and methods SetRightMargin(), SetTopMargin().
-- Modification of SetDisplayMode() to select page layout.
-- The border parameter of MultiCell() now lets choose borders to draw as Cell().
-- When a document contains no page, Close() now calls AddPage() instead of causing a fatal error.
-
-
v1.41 (2002-03-13)
-
-- Fixed SetDisplayMode() which no longer worked (the PDF viewer used its default display).
-
-
v1.4 (2002-03-02)
-
-- PHP3 is no longer supported.
-- Page compression (SetCompression()).
-- Choice of page format and possibility to change orientation inside document.
-- Added AcceptPageBreak() method.
-- Ability to print the total number of pages (AliasNbPages()).
-- Choice of cell borders to draw.
-- New mode for Cell(): the current position can now move under the cell.
-- Ability to include an image by specifying height only (width is calculated automatically).
-- Fixed a bug: when a justified line triggered a page break, the footer inherited the corresponding word spacing.
-
-
v1.31 (2002-01-12)
-
-- Fixed a bug in drawing frame with MultiCell(): the last line always started from the left margin.
-- Removed Expires HTTP header (gives trouble in some situations).
-- Added Content-disposition HTTP header (seems to help in some situations).
-
-
v1.3 (2001-12-03)
-
-- Line break and text justification support (MultiCell()).
-- Color support (SetDrawColor(), SetFillColor(), SetTextColor()). Possibility to draw filled rectangles and paint cell background.
-- A cell whose width is declared null extends up to the right margin of the page.
-- Line width is now retained from page to page and defaults to 0.2 mm.
-- Added SetXY() method.
-- Fixed a passing by reference done in a deprecated manner for PHP4.
-
-
v1.2 (2001-11-11)
-
-- Added font metric files and GetStringWidth() method.
-- Centering and right-aligning text in cells.
-- Display mode control (SetDisplayMode()).
-- Added methods to set document properties (SetAuthor(), SetCreator(), SetKeywords(), SetSubject(), SetTitle()).
-- Possibility to force PDF download by browser.
-- Added SetX() and GetX() methods.
-- During automatic page break, current abscissa is now retained.
-
-
v1.11 (2001-10-20)
-
-- PNG support doesn't require PHP4/zlib any more. Data are now put directly into PDF without any decompression/recompression stage.
-- Image insertion now works correctly even with magic_quotes_runtime option set to on.
-
-
v1.1 (2001-10-07)
-
-- JPEG and PNG image support.
-
-
v1.01 (2001-10-03)
-
-- Fixed a bug involving page break: in case when Header() doesn't specify a font, the one from previous page was not restored and produced an incorrect document.
-
-
v1.0 (2001-09-17)
-
-- First version.
-
-
- - diff --git a/vendor/fpdf/doc/acceptpagebreak.htm b/vendor/fpdf/doc/acceptpagebreak.htm deleted file mode 100644 index 8db1d26d..00000000 --- a/vendor/fpdf/doc/acceptpagebreak.htm +++ /dev/null @@ -1,63 +0,0 @@ - - - - -AcceptPageBreak - - - -

AcceptPageBreak

-boolean AcceptPageBreak() -

Description

-Whenever a page break condition is met, the method is called, and the break is issued or not -depending on the returned value. The default implementation returns a value according to the -mode selected by SetAutoPageBreak(). -
-This method is called automatically and should not be called directly by the application. -

Example

-The method is overriden in an inherited class in order to obtain a 3 column layout: -
-
class PDF extends FPDF
-{
-var $col = 0;
-
-function SetCol($col)
-{
-    // Move position to a column
-    $this->col = $col;
-    $x = 10+$col*65;
-    $this->SetLeftMargin($x);
-    $this->SetX($x);
-}
-
-function AcceptPageBreak()
-{
-    if($this->col<2)
-    {
-        // Go to next column
-        $this->SetCol($this->col+1);
-        $this->SetY(10);
-        return false;
-    }
-    else
-    {
-        // Go back to first column and issue page break
-        $this->SetCol(0);
-        return true;
-    }
-}
-}
-
-$pdf = new PDF();
-$pdf->AddPage();
-$pdf->SetFont('Arial','',12);
-for($i=1;$i<=300;$i++)
-    $pdf->Cell(0,5,"Line $i",0,1);
-$pdf->Output();
-
-

See also

-
SetAutoPageBreak(). -
- - - diff --git a/vendor/fpdf/doc/addfont.htm b/vendor/fpdf/doc/addfont.htm deleted file mode 100644 index 6910bbb6..00000000 --- a/vendor/fpdf/doc/addfont.htm +++ /dev/null @@ -1,55 +0,0 @@ - - - - -AddFont - - - -

AddFont

-AddFont(string family [, string style [, string file]]) -

Description

-Imports a TrueType, OpenType or Type1 font and makes it available. It is necessary to generate a font -definition file first with the MakeFont utility. -
-The definition file (and the font file itself when embedding) must be present in the font directory. -If it is not found, the error "Could not include font definition file" is raised. -

Parameters

-
-
family
-
-Font family. The name can be chosen arbitrarily. If it is a standard family name, it will -override the corresponding font. -
-
style
-
-Font style. Possible values are (case insensitive): -
    -
  • empty string: regular
  • -
  • B: bold
  • -
  • I: italic
  • -
  • BI or IB: bold italic
  • -
-The default value is regular. -
-
file
-
-The font definition file. -
-By default, the name is built from the family and style, in lower case with no space. -
-
-

Example

-
-
$pdf->AddFont('Comic','I');
-
-is equivalent to: -
-
$pdf->AddFont('Comic','I','comici.php');
-
-

See also

-SetFont(). -
- - - diff --git a/vendor/fpdf/doc/addlink.htm b/vendor/fpdf/doc/addlink.htm deleted file mode 100644 index 35c666d4..00000000 --- a/vendor/fpdf/doc/addlink.htm +++ /dev/null @@ -1,26 +0,0 @@ - - - - -AddLink - - - -

AddLink

-int AddLink() -

Description

-Creates a new internal link and returns its identifier. An internal link is a clickable area -which directs to another place within the document. -
-The identifier can then be passed to Cell(), Write(), Image() or Link(). The destination is -defined with SetLink(). -

See also

-Cell(), -Write(), -Image(), -Link(), -SetLink(). -
- - - diff --git a/vendor/fpdf/doc/addpage.htm b/vendor/fpdf/doc/addpage.htm deleted file mode 100644 index a870812e..00000000 --- a/vendor/fpdf/doc/addpage.htm +++ /dev/null @@ -1,56 +0,0 @@ - - - - -AddPage - - - -

AddPage

-AddPage([string orientation [, mixed size]]) -

Description

-Adds a new page to the document. If a page is already present, the Footer() method is called -first to output the footer. Then the page is added, the current position set to the top-left -corner according to the left and top margins, and Header() is called to display the header. -
-The font which was set before calling is automatically restored. There is no need to call -SetFont() again if you want to continue with the same font. The same is true for colors and -line width. -
-The origin of the coordinate system is at the top-left corner and increasing ordinates go -downwards. -

Parameters

-
-
orientation
-
-Page orientation. Possible values are (case insensitive): -
    -
  • P or Portrait
  • -
  • L or Landscape
  • -
-The default value is the one passed to the constructor. -
-
size
-
-Page size. It can be either one of the following values (case insensitive): -
    -
  • A3
  • -
  • A4
  • -
  • A5
  • -
  • Letter
  • -
  • Legal
  • -
-or an array containing the width and the height (expressed in user unit).
-
-The default value is the one passed to the constructor. -
-
-

See also

-FPDF(), -Header(), -Footer(), -SetMargins(). -
- - - diff --git a/vendor/fpdf/doc/aliasnbpages.htm b/vendor/fpdf/doc/aliasnbpages.htm deleted file mode 100644 index e76ec917..00000000 --- a/vendor/fpdf/doc/aliasnbpages.htm +++ /dev/null @@ -1,45 +0,0 @@ - - - - -AliasNbPages - - - -

AliasNbPages

-AliasNbPages([string alias]) -

Description

-Defines an alias for the total number of pages. It will be substituted as the document is -closed. -

Parameters

-
-
alias
-
-The alias. Default value: {nb}. -
-
-

Example

-
-
class PDF extends FPDF
-{
-function Footer()
-{
-    // Go to 1.5 cm from bottom
-    $this->SetY(-15);
-    // Select Arial italic 8
-    $this->SetFont('Arial','I',8);
-    // Print current and total page numbers
-    $this->Cell(0,10,'Page '.$this->PageNo().'/{nb}',0,0,'C');
-}
-}
-
-$pdf = new PDF();
-$pdf->AliasNbPages();
-
-

See also

-PageNo(), -Footer(). -
- - - diff --git a/vendor/fpdf/doc/cell.htm b/vendor/fpdf/doc/cell.htm deleted file mode 100644 index 5cbfb3ed..00000000 --- a/vendor/fpdf/doc/cell.htm +++ /dev/null @@ -1,104 +0,0 @@ - - - - -Cell - - - -

Cell

-Cell(float w [, float h [, string txt [, mixed border [, int ln [, string align [, boolean fill [, mixed link]]]]]]]) -

Description

-Prints a cell (rectangular area) with optional borders, background color and character string. -The upper-left corner of the cell corresponds to the current position. The text can be aligned -or centered. After the call, the current position moves to the right or to the next line. It is -possible to put a link on the text. -
-If automatic page breaking is enabled and the cell goes beyond the limit, a page break is -done before outputting. -

Parameters

-
-
w
-
-Cell width. If 0, the cell extends up to the right margin. -
-
h
-
-Cell height. -Default value: 0. -
-
txt
-
-String to print. -Default value: empty string. -
-
border
-
-Indicates if borders must be drawn around the cell. The value can be either a number: -
    -
  • 0: no border
  • -
  • 1: frame
  • -
-or a string containing some or all of the following characters (in any order): -
    -
  • L: left
  • -
  • T: top
  • -
  • R: right
  • -
  • B: bottom
  • -
-Default value: 0. -
-
ln
-
-Indicates where the current position should go after the call. Possible values are: -
    -
  • 0: to the right
  • -
  • 1: to the beginning of the next line
  • -
  • 2: below
  • -
-Putting 1 is equivalent to putting 0 and calling Ln() just after. -Default value: 0. -
-
align
-
-Allows to center or align the text. Possible values are: -
    -
  • L or empty string: left align (default value)
  • -
  • C: center
  • -
  • R: right align
  • -
-
-
fill
-
-Indicates if the cell background must be painted (true) or transparent (false). -Default value: false. -
-
link
-
-URL or identifier returned by AddLink(). -
-
-

Example

-
-
// Set font
-$pdf->SetFont('Arial','B',16);
-// Move to 8 cm to the right
-$pdf->Cell(80);
-// Centered text in a framed 20*10 mm cell and line break
-$pdf->Cell(20,10,'Title',1,1,'C');
-
-

See also

-SetFont(), -SetDrawColor(), -SetFillColor(), -SetTextColor(), -SetLineWidth(), -AddLink(), -Ln(), -MultiCell(), -Write(), -SetAutoPageBreak(). -
- - - diff --git a/vendor/fpdf/doc/close.htm b/vendor/fpdf/doc/close.htm deleted file mode 100644 index d21f881c..00000000 --- a/vendor/fpdf/doc/close.htm +++ /dev/null @@ -1,21 +0,0 @@ - - - - -Close - - - -

Close

-Close() -

Description

-Terminates the PDF document. It is not necessary to call this method explicitly because Output() -does it automatically. -
-If the document contains no page, AddPage() is called to prevent from getting an invalid document. -

See also

-Output(). -
- - - diff --git a/vendor/fpdf/doc/error.htm b/vendor/fpdf/doc/error.htm deleted file mode 100644 index e0097c29..00000000 --- a/vendor/fpdf/doc/error.htm +++ /dev/null @@ -1,25 +0,0 @@ - - - - -Error - - - -

Error

-Error(string msg) -

Description

-This method is automatically called in case of fatal error; it simply outputs the message -and halts the execution. An inherited class may override it to customize the error handling -but should always halt the script, or the resulting document would probably be invalid. -

Parameters

-
-
msg
-
-The error message. -
-
-
- - - diff --git a/vendor/fpdf/doc/footer.htm b/vendor/fpdf/doc/footer.htm deleted file mode 100644 index 0bbc12fb..00000000 --- a/vendor/fpdf/doc/footer.htm +++ /dev/null @@ -1,35 +0,0 @@ - - - - -Footer - - - -

Footer

-Footer() -

Description

-This method is used to render the page footer. It is automatically called by AddPage() and -Close() and should not be called directly by the application. The implementation in FPDF is -empty, so you have to subclass it and override the method if you want a specific processing. -

Example

-
-
class PDF extends FPDF
-{
-function Footer()
-{
-    // Go to 1.5 cm from bottom
-    $this->SetY(-15);
-    // Select Arial italic 8
-    $this->SetFont('Arial','I',8);
-    // Print centered page number
-    $this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C');
-}
-}
-
-

See also

-Header(). -
- - - diff --git a/vendor/fpdf/doc/fpdf.htm b/vendor/fpdf/doc/fpdf.htm deleted file mode 100644 index cbffba0c..00000000 --- a/vendor/fpdf/doc/fpdf.htm +++ /dev/null @@ -1,63 +0,0 @@ - - - - -FPDF - - - -

FPDF

-FPDF([string orientation [, string unit [, mixed size]]]) -

Description

-This is the class constructor. It allows to set up the page size, the orientation and the -unit of measure used in all methods (except for font sizes). -

Parameters

-
-
orientation
-
-Default page orientation. Possible values are (case insensitive): -
    -
  • P or Portrait
  • -
  • L or Landscape
  • -
-Default value is P. -
-
unit
-
-User unit. Possible values are: -
    -
  • pt: point
  • -
  • mm: millimeter
  • -
  • cm: centimeter
  • -
  • in: inch
  • -
-A point equals 1/72 of inch, that is to say about 0.35 mm (an inch being 2.54 cm). This -is a very common unit in typography; font sizes are expressed in that unit. -
-
-Default value is mm. -
-
size
-
-The size used for pages. It can be either one of the following values (case insensitive): -
    -
  • A3
  • -
  • A4
  • -
  • A5
  • -
  • Letter
  • -
  • Legal
  • -
-or an array containing the width and the height (expressed in the unit given by unit).
-
-Default value is A4. -
-
-

Example

-Example with a custom 100x150 mm page size: -
-
$pdf = new FPDF('P','mm',array(100,150));
-
-
- - - diff --git a/vendor/fpdf/doc/getstringwidth.htm b/vendor/fpdf/doc/getstringwidth.htm deleted file mode 100644 index 38b48756..00000000 --- a/vendor/fpdf/doc/getstringwidth.htm +++ /dev/null @@ -1,23 +0,0 @@ - - - - -GetStringWidth - - - -

GetStringWidth

-float GetStringWidth(string s) -

Description

-Returns the length of a string in user unit. A font must be selected. -

Parameters

-
-
s
-
-The string whose length is to be computed. -
-
-
- - - diff --git a/vendor/fpdf/doc/getx.htm b/vendor/fpdf/doc/getx.htm deleted file mode 100644 index 401447ed..00000000 --- a/vendor/fpdf/doc/getx.htm +++ /dev/null @@ -1,20 +0,0 @@ - - - - -GetX - - - -

GetX

-float GetX() -

Description

-Returns the abscissa of the current position. -

See also

-SetX(), -GetY(), -SetY(). -
- - - diff --git a/vendor/fpdf/doc/gety.htm b/vendor/fpdf/doc/gety.htm deleted file mode 100644 index bee0526a..00000000 --- a/vendor/fpdf/doc/gety.htm +++ /dev/null @@ -1,20 +0,0 @@ - - - - -GetY - - - -

GetY

-float GetY() -

Description

-Returns the ordinate of the current position. -

See also

-SetY(), -GetX(), -SetX(). -
- - - diff --git a/vendor/fpdf/doc/header.htm b/vendor/fpdf/doc/header.htm deleted file mode 100644 index b9f048bb..00000000 --- a/vendor/fpdf/doc/header.htm +++ /dev/null @@ -1,37 +0,0 @@ - - - - -Header - - - -

Header

-Header() -

Description

-This method is used to render the page header. It is automatically called by AddPage() and -should not be called directly by the application. The implementation in FPDF is empty, so -you have to subclass it and override the method if you want a specific processing. -

Example

-
-
class PDF extends FPDF
-{
-function Header()
-{
-    // Select Arial bold 15
-    $this->SetFont('Arial','B',15);
-    // Move to the right
-    $this->Cell(80);
-    // Framed title
-    $this->Cell(30,10,'Title',1,0,'C');
-    // Line break
-    $this->Ln(20);
-}
-}
-
-

See also

-Footer(). -
- - - diff --git a/vendor/fpdf/doc/image.htm b/vendor/fpdf/doc/image.htm deleted file mode 100644 index c5509504..00000000 --- a/vendor/fpdf/doc/image.htm +++ /dev/null @@ -1,99 +0,0 @@ - - - - -Image - - - -

Image

-Image(string file [, float x [, float y [, float w [, float h [, string type [, mixed link]]]]]]) -

Description

-Puts an image. The size it will take on the page can be specified in different ways: -
    -
  • explicit width and height (expressed in user unit or dpi)
  • -
  • one explicit dimension, the other being calculated automatically in order to keep the original proportions
  • -
  • no explicit dimension, in which case the image is put at 96 dpi
  • -
-Supported formats are JPEG, PNG and GIF. The GD extension is required for GIF. -
-
-For JPEGs, all flavors are allowed: -
    -
  • gray scales
  • -
  • true colors (24 bits)
  • -
  • CMYK (32 bits)
  • -
-For PNGs, are allowed: -
    -
  • gray scales on at most 8 bits (256 levels)
  • -
  • indexed colors
  • -
  • true colors (24 bits)
  • -
-For GIFs: in case of an animated GIF, only the first frame is displayed.
-
-Transparency is supported.
-
-The format can be specified explicitly or inferred from the file extension.
-
-It is possible to put a link on the image.
-
-Remark: if an image is used several times, only one copy is embedded in the file. -

Parameters

-
-
file
-
-Path or URL of the image. -
-
x
-
-Abscissa of the upper-left corner. If not specified or equal to null, the current abscissa -is used. -
-
y
-
-Ordinate of the upper-left corner. If not specified or equal to null, the current ordinate -is used; moreover, a page break is triggered first if necessary (in case automatic page breaking is enabled) -and, after the call, the current ordinate is moved to the bottom of the image. -
-
w
-
-Width of the image in the page. There are three cases: -
    -
  • If the value is positive, it represents the width in user unit
  • -
  • If the value is negative, the absolute value represents the horizontal resolution in dpi
  • -
  • If the value is not specified or equal to zero, it is automatically calculated
  • -
-
-
h
-
-Height of the image in the page. There are three cases: -
    -
  • If the value is positive, it represents the height in user unit
  • -
  • If the value is negative, the absolute value represents the vertical resolution in dpi
  • -
  • If the value is not specified or equal to zero, it is automatically calculated
  • -
-
-
type
-
-Image format. Possible values are (case insensitive): JPG, JPEG, PNG and GIF. -If not specified, the type is inferred from the file extension. -
-
link
-
-URL or identifier returned by AddLink(). -
-
-

Example

-
-
// Insert a logo in the top-left corner at 300 dpi
-$pdf->Image('logo.png',10,10,-300);
-// Insert a dynamic image from a URL
-$pdf->Image('http://chart.googleapis.com/chart?cht=p3&chd=t:60,40&chs=250x100&chl=Hello|World',60,30,90,0,'PNG');
-
-

See also

-AddLink(). -
- - - diff --git a/vendor/fpdf/doc/index.htm b/vendor/fpdf/doc/index.htm deleted file mode 100644 index 143ee70b..00000000 --- a/vendor/fpdf/doc/index.htm +++ /dev/null @@ -1,57 +0,0 @@ - - - - -FPDF 1.7 Reference Manual - - - -

FPDF 1.7 Reference Manual

-AcceptPageBreak - accept or not automatic page break
-AddFont - add a new font
-AddLink - create an internal link
-AddPage - add a new page
-AliasNbPages - define an alias for number of pages
-Cell - print a cell
-Close - terminate the document
-Error - fatal error
-Footer - page footer
-FPDF - constructor
-GetStringWidth - compute string length
-GetX - get current x position
-GetY - get current y position
-Header - page header
-Image - output an image
-Line - draw a line
-Link - put a link
-Ln - line break
-MultiCell - print text with line breaks
-Output - save or send the document
-PageNo - page number
-Rect - draw a rectangle
-SetAuthor - set the document author
-SetAutoPageBreak - set the automatic page breaking mode
-SetCompression - turn compression on or off
-SetCreator - set document creator
-SetDisplayMode - set display mode
-SetDrawColor - set drawing color
-SetFillColor - set filling color
-SetFont - set font
-SetFontSize - set font size
-SetKeywords - associate keywords with document
-SetLeftMargin - set left margin
-SetLineWidth - set line width
-SetLink - set internal link destination
-SetMargins - set margins
-SetRightMargin - set right margin
-SetSubject - set document subject
-SetTextColor - set text color
-SetTitle - set document title
-SetTopMargin - set top margin
-SetX - set current x position
-SetXY - set current x and y positions
-SetY - set current y position
-Text - print a string
-Write - print flowing text
- - diff --git a/vendor/fpdf/doc/line.htm b/vendor/fpdf/doc/line.htm deleted file mode 100644 index ceb4e07e..00000000 --- a/vendor/fpdf/doc/line.htm +++ /dev/null @@ -1,38 +0,0 @@ - - - - -Line - - - -

Line

-Line(float x1, float y1, float x2, float y2) -

Description

-Draws a line between two points. -

Parameters

-
-
x1
-
-Abscissa of first point. -
-
y1
-
-Ordinate of first point. -
-
x2
-
-Abscissa of second point. -
-
y2
-
-Ordinate of second point. -
-
-

See also

-SetLineWidth(), -SetDrawColor(). -
- - - diff --git a/vendor/fpdf/doc/link.htm b/vendor/fpdf/doc/link.htm deleted file mode 100644 index 66f28d6a..00000000 --- a/vendor/fpdf/doc/link.htm +++ /dev/null @@ -1,46 +0,0 @@ - - - - -Link - - - -

Link

-Link(float x, float y, float w, float h, mixed link) -

Description

-Puts a link on a rectangular area of the page. Text or image links are generally put via Cell(), -Write() or Image(), but this method can be useful for instance to define a clickable area inside -an image. -

Parameters

-
-
x
-
-Abscissa of the upper-left corner of the rectangle. -
-
y
-
-Ordinate of the upper-left corner of the rectangle. -
-
w
-
-Width of the rectangle. -
-
h
-
-Height of the rectangle. -
-
link
-
-URL or identifier returned by AddLink(). -
-
-

See also

-AddLink(), -Cell(), -Write(), -Image(). -
- - - diff --git a/vendor/fpdf/doc/ln.htm b/vendor/fpdf/doc/ln.htm deleted file mode 100644 index 67782044..00000000 --- a/vendor/fpdf/doc/ln.htm +++ /dev/null @@ -1,28 +0,0 @@ - - - - -Ln - - - -

Ln

-Ln([float h]) -

Description

-Performs a line break. The current abscissa goes back to the left margin and the ordinate -increases by the amount passed in parameter. -

Parameters

-
-
h
-
-The height of the break. -
-By default, the value equals the height of the last printed cell. -
-
-

See also

-Cell(). -
- - - diff --git a/vendor/fpdf/doc/multicell.htm b/vendor/fpdf/doc/multicell.htm deleted file mode 100644 index 5c3543f9..00000000 --- a/vendor/fpdf/doc/multicell.htm +++ /dev/null @@ -1,76 +0,0 @@ - - - - -MultiCell - - - -

MultiCell

-MultiCell(float w, float h, string txt [, mixed border [, string align [, boolean fill]]]) -

Description

-This method allows printing text with line breaks. They can be automatic (as soon as the -text reaches the right border of the cell) or explicit (via the \n character). As many cells -as necessary are output, one below the other. -
-Text can be aligned, centered or justified. The cell block can be framed and the background -painted. -

Parameters

-
-
w
-
-Width of cells. If 0, they extend up to the right margin of the page. -
-
h
-
-Height of cells. -
-
txt
-
-String to print. -
-
border
-
-Indicates if borders must be drawn around the cell block. The value can be either a number: -
    -
  • 0: no border
  • -
  • 1: frame
  • -
-or a string containing some or all of the following characters (in any order): -
    -
  • L: left
  • -
  • T: top
  • -
  • R: right
  • -
  • B: bottom
  • -
-Default value: 0. -
-
align
-
-Sets the text alignment. Possible values are: -
    -
  • L: left alignment
  • -
  • C: center
  • -
  • R: right alignment
  • -
  • J: justification (default value)
  • -
-
-
fill
-
-Indicates if the cell background must be painted (true) or transparent (false). -Default value: false. -
-
-

See also

-SetFont(), -SetDrawColor(), -SetFillColor(), -SetTextColor(), -SetLineWidth(), -Cell(), -Write(), -SetAutoPageBreak(). -
- - - diff --git a/vendor/fpdf/doc/output.htm b/vendor/fpdf/doc/output.htm deleted file mode 100644 index f627b82b..00000000 --- a/vendor/fpdf/doc/output.htm +++ /dev/null @@ -1,42 +0,0 @@ - - - - -Output - - - -

Output

-string Output([string name, string dest]) -

Description

-Send the document to a given destination: browser, file or string. In the case of browser, the -plug-in may be used (if present) or a download ("Save as" dialog box) may be forced. -
-The method first calls Close() if necessary to terminate the document. -

Parameters

-
-
name
-
-The name of the file. If not specified, the document will be sent to the browser -(destination I) with the name doc.pdf. -
-
dest
-
-Destination where to send the document. It can take one of the following values: -
    -
  • I: send the file inline to the browser. The plug-in is used if available. -The name given by name is used when one selects the "Save as" option on the -link generating the PDF.
  • -
  • D: send to the browser and force a file download with the name given by -name.
  • -
  • F: save to a local file with the name given by name (may include a path).
  • -
  • S: return the document as a string. name is ignored.
  • -
-
-
-

See also

-Close(). -
- - - diff --git a/vendor/fpdf/doc/pageno.htm b/vendor/fpdf/doc/pageno.htm deleted file mode 100644 index c917d66f..00000000 --- a/vendor/fpdf/doc/pageno.htm +++ /dev/null @@ -1,18 +0,0 @@ - - - - -PageNo - - - -

PageNo

-int PageNo() -

Description

-Returns the current page number. -

See also

-AliasNbPages(). -
- - - diff --git a/vendor/fpdf/doc/rect.htm b/vendor/fpdf/doc/rect.htm deleted file mode 100644 index ab3d017f..00000000 --- a/vendor/fpdf/doc/rect.htm +++ /dev/null @@ -1,48 +0,0 @@ - - - - -Rect - - - -

Rect

-Rect(float x, float y, float w, float h [, string style]) -

Description

-Outputs a rectangle. It can be drawn (border only), filled (with no border) or both. -

Parameters

-
-
x
-
-Abscissa of upper-left corner. -
-
y
-
-Ordinate of upper-left corner. -
-
w
-
-Width. -
-
h
-
-Height. -
-
style
-
-Style of rendering. Possible values are: -
    -
  • D or empty string: draw. This is the default value.
  • -
  • F: fill
  • -
  • DF or FD: draw and fill
  • -
-
-
-

See also

-SetLineWidth(), -SetDrawColor(), -SetFillColor(). -
- - - diff --git a/vendor/fpdf/doc/setauthor.htm b/vendor/fpdf/doc/setauthor.htm deleted file mode 100644 index 6cb37544..00000000 --- a/vendor/fpdf/doc/setauthor.htm +++ /dev/null @@ -1,33 +0,0 @@ - - - - -SetAuthor - - - -

SetAuthor

-SetAuthor(string author [, boolean isUTF8]) -

Description

-Defines the author of the document. -

Parameters

-
-
author
-
-The name of the author. -
-
isUTF8
-
-Indicates if the string is encoded in ISO-8859-1 (false) or UTF-8 (true).
-Default value: false. -
-
-

See also

-SetCreator(), -SetKeywords(), -SetSubject(), -SetTitle(). -
- - - diff --git a/vendor/fpdf/doc/setautopagebreak.htm b/vendor/fpdf/doc/setautopagebreak.htm deleted file mode 100644 index 80291a20..00000000 --- a/vendor/fpdf/doc/setautopagebreak.htm +++ /dev/null @@ -1,33 +0,0 @@ - - - - -SetAutoPageBreak - - - -

SetAutoPageBreak

-SetAutoPageBreak(boolean auto [, float margin]) -

Description

-Enables or disables the automatic page breaking mode. When enabling, the second parameter is -the distance from the bottom of the page that defines the triggering limit. By default, the -mode is on and the margin is 2 cm. -

Parameters

-
-
auto
-
-Boolean indicating if mode should be on or off. -
-
margin
-
-Distance from the bottom of the page. -
-
-

See also

-Cell(), -MultiCell(), -AcceptPageBreak(). -
- - - diff --git a/vendor/fpdf/doc/setcompression.htm b/vendor/fpdf/doc/setcompression.htm deleted file mode 100644 index ec506d93..00000000 --- a/vendor/fpdf/doc/setcompression.htm +++ /dev/null @@ -1,31 +0,0 @@ - - - - -SetCompression - - - -

SetCompression

-SetCompression(boolean compress) -

Description

-Activates or deactivates page compression. When activated, the internal representation of -each page is compressed, which leads to a compression ratio of about 2 for the resulting -document. -
-Compression is on by default. -
-
-Note: the Zlib extension is required for this feature. If not present, compression -will be turned off. -

Parameters

-
-
compress
-
-Boolean indicating if compression must be enabled. -
-
-
- - - diff --git a/vendor/fpdf/doc/setcreator.htm b/vendor/fpdf/doc/setcreator.htm deleted file mode 100644 index 19f820c6..00000000 --- a/vendor/fpdf/doc/setcreator.htm +++ /dev/null @@ -1,34 +0,0 @@ - - - - -SetCreator - - - -

SetCreator

-SetCreator(string creator [, boolean isUTF8]) -

Description

-Defines the creator of the document. This is typically the name of the application that -generates the PDF. -

Parameters

-
-
creator
-
-The name of the creator. -
-
isUTF8
-
-Indicates if the string is encoded in ISO-8859-1 (false) or UTF-8 (true).
-Default value: false. -
-
-

See also

-SetAuthor(), -SetKeywords(), -SetSubject(), -SetTitle(). -
- - - diff --git a/vendor/fpdf/doc/setdisplaymode.htm b/vendor/fpdf/doc/setdisplaymode.htm deleted file mode 100644 index e9deb56c..00000000 --- a/vendor/fpdf/doc/setdisplaymode.htm +++ /dev/null @@ -1,45 +0,0 @@ - - - - -SetDisplayMode - - - -

SetDisplayMode

-SetDisplayMode(mixed zoom [, string layout]) -

Description

-Defines the way the document is to be displayed by the viewer. The zoom level can be set: pages can be -displayed entirely on screen, occupy the full width of the window, use real size, be scaled by a -specific zooming factor or use viewer default (configured in the Preferences menu of Adobe Reader). -The page layout can be specified too: single at once, continuous display, two columns or viewer -default. -

Parameters

-
-
zoom
-
-The zoom to use. It can be one of the following string values: -
    -
  • fullpage: displays the entire page on screen
  • -
  • fullwidth: uses maximum width of window
  • -
  • real: uses real size (equivalent to 100% zoom)
  • -
  • default: uses viewer default mode
  • -
-or a number indicating the zooming factor to use. -
-
layout
-
-The page layout. Possible values are: -
    -
  • single: displays one page at once
  • -
  • continuous: displays pages continuously
  • -
  • two: displays two pages on two columns
  • -
  • default: uses viewer default mode
  • -
-Default value is default. -
-
-
- - - diff --git a/vendor/fpdf/doc/setdrawcolor.htm b/vendor/fpdf/doc/setdrawcolor.htm deleted file mode 100644 index 1a6c736f..00000000 --- a/vendor/fpdf/doc/setdrawcolor.htm +++ /dev/null @@ -1,41 +0,0 @@ - - - - -SetDrawColor - - - -

SetDrawColor

-SetDrawColor(int r [, int g, int b]) -

Description

-Defines the color used for all drawing operations (lines, rectangles and cell borders). It -can be expressed in RGB components or gray scale. The method can be called before the first -page is created and the value is retained from page to page. -

Parameters

-
-
r
-
-If g et b are given, red component; if not, indicates the gray level. -Value between 0 and 255. -
-
g
-
-Green component (between 0 and 255). -
-
b
-
-Blue component (between 0 and 255). -
-
-

See also

-SetFillColor(), -SetTextColor(), -Line(), -Rect(), -Cell(), -MultiCell(). -
- - - diff --git a/vendor/fpdf/doc/setfillcolor.htm b/vendor/fpdf/doc/setfillcolor.htm deleted file mode 100644 index 76f86609..00000000 --- a/vendor/fpdf/doc/setfillcolor.htm +++ /dev/null @@ -1,40 +0,0 @@ - - - - -SetFillColor - - - -

SetFillColor

-SetFillColor(int r [, int g, int b]) -

Description

-Defines the color used for all filling operations (filled rectangles and cell backgrounds). -It can be expressed in RGB components or gray scale. The method can be called before the first -page is created and the value is retained from page to page. -

Parameters

-
-
r
-
-If g and b are given, red component; if not, indicates the gray level. -Value between 0 and 255. -
-
g
-
-Green component (between 0 and 255). -
-
b
-
-Blue component (between 0 and 255). -
-
-

See also

-SetDrawColor(), -SetTextColor(), -Rect(), -Cell(), -MultiCell(). -
- - - diff --git a/vendor/fpdf/doc/setfont.htm b/vendor/fpdf/doc/setfont.htm deleted file mode 100644 index 6a97979f..00000000 --- a/vendor/fpdf/doc/setfont.htm +++ /dev/null @@ -1,92 +0,0 @@ - - - - -SetFont - - - -

SetFont

-SetFont(string family [, string style [, float size]]) -

Description

-Sets the font used to print character strings. It is mandatory to call this method -at least once before printing text or the resulting document would not be valid. -
-The font can be either a standard one or a font added via the AddFont() method. Standard fonts -use the Windows encoding cp1252 (Western Europe). -
-The method can be called before the first page is created and the font is kept from page -to page. -
-If you just wish to change the current font size, it is simpler to call SetFontSize(). -
-
-Note: the font definition files must be accessible. They are searched successively in: -
    -
  • The directory defined by the FPDF_FONTPATH constant (if this constant is defined)
  • -
  • The font directory located in the same directory as fpdf.php (if it exists)
  • -
  • The directories accessible through include()
  • -
-Example using FPDF_FONTPATH: -
-
define('FPDF_FONTPATH','/home/www/font');
-require('fpdf.php');
-
-If the file corresponding to the requested font is not found, the error "Could not include font -definition file" is raised. -

Parameters

-
-
family
-
-Family font. It can be either a name defined by AddFont() or one of the standard families (case -insensitive): -
    -
  • Courier (fixed-width)
  • -
  • Helvetica or Arial (synonymous; sans serif)
  • -
  • Times (serif)
  • -
  • Symbol (symbolic)
  • -
  • ZapfDingbats (symbolic)
  • -
-It is also possible to pass an empty string. In that case, the current family is kept. -
-
style
-
-Font style. Possible values are (case insensitive): -
    -
  • empty string: regular
  • -
  • B: bold
  • -
  • I: italic
  • -
  • U: underline
  • -
-or any combination. The default value is regular. -Bold and italic styles do not apply to Symbol and ZapfDingbats. -
-
size
-
-Font size in points. -
-The default value is the current size. If no size has been specified since the beginning of -the document, the value taken is 12. -
-
-

Example

-
-
// Times regular 12
-$pdf->SetFont('Times');
-// Arial bold 14
-$pdf->SetFont('Arial','B',14);
-// Removes bold
-$pdf->SetFont('');
-// Times bold, italic and underlined 14
-$pdf->SetFont('Times','BIU');
-
-

See also

-AddFont(), -SetFontSize(), -Cell(), -MultiCell(), -Write(). -
- - - diff --git a/vendor/fpdf/doc/setfontsize.htm b/vendor/fpdf/doc/setfontsize.htm deleted file mode 100644 index 54fd8999..00000000 --- a/vendor/fpdf/doc/setfontsize.htm +++ /dev/null @@ -1,25 +0,0 @@ - - - - -SetFontSize - - - -

SetFontSize

-SetFontSize(float size) -

Description

-Defines the size of the current font. -

Parameters

-
-
size
-
-The size (in points). -
-
-

See also

-SetFont(). -
- - - diff --git a/vendor/fpdf/doc/setkeywords.htm b/vendor/fpdf/doc/setkeywords.htm deleted file mode 100644 index 02eb466a..00000000 --- a/vendor/fpdf/doc/setkeywords.htm +++ /dev/null @@ -1,33 +0,0 @@ - - - - -SetKeywords - - - -

SetKeywords

-SetKeywords(string keywords [, boolean isUTF8]) -

Description

-Associates keywords with the document, generally in the form 'keyword1 keyword2 ...'. -

Parameters

-
-
keywords
-
-The list of keywords. -
-
isUTF8
-
-Indicates if the string is encoded in ISO-8859-1 (false) or UTF-8 (true).
-Default value: false. -
-
-

See also

-SetAuthor(), -SetCreator(), -SetSubject(), -SetTitle(). -
- - - diff --git a/vendor/fpdf/doc/setleftmargin.htm b/vendor/fpdf/doc/setleftmargin.htm deleted file mode 100644 index 500c17ac..00000000 --- a/vendor/fpdf/doc/setleftmargin.htm +++ /dev/null @@ -1,30 +0,0 @@ - - - - -SetLeftMargin - - - -

SetLeftMargin

-SetLeftMargin(float margin) -

Description

-Defines the left margin. The method can be called before creating the first page. -
-If the current abscissa gets out of page, it is brought back to the margin. -

Parameters

-
-
margin
-
-The margin. -
-
-

See also

-SetTopMargin(), -SetRightMargin(), -SetAutoPageBreak(), -SetMargins(). -
- - - diff --git a/vendor/fpdf/doc/setlinewidth.htm b/vendor/fpdf/doc/setlinewidth.htm deleted file mode 100644 index fa15b7dd..00000000 --- a/vendor/fpdf/doc/setlinewidth.htm +++ /dev/null @@ -1,29 +0,0 @@ - - - - -SetLineWidth - - - -

SetLineWidth

-SetLineWidth(float width) -

Description

-Defines the line width. By default, the value equals 0.2 mm. The method can be called before -the first page is created and the value is retained from page to page. -

Parameters

-
-
width
-
-The width. -
-
-

See also

-Line(), -Rect(), -Cell(), -MultiCell(). -
- - - diff --git a/vendor/fpdf/doc/setlink.htm b/vendor/fpdf/doc/setlink.htm deleted file mode 100644 index 654c25ec..00000000 --- a/vendor/fpdf/doc/setlink.htm +++ /dev/null @@ -1,34 +0,0 @@ - - - - -SetLink - - - -

SetLink

-SetLink(int link [, float y [, int page]]) -

Description

-Defines the page and position a link points to. -

Parameters

-
-
link
-
-The link identifier returned by AddLink(). -
-
y
-
-Ordinate of target position; -1 indicates the current position. -The default value is 0 (top of page). -
-
page
-
-Number of target page; -1 indicates the current page. This is the default value. -
-
-

See also

-AddLink(). -
- - - diff --git a/vendor/fpdf/doc/setmargins.htm b/vendor/fpdf/doc/setmargins.htm deleted file mode 100644 index eaa17011..00000000 --- a/vendor/fpdf/doc/setmargins.htm +++ /dev/null @@ -1,37 +0,0 @@ - - - - -SetMargins - - - -

SetMargins

-SetMargins(float left, float top [, float right]) -

Description

-Defines the left, top and right margins. By default, they equal 1 cm. Call this method to change -them. -

Parameters

-
-
left
-
-Left margin. -
-
top
-
-Top margin. -
-
right
-
-Right margin. Default value is the left one. -
-
-

See also

-SetLeftMargin(), -SetTopMargin(), -SetRightMargin(), -SetAutoPageBreak(). -
- - - diff --git a/vendor/fpdf/doc/setrightmargin.htm b/vendor/fpdf/doc/setrightmargin.htm deleted file mode 100644 index ef0d942c..00000000 --- a/vendor/fpdf/doc/setrightmargin.htm +++ /dev/null @@ -1,28 +0,0 @@ - - - - -SetRightMargin - - - -

SetRightMargin

-SetRightMargin(float margin) -

Description

-Defines the right margin. The method can be called before creating the first page. -

Parameters

-
-
margin
-
-The margin. -
-
-

See also

-SetLeftMargin(), -SetTopMargin(), -SetAutoPageBreak(), -SetMargins(). -
- - - diff --git a/vendor/fpdf/doc/setsubject.htm b/vendor/fpdf/doc/setsubject.htm deleted file mode 100644 index 64a27d82..00000000 --- a/vendor/fpdf/doc/setsubject.htm +++ /dev/null @@ -1,33 +0,0 @@ - - - - -SetSubject - - - -

SetSubject

-SetSubject(string subject [, boolean isUTF8]) -

Description

-Defines the subject of the document. -

Parameters

-
-
subject
-
-The subject. -
-
isUTF8
-
-Indicates if the string is encoded in ISO-8859-1 (false) or UTF-8 (true).
-Default value: false. -
-
-

See also

-SetAuthor(), -SetCreator(), -SetKeywords(), -SetTitle(). -
- - - diff --git a/vendor/fpdf/doc/settextcolor.htm b/vendor/fpdf/doc/settextcolor.htm deleted file mode 100644 index 1772712c..00000000 --- a/vendor/fpdf/doc/settextcolor.htm +++ /dev/null @@ -1,40 +0,0 @@ - - - - -SetTextColor - - - -

SetTextColor

-SetTextColor(int r [, int g, int b]) -

Description

-Defines the color used for text. It can be expressed in RGB components or gray scale. The -method can be called before the first page is created and the value is retained from page to -page. -

Parameters

-
-
r
-
-If g et b are given, red component; if not, indicates the gray level. -Value between 0 and 255. -
-
g
-
-Green component (between 0 and 255). -
-
b
-
-Blue component (between 0 and 255). -
-
-

See also

-SetDrawColor(), -SetFillColor(), -Text(), -Cell(), -MultiCell(). -
- - - diff --git a/vendor/fpdf/doc/settitle.htm b/vendor/fpdf/doc/settitle.htm deleted file mode 100644 index 741f4c6a..00000000 --- a/vendor/fpdf/doc/settitle.htm +++ /dev/null @@ -1,33 +0,0 @@ - - - - -SetTitle - - - -

SetTitle

-SetTitle(string title [, boolean isUTF8]) -

Description

-Defines the title of the document. -

Parameters

-
-
title
-
-The title. -
-
isUTF8
-
-Indicates if the string is encoded in ISO-8859-1 (false) or UTF-8 (true).
-Default value: false. -
-
-

See also

-SetAuthor(), -SetCreator(), -SetKeywords(), -SetSubject(). -
- - - diff --git a/vendor/fpdf/doc/settopmargin.htm b/vendor/fpdf/doc/settopmargin.htm deleted file mode 100644 index 99339fc7..00000000 --- a/vendor/fpdf/doc/settopmargin.htm +++ /dev/null @@ -1,28 +0,0 @@ - - - - -SetTopMargin - - - -

SetTopMargin

-SetTopMargin(float margin) -

Description

-Defines the top margin. The method can be called before creating the first page. -

Parameters

-
-
margin
-
-The margin. -
-
-

See also

-SetLeftMargin(), -SetRightMargin(), -SetAutoPageBreak(), -SetMargins(). -
- - - diff --git a/vendor/fpdf/doc/setx.htm b/vendor/fpdf/doc/setx.htm deleted file mode 100644 index 9336d767..00000000 --- a/vendor/fpdf/doc/setx.htm +++ /dev/null @@ -1,29 +0,0 @@ - - - - -SetX - - - -

SetX

-SetX(float x) -

Description

-Defines the abscissa of the current position. If the passed value is negative, it is relative -to the right of the page. -

Parameters

-
-
x
-
-The value of the abscissa. -
-
-

See also

-GetX(), -GetY(), -SetY(), -SetXY(). -
- - - diff --git a/vendor/fpdf/doc/setxy.htm b/vendor/fpdf/doc/setxy.htm deleted file mode 100644 index 7e62fe36..00000000 --- a/vendor/fpdf/doc/setxy.htm +++ /dev/null @@ -1,31 +0,0 @@ - - - - -SetXY - - - -

SetXY

-SetXY(float x, float y) -

Description

-Defines the abscissa and ordinate of the current position. If the passed values are negative, -they are relative respectively to the right and bottom of the page. -

Parameters

-
-
x
-
-The value of the abscissa. -
-
y
-
-The value of the ordinate. -
-
-

See also

-SetX(), -SetY(). -
- - - diff --git a/vendor/fpdf/doc/sety.htm b/vendor/fpdf/doc/sety.htm deleted file mode 100644 index 37435f69..00000000 --- a/vendor/fpdf/doc/sety.htm +++ /dev/null @@ -1,29 +0,0 @@ - - - - -SetY - - - -

SetY

-SetY(float y) -

Description

-Moves the current abscissa back to the left margin and sets the ordinate. If the passed value -is negative, it is relative to the bottom of the page. -

Parameters

-
-
y
-
-The value of the ordinate. -
-
-

See also

-GetX(), -GetY(), -SetX(), -SetXY(). -
- - - diff --git a/vendor/fpdf/doc/text.htm b/vendor/fpdf/doc/text.htm deleted file mode 100644 index c79fa2da..00000000 --- a/vendor/fpdf/doc/text.htm +++ /dev/null @@ -1,39 +0,0 @@ - - - - -Text - - - -

Text

-Text(float x, float y, string txt) -

Description

-Prints a character string. The origin is on the left of the first character, on the baseline. -This method allows to place a string precisely on the page, but it is usually easier to use -Cell(), MultiCell() or Write() which are the standard methods to print text. -

Parameters

-
-
x
-
-Abscissa of the origin. -
-
y
-
-Ordinate of the origin. -
-
txt
-
-String to print. -
-
-

See also

-SetFont(), -SetTextColor(), -Cell(), -MultiCell(), -Write(). -
- - - diff --git a/vendor/fpdf/doc/write.htm b/vendor/fpdf/doc/write.htm deleted file mode 100644 index c1c2e043..00000000 --- a/vendor/fpdf/doc/write.htm +++ /dev/null @@ -1,51 +0,0 @@ - - - - -Write - - - -

Write

-Write(float h, string txt [, mixed link]) -

Description

-This method prints text from the current position. When the right margin is reached (or the \n -character is met) a line break occurs and text continues from the left margin. Upon method exit, -the current position is left just at the end of the text. -
-It is possible to put a link on the text. -

Parameters

-
-
h
-
-Line height. -
-
txt
-
-String to print. -
-
link
-
-URL or identifier returned by AddLink(). -
-
-

Example

-
-
// Begin with regular font
-$pdf->SetFont('Arial','',14);
-$pdf->Write(5,'Visit ');
-// Then put a blue underlined link
-$pdf->SetTextColor(0,0,255);
-$pdf->SetFont('','U');
-$pdf->Write(5,'www.fpdf.org','http://www.fpdf.org');
-
-

See also

-SetFont(), -SetTextColor(), -AddLink(), -MultiCell(), -SetAutoPageBreak(). -
- - - diff --git a/vendor/fpdf/font/courier.php b/vendor/fpdf/font/courier.php deleted file mode 100644 index 02525f58..00000000 --- a/vendor/fpdf/font/courier.php +++ /dev/null @@ -1,8 +0,0 @@ - diff --git a/vendor/fpdf/font/courierb.php b/vendor/fpdf/font/courierb.php deleted file mode 100644 index f472063c..00000000 --- a/vendor/fpdf/font/courierb.php +++ /dev/null @@ -1,8 +0,0 @@ - diff --git a/vendor/fpdf/font/courierbi.php b/vendor/fpdf/font/courierbi.php deleted file mode 100644 index 6ce8501a..00000000 --- a/vendor/fpdf/font/courierbi.php +++ /dev/null @@ -1,8 +0,0 @@ - diff --git a/vendor/fpdf/font/courieri.php b/vendor/fpdf/font/courieri.php deleted file mode 100644 index 320150a0..00000000 --- a/vendor/fpdf/font/courieri.php +++ /dev/null @@ -1,8 +0,0 @@ - diff --git a/vendor/fpdf/font/helvetica.php b/vendor/fpdf/font/helvetica.php deleted file mode 100644 index 891ea251..00000000 --- a/vendor/fpdf/font/helvetica.php +++ /dev/null @@ -1,19 +0,0 @@ -278,chr(1)=>278,chr(2)=>278,chr(3)=>278,chr(4)=>278,chr(5)=>278,chr(6)=>278,chr(7)=>278,chr(8)=>278,chr(9)=>278,chr(10)=>278,chr(11)=>278,chr(12)=>278,chr(13)=>278,chr(14)=>278,chr(15)=>278,chr(16)=>278,chr(17)=>278,chr(18)=>278,chr(19)=>278,chr(20)=>278,chr(21)=>278, - chr(22)=>278,chr(23)=>278,chr(24)=>278,chr(25)=>278,chr(26)=>278,chr(27)=>278,chr(28)=>278,chr(29)=>278,chr(30)=>278,chr(31)=>278,' '=>278,'!'=>278,'"'=>355,'#'=>556,'$'=>556,'%'=>889,'&'=>667,'\''=>191,'('=>333,')'=>333,'*'=>389,'+'=>584, - ','=>278,'-'=>333,'.'=>278,'/'=>278,'0'=>556,'1'=>556,'2'=>556,'3'=>556,'4'=>556,'5'=>556,'6'=>556,'7'=>556,'8'=>556,'9'=>556,':'=>278,';'=>278,'<'=>584,'='=>584,'>'=>584,'?'=>556,'@'=>1015,'A'=>667, - 'B'=>667,'C'=>722,'D'=>722,'E'=>667,'F'=>611,'G'=>778,'H'=>722,'I'=>278,'J'=>500,'K'=>667,'L'=>556,'M'=>833,'N'=>722,'O'=>778,'P'=>667,'Q'=>778,'R'=>722,'S'=>667,'T'=>611,'U'=>722,'V'=>667,'W'=>944, - 'X'=>667,'Y'=>667,'Z'=>611,'['=>278,'\\'=>278,']'=>278,'^'=>469,'_'=>556,'`'=>333,'a'=>556,'b'=>556,'c'=>500,'d'=>556,'e'=>556,'f'=>278,'g'=>556,'h'=>556,'i'=>222,'j'=>222,'k'=>500,'l'=>222,'m'=>833, - 'n'=>556,'o'=>556,'p'=>556,'q'=>556,'r'=>333,'s'=>500,'t'=>278,'u'=>556,'v'=>500,'w'=>722,'x'=>500,'y'=>500,'z'=>500,'{'=>334,'|'=>260,'}'=>334,'~'=>584,chr(127)=>350,chr(128)=>556,chr(129)=>350,chr(130)=>222,chr(131)=>556, - chr(132)=>333,chr(133)=>1000,chr(134)=>556,chr(135)=>556,chr(136)=>333,chr(137)=>1000,chr(138)=>667,chr(139)=>333,chr(140)=>1000,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>222,chr(146)=>222,chr(147)=>333,chr(148)=>333,chr(149)=>350,chr(150)=>556,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>500,chr(155)=>333,chr(156)=>944,chr(157)=>350,chr(158)=>500,chr(159)=>667,chr(160)=>278,chr(161)=>333,chr(162)=>556,chr(163)=>556,chr(164)=>556,chr(165)=>556,chr(166)=>260,chr(167)=>556,chr(168)=>333,chr(169)=>737,chr(170)=>370,chr(171)=>556,chr(172)=>584,chr(173)=>333,chr(174)=>737,chr(175)=>333, - chr(176)=>400,chr(177)=>584,chr(178)=>333,chr(179)=>333,chr(180)=>333,chr(181)=>556,chr(182)=>537,chr(183)=>278,chr(184)=>333,chr(185)=>333,chr(186)=>365,chr(187)=>556,chr(188)=>834,chr(189)=>834,chr(190)=>834,chr(191)=>611,chr(192)=>667,chr(193)=>667,chr(194)=>667,chr(195)=>667,chr(196)=>667,chr(197)=>667, - chr(198)=>1000,chr(199)=>722,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>278,chr(205)=>278,chr(206)=>278,chr(207)=>278,chr(208)=>722,chr(209)=>722,chr(210)=>778,chr(211)=>778,chr(212)=>778,chr(213)=>778,chr(214)=>778,chr(215)=>584,chr(216)=>778,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>667,chr(222)=>667,chr(223)=>611,chr(224)=>556,chr(225)=>556,chr(226)=>556,chr(227)=>556,chr(228)=>556,chr(229)=>556,chr(230)=>889,chr(231)=>500,chr(232)=>556,chr(233)=>556,chr(234)=>556,chr(235)=>556,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>556,chr(241)=>556, - chr(242)=>556,chr(243)=>556,chr(244)=>556,chr(245)=>556,chr(246)=>556,chr(247)=>584,chr(248)=>611,chr(249)=>556,chr(250)=>556,chr(251)=>556,chr(252)=>556,chr(253)=>500,chr(254)=>556,chr(255)=>500); -?> diff --git a/vendor/fpdf/font/helveticab.php b/vendor/fpdf/font/helveticab.php deleted file mode 100644 index 6c9b972b..00000000 --- a/vendor/fpdf/font/helveticab.php +++ /dev/null @@ -1,19 +0,0 @@ -278,chr(1)=>278,chr(2)=>278,chr(3)=>278,chr(4)=>278,chr(5)=>278,chr(6)=>278,chr(7)=>278,chr(8)=>278,chr(9)=>278,chr(10)=>278,chr(11)=>278,chr(12)=>278,chr(13)=>278,chr(14)=>278,chr(15)=>278,chr(16)=>278,chr(17)=>278,chr(18)=>278,chr(19)=>278,chr(20)=>278,chr(21)=>278, - chr(22)=>278,chr(23)=>278,chr(24)=>278,chr(25)=>278,chr(26)=>278,chr(27)=>278,chr(28)=>278,chr(29)=>278,chr(30)=>278,chr(31)=>278,' '=>278,'!'=>333,'"'=>474,'#'=>556,'$'=>556,'%'=>889,'&'=>722,'\''=>238,'('=>333,')'=>333,'*'=>389,'+'=>584, - ','=>278,'-'=>333,'.'=>278,'/'=>278,'0'=>556,'1'=>556,'2'=>556,'3'=>556,'4'=>556,'5'=>556,'6'=>556,'7'=>556,'8'=>556,'9'=>556,':'=>333,';'=>333,'<'=>584,'='=>584,'>'=>584,'?'=>611,'@'=>975,'A'=>722, - 'B'=>722,'C'=>722,'D'=>722,'E'=>667,'F'=>611,'G'=>778,'H'=>722,'I'=>278,'J'=>556,'K'=>722,'L'=>611,'M'=>833,'N'=>722,'O'=>778,'P'=>667,'Q'=>778,'R'=>722,'S'=>667,'T'=>611,'U'=>722,'V'=>667,'W'=>944, - 'X'=>667,'Y'=>667,'Z'=>611,'['=>333,'\\'=>278,']'=>333,'^'=>584,'_'=>556,'`'=>333,'a'=>556,'b'=>611,'c'=>556,'d'=>611,'e'=>556,'f'=>333,'g'=>611,'h'=>611,'i'=>278,'j'=>278,'k'=>556,'l'=>278,'m'=>889, - 'n'=>611,'o'=>611,'p'=>611,'q'=>611,'r'=>389,'s'=>556,'t'=>333,'u'=>611,'v'=>556,'w'=>778,'x'=>556,'y'=>556,'z'=>500,'{'=>389,'|'=>280,'}'=>389,'~'=>584,chr(127)=>350,chr(128)=>556,chr(129)=>350,chr(130)=>278,chr(131)=>556, - chr(132)=>500,chr(133)=>1000,chr(134)=>556,chr(135)=>556,chr(136)=>333,chr(137)=>1000,chr(138)=>667,chr(139)=>333,chr(140)=>1000,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>278,chr(146)=>278,chr(147)=>500,chr(148)=>500,chr(149)=>350,chr(150)=>556,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>556,chr(155)=>333,chr(156)=>944,chr(157)=>350,chr(158)=>500,chr(159)=>667,chr(160)=>278,chr(161)=>333,chr(162)=>556,chr(163)=>556,chr(164)=>556,chr(165)=>556,chr(166)=>280,chr(167)=>556,chr(168)=>333,chr(169)=>737,chr(170)=>370,chr(171)=>556,chr(172)=>584,chr(173)=>333,chr(174)=>737,chr(175)=>333, - chr(176)=>400,chr(177)=>584,chr(178)=>333,chr(179)=>333,chr(180)=>333,chr(181)=>611,chr(182)=>556,chr(183)=>278,chr(184)=>333,chr(185)=>333,chr(186)=>365,chr(187)=>556,chr(188)=>834,chr(189)=>834,chr(190)=>834,chr(191)=>611,chr(192)=>722,chr(193)=>722,chr(194)=>722,chr(195)=>722,chr(196)=>722,chr(197)=>722, - chr(198)=>1000,chr(199)=>722,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>278,chr(205)=>278,chr(206)=>278,chr(207)=>278,chr(208)=>722,chr(209)=>722,chr(210)=>778,chr(211)=>778,chr(212)=>778,chr(213)=>778,chr(214)=>778,chr(215)=>584,chr(216)=>778,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>667,chr(222)=>667,chr(223)=>611,chr(224)=>556,chr(225)=>556,chr(226)=>556,chr(227)=>556,chr(228)=>556,chr(229)=>556,chr(230)=>889,chr(231)=>556,chr(232)=>556,chr(233)=>556,chr(234)=>556,chr(235)=>556,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>611,chr(241)=>611, - chr(242)=>611,chr(243)=>611,chr(244)=>611,chr(245)=>611,chr(246)=>611,chr(247)=>584,chr(248)=>611,chr(249)=>611,chr(250)=>611,chr(251)=>611,chr(252)=>611,chr(253)=>556,chr(254)=>611,chr(255)=>556); -?> diff --git a/vendor/fpdf/font/helveticabi.php b/vendor/fpdf/font/helveticabi.php deleted file mode 100644 index 47203119..00000000 --- a/vendor/fpdf/font/helveticabi.php +++ /dev/null @@ -1,19 +0,0 @@ -278,chr(1)=>278,chr(2)=>278,chr(3)=>278,chr(4)=>278,chr(5)=>278,chr(6)=>278,chr(7)=>278,chr(8)=>278,chr(9)=>278,chr(10)=>278,chr(11)=>278,chr(12)=>278,chr(13)=>278,chr(14)=>278,chr(15)=>278,chr(16)=>278,chr(17)=>278,chr(18)=>278,chr(19)=>278,chr(20)=>278,chr(21)=>278, - chr(22)=>278,chr(23)=>278,chr(24)=>278,chr(25)=>278,chr(26)=>278,chr(27)=>278,chr(28)=>278,chr(29)=>278,chr(30)=>278,chr(31)=>278,' '=>278,'!'=>333,'"'=>474,'#'=>556,'$'=>556,'%'=>889,'&'=>722,'\''=>238,'('=>333,')'=>333,'*'=>389,'+'=>584, - ','=>278,'-'=>333,'.'=>278,'/'=>278,'0'=>556,'1'=>556,'2'=>556,'3'=>556,'4'=>556,'5'=>556,'6'=>556,'7'=>556,'8'=>556,'9'=>556,':'=>333,';'=>333,'<'=>584,'='=>584,'>'=>584,'?'=>611,'@'=>975,'A'=>722, - 'B'=>722,'C'=>722,'D'=>722,'E'=>667,'F'=>611,'G'=>778,'H'=>722,'I'=>278,'J'=>556,'K'=>722,'L'=>611,'M'=>833,'N'=>722,'O'=>778,'P'=>667,'Q'=>778,'R'=>722,'S'=>667,'T'=>611,'U'=>722,'V'=>667,'W'=>944, - 'X'=>667,'Y'=>667,'Z'=>611,'['=>333,'\\'=>278,']'=>333,'^'=>584,'_'=>556,'`'=>333,'a'=>556,'b'=>611,'c'=>556,'d'=>611,'e'=>556,'f'=>333,'g'=>611,'h'=>611,'i'=>278,'j'=>278,'k'=>556,'l'=>278,'m'=>889, - 'n'=>611,'o'=>611,'p'=>611,'q'=>611,'r'=>389,'s'=>556,'t'=>333,'u'=>611,'v'=>556,'w'=>778,'x'=>556,'y'=>556,'z'=>500,'{'=>389,'|'=>280,'}'=>389,'~'=>584,chr(127)=>350,chr(128)=>556,chr(129)=>350,chr(130)=>278,chr(131)=>556, - chr(132)=>500,chr(133)=>1000,chr(134)=>556,chr(135)=>556,chr(136)=>333,chr(137)=>1000,chr(138)=>667,chr(139)=>333,chr(140)=>1000,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>278,chr(146)=>278,chr(147)=>500,chr(148)=>500,chr(149)=>350,chr(150)=>556,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>556,chr(155)=>333,chr(156)=>944,chr(157)=>350,chr(158)=>500,chr(159)=>667,chr(160)=>278,chr(161)=>333,chr(162)=>556,chr(163)=>556,chr(164)=>556,chr(165)=>556,chr(166)=>280,chr(167)=>556,chr(168)=>333,chr(169)=>737,chr(170)=>370,chr(171)=>556,chr(172)=>584,chr(173)=>333,chr(174)=>737,chr(175)=>333, - chr(176)=>400,chr(177)=>584,chr(178)=>333,chr(179)=>333,chr(180)=>333,chr(181)=>611,chr(182)=>556,chr(183)=>278,chr(184)=>333,chr(185)=>333,chr(186)=>365,chr(187)=>556,chr(188)=>834,chr(189)=>834,chr(190)=>834,chr(191)=>611,chr(192)=>722,chr(193)=>722,chr(194)=>722,chr(195)=>722,chr(196)=>722,chr(197)=>722, - chr(198)=>1000,chr(199)=>722,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>278,chr(205)=>278,chr(206)=>278,chr(207)=>278,chr(208)=>722,chr(209)=>722,chr(210)=>778,chr(211)=>778,chr(212)=>778,chr(213)=>778,chr(214)=>778,chr(215)=>584,chr(216)=>778,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>667,chr(222)=>667,chr(223)=>611,chr(224)=>556,chr(225)=>556,chr(226)=>556,chr(227)=>556,chr(228)=>556,chr(229)=>556,chr(230)=>889,chr(231)=>556,chr(232)=>556,chr(233)=>556,chr(234)=>556,chr(235)=>556,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>611,chr(241)=>611, - chr(242)=>611,chr(243)=>611,chr(244)=>611,chr(245)=>611,chr(246)=>611,chr(247)=>584,chr(248)=>611,chr(249)=>611,chr(250)=>611,chr(251)=>611,chr(252)=>611,chr(253)=>556,chr(254)=>611,chr(255)=>556); -?> diff --git a/vendor/fpdf/font/helveticai.php b/vendor/fpdf/font/helveticai.php deleted file mode 100644 index 25fb7949..00000000 --- a/vendor/fpdf/font/helveticai.php +++ /dev/null @@ -1,19 +0,0 @@ -278,chr(1)=>278,chr(2)=>278,chr(3)=>278,chr(4)=>278,chr(5)=>278,chr(6)=>278,chr(7)=>278,chr(8)=>278,chr(9)=>278,chr(10)=>278,chr(11)=>278,chr(12)=>278,chr(13)=>278,chr(14)=>278,chr(15)=>278,chr(16)=>278,chr(17)=>278,chr(18)=>278,chr(19)=>278,chr(20)=>278,chr(21)=>278, - chr(22)=>278,chr(23)=>278,chr(24)=>278,chr(25)=>278,chr(26)=>278,chr(27)=>278,chr(28)=>278,chr(29)=>278,chr(30)=>278,chr(31)=>278,' '=>278,'!'=>278,'"'=>355,'#'=>556,'$'=>556,'%'=>889,'&'=>667,'\''=>191,'('=>333,')'=>333,'*'=>389,'+'=>584, - ','=>278,'-'=>333,'.'=>278,'/'=>278,'0'=>556,'1'=>556,'2'=>556,'3'=>556,'4'=>556,'5'=>556,'6'=>556,'7'=>556,'8'=>556,'9'=>556,':'=>278,';'=>278,'<'=>584,'='=>584,'>'=>584,'?'=>556,'@'=>1015,'A'=>667, - 'B'=>667,'C'=>722,'D'=>722,'E'=>667,'F'=>611,'G'=>778,'H'=>722,'I'=>278,'J'=>500,'K'=>667,'L'=>556,'M'=>833,'N'=>722,'O'=>778,'P'=>667,'Q'=>778,'R'=>722,'S'=>667,'T'=>611,'U'=>722,'V'=>667,'W'=>944, - 'X'=>667,'Y'=>667,'Z'=>611,'['=>278,'\\'=>278,']'=>278,'^'=>469,'_'=>556,'`'=>333,'a'=>556,'b'=>556,'c'=>500,'d'=>556,'e'=>556,'f'=>278,'g'=>556,'h'=>556,'i'=>222,'j'=>222,'k'=>500,'l'=>222,'m'=>833, - 'n'=>556,'o'=>556,'p'=>556,'q'=>556,'r'=>333,'s'=>500,'t'=>278,'u'=>556,'v'=>500,'w'=>722,'x'=>500,'y'=>500,'z'=>500,'{'=>334,'|'=>260,'}'=>334,'~'=>584,chr(127)=>350,chr(128)=>556,chr(129)=>350,chr(130)=>222,chr(131)=>556, - chr(132)=>333,chr(133)=>1000,chr(134)=>556,chr(135)=>556,chr(136)=>333,chr(137)=>1000,chr(138)=>667,chr(139)=>333,chr(140)=>1000,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>222,chr(146)=>222,chr(147)=>333,chr(148)=>333,chr(149)=>350,chr(150)=>556,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>500,chr(155)=>333,chr(156)=>944,chr(157)=>350,chr(158)=>500,chr(159)=>667,chr(160)=>278,chr(161)=>333,chr(162)=>556,chr(163)=>556,chr(164)=>556,chr(165)=>556,chr(166)=>260,chr(167)=>556,chr(168)=>333,chr(169)=>737,chr(170)=>370,chr(171)=>556,chr(172)=>584,chr(173)=>333,chr(174)=>737,chr(175)=>333, - chr(176)=>400,chr(177)=>584,chr(178)=>333,chr(179)=>333,chr(180)=>333,chr(181)=>556,chr(182)=>537,chr(183)=>278,chr(184)=>333,chr(185)=>333,chr(186)=>365,chr(187)=>556,chr(188)=>834,chr(189)=>834,chr(190)=>834,chr(191)=>611,chr(192)=>667,chr(193)=>667,chr(194)=>667,chr(195)=>667,chr(196)=>667,chr(197)=>667, - chr(198)=>1000,chr(199)=>722,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>278,chr(205)=>278,chr(206)=>278,chr(207)=>278,chr(208)=>722,chr(209)=>722,chr(210)=>778,chr(211)=>778,chr(212)=>778,chr(213)=>778,chr(214)=>778,chr(215)=>584,chr(216)=>778,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>667,chr(222)=>667,chr(223)=>611,chr(224)=>556,chr(225)=>556,chr(226)=>556,chr(227)=>556,chr(228)=>556,chr(229)=>556,chr(230)=>889,chr(231)=>500,chr(232)=>556,chr(233)=>556,chr(234)=>556,chr(235)=>556,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>556,chr(241)=>556, - chr(242)=>556,chr(243)=>556,chr(244)=>556,chr(245)=>556,chr(246)=>556,chr(247)=>584,chr(248)=>611,chr(249)=>556,chr(250)=>556,chr(251)=>556,chr(252)=>556,chr(253)=>500,chr(254)=>556,chr(255)=>500); -?> diff --git a/vendor/fpdf/font/symbol.php b/vendor/fpdf/font/symbol.php deleted file mode 100644 index a89f2954..00000000 --- a/vendor/fpdf/font/symbol.php +++ /dev/null @@ -1,19 +0,0 @@ -250,chr(1)=>250,chr(2)=>250,chr(3)=>250,chr(4)=>250,chr(5)=>250,chr(6)=>250,chr(7)=>250,chr(8)=>250,chr(9)=>250,chr(10)=>250,chr(11)=>250,chr(12)=>250,chr(13)=>250,chr(14)=>250,chr(15)=>250,chr(16)=>250,chr(17)=>250,chr(18)=>250,chr(19)=>250,chr(20)=>250,chr(21)=>250, - chr(22)=>250,chr(23)=>250,chr(24)=>250,chr(25)=>250,chr(26)=>250,chr(27)=>250,chr(28)=>250,chr(29)=>250,chr(30)=>250,chr(31)=>250,' '=>250,'!'=>333,'"'=>713,'#'=>500,'$'=>549,'%'=>833,'&'=>778,'\''=>439,'('=>333,')'=>333,'*'=>500,'+'=>549, - ','=>250,'-'=>549,'.'=>250,'/'=>278,'0'=>500,'1'=>500,'2'=>500,'3'=>500,'4'=>500,'5'=>500,'6'=>500,'7'=>500,'8'=>500,'9'=>500,':'=>278,';'=>278,'<'=>549,'='=>549,'>'=>549,'?'=>444,'@'=>549,'A'=>722, - 'B'=>667,'C'=>722,'D'=>612,'E'=>611,'F'=>763,'G'=>603,'H'=>722,'I'=>333,'J'=>631,'K'=>722,'L'=>686,'M'=>889,'N'=>722,'O'=>722,'P'=>768,'Q'=>741,'R'=>556,'S'=>592,'T'=>611,'U'=>690,'V'=>439,'W'=>768, - 'X'=>645,'Y'=>795,'Z'=>611,'['=>333,'\\'=>863,']'=>333,'^'=>658,'_'=>500,'`'=>500,'a'=>631,'b'=>549,'c'=>549,'d'=>494,'e'=>439,'f'=>521,'g'=>411,'h'=>603,'i'=>329,'j'=>603,'k'=>549,'l'=>549,'m'=>576, - 'n'=>521,'o'=>549,'p'=>549,'q'=>521,'r'=>549,'s'=>603,'t'=>439,'u'=>576,'v'=>713,'w'=>686,'x'=>493,'y'=>686,'z'=>494,'{'=>480,'|'=>200,'}'=>480,'~'=>549,chr(127)=>0,chr(128)=>0,chr(129)=>0,chr(130)=>0,chr(131)=>0, - chr(132)=>0,chr(133)=>0,chr(134)=>0,chr(135)=>0,chr(136)=>0,chr(137)=>0,chr(138)=>0,chr(139)=>0,chr(140)=>0,chr(141)=>0,chr(142)=>0,chr(143)=>0,chr(144)=>0,chr(145)=>0,chr(146)=>0,chr(147)=>0,chr(148)=>0,chr(149)=>0,chr(150)=>0,chr(151)=>0,chr(152)=>0,chr(153)=>0, - chr(154)=>0,chr(155)=>0,chr(156)=>0,chr(157)=>0,chr(158)=>0,chr(159)=>0,chr(160)=>750,chr(161)=>620,chr(162)=>247,chr(163)=>549,chr(164)=>167,chr(165)=>713,chr(166)=>500,chr(167)=>753,chr(168)=>753,chr(169)=>753,chr(170)=>753,chr(171)=>1042,chr(172)=>987,chr(173)=>603,chr(174)=>987,chr(175)=>603, - chr(176)=>400,chr(177)=>549,chr(178)=>411,chr(179)=>549,chr(180)=>549,chr(181)=>713,chr(182)=>494,chr(183)=>460,chr(184)=>549,chr(185)=>549,chr(186)=>549,chr(187)=>549,chr(188)=>1000,chr(189)=>603,chr(190)=>1000,chr(191)=>658,chr(192)=>823,chr(193)=>686,chr(194)=>795,chr(195)=>987,chr(196)=>768,chr(197)=>768, - chr(198)=>823,chr(199)=>768,chr(200)=>768,chr(201)=>713,chr(202)=>713,chr(203)=>713,chr(204)=>713,chr(205)=>713,chr(206)=>713,chr(207)=>713,chr(208)=>768,chr(209)=>713,chr(210)=>790,chr(211)=>790,chr(212)=>890,chr(213)=>823,chr(214)=>549,chr(215)=>250,chr(216)=>713,chr(217)=>603,chr(218)=>603,chr(219)=>1042, - chr(220)=>987,chr(221)=>603,chr(222)=>987,chr(223)=>603,chr(224)=>494,chr(225)=>329,chr(226)=>790,chr(227)=>790,chr(228)=>786,chr(229)=>713,chr(230)=>384,chr(231)=>384,chr(232)=>384,chr(233)=>384,chr(234)=>384,chr(235)=>384,chr(236)=>494,chr(237)=>494,chr(238)=>494,chr(239)=>494,chr(240)=>0,chr(241)=>329, - chr(242)=>274,chr(243)=>686,chr(244)=>686,chr(245)=>686,chr(246)=>384,chr(247)=>384,chr(248)=>384,chr(249)=>384,chr(250)=>384,chr(251)=>384,chr(252)=>494,chr(253)=>494,chr(254)=>494,chr(255)=>0); -?> diff --git a/vendor/fpdf/font/times.php b/vendor/fpdf/font/times.php deleted file mode 100644 index 57b9bce8..00000000 --- a/vendor/fpdf/font/times.php +++ /dev/null @@ -1,19 +0,0 @@ -250,chr(1)=>250,chr(2)=>250,chr(3)=>250,chr(4)=>250,chr(5)=>250,chr(6)=>250,chr(7)=>250,chr(8)=>250,chr(9)=>250,chr(10)=>250,chr(11)=>250,chr(12)=>250,chr(13)=>250,chr(14)=>250,chr(15)=>250,chr(16)=>250,chr(17)=>250,chr(18)=>250,chr(19)=>250,chr(20)=>250,chr(21)=>250, - chr(22)=>250,chr(23)=>250,chr(24)=>250,chr(25)=>250,chr(26)=>250,chr(27)=>250,chr(28)=>250,chr(29)=>250,chr(30)=>250,chr(31)=>250,' '=>250,'!'=>333,'"'=>408,'#'=>500,'$'=>500,'%'=>833,'&'=>778,'\''=>180,'('=>333,')'=>333,'*'=>500,'+'=>564, - ','=>250,'-'=>333,'.'=>250,'/'=>278,'0'=>500,'1'=>500,'2'=>500,'3'=>500,'4'=>500,'5'=>500,'6'=>500,'7'=>500,'8'=>500,'9'=>500,':'=>278,';'=>278,'<'=>564,'='=>564,'>'=>564,'?'=>444,'@'=>921,'A'=>722, - 'B'=>667,'C'=>667,'D'=>722,'E'=>611,'F'=>556,'G'=>722,'H'=>722,'I'=>333,'J'=>389,'K'=>722,'L'=>611,'M'=>889,'N'=>722,'O'=>722,'P'=>556,'Q'=>722,'R'=>667,'S'=>556,'T'=>611,'U'=>722,'V'=>722,'W'=>944, - 'X'=>722,'Y'=>722,'Z'=>611,'['=>333,'\\'=>278,']'=>333,'^'=>469,'_'=>500,'`'=>333,'a'=>444,'b'=>500,'c'=>444,'d'=>500,'e'=>444,'f'=>333,'g'=>500,'h'=>500,'i'=>278,'j'=>278,'k'=>500,'l'=>278,'m'=>778, - 'n'=>500,'o'=>500,'p'=>500,'q'=>500,'r'=>333,'s'=>389,'t'=>278,'u'=>500,'v'=>500,'w'=>722,'x'=>500,'y'=>500,'z'=>444,'{'=>480,'|'=>200,'}'=>480,'~'=>541,chr(127)=>350,chr(128)=>500,chr(129)=>350,chr(130)=>333,chr(131)=>500, - chr(132)=>444,chr(133)=>1000,chr(134)=>500,chr(135)=>500,chr(136)=>333,chr(137)=>1000,chr(138)=>556,chr(139)=>333,chr(140)=>889,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>333,chr(146)=>333,chr(147)=>444,chr(148)=>444,chr(149)=>350,chr(150)=>500,chr(151)=>1000,chr(152)=>333,chr(153)=>980, - chr(154)=>389,chr(155)=>333,chr(156)=>722,chr(157)=>350,chr(158)=>444,chr(159)=>722,chr(160)=>250,chr(161)=>333,chr(162)=>500,chr(163)=>500,chr(164)=>500,chr(165)=>500,chr(166)=>200,chr(167)=>500,chr(168)=>333,chr(169)=>760,chr(170)=>276,chr(171)=>500,chr(172)=>564,chr(173)=>333,chr(174)=>760,chr(175)=>333, - chr(176)=>400,chr(177)=>564,chr(178)=>300,chr(179)=>300,chr(180)=>333,chr(181)=>500,chr(182)=>453,chr(183)=>250,chr(184)=>333,chr(185)=>300,chr(186)=>310,chr(187)=>500,chr(188)=>750,chr(189)=>750,chr(190)=>750,chr(191)=>444,chr(192)=>722,chr(193)=>722,chr(194)=>722,chr(195)=>722,chr(196)=>722,chr(197)=>722, - chr(198)=>889,chr(199)=>667,chr(200)=>611,chr(201)=>611,chr(202)=>611,chr(203)=>611,chr(204)=>333,chr(205)=>333,chr(206)=>333,chr(207)=>333,chr(208)=>722,chr(209)=>722,chr(210)=>722,chr(211)=>722,chr(212)=>722,chr(213)=>722,chr(214)=>722,chr(215)=>564,chr(216)=>722,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>722,chr(222)=>556,chr(223)=>500,chr(224)=>444,chr(225)=>444,chr(226)=>444,chr(227)=>444,chr(228)=>444,chr(229)=>444,chr(230)=>667,chr(231)=>444,chr(232)=>444,chr(233)=>444,chr(234)=>444,chr(235)=>444,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>500,chr(241)=>500, - chr(242)=>500,chr(243)=>500,chr(244)=>500,chr(245)=>500,chr(246)=>500,chr(247)=>564,chr(248)=>500,chr(249)=>500,chr(250)=>500,chr(251)=>500,chr(252)=>500,chr(253)=>500,chr(254)=>500,chr(255)=>500); -?> diff --git a/vendor/fpdf/font/timesb.php b/vendor/fpdf/font/timesb.php deleted file mode 100644 index 6946b9ea..00000000 --- a/vendor/fpdf/font/timesb.php +++ /dev/null @@ -1,19 +0,0 @@ -250,chr(1)=>250,chr(2)=>250,chr(3)=>250,chr(4)=>250,chr(5)=>250,chr(6)=>250,chr(7)=>250,chr(8)=>250,chr(9)=>250,chr(10)=>250,chr(11)=>250,chr(12)=>250,chr(13)=>250,chr(14)=>250,chr(15)=>250,chr(16)=>250,chr(17)=>250,chr(18)=>250,chr(19)=>250,chr(20)=>250,chr(21)=>250, - chr(22)=>250,chr(23)=>250,chr(24)=>250,chr(25)=>250,chr(26)=>250,chr(27)=>250,chr(28)=>250,chr(29)=>250,chr(30)=>250,chr(31)=>250,' '=>250,'!'=>333,'"'=>555,'#'=>500,'$'=>500,'%'=>1000,'&'=>833,'\''=>278,'('=>333,')'=>333,'*'=>500,'+'=>570, - ','=>250,'-'=>333,'.'=>250,'/'=>278,'0'=>500,'1'=>500,'2'=>500,'3'=>500,'4'=>500,'5'=>500,'6'=>500,'7'=>500,'8'=>500,'9'=>500,':'=>333,';'=>333,'<'=>570,'='=>570,'>'=>570,'?'=>500,'@'=>930,'A'=>722, - 'B'=>667,'C'=>722,'D'=>722,'E'=>667,'F'=>611,'G'=>778,'H'=>778,'I'=>389,'J'=>500,'K'=>778,'L'=>667,'M'=>944,'N'=>722,'O'=>778,'P'=>611,'Q'=>778,'R'=>722,'S'=>556,'T'=>667,'U'=>722,'V'=>722,'W'=>1000, - 'X'=>722,'Y'=>722,'Z'=>667,'['=>333,'\\'=>278,']'=>333,'^'=>581,'_'=>500,'`'=>333,'a'=>500,'b'=>556,'c'=>444,'d'=>556,'e'=>444,'f'=>333,'g'=>500,'h'=>556,'i'=>278,'j'=>333,'k'=>556,'l'=>278,'m'=>833, - 'n'=>556,'o'=>500,'p'=>556,'q'=>556,'r'=>444,'s'=>389,'t'=>333,'u'=>556,'v'=>500,'w'=>722,'x'=>500,'y'=>500,'z'=>444,'{'=>394,'|'=>220,'}'=>394,'~'=>520,chr(127)=>350,chr(128)=>500,chr(129)=>350,chr(130)=>333,chr(131)=>500, - chr(132)=>500,chr(133)=>1000,chr(134)=>500,chr(135)=>500,chr(136)=>333,chr(137)=>1000,chr(138)=>556,chr(139)=>333,chr(140)=>1000,chr(141)=>350,chr(142)=>667,chr(143)=>350,chr(144)=>350,chr(145)=>333,chr(146)=>333,chr(147)=>500,chr(148)=>500,chr(149)=>350,chr(150)=>500,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>389,chr(155)=>333,chr(156)=>722,chr(157)=>350,chr(158)=>444,chr(159)=>722,chr(160)=>250,chr(161)=>333,chr(162)=>500,chr(163)=>500,chr(164)=>500,chr(165)=>500,chr(166)=>220,chr(167)=>500,chr(168)=>333,chr(169)=>747,chr(170)=>300,chr(171)=>500,chr(172)=>570,chr(173)=>333,chr(174)=>747,chr(175)=>333, - chr(176)=>400,chr(177)=>570,chr(178)=>300,chr(179)=>300,chr(180)=>333,chr(181)=>556,chr(182)=>540,chr(183)=>250,chr(184)=>333,chr(185)=>300,chr(186)=>330,chr(187)=>500,chr(188)=>750,chr(189)=>750,chr(190)=>750,chr(191)=>500,chr(192)=>722,chr(193)=>722,chr(194)=>722,chr(195)=>722,chr(196)=>722,chr(197)=>722, - chr(198)=>1000,chr(199)=>722,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>389,chr(205)=>389,chr(206)=>389,chr(207)=>389,chr(208)=>722,chr(209)=>722,chr(210)=>778,chr(211)=>778,chr(212)=>778,chr(213)=>778,chr(214)=>778,chr(215)=>570,chr(216)=>778,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>722,chr(222)=>611,chr(223)=>556,chr(224)=>500,chr(225)=>500,chr(226)=>500,chr(227)=>500,chr(228)=>500,chr(229)=>500,chr(230)=>722,chr(231)=>444,chr(232)=>444,chr(233)=>444,chr(234)=>444,chr(235)=>444,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>500,chr(241)=>556, - chr(242)=>500,chr(243)=>500,chr(244)=>500,chr(245)=>500,chr(246)=>500,chr(247)=>570,chr(248)=>500,chr(249)=>556,chr(250)=>556,chr(251)=>556,chr(252)=>556,chr(253)=>500,chr(254)=>556,chr(255)=>500); -?> diff --git a/vendor/fpdf/font/timesbi.php b/vendor/fpdf/font/timesbi.php deleted file mode 100644 index cd5e5f12..00000000 --- a/vendor/fpdf/font/timesbi.php +++ /dev/null @@ -1,19 +0,0 @@ -250,chr(1)=>250,chr(2)=>250,chr(3)=>250,chr(4)=>250,chr(5)=>250,chr(6)=>250,chr(7)=>250,chr(8)=>250,chr(9)=>250,chr(10)=>250,chr(11)=>250,chr(12)=>250,chr(13)=>250,chr(14)=>250,chr(15)=>250,chr(16)=>250,chr(17)=>250,chr(18)=>250,chr(19)=>250,chr(20)=>250,chr(21)=>250, - chr(22)=>250,chr(23)=>250,chr(24)=>250,chr(25)=>250,chr(26)=>250,chr(27)=>250,chr(28)=>250,chr(29)=>250,chr(30)=>250,chr(31)=>250,' '=>250,'!'=>389,'"'=>555,'#'=>500,'$'=>500,'%'=>833,'&'=>778,'\''=>278,'('=>333,')'=>333,'*'=>500,'+'=>570, - ','=>250,'-'=>333,'.'=>250,'/'=>278,'0'=>500,'1'=>500,'2'=>500,'3'=>500,'4'=>500,'5'=>500,'6'=>500,'7'=>500,'8'=>500,'9'=>500,':'=>333,';'=>333,'<'=>570,'='=>570,'>'=>570,'?'=>500,'@'=>832,'A'=>667, - 'B'=>667,'C'=>667,'D'=>722,'E'=>667,'F'=>667,'G'=>722,'H'=>778,'I'=>389,'J'=>500,'K'=>667,'L'=>611,'M'=>889,'N'=>722,'O'=>722,'P'=>611,'Q'=>722,'R'=>667,'S'=>556,'T'=>611,'U'=>722,'V'=>667,'W'=>889, - 'X'=>667,'Y'=>611,'Z'=>611,'['=>333,'\\'=>278,']'=>333,'^'=>570,'_'=>500,'`'=>333,'a'=>500,'b'=>500,'c'=>444,'d'=>500,'e'=>444,'f'=>333,'g'=>500,'h'=>556,'i'=>278,'j'=>278,'k'=>500,'l'=>278,'m'=>778, - 'n'=>556,'o'=>500,'p'=>500,'q'=>500,'r'=>389,'s'=>389,'t'=>278,'u'=>556,'v'=>444,'w'=>667,'x'=>500,'y'=>444,'z'=>389,'{'=>348,'|'=>220,'}'=>348,'~'=>570,chr(127)=>350,chr(128)=>500,chr(129)=>350,chr(130)=>333,chr(131)=>500, - chr(132)=>500,chr(133)=>1000,chr(134)=>500,chr(135)=>500,chr(136)=>333,chr(137)=>1000,chr(138)=>556,chr(139)=>333,chr(140)=>944,chr(141)=>350,chr(142)=>611,chr(143)=>350,chr(144)=>350,chr(145)=>333,chr(146)=>333,chr(147)=>500,chr(148)=>500,chr(149)=>350,chr(150)=>500,chr(151)=>1000,chr(152)=>333,chr(153)=>1000, - chr(154)=>389,chr(155)=>333,chr(156)=>722,chr(157)=>350,chr(158)=>389,chr(159)=>611,chr(160)=>250,chr(161)=>389,chr(162)=>500,chr(163)=>500,chr(164)=>500,chr(165)=>500,chr(166)=>220,chr(167)=>500,chr(168)=>333,chr(169)=>747,chr(170)=>266,chr(171)=>500,chr(172)=>606,chr(173)=>333,chr(174)=>747,chr(175)=>333, - chr(176)=>400,chr(177)=>570,chr(178)=>300,chr(179)=>300,chr(180)=>333,chr(181)=>576,chr(182)=>500,chr(183)=>250,chr(184)=>333,chr(185)=>300,chr(186)=>300,chr(187)=>500,chr(188)=>750,chr(189)=>750,chr(190)=>750,chr(191)=>500,chr(192)=>667,chr(193)=>667,chr(194)=>667,chr(195)=>667,chr(196)=>667,chr(197)=>667, - chr(198)=>944,chr(199)=>667,chr(200)=>667,chr(201)=>667,chr(202)=>667,chr(203)=>667,chr(204)=>389,chr(205)=>389,chr(206)=>389,chr(207)=>389,chr(208)=>722,chr(209)=>722,chr(210)=>722,chr(211)=>722,chr(212)=>722,chr(213)=>722,chr(214)=>722,chr(215)=>570,chr(216)=>722,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>611,chr(222)=>611,chr(223)=>500,chr(224)=>500,chr(225)=>500,chr(226)=>500,chr(227)=>500,chr(228)=>500,chr(229)=>500,chr(230)=>722,chr(231)=>444,chr(232)=>444,chr(233)=>444,chr(234)=>444,chr(235)=>444,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>500,chr(241)=>556, - chr(242)=>500,chr(243)=>500,chr(244)=>500,chr(245)=>500,chr(246)=>500,chr(247)=>570,chr(248)=>500,chr(249)=>556,chr(250)=>556,chr(251)=>556,chr(252)=>556,chr(253)=>444,chr(254)=>500,chr(255)=>444); -?> diff --git a/vendor/fpdf/font/timesi.php b/vendor/fpdf/font/timesi.php deleted file mode 100644 index d6da2a99..00000000 --- a/vendor/fpdf/font/timesi.php +++ /dev/null @@ -1,19 +0,0 @@ -250,chr(1)=>250,chr(2)=>250,chr(3)=>250,chr(4)=>250,chr(5)=>250,chr(6)=>250,chr(7)=>250,chr(8)=>250,chr(9)=>250,chr(10)=>250,chr(11)=>250,chr(12)=>250,chr(13)=>250,chr(14)=>250,chr(15)=>250,chr(16)=>250,chr(17)=>250,chr(18)=>250,chr(19)=>250,chr(20)=>250,chr(21)=>250, - chr(22)=>250,chr(23)=>250,chr(24)=>250,chr(25)=>250,chr(26)=>250,chr(27)=>250,chr(28)=>250,chr(29)=>250,chr(30)=>250,chr(31)=>250,' '=>250,'!'=>333,'"'=>420,'#'=>500,'$'=>500,'%'=>833,'&'=>778,'\''=>214,'('=>333,')'=>333,'*'=>500,'+'=>675, - ','=>250,'-'=>333,'.'=>250,'/'=>278,'0'=>500,'1'=>500,'2'=>500,'3'=>500,'4'=>500,'5'=>500,'6'=>500,'7'=>500,'8'=>500,'9'=>500,':'=>333,';'=>333,'<'=>675,'='=>675,'>'=>675,'?'=>500,'@'=>920,'A'=>611, - 'B'=>611,'C'=>667,'D'=>722,'E'=>611,'F'=>611,'G'=>722,'H'=>722,'I'=>333,'J'=>444,'K'=>667,'L'=>556,'M'=>833,'N'=>667,'O'=>722,'P'=>611,'Q'=>722,'R'=>611,'S'=>500,'T'=>556,'U'=>722,'V'=>611,'W'=>833, - 'X'=>611,'Y'=>556,'Z'=>556,'['=>389,'\\'=>278,']'=>389,'^'=>422,'_'=>500,'`'=>333,'a'=>500,'b'=>500,'c'=>444,'d'=>500,'e'=>444,'f'=>278,'g'=>500,'h'=>500,'i'=>278,'j'=>278,'k'=>444,'l'=>278,'m'=>722, - 'n'=>500,'o'=>500,'p'=>500,'q'=>500,'r'=>389,'s'=>389,'t'=>278,'u'=>500,'v'=>444,'w'=>667,'x'=>444,'y'=>444,'z'=>389,'{'=>400,'|'=>275,'}'=>400,'~'=>541,chr(127)=>350,chr(128)=>500,chr(129)=>350,chr(130)=>333,chr(131)=>500, - chr(132)=>556,chr(133)=>889,chr(134)=>500,chr(135)=>500,chr(136)=>333,chr(137)=>1000,chr(138)=>500,chr(139)=>333,chr(140)=>944,chr(141)=>350,chr(142)=>556,chr(143)=>350,chr(144)=>350,chr(145)=>333,chr(146)=>333,chr(147)=>556,chr(148)=>556,chr(149)=>350,chr(150)=>500,chr(151)=>889,chr(152)=>333,chr(153)=>980, - chr(154)=>389,chr(155)=>333,chr(156)=>667,chr(157)=>350,chr(158)=>389,chr(159)=>556,chr(160)=>250,chr(161)=>389,chr(162)=>500,chr(163)=>500,chr(164)=>500,chr(165)=>500,chr(166)=>275,chr(167)=>500,chr(168)=>333,chr(169)=>760,chr(170)=>276,chr(171)=>500,chr(172)=>675,chr(173)=>333,chr(174)=>760,chr(175)=>333, - chr(176)=>400,chr(177)=>675,chr(178)=>300,chr(179)=>300,chr(180)=>333,chr(181)=>500,chr(182)=>523,chr(183)=>250,chr(184)=>333,chr(185)=>300,chr(186)=>310,chr(187)=>500,chr(188)=>750,chr(189)=>750,chr(190)=>750,chr(191)=>500,chr(192)=>611,chr(193)=>611,chr(194)=>611,chr(195)=>611,chr(196)=>611,chr(197)=>611, - chr(198)=>889,chr(199)=>667,chr(200)=>611,chr(201)=>611,chr(202)=>611,chr(203)=>611,chr(204)=>333,chr(205)=>333,chr(206)=>333,chr(207)=>333,chr(208)=>722,chr(209)=>667,chr(210)=>722,chr(211)=>722,chr(212)=>722,chr(213)=>722,chr(214)=>722,chr(215)=>675,chr(216)=>722,chr(217)=>722,chr(218)=>722,chr(219)=>722, - chr(220)=>722,chr(221)=>556,chr(222)=>611,chr(223)=>500,chr(224)=>500,chr(225)=>500,chr(226)=>500,chr(227)=>500,chr(228)=>500,chr(229)=>500,chr(230)=>667,chr(231)=>444,chr(232)=>444,chr(233)=>444,chr(234)=>444,chr(235)=>444,chr(236)=>278,chr(237)=>278,chr(238)=>278,chr(239)=>278,chr(240)=>500,chr(241)=>500, - chr(242)=>500,chr(243)=>500,chr(244)=>500,chr(245)=>500,chr(246)=>500,chr(247)=>675,chr(248)=>500,chr(249)=>500,chr(250)=>500,chr(251)=>500,chr(252)=>500,chr(253)=>444,chr(254)=>500,chr(255)=>444); -?> diff --git a/vendor/fpdf/font/zapfdingbats.php b/vendor/fpdf/font/zapfdingbats.php deleted file mode 100644 index 8f7d4906..00000000 --- a/vendor/fpdf/font/zapfdingbats.php +++ /dev/null @@ -1,19 +0,0 @@ -0,chr(1)=>0,chr(2)=>0,chr(3)=>0,chr(4)=>0,chr(5)=>0,chr(6)=>0,chr(7)=>0,chr(8)=>0,chr(9)=>0,chr(10)=>0,chr(11)=>0,chr(12)=>0,chr(13)=>0,chr(14)=>0,chr(15)=>0,chr(16)=>0,chr(17)=>0,chr(18)=>0,chr(19)=>0,chr(20)=>0,chr(21)=>0, - chr(22)=>0,chr(23)=>0,chr(24)=>0,chr(25)=>0,chr(26)=>0,chr(27)=>0,chr(28)=>0,chr(29)=>0,chr(30)=>0,chr(31)=>0,' '=>278,'!'=>974,'"'=>961,'#'=>974,'$'=>980,'%'=>719,'&'=>789,'\''=>790,'('=>791,')'=>690,'*'=>960,'+'=>939, - ','=>549,'-'=>855,'.'=>911,'/'=>933,'0'=>911,'1'=>945,'2'=>974,'3'=>755,'4'=>846,'5'=>762,'6'=>761,'7'=>571,'8'=>677,'9'=>763,':'=>760,';'=>759,'<'=>754,'='=>494,'>'=>552,'?'=>537,'@'=>577,'A'=>692, - 'B'=>786,'C'=>788,'D'=>788,'E'=>790,'F'=>793,'G'=>794,'H'=>816,'I'=>823,'J'=>789,'K'=>841,'L'=>823,'M'=>833,'N'=>816,'O'=>831,'P'=>923,'Q'=>744,'R'=>723,'S'=>749,'T'=>790,'U'=>792,'V'=>695,'W'=>776, - 'X'=>768,'Y'=>792,'Z'=>759,'['=>707,'\\'=>708,']'=>682,'^'=>701,'_'=>826,'`'=>815,'a'=>789,'b'=>789,'c'=>707,'d'=>687,'e'=>696,'f'=>689,'g'=>786,'h'=>787,'i'=>713,'j'=>791,'k'=>785,'l'=>791,'m'=>873, - 'n'=>761,'o'=>762,'p'=>762,'q'=>759,'r'=>759,'s'=>892,'t'=>892,'u'=>788,'v'=>784,'w'=>438,'x'=>138,'y'=>277,'z'=>415,'{'=>392,'|'=>392,'}'=>668,'~'=>668,chr(127)=>0,chr(128)=>390,chr(129)=>390,chr(130)=>317,chr(131)=>317, - chr(132)=>276,chr(133)=>276,chr(134)=>509,chr(135)=>509,chr(136)=>410,chr(137)=>410,chr(138)=>234,chr(139)=>234,chr(140)=>334,chr(141)=>334,chr(142)=>0,chr(143)=>0,chr(144)=>0,chr(145)=>0,chr(146)=>0,chr(147)=>0,chr(148)=>0,chr(149)=>0,chr(150)=>0,chr(151)=>0,chr(152)=>0,chr(153)=>0, - chr(154)=>0,chr(155)=>0,chr(156)=>0,chr(157)=>0,chr(158)=>0,chr(159)=>0,chr(160)=>0,chr(161)=>732,chr(162)=>544,chr(163)=>544,chr(164)=>910,chr(165)=>667,chr(166)=>760,chr(167)=>760,chr(168)=>776,chr(169)=>595,chr(170)=>694,chr(171)=>626,chr(172)=>788,chr(173)=>788,chr(174)=>788,chr(175)=>788, - chr(176)=>788,chr(177)=>788,chr(178)=>788,chr(179)=>788,chr(180)=>788,chr(181)=>788,chr(182)=>788,chr(183)=>788,chr(184)=>788,chr(185)=>788,chr(186)=>788,chr(187)=>788,chr(188)=>788,chr(189)=>788,chr(190)=>788,chr(191)=>788,chr(192)=>788,chr(193)=>788,chr(194)=>788,chr(195)=>788,chr(196)=>788,chr(197)=>788, - chr(198)=>788,chr(199)=>788,chr(200)=>788,chr(201)=>788,chr(202)=>788,chr(203)=>788,chr(204)=>788,chr(205)=>788,chr(206)=>788,chr(207)=>788,chr(208)=>788,chr(209)=>788,chr(210)=>788,chr(211)=>788,chr(212)=>894,chr(213)=>838,chr(214)=>1016,chr(215)=>458,chr(216)=>748,chr(217)=>924,chr(218)=>748,chr(219)=>918, - chr(220)=>927,chr(221)=>928,chr(222)=>928,chr(223)=>834,chr(224)=>873,chr(225)=>828,chr(226)=>924,chr(227)=>924,chr(228)=>917,chr(229)=>930,chr(230)=>931,chr(231)=>463,chr(232)=>883,chr(233)=>836,chr(234)=>836,chr(235)=>867,chr(236)=>867,chr(237)=>696,chr(238)=>696,chr(239)=>874,chr(240)=>0,chr(241)=>874, - chr(242)=>760,chr(243)=>946,chr(244)=>771,chr(245)=>865,chr(246)=>771,chr(247)=>888,chr(248)=>967,chr(249)=>888,chr(250)=>831,chr(251)=>873,chr(252)=>927,chr(253)=>970,chr(254)=>918,chr(255)=>0); -?> diff --git a/vendor/fpdf/fpdf.css b/vendor/fpdf/fpdf.css deleted file mode 100644 index 8cfa33d7..00000000 --- a/vendor/fpdf/fpdf.css +++ /dev/null @@ -1,21 +0,0 @@ -body {font-family:"Times New Roman",serif} -h1 {font:bold 135% Arial,sans-serif; color:#4000A0; margin-bottom:0.9em} -h2 {font:bold 95% Arial,sans-serif; color:#900000; margin-top:1.5em; margin-bottom:1em} -dl.param dt {text-decoration:underline} -dl.param dd {margin-top:1em; margin-bottom:1em} -dl.param ul {margin-top:1em; margin-bottom:1em} -tt, code, kbd {font-family:"Courier New",Courier,monospace; font-size:82%} -div.source {margin-top:1.4em; margin-bottom:1.3em} -div.source pre {display:table; border:1px solid #24246A; width:100%; margin:0em; font-family:inherit; font-size:100%} -div.source code {display:block; border:1px solid #C5C5EC; background-color:#F0F5FF; padding:6px; color:#000000} -div.doc-source {margin-top:1.4em; margin-bottom:1.3em} -div.doc-source pre {display:table; width:100%; margin:0em; font-family:inherit; font-size:100%} -div.doc-source code {display:block; background-color:#E0E0E0; padding:4px} -.kw {color:#000080; font-weight:bold} -.str {color:#CC0000} -.cmt {color:#008000} -p.demo {text-align:center; margin-top:-0.9em} -a.demo {text-decoration:none; font-weight:bold; color:#0000CC} -a.demo:link {text-decoration:none; font-weight:bold; color:#0000CC} -a.demo:hover {text-decoration:none; font-weight:bold; color:#0000FF} -a.demo:active {text-decoration:none; font-weight:bold; color:#0000FF} diff --git a/vendor/fpdf/fpdf.php b/vendor/fpdf/fpdf.php deleted file mode 100644 index ef99ceeb..00000000 --- a/vendor/fpdf/fpdf.php +++ /dev/null @@ -1,1804 +0,0 @@ -_dochecks(); - // Initialization of properties - $this->page = 0; - $this->n = 2; - $this->buffer = ''; - $this->pages = array(); - $this->PageSizes = array(); - $this->state = 0; - $this->fonts = array(); - $this->FontFiles = array(); - $this->diffs = array(); - $this->images = array(); - $this->links = array(); - $this->InHeader = false; - $this->InFooter = false; - $this->lasth = 0; - $this->FontFamily = ''; - $this->FontStyle = ''; - $this->FontSizePt = 12; - $this->underline = false; - $this->DrawColor = '0 G'; - $this->FillColor = '0 g'; - $this->TextColor = '0 g'; - $this->ColorFlag = false; - $this->ws = 0; - // Font path - if(defined('FPDF_FONTPATH')) - { - $this->fontpath = FPDF_FONTPATH; - if(substr($this->fontpath,-1)!='/' && substr($this->fontpath,-1)!='\\') - $this->fontpath .= '/'; - } - elseif(is_dir(dirname(__FILE__).'/font')) - $this->fontpath = dirname(__FILE__).'/font/'; - else - $this->fontpath = ''; - // Core fonts - $this->CoreFonts = array('courier', 'helvetica', 'times', 'symbol', 'zapfdingbats'); - // Scale factor - if($unit=='pt') - $this->k = 1; - elseif($unit=='mm') - $this->k = 72/25.4; - elseif($unit=='cm') - $this->k = 72/2.54; - elseif($unit=='in') - $this->k = 72; - else - $this->Error('Incorrect unit: '.$unit); - // Page sizes - $this->StdPageSizes = array('a3'=>array(841.89,1190.55), 'a4'=>array(595.28,841.89), 'a5'=>array(420.94,595.28), - 'letter'=>array(612,792), 'legal'=>array(612,1008)); - $size = $this->_getpagesize($size); - $this->DefPageSize = $size; - $this->CurPageSize = $size; - // Page orientation - $orientation = strtolower($orientation); - if($orientation=='p' || $orientation=='portrait') - { - $this->DefOrientation = 'P'; - $this->w = $size[0]; - $this->h = $size[1]; - } - elseif($orientation=='l' || $orientation=='landscape') - { - $this->DefOrientation = 'L'; - $this->w = $size[1]; - $this->h = $size[0]; - } - else - $this->Error('Incorrect orientation: '.$orientation); - $this->CurOrientation = $this->DefOrientation; - $this->wPt = $this->w*$this->k; - $this->hPt = $this->h*$this->k; - // Page margins (1 cm) - $margin = 28.35/$this->k; - $this->SetMargins($margin,$margin); - // Interior cell margin (1 mm) - $this->cMargin = $margin/10; - // Line width (0.2 mm) - $this->LineWidth = .567/$this->k; - // Automatic page break - $this->SetAutoPageBreak(true,2*$margin); - // Default display mode - $this->SetDisplayMode('default'); - // Enable compression - $this->SetCompression(true); - // Set default PDF version number - $this->PDFVersion = '1.3'; -} - -function SetMargins($left, $top, $right=null) -{ - // Set left, top and right margins - $this->lMargin = $left; - $this->tMargin = $top; - if($right===null) - $right = $left; - $this->rMargin = $right; -} - -function SetLeftMargin($margin) -{ - // Set left margin - $this->lMargin = $margin; - if($this->page>0 && $this->x<$margin) - $this->x = $margin; -} - -function SetTopMargin($margin) -{ - // Set top margin - $this->tMargin = $margin; -} - -function SetRightMargin($margin) -{ - // Set right margin - $this->rMargin = $margin; -} - -function SetAutoPageBreak($auto, $margin=0) -{ - // Set auto page break mode and triggering margin - $this->AutoPageBreak = $auto; - $this->bMargin = $margin; - $this->PageBreakTrigger = $this->h-$margin; -} - -function SetDisplayMode($zoom, $layout='default') -{ - // Set display mode in viewer - if($zoom=='fullpage' || $zoom=='fullwidth' || $zoom=='real' || $zoom=='default' || !is_string($zoom)) - $this->ZoomMode = $zoom; - else - $this->Error('Incorrect zoom display mode: '.$zoom); - if($layout=='single' || $layout=='continuous' || $layout=='two' || $layout=='default') - $this->LayoutMode = $layout; - else - $this->Error('Incorrect layout display mode: '.$layout); -} - -function SetCompression($compress) -{ - // Set page compression - if(function_exists('gzcompress')) - $this->compress = $compress; - else - $this->compress = false; -} - -function SetTitle($title, $isUTF8=false) -{ - // Title of document - if($isUTF8) - $title = $this->_UTF8toUTF16($title); - $this->title = $title; -} - -function SetSubject($subject, $isUTF8=false) -{ - // Subject of document - if($isUTF8) - $subject = $this->_UTF8toUTF16($subject); - $this->subject = $subject; -} - -function SetAuthor($author, $isUTF8=false) -{ - // Author of document - if($isUTF8) - $author = $this->_UTF8toUTF16($author); - $this->author = $author; -} - -function SetKeywords($keywords, $isUTF8=false) -{ - // Keywords of document - if($isUTF8) - $keywords = $this->_UTF8toUTF16($keywords); - $this->keywords = $keywords; -} - -function SetCreator($creator, $isUTF8=false) -{ - // Creator of document - if($isUTF8) - $creator = $this->_UTF8toUTF16($creator); - $this->creator = $creator; -} - -function AliasNbPages($alias='{nb}') -{ - // Define an alias for total number of pages - $this->AliasNbPages = $alias; -} - -function Error($msg) -{ - // Fatal error - die('FPDF error: '.$msg); -} - -function Open() -{ - // Begin document - $this->state = 1; -} - -function Close() -{ - // Terminate document - if($this->state==3) - return; - if($this->page==0) - $this->AddPage(); - // Page footer - $this->InFooter = true; - $this->Footer(); - $this->InFooter = false; - // Close page - $this->_endpage(); - // Close document - $this->_enddoc(); -} - -function AddPage($orientation='', $size='') -{ - // Start a new page - if($this->state==0) - $this->Open(); - $family = $this->FontFamily; - $style = $this->FontStyle.($this->underline ? 'U' : ''); - $fontsize = $this->FontSizePt; - $lw = $this->LineWidth; - $dc = $this->DrawColor; - $fc = $this->FillColor; - $tc = $this->TextColor; - $cf = $this->ColorFlag; - if($this->page>0) - { - // Page footer - $this->InFooter = true; - $this->Footer(); - $this->InFooter = false; - // Close page - $this->_endpage(); - } - // Start new page - $this->_beginpage($orientation,$size); - // Set line cap style to square - $this->_out('2 J'); - // Set line width - $this->LineWidth = $lw; - $this->_out(sprintf('%.2F w',$lw*$this->k)); - // Set font - if($family) - $this->SetFont($family,$style,$fontsize); - // Set colors - $this->DrawColor = $dc; - if($dc!='0 G') - $this->_out($dc); - $this->FillColor = $fc; - if($fc!='0 g') - $this->_out($fc); - $this->TextColor = $tc; - $this->ColorFlag = $cf; - // Page header - $this->InHeader = true; - $this->Header(); - $this->InHeader = false; - // Restore line width - if($this->LineWidth!=$lw) - { - $this->LineWidth = $lw; - $this->_out(sprintf('%.2F w',$lw*$this->k)); - } - // Restore font - if($family) - $this->SetFont($family,$style,$fontsize); - // Restore colors - if($this->DrawColor!=$dc) - { - $this->DrawColor = $dc; - $this->_out($dc); - } - if($this->FillColor!=$fc) - { - $this->FillColor = $fc; - $this->_out($fc); - } - $this->TextColor = $tc; - $this->ColorFlag = $cf; -} - -function Header() -{ - // To be implemented in your own inherited class -} - -function Footer() -{ - // To be implemented in your own inherited class -} - -function PageNo() -{ - // Get current page number - return $this->page; -} - -function SetDrawColor($r, $g=null, $b=null) -{ - // Set color for all stroking operations - if(($r==0 && $g==0 && $b==0) || $g===null) - $this->DrawColor = sprintf('%.3F G',$r/255); - else - $this->DrawColor = sprintf('%.3F %.3F %.3F RG',$r/255,$g/255,$b/255); - if($this->page>0) - $this->_out($this->DrawColor); -} - -function SetFillColor($r, $g=null, $b=null) -{ - // Set color for all filling operations - if(($r==0 && $g==0 && $b==0) || $g===null) - $this->FillColor = sprintf('%.3F g',$r/255); - else - $this->FillColor = sprintf('%.3F %.3F %.3F rg',$r/255,$g/255,$b/255); - $this->ColorFlag = ($this->FillColor!=$this->TextColor); - if($this->page>0) - $this->_out($this->FillColor); -} - -function SetTextColor($r, $g=null, $b=null) -{ - // Set color for text - if(($r==0 && $g==0 && $b==0) || $g===null) - $this->TextColor = sprintf('%.3F g',$r/255); - else - $this->TextColor = sprintf('%.3F %.3F %.3F rg',$r/255,$g/255,$b/255); - $this->ColorFlag = ($this->FillColor!=$this->TextColor); -} - -function GetStringWidth($s) -{ - // Get width of a string in the current font - $s = (string)$s; - $cw = &$this->CurrentFont['cw']; - $w = 0; - $l = strlen($s); - for($i=0;$i<$l;$i++) - $w += $cw[$s[$i]]; - return $w*$this->FontSize/1000; -} - -function SetLineWidth($width) -{ - // Set line width - $this->LineWidth = $width; - if($this->page>0) - $this->_out(sprintf('%.2F w',$width*$this->k)); -} - -function Line($x1, $y1, $x2, $y2) -{ - // Draw a line - $this->_out(sprintf('%.2F %.2F m %.2F %.2F l S',$x1*$this->k,($this->h-$y1)*$this->k,$x2*$this->k,($this->h-$y2)*$this->k)); -} - -function Rect($x, $y, $w, $h, $style='') -{ - // Draw a rectangle - if($style=='F') - $op = 'f'; - elseif($style=='FD' || $style=='DF') - $op = 'B'; - else - $op = 'S'; - $this->_out(sprintf('%.2F %.2F %.2F %.2F re %s',$x*$this->k,($this->h-$y)*$this->k,$w*$this->k,-$h*$this->k,$op)); -} - -function AddFont($family, $style='', $file='') -{ - // Add a TrueType, OpenType or Type1 font - $family = strtolower($family); - if($file=='') - $file = str_replace(' ','',$family).strtolower($style).'.php'; - $style = strtoupper($style); - if($style=='IB') - $style = 'BI'; - $fontkey = $family.$style; - if(isset($this->fonts[$fontkey])) - return; - $info = $this->_loadfont($file); - $info['i'] = count($this->fonts)+1; - if(!empty($info['diff'])) - { - // Search existing encodings - $n = array_search($info['diff'],$this->diffs); - if(!$n) - { - $n = count($this->diffs)+1; - $this->diffs[$n] = $info['diff']; - } - $info['diffn'] = $n; - } - if(!empty($info['file'])) - { - // Embedded font - if($info['type']=='TrueType') - $this->FontFiles[$info['file']] = array('length1'=>$info['originalsize']); - else - $this->FontFiles[$info['file']] = array('length1'=>$info['size1'], 'length2'=>$info['size2']); - } - $this->fonts[$fontkey] = $info; -} - -function SetFont($family, $style='', $size=0) -{ - // Select a font; size given in points - if($family=='') - $family = $this->FontFamily; - else - $family = strtolower($family); - $style = strtoupper($style); - if(strpos($style,'U')!==false) - { - $this->underline = true; - $style = str_replace('U','',$style); - } - else - $this->underline = false; - if($style=='IB') - $style = 'BI'; - if($size==0) - $size = $this->FontSizePt; - // Test if font is already selected - if($this->FontFamily==$family && $this->FontStyle==$style && $this->FontSizePt==$size) - return; - // Test if font is already loaded - $fontkey = $family.$style; - if(!isset($this->fonts[$fontkey])) - { - // Test if one of the core fonts - if($family=='arial') - $family = 'helvetica'; - if(in_array($family,$this->CoreFonts)) - { - if($family=='symbol' || $family=='zapfdingbats') - $style = ''; - $fontkey = $family.$style; - if(!isset($this->fonts[$fontkey])) - $this->AddFont($family,$style); - } - else - $this->Error('Undefined font: '.$family.' '.$style); - } - // Select it - $this->FontFamily = $family; - $this->FontStyle = $style; - $this->FontSizePt = $size; - $this->FontSize = $size/$this->k; - $this->CurrentFont = &$this->fonts[$fontkey]; - if($this->page>0) - $this->_out(sprintf('BT /F%d %.2F Tf ET',$this->CurrentFont['i'],$this->FontSizePt)); -} - -function SetFontSize($size) -{ - // Set font size in points - if($this->FontSizePt==$size) - return; - $this->FontSizePt = $size; - $this->FontSize = $size/$this->k; - if($this->page>0) - $this->_out(sprintf('BT /F%d %.2F Tf ET',$this->CurrentFont['i'],$this->FontSizePt)); -} - -function AddLink() -{ - // Create a new internal link - $n = count($this->links)+1; - $this->links[$n] = array(0, 0); - return $n; -} - -function SetLink($link, $y=0, $page=-1) -{ - // Set destination of internal link - if($y==-1) - $y = $this->y; - if($page==-1) - $page = $this->page; - $this->links[$link] = array($page, $y); -} - -function Link($x, $y, $w, $h, $link) -{ - // Put a link on the page - $this->PageLinks[$this->page][] = array($x*$this->k, $this->hPt-$y*$this->k, $w*$this->k, $h*$this->k, $link); -} - -function Text($x, $y, $txt) -{ - // Output a string - $s = sprintf('BT %.2F %.2F Td (%s) Tj ET',$x*$this->k,($this->h-$y)*$this->k,$this->_escape($txt)); - if($this->underline && $txt!='') - $s .= ' '.$this->_dounderline($x,$y,$txt); - if($this->ColorFlag) - $s = 'q '.$this->TextColor.' '.$s.' Q'; - $this->_out($s); -} - -function AcceptPageBreak() -{ - // Accept automatic page break or not - return $this->AutoPageBreak; -} - -function Cell($w, $h=0, $txt='', $border=0, $ln=0, $align='', $fill=false, $link='') -{ - // Output a cell - $k = $this->k; - if($this->y+$h>$this->PageBreakTrigger && !$this->InHeader && !$this->InFooter && $this->AcceptPageBreak()) - { - // Automatic page break - $x = $this->x; - $ws = $this->ws; - if($ws>0) - { - $this->ws = 0; - $this->_out('0 Tw'); - } - $this->AddPage($this->CurOrientation,$this->CurPageSize); - $this->x = $x; - if($ws>0) - { - $this->ws = $ws; - $this->_out(sprintf('%.3F Tw',$ws*$k)); - } - } - if($w==0) - $w = $this->w-$this->rMargin-$this->x; - $s = ''; - if($fill || $border==1) - { - if($fill) - $op = ($border==1) ? 'B' : 'f'; - else - $op = 'S'; - $s = sprintf('%.2F %.2F %.2F %.2F re %s ',$this->x*$k,($this->h-$this->y)*$k,$w*$k,-$h*$k,$op); - } - if(is_string($border)) - { - $x = $this->x; - $y = $this->y; - if(strpos($border,'L')!==false) - $s .= sprintf('%.2F %.2F m %.2F %.2F l S ',$x*$k,($this->h-$y)*$k,$x*$k,($this->h-($y+$h))*$k); - if(strpos($border,'T')!==false) - $s .= sprintf('%.2F %.2F m %.2F %.2F l S ',$x*$k,($this->h-$y)*$k,($x+$w)*$k,($this->h-$y)*$k); - if(strpos($border,'R')!==false) - $s .= sprintf('%.2F %.2F m %.2F %.2F l S ',($x+$w)*$k,($this->h-$y)*$k,($x+$w)*$k,($this->h-($y+$h))*$k); - if(strpos($border,'B')!==false) - $s .= sprintf('%.2F %.2F m %.2F %.2F l S ',$x*$k,($this->h-($y+$h))*$k,($x+$w)*$k,($this->h-($y+$h))*$k); - } - if($txt!=='') - { - if($align=='R') - $dx = $w-$this->cMargin-$this->GetStringWidth($txt); - elseif($align=='C') - $dx = ($w-$this->GetStringWidth($txt))/2; - else - $dx = $this->cMargin; - if($this->ColorFlag) - $s .= 'q '.$this->TextColor.' '; - $txt2 = str_replace(')','\\)',str_replace('(','\\(',str_replace('\\','\\\\',$txt))); - $s .= sprintf('BT %.2F %.2F Td (%s) Tj ET',($this->x+$dx)*$k,($this->h-($this->y+.5*$h+.3*$this->FontSize))*$k,$txt2); - if($this->underline) - $s .= ' '.$this->_dounderline($this->x+$dx,$this->y+.5*$h+.3*$this->FontSize,$txt); - if($this->ColorFlag) - $s .= ' Q'; - if($link) - $this->Link($this->x+$dx,$this->y+.5*$h-.5*$this->FontSize,$this->GetStringWidth($txt),$this->FontSize,$link); - } - if($s) - $this->_out($s); - $this->lasth = $h; - if($ln>0) - { - // Go to next line - $this->y += $h; - if($ln==1) - $this->x = $this->lMargin; - } - else - $this->x += $w; -} - -function MultiCell($w, $h, $txt, $border=0, $align='J', $fill=false) -{ - // Output text with automatic or explicit line breaks - $cw = &$this->CurrentFont['cw']; - if($w==0) - $w = $this->w-$this->rMargin-$this->x; - $wmax = ($w-2*$this->cMargin)*1000/$this->FontSize; - $s = str_replace("\r",'',$txt); - $nb = strlen($s); - if($nb>0 && $s[$nb-1]=="\n") - $nb--; - $b = 0; - if($border) - { - if($border==1) - { - $border = 'LTRB'; - $b = 'LRT'; - $b2 = 'LR'; - } - else - { - $b2 = ''; - if(strpos($border,'L')!==false) - $b2 .= 'L'; - if(strpos($border,'R')!==false) - $b2 .= 'R'; - $b = (strpos($border,'T')!==false) ? $b2.'T' : $b2; - } - } - $sep = -1; - $i = 0; - $j = 0; - $l = 0; - $ns = 0; - $nl = 1; - while($i<$nb) - { - // Get next character - $c = $s[$i]; - if($c=="\n") - { - // Explicit line break - if($this->ws>0) - { - $this->ws = 0; - $this->_out('0 Tw'); - } - $this->Cell($w,$h,substr($s,$j,$i-$j),$b,2,$align,$fill); - $i++; - $sep = -1; - $j = $i; - $l = 0; - $ns = 0; - $nl++; - if($border && $nl==2) - $b = $b2; - continue; - } - if($c==' ') - { - $sep = $i; - $ls = $l; - $ns++; - } - $l += $cw[$c]; - if($l>$wmax) - { - // Automatic line break - if($sep==-1) - { - if($i==$j) - $i++; - if($this->ws>0) - { - $this->ws = 0; - $this->_out('0 Tw'); - } - $this->Cell($w,$h,substr($s,$j,$i-$j),$b,2,$align,$fill); - } - else - { - if($align=='J') - { - $this->ws = ($ns>1) ? ($wmax-$ls)/1000*$this->FontSize/($ns-1) : 0; - $this->_out(sprintf('%.3F Tw',$this->ws*$this->k)); - } - $this->Cell($w,$h,substr($s,$j,$sep-$j),$b,2,$align,$fill); - $i = $sep+1; - } - $sep = -1; - $j = $i; - $l = 0; - $ns = 0; - $nl++; - if($border && $nl==2) - $b = $b2; - } - else - $i++; - } - // Last chunk - if($this->ws>0) - { - $this->ws = 0; - $this->_out('0 Tw'); - } - if($border && strpos($border,'B')!==false) - $b .= 'B'; - $this->Cell($w,$h,substr($s,$j,$i-$j),$b,2,$align,$fill); - $this->x = $this->lMargin; -} - -function Write($h, $txt, $link='') -{ - // Output text in flowing mode - $cw = &$this->CurrentFont['cw']; - $w = $this->w-$this->rMargin-$this->x; - $wmax = ($w-2*$this->cMargin)*1000/$this->FontSize; - $s = str_replace("\r",'',$txt); - $nb = strlen($s); - $sep = -1; - $i = 0; - $j = 0; - $l = 0; - $nl = 1; - while($i<$nb) - { - // Get next character - $c = $s[$i]; - if($c=="\n") - { - // Explicit line break - $this->Cell($w,$h,substr($s,$j,$i-$j),0,2,'',0,$link); - $i++; - $sep = -1; - $j = $i; - $l = 0; - if($nl==1) - { - $this->x = $this->lMargin; - $w = $this->w-$this->rMargin-$this->x; - $wmax = ($w-2*$this->cMargin)*1000/$this->FontSize; - } - $nl++; - continue; - } - if($c==' ') - $sep = $i; - $l += $cw[$c]; - if($l>$wmax) - { - // Automatic line break - if($sep==-1) - { - if($this->x>$this->lMargin) - { - // Move to next line - $this->x = $this->lMargin; - $this->y += $h; - $w = $this->w-$this->rMargin-$this->x; - $wmax = ($w-2*$this->cMargin)*1000/$this->FontSize; - $i++; - $nl++; - continue; - } - if($i==$j) - $i++; - $this->Cell($w,$h,substr($s,$j,$i-$j),0,2,'',0,$link); - } - else - { - $this->Cell($w,$h,substr($s,$j,$sep-$j),0,2,'',0,$link); - $i = $sep+1; - } - $sep = -1; - $j = $i; - $l = 0; - if($nl==1) - { - $this->x = $this->lMargin; - $w = $this->w-$this->rMargin-$this->x; - $wmax = ($w-2*$this->cMargin)*1000/$this->FontSize; - } - $nl++; - } - else - $i++; - } - // Last chunk - if($i!=$j) - $this->Cell($l/1000*$this->FontSize,$h,substr($s,$j),0,0,'',0,$link); -} - -function Ln($h=null) -{ - // Line feed; default value is last cell height - $this->x = $this->lMargin; - if($h===null) - $this->y += $this->lasth; - else - $this->y += $h; -} - -function Image($file, $x=null, $y=null, $w=0, $h=0, $type='', $link='') -{ - // Put an image on the page - if(!isset($this->images[$file])) - { - // First use of this image, get info - if($type=='') - { - $pos = strrpos($file,'.'); - if(!$pos) - $this->Error('Image file has no extension and no type was specified: '.$file); - $type = substr($file,$pos+1); - } - $type = strtolower($type); - if($type=='jpeg') - $type = 'jpg'; - $mtd = '_parse'.$type; - if(!method_exists($this,$mtd)) - $this->Error('Unsupported image type: '.$type); - $info = $this->$mtd($file); - $info['i'] = count($this->images)+1; - $this->images[$file] = $info; - } - else - $info = $this->images[$file]; - - // Automatic width and height calculation if needed - if($w==0 && $h==0) - { - // Put image at 96 dpi - $w = -96; - $h = -96; - } - if($w<0) - $w = -$info['w']*72/$w/$this->k; - if($h<0) - $h = -$info['h']*72/$h/$this->k; - if($w==0) - $w = $h*$info['w']/$info['h']; - if($h==0) - $h = $w*$info['h']/$info['w']; - - // Flowing mode - if($y===null) - { - if($this->y+$h>$this->PageBreakTrigger && !$this->InHeader && !$this->InFooter && $this->AcceptPageBreak()) - { - // Automatic page break - $x2 = $this->x; - $this->AddPage($this->CurOrientation,$this->CurPageSize); - $this->x = $x2; - } - $y = $this->y; - $this->y += $h; - } - - if($x===null) - $x = $this->x; - $this->_out(sprintf('q %.2F 0 0 %.2F %.2F %.2F cm /I%d Do Q',$w*$this->k,$h*$this->k,$x*$this->k,($this->h-($y+$h))*$this->k,$info['i'])); - if($link) - $this->Link($x,$y,$w,$h,$link); -} - -function GetX() -{ - // Get x position - return $this->x; -} - -function SetX($x) -{ - // Set x position - if($x>=0) - $this->x = $x; - else - $this->x = $this->w+$x; -} - -function GetY() -{ - // Get y position - return $this->y; -} - -function SetY($y) -{ - // Set y position and reset x - $this->x = $this->lMargin; - if($y>=0) - $this->y = $y; - else - $this->y = $this->h+$y; -} - -function SetXY($x, $y) -{ - // Set x and y positions - $this->SetY($y); - $this->SetX($x); -} - -function Output($name='', $dest='') -{ - // Output PDF to some destination - if($this->state<3) - $this->Close(); - $dest = strtoupper($dest); - if($dest=='') - { - if($name=='') - { - $name = 'doc.pdf'; - $dest = 'I'; - } - else - $dest = 'F'; - } - switch($dest) - { - case 'I': - // Send to standard output - $this->_checkoutput(); - if(PHP_SAPI!='cli') - { - // We send to a browser - header('Content-Type: application/pdf'); - header('Content-Disposition: inline; filename="'.$name.'"'); - header('Cache-Control: private, max-age=0, must-revalidate'); - header('Pragma: public'); - } - echo $this->buffer; - break; - case 'D': - // Download file - $this->_checkoutput(); - header('Content-Type: application/x-download'); - header('Content-Disposition: attachment; filename="'.$name.'"'); - header('Cache-Control: private, max-age=0, must-revalidate'); - header('Pragma: public'); - echo $this->buffer; - break; - case 'F': - // Save to local file - $f = fopen($name,'wb'); - if(!$f) - $this->Error('Unable to create output file: '.$name); - fwrite($f,$this->buffer,strlen($this->buffer)); - fclose($f); - break; - case 'S': - // Return as a string - return $this->buffer; - default: - $this->Error('Incorrect output destination: '.$dest); - } - return ''; -} - -/******************************************************************************* -* * -* Protected methods * -* * -*******************************************************************************/ -function _dochecks() -{ - // Check availability of %F - if(sprintf('%.1F',1.0)!='1.0') - $this->Error('This version of PHP is not supported'); - // Check mbstring overloading - if(ini_get('mbstring.func_overload') & 2) - $this->Error('mbstring overloading must be disabled'); - // Ensure runtime magic quotes are disabled - if(get_magic_quotes_runtime()) - @set_magic_quotes_runtime(0); -} - -function _checkoutput() -{ - if(PHP_SAPI!='cli') - { - if(headers_sent($file,$line)) - $this->Error("Some data has already been output, can't send PDF file (output started at $file:$line)"); - } - if(ob_get_length()) - { - // The output buffer is not empty - if(preg_match('/^(\xEF\xBB\xBF)?\s*$/',ob_get_contents())) - { - // It contains only a UTF-8 BOM and/or whitespace, let's clean it - ob_clean(); - } - else - $this->Error("Some data has already been output, can't send PDF file"); - } -} - -function _getpagesize($size) -{ - if(is_string($size)) - { - $size = strtolower($size); - if(!isset($this->StdPageSizes[$size])) - $this->Error('Unknown page size: '.$size); - $a = $this->StdPageSizes[$size]; - return array($a[0]/$this->k, $a[1]/$this->k); - } - else - { - if($size[0]>$size[1]) - return array($size[1], $size[0]); - else - return $size; - } -} - -function _beginpage($orientation, $size) -{ - $this->page++; - $this->pages[$this->page] = ''; - $this->state = 2; - $this->x = $this->lMargin; - $this->y = $this->tMargin; - $this->FontFamily = ''; - // Check page size and orientation - if($orientation=='') - $orientation = $this->DefOrientation; - else - $orientation = strtoupper($orientation[0]); - if($size=='') - $size = $this->DefPageSize; - else - $size = $this->_getpagesize($size); - if($orientation!=$this->CurOrientation || $size[0]!=$this->CurPageSize[0] || $size[1]!=$this->CurPageSize[1]) - { - // New size or orientation - if($orientation=='P') - { - $this->w = $size[0]; - $this->h = $size[1]; - } - else - { - $this->w = $size[1]; - $this->h = $size[0]; - } - $this->wPt = $this->w*$this->k; - $this->hPt = $this->h*$this->k; - $this->PageBreakTrigger = $this->h-$this->bMargin; - $this->CurOrientation = $orientation; - $this->CurPageSize = $size; - } - if($orientation!=$this->DefOrientation || $size[0]!=$this->DefPageSize[0] || $size[1]!=$this->DefPageSize[1]) - $this->PageSizes[$this->page] = array($this->wPt, $this->hPt); -} - -function _endpage() -{ - $this->state = 1; -} - -function _loadfont($font) -{ - // Load a font definition file from the font directory - include($this->fontpath.$font); - $a = get_defined_vars(); - if(!isset($a['name'])) - $this->Error('Could not include font definition file'); - return $a; -} - -function _escape($s) -{ - // Escape special characters in strings - $s = str_replace('\\','\\\\',$s); - $s = str_replace('(','\\(',$s); - $s = str_replace(')','\\)',$s); - $s = str_replace("\r",'\\r',$s); - return $s; -} - -function _textstring($s) -{ - // Format a text string - return '('.$this->_escape($s).')'; -} - -function _UTF8toUTF16($s) -{ - // Convert UTF-8 to UTF-16BE with BOM - $res = "\xFE\xFF"; - $nb = strlen($s); - $i = 0; - while($i<$nb) - { - $c1 = ord($s[$i++]); - if($c1>=224) - { - // 3-byte character - $c2 = ord($s[$i++]); - $c3 = ord($s[$i++]); - $res .= chr((($c1 & 0x0F)<<4) + (($c2 & 0x3C)>>2)); - $res .= chr((($c2 & 0x03)<<6) + ($c3 & 0x3F)); - } - elseif($c1>=192) - { - // 2-byte character - $c2 = ord($s[$i++]); - $res .= chr(($c1 & 0x1C)>>2); - $res .= chr((($c1 & 0x03)<<6) + ($c2 & 0x3F)); - } - else - { - // Single-byte character - $res .= "\0".chr($c1); - } - } - return $res; -} - -function _dounderline($x, $y, $txt) -{ - // Underline text - $up = $this->CurrentFont['up']; - $ut = $this->CurrentFont['ut']; - $w = $this->GetStringWidth($txt)+$this->ws*substr_count($txt,' '); - return sprintf('%.2F %.2F %.2F %.2F re f',$x*$this->k,($this->h-($y-$up/1000*$this->FontSize))*$this->k,$w*$this->k,-$ut/1000*$this->FontSizePt); -} - -function _parsejpg($file) -{ - // Extract info from a JPEG file - $a = getimagesize($file); - if(!$a) - $this->Error('Missing or incorrect image file: '.$file); - if($a[2]!=2) - $this->Error('Not a JPEG file: '.$file); - if(!isset($a['channels']) || $a['channels']==3) - $colspace = 'DeviceRGB'; - elseif($a['channels']==4) - $colspace = 'DeviceCMYK'; - else - $colspace = 'DeviceGray'; - $bpc = isset($a['bits']) ? $a['bits'] : 8; - $data = file_get_contents($file); - return array('w'=>$a[0], 'h'=>$a[1], 'cs'=>$colspace, 'bpc'=>$bpc, 'f'=>'DCTDecode', 'data'=>$data); -} - -function _parsepng($file) -{ - // Extract info from a PNG file - $f = fopen($file,'rb'); - if(!$f) - $this->Error('Can\'t open image file: '.$file); - $info = $this->_parsepngstream($f,$file); - fclose($f); - return $info; -} - -function _parsepngstream($f, $file) -{ - // Check signature - if($this->_readstream($f,8)!=chr(137).'PNG'.chr(13).chr(10).chr(26).chr(10)) - $this->Error('Not a PNG file: '.$file); - - // Read header chunk - $this->_readstream($f,4); - if($this->_readstream($f,4)!='IHDR') - $this->Error('Incorrect PNG file: '.$file); - $w = $this->_readint($f); - $h = $this->_readint($f); - $bpc = ord($this->_readstream($f,1)); - if($bpc>8) - $this->Error('16-bit depth not supported: '.$file); - $ct = ord($this->_readstream($f,1)); - if($ct==0 || $ct==4) - $colspace = 'DeviceGray'; - elseif($ct==2 || $ct==6) - $colspace = 'DeviceRGB'; - elseif($ct==3) - $colspace = 'Indexed'; - else - $this->Error('Unknown color type: '.$file); - if(ord($this->_readstream($f,1))!=0) - $this->Error('Unknown compression method: '.$file); - if(ord($this->_readstream($f,1))!=0) - $this->Error('Unknown filter method: '.$file); - if(ord($this->_readstream($f,1))!=0) - $this->Error('Interlacing not supported: '.$file); - $this->_readstream($f,4); - $dp = '/Predictor 15 /Colors '.($colspace=='DeviceRGB' ? 3 : 1).' /BitsPerComponent '.$bpc.' /Columns '.$w; - - // Scan chunks looking for palette, transparency and image data - $pal = ''; - $trns = ''; - $data = ''; - do - { - $n = $this->_readint($f); - $type = $this->_readstream($f,4); - if($type=='PLTE') - { - // Read palette - $pal = $this->_readstream($f,$n); - $this->_readstream($f,4); - } - elseif($type=='tRNS') - { - // Read transparency info - $t = $this->_readstream($f,$n); - if($ct==0) - $trns = array(ord(substr($t,1,1))); - elseif($ct==2) - $trns = array(ord(substr($t,1,1)), ord(substr($t,3,1)), ord(substr($t,5,1))); - else - { - $pos = strpos($t,chr(0)); - if($pos!==false) - $trns = array($pos); - } - $this->_readstream($f,4); - } - elseif($type=='IDAT') - { - // Read image data block - $data .= $this->_readstream($f,$n); - $this->_readstream($f,4); - } - elseif($type=='IEND') - break; - else - $this->_readstream($f,$n+4); - } - while($n); - - if($colspace=='Indexed' && empty($pal)) - $this->Error('Missing palette in '.$file); - $info = array('w'=>$w, 'h'=>$h, 'cs'=>$colspace, 'bpc'=>$bpc, 'f'=>'FlateDecode', 'dp'=>$dp, 'pal'=>$pal, 'trns'=>$trns); - if($ct>=4) - { - // Extract alpha channel - if(!function_exists('gzuncompress')) - $this->Error('Zlib not available, can\'t handle alpha channel: '.$file); - $data = gzuncompress($data); - $color = ''; - $alpha = ''; - if($ct==4) - { - // Gray image - $len = 2*$w; - for($i=0;$i<$h;$i++) - { - $pos = (1+$len)*$i; - $color .= $data[$pos]; - $alpha .= $data[$pos]; - $line = substr($data,$pos+1,$len); - $color .= preg_replace('/(.)./s','$1',$line); - $alpha .= preg_replace('/.(.)/s','$1',$line); - } - } - else - { - // RGB image - $len = 4*$w; - for($i=0;$i<$h;$i++) - { - $pos = (1+$len)*$i; - $color .= $data[$pos]; - $alpha .= $data[$pos]; - $line = substr($data,$pos+1,$len); - $color .= preg_replace('/(.{3})./s','$1',$line); - $alpha .= preg_replace('/.{3}(.)/s','$1',$line); - } - } - unset($data); - $data = gzcompress($color); - $info['smask'] = gzcompress($alpha); - if($this->PDFVersion<'1.4') - $this->PDFVersion = '1.4'; - } - $info['data'] = $data; - return $info; -} - -function _readstream($f, $n) -{ - // Read n bytes from stream - $res = ''; - while($n>0 && !feof($f)) - { - $s = fread($f,$n); - if($s===false) - $this->Error('Error while reading stream'); - $n -= strlen($s); - $res .= $s; - } - if($n>0) - $this->Error('Unexpected end of stream'); - return $res; -} - -function _readint($f) -{ - // Read a 4-byte integer from stream - $a = unpack('Ni',$this->_readstream($f,4)); - return $a['i']; -} - -function _parsegif($file) -{ - // Extract info from a GIF file (via PNG conversion) - if(!function_exists('imagepng')) - $this->Error('GD extension is required for GIF support'); - if(!function_exists('imagecreatefromgif')) - $this->Error('GD has no GIF read support'); - $im = imagecreatefromgif($file); - if(!$im) - $this->Error('Missing or incorrect image file: '.$file); - imageinterlace($im,0); - $f = @fopen('php://temp','rb+'); - if($f) - { - // Perform conversion in memory - ob_start(); - imagepng($im); - $data = ob_get_clean(); - imagedestroy($im); - fwrite($f,$data); - rewind($f); - $info = $this->_parsepngstream($f,$file); - fclose($f); - } - else - { - // Use temporary file - $tmp = tempnam('.','gif'); - if(!$tmp) - $this->Error('Unable to create a temporary file'); - if(!imagepng($im,$tmp)) - $this->Error('Error while saving to temporary file'); - imagedestroy($im); - $info = $this->_parsepng($tmp); - unlink($tmp); - } - return $info; -} - -function _newobj() -{ - // Begin a new object - $this->n++; - $this->offsets[$this->n] = strlen($this->buffer); - $this->_out($this->n.' 0 obj'); -} - -function _putstream($s) -{ - $this->_out('stream'); - $this->_out($s); - $this->_out('endstream'); -} - -function _out($s) -{ - // Add a line to the document - if($this->state==2) - $this->pages[$this->page] .= $s."\n"; - else - $this->buffer .= $s."\n"; -} - -function _putpages() -{ - $nb = $this->page; - if(!empty($this->AliasNbPages)) - { - // Replace number of pages - for($n=1;$n<=$nb;$n++) - $this->pages[$n] = str_replace($this->AliasNbPages,$nb,$this->pages[$n]); - } - if($this->DefOrientation=='P') - { - $wPt = $this->DefPageSize[0]*$this->k; - $hPt = $this->DefPageSize[1]*$this->k; - } - else - { - $wPt = $this->DefPageSize[1]*$this->k; - $hPt = $this->DefPageSize[0]*$this->k; - } - $filter = ($this->compress) ? '/Filter /FlateDecode ' : ''; - for($n=1;$n<=$nb;$n++) - { - // Page - $this->_newobj(); - $this->_out('<_out('/Parent 1 0 R'); - if(isset($this->PageSizes[$n])) - $this->_out(sprintf('/MediaBox [0 0 %.2F %.2F]',$this->PageSizes[$n][0],$this->PageSizes[$n][1])); - $this->_out('/Resources 2 0 R'); - if(isset($this->PageLinks[$n])) - { - // Links - $annots = '/Annots ['; - foreach($this->PageLinks[$n] as $pl) - { - $rect = sprintf('%.2F %.2F %.2F %.2F',$pl[0],$pl[1],$pl[0]+$pl[2],$pl[1]-$pl[3]); - $annots .= '<_textstring($pl[4]).'>>>>'; - else - { - $l = $this->links[$pl[4]]; - $h = isset($this->PageSizes[$l[0]]) ? $this->PageSizes[$l[0]][1] : $hPt; - $annots .= sprintf('/Dest [%d 0 R /XYZ 0 %.2F null]>>',1+2*$l[0],$h-$l[1]*$this->k); - } - } - $this->_out($annots.']'); - } - if($this->PDFVersion>'1.3') - $this->_out('/Group <>'); - $this->_out('/Contents '.($this->n+1).' 0 R>>'); - $this->_out('endobj'); - // Page content - $p = ($this->compress) ? gzcompress($this->pages[$n]) : $this->pages[$n]; - $this->_newobj(); - $this->_out('<<'.$filter.'/Length '.strlen($p).'>>'); - $this->_putstream($p); - $this->_out('endobj'); - } - // Pages root - $this->offsets[1] = strlen($this->buffer); - $this->_out('1 0 obj'); - $this->_out('<_out($kids.']'); - $this->_out('/Count '.$nb); - $this->_out(sprintf('/MediaBox [0 0 %.2F %.2F]',$wPt,$hPt)); - $this->_out('>>'); - $this->_out('endobj'); -} - -function _putfonts() -{ - $nf = $this->n; - foreach($this->diffs as $diff) - { - // Encodings - $this->_newobj(); - $this->_out('<>'); - $this->_out('endobj'); - } - foreach($this->FontFiles as $file=>$info) - { - // Font file embedding - $this->_newobj(); - $this->FontFiles[$file]['n'] = $this->n; - $font = file_get_contents($this->fontpath.$file,true); - if(!$font) - $this->Error('Font file not found: '.$file); - $compressed = (substr($file,-2)=='.z'); - if(!$compressed && isset($info['length2'])) - $font = substr($font,6,$info['length1']).substr($font,6+$info['length1']+6,$info['length2']); - $this->_out('<_out('/Filter /FlateDecode'); - $this->_out('/Length1 '.$info['length1']); - if(isset($info['length2'])) - $this->_out('/Length2 '.$info['length2'].' /Length3 0'); - $this->_out('>>'); - $this->_putstream($font); - $this->_out('endobj'); - } - foreach($this->fonts as $k=>$font) - { - // Font objects - $this->fonts[$k]['n'] = $this->n+1; - $type = $font['type']; - $name = $font['name']; - if($type=='Core') - { - // Core font - $this->_newobj(); - $this->_out('<_out('/BaseFont /'.$name); - $this->_out('/Subtype /Type1'); - if($name!='Symbol' && $name!='ZapfDingbats') - $this->_out('/Encoding /WinAnsiEncoding'); - $this->_out('>>'); - $this->_out('endobj'); - } - elseif($type=='Type1' || $type=='TrueType') - { - // Additional Type1 or TrueType/OpenType font - $this->_newobj(); - $this->_out('<_out('/BaseFont /'.$name); - $this->_out('/Subtype /'.$type); - $this->_out('/FirstChar 32 /LastChar 255'); - $this->_out('/Widths '.($this->n+1).' 0 R'); - $this->_out('/FontDescriptor '.($this->n+2).' 0 R'); - if(isset($font['diffn'])) - $this->_out('/Encoding '.($nf+$font['diffn']).' 0 R'); - else - $this->_out('/Encoding /WinAnsiEncoding'); - $this->_out('>>'); - $this->_out('endobj'); - // Widths - $this->_newobj(); - $cw = &$font['cw']; - $s = '['; - for($i=32;$i<=255;$i++) - $s .= $cw[chr($i)].' '; - $this->_out($s.']'); - $this->_out('endobj'); - // Descriptor - $this->_newobj(); - $s = '<$v) - $s .= ' /'.$k.' '.$v; - if(!empty($font['file'])) - $s .= ' /FontFile'.($type=='Type1' ? '' : '2').' '.$this->FontFiles[$font['file']]['n'].' 0 R'; - $this->_out($s.'>>'); - $this->_out('endobj'); - } - else - { - // Allow for additional types - $mtd = '_put'.strtolower($type); - if(!method_exists($this,$mtd)) - $this->Error('Unsupported font type: '.$type); - $this->$mtd($font); - } - } -} - -function _putimages() -{ - foreach(array_keys($this->images) as $file) - { - $this->_putimage($this->images[$file]); - unset($this->images[$file]['data']); - unset($this->images[$file]['smask']); - } -} - -function _putimage(&$info) -{ - $this->_newobj(); - $info['n'] = $this->n; - $this->_out('<_out('/Subtype /Image'); - $this->_out('/Width '.$info['w']); - $this->_out('/Height '.$info['h']); - if($info['cs']=='Indexed') - $this->_out('/ColorSpace [/Indexed /DeviceRGB '.(strlen($info['pal'])/3-1).' '.($this->n+1).' 0 R]'); - else - { - $this->_out('/ColorSpace /'.$info['cs']); - if($info['cs']=='DeviceCMYK') - $this->_out('/Decode [1 0 1 0 1 0 1 0]'); - } - $this->_out('/BitsPerComponent '.$info['bpc']); - if(isset($info['f'])) - $this->_out('/Filter /'.$info['f']); - if(isset($info['dp'])) - $this->_out('/DecodeParms <<'.$info['dp'].'>>'); - if(isset($info['trns']) && is_array($info['trns'])) - { - $trns = ''; - for($i=0;$i_out('/Mask ['.$trns.']'); - } - if(isset($info['smask'])) - $this->_out('/SMask '.($this->n+1).' 0 R'); - $this->_out('/Length '.strlen($info['data']).'>>'); - $this->_putstream($info['data']); - $this->_out('endobj'); - // Soft mask - if(isset($info['smask'])) - { - $dp = '/Predictor 15 /Colors 1 /BitsPerComponent 8 /Columns '.$info['w']; - $smask = array('w'=>$info['w'], 'h'=>$info['h'], 'cs'=>'DeviceGray', 'bpc'=>8, 'f'=>$info['f'], 'dp'=>$dp, 'data'=>$info['smask']); - $this->_putimage($smask); - } - // Palette - if($info['cs']=='Indexed') - { - $filter = ($this->compress) ? '/Filter /FlateDecode ' : ''; - $pal = ($this->compress) ? gzcompress($info['pal']) : $info['pal']; - $this->_newobj(); - $this->_out('<<'.$filter.'/Length '.strlen($pal).'>>'); - $this->_putstream($pal); - $this->_out('endobj'); - } -} - -function _putxobjectdict() -{ - foreach($this->images as $image) - $this->_out('/I'.$image['i'].' '.$image['n'].' 0 R'); -} - -function _putresourcedict() -{ - $this->_out('/ProcSet [/PDF /Text /ImageB /ImageC /ImageI]'); - $this->_out('/Font <<'); - foreach($this->fonts as $font) - $this->_out('/F'.$font['i'].' '.$font['n'].' 0 R'); - $this->_out('>>'); - $this->_out('/XObject <<'); - $this->_putxobjectdict(); - $this->_out('>>'); -} - -function _putresources() -{ - $this->_putfonts(); - $this->_putimages(); - // Resource dictionary - $this->offsets[2] = strlen($this->buffer); - $this->_out('2 0 obj'); - $this->_out('<<'); - $this->_putresourcedict(); - $this->_out('>>'); - $this->_out('endobj'); -} - -function _putinfo() -{ - $this->_out('/Producer '.$this->_textstring('FPDF '.FPDF_VERSION)); - if(!empty($this->title)) - $this->_out('/Title '.$this->_textstring($this->title)); - if(!empty($this->subject)) - $this->_out('/Subject '.$this->_textstring($this->subject)); - if(!empty($this->author)) - $this->_out('/Author '.$this->_textstring($this->author)); - if(!empty($this->keywords)) - $this->_out('/Keywords '.$this->_textstring($this->keywords)); - if(!empty($this->creator)) - $this->_out('/Creator '.$this->_textstring($this->creator)); - $this->_out('/CreationDate '.$this->_textstring('D:'.@date('YmdHis'))); -} - -function _putcatalog() -{ - $this->_out('/Type /Catalog'); - $this->_out('/Pages 1 0 R'); - if($this->ZoomMode=='fullpage') - $this->_out('/OpenAction [3 0 R /Fit]'); - elseif($this->ZoomMode=='fullwidth') - $this->_out('/OpenAction [3 0 R /FitH null]'); - elseif($this->ZoomMode=='real') - $this->_out('/OpenAction [3 0 R /XYZ null null 1]'); - elseif(!is_string($this->ZoomMode)) - $this->_out('/OpenAction [3 0 R /XYZ null null '.sprintf('%.2F',$this->ZoomMode/100).']'); - if($this->LayoutMode=='single') - $this->_out('/PageLayout /SinglePage'); - elseif($this->LayoutMode=='continuous') - $this->_out('/PageLayout /OneColumn'); - elseif($this->LayoutMode=='two') - $this->_out('/PageLayout /TwoColumnLeft'); -} - -function _putheader() -{ - $this->_out('%PDF-'.$this->PDFVersion); -} - -function _puttrailer() -{ - $this->_out('/Size '.($this->n+1)); - $this->_out('/Root '.$this->n.' 0 R'); - $this->_out('/Info '.($this->n-1).' 0 R'); -} - -function _enddoc() -{ - $this->_putheader(); - $this->_putpages(); - $this->_putresources(); - // Info - $this->_newobj(); - $this->_out('<<'); - $this->_putinfo(); - $this->_out('>>'); - $this->_out('endobj'); - // Catalog - $this->_newobj(); - $this->_out('<<'); - $this->_putcatalog(); - $this->_out('>>'); - $this->_out('endobj'); - // Cross-ref - $o = strlen($this->buffer); - $this->_out('xref'); - $this->_out('0 '.($this->n+1)); - $this->_out('0000000000 65535 f '); - for($i=1;$i<=$this->n;$i++) - $this->_out(sprintf('%010d 00000 n ',$this->offsets[$i])); - // Trailer - $this->_out('trailer'); - $this->_out('<<'); - $this->_puttrailer(); - $this->_out('>>'); - $this->_out('startxref'); - $this->_out($o); - $this->_out('%%EOF'); - $this->state = 3; -} -// End of class -} - -// Handle special IE contype request -if(isset($_SERVER['HTTP_USER_AGENT']) && $_SERVER['HTTP_USER_AGENT']=='contype') -{ - header('Content-Type: application/pdf'); - exit; -} - -?> diff --git a/vendor/fpdf/install.txt b/vendor/fpdf/install.txt deleted file mode 100644 index 62d25e63..00000000 --- a/vendor/fpdf/install.txt +++ /dev/null @@ -1,15 +0,0 @@ -The FPDF library is made up of the following elements: - -- the main file, fpdf.php, which contains the class -- the font definition files located in the font directory - -The font definition files are necessary as soon as you want to output some text in a document. -If they are not accessible, the SetFont() method will produce the following error: - -FPDF error: Could not include font definition file - - -Remarks: - -- Only the files corresponding to the fonts actually used are necessary -- The tutorials provided in this package are ready to be executed diff --git a/vendor/fpdf/license.txt b/vendor/fpdf/license.txt deleted file mode 100644 index 6107ee47..00000000 --- a/vendor/fpdf/license.txt +++ /dev/null @@ -1,6 +0,0 @@ -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software to use, copy, modify, distribute, sublicense, and/or sell -copies of the software, and to permit persons to whom the software is furnished -to do so. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED. \ No newline at end of file diff --git a/vendor/fpdf/makefont/cp1250.map b/vendor/fpdf/makefont/cp1250.map deleted file mode 100644 index ec110af0..00000000 --- a/vendor/fpdf/makefont/cp1250.map +++ /dev/null @@ -1,251 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!89 U+2030 perthousand -!8A U+0160 Scaron -!8B U+2039 guilsinglleft -!8C U+015A Sacute -!8D U+0164 Tcaron -!8E U+017D Zcaron -!8F U+0179 Zacute -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!99 U+2122 trademark -!9A U+0161 scaron -!9B U+203A guilsinglright -!9C U+015B sacute -!9D U+0165 tcaron -!9E U+017E zcaron -!9F U+017A zacute -!A0 U+00A0 space -!A1 U+02C7 caron -!A2 U+02D8 breve -!A3 U+0141 Lslash -!A4 U+00A4 currency -!A5 U+0104 Aogonek -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+015E Scedilla -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+017B Zdotaccent -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+02DB ogonek -!B3 U+0142 lslash -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+0105 aogonek -!BA U+015F scedilla -!BB U+00BB guillemotright -!BC U+013D Lcaron -!BD U+02DD hungarumlaut -!BE U+013E lcaron -!BF U+017C zdotaccent -!C0 U+0154 Racute -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+0102 Abreve -!C4 U+00C4 Adieresis -!C5 U+0139 Lacute -!C6 U+0106 Cacute -!C7 U+00C7 Ccedilla -!C8 U+010C Ccaron -!C9 U+00C9 Eacute -!CA U+0118 Eogonek -!CB U+00CB Edieresis -!CC U+011A Ecaron -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+010E Dcaron -!D0 U+0110 Dcroat -!D1 U+0143 Nacute -!D2 U+0147 Ncaron -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+0150 Ohungarumlaut -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+0158 Rcaron -!D9 U+016E Uring -!DA U+00DA Uacute -!DB U+0170 Uhungarumlaut -!DC U+00DC Udieresis -!DD U+00DD Yacute -!DE U+0162 Tcommaaccent -!DF U+00DF germandbls -!E0 U+0155 racute -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+0103 abreve -!E4 U+00E4 adieresis -!E5 U+013A lacute -!E6 U+0107 cacute -!E7 U+00E7 ccedilla -!E8 U+010D ccaron -!E9 U+00E9 eacute -!EA U+0119 eogonek -!EB U+00EB edieresis -!EC U+011B ecaron -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+010F dcaron -!F0 U+0111 dcroat -!F1 U+0144 nacute -!F2 U+0148 ncaron -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+0151 ohungarumlaut -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+0159 rcaron -!F9 U+016F uring -!FA U+00FA uacute -!FB U+0171 uhungarumlaut -!FC U+00FC udieresis -!FD U+00FD yacute -!FE U+0163 tcommaaccent -!FF U+02D9 dotaccent diff --git a/vendor/fpdf/makefont/cp1251.map b/vendor/fpdf/makefont/cp1251.map deleted file mode 100644 index de6a198d..00000000 --- a/vendor/fpdf/makefont/cp1251.map +++ /dev/null @@ -1,255 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0402 afii10051 -!81 U+0403 afii10052 -!82 U+201A quotesinglbase -!83 U+0453 afii10100 -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!88 U+20AC Euro -!89 U+2030 perthousand -!8A U+0409 afii10058 -!8B U+2039 guilsinglleft -!8C U+040A afii10059 -!8D U+040C afii10061 -!8E U+040B afii10060 -!8F U+040F afii10145 -!90 U+0452 afii10099 -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!99 U+2122 trademark -!9A U+0459 afii10106 -!9B U+203A guilsinglright -!9C U+045A afii10107 -!9D U+045C afii10109 -!9E U+045B afii10108 -!9F U+045F afii10193 -!A0 U+00A0 space -!A1 U+040E afii10062 -!A2 U+045E afii10110 -!A3 U+0408 afii10057 -!A4 U+00A4 currency -!A5 U+0490 afii10050 -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+0401 afii10023 -!A9 U+00A9 copyright -!AA U+0404 afii10053 -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+0407 afii10056 -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+0406 afii10055 -!B3 U+0456 afii10103 -!B4 U+0491 afii10098 -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+0451 afii10071 -!B9 U+2116 afii61352 -!BA U+0454 afii10101 -!BB U+00BB guillemotright -!BC U+0458 afii10105 -!BD U+0405 afii10054 -!BE U+0455 afii10102 -!BF U+0457 afii10104 -!C0 U+0410 afii10017 -!C1 U+0411 afii10018 -!C2 U+0412 afii10019 -!C3 U+0413 afii10020 -!C4 U+0414 afii10021 -!C5 U+0415 afii10022 -!C6 U+0416 afii10024 -!C7 U+0417 afii10025 -!C8 U+0418 afii10026 -!C9 U+0419 afii10027 -!CA U+041A afii10028 -!CB U+041B afii10029 -!CC U+041C afii10030 -!CD U+041D afii10031 -!CE U+041E afii10032 -!CF U+041F afii10033 -!D0 U+0420 afii10034 -!D1 U+0421 afii10035 -!D2 U+0422 afii10036 -!D3 U+0423 afii10037 -!D4 U+0424 afii10038 -!D5 U+0425 afii10039 -!D6 U+0426 afii10040 -!D7 U+0427 afii10041 -!D8 U+0428 afii10042 -!D9 U+0429 afii10043 -!DA U+042A afii10044 -!DB U+042B afii10045 -!DC U+042C afii10046 -!DD U+042D afii10047 -!DE U+042E afii10048 -!DF U+042F afii10049 -!E0 U+0430 afii10065 -!E1 U+0431 afii10066 -!E2 U+0432 afii10067 -!E3 U+0433 afii10068 -!E4 U+0434 afii10069 -!E5 U+0435 afii10070 -!E6 U+0436 afii10072 -!E7 U+0437 afii10073 -!E8 U+0438 afii10074 -!E9 U+0439 afii10075 -!EA U+043A afii10076 -!EB U+043B afii10077 -!EC U+043C afii10078 -!ED U+043D afii10079 -!EE U+043E afii10080 -!EF U+043F afii10081 -!F0 U+0440 afii10082 -!F1 U+0441 afii10083 -!F2 U+0442 afii10084 -!F3 U+0443 afii10085 -!F4 U+0444 afii10086 -!F5 U+0445 afii10087 -!F6 U+0446 afii10088 -!F7 U+0447 afii10089 -!F8 U+0448 afii10090 -!F9 U+0449 afii10091 -!FA U+044A afii10092 -!FB U+044B afii10093 -!FC U+044C afii10094 -!FD U+044D afii10095 -!FE U+044E afii10096 -!FF U+044F afii10097 diff --git a/vendor/fpdf/makefont/cp1252.map b/vendor/fpdf/makefont/cp1252.map deleted file mode 100644 index dd490e59..00000000 --- a/vendor/fpdf/makefont/cp1252.map +++ /dev/null @@ -1,251 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!83 U+0192 florin -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!88 U+02C6 circumflex -!89 U+2030 perthousand -!8A U+0160 Scaron -!8B U+2039 guilsinglleft -!8C U+0152 OE -!8E U+017D Zcaron -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!98 U+02DC tilde -!99 U+2122 trademark -!9A U+0161 scaron -!9B U+203A guilsinglright -!9C U+0153 oe -!9E U+017E zcaron -!9F U+0178 Ydieresis -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+00D0 Eth -!D1 U+00D1 Ntilde -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+00DD Yacute -!DE U+00DE Thorn -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+00F0 eth -!F1 U+00F1 ntilde -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+00FD yacute -!FE U+00FE thorn -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/cp1253.map b/vendor/fpdf/makefont/cp1253.map deleted file mode 100644 index 4bd826fb..00000000 --- a/vendor/fpdf/makefont/cp1253.map +++ /dev/null @@ -1,239 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!83 U+0192 florin -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!89 U+2030 perthousand -!8B U+2039 guilsinglleft -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!99 U+2122 trademark -!9B U+203A guilsinglright -!A0 U+00A0 space -!A1 U+0385 dieresistonos -!A2 U+0386 Alphatonos -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+2015 afii00208 -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+0384 tonos -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+0388 Epsilontonos -!B9 U+0389 Etatonos -!BA U+038A Iotatonos -!BB U+00BB guillemotright -!BC U+038C Omicrontonos -!BD U+00BD onehalf -!BE U+038E Upsilontonos -!BF U+038F Omegatonos -!C0 U+0390 iotadieresistonos -!C1 U+0391 Alpha -!C2 U+0392 Beta -!C3 U+0393 Gamma -!C4 U+0394 Delta -!C5 U+0395 Epsilon -!C6 U+0396 Zeta -!C7 U+0397 Eta -!C8 U+0398 Theta -!C9 U+0399 Iota -!CA U+039A Kappa -!CB U+039B Lambda -!CC U+039C Mu -!CD U+039D Nu -!CE U+039E Xi -!CF U+039F Omicron -!D0 U+03A0 Pi -!D1 U+03A1 Rho -!D3 U+03A3 Sigma -!D4 U+03A4 Tau -!D5 U+03A5 Upsilon -!D6 U+03A6 Phi -!D7 U+03A7 Chi -!D8 U+03A8 Psi -!D9 U+03A9 Omega -!DA U+03AA Iotadieresis -!DB U+03AB Upsilondieresis -!DC U+03AC alphatonos -!DD U+03AD epsilontonos -!DE U+03AE etatonos -!DF U+03AF iotatonos -!E0 U+03B0 upsilondieresistonos -!E1 U+03B1 alpha -!E2 U+03B2 beta -!E3 U+03B3 gamma -!E4 U+03B4 delta -!E5 U+03B5 epsilon -!E6 U+03B6 zeta -!E7 U+03B7 eta -!E8 U+03B8 theta -!E9 U+03B9 iota -!EA U+03BA kappa -!EB U+03BB lambda -!EC U+03BC mu -!ED U+03BD nu -!EE U+03BE xi -!EF U+03BF omicron -!F0 U+03C0 pi -!F1 U+03C1 rho -!F2 U+03C2 sigma1 -!F3 U+03C3 sigma -!F4 U+03C4 tau -!F5 U+03C5 upsilon -!F6 U+03C6 phi -!F7 U+03C7 chi -!F8 U+03C8 psi -!F9 U+03C9 omega -!FA U+03CA iotadieresis -!FB U+03CB upsilondieresis -!FC U+03CC omicrontonos -!FD U+03CD upsilontonos -!FE U+03CE omegatonos diff --git a/vendor/fpdf/makefont/cp1254.map b/vendor/fpdf/makefont/cp1254.map deleted file mode 100644 index 829473b2..00000000 --- a/vendor/fpdf/makefont/cp1254.map +++ /dev/null @@ -1,249 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!83 U+0192 florin -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!88 U+02C6 circumflex -!89 U+2030 perthousand -!8A U+0160 Scaron -!8B U+2039 guilsinglleft -!8C U+0152 OE -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!98 U+02DC tilde -!99 U+2122 trademark -!9A U+0161 scaron -!9B U+203A guilsinglright -!9C U+0153 oe -!9F U+0178 Ydieresis -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+011E Gbreve -!D1 U+00D1 Ntilde -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+0130 Idotaccent -!DE U+015E Scedilla -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+011F gbreve -!F1 U+00F1 ntilde -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+0131 dotlessi -!FE U+015F scedilla -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/cp1255.map b/vendor/fpdf/makefont/cp1255.map deleted file mode 100644 index 079e10c6..00000000 --- a/vendor/fpdf/makefont/cp1255.map +++ /dev/null @@ -1,233 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!83 U+0192 florin -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!88 U+02C6 circumflex -!89 U+2030 perthousand -!8B U+2039 guilsinglleft -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!98 U+02DC tilde -!99 U+2122 trademark -!9B U+203A guilsinglright -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+20AA afii57636 -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00D7 multiply -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD sfthyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 middot -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00F7 divide -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+05B0 afii57799 -!C1 U+05B1 afii57801 -!C2 U+05B2 afii57800 -!C3 U+05B3 afii57802 -!C4 U+05B4 afii57793 -!C5 U+05B5 afii57794 -!C6 U+05B6 afii57795 -!C7 U+05B7 afii57798 -!C8 U+05B8 afii57797 -!C9 U+05B9 afii57806 -!CB U+05BB afii57796 -!CC U+05BC afii57807 -!CD U+05BD afii57839 -!CE U+05BE afii57645 -!CF U+05BF afii57841 -!D0 U+05C0 afii57842 -!D1 U+05C1 afii57804 -!D2 U+05C2 afii57803 -!D3 U+05C3 afii57658 -!D4 U+05F0 afii57716 -!D5 U+05F1 afii57717 -!D6 U+05F2 afii57718 -!D7 U+05F3 gereshhebrew -!D8 U+05F4 gershayimhebrew -!E0 U+05D0 afii57664 -!E1 U+05D1 afii57665 -!E2 U+05D2 afii57666 -!E3 U+05D3 afii57667 -!E4 U+05D4 afii57668 -!E5 U+05D5 afii57669 -!E6 U+05D6 afii57670 -!E7 U+05D7 afii57671 -!E8 U+05D8 afii57672 -!E9 U+05D9 afii57673 -!EA U+05DA afii57674 -!EB U+05DB afii57675 -!EC U+05DC afii57676 -!ED U+05DD afii57677 -!EE U+05DE afii57678 -!EF U+05DF afii57679 -!F0 U+05E0 afii57680 -!F1 U+05E1 afii57681 -!F2 U+05E2 afii57682 -!F3 U+05E3 afii57683 -!F4 U+05E4 afii57684 -!F5 U+05E5 afii57685 -!F6 U+05E6 afii57686 -!F7 U+05E7 afii57687 -!F8 U+05E8 afii57688 -!F9 U+05E9 afii57689 -!FA U+05EA afii57690 -!FD U+200E afii299 -!FE U+200F afii300 diff --git a/vendor/fpdf/makefont/cp1257.map b/vendor/fpdf/makefont/cp1257.map deleted file mode 100644 index 2f2ecfa2..00000000 --- a/vendor/fpdf/makefont/cp1257.map +++ /dev/null @@ -1,244 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!89 U+2030 perthousand -!8B U+2039 guilsinglleft -!8D U+00A8 dieresis -!8E U+02C7 caron -!8F U+00B8 cedilla -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!99 U+2122 trademark -!9B U+203A guilsinglright -!9D U+00AF macron -!9E U+02DB ogonek -!A0 U+00A0 space -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00D8 Oslash -!A9 U+00A9 copyright -!AA U+0156 Rcommaaccent -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00C6 AE -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00F8 oslash -!B9 U+00B9 onesuperior -!BA U+0157 rcommaaccent -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00E6 ae -!C0 U+0104 Aogonek -!C1 U+012E Iogonek -!C2 U+0100 Amacron -!C3 U+0106 Cacute -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+0118 Eogonek -!C7 U+0112 Emacron -!C8 U+010C Ccaron -!C9 U+00C9 Eacute -!CA U+0179 Zacute -!CB U+0116 Edotaccent -!CC U+0122 Gcommaaccent -!CD U+0136 Kcommaaccent -!CE U+012A Imacron -!CF U+013B Lcommaaccent -!D0 U+0160 Scaron -!D1 U+0143 Nacute -!D2 U+0145 Ncommaaccent -!D3 U+00D3 Oacute -!D4 U+014C Omacron -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+0172 Uogonek -!D9 U+0141 Lslash -!DA U+015A Sacute -!DB U+016A Umacron -!DC U+00DC Udieresis -!DD U+017B Zdotaccent -!DE U+017D Zcaron -!DF U+00DF germandbls -!E0 U+0105 aogonek -!E1 U+012F iogonek -!E2 U+0101 amacron -!E3 U+0107 cacute -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+0119 eogonek -!E7 U+0113 emacron -!E8 U+010D ccaron -!E9 U+00E9 eacute -!EA U+017A zacute -!EB U+0117 edotaccent -!EC U+0123 gcommaaccent -!ED U+0137 kcommaaccent -!EE U+012B imacron -!EF U+013C lcommaaccent -!F0 U+0161 scaron -!F1 U+0144 nacute -!F2 U+0146 ncommaaccent -!F3 U+00F3 oacute -!F4 U+014D omacron -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+0173 uogonek -!F9 U+0142 lslash -!FA U+015B sacute -!FB U+016B umacron -!FC U+00FC udieresis -!FD U+017C zdotaccent -!FE U+017E zcaron -!FF U+02D9 dotaccent diff --git a/vendor/fpdf/makefont/cp1258.map b/vendor/fpdf/makefont/cp1258.map deleted file mode 100644 index fed915f7..00000000 --- a/vendor/fpdf/makefont/cp1258.map +++ /dev/null @@ -1,247 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!82 U+201A quotesinglbase -!83 U+0192 florin -!84 U+201E quotedblbase -!85 U+2026 ellipsis -!86 U+2020 dagger -!87 U+2021 daggerdbl -!88 U+02C6 circumflex -!89 U+2030 perthousand -!8B U+2039 guilsinglleft -!8C U+0152 OE -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!98 U+02DC tilde -!99 U+2122 trademark -!9B U+203A guilsinglright -!9C U+0153 oe -!9F U+0178 Ydieresis -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+0102 Abreve -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+0300 gravecomb -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+0110 Dcroat -!D1 U+00D1 Ntilde -!D2 U+0309 hookabovecomb -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+01A0 Ohorn -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+01AF Uhorn -!DE U+0303 tildecomb -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+0103 abreve -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+0301 acutecomb -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+0111 dcroat -!F1 U+00F1 ntilde -!F2 U+0323 dotbelowcomb -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+01A1 ohorn -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+01B0 uhorn -!FE U+20AB dong -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/cp874.map b/vendor/fpdf/makefont/cp874.map deleted file mode 100644 index 1006e6b1..00000000 --- a/vendor/fpdf/makefont/cp874.map +++ /dev/null @@ -1,225 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+20AC Euro -!85 U+2026 ellipsis -!91 U+2018 quoteleft -!92 U+2019 quoteright -!93 U+201C quotedblleft -!94 U+201D quotedblright -!95 U+2022 bullet -!96 U+2013 endash -!97 U+2014 emdash -!A0 U+00A0 space -!A1 U+0E01 kokaithai -!A2 U+0E02 khokhaithai -!A3 U+0E03 khokhuatthai -!A4 U+0E04 khokhwaithai -!A5 U+0E05 khokhonthai -!A6 U+0E06 khorakhangthai -!A7 U+0E07 ngonguthai -!A8 U+0E08 chochanthai -!A9 U+0E09 chochingthai -!AA U+0E0A chochangthai -!AB U+0E0B sosothai -!AC U+0E0C chochoethai -!AD U+0E0D yoyingthai -!AE U+0E0E dochadathai -!AF U+0E0F topatakthai -!B0 U+0E10 thothanthai -!B1 U+0E11 thonangmonthothai -!B2 U+0E12 thophuthaothai -!B3 U+0E13 nonenthai -!B4 U+0E14 dodekthai -!B5 U+0E15 totaothai -!B6 U+0E16 thothungthai -!B7 U+0E17 thothahanthai -!B8 U+0E18 thothongthai -!B9 U+0E19 nonuthai -!BA U+0E1A bobaimaithai -!BB U+0E1B poplathai -!BC U+0E1C phophungthai -!BD U+0E1D fofathai -!BE U+0E1E phophanthai -!BF U+0E1F fofanthai -!C0 U+0E20 phosamphaothai -!C1 U+0E21 momathai -!C2 U+0E22 yoyakthai -!C3 U+0E23 roruathai -!C4 U+0E24 ruthai -!C5 U+0E25 lolingthai -!C6 U+0E26 luthai -!C7 U+0E27 wowaenthai -!C8 U+0E28 sosalathai -!C9 U+0E29 sorusithai -!CA U+0E2A sosuathai -!CB U+0E2B hohipthai -!CC U+0E2C lochulathai -!CD U+0E2D oangthai -!CE U+0E2E honokhukthai -!CF U+0E2F paiyannoithai -!D0 U+0E30 saraathai -!D1 U+0E31 maihanakatthai -!D2 U+0E32 saraaathai -!D3 U+0E33 saraamthai -!D4 U+0E34 saraithai -!D5 U+0E35 saraiithai -!D6 U+0E36 sarauethai -!D7 U+0E37 saraueethai -!D8 U+0E38 sarauthai -!D9 U+0E39 sarauuthai -!DA U+0E3A phinthuthai -!DF U+0E3F bahtthai -!E0 U+0E40 saraethai -!E1 U+0E41 saraaethai -!E2 U+0E42 saraothai -!E3 U+0E43 saraaimaimuanthai -!E4 U+0E44 saraaimaimalaithai -!E5 U+0E45 lakkhangyaothai -!E6 U+0E46 maiyamokthai -!E7 U+0E47 maitaikhuthai -!E8 U+0E48 maiekthai -!E9 U+0E49 maithothai -!EA U+0E4A maitrithai -!EB U+0E4B maichattawathai -!EC U+0E4C thanthakhatthai -!ED U+0E4D nikhahitthai -!EE U+0E4E yamakkanthai -!EF U+0E4F fongmanthai -!F0 U+0E50 zerothai -!F1 U+0E51 onethai -!F2 U+0E52 twothai -!F3 U+0E53 threethai -!F4 U+0E54 fourthai -!F5 U+0E55 fivethai -!F6 U+0E56 sixthai -!F7 U+0E57 seventhai -!F8 U+0E58 eightthai -!F9 U+0E59 ninethai -!FA U+0E5A angkhankhuthai -!FB U+0E5B khomutthai diff --git a/vendor/fpdf/makefont/iso-8859-1.map b/vendor/fpdf/makefont/iso-8859-1.map deleted file mode 100644 index 61740a38..00000000 --- a/vendor/fpdf/makefont/iso-8859-1.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+00D0 Eth -!D1 U+00D1 Ntilde -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+00DD Yacute -!DE U+00DE Thorn -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+00F0 eth -!F1 U+00F1 ntilde -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+00FD yacute -!FE U+00FE thorn -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/iso-8859-11.map b/vendor/fpdf/makefont/iso-8859-11.map deleted file mode 100644 index 91688120..00000000 --- a/vendor/fpdf/makefont/iso-8859-11.map +++ /dev/null @@ -1,248 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+0E01 kokaithai -!A2 U+0E02 khokhaithai -!A3 U+0E03 khokhuatthai -!A4 U+0E04 khokhwaithai -!A5 U+0E05 khokhonthai -!A6 U+0E06 khorakhangthai -!A7 U+0E07 ngonguthai -!A8 U+0E08 chochanthai -!A9 U+0E09 chochingthai -!AA U+0E0A chochangthai -!AB U+0E0B sosothai -!AC U+0E0C chochoethai -!AD U+0E0D yoyingthai -!AE U+0E0E dochadathai -!AF U+0E0F topatakthai -!B0 U+0E10 thothanthai -!B1 U+0E11 thonangmonthothai -!B2 U+0E12 thophuthaothai -!B3 U+0E13 nonenthai -!B4 U+0E14 dodekthai -!B5 U+0E15 totaothai -!B6 U+0E16 thothungthai -!B7 U+0E17 thothahanthai -!B8 U+0E18 thothongthai -!B9 U+0E19 nonuthai -!BA U+0E1A bobaimaithai -!BB U+0E1B poplathai -!BC U+0E1C phophungthai -!BD U+0E1D fofathai -!BE U+0E1E phophanthai -!BF U+0E1F fofanthai -!C0 U+0E20 phosamphaothai -!C1 U+0E21 momathai -!C2 U+0E22 yoyakthai -!C3 U+0E23 roruathai -!C4 U+0E24 ruthai -!C5 U+0E25 lolingthai -!C6 U+0E26 luthai -!C7 U+0E27 wowaenthai -!C8 U+0E28 sosalathai -!C9 U+0E29 sorusithai -!CA U+0E2A sosuathai -!CB U+0E2B hohipthai -!CC U+0E2C lochulathai -!CD U+0E2D oangthai -!CE U+0E2E honokhukthai -!CF U+0E2F paiyannoithai -!D0 U+0E30 saraathai -!D1 U+0E31 maihanakatthai -!D2 U+0E32 saraaathai -!D3 U+0E33 saraamthai -!D4 U+0E34 saraithai -!D5 U+0E35 saraiithai -!D6 U+0E36 sarauethai -!D7 U+0E37 saraueethai -!D8 U+0E38 sarauthai -!D9 U+0E39 sarauuthai -!DA U+0E3A phinthuthai -!DF U+0E3F bahtthai -!E0 U+0E40 saraethai -!E1 U+0E41 saraaethai -!E2 U+0E42 saraothai -!E3 U+0E43 saraaimaimuanthai -!E4 U+0E44 saraaimaimalaithai -!E5 U+0E45 lakkhangyaothai -!E6 U+0E46 maiyamokthai -!E7 U+0E47 maitaikhuthai -!E8 U+0E48 maiekthai -!E9 U+0E49 maithothai -!EA U+0E4A maitrithai -!EB U+0E4B maichattawathai -!EC U+0E4C thanthakhatthai -!ED U+0E4D nikhahitthai -!EE U+0E4E yamakkanthai -!EF U+0E4F fongmanthai -!F0 U+0E50 zerothai -!F1 U+0E51 onethai -!F2 U+0E52 twothai -!F3 U+0E53 threethai -!F4 U+0E54 fourthai -!F5 U+0E55 fivethai -!F6 U+0E56 sixthai -!F7 U+0E57 seventhai -!F8 U+0E58 eightthai -!F9 U+0E59 ninethai -!FA U+0E5A angkhankhuthai -!FB U+0E5B khomutthai diff --git a/vendor/fpdf/makefont/iso-8859-15.map b/vendor/fpdf/makefont/iso-8859-15.map deleted file mode 100644 index 6c2b5712..00000000 --- a/vendor/fpdf/makefont/iso-8859-15.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+20AC Euro -!A5 U+00A5 yen -!A6 U+0160 Scaron -!A7 U+00A7 section -!A8 U+0161 scaron -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+017D Zcaron -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+017E zcaron -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+0152 OE -!BD U+0153 oe -!BE U+0178 Ydieresis -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+00D0 Eth -!D1 U+00D1 Ntilde -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+00DD Yacute -!DE U+00DE Thorn -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+00F0 eth -!F1 U+00F1 ntilde -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+00FD yacute -!FE U+00FE thorn -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/iso-8859-16.map b/vendor/fpdf/makefont/iso-8859-16.map deleted file mode 100644 index 202c8fe5..00000000 --- a/vendor/fpdf/makefont/iso-8859-16.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+0104 Aogonek -!A2 U+0105 aogonek -!A3 U+0141 Lslash -!A4 U+20AC Euro -!A5 U+201E quotedblbase -!A6 U+0160 Scaron -!A7 U+00A7 section -!A8 U+0161 scaron -!A9 U+00A9 copyright -!AA U+0218 Scommaaccent -!AB U+00AB guillemotleft -!AC U+0179 Zacute -!AD U+00AD hyphen -!AE U+017A zacute -!AF U+017B Zdotaccent -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+010C Ccaron -!B3 U+0142 lslash -!B4 U+017D Zcaron -!B5 U+201D quotedblright -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+017E zcaron -!B9 U+010D ccaron -!BA U+0219 scommaaccent -!BB U+00BB guillemotright -!BC U+0152 OE -!BD U+0153 oe -!BE U+0178 Ydieresis -!BF U+017C zdotaccent -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+0102 Abreve -!C4 U+00C4 Adieresis -!C5 U+0106 Cacute -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+0110 Dcroat -!D1 U+0143 Nacute -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+0150 Ohungarumlaut -!D6 U+00D6 Odieresis -!D7 U+015A Sacute -!D8 U+0170 Uhungarumlaut -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+0118 Eogonek -!DE U+021A Tcommaaccent -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+0103 abreve -!E4 U+00E4 adieresis -!E5 U+0107 cacute -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+0111 dcroat -!F1 U+0144 nacute -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+0151 ohungarumlaut -!F6 U+00F6 odieresis -!F7 U+015B sacute -!F8 U+0171 uhungarumlaut -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+0119 eogonek -!FE U+021B tcommaaccent -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/iso-8859-2.map b/vendor/fpdf/makefont/iso-8859-2.map deleted file mode 100644 index 65ae09f9..00000000 --- a/vendor/fpdf/makefont/iso-8859-2.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+0104 Aogonek -!A2 U+02D8 breve -!A3 U+0141 Lslash -!A4 U+00A4 currency -!A5 U+013D Lcaron -!A6 U+015A Sacute -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+0160 Scaron -!AA U+015E Scedilla -!AB U+0164 Tcaron -!AC U+0179 Zacute -!AD U+00AD hyphen -!AE U+017D Zcaron -!AF U+017B Zdotaccent -!B0 U+00B0 degree -!B1 U+0105 aogonek -!B2 U+02DB ogonek -!B3 U+0142 lslash -!B4 U+00B4 acute -!B5 U+013E lcaron -!B6 U+015B sacute -!B7 U+02C7 caron -!B8 U+00B8 cedilla -!B9 U+0161 scaron -!BA U+015F scedilla -!BB U+0165 tcaron -!BC U+017A zacute -!BD U+02DD hungarumlaut -!BE U+017E zcaron -!BF U+017C zdotaccent -!C0 U+0154 Racute -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+0102 Abreve -!C4 U+00C4 Adieresis -!C5 U+0139 Lacute -!C6 U+0106 Cacute -!C7 U+00C7 Ccedilla -!C8 U+010C Ccaron -!C9 U+00C9 Eacute -!CA U+0118 Eogonek -!CB U+00CB Edieresis -!CC U+011A Ecaron -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+010E Dcaron -!D0 U+0110 Dcroat -!D1 U+0143 Nacute -!D2 U+0147 Ncaron -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+0150 Ohungarumlaut -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+0158 Rcaron -!D9 U+016E Uring -!DA U+00DA Uacute -!DB U+0170 Uhungarumlaut -!DC U+00DC Udieresis -!DD U+00DD Yacute -!DE U+0162 Tcommaaccent -!DF U+00DF germandbls -!E0 U+0155 racute -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+0103 abreve -!E4 U+00E4 adieresis -!E5 U+013A lacute -!E6 U+0107 cacute -!E7 U+00E7 ccedilla -!E8 U+010D ccaron -!E9 U+00E9 eacute -!EA U+0119 eogonek -!EB U+00EB edieresis -!EC U+011B ecaron -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+010F dcaron -!F0 U+0111 dcroat -!F1 U+0144 nacute -!F2 U+0148 ncaron -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+0151 ohungarumlaut -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+0159 rcaron -!F9 U+016F uring -!FA U+00FA uacute -!FB U+0171 uhungarumlaut -!FC U+00FC udieresis -!FD U+00FD yacute -!FE U+0163 tcommaaccent -!FF U+02D9 dotaccent diff --git a/vendor/fpdf/makefont/iso-8859-4.map b/vendor/fpdf/makefont/iso-8859-4.map deleted file mode 100644 index a7d87bf3..00000000 --- a/vendor/fpdf/makefont/iso-8859-4.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+0104 Aogonek -!A2 U+0138 kgreenlandic -!A3 U+0156 Rcommaaccent -!A4 U+00A4 currency -!A5 U+0128 Itilde -!A6 U+013B Lcommaaccent -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+0160 Scaron -!AA U+0112 Emacron -!AB U+0122 Gcommaaccent -!AC U+0166 Tbar -!AD U+00AD hyphen -!AE U+017D Zcaron -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+0105 aogonek -!B2 U+02DB ogonek -!B3 U+0157 rcommaaccent -!B4 U+00B4 acute -!B5 U+0129 itilde -!B6 U+013C lcommaaccent -!B7 U+02C7 caron -!B8 U+00B8 cedilla -!B9 U+0161 scaron -!BA U+0113 emacron -!BB U+0123 gcommaaccent -!BC U+0167 tbar -!BD U+014A Eng -!BE U+017E zcaron -!BF U+014B eng -!C0 U+0100 Amacron -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+012E Iogonek -!C8 U+010C Ccaron -!C9 U+00C9 Eacute -!CA U+0118 Eogonek -!CB U+00CB Edieresis -!CC U+0116 Edotaccent -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+012A Imacron -!D0 U+0110 Dcroat -!D1 U+0145 Ncommaaccent -!D2 U+014C Omacron -!D3 U+0136 Kcommaaccent -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+0172 Uogonek -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+0168 Utilde -!DE U+016A Umacron -!DF U+00DF germandbls -!E0 U+0101 amacron -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+012F iogonek -!E8 U+010D ccaron -!E9 U+00E9 eacute -!EA U+0119 eogonek -!EB U+00EB edieresis -!EC U+0117 edotaccent -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+012B imacron -!F0 U+0111 dcroat -!F1 U+0146 ncommaaccent -!F2 U+014D omacron -!F3 U+0137 kcommaaccent -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+0173 uogonek -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+0169 utilde -!FE U+016B umacron -!FF U+02D9 dotaccent diff --git a/vendor/fpdf/makefont/iso-8859-5.map b/vendor/fpdf/makefont/iso-8859-5.map deleted file mode 100644 index f9cd4edc..00000000 --- a/vendor/fpdf/makefont/iso-8859-5.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+0401 afii10023 -!A2 U+0402 afii10051 -!A3 U+0403 afii10052 -!A4 U+0404 afii10053 -!A5 U+0405 afii10054 -!A6 U+0406 afii10055 -!A7 U+0407 afii10056 -!A8 U+0408 afii10057 -!A9 U+0409 afii10058 -!AA U+040A afii10059 -!AB U+040B afii10060 -!AC U+040C afii10061 -!AD U+00AD hyphen -!AE U+040E afii10062 -!AF U+040F afii10145 -!B0 U+0410 afii10017 -!B1 U+0411 afii10018 -!B2 U+0412 afii10019 -!B3 U+0413 afii10020 -!B4 U+0414 afii10021 -!B5 U+0415 afii10022 -!B6 U+0416 afii10024 -!B7 U+0417 afii10025 -!B8 U+0418 afii10026 -!B9 U+0419 afii10027 -!BA U+041A afii10028 -!BB U+041B afii10029 -!BC U+041C afii10030 -!BD U+041D afii10031 -!BE U+041E afii10032 -!BF U+041F afii10033 -!C0 U+0420 afii10034 -!C1 U+0421 afii10035 -!C2 U+0422 afii10036 -!C3 U+0423 afii10037 -!C4 U+0424 afii10038 -!C5 U+0425 afii10039 -!C6 U+0426 afii10040 -!C7 U+0427 afii10041 -!C8 U+0428 afii10042 -!C9 U+0429 afii10043 -!CA U+042A afii10044 -!CB U+042B afii10045 -!CC U+042C afii10046 -!CD U+042D afii10047 -!CE U+042E afii10048 -!CF U+042F afii10049 -!D0 U+0430 afii10065 -!D1 U+0431 afii10066 -!D2 U+0432 afii10067 -!D3 U+0433 afii10068 -!D4 U+0434 afii10069 -!D5 U+0435 afii10070 -!D6 U+0436 afii10072 -!D7 U+0437 afii10073 -!D8 U+0438 afii10074 -!D9 U+0439 afii10075 -!DA U+043A afii10076 -!DB U+043B afii10077 -!DC U+043C afii10078 -!DD U+043D afii10079 -!DE U+043E afii10080 -!DF U+043F afii10081 -!E0 U+0440 afii10082 -!E1 U+0441 afii10083 -!E2 U+0442 afii10084 -!E3 U+0443 afii10085 -!E4 U+0444 afii10086 -!E5 U+0445 afii10087 -!E6 U+0446 afii10088 -!E7 U+0447 afii10089 -!E8 U+0448 afii10090 -!E9 U+0449 afii10091 -!EA U+044A afii10092 -!EB U+044B afii10093 -!EC U+044C afii10094 -!ED U+044D afii10095 -!EE U+044E afii10096 -!EF U+044F afii10097 -!F0 U+2116 afii61352 -!F1 U+0451 afii10071 -!F2 U+0452 afii10099 -!F3 U+0453 afii10100 -!F4 U+0454 afii10101 -!F5 U+0455 afii10102 -!F6 U+0456 afii10103 -!F7 U+0457 afii10104 -!F8 U+0458 afii10105 -!F9 U+0459 afii10106 -!FA U+045A afii10107 -!FB U+045B afii10108 -!FC U+045C afii10109 -!FD U+00A7 section -!FE U+045E afii10110 -!FF U+045F afii10193 diff --git a/vendor/fpdf/makefont/iso-8859-7.map b/vendor/fpdf/makefont/iso-8859-7.map deleted file mode 100644 index e163796b..00000000 --- a/vendor/fpdf/makefont/iso-8859-7.map +++ /dev/null @@ -1,250 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+2018 quoteleft -!A2 U+2019 quoteright -!A3 U+00A3 sterling -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AF U+2015 afii00208 -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+0384 tonos -!B5 U+0385 dieresistonos -!B6 U+0386 Alphatonos -!B7 U+00B7 periodcentered -!B8 U+0388 Epsilontonos -!B9 U+0389 Etatonos -!BA U+038A Iotatonos -!BB U+00BB guillemotright -!BC U+038C Omicrontonos -!BD U+00BD onehalf -!BE U+038E Upsilontonos -!BF U+038F Omegatonos -!C0 U+0390 iotadieresistonos -!C1 U+0391 Alpha -!C2 U+0392 Beta -!C3 U+0393 Gamma -!C4 U+0394 Delta -!C5 U+0395 Epsilon -!C6 U+0396 Zeta -!C7 U+0397 Eta -!C8 U+0398 Theta -!C9 U+0399 Iota -!CA U+039A Kappa -!CB U+039B Lambda -!CC U+039C Mu -!CD U+039D Nu -!CE U+039E Xi -!CF U+039F Omicron -!D0 U+03A0 Pi -!D1 U+03A1 Rho -!D3 U+03A3 Sigma -!D4 U+03A4 Tau -!D5 U+03A5 Upsilon -!D6 U+03A6 Phi -!D7 U+03A7 Chi -!D8 U+03A8 Psi -!D9 U+03A9 Omega -!DA U+03AA Iotadieresis -!DB U+03AB Upsilondieresis -!DC U+03AC alphatonos -!DD U+03AD epsilontonos -!DE U+03AE etatonos -!DF U+03AF iotatonos -!E0 U+03B0 upsilondieresistonos -!E1 U+03B1 alpha -!E2 U+03B2 beta -!E3 U+03B3 gamma -!E4 U+03B4 delta -!E5 U+03B5 epsilon -!E6 U+03B6 zeta -!E7 U+03B7 eta -!E8 U+03B8 theta -!E9 U+03B9 iota -!EA U+03BA kappa -!EB U+03BB lambda -!EC U+03BC mu -!ED U+03BD nu -!EE U+03BE xi -!EF U+03BF omicron -!F0 U+03C0 pi -!F1 U+03C1 rho -!F2 U+03C2 sigma1 -!F3 U+03C3 sigma -!F4 U+03C4 tau -!F5 U+03C5 upsilon -!F6 U+03C6 phi -!F7 U+03C7 chi -!F8 U+03C8 psi -!F9 U+03C9 omega -!FA U+03CA iotadieresis -!FB U+03CB upsilondieresis -!FC U+03CC omicrontonos -!FD U+03CD upsilontonos -!FE U+03CE omegatonos diff --git a/vendor/fpdf/makefont/iso-8859-9.map b/vendor/fpdf/makefont/iso-8859-9.map deleted file mode 100644 index 48c123ae..00000000 --- a/vendor/fpdf/makefont/iso-8859-9.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+0080 .notdef -!81 U+0081 .notdef -!82 U+0082 .notdef -!83 U+0083 .notdef -!84 U+0084 .notdef -!85 U+0085 .notdef -!86 U+0086 .notdef -!87 U+0087 .notdef -!88 U+0088 .notdef -!89 U+0089 .notdef -!8A U+008A .notdef -!8B U+008B .notdef -!8C U+008C .notdef -!8D U+008D .notdef -!8E U+008E .notdef -!8F U+008F .notdef -!90 U+0090 .notdef -!91 U+0091 .notdef -!92 U+0092 .notdef -!93 U+0093 .notdef -!94 U+0094 .notdef -!95 U+0095 .notdef -!96 U+0096 .notdef -!97 U+0097 .notdef -!98 U+0098 .notdef -!99 U+0099 .notdef -!9A U+009A .notdef -!9B U+009B .notdef -!9C U+009C .notdef -!9D U+009D .notdef -!9E U+009E .notdef -!9F U+009F .notdef -!A0 U+00A0 space -!A1 U+00A1 exclamdown -!A2 U+00A2 cent -!A3 U+00A3 sterling -!A4 U+00A4 currency -!A5 U+00A5 yen -!A6 U+00A6 brokenbar -!A7 U+00A7 section -!A8 U+00A8 dieresis -!A9 U+00A9 copyright -!AA U+00AA ordfeminine -!AB U+00AB guillemotleft -!AC U+00AC logicalnot -!AD U+00AD hyphen -!AE U+00AE registered -!AF U+00AF macron -!B0 U+00B0 degree -!B1 U+00B1 plusminus -!B2 U+00B2 twosuperior -!B3 U+00B3 threesuperior -!B4 U+00B4 acute -!B5 U+00B5 mu -!B6 U+00B6 paragraph -!B7 U+00B7 periodcentered -!B8 U+00B8 cedilla -!B9 U+00B9 onesuperior -!BA U+00BA ordmasculine -!BB U+00BB guillemotright -!BC U+00BC onequarter -!BD U+00BD onehalf -!BE U+00BE threequarters -!BF U+00BF questiondown -!C0 U+00C0 Agrave -!C1 U+00C1 Aacute -!C2 U+00C2 Acircumflex -!C3 U+00C3 Atilde -!C4 U+00C4 Adieresis -!C5 U+00C5 Aring -!C6 U+00C6 AE -!C7 U+00C7 Ccedilla -!C8 U+00C8 Egrave -!C9 U+00C9 Eacute -!CA U+00CA Ecircumflex -!CB U+00CB Edieresis -!CC U+00CC Igrave -!CD U+00CD Iacute -!CE U+00CE Icircumflex -!CF U+00CF Idieresis -!D0 U+011E Gbreve -!D1 U+00D1 Ntilde -!D2 U+00D2 Ograve -!D3 U+00D3 Oacute -!D4 U+00D4 Ocircumflex -!D5 U+00D5 Otilde -!D6 U+00D6 Odieresis -!D7 U+00D7 multiply -!D8 U+00D8 Oslash -!D9 U+00D9 Ugrave -!DA U+00DA Uacute -!DB U+00DB Ucircumflex -!DC U+00DC Udieresis -!DD U+0130 Idotaccent -!DE U+015E Scedilla -!DF U+00DF germandbls -!E0 U+00E0 agrave -!E1 U+00E1 aacute -!E2 U+00E2 acircumflex -!E3 U+00E3 atilde -!E4 U+00E4 adieresis -!E5 U+00E5 aring -!E6 U+00E6 ae -!E7 U+00E7 ccedilla -!E8 U+00E8 egrave -!E9 U+00E9 eacute -!EA U+00EA ecircumflex -!EB U+00EB edieresis -!EC U+00EC igrave -!ED U+00ED iacute -!EE U+00EE icircumflex -!EF U+00EF idieresis -!F0 U+011F gbreve -!F1 U+00F1 ntilde -!F2 U+00F2 ograve -!F3 U+00F3 oacute -!F4 U+00F4 ocircumflex -!F5 U+00F5 otilde -!F6 U+00F6 odieresis -!F7 U+00F7 divide -!F8 U+00F8 oslash -!F9 U+00F9 ugrave -!FA U+00FA uacute -!FB U+00FB ucircumflex -!FC U+00FC udieresis -!FD U+0131 dotlessi -!FE U+015F scedilla -!FF U+00FF ydieresis diff --git a/vendor/fpdf/makefont/koi8-r.map b/vendor/fpdf/makefont/koi8-r.map deleted file mode 100644 index 6ad5d05d..00000000 --- a/vendor/fpdf/makefont/koi8-r.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+2500 SF100000 -!81 U+2502 SF110000 -!82 U+250C SF010000 -!83 U+2510 SF030000 -!84 U+2514 SF020000 -!85 U+2518 SF040000 -!86 U+251C SF080000 -!87 U+2524 SF090000 -!88 U+252C SF060000 -!89 U+2534 SF070000 -!8A U+253C SF050000 -!8B U+2580 upblock -!8C U+2584 dnblock -!8D U+2588 block -!8E U+258C lfblock -!8F U+2590 rtblock -!90 U+2591 ltshade -!91 U+2592 shade -!92 U+2593 dkshade -!93 U+2320 integraltp -!94 U+25A0 filledbox -!95 U+2219 periodcentered -!96 U+221A radical -!97 U+2248 approxequal -!98 U+2264 lessequal -!99 U+2265 greaterequal -!9A U+00A0 space -!9B U+2321 integralbt -!9C U+00B0 degree -!9D U+00B2 twosuperior -!9E U+00B7 periodcentered -!9F U+00F7 divide -!A0 U+2550 SF430000 -!A1 U+2551 SF240000 -!A2 U+2552 SF510000 -!A3 U+0451 afii10071 -!A4 U+2553 SF520000 -!A5 U+2554 SF390000 -!A6 U+2555 SF220000 -!A7 U+2556 SF210000 -!A8 U+2557 SF250000 -!A9 U+2558 SF500000 -!AA U+2559 SF490000 -!AB U+255A SF380000 -!AC U+255B SF280000 -!AD U+255C SF270000 -!AE U+255D SF260000 -!AF U+255E SF360000 -!B0 U+255F SF370000 -!B1 U+2560 SF420000 -!B2 U+2561 SF190000 -!B3 U+0401 afii10023 -!B4 U+2562 SF200000 -!B5 U+2563 SF230000 -!B6 U+2564 SF470000 -!B7 U+2565 SF480000 -!B8 U+2566 SF410000 -!B9 U+2567 SF450000 -!BA U+2568 SF460000 -!BB U+2569 SF400000 -!BC U+256A SF540000 -!BD U+256B SF530000 -!BE U+256C SF440000 -!BF U+00A9 copyright -!C0 U+044E afii10096 -!C1 U+0430 afii10065 -!C2 U+0431 afii10066 -!C3 U+0446 afii10088 -!C4 U+0434 afii10069 -!C5 U+0435 afii10070 -!C6 U+0444 afii10086 -!C7 U+0433 afii10068 -!C8 U+0445 afii10087 -!C9 U+0438 afii10074 -!CA U+0439 afii10075 -!CB U+043A afii10076 -!CC U+043B afii10077 -!CD U+043C afii10078 -!CE U+043D afii10079 -!CF U+043E afii10080 -!D0 U+043F afii10081 -!D1 U+044F afii10097 -!D2 U+0440 afii10082 -!D3 U+0441 afii10083 -!D4 U+0442 afii10084 -!D5 U+0443 afii10085 -!D6 U+0436 afii10072 -!D7 U+0432 afii10067 -!D8 U+044C afii10094 -!D9 U+044B afii10093 -!DA U+0437 afii10073 -!DB U+0448 afii10090 -!DC U+044D afii10095 -!DD U+0449 afii10091 -!DE U+0447 afii10089 -!DF U+044A afii10092 -!E0 U+042E afii10048 -!E1 U+0410 afii10017 -!E2 U+0411 afii10018 -!E3 U+0426 afii10040 -!E4 U+0414 afii10021 -!E5 U+0415 afii10022 -!E6 U+0424 afii10038 -!E7 U+0413 afii10020 -!E8 U+0425 afii10039 -!E9 U+0418 afii10026 -!EA U+0419 afii10027 -!EB U+041A afii10028 -!EC U+041B afii10029 -!ED U+041C afii10030 -!EE U+041D afii10031 -!EF U+041E afii10032 -!F0 U+041F afii10033 -!F1 U+042F afii10049 -!F2 U+0420 afii10034 -!F3 U+0421 afii10035 -!F4 U+0422 afii10036 -!F5 U+0423 afii10037 -!F6 U+0416 afii10024 -!F7 U+0412 afii10019 -!F8 U+042C afii10046 -!F9 U+042B afii10045 -!FA U+0417 afii10025 -!FB U+0428 afii10042 -!FC U+042D afii10047 -!FD U+0429 afii10043 -!FE U+0427 afii10041 -!FF U+042A afii10044 diff --git a/vendor/fpdf/makefont/koi8-u.map b/vendor/fpdf/makefont/koi8-u.map deleted file mode 100644 index 40a7e4fd..00000000 --- a/vendor/fpdf/makefont/koi8-u.map +++ /dev/null @@ -1,256 +0,0 @@ -!00 U+0000 .notdef -!01 U+0001 .notdef -!02 U+0002 .notdef -!03 U+0003 .notdef -!04 U+0004 .notdef -!05 U+0005 .notdef -!06 U+0006 .notdef -!07 U+0007 .notdef -!08 U+0008 .notdef -!09 U+0009 .notdef -!0A U+000A .notdef -!0B U+000B .notdef -!0C U+000C .notdef -!0D U+000D .notdef -!0E U+000E .notdef -!0F U+000F .notdef -!10 U+0010 .notdef -!11 U+0011 .notdef -!12 U+0012 .notdef -!13 U+0013 .notdef -!14 U+0014 .notdef -!15 U+0015 .notdef -!16 U+0016 .notdef -!17 U+0017 .notdef -!18 U+0018 .notdef -!19 U+0019 .notdef -!1A U+001A .notdef -!1B U+001B .notdef -!1C U+001C .notdef -!1D U+001D .notdef -!1E U+001E .notdef -!1F U+001F .notdef -!20 U+0020 space -!21 U+0021 exclam -!22 U+0022 quotedbl -!23 U+0023 numbersign -!24 U+0024 dollar -!25 U+0025 percent -!26 U+0026 ampersand -!27 U+0027 quotesingle -!28 U+0028 parenleft -!29 U+0029 parenright -!2A U+002A asterisk -!2B U+002B plus -!2C U+002C comma -!2D U+002D hyphen -!2E U+002E period -!2F U+002F slash -!30 U+0030 zero -!31 U+0031 one -!32 U+0032 two -!33 U+0033 three -!34 U+0034 four -!35 U+0035 five -!36 U+0036 six -!37 U+0037 seven -!38 U+0038 eight -!39 U+0039 nine -!3A U+003A colon -!3B U+003B semicolon -!3C U+003C less -!3D U+003D equal -!3E U+003E greater -!3F U+003F question -!40 U+0040 at -!41 U+0041 A -!42 U+0042 B -!43 U+0043 C -!44 U+0044 D -!45 U+0045 E -!46 U+0046 F -!47 U+0047 G -!48 U+0048 H -!49 U+0049 I -!4A U+004A J -!4B U+004B K -!4C U+004C L -!4D U+004D M -!4E U+004E N -!4F U+004F O -!50 U+0050 P -!51 U+0051 Q -!52 U+0052 R -!53 U+0053 S -!54 U+0054 T -!55 U+0055 U -!56 U+0056 V -!57 U+0057 W -!58 U+0058 X -!59 U+0059 Y -!5A U+005A Z -!5B U+005B bracketleft -!5C U+005C backslash -!5D U+005D bracketright -!5E U+005E asciicircum -!5F U+005F underscore -!60 U+0060 grave -!61 U+0061 a -!62 U+0062 b -!63 U+0063 c -!64 U+0064 d -!65 U+0065 e -!66 U+0066 f -!67 U+0067 g -!68 U+0068 h -!69 U+0069 i -!6A U+006A j -!6B U+006B k -!6C U+006C l -!6D U+006D m -!6E U+006E n -!6F U+006F o -!70 U+0070 p -!71 U+0071 q -!72 U+0072 r -!73 U+0073 s -!74 U+0074 t -!75 U+0075 u -!76 U+0076 v -!77 U+0077 w -!78 U+0078 x -!79 U+0079 y -!7A U+007A z -!7B U+007B braceleft -!7C U+007C bar -!7D U+007D braceright -!7E U+007E asciitilde -!7F U+007F .notdef -!80 U+2500 SF100000 -!81 U+2502 SF110000 -!82 U+250C SF010000 -!83 U+2510 SF030000 -!84 U+2514 SF020000 -!85 U+2518 SF040000 -!86 U+251C SF080000 -!87 U+2524 SF090000 -!88 U+252C SF060000 -!89 U+2534 SF070000 -!8A U+253C SF050000 -!8B U+2580 upblock -!8C U+2584 dnblock -!8D U+2588 block -!8E U+258C lfblock -!8F U+2590 rtblock -!90 U+2591 ltshade -!91 U+2592 shade -!92 U+2593 dkshade -!93 U+2320 integraltp -!94 U+25A0 filledbox -!95 U+2022 bullet -!96 U+221A radical -!97 U+2248 approxequal -!98 U+2264 lessequal -!99 U+2265 greaterequal -!9A U+00A0 space -!9B U+2321 integralbt -!9C U+00B0 degree -!9D U+00B2 twosuperior -!9E U+00B7 periodcentered -!9F U+00F7 divide -!A0 U+2550 SF430000 -!A1 U+2551 SF240000 -!A2 U+2552 SF510000 -!A3 U+0451 afii10071 -!A4 U+0454 afii10101 -!A5 U+2554 SF390000 -!A6 U+0456 afii10103 -!A7 U+0457 afii10104 -!A8 U+2557 SF250000 -!A9 U+2558 SF500000 -!AA U+2559 SF490000 -!AB U+255A SF380000 -!AC U+255B SF280000 -!AD U+0491 afii10098 -!AE U+255D SF260000 -!AF U+255E SF360000 -!B0 U+255F SF370000 -!B1 U+2560 SF420000 -!B2 U+2561 SF190000 -!B3 U+0401 afii10023 -!B4 U+0404 afii10053 -!B5 U+2563 SF230000 -!B6 U+0406 afii10055 -!B7 U+0407 afii10056 -!B8 U+2566 SF410000 -!B9 U+2567 SF450000 -!BA U+2568 SF460000 -!BB U+2569 SF400000 -!BC U+256A SF540000 -!BD U+0490 afii10050 -!BE U+256C SF440000 -!BF U+00A9 copyright -!C0 U+044E afii10096 -!C1 U+0430 afii10065 -!C2 U+0431 afii10066 -!C3 U+0446 afii10088 -!C4 U+0434 afii10069 -!C5 U+0435 afii10070 -!C6 U+0444 afii10086 -!C7 U+0433 afii10068 -!C8 U+0445 afii10087 -!C9 U+0438 afii10074 -!CA U+0439 afii10075 -!CB U+043A afii10076 -!CC U+043B afii10077 -!CD U+043C afii10078 -!CE U+043D afii10079 -!CF U+043E afii10080 -!D0 U+043F afii10081 -!D1 U+044F afii10097 -!D2 U+0440 afii10082 -!D3 U+0441 afii10083 -!D4 U+0442 afii10084 -!D5 U+0443 afii10085 -!D6 U+0436 afii10072 -!D7 U+0432 afii10067 -!D8 U+044C afii10094 -!D9 U+044B afii10093 -!DA U+0437 afii10073 -!DB U+0448 afii10090 -!DC U+044D afii10095 -!DD U+0449 afii10091 -!DE U+0447 afii10089 -!DF U+044A afii10092 -!E0 U+042E afii10048 -!E1 U+0410 afii10017 -!E2 U+0411 afii10018 -!E3 U+0426 afii10040 -!E4 U+0414 afii10021 -!E5 U+0415 afii10022 -!E6 U+0424 afii10038 -!E7 U+0413 afii10020 -!E8 U+0425 afii10039 -!E9 U+0418 afii10026 -!EA U+0419 afii10027 -!EB U+041A afii10028 -!EC U+041B afii10029 -!ED U+041C afii10030 -!EE U+041D afii10031 -!EF U+041E afii10032 -!F0 U+041F afii10033 -!F1 U+042F afii10049 -!F2 U+0420 afii10034 -!F3 U+0421 afii10035 -!F4 U+0422 afii10036 -!F5 U+0423 afii10037 -!F6 U+0416 afii10024 -!F7 U+0412 afii10019 -!F8 U+042C afii10046 -!F9 U+042B afii10045 -!FA U+0417 afii10025 -!FB U+0428 afii10042 -!FC U+042D afii10047 -!FD U+0429 afii10043 -!FE U+0427 afii10041 -!FF U+042A afii10044 diff --git a/vendor/fpdf/makefont/makefont.php b/vendor/fpdf/makefont/makefont.php deleted file mode 100644 index eb92a260..00000000 --- a/vendor/fpdf/makefont/makefont.php +++ /dev/null @@ -1,373 +0,0 @@ -$severity
: "; - echo "$txt
"; - } -} - -function Notice($txt) -{ - Message($txt, 'Notice'); -} - -function Warning($txt) -{ - Message($txt, 'Warning'); -} - -function Error($txt) -{ - Message($txt, 'Error'); - exit; -} - -function LoadMap($enc) -{ - $file = dirname(__FILE__).'/'.strtolower($enc).'.map'; - $a = file($file); - if(empty($a)) - Error('Encoding not found: '.$enc); - $map = array_fill(0, 256, array('uv'=>-1, 'name'=>'.notdef')); - foreach($a as $line) - { - $e = explode(' ', rtrim($line)); - $c = hexdec(substr($e[0],1)); - $uv = hexdec(substr($e[1],2)); - $name = $e[2]; - $map[$c] = array('uv'=>$uv, 'name'=>$name); - } - return $map; -} - -function GetInfoFromTrueType($file, $embed, $map) -{ - // Return informations from a TrueType font - $ttf = new TTFParser(); - $ttf->Parse($file); - if($embed) - { - if(!$ttf->Embeddable) - Error('Font license does not allow embedding'); - $info['Data'] = file_get_contents($file); - $info['OriginalSize'] = filesize($file); - } - $k = 1000/$ttf->unitsPerEm; - $info['FontName'] = $ttf->postScriptName; - $info['Bold'] = $ttf->Bold; - $info['ItalicAngle'] = $ttf->italicAngle; - $info['IsFixedPitch'] = $ttf->isFixedPitch; - $info['Ascender'] = round($k*$ttf->typoAscender); - $info['Descender'] = round($k*$ttf->typoDescender); - $info['UnderlineThickness'] = round($k*$ttf->underlineThickness); - $info['UnderlinePosition'] = round($k*$ttf->underlinePosition); - $info['FontBBox'] = array(round($k*$ttf->xMin), round($k*$ttf->yMin), round($k*$ttf->xMax), round($k*$ttf->yMax)); - $info['CapHeight'] = round($k*$ttf->capHeight); - $info['MissingWidth'] = round($k*$ttf->widths[0]); - $widths = array_fill(0, 256, $info['MissingWidth']); - for($c=0;$c<=255;$c++) - { - if($map[$c]['name']!='.notdef') - { - $uv = $map[$c]['uv']; - if(isset($ttf->chars[$uv])) - { - $w = $ttf->widths[$ttf->chars[$uv]]; - $widths[$c] = round($k*$w); - } - else - Warning('Character '.$map[$c]['name'].' is missing'); - } - } - $info['Widths'] = $widths; - return $info; -} - -function GetInfoFromType1($file, $embed, $map) -{ - // Return informations from a Type1 font - if($embed) - { - $f = fopen($file, 'rb'); - if(!$f) - Error('Can\'t open font file'); - // Read first segment - $a = unpack('Cmarker/Ctype/Vsize', fread($f,6)); - if($a['marker']!=128) - Error('Font file is not a valid binary Type1'); - $size1 = $a['size']; - $data = fread($f, $size1); - // Read second segment - $a = unpack('Cmarker/Ctype/Vsize', fread($f,6)); - if($a['marker']!=128) - Error('Font file is not a valid binary Type1'); - $size2 = $a['size']; - $data .= fread($f, $size2); - fclose($f); - $info['Data'] = $data; - $info['Size1'] = $size1; - $info['Size2'] = $size2; - } - - $afm = substr($file, 0, -3).'afm'; - if(!file_exists($afm)) - Error('AFM font file not found: '.$afm); - $a = file($afm); - if(empty($a)) - Error('AFM file empty or not readable'); - foreach($a as $line) - { - $e = explode(' ', rtrim($line)); - if(count($e)<2) - continue; - $entry = $e[0]; - if($entry=='C') - { - $w = $e[4]; - $name = $e[7]; - $cw[$name] = $w; - } - elseif($entry=='FontName') - $info['FontName'] = $e[1]; - elseif($entry=='Weight') - $info['Weight'] = $e[1]; - elseif($entry=='ItalicAngle') - $info['ItalicAngle'] = (int)$e[1]; - elseif($entry=='Ascender') - $info['Ascender'] = (int)$e[1]; - elseif($entry=='Descender') - $info['Descender'] = (int)$e[1]; - elseif($entry=='UnderlineThickness') - $info['UnderlineThickness'] = (int)$e[1]; - elseif($entry=='UnderlinePosition') - $info['UnderlinePosition'] = (int)$e[1]; - elseif($entry=='IsFixedPitch') - $info['IsFixedPitch'] = ($e[1]=='true'); - elseif($entry=='FontBBox') - $info['FontBBox'] = array((int)$e[1], (int)$e[2], (int)$e[3], (int)$e[4]); - elseif($entry=='CapHeight') - $info['CapHeight'] = (int)$e[1]; - elseif($entry=='StdVW') - $info['StdVW'] = (int)$e[1]; - } - - if(!isset($info['FontName'])) - Error('FontName missing in AFM file'); - $info['Bold'] = isset($info['Weight']) && preg_match('/bold|black/i', $info['Weight']); - if(isset($cw['.notdef'])) - $info['MissingWidth'] = $cw['.notdef']; - else - $info['MissingWidth'] = 0; - $widths = array_fill(0, 256, $info['MissingWidth']); - for($c=0;$c<=255;$c++) - { - $name = $map[$c]['name']; - if($name!='.notdef') - { - if(isset($cw[$name])) - $widths[$c] = $cw[$name]; - else - Warning('Character '.$name.' is missing'); - } - } - $info['Widths'] = $widths; - return $info; -} - -function MakeFontDescriptor($info) -{ - // Ascent - $fd = "array('Ascent'=>".$info['Ascender']; - // Descent - $fd .= ",'Descent'=>".$info['Descender']; - // CapHeight - if(!empty($info['CapHeight'])) - $fd .= ",'CapHeight'=>".$info['CapHeight']; - else - $fd .= ",'CapHeight'=>".$info['Ascender']; - // Flags - $flags = 0; - if($info['IsFixedPitch']) - $flags += 1<<0; - $flags += 1<<5; - if($info['ItalicAngle']!=0) - $flags += 1<<6; - $fd .= ",'Flags'=>".$flags; - // FontBBox - $fbb = $info['FontBBox']; - $fd .= ",'FontBBox'=>'[".$fbb[0].' '.$fbb[1].' '.$fbb[2].' '.$fbb[3]."]'"; - // ItalicAngle - $fd .= ",'ItalicAngle'=>".$info['ItalicAngle']; - // StemV - if(isset($info['StdVW'])) - $stemv = $info['StdVW']; - elseif($info['Bold']) - $stemv = 120; - else - $stemv = 70; - $fd .= ",'StemV'=>".$stemv; - // MissingWidth - $fd .= ",'MissingWidth'=>".$info['MissingWidth'].')'; - return $fd; -} - -function MakeWidthArray($widths) -{ - $s = "array(\n\t"; - for($c=0;$c<=255;$c++) - { - if(chr($c)=="'") - $s .= "'\\''"; - elseif(chr($c)=="\\") - $s .= "'\\\\'"; - elseif($c>=32 && $c<=126) - $s .= "'".chr($c)."'"; - else - $s .= "chr($c)"; - $s .= '=>'.$widths[$c]; - if($c<255) - $s .= ','; - if(($c+1)%22==0) - $s .= "\n\t"; - } - $s .= ')'; - return $s; -} - -function MakeFontEncoding($map) -{ - // Build differences from reference encoding - $ref = LoadMap('cp1252'); - $s = ''; - $last = 0; - for($c=32;$c<=255;$c++) - { - if($map[$c]['name']!=$ref[$c]['name']) - { - if($c!=$last+1) - $s .= $c.' '; - $last = $c; - $s .= '/'.$map[$c]['name'].' '; - } - } - return rtrim($s); -} - -function SaveToFile($file, $s, $mode) -{ - $f = fopen($file, 'w'.$mode); - if(!$f) - Error('Can\'t write to file '.$file); - fwrite($f, $s, strlen($s)); - fclose($f); -} - -function MakeDefinitionFile($file, $type, $enc, $embed, $map, $info) -{ - $s = "\n"; - SaveToFile($file, $s, 't'); -} - -function MakeFont($fontfile, $enc='cp1252', $embed=true) -{ - // Generate a font definition file - if(get_magic_quotes_runtime()) - @set_magic_quotes_runtime(0); - ini_set('auto_detect_line_endings', '1'); - - if(!file_exists($fontfile)) - Error('Font file not found: '.$fontfile); - $ext = strtolower(substr($fontfile,-3)); - if($ext=='ttf' || $ext=='otf') - $type = 'TrueType'; - elseif($ext=='pfb') - $type = 'Type1'; - else - Error('Unrecognized font file extension: '.$ext); - - $map = LoadMap($enc); - - if($type=='TrueType') - $info = GetInfoFromTrueType($fontfile, $embed, $map); - else - $info = GetInfoFromType1($fontfile, $embed, $map); - - $basename = substr(basename($fontfile), 0, -4); - if($embed) - { - if(function_exists('gzcompress')) - { - $file = $basename.'.z'; - SaveToFile($file, gzcompress($info['Data']), 'b'); - $info['File'] = $file; - Message('Font file compressed: '.$file); - } - else - { - $info['File'] = basename($fontfile); - Notice('Font file could not be compressed (zlib extension not available)'); - } - } - - MakeDefinitionFile($basename.'.php', $type, $enc, $embed, $map, $info); - Message('Font definition file generated: '.$basename.'.php'); -} - -if(PHP_SAPI=='cli') -{ - // Command-line interface - if($argc==1) - die("Usage: php makefont.php fontfile [enc] [embed]\n"); - $fontfile = $argv[1]; - if($argc>=3) - $enc = $argv[2]; - else - $enc = 'cp1252'; - if($argc>=4) - $embed = ($argv[3]=='true' || $argv[3]=='1'); - else - $embed = true; - MakeFont($fontfile, $enc, $embed); -} -?> diff --git a/vendor/fpdf/makefont/ttfparser.php b/vendor/fpdf/makefont/ttfparser.php deleted file mode 100644 index 24177814..00000000 --- a/vendor/fpdf/makefont/ttfparser.php +++ /dev/null @@ -1,289 +0,0 @@ -f = fopen($file, 'rb'); - if(!$this->f) - $this->Error('Can\'t open file: '.$file); - - $version = $this->Read(4); - if($version=='OTTO') - $this->Error('OpenType fonts based on PostScript outlines are not supported'); - if($version!="\x00\x01\x00\x00") - $this->Error('Unrecognized file format'); - $numTables = $this->ReadUShort(); - $this->Skip(3*2); // searchRange, entrySelector, rangeShift - $this->tables = array(); - for($i=0;$i<$numTables;$i++) - { - $tag = $this->Read(4); - $this->Skip(4); // checkSum - $offset = $this->ReadULong(); - $this->Skip(4); // length - $this->tables[$tag] = $offset; - } - - $this->ParseHead(); - $this->ParseHhea(); - $this->ParseMaxp(); - $this->ParseHmtx(); - $this->ParseCmap(); - $this->ParseName(); - $this->ParseOS2(); - $this->ParsePost(); - - fclose($this->f); - } - - function ParseHead() - { - $this->Seek('head'); - $this->Skip(3*4); // version, fontRevision, checkSumAdjustment - $magicNumber = $this->ReadULong(); - if($magicNumber!=0x5F0F3CF5) - $this->Error('Incorrect magic number'); - $this->Skip(2); // flags - $this->unitsPerEm = $this->ReadUShort(); - $this->Skip(2*8); // created, modified - $this->xMin = $this->ReadShort(); - $this->yMin = $this->ReadShort(); - $this->xMax = $this->ReadShort(); - $this->yMax = $this->ReadShort(); - } - - function ParseHhea() - { - $this->Seek('hhea'); - $this->Skip(4+15*2); - $this->numberOfHMetrics = $this->ReadUShort(); - } - - function ParseMaxp() - { - $this->Seek('maxp'); - $this->Skip(4); - $this->numGlyphs = $this->ReadUShort(); - } - - function ParseHmtx() - { - $this->Seek('hmtx'); - $this->widths = array(); - for($i=0;$i<$this->numberOfHMetrics;$i++) - { - $advanceWidth = $this->ReadUShort(); - $this->Skip(2); // lsb - $this->widths[$i] = $advanceWidth; - } - if($this->numberOfHMetrics<$this->numGlyphs) - { - $lastWidth = $this->widths[$this->numberOfHMetrics-1]; - $this->widths = array_pad($this->widths, $this->numGlyphs, $lastWidth); - } - } - - function ParseCmap() - { - $this->Seek('cmap'); - $this->Skip(2); // version - $numTables = $this->ReadUShort(); - $offset31 = 0; - for($i=0;$i<$numTables;$i++) - { - $platformID = $this->ReadUShort(); - $encodingID = $this->ReadUShort(); - $offset = $this->ReadULong(); - if($platformID==3 && $encodingID==1) - $offset31 = $offset; - } - if($offset31==0) - $this->Error('No Unicode encoding found'); - - $startCount = array(); - $endCount = array(); - $idDelta = array(); - $idRangeOffset = array(); - $this->chars = array(); - fseek($this->f, $this->tables['cmap']+$offset31, SEEK_SET); - $format = $this->ReadUShort(); - if($format!=4) - $this->Error('Unexpected subtable format: '.$format); - $this->Skip(2*2); // length, language - $segCount = $this->ReadUShort()/2; - $this->Skip(3*2); // searchRange, entrySelector, rangeShift - for($i=0;$i<$segCount;$i++) - $endCount[$i] = $this->ReadUShort(); - $this->Skip(2); // reservedPad - for($i=0;$i<$segCount;$i++) - $startCount[$i] = $this->ReadUShort(); - for($i=0;$i<$segCount;$i++) - $idDelta[$i] = $this->ReadShort(); - $offset = ftell($this->f); - for($i=0;$i<$segCount;$i++) - $idRangeOffset[$i] = $this->ReadUShort(); - - for($i=0;$i<$segCount;$i++) - { - $c1 = $startCount[$i]; - $c2 = $endCount[$i]; - $d = $idDelta[$i]; - $ro = $idRangeOffset[$i]; - if($ro>0) - fseek($this->f, $offset+2*$i+$ro, SEEK_SET); - for($c=$c1;$c<=$c2;$c++) - { - if($c==0xFFFF) - break; - if($ro>0) - { - $gid = $this->ReadUShort(); - if($gid>0) - $gid += $d; - } - else - $gid = $c+$d; - if($gid>=65536) - $gid -= 65536; - if($gid>0) - $this->chars[$c] = $gid; - } - } - } - - function ParseName() - { - $this->Seek('name'); - $tableOffset = ftell($this->f); - $this->postScriptName = ''; - $this->Skip(2); // format - $count = $this->ReadUShort(); - $stringOffset = $this->ReadUShort(); - for($i=0;$i<$count;$i++) - { - $this->Skip(3*2); // platformID, encodingID, languageID - $nameID = $this->ReadUShort(); - $length = $this->ReadUShort(); - $offset = $this->ReadUShort(); - if($nameID==6) - { - // PostScript name - fseek($this->f, $tableOffset+$stringOffset+$offset, SEEK_SET); - $s = $this->Read($length); - $s = str_replace(chr(0), '', $s); - $s = preg_replace('|[ \[\](){}<>/%]|', '', $s); - $this->postScriptName = $s; - break; - } - } - if($this->postScriptName=='') - $this->Error('PostScript name not found'); - } - - function ParseOS2() - { - $this->Seek('OS/2'); - $version = $this->ReadUShort(); - $this->Skip(3*2); // xAvgCharWidth, usWeightClass, usWidthClass - $fsType = $this->ReadUShort(); - $this->Embeddable = ($fsType!=2) && ($fsType & 0x200)==0; - $this->Skip(11*2+10+4*4+4); - $fsSelection = $this->ReadUShort(); - $this->Bold = ($fsSelection & 32)!=0; - $this->Skip(2*2); // usFirstCharIndex, usLastCharIndex - $this->typoAscender = $this->ReadShort(); - $this->typoDescender = $this->ReadShort(); - if($version>=2) - { - $this->Skip(3*2+2*4+2); - $this->capHeight = $this->ReadShort(); - } - else - $this->capHeight = 0; - } - - function ParsePost() - { - $this->Seek('post'); - $this->Skip(4); // version - $this->italicAngle = $this->ReadShort(); - $this->Skip(2); // Skip decimal part - $this->underlinePosition = $this->ReadShort(); - $this->underlineThickness = $this->ReadShort(); - $this->isFixedPitch = ($this->ReadULong()!=0); - } - - function Error($msg) - { - if(PHP_SAPI=='cli') - die("Error: $msg\n"); - else - die("Error: $msg"); - } - - function Seek($tag) - { - if(!isset($this->tables[$tag])) - $this->Error('Table not found: '.$tag); - fseek($this->f, $this->tables[$tag], SEEK_SET); - } - - function Skip($n) - { - fseek($this->f, $n, SEEK_CUR); - } - - function Read($n) - { - return fread($this->f, $n); - } - - function ReadUShort() - { - $a = unpack('nn', fread($this->f,2)); - return $a['n']; - } - - function ReadShort() - { - $a = unpack('nn', fread($this->f,2)); - $v = $a['n']; - if($v>=0x8000) - $v -= 65536; - return $v; - } - - function ReadULong() - { - $a = unpack('NN', fread($this->f,4)); - return $a['N']; - } -} -?> diff --git a/vendor/fpdf/tutorial/20k_c1.txt b/vendor/fpdf/tutorial/20k_c1.txt deleted file mode 100644 index 6d5b2954..00000000 --- a/vendor/fpdf/tutorial/20k_c1.txt +++ /dev/null @@ -1,10 +0,0 @@ -The year 1866 was marked by a bizarre development, an unexplained and downright inexplicable phenomenon that surely no one has forgotten. Without getting into those rumors that upset civilians in the seaports and deranged the public mind even far inland, it must be said that professional seamen were especially alarmed. Traders, shipowners, captains of vessels, skippers, and master mariners from Europe and America, naval officers from every country, and at their heels the various national governments on these two continents, were all extremely disturbed by the business. -In essence, over a period of time several ships had encountered "an enormous thing" at sea, a long spindle-shaped object, sometimes giving off a phosphorescent glow, infinitely bigger and faster than any whale. -The relevant data on this apparition, as recorded in various logbooks, agreed pretty closely as to the structure of the object or creature in question, its unprecedented speed of movement, its startling locomotive power, and the unique vitality with which it seemed to be gifted. If it was a cetacean, it exceeded in bulk any whale previously classified by science. No naturalist, neither Cuvier nor Lacpde, neither Professor Dumeril nor Professor de Quatrefages, would have accepted the existence of such a monster sight unseen -- specifically, unseen by their own scientific eyes. -Striking an average of observations taken at different times -- rejecting those timid estimates that gave the object a length of 200 feet, and ignoring those exaggerated views that saw it as a mile wide and three long--you could still assert that this phenomenal creature greatly exceeded the dimensions of anything then known to ichthyologists, if it existed at all. -Now then, it did exist, this was an undeniable fact; and since the human mind dotes on objects of wonder, you can understand the worldwide excitement caused by this unearthly apparition. As for relegating it to the realm of fiction, that charge had to be dropped. -In essence, on July 20, 1866, the steamer Governor Higginson, from the Calcutta & Burnach Steam Navigation Co., encountered this moving mass five miles off the eastern shores of Australia. Captain Baker at first thought he was in the presence of an unknown reef; he was even about to fix its exact position when two waterspouts shot out of this inexplicable object and sprang hissing into the air some 150 feet. So, unless this reef was subject to the intermittent eruptions of a geyser, the Governor Higginson had fair and honest dealings with some aquatic mammal, until then unknown, that could spurt from its blowholes waterspouts mixed with air and steam. -Similar events were likewise observed in Pacific seas, on July 23 of the same year, by the Christopher Columbus from the West India & Pacific Steam Navigation Co. Consequently, this extraordinary cetacean could transfer itself from one locality to another with startling swiftness, since within an interval of just three days, the Governor Higginson and the Christopher Columbus had observed it at two positions on the charts separated by a distance of more than 700 nautical leagues. -Fifteen days later and 2,000 leagues farther, the Helvetia from the Compagnie Nationale and the Shannon from the Royal Mail line, running on opposite tacks in that part of the Atlantic lying between the United States and Europe, respectively signaled each other that the monster had been sighted in latitude 42 degrees 15' north and longitude 60 degrees 35' west of the meridian of Greenwich. From their simultaneous observations, they were able to estimate the mammal's minimum length at more than 350 English feet; this was because both the Shannon and the Helvetia were of smaller dimensions, although each measured 100 meters stem to stern. Now then, the biggest whales, those rorqual whales that frequent the waterways of the Aleutian Islands, have never exceeded a length of 56 meters--if they reach even that. -One after another, reports arrived that would profoundly affect public opinion: new observations taken by the transatlantic liner Pereire, the Inman line's Etna running afoul of the monster, an official report drawn up by officers on the French frigate Normandy, dead-earnest reckonings obtained by the general staff of Commodore Fitz-James aboard the Lord Clyde. In lighthearted countries, people joked about this phenomenon, but such serious, practical countries as England, America, and Germany were deeply concerned. -In every big city the monster was the latest rage; they sang about it in the coffee houses, they ridiculed it in the newspapers, they dramatized it in the theaters. The tabloids found it a fine opportunity for hatching all sorts of hoaxes. In those newspapers short of copy, you saw the reappearance of every gigantic imaginary creature, from "Moby Dick," that dreadful white whale from the High Arctic regions, to the stupendous kraken whose tentacles could entwine a 500-ton craft and drag it into the ocean depths. They even reprinted reports from ancient times: the views of Aristotle and Pliny accepting the existence of such monsters, then the Norwegian stories of Bishop Pontoppidan, the narratives of Paul Egede, and finally the reports of Captain Harrington -- whose good faith is above suspicion--in which he claims he saw, while aboard the Castilian in 1857, one of those enormous serpents that, until then, had frequented only the seas of France's old extremist newspaper, The Constitutionalist. diff --git a/vendor/fpdf/tutorial/20k_c2.txt b/vendor/fpdf/tutorial/20k_c2.txt deleted file mode 100644 index 7b5c5651..00000000 --- a/vendor/fpdf/tutorial/20k_c2.txt +++ /dev/null @@ -1,23 +0,0 @@ -During the period in which these developments were occurring, I had returned from a scientific undertaking organized to explore the Nebraska badlands in the United States. In my capacity as Assistant Professor at the Paris Museum of Natural History, I had been attached to this expedition by the French government. After spending six months in Nebraska, I arrived in New York laden with valuable collections near the end of March. My departure for France was set for early May. In the meantime, then, I was busy classifying my mineralogical, botanical, and zoological treasures when that incident took place with the Scotia. -I was perfectly abreast of this question, which was the big news of the day, and how could I not have been? I had read and reread every American and European newspaper without being any farther along. This mystery puzzled me. Finding it impossible to form any views, I drifted from one extreme to the other. Something was out there, that much was certain, and any doubting Thomas was invited to place his finger on the Scotia's wound. -When I arrived in New York, the question was at the boiling point. The hypothesis of a drifting islet or an elusive reef, put forward by people not quite in their right minds, was completely eliminated. And indeed, unless this reef had an engine in its belly, how could it move about with such prodigious speed? -Also discredited was the idea of a floating hull or some other enormous wreckage, and again because of this speed of movement. -So only two possible solutions to the question were left, creating two very distinct groups of supporters: on one side, those favoring a monster of colossal strength; on the other, those favoring an "underwater boat" of tremendous motor power. -Now then, although the latter hypothesis was completely admissible, it couldn't stand up to inquiries conducted in both the New World and the Old. That a private individual had such a mechanism at his disposal was less than probable. Where and when had he built it, and how could he have built it in secret? -Only some government could own such an engine of destruction, and in these disaster-filled times, when men tax their ingenuity to build increasingly powerful aggressive weapons, it was possible that, unknown to the rest of the world, some nation could have been testing such a fearsome machine. The Chassepot rifle led to the torpedo, and the torpedo has led to this underwater battering ram, which in turn will lead to the world putting its foot down. At least I hope it will. -But this hypothesis of a war machine collapsed in the face of formal denials from the various governments. Since the public interest was at stake and transoceanic travel was suffering, the sincerity of these governments could not be doubted. Besides, how could the assembly of this underwater boat have escaped public notice? Keeping a secret under such circumstances would be difficult enough for an individual, and certainly impossible for a nation whose every move is under constant surveillance by rival powers. -So, after inquiries conducted in England, France, Russia, Prussia, Spain, Italy, America, and even Turkey, the hypothesis of an underwater Monitor was ultimately rejected. -After I arrived in New York, several people did me the honor of consulting me on the phenomenon in question. In France I had published a two-volume work, in quarto, entitled The Mysteries of the Great Ocean Depths. Well received in scholarly circles, this book had established me as a specialist in this pretty obscure field of natural history. My views were in demand. As long as I could deny the reality of the business, I confined myself to a flat "no comment." But soon, pinned to the wall, I had to explain myself straight out. And in this vein, "the honorable Pierre Aronnax, Professor at the Paris Museum," was summoned by The New York Herald to formulate his views no matter what. -I complied. Since I could no longer hold my tongue, I let it wag. I discussed the question in its every aspect, both political and scientific, and this is an excerpt from the well-padded article I published in the issue of April 30. - -"Therefore," I wrote, "after examining these different hypotheses one by one, we are forced, every other supposition having been refuted, to accept the existence of an extremely powerful marine animal. -"The deepest parts of the ocean are totally unknown to us. No soundings have been able to reach them. What goes on in those distant depths? What creatures inhabit, or could inhabit, those regions twelve or fifteen miles beneath the surface of the water? What is the constitution of these animals? It's almost beyond conjecture. -"However, the solution to this problem submitted to me can take the form of a choice between two alternatives. -"Either we know every variety of creature populating our planet, or we do not. -"If we do not know every one of them, if nature still keeps ichthyological secrets from us, nothing is more admissible than to accept the existence of fish or cetaceans of new species or even new genera, animals with a basically 'cast-iron' constitution that inhabit strata beyond the reach of our soundings, and which some development or other, an urge or a whim if you prefer, can bring to the upper level of the ocean for long intervals. -"If, on the other hand, we do know every living species, we must look for the animal in question among those marine creatures already cataloged, and in this event I would be inclined to accept the existence of a giant narwhale. -"The common narwhale, or sea unicorn, often reaches a length of sixty feet. Increase its dimensions fivefold or even tenfold, then give this cetacean a strength in proportion to its size while enlarging its offensive weapons, and you have the animal we're looking for. It would have the proportions determined by the officers of the Shannon, the instrument needed to perforate the Scotia, and the power to pierce a steamer's hull. -"In essence, the narwhale is armed with a sort of ivory sword, or lance, as certain naturalists have expressed it. It's a king-sized tooth as hard as steel. Some of these teeth have been found buried in the bodies of baleen whales, which the narwhale attacks with invariable success. Others have been wrenched, not without difficulty, from the undersides of vessels that narwhales have pierced clean through, as a gimlet pierces a wine barrel. The museum at the Faculty of Medicine in Paris owns one of these tusks with a length of 2.25 meters and a width at its base of forty-eight centimeters! -"All right then! Imagine this weapon to be ten times stronger and the animal ten times more powerful, launch it at a speed of twenty miles per hour, multiply its mass times its velocity, and you get just the collision we need to cause the specified catastrophe. -"So, until information becomes more abundant, I plump for a sea unicorn of colossal dimensions, no longer armed with a mere lance but with an actual spur, like ironclad frigates or those warships called 'rams,' whose mass and motor power it would possess simultaneously. -"This inexplicable phenomenon is thus explained away--unless it's something else entirely, which, despite everything that has been sighted, studied, explored and experienced, is still possible!" diff --git a/vendor/fpdf/tutorial/calligra.php b/vendor/fpdf/tutorial/calligra.php deleted file mode 100644 index c156b4e5..00000000 --- a/vendor/fpdf/tutorial/calligra.php +++ /dev/null @@ -1,23 +0,0 @@ -899,'Descent'=>-234,'CapHeight'=>899,'Flags'=>32,'FontBBox'=>'[-173 -234 1328 899]','ItalicAngle'=>0,'StemV'=>70,'MissingWidth'=>800); -$up = -200; -$ut = 20; -$cw = array( - chr(0)=>800,chr(1)=>800,chr(2)=>800,chr(3)=>800,chr(4)=>800,chr(5)=>800,chr(6)=>800,chr(7)=>800,chr(8)=>800,chr(9)=>800,chr(10)=>800,chr(11)=>800,chr(12)=>800,chr(13)=>800,chr(14)=>800,chr(15)=>800,chr(16)=>800,chr(17)=>800,chr(18)=>800,chr(19)=>800,chr(20)=>800,chr(21)=>800, - chr(22)=>800,chr(23)=>800,chr(24)=>800,chr(25)=>800,chr(26)=>800,chr(27)=>800,chr(28)=>800,chr(29)=>800,chr(30)=>800,chr(31)=>800,' '=>282,'!'=>324,'"'=>405,'#'=>584,'$'=>632,'%'=>980,'&'=>776,'\''=>259,'('=>299,')'=>299,'*'=>377,'+'=>600, - ','=>259,'-'=>432,'.'=>254,'/'=>597,'0'=>529,'1'=>298,'2'=>451,'3'=>359,'4'=>525,'5'=>423,'6'=>464,'7'=>417,'8'=>457,'9'=>479,':'=>275,';'=>282,'<'=>600,'='=>600,'>'=>600,'?'=>501,'@'=>800,'A'=>743, - 'B'=>636,'C'=>598,'D'=>712,'E'=>608,'F'=>562,'G'=>680,'H'=>756,'I'=>308,'J'=>314,'K'=>676,'L'=>552,'M'=>1041,'N'=>817,'O'=>729,'P'=>569,'Q'=>698,'R'=>674,'S'=>618,'T'=>673,'U'=>805,'V'=>753,'W'=>1238, - 'X'=>716,'Y'=>754,'Z'=>599,'['=>315,'\\'=>463,']'=>315,'^'=>600,'_'=>547,'`'=>278,'a'=>581,'b'=>564,'c'=>440,'d'=>571,'e'=>450,'f'=>347,'g'=>628,'h'=>611,'i'=>283,'j'=>283,'k'=>560,'l'=>252,'m'=>976, - 'n'=>595,'o'=>508,'p'=>549,'q'=>540,'r'=>395,'s'=>441,'t'=>307,'u'=>614,'v'=>556,'w'=>915,'x'=>559,'y'=>597,'z'=>452,'{'=>315,'|'=>222,'}'=>315,'~'=>600,chr(127)=>800,chr(128)=>800,chr(129)=>800,chr(130)=>0,chr(131)=>0, - chr(132)=>0,chr(133)=>780,chr(134)=>0,chr(135)=>0,chr(136)=>278,chr(137)=>0,chr(138)=>0,chr(139)=>0,chr(140)=>1064,chr(141)=>800,chr(142)=>0,chr(143)=>800,chr(144)=>800,chr(145)=>259,chr(146)=>259,chr(147)=>470,chr(148)=>470,chr(149)=>500,chr(150)=>300,chr(151)=>600,chr(152)=>278,chr(153)=>990, - chr(154)=>0,chr(155)=>0,chr(156)=>790,chr(157)=>800,chr(158)=>800,chr(159)=>754,chr(160)=>282,chr(161)=>324,chr(162)=>450,chr(163)=>640,chr(164)=>518,chr(165)=>603,chr(166)=>0,chr(167)=>519,chr(168)=>254,chr(169)=>800,chr(170)=>349,chr(171)=>0,chr(172)=>0,chr(173)=>432,chr(174)=>800,chr(175)=>278, - chr(176)=>0,chr(177)=>0,chr(178)=>0,chr(179)=>0,chr(180)=>278,chr(181)=>614,chr(182)=>0,chr(183)=>254,chr(184)=>278,chr(185)=>0,chr(186)=>305,chr(187)=>0,chr(188)=>0,chr(189)=>0,chr(190)=>0,chr(191)=>501,chr(192)=>743,chr(193)=>743,chr(194)=>743,chr(195)=>743,chr(196)=>743,chr(197)=>743, - chr(198)=>1060,chr(199)=>598,chr(200)=>608,chr(201)=>608,chr(202)=>608,chr(203)=>608,chr(204)=>308,chr(205)=>308,chr(206)=>308,chr(207)=>308,chr(208)=>0,chr(209)=>817,chr(210)=>729,chr(211)=>729,chr(212)=>729,chr(213)=>729,chr(214)=>729,chr(215)=>0,chr(216)=>729,chr(217)=>805,chr(218)=>805,chr(219)=>805, - chr(220)=>805,chr(221)=>0,chr(222)=>0,chr(223)=>688,chr(224)=>581,chr(225)=>581,chr(226)=>581,chr(227)=>581,chr(228)=>581,chr(229)=>581,chr(230)=>792,chr(231)=>440,chr(232)=>450,chr(233)=>450,chr(234)=>450,chr(235)=>450,chr(236)=>283,chr(237)=>283,chr(238)=>283,chr(239)=>283,chr(240)=>0,chr(241)=>595, - chr(242)=>508,chr(243)=>508,chr(244)=>508,chr(245)=>508,chr(246)=>508,chr(247)=>0,chr(248)=>508,chr(249)=>614,chr(250)=>614,chr(251)=>614,chr(252)=>614,chr(253)=>0,chr(254)=>0,chr(255)=>597); -$enc = 'cp1252'; -$file = 'calligra.z'; -$originalsize = 40120; -?> diff --git a/vendor/fpdf/tutorial/calligra.ttf b/vendor/fpdf/tutorial/calligra.ttf deleted file mode 100644 index 9713c468ca29f5bfcecb65d96e52711aaa5f50e7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 40120 zcmbrn2b^PPc`tn4_vkd~^s3%_A88~_(Tp^GW_$O}+GFo}cfISf_IlmcxPlwim>XIs z!3i}$z_eVJ1W17d2J<`msjk)~p@AHnNqobpvw>;(l z{GaE2O(BY+WU5Zl)Dt`R)*5$mEs>&L`8b^2arD%Y(}7sF!_?qVV}^PMxx zpHh_axs%6_96M3E?PG8)+=FVLgcH1gZ=@)chWF`{r*1v_=LfhZMLh(c)Bk+KO-GMV zE9_rV)LoCm`|qAQa`rU36MYx1Uxw@BHy$~4ypcKfad>|c+Viv1H{EjUo!xTAAt8X zh23ws-=QB^x8XkL*Y`gAa;82!Prfwx??2o#|3O_(d8i}s!0>B*$_pPJr@jL3XgIPE z9$rmR6I5h)j3_^Kba;$mCSEc;rl~{JCx^!#DvwITV}|OZTZYFhod5gHwvaoL9+GE~ zx@>riDUP~pcuZ3j>apRmhcb~fJZ7jk+B-aE;rvISy~rcLok%+e$AfkbjtA`=91q$# zI3Bcfa6D+|;Mi^F((xOQpE+{t@ni9;?~E_rbmOfzoj7yk^vUCA;>~J{T7rSP5gun? z_-=*QV^o~Fnz|F77pa@zlUw2Wg!}1f>ZE&JoN7{4sx^1yh8wOO-iexnZ{Gm_u6^#c zdyb#D?S>;~s6Ft-6Vz>R!4c}r%ni5Ra_23-)slGp(mTdCzB&V6x|O;GT6D|rZxdV* z|6Of?PoC3^7yPx~(U0eU_jh)oRco|s;|=QnzSS+NMm4B5Jdab2|37U5;psDshsIR- z_J#NpbY>xS5(0%ynt$H!JHeS}{1akTyr=vV`E{%JZ6^2$+D{SfE*dx~ZL9x)zF zV~)j$!swqs9uc*8d#&TAdfi?Z)w<7i$%9g#?ZV$k{lh%Pl$u&X%fX|8|FZGyd+7LY zz6(ds&ckoat^btzFZ^ZDY(F*E5Bn$^aWwp~0h0%Z)2xHP z{Leq%di!lxToH*xpM7`^cdVe_kAucEw5p4~h>k$3NY7J!k@a9OLEIXPg|pP{y)OLu zDfmtIS9z8xAq91E@IXfz`@{@9@Rxt(eMW@`3?Y?*rwsli6{2F)SNcbF*+V%t_6Gv~ zn81f|)a#2xd~n7hN7&R#EKePGoH-n?93byl^SBH> z=Tck~9;uG|=rlVicr-b9CH@;?qOwlj@TrWMI188hJQf^*l&Z z@7dn7U3fZAL`v;a@Jzu3yL~0Xb;Qqsp-RztkvBH`sJbax$>&vMyA!0b=!=<} zZVEmzA856eV74Y?mWu!T-M&ns6}<4HXv0%)l!|Pq#S>qiTK_5iA^d5o42JnS>fU~H z|DNp?Q}=GE1T`*ONE|zHc&szt#@(r@?(ReJ>(hx?;c#>fgVsk1$;mE{yc;Ur1BI?V zOP!-mptT-oHCT>w)KN6sJHH`vL|n;~3};?%^MRGt=$T?-Kpz$BS0Vy}rJif4S;II)fA7~aX%XmCWF;m%> zlMkjU@1i}jub8@=SfIlCPv{cN+4Hu77%f*lS;kyuVf7e-gM;g>Qm$G4nZoZ4b*$zqa0=)J*U zB4tnPzbobSdBfR;KeJpCcq0@`YJ~&ku!;N;UiH^h(a?G9D}u#p=jpU^5 z!Avl!0IFL?U!=b5dWTS-2MEfo4g3OlCgK&qSiq&=iBRXu8?FGpHNO5bRH8M&e~G@& zqyktpt81PbaVP_qHvDc>WJ(MN_N9uzxZu_($TKa|FdWE1rEWl!LwQ5=c||+q7dhcU zHBq$FnY6!V`;_F4@ocVfYpr$nWivsa+KVopzG->&kFFReSakhm)H55uZ}}9A{na(! z3;ezXZ3inQ(+WKeKVQW)1d|p8^{{^^=z<;evBE>?G20u=rp0Ka87de)9er+By>oSX z>zrRy`~BD6v|QSM$J&@-1#8LeW7#SA{S;< zEmft;_Gnq=II28Jl~t?tv&2YoU#(hhX`{Fd0Bp_foJHw@9Fjrn5+Kk8^WAl=_Ye!H z-JzYh)Labh_`qXNr$Hz|zrhHA*|x}7XLH1`b5%M=YyudP8fvvWj@@i@vQwzhZn7L$ zbMl#EqXQ~0h9xJI_Df#fFzOx}fPo}MEt@w24r>MNki;lbCddm>ZC=+H&hg2%qS_ej z2O|n*S}-+JpD6i#aj&j;L`mZ$J!W|YPbi-e6LcmQ#)(qE=Lmw2vEn5DsDT<6(0@`s zYF9taco0olJ}*c6D8vE;5HO7}&v|HC;Kyl<5VL7oL0w%Cpg!4!zY#F9EE)xD02&N} zDl*{JQdX*!YBgI;tBDI=I{YQ_=RT2HTmK~WUFuILlZy4dhA6P=Izy%ya` zY1Cxj@1r!8qC~;x6&@BfRheSN-WuEA_)TyR1X;QsT7?&wTIh)GBZkJELj<6t6GhD) zLa#NwP0Tal$^7Ep6HZ~*NDJNQmnN`JU_Iy#uLrOz{CWv6==Y$H5>@OgK8mF<>ziCd zG>_PgVcgJAkSX{v86aQh5`_7^OJHT|QY48eZv7d&6Qo|J>^=)bKwF%pdcC2l8!&8u zCP34m;VB|r(+KYjq>`7vbSi)e{Vu^-y)f-}l(IgEA?rnbXPfhPwS!sU8s8X9a{fSi8#QrhdNKCde2J|jI6 z_No@f%a_%^)#{GLIZc!WB@mYa*50@L0~s%E{a5G%cpK=_R6khGMKmhx@JJBK47IIZ zt5%j7l-Q0RAoBxQ5QL04Gk}7Z!oa!!3IqO%fQms|TB9w}Fjm32X@Cy4Lqwl|#2!W; z*cmMx*r(-v0hQCr-AB`WMh{7{w8))K}}3e9Ui1Tr{MssYP}tX+LT6 zb8KECM&K(=APtDw0N)TyG&~%f-$bim7cCQQWnzuV#h8)IS2*#M$;;e$(6sutrEA(L zU)*Hll}y%D)xgom{k3X7ulcP=-3*0x=CKu1%^9Wcv~Nw?e->F6 zJped>E`Sl&APi7E;1L%;5@+z7i5mg8h6oUcnW9;)M{}tp=m6aTsOTa>Kco(xA^ciYCEZp?8e>^h88%=89ap z)a~-ob~lqsnnvvM15&(_DmN9yo-l*0GVZS`md-MAPIJmDO(j?DRQ;A20kk{2+~SSk z=<@zxfbjy|hA3zK8T4tqof@MGeWmOd>2`i~+-Ss|LmV+`s0NPsQiC%N<}G8J8y07j z40n%l2m-glD2j=DC58v$rWy=9z(E^*5-&Vd89Qz&lZ%2+m^J8t;nfU2+88m%qLNqE z{Irjc&05n^Hayb#IVW)=SF9de)mVG~Rm%b|jH_4;bF#ukS|^)6b^nCl!#K9rjN21_ zuEIG-p&vZh&9^~6;?$0Q*c*2uG8K^-4}{s0D9fU*$(IKYt%>s+9_Jht0R#k6HjI>q z;qYcW;yR#&GmtM@#+HJN4#XTalq4O4Nr8x>gWe{JUb?UpQiNSwK9UZ#LwYP-w!DtB z)$VU~MngCv>ngkZ)zkIycqxZYuOLJlmd~;mEO0o0;*Is6q9?%Kw}ISS>4(zMkR$TN zR1w!Fr#qEg9aDI8&ft+V^ja_@pdIIH=Ruri(G`Qx_Bj%@Od1WU4iHEo_ztGZGjI+B zrb9GKe1t=yBHN8pUEdDVM2|wp++fM=+B8CMLpgC2Z)i5XMpR5inVQb>fQWeAGJ*inxok1iovNx)u2a^hgFC&oZltJ~ zQ$Dd6AF0ts(5eKvhU!gUxG~XHX)TfGnknAzRbftpFgAY!w!KAV`%*0)m2im9S_n2OaW7$UpJ(0f95aQ9W+2tVNpqat(B(UT49;I!Xs8(u~TYW8@5 zt?>5I8ehM1^*D*pCIN#ygPsBm5~3#h4ju3T5D740lf^RSJG`c7&qpHzl5NOV5C{|o zRB|crb?NalM;Tw#CB7J^dDP1cNHE4h_srss8FGoQsS9rc>@s{qSgWSx zNWw7zZ?aK}HQ<>^Q8>s#%Z%>X4V*NLWWa1~GIOpOCI|!?n0kH#pMw~Q%lYvo&5Wx| zRP3l;7d=)&vDS0jdiuFoGAi4pWPn(y+WN0>0YgwhE%yDuRbrY38H3CNq8PB&^wn$B z14GRw`auz;KKI!jKe*4g!G-+>-UeRm`wTRhLlBH*S{X}1xNw0*|9Rmh=wANGT~A*1 zu6Mx*)u^ihmA}#D2}k=j#}a-PKp$&)0GFKx2n5eBto(`$2o44-5-;B#0F{L@`&dq2KPu#D|~LkBJXo(vJ+&s-PC*{?xtD zkN^B9(u=E}gnn3{J>SItgGvJDyV8&Oy^c{!6$SV^-mEdr6fQ!z7`i5%<~go>9FB-qZQn|z$a}-#O0+fB+ULh!-aMG_ zuyS?b*`Lf|xiA#vNELb*S^ovd!MCVU;6RS|s|APEW8e?-r)I`(2wX4FvDHRqwLEq_-V*8=XbyORe;_~SCiMCh&kzG+Lie&Q zg0=}QNRVNtNrQ#ipqGfTA&#MW$t4WoorWLK^q(E{$L;a(^y=LQvSX&QbBYbrw*29} zFMZp)U%7lsZg=BtC*Sj(C*S#oFJ1V4J~6sjOgHAx$6oWsaM&L|x^UvPv2^>wx~+z; z-G1v!-hKarZ!6_@?ES~b|LC9I{8yQgLle2tBVc#de+co(Gx#4Nk2ON|`*yu*P&N8U zqk5ZAzjeg)^6~#}%x+>50Y!UV(&Zu?xC1aWsxaXVV0wTb&4J4Ulu3XV%=NUVhXG=> z!JFQtvK|&Qr=+5$WxJz2Ic9LNWL)F@tdEw)mz{E53t#w~ z8%`eD9+|-TR<(c;SWu-{XJs}p{m31!s2v=qWmDxnUM=g(J@WqQ?nRn;|N1)2H(o!# z{%d>~{|%L=woo(u@JcP^XxOplQd=jdLoFPip2SAzMZO0vb(e(90!<|#<`Uesb?7Bo z4nV#uvo#FzObGuCh8MgixOon^5+EO4)`U)(xWB}Dx@D)Zi5)Al|TFC3Qc%~S~hLo7ofD}v>P+n6K-HPZl%q5z$ z80O&{zqf;CZ)LqoZ8kkw6(w0QtJCp>%(1lL5wm%t7EvT-+l8-g6|m2XnMNu`>|<#C z7r2W*2bx~)>!pZ7WgC@d{hns(u0Y^k_6&(0$Ov2t7X=*6RzMnsfqdf3>P8QUgs{l9MI3fBhm zNd*!d`;SdbXY<=8R56n47L~9M&{9q^BB>qQRgX3Hi6x&qr@zGS$A1lWYK+?6Pg<7N zo*FMz?+e?a(x{JAYgG({K^9Yi@JoaTHX?-{$xDH*lGxzO}FXy|vnjmJgwLJy>|T&rpNS zz|t#DO=ax|5bFP_WAGMBBUIfRU>9c4ZIwnd-b>Ht0`e4EnC{iFhrbu7o8b7uhSxaZB@3ypgSmV@xe$@EIeJF4aCUs`Va75aj0KWmY}B(EY^sXrG2)MUfj+vJPU~*O+c4n} za1bZuQn}}-Fxusk@o)`$iHZ!~}q90Q26SLR`C(<4DBm zV&G;6q$R~UVDx|vt|13tC1(M<*1?CZeAGX2^zLyhf|2K;l?ilzDVwmPhuG}jI@|QU zBZt<|>;tp_=7=@OC z7!|VfaaI5jK*n_aX}pZT2+8hy`eUVBNTW)HTq+(*r6fBo*<~^9*e{hO_NC>9cHe~`G* z5=fj&`jDrH3!;h9gt6fuHbt%kraGh97U73B1`jXK0_4m@4>?(c4_5oz+H$^rrNd>K z9iRmwYG1vF2?R2khr_jG_WhY{_=~-u5BNodgi?Hlswl~N}+U43( zh}CfGfiYjMMsxn{z6fWxvRlxCtyXvDYKrU=QjZ+nbJ<-7s|A%|1V_`vmf{VhCRZ!| zkv@0F4t}I0Y5s*E?Qm)u`nCx94*`FJTBZKHzuIo*6>4=NM@>XWB$%! z#UoqavIc4O<`5o-8)YXS`b~HAK2Uh zkOISWiLe}M!XSfn0)cTL2>=F`P!=${HBSmskzr)JJhcNR%bf!do+(TMHxAUR3Ch;P zQ>aHrSd)z))3#_Knf5_kfshhnWv_3Bt`~JK#Lx^Xo{z*hhL?T3xMGfbIYaO;*vj$C zAYYm6s$LuT(LGisp-Dz1eaFJuy=l`3nXC`j zimV)oo1x1ulZ7`5C*o|_lwyHxuUh;E;KNkFkmI3f_T>Nib64tqh3E0-sSM;*vW~=3 zwn43A1^!s(?VjW#;3<=sOT@8PfU=74JK5);#esqouc<=a0I`b$3lBq+1<2?krUciS z!lT*TXpY!Jmu3YM7zLXTirK^f1qz`Hf0sc(A2I?!9)%J7^=_Jr`>?0@(XofJ{&Jii z8y&l>wmskV`)dJ#Htcd<+Wnfp@ctQ;!y&2&w(ZyWd(G(8pytSwn5b{Km;;l z<17n&n3=1aq9oog`SfriI2USNJ62P|NRYSU@8%M7t6zGFe7R|wwtsTVy^Wrt1r+B@ zP+t&|R$y_#7e=kh*tCK?qV^Ss;lca6909K&f5P#^=y# z$O;@dGIrMiA)?o&M`W{-HcL}YCqJFUyjEW9M-8*8t5RN0uhyJxA3*Qrb^eZ<;+E6T zo|Z^fhz3wR0}OaWri@f?kxbC3FAe`p@tLV7UUdt)GZR z{4qYFYxidbQ^MG^aM08Z90+D#=Li20+n8qp+J=63SVu;(h_32Fe~XYPafu7;_K0*3 zU|9^r9dH={vLplpu5*bZJR(f&8;_*9;7HN8cRGYHj_r>Nh*_HSR|EdpvD)^VkK=YI zSlUuE1<{g%os2v+fuDZ(A!EY-$&rV@Bl^s0C?v3EvmeDIR^%+=uyMv2&CaDv3t!YuJHOL#aR4tRYT0}bQmdIoao z0yBZI4@|v$*JJPOA9>~2>224}%@w*m-Jk6(u0ab2$S8bmCY+T+;_v289!#o(QWY*dO(X~6Y@ zTDChiFlRm5bxUB>AkYVB2L(hO{Bi$LR`i8eRuf8J8=Kh^Vp#zyAPf0a+5;F0%`HaZ zzd|c`$LeJV6X~k1@hJ#+8)?zQ?@{_5_P}eG3rTNjv^XQ<3%5*mLqNA~|HzjQ`~Aoh ziG(9O&xN*5#-|f0Z_w9n$=Xbs)JexcQ@4Yr_Naw^bh;dnnp!8NeXMVOv~Pc;U;l8S zgHwe+<#{9x2IC?=C!Twd|8j)`B%?1u_ho_(fr)U7Ihx>?-BG9kPzPawt^z0lfRY`c z_Cci@p7K@NPJMoRvAkSV8{N3?K%VtAds3-se?)Y~=T-w}=KI^c$=zb3$88CWj`MGN z$rtVRh!%_J{*3L@iy0%ojM{mwo;A1;k5nD4T-lMzBaXybWvwestC6~mp-hQXIY4ao zBm60dK?2lrKdwuZ&T@|du6?!hA|F;btngS?Y^qJNfcixdaH~#9r%Bot;@1Hw1>Fwn zpvw?Yfl7dJwjGx17|Co30I}0Z<4>KGb4ochMYH^6dl^*uaH&15DyJ6E4F1A3vXAzl zvnSqrs4?5cQMFO=`k*ic$k+8B(`o!QV9Ou}RwASE;2nAK7 zRSq^v^C=bLxJr2xe=TU|s)svAqGzw2j)|QkXAbr5u2syfp~UhvODRwMircSQ-94R4 zl(|4KNEn~>@2~%eHt{!st%lr4B`kWWcqmAnThsOrT71#qLxbyK(qPxS6C>efN4XkZ z1@|^UZFY>1dZ^Vyv}vl*{g=lqk@o_mPbVc`e@}HhZa_}vK99v4h5Vr=BzJ{kAsmh3 zZ>B=+H+^)W9tlc{BT7EYNQM94{YQ=_yhyYU(B9FdCr(aO!urvxPq$R4vx0X2#Pe(L z?3Y8H)R@es6^Yt0JuwzGXRe^$U2s8-f5TyIcxHl2uK-+%WCp7IHrtP(vd7IkLWgjT z1!O~mpbxodD9UsIkV0w_`bG}0=hs|tVtcRP!;%DkS=H<@)q`{5XPZ2M2j+z*hTe_;V!RcH&kh58$KW^aZ5_^tJyZkQrLSQXi86h$O zwsVN;0qa0omlUkw&yH8F4){Zn11l-rCkd%cPxty{rrMTbzD@zduq^ zeX{Tv55)acJS%1cEZz7J{z`xJ_IM;&JbPu>XWRa!2tx86aY4|$GtH>RD_JXKd^EVP z>wO}Z5!4&l>0^zKINnJb{=G!zp9EBF;isq$u-buUJx&!se20rHDq zG$DWpz>82DRRfziek@Kz2`LQd0+feB$GfQG0-k~F43OQl2kJ$ka_{BEhO|%TL!eLH60V1VSspJ}~*Jf5cX3&-i$I41dR&9}C8=j4V!fC#tqz&j*yK zvUBgmwrfTf3#_K?KbYLxIh3^0hbnbj&_w`^5t!@f`hNk7^&@H$EM*d?lZap8sca^p zP=DJs4UN`6oYd66N`AGI_k=$K$tV}ux#kg&tqbvnY}5ezcX@CSz;A<<0>lF<0EA8n z4YD&BO4>}qBXqz=5NSZNhg2hi1%qmvB_Lq$xPPm?ZS}HbwpyR)sZphC$p>v*+Hqj( zvI!Ypq$K+jTN)vMY^q!>Z1unA$`w{hW%aS+$ByM|z~5mdYDVo&m(T= z5=qPhtd*OZ0dO#=6CCs(>;zC9fR~8qvK+9!FomR3?GBgYOuzt;fNCRvA)Tl*X@e%) zQ-R2WCDxk&-RE0N*yF)BpgHc|PaPzO<21eR!f*6F7cMxg>&c!*-v`^JQ}Mpn3(Fg% zcdyZ#6$Jyh2~B`>a47*lUuAOe!%+|VetaYsYEE6ft)qqK0(x!7mDls$`4cz3|K-=_ zecbqUkG<=YaQ9!YKS=!xj7Ego)6dZlNBMYE|AHZKarX1d-&yyvx}XT6p9+aM>lht?>_fjF>J+R-wPI>n zbE1|=U?~>IQuv>^^2HjCYBxojxVl$$efbUCmxN(rp}44rz%KQ%D)p7ekqAMyOQ)3FiCr;Em7QQH zsIvkm#}`bWlW_KJiHjJP4-)+OGn~bLKy|5HUzx0wvSC&B`rk8E{06r)Xy!&hNRZGJ zIPi=Nwe`S@LLm=n6@s#{LD^N6gOjdthfs&)FG0Pr=xuh)`SHl^Yi>yRf&%AFwjx4m zM8MqiYUuU@QI)?>RkK=1h~^5Koh7?w3=vS)I`#W(t(I3WGqdsSk-)a z`xOeY?N34-+_#{Teug^QuNMufnlpIMlas~FZ6k8y7g3yw$r3H%W+qKHLP4Ag0B4+< ztR`m9qT=%)2g$a%wb&$hArRye-weH+ErOwg$ejok*a!za5-g8kVkDSRa4SdW*i;b# z@`%x`X_gR8Acg2#v8Wi6jJgztn8E49RLv_SeRj)(p`I~x2njeE)6+V{om?p5_?g69 zq?SqvmQoCWp8TUf>((;&vBCu1MV%g*-0+vdjG^`z*bseOBQ8&j`7*t+}RqSA4w?-afZ!U~|v ztr)zd&#v8YC-`8UblnZb2X*DcF)(3L+*MR0TbtUXqud%bFrbiq2g8{iMzt6!I*I4P z$4ZrX-SK-=Sb#%Mq`gu$!L#0AEdL4Rs+rvfS9d3P-kWs_b|5vO@$4RnFXzHAYt8B- zIeTUL;jL|7Om-^s=%XHhpV%)EJs8%fomCO|zDw45d z*!imJncu*w;KBw_^%AVQ0py6j16<80w3`EwX;PmIa1~P81EZA7f;$0-POAALklqHP z1$s|oSV@>nFrw%WTSb5Qnhc~*5hR>6OSS|Ct&}u9z;Z>5larbGrsfYBUdX`C8BpDj zojx%+m$a)7t_h>#m%ViSYbO7WVl>dcL@j`QA18#X>LHyL?x_lqD4>&p@8% zXZYQ)GCM>198%&zhxTR6FmF+53#S30XMF#U28>-z;dtaA9+oR8Hl zDHS)Bp!w_%3hm@g_G@;s9y4ZDR5n?9tJ{8i*#0cl>j#n{B}&?_^E#C=bex68>;JmZ zc2~$js|hc)5nK!{SnjvmO@o)zHYRJZUJd3dhMw1QPiY~+>bl4a^4obqwIG#;pWF1` zJSD{pboaemqa1JCz}WTa-Jd_Qhm8Kef&W;fEvTSapw{}uUUzf^U;xkzG%R2h7w%b{ zd&6RaN@5n09&8jtUG4Ws@=d*TDoDNq3>C1ZLrAk3GrH;vbFv6|VOSo?0fHfwq63HT z${zS1%h9bEJtQh&&VZ%_jpe`<4O}RhK|n(1Gc!3L#i1xZB0SmzM z&HKEzFMK$xc6WLtqc6+^gH9wFE+4+KT+|qTn^BBT-#vZnjSmzvtVdn)7$P52g^`g9 z-|rV&g;Z#sS8h*Q+xs3VphOJRuxy&sH9M5qeO)t&3I6#$Nb1*MtYBe$AJ!F9vQK4j zFc7l7hhHEcd1>-5LDG>RgfHBEBSwF1VVU&J!-gfW!_YTV2XDL4w{4mB3pf28q~*}E zr(o^n+W>R!f?TOxN~e-4HQTNi^FihNyO*ZE2FXgmoTL(A6N_D9Bz8mb0pLIEW~6`^ zMmd-x&%i{$D#}!6P^#zVPywICfD|1P-Z3<^84UflW*b%=i+U)k7i(MVx-SLYjcQsccEsXthZ=6Sw*;+mC6 z|%rEFjMY|Hw33v=ipB5!`mZE*JX3nMC({k zsZI~)49KY;L);H5BeGFTr;3rFP)~eY*JuDp?wGjfbO4h;R>z_QNw6G{7=R{ZQcn-Y zqlO1U>uMn^XP^i5PGBvkqwPF41aCNKwl8by5Q~HaAEw!~ItLE>#v=O zm8ZHolgUS%lW8xvE!9~a$BZ5sZD(Cw$patsQ>d@p-cP`IR?-QzT&XxA_Agt0#|P;c z2S>v7{C7e>*kJG7vMhi+Lug0L<1ouMw2&2^* zSAamEsdKk=WusjeQccatdNKIrB#l_xkzq~8`&ge}!6)v~{T4^UI=l*W16|nIXFJ)cTLn2hfjz%LcwMPE*BLn5T>RLP2pne}>))b2LXmRrb_qwGcIERcd^6zWU>|_eZm{ z-%byMrRT=v1WwEspbw<5kyVIIgpxl}k4r$Od)Cc?g1-VB?owc+XTT*7LJ)MbrWk%* z@>W#$u?-mY?jMvt5X-$xk~iDUJ89fHhrS4OFSz@ z5(wxUo|jB7s9-u9UEC3p8MCaK=@?d=QZOWBlCa>DiB{sxz*U2J{3&`7J_Y>#75#F# zl+>wglFG7C?I(5R>3S>*%R=v|WXivYM7;vzftuTB>1P2RB?rRk=8Z_Y+YLYnJGhZO z+HmVID)l6c3ZeciF6@SiL_*>Hpz5pDfk8@v1Mhh_fZOOriFOc*brI{)0v^r_pbN@f zQbr=;@x;VYxueK2I-ie3xSm!2~MZW~ByrmycM-!1CQ~uj2syo5p2@mcx@Z?12nKj)56?)MP#TzhypmoqI z0v<2M8qljL*Ytxa0izF{VL;;uh#aEjPTL_?1#&fReHEY-C}k$qdJe8;i-{O(VxN}D zK_Pn@YM~-frW;|kfW&jm>jC^~P(uYZ9jq-%fy@G<%>+_3?b+#s>;O^%*b3CjDG!bX z_>>;|K{JAod5}Sh_vX?4uv$`svbCdI7^$urv8C!+H`fhW96XM`M-?H9BLmS(%aNa# z3i>Zt4$?RquHN-((6bT%5LaFm3`^?=CHF2@?QxTzHB2IA9Mt6d-yby+Q?+c`_Pvbf zjY`&nHKs^HY%`*_Q)a4I4TjNYpf|BUei}D++;^aETXUY~T&_H2(pg4X9?3#r@ACu_ zP-jOnHuU4@C)8G|+Ba5aq11IWm6*tH%l$GGWN6~F21M9J4-9SHMwVj(sSFQ*A>g7& znKhBEToppRfwO{iB#G=?t3mn!`5I6{!22CH7G&wy6joD*eF521^eMh@HV`PtX+c*s z5!|yc-mH~PuOK`q34z&hTDAFLEyKo~)Qpx)X}~=T`{eqh5iOPlbZ__G=4(_G<&OlS zcBR==dU`URiHI65Ty@W(s>i>dKm95;2JmEgg3q6dc2}z9XeA-nL!Ne-_363=%VS72 z+fQ&3{Q`3NyZR{@-*~{(sB$5bW}9OT@y84EZ(5kWZJ~k3n*VNV* zjUuGi<+gbulPy8cKOwKw8}V#Nezi}~L&v3dOT0!C^tPH>8QT^Og*l(HQ_@2QgRvN1 z3Upc3vUsqodjviLOEitB-#fmr6ts7;xz}+;+m3jaIS&_s+Mmco^<)*+;SFq61V><8 zMhHJp52AX&$^WV${zrovVekmXBZ+@UzkZ(MbXC_K79ux8aL{mlCMl5xVF95bX4n-T zU_+)Mejo{Kl4FIvfNkicZjoTe9GT+@Mc2!Q4U-P16Bd%Am`zpMsci@?)`J z3V)=2=iJYw+I6DrSk-R6zNC#OgQ}%Ua#Hrm-tT0xQGfHQZW~?L4SfPc@L%W?n1+ht z*?y#CDI%3nlCV?6&qu3)(fT8!n);uCXz*DN*_Q`+U{ZWSj4YTUw}N8`%|R1J2TZAg ziimT0EvVrHluqidNK6C<7IK(`ga=v!SPk@v$V@IB8nNREalG`tKQvTZlS0uR_F2gT z@*c*=c@9V7flyp6FlMR#%H%?pMhtBwVy&-ni1ulcDuw)2!SC}xt*9a}r&IYvNilp- zu?{>J#jd{`wIIuoq*nXjRWvFHerZ)$H}nxTnHZs>5r?)RoyO3fAQpH{g$`ao{7{y` zBmq`>=k{QBwT*crydo{z&ceh!)J-=}V3gf;#MyH=Ei!e5Kac2WyGwGgOu$yAN{Iqtw@_ z&uyN6VDtQw)IU@2gf@rPSKO5-Gf;^?GBI9>1*o>nimc#Q1lg~{id^NTvon?1-aWI; zy9z+0VZo0D3s{?bH>$bLQ6ki3x%4p6C-oeqBl=l*VUfpGF;~&tm080Cx2tll1iI|e zELj&%^13OGFvx%aa)WYvu$`$+6%xBIwAO{?pc31)r|wdhkQ&K1a;tSIJSVZ08?xSKn0^mna+Sz1x^kHZoe7)^Ig2z?KXX5Jm;S5a?v zN7=1|r0<0DBkuWcQqPj}gNi?QR$xE3i?cGQWO2`r4bT75z241dK^80v>Ow)j?p3$I zuMVB`2%yw8xfBS{A+ktKRq zScEcjwcpMJDYfTig6iJfrDCyVWbTDBLvn2FlGG5)gquroXJ~maZ#R4#=*G1L_s)Z}-(bku z{}=91!{ok$vyc84ISULMAW;7Fkr-vn8P^8@a~y)%%OL|F61`{cX{;e#k-K-9Gv|o8K*&P;r`-5_a3jJUPJEjTj%GXZ06#5GJb>WzX2BQ z;(79$gY%D4kHh^i^yp#qF}w?QyqKi!>z5;z!cdJ$*08g-)$Nw8Zt!dEhG_`Ahr>nN zXkgC>F6KOI8_OQfQ5>>+V8<=k+l_2{;gYc6$p(?zIoMuFBLaPnsw17eOd^A%%v^J~ zfgwSpyAT+-_6`cWrVwyvZY&Fsks}cS$zWorMnE|T^BnNKkWYbNevqDa(AyKWN|4Pf z(=A>b-MK4;TgaoRa(N|{^yrp10NZ7y%OWq^ANE+uAS>m9mj#ny??OVztcVTP+%h-) zqPDXuc@mNzBau+hk0oCqt@c~jHZAP=;KQ_DvZX|QNg|q0t^WtU9%_5%s5AYsiDp8D zbw3pBdE~A6dsEX&R-;}$KQ+6J9v@R_<)Nl!8oI{Tk51KVKqULaucIH>V69ye-X$#t z`yRPi#LXoP7HJJZCA_#UVIIh9;70*ZLQo6UzEiL@k28rotq%AC;u+mUBh<-*wv=5V|Adv1i!fsOI;2yh^HvsF*=fER<(o_G#I64J46g9FnZ?#P zR{THMOjDer+9*Wa=-?kQlpf?C2oypAB2e=vxUt>l&{Ph9D+tvRq%z2UWhsbCT(;5W zPXNHV4mAsaV&GFZ3y?`^gInMLB1gm02$Ult=5b*ABk|t$SSl8^X6CPHjkgmFd+vrE z*Gby#Sh*@yPv}Oz^Uy+Pwk%7Zx^cR@J>9r}4lt89DH-^KyILVtF%p$VrW0OjH6b;S z3m$r;GG-pam8}6u&m`J<)xWnsc`T;Y0+-*Kx!{S|!G#GWA86ha)^kMa7O9WG9zh}4 zXDi%?Rra9mG^}+#M+qphv1^kE+ZX^ob(89Zctjt#ZtIq7uidisI&@;ob=Pj)dhJQL zlUtkq7Rc-!r*7)EuQ)gZybxZPF4!NvM*lHC)4gqZ6_-2WvG4bjA?Q5c=wx8E70yg_BzS7viZlvf~g(#OU9d zMkZ57ro`pFYFTb`|Jx7&bo63!V4w&8HKC7@? z3MQlWJV}A9Bmis@zct!iDhK$x_b}vfwmLf9nt5`0a1M@ejYX?_GD^`7ZLf zd*9K_>nRrAZm3_9_SuYBbl@A%4>-+9-2-+LE4_I>oD=&jA^@rg50|IL1g zdNy`DAblSJMm{s*&!h+4t*(ahtBJ+5=od>k3O$B?|8`F|wmIkxh%;Dhcb;q)*Z4nl z2vm4eC7cxD(1tzjT>;?cQ7XKuW5;jnib+sU@O-FC6%x!AG6RqvZz z*?;d_}5C% zj~}{u;U;|OkrO8#e)j3JhtHy2sDbJizUn^Sa^Y#D@3`<`v||U@p%Lr{o{`j|Mf)sl zcmCBu6bHeu8^wXf!!MC?G++oi$oXLBHTd3ZoQJ^={0JA(C?G8ns_19>mX~53$&j!C zcX8HK8OoW5TX_=G)`tE9sPH1+U^hjO?I9M1+Xu zWwggH9^xzNIIozn>8wxT8)u%F_+5q_ZR#7m!|e7lCbu6|AGD#_0m=T#jE@FJ`C$1rG$bxrZtXNo6Wm`aH!rKm_osK8su7S^gLJ0T*3T$Tl`d6tQKjVLiGGc@lZ~gFr znajwMc(o4;OW3$q@;Swac&Q}~I#Do^YtmNVIQmra87`+BI(;)ly%j^G! z|0k?QnTL7W-Vg8DGFHu|BaY3{)N(ULB|7_dyl4M@#j}6vPhos*G&$Ht;vA)+aWck` zro1?cgFyue+wZQ90ET^YeHrW=0Hd@Kc(@BCMwv z)U##r|BRK4G2d|U+2wP(6Udo|IAO2|O<>GQQu1s&oGJMyJI`H!wrEuC!XGo5`rz&H z=3to`{;N#QoIkU#;Iy?`yR0RTs z>?)dV!6d;enZ5y+KdhODvPn`ikMB^m5m~AEZg~S!V7~B06f)}p=ELvzuzvg2?Up^3 zl6fGc*L16EmP>in8PUMvS1Y9o{*Dzr45jn-oOefkZny1M%T70aikZ_GtDT!mC3oZo z_47+Rb|!N-maBfBEV8GGLo(CY6XXBY!*VxpKC`P%}LS_dK}U z!TnzMnYFVU=`ygEHku+v*kv~fL?-moCOv(rshEYVnHy{k^Gh+B)PxKdK@YQ`ByUa7 z*6+797M3+y-N-V@JjpV_a0@pK1b0 zb$3f}Ws>|qGDtlAl*=$})T(76zvG@qP?8GQbL$B-grkOk-PTJ?NNK!qxV9O z5GA1(qc!{`h~k&}c0NgEG|1KIK{1!pgE|hPjf6ju5rBmR9nO%b%5|#l#>AUu5IQgd zDGWmJLzYV(7Ckw{M?fxv|5x3a$H`SxegE9*<#ylh+w1HzNoGqjnXEID zWRj3&$es{FAS($&h9m-p009CW>0b?HFm0eMh zm*;r`{d`Z|?wJl5p7rzo@!px!%k8>V^{eI7sj5@wWYU~R^oG>rqOG-@`AtNyhv2hq zKD=?wl8y;F>&ZB0J1youM&^+{ZevZxkB5BNc+{E8)TafrCKxst7y(D3`fS^5APz9! zJxIv}0R21tC}Skfo6tV9sTz|e$1Pd0Vduv6)f?-oHugTdvF5Cejp2U zs&4LtA|*xT&RqTc*4in#|C)mT;?`j+%k`SW69c{GOulX=n$4kTxTxEVYH4GfgBJhU z5r7lA+836qK#wbGK#y)~X`GeDFb8tmJJ_J*gesa=^X0OhnXSXHnl2N^jqIE;zH>&X zb4J6g>Tylgsix|N(WAOs-&inb+k$z!7c5BbS}^0^I)6K577}HXsg||5qe?P(X&qmk zF;EM4Ny=GJtPb>?%7n6V@ob=3E>O7}8!5p84WgO$rEV4%v@=;fDC`YYBAAUp2MXEE z?uzTdKlEiyAV(mqId9gsw1z4hnoy1E95W0X%tv#qE6|XNyCWx6kDrx|h0_M@sLA#9 zhgFU|EzuB3n2%Jp$HS;knIngf?=qPYN2$)#$eFIYHB?`wIn~I%(c~jrMq9wBtA9w-D@t=XbIFLoFau5|U96)eig*^n!m z+N-mM_s+u-9~M;Fu*4TT)J`9kTKbLcr7^wt?oDf&LN12*CJkn#PuD}|6(-5MCXW_y zt<3GI$a__;%e*07Ve~(-y`=gNy1cVwR?S`T-XnBe(5~7KO_>td>QH-All5R@!y8#U zpJv~8n0YmCF{s7M=&%<2zl;i8!8mW%m7Kja%rWoo!UN2(z!?lV8%p+`HTN>}a%FxG z%C)Yj#~Z=pjoN6yj-*o@tKjd(Sy~*d?53h!Han78#$6I|cqeaa<#CjgZNgk>);#;} zTyt;jyXWBirq^8l?m5cc?1|#gDtPY{JJvks#N?X(mFK&;AFL!lCpYkWNUfD4|Eaa| zdUVj1_l!_Op{WYg)f=#FOxH{`bKJjTWGyz#hYiW5+3_9F^ zPDOTclmL4R7`r;p>7Vnx@3VQW%;x#iAMm-{7CHsp?_sC>Gf1rsLc60C>>JJzyAxHs zuRB`7{olz`Wjk7Wztfi3@8n@SI%C@+Jd8QYM)`WrvfgzomrQHIl%*`1Gkem|*qn7^ zW9!DwKW^;$WBo|O)D?2srncRij=pIA+G8&~X4%-a>vkTqal=kb@H41zLNqkitUvyk zqr=B7nRQDpRx)~NRTiy;tePx#ec&#cU$m1J3>+AO;jfHY1+sFHO%(@`O+{xi{kGC3 z+4VYWTZ8s%Cp~Itg#|qIjL|>s;heJe&w<&bp2}n{Ii6$Xfg!cc!Uusw1bdCoN9LoxdUZ?WYDg2U_NKo>@u-(Vt&_8S=Zk2>AJ1#JTg!6Z+l_uup z17kxl%d|^$2M^jQov^A(MyC$j=0IuKZb}>XlroLlg?3E9M8lXBo!NLWYIJvW=Bm7w z(T5J$)lD3_IN_iHySXlQ(m|THZBcg#I!0~B1iH5)(zTUMt%nZP!-nU=jYB#%+Oe9w z6zuqpagK+3wDzd=JXU@X@5EW5GOBTwzwcZm{(hRAG4DO&jQPihk+gW)toiRfZPvWI z+pOVfgZTK0a}P3e1)9vAJ;_lchUU`ZRu1p2wR#C5XBDQ2bPQuU3uA)22lWOs8pHmp z+HbHbFcCCjDRf;QV5>omQ*&V73ZBkAsWIc?$)5Ute-n@4Z=x>lB_`{wWH&A-x=e>Z zyei^OY_1-H6-2b|5<{x$M0prFT>}Agg-5tgzo%HJB5KW5#tK36|h44Usep4j~rn@}9 zB@n~PavK`}L2XgqvY+yd;QR(7{#82mus*Q7@S-!> z+(tU>J$P54%c$99I*sG3)lMVMv2>c!f}y6#T5Q~Dah%EToqmk-S##UFlQCpMJ7R&1 z=NFUn@v^;VY(qBTaoVGLq>PQUp!V6=8gEaTB@;$gR?i>H@h8(*(QZ=pz43Ap$WfzR zRuozn2zt6QO=cq8w`-Wi@kSN01K}7RSSpPP_Ne4Y<#{7UGM%&=Z`~*c>TV_@N_DVN z=dzAzrz5b!$tKi2rEck{_9Ghb;Z;*xQ#uoEb zr4N{StcH8&xvE1C_q}lFX})EH9N*I%n6XYPs|iugddI>N(QTlR9S!@C>9kL={-mo; zhE*r}5G^pUH(*zkoYr9Z$c$yBh}fPnUCw+oSSrAik(8UrhTT(A*;B%)-mo1fJl!Y+ zPlc1D>juk&K^GtE-2$Remg+ul4KeC$v`XsLwU{=DL=a z5p9(f6`kE}h)7Q1X|vFoXLd1*YVYx4lI)1Yy!hT;%NaImDGD}5@yv;sA0SDia%t_j zq1bQ{g1cKJr~HT|Mda=6L1iP_Wlo&Tme% z8~c8s_h74rI;r^&_BfryqVCCy7j;irxUi;iXq}SzXvf4!6S_LF?A+2i45G|g8)=i5 z0G4N+uptx4N-7nr$TAUoIE1^igc0l;h5qD}ymSTg+Q9NS4KM1P#4J}?dQh+x6l`^% zny3Y<%SL$E?5uieUdNot!0vcmkc!^Xx97 ziw&hT*49xhA%iaaiGdj7I3K34wHixfS&*jnYRX`tD|ya&_qBcYEXeFQrD10`L=3kG73Zmaz@;%qMU*O1DMEhD?C zyPekcTTVKALWlXr_U+5D3{<){@u8gl6-a2jnR8JcUi-7LLZFMuW1A0}Y z>K7u_FN)OMCsMmdr0!~w`b$I__&ns#B16eX<7v=4B2C28OxTv2aP18Ze@0{kYXT#; zinMJI8AY7!XNrs_q0x_ujJZf;?Cmhmdqu`yBQoI%kq)Gs4)WQ#1o{#5rbyQa;n*HT zekOe$7iGkSJ71Z?&8eGkS2UKcq!3^hO#A;OmE z7_clS-W9~Ra%MoQ?h{!}e%E{v9q{v^J4Mzmg-#SXE-BK>=iW_4;`iRqiyTj$)>Bt~ z83@dMJdiP$ce{6ZwGV|@mku!J872axi)@KO^P%@dP9=Y*k>+XS!_qH!e-Sz$ayntQF8ctwgZt&gb6a_CE6<%#0gZv? zLge*~ZO|3ajnKW&TOwyBp;l-*v;x{Aau(mux+w=Jgw?@e(kPseN1ks*uZSHJB*ami${LOJn6c;?jc0eL18J;_PBlp;vpzlr3p&%# z`Zjt^{dCzXXULhjRo{kZ_H*PT zvK=Su=i;;ee7Qh&$c1u|T#Sb7rSdWPxa^cq$Yt_Lw5>md=Ju7$e?E;z`_IbN@;Uju zd;zWPFUgl>mwbi!(lzomxmNxOjn?Z~fBd@Kh|cRxa`Ew>>j-!9*k z@5%R(P=6qI$`9p7hzxhjJ#w%7SniYi znx2xU%f^jrTzL41k!_>eM~@jhZv2Ff&aR2L4xKV}+F{dY%$(J8 z`0P1z=gnWRaM9u;mK?eCsAWeVvwX$MRjbz=yLR1iy~nTbqbfIU`p}6do&4d=r))X( zw9~hqapqau&OYZO+dq2ldFNlS;7813=K0XqL$`z;Xsl?gYaH6x+&H3fLgTci z=4KY2o72rX><`y94{aXZys){i`9s4Wf79qpKpN#b;yc_q#_21I?_uKGTZ}K?Sku_h z*l6RMdQg0|{qb!gKD%Cia0UIZzB#fK!(or|_c$KkpDg=(%6ZD!Tl{<0+2{Px`IG&7 z*(v{f)hYeG&N*srY5za-lw0Z3$`gJ}uYVcNa1}h^YxM0K;fR;h122UqXurA=o^Toc zcOU)iT6+FJ=xJ}m5xz}7egqDnyy-J=r=P>09;Ijhve>g{U3~x$v^{;A7{*Rj!AZ?XcYJb^86? za0=xL%6*hG++%seP4J7o@QV`v*bgt+1rPhG7Qz_gb9W;YIJsXtPpWlSQ?^U1H8pnfji@90BXM&dq4%Jtfu7 z_1u4qjj%tU3Xw;(A0G)CM~OHST}fVsn3q^hKfkcYtde^3DDQoR*Gwn0o8R7Iqhcb< ztkX#AMoF1AVF^*%LmhkF@ihQkp5T6i(Mr|=@0_^$aI zzpY01^)Tsmepz_UISe05Yh;#bDg295h5fvFI6a$Kc-i?8?}vf)L7d2}sVbOY>Hw5)UGt zdUFwF<`$mhjO%>8Z*DLAUhBrvKD1Y>kPhBMOOw2YTMI8x_9@Ma4XgE}Wwj2x8aHv+ za-+^{xlu1pFFTinQ*CLqF>kO0xb&8|^PE z>O9;=8?6Ex5+3C!&K}yNlD19AK37kBrQEgd<>tb2)&+{=sf~8vg?2pfrI?PkKdl#i zhivHqIPGj?4M)(o8O4)Y`)@_s>$-YjzsUJ>O0^4c=wv(?CDeQ>RFZP+peYYS1ZIsi@$(lCvSvA{Ml-4dbOJs84ad_mJNT|1(wT0KEyYLvCXsJ089<35tPCkv_ zMtnBon{b0XVxC5_JPJP6j7+%}4z?Ic@)GlG;jNNPX?_XUbIpTr#-wb)BD-?gg!xI~ zA6BM32flkg2)+zwM0P`4_X7BCART@c&hRC8H*TT8a=O{edV3QRb)|gB{D$#l3gi3> zX1}arXLc5n@13&A{JhZ3NU?#@MJ3$_Y4N`*yg>{2E)w_%^Bi`JUxW8vBiG4p4(6VL zMBOC|uz7m8x!UpYN#2Wv&mVA({Li$xj!?DS?YwF}hopXj^G4wna(S=wCU)pvN? zsRrMmZRD+5cZnILuVs8&i9~&sIhB5Mh4X^*7y4>czE>E+cygnB%Y-=hyh3gYof*0m zN&gb$`oju~LKlQSYQAB~q~;s3m{P;J{Bf z7n}Q>vzeh}n1?)Mh7_ioJbDwg=HAdMbGH+g6P@E}i$mFAdr2D1ZE%gnj5OHBb^dO~ znl7^o8^KMo(^N2K&qmvV{>61aQeI?`{!tQy2l+{F9lmATSzu~>(}XT9RMAr}WklAC zxvm_DCtL|(;Ua?BO2dbUVMhezvk(?XxJ)R*<>Dbz{aB(b8;!(W7q>josOu)8t__I` zqDUAQns{B}`M5q2)^9Q1@hrsS8U-)GFGNd1He%xBLXahPA;x&fL_9Z)d07%8wkSE{ zIo0XFL5R2^qVZhK8#ZX&2zI3`62mLs2*^bcz4RlA>t(|X^5WrTmY>n0Mr&K&fei-5 z!k;FuUOil(@=pktaBOSxAB!d3STw}pFaA-()>qA~2M&uJH0&E5zs#0Z0D<$`dxWP?!=7G0%;G9c5rjJVuISj61O+c11^yG=0TRS}_Gvx(0!5 zZ(+I{>{yj?6WC>=lmUYWLJn`+tl46WqMA&EMeK<xU4J9<= zVU5Mpx-%hiqM<1Xy^7IlDe9$F#CjcHBo>b+xShmcwB9A|kW2gHxvZ-E11&tLD-Xc?gnzi)i}evTQJml(8>esxDIk@>aln@9CMQ% ziIS3sf#$dyjw)mtv>V|!f`^h?1Jpb<#O*M}Nif%odkU!7@-r(SrJ~55n$eJmG-|mWn*ZPJ;@? zKm-=hM*&MdJWmVLjeErG;3#o;MyqY8nH0#2Fp1h)Z5x8zz!y?KoQnn zwzf5o8jSMfLK&1VLX3Vm6idaUf`N({ans(x4kXrf*cV~h*7M>ik8=|id(1}ealLGqL0(eX1lS`{3@|1L7Ab-OyKRvH_5>BL|AdIguv^R*+Giq*Z#2ao z{H;P%x!y5ZLxsI-j)I<8i!6((U7b(NoKj z7&WO$khfS8@N{!85s7%Q3@5HAeh=5B3C>=*><{n+Ev|??t(8VkSAM`vIxNBB$wX3N zYV+sPTxl?x6Bmq%IukFMOmjQK$YaYE;EWmAkB0%Unn$o?7*Ls{4mDs;!X9W0T#6lQ zeQ`U)V5|veqY9>U*)W5=WGZ}7b{qFH*cFOIu|yE|V$`~=mKaTr7V9UqFyjff!xHhV zPofm9pTxkI2X++9fE0(fd3Y`iXFLFbUHO4WhmU}X)|~VeW)ZtGyr2&dJ!{<-d&2iK zR9iObaweL-Pi%}CF0Ch`>zD+?15YxU_4QG(`>=-r>`5Nri3mYR%lCsZ+QJ_Mw!MWl zSg=Q34@(vO*f~i@E7Z12^4i7l%tp*fU$N(~HJ7CPQ+{RA_ZY;nKIU^FR?hX{Az{gpSf&Hq0O|xvBtrB9YVJZUQi10K09GBu|S4dqUx- zqS2(6Pm>JIDwV48QwjPx!2zk*wNFHH+9lv}2@hL$boeOsnMkDlB6i!-HAleZBKic_ z=@5!N$L+k&Zm*Utz!iH+v8S+5$`%yZ{d_6{>i`kWGObqPOxMql~$MpRK%Ji4MtnyV&JA#iJwmAxm}Tpi7i_WVl!UC`(S>o z+Y<~w9jR1BI%<2iq`^*O;8N^Vb~35hQ=AJ;r_-85@v>nCd8w$)AVEfB7%$I&Jq9C* zBteAuq~jPBO>fPlePYJ72{9)sGb9T3Ou9Ce#*z&n`G?cEK4~W+6-n4El1ws@gTH}2 znNBB@nRG^BCIgPAc?9kNcG|0?GMNhCR;J@Z{7K@*|7bKu&xz`e1=urDKvia8BIb*X|6$F+gp`&S+Kj<1+BE$eX#pr*8!QfYyD{^vKil3_!)dG zC9AR|L$k_e>e3n9akvBrQWESwxdl6n7VLg94}U}G@$uw{U4-oWvD;=qBgPCwoc1ay zj2=WIewD=z-}Bul|8ZK6&Wy4I%S1DobXAtdN6+R?CQL`*(t2k*T+@$IJfxMyOdr>O zjJ=AZB#PZn5htRCk0k0RY4Mz2VILsCp39_&IhjU7Kb@?`nO&M@mCM#=vKD)iC*U+O zJPBjcsM2SMfy1YgIQE0l2iS9&oWfML$EEoKE*FhB#o(L*dpeh^;&wICmMvR=BP#^h z*`*>_7VMeotV<-+X4cOZv1`p*>^gpCGTBTnm(wJQmln@pS9L=Xd%7C$TP`kBJ=_r~ zb}J%i_emx7yrIGed&aNHQ{Z&pe6}HzMFYkKGLRH|%5{DGO)$tPcE1w-26pNb?Z#}r z47=u$?#WfePJ0z{Tupj4xV+AAo48%Yo=d{`vyumUjst$#njE4fl|pG`!*m2L#h&E> zo^ai477qki6)hqE;5J_~G|$W-=3z_}6XHeeJ`)??Vkdd9=X2>4o@+BXHPLG| zXY#qB*&GKIscr(nmSgF(Vy_0f&(t{W>o^d@wQeqlpZ08CVG>ZU0qk_(G=hm@C&x8Z zbuE%6hELMDG>)Z^r}Igsn(R#yEbr!W**dg0E%tmWSB5>u1EjCmDQB?j1tKn6K7+jc EJEXL@qyPW_ diff --git a/vendor/fpdf/tutorial/calligra.z b/vendor/fpdf/tutorial/calligra.z deleted file mode 100644 index 1c0bebd20b3f68fe84a44520cc93c7cee39f2792..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 25604 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 jkH^DoB9A@c#fz}Vaf2UWPe| - - - -Tutorials - - - -

Tutorials

-
- - diff --git a/vendor/fpdf/tutorial/logo.png b/vendor/fpdf/tutorial/logo.png deleted file mode 100644 index 284a0071c850b5a2f1ba86f16775c5c0da9fe082..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2373 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 diff --git a/vendor/fpdf/tutorial/tuto1.htm b/vendor/fpdf/tutorial/tuto1.htm deleted file mode 100644 index a3e993d5..00000000 --- a/vendor/fpdf/tutorial/tuto1.htm +++ /dev/null @@ -1,76 +0,0 @@ - - - - -Minimal example - - - -

Minimal example

-Let's start with the classic example: -
-
<?php
-require('fpdf.php');
-
-$pdf = new FPDF();
-$pdf->AddPage();
-$pdf->SetFont('Arial','B',16);
-$pdf->Cell(40,10,'Hello World!');
-$pdf->Output();
-?>
-
-

[Demo]

-After including the library file, we create an FPDF object. -The FPDF() constructor is used here with the default values: pages are in A4 portrait and -the unit of measure is millimeter. It could have been specified explicitly with: -
-
$pdf = new FPDF('P','mm','A4');
-
-
-It's possible to use landscape (L), other page sizes (such as Letter and -Legal) and units (pt, cm, in). -
-
-There's no page at the moment, so we have to add one with AddPage(). The origin -is at the upper-left corner and the current position is by default set at 1 cm from the -borders; the margins can be changed with SetMargins(). -
-
-Before we can print text, it's mandatory to select a font with SetFont(), otherwise the -document would be invalid. We choose Arial bold 16: -
-
$pdf->SetFont('Arial','B',16);
-
-
-We could have specified italics with I, underlined with U or a regular font with an empty string -(or any combination). Note that the font size is given in points, not millimeters (or another user -unit); it's the only exception. The other standard fonts are Times, Courier, Symbol and ZapfDingbats. -
-
-We can now print a cell with Cell(). A cell is a rectangular area, possibly framed, -which contains a line of text. It is output at the current position. We specify its dimensions, -its text (centered or aligned), if borders should be drawn, and where the current position -moves after it (to the right, below or to the beginning of the next line). To add a frame, we would do this: -
-
$pdf->Cell(40,10,'Hello World !',1);
-
-
-To add a new cell next to it with centered text and go to the next line, we would do: -
-
$pdf->Cell(60,10,'Powered by FPDF.',0,1,'C');
-
-
-Remark: the line break can also be done with Ln(). This method additionnaly allows to specify -the height of the break. -
-
-Finally, the document is closed and sent to the browser with Output(). We could have saved -it to a file by passing the desired file name. -
-
-Caution: in case when the PDF is sent to the browser, nothing else must be output by the -script, neither before nor after (no HTML, not even a space or a carriage return). If you send something -before, you will get the error message: "Some data has already been output, can't send PDF file". If you -send something after, the document might not display. - - diff --git a/vendor/fpdf/tutorial/tuto1.php b/vendor/fpdf/tutorial/tuto1.php deleted file mode 100644 index 3ab55a10..00000000 --- a/vendor/fpdf/tutorial/tuto1.php +++ /dev/null @@ -1,9 +0,0 @@ -AddPage(); -$pdf->SetFont('Arial','B',16); -$pdf->Cell(40,10,'Hello World!'); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto2.htm b/vendor/fpdf/tutorial/tuto2.htm deleted file mode 100644 index c402cf44..00000000 --- a/vendor/fpdf/tutorial/tuto2.htm +++ /dev/null @@ -1,80 +0,0 @@ - - - - -Header, footer, page break and image - - - -

Header, footer, page break and image

-Here's a two page example with header, footer and logo: -
-
<?php
-require('fpdf.php');
-
-class PDF extends FPDF
-{
-// Page header
-function Header()
-{
-    // Logo
-    $this->Image('logo.png',10,6,30);
-    // Arial bold 15
-    $this->SetFont('Arial','B',15);
-    // Move to the right
-    $this->Cell(80);
-    // Title
-    $this->Cell(30,10,'Title',1,0,'C');
-    // Line break
-    $this->Ln(20);
-}
-
-// Page footer
-function Footer()
-{
-    // Position at 1.5 cm from bottom
-    $this->SetY(-15);
-    // Arial italic 8
-    $this->SetFont('Arial','I',8);
-    // Page number
-    $this->Cell(0,10,'Page '.$this->PageNo().'/{nb}',0,0,'C');
-}
-}
-
-// Instanciation of inherited class
-$pdf = new PDF();
-$pdf->AliasNbPages();
-$pdf->AddPage();
-$pdf->SetFont('Times','',12);
-for($i=1;$i<=40;$i++)
-    $pdf->Cell(0,10,'Printing line number '.$i,0,1);
-$pdf->Output();
-?>
-
-

[Demo]

-This example makes use of the Header() and Footer() methods to process page headers and -footers. They are called automatically. They already exist in the FPDF class but do nothing, -therefore we have to extend the class and override them. -
-
-The logo is printed with the Image() method by specifying its upper-left corner and -its width. The height is calculated automatically to respect the image proportions. -
-
-To print the page number, a null value is passed as the cell width. It means that the cell -should extend up to the right margin of the page; this is handy to center text. The current page -number is returned by the PageNo() method; as for the total number of pages, it's obtained -via the special value {nb} which is substituted when the document is finished -(provided you first called AliasNbPages()). -
-Note the use of the SetY() method which allows to set position at an absolute location in -the page, starting from the top or the bottom. -
-
-Another interesting feature is used here: the automatic page breaking. As soon as a cell would -cross a limit in the page (at 2 centimeters from the bottom by default), a break is issued -and the font restored. Although the header and footer select their own font (Arial), the body -continues with Times. This mechanism of automatic restoration also applies to colors and line -width. The limit which triggers page breaks can be set with SetAutoPageBreak(). - - diff --git a/vendor/fpdf/tutorial/tuto2.php b/vendor/fpdf/tutorial/tuto2.php deleted file mode 100644 index 6a1b4f86..00000000 --- a/vendor/fpdf/tutorial/tuto2.php +++ /dev/null @@ -1,41 +0,0 @@ -Image('logo.png',10,6,30); - // Arial bold 15 - $this->SetFont('Arial','B',15); - // Move to the right - $this->Cell(80); - // Title - $this->Cell(30,10,'Title',1,0,'C'); - // Line break - $this->Ln(20); -} - -// Page footer -function Footer() -{ - // Position at 1.5 cm from bottom - $this->SetY(-15); - // Arial italic 8 - $this->SetFont('Arial','I',8); - // Page number - $this->Cell(0,10,'Page '.$this->PageNo().'/{nb}',0,0,'C'); -} -} - -// Instanciation of inherited class -$pdf = new PDF(); -$pdf->AliasNbPages(); -$pdf->AddPage(); -$pdf->SetFont('Times','',12); -for($i=1;$i<=40;$i++) - $pdf->Cell(0,10,'Printing line number '.$i,0,1); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto3.htm b/vendor/fpdf/tutorial/tuto3.htm deleted file mode 100644 index 5d8363f5..00000000 --- a/vendor/fpdf/tutorial/tuto3.htm +++ /dev/null @@ -1,115 +0,0 @@ - - - - -Line breaks and colors - - - -

Line breaks and colors

-Let's continue with an example which prints justified paragraphs. It also illustrates the use -of colors. -
-
<?php
-require('fpdf.php');
-
-class PDF extends FPDF
-{
-function Header()
-{
-    global $title;
-
-    // Arial bold 15
-    $this->SetFont('Arial','B',15);
-    // Calculate width of title and position
-    $w = $this->GetStringWidth($title)+6;
-    $this->SetX((210-$w)/2);
-    // Colors of frame, background and text
-    $this->SetDrawColor(0,80,180);
-    $this->SetFillColor(230,230,0);
-    $this->SetTextColor(220,50,50);
-    // Thickness of frame (1 mm)
-    $this->SetLineWidth(1);
-    // Title
-    $this->Cell($w,9,$title,1,1,'C',true);
-    // Line break
-    $this->Ln(10);
-}
-
-function Footer()
-{
-    // Position at 1.5 cm from bottom
-    $this->SetY(-15);
-    // Arial italic 8
-    $this->SetFont('Arial','I',8);
-    // Text color in gray
-    $this->SetTextColor(128);
-    // Page number
-    $this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C');
-}
-
-function ChapterTitle($num, $label)
-{
-    // Arial 12
-    $this->SetFont('Arial','',12);
-    // Background color
-    $this->SetFillColor(200,220,255);
-    // Title
-    $this->Cell(0,6,"Chapter $num : $label",0,1,'L',true);
-    // Line break
-    $this->Ln(4);
-}
-
-function ChapterBody($file)
-{
-    // Read text file
-    $txt = file_get_contents($file);
-    // Times 12
-    $this->SetFont('Times','',12);
-    // Output justified text
-    $this->MultiCell(0,5,$txt);
-    // Line break
-    $this->Ln();
-    // Mention in italics
-    $this->SetFont('','I');
-    $this->Cell(0,5,'(end of excerpt)');
-}
-
-function PrintChapter($num, $title, $file)
-{
-    $this->AddPage();
-    $this->ChapterTitle($num,$title);
-    $this->ChapterBody($file);
-}
-}
-
-$pdf = new PDF();
-$title = '20000 Leagues Under the Seas';
-$pdf->SetTitle($title);
-$pdf->SetAuthor('Jules Verne');
-$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt');
-$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt');
-$pdf->Output();
-?>
-
-

[Demo]

-The GetStringWidth() method allows to determine the length of a string in the current font, -which is used here to calculate the position and the width of the frame surrounding the title. -Then colors are set (via SetDrawColor(), SetFillColor() and SetTextColor()) and the -thickness of the line is set to 1 mm (instead of 0.2 by default) with SetLineWidth(). Finally, -we output the cell (the last parameter true indicates that the background must -be filled). -
-
-The method used to print the paragraphs is MultiCell(). Each time a line reaches the -right extremity of the cell or a carriage return character is met, a line break is issued -and a new cell automatically created under the current one. Text is justified by default. -
-
-Two document properties are defined: the title (SetTitle()) and the author (SetAuthor()). -There are several ways to view them in Adobe Reader. The first one is to open the file directly with -the reader, go to the File menu and choose the Properties option. The second one, also available from -the plug-in, is to right-click and select Document Properties. The third method is to type the Ctrl+D -key combination. - - diff --git a/vendor/fpdf/tutorial/tuto3.php b/vendor/fpdf/tutorial/tuto3.php deleted file mode 100644 index 3316ddb0..00000000 --- a/vendor/fpdf/tutorial/tuto3.php +++ /dev/null @@ -1,81 +0,0 @@ -SetFont('Arial','B',15); - // Calculate width of title and position - $w = $this->GetStringWidth($title)+6; - $this->SetX((210-$w)/2); - // Colors of frame, background and text - $this->SetDrawColor(0,80,180); - $this->SetFillColor(230,230,0); - $this->SetTextColor(220,50,50); - // Thickness of frame (1 mm) - $this->SetLineWidth(1); - // Title - $this->Cell($w,9,$title,1,1,'C',true); - // Line break - $this->Ln(10); -} - -function Footer() -{ - // Position at 1.5 cm from bottom - $this->SetY(-15); - // Arial italic 8 - $this->SetFont('Arial','I',8); - // Text color in gray - $this->SetTextColor(128); - // Page number - $this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C'); -} - -function ChapterTitle($num, $label) -{ - // Arial 12 - $this->SetFont('Arial','',12); - // Background color - $this->SetFillColor(200,220,255); - // Title - $this->Cell(0,6,"Chapter $num : $label",0,1,'L',true); - // Line break - $this->Ln(4); -} - -function ChapterBody($file) -{ - // Read text file - $txt = file_get_contents($file); - // Times 12 - $this->SetFont('Times','',12); - // Output justified text - $this->MultiCell(0,5,$txt); - // Line break - $this->Ln(); - // Mention in italics - $this->SetFont('','I'); - $this->Cell(0,5,'(end of excerpt)'); -} - -function PrintChapter($num, $title, $file) -{ - $this->AddPage(); - $this->ChapterTitle($num,$title); - $this->ChapterBody($file); -} -} - -$pdf = new PDF(); -$title = '20000 Leagues Under the Seas'; -$pdf->SetTitle($title); -$pdf->SetAuthor('Jules Verne'); -$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt'); -$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt'); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto4.htm b/vendor/fpdf/tutorial/tuto4.htm deleted file mode 100644 index 18a21081..00000000 --- a/vendor/fpdf/tutorial/tuto4.htm +++ /dev/null @@ -1,134 +0,0 @@ - - - - -Multi-columns - - - -

Multi-columns

-This example is a variant of the previous one showing how to lay the text across multiple -columns. -
-
<?php
-require('fpdf.php');
-
-class PDF extends FPDF
-{
-// Current column
-var $col = 0;
-// Ordinate of column start
-var $y0;
-
-function Header()
-{
-    // Page header
-    global $title;
-
-    $this->SetFont('Arial','B',15);
-    $w = $this->GetStringWidth($title)+6;
-    $this->SetX((210-$w)/2);
-    $this->SetDrawColor(0,80,180);
-    $this->SetFillColor(230,230,0);
-    $this->SetTextColor(220,50,50);
-    $this->SetLineWidth(1);
-    $this->Cell($w,9,$title,1,1,'C',true);
-    $this->Ln(10);
-    // Save ordinate
-    $this->y0 = $this->GetY();
-}
-
-function Footer()
-{
-    // Page footer
-    $this->SetY(-15);
-    $this->SetFont('Arial','I',8);
-    $this->SetTextColor(128);
-    $this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C');
-}
-
-function SetCol($col)
-{
-    // Set position at a given column
-    $this->col = $col;
-    $x = 10+$col*65;
-    $this->SetLeftMargin($x);
-    $this->SetX($x);
-}
-
-function AcceptPageBreak()
-{
-    // Method accepting or not automatic page break
-    if($this->col<2)
-    {
-        // Go to next column
-        $this->SetCol($this->col+1);
-        // Set ordinate to top
-        $this->SetY($this->y0);
-        // Keep on page
-        return false;
-    }
-    else
-    {
-        // Go back to first column
-        $this->SetCol(0);
-        // Page break
-        return true;
-    }
-}
-
-function ChapterTitle($num, $label)
-{
-    // Title
-    $this->SetFont('Arial','',12);
-    $this->SetFillColor(200,220,255);
-    $this->Cell(0,6,"Chapter $num : $label",0,1,'L',true);
-    $this->Ln(4);
-    // Save ordinate
-    $this->y0 = $this->GetY();
-}
-
-function ChapterBody($file)
-{
-    // Read text file
-    $txt = file_get_contents($file);
-    // Font
-    $this->SetFont('Times','',12);
-    // Output text in a 6 cm width column
-    $this->MultiCell(60,5,$txt);
-    $this->Ln();
-    // Mention
-    $this->SetFont('','I');
-    $this->Cell(0,5,'(end of excerpt)');
-    // Go back to first column
-    $this->SetCol(0);
-}
-
-function PrintChapter($num, $title, $file)
-{
-    // Add chapter
-    $this->AddPage();
-    $this->ChapterTitle($num,$title);
-    $this->ChapterBody($file);
-}
-}
-
-$pdf = new PDF();
-$title = '20000 Leagues Under the Seas';
-$pdf->SetTitle($title);
-$pdf->SetAuthor('Jules Verne');
-$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt');
-$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt');
-$pdf->Output();
-?>
-
-

[Demo]

-The key method used is AcceptPageBreak(). It allows to accept or not an automatic page -break. By refusing it and altering the margin and current position, the desired column layout -is achieved. -
-For the rest, not many changes; two properties have been added to the class to save the current -column number and the position where columns begin, and the MultiCell() call specifies a -6 centimeter width. - - diff --git a/vendor/fpdf/tutorial/tuto4.php b/vendor/fpdf/tutorial/tuto4.php deleted file mode 100644 index c3269827..00000000 --- a/vendor/fpdf/tutorial/tuto4.php +++ /dev/null @@ -1,111 +0,0 @@ -SetFont('Arial','B',15); - $w = $this->GetStringWidth($title)+6; - $this->SetX((210-$w)/2); - $this->SetDrawColor(0,80,180); - $this->SetFillColor(230,230,0); - $this->SetTextColor(220,50,50); - $this->SetLineWidth(1); - $this->Cell($w,9,$title,1,1,'C',true); - $this->Ln(10); - // Save ordinate - $this->y0 = $this->GetY(); -} - -function Footer() -{ - // Page footer - $this->SetY(-15); - $this->SetFont('Arial','I',8); - $this->SetTextColor(128); - $this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C'); -} - -function SetCol($col) -{ - // Set position at a given column - $this->col = $col; - $x = 10+$col*65; - $this->SetLeftMargin($x); - $this->SetX($x); -} - -function AcceptPageBreak() -{ - // Method accepting or not automatic page break - if($this->col<2) - { - // Go to next column - $this->SetCol($this->col+1); - // Set ordinate to top - $this->SetY($this->y0); - // Keep on page - return false; - } - else - { - // Go back to first column - $this->SetCol(0); - // Page break - return true; - } -} - -function ChapterTitle($num, $label) -{ - // Title - $this->SetFont('Arial','',12); - $this->SetFillColor(200,220,255); - $this->Cell(0,6,"Chapter $num : $label",0,1,'L',true); - $this->Ln(4); - // Save ordinate - $this->y0 = $this->GetY(); -} - -function ChapterBody($file) -{ - // Read text file - $txt = file_get_contents($file); - // Font - $this->SetFont('Times','',12); - // Output text in a 6 cm width column - $this->MultiCell(60,5,$txt); - $this->Ln(); - // Mention - $this->SetFont('','I'); - $this->Cell(0,5,'(end of excerpt)'); - // Go back to first column - $this->SetCol(0); -} - -function PrintChapter($num, $title, $file) -{ - // Add chapter - $this->AddPage(); - $this->ChapterTitle($num,$title); - $this->ChapterBody($file); -} -} - -$pdf = new PDF(); -$title = '20000 Leagues Under the Seas'; -$pdf->SetTitle($title); -$pdf->SetAuthor('Jules Verne'); -$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt'); -$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt'); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto5.htm b/vendor/fpdf/tutorial/tuto5.htm deleted file mode 100644 index f90102bd..00000000 --- a/vendor/fpdf/tutorial/tuto5.htm +++ /dev/null @@ -1,134 +0,0 @@ - - - - -Tables - - - -

Tables

-This tutorial shows different ways to make tables. -
-
<?php
-require('fpdf.php');
-
-class PDF extends FPDF
-{
-// Load data
-function LoadData($file)
-{
-    // Read file lines
-    $lines = file($file);
-    $data = array();
-    foreach($lines as $line)
-        $data[] = explode(';',trim($line));
-    return $data;
-}
-
-// Simple table
-function BasicTable($header, $data)
-{
-    // Header
-    foreach($header as $col)
-        $this->Cell(40,7,$col,1);
-    $this->Ln();
-    // Data
-    foreach($data as $row)
-    {
-        foreach($row as $col)
-            $this->Cell(40,6,$col,1);
-        $this->Ln();
-    }
-}
-
-// Better table
-function ImprovedTable($header, $data)
-{
-    // Column widths
-    $w = array(40, 35, 40, 45);
-    // Header
-    for($i=0;$i<count($header);$i++)
-        $this->Cell($w[$i],7,$header[$i],1,0,'C');
-    $this->Ln();
-    // Data
-    foreach($data as $row)
-    {
-        $this->Cell($w[0],6,$row[0],'LR');
-        $this->Cell($w[1],6,$row[1],'LR');
-        $this->Cell($w[2],6,number_format($row[2]),'LR',0,'R');
-        $this->Cell($w[3],6,number_format($row[3]),'LR',0,'R');
-        $this->Ln();
-    }
-    // Closing line
-    $this->Cell(array_sum($w),0,'','T');
-}
-
-// Colored table
-function FancyTable($header, $data)
-{
-    // Colors, line width and bold font
-    $this->SetFillColor(255,0,0);
-    $this->SetTextColor(255);
-    $this->SetDrawColor(128,0,0);
-    $this->SetLineWidth(.3);
-    $this->SetFont('','B');
-    // Header
-    $w = array(40, 35, 40, 45);
-    for($i=0;$i<count($header);$i++)
-        $this->Cell($w[$i],7,$header[$i],1,0,'C',true);
-    $this->Ln();
-    // Color and font restoration
-    $this->SetFillColor(224,235,255);
-    $this->SetTextColor(0);
-    $this->SetFont('');
-    // Data
-    $fill = false;
-    foreach($data as $row)
-    {
-        $this->Cell($w[0],6,$row[0],'LR',0,'L',$fill);
-        $this->Cell($w[1],6,$row[1],'LR',0,'L',$fill);
-        $this->Cell($w[2],6,number_format($row[2]),'LR',0,'R',$fill);
-        $this->Cell($w[3],6,number_format($row[3]),'LR',0,'R',$fill);
-        $this->Ln();
-        $fill = !$fill;
-    }
-    // Closing line
-    $this->Cell(array_sum($w),0,'','T');
-}
-}
-
-$pdf = new PDF();
-// Column headings
-$header = array('Country', 'Capital', 'Area (sq km)', 'Pop. (thousands)');
-// Data loading
-$data = $pdf->LoadData('countries.txt');
-$pdf->SetFont('Arial','',14);
-$pdf->AddPage();
-$pdf->BasicTable($header,$data);
-$pdf->AddPage();
-$pdf->ImprovedTable($header,$data);
-$pdf->AddPage();
-$pdf->FancyTable($header,$data);
-$pdf->Output();
-?>
-
-

[Demo]

-A table being just a collection of cells, it's natural to build one from them. The first -example is achieved in the most basic way possible: simple framed cells, all of the same size -and left aligned. The result is rudimentary but very quick to obtain. -
-
-The second table brings some improvements: each column has its own width, headings are centered, -and numbers right aligned. Moreover, horizontal lines have been removed. This is done by means -of the border parameter of the Cell() method, which specifies which sides of the -cell must be drawn. Here we want the left (L) and right (R) ones. It remains -the problem of the horizontal line to finish the table. There are two possibilities: either -check for the last line in the loop, in which case we use LRB for the border -parameter; or, as done here, add the line once the loop is over. -
-
-The third table is similar to the second one but uses colors. Fill, text and line colors are -simply specified. Alternate coloring for rows is obtained by using alternatively transparent -and filled cells. - - diff --git a/vendor/fpdf/tutorial/tuto5.php b/vendor/fpdf/tutorial/tuto5.php deleted file mode 100644 index 252b70f2..00000000 --- a/vendor/fpdf/tutorial/tuto5.php +++ /dev/null @@ -1,102 +0,0 @@ -Cell(40,7,$col,1); - $this->Ln(); - // Data - foreach($data as $row) - { - foreach($row as $col) - $this->Cell(40,6,$col,1); - $this->Ln(); - } -} - -// Better table -function ImprovedTable($header, $data) -{ - // Column widths - $w = array(40, 35, 40, 45); - // Header - for($i=0;$iCell($w[$i],7,$header[$i],1,0,'C'); - $this->Ln(); - // Data - foreach($data as $row) - { - $this->Cell($w[0],6,$row[0],'LR'); - $this->Cell($w[1],6,$row[1],'LR'); - $this->Cell($w[2],6,number_format($row[2]),'LR',0,'R'); - $this->Cell($w[3],6,number_format($row[3]),'LR',0,'R'); - $this->Ln(); - } - // Closing line - $this->Cell(array_sum($w),0,'','T'); -} - -// Colored table -function FancyTable($header, $data) -{ - // Colors, line width and bold font - $this->SetFillColor(255,0,0); - $this->SetTextColor(255); - $this->SetDrawColor(128,0,0); - $this->SetLineWidth(.3); - $this->SetFont('','B'); - // Header - $w = array(40, 35, 40, 45); - for($i=0;$iCell($w[$i],7,$header[$i],1,0,'C',true); - $this->Ln(); - // Color and font restoration - $this->SetFillColor(224,235,255); - $this->SetTextColor(0); - $this->SetFont(''); - // Data - $fill = false; - foreach($data as $row) - { - $this->Cell($w[0],6,$row[0],'LR',0,'L',$fill); - $this->Cell($w[1],6,$row[1],'LR',0,'L',$fill); - $this->Cell($w[2],6,number_format($row[2]),'LR',0,'R',$fill); - $this->Cell($w[3],6,number_format($row[3]),'LR',0,'R',$fill); - $this->Ln(); - $fill = !$fill; - } - // Closing line - $this->Cell(array_sum($w),0,'','T'); -} -} - -$pdf = new PDF(); -// Column headings -$header = array('Country', 'Capital', 'Area (sq km)', 'Pop. (thousands)'); -// Data loading -$data = $pdf->LoadData('countries.txt'); -$pdf->SetFont('Arial','',14); -$pdf->AddPage(); -$pdf->BasicTable($header,$data); -$pdf->AddPage(); -$pdf->ImprovedTable($header,$data); -$pdf->AddPage(); -$pdf->FancyTable($header,$data); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto6.htm b/vendor/fpdf/tutorial/tuto6.htm deleted file mode 100644 index 59ef1776..00000000 --- a/vendor/fpdf/tutorial/tuto6.htm +++ /dev/null @@ -1,165 +0,0 @@ - - - - -Links and flowing text - - - -

Links and flowing text

-This tutorial explains how to insert links (internal and external) and shows a new text writing -mode. It also contains a basic HTML parser. -
-
<?php
-require('fpdf.php');
-
-class PDF extends FPDF
-{
-var $B;
-var $I;
-var $U;
-var $HREF;
-
-function PDF($orientation='P', $unit='mm', $size='A4')
-{
-    // Call parent constructor
-    $this->FPDF($orientation,$unit,$size);
-    // Initialization
-    $this->B = 0;
-    $this->I = 0;
-    $this->U = 0;
-    $this->HREF = '';
-}
-
-function WriteHTML($html)
-{
-    // HTML parser
-    $html = str_replace("\n",' ',$html);
-    $a = preg_split('/<(.*)>/U',$html,-1,PREG_SPLIT_DELIM_CAPTURE);
-    foreach($a as $i=>$e)
-    {
-        if($i%2==0)
-        {
-            // Text
-            if($this->HREF)
-                $this->PutLink($this->HREF,$e);
-            else
-                $this->Write(5,$e);
-        }
-        else
-        {
-            // Tag
-            if($e[0]=='/')
-                $this->CloseTag(strtoupper(substr($e,1)));
-            else
-            {
-                // Extract attributes
-                $a2 = explode(' ',$e);
-                $tag = strtoupper(array_shift($a2));
-                $attr = array();
-                foreach($a2 as $v)
-                {
-                    if(preg_match('/([^=]*)=["\']?([^"\']*)/',$v,$a3))
-                        $attr[strtoupper($a3[1])] = $a3[2];
-                }
-                $this->OpenTag($tag,$attr);
-            }
-        }
-    }
-}
-
-function OpenTag($tag, $attr)
-{
-    // Opening tag
-    if($tag=='B' || $tag=='I' || $tag=='U')
-        $this->SetStyle($tag,true);
-    if($tag=='A')
-        $this->HREF = $attr['HREF'];
-    if($tag=='BR')
-        $this->Ln(5);
-}
-
-function CloseTag($tag)
-{
-    // Closing tag
-    if($tag=='B' || $tag=='I' || $tag=='U')
-        $this->SetStyle($tag,false);
-    if($tag=='A')
-        $this->HREF = '';
-}
-
-function SetStyle($tag, $enable)
-{
-    // Modify style and select corresponding font
-    $this->$tag += ($enable ? 1 : -1);
-    $style = '';
-    foreach(array('B', 'I', 'U') as $s)
-    {
-        if($this->$s>0)
-            $style .= $s;
-    }
-    $this->SetFont('',$style);
-}
-
-function PutLink($URL, $txt)
-{
-    // Put a hyperlink
-    $this->SetTextColor(0,0,255);
-    $this->SetStyle('U',true);
-    $this->Write(5,$txt,$URL);
-    $this->SetStyle('U',false);
-    $this->SetTextColor(0);
-}
-}
-
-$html = 'You can now easily print text mixing different styles: <b>bold</b>, <i>italic</i>,
-<u>underlined</u>, or <b><i><u>all at once</u></i></b>!<br><br>You can also insert links on
-text, such as <a href="http://www.fpdf.org">www.fpdf.org</a>, or on an image: click on the logo.';
-
-$pdf = new PDF();
-// First page
-$pdf->AddPage();
-$pdf->SetFont('Arial','',20);
-$pdf->Write(5,"To find out what's new in this tutorial, click ");
-$pdf->SetFont('','U');
-$link = $pdf->AddLink();
-$pdf->Write(5,'here',$link);
-$pdf->SetFont('');
-// Second page
-$pdf->AddPage();
-$pdf->SetLink($link);
-$pdf->Image('logo.png',10,12,30,0,'','http://www.fpdf.org');
-$pdf->SetLeftMargin(45);
-$pdf->SetFontSize(14);
-$pdf->WriteHTML($html);
-$pdf->Output();
-?>
-
-

[Demo]

-The new method to print text is Write(). It's very close to MultiCell(); the differences are: -
    -
  • The end of line is at the right margin and the next line begins at the left one
  • -
  • The current position moves at the end of the text
  • -
-So it allows to write a chunk of text, alter the font style, then continue from the exact -place we left it. On the other hand, you cannot justify it. -
-
-The method is used on the first page to put a link pointing to the second one. The beginning of -the sentence is written in regular style, then we switch to underline and finish it. The link -is created with AddLink(), which returns a link identifier. The identifier is -passed as third parameter of Write(). Once the second page is created, we use SetLink() to -make the link point to the beginning of the current page. -
-
-Then we put an image with an external link on it. An external link is just a URL. It's passed as -last parameter of Image(). -
-
-Finally, the left margin is moved after the image with SetLeftMargin() and some text in -HTML format is output. A very simple HTML parser is used for this, based on regular expressions. -Recognized tags are <b>, <i>, <u>, <a> and <br>; the others are -ignored. The parser also makes use of the Write() method. An external link is put the same way as -an internal one (third parameter of Write()). Note that Cell() also allows to put links. - - diff --git a/vendor/fpdf/tutorial/tuto6.php b/vendor/fpdf/tutorial/tuto6.php deleted file mode 100644 index d933556e..00000000 --- a/vendor/fpdf/tutorial/tuto6.php +++ /dev/null @@ -1,124 +0,0 @@ -FPDF($orientation,$unit,$size); - // Initialization - $this->B = 0; - $this->I = 0; - $this->U = 0; - $this->HREF = ''; -} - -function WriteHTML($html) -{ - // HTML parser - $html = str_replace("\n",' ',$html); - $a = preg_split('/<(.*)>/U',$html,-1,PREG_SPLIT_DELIM_CAPTURE); - foreach($a as $i=>$e) - { - if($i%2==0) - { - // Text - if($this->HREF) - $this->PutLink($this->HREF,$e); - else - $this->Write(5,$e); - } - else - { - // Tag - if($e[0]=='/') - $this->CloseTag(strtoupper(substr($e,1))); - else - { - // Extract attributes - $a2 = explode(' ',$e); - $tag = strtoupper(array_shift($a2)); - $attr = array(); - foreach($a2 as $v) - { - if(preg_match('/([^=]*)=["\']?([^"\']*)/',$v,$a3)) - $attr[strtoupper($a3[1])] = $a3[2]; - } - $this->OpenTag($tag,$attr); - } - } - } -} - -function OpenTag($tag, $attr) -{ - // Opening tag - if($tag=='B' || $tag=='I' || $tag=='U') - $this->SetStyle($tag,true); - if($tag=='A') - $this->HREF = $attr['HREF']; - if($tag=='BR') - $this->Ln(5); -} - -function CloseTag($tag) -{ - // Closing tag - if($tag=='B' || $tag=='I' || $tag=='U') - $this->SetStyle($tag,false); - if($tag=='A') - $this->HREF = ''; -} - -function SetStyle($tag, $enable) -{ - // Modify style and select corresponding font - $this->$tag += ($enable ? 1 : -1); - $style = ''; - foreach(array('B', 'I', 'U') as $s) - { - if($this->$s>0) - $style .= $s; - } - $this->SetFont('',$style); -} - -function PutLink($URL, $txt) -{ - // Put a hyperlink - $this->SetTextColor(0,0,255); - $this->SetStyle('U',true); - $this->Write(5,$txt,$URL); - $this->SetStyle('U',false); - $this->SetTextColor(0); -} -} - -$html = 'You can now easily print text mixing different styles: bold, italic, -underlined, or all at once!

You can also insert links on -text, such as www.fpdf.org, or on an image: click on the logo.'; - -$pdf = new PDF(); -// First page -$pdf->AddPage(); -$pdf->SetFont('Arial','',20); -$pdf->Write(5,"To find out what's new in this tutorial, click "); -$pdf->SetFont('','U'); -$link = $pdf->AddLink(); -$pdf->Write(5,'here',$link); -$pdf->SetFont(''); -// Second page -$pdf->AddPage(); -$pdf->SetLink($link); -$pdf->Image('logo.png',10,12,30,0,'','http://www.fpdf.org'); -$pdf->SetLeftMargin(45); -$pdf->SetFontSize(14); -$pdf->WriteHTML($html); -$pdf->Output(); -?> diff --git a/vendor/fpdf/tutorial/tuto7.htm b/vendor/fpdf/tutorial/tuto7.htm deleted file mode 100644 index 28630186..00000000 --- a/vendor/fpdf/tutorial/tuto7.htm +++ /dev/null @@ -1,241 +0,0 @@ - - - - -Adding new fonts and encoding support - - - - -

Adding new fonts and encoding support

-This tutorial explains how to use TrueType, OpenType and Type1 fonts so that you are not limited to -the standard fonts any more. The other benefit is that you can choose the font encoding, which allows -you to use other languages than the Western ones (the standard fonts having too few available characters). -
-
-Remark: for OpenType, only the format based on TrueType is supported (not the one based on Type1). -
-
-There are two ways to use a new font: embedding it in the PDF or not. When a font is not -embedded, it is searched in the system. The advantage is that the PDF file is lighter; on the other -hand, if it's not available, a substitution font is used. So it's preferable to ensure that the -needed font is installed on the client systems. If the file is to be viewed by a large audience, -it's highly recommended to embed. -
-
-Adding a new font requires two steps: -
    -
  • Generation of the font definition file
  • -
  • Declaration of the font in the script
  • -
-For Type1, you need the corresponding AFM file. It's usually provided with the font. - -

Generation of the font definition file

-The first step consists in generating a PHP file containing all the information needed by FPDF; -in addition, the font file is compressed. To do this, a helper script is provided in the makefont -directory of the package: makefont.php. It contains the following function: -
-
-MakeFont(string fontfile, [, string enc [, boolean embed]]) -
-
fontfile
-
-

Path to the .ttf, .otf or .pfb file.

-
-
enc
-
-

Name of the encoding to use. Default value: cp1252.

-
-
embed
-
-

Whether to embed the font or not. Default value: true.

-
-
-The first parameter is the name of the font file. The extension must be either .ttf, .otf or .pfb and -determines the font type. If your Type1 font is in ASCII format (.pfa), you can convert it to binary -(.pfb) with the help of t1utils. -
-
-For Type1 fonts, the corresponding .afm file must be present in the same directory. -
-
-The encoding defines the association between a code (from 0 to 255) and a character. The first 128 are -always the same and correspond to ASCII; the following are variable. Encodings are stored in .map -files. The available ones are: -
    -
  • cp1250 (Central Europe)
  • -
  • cp1251 (Cyrillic)
  • -
  • cp1252 (Western Europe)
  • -
  • cp1253 (Greek)
  • -
  • cp1254 (Turkish)
  • -
  • cp1255 (Hebrew)
  • -
  • cp1257 (Baltic)
  • -
  • cp1258 (Vietnamese)
  • -
  • cp874 (Thai)
  • -
  • ISO-8859-1 (Western Europe)
  • -
  • ISO-8859-2 (Central Europe)
  • -
  • ISO-8859-4 (Baltic)
  • -
  • ISO-8859-5 (Cyrillic)
  • -
  • ISO-8859-7 (Greek)
  • -
  • ISO-8859-9 (Turkish)
  • -
  • ISO-8859-11 (Thai)
  • -
  • ISO-8859-15 (Western Europe)
  • -
  • ISO-8859-16 (Central Europe)
  • -
  • KOI8-R (Russian)
  • -
  • KOI8-U (Ukrainian)
  • -
-Of course, the font must contain the characters corresponding to the chosen encoding. -
-
-Remark: the standard fonts use cp1252. -
-
-After you have called the function (create a new file for this and include makefont.php), a .php file -is created, with the same name as the font file. You may rename it if you wish. If the case of embedding, -the font file is compressed and gives a second file with .z as extension (except if the compression -function is not available, it requires Zlib). You may rename it too, but in this case you have to change -the variable $file in the .php file accordingly. -
-
-Example: -
-
<?php
-require('makefont/makefont.php');
-
-MakeFont('c:\\Windows\\Fonts\\comic.ttf','cp1252');
-?>
-
-which gives the files comic.php and comic.z. -
-
-Then copy the generated files to the font directory. If the font file could not be compressed, copy -it directly instead of the .z version. -
-
-Another way to call MakeFont() is through the command line: -
-
-php makefont\makefont.php c:\Windows\Fonts\comic.ttf cp1252 -
-
-Finally, for TrueType and OpenType fonts, you can also generate the files -online instead of doing it manually. - -

Declaration of the font in the script

-The second step is simple. You just need to call the AddFont() method: -
-
$pdf->AddFont('Comic','','comic.php');
-
-
-And the font is now available (in regular and underlined styles), usable like the others. If we -had worked with Comic Sans MS Bold (comicbd.ttf), we would have written: -
-
$pdf->AddFont('Comic','B','comicbd.php');
-
-
- -

Example

-Let's now see a complete example. We will use the font Calligrapher. -The first step is the generation of the font files: -
-
<?php
-require('makefont/makefont.php');
-
-MakeFont('calligra.ttf','cp1252');
-?>
-
-The script gives the following report: -
-
-Warning: character Euro is missing
-Warning: character zcaron is missing
-Font file compressed: calligra.z
-Font definition file generated: calligra.php
-
-The euro character is not present in the font (it's too old). Another character is missing too. -
-
-Alternatively we could have used the command line: -
-
-php makefont\makefont.php calligra.ttf cp1252 -
-
-or used the online generator. -
-
-We can now copy the two generated files to the font directory and write the script: -
-
<?php
-require('fpdf.php');
-
-$pdf = new FPDF();
-$pdf->AddFont('Calligrapher','','calligra.php');
-$pdf->AddPage();
-$pdf->SetFont('Calligrapher','',35);
-$pdf->Write(10,'Enjoy new fonts with FPDF!');
-$pdf->Output();
-?>
-
-

[Demo]

- -

About the euro symbol

-The euro character is not present in all encodings, and is not always placed at the same position: - - - - - - - - - - - - - - - - - - - - - - -
EncodingPosition
cp1250128
cp1251136
cp1252128
cp1253128
cp1254128
cp1255128
cp1257128
cp1258128
cp874128
ISO-8859-1N/A
ISO-8859-2N/A
ISO-8859-4N/A
ISO-8859-5N/A
ISO-8859-7N/A
ISO-8859-9N/A
ISO-8859-11N/A
ISO-8859-15164
ISO-8859-16164
KOI8-RN/A
KOI8-UN/A
-ISO-8859-1 is widespread but does not include the euro sign. If you need it, the simplest thing -to do is to use cp1252 or ISO-8859-15 instead, which are nearly identical but contain the precious -symbol. - -

Reducing the size of TrueType fonts

-Font files are often quite voluminous; this is due to the fact that they contain the characters -corresponding to many encodings. Zlib compression reduces them but they remain fairly big. A -technique exists to reduce them further. It consists in converting the font to the Type1 format -with ttf2pt1 (the Windows binary is -available here) while specifying the encoding -you are interested in; all other characters will be discarded. -
-For example, the arial.ttf font that ships with Windows Vista weights 748 KB (it contains 3381 characters). -After compression it drops to 411. Let's convert it to Type1 by keeping only cp1250 characters: -
-
-ttf2pt1 -b -L cp1250.map c:\Windows\Fonts\arial.ttf arial -
-
-The .map files are located in the makefont directory of the package. The command produces -arial.pfb and arial.afm. The arial.pfb file weights only 57 KB, and 53 after compression. -
-
-It's possible to go even further. If you are interested only by a subset of the encoding (you -probably don't need all 217 characters), you can open the .map file and remove the lines you are -not interested in. This will reduce the file size accordingly. - - diff --git a/vendor/fpdf/tutorial/tuto7.php b/vendor/fpdf/tutorial/tuto7.php deleted file mode 100644 index a7acb47f..00000000 --- a/vendor/fpdf/tutorial/tuto7.php +++ /dev/null @@ -1,11 +0,0 @@ -AddFont('Calligrapher','','calligra.php'); -$pdf->AddPage(); -$pdf->SetFont('Calligrapher','',35); -$pdf->Cell(0,10,'Enjoy new fonts with FPDF!'); -$pdf->Output(); -?> diff --git a/vendor/fpdi/filters/FilterASCII85.php b/vendor/fpdi/filters/FilterASCII85.php deleted file mode 100644 index 59bc845f..00000000 --- a/vendor/fpdi/filters/FilterASCII85.php +++ /dev/null @@ -1,114 +0,0 @@ - ord('~'), - 'z' => ord('z'), - 'u' => ord('u'), - 'z' => ord('z'), - '!' => ord('!') - ); - - $out = ''; - $state = 0; - $chn = null; - - $l = strlen($in); - - for ($k = 0; $k < $l; ++$k) { - $ch = ord($in[$k]) & 0xff; - - if ($ch == $ord['~']) { - break; - } - if (preg_match('/^\s$/',chr($ch))) { - continue; - } - if ($ch == $ord['z'] && $state == 0) { - $out .= chr(0) . chr(0) . chr(0) . chr(0); - continue; - } - if ($ch < $ord['!'] || $ch > $ord['u']) { - throw new Exception('Illegal character in ASCII85Decode.'); - } - - $chn[$state++] = $ch - $ord['!']; - - if ($state == 5) { - $state = 0; - $r = 0; - for ($j = 0; $j < 5; ++$j) - $r = $r * 85 + $chn[$j]; - $out .= chr($r >> 24); - $out .= chr($r >> 16); - $out .= chr($r >> 8); - $out .= chr($r); - } - } - $r = 0; - - if ($state == 1) { - throw new Exception('Illegal length in ASCII85Decode.'); - } - - if ($state == 2) { - $r = $chn[0] * 85 * 85 * 85 * 85 + ($chn[1]+1) * 85 * 85 * 85; - $out .= chr($r >> 24); - - } else if ($state == 3) { - $r = $chn[0] * 85 * 85 * 85 * 85 + $chn[1] * 85 * 85 * 85 + ($chn[2]+1) * 85 * 85; - $out .= chr($r >> 24); - $out .= chr($r >> 16); - - } else if ($state == 4) { - $r = $chn[0] * 85 * 85 * 85 * 85 + $chn[1] * 85 * 85 * 85 + $chn[2] * 85 * 85 + ($chn[3]+1) * 85 ; - $out .= chr($r >> 24); - $out .= chr($r >> 16); - $out .= chr($r >> 8); - } - - return $out; - } - - /** - * NOT IMPLEMENTED - * - * @param string $in - * @return string - * @throws LogicException - */ - public function encode($in) - { - throw new LogicException("ASCII85 encoding not implemented."); - } -} \ No newline at end of file diff --git a/vendor/fpdi/filters/FilterASCIIHexDecode.php b/vendor/fpdi/filters/FilterASCIIHexDecode.php deleted file mode 100644 index 4040302d..00000000 --- a/vendor/fpdi/filters/FilterASCIIHexDecode.php +++ /dev/null @@ -1,52 +0,0 @@ -')); - if ((strlen($data) % 2) == 1) { - $data .= '0'; - } - - return pack('H*', $data); - } - - /** - * Converts a string into ASCII hexadecimal representation. - * - * @param string $data The input string - * @param boolean $leaveEOD - * @return string - */ - public function encode($data, $leaveEOD = false) - { - return current(unpack('H*', $data)) . ($leaveEOD ? '' : '>'); - } -} \ No newline at end of file diff --git a/vendor/fpdi/filters/FilterLZW.php b/vendor/fpdi/filters/FilterLZW.php deleted file mode 100644 index b4dfbe82..00000000 --- a/vendor/fpdi/filters/FilterLZW.php +++ /dev/null @@ -1,173 +0,0 @@ -_initsTable(); - - $this->_data = $data; - $this->_dataLength = strlen($data); - - // Initialize pointers - $this->_bytePointer = 0; - $this->_bitPointer = 0; - - $this->_nextData = 0; - $this->_nextBits = 0; - - $oldCode = 0; - - $unCompData = ''; - - while (($code = $this->_getNextCode()) != 257) { - if ($code == 256) { - $this->_initsTable(); - $code = $this->_getNextCode(); - - if ($code == 257) { - break; - } - - if (!isset($this->_sTable[$code])) { - throw new Exception('Error while decompression LZW compressed data.'); - } - - $unCompData .= $this->_sTable[$code]; - $oldCode = $code; - - } else { - - if ($code < $this->_tIdx) { - $string = $this->_sTable[$code]; - $unCompData .= $string; - - $this->_addStringToTable($this->_sTable[$oldCode], $string[0]); - $oldCode = $code; - } else { - $string = $this->_sTable[$oldCode]; - $string = $string . $string[0]; - $unCompData .= $string; - - $this->_addStringToTable($string); - $oldCode = $code; - } - } - } - - return $unCompData; - } - - - /** - * Initialize the string table. - */ - protected function _initsTable() - { - $this->_sTable = array(); - - for ($i = 0; $i < 256; $i++) - $this->_sTable[$i] = chr($i); - - $this->_tIdx = 258; - $this->_bitsToGet = 9; - } - - /** - * Add a new string to the string table. - */ - protected function _addStringToTable($oldString, $newString = '') - { - $string = $oldString . $newString; - - // Add this new String to the table - $this->_sTable[$this->_tIdx++] = $string; - - if ($this->_tIdx == 511) { - $this->_bitsToGet = 10; - } else if ($this->_tIdx == 1023) { - $this->_bitsToGet = 11; - } else if ($this->_tIdx == 2047) { - $this->_bitsToGet = 12; - } - } - - /** - * Returns the next 9, 10, 11 or 12 bits - * - * @return int - */ - protected function _getNextCode() - { - if ($this->_bytePointer == $this->_dataLength) { - return 257; - } - - $this->_nextData = ($this->_nextData << 8) | (ord($this->_data[$this->_bytePointer++]) & 0xff); - $this->_nextBits += 8; - - if ($this->_nextBits < $this->_bitsToGet) { - $this->_nextData = ($this->_nextData << 8) | (ord($this->_data[$this->_bytePointer++]) & 0xff); - $this->_nextBits += 8; - } - - $code = ($this->_nextData >> ($this->_nextBits - $this->_bitsToGet)) & $this->_andTable[$this->_bitsToGet-9]; - $this->_nextBits -= $this->_bitsToGet; - - return $code; - } - - /** - * NOT IMPLEMENTED - * - * @param string $in - * @return string - * @throws LogicException - */ - public function encode($in) - { - throw new LogicException("LZW encoding not implemented."); - } -} \ No newline at end of file diff --git a/vendor/fpdi/fpdf_tpl.php b/vendor/fpdi/fpdf_tpl.php deleted file mode 100644 index 5da77aff..00000000 --- a/vendor/fpdi/fpdf_tpl.php +++ /dev/null @@ -1,555 +0,0 @@ -page <= 0) { - throw new LogicException("You have to add at least a page first!"); - } - - if ($x == null) - $x = 0; - if ($y == null) - $y = 0; - if ($w == null) - $w = $this->w; - if ($h == null) - $h = $this->h; - - // Save settings - $this->tpl++; - $tpl =& $this->_tpls[$this->tpl]; - $tpl = array( - 'o_x' => $this->x, - 'o_y' => $this->y, - 'o_AutoPageBreak' => $this->AutoPageBreak, - 'o_bMargin' => $this->bMargin, - 'o_tMargin' => $this->tMargin, - 'o_lMargin' => $this->lMargin, - 'o_rMargin' => $this->rMargin, - 'o_h' => $this->h, - 'o_w' => $this->w, - 'o_FontFamily' => $this->FontFamily, - 'o_FontStyle' => $this->FontStyle, - 'o_FontSizePt' => $this->FontSizePt, - 'o_FontSize' => $this->FontSize, - 'buffer' => '', - 'x' => $x, - 'y' => $y, - 'w' => $w, - 'h' => $h - ); - - $this->SetAutoPageBreak(false); - - // Define own high and width to calculate correct positions - $this->h = $h; - $this->w = $w; - - $this->_inTpl = true; - $this->SetXY($x + $this->lMargin, $y + $this->tMargin); - $this->SetRightMargin($this->w - $w + $this->rMargin); - - if ($this->CurrentFont) { - $fontKey = $this->FontFamily . $this->FontStyle; - if ($fontKey) { - $this->_res['tpl'][$this->tpl]['fonts'][$fontKey] =& $this->fonts[$fontKey]; - $this->_out(sprintf('BT /F%d %.2F Tf ET', $this->CurrentFont['i'], $this->FontSizePt)); - } - } - - return $this->tpl; - } - - /** - * End template. - * - * This method ends a template and reset initiated variables collected in {@link beginTemplate()}. - * - * @return int|boolean If a template is opened, the id is returned. If not a false is returned. - */ - public function endTemplate() - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::endTemplate'), $args); - } - - if ($this->_inTpl) { - $this->_inTpl = false; - $tpl = $this->_tpls[$this->tpl]; - $this->SetXY($tpl['o_x'], $tpl['o_y']); - $this->tMargin = $tpl['o_tMargin']; - $this->lMargin = $tpl['o_lMargin']; - $this->rMargin = $tpl['o_rMargin']; - $this->h = $tpl['o_h']; - $this->w = $tpl['o_w']; - $this->SetAutoPageBreak($tpl['o_AutoPageBreak'], $tpl['o_bMargin']); - - $this->FontFamily = $tpl['o_FontFamily']; - $this->FontStyle = $tpl['o_FontStyle']; - $this->FontSizePt = $tpl['o_FontSizePt']; - $this->FontSize = $tpl['o_FontSize']; - - $fontKey = $this->FontFamily . $this->FontStyle; - if ($fontKey) - $this->CurrentFont =& $this->fonts[$fontKey]; - - return $this->tpl; - } else { - return false; - } - } - - /** - * Use a template in current page or other template. - * - * You can use a template in a page or in another template. - * You can give the used template a new size. - * All parameters are optional. The width or height is calculated automatically - * if one is given. If no parameter is given the origin size as defined in - * {@link beginTemplate()} method is used. - * - * The calculated or used width and height are returned as an array. - * - * @param int $tplIdx A valid template-id - * @param int $x The x-position - * @param int $y The y-position - * @param int $w The new width of the template - * @param int $h The new height of the template - * @return array The height and width of the template (array('w' => ..., 'h' => ...)) - * @throws LogicException|InvalidArgumentException - */ - public function useTemplate($tplIdx, $x = null, $y = null, $w = 0, $h = 0) - { - if ($this->page <= 0) { - throw new LogicException('You have to add at least a page first!'); - } - - if (!isset($this->_tpls[$tplIdx])) { - throw new InvalidArgumentException('Template does not exist!'); - } - - if ($this->_inTpl) { - $this->_res['tpl'][$this->tpl]['tpls'][$tplIdx] =& $this->_tpls[$tplIdx]; - } - - $tpl = $this->_tpls[$tplIdx]; - $_w = $tpl['w']; - $_h = $tpl['h']; - - if ($x == null) { - $x = 0; - } - - if ($y == null) { - $y = 0; - } - - $x += $tpl['x']; - $y += $tpl['y']; - - $wh = $this->getTemplateSize($tplIdx, $w, $h); - $w = $wh['w']; - $h = $wh['h']; - - $tplData = array( - 'x' => $this->x, - 'y' => $this->y, - 'w' => $w, - 'h' => $h, - 'scaleX' => ($w / $_w), - 'scaleY' => ($h / $_h), - 'tx' => $x, - 'ty' => ($this->h - $y - $h), - 'lty' => ($this->h - $y - $h) - ($this->h - $_h) * ($h / $_h) - ); - - $this->_out(sprintf('q %.4F 0 0 %.4F %.4F %.4F cm', - $tplData['scaleX'], $tplData['scaleY'], $tplData['tx'] * $this->k, $tplData['ty'] * $this->k) - ); // Translate - $this->_out(sprintf('%s%d Do Q', $this->tplPrefix, $tplIdx)); - - $this->lastUsedTemplateData = $tplData; - - return array('w' => $w, 'h' => $h); - } - - /** - * Get the calculated size of a template. - * - * If one size is given, this method calculates the other one. - * - * @param int $tplIdx A valid template-id - * @param int $w The width of the template - * @param int $h The height of the template - * @return array The height and width of the template (array('w' => ..., 'h' => ...)) - */ - public function getTemplateSize($tplIdx, $w = 0, $h = 0) - { - if (!isset($this->_tpls[$tplIdx])) - return false; - - $tpl = $this->_tpls[$tplIdx]; - $_w = $tpl['w']; - $_h = $tpl['h']; - - if ($w == 0 && $h == 0) { - $w = $_w; - $h = $_h; - } - - if ($w == 0) - $w = $h * $_w / $_h; - if($h == 0) - $h = $w * $_h / $_w; - - return array("w" => $w, "h" => $h); - } - - /** - * Sets the font used to print character strings. - * - * See FPDF/TCPDF documentation. - * - * @see http://fpdf.org/en/doc/setfont.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#afd56e360c43553830d543323e81bc045 - */ - public function SetFont($family, $style = '', $size = null, $fontfile = '', $subset = 'default', $out = true) - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::SetFont'), $args); - } - - parent::SetFont($family, $style, $size); - - $fontkey = $this->FontFamily . $this->FontStyle; - - if ($this->_inTpl) { - $this->_res['tpl'][$this->tpl]['fonts'][$fontkey] =& $this->fonts[$fontkey]; - } else { - $this->_res['page'][$this->page]['fonts'][$fontkey] =& $this->fonts[$fontkey]; - } - } - - /** - * Puts an image. - * - * See FPDF/TCPDF documentation. - * - * @see http://fpdf.org/en/doc/image.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#a714c2bee7d6b39d4d6d304540c761352 - */ - public function Image( - $file, $x = '', $y = '', $w = 0, $h = 0, $type = '', $link = '', $align = '', $resize = false, - $dpi = 300, $palign = '', $ismask = false, $imgmask = false, $border = 0, $fitbox = false, - $hidden = false, $fitonpage = false, $alt = false, $altimgs = array() - ) - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::Image'), $args); - } - - $ret = parent::Image($file, $x, $y, $w, $h, $type, $link); - if ($this->_inTpl) { - $this->_res['tpl'][$this->tpl]['images'][$file] =& $this->images[$file]; - } else { - $this->_res['page'][$this->page]['images'][$file] =& $this->images[$file]; - } - - return $ret; - } - - /** - * Adds a new page to the document. - * - * See FPDF/TCPDF documentation. - * - * This method cannot be used if you'd started a template. - * - * @see http://fpdf.org/en/doc/addpage.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#a5171e20b366b74523709d84c349c1ced - */ - public function AddPage($orientation = '', $format = '', $keepmargins = false, $tocpage = false) - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::AddPage'), $args); - } - - if ($this->_inTpl) { - throw new LogicException('Adding pages in templates is not possible!'); - } - - parent::AddPage($orientation, $format); - } - - /** - * Puts a link on a rectangular area of the page. - * - * Overwritten because adding links in a template will not work. - * - * @see http://fpdf.org/en/doc/link.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#ab87bf1826384fbfe30eb499d42f1d994 - */ - public function Link($x, $y, $w, $h, $link, $spaces = 0) - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::Link'), $args); - } - - if ($this->_inTpl) { - throw new LogicException('Using links in templates is not posible!'); - } - - parent::Link($x, $y, $w, $h, $link); - } - - /** - * Creates a new internal link and returns its identifier. - * - * Overwritten because adding links in a template will not work. - * - * @see http://fpdf.org/en/doc/addlink.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#a749522038ed7786c3e1701435dcb891e - */ - public function AddLink() - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::AddLink'), $args); - } - - if ($this->_inTpl) { - throw new LogicException('Adding links in templates is not possible!'); - } - - return parent::AddLink(); - } - - /** - * Defines the page and position a link points to. - * - * Overwritten because adding links in a template will not work. - * - * @see http://fpdf.org/en/doc/setlink.htm - * @see http://www.tcpdf.org/doc/code/classTCPDF.html#ace5be60e7857953ea5e2b89cb90df0ae - */ - public function SetLink($link, $y = 0, $page = -1) - { - if (is_subclass_of($this, 'TCPDF')) { - $args = func_get_args(); - return call_user_func_array(array($this, 'TCPDF::SetLink'), $args); - } - - if ($this->_inTpl) { - throw new LogicException('Setting links in templates is not possible!'); - } - - parent::SetLink($link, $y, $page); - } - - /** - * Writes the form XObjects to the PDF document. - */ - protected function _putformxobjects() - { - $filter=($this->compress) ? '/Filter /FlateDecode ' : ''; - reset($this->_tpls); - - foreach($this->_tpls AS $tplIdx => $tpl) { - $this->_newobj(); - $this->_tpls[$tplIdx]['n'] = $this->n; - $this->_out('<<'.$filter.'/Type /XObject'); - $this->_out('/Subtype /Form'); - $this->_out('/FormType 1'); - $this->_out(sprintf('/BBox [%.2F %.2F %.2F %.2F]', - // llx - $tpl['x'] * $this->k, - // lly - -$tpl['y'] * $this->k, - // urx - ($tpl['w'] + $tpl['x']) * $this->k, - // ury - ($tpl['h'] - $tpl['y']) * $this->k - )); - - if ($tpl['x'] != 0 || $tpl['y'] != 0) { - $this->_out(sprintf('/Matrix [1 0 0 1 %.5F %.5F]', - -$tpl['x'] * $this->k * 2, $tpl['y'] * $this->k * 2 - )); - } - - $this->_out('/Resources '); - $this->_out('<_res['tpl'][$tplIdx])) { - $res = $this->_res['tpl'][$tplIdx]; - if (isset($res['fonts']) && count($res['fonts'])) { - $this->_out('/Font <<'); - - foreach($res['fonts'] as $font) { - $this->_out('/F' . $font['i'] . ' ' . $font['n'] . ' 0 R'); - } - - $this->_out('>>'); - } - - if(isset($res['images']) || isset($res['tpls'])) { - $this->_out('/XObject <<'); - - if (isset($res['images'])) { - foreach($res['images'] as $image) - $this->_out('/I' . $image['i'] . ' ' . $image['n'] . ' 0 R'); - } - - if (isset($res['tpls'])) { - foreach($res['tpls'] as $i => $_tpl) - $this->_out($this->tplPrefix . $i . ' ' . $_tpl['n'] . ' 0 R'); - } - - $this->_out('>>'); - } - } - - $this->_out('>>'); - - $buffer = ($this->compress) ? gzcompress($tpl['buffer']) : $tpl['buffer']; - $this->_out('/Length ' . strlen($buffer) . ' >>'); - $this->_putstream($buffer); - $this->_out('endobj'); - } - } - - /** - * Output images. - * - * Overwritten to add {@link _putformxobjects()} after _putimages(). - */ - public function _putimages() - { - parent::_putimages(); - $this->_putformxobjects(); - } - - /** - * Writes the references of XObject resources to the document. - * - * Overwritten to add the the templates to the XObject resource dictionary. - */ - public function _putxobjectdict() - { - parent::_putxobjectdict(); - - foreach($this->_tpls as $tplIdx => $tpl) { - $this->_out(sprintf('%s%d %d 0 R', $this->tplPrefix, $tplIdx, $tpl['n'])); - } - } - - /** - * Writes bytes to the resulting document. - * - * Overwritten to delegate the data to the template buffer. - * - * @param string $s - */ - public function _out($s) - { - if ($this->state == 2 && $this->_inTpl) { - $this->_tpls[$this->tpl]['buffer'] .= $s . "\n"; - } else { - parent::_out($s); - } - } -} diff --git a/vendor/fpdi/fpdi.php b/vendor/fpdi/fpdi.php deleted file mode 100644 index 23288ff0..00000000 --- a/vendor/fpdi/fpdi.php +++ /dev/null @@ -1,699 +0,0 @@ -currentFilename = $filename; - - if (!isset($this->parsers[$filename])) { - $this->parsers[$filename] = $this->_getPdfParser($filename); - $this->setPdfVersion( - max($this->getPdfVersion(), $this->parsers[$filename]->getPdfVersion()) - ); - } - - $this->currentParser =& $this->parsers[$filename]; - - return $this->parsers[$filename]->getPageCount(); - } - - /** - * Returns a PDF parser object - * - * @param string $filename - * @return fpdi_pdf_parser - */ - protected function _getPdfParser($filename) - { - require_once('fpdi_pdf_parser.php'); - return new fpdi_pdf_parser($filename); - } - - /** - * Get the current PDF version. - * - * @return string - */ - public function getPdfVersion() - { - return $this->PDFVersion; - } - - /** - * Set the PDF version. - * - * @param string $version - */ - public function setPdfVersion($version = '1.3') - { - $this->PDFVersion = sprintf('%.1F', $version); - } - - /** - * Import a page. - * - * The second parameter defines the bounding box that should be used to transform the page into a - * form XObject. - * - * Following values are available: MediaBox, CropBox, BleedBox, TrimBox, ArtBox. - * If a box is not especially defined its default box will be used: - * - *
    - *
  • CropBox: Default -> MediaBox
  • - *
  • BleedBox: Default -> CropBox
  • - *
  • TrimBox: Default -> CropBox
  • - *
  • ArtBox: Default -> CropBox
  • - *
- * - * It is possible to get the used page box by the {@link getLastUsedPageBox()} method. - * - * @param int $pageNo The page number - * @param string $boxName The boundary box to use when transforming the page into a form XObject - * @param boolean $groupXObject Define the form XObject as a group XObject to support transparency (if used) - * @return int An id of the imported page/template to use with e.g. fpdf_tpl::useTemplate() - * @throws LogicException|InvalidArgumentException - * @see getLastUsedPageBox() - */ - public function importPage($pageNo, $boxName = 'CropBox', $groupXObject = true) - { - if ($this->_inTpl) { - throw new LogicException('Please import the desired pages before creating a new template.'); - } - - $fn = $this->currentFilename; - $boxName = '/' . ltrim($boxName, '/'); - - // check if page already imported - $pageKey = $fn . '-' . ((int)$pageNo) . $boxName; - if (isset($this->_importedPages[$pageKey])) { - return $this->_importedPages[$pageKey]; - } - - $parser = $this->parsers[$fn]; - $parser->setPageNo($pageNo); - - if (!in_array($boxName, $parser->availableBoxes)) { - throw new InvalidArgumentException(sprintf('Unknown box: %s', $boxName)); - } - - $pageBoxes = $parser->getPageBoxes($pageNo, $this->k); - - /** - * MediaBox - * CropBox: Default -> MediaBox - * BleedBox: Default -> CropBox - * TrimBox: Default -> CropBox - * ArtBox: Default -> CropBox - */ - if (!isset($pageBoxes[$boxName]) && ($boxName == '/BleedBox' || $boxName == '/TrimBox' || $boxName == '/ArtBox')) - $boxName = '/CropBox'; - if (!isset($pageBoxes[$boxName]) && $boxName == '/CropBox') - $boxName = '/MediaBox'; - - if (!isset($pageBoxes[$boxName])) - return false; - - $this->lastUsedPageBox = $boxName; - - $box = $pageBoxes[$boxName]; - - $this->tpl++; - $this->_tpls[$this->tpl] = array(); - $tpl =& $this->_tpls[$this->tpl]; - $tpl['parser'] = $parser; - $tpl['resources'] = $parser->getPageResources(); - $tpl['buffer'] = $parser->getContent(); - $tpl['box'] = $box; - $tpl['groupXObject'] = $groupXObject; - if ($groupXObject) { - $this->setPdfVersion(max($this->getPdfVersion(), 1.4)); - } - - // To build an array that can be used by PDF_TPL::useTemplate() - $this->_tpls[$this->tpl] = array_merge($this->_tpls[$this->tpl], $box); - - // An imported page will start at 0,0 all the time. Translation will be set in _putformxobjects() - $tpl['x'] = 0; - $tpl['y'] = 0; - - // handle rotated pages - $rotation = $parser->getPageRotation($pageNo); - $tpl['_rotationAngle'] = 0; - if (isset($rotation[1]) && ($angle = $rotation[1] % 360) != 0) { - $steps = $angle / 90; - - $_w = $tpl['w']; - $_h = $tpl['h']; - $tpl['w'] = $steps % 2 == 0 ? $_w : $_h; - $tpl['h'] = $steps % 2 == 0 ? $_h : $_w; - - if ($angle < 0) - $angle += 360; - - $tpl['_rotationAngle'] = $angle * -1; - } - - $this->_importedPages[$pageKey] = $this->tpl; - - return $this->tpl; - } - - /** - * Returns the last used page boundary box. - * - * @return string The used boundary box: MediaBox, CropBox, BleedBox, TrimBox or ArtBox - */ - public function getLastUsedPageBox() - { - return $this->lastUsedPageBox; - } - - /** - * Use a template or imported page in current page or other template. - * - * You can use a template in a page or in another template. - * You can give the used template a new size. All parameters are optional. - * The width or height is calculated automatically if one is given. If no - * parameter is given the origin size as defined in beginTemplate() or of - * the imported page is used. - * - * The calculated or used width and height are returned as an array. - * - * @param int $tplIdx A valid template-id - * @param int $x The x-position - * @param int $y The y-position - * @param int $w The new width of the template - * @param int $h The new height of the template - * @param boolean $adjustPageSize If set to true the current page will be resized to fit the dimensions - * of the template - * - * @return array The height and width of the template (array('w' => ..., 'h' => ...)) - * @throws LogicException|InvalidArgumentException - */ - public function useTemplate($tplIdx, $x = null, $y = null, $w = 0, $h = 0, $adjustPageSize = false) - { - if ($adjustPageSize == true && is_null($x) && is_null($y)) { - $size = $this->getTemplateSize($tplIdx, $w, $h); - $orientation = $size['w'] > $size['h'] ? 'L' : 'P'; - $size = array($size['w'], $size['h']); - - if (is_subclass_of($this, 'TCPDF')) { - $this->setPageFormat($size, $orientation); - } else { - $size = $this->_getpagesize($size); - - if($orientation != $this->CurOrientation || - $size[0] != $this->CurPageSize[0] || - $size[1] != $this->CurPageSize[1] - ) { - // New size or orientation - if ($orientation=='P') { - $this->w = $size[0]; - $this->h = $size[1]; - } else { - $this->w = $size[1]; - $this->h = $size[0]; - } - $this->wPt = $this->w * $this->k; - $this->hPt = $this->h * $this->k; - $this->PageBreakTrigger = $this->h - $this->bMargin; - $this->CurOrientation = $orientation; - $this->CurPageSize = $size; - $this->PageSizes[$this->page] = array($this->wPt, $this->hPt); - } - } - } - - $this->_out('q 0 J 1 w 0 j 0 G 0 g'); // reset standard values - $size = parent::useTemplate($tplIdx, $x, $y, $w, $h); - $this->_out('Q'); - - return $size; - } - - /** - * Copy all imported objects to the resulting document. - */ - protected function _putimportedobjects() - { - foreach($this->parsers AS $filename => $p) { - $this->currentParser =& $p; - if (!isset($this->_objStack[$filename]) || !is_array($this->_objStack[$filename])) { - continue; - } - while(($n = key($this->_objStack[$filename])) !== null) { - try { - $nObj = $this->currentParser->resolveObject($this->_objStack[$filename][$n][1]); - } catch (Exception $e) { - $nObj = array(pdf_parser::TYPE_OBJECT, pdf_parser::TYPE_NULL); - } - - $this->_newobj($this->_objStack[$filename][$n][0]); - - if ($nObj[0] == pdf_parser::TYPE_STREAM) { - $this->_writeValue($nObj); - } else { - $this->_writeValue($nObj[1]); - } - - $this->_out("\nendobj"); - $this->_objStack[$filename][$n] = null; // free memory - unset($this->_objStack[$filename][$n]); - reset($this->_objStack[$filename]); - } - } - } - - /** - * Writes the form XObjects to the PDF document. - */ - protected function _putformxobjects() - { - $filter = ($this->compress) ? '/Filter /FlateDecode ' : ''; - reset($this->_tpls); - foreach($this->_tpls AS $tplIdx => $tpl) { - $this->_newobj(); - $currentN = $this->n; // TCPDF/Protection: rem current "n" - - $this->_tpls[$tplIdx]['n'] = $this->n; - $this->_out('<<' . $filter . '/Type /XObject'); - $this->_out('/Subtype /Form'); - $this->_out('/FormType 1'); - - $this->_out(sprintf('/BBox [%.2F %.2F %.2F %.2F]', - (isset($tpl['box']['llx']) ? $tpl['box']['llx'] : $tpl['x']) * $this->k, - (isset($tpl['box']['lly']) ? $tpl['box']['lly'] : -$tpl['y']) * $this->k, - (isset($tpl['box']['urx']) ? $tpl['box']['urx'] : $tpl['w'] + $tpl['x']) * $this->k, - (isset($tpl['box']['ury']) ? $tpl['box']['ury'] : $tpl['h'] - $tpl['y']) * $this->k - )); - - $c = 1; - $s = 0; - $tx = 0; - $ty = 0; - - if (isset($tpl['box'])) { - $tx = -$tpl['box']['llx']; - $ty = -$tpl['box']['lly']; - - if ($tpl['_rotationAngle'] <> 0) { - $angle = $tpl['_rotationAngle'] * M_PI/180; - $c = cos($angle); - $s = sin($angle); - - switch($tpl['_rotationAngle']) { - case -90: - $tx = -$tpl['box']['lly']; - $ty = $tpl['box']['urx']; - break; - case -180: - $tx = $tpl['box']['urx']; - $ty = $tpl['box']['ury']; - break; - case -270: - $tx = $tpl['box']['ury']; - $ty = -$tpl['box']['llx']; - break; - } - } - } else if ($tpl['x'] != 0 || $tpl['y'] != 0) { - $tx = -$tpl['x'] * 2; - $ty = $tpl['y'] * 2; - } - - $tx *= $this->k; - $ty *= $this->k; - - if ($c != 1 || $s != 0 || $tx != 0 || $ty != 0) { - $this->_out(sprintf('/Matrix [%.5F %.5F %.5F %.5F %.5F %.5F]', - $c, $s, -$s, $c, $tx, $ty - )); - } - - $this->_out('/Resources '); - - if (isset($tpl['resources'])) { - $this->currentParser = $tpl['parser']; - $this->_writeValue($tpl['resources']); // "n" will be changed - } else { - - $this->_out('<_res['tpl'][$tplIdx])) { - $res = $this->_res['tpl'][$tplIdx]; - - if (isset($res['fonts']) && count($res['fonts'])) { - $this->_out('/Font <<'); - foreach ($res['fonts'] as $font) - $this->_out('/F' . $font['i'] . ' ' . $font['n'] . ' 0 R'); - $this->_out('>>'); - } - if (isset($res['images']) && count($res['images']) || - isset($res['tpls']) && count($res['tpls'])) - { - $this->_out('/XObject <<'); - if (isset($res['images'])) { - foreach ($res['images'] as $image) - $this->_out('/I' . $image['i'] . ' ' . $image['n'] . ' 0 R'); - } - if (isset($res['tpls'])) { - foreach ($res['tpls'] as $i => $_tpl) - $this->_out($this->tplPrefix . $i . ' ' . $_tpl['n'] . ' 0 R'); - } - $this->_out('>>'); - } - $this->_out('>>'); - } - } - - if (isset($tpl['groupXObject']) && $tpl['groupXObject']) { - $this->_out('/Group <>'); - } - - $newN = $this->n; // TCPDF: rem new "n" - $this->n = $currentN; // TCPDF: reset to current "n" - - $buffer = ($this->compress) ? gzcompress($tpl['buffer']) : $tpl['buffer']; - - if (is_subclass_of($this, 'TCPDF')) { - $buffer = $this->_getrawstream($buffer); - $this->_out('/Length ' . strlen($buffer) . ' >>'); - $this->_out("stream\n" . $buffer . "\nendstream"); - } else { - $this->_out('/Length ' . strlen($buffer) . ' >>'); - $this->_putstream($buffer); - } - $this->_out('endobj'); - $this->n = $newN; // TCPDF: reset to new "n" - } - - $this->_putimportedobjects(); - } - - /** - * Creates and optionally write the object definition to the document. - * - * Rewritten to handle existing own defined objects - * - * @param bool $objId - * @param bool $onlyNewObj - * @return bool|int - */ - public function _newobj($objId = false, $onlyNewObj = false) - { - if (!$objId) { - $objId = ++$this->n; - } - - //Begin a new object - if (!$onlyNewObj) { - $this->offsets[$objId] = is_subclass_of($this, 'TCPDF') ? $this->bufferlen : strlen($this->buffer); - $this->_out($objId . ' 0 obj'); - $this->_currentObjId = $objId; // for later use with encryption - } - - return $objId; - } - - /** - * Writes a PDF value to the resulting document. - * - * Needed to rebuild the source document - * - * @param mixed $value A PDF-Value. Structure of values see cases in this method - */ - protected function _writeValue(&$value) - { - if (is_subclass_of($this, 'TCPDF')) { - parent::_prepareValue($value); - } - - switch ($value[0]) { - - case pdf_parser::TYPE_TOKEN: - $this->_straightOut($value[1] . ' '); - break; - case pdf_parser::TYPE_NUMERIC: - case pdf_parser::TYPE_REAL: - if (is_float($value[1]) && $value[1] != 0) { - $this->_straightOut(rtrim(rtrim(sprintf('%F', $value[1]), '0'), '.') . ' '); - } else { - $this->_straightOut($value[1] . ' '); - } - break; - - case pdf_parser::TYPE_ARRAY: - - // An array. Output the proper - // structure and move on. - - $this->_straightOut('['); - for ($i = 0; $i < count($value[1]); $i++) { - $this->_writeValue($value[1][$i]); - } - - $this->_out(']'); - break; - - case pdf_parser::TYPE_DICTIONARY: - - // A dictionary. - $this->_straightOut('<<'); - - reset ($value[1]); - - foreach ($value[1] as $k => $v){ - $this->_straightOut($k . ' '); - $this->_writeValue($v); - } - // while (list($k, $v) = each($value[1])) { - // $this->_straightOut($k . ' '); - // $this->_writeValue($v); - // } - - $this->_straightOut('>>'); - break; - - case pdf_parser::TYPE_OBJREF: - - // An indirect object reference - // Fill the object stack if needed - $cpfn =& $this->currentParser->filename; - if (!isset($this->_doneObjStack[$cpfn][$value[1]])) { - $this->_newobj(false, true); - $this->_objStack[$cpfn][$value[1]] = array($this->n, $value); - $this->_doneObjStack[$cpfn][$value[1]] = array($this->n, $value); - } - $objId = $this->_doneObjStack[$cpfn][$value[1]][0]; - - $this->_out($objId . ' 0 R'); - break; - - case pdf_parser::TYPE_STRING: - - // A string. - $this->_straightOut('(' . $value[1] . ')'); - - break; - - case pdf_parser::TYPE_STREAM: - - // A stream. First, output the - // stream dictionary, then the - // stream data itself. - $this->_writeValue($value[1]); - $this->_out('stream'); - $this->_out($value[2][1]); - $this->_straightOut("endstream"); - break; - - case pdf_parser::TYPE_HEX: - $this->_straightOut('<' . $value[1] . '>'); - break; - - case pdf_parser::TYPE_BOOLEAN: - $this->_straightOut($value[1] ? 'true ' : 'false '); - break; - - case pdf_parser::TYPE_NULL: - // The null object. - - $this->_straightOut('null '); - break; - } - } - - - /** - * Modified _out() method so not each call will add a newline to the output. - */ - protected function _straightOut($s) - { - if (!is_subclass_of($this, 'TCPDF')) { - if ($this->state == 2) { - $this->pages[$this->page] .= $s; - } else { - $this->buffer .= $s; - } - - } else { - if ($this->state == 2) { - if ($this->inxobj) { - // we are inside an XObject template - $this->xobjects[$this->xobjid]['outdata'] .= $s; - } else if ((!$this->InFooter) AND isset($this->footerlen[$this->page]) AND ($this->footerlen[$this->page] > 0)) { - // puts data before page footer - $pagebuff = $this->getPageBuffer($this->page); - $page = substr($pagebuff, 0, -$this->footerlen[$this->page]); - $footer = substr($pagebuff, -$this->footerlen[$this->page]); - $this->setPageBuffer($this->page, $page . $s . $footer); - // update footer position - $this->footerpos[$this->page] += strlen($s); - } else { - // set page data - $this->setPageBuffer($this->page, $s, true); - } - } else if ($this->state > 0) { - // set general data - $this->setBuffer($s); - } - } - } - - /** - * Ends the document - * - * Overwritten to close opened parsers - */ - public function _enddoc() - { - parent::_enddoc(); - $this->_closeParsers(); - } - - /** - * Close all files opened by parsers. - * - * @return boolean - */ - protected function _closeParsers() - { - if ($this->state > 2) { - $this->cleanUp(); - return true; - } - - return false; - } - - /** - * Removes cycled references and closes the file handles of the parser objects. - */ - public function cleanUp() - { - while (($parser = array_pop($this->parsers)) !== null) { - /** - * @var fpdi_pdf_parser $parser - */ - $parser->closeFile(); - } - } -} \ No newline at end of file diff --git a/vendor/fpdi/fpdi_bridge.php b/vendor/fpdi/fpdi_bridge.php deleted file mode 100644 index f89822d9..00000000 --- a/vendor/fpdi/fpdi_bridge.php +++ /dev/null @@ -1,215 +0,0 @@ -_tpls as $tplIdx => $tpl) { - $out .= sprintf('%s%d %d 0 R', $this->tplPrefix, $tplIdx, $tpl['n']); - } - - return $out; - } - - /** - * Writes a PDF value to the resulting document. - * - * Prepares the value for encryption of imported data by FPDI - * - * @param array $value - */ - protected function _prepareValue(&$value) - { - switch ($value[0]) { - case pdf_parser::TYPE_STRING: - if ($this->encrypted) { - $value[1] = $this->_unescape($value[1]); - $value[1] = $this->_encrypt_data($this->_currentObjId, $value[1]); - $value[1] = TCPDF_STATIC::_escape($value[1]); - } - break; - - case pdf_parser::TYPE_STREAM: - if ($this->encrypted) { - $value[2][1] = $this->_encrypt_data($this->_currentObjId, $value[2][1]); - $value[1][1]['/Length'] = array( - pdf_parser::TYPE_NUMERIC, - strlen($value[2][1]) - ); - } - break; - - case pdf_parser::TYPE_HEX: - if ($this->encrypted) { - $value[1] = $this->hex2str($value[1]); - $value[1] = $this->_encrypt_data($this->_currentObjId, $value[1]); - - // remake hexstring of encrypted string - $value[1] = $this->str2hex($value[1]); - } - break; - } - } - - /** - * Un-escapes a PDF string - * - * @param string $s - * @return string - */ - protected function _unescape($s) - { - $out = ''; - for ($count = 0, $n = strlen($s); $count < $n; $count++) { - if ($s[$count] != '\\' || $count == $n-1) { - $out .= $s[$count]; - } else { - switch ($s[++$count]) { - case ')': - case '(': - case '\\': - $out .= $s[$count]; - break; - case 'f': - $out .= chr(0x0C); - break; - case 'b': - $out .= chr(0x08); - break; - case 't': - $out .= chr(0x09); - break; - case 'r': - $out .= chr(0x0D); - break; - case 'n': - $out .= chr(0x0A); - break; - case "\r": - if ($count != $n-1 && $s[$count+1] == "\n") - $count++; - break; - case "\n": - break; - default: - // Octal-Values - if (ord($s[$count]) >= ord('0') && - ord($s[$count]) <= ord('9')) { - $oct = ''. $s[$count]; - - if (ord($s[$count+1]) >= ord('0') && - ord($s[$count+1]) <= ord('9')) { - $oct .= $s[++$count]; - - if (ord($s[$count+1]) >= ord('0') && - ord($s[$count+1]) <= ord('9')) { - $oct .= $s[++$count]; - } - } - - $out .= chr(octdec($oct)); - } else { - $out .= $s[$count]; - } - } - } - } - return $out; - } - - /** - * Hexadecimal to string - * - * @param string $data - * @return string - */ - public function hex2str($data) - { - $data = preg_replace('/[^0-9A-Fa-f]/', '', rtrim($data, '>')); - if ((strlen($data) % 2) == 1) { - $data .= '0'; - } - - return pack('H*', $data); - } - - /** - * String to hexadecimal - * - * @param string $str - * @return string - */ - public function str2hex($str) - { - return current(unpack('H*', $str)); - } - } -} \ No newline at end of file diff --git a/vendor/fpdi/fpdi_pdf_parser.php b/vendor/fpdi/fpdi_pdf_parser.php deleted file mode 100644 index 9e76341b..00000000 --- a/vendor/fpdi/fpdi_pdf_parser.php +++ /dev/null @@ -1,354 +0,0 @@ -resolveObject($this->_root[1][1]['/Pages']); - - // Read pages - $this->_readPages($pages, $this->_pages); - - // count pages; - $this->_pageCount = count($this->_pages); - } - - /** - * Get page count from source file. - * - * @return int - */ - public function getPageCount() - { - return $this->_pageCount; - } - - /** - * Set the page number. - * - * @param int $pageNo Page number to use - * @throws InvalidArgumentException - */ - public function setPageNo($pageNo) - { - $pageNo = ((int) $pageNo) - 1; - - if ($pageNo < 0 || $pageNo >= $this->getPageCount()) { - throw new InvalidArgumentException('Invalid page number!'); - } - - $this->pageNo = $pageNo; - } - - /** - * Get page-resources from current page - * - * @return array|boolean - */ - public function getPageResources() - { - return $this->_getPageResources($this->_pages[$this->pageNo]); - } - - /** - * Get page-resources from a /Page dictionary. - * - * @param array $obj Array of pdf-data - * @return array|boolean - */ - protected function _getPageResources($obj) - { - $obj = $this->resolveObject($obj); - - // If the current object has a resources - // dictionary associated with it, we use - // it. Otherwise, we move back to its - // parent object. - if (isset($obj[1][1]['/Resources'])) { - $res = $this->resolveObject($obj[1][1]['/Resources']); - if ($res[0] == pdf_parser::TYPE_OBJECT) - return $res[1]; - return $res; - } - - if (!isset($obj[1][1]['/Parent'])) { - return false; - } - - $res = $this->_getPageResources($obj[1][1]['/Parent']); - if ($res[0] == pdf_parser::TYPE_OBJECT) - return $res[1]; - return $res; - } - - /** - * Get content of current page. - * - * If /Contents is an array, the streams are concatenated - * - * @return string - */ - public function getContent() - { - $buffer = ''; - - if (isset($this->_pages[$this->pageNo][1][1]['/Contents'])) { - $contents = $this->_getPageContent($this->_pages[$this->pageNo][1][1]['/Contents']); - foreach ($contents AS $tmpContent) { - $buffer .= $this->_unFilterStream($tmpContent) . ' '; - } - } - - return $buffer; - } - - /** - * Resolve all content objects. - * - * @param array $contentRef - * @return array - */ - protected function _getPageContent($contentRef) - { - $contents = array(); - - if ($contentRef[0] == pdf_parser::TYPE_OBJREF) { - $content = $this->resolveObject($contentRef); - if ($content[1][0] == pdf_parser::TYPE_ARRAY) { - $contents = $this->_getPageContent($content[1]); - } else { - $contents[] = $content; - } - } else if ($contentRef[0] == pdf_parser::TYPE_ARRAY) { - foreach ($contentRef[1] AS $tmp_content_ref) { - $contents = array_merge($contents, $this->_getPageContent($tmp_content_ref)); - } - } - - return $contents; - } - - /** - * Get a boundary box from a page - * - * Array format is same as used by FPDF_TPL. - * - * @param array $page a /Page dictionary - * @param string $boxIndex Type of box {see {@link $availableBoxes}) - * @param float Scale factor from user space units to points - * - * @return array|boolean - */ - protected function _getPageBox($page, $boxIndex, $k) - { - $page = $this->resolveObject($page); - $box = null; - if (isset($page[1][1][$boxIndex])) { - $box = $page[1][1][$boxIndex]; - } - - if (!is_null($box) && $box[0] == pdf_parser::TYPE_OBJREF) { - $tmp_box = $this->resolveObject($box); - $box = $tmp_box[1]; - } - - if (!is_null($box) && $box[0] == pdf_parser::TYPE_ARRAY) { - $b = $box[1]; - return array( - 'x' => $b[0][1] / $k, - 'y' => $b[1][1] / $k, - 'w' => abs($b[0][1] - $b[2][1]) / $k, - 'h' => abs($b[1][1] - $b[3][1]) / $k, - 'llx' => min($b[0][1], $b[2][1]) / $k, - 'lly' => min($b[1][1], $b[3][1]) / $k, - 'urx' => max($b[0][1], $b[2][1]) / $k, - 'ury' => max($b[1][1], $b[3][1]) / $k, - ); - } else if (!isset($page[1][1]['/Parent'])) { - return false; - } else { - return $this->_getPageBox($this->resolveObject($page[1][1]['/Parent']), $boxIndex, $k); - } - } - - /** - * Get all page boundary boxes by page number - * - * @param int $pageNo The page number - * @param float $k Scale factor from user space units to points - * @return array - * @throws InvalidArgumentException - */ - public function getPageBoxes($pageNo, $k) - { - if (!isset($this->_pages[$pageNo - 1])) { - throw new InvalidArgumentException('Page ' . $pageNo . ' does not exists.'); - } - - return $this->_getPageBoxes($this->_pages[$pageNo - 1], $k); - } - - /** - * Get all boxes from /Page dictionary - * - * @param array $page A /Page dictionary - * @param float $k Scale factor from user space units to points - * @return array - */ - protected function _getPageBoxes($page, $k) - { - $boxes = array(); - - foreach($this->availableBoxes AS $box) { - if ($_box = $this->_getPageBox($page, $box, $k)) { - $boxes[$box] = $_box; - } - } - - return $boxes; - } - - /** - * Get the page rotation by page number - * - * @param integer $pageNo - * @throws InvalidArgumentException - * @return array - */ - public function getPageRotation($pageNo) - { - if (!isset($this->_pages[$pageNo - 1])) { - throw new InvalidArgumentException('Page ' . $pageNo . ' does not exists.'); - } - - return $this->_getPageRotation($this->_pages[$pageNo - 1]); - } - - /** - * Get the rotation value of a page - * - * @param array $obj A /Page dictionary - * @return array|bool - */ - protected function _getPageRotation($obj) - { - $obj = $this->resolveObject($obj); - if (isset($obj[1][1]['/Rotate'])) { - $res = $this->resolveObject($obj[1][1]['/Rotate']); - if ($res[0] == pdf_parser::TYPE_OBJECT) - return $res[1]; - return $res; - } - - if (!isset($obj[1][1]['/Parent'])) { - return false; - } - - $res = $this->_getPageRotation($obj[1][1]['/Parent']); - if ($res[0] == pdf_parser::TYPE_OBJECT) - return $res[1]; - - return $res; - } - - /** - * Read all pages - * - * @param array $pages /Pages dictionary - * @param array $result The result array - * @throws Exception - */ - protected function _readPages(&$pages, &$result) - { - // Get the kids dictionary - $_kids = $this->resolveObject($pages[1][1]['/Kids']); - - if (!is_array($_kids)) { - throw new Exception('Cannot find /Kids in current /Page-Dictionary'); - } - - if ($_kids[0] === self::TYPE_OBJECT) { - $_kids = $_kids[1]; - } - - $kids = $_kids[1]; - - foreach ($kids as $v) { - $pg = $this->resolveObject($v); - if ($pg[1][1]['/Type'][1] === '/Pages') { - // If one of the kids is an embedded - // /Pages array, resolve it as well. - $this->_readPages($pg, $result); - } else { - $result[] = $pg; - } - } - } -} \ No newline at end of file diff --git a/vendor/fpdi/pdf_context.php b/vendor/fpdi/pdf_context.php deleted file mode 100644 index 88f3aede..00000000 --- a/vendor/fpdi/pdf_context.php +++ /dev/null @@ -1,153 +0,0 @@ -file =& $f; - if (is_string($this->file)) - $this->_mode = 1; - - $this->reset(); - } - - /** - * Get the position in the file stream - * - * @return int - */ - public function getPos() - { - if ($this->_mode == 0) { - return ftell($this->file); - } else { - return 0; - } - } - - /** - * Reset the position in the file stream. - * - * Optionally move the file pointer to a new location and reset the buffered data. - * - * @param null $pos - * @param int $l - */ - public function reset($pos = null, $l = 100) - { - if ($this->_mode == 0) { - if (!is_null($pos)) { - fseek ($this->file, $pos); - } - - $this->buffer = $l > 0 ? fread($this->file, $l) : ''; - $this->length = strlen($this->buffer); - if ($this->length < $l) - $this->increaseLength($l - $this->length); - } else { - $this->buffer = $this->file; - $this->length = strlen($this->buffer); - } - $this->offset = 0; - $this->stack = array(); - } - - /** - * Make sure that there is at least one character beyond the current offset in the buffer. - * - * To prevent the tokenizer from attempting to access data that does not exist. - * - * @return bool - */ - public function ensureContent() - { - if ($this->offset >= $this->length - 1) { - return $this->increaseLength(); - } else { - return true; - } - } - - /** - * Forcefully read more data into the buffer - * - * @param int $l - * @return bool - */ - public function increaseLength($l = 100) - { - if ($this->_mode == 0 && feof($this->file)) { - return false; - } else if ($this->_mode == 0) { - $totalLength = $this->length + $l; - do { - $toRead = $totalLength - $this->length; - if ($toRead < 1) - break; - - $this->buffer .= fread($this->file, $toRead); - } while ((($this->length = strlen($this->buffer)) != $totalLength) && !feof($this->file)); - - return true; - } else { - return false; - } - } -} \ No newline at end of file diff --git a/vendor/fpdi/pdf_parser.php b/vendor/fpdi/pdf_parser.php deleted file mode 100644 index a1c82dec..00000000 --- a/vendor/fpdi/pdf_parser.php +++ /dev/null @@ -1,913 +0,0 @@ -filename = $filename; - - $this->_f = @fopen($this->filename, 'rb'); - - if (!$this->_f) { - throw new InvalidArgumentException(sprintf('Cannot open %s !', $filename)); - } - - $this->getPdfVersion(); - - require_once('pdf_context.php'); - $this->_c = new pdf_context($this->_f); - - // Read xref-Data - $this->_xref = array(); - $this->_readXref($this->_xref, $this->_findXref()); - - // Check for Encryption - $this->getEncryption(); - - // Read root - $this->_readRoot(); - } - - /** - * Destructor - */ - public function __destruct() - { - $this->closeFile(); - } - - /** - * Close the opened file - */ - public function closeFile() - { - if (isset($this->_f) && is_resource($this->_f)) { - fclose($this->_f); - unset($this->_f); - } - } - - /** - * Check Trailer for Encryption - * - * @throws Exception - */ - public function getEncryption() - { - if (isset($this->_xref['trailer'][1]['/Encrypt'])) { - throw new Exception('File is encrypted!'); - } - } - - /** - * Get PDF-Version - * - * @return string - */ - public function getPdfVersion() - { - if ($this->_pdfVersion === null) { - fseek($this->_f, 0); - preg_match('/\d\.\d/', fread($this->_f, 16), $m); - if (isset($m[0])) - $this->_pdfVersion = $m[0]; - } - - return $this->_pdfVersion; - } - - /** - * Read the /Root dictionary - */ - protected function _readRoot() - { - if ($this->_xref['trailer'][1]['/Root'][0] != self::TYPE_OBJREF) { - throw new Exception('Wrong Type of Root-Element! Must be an indirect reference'); - } - - $this->_root = $this->resolveObject($this->_xref['trailer'][1]['/Root']); - } - - /** - * Find the xref table - * - * @return integer - * @throws Exception - */ - protected function _findXref() - { - $toRead = self::$searchForStartxrefLength; - - $stat = fseek($this->_f, -$toRead, SEEK_END); - if ($stat === -1) { - fseek($this->_f, 0); - } - - $data = fread($this->_f, $toRead); - - $keywordPos = strpos(strrev($data), strrev('startxref')); - if (false === $keywordPos) { - $keywordPos = strpos(strrev($data), strrev('startref')); - } - - if (false === $keywordPos) { - throw new Exception('Unable to find "startxref" keyword.'); - } - - $pos = strlen($data) - $keywordPos; - $data = substr($data, $pos); - - if (!preg_match('/\s*(\d+).*$/s', $data, $matches)) { - throw new Exception('Unable to find pointer to xref table.'); - } - - return (int) $matches[1]; - } - - /** - * Read the xref table - * - * @param array $result Array of xref table entries - * @param integer $offset of xref table - * @return boolean - * @throws Exception - */ - protected function _readXref(&$result, $offset) - { - $tempPos = $offset - min(20, $offset); - fseek($this->_f, $tempPos); // set some bytes backwards to fetch corrupted docs - - $data = fread($this->_f, 100); - - $xrefPos = strrpos($data, 'xref'); - - if ($xrefPos === false) { - $this->_c->reset($offset); - $xrefStreamObjDec = $this->_readValue($this->_c); - - if (is_array($xrefStreamObjDec) && isset($xrefStreamObjDec[0]) && $xrefStreamObjDec[0] == self::TYPE_OBJDEC) { - throw new Exception( - sprintf( - 'This document (%s) probably uses a compression technique which is not supported by the ' . - 'free parser shipped with FPDI. (See https://www.setasign.com/fpdi-pdf-parser for more details)', - $this->filename - ) - ); - } else { - throw new Exception('Unable to find xref table.'); - } - } - - if (!isset($result['xrefLocation'])) { - $result['xrefLocation'] = $tempPos + $xrefPos; - $result['maxObject'] = 0; - } - - $cycles = -1; - $bytesPerCycle = 100; - - fseek($this->_f, $tempPos = $tempPos + $xrefPos + 4); // set the handle directly after the "xref"-keyword - $data = fread($this->_f, $bytesPerCycle); - - while (($trailerPos = strpos($data, 'trailer', max($bytesPerCycle * $cycles++, 0))) === false && !feof($this->_f)) { - $data .= fread($this->_f, $bytesPerCycle); - } - - if ($trailerPos === false) { - throw new Exception('Trailer keyword not found after xref table'); - } - - $data = ltrim(substr($data, 0, $trailerPos)); - - // get Line-Ending - preg_match_all("/(\r\n|\n|\r)/", substr($data, 0, 100), $m); // check the first 100 bytes for line breaks - - $differentLineEndings = count(array_unique($m[0])); - if ($differentLineEndings > 1) { - $lines = preg_split("/(\r\n|\n|\r)/", $data, -1, PREG_SPLIT_NO_EMPTY); - } else { - $lines = explode($m[0][0], $data); - } - - $data = $differentLineEndings = $m = null; - unset($data, $differentLineEndings, $m); - - $linesCount = count($lines); - - $start = 1; - - for ($i = 0; $i < $linesCount; $i++) { - $line = trim($lines[$i]); - if ($line) { - $pieces = explode(' ', $line); - $c = count($pieces); - switch($c) { - case 2: - $start = (int)$pieces[0]; - $end = $start + (int)$pieces[1]; - if ($end > $result['maxObject']) - $result['maxObject'] = $end; - break; - case 3: - if (!isset($result['xref'][$start])) - $result['xref'][$start] = array(); - - if (!array_key_exists($gen = (int) $pieces[1], $result['xref'][$start])) { - $result['xref'][$start][$gen] = $pieces[2] == 'n' ? (int) $pieces[0] : null; - } - $start++; - break; - default: - throw new Exception('Unexpected data in xref table'); - } - } - } - - $lines = $pieces = $line = $start = $end = $gen = null; - unset($lines, $pieces, $line, $start, $end, $gen); - - $this->_c->reset($tempPos + $trailerPos + 7); - $trailer = $this->_readValue($this->_c); - - if (!isset($result['trailer'])) { - $result['trailer'] = $trailer; - } - - if (isset($trailer[1]['/Prev'])) { - $this->_readXref($result, $trailer[1]['/Prev'][1]); - } - - $trailer = null; - unset($trailer); - - return true; - } - - /** - * Reads a PDF value - * - * @param pdf_context $c - * @param string $token A token - * @return mixed - */ - protected function _readValue(&$c, $token = null) - { - if (is_null($token)) { - $token = $this->_readToken($c); - } - - if ($token === false) { - return false; - } - - switch ($token) { - case '<': - // This is a hex string. - // Read the value, then the terminator - - $pos = $c->offset; - - while(1) { - - $match = strpos ($c->buffer, '>', $pos); - - // If you can't find it, try - // reading more data from the stream - - if ($match === false) { - if (!$c->increaseLength()) { - return false; - } else { - continue; - } - } - - $result = substr ($c->buffer, $c->offset, $match - $c->offset); - $c->offset = $match + 1; - - return array (self::TYPE_HEX, $result); - } - break; - - case '<<': - // This is a dictionary. - - $result = array(); - - // Recurse into this function until we reach - // the end of the dictionary. - while (($key = $this->_readToken($c)) !== '>>') { - if ($key === false) { - return false; - } - - if (($value = $this->_readValue($c)) === false) { - return false; - } - - // Catch missing value - if ($value[0] == self::TYPE_TOKEN && $value[1] == '>>') { - $result[$key] = array(self::TYPE_NULL); - break; - } - - $result[$key] = $value; - } - - return array (self::TYPE_DICTIONARY, $result); - - case '[': - // This is an array. - - $result = array(); - - // Recurse into this function until we reach - // the end of the array. - while (($token = $this->_readToken($c)) !== ']') { - if ($token === false) { - return false; - } - - if (($value = $this->_readValue($c, $token)) === false) { - return false; - } - - $result[] = $value; - } - - return array (self::TYPE_ARRAY, $result); - - case '(': - // This is a string - $pos = $c->offset; - - $openBrackets = 1; - do { - for (; $openBrackets != 0 && $pos < $c->length; $pos++) { - switch (ord($c->buffer[$pos])) { - case 0x28: // '(' - $openBrackets++; - break; - case 0x29: // ')' - $openBrackets--; - break; - case 0x5C: // backslash - $pos++; - } - } - } while($openBrackets != 0 && $c->increaseLength()); - - $result = substr($c->buffer, $c->offset, $pos - $c->offset - 1); - $c->offset = $pos; - - return array (self::TYPE_STRING, $result); - - case 'stream': - $tempPos = $c->getPos() - strlen($c->buffer); - $tempOffset = $c->offset; - - $c->reset($startPos = $tempPos + $tempOffset); - - $e = 0; // ensure line breaks in front of the stream - if ($c->buffer[0] == chr(10) || $c->buffer[0] == chr(13)) - $e++; - if ($c->buffer[1] == chr(10) && $c->buffer[0] != chr(10)) - $e++; - - if ($this->_currentObj[1][1]['/Length'][0] == self::TYPE_OBJREF) { - $tmpLength = $this->resolveObject($this->_currentObj[1][1]['/Length']); - $length = $tmpLength[1][1]; - } else { - $length = $this->_currentObj[1][1]['/Length'][1]; - } - - if ($length > 0) { - $c->reset($startPos + $e, $length); - $v = $c->buffer; - } else { - $v = ''; - } - - $c->reset($startPos + $e + $length); - $endstream = $this->_readToken($c); - - if ($endstream != 'endstream') { - $c->reset($startPos + $e + $length + 9); // 9 = strlen("endstream") - // We don't throw an error here because the next - // round trip will start at a new offset - } - - return array(self::TYPE_STREAM, $v); - - default : - if (is_numeric($token)) { - // A numeric token. Make sure that - // it is not part of something else. - if (($tok2 = $this->_readToken($c)) !== false) { - if (is_numeric($tok2)) { - - // Two numeric tokens in a row. - // In this case, we're probably in - // front of either an object reference - // or an object specification. - // Determine the case and return the data - if (($tok3 = $this->_readToken($c)) !== false) { - switch ($tok3) { - case 'obj': - return array(self::TYPE_OBJDEC, (int)$token, (int)$tok2); - case 'R': - return array(self::TYPE_OBJREF, (int)$token, (int)$tok2); - } - // If we get to this point, that numeric value up - // there was just a numeric value. Push the extra - // tokens back into the stack and return the value. - array_push($c->stack, $tok3); - } - } - - array_push($c->stack, $tok2); - } - - if ($token === (string)((int)$token)) - return array(self::TYPE_NUMERIC, (int)$token); - else - return array(self::TYPE_REAL, (float)$token); - } else if ($token == 'true' || $token == 'false') { - return array(self::TYPE_BOOLEAN, $token == 'true'); - } else if ($token == 'null') { - return array(self::TYPE_NULL); - } else { - // Just a token. Return it. - return array(self::TYPE_TOKEN, $token); - } - } - } - - /** - * Resolve an object - * - * @param array $objSpec The object-data - * @return array|boolean - * @throws Exception - */ - public function resolveObject($objSpec) - { - $c = $this->_c; - - // Exit if we get invalid data - if (!is_array($objSpec)) { - return false; - } - - if ($objSpec[0] == self::TYPE_OBJREF) { - - // This is a reference, resolve it - if (isset($this->_xref['xref'][$objSpec[1]][$objSpec[2]])) { - - // Save current file position - // This is needed if you want to resolve - // references while you're reading another object - // (e.g.: if you need to determine the length - // of a stream) - - $oldPos = $c->getPos(); - - // Reposition the file pointer and - // load the object header. - - $c->reset($this->_xref['xref'][$objSpec[1]][$objSpec[2]]); - - $header = $this->_readValue($c); - - if ($header[0] != self::TYPE_OBJDEC || $header[1] != $objSpec[1] || $header[2] != $objSpec[2]) { - $toSearchFor = $objSpec[1] . ' ' . $objSpec[2] . ' obj'; - if (preg_match('/' . $toSearchFor . '/', $c->buffer)) { - $c->offset = strpos($c->buffer, $toSearchFor) + strlen($toSearchFor); - // reset stack - $c->stack = array(); - } else { - throw new Exception( - sprintf("Unable to find object (%s, %s) at expected location.", $objSpec[1], $objSpec[2]) - ); - } - } - - // If we're being asked to store all the information - // about the object, we add the object ID and generation - // number for later use - $result = array ( - self::TYPE_OBJECT, - 'obj' => $objSpec[1], - 'gen' => $objSpec[2] - ); - - $this->_currentObj =& $result; - - // Now simply read the object data until - // we encounter an end-of-object marker - while (true) { - $value = $this->_readValue($c); - if ($value === false || count($result) > 4) { - // in this case the parser couldn't find an "endobj" so we break here - break; - } - - if ($value[0] == self::TYPE_TOKEN && $value[1] === 'endobj') { - break; - } - - $result[] = $value; - } - - $c->reset($oldPos); - - if (isset($result[2][0]) && $result[2][0] == self::TYPE_STREAM) { - $result[0] = self::TYPE_STREAM; - } - - } else { - throw new Exception( - sprintf("Unable to find object (%s, %s) at expected location.", $objSpec[1], $objSpec[2]) - ); - } - - return $result; - } else { - return $objSpec; - } - } - - /** - * Reads a token from the context - * - * @param pdf_context $c - * @return mixed - */ - protected function _readToken($c) - { - // If there is a token available - // on the stack, pop it out and - // return it. - - if (count($c->stack)) { - return array_pop($c->stack); - } - - // Strip away any whitespace - - do { - if (!$c->ensureContent()) { - return false; - } - $c->offset += strspn($c->buffer, "\x20\x0A\x0C\x0D\x09\x00", $c->offset); - } while ($c->offset >= $c->length - 1); - - // Get the first character in the stream - - $char = $c->buffer[$c->offset++]; - - switch ($char) { - - case '[': - case ']': - case '(': - case ')': - - // This is either an array or literal string - // delimiter, Return it - - return $char; - - case '<': - case '>': - - // This could either be a hex string or - // dictionary delimiter. Determine the - // appropriate case and return the token - - if ($c->buffer[$c->offset] == $char) { - if (!$c->ensureContent()) { - return false; - } - $c->offset++; - return $char . $char; - } else { - return $char; - } - - case '%': - - // This is a comment - jump over it! - - $pos = $c->offset; - while(1) { - $match = preg_match("/(\r\n|\r|\n)/", $c->buffer, $m, PREG_OFFSET_CAPTURE, $pos); - if ($match === 0) { - if (!$c->increaseLength()) { - return false; - } else { - continue; - } - } - - $c->offset = $m[0][1] + strlen($m[0][0]); - - return $this->_readToken($c); - } - - default: - - // This is "another" type of token (probably - // a dictionary entry or a numeric value) - // Find the end and return it. - - if (!$c->ensureContent()) { - return false; - } - - while(1) { - - // Determine the length of the token - - $pos = strcspn($c->buffer, "\x20%[]<>()/\x0A\x0C\x0D\x09\x00", $c->offset); - - if ($c->offset + $pos <= $c->length - 1) { - break; - } else { - // If the script reaches this point, - // the token may span beyond the end - // of the current buffer. Therefore, - // we increase the size of the buffer - // and try again--just to be safe. - - $c->increaseLength(); - } - } - - $result = substr($c->buffer, $c->offset - 1, $pos + 1); - - $c->offset += $pos; - - return $result; - } - } - - /** - * Un-filter a stream object - * - * @param array $obj - * @return string - * @throws Exception - */ - protected function _unFilterStream($obj) - { - $filters = array(); - - if (isset($obj[1][1]['/Filter'])) { - $filter = $obj[1][1]['/Filter']; - - if ($filter[0] == pdf_parser::TYPE_OBJREF) { - $tmpFilter = $this->resolveObject($filter); - $filter = $tmpFilter[1]; - } - - if ($filter[0] == pdf_parser::TYPE_TOKEN) { - $filters[] = $filter; - } else if ($filter[0] == pdf_parser::TYPE_ARRAY) { - $filters = $filter[1]; - } - } - - $stream = $obj[2][1]; - - foreach ($filters AS $filter) { - switch ($filter[1]) { - case '/FlateDecode': - case '/Fl': - if (function_exists('gzuncompress')) { - $oStream = $stream; - $stream = (strlen($stream) > 0) ? @gzuncompress($stream) : ''; - } else { - throw new Exception( - sprintf('To handle %s filter, please compile php with zlib support.', $filter[1]) - ); - } - - if ($stream === false) { - $tries = 0; - while ($tries < 8 && ($stream === false || strlen($stream) < strlen($oStream))) { - $oStream = substr($oStream, 1); - $stream = @gzinflate($oStream); - $tries++; - } - - if ($stream === false) { - throw new Exception('Error while decompressing stream.'); - } - } - break; - case '/LZWDecode': - require_once('filters/FilterLZW.php'); - $decoder = new FilterLZW(); - $stream = $decoder->decode($stream); - break; - case '/ASCII85Decode': - require_once('filters/FilterASCII85.php'); - $decoder = new FilterASCII85(); - $stream = $decoder->decode($stream); - break; - case '/ASCIIHexDecode': - require_once('filters/FilterASCIIHexDecode.php'); - $decoder = new FilterASCIIHexDecode(); - $stream = $decoder->decode($stream); - break; - case null: - break; - default: - throw new Exception(sprintf('Unsupported Filter: %s', $filter[1])); - } - } - - return $stream; - } -} \ No newline at end of file diff --git a/vendor/hg/apidoc/.github/workflows/mirror.yml b/vendor/hg/apidoc/.github/workflows/mirror.yml deleted file mode 100644 index abed2638..00000000 --- a/vendor/hg/apidoc/.github/workflows/mirror.yml +++ /dev/null @@ -1,17 +0,0 @@ -name: 'GitHub Actions Mirror' - -on: [push] - -jobs: - mirror_to_gitee: - runs-on: ubuntu-latest - steps: - - name: 'Checkout' - uses: actions/checkout@v1 - - name: 'Mirror to gitee' - uses: pixta-dev/repository-mirroring-action@v1 - with: - target_repo_url: - git@gitee.com:hg-code/thinkphp-apidoc.git - ssh_private_key: - ${{ secrets.GITEE_KEY }} \ No newline at end of file diff --git a/vendor/hg/apidoc/.gitignore b/vendor/hg/apidoc/.gitignore deleted file mode 100644 index 485dee64..00000000 --- a/vendor/hg/apidoc/.gitignore +++ /dev/null @@ -1 +0,0 @@ -.idea diff --git a/vendor/hg/apidoc/LICENSE b/vendor/hg/apidoc/LICENSE deleted file mode 100644 index 5c9fa6f4..00000000 --- a/vendor/hg/apidoc/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2021 HG - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. \ No newline at end of file diff --git a/vendor/hg/apidoc/README.md b/vendor/hg/apidoc/README.md deleted file mode 100644 index fa988952..00000000 --- a/vendor/hg/apidoc/README.md +++ /dev/null @@ -1,79 +0,0 @@ -

- -

- -

- ThinkPHP ApiDoc -

- -
-基于ThinkPHP 根据注释自动生成API接口文档 -
- -
- - - - - - -
- - -## 🤷‍♀️ Apidoc是什么? - -如今,前后端分离的开发模式以必不可少,基于ThinkPHP可以很方便的作为后端Api的开发。可是一个Api开发过程中需要快速调试,开发完成后需要给其它开发者对接,这时一个详细的Api文档,就显得特别重要。 - -大多数开发者可能都是通过各种工具配合来达到这一目的,其各种工具的安装和配置也是繁琐。甚至还有通过word等文本工具手写api文档的,这样的开发效率与可维护性是非常差的。 - -综合种种Api开发中的痛点,我们专为ThinkPHP开发了Apidoc的扩展插件,本插件可通过简单的注解即可生成Api文档,及帮助开发者提高生产效率的在线调试、快速生成Crud、一键生成整个模块Api等,涵盖Api开发方方面面。 - - -## ✨特性 - -- 开箱即用:无繁杂的配置、安装后按文档编写注释即可自动生成API文档。 -- 在线调试:在线文档可直接调试,支持设置全局参数,接口调试省时省力。 -- 轻松编写:支持公共注释定义、业务逻辑层、数据表字段的引用,几句注释即可完成。 -- 安全高效:支持访问密码验证、应用/版本独立密码;支持文档缓存。 -- 多应用/多版本:可适应各种单应用、多应用、多版本的项目的Api管理。 -- Markdown文档:支持.md文件的文档展示。 -- 快速生成Crud:配置+模板即可快速生成Crud接口代码及数据表的创建,大大提高工作效率。 -- 控制器分组:更精细化的对控制器接口进行分组展示。 - - -## 📌兼容 - -ThinkPHP 5.x - -ThinkPHP 6.x - -> 📢 2.6.0版本开始全面兼容TP5了啦~~~ - - -## 📖使用文档 - -[ThinkPHP ApiDoc V2.x文档](https://hg-code.gitee.io/thinkphp-apidoc/) - - -## 🏆支持我们 - -如果本项目对您有所帮助,请点个Star支持我们 - -- [Github](https://github.com/HGthecode/thinkphp-apidoc) -> - Star me on GitHub -- [Gitee](https://gitee.com/hg-code/thinkphp-apidoc) -> star - -## 💡鸣谢 - -[ThinkPHP](http://www.thinkphp.cn/) -ThinkPHP - -doctrine/annotations - - -## 🔗链接 - ApiDoc UI前端 - - ApiDoc Demo 示例项目 - - diff --git a/vendor/hg/apidoc/composer.json b/vendor/hg/apidoc/composer.json deleted file mode 100644 index b3ada789..00000000 --- a/vendor/hg/apidoc/composer.json +++ /dev/null @@ -1,43 +0,0 @@ -{ - "name": "hg/apidoc", - "description": "thinkphp API文档自动生成", - "type": "think-extend", - "keywords": [ - "thinkphp", - "swagger", - "apidoc", - "api文档", - "接口文档", - "自动生成", - "注释生成", - "php接口文档" - ], - "require": { - "php": ">=7.1.0", - "doctrine/annotations": "^1.6", - "symfony/class-loader": "~3.2.0" - }, - "license": "MIT", - "authors": [ - { - "name": "hg-code", - "email": "376401263@qq.com" - } - ], - "autoload": { - "psr-4": { - "hg\\apidoc\\": "src/" - } - }, - "extra": { - "think": { - "services": [ - "hg\\apidoc\\Service" - ], - "config": { - "apidoc": "src/config.php" - } - } - }, - "minimum-stability": "beta" -} diff --git a/vendor/hg/apidoc/src/Auth.php b/vendor/hg/apidoc/src/Auth.php deleted file mode 100644 index 2da24fbb..00000000 --- a/vendor/hg/apidoc/src/Auth.php +++ /dev/null @@ -1,172 +0,0 @@ -config = Config::get('apidoc')?Config::get('apidoc'):Config::get('apidoc.'); - } - - /** - * 验证密码 - * @param $password - * @return false|string - */ - public function verifyAuth(string $password, string $appKey) - { - if (!empty($appKey)) { - $currentApps = (new Utils())->getCurrentApps($appKey); - $currentApp = $currentApps[count($currentApps) - 1]; - if (!empty($currentApp) && !empty($currentApp['password'])) { - // 应用密码 - if (md5($currentApp['password']) === $password) { - return $this->createToken($currentApp['password']); - } - throw new AuthException("password error"); - } - } - if ($this->config['auth']['enable']) { - // 密码验证 - if (md5($this->config['auth']['password']) === $password) { - return $this->createToken($this->config['auth']['password']); - } - throw new AuthException("password error"); - } - return false; - } - - /** - * 获取tokencode - * @param string $password - * @return string - */ - protected function getTokenCode(string $password): string - { - return md5(md5($password) . strtotime(date('Y-m-d', time()))); - } - - - /** - * 创建token - * @param string $password - * @return string - */ - public function createToken(string $password): string - { - return $this->handleToken($this->getTokenCode($password), "CE"); - } - - /** - * 验证token - * @param $token - * @return bool - */ - public function checkToken(string $token, string $password): bool - { - if (empty($password)) { - $password = $this->config['auth']['password']; - } - $decode = $this->handleToken($token, "DE"); - if ($decode === $this->getTokenCode($password)) { - return true; - } - return false; - } - - /** - * @param $request - * @return bool - */ - public function checkAuth(string $appKey): bool - { - $config = $this->config; - $request = Request::instance(); - - $token = $request->param("apidocToken"); - - if (!empty($appKey)) { - $currentApps = (new Utils())->getCurrentApps($appKey); - $currentApp = $currentApps[count($currentApps) - 1]; - if (!empty($currentApp) && !empty($currentApp['password'])) { - if (empty($token)) { - throw new AuthException("token not found"); - } - // 应用密码 - if ($this->checkToken($token, $currentApp['password'])) { - return true; - } else { - throw new AuthException("token error"); - } - } else if (!(!empty($config['auth']) && $config['auth']['enable'])) { - return true; - } - } - if(!empty($config['auth']) && $config['auth']['enable'] && empty($token)){ - throw new AuthException("token not found"); - }else if (!empty($token) && !$this->checkToken($token, "")) { - throw new AuthException("token error"); - } - return true; - } - - /** - * 处理token - * @param $string - * @param string $operation - * @param string $key - * @param int $expiry - * @return false|string - */ - protected function handleToken(string $string, string $operation = 'DE', string $key = '', int $expiry = 0):string - { - $ckey_length = 4; - $key = md5($key ? $key : $this->config['auth']['secret_key']); - $keya = md5(substr($key, 0, 16)); - $keyb = md5(substr($key, 16, 16)); - $keyc = $ckey_length ? ($operation == 'DE' ? substr($string, 0, $ckey_length) : substr(md5(microtime()), -$ckey_length)) : ''; - $cryptkey = $keya . md5($keya . $keyc); - $key_length = strlen($cryptkey); - $string = $operation == 'DE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) . $string; - $string_length = strlen($string); - $result = ''; - $box = range(0, 255); - $rndkey = array(); - for ($i = 0; $i <= 255; $i++) { - $rndkey[$i] = ord($cryptkey[$i % $key_length]); - } - for ($j = $i = 0; $i < 256; $i++) { - $j = ($j + $box[$i] + $rndkey[$i]) % 256; - $tmp = $box[$i]; - $box[$i] = $box[$j]; - $box[$j] = $tmp; - } - for ($a = $j = $i = 0; $i < $string_length; $i++) { - $a = ($a + 1) % 256; - $j = ($j + $box[$a]) % 256; - $tmp = $box[$a]; - $box[$a] = $box[$j]; - $box[$j] = $tmp; - $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256])); - } - if ($operation == 'DE') { - if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) { - return substr($result, 26); - } else { - return ''; - } - } else { - return $keyc . str_replace('=', '', base64_encode($result)); - } - } - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/Controller.php b/vendor/hg/apidoc/src/Controller.php deleted file mode 100644 index 48233401..00000000 --- a/vendor/hg/apidoc/src/Controller.php +++ /dev/null @@ -1,259 +0,0 @@ -[ - 'model'=>[ - 'fields_types'=>[ - "int", - "tinyint", - "smallint", - "mediumint", - "integer", - "bigint", - "bit", - "real", - "float", - "decimal", - "numeric", - "char", - "varchar", - "date", - "time", - "year", - "timestamp", - "datetime", - "tinyblob", - "blob", - "mediumblob", - "longblob", - "tinytext", - "text", - "mediumtext", - "longtext", - "enum", - "set", - "binary", - "varbinary", - "point", - "linestring", - "polygon", - "geometry", - "multipoint", - "multilinestring", - "multipolygon", - "geometrycollection" - ] - ] - ] - ]; - - public function __construct(App $app) - { - $this->app = $app; - $this->config = Config::get("apidoc")?Config::get("apidoc"):Config::get("apidoc."); - } - - /** - * 获取配置 - * @return \think\response\Json - */ - public function getConfig(){ - $config = $this->config; - if (!empty($config['auth'])){ - unset($config['auth']['auth_password']); - unset($config['auth']['password']); - unset($config['auth']['key']); - } - // 处理统一返回信息 - if (!empty($config['responses']) && is_string($config['responses'])){ - // 兼容原配置 - $config['responses'] = [ - 'jsonStr'=>$config['responses'] - ]; - }else if (!empty($config['responses']) && isset($config['responses']['show_responses']) && !$config['responses']['show_responses'] && !empty($config['responses']['data'])){ - // 显示在提示中 - $responsesStr = '{'."\r\n"; - $responsesMain = ""; - foreach ($config['responses']['data'] as $item){ - $responsesStr.='"'.$item['name'].'":"'.$item['desc'].'",'."\r\n"; - if (!empty($item['main']) && $item['main']==true){ - $responsesMain = $item; - } - } - $responsesStr.= '}'; - $config['responses']['jsonStr']=$responsesStr; - $config['responses']['main']=$responsesMain; - } - - $config['debug']=app()->isDebug(); - - if (!empty($config['crud'])){ - // 无配置可选字段类型,使用默认的 - if (!empty($config['crud']['model']) && empty($config['crud']['model']['fields_types'])){ - $config['crud']['model']['fields_types'] = $this->defaultConfig['crud']['model']['fields_types']; - } - // 过滤route文件配置 - if (!empty($config['crud']['route'])){ - unset($config['crud']['route']); - } - } - // 清除apps配置中的password - $config['apps'] = (new Utils())->handleAppsConfig($config['apps']); - return Utils::showJson(0,"",$config); - } - - /** - * 验证密码 - * @return false|\think\response\Json - * @throws \think\Exception - */ - public function verifyAuth(){ - $config = $this->config; - - $request = Request::instance(); - $params = $request->param(); - $password = $params['password']; - if (empty($password)){ - throw new AuthException( "password not found"); - } - $appKey = !empty($params['appKey'])?$params['appKey']:""; - - if (!$appKey && !(!empty($config['auth']) && $config['auth']['enable'])) { - return false; - } - try { - $hasAuth = (new Auth())->verifyAuth($password,$appKey); - return Utils::showJson(0,"",$hasAuth); - } catch (AuthException $e) { - return Utils::showJson($e->getCode(),$e->getMessage()); - } - - } - - /** - * 获取文档数据 - * @return \think\response\Json - */ - public function getApidoc(){ - - $config = $this->config; - $request = Request::instance(); - $params = $request->param(); - (new Auth())->checkAuth($params['appKey']); - - $cacheData=null; - if (!empty($config['cache']) && $config['cache']['enable']){ - $cacheData = (new CacheApiData())->get($params['appKey'],$params['cacheFileName']); - if ($cacheData && $params['reload']=='false'){ - $apiData = $cacheData['data']; - }else{ - // 生成数据并缓存 - $apiData = (new ParseAnnotation())->renderApiData($params['appKey']); - $cacheData =(new CacheApiData())->set($params['appKey'],$apiData); - } - }else{ - // 生成数据 - $apiData = (new ParseAnnotation())->renderApiData($params['appKey']); - } - $groups=[['title'=>'全部','name'=>0]]; - // 获取md - $docs = (new ParseMarkdown())->getDocsMenu(); - if (count($docs)>0){ - $menu_title = !empty($config['docs']) && !empty($config['docs']['menu_title'])?$config['docs']['menu_title']:'文档'; - $groups[]=['title'=>$menu_title,'name'=>'markdown_doc']; - } - if (!empty($config['groups']) && count($config['groups'])>0 && !empty($apiData['groups']) && count($apiData['groups'])>0){ - $configGroups=[]; - foreach ($config['groups'] as $group) { - if (in_array($group['name'],$apiData['groups'])){ - $configGroups[]=$group; - } - } - $groups = array_merge($groups,$configGroups); - } - $json=[ - 'groups'=>$groups, - 'list'=>$apiData['data'], - 'docs'=>$docs, - 'tags'=>$apiData['tags'] - ]; - if ($cacheData && !empty($cacheData['list'])){ - $json['cacheFiles']=$cacheData['list']; - $json['cacheName']=$cacheData['name']; - } - return Utils::showJson(0,"",$json); - } - - /** - * 获取md文档内容 - * @return \think\response\Json - */ - public function getMdDetail(){ - $request = Request::instance(); - $params = $request->param(); - try { - if (empty($params['path'])){ - throw new ErrorException("mdPath not found"); - } - if (empty($params['appKey'])){ - throw new ErrorException("appkey not found"); - } - (new Auth())->checkAuth($params['appKey']); - $res = (new ParseMarkdown())->getContent($params['appKey'],$params['path']); - return Utils::showJson(0,"",$res); - - } catch (ErrorException $e) { - return Utils::showJson($e->getCode(),$e->getMessage()); - } - } - - - /** - * 创建Crud - * @return \think\response\Json - */ - public function createCrud() - { - if (!\think\facade\App::isDebug()) { - throw new ErrorException("no debug",501); - } - $request = Request::instance(); - $params = $request->param(); - - if (!isset($params['appKey'])){ - throw new ErrorException("appkey not found"); - } - (new Auth())->checkAuth($params['appKey']); - $res = (new CreateCrud())->create($params); - return Utils::showJson(0,"",$res); - - - - } - - - - - - - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/Service.php b/vendor/hg/apidoc/src/Service.php deleted file mode 100644 index 42e6045f..00000000 --- a/vendor/hg/apidoc/src/Service.php +++ /dev/null @@ -1,35 +0,0 @@ -registerRoutes(function (){ - $route_prefix = 'apidoc'; - $apidocConfig = Config::get("apidoc")?Config::get("apidoc"):Config::get("apidoc."); - $routes = function () { - $controller_namespace = '\hg\apidoc\Controller@'; - Route::get('config' , $controller_namespace . 'getConfig'); - Route::get('apiData' , $controller_namespace . 'getApidoc'); - Route::get('mdDetail' , $controller_namespace . 'getMdDetail'); - Route::post('verifyAuth' , $controller_namespace . 'verifyAuth'); - Route::post('createCrud' , $controller_namespace . 'createCrud'); - }; - if (!empty($apidocConfig['allowCrossDomain'])){ - Route::group($route_prefix, $routes)->allowCrossDomain(); - } - Route::group($route_prefix, $routes); - }); - - - } - - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/Utils.php b/vendor/hg/apidoc/src/Utils.php deleted file mode 100644 index ec1166de..00000000 --- a/vendor/hg/apidoc/src/Utils.php +++ /dev/null @@ -1,330 +0,0 @@ - $code, - 'msg' => $msg, - 'data' => $data, - ]; - return json($res); - } - - /** - * 过滤参数字段 - * @param $data - * @param $fields - * @param string $type - * @return array - */ - public function filterParamsField(array $data, $fields, string $type = "field"): array - { - if ($fields && strpos($fields, ',') !== false){ - $fieldArr = explode(',', $fields); - }else{ - $fieldArr = [$fields]; - } - - $dataList = []; - foreach ($data as $item) { - if (!empty($item['name']) && in_array($item['name'], $fieldArr) && $type === 'field') { - $dataList[] = $item; - } else if (!(!empty($item['name']) && in_array($item['name'], $fieldArr)) && $type == "withoutField") { - $dataList[] = $item; - } - } - return $dataList; - } - - /** - * 读取文件内容 - * @param $fileName - * @return false|string - */ - public static function getFileContent(string $fileName): string - { - $content = ""; - if (file_exists($fileName)) { - $handle = fopen($fileName, "r"); - $content = fread($handle, filesize($fileName)); - fclose($handle); - } - return $content; - } - - /** - * 保存文件 - * @param $path - * @param $str_tmp - * @return bool - */ - public static function createFile(string $path, string $str_tmp): bool - { - $pathArr = explode("/", $path); - unset($pathArr[count($pathArr) - 1]); - $dir = implode("/", $pathArr); - if (!file_exists($dir)) { - mkdir($dir, 0777, true); - } - $fp = fopen($path, "w") or die("Unable to open file!"); - fwrite($fp, $str_tmp); //存入内容 - fclose($fp); - return true; - } - - /** - * 删除文件 - * @param $path - */ - public static function delFile(string $path) - { - $url = iconv('utf-8', 'gbk', $path); - if (PATH_SEPARATOR == ':') { //linux - unlink($path); - } else { //Windows - unlink($url); - } - } - - /** - * 将tree树形数据转成list数据 - * @param array $tree tree数据 - * @param string $childName 子节点名称 - * @return array 转换后的list数据 - */ - public function treeToList(array $tree, string $childName = 'children',string $key = "id",string $parentField = "parent") - { - $array = array(); - foreach ($tree as $val) { - $array[] = $val; - if (isset($val[$childName])) { - $children = $this->treeToList($val[$childName], $childName); - if ($children) { - $newChildren = []; - foreach ($children as $item) { - $item[$parentField] = $val[$key]; - $newChildren[] = $item; - } - $array = array_merge($array, $newChildren); - } - } - } - return $array; - } - - /** - * 根据一组keys获取所有关联节点 - * @param $tree - * @param $keys - */ - public function getTreeNodesByKeys(array $tree, array $keys, string $field = "id", string $childrenField = "children") - { - $list = $this->TreeToList($tree, $childrenField, "folder"); - $data = []; - foreach ($keys as $k => $v) { - $parent = !$k ? "" : $keys[$k - 1]; - foreach ($list as $item) { - if (((!empty($item['parent']) && $item['parent'] === $parent) || empty($item['parent'])) && $item[$field] == $v) { - $data[] = $item; - break; - } - } - } - return $data; - - } - - /** - * 替换模板变量 - * @param $temp - * @param $data - * @return string|string[] - */ - public static function replaceTemplate(string $temp, array $data):string - { - $str = $temp; - foreach ($data as $k => $v) { - $key = '${' . $k . '}'; - if (strpos($str, $key) !== false) { - $str = str_replace($key, $v, $str); - } - } - return $str; - } - - /** - * 替换当前所选应用/版本的变量 - * @param $temp - * @param $currentApps - * @return string|string[] - */ - public function replaceCurrentAppTemplate(string $temp,array $currentApps):string - { - $str = $temp; - if (!empty($currentApps) && count($currentApps) > 0) { - $data = []; - for ($i = 0; $i <= 3; $i++) { - if (isset($currentApps[$i])) { - $appItem = $currentApps[$i]; - foreach ($appItem as $k => $v) { - $key = 'app[' . $i . '].' . $k; - $data[$key] = $v; - } - } else { - $appItem = $currentApps[0]; - foreach ($appItem as $k => $v) { - $key = 'app[' . $i . '].' . $k; - $data[$key] = ""; - } - } - } - $str = $this->replaceTemplate($str, $data); - } - return $str; - } - - /** - * 根据条件获取数组中的值 - * @param array $array - * @param $query - * @return mixed|null - */ - public static function getArrayFind(array $array, $query) - { - $res = null; - if (is_array($array)) { - foreach ($array as $item) { - if ($query($item)) { - $res = $item; - break; - } - } - } - return $res; - } - - /** - * 合并对象数组并根据key去重 - * @param string $name - * @param mixed ...$array - * @return array - */ - public static function arrayMergeAndUnique(string $key = "name", ...$array):array - { - $mergeArr = []; - foreach ($array as $k => $v) { - $mergeArr = array_merge($mergeArr, $v); - } - $keys = []; - foreach ($mergeArr as $k => $v) { - $keys[] = $v[$key]; - } - $uniqueKeys = array_flip(array_flip($keys)); - $newArray = []; - foreach ($uniqueKeys as $k => $v) { - $newArray[] = $mergeArr[$k]; - } - return $newArray; - - } - - /** - * 初始化当前所选的应用/版本数据 - * @param $appKey - */ - public function getCurrentApps(string $appKey):array - { - $config = Config::get("apidoc")?Config::get("apidoc"):Config::get("apidoc."); - if (!(!empty($config['apps']) && count($config['apps']) > 0)) { - throw new ErrorException("no config apps", 500); - } - if (strpos($appKey, '_') !== false) { - $keyArr = explode("_", $appKey); - } else { - $keyArr = [$appKey]; - } - $currentApps = $this->getTreeNodesByKeys($config['apps'], $keyArr, 'folder', 'items'); - if (!$currentApps) { - throw new ErrorException("appKey error", 412, [ - 'appKey' => $appKey - ]); - } - return $currentApps; - - } - - /** - * 处理apps配置参数 - * @param array $apps - * @return array - */ - public function handleAppsConfig(array $apps):array - { - $appsConfig = []; - foreach ($apps as $app) { - if (!empty($app['password'])) { - unset($app['password']); - $app['hasPassword'] = true; - } - if (!empty($app['items']) && count($app['items']) > 0) { - $app['items'] = $this->handleAppsConfig($app['items']); - } - $appsConfig[] = $app; - } - return $appsConfig; - } - - /** - * 驼峰转下划线 - * - * @param string $value - * @param string $delimiter - * @return string - */ - public static function snake(string $value, string $delimiter = '_'): string - { - $key = $value; - - if (isset(static::$snakeCache[$key][$delimiter])) { - return static::$snakeCache[$key][$delimiter]; - } - - if (!ctype_lower($value)) { - $value = preg_replace('/\s+/u', '', $value); - - $value = static::lower(preg_replace('/(.)(?=[A-Z])/u', '$1' . $delimiter, $value)); - } - - return static::$snakeCache[$key][$delimiter] = $value; - } - - /** - * 字符串转小写 - * - * @param string $value - * @return string - */ - public static function lower(string $value): string - { - return mb_strtolower($value, 'UTF-8'); - } - - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/annotation/AddField.php b/vendor/hg/apidoc/src/annotation/AddField.php deleted file mode 100644 index 1e15028d..00000000 --- a/vendor/hg/apidoc/src/annotation/AddField.php +++ /dev/null @@ -1,44 +0,0 @@ - 'APi接口文档', - // 文档描述 - 'desc' => '', - // 版权申明 - 'copyright' => 'Powered By hg-code', - // 默认作者 - 'default_author'=>'', - // 默认请求类型 - 'default_method'=>'GET', - // 设置应用/版本(必须设置) - 'apps' => [ - ['title'=>'v1.0','path'=>'app\controller','folder'=>'v1'], - ], - // 控制器分组 - 'groups' => [], - // 指定公共注释定义的文件地址 - 'definitions' => "app\controller\Definitions", - //指定生成文档的控制器 - 'controllers' => [], - // 过滤,不解析的控制器 - 'filter_controllers' => [], - // 缓存配置 - 'cache' => [ - // 是否开启缓存 - 'enable' => false, - // 缓存文件路径 - 'path' => '../runtime/apidoc/', - // 是否显示更新缓存按钮 - 'reload' => true, - // 最大缓存文件数 - 'max' => 5, //最大缓存数量 - ], - // 权限认证配置 - 'auth' => [ - // 是否启用密码验证 - 'enable' => false, - // 验证密码 - 'password' => "123456", - // 密码加密盐 - 'secret_key' => "apidoc#hg_code", - ], - // 统一的请求Header - 'headers'=>[], - // 统一的请求参数Parameters - 'parameters'=>[], - // 统一的请求响应体,仅显示在文档提示中 - 'responses'=>[ - ['name'=>'code','desc'=>'状态码','type'=>'int'], - ['name'=>'message','desc'=>'操作描述','type'=>'string'], - ['name'=>'data','desc'=>'业务数据','main'=>true,'type'=>'object'], - ], - // md文档 - 'docs' => [ - 'menu_title' => '开发文档', - 'menus' => [] - ], - 'crud'=>[] - -]; diff --git a/vendor/hg/apidoc/src/crud/CreateCrud.php b/vendor/hg/apidoc/src/crud/CreateCrud.php deleted file mode 100644 index 0f58ca81..00000000 --- a/vendor/hg/apidoc/src/crud/CreateCrud.php +++ /dev/null @@ -1,383 +0,0 @@ -controller_layer = Config::get('route.controller_layer',"controller"); - if (!empty($config) && !empty($config['crud'])){ - $this->config = $config['crud']; - }else{ - throw new ErrorException("no config crud",501); - } - - } - - /** - * 创建Crud - * @param $params - * @return array - */ - public function create($params){ - - $appKey = $params['appKey']; - $currentApps = (new Utils())->getCurrentApps($appKey); -// $currentApp = $currentApps[count($currentApps) - 1]; - - $data = $this->renderTemplateData($params,$currentApps); - $res = []; - // 创建数据表 - if (!empty($params['model']['table'])){ - $sqlRes = $this->createModelTable($params['model'],$params['title']); - if ($sqlRes == true){ - $res[]="创建数据表成功"; - }else{ -// $msg= $sqlRes?$sqlRes:"数据表创建失败,请检查配置"; - throw new ErrorException("datatable crud error",500); - } - } - // 生成文件 - $keys = array_keys($this->config); - foreach ($keys as $index=>$key) { - // 添加路由 - if ( - $key==="route" && - !empty($this->config['route']) && - !empty($this->config['route']['template']) && - !empty($this->config['route']['path']) - ){ - $tmp_path = (new Utils())->replaceCurrentAppTemplate($this->config['route']['template'],$currentApps); - $tempPath = $tmp_path.".txt"; - $str_tmp = Utils::getFileContent($tempPath); - if (!empty($str_tmp)){ - $tmp_content = Utils::replaceTemplate($str_tmp,$data); - $tmp_content = (new Utils())->replaceCurrentAppTemplate($tmp_content,$currentApps); - $routePathStr = (new Utils())->replaceCurrentAppTemplate($this->config['route']['path'],$currentApps); - $routePathStr = str_replace("\\","/",$routePathStr); - $routePath = App::getAppPath().$routePathStr; - $routeContent = Utils::getFileContent($routePath); - $routeContent.="\r\n".$tmp_content."\r\n"; - Utils::createFile($routePath,$routeContent); - $res[]="添加路由成功"; - } - - }else{ - $currentConfig = $this->config[$key]; - $currentParam = $params[$key]; - $tmp_path = (new Utils())->replaceCurrentAppTemplate($currentParam['template'],$currentApps); - $tempPath = $tmp_path.".txt"; - $str_tmp = Utils::getFileContent($tempPath); - $file_content = Utils::replaceTemplate($str_tmp,$data); - $file_content = (new Utils())->replaceCurrentAppTemplate($file_content,$currentApps); - $namespacePath = str_replace("\\","/",$currentParam['path']); - $fileName = $data[$key.'.file_name']; - $filePath = '../'.$namespacePath.'/'.$fileName.'.php'; - $fp=Utils::createFile($filePath,$file_content); - if ($fp){ - $res[]="创建文件成功 path:".$filePath; - } - } - } - - return $res; - } - - - /** - * 生成模板变量的数据 - * @param $params - * @return array - */ - public function renderTemplateData($params,array $currentApps){ - // 模板参数 - $api_group = ""; - if (!empty($params['group'])){ - $api_group = '@Apidoc\Group("'.$params['group'].'")'; - } - $data=[ - 'title'=>!empty($params['title'])?$params['title']:"", - 'api_group'=>$api_group, - ]; - $keys = array_keys($this->config); - foreach ($keys as $index=>$key){ - $currentConfig = $this->config[$key]; - //验证模板是否存在 - $tmp_path = (new Utils())->replaceCurrentAppTemplate($currentConfig['template'],$currentApps); - if(!file_exists($tmp_path.'.txt')){ - throw new ErrorException("template not found",404,[ - 'template'=>$currentConfig['template'] - ]); - } - if ($key==="route"){ - continue; - } - $currentParam = $params[$key]; - if(!preg_match("/^[A-Z]{1}[A-Za-z0-9]{1,32}$/",$currentParam['class_name'])){ - throw new ErrorException("classname error",412,[ - 'classname'=>$currentParam['class_name'] - ]); - } - $currentParamPath = str_replace("\\","/",$currentParam['path']); - // 验证目录是否存在 - if(!is_dir('../'.$currentParamPath)){ - throw new ErrorException("path not found",404,[ - 'path'=>$currentParamPath - ]); - } - - - - $appPath = App::getAppPath(); - $appPathArr = explode("\\", $appPath); - $appFolder = $appPathArr[count($appPathArr)-1]?$appPathArr[count($appPathArr)-1]:$appPathArr[count($appPathArr)-2]; - $namespace = str_replace($appFolder, App::getNamespace(), $currentParam['path']); - - if ($key==="controller"){ - $pathArr = explode("\\", $namespace); - $notArr = array(App::getNamespace(), $this->controller_layer); - $url = "/"; - foreach ($pathArr as $pathItem){ - if (!in_array($pathItem,$notArr)){ - $url.=$pathItem."/"; - } - } - $data['folder']=$url; - $data['api_class_name']=lcfirst($currentParam['class_name']); - $data['api_url']=$url.lcfirst($currentParam['class_name']); - }else if ($key==="model" && !empty($currentParam['table'])){ - // 模型 - // 获取主键 - foreach ($currentParam['table'] as $item){ - if ($item['main_key']==true){ - $data['main_key.field'] = $item['field']; - $data['main_key.type'] = $item['type']; - $data['main_key.desc'] = $item['desc']; - break; - } - } - $tp_version = \think\facade\App::version(); - if (substr($tp_version, 0, 2) == '5.') { - $table_prefix = Config::get('database.prefix'); - }else{ - $driver = Config::get('database.default'); - $table_prefix = Config::get('database.connections.' . $driver . '.prefix'); - } - $data[$currentParam['name'] . '.table_prefix'] = $table_prefix; - $table_name = Utils::snake($currentParam['class_name']); - $data[$currentParam['name'].'.table_name']=$table_name; - } - - $namespace = str_replace($appFolder, App::getNamespace(), $currentParam['path']); - $data[$currentParam['name'].'.class_name']=$currentParam['class_name']; - $data[$currentParam['name'].'.namespace']=$namespace; - - // 验证文件是否已存在 - $fileName = $currentParam['class_name']; - if (!empty($currentConfig['file_name'])){ - $fileName = (new Utils())->replaceTemplate($currentConfig['file_name'],$data); - } - $filePath = '../'.$currentParamPath.'/'.$fileName.'.php'; - $data[$currentParam['name'].'.file_name']=$fileName; - if(file_exists($filePath)){ - throw new ErrorException("file already exists",500,[ - 'filepath'=>$filePath - ]); - } - $data[$currentParam['name'].'.use_path']=$namespace."\\".$fileName; - $data[$currentParam['name'].'.use_alias']=$fileName.ucwords($currentParam['name']); - - - } - - - - // 字段过滤数据 - if (!empty($params['model']['table'])){ - $checkKeys = ['list','detail','add','edit']; - foreach ($checkKeys as $checkKey){ - $itemArr = ['field'=>[],'withoutField'=>[]]; - foreach ($params['model']['table'] as $item){ - if ($item[$checkKey]){ - $itemArr['field'][]=$item['field']; - }else{ - $itemArr['withoutField'][]=$item['field']; - } - } - $data[$checkKey.'.field']=implode(",", $itemArr['field']); - $data[$checkKey.'.withoutField']=implode(",", $itemArr['withoutField']); - } - // 查询条件、验证规则 - $query_where='$where=[];'."\r\n"; - $query_annotation = ""; - $validate_rule = "["."\r\n"; - $validate_message = "["."\r\n"; - $validate_fields = []; - $addRequireFields = []; - foreach ($params['model']['table'] as $i=>$item){ - if ($item['query']){ - $itemArr['field'][]=$item['field']; - $query_where.= ' if(!empty($param[\''.$item['field'].'\'])){'."\r\n"; - $query_where.= ' $where[] = [\''.$item['field'].'\',\'=\',$param[\''.$item['field'].'\']];'."\r\n"; - $query_where.= ' }'."\r\n"; - $fh = empty($query_annotation)?'* ':' * '; - $require = $item['not_null']==true?'true':'false'; - $rn=""; - if (($i+1)config['validate'])){ - // 存在配置验证规则 - if (!empty($item['validate']) && $this->config['validate']['rules']){ - $rulesConfig = $this->config['validate']['rules']; - $currentRuleConfig = ""; - foreach ($rulesConfig as $rule){ - if ($rule['rule'] === $item['validate']){ - $currentRuleConfig = $rule; - break; - } - } - if (!empty($currentRuleConfig)){ - $validate_rule.=' \''.$item['field'].'\' => \''.$item['validate'].'\','."\r\n"; - if (!empty($currentRuleConfig['message']) ){ - if (is_array($currentRuleConfig['message']) && count($currentRuleConfig['message'])>0){ - foreach ($currentRuleConfig['message'] as $ruleKey=>$ruleMessage){ - if ($ruleKey=='0'){ - $ruleKeyStr = $item['field']; - }else{ - $ruleKeyStr = Utils::replaceTemplate($ruleKey,$item); - } - $ruleMessageStr = Utils::replaceTemplate($ruleMessage,$item); - $validate_message.=' \''.$ruleKeyStr.'\' => \''.$ruleMessageStr.'\','."\r\n"; - } - }else{ - $ruleMessageStr = Utils::replaceTemplate($currentRuleConfig['message'],$item); - $validate_message.=' \''.$item['field'].'\' => \''.$ruleMessageStr.'\','."\r\n"; - } - } - $validate_fields[]=$item['field']; - if($item['field'] !== $data['main_key.field']){ - $addRequireFields[]=$item['field']; - } - } - }else if($item['not_null']){ - $validate_fields[]=$item['field']; - if($item['field'] !== $data['main_key.field']){ - $addRequireFields[]=$item['field']; - } - // 根据not_null生成必填 - $validate_rule.=' \''.$item['field'].'\' => \'require\','."\r\n"; - $validate_message.=' \''.$item['field'].'\' => \''.$item['field'].'不可为空\','."\r\n"; - } - } - } - $validate_rule.=' ];'."\r\n"; - $validate_message.=' ];'."\r\n"; - if (!empty($this->config['validate'])) { - $data['validate.rule'] = $validate_rule; - $data['validate.message'] = $validate_message; - $data['validate.scene.edit'] = json_encode($validate_fields); - $data['validate.scene.add'] = json_encode($addRequireFields)=='[]'?'[\'\']':json_encode($addRequireFields); - $data['validate.scene.delete'] = '[\'' . $data['main_key.field'] . '\']'; - } - - $data['query.where']=$query_where; - $data['query.annotation']=$query_annotation; - } - return $data; - - } - - - /** - * 创建数据表 - * @return mixed - */ - public function createModelTable($params,$title=""){ - $data = $params['table']; - if (empty($title)){ - $title =$params['class_name']; - } - $driver = Config::get('database.default'); - $table_prefix=Config::get('database.connections.'.$driver.'.prefix'); - $table_name = $table_prefix.Utils::snake($params['class_name']); - $table_data = ''; - $main_keys = ''; - foreach ($data as $item){ - $table_field="`".$item['field']."` ".$item['type']; - if (!empty($item['length'])){ - $table_field.="(".$item['length'].")"; - } - if ($item['main_key']){ - $main_keys.=$item['field']; - $table_field.=" NOT NULL"; - }else if ($item['not_null']){ - $table_field.=" NOT NULL"; - } - if ($item['incremental']==true){ - $table_field.=" AUTO_INCREMENT"; - } - if (!empty($item['default']) || $item['default']=="0"){ - $table_field.=" DEFAULT '".$item['default']."'"; - } - $table_field.=" COMMENT '".$item['desc']."',"; - $table_data.=$table_field; - } - $sql = "CREATE TABLE IF NOT EXISTS `$table_name` ( - $table_data - PRIMARY KEY (`$main_keys`) - ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='$title' AUTO_INCREMENT=1 ;"; - - $tp_version = \think\facade\App::version(); - if (substr($tp_version, 0, 2) == '5.'){ - Db5::startTrans(); - try { - Db5::query($sql); - // 提交事务 - Db5::commit(); - return true; - } catch (\Exception $e) { - // 回滚事务 - Db5::rollback(); - return $e->getMessage(); - } - }else{ - Db::startTrans(); - try { - Db::query($sql); - // 提交事务 - Db::commit(); - return true; - } catch (\Exception $e) { - // 回滚事务 - Db::rollback(); - return $e->getMessage(); - } - } - - } - - - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/exception/AuthException.php b/vendor/hg/apidoc/src/exception/AuthException.php deleted file mode 100644 index 4083d4c3..00000000 --- a/vendor/hg/apidoc/src/exception/AuthException.php +++ /dev/null @@ -1,33 +0,0 @@ - ['code' => 4001, 'msg' => '密码不正确,请重新输入'], - 'password not found' => ['code' => 4002, 'msg' => '密码不可为空'], - 'token error' => ['code' => 4003, 'msg' => '不合法的Token'], - 'token not found' => ['code' => 4004, 'msg' => '不存在Token'], - ]; - - public function __construct(string $exceptionCode) - { - $exception = $this->getException($exceptionCode); - parent::__construct(401, $exception['msg'], null, [], $exception['code']); - } - - public function getException($exceptionCode) - { - if (isset($this->exceptions[$exceptionCode])) { - return $this->exceptions[$exceptionCode]; - } - throw new Exception('exceptionCode "' . $exceptionCode . '" Not Found'); - } -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/exception/ErrorException.php b/vendor/hg/apidoc/src/exception/ErrorException.php deleted file mode 100644 index b9dcd158..00000000 --- a/vendor/hg/apidoc/src/exception/ErrorException.php +++ /dev/null @@ -1,44 +0,0 @@ - ['code' => 4005, 'msg' => '缺少必要参数appKey'], - 'mdPath not found' => ['code' => 4006, 'msg' => '缺少必要参数path'], - 'appKey error' => ['code' => 4007, 'msg' => '不存在 folder为${appKey}的apps配置'], - 'template not found' => ['code' => 4008, 'msg' => '${template}模板不存在'], - 'path not found' => ['code' => 4009, 'msg' => '${path}目录不存在'], - 'classname error' => ['code' => 4010, 'msg' => '${classname}文件名不合法'], - 'no config apps' => ['code' => 5000, 'msg' => 'apps配置不可为空'], - 'no debug' => ['code' => 5001, 'msg' => '请在debug模式下,使用该功能'], - 'no config crud' => ['code' => 5002, 'msg' => 'crud未配置'], - 'datatable crud error' => ['code' => 5003, 'msg' => '数据表创建失败,请检查配置'], - 'file already exists' => ['code' => 5004, 'msg' => '${filepath}文件已存在'], - - ]; - - public function __construct(string $exceptionCode, int $statusCode = 412, array $data = []) - { - $exception = $this->getException($exceptionCode); - $msg = Utils::replaceTemplate($exception['msg'], $data); - parent::__construct($statusCode, $msg, null, [], $exception['code']); - } - - public function getException($exceptionCode) - { - if (isset($this->exceptions[$exceptionCode])) { - return $this->exceptions[$exceptionCode]; - } - throw new Exception('exceptionCode "' . $exceptionCode . '" Not Found'); - } - -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/parseApi/CacheApiData.php b/vendor/hg/apidoc/src/parseApi/CacheApiData.php deleted file mode 100644 index e10efda4..00000000 --- a/vendor/hg/apidoc/src/parseApi/CacheApiData.php +++ /dev/null @@ -1,127 +0,0 @@ -config = Config::get('apidoc'); - } - - /** - * 获取缓存目录 - * @param string $appKey - * @return string - */ - protected function getCacheFolder(string $appKey):string - { - $config = $this->config; - $currentApps = (new Utils())->getCurrentApps($appKey); - $configPath = !empty($config['cache']) && !empty($config['cache']['path']) ? $config['cache']['path'] : '../runtime/apidoc/'; - $cacheAppFolder = ""; - if (!empty($currentApps) && count($currentApps) > 0) { - foreach ($currentApps as $keyIndex => $appItem) { - $cacheAppFolder .= $appItem['folder'] . "/"; - } - } - $cacheFolder = $configPath . $cacheAppFolder; - return $cacheFolder; - } - - /** - * 获取指定目录下缓存文件名列表 - * @param string $folder - * @return array - */ - public function getCacheFileList(string $folder):array - { - $filePaths = glob($folder . '*.json'); - $cacheFiles = []; - if (count($filePaths) > 0) { - foreach ($filePaths as $item) { - $cacheFiles[] = str_replace(".json", "", basename($item)); - } - } - return $cacheFiles; - } - - - /** - * 获取接口缓存数据 - * @param string $appKey - * @param string $cacheFileName - * @return array|false - */ - public function get(string $appKey, string $cacheFileName) - { - $cacheFolder = $this->getCacheFolder($appKey); - $cacheFileList = $this->getCacheFileList($cacheFolder); - if (!file_exists($cacheFolder)) { - return false; - } - if (empty($cacheFileName) && count($cacheFileList) > 0) { - // 默认最后一个缓存文件 - $cacheFileName = $cacheFileList[count($cacheFileList) - 1]; - } - $cacheFilePath = $cacheFolder . "/" . $cacheFileName . '.json'; - if (file_exists($cacheFilePath)) { - // 存在缓存文件 - $fileContent = file_get_contents($cacheFilePath); - if (empty($fileContent)) { - return false; - } - $json = json_decode($fileContent); - if (is_object($json)) { - $json = [ - "data" => $json->data, - "tags" => $json->tags, - "groups" => $json->groups, - ]; - } - return [ - 'name' => $cacheFileName, - 'data' => $json, - 'list' => $cacheFileList - ]; - } - return false; - } - - /** - * 设置接口缓存 - * @param string $appKey - * @param array $json - * @return array|false - */ - public function set(string $appKey, array $json):array - { - if (empty($json)) { - return false; - } - $config = $this->config; - $fileName = date("Y-m-d H_i_s"); - $fileContent = json_encode($json); - $cacheFolder = $this->getCacheFolder($appKey); - $path = $cacheFolder . $fileName . ".json"; - Utils::createFile($path, $fileContent); - $filePaths = $this->getCacheFileList($cacheFolder); - if ($config['cache']['max'] && count($filePaths) >= $config['cache']['max']) { - //达到最大数量,删除第一个 - $filePath = $cacheFolder . $filePaths[0] . ".json"; - Utils::delFile($filePath); - } - return [ - "name" => $fileName, - "data" => $json, - "list" => $this->getCacheFileList($cacheFolder) - ]; - } -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/parseApi/ParseAnnotation.php b/vendor/hg/apidoc/src/parseApi/ParseAnnotation.php deleted file mode 100644 index 60cfbddb..00000000 --- a/vendor/hg/apidoc/src/parseApi/ParseAnnotation.php +++ /dev/null @@ -1,663 +0,0 @@ -reader = new AnnotationReader(); - $this->config = Config::get('apidoc')?Config::get('apidoc'):Config::get('apidoc.'); - $this->controller_layer = Config::get('route.controller_layer',"controller"); - } - - /** - * 生成api接口数据 - * @param string $appKey - * @return array - */ - public function renderApiData(string $appKey): array - { - $config = $this->config; - $currentApps = (new Utils())->getCurrentApps($appKey); - $currentApp = $currentApps[count($currentApps) - 1]; - - if (!empty($config['controllers']) && count($config['controllers']) > 0) { - // 配置的控制器列表 - $controllers = $this->getConfigControllers($currentApp['path']); - } else { - // 默认读取所有的 - $controllers = $this->getDirControllers($currentApp['path']); - } - $apiData = []; - if (!empty($controllers) && count($controllers) > 0) { - foreach ($controllers as $class) { - $classData = $this->parseController($class); - if ($classData !== false) { - $apiData[] = $classData; - } - } - } - $json = array( - "data" => $apiData, - "tags" => $this->tags, - "groups" => $this->groups - ); - return $json; - } - - /** - * 获取生成文档的控制器列表 - * @param string $path - * @return array - */ - protected function getConfigControllers(string $path): array - { - $config = $this->config; - $controllers = []; - - $configControllers = $config['controllers']; - if (!empty($configControllers) && count($configControllers) > 0) { - foreach ($configControllers as $item) { - if ( strpos($item, $path) !== false && class_exists($item)) { - $controllers[] = $item; - } - } - } - return $controllers; - } - - /** - * 获取目录下的控制器列表 - * @param string $path - * @return array - */ - protected function getDirControllers(string $path): array - { - if ($path) { - if (strpos(App::getRootPath(), '/') !== false) { - $pathStr = str_replace("\\", "/", $path); - } else { - $pathStr = $path; - } - $dir = App::getRootPath() . $pathStr; - } else { - $dir = App::getRootPath() . $this->controller_layer; - } - $controllers = []; - if (is_dir($dir)) { - $controllers = $this->scanDir($dir, $path); - } - return $controllers; - } - - /** - * 处理指定目录下的控制器 - * @param string $dir - * @param string $appPath - * @return array - */ - protected function scanDir(string $dir, string $appPath): array - { - $list = []; - foreach (ClassMapGenerator::createMap($dir) as $class => $path) { - if ( - !isset($this->config['filter_controllers']) || - (isset($this->config['filter_controllers']) && !in_array($class, $this->config['filter_controllers'])) && - $this->config['definitions'] != $class - ) { - if (strpos($class, '\\') === false) { - $list[] = $appPath . "\\" . $class; - } else { - $list[] = $class; - } - } - } - return $list; - } - - protected function parseController($class) - { - $config = $this->config; - $data = []; - $refClass = new ReflectionClass($class); - $classTextAnnotations = $this->parseTextAnnotation($refClass); - if (in_array("NotParse", $classTextAnnotations)) { - return false; - } - $title = $this->reader->getClassAnnotation($refClass, Title::class); - $group = $this->reader->getClassAnnotation($refClass, Group::class); - $sort = $this->reader->getClassAnnotation($refClass, Sort::class); - - $routeGroup = $this->reader->getClassAnnotation($refClass, RouteGroup::class); - $controllersNameArr = explode("\\", $class); - $controllersName = $controllersNameArr[count($controllersNameArr) - 1]; - $data['controller'] = $controllersName; - $data['group'] = !empty($group->value) ? $group->value : null; - $data['sort'] = !empty($sort->value) ? $sort->value : null; - if (!empty($data['group']) && !in_array($data['group'], $this->groups)) { - $this->groups[] = $data['group']; - } - $data['title'] = !empty($title) && !empty($title->value) ? $title->value : ""; - - if (empty($title)) { - if (!empty($classTextAnnotations) && count($classTextAnnotations) > 0) { - $data['title'] = $classTextAnnotations[0]; - } else { - $data['title'] = $controllersName; - } - } - $methodList = []; - $filter_method = !empty($config['filter_method']) ? $config['filter_method'] : []; - $data['menu_key'] = $data['controller'] . "_" . mt_rand(10000, 99999); - - foreach ($refClass->getMethods(\ReflectionMethod::IS_PUBLIC) as $refMethod) { - if (!empty($refMethod->name) && !in_array($refMethod->name, $filter_method)) { - $methodItem = $this->parseAnnotation($refMethod, true,"controller"); - if (!count((array)$methodItem)) { - continue; - } - $textAnnotations = $this->parseTextAnnotation($refMethod); - // 标注不解析的方法 - if (in_array("NotParse", $textAnnotations)) { - continue; - } - // 无标题,且有文本注释 - if (empty($methodItem['title']) && !empty($textAnnotations) && count($textAnnotations) > 0) { - $methodItem['title'] = $textAnnotations[0]; - } - // 添加统一headers请求头参数 - if (!empty($config['headers']) && !in_array("NotHeaders", $textAnnotations)) { - if (!empty($methodItem['header'])) { - $methodItem['header'] = Utils::arrayMergeAndUnique("name", $config['headers'], $methodItem['header']); - } else { - $methodItem['header'] = $config['headers']; - } - } - // 添加统一params请求参数 - if (!empty($config['parameters']) && !in_array("NotParameters", $textAnnotations)) { - if (!empty($methodItem['param'])) { - $methodItem['param'] = Utils::arrayMergeAndUnique("name", $config['parameters'], $methodItem['param']); - } else { - $methodItem['param'] = $config['parameters']; - } - } - // 添加responses统一响应体 - if ( - !empty($config['responses']) && - !is_string($config['responses']) && - !in_array("NotResponses", $textAnnotations) - ) { - // 显示在响应体中 - $returned = []; - $hasMian = false; - if (isset($config['responses']['data']) && !$config['responses']['show_responses']) { - $responsesData = []; - } else if (isset($config['responses']['data']) && $config['responses']['show_responses'] === true) { - $responsesData = $config['responses']['data']; - } else { - $responsesData = $config['responses']; - } - // 合并统一响应体及响应参数相同的字段 - $returnData = []; - $resKeys = []; - foreach ($responsesData as $resItem) { - $resKeys[]=$resItem['name']; - } - foreach ($methodItem['return'] as $returnItem){ - if (!(in_array($returnItem['name'],$resKeys) && $returnItem['source']==='controller' && !empty($returnItem['replaceGlobal']))){ - $returnData[]=$returnItem; - } - } - - foreach ($responsesData as $resItem) { - $resData = $resItem; - $globalFind = Utils::getArrayFind($methodItem['return'],function ($item)use ($resItem){ - if ($item['name'] == $resItem['name'] && $item['source']==='controller' && !empty($item['replaceGlobal'])){ - return true; - } - return false; - }); - if (!empty($globalFind)){ - $resData = array_merge($resItem,$globalFind); - }else if (!empty($resData['main']) && $resData['main'] === true) { - $resData['params'] = $returnData; - - $resData['resKeys']=$resKeys; - $hasMian = true; - } - $resData['find'] =$globalFind; - $returned[] = $resData; - } - if (!$hasMian) { - $returned = Utils::arrayMergeAndUnique("name", $returned, $methodItem['return']); - } - $methodItem['return'] = $returned; - } - // 默认method - if (empty($methodItem['method'])) { - $methodItem['method'] = !empty($config['default_method']) ? $config['default_method'] : 'GET'; - } - // 默认default_author - if (empty($methodItem['author']) && !empty($config['default_author']) && !in_array("NotDefaultAuthor", $textAnnotations)) { - $methodItem['author'] = $config['default_author']; - } - - // Tags - if (!empty($methodItem['tag'])) { - if (strpos($methodItem['tag'], ' ') !== false) { - $tagArr = explode(" ", $methodItem['tag']); - foreach ($tagArr as $tag) { - if (!in_array($tag, $this->tags)) { - $this->tags[] = $tag; - } - } - } else if (!in_array($methodItem['tag'], $this->tags)) { - $this->tags[] = $methodItem['tag']; - } - } - - // 无url,自动生成 - if (empty($methodItem['url'])) { - $methodItem['url'] = $this->autoCreateUrl($refMethod); - } else if (!empty($routeGroup->value)) { - // 路由分组,url加上分组 - $methodItem['url'] = '/' . $routeGroup->value . '/' . $methodItem['url']; - } - if (!empty($methodItem['url']) && substr($methodItem['url'], 0, 1) != "/") { - $methodItem['url'] = "/" . $methodItem['url']; - } - $methodItem['name'] = $refMethod->name; - $methodItem['menu_key'] = $methodItem['method'] . "_" . $refMethod->name . "_" . mt_rand(10000, 99999); - - $methodList[] = $methodItem; - - } - - } - $data['children'] = $methodList; - return $data; - } - - /** - * 自动生成url - * @param $method - * @return string - */ - protected function autoCreateUrl($method): string - { - if (Config::get("controller_auto_search") || !empty($this->config['controller_auto_search'])){ - $pathArr = explode("\\", $method->class ); - }else{ - $searchString = $this->controller_layer . '\\'; - $substr = substr(strstr($method->class, $searchString), strlen($searchString)); - $pathArr = explode("\\", str_replace($substr, str_replace('\\', '.', $substr), $method->class)); - } - // 控制器地址 - $filterPathNames = array(App::getNamespace(), $this->controller_layer); - $classPathArr = []; - foreach ($pathArr as $item) { - if (!in_array($item, $filterPathNames)) { - if (!empty($this->config['auto_url_rule'])){ - switch ($this->config['auto_url_rule']) { - case 'lcfirst': - $classPathArr[] = lcfirst($item); - break; - case 'ucfirst': - $classPathArr[] = ucfirst($item); - break; - default: - $classPathArr[] = $item; - } - }else{ - $classPathArr[] = $item; - } - } - } - $classPath = implode('/', $classPathArr); - return '/' . $classPath . '/' . $method->name; - } - - /** - * ref引用 - * @param $refPath - * @param bool $enableRefService - * @return false|string[] - */ - protected function renderRef(string $refPath, bool $enableRefService = true): array - { - $res = ['type' => 'model']; - // 通用定义引入 - if (strpos($refPath, '\\') === false) { - $config = $this->config; - $refPath = $config['definitions'] . '\\' . $refPath; - $data = $this->renderService($refPath); - $res['type'] = "service"; - $res['data'] = $data; - return $res; - } - // 模型引入 - $modelData = (new ParseModel($this->reader))->renderModel($refPath); - if ($modelData !== false) { - $res['data'] = $modelData; - return $res; - } - if ($enableRefService === false) { - return false; - } - $data = $this->renderService($refPath); - $res['type'] = "service"; - $res['data'] = $data; - return $res; - } - - /** - * 解析注释引用 - * @param $refPath - * @return array - * @throws \ReflectionException - */ - protected function renderService(string $refPath) - { - $pathArr = explode("\\", $refPath); - $methodName = $pathArr[count($pathArr) - 1]; - unset($pathArr[count($pathArr) - 1]); - $classPath = implode("\\", $pathArr); - $classReflect = new \ReflectionClass($classPath); - $methodName = trim($methodName); - $refMethod = $classReflect->getMethod($methodName); - $res = $this->parseAnnotation($refMethod, true); - return $res; - } - - /** - * 处理Param/Returned的字段名name、params子级参数 - * @param $values - * @return array - */ - protected function handleParamValue($values, string $field = 'param'): array - { - $name = ""; - $params = []; - if (!empty($values) && is_array($values) && count($values) > 0) { - foreach ($values as $item) { - if (is_string($item)) { - $name = $item; - } else if (is_object($item)) { - if (!empty($item->ref)) { - $refRes = $this->renderRef($item->ref, true); - $params = $this->handleRefData($params, $refRes, $item, $field); - } else { - $param = [ - "name" => "", - "type" => $item->type, - "desc" => $item->desc, - "default" => $item->default, - "require" => $item->require, - "childrenType"=> $item->childrenType - ]; - $children = $this->handleParamValue($item->value); - $param['name'] = $children['name']; - if (count($children['params']) > 0) { - $param['params'] = $children['params']; - } - $params[] = $param; - } - } - } - } else { - $name = $values; - } - return ['name' => $name, 'params' => $params]; - } - - /** - * 解析方法注释 - * @param $refMethod - * @param bool $enableRefService 是否终止service的引入 - * @param string $source 注解来源 - * @return array - */ - protected function parseAnnotation($refMethod, bool $enableRefService = true,$source=""): array - { - $data = []; - if ($annotations = $this->reader->getMethodAnnotations($refMethod)) { - $headers = []; - $params = []; - $returns = []; - - foreach ($annotations as $annotation) { - switch (true) { - case $annotation instanceof Param: - $params = $this->handleParamAndReturned($params,$annotation,'param',$enableRefService); - break; - case $annotation instanceof Returned: - - $returns = $this->handleParamAndReturned($returns,$annotation,'return',$enableRefService,$source); - break; - case $annotation instanceof Header: - if (!empty($annotation->ref)) { - $refRes = $this->renderRef($annotation->ref, $enableRefService); - $headers = $this->handleRefData($headers, $refRes, $annotation, 'header'); - } else { - $param = [ - "name" => $annotation->value, - "desc" => $annotation->desc, - "require" => $annotation->require, - "type" => $annotation->type, - "default" => $annotation->default, - ]; - $headers[] = $param; - } - break; - case $annotation instanceof Route: - if (empty($data['method'])) { - $data['method'] = $annotation->method; - } - if (empty($data['url'])) { - $data['url'] = $annotation->value; - } - break; - case $annotation instanceof Author: - $data['author'] = $annotation->value; - break; - - case $annotation instanceof Title: - $data['title'] = $annotation->value; - break; - case $annotation instanceof Desc: - $data['desc'] = $annotation->value; - break; - case $annotation instanceof ParamType: - $data['paramType'] = $annotation->value; - break; - case $annotation instanceof Url: - $data['url'] = $annotation->value; - break; - case $annotation instanceof Method: - $data['method'] = $annotation->value; - break; - case $annotation instanceof Tag: - $data['tag'] = $annotation->value; - break; - } - } - if ($headers && count($headers) > 0) { - $data['header'] = $headers; - } - $data['param'] = $params; - $data['return'] = $returns; - } - return $data; - } - - - /** - * 处理请求参数与返回参数 - * @param $params - * @param $annotation - * @param string $type - * @param false $enableRefService - * @param string $source 注解来源 - * @return array - */ - protected function handleParamAndReturned($params,$annotation,$type="param",$enableRefService=false,$source=""){ - if (!empty($annotation->ref)) { - $refRes = $this->renderRef($annotation->ref, $enableRefService); - $params = $this->handleRefData($params, $refRes, $annotation, $type,$source); - } else { - $param = [ - "name" => "", - "type" => $annotation->type, - "desc" => $annotation->desc, - "default" => $annotation->default, - "require" => $annotation->require, - "childrenType" => $annotation->childrenType, - "source" => $source, - "replaceGlobal" =>!empty($annotation->replaceGlobal)?$annotation->replaceGlobal:"" - ]; - $children = $this->handleParamValue($annotation->value, $type); - $param['name'] = $children['name']; - if (count($children['params']) > 0) { - $param['params'] = $children['params']; - if ($annotation->type === 'tree' && !empty($annotation->childrenField)) { - // 类型为tree的 - $param['params'][] = [ - 'params' => $children['params'], - 'name' => $annotation->childrenField, - 'type' => 'array', - 'desc' => $annotation->childrenDesc, - ]; - } - } - // 合并同级已有的字段 - $params = Utils::arrayMergeAndUnique("name", $params, [$param]); - } - return $params; - } - - /** - * 解析非注解文本注释 - * @param $refMethod - * @return array|false - */ - protected function parseTextAnnotation($refMethod): array - { - $annotation = $refMethod->getDocComment(); - if (empty($annotation)) { - return []; - } - if (preg_match('#^/\*\*(.*)\*/#s', $annotation, $comment) === false) - return []; - $comment = trim($comment [1]); - if (preg_match_all('#^\s*\*(.*)#m', $comment, $lines) === false) - return []; - $data = []; - foreach ($lines[1] as $line) { - $line = trim($line); - if (!empty ($line) && strpos($line, '@') !== 0) { - $data[] = $line; - } - } - return $data; - } - - - /** - * 处理param、returned 参数 - * @param $params - * @param $refRes - * @param $annotation - * @param string|null $source 注解来源 - * @return array - */ - protected function handleRefData($params, $refRes, $annotation, string $field,$source=""): array - { - if ($refRes['type'] === "model" && count($refRes['data']) > 0) { - // 模型引入 - $data = $refRes['data']; - } else if ($refRes['type'] === "service" && !empty($refRes['data']) && !empty($refRes['data'][$field])) { - // service引入 - $data = $refRes['data'][$field]; - } else { - return $params; - } - // 过滤field - if (!empty($annotation->field)) { - $data = (new Utils())->filterParamsField($data, $annotation->field, 'field'); - } - // 过滤withoutField - if (!empty($annotation->withoutField)) { - $data = (new Utils())->filterParamsField($data, $annotation->withoutField, 'withoutField'); - } - - if (!empty($annotation->value)) { - $item = [ - 'name' => $annotation->value, - 'desc' => $annotation->desc, - 'type' => $annotation->type, - 'require' => $annotation->require, - 'default' => $annotation->default, - 'params' => $data, - 'source'=>$source, - "replaceGlobal" =>!empty($annotation->replaceGlobal)?$annotation->replaceGlobal:"" - ]; - $children = $this->handleParamValue($annotation->value, 'param'); - $item['name'] = $children['name']; - if (count($children['params']) > 0) { - $item['params'] = Utils::arrayMergeAndUnique("name",$data,$children['params']); - if ($annotation->type === 'tree' && !empty($annotation->childrenField)) { - // 类型为tree的 - $item['params'][] = [ - 'params' => $item['params'], - 'name' => $annotation->childrenField, - 'type' => 'array', - 'desc' => $annotation->childrenDesc, - ]; - } - } - $params[] = $item; - - - } else { - $params = array_merge($params, $data); - } - return $params; - } -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/parseApi/ParseMarkdown.php b/vendor/hg/apidoc/src/parseApi/ParseMarkdown.php deleted file mode 100644 index d9daf30f..00000000 --- a/vendor/hg/apidoc/src/parseApi/ParseMarkdown.php +++ /dev/null @@ -1,71 +0,0 @@ -config = Config::get('apidoc')?Config::get('apidoc'):Config::get('apidoc.'); - } - - /** - * 获取md文档菜单 - * @return array - */ - public function getDocsMenu(): array - { - $config = $this->config; - $docData = []; - if (!empty($config['docs']) && !empty($config['docs']['menus']) && count($config['docs']['menus']) > 0) { - $docData = $this->handleDocsMenuData($config['docs']['menus']); - } - return $docData; - } - - /** - * 处理md文档菜单数据 - * @param array $menus - * @return array - */ - protected function handleDocsMenuData(array $menus): array - { - $list = []; - foreach ($menus as $item) { - if (!empty($item['items']) && count($item['items']) > 0) { - $item['items'] = $this->handleDocsMenuData($item['items']); - $item['group'] = 'markdown_doc'; - $item['menu_key'] = "md_group_" . mt_rand(10000, 99999); - $list[] = $item; - } else { - $item['type'] = 'md'; - $item['menu_key'] = "md_" . mt_rand(10000, 99999); - $list[] = $item; - } - } - return $list; - } - - - /** - * 获取md文档内容 - * @param string $appKey - * @param string $path - * @return string - */ - public function getContent(string $appKey, string $path): string - { - $currentApps = (new Utils())->getCurrentApps($appKey); - $mdPath = (new Utils())->replaceCurrentAppTemplate($path, $currentApps); - $filePath = App::getRootPath() . $mdPath . '.md'; - $contents = Utils::getFileContent($filePath); - return $contents; - } -} \ No newline at end of file diff --git a/vendor/hg/apidoc/src/parseApi/ParseModel.php b/vendor/hg/apidoc/src/parseApi/ParseModel.php deleted file mode 100644 index 339044b0..00000000 --- a/vendor/hg/apidoc/src/parseApi/ParseModel.php +++ /dev/null @@ -1,236 +0,0 @@ -reader = $reader; - } - - /** - * 生成模型数据 - * @param string $path - * @return array|false - * @throws \ReflectionException - */ - public function renderModel(string $path) - { - $modelClassArr = explode("\\", $path); - $modelActionName = $modelClassArr[count($modelClassArr) - 1]; - $modelClassName = $modelClassArr[count($modelClassArr) - 2]; - unset($modelClassArr[count($modelClassArr) - 1]); - $modelClassPath = implode("\\", $modelClassArr); - $classReflect = new \ReflectionClass($modelClassPath); - $modelActionName = trim($modelActionName); - $methodAction = $classReflect->getMethod($modelActionName); - // 获取所有模型属性 - $propertys = $classReflect->getDefaultProperties(); - - // 获取表字段 - $model = $this->getModel($methodAction, $modelClassName); - if (!is_callable(array($model, 'getTable'))) { - return false; - } - $table = $this->getTableDocument($model, $propertys); - - // 模型注释-field - if ($fieldAnnotations = $this->reader->getMethodAnnotation($methodAction, Field::class)) { - $table = (new Utils())->filterParamsField($table, $fieldAnnotations->value, 'field'); - } - // 模型注释-withoutField - if ($fieldAnnotations = $this->reader->getMethodAnnotation($methodAction, WithoutField::class)) { - $table = (new Utils())->filterParamsField($table, $fieldAnnotations->value, 'withoutField'); - } - // 模型注释-addField - if ($annotations = $this->reader->getMethodAnnotations($methodAction)) { - foreach ($annotations as $annotation) { - switch (true) { - case $annotation instanceof AddField: - $param = [ - "name" => "", - "desc" => $annotation->desc, - "require" => $annotation->require, - "type" => $annotation->type, - "default" => $annotation->default - ]; - $children = $this->handleParamValue($annotation->value); - $param['name'] = $children['name']; - if (count($children['params']) > 0) { - $param['params'] = $children['params']; - } - $isExists = false; - $newTable = []; - foreach ($table as $item) { - if ($param['name'] === $item['name']) { - $isExists = true; - $newTable[] = $param; - } else { - $newTable[] = $item; - } - } - $table = $newTable; - if (!$isExists) { - $table[] = $param; - } - break; - } - } - } - return $table; - } - - /** - * 处理字段参数 - * @param $values - * @return array - */ - protected function handleParamValue($values): array - { - $name = ""; - $params = []; - if (!empty($values) && is_array($values) && count($values) > 0) { - foreach ($values as $item) { - if (is_string($item)) { - $name = $item; - } else if (is_object($item)) { - $param = [ - "name" => "", - "type" => $item->type, - "desc" => $item->desc, - "default" => $item->default, - "require" => $item->require, - ]; - $children = $this->handleParamValue($item->value); - $param['name'] = $children['name']; - if (count($children['params']) > 0) { - $param['params'] = $children['params']; - } - $params[] = $param; - } - } - } else { - $name = $values; - } - return ['name' => $name, 'params' => $params]; - } - - /** - * 获取模型实例 - * @param $method - * @param $modelClassName - * @return mixed|null - */ - public function getModel($method, $modelClassName) - { - if (!empty($method->class)) { - $relationModelClass = $this->getIncludeClassName($method->class, $modelClassName); - if ($relationModelClass) { - $modelInstance = new $relationModelClass(); - return $modelInstance; - } else { - return null; - } - } else { - return null; - } - } - - - /** - * 获取模型类 - * @param $mainClass - * @param $class - * @return string - * @throws \ReflectionException - */ - protected function getIncludeClassName($mainClass, $class) - { - $classReflect = new \ReflectionClass($mainClass); - $possibleClass = $classReflect->getNamespaceName() . "\\" . $class; - if (class_exists($possibleClass)) { - return $possibleClass; - } else { - return ""; - } - } - - /** - * 获取模型注解数据 - * @param $model - * @param $propertys - * @return array - */ - public function getTableDocument($model,array $propertys):array - { - - $tp_version = \think\facade\App::version(); - if (substr($tp_version, 0, 2) == '5.'){ - $createSQL = Db5::query("show create table " . $model->getTable())[0]['Create Table']; - }else{ - $createSQL = Db::query("show create table " . $model->getTable())[0]['Create Table']; - } -// $createSQL = Db::query("show create table " . $model->getTable())[0]['Create Table']; - preg_match_all("#[^KEY]`(.*?)` (.*?) (.*?),\n#", $createSQL, $matches); - $fields = $matches[1]; - $types = $matches[2]; - $contents = $matches[3]; - $fieldComment = []; - //组织注释 - for ($i = 0; $i < count($matches[0]); $i++) { - $key = $fields[$i]; - $type = $types[$i]; - $default = ""; - $require = "0"; - $desc = ""; - $content = $contents[$i]; - if (strpos($type, '(`') !== false) { - continue; - } - if (strpos($content, 'COMMENT') !== false) { - // 存在字段注释 - preg_match_all("#COMMENT\s*'(.*?)'#", $content, $edscs); - if (!empty($edscs[1]) && !empty($edscs[1][0])) - $desc = $edscs[1][0]; - } - if (strpos($content, 'DEFAULT') !== false) { - // 存在字段默认值 - preg_match_all("#DEFAULT\s*'(.*?)'#", $content, $defaults); - $default = $defaults[1] && is_array($defaults[1])?$defaults[1][0]:""; - } - - if (strpos($content, 'NOT NULL') !== false) { - // 必填字段 - $require = "1"; - } - - $name = $key; - // 转换字段名为驼峰命名(用于输出) - if (isset($propertys['convertNameToCamel']) && $propertys['convertNameToCamel'] === true) { - $name = Str::camel($key); - } - $fieldComment[] = [ - "name" => $name, - "type" => $type, - "desc" => $desc, - "default" => $default, - "require" => $require, - ]; - } - return $fieldComment; - } - -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/.gitignore b/vendor/itxq/api-doc-php/.gitignore deleted file mode 100644 index c7e08005..00000000 --- a/vendor/itxq/api-doc-php/.gitignore +++ /dev/null @@ -1,3 +0,0 @@ -/.idea -/vendor/ -/composer.lock \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/LICENSE b/vendor/itxq/api-doc-php/LICENSE deleted file mode 100644 index 936e278d..00000000 --- a/vendor/itxq/api-doc-php/LICENSE +++ /dev/null @@ -1,191 +0,0 @@ -Apache License -Version 2.0, January 2004 -http://www.apache.org/licenses/ - -TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - -1. Definitions. - -"License" shall mean the terms and conditions for use, reproduction, and -distribution as defined by Sections 1 through 9 of this document. - -"Licensor" shall mean the copyright owner or entity authorized by the copyright -owner that is granting the License. - -"Legal Entity" shall mean the union of the acting entity and all other entities -that control, are controlled by, or are under common control with that entity. -For the purposes of this definition, "control" means (i) the power, direct or -indirect, to cause the direction or management of such entity, whether by -contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the -outstanding shares, or (iii) beneficial ownership of such entity. - -"You" (or "Your") shall mean an individual or Legal Entity exercising -permissions granted by this License. - -"Source" form shall mean the preferred form for making modifications, including -but not limited to software source code, documentation source, and configuration -files. - -"Object" form shall mean any form resulting from mechanical transformation or -translation of a Source form, including but not limited to compiled object code, -generated documentation, and conversions to other media types. - -"Work" shall mean the work of authorship, whether in Source or Object form, made -available under the License, as indicated by a copyright notice that is included -in or attached to the work (an example is provided in the Appendix below). - -"Derivative Works" shall mean any work, whether in Source or Object form, that -is based on (or derived from) the Work and for which the editorial revisions, -annotations, elaborations, or other modifications represent, as a whole, an -original work of authorship. For the purposes of this License, Derivative Works -shall not include works that remain separable from, or merely link (or bind by -name) to the interfaces of, the Work and Derivative Works thereof. - -"Contribution" shall mean any work of authorship, including the original version -of the Work and any modifications or additions to that Work or Derivative Works -thereof, that is intentionally submitted to Licensor for inclusion in the Work -by the copyright owner or by an individual or Legal Entity authorized to submit -on behalf of the copyright owner. For the purposes of this definition, -"submitted" means any form of electronic, verbal, or written communication sent -to the Licensor or its representatives, including but not limited to -communication on electronic mailing lists, source code control systems, and -issue tracking systems that are managed by, or on behalf of, the Licensor for -the purpose of discussing and improving the Work, but excluding communication -that is conspicuously marked or otherwise designated in writing by the copyright -owner as "Not a Contribution." - -"Contributor" shall mean Licensor and any individual or Legal Entity on behalf -of whom a Contribution has been received by Licensor and subsequently -incorporated within the Work. - -2. Grant of Copyright License. - -Subject to the terms and conditions of this License, each Contributor hereby -grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, -irrevocable copyright license to reproduce, prepare Derivative Works of, -publicly display, publicly perform, sublicense, and distribute the Work and such -Derivative Works in Source or Object form. - -3. Grant of Patent License. - -Subject to the terms and conditions of this License, each Contributor hereby -grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, -irrevocable (except as stated in this section) patent license to make, have -made, use, offer to sell, sell, import, and otherwise transfer the Work, where -such license applies only to those patent claims licensable by such Contributor -that are necessarily infringed by their Contribution(s) alone or by combination -of their Contribution(s) with the Work to which such Contribution(s) was -submitted. If You institute patent litigation against any entity (including a -cross-claim or counterclaim in a lawsuit) alleging that the Work or a -Contribution incorporated within the Work constitutes direct or contributory -patent infringement, then any patent licenses granted to You under this License -for that Work shall terminate as of the date such litigation is filed. - -4. Redistribution. - -You may reproduce and distribute copies of the Work or Derivative Works thereof -in any medium, with or without modifications, and in Source or Object form, -provided that You meet the following conditions: - -You must give any other recipients of the Work or Derivative Works a copy of -this License; and -You must cause any modified files to carry prominent notices stating that You -changed the files; and -You must retain, in the Source form of any Derivative Works that You distribute, -all copyright, patent, trademark, and attribution notices from the Source form -of the Work, excluding those notices that do not pertain to any part of the -Derivative Works; and -If the Work includes a "NOTICE" text file as part of its distribution, then any -Derivative Works that You distribute must include a readable copy of the -attribution notices contained within such NOTICE file, excluding those notices -that do not pertain to any part of the Derivative Works, in at least one of the -following places: within a NOTICE text file distributed as part of the -Derivative Works; within the Source form or documentation, if provided along -with the Derivative Works; or, within a display generated by the Derivative -Works, if and wherever such third-party notices normally appear. The contents of -the NOTICE file are for informational purposes only and do not modify the -License. You may add Your own attribution notices within Derivative Works that -You distribute, alongside or as an addendum to the NOTICE text from the Work, -provided that such additional attribution notices cannot be construed as -modifying the License. -You may add Your own copyright statement to Your modifications and may provide -additional or different license terms and conditions for use, reproduction, or -distribution of Your modifications, or for any such Derivative Works as a whole, -provided Your use, reproduction, and distribution of the Work otherwise complies -with the conditions stated in this License. - -5. Submission of Contributions. - -Unless You explicitly state otherwise, any Contribution intentionally submitted -for inclusion in the Work by You to the Licensor shall be under the terms and -conditions of this License, without any additional terms or conditions. -Notwithstanding the above, nothing herein shall supersede or modify the terms of -any separate license agreement you may have executed with Licensor regarding -such Contributions. - -6. Trademarks. - -This License does not grant permission to use the trade names, trademarks, -service marks, or product names of the Licensor, except as required for -reasonable and customary use in describing the origin of the Work and -reproducing the content of the NOTICE file. - -7. Disclaimer of Warranty. - -Unless required by applicable law or agreed to in writing, Licensor provides the -Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, -including, without limitation, any warranties or conditions of TITLE, -NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are -solely responsible for determining the appropriateness of using or -redistributing the Work and assume any risks associated with Your exercise of -permissions under this License. - -8. Limitation of Liability. - -In no event and under no legal theory, whether in tort (including negligence), -contract, or otherwise, unless required by applicable law (such as deliberate -and grossly negligent acts) or agreed to in writing, shall any Contributor be -liable to You for damages, including any direct, indirect, special, incidental, -or consequential damages of any character arising as a result of this License or -out of the use or inability to use the Work (including but not limited to -damages for loss of goodwill, work stoppage, computer failure or malfunction, or -any and all other commercial damages or losses), even if such Contributor has -been advised of the possibility of such damages. - -9. Accepting Warranty or Additional Liability. - -While redistributing the Work or Derivative Works thereof, You may choose to -offer, and charge a fee for, acceptance of support, warranty, indemnity, or -other liability obligations and/or rights consistent with this License. However, -in accepting such obligations, You may act only on Your own behalf and on Your -sole responsibility, not on behalf of any other Contributor, and only if You -agree to indemnify, defend, and hold each Contributor harmless for any liability -incurred by, or claims asserted against, such Contributor by reason of your -accepting any such warranty or additional liability. - -END OF TERMS AND CONDITIONS - -APPENDIX: How to apply the Apache License to your work - -To apply the Apache License to your work, attach the following boilerplate -notice, with the fields enclosed by brackets "{}" replaced with your own -identifying information. (Don't include the brackets!) The text should be -enclosed in the appropriate comment syntax for the file format. We also -recommend that a file or class name and description of purpose be included on -the same "printed page" as the copyright notice for easier identification within -third-party archives. - - Copyright 2018 IT小强xqitw.cn - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/README.md b/vendor/itxq/api-doc-php/README.md deleted file mode 100644 index 2c6b8f72..00000000 --- a/vendor/itxq/api-doc-php/README.md +++ /dev/null @@ -1,49 +0,0 @@ -# Api-Doc-PHP - -### 主要功能: - -+ 根据接口注释自动生成接口文档 - -### 演示地址 - -[【Gitee Pages:】http://itxq.gitee.io/api-doc-php](http://itxq.gitee.io/api-doc-php) - -### 开源地址: - -[【GigHub:】https://github.com/itxq/api-doc-php](https://github.com/itxq/api-doc-php) - -[【码云:】https://gitee.com/itxq/api-doc-php](https://github.com/itxq/api-doc-php) - -### 扩展安装: - -+ 方法一:composer命令 `composer require itxq/api-doc-php` - -+ 方法二:直接下载压缩包,然后进入项目中执行 composer命令 `composer update` 来生成自动加载文件 - -### 引用扩展: - -+ 当你的项目不支持composer自动加载时,可以使用以下方式来引用该扩展包 - -``` -// 引入扩展(具体路径请根据你的目录结构自行修改) -require_once __DIR__ . '/vendor/autoload.php'; -``` - -### 使用扩展: - -``` -// 引入扩展(具体路径请根据你的目录结构自行修改) -require_once __DIR__ . '/../vendor/autoload.php'; -// 加载测试API类1 -require_once __DIR__ . '/Api.php'; -// 加载测试API类2 -require_once __DIR__ . '/Api2.php'; -$config = [ - 'class' => ['Api', 'Api2'], // 要生成文档的类 - 'filter_method' => ['__construct'], // 要过滤的方法名称 -]; -$api = new \itxq\apidoc\BootstrapApiDoc($config); -$doc = $api->getHtml(); -exit($doc); -``` -### 具体效果可运行test目录下的`index.php`查看 \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/assets/css/bootstrap.min.css b/vendor/itxq/api-doc-php/assets/css/bootstrap.min.css deleted file mode 100644 index 7aebd0ff..00000000 --- a/vendor/itxq/api-doc-php/assets/css/bootstrap.min.css +++ /dev/null @@ -1,7 +0,0 @@ -/*! - * Bootstrap v4.1.1 (https://getbootstrap.com/) - * Copyright 2011-2018 The Bootstrap Authors - * Copyright 2011-2018 Twitter, Inc. - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) - */:root{--blue:#007bff;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#fd7e14;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#6c757d;--gray-dark:#343a40;--primary:#007bff;--secondary:#6c757d;--success:#28a745;--info:#17a2b8;--warning:#ffc107;--danger:#dc3545;--light:#f8f9fa;--dark:#343a40;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";--font-family-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}*,::after,::before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:transparent}@-ms-viewport{width:device-width}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;text-align:left;background-color:#fff}[tabindex="-1"]:focus{outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0}address{margin-bottom:1rem;font-style:normal;line-height:inherit}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects}a:hover{color:#0056b3;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus,a:not([href]):not([tabindex]):hover{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto;-ms-overflow-style:scrollbar}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg:not(:root){overflow:hidden}table{border-collapse:collapse}caption{padding-top:.75rem;padding-bottom:.75rem;color:#6c757d;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-family:inherit;font-weight:500;line-height:1.2;color:inherit}.h1,h1{font-size:2.5rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{margin-top:1rem;margin-bottom:1rem;border:0;border-top:1px solid rgba(0,0,0,.1)}.small,small{font-size:80%;font-weight:400}.mark,mark{padding:.2em;background-color:#fcf8e3}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:90%;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote-footer{display:block;font-size:80%;color:#6c757d}.blockquote-footer::before{content:"\2014 \00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:.25rem;background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{font-size:90%;color:#6c757d}code{font-size:87.5%;color:#e83e8c;word-break:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:87.5%;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{display:block;font-size:87.5%;color:#212529}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-right:0;padding-left:0}.col,.col-1,.col-10,.col-11,.col-12,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-auto,.col-lg,.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-auto,.col-md,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-auto,.col-sm,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-auto,.col-xl,.col-xl-1,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-auto{position:relative;width:100%;min-height:1px;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-ms-flex-order:-1;order:-1}.order-last{-ms-flex-order:13;order:13}.order-0{-ms-flex-order:0;order:0}.order-1{-ms-flex-order:1;order:1}.order-2{-ms-flex-order:2;order:2}.order-3{-ms-flex-order:3;order:3}.order-4{-ms-flex-order:4;order:4}.order-5{-ms-flex-order:5;order:5}.order-6{-ms-flex-order:6;order:6}.order-7{-ms-flex-order:7;order:7}.order-8{-ms-flex-order:8;order:8}.order-9{-ms-flex-order:9;order:9}.order-10{-ms-flex-order:10;order:10}.order-11{-ms-flex-order:11;order:11}.order-12{-ms-flex-order:12;order:12}.offset-1{margin-left:8.333333%}.offset-2{margin-left:16.666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.333333%}.offset-5{margin-left:41.666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.333333%}.offset-8{margin-left:66.666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.333333%}.offset-11{margin-left:91.666667%}@media (min-width:576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-sm-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-sm-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-sm-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-sm-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-sm-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-sm-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-sm-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-sm-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-sm-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-ms-flex-order:-1;order:-1}.order-sm-last{-ms-flex-order:13;order:13}.order-sm-0{-ms-flex-order:0;order:0}.order-sm-1{-ms-flex-order:1;order:1}.order-sm-2{-ms-flex-order:2;order:2}.order-sm-3{-ms-flex-order:3;order:3}.order-sm-4{-ms-flex-order:4;order:4}.order-sm-5{-ms-flex-order:5;order:5}.order-sm-6{-ms-flex-order:6;order:6}.order-sm-7{-ms-flex-order:7;order:7}.order-sm-8{-ms-flex-order:8;order:8}.order-sm-9{-ms-flex-order:9;order:9}.order-sm-10{-ms-flex-order:10;order:10}.order-sm-11{-ms-flex-order:11;order:11}.order-sm-12{-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.333333%}.offset-sm-2{margin-left:16.666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.333333%}.offset-sm-5{margin-left:41.666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.333333%}.offset-sm-8{margin-left:66.666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.333333%}.offset-sm-11{margin-left:91.666667%}}@media (min-width:768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-md-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-ms-flex-order:-1;order:-1}.order-md-last{-ms-flex-order:13;order:13}.order-md-0{-ms-flex-order:0;order:0}.order-md-1{-ms-flex-order:1;order:1}.order-md-2{-ms-flex-order:2;order:2}.order-md-3{-ms-flex-order:3;order:3}.order-md-4{-ms-flex-order:4;order:4}.order-md-5{-ms-flex-order:5;order:5}.order-md-6{-ms-flex-order:6;order:6}.order-md-7{-ms-flex-order:7;order:7}.order-md-8{-ms-flex-order:8;order:8}.order-md-9{-ms-flex-order:9;order:9}.order-md-10{-ms-flex-order:10;order:10}.order-md-11{-ms-flex-order:11;order:11}.order-md-12{-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.333333%}.offset-md-2{margin-left:16.666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.333333%}.offset-md-5{margin-left:41.666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.333333%}.offset-md-8{margin-left:66.666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.333333%}.offset-md-11{margin-left:91.666667%}}@media (min-width:992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-lg-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-ms-flex-order:-1;order:-1}.order-lg-last{-ms-flex-order:13;order:13}.order-lg-0{-ms-flex-order:0;order:0}.order-lg-1{-ms-flex-order:1;order:1}.order-lg-2{-ms-flex-order:2;order:2}.order-lg-3{-ms-flex-order:3;order:3}.order-lg-4{-ms-flex-order:4;order:4}.order-lg-5{-ms-flex-order:5;order:5}.order-lg-6{-ms-flex-order:6;order:6}.order-lg-7{-ms-flex-order:7;order:7}.order-lg-8{-ms-flex-order:8;order:8}.order-lg-9{-ms-flex-order:9;order:9}.order-lg-10{-ms-flex-order:10;order:10}.order-lg-11{-ms-flex-order:11;order:11}.order-lg-12{-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.333333%}.offset-lg-2{margin-left:16.666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.333333%}.offset-lg-5{margin-left:41.666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.333333%}.offset-lg-8{margin-left:66.666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.333333%}.offset-lg-11{margin-left:91.666667%}}@media (min-width:1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-xl-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-xl-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-xl-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-xl-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-xl-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-xl-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-xl-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-xl-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-xl-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-ms-flex-order:-1;order:-1}.order-xl-last{-ms-flex-order:13;order:13}.order-xl-0{-ms-flex-order:0;order:0}.order-xl-1{-ms-flex-order:1;order:1}.order-xl-2{-ms-flex-order:2;order:2}.order-xl-3{-ms-flex-order:3;order:3}.order-xl-4{-ms-flex-order:4;order:4}.order-xl-5{-ms-flex-order:5;order:5}.order-xl-6{-ms-flex-order:6;order:6}.order-xl-7{-ms-flex-order:7;order:7}.order-xl-8{-ms-flex-order:8;order:8}.order-xl-9{-ms-flex-order:9;order:9}.order-xl-10{-ms-flex-order:10;order:10}.order-xl-11{-ms-flex-order:11;order:11}.order-xl-12{-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.333333%}.offset-xl-2{margin-left:16.666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.333333%}.offset-xl-5{margin-left:41.666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.333333%}.offset-xl-8{margin-left:66.666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.333333%}.offset-xl-11{margin-left:91.666667%}}.table{width:100%;max-width:100%;margin-bottom:1rem;background-color:transparent}.table td,.table th{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table tbody+tbody{border-top:2px solid #dee2e6}.table .table{background-color:#fff}.table-sm td,.table-sm th{padding:.3rem}.table-bordered{border:1px solid #dee2e6}.table-bordered td,.table-bordered th{border:1px solid #dee2e6}.table-bordered thead td,.table-bordered thead th{border-bottom-width:2px}.table-borderless tbody+tbody,.table-borderless td,.table-borderless th,.table-borderless thead th{border:0}.table-striped tbody tr:nth-of-type(odd){background-color:rgba(0,0,0,.05)}.table-hover tbody tr:hover{background-color:rgba(0,0,0,.075)}.table-primary,.table-primary>td,.table-primary>th{background-color:#b8daff}.table-hover .table-primary:hover{background-color:#9fcdff}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#9fcdff}.table-secondary,.table-secondary>td,.table-secondary>th{background-color:#d6d8db}.table-hover .table-secondary:hover{background-color:#c8cbcf}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#c8cbcf}.table-success,.table-success>td,.table-success>th{background-color:#c3e6cb}.table-hover .table-success:hover{background-color:#b1dfbb}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b1dfbb}.table-info,.table-info>td,.table-info>th{background-color:#bee5eb}.table-hover .table-info:hover{background-color:#abdde5}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#abdde5}.table-warning,.table-warning>td,.table-warning>th{background-color:#ffeeba}.table-hover .table-warning:hover{background-color:#ffe8a1}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#ffe8a1}.table-danger,.table-danger>td,.table-danger>th{background-color:#f5c6cb}.table-hover .table-danger:hover{background-color:#f1b0b7}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#f1b0b7}.table-light,.table-light>td,.table-light>th{background-color:#fdfdfe}.table-hover .table-light:hover{background-color:#ececf6}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#ececf6}.table-dark,.table-dark>td,.table-dark>th{background-color:#c6c8ca}.table-hover .table-dark:hover{background-color:#b9bbbe}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#b9bbbe}.table-active,.table-active>td,.table-active>th{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:rgba(0,0,0,.075)}.table .thead-dark th{color:#fff;background-color:#212529;border-color:#32383e}.table .thead-light th{color:#495057;background-color:#e9ecef;border-color:#dee2e6}.table-dark{color:#fff;background-color:#212529}.table-dark td,.table-dark th,.table-dark thead th{border-color:#32383e}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,.05)}.table-dark.table-hover tbody tr:hover{background-color:rgba(255,255,255,.075)}@media (max-width:575.98px){.table-responsive-sm{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-sm>.table-bordered{border:0}}@media (max-width:767.98px){.table-responsive-md{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-md>.table-bordered{border:0}}@media (max-width:991.98px){.table-responsive-lg{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-lg>.table-bordered{border:0}}@media (max-width:1199.98px){.table-responsive-xl{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive>.table-bordered{border:0}.form-control{display:block;width:100%;padding:.375rem .75rem;font-size:1rem;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media screen and (prefers-reduced-motion:reduce){.form-control{transition:none}}.form-control::-ms-expand{background-color:transparent;border:0}.form-control:focus{color:#495057;background-color:#fff;border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.form-control::-webkit-input-placeholder{color:#6c757d;opacity:1}.form-control::-moz-placeholder{color:#6c757d;opacity:1}.form-control:-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::placeholder{color:#6c757d;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#e9ecef;opacity:1}select.form-control:not([size]):not([multiple]){height:calc(2.25rem + 2px)}select.form-control:focus::-ms-value{color:#495057;background-color:#fff}.form-control-file,.form-control-range{display:block;width:100%}.col-form-label{padding-top:calc(.375rem + 1px);padding-bottom:calc(.375rem + 1px);margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + 1px);padding-bottom:calc(.5rem + 1px);font-size:1.25rem;line-height:1.5}.col-form-label-sm{padding-top:calc(.25rem + 1px);padding-bottom:calc(.25rem + 1px);font-size:.875rem;line-height:1.5}.form-control-plaintext{display:block;width:100%;padding-top:.375rem;padding-bottom:.375rem;margin-bottom:0;line-height:1.5;color:#212529;background-color:transparent;border:solid transparent;border-width:1px 0}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm,.input-group-lg>.form-control-plaintext.form-control,.input-group-lg>.input-group-append>.form-control-plaintext.btn,.input-group-lg>.input-group-append>.form-control-plaintext.input-group-text,.input-group-lg>.input-group-prepend>.form-control-plaintext.btn,.input-group-lg>.input-group-prepend>.form-control-plaintext.input-group-text,.input-group-sm>.form-control-plaintext.form-control,.input-group-sm>.input-group-append>.form-control-plaintext.btn,.input-group-sm>.input-group-append>.form-control-plaintext.input-group-text,.input-group-sm>.input-group-prepend>.form-control-plaintext.btn,.input-group-sm>.input-group-prepend>.form-control-plaintext.input-group-text{padding-right:0;padding-left:0}.form-control-sm,.input-group-sm>.form-control,.input-group-sm>.input-group-append>.btn,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-prepend>.input-group-text{padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.input-group-sm>.input-group-append>select.btn:not([size]):not([multiple]),.input-group-sm>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-sm>select.form-control:not([size]):not([multiple]),select.form-control-sm:not([size]):not([multiple]){height:calc(1.8125rem + 2px)}.form-control-lg,.input-group-lg>.form-control,.input-group-lg>.input-group-append>.btn,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-prepend>.input-group-text{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.input-group-lg>.input-group-append>select.btn:not([size]):not([multiple]),.input-group-lg>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-lg>select.form-control:not([size]):not([multiple]),select.form-control-lg:not([size]):not([multiple]){height:calc(2.875rem + 2px)}.form-group{margin-bottom:1rem}.form-text{display:block;margin-top:.25rem}.form-row{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.form-row>.col,.form-row>[class*=col-]{padding-right:5px;padding-left:5px}.form-check{position:relative;display:block;padding-left:1.25rem}.form-check-input{position:absolute;margin-top:.3rem;margin-left:-1.25rem}.form-check-input:disabled~.form-check-label{color:#6c757d}.form-check-label{margin-bottom:0}.form-check-inline{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center;padding-left:0;margin-right:.75rem}.form-check-inline .form-check-input{position:static;margin-top:0;margin-right:.3125rem;margin-left:0}.valid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#28a745}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(40,167,69,.8);border-radius:.2rem}.custom-select.is-valid,.form-control.is-valid,.was-validated .custom-select:valid,.was-validated .form-control:valid{border-color:#28a745}.custom-select.is-valid:focus,.form-control.is-valid:focus,.was-validated .custom-select:valid:focus,.was-validated .form-control:valid:focus{border-color:#28a745;box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.custom-select.is-valid~.valid-feedback,.custom-select.is-valid~.valid-tooltip,.form-control.is-valid~.valid-feedback,.form-control.is-valid~.valid-tooltip,.was-validated .custom-select:valid~.valid-feedback,.was-validated .custom-select:valid~.valid-tooltip,.was-validated .form-control:valid~.valid-feedback,.was-validated .form-control:valid~.valid-tooltip{display:block}.form-control-file.is-valid~.valid-feedback,.form-control-file.is-valid~.valid-tooltip,.was-validated .form-control-file:valid~.valid-feedback,.was-validated .form-control-file:valid~.valid-tooltip{display:block}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:#28a745}.form-check-input.is-valid~.valid-feedback,.form-check-input.is-valid~.valid-tooltip,.was-validated .form-check-input:valid~.valid-feedback,.was-validated .form-check-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid~.custom-control-label,.was-validated .custom-control-input:valid~.custom-control-label{color:#28a745}.custom-control-input.is-valid~.custom-control-label::before,.was-validated .custom-control-input:valid~.custom-control-label::before{background-color:#71dd8a}.custom-control-input.is-valid~.valid-feedback,.custom-control-input.is-valid~.valid-tooltip,.was-validated .custom-control-input:valid~.valid-feedback,.was-validated .custom-control-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid:checked~.custom-control-label::before,.was-validated .custom-control-input:valid:checked~.custom-control-label::before{background-color:#34ce57}.custom-control-input.is-valid:focus~.custom-control-label::before,.was-validated .custom-control-input:valid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(40,167,69,.25)}.custom-file-input.is-valid~.custom-file-label,.was-validated .custom-file-input:valid~.custom-file-label{border-color:#28a745}.custom-file-input.is-valid~.custom-file-label::before,.was-validated .custom-file-input:valid~.custom-file-label::before{border-color:inherit}.custom-file-input.is-valid~.valid-feedback,.custom-file-input.is-valid~.valid-tooltip,.was-validated .custom-file-input:valid~.valid-feedback,.was-validated .custom-file-input:valid~.valid-tooltip{display:block}.custom-file-input.is-valid:focus~.custom-file-label,.was-validated .custom-file-input:valid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.invalid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#dc3545}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(220,53,69,.8);border-radius:.2rem}.custom-select.is-invalid,.form-control.is-invalid,.was-validated .custom-select:invalid,.was-validated .form-control:invalid{border-color:#dc3545}.custom-select.is-invalid:focus,.form-control.is-invalid:focus,.was-validated .custom-select:invalid:focus,.was-validated .form-control:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.custom-select.is-invalid~.invalid-feedback,.custom-select.is-invalid~.invalid-tooltip,.form-control.is-invalid~.invalid-feedback,.form-control.is-invalid~.invalid-tooltip,.was-validated .custom-select:invalid~.invalid-feedback,.was-validated .custom-select:invalid~.invalid-tooltip,.was-validated .form-control:invalid~.invalid-feedback,.was-validated .form-control:invalid~.invalid-tooltip{display:block}.form-control-file.is-invalid~.invalid-feedback,.form-control-file.is-invalid~.invalid-tooltip,.was-validated .form-control-file:invalid~.invalid-feedback,.was-validated .form-control-file:invalid~.invalid-tooltip{display:block}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:#dc3545}.form-check-input.is-invalid~.invalid-feedback,.form-check-input.is-invalid~.invalid-tooltip,.was-validated .form-check-input:invalid~.invalid-feedback,.was-validated .form-check-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid~.custom-control-label,.was-validated .custom-control-input:invalid~.custom-control-label{color:#dc3545}.custom-control-input.is-invalid~.custom-control-label::before,.was-validated .custom-control-input:invalid~.custom-control-label::before{background-color:#efa2a9}.custom-control-input.is-invalid~.invalid-feedback,.custom-control-input.is-invalid~.invalid-tooltip,.was-validated .custom-control-input:invalid~.invalid-feedback,.was-validated .custom-control-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid:checked~.custom-control-label::before,.was-validated .custom-control-input:invalid:checked~.custom-control-label::before{background-color:#e4606d}.custom-control-input.is-invalid:focus~.custom-control-label::before,.was-validated .custom-control-input:invalid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(220,53,69,.25)}.custom-file-input.is-invalid~.custom-file-label,.was-validated .custom-file-input:invalid~.custom-file-label{border-color:#dc3545}.custom-file-input.is-invalid~.custom-file-label::before,.was-validated .custom-file-input:invalid~.custom-file-label::before{border-color:inherit}.custom-file-input.is-invalid~.invalid-feedback,.custom-file-input.is-invalid~.invalid-tooltip,.was-validated .custom-file-input:invalid~.invalid-feedback,.was-validated .custom-file-input:invalid~.invalid-tooltip{display:block}.custom-file-input.is-invalid:focus~.custom-file-label,.was-validated .custom-file-input:invalid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.form-inline{display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap;-ms-flex-align:center;align-items:center}.form-inline .form-check{width:100%}@media (min-width:576px){.form-inline label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;margin-bottom:0}.form-inline .form-group{display:-ms-flexbox;display:flex;-ms-flex:0 0 auto;flex:0 0 auto;-ms-flex-flow:row wrap;flex-flow:row wrap;-ms-flex-align:center;align-items:center;margin-bottom:0}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-plaintext{display:inline-block}.form-inline .custom-select,.form-inline .input-group{width:auto}.form-inline .form-check{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:auto;padding-left:0}.form-inline .form-check-input{position:relative;margin-top:0;margin-right:.25rem;margin-left:0}.form-inline .custom-control{-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{display:inline-block;font-weight:400;text-align:center;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border:1px solid transparent;padding:.375rem .75rem;font-size:1rem;line-height:1.5;border-radius:.25rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media screen and (prefers-reduced-motion:reduce){.btn{transition:none}}.btn:focus,.btn:hover{text-decoration:none}.btn.focus,.btn:focus{outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.btn.disabled,.btn:disabled{opacity:.65}.btn:not(:disabled):not(.disabled){cursor:pointer}.btn:not(:disabled):not(.disabled).active,.btn:not(:disabled):not(.disabled):active{background-image:none}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:hover{color:#fff;background-color:#0069d9;border-color:#0062cc}.btn-primary.focus,.btn-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#0062cc;border-color:#005cbf}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-secondary{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:hover{color:#fff;background-color:#5a6268;border-color:#545b62}.btn-secondary.focus,.btn-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#545b62;border-color:#4e555b}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-success{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:hover{color:#fff;background-color:#218838;border-color:#1e7e34}.btn-success.focus,.btn-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:not(:disabled):not(.disabled).active,.btn-success:not(:disabled):not(.disabled):active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#1e7e34;border-color:#1c7430}.btn-success:not(:disabled):not(.disabled).active:focus,.btn-success:not(:disabled):not(.disabled):active:focus,.show>.btn-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-info{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:hover{color:#fff;background-color:#138496;border-color:#117a8b}.btn-info.focus,.btn-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:not(:disabled):not(.disabled).active,.btn-info:not(:disabled):not(.disabled):active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#117a8b;border-color:#10707f}.btn-info:not(:disabled):not(.disabled).active:focus,.btn-info:not(:disabled):not(.disabled):active:focus,.show>.btn-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-warning{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:hover{color:#212529;background-color:#e0a800;border-color:#d39e00}.btn-warning.focus,.btn-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-warning.disabled,.btn-warning:disabled{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:not(:disabled):not(.disabled).active,.btn-warning:not(:disabled):not(.disabled):active,.show>.btn-warning.dropdown-toggle{color:#212529;background-color:#d39e00;border-color:#c69500}.btn-warning:not(:disabled):not(.disabled).active:focus,.btn-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:hover{color:#fff;background-color:#c82333;border-color:#bd2130}.btn-danger.focus,.btn-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:not(:disabled):not(.disabled).active,.btn-danger:not(:disabled):not(.disabled):active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#bd2130;border-color:#b21f2d}.btn-danger:not(:disabled):not(.disabled).active:focus,.btn-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-light{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:hover{color:#212529;background-color:#e2e6ea;border-color:#dae0e5}.btn-light.focus,.btn-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-light.disabled,.btn-light:disabled{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:not(:disabled):not(.disabled).active,.btn-light:not(:disabled):not(.disabled):active,.show>.btn-light.dropdown-toggle{color:#212529;background-color:#dae0e5;border-color:#d3d9df}.btn-light:not(:disabled):not(.disabled).active:focus,.btn-light:not(:disabled):not(.disabled):active:focus,.show>.btn-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-dark{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:hover{color:#fff;background-color:#23272b;border-color:#1d2124}.btn-dark.focus,.btn-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:not(:disabled):not(.disabled).active,.btn-dark:not(:disabled):not(.disabled):active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#1d2124;border-color:#171a1d}.btn-dark:not(:disabled):not(.disabled).active:focus,.btn-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-primary{color:#007bff;background-color:transparent;background-image:none;border-color:#007bff}.btn-outline-primary:hover{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary.focus,.btn-outline-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#007bff;background-color:transparent}.btn-outline-primary:not(:disabled):not(.disabled).active,.btn-outline-primary:not(:disabled):not(.disabled):active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-secondary{color:#6c757d;background-color:transparent;background-image:none;border-color:#6c757d}.btn-outline-secondary:hover{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary.focus,.btn-outline-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#6c757d;background-color:transparent}.btn-outline-secondary:not(:disabled):not(.disabled).active,.btn-outline-secondary:not(:disabled):not(.disabled):active,.show>.btn-outline-secondary.dropdown-toggle{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-success{color:#28a745;background-color:transparent;background-image:none;border-color:#28a745}.btn-outline-success:hover{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success.focus,.btn-outline-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#28a745;background-color:transparent}.btn-outline-success:not(:disabled):not(.disabled).active,.btn-outline-success:not(:disabled):not(.disabled):active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success:not(:disabled):not(.disabled).active:focus,.btn-outline-success:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-info{color:#17a2b8;background-color:transparent;background-image:none;border-color:#17a2b8}.btn-outline-info:hover{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info.focus,.btn-outline-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#17a2b8;background-color:transparent}.btn-outline-info:not(:disabled):not(.disabled).active,.btn-outline-info:not(:disabled):not(.disabled):active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info:not(:disabled):not(.disabled).active:focus,.btn-outline-info:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-warning{color:#ffc107;background-color:transparent;background-image:none;border-color:#ffc107}.btn-outline-warning:hover{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning.focus,.btn-outline-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#ffc107;background-color:transparent}.btn-outline-warning:not(:disabled):not(.disabled).active,.btn-outline-warning:not(:disabled):not(.disabled):active,.show>.btn-outline-warning.dropdown-toggle{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-danger{color:#dc3545;background-color:transparent;background-image:none;border-color:#dc3545}.btn-outline-danger:hover{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger.focus,.btn-outline-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#dc3545;background-color:transparent}.btn-outline-danger:not(:disabled):not(.disabled).active,.btn-outline-danger:not(:disabled):not(.disabled):active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-light{color:#f8f9fa;background-color:transparent;background-image:none;border-color:#f8f9fa}.btn-outline-light:hover{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light.focus,.btn-outline-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#f8f9fa;background-color:transparent}.btn-outline-light:not(:disabled):not(.disabled).active,.btn-outline-light:not(:disabled):not(.disabled):active,.show>.btn-outline-light.dropdown-toggle{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light:not(:disabled):not(.disabled).active:focus,.btn-outline-light:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-dark{color:#343a40;background-color:transparent;background-image:none;border-color:#343a40}.btn-outline-dark:hover{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark.focus,.btn-outline-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#343a40;background-color:transparent}.btn-outline-dark:not(:disabled):not(.disabled).active,.btn-outline-dark:not(:disabled):not(.disabled):active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-link{font-weight:400;color:#007bff;background-color:transparent}.btn-link:hover{color:#0056b3;text-decoration:underline;background-color:transparent;border-color:transparent}.btn-link.focus,.btn-link:focus{text-decoration:underline;border-color:transparent;box-shadow:none}.btn-link.disabled,.btn-link:disabled{color:#6c757d;pointer-events:none}.btn-group-lg>.btn,.btn-lg{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.btn-group-sm>.btn,.btn-sm{padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:.5rem}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{transition:opacity .15s linear}@media screen and (prefers-reduced-motion:reduce){.fade{transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{position:relative;height:0;overflow:hidden;transition:height .35s ease}@media screen and (prefers-reduced-motion:reduce){.collapsing{transition:none}}.dropdown,.dropleft,.dropright,.dropup{position:relative}.dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid;border-right:.3em solid transparent;border-bottom:0;border-left:.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:10rem;padding:.5rem 0;margin:.125rem 0 0;font-size:1rem;color:#212529;text-align:left;list-style:none;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.15);border-radius:.25rem}.dropdown-menu-right{right:0;left:auto}.dropup .dropdown-menu{top:auto;bottom:100%;margin-top:0;margin-bottom:.125rem}.dropup .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:0;border-right:.3em solid transparent;border-bottom:.3em solid;border-left:.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-menu{top:0;right:auto;left:100%;margin-top:0;margin-left:.125rem}.dropright .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:0;border-bottom:.3em solid transparent;border-left:.3em solid}.dropright .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-toggle::after{vertical-align:0}.dropleft .dropdown-menu{top:0;right:100%;left:auto;margin-top:0;margin-right:.125rem}.dropleft .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:""}.dropleft .dropdown-toggle::after{display:none}.dropleft .dropdown-toggle::before{display:inline-block;width:0;height:0;margin-right:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:.3em solid;border-bottom:.3em solid transparent}.dropleft .dropdown-toggle:empty::after{margin-left:0}.dropleft .dropdown-toggle::before{vertical-align:0}.dropdown-menu[x-placement^=bottom],.dropdown-menu[x-placement^=left],.dropdown-menu[x-placement^=right],.dropdown-menu[x-placement^=top]{right:auto;bottom:auto}.dropdown-divider{height:0;margin:.5rem 0;overflow:hidden;border-top:1px solid #e9ecef}.dropdown-item{display:block;width:100%;padding:.25rem 1.5rem;clear:both;font-weight:400;color:#212529;text-align:inherit;white-space:nowrap;background-color:transparent;border:0}.dropdown-item:focus,.dropdown-item:hover{color:#16181b;text-decoration:none;background-color:#f8f9fa}.dropdown-item.active,.dropdown-item:active{color:#fff;text-decoration:none;background-color:#007bff}.dropdown-item.disabled,.dropdown-item:disabled{color:#6c757d;background-color:transparent}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:.5rem 1.5rem;margin-bottom:0;font-size:.875rem;color:#6c757d;white-space:nowrap}.dropdown-item-text{display:block;padding:.25rem 1.5rem;color:#212529}.btn-group,.btn-group-vertical{position:relative;display:-ms-inline-flexbox;display:inline-flex;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;-ms-flex:0 1 auto;flex:0 1 auto}.btn-group-vertical>.btn:hover,.btn-group>.btn:hover{z-index:1}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus{z-index:1}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group,.btn-group-vertical .btn+.btn,.btn-group-vertical .btn+.btn-group,.btn-group-vertical .btn-group+.btn,.btn-group-vertical .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:start;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:.5625rem;padding-left:.5625rem}.dropdown-toggle-split::after,.dropright .dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after{margin-left:0}.dropleft .dropdown-toggle-split::before{margin-right:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-right:.375rem;padding-left:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-group-vertical{-ms-flex-direction:column;flex-direction:column;-ms-flex-align:start;align-items:flex-start;-ms-flex-pack:center;justify-content:center}.btn-group-vertical .btn,.btn-group-vertical .btn-group{width:100%}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn:not(:first-child){border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type=checkbox],.btn-group-toggle>.btn input[type=radio],.btn-group-toggle>.btn-group>.btn input[type=checkbox],.btn-group-toggle>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:stretch;align-items:stretch;width:100%}.input-group>.custom-file,.input-group>.custom-select,.input-group>.form-control{position:relative;-ms-flex:1 1 auto;flex:1 1 auto;width:1%;margin-bottom:0}.input-group>.custom-file:focus,.input-group>.custom-select:focus,.input-group>.form-control:focus{z-index:3}.input-group>.custom-file+.custom-file,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.form-control,.input-group>.custom-select+.custom-file,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.form-control,.input-group>.form-control+.custom-file,.input-group>.form-control+.custom-select,.input-group>.form-control+.form-control{margin-left:-1px}.input-group>.custom-select:not(:last-child),.input-group>.form-control:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-select:not(:first-child),.input-group>.form-control:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label::after{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-append,.input-group-prepend{display:-ms-flexbox;display:flex}.input-group-append .btn,.input-group-prepend .btn{position:relative;z-index:2}.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.btn,.input-group-append .input-group-text+.input-group-text,.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-prepend .input-group-text+.input-group-text{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;padding:.375rem .75rem;margin-bottom:0;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;text-align:center;white-space:nowrap;background-color:#e9ecef;border:1px solid #ced4da;border-radius:.25rem}.input-group-text input[type=checkbox],.input-group-text input[type=radio]{margin-top:0}.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child),.input-group>.input-group-append:not(:last-child)>.btn,.input-group>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child),.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text{border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{position:relative;display:block;min-height:1.5rem;padding-left:1.5rem}.custom-control-inline{display:-ms-inline-flexbox;display:inline-flex;margin-right:1rem}.custom-control-input{position:absolute;z-index:-1;opacity:0}.custom-control-input:checked~.custom-control-label::before{color:#fff;background-color:#007bff}.custom-control-input:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-control-input:active~.custom-control-label::before{color:#fff;background-color:#b3d7ff}.custom-control-input:disabled~.custom-control-label{color:#6c757d}.custom-control-input:disabled~.custom-control-label::before{background-color:#e9ecef}.custom-control-label{position:relative;margin-bottom:0}.custom-control-label::before{position:absolute;top:.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;pointer-events:none;content:"";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#dee2e6}.custom-control-label::after{position:absolute;top:.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;content:"";background-repeat:no-repeat;background-position:center center;background-size:50% 50%}.custom-checkbox .custom-control-label::before{border-radius:.25rem}.custom-checkbox .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-checkbox .custom-control-input:disabled:indeterminate~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-radio .custom-control-label::before{border-radius:50%}.custom-radio .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-radio .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E")}.custom-radio .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-select{display:inline-block;width:100%;height:calc(2.25rem + 2px);padding:.375rem 1.75rem .375rem .75rem;line-height:1.5;color:#495057;vertical-align:middle;background:#fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right .75rem center;background-size:8px 10px;border:1px solid #ced4da;border-radius:.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:inset 0 1px 2px rgba(0,0,0,.075),0 0 5px rgba(128,189,255,.5)}.custom-select:focus::-ms-value{color:#495057;background-color:#fff}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;padding-right:.75rem;background-image:none}.custom-select:disabled{color:#6c757d;background-color:#e9ecef}.custom-select::-ms-expand{opacity:0}.custom-select-sm{height:calc(1.8125rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:75%}.custom-select-lg{height:calc(2.875rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:125%}.custom-file{position:relative;display:inline-block;width:100%;height:calc(2.25rem + 2px);margin-bottom:0}.custom-file-input{position:relative;z-index:2;width:100%;height:calc(2.25rem + 2px);margin:0;opacity:0}.custom-file-input:focus~.custom-file-label{border-color:#80bdff;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.custom-file-input:focus~.custom-file-label::after{border-color:#80bdff}.custom-file-input:lang(en)~.custom-file-label::after{content:"Browse"}.custom-file-label{position:absolute;top:0;right:0;left:0;z-index:1;height:calc(2.25rem + 2px);padding:.375rem .75rem;line-height:1.5;color:#495057;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem}.custom-file-label::after{position:absolute;top:0;right:0;bottom:0;z-index:3;display:block;height:2.25rem;padding:.375rem .75rem;line-height:1.5;color:#495057;content:"Browse";background-color:#e9ecef;border-left:1px solid #ced4da;border-radius:0 .25rem .25rem 0}.custom-range{width:100%;padding-left:0;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-range:focus{outline:0}.custom-range::-moz-focus-outer{border:0}.custom-range::-webkit-slider-thumb{width:1rem;height:1rem;margin-top:-.25rem;background-color:#007bff;border:0;border-radius:1rem;-webkit-appearance:none;appearance:none}.custom-range::-webkit-slider-thumb:focus{outline:0;box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range::-webkit-slider-thumb:active{background-color:#b3d7ff}.custom-range::-webkit-slider-runnable-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-moz-range-thumb{width:1rem;height:1rem;background-color:#007bff;border:0;border-radius:1rem;-moz-appearance:none;appearance:none}.custom-range::-moz-range-thumb:focus{outline:0;box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range::-moz-range-thumb:active{background-color:#b3d7ff}.custom-range::-moz-range-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-ms-thumb{width:1rem;height:1rem;background-color:#007bff;border:0;border-radius:1rem;appearance:none}.custom-range::-ms-thumb:focus{outline:0;box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range::-ms-thumb:active{background-color:#b3d7ff}.custom-range::-ms-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:transparent;border-color:transparent;border-width:.5rem}.custom-range::-ms-fill-lower{background-color:#dee2e6;border-radius:1rem}.custom-range::-ms-fill-upper{margin-right:15px;background-color:#dee2e6;border-radius:1rem}.nav{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:.5rem 1rem}.nav-link:focus,.nav-link:hover{text-decoration:none}.nav-link.disabled{color:#6c757d}.nav-tabs{border-bottom:1px solid #dee2e6}.nav-tabs .nav-item{margin-bottom:-1px}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:.25rem;border-top-right-radius:.25rem}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{border-color:#e9ecef #e9ecef #dee2e6}.nav-tabs .nav-link.disabled{color:#6c757d;background-color:transparent;border-color:transparent}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{color:#495057;background-color:#fff;border-color:#dee2e6 #dee2e6 #fff}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.nav-pills .nav-link{border-radius:.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:#fff;background-color:#007bff}.nav-fill .nav-item{-ms-flex:1 1 auto;flex:1 1 auto;text-align:center}.nav-justified .nav-item{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;text-align:center}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{position:relative;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;padding:.5rem 1rem}.navbar>.container,.navbar>.container-fluid{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}.navbar-brand{display:inline-block;padding-top:.3125rem;padding-bottom:.3125rem;margin-right:1rem;font-size:1.25rem;line-height:inherit;white-space:nowrap}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-nav{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link{padding-right:0;padding-left:0}.navbar-nav .dropdown-menu{position:static;float:none}.navbar-text{display:inline-block;padding-top:.5rem;padding-bottom:.5rem}.navbar-collapse{-ms-flex-preferred-size:100%;flex-basis:100%;-ms-flex-positive:1;flex-grow:1;-ms-flex-align:center;align-items:center}.navbar-toggler{padding:.25rem .75rem;font-size:1.25rem;line-height:1;background-color:transparent;border:1px solid transparent;border-radius:.25rem}.navbar-toggler:focus,.navbar-toggler:hover{text-decoration:none}.navbar-toggler:not(:disabled):not(.disabled){cursor:pointer}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;content:"";background:no-repeat center center;background-size:100% 100%}@media (max-width:575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:576px){.navbar-expand-sm{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}}@media (max-width:767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:768px){.navbar-expand-md{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-md .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}}@media (max-width:991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:992px){.navbar-expand-lg{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}}@media (max-width:1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:1200px){.navbar-expand-xl{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}}.navbar-expand{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-right:0;padding-left:0}.navbar-expand .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-light .navbar-brand{color:rgba(0,0,0,.9)}.navbar-light .navbar-brand:focus,.navbar-light .navbar-brand:hover{color:rgba(0,0,0,.9)}.navbar-light .navbar-nav .nav-link{color:rgba(0,0,0,.5)}.navbar-light .navbar-nav .nav-link:focus,.navbar-light .navbar-nav .nav-link:hover{color:rgba(0,0,0,.7)}.navbar-light .navbar-nav .nav-link.disabled{color:rgba(0,0,0,.3)}.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.active,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .show>.nav-link{color:rgba(0,0,0,.9)}.navbar-light .navbar-toggler{color:rgba(0,0,0,.5);border-color:rgba(0,0,0,.1)}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-light .navbar-text{color:rgba(0,0,0,.5)}.navbar-light .navbar-text a{color:rgba(0,0,0,.9)}.navbar-light .navbar-text a:focus,.navbar-light .navbar-text a:hover{color:rgba(0,0,0,.9)}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:focus,.navbar-dark .navbar-brand:hover{color:#fff}.navbar-dark .navbar-nav .nav-link{color:rgba(255,255,255,.5)}.navbar-dark .navbar-nav .nav-link:focus,.navbar-dark .navbar-nav .nav-link:hover{color:rgba(255,255,255,.75)}.navbar-dark .navbar-nav .nav-link.disabled{color:rgba(255,255,255,.25)}.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.active,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .show>.nav-link{color:#fff}.navbar-dark .navbar-toggler{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.1)}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-dark .navbar-text{color:rgba(255,255,255,.5)}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:focus,.navbar-dark .navbar-text a:hover{color:#fff}.card{position:relative;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;min-width:0;word-wrap:break-word;background-color:#fff;background-clip:border-box;border:1px solid rgba(0,0,0,.125);border-radius:.25rem}.card>hr{margin-right:0;margin-left:0}.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-body{-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:.75rem}.card-subtitle{margin-top:-.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{padding:.75rem 1.25rem;margin-bottom:0;background-color:rgba(0,0,0,.03);border-bottom:1px solid rgba(0,0,0,.125)}.card-header:first-child{border-radius:calc(.25rem - 1px) calc(.25rem - 1px) 0 0}.card-header+.list-group .list-group-item:first-child{border-top:0}.card-footer{padding:.75rem 1.25rem;background-color:rgba(0,0,0,.03);border-top:1px solid rgba(0,0,0,.125)}.card-footer:last-child{border-radius:0 0 calc(.25rem - 1px) calc(.25rem - 1px)}.card-header-tabs{margin-right:-.625rem;margin-bottom:-.75rem;margin-left:-.625rem;border-bottom:0}.card-header-pills{margin-right:-.625rem;margin-left:-.625rem}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem}.card-img{width:100%;border-radius:calc(.25rem - 1px)}.card-img-top{width:100%;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card-img-bottom{width:100%;border-bottom-right-radius:calc(.25rem - 1px);border-bottom-left-radius:calc(.25rem - 1px)}.card-deck{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.card-deck .card{margin-bottom:15px}@media (min-width:576px){.card-deck{-ms-flex-flow:row wrap;flex-flow:row wrap;margin-right:-15px;margin-left:-15px}.card-deck .card{display:-ms-flexbox;display:flex;-ms-flex:1 0 0%;flex:1 0 0%;-ms-flex-direction:column;flex-direction:column;margin-right:15px;margin-bottom:0;margin-left:15px}}.card-group{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.card-group>.card{margin-bottom:15px}@media (min-width:576px){.card-group{-ms-flex-flow:row wrap;flex-flow:row wrap}.card-group>.card{-ms-flex:1 0 0%;flex:1 0 0%;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:first-child .card-header,.card-group>.card:first-child .card-img-top{border-top-right-radius:0}.card-group>.card:first-child .card-footer,.card-group>.card:first-child .card-img-bottom{border-bottom-right-radius:0}.card-group>.card:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:last-child .card-header,.card-group>.card:last-child .card-img-top{border-top-left-radius:0}.card-group>.card:last-child .card-footer,.card-group>.card:last-child .card-img-bottom{border-bottom-left-radius:0}.card-group>.card:only-child{border-radius:.25rem}.card-group>.card:only-child .card-header,.card-group>.card:only-child .card-img-top{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card-group>.card:only-child .card-footer,.card-group>.card:only-child .card-img-bottom{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-group>.card:not(:first-child):not(:last-child):not(:only-child){border-radius:0}.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top{border-radius:0}}.card-columns .card{margin-bottom:.75rem}@media (min-width:576px){.card-columns{-webkit-column-count:3;-moz-column-count:3;column-count:3;-webkit-column-gap:1.25rem;-moz-column-gap:1.25rem;column-gap:1.25rem;orphans:1;widows:1}.card-columns .card{display:inline-block;width:100%}}.accordion .card:not(:first-of-type):not(:last-of-type){border-bottom:0;border-radius:0}.accordion .card:not(:first-of-type) .card-header:first-child{border-radius:0}.accordion .card:first-of-type{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.accordion .card:last-of-type{border-top-left-radius:0;border-top-right-radius:0}.breadcrumb{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:.75rem 1rem;margin-bottom:1rem;list-style:none;background-color:#e9ecef;border-radius:.25rem}.breadcrumb-item+.breadcrumb-item{padding-left:.5rem}.breadcrumb-item+.breadcrumb-item::before{display:inline-block;padding-right:.5rem;color:#6c757d;content:"/"}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:none}.breadcrumb-item.active{color:#6c757d}.pagination{display:-ms-flexbox;display:flex;padding-left:0;list-style:none;border-radius:.25rem}.page-link{position:relative;display:block;padding:.5rem .75rem;margin-left:-1px;line-height:1.25;color:#007bff;background-color:#fff;border:1px solid #dee2e6}.page-link:hover{z-index:2;color:#0056b3;text-decoration:none;background-color:#e9ecef;border-color:#dee2e6}.page-link:focus{z-index:2;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.page-link:not(:disabled):not(.disabled){cursor:pointer}.page-item:first-child .page-link{margin-left:0;border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.page-item:last-child .page-link{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.page-item.active .page-link{z-index:1;color:#fff;background-color:#007bff;border-color:#007bff}.page-item.disabled .page-link{color:#6c757d;pointer-events:none;cursor:auto;background-color:#fff;border-color:#dee2e6}.pagination-lg .page-link{padding:.75rem 1.5rem;font-size:1.25rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:.3rem;border-bottom-left-radius:.3rem}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:.3rem;border-bottom-right-radius:.3rem}.pagination-sm .page-link{padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:.2rem;border-bottom-left-radius:.2rem}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:.2rem;border-bottom-right-radius:.2rem}.badge{display:inline-block;padding:.25em .4em;font-size:75%;font-weight:700;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25rem}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{padding-right:.6em;padding-left:.6em;border-radius:10rem}.badge-primary{color:#fff;background-color:#007bff}.badge-primary[href]:focus,.badge-primary[href]:hover{color:#fff;text-decoration:none;background-color:#0062cc}.badge-secondary{color:#fff;background-color:#6c757d}.badge-secondary[href]:focus,.badge-secondary[href]:hover{color:#fff;text-decoration:none;background-color:#545b62}.badge-success{color:#fff;background-color:#28a745}.badge-success[href]:focus,.badge-success[href]:hover{color:#fff;text-decoration:none;background-color:#1e7e34}.badge-info{color:#fff;background-color:#17a2b8}.badge-info[href]:focus,.badge-info[href]:hover{color:#fff;text-decoration:none;background-color:#117a8b}.badge-warning{color:#212529;background-color:#ffc107}.badge-warning[href]:focus,.badge-warning[href]:hover{color:#212529;text-decoration:none;background-color:#d39e00}.badge-danger{color:#fff;background-color:#dc3545}.badge-danger[href]:focus,.badge-danger[href]:hover{color:#fff;text-decoration:none;background-color:#bd2130}.badge-light{color:#212529;background-color:#f8f9fa}.badge-light[href]:focus,.badge-light[href]:hover{color:#212529;text-decoration:none;background-color:#dae0e5}.badge-dark{color:#fff;background-color:#343a40}.badge-dark[href]:focus,.badge-dark[href]:hover{color:#fff;text-decoration:none;background-color:#1d2124}.jumbotron{padding:2rem 1rem;margin-bottom:2rem;background-color:#e9ecef;border-radius:.3rem}@media (min-width:576px){.jumbotron{padding:4rem 2rem}}.jumbotron-fluid{padding-right:0;padding-left:0;border-radius:0}.alert{position:relative;padding:.75rem 1.25rem;margin-bottom:1rem;border:1px solid transparent;border-radius:.25rem}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:4rem}.alert-dismissible .close{position:absolute;top:0;right:0;padding:.75rem 1.25rem;color:inherit}.alert-primary{color:#004085;background-color:#cce5ff;border-color:#b8daff}.alert-primary hr{border-top-color:#9fcdff}.alert-primary .alert-link{color:#002752}.alert-secondary{color:#383d41;background-color:#e2e3e5;border-color:#d6d8db}.alert-secondary hr{border-top-color:#c8cbcf}.alert-secondary .alert-link{color:#202326}.alert-success{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert-success hr{border-top-color:#b1dfbb}.alert-success .alert-link{color:#0b2e13}.alert-info{color:#0c5460;background-color:#d1ecf1;border-color:#bee5eb}.alert-info hr{border-top-color:#abdde5}.alert-info .alert-link{color:#062c33}.alert-warning{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.alert-warning hr{border-top-color:#ffe8a1}.alert-warning .alert-link{color:#533f03}.alert-danger{color:#721c24;background-color:#f8d7da;border-color:#f5c6cb}.alert-danger hr{border-top-color:#f1b0b7}.alert-danger .alert-link{color:#491217}.alert-light{color:#818182;background-color:#fefefe;border-color:#fdfdfe}.alert-light hr{border-top-color:#ececf6}.alert-light .alert-link{color:#686868}.alert-dark{color:#1b1e21;background-color:#d6d8d9;border-color:#c6c8ca}.alert-dark hr{border-top-color:#b9bbbe}.alert-dark .alert-link{color:#040505}@-webkit-keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}.progress{display:-ms-flexbox;display:flex;height:1rem;overflow:hidden;font-size:.75rem;background-color:#e9ecef;border-radius:.25rem}.progress-bar{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;color:#fff;text-align:center;white-space:nowrap;background-color:#007bff;transition:width .6s ease}@media screen and (prefers-reduced-motion:reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}.media{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:flex-start}.media-body{-ms-flex:1;flex:1}.list-group{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0}.list-group-item-action{width:100%;color:#495057;text-align:inherit}.list-group-item-action:focus,.list-group-item-action:hover{color:#495057;text-decoration:none;background-color:#f8f9fa}.list-group-item-action:active{color:#212529;background-color:#e9ecef}.list-group-item{position:relative;display:block;padding:.75rem 1.25rem;margin-bottom:-1px;background-color:#fff;border:1px solid rgba(0,0,0,.125)}.list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.list-group-item:focus,.list-group-item:hover{z-index:1;text-decoration:none}.list-group-item.disabled,.list-group-item:disabled{color:#6c757d;background-color:#fff}.list-group-item.active{z-index:2;color:#fff;background-color:#007bff;border-color:#007bff}.list-group-flush .list-group-item{border-right:0;border-left:0;border-radius:0}.list-group-flush:first-child .list-group-item:first-child{border-top:0}.list-group-flush:last-child .list-group-item:last-child{border-bottom:0}.list-group-item-primary{color:#004085;background-color:#b8daff}.list-group-item-primary.list-group-item-action:focus,.list-group-item-primary.list-group-item-action:hover{color:#004085;background-color:#9fcdff}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#004085;border-color:#004085}.list-group-item-secondary{color:#383d41;background-color:#d6d8db}.list-group-item-secondary.list-group-item-action:focus,.list-group-item-secondary.list-group-item-action:hover{color:#383d41;background-color:#c8cbcf}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#383d41;border-color:#383d41}.list-group-item-success{color:#155724;background-color:#c3e6cb}.list-group-item-success.list-group-item-action:focus,.list-group-item-success.list-group-item-action:hover{color:#155724;background-color:#b1dfbb}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#155724;border-color:#155724}.list-group-item-info{color:#0c5460;background-color:#bee5eb}.list-group-item-info.list-group-item-action:focus,.list-group-item-info.list-group-item-action:hover{color:#0c5460;background-color:#abdde5}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#0c5460;border-color:#0c5460}.list-group-item-warning{color:#856404;background-color:#ffeeba}.list-group-item-warning.list-group-item-action:focus,.list-group-item-warning.list-group-item-action:hover{color:#856404;background-color:#ffe8a1}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#856404;border-color:#856404}.list-group-item-danger{color:#721c24;background-color:#f5c6cb}.list-group-item-danger.list-group-item-action:focus,.list-group-item-danger.list-group-item-action:hover{color:#721c24;background-color:#f1b0b7}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#721c24;border-color:#721c24}.list-group-item-light{color:#818182;background-color:#fdfdfe}.list-group-item-light.list-group-item-action:focus,.list-group-item-light.list-group-item-action:hover{color:#818182;background-color:#ececf6}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#818182;border-color:#818182}.list-group-item-dark{color:#1b1e21;background-color:#c6c8ca}.list-group-item-dark.list-group-item-action:focus,.list-group-item-dark.list-group-item-action:hover{color:#1b1e21;background-color:#b9bbbe}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#1b1e21;border-color:#1b1e21}.close{float:right;font-size:1.5rem;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.5}.close:focus,.close:hover{color:#000;text-decoration:none;opacity:.75}.close:not(:disabled):not(.disabled){cursor:pointer}button.close{padding:0;background-color:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;outline:0}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:.5rem;pointer-events:none}.modal.fade .modal-dialog{transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out;-webkit-transform:translate(0,-25%);transform:translate(0,-25%)}@media screen and (prefers-reduced-motion:reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog{-webkit-transform:translate(0,0);transform:translate(0,0)}.modal-dialog-centered{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;min-height:calc(100% - (.5rem * 2))}.modal-content{position:relative;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;width:100%;pointer-events:auto;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem;outline:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:.5}.modal-header{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:flex-start;-ms-flex-pack:justify;justify-content:space-between;padding:1rem;border-bottom:1px solid #e9ecef;border-top-left-radius:.3rem;border-top-right-radius:.3rem}.modal-header .close{padding:1rem;margin:-1rem -1rem -1rem auto}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{position:relative;-ms-flex:1 1 auto;flex:1 1 auto;padding:1rem}.modal-footer{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end;padding:1rem;border-top:1px solid #e9ecef}.modal-footer>:not(:first-child){margin-left:.25rem}.modal-footer>:not(:last-child){margin-right:.25rem}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-centered{min-height:calc(100% - (1.75rem * 2))}.modal-sm{max-width:300px}}@media (min-width:992px){.modal-lg{max-width:800px}}.tooltip{position:absolute;z-index:1070;display:block;margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem}.tooltip .arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-auto[x-placement^=top],.bs-tooltip-top{padding:.4rem 0}.bs-tooltip-auto[x-placement^=top] .arrow,.bs-tooltip-top .arrow{bottom:0}.bs-tooltip-auto[x-placement^=top] .arrow::before,.bs-tooltip-top .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-auto[x-placement^=right],.bs-tooltip-right{padding:0 .4rem}.bs-tooltip-auto[x-placement^=right] .arrow,.bs-tooltip-right .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=right] .arrow::before,.bs-tooltip-right .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-auto[x-placement^=bottom],.bs-tooltip-bottom{padding:.4rem 0}.bs-tooltip-auto[x-placement^=bottom] .arrow,.bs-tooltip-bottom .arrow{top:0}.bs-tooltip-auto[x-placement^=bottom] .arrow::before,.bs-tooltip-bottom .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-auto[x-placement^=left],.bs-tooltip-left{padding:0 .4rem}.bs-tooltip-auto[x-placement^=left] .arrow,.bs-tooltip-left .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=left] .arrow::before,.bs-tooltip-left .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.popover{position:absolute;top:0;left:0;z-index:1060;display:block;max-width:276px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem}.popover .arrow{position:absolute;display:block;width:1rem;height:.5rem;margin:0 .3rem}.popover .arrow::after,.popover .arrow::before{position:absolute;display:block;content:"";border-color:transparent;border-style:solid}.bs-popover-auto[x-placement^=top],.bs-popover-top{margin-bottom:.5rem}.bs-popover-auto[x-placement^=top] .arrow,.bs-popover-top .arrow{bottom:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::after,.bs-popover-top .arrow::before{border-width:.5rem .5rem 0}.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::before{bottom:0;border-top-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-top .arrow::after{bottom:1px;border-top-color:#fff}.bs-popover-auto[x-placement^=right],.bs-popover-right{margin-left:.5rem}.bs-popover-auto[x-placement^=right] .arrow,.bs-popover-right .arrow{left:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::after,.bs-popover-right .arrow::before{border-width:.5rem .5rem .5rem 0}.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::before{left:0;border-right-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-right .arrow::after{left:1px;border-right-color:#fff}.bs-popover-auto[x-placement^=bottom],.bs-popover-bottom{margin-top:.5rem}.bs-popover-auto[x-placement^=bottom] .arrow,.bs-popover-bottom .arrow{top:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::after,.bs-popover-bottom .arrow::before{border-width:0 .5rem .5rem .5rem}.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::before{top:0;border-bottom-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-bottom .arrow::after{top:1px;border-bottom-color:#fff}.bs-popover-auto[x-placement^=bottom] .popover-header::before,.bs-popover-bottom .popover-header::before{position:absolute;top:0;left:50%;display:block;width:1rem;margin-left:-.5rem;content:"";border-bottom:1px solid #f7f7f7}.bs-popover-auto[x-placement^=left],.bs-popover-left{margin-right:.5rem}.bs-popover-auto[x-placement^=left] .arrow,.bs-popover-left .arrow{right:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::after,.bs-popover-left .arrow::before{border-width:.5rem 0 .5rem .5rem}.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::before{right:0;border-left-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-left .arrow::after{right:1px;border-left-color:#fff}.popover-header{padding:.5rem .75rem;margin-bottom:0;font-size:1rem;color:inherit;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px)}.popover-header:empty{display:none}.popover-body{padding:.5rem .75rem;color:#212529}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-item{position:relative;display:none;-ms-flex-align:center;align-items:center;width:100%;transition:-webkit-transform .6s ease;transition:transform .6s ease;transition:transform .6s ease,-webkit-transform .6s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}@media screen and (prefers-reduced-motion:reduce){.carousel-item{transition:none}}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block}.carousel-item-next,.carousel-item-prev{position:absolute;top:0}.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translateX(0);transform:translateX(0)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.active.carousel-item-right,.carousel-item-next{-webkit-transform:translateX(100%);transform:translateX(100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-right,.carousel-item-next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translateX(-100%);transform:translateX(-100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.carousel-fade .carousel-item{opacity:0;transition-duration:.6s;transition-property:opacity}.carousel-fade .carousel-item-next.carousel-item-left,.carousel-fade .carousel-item-prev.carousel-item-right,.carousel-fade .carousel-item.active{opacity:1}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{opacity:0}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-prev,.carousel-fade .carousel-item-next,.carousel-fade .carousel-item-prev,.carousel-fade .carousel-item.active{-webkit-transform:translateX(0);transform:translateX(0)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-prev,.carousel-fade .carousel-item-next,.carousel-fade .carousel-item-prev,.carousel-fade .carousel-item.active{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.carousel-control-next,.carousel-control-prev{position:absolute;top:0;bottom:0;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:15%;color:#fff;text-align:center;opacity:.5}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{display:inline-block;width:20px;height:20px;background:transparent no-repeat center center;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E")}.carousel-control-next-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E")}.carousel-indicators{position:absolute;right:0;bottom:10px;left:0;z-index:15;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;padding-left:0;margin-right:15%;margin-left:15%;list-style:none}.carousel-indicators li{position:relative;-ms-flex:0 1 auto;flex:0 1 auto;width:30px;height:3px;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-color:rgba(255,255,255,.5)}.carousel-indicators li::before{position:absolute;top:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators li::after{position:absolute;bottom:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators .active{background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center}.align-baseline{vertical-align:baseline!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.bg-primary{background-color:#007bff!important}a.bg-primary:focus,a.bg-primary:hover,button.bg-primary:focus,button.bg-primary:hover{background-color:#0062cc!important}.bg-secondary{background-color:#6c757d!important}a.bg-secondary:focus,a.bg-secondary:hover,button.bg-secondary:focus,button.bg-secondary:hover{background-color:#545b62!important}.bg-success{background-color:#28a745!important}a.bg-success:focus,a.bg-success:hover,button.bg-success:focus,button.bg-success:hover{background-color:#1e7e34!important}.bg-info{background-color:#17a2b8!important}a.bg-info:focus,a.bg-info:hover,button.bg-info:focus,button.bg-info:hover{background-color:#117a8b!important}.bg-warning{background-color:#ffc107!important}a.bg-warning:focus,a.bg-warning:hover,button.bg-warning:focus,button.bg-warning:hover{background-color:#d39e00!important}.bg-danger{background-color:#dc3545!important}a.bg-danger:focus,a.bg-danger:hover,button.bg-danger:focus,button.bg-danger:hover{background-color:#bd2130!important}.bg-light{background-color:#f8f9fa!important}a.bg-light:focus,a.bg-light:hover,button.bg-light:focus,button.bg-light:hover{background-color:#dae0e5!important}.bg-dark{background-color:#343a40!important}a.bg-dark:focus,a.bg-dark:hover,button.bg-dark:focus,button.bg-dark:hover{background-color:#1d2124!important}.bg-white{background-color:#fff!important}.bg-transparent{background-color:transparent!important}.border{border:1px solid #dee2e6!important}.border-top{border-top:1px solid #dee2e6!important}.border-right{border-right:1px solid #dee2e6!important}.border-bottom{border-bottom:1px solid #dee2e6!important}.border-left{border-left:1px solid #dee2e6!important}.border-0{border:0!important}.border-top-0{border-top:0!important}.border-right-0{border-right:0!important}.border-bottom-0{border-bottom:0!important}.border-left-0{border-left:0!important}.border-primary{border-color:#007bff!important}.border-secondary{border-color:#6c757d!important}.border-success{border-color:#28a745!important}.border-info{border-color:#17a2b8!important}.border-warning{border-color:#ffc107!important}.border-danger{border-color:#dc3545!important}.border-light{border-color:#f8f9fa!important}.border-dark{border-color:#343a40!important}.border-white{border-color:#fff!important}.rounded{border-radius:.25rem!important}.rounded-top{border-top-left-radius:.25rem!important;border-top-right-radius:.25rem!important}.rounded-right{border-top-right-radius:.25rem!important;border-bottom-right-radius:.25rem!important}.rounded-bottom{border-bottom-right-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-left{border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-circle{border-radius:50%!important}.rounded-0{border-radius:0!important}.clearfix::after{display:block;clear:both;content:""}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:-ms-flexbox!important;display:flex!important}.d-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}@media (min-width:576px){.d-sm-none{display:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:-ms-flexbox!important;display:flex!important}.d-sm-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:768px){.d-md-none{display:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:-ms-flexbox!important;display:flex!important}.d-md-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:992px){.d-lg-none{display:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:-ms-flexbox!important;display:flex!important}.d-lg-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:1200px){.d-xl-none{display:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:-ms-flexbox!important;display:flex!important}.d-xl-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media print{.d-print-none{display:none!important}.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:-ms-flexbox!important;display:flex!important}.d-print-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}.embed-responsive{position:relative;display:block;width:100%;padding:0;overflow:hidden}.embed-responsive::before{display:block;content:""}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-21by9::before{padding-top:42.857143%}.embed-responsive-16by9::before{padding-top:56.25%}.embed-responsive-4by3::before{padding-top:75%}.embed-responsive-1by1::before{padding-top:100%}.flex-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-center{-ms-flex-align:center!important;align-items:center!important}.align-items-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}@media (min-width:576px){.flex-sm-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-sm-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-sm-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-sm-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-sm-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-sm-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-sm-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-sm-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-sm-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-sm-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-sm-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-sm-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-sm-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-sm-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-sm-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-sm-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-sm-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-sm-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-sm-center{-ms-flex-align:center!important;align-items:center!important}.align-items-sm-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-sm-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-sm-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-sm-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-sm-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-sm-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-sm-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-sm-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-sm-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-sm-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-sm-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-sm-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-sm-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-sm-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:768px){.flex-md-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-md-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-md-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-md-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-md-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-md-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-md-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-md-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-md-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-md-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-md-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-md-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-md-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-md-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-md-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-md-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-md-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-md-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-md-center{-ms-flex-align:center!important;align-items:center!important}.align-items-md-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-md-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-md-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-md-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-md-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-md-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-md-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-md-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-md-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-md-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-md-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-md-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-md-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-md-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:992px){.flex-lg-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-lg-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-lg-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-lg-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-lg-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-lg-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-lg-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-lg-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-lg-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-lg-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-lg-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-lg-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-lg-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-lg-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-lg-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-lg-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-lg-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-lg-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-lg-center{-ms-flex-align:center!important;align-items:center!important}.align-items-lg-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-lg-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-lg-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-lg-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-lg-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-lg-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-lg-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-lg-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-lg-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-lg-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-lg-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-lg-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-lg-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-lg-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:1200px){.flex-xl-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-xl-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-xl-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-xl-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-xl-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-xl-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-xl-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-xl-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-xl-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-xl-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-xl-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-xl-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-xl-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-xl-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-xl-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-xl-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-xl-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-xl-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-xl-center{-ms-flex-align:center!important;align-items:center!important}.align-items-xl-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-xl-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-xl-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-xl-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-xl-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-xl-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-xl-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-xl-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-xl-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-xl-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-xl-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-xl-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-xl-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-xl-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}.float-left{float:left!important}.float-right{float:right!important}.float-none{float:none!important}@media (min-width:576px){.float-sm-left{float:left!important}.float-sm-right{float:right!important}.float-sm-none{float:none!important}}@media (min-width:768px){.float-md-left{float:left!important}.float-md-right{float:right!important}.float-md-none{float:none!important}}@media (min-width:992px){.float-lg-left{float:left!important}.float-lg-right{float:right!important}.float-lg-none{float:none!important}}@media (min-width:1200px){.float-xl-left{float:left!important}.float-xl-right{float:right!important}.float-xl-none{float:none!important}}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}@supports ((position:-webkit-sticky) or (position:sticky)){.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.shadow-sm{box-shadow:0 .125rem .25rem rgba(0,0,0,.075)!important}.shadow{box-shadow:0 .5rem 1rem rgba(0,0,0,.15)!important}.shadow-lg{box-shadow:0 1rem 3rem rgba(0,0,0,.175)!important}.shadow-none{box-shadow:none!important}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.w-auto{width:auto!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.h-auto{height:auto!important}.mw-100{max-width:100%!important}.mh-100{max-height:100%!important}.m-0{margin:0!important}.mt-0,.my-0{margin-top:0!important}.mr-0,.mx-0{margin-right:0!important}.mb-0,.my-0{margin-bottom:0!important}.ml-0,.mx-0{margin-left:0!important}.m-1{margin:.25rem!important}.mt-1,.my-1{margin-top:.25rem!important}.mr-1,.mx-1{margin-right:.25rem!important}.mb-1,.my-1{margin-bottom:.25rem!important}.ml-1,.mx-1{margin-left:.25rem!important}.m-2{margin:.5rem!important}.mt-2,.my-2{margin-top:.5rem!important}.mr-2,.mx-2{margin-right:.5rem!important}.mb-2,.my-2{margin-bottom:.5rem!important}.ml-2,.mx-2{margin-left:.5rem!important}.m-3{margin:1rem!important}.mt-3,.my-3{margin-top:1rem!important}.mr-3,.mx-3{margin-right:1rem!important}.mb-3,.my-3{margin-bottom:1rem!important}.ml-3,.mx-3{margin-left:1rem!important}.m-4{margin:1.5rem!important}.mt-4,.my-4{margin-top:1.5rem!important}.mr-4,.mx-4{margin-right:1.5rem!important}.mb-4,.my-4{margin-bottom:1.5rem!important}.ml-4,.mx-4{margin-left:1.5rem!important}.m-5{margin:3rem!important}.mt-5,.my-5{margin-top:3rem!important}.mr-5,.mx-5{margin-right:3rem!important}.mb-5,.my-5{margin-bottom:3rem!important}.ml-5,.mx-5{margin-left:3rem!important}.p-0{padding:0!important}.pt-0,.py-0{padding-top:0!important}.pr-0,.px-0{padding-right:0!important}.pb-0,.py-0{padding-bottom:0!important}.pl-0,.px-0{padding-left:0!important}.p-1{padding:.25rem!important}.pt-1,.py-1{padding-top:.25rem!important}.pr-1,.px-1{padding-right:.25rem!important}.pb-1,.py-1{padding-bottom:.25rem!important}.pl-1,.px-1{padding-left:.25rem!important}.p-2{padding:.5rem!important}.pt-2,.py-2{padding-top:.5rem!important}.pr-2,.px-2{padding-right:.5rem!important}.pb-2,.py-2{padding-bottom:.5rem!important}.pl-2,.px-2{padding-left:.5rem!important}.p-3{padding:1rem!important}.pt-3,.py-3{padding-top:1rem!important}.pr-3,.px-3{padding-right:1rem!important}.pb-3,.py-3{padding-bottom:1rem!important}.pl-3,.px-3{padding-left:1rem!important}.p-4{padding:1.5rem!important}.pt-4,.py-4{padding-top:1.5rem!important}.pr-4,.px-4{padding-right:1.5rem!important}.pb-4,.py-4{padding-bottom:1.5rem!important}.pl-4,.px-4{padding-left:1.5rem!important}.p-5{padding:3rem!important}.pt-5,.py-5{padding-top:3rem!important}.pr-5,.px-5{padding-right:3rem!important}.pb-5,.py-5{padding-bottom:3rem!important}.pl-5,.px-5{padding-left:3rem!important}.m-auto{margin:auto!important}.mt-auto,.my-auto{margin-top:auto!important}.mr-auto,.mx-auto{margin-right:auto!important}.mb-auto,.my-auto{margin-bottom:auto!important}.ml-auto,.mx-auto{margin-left:auto!important}@media (min-width:576px){.m-sm-0{margin:0!important}.mt-sm-0,.my-sm-0{margin-top:0!important}.mr-sm-0,.mx-sm-0{margin-right:0!important}.mb-sm-0,.my-sm-0{margin-bottom:0!important}.ml-sm-0,.mx-sm-0{margin-left:0!important}.m-sm-1{margin:.25rem!important}.mt-sm-1,.my-sm-1{margin-top:.25rem!important}.mr-sm-1,.mx-sm-1{margin-right:.25rem!important}.mb-sm-1,.my-sm-1{margin-bottom:.25rem!important}.ml-sm-1,.mx-sm-1{margin-left:.25rem!important}.m-sm-2{margin:.5rem!important}.mt-sm-2,.my-sm-2{margin-top:.5rem!important}.mr-sm-2,.mx-sm-2{margin-right:.5rem!important}.mb-sm-2,.my-sm-2{margin-bottom:.5rem!important}.ml-sm-2,.mx-sm-2{margin-left:.5rem!important}.m-sm-3{margin:1rem!important}.mt-sm-3,.my-sm-3{margin-top:1rem!important}.mr-sm-3,.mx-sm-3{margin-right:1rem!important}.mb-sm-3,.my-sm-3{margin-bottom:1rem!important}.ml-sm-3,.mx-sm-3{margin-left:1rem!important}.m-sm-4{margin:1.5rem!important}.mt-sm-4,.my-sm-4{margin-top:1.5rem!important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem!important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem!important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem!important}.m-sm-5{margin:3rem!important}.mt-sm-5,.my-sm-5{margin-top:3rem!important}.mr-sm-5,.mx-sm-5{margin-right:3rem!important}.mb-sm-5,.my-sm-5{margin-bottom:3rem!important}.ml-sm-5,.mx-sm-5{margin-left:3rem!important}.p-sm-0{padding:0!important}.pt-sm-0,.py-sm-0{padding-top:0!important}.pr-sm-0,.px-sm-0{padding-right:0!important}.pb-sm-0,.py-sm-0{padding-bottom:0!important}.pl-sm-0,.px-sm-0{padding-left:0!important}.p-sm-1{padding:.25rem!important}.pt-sm-1,.py-sm-1{padding-top:.25rem!important}.pr-sm-1,.px-sm-1{padding-right:.25rem!important}.pb-sm-1,.py-sm-1{padding-bottom:.25rem!important}.pl-sm-1,.px-sm-1{padding-left:.25rem!important}.p-sm-2{padding:.5rem!important}.pt-sm-2,.py-sm-2{padding-top:.5rem!important}.pr-sm-2,.px-sm-2{padding-right:.5rem!important}.pb-sm-2,.py-sm-2{padding-bottom:.5rem!important}.pl-sm-2,.px-sm-2{padding-left:.5rem!important}.p-sm-3{padding:1rem!important}.pt-sm-3,.py-sm-3{padding-top:1rem!important}.pr-sm-3,.px-sm-3{padding-right:1rem!important}.pb-sm-3,.py-sm-3{padding-bottom:1rem!important}.pl-sm-3,.px-sm-3{padding-left:1rem!important}.p-sm-4{padding:1.5rem!important}.pt-sm-4,.py-sm-4{padding-top:1.5rem!important}.pr-sm-4,.px-sm-4{padding-right:1.5rem!important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem!important}.pl-sm-4,.px-sm-4{padding-left:1.5rem!important}.p-sm-5{padding:3rem!important}.pt-sm-5,.py-sm-5{padding-top:3rem!important}.pr-sm-5,.px-sm-5{padding-right:3rem!important}.pb-sm-5,.py-sm-5{padding-bottom:3rem!important}.pl-sm-5,.px-sm-5{padding-left:3rem!important}.m-sm-auto{margin:auto!important}.mt-sm-auto,.my-sm-auto{margin-top:auto!important}.mr-sm-auto,.mx-sm-auto{margin-right:auto!important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto!important}.ml-sm-auto,.mx-sm-auto{margin-left:auto!important}}@media (min-width:768px){.m-md-0{margin:0!important}.mt-md-0,.my-md-0{margin-top:0!important}.mr-md-0,.mx-md-0{margin-right:0!important}.mb-md-0,.my-md-0{margin-bottom:0!important}.ml-md-0,.mx-md-0{margin-left:0!important}.m-md-1{margin:.25rem!important}.mt-md-1,.my-md-1{margin-top:.25rem!important}.mr-md-1,.mx-md-1{margin-right:.25rem!important}.mb-md-1,.my-md-1{margin-bottom:.25rem!important}.ml-md-1,.mx-md-1{margin-left:.25rem!important}.m-md-2{margin:.5rem!important}.mt-md-2,.my-md-2{margin-top:.5rem!important}.mr-md-2,.mx-md-2{margin-right:.5rem!important}.mb-md-2,.my-md-2{margin-bottom:.5rem!important}.ml-md-2,.mx-md-2{margin-left:.5rem!important}.m-md-3{margin:1rem!important}.mt-md-3,.my-md-3{margin-top:1rem!important}.mr-md-3,.mx-md-3{margin-right:1rem!important}.mb-md-3,.my-md-3{margin-bottom:1rem!important}.ml-md-3,.mx-md-3{margin-left:1rem!important}.m-md-4{margin:1.5rem!important}.mt-md-4,.my-md-4{margin-top:1.5rem!important}.mr-md-4,.mx-md-4{margin-right:1.5rem!important}.mb-md-4,.my-md-4{margin-bottom:1.5rem!important}.ml-md-4,.mx-md-4{margin-left:1.5rem!important}.m-md-5{margin:3rem!important}.mt-md-5,.my-md-5{margin-top:3rem!important}.mr-md-5,.mx-md-5{margin-right:3rem!important}.mb-md-5,.my-md-5{margin-bottom:3rem!important}.ml-md-5,.mx-md-5{margin-left:3rem!important}.p-md-0{padding:0!important}.pt-md-0,.py-md-0{padding-top:0!important}.pr-md-0,.px-md-0{padding-right:0!important}.pb-md-0,.py-md-0{padding-bottom:0!important}.pl-md-0,.px-md-0{padding-left:0!important}.p-md-1{padding:.25rem!important}.pt-md-1,.py-md-1{padding-top:.25rem!important}.pr-md-1,.px-md-1{padding-right:.25rem!important}.pb-md-1,.py-md-1{padding-bottom:.25rem!important}.pl-md-1,.px-md-1{padding-left:.25rem!important}.p-md-2{padding:.5rem!important}.pt-md-2,.py-md-2{padding-top:.5rem!important}.pr-md-2,.px-md-2{padding-right:.5rem!important}.pb-md-2,.py-md-2{padding-bottom:.5rem!important}.pl-md-2,.px-md-2{padding-left:.5rem!important}.p-md-3{padding:1rem!important}.pt-md-3,.py-md-3{padding-top:1rem!important}.pr-md-3,.px-md-3{padding-right:1rem!important}.pb-md-3,.py-md-3{padding-bottom:1rem!important}.pl-md-3,.px-md-3{padding-left:1rem!important}.p-md-4{padding:1.5rem!important}.pt-md-4,.py-md-4{padding-top:1.5rem!important}.pr-md-4,.px-md-4{padding-right:1.5rem!important}.pb-md-4,.py-md-4{padding-bottom:1.5rem!important}.pl-md-4,.px-md-4{padding-left:1.5rem!important}.p-md-5{padding:3rem!important}.pt-md-5,.py-md-5{padding-top:3rem!important}.pr-md-5,.px-md-5{padding-right:3rem!important}.pb-md-5,.py-md-5{padding-bottom:3rem!important}.pl-md-5,.px-md-5{padding-left:3rem!important}.m-md-auto{margin:auto!important}.mt-md-auto,.my-md-auto{margin-top:auto!important}.mr-md-auto,.mx-md-auto{margin-right:auto!important}.mb-md-auto,.my-md-auto{margin-bottom:auto!important}.ml-md-auto,.mx-md-auto{margin-left:auto!important}}@media (min-width:992px){.m-lg-0{margin:0!important}.mt-lg-0,.my-lg-0{margin-top:0!important}.mr-lg-0,.mx-lg-0{margin-right:0!important}.mb-lg-0,.my-lg-0{margin-bottom:0!important}.ml-lg-0,.mx-lg-0{margin-left:0!important}.m-lg-1{margin:.25rem!important}.mt-lg-1,.my-lg-1{margin-top:.25rem!important}.mr-lg-1,.mx-lg-1{margin-right:.25rem!important}.mb-lg-1,.my-lg-1{margin-bottom:.25rem!important}.ml-lg-1,.mx-lg-1{margin-left:.25rem!important}.m-lg-2{margin:.5rem!important}.mt-lg-2,.my-lg-2{margin-top:.5rem!important}.mr-lg-2,.mx-lg-2{margin-right:.5rem!important}.mb-lg-2,.my-lg-2{margin-bottom:.5rem!important}.ml-lg-2,.mx-lg-2{margin-left:.5rem!important}.m-lg-3{margin:1rem!important}.mt-lg-3,.my-lg-3{margin-top:1rem!important}.mr-lg-3,.mx-lg-3{margin-right:1rem!important}.mb-lg-3,.my-lg-3{margin-bottom:1rem!important}.ml-lg-3,.mx-lg-3{margin-left:1rem!important}.m-lg-4{margin:1.5rem!important}.mt-lg-4,.my-lg-4{margin-top:1.5rem!important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem!important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem!important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem!important}.m-lg-5{margin:3rem!important}.mt-lg-5,.my-lg-5{margin-top:3rem!important}.mr-lg-5,.mx-lg-5{margin-right:3rem!important}.mb-lg-5,.my-lg-5{margin-bottom:3rem!important}.ml-lg-5,.mx-lg-5{margin-left:3rem!important}.p-lg-0{padding:0!important}.pt-lg-0,.py-lg-0{padding-top:0!important}.pr-lg-0,.px-lg-0{padding-right:0!important}.pb-lg-0,.py-lg-0{padding-bottom:0!important}.pl-lg-0,.px-lg-0{padding-left:0!important}.p-lg-1{padding:.25rem!important}.pt-lg-1,.py-lg-1{padding-top:.25rem!important}.pr-lg-1,.px-lg-1{padding-right:.25rem!important}.pb-lg-1,.py-lg-1{padding-bottom:.25rem!important}.pl-lg-1,.px-lg-1{padding-left:.25rem!important}.p-lg-2{padding:.5rem!important}.pt-lg-2,.py-lg-2{padding-top:.5rem!important}.pr-lg-2,.px-lg-2{padding-right:.5rem!important}.pb-lg-2,.py-lg-2{padding-bottom:.5rem!important}.pl-lg-2,.px-lg-2{padding-left:.5rem!important}.p-lg-3{padding:1rem!important}.pt-lg-3,.py-lg-3{padding-top:1rem!important}.pr-lg-3,.px-lg-3{padding-right:1rem!important}.pb-lg-3,.py-lg-3{padding-bottom:1rem!important}.pl-lg-3,.px-lg-3{padding-left:1rem!important}.p-lg-4{padding:1.5rem!important}.pt-lg-4,.py-lg-4{padding-top:1.5rem!important}.pr-lg-4,.px-lg-4{padding-right:1.5rem!important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem!important}.pl-lg-4,.px-lg-4{padding-left:1.5rem!important}.p-lg-5{padding:3rem!important}.pt-lg-5,.py-lg-5{padding-top:3rem!important}.pr-lg-5,.px-lg-5{padding-right:3rem!important}.pb-lg-5,.py-lg-5{padding-bottom:3rem!important}.pl-lg-5,.px-lg-5{padding-left:3rem!important}.m-lg-auto{margin:auto!important}.mt-lg-auto,.my-lg-auto{margin-top:auto!important}.mr-lg-auto,.mx-lg-auto{margin-right:auto!important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto!important}.ml-lg-auto,.mx-lg-auto{margin-left:auto!important}}@media (min-width:1200px){.m-xl-0{margin:0!important}.mt-xl-0,.my-xl-0{margin-top:0!important}.mr-xl-0,.mx-xl-0{margin-right:0!important}.mb-xl-0,.my-xl-0{margin-bottom:0!important}.ml-xl-0,.mx-xl-0{margin-left:0!important}.m-xl-1{margin:.25rem!important}.mt-xl-1,.my-xl-1{margin-top:.25rem!important}.mr-xl-1,.mx-xl-1{margin-right:.25rem!important}.mb-xl-1,.my-xl-1{margin-bottom:.25rem!important}.ml-xl-1,.mx-xl-1{margin-left:.25rem!important}.m-xl-2{margin:.5rem!important}.mt-xl-2,.my-xl-2{margin-top:.5rem!important}.mr-xl-2,.mx-xl-2{margin-right:.5rem!important}.mb-xl-2,.my-xl-2{margin-bottom:.5rem!important}.ml-xl-2,.mx-xl-2{margin-left:.5rem!important}.m-xl-3{margin:1rem!important}.mt-xl-3,.my-xl-3{margin-top:1rem!important}.mr-xl-3,.mx-xl-3{margin-right:1rem!important}.mb-xl-3,.my-xl-3{margin-bottom:1rem!important}.ml-xl-3,.mx-xl-3{margin-left:1rem!important}.m-xl-4{margin:1.5rem!important}.mt-xl-4,.my-xl-4{margin-top:1.5rem!important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem!important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem!important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem!important}.m-xl-5{margin:3rem!important}.mt-xl-5,.my-xl-5{margin-top:3rem!important}.mr-xl-5,.mx-xl-5{margin-right:3rem!important}.mb-xl-5,.my-xl-5{margin-bottom:3rem!important}.ml-xl-5,.mx-xl-5{margin-left:3rem!important}.p-xl-0{padding:0!important}.pt-xl-0,.py-xl-0{padding-top:0!important}.pr-xl-0,.px-xl-0{padding-right:0!important}.pb-xl-0,.py-xl-0{padding-bottom:0!important}.pl-xl-0,.px-xl-0{padding-left:0!important}.p-xl-1{padding:.25rem!important}.pt-xl-1,.py-xl-1{padding-top:.25rem!important}.pr-xl-1,.px-xl-1{padding-right:.25rem!important}.pb-xl-1,.py-xl-1{padding-bottom:.25rem!important}.pl-xl-1,.px-xl-1{padding-left:.25rem!important}.p-xl-2{padding:.5rem!important}.pt-xl-2,.py-xl-2{padding-top:.5rem!important}.pr-xl-2,.px-xl-2{padding-right:.5rem!important}.pb-xl-2,.py-xl-2{padding-bottom:.5rem!important}.pl-xl-2,.px-xl-2{padding-left:.5rem!important}.p-xl-3{padding:1rem!important}.pt-xl-3,.py-xl-3{padding-top:1rem!important}.pr-xl-3,.px-xl-3{padding-right:1rem!important}.pb-xl-3,.py-xl-3{padding-bottom:1rem!important}.pl-xl-3,.px-xl-3{padding-left:1rem!important}.p-xl-4{padding:1.5rem!important}.pt-xl-4,.py-xl-4{padding-top:1.5rem!important}.pr-xl-4,.px-xl-4{padding-right:1.5rem!important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem!important}.pl-xl-4,.px-xl-4{padding-left:1.5rem!important}.p-xl-5{padding:3rem!important}.pt-xl-5,.py-xl-5{padding-top:3rem!important}.pr-xl-5,.px-xl-5{padding-right:3rem!important}.pb-xl-5,.py-xl-5{padding-bottom:3rem!important}.pl-xl-5,.px-xl-5{padding-left:3rem!important}.m-xl-auto{margin:auto!important}.mt-xl-auto,.my-xl-auto{margin-top:auto!important}.mr-xl-auto,.mx-xl-auto{margin-right:auto!important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto!important}.ml-xl-auto,.mx-xl-auto{margin-left:auto!important}}.text-monospace{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}.text-justify{text-align:justify!important}.text-nowrap{white-space:nowrap!important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}@media (min-width:576px){.text-sm-left{text-align:left!important}.text-sm-right{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.text-md-left{text-align:left!important}.text-md-right{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.text-lg-left{text-align:left!important}.text-lg-right{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.text-xl-left{text-align:left!important}.text-xl-right{text-align:right!important}.text-xl-center{text-align:center!important}}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.font-weight-light{font-weight:300!important}.font-weight-normal{font-weight:400!important}.font-weight-bold{font-weight:700!important}.font-italic{font-style:italic!important}.text-white{color:#fff!important}.text-primary{color:#007bff!important}a.text-primary:focus,a.text-primary:hover{color:#0062cc!important}.text-secondary{color:#6c757d!important}a.text-secondary:focus,a.text-secondary:hover{color:#545b62!important}.text-success{color:#28a745!important}a.text-success:focus,a.text-success:hover{color:#1e7e34!important}.text-info{color:#17a2b8!important}a.text-info:focus,a.text-info:hover{color:#117a8b!important}.text-warning{color:#ffc107!important}a.text-warning:focus,a.text-warning:hover{color:#d39e00!important}.text-danger{color:#dc3545!important}a.text-danger:focus,a.text-danger:hover{color:#bd2130!important}.text-light{color:#f8f9fa!important}a.text-light:focus,a.text-light:hover{color:#dae0e5!important}.text-dark{color:#343a40!important}a.text-dark:focus,a.text-dark:hover{color:#1d2124!important}.text-body{color:#212529!important}.text-muted{color:#6c757d!important}.text-black-50{color:rgba(0,0,0,.5)!important}.text-white-50{color:rgba(255,255,255,.5)!important}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.visible{visibility:visible!important}.invisible{visibility:hidden!important}@media print{*,::after,::before{text-shadow:none!important;box-shadow:none!important}a:not(.btn){text-decoration:underline}abbr[title]::after{content:" (" attr(title) ")"}pre{white-space:pre-wrap!important}blockquote,pre{border:1px solid #adb5bd;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body{min-width:992px!important}.container{min-width:992px!important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #dee2e6!important}.table-dark{color:inherit}.table-dark tbody+tbody,.table-dark td,.table-dark th,.table-dark thead th{border-color:#dee2e6}.table .thead-dark th{color:inherit;border-color:#dee2e6}} -/*# sourceMappingURL=bootstrap.min.css.map */ \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/assets/index.html b/vendor/itxq/api-doc-php/assets/index.html deleted file mode 100644 index 9bd9db9e..00000000 --- a/vendor/itxq/api-doc-php/assets/index.html +++ /dev/null @@ -1,193 +0,0 @@ - - - - - - - - - API文档 By Api-Doc-PHP - - - -
- -
-
-

登录注册

-
-

API - 用户登录API

-

请求方式: - POST -

-

请求地址:https://wwww.baidu.com/login

-

请求参数

- - - - - - - - - - - -
参数类型描述默认值是否必须
usernamestring账号必须
passwordstring密码必须
-

返回参数

- - - - - - - -
参数类型描述
codeint状态码(具体参见状态码说明)
msgstring提示信息
-

状态码说明

- - - - - -
状态码描述
1成功
2失败
-
-

API - 用户注册API

-

请求方式: - POST -

-

请求地址:https://wwww.baidu.com/reg

-

请求参数

- - - - - - - - - - - - - - - - - -
参数类型描述默认值是否必须
usernamestring账号必须
passwordstring密码必须
password2string重复密码必须
-

返回参数

- - - - - - - -
参数类型描述
codeint状态码(具体参见状态码说明)
msgstring提示信息
-

状态码说明

- - - - - -
状态码描述
1成功
2失败
-
-
-

用户相关

-
-

API - 获取用户信息

-

请求方式: - GET -

-

请求地址:https://wwww.baidu.com/getuserinfo

-

请求参数

- - - - - - - - - - - -
参数类型描述默认值是否必须
uidint用户ID0必须
tokenstring令牌必须
-

返回参数

- - - - - - - -
参数类型描述
codeint状态码(具体参见状态码说明)
msgstring提示信息
-

状态码说明

- - - - - -
状态码描述
1成功
2失败
-
-
-
-
- -
-
- - - \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/assets/js/bootstrap.min.js b/vendor/itxq/api-doc-php/assets/js/bootstrap.min.js deleted file mode 100644 index 0e846b78..00000000 --- a/vendor/itxq/api-doc-php/assets/js/bootstrap.min.js +++ /dev/null @@ -1,7 +0,0 @@ -/*! - * Bootstrap v4.1.1 (https://getbootstrap.com/) - * Copyright 2011-2018 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) - */ -!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("jquery"),require("popper.js")):"function"==typeof define&&define.amd?define(["exports","jquery","popper.js"],e):e(t.bootstrap={},t.jQuery,t.Popper)}(this,function(t,e,c){"use strict";function i(t,e){for(var n=0;nthis._items.length-1||t<0))if(this._isSliding)P(this._element).one(Q.SLID,function(){return e.to(t)});else{if(n===t)return this.pause(),void this.cycle();var i=ndocument.documentElement.clientHeight;!this._isBodyOverflowing&&t&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),this._isBodyOverflowing&&!t&&(this._element.style.paddingRight=this._scrollbarWidth+"px")},t._resetAdjustments=function(){this._element.style.paddingLeft="",this._element.style.paddingRight=""},t._checkScrollbar=function(){var t=document.body.getBoundingClientRect();this._isBodyOverflowing=t.left+t.right
',trigger:"hover focus",title:"",delay:0,html:!(_e={AUTO:"auto",TOP:"top",RIGHT:"right",BOTTOM:"bottom",LEFT:"left"}),selector:!(de={animation:"boolean",template:"string",title:"(string|element|function)",trigger:"string",delay:"(number|object)",html:"boolean",selector:"(string|boolean)",placement:"(string|function)",offset:"(number|string)",container:"(string|element|boolean)",fallbackPlacement:"(string|array)",boundary:"(string|element)"}),placement:"top",offset:0,container:!1,fallbackPlacement:"flip",boundary:"scrollParent"},pe="out",ve={HIDE:"hide"+he,HIDDEN:"hidden"+he,SHOW:(me="show")+he,SHOWN:"shown"+he,INSERTED:"inserted"+he,CLICK:"click"+he,FOCUSIN:"focusin"+he,FOCUSOUT:"focusout"+he,MOUSEENTER:"mouseenter"+he,MOUSELEAVE:"mouseleave"+he},Ee="fade",ye="show",Te=".tooltip-inner",Ce=".arrow",Ie="hover",Ae="focus",De="click",be="manual",Se=function(){function i(t,e){if("undefined"==typeof c)throw new TypeError("Bootstrap tooltips require Popper.js (https://popper.js.org)");this._isEnabled=!0,this._timeout=0,this._hoverState="",this._activeTrigger={},this._popper=null,this.element=t,this.config=this._getConfig(e),this.tip=null,this._setListeners()}var t=i.prototype;return t.enable=function(){this._isEnabled=!0},t.disable=function(){this._isEnabled=!1},t.toggleEnabled=function(){this._isEnabled=!this._isEnabled},t.toggle=function(t){if(this._isEnabled)if(t){var e=this.constructor.DATA_KEY,n=oe(t.currentTarget).data(e);n||(n=new this.constructor(t.currentTarget,this._getDelegateConfig()),oe(t.currentTarget).data(e,n)),n._activeTrigger.click=!n._activeTrigger.click,n._isWithActiveTrigger()?n._enter(null,n):n._leave(null,n)}else{if(oe(this.getTipElement()).hasClass(ye))return void this._leave(null,this);this._enter(null,this)}},t.dispose=function(){clearTimeout(this._timeout),oe.removeData(this.element,this.constructor.DATA_KEY),oe(this.element).off(this.constructor.EVENT_KEY),oe(this.element).closest(".modal").off("hide.bs.modal"),this.tip&&oe(this.tip).remove(),this._isEnabled=null,this._timeout=null,this._hoverState=null,(this._activeTrigger=null)!==this._popper&&this._popper.destroy(),this._popper=null,this.element=null,this.config=null,this.tip=null},t.show=function(){var e=this;if("none"===oe(this.element).css("display"))throw new Error("Please use show on visible elements");var t=oe.Event(this.constructor.Event.SHOW);if(this.isWithContent()&&this._isEnabled){oe(this.element).trigger(t);var n=oe.contains(this.element.ownerDocument.documentElement,this.element);if(t.isDefaultPrevented()||!n)return;var i=this.getTipElement(),r=Cn.getUID(this.constructor.NAME);i.setAttribute("id",r),this.element.setAttribute("aria-describedby",r),this.setContent(),this.config.animation&&oe(i).addClass(Ee);var s="function"==typeof this.config.placement?this.config.placement.call(this,i,this.element):this.config.placement,o=this._getAttachment(s);this.addAttachmentClass(o);var a=!1===this.config.container?document.body:oe(this.config.container);oe(i).data(this.constructor.DATA_KEY,this),oe.contains(this.element.ownerDocument.documentElement,this.tip)||oe(i).appendTo(a),oe(this.element).trigger(this.constructor.Event.INSERTED),this._popper=new c(this.element,i,{placement:o,modifiers:{offset:{offset:this.config.offset},flip:{behavior:this.config.fallbackPlacement},arrow:{element:Ce},preventOverflow:{boundariesElement:this.config.boundary}},onCreate:function(t){t.originalPlacement!==t.placement&&e._handlePopperPlacementChange(t)},onUpdate:function(t){e._handlePopperPlacementChange(t)}}),oe(i).addClass(ye),"ontouchstart"in document.documentElement&&oe(document.body).children().on("mouseover",null,oe.noop);var l=function(){e.config.animation&&e._fixTransition();var t=e._hoverState;e._hoverState=null,oe(e.element).trigger(e.constructor.Event.SHOWN),t===pe&&e._leave(null,e)};if(oe(this.tip).hasClass(Ee)){var h=Cn.getTransitionDurationFromElement(this.tip);oe(this.tip).one(Cn.TRANSITION_END,l).emulateTransitionEnd(h)}else l()}},t.hide=function(t){var e=this,n=this.getTipElement(),i=oe.Event(this.constructor.Event.HIDE),r=function(){e._hoverState!==me&&n.parentNode&&n.parentNode.removeChild(n),e._cleanTipClass(),e.element.removeAttribute("aria-describedby"),oe(e.element).trigger(e.constructor.Event.HIDDEN),null!==e._popper&&e._popper.destroy(),t&&t()};if(oe(this.element).trigger(i),!i.isDefaultPrevented()){if(oe(n).removeClass(ye),"ontouchstart"in document.documentElement&&oe(document.body).children().off("mouseover",null,oe.noop),this._activeTrigger[De]=!1,this._activeTrigger[Ae]=!1,this._activeTrigger[Ie]=!1,oe(this.tip).hasClass(Ee)){var s=Cn.getTransitionDurationFromElement(n);oe(n).one(Cn.TRANSITION_END,r).emulateTransitionEnd(s)}else r();this._hoverState=""}},t.update=function(){null!==this._popper&&this._popper.scheduleUpdate()},t.isWithContent=function(){return Boolean(this.getTitle())},t.addAttachmentClass=function(t){oe(this.getTipElement()).addClass(ue+"-"+t)},t.getTipElement=function(){return this.tip=this.tip||oe(this.config.template)[0],this.tip},t.setContent=function(){var t=oe(this.getTipElement());this.setElementContent(t.find(Te),this.getTitle()),t.removeClass(Ee+" "+ye)},t.setElementContent=function(t,e){var n=this.config.html;"object"==typeof e&&(e.nodeType||e.jquery)?n?oe(e).parent().is(t)||t.empty().append(e):t.text(oe(e).text()):t[n?"html":"text"](e)},t.getTitle=function(){var t=this.element.getAttribute("data-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this.element):this.config.title),t},t._getAttachment=function(t){return _e[t.toUpperCase()]},t._setListeners=function(){var i=this;this.config.trigger.split(" ").forEach(function(t){if("click"===t)oe(i.element).on(i.constructor.Event.CLICK,i.config.selector,function(t){return i.toggle(t)});else if(t!==be){var e=t===Ie?i.constructor.Event.MOUSEENTER:i.constructor.Event.FOCUSIN,n=t===Ie?i.constructor.Event.MOUSELEAVE:i.constructor.Event.FOCUSOUT;oe(i.element).on(e,i.config.selector,function(t){return i._enter(t)}).on(n,i.config.selector,function(t){return i._leave(t)})}oe(i.element).closest(".modal").on("hide.bs.modal",function(){return i.hide()})}),this.config.selector?this.config=h({},this.config,{trigger:"manual",selector:""}):this._fixTitle()},t._fixTitle=function(){var t=typeof this.element.getAttribute("data-original-title");(this.element.getAttribute("title")||"string"!==t)&&(this.element.setAttribute("data-original-title",this.element.getAttribute("title")||""),this.element.setAttribute("title",""))},t._enter=function(t,e){var n=this.constructor.DATA_KEY;(e=e||oe(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),oe(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusin"===t.type?Ae:Ie]=!0),oe(e.getTipElement()).hasClass(ye)||e._hoverState===me?e._hoverState=me:(clearTimeout(e._timeout),e._hoverState=me,e.config.delay&&e.config.delay.show?e._timeout=setTimeout(function(){e._hoverState===me&&e.show()},e.config.delay.show):e.show())},t._leave=function(t,e){var n=this.constructor.DATA_KEY;(e=e||oe(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),oe(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusout"===t.type?Ae:Ie]=!1),e._isWithActiveTrigger()||(clearTimeout(e._timeout),e._hoverState=pe,e.config.delay&&e.config.delay.hide?e._timeout=setTimeout(function(){e._hoverState===pe&&e.hide()},e.config.delay.hide):e.hide())},t._isWithActiveTrigger=function(){for(var t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1},t._getConfig=function(t){return"number"==typeof(t=h({},this.constructor.Default,oe(this.element).data(),"object"==typeof t&&t?t:{})).delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),Cn.typeCheckConfig(ae,t,this.constructor.DefaultType),t},t._getDelegateConfig=function(){var t={};if(this.config)for(var e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t},t._cleanTipClass=function(){var t=oe(this.getTipElement()),e=t.attr("class").match(fe);null!==e&&0

'}),He=h({},Nn.DefaultType,{content:"(string|element|function)"}),We="fade",xe=".popover-header",Ue=".popover-body",Ke={HIDE:"hide"+ke,HIDDEN:"hidden"+ke,SHOW:(Me="show")+ke,SHOWN:"shown"+ke,INSERTED:"inserted"+ke,CLICK:"click"+ke,FOCUSIN:"focusin"+ke,FOCUSOUT:"focusout"+ke,MOUSEENTER:"mouseenter"+ke,MOUSELEAVE:"mouseleave"+ke},Fe=function(t){var e,n;function i(){return t.apply(this,arguments)||this}n=t,(e=i).prototype=Object.create(n.prototype),(e.prototype.constructor=e).__proto__=n;var r=i.prototype;return r.isWithContent=function(){return this.getTitle()||this._getContent()},r.addAttachmentClass=function(t){we(this.getTipElement()).addClass(Le+"-"+t)},r.getTipElement=function(){return this.tip=this.tip||we(this.config.template)[0],this.tip},r.setContent=function(){var t=we(this.getTipElement());this.setElementContent(t.find(xe),this.getTitle());var e=this._getContent();"function"==typeof e&&(e=e.call(this.element)),this.setElementContent(t.find(Ue),e),t.removeClass(We+" "+Me)},r._getContent=function(){return this.element.getAttribute("data-content")||this.config.content},r._cleanTipClass=function(){var t=we(this.getTipElement()),e=t.attr("class").match(je);null!==e&&0=this._offsets[r]&&("undefined"==typeof this._offsets[r+1]||t=0&&n0&&t-1 in e)}var E=function(e){var t,n,r,i,o,a,s,u,l,c,f,p,d,h,g,y,v,m,x,b="sizzle"+1*new Date,w=e.document,T=0,C=0,E=ae(),k=ae(),S=ae(),D=function(e,t){return e===t&&(f=!0),0},N={}.hasOwnProperty,A=[],j=A.pop,q=A.push,L=A.push,H=A.slice,O=function(e,t){for(var n=0,r=e.length;n+~]|"+M+")"+M+"*"),z=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),X=new RegExp(W),U=new RegExp("^"+R+"$"),V={ID:new RegExp("^#("+R+")"),CLASS:new RegExp("^\\.("+R+")"),TAG:new RegExp("^("+R+"|[*])"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Q=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/[+~]/,Z=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ee=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},te=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ne=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},re=function(){p()},ie=me(function(e){return!0===e.disabled&&("form"in e||"label"in e)},{dir:"parentNode",next:"legend"});try{L.apply(A=H.call(w.childNodes),w.childNodes),A[w.childNodes.length].nodeType}catch(e){L={apply:A.length?function(e,t){q.apply(e,H.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function oe(e,t,r,i){var o,s,l,c,f,h,v,m=t&&t.ownerDocument,T=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==T&&9!==T&&11!==T)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&p(t),t=t||d,g)){if(11!==T&&(f=J.exec(e)))if(o=f[1]){if(9===T){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return L.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!S[e+" "]&&(!y||!y.test(e))){if(1!==T)m=t,v=e;else if("object"!==t.nodeName.toLowerCase()){(c=t.getAttribute("id"))?c=c.replace(te,ne):t.setAttribute("id",c=b),s=(h=a(e)).length;while(s--)h[s]="#"+c+" "+ve(h[s]);v=h.join(","),m=K.test(e)&&ge(t.parentNode)||t}if(v)try{return L.apply(r,m.querySelectorAll(v)),r}catch(e){}finally{c===b&&t.removeAttribute("id")}}}return u(e.replace(B,"$1"),t,r,i)}function ae(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[b]=!0,e}function ue(e){var t=d.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function le(e,t){var n=e.split("|"),i=n.length;while(i--)r.attrHandle[n[i]]=t}function ce(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function de(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ie(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function he(e){return se(function(t){return t=+t,se(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}function ge(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}n=oe.support={},o=oe.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},p=oe.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!==d&&9===a.nodeType&&a.documentElement?(d=a,h=d.documentElement,g=!o(d),w!==d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ue(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ue(function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=Q.test(d.getElementsByClassName),n.getById=ue(function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length}),n.getById?(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){return e.getAttribute("id")===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){var n="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&g)return t.getElementsByClassName(e)},v=[],y=[],(n.qsa=Q.test(d.querySelectorAll))&&(ue(function(e){h.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+P+")"),e.querySelectorAll("[id~="+b+"-]").length||y.push("~="),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+b+"+*").length||y.push(".#.+[+~]")}),ue(function(e){e.innerHTML="";var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(n.matchesSelector=Q.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ue(function(e){n.disconnectedMatch=m.call(e,"*"),m.call(e,"[s!='']:x"),v.push("!=",W)}),y=y.length&&new RegExp(y.join("|")),v=v.length&&new RegExp(v.join("|")),t=Q.test(h.compareDocumentPosition),x=t||Q.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&x(w,e)?-1:t===d||t.ownerDocument===w&&x(w,t)?1:c?O(c,e)-O(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?O(c,e)-O(c,t):0;if(i===o)return ce(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?ce(a[r],s[r]):a[r]===w?-1:s[r]===w?1:0},d):d},oe.matches=function(e,t){return oe(e,null,null,t)},oe.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&p(e),t=t.replace(z,"='$1']"),n.matchesSelector&&g&&!S[t+" "]&&(!v||!v.test(t))&&(!y||!y.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){}return oe(t,d,null,[e]).length>0},oe.contains=function(e,t){return(e.ownerDocument||e)!==d&&p(e),x(e,t)},oe.attr=function(e,t){(e.ownerDocument||e)!==d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&N.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},oe.escape=function(e){return(e+"").replace(te,ne)},oe.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},oe.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(D),f){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return c=null,e},i=oe.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else while(t=e[r++])n+=i(t);return n},(r=oe.selectors={cacheLength:50,createPseudo:se,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(Z,ee),e[3]=(e[3]||e[4]||e[5]||"").replace(Z,ee),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||oe.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&oe.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return V.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(Z,ee).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&E(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=oe.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace($," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?"nextSibling":"previousSibling",y=t.parentNode,v=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(y){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===v:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?y.firstChild:y.lastChild],a&&m){x=(d=(l=(c=(f=(p=y)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&y.childNodes[d];while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===v:1===p.nodeType)&&++x&&(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p===t))break;return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||oe.error("unsupported pseudo: "+e);return i[b]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se(function(e,n){var r,o=i(e,t),a=o.length;while(a--)e[r=O(e,o[a])]=!(n[r]=o[a])}):function(e){return i(e,0,n)}):i}},pseudos:{not:se(function(e){var t=[],n=[],r=s(e.replace(B,"$1"));return r[b]?se(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}}),has:se(function(e){return function(t){return oe(e,t).length>0}}),contains:se(function(e){return e=e.replace(Z,ee),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:se(function(e){return U.test(e||"")||oe.error("unsupported lang: "+e),e=e.replace(Z,ee).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:de(!1),disabled:de(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Y.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he(function(){return[0]}),last:he(function(e,t){return[t-1]}),eq:he(function(e,t,n){return[n<0?n+t:n]}),even:he(function(e,t){for(var n=0;n=0;)e.push(r);return e}),gt:he(function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function be(e,t,n){for(var r=0,i=t.length;r-1&&(o[l]=!(a[l]=f))}}else v=we(v===a?v.splice(h,v.length):v),i?i(null,a,v,u):L.apply(a,v)})}function Ce(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[" "],u=a?1:0,c=me(function(e){return e===t},s,!0),f=me(function(e){return O(t,e)>-1},s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&xe(p),u>1&&ve(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(B,"$1"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,y,v=0,m="0",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG("*",c),E=T+=null==w?1:Math.random()||.1,k=C.length;for(c&&(l=a===d||a||c);m!==k&&null!=(f=C[m]);m++){if(i&&f){h=0,a||f.ownerDocument===d||(p(f),s=!g);while(y=e[h++])if(y(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!y&&f)&&v--,o&&x.push(f))}if(v+=m,n&&m!==v){h=0;while(y=t[h++])y(x,b,a,s);if(o){if(v>0)while(m--)x[m]||b[m]||(b[m]=j.call(u));b=we(b)}L.apply(u,b),c&&!o&&b.length>0&&v+t.length>1&&oe.uniqueSort(u)}return c&&(T=E,l=w),x};return n?se(o):o}return s=oe.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=a(e)),n=t.length;while(n--)(o=Ce(t[n]))[b]?r.push(o):i.push(o);(o=S(e,Ee(i,r))).selector=e}return o},u=oe.select=function(e,t,n,i){var o,u,l,c,f,p="function"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&"ID"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(Z,ee),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}o=V.needsContext.test(e)?0:u.length;while(o--){if(l=u[o],r.relative[c=l.type])break;if((f=r.find[c])&&(i=f(l.matches[0].replace(Z,ee),K.test(u[0].type)&&ge(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&ve(u)))return L.apply(n,i),n;break}}}return(p||s(e,d))(i,t,!g,n,!t||K.test(e)&&ge(t.parentNode)||t),n},n.sortStable=b.split("").sort(D).join("")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ue(function(e){return 1&e.compareDocumentPosition(d.createElement("fieldset"))}),ue(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||le("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ue(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||le("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ue(function(e){return null==e.getAttribute("disabled")})||le(P,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),oe}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var k=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},D=w.expr.match.needsContext;function N(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var A=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,t,n){return g(t)?w.grep(e,function(e,r){return!!t.call(e,r,e)!==n}):t.nodeType?w.grep(e,function(e){return e===t!==n}):"string"!=typeof t?w.grep(e,function(e){return u.call(t,e)>-1!==n}):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,function(e){return 1===e.nodeType}))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(w(e).filter(function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&D.test(e)?w(e):e||[],!1).length}});var q,L=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:L.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),A.test(i[1])&&w.isPlainObject(t))for(i in t)g(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):g(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,q=w(r);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter(function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?u.call(w(e),this[0]):u.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return k(e,"parentNode")},parentsUntil:function(e,t,n){return k(e,"parentNode",n)},next:function(e){return P(e,"nextSibling")},prev:function(e){return P(e,"previousSibling")},nextAll:function(e){return k(e,"nextSibling")},prevAll:function(e){return k(e,"previousSibling")},nextUntil:function(e,t,n){return k(e,"nextSibling",n)},prevUntil:function(e,t,n){return k(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return N(e,"iframe")?e.contentDocument:(N(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=w.filter(r,i)),this.length>1&&(O[e]||w.uniqueSort(i),H.test(e)&&i.reverse()),this.pushStack(i)}});var M=/[^\x20\t\r\n\f]+/g;function R(e){var t={};return w.each(e.match(M)||[],function(e,n){t[n]=!0}),t}w.Callbacks=function(e){e="string"==typeof e?R(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1){n=a.shift();while(++s-1)o.splice(n,1),n<=s&&s--}),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l};function I(e){return e}function W(e){throw e}function $(e,t,n,r){var i;try{e&&g(i=e.promise)?i.call(e).done(t).fail(n):e&&g(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},"catch":function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred(function(t){w.each(n,function(n,r){var i=g(e[r[4]])&&e[r[4]];o[r[1]](function(){var e=i&&i.apply(this,arguments);e&&g(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+"With"](this,i?[e]:arguments)})}),e=null}).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==W&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred(function(e){n[0][3].add(a(0,e,g(i)?i:I,e.notifyWith)),n[1][3].add(a(0,e,g(t)?t:I)),n[2][3].add(a(0,e,g(r)?r:W))}).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add(function(){r=s},n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+"With"](this===o?void 0:this,arguments),this},o[t[0]+"With"]=a.fireWith}),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=o.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?o.call(arguments):n,--t||a.resolveWith(r,i)}};if(t<=1&&($(e,a.done(s(n)).resolve,a.reject,!t),"pending"===a.state()||g(i[n]&&i[n].then)))return a.then();while(n--)$(i[n],s(n),a.reject);return a.promise()}});var B=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&B.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout(function(){throw t})};var F=w.Deferred();w.fn.ready=function(e){return F.then(e)["catch"](function(e){w.readyException(e)}),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(r,[w]))}}),w.ready.then=F.then;function _(){r.removeEventListener("DOMContentLoaded",_),e.removeEventListener("load",_),w.ready()}"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(w.ready):(r.addEventListener("DOMContentLoaded",_),e.addEventListener("load",_));var z=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===x(n)){i=!0;for(s in n)z(e,t,s,n[s],!0,o,a)}else if(void 0!==r&&(i=!0,g(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each(function(){K.remove(this,e)})}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=J.get(e,t),n&&(!r||Array.isArray(n)?r=J.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t),a=function(){w.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return J.get(e,n)||J.access(e,n,{empty:w.Callbacks("once memory").add(function(){J.remove(e,[t+"queue",n])})})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]+)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ge.optgroup=ge.option,ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td;function ye(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&N(e,t)?w.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n-1)i&&i.push(o);else if(l=w.contains(o.ownerDocument,o),a=ye(f.appendChild(o),"script"),l&&ve(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}!function(){var e=r.createDocumentFragment().appendChild(r.createElement("div")),t=r.createElement("input");t.setAttribute("type","radio"),t.setAttribute("checked","checked"),t.setAttribute("name","t"),e.appendChild(t),h.checkClone=e.cloneNode(!0).cloneNode(!0).lastChild.checked,e.innerHTML="",h.noCloneChecked=!!e.cloneNode(!0).lastChild.defaultValue}();var be=r.documentElement,we=/^key/,Te=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ce=/^([^.]*)(?:\.(.+)|)/;function Ee(){return!0}function ke(){return!1}function Se(){try{return r.activeElement}catch(e){}}function De(e,t,n,r,i,o){var a,s;if("object"==typeof t){"string"!=typeof n&&(r=r||n,n=void 0);for(s in t)De(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=ke;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return w().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=w.guid++)),e.each(function(){w.event.add(this,t,i,r,n)})}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.get(e);if(y){n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(be,i),n.guid||(n.guid=w.guid++),(u=y.events)||(u=y.events={}),(a=y.handle)||(a=y.handle=function(t){return"undefined"!=typeof w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||"").match(M)||[""]).length;while(l--)d=g=(s=Ce.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.hasData(e)&&J.get(e);if(y&&(u=y.events)){l=(t=(t||"").match(M)||[""]).length;while(l--)if(s=Ce.exec(t[l])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,y.handle)||w.removeEvent(e,d,y.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&J.remove(e,"handle events")}},dispatch:function(e){var t=w.event.fix(e),n,r,i,o,a,s,u=new Array(arguments.length),l=(J.get(this,"events")||{})[t.type]||[],c=w.event.special[t.type]||{};for(u[0]=t,n=1;n=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\x20\t\r\n\f]*)[^>]*)\/>/gi,Ae=/\s*$/g;function Le(e,t){return N(e,"table")&&N(11!==t.nodeType?t:t.firstChild,"tr")?w(e).children("tbody")[0]||e:e}function He(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function Oe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Pe(e,t){var n,r,i,o,a,s,u,l;if(1===t.nodeType){if(J.hasData(e)&&(o=J.access(e),a=J.set(t,o),l=o.events)){delete a.handle,a.events={};for(i in l)for(n=0,r=l[i].length;n1&&"string"==typeof y&&!h.checkClone&&je.test(y))return e.each(function(i){var o=e.eq(i);v&&(t[0]=y.call(this,i,o.html())),Re(o,t,n,r)});if(p&&(i=xe(t,e[0].ownerDocument,!1,e,r),o=i.firstChild,1===i.childNodes.length&&(i=o),o||r)){for(u=(s=w.map(ye(i,"script"),He)).length;f")},clone:function(e,t,n){var r,i,o,a,s=e.cloneNode(!0),u=w.contains(e.ownerDocument,e);if(!(h.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||w.isXMLDoc(e)))for(a=ye(s),r=0,i=(o=ye(e)).length;r0&&ve(a,!u&&ye(e,"script")),s},cleanData:function(e){for(var t,n,r,i=w.event.special,o=0;void 0!==(n=e[o]);o++)if(Y(n)){if(t=n[J.expando]){if(t.events)for(r in t.events)i[r]?w.event.remove(n,r):w.removeEvent(n,r,t.handle);n[J.expando]=void 0}n[K.expando]&&(n[K.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Ie(this,e,!0)},remove:function(e){return Ie(this,e)},text:function(e){return z(this,function(e){return void 0===e?w.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Re(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||Le(this,e).appendChild(e)})},prepend:function(){return Re(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Le(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ye(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return w.clone(this,e,t)})},html:function(e){return z(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ae.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))),u}function et(e,t,n){var r=$e(e),i=Fe(e,t,r),o="border-box"===w.css(e,"boxSizing",!1,r),a=o;if(We.test(i)){if(!n)return i;i="auto"}return a=a&&(h.boxSizingReliable()||i===e.style[t]),("auto"===i||!parseFloat(i)&&"inline"===w.css(e,"display",!1,r))&&(i=e["offset"+t[0].toUpperCase()+t.slice(1)],a=!0),(i=parseFloat(i)||0)+Ze(e,t,n||(o?"border":"content"),a,r,i)+"px"}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Fe(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=G(t),u=Xe.test(t),l=e.style;if(u||(t=Je(s)),a=w.cssHooks[t]||w.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"==(o=typeof n)&&(i=ie.exec(n))&&i[1]&&(n=ue(e,t,i),o="number"),null!=n&&n===n&&("number"===o&&(n+=i&&i[3]||(w.cssNumber[s]?"":"px")),h.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=G(t);return Xe.test(t)||(t=Je(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Fe(e,t,r)),"normal"===i&&t in Ve&&(i=Ve[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),w.each(["height","width"],function(e,t){w.cssHooks[t]={get:function(e,n,r){if(n)return!ze.test(w.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?et(e,t,r):se(e,Ue,function(){return et(e,t,r)})},set:function(e,n,r){var i,o=$e(e),a="border-box"===w.css(e,"boxSizing",!1,o),s=r&&Ze(e,t,r,a,o);return a&&h.scrollboxSize()===o.position&&(s-=Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-Ze(e,t,"border",!1,o)-.5)),s&&(i=ie.exec(n))&&"px"!==(i[3]||"px")&&(e.style[t]=n,n=w.css(e,t)),Ke(e,n,s)}}}),w.cssHooks.marginLeft=_e(h.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Fe(e,"marginLeft"))||e.getBoundingClientRect().left-se(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),w.each({margin:"",padding:"",border:"Width"},function(e,t){w.cssHooks[e+t]={expand:function(n){for(var r=0,i={},o="string"==typeof n?n.split(" "):[n];r<4;r++)i[e+oe[r]+t]=o[r]||o[r-2]||o[0];return i}},"margin"!==e&&(w.cssHooks[e+t].set=Ke)}),w.fn.extend({css:function(e,t){return z(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=$e(e),i=t.length;a1)}});function tt(e,t,n,r,i){return new tt.prototype.init(e,t,n,r,i)}w.Tween=tt,tt.prototype={constructor:tt,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||w.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(w.cssNumber[n]?"":"px")},cur:function(){var e=tt.propHooks[this.prop];return e&&e.get?e.get(this):tt.propHooks._default.get(this)},run:function(e){var t,n=tt.propHooks[this.prop];return this.options.duration?this.pos=t=w.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):tt.propHooks._default.set(this),this}},tt.prototype.init.prototype=tt.prototype,tt.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=w.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){w.fx.step[e.prop]?w.fx.step[e.prop](e):1!==e.elem.nodeType||null==e.elem.style[w.cssProps[e.prop]]&&!w.cssHooks[e.prop]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},tt.propHooks.scrollTop=tt.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},w.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},w.fx=tt.prototype.init,w.fx.step={};var nt,rt,it=/^(?:toggle|show|hide)$/,ot=/queueHooks$/;function at(){rt&&(!1===r.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(at):e.setTimeout(at,w.fx.interval),w.fx.tick())}function st(){return e.setTimeout(function(){nt=void 0}),nt=Date.now()}function ut(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=oe[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function lt(e,t,n){for(var r,i=(pt.tweeners[t]||[]).concat(pt.tweeners["*"]),o=0,a=i.length;o1)},removeAttr:function(e){return this.each(function(){w.removeAttr(this,e)})}}),w.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?w.prop(e,t,n):(1===o&&w.isXMLDoc(e)||(i=w.attrHooks[t.toLowerCase()]||(w.expr.match.bool.test(t)?dt:void 0)),void 0!==n?null===n?void w.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=w.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!h.radioValue&&"radio"===t&&N(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(M);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),dt={set:function(e,t,n){return!1===t?w.removeAttr(e,n):e.setAttribute(n,n),n}},w.each(w.expr.match.bool.source.match(/\w+/g),function(e,t){var n=ht[t]||w.find.attr;ht[t]=function(e,t,r){var i,o,a=t.toLowerCase();return r||(o=ht[a],ht[a]=i,i=null!=n(e,t,r)?a:null,ht[a]=o),i}});var gt=/^(?:input|select|textarea|button)$/i,yt=/^(?:a|area)$/i;w.fn.extend({prop:function(e,t){return z(this,w.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[w.propFix[e]||e]})}}),w.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&w.isXMLDoc(e)||(t=w.propFix[t]||t,i=w.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=w.find.attr(e,"tabindex");return t?parseInt(t,10):gt.test(e.nodeName)||yt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),h.optSelected||(w.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),w.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){w.propFix[this.toLowerCase()]=this});function vt(e){return(e.match(M)||[]).join(" ")}function mt(e){return e.getAttribute&&e.getAttribute("class")||""}function xt(e){return Array.isArray(e)?e:"string"==typeof e?e.match(M)||[]:[]}w.fn.extend({addClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).addClass(e.call(this,t,mt(this)))});if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).removeClass(e.call(this,t,mt(this)))});if(!arguments.length)return this.attr("class","");if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])while(r.indexOf(" "+o+" ")>-1)r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(e,t){var n=typeof e,r="string"===n||Array.isArray(e);return"boolean"==typeof t&&r?t?this.addClass(e):this.removeClass(e):g(e)?this.each(function(n){w(this).toggleClass(e.call(this,n,mt(this),t),t)}):this.each(function(){var t,i,o,a;if(r){i=0,o=w(this),a=xt(e);while(t=a[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else void 0!==e&&"boolean"!==n||((t=mt(this))&&J.set(this,"__className__",t),this.setAttribute&&this.setAttribute("class",t||!1===e?"":J.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&(" "+vt(mt(n))+" ").indexOf(t)>-1)return!0;return!1}});var bt=/\r/g;w.fn.extend({val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=g(e),this.each(function(n){var i;1===this.nodeType&&(null==(i=r?e.call(this,n,w(this).val()):e)?i="":"number"==typeof i?i+="":Array.isArray(i)&&(i=w.map(i,function(e){return null==e?"":e+""})),(t=w.valHooks[this.type]||w.valHooks[this.nodeName.toLowerCase()])&&"set"in t&&void 0!==t.set(this,i,"value")||(this.value=i))});if(i)return(t=w.valHooks[i.type]||w.valHooks[i.nodeName.toLowerCase()])&&"get"in t&&void 0!==(n=t.get(i,"value"))?n:"string"==typeof(n=i.value)?n.replace(bt,""):null==n?"":n}}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,"value");return null!=t?t:vt(w.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),w.each(["radio","checkbox"],function(){w.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=w.inArray(w(e).val(),t)>-1}},h.checkOn||(w.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),h.focusin="onfocusin"in e;var wt=/^(?:focusinfocus|focusoutblur)$/,Tt=function(e){e.stopPropagation()};w.extend(w.event,{trigger:function(t,n,i,o){var a,s,u,l,c,p,d,h,v=[i||r],m=f.call(t,"type")?t.type:t,x=f.call(t,"namespace")?t.namespace.split("."):[];if(s=h=u=i=i||r,3!==i.nodeType&&8!==i.nodeType&&!wt.test(m+w.event.triggered)&&(m.indexOf(".")>-1&&(m=(x=m.split(".")).shift(),x.sort()),c=m.indexOf(":")<0&&"on"+m,t=t[w.expando]?t:new w.Event(m,"object"==typeof t&&t),t.isTrigger=o?2:3,t.namespace=x.join("."),t.rnamespace=t.namespace?new RegExp("(^|\\.)"+x.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=void 0,t.target||(t.target=i),n=null==n?[t]:w.makeArray(n,[t]),d=w.event.special[m]||{},o||!d.trigger||!1!==d.trigger.apply(i,n))){if(!o&&!d.noBubble&&!y(i)){for(l=d.delegateType||m,wt.test(l+m)||(s=s.parentNode);s;s=s.parentNode)v.push(s),u=s;u===(i.ownerDocument||r)&&v.push(u.defaultView||u.parentWindow||e)}a=0;while((s=v[a++])&&!t.isPropagationStopped())h=s,t.type=a>1?l:d.bindType||m,(p=(J.get(s,"events")||{})[t.type]&&J.get(s,"handle"))&&p.apply(s,n),(p=c&&s[c])&&p.apply&&Y(s)&&(t.result=p.apply(s,n),!1===t.result&&t.preventDefault());return t.type=m,o||t.isDefaultPrevented()||d._default&&!1!==d._default.apply(v.pop(),n)||!Y(i)||c&&g(i[m])&&!y(i)&&((u=i[c])&&(i[c]=null),w.event.triggered=m,t.isPropagationStopped()&&h.addEventListener(m,Tt),i[m](),t.isPropagationStopped()&&h.removeEventListener(m,Tt),w.event.triggered=void 0,u&&(i[c]=u)),t.result}},simulate:function(e,t,n){var r=w.extend(new w.Event,n,{type:e,isSimulated:!0});w.event.trigger(r,null,t)}}),w.fn.extend({trigger:function(e,t){return this.each(function(){w.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return w.event.trigger(e,t,n,!0)}}),h.focusin||w.each({focus:"focusin",blur:"focusout"},function(e,t){var n=function(e){w.event.simulate(t,e.target,w.event.fix(e))};w.event.special[t]={setup:function(){var r=this.ownerDocument||this,i=J.access(r,t);i||r.addEventListener(e,n,!0),J.access(r,t,(i||0)+1)},teardown:function(){var r=this.ownerDocument||this,i=J.access(r,t)-1;i?J.access(r,t,i):(r.removeEventListener(e,n,!0),J.remove(r,t))}}});var Ct=e.location,Et=Date.now(),kt=/\?/;w.parseXML=function(t){var n;if(!t||"string"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,"text/xml")}catch(e){n=void 0}return n&&!n.getElementsByTagName("parsererror").length||w.error("Invalid XML: "+t),n};var St=/\[\]$/,Dt=/\r?\n/g,Nt=/^(?:submit|button|image|reset|file)$/i,At=/^(?:input|select|textarea|keygen)/i;function jt(e,t,n,r){var i;if(Array.isArray(t))w.each(t,function(t,i){n||St.test(e)?r(e,i):jt(e+"["+("object"==typeof i&&null!=i?t:"")+"]",i,n,r)});else if(n||"object"!==x(t))r(e,t);else for(i in t)jt(e+"["+i+"]",t[i],n,r)}w.param=function(e,t){var n,r=[],i=function(e,t){var n=g(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(Array.isArray(e)||e.jquery&&!w.isPlainObject(e))w.each(e,function(){i(this.name,this.value)});else for(n in e)jt(n,e[n],t,i);return r.join("&")},w.fn.extend({serialize:function(){return w.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=w.prop(this,"elements");return e?w.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!w(this).is(":disabled")&&At.test(this.nodeName)&&!Nt.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=w(this).val();return null==n?null:Array.isArray(n)?w.map(n,function(e){return{name:t.name,value:e.replace(Dt,"\r\n")}}):{name:t.name,value:n.replace(Dt,"\r\n")}}).get()}});var qt=/%20/g,Lt=/#.*$/,Ht=/([?&])_=[^&]*/,Ot=/^(.*?):[ \t]*([^\r\n]*)$/gm,Pt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Mt=/^(?:GET|HEAD)$/,Rt=/^\/\//,It={},Wt={},$t="*/".concat("*"),Bt=r.createElement("a");Bt.href=Ct.href;function Ft(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(M)||[];if(g(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function _t(e,t,n,r){var i={},o=e===Wt;function a(s){var u;return i[s]=!0,w.each(e[s]||[],function(e,s){var l=s(t,n,r);return"string"!=typeof l||o||i[l]?o?!(u=l):void 0:(t.dataTypes.unshift(l),a(l),!1)}),u}return a(t.dataTypes[0])||!i["*"]&&a("*")}function zt(e,t){var n,r,i=w.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&w.extend(!0,e,r),e}function Xt(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}function Ut(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Ct.href,type:"GET",isLocal:Pt.test(Ct.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":$t,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":w.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?zt(zt(e,w.ajaxSettings),t):zt(w.ajaxSettings,e)},ajaxPrefilter:Ft(It),ajaxTransport:Ft(Wt),ajax:function(t,n){"object"==typeof t&&(n=t,t=void 0),n=n||{};var i,o,a,s,u,l,c,f,p,d,h=w.ajaxSetup({},n),g=h.context||h,y=h.context&&(g.nodeType||g.jquery)?w(g):w.event,v=w.Deferred(),m=w.Callbacks("once memory"),x=h.statusCode||{},b={},T={},C="canceled",E={readyState:0,getResponseHeader:function(e){var t;if(c){if(!s){s={};while(t=Ot.exec(a))s[t[1].toLowerCase()]=t[2]}t=s[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return c?a:null},setRequestHeader:function(e,t){return null==c&&(e=T[e.toLowerCase()]=T[e.toLowerCase()]||e,b[e]=t),this},overrideMimeType:function(e){return null==c&&(h.mimeType=e),this},statusCode:function(e){var t;if(e)if(c)E.always(e[E.status]);else for(t in e)x[t]=[x[t],e[t]];return this},abort:function(e){var t=e||C;return i&&i.abort(t),k(0,t),this}};if(v.promise(E),h.url=((t||h.url||Ct.href)+"").replace(Rt,Ct.protocol+"//"),h.type=n.method||n.type||h.method||h.type,h.dataTypes=(h.dataType||"*").toLowerCase().match(M)||[""],null==h.crossDomain){l=r.createElement("a");try{l.href=h.url,l.href=l.href,h.crossDomain=Bt.protocol+"//"+Bt.host!=l.protocol+"//"+l.host}catch(e){h.crossDomain=!0}}if(h.data&&h.processData&&"string"!=typeof h.data&&(h.data=w.param(h.data,h.traditional)),_t(It,h,n,E),c)return E;(f=w.event&&h.global)&&0==w.active++&&w.event.trigger("ajaxStart"),h.type=h.type.toUpperCase(),h.hasContent=!Mt.test(h.type),o=h.url.replace(Lt,""),h.hasContent?h.data&&h.processData&&0===(h.contentType||"").indexOf("application/x-www-form-urlencoded")&&(h.data=h.data.replace(qt,"+")):(d=h.url.slice(o.length),h.data&&(h.processData||"string"==typeof h.data)&&(o+=(kt.test(o)?"&":"?")+h.data,delete h.data),!1===h.cache&&(o=o.replace(Ht,"$1"),d=(kt.test(o)?"&":"?")+"_="+Et+++d),h.url=o+d),h.ifModified&&(w.lastModified[o]&&E.setRequestHeader("If-Modified-Since",w.lastModified[o]),w.etag[o]&&E.setRequestHeader("If-None-Match",w.etag[o])),(h.data&&h.hasContent&&!1!==h.contentType||n.contentType)&&E.setRequestHeader("Content-Type",h.contentType),E.setRequestHeader("Accept",h.dataTypes[0]&&h.accepts[h.dataTypes[0]]?h.accepts[h.dataTypes[0]]+("*"!==h.dataTypes[0]?", "+$t+"; q=0.01":""):h.accepts["*"]);for(p in h.headers)E.setRequestHeader(p,h.headers[p]);if(h.beforeSend&&(!1===h.beforeSend.call(g,E,h)||c))return E.abort();if(C="abort",m.add(h.complete),E.done(h.success),E.fail(h.error),i=_t(Wt,h,n,E)){if(E.readyState=1,f&&y.trigger("ajaxSend",[E,h]),c)return E;h.async&&h.timeout>0&&(u=e.setTimeout(function(){E.abort("timeout")},h.timeout));try{c=!1,i.send(b,k)}catch(e){if(c)throw e;k(-1,e)}}else k(-1,"No Transport");function k(t,n,r,s){var l,p,d,b,T,C=n;c||(c=!0,u&&e.clearTimeout(u),i=void 0,a=s||"",E.readyState=t>0?4:0,l=t>=200&&t<300||304===t,r&&(b=Xt(h,E,r)),b=Ut(h,b,E,l),l?(h.ifModified&&((T=E.getResponseHeader("Last-Modified"))&&(w.lastModified[o]=T),(T=E.getResponseHeader("etag"))&&(w.etag[o]=T)),204===t||"HEAD"===h.type?C="nocontent":304===t?C="notmodified":(C=b.state,p=b.data,l=!(d=b.error))):(d=C,!t&&C||(C="error",t<0&&(t=0))),E.status=t,E.statusText=(n||C)+"",l?v.resolveWith(g,[p,C,E]):v.rejectWith(g,[E,C,d]),E.statusCode(x),x=void 0,f&&y.trigger(l?"ajaxSuccess":"ajaxError",[E,h,l?p:d]),m.fireWith(g,[E,C]),f&&(y.trigger("ajaxComplete",[E,h]),--w.active||w.event.trigger("ajaxStop")))}return E},getJSON:function(e,t,n){return w.get(e,t,n,"json")},getScript:function(e,t){return w.get(e,void 0,t,"script")}}),w.each(["get","post"],function(e,t){w[t]=function(e,n,r,i){return g(n)&&(i=i||r,r=n,n=void 0),w.ajax(w.extend({url:e,type:t,dataType:i,data:n,success:r},w.isPlainObject(e)&&e))}}),w._evalUrl=function(e){return w.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},w.fn.extend({wrapAll:function(e){var t;return this[0]&&(g(e)&&(e=e.call(this[0])),t=w(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(e){return g(e)?this.each(function(t){w(this).wrapInner(e.call(this,t))}):this.each(function(){var t=w(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=g(e);return this.each(function(n){w(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(e){return this.parent(e).not("body").each(function(){w(this).replaceWith(this.childNodes)}),this}}),w.expr.pseudos.hidden=function(e){return!w.expr.pseudos.visible(e)},w.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},w.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(e){}};var Vt={0:200,1223:204},Gt=w.ajaxSettings.xhr();h.cors=!!Gt&&"withCredentials"in Gt,h.ajax=Gt=!!Gt,w.ajaxTransport(function(t){var n,r;if(h.cors||Gt&&!t.crossDomain)return{send:function(i,o){var a,s=t.xhr();if(s.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(a in t.xhrFields)s[a]=t.xhrFields[a];t.mimeType&&s.overrideMimeType&&s.overrideMimeType(t.mimeType),t.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");for(a in i)s.setRequestHeader(a,i[a]);n=function(e){return function(){n&&(n=r=s.onload=s.onerror=s.onabort=s.ontimeout=s.onreadystatechange=null,"abort"===e?s.abort():"error"===e?"number"!=typeof s.status?o(0,"error"):o(s.status,s.statusText):o(Vt[s.status]||s.status,s.statusText,"text"!==(s.responseType||"text")||"string"!=typeof s.responseText?{binary:s.response}:{text:s.responseText},s.getAllResponseHeaders()))}},s.onload=n(),r=s.onerror=s.ontimeout=n("error"),void 0!==s.onabort?s.onabort=r:s.onreadystatechange=function(){4===s.readyState&&e.setTimeout(function(){n&&r()})},n=n("abort");try{s.send(t.hasContent&&t.data||null)}catch(e){if(n)throw e}},abort:function(){n&&n()}}}),w.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),w.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return w.globalEval(e),e}}}),w.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),w.ajaxTransport("script",function(e){if(e.crossDomain){var t,n;return{send:function(i,o){t=w("'; - - /** - * Bootstrap 构造函数. - * @param array $config - 配置信息 - */ - public function __construct($config) { - parent::__construct($config); - // bootstrapJs文件路径 - $this->bootstrapJs = Tools::getSubValue('bootstrap_js', $config, $this->bootstrapJs); - // jQueryJs文件路径 - $this->jQueryJs = Tools::getSubValue('jquery_js', $config, $this->jQueryJs); - // 自定义js - $this->customJs .= Tools::getSubValue('custom_js', $config, ''); - // bootstrapCSS文件路径 - $this->bootstrapCss = Tools::getSubValue('bootstrap_css', $config, $this->bootstrapCss); - // 自定义CSS - $this->customCss .= Tools::getSubValue('custom_css', $config, ''); - // 合并CSS - $this->_getCss(); - // 合并JS - $this->_getJs(); - } - - /** - * 输出HTML - * @param int $type - 方法过滤,默认只获取 public类型 方法 - * ReflectionMethod::IS_STATIC - * ReflectionMethod::IS_PUBLIC - * ReflectionMethod::IS_PROTECTED - * ReflectionMethod::IS_PRIVATE - * ReflectionMethod::IS_ABSTRACT - * ReflectionMethod::IS_FINAL - * @return string - */ - public function getHtml($type = \ReflectionMethod::IS_PUBLIC) { - $data = $this->getApiDoc($type); - $html = << - - - - - - - - API文档 By Api-Doc-PHP - {$this->customCss} - - -
- -
-
{$this->_getDocList($data)}
-
-
- -
-
- {$this->customJs} - - -EXT; - - if (isset($_GET['download']) && $_GET['download'] === 'api_doc_php') { - Tools::downloadFile($html); - return true; - } - return $html; - } - - /** - * 解析return 并生成HTML - * @param array $data - * @return string - */ - private function _getReturnData($data = []) { - $html = ''; - if (!is_array($data) || count($data) < 1) { - return $html; - } - $html .= '

返回参数

'; - $html .= ''; - foreach ($data as $v) { - $html .= ' - - - - '; - } - $html .= '
参数类型描述
' . Tools::getSubValue('return_name', $v, '') . '' . Tools::getSubValue('return_type', $v, '') . '' . Tools::getSubValue('return_title', $v, '') . '
'; - return $html; - } - - /** - * 解析param 并生成HTML - * @param array $data - * @return string - */ - private function _getParamData($data = []) { - $html = ''; - if (!is_array($data) || count($data) < 1) { - return $html; - } - $html .= '

请求参数

'; - $html .= ''; - foreach ($data as $v) { - $html .= ' - - - - - - '; - } - $html .= '
参数类型描述默认值是否必须
' . Tools::getSubValue('param_name', $v, '') . '' . Tools::getSubValue('param_type', $v, '') . '' . Tools::getSubValue('param_title', $v, '') . '' . Tools::getSubValue('param_default', $v, '无默认值') . '' . Tools::getSubValue('param_require', $v, '非必须') . '
'; - return $html; - } - - /** - * 解析code 并生成HTML - * @param array $data - * @return string - */ - private function _getCodeData($data = []) { - $html = ''; - if (!is_array($data) || count($data) < 1) { - return $html; - } - $html .= '

状态码说明

'; - $html .= ''; - foreach ($data as $v) { - $html .= ' - - - '; - } - $html .= '
状态码描述
' . Tools::getSubValue('code', $v, '') . '' . Tools::getSubValue('content', $v, '暂无说明') . '
'; - return $html; - } - - /** - * 获取指定接口操作下的文档信息 - * @param $className - 类名 - * @param $actionName - 操作名 - * @param $actionItem - 接口数据 - * @return string - */ - private function _getActionItem($className, $actionName, $actionItem) { - $html = << -

API - {$actionItem['title']}

-

请求方式: - {$actionItem['method']} -

-

请求地址:{$actionItem['url']}

- {$this->_getParamData(Tools::getSubValue('param', $actionItem, []))} - {$this->_getReturnData(Tools::getSubValue('return', $actionItem, []))} - {$this->_getCodeData(Tools::getSubValue('code', $actionItem, []))} - -EXT; - return $html; - } - - /** - * 获取指定API类的文档HTML - * @param $className - 类名称 - * @param $classItem - 类数据 - * @return string - */ - private function _getClassItem($className, $classItem) { - $title = Tools::getSubValue('title', $classItem, '未命名'); - $actionHtml = ''; - if (isset($classItem['action']) && is_array($classItem['action']) && count($classItem['action']) >= 1) { - foreach ($classItem['action'] as $actionName => $actionItem) { - $actionHtml .= $this->_getActionItem($className, $actionName, $actionItem); - } - } - $html = << -

{$title}

-
{$actionHtml}
- -EXT; - return $html; - } - - /** - * 获取API文档HTML - * @param array $data - 文档数据 - * @return string - */ - private function _getDocList($data) { - $html = ''; - if (count($data) < 1) { - return $html; - } - $html .= '
'; - foreach ($data as $className => $classItem) { - $html .= $this->_getClassItem($className, $classItem); - } - $html .= '
'; - return $html; - } - - /** - * 获取顶部导航HTML - * @param $data -API文档数据 - * @return string - */ - private function _getTopNavList($data) { - $html = ''; - return $html; - } - - /** - * 获取文档CSS - * @return string - */ - private function _getCss() { - $path = realpath($this->bootstrapCss); - if (!$path || !is_file($path)) { - return $this->customCss; - } - $bootstrapCss = file_get_contents($path); - if (empty($bootstrapCss)) { - return $this->customCss; - } - $this->customCss = '' . $this->customCss; - // $this->customCss = ' ' . $this->customCss; - return $this->customCss; - } - - /** - * 获取文档JS - * @return string - */ - private function _getJs() { - // $js = ''; - // $js .= ''; - // $this->customJs = $js . $this->customJs; - // return $this->customJs; - $bootstrapJs = realpath($this->bootstrapJs); - $jQueryJs = realpath($this->jQueryJs); - if (!$bootstrapJs || !$jQueryJs || !is_file($bootstrapJs) || !is_file($jQueryJs)) { - $this->customJs = ''; - return $this->customCss; - } - $bootstrapJs = file_get_contents($bootstrapJs); - $jQueryJs = file_get_contents($jQueryJs); - if (empty($bootstrapJs) || empty($jQueryJs)) { - $this->customJs = ''; - return $this->customJs; - } - $js = '' . ''; - $this->customJs = $js . $this->customJs; - return $this->customJs; - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/src/lib/ParseComment.php b/vendor/itxq/api-doc-php/src/lib/ParseComment.php deleted file mode 100644 index 643a3d49..00000000 --- a/vendor/itxq/api-doc-php/src/lib/ParseComment.php +++ /dev/null @@ -1,87 +0,0 @@ - $v) { - $comments[$k] = $v = trim($v); - if (strpos($v, '@') !== 0) { - continue; - } - $_parse = $this->_parseCommentLine($v); - if (!$_parse) { - continue; - } - $_type = $_parse['type']; - $_content = isset($_parse['content']) ? $_parse['content'] : ''; - if (in_array($_type, ['param', 'code', 'return'])) { - if (!isset($this->commentParams[$_type])) { - $this->commentParams[$_type] = []; - } - unset($_parse['type']); - $this->commentParams[$_type][] = $_parse; - } else { - $this->commentParams[$_type] = $_content; - } - } - return $this->commentParams; - } - - /** - * 解析注释中的参数 - * @param $line - 注释行 - * @return bool|array - 解析后的数组(解析失败返回false) - */ - private function _parseCommentLine($line) { - $line = explode(' ', $line); - $line[0] = substr($line[0], 1); - $class = new ParseLine(); - $action = 'parseLine' . Tools::underlineToHump($line[0]); - if (!method_exists($class, $action)) { - $action = 'parseLineTitle'; - } - return $class->$action($line); - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/src/lib/ParseLine.php b/vendor/itxq/api-doc-php/src/lib/ParseLine.php deleted file mode 100644 index 2e57ab25..00000000 --- a/vendor/itxq/api-doc-php/src/lib/ParseLine.php +++ /dev/null @@ -1,73 +0,0 @@ - isset($line[0]) ? $line[0] : '', 'content' => isset($line[1]) ? $line[1] : '']; - } - - /** - * 解析 param - * @param $line - * @return array - */ - public function parseLineParam($line) { - return [ - 'type' => isset($line[0]) ? $line[0] : '', - 'param_type' => isset($line[1]) ? $line[1] : '', - 'param_name' => isset($line[2]) ? $line[2] : '', - 'param_title' => isset($line[3]) ? $line[3] : '', - 'param_default' => isset($line[4]) ? $line[4] : '', - 'param_require' => isset($line[5]) ? $line[5] : '', - ]; - } - - /** - * 解析 code - * @param $line - * @return array - */ - public function parseLineCode($line) { - return [ - 'type' => isset($line[0]) ? $line[0] : '', - 'code' => isset($line[1]) ? $line[1] : '', - 'content' => isset($line[2]) ? $line[2] : '', - ]; - } - - /** - * 解析 return - * @param $line - * @return array - */ - public function parseLineReturn($line) { - return [ - 'type' => isset($line[0]) ? $line[0] : '', - 'return_type' => isset($line[1]) ? $line[1] : '', - 'return_name' => isset($line[2]) ? $line[2] : '', - 'return_title' => isset($line[3]) ? $line[3] : '', - ]; - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/src/lib/Tools.php b/vendor/itxq/api-doc-php/src/lib/Tools.php deleted file mode 100644 index ebf46a94..00000000 --- a/vendor/itxq/api-doc-php/src/lib/Tools.php +++ /dev/null @@ -1,82 +0,0 @@ -$name) ? $data->$name : $default; - } else if (is_array($data)) { - $value = isset($data[$name]) ? $data[$name] : $default; - } else { - $value = $default; - } - return $value; - } - - /** - * 文件下载 - * @param string - $docHtml - API文档HTML内容 - */ - public static function downloadFile($docHtml) { - set_time_limit(0); - //下载文件需要用到的头 - header('Content-type: application/octet-stream'); - header('Accept-Ranges: bytes'); - header('Content-Disposition: attachment; filename=api-doc_' . date('Y-m-d') . '.html'); - echo $docHtml; - exit(); - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/test/Api.php b/vendor/itxq/api-doc-php/test/Api.php deleted file mode 100644 index e9b2d43e..00000000 --- a/vendor/itxq/api-doc-php/test/Api.php +++ /dev/null @@ -1,49 +0,0 @@ - 1, 'msg' => '登录成功']); - } - - /** - * @title 用户注册API - * @url https://wwww.baidu.com/reg - * @method POST - * @param string username 账号 空 必须 - * @param string password 密码 空 必须 - * @param string password2 重复密码 空 必须 - * @code 1 成功 - * @code 2 失败 - * @return int code 状态码(具体参见状态码说明) - * @return string msg 提示信息 - */ - public function reg() { - return json_encode(['code' => 1, 'msg' => '注册成功']); - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/test/Api2.php b/vendor/itxq/api-doc-php/test/Api2.php deleted file mode 100644 index 4ae608d6..00000000 --- a/vendor/itxq/api-doc-php/test/Api2.php +++ /dev/null @@ -1,33 +0,0 @@ - 1, 'msg' => '获取信息成功', 'data' => ['uid' => 1, 'username' => 'admin']]); - } -} \ No newline at end of file diff --git a/vendor/itxq/api-doc-php/test/index.php b/vendor/itxq/api-doc-php/test/index.php deleted file mode 100644 index 74e25810..00000000 --- a/vendor/itxq/api-doc-php/test/index.php +++ /dev/null @@ -1,22 +0,0 @@ - ['Api', 'Api2'], // 要生成文档的类 - 'filter_method' => ['__construct'], // 要过滤的方法名称 -]; -$api = new \itxq\apidoc\BootstrapApiDoc($config); -$doc = $api->getHtml(); -exit($doc); - diff --git a/vendor/phpmailer/phpmailer/.editorconfig b/vendor/phpmailer/phpmailer/.editorconfig deleted file mode 100644 index a7c44ddb..00000000 --- a/vendor/phpmailer/phpmailer/.editorconfig +++ /dev/null @@ -1,15 +0,0 @@ -root = true - -[*] -charset = utf-8 -indent_size = 4 -indent_style = space -end_of_line = lf -insert_final_newline = true -trim_trailing_whitespace = true - -[*.md] -trim_trailing_whitespace = false - -[*.{yml,yaml}] -indent_size = 2 diff --git a/vendor/phpmailer/phpmailer/README.md b/vendor/phpmailer/phpmailer/README.md index 07fe8c8a..646649c9 100644 --- a/vendor/phpmailer/phpmailer/README.md +++ b/vendor/phpmailer/phpmailer/README.md @@ -20,25 +20,26 @@ - Multipart/alternative emails for mail clients that do not read HTML email - Add attachments, including inline - Support for UTF-8 content and 8bit, base64, binary, and quoted-printable encodings -- SMTP authentication with LOGIN, PLAIN, CRAM-MD5, and XOAUTH2 mechanisms over SMTPS and SMTP+STARTTLS transports +- Full UTF-8 support when using servers that support `SMTPUTF8`. +- Support for iCal events in multiparts and attachments +- SMTP authentication with `LOGIN`, `PLAIN`, `CRAM-MD5`, and `XOAUTH2` mechanisms over SMTPS and SMTP+STARTTLS transports - Validates email addresses automatically - Protects against header injection attacks - Error messages in over 50 languages! - DKIM and S/MIME signing support -- Compatible with PHP 5.5 and later, including PHP 8.2 +- Compatible with PHP 5.5 and later, including PHP 8.4 - Namespaced to prevent name clashes - Much more! ## Why you might need it -Many PHP developers need to send email from their code. The only PHP function that supports this directly is [`mail()`](https://www.php.net/manual/en/function.mail.php). However, it does not provide any assistance for making use of popular features such as encryption, authentication, HTML messages, and attachments. +Many PHP developers need to send email from their code. The only PHP function that supports this directly is [`mail()`](https://www.php.net/manual/en/function.mail.php). However, it does not provide any assistance for making use of popular features such as authentication, HTML messages, and attachments. Formatting email correctly is surprisingly difficult. There are myriad overlapping (and conflicting) standards, requiring tight adherence to horribly complicated formatting and encoding rules – the vast majority of code that you'll find online that uses the `mail()` function directly is just plain wrong, if not unsafe! The PHP `mail()` function usually sends via a local mail server, typically fronted by a `sendmail` binary on Linux, BSD, and macOS platforms, however, Windows usually doesn't include a local mail server; PHPMailer's integrated SMTP client allows email sending on all platforms without needing a local mail server. Be aware though, that the `mail()` function should be avoided when possible; it's both faster and [safer](https://exploitbox.io/paper/Pwning-PHP-Mail-Function-For-Fun-And-RCE.html) to use SMTP to localhost. *Please* don't be tempted to do it yourself – if you don't use PHPMailer, there are many other excellent libraries that -you should look at before rolling your own. Try [SwiftMailer](https://swiftmailer.symfony.com/) -, [Laminas/Mail](https://docs.laminas.dev/laminas-mail/), [ZetaComponents](https://github.com/zetacomponents/Mail), etc. +you should look at before rolling your own. Try [Symfony Mailer](https://symfony.com/doc/current/mailer.html), [Laminas/Mail](https://docs.laminas.dev/laminas-mail/), [ZetaComponents](https://github.com/zetacomponents/Mail), etc. ## License This software is distributed under the [LGPL 2.1](https://www.gnu.org/licenses/old-licenses/lgpl-2.1.html) license, along with the [GPL Cooperation Commitment](https://gplcc.github.io/gplcc/). Please read [LICENSE](https://github.com/PHPMailer/PHPMailer/blob/master/LICENSE) for information on the software availability and distribution. @@ -47,7 +48,7 @@ This software is distributed under the [LGPL 2.1](https://www.gnu.org/licenses/o PHPMailer is available on [Packagist](https://packagist.org/packages/phpmailer/phpmailer) (using semantic versioning), and installation via [Composer](https://getcomposer.org) is the recommended way to install PHPMailer. Just add this line to your `composer.json` file: ```json -"phpmailer/phpmailer": "^6.9.2" +"phpmailer/phpmailer": "^6.12.0" ``` or run @@ -74,7 +75,7 @@ require 'path/to/PHPMailer/src/PHPMailer.php'; require 'path/to/PHPMailer/src/SMTP.php'; ``` -If you're not using the `SMTP` class explicitly (you're probably not), you don't need a `use` line for the SMTP class. Even if you're not using exceptions, you do still need to load the `Exception` class as it is used internally. +If you're not using the `SMTP` class explicitly (you're probably not), you don't need a `use` line for it. Even if you're not using exceptions, you do still need to load the `Exception` class as it is used internally. ## Legacy versions PHPMailer 5.2 (which is compatible with PHP 5.0 — 7.0) is no longer supported, even for security updates. You will find the latest version of 5.2 in the [5.2-stable branch](https://github.com/PHPMailer/PHPMailer/tree/5.2-stable). If you're using PHP 5.5 or later (which you should be), switch to the 6.x releases. @@ -95,7 +96,7 @@ use PHPMailer\PHPMailer\PHPMailer; use PHPMailer\PHPMailer\SMTP; use PHPMailer\PHPMailer\Exception; -//Load Composer's autoloader +//Load Composer's autoloader (created by composer, not included with PHPMailer) require 'vendor/autoload.php'; //Create an instance; passing `true` enables exceptions diff --git a/vendor/phpmailer/phpmailer/VERSION b/vendor/phpmailer/phpmailer/VERSION index 5f54f91e..d4e6cb42 100644 --- a/vendor/phpmailer/phpmailer/VERSION +++ b/vendor/phpmailer/phpmailer/VERSION @@ -1 +1 @@ -6.9.3 +6.12.0 diff --git a/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt.php b/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt.php index f1ce946e..79a68026 100644 --- a/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt.php +++ b/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt.php @@ -3,25 +3,32 @@ /** * Portuguese (European) PHPMailer language file: refer to English translation for definitive list * @package PHPMailer - * @author Jonadabe + * @author João Vieira */ -$PHPMAILER_LANG['authenticate'] = 'Erro do SMTP: Não foi possível realizar a autenticação.'; -$PHPMAILER_LANG['connect_host'] = 'Erro do SMTP: Não foi possível realizar ligação com o servidor SMTP.'; -$PHPMAILER_LANG['data_not_accepted'] = 'Erro do SMTP: Os dados foram rejeitados.'; -$PHPMAILER_LANG['empty_message'] = 'A mensagem no e-mail está vazia.'; +$PHPMAILER_LANG['authenticate'] = 'Erro SMTP: Falha na autenticação.'; +$PHPMAILER_LANG['buggy_php'] = 'A sua versão do PHP tem um bug que pode causar mensagens corrompidas. Para resolver, utilize o envio por SMTP, desative a opção mail.add_x_header no ficheiro php.ini, mude para MacOS ou Linux, ou atualize o PHP para a versão 7.0.17+ ou 7.1.3+.'; +$PHPMAILER_LANG['connect_host'] = 'Erro SMTP: Não foi possível ligar ao servidor SMTP.'; +$PHPMAILER_LANG['data_not_accepted'] = 'Erro SMTP: Dados não aceites.'; +$PHPMAILER_LANG['empty_message'] = 'A mensagem de e-mail está vazia.'; $PHPMAILER_LANG['encoding'] = 'Codificação desconhecida: '; $PHPMAILER_LANG['execute'] = 'Não foi possível executar: '; -$PHPMAILER_LANG['file_access'] = 'Não foi possível aceder o ficheiro: '; -$PHPMAILER_LANG['file_open'] = 'Abertura do ficheiro: Não foi possível abrir o ficheiro: '; -$PHPMAILER_LANG['from_failed'] = 'Ocorreram falhas nos endereços dos seguintes remententes: '; -$PHPMAILER_LANG['instantiate'] = 'Não foi possível iniciar uma instância da função mail.'; -$PHPMAILER_LANG['invalid_address'] = 'Não foi enviado nenhum e-mail para o endereço de e-mail inválido: '; -$PHPMAILER_LANG['mailer_not_supported'] = ' mailer não é suportado.'; -$PHPMAILER_LANG['provide_address'] = 'Tem de fornecer pelo menos um endereço como destinatário do e-mail.'; -$PHPMAILER_LANG['recipients_failed'] = 'Erro do SMTP: O endereço do seguinte destinatário falhou: '; -$PHPMAILER_LANG['signing'] = 'Erro ao assinar: '; -$PHPMAILER_LANG['smtp_connect_failed'] = 'SMTP Connect() falhou.'; -$PHPMAILER_LANG['smtp_error'] = 'Erro de servidor SMTP: '; -$PHPMAILER_LANG['variable_set'] = 'Não foi possível definir ou redefinir a variável: '; $PHPMAILER_LANG['extension_missing'] = 'Extensão em falta: '; +$PHPMAILER_LANG['file_access'] = 'Não foi possível aceder ao ficheiro: '; +$PHPMAILER_LANG['file_open'] = 'Erro ao abrir o ficheiro: '; +$PHPMAILER_LANG['from_failed'] = 'O envio falhou para o seguinte endereço do remetente: '; +$PHPMAILER_LANG['instantiate'] = 'Não foi possível instanciar a função mail.'; +$PHPMAILER_LANG['invalid_address'] = 'Endereço de e-mail inválido: '; +$PHPMAILER_LANG['invalid_header'] = 'Nome ou valor do cabeçalho inválido.'; +$PHPMAILER_LANG['invalid_hostentry'] = 'Entrada de host inválida: '; +$PHPMAILER_LANG['invalid_host'] = 'Host inválido: '; +$PHPMAILER_LANG['mailer_not_supported'] = 'O cliente de e-mail não é suportado.'; +$PHPMAILER_LANG['provide_address'] = 'Deve fornecer pelo menos um endereço de destinatário.'; +$PHPMAILER_LANG['recipients_failed'] = 'Erro SMTP: Falha no envio para os seguintes destinatários: '; +$PHPMAILER_LANG['signing'] = 'Erro ao assinar: '; +$PHPMAILER_LANG['smtp_code'] = 'Código SMTP: '; +$PHPMAILER_LANG['smtp_code_ex'] = 'Informações adicionais SMTP: '; +$PHPMAILER_LANG['smtp_connect_failed'] = 'Falha na função SMTP connect().'; +$PHPMAILER_LANG['smtp_detail'] = 'Detalhes: '; +$PHPMAILER_LANG['smtp_error'] = 'Erro do servidor SMTP: '; +$PHPMAILER_LANG['variable_set'] = 'Não foi possível definir ou redefinir a variável: '; diff --git a/vendor/phpmailer/phpmailer/src/PHPMailer.php b/vendor/phpmailer/phpmailer/src/PHPMailer.php index 4a6077c0..4b3f34c8 100644 --- a/vendor/phpmailer/phpmailer/src/PHPMailer.php +++ b/vendor/phpmailer/phpmailer/src/PHPMailer.php @@ -580,6 +580,10 @@ class PHPMailer * May be a callable to inject your own validator, but there are several built-in validators. * The default validator uses PHP's FILTER_VALIDATE_EMAIL filter_var option. * + * If CharSet is UTF8, the validator is left at the default value, + * and you send to addresses that use non-ASCII local parts, then + * PHPMailer automatically changes to the 'eai' validator. + * * @see PHPMailer::validateAddress() * * @var string|callable @@ -659,6 +663,14 @@ class PHPMailer */ protected $ReplyToQueue = []; + /** + * Whether the need for SMTPUTF8 has been detected. Set by + * preSend() if necessary. + * + * @var bool + */ + public $UseSMTPUTF8 = false; + /** * The array of attachments. * @@ -756,7 +768,7 @@ class PHPMailer * * @var string */ - const VERSION = '6.9.3'; + const VERSION = '6.12.0'; /** * Error severity: message only, continue processing. @@ -1110,19 +1122,22 @@ class PHPMailer $params = [$kind, $address, $name]; //Enqueue addresses with IDN until we know the PHPMailer::$CharSet. //Domain is assumed to be whatever is after the last @ symbol in the address - if (static::idnSupported() && $this->has8bitChars(substr($address, ++$pos))) { - if ('Reply-To' !== $kind) { - if (!array_key_exists($address, $this->RecipientsQueue)) { - $this->RecipientsQueue[$address] = $params; + if ($this->has8bitChars(substr($address, ++$pos))) { + if (static::idnSupported()) { + if ('Reply-To' !== $kind) { + if (!array_key_exists($address, $this->RecipientsQueue)) { + $this->RecipientsQueue[$address] = $params; + + return true; + } + } elseif (!array_key_exists($address, $this->ReplyToQueue)) { + $this->ReplyToQueue[$address] = $params; return true; } - } elseif (!array_key_exists($address, $this->ReplyToQueue)) { - $this->ReplyToQueue[$address] = $params; - - return true; } - + //We have an 8-bit domain, but we are missing the necessary extensions to support it + //Or we are already sending to this address return false; } @@ -1160,6 +1175,15 @@ class PHPMailer */ protected function addAnAddress($kind, $address, $name = '') { + if ( + self::$validator === 'php' && + ((bool) preg_match('/[\x80-\xFF]/', $address)) + ) { + //The caller has not altered the validator and is sending to an address + //with UTF-8, so assume that they want UTF-8 support instead of failing + $this->CharSet = self::CHARSET_UTF8; + self::$validator = 'eai'; + } if (!in_array($kind, ['to', 'cc', 'bcc', 'Reply-To'])) { $error_message = sprintf( '%s: %s', @@ -1362,6 +1386,7 @@ class PHPMailer * * `pcre` Use old PCRE implementation; * * `php` Use PHP built-in FILTER_VALIDATE_EMAIL; * * `html5` Use the pattern given by the HTML5 spec for 'email' type form input elements. + * * `eai` Use a pattern similar to the HTML5 spec for 'email' and to firefox, extended to support EAI (RFC6530). * * `noregex` Don't use a regex: super fast, really dumb. * Alternatively you may pass in a callable to inject your own validator, for example: * @@ -1432,6 +1457,24 @@ class PHPMailer '[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/sD', $address ); + case 'eai': + /* + * This is the pattern used in the HTML5 spec for validation of 'email' type + * form input elements (as above), modified to accept Unicode email addresses. + * This is also more lenient than Firefox' html5 spec, in order to make the regex faster. + * 'eai' is an acronym for Email Address Internationalization. + * This validator is selected automatically if you attempt to use recipient addresses + * that contain Unicode characters in the local part. + * + * @see https://html.spec.whatwg.org/#e-mail-state-(type=email) + * @see https://en.wikipedia.org/wiki/International_email + */ + return (bool) preg_match( + '/^[-\p{L}\p{N}\p{M}.!#$%&\'*+\/=?^_`{|}~]+@[\p{L}\p{N}\p{M}](?:[\p{L}\p{N}\p{M}-]{0,61}' . + '[\p{L}\p{N}\p{M}])?(?:\.[\p{L}\p{N}\p{M}]' . + '(?:[-\p{L}\p{N}\p{M}]{0,61}[\p{L}\p{N}\p{M}])?)*$/usD', + $address + ); case 'php': default: return filter_var($address, FILTER_VALIDATE_EMAIL) !== false; @@ -1565,9 +1608,26 @@ class PHPMailer $this->error_count = 0; //Reset errors $this->mailHeader = ''; + //The code below tries to support full use of Unicode, + //while remaining compatible with legacy SMTP servers to + //the greatest degree possible: If the message uses + //Unicode in the local parts of any addresses, it is sent + //using SMTPUTF8. If not, it it sent using + //punycode-encoded domains and plain SMTP. + if ( + static::CHARSET_UTF8 === strtolower($this->CharSet) && + ($this->anyAddressHasUnicodeLocalPart($this->RecipientsQueue) || + $this->anyAddressHasUnicodeLocalPart(array_keys($this->all_recipients)) || + $this->anyAddressHasUnicodeLocalPart($this->ReplyToQueue) || + $this->addressHasUnicodeLocalPart($this->From)) + ) { + $this->UseSMTPUTF8 = true; + } //Dequeue recipient and Reply-To addresses with IDN foreach (array_merge($this->RecipientsQueue, $this->ReplyToQueue) as $params) { - $params[1] = $this->punyencodeAddress($params[1]); + if (!$this->UseSMTPUTF8) { + $params[1] = $this->punyencodeAddress($params[1]); + } call_user_func_array([$this, 'addAnAddress'], $params); } if (count($this->to) + count($this->cc) + count($this->bcc) < 1) { @@ -2058,6 +2118,11 @@ class PHPMailer if (!$this->smtpConnect($this->SMTPOptions)) { throw new Exception($this->lang('smtp_connect_failed'), self::STOP_CRITICAL); } + //If we have recipient addresses that need Unicode support, + //but the server doesn't support it, stop here + if ($this->UseSMTPUTF8 && !$this->smtp->getServerExt('SMTPUTF8')) { + throw new Exception($this->lang('no_smtputf8'), self::STOP_CRITICAL); + } //Sender already validated in preSend() if ('' === $this->Sender) { $smtp_from = $this->From; @@ -2159,6 +2224,7 @@ class PHPMailer $this->smtp->setDebugLevel($this->SMTPDebug); $this->smtp->setDebugOutput($this->Debugoutput); $this->smtp->setVerp($this->do_verp); + $this->smtp->setSMTPUTF8($this->UseSMTPUTF8); if ($this->Host === null) { $this->Host = 'localhost'; } @@ -2356,6 +2422,7 @@ class PHPMailer 'smtp_detail' => 'Detail: ', 'smtp_error' => 'SMTP server error: ', 'variable_set' => 'Cannot set or reset variable: ', + 'no_smtputf8' => 'Server does not support SMTPUTF8 needed to send to Unicode addresses', ]; if (empty($lang_path)) { //Calculate an absolute path so it can work if CWD is not here @@ -2870,7 +2937,9 @@ class PHPMailer $bodyEncoding = $this->Encoding; $bodyCharSet = $this->CharSet; //Can we do a 7-bit downgrade? - if (static::ENCODING_8BIT === $bodyEncoding && !$this->has8bitChars($this->Body)) { + if ($this->UseSMTPUTF8) { + $bodyEncoding = static::ENCODING_8BIT; + } elseif (static::ENCODING_8BIT === $bodyEncoding && !$this->has8bitChars($this->Body)) { $bodyEncoding = static::ENCODING_7BIT; //All ISO 8859, Windows codepage and UTF-8 charsets are ascii compatible up to 7-bit $bodyCharSet = static::CHARSET_ASCII; @@ -3507,7 +3576,8 @@ class PHPMailer /** * Encode a header value (not including its label) optimally. * Picks shortest of Q, B, or none. Result includes folding if needed. - * See RFC822 definitions for phrase, comment and text positions. + * See RFC822 definitions for phrase, comment and text positions, + * and RFC2047 for inline encodings. * * @param string $str The header value to encode * @param string $position What context the string will be used in @@ -3516,6 +3586,11 @@ class PHPMailer */ public function encodeHeader($str, $position = 'text') { + $position = strtolower($position); + if ($this->UseSMTPUTF8 && !("comment" === $position)) { + return trim(static::normalizeBreaks($str)); + } + $matchcount = 0; switch (strtolower($position)) { case 'phrase': @@ -4180,7 +4255,7 @@ class PHPMailer if ('smtp' === $this->Mailer && null !== $this->smtp) { $lasterror = $this->smtp->getError(); if (!empty($lasterror['error'])) { - $msg .= $this->lang('smtp_error') . $lasterror['error']; + $msg .= ' ' . $this->lang('smtp_error') . $lasterror['error']; if (!empty($lasterror['detail'])) { $msg .= ' ' . $this->lang('smtp_detail') . $lasterror['detail']; } @@ -4267,6 +4342,45 @@ class PHPMailer return filter_var('https://' . $host, FILTER_VALIDATE_URL) !== false; } + /** + * Check whether the supplied address uses Unicode in the local part. + * + * @return bool + */ + protected function addressHasUnicodeLocalPart($address) + { + return (bool) preg_match('/[\x80-\xFF].*@/', $address); + } + + /** + * Check whether any of the supplied addresses use Unicode in the local part. + * + * @return bool + */ + protected function anyAddressHasUnicodeLocalPart($addresses) + { + foreach ($addresses as $address) { + if (is_array($address)) { + $address = $address[0]; + } + if ($this->addressHasUnicodeLocalPart($address)) { + return true; + } + } + return false; + } + + /** + * Check whether the message requires SMTPUTF8 based on what's known so far. + * + * @return bool + */ + public function needsSMTPUTF8() + { + return $this->UseSMTPUTF8; + } + + /** * Get an error message in the current language. * diff --git a/vendor/phpmailer/phpmailer/src/POP3.php b/vendor/phpmailer/phpmailer/src/POP3.php index 376fae2a..4d3e8db2 100644 --- a/vendor/phpmailer/phpmailer/src/POP3.php +++ b/vendor/phpmailer/phpmailer/src/POP3.php @@ -46,7 +46,7 @@ class POP3 * * @var string */ - const VERSION = '6.9.3'; + const VERSION = '6.12.0'; /** * Default POP3 port number. diff --git a/vendor/phpmailer/phpmailer/src/SMTP.php b/vendor/phpmailer/phpmailer/src/SMTP.php index b4eff404..d8749c5b 100644 --- a/vendor/phpmailer/phpmailer/src/SMTP.php +++ b/vendor/phpmailer/phpmailer/src/SMTP.php @@ -35,7 +35,7 @@ class SMTP * * @var string */ - const VERSION = '6.9.3'; + const VERSION = '6.12.0'; /** * SMTP line break constant. @@ -159,6 +159,15 @@ class SMTP */ public $do_verp = false; + /** + * Whether to use SMTPUTF8. + * + * @see https://www.rfc-editor.org/rfc/rfc6531 + * + * @var bool + */ + public $do_smtputf8 = false; + /** * The timeout value for connection, in seconds. * Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2. @@ -913,7 +922,15 @@ class SMTP * $from. Returns true if successful or false otherwise. If True * the mail transaction is started and then one or more recipient * commands may be called followed by a data command. - * Implements RFC 821: MAIL FROM: . + * Implements RFC 821: MAIL FROM: and + * two extensions, namely XVERP and SMTPUTF8. + * + * The server's EHLO response is not checked. If use of either + * extensions is enabled even though the server does not support + * that, mail submission will fail. + * + * XVERP is documented at https://www.postfix.org/VERP_README.html + * and SMTPUTF8 is specified in RFC 6531. * * @param string $from Source address of this message * @@ -922,10 +939,11 @@ class SMTP public function mail($from) { $useVerp = ($this->do_verp ? ' XVERP' : ''); + $useSmtputf8 = ($this->do_smtputf8 ? ' SMTPUTF8' : ''); return $this->sendCommand( 'MAIL FROM', - 'MAIL FROM:<' . $from . '>' . $useVerp, + 'MAIL FROM:<' . $from . '>' . $useSmtputf8 . $useVerp, 250 ); } @@ -1364,6 +1382,26 @@ class SMTP return $this->do_verp; } + /** + * Enable or disable use of SMTPUTF8. + * + * @param bool $enabled + */ + public function setSMTPUTF8($enabled = false) + { + $this->do_smtputf8 = $enabled; + } + + /** + * Get SMTPUTF8 use. + * + * @return bool + */ + public function getSMTPUTF8() + { + return $this->do_smtputf8; + } + /** * Set error messages and codes. * diff --git a/vendor/phpoffice/math/.github/workflows/php.yml b/vendor/phpoffice/math/.github/workflows/php.yml index df807baa..5390049e 100644 --- a/vendor/phpoffice/math/.github/workflows/php.yml +++ b/vendor/phpoffice/math/.github/workflows/php.yml @@ -45,6 +45,7 @@ jobs: - '8.1' - '8.2' - '8.3' + - '8.4' steps: - name: Setup PHP uses: shivammathur/setup-php@v2 @@ -75,6 +76,7 @@ jobs: - '8.1' - '8.2' - '8.3' + - '8.4' steps: - name: Setup PHP uses: shivammathur/setup-php@v2 diff --git a/vendor/phpoffice/math/docs/index.md b/vendor/phpoffice/math/docs/index.md index 340b0dcc..80b4333c 100644 --- a/vendor/phpoffice/math/docs/index.md +++ b/vendor/phpoffice/math/docs/index.md @@ -48,7 +48,7 @@ Math is an open source project licensed under the terms of [MIT](https://github. | **Simple** | Fraction | :material-check: | :material-check: | | | Superscript | :material-check: | | | **Architectural** | Row | :material-check: | :material-check: | -| | Semantics | | | +| | Semantics | :material-check: | | ## Contributing diff --git a/vendor/phpoffice/math/mkdocs.yml b/vendor/phpoffice/math/mkdocs.yml index 972d2741..198c5fe5 100644 --- a/vendor/phpoffice/math/mkdocs.yml +++ b/vendor/phpoffice/math/mkdocs.yml @@ -57,7 +57,9 @@ nav: - Writers: 'usage/writers.md' - Credits: 'credits.md' - Releases: - - '0.1.0 (WIP)': 'changes/0.1.0.md' + - '0.3.0 (WIP)': 'changes/0.3.0.md' + - '0.2.0': 'changes/0.2.0.md' + - '0.1.0': 'changes/0.1.0.md' - Developers: - 'Coveralls': 'https://coveralls.io/github/PHPOffice/Math' - 'Code Coverage': 'coverage/index.html' diff --git a/vendor/phpoffice/math/src/Math/Reader/MathML.php b/vendor/phpoffice/math/src/Math/Reader/MathML.php index 58d93935..cf1edb8d 100644 --- a/vendor/phpoffice/math/src/Math/Reader/MathML.php +++ b/vendor/phpoffice/math/src/Math/Reader/MathML.php @@ -10,6 +10,7 @@ use PhpOffice\Math\Element; use PhpOffice\Math\Exception\InvalidInputException; use PhpOffice\Math\Exception\NotImplementedException; use PhpOffice\Math\Math; +use PhpOffice\Math\Reader\Security\XmlScanner; class MathML implements ReaderInterface { @@ -22,8 +23,17 @@ class MathML implements ReaderInterface /** @var DOMXPath */ private $xpath; + /** @var XmlScanner */ + private $xmlScanner; + + public function __construct() + { + $this->xmlScanner = XmlScanner::getInstance(); + } + public function read(string $content): ?Math { + $content = $this->xmlScanner->scan($content); $content = str_replace( [ '⁢', @@ -35,7 +45,7 @@ class MathML implements ReaderInterface ); $this->dom = new DOMDocument(); - $this->dom->loadXML($content, LIBXML_DTDLOAD); + $this->dom->loadXML($content); $this->math = new Math(); $this->parseNode(null, $this->math); diff --git a/vendor/phpoffice/math/src/Math/Writer/MathML.php b/vendor/phpoffice/math/src/Math/Writer/MathML.php index d8905f00..34a20dc3 100644 --- a/vendor/phpoffice/math/src/Math/Writer/MathML.php +++ b/vendor/phpoffice/math/src/Math/Writer/MathML.php @@ -40,6 +40,26 @@ class MathML implements WriterInterface { $tagName = $this->getElementTagName($element); + // Element\AbstractGroupElement + if ($element instanceof Element\Semantics) { + $this->output->startElement($tagName); + // Write elements + foreach ($element->getElements() as $childElement) { + $this->writeElementItem($childElement); + } + + // Write annotations + foreach ($element->getAnnotations() as $encoding => $annotation) { + $this->output->startElement('annotation'); + $this->output->writeAttribute('encoding', $encoding); + $this->output->text($annotation); + $this->output->endElement(); + } + $this->output->endElement(); + + return; + } + // Element\AbstractGroupElement if ($element instanceof Element\AbstractGroupElement) { $this->output->startElement($tagName); @@ -121,6 +141,9 @@ class MathML implements WriterInterface if ($element instanceof Element\Operator) { return 'mo'; } + if ($element instanceof Element\Semantics) { + return 'semantics'; + } throw new NotImplementedException(sprintf( '%s : The element of the class `%s` has no tag name', diff --git a/vendor/phpoffice/math/tests/Math/Reader/MathMLTest.php b/vendor/phpoffice/math/tests/Math/Reader/MathMLTest.php index db9b174a..a17c179c 100644 --- a/vendor/phpoffice/math/tests/Math/Reader/MathMLTest.php +++ b/vendor/phpoffice/math/tests/Math/Reader/MathMLTest.php @@ -7,6 +7,7 @@ namespace Tests\PhpOffice\Math\Reader; use PhpOffice\Math\Element; use PhpOffice\Math\Exception\InvalidInputException; use PhpOffice\Math\Exception\NotImplementedException; +use PhpOffice\Math\Exception\SecurityException; use PhpOffice\Math\Math; use PhpOffice\Math\Reader\MathML; use PHPUnit\Framework\TestCase; @@ -294,4 +295,15 @@ class MathMLTest extends TestCase $reader = new MathML(); $math = $reader->read($content); } + + public function testReadSecurity(): void + { + $this->expectException(SecurityException::class); + $this->expectExceptionMessage('Detected use of ENTITY in XML, loading aborted to prevent XXE/XEE attacks'); + + $content = ' M'; + + $reader = new MathML(); + $math = $reader->read($content); + } } diff --git a/vendor/phpoffice/math/tests/Math/Writer/MathMLTest.php b/vendor/phpoffice/math/tests/Math/Writer/MathMLTest.php index 06aac383..90724856 100644 --- a/vendor/phpoffice/math/tests/Math/Writer/MathMLTest.php +++ b/vendor/phpoffice/math/tests/Math/Writer/MathMLTest.php @@ -80,6 +80,35 @@ class MathMLTest extends WriterTestCase $this->assertIsSchemaMathMLValid($output); } + public function testWriteSemantics(): void + { + $opTimes = new Element\Operator('⁢'); + + $math = new Math(); + + $semantics = new Element\Semantics(); + $semantics->add(new Element\Identifier('y')); + $semantics->addAnnotation('application/x-tex', ' y '); + + $math->add($semantics); + + $writer = new MathML(); + $output = $writer->write($math); + + $expected = '' + . PHP_EOL + . '' + . '' + . '' + . 'y' + . ' y ' + . '' + . '' + . PHP_EOL; + $this->assertEquals($expected, $output); + $this->assertIsSchemaMathMLValid($output); + } + public function testWriteNotImplemented(): void { $this->expectException(NotImplementedException::class); diff --git a/vendor/phpoffice/phpword/LICENSE b/vendor/phpoffice/phpword/LICENSE index 8a1acaea..aebd12b0 100644 --- a/vendor/phpoffice/phpword/LICENSE +++ b/vendor/phpoffice/phpword/LICENSE @@ -1,6 +1,6 @@ PHPWord, a pure PHP library for reading and writing word processing documents. -Copyright (c) 2010-2016 PHPWord. +Copyright (c) 2010-2025 PHPWord. PHPWord is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License version 3 as published by diff --git a/vendor/phpoffice/phpword/README.md b/vendor/phpoffice/phpword/README.md index 11bcd152..e080d32d 100644 --- a/vendor/phpoffice/phpword/README.md +++ b/vendor/phpoffice/phpword/README.md @@ -1,11 +1,11 @@ # ![PHPWord](https://rawgit.com/PHPOffice/PHPWord/develop/docs/images/phpword.svg "PHPWord") -[![Latest Stable Version](https://poser.pugx.org/phpoffice/phpword/v/stable.png)](https://packagist.org/packages/phpoffice/phpword) +[![Latest Stable Version](https://poser.pugx.org/phpoffice/phpword/v)](https://packagist.org/packages/phpoffice/phpword) [![Coverage Status](https://coveralls.io/repos/github/PHPOffice/PHPWord/badge.svg?branch=master)](https://coveralls.io/github/PHPOffice/PHPWord?branch=master) -[![Total Downloads](https://poser.pugx.org/phpoffice/phpword/downloads.png)](https://packagist.org/packages/phpoffice/phpword) -[![License](https://poser.pugx.org/phpoffice/phpword/license.png)](https://packagist.org/packages/phpoffice/phpword) -[![CI](https://github.com/PHPOffice/PHPWord/actions/workflows/ci.yml/badge.svg)](https://github.com/PHPOffice/PHPWord/actions/workflows/ci.yml) -[![Join the chat at https://gitter.im/PHPOffice/PHPWord](https://img.shields.io/badge/GITTER-join%20chat-green.svg)](https://gitter.im/PHPOffice/PHPWord) +[![Total Downloads](https://poser.pugx.org/phpoffice/phpword/downloads)](https://packagist.org/packages/phpoffice/phpword) +[![License](https://poser.pugx.org/phpoffice/phpword/license)](https://packagist.org/packages/phpoffice/phpword) + +Branch Master : [![PHPWord](https://github.com/PHPOffice/PHPWord/actions/workflows/php.yml/badge.svg?branch=master)](https://github.com/PHPOffice/PHPWord/actions/workflows/php.yml) PHPWord is a library written in pure PHP that provides a set of classes to write to and read from different document file formats. The current version of PHPWord supports Microsoft [Office Open XML](http://en.wikipedia.org/wiki/Office_Open_XML) (OOXML or OpenXML), OASIS [Open Document Format for Office Applications](http://en.wikipedia.org/wiki/OpenDocument) (OpenDocument or ODF), [Rich Text Format](http://en.wikipedia.org/wiki/Rich_Text_Format) (RTF), HTML, and PDF. @@ -81,7 +81,6 @@ The following is a basic usage example of the PHPWord library. ```php =7.0", - "tecnickcom/tcpdf": "^6.5", - "symfony/process": "^4.4 || ^5.0", + "dompdf/dompdf": "^2.0 || ^3.0", "friendsofphp/php-cs-fixer": "^3.3", - "phpstan/phpstan-phpunit": "@stable" + "mpdf/mpdf": "^7.0 || ^8.0", + "phpmd/phpmd": "^2.13", + "phpstan/phpstan": "^0.12.88 || ^1.0.0", + "phpstan/phpstan-phpunit": "^1.0 || ^2.0", + "phpunit/phpunit": ">=7.0", + "symfony/process": "^4.4 || ^5.0", + "tecnickcom/tcpdf": "^6.5" }, "suggest": { - "ext-zip": "Allows writing OOXML and ODF", - "ext-gd2": "Allows adding images", "ext-xmlwriter": "Allows writing OOXML and ODF", "ext-xsl": "Allows applying XSL style sheet to headers, to main document part, and to footers of an OOXML template", "dompdf/dompdf": "Allows writing PDF" diff --git a/vendor/phpoffice/phpword/mkdocs.yml b/vendor/phpoffice/phpword/mkdocs.yml index dfabbb19..97c84211 100644 --- a/vendor/phpoffice/phpword/mkdocs.yml +++ b/vendor/phpoffice/phpword/mkdocs.yml @@ -63,6 +63,7 @@ nav: - OLE Object: 'usage/elements/oleobject.md' - Page Break: 'usage/elements/pagebreak.md' - Preserve Text: 'usage/elements/preservetext.md' + - Ruby: 'usage/elements/ruby.md' - Text: 'usage/elements/text.md' - TextBox: 'usage/elements/textbox.md' - Text Break: 'usage/elements/textbreak.md' @@ -87,7 +88,9 @@ nav: - Credits: 'credits.md' - Releases: - '1.x': - - '1.3.0 (WIP)': 'changes/1.x/1.3.0.md' + - '1.5.0 (WIP)': 'changes/1.x/1.5.0.md' + - '1.4.0': 'changes/1.x/1.4.0.md' + - '1.3.0': 'changes/1.x/1.3.0.md' - '1.2.0': 'changes/1.x/1.2.0.md' - '1.1.0': 'changes/1.x/1.1.0.md' - '1.0.0': 'changes/1.x/1.0.0.md' diff --git a/vendor/phpoffice/phpword/phpstan-baseline.neon b/vendor/phpoffice/phpword/phpstan-baseline.neon index 909718b8..86a54276 100644 --- a/vendor/phpoffice/phpword/phpstan-baseline.neon +++ b/vendor/phpoffice/phpword/phpstan-baseline.neon @@ -375,11 +375,6 @@ parameters: count: 1 path: src/PhpWord/Shared/Drawing.php - - - message: "#^Binary operation \"\\*\" between string and 50 results in an error\\.$#" - count: 1 - path: src/PhpWord/Shared/Html.php - - message: "#^Call to an undefined method DOMNode\\:\\:getAttribute\\(\\)\\.$#" count: 1 @@ -435,6 +430,11 @@ parameters: count: 1 path: src/PhpWord/Shared/Html.php + - + message: "#^Method PhpOffice\\\\PhpWord\\\\Shared\\\\Html\\:\\:parseRuby\\(\\) has no return type specified\\.$#" + count: 1 + path: src/PhpWord/Shared/Html.php + - message: "#^Method PhpOffice\\\\PhpWord\\\\Shared\\\\Html\\:\\:parseStyleDeclarations\\(\\) has no return type specified\\.$#" count: 1 @@ -447,7 +447,7 @@ parameters: - message: "#^Parameter \\#1 \\$attribute of static method PhpOffice\\\\PhpWord\\\\Shared\\\\Html\\:\\:parseStyle\\(\\) expects DOMAttr, DOMNode given\\.$#" - count: 1 + count: 3 path: src/PhpWord/Shared/Html.php - @@ -685,11 +685,6 @@ parameters: count: 1 path: src/PhpWord/Style/Cell.php - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Cell\\:\\:\\$shading is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Cell.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Style\\\\Chart\\:\\:getMajorTickPosition\\(\\) has no return type specified\\.$#" count: 1 @@ -760,41 +755,6 @@ parameters: count: 1 path: src/PhpWord/Style/Font.php - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$allCaps is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$doubleStrikethrough is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$lang is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$paragraph is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$shading is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$smallCaps is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Font\\:\\:\\$strikethrough is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Font.php - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Line\\:\\:\\$weight \\(int\\) does not accept float\\|int\\|null\\.$#" count: 1 @@ -815,21 +775,6 @@ parameters: count: 1 path: src/PhpWord/Style/Paragraph.php - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Paragraph\\:\\:\\$indentation is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Paragraph.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Paragraph\\:\\:\\$shading is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Paragraph.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Paragraph\\:\\:\\$spacing is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Paragraph.php - - message: "#^Result of && is always false\\.$#" count: 1 @@ -840,36 +785,6 @@ parameters: count: 1 path: src/PhpWord/Style/Section.php - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Section\\:\\:\\$lineNumbering is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Section.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Shape\\:\\:\\$extrusion is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Shape.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Shape\\:\\:\\$fill is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Shape.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Shape\\:\\:\\$frame is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Shape.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Shape\\:\\:\\$outline is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Shape.php - - - - message: "#^Property PhpOffice\\\\PhpWord\\\\Style\\\\Shape\\:\\:\\$shadow is never written, only read\\.$#" - count: 1 - path: src/PhpWord/Style/Shape.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Style\\\\TOC\\:\\:setTabLeader\\(\\) should return PhpOffice\\\\PhpWord\\\\Style\\\\TOC but returns PhpOffice\\\\PhpWord\\\\Style\\\\Tab\\.$#" count: 1 @@ -1120,11 +1035,6 @@ parameters: count: 1 path: src/PhpWord/Writer/AbstractWriter.php - - - message: "#^PHPDoc tag @param has invalid value \\(\\\\PhpOffice\\\\PhpWord\\\\PhpWord\\)\\: Unexpected token \"\\\\n \\*\", expected variable at offset 78$#" - count: 1 - path: src/PhpWord/Writer/AbstractWriter.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\HTML\\\\Element\\\\AbstractElement\\:\\:write\\(\\) has no return type specified\\.$#" count: 1 @@ -1146,14 +1056,14 @@ parameters: path: src/PhpWord/Writer/ODText/Element/Table.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\ODText\\\\Element\\\\Text\\:\\:replacetabs\\(\\) has parameter \\$text with no type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\ODText\\\\Element\\\\AbstractElement\\:\\:replaceTabs\\(\\) has parameter \\$text with no type specified\\.$#" count: 1 - path: src/PhpWord/Writer/ODText/Element/Text.php + path: src/PhpWord/Writer/ODText/Element/AbstractElement.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\ODText\\\\Element\\\\Text\\:\\:replacetabs\\(\\) has parameter \\$xmlWriter with no type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\ODText\\\\Element\\\\AbstractElement\\:\\:replaceTabs\\(\\) has parameter \\$xmlWriter with no type specified\\.$#" count: 1 - path: src/PhpWord/Writer/ODText/Element/Text.php + path: src/PhpWord/Writer/ODText/Element/AbstractElement.php - message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\ODText\\\\Element\\\\Text\\:\\:writeChangeInsertion\\(\\) has parameter \\$start with no type specified\\.$#" @@ -1315,11 +1225,6 @@ parameters: count: 1 path: src/PhpWord/Writer/RTF/Style/Border.php - - - message: "#^PHPDoc tag @param has invalid value \\(\\\\PhpOffice\\\\PhpWord\\\\PhpWord\\)\\: Unexpected token \"\\\\n \", expected variable at offset 86$#" - count: 1 - path: src/PhpWord/Writer/Word2007.php - - message: "#^Method PhpOffice\\\\PhpWord\\\\Writer\\\\Word2007\\\\Element\\\\AbstractElement\\:\\:write\\(\\) has no return type specified\\.$#" count: 1 @@ -1426,29 +1331,29 @@ parameters: path: tests/PhpWordTests/AbstractTestReader.php - - message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbeddedTest\\:\\:getBaseUrl\\(\\) has no return type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbedded\\:\\:getBaseUrl\\(\\) has no return type specified\\.$#" count: 1 - path: tests/PhpWordTests/AbstractWebServerEmbeddedTest.php + path: tests/PhpWordTests/AbstractWebServerEmbedded.php - - message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbeddedTest\\:\\:getRemoteBmpImageUrl\\(\\) has no return type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbedded\\:\\:getRemoteBmpImageUrl\\(\\) has no return type specified\\.$#" count: 1 - path: tests/PhpWordTests/AbstractWebServerEmbeddedTest.php + path: tests/PhpWordTests/AbstractWebServerEmbedded.php - - message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbeddedTest\\:\\:getRemoteGifImageUrl\\(\\) has no return type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbedded\\:\\:getRemoteGifImageUrl\\(\\) has no return type specified\\.$#" count: 1 - path: tests/PhpWordTests/AbstractWebServerEmbeddedTest.php + path: tests/PhpWordTests/AbstractWebServerEmbedded.php - - message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbeddedTest\\:\\:getRemoteImageUrl\\(\\) has no return type specified\\.$#" + message: "#^Method PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbedded\\:\\:getRemoteImageUrl\\(\\) has no return type specified\\.$#" count: 1 - path: tests/PhpWordTests/AbstractWebServerEmbeddedTest.php + path: tests/PhpWordTests/AbstractWebServerEmbedded.php - - message: "#^Property PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbeddedTest\\:\\:\\$httpServer has no type specified\\.$#" + message: "#^Property PhpOffice\\\\PhpWordTests\\\\AbstractWebServerEmbedded\\:\\:\\$httpServer has no type specified\\.$#" count: 1 - path: tests/PhpWordTests/AbstractWebServerEmbeddedTest.php + path: tests/PhpWordTests/AbstractWebServerEmbedded.php - message: "#^Parameter \\#1 \\$width of class PhpOffice\\\\PhpWord\\\\Element\\\\Cell constructor expects int\\|null, string given\\.$#" @@ -1789,6 +1694,11 @@ parameters: message: "#^Cannot access property \\$length on DOMNodeList\\\\|false\\.$#" count: 9 path: tests/PhpWordTests/Writer/HTML/ElementTest.php + + - + message: "#^Cannot access property \\$length on DOMNodeList\\\\|false\\.$#" + count: 2 + path: tests/PhpWordTests/Writer/HTML/Element/RubyTest.php - message: "#^Cannot call method item\\(\\) on DOMNodeList\\\\|false\\.$#" diff --git a/vendor/phpoffice/phpword/phpword.ini.dist b/vendor/phpoffice/phpword/phpword.ini.dist index f3f66dbe..21d3b506 100644 --- a/vendor/phpoffice/phpword/phpword.ini.dist +++ b/vendor/phpoffice/phpword/phpword.ini.dist @@ -14,6 +14,7 @@ outputEscapingEnabled = false defaultFontName = Arial defaultFontSize = 10 +defaultFontColor = 000000 [Paper] diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/AbstractCollection.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/AbstractCollection.php index 646489d8..97c2c45d 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/AbstractCollection.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/AbstractCollection.php @@ -1,4 +1,5 @@ */ class Bookmarks extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/Charts.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/Charts.php index 7c2dfbab..ef1c6597 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/Charts.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/Charts.php @@ -1,4 +1,5 @@ */ class Charts extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/Comments.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/Comments.php index 5fa4020a..4f139435 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/Comments.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/Comments.php @@ -1,4 +1,5 @@ */ class Comments extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/Endnotes.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/Endnotes.php index 09903b1b..3de1ad22 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/Endnotes.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/Endnotes.php @@ -1,4 +1,5 @@ */ class Endnotes extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/Footnotes.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/Footnotes.php index 0387fce3..804a45c8 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/Footnotes.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/Footnotes.php @@ -1,4 +1,5 @@ */ class Footnotes extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/Collection/Titles.php b/vendor/phpoffice/phpword/src/PhpWord/Collection/Titles.php index 543aabda..1a943697 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Collection/Titles.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Collection/Titles.php @@ -1,4 +1,5 @@ */ class Titles extends AbstractCollection diff --git a/vendor/phpoffice/phpword/src/PhpWord/ComplexType/FootnoteProperties.php b/vendor/phpoffice/phpword/src/PhpWord/ComplexType/FootnoteProperties.php index 2e7743ca..10c426e8 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/ComplexType/FootnoteProperties.php +++ b/vendor/phpoffice/phpword/src/PhpWord/ComplexType/FootnoteProperties.php @@ -1,4 +1,5 @@ newInstanceArgs($elementArgs); // Set parent container @@ -165,7 +167,7 @@ abstract class AbstractContainer extends AbstractElement /** * Get all elements. * - * @return \PhpOffice\PhpWord\Element\AbstractElement[] + * @return AbstractElement[] */ public function getElements() { @@ -177,7 +179,7 @@ abstract class AbstractContainer extends AbstractElement * * @param int $index * - * @return null|\PhpOffice\PhpWord\Element\AbstractElement + * @return null|AbstractElement */ public function getElement($index) { @@ -191,13 +193,13 @@ abstract class AbstractContainer extends AbstractElement /** * Removes the element at requested index. * - * @param int|\PhpOffice\PhpWord\Element\AbstractElement $toRemove + * @param AbstractElement|int $toRemove */ public function removeElement($toRemove): void { if (is_int($toRemove) && array_key_exists($toRemove, $this->elements)) { unset($this->elements[$toRemove]); - } elseif ($toRemove instanceof \PhpOffice\PhpWord\Element\AbstractElement) { + } elseif ($toRemove instanceof AbstractElement) { foreach ($this->elements as $key => $element) { if ($element->getElementId() === $toRemove->getElementId()) { unset($this->elements[$key]); @@ -253,7 +255,7 @@ abstract class AbstractContainer extends AbstractElement 'Footnote' => ['Section', 'TextRun', 'Cell', 'ListItemRun'], 'Endnote' => ['Section', 'TextRun', 'Cell'], 'PreserveText' => ['Section', 'Header', 'Footer', 'Cell'], - 'Title' => ['Section', 'Cell'], + 'Title' => ['Section', 'Cell', 'Header'], 'TOC' => ['Section'], 'PageBreak' => ['Section'], 'Chart' => ['Section', 'Cell'], diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/AbstractElement.php b/vendor/phpoffice/phpword/src/PhpWord/Element/AbstractElement.php index 385e4d31..3a29b686 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/AbstractElement.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/AbstractElement.php @@ -1,4 +1,5 @@ elementId = substr(md5(mt_rand()), 0, 6); + $this->elementId = substr(md5((string) mt_rand()), 0, 6); } /** @@ -291,8 +290,6 @@ abstract class AbstractElement /** * Get comments start. - * - * @return Comments */ public function getCommentsRangeStart(): ?Comments { @@ -301,8 +298,6 @@ abstract class AbstractElement /** * Get comment start. - * - * @return Comment */ public function getCommentRangeStart(): ?Comment { @@ -339,8 +334,6 @@ abstract class AbstractElement /** * Get comments end. - * - * @return Comments */ public function getCommentsRangeEnd(): ?Comments { @@ -349,8 +342,6 @@ abstract class AbstractElement /** * Get comment end. - * - * @return Comment */ public function getCommentRangeEnd(): ?Comment { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/Bookmark.php b/vendor/phpoffice/phpword/src/PhpWord/Element/Bookmark.php index 4fe3d0f0..151d5a48 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/Bookmark.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/Bookmark.php @@ -1,4 +1,5 @@ text; } @@ -109,7 +108,7 @@ class Link extends AbstractElement /** * Get Text style. * - * @return null|\PhpOffice\PhpWord\Style\Font|string + * @return null|Font|string */ public function getFontStyle() { @@ -119,7 +118,7 @@ class Link extends AbstractElement /** * Get Paragraph style. * - * @return null|\PhpOffice\PhpWord\Style\Paragraph|string + * @return null|Paragraph|string */ public function getParagraphStyle() { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/ListItem.php b/vendor/phpoffice/phpword/src/PhpWord/Element/ListItem.php index d3f25c29..bedfd110 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/ListItem.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/ListItem.php @@ -1,4 +1,5 @@ $collectionArray; if (in_array($type, [Header::AUTO, Header::FIRST, Header::EVEN])) { $index = count($collection); - /** @var \PhpOffice\PhpWord\Element\AbstractContainer $container Type hint */ + /** @var AbstractContainer $container Type hint */ $container = new $containerClass($this->sectionId, ++$index, $type); $container->setPhpWord($this->phpWord); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/Shape.php b/vendor/phpoffice/phpword/src/PhpWord/Element/Shape.php index 15161f89..9ea221db 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/Shape.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/Shape.php @@ -1,4 +1,5 @@ phpWord->getTitles()->getItems(); foreach ($titles as $i => $title) { - /** @var \PhpOffice\PhpWord\Element\Title $title Type hint */ + /** @var Title $title Type hint */ $depth = $title->getDepth(); if ($this->minDepth > $depth) { unset($titles[$i]); @@ -110,7 +111,7 @@ class TOC extends AbstractElement /** * Get TOC Style. * - * @return \PhpOffice\PhpWord\Style\TOC + * @return TOCStyle */ public function getStyleTOC() { @@ -120,7 +121,7 @@ class TOC extends AbstractElement /** * Get Font Style. * - * @return \PhpOffice\PhpWord\Style\Font|string + * @return Font|string */ public function getStyleFont() { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/Table.php b/vendor/phpoffice/phpword/src/PhpWord/Element/Table.php index 53a828a9..7fb10306 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/Table.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/Table.php @@ -1,4 +1,5 @@ rows); for ($i = 0; $i < $rowCount; ++$i) { - /** @var \PhpOffice\PhpWord\Element\Row $row Type hint */ + /** @var Row $row Type hint */ $row = $this->rows[$i]; $cellCount = count($row->getCells()); if ($columnCount < $cellCount) { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/Text.php b/vendor/phpoffice/phpword/src/PhpWord/Element/Text.php index 96953953..f20b273e 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/Text.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/Text.php @@ -1,4 +1,5 @@ text; } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/TextBox.php b/vendor/phpoffice/phpword/src/PhpWord/Element/TextBox.php index af37f657..b9f8b50b 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/TextBox.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/TextBox.php @@ -1,4 +1,5 @@ getElements() as $element) { if ($element instanceof Text) { $outstr .= $element->getText(); + } elseif ($element instanceof Ruby) { + $outstr .= $element->getBaseTextRun()->getText() . + ' (' . $element->getRubyTextRun()->getText() . ')'; } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Element/Title.php b/vendor/phpoffice/phpword/src/PhpWord/Element/Title.php index 8fd5b21b..89f438a5 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Element/Title.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Element/Title.php @@ -1,4 +1,5 @@ load($filename); @@ -100,7 +101,7 @@ abstract class IOFactory */ public static function extractVariables(string $filename, string $readerName = 'Word2007'): array { - /** @var \PhpOffice\PhpWord\Reader\ReaderInterface $reader */ + /** @var ReaderInterface $reader */ $reader = self::createReader($readerName); $document = $reader->load($filename); $extractedVariables = []; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Media.php b/vendor/phpoffice/phpword/src/PhpWord/Media.php index 31487a91..0a340a0a 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Media.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Media.php @@ -1,4 +1,5 @@ setRels($relationships); $part->read($phpWord); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Reader/ODText/AbstractPart.php b/vendor/phpoffice/phpword/src/PhpWord/Reader/ODText/AbstractPart.php index 4c89192e..447c96f0 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Reader/ODText/AbstractPart.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Reader/ODText/AbstractPart.php @@ -1,4 +1,5 @@ getElements('w:r|w:hyperlink', $domNode); - if ($nodes->length === 1) { + $hasRubyElement = $xmlReader->elementExists('w:r/w:ruby', $domNode); + if ($nodes->length === 1 && !$hasRubyElement) { $textContent = htmlspecialchars($xmlReader->getValue('w:t', $nodes->item(0)), ENT_QUOTES, 'UTF-8'); } else { $textContent = new TextRun($paragraphStyle); @@ -450,7 +455,7 @@ abstract class AbstractPart /** * Read w:r. * - * @param \PhpOffice\PhpWord\Element\AbstractContainer $parent + * @param AbstractContainer $parent * @param string $docPart * @param mixed $paragraphStyle * @@ -584,9 +589,47 @@ abstract class AbstractPart } } elseif ($node->nodeName == 'w:softHyphen') { $element = $parent->addText("\u{200c}", $fontStyle, $paragraphStyle); + } elseif ($node->nodeName == 'w:ruby') { + $rubyPropertiesNode = $xmlReader->getElement('w:rubyPr', $node); + $properties = $this->readRubyProperties($xmlReader, $rubyPropertiesNode); + // read base text node + $baseText = new TextRun($paragraphStyle); + $baseTextNode = $xmlReader->getElement('w:rubyBase/w:r', $node); + $this->readRun($xmlReader, $baseTextNode, $baseText, $docPart, $paragraphStyle); + // read the actual ruby text (e.g. furigana in Japanese) + $rubyText = new TextRun($paragraphStyle); + $rubyTextNode = $xmlReader->getElement('w:rt/w:r', $node); + $this->readRun($xmlReader, $rubyTextNode, $rubyText, $docPart, $paragraphStyle); + // add element to parent + $parent->addRuby($baseText, $rubyText, $properties); } } + /** + * Read w:rubyPr element. + * + * @param XMLReader $xmlReader reader for XML + * @param DOMElement $domNode w:RubyPr element + * + * @return RubyProperties ruby properties from element + */ + protected function readRubyProperties(XMLReader $xmlReader, DOMElement $domNode): RubyProperties + { + $rubyAlignment = $xmlReader->getElement('w:rubyAlign', $domNode)->getAttribute('w:val'); + $rubyHps = $xmlReader->getElement('w:hps', $domNode)->getAttribute('w:val'); // font face + $rubyHpsRaise = $xmlReader->getElement('w:hpsRaise', $domNode)->getAttribute('w:val'); // pts above base text + $rubyHpsBaseText = $xmlReader->getElement('w:hpsBaseText', $domNode)->getAttribute('w:val'); // base text size + $rubyLid = $xmlReader->getElement('w:lid', $domNode)->getAttribute('w:val'); // type of ruby + $properties = new RubyProperties(); + $properties->setAlignment($rubyAlignment); + $properties->setFontFaceSize((float) $rubyHps); + $properties->setFontPointsAboveBaseText((float) $rubyHpsRaise); + $properties->setFontSizeForBaseText((float) $rubyHpsBaseText); + $properties->setLanguageId($rubyLid); + + return $properties; + } + /** * Read w:tbl. * @@ -661,8 +704,11 @@ abstract class AbstractPart 'alignment' => [self::READ_VALUE, 'w:jc'], 'basedOn' => [self::READ_VALUE, 'w:basedOn'], 'next' => [self::READ_VALUE, 'w:next'], - 'indent' => [self::READ_VALUE, 'w:ind', 'w:left'], - 'hanging' => [self::READ_VALUE, 'w:ind', 'w:hanging'], + 'indentLeft' => [self::READ_VALUE, 'w:ind', 'w:left'], + 'indentRight' => [self::READ_VALUE, 'w:ind', 'w:right'], + 'indentHanging' => [self::READ_VALUE, 'w:ind', 'w:hanging'], + 'indentFirstLine' => [self::READ_VALUE, 'w:ind', 'w:firstLine'], + 'indentFirstLineChars' => [self::READ_VALUE, 'w:ind', 'w:firstLineChars'], 'spaceAfter' => [self::READ_VALUE, 'w:spacing', 'w:after'], 'spaceBefore' => [self::READ_VALUE, 'w:spacing', 'w:before'], 'widowControl' => [self::READ_FALSE, 'w:widowControl'], diff --git a/vendor/phpoffice/phpword/src/PhpWord/Reader/Word2007/DocPropsApp.php b/vendor/phpoffice/phpword/src/PhpWord/Reader/Word2007/DocPropsApp.php index 9d6f3cbb..c7ecb007 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Reader/Word2007/DocPropsApp.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Reader/Word2007/DocPropsApp.php @@ -1,4 +1,5 @@ setDefaultFontSize($fontDefaultStyle['size']); } + if (array_key_exists('color', $fontDefaultStyle)) { + $phpWord->setDefaultFontColor($fontDefaultStyle['color']); + } if (array_key_exists('lang', $fontDefaultStyle)) { $phpWord->getSettings()->setThemeFontLang(new Language($fontDefaultStyle['lang'])); } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Settings.php b/vendor/phpoffice/phpword/src/PhpWord/Settings.php index 984486cc..16f49166 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Settings.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Settings.php @@ -1,4 +1,5 @@ cssContent); preg_match_all('/(.+?)\s?\{\s?(.+?)\s?\}/', $cssContent, $cssExtracted); - // Check the number of extracted - if (count($cssExtracted) != 3) { - return; - } // Check if there are x selectors and x rules if (count($cssExtracted[1]) != count($cssExtracted[2])) { return; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Shared/Drawing.php b/vendor/phpoffice/phpword/src/PhpWord/Shared/Drawing.php index df218108..8af7da2f 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Shared/Drawing.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Shared/Drawing.php @@ -1,4 +1,5 @@ . * - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element Where the parts need to be added + * @param AbstractContainer $element Where the parts need to be added * @param string $html The code to parse * @param bool $fullHTML If it's a full HTML, no need to add 'body' tag * @param bool $preserveWhiteSpace If false, the whitespaces between nodes will be removed @@ -127,21 +130,21 @@ class Html break; case 'width': // tables, cells + $val = $val === 'auto' ? '100%' : $val; if (false !== strpos($val, '%')) { // e.g. or
$styles['width'] = (int) $val * 50; $styles['unit'] = \PhpOffice\PhpWord\SimpleType\TblWidth::PERCENT; } else { // e.g. , where "2" = 2px (always pixels) - $val = (int) $val . 'px'; - $styles['cellSpacing'] = Converter::cssToTwip($val); + $styles['cellSpacing'] = Converter::pixelToTwip(self::convertHtmlSize($val)); break; case 'bgcolor': @@ -185,7 +188,7 @@ class Html * Parse a node and add a corresponding element to the parent element. * * @param DOMNode $node node to parse - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element object to add an element corresponding with the node + * @param AbstractContainer $element object to add an element corresponding with the node * @param array $styles Array with all styles * @param array $data Array to transport data to a next level in the DOM tree, for example level of listitems */ @@ -208,16 +211,16 @@ class Html // Node mapping table $nodes = [ - // $method $node $element $styles $data $argument1 $argument2 - 'p' => ['Paragraph', $node, $element, $styles, null, null, null], - 'h1' => ['Heading', null, $element, $styles, null, 'Heading1', null], - 'h2' => ['Heading', null, $element, $styles, null, 'Heading2', null], - 'h3' => ['Heading', null, $element, $styles, null, 'Heading3', null], - 'h4' => ['Heading', null, $element, $styles, null, 'Heading4', null], - 'h5' => ['Heading', null, $element, $styles, null, 'Heading5', null], - 'h6' => ['Heading', null, $element, $styles, null, 'Heading6', null], - '#text' => ['Text', $node, $element, $styles, null, null, null], - 'strong' => ['Property', null, null, $styles, null, 'bold', true], + // $method $node $element $styles $data $argument1 $argument2 + 'p' => ['Paragraph', $node, $element, $styles, null, null, null], + 'h1' => ['Heading', $node, $element, $styles, null, 'Heading1', null], + 'h2' => ['Heading', $node, $element, $styles, null, 'Heading2', null], + 'h3' => ['Heading', $node, $element, $styles, null, 'Heading3', null], + 'h4' => ['Heading', $node, $element, $styles, null, 'Heading4', null], + 'h5' => ['Heading', $node, $element, $styles, null, 'Heading5', null], + 'h6' => ['Heading', $node, $element, $styles, null, 'Heading6', null], + '#text' => ['Text', $node, $element, $styles, null, null, null], + 'strong' => ['Property', null, null, $styles, null, 'bold', true], 'b' => ['Property', null, null, $styles, null, 'bold', true], 'em' => ['Property', null, null, $styles, null, 'italic', true], 'i' => ['Property', null, null, $styles, null, 'italic', true], @@ -238,6 +241,7 @@ class Html 'a' => ['Link', $node, $element, $styles, null, null, null], 'input' => ['Input', $node, $element, $styles, null, null, null], 'hr' => ['HorizRule', $node, $element, $styles, null, null, null], + 'ruby' => ['Ruby', $node, $element, $styles, null, null, null], ]; $newElement = null; @@ -276,7 +280,7 @@ class Html * Parse child nodes. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer|Row|Table $element + * @param AbstractContainer|Row|Table $element * @param array $styles * @param array $data */ @@ -298,10 +302,10 @@ class Html * Parse paragraph node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles * - * @return \PhpOffice\PhpWord\Element\PageBreak|\PhpOffice\PhpWord\Element\TextRun + * @return \PhpOffice\PhpWord\Element\PageBreak|TextRun */ protected static function parseParagraph($node, $element, &$styles) { @@ -317,7 +321,7 @@ class Html * Parse input node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles */ protected static function parseInput($node, $element, &$styles): void @@ -341,28 +345,25 @@ class Html /** * Parse heading node. * - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element - * @param array &$styles * @param string $argument1 Name of heading style * - * @return \PhpOffice\PhpWord\Element\TextRun - * * @todo Think of a clever way of defining header styles, now it is only based on the assumption, that * Heading1 - Heading6 are already defined somewhere */ - protected static function parseHeading($element, &$styles, $argument1) + protected static function parseHeading(DOMNode $node, AbstractContainer $element, array &$styles, string $argument1): TextRun { - $styles['paragraph'] = $argument1; - $newElement = $element->addTextRun($styles['paragraph']); + $style = new Paragraph(); + $style->setStyleName($argument1); + $style->setStyleByArray(self::parseInlineStyle($node, $styles['paragraph'])); - return $newElement; + return $element->addTextRun($style); } /** * Parse text node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles */ protected static function parseText($node, $element, &$styles): void @@ -406,7 +407,7 @@ class Html * Parse table node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles * * @return Table $element @@ -437,7 +438,7 @@ class Html * Parse a table row. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\Table $element + * @param Table $element * @param array &$styles * * @return Row $element @@ -460,10 +461,10 @@ class Html * Parse table cell. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\Table $element + * @param Table $element * @param array &$styles * - * @return \PhpOffice\PhpWord\Element\Cell|\PhpOffice\PhpWord\Element\TextRun $element + * @return \PhpOffice\PhpWord\Element\Cell|TextRun $element */ protected static function parseCell($node, $element, &$styles) { @@ -554,7 +555,7 @@ class Html * Parse list node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles * @param array &$data */ @@ -627,15 +628,15 @@ class Html return [ 'type' => 'hybridMultilevel', 'levels' => [ - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 720, 'left' => 720, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => 'o', 'alignment' => 'left', 'tabPos' => 1440, 'left' => 1440, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 2160, 'left' => 2160, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 2880, 'left' => 2880, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => 'o', 'alignment' => 'left', 'tabPos' => 3600, 'left' => 3600, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 4320, 'left' => 4320, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 5040, 'left' => 5040, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => 'o', 'alignment' => 'left', 'tabPos' => 5760, 'left' => 5760, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], - ['format' => NumberFormat::BULLET, 'text' => '', 'alignment' => 'left', 'tabPos' => 6480, 'left' => 6480, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 720, 'left' => 720, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '◦', 'alignment' => 'left', 'tabPos' => 1440, 'left' => 1440, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 2160, 'left' => 2160, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 2880, 'left' => 2880, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '◦', 'alignment' => 'left', 'tabPos' => 3600, 'left' => 3600, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 4320, 'left' => 4320, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 5040, 'left' => 5040, 'hanging' => 360, 'font' => 'Symbol', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '◦', 'alignment' => 'left', 'tabPos' => 5760, 'left' => 5760, 'hanging' => 360, 'font' => 'Courier New', 'hint' => 'default'], + ['format' => NumberFormat::BULLET, 'text' => '•', 'alignment' => 'left', 'tabPos' => 6480, 'left' => 6480, 'hanging' => 360, 'font' => 'Wingdings', 'hint' => 'default'], ], ]; } @@ -644,7 +645,7 @@ class Html * Parse list item node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array &$styles * @param array $data * @@ -704,6 +705,10 @@ class Html case 'text-align': $styles['alignment'] = self::mapAlign($value, $bidi); + break; + case 'ruby-align': + $styles['rubyAlignment'] = self::mapRubyAlign($value); + break; case 'display': $styles['hidden'] = $value === 'none' || $value === 'hidden'; @@ -733,7 +738,7 @@ class Html break; case 'line-height': $matches = []; - if ($value === 'normal') { + if ($value === 'normal' || $value === 'inherit') { $spacingLineRule = \PhpOffice\PhpWord\SimpleType\LineSpacingRule::AUTO; $spacing = 0; } elseif (preg_match('/([0-9]+\.?[0-9]*[a-z]+)/', $value, $matches)) { @@ -803,6 +808,58 @@ class Html $styles['spaceAfter'] = Converter::cssToTwip($value); break; + + case 'padding': + $valueTop = $valueRight = $valueBottom = $valueLeft = null; + $cValue = preg_replace('# +#', ' ', trim($value)); + $paddingArr = explode(' ', $cValue); + $countParams = count($paddingArr); + if ($countParams == 1) { + $valueTop = $valueRight = $valueBottom = $valueLeft = $paddingArr[0]; + } elseif ($countParams == 2) { + $valueTop = $valueBottom = $paddingArr[0]; + $valueRight = $valueLeft = $paddingArr[1]; + } elseif ($countParams == 3) { + $valueTop = $paddingArr[0]; + $valueRight = $valueLeft = $paddingArr[1]; + $valueBottom = $paddingArr[2]; + } elseif ($countParams == 4) { + $valueTop = $paddingArr[0]; + $valueRight = $paddingArr[1]; + $valueBottom = $paddingArr[2]; + $valueLeft = $paddingArr[3]; + } + if ($valueTop !== null) { + $styles['paddingTop'] = Converter::cssToTwip($valueTop); + } + if ($valueRight !== null) { + $styles['paddingRight'] = Converter::cssToTwip($valueRight); + } + if ($valueBottom !== null) { + $styles['paddingBottom'] = Converter::cssToTwip($valueBottom); + } + if ($valueLeft !== null) { + $styles['paddingLeft'] = Converter::cssToTwip($valueLeft); + } + + break; + case 'padding-top': + $styles['paddingTop'] = Converter::cssToTwip($value); + + break; + case 'padding-right': + $styles['paddingRight'] = Converter::cssToTwip($value); + + break; + case 'padding-bottom': + $styles['paddingBottom'] = Converter::cssToTwip($value); + + break; + case 'padding-left': + $styles['paddingLeft'] = Converter::cssToTwip($value); + + break; + case 'border-color': self::mapBorderColor($styles, $value); @@ -886,7 +943,7 @@ class Html * Parse image node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * * @return \PhpOffice\PhpWord\Element\Image */ @@ -901,36 +958,12 @@ class Html break; case 'width': - $width = $attribute->value; - - // pt - if (false !== strpos($width, 'pt')) { - $width = Converter::pointToPixel((float) str_replace('pt', '', $width)); - } - - // px - if (false !== strpos($width, 'px')) { - $width = str_replace('px', '', $width); - } - - $style['width'] = $width; + $style['width'] = self::convertHtmlSize($attribute->value); $style['unit'] = \PhpOffice\PhpWord\Style\Image::UNIT_PX; break; case 'height': - $height = $attribute->value; - - // pt - if (false !== strpos($height, 'pt')) { - $height = Converter::pointToPixel((float) str_replace('pt', '', $height)); - } - - // px - if (false !== strpos($height, 'px')) { - $height = str_replace('px', '', $height); - } - - $style['height'] = $height; + $style['height'] = self::convertHtmlSize($attribute->value); $style['unit'] = \PhpOffice\PhpWord\Style\Image::UNIT_PX; break; @@ -970,14 +1003,15 @@ class Html $match = []; preg_match('/data:image\/(\w+);base64,(.+)/', $src, $match); + if (!empty($match)) { + $src = $imgFile = $tmpDir . uniqid() . '.' . $match[1]; - $src = $imgFile = $tmpDir . uniqid() . '.' . $match[1]; + $ifp = fopen($imgFile, 'wb'); - $ifp = fopen($imgFile, 'wb'); - - if ($ifp !== false) { - fwrite($ifp, base64_decode($match[2])); - fclose($ifp); + if ($ifp !== false) { + fwrite($ifp, base64_decode($match[2])); + fclose($ifp); + } } } $src = urldecode($src); @@ -1073,6 +1107,23 @@ class Html } } + /** + * Transforms a HTML/CSS ruby alignment into a \PhpOffice\PhpWord\SimpleType\Jc. + */ + protected static function mapRubyAlign(string $cssRubyAlignment): string + { + switch ($cssRubyAlignment) { + case 'center': + return RubyProperties::ALIGNMENT_CENTER; + case 'start': + return RubyProperties::ALIGNMENT_LEFT; + case 'space-between': + return RubyProperties::ALIGNMENT_DISTRIBUTE_SPACE; + default: + return ''; + } + } + /** * Transforms a HTML/CSS vertical alignment. * @@ -1129,7 +1180,7 @@ class Html /** * Parse line break. * - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element */ protected static function parseLineBreak($element): void { @@ -1140,7 +1191,7 @@ class Html * Parse link node. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element * @param array $styles */ protected static function parseLink($node, $element, &$styles) @@ -1172,7 +1223,7 @@ class Html * Note: Word rule is not the same as HTML's
since it does not support width and thus neither alignment. * * @param DOMNode $node - * @param \PhpOffice\PhpWord\Element\AbstractContainer $element + * @param AbstractContainer $element */ protected static function parseHorizRule($node, $element): void { @@ -1201,6 +1252,59 @@ class Html // - repeated text, e.g. underline "_", because of unpredictable line wrapping } + /** + * Parse ruby node. + * + * @param DOMNode $node + * @param AbstractContainer $element + * @param array $styles + */ + protected static function parseRuby($node, $element, &$styles) + { + $rubyProperties = new RubyProperties(); + $baseTextRun = new TextRun($styles['paragraph']); + $rubyTextRun = new TextRun(null); + if ($node->hasAttributes()) { + $langAttr = $node->attributes->getNamedItem('lang'); + if ($langAttr !== null) { + $rubyProperties->setLanguageId($langAttr->textContent); + } + $styleAttr = $node->attributes->getNamedItem('style'); + if ($styleAttr !== null) { + $styles = self::parseStyle($styleAttr, $styles['paragraph']); + if (isset($styles['rubyAlignment']) && $styles['rubyAlignment'] !== '') { + $rubyProperties->setAlignment($styles['rubyAlignment']); + } + if (isset($styles['size']) && $styles['size'] !== '') { + $rubyProperties->setFontSizeForBaseText($styles['size']); + } + $baseTextRun->setParagraphStyle($styles); + } + } + foreach ($node->childNodes as $child) { + if ($child->nodeName === '#text') { + $content = trim($child->textContent); + if ($content !== '') { + $baseTextRun->addText($content); + } + } elseif ($child->nodeName === 'rt') { + $rubyTextRun->addText(trim($child->textContent)); + if ($child->hasAttributes()) { + $styleAttr = $child->attributes->getNamedItem('style'); + if ($styleAttr !== null) { + $styles = self::parseStyle($styleAttr, []); + if (isset($styles['size']) && $styles['size'] !== '') { + $rubyProperties->setFontFaceSize($styles['size']); + } + $rubyTextRun->setParagraphStyle($styles); + } + } + } + } + + return $element->addRuby($baseTextRun, $rubyTextRun, $rubyProperties); + } + private static function convertRgb(string $rgb): string { if (preg_match(self::RGB_REGEXP, $rgb, $matches) === 1) { @@ -1209,4 +1313,22 @@ class Html return trim($rgb, '# '); } + + /** + * Transform HTML sizes (pt, px) in pixels. + */ + protected static function convertHtmlSize(string $size): float + { + // pt + if (false !== strpos($size, 'pt')) { + return Converter::pointToPixel((float) str_replace('pt', '', $size)); + } + + // px + if (false !== strpos($size, 'px')) { + return (float) str_replace('px', '', $size); + } + + return (float) $size; + } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Shared/Microsoft/PasswordEncoder.php b/vendor/phpoffice/phpword/src/PhpWord/Shared/Microsoft/PasswordEncoder.php index d6cf69fc..4762cc71 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Shared/Microsoft/PasswordEncoder.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Shared/Microsoft/PasswordEncoder.php @@ -1,4 +1,5 @@ tempDir . DIRECTORY_SEPARATOR . $filenameParts['basename'], 'wb'); - fwrite($handle, $contents); - fclose($handle); + if ($handle) { + fwrite($handle, $contents); + fclose($handle); + } // Add temp file to zip $filename = $this->tempDir . DIRECTORY_SEPARATOR . $filenameParts['basename']; @@ -420,4 +423,15 @@ class ZipArchive return ($listIndex > -1) ? $listIndex : false; } + + /** + * Add an empty directory to the zip archive (emulate \ZipArchive). + * + * @param string $dirname Directory name to add to the zip archive + */ + public function addEmptyDir(string $dirname): bool + { + // Create a directory entry by adding an empty file with trailing slash + return $this->addFromString(rtrim($dirname, '/') . '/', ''); + } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/SimpleType/Border.php b/vendor/phpoffice/phpword/src/PhpWord/SimpleType/Border.php index 6cb42f04..acd1c1a1 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/SimpleType/Border.php +++ b/vendor/phpoffice/phpword/src/PhpWord/SimpleType/Border.php @@ -1,4 +1,5 @@ vAlign = null; + + return $this; + } + VerticalJc::validate($value); $this->vAlign = $this->setEnumVal($value, VerticalJc::values(), $this->vAlign); @@ -235,7 +262,7 @@ class Cell extends Border /** * Get vertical merge (rowspan). * - * @return string + * @return null|string */ public function getVMerge() { @@ -245,12 +272,18 @@ class Cell extends Border /** * Set vertical merge (rowspan). * - * @param string $value + * @param null|string $value * * @return self */ public function setVMerge($value = null) { + if ($value === null) { + $this->vMerge = null; + + return $this; + } + $enum = [self::VMERGE_RESTART, self::VMERGE_CONTINUE]; $this->vMerge = $this->setEnumVal($value, $enum, $this->vMerge); @@ -260,7 +293,7 @@ class Cell extends Border /** * Get shading. * - * @return \PhpOffice\PhpWord\Style\Shading + * @return Shading */ public function getShading() { @@ -344,4 +377,84 @@ class Cell extends Border { return $this->noWrap; } + + /** + * Get style padding-top. + */ + public function getPaddingTop(): ?int + { + return $this->paddingTop; + } + + /** + * Set style padding-top. + * + * @return $this + */ + public function setPaddingTop(int $value): self + { + $this->paddingTop = $value; + + return $this; + } + + /** + * Get style padding-bottom. + */ + public function getPaddingBottom(): ?int + { + return $this->paddingBottom; + } + + /** + * Set style padding-bottom. + * + * @return $this + */ + public function setPaddingBottom(int $value): self + { + $this->paddingBottom = $value; + + return $this; + } + + /** + * Get style padding-left. + */ + public function getPaddingLeft(): ?int + { + return $this->paddingLeft; + } + + /** + * Set style padding-left. + * + * @return $this + */ + public function setPaddingLeft(int $value): self + { + $this->paddingLeft = $value; + + return $this; + } + + /** + * Get style padding-right. + */ + public function getPaddingRight(): ?int + { + return $this->paddingRight; + } + + /** + * Set style padding-right. + * + * @return $this + */ + public function setPaddingRight(int $value): self + { + $this->paddingRight = $value; + + return $this; + } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Style/Chart.php b/vendor/phpoffice/phpword/src/PhpWord/Style/Chart.php index 9dbc8db0..6cffc4d5 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Style/Chart.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Style/Chart.php @@ -1,4 +1,5 @@ color; } @@ -682,7 +681,7 @@ class Font extends AbstractStyle * * @param string $value * - * @return \PhpOffice\PhpWord\Style\Table + * @return Table */ public function setBgColor($value = null) { @@ -812,7 +811,7 @@ class Font extends AbstractStyle /** * Get paragraph style. * - * @return \PhpOffice\PhpWord\Style\Paragraph + * @return Paragraph */ public function getParagraph() { @@ -860,7 +859,7 @@ class Font extends AbstractStyle /** * Get shading. * - * @return \PhpOffice\PhpWord\Style\Shading + * @return Shading */ public function getShading() { @@ -884,7 +883,7 @@ class Font extends AbstractStyle /** * Get language. * - * @return null|\PhpOffice\PhpWord\Style\Language + * @return null|Language */ public function getLang() { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Style/Frame.php b/vendor/phpoffice/phpword/src/PhpWord/Style/Frame.php index 45fc583e..016722f3 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Style/Frame.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Style/Frame.php @@ -1,4 +1,5 @@ left; } /** * Set left. - * - * @param float|int $value - * - * @return self */ - public function setLeft($value) + public function setLeft(?float $value): self { - $this->left = $this->setNumericVal($value, $this->left); + $this->left = $this->setNumericVal($value); return $this; } /** * Get right. - * - * @return float|int */ - public function getRight() + public function getRight(): ?float { return $this->right; } /** * Set right. - * - * @param float|int $value - * - * @return self */ - public function setRight($value) + public function setRight(?float $value): self { - $this->right = $this->setNumericVal($value, $this->right); + $this->right = $this->setNumericVal($value); return $this; } /** * Get first line. - * - * @return float|int */ - public function getFirstLine() + public function getFirstLine(): ?float { return $this->firstLine; } /** * Set first line. - * - * @param float|int $value - * - * @return self */ - public function setFirstLine($value) + public function setFirstLine(?float $value): self { - $this->firstLine = $this->setNumericVal($value, $this->firstLine); + $this->firstLine = $this->setNumericVal($value); + + return $this; + } + + /** + * Get first line chars. + */ + public function getFirstLineChars(): int + { + return $this->firstLineChars; + } + + /** + * Set first line chars. + */ + public function setFirstLineChars(int $value): self + { + $this->firstLineChars = $this->setIntVal($value, $this->firstLineChars); return $this; } /** * Get hanging. - * - * @return float|int */ - public function getHanging() + public function getHanging(): ?float { return $this->hanging; } /** * Set hanging. - * - * @param float|int $value - * - * @return self */ - public function setHanging($value = null) + public function setHanging(?float $value = null): self { - $this->hanging = $this->setNumericVal($value, $this->hanging); + $this->hanging = $this->setNumericVal($value); return $this; } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Style/Language.php b/vendor/phpoffice/phpword/src/PhpWord/Style/Language.php index 18e7f76e..54e43765 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Style/Language.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Style/Language.php @@ -1,4 +1,5 @@ numId; } /** * Set Id. - * - * @param int $value - * - * @return self */ - public function setNumId($value) + public function setNumId(int $value): self { $this->numId = $this->setIntVal($value, $this->numId); @@ -78,22 +73,16 @@ class Numbering extends AbstractStyle /** * Get multilevel type. - * - * @return string */ - public function getType() + public function getType(): ?string { return $this->type; } /** * Set multilevel type. - * - * @param string $value - * - * @return self */ - public function setType($value) + public function setType(string $value): self { $enum = ['singleLevel', 'multilevel', 'hybridMultilevel']; $this->type = $this->setEnumVal($value, $enum, $this->type); @@ -106,19 +95,15 @@ class Numbering extends AbstractStyle * * @return NumberingLevel[] */ - public function getLevels() + public function getLevels(): array { return $this->levels; } /** * Set multilevel type. - * - * @param array $values - * - * @return self */ - public function setLevels($values) + public function setLevels(array $values): self { if (is_array($values)) { foreach ($values as $key => $value) { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Style/NumberingLevel.php b/vendor/phpoffice/phpword/src/PhpWord/Style/NumberingLevel.php index 39c0d839..31ec3738 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Style/NumberingLevel.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Style/NumberingLevel.php @@ -1,4 +1,5 @@ getChildStyleValue($this->indentation, 'hanging'); + } + /** * Get indentation. * - * @return null|\PhpOffice\PhpWord\Style\Indentation + * @deprecated 1.4.0 Use getIndentLeft */ - public function getIndentation() + public function getIndent(): ?float + { + return $this->getChildStyleValue($this->indentation, 'left'); + } + + /** + * Get indentation. + */ + public function getIndentation(): ?Indentation { return $this->indentation; } /** - * Set shading. - * - * @param mixed $value - * - * @return self + * Get firstLine. */ - public function setIndentation($value = null) + public function getIndentFirstLine(): ?float { + return $this->getChildStyleValue($this->indentation, 'firstLine'); + } + + /** + * Get left indentation. + */ + public function getIndentLeft(): ?float + { + return $this->getChildStyleValue($this->indentation, 'left'); + } + + /** + * Get right indentation. + */ + public function getIndentRight(): ?float + { + return $this->getChildStyleValue($this->indentation, 'right'); + } + + /** + * Set hanging. + * + * @deprecated 1.4.0 Use setIndentHanging + */ + public function setHanging(?float $value = null): self + { + return $this->setIndentation(['hanging' => $value]); + } + + /** + * Set indentation. + * + * @deprecated 1.4.0 Use setIndentLeft + */ + public function setIndent(?float $value = null): self + { + return $this->setIndentation(['left' => $value]); + } + + /** + * Set indentation. + * + * @param array{ + * left?:null|float|int|numeric-string, + * right?:null|float|int|numeric-string, + * hanging?:null|float|int|numeric-string, + * firstLine?:null|float|int|numeric-string + * } $value + */ + public function setIndentation(array $value = []): self + { + $value = array_map(function ($indent) { + if (is_string($indent) || is_numeric($indent)) { + $indent = $this->setFloatVal($indent); + } + + return $indent; + }, $value); $this->setObjectVal($value, 'Indentation', $this->indentation); return $this; } /** - * Get indentation. - * - * @return int + * Set hanging indentation. */ - public function getIndent() - { - return $this->getChildStyleValue($this->indentation, 'left'); - } - - /** - * Set indentation. - * - * @param int $value - * - * @return self - */ - public function setIndent($value = null) - { - return $this->setIndentation(['left' => $value]); - } - - /** - * Get hanging. - * - * @return int - */ - public function getHanging() - { - return $this->getChildStyleValue($this->indentation, 'hanging'); - } - - /** - * Set hanging. - * - * @param int $value - * - * @return self - */ - public function setHanging($value = null) + public function setIndentHanging(?float $value = null): self { return $this->setIndentation(['hanging' => $value]); } + /** + * Set firstline indentation. + */ + public function setIndentFirstLine(?float $value = null): self + { + return $this->setIndentation(['firstLine' => $value]); + } + + /** + * Set firstlineChars indentation. + */ + public function setIndentFirstLineChars(int $value = 0): self + { + return $this->setIndentation(['firstLineChars' => $value]); + } + + /** + * Set left indentation. + */ + public function setIndentLeft(?float $value = null): self + { + return $this->setIndentation(['left' => $value]); + } + + /** + * Set right indentation. + */ + public function setIndentRight(?float $value = null): self + { + return $this->setIndentation(['right' => $value]); + } + /** * Get spacing. * - * @return \PhpOffice\PhpWord\Style\Spacing + * @return Spacing * * @todo Rename to getSpacing in 1.0 */ @@ -498,7 +565,7 @@ class Paragraph extends Border * * @param string $value Possible values are defined in LineSpacingRule * - * @return \PhpOffice\PhpWord\Style\Paragraph + * @return Paragraph */ public function setSpacingLineRule($value) { @@ -686,7 +753,7 @@ class Paragraph extends Border /** * Get tabs. * - * @return \PhpOffice\PhpWord\Style\Tab[] + * @return Tab[] */ public function getTabs() { @@ -712,7 +779,7 @@ class Paragraph extends Border /** * Get shading. * - * @return \PhpOffice\PhpWord\Style\Shading + * @return Shading */ public function getShading() { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Style/Row.php b/vendor/phpoffice/phpword/src/PhpWord/Style/Row.php index 765c54f8..31ae3ded 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Style/Row.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Style/Row.php @@ -1,4 +1,5 @@ zip()->AddFromString("word/media/image1.jpg", file_get_contents($file));
* To read a file: $templateProcessor->zip()->getFromName("word/media/image1.jpg"); * - * @return \PhpOffice\PhpWord\Shared\ZipArchive + * @return ZipArchive */ public function zip() { @@ -269,7 +269,7 @@ class TemplateProcessor */ protected static function ensureUtf8Encoded($subject) { - return $subject ? Text::toUTF8($subject) : ''; + return (null !== $subject) ? Text::toUTF8($subject) : ''; } /** @@ -281,7 +281,7 @@ class TemplateProcessor $objectClass = 'PhpOffice\\PhpWord\\Writer\\Word2007\\Element\\' . $elementName; $xmlWriter = new XMLWriter(); - /** @var \PhpOffice\PhpWord\Writer\Word2007\Element\AbstractElement $elementWriter */ + /** @var Writer\Word2007\Element\AbstractElement $elementWriter */ $elementWriter = new $objectClass($xmlWriter, $complexType, true); $elementWriter->write(); @@ -308,7 +308,7 @@ class TemplateProcessor $objectClass = 'PhpOffice\\PhpWord\\Writer\\Word2007\\Element\\' . $elementName; $xmlWriter = new XMLWriter(); - /** @var \PhpOffice\PhpWord\Writer\Word2007\Element\AbstractElement $elementWriter */ + /** @var Writer\Word2007\Element\AbstractElement $elementWriter */ $elementWriter = new $objectClass($xmlWriter, $complexType, false); $elementWriter->write(); @@ -362,10 +362,10 @@ class TemplateProcessor /** * Set values from a one-dimensional array of "variable => value"-pairs. */ - public function setValues(array $values): void + public function setValues(array $values, int $limit = self::MAXIMUM_REPLACEMENTS_DEFAULT): void { foreach ($values as $macro => $replace) { - $this->setValue($macro, $replace); + $this->setValue($macro, $replace, $limit); } } @@ -406,7 +406,7 @@ class TemplateProcessor $filename = "charts/chart{$rId}.xml"; // Get the part writer - $writerPart = new \PhpOffice\PhpWord\Writer\Word2007\Part\Chart(); + $writerPart = new Writer\Word2007\Part\Chart(); $writerPart->setElement($chart); // ContentTypes.xml @@ -499,20 +499,22 @@ class TemplateProcessor $widthFloat = $heightFloat * $imageRatio; $matches = []; preg_match('/\\d([a-z%]+)$/', $height, $matches); - $width = $widthFloat . $matches[1]; + $width = $widthFloat . (!empty($matches) ? $matches[1] : 'px'); } elseif ($height === '') { // defined height is empty $widthFloat = (float) $width; $heightFloat = $widthFloat / $imageRatio; $matches = []; preg_match('/\\d([a-z%]+)$/', $width, $matches); - $height = $heightFloat . $matches[1]; + $height = $heightFloat . (!empty($matches) ? $matches[1] : 'px'); } else { // we have defined size, but we need also check it aspect ratio $widthMatches = []; preg_match('/\\d([a-z%]+)$/', $width, $widthMatches); $heightMatches = []; preg_match('/\\d([a-z%]+)$/', $height, $heightMatches); // try to fix only if dimensions are same - if ($widthMatches[1] == $heightMatches[1]) { + if (!empty($widthMatches) + && !empty($heightMatches) + && $widthMatches[1] == $heightMatches[1]) { $dimention = $widthMatches[1]; $widthFloat = (float) $width; $heightFloat = (float) $height; @@ -1287,7 +1289,7 @@ class TemplateProcessor * @param int $count * @param string $xmlBlock * - * @return string + * @return array */ protected function indexClonedVariables($count, $xmlBlock) { @@ -1339,7 +1341,7 @@ class TemplateProcessor * @param string $block New block content * @param string $blockType XML tag type of block * - * @return \PhpOffice\PhpWord\TemplateProcessor Fluent interface + * @return TemplateProcessor Fluent interface */ public function replaceXmlBlock($macro, $block, $blockType = 'w:p') { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/AbstractWriter.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/AbstractWriter.php index 8ebf98c7..13859d82 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/AbstractWriter.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/AbstractWriter.php @@ -1,4 +1,5 @@ parts as $partName) { $partClass = 'PhpOffice\\PhpWord\\Writer\\HTML\\Part\\' . $partName; if (class_exists($partClass)) { - /** @var \PhpOffice\PhpWord\Writer\HTML\Part\AbstractPart $part Type hint */ + /** @var HTML\Part\AbstractPart $part Type hint */ $part = new $partClass(); $part->setParentWriter($this); $this->writerParts[strtolower($partName)] = $part; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/AbstractElement.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/AbstractElement.php index 7c7bde31..0e6a112e 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/AbstractElement.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/AbstractElement.php @@ -1,4 +1,5 @@ namespace, $elementClass); if (class_exists($writerClass)) { - /** @var \PhpOffice\PhpWord\Writer\HTML\Element\AbstractElement $writer Type hint */ + /** @var AbstractElement $writer Type hint */ $writer = new $writerClass($this->parentWriter, $element, $withoutP); $content .= $writer->write(); } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/Endnote.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/Endnote.php index 1c35e8fa..7e7f31d4 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/Endnote.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/Endnote.php @@ -1,4 +1,5 @@ element; - $text = $this->parentWriter->escapeHTML($element->getText()); + $text = $this->parentWriter->escapeHTML($element->getText() ?? ''); if (!$this->withoutP && !trim($text)) { $text = ' '; } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/TextBreak.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/TextBreak.php index af73cb4a..576f6a83 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/TextBreak.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Element/TextBreak.php @@ -1,4 +1,5 @@ ' . PHP_EOL; - + $defaultFontColor = Settings::getDefaultFontColor(); // Default styles $astarray = [ 'font-family' => $this->getFontFamily(Settings::getDefaultFontName(), $this->getParentWriter()->getDefaultGenericFont()), 'font-size' => Settings::getDefaultFontSize() . 'pt', + 'color' => "#{$defaultFontColor}", ]; // Mpdf sometimes needs separate tag for body; doesn't harm others. $bodyarray = $astarray; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Style/AbstractStyle.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Style/AbstractStyle.php index a6507867..4672347b 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Style/AbstractStyle.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/HTML/Style/AbstractStyle.php @@ -1,4 +1,5 @@ getVAlign(); + } foreach (['Top', 'Left', 'Bottom', 'Right'] as $direction) { $method = 'getBorder' . $direction . 'Style'; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText.php index 616119e5..c9a524e8 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText.php @@ -1,4 +1,5 @@ parts) as $partName) { $partClass = static::class . '\\Part\\' . $partName; if (class_exists($partClass)) { - /** @var \PhpOffice\PhpWord\Writer\ODText\Part\AbstractPart $partObject Type hint */ + /** @var AbstractPart $partObject Type hint */ $partObject = new $partClass(); $partObject->setParentWriter($this); $this->writerParts[strtolower($partName)] = $partObject; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/AbstractElement.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/AbstractElement.php index 5cd396aa..97d1875c 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/AbstractElement.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/AbstractElement.php @@ -1,4 +1,5 @@ startElement('text:s'); + $xmlWriter->writeAttributeIf($num > 1, 'text:c', "$num"); + $xmlWriter->endElement(); + $text = preg_replace('/^ +/', '', $text); + } + preg_match_all('/([\\s\\S]*?)(\\t| +| ?$)/', $text, $matches, PREG_SET_ORDER); + foreach ($matches as $match) { + $this->writeText($match[1]); + if ($match[2] === '') { + break; + } elseif ($match[2] === "\t") { + $xmlWriter->writeElement('text:tab'); + } elseif ($match[2] === ' ') { + $xmlWriter->writeElement('text:s'); + + break; + } else { + $num = strlen($match[2]); + $xmlWriter->startElement('text:s'); + $xmlWriter->writeAttributeIf($num > 1, 'text:c', "$num"); + $xmlWriter->endElement(); + } + } + } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Container.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Container.php index 6e6b88ea..6b0fee8c 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Container.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Container.php @@ -1,4 +1,5 @@ + */ + protected $containerWithoutP = ['TextRun', 'Footnote', 'Endnote']; } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Field.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Field.php index 46f62b0f..6b548078 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Field.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Field.php @@ -1,4 +1,5 @@ getXmlWriter(); $element = $this->getElement(); - if (!$element instanceof \PhpOffice\PhpWord\Element\Image) { + if (!$element instanceof ElementImage) { return; } @@ -43,11 +44,16 @@ class Image extends AbstractElement $width = Converter::pixelToCm($style->getWidth()); $height = Converter::pixelToCm($style->getHeight()); - $xmlWriter->startElement('text:p'); - $xmlWriter->writeAttribute('text:style-name', 'IM' . $mediaIndex); + $xmlWriter = $this->getXmlWriter(); + + if (!$this->withoutP) { + $xmlWriter->startElement('text:p'); + $xmlWriter->writeAttribute('text:style-name', 'IM' . $mediaIndex); + } $xmlWriter->startElement('draw:frame'); $xmlWriter->writeAttribute('draw:style-name', 'fr' . $mediaIndex); + $xmlWriter->writeAttributeIf($this->withoutP, 'draw:text-style-name', 'IM' . $mediaIndex); $xmlWriter->writeAttribute('draw:name', $element->getElementId()); $xmlWriter->writeAttribute('text:anchor-type', 'as-char'); $xmlWriter->writeAttribute('svg:width', $width . 'cm'); @@ -63,6 +69,8 @@ class Image extends AbstractElement $xmlWriter->endElement(); // draw:frame - $xmlWriter->endElement(); // text:p + if (!$this->withoutP) { + $xmlWriter->endElement(); // text:p + } } } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Link.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Link.php index 0375b11b..9ef35692 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Link.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Link.php @@ -1,4 +1,5 @@ getXmlWriter(); $element = $this->getElement(); - if (!$element instanceof \PhpOffice\PhpWord\Element\Table) { + if (!$element instanceof TableElement) { return; } $rows = $element->getRows(); @@ -77,7 +78,7 @@ class Table extends AbstractElement private function writeRow(XMLWriter $xmlWriter, RowElement $row): void { $xmlWriter->startElement('table:table-row'); - /** @var \PhpOffice\PhpWord\Element\Row $row Type hint */ + /** @var RowElement $row Type hint */ foreach ($row->getCells() as $cell) { $xmlWriter->startElement('table:table-cell'); $xmlWriter->writeAttribute('office:value-type', 'string'); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Text.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Text.php index 75fb9308..39969723 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Text.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/Text.php @@ -1,4 +1,5 @@ writeAttribute('text:change-id', $element->getTrackChange()->getElementId()); $xmlWriter->endElement(); } else { - if (empty($fontStyle)) { - if (empty($paragraphStyle)) { - if (!$this->withoutP) { - $xmlWriter->writeAttribute('text:style-name', 'Normal'); - } - } elseif (is_string($paragraphStyle)) { - if (!$this->withoutP) { - $xmlWriter->writeAttribute('text:style-name', $paragraphStyle); - } + if (empty($paragraphStyle)) { + if (!$this->withoutP) { + $xmlWriter->writeAttribute('text:style-name', 'Normal'); } - $this->writeChangeInsertion(true, $element->getTrackChange()); - $this->replaceTabs($element->getText(), $xmlWriter); - $this->writeChangeInsertion(false, $element->getTrackChange()); - } else { - if (empty($paragraphStyle)) { - if (!$this->withoutP) { - $xmlWriter->writeAttribute('text:style-name', 'Normal'); - } - } elseif (is_string($paragraphStyle)) { - if (!$this->withoutP) { - $xmlWriter->writeAttribute('text:style-name', $paragraphStyle); - } + } elseif (is_string($paragraphStyle)) { + if (!$this->withoutP) { + $xmlWriter->writeAttribute('text:style-name', $paragraphStyle); } + } + + if (!empty($fontStyle)) { // text:span $xmlWriter->startElement('text:span'); if (is_string($fontStyle)) { $xmlWriter->writeAttribute('text:style-name', $fontStyle); } - $this->writeChangeInsertion(true, $element->getTrackChange()); - $this->replaceTabs($element->getText(), $xmlWriter); - $this->writeChangeInsertion(false, $element->getTrackChange()); + } + + $this->writeChangeInsertion(true, $element->getTrackChange()); + $this->replaceTabs($element->getText(), $xmlWriter); + $this->writeChangeInsertion(false, $element->getTrackChange()); + + if (!empty($fontStyle)) { $xmlWriter->endElement(); } } @@ -96,35 +89,6 @@ class Text extends AbstractElement } } - private function replacetabs($text, $xmlWriter): void - { - if (preg_match('/^ +/', $text, $matches)) { - $num = strlen($matches[0]); - $xmlWriter->startElement('text:s'); - $xmlWriter->writeAttributeIf($num > 1, 'text:c', "$num"); - $xmlWriter->endElement(); - $text = preg_replace('/^ +/', '', $text); - } - preg_match_all('/([\\s\\S]*?)(\\t| +| ?$)/', $text, $matches, PREG_SET_ORDER); - foreach ($matches as $match) { - $this->writeText($match[1]); - if ($match[2] === '') { - break; - } elseif ($match[2] === "\t") { - $xmlWriter->writeElement('text:tab'); - } elseif ($match[2] === ' ') { - $xmlWriter->writeElement('text:s'); - - break; - } else { - $num = strlen($match[2]); - $xmlWriter->startElement('text:s'); - $xmlWriter->writeAttributeIf($num > 1, 'text:c', "$num"); - $xmlWriter->endElement(); - } - } - } - private function writeChangeInsertion($start = true, ?TrackChange $trackChange = null): void { if ($trackChange == null || $trackChange->getChangeType() != TrackChange::INSERTED) { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/TextBreak.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/TextBreak.php index 1bfe3988..1a697007 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/TextBreak.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Element/TextBreak.php @@ -1,4 +1,5 @@ imageParagraphStyles as $style) { - $styleWriter = new \PhpOffice\PhpWord\Writer\ODText\Style\Paragraph($xmlWriter, $style); + $styleWriter = new ParagraphStyleWriter($xmlWriter, $style); $styleWriter->write(); } } @@ -256,7 +257,7 @@ class Content extends AbstractPart * * Table style can be null or string of the style name * - * @param \PhpOffice\PhpWord\Element\AbstractContainer $container + * @param AbstractContainer $container * @param int $paragraphStyleCount * @param int $fontStyleCount * @@ -277,7 +278,7 @@ class Content extends AbstractPart $style = $element->getStyle(); $style->setStyleName('fr' . $element->getMediaIndex()); $this->autoStyles['Image'][] = $style; - $sty = new \PhpOffice\PhpWord\Style\Paragraph(); + $sty = new Paragraph(); $sty->setStyleName('IM' . $element->getMediaIndex()); $sty->setAuto(); $sty->setAlignment($style->getAlignment()); @@ -300,7 +301,7 @@ class Content extends AbstractPart /** * Get style of individual element. * - * @param \PhpOffice\PhpWord\Element\Text $element + * @param Text $element * @param int $paragraphStyleCount * @param int $fontStyleCount */ @@ -346,7 +347,7 @@ class Content extends AbstractPart /** * Get font style of individual field element. * - * @param \PhpOffice\PhpWord\Element\Field $element + * @param Field $element * @param int $fontStyleCount */ private function getElementStyleField($element, &$fontStyleCount): void @@ -371,7 +372,7 @@ class Content extends AbstractPart /** * Get style of individual element. * - * @param \PhpOffice\PhpWord\Element\TextRun $element + * @param TextRun $element * @param int $paragraphStyleCount */ private function getElementStyleTextRun($element, &$paragraphStyleCount): void diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Part/Manifest.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Part/Manifest.php index 37fb7979..200da158 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Part/Manifest.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Part/Manifest.php @@ -1,4 +1,5 @@ startElement('style:text-properties'); - $xmlWriter->writeAttribute('style:use-window-font-color', 'true'); + $xmlWriter->writeAttribute('style:use-window-font-color', 'false'); $xmlWriter->writeAttribute('style:font-name', Settings::getDefaultFontName()); $xmlWriter->writeAttribute('fo:font-size', Settings::getDefaultFontSize() . 'pt'); $xmlWriter->writeAttribute('fo:language', $latinLang[0]); $xmlWriter->writeAttribute('fo:country', $latinLang[1]); + $xmlWriter->writeAttribute('fo:color', '#' . Settings::getDefaultFontColor()); $xmlWriter->writeAttribute('style:letter-kerning', 'true'); $xmlWriter->writeAttribute('style:font-name-asian', Settings::getDefaultFontName() . '2'); $xmlWriter->writeAttribute('style:font-size-asian', Settings::getDefaultFontSize() . 'pt'); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/AbstractStyle.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/AbstractStyle.php index 439434c9..3545009f 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/AbstractStyle.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/AbstractStyle.php @@ -1,4 +1,5 @@ setStyleName($style->getStyleName()); - $temp2 = new \PhpOffice\PhpWord\Writer\ODText\Style\Paragraph($xmlWriter, $temp1); + $temp2 = new Paragraph($xmlWriter, $temp1); $temp2->write(); } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Image.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Image.php index 79ddfc50..56c4f57a 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Image.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Image.php @@ -1,4 +1,5 @@ getStyle(); - if (!$style instanceof \PhpOffice\PhpWord\Style\Paragraph) { + if (!$style instanceof Style\Paragraph) { return; } $xmlWriter = $this->getXmlWriter(); @@ -73,13 +74,13 @@ class Paragraph extends AbstractStyle } elseif (substr($styleName, 0, 2) === 'HD') { $styleAuto = true; $psm = 'Heading_' . substr($styleName, 2); - $stylep = \PhpOffice\PhpWord\Style::getStyle($psm); - if ($stylep instanceof \PhpOffice\PhpWord\Style\Font) { + $stylep = Style::getStyle($psm); + if ($stylep instanceof Style\Font) { if (method_exists($stylep, 'getParagraph')) { $stylep = $stylep->getParagraph(); } } - if ($stylep instanceof \PhpOffice\PhpWord\Style\Paragraph) { + if ($stylep instanceof Style\Paragraph) { if ($stylep->hasPageBreakBefore()) { $breakbefore = true; } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Section.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Section.php index 0a250194..05152a39 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Section.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/ODText/Style/Section.php @@ -1,4 +1,5 @@ parts as $partName) { $partClass = static::class . '\\Part\\' . $partName; if (class_exists($partClass)) { - /** @var \PhpOffice\PhpWord\Writer\RTF\Part\AbstractPart $part Type hint */ + /** @var RTF\Part\AbstractPart $part Type hint */ $part = new $partClass(); $part->setParentWriter($this); $this->writerParts[strtolower($partName)] = $part; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/AbstractElement.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/AbstractElement.php index 5c33868a..e007e6aa 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/AbstractElement.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/AbstractElement.php @@ -1,4 +1,5 @@ parentWriter; /** @var \PhpOffice\PhpWord\Element\Text $element Type hint */ @@ -188,7 +189,7 @@ abstract class AbstractElement return ''; } - /** @var \PhpOffice\PhpWord\Writer\RTF $parentWriter Type hint */ + /** @var WriterRTF $parentWriter Type hint */ $parentWriter = $this->parentWriter; // Create style writer and set color/name index diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/Container.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/Container.php index 5e198aec..dcac8ec0 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/Container.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Element/Container.php @@ -1,4 +1,5 @@ element; $elementClass = str_replace('\\Writer\\RTF', '', static::class); - if (!$element instanceof $elementClass || !is_string($element->getText())) { + if (!$element instanceof $elementClass) { return ''; } + $textToWrite = $element->getText(); + if ($textToWrite instanceof \PhpOffice\PhpWord\Element\TextRun) { + $textToWrite = $textToWrite->getText(); // gets text from TextRun + } + $this->getStyles(); $content = ''; @@ -82,7 +88,7 @@ class Title extends Text $content .= '{'; $content .= $this->writeFontStyle(); - $content .= $this->writeText($element->getText()); + $content .= $this->writeText($textToWrite); $content .= '}'; $content .= $this->writeClosing(); $content .= $endout; diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/AbstractPart.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/AbstractPart.php index be772b93..a07f70bb 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/AbstractPart.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/AbstractPart.php @@ -1,4 +1,5 @@ getHeaders() as $header) { $type = $header->getType(); - if ($evenOdd || $type !== FOOTER::EVEN) { + if ($evenOdd || $type !== Footer::EVEN) { $content .= '{\\header'; if ($type === Footer::FIRST) { $content .= 'f'; } elseif ($evenOdd) { - $content .= ($type === FOOTER::EVEN) ? 'l' : 'r'; + $content .= ($type === Footer::EVEN) ? 'l' : 'r'; } foreach ($header->getElements() as $element) { $cl = get_class($element); @@ -182,12 +183,12 @@ class Document extends AbstractPart } foreach ($section->getFooters() as $footer) { $type = $footer->getType(); - if ($evenOdd || $type !== FOOTER::EVEN) { + if ($evenOdd || $type !== Footer::EVEN) { $content .= '{\\footer'; if ($type === Footer::FIRST) { $content .= 'f'; } elseif ($evenOdd) { - $content .= ($type === FOOTER::EVEN) ? 'l' : 'r'; + $content .= ($type === Footer::EVEN) ? 'l' : 'r'; } foreach ($footer->getElements() as $element) { $cl = get_class($element); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/Header.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/Header.php index 7f8cc84b..97644fe4 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/Header.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/RTF/Part/Header.php @@ -1,4 +1,5 @@ parts) as $partName) { $partClass = static::class . '\\Part\\' . $partName; if (class_exists($partClass)) { - /** @var \PhpOffice\PhpWord\Writer\Word2007\Part\AbstractPart $part Type hint */ + /** @var Word2007\Part\AbstractPart $part Type hint */ $part = new $partClass(); $part->setParentWriter($this); $this->writerParts[strtolower($partName)] = $part; @@ -179,7 +178,7 @@ class Word2007 extends AbstractWriter implements WriterInterface $this->registerContentTypes($media); } - /** @var \PhpOffice\PhpWord\Writer\Word2007\Part\AbstractPart $writerPart Type hint */ + /** @var Word2007\Part\AbstractPart $writerPart Type hint */ $writerPart = $this->getWriterPart('relspart')->setMedia($media); $zip->addFromString("word/_rels/{$file}.xml.rels", $writerPart->write()); } @@ -206,7 +205,7 @@ class Word2007 extends AbstractWriter implements WriterInterface $this->contentTypes['override']["/word/$elmFile"] = $elmType; $this->relationships[] = ['target' => $elmFile, 'type' => $elmType, 'rID' => $rId]; - /** @var \PhpOffice\PhpWord\Writer\Word2007\Part\AbstractPart $writerPart Type hint */ + /** @var Word2007\Part\AbstractPart $writerPart Type hint */ $writerPart = $this->getWriterPart($elmType)->setElement($element); $zip->addFromString("word/$elmFile", $writerPart->write()); } @@ -236,7 +235,7 @@ class Word2007 extends AbstractWriter implements WriterInterface // Write relationships file, e.g. word/_rels/footnotes.xml if (!empty($media)) { - /** @var \PhpOffice\PhpWord\Writer\Word2007\Part\AbstractPart $writerPart Type hint */ + /** @var Word2007\Part\AbstractPart $writerPart Type hint */ $writerPart = $this->getWriterPart('relspart')->setMedia($media); $zip->addFromString("word/_rels/{$partName}.xml.rels", $writerPart->write()); } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/AbstractElement.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/AbstractElement.php index b677556d..5743c8c7 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/AbstractElement.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/AbstractElement.php @@ -1,4 +1,5 @@ xmlWriter = $xmlWriter; $this->element = $element; @@ -76,7 +75,7 @@ abstract class AbstractElement /** * Get XML Writer. * - * @return \PhpOffice\PhpWord\Shared\XMLWriter + * @return XMLWriter */ protected function getXmlWriter() { @@ -86,7 +85,7 @@ abstract class AbstractElement /** * Get element. * - * @return \PhpOffice\PhpWord\Element\AbstractElement + * @return Element */ protected function getElement() { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Bookmark.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Bookmark.php index 1e618af9..ba61ad69 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Bookmark.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Bookmark.php @@ -1,4 +1,5 @@ + */ + protected $containerWithoutP = ['TextRun', 'Footnote', 'Endnote', 'ListItemRun']; + /** * Write element. */ @@ -46,7 +52,7 @@ class Container extends AbstractElement return; } $containerClass = substr(get_class($container), strrpos(get_class($container), '\\') + 1); - $withoutP = in_array($containerClass, ['TextRun', 'Footnote', 'Endnote', 'ListItemRun']); + $withoutP = in_array($containerClass, $this->containerWithoutP); $xmlWriter = $this->getXmlWriter(); // Loop through elements @@ -62,7 +68,7 @@ class Container extends AbstractElement $writeLastTextBreak = ($containerClass == 'Cell') && ($elementClass == '' || $elementClass == 'Table'); if ($writeLastTextBreak) { $writerClass = $this->namespace . '\\TextBreak'; - /** @var \PhpOffice\PhpWord\Writer\Word2007\Element\AbstractElement $writer Type hint */ + /** @var AbstractElement $writer Type hint */ $writer = new $writerClass($xmlWriter, new TextBreakElement(), $withoutP); $writer->write(); } @@ -70,18 +76,14 @@ class Container extends AbstractElement /** * Write individual element. - * - * @param bool $withoutP - * - * @return string */ - private function writeElement(XMLWriter $xmlWriter, Element $element, $withoutP) + private function writeElement(XMLWriter $xmlWriter, Element $element, bool $withoutP): string { $elementClass = substr(get_class($element), strrpos(get_class($element), '\\') + 1); $writerClass = $this->namespace . '\\' . $elementClass; if (class_exists($writerClass)) { - /** @var \PhpOffice\PhpWord\Writer\Word2007\Element\AbstractElement $writer Type hint */ + /** @var AbstractElement $writer Type hint */ $writer = new $writerClass($xmlWriter, $element, $withoutP); $writer->setPart($this->getPart()); $writer->write(); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Endnote.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Endnote.php index f96ac797..6a00ed5b 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Endnote.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Endnote.php @@ -1,4 +1,5 @@ endElement(); // w:r if ($element->getText() != null) { - if ($element->getText() instanceof \PhpOffice\PhpWord\Element\TextRun) { + if ($element->getText() instanceof TextRun) { $containerWriter = new Container($xmlWriter, $element->getText(), true); $containerWriter->write(); } @@ -262,7 +263,7 @@ class Field extends Text $xmlWriter->endElement(); // w:r if ($element->getText() != null) { - if ($element->getText() instanceof \PhpOffice\PhpWord\Element\TextRun) { + if ($element->getText() instanceof TextRun) { $containerWriter = new Container($xmlWriter, $element->getText(), true); $containerWriter->write(); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Footnote.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Footnote.php index 77073a23..68f998e3 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Footnote.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Footnote.php @@ -1,4 +1,5 @@ startElement('w:r'); $xmlWriter->startElement('w:instrText'); $xmlWriter->writeAttribute('xml:space', 'preserve'); - $xmlWriter->text("PAGEREF _Toc{$rId} \\h"); + $xmlWriter->text("PAGEREF $rId \\h"); $xmlWriter->endElement(); $xmlWriter->endElement(); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Table.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Table.php index a32cc196..2bb1b3f3 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Table.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/Table.php @@ -1,4 +1,5 @@ getBgColor()) { $xmlWriter->writeAttribute('fillcolor', $style->getBgColor()); + } else { + $xmlWriter->writeAttribute('filled', 'f'); + } + + if (!$style->getBorderColor()) { + $xmlWriter->writeAttribute('stroked', 'f'); + $xmlWriter->writeAttribute('strokecolor', 'white'); } $styleWriter->write(); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/TextBreak.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/TextBreak.php index bcae3b2e..4c2ecde7 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/TextBreak.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Element/TextBreak.php @@ -1,4 +1,5 @@ getSalt() == null) { - $documentProtection->setSalt(openssl_random_pseudo_bytes(16)); + $documentProtection->setSalt((string) openssl_random_pseudo_bytes(16)); } $passwordHash = PasswordEncoder::hashPassword($documentProtection->getPassword(), $documentProtection->getAlgorithm(), $documentProtection->getSalt(), $documentProtection->getSpinCount()); $this->settings['w:documentProtection'] = [ diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Styles.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Styles.php index 2112fd3c..edf0314c 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Styles.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Styles.php @@ -1,4 +1,5 @@ getParentWriter()->getPhpWord(); $fontName = $phpWord->getDefaultFontName(); + $asianFontName = $phpWord->getDefaultAsianFontName(); $fontSize = $phpWord->getDefaultFontSize(); + $fontColor = $phpWord->getDefaultFontColor(); $language = $phpWord->getSettings()->getThemeFontLang(); $latinLanguage = ($language == null || $language->getLatin() === null) ? 'en-US' : $language->getLatin(); @@ -94,9 +97,12 @@ class Styles extends AbstractPart $xmlWriter->startElement('w:rFonts'); $xmlWriter->writeAttribute('w:ascii', $fontName); $xmlWriter->writeAttribute('w:hAnsi', $fontName); - $xmlWriter->writeAttribute('w:eastAsia', $fontName); + $xmlWriter->writeAttribute('w:eastAsia', $asianFontName); $xmlWriter->writeAttribute('w:cs', $fontName); $xmlWriter->endElement(); // w:rFonts + $xmlWriter->startElement('w:color'); + $xmlWriter->writeAttribute('w:val', $fontColor); + $xmlWriter->endElement(); $xmlWriter->startElement('w:sz'); $xmlWriter->writeAttribute('w:val', $fontSize * 2); $xmlWriter->endElement(); // w:sz @@ -125,7 +131,7 @@ class Styles extends AbstractPart if (isset($styles['Normal'])) { $normalStyle = $styles['Normal']; // w:pPr - if ($normalStyle instanceof Fontstyle && $normalStyle->getParagraph() != null) { + if ($normalStyle instanceof FontStyle && $normalStyle->getParagraph() != null) { $styleWriter = new ParagraphStyleWriter($xmlWriter, $normalStyle->getParagraph()); $styleWriter->write(); } elseif ($normalStyle instanceof ParagraphStyle) { diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Theme.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Theme.php index ad57d664..a70c248d 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Theme.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Part/Theme.php @@ -1,4 +1,5 @@ write(); } diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Cell.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Cell.php index 6e22597d..bb0d6d71 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Cell.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Cell.php @@ -1,4 +1,5 @@ endElement(); // w:tcW } + $paddingTop = $style->getPaddingTop(); + $paddingLeft = $style->getPaddingLeft(); + $paddingBottom = $style->getPaddingBottom(); + $paddingRight = $style->getPaddingRight(); + + if ($paddingTop !== null || $paddingLeft !== null || $paddingBottom !== null || $paddingRight !== null) { + $xmlWriter->startElement('w:tcMar'); + if ($paddingTop !== null) { + $xmlWriter->startElement('w:top'); + $xmlWriter->writeAttribute('w:w', $paddingTop); + $xmlWriter->writeAttribute('w:type', \PhpOffice\PhpWord\SimpleType\TblWidth::TWIP); + $xmlWriter->endElement(); // w:top + } + if ($paddingLeft !== null) { + $xmlWriter->startElement('w:start'); + $xmlWriter->writeAttribute('w:w', $paddingLeft); + $xmlWriter->writeAttribute('w:type', \PhpOffice\PhpWord\SimpleType\TblWidth::TWIP); + $xmlWriter->endElement(); // w:start + } + if ($paddingBottom !== null) { + $xmlWriter->startElement('w:bottom'); + $xmlWriter->writeAttribute('w:w', $paddingBottom); + $xmlWriter->writeAttribute('w:type', \PhpOffice\PhpWord\SimpleType\TblWidth::TWIP); + $xmlWriter->endElement(); // w:bottom + } + if ($paddingRight !== null) { + $xmlWriter->startElement('w:end'); + $xmlWriter->writeAttribute('w:w', $paddingRight); + $xmlWriter->writeAttribute('w:type', \PhpOffice\PhpWord\SimpleType\TblWidth::TWIP); + $xmlWriter->endElement(); // w:end + } + $xmlWriter->endElement(); // w:tcMar + } + // Text direction $textDir = $style->getTextDirection(); $xmlWriter->writeElementIf(null !== $textDir, 'w:textDirection', 'w:val', $textDir); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Extrusion.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Extrusion.php index f6ad6221..8bb92187 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Extrusion.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Extrusion.php @@ -1,4 +1,5 @@ getFirstLine(); $xmlWriter->writeAttributeIf(null !== $firstLine, 'w:firstLine', $this->convertTwip($firstLine)); + $firstLineChars = $style->getFirstLineChars(); + $xmlWriter->writeAttributeIf(0 !== $firstLineChars, 'w:firstLineChars', $this->convertTwip($firstLineChars)); + $hanging = $style->getHanging(); $xmlWriter->writeAttributeIf(null !== $hanging, 'w:hanging', $this->convertTwip($hanging)); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Line.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Line.php index 90107f8e..2603545f 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Line.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Line.php @@ -1,4 +1,5 @@ startElement('w:numPr'); diff --git a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Row.php b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Row.php index 7e1468e8..2b9d804f 100644 --- a/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Row.php +++ b/vendor/phpoffice/phpword/src/PhpWord/Writer/Word2007/Style/Row.php @@ -1,4 +1,5 @@ =5.3.0" - }, - "autoload": { - "psr-4": { - "Psr\\Cache\\": "src/" - } - }, - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - } -} diff --git a/vendor/psr/cache/src/CacheException.php b/vendor/psr/cache/src/CacheException.php deleted file mode 100644 index e27f22f8..00000000 --- a/vendor/psr/cache/src/CacheException.php +++ /dev/null @@ -1,10 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * ApcClassLoader implements a wrapping autoloader cached in APC for PHP 5.3. - * - * It expects an object implementing a findFile method to find the file. This - * allows using it as a wrapper around the other loaders of the component (the - * ClassLoader for instance) but also around any other autoloaders following - * this convention (the Composer one for instance). - * - * // with a Symfony autoloader - * use Symfony\Component\ClassLoader\ClassLoader; - * - * $loader = new ClassLoader(); - * $loader->addPrefix('Symfony\Component', __DIR__.'/component'); - * $loader->addPrefix('Symfony', __DIR__.'/framework'); - * - * // or with a Composer autoloader - * use Composer\Autoload\ClassLoader; - * - * $loader = new ClassLoader(); - * $loader->add('Symfony\Component', __DIR__.'/component'); - * $loader->add('Symfony', __DIR__.'/framework'); - * - * $cachedLoader = new ApcClassLoader('my_prefix', $loader); - * - * // activate the cached autoloader - * $cachedLoader->register(); - * - * // eventually deactivate the non-cached loader if it was registered previously - * // to be sure to use the cached one. - * $loader->unregister(); - * - * @author Fabien Potencier - * @author Kris Wallsmith - */ -class ApcClassLoader -{ - private $prefix; - - /** - * A class loader object that implements the findFile() method. - * - * @var object - */ - protected $decorated; - - /** - * Constructor. - * - * @param string $prefix The APC namespace prefix to use - * @param object $decorated A class loader object that implements the findFile() method - * - * @throws \RuntimeException - * @throws \InvalidArgumentException - */ - public function __construct($prefix, $decorated) - { - if (!function_exists('apcu_fetch')) { - throw new \RuntimeException('Unable to use ApcClassLoader as APC is not installed.'); - } - - if (!method_exists($decorated, 'findFile')) { - throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); - } - - $this->prefix = $prefix; - $this->decorated = $decorated; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend Whether to prepend the autoloader or not - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Unregisters this instance as an autoloader. - */ - public function unregister() - { - spl_autoload_unregister(array($this, 'loadClass')); - } - - /** - * Loads the given class or interface. - * - * @param string $class The name of the class - * - * @return bool|null True, if loaded - */ - public function loadClass($class) - { - if ($file = $this->findFile($class)) { - require $file; - - return true; - } - } - - /** - * Finds a file by class name while caching lookups to APC. - * - * @param string $class A class name to resolve to file - * - * @return string|null - */ - public function findFile($class) - { - $file = apcu_fetch($this->prefix.$class, $success); - - if (!$success) { - apcu_store($this->prefix.$class, $file = $this->decorated->findFile($class) ?: null); - } - - return $file; - } - - /** - * Passes through all unknown calls onto the decorated object. - */ - public function __call($method, $args) - { - return call_user_func_array(array($this->decorated, $method), $args); - } -} diff --git a/vendor/symfony/class-loader/CHANGELOG.md b/vendor/symfony/class-loader/CHANGELOG.md deleted file mode 100644 index 64ef8d9c..00000000 --- a/vendor/symfony/class-loader/CHANGELOG.md +++ /dev/null @@ -1,36 +0,0 @@ -CHANGELOG -========= - -3.0.0 ------ - - * The DebugClassLoader class has been removed - * The DebugUniversalClassLoader class has been removed - * The UniversalClassLoader class has been removed - * The ApcUniversalClassLoader class has been removed - -2.4.0 ------ - - * deprecated the UniversalClassLoader in favor of the ClassLoader class instead - * deprecated the ApcUniversalClassLoader in favor of the ApcClassLoader class instead - * deprecated the DebugUniversalClassLoader in favor of the DebugClassLoader class from the Debug component - * deprecated the DebugClassLoader as it has been moved to the Debug component instead - -2.3.0 ------ - - * added a WinCacheClassLoader for WinCache - -2.1.0 ------ - - * added a DebugClassLoader able to wrap any autoloader providing a findFile - method - * added a new ApcClassLoader and XcacheClassLoader using composition to wrap - other loaders - * added a new ClassLoader which does not distinguish between namespaced and - pear-like classes (as the PEAR convention is a subset of PSR-0) and - supports using Composer's namespace maps - * added a class map generator - * added support for loading globally-installed PEAR packages diff --git a/vendor/symfony/class-loader/ClassCollectionLoader.php b/vendor/symfony/class-loader/ClassCollectionLoader.php deleted file mode 100644 index 1d53c482..00000000 --- a/vendor/symfony/class-loader/ClassCollectionLoader.php +++ /dev/null @@ -1,444 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * ClassCollectionLoader. - * - * @author Fabien Potencier - */ -class ClassCollectionLoader -{ - private static $loaded; - private static $seen; - private static $useTokenizer = true; - - /** - * Loads a list of classes and caches them in one big file. - * - * @param array $classes An array of classes to load - * @param string $cacheDir A cache directory - * @param string $name The cache name prefix - * @param bool $autoReload Whether to flush the cache when the cache is stale or not - * @param bool $adaptive Whether to remove already declared classes or not - * @param string $extension File extension of the resulting file - * - * @throws \InvalidArgumentException When class can't be loaded - */ - public static function load($classes, $cacheDir, $name, $autoReload, $adaptive = false, $extension = '.php') - { - // each $name can only be loaded once per PHP process - if (isset(self::$loaded[$name])) { - return; - } - - self::$loaded[$name] = true; - - if ($adaptive) { - $declared = array_merge(get_declared_classes(), get_declared_interfaces(), get_declared_traits()); - - // don't include already declared classes - $classes = array_diff($classes, $declared); - - // the cache is different depending on which classes are already declared - $name = $name.'-'.substr(hash('sha256', implode('|', $classes)), 0, 5); - } - - $classes = array_unique($classes); - - // cache the core classes - if (!is_dir($cacheDir) && !@mkdir($cacheDir, 0777, true) && !is_dir($cacheDir)) { - throw new \RuntimeException(sprintf('Class Collection Loader was not able to create directory "%s"', $cacheDir)); - } - $cacheDir = rtrim(realpath($cacheDir) ?: $cacheDir, '/'.DIRECTORY_SEPARATOR); - $cache = $cacheDir.'/'.$name.$extension; - - // auto-reload - $reload = false; - if ($autoReload) { - $metadata = $cache.'.meta'; - if (!is_file($metadata) || !is_file($cache)) { - $reload = true; - } else { - $time = filemtime($cache); - $meta = unserialize(file_get_contents($metadata)); - - sort($meta[1]); - sort($classes); - - if ($meta[1] != $classes) { - $reload = true; - } else { - foreach ($meta[0] as $resource) { - if (!is_file($resource) || filemtime($resource) > $time) { - $reload = true; - - break; - } - } - } - } - } - - if (!$reload && file_exists($cache)) { - require_once $cache; - - return; - } - if (!$adaptive) { - $declared = array_merge(get_declared_classes(), get_declared_interfaces(), get_declared_traits()); - } - - $files = self::inline($classes, $cache, $declared); - - if ($autoReload) { - // save the resources - self::writeCacheFile($metadata, serialize(array(array_values($files), $classes))); - } - } - - /** - * Generates a file where classes and their parents are inlined. - * - * @param array $classes An array of classes to load - * @param string $cache The file where classes are inlined - * @param array $excluded An array of classes that won't be inlined - * - * @return array The source map of inlined classes, with classes as keys and files as values - * - * @throws \RuntimeException When class can't be loaded - */ - public static function inline($classes, $cache, array $excluded) - { - $declared = array(); - foreach (self::getOrderedClasses($excluded) as $class) { - $declared[$class->getName()] = true; - } - - // cache the core classes - $cacheDir = dirname($cache); - if (!is_dir($cacheDir) && !@mkdir($cacheDir, 0777, true) && !is_dir($cacheDir)) { - throw new \RuntimeException(sprintf('Class Collection Loader was not able to create directory "%s"', $cacheDir)); - } - - $spacesRegex = '(?:\s*+(?:(?:\#|//)[^\n]*+\n|/\*(?:(?getName()])) { - continue; - } - $declared[$class->getName()] = true; - - $files[$class->getName()] = $file = $class->getFileName(); - $c = file_get_contents($file); - - if (preg_match($dontInlineRegex, $c)) { - $file = explode('/', str_replace(DIRECTORY_SEPARATOR, '/', $file)); - - for ($i = 0; isset($file[$i], $cacheDir[$i]); ++$i) { - if ($file[$i] !== $cacheDir[$i]) { - break; - } - } - if (1 >= $i) { - $file = var_export(implode('/', $file), true); - } else { - $file = array_slice($file, $i); - $file = str_repeat('../', count($cacheDir) - $i).implode('/', $file); - $file = '__DIR__.'.var_export('/'.$file, true); - } - - $c = "\nnamespace {require $file;}"; - } else { - $c = preg_replace(array('/^\s*<\?php/', '/\?>\s*$/'), '', $c); - - // fakes namespace declaration for global code - if (!$class->inNamespace()) { - $c = "\nnamespace\n{\n".$c."\n}\n"; - } - - $c = self::fixNamespaceDeclarations('= 70000) { - // PHP 7 memory manager will not release after token_get_all(), see https://bugs.php.net/70098 - unset($tokens, $rawChunk); - gc_mem_caches(); - } - - return $output; - } - - /** - * This method is only useful for testing. - */ - public static function enableTokenizer($bool) - { - self::$useTokenizer = (bool) $bool; - } - - /** - * Strips leading & trailing ws, multiple EOL, multiple ws. - * - * @param string $code Original PHP code - * - * @return string compressed code - */ - private static function compressCode($code) - { - return preg_replace( - array('/^\s+/m', '/\s+$/m', '/([\n\r]+ *[\n\r]+)+/', '/[ \t]+/'), - array('', '', "\n", ' '), - $code - ); - } - - /** - * Writes a cache file. - * - * @param string $file Filename - * @param string $content Temporary file content - * - * @throws \RuntimeException when a cache file cannot be written - */ - private static function writeCacheFile($file, $content) - { - $dir = dirname($file); - if (!is_writable($dir)) { - throw new \RuntimeException(sprintf('Cache directory "%s" is not writable.', $dir)); - } - - $tmpFile = tempnam($dir, basename($file)); - - if (false !== @file_put_contents($tmpFile, $content) && @rename($tmpFile, $file)) { - @chmod($file, 0666 & ~umask()); - - return; - } - - throw new \RuntimeException(sprintf('Failed to write cache file "%s".', $file)); - } - - /** - * Gets an ordered array of passed classes including all their dependencies. - * - * @param array $classes - * - * @return \ReflectionClass[] An array of sorted \ReflectionClass instances (dependencies added if needed) - * - * @throws \InvalidArgumentException When a class can't be loaded - */ - private static function getOrderedClasses(array $classes) - { - $map = array(); - self::$seen = array(); - foreach ($classes as $class) { - try { - $reflectionClass = new \ReflectionClass($class); - } catch (\ReflectionException $e) { - throw new \InvalidArgumentException(sprintf('Unable to load class "%s"', $class)); - } - - $map = array_merge($map, self::getClassHierarchy($reflectionClass)); - } - - return $map; - } - - private static function getClassHierarchy(\ReflectionClass $class) - { - if (isset(self::$seen[$class->getName()])) { - return array(); - } - - self::$seen[$class->getName()] = true; - - $classes = array($class); - $parent = $class; - while (($parent = $parent->getParentClass()) && $parent->isUserDefined() && !isset(self::$seen[$parent->getName()])) { - self::$seen[$parent->getName()] = true; - - array_unshift($classes, $parent); - } - - $traits = array(); - - foreach ($classes as $c) { - foreach (self::resolveDependencies(self::computeTraitDeps($c), $c) as $trait) { - if ($trait !== $c) { - $traits[] = $trait; - } - } - } - - return array_merge(self::getInterfaces($class), $traits, $classes); - } - - private static function getInterfaces(\ReflectionClass $class) - { - $classes = array(); - - foreach ($class->getInterfaces() as $interface) { - $classes = array_merge($classes, self::getInterfaces($interface)); - } - - if ($class->isUserDefined() && $class->isInterface() && !isset(self::$seen[$class->getName()])) { - self::$seen[$class->getName()] = true; - - $classes[] = $class; - } - - return $classes; - } - - private static function computeTraitDeps(\ReflectionClass $class) - { - $traits = $class->getTraits(); - $deps = array($class->getName() => $traits); - while ($trait = array_pop($traits)) { - if ($trait->isUserDefined() && !isset(self::$seen[$trait->getName()])) { - self::$seen[$trait->getName()] = true; - $traitDeps = $trait->getTraits(); - $deps[$trait->getName()] = $traitDeps; - $traits = array_merge($traits, $traitDeps); - } - } - - return $deps; - } - - /** - * Dependencies resolution. - * - * This function does not check for circular dependencies as it should never - * occur with PHP traits. - * - * @param array $tree The dependency tree - * @param \ReflectionClass $node The node - * @param \ArrayObject $resolved An array of already resolved dependencies - * @param \ArrayObject $unresolved An array of dependencies to be resolved - * - * @return \ArrayObject The dependencies for the given node - * - * @throws \RuntimeException if a circular dependency is detected - */ - private static function resolveDependencies(array $tree, $node, \ArrayObject $resolved = null, \ArrayObject $unresolved = null) - { - if (null === $resolved) { - $resolved = new \ArrayObject(); - } - if (null === $unresolved) { - $unresolved = new \ArrayObject(); - } - $nodeName = $node->getName(); - - if (isset($tree[$nodeName])) { - $unresolved[$nodeName] = $node; - foreach ($tree[$nodeName] as $dependency) { - if (!$resolved->offsetExists($dependency->getName())) { - self::resolveDependencies($tree, $dependency, $resolved, $unresolved); - } - } - $resolved[$nodeName] = $node; - unset($unresolved[$nodeName]); - } - - return $resolved; - } -} diff --git a/vendor/symfony/class-loader/ClassLoader.php b/vendor/symfony/class-loader/ClassLoader.php deleted file mode 100644 index a506dc09..00000000 --- a/vendor/symfony/class-loader/ClassLoader.php +++ /dev/null @@ -1,203 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * ClassLoader implements an PSR-0 class loader. - * - * See https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md - * - * $loader = new ClassLoader(); - * - * // register classes with namespaces - * $loader->addPrefix('Symfony\Component', __DIR__.'/component'); - * $loader->addPrefix('Symfony', __DIR__.'/framework'); - * - * // activate the autoloader - * $loader->register(); - * - * // to enable searching the include path (e.g. for PEAR packages) - * $loader->setUseIncludePath(true); - * - * In this example, if you try to use a class in the Symfony\Component - * namespace or one of its children (Symfony\Component\Console for instance), - * the autoloader will first look for the class under the component/ - * directory, and it will then fallback to the framework/ directory if not - * found before giving up. - * - * @author Fabien Potencier - * @author Jordi Boggiano - */ -class ClassLoader -{ - private $prefixes = array(); - private $fallbackDirs = array(); - private $useIncludePath = false; - - /** - * Returns prefixes. - * - * @return array - */ - public function getPrefixes() - { - return $this->prefixes; - } - - /** - * Returns fallback directories. - * - * @return array - */ - public function getFallbackDirs() - { - return $this->fallbackDirs; - } - - /** - * Adds prefixes. - * - * @param array $prefixes Prefixes to add - */ - public function addPrefixes(array $prefixes) - { - foreach ($prefixes as $prefix => $path) { - $this->addPrefix($prefix, $path); - } - } - - /** - * Registers a set of classes. - * - * @param string $prefix The classes prefix - * @param array|string $paths The location(s) of the classes - */ - public function addPrefix($prefix, $paths) - { - if (!$prefix) { - foreach ((array) $paths as $path) { - $this->fallbackDirs[] = $path; - } - - return; - } - if (isset($this->prefixes[$prefix])) { - if (is_array($paths)) { - $this->prefixes[$prefix] = array_unique(array_merge( - $this->prefixes[$prefix], - $paths - )); - } elseif (!in_array($paths, $this->prefixes[$prefix])) { - $this->prefixes[$prefix][] = $paths; - } - } else { - $this->prefixes[$prefix] = array_unique((array) $paths); - } - } - - /** - * Turns on searching the include for class files. - * - * @param bool $useIncludePath - */ - public function setUseIncludePath($useIncludePath) - { - $this->useIncludePath = (bool) $useIncludePath; - } - - /** - * Can be used to check if the autoloader uses the include path to check - * for classes. - * - * @return bool - */ - public function getUseIncludePath() - { - return $this->useIncludePath; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend Whether to prepend the autoloader or not - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Unregisters this instance as an autoloader. - */ - public function unregister() - { - spl_autoload_unregister(array($this, 'loadClass')); - } - - /** - * Loads the given class or interface. - * - * @param string $class The name of the class - * - * @return bool|null True, if loaded - */ - public function loadClass($class) - { - if ($file = $this->findFile($class)) { - require $file; - - return true; - } - } - - /** - * Finds the path to the file where the class is defined. - * - * @param string $class The name of the class - * - * @return string|null The path, if found - */ - public function findFile($class) - { - if (false !== $pos = strrpos($class, '\\')) { - // namespaced class name - $classPath = str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 0, $pos)).DIRECTORY_SEPARATOR; - $className = substr($class, $pos + 1); - } else { - // PEAR-like class name - $classPath = null; - $className = $class; - } - - $classPath .= str_replace('_', DIRECTORY_SEPARATOR, $className).'.php'; - - foreach ($this->prefixes as $prefix => $dirs) { - if ($class === strstr($class, $prefix)) { - foreach ($dirs as $dir) { - if (file_exists($dir.DIRECTORY_SEPARATOR.$classPath)) { - return $dir.DIRECTORY_SEPARATOR.$classPath; - } - } - } - } - - foreach ($this->fallbackDirs as $dir) { - if (file_exists($dir.DIRECTORY_SEPARATOR.$classPath)) { - return $dir.DIRECTORY_SEPARATOR.$classPath; - } - } - - if ($this->useIncludePath && $file = stream_resolve_include_path($classPath)) { - return $file; - } - } -} diff --git a/vendor/symfony/class-loader/ClassMapGenerator.php b/vendor/symfony/class-loader/ClassMapGenerator.php deleted file mode 100644 index baeb4c1a..00000000 --- a/vendor/symfony/class-loader/ClassMapGenerator.php +++ /dev/null @@ -1,156 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * ClassMapGenerator. - * - * @author Gyula Sallai - */ -class ClassMapGenerator -{ - /** - * Generate a class map file. - * - * @param array|string $dirs Directories or a single path to search in - * @param string $file The name of the class map file - */ - public static function dump($dirs, $file) - { - $dirs = (array) $dirs; - $maps = array(); - - foreach ($dirs as $dir) { - $maps = array_merge($maps, static::createMap($dir)); - } - - file_put_contents($file, sprintf('isFile()) { - continue; - } - - $path = $file->getRealPath() ?: $file->getPathname(); - - if (pathinfo($path, PATHINFO_EXTENSION) !== 'php') { - continue; - } - - $classes = self::findClasses($path); - - if (\PHP_VERSION_ID >= 70000) { - // PHP 7 memory manager will not release after token_get_all(), see https://bugs.php.net/70098 - gc_mem_caches(); - } - - foreach ($classes as $class) { - $map[$class] = $path; - } - } - - return $map; - } - - /** - * Extract the classes in the given file. - * - * @param string $path The file to check - * - * @return array The found classes - */ - private static function findClasses($path) - { - $contents = file_get_contents($path); - $tokens = token_get_all($contents); - - $classes = array(); - - $namespace = ''; - for ($i = 0; isset($tokens[$i]); ++$i) { - $token = $tokens[$i]; - - if (!isset($token[1])) { - continue; - } - - $class = ''; - - switch ($token[0]) { - case T_NAMESPACE: - $namespace = ''; - // If there is a namespace, extract it - while (isset($tokens[++$i][1])) { - if (in_array($tokens[$i][0], array(T_STRING, T_NS_SEPARATOR))) { - $namespace .= $tokens[$i][1]; - } - } - $namespace .= '\\'; - break; - case T_CLASS: - case T_INTERFACE: - case T_TRAIT: - // Skip usage of ::class constant - $isClassConstant = false; - for ($j = $i - 1; $j > 0; --$j) { - if (!isset($tokens[$j][1])) { - break; - } - - if (T_DOUBLE_COLON === $tokens[$j][0]) { - $isClassConstant = true; - break; - } elseif (!in_array($tokens[$j][0], array(T_WHITESPACE, T_DOC_COMMENT, T_COMMENT))) { - break; - } - } - - if ($isClassConstant) { - break; - } - - // Find the classname - while (isset($tokens[++$i][1])) { - $t = $tokens[$i]; - if (T_STRING === $t[0]) { - $class .= $t[1]; - } elseif ('' !== $class && T_WHITESPACE === $t[0]) { - break; - } - } - - $classes[] = ltrim($namespace.$class, '\\'); - break; - default: - break; - } - } - - return $classes; - } -} diff --git a/vendor/symfony/class-loader/LICENSE b/vendor/symfony/class-loader/LICENSE deleted file mode 100644 index 17d16a13..00000000 --- a/vendor/symfony/class-loader/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2004-2017 Fabien Potencier - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is furnished -to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/vendor/symfony/class-loader/MapClassLoader.php b/vendor/symfony/class-loader/MapClassLoader.php deleted file mode 100644 index 1d8bcc2a..00000000 --- a/vendor/symfony/class-loader/MapClassLoader.php +++ /dev/null @@ -1,68 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * A class loader that uses a mapping file to look up paths. - * - * @author Fabien Potencier - */ -class MapClassLoader -{ - private $map = array(); - - /** - * Constructor. - * - * @param array $map A map where keys are classes and values the absolute file path - */ - public function __construct(array $map) - { - $this->map = $map; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend Whether to prepend the autoloader or not - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Loads the given class or interface. - * - * @param string $class The name of the class - */ - public function loadClass($class) - { - if (isset($this->map[$class])) { - require $this->map[$class]; - } - } - - /** - * Finds the path to the file where the class is defined. - * - * @param string $class The name of the class - * - * @return string|null The path, if found - */ - public function findFile($class) - { - if (isset($this->map[$class])) { - return $this->map[$class]; - } - } -} diff --git a/vendor/symfony/class-loader/Psr4ClassLoader.php b/vendor/symfony/class-loader/Psr4ClassLoader.php deleted file mode 100644 index 84647b75..00000000 --- a/vendor/symfony/class-loader/Psr4ClassLoader.php +++ /dev/null @@ -1,93 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * A PSR-4 compatible class loader. - * - * See http://www.php-fig.org/psr/psr-4/ - * - * @author Alexander M. Turek - */ -class Psr4ClassLoader -{ - /** - * @var array - */ - private $prefixes = array(); - - /** - * @param string $prefix - * @param string $baseDir - */ - public function addPrefix($prefix, $baseDir) - { - $prefix = trim($prefix, '\\').'\\'; - $baseDir = rtrim($baseDir, DIRECTORY_SEPARATOR).DIRECTORY_SEPARATOR; - $this->prefixes[] = array($prefix, $baseDir); - } - - /** - * @param string $class - * - * @return string|null - */ - public function findFile($class) - { - $class = ltrim($class, '\\'); - - foreach ($this->prefixes as list($currentPrefix, $currentBaseDir)) { - if (0 === strpos($class, $currentPrefix)) { - $classWithoutPrefix = substr($class, strlen($currentPrefix)); - $file = $currentBaseDir.str_replace('\\', DIRECTORY_SEPARATOR, $classWithoutPrefix).'.php'; - if (file_exists($file)) { - return $file; - } - } - } - } - - /** - * @param string $class - * - * @return bool - */ - public function loadClass($class) - { - $file = $this->findFile($class); - if (null !== $file) { - require $file; - - return true; - } - - return false; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Removes this instance from the registered autoloaders. - */ - public function unregister() - { - spl_autoload_unregister(array($this, 'loadClass')); - } -} diff --git a/vendor/symfony/class-loader/README.md b/vendor/symfony/class-loader/README.md deleted file mode 100644 index d61992b6..00000000 --- a/vendor/symfony/class-loader/README.md +++ /dev/null @@ -1,14 +0,0 @@ -ClassLoader Component -===================== - -The ClassLoader component provides tools to autoload your classes and cache -their locations for performance. - -Resources ---------- - - * [Documentation](https://symfony.com/doc/current/components/class_loader/index.html) - * [Contributing](https://symfony.com/doc/current/contributing/index.html) - * [Report issues](https://github.com/symfony/symfony/issues) and - [send Pull Requests](https://github.com/symfony/symfony/pulls) - in the [main Symfony repository](https://github.com/symfony/symfony) diff --git a/vendor/symfony/class-loader/Tests/ApcClassLoaderTest.php b/vendor/symfony/class-loader/Tests/ApcClassLoaderTest.php deleted file mode 100644 index 8ad7132e..00000000 --- a/vendor/symfony/class-loader/Tests/ApcClassLoaderTest.php +++ /dev/null @@ -1,197 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader\Tests; - -use PHPUnit\Framework\TestCase; -use Symfony\Component\ClassLoader\ApcClassLoader; -use Symfony\Component\ClassLoader\ClassLoader; - -class ApcClassLoaderTest extends TestCase -{ - protected function setUp() - { - if (!(ini_get('apc.enabled') && ini_get('apc.enable_cli'))) { - $this->markTestSkipped('The apc extension is not enabled.'); - } else { - apcu_clear_cache(); - } - } - - protected function tearDown() - { - if (ini_get('apc.enabled') && ini_get('apc.enable_cli')) { - apcu_clear_cache(); - } - } - - public function testConstructor() - { - $loader = new ClassLoader(); - $loader->addPrefix('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - - $loader = new ApcClassLoader('test.prefix.', $loader); - - $this->assertEquals($loader->findFile('\Apc\Namespaced\FooBar'), apcu_fetch('test.prefix.\Apc\Namespaced\FooBar'), '__construct() takes a prefix as its first argument'); - } - - /** - * @dataProvider getLoadClassTests - */ - public function testLoadClass($className, $testClassName, $message) - { - $loader = new ClassLoader(); - $loader->addPrefix('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Apc_Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - - $loader = new ApcClassLoader('test.prefix.', $loader); - $loader->loadClass($testClassName); - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassTests() - { - return array( - array('\\Apc\\Namespaced\\Foo', 'Apc\\Namespaced\\Foo', '->loadClass() loads Apc\Namespaced\Foo class'), - array('Apc_Pearlike_Foo', 'Apc_Pearlike_Foo', '->loadClass() loads Apc_Pearlike_Foo class'), - ); - } - - /** - * @dataProvider getLoadClassFromFallbackTests - */ - public function testLoadClassFromFallback($className, $testClassName, $message) - { - $loader = new ClassLoader(); - $loader->addPrefix('Apc\Namespaced', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Apc_Pearlike_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('', array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/fallback')); - - $loader = new ApcClassLoader('test.prefix.fallback', $loader); - $loader->loadClass($testClassName); - - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassFromFallbackTests() - { - return array( - array('\\Apc\\Namespaced\\Baz', 'Apc\\Namespaced\\Baz', '->loadClass() loads Apc\Namespaced\Baz class'), - array('Apc_Pearlike_Baz', 'Apc_Pearlike_Baz', '->loadClass() loads Apc_Pearlike_Baz class'), - array('\\Apc\\Namespaced\\FooBar', 'Apc\\Namespaced\\FooBar', '->loadClass() loads Apc\Namespaced\Baz class from fallback dir'), - array('Apc_Pearlike_FooBar', 'Apc_Pearlike_FooBar', '->loadClass() loads Apc_Pearlike_Baz class from fallback dir'), - ); - } - - /** - * @dataProvider getLoadClassNamespaceCollisionTests - */ - public function testLoadClassNamespaceCollision($namespaces, $className, $message) - { - $loader = new ClassLoader(); - $loader->addPrefixes($namespaces); - - $loader = new ApcClassLoader('test.prefix.collision.', $loader); - $loader->loadClass($className); - - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassNamespaceCollisionTests() - { - return array( - array( - array( - 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', - 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', - ), - 'Apc\NamespaceCollision\A\Foo', - '->loadClass() loads NamespaceCollision\A\Foo from alpha.', - ), - array( - array( - 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', - 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', - ), - 'Apc\NamespaceCollision\A\Bar', - '->loadClass() loads NamespaceCollision\A\Bar from alpha.', - ), - array( - array( - 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', - 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', - ), - 'Apc\NamespaceCollision\A\B\Foo', - '->loadClass() loads NamespaceCollision\A\B\Foo from beta.', - ), - array( - array( - 'Apc\\NamespaceCollision\\A\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta', - 'Apc\\NamespaceCollision\\A' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha', - ), - 'Apc\NamespaceCollision\A\B\Bar', - '->loadClass() loads NamespaceCollision\A\B\Bar from beta.', - ), - ); - } - - /** - * @dataProvider getLoadClassPrefixCollisionTests - */ - public function testLoadClassPrefixCollision($prefixes, $className, $message) - { - $loader = new ClassLoader(); - $loader->addPrefixes($prefixes); - - $loader = new ApcClassLoader('test.prefix.collision.', $loader); - $loader->loadClass($className); - - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassPrefixCollisionTests() - { - return array( - array( - array( - 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', - 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', - ), - 'ApcPrefixCollision_A_Foo', - '->loadClass() loads ApcPrefixCollision_A_Foo from alpha.', - ), - array( - array( - 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', - 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', - ), - 'ApcPrefixCollision_A_Bar', - '->loadClass() loads ApcPrefixCollision_A_Bar from alpha.', - ), - array( - array( - 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', - 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', - ), - 'ApcPrefixCollision_A_B_Foo', - '->loadClass() loads ApcPrefixCollision_A_B_Foo from beta.', - ), - array( - array( - 'ApcPrefixCollision_A_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/beta/Apc', - 'ApcPrefixCollision_A_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/Apc/alpha/Apc', - ), - 'ApcPrefixCollision_A_B_Bar', - '->loadClass() loads ApcPrefixCollision_A_B_Bar from beta.', - ), - ); - } -} diff --git a/vendor/symfony/class-loader/Tests/ClassCollectionLoaderTest.php b/vendor/symfony/class-loader/Tests/ClassCollectionLoaderTest.php deleted file mode 100644 index 42bb04d9..00000000 --- a/vendor/symfony/class-loader/Tests/ClassCollectionLoaderTest.php +++ /dev/null @@ -1,316 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader\Tests; - -use PHPUnit\Framework\TestCase; -use Symfony\Component\ClassLoader\ClassCollectionLoader; -use Symfony\Component\ClassLoader\Tests\Fixtures\DeclaredClass; -use Symfony\Component\ClassLoader\Tests\Fixtures\WarmedClass; - -require_once __DIR__.'/Fixtures/ClassesWithParents/GInterface.php'; -require_once __DIR__.'/Fixtures/ClassesWithParents/CInterface.php'; -require_once __DIR__.'/Fixtures/ClassesWithParents/B.php'; -require_once __DIR__.'/Fixtures/ClassesWithParents/A.php'; - -class ClassCollectionLoaderTest extends TestCase -{ - public function testTraitDependencies() - { - require_once __DIR__.'/Fixtures/deps/traits.php'; - - $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); - $m = $r->getMethod('getOrderedClasses'); - $m->setAccessible(true); - - $ordered = $m->invoke(null, array('CTFoo')); - - $this->assertEquals( - array('TD', 'TC', 'TB', 'TA', 'TZ', 'CTFoo'), - array_map(function ($class) { return $class->getName(); }, $ordered) - ); - - $ordered = $m->invoke(null, array('CTBar')); - - $this->assertEquals( - array('TD', 'TZ', 'TC', 'TB', 'TA', 'CTBar'), - array_map(function ($class) { return $class->getName(); }, $ordered) - ); - } - - /** - * @dataProvider getDifferentOrders - */ - public function testClassReordering(array $classes) - { - $expected = array( - 'ClassesWithParents\\GInterface', - 'ClassesWithParents\\CInterface', - 'ClassesWithParents\\B', - 'ClassesWithParents\\A', - ); - - $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); - $m = $r->getMethod('getOrderedClasses'); - $m->setAccessible(true); - - $ordered = $m->invoke(null, $classes); - - $this->assertEquals($expected, array_map(function ($class) { return $class->getName(); }, $ordered)); - } - - public function getDifferentOrders() - { - return array( - array(array( - 'ClassesWithParents\\A', - 'ClassesWithParents\\CInterface', - 'ClassesWithParents\\GInterface', - 'ClassesWithParents\\B', - )), - array(array( - 'ClassesWithParents\\B', - 'ClassesWithParents\\A', - 'ClassesWithParents\\CInterface', - )), - array(array( - 'ClassesWithParents\\CInterface', - 'ClassesWithParents\\B', - 'ClassesWithParents\\A', - )), - array(array( - 'ClassesWithParents\\A', - )), - ); - } - - /** - * @dataProvider getDifferentOrdersForTraits - */ - public function testClassWithTraitsReordering(array $classes) - { - require_once __DIR__.'/Fixtures/ClassesWithParents/ATrait.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/BTrait.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/CTrait.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/D.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/E.php'; - - $expected = array( - 'ClassesWithParents\\GInterface', - 'ClassesWithParents\\CInterface', - 'ClassesWithParents\\ATrait', - 'ClassesWithParents\\BTrait', - 'ClassesWithParents\\CTrait', - 'ClassesWithParents\\B', - 'ClassesWithParents\\A', - 'ClassesWithParents\\D', - 'ClassesWithParents\\E', - ); - - $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); - $m = $r->getMethod('getOrderedClasses'); - $m->setAccessible(true); - - $ordered = $m->invoke(null, $classes); - - $this->assertEquals($expected, array_map(function ($class) { return $class->getName(); }, $ordered)); - } - - public function getDifferentOrdersForTraits() - { - return array( - array(array( - 'ClassesWithParents\\E', - 'ClassesWithParents\\ATrait', - )), - array(array( - 'ClassesWithParents\\E', - )), - ); - } - - public function testFixClassWithTraitsOrdering() - { - require_once __DIR__.'/Fixtures/ClassesWithParents/CTrait.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/F.php'; - require_once __DIR__.'/Fixtures/ClassesWithParents/G.php'; - - $classes = array( - 'ClassesWithParents\\F', - 'ClassesWithParents\\G', - ); - - $expected = array( - 'ClassesWithParents\\CTrait', - 'ClassesWithParents\\F', - 'ClassesWithParents\\G', - ); - - $r = new \ReflectionClass('Symfony\Component\ClassLoader\ClassCollectionLoader'); - $m = $r->getMethod('getOrderedClasses'); - $m->setAccessible(true); - - $ordered = $m->invoke(null, $classes); - - $this->assertEquals($expected, array_map(function ($class) { return $class->getName(); }, $ordered)); - } - - /** - * @dataProvider getFixNamespaceDeclarationsData - */ - public function testFixNamespaceDeclarations($source, $expected) - { - $this->assertEquals('assertEquals('assertEquals(<<<'EOF' -namespace Namespaced -{ -class WithComments -{ -public static $loaded = true; -} -$string ='string should not be modified {$string}'; -$heredoc = (<<assertTrue(class_exists(WarmedClass::class, true)); - - @unlink($cache = sys_get_temp_dir().'/inline.php'); - - $classes = array(WarmedClass::class); - $excluded = array(DeclaredClass::class); - - ClassCollectionLoader::inline($classes, $cache, $excluded); - - $this->assertSame(<<<'EOTXT' - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader\Tests; - -use PHPUnit\Framework\TestCase; -use Symfony\Component\ClassLoader\ClassLoader; - -class ClassLoaderTest extends TestCase -{ - public function testGetPrefixes() - { - $loader = new ClassLoader(); - $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Bar', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Bas', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $prefixes = $loader->getPrefixes(); - $this->assertArrayHasKey('Foo', $prefixes); - $this->assertArrayNotHasKey('Foo1', $prefixes); - $this->assertArrayHasKey('Bar', $prefixes); - $this->assertArrayHasKey('Bas', $prefixes); - } - - public function testGetFallbackDirs() - { - $loader = new ClassLoader(); - $loader->addPrefix(null, __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix(null, __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $fallback_dirs = $loader->getFallbackDirs(); - $this->assertCount(2, $fallback_dirs); - } - - /** - * @dataProvider getLoadClassTests - */ - public function testLoadClass($className, $testClassName, $message) - { - $loader = new ClassLoader(); - $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->loadClass($testClassName); - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassTests() - { - return array( - array('\\Namespaced2\\Foo', 'Namespaced2\\Foo', '->loadClass() loads Namespaced2\Foo class'), - array('\\Pearlike2_Foo', 'Pearlike2_Foo', '->loadClass() loads Pearlike2_Foo class'), - ); - } - - /** - * @dataProvider getLoadNonexistentClassTests - */ - public function testLoadNonexistentClass($className, $testClassName, $message) - { - $loader = new ClassLoader(); - $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->loadClass($testClassName); - $this->assertFalse(class_exists($className), $message); - } - - public function getLoadNonexistentClassTests() - { - return array( - array('\\Pearlike3_Bar', '\\Pearlike3_Bar', '->loadClass() loads non existing Pearlike3_Bar class with a leading slash'), - ); - } - - public function testAddPrefixSingle() - { - $loader = new ClassLoader(); - $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Foo', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $prefixes = $loader->getPrefixes(); - $this->assertArrayHasKey('Foo', $prefixes); - $this->assertCount(1, $prefixes['Foo']); - } - - public function testAddPrefixesSingle() - { - $loader = new ClassLoader(); - $loader->addPrefixes(array('Foo' => array('foo', 'foo'))); - $loader->addPrefixes(array('Foo' => array('foo'))); - $prefixes = $loader->getPrefixes(); - $this->assertArrayHasKey('Foo', $prefixes); - $this->assertCount(1, $prefixes['Foo'], print_r($prefixes, true)); - } - - public function testAddPrefixMulti() - { - $loader = new ClassLoader(); - $loader->addPrefix('Foo', 'foo'); - $loader->addPrefix('Foo', 'bar'); - $prefixes = $loader->getPrefixes(); - $this->assertArrayHasKey('Foo', $prefixes); - $this->assertCount(2, $prefixes['Foo']); - $this->assertContains('foo', $prefixes['Foo']); - $this->assertContains('bar', $prefixes['Foo']); - } - - public function testUseIncludePath() - { - $loader = new ClassLoader(); - $this->assertFalse($loader->getUseIncludePath()); - - $this->assertNull($loader->findFile('Foo')); - - $includePath = get_include_path(); - - $loader->setUseIncludePath(true); - $this->assertTrue($loader->getUseIncludePath()); - - set_include_path(__DIR__.'/Fixtures/includepath'.PATH_SEPARATOR.$includePath); - - $this->assertEquals(__DIR__.DIRECTORY_SEPARATOR.'Fixtures'.DIRECTORY_SEPARATOR.'includepath'.DIRECTORY_SEPARATOR.'Foo.php', $loader->findFile('Foo')); - - set_include_path($includePath); - } - - /** - * @dataProvider getLoadClassFromFallbackTests - */ - public function testLoadClassFromFallback($className, $testClassName, $message) - { - $loader = new ClassLoader(); - $loader->addPrefix('Namespaced2\\', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('Pearlike2_', __DIR__.DIRECTORY_SEPARATOR.'Fixtures'); - $loader->addPrefix('', array(__DIR__.DIRECTORY_SEPARATOR.'Fixtures/fallback')); - $loader->loadClass($testClassName); - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassFromFallbackTests() - { - return array( - array('\\Namespaced2\\Baz', 'Namespaced2\\Baz', '->loadClass() loads Namespaced2\Baz class'), - array('\\Pearlike2_Baz', 'Pearlike2_Baz', '->loadClass() loads Pearlike2_Baz class'), - array('\\Namespaced2\\FooBar', 'Namespaced2\\FooBar', '->loadClass() loads Namespaced2\Baz class from fallback dir'), - array('\\Pearlike2_FooBar', 'Pearlike2_FooBar', '->loadClass() loads Pearlike2_Baz class from fallback dir'), - ); - } - - /** - * @dataProvider getLoadClassNamespaceCollisionTests - */ - public function testLoadClassNamespaceCollision($namespaces, $className, $message) - { - $loader = new ClassLoader(); - $loader->addPrefixes($namespaces); - - $loader->loadClass($className); - $this->assertTrue(class_exists($className), $message); - } - - public function getLoadClassNamespaceCollisionTests() - { - return array( - array( - array( - 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - ), - 'NamespaceCollision\C\Foo', - '->loadClass() loads NamespaceCollision\C\Foo from alpha.', - ), - array( - array( - 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - ), - 'NamespaceCollision\C\Bar', - '->loadClass() loads NamespaceCollision\C\Bar from alpha.', - ), - array( - array( - 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - ), - 'NamespaceCollision\C\B\Foo', - '->loadClass() loads NamespaceCollision\C\B\Foo from beta.', - ), - array( - array( - 'NamespaceCollision\\C\\B' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - 'NamespaceCollision\\C' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - ), - 'NamespaceCollision\C\B\Bar', - '->loadClass() loads NamespaceCollision\C\B\Bar from beta.', - ), - array( - array( - 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - ), - 'PrefixCollision_C_Foo', - '->loadClass() loads PrefixCollision_C_Foo from alpha.', - ), - array( - array( - 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - ), - 'PrefixCollision_C_Bar', - '->loadClass() loads PrefixCollision_C_Bar from alpha.', - ), - array( - array( - 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - ), - 'PrefixCollision_C_B_Foo', - '->loadClass() loads PrefixCollision_C_B_Foo from beta.', - ), - array( - array( - 'PrefixCollision_C_B_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/beta', - 'PrefixCollision_C_' => __DIR__.DIRECTORY_SEPARATOR.'Fixtures/alpha', - ), - 'PrefixCollision_C_B_Bar', - '->loadClass() loads PrefixCollision_C_B_Bar from beta.', - ), - ); - } -} diff --git a/vendor/symfony/class-loader/Tests/ClassMapGeneratorTest.php b/vendor/symfony/class-loader/Tests/ClassMapGeneratorTest.php deleted file mode 100644 index 44359268..00000000 --- a/vendor/symfony/class-loader/Tests/ClassMapGeneratorTest.php +++ /dev/null @@ -1,148 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader\Tests; - -use PHPUnit\Framework\TestCase; -use Symfony\Component\ClassLoader\ClassMapGenerator; - -class ClassMapGeneratorTest extends TestCase -{ - /** - * @var string|null - */ - private $workspace = null; - - public function prepare_workspace() - { - $this->workspace = sys_get_temp_dir().'/'.microtime(true).'.'.mt_rand(); - mkdir($this->workspace, 0777, true); - $this->workspace = realpath($this->workspace); - } - - /** - * @param string $file - */ - private function clean($file) - { - if (is_dir($file) && !is_link($file)) { - $dir = new \FilesystemIterator($file); - foreach ($dir as $childFile) { - $this->clean($childFile); - } - - rmdir($file); - } else { - unlink($file); - } - } - - /** - * @dataProvider getTestCreateMapTests - */ - public function testDump($directory) - { - $this->prepare_workspace(); - - $file = $this->workspace.'/file'; - - $generator = new ClassMapGenerator(); - $generator->dump($directory, $file); - $this->assertFileExists($file); - - $this->clean($this->workspace); - } - - /** - * @dataProvider getTestCreateMapTests - */ - public function testCreateMap($directory, $expected) - { - $this->assertEqualsNormalized($expected, ClassMapGenerator::createMap($directory)); - } - - public function getTestCreateMapTests() - { - $data = array( - array(__DIR__.'/Fixtures/Namespaced', array( - 'Namespaced\\Bar' => realpath(__DIR__).'/Fixtures/Namespaced/Bar.php', - 'Namespaced\\Foo' => realpath(__DIR__).'/Fixtures/Namespaced/Foo.php', - 'Namespaced\\Baz' => realpath(__DIR__).'/Fixtures/Namespaced/Baz.php', - 'Namespaced\\WithComments' => realpath(__DIR__).'/Fixtures/Namespaced/WithComments.php', - 'Namespaced\\WithStrictTypes' => realpath(__DIR__).'/Fixtures/Namespaced/WithStrictTypes.php', - 'Namespaced\\WithHaltCompiler' => realpath(__DIR__).'/Fixtures/Namespaced/WithHaltCompiler.php', - 'Namespaced\\WithDirMagic' => realpath(__DIR__).'/Fixtures/Namespaced/WithDirMagic.php', - 'Namespaced\\WithFileMagic' => realpath(__DIR__).'/Fixtures/Namespaced/WithFileMagic.php', - )), - array(__DIR__.'/Fixtures/beta/NamespaceCollision', array( - 'NamespaceCollision\\A\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Bar.php', - 'NamespaceCollision\\A\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Foo.php', - 'NamespaceCollision\\C\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Bar.php', - 'NamespaceCollision\\C\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Foo.php', - )), - array(__DIR__.'/Fixtures/Pearlike', array( - 'Pearlike_Foo' => realpath(__DIR__).'/Fixtures/Pearlike/Foo.php', - 'Pearlike_Bar' => realpath(__DIR__).'/Fixtures/Pearlike/Bar.php', - 'Pearlike_Baz' => realpath(__DIR__).'/Fixtures/Pearlike/Baz.php', - 'Pearlike_WithComments' => realpath(__DIR__).'/Fixtures/Pearlike/WithComments.php', - )), - array(__DIR__.'/Fixtures/classmap', array( - 'Foo\\Bar\\A' => realpath(__DIR__).'/Fixtures/classmap/sameNsMultipleClasses.php', - 'Foo\\Bar\\B' => realpath(__DIR__).'/Fixtures/classmap/sameNsMultipleClasses.php', - 'A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', - 'Alpha\\A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', - 'Alpha\\B' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', - 'Beta\\A' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', - 'Beta\\B' => realpath(__DIR__).'/Fixtures/classmap/multipleNs.php', - 'ClassMap\\SomeInterface' => realpath(__DIR__).'/Fixtures/classmap/SomeInterface.php', - 'ClassMap\\SomeParent' => realpath(__DIR__).'/Fixtures/classmap/SomeParent.php', - 'ClassMap\\SomeClass' => realpath(__DIR__).'/Fixtures/classmap/SomeClass.php', - )), - array(__DIR__.'/Fixtures/php5.4', array( - 'TFoo' => __DIR__.'/Fixtures/php5.4/traits.php', - 'CFoo' => __DIR__.'/Fixtures/php5.4/traits.php', - 'Foo\\TBar' => __DIR__.'/Fixtures/php5.4/traits.php', - 'Foo\\IBar' => __DIR__.'/Fixtures/php5.4/traits.php', - 'Foo\\TFooBar' => __DIR__.'/Fixtures/php5.4/traits.php', - 'Foo\\CBar' => __DIR__.'/Fixtures/php5.4/traits.php', - )), - array(__DIR__.'/Fixtures/php5.5', array( - 'ClassCons\\Foo' => __DIR__.'/Fixtures/php5.5/class_cons.php', - )), - ); - - return $data; - } - - public function testCreateMapFinderSupport() - { - $finder = new \Symfony\Component\Finder\Finder(); - $finder->files()->in(__DIR__.'/Fixtures/beta/NamespaceCollision'); - - $this->assertEqualsNormalized(array( - 'NamespaceCollision\\A\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Bar.php', - 'NamespaceCollision\\A\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/A/B/Foo.php', - 'NamespaceCollision\\C\\B\\Bar' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Bar.php', - 'NamespaceCollision\\C\\B\\Foo' => realpath(__DIR__).'/Fixtures/beta/NamespaceCollision/C/B/Foo.php', - ), ClassMapGenerator::createMap($finder)); - } - - protected function assertEqualsNormalized($expected, $actual, $message = null) - { - foreach ($expected as $ns => $path) { - $expected[$ns] = str_replace('\\', '/', $path); - } - foreach ($actual as $ns => $path) { - $actual[$ns] = str_replace('\\', '/', $path); - } - $this->assertEquals($expected, $actual, $message); - } -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Bar.php deleted file mode 100644 index 4259f145..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Bar.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\Namespaced; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Baz.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Baz.php deleted file mode 100644 index 3ddb595e..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Baz.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\Namespaced; - -class Baz -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Foo.php deleted file mode 100644 index cf0a4b74..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\Namespaced; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/FooBar.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/FooBar.php deleted file mode 100644 index bbbc8151..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Namespaced/FooBar.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\Namespaced; - -class FooBar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Bar.php deleted file mode 100644 index e774cb9b..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/Pearlike/Bar.php +++ /dev/null @@ -1,6 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\NamespaceCollision\A; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Foo.php deleted file mode 100644 index 184a1b1d..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/alpha/Apc/NamespaceCollision/A/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\NamespaceCollision\A; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Bar.php deleted file mode 100644 index 3892f706..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/ApcPrefixCollision/A/B/Bar.php +++ /dev/null @@ -1,6 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\NamespaceCollision\A\B; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Foo.php deleted file mode 100644 index 450eeb50..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/beta/Apc/NamespaceCollision/A/B/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\NamespaceCollision\A\B; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Apc/fallback/Apc/Pearlike/FooBar.php b/vendor/symfony/class-loader/Tests/Fixtures/Apc/fallback/Apc/Pearlike/FooBar.php deleted file mode 100644 index 96f2f76c..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Apc/fallback/Apc/Pearlike/FooBar.php +++ /dev/null @@ -1,6 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Apc\Namespaced; - -class FooBar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/A.php b/vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/A.php deleted file mode 100644 index b0f94259..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/ClassesWithParents/A.php +++ /dev/null @@ -1,7 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Namespaced; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Baz.php b/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Baz.php deleted file mode 100644 index 0b0bbd05..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Baz.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Namespaced; - -class Baz -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Foo.php deleted file mode 100644 index df5e1f4c..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Namespaced; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithComments.php b/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithComments.php deleted file mode 100644 index 361e53de..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Namespaced/WithComments.php +++ /dev/null @@ -1,37 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Namespaced; - -class WithComments -{ - /** @Boolean */ - public static $loaded = true; -} - -$string = 'string should not be modified {$string}'; - -$heredoc = (<< - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -class Pearlike_WithComments -{ - /** @Boolean */ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Bar.php deleted file mode 100644 index 7f5f7977..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/Pearlike2/Bar.php +++ /dev/null @@ -1,6 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace NamespaceCollision\A; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/A/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/A/Foo.php deleted file mode 100644 index aee6a080..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/A/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace NamespaceCollision\A; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/C/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/C/Bar.php deleted file mode 100644 index c1b8dd65..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/alpha/NamespaceCollision/C/Bar.php +++ /dev/null @@ -1,8 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace NamespaceCollision\A\B; - -class Bar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/A/B/Foo.php b/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/A/B/Foo.php deleted file mode 100644 index f5f2d727..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/A/B/Foo.php +++ /dev/null @@ -1,17 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace NamespaceCollision\A\B; - -class Foo -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/C/B/Bar.php b/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/C/B/Bar.php deleted file mode 100644 index 4bb03dc7..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/beta/NamespaceCollision/C/B/Bar.php +++ /dev/null @@ -1,8 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace ClassMap; - -class SomeClass extends SomeParent implements SomeInterface -{ -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeInterface.php b/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeInterface.php deleted file mode 100644 index 1fe5e09a..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeInterface.php +++ /dev/null @@ -1,16 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace ClassMap; - -interface SomeInterface -{ -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeParent.php b/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeParent.php deleted file mode 100644 index ce2f9fc6..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/classmap/SomeParent.php +++ /dev/null @@ -1,16 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace ClassMap; - -abstract class SomeParent -{ -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/classmap/multipleNs.php b/vendor/symfony/class-loader/Tests/Fixtures/classmap/multipleNs.php deleted file mode 100644 index c7cec646..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/classmap/multipleNs.php +++ /dev/null @@ -1,25 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Foo\Bar; - -class A -{ -} -class B -{ -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/deps/traits.php b/vendor/symfony/class-loader/Tests/Fixtures/deps/traits.php deleted file mode 100644 index 82b30a6f..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/deps/traits.php +++ /dev/null @@ -1,37 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Namespaced; - -class FooBar -{ - public static $loaded = true; -} diff --git a/vendor/symfony/class-loader/Tests/Fixtures/fallback/Namespaced2/FooBar.php b/vendor/symfony/class-loader/Tests/Fixtures/fallback/Namespaced2/FooBar.php deleted file mode 100644 index 1036d435..00000000 --- a/vendor/symfony/class-loader/Tests/Fixtures/fallback/Namespaced2/FooBar.php +++ /dev/null @@ -1,8 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader\Tests; - -use PHPUnit\Framework\TestCase; -use Symfony\Component\ClassLoader\Psr4ClassLoader; - -class Psr4ClassLoaderTest extends TestCase -{ - /** - * @param string $className - * @dataProvider getLoadClassTests - */ - public function testLoadClass($className) - { - $loader = new Psr4ClassLoader(); - $loader->addPrefix( - 'Acme\\DemoLib', - __DIR__.DIRECTORY_SEPARATOR.'Fixtures'.DIRECTORY_SEPARATOR.'psr-4' - ); - $loader->loadClass($className); - $this->assertTrue(class_exists($className), sprintf('loadClass() should load %s', $className)); - } - - /** - * @return array - */ - public function getLoadClassTests() - { - return array( - array('Acme\\DemoLib\\Foo'), - array('Acme\\DemoLib\\Class_With_Underscores'), - array('Acme\\DemoLib\\Lets\\Go\\Deeper\\Foo'), - array('Acme\\DemoLib\\Lets\\Go\\Deeper\\Class_With_Underscores'), - ); - } - - /** - * @param string $className - * @dataProvider getLoadNonexistentClassTests - */ - public function testLoadNonexistentClass($className) - { - $loader = new Psr4ClassLoader(); - $loader->addPrefix( - 'Acme\\DemoLib', - __DIR__.DIRECTORY_SEPARATOR.'Fixtures'.DIRECTORY_SEPARATOR.'psr-4' - ); - $loader->loadClass($className); - $this->assertFalse(class_exists($className), sprintf('loadClass() should not load %s', $className)); - } - - /** - * @return array - */ - public function getLoadNonexistentClassTests() - { - return array( - array('Acme\\DemoLib\\I_Do_Not_Exist'), - array('UnknownVendor\\SomeLib\\I_Do_Not_Exist'), - ); - } -} diff --git a/vendor/symfony/class-loader/WinCacheClassLoader.php b/vendor/symfony/class-loader/WinCacheClassLoader.php deleted file mode 100644 index b95a1d79..00000000 --- a/vendor/symfony/class-loader/WinCacheClassLoader.php +++ /dev/null @@ -1,140 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * WinCacheClassLoader implements a wrapping autoloader cached in WinCache. - * - * It expects an object implementing a findFile method to find the file. This - * allow using it as a wrapper around the other loaders of the component (the - * ClassLoader for instance) but also around any other autoloaders following - * this convention (the Composer one for instance). - * - * // with a Symfony autoloader - * $loader = new ClassLoader(); - * $loader->addPrefix('Symfony\Component', __DIR__.'/component'); - * $loader->addPrefix('Symfony', __DIR__.'/framework'); - * - * // or with a Composer autoloader - * use Composer\Autoload\ClassLoader; - * - * $loader = new ClassLoader(); - * $loader->add('Symfony\Component', __DIR__.'/component'); - * $loader->add('Symfony', __DIR__.'/framework'); - * - * $cachedLoader = new WinCacheClassLoader('my_prefix', $loader); - * - * // activate the cached autoloader - * $cachedLoader->register(); - * - * // eventually deactivate the non-cached loader if it was registered previously - * // to be sure to use the cached one. - * $loader->unregister(); - * - * @author Fabien Potencier - * @author Kris Wallsmith - * @author Artem Ryzhkov - */ -class WinCacheClassLoader -{ - private $prefix; - - /** - * A class loader object that implements the findFile() method. - * - * @var object - */ - protected $decorated; - - /** - * Constructor. - * - * @param string $prefix The WinCache namespace prefix to use - * @param object $decorated A class loader object that implements the findFile() method - * - * @throws \RuntimeException - * @throws \InvalidArgumentException - */ - public function __construct($prefix, $decorated) - { - if (!extension_loaded('wincache')) { - throw new \RuntimeException('Unable to use WinCacheClassLoader as WinCache is not enabled.'); - } - - if (!method_exists($decorated, 'findFile')) { - throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); - } - - $this->prefix = $prefix; - $this->decorated = $decorated; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend Whether to prepend the autoloader or not - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Unregisters this instance as an autoloader. - */ - public function unregister() - { - spl_autoload_unregister(array($this, 'loadClass')); - } - - /** - * Loads the given class or interface. - * - * @param string $class The name of the class - * - * @return bool|null True, if loaded - */ - public function loadClass($class) - { - if ($file = $this->findFile($class)) { - require $file; - - return true; - } - } - - /** - * Finds a file by class name while caching lookups to WinCache. - * - * @param string $class A class name to resolve to file - * - * @return string|null - */ - public function findFile($class) - { - $file = wincache_ucache_get($this->prefix.$class, $success); - - if (!$success) { - wincache_ucache_set($this->prefix.$class, $file = $this->decorated->findFile($class) ?: null, 0); - } - - return $file; - } - - /** - * Passes through all unknown calls onto the decorated object. - */ - public function __call($method, $args) - { - return call_user_func_array(array($this->decorated, $method), $args); - } -} diff --git a/vendor/symfony/class-loader/XcacheClassLoader.php b/vendor/symfony/class-loader/XcacheClassLoader.php deleted file mode 100644 index bf309a69..00000000 --- a/vendor/symfony/class-loader/XcacheClassLoader.php +++ /dev/null @@ -1,141 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ - -namespace Symfony\Component\ClassLoader; - -/** - * XcacheClassLoader implements a wrapping autoloader cached in XCache for PHP 5.3. - * - * It expects an object implementing a findFile method to find the file. This - * allows using it as a wrapper around the other loaders of the component (the - * ClassLoader for instance) but also around any other autoloaders following - * this convention (the Composer one for instance). - * - * // with a Symfony autoloader - * $loader = new ClassLoader(); - * $loader->addPrefix('Symfony\Component', __DIR__.'/component'); - * $loader->addPrefix('Symfony', __DIR__.'/framework'); - * - * // or with a Composer autoloader - * use Composer\Autoload\ClassLoader; - * - * $loader = new ClassLoader(); - * $loader->add('Symfony\Component', __DIR__.'/component'); - * $loader->add('Symfony', __DIR__.'/framework'); - * - * $cachedLoader = new XcacheClassLoader('my_prefix', $loader); - * - * // activate the cached autoloader - * $cachedLoader->register(); - * - * // eventually deactivate the non-cached loader if it was registered previously - * // to be sure to use the cached one. - * $loader->unregister(); - * - * @author Fabien Potencier - * @author Kris Wallsmith - * @author Kim Hemsø Rasmussen - */ -class XcacheClassLoader -{ - private $prefix; - - /** - * A class loader object that implements the findFile() method. - * - * @var object - */ - private $decorated; - - /** - * Constructor. - * - * @param string $prefix The XCache namespace prefix to use - * @param object $decorated A class loader object that implements the findFile() method - * - * @throws \RuntimeException - * @throws \InvalidArgumentException - */ - public function __construct($prefix, $decorated) - { - if (!extension_loaded('xcache')) { - throw new \RuntimeException('Unable to use XcacheClassLoader as XCache is not enabled.'); - } - - if (!method_exists($decorated, 'findFile')) { - throw new \InvalidArgumentException('The class finder must implement a "findFile" method.'); - } - - $this->prefix = $prefix; - $this->decorated = $decorated; - } - - /** - * Registers this instance as an autoloader. - * - * @param bool $prepend Whether to prepend the autoloader or not - */ - public function register($prepend = false) - { - spl_autoload_register(array($this, 'loadClass'), true, $prepend); - } - - /** - * Unregisters this instance as an autoloader. - */ - public function unregister() - { - spl_autoload_unregister(array($this, 'loadClass')); - } - - /** - * Loads the given class or interface. - * - * @param string $class The name of the class - * - * @return bool|null True, if loaded - */ - public function loadClass($class) - { - if ($file = $this->findFile($class)) { - require $file; - - return true; - } - } - - /** - * Finds a file by class name while caching lookups to Xcache. - * - * @param string $class A class name to resolve to file - * - * @return string|null - */ - public function findFile($class) - { - if (xcache_isset($this->prefix.$class)) { - $file = xcache_get($this->prefix.$class); - } else { - $file = $this->decorated->findFile($class) ?: null; - xcache_set($this->prefix.$class, $file); - } - - return $file; - } - - /** - * Passes through all unknown calls onto the decorated object. - */ - public function __call($method, $args) - { - return call_user_func_array(array($this->decorated, $method), $args); - } -} diff --git a/vendor/symfony/class-loader/composer.json b/vendor/symfony/class-loader/composer.json deleted file mode 100644 index 634c647c..00000000 --- a/vendor/symfony/class-loader/composer.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "name": "symfony/class-loader", - "type": "library", - "description": "Symfony ClassLoader Component", - "keywords": [], - "homepage": "https://symfony.com", - "license": "MIT", - "authors": [ - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "minimum-stability": "dev", - "require": { - "php": ">=5.5.9" - }, - "require-dev": { - "symfony/finder": "~2.8|~3.0", - "symfony/polyfill-apcu": "~1.1" - }, - "suggest": { - "symfony/polyfill-apcu": "For using ApcClassLoader on HHVM" - }, - "autoload": { - "psr-4": { "Symfony\\Component\\ClassLoader\\": "" }, - "exclude-from-classmap": [ - "/Tests/" - ] - }, - "extra": { - "branch-alias": { - "dev-master": "3.2-dev" - } - } -} diff --git a/vendor/symfony/class-loader/phpunit.xml.dist b/vendor/symfony/class-loader/phpunit.xml.dist deleted file mode 100644 index 5158b22f..00000000 --- a/vendor/symfony/class-loader/phpunit.xml.dist +++ /dev/null @@ -1,31 +0,0 @@ - - - - - - - - - - ./Tests/ - - - - - - ./ - - ./Resources - ./Tests - ./vendor - - - - diff --git a/vendor/topthink/think-captcha/src/Captcha.php b/vendor/topthink/think-captcha/src/Captcha.php index c97e49d9..6c7f8f4a 100644 --- a/vendor/topthink/think-captcha/src/Captcha.php +++ b/vendor/topthink/think-captcha/src/Captcha.php @@ -12,7 +12,6 @@ namespace think\captcha; use think\Session; -use think\Cache; /** * @property mixed seKey @@ -231,14 +230,7 @@ class Captcha $secode['verify_code'] = $code; // 把校验码保存到session $secode['verify_time'] = time(); // 验证码创建时间 Session::set($key . $id, $secode, ''); - //存储到数据库 -// Db::table('t_captcha')->insert(array( -// 'code'=>$code, -// 'vkey'=>md5($id), -// 'time'=> time() -// )); - //存储到缓存 - Cache::set(md5($id),$code,3600); + ob_start(); // 输出图像 imagepng($this->im);