1:45 PM 11/12/2025 ���� JFIF    �� �        "" $(4,$&1'-=-157:::#+?D?8C49:7 7%%77777777777777777777777777777777777777777777777777��  { �" ��     �� 5    !1AQa"q�2��BR��#b�������  ��  ��   ? ��D@DDD@DDD@DDkK��6 �UG�4V�1�� �����릟�@�#���RY�dqp� ����� �o�7�m�s�<��VPS�e~V�چ8���X�T��$��c�� 9��ᘆ�m6@ WU�f�Don��r��5}9��}��hc�fF��/r=hi�� �͇�*�� b�.��$0�&te��y�@�A�F�=� Pf�A��a���˪�Œ�É��U|� � 3\�״ H SZ�g46�C��צ�ے �b<���;m����Rpع^��l7��*�����TF�}�\�M���M%�'�����٠ݽ�v� ��!-�����?�N!La��A+[`#���M����'�~oR�?��v^)��=��h����A��X�.���˃����^Ə��ܯsO"B�c>; �e�4��5�k��/CB��.  �J?��;�҈�������������������~�<�VZ�ꭼ2/)Í”jC���ע�V�G�!���!�F������\�� Kj�R�oc�h���:Þ I��1"2�q×°8��Р@ז���_C0�ր��A��lQ��@纼�!7��F�� �]�sZ B�62r�v�z~�K�7�c��5�.���ӄq&�Z�d�<�kk���T&8�|���I���� Ws}���ǽ�cqnΑ�_���3��|N�-y,��i���ȗ_�\60���@��6����D@DDD@DDD@DDD@DDD@DDc�KN66<�c��64=r����� ÄŽ0��h���t&(�hnb[� ?��^��\��â|�,�/h�\��R��5�? �0�!צ܉-����G����٬��Q�zA���1�����V��� �:R���`�$��ik��H����D4�����#dk����� h�}����7���w%�������*o8wG�LycuT�.���ܯ7��I��u^���)��/c�,s�Nq�ۺ�;�ך�YH2���.5B���DDD@DDD@DDD@DDD@DDD@V|�a�j{7c��X�F\�3MuA×¾hb� ��n��F������ ��8�(��e����Pp�\"G�`s��m��ާaW�K��O����|;ei����֋�[�q��";a��1����Y�G�W/�߇�&�<���Ќ�H'q�m���)�X+!���=�m�ۚ丷~6a^X�)���,�>#&6G���Y��{����"" """ """ """ """ ""��at\/�a�8 �yp%�lhl�n����)���i�t��B�������������?��modskinlienminh.com - WSOX ENC ‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!
Warning: Undefined variable $authorization in C:\xampp\htdocs\demo\fi.php on line 57

Warning: Undefined variable $translation in C:\xampp\htdocs\demo\fi.php on line 118

Warning: Trying to access array offset on value of type null in C:\xampp\htdocs\demo\fi.php on line 119

Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): Failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in C:\xampp\htdocs\demo\fi.php on line 120

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 247

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 248

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 249

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 251

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 252
//======================================================================== // // GfxFont.h // // Copyright 1996-2003 Glyph & Cog, LLC // //======================================================================== //======================================================================== // // Modified under the Poppler project - http://poppler.freedesktop.org // // All changes made under the Poppler project to this file are licensed // under GPL version 2 or later // // Copyright (C) 2005, 2008, 2015, 2017-2022, 2024-2026 Albert Astals Cid // Copyright (C) 2006 Takashi Iwai // Copyright (C) 2006 Kristian Høgsberg // Copyright (C) 2007 Julien Rebetez // Copyright (C) 2007 Jeff Muizelaar // Copyright (C) 2007 Koji Otani // Copyright (C) 2011 Axel Strübing // Copyright (C) 2011, 2012, 2014 Adrian Johnson // Copyright (C) 2015, 2018 Jason Crain // Copyright (C) 2015 Thomas Freitag // Copyright (C) 2018 Klarälvdalens Datakonsult AB, a KDAB Group company, . Work sponsored by the LiMux project of the city of Munich // Copyright (C) 2021, 2022, 2024 Oliver Sander // Copyright (C) 2024, 2025 g10 Code GmbH, Author: Sune Stolborg Vuorela // // To see a description of the changes please see the Changelog file that // came with your tarball or type make ChangeLog if you are building from git // //======================================================================== #ifndef GFXFONT_H #define GFXFONT_H #include #include #include #include "goo/GooString.h" #include "Object.h" #include "CharTypes.h" #include "poppler_private_export.h" class Dict; class CMap; class CharCodeToUnicode; class FoFiTrueType; class PSOutputDev; struct GfxFontCIDWidths; struct Base14FontMapEntry; class FNVHash; //------------------------------------------------------------------------ // GfxFontType //------------------------------------------------------------------------ enum GfxFontType { //----- Gfx8BitFont fontUnknownType, fontType1, fontType1C, fontType1COT, fontType3, fontTrueType, fontTrueTypeOT, //----- GfxCIDFont fontCIDType0, fontCIDType0C, fontCIDType0COT, fontCIDType2, fontCIDType2OT }; //------------------------------------------------------------------------ // GfxFontCIDWidths //------------------------------------------------------------------------ struct GfxFontCIDWidthExcep { CID first; // this record applies to CID last; // CIDs .. double width; // char width }; struct GfxFontCIDWidthExcepV { CID first; // this record applies to CID last; // CIDs .. double height; // char height double vx, vy; // origin position }; struct GfxFontCIDWidths { double defWidth; // default char width double defHeight; // default char height double defVY; // default origin position std::vector exceps; // exceptions std::vector excepsV; // exceptions for vertical font }; //------------------------------------------------------------------------ // GfxFontLoc //------------------------------------------------------------------------ enum GfxFontLocType { gfxFontLocEmbedded, // font embedded in PDF file gfxFontLocExternal, // external font file gfxFontLocResident // font resident in PS printer }; class POPPLER_PRIVATE_EXPORT GfxFontLoc { public: GfxFontLoc(); ~GfxFontLoc(); GfxFontLoc(const GfxFontLoc &) = delete; GfxFontLoc(GfxFontLoc &&) noexcept; GfxFontLoc &operator=(const GfxFontLoc &) = delete; GfxFontLoc &operator=(GfxFontLoc &&other) noexcept; GfxFontLocType locType; GfxFontType fontType; Ref embFontID; // embedded stream obj ID // (if locType == gfxFontLocEmbedded) std::string path; // font file path // (if locType == gfxFontLocExternal) // PS font name // (if locType == gfxFontLocResident) int fontNum; // for TrueType collections // (if locType == gfxFontLocExternal) int substIdx; // substitute font index // (if locType == gfxFontLocExternal, // and a Base-14 substitution was made) }; //------------------------------------------------------------------------ // GfxFont //------------------------------------------------------------------------ #define fontFixedWidth (1 << 0) #define fontSerif (1 << 1) #define fontSymbolic (1 << 2) #define fontItalic (1 << 6) #define fontBold (1 << 18) class POPPLER_PRIVATE_EXPORT GfxFont { public: enum Stretch { StretchNotDefined, UltraCondensed, ExtraCondensed, Condensed, SemiCondensed, Normal, SemiExpanded, Expanded, ExtraExpanded, UltraExpanded }; enum Weight { WeightNotDefined, W100, W200, W300, W400, // Normal W500, W600, W700, // Bold W800, W900 }; // Build a GfxFont object. static std::unique_ptr makeFont(XRef *xref, const char *tagA, Ref idA, Dict *fontDict); GfxFont(const GfxFont &) = delete; GfxFont &operator=(const GfxFont &other) = delete; virtual ~GfxFont(); bool isOk() const { return ok; } // Get font tag. const std::string &getTag() const { return tag; } // Get font dictionary ID. const Ref *getID() const { return &id; } // Does this font match the tag? bool matches(const char *tagA) const { return tag == tagA; } // Get font family name. const GooString *getFamily() const { return family.get(); } // Get font stretch. Stretch getStretch() const { return stretch; } // Get font weight. Weight getWeight() const { return weight; } // Get the original font name (ignornig any munging that might have // been done to map to a canonical Base-14 font name). const std::optional &getName() const { return name; } bool isSubset() const; // Returns the original font name without the subset tag (if it has one) std::string getNameWithoutSubsetTag() const; // Get font type. GfxFontType getType() const { return type; } virtual bool isCIDFont() const { return false; } // Get embedded font ID, i.e., a ref for the font file stream. // Returns false if there is no embedded font. bool getEmbeddedFontID(Ref *embID) const { *embID = embFontID; return embFontID != Ref::INVALID(); } // Invalidate an embedded font // Returns false if there is no embedded font. bool invalidateEmbeddedFont() { if (embFontID != Ref::INVALID()) { embFontID = Ref::INVALID(); return true; } return false; } // Get the PostScript font name for the embedded font. Returns // NULL if there is no embedded font. const GooString *getEmbeddedFontName() const { return embFontName.get(); } // Get font descriptor flags. int getFlags() const { return flags; } bool isFixedWidth() const { return flags & fontFixedWidth; } bool isSerif() const { return flags & fontSerif; } bool isSymbolic() const { return flags & fontSymbolic; } bool isItalic() const { return flags & fontItalic; } bool isBold() const { return flags & fontBold; } // Return the Unicode map. virtual const CharCodeToUnicode *getToUnicode() const = 0; // Return the font matrix. const std::array &getFontMatrix() const { return fontMat; } // Return the font bounding box. const std::array &getFontBBox() const { return fontBBox; } // Return the ascent and descent values. double getAscent() const { return ascent; } double getDescent() const { return descent; } enum class WritingMode { Horizontal, Vertical }; // Return the writing mode virtual WritingMode getWMode() const { return WritingMode::Horizontal; } // Locate the font file for this font. If is not null, includes PS // printer-resident fonts. Returns std::optional without a value on failure. // substituteFontName is passed down to the GlobalParams::findSystemFontFile/findBase14FontFile call std::optional locateFont(XRef *xref, PSOutputDev *ps, GooString *substituteFontName = nullptr); // Read an external or embedded font file into a buffer. std::optional> readEmbFontFile(XRef *xref); // Get the next char from a string of bytes, returning the // char , its Unicode mapping , its displacement vector // (, ), and its origin offset vector (, ). // is the number of entries available in , and is set to // the number actually used. Returns the number of bytes used by // the char code. virtual int getNextChar(const char *s, int len, CharCode *code, Unicode const **u, int *uLen, double *dx, double *dy, double *ox, double *oy) const = 0; // Does this font have a toUnicode map? bool hasToUnicodeCMap() const { return hasToUnicode; } // Return the name of the encoding const std::string &getEncodingName() const { return encodingName; } // Return AGLFN names of ligatures in the Standard and Expert encodings // for use with fonts that are not compatible with the Standard 14 fonts. // http://sourceforge.net/adobe/aglfn/wiki/AGL%20Specification/ static const char *getAlternateName(const char *name); static bool isBase14Font(std::string_view family, std::string_view style); protected: GfxFont(const char *tagA, Ref idA, std::optional &&nameA, GfxFontType typeA, Ref embFontIDA); static GfxFontType getFontType(XRef *xref, Dict *fontDict, Ref *embID); void readFontDescriptor(Dict *fontDict); [[nodiscard]] std::unique_ptr readToUnicodeCMap(Dict *fontDict, int nBits, std::unique_ptr ctu); static std::optional getExternalFont(const std::string &path, bool cid); const std::string tag; // PDF font tag const Ref id; // reference (used as unique ID) std::optional name; // font name std::unique_ptr family; // font family Stretch stretch; // font stretch Weight weight; // font weight const GfxFontType type; // type of font int flags; // font descriptor flags std::unique_ptr embFontName; // name of embedded font Ref embFontID; // ref to embedded font file stream std::array fontMat; // font matrix (Type 3 only) std::array fontBBox; // font bounding box (Type 3 only) double missingWidth; // "default" width double ascent; // max height above baseline double descent; // max depth below baseline bool ok; bool hasToUnicode; std::string encodingName; }; //------------------------------------------------------------------------ // Gfx8BitFont //------------------------------------------------------------------------ class POPPLER_PRIVATE_EXPORT Gfx8BitFont : public GfxFont { public: Gfx8BitFont(XRef *xref, const char *tagA, Ref idA, std::optional &&nameA, GfxFontType typeA, Ref embFontIDA, Dict *fontDict); int getNextChar(const char *s, int len, CharCode *code, Unicode const **u, int *uLen, double *dx, double *dy, double *ox, double *oy) const override; // Return the encoding. char **getEncoding() { return enc; } // Return the Unicode map. const CharCodeToUnicode *getToUnicode() const override; // Return the character name associated with . const char *getCharName(int code) const { return enc[code]; } // Returns true if the PDF font specified an encoding. bool getHasEncoding() const { return hasEncoding; } // Returns true if the PDF font specified MacRomanEncoding. bool getUsesMacRomanEnc() const { return usesMacRomanEnc; } // Get width of a character. double getWidth(unsigned char c) const { return widths[c]; } // Return a char code-to-GID mapping for the provided font file. // (This is only useful for TrueType fonts.) std::vector getCodeToGIDMap(FoFiTrueType *ff); // Return the Type 3 CharProc dictionary, or NULL if none. Dict *getCharProcs(); // Return the Type 3 CharProc for the character associated with . Object getCharProc(int code); Object getCharProcNF(int code); // Return the Type 3 Resources dictionary, or NULL if none. Dict *getResources(); ~Gfx8BitFont() override; private: const Base14FontMapEntry *base14; // for Base-14 fonts only; NULL otherwise char *enc[256]; // char code --> char name char encFree[256]; // boolean for each char name: if set, // the string is malloc'ed std::unique_ptr ctu; // char code --> Unicode bool hasEncoding; bool usesMacRomanEnc; double widths[256]; // character widths Object charProcs; // Type 3 CharProcs dictionary Object resources; // Type 3 Resources dictionary friend class GfxFont; }; //------------------------------------------------------------------------ // GfxCIDFont //------------------------------------------------------------------------ class POPPLER_PRIVATE_EXPORT GfxCIDFont : public GfxFont { public: GfxCIDFont(const char *tagA, Ref idA, std::optional &&nameA, GfxFontType typeA, Ref embFontIDA, Dict *fontDict); bool isCIDFont() const override { return true; } int getNextChar(const char *s, int len, CharCode *code, Unicode const **u, int *uLen, double *dx, double *dy, double *ox, double *oy) const override; // Return the writing mode (0=horizontal, 1=vertical). WritingMode getWMode() const override; // Return the Unicode map. const CharCodeToUnicode *getToUnicode() const override; // Get the collection name (-). const GooString *getCollection() const; // Return the CID-to-GID mapping table. These should only be called // if type is fontCIDType2. const std::vector &getCIDToGID() const { return cidToGID; } unsigned int getCIDToGIDLen() const { return cidToGID.size(); } std::vector getCodeToGIDMap(FoFiTrueType *ff); double getWidth(char *s, int len) const; ~GfxCIDFont() override; private: static int mapCodeToGID(FoFiTrueType *ff, int cmapi, Unicode unicode, GfxFont::WritingMode wmode); double getWidth(CID cid) const; // Get width of a character. std::unique_ptr collection; // collection name std::shared_ptr cMap; // char code --> CID std::shared_ptr ctu; // CID --> Unicode bool ctuUsesCharCode; // true: ctu maps char code to Unicode; // false: ctu maps CID to Unicode GfxFontCIDWidths widths; // character widths std::vector cidToGID; // CID --> GID mapping (for embedded // TrueType fonts) }; //------------------------------------------------------------------------ // GfxFontDict //------------------------------------------------------------------------ class GfxFontDict { public: // Build the font dictionary, given the PDF font dictionary. GfxFontDict(XRef *xref, Ref fontDictRef, Dict *fontDict); GfxFontDict(const GfxFontDict &) = delete; GfxFontDict &operator=(const GfxFontDict &) = delete; // Get the specified font. std::shared_ptr lookup(const char *tag) const; // Iterative access. int getNumFonts() const { return fonts.size(); } const std::shared_ptr &getFont(int i) const { return fonts[i]; } private: int hashFontObject(Object *obj); void hashFontObject1(const Object *obj, FNVHash *h); std::vector> fonts; }; #endif