1 // © 2016 and later: Unicode, Inc. and others. 2 // License & terms of use: http://www.unicode.org/copyright.html 3 /* 4 ******************************************************************************* 5 * 6 * Copyright (C) 1998-2014, International Business Machines 7 * Corporation and others. All Rights Reserved. 8 * 9 ******************************************************************************* 10 * 11 * File ufile.h 12 * 13 * Modification History: 14 * 15 * Date Name Description 16 * 12/01/98 stephen Creation. 17 * 03/12/99 stephen Modified for new C API. 18 ******************************************************************************* 19 */ 20 21 #ifndef UFILE_H 22 #define UFILE_H 23 24 #include "unicode/utypes.h" 25 26 #if !UCONFIG_NO_CONVERSION 27 28 #include <stdio.h> 29 30 #include "unicode/ucnv.h" 31 #include "unicode/utrans.h" 32 #include "locbund.h" 33 34 /* The buffer size for fromUnicode calls */ 35 #define UFILE_CHARBUFFER_SIZE 1024 36 37 /* The buffer size for toUnicode calls */ 38 #define UFILE_UCHARBUFFER_SIZE 1024 39 40 /* A UFILE */ 41 42 #if !UCONFIG_NO_TRANSLITERATION 43 44 typedef struct { 45 UChar *buffer; /* Beginning of buffer */ 46 int32_t capacity; /* Capacity of buffer */ 47 int32_t pos; /* Beginning of untranslitted data */ 48 int32_t length; /* Length *from beginning of buffer* of untranslitted data */ 49 UTransliterator *translit; 50 } UFILETranslitBuffer; 51 52 #endif 53 54 typedef struct u_localized_string { 55 UChar *fPos; /* current pos in fUCBuffer */ 56 const UChar *fLimit; /* data limit in fUCBuffer */ 57 UChar *fBuffer; /* Place to write the string */ 58 59 #if !UCONFIG_NO_FORMATTING 60 ULocaleBundle fBundle; /* formatters */ 61 #endif 62 } u_localized_string; 63 64 struct UFILE { 65 #if !UCONFIG_NO_TRANSLITERATION 66 UFILETranslitBuffer *fTranslit; 67 #endif 68 69 FILE *fFile; /* the actual filesystem interface */ 70 71 UConverter *fConverter; /* for codeset conversion */ 72 73 u_localized_string str; /* struct to handle strings for number formatting */ 74 75 UChar fUCBuffer[UFILE_UCHARBUFFER_SIZE];/* buffer used for toUnicode */ 76 77 UBool fOwnFile; /* TRUE if fFile should be closed */ 78 79 int32_t fFileno; /* File number. Useful to determine if it's stdin. */ 80 }; 81 82 /** 83 * Like u_file_write but takes a flush parameter 84 */ 85 U_CFUNC int32_t U_EXPORT2 86 u_file_write_flush( const UChar *chars, 87 int32_t count, 88 UFILE *f, 89 UBool flushIO, 90 UBool flushTranslit); 91 92 /** 93 * Fill a UFILE's buffer with converted codepage data. 94 * @param f The UFILE containing the buffer to fill. 95 */ 96 void 97 ufile_fill_uchar_buffer(UFILE *f); 98 99 /** 100 * Get one code unit and detect whether the end of file has been reached. 101 * @param f The UFILE containing the characters. 102 * @param ch The read in character 103 * @return TRUE if the character is valid, or FALSE when EOF has been detected 104 */ 105 U_CFUNC UBool U_EXPORT2 106 ufile_getch(UFILE *f, UChar *ch); 107 108 /** 109 * Get one character and detect whether the end of file has been reached. 110 * @param f The UFILE containing the characters. 111 * @param ch The read in character 112 * @return TRUE if the character is valid, or FALSE when EOF has been detected 113 */ 114 U_CFUNC UBool U_EXPORT2 115 ufile_getch32(UFILE *f, UChar32 *ch); 116 117 /** 118 * Close out the transliterator and flush any data therein. 119 * @param f flu 120 */ 121 void 122 ufile_close_translit(UFILE *f); 123 124 /** 125 * Flush the buffer in the transliterator 126 * @param f UFile to flush 127 */ 128 void 129 ufile_flush_translit(UFILE *f); 130 131 /** 132 * Flush the IO buffer 133 * @param f UFile to flush 134 */ 135 void 136 ufile_flush_io(UFILE *f); 137 138 139 #endif 140 #endif 141