K-means weightp
[x264-7mod.git] / common / osdep.c
blob1f393de8a80d612cf7c2ea3904f246c4bbef46e3
1 /*****************************************************************************
2 * osdep.c: platform-specific code
3 *****************************************************************************
4 * Copyright (C) 2003-2017 x264 project
6 * Authors: Steven Walters <kemuri9@gmail.com>
7 * Laurent Aimar <fenrir@via.ecp.fr>
8 * Henrik Gramner <henrik@gramner.com>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA.
24 * This program is also available under a commercial proprietary license.
25 * For more information, contact us at licensing@x264.com.
26 *****************************************************************************/
28 #include "common.h"
30 #ifdef _WIN32
31 #include <windows.h>
32 #include <io.h>
33 #endif
35 #if SYS_WINDOWS
36 #include <sys/types.h>
37 #include <sys/timeb.h>
38 #else
39 #include <sys/time.h>
40 #endif
41 #include <time.h>
43 #if PTW32_STATIC_LIB
44 /* this is a global in pthread-win32 to indicate if it has been initialized or not */
45 extern int ptw32_processInitialized;
46 #endif
48 int64_t x264_mdate( void )
50 #if SYS_WINDOWS
51 struct timeb tb;
52 ftime( &tb );
53 return ((int64_t)tb.time * 1000 + (int64_t)tb.millitm) * 1000;
54 #else
55 struct timeval tv_date;
56 gettimeofday( &tv_date, NULL );
57 return (int64_t)tv_date.tv_sec * 1000000 + (int64_t)tv_date.tv_usec;
58 #endif
61 #if HAVE_WIN32THREAD || PTW32_STATIC_LIB
62 /* state of the threading library being initialized */
63 static volatile LONG x264_threading_is_init = 0;
65 static void x264_threading_destroy( void )
67 #if PTW32_STATIC_LIB
68 pthread_win32_thread_detach_np();
69 pthread_win32_process_detach_np();
70 #else
71 x264_win32_threading_destroy();
72 #endif
75 int x264_threading_init( void )
77 /* if already init, then do nothing */
78 if( InterlockedCompareExchange( &x264_threading_is_init, 1, 0 ) )
79 return 0;
80 #if PTW32_STATIC_LIB
81 /* if static pthread-win32 is already initialized, then do nothing */
82 if( ptw32_processInitialized )
83 return 0;
84 if( !pthread_win32_process_attach_np() )
85 return -1;
86 #else
87 if( x264_win32_threading_init() )
88 return -1;
89 #endif
90 /* register cleanup to run at process termination */
91 atexit( x264_threading_destroy );
93 return 0;
95 #endif
97 #ifdef _WIN32
98 /* Functions for dealing with Unicode on Windows. */
99 FILE *x264_fopen( const char *filename, const char *mode )
101 wchar_t filename_utf16[MAX_PATH * 2];
102 wchar_t mode_utf16[16];
103 if( utf8_to_utf16( filename, filename_utf16 ) && utf8_to_utf16( mode, mode_utf16 ) )
104 return _wfopen( filename_utf16, mode_utf16 );
105 return NULL;
108 int x264_rename( const char *oldname, const char *newname )
110 wchar_t oldname_utf16[MAX_PATH * 2];
111 wchar_t newname_utf16[MAX_PATH * 2];
112 if( utf8_to_utf16( oldname, oldname_utf16 ) && utf8_to_utf16( newname, newname_utf16 ) )
114 /* POSIX says that rename() removes the destination, but Win32 doesn't. */
115 _wunlink( newname_utf16 );
116 return _wrename( oldname_utf16, newname_utf16 );
118 return -1;
121 int x264_stat( const char *path, x264_struct_stat *buf )
123 wchar_t path_utf16[MAX_PATH * 2];
124 if( utf8_to_utf16( path, path_utf16 ) )
125 return _wstati64( path_utf16, buf );
126 return -1;
129 #if !HAVE_WINRT
130 int x264_vfprintf( FILE *stream, const char *format, va_list arg )
132 HANDLE console = NULL;
133 DWORD mode;
135 if( stream == stdout )
136 console = GetStdHandle( STD_OUTPUT_HANDLE );
137 else if( stream == stderr )
138 console = GetStdHandle( STD_ERROR_HANDLE );
140 /* Only attempt to convert to UTF-16 when writing to a non-redirected console screen buffer. */
141 if( GetConsoleMode( console, &mode ) )
143 char buf[4096];
144 wchar_t buf_utf16[4096];
145 va_list arg2;
147 va_copy( arg2, arg );
148 int length = vsnprintf( buf, sizeof(buf), format, arg2 );
149 va_end( arg2 );
151 if( length > 0 && length < sizeof(buf) )
153 /* WriteConsoleW is the most reliable way to output Unicode to a console. */
154 int length_utf16 = MultiByteToWideChar( CP_UTF8, 0, buf, length, buf_utf16, sizeof(buf_utf16)/sizeof(wchar_t) );
155 DWORD written;
156 WriteConsoleW( console, buf_utf16, length_utf16, &written, NULL );
157 return length;
160 return vfprintf( stream, format, arg );
163 int x264_is_pipe( const char *path )
165 wchar_t path_utf16[MAX_PATH * 2];
166 if( utf8_to_utf16( path, path_utf16 ) )
167 return WaitNamedPipeW( path_utf16, 0 );
168 return 0;
170 #endif
172 #if defined(_MSC_VER) && _MSC_VER < 1900
173 /* MSVC pre-VS2015 has broken snprintf/vsnprintf implementations which are incompatible with C99. */
174 int x264_snprintf( char *s, size_t n, const char *fmt, ... )
176 va_list arg;
177 va_start( arg, fmt );
178 int length = x264_vsnprintf( s, n, fmt, arg );
179 va_end( arg );
180 return length;
183 int x264_vsnprintf( char *s, size_t n, const char *fmt, va_list arg )
185 int length = -1;
187 if( n )
189 va_list arg2;
190 va_copy( arg2, arg );
191 length = _vsnprintf( s, n, fmt, arg2 );
192 va_end( arg2 );
194 /* _(v)snprintf adds a null-terminator only if the length is less than the buffer size. */
195 if( length < 0 || length >= n )
196 s[n-1] = '\0';
199 /* _(v)snprintf returns a negative number if the length is greater than the buffer size. */
200 if( length < 0 )
201 return _vscprintf( fmt, arg );
203 return length;
205 #endif
206 #endif