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